From 3d362f278faf97828cb1959514f9c219b33ebe3f Mon Sep 17 00:00:00 2001 From: Danny Willems Date: Wed, 4 Oct 2023 12:21:53 +0200 Subject: [PATCH] Regenerate bindings after stopping using ptr attr --- compiled/node_bindings/snarky_js_node.bc.cjs | 6 +++--- compiled/node_bindings/snarky_js_node.bc.map | 2 +- compiled/web_bindings/snarky_js_web.bc.js | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/compiled/node_bindings/snarky_js_node.bc.cjs b/compiled/node_bindings/snarky_js_node.bc.cjs index d54674f8..e46adade 100755 --- a/compiled/node_bindings/snarky_js_node.bc.cjs +++ b/compiled/node_bindings/snarky_js_node.bc.cjs @@ -2421,7 +2421,7 @@ return res} function js_class_vector_to_rust_vector(v) {var len=v.length,res=new (globalThis.Uint32Array)(len); - for(var i=0;i < len;i++)res[i] = v[i].ptr; + for(var i=0;i < len;i++)res[i] = v[i].__wbg_ptr; return res} var free_finalization_registry= @@ -2459,7 +2459,7 @@ rust_affine_to_caml_affine, false)} function free_on_finalize(x) - {var instance_representative=x.constructor.__wrap(x.ptr); + {var instance_representative=x.constructor.__wrap(x.__wbg_ptr); free_finalization_registry.register(x,instance_representative,x); return x} function caml_fp_srs_create(i) @@ -5079,7 +5079,7 @@ || tag} function wrap(ptr,klass) - {var obj=Object.create(klass.prototype);obj.ptr = ptr;return obj} + {var obj=Object.create(klass.prototype);obj.__wbg_ptr = ptr;return obj} function index_term_of_rust(term,token_class) {var column=column_of_rust(term.column), diff --git a/compiled/node_bindings/snarky_js_node.bc.map b/compiled/node_bindings/snarky_js_node.bc.map index e4fb3d30..f1261d19 100755 --- a/compiled/node_bindings/snarky_js_node.bc.map +++ b/compiled/node_bindings/snarky_js_node.bc.map @@ -1 +1 @@ -{"version":3.0,"file":"snarky_js_node.bc.js","sourceRoot":"","names":["Object","globalThis","this","get","_T_","global","self","DefaultLocale","defaultStrftime","Strftime","isCommonJS","module","namespace","adaptedStrftime","deprecatedStrftime","joo_global_object","eval","_require","_deprecationWarnings","deprecationWarning","name","instead","console","deprecatedStrftimeTZ","deprecatedStrftimeUTC","deprecatedStrftimeLocalized","adaptForwards","fn","fmt","d","locale","undefined","strftime","timezone","null","utcStrftime","Date","customTimezoneOffset","useUtcTimezone","_locale","_customTimezoneOffset","_useUtcBasedDate","_cachedDateTimestamp","_cachedDate","_strftime","format","date","timestamp","currentTimestamp","getTimestampToUtcOffsetFor","_processFormat","resultString","padding","isInScope","length","extendedTZ","i","currentCharCode","padTill2","Math","hours12","padTill3","weekNumber","tzString","y","day","String","ordinal","off","sign","sep","hours","mins","useUtcBasedDate","timezoneType","parseInt","minutes","numberToPad","paddingChar","hour","firstWeekday","weekday","firstDayOfYearUtc","dateUtc","yday","weekNum","number","ii","Base_am_testing","x","caml_mul","a","b","caml_hash_mix_int","h","caml_hash_mix_jsbytes","s","len","w","log2_ok","jsoo_floor_log2","Infinity","caml_int64_offset","caml_raise_constant","tag","caml_global_data","caml_raise_zero_divide","MlInt64","lo","mi","hi","xhi","offset","modulus","divisor","quotient","q","r","caml_int64_create_lo_mi_hi","caml_int64_bits_of_float","isFinite","isNaN","exp","k","r3","r2","r1","caml_int64_lo32","v","caml_int64_hi32","caml_hash_mix_int64","caml_hash_mix_float","v0","caml_str_repeat","n","l","caml_subarray_to_jsbytes","f","caml_convert_string_to_bytes","caml_jsbytes_of_string","caml_hash_mix_string","caml_hash_mix_bytes_arr","jsoo_is_ascii","caml_utf16_of_utf8","t","c","c1","c2","j","MlBytes","contents","content","caml_ml_bytes_content","caml_hash_mix_bytes","caml_int32_bits_of_float","float32a","int32a","caml_int64_to_bytes","caml_ba_serialize","writer","ba","sz","complex","caml_raise_with_string","msg","caml_invalid_argument","caml_ba_get_size_per_element","kind","caml_ba_create_buffer","size","g","view","data","caml_int32_float_of_bits","caml_int64_of_bytes","caml_int64_float_of_bits","NaN","res","caml_ba_get_size","dims","n_dims","caml_int64_create_lo_hi","caml_array_bound_error","caml_ba_custom_name","Ml_Bigarray","layout","buffer","arg","ofs","Array","im","re","total","k1","k2","Ml_Bigarray_c_1_1","caml_ba_create_unsafe","size_per_element","caml_bytes_of_jsbytes","caml_string_of_jsbytes","caml_failwith","caml_ba_deserialize","reader","num_dims","size_dim","size_dim_hi","size_dim_lo","sixty","int64","caml_ba_compare","caml_ba_hash","num_elts","caml_int32_unmarshal","caml_nativeint_unmarshal","caml_int64_unmarshal","caml_int64_marshal","sizes","caml_int64_compare","caml_int64_hash","caml_custom_ops","caml_hash_mix_final","caml_is_ml_bytes","caml_is_ml_string","caml_hash","count","limit","seed","obj","queue","rd","wr","num","hh","Base_hash_double","Base_hash_string","Base_int_math_int32_clz","Base_int_math_int32_ctz","caml_int64_shift_right_unsigned","caml_int64_is_zero","caml_int64_to_int32","Base_int_math_int64_clz","caml_int64_and","caml_int64_of_int32","Base_int_math_int64_ctz","is_zero","land","small_int64","caml_int64_mul","Base_int_math_int64_pow_stub","base","exponent","one","mul","Base_int_math_int_clz","Base_int_math_int_ctz","Base_int_math_int_popcount","Base_int_math_int_pow_stub","Base_int_math_nativeint_clz","Base_int_math_nativeint_ctz","Base_internalhash_fold_float","Base_internalhash_fold_int","Base_internalhash_fold_int64","Base_internalhash_fold_string","Base_internalhash_get_hash_value","incr_nat","nat","carry_in","carry","add_nat","nat1","ofs1","len1","nat2","ofs2","len2","caml_js_from_array","caml_ba_create","dims_ml","bigstring_alloc","_","caml_ml_bytes_length","caml_convert_bytes_to_array","caml_blit_bytes","s1","i1","s2","i2","caml_bytes_of_array","caml_bigstring_blit_ba_to_bytes","ba1","pos1","bytes2","pos2","slice","bigstring_blit_bigstring_bytes_stub","src","src_pos","dst","dst_pos","caml_array_of_bytes","caml_bigstring_blit_bytes_to_ba","str1","ba2","bigstring_blit_bytes_bigstring_stub","caml_ml_string_length","caml_bytes_unsafe_get","caml_string_unsafe_get","caml_array_of_string","caml_bigstring_blit_string_to_ba","bigstring_blit_string_bigstring_stub","caml_bigstring_blit_ba_to_ba","bigstring_blit_stub","caml_bytes_unsafe_set","caml_string_unsafe_set","caml_ba_get_1","i0","bigstringaf_blit_to_bytes","src_off","dst_off","bin_prot_blit_buf_bytes_stub","caml_check_bound","array","index","caml_check_bound_bigstring","bigstring","bin_prot_blit_buf_float_array_stub","bin_prot_blit_float_array_buf_stub","float64","float64_uint8","bin_prot_blit_string_buf_stub","blit_nat","caml_array_append","a1","a2","l1","l2","caml_array_blit","caml_array_concat","caml_array_fill","caml_array_set","newval","caml_array_sub","caml_ba_blit","caml_ba_dim","caml_ba_dim_1","caml_ba_dim_2","caml_ba_get_2","caml_ba_layout","caml_ba_set_1","caml_ba_set_2","caml_ba_sub","changed_dim","new_dims","new_data","caml_ba_uint8_get16","b1","b2","caml_ba_uint8_get32","b3","b4","caml_ba_uint8_get64","b5","b6","b7","b8","caml_ba_uint8_set16","caml_ba_uint8_set32","caml_ba_uint8_set64","caml_backtrace_status","plonk_wasm","require","caml_bigint_256_bytes_per_limb","caml_bigint_256_compare","caml_bigint_256_div","caml_bigint_256_num_limbs","caml_bytes_to_uint8array","ocaml_bytes","bytes","caml_bigint_256_of_bytes","caml_jsstring_of_string","caml_bigint_256_of_decimal_string","caml_bigint_256_of_numeral","caml_bigint_256_print","caml_js_to_bool","caml_bigint_256_test_bit","caml_create_bytes","caml_bytes_of_uint8array","uint8array","caml_bigint_256_to_bytes","caml_utf8_of_utf16","caml_bytes_of_utf16_jsstring","caml_string_of_jsstring","caml_bigint_256_to_string","caml_bytes_of_string","caml_blit_string","e","caml_bswap16","caml_bytes_bound_error","caml_bytes_get","caml_bytes_get16","caml_bytes_set","caml_bytes_set16","i16","caml_bytes_set32","i32","caml_bytes_set64","i64","caml_call_gen","args","argsLen","extra_args","arguments","nargs","caml_classify_float","caml_compare_val_get_custom","caml_compare_val_number_custom","custom","swap","comp","caml_compare_val_tag","Number","caml_int_compare","caml_bytes_compare","caml_string_compare","caml_compare_val","stack","tag_a","tag_b","caml_compare","caml_convert_raw_backtrace","caml_convert_raw_backtrace_slot","caml_div","caml_ephe_key_offset","caml_weak_create","caml_ephe_create","caml_ephe_data_offset","caml_ephe_get_data","caml_ephe_set_data","caml_weak_set","caml_ephe_set_key","caml_equal","caml_fill_bytes","caml_final_register","caml_float_compare","caml_float_of_string","m","m3","mantissa","caml_parse_format","caml_finish_formatting","rawbuffer","caml_format_float","toFixed","dp","prec","p","caml_format_int","rust_affine_to_caml_affine","pt","infinity","js_class_vector_of_rust_vector","klass","caml_array_of_rust_vector","convert","should_free","rust_val","caml_poly_comm_of_rust_poly_comm","poly_comm","rust_shifted","rust_unshifted","caml_shifted","caml_unshifted","caml_vesta_poly_comm_of_rust","caml_u8array_vector_to_rust_flat_vector","inner_len","pos","caml_fp_srs_b_poly_commitment","srs","chals","rust_affine_of_caml_affine","js_class_vector_to_rust_vector","free_finalization_registry","instance_representative","caml_array_to_rust_vector","mk_new","class_val","caml_fp_vector_to_rust","caml_fp_srs_batch_accumulator_check","comms","rust_comms","rust_chals","ok","caml_fp_srs_batch_accumulator_generate","free_on_finalize","caml_fp_srs_create","caml_fp_srs_h","caml_fp_srs_lagrange_commitment","domain_size","caml_fp_srs_read","path","caml_fp_srs_write","append","caml_fp_vector_create","caml_fp_vector_emplace_back","caml_fp_vector_get","value","Error","caml_fp_vector_length","caml_fq_srs_add_lagrange_basis","log2_size","caml_pallas_poly_comm_of_rust","caml_fq_srs_b_poly_commitment","caml_fq_srs_create","caml_fq_srs_h","caml_fq_srs_lagrange_commitment","caml_fq_srs_read","caml_fq_srs_write","caml_fq_vector_create","caml_fq_vector_emplace_back","caml_fq_vector_get","caml_fq_vector_length","caml_oo_last_id","caml_fresh_oo_id","caml_frexp_float","neg","fs_node_supported","make_path_is_absolute","posix","win32","splitDeviceRe","result","device","isUnc","Boolean","root","path_is_absolute","caml_trailing_slash","caml_current_dir","caml_make_path","comp0","ncomp","unix_error","make_unix_err_args","code","syscall","errno","variant","caml_named_values","caml_named_value","nm","caml_raise_with_args","caml_raise_sys_error","caml_raise_no_such_file","MlFile","MlFakeFile","old","buf","clen","new_str","old_data","MlFakeDevice","Symbol","name_slash","mode","raise_unix","parent","RegExp","seen","file","MlNodeFile","fd","err","buf_offset","MlNodeDevice","consts","key","o","js_stats","to_dir","target","link","file_kind","caml_get_root","caml_root","jsoo_mount_point","resolve_fs_device","caml_create_file","jsoo_create_file","caml_fs_init","tmp","caml_gc_quick_stat","caml_get_current_callstack","caml_get_exception_raw_backtrace","caml_method_cache","caml_get_public_method","cacheid","meths","li","caml_greaterequal","caml_greaterthan","caml_hexstring_of_float","style","exp_sign","sign_str","cst","x_str","idx","caml_marshal_data_size","get32","MlStringReader","caml_float_of_bytes","caml_input_value_from_reader","_magic","_block_len","num_objects","_size_32","_size_64","intern_obj_table","obj_counter","intern_rec","header","ops","expected_size","old_pos","caml_string_of_bytes","caml_input_value_from_bytes","caml_ml_channels","caml_input_value","chanid","chan","caml_int32_bswap","caml_int64_add","caml_int64_bswap","caml_int64_div","caml_int64_is_negative","caml_int64_neg","caml_int64_format","wbase","cvtbl","caml_int64_mod","caml_int64_of_float","caml_int64_ult","caml_parse_sign_and_base","caml_parse_digit","caml_int64_of_string","base64","threshold","caml_int64_or","caml_int64_shift_left","caml_int64_shift_right","caml_int64_sub","caml_int64_to_float","caml_int64_xor","caml_int_of_string","caml_js_eval_string","caml_js_to_array","caml_js_wrap_callback","caml_js_wrap_meth_callback","caml_lazy_make_forward","caml_ldexp_float","caml_lessequal","caml_lessthan","caml_lex_array","caml_lex_engine","tbl","start_state","lexbuf","lex_buffer","lex_buffer_len","lex_start_pos","lex_curr_pos","lex_last_pos","lex_last_action","lex_eof_reached","lex_base","lex_backtrk","lex_default","lex_trans","lex_check","state","backtrk","caml_list_of_js_array","caml_log10_float","caml_make_float_vect","caml_make_vect","init","caml_string_of_array","caml_md5_bytes","add","xx","ff","gg","md5","caml_md5_string","caml_ml_channel_size","caml_ml_channel_size_64","caml_sys_close","caml_ml_flush","output","caml_ml_close_channel","caml_ml_debug_info_status","caml_ml_refill_input","str","str_len","caml_ml_input","caml_ml_may_refill_input","caml_raise_end_of_file","caml_ml_input_char","caml_ml_input_int","caml_std_output","slen","js_print_stderr","js_print_stdout","caml_sys_open_internal","flags","info","caml_sys_open","_perms","caml_ml_open_descriptor_in","refill","fs","channel","caml_ml_open_descriptor_out","caml_ml_out_channels_list","caml_ml_output_bytes","string","jsstring","id","caml_ml_output","caml_ml_output_char","caml_ml_output_int","arr","caml_ml_pos_in","caml_ml_pos_in_64","caml_ml_pos_out","caml_ml_pos_out_64","caml_ml_seek_in","caml_ml_seek_in_64","caml_ml_seek_out","caml_ml_seek_out_64","caml_ml_set_binary_mode","caml_ml_set_channel_name","caml_mod","caml_modf_float","caml_lex_run_mem","mem","curr_pos","caml_lex_run_tag","caml_new_lex_engine","lex_mem","lex_base_code","lex_backtrk_code","lex_default_code","lex_trans_code","lex_check_code","lex_code","pc_off","pstate","base_code","caml_notequal","caml_obj_block","caml_obj_make_forward","caml_obj_tag","Function","caml_out_channel_pos_fd","MlObjectTable","NaiveLookup","objs","caml_list_to_js_array","caml_legacy_custom_code","caml_output_val","Writer","no_sharing","closures","memo","existing_offset","extern_rec","sz_32_64","header_pos","type_of_v","caml_output_value_to_buffer","caml_pallas_add","caml_pallas_double","caml_pallas_endo_base","caml_pallas_endo_scalar","caml_pallas_negate","caml_pallas_of_affine_coordinates","caml_pallas_one","caml_pallas_random","caml_pallas_scale","caml_pallas_sub","caml_pallas_to_affine","caml_pasta_fp_add","caml_pasta_fp_copy","caml_pasta_fp_div","caml_pasta_fp_domain_generator","caml_pasta_fp_equal","caml_option_of_maybe_undefined","caml_pasta_fp_inv","caml_pasta_fp_is_square","caml_pasta_fp_mul","caml_pasta_fp_mut_add","caml_pasta_fp_mut_mul","caml_pasta_fp_square","caml_pasta_fp_mut_square","caml_pasta_fp_sub","caml_pasta_fp_mut_sub","caml_pasta_fp_negate","caml_pasta_fp_of_bigint","caml_pasta_fp_of_bytes","caml_pasta_fp_of_int","caml_pasta_fp_of_string","caml_pasta_fp_plonk_circuit_serialize","public_input_size","gate_vector","caml_plonk_wire_to_rust","wire","caml_plonk_wires_to_rust","wires","caml_fp_plonk_gate_to_rust","gate","caml_pasta_fp_plonk_gate_vector_add","caml_pasta_fp_plonk_gate_vector_create","caml_pasta_fp_plonk_gate_vector_digest","caml_plonk_wire_of_rust","caml_plonk_wires_of_rust","caml_u8array_vector_of_rust_flat_vector","output_len","inner_res","caml_plonk_gate_of_rust","caml_pasta_fp_plonk_gate_vector_get","caml_pasta_fp_plonk_gate_vector_len","caml_pasta_fp_plonk_gate_vector_wrap","caml_fp_runtime_table_cfg_to_rust","caml_runtime_table_cfg","mk_class","caml_runtime_table_cfg_id","caml_runtime_table_cfg_first_column","caml_fp_vector_of_rust","caml_fp_lookup_table_to_rust","caml_lookup_table","caml_lookup_table_id","caml_lookup_table_data","lt_data_length","caml_pasta_fp_plonk_index_create","gates","public_inputs","caml_lookup_tables","caml_runtime_table_cfgs","prev_challenges","urs","wasm_lookup_tables","wasm_runtime_table_cfgs","caml_pasta_fp_plonk_index_create_bytecode","caml_pasta_fp_plonk_index_read","caml_pasta_fp_plonk_index_write","caml_poly_comm_to_rust_poly_comm","poly_comm_class","mk_affine","caml_vesta_poly_comm_to_rust","caml_plonk_domain_to_rust","caml_plonk_verification_evals_to_rust","poly_comm_to_rust","convert_opt","poly_comm_opt","convertArray","sigma_comm","coefficients_comm","generic_comm","psm_comm","complete_add_comm","mul_comm","emul_comm","endomul_scalar_comm","xor_comm","range_check0_comm","range_check1_comm","foreign_field_add_comm","foreign_field_mul_comm","rot_comm","caml_plonk_verification_shifts_to_rust","caml_lookup_table_to_rust","wasm_lookup_table","None","caml_is_none","caml_opt_to_rust","caml_optional_value","to_rust","caml_lookup_selectors_to_rust","wasm_lookup_selectors","xor","lookup","range_check","ffmul","caml_lookup_patterns_to_rust","wasm_lookup_patterns","foreign_field_mul","caml_lookup_features_to_rust","wasm_lookup_features","patterns","joint_lookup_used","uses_runtime_tables","caml_lookup_info_to_rust","wasm_lookup_info","max_per_row","max_poly_size","features","caml_plonk_lookup_verifier_index_to_rust","caml_lookup_verifier_index","lookup_selectors_class","lookup_table","lookup_selectors","table_ids","lookup_info","runtime_tables_selector","caml_plonk_verifier_index_to_rust","domain_class","verification_evals_class","verification_shifts_class","lookup_verifier_index_class","domain","public_","evals","shifts","lookup_index_to_rust","lidx","wasm_lookup_index","caml_pasta_fp_plonk_verifier_index_to_rust","caml_fp_lookup_commitments_to_rust","caml_lc","wasm_sorted","wasm_aggreg","wasm_runtime","caml_pasta_fp_commitments_to_rust","w_comm","z_comm","t_comm","caml_pasta_fp_opening_proof_to_rust","convert_affines","affines","lr","delta","z1","z2","sg","l_ocaml","r_ocaml","PERMUTS_MINUS_1","COLUMNS","caml_pasta_fp_proof_evaluations_to_rust","caml_pasta_fp_proof_to_rust","public_evals","commitments","proof","evals_actual","ft_eval1","chals_len","prev_challenges_scalars","prev_challenges_comms","caml_pasta_fp_plonk_proof_batch_verify","indexes","proofs","caml_fp_lookup_commitments_of_rust","wasm_lc","sorted","aggreg","wasm_lc_runtime","caml_runtime","caml_opt_of_rust","value_of_rust","caml_pasta_fp_commitments_of_rust","caml_lookup","caml_pasta_fp_opening_proof_of_rust","tuple","caml_pasta_fp_proof_evaluations_of_rust","caml_pasta_fp_proof_of_rust","messages","caml_fp_runtime_table_to_rust","caml_runtime_table","caml_runtime_table_id","caml_runtime_table_data","caml_pasta_fp_plonk_proof_create","witness_cols","caml_runtime_tables","prev_sgs","wasm_runtime_tables","caml_pasta_fp_plonk_proof_example_with_ffadd","caml_pasta_fp_plonk_proof_example_with_lookup","caml_pasta_fp_plonk_proof_example_with_range_check","caml_pasta_fp_plonk_proof_example_with_range_check0","caml_pasta_fp_plonk_proof_example_with_rot","caml_pasta_fp_plonk_proof_example_with_xor","caml_pasta_fp_plonk_proof_verify","column_of_rust","col","gate_type","variable_of_rust","variable","row","polish_token_of_rust","token","wrap","ptr","index_term_of_rust","term","token_class","column","coefficient","linearization_of_rust","linearization","affine_class","F","WasmPolishToken","WasmIndexTerm","constant_term","index_terms","wasmIndexTerm","caml_plonk_domain_of_rust","log_size_of_group","group_gen","caml_plonk_verification_evals_of_rust","affine_klass","caml_plonk_verification_shifts_of_rust","caml_map_of_rust_vector","converter_to_rust","caml_bool_of_rust","bool","caml_lookup_selectors_of_rust","poly_comm_of_rust","caml_lookup_patterns_of_rust","caml_lookup_features_of_rust","caml_lookup_patterns","caml_joint_lookup_used","caml_uses_runtime_tables","caml_lookup_info_of_rust","caml_max_per_row","caml_max_joint_size","caml_lookup_features","caml_lookup_verifier_index_of_rust","caml_lookup_selectors","caml_table_ids","caml_lookup_info","caml_runtime_tables_selector","caml_plonk_verifier_index_of_rust","caml_lookup_index","caml_pasta_fp_plonk_verifier_index_of_rust","caml_pasta_fp_plonk_verifier_index_create","vk","vk_caml","caml_pasta_fp_plonk_verifier_index_read","caml_pasta_fp_plonk_verifier_index_shifts","caml_pasta_fp_plonk_verifier_index_write","caml_pasta_fp_poseidon_block_cipher","_fake_params","fp_vector","wasm_flat_vector","new_fp_vector","caml_pasta_fp_poseidon_params_create","caml_pasta_fp_print","caml_pasta_fp_random","caml_pasta_fp_rng","caml_pasta_fp_size","caml_pasta_fp_size_in_bits","caml_pasta_fp_sqrt","caml_pasta_fp_to_bigint","caml_pasta_fp_to_bytes","caml_pasta_fp_to_string","caml_pasta_fp_two_adic_root_of_unity","caml_pasta_fq_add","caml_pasta_fq_copy","caml_pasta_fq_div","caml_pasta_fq_domain_generator","caml_pasta_fq_equal","caml_pasta_fq_inv","caml_pasta_fq_is_square","caml_pasta_fq_mul","caml_pasta_fq_mut_add","caml_pasta_fq_mut_mul","caml_pasta_fq_square","caml_pasta_fq_mut_square","caml_pasta_fq_sub","caml_pasta_fq_mut_sub","caml_pasta_fq_negate","caml_pasta_fq_of_bigint","caml_pasta_fq_of_bytes","caml_pasta_fq_of_int","caml_pasta_fq_of_string","caml_pasta_fq_plonk_circuit_serialize","caml_fq_plonk_gate_to_rust","caml_pasta_fq_plonk_gate_vector_add","caml_pasta_fq_plonk_gate_vector_create","caml_pasta_fq_plonk_gate_vector_digest","caml_pasta_fq_plonk_gate_vector_get","caml_pasta_fq_plonk_gate_vector_len","caml_pasta_fq_plonk_gate_vector_wrap","caml_fq_vector_to_rust","caml_fq_runtime_table_cfg_to_rust","caml_fq_lookup_table_to_rust","caml_pasta_fq_plonk_index_create","caml_pasta_fq_plonk_index_create_bytecode","caml_pasta_fq_plonk_index_domain_d1_size","caml_pasta_fq_plonk_index_read","caml_pasta_fq_plonk_index_write","caml_pallas_poly_comm_to_rust","caml_pasta_fq_plonk_verifier_index_to_rust","caml_fq_lookup_commitments_to_rust","caml_pasta_fq_commitments_to_rust","caml_pasta_fq_opening_proof_to_rust","caml_pasta_fq_proof_evaluations_to_rust","caml_pasta_fq_proof_to_rust","caml_pasta_fq_plonk_proof_batch_verify","caml_fq_lookup_commitments_of_rust","caml_pasta_fq_commitments_of_rust","caml_pasta_fq_opening_proof_of_rust","caml_fq_vector_of_rust","caml_pasta_fq_proof_evaluations_of_rust","caml_pasta_fq_proof_of_rust","caml_fq_runtime_table_to_rust","caml_pasta_fq_plonk_proof_create","caml_pasta_fq_plonk_proof_verify","caml_pasta_fq_plonk_verifier_index_of_rust","caml_pasta_fq_plonk_verifier_index_create","caml_pasta_fq_plonk_verifier_index_shifts","caml_pasta_fq_print","caml_pasta_fq_random","caml_pasta_fq_rng","caml_pasta_fq_size","caml_pasta_fq_size_in_bits","caml_pasta_fq_sqrt","caml_pasta_fq_to_bigint","caml_pasta_fq_to_bytes","caml_pasta_fq_to_string","caml_pasta_fq_two_adic_root_of_unity","caml_raw_backtrace_slot","caml_record_backtrace","caml_register_global","name_opt","caml_register_named_value","caml_restore_raw_backtrace","exn","bt","caml_set_oo_id","caml_bytes_equal","caml_string_equal","caml_string_bound_error","caml_string_get","caml_string_get16","caml_string_get32","caml_string_get64","caml_bytes_lessequal","caml_string_lessequal","caml_string_greaterequal","caml_bytes_lessthan","caml_string_lessthan","caml_string_greaterthan","caml_string_notequal","caml_argv","main","argv","args2","caml_sys_argv","caml_sys_const_max_wosize","os_type","caml_sys_const_ostype_cygwin","caml_sys_const_ostype_win32","caml_executable_name","caml_sys_executable_name","caml_sys_exit","caml_sys_file_exists","caml_sys_get_config","caml_sys_getcwd","caml_raise_not_found","caml_sys_getenv","caml_sys_isatty","_chan","caml_sys_random_seed","buff","now","caml_sys_remove","caml_sys_system_command","cmd","caml_trampoline","caml_trampoline_return","caml_update_dummy","caml_vesta_add","caml_vesta_double","caml_vesta_endo_base","caml_vesta_endo_scalar","caml_vesta_negate","caml_vesta_of_affine_coordinates","caml_vesta_one","caml_vesta_random","caml_vesta_scale","caml_vesta_sub","caml_vesta_to_affine","caml_return_exn_constant","caml_wrap_exception","num_digits_nat","compare_nat","core_array_unsafe_float_blit","core_array_unsafe_int_blit","core_kernel_gc_minor_words","core_kernel_time_ns_format","time","formatjs","jstring","caml_md5_chan","chan_len","core_md5_fd","ic","MlNat","create_nat","custom_reraise_exn","fallbackMessage","decr_nat","borrow","deferred_bind","deferred","func","newDeferred","anotherDeferred","deferred_map","deferred_return","Promise","deferred_run","deferred_to_promise","deferred_upon_exn","div_helper","z","div_digit_nat","natq","ofsq","natr","ofsr","rem","num_leading_zero_bits_in_digit","shift_left_nat","nbits","shift_right_nat","set_to_zero_nat","nat_of_array","mult_digit_nat","nat3","ofs3","x1","x2","x3","sub_nat","div_nat","quo","expect_test_collector_saved_stderr","expect_test_collector_saved_stdout","expect_test_collector_after_test","vstdout","vstderr","expect_test_collector_before_test","voutput","caml_random_oracles_of_rust","joint_combiner_chal","joint_combiner","joint_combiner_ocaml","caml_oracles_of_rust","fp_oracles_create","lgr_comm","verifier_index","fp_oracles_create_no_public","fq_oracles_create","fq_oracles_create_no_public","tsBindings","getTsBindings","serialize_nat","deserialize_nat","caml_hash_nat","initialize_nat","integers_int32_of_uint32","integers_size_t_size","unit","integers_uint_of_string","max_val","negative","no_digits","ten","max_base_10","UInt32","integers_uint32_of_int64","integers_uint32_of_string","integers_uint16_of_string","integers_uint32_add","integers_uint32_div","integers_uint32_logand","integers_uint32_logor","integers_uint32_logxor","integers_uint32_max","integers_uint32_to_int64","integers_uint32_mul","x_64","y_64","integers_uint32_of_int","integers_uint32_of_int32","integers_uint32_rem","integers_uint32_shift_left","integers_uint32_shift_right","integers_uint32_sub","integers_uint32_to_int","caml_new_string","integers_uint32_to_string","UInt64","integers_uint64_add","integers_uint64_div","integers_uint64_logand","integers_uint64_logor","integers_uint64_logxor","integers_uint64_max","integers_uint64_mul","integers_uint64_of_int","integers_uint64_of_int64","integers_uint64_of_string","integers_uint64_of_uint32","integers_uint64_rem","integers_uint64_shift_left","integers_uint64_shift_right","integers_uint64_sub","integers_uint64_to_int","integers_uint64_to_int64","integers_uint64_to_string","integers_uint8_of_string","integers_uint_size","integers_ulong_size","integers_ulonglong_size","integers_uint8_deserialize","integers_uint16_deserialize","integers_uint32_serialize","integers_uint32_deserialize","integers_uint32_hash","integers_uint32_compare","integers_uint64_compare","integers_uint64_hash","integers_uint64_marshal","integers_uint64_unmarshal","integers_unsigned_init","integers_ushort_size","is_digit_int","is_digit_zero","land_digit_nat","lor_digit_nat","bigInt","BASE","LOG_BASE","MAX_INT","MAX_INT_ARR","smallToArray","DEFAULT_ALPHABET","BigInt","supportsNativeBigInt","Integer","radix","alphabet","caseSensitive","parseValue","parseBase","BigInteger","SmallInteger","NativeBigInt","isPrecise","arrayToSmall","trim","compareAbs","createArray","truncate","l_a","l_b","sum","addAny","addSmall","subtract","a_l","b_l","difference","subtractAny","subtractSmall","small","multiplyLong","product","a_i","b_j","multiplySmall","shiftLeft","multiplyKaratsuba","ac","bd","abcd","useKaratsuba","abs","multiplySmallAndArray","square","a_j","divMod1","divisorMostSignificantDigit","lambda","remainder","quotientDigit","shift","divModSmall","divMod2","part","guess","xlen","highx","highy","check","divModAny","comparison","qSign","mod","mSign","_0","_1","_2","isBasicPrime","millerRabinTest","nPrev","strict","isPrime","bits","logN","iterations","newT","newR","lastT","lastR","powersOfTwo","powers2Length","highestPower2","shift_isSmall","remQuo","bitwise","xSign","ySign","xRem","yRem","xDigit","yDigit","xDivMod","yDivMod","LOBMASK_I","LOBMASK_BI","roughLOB","integerLogarithm","max","min","gcd","lcm","randBetween","low","high","range","digits","toBase","restricted","top","digit","text","absBase","alphabetValues","isNegative","start","parseBaseFromArray","val","pow","stringify","out","left","divmod","toBaseString","zeros","parseStringValue","split","decimalPlace","isValid","parseNumberValue","ml_z_normalize","ml_z_abs","ml_z_add","ml_z_compare","ml_z_div","ml_z_divexact","ml_z_equal","ml_z_fits_int","ml_z_fits_int32","ml_z_format","cas","width","alt","dir","pad","prefix","pre","ml_z_gcd","ml_z_hash","acc","caml_zarith_marshal","block","caml_zarith_unmarshal","negate","ml_z_init","ml_z_logand","ml_z_logor","ml_z_mul","ml_z_neg","ml_z_numbits","upperBound","ml_z_of_bits","base1","ml_z_of_float","f1","ml_z_of_int","ml_z_of_int64","jsoo_z_of_js_string_base","bc","ml_z_of_substring_base","ml_z_pow","ml_z_pred","ml_z_rem","ml_z_shift_left","amt","ml_z_shift_right","ml_z_sign","ml_z_sub","ml_z_succ","ml_z_testbit","ml_z_to_bits","ml_z_to_int","ml_z_fits_int64","ml_z_to_int64","mask","mult_nat","len3","nth_digit_nat","prover_to_json","set_digit_nat","set_digit_nat_native","ms_to_nano","time_now_nanoseconds_since_unix_epoch_or_zero","ms","ms_i63","unix_inet_addr_of_string","caml_fatal_uncaught_exception","throw_errors","collect_strings","caml_setup_uncaught_exception_handler","origin","event","zero$0","y$0","minus_one$0","zero_pos","sub_format","formatting_lit","opt","locfmt","null$0","current_dir_name","parent_dir_name","dir_sep","quotequote","null$1","current_dir_name$0","parent_dir_name$0","dir_sep$0","null$2","current_dir_name$1","parent_dir_name$1","dir_sep$1","module_name","tp_loc","module_name$2","ocaml_lex_tables","m1","m2","m4","h01","the_generic_group$2","mask$0","the_generic_group$3","module_name$13","module_name$14","elided_message","null$3","tp_loc$0","tp_loc$1","tp_loc$2","flags$0","am_recording_environment_varia","name$3","name$4","name$5","name$6","name$7","name$8","name$9","name$10","name$11","name$12","name$13","name$14","name$15","name$16","name$17","name$18","name$19","name$20","name$21","name$22","name$23","ocaml_lex_tables$0","int64$1","golden_gamma","beginning_of_file","err$2","err$1","err$0","tp_loc$3","name$26","tp_loc$4","name$27","tp_loc$5","tp_loc$6","name$28","tp_loc$7","tp_loc$8","name$29","tp_loc$9","tp_loc$10","name$30","tp_loc$11","name$31","name$32","default_seed","default_shrink_attempts","name$55","name$56","name$57","name$58","name$59","name$60","name$61","name$62","name$63","name$64","name$65","name$66","name$67","name$68","name$69","name$70","name$71","name$72","name$73","name$74","name$75","unit_of_time_list","name$77","name$78","name$81","name$80","name$79","module_name$24","tp_loc$14","all$2","name$82","tp_loc$15","name$83","module_name$25","name$84","name$85","suffix$6","suffix","tp_loc$16","module_name$26","module_name$27","suffix$13","module_name$28","name$86","name$87","module_name$29","tp_loc$17","tp_loc$18","atom","record$1","label","ocaml_lex_tables$1","ocaml_lex_tables$2","ocaml_lex_tables$3","name$89","module_name$30","name$90","tp_loc$19","tp_loc$20","tp_loc$21","label$0","pos$0","tp_loc$22","tp_loc$23","tp_loc$24","pos$1","op","tp_loc$25","tp_loc$26","tp_loc$27","tp_loc$28","state$11","state$10","state$9","state$8","state$7","state$6","state$5","state$4","state$3","state$2","state$1","state$0","feature_flags","maybe","tp_loc$29","none$1","actual_feature_flags","tp_loc$30","tp_loc$31","tp_loc$32","tp_loc$33","tp_loc$34","tp_loc$35","tp_loc$36","tp_loc$37","tp_loc$38","tp_loc$39","tp_loc$40","tp_loc$41","tp_loc$42","tp_loc$43","tp_loc$44","tp_loc$45","pos$3","pos$2","slots","slots$0","name$91","n$0","here","tp_loc$46","none$2","arg$0","tp_loc$47","level_bits$0","here$0","here$1","here$2","here$3","here$4","here$5","tp_loc$48","tp_loc$49","tp_loc$50","tp_loc$51","list$1","tp_loc$52","list$2","tp_loc$53","empty$15","v_print_debug_messages_for","environment_variable","job_queue","deferred0","deferred1","monitor","import0","error$0","pos$4","fmt$0","fmt$1","start$0","expected","id$2","pos$9","pos$8","pos$7","pos$6","pos$5","tp_loc$54","state$12","tp_loc$55","tp_loc$56","state$13","tp_loc$57","pos$10","tp_loc$58","tp_loc$59","pos$12","pos$11","tp_loc$65","tp_loc$60","tp_loc$61","tp_loc$62","tp_loc$63","tp_loc$64","pos$13","pos$16","pos$15","pos$14","name$92","id$3","name$93","id$4","pos$18","pos$17","ast_impl_magic_number","ast_intf_magic_number","right","fmt$4","fmt$5","fmt$6","opt$1","cs","infix_symbols","special_infix_strings","reset_ctxt","ast_impl_magic_number$0","ast_intf_magic_number$0","ast_impl_magic_number$1","ast_intf_magic_number$1","ast_impl_magic_number$2","ast_intf_magic_number$2","ast_impl_magic_number$3","ast_intf_magic_number$3","ast_impl_magic_number$4","ast_intf_magic_number$4","ast_impl_magic_number$5","ast_intf_magic_number$5","ast_impl_magic_number$6","ast_intf_magic_number$6","ast_impl_magic_number$7","ast_intf_magic_number$7","ast_impl_magic_number$8","ast_intf_magic_number$8","ast_impl_magic_number$9","ast_intf_magic_number$9","ast_impl_magic_number$10","ast_intf_magic_number$10","ast_impl_magic_number$11","ast_intf_magic_number$11","pos$19","txt","string_version","string_version$0","string_version$1","string_version$2","string_version$3","string_version$4","string_version$5","string_version$6","string_version$7","string_version$8","string_version$10","string_version$11","flags$2","flags$1","prefix$3","kind$2","vals","prefix$4","warnings","prefix$5","pos$24","pos$23","pos$22","pos$21","pos$20","tp_loc$66","tp_loc$67","tp_loc$68","tp_loc$69","state$15","state$14","tp_loc$70","tp_loc$71","state$16","tp_loc$72","state$21","state$20","state$19","state$18","state$17","tp_loc$73","tp_loc$74","tp_loc$75","tp_loc$76","tp_loc$77","tp_loc$78","tp_loc$79","tp_loc$80","commit_id","commit_date","marlin_commit_id","pos$31","pos$30","pos$29","pos$28","pos$27","pos$26","pos$25","state$25","initial_prefix","prefix$7","state$24","state$23","state$22","tp_loc$81","tp_loc$82","tp_loc$83","tp_loc$84","tp_loc$85","tp_loc$86","prefix$6","acc$0","state$27","state$26","tp_loc$87","tp_loc$88","tp_loc$89","pos$32","b_010","b_002","pos$34","pos$33","state$28","tp_loc$90","sponge_name","pos$35","description$0","state$30","tp_loc$91","sponge_name$0","pos$43","pos$42","pos$41","pos$40","t2$2","t1$2","t2$3","t1$3","pos$39","pos$38","pos$37","pos$36","t2$0","t1$0","t2$1","t1$1","v0$0","t$7","pos$48","pos$47","pos$46","pos$45","t2$4","t1$4","t2$5","t1$5","pos$44","domains","t$8","tp_loc$92","tp_loc$93","pos$64","pos$63","pos$62","pos$61","pos$60","pos$59","pos$58","pos$57","pos$56","pos$55","pos$54","pos$53","pos$52","pos$51","pos$50","pos$49","tp_loc$94","pos$65","tagname","branches","pos$67","pos$66","tp_loc$95","tp_loc$96","pos$68","pos$69","description$1","description$2","tp_loc$97","tp_loc$98","tp_loc$99","tp_loc$100","tp_loc$101","pos$72","message$2","state$33","tp_loc$106","pos$71","message$1","state$32","tp_loc$102","tp_loc$103","tp_loc$104","tp_loc$105","hex_key_odd","hex_key_even","deriver","state$34","tp_loc$107","tp_loc$108","pos$73","cany","v$99","v$100","v$101","v$102","v$103","v$104","ocaml_lex_tables$5","type_kind$0","directive_location","pos$80","pos$79","pos$78","t1$6","t1$7","t1$8","pos$77","pos$76","pos$75","t2$7","t2$8","t2$9","key$1","pos$74","t2$6","introspection_query_raw","pos$84","prefix$8","suffix$14","pos$83","pos$82","pos$81","doc$0","v1","v2","manual","pos$88","pos$87","pos$86","pos$85","state$35","v$105","state$36","tp_loc$109","tp_loc$110","pos$94","pos$93","t2$11","pos$92","pos$91","t2$10","pos$90","pos$89","description$3","compiled","coinbase_amount_string","account_creation_fee_string","genesis_state_timestamp_string","env$1","tp_loc$112","err$3","tp_loc$111","description$4","tp_loc$113","state$37","tp_loc$114","tp_loc$115","description$5","pos$95","tp_loc$116","tp_loc$117","state$39","state$38","tp_loc$118","tp_loc$119","description$6","pos$98","pos$97","state$40","pos$96","tp_loc$120","tp_loc$121","t1$9","empty$35","pos$99","s$2","s$1","s$0","description$7","state$42","state$41","tp_loc$122","tp_loc$123","pos$100","tp_loc$124","tp_loc$125","empty$37","state$45","state$44","state$43","tp_loc$126","tp_loc$127","tp_loc$128","tp_loc$129","tp_loc$130","state$47","state$46","tp_loc$131","tp_loc$132","description$8","description$9","description$10","tp_loc$133","tp_loc$134","tp_loc$135","five","state$48","empty_stack_msg","salt_phrase","deriver_name","salt_phrase$0","deriver_name$0","salt_phrase$1","tp_loc$136","state$49","default$10","tp_loc$137","tp_loc$138","description$11","tp_loc$139","pos$105","pos$104","pos$103","pos$102","t2$13","pos$101","t2$12","tp_loc$140","tp_loc$141","tp_loc$142","epoch_data$0","dummy_value","tp_loc$143","tp_loc$144","tp_loc$145","tp_loc$146","tp_loc$147","tp_loc$148","tp_loc$149","tp_loc$150","tp_loc$151","tp_loc$152","tp_loc$153","tp_loc$154","tp_loc$155","tp_loc$156","tp_loc$157","tp_loc$158","tp_loc$159","tp_loc$160","tp_loc$161","tp_loc$162","tp_loc$163","tp_loc$164","tp_loc$165","tp_loc$166","tp_loc$167","tp_loc$168","tp_loc$169","state$54","state$53","state$52","tp_loc$170","description$12","tp_loc$171","tp_loc$172","state$56","state$55","tp_loc$173","description$13","tp_loc$174","state$58","state$57","tp_loc$175","description$14","tp_loc$176","state$63","state$62","state$61","state$60","state$59","tp_loc$177","description$15","description$16","tp_loc$178","tp_loc$179","description$17","tp_loc$180","tp_loc$181","tp_loc$182","tp_loc$183","tp_loc$184","tp_loc$185","tp_loc$186","tp_loc$187","tp_loc$188","tp_loc$189","state$67","state$66","state$65","state$64","description$18","description$19","tp_loc$190","names$1","tp_loc$191","names$2","tp_loc$192","tp_loc$193","state$69","state$68","tp_loc$194","tp_loc$195","pos$107","pos$106","tp_loc$196","tp_loc$197","transaction_id$1","expected_hash$1","transaction_id$0","expected_hash$0","transaction_id","expected_hash","description$20","pos$108","update_failed","kind$3","tp_loc$198","tp_loc$199","tp_loc$200","tp_loc$201","tp_loc$202","tp_loc$203","tp_loc$204","tp_loc$205","tp_loc$206","nsf_tag","min_balance_tag","description$22","description$21","name$99","erase_rel","rest","rest$0","rest$1","rest$2","rest$3","rest$4","rest$5","rest$6","rest$7","ty","rest$8","ty1","rest$9","rest$10","rest$11","rest$12","rest$13","concat_fmtty","fmtty1","fmtty2","ty2","concat_fmt","fmt1","fmt2","pad$0","pad$1","iconv","prec$0","pad$2","iconv$0","prec$1","pad$3","iconv$1","prec$2","pad$4","iconv$2","prec$3","pad$5","fconv","pad$6","chr","fmtty","pad$7","fmtty$0","pad$8","rest$14","rest$15","rest$16","fmting_lit","rest$17","fmting_gen","rest$18","rest$19","char_set","width_opt","rest$20","counter","rest$21","rest$22","ign","rest$23","arity","cur","failwith","invalid_arg","lnot","nan","max_finite_value","max_queue_length","min$0","symbol","char_of_int","bool_of_string","int_to_string","valid_float_lexem","i$0","string_of_float","tl","hd","open_out_gen","perm","open_out","open_out_bin","flush_all","iter","output_string","oc","output_substring","close_out","open_in_gen","open_in_bin","input","unsafe_really_input","ofs$0","len$0","len$1","ofs$1","really_input","really_input_string","prerr_string","symbol$0","str2","exit_function","at_exit","f_yet_to_run","old_exit","new_exit$0","new_exit","success","do_at_exit","exit","retcode","close_in","os_type$0","cygwin","arch_big_endian","num_bits_int","is_block","lazy_tag","object_tag","forward_tag","slot","extension_name","max_ephe_length","raise_undefined","force_lazy_block","blk","closure","empty","append$0","seq1","seq2","next","map","seq","filter_map","seq$0","flat_map","fold_left","acc$1","unfold","u","u$0","some","default$0","map$0","fold","none","iter$0","is_none","map$1","map_error","equal","param$0","nth","l$0","l$1","n$1","rev_append","l1$0","l2$0","l1$1","l2$1","rev","param","accu","accu$0","accu$1","assoc_exn","find_exn","xs","ry","rx","cmp","rev_sort","tl$1","x2$0","x1$0","n1","n2","sort","tl$0","t2","h2","t1","h1","c$0","c$1","c$2","c$3","c$4","c$5","c$6","accu$2","aux","tail","min$1","max$0","to_string$0","is_space","apply1","seplen","is_space$0","i$1","i$2","index_rec","lim","lowercase_ascii$0","capitalize_ascii","uncapitalize_ascii","to_buffer","sx","sy","la","lb","res$0","hd$0","zero","minus_one","succ","pred","abs$0","min$2","max$1","lognot","int32_to_string","succ$0","pred$0","abs$1","bit_not","int64_to_string","y$1","min_nativeint","max_nativeint","nativeint_to_string","engine","sth","with_positions","aux_buffer","read","newlen","newbuf","env","clear_parser","height","create","hl","h$0","hr","bal","lv","ll","lrr","lrv","lrl","rr","rv","rl","rlr","rlv","rll","singleton","add_min_element","add_max_element","join","rh","lh","min_elt","min_elt_opt","max_elt","param$1","max_elt_opt","remove_min_elt","r$0","concat","pres","pres$0","is_empty","remove","union","r2$0","r1$0","inter","split_bis","disjoint","s1$0","s2$0","s2$1","diff","cons_enum","e$0","e$1","compare","e2$2","e1$2","e1","e2","e2$0","e1$0","e2$1","e1$1","subset","for_all","exists","filter","pv","partition","lf","lt","rf","rt","cardinal","elements_aux","elements","find","find_first","v$0","find_first_opt","find_last","find_last_opt","find_opt","try_join","v$1","of_list","sub","l$3","x0","l$4","x0$0","l$5","x0$1","nl","mid","l$2","x4","add_seq","of_seq","seq_of_enum","to_seq","snoc_enum","rev_seq_of_enum","to_rev_seq","to_seq_from","ld","lrd","rld","d$0","min_binding","min_binding_opt","max_binding","max_binding_opt","remove_min_binding","update","data$0","mapi","m$0","add_min_binding","add_max_binding","concat_or_join","merge","d1","d2","d2$0","d1$0","d2$1","d1$1","pvd","fvd","m$1","bindings_aux","bindings","clear","push","pop_opt","top_opt","clear$0","cell","resize","more","old_len","new_len","new_buffer","uchar_utf_8_byte_length_max","new_position","create_char_set","add_in_char_set","str_ind","pad_of_pad_opt","pad_opt","param_format_of_ignored_format","pad_opt$0","pad_opt$1","pad_opt$2","pad_opt$3","pad_opt$4","prec_opt","pad_opt$5","ndec","pad_opt$6","pad_opt$7","pad_opt$8","default_float_precision","buffer_create","init_size","buffer_check_size","overhead","min_len","buffer_add_char","buffer_add_string","buffer_contents","char_of_iconv","string_of_formatting_lit","str$0","bprint_fmtty","sub_fmtty","sub_fmtty$0","symm","trans","rest2","rest2$0","rest2$1","rest2$2","rest2$3","rest2$4","rest2$5","rest2$6","rest2$7","ty2$0","rest2$8","ty22","ty21","fmtty_rel_det","f4","f2","rest2$9","rest2$10","rest2$11","rest2$12","rest2$13","de","ed","af","fa","de$0","ed$0","af$0","fa$0","de$1","ed$1","af$1","fa$1","de$2","ed$2","af$2","fa$2","de$3","ed$3","af$3","fa$3","de$4","ed$4","af$4","fa$4","de$5","ed$5","af$5","fa$5","de$6","ed$6","af$6","fa$6","de$7","ed$7","af$7","fa$7","de$8","ed$8","af$8","fa$8","jd","dj","ga","ag","de$9","ed$9","af$9","fa$9","de$10","ed$10","af$10","fa$10","de$11","ed$11","af$11","fa$11","de$12","ed$12","af$12","fa$12","de$13","ed$13","af$13","fa$13","fmtty_of_precision_fmtty","fmtty_of_padding_fmtty","fmtty_of_custom","arity$0","fmtty_of_fmt","ty_rest","prec_ty","ty_rest$0","prec_ty$0","ty_rest$1","prec_ty$1","ty_rest$2","prec_ty$2","ty_rest$3","prec_ty$3","fmtty$1","fmtty$2","fmtty$3","ty$0","fmtty$4","fmtty$5","type_padding","padty","padty$0","type_padprec","type_ignored_format_substituti","type_format_gen","fmtty_rest","sub_fmtty_rest","sub_fmtty_rest$0","fmtty_rest$0","sub_fmtty_rest$1","sub_fmtty_rest$2","fmtty_rest$1","sub_fmtty_rest$3","fmt$2","sub_fmtty_rest$4","fmtty_rest$2","sub_fmtty_rest$5","fmt$3","sub_fmtty_rest$6","fmtty_rest$3","sub_fmtty_rest$7","sub_fmtty_rest$8","fmtty_rest$4","sub_fmtty_rest$9","sub_fmtty_rest$10","fmtty_rest$5","sub_fmtty_rest$11","sub_fmtty_rest$12","fmtty_rest$6","sub_fmtty_rest$13","fmt$7","sub_fmtty_rest$14","fmtty_rest$7","sub2_fmtty","sub_fmtty_rest$15","sub2_fmtty$0","fmt$8","sub_fmtty_rest$16","fmtty_rest$8","sub2_fmtty$1","sub1_fmtty","sub_fmtty_rest$17","sub2_fmtty$2","sub1_fmtty$0","fmt$9","sub_fmtty_rest$18","fmtty_rest$9","sub_fmtty_rest$19","fmt$10","sub_fmtty_rest$20","fmtty_rest$10","sub_fmtty_rest$21","fmt$11","sub_fmtty_rest$22","fmtty_rest$11","sub_fmtty_rest$23","fmt$12","sub_fmtty_rest$24","fmtty_rest$12","sub_fmtty_rest$25","fmt$13","sub_fmtty_rest$26","fmt_rest","fmt_rest$0","fmt_rest$1","fmt_rest$2","fmt_rest$3","fmt_rest$4","fmt_rest$5","prec$4","fmtty$6","fmt_rest$6","prec$5","prec$6","fmtty$7","fmt_rest$7","prec$7","prec$8","fmtty$8","fmt_rest$8","fmtty$9","fmt_rest$9","fmtty$10","fmt_rest$10","fmtty$11","fmt_rest$11","fmtty$12","fmt_rest$12","fmtty$13","sub_fmtty1","fmt_rest$13","sub_fmtty$1","fmtty$14","fmt$14","fmt_rest$14","fmtty$15","fmt$15","fmt_rest$15","fmtty$16","fmt$16","fmt_rest$16","fmtty$17","fmt$17","fmt_rest$17","formatting_gen","fmtty3","fmt3","str$1","fmt1$0","fmtty2$0","fmt2$0","fmtty3$0","fmt3$0","fmtty_rest$13","fmt_rest$18","fmtty$18","fmt$18","fmtty_rest$14","fmt_rest$19","fmtty$19","fmt$19","fmtty_rest$15","fmt_rest$20","fmtty$20","fmt$20","type_ignored_param_one","fmtty_rest$16","fmtty$21","fmt$21","sub_fmtty$2","sub_fmtty$3","fmtty$22","fmt$22","sub_fmtty$4","type_format","recast","fix_padding","width$0","fix_int_precision","res$1","string_to_caml_string","format_of_fconv","symb","transform_int_alt","put","convert_int","convert_int32","convert_nativeint","convert_int64","convert_float","hex","caml_special_val","string_of_fmtty","make_printf$0","k$0","new_acc","make_printf","make_padding","make_int_padding_precision","p$0","p$1","acc$2","acc$3","acc$4","k$3","kacc","k$1","k$4","k$2","make_ignored_param","make_custom$0","make_invalid_arg","make_from_fmtty$0","make_from_fmtty","make_custom","output_acc","p$2","p$3","p$4","bufput_acc","strput_acc","failwith_message","open_box_of_string","invalid_box","parse_spaces","parse_lword","j$0","j$1","parse_int","wstart","wend","box_name","nstart","nend","indent","exp_end","box_type","make_padding_fmt_ebb","make_padprec_fmt_ebb","fmt_ebb_of_string","legacy_behavior","flag","legacy_behavior$0","invalid_format_message","unexpected_end_of_format","end_ind","invalid_format_without","expected_character","add_literal","lit_start","parse_positive","str_ind$0","str_ind$1","parse_integer","next_ind","incompatible_flag","pct_ind","option","subfmt","compute_int_conv","plus","hash","space","plus$0","hash$0","space$0","search_subformat_end","sub_end","str_ind$2","sub_end$0","str_ind$3","sub_end$1","str_ind$4","str_ind$5","sub_end$2","str_ind$6","str_ind$7","parse_magic_size","str_ind_1","str_ind_2","str_ind_3","parse","parse_good_break","formatting_lit$0","str_ind_4","str_ind_5","parse_tag","is_open_tag","ind","sub_str","sub_fmt","sub_format$0","formatting$0","formatting","parse_flags","minus","set_flag","new_ind","parse_after_padding","parse_literal","parse_after_precision","symb$0","minus$0","parse_conversion","parse_conv","padprec","plus_used","hash_used","space_used","ign_used","pad_used","prec_used","get_plus","get_hash","get_space","get_ign","get_pad","get_prec","get_padprec","get_int_pad","check_no_0","opt_of_pad","width$1","get_pad_opt","get_padprec_opt","fmt_result","ignored$2","counter$0","ignored$6","ignored$7","char_set$1","add_char","add_range","fail_single_percent","parse_char_set_content","parse_char_set_after_char$0","parse_char_set_after_char","reverse","char_set$0","char_set$2","ignored$9","char_format","fmt_rest$21","fmt_rest$22","pad$9","fmt_rest$23","ignored$10","fmt_rest$24","pad$10","fmt_rest$25","sub_fmt$0","fmt_rest$26","ignored$11","ignored$3","ignored$5","ignored$8","space$1","hash$1","plus$2","ignored$4","ignored","ignored$0","ignored$1","plus$1","ign$0","fprintf","bprintf","ksprintf","sprintf","assoc3","y2","y1","split$0","make_symlist","help_action","add_help","speclist","add2","current","bool_of_string_opt","int_of_string_opt","float_of_string_opt","parse_and_expand_argv_dynamic_","allow_expand","anonfun","errmsg","initpos","convert_error","error","progname","doc","spec","follow$0","action","keyword","no_arg$0","follow","no_arg","get_arg$0","get_arg","consume_arg$0","consume_arg","treat_action$0","treat_action","f$0","f$1","r$1","f$2","arg$1","r$2","arg$2","x$0","f$3","arg$3","x$1","r$3","arg$4","x$2","specs","f$4","arg$5","f$5","f$6","f$7","arg$6","newarg","before","after","parse_argv","sth$0","speclist$0","second_word","loop","max_arg_len","kwd","replace_leading_tab","align","completed","ksd","msg$0","cutcol$0","spaces$0","cutcol","kwd_len","spaces","printers","field","other_fields","to_string$1","conv","char$0","line","char$1","line$0","file$0","char$2","line$1","file$1","constructor","convert_raw_backtrace","format_backtrace_slot","is_raise","print_raw_backtrace","outchan","raw_backtrace","backtrace","raw_backtrace_to_string","get_backtrace","register_printer","old_printers","new_printers","errors","default_uncaught_exception_han","status","uncaught_exception_handler","empty_backtrace","handle_uncaught_exception","debugger_in_use","exn$0","raw_backtrace$0","protect","finally$0","work","finally_no_exn","work_exn","work_bt","char_hex","new_state","assign","st1","st2","full_init","seed$0","make$1","make_self_init","copy$1","curval","newval30","init$2","get_state","set_state","ongoing_traversal","flip_ongoing_traversal","params","randomized_default","prng","initial_size","random","clear$2","reset$0","copy_bucketlist","key$0","next$0","copy$2","length$1","resize$0","indexfun","odata","osize","nsize$0","ndata","inplace","indexfun$0","nsize","ndata_tail","cell$0","nidx","match","match$0","iter$4","do_bucket","old_trav","filter_map_inplace_bucket","filter_map_inplace","fold$0","b$0","bucket_length","stats","mbl","histo","to_seq$0","tbl_data","buck","buck$0","buck$1","to_seq_keys","to_seq_values","key_index","bucket","next1","next2","k3","d3","next3","find_all","find_in_bucket","replace","replace_seq","id$0","unknown","pp_enqueue","pp_infinity","pp_output_string","pp_output_newline","format_pp_text","format_string","break_new_line","real_indent","break_line","break_same_line","format_pp_token","size$0","tabs","add_tab","ls","tag_name","marker","breaks","fits","box_type$0","off$0","insertion_point","tabs$0","first","head","tab","off$1","insertion_point$0","width$2","box_type$1","tbox","tag_name$0","marker$0","advance_left","pending_count","enqueue_advance","tok","enqueue_string_as","initialize_scan_stack","queue_elem","set_size","left_total","scan_push","elem","pp_open_box_gen","br_ty","pp_flush_queue","pp_print_as_size","isize","pp","blank_line","display_indent","default_pp_mark_open_tag","default_pp_mark_close_tag","default_pp_print_open_tag","default_pp_print_close_tag","flush","pp_queue","sys_tok","scan_stack","ppf","pp_buffer_size","pp_make_buffer","flush_buffer_formatter","pp_print_list","pp_v","opt$0","pp_sep","vs","compute_tag","tag_acc","output_formatting_lit","output_acc$0","bty","p$5","p$6","strput_acc$0","size$1","flush_standard_formatters","null_char","next_char","ib","peek_char","checked_peek_char","end_of_input","char_count","reset_token","invalidate_current_char","token_string","token_buffer","skip_char","ignore_char","store_char","default_token_buffer_size","create$2","iname","scan_raise_at_end","from_ic","scan_close_ic","eof","bad_input","bad_input_escape","bad_token_length","message","bad_float","bad_hex_float","character_mismatch","ci","check_this_char","check_char","token_char","token_bool","integer_conversion_of_char","token_int_literal","token_float","scan_decimal_digit_star","scan_unsigned_decimal_int","scan_digit_plus","basis","digitp","width$3","is_binary_digit","scan_binary_int","is_octal_digit","scan_octal_int","is_hexa_digit","scan_hexadecimal_int","scan_sign","scan_optionally_signed_decimal","scan_int_conversion","scan_fractional_part","scan_exponent_part","scan_float","precision","precision$0","check_case_insensitive_string","lowercase","scan_hex_float","width$4","width$5","width$6","width$10","width$7","width$8","width$9","scan_caml_float_rest","width_precision","frac_width","scan_caml_float","scan_string","stp","scan_char","hexadecimal_value_of_char","check_next_char","check_next_char_for_char","check_next_char_for_string","scan_backslash_char","c0","get_digit","get_digit$0","c1$0","c2$0","scan_caml_char","find_stop","scan_caml_string","find_stop$0","skip_spaces","scan_chars_in_char_set","scan_indic","scan_chars","ef","get_counter","width_of_pad_opt","stopper_of_formatting_lit","fmting","take_format_readers$0","take_fmtty_format_readers$0","new_k","readers_rest","take_format_readers","fmt$23","fmt$24","fmt$25","take_fmtty_format_readers","make_scanf","readers","scan$0","str_rest","pad_prec_scanf","scan$1","scan$2","scan","scan$3","scan$4","conv$0","scan$5","conv$1","scan$6","conv$2","scan$7","scan$8","fmting_lit$0","str$2","stp$0","str_rest$0","rest$24","rest$25","rest$26","arg_rest","sscanf","apply","args$0","exc","register_exception","initial_object_size","public_method_label","compare$0","compare$1","compare$2","table_count","dummy_met","fit_size","new_table","pub_labels","methods","resize$1","new_size","old_size","new_buck","method_count","inst_var_count","new_method","table","get_method_label","get_method_labels","names","set_method","element","get_method","to_list$0","new_slot","new_variable","to_array","get_variable","create_table","public_methods","tags","met","lab","init_class","inherits","cla","virt_meths$1","concr_meths$0","super$0","vars","virt_meths","concr_meths","virt_meth_labs","concr_meth_labs","tvars","by_name","by_label","hm","vars$0","virt_meths$0","saved_vars","saved_hidden_meths","by_label$0","by_name$0","make_class","pub_meths","class_init","env_init","create_object_opt","obj_0","run_initializers_opt","inits","new_cache","set_methods","clo","clo$0","n$2","n$3","n$4","n$5","n$6","x$3","n$7","x$4","n$8","n$9","x$5","f$8","e$2","n$10","x$6","f$9","n$11","x$7","n$12","x$8","n$13","n$14","e$3","n$15","m$2","x$9","m$3","n$16","m$4","e$4","n$17","m$5","n$18","init_mod_block","loc","comps$0","modu","shape","fn$0","undef","comps","init_mod","update_mod_block","cl","update_mod","generic_basename","is_dir_sep","generic_dirname","is_relative","is_implicit","check_suffix","suff","len_s","len_suf","chop_suffix_opt","filename","len_f","quote","quote_command","stdin","stdout","stderr","basename","dirname","is_dir_sep$0","is_relative$0","is_implicit$0","check_suffix$0","chop_suffix_opt$0","temp_dir_name","quote$0","add_bs","loop$0","loop_bs","quote_cmd_filename","quote_command$0","drive_and_path","dirname$0","drive","basename$0","basename$1","dirname$1","dir_sep$2","is_dir_sep$1","is_relative$1","temp_dir_name$0","quote$1","basename$2","concat$0","prng$0","temp_file_name","temp_dir","rnd","temp_file","try_name","counter$1","create$3","dim","create$4","dim1","dim2","create$5","of_bool","sexp_of_string","sexp_of_ref","sexp_of_a","sexp_of_option","sexp_of_b","sexp_of_list","lst","sexp_of_array","ar","lst_ref","compare$4","exn_id_map","clean_up_handler","old_exn_id_map","new_exn_id_map","add$1","sexp_of_exn","finalise","ephe","find_auto","sexp","exn_to_string","what","of_bool$0","string_of_sexp","int_of_sexp","int32_of_sexp","int64_of_sexp","nativeint_of_sexp","ref_of_sexp","a_of_sexp","option_of_sexp","el","b_of_sexp","b_sexp","a_sexp","list_of_sexp","rev_lst","array_of_sexp","t$0","t_of_sexp$1","get_flc_error","handler","extension_constructor","tuple_of_size_n_expected","stag_no_args","stag_incorrect_n_args","stag_takes_args","nested_list_invalid_sum","empty_list_invalid_sum","unexpected_stag","record_only_pairs_expected","record_superfluous_fields","rev_fld_names","fld_names_str","record_duplicate_fields","record_extra_fields","record_undefined_elements","undefined$0","record_list_instead_atom","no_variant_match","no_matching_variant_found","ptag_no_args","ptag_incorrect_n_args","cnstr","ptag_takes_args","nested_list_invalid_poly_var","empty_list_invalid_poly_var","empty_type","scale","symbol$1","symbol$2","symbol$3","symbol$4","symbol$5","symbol$6","ascending","descending","equal$1","max$2","min$3","symbol$7","symbol$8","symbol$9","symbol$10","symbol$11","symbol$12","ascending$0","descending$0","compare_int64","equal_int64","max$3","min$4","symbol$13","symbol$14","symbol$15","symbol$16","symbol$17","symbol$18","ascending$1","descending$1","compare_nativeint","equal_nativeint","max$4","min$5","compare_bool","equal_bool","compare$6","compare_float","equal_float","compare_string","equal_string","asr","lor","lsl","lsr","lxor","decr","incr","am_testing","failwithf","getenv","var$0","of_int_exn","of_msb_first","hash_fold_unit","as_int","hash_fold_int32","hash_fold_char","hash_fold_bool","hash_fold_nativeint","hash_fold_option","hash_fold_elem","hash_fold_list","list$0","list","hash_fold_lazy_t","hash_fold_ref_frozen","hash_fold_array_frozen","hash_nativeint","hash_int64","hash_int32","hash_char","hash_int","hash_bool","hash_string","hash_float","hash_unit","compare_state","state_to_string","create$6","run","folder","of_fold","hash_fold_t","hash_fold_t$4","hash_fold_t$7","func$1","t$1","t$2","t$3","t$4","t$5","type_name","compare$11","compare_option","compare_elt","concat$1","ys","num_bits","word_size","formatter","v1$0","reraise","to_string$3","protectx","final_exn","protect$0","does_raise","pp$0","raise_without_backtrace","initialize_module","is_alive","return$0","a$0","map_via_bind","ma","symbol_bind","symbol_map","symbol_bind$0","symbol_map$0","symbol_bind$1","symbol_map$1","both","ignore_m","ts","all","all_unit","bind","map$5","bind$0","return$1","map$6","get$0","fst","snd","fst$0","snd$0","fold_result","fold_until","iter$1","return$5","join$1","bits$0","int32","bound","make$3","make_self_init$0","allow_in_tests","assign$0","int$0","bits$1","full_range_int64","bits$2","full_range_int_on_64bits","raise_crossed_bounds","lower_bound","upper_bound","string_of_bound","int$1","init$3","set_state$0","const$0","symbol$43","compare_list","equal_list","derived_map","map2","ta","tb","map3","tc","invariant$1","sexp_of_t","bounds_crossed","lower","upper","lower$0","upper$0","try_with$0","ok_exn","error_s","pass","fail","fail_s","name$0","protect$2","extract_name","alist","first_failure","t_of_sexp$4","sexp_of_t$8","compare$18","hash_fold_t$12","hsv","symbol$45","symbol$46","symbol$47","symbol$48","symbol$49","symbol$50","ascending$6","descending$6","compare$19","equal$4","max$8","min$9","of_string$1","to_string$5","incl","excl","incl$0","excl$0","incl$1","excl$1","incl$2","excl$2","between","clamp_exn","clamp","comparator","validate_lbound","validate_ubound","validate_bound","find_first_satisfying","hi$0","lo$1","lo$0","lo$2","find_last_satisfying","binary_search","how","binary_search_segmented","segment_of","is_left","is_right","unsafe_blit","blit","blito","src_len","sth$1","subo","create_like","length$0","unsafe_blit$0","is_none$0","is_some","equal_option","symbol_bind$2","bind$6","return$9","map$15","join$3","second","other","either","combine","other_loop","return_loop","combine_all","other_loop$0","return_loop$0","combine_all_unit","to_option","with_return$0","ret","combine$1","bind$7","either$0","combine$2","bind$8","iteri","foldi","foldi$0","counti","existsi","for_alli","find_mapi","findi","bind$10","return$11","map$17","create_zero","create$9","get$2","unsafe_set_with_caml_modify","unsafe_set_int_assuming_curren","unsafe_set","old_obj","abs_float","one_ulp","upper_bound_for_int","is_x_minus_one_exact","lower_bound_for_int","min_int_as_float","clamp_unchecked","hash_fold_t$14","t_of_sexp$6","sexp_of_t$11","equal$6","compare$23","comparator$2","compare$25","comparator$4","init$6","convert_failure","to_string","num_bits_nativeint","int_to_int32_trunc","int_to_int32","int_to_int32_exn","int32_to_int_exn","int_to_int64","int64_to_int_trunc","min$11","max$10","int64_is_representable_as_int","int64_to_int","int64_to_int_exn","int_to_nativeint","nativeint_to_int_trunc","nativeint_to_int","nativeint_to_int_exn","int32_to_int64","min$12","max$11","int64_is_representable_as_int3","int64_to_int32_exn","int32_to_nativeint","nativeint_to_int32_exn","nativeint_to_int64","min$28","max$29","to_nativeint_exn","min$13","max$12","int64_is_representable_as_int6","insert_delimiter_every","delimiter","chars_per_delimiter","input_length","has_sign","num_digits","num_delimiters","output_length","input_pos","output_pos","num_chars_until_delimiter","first_digit_pos","insert_delimiter","delimiter$0","make_suffix","to_string_hum","invalid","of_string_with_delimiter","of_string","ocaml_lex_state","ocaml_lex_state$0","body","body$0","int32_positive_overflow_bounds","int_positive_overflow_bounds","int63_on_int64_positive_overfl","int64_positive_overflow_bounds","int64_negative_overflow_bounds","negative_exponent","overflow","pow$0","rval","round_down","round_up","round_towards_zero","to_multiple_of","round_nearest","modulus_minus_remainder","round","int64_popcount","int32_popcount","popcount","popcount$0","t_sexp_grammar","of_float_unchecked","comparator$6","validate_lbound$2","validate_ubound$2","validate_bound$2","validate_positive","validate_non_negative","validate_negative","validate_non_positive","is_positive","is_non_negative","is_negative","is_non_positive","to_string_hum$2","sexp_of_t$13","zero$2","minus_one$2","pp$9","invariant$2","pred$2","succ$2","to_int$2","of_int$0","max_value_30_bits","abs$3","symbol$57","symbol$58","symbol$59","symbol$60","symbol$61","incr$0","decr$0","shift_right","shift_right_logical","shift_left","bit_not$0","bit_or","bit_and","bit_xor","symbol$62","ceil_pow2","floor_pow2","is_pow2","floor_log2","ceil_log2","symbol$63","symbol$64","symbol$65","bswap16","ctz","clz","sexp_of_t$14","symbol$66","symbol$67","symbol$68","symbol$69","symbol$70","symbol$71","equal$7","compare$27","min$14","max$13","ascending$8","descending$8","between$3","clamp_exn$3","clamp$3","comparator$7","validate_lbound$3","validate_ubound$3","validate_bound$3","t_of_sexp_direct","empty$4","to_list$5","mem$4","add$5","remove$2","of_list$3","never_returns","func$5","t_sexp_grammar$0","of_string$11","validate_lbound$6","validate_ubound$6","validate_bound$6","validate_positive$0","validate_non_negative$0","validate_negative$0","validate_non_positive$0","is_positive$0","is_non_negative$0","is_negative$0","is_non_positive$0","sign$0","invariant$3","num_bits$0","shift_right_logical$0","shift_right$0","shift_left$0","bit_xor$0","bit_or$0","bit_and$0","rem$0","symbol$84","to_float","of_float_unchecked$0","of_float","ceil_pow2$0","floor_pow2$0","is_pow2$0","floor_log2$0","ceil_log2$0","between$6","clamp_exn$6","clamp$6","symbol$85","symbol$86","symbol$87","symbol$88","incr$1","decr$1","pow$1","symbol$89","symbol$90","symbol$91","symbol$92","round$0","round_towards_zero$0","round_down$0","round_up$0","round_nearest$0","ctz$0","clz$0","is_empty$5","of_alist_exn$0","set$3","add_exn$1","add$7","change$1","remove$5","nth$5","of_tree$1","of_sorted_array_unchecked$2","of_alist$0","of_iteri$0","of_increasing_iterator_uncheck$2","hash$13","t_sexp_grammar$1","of_string$13","shift_right_logical$1","shift_right$1","shift_left$1","bit_xor$1","bit_or$1","bit_and$1","rem$1","symbol$93","to_float$0","of_float_unchecked$1","num_bits$1","of_float$0","symbol$94","bswap32","bswap48","validate_lbound$7","validate_ubound$7","validate_bound$7","validate_positive$1","validate_non_negative$1","validate_negative$1","validate_non_positive$1","is_positive$1","is_non_negative$1","is_negative$1","is_non_positive$1","sign$1","invariant$4","between$7","clamp_exn$7","clamp$7","symbol$95","symbol$96","symbol$97","symbol$98","incr$2","decr$2","of_int64","to_int64","ceil_pow2$1","floor_pow2$1","is_pow2$1","floor_log2$1","ceil_log2$1","to_string_hum$4","sexp_of_t$21","pp$11","symbol$99","symbol$100","symbol$101","round$1","round_towards_zero$1","round_down$1","round_up$1","round_nearest$1","ctz$1","clz$1","the_group$2","t_sexp_grammar$2","comparator$11","wrap_modulo","invariant$5","symbol$102","symbol$103","neg$2","abs$4","one$0","succ$3","pred$3","min_value$1","max_value$1","lnot$0","land$0","lxor$0","lor$0","lsl$0","asr$0","lsr$0","pow$2","symbol$104","symbol$105","rem$2","popcount$1","to_int64$0","of_int64$0","of_int64_exn","of_int64_trunc","t_of_sexp$10","sexp_of_t$22","compare$33","is_pow2$2","clz$2","ctz$2","floor_pow2$2","ceil_pow2$2","floor_log2$2","ceil_log2$2","the_group$3","t_sexp_grammar$3","func$6","invalid_str","sign_and_signedness","to_string$15","of_string$15","signedness","pos_str","int63","int63$0","bswap16$0","bswap32$0","bswap48$0","float_lower_bound$2","float_upper_bound$2","minus_one$3","one$1","zero$3","num_bits$2","to_float$1","of_float_unchecked$2","of_float$1","validate_lbound$8","validate_ubound$8","validate_bound$8","validate_positive$2","validate_non_negative$2","validate_negative$2","validate_non_positive$2","is_positive$2","is_non_negative$2","is_negative$2","is_non_positive$2","sign$2","between$8","clamp_unchecked$4","clamp_exn$8","clamp$8","symbol$106","incr$3","decr$3","of_int$1","of_int_exn$0","to_int$3","to_int_exn","to_int_trunc","of_int32","of_int32_exn","to_int32","to_int32_exn","to_int32_trunc","of_nativeint$0","of_nativeint_exn","of_nativeint_trunc","to_nativeint$0","to_nativeint_exn$0","to_nativeint_trunc","hash$15","to_string$16","of_string$16","to_string$17","repr","validate_lbound$9","validate_ubound$9","validate_bound$9","func$7","t_sexp_grammar$4","compare_int32","of_string$18","num_bits$3","shift_right_logical$2","shift_right$2","shift_left$2","bit_xor$2","bit_or$2","bit_and$2","rem$3","symbol$110","to_float$2","of_float_unchecked$3","of_float$2","validate_lbound$10","validate_ubound$10","validate_bound$10","validate_positive$3","validate_non_negative$3","validate_negative$3","validate_non_positive$3","is_positive$3","is_non_negative$3","is_negative$3","is_non_positive$3","sign$3","symbol$111","symbol$112","symbol$113","symbol$114","symbol$115","symbol$116","descending$11","min$17","max$16","equal_int32","between$10","clamp_exn$10","clamp$10","invariant$6","symbol$117","symbol$118","symbol$119","symbol$120","incr$4","decr$4","pow$3","symbol$121","ceil_pow2$3","floor_pow2$3","is_pow2$3","floor_log2$3","ceil_log2$3","to_string_hum$6","sexp_of_t$24","pp$14","symbol$122","symbol$123","symbol$124","round$3","round_towards_zero$3","round_down$3","round_up$3","round_nearest$3","ctz$3","clz$3","hash_fold_t$20","hashable","of_key","Key","to_key","max$18","empty$9","height$1","update_height","old_height","new_height","balance","tree","left_node_left","left_node_right","lr_left","lr_right","right_node_left","right_node_right","rl_left","rl_right","set_left","tree$0","set_right","add$8","added","findi_and_call_impl","arg1","arg2","call_if_found","call_if_not_found","if_found","if_not_found","find_and_call","call_if_found$0","call_if_not_found$0","call_if_found$1","call_if_not_found$1","call_if_found$2","call_if_not_found$2","call_if_found$3","call_if_not_found$3","call_if_found$4","call_if_not_found$4","if_not_found$0","remove_min_elt$1","remove$6","removed","fold$11","init$0","rkey","rdata","rkey$0","rdata$0","rkey$1","rdata$1","lkey","ldata","right$0","init$1","data$1","iter$16","mapi_inplace","value$0","clear$4","mem$7","remove$7","length$15","inv$0","inv","left_key","right_key","to_list$7","add$10","iter$18","magnitude","round$5","sexp_of_float","validate$2","validate_positive$5","validate_non_negative$5","validate_negative$5","validate_non_positive$5","create$23","unsafe_blit$4","elide","to_string_list","sexp_of_t$27","initialize_module$0","ocamlrunparam_mentions_backtra","symbol$140","symbol$141","symbol$142","symbol$143","libname_ref","set$5","unset","add_environment_var","libs_to_entries","lookup_rev_lib","libname","force_drop","add_bench","type_conv_path","startpos","endpos","test_spec","entry","empty$10","eval_fail","custom_printf_001","equal_option$0","create$24","eq","xs$1","xs$0","map$23","uuid","int$2","pair","t_of_sexp$14","of_a","sexp_args$7","v1$5","v0$15","v0$16","v1$6","sexp_args$5","v1$1","v0$11","v0$12","v1$2","sexp_args$1","v0$3","v0$4","sexp_args$2","v0$5","v0$6","sexp_args","sexp_args$4","v0$9","v0$10","field_sexps","sorted_field","duplicates","extra","field_sexp","fvalue","sorted_value","sexp_args$6","v1$3","v0$13","v0$14","v1$4","sexp_args$3","v0$7","v0$8","sexp_args$0","v0$1","v0$2","map$24","to_string$21","v_sorted","bnds","bnds$0","digest_layer","to_digest","to_digest$0","equal$16","opaque","create$25","desc","apply$0","def","recurse","tid","get_poly_variant","annotate","basetype","poly_variant","var$1","apply$1","recurse$0","define","record","create$26","compare$36","a_064","b_065","b_067","a_066","cmp_a","a_068","b_069","b_015","b_013","a_014","b_019","b_017","a_020","b_021","b_023","a_024","b_025","b_027","a_028","b_029","t_031","t_030","t_033","t_032","b_035","a_036","b_037","t_039","t_038","t_041","t_040","a_042","b_043","b_045","a_004","b_005","t_007","t_006","t_009","t_008","a_048","b_049","b_053","b_051","a_054","b_055","b_059","b_057","a_060","b_061","b_063","t_of_sexp$15","equal_t0","var$2","apply$2","recurse$1","get_poly_variant$0","opaque$0","to_digest$1","to_digest$2","annotate$0","basetype$0","tuple$0","poly_variant$0","var$3","recurse$2","apply$3","define$0","record$0","variant$0","create$27","trips","members","scheme","custom_printf_108","v0$17","v1$7","v0$18","v0$19","v1$8","v1$9","v0$20","v_members","v_loc","v_gid","bnds$1","bnds$2","v1$10","v2$0","is_cyclic_0","via_VR","group","set","visited","trav_tid","trav","ts$0","lookup$0","a_109","b_110","t_112","t_111","t_114","t_113","extend","tenv","depth","look_env","extend_new_tid","def_t","tenv$0","exec","sequence_defining","acc_ys","eval_app","gid","formals","record_or_normal_variant","cyclic","cyclic_no_VR","venv","eval_definition","eval_poly_constr","eval_list","binds","alts","xss","vid","loc$0","custom_printf_115","tid$0","in_group","eval$0","bin_write_unit","bin_write_bool","all_bin_write_small_int","all_bin_write_int16","all_bin_write_int32","bin_write_char","bin_write_int","bin_write_nat0","bin_write_string","new_pos","bin_write_float","bin_write_el","pair$0","bin_write_a","bin_write_b","els_pos$1","els_pos$0","els_pos","els_pos_ref","bin_write_variant_int","bin_write_int_8bit","bin_read_unit","pos_ref","bin_read_bool","safe_bin_read_neg_int8","safe_bin_read_int16","bin_read_nat0","ch","bin_read_bytes","start_pos","bin_read_string","bin_read_char","bin_read_int","bin_read_float","bin_read_int32","bin_read_int64","bin_read_nativeint","bin_read_ref","bin_read_el","bin_read_option","bin_read_pair","bin_read_a","bin_read_b","bin_read_list","dummy_float_buf","max_float_array_length","el$1","maybe_float","el$0","bin_read_variant_int","bin_read_int_8bit","bin_shape_array","pair$1","bin_size_unit","bin_size_bool","bin_size_char","bin_size_int","bin_size_nat0","bin_size_string_or_bytes","size_len","bin_size_string","bin_size_float","bin_size_int32","bin_size_int64","bin_size_el","bin_size_a","bin_size_b","len$2","bin_size_len","total_len","total_len_ref","variant_wrong_type","pair$2","bin_writer_el1","bin_writer_el2","pair$3","bin_reader_el1","bin_reader_el2","pair$4","bin_el1","bin_el2","cnv_writer","cnv","tp_class","cnv_reader","vtag","pre_test_hook","nanoseconds_since_unix_epoch","create$28","binary","may_eof","really_input_exn","input_byte","input_char","already_read","to_read","already_read$0","to_read$0","mach","with_file","binary$0","fail_if_exists$0","perm$0","fail_if_exists","sth$2","value$1","am_recording_value","am_recording","of_string$22","to_string$22","nanos","to_string_with_same_unit","of_string$23","Format","create$29","nested_timer","definition_timer","record_start","record_until","until","gc_stats_after","gc_stats_before","runtime","gc_events","nested$0","nested_timing_events","timing_event","nested","timing_events_to_strings","duration_strings","duration_string","description","compactions","major_collections","minor_collections","to_list","strings","left_column_width","fake_timing_events","print_recorded_timing_events","timing_events","notify_of_overriding","override","timing_events$0","nested_timing_event","uid$0","witness","next$1","cmp$0","same_witness$0","nm1","nm2","uid","typename_of_t","args_labels","ocaml_repr","tyid","traverse","internal_use_only","is_polymorphic","internal_use_only$0","index$0","is_mutable","tyid$0","traverse$0","internal_use_only$1","typename_of_t$0","has_double_array_tag","create$0","internal_use_only$2","typename_of_int","typename_of_int32","typename_of_int64","typename_of_nativeint","typename_of_char","typename_of_float","typename_of_string","typename_of_bytes","typename_of_bool","typename_of_unit","typename_of_option","typename_of_list","typename_of_array","typename_of_lazy_t","typename_of_ref","typename_of_function","typename_of_tuple2","typename_of_tuple3","typename_of_tuple4","typename_of_tuple5","rep","rep$0","rep$1","rep$2","rep$3","rep$4","name$24","b$1","a$1","b$2","a$2","typename_of_t$1","rng","dom","rep$5","rep$6","same_witness$1","r2$1","r2$2","r2$3","r2$4","rng2","dom2","b2$0","a2$0","b1$0","a1$0","b2$1","a2$1","b1$1","a1$1","c2$1","b2$2","a2$2","c1$1","b1$2","a1$2","r2$5","r2$6","r2$7","name2","same$0","same_witness_exn$0","typerep_and_typename_of_int63_","repr_of_poly_variant","hash_variant","double_array_value","double$0","simple","named","of_p1","of_p2","of_p3","typename_of_named","typerep_of_t","v$106","dir_or_error","sexp_of_t$28","v_end_pos","v_start_pos","v_line_start","v_line_number","v_filename","bnds$3","compare$37","of_string$24","expected_length","tests_run","protect$3","current$2","set$7","absolute_filename","unset$0","flushed","upon_unreleasable_issue","get_position","extract_output","ocaml_lex_state$1","ocaml_lex_state$2","relative_filename","with_ic","fname","get_outputs_and_cleanup","last_ofs","next_ofs","outputs","trailing_output","current_test","get_current","save_output","location","save_and_return_output","prev_pos","prev_pos$0","trailing","blocks","final_flush","max_attempts","file_digest","expectations","uncaught_exn_expectation","uncaught_exn","saved_output","run$0","defined_in","inline_test_config","registering_tests_for","return$12","bind$11","to_run","of_int$3","mix_bits","mix64","z$0","z$1","random_int64","create$30","random_state","gamma","odd_gamma","next_int64","bool$0","int64$0","maximum","draw$0","draw","int$3","int32$0","nativeint","unit_float_from_int64","float$0","bits_to_represent","log_uniform","min_bits","max_bits","log_uniform$0","log_uniform$1","log_uniform$2","log_uniform$3","return$13","tf","tx","map$26","map$27","values","weights","value_array","weight","cumulative","choice","lazy_t","of_generator","min_length","max_length","max_length$0","remaining","max_index","let_syntax_267","value_t","list_generic","elt_gen","list_with_length","char_print_uniform","char_uniform","small_int","allow_zero","weighted_low","weighted_high","small_non_negative_int","let_syntax_002","uniform_inclusive","log_uniform_inclusive","non_uniform","inclusive","log_inclusive","uniform_all","quickcheck_generator$0","float_zero_exponent","float_zero_mantissa","float_max_positive_subnormal_v","float_subnormal_exponent","float_min_subnormal_mantissa","float_max_subnormal_mantissa","float_min_normal_exponent","float_max_normal_exponent","float_max_nan_mantissa","float_inf_exponent","float_inf_mantissa","float_nan_exponent","float_min_nan_mantissa","float_num_mantissa_bits","float_normal_mantissa","float_exponent_weighted_low","float_exponent_weighted_high","midpoint","float_exponent","float_zero","let_syntax_004","let_syntax_005","float_subnormal","float_normal","float_infinite","let_syntax_010","let_syntax_011","float_nan","float_matching_classes","quickcheck_generator$1","float_finite_non_zero","lower_inclusive","upper_inclusive","char_gen","let_syntax_033","key_gen","data_gen","keys","keys$0","bigarray1","elts","elts$0","offset$1","offset$0","max_total_size","max_b","b_weighted_low","bigarray2_dim","bigarray2","quickcheck_shrinker","f_inverse","of_shrinker","elt_t","list_t","shrinker","shrink_list","shrink_tree","key_t","data_t","drop_keys","shrink_keys","smaller_key","shrink_data","smaller_data","elt","drop_elts","shrink_elts","smaller_elt","default_config","lazy_nondeterministic_state","with_sample","generator","config","examples","number_of_size_values","remaining_sizes","sequence","run$1","config$0","examples$0","M","error$1","error$2","input$0","shrink_count$1","alternates$2","shrink_count","alternates","shrink_count$0","alternates$0","alternate","alternates$1","with_sample_exn","quickcheck_observer","sizes$0","key_obs","data_obs","elt_obs","length$16","create$31","max_mem_waiting_gc_in_bytes","create$32","unsafe_blit$5","length$17","to_string$23","of_string$25","sexp_of_pos","v_offset","v_col","v_line","sexp_of_range","make_range_incl","last_pos","create$33","initial_pos","reset$2","add_uint16","add_bits","int_buf","add_gen","instr","instr_bits","add_newline","create$34","chunks","chunk","no_more","next_instruction_bits","added_bits","advance","skip","offset_shift","offset_shift_num_bits","skip$0","offset_shift$0","offset_shift_num_bits$0","skip$1","offset_shift$1","offset_shift_num_bits$1","offset_shift$2","skip$2","advance_exn","find$7","sub_sexp_count","loop_list","sexps","loop$1","finalize","find$8","find$9","empty$11","get_many","empty$12","get_single","get_many$0","v_location","v_sub_sexp","v_user_exn","position","initial_state","error_state","rev_chunks","chunk_pos","extra_bits","is_ignoring","is_not_ignoring","raise$0","at_eof","reason","old_parser_exn","current_pos","set_automaton_state","advance$0","advance_eol","newline_offset","add_token_char","add_atom_char","add_quoted_atom_char","check_new_sexp_allowed","is_single","add_pos","add_first_char","eps_add_first_char_hash","start_quoted_string","eps_add_escaped_cr","hex_val","add_dec_escape_char","opening","do_reset_positions","reset_positions","toplevel_sexp_or_comment_added","saved_offset","saved_full_sexps","stack$0","is_top_level","comment_added_assuming_cst","sexp_added","inner_comment_depth","is_comment","make_list","add_comment_to_stack_cst","comment","add_sexp_to_stack_cst","rev_comments","hash_semi_pos","closing","stack$1","end_pos","make_loc","add_non_quoted_atom_pos","eps_push_atom","push_quoted_atom","start_line_comment","end_line_comment","eps_eoi_check","create$35","Stack","tr_00","tr_01","tr_02","tr_03","tr_04","tr_05","tr_06","tr_07","tr_08","tr_09","tr_10","tr_11","tr_12","tr_13","tr_14","tr_15","tr_16","tr_17","tr_18","tr_19","tr_20","tr_21","tr_22","tr_23","tr_24","tr_25","tr_26","tr_27","tr_28","tr_29","tr_30","stack$2","tr_31","tr_32","tr_33","tr_34","tr_35","tr_36","tr_37","tr_38","tr_39","tr_40","tr_41","tr_42","tr_43","tr_44","tr_45","tr_46","tr_47","tr_48","tr_49","tr_50","tr_51","tr_52","tr_53","tr_54","tr_55","tr_56","tr_57","tr_58","tr_59","tr_60","tr_61","tr_62","tr_63","tr_64","tr_65","tr_66","tr_67","tr_68","tr_69","tr_70","tr_71","tr_72","tr_73","tr_74","tr_75","tr_76","tr_77","tr_78","tr_eoi_00","tr_eoi_01","tr_eoi_02","tr_eoi_03","tr_eoi_04","tr_eoi_05","tr_eoi_06","tr_eoi_07","transitions","transitions_eoi","old_parser_approx_cont_states","feed_eoi","feed_substring_unsafe","stop","feed_subbytes_unsafe","match$1","make_value","mode$0","make_value$0","make_value$1","mode$1","make_value$2","mode$2","make_value$3","make_value$4","mode$3","make_value$5","mode$4","make_value$6","make_value$7","mode$5","make_value$8","make_value$9","apply_f","apply_f$0","apply_f$1","to_binable","of_binable","bin_shape_t","of_bigstring","to_bigstring","prefix_with_length","bigstring_length","group$3","bin_shape_t$0","bin_size_t","bin_write_t","bin_writer_t","bin_read_t","vint","bin_read_t$0","bin_reader_t","bin_t","compare$38","a_001","hash_fold_t$21","hash$20","t_of_sexp$16","sexp_of_t$29","group$4","bin_shape_t$1","bin_size_t$0","bin_write_t$0","bin_writer_t$0","bin_read_t$1","bin_read_t$2","bin_reader_t$0","bin_t$0","compare$39","a_003","b_004","hash_fold_t$22","hash$21","t_of_sexp$17","sexp_of_t$30","group$5","bin_shape_t$2","bin_size_t$1","bin_write_t$1","bin_writer_t$1","bin_read_t$3","bin_read_t$4","bin_reader_t$1","bin_t$1","compare$40","a_005","b_006","hash_fold_t$23","hash$22","t_of_sexp$18","atom$0","t_of_sexp$19","sexp_of_t$31","group$6","bin_shape_t$3","bin_size_t$2","size_args","bin_write_t$2","bin_writer_t$2","bin_read_t$5","arg_1","bin_read_t$6","bin_reader_t$2","bin_t$2","compare$41","a_007","b_008","right_010","left_009","hash_fold_t$24","hsv$0","hash$23","t_of_sexp$20","t_of_sexp$21","sexp_of_t$32","group$7","bin_shape_t$4","bin_size_t$3","bin_write_t$3","bin_writer_t$3","bin_read_t$7","bin_read_t$8","bin_reader_t$3","bin_t$3","compare$42","a_011","b_012","right_016","left_015","hash_fold_t$25","hash$24","t_of_sexp$22","sexp_of_t$33","group$8","bin_shape_t$5","bin_size_t$4","bin_write_t$4","bin_writer_t$4","bin_read_t$9","bin_read_t$10","bin_reader_t$4","bin_t$4","compare$43","a_017","b_018","hash_fold_t$26","hash$25","t_of_sexp$23","sexp_of_t$34","group$9","bin_shape_t$6","t_of_sexp","size_of_a","write_a","a_029","b_030","a_031","b_032","group$10","bin_shape_t$7","bin_size_t$8","bin_write_t$8","bin_read_t$17","bin_shape_t$14","failwiths","of_alist","of_alist_report_all_dups","of_alist_or_error","of_alist_exn","of_alist_multi","create_mapped","create_with_key","create_with_key_or_error","create_with_key_exn","variant3","generator_033","generator_034","generator_035","size_040","random_041","size_038","random_039","size_036","random_037","tuple2","generator_166","generator_167","size_168","random_169","tuple3","generator_184","generator_185","generator_186","size_187","random_188","of_hash","list_with_length$0","empty$13","nondeterministic_state","random_state_of_seed","make_seed","make_shrink_count","make_config","trials","shrink_attempts","make_test_m","quickcheck_generator","sexp_of","quickcheck_shrinker$0","random_value","gen","random_sequence","test","testable","test_or_error","test_m","test_distinct_values","distinct_values","actual_count","sexp_of_elt","test_can_generate","sexp_of_value","default_sizes","map_t","set_t","create$39","representative","inner_node","inner","descendants","descendants$0","get$8","union$2","create$40","equal$17","union_find_get_check_no_pendin","check_no_pending_iterations","incr_length","incr_pending_iters","decr_pending_iters","with_iteration_2","with_iteration_3","with_iteration_4","create_aux","is_singleton","value$2","unsafe_split_or_splice","unsafe_split_or_splice_after","unsafe_split_or_splice_before","check_two_nodes_no_pending_ite","split_or_splice_before","insert_before","node","dummy_header","unlink","create$41","iter$20","length$19","fold$13","elt$0","iter$21","length$20","to_list$8","sexp_of_t$35","first$0","insert_empty","new_elt","add$11","remove_one","remove$8","move_to_front","first$1","after_elt","move_to_back","last","sexp_of_key","sexp_of_data","invariant","kv","growth_allowed","ensure_can_modify","lookup_exn","find_map","enqueue","back_or_front","enqueue_back","enqueue_front","enqueue_exn","enqueue_back_exn","enqueue_front_exn","lookup_and_move_to_back_exn","lookup_and_move_to_back","lookup_and_move_to_front_exn","lookup_and_move_to_front","dequeue_with_key","maybe_kv","dequeue_with_key_exn","dequeue_back_with_key","dequeue_back_with_key_exn","dequeue_front_with_key","dequeue_front_with_key_exn","dequeue","dequeue_back","dequeue_front","first_with_key","dequeue_exn","dequeue_back_exn","dequeue_front_exn","count$0","sum$0","min_elt$0","max_elt$0","fold_result$0","fold_until$0","dequeue_all","remove_exn","lookup_and_remove","replace_exn","drop","drop_back","drop_front","sexp_of_t$0","of_data","hash_fold_t$0","bin_size_t$13","bin_write_t$13","bin_read_t$26","bin_read_t$27","t_of_sexp$25","sexp_of_t$36","equal$18","compare$45","hash_fold_t$30","bin_size_t$14","bin_write_t$14","bin_read_t$28","bin_read_t$29","typename_of_t$2","hash_fold_t$31","hash$30","comparator$14","bin_size_t$16","bin_write_t$16","bin_read_t$32","bin_read_t$33","bin_size_t$17","bin_write_t$17","bin_read_t$34","bin_read_t$35","bin_size_t$18","bin_write_t$18","bin_read_t$36","bin_read_t$37","of_string$27","bin_size_t$19","bin_write_t$19","bin_read_t$38","bin_read_t$39","bin_shape_t$38","bin_writer_t$19","bin_reader_t$19","bin_t$19","to_q","group$44","bin_shape_array$1","bin_size_array$0","bin_write_array$0","bin_read_array$1","compare_array","len_a","len_b","equal_array","group$45","bool$1","group$46","bin_shape_char$0","func$8","group$47","bin_shape_float$0","group$48","bin_shape_int","func$9","group$49","bin_shape_list$0","bin_size_list$0","bin_write_list$0","bin_read_list$0","compare_list$0","a_037","b_038","a_039","b_040","equal_list$0","a_041","b_042","a_043","b_044","group$50","bin_shape_option$0","bin_size_option$0","bin_write_option$0","bin_read_option$0","compare_option$0","a_049","b_050","a_051","b_052","equal_option$1","a_053","b_054","a_055","b_056","group$51","bin_shape_string","func$10","group$52","bin_shape_unit$0","group$53","bin_shape_sexp_list","group$54","bin_shape_sexp_option","group$55","bin_shape_t$48","sexp_of_t$37","t_of_sexp$26","compare$46","before_first_transition","to_external","of_external","bin_shape_t$50","group$56","bin_shape_t$51","group$57","bin_shape_t$52","group$58","bin_shape_t$53","compare$47","original_filename","zone","digest","bool_of_int","long$0","int32_of_char","input_long_as_int32","sb1","sb2","sb3","sb4","input_long_as_int","input_long_as_int63","input_long_long_as_int63","int63_of_char","long_long","result$0","result$1","result$2","result$3","result$4","result$5","result$6","input_list","lst$0","input_array","input_regime","utc_offset_in_seconds","is_dst","abbrv_index","abbrv","input_tz_file_gen","input_transition","input_leap_second","utc_local_count","std_wall_count","leap_count","transition_count","type_count","transition_times","transition_indices","regimes","raw_abbrvs","abbrvs","next_index","abbrvs$0","indexed_abbrvs","leap_seconds","regime","new_regime","start_time_in_seconds_since_ep","ltt","default_local_time_type","input_leap_second_gen","time_in_seconds_since_epoch","seconds","read_header","magic","input_tz_file_v1","input_tz_file","zonename","version","x_001","make_zone","of_utc_offset","sexp_of_t$39","likely_machine_zones","utc","name$76","reset_transition_cache","get_regime_exn","effective_start_time","index_lower_bound_contains_sec","index_upper_bound_contains_sec","binary_search_index_of_seconds","transition","index_of_seconds_since_epoch","index$1","index$2","index$3","index$4","index_has_prev_clock_shift","index_has_next_clock_shift","index_prev_clock_shift_time_ex","index_prev_clock_shift_amount_","index_abbreviation_exn","validation_failed","create_exn","raw","to_type_id","sexp_of_t$40","sexp_of_type_id","type_id","type_id1","type_id2","name_of_key","uid_of_key","type_id_name","type_id_uid","sexp_of_t$1","mem_by_id","remove_by_id","add_exn","change_exn","change","orig","to_alist","sexp_of_t$2","invariant$0","empty$0","set$0","mem$0","mem_by_id$0","find$0","find_exn$0","add$0","add_exn$0","change$0","change_exn$0","update$0","remove$0","remove_by_id$0","to_alist$0","find$10","empty$14","race_free_create_loop","make","new_x","create$42","uncurry","group$59","bin_shape_t$54","bin_size_t$23","bin_write_t$24","bin_writer_t$25","bin_read_t$48","bin_read_t$49","bin_reader_t$25","bin_t$25","compare$48","hash_fold_t$33","hash$32","size_018","random_019","size_016","random_017","size_014","random_015","size_012","random_013","size_010","random_011","size_008","random_009","size_006","random_007","to_string$26","of_string_internal","of_int_exn$2","of_string$29","compare$49","comparator$15","hash$33","int63_ten","int63_twenty","int63_billion","digits_of_positive_int63","digits_of_int63_max_value","max_int63_with","billions","digit_of_char","write_1_digit_int","return_tens_and_write_ones","tens","ones","write_2_digit_int","write_3_digit_int","write_4_digit_int","write_5_digit_int","write_6_digit_int","write_7_digit_int","write_8_digit_int","write_9_digit_int","read_1_digit_int","read_2_digit_int","max_scale","check_pos$0","check_write","write_2_digit_int$0","write_3_digit_int$0","write_int63","digits$1","int63$1","custom_printf_003","custom_printf_004","digits$0","check_read","read_1_digit_int$0","read_2_digit_int$0","t_of_sexp$29","sexp_of_t$42","compare$50","hash_fold_t$34","of_int_exn$3","to_int$5","to_binable$1","of_binable$1","bin_size_t$24","bin_write_t$25","bin_read_t$50","bin_read_t$51","bin_shape_t$55","bin_writer_t$26","bin_reader_t$26","bin_t$26","num_months","t_of_sexp$30","all_strings","hash$34","bin_shape_t$56","create0","year","month","all_strings$0","days_in_month","bin_read_t$52","bin_read_t$53","bin_reader_t$27","bin_size_t$25","bin_write_t$26","bin_writer_t$27","bin_t$27","unchecked_value","none$0","to_string$27","parse_year4","parse_day","ensure","month_num","month_abrv","year$0","of_string$30","y_field","m_field","d_field","field_sexp$3","field_sexp$0","field_sexp$1","fvalue$0","field_sexp$2","fvalue$1","d_value","m_value","y_value","t_of_sexp$31","sexp_of_t$43","compare$52","sexp_of_t$44","compare$54","unix_epoch","of_year","of_date","c_10_000","c_14_780","c_3_652_425","to_date","days","ddd","ddd$0","y$2","unix_epoch$0","add_days","gen_incl","quickcheck_generator$3","hash$35","suffixes","am_suffixes","pm_suffixes","find_suffix","suffixes$0","suffixes$1","has_colon","decrement_length_if_ends_in_sp","invalid_string","parse$0","am_or_pm","expect_minutes_and_seconds","hr$1","expect_seconds","subsec_nonzero","subsec_len","subsec_pos","sec","sec$1","nonzero","hr$0","sec$0","subsec_len$0","parse_iso8601_extended","verify","of_binable$2","to_binable$2","t_of_sexp$32","to_string$28","x_abs","of_string$31","float_of_string","group$60","bin_shape_t$57","bin_writer_t$28","bin_reader_t$28","bin_t$28","t_of_sexp$33","format_decimal","tenths","units","compare$55","t_of_sexp$34","sign_field","hr_field","min_field","sec_field","ms_field","us_field","ns_field","field_sexp$7","fvalue$2","field_sexp$4","fvalue$3","field_sexp$5","fvalue$4","field_sexp$6","fvalue$5","ns_value","us_value","ms_value","sec_value","min_value","hr_value","sign_value","sexp_of_t$45","v_ns","v_us","v_ms","v_sec","v_min","v_hr","v_sign","bnds$4","bnds$5","robust_comparison_tolerance","symbol$145","symbol$146","symbol$147","symbol$148","symbol$149","symbol$150","robustly_compare","integral","fractional","nanoseconds","nanoseconds$0","seconds$0","ns","microseconds","us","milliseconds","to_span_since_epoch","divide_by_unit_of_time","unit_of_time","scale_by_unit_of_time","sth$3","sth$4","sth$5","sth$6","span","percent","factor","abs_t","suffix_of_unit_of_time","invalid_string$0","state_is_final","invalid_string$1","magnitude$0","suffix_index","unit_of_time_list$0","unit_of_time$0","float_string","magnitude$1","string_of_float_without_traili","sum$3","sum_t","to_float_string","fixup_unit_of_time","sum_t$0","rem_t","fixup_magnitude","to_int_string_and_sum","unit_span","new_sum_t","new_rem_t","next_magnitude","next_sum_t","next_rem_t","new_sum_t$0","symbol$153","magnitude_string","day_string","hour_string","sum_t$1","minute_string","order_of_magnitude_of_first_di","half_ulp","order_of_magnitude_of_final_di","number_of_digits","decimals","align_decimal","float$1","suffix$7","group$61","bin_shape_t$58","bin_writer_t$29","bin_reader_t$29","bin_t$29","hash$36","t_of_sexp$36","group$62","bin_shape_t$59","bin_writer_t$30","bin_reader_t$30","bin_t$30","t_of_sexp$37","symbol$154","symbol$155","symbol$156","symbol$157","symbol$158","symbol$159","robustly_compare$0","to_span_since_start_of_day","is_valid","of_span_since_start_of_day_unc","span_since_start_of_day_is_val","of_span_since_start_of_day","start_of_next_day","start_of_day","add$12","sub$4","next$3","candidate","prev$0","diff$1","approximate_end_of_day","create$44","ns$0","us$0","ms$0","to_parts$0","to_string_gen","drop_ms","drop_us","drop_us$0","dont_print_us","dont_print_ms","dont_print_s","to_string_trimmed","to_sec_string","to_millisec_string","small_diff","ofday1","ofday2","to_string$30","create_from_parsed","subsec","of_string$33","t_of_sexp$38","sexp_of_t$47","of_string_iso8601_extended","gen_incl$1","gen_uniform_incl$0","quickcheck_generator$4","quickcheck_observer$4","quickcheck_shrinker$3","group$63","bin_shape_t$60","bin_writer_t$31","bin_reader_t$31","bin_t$31","hash$37","t_of_sexp$39","group$64","bin_shape_t$61","bin_writer_t$32","bin_reader_t$32","bin_t$32","t_of_sexp$40","epoch","is_earlier","is_later","of_span_in_seconds","span_in_seconds","of_time_in_seconds","time_in_seconds","time$0","index_of_date_and_ofday","relative","index_offset_from_utc_exn","index_prev_clock_shift_time_ex$0","index_next_clock_shift_time_ex","index_prev_clock_shift_amount_$0","index_next_clock_shift_amount_","abbreviation","index_prev_clock_shift","prev_clock_shift","next_clock_shift","date_and_ofday_of_absolute_tim","offset_from_utc","absolute_time_of_date_and_ofda","abs_diff","of_date_ofday","ofday","of_date_ofday_precise","proposed_time","shift_amount","shift_start","shift_backwards","date_cache","reset_date_cache","set_date_cache","rel","effective_day_start","effective_day_until","cache_start_incl","cache_until_excl","to_ofday","to_date_ofday","to_date_ofday_precise","clock_shift_after","clock_shift_before_or_at","amount","ofday$0","ambiguity","amount$0","from_tz","to_tz","start_time","utc_offset$0","utc_epoch","offset_string","utc_offset","is_utc","to_string_abs_parts","offset_string$0","to_string_abs_trimmed","to_string_abs","to_string_iso8601_basic","to_filename_string","of_filename_string","date$0","ofday$1","of_localized_string","occurrence","before_or_after","first_guess_date","first_guess","increment","ensure_colon_in_offset","offset_length","of_string_gen","default_zone","find_zone","ofday$2","tz","ofday$3","date$1","ofday_to_sec","od","tz$0","utc_offset$1","utc_t","zone_name","gen_uniform_incl","of_synthetic_span_since_epoch","to_synthetic_span_since_epoch","to_absolute","of_absolute","absolute","sec_per_day","to_days_from_epoch","days_from_epoch_approx","ofday_of_days_from_epoch","days_from_epoch","days_from_epoch_in_sec","date_of_days_from_epoch","to_date$0","next_multiple_internal","can_equal_after","interval","base_to_after","can_equal_before","float_ns","group$65","bin_shape_t$62","nanosecond$0","microsecond$0","millisecond$0","second$1","minute$0","hour$0","max_value_for_1us_rounding","min_value_for_1us_rounding","of_int_sec$0","of_sec","to_sec$0","to_int_sec","group$66","bin_shape_t$63","bin_writer_t$33","bin_reader_t$33","bin_t$33","compare$56","number_of_digits_to_write","span_part_magnitude","write_char","write_2_chars","char1","char2","write_digits","write_if_non_empty","nanos_of_millisecond","nanos_of_microsecond","int63_60","int63_24","digits_of_d","digits_of_h","digits_of_m","decimal_unit","decimal_unit_integer","decimal_unit_billionths","decimals_of_decimal_unit","sign_len","d_len","h_len","m_len","digits_len","decimals_len","decimal_unit_len","string_length","int63_10","min_mult10_without_underflow","invalid_string$2","add_without_underflow","min_factor_of","min_days_without_underflow","min_hours_without_underflow","min_minutes_without_underflow","min_seconds_without_underflow","min_milliseconds_without_under","min_microseconds_without_under","min_nanoseconds_without_underf","neg_ns","round_ties_before_negating","has_digit","end_of_digits","digit$0","neg_integer","decimal_pos","end_of_decimals","scale$0","min_without_underflow","neg_integer_ns","neg_nanos_of_part","divisor$0","round_at","numerator","denominator","comparator$17","compare$57","float$2","suffix$0","group$67","bin_shape_t$64","bin_writer_t$34","bin_reader_t$34","bin_t$34","compare$58","hash$38","group$68","bin_shape_t$65","bin_writer_t$35","bin_reader_t$35","bin_t$35","group$69","bin_shape_t$66","create_from_parsed$0","of_string$35","t_of_sexp$42","to_string$32","thousand","sexp_of_t$49","group$70","bin_shape_t$67","bin_writer_t$36","bin_reader_t$36","bin_t$36","group$72","bin_shape_t$69","bin_size_t$26","bin_write_t$27","bin_read_t$54","bin_read_t$55","t_of_sexp$43","sexp_of_t$51","of_format","to_format","create$45","set_exn","get_exn","compare$60","t_of_sexp$44","minor_words_field","promoted_words_field","major_words_field","minor_collections_field","major_collections_field","heap_words_field","heap_chunks_field","live_words_field","live_blocks_field","free_words_field","free_blocks_field","largest_free_field","fragments_field","compactions_field","top_heap_words_field","stack_size_field","forced_major_collections_field","field_sexp$17","fvalue$6","field_sexp$8","fvalue$7","field_sexp$9","fvalue$8","field_sexp$10","fvalue$9","field_sexp$11","fvalue$10","field_sexp$12","fvalue$11","field_sexp$13","fvalue$12","field_sexp$14","fvalue$13","field_sexp$15","fvalue$14","field_sexp$16","fvalue$15","forced_major_collections_value","stack_size_value","top_heap_words_value","compactions_value","fragments_value","largest_free_value","free_blocks_value","free_words_value","live_blocks_value","live_words_value","heap_chunks_value","heap_words_value","major_collections_value","minor_collections_value","major_words_value","promoted_words_value","minor_words_value","sexp_of_t$52","v_forced_major_collections","v_stack_size","v_top_heap_words","v_compactions","v_fragments","v_largest_free","v_free_blocks","v_free_words","v_live_blocks","v_live_words","v_heap_chunks","v_heap_words","v_major_collections","v_minor_collections","v_major_words","v_promoted_words","v_minor_words","bnds$6","arg$7","bnds$7","arg$8","bnds$8","arg$9","bnds$9","arg$10","bnds$10","arg$11","bnds$11","arg$12","bnds$12","arg$13","bnds$13","arg$14","bnds$14","arg$15","bnds$15","compare$61","t_of_sexp$45","minor_heap_size_field","major_heap_increment_field","space_overhead_field","verbose_field","max_overhead_field","stack_limit_field","allocation_policy_field","window_size_field","custom_major_ratio_field","custom_minor_ratio_field","custom_minor_max_size_field","custom_minor_max_size_value","custom_minor_ratio_value","custom_major_ratio_value","window_size_value","allocation_policy_value","stack_limit_value","max_overhead_value","verbose_value","space_overhead_value","major_heap_increment_value","minor_heap_size_value","sexp_of_t$53","v_minor_heap_size","v_major_heap_increment","v_space_overhead","v_verbose","v_max_overhead","v_stack_limit","v_allocation_policy","v_custom_minor_max_size","v_custom_minor_ratio","v_custom_major_ratio","v_window_size","return$14","capture","general","hashable$2","cache_size_bound","hashable$1","cache$0","hashable$0","cache","really_call_f","create$46","initial_length","never_shrink","never_shrink$0","initial_length$0","arr_length","length$21","is_empty$7","assert_not_empty","of_array$3","new_arr","actual_front","actual_back","old_arr","break_pos","get$9","i_from_zero","apparent_front","apparent_back","true_i","max_int","add$15","sub$6","div","rem$5","logand","logor","logxor","shift_left$4","shift_right$4","of_int$4","of_int64$1","to_int64$2","zero$5","one$3","lognot$1","succ$5","pred$5","compare$62","equal$20","max$20","min$20","pp$17","max_int$0","add$16","sub$7","mul$0","div$0","rem$6","logand$0","logor$0","logxor$0","shift_left$5","shift_right$5","of_int$5","of_int64$2","to_int64$3","zero$6","one$4","lognot$2","succ$6","pred$6","compare$63","equal$21","max$21","min$21","pp$18","max_int$1","zero$7","one$5","lognot$3","succ$7","pred$7","compare$64","equal$22","max$22","min$22","pp$19","max_int$2","succ$8","pred$8","compare$65","max$23","min$23","pp$20","of_byte_size","to_binable$3","of_binable$3","to_binable$4","of_binable$4","pp_open_xbox","extra_box","open_tag","close_tag","tag_string","fprint_opt_label","lp","fprint_t","fprint_list_body_stick_left","fprint_list","indent$0","cl$0","sep$0","op$0","base_indent","sep_indent","close_extra$0","open_extra$0","close_extra","open_extra","equal$25","create$47","really_extend","slen0","reqlen","create$48","make_room","shrlen","alloc$0","add_sub","add_substring","write_stringlit","add$17","clear$5","contents$0","json_error","utf8_of_code","maxbits","is_object_or_array","init_lexer","lnum","buf$0","buf$1","write_special","ob","finish_string","json_string_of_string","float_needs_period","tuple$1","variant$1","std","ob$0","s$3","hex$0","write_special$0","finish_string$0","write_string","write_null","write_bool","max_digits","write_digits$0","write_int","float_needs_period$0","iter2$4","f_elt","f_sep","write_t","write_std_json","to_string$34","std$0","read_junk","junk","to_basic","hex$1","write_special$1","finish_string$1","write_string$0","write_null$0","write_bool$0","max_digits$0","write_digits$1","write_int$0","float_needs_period$1","iter2$5","f_sep$0","write_t$0","write_std_json$0","to_string$35","hex$2","custom_error","descr","offs","bol","file_line","read_junk$0","long_error","extra_junk","extract_positive_int","extract_negative_int","newline","read_colon","read_object_sep","read_object_end","read_tuple_sep","read_tuple_end","read_array_sep","read_array_end","finish_string$2","ocaml_lex_state$3","ocaml_lex_state$4","high10","low10","read_ident","finish_comment","read_space","read_json$0","ocaml_lex_read_json_rec","field_name","read_json","field_name$0","cons","finish_variant","read_eof","junk$0","from_lexbuf","stream","from_string$0","typerr","js","assoc","member","to_string$36","read_junk$1","junk$1","symbol_bind$5","symbol$169","map_bind","safe_map","func$11","func$12","var_to_bits","gen$0","equal$26","rhs1","rhs0","lhs1","lhs0","of_interval","canonicalize","a4","a3","disjoint_union_exn","of_intervals_exn","is","is$0","invariant$9","gen_from","min_size","go","gen$1","gen_disjoint_pair","y0","y3","num_bits$5","compare$66","equal$27","symbol$170","symbol$171","of_int$6","symbol$172","symbol$173","symbol$174","symbol$175","to_int_exn$1","to_string$37","of_string$38","shift_left$6","shift_right$6","log_and","log_or","two_to_the_i","compare$67","is_integer_string","char_is_digit","of_string_base","of_string_no_underscores","group$74","bin_shape_t$71","bin_size_t$28","bin_write_t$29","bin_read_t$58","bin_read_t$59","arg_1$0","to_binable$5","of_binable$5","t_of_sexp$46","sexp_of_t$54","bin_size_t$29","bin_write_t$30","bin_read_t$60","bin_read_t$61","bin_shape_t$72","bin_writer_t$37","bin_reader_t$37","bin_t$37","to_string_hum$11","range_at_depth","random_bigint_at_depth","prev_depth","range$0","tolerance_factor","depth$0","int$4","bits$3","extra_bytes","num_bytes","hash$40","to_string$39","char_is_hex_digit","of_hex_string_no_underscores","of_string$40","module_name$31","cvar_of_sexp","of_f","sexp_of_cvar","of_index","var$5","bind$1","return$2","unhandled","fail$0","run$2","label_stack","req","hs","handle","req$1","create_single","request","bind$13","return$15","run$3","map2$4","read_var","value_of_fields","var_to_fields","field_vars","fields","map$29","symbol_bind$6","bind$14","return$16","map$30","join$8","ignore_m$0","all$3","all_unit$0","run$4","rc","rc$0","value$3","cases","add_case","case$0","sexp_of_basic","of_basic","unhandled$0","sexp_of_t$55","t_of_sexp$47","to_basic$0","map$31","v3","Field","get_value","override_label","label_opt","basic","equal$28","boolean$0","r1cs","annotation","unit$0","create$49","get$10","emplace_back","length$22","dummy_vector","get$11","T","make$4","num_inputs","next_auxiliary","system","eval_constraints","log_constraint","with_witness","is_running","eval_constraints$0","as_prover","set_as_prover","set_stack","set_handler","constraint_count","direct","assert_equal","assert_all","assert_square","assert_r1cs","assert","with_label","handle_as_prover","exists_handle","request_witness","mk_lazy","create$50","stack_to_string","eval_constraints_ref","run$5","return$17","map$32","bind$15","symbol_bind$7","symbol_map$2","bind$16","return$18","map$33","join$9","ignore_m$1","all$4","all_unit$1","field_vec_id","pack_field_vec","field_vec","auxiliary_input","t0","handlers","return_typ","auxiliary_output_data","output$0","true_output","auxiliary_input_size","run_and_check_exn","get_one","run_and_check","run_and_check_deferred_exn","run_and_check_deferred","run_unchecked","run_and_check_exn$0","run_and_check$0","check_exn","alloc_var","next_input","store_field_elt","primary_input","collect_input_constraints","input_typ","alloc_input","constraint_system_auxiliary","size_in_field_elements","var_of_fields","retval","circuit","r1cs_h","return_typ$0","checked","checked$0","constraint_system","generate_public_input","value_to_fields","store_field_elt$0","cont0","k0","fields$0","generate_auxiliary_input","primary","generate_witness_conv","auxiliary","read_cvar","output$1","inputs","generate_witness","generate_witness$0","generate_witness_conv$0","constraint_system$0","generate_auxiliary_input$0","generate_public_input$0","generate_witness$1","generate_witness_conv$1","constraint_system$1","run_unchecked$0","run_and_check$1","run_and_check_exn$1","check$0","check_exn$0","snarkless","typ","ref","transport","there","back","transport_var","auxes","num_fields","end_pos$0","fieldss","hlist","spec0","spec0$0","typ1","typ2","typ3","tuple4","typ4","tuple5","typ5","tuple6","typ6","of_hlistable","var_to_hlist","var_of_hlist","value_to_hlist","value_of_hlist","field$0","transport$0","transport_var$0","array$0","hlist$0","tuple2$0","tuple3$0","tuple4$0","tuple5$0","tuple6$0","of_hlistable$0","field_to_int","bs","to_field","of_field","typ$0","to_bits","ith_bit","if$0","then","else$0","t_of_sexp$48","non_empty_tree_of_sexp","tree_of_sexp","implied_root","entry_hash","addr0","path0","addr","let_syntax_001","fetch_and_update_req","prev_path","prev","next_entry_hash","new_root","let_syntax_003","prev_entry_hash","modify_req","get_req","update_req","let_syntax_006","let_syntax_007","let_syntax_008","let_syntax_009","pow2","bigint_num_bits","two_to_the","of_bits","mul_pow_2","multiplied","div_pow_2","divided","divided_of_bits","clamp_to_n_bits","bs$0","bit_length","less","less_or_equal","to_var","constant","tick_n","of_pow_2","ceil_div_pow_2","floor_div","m_divides_n","mod_pow_2","x_div_n","n_x_div_n","set_constraint_logger","clear_constraint_logger","constant$0","all$5","assert$0","exists$1","all$6","join$0","map$2","perform","z_inv","x_inv","y_inv","then$0","true$0","false$0","not","if$1","and_for_square_constraint_syst","x_plus_y","both_false","any","all_zero","to_constant","var_of_value","typ$1","typ_unchecked","num_true","any$0","all$0","any$1","all$1","equal$0","of_cvar","is_true","any$2","exactly_one","not$0","any$3","choose_preimage_unchecked","packing_sum","choose_preimage","lc","choose_preimage_flagged","all_unit$2","all$8","fold_map","any$5","all$9","foldi$1","iteri$0","mapi$0","fold_map$0","existsi$0","exists$0","for_alli$0","for_all$1","two","project","pack","unpack","unpack_flagged","lo_bigint","hi_bigint","gen_uniform","parity","square$0","sqrt","quadratic_nonresidue","sqrt_check","is_square","typf","answer","alpha_packed","alpha","not_all_zeros","lte","gt","gte","non_zero","not_equal","of_binary","eval$1","lt_binary","ys$0","ys$1","lt_bitstring_value","field_size_bits","unpack_full","parity$0","unpack_full$0","unpack_full$1","lt_value","chunk_for_equality","chunk_size","t1_b","t1_a","t2_a","equal$2","equal_expect_true","equal$3","correct_answer","if$2","then_aux","else_aux","else$1","res_aux","res_aux$0","checked_to_unchecked","checked_result","test_equal","unchecked","add_constraint","set_primary_input_size","set_auxiliary_input_size","get_public_input_size","get_rows_len","of_bignum_bigint","to_bignum_bigint","two_to_the_i$0","two_to_the_i$1","negate$0","to_bignum_bigint$0","of_bignum_bigint$0","of_f$0","context","scale$1","scale$2","terms$1","constant$1","to_constant_and_terms","neg_one","linear_combination","terms","var_indices","t_of_sexp$0","basic_field","annotation_field","annotation_value","basic_value","v_annotation","v_basic","fm","constraint_logger","run_as_prover","as_prover$0","old_stack","var2","var1","var2$0","var1$0","var3","var2$1","var1$1","system$0","C","with_handler","store_value","log","at_label_boundary","run_as_prover$0","get_value$0","constraint_count$0","direct$0","next_auxiliary$0","with_handler$0","with_label$0","mk_lazy$0","as_prover$1","add_constraint$0","fake_state","log_constraint$0","sys","constraint_count$1","direct$1","next_auxiliary$1","with_handler$1","with_label$1","mk_lazy$1","as_prover$2","add_constraint$1","ignore_m$2","such_that","such_that$0","compute","request$0","provider","custom_printf_002","symbol_map$3","bind$2","return$3","map$3","join$2","ignore_m$3","all_unit$3","as_prover$3","mk_lazy$2","request_witness$0","exists_handle$0","exists$2","handle$0","handle_as_prover$0","next_auxiliary$2","with_label$2","assert_r1cs$0","assert_square$0","assert_all$0","assert_equal$0","direct$2","constraint_count$2","set_constraint_logger$0","clear_constraint_logger$0","symbol_bind$4","symbol_map$4","bind$3","return$4","map$4","ignore_m$4","all_unit$4","as_prover$4","mk_lazy$3","request_witness$1","request$1","exists_handle$1","exists$3","unhandled$1","handle$1","handle_as_prover$1","next_auxiliary$3","with_label$3","assert$1","assert_r1cs$1","assert_square$1","assert_all$1","assert_equal$1","direct$3","constraint_count$3","functor_counter","active_counters","is_active_functor_id","active","dump","in_prover","in_checked_computation","as_stateful","make_checked","size_in_bits","func$0","of_int","print","sub$0","sqrt$0","is_square$0","size_in_bits$0","print$0","random$0","of_string$0","unpack$0","project$0","zero$1","mul$1","square$1","inv$1","is_square$1","sqrt$1","unpack$1","parity$1","choose_preimage_var","equal$5","eval_as_prover","in_prover_block","of_int$2","one$2","sub$1","mul$2","inv$2","square$2","sqrt$2","is_square$2","size_in_bits$1","print$1","random$1","negate$1","symbol$19","symbol$20","unpack$2","project$1","parity$2","run_prover","mark_active","counters","mark_active_deferred","compute$0","lbl","inject_wrapper","finalize_is_running","cached_state","prover_block","this_functor_id","run_checked","shape_tbl","register","path_to_type","ty_decl","shape$0","canonical1","canonical2","create$51","substring","buffer_len","length$23","bytes_for_client_to_commit","offset_in_buffer","apply$5","unsafe_get_char","count_while","lift2","succ1","input1","more1","succ2","input2","more2","symbol$188","symbol$189","more$0","marks","prompt","parser_uncommitted_bytes","parser_committed_bytes","continue$0","demand_input","ensure_suspended","commit","peek_char_fail","satisfy","count_while$0","with_buffer","input_len","count_while1","succ$1","fail$1","string$2","take_while","take_while1","ps","failure_msg","cons$2","many1","steps","max_steps","interpolation","to_int$6","of_int$8","add$18","create$52","N","eq$0","pi","t_plus_n","compare$68","lte_exn","eq_exn","num_commitments_without_degree","to_nat","contr","singleton$0","func$13","length$24","func$14","hhead_off","xss$0","tls","hds","mapn","nth$6","idx$0","idx$1","zip","to_list$9","to_array$4","init$9","map$34","of_list$7","of_list_and_length_exn","of_array_and_length_exn","fold$14","for_all$9","foldi$4","reduce_exn$1","to_yojson","poly_a","of_yojson","for_reader","cnv$0","cnv$1","a_to_b","b_to_a","b_sizer","cnv$2","b_writer","cnv$3","cnv$4","b_reader","cnv$5","sh","to_yojson$0","of_yojson$0","of_list_exn","there$0","back$0","append$5","adds","adds$0","rev$0","split$6","transpose","tails","heads","trim_front","extend_front_exn","dummy","extend_exn","extended","extend_front","bin_shape_t$73","bin_size_t$30","bin_write_t$31","bin_read_t$62","bin_shape_t$74","bin_size_t$31","bin_write_t$32","bin_read_t$63","bin_read_t$64","compare$69","hash_fold_t$37","equal$29","t_of_sexp$49","sexp_of_t$56","compare$70","hash_fold_t$38","equal$30","to_yojson$1","of_yojson$1","t_of_sexp$50","sexp_of_t$57","bin_shape_t$75","bin_size_t$32","bin_write_t$33","bin_read_t$65","compare$71","hash_fold_t$39","equal$31","to_yojson$2","of_yojson$2","t_of_sexp$51","sexp_of_t$58","compare$72","hash_fold_t$40","equal$32","to_yojson$3","of_yojson$3","t_of_sexp$52","sexp_of_t$59","to_list$10","bin_shape_t$76","bin_size_t$33","bin_write_t$34","bin_read_t$66","compare$73","hash_fold_t$41","equal$33","to_yojson$4","of_yojson$4","t_of_sexp$53","sexp_of_t$60","compare$74","hash_fold_t$42","equal$34","to_yojson$5","of_yojson$5","t_of_sexp$54","sexp_of_t$61","bin_shape_t$77","bin_size_t$34","bin_write_t$35","bin_read_t$67","compare$75","hash_fold_t$43","equal$35","t_of_sexp$55","sexp_of_t$62","compare$76","hash_fold_t$44","equal$36","to_yojson$6","of_yojson$6","t_of_sexp$56","sexp_of_t$63","bin_shape_t$78","bin_size_t$35","bin_write_t$36","bin_read_t$68","compare$77","hash_fold_t$45","equal$37","to_yojson$7","of_yojson$7","t_of_sexp$57","sexp_of_t$64","compare$78","equal$38","t_of_sexp$58","sexp_of_t$65","of_list_exn$0","bin_shape_t$79","bin_size_t$36","bin_write_t$37","bin_read_t$69","compare$79","hash_fold_t$46","equal$39","to_yojson$8","of_yojson$8","t_of_sexp$59","sexp_of_t$66","compare$80","hash_fold_t$47","equal$40","to_yojson$9","of_yojson$9","t_of_sexp$60","sexp_of_t$67","bin_shape_t$80","bin_size_t$37","bin_write_t$38","bin_read_t$70","compare$81","hash_fold_t$48","equal$41","to_yojson$10","of_yojson$10","t_of_sexp$61","sexp_of_t$68","to_yojson$11","poly_f","arg0","symbol$190","group$75","bin_shape_t$81","bin_size_t$38","size_of_f","bin_write_t$39","write_f","bin_writer_t$38","bin_writer_f","bin_read_t$71","bin_read_t$72","bin_reader_t$38","bin_reader_f","bin_t$38","bin_f","versioned","t_of_sexp$62","sexp_of_t$69","compare$82","cmp_f","equal$42","hash_fold_t$49","hash_fold_f","a0","to_yojson$12","symbol$191","t_of_sexp$63","sexp_of_t$70","compare$83","a_009","hash_fold_t$50","map$35","map$36","create$53","equal$43","to_yojson$13","symbol$192","group$76","bin_shape_t$82","bin_size_t$39","bin_write_t$40","bin_writer_t$39","bin_read_t$73","bin_read_t$74","bin_reader_t$39","bin_t$39","versioned$0","t_of_sexp$64","sexp_of_t$71","compare$84","b_020","a_019","equal$44","a_021","b_022","b_024","a_023","hash_fold_t$51","to_yojson$14","symbol$193","t_of_sexp$65","sexp_of_t$72","compare$85","a_025","b_026","b_028","a_027","hash_fold_t$52","typ$2","func$15","map$37","create$54","of_field$0","to_field$0","equal$45","maxes","just","nothing","to_option_unsafe","value_exn$1","of_option","symbol$194","map$38","constant_layout_typ","bool_typ","a_typ","dummy_var","bool_typ$0","bool_typ$1","typ$3","hash_fold_array","group$77","bin_shape_t$83","t_of_sexp$66","range_check0_field","range_check1_field","foreign_field_add_field","foreign_field_mul_field","xor_field","rot_field","lookup_field","runtime_tables_field","runtime_tables_value","lookup_value","rot_value","xor_value","foreign_field_mul_value","foreign_field_add_value","range_check1_value","range_check0_value","to_hlist","runtime_tables","rot","foreign_field_add","range_check1","range_check0","of_hlist","of_full","to_full","lookup_pattern_range_check","table_width_at_least_2","table_width_at_least_1","lookups_per_row_4","lookups_per_row_3","to_data","map$39","group$78","bin_shape_t$84","bin_size_t$40","v25","v24","v23","v22","v21","v20","v19","v18","v17","v16","v15","v14","v13","v12","v11","v10","v9","v8","v7","v6","v5","v4","size$2","size$3","size$4","size$5","size$6","size$7","size$8","size$9","size$10","size$11","size$12","size$13","size$14","size$15","size$16","size$17","size$18","size$19","size$20","size$21","size$22","bin_write_t$41","bin_read_t$75","v_w","v_coefficients","v_z","v_s","v_generic_selector","v_poseidon_selector","v_complete_add_selector","v_mul_selector","v_emul_selector","v_endomul_scalar_selector","v_range_check0_selector","v_range_check1_selector","v_foreign_field_add_selector","v_foreign_field_mul_selector","v_xor_selector","v_rot_selector","v_lookup_aggregation","v_lookup_table","v_lookup_sorted","v_runtime_lookup_table","v_runtime_lookup_table_selecto","v_xor_lookup_selector","v_lookup_gate_lookup_selector","v_range_check_lookup_selector","v_foreign_field_mul_lookup_sel","t_of_sexp$67","w_field","coefficients_field","z_field","s_field","generic_selector_field","poseidon_selector_field","complete_add_selector_field","mul_selector_field","emul_selector_field","endomul_scalar_selector_field","range_check0_selector_field","range_check1_selector_field","foreign_field_add_selector_fie","foreign_field_mul_selector_fie","xor_selector_field","rot_selector_field","lookup_aggregation_field","lookup_table_field","lookup_sorted_field","runtime_lookup_table_field","runtime_lookup_table_selector_","xor_lookup_selector_field","lookup_gate_lookup_selector_fi","range_check_lookup_selector_fi","foreign_field_mul_lookup_selec","field_sexp$25","fvalue$16","field_sexp$18","fvalue$17","field_sexp$19","fvalue$18","field_sexp$20","fvalue$19","field_sexp$21","fvalue$20","field_sexp$22","fvalue$21","field_sexp$23","fvalue$22","field_sexp$24","fvalue$23","foreign_field_mul_lookup_selec$0","range_check_lookup_selector_va","lookup_gate_lookup_selector_va","xor_lookup_selector_value","runtime_lookup_table_selector_$0","runtime_lookup_table_value","lookup_sorted_value","lookup_table_value","lookup_aggregation_value","rot_selector_value","xor_selector_value","foreign_field_mul_selector_val","foreign_field_add_selector_val","range_check1_selector_value","range_check0_selector_value","endomul_scalar_selector_value","emul_selector_value","mul_selector_value","complete_add_selector_value","poseidon_selector_value","generic_selector_value","s_value","z_value","coefficients_value","w_value","to_yojson$15","fields$1","fields$2","fields$3","fields$4","fields$5","fields$6","fields$7","fields$8","fields$9","fields$10","x$10","fields$11","x$11","fields$12","x$12","fields$13","x$13","fields$14","fields$15","fields$16","fields$17","fields$18","fields$19","fields$20","fields$21","fields$22","fields$23","fields$24","symbol$195","arg24","arg23","arg22","arg21","arg20","arg19","arg18","arg17","arg16","arg15","arg14","arg13","arg12","arg11","arg10","arg9","arg8","arg7","arg6","arg5","arg4","arg3","xs$13","xs$6","xs$5","xs$4","xs$3","xs$2","xs$12","xs$11","xs$10","xs$9","xs$8","xs$7","xs$19","x$17","xs$18","x$16","xs$17","x$15","xs$16","x$14","xs$15","xs$14","xs$25","x$23","xs$24","x$22","xs$23","x$21","xs$22","x$20","xs$21","x$19","xs$20","x$18","t_of_sexp$68","sexp_of_t$73","arg$16","bnds$16","arg$17","bnds$17","arg$18","bnds$18","arg$19","bnds$19","arg$20","bnds$20","arg$21","bnds$21","arg$22","bnds$22","arg$23","bnds$23","compare$86","a_093","b_094","a_095","b_096","a_097","b_098","a_099","b_100","a_101","b_102","a_103","b_104","a_105","b_106","a_107","b_108","a_111","b_112","a_113","b_114","a_115","b_116","a_117","b_118","a_119","b_120","a_121","b_122","n$19","a_123","b_124","n$20","a_125","b_126","n$21","a_127","b_128","n$22","a_129","b_130","a_131","b_132","hash_fold_t$53","hash_fold_a","hsv$1","hsv$2","hsv$3","hsv$4","hsv$5","hsv$6","hsv$7","hsv$8","hsv$9","hsv$10","hsv$11","hsv$12","hsv$13","hsv$14","hsv$15","hsv$16","hsv$17","hsv$18","hsv$19","hsv$20","hsv$21","hsv$22","hsv$23","equal$46","a_133","b_134","a_135","b_136","a_137","b_138","a_139","b_140","a_141","b_142","a_143","b_144","a_145","b_146","a_147","b_148","a_149","b_150","a_151","b_152","a_153","b_154","a_155","b_156","a_157","b_158","a_159","b_160","a_161","b_162","a_163","b_164","a_165","b_166","a_167","b_168","a_169","b_170","a_171","b_172","to_hlist$0","range_check_lookup_selector","lookup_gate_lookup_selector","xor_lookup_selector","runtime_lookup_table_selector","runtime_lookup_table","lookup_sorted","lookup_aggregation","rot_selector","xor_selector","foreign_field_mul_selector","foreign_field_add_selector","range_check1_selector","range_check0_selector","endomul_scalar_selector","emul_selector","mul_selector","complete_add_selector","poseidon_selector","generic_selector","coefficients","of_hlist$0","validate_feature_flags","enable_if","range_check_lookup","to_hlist$1","of_hlist$1","map$40","to_list$11","always_present","optional_gates","to_absorption_sequence","to_in_circuit","map$41","to_list$12","group$79","to_hlist$2","public_input","of_hlist$2","to_hlist$3","of_hlist$3","p2","p1","group$80","f_multi","to_hlist$4","of_hlist$4","to_hlist$5","of_hlist$5","typ$4","Impl","single","uses_lookups","lookups_per_row_3$0","lookups_per_row_4$0","evals$0","group$81","bin_shape_t$85","fq","bin_size_t$41","size_of_g","size_of_fq","bin_write_t$42","write_g","write_fq","bin_read_t$76","of_g","of_fq","v_lr","v_z_1","v_z_2","v_delta","v_challenge_polynomial_commitm","poly_g","poly_fq","lr_field","z_1_field","z_2_field","delta_field","challenge_polynomial_commitmen","challenge_polynomial_commitmen$0","delta_value","z_2_value","z_1_value","lr_value","cmp_g","cmp_fq","a_261","b_262","a_263","b_264","t_266","t_265","t_268","t_267","hash_fold_g","hash_fold_fq","e0","a_269","b_270","a_271","b_272","t_274","t_273","t_276","t_275","to_hlist$6","z_2","z_1","of_hlist$6","group$82","to_yojson$17","symbol$196","group$83","bin_shape_t$86","bin_size_t$42","bin_write_t$43","bin_read_t$77","compare$88","a_341","b_342","a_343","b_344","equal$48","a_345","b_346","a_347","b_348","to_yojson$18","symbol$197","compare$89","a_349","b_350","a_351","b_352","equal$49","a_353","b_354","a_355","b_356","group$84","bin_shape_t$87","to_hlist$7","sorted_5th_column","of_hlist$7","to_hlist$8","of_hlist$8","group$85","bin_shape_t$88","to_hlist$9","of_hlist$9","to_hlist$10","of_hlist$10","typ$6","commitment_lengths","w_lens","wo","fqv","group$86","t_of_sexp$70","of_g$0","of_fqv","sexp$0","field_sexps$2","messages_field","openings_field","duplicates$2","extra$2","tail$2","sexp$1","field_sexps$0","proof_field","evals_field","ft_eval1_field","duplicates$0","extra$0","tail$0","ft_eval1_value","evals_value","proof_value","sexp$2","field_sexps$1","w_comm_field","z_comm_field","t_comm_field","duplicates$1","extra$1","tail$1","aggreg_field","runtime_field","runtime_value","aggreg_value","t_comm_value","z_comm_value","w_comm_value","openings_value","messages_value","t_of_sexp$71","sorted_5th_column_field","sorted_5th_column_value","group$87","bin_shape_t$89","comm","bin_size_t$43","size_of_comm","bin_write_t$44","write_comm","bin_read_t$78","of_comm","v_sigma_comm","v_coefficients_comm","v_generic_comm","v_psm_comm","v_complete_add_comm","v_mul_comm","v_emul_comm","v_endomul_scalar_comm","t_of_sexp$72","sigma_comm_field","coefficients_comm_field","generic_comm_field","psm_comm_field","complete_add_comm_field","mul_comm_field","emul_comm_field","endomul_scalar_comm_field","endomul_scalar_comm_value","emul_comm_value","mul_comm_value","complete_add_comm_value","psm_comm_value","generic_comm_value","coefficients_comm_value","sigma_comm_value","to_hlist$11","of_hlist$11","typ$7","map$42","f_opt","lookup_selector_ffmul","lookup_selector_range_check","lookup_selector_xor","lookup_selector_lookup","lookup_table_ids","lookup_table_comm","pow$6","combine_split_commitments","scale_and_add","xi","without_degree_bound","with_degree_bound","shifted","unshifted","flat","combine_split_evaluations","mul_and_add","evals0","es","fx","to_list$13","to_vector","of_vector","of_list_and_length_exn$0","of_sexpable","of_binable$6","bin_shape_t$90","bin_size_t$44","bin_write_t$45","bin_read_t$79","of_binable$7","map$43","round_constants","mds","pasta_p_legacy","pasta_p_kimchi","pasta_q_kimchi","id$1","make$5","sponge_state","capacity","sponge_state_of_sexp","sexp_of_sponge_state","copy","rate","absorb","squeeze","debug","operation","sponge","fe","to_blocks","field_elems","num_blocks","create_block","global_pos","sexpifier","first_half_rounds_full","block_cipher","sbox","constant_offset","second_half_rounds_full","slots_per_tuple","arch_sixtyfour$0","max_slot","t3","t4","t5","t13","masked_tuple_id_num_bits","max_array_length","tuple_id_mask","init$10","create$55","header_index","tuple_id","header_index_mask","invariant$10","slot_index","first_slot_index","null$4","is_null","is_used","metadata_index","start_of_tuples_index","max_capacity","array_indices_per_tuple","tuple_num_to_header_index","tuple_num","sexp_of_t$75","sexp_of_ty","v_capacity","v_slots_per_tuple","v_length","v_next_id","v_first_free","v_dummy","unsafe_set_header","pointer_is_valid","pointer","header_index$1","header_index$0","is_full","unsafe_add_to_free_list","metadata","set_metadata","create_array","unsafe_init_range","tuple_num$0","create_with_dummy","slots_per_tuple$0","max_capacity$0","grow","capacity$0","old_capacity","next_id","dummy$0","capacity$1","metadata$1","metadata$0","malloc","first_free","get$12","set$9","bin_writer_a","bin_reader_a","bin_a","group$0","t_of_sexp$73","sexp_of_t$76","validate$3","sexp_of_t$78","max_num_bits","invariant$11","of_int$9","symbol$198","symbol$199","pow2$0","num_bits_internal","create_exn$1","ints","extend_to_max_num_bits","ints$0","level_bits_default","to_sexpable$0","alarm_precision","of_sexpable$0","sexp_of_t$80","v_level_bits","v_alarm_precision","bnd","create$56","level_bits","max_num_bits$0","num_keys","add_clamp_to_max","min_key_in_same_slot","min_key_in_same_slot_mask","value$4","next$5","pool","slot$0","min_key_in_same_slot$0","num_levels","min_allowed_key","max_allowed_key","add_elt","pool$1","pool$0","levels","level_index","level","v_elts","v_max_allowed_key$0","v_min_allowed_key$0","v_key","level_index$0","level_index$1","level$0","v_diff_max_min_allowed_key","v_min_key_in_same_slot_mask","v_keys_per_slot","v_bits_per_slot","v_slots_mask","v_bits","v_index","v_min_allowed_key","v_max_allowed_key","v_slots","interval_num_internal","interval_num_unchecked","interval_num_start_unchecked","interval_num","default$1","sexp_of_t$81","v_how_to_dump","v_dump_if_delayed_by","t_of_sexp$76","sexp_of_t$82","equal$50","x_003","x_004","t_of_sexp$77","sexp_of_t$83","t_of_sexp$78","sexp_of_t$84","timing_wheel_config","thread_pool_cpu_affinity","report_thread_pool_stuck_for","record_backtraces","print_debug_messages_for","min_inter_cycle_timeout","max_num_jobs_per_priority_per_","max_num_threads","max_num_open_file_descrs","max_inter_cycle_timeout","file_descr_watcher","epoll_max_ready_events","dump_core_on_job_delay","detect_invalid_access_from_thr","check_invariants","abort_after_thread_pool_stuck_","timing_wheel_config$0","thread_pool_cpu_affinity$0","report_thread_pool_stuck_for$0","record_backtraces$0","print_debug_messages_for$0","min_inter_cycle_timeout$0","max_num_jobs_per_priority_per_$0","max_num_threads$0","max_num_open_file_descrs$0","max_inter_cycle_timeout$0","file_descr_watcher$0","epoll_max_ready_events$0","dump_core_on_job_delay$0","detect_invalid_access_from_thr$0","check_invariants$0","abort_after_thread_pool_stuck_$0","default_timing_wheel_config_fo","level_bits$1","alarm_precision$0","default_timing_wheel_config","default$2","v_timing_wheel_config","v_report_thread_pool_stuck_for","v_record_backtraces","v_min_inter_cycle_timeout","v_max_num_jobs_per_priority_pe","v_max_num_threads","v_max_num_open_file_descrs","v_max_inter_cycle_timeout","v_file_descr_watcher","v_epoll_max_ready_events","v_dump_core_on_job_delay","v_detect_invalid_access_from_t","v_check_invariants","v_abort_after_thread_pool_stuc","usage","to_sexp","name1","bnd$0","bnd$1","v$2","bnd$2","v$3","bnd$3","v$4","bnd$4","v$5","bnd$5","v$6","bnd$6","v$7","bnd$7","v$8","bnd$8","v$9","bnd$9","v$10","bnd$10","v$11","bnd$11","v$12","bnd$12","v$13","bnd$13","v$14","bnd$14","check_invariants_field","dump_core_on_job_delay_field","epoll_max_ready_events_field","file_descr_watcher_field","max_inter_cycle_timeout_field","max_num_open_file_descrs_field","max_num_threads_field","min_inter_cycle_timeout_field","print_debug_messages_for_field","record_backtraces_field","report_thread_pool_stuck_for_f","thread_pool_cpu_affinity_field","timing_wheel_config_field","alarm_precision_field","level_bits_field","capacity_field","num_key_bits","alarm_precision_value","sexp$3","sexp$4","dump_if_delayed_by_field","how_to_dump_field","how_to_dump_value","dump_if_delayed_by_value","timing_wheel_config_value","thread_pool_cpu_affinity_value","report_thread_pool_stuck_for_v","record_backtraces_value","print_debug_messages_for_value","min_inter_cycle_timeout_value","max_num_threads_value","max_num_open_file_descrs_value","max_inter_cycle_timeout_value","file_descr_watcher_value","epoll_max_ready_events_value","dump_core_on_job_delay_value","check_invariants_value","print_debug_messages_for$1","debug$0","symbol$200","check_invariants$1","max_num_jobs_per_priority_per_$1","record_backtraces$1","normal","sexp_of_one","v_is_detached","v_has_seen_error","v_id","v_here","v_name","loop$2","has_seen_error","is_detached","ac$0","sexp_of_t$85","create_with_parent","dummy_e","dummy_f","dummy_a","create_array$0","create$57","none$3","is_none$1","is_some$1","create$59","enqueue$0","execution_context","priority","new_capacity","old_jobs","old_front","new_jobs","create$60","time_source","max_level_min_allowed_key","bits_per_slot","keys_per_slot","diff_max_min_allowed_key","levels$0","tw","prev_level_max_allowed_key","num_levels$0","min_allowed_key_before","desired_min_allowed_key","level_min_allowed_key","level_min_allowed_key$0","slots$1","max_allowed_key$0","alarm","job_pool","from","to","at","current_execution_context","set_prev","set_next","create$61","create2","run1","execution_context1","run2","execution_context2","enqueue$1","scheduler","schedule_jobs","add$19","squash","indir","execution_context$0","bind_result","bind_rhs","bind_result$0","ivar","ivar$0","last1","last2","handler1","execution_context2$0","run2$0","handler1$0","fill_if_empty","to_binable$6","of_binable$8","map$44","bind$18","map$45","bind$19","map$46","both$0","symbol_map$5","choices","unregisters","choices$0","choices$1","handler$0","handler$1","monitor$0","backtrace_history","monitor$1","name$1","backtrace$0","backtrace$1","traces","backtrace$2","list_if_not_empty","return$20","bind$20","map$47","return$21","apply$6","map$48","return$22","equal$51","combine$3","sexp_of_t$87","v_pipe_id","v_values_read","values_sent_downstream","values_sent_downstream_and_flu","when_sent_downstream","fill_with_eof","sexp_of_t$88","v_ready","v_fill_when_num_values_read","fill$2","sexp_of_pipe","of_phantom","v_info","v_buffer","v_size_budget","v_pushback","v_num_values_read","v_read_closed","v_closed","v_blocked_reads","v_blocked_flushes","v_consumers","v_upstream_flusheds","v_consumer","v_wants","is_closed","length$25","is_empty$9","sexp_of_phantom","id_ref","update_pushback","close","close$0","values_were_read","consumer","consumer$0","flush_result","consume_one","consume","ensure_consumer_matches","start_read","gen_read_now","values_available","downstream_flushed","ready","expect","got","create$63","length$26","sub$8","copy$4","init$11","be32_to_cpu","le32_to_cpu","be64_to_cpu","le64_to_cpu","benat_to_cpu","cpu_to_benat","blit_from_bigstring","cpu_to_be32","cpu_to_be64","be32_to_cpu$0","le32_to_cpu$0","be64_to_cpu$0","le64_to_cpu$0","benat_to_cpu$0","cpu_to_benat$0","imin","size_of_long","xor_into","invalid_arg$0","ror64","dup","ctx","param_to_bytes","iv","max_outlen","increment_counter","inc","sigma","compress","a_idx","b_idx","c_idx","d_idx","feed$0","in_off","in_len","fill","unsafe_feed_bytes","unsafe_feed_bigstring","with_outlen_and_key","outlen","param_bytes","with_outlen_and_bytes_key","with_outlen_and_bigstring_key","unsafe_get$0","ror32","dup$0","iv$0","max_outlen$0","increment_counter$0","sigma$0","compress$0","feed$1","unsafe_feed_bytes$0","unsafe_feed_bigstring$0","with_outlen_and_key$0","with_outlen_and_bytes_key$0","with_outlen_and_bigstring_key$0","unsafe_get$1","dup$1","init$12","f3","md5_do_chunk","feed$2","to_fill","unsafe_feed_bytes$1","unsafe_feed_bigstring$1","unsafe_get$2","padlen","rol32","dup$2","init$13","g$0","jj","fff","ggg","hhh","iii","jjj","rmd160_do_chunk","eee","ccc","bbb","aaa","ee","dd","cc","bb","aa","feed$3","unsafe_feed_bytes$2","unsafe_feed_bigstring$2","unsafe_get$3","rol32$0","dup$3","init$14","f1$0","f4$0","f3$0","k4","sha1_do_chunk","feed$4","unsafe_feed_bytes$3","unsafe_feed_bigstring$3","unsafe_get$4","ror32$0","dup$4","init$15","sha256_do_chunk","feed$5","unsafe_feed_bytes$4","unsafe_feed_bigstring$4","unsafe_get$5","init$16","unsafe_get$6","dup$5","unsafe_feed_bytes$5","unsafe_feed_bigstring$5","rol64","dup$6","init$17","mdlen","rsize","keccaft_rndc","keccaft_rotc","keccakf_piln","sha3_keccakf","rotc","bc$0","masks","feed$6","get_uint8","unsafe_feed_bytes$6","unsafe_feed_bigstring$6","unsafe_get$7","ror64$0","dup$7","init$18","sha512_do_chunk","feed$7","unsafe_feed_bytes$7","unsafe_feed_bigstring$7","unsafe_get$8","init$19","unsafe_get$9","dup$8","unsafe_feed_bytes$8","unsafe_feed_bigstring$8","init$20","init$21","init$22","init$23","dup$9","init$24","whirlpool_do_chunk","i$3","wp_op","get_k","m0","feed$8","unsafe_feed_bytes$9","unsafe_feed_bigstring$9","unsafe_get$10","digest_size","block_size","len$3","unsafe_feed_string","unsafe_get","chr$0","chr1","chr2","have_first","ln","bl","feed_bytes","feed_string","feed_bigstring","feedi_bytes","feed","feedi_string","feedi_bigstring","digest_bytes","digest_string","digest_bigstring","digesti_bytes","digesti_string","digesti_bigstring","digestv_bytes","digestv_string","digestv_bigstring","bytes_opad","bytes_ipad","norm_bytes","bigstring_opad","bigstring_ipad","norm_bigstring","hmaci_bytes","outer","hmaci_string","ctx$0","hmaci_bigstring","hmac_bytes","hmac_string","hmac_bigstring","hmacv_bytes","bufs","hmacv_string","hmacv_bigstring","maci_bytes","maci_string","maci_bigstring","mac_bytes","mac_string","mac_bigstring","macv_bytes","macv_string","macv_bigstring","digest_size$0","module_of","b2b","b2s","read$0","ds","of_char_exn","to_int$7","decode","encode","byte$0","to_hex$0","charify","hexified","to_u4","actual","not_implemented","to_binable$7","of_binable$9","empty$16","group$88","bin_shape_t$91","path$0","log$1","internal","empty_quartiles","allocation_times","now$0","get_lifetime_ms","mean","indices","lifetimes","q1","q2","q3_offset","q3","q4","compute_statistics","run_test","time_offsets","expected_quartiles","message$0","comparator$0","comparator$1","message$3","comparator$3","table$0","attach_finalizer","object_id","info_opt","data_opt","statistics","json","block_on_async_exn","to_deferred","promise","map$49","bind$21","return$23","return$24","map$50","get$13","t_of_sexp$79","accs_field","bits_field","ss_field","base_field","n_prev_field","n_next_field","n_next_value","n_prev_value","base_value","ss_value","bits_value","accs_value","map$51","n_next","n_prev","ss","accs","group$89","bin_shape_t$92","bin_size_t$45","bin_write_t$46","bin_read_t$80","v_inner","to_yojson$19","of_yojson$12","t_of_sexp$80","inner_field","inner_value","sexp_of_t$89","compare$90","equal$52","hash_fold_t$55","typ$8","map$52","y_squared","t_004","t_003","t_005","t_010","t_012","t_011","hash_fold_t$1","to_backend","of_backend","to_affine_or_infinity","to_affine_exn","of_affine","find_y","point_near_x","g_vec","or_infinity_to_backend","or_infinity_of_backend","with_degree_bound_to_backend","commitment","without_degree_bound_to_backen","of_backend_with_degree_bound","shifted$0","of_backend_without_degree_boun","tuple15_to_vec","w14","w13","w12","w11","w10","w9","w8","w7","w6","w5","w4","w3","w2","w1","w0","tuple15_of_vec","group$90","v_challenges","v_commitment","challenges_field","commitment_field","commitment_value","challenges_value","a_013","b_014","to_latest","hash_fold_array$0","poly_fqv","poly_g$0","arg1$2","arg0$2","arg2$1","arg1$1","arg0$1","arg2$0","arg1$0","arg0$0","size_of_fqv","v2$1","v3$0","write_fqv","v_w_comm","v_z_comm","v_t_comm","v_lookup","v_aggreg","v_runtime","v_messages","v_proof","v_evals","v_ft_eval1","v_openings","version$0","cmp_g$1","cmp_g$0","a_455","b_456","n$32","n$29","a_391","b_392","a_393","b_394","n$30","a_395","b_396","n$31","a_397","b_398","a_399","b_400","a_401","b_402","a_403","b_404","a_363","b_364","a_365","b_366","cmp_fqv","cmp_fq$0","a_281","b_282","a_457","b_458","n$27","n$23","a_247","b_248","t_250","t_249","t_252","t_251","n$24","n$25","n$26","a_283","b_284","t_286","t_285","t_288","t_287","n$28","a_015","b_016","a_033","b_034","a_035","b_036","a_045","b_046","a_047","b_048","t_of_sexp$2","arg$31","bnds$29","bnds$37","arg$24","bnds$30","arg$25","bnds$24","arg$26","bnds$25","arg$27","bnds$26","arg$28","bnds$27","arg$29","bnds$28","arg$30","bnds$31","arg$32","bnds$38","bnds$32","arg$33","bnds$33","arg$34","bnds$34","arg$35","bnds$35","arg$36","bnds$36","arg$37","bnds$39","hsv$33","hash_fold_fqv","hsv$29","hsv$30","hsv$31","hsv$32","hsv$24","hsv$25","hsv$26","hsv$27","hsv$28","a_465","b_466","a_407","b_408","a_409","b_410","a_411","b_412","a_413","b_414","a_415","b_416","a_417","b_418","a_419","b_420","a_369","b_370","a_371","b_372","a_293","b_294","a_467","b_468","a_255","b_256","t_258","t_257","t_260","t_259","a_295","b_296","t_298","t_297","t_300","t_299","a_057","b_058","a_059","b_060","a_061","b_062","a_063","b_064","a_065","b_066","a_067","b_068","a_069","b_070","a_071","b_072","a_073","b_074","a_075","b_076","a_077","b_078","a_079","b_080","a_081","b_082","a_083","b_084","a_085","b_086","a_087","b_088","a_089","b_090","a_091","b_092","map_creator","openings","to_latest$0","arg3$0","a_475","b_476","a_423","b_424","a_425","b_426","a_427","b_428","a_429","b_430","a_431","b_432","a_433","b_434","a_435","b_436","a_375","b_376","a_377","b_378","a_379","b_380","a_305","b_306","a_477","b_478","a_307","b_308","t_310","t_309","t_312","t_311","t_of_sexp$3","sexp_of_t$3","v_sorted_5th_column","a_485","b_486","a_439","b_440","a_441","b_442","a_443","b_444","a_445","b_446","a_447","b_448","a_449","b_450","a_451","b_452","a_383","b_384","a_385","b_386","a_387","b_388","a_317","b_318","a_487","b_488","a_319","b_320","t_322","t_321","t_324","t_323","map_creator$0","create$1","compare$3","hash_fold_t$2","map_creator$1","sexp_of_t$4","fq_array_to_vec","vec","opening_proof_of_backend_exn","gpair","g2","g1","eval_of_backend","evals_to_tuple","zeta_omega","zeta","gs","of_backend_with_public_evals","eval_to_backend","vec_to_array","V","evals_of_tuple","chal_polys","pcwo","lr$0","challenges","to_backend$0","to_backend_with_public_evals","to_backend_with_public_evals$0","pk","create_async","batch_verify","logger","vks_and_v","batch_verify$0","prev_challenge","pi$0","create_with_public_evals","scalar_challenge","beta","digest_before_evaluations","p_eval_1","p_eval_2","opening_prechallenges","columns","permutation_cols","map$53","s3","yr","xr","n_acc","yp","xp","yt","xt","map$54","x7","x6","x5","a8","b0","n8","n0","bin_shape_t_tagged","read_version","all_tag_versions","bin_read_all_tagged_to_latest","saved_pos","pos_ref$0","domain_generator","over","t_of_sexp$81","compare$91","compare$92","cmp_row","to_rust_wire","t_of_sexp$82","of_v","field_sexps$12","l_field","r_field","o_field","c_field","duplicates$12","extra$12","tail$7","field_sexp$60","field_sexp$41","field_sexp$42","fvalue$36","field_sexp$43","fvalue$37","field_sexp$44","fvalue$38","field_sexp$45","fvalue$39","field_sexp$46","fvalue$40","c_value","o_value","r_value","l_value","field_sexps$4","state_field","duplicates$4","extra$4","state_value","field_sexps$11","p1_field","p2_field","p3_field","inf_field","same_x_field","slope_field","inf_z_field","x21_inv_field","duplicates$11","extra$11","tail$6","field_sexp$59","field_sexp$32","field_sexp$33","fvalue$28","field_sexp$34","fvalue$29","field_sexp$35","fvalue$30","field_sexp$36","fvalue$31","field_sexp$37","fvalue$32","field_sexp$38","fvalue$33","field_sexp$39","fvalue$34","field_sexp$40","fvalue$35","x21_inv_value","inf_z_value","slope_value","same_x_value","inf_value","p3_value","p2_value","p1_value","field_sexps$8","state_field$0","duplicates$8","extra$8","tail$3","state_value$0","field_sexps$9","state_field$1","xs_field","ys_field","n_acc_field","duplicates$9","extra$9","tail$4","field_sexp$58","field_sexp$26","field_sexp$27","field_sexp$28","fvalue$24","field_sexp$29","fvalue$25","xt_field","yt_field","xp_field","yp_field","xr_field","yr_field","s1_field","s3_field","b1_field","b2_field","b3_field","b4_field","b4_value","b3_value","b2_value","b1_value","s3_value","s1_value","yr_value","xr_value","n_acc_value","yp_value","xp_value","yt_value","xt_value","field_sexp$30","fvalue$26","ys_value","xs_value","state_value$1","field_sexps$10","state_field$2","duplicates$10","extra$10","tail$5","field_sexp$31","fvalue$27","n0_field","n8_field","a0_field","b0_field","a8_field","b8_field","x0_field","x1_field","x2_field","x3_field","x4_field","x5_field","x6_field","x7_field","x7_value","x6_value","x5_value","x4_value","x3_value","x2_value","x1_value","x0_value","b8_value","a8_value","b0_value","a0_value","n8_value","n0_value","state_value$2","field_sexps$5","w0_field","w1_field","w2_field","w3_field","w4_field","w5_field","w6_field","duplicates$5","extra$5","field_sexp$57","w6_value","w5_value","w4_value","w3_value","w2_value","w1_value","w0_value","field_sexps$3","v0_field","v0p0_field$0","v0p1_field$0","v0p2_field","v0p3_field","v0p4_field","v0p5_field","v0c0_field","v0c1_field","v0c2_field","v0c3_field","v0c4_field","v0c5_field","v0c6_field","v0c7_field","compact_field","duplicates$3","extra$3","iter$2","compact_value","v0c7_value","v0c6_value","v0c5_value","v0c4_value","v0c3_value","v0c2_value","v0c1_value","v0c0_value","v0p5_value","v0p4_value","v0p3_value","v0p2_value","v0p1_value$0","v0p0_value$0","v0_value","v2_field","v12_field","v2c0_field","v2p0_field","v2p1_field","v2p2_field","v2p3_field","v2c1_field","v2c2_field","v2c3_field","v2c4_field","v2c5_field","v2c6_field","v2c7_field","v2c8_field","v2c9_field","v2c10_field","v2c11_field","v0p0_field","v0p1_field","v1p0_field","v1p1_field","v2c12_field","v2c13_field","v2c14_field","v2c15_field","v2c16_field","v2c17_field","v2c18_field","v2c19_field","v2c19_value","v2c18_value","v2c17_value","v2c16_value","v2c15_value","v2c14_value","v2c13_value","v2c12_value","v1p1_value","v1p0_value","v0p1_value","v0p0_value","v2c11_value","v2c10_value","v2c9_value","v2c8_value","v2c7_value","v2c6_value","v2c5_value","v2c4_value","v2c3_value","v2c2_value","v2c1_value","v2p3_value","v2p2_value","v2p1_value","v2p0_value","v2c0_value","v12_value","v2_value","in1_field","in2_field","out_field","in1_0_field","in1_1_field","in1_2_field","in1_3_field","in2_0_field","in2_1_field","in2_2_field","in2_3_field","out_0_field","out_1_field","out_2_field","out_3_field","out_3_value","out_2_value","out_1_value","out_0_value","in2_3_value","in2_2_value","in2_1_value","in2_0_value","in1_3_value","in1_2_value","in1_1_value","in1_0_value","out_value","in2_value","in1_value","field_sexps$7","left_input_lo_field","left_input_mi_field","left_input_hi_field","right_input_lo_field","right_input_mi_field","right_input_hi_field","field_overflow_field","carry_field","foreign_field_modulus0_field","foreign_field_modulus1_field","foreign_field_modulus2_field$0","duplicates$7","extra$7","field_sexp$56","foreign_field_modulus2_value$0","foreign_field_modulus1_value","foreign_field_modulus0_value","carry_value","field_overflow_value","right_input_hi_value","right_input_mi_value","right_input_lo_value","left_input_hi_value","left_input_mi_value","left_input_lo_value","field_sexps$6","left_input0_field","left_input1_field","left_input2_field","right_input0_field","right_input1_field","right_input2_field","remainder01_field","remainder2_field","quotient0_field","quotient1_field","quotient2_field","quotient_hi_bound_field","product1_lo_field","product1_hi_0_field","product1_hi_1_field","carry0_field","carry1_0_field","carry1_12_field","carry1_24_field","carry1_36_field","carry1_48_field","carry1_60_field","carry1_72_field","carry1_84_field","carry1_86_field","carry1_88_field","carry1_90_field","foreign_field_modulus2_field","neg_foreign_field_modulus0_fie","neg_foreign_field_modulus1_fie","neg_foreign_field_modulus2_fie","duplicates$6","extra$6","iter$3","neg_foreign_field_modulus2_val","neg_foreign_field_modulus1_val","neg_foreign_field_modulus0_val","foreign_field_modulus2_value","carry1_90_value","carry1_88_value","carry1_86_value","carry1_84_value","carry1_72_value","carry1_60_value","carry1_48_value","carry1_36_value","carry1_24_value","carry1_12_value","carry1_0_value","carry0_value","product1_hi_1_value","product1_hi_0_value","product1_lo_value","quotient_hi_bound_value","quotient2_value","quotient1_value","quotient0_value","remainder2_value","remainder01_value","right_input2_value","right_input1_value","right_input0_value","left_input2_value","left_input1_value","left_input0_value","word_field","rotated_field","excess_field","bound_limb0_field","bound_limb1_field","bound_limb2_field","bound_limb3_field","bound_crumb0_field","bound_crumb1_field","bound_crumb2_field","bound_crumb3_field","bound_crumb4_field","bound_crumb5_field","bound_crumb6_field","bound_crumb7_field","two_to_rot_field","two_to_rot_value","bound_crumb7_value","bound_crumb6_value","bound_crumb5_value","bound_crumb4_value","bound_crumb3_value","bound_crumb2_value","bound_crumb1_value","bound_crumb0_value","bound_limb3_value","bound_limb2_value","bound_limb1_value","bound_limb0_value","excess_value","rotated_value","word_value","field_sexps$14","id_field$0","data_field","duplicates$14","extra$14","tail$9","field_sexp$55","field_sexp$50","field_sexp$51","fvalue$43","field_sexp$52","fvalue$44","data_value","id_value$0","field_sexps$13","id_field","first_column_field","duplicates$13","extra$13","tail$8","field_sexp$54","field_sexp$47","field_sexp$48","fvalue$41","field_sexp$49","fvalue$42","first_column_value","id_value","kind_field","values_field","coeffs_field","field_sexp$53","coeffs_value","values_value","kind_value","sexp_of_t$90","v_c","v_m","v_o","v_r","v_l","v_state","v_x21_inv","v_inf_z","v_slope","v_same_x","v_inf","v_p3","v_p2","v_p1","v_state$0","v_n_next","v_n_prev","v_base","v_ss","v_accs","v_n_acc","v_ys","v_xs","v_state$1","v_b4","v_b3","v_b2","v_b1","v_s3","v_s1","v_yr","v_xr","v_yp","v_xp","v_yt","v_xt","v_state$2","v_x7","v_x6","v_x5","v_x4","v_x3","v_x2","v_x1","v_x0","v_b8","v_a8","v_b0","v_a0","v_n8","v_n0","v_w6","v_w5","v_w4","v_w3","v_w2","v_w1","v_w0","v_compact","v_v0c7","v_v0c6","v_v0c5","v_v0c4","v_v0c3","v_v0c2","v_v0c1","v_v0c0","v_v0p5","v_v0p4","v_v0p3","v_v0p2","v_v0p1","v_v0p0","v_v0","bnds$40","arg$38","bnds$41","arg$39","bnds$42","arg$40","bnds$43","arg$41","bnds$44","v_v2c19","v_v2c18","v_v2c17","v_v2c16","v_v2c15","v_v2c14","v_v2c13","v_v2c12","v_v1p1","v_v1p0","v_v0p1$0","v_v0p0$0","v_v2c11","v_v2c10","v_v2c9","v_v2c8","v_v2c7","v_v2c6","v_v2c5","v_v2c4","v_v2c3","v_v2c2","v_v2c1","v_v2p3","v_v2p2","v_v2p1","v_v2p0","v_v2c0","v_v12","v_v2","arg$42","bnds$45","arg$43","bnds$46","arg$44","bnds$47","arg$45","bnds$48","arg$46","bnds$49","arg$47","bnds$50","arg$48","bnds$51","arg$49","bnds$52","arg$50","bnds$53","arg$51","bnds$54","arg$52","bnds$55","arg$53","bnds$56","arg$54","bnds$57","arg$55","bnds$58","arg$56","bnds$59","arg$57","bnds$60","arg$58","bnds$61","arg$59","bnds$62","arg$60","bnds$63","arg$61","bnds$64","arg$62","bnds$65","arg$63","bnds$66","arg$64","bnds$67","arg$65","bnds$68","arg$66","bnds$69","arg$67","bnds$70","arg$68","bnds$71","arg$69","bnds$72","arg$70","bnds$73","arg$71","bnds$74","v_out_3","v_out_2","v_out_1","v_out_0","v_in2_3","v_in2_2","v_in2_1","v_in2_0","v_in1_3","v_in1_2","v_in1_1","v_in1_0","v_out","v_in2","v_in1","arg$72","bnds$75","arg$73","bnds$76","arg$74","bnds$77","arg$75","bnds$78","arg$76","bnds$79","arg$77","bnds$80","arg$78","bnds$81","arg$79","bnds$82","arg$80","bnds$83","arg$81","bnds$84","arg$82","bnds$85","arg$83","bnds$86","arg$84","bnds$87","arg$85","bnds$88","arg$86","bnds$89","v_foreign_field_modulus2","v_foreign_field_modulus1","v_foreign_field_modulus0","v_carry","v_field_overflow","v_right_input_hi","v_right_input_mi","v_right_input_lo","v_left_input_hi","v_left_input_mi","v_left_input_lo","arg$87","bnds$90","arg$88","bnds$91","arg$89","bnds$92","arg$90","bnds$93","arg$91","bnds$94","arg$92","bnds$95","arg$93","bnds$96","arg$94","bnds$97","arg$95","bnds$98","arg$96","bnds$99","arg$97","bnds$100","arg$98","bnds$101","v_neg_foreign_field_modulus2","v_neg_foreign_field_modulus1","v_neg_foreign_field_modulus0","v_foreign_field_modulus2$0","v_carry1_90","v_carry1_88","v_carry1_86","v_carry1_84","v_carry1_72","v_carry1_60","v_carry1_48","v_carry1_36","v_carry1_24","v_carry1_12","v_carry1_0","v_carry0","v_product1_hi_1","v_product1_hi_0","v_product1_lo","v_quotient_hi_bound","v_quotient2","v_quotient1","v_quotient0","v_remainder2","v_remainder01","v_right_input2","v_right_input1","v_right_input0","v_left_input2","v_left_input1","v_left_input0","arg$99","bnds$102","arg$100","bnds$103","arg$101","bnds$104","arg$102","bnds$105","arg$103","bnds$106","arg$104","bnds$107","arg$105","bnds$108","arg$106","bnds$109","arg$107","bnds$110","arg$108","bnds$111","arg$109","bnds$112","arg$110","bnds$113","arg$111","bnds$114","arg$112","bnds$115","arg$113","bnds$116","arg$114","bnds$117","arg$115","bnds$118","arg$116","bnds$119","arg$117","bnds$120","arg$118","bnds$121","arg$119","bnds$122","arg$120","bnds$123","arg$121","bnds$124","arg$122","bnds$125","arg$123","bnds$126","arg$124","bnds$127","arg$125","bnds$128","arg$126","bnds$129","arg$127","bnds$130","arg$128","bnds$131","arg$129","bnds$132","v_two_to_rot","v_bound_crumb7","v_bound_crumb6","v_bound_crumb5","v_bound_crumb4","v_bound_crumb3","v_bound_crumb2","v_bound_crumb1","v_bound_crumb0","v_bound_limb3","v_bound_limb2","v_bound_limb1","v_bound_limb0","v_excess","v_rotated","v_word","arg$130","bnds$133","arg$131","bnds$134","arg$132","bnds$135","arg$133","bnds$136","arg$134","bnds$137","arg$135","bnds$138","arg$136","bnds$139","arg$137","bnds$140","arg$138","bnds$141","arg$139","bnds$142","arg$140","bnds$143","arg$141","bnds$144","arg$142","bnds$145","arg$143","bnds$146","arg$144","bnds$147","arg$145","bnds$148","v_data","bnds$149","arg$146","bnds$150","arg$147","bnds$151","v_first_column","v_id$0","arg$148","bnds$152","arg$149","bnds$153","v_coeffs","v_values","v_kind","arg$150","bnds$154","arg$151","bnds$155","arg$152","bnds$156","map$55","fp","x21_inv","inf_z","slope","same_x","inf","p3","compact","v0c7","v0c6","v0c5","v0c4","v0c3","v0c2","v0c1","v0c0","v0p5","v0p4","v0p3","v0p2","v0p1","v0p0","v2c19","v2c18","v2c17","v2c16","v2c15","v2c14","v2c13","v2c12","v1p1","v1p0","v0p1$0","v0p0$0","v2c11","v2c10","v2c9","v2c8","v2c7","v2c6","v2c5","v2c4","v2c3","v2c2","v2c1","v2p3","v2p2","v2p1","v2p0","v2c0","out_3","out_2","out_1","out_0","in2_3","in2_2","in2_1","in2_0","in1_3","in1_2","in1_1","in1_0","in2","in1","foreign_field_modulus2","foreign_field_modulus1","foreign_field_modulus0","field_overflow","right_input_hi","right_input_mi","right_input_lo","left_input_hi","left_input_mi","left_input_lo","neg_foreign_field_modulus2","neg_foreign_field_modulus1","neg_foreign_field_modulus0","foreign_field_modulus2$0","carry1_90","carry1_88","carry1_86","carry1_84","carry1_72","carry1_60","carry1_48","carry1_36","carry1_24","carry1_12","carry1_0","carry0","product1_hi_1","product1_hi_0","product1_lo","quotient_hi_bound","quotient2","quotient1","quotient0","remainder2","remainder01","right_input2","right_input1","right_input0","left_input2","left_input1","left_input0","two_to_rot","bound_crumb7","bound_crumb6","bound_crumb5","bound_crumb4","bound_crumb3","bound_crumb2","bound_crumb1","bound_crumb0","bound_limb3","bound_limb2","bound_limb1","bound_limb0","excess","rotated","word","first_column","coeffs","eval_one","vo","co","vr","cr","vl","vl$0","vr$0","vo$0","custom_printf_009","custom_printf_010","custom_printf_011","custom_printf_012","custom_printf_013","custom_printf_014","custom_printf_015","custom_printf_016","custom_printf_017","custom_printf_018","compare$93","hash_fold_t$56","a0$0","hash$41","t_of_sexp$83","sexp_of_t$91","get_concatenated_fixed_lookup_","flts","flt","get_concatenated_runtime_looku","rt_cfgs","rt_cfg","finalize_fixed_lookup_tables","fixed_lt_rev","finalize_runtime_lookup_tables","rt_cfgs_rev","t_028","t_027","t_029","compute_witness","external_values","internal_values","num_rows","custom_printf_039","i_after_input","cols","row_idx","col_idx","map_runtime_tables","cfgs","rt_idx","compute_value","vidx","vv","id_int32","union_find","create_internal","get_auxiliary_input_size","get_primary_input_size","get_prev_challenges","num_pub_inputs","set_prev_challenges","num_prev_challenges","next_row","get_concatenated_fixed_lookup_$0","get_concatenated_runtime_looku$0","add_row","vars_for_perm","finalize_and_get_gates","runtime_tables_cfg$0","gates_rev","fixed_lookup_tables","runtime_tables_cfg","rust_gates","pub_selectors","pub_input_gate_specs_rev","public_var","row_field","col_field","col_value","row_value","v_row","equivalence_classes","pos_map","update_gate_with_permutation_i","public_gates","public_gates$0","absolute_row","gates$0","relative_row","add_gates","wired_to","wired_to$0","md5_digest","num_constraints","to_json","add_generic_constraint","coeffs2","o2","coeffs$0","constr","red","terms$0","terms_list","lx","go$0","lx$0","rs","s1x1_plus_s2x2","reduce_to_v","xo","xo$0","x3$0","x3$1","x3$2","ratio","ratio$0","x2$1","red_pr","l_s","r_s","o$0","coeff","add_round_state","s5","s4","reduce_curve_point","x1$1","x2$2","x3$3","curr_row","add_endoscale_round","vars$1","add_endoscale_scalar_round","red_w0","red_w1","red_w2","red_w3","red_w4","red_w5","red_w6","vars$2","lookup1","lookup2","lookup3","vars$3","coeff$0","v2$2","vars_curr","vars_next","vars$4","vars_curr$0","vars_next$0","vars_curr$1","values$0","urs_info","degree","set_urs_info","load","urs$0","store","urs$1","runtime_table_cfgs","prev_challenges$0","prev_challenges$1","array_to_vector","vk_commitments","full_vk_commitments","to_list$14","of_list$8","group3","pt$0","tuples","string_bits","test_bit","to_bytes$0","bit","of_bytes$0","hash$42","hash_fold_t$57","to_yojson$20","of_yojson$13","length_in_bits","order","length_in_bytes","remaining_bytes","extended_euclidean","inv_no_mod","euler","while$0","t_minus_1_over_2","b2m","of_bigint","to_bigint","make_gen","t_of_bignum_bigint","make_gen_full","bignum_bigint_of_t","fold_bits","group$91","bin_shape_t$93","group$92","bin_shape_t$94","bin_size_t$46","bin_write_t$47","bin_read_t$81","to_yojson$21","of_yojson$14","compare$94","equal$53","of_bytes$1","to_bytes$1","of_decimal_string","to_string$42","test_bit$0","div$1","compare$95","num_limbs","bytes_per_limb","to_hex","to_hex_string","of_hex_string","of_numeral","double$1","one$8","symbol$205","double$2","one$9","to_affine_exn$0","of_affine$0","symbol$206","make$6","unshifted$0","make$7","sponge_params","sponge_params_constant","to_field$1","of_field$1","with_lagrange","vks","create_aux$0","prev_chals","prev_comms","computed_witness","create$64","to_binable$8","of_binable$10","create$65","of_data$0","to_field$2","of_field$2","with_lagrange$0","create_aux$1","create_async$0","create$66","to_binable$9","of_binable$11","create$67","create_with_public_evals$0","digest_size_in_bits","digest_size_in_bytes","char_generator","of_hex$0","digest_bigstring$0","digest_string$0","to_raw_string$0","of_raw_string$0","hash$2","bits_to_string","finished","string_to_bits","pct","pot","mct","mot","loc$2","last$0","last$1","map$60","raise_errorf","fixity_of_string","first_is","last_is","needs_parens","needs_spaces","protect_ident","view_expr","exp$0","is_simple_construct","under_semi","ctxt","list$4","fu","option$0","paren","print_longident$0","longident_loc","delim","mutable_flag","virtual_flag","rec_flag","nonrec_flag","direction_flag","private_flag","constant_string","tyvar","tyvar_loc","f$11","module_type$5","mt2","mt1","module_type$2","module_type1","mt2$0","with_constraint","td","ls$0","type_declaration$2","core_type","li2","li$0","td$0","ls$1","li$1","ls$2","li2$0","li$2","module_type1$0","attributes","signature_item$1","me","module_expr$0","extension","e$6","sugar_expr","label_x_expression_param","simple_expr","s$4","expression2","eo$0","eo$1","l$6","e$7","s$5","l$7","string_x_expression","e$8","e$9","ct","e$10","case_list","label_exp","cd","extension_constructor$4","e$5","ands","let$0","binding_op$1","eo","expression_under_ifthenelse","class_structure$2","expression2$0","simple_expr$0","longident_x_expression","e3","df","expression","pattern$0","ct$0","cto1","lid","pattern$6","pattern1$0","pattern_list_helper","pat2","pat1","simple_pattern","pattern1","simple_pattern$0","po","closed","longident_x_pattern","with_paren","simple_name","pc_rhs","pc_guard","pc_lhs","constructor_declaration","attrs","core_type1","record_declaration","priv","manifest","constructor_declaration$0","pcd","intro","variants","constraints","ct2","ct1","lbls","type_record_field","pld","type_param","structure_item$0","item_attributes","vd","value_description$2","type_def_list","te","type_extension$0","exception_declaration","me$1","me$0","arg_opt","mt","decls","pmb","expr","attrs$0","md","class_constraint","class_type$3","class_declaration","cl$2","cl$1","class_expr$2","class_params_def","class_type_declaration_list","floating_attribute","item_extension","binding$0","binding","pp_print_pexp_function","tyvars_str","tyvars","args_tyvars","gadt_pattern","gadt_exp","tyvars$0","e_ct","e_tyvars","pt_ct","pt_tyvars","check_variable","var_names","core_type$0","lst$1","loop_object_field","lst$2","longident","core_type$1","lbl_lst_option","row_field_list","loop_row_field","core_type$2","string_lst","lst$3","longident$0","prf_desc","pof_desc","ety","tyvars$1","ct$1","payload","me2","me1","mt$0","alias","pms","pmd","s$6","s$7","class_description","exported","type_decl","ce","ce$0","ce$1","so","ovf","ovf$0","ovf$1","class_type_declaration","vf","mf","vf$0","pf","type_with_label","print_indexop","path_prefix","print_index","rem_args","print_path","other_args","i3","i2$0","i1$0","i1$1","left$0","txt$0","core_field_type","field_var","first_is_inherit","type_variant_helper","ctl","cstrs","pp$26","pp$27","migration_error","missing_feature","copy_loc","f0","copy_structure","copy_structure_item","copy_toplevel_phrase","pdir_loc","pdir_arg","pdir_name","copy_directive_argument","pdira_loc","pdira_desc","x0$2","copy_attributes","copy_attribute","copy_constant","copy_rec_flag","copy_arg_label","copy_constructor_arguments","copy_core_type","copy_label_declaration","copy_extension_constructor","pext_attributes","pext_loc","pext_kind","pext_name","copy_Longident_t","copy_extension","copy_payload","copy_signature","copy_signature_item","copy_functor_parameter","copy_module_type","copy_override_flag","copy_open_infos","popen_attributes","popen_loc","popen_override","popen_expr","copy_open_declaration","copy_module_expr","copy_closed_flag","ptyp_attributes","ptyp_loc_stack","ptyp_loc","ptyp_desc","x0$3","copy_object_field","x1$2","x0$4","x1$3","x0$5","x1$4","x0$6","copy_label","copy_row_field","x1$5","x0$7","x0$8","x1$6","x0$10","x0$9","copy_pattern","ppat_attributes","ppat_loc_stack","ppat_loc","ppat_desc","x0$11","x0$12","x0$13","x0$14","x0$15","copy_class_structure","pcstr_fields","pcstr_self","copy_class_field","pmty_attributes","pmty_loc","pmty_desc","copy_with_constraint","pmod_attributes","pmod_loc","pmod_desc","copy_expression","copy_binding_op","pbop_loc","pbop_exp","pbop_pat","pbop_op","copy_expression_desc","copy_value_binding","copy_case","x1$7","x1$8","x1$9","x1$10","x1$11","x0$16","x2$3","x1$12","x0$17","x1$13","x0$18","x2$4","x1$14","x0$19","x1$15","x0$20","x0$21","x1$16","x0$22","x0$23","x2$5","x1$17","x0$24","x1$18","x0$25","x0$26","x0$27","x1$19","x0$28","x0$29","x1$20","x0$30","x0$31","x1$21","x0$32","x0$33","x0$34","pexp_attributes","pexp_loc_stack","pexp_loc","pexp_desc","pvb_loc","pvb_attributes","pvb_expr","pvb_pat","prf_attributes","prf_loc","pof_attributes","pof_loc","attr_loc","attr_payload","attr_name","copy_value_description","pval_loc","pval_attributes","pval_prim","pval_type","pval_name","copy_variance","copy_injectivity","copy_private_flag","copy_type_extension","ptyext_attributes","ptyext_loc","ptyext_private","ptyext_constructors","ptyext_params","ptyext_path","copy_type_exception","ptyexn_attributes","ptyexn_loc","ptyexn_constructor","copy_module_type_declaration","pmtd_loc","pmtd_attributes","pmtd_type","pmtd_name","copy_include_infos","pincl_attributes","pincl_loc","pincl_mod","copy_module_binding","pmb_loc","pmb_attributes","pmb_expr","pmb_name","pstr_loc","pstr_desc","copy_type_declaration","copy_class_declaration","copy_class_type_declaration","copy_virtual_flag","copy_class_infos","pci_attributes","pci_loc","pci_expr","pci_name","pci_params","pci_virt","copy_class_expr","copy_open_description","copy_class_type","pcty_attributes","pcty_loc","pcty_desc","pcsig_fields","pcsig_self","copy_class_type_field","pcl_attributes","pcl_loc","pcl_desc","copy_mutable_flag","copy_class_field_kind","pcf_attributes","pcf_loc","pcf_desc","ptype_loc","ptype_attributes","ptype_manifest","ptype_private","ptype_kind","ptype_cstrs","ptype_params","ptype_name","copy_constructor_declaration","copy_module_declaration","pmd_loc","pmd_attributes","pmd_type","pmd_name","psig_loc","psig_desc","pms_loc","pms_attributes","pms_manifest","pms_name","copy_class_description","pctf_attributes","pctf_loc","pctf_desc","pcd_attributes","pcd_loc","pcd_res","pcd_args","pcd_vars","pcd_name","pld_attributes","pld_loc","pld_type","pld_mutable","pld_name","copy_loc$0","copy_structure$0","copy_structure_item$0","copy_toplevel_phrase$0","copy_directive_argument$0","copy_attributes$0","copy_attribute$0","copy_constant$0","copy_rec_flag$0","copy_arg_label$0","copy_constructor_arguments$0","copy_core_type$0","copy_label_declaration$0","copy_extension_constructor$0","copy_Longident_t$0","copy_extension$0","copy_payload$0","copy_signature$0","copy_signature_item$0","copy_functor_parameter$0","copy_module_type$0","copy_override_flag$0","copy_open_infos$0","copy_open_declaration$0","copy_module_expr$0","copy_closed_flag$0","copy_object_field$0","copy_label$0","copy_row_field$0","copy_pattern$0","copy_class_structure$0","copy_class_field$0","copy_with_constraint$0","copy_expression$0","copy_binding_op$0","copy_expression_desc$0","copy_value_binding$0","copy_case$0","copy_value_description$0","copy_variance$0","copy_injectivity$0","copy_private_flag$0","copy_type_extension$0","copy_type_exception$0","copy_module_type_declaration$0","copy_include_infos$0","copy_module_binding$0","copy_type_declaration$0","copy_class_declaration$0","copy_class_type_declaration$0","copy_virtual_flag$0","copy_class_infos$0","copy_class_expr$0","copy_open_description$0","copy_class_type$0","copy_class_type_field$0","copy_mutable_flag$0","copy_class_field_kind$0","copy_constructor_declaration$0","copy_module_declaration$0","copy_class_description$0","migration_error$0","copy_loc$1","copy_structure$1","copy_structure_item$1","copy_toplevel_phrase$1","copy_directive_argument$1","copy_attributes$1","copy_attribute$1","copy_location_stack","copy_location","copy_constant$1","copy_rec_flag$1","copy_arg_label$1","copy_constructor_arguments$1","copy_core_type$1","copy_label_declaration$1","copy_extension_constructor$1","copy_Longident_t$1","copy_extension$1","copy_payload$1","copy_signature$1","copy_signature_item$1","copy_functor_parameter$1","copy_module_type$1","copy_override_flag$1","copy_open_infos$1","copy_open_declaration$1","copy_module_expr$1","copy_closed_flag$1","copy_object_field$1","copy_label$1","copy_row_field$1","copy_pattern$1","copy_class_structure$1","copy_class_field$1","copy_with_constraint$1","copy_expression$1","copy_binding_op$1","copy_expression_desc$1","copy_value_binding$1","copy_case$1","copy_value_description$1","copy_variance$1","copy_injectivity$1","copy_private_flag$1","copy_type_extension$1","copy_type_exception$1","copy_module_type_declaration$1","copy_include_infos$1","copy_module_binding$1","copy_type_declaration$1","copy_class_declaration$1","copy_class_type_declaration$1","copy_virtual_flag$1","copy_class_infos$1","copy_class_expr$1","copy_open_description$1","copy_class_type$1","copy_class_type_field$1","copy_mutable_flag$1","copy_class_field_kind$1","copy_constructor_declaration$1","copy_module_declaration$1","copy_class_description$1","copy_loc$2","copy_structure$2","copy_structure_item$2","copy_toplevel_phrase$2","copy_directive_argument$2","copy_attributes$2","copy_attribute$2","copy_location_stack$0","copy_location$0","copy_constant$2","copy_rec_flag$2","copy_arg_label$2","copy_constructor_arguments$2","copy_core_type$2","copy_label_declaration$2","copy_extension_constructor$2","copy_Longident_t$2","copy_extension$2","copy_payload$2","copy_signature$2","copy_signature_item$2","copy_functor_parameter$2","copy_module_type$2","copy_override_flag$2","copy_open_infos$2","copy_open_declaration$2","copy_module_expr$2","copy_closed_flag$2","copy_object_field$2","copy_label$2","copy_row_field$2","copy_pattern$2","copy_class_structure$2","copy_class_field$2","copy_with_constraint$2","copy_expression$2","copy_binding_op$2","copy_expression_desc$2","copy_value_binding$2","copy_case$2","copy_value_description$2","copy_variance$2","copy_injectivity$2","copy_private_flag$2","copy_type_extension$2","copy_type_exception$2","copy_module_type_declaration$2","copy_include_infos$2","copy_module_binding$2","copy_type_declaration$2","copy_class_declaration$2","copy_class_type_declaration$2","copy_virtual_flag$2","copy_class_infos$2","copy_class_expr$2","copy_open_description$2","copy_class_type$2","copy_class_type_field$2","copy_mutable_flag$2","copy_class_field_kind$2","copy_constructor_declaration$2","copy_module_declaration$2","copy_class_description$2","copy_loc$3","copy_structure$3","copy_structure_item$3","copy_toplevel_phrase$3","copy_directive_argument$3","copy_attributes$3","copy_attribute$3","copy_constant$3","copy_rec_flag$3","copy_arg_label$3","copy_constructor_arguments$3","copy_core_type$3","copy_label_declaration$3","copy_extension_constructor$3","copy_Longident_t$3","copy_extension$3","copy_payload$3","copy_signature$3","copy_signature_item$3","copy_functor_parameter$3","copy_module_type$3","copy_override_flag$3","copy_open_infos$3","copy_open_declaration$3","copy_module_expr$3","copy_closed_flag$3","copy_object_field$3","copy_label$3","copy_row_field$3","copy_pattern$3","copy_class_structure$3","copy_class_field$3","copy_with_constraint$3","copy_expression$3","copy_binding_op$3","copy_expression_desc$3","copy_value_binding$3","copy_case$3","copy_value_description$3","copy_variance$3","copy_private_flag$3","copy_type_extension$3","copy_type_exception$3","copy_module_type_declaration$3","copy_include_infos$3","copy_module_binding$3","copy_type_declaration$3","copy_class_declaration$3","copy_class_type_declaration$3","copy_virtual_flag$3","copy_class_infos$3","copy_class_expr$3","copy_open_description$3","copy_class_type$3","copy_class_type_field$3","copy_mutable_flag$3","copy_class_field_kind$3","copy_constructor_declaration$3","copy_module_declaration$3","copy_class_description$3","copy_loc$4","copy_structure$4","copy_structure_item$4","copy_toplevel_phrase$4","copy_directive_argument$4","copy_attributes$4","copy_attribute$4","copy_constant$4","copy_rec_flag$4","copy_arg_label$4","copy_constructor_arguments$4","copy_core_type$4","copy_label_declaration$4","copy_extension_constructor$4","copy_Longident_t$4","copy_extension$4","copy_payload$4","copy_signature$4","copy_signature_item$4","copy_functor_parameter$4","copy_module_type$4","copy_override_flag$4","copy_open_infos$4","copy_open_declaration$4","copy_module_expr$4","copy_closed_flag$4","copy_object_field$4","copy_label$4","copy_row_field$4","copy_pattern$4","copy_class_structure$4","copy_class_field$4","copy_with_constraint$4","copy_expression$4","copy_binding_op$4","copy_expression_desc$4","copy_value_binding$4","copy_case$4","copy_value_description$4","copy_variance$4","copy_private_flag$4","copy_type_extension$4","copy_type_exception$4","copy_module_type_declaration$4","copy_include_infos$4","copy_module_binding$4","copy_type_declaration$4","copy_class_declaration$4","copy_class_type_declaration$4","copy_virtual_flag$4","copy_class_infos$4","copy_class_expr$4","copy_open_description$4","copy_class_type$4","copy_class_type_field$4","copy_mutable_flag$4","copy_class_field_kind$4","copy_constructor_declaration$4","copy_module_declaration$4","copy_class_description$4","copy_loc$5","copy_structure$5","copy_structure_item$5","copy_toplevel_phrase$5","copy_directive_argument$5","copy_attributes$5","copy_attribute$5","copy_location_stack$1","copy_location$1","copy_constant$5","copy_rec_flag$5","copy_arg_label$5","copy_constructor_arguments$5","copy_core_type$5","copy_label_declaration$5","copy_extension_constructor$5","copy_Longident_t$5","copy_extension$5","copy_payload$5","copy_signature$5","copy_signature_item$5","copy_functor_parameter$5","copy_module_type$5","copy_override_flag$5","copy_open_infos$5","copy_open_declaration$5","copy_module_expr$5","copy_closed_flag$5","copy_object_field$5","copy_label$5","copy_row_field$5","copy_pattern$5","copy_class_structure$5","copy_class_field$5","copy_with_constraint$5","copy_expression$5","copy_binding_op$5","copy_expression_desc$5","copy_value_binding$5","copy_case$5","copy_value_description$5","copy_variance$5","copy_private_flag$5","copy_type_extension$5","copy_type_exception$5","copy_module_type_declaration$5","copy_include_infos$5","copy_module_binding$5","copy_type_declaration$5","copy_class_declaration$5","copy_class_type_declaration$5","copy_virtual_flag$5","copy_class_infos$5","copy_class_expr$5","copy_open_description$5","copy_class_type$5","copy_class_type_field$5","copy_mutable_flag$5","copy_class_field_kind$5","copy_constructor_declaration$5","copy_module_declaration$5","copy_class_description$5","copy_loc$6","copy_structure$6","copy_structure_item$6","copy_toplevel_phrase$6","copy_directive_argument$6","copy_attributes$6","copy_attribute$6","copy_location_stack$2","copy_location$2","copy_constant$6","copy_rec_flag$6","copy_arg_label$6","copy_constructor_arguments$6","copy_core_type$6","copy_label_declaration$6","copy_extension_constructor$6","copy_Longident_t$6","copy_extension$6","copy_payload$6","copy_signature$6","copy_signature_item$6","copy_functor_parameter$6","copy_module_type$6","copy_override_flag$6","copy_open_infos$6","copy_open_declaration$6","copy_module_expr$6","copy_closed_flag$6","copy_object_field$6","copy_label$6","copy_row_field$6","copy_pattern$6","copy_class_structure$6","copy_class_field$6","copy_with_constraint$6","copy_expression$6","copy_binding_op$6","copy_expression_desc$6","copy_value_binding$6","copy_case$6","copy_value_description$6","copy_variance$6","copy_private_flag$6","copy_type_extension$6","copy_type_exception$6","copy_module_type_declaration$6","copy_include_infos$6","copy_module_binding$6","copy_type_declaration$6","copy_class_declaration$6","copy_class_type_declaration$6","copy_virtual_flag$6","copy_class_infos$6","copy_class_expr$6","copy_open_description$6","copy_class_type$6","copy_class_type_field$6","copy_mutable_flag$6","copy_class_field_kind$6","copy_constructor_declaration$6","copy_module_declaration$6","copy_class_description$6","migration_error$1","map_option","copy_loc$7","copy_structure$7","copy_structure_item$7","copy_toplevel_phrase$7","copy_directive_argument$7","copy_attributes$7","copy_attribute$7","copy_location_stack$3","copy_location$3","copy_constant$7","copy_rec_flag$7","copy_arg_label$7","copy_constructor_arguments$7","copy_core_type$7","copy_label_declaration$7","copy_extension_constructor$7","copy_Longident_t$7","copy_extension$7","copy_payload$7","copy_signature$7","copy_signature_item$7","copy_functor_parameter$7","copy_module_type$7","copy_override_flag$7","copy_open_infos$7","copy_open_declaration$7","copy_module_expr$7","copy_closed_flag$7","copy_object_field$7","copy_label$7","copy_row_field$7","copy_pattern$7","copy_class_structure$7","copy_class_field$7","copy_with_constraint$7","copy_expression$7","copy_binding_op$7","copy_expression_desc$7","copy_value_binding$7","copy_case$7","copy_value_description$7","copy_variance$7","copy_private_flag$7","copy_type_extension$7","copy_type_exception$7","copy_module_type_declaration$7","copy_include_infos$7","copy_module_binding$7","copy_type_declaration$7","copy_class_declaration$7","copy_class_type_declaration$7","copy_virtual_flag$7","copy_class_infos$7","copy_class_expr$7","copy_open_description$7","copy_class_type$7","copy_class_type_field$7","copy_mutable_flag$7","copy_class_field_kind$7","copy_constructor_declaration$7","copy_module_declaration$7","copy_class_description$7","map_option$0","copy_loc$8","copy_structure$8","copy_structure_item$8","copy_toplevel_phrase$8","copy_directive_argument$8","copy_attributes$8","copy_attribute$8","copy_constant$8","copy_rec_flag$8","copy_arg_label$8","copy_constructor_arguments$8","copy_core_type$8","copy_label_declaration$8","copy_extension_constructor$8","copy_Longident_t$8","copy_extension$8","copy_payload$8","copy_signature$8","copy_signature_item$8","copy_override_flag$8","copy_open_infos$8","copy_open_declaration$8","copy_module_expr$8","copy_closed_flag$8","copy_location$4","copy_object_field$8","copy_label$8","copy_row_field$8","copy_pattern$8","copy_class_structure$8","copy_class_field$8","copy_cases","copy_case$8","copy_module_type$8","copy_with_constraint$8","copy_expression$8","copy_binding_op$8","copy_expression_desc$8","copy_value_binding$8","copy_value_description$8","copy_variance$8","copy_private_flag$8","copy_type_extension$8","copy_type_exception$8","copy_module_type_declaration$8","copy_include_infos$8","copy_module_binding$8","copy_type_declaration$8","copy_class_declaration$8","copy_class_type_declaration$8","copy_virtual_flag$8","copy_class_infos$8","copy_class_expr$8","copy_open_description$8","copy_class_type$8","copy_class_type_field$8","copy_mutable_flag$8","copy_class_field_kind$8","copy_constructor_declaration$8","copy_module_declaration$8","copy_class_description$8","copy_loc$9","copy_structure$9","copy_structure_item$9","copy_toplevel_phrase$9","copy_directive_argument$9","copy_attributes$9","copy_attribute$9","copy_constant$9","copy_rec_flag$9","copy_arg_label$9","copy_constructor_arguments$9","copy_core_type$9","copy_label_declaration$9","copy_extension_constructor$9","copy_Longident_t$9","copy_extension$9","copy_payload$9","copy_signature$9","copy_signature_item$9","copy_override_flag$9","copy_open_infos$9","copy_open_declaration$9","copy_module_expr$9","copy_closed_flag$9","copy_location$5","copy_object_field$9","copy_label$9","copy_row_field$9","copy_pattern$9","copy_class_structure$9","copy_class_field$9","copy_cases$0","copy_case$9","copy_module_type$9","copy_with_constraint$9","copy_expression$9","copy_binding_op$9","copy_expression_desc$9","copy_value_binding$9","copy_value_description$9","copy_variance$9","copy_private_flag$9","copy_type_extension$9","copy_type_exception$9","copy_module_type_declaration$9","copy_include_infos$9","copy_module_binding$9","copy_type_declaration$9","copy_class_declaration$9","copy_class_type_declaration$9","copy_virtual_flag$9","copy_class_infos$9","copy_class_expr$9","copy_open_description$9","copy_class_type$9","copy_class_type_field$9","copy_mutable_flag$9","copy_class_field_kind$9","copy_constructor_declaration$9","copy_module_declaration$9","copy_class_description$9","copy_loc$10","copy_structure$10","copy_structure_item$10","copy_toplevel_phrase$10","copy_directive_argument$10","copy_attributes$10","copy_attribute$10","copy_constant$10","copy_rec_flag$10","copy_arg_label$10","copy_constructor_arguments$10","copy_core_type$10","copy_label_declaration$10","copy_extension_constructor$10","copy_Longident_t$10","copy_extension$10","copy_payload$10","copy_signature$10","copy_signature_item$10","copy_override_flag$10","copy_open_infos$10","copy_open_declaration$10","copy_module_expr$10","copy_closed_flag$10","copy_location$6","copy_object_field$10","copy_label$10","copy_row_field$10","copy_pattern$10","copy_class_structure$10","copy_class_field$10","copy_cases$1","copy_case$10","copy_module_type$10","copy_with_constraint$10","copy_expression$10","copy_binding_op$10","copy_expression_desc$10","copy_value_binding$10","copy_value_description$10","copy_variance$10","copy_private_flag$10","copy_type_extension$10","copy_type_exception$10","copy_module_type_declaration$10","copy_include_infos$10","copy_module_binding$10","copy_type_declaration$10","copy_class_declaration$10","copy_class_type_declaration$10","copy_virtual_flag$10","copy_class_infos$10","copy_class_expr$10","copy_open_description$10","copy_class_type$10","copy_class_type_field$10","copy_mutable_flag$10","copy_class_field_kind$10","copy_constructor_declaration$10","copy_module_declaration$10","copy_class_description$10","migration_error$2","copy_bool","copy_option","copy_structure$11","copy_structure_item$11","copy_toplevel_phrase$11","copy_attributes$11","copy_attribute$11","copy_loc$11","copy_constant$11","copy_rec_flag$11","copy_arg_label$11","copy_constructor_arguments$11","copy_core_type$11","copy_label_declaration$11","copy_extension_constructor$11","copy_longident","copy_override_flag$11","copy_extension$11","copy_payload$11","copy_signature$11","copy_signature_item$11","copy_closed_flag$11","copy_object_field$11","copy_label$11","copy_row_field$11","copy_pattern$11","copy_class_structure$11","copy_class_field$11","copy_module_type$11","copy_with_constraint$11","copy_module_expr$11","copy_expression$11","copy_expression_desc$11","copy_value_binding$11","copy_case$11","copy_value_description$11","copy_variance$11","copy_private_flag$11","copy_type_extension$11","copy_module_type_declaration$11","copy_include_infos$11","copy_module_binding$11","copy_type_declaration$11","copy_class_declaration$11","copy_class_type_declaration$11","copy_virtual_flag$11","copy_class_infos$11","copy_class_expr$11","copy_class_type$11","copy_class_type_field$11","copy_mutable_flag$11","copy_class_field_kind$11","copy_constructor_declaration$11","copy_module_declaration$11","x0_loc","copy_class_description$11","copy_toplevel_phrase$12","copy_directive_argument$11","copy_expression$12","copy_expression_desc$12","copy_direction_flag","copy_case$12","copy_value_binding$12","copy_pattern$12","copy_pattern_desc","copy_core_type$12","copy_core_type_desc","copy_package_type","copy_row_field$12","copy_object_field$12","copy_attributes$12","copy_attribute$12","copy_payload$12","copy_structure$12","copy_structure_item$12","copy_structure_item_desc","copy_include_declaration","copy_class_declaration$12","copy_class_expr$12","copy_class_expr_desc","copy_class_structure$12","copy_class_field$12","copy_class_field_desc","copy_class_field_kind$12","copy_module_binding$12","copy_module_expr$12","copy_module_expr_desc","copy_module_type$12","copy_module_type_desc","copy_with_constraint$12","copy_signature$12","copy_signature_item$12","copy_signature_item_desc","copy_class_type_declaration$12","copy_class_description$12","copy_class_type$12","copy_class_type_desc","copy_class_signature","copy_class_type_field$12","copy_class_type_field_desc","copy_extension$12","copy_class_infos$12","copy_virtual_flag$12","copy_include_description","copy_include_infos$12","copy_open_description$11","copy_override_flag$12","copy_module_type_declaration$12","copy_module_declaration$12","copy_type_extension$12","copy_extension_constructor$12","copy_extension_constructor_kin","copy_type_declaration$12","copy_private_flag$12","copy_type_kind","copy_constructor_declaration$12","copy_constructor_arguments$12","copy_label_declaration$12","copy_mutable_flag$12","copy_variance$12","copy_value_description$12","copy_arg_label$12","copy_closed_flag$12","copy_label$12","copy_rec_flag$12","copy_constant$12","copy_option$0","copy_longident$0","copy_loc$12","copy_location$7","copy_bool$0","wrap$2","x2$6","atat","popen_lid","copy_attributes$13","copy_attribute$13","copy_loc$13","copy_option$1","copy_constant$13","copy_rec_flag$13","copy_arg_label$13","copy_constructor_arguments$13","copy_core_type$13","copy_label_declaration$13","copy_extension_constructor$13","copy_longident$1","copy_override_flag$13","copy_extension$13","copy_payload$13","copy_signature$13","copy_signature_item$13","copy_structure$13","copy_structure_item$13","copy_closed_flag$13","copy_object_field$13","copy_label$13","copy_row_field$13","copy_pattern$13","copy_class_structure$13","copy_class_field$13","copy_module_type$13","copy_with_constraint$13","copy_module_expr$13","copy_expression$13","copy_expression_desc$13","copy_value_binding$13","copy_case$13","copy_bool$1","copy_value_description$13","copy_variance$13","copy_private_flag$13","copy_type_extension$13","copy_module_type_declaration$13","copy_open_description$12","copy_include_infos$13","copy_module_binding$13","copy_type_declaration$13","copy_class_declaration$13","copy_class_type_declaration$13","copy_virtual_flag$13","copy_class_infos$13","copy_class_expr$13","copy_class_type$13","copy_class_type_field$13","cty","copy_class_field_kind$13","copy_mutable_flag$13","copy_constructor_declaration$13","copy_module_declaration$13","copy_class_description$13","copy_toplevel_phrase$13","copy_attributes$14","copy_attribute$14","copy_loc$14","copy_option$2","copy_constant$14","copy_rec_flag$14","copy_arg_label$14","copy_constructor_arguments$14","copy_core_type$14","copy_label_declaration$14","copy_extension_constructor$14","copy_longident$2","copy_override_flag$14","copy_extension$14","copy_payload$14","copy_signature$14","copy_signature_item$14","copy_structure$14","copy_structure_item$14","copy_closed_flag$14","copy_object_field$14","copy_label$14","copy_row_field$14","copy_pattern$14","copy_class_structure$14","copy_class_field$14","copy_module_type$14","copy_with_constraint$14","copy_module_expr$14","copy_expression$14","copy_expression_desc$14","copy_value_binding$14","copy_case$14","copy_bool$2","copy_value_description$14","copy_variance$14","copy_private_flag$14","copy_type_extension$14","copy_module_type_declaration$14","copy_open_description$13","copy_include_infos$14","copy_module_binding$14","copy_type_declaration$14","copy_class_declaration$14","copy_class_type_declaration$14","copy_virtual_flag$14","copy_class_infos$14","copy_class_expr$14","copy_class_type$14","copy_class_type_field$14","copy_class_field_kind$14","copy_mutable_flag$14","copy_constructor_declaration$14","copy_module_declaration$14","copy_class_description$14","copy_toplevel_phrase$14","migration_error$3","copy_attributes$15","copy_attribute$15","copy_loc$15","copy_option$3","copy_constant$15","copy_rec_flag$15","copy_arg_label$15","copy_constructor_arguments$15","copy_core_type$15","copy_label_declaration$15","copy_extension_constructor$15","copy_longident$3","copy_override_flag$15","copy_extension$15","copy_payload$15","copy_signature$15","copy_signature_item$15","copy_structure$15","copy_structure_item$15","copy_closed_flag$15","copy_label$15","copy_row_field$15","copy_pattern$15","copy_class_structure$15","copy_class_field$15","copy_module_type$15","copy_with_constraint$15","copy_module_expr$15","copy_expression$15","copy_expression_desc$15","copy_value_binding$15","copy_case$15","copy_bool$3","copy_value_description$15","copy_variance$15","copy_private_flag$15","copy_type_extension$15","copy_module_type_declaration$15","copy_open_description$14","copy_include_infos$15","copy_module_binding$15","copy_type_declaration$15","copy_class_declaration$15","copy_class_type_declaration$15","copy_virtual_flag$15","copy_class_infos$15","copy_class_expr$15","copy_class_type$15","copy_class_type_field$15","copy_class_field_kind$15","copy_mutable_flag$15","copy_constructor_declaration$15","loc$1","copy_module_declaration$15","copy_class_description$15","copy_toplevel_phrase$15","copy_attributes$16","copy_attribute$16","copy_loc$16","copy_option$4","copy_constant$16","copy_rec_flag$16","copy_arg_label$16","copy_constructor_arguments$16","copy_core_type$16","copy_label_declaration$16","copy_extension_constructor$16","copy_longident$4","copy_override_flag$16","copy_extension$16","copy_payload$16","copy_signature$16","copy_signature_item$16","copy_structure$16","copy_structure_item$16","copy_closed_flag$16","copy_label$16","copy_row_field$16","copy_pattern$16","copy_class_structure$16","copy_class_field$16","copy_module_type$16","copy_with_constraint$16","copy_module_expr$16","copy_expression$16","copy_expression_desc$16","copy_value_binding$16","copy_case$16","copy_bool$4","copy_value_description$16","copy_variance$16","copy_private_flag$16","copy_type_extension$16","copy_module_type_declaration$16","copy_open_description$15","copy_include_infos$16","copy_module_binding$16","copy_type_declaration$16","copy_class_declaration$16","copy_class_type_declaration$16","copy_virtual_flag$16","copy_class_infos$16","copy_class_expr$16","copy_class_type$16","copy_class_type_field$16","copy_class_field_kind$16","copy_mutable_flag$16","copy_constructor_declaration$16","copy_module_declaration$16","copy_class_description$16","copy_toplevel_phrase$16","copy_attributes$17","copy_attribute$17","copy_loc$17","copy_option$5","copy_constant$17","copy_rec_flag$17","copy_arg_label$17","copy_constructor_arguments$17","copy_core_type$17","copy_label_declaration$17","copy_extension_constructor$17","copy_longident$5","copy_override_flag$17","copy_extension$17","copy_payload$17","copy_signature$17","copy_signature_item$17","copy_structure$17","copy_structure_item$17","copy_closed_flag$17","copy_label$17","copy_row_field$17","copy_pattern$17","copy_class_structure$17","copy_class_field$17","copy_module_type$17","copy_with_constraint$17","copy_module_expr$17","copy_expression$17","copy_expression_desc$17","copy_value_binding$17","copy_case$17","copy_bool$5","copy_value_description$17","copy_variance$17","copy_private_flag$17","copy_type_extension$17","copy_module_type_declaration$17","copy_open_description$16","copy_include_infos$17","copy_module_binding$17","copy_type_declaration$17","copy_class_declaration$17","copy_class_type_declaration$17","copy_virtual_flag$17","copy_class_infos$17","copy_class_expr$17","copy_class_type$17","copy_class_type_field$17","copy_class_field_kind$17","copy_mutable_flag$17","copy_constructor_declaration$17","copy_module_declaration$17","copy_class_description$17","copy_toplevel_phrase$17","noloc","copy_attributes$18","copy_attribute$18","copy_loc$18","copy_option$6","copy_constant$18","copy_rec_flag$18","copy_arg_label$18","copy_constructor_arguments$18","copy_core_type$18","copy_label_declaration$18","copy_extension_constructor$18","copy_longident$6","copy_override_flag$18","copy_extension$18","copy_payload$18","copy_signature$18","copy_signature_item$18","copy_structure$18","copy_structure_item$18","copy_closed_flag$18","copy_label$18","copy_row_field$18","copy_pattern$18","copy_class_structure$18","copy_class_field$18","copy_module_type$18","copy_with_constraint$18","copy_module_expr$18","copy_expression$18","copy_expression_desc$18","copy_value_binding$18","copy_case$18","copy_bool$6","copy_value_description$18","copy_variance$18","copy_private_flag$18","copy_type_extension$18","copy_module_type_declaration$18","copy_open_description$17","copy_include_infos$18","copy_module_binding$18","copy_type_declaration$18","copy_class_declaration$18","copy_class_type_declaration$18","copy_virtual_flag$18","copy_class_infos$18","copy_class_expr$18","copy_class_type$18","copy_class_type_field$18","copy_class_field_kind$18","copy_mutable_flag$18","copy_constructor_declaration$18","copy_module_declaration$18","copy_class_description$18","copy_toplevel_phrase$18","migration_error$4","copy_attributes$19","copy_attribute$19","copy_loc$19","copy_option$7","copy_constant$19","copy_rec_flag$19","copy_arg_label$19","copy_override_flag$19","copy_extension$19","copy_payload$19","copy_signature$19","copy_signature_item$19","copy_structure$19","copy_structure_item$19","copy_closed_flag$19","copy_core_type$19","copy_longident$7","copy_label$19","copy_row_field$19","copy_pattern$19","copy_class_structure$19","copy_class_field$19","copy_module_type$19","copy_with_constraint$19","copy_module_expr$19","copy_expression$19","copy_expression_desc$19","copy_value_binding$19","copy_case$19","copy_bool$7","copy_value_description$19","copy_constructor_arguments$19","copy_label_declaration$19","copy_extension_constructor$19","copy_variance$19","copy_private_flag$19","copy_type_extension$19","copy_module_type_declaration$19","copy_open_description$18","copy_include_infos$19","copy_module_binding$19","copy_type_declaration$19","copy_class_declaration$19","copy_class_type_declaration$19","copy_virtual_flag$19","copy_class_infos$19","copy_class_expr$19","copy_class_type$19","copy_class_type_field$19","copy_class_field_kind$19","copy_mutable_flag$19","copy_constructor_declaration$19","copy_module_declaration$19","copy_class_description$19","copy_toplevel_phrase$19","copy_attributes$20","copy_attribute$20","copy_loc$20","copy_option$8","copy_constant$20","copy_rec_flag$20","copy_arg_label$20","copy_override_flag$20","copy_extension$20","copy_payload$20","copy_signature$20","copy_signature_item$20","copy_structure$20","copy_structure_item$20","copy_closed_flag$20","copy_core_type$20","copy_longident$8","copy_label$20","copy_row_field$20","copy_pattern$20","copy_class_structure$20","copy_class_field$20","copy_module_type$20","copy_with_constraint$20","copy_module_expr$20","copy_expression$20","copy_expression_desc$20","copy_value_binding$20","copy_case$20","copy_bool$8","copy_value_description$20","copy_constructor_arguments$20","copy_label_declaration$20","copy_extension_constructor$20","copy_variance$20","copy_private_flag$20","copy_type_extension$20","copy_module_type_declaration$20","copy_open_description$19","copy_include_infos$20","copy_module_binding$20","copy_type_declaration$20","copy_class_declaration$20","copy_class_type_declaration$20","copy_virtual_flag$20","copy_class_infos$20","copy_class_expr$20","copy_class_type$20","copy_class_type_field$20","copy_class_field_kind$20","copy_mutable_flag$20","copy_constructor_declaration$20","copy_module_declaration$20","copy_class_description$20","copy_toplevel_phrase$20","inject_predef_option","ident","migration_error$5","copy_attributes$21","copy_attribute$21","copy_loc$21","copy_option$9","copy_constant$21","copy_rec_flag$21","copy_arg_label$21","copy_override_flag$21","copy_extension$21","copy_payload$21","copy_signature$21","copy_signature_item$21","copy_structure$21","copy_structure_item$21","copy_closed_flag$21","copy_core_type$21","copy_longident$9","copy_label$21","copy_row_field$21","copy_pattern$21","copy_class_structure$21","copy_class_field$21","copy_module_type$21","copy_with_constraint$21","copy_module_expr$21","copy_expression$21","copy_expression_desc$21","copy_value_binding$21","copy_case$21","copy_bool$9","type_declarations$3","recflag","types","copy_type_declaration$21","copy_value_description$21","copy_constructor_arguments$21","copy_extension_constructor$21","copy_variance$21","copy_private_flag$21","copy_type_extension$21","copy_module_type_declaration$21","copy_open_description$20","copy_include_infos$21","copy_module_binding$21","copy_class_declaration$21","copy_class_type_declaration$21","copy_virtual_flag$21","copy_class_infos$21","copy_class_expr$21","copy_class_type$21","copy_class_type_field$21","copy_class_field_kind$21","copy_mutable_flag$21","copy_constructor_declaration$21","copy_label_declaration$21","copy_module_declaration$21","copy_class_description$21","copy_toplevel_phrase$21","extract_predef_option","copy_attributes$22","copy_attribute$22","copy_loc$22","copy_option$10","copy_constant$22","copy_rec_flag$22","copy_arg_label$22","copy_override_flag$22","copy_extension$22","copy_payload$22","copy_signature$22","copy_signature_item$22","copy_structure$22","copy_structure_item$22","copy_closed_flag$22","copy_core_type$22","copy_longident$10","copy_label$22","copy_row_field$22","copy_pattern$22","copy_class_structure$22","copy_class_field$22","copy_module_type$22","copy_with_constraint$22","copy_module_expr$22","copy_expression$22","copy_expression_desc$22","copy_value_binding$22","copy_case$22","copy_bool$10","type_declarations$4","is_nonrec","attr","types$0","copy_type_declaration$22","copy_value_description$22","copy_extension_constructor$22","copy_variance$22","copy_private_flag$22","copy_type_extension$22","copy_module_type_declaration$22","copy_open_description$21","copy_include_infos$22","copy_module_binding$22","copy_class_declaration$22","copy_class_type_declaration$22","copy_virtual_flag$22","copy_class_infos$22","copy_class_expr$22","copy_class_type$22","copy_class_type_field$22","copy_class_field_kind$22","copy_mutable_flag$22","copy_constructor_declaration$22","copy_label_declaration$22","copy_module_declaration$22","copy_class_description$22","copy_toplevel_phrase$22","migration_info","id$7","migration_identity","compose$2","migration_functions","is_undefined","immediate_migration","A","direction","funs","B","To","to2","migration_info$0","migration_info$1","migration_info$2","migration_info$3","migration_info$4","migration_info$5","migration_info$6","migration_info$7","migration_info$8","migration_info$10","migration_info$11","version$1","version$2","version$3","version$4","version$5","version$6","version$7","version$9","version$10","of_ocaml","to_ocaml","of_ocaml_mapper","item","to_ocaml_mapper","parse$1","parse$2","self_1","a$3","a$4","a$5","a$6","pdira_desc$0","pdira_loc$0","pdir_name$0","pdir_arg$0","pdir_loc$0","pmb_name$0","pmb_expr$0","pmb_attributes$0","pmb_loc$0","pvb_pat$0","pvb_expr$0","pvb_attributes$0","pvb_loc$0","b$3","b$4","a$7","a$8","a$9","a$10","a$11","a$12","a$13","a$14","a$15","a$16","a$17","a$18","a$19","a$20","a$21","a$22","a$23","a$24","a$25","a$26","b$5","a$27","a$28","b$6","pstr_desc$0","pstr_loc$0","pmod_desc$0","pmod_loc$0","pmod_attributes$0","pincl_mod$0","pincl_loc$0","pincl_attributes$0","popen_expr$0","popen_override$0","popen_loc$0","popen_attributes$0","pmtd_name$0","pmtd_type$0","pmtd_attributes$0","pmtd_loc$0","pms_name$0","pms_manifest$0","pms_attributes$0","pms_loc$0","pmd_name$0","pmd_type$0","pmd_attributes$0","pmd_loc$0","psig_desc$0","psig_loc$0","pmty_desc$0","pmty_loc$0","pmty_attributes$0","pcf_desc$0","pcf_loc$0","pcf_attributes$0","pcstr_self$0","pcstr_fields$0","b$7","b$8","b$9","b$10","pcl_desc$0","pcl_loc$0","pcl_attributes$0","pci_virt$0","pci_params$0","pci_name$0","pci_expr$0","pci_loc$0","pci_attributes$0","d$1","d$2","pctf_desc$0","pctf_loc$0","pctf_attributes$0","pcsig_self$0","pcsig_fields$0","pcty_desc$0","pcty_loc$0","pcty_attributes$0","ptyexn_constructor$0","ptyexn_loc$0","ptyexn_attributes$0","pext_name$0","pext_kind$0","pext_loc$0","pext_attributes$0","ptyext_path$0","ptyext_params$0","ptyext_constructors$0","ptyext_private$0","ptyext_loc$0","ptyext_attributes$0","pcd_name$0","pcd_args$0","pcd_res$0","pcd_loc$0","pcd_attributes$0","pld_name$0","pld_mutable$0","pld_type$0","pld_loc$0","pld_attributes$0","ptype_name$0","ptype_params$0","ptype_cstrs$0","ptype_kind$0","ptype_private$0","ptype_manifest$0","ptype_attributes$0","ptype_loc$0","pval_name$0","pval_type$0","pval_prim$0","pval_attributes$0","pval_loc$0","pbop_op$0","pbop_pat$0","pbop_exp$0","pbop_loc$0","let$1","ands$0","pc_lhs$0","pc_guard$0","pc_rhs$0","b$11","b$12","b$13","b$14","b$15","b$16","b$17","b$18","b$19","a$29","a$30","b$20","b$21","a$31","a$32","b$22","b$23","a$33","a$34","b$24","c$7","b$25","a$35","a$36","b$26","c$8","b$27","a$37","a$38","b$28","c$9","b$29","a$39","a$40","b$30","c$10","b$31","a$41","a$42","b$32","a$43","a$44","b$33","a$45","a$46","b$34","a$47","a$48","c$11","b$35","a$49","a$50","b$36","c$12","b$37","a$51","a$52","b$38","a$53","a$54","a$55","a$56","b$39","a$57","a$58","b$40","a$59","a$60","b$41","a$61","a$62","b$42","a$63","a$64","b$43","a$65","a$66","b$44","a$67","a$68","a$69","a$70","pexp_desc$0","pexp_loc$0","pexp_loc_stack$0","pexp_attributes$0","ppat_desc$0","ppat_loc$0","ppat_loc_stack$0","ppat_attributes$0","pof_desc$0","pof_loc$0","pof_attributes$0","prf_desc$0","prf_loc$0","prf_attributes$0","ptyp_desc$0","ptyp_loc$0","ptyp_loc_stack$0","ptyp_attributes$0","attr_name$0","attr_payload$0","attr_loc$0","loc_ghost","loc_end","loc_start","loc_start$0","loc_end$0","loc_ghost$0","pos_cnum","pos_bol","pos_lnum","pos_fname","pos_fname$0","pos_lnum$0","pos_bol$0","pos_cnum$0","self_2","self_3","acc$5","acc$6","acc$7","acc$8","acc$9","acc$10","acc$11","acc$12","acc$13","acc$14","acc$15","acc$16","acc$17","acc$18","acc$19","acc$20","acc$21","acc$22","acc$23","acc$24","acc$25","acc$26","acc$27","acc$28","acc$29","acc$30","acc$31","acc$32","acc$33","acc$34","acc$35","acc$36","acc$37","acc$38","acc$39","acc$40","acc$41","acc$42","acc$43","acc$44","acc$45","acc$46","acc$47","acc$48","acc$49","acc$50","acc$51","acc$52","acc$53","acc$54","acc$55","self_4","acc$56","acc$57","acc$58","acc$59","acc$60","acc$61","acc$62","acc$63","acc$64","acc$65","acc$66","acc$67","acc$68","self_5","self_6","lookup$1","drv","compare$112","equal$65","protectx$0","add$27","add_exn$3","find_opt$1","of_alist$5","alist$0","f$12","read_all_into","map$63","fold_right$6","symbol$210","concat$4","is_empty$12","filter_map$9","concat_map$2","assoc_opt","iter$32","is_some$2","map$64","is_empty$13","prefix$2","drop_prefix$0","index_opt","rindex_opt","split_on_char$0","find_opt$2","to_string_path","located","in_file$0","loc$4","raise_errorf$0","enter_module","enter_value$0","module_name$32","enter","enter_opt","self_7","mtd","mb","self_8","var_names_of","ec_enter_module_opt","self_9","var_name","var_name$0","in_binding_ctxt","sexp_of$0","self_10","levenshtein_distance","cutoff","line_min","distance","spellcheck$2","registered_name","names_at_best_distance","best_distance","dist","suggestions","rev_rest","ptyp_any","ptyp_constr","pexp_ident","pexp_constant","pexp_let","pexp_fun","pexp_construct","pexp_variant","pexp_record","include_infos$0","ppat_any","ppat_constant","ppat_construct","ppat_variant","ppat_record","pstr_eval","pstr_value","value_binding$0","pat","short_name","name$96","flatten_exn","unflatten","parse$3","map$66","map_lident","lident","vbs","pexp_tuple","ppat_tuple","pexp_apply","unapplied_type_constr_conv_wit","apply_loc","suffix_n","functor","functor_args","functor$0","functor_path","ident$0","gather_args","subpat","param_label","arg_label","ty_opt","attribute","binding_op","lhs","guard","rhs","pcl_constr","pcl_structure","pcl_fun","pcl_apply","pcl_let","pcl_constraint","pcl_extension","pcl_open","pcf_inherit","pcf_val","pcf_method","pcf_constraint","pcf_initializer","pcf_attribute","pcf_extension","class_infos","virt","class_signature","class_structure","pcty_constr","pcty_signature","pcty_arrow","pcty_extension","pcty_open","pctf_inherit","pctf_val","pctf_method","pctf_constraint","pctf_attribute","pctf_extension","ptyp_var","ptyp_arrow","ptyp_object","ptyp_class","ptyp_alias","ptyp_variant","ptyp_package","ptyp_extension","pdir_string","pdir_int","pdir_ident","pdir_bool","pexp_constant$0","pexp_function","pexp_fun$0","pexp_match","pexp_try","pexp_construct$0","pexp_field","pexp_setfield","pexp_array","pexp_ifthenelse","pexp_sequence","pexp_while","pexp_for","pexp_constraint","pexp_coerce","pexp_send","pexp_new","pexp_setinstvar","pexp_override","pexp_letmodule","pexp_letexception","pexp_assert","pexp_lazy","pexp_poly","pexp_object","pexp_newtype","pexp_pack","pexp_open","pexp_letop","pexp_extension","pexp_unreachable","include_infos","label_declaration","mutable","type","letop","end","ghost","module_binding","module_declaration","pmod_ident","pmod_structure","pmod_functor","pmod_apply","pmod_constraint","pmod_unpack","pmod_extension","module_substitution","pmty_ident","pmty_signature","pmty_functor","pmty_with","pmty_typeof","pmty_extension","pmty_alias","module_type_declaration","otag","oinherit","open_infos","ppat_var","ppat_alias","ppat_constant$0","ppat_interval","ppat_construct$0","ppat_array","ppat_or","ppat_constraint","ppat_type","ppat_lazy","ppat_unpack","ppat_exception","ppat_extension","ppat_open","cnum","rtag","rinherit","psig_value","psig_type","psig_typesubst","psig_typext","psig_exception","psig_module","psig_modsubst","psig_recmodule","psig_modtype","psig_open","psig_include","psig_class","psig_class_type","psig_attribute","psig_extension","pstr_primitive","pstr_type","pstr_typext","pstr_exception","pstr_module","pstr_recmodule","pstr_modtype","pstr_open","pstr_class","pstr_class_type","pstr_include","pstr_attribute","pstr_extension","toplevel_directive","type_declaration","private$0","type_exception","type_extension","constructors","value_binding","value_description","prim","nonrec_type_declaration","mk","lident$0","pexp_tuple$0","ppat_tuple$0","ptyp_tuple","pexp_tuple_opt","ppat_tuple_opt","ptyp_poly","pexp_apply$0","eint$0","echar","estring$0","efloat$0","eint32","eint64","enativeint","ebool","evar$0","pint","pchar","pstring","pfloat","pint32","pint64","pnativeint","pbool","pvar$0","eunit$0","punit","eapply$0","eabstract","esequence","elist$0","plist$0","type_constr_conv$0","unapplied_type_constr_conv","make$9","get$15","fold_dot_suffixes","collapse_after_at","parts","parts$1","parts$0","make$10","matches","matched","create_set","fully_qualified_names","attributes$0","list$5","is_whitelisted","reserve","is_in_reserved_namespaces","ignore_checks","create$74","current_file","string_of_context","get_all_for_context","check_collisions_local","caller","all_for_context","declared_at","context$0","check_collisions","register$1","kind$0","raise_errorf$1","white_list","white_list$0","other_contexts","current_context","a_or_an","rev_others","others","meths$0","nmeths","nvals","pstr","pstr_eval$0","restore_context","backup","incr_matched","parse$4","on_error","param$2","f2$0","nil","symbol$211","symbol$212","map$67","many","single_expr_payload","get_pstr_eval","st","get_pstr_extension","get_psig_extension","get_attributes","get_attribute_if_is_floating_n","dummy_ext","name$97","registrar","declare","pattern","not_seen","mark_as_seen","do_mark_as_seen","get$16","longest_match","longest_match$1","longest_match$0","attr$0","name$98","declare$0","convert$0","check_attribute","item$0","item$1","closed_flag","end_marker","end_marker_str","extract_prefix","remove_loc","remove_loc$0","prev$1","diff_asts","generated","round_trip","with_temp_file","fn1","fn2","ast","cmd$0","parse_string","match_loop","mismatch_handler","source","expected$0","source$0","source$1","expected$1","do_match","get_loc","get_loc$0","to_sexp$0","match_structure","match_signature","class_expr$3","class_field$1","class_type$4","class_type_field$0","expression$0","module_expr$1","module_type$3","pattern$1","signature_item$2","structure_item$1","get_extension","virtual_payload","merge_attributes","registrar$0","with_arg","ext","i$4","convert$1","convert_inline","filter_by_context","expanders","expanders$0","fail$2","split_normal_and_expect","split_normal_and_expect$0","filter$7","extension$0","attr_str_type_decl","expand","attr_sig_type_decl","attr_str_module_type_decl","attr_sig_module_type_decl","attr_str_type_ext","attr_sig_type_ext","attr_str_exception","attr_sig_exception","attr_str_type_decl_expect","attr_sig_type_decl_expect","attr_str_module_type_decl_expe","attr_sig_module_type_decl_expe","attr_str_type_ext_expect","attr_sig_type_ext_expect","attr_str_exception_expect","attr_sig_exception_expect","hook","replace$0","insert_after","map_nodes","super_call","base_ctxt","in_generated_code","extension_point_loc","generated_code","get_group","vals$0","rev_concat","sort_attr_group_inline","sort_attr_inline","context_free_attribute_modific","handle_attr_group_inline","items","expanded_items","expect_items","handle_attr_inline","expanded_item","expect_mismatch_handler","items$0","exp_tds","exp_rf","tds","extra_items","with_extra_items","exp_te","extra_items$0","expect_items$0","exp_ec","ec","extra_items$1","expect_items$1","exp_mtd","extra_items$2","expect_items$2","original_rest","repl","pexp_attributes$1","pexp_attributes$2","expand_constant","rules","special_functions","special_functions$0","extensions","class_expr","class_field","class_type","class_type_field","module_expr","module_type","signature_item","structure_item","ppx_import","attr_sig_exceptions_expect","attr_sig_exceptions","map_node","ctxt$0","ext$0","mk_attr_noloc","hide_attribute","add_arg","loc_fname","perform_checks$0","perform_checks_on_extensions$0","perform_locations_check$0","no_merge","given_through_cli","has_name","all$7","print_caller_id","caller_id","add_ctxt_arg","register_transformation","enclose_impl","enclose_intf","impl","intf","lint_impl","lint_intf","preprocess_impl","preprocess_intf","impl$0","intf$0","preprocess_impl$0","preprocess_intf$0","lint_impl$0","lint_intf$0","enclose_impl$0","enclose_intf$0","instrument","extensions$0","rules$0","aliases","rules$1","new_fn","old_fn","parse_apply_list","mask$1","handle_apply","handle_dont_apply","set_cookie","shared_args","pretty","patt","vars_of","st$2","st$0","vb","st$1","add_dummy_user_for_values","binds_module_names","do_insert_unused_warning_attri","keep_w32_impl","keep_w32_intf","keep_w32_spec","conv_w32_spec","keep_w32_impl$0","keep_w60_impl","keep_w60_intf","keep_w60_spec","names$0","create$75","apply$8","make_noarg","deps$0","deps","arg_names","apply_all","generators","spellcheck_msg","str_type_decl","str_type_ext","str_exception","str_module_type_decl","sig_type_decl","sig_type_ext","sig_exception","sig_module_type_decl","resolve_actual_derivers","collected","resolve_internal","not_supported","spellcheck","resolve","resolve_all","derivers","derivers_and_args","named_generators","actual_deriver_name","dep","dep_name","add$29","extension$1","actual_deriver","invalid_with","generator_name_of_id","f$13","mk_deriving_attr","generator_name","disable_warnings_attribute","warning","inline_doc_attr","wrap_str","hide","warnings$0","warnings$2","warnings$1","wrap_sig","sg$0","sg$1","merge_generators","expand_str_type_decls","expand_sig_type_decls","expand_str_module_type_decl","generators$0","expand_sig_module_type_decl","expand_str_exception","expand_sig_exception","expand_str_type_ext","expand_sig_type_ext","expand_sig","expand_str","rule_str","rule_sig","rule_str_expect","rule_sig_expect","deriving_attr","deriving_attr_expect","rules_type_decl","rules_type_ext","rules_exception","rules_module_type_decl","error$6","unsupported","internal_error","short_string_of_core_type","loc_map$0","lident_loc","prefixed_type_name","observer_name","shrinker_name","pname","ename","gensym","sym","gensyms","loc_list","fn_map_label","f_expr","f_pat","x_expr","x_pat","create_list","salt","location$0","weight_attribute","weight$3","core_type_list","label_decl_list","label_decl","pattern$2","pat_list","expression$1","expr_list","create_list$0","salt$0","location$1","weight_attribute$0","weight$4","core_type_list$0","pattern$3","expression$2","create$76","location$2","pattern$4","expression$3","create$77","location$3","core_type$3","pattern$5","expression$4","compound_sequence","make_compound_expr","field_pats","field_exprs","shrinker_exprs","compound","shrinker_of_core_type","variant$2","variant_type","clauses","Clause","clauses$0","clause","empty$31","lookup$2","of_alist$6","variance_error","create_with_variance","covariant","contravariant","param_list","injectivity","variance","expr$0","pat$0","by_variance_list","covariant_t","tyvar$0","contravariant_t","compound_generator","generator_list","size_expr","size_pat","random_expr","random_pat","compound$0","generator_of_core_type","variant$3","rec_names","make_generator","make_pair","nonrecursive_clauses","nonrec_expr","nonrec_pat","rec_expr","rec_pat","nonrec_exprs","nonrec_pats","rec_exprs","rec_pats","weight_expr","gen_expr","pairs","compound_hash","hash_expr","hash_pat","observer_exprs","body_expr","field_expr","observer_expr","compound$1","observer_of_core_type","variant$4","custom_extension","generator_attribute","obs_env","gen_env","output_type","input_type","generator_of_core_type$0","input_generator","output_observer","unlabelled","observer_of_core_type$0","input_observer","output_generator","generator_impl","observer_impl","shrinker_impl","maybe_mutually_recursive","of_lazy","decls$0","decl","impls","pats","inner_bindings","lazy_expr","covar","contravar","covar$0","contravar$0","type_decl$0","shrinker_intf","generator_intf","observer_intf","sig_type_decl$0","str_type_decl$0","rec_flag$0","generator_extension","observer_extension","shrinker_extension","create$78","fu$0","three_u_squared","sqrt_neg_three_u_squared","potential_xs","alpha_inv","temp","t2_plus_fu","t2_inv","temp$0","try_decode","group$93","bin_shape_t$97","group$94","bin_shape_t$98","group$95","create$79","first_map","three_fourths","curve_eqn","conic_c","conic_d","projection_point","field_to_conic","z0","conic_to_s","s_to_v","s_to_v_truncated","to_group","include","on_conic","on_s","on_v","conic_gen","symbol$213","unsafe_set_uint8","make_alphabet","emap","dmap","default_alphabet","unsafe_set_be_uint16","error_msgf","encode_exn","alphabet$0","emap$0","emit","decode$0","invalid_pad_overflow","get_uint8_or_padding","dmap$0","only_padding","wrap$3","non_residue","sqrt_flagged","x2_is_first","x3_is_first","to_group$0","append$6","field_elements","to_input","packeds","packed","xn","pack_to_fields","acc_n","packed_bits","append$7","field_elements$0","bitstring","pack_bits","max_size","bitstrings","field_bits","rev_fields","remaining_length","remaining_bits","packed_field_elements","pack_to_fields$0","return$25","bind$24","map$68","run$6","u8","u32","many$0","exactly","t_036","t_035","t_037","bits_of_byte","string_of_field","field_of_string","gen_field","gen_input","middle","serialized","len_to_string","u8x32","parser","normalized","v_bitstrings","v_field_elements","bools_equal","bitstring_bits","input_field","packed_fields","final_field_idx","input_bitstrings$3","input_bitstrings","packed_fields$0","packed_fields$1","packed_field","bp","input_bitstrings$0","input_bitstring","bi","packed_fields$2","input_bitstrings$1","packed_fields$3","input_bitstrings$2","of_vector_unsafe","group$96","bin_shape_t$99","bin_write_t$50","bin_read_t$86","t_of_sexp$85","sexp_of_t$93","hash_fold_proofs_verified","path$4","to_int$8","of_int$10","to_input$0","to_input$1","one_hot","typ$10","group$97","bin_shape_t$100","path$5","group$98","bin_shape_t$101","bin_read_t$87","group$99","bin_shape_t$102","bin_size_t$49","bin_write_t$51","bin_read_t$88","group$100","bin_shape_t$103","group$101","bin_shape_t$104","t_of_sexp$86","sexp_of_t$94","compare$113","hash_fold_t$58","hash$49","path$6","equal$66","group$102","bin_shape_t$105","path$7","h$1","to_bits$0","to_yojson$22","symbol$214","of_yojson$15","yojson","to_hex$3","of_hex","sexp_of_t$95","t_of_sexp$87","group$103","bin_shape_t$106","path$8","n_expected","of_tick_field","of_tock_field","to_tick_field","to_tock_field","of_bits_msb","v_proofs_verified","v_domain_log2","domain_log2","proofs_verified","proofs_verified_field","domain_log2_field","domain_log2_value","proofs_verified_value","proofs_verified_mask","four","packed_typ","y7","y6","y5","y4","assert_16_bits","group$104","bin_shape_t$107","challenge","bin_size_t$50","size_of_challenge","bin_write_t$52","write_challenge","bin_read_t$89","of_challenge","v_prechallenge","to_yojson$23","poly_challenge","of_yojson$16","t_of_sexp$88","prechallenge_field","prechallenge_value","sexp_of_t$96","compare$114","cmp_challenge","hash_fold_t$59","hash_fold_challenge","equal$67","prechallenge","typ$11","chal","to_yojson$24","symbol$215","group$105","digest$0","size_of_digest","write_digest","bin_writer_t$42","bin_read_t$90","of_digest","bin_reader_t$42","bin_t$42","version$11","versioned$1","compare$115","of_digest$0","of_digest$1","hash_fold_digest","hash$50","equal$68","path$9","to_bits_unboolean","pack$0","t_constant_opt","spec$0","t_constant_opt$0","spec$1","t_constant_opt$1","spec$2","t_constant_opt$2","spec$3","spec$4","t_const","spec$5","tl_constant_opt","hd_constant_opt","hd$1","dummy2","dummy1","t_constant_opt$3","t_constant_opt$4","b_constant_opt","x_constant_opt","dummy2$0","dummy1$0","inner$0","t_constant_opt$5","t_constant_opt$6","spec$6","t_constant_opt$7","typ$12","flag$0","assert_eq","constant_var","etyp","f_inv","f_inv$0","f_inv$1","f1_inv","f2_inv","f_bool","f_bool$0","f_a","f_a$0","opt_map","f_inv$2","f_inv$3","typ$5","pack$1","typ$13","etyp$0","bp_challenge","group$106","to_hlist$13","zeta_to_domain_size","zeta_to_srs_length","of_hlist$13","to_minimal","group$107","to_hlist$14","branch_data","bulletproof_challenges","combined_inner_product","plonk","of_hlist$14","group$108","map_challenges","scalar","typ$14","dummy_scalar_challenge","constant_typ","bool_typ_of_flag","group$109","bin_shape_t$108","bin_size_t$51","size_of_g1","size_of_bulletproof_challenges","bin_write_t$53","write_g1","write_bulletproof_challenges","bin_read_t$91","of_g1","of_bulletproof_challenges","v_old_bulletproof_challenges","to_hlist$15","old_bulletproof_challenges","of_hlist$15","to_field_elements","g1_to_field_elements","scalar_challenge$0","group$110","to_hlist$16","messages_for_next_wrap_proof","sponge_digest_before_evaluatio","deferred_values","of_hlist$16","bulletproof_challenges$0","bool$2","fp$0","scalar_challenge$1","challenge$0","group$111","to_field_elements_without_inde","app_state_to_field_elements","app_state","bp_chals","digest$1","fp$1","scalar_challenge$2","plonk$0","bp_chals$0","digest$2","messages_for_next_wrap_proof$0","bool$3","fp$2","scalar_challenge$3","challenge$1","group$112","f8","f7","f6","f5","maybe_constant","feature_flags_spec","use","to_data$0","option_map","messages_for_next_step_proof","of_data$1","feature_flags$0","to_minimal$0","proof_state","to_wrap","opt_none","of_wrap","assert_none","assert_false","map_challenges$0","bp_log2","to_data$1","should_finalize","of_data$2","typ$15","to_hlist$17","unfinalized_proofs","of_hlist$17","to_data$2","of_data$3","per_proof","hash_fold_t$60","hash$51","compare$116","t_of_sexp$89","sexp_of_t$97","hash_fold_t$61","hash$52","compare$117","t_of_sexp$90","sexp_of_t$98","equal$69","rhs0$0","lhs0$0","rhs0$1","lhs0$1","rhs0$2","lhs0$2","rhs0$3","lhs0$3","hash_fold_t$62","a0$1","a0$2","a0$3","hash$53","compare$118","t_of_sexp$91","sexp_of_t$99","if_feature","unnormalized_lagrange_basis","vanishes_on_zero_knowledge_and","endo_coefficient","alpha_pow","x_0","x_1","x_2","x_3","x_4","x_5","x_6","x_7","x_8","x_9","x_10","x_11","x_12","x_13","x_14","x_15","x_15$0","x_16","x_15$1","x_16$0","x_17","x_18","x_18$0","x_19","x_18$1","x_19$0","x_20","x_21","x_21$0","x_22","x_21$1","x_22$0","x_23","x_24","x_24$0","x_25","x_24$1","x_25$0","x_26","x_27","x_27$0","x_28","x_27$1","x_28$0","x_29","x_30","x_31","x_32","x_33","x_34","x_35","x_36","x_37","x_38","x_39","x_40","x_41","x_42","x_43","x_44","x_45","x_46","x_47","x_48","constant_term$0","index_terms$0","pow2pow","shifts$0","zetaw","rounds","expand_feature_flags","all_feature_flags","endo","field_of_hex","srs_length_log2","get_eval","zk_polynomial","zeta_to_n_minus_1","feature","lazy_flag","w_to_i","perm_alpha0","ft_eval0","p_eval0","e0_s","zkp","zeta1m1","w_n","ft_eval0$0","ft_eval0$1","nominator","ft_eval0$2","derive_plonk","w0$0","seal","choose","shifted_pow","crs_max_degree","deg","num_shifts","log2s","all_shifts","other_shiftss","all_the_same","which","to_domain","log2_sizes","generator$0","max_log2","mina_alphabet","version_byte","version_byte$0","version_byte$1","version_byte$2","version_byte$3","version_byte$4","version_byte$5","version_byte$6","version_byte$7","version_byte$8","version_byte$9","version_byte$10","version_byte$11","version_byte$12","version_byte$13","version_byte$14","version_byte$15","version_byte$16","version_byte$17","checksum_len","version_string","compute_checksum","ctx0","ctx1","ctx2","first_hash","ctx3","second_hash","checksum","decode_exn","decoded","error_str","check_encoding","to_base58_check","of_base58_check","of_base58_check_exn","to_base64","of_base64","b64","rev_events","log_func","apply_args","ay","ax","x_squared","x_squared$0","ay$0","lambda$0","ax$0","bx","bx$0","by","cx","cx$0","cy","assert_on_curve","typ_unchecked$0","ey","ex","unshift_nonzero","bs0","S","bs0$0","add_pt","windows","g3","pow2s","group_map","unrelated_base","div_unsafe","add_unsafe","lookup_point","b0_and_b1","lookup_one","pc","bs$1","windows_required","bit_pair","with_shifts","unshift","multiscale_known","scale_known","conditional_negation","p_plus_q_plus_p","lambda_1","lambda_2","scale_fast","scale_constant","bs$2","message$4","message$5","comparator$5","compare$119","to_yojson$25","of_yojson$17","sexp_of_t$100","t_of_sexp$92","compare$120","sexpifier$0","v_identifier","v_type","compare$121","to_int","compare$122","t_of_sexp$93","previous_state_hash_field","previous_length_field","genesis_slot_field","genesis_slot_value","previous_length_value","previous_state_hash_value","sexp_of_t$101","v_genesis_slot","v_previous_length","v_previous_state_hash","compare$123","sexpifier$1","v_fork","v_account_creation_fee","v_supercharged_coinbase_factor","v_coinbase_amount","v_pending_coinbase_depth","v_transaction_capacity","v_block_window_duration_ms","v_work_delay","v_ledger_depth","v_sub_windows_per_window","compare$124","header_version","to_yojson$26","compare$125","prefix_len","parse_lexbuf","yojson_parsebuffer","read_prefix","valid_header","valid_header_string","valid_header_with_prefix","fake_prefix","partial_prefix","from_string","initial_prefix_len","write_with_header","expected_max_size_log2","append_data","header_string","length_offset","length_string","length_data_offset","out_channel","true_length","true_length_string","true_length_padding","read_with_header","read_data","file_length","header_json","sexp_to_yojson","info_internal_repr_to_yojson","info$5","info$0","tag$0","info$1","tag$1","infos","trunc_after$0","acc_len","infos$0","rev_json_infos","infos$2","info$3","json_info$0","acc_infos$0","acc_len$1","infos$1","info$2","json_info","acc_infos","acc_len$0","length$2","trunc_after$1","json_infos","info$4","base_pairs","trunc_after","json$0","tag_to_json","jsons","jsons$0","group$113","bin_shape_t$109","path$10","group$114","bin_shape_t$110","path$11","group$115","bin_shape_t$111","path$12","sexp_of_t$102","v_bulletproof","v_evaluations","v_commitments","v1$11","v1$12","v1$13","v1$14","to_kimchi_proof","bulletproof","evaluations","of_kimchi_proof","debug$1","absorb_field","absorb_scalar","mask_g1_opt","absorb$0","absorb$1","ones_vector","first_zero","lowest_128_bits","constrain_low_bits","assert_128_bits","num_bits$6","to_field_checked","bits_msb","nybbles_per_row","rows","nybbles_by_row","to_field_checked$0","to_field_constant","r_2i1","test$0","seal$0","rounds_rev","n_acc_prev","xq1","yq1","s1_squared","xq2","yq2","s3_squared","random_point","endo_inv","gy","gx","endo_to_field","base$0","scalar$0","endo_to_field$0","forbidden_shifted_values","two_to_n","neg_two_to_n","representatives","generate$0","keypair","forbidden_shifted_values$0","other_mod","high$0","check$5","x_eq","b_eq","typ$16","wrap_rounds","forbidden_shifted_values$1","typ$17","t0$0","check$7","typ_unchecked$1","typ$18","input$1","high_entropy_bits","to_the_alpha","add_assign","apply_affine_map","constants","matrix","dotv","copy$0","underlying","last_squeezed","squeeze_field","step_log2","step","mk$24","tock_shifts","tick_shifts","wrap_domains","hash_messages_for_next_step_pr","app_state$0","dlog_plonk_index","dlog_pcs_batch","when_profiling","profiling","tock2","finite_exn","or_infinite_conv","compute_challenge","compute_challenges","field$2","compute_challenge$0","compute_challenges$0","compute_sg","field$3","compute_challenge$1","compute_challenges$1","tock_unpadded_public_input_of_","prev_statement","tick_public_input_of_statement","max_proofs_verified","ft_comm","sigma_comm_last","f_comm","chunked_t_comm","combined_evaluation","fx$0","fx$1","needs_final_permute_if_empty","of_sponge","add_in","i_equals_0","i_equals_j","cond_permute","permute","permuted","consume_pairs","pos_after","add_in_y_after_perm","add_in_y_before_perm","num_pairs","empty_imput","should_permute","consume_all_pending","pos_after$0","recombine","original_sponge","xs_curr","next_index_curr","curr_i","n_pre","filtered","pre$0","filtered_res","opt_res","custom_printf_006","custom_printf_007","custom_printf_008","add_fast","check_finite","p1$0","p2$0","same_x_bool","x1_squared","y1$0","add_fast$0","bits_per_chunk","chunks_needed","scale_fast_msb_bits","y_base","x_base","y_acc","x_acc","x_res","y_res","slopes","accs$0","scale_fast_unpack","scale_fast2","s_odd","s_div_2","s_div_2_bits","chunks_needed$0","actual_bits_used","bits_lsb","scale_fast2$0","Scalar_field","s_parts","custom_printf_005","one$10","lengths","one$11","default$8","hash$54","ro","tock","tick","scalar_chal","evals_combined","dummy_chals","challenges_computed","challenges_computed$0","group$116","bin_shape_t$112","bpcs","bin_size_t$52","size_of_s","size_of_challenge_polynomial_c","size_of_bpcs","bin_write_t$54","write_s","write_challenge_polynomial_com","write_bpcs","bin_read_t$92","of_s","of_challenge_polynomial_commit","of_bpcs","v_app_state","prepare","group$117","bin_shape_t$113","bin_read_t$93","path$13","t_of_sexp$94","sexp_of_t$103","hash_fold_t$63","f$14","read_step_circuit_field_elemen","prover_fe","sponge_params$0","one$12","group_size_in_bits","constant$4","typ$19","inv_exn","symbol$216","symbol$217","symbol$218","negate$2","inv_exn$0","symbol$219","symbol$220","symbol$221","equal$70","t_of_sexp$95","sexp_of_t$104","scale$3","zero$10","symbol$222","negate$3","to_affine_exn$1","of_affine$1","typ$20","typ_unchecked$2","constant$5","symbol$223","double$3","scale$4","to_field_elements$0","scale_inv","negate$4","one$13","if$3","h$2","max$25","hash_fold_vk","group$118","bin_shape_t$114","bin_size_t$53","bin_write_t$55","bin_read_t$94","bin_read_t$95","v_max_proofs_verified","v_actual_wrap_domain_size","v_wrap_index","path$14","versioned$2","func$16","to_repr","wrap_index","actual_wrap_domain_size","of_repr","public$0","wrap_vk","max_proofs_verified_field","actual_wrap_domain_size_field","wrap_index_field","wrap_index_value","actual_wrap_domain_size_value","max_proofs_verified_value","cmp_comm","to_binable$10","of_binable$12","bin_size_t$54","bin_write_t$56","bin_read_t$96","bin_read_t$97","bin_shape_t$115","bin_writer_t$43","bin_reader_t$43","bin_t$43","path$15","g$1","to_hlist$18","of_hlist$18","to_input$2","max_proofs_verified$0","actual_wrap_domain_size$0","bp_chals$1","messages_for_next_wrap_proof$1","fp$3","scalar_challenge$4","challenge$2","group$119","bin_shape_t$116","bin_size_t$55","size_of_messages_for_next_wrap","size_of_messages_for_next_step","v3$6","v2$18","v1$18","size$45","size_of_scalar_challenge","v2$6","v3$2","v2$5","v3$1","v2$4","v6$0","v5$0","v4$0","v2$3","size$46","size_of_f_multi$0","size_of_f_multi","size$47","v4$2","v3$5","v2$17","v1$17","v3$3","v2$7","size$41","v2$8","size$23","size$42","v8$0","v7$0","v6$1","v5$1","v4$1","v3$4","v2$9","size$24","size$25","size$26","v2$10","size$27","size$28","size$29","v2$11","size$30","size$31","v2$12","size$32","size$33","v2$13","size$34","size$35","v2$14","size$36","size$37","v2$15","v1$15","size$38","size$39","v2$16","v1$16","size$40","size$43","size$44","bin_write_t$57","write_messages_for_next_wrap_p","write_messages_for_next_step_p","write_scalar_challenge","write_f_multi$0","write_f_multi","bin_read_t$98","of_messages_for_next_wrap_proo","of_messages_for_next_step_proo","bin_read_t$99","of_scalar_challenge","v_alpha","v_beta","v_gamma","v_zeta","v_joint_combiner","v_range_check0","v_range_check1","v_foreign_field_add","v_foreign_field_mul","v_xor","v_rot","v_runtime_tables","v_feature_flags","v_plonk","v_bulletproof_challenges","v_branch_data","v_deferred_values","v_sponge_digest_before_evaluat","v_messages_for_next_wrap_proof","v_proof_state","v_messages_for_next_step_proof","v_statement","of_f_multi$0","of_f_multi","v_public_input","v_evals$0","v_prev_evals","v_ft_eval1$0","most_recent_width","g0","tick_arr","fields$53","fields$44","fields$45","fields$46","fields$34","fields$35","arg1$3","arg0$3","fields$36","arg1$4","arg0$4","fields$37","arg1$5","arg0$5","fields$38","arg1$6","arg0$6","fields$39","fields$40","arg1$7","arg0$7","fields$41","fields$42","fields$43","fields$47","fields$30","fields$31","fields$32","fields$33","fields$48","fields$54","poly_f_multi$0","poly_f_multi","fields$55","poly_bool","poly_scalar_challenge","fields$27","fields$49","fields$50","fields$51","fields$52","fields$28","fields$25","fields$26","fields$29","fields$56","xs$60","xs$61","arg2$6","arg1$12","arg0$12","xs$62","x$37","xs$39","xs$40","xs$42","x$26","xs$55","xs$56","arg2$5","arg1$11","arg0$11","xs$59","x$36","xs$58","x$35","xs$57","x$34","xs$41","x$25","xs$34","xs$35","arg2$2","xs$38","x$24","xs$26","xs$29","xs$28","xs$27","arg5$0","arg4$0","state$31","state$29","xs$37","xs$30","xs$31","xs$33","xs$32","xs$36","xs$63","x$38","xs$49","xs$50","state$51","arg3$1","arg2$4","arg1$10","arg0$10","xs$54","x$33","xs$53","x$32","xs$43","xs$44","arg2$3","arg1$8","arg0$8","xs$47","x$29","state$50","xs$46","x$28","xs$45","x$27","arg1$9","arg0$9","xs$52","x$31","xs$48","xs$51","x$30","xs$64","x$39","poly_f_multi$1","n$34","cmp_scalar_challenge","n$33","n$38","n$37","a_173","b_174","n$36","a_177","b_178","a_179","b_180","a_181","b_182","a_183","b_184","cmp_f_multi","n$35","t_222","t_221","t_224","t_223","a_225","b_226","t_228","t_227","t_230","t_229","t_042","t_044","t_043","t_046","t_045","t_048","t_047","t_052","t_051","t_054","t_053","t_174","t_173","t_176","t_175","t_180","t_179","t_182","t_181","t_184","t_183","t_186","t_185","a_187","b_188","t_190","t_189","t_192","t_191","t_194","t_193","t_196","t_195","t_198","t_197","t_200","t_199","t_202","t_201","t_204","t_203","t_206","t_205","t_208","t_207","t_210","t_209","t_212","t_211","t_214","t_213","t_216","t_215","a_287","b_288","t_290","t_289","t_292","t_291","statement_field","prev_evals_field","sexp$6","of_bp_chals","of_scalar_challenge$0","proof_state_field","messages_for_next_step_proof_f","deferred_values_field","messages_for_next_wrap_proof_f","old_bulletproof_challenges_fie","old_bulletproof_challenges_val","plonk_field","bulletproof_challenges_field","branch_data_field","alpha_field","beta_field","gamma_field","zeta_field","joint_combiner_field","feature_flags_field","feature_flags_value","joint_combiner_value","zeta_value","gamma_value","beta_value","alpha_value","branch_data_value","bulletproof_challenges_value","plonk_value","messages_for_next_wrap_proof_v","sponge_digest_before_evaluatio$0","deferred_values_value","sexp$5","app_state_field","challenge_polynomial_commitmen$1","old_bulletproof_challenges_fie$0","old_bulletproof_challenges_val$0","challenge_polynomial_commitmen$2","app_state_value","messages_for_next_step_proof_v","proof_state_value","sexp$7","commitments_field","evaluations_field","ft_eval1_field$0","bulletproof_field","bulletproof_value","ft_eval1_value$0","evaluations_value","commitments_value","sexp$8","of_f_multi$2","evals_field$0","of_f_multi$1","public_input_field","public_input_value","evals_value$0","prev_evals_value","statement_value","v_old_bulletproof_challenges$0","v_challenge_polynomial_commitm$0","hsv$43","hash_fold_scalar_challenge","hsv$42","hsv$46","hsv$41","hsv$45","hsv$44","hash_fold_f_multi$0","hash_fold_f_multi","e0$0","e0$1","e0$2","e1$3","e0$3","e1$4","e0$4","e1$5","e0$5","hsv$34","hsv$35","e1$6","e0$6","hsv$36","hsv$37","e1$7","e0$7","hsv$38","hsv$39","hsv$40","a_185","b_186","a_201","b_202","a_205","b_206","a_207","b_208","a_209","b_210","a_211","b_212","t_236","t_235","t_238","t_237","a_239","b_240","t_242","t_241","t_244","t_243","t_060","t_059","t_062","t_061","t_064","t_063","t_066","t_065","t_070","t_069","t_072","t_071","a_219","b_220","t_232","t_231","t_234","t_233","a_235","b_236","t_240","t_239","t_246","t_245","t_248","t_247","t_254","t_253","t_256","t_255","t_262","t_261","t_264","t_263","a_303","b_304","a_297","b_298","t_302","t_301","to_yojson_full","group$120","bin_shape_t$117","bin_size_t$56","bin_write_t$58","bin_read_t$100","bin_read_t$101","path$16","of_yojson$18","to_yojson$27","sexp_of_t$106","t_of_sexp$97","hash$56","hash_fold_t$65","equal$72","compare$127","of_repr$0","to_repr$0","versioned$3","path$17","of_yojson$19","to_yojson$28","to_yojson_full$0","sexp_of_t$107","t_of_sexp$98","hash$57","hash_fold_t$66","equal$73","compare$128","group$121","bin_shape_t$118","bin_size_t$57","bin_write_t$59","bin_read_t$102","bin_read_t$103","path$18","of_yojson$20","to_yojson$29","sexp_of_t$108","t_of_sexp$99","hash$58","hash_fold_t$67","equal$74","compare$129","of_repr$1","to_repr$1","versioned$4","path$19","read_wrap_circuit_field_elemen","sponge_params$1","squeeze_field$0","one$14","group_size_in_bits$0","constant$6","typ$22","if$4","scale$5","inv_exn$1","symbol$224","symbol$225","symbol$226","negate$5","negate$6","square$3","inv_exn$2","symbol$227","symbol$228","symbol$229","assert_square$2","assert_r1cs$2","equal$76","t_of_sexp$101","sexp_of_t$110","scale$6","random$2","zero$11","symbol$230","negate$7","to_affine_exn$2","of_affine$2","multiscale_known$0","typ$23","typ_unchecked$3","constant$7","symbol$231","double$4","scale$7","to_field_elements$1","scale_inv$0","negate$8","g$2","if$5","h$3","pad_vector","pad_challenges","chalss","pad_accumulator","hash_messages_for_next_wrap_pr","of_proof","dummy_messages_for_next_wrap_p","full_state","s0","hash_messages_for_next_wrap_pr$0","challenge_polynomial","num_possible_domains","all_possible_domains","to_bits_unsafe","absorb_shifted","absorb_shifted$0","print_g","print_w","print_chal","print_bool","scalar_to_field","assert_n_bits","lowest_128_bits$0","squeeze_challenge","squeeze_scalar","bullet_reduce","gammas","prechallenges","gammas_i","term_and_challenge","left_term","right_term","equal_g","choose_key","nones","maybes","none_sum","some_sum","some_is_yes","b_g","maybe_sum","maybe_is_yes","is_yes","no_2","maybe_2","yes_2","no_1","maybe_1","yes_1","b_x","lagrange","which_branch","scaled_lagrange","lagrange_with_correction","base_and_correction","pr","h_precomp","finite","batch","without_bound","with_bound","keep","point","check_bulletproof","pcs_batch","advice","combined_polynomial","scale_fast$0","lr_prod","uc","p_prime","cq","b_u","z_1_g_plus_b_u","z2_h","absorb$2","iter2","j1","zeta_1","gamma_1","beta_1","alpha_1","j0","zeta_0","gamma_0","beta_0","alpha_0","j1$0","j1$1","var_to_fields$0","assert_eq_plonk","index_to_field_elements","g_opt","simulate_optional_sponge_with_","sponge_state_before","state_before","incrementally_verify_proof","Max_proofs_verified","actual_proofs_verified_mask","step_domains","sg_old","openings_proof","sg_old$0","sample","sample_scalar","index_sponge","index_digest","without","absorb_g","public_input$0","non_constant_part","constant_part","corr","correction","x_hat","x_hat$0","compute_joint_combiner","absorb_sorted_1","absorb_sorted_2_to_4","absorb_sorted_5","z$2","sponge2$0","joint_combiner_if_true$0","sponge2","joint_combiner_if_true","joint_combiner$2","compute_lookup_table_comm","second_column","runtime$0","has_runtime","second_column_with_runtime","runtime$1","runtime$2","has_runtime$0","sum$1","second_with_runtime","rest_rev","comm$0","scaled_acc","comm$1","has_comm","scaled_acc$0","has_acc","comm$2","scaled_acc$1","comm$3","has_comm$0","scaled_acc$2","acc_with_comm","joint_combiner$0","joint_combiner$1","lookup_table_comm$0","lookup_table_comm$1","b_lookup_table_comm","lookup_sorted_minus_1","aggreg$0","sponge$0","sponge_before_evaluations","sigma_comm_init","ft_comm$0","len_1_add","len_1","len_2_add","len_2","len_3_add","len_4_add","len_5_add","len_5","len_6_add","len_6","append_chain","undo_chunking","mask_evals","challenge_polynomial$0","actual_evaluation","pt_to_n","pt_n_acc","shift1","shift2","map_plonk_to_field","finalize_other_proof","Proofs_verified","sg_olds","sg_evals","sg_evals2","sg_evals1","challenge_digest","xi_actual","r_actual","xi_actual$0","xi$0","xi_correct","plonk_minimal","zeta_n","zetaw_n","combined_evals","evals2","evals1","ft","sg_evals$0","actual_combined_inner_product","combined_inner_product_correct","challenge_poly","b_actual","b_correct","plonk_checks_passed","to_hlist$19","of_hlist$19","to_hlist$20","of_hlist$20","shift$0","typ$24","create$82","find$17","lookup_compiled","other_id","lookup_side_loaded","lookup_basic","wrap_domains$0","wrap_vk$1","wrap_key$0","ephemeral","wrap_key","wrap_vk$0","set_ephemeral","eph","prover","add_exn$4","print_fp","add_opt","constant_part$0","rr$0","xi_acc","p_is_finite","acc_is_finite","xi_acc$0","p_is_finite$0","is_finite","xi_acc$1","assert_eq_deferred_values","lagrange_commitment","public_input_commitment_dynami","lagrange_commitment$0","select_curve_points","points_for_domain","points","sponge_after_index","receive","domain$0","z_comm$0","t_comm$0","vanishing_polynomial","should_square","side_loaded_domain","max_n","vanishing_polynomial$0","d_unchecked","a_002","b_003","pow2_pow","squeeze_challenge$0","domain_for_compiled","unique_domains","which_log2","actual_width_mask","opt_sponge","a_008","b_009","a_010","b_011","a_006","b_007","xi$1","b_used","state_to_field_elements","after_index","hash_messages_for_next_step_pr$0","not_opt","hash_inputs","sponge$1","accumulation_verifier","accumulator_verification_key","prev_accumulators","new_accumulator","is_base_case","lookup_parameters","wrap_domain","wrap_verification_key","statement","unfinalized","bulletproof_challenges_actual","bulletproof_success","to_hlist$21","prev_challenge_polynomial_comm","prev_proof_evals","wrap_proof","of_hlist$21","to_hlist$22","of_hlist$22","shift$1","dummy$1","one_chal","typ$25","dummy$2","create$83","r$4","start$3","clock","is_odd","wrap_main","full_signature","pi_branches","step_keys","step_widths","Req","Max_widths_by_slot","messages_for_next_wrap_proof_d","which_branch$0","prev_proof_state","step_plonk_index","prev_step_accs","old_bp_chals","new_bulletproof_challenges","wrap_domain_indices","old_bulletproof_challenges$0","old_bulletproof_challenges$1","finalized","prev_messages_for_next_wrap_pr","sacc","max_local_max_proofs_verified","rough_domains","domains$0","ret_conv_inv","main$0","range_check_table_used","combined_lookup_table_length","lookup_table_length_log2","group$122","bin_shape_t$119","path$20","group$123","bin_shape_t$120","bin_size_t$58","bin_write_t$60","bin_read_t$104","bin_read_t$105","v_constraints","path$21","poly_polyComm","versioned$5","of_repr$2","to_binable$11","of_binable$13","path$22","f_debug","num_choices","choices_length","num_choices$0","dummy_step_domains","dummy_step_widths","dummy_step_keys","compare$131","right_026","left_025","right_014","left_013","t_018","t_017","t_020","t_019","right_022","left_021","right_004","left_003","right_030","left_029","t_034","right_006","left_005","right_008","left_007","right_012","left_011","t_of_sexp$102","t_of_sexp$103","sexp_of_t$111","or_infinity_to_yojson","poly_comm_to_yojson","poly_caml_g","verifier_index_to_yojson","poly_fr","poly_srs","poly_poly_comm","step_verification_key_to_yojso","wrap_verification_key_to_yojso","get_proof","verification_key","for_vk","set_proof","constant_term$1","index_terms$1","tick_rounds","AB","challenge_polys","which_eval","sgs","step_vk","actual_proofs_verified","tick_plonk_minimal","tick_combined_evals","tick_domain","tick_env","prechals","shift_value","compute_feature_flags","true_opt","false_opt","test_feature_flags_configs","runtest","deferred_values$0","x_hat_evals","full_features","deferred_values_typ","deferred_values$1","no_public_input","gate_example","public_input_1","public_input_2","public_input2","public_input1","example","actual_feature_flags$0","expand_deferred","tick_field","sc","plonk0","step_domain","w$0","challenges_digest","lookup_final_terms","xi_chal","r_chal","combined_inner_product_actual","to_shifted","verify_heterogenous","non_chunking","least_wrap_domain","actual_wrap_domain","accumulator_check","batch_verify_inputs","A_value","prepared_statement","dlog_check","comm_chals","verify_promise","a_value","create$84","proofs_verifieds","auxiliary_typ","var_to_field_elements","value_to_field_elements","rule","self_width","extract_lengths","len_ms","len_ns","branches$0","local_branches_length","local_signature_length","heights","widths","requests","output_typ","ld$0","ds$0","ns1","ns2","ln1","ln2","feature_flagss","feature_flagss$0","ln2$0","ln1$0","ns2$0","ns1$0","prev_proof_typs","output_typ$0","input_typ$0","auxiliary_var","ret_var","previous_proof_statements","ret_value","auxiliary_value","previous_proof_statement","tags$0","stmts","proof_must_verify","public_input$1","previous_proof_statements$0","prevs","unfinalized_proofs_unextended","actual_wrap_domains","stmts$0","stmt","proofs$0","prevs$0","datas","messages_for_next_wrap_proofs","unfinalizeds","actual_wrap_domains$0","should_verify","unfinalizeds$0","messages_for_next_wrap_proofs$0","datas$0","actual_wrap_domain$0","actual_wrap_domain$1","sponge_digest","prev_messages_for_next_step_pr","verified","self_data","own_domains","proof_cache","next_state","Maxes","prevs_length","self_dlog_plonk_index","self_dlog_vk","prev_vars_length","prev_values_length","expand_proof","dlog_vk","dlog_index","must_verify","Local_max_proofs_verified","deferred_values_computed","x_hat_1","zeta$0","alpha$0","zetaw$0","tock_domain","tock_combined_evals","tock_plonk_minimal","true$1","false$1","tock_env","b_polys","ft_eval","shifted_value","statements_with_hashes","x_hats","witnesses","prev_proofs","return_value","unfinalized_proofs$0","unfinalized_proofs_extended","extract_from_proofs","Extract","return_value$0","messages_for_next_step_proof_p","messages_for_next_wrap_proof_p","respond","prev_proof_requests","prev_proof_stmts","prev_proof_stmts$0","ws","prev_proofs$0","witnesses$0","x_hats$0","statements_with_hashes$0","unfinalized_proofs$1","domain_index","to_fold_in","next_proof","prev_evals","next_statement","conv_inv","promise_or_error","next_statement_hashed","auxiliary_inputs","create_proof","proof_cache$0","proof_json","to_string$44","to_string$45","s_p","header_read","s_v","read_or_generate","k_p","k_v","dirty","k_v$0","pk$0","vk$0","header_version_field","constraint_constants_field","commits_field","length_field","commit_date_field","constraint_system_hash_field","identifying_hash_field","type_field","identifier_field","identifier_value","type_value","sub_windows_per_window_field","ledger_depth_field","work_delay_field","block_window_duration_ms_field","transaction_capacity_field","pending_coinbase_depth_field","coinbase_amount_field","supercharged_coinbase_factor_f","account_creation_fee_field","fork_field","fork_value","account_creation_fee_value","supercharged_coinbase_factor_v","coinbase_amount_value","pending_coinbase_depth_value","transaction_capacity_value","block_window_duration_ms_value","work_delay_value","ledger_depth_value","sub_windows_per_window_value","mina_field","marlin_field","marlin_value","mina_value","identifying_hash_value","constraint_system_hash_value","commit_date_value","length_value","commits_value","constraint_constants_value","header_version_value","v_identifying_hash","v_constraint_system_hash","v_commit_date","v_commits","v_constraint_constants","v_header_version","v_marlin","v_mina","t_022","to_string$46","to_string$47","s_p$0","read_or_generate$0","kp","vk$1","symbol$232","generate_or_load","pad_messages_for_next_wrap_pro","messages_len","maxes_len","maxes$0","maxes$1","compile_with_wrap_main_overrid","disk_keys$0","override_wrap_domain","override_wrap_main","Branches","constraint_constants","self$0","self$1","a_value_to_fields","a_var_to_fields","a_value_to_fields$0","a_var_to_fields$0","conv_irs","snark_keys_header","constraint_system_hash","prev_varss_length","prev_varss_n","padded","enabled","step_data","cache_handle","accum_dirty","disk_keys","cs_hash","ks","step_keypairs","step_vks","wrap_main$0","wrap_main$1","wrap_requests","self_id","disk_key_prover","wrap_disk_key","wrap_pk","computed_domain_size","ks$0","step_pk","step_vk$0","proof$0","which_index","tweak_statement","tweak_statement$0","prev_statement_with_hashes","next_statement$0","next_accumulator","provers","cache_handle$0","verify_promise$0","wrap_main_dummy_override","dummy_id","write","of_compiled","in_circuit","permanent","verify$0","srs_precomputation","compile_promise","return_early_digest_exception","compile","proof_module","adjust_provers","dummy_constraints","b0$0","example$0","prev_input","self_correct","s_neg_one","b_neg_one","b0$1","recursion_proof","recursion_input","no_recursion_proof","no_recursion_input","no_recursive_input","no_recursive_proof","prev_proof","s_neg_one$0","b_neg_one$0","b0$2","example2","example1","s_neg_one$1","b_neg_one$1","b0$3","example2$0","example1$0","b0$4","blinding_value","b0$5","dummy_proof","pairing_vk","tick_combined_evals$0","combined_inner_product$0","overwritten_prechals","chals$0","sg_new","proof_with_stmt","assocs","example_proof","example_input","example_proof$0","example_input$0","example_proof$1","example_input$1","side_loaded_tag","maybe_features","params$1","v_u","v_u_over_2","v_y","v_projection_point","v_conic_c","v_a","v_b","v_spec","group_map_params","arg_typ","gen_arg","sexp_of_arg","test1","test2","mul_field","real_part","x_over_y","let_syntax_016","let_syntax_017","let_syntax_018","let_syntax_012","let_syntax_013","let_syntax_014","let_syntax_015","if_value","cond","Shifted","sigma_count","two_to_the_i_plus_1","result_with_shift","let_syntax_021","let_syntax_022","let_syntax_019","let_syntax_020","func$17","length$27","get$17","set$13","length$28","get$18","set$14","bools","v_of_list","pack_value","var_of_bits","var_to_triples","unpack_var","var_of_field_unsafe","unpack_value","compare_var","increment_if_var","increment_var","equal_var","assert_equal_var","pack_int","boolean_assert_lte","assert_decreasing","nth_bit","apply_mask","pack_unsafe","n_ones","total_length","assert_num_bits_upper_bound","masked","size_in_bits_size_in_bits","num_bits_upper_bound_unchecked","leading_zeroes","num_bits_upper_bound_unpacked","x_unpacked","num_bits_upper_bound","decreasing","handle_with$0","handle_with","resp","correct","t_of_sexp$105","sexp_of_t$113","hash_fold_t$69","compare$132","t_of_sexp$106","sexp_of_t$114","bin_size_t$59","bin_write_t$61","bin_read_t$106","bin_read_t$107","empty$32","equal$78","typ$26","t_of_sexp$107","sexp_of_t$115","add$31","typ$27","negate$9","constant$10","if$8","double$5","scale$8","sum$4","make_checked$1","params$2","block_cipher$1","add_assign$1","copy$10","to_bits$1","update$5","hash$60","pow2$1","to_bits$2","params$3","hash$61","pack_input","pack_input$0","prefix_to_field","params$4","rounds_full$0","initial_ark$0","rounds_partial$0","to_the_alpha$1","hash$62","pack_input$1","to_the_alpha$2","seal$1","add_assign$2","apply_affine_map$0","copy$11","params$5","length_in_bytes$1","padding_char","create$85","protocol_state","protocol_state_body","account","side_loaded_vk","zkapp_account","zkapp_payload","zkapp_body_mainnet","zkapp_body_testnet","merge_snark","base_snark","transition_system_snark","signature_testnet","signature_mainnet","signature_other","chain_name","receipt_chain_user_command","receipt_chain_zkapp","epoch_seed","vrf_message","vrf_output","vrf_evaluation","pending_coinbases","coinbase_stack_data","coinbase_stack_state_hash","coinbase_stack","coinbase","checkpoint_list","zkapp_precondition","zkapp_precondition_account","zkapp_precondition_protocol_st","account_update_account_precond","account_update_cons","account_update_node","account_update_stack_frame","account_update_stack_frame_con","zkapp_uri","zkapp_event","zkapp_events","zkapp_actions","zkapp_memo","zkapp_test","derive_token_id","raise$1","to_option$0","array_length","export$0","jsoo_exports","symbol$233","lookup$3","of_js","salt$1","salt$2","salt_legacy","cached","cached$0","signature_kind","crypto_hash_prefix","hash_prefix","hash_prefix$0","triple_string","test_to_triples","arbitrary_string","with_randomness","print_digest","check_serialization","known_good_digest","group$124","bin_shape_t$121","group$125","field$4","group$126","create$86","bin_read_t$108","v_x","v_is_odd","bin_size_t$60","bin_write_t$62","to_hlist$23","of_hlist$23","gen$2","group$127","bin_shape_t$122","path$23","version$12","group$128","bin_shape_typ","group$129","bin_shape_t$123","create$87","bin_read_t$109","bin_read_t$110","bin_reader_t$44","bin_size_t$61","bin_write_t$63","bin_writer_t$44","bin_t$44","group$130","size_of_pk","write_pk","bin_writer_t$45","bin_read_t$111","of_pk","bin_reader_t$45","bin_t$45","version$13","equal_key","compare_key$2","hash_fold_t$70","hash$63","to_yojson$32","of_yojson$22","of_pk$0","of_public_key","hash_fold_t$71","uncompressed","path$24","group$131","bin_shape_typ$0","group$132","public_key","create$88","bin_read_t$112","key_to_string","compress$1","empty$33","to_input$3","to_input_legacy","typ$28","var_of_t","equal$79","odd_eq","to_input$4","decompress","y_parity","decompress_exn","compare$133","t_026","t_025","hash_fold_t$72","of_yojson$23","compressed","to_yojson$33","sexp_of_t$117","t_of_sexp$109","path$25","group$133","bin_shape_t_tagged$0","create$89","bin_read_t$113","bin_size_t$62","bin_write_t$64","group$134","bin_shape_t$124","bin_size_t$63","bin_write_t$65","bin_writer_t$46","bin_read_t$114","bin_read_t$115","bin_reader_t$46","bin_t$46","compare$134","version$14","t_of_sexp$110","upperbound","path$26","group$135","bin_shape_typ$1","bin_size_typ","bin_write_typ","bin_read_typ","group$136","bin_shape_t_tagged$1","create$90","bin_read_t$116","bin_read_t$117","bin_reader_t$47","bin_size_t$64","bin_write_t$66","bin_writer_t$47","bin_t$47","is_even","derive","k_prime","r_pt","verifier","final_check","e_pk","s_g_e_pk","y_even","r_correct","verifies","assert_verifies","ry_even","network_id_mainnet","network_id_testnet","make_derive","network_id","private_key","network_id_mainnet$0","derive_for_mainnet","derive_for_testnet","make_hash","py","px","hash$64","hash_for_mainnet","hash_for_testnet","hash_checked","make_derive$0","derive$0","derive_for_mainnet$0","derive_for_testnet$0","make_hash$0","hash$65","hash_for_mainnet$0","hash_for_testnet$0","hash_checked$0","gen_legacy","gen_chunked","pubkey","const_typ","group$137","bin_shape_t$125","path$27","t_of_sexp$111","public_key_field","private_key_field","private_key_value","public_key_value","sexp_of_t$118","v_private_key","v_public_key","compare$135","pk2","pk1","of_private_key_exn","gen$3","t_of_sexp$112","sexp_of_t$119","compare$136","group$138","bin_shape_t$126","path$28","t_of_sexp$113","sexp_of_t$120","gen$4","to_field$3","typ$29","one_half","is_pos","constant$11","pos$70","if$9","to_yojson$34","poly_hash","poly_account","group$139","bin_size_t$65","size_of_hash","size_of_account","bin_write_t$67","write_hash","write_account","bin_read_t$118","of_account","arg_1$1","arg_2","arg_3","t_of_sexp$114","sexp_of_t$121","to_yojson$35","of_yojson$24","equal$80","cmp_hash","cmp_account","cmp_hash$0","cmp_account$0","a_021$0","b_022$0","cmp_account$2","cmp_account$1","cmp_hash$2","cmp_hash$1","t_of_sexp$115","sexp_of_t$122","hash$66","group$140","bin_shape_t$127","indexes_field","depth_field","tree_field","tree_value","depth_value","indexes_value","v_tree","v_depth","v_indexes","merkle_root","add_path","account_id","build_tree","h_r","h_l","path$1","find_index_exn","aid","custom_printf_043","custom_printf_044","acct","go_right","expected_kind","custom_printf_045","path_exn","v_favorite_number","name_field","favorite_number_field","favorite_number_value","name_value","data_hash","favorite_number","prune_hash_branches","let_syntax_055","hex_char_to_bits4","bits4_to_hex_char","bits_by_n","bitsn","bits_by_8s","of_unpackable","padding_bit","bytes$0","of_field$3","pack$2","bytes_rev","of_public_key_compressed","to_public_key_compressed","pk_compressed_roundtrip_test","hex_key","field0","field_key_attr","make_lident_cmp","dhall_type_of_core_type","Ast_builder","dhall_type_fun","params$0","mod_path","dhall_type_fun$0","nm$0","mod_path$0","dhall_variant_from_constructor","ctor_decl","tys_expr","dhall_field_from_label_declara","generate_dhall_type","dhall_type","ctor_decls","label_decls","ty_name","generate_dhall_types","type_decls","attributes$1","str_type_decl$1","group$141","bin_shape_t$128","group$142","bin_shape_typ$2","group$143","bin_shape_t$129","path$29","of_yojson$25","to_yojson$36","t_of_sexp$116","sexp_of_t$123","hash_fold_t$73","func$18","compare$137","equal$81","version$15","bin_size_t$66","bin_write_t$68","bin_read_t$119","bin_read_t$120","path$30","group$144","bin_shape_t_tagged$2","create$91","bin_read_typ$0","bin_read_typ$1","bin_size_typ$0","bin_write_typ$0","to_yojson$37","of_yojson$26","t_of_sexp$117","sexp_of_t$124","hash_fold_t$74","hash$67","hashable$3","add$32","sub$9","div$2","rem$8","max_value$3","logand$1","logor$1","logxor$1","shift_left$7","shift_right$7","of_int$11","to_int$9","of_ms$0","to_ms$0","of_string$45","to_string$48","zero$12","one$15","lognot$6","succ$9","pred$9","compare$138","equal$82","max$26","min$25","pp$28","symbol$234","symbol$235","symbol$236","symbol$237","symbol$238","to_uint64","of_uint64","group$145","bin_shape_t$130","group$146","bin_shape_typ$3","group$147","bin_shape_t$131","path$31","of_yojson$27","to_yojson$38","t_of_sexp$118","sexp_of_t$125","hash_fold_t$75","func$19","compare$139","equal$83","bin_size_t$67","bin_write_t$69","bin_read_t$121","bin_read_t$122","path$32","group$148","bin_shape_t_tagged$3","create$92","to_yojson$39","of_yojson$28","t_of_sexp$119","sexp_of_t$126","length_in_bits$0","hash_fold_t$76","hash$68","hashable$4","add$33","sub$10","div$3","rem$9","max_int$3","logand$2","logor$2","logxor$2","shift_left$8","shift_right$8","of_int$12","to_int$10","of_int64$3","to_int64$4","of_string$46","to_string$49","zero$13","one$16","lognot$7","succ$10","pred$10","compare$140","equal$84","max$27","min$26","pp$29","symbol$239","symbol$240","symbol$241","symbol$242","symbol$243","to_bigint$0","to_uint32","of_uint32","actual_packed","range_check$0","range_check_flag","field_typ","div_mod","is_succ","xy","yx","x_gte_y","y_gte_x","a_lte_b","succ_if","subtract_unpacking_or_zero","neg_res","underflow","sub_or_zero","group$1","read_version$0","max_value","u32_1","u32_2","zero$14","symbol$244","diff_or_zero","u32_slot","u32_span","u32_sum","diff$0","to_uint32$0","of_uint32$0","zero$15","equal$85","zero$16","succ$11","group$149","bin_shape_t$132","sgn","t_fields_annots","t_toplevel_annots","t_of_sexp$120","of_magnitude","of_sgn","magnitude_field","sgn_field","sgn_value","magnitude_value","sexp_of_t$127","v_sgn","v_magnitude","sgn$0","precision_exp","to_mina_string","whole","num$1","num_stripped_zeros","num$0","num_stripped_zeros$0","of_mina_string_exn","decimal","decimal_length","pack_var","var_to_bits$0","var_to_bits$1","var_to_input","var_to_input_legacy","modulus_as_field","double_modulus_as_field","range_check_flagged","adjustment_factor","out_of_range","t_adjusted","unit_to_nano","to_mina_int","sub_flagged","add_flagged","add_signed_flagged","u64","of_nanomina_int","of_mina_int","of_nanomina_int_exn","of_mina_int_exn","typ_to_hlist","typ_of_hlist","compare_magnitude","sgn_to_bool","to_input_legacy$0","add_flagged$0","of_unsigned","to_fee","of_fee","repr_typ","create_var","mag","to_input_legacy$1","of_unsigned$0","let_syntax_025","let_syntax_026","add_flagged$1","let_syntax_027","let_syntax_028","yv","xv","res_magnitude","res_value","let_syntax_029","let_syntax_030","let_syntax_031","let_syntax_032","let_syntax_034","let_syntax_035","let_syntax_036","let_syntax_037","let_syntax_038","to_fee$0","of_fee$0","sub_flagged$0","y_lt_x","add_flagged$2","add_signed","add_signed_flagged$0","expect_failure","expect_success","qc_test_fast","custom_printf_040","custom_printf_041","custom_printf_042","custom_printf_046","after_format","custom_printf_050","custom_printf_047","custom_printf_048","custom_printf_049","formatted","has_decimal","trailing_zero","trailing_zero$0","custom_printf_051","custom_printf_052","currency_length","bin_writer_typ","bin_reader_typ","bin_typ","bin_size_t_tagged","bin_write_t_tagged","bin_writer_t_tagged","bin_read_t_tagged","bin_read_t_tagged$0","v_version","v_t","bin_reader_t_tagged","bin_t_tagged","minimum_user_command_fee","default_transaction_fee","default_snark_worker_fee","fee","add_fee","sexp_of_magnitude","magnitude_of_sexp","to_uint64$0","of_uint64$0","to_nanomina_int","pack_var$0","equal_var$0","var_to_input_legacy$0","var_to_input$0","var_of_t$0","to_nanomina_int$0","to_mina_int$0","of_nanomina_int$0","of_mina_int$0","of_nanomina_int_exn$0","of_mina_int_exn$0","of_uint64$1","to_uint64$1","to_mina_string$0","of_mina_string_exn$0","of_bits$0","gen_incl$0","validate_bound$0","validate_ubound$0","validate_lbound$0","clamp$0","clamp_exn$0","between$0","length_in_bits$1","dhall_type$0","compare_magnitude$0","magnitude_of_sexp$0","sexp_of_magnitude$0","to_amount","add_amount","add_amount_flagged","sub_amount","sub_amount_flagged","add_signed_amount_flagged","to_amount$0","uint64_to_z","uint64_of_z","max_uint64_z","fits_uint64","check_q","den","of_q","of_q_exn","make_exn","to_uint64$2","to_uint64_exn","fr","sub_flagged$1","scale_exn","sexp_of_fee","sexp_of_weight","sub_flagged_checked","u_checked","m_checked","union$6","diff$4","single$0","empty$34","csingle","cseq","cadd","cupper","clower","calpha","cdigit","calnum","eRR","menhir_discard","menhir_env","lexer","menhir_errorcase","menhir_stack","menhir_s","menhir_stack$0","menhir_s$0","menhir_s$1","menhir_stack$1","menhir_s$2","menhir_stack$2","menhir_s$3","menhir_stack$3","menhir_s$4","menhir_stack$4","menhir_s$5","menhir_stack$5","menhir_s$6","menhir_stack$6","menhir_s$7","menhir_stack$7","menhir_s$8","menhir_stack$8","menhir_s$9","menhir_stack$9","menhir_s$10","menhir_stack$10","menhir_s$11","menhir_stack$11","menhir_s$12","menhir_stack$12","menhir_s$13","menhir_stack$13","menhir_s$14","menhir_stack$14","menhir_s$15","menhir_stack$15","menhir_s$16","menhir_stack$16","menhir_s$17","menhir_stack$17","menhir_s$18","menhir_stack$18","menhir_s$19","menhir_stack$19","menhir_s$20","menhir_stack$20","menhir_s$21","menhir_stack$21","menhir_s$22","menhir_stack$22","menhir_s$23","menhir_stack$23","menhir_s$24","menhir_stack$24","menhir_s$25","menhir_stack$25","menhir_s$26","menhir_stack$26","menhir_s$27","menhir_stack$27","menhir_s$28","menhir_stack$28","menhir_s$29","menhir_stack$29","menhir_s$30","menhir_stack$30","menhir_s$31","menhir_stack$31","menhir_s$32","menhir_stack$32","menhir_s$33","menhir_stack$33","menhir_s$34","menhir_stack$34","menhir_s$35","menhir_stack$35","menhir_s$36","menhir_stack$36","menhir_s$37","menhir_stack$37","menhir_s$38","menhir_stack$38","menhir_s$39","menhir_stack$39","menhir_s$40","menhir_stack$40","menhir_s$41","menhir_stack$41","menhir_s$42","menhir_stack$42","menhir_s$43","menhir_stack$43","menhir_fail","menhir_goto_field","menhir_goto_selection","menhir_goto_operation","menhir_goto_definition","tok$0","menhir_run1$0","menhir_run2$0","menhir_run3$0","menhir_run4$0","menhir_run78$0","menhir_goto_loption_selection_","_6","_3","_5","_4","_3$0","_1$0","menhir_reduce40","menhir_env$0","menhir_env$1","menhir_run5","_2$0","_4$0","_2$1","_3$1","_2$2","menhir_run6","menhir_run7","menhir_run8","menhir_run10","menhir_run11","menhir_run12","menhir_run9","menhir_run14","menhir_reduce30","menhir_goto_value_parser_const","menhir_reduce24","menhir_goto_option_default_val","menhir_reduce36","menhir_run87","menhir_run93","menhir_goto_typ","menhir_reduce34","menhir_goto_value_parser_value","menhir_reduce26","menhir_goto_loption_arguments","menhir_run20","menhir_reduce32","tok$1","menhir_reduce28","menhir_run98","menhir_run99","menhir_run100","menhir_run97","menhir_run27","menhir_run103","menhir_run104","menhir_run105","menhir_goto_value","menhir_goto_list_directive","tok$2","tok$3","menhir_goto_loption_variable_d","menhir_env$2","menhir_run26","menhir_run28","menhir_run29","menhir_run34","menhir_run25","menhir_run32","menhir_run33","menhir_run36","menhir_goto_enum_value","menhir_reduce38","menhir_run22","menhir_goto_option_name","menhir_goto_name","menhir_env$3","tok$4","v$23","tok$11","tok$12","v$24","menhir_goto_option_type_condit","tok$7","menhir_env$5","tok$8","v$15","v$16","v$17","tok$9","menhir_env$6","tok$10","v$18","v$19","v$20","v$21","v$22","tok$5","menhir_env$4","tok$6","menhir_run13","menhir_goto_keyword_name","menhir_goto_fragment_name","menhir_goto_optype","menhir_run1","menhir_run2","menhir_run3","menhir_run4","menhir_run78","token$0","lcp","string_of_pos","parse$5","find$18","map$70","map_s","map_p","enum_value","deprecated","coerce","enum$0","string_of_const_value","string_of_arg_typ","eval_arg_error","arg_name","field_type","found_str","guid","non_null","value_to_const_value","variable_map","props","props$0","eval_arg","coerced","eval_arglist","arglist","key_values","arglist$0","arglist$1","const_value","arglist$2","arglist$3","schema","mutations","subscriptions","mutation_name","subscription_name","query_name","obj$0","io_field","abstract_field","subscription_field","enum$1","non_null$0","union$0","interface$0","add_type","abstract_typ","obj_of_subscription_obj","string$0","guid$0","skip_directive","include_directive","unless_visited","arg_list_types","memo$0","memo$1","arg_types","argtyp","argtyp$0","argtyp$1","argtyp$2","visited$0","reducer","opt$2","types_of_schema","args_to_list","no_abstracts","enum_value$0","input_value","interfaces","arg_list","directive","schema$0","subs","mut","add_built_in_fields","schema_field","matches_type_condition","type_condition","abstract$0","should_include_field","directives","arguments$0","eval_directive","arguments$1","alias_or_name","merge_selections","matching","selection_sets","selection_set","collect_fields","include_field","spread","fragment","condition","matches_type_condition$0","field_from_object","field_from_subscription_object","coerce_or_null","src$0","map_fields_with_order","error_to_json","extension_props","error_response","resolve_fields","execution_order","query_field","resolve_field","resolve_info","resolver","unlifted_value","resolved","present","lifted_value","src$1","data_to_json","errors$0","field_error","to_response","msg$1","subscribe","subs_field","source_stream","execute_operation","query","data_errs","collect_fragments","validate_fragment_selection","fragment_map","selection","fragment_spread","validate_fragment","inline_fragment","validate_fragments","fragment_names","cycle","collect_and_validate_fragments","fragments","collect_operations","select_operation","operation_name","operations","execute","variables","default_variables","default_value","variables$0","execution_ctx","find$19","find_string","t_toplevel_annots$0","sexp_of_t$128","v_doc","of_annots","t_fields_annots$0","sexpifier$2","v_deprecated","v_skip","compare$141","of_annots$0","annots","under_to_camel","prefix_us","ws$0","name_under_to_camel","add_field","skip_data","f_input","annotations","ref_as_pipe","inner_acc","graphql_arg_coerce","graphql_arg_fields","creator_input","finish","creator","add_field$0","t_field","finish$0","graphql_fields_accumulator","graphql_fields","nullable_graphql_fields","contramap","arg_to_yojson_rec","arg_to_yojson","acc_obj","graphql_query_accumulator","scalar$1","int$6","string$4","wrapped","option$1","list$6","inner_query","bind$25","map$71","initial_buffer","upstream_flushed","downstream_flushed$0","output_closed","blocked_read","ivar$1","iter$34","message_of_field_error","extensions_of_field_error","parse_query","introspection_query","graphql_arg","nullable_graphql_arg","graphql_arg_accumulator","graphql_creator","graphql_query","raw_server","init_acc","merge_acc","force_breaks1","force_breaks2","force_breaks1$0","force_breaks","children","new_children","param$3","acc0","acc1","new_x1","acc2","new_x2","query_schema","query_for_all","hit_server","hit_server_query","hit_server_args","bar","skipped","foo_hello","bar$0","skipped$0","foo_hello$0","make_creator","foo_hello_fun","skipped_fun","bar_fun","compile_acc","compile_acc$0","foo_hello_gen","compile_acc$1","skipped_gen","compile_acc$2","bar_gen","manual_typ","manual_typ$0","foo","foo$0","make_creator$0","foo_fun","foo_gen","manual_typ$1","derived","manual_typ$2","typ_input","generated_typ","generated_arg_typ","generated_query","to_json_accumulator","int$7","string$5","list$7","add_field$1","finished_obj","finish$1","of_json","int$8","string$6","list$8","of_json_creator","full_derivers","group$150","bin_shape_t$133","t_fields_annots$1","t_toplevel_annots$1","t_of_sexp$121","of_h","hash_field","hash_value","sexp_of_t$129","v_hash","hash$69","data$3","hash$70","data$4","sexp_of_t$130","compare$142","cmp_h","hash$71","map$72","to_key$0","to_entry","to_doc_entry","docs","leaf_type","js_layout","js_layout_accumulator","js_type","invalid_scalar_to_string","raise_invalid_scalar","except","iso_string","uint64","uint32","js_only","js_leaf","leaf","js_record","entries","global_slot_since_genesis","global_slot_since_hard_fork","global_slot_span","a_opt","static_length$0","static_length","iso","iso_record","of_record","to_record","record_deriver","add_field$2","new_field","finish$2","accumulator","needs_custom_js","balance_change","sign_to_string","sign_of_string","sgn_fun","magnitude_fun","magnitude_gen","sgn_gen","inner_query$0","json_to_safe","print_schema","full","query_top_level","json_to_string_gql","arg_query","out_query","in_schema","out_schema","run_query","unwrap","verification_key_with_hash","hash_fun","data_fun","hash_gen","baz","foo1","baz$0","foo1$0","baz_fun","foo1_fun","foo1_gen","baz_gen","v_nothing","v_field","nothing$0","nothing_fun","field_fun","compile_acc$3","field_gen","compile_acc$4","nothing_gen","public_key$0","obj$1","compile_acc$5","public_key_gen","group$151","bin_shape_t$134","bin_writer_t$48","bin_reader_t$48","bin_t$48","version$16","func$20","path$33","group$152","bin_shape_typ$4","group$153","bin_shape_t$135","create$93","bin_read_t$123","bin_read_t$124","bin_reader_t$49","bin_size_t$68","bin_write_t$70","bin_writer_t$49","bin_t$49","to_decimal_string","to_bytes","curr","curr$0","var_to_hash_packed","var_of_hash_packed","var_to_field","group$154","state_hash","bin_writer_t$50","bin_reader_t$50","bin_t$50","hash$72","path$34","of_string$47","group$155","bin_shape_t$136","pending_coinbase_depth","init$28","genesis_timestamp_of_string","of_time","compare$143","poly_length","poly_delta","poly_genesis_state_timestamp","group$156","bin_shape_t$137","genesis_state_timestamp","to_hlist$24","slots_per_sub_window","slots_per_epoch","of_hlist$24","compare$144","group$157","bin_shape_t$138","path$35","compare$145","compiled$0","max_epoch_length","hash_typ","time_offset","setting_enabled","disable_setting_offset","enable_setting_offset","set_time_offset","tm","env_offset","get_time_offset","var_of_field","pack_value$0","unpack_value$0","unpack_var$0","compare_var$0","increment_var$0","increment_if_var$0","assert_equal_var$0","var_of_field$0","var_of_field_unsafe$0","of_time_span","to_time_span","to_time_ns_span","of_time_ns_span","int64_ns","to_time_exn","t_int64","now$1","field_var_to_unpacked","diff_checked","unpacked_to_number","to_string_exn","of_time_ns","to_system_time","to_string_system_time_exn","of_string_exn","time_beginning","time_end","time_beginning_int64","time_end_int64","int64_time_span","pack_value$1","unpack_value$1","pack_var$1","unpack_var$1","compare_var$1","increment_var$1","increment_if_var$1","assert_equal_var$1","equal_var$1","var_of_field$1","var_of_field_unsafe$1","of_time$0","to_time_exn$0","now$2","field_var_to_unpacked$0","epoch$0","of_span_since_epoch","diff_checked$0","modulus$0","unpacked_to_number$0","to_string_exn$0","of_time_ns$0","to_system_time$0","to_string_system_time_exn$0","of_string_exn$0","ctrl","cancel_ivar","span$0","timeout","cancel","peek","remaining_time","current_time","time_elapsed","await$0","timeout_duration","time_controller","await_exn","group$158","bin_read_t$125","bin_read_t$126","t_of_sexp$122","to_list$15","to_numbered_list","def2","def1","map$73","fold$19","gen$5","inner_gen","of_array$4","map_gens","gen_division_generic","dirichlet","n_float","uniform","gen_division","symbol$245","zero$18","symbol$246","symbol$247","gen_division_currency","root_gen","node_gen","this$0","next_elem","field_of_bool","of_bigstring_exn","to_bigstring$0","to_field_unsafe","gen_non_default","to_field_unsafe$0","t_014","t_013","of_public_key$0","token_id","owner","token_id$0","derive_token_id$1","tid2","tid1","pk_equal","tid_equal","tid_else","pk_else","tid_then","pk_then","create$94","equal$86","group$159","t_of_sexp$123","of_slot","of_slot_span","of_balance","of_amount","initial_minimum_balance_field","cliff_time_field","cliff_amount_field","vesting_period_field","vesting_increment_field","vesting_increment_value","vesting_period_value","cliff_amount_value","cliff_time_value","initial_minimum_balance_value","group$160","timing","t_of_sexp$124","path$36","vesting_increment","vesting_period","cliff_amount","cliff_time","initial_minimum_balance","is_timed","vesting_increment$0","vesting_period$0","cliff_amount$0","cliff_time$0","initial_minimum_balance$0","is_timed$0","t_fields_annots$2","t_toplevel_annots$2","deriver$1","vesting_increment_fun","vesting_period_fun","cliff_amount_fun","cliff_time_fun","initial_minimum_balance_fun","is_timed_fun","is_timed_gen","initial_minimum_balance_gen","cliff_time_gen","cliff_amount_gen","vesting_period_gen","vesting_increment_gen","slot_span_one","balance_unused","amount_unused","to_input$5","typ$30","deriver$2","group$161","group$162","field$5","version$17","group$163","bin_shape_t_tagged$4","create$95","bin_read_t$127","bin_size_t$69","bin_write_t$71","group$164","bin_shape_t$139","bin_size_t$70","bin_write_t$72","bin_read_t$128","t_of_sexp$125","sexp_of_t$131","compare$146","hash_fold_t$77","group$165","bin_shape_t$140","bin_read_t$129","bin_read_t$130","bin_reader_t$51","bin_size_t$71","bin_write_t$73","bin_writer_t$51","bin_t$51","path$37","group$166","bin_shape_typ$5","group$167","bin_shape_t_tagged$5","create$96","bin_read_t$131","bin_size_t$72","bin_write_t$74","authorization","group$168","bin_shape_t$141","path$38","sexp_of_t$132","gen$6","dummy_signature","let_syntax_297","signature_deriver","t_fields_annots$3","t_toplevel_annots$3","signature$3","signature$4","deriver$3","signature_fun","proof_fun","proof_gen","signature_gen","signature","to_record$0","of_record$0","deriver$4","control","typ$31","to_input$6","t_fields_annots$4","t_toplevel_annots$4","hash$73","data$5","hash$74","data$6","deriver$5","to_yojson$40","symbol$248","group$169","id$8","bin_size_t$73","bin_write_t$75","bin_read_t$132","t_of_sexp$126","sexp_of_t$133","equal$87","compare$147","hash_fold_t$78","path$39","to_yojson$41","symbol$249","group$170","bin_size_t$74","bin_write_t$76","bin_read_t$133","t_of_sexp$127","sexp_of_t$134","compare$148","hash_fold_t$79","path$40","group$171","bin_shape_typ$6","bin_size_typ$1","bin_write_typ$1","bin_read_typ$2","group$172","create$97","to_yojson$42","symbol$250","default_caller","of_string$48","equal$88","deriver$6","group$173","to_hlist$25","fee_excess_r","fee_token_r","fee_excess_l","fee_token_l","of_hlist$25","typ$32","token_typ","fee_typ","group$174","bin_shape_t$142","path$41","rebalance","fee_token_l$0","fee_token_r$0","fee_excess_l$0","zero$19","of_one_or_two","excesses","unreduced","gen_single","group$175","group$176","group$177","token_id$1","group$178","create$98","group$179","bin_shape_t$143","path$42","group$180","bin_shape_t$144","path$43","group$181","bin_shape_typ$7","group$182","bin_shape_t_tagged$6","create$99","dummy$4","to_yojson$43","of_yojson$29","t_of_sexp$128","sexp_of_t$135","equal$89","compare$149","group$183","ledger","bin_writer_t$52","bin_reader_t$52","bin_t$52","hash$75","path$44","group$184","bin_shape_t$145","write_controller","of_controller","of_controller$0","of_controller$1","hash_fold_controller","path$45","sexp_of_t$136","gen_for_proof_authorization","gen_for_signature_authorizatio","gen_for_none_given_authorizati","to_string$50","of_string$49","to_hlist$26","signature_sufficient","signature_necessary","of_hlist$26","to_input$7","encode$0","decode$1","to_input$8","t$9","typ$33","to_input$9","check$10","group$185","bin_shape_t$146","controller","to_hlist$27","set_timing","set_voting_for","increment_nonce","set_token_symbol","edit_action_state","set_zkapp_uri","set_verification_key","set_permissions","set_delegate","send","access","edit_state","of_hlist$27","set_timing$0","set_voting_for$0","increment_nonce$0","set_token_symbol$0","edit_action_state$0","set_zkapp_uri$0","set_verification_key$0","set_permissions$0","set_delegate$0","receive$0","send$0","access$0","edit_state$0","t_fields_annots$5","t_toplevel_annots$5","set_timing$1","set_voting_for$1","increment_nonce$1","set_token_symbol$1","edit_action_state$1","set_zkapp_uri$1","set_verification_key$1","set_permissions$1","set_delegate$1","receive$1","send$1","access$1","edit_state$1","set_timing$2","set_voting_for$2","increment_nonce$2","set_token_symbol$2","edit_action_state$2","set_zkapp_uri$2","set_verification_key$2","set_permissions$2","set_delegate$2","receive$2","send$2","access$2","edit_state$2","to_input$10","group$186","permissions","size_of_permissions","write_permissions","of_permissions","v_edit_state","v_access","v_send","v_receive","v_set_delegate","v_set_permissions","v_set_verification_key","v_set_zkapp_uri","v_edit_action_state","v_set_token_symbol","v_increment_nonce","v_set_voting_for","v_set_timing","t_of_sexp$129","edit_state_field","access_field","send_field","receive_field","set_delegate_field","set_permissions_field","set_verification_key_field","set_zkapp_uri_field","edit_action_state_field","set_token_symbol_field","increment_nonce_field","set_voting_for_field","set_timing_field","set_timing_value","set_voting_for_value","increment_nonce_value","set_token_symbol_value","edit_action_state_value","set_zkapp_uri_value","set_verification_key_value","set_permissions_value","set_delegate_value","receive_value","send_value","access_value","edit_state_value","of_permissions$0","compare$150","hash_fold_t$80","path$46","to_input$11","typ$34","to_input$12","auth_required","deriver$7","set_timing_fun","set_voting_for_fun","increment_nonce_fun","set_token_symbol_fun","edit_action_state_fun","set_zkapp_uri_fun","set_verification_key_fun","set_permissions_fun","set_delegate_fun","receive_fun","send_fun","access_fun","edit_state_fun","edit_state_gen","access_gen","send_gen","receive_gen","set_delegate_gen","set_permissions_gen","set_verification_key_gen","compile_acc$6","set_zkapp_uri_gen","compile_acc$7","edit_action_state_gen","compile_acc$8","set_token_symbol_gen","compile_acc$9","increment_nonce_gen","compile_acc$10","set_voting_for_gen","compile_acc$11","set_timing_gen","digest_length_byte","memo_length","max_digestible_string_length","digest_tag","bytes_tag","is_digest","create_by_digesting_string_exn","ndx","create_by_digesting_string","create_from_value_exn","create_from_bytes_exn","create_from_bytes","create_from_string_exn","create_from_string","to_raw_exn","to_raw_bytes_exn","of_raw_exn","base58_check","memo_var","aux$0","arr$0","group$187","bin_shape_t$147","path$47","group$188","bin_shape_typ$8","group$189","bin_shape_t$148","path$48","group$190","bin_shape_typ$9","group$191","bin_shape_t_tagged$7","create$100","generator_013","to_yojson$44","group$192","bin_shape_t$149","t_of_sexp$130","sexp_of_t$137","path$49","sexp_of_t$138","compare$151","predicate","source_not_present","receiver_not_present","amount_insufficient_to_create_","cannot_pay_creation_fee_in_tok","source_insufficient_balance","source_minimum_balance_violati","receiver_already_exists","token_owner_not_caller","overflow$0","global_excess_overflow","local_excess_overflow","local_supply_increase_overflow","global_supply_increase_overflo","signed_command_on_zkapp_accoun","zkapp_account_not_present","update_not_permitted_balance","update_not_permitted_access","update_not_permitted_timing","update_not_permitted_delegate","update_not_permitted_app_state","update_not_permitted_verificat","update_not_permitted_action_st","update_not_permitted_zkapp_uri","update_not_permitted_token_sym","update_not_permitted_permissio","update_not_permitted_nonce","update_not_permitted_voting_fo","zkapp_command_replay_check_fai","fee_payer_nonce_must_increase","fee_payer_must_be_signed","account_balance_precondition_u","account_nonce_precondition_uns","account_receipt_chain_hash_pre","account_delegate_precondition_","account_action_state_precondit","account_app_state_precondition","predicate$0","source_not_present$0","receiver_not_present$0","amount_insufficient_to_create_$0","cannot_pay_creation_fee_in_tok$0","source_insufficient_balance$0","source_minimum_balance_violati$0","receiver_already_exists$0","token_owner_not_caller$0","overflow$1","global_excess_overflow$0","local_excess_overflow$0","local_supply_increase_overflow$0","global_supply_increase_overflo$0","signed_command_on_zkapp_accoun$0","zkapp_account_not_present$0","update_not_permitted_balance$0","update_not_permitted_access$0","update_not_permitted_timing$0","update_not_permitted_delegate$0","update_not_permitted_app_state$0","update_not_permitted_verificat$0","update_not_permitted_action_st$0","update_not_permitted_zkapp_uri$0","update_not_permitted_token_sym$0","update_not_permitted_permissio$0","update_not_permitted_nonce$0","update_not_permitted_voting_fo$0","zkapp_command_replay_check_fai$0","fee_payer_nonce_must_increase$0","fee_payer_must_be_signed$0","account_balance_precondition_u$0","account_nonce_precondition_uns$0","account_receipt_chain_hash_pre$0","account_delegate_precondition_$0","account_action_state_precondit$0","account_app_state_precondition$0","account_proved_state_precondit","account_is_new_precondition_un","protocol_state_precondition_un","unexpected_verification_key_ha","valid_while_precondition_unsat","incorrect_nonce","invalid_fee_excess","cancelled","fold$20","predicate_fun","source_not_present_fun","receiver_not_present_fun","source_insufficient_balance_fu","receiver_already_exists_fun","token_owner_not_caller_fun","overflow_fun","global_excess_overflow_fun","local_excess_overflow_fun","zkapp_account_not_present_fun","update_not_permitted_balance_f","update_not_permitted_access_fu","update_not_permitted_timing_fu","update_not_permitted_delegate_","update_not_permitted_nonce_fun","fee_payer_nonce_must_increase_","fee_payer_must_be_signed_fun","account_proved_state_precondit$0","account_is_new_precondition_un$0","protocol_state_precondition_un$0","unexpected_verification_key_ha$0","valid_while_precondition_unsat$0","incorrect_nonce_fun","invalid_fee_excess_fun","cancelled_fun","group$193","bin_shape_t$150","path$50","to_yojson$45","group$194","bin_shape_t$151","path$51","to_display","display","empty$36","of_single_failure","is_empty$14","add$34","failure","describe","group$195","bin_shape_t$152","path$52","min$27","max$28","of_enum","equal$90","gen$7","equal$91","of_t","test_mask","payment","stake_delegation","fee_transfer","coinbase$0","typ$35","to_hlist$28","is_user_command","is_coinbase","is_fee_transfer","is_stake_delegation","is_payment","of_hlist$28","typ$36","equal$92","payment$0","stake_delegation$0","fee_transfer$0","coinbase$1","to_bits_t","to_bits_var","bool_var","bit3","bit2","bit1","acc3","add_if_true","base_typ","typ$37","unpacked_t_of_t","t_of_unpacked_t","unpacked","bits_t_of_t","t_of_bits_t","unpacked_typ","test_predicate","one_of","one$17","default$9","group$196","group$197","group$198","global_slot","nonce","token_id$2","public_key$1","group$199","create$101","to_hlist$29","valid_until","fee_payer_pk","of_hlist$29","symbol$251","group$200","bin_shape_t$153","bin_size_t$75","bin_write_t$77","bin_writer_t$53","bin_read_t$134","bin_read_t$135","v_fee","v_fee_payer_pk","v_nonce","v_valid_until","v_memo","bin_reader_t$53","bin_t$53","t_of_sexp$131","fee_field","fee_payer_pk_field","nonce_field","valid_until_field","memo_field","memo_value","valid_until_value","nonce_value","fee_payer_pk_value","fee_value","sexp_of_t$139","hash_fold_t$81","path$53","group$201","bin_shape_t$154","bin_size_t$76","bin_write_t$78","bin_read_t$136","v_fee_token","t_of_sexp$132","fee_token_field","fee_token_value","sexp_of_t$140","hash_fold_t$82","path$54","group$202","bin_shape_typ$10","group$203","common","create$102","let_syntax_073","gen$8","group$204","bin_shape_t$155","bin_size_t$77","bin_write_t$79","bin_read_t$137","v_receiver_pk","v_amount","v_new_delegate","t_of_sexp$133","new_delegate_field","new_delegate_value","receiver_pk_field","amount_field","amount_value","receiver_pk_value","sexp_of_t$141","hash_fold_t$83","path$55","group$205","bin_shape_t$156","bin_size_t$78","bin_write_t$80","bin_read_t$138","v_source_pk","v_token_id","v_delegator","t_of_sexp$134","delegator_field","delegator_value","source_pk_field","token_id_field","token_id_value","source_pk_value","sexp_of_t$142","hash_fold_t$84","path$56","group$206","bin_shape_typ$11","group$207","bin_shape_t_tagged$8","create$103","to_yojson$46","poly_common","poly_body","symbol$252","group$208","bin_shape_t$157","bin_size_t$79","size_of_common","size_of_body","bin_write_t$81","write_common","write_body","bin_read_t$139","of_common","of_body","v_common","v_body","t_of_sexp$135","common_field","body_field","body_value","common_value","sexp_of_t$143","hash_fold_t$85","hash_fold_common","hash_fold_body","compare$152","cmp_common","cmp_body","group$209","common$0","group$210","create$104","to_hlist$30","of_hlist$30","group$211","bin_shape_t$158","bin_size_t$80","bin_write_t$82","bin_read_t$140","t_of_sexp$136","sexp_of_t$144","hash_fold_t$86","path$57","group$212","bin_shape_t$159","bin_size_t$81","bin_write_t$83","bin_read_t$141","t_of_sexp$137","sexp_of_t$145","hash_fold_t$87","path$58","group$213","bin_shape_typ$12","group$214","bin_shape_t_tagged$9","create$105","bin_read_t$142","read_version$6","read_version$5","read_version$3","read_version$2","read_version$4","read_version$1","bin_size_t$82","bin_write_t$84","create$106","fee$0","fee_payer","nonce$0","receiver","payload$0","new_delegate","max_amount","receiver_pk","generator_012","t_to_hlist","source_pk","t_of_hlist","typ$38","to_hlist$31","fee_token","of_hlist$31","typ$39","of_user_command_payload","max_amount_without_overflow","poly_payload","poly_pk","poly_signature","size_of_payload","size_of_signature","write_payload","write_signature","bin_writer_payload","bin_writer_pk","bin_writer_signature","of_payload","of_signature","v_payload","v_signer","v_signature","bin_reader_payload","bin_reader_pk","bin_reader_signature","bin_payload","bin_pk","bin_signature","cmp_payload","cmp_pk","cmp_signature","payload_field","signer_field","signature_field","signature_value","signer_value","payload_value","hash_fold_payload","hash_fold_pk","hash_fold_signature","account_access_statuses","acct_id","accounts_referenced","bin_writer_typ$0","bin_reader_typ$0","bin_typ$0","bin_size_t_tagged$0","bin_write_t_tagged$0","bin_writer_t_tagged$0","bin_read_t_tagged$1","bin_read_t_tagged$2","bin_reader_t_tagged$0","bin_t_tagged$0","poly_public_key","bin_read_typ$3","bin_read_typ$4","cmp_public_key","signer","payment_payload","stake_delegation_payload","payload$1","bin_size_typ$2","bin_write_typ$2","bin_writer_typ$1","bin_read_typ$5","bin_read_typ$6","bin_reader_typ$1","bin_typ$1","bin_size_t_tagged$1","bin_write_t_tagged$1","bin_writer_t_tagged$1","bin_read_t_tagged$3","bin_read_t_tagged$4","bin_reader_t_tagged$1","bin_t_tagged$1","bin_writer_typ$2","bin_reader_typ$2","bin_typ$2","bin_size_t_tagged$2","bin_write_t_tagged$2","bin_writer_t_tagged$2","bin_read_t_tagged$5","bin_read_t_tagged$6","bin_reader_t_tagged$2","bin_t_tagged$2","bin_reader_t$5","bin_writer_t$5","bin_t$5","top_tag_versions","bin_read_top_tagged_to_latest","has_insufficient_fee","fee_payer$0","fee_excess","receiver$0","valid_until$0","sign_payload","fake_sign","gen_inner","fee_range","create_body","min_fee","max_fee","with_random_participants","gen_inner$0","min_amount","sign_type","gen_with_random_participants","gen_with_random_participants$0","payment_with_random_participan","stake_delegation_with_random_p","account_info","n_commands","currency_splits","command_senders","account_nonces","sender","rest_splits","this_split","sender_pk","sender_pk$0","splits","command_splits","command_splits$0","spend_all","amount_to_spend","swap_idx","group$11","bin_writer_t$6","bin_reader_t$6","bin_t$6","hash_fold_t$3","to_valid_unsafe","bin_size_typ$3","bin_write_typ$3","bin_writer_typ$3","bin_read_typ$7","bin_read_typ$8","bin_reader_typ$3","bin_typ$3","bin_size_t_tagged$3","bin_write_t_tagged$3","bin_writer_t_tagged$3","bin_read_t_tagged$7","bin_read_t_tagged$8","bin_reader_t_tagged$3","bin_t_tagged$3","bin_read_t$11","bin_read_t$12","bin_reader_t$7","bin_size_t$5","bin_write_t$5","bin_writer_t$7","bin_t$7","check_signature","public_keys","check_valid_keys","create_with_signature_checked","gen_test","check_only_for_signature","forget_check","filter_by_participant","user_commands","user_command","group$215","receipt_chain_hash","bin_writer_t$54","bin_reader_t$54","bin_t$54","hash$76","path$59","empty$38","group$216","bin_shape_t$160","bin_writer_t$55","bin_reader_t$55","bin_t$55","hash$77","path$60","group$217","bin_shape_t$161","path$61","group$218","bin_shape_t$162","to_hlist$32","of_hlist$32","to_input$13","of_option$0","to_option$1","map$74","typ$40","option_typ","lazy_option_typ","group$219","bin_shape_t$163","bin_size_t$83","bin_write_t$85","bin_read_t$143","t_of_sexp$138","sexp_of_t$146","compare$153","hash_fold_t$88","t_of_sexp$139","sexp_of_t$147","map$75","to_option$2","of_option$1","is_set","is_keep","deriver$8","gen$9","gen_a","typ$41","optional_typ","to_input$14","to_input$15","group$220","bin_shape_t$164","bin_size_t$84","bin_write_t$86","bin_read_t$144","t_of_sexp$140","sexp_of_t$148","compare$154","hash_fold_t$89","sexp_of_t$149","compare$155","gen$10","to_option$3","of_option$2","deriver_base","deriver$9","to_input$16","typ$42","ignore","group$221","bin_shape_t$165","path$62","to_hlist$33","of_hlist$33","encode$1","decode$2","invalid_public_key","digest_vk","dummy_vk_hash","t_of_sexp$141","sexp_of_t$150","equal$93","hash_fold_t$90","to_binable$12","of_binable$14","path$63","group$222","bin_shape_t$166","bin_size_t$85","bin_write_t$87","bin_read_t$145","typ$43","group$223","t_of_sexp$142","path$64","to_input$17","deriver$10","t_of_sexp$143","sexp_of_t$151","hash$78","empty_hash","push_hash","push_event","push_to_data_as_hash","events","pop_from_data_as_hash","events$0","typ$44","to_input$18","deriver$11","hash$79","typ$45","var_to_input$1","to_input$19","deriver$12","empty$39","max_length$1","check$11","t_of_sexp$144","to_binable$13","of_binable$15","path$65","group$224","t_of_sexp$145","of_app_state","of_vk","of_zkapp_version","of_zkapp_uri","verification_key_field","zkapp_version_field","action_state_field","last_action_slot_field","proved_state_field","zkapp_uri_field","zkapp_uri_value","proved_state_value","last_action_slot_value","action_state_value","zkapp_version_value","verification_key_value","to_hlist$34","proved_state","last_action_slot","action_state","zkapp_version","of_hlist$34","zkapp_uri$1","zkapp_uri$2","proved_state$0","last_action_slot$0","action_state$0","zkapp_version$0","verification_key$0","app_state$1","t_fields_annots$6","t_toplevel_annots$6","group$225","bin_shape_t$167","bin_size_t$86","bin_write_t$88","bin_read_t$146","v_verification_key","v_zkapp_version","v_action_state","v_last_action_slot","v_proved_state","v_zkapp_uri","t_of_sexp$146","sexp_of_t$152","path$66","zkapp_uri_non_preimage","hash_zkapp_uri_opt","zkapp_uri_opt","hash$80","typ$46","zkapp_uri_to_input","digest$4","default_digest","action_state_deriver","list_5","gen_uri","app_state$2","seq_state","last_sequence_slot","group$226","bin_shape_t$168","bin_writer_t$56","bin_reader_t$56","bin_t$56","hash$81","path$67","max_length$2","check$12","t_of_sexp$147","to_binable$14","of_binable$16","path$68","num_bits$7","to_field$4","byte_index","to_input$20","of_field$4","chars","typ$47","typ$48","var_to_input$2","group$227","t_of_sexp$148","of_id","of_token_symbol","of_nonce","of_receipt_chain_hash","of_delegate","of_state_hash","of_timing","of_zkapp_opt","token_symbol_field","balance_field","receipt_chain_hash_field","delegate_field","voting_for_field","timing_field","permissions_field","zkapp_field","zkapp_value","permissions_value","timing_value","voting_for_value","delegate_value","receipt_chain_hash_value","balance_value","token_symbol_value","zkapp","permissions$0","timing$0","voting_for","delegate","receipt_chain_hash$0","nonce$1","balance$1","token_symbol","token$1","public_key$2","zkapp$0","permissions$1","timing$1","voting_for$0","delegate$0","receipt_chain_hash$1","nonce$2","balance$2","token_symbol$0","token_id$3","public_key$3","fold$21","public_key_fun","token_id_fun","token_symbol_fun","balance_fun","nonce_fun","receipt_chain_hash_fun","delegate_fun","voting_for_fun","timing_fun","permissions_fun","zkapp_fun","to_hlist$35","of_hlist$35","t_fields_annots$7","t_toplevel_annots$7","group$228","bin_shape_t$169","path$69","delegate$1","group$229","zkapp_opt","bin_shape_t$170","bin_size_t$87","bin_write_t$89","bin_read_t$147","bin_read_t$148","v_token_symbol","v_balance","v_receipt_chain_hash","v_delegate","v_voting_for","v_timing","v_initial_minimum_balance","v_cliff_time","v_cliff_amount","v_vesting_period","v_vesting_increment","v_permissions","v_zkapp","t_of_sexp$149","sexp_of_t$153","equal$94","cmp_amount","path$70","check$13","path$71","to_yojson$47","poly_field","poly_controller","poly_amount","symbol$253","arg10$0","arg9$0","arg8$0","arg7$0","arg6$1","arg5$1","arg4$2","arg3$2","arg6$0","arg4$1","hash_zkapp_account_opt","delegate_opt","digest$5","typ$49","account$0","zkapp$1","typ$50","hash$82","create$107","min_balance_at_slot","min_balance_past_cliff","global_slot_u32","cliff_time_u32","vesting_period_u32","num_periods","vesting_decrement","has_permission","has_permission_to_send","has_permission_to_receive","gen_with_constrained_balance","vesting_end","gen_any_vesting_range","let_syntax_102","vesting_slots","vesting_periods_count","max_cliff_amt","to_vest","vi","group$230","bin_shape_t$171","ledger_hash","t_fields_annots$8","t_toplevel_annots$8","to_hlist$36","total_currency","of_hlist$36","hash$83","total_currency$0","hash$84","total_currency_fun","total_currency_gen","group$231","bin_shape_t$172","path$72","group$232","bin_shape_t$173","bin_writer_t$57","bin_reader_t$57","bin_t$57","hash$85","path$73","group$233","bin_shape_t$174","epoch_ledger","start_checkpoint","lock_checkpoint","t_fields_annots$9","t_toplevel_annots$9","to_hlist$37","epoch_length","of_hlist$37","ledger$0","epoch_length$0","lock_checkpoint$0","start_checkpoint$0","ledger$1","ledger_fun","seed_fun","start_checkpoint_fun","lock_checkpoint_fun","epoch_length_fun","ledger_gen","seed_gen","start_checkpoint_gen","lock_checkpoint_gen","epoch_length_gen","group$234","bin_shape_t$175","path$74","merge$10","if$10","merge$11","f$15","of_digest$2","group$235","bin_shape_t$176","t_fields_annots$10","t_toplevel_annots$10","to_hlist$38","of_hlist$38","to_input$21","deriver$13","upper_fun","lower_fun","lower_gen","upper_gen","v_upper","v_lower","run$7","length$29","balance$3","global_slot$0","group$236","bin_shape_t$177","bin_size_t$88","bin_write_t$90","bin_read_t$149","t_of_sexp$150","lower_field","upper_field","upper_value","lower_value","sexp_of_t$154","hash_fold_t$91","compare$156","cmp_a$0","compare$157","deriver$14","range_max","range_uint32","range_uint64","nonce$3","balance$4","amount$1","length$30","deriver$15","v_foo","gen$11","compare_a","to_input$22","to_input$23","to_input_checked","typ$51","check$14","run$8","init$29","action_state$1","boolean$1","receipt_chain_hash$2","frozen_ledger_hash","state_hash$0","token_id$4","epoch_seed$0","public_key$4","to_input$24","check$15","typ$52","receipt_chain_hash$3","balance$5","nonce$4","group$237","account$1","t_of_sexp$151","is_new_field","is_new_value","sexp_of_t$155","v_is_new","path$75","t_fields_annots$11","t_toplevel_annots$11","to_hlist$39","is_new","of_hlist$39","sexp_of_t$156","compare$158","proved_state$1","action_state$2","delegate$2","receipt_chain_hash$4","nonce$5","balance$6","is_new$0","proved_state$2","action_state$3","delegate$3","receipt_chain_hash$5","nonce$6","balance$7","gen$12","accept","nonce$7","deriver$16","is_new_fun","proved_state_fun","action_state_fun","state_fun","balance_gen","nonce_gen","receipt_chain_hash_gen","delegate_gen","state_gen","action_state_gen","proved_state_gen","is_new_gen","to_input$25","to_hlist$40","of_hlist$40","group$238","bin_shape_t$178","size_of_epoch_data","write_epoch_data","of_epoch_data","v_total_currency","v_ledger","v_seed","v_start_checkpoint","v_lock_checkpoint","v_epoch_length","t_of_sexp$152","ledger_field","seed_field","start_checkpoint_field","lock_checkpoint_field","epoch_length_field","total_currency_field","total_currency_value","epoch_length_value","lock_checkpoint_value","start_checkpoint_value","seed_value","ledger_value","of_epoch_data$0","hash_fold_epoch_data","compare$159","a_189","b_190","a_193","b_194","a_197","b_198","path$76","deriver$17","a_203","b_204","min_epoch_length","gen$13","to_input$26","to_input$27","group$239","bin_shape_t$179","snarked_ledger_hash","epoch_data","to_hlist$41","next_epoch_data","staking_epoch_data","min_window_density","blockchain_length","of_hlist$41","t_of_sexp$153","of_snarked_ledger_hash","of_length","of_global_slot","snarked_ledger_hash_field","blockchain_length_field","min_window_density_field","global_slot_since_genesis_fiel","staking_epoch_data_field","next_epoch_data_field","next_epoch_data_value","staking_epoch_data_value","global_slot_since_genesis_valu","min_window_density_value","blockchain_length_value","snarked_ledger_hash_value","t_fields_annots$12","t_toplevel_annots$12","total_currency$1","next_epoch_data$0","staking_epoch_data$0","global_slot_since_genesis$0","total_currency$2","min_window_density$0","blockchain_length$0","snarked_ledger_hash$0","make_creator$1","snarked_ledger_hash_fun","blockchain_length_fun","min_window_density_fun","global_slot_since_genesis_fun","staking_epoch_data_fun","next_epoch_data_fun","snarked_ledger_hash_gen","blockchain_length_gen","min_window_density_gen","global_slot_since_genesis_gen","staking_epoch_data_gen","next_epoch_data_gen","group$240","protocol_state$1","t_of_sexp$154","sexp_of_t$157","v_next_epoch_data","v_staking_epoch_data","v_global_slot_since_genesis","v_min_window_density","v_blockchain_length","v_snarked_ledger_hash","compare$160","a_233","b_234","cmp_epoch_data","a_251","b_252","cmp_length","a_241","b_242","a_237","b_238","a_249","b_250","a_245","b_246","path$77","deriver$18","snarked_ledger_hash$1","max_min_window_density","gen$14","to_input$28","group$241","bin_shape_t$180","path$78","epoch_data_deriver","frozen_ledger_hash$0","state_hash$1","epoch_seed$1","length$31","amount$2","global_slot$1","typ$53","t1$10","a_313","b_314","group$242","bin_shape_t$181","path$79","gen$15","typ$54","group$243","bin_shape_t$182","path$80","to_hlist$42","user","of_hlist$42","group$244","account_transition","group$245","path$81","group$246","group$247","bin_shape_t$183","path$82","group$248","bin_shape_t$184","path$83","to_hlist$43","verification_key_hash","is_proved","is_signed","of_hlist$43","t_fields_annots$13","t_toplevel_annots$13","verification_key_hash$0","is_proved$0","is_signed$0","to_hlist$44","of_hlist$44","typ$55","deriver$19","verification_key_hash_fun","is_proved_fun","is_signed_fun","is_signed_gen","is_proved_gen","verification_key_hash_gen","to_structured","of_structured_exn","let_syntax_269","vk_hash","deriver$20","typ$56","group$249","bin_shape_t$185","path$84","let_syntax_268","t_fields_annots$14","t_toplevel_annots$14","to_hlist$45","inherit_from_parent","parents_own_token","of_hlist$45","inherit_from_parent$0","parents_own_token$0","typ$57","sum_squared","typ$58","to_input$29","to_variant","of_variant","deriver$21","inherit_from_parent_fun","parents_own_token_fun","parents_own_token_gen","inherit_from_parent_gen","deriver$22","typ$59","group$250","bin_shape_t$186","bin_size_t$89","bin_write_t$91","bin_read_t$150","t_of_sexp$155","sexp_of_t$158","hash_fold_t$92","path$85","t_fields_annots$15","t_toplevel_annots$15","t_of_sexp$156","sexp_of_t$159","to_hlist$46","of_hlist$46","vesting_increment$1","vesting_period$1","cliff_amount$1","cliff_time$1","initial_minimum_balance$1","vesting_increment$2","vesting_period$2","cliff_amount$2","cliff_time$2","initial_minimum_balance$2","to_input$30","dummy$5","to_account_timing","of_account_timing","to_hlist$47","of_hlist$47","to_input$31","typ$60","deriver$23","group$251","bin_shape_t$187","path$86","t_fields_annots$16","t_toplevel_annots$16","voting_for$1","timing$2","token_symbol$1","zkapp_uri$3","permissions$2","verification_key$1","delegate$4","app_state$3","voting_for$2","timing$3","token_symbol$2","zkapp_uri$4","permissions$3","verification_key$2","delegate$5","app_state$4","to_hlist$48","of_hlist$48","gen$16","permissions_auth","token_account","token_gen","uri_gen","auth_tag","auth_required_gen","to_hlist$49","of_hlist$49","noop","to_input$32","deriver$24","zkapp_uri_fun","verification_key_fun","app_state_fun","app_state_gen","verification_key_gen","permissions_gen","zkapp_uri_gen","token_symbol_gen","timing_gen","voting_for_gen","group$252","bin_shape_t$188","path$87","precondition","gen$17","deriver$25","group$253","bin_shape_t$189","path$88","t_fields_annots$17","t_toplevel_annots$17","to_hlist$50","valid_while","network","of_hlist$50","account$2","valid_while$0","account$3","network$0","deriver$26","valid_while_fun","account_fun","network_fun","network_gen","account_gen","valid_while_gen","let_syntax_265","to_hlist$51","of_hlist$51","group$254","bin_shape_t$190","bin_size_t$90","bin_write_t$92","bin_read_t$151","t_of_sexp$157","sexp_of_t$160","hash_fold_t$93","compare$161","a_142","b_143","a_144","b_145","a_146","b_147","path$89","group$255","bin_shape_t$191","path$90","t_fields_annots$18","t_toplevel_annots$18","authorization_kind","may_use_token","implicit_account_creation_fee","use_full_commitment","preconditions","call_depth","call_data","actions","increment_nonce$3","update$6","token_id$5","public_key$5","authorization_kind$0","may_use_token$0","implicit_account_creation_fee$0","use_full_commitment$0","preconditions$0","call_depth$0","call_data$0","actions$0","increment_nonce$4","balance_change$0","update$7","token_id$6","public_key$6","deriver$27","authorization_kind_fun","may_use_token_fun","implicit_account_creation_fee_$0","use_full_commitment_fun","preconditions_fun","call_depth_fun","call_data_fun","actions_fun","events_fun","balance_change_fun","update_fun","token_id_gen","update_gen","balance_change_gen","events_gen","actions_gen","call_data_gen","call_depth_gen","preconditions_gen","use_full_commitment_gen","implicit_account_creation_fee_","may_use_token_gen","compile_acc$12","authorization_kind_gen","group$256","bin_shape_t$192","path$91","group$257","bin_shape_t$193","sexp_of_t$161","v_authorization_kind","v_may_use_token","v_implicit_account_creation_fe","v_use_full_commitment","v_preconditions","v_call_data","v_actions","v_events","v_balance_change","v_update","v_valid_while","v_account","v_network","compare$162","a_206","b_207","path$92","to_hlist$52","of_hlist$52","of_graphql_repr","group$258","bin_shape_t$194","path$93","t_fields_annots$19","t_toplevel_annots$19","nonce$8","fee$1","public_key$7","nonce$9","valid_until$1","fee$2","public_key$8","let_syntax_242","gen$18","deriver$28","valid_until_fun","fee_fun","fee_gen","valid_until_gen","of_fee_payer","to_hlist$53","of_hlist$53","chain","typ$61","non_preimage","to_input$33","create_body$0","let_syntax_246","let_syntax_249","let_syntax_250","let_syntax_294","let_syntax_259","let_syntax_262","let_syntax_263","let_syntax_296","group$259","bin_shape_t$195","path$94","t_fields_annots$20","t_toplevel_annots$20","authorization$0","authorization$1","deriver$29","authorization_fun","body_fun","body_gen","authorization_gen","group$260","bin_shape_t$196","path$95","group$261","bin_shape_t$197","size_of_account_update","v8$1","v7$2","v6$2","v5$2","v7$1","size_of_length","write_account_update","write_length","of_account_update","v_delegate$0","v_authorization","t_of_sexp$158","authorization_field","update_field","balance_change_field","events_field","actions_field","call_data_field","preconditions_field","use_full_commitment_field","may_use_token_field","authorization_kind_field","network_field","account_field","valid_while_field","valid_while_value","account_value","network_value","authorization_kind_value","may_use_token_value","use_full_commitment_value","preconditions_value","call_data_value","actions_value","events_value","balance_change_value","update_value","authorization_value","sexp_of_t$162","hash_fold_account_update","hash_fold_length","hash$86","path$96","t_of_sexp$159","sexp_of_t$163","of_graphql_repr$0","quickcheck_generator$5","digest$6","create$108","group$262","bin_shape_t$198","hash_fold_t$94","hash$87","path$97","t_fields_annots$21","t_toplevel_annots$21","authorization$2","body$1","authorization$3","body$2","let_syntax_274","deriver$30","of_fee_payer$0","balance_change$1","public_key$9","token_id$7","increment_nonce$5","group$263","bin_shape_t$199","bin_size_t$91","size_of_field","bin_write_t$93","write_field","bin_read_t$152","v_elt","v_stack_hash","t_of_sexp$160","elt_field","stack_hash_field","stack_hash_value","elt_value","sexp_of_t$164","compare$163","cmp_field","hash_fold_t$95","hash_fold_field","group$264","bin_shape_t$200","t_of_sexp$161","status_field","status_value","sexp_of_t$165","v_status","map$76","group$265","bin_size_t$92","size_of_account_update_digest","bin_write_t$94","write_account_update_digest","bin_read_t$153","of_account_update_digest","v_account_update","v_account_update_digest","v_calls","t_of_sexp$162","account_update_field","account_update_digest_field","calls_field","calls_value","account_update_digest_value","account_update_value","sexp_of_t$166","compare$164","cmp_account_update","cmp_account_update_digest","cmp_digest","hash_fold_t$96","hash_fold_account_update_diges","t_of_sexp$163","fold$22","calls","account_update","mapi_forest_with_trees","map$77","func$2","h_tl","cons$0","func$3","func$4","account_update_digest","stack_hash","group$266","bin_shape_t$201","t_of_sexp$164","sexp_of_t$167","quickcheck_shrinker$4","quickcheck_generator$6","size_138","random_139","size_136","random_137","quickcheck_observer$0","x_128","size_129","hash_130","x_135","hash_130$0","hash_130$1","size_133","hash_134","x_132","x_131","hash_134$0","hash_134$1","quickcheck_shrinker$5","x_125","x_127","x_126","of_account_updates_map","account_update_depth","account_updates","siblings","to_account_updates_map","collect","hash$88","accumulate_hashes","hash_account_update","calls$0","node_hash","group$267","bin_shape_t$202","group$268","bin_shape_t$203","path$98","empty$40","group$269","bin_shape_t$204","path$99","group$270","bin_shape_t$205","path$100","version$18","t_of_sexp$165","fee_payer_field","account_updates_field","account_updates_value","fee_payer_value","sexp_of_t$168","v_account_updates","v_fee_payer","compare$165","a_224","b_225","a_230","b_231","a_228","b_229","a_226","b_227","hash_fold_t$97","group$271","bin_shape_t$206","bin_size_t$93","bin_write_t$95","bin_read_t$154","bin_read_t$155","path$101","let_syntax_275","let_syntax_273","calls_length","to_wire","forget_hashes","forget_hash","of_binable$17","path$102","group$272","bin_shape_typ$13","t_fields_annots$22","t_toplevel_annots$22","t_of_sexp$166","sexp_of_t$169","memo$2","account_updates$0","fee_payer$1","fee_payer$2","status_sym","if$11","group$273","bin_shape_t$207","path$103","create_complete","memo_hash","fee_payer_hash","group$274","bin_shape_t$208","path$104","group$275","bin_shape_t$209","t_of_sexp$167","zkapp_command_field","zkapp_command_value","sexp_of_t$170","v_zkapp_command","hash_fold_t$98","path$105","account_updates_deriver","of_zkapp_command_with_depth","to_zkapp_command_with_depth","memo_fun","account_updates_fun","fee_payer_fun","fee_payer_gen","account_updates_gen","memo_gen","group$276","bin_shape_t$210","to_hlist$54","of_hlist$54","group$277","bin_shape_t$211","path$106","forest","group$278","bin_shape_t$212","t_of_sexp$168","of_u","sexp_of_t$171","compare$166","cmp_u","cmp_s","hash_fold_t$99","hash_fold_u","hash_fold_s","to_signed_command","gen_signed","group$279","bin_shape_t$213","t_of_sexp$169","sexp_of_t$172","hash_fold_t$100","path$107","group$280","bin_shape_t$214","path$108","group$281","bin_shape_t$215","t_of_sexp$170","sexp_of_t$173","hash_fold_t$101","path$109","with_random_receivers","size_args$0","a_012","a_016","a_018","single_to_yojson","single_of_yojson","single_of_sexp","sexp_of_single","compare_single","hash_fold_single","hash_single","to_singles","of_singles","custom_printf_026","custom_printf_027","two$0","singles","receiver_pks","receivers","ft$0","ft$1","fee_tokens","to_fee_transfer","coinbase_amount","v_receiver","v_fee_transfer","receiver_field","fee_transfer_field","fee_transfer_value","receiver_value","cb","access_status","account_ids","adjusted_fee_transfer","expected_supply_increase","increase","supercharged_coinbase","of_coinbase","incr_by_one","push$0","check_merge","to_latest$1","path$2","poly_stack_hash","size_of_stack_hash","write_stack_hash","bin_writer_stack_hash","of_stack_hash","v_init","v_curr","bin_reader_stack_hash","bin_stack_hash","init_field","curr_field","curr_value","init_value","cmp_stack_hash","hash_fold_stack_hash","to_latest$2","path$3","var_of_t$1","push$1","state_body_hash","empty$1","push$2","check_merge$0","correct_transition","eq_target","eq_src","same_update","bin_shape_t$8","hash$3","to_latest$3","bin_shape_t$9","versioned$6","t_of_sexp$5","sexp_of_t$5","to_latest$4","sexp_of_t$6","var_of_t$2","no_update","update_two_stacks_coinbase_in_","update_two_stacks_coinbase_in_$0","poly_action","poly_coinbase_amount","size_of_action","size_of_coinbase_amount","write_action","write_coinbase_amount","bin_writer_action","bin_writer_coinbase_amount","of_action","of_coinbase_amount","v_action","bin_reader_action","bin_reader_coinbase_amount","bin_action","bin_coinbase_amount","versioned$7","t_of_sexp$7","action_field","action_value","sexp_of_t$7","t_of_sexp$8","bin_shape_t$10","bin_writer_t$8","bin_reader_t$8","bin_t$8","versioned$8","t_of_sexp$9","sexp_of_t$9","to_latest$5","sexp_of_t$10","genesis","var_of_t$3","poly_data_stack","poly_state_stack","data_stack","state_stack","size_of_data_stack","size_of_state_stack","write_data_stack","write_state_stack","bin_writer_t$9","bin_writer_data_stack","bin_writer_state_stack","of_data_stack","of_state_stack","bin_reader_t$9","bin_reader_data_stack","bin_reader_state_stack","bin_t$9","bin_data_stack","bin_state_stack","version$8","versioned$9","hash_fold_data_stack","hash_fold_state_stack","t_of_sexp$11","cmp_data_stack","cmp_state_stack","a_044","t_of_sexp$12","sexp_of_t$12","a_046","b_047","bin_shape_t$11","bin_size_t$6","bin_write_t$6","bin_writer_t$10","bin_read_t$13","bin_read_t$14","bin_reader_t$10","bin_t$10","versioned$10","equal$8","a_050","a_052","hash_fold_t$5","hash$4","t_of_sexp$13","a_056","a_058","to_latest$6","equal$9","hash_fold_t$6","hash$5","sexp_of_t$15","compare$7","group$12","bin_shape_t$12","bin_size_t$7","bin_write_t$7","bin_writer_t$11","bin_read_t$15","bin_read_t$16","bin_reader_t$11","bin_t$11","equal$10","compare$8","sexp_of_t$16","versioned$11","hash$6","to_latest$7","equal$11","compare$9","sexp_of_t$17","hash_fold_t$8","hash$7","group$13","bin_shape_t$13","bin_writer_t$12","bin_read_t$18","bin_reader_t$12","bin_t$12","versioned$12","sexp_of_t$18","to_latest$8","symbol$21","sexp_of_t$19","max_coinbase_stack_count","hash_fold_t$9","sexp_of_t$20","compare$10","a_076","b_077","symbol$22","equal$12","hash_fold_t$10","hash$8","hash_var","var_of_t$4","num_pad_bits","pad_bits","empty$2","create_with","equal_state_hash","equal_data","connected","coinbase_stack_connected","state_stack_connected","state_stack_connected$0","push_coinbase","push_state","push_coinbase$0","push_state$0","check_merge$1","valid_coinbase_stacks","valid_state_stacks","create_with$0","equal$13","a_082","b_083","compare$12","a_084","b_085","hash_fold_t$11","hash$9","var_of_t$5","empty_hash$0","merge$0","sexp_of_t$23","hash_var$0","hash$10","merge$1","reraise_merkle_requests","addr$0","addr$1","add_coinbase","coinbase_receiver","supercharge_coinbase","addr2","addr1","equal_to_zero","update_stack1","total_coinbase_amount","rem_amount","no_coinbase_in_this_stack","amount1_equal_to_zero","amount2_equal_to_zero","no_coinbase","stack_with_amount1","stack_with_amount2","previous_state_stack","stack_initialized","stack_with_state_hash","update_state","stack_with_coinbase","stack_with_state","update_second_stack","act","pop_coinbases","proof_emitted","let_syntax_086","let_syntax_087","poly_tree","poly_stack_id","of_tree","of_stack_id","pos_list_field","new_pos_field","new_pos_value","pos_list_value","v_new_pos","v_pos_list","to_yojson$16","t_of_sexp$24","sexp_of_t$25","hash_at_level","cur_hash","root_hash","key$2","key$3","height$0","merkle_root$0","get_stack","find_index","next_stack_id","is_new_stack","incr_index","latest_stack_id","curr_stack_id","current_stack","prev_stack_id","latest_stack","prev_stack","oldest_stack_id","remove_oldest_stack_id","oldest_stack","update_stack","stack_index","stack_before","stack_after","add_coinbase$0","add_state","update_coinbase_stack","remove_coinbase_stack","hash_extra","pos_list","pending_coinbase","coinbase_stack_path_exn","stack_id","stack_id$0","index1","stack_id$1","index2","idx$2","prev_state","symbol$23","group$14","bin_size_t$9","size_of_tree","size_of_stack_id","bin_write_t$9","write_tree","write_stack_id","bin_writer_t$13","bin_writer_tree","bin_writer_stack_id","bin_read_t$19","bin_read_t$20","bin_reader_t$13","bin_reader_tree","bin_reader_stack_id","bin_t$13","bin_tree","bin_stack_id","versioned$13","sexp_of_t$26","symbol$24","symbol$25","group$15","bin_size_t$10","bin_write_t$10","bin_writer_t$14","bin_read_t$21","bin_read_t$22","bin_reader_t$14","bin_t$14","versioned$14","t_of_sexp$27","to_latest$9","coinbases_gen","cbs","after_adding","after_del","add_coinbase_with_zero_checks","max_coinbase_amount","t_with_state","interim_tree","coinbase_data","cb_var","f_add_coinbase","amount_var","action_var","coinbase_receiver_var","supercharge_coinbase_var","state_body_hash_var","global_slot_var","checked_merkle_root","f_pop_coinbase","unchecked_after_pop","comp$0","checked_merkle_root_after_pop","add_remove_check","coinbase_lists","coinbase_lists$0","pc$0","coinbase_lists$1","coinbases$0","stacks","coinbases","initial_coinbase","updated","new_stack","new_stack$0","pending_coinbases_updated","added_stacks","expected_stack","updated_pending_coinbases","popped_stack","pc$1","coinbase_lists$2","coinbase_lists_gen","of_bytes","of_sha256","length_in_bytes$0","to_base58_check$0","of_base58_check_exn$0","v_ledger_hash","v_aux_hash","v_pending_coinbase_aux","ledger_hash_field","aux_hash_field","pending_coinbase_aux_field","pending_coinbase_aux_value","aux_hash_value","ledger_hash_value","pending_coinbase_aux","aux_hash","pending_coinbase_aux$0","aux_hash$0","ledger_hash$0","ledger_hash_fun","aux_hash_fun","pending_coinbase_aux_fun","ledger_hash_gen","aux_hash_gen","pending_coinbase_aux_gen","map_poly","for_all$0","set_all_mutable_fields","value_of_sexp","compare_value","hash_fold_value","pending_coinbase_aux$1","aux_hash$1","ledger_hash$1","pending_coinbase_aux$2","aux_hash$2","ledger_hash$2","fold$1","map_poly$0","to_list$1","fold$2","for_all$2","to_list$2","set_all_mutable_fields$0","value_to_yojson","genesis_ledger_hash","fold$3","ledger_hash$3","aux_hash$3","of_ledger_aux_coinbase_hash","warn_improper_transport","poly_non_snark","poly_pending_coinbase_hash","non_snark","pending_coinbase_hash","size_of_non_snark","size_of_pending_coinbase_hash","write_non_snark","write_pending_coinbase_hash","bin_writer_non_snark","bin_writer_pending_coinbase_ha","of_non_snark","of_pending_coinbase_hash","v_non_snark","v_pending_coinbase_hash","bin_reader_non_snark","bin_reader_pending_coinbase_ha","bin_non_snark","bin_pending_coinbase_hash","non_snark_field","pending_coinbase_hash_field","pending_coinbase_hash_value","non_snark_value","cmp_non_snark","cmp_pending_coinbase_hash","hash_fold_non_snark","hash_fold_pending_coinbase_has","hash_value$0","ledger_hash$4","aux_hash$4","pending_coinbase_aux$3","pending_coinbase_hash_var","of_aux_ledger_and_coinbase_has","genesis$0","non_snark$0","pending_coinbase_hash$0","caller_caller","hash_zkapp_command","group$282","bin_shape_t$216","path$110","v_prover","prover_field","prover_value","compare$167","group$283","bin_shape_t$217","sexpifier$3","v_genesis_state_timestamp","v_slots_per_sub_window","v_slots_per_epoch","v_k","path$111","compare$168","end_time","gen$19","value_of_t","typ$62","p_var","transaction_dummy","group$284","bin_shape_t$218","path$112","group$285","bin_shape_t$219","path$113","group$286","bin_shape_t$220","t_of_sexp$171","sexp_of_t$174","compare$169","path$114","equal_account_state","group$287","bin_shape_t$221","command","t_of_sexp$172","of_command","sexp_of_t$175","compare$170","cmp_command","hash_fold_t$102","hash_fold_command","group$288","bin_shape_t$222","t_of_sexp$173","sexp_of_t$176","compare$171","hash_fold_t$103","func$21","path$115","group$289","bin_shape_t$223","t_of_sexp$174","sexp_of_t$177","compare$172","hash_fold_t$104","func$22","path$116","compare_hash","group$290","bin_shape_t$224","bin_read_t$156","bin_read_t$157","bin_reader_t$58","bin_size_t$94","bin_write_t$96","bin_writer_t$58","bin_t$58","mk_hasher","bin_size_t$95","bin_write_t$97","bin_read_t$158","bin_read_t$159","bin_shape_t$225","bin_writer_t$59","bin_reader_t$59","bin_t$59","signed_cmd_hasher_v1","signed_cmd_hasher","zkapp_cmd_hasher","hash_signed_command_v1","cmd_dummy_signature","hash_signed_command_v2","acct_update","dummy_auth","cmd_dummy_signatures_and_proof","hash_of_transaction_id","cmd_v1","group$291","bin_shape_t$226","t_of_sexp$175","sexp_of_t$178","compare$173","path$117","group$292","bin_shape_t$227","t_of_sexp$176","sexp_of_t$179","compare$174","path$118","group$293","signed_amount","group$294","failure_status_tbl","bin_shape_t$228","path$119","group$295","bin_shape_t$229","path$120","t_of_sexp$177","user_command_field","user_command_value","sexp_of_t$180","v_user_command","group$296","bin_shape_t$230","path$121","t_of_sexp$178","previous_delegate_field","previous_delegate_value","new_accounts_field","new_accounts_value","sexp_of_t$181","v_new_accounts","v_previous_delegate","group$297","bin_shape_t$231","path$122","t_of_sexp$179","sexp_of_t$182","group$298","bin_shape_t$232","path$123","t_of_sexp$180","accounts_field","command_field","command_value","accounts_value","sexp_of_t$183","v_command","v_accounts","group$299","bin_shape_t$233","path$124","t_of_sexp$181","sexp_of_t$184","group$300","bin_shape_t$234","path$125","t_of_sexp$182","burned_tokens_field","burned_tokens_value","sexp_of_t$185","v_burned_tokens","group$301","bin_shape_t$235","path$126","t_of_sexp$183","coinbase_field","coinbase_value","sexp_of_t$186","v_coinbase","group$302","bin_shape_t$236","path$127","t_of_sexp$184","sexp_of_t$187","group$303","bin_shape_t$237","path$128","t_of_sexp$185","previous_hash_field","varying_field","varying_value","previous_hash_value","sexp_of_t$188","v_varying","v_previous_hash","burned_tokens","varying","supply_increase","burned_tokens$0","account_creation_fee_int","new_accounts","zc","num_accounts_created","account_creation_fees","txn","process_decreases","amts","timing_error_to_user_command_s","validate_timing_with_min_balan","txn_amount","txn_global_slot","account_balance","proposed_new_balance","curr_min_balance","curr_min_balance$0","invalid_timing","invalid_balance","possibly_error","validate_timing_with_min_balan$0","min_balance","validate_timing","error_opt","get_with_location","set_with_location","sub_account_creation_fee","transaction","transaction_status","get_new_accounts","has_locked_tokens","apply_user_command_unchecked","signer_pk","fee_payer_account","fee_payer_location","ok_or_reject","compute_updates","receiver_account","receiver_location","receiver_amount","updated_accounts","previous_delegate","applied_body","located_accounts","applied_common","apply_user_command","second_pass_ledger","value_if","is_empty$0","assert_with_failure_status_tbl","ecol","proof_verifies","signature_verifies","get_zkapp","set_zkapp","is_non_neg","of_constant_fee","set_or_keep","or_default","add_check","eff","global_state","local_state","new_account","local_state$0","global_state$0","or_err","pop_call_stack","next_call_stack","next_frame","update_action_state","s1_updated","is_this_slot","is_empty_or_this_slot","s5$0","s4$0","s3$0","is_start","is_empty_call_forest","is_start$0","will_succeed","start_data$2","start_data$3","first_pass_ledger","call_stack","to_pop","start_data$0","start_data$1","call_stack$1","to_pop$0","next_forest","current_is_empty","call_stack$0","current_forest","remainder_of_current_forest","account_update_forest","account_update$0","may_use_parents_own_token","may_use_token_inherited_from_p","account_update_forest_empty","remainder_of_current_forest_em","popped_call_stack","newly_popped_frame","remainder_of_current_forest_fr","new_call_stack","new_frame","local_state$1","account_update_token_id","default_token_or_token_owner_w","full_transaction_commitment","transaction_commitment","start_data","full_tx_commitment_on_start","tx_commitment","full_tx_commitment","local_state$35","account_is_new","self_delegate","zkapp$2","matching_verification_key_hash","local_state$2","local_state$3","protocol_state_predicate_satis","local_state$4","valid_while_satisfied","local_state$5","local_state$6","local_state$7","precondition_has_constant_nonc","increments_nonce_and_constrain","depends_on_the_fee_payers_nonc","does_not_use_a_signature","local_state$8","account_update_token","account_update_token_is_defaul","account_is_untimed","local_state$9","account_creation_fee","local_state$10","neg_creation_fee","creation_overflow","balance_change_for_creation","pay_creation_fee","creation_overflow$0","local_state$11","pay_creation_fee_from_excess","failed1","local_state$12","account_creation_fee$0","excess_update_failed","excess_minus_creation_fee","local_state$13","supply_increase_update_failed","supply_increase_minus_creation","local_state$14","is_receiver","has_permission$0","local_state$15","invalid_timing$1","invalid_timing$0","local_state$16","has_permission$1","local_state$17","keeping_app_state","changing_entire_app_state","has_permission$2","local_state$18","has_permission$3","local_state$19","has_permission$4","local_state$20","has_permission$5","local_state$21","has_permission$6","local_state$22","base_delegate","has_permission$7","local_state$23","has_permission$8","local_state$24","old_hash","has_permission$9","local_state$25","index_input","has_permission$10","local_state$26","local_delta","new_local_fee_excess","overflowed","new_local_fee_excess$0","local_state$27","local_state$28","is_last_account_update","local_state$29","delta_settled","valid_fee_excess","local_state$30","is_start_or_last","update_global_state_fee_excess","global_excess_update_failed","local_state$31","local_state$32","local_state$33","should_update","local_state$34","update_action_state$0","apply_zkapp_command_first_pass","state_view","previous_hash","original_first_pass_account_st","perform$0","user_acc","eta","apply_zkapp_command_first_pass$0","partial_stmt","apply_zkapp_command_second_pas","account_states","acc_opt","original_account_states","step_all","l_state","g_state","states","reversed_failure_status_tbl","account_ids_originally_not_in_","loc_and_acct","successfully_applied","failure_status_tbl$0","valid_result","loc_opt","other_account_update_accounts_","apply_zkapp_command_unchecked_","apply_zkapp_command_unchecked","state_res","account_update_applied","update_timing_when_no_deductio","has_permission_to_receive$0","receiver_account_id","init_account","single_failure","no_failure","append_entry","apply_fee_transfer","transfer","failures","ft_with_status","modify_timing","modify_balance","ft2","ft1","account_id1","can_receive1","action1","account_id2","new_accounts1","can_receive2","action2","balance1","timing2","balance2","burned_tokens1","burned_tokens2","new_accounts2","can_receive","apply_coinbase","failures1","transferee_timing_prev","transferee_update","receiver_reward","receiver_id","coinbase_receiver_timing","receiver_balance","coinbase_with_status","new_receiver_timing","transferee","transferee_id","transferee_account","transferee_location","apply_transaction_first_pass","txn_state_view","applied","txn$0","partially_applied","apply_transaction_second_pass","applied$0","previous_hash$0","applied$1","previous_hash$1","apply_transactions","txns","min_init_balance","max_init_balance","num_accounts","num_transactions","mk_gen","num_transactions$0","init_ledger","nonces","receiver_is_new","gen_index","receiver_index","nonces$0","let_syntax_041","let_syntax_042","raise_error","raise_exn","json_parse","binary_string_to_base58_check","bin_string","binary_string_of_base58_check","base58","public_key_to_base58","public_key_of_base58","pk_base58","private_key_to_base58","sk","private_key_of_base58","sk_base58","token_id_to_base58","token_id_of_base58","memo_to_base58","memo_hash_base58","memo_base58","derive$1","derive_checked","deriver$31","body_deriver","of_json$0","hash_to_group","sign_field_element","is_mainnet","typ$63","account_update$1","transaction_commitments","tx_json","zkapp_public_input","account_update_index","pack_input$2","timing_input","permissions_input","update_input","account_precondition_input","network_precondition_input","body_input","ok_exn$0","hash_payment","command$0","hash_payment_v1","b58","serialize_common","serialize_payment","serialize_payment_v1","example_payment","hashPayment","hashPaymentV1","serializeCommon","serializePayment","serializePaymentV1","examplePayment","accountUpdate","transactionCommitments","zkappPublicInput","signFieldElement","dummySignature","deriveChecked","toBase58","ofBase58","publicKeyToBase58","publicKeyOfBase58","privateKeyToBase58","privateKeyOfBase58","tokenIdToBase58","tokenIdOfBase58","memoToBase58","memoHashBase58","test$1","class$1","get$19","location_of_account","set$16","next_location","get_or_create","get_or_create_account","create_new_account","remove_accounts_exn","ids","locs","empty$41","with_ledger","create_masked","default_token_id","account_id$0","create$109","deriver$32","last_action_slot_fun","zkapp_version_fun","zkapp_version_gen","last_action_slot_gen","compile_acc$13","compile_acc$14","compile_acc$15","compile_acc$16","zkapp_gen","transform","get_account","add_account","balance$0","bal_u64","deriver$33","apply_json_transaction","network_json","network_state","who","application_result","static_method","method","prototype","public_input_typ","statement_typ","input_size","output_size","inner_curve_typ","should_verifys_js","js_bool","should_verifys","public_output_size","statements","nat_modules_list","nat_add_modules_list","pickles_compile","max_proofs","to_js_provers","prove","js_prevs","public_output","previous_proofs_should_verify","previous_public_inputs","should_verifys$0","public_inputs$0","prevs$1","proof_to_base64","proof$1","proof_of_base64","dummy_base64_proof","dummy_verification_key","pickles","typ$64","size_in_fields","exists$12","exists_var","run_and_check$3","run_unchecked$3","constraint_system$3","add$35","scale$9","mul$3","read_var$0","assert_mul","assert_square$5","assert_boolean","compare$175","to_bits$3","from_bits","truncate_to_bits16","length_div_16","seal$2","and","or","equals","ec_add","scale$10","scalar_bits","of_js$0","verify$1","public_input_vec","get_vk","get_cs_json","update$8","hash_to_group$0","sponge_params_checked","sponge_create","is_checked","sponge_absorb","sponge_squeeze","existsVar","poseidon","hashToGroup","getVerificationKey","getConstraintSystemJSON","ecadd","assertEqual","readVar","assertMul","assertSquare","assertBoolean","toBits","fromBits","truncateToBits16","toConstantAndTerms","asProver","inProverBlock","runAndCheck","runUnchecked","constraintSystem","snarky","export$1","export_global","snarky_obj"],"sources":["","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/strftime.js","/home/soc/codes/o1-labs/mina/_opam/lib/base/runtime.js","/builtin/+ints.js","/builtin/+hash.js","/builtin/+ieee_754.js","/builtin/+int64.js","/builtin/+fail.js","/builtin/+stdlib.js","/builtin/+mlBytes.js","/builtin/+bigarray.js","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/overrides.js","/builtin/+marshal.js","/home/soc/codes/o1-labs/mina/_opam/lib/base/base_internalhash_types/runtime.js","/builtin/+nat.js","/builtin/+jslib.js","/home/soc/codes/o1-labs/mina/_opam/lib/base_bigstring/runtime.js","/builtin/+bigstring.js","/home/soc/codes/o1-labs/mina/_opam/lib/bigstringaf/runtime.js","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/runtime.js","/builtin/+array.js","/builtin/+backtrace.js","/workspace_root/src/lib/snarkyjs/src/bindings/kimchi/js/node_js/node_backend.js","/workspace_root/src/lib/snarkyjs/src/bindings/kimchi/js/bindings.js","/builtin/+compare.js","/builtin/+weak.js","/builtin/+gc.js","/builtin/+format.js","/builtin/+obj.js","/builtin/+fs_node.js","/builtin/+fs.js","/builtin/+unix.js","/builtin/+sys.js","/builtin/+fs_fake.js","/builtin/+io.js","/builtin/+lexing.js","/builtin/+md5.js","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/collector/runtime.js","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/runtime.js","/workspace_root/src/lib/promise/js/promise.js","/workspace_root/src/lib/integers_stubs_js/runtime.js","/home/soc/codes/o1-labs/mina/_opam/lib/zarith_stubs_js/biginteger.js","/home/soc/codes/o1-labs/mina/_opam/lib/zarith_stubs_js/runtime.js","/home/soc/codes/o1-labs/mina/_opam/lib/time_now/runtime.js","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/obj.ml","/workspace_root/src/lib/pickles/limb_vector/constant.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/int64.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/random.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/lexing.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalFormat.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/printexc.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/filename.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/exn.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/sign0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hex_lexer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/popcount.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int63_emul.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/backtrace.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_bench/runtime-lib/benchmark_accumulator.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/shape/bin_shape.ml","/home/soc/codes/o1-labs/mina/_opam/lib/stdio/in_channel.ml","/home/soc/codes/o1-labs/mina/_opam/lib/stdio/out_channel.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_module_timer/runtime/ppx_module_timer_runtime.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/std_internal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/collector/check_backtraces.ml","/home/soc/codes/o1-labs/mina/_opam/lib/splittable_random/splittable_random.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/positions.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/perms.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/quickcheck.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/std_internal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/span_float.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/tuple.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/digit_string_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/month.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/date0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/percent.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ofday_float.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/span_ns.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ofday_ns.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/gc.ml","/home/soc/codes/o1-labs/mina/_opam/lib/easy-format/easy_format.ml","/home/soc/codes/o1-labs/mina/_opam/lib/yojson/yojson.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bignum/bigint/bigint.ml","/workspace_root/src/lib/snarky/src/base/cvar.ml","/workspace_root/src/lib/snarky/src/base/constraint.ml","/workspace_root/src/lib/snarky/src/base/backend_extended.ml","/workspace_root/src/lib/snarky/src/base/checked_runner.ml","/workspace_root/src/lib/snarky/src/base/utils.ml","/workspace_root/src/lib/snarky/src/base/merkle_tree.ml","/workspace_root/src/lib/snarky/src/base/snark0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bigstringaf/bigstringaf.ml","/workspace_root/src/lib/pickles_types/shifted_value.ml","/workspace_root/src/lib/pickles_types/plonk_types.ml","/workspace_root/src/lib/pickles/pickles.ml","/workspace_root/src/lib/pickles_types/plonk_verification_key_evals.ml","/workspace_root/src/lib/snarky/sponge/sponge.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/tuple_pool/tuple_pool.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/validate.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/thread_pool_cpu_affinity/thread_pool_cpu_affinity.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/uopt/uopt.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/timing_wheel/timing_wheel.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/async_kernel_config.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/monitor.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/async_kernel.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_blake2b.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_blake2s.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/digestif.ml","/workspace_root/src/lib/hex/hex.ml","/workspace_root/src/lib/logger/fake/logger.ml","/workspace_root/src/lib/allocation_functor/table.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/scale_round.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/scalar_challenge.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/curve.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/plonk_dlog_proof.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/bigint.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/endoscale_round.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/endoscale_scalar_round.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/field.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/plonk_constraint_system.ml","/workspace_root/src/lib/snarky/fold_lib/fold.ml","/workspace_root/src/lib/snarky/snarkette/fields.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/vesta_based_plonk.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/pallas_based_plonk.ml","/workspace_root/src/lib/blake2/blake2.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_412.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/pprintast.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_413.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_414.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_411.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_410.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_409.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_408.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_407.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_406.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_405.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_404.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_403.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_402.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_403_402.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast/versions.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/stdppx/stdppx.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/name.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalOO.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/deriving.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/environment.ml","/workspace_root/src/lib/random_oracle_input/random_oracle_input.ml","/workspace_root/src/lib/pickles_base/proofs_verified.ml","/workspace_root/src/lib/pickles_base/side_loaded_verification_key.ml","/workspace_root/src/lib/pickles_base/domain.ml","/workspace_root/src/lib/pickles/composition_types/branch_data.ml","/workspace_root/src/lib/pickles/composition_types/bulletproof_challenge.ml","/workspace_root/src/lib/pickles/composition_types/composition_types.ml","/workspace_root/src/lib/pickles/plonk_checks/scalars.ml","/workspace_root/src/lib/mina_version/normal/mina_version.ml","/workspace_root/src/lib/snarky/snarky_curve/snarky_curve.ml","/workspace_root/src/lib/snark_keys_header/snark_keys_header.ml","/workspace_root/src/lib/error_json/error_json.ml","/workspace_root/src/lib/pickles/wrap_wire_proof.ml","/workspace_root/src/lib/pickles/scalar_challenge.ml","/workspace_root/src/lib/pickles/impls.ml","/workspace_root/src/lib/pickles/plonk_curve_ops.ml","/workspace_root/src/lib/pickles/reduced_messages_for_next_proof_over_same_field.ml","/workspace_root/src/lib/pickles/step_main_inputs.ml","/workspace_root/src/lib/pickles/side_loaded_verification_key.ml","/workspace_root/src/lib/pickles/proof.ml","/workspace_root/src/lib/pickles/wrap_main_inputs.ml","/workspace_root/src/lib/pickles/wrap_verifier.ml","/workspace_root/src/lib/pickles_types/opt.ml","/workspace_root/src/lib/pickles/step_verifier.ml","/workspace_root/src/lib/pickles/proof_cache.ml","/workspace_root/src/lib/pickles/cache.ml","/workspace_root/src/lib/snark_params/snark_params.ml","/workspace_root/src/lib/random_oracle/permutation/external/random_oracle_permutation.ml","/workspace_root/src/lib/random_oracle/random_oracle.ml","/workspace_root/src/lib/non_zero_curve_point/non_zero_curve_point.ml","/workspace_root/src/lib/signature_lib/private_key.ml","/workspace_root/src/lib/signature_lib/schnorr.ml","/workspace_root/src/lib/signature_lib/keypair.ml","/workspace_root/src/lib/sgn/sgn.ml","/workspace_root/src/lib/sparse_ledger_lib/sparse_ledger.ml","/workspace_root/src/lib/rosetta_coding/coding.ml","/workspace_root/src/lib/ppx_dhall_type/deriving.ml","/workspace_root/src/lib/currency/signed_poly.ml","/workspace_root/src/lib/currency/currency.ml","/home/soc/codes/o1-labs/mina/_opam/lib/re/cset.ml","/home/soc/codes/o1-labs/mina/_opam/lib/graphql_parser/parser.ml","/home/soc/codes/o1-labs/mina/_opam/lib/graphql_parser/lexer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/graphql/graphql_schema.ml","/workspace_root/src/lib/fields_derivers/fields_derivers.ml","/workspace_root/src/lib/fields_derivers_graphql/fields_derivers_graphql.ml","/workspace_root/src/lib/fields_derivers_json/fields_derivers_json.ml","/workspace_root/src/lib/with_hash/with_hash.ml","/workspace_root/src/lib/fields_derivers_zkapps/fields_derivers_zkapps.ml","/workspace_root/src/lib/data_hash_lib/state_hash.ml","/workspace_root/src/lib/genesis_constants/genesis_constants.ml","/workspace_root/src/lib/block_time/block_time.ml","/workspace_root/src/lib/one_or_two/one_or_two.ml","/workspace_root/src/lib/mina_base/account_id.ml","/workspace_root/src/lib/mina_base/account_timing.ml","/workspace_root/src/lib/mina_base/signature.ml","/workspace_root/src/lib/mina_base/control.ml","/workspace_root/src/lib/mina_base/payment_payload.ml","/workspace_root/src/lib/mina_base/ledger_hash0.ml","/workspace_root/src/lib/mina_base/permissions.ml","/workspace_root/src/lib/mina_base/signed_command_memo.ml","/workspace_root/src/lib/mina_base/stake_delegation.ml","/workspace_root/src/lib/mina_base/transaction_status.ml","/workspace_root/src/lib/mina_base/transaction_union_tag.ml","/workspace_root/src/lib/mina_base/signed_command_payload.ml","/workspace_root/src/lib/mina_base/signed_command.ml","/workspace_root/src/lib/mina_base/receipt.ml","/workspace_root/src/lib/mina_base/state_body_hash.ml","/workspace_root/src/lib/mina_base/zkapp_basic.ml","/workspace_root/src/lib/mina_base/zkapp_account.ml","/workspace_root/src/lib/mina_base/account.ml","/workspace_root/src/lib/mina_base/epoch_ledger.ml","/workspace_root/src/lib/mina_base/epoch_seed.ml","/workspace_root/src/lib/mina_base/epoch_data.ml","/workspace_root/src/lib/mina_base/zkapp_precondition.ml","/workspace_root/src/lib/mina_base/data_as_hash.ml","/workspace_root/src/lib/mina_base/account_update.ml","/workspace_root/src/lib/mina_base/with_stack_hash.ml","/workspace_root/src/lib/mina_base/with_status.ml","/workspace_root/src/lib/mina_base/zkapp_command.ml","/workspace_root/src/lib/mina_base/user_command.ml","/workspace_root/src/lib/mina_base/fee_transfer.ml","/workspace_root/src/lib/mina_base/coinbase_fee_transfer.ml","/workspace_root/src/lib/mina_base/coinbase.ml","/workspace_root/src/lib/mina_base/pending_coinbase.ml","/workspace_root/src/lib/mina_base/staged_ledger_hash.ml","/workspace_root/src/lib/mina_base/sok_message.ml","/workspace_root/src/lib/mina_base/protocol_constants_checked.ml","/workspace_root/src/lib/mina_base/fee_with_prover.ml","/workspace_root/src/lib/transaction/transaction.ml","/workspace_root/src/lib/transaction/transaction_hash.ml","/workspace_root/src/lib/transaction_logic/mina_transaction_logic.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/consistency_test.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/pickles_bindings.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalFormatBasics.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalAtomic.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/stdlib.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/base.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/stdlib.mli","/home/soc/codes/o1-labs/mina/_opam/lib/base/int_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/float0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/pipe.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int_conversions.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/list.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/import.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/sys0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/write.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalLazy.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/lazy.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/seq.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/option.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/result.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/char.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/int.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/bytes.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/string.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/marshal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/int32.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/nativeint.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/parsing.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/set.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/map.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/stack.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/queue.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/buffer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/printf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_bigstring/base_bigstring.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/arg.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/fun.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/digest.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/random.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/hashtbl.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/attribute.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/format.ml","/home/soc/codes/o1-labs/mina/_opam/lib/re/fmt.ml","/home/soc/codes/o1-labs/mina/_opam/lib/re/pmark.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/scanf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/callback.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalMod.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/bigarray.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib0/lazy_group_id.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib0/sexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib0/sexp_conv.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/ephemeron.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib0/sexp_conv_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/span_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/import0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/printf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/array0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/char0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/list0.ml","/workspace_root/src/lib/snarky/bitstring_lib/bitstring.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hash.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/ppx_compare_lib.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/string0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/sexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/sexpable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/word_size.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/pretty_printer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/core_kernel.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/with_return.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/monad.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/comparator.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/field.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/source_code_position0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/list1.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/result.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/container_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/container.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/lazy.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/monad_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/fn.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/list.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/ordering.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/applicative.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/info.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/invariant.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/maybe_bound.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/or_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/comparable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/identifiable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/comparable_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/unit.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/ordered_collection_common.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/binary_search.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/binary_searchable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/bytes0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/blit.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/option.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/either.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/indexed_container.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/sequence.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/obj_array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/uniform_array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/char.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/string.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/bytes.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/pow_overflow_bounds.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int_math.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/type_equal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/univ_map.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/option_array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/stack.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/set.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/set_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/queue.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/nothing.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/never_returns.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/nativeint.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/map.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/map_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int64.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/bool.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int32.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int63.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hashtbl.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hashtbl_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hashable_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/avltree.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hash_set_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hash_set.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/float.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/buffer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_assert/runtime-lib/runtime.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/md5/md5_lib.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/common.ml","/workspace_root/src/lib/pickles_types/vector.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/read.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/shape.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/size.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/type_class.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/utils.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/std.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_inline_test/config/inline_test_config.ml","/home/soc/codes/o1-labs/mina/_opam/lib/time_now/time_now.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_inline_test/runtime-lib/runtime.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/typename.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/make_typename.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/variant_and_record_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/typerep_obj.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/type_abstract.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/common/file.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/collector/expect_test_collector.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/config_types/expect_test_config_types_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/config_types/expect_test_config_types.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/config/expect_test_config.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/generator.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/bigarray_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/observer0.ml","/workspace_root/src/lib/pickles/opt_sponge.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/shrinker.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/test.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/observer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/base_for_tests/test_blit.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/base_for_tests/test_binary_searchable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/parsexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/automaton_stack.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/of_sexp_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/parse_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/parser_automaton_internal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/parser_automaton.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/kind.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/automaton_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/parser.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/conv.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib/pre_sexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/old_parser_cont_state.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib/conv.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/import.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/sexpable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/binable_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/binable0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/printf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/comparator.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/result.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/container.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/deprecate_pipe_bang.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/fn.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ordered_collection_common.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/sequence.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/source_code_position0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/info.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/t.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/list0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hashtbl.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hash_set.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/or_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/map.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/set.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/comparable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/doubly_linked_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/list.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/option.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/union_find.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/doubly_linked.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/bag.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/sexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hash_queue.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hashable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/identifiable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/bool.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hexdump_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hexdump.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/string.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/bytes.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/char.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/core_pervasives.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/sign.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/float.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/int.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/int32.ml","/workspace_root/src/lib/unsigned_extended/unsigned_extended.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/int64.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/int63.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/unit.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/interfaces.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/lazy.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/nativeint.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/nothing.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ordering.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ref.ml","/workspace_root/src/lib/transaction_logic/zkapp_command_logic.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/byte_units0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/bigstring.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/core_bin_prot.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/md5.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/zone_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/binable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/zone.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/source_code_position.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/validated.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/type_equal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/univ_map_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/unit_of_time.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/unique_id.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/uniform_array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/day_of_week.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ofday_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/stable_internal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/float_with_finite_only_serialization.ml","/workspace_root/src/lib/timeout_lib/timeout_lib.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time_float0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time_float.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time_ns.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time_ns_alternate_sexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/set_once.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/heap_block.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/queue.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/option_array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/memo.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/deque.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/debug.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/bag_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/integers/unsigned.ml","/home/soc/codes/o1-labs/mina/_opam/lib/biniou/bi_util.ml","/home/soc/codes/o1-labs/mina/_opam/lib/biniou/bi_outbuf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/biniou/bi_share.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_deriving_yojson/runtime/ppx_deriving_yojson_runtime.ml","/workspace_root/src/lib/crypto/kimchi_bindings/stubs/pasta_bindings.ml","/workspace_root/src/lib/snarky/tuple_lib/double.ml","/workspace_root/src/lib/snarky/tuple_lib/intf.ml","/workspace_root/src/lib/snarky/tuple_lib/four.ml","/workspace_root/src/lib/snarky/tuple_lib/quadruple.ml","/workspace_root/src/lib/snarky/tuple_lib/triple.ml","/workspace_root/src/lib/snarky/tuple_lib/tuple_lib.ml","/workspace_root/src/lib/snark_bits/bits.ml","/workspace_root/src/lib/snarky/interval_union/interval_union.ml","/workspace_root/src/lib/snarky/snarkette/nat.ml","/workspace_root/src/lib/snarky/src/base/handle.ml","/workspace_root/src/lib/snarky/src/base/monad_let.ml","/workspace_root/src/lib/snarky/src/base/request.ml","/workspace_root/src/lib/snarky/src/base/checked.ml","/workspace_root/src/lib/snarky/src/base/types.ml","/workspace_root/src/lib/snarky/src/base/as_prover0.ml","/workspace_root/src/lib/snarky/src/base/run_state.ml","/workspace_root/src/lib/snarky/src/base/checked_intf.ml","/workspace_root/src/lib/snarky/src/base/as_prover_ref.ml","/workspace_root/src/lib/snarky/src/base/boolean.ml","/workspace_root/src/lib/snarky/src/base/runners.ml","/workspace_root/src/lib/snarky/src/base/typ.ml","/workspace_root/src/lib/snarky/src/base/monad_sequence.ml","/workspace_root/src/lib/snarky/src/base/enumerable.ml","/workspace_root/src/lib/snarky/src/base/number.ml","/workspace_root/src/lib/snarky/src/base/snark.ml","/workspace_root/src/lib/ppx_version/runtime/shapes.ml","/home/soc/codes/o1-labs/mina/_opam/lib/angstrom/input.ml","/home/soc/codes/o1-labs/mina/_opam/lib/angstrom/parser.ml","/home/soc/codes/o1-labs/mina/_opam/lib/angstrom/angstrom.ml","/workspace_root/src/lib/logproc_lib/interpolator.ml","/workspace_root/src/lib/structured_log_events/structured_log_events.ml","/workspace_root/src/lib/pickles_types/nat.ml","/workspace_root/src/lib/pickles_types/hlist0.ml","/workspace_root/src/lib/mina_base/zkapp_state.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/basic/kimchi_pasta_basic.ml","/workspace_root/src/lib/pickles_types/hlist.ml","/workspace_root/src/lib/pickles_types/or_infinity.ml","/workspace_root/src/lib/pickles/plonk_checks/plonk_checks.ml","/workspace_root/src/lib/pickles_types/pcs_batch.ml","/workspace_root/src/lib/pickles_types/at_most.ml","/workspace_root/src/lib/crypto/kimchi_bindings/stubs/kimchi_bindings.ml","/workspace_root/src/lib/snarky/sponge/params.ml","/workspace_root/src/lib/snarky/sponge/constants.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/tuple_pool/tuple_type_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/tuple_pool/tuple_type.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/pairing_heap/pairing_heap.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/sexp_hidden_in_test/sexp_hidden_in_test.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/thread_safe_queue/thread_safe_queue.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/time_ns.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/monitor0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/debug.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/import.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/priority.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/types.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/execution_context.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/job_queue.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/tracing.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/external_job.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/job_pool.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/job_or_event.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/scheduler0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/synchronous_time_source0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/scheduler1.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/scheduler.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/ivar0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/ivar.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/monad_sequence.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred1.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred_std.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/ivar_filler.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/tail.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/async_stream.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/synchronous_time_source.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/bvar.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/time_source.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/stack_or_counter.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/throttle.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/async_kernel_scheduler.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/clock_ns.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred_list.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred_result.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred_or_error.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred_queue.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/async_gc.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/digestif_bi.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/digestif_by.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/xor.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/digestif_conv.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_md5.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_rmd160.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha1.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha256.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha224.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha3.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha3_512.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha512.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha384.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha3_224.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha3_256.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha3_384.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_whirlpool.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/digestif_eq.ml","/home/soc/codes/o1-labs/mina/_opam/lib/eqaf/eqaf.ml","/workspace_root/src/lib/key_cache/key_cache.ml","/workspace_root/src/lib/allocation_functor/make.ml","/workspace_root/src/lib/promise/js/promise.ml","/workspace_root/src/lib/internal_tracing/context_logger/internal_tracing_context_logger.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/poly_comm.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/plonk_dlog_oracles.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/constants.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/dlog_plonk_based_keypair.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/kimchi_backend_common.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/snarky_bindings.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/constraint_system/caml/vesta_constraint_system.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/constraint_system/caml/pallas_constraint_system.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/kimchi_pasta.ml","/workspace_root/src/lib/mina_wire_types/block_time.ml","/workspace_root/src/lib/mina_wire_types/currency.ml","/workspace_root/src/lib/mina_wire_types/pickles/pickles_composition_types.ml","/workspace_root/src/lib/mina_wire_types/pickles/pickles.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_account_id.ml","/workspace_root/src/lib/mina_wire_types/mina_numbers.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_call_stack_digest.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_coinbase_fee_transfer.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_coinbase.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_fee_transfer.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_pending_coinbase.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_signed_command_memo.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_signed_command.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_sok_message.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_stack_frame.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_staged_ledger_hash.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_zkapp_command.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast/ast_helper_lite.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/uchar.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/stdlib0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/location.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/code_matcher.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_414_413.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_413_414.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_413_412.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_412_413.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_412_411.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_411_412.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_411_410.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_410_411.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_410_409.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_409_410.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_409_408.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_408_409.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_408_407.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_407_408.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_407_406.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_406_407.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_406_405.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_405_406.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_405_404.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_404_405.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_404_403.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_403_404.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_402_403.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast/import.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast/ast.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_derivers/ppx_derivers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/traverse_builtins/ppxlib_traverse_builtins.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/longident.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/code_path.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/location.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast/location_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/expansion_context.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_traverse.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/spellcheck.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_pattern0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_builder_generated.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_builder.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/caller_id.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/common.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_pattern_generated.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_pattern.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/extension.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/context_free.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/driver.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/merlin_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ignore_unused_warning.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/clause_syntax.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/field_syntax.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/ppx_shrinker_expander.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/ppx_generator_expander.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/ppx_observer_expander.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/ppx_quickcheck_expander.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/ppx_quickcheck.ml","/workspace_root/src/lib/crypto/kimchi_backend/kimchi_backend.ml","/workspace_root/src/lib/pickles/backend/backend.ml","/workspace_root/src/lib/snarky/group_map/bw19.ml","/workspace_root/src/lib/cache_dir/fake/cache_dir.ml","/workspace_root/src/lib/snarky/group_map/group_map.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base64/base64.ml","/workspace_root/src/lib/snarky_group_map/checked_map.ml","/workspace_root/src/lib/snarky_group_map/snarky_group_map.ml","/workspace_root/src/lib/pickles/one_hot_vector/one_hot_vector.ml","/workspace_root/src/lib/pickles_base/domains.ml","/workspace_root/src/lib/pickles/limb_vector/make.ml","/workspace_root/src/lib/pickles/limb_vector/challenge.ml","/workspace_root/src/lib/pickles/composition_types/digest.ml","/workspace_root/src/lib/pickles/composition_types/spec.ml","/workspace_root/src/lib/pickles/pseudo/pseudo.ml","/workspace_root/src/lib/base58_check/version_bytes.ml","/workspace_root/src/lib/base58_check/base58_check.ml","/workspace_root/src/lib/codable/codable.ml","/workspace_root/src/lib/snarky_log/snarky_log.ml","/workspace_root/src/lib/pickles/import.ml","/workspace_root/src/lib/pickles/util.ml","/workspace_root/src/lib/pickles/endo.ml","/workspace_root/src/lib/pickles/common.ml","/workspace_root/src/lib/pickles/make_sponge.ml","/workspace_root/src/lib/pickles/tick_field_sponge.ml","/workspace_root/src/lib/pickles/dummy.ml","/workspace_root/src/lib/pickles/wrap_main.ml","/workspace_root/src/lib/pickles/commitment_lengths.ml","/workspace_root/src/lib/pickles/evaluation_lengths.ml","/workspace_root/src/lib/pickles/ro.ml","/workspace_root/src/lib/pickles/compile.ml","/workspace_root/src/lib/pickles/sponge_inputs.ml","/workspace_root/src/lib/pickles/tock_field_sponge.ml","/workspace_root/src/lib/pickles/wrap_hack.ml","/workspace_root/src/lib/pickles/wrap_proof.ml","/workspace_root/src/lib/pickles/tag.ml","/workspace_root/src/lib/pickles/inductive_rule.ml","/workspace_root/src/lib/pickles/types_map.ml","/workspace_root/src/lib/pickles/per_proof_witness.ml","/workspace_root/src/lib/pickles/unfinalized.ml","/workspace_root/src/lib/pickles/requests.ml","/workspace_root/src/lib/pickles/timer.ml","/workspace_root/src/lib/pickles/fix_domains.ml","/workspace_root/src/lib/pickles/verification_key.ml","/workspace_root/src/lib/pickles/wrap_domains.ml","/workspace_root/src/lib/pickles/wrap.ml","/workspace_root/src/lib/pickles/wrap_deferred_values.ml","/workspace_root/src/lib/pickles/verify.ml","/workspace_root/src/lib/pickles/step_main.ml","/workspace_root/src/lib/pickles/step_branch_data.ml","/workspace_root/src/lib/pickles/step.ml","/workspace_root/src/lib/pickles/dirty.ml","/workspace_root/src/lib/pickles/cache_handle.ml","/workspace_root/src/lib/crypto_params/group_map_params.ml","/workspace_root/src/lib/crypto_params/crypto_params.ml","/workspace_root/src/lib/bignum_bigint/bignum_bigint.ml","/workspace_root/src/lib/snarky_field_extensions/field_extensions.ml","/workspace_root/src/lib/snarky_curves/snarky_curves.ml","/workspace_root/src/lib/mina_stdlib/list.ml","/workspace_root/src/lib/mina_stdlib/result.ml","/workspace_root/src/lib/snark_bits/bits_intf.ml","/workspace_root/src/lib/snark_params/snark_util.ml","/workspace_root/src/lib/snark_params/snark_intf.ml","/workspace_root/src/lib/data_hash_lib/data_hash.ml","/workspace_root/src/lib/crypto/kimchi_bindings/pasta_fp_poseidon/kimchi_pasta_fp_poseidon.ml","/workspace_root/src/lib/hash_prefixes/hash_prefixes.ml","/home/soc/codes/o1-labs/mina/_opam/lib/js_of_ocaml-compiler/runtime/jsoo_runtime.ml","/home/soc/codes/o1-labs/mina/_opam/lib/js_of_ocaml/js.ml","/workspace_root/src/lib/hash_prefix_states/hash_prefix_create/js/hash_prefix_create.ml","/workspace_root/src/lib/hash_prefix_states/hash_prefix_states.ml","/workspace_root/src/lib/test_util/test_util.ml","/workspace_root/src/lib/non_zero_curve_point/compressed_poly.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/local_ledger.ml","/workspace_root/src/lib/signature_lib/public_key.ml","/workspace_root/src/lib/sparse_ledger_lib/inputs.ml","/workspace_root/src/lib/dummy_values/dummy_values.ml","/workspace_root/src/lib/unsigned_extended/intf.ml","/workspace_root/src/lib/mina_numbers/nat.ml","/workspace_root/src/lib/mina_numbers/intf.ml","/workspace_root/src/lib/mina_numbers/zkapp_version.ml","/workspace_root/src/lib/mina_numbers/account_nonce.ml","/workspace_root/src/lib/mina_numbers/global_slot_intf.ml","/workspace_root/src/lib/mina_numbers/global_slot_legacy.ml","/workspace_root/src/lib/mina_numbers/global_slot_span.ml","/workspace_root/src/lib/mina_numbers/global_slot.ml","/workspace_root/src/lib/mina_numbers/global_slot_since_genesis.ml","/workspace_root/src/lib/mina_numbers/global_slot_since_hard_fork.ml","/workspace_root/src/lib/mina_numbers/hd_index.ml","/workspace_root/src/lib/mina_numbers/index.ml","/workspace_root/src/lib/mina_numbers/length.ml","/workspace_root/src/lib/mina_numbers/mina_numbers.ml","/workspace_root/src/lib/currency/intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/re/core.ml","/home/soc/codes/o1-labs/mina/_opam/lib/graphql_parser/graphql_parser.ml","/workspace_root/src/lib/fields_derivers_zkapps/fields_derivers_js.ml","/workspace_root/src/lib/data_hash_lib/data_hash_intf.ml","/workspace_root/src/lib/block_time/intf.ml","/workspace_root/src/lib/quickcheck_lib/quickcheck_lib.ml","/workspace_root/src/lib/mina_base/util/mina_base_util.ml","/workspace_root/src/lib/mina_base/account_id_intf.ml","/workspace_root/src/lib/mina_base/hash_prefix.ml","/workspace_root/src/lib/mina_base/data_hash.ml","/workspace_root/src/lib/mina_base/token_id.ml","/workspace_root/src/lib/mina_base/fee_excess.ml","/workspace_root/src/lib/mina_base/ledger_hash_intf0.ml","/workspace_root/src/lib/mina_base/frozen_ledger_hash0.ml","/workspace_root/src/lib/mina_base/signed_command_memo_intf.ml","/workspace_root/src/lib/mina_base/transaction_union_payload.ml","/workspace_root/src/lib/mina_base/signed_command_intf.ml","/workspace_root/src/lib/mina_base/side_loaded_verification_key.ml","/workspace_root/src/lib/mina_base/state_hash.ml","/workspace_root/src/lib/mina_base/verification_key_wire.ml","/workspace_root/src/lib/mina_base/ledger_hash.ml","/workspace_root/src/lib/mina_base/ledger_hash_intf.ml","/workspace_root/src/lib/mina_base/frozen_ledger_hash.ml","/workspace_root/src/lib/mina_base/digest_intf.ml","/workspace_root/src/lib/mina_base/zkapp_statement.ml","/workspace_root/src/lib/mina_base/prover_value.ml","/workspace_root/src/lib/mina_base/zkapp_call_forest.ml","/workspace_root/src/lib/mina_base/fee_transfer_intf.ml","/workspace_root/src/lib/mina_base/coinbase_fee_transfer_intf.ml","/workspace_root/src/lib/mina_base/coinbase_intf.ml","/workspace_root/src/lib/mina_base/pending_coinbase_intf.ml","/workspace_root/src/lib/run_in_thread/fake/run_in_thread.ml","/workspace_root/src/lib/mina_base/staged_ledger_hash_intf.ml","/workspace_root/src/lib/mina_base/stack_frame.ml","/workspace_root/src/lib/mina_base/sparse_ledger_base.ml","/workspace_root/src/lib/mina_base/sok_message_intf.ml","/workspace_root/src/lib/mina_base/proof.ml","/workspace_root/src/lib/mina_base/pending_coinbase_witness.ml","/workspace_root/src/lib/mina_base/call_stack_digest_intf.ml","/workspace_root/src/lib/mina_base/call_stack_digest.ml","/workspace_root/src/lib/mina_base/ledger_intf.ml","/workspace_root/src/lib/mina_base/mina_base.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/util.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/snarky_js_bindings_lib.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/snarky_js_node.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/std_exit.ml"],"mappings":"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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KCg4BPC;KACAC;;KC/WgBC;;;;;;;;;;;;;;KA0GVC;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA+HAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAGAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAoUgCC;;;;;;;;;;;;;;;;;;;;;;;;KAtjC5BC;KA9CZC;;KAIAC;;;;;;;;;;;;;KA+HAC;KCsyBEC;KACAC;KCGAC;KACAC;KCfAC;KACAC;KCDAC;KACAC;KCFAC;KACAC;KCUAC;KACAC;KCxFAC;KACAC;KCCAC;KACAC;KCpBAC;KACAC;KCHAC;KACAC;KCJAC;KACAC;KCrCAC;KACAC;KCmIIC;KA39BAC;;;;KCqYJC;KAOAC;KAOAC;KAOAC;KAOAC;KAOAC;KAOAC;KAOAC;KAOAC;KAOAC;;KAcAC;KAOAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KC/NEC;KAhJAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAuKWC;KC1KXC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KC2I8BC;KAANzvC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KC6c1B0vC;KAnKAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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AqnD;qB4LgJFmU;qBAGAD;qBAIAyC;qBACAD;;;qBG7CE5Z;qBAbAJ;qBA4CAM;qBAlBAD;qBH+CF2X;qBAmDAV;qBGlNMt7D;qBADAD;qBHgONw7D;;qBAIA6C;qBAIAC;qBAGAG;qBAGAD;qBAGAD;qBAMAe;qBAMAD;;qBlL1GE+nB;qByU6LIQ;kBTvXK;mBSmUqB;;;;;;;;uB7T9I1BroB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBZiBJ7H;uByU+LImwB;mBAlE0B;;;;uB7VvSb/2B;;;uByMiDjBxN;uBAaAM;uBzMjCExO;uBA7Beyb;uBoMyaf1jB;uBEjYI0mB;uBtMxCW9C;uByMHjBvwD;uBzMGiBswC;;;;;;uBoM6ZfI;uBADAD;uBpM5ZeG;;;;;;;;uBsMwCX2gB;;;;uBACAG;;;;;;;;;uBtMzCWS;;uBsM8CnBiB;uBtM9CmB/uF;uBCoDHC;uBDpDGC;;;;;;;uBsMqFnBivF;uBACAD;uBtMtFmBhB;;uBsM2FnBkB;uBtM3FmB5C;;;;;;uBsMiHX6C;;;;;uBtMjHW5zD;;;;;;;;uBUtBjBgnD;uBVsBiB4J;;;;uByMkGjBjN;uBAaAI;uBzM/GiBgP;;uByMyJjB7O;uBzMzJiBG;;;uBE6LJh6H;uBAAHF;uBF7LOumI;;;;;;;;;;uBoB0HjB+1B;uByU6PIe;mBAhF0B;;;;qBvJrQhCn7B;qBAIQ0B;;qBGkCNxK;qBAgBAG;;qBjLeF0I;qB4K0ZItf;;qBEzdIwf;qBG1CNhsD;qBH0CM8wC;;;;;;qBF6cJI;qBADAD;qBE5cIG;;;;;;;;qBoF+KE6a;;;;qBACAG;;;;;;;;;qBpF9KFS;;;;qBoBAQhtD;;qBpBWhBwuD;qBACAD;qBACAD;qBAGAM;qBAKAnB;;qBAsBAqB;qBACAD;qBACAR;qBACAb;qBAGAuB;qBA2CAxB;qBAEAD;qBACAD;;qBAWAD;qBAGAD;qBAtCQ6B;;;;;;;;qBAeRL;qBAMApB;qBAEAD;qBACAD;;qBAIAtG;qBAOAqG;qBAGAD;qBAIAuB;qBACAD;qBGhCE5K;qBAkBAC;qB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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAgBAE;qBAhBAF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAwBAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAIAC;;;;;;;;;;qBAJAD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAWAE;;;;;;;;;;qBAXAF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAkBAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAIAC;;;;;;;;;;qBAJAD;;;;;;;qBAIAC;;;;;;qBAJAD;;;;;;;;;;;;;;;;;;;;;;;;;;qBAIAC;;;;;;qBAJAD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAWAE;;;;;;;;;;qBAXAF;;;;;;;qBAWAE;;;;;;qBAXAF;;;;;;;;;;;;;;;;;;;;;;;;;;qBAWAE;;;;;;qBAX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;;;;;;;;;;;;;;;;;;qDpLgEJnzB;;;4BoLhEI;;;;;qEAU4B;;;wBAV5B,gDAU4B;;wBAV5B;;;;;;;;kDX1DyDozB;2BW0DzD;;;;;;;;6BvDkUJnxB;;;2BuDlUI;;;;;;;;;;;;oCvDkUJA,gBAjGAP;oCA0IAW;;;2BuD3WI;;;sDAU4B;;;;;wBAV5B;iCACE;;2BACA;;;2BACA;;iCACA;;2BACA;;;;;iC7LugBJvqC;;;2B6LtgBI;;;;;;;2BACA;;;;;;;;;;;kC7LqgBJA,ebveE8c;iCayYF5c;;;2B6LraI;;;;;oEAC0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAa5B,yBAAgD;;;;;;;;;;;;;;;;;uBXjFS+1D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wB;0BFIrD,oCACK;;;0DAA0B;4CAGA,gCAAiB;sBauH1D;;;;;;;;;;;;;;;;uBX/H+DkB;;;;;;;;;;;;;;;;;;;;;;;;uBW+H/D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBArHoC;;;;;;kBAwHZ;;kBpXjIpBv9B;kBI4HFsV;kBmUrIS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBnUoITD;kBJ5HEtV;kBqXVN;;kB9CEa;mB8CFb;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAIQ;wFAA0C;kBAIA;;kBrXG5CC;kBI4HFsV;kBADAD;kBJ5HEtV;kBsXRN;;kBAKG;;kBtXIGC;kBI4HFsV;kBADAD;kBJ5HEtV;kBuXVN;;kBhDEa;mBgDGb;;;;8C,gCAAgD;mBAAhD;0C;mBAAA;;sB,wCAAgD;mBAAhD;;sBrD6KE;mBqD7KF;;sB,O1D0aI4Q,+B0D1a4C;kBAAhD;kBhDHa;kBgDQX;;;;;;;;kBhDRW;;;sBgDiCX,oDAAuE;kBAMlB;;kBvX9BjD3Q;kBI4HFsV;kBADAD;kBJ5HEtV;kBwXVN;;kBjDEa;mBiDFb;;sBAwBiC,sDAA+B;mBAxBhE;;sBA4BmC,yDAAiC;mBA5BpE;;sBAgCmD;sEAAiC;mBAhCpF;;sBAoC4C;sEAAiC;mBApC7E;;sBAwCuC;sEAAiC;mBAxCxE;;sBA4CyC;sEAAiC;mBA5C1E;;sBAmDM;uFAGC;mBAtDP;;sBA0D0C;8EAA0C;mBA1DpF;;sBAiEM;8EAEC;mBAnEP;;sBAuE8C;8EAA0C;mBAvExF;;;sBA8EM;;;;;;;iCAIC;;mBAgBD;;;;;;;kC,sCAA8C;mBAA9C;;;;;;iFAA8C;mBAA9C;;;;;;6DAA8C;mBAA9C;;;;;;;;sBAQgB;oDAA8B,iCAAa,EAAC;;;sBAGlD;;uBACM,iB/L2LTL;uB+L5LG;sBACM;;wBACZ;0BAAgB;;;;2BACV;qCAEM,oBADF;0BAFM;;;sBAKlB,QAAC;;;;;;uBnESCvB;;;;;;;;;;;;;;;;;;;;uBHioBN4iC;uBAGE/kG;;;;;;;;;;;;wBsEzmB4B;iD,0BAAgC;;wBACpC,uCAAwC;;;0BAQnC,kBtE6lB/B+kG,gCsE7lBqE;;;wBAenE;yBtEzKF3rD;;;;;yBsEyKE;;;;;;;;;iD,6BAA2C;wBAA3C;;;;;qFAA2C;wBAA3C;;;;;iEAA2C;wBAA3C;;;;;;0BAQgB;wDAA8B,iCAAa,EAAC;;0BAGlD;wCtEskBVp5C;2BsErkBgB,iB/L6GT0jE;2B+L9GG;0BACM;;4BACZ;8BAAgB;;;;+BACV;;+BAGJ,0BtE1LRtqB;;+BsEwLgB;8BAFM;;;0BAUlB,QAAC;;;;;kCnE1EC+oB;;;;;;;;;8BHioBN4iC;8BAGE/kG;;;;;;;;;;;;8BGpoBIgiE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBHooBJhiE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBsEriBiC;;kBxXjNjCgkE;kBI4HFsV;kBmUrIS;;;;;;uBrB+vBPt5E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBvF5dAqf;;;;;;;;;;;;;;;qB0FxKI2iD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBH+eR/D;;;;;;;;;;;;;;sBG/eQ+D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBjTSNqX;kBJ5HEtV;kByXVN;;kBlDEa;mBkDFb;;sBAmBqB;+BpEqLf/jE;wBCtD2B,sDAA8B;+BDsDzD8E;wBClD4B;wBA9ChC,UAEc,qCACF;wBA2CoB,MAzCxB;wBACR,qBAAyB,kBAAO;wBAAhC,QAwCgE;+BD+C9DigG;wBC5CuC;wBAtCzC,iBACiB;wBAqCwB,IAnCvC,aAAQ,iBAAe;wBACvB;;;4BACU;;6BAxFP,iBACE,oBAEH;oDAwFa,wBAA+D;wBAJ9E,QAkCoF;;wBmEnIpE,iBnEwCQ;+B/HobtBz6D,uCkM5d4C;;mDAQzB,2BAA0B;;;wBAe7C;;;;;;;;0BAaU;;2BACM,iBhM8OTo5B;2BgM/OG;0BACM;;4BACZ;8BAAQ;8BACR;8BADQ;;;0BAGV,QAAC;;;;;kCpE8DCvB;;;;;;;;8BAwEN4iC;8BAGE/kG;;;;;mBoExMN;;;;uBpEwMMA;;;;;;;;;;;;;;kBoE7G6D;;kBzXhF7DgkE;kBI4HFsV;kBmUrIS;;;;;uBlBsMPt5E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBjTlEFq5E;kBJ5HEtV;kB0XVN;;kBnDEa,ImDFb;kBAGA;;;;;;sC;;kBnDDa,ImDCb;kBAoBI;;;;;;sC;;kBnDrBS,ImDqBT;kBAOA;;;;;;sC;;kBAKD;;kB1XxBGC;kBI4HFsV;k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gEhE,sB,gBqCxkDHA;wBrCykDA;kEqCzkDAA,qB2C9bqD;;wBhF2gEjD,iCqC7kDJA;wBrC6kDI;;6CqC7kDJA;wBrC+kDyB,QgF1gEqC;;wBhF8gEhE,qBACE,gBqCplDAA,gBrColDyB;wBADhB;;qEqCnlDTA;uC2C1bgF;;wBhFkhE7D;iCqCxlDnBA,WrCwlDmB,+BqCxlDnBA,Y2CzbsE;;wBhFuhEtE;iCqC9lDAA,WrC8lDA,sBqC9lDAA,e2Cxb0E;;wBhF4hE1E;iCqCpmDAA;iCrComDA,uCqCpmDAA,e2CrbwD;;wBhF+hExD;iCqC1mDAA;iCrC0mDA,oCqC1mDAA,e2ClbkF;;wBACjE,kB3CibjBA,iB2Cjb4D;;wBhFm9D9D,qBACE,gBqCniDAA,gBrCmiDyB;wBADhB;0EqCliDTA,kB2Chb8E;;wBhFu9D3D;iCqCviDnBA,WrCuiDmB,8BqCviDnBA,Y2C/aoE;;wBAC3C,sB3C8azBA,mB2C9a4E;;wBhF29D5E;iCqC7iDAA,WrC6iDA,qBqC7iDAA,e2C7awE;;wBhFg+DxE;iCqCnjDAA;iCrCmjDA,sCqCnjDAA,e2C1auD;;wBhFm+DvD;iCqCzjDAA;iCrCyjDA,mCqCzjDAA,e2CvagF;;wBAC9D,kB3CsalBA,iB2Cta8D;;wBhFohE3C;iCqC9mDnBA;iCrC8mDmB,4CqC9mDnBA,Y2CnaoE;qDAG5C,wBAAsC;oD3C+ZtD+uC,QAAQC;wBAEpB;;oDADIhvC,WADQ+uC,QAAQC;;uD,OpCk3DhBl8B,UoCj3DA9S,mB2C7Z2D;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBA8J3D;;;;;kBpDzZO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wBoDqec,mCAAyB;;wBhFq1CV,0CgFl1C4B;;;0BASnC,oDAAsC;;;;0BhF21CrE,egFt1CE;0BhF0rBF;4BAG6C;qFAA8B;0BADnE;;8C/IlqCJvI,oB+IkqCyB;yCgF5rB8C;;;wBAlD3E;;;;;;;;;;;;;;;iD,6BAA2C;wBAA3C;;;;;qFAA2C;wBAA3C;;;;;iEAA2C;wBAA3C;;;;;;0BAUgB;wDAA8B,iCAAa,EAAC;;0BAG1D,kBAAoC,yBAAO;0BAnFrC;0BACP,qBACE;0BAFK;;4BAKF;yD;0BAAA,sBACO;0BACY,qBA4EgD;;;;;;;;;;;;;;wBhFwrDrE,8CgFr4DkD;6CAErC,WAAI;;wBACL,uB,mBAAuB;;wBhFqlDrC,sDgFplDqE;;wB;uChFwlDvE,2CgFvlDmD;;wBhF0nDnD,8CgFvnDoD;;wBhF6nDlD;yFgF1nDmE;;wBhF8nD/D;;;wBACqB,QgF9nDgB;;wB;;iChFmoD3C;yCgFloD6D;;wBhFqoDrB,kDgFpoDW;;wBhFuoD/C,4CgFtoDmD;;wBhF0oDnD;mCgFzoDmE;;wBhF6oDnE,0DgF5oD2D;;wBhFglDzD;;;wBACqB,QgFhlDU;;wB;uChFqlDrC,mDgFplDuD;;wBACpC,mCAA0B;;wBAxLrC,sCAyL+D;;wBhFwlDnE,yCgFvlD6C;;wBhF2lD7C,0DgF1lD6D;;wBhF8lD7D,uDgF7lDqD;;wBhFimDnD;;;wBAEqB,QgFlmDoB;0CAEjC,QAAC;6ChFwoDf,oCgFvoDyC;2ChF0oD1B,oBgFzoDU;yChF0oDZ,mBgFzoDQ;;wBACA,mCAA4B;;wBAC5B,mCAA4B;;wBACxB,uCAAgC;;wBhF6pDzD,+CgF5pD6D;;wBhFiqD7D,2CgFhqDiD;;wBhFoqDjD,oCgFnqD6C;6CAC3B,iCAAyB;;wBhF0qD3C;;;;gDAA8C,6BAAQ,EgFzqDX;;wBhF6qD3C,kDgF5qDyC;yChForDzC,gCgFnrDiC;2CAClB,+BAAsB;wChFyrDX,+BgFxrDK;4ChF+rD/B,mCgF1rDyC;;wBhFmsDzC,wCgF9rDqD;;wBhFksDjD,wCgFjsD6C;2ChFqsD7C,qCgFpsDmC;;wBhFwsDnC,oCgFvsDqC;;wBhF2sDrC,yCgF1sD2C;;wBhF8sD3C,wCgF7sD6C;;wBhFktD/C;;;;;sCgFjtDqD;;wBhFwtDrD;;;;;sCgFvtDmD;;wBhF8tDnD;;;;;sCgF7tDmD;;wBhFouDnD;;;;;sCgFnuDiD;;wBhF2uDjD;;;yCgF1uD+C;;wBhFivDjD,sCgFhvDyD;4ChFovDzD,oCgFnvDuC;;wBhF6vDvC,qDgFvvD6E;;wBhF2vD7E;qEgFxvDwD;;wBhFkwDpD,sCgF/vDqC;0ChF4wDf,iCgFjwDS;;wBhFowDnC,oDgFnwD6E;;wBhFwwD3E;;;kCgFrwD8C;;wBhF+wDhD,2DgF3wDqD;;wBhFqxDrD,8CgFlxDqE;;wBhFsxDrE,uCgFrxDmD;;wBACzC,uB,O/EopENob,0B+EppEuB;;wBACb;0BhFuxD+B,8CgFvxDV;2ChF0xDnC,8BgFzxDiC;;;wBhFmyDjC;;;;;mCgFhyDiF;;wBhFwyDhC,uCgFryD4B;;wBhFwyD7E,kDgFryDqD;;wBA1QC,kDA6QM;;wBAxT5D,gDAyToE;wDAlT3C,oBAmT8B;;wBAhTvD,kDAiTmE;;wBhF6wD7B,uCgF7nDuC;;;0BAQ5C,qCAAoC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BzF7bnEP;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kByF0lBH;;kB3XrqBGuV;kBI4HFsV;kBmUrIS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uB3B0BXyrB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBxS0GE1rB;kBJ5HEtV;kB4XVN;;kBrDEa;mBqDFb;sCtC0F0B,uCsC5DgD;mBA9B1E;;sBxC2NE,gBAAYylC;wBACO,IAAbrtD,WADMqtD;wBAKH,sB,UAJHrtD;wBAEF;yBADE7wH;0BACF;4BACE,4BAHA6wH;;;0CACA7wH,EAFMk+K,MAQI,CwCnMwD;mBAhC1E,0BAkDmD,wBAAe;mBAlDlE;;sBAqD6B;sBtEFL;;;mDsEEwC,4BtEFmB,EsEEC;mBArDpF;;sBAyDI,0BACE,4BAAmB;sBADM;qEACL;mBA1D1B;;sB,I5CgqBMrtD;6C4Clfe,U5CkffA,gB4ClfuC;;wBACL,mC5CiflCA,iB4Cjf6E;;wBAG/E,wC5C8eEA,iB4C9ekD;;wBvF0rCpD,qBAEkB,U2C9sBhBA,gB3C8sBoC;wBADpC,gC2C7sBAA;wB3C6sBA,+CuFxrCyD;;4CvFqqCV,U2C1rB/CA,iB4CteqC;;wBvFmqCnB,U2C7rBlBA,W3C6rBkB,W2C7rBlBA,sB4CreuC;0CAC3B,iB5CoeZA,a4CpeiC;;wBAzDf,U5C6hBlBA,W4C7hBkB,Y5C6hBlBA,c4CneyC;;wBAtDvB,U5CyhBlBA,W4CzhBkB,gB5CyhBlBA,c4CleiD;;wBvFwrC9B,U2CttBnBA,W3CstBmB,a2CttBnBA,e4CjemC;;wBvF2rCrC,4B2C1tBEA,c4CheuD;;wBvF8rCpC,U2C9tBnBA,W3C8tBmB,c2C9tBnBA,e4C/d+B;;wBvFksCxB,U2CnuBPA,W3CmuBO,oB2CnuBPA,e4C9d6C;;wBAGvC,gC5C2dNA,2B4C3dwD;oD5C0dhD2rC;wBAEZ,oCADI3rC,WADQ2rC;;uD,UACR3rC,mB4Cvd+D;;;;;;;;;;;;;;;;;;;mBAzMrE;kBAmUM;kBrDjUO;;;;;;;;;;;;;;;;;;;;;;;8CqDyYS,4BAAoB;4CvFwxBV,gCuFvxB2B;;;0BAQlC,wCAA4B;;;;0BvFsyBjD,euFlyB0B;0BvFsab;;8CzI5yBTvI,oByI4yB8B;yCuFtaiD;;0BAI/E;+CAAa,iBAAoC;;;wBAlDrD;;;;;;;;;0BAUgB,+BAAoB,wBAAK,EAAG;;0BAG1C,kBAAoC,yBAAO;0BA9ErC;0BACP,qBACE;0BAEH;4BAGQ;qCACE;qCACA,yBAA4B;0BAHpC,gCAAgB,2BAwEuD;;;;;;;;;;;;;4CAxKzD,YAA4B;+CvFggCiB,kCuF//Bf;yCvF8/BjC,kBuF7/Ba;2CvF+/BX,oBuF9/Be;6CvF+/Bf,kBuF9/Be;0CvF+/BhB,mBuF9/Bc;gDvF+/BV,qBuF9/BkB;0CvF+/BtB,mBuF9/Bc;gDvF+/BV,qBuF9/BkB;2CvF+/BvB,gBuF9/Ba;+CvF+/BT,oBuF9/BiB;0CACpB,mBAAc;2CvF+/Bb,oBuF9/Be;yCvF+/BhB,kBuF9/Bc;;wBvFihCiC,+CuFhhCf;2CvF8/B9B,oBuF7/BgB;4CvF8/Bf,qBuF7/BiB;0CvF8/BnB,mBuF7/Be;0CvF8/Bf,mBuF7/Be;yCvF8/BhB,kBuF7/Bc;6CvF8/BV,sBuF7/BkB;6CvF8/BlB,sBuF7/BkB;8CvF8/BhB,uBuF7/BoB;;wBvF8/Bd,uB,oCuF7/B0B;oDvF8/B1B,6BuF7/B0B;;wBACzB,iCAAsC;wCvF6/BZ,gCuF5/Bf;2CvF6/BqB,kCuF5/Bf;;wBvF6/BuB,sCuF5/Bf;;wBvF+/Bf,sCuF9/BmB;wCAC5C,4BAAwB;wCACxB,4BAAwB;2CACrB,+BAA2B;8CvFkgCiB,iCuFjgCf;8CvFkgCe,iCuFjgCf;6CvFkgCa,gCuFjgCf;;wBvFogCF,0CuFngCsB;;wBvFsgCX,sCuFrgCW;4CvFsgCH,mCuFrgCf;;wBvFsgCyB,oCuFrgCf;;wBvFwgChB,wCuFvgCoB;0CAC5C,8BAA0B;gDACtB,gCAA8B;;wBAC1B,oCAAkC;2CvFwgCC,kCuFvgCf;;wBvF0gCK,iDuFzgC6B;;wBvF6gC5E,4CuF1gCyD;;wBvF8gCpB,uCuF3gCmB;;wBvF8gC3B;4D,gBuF7gCiB;;wBvFghCN,0CuF/gCsB;;wBvFmhCzB,sCuFlhCmB;0CvFqhCD,iCuFphCf;wCvFqhC5B,iBuFphCY;;wBvFqhC6C,sCuFphCf;4CACxC,QAAC;0CACD,QAAC;;;wBvFwhCf;yFuFrhC4E;;wBvFwhC3B,uCuFrhCiC;;wBvFwhClF,kDuFrhC0D;;;wBvFyhC1D;;;;;;mCuFrhCqF;6C,iCAIzC;;wBvF6hC3B,oDuF1hC6C;;wBvFkiC7C;;;yBA5QX;wBADA;0EuFpxB8C;;;wBApQpD,gDAuQoE;wDAnQ/C,oBAoQkC;;wBAhQvD,kDAiQmE;gDA4I/C,8BAAoB;8CvF62BZ,6BuF52BkC;;;0BAS1D,2CAAoE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBA+IzE;;kB5X9jBGowB;kBI4HFsV;kBmUrIS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBnUoITD;kBJ5HEtV;kB6QVN;;kBAkEG;;kB7QvDGC;kBI4HFsV;kBADAD;kBJ5HEtV;kB6XVN;;kBtDEa;mBsDFb;oC;mBAAA;;;;;;;;uBhH2MW9uE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBgH3MX;;;;;;;;;uBhH2MWA;;;;;;;;;;;;;;;;;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DLt2B;kBJ5HEtV;kBwYVN;;kBjEEa;mBiEAb;;mBAA0C;oC;kBAAA;kBjEA7B;mBiEKP;;mBAAqC;oC;mBAAA,kBzE8EvCuR,c/HPArD;mBwMvEuC,kB3EwGvCsB;mB2ExGuC;;;qBzE8EvC+B;qB/HPArD;qB6HiCAsB;;;;;;mB2ExGuC;;;;qB3SqqBjC/nC;qB8D3eJxB;;;;;;;;;qB4B6CA2G;qBADAD;;;;;;;;;qBsFjBK+oB;;;;mB2HrNgC,qB;mBAAA;;;;kBAkBvC;kBAED;;kBxYhBGuK;kBI4HFsV;kBADAD;kBJ5HEtV;kByYKN;;kBAsHG;;kBzY1HGC;kBI4HFsV;kBADAD;kBJ5HEtV;kB0YVN;;kBAW4B,sBAAC,WjN8RhBH;kBiNzIV;;kB1YrJGI;kBI4HFsV;kBADAD;kBJ5HEtV;kB2YVN;;kBpEEa;mBoEWP;;mBAAmC;oC;mBAAA,kB5EkHrC6R,gB/HqCApD;mB2MvJqC,kB9E4QrCsB;mB8E5QqC;;;qB5EkHrC8B;qB/HqCApD;qB6HqHAsB;;;;;;qBtI+XE/iC;qBAaAtF;qBACAxB;;kBoNzpBmC;;qB5EkHrC2rC;qB/HqCApD;qB6HqHAsB;;;;;;qBtI4YEroC;qBAbAsF;qBAcA9G;;kBgJpqBO;mBoE4BT;;mBAAmC;oC;mBAAA,kB5EiGnC2rC,gB/HqCApD;mB2MtImC,kB9E2PnCsB;mB8E3PmC;;;qB5EiGnC8B;qB/HqCApD;qB6HqHAsB;;;;;;qBtI4YEroC;qBACAxB;qBsFreKqX;kB8HnK4B;;;qB5EiGnCs0B;qB/HqCApD;qB6HqHAsB;;;;;;qBtI4YEroC;qBsFpeK4V;qBtFqeLpX;;kBoNxoBiC;kBpE5B1B;mBoEyCP;;mBAAmC;oC;mBAAA,kB5EoFrC2rC,gB/HqCApD;mB2MzHqC,kB9E8OrCsB;mB8E9OqC;;;qB5EoFrC8B;qB/HqCApD;qB6HqHAsB;;;;;;mB8E9OqC;;;;qBpN0nBnCroC;qBACAxB;;;;;;;;;qBAbA+G;qBADAD;;;;;;;;;;;;qBsCroBF3iG;mB8KwBqC,2B;mBAAA;;;;;;;;;;;;;;;;sBAkBvC,0CAA6D;mBAlBtB;;sBAqCvC,sDAA4E;kBAK3D;;kB3Y1Eb41H;kBI4HFsV;kBADAD;kBJ5HEtV;kB4YVN;;kBrEEa;mBqEIT;;mBAA2C;oC;kBAAA;kBA4B+B;;kB5YvBxEC;kBI4HFsV;kBADAD;kBJ5HEtV;kB6YVN;;;kBtEEa;mBsEKP;;mBAAiC;oC;mBAAA,mB9EoGnCwR,c/HkBAlD;mB6MtHmC,mBhFuRnC0B;mBgFvRmC;;;qB9EoGnCwB;qB/HkBAlD;qB6HiKA0B;;;;;;mBgFvRmC;;qBlTa/BhzB;;;;;;;;;;;;;;;;;;;;;;;;;;mBkTb+B,qB;mBAAA;;;;;mBAgBnC;;mBAAiC;oC;mBAAA,mB9EoFjCw0B,c/HkBAlD;mB6MtGiC,mBhFuQjC0B;mBgFvQiC;;;qB9EoFjCwB;qB/HkBAlD;qB6HiKA0B;;;;;;;;qBhD7FO3yB;kBgI1K0B;;;qB9EoFjCm0B;qB/HkBAlD;qB6HiKA0B;;;;;;;qBhD7FO5yB;;;kBgItJiE;;kB7YhCtE6iB;kBI4HFsV;kBADAD;kBJ5HEtV;kB8YVN;;kBAauC;;kB9YFjCC;kBI4HFsV;kBADAD;kBJ5HEtV;kB+YVN;;kBxEEa;mBwEGT;;mBAI4D;oC;mBAAA,8BAJ5D,QAI4D;;;sBAJ5D;;;qEAI4D;;;;sBAJ5D,gDAI4D;;;sBAJ5D;;;+BACE,gBACA,iBACA,SAC0D;;;;kBxEPnD;mBwEOmD;;;;;;;;;;;;;;;;;;qBpZ2D1DhpB;qBAJAJ;qBAEAE;qBACAC;qBAJAJ;qBAEAE;qBAOAO;qBADAD;qBAGAG;qBADAD;qBAJAJ;qBACAC;;;;;;;;;mBoZ7D0D,2B;mBAAA;;;kBAMlB;;kB/YJxC+oB;kBI4HFsV;kBADAD;kBJ5HEtV;kBgZVN;;kBzEEa;mByEuBX;;mBAA2C;oC;mBAAA,mBjF0GzC8R,e/HuDAnD;mBgNjKyC,mBnFkSzCuB;mBmFlSyC;;;;;;;;;uBjF0GzC4B;uB/HuDAnD;uB6HiIAuB;;;;;;;uBtIQEpjC;uBAcAgyB;;mByNxTuC;;;;;uBjF0GzCgT;uB/HuDAnD;uB6HiIAuB;;;;;;uBtIQEpjC;;uBAcAgyB;;mByNxTuC;;;;;;;;;qBzN2SvC/xB;qBADAD;;;mByN1SuC;;sB;;wBA4BlB,+CAAyC;6CAC9C,kBAAO;;wBACR,oDAAkB;;wBACd,8CAAyC;6CAC7C,oBAAM;6CACD,wBAAQ;;wBAGpB;wBACR;;oEAIM;;;;;;;;;;kBAiBV;kBAmCkE;;kBhZ3G9DmzB;kBI4HFsV;kBADAD;kBJ5HEtV;kBiZVN;;kB1EEa;mB0EKP;;mBAA4C;oC;mBAAA,mBlFqG9CyR,a/HwBAlD;mBiN7H8C,mBpF8R9C0B;mBoF9R8C;;;qBlFqG9CwB;qB/HwBAlD;qB6HiKA0B;;;;;;;qBtIkFEtoC;qBb9QEwb;qBenCEb;kB8IpEG;mB0EgBP;;mBAAgC;oC;mBAAA,mBlF0FlCmvB,a/HwBAlD;mBiNlHkC,mBpFmRlC0B;mBoFnRkC;;;qBlF0FlCwB;qB/HwBAlD;qB6HiKA0B;;;;;;mBoFnRkC;;qBrPA9BpgC;;qB2BqWFlI;qBb9QEwb;;qBkBhFJ9xD;qB6CsIEw5C;qBAJAJ;qBAEAE;qBACAC;qBAJAJ;qBAEAE;qBAOAM;;qBAEAE;qBADAD;qBAHAH;qBACAC;;;;qBhD5FIuX;;;;;mBwNpD4B,qB;mBAAA;;;;;;;;;;;;;;;;;;;kBAWpC;kBAS4E;;kBjZ3BxE2d;kBI4HFsV;kBmUrIS;;;qB9F6JP1qC;qBAJAJ;qBAEAE;qBACAC;qBAJAJ;qBAEAE;qBAOAM;;qBAEAE;qBADAD;kBrO9BFqqC;kBJ5HEtV;kBkZVN;;kB3EEa;mB2EGP;;mBAAkC;oC;mBAAA,mBnFwIpC+R;mBmFxIoC,mBrFgUpC5B;mBqFhUoC;;;qBnFwIpC4B;;qBFwLA5B;;;;;;mBqFhUoC;;;qBvYoHtCta;qB4KsSIjuB;qBEzVIyxB;;qBG5CNx+D;qBH4CM48D;;;;;;qBF6UJS;qBADAnC;qBE5UIiC;;qBF4UJjC;qBE5UIgC;;;;;;;;;mByNjE8B,qB;mBAAA;;;;;;;kBAUtC;kBAS8E;;kBlZb1EkI;kBI4HFsV;kBADAD;kBJ5HEtV;kBoZVN;;kB7EEa;mB6EGP;;mBAAkC;oC;mBAAA,mBrFgJpCgS;mBqFhJoC,mBvFiVpC5B;mBuFjVoC;;;qBrFgJpC4B;;qBFiMA5B;;;;;;mBuFjVoC;;qBjasDlCtgC;qBA7Beyb;qBoMyaf1jB;qBEjYI0mB;qBtMxCW9C;qByMHjBvwD;qBzMGiBswC;;;;;;qBoM6ZfI;qBADAD;qBpM5ZeG;;;;;;;;qBsMwCX2gB;;;;mB2NjE8B,qB;mBAAA;;;;;;kB7EH3B,I9IuEHihD;kB2NpE8B;kBAUtC;kBAS8E;;kBpZb1EztC;kBI4HFsV;kBADAD;kBJ5HEtV;kBqZVN;;kB9EEa;mB8EFb;;;;qBFuFUstC;;;;mBEvFV,2B;mBAAA;;;;;;;;;;qB5CUiEK;;;;;;;;mB4CVjE;;sBAkBM;;;gC3OuFEb;;;;;;;yC2OpFsD;mBAGvB;;;;;;;;;;;;;;;;;;;;;;kB9EtB1B;mB8EsB0B;;;;;;;;;;;;qBlY+J/B7yC;;;;;;;;;;;;;;;;;;;;;;;;;;mBkY/J+B,qB;mBAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAmDrC;kBAS8E;;kBrZzE1EgG;kBI4HFsV;kBADAD;kBJ5HEtV;kBsZVN;;kB/EEa;mB+EIP;;mBAAgD;oC;mBAAA;;;sBAOhD;;kFACgD;wB3EqRhDge;;;;;;;;;;;;;;;;;;kBJjSO;mB+EsBP;;mBAAiC;oC;mBAAA,mBvF4DnC1M,c/HbArD;mBsN/CmC,mBzF+EnCqB;mByF/EmC;;;qBvF4DnCgC;qB/HbArD;qB6HgCAqB;;;;;;mByF/EmC;;;;;;;;;;;;;;;;;;;;;;;;;;;;wC;mBAAA;;;;;;kBAapB;;kBtZ1BbrP;kBI4HFsV;kBADAD;kBJ5HEtV;kBuZRN;;kBAwByB;;kBvZfnBC;kBI4HFsV;kBADAD;kBJ5HEtV;kBwZVN;;kBjFEa;mBiFIT;;8C,gCAAwD;kBAAxD;kBAW2B;;kBxZNzBC;kBI4HFsV;kBADAD;kBJ5HEtV;kByZVN;;kBlFEa;mBkFGP;;mBAAsC;oC;mBAAA;sC5FoWxCqQ;mB4FpWwC;;;;;qB5FoWxCA;;;;;;mB4FpWwC;;;qB9YgI1CjpB;qB4K0ZItf;;qBEzdIwf;qBG1CNhsD;qBH0CM8wC;;;;;;qBF6cJI;qBADAD;qBE5cIG;;;;;;;;qBoF+KE6a;;;;mB4IhPgC;oC;kBAAA;;kBAU1C;kBASkF;;kBzZb9E0Y;kBI4HFsV;kBADAD;kBJ5HEtV;kB0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xC;kBAKF,0BAPEC;kBA+KuD;;kB/Z9KvD9xC;kBI4HFsV;kBADAD;kBJ5HEtV;kBgaVN;;kBAqDG;;kBha1CGC;kBI4HFsV;kBADAD;kBJ5HEtV;kBiaVN;;kB1FEa;mB0FFb;gCAGoB,kBrP4BZksC,aqP5BY,UAA+B;mBAHnD;gCAIoB,6BrP2BZD,gBqP3B+C;mBAJvD;sC,kBrP+BQI,uBqPxB0D;mBAPlE,oB,4BAQwC;mBARxC,yB,kBrP+BQH,eqPdgD;mBAjBxD;;sBAkBwC,gCrPahCD,gBqPboD;mBAlB5D;;;;;wB/QoBMJ;;;;;;mB+QpBN;;;;;;;;;kB1FEa;mB0FFb,qBAqDwB,kBAAgB;mBArDxC,0BxSuRMoG;mBwSvRN;;;;uBxSuRMA;;;;mBwSvRN;kBAwImE;;kBja7H7DhyC;kBI4HFsV;kBADAD;kBJ5HEtV;kBkaRN;;kBAmIG;;kBla1HGC;kBI4HFsV;kBADAD;kBJ5HEtV;kBmaVN;;kB5FEa;mB4FFb;;sBAKwC,iC9MmKpCyrB,yB8MnKgE;mBALpE;;sBAMwC,kB9MoKpCD,iB8MpKoC,oBAAkB;kBAOW;;kBnaF/DvrB;kBI4HFsV;kBADAD;kBJ5HEtV;kBoaAN;;kB7FRa,kC6FQb;kB/LqHM/4B;;;;sB;wDzDhGEilE;;;kB2J7BK;mB6FuBDiG;mBAIAC;6BAAY7qL;sBAAI,sDAAJA,EAAW;mBAUvB8qL,4BAAsB,SAAE;2BAVxBD,YAUAC;;;;qB1PkEJvF;;;;8C;mB8LwBuDwF;2B4DpGnDF,YAUAC;2B7OgVN1qE,Yb9QEwb;mC;kB6JvGK;mB6F2DL;;;;;;;;;;qCP8IG2rD,mBlZxCXwC;;mByZtGQ;mBAKyB;oC,UALzBiB;mBAYA;;;;;;;8DzZ0FRlD;;mByZ1FQ;mBAIyB;oC,UAJzBoD;mBAQA;;;;;;;8DApBKD;;mBAoBL;mBAIyB;oC,UAJzBG;;;6B5DgDuDL;;8B4DpElDE;iCzZsGbhD,iByZ1FakD;mCzZ0FbrE,kByZlFauE;mCzZkFbrC;kByZ3EM;;;;;;;;gCzZ2ENe;;;kB4TjKa;mB6FiGkB;6BAGbl5G,GAAGF,IAAK,kBxPvElBk0G,WwPuEUh0G,MAAGF,MAAmC;mBA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kDAZJypN;4BA+BI;6BA+BR,4BAjCEJ;6BAiCF,2BAIExvR,GAFoB,OAEpBA,SAAqB;6BAItB,0BAdC6vR;6BAgBC,wBA5CyBN;6BA4CzB;;;8BAHH9vR;;iD2IkUAggH,axLjeFi5B,a6C+JEj5I;;;;;;uC2IkUAggH,aXndE2lE,ahIiJF1rG;;;4BAtCQ,IAiDW8mC,W2IkInBJ,Y3ItLYxhF;qCAoDO4hF;;;;;0BAGnB,8BAAa;sBAuR6D;;sB5C1c1E24B;sBI4HFsV;sBADAD;sBJ5HEtV;sB6gBVN;;sBAwQiB;;sB7gB7PXC;sBI4HFsV;sBADAD;sBJ5HEtV;sB8gBVN;;sBAGsC;;sB9gBQhCC;sBI4HFsV;sBADAD;sBJ5HEtV;sB+gBVN;;sBAkDsB;;sB/gBvChBC;sBI4HFsV;sBADAD;sBJ5HEtV;sBghBVN;;sB/E+EoB,I+EqEO56C,aAahB3lF,QAAS,cAATA,SAA4B;sBA4Xf;;sBhhBlhBlBwgI;sBI4HFsV;sBADAD;sBJ5HEtV;sBihBVN;;sBAiDQ;;sBjhBtCFC;sBI4HFsV;sBADAD;sBJ5HEtV;sBkhBVN;;sBA4U8E;;sBlhBjUxEC;sBI4HFsV;sBADAD;sBJ5HEtV;sBogBVN;;sBAsB6B;sBnEyDT;;iCmE5BOv3B;0BQnBF,0BCwBf,ETJW1vC;0BACjB,SAxByB/xE;4BAyBrB,eQXKw5E;8BACA,sBAREj6E,KAOFi6E,IACPxL;iCAVyB,URkBV+D;;;+BQfsD,ORetDA,QQhBNxyE;8BRgBMwyE,UQRf/D;sCRUsE;4BAApE,OAHmByzC;4BAGnB;oCAAoG;0BAzB3E,aAAJzhH,EAsBFyhH;iCSKrBlhH,CTFyG;sBA4Q5G;;sBpgBvTG04I;sBI4HFsV;sBADAD;sBJ5HEtV;sBmhBVN;;sBAmB6B,uBAAuB;sBAmC1B;;sBnhB3CpBC;sBI4HFsV;sBADAD;sBJ5HEtV;sBohBVN;;sBA4DG;;sBphBjDGC;sBI4HFsV;sBADAD;sBJ5HEtV;sBqhBVN;;sBAoGuD;;sBrhBzFjDC;sBI4HFsV;sBADAD;sBJ5HEtV;sBshBVN;;sBrF+EoB;uBqF/EpB,mBAmBe97I,GAAI,oBAAJA,GAA0B;uBAnBzC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ACApH,EAlBFygS,KAQArzL,GAyEoB;4BACtB,MAhEIptG,EACA8W,EAJAhT,EACAC,EACAqD,EAjBFq5R,KAQArzL,GA0EoB;4BACtB,MAlEIhmG,EACApH,EACA8W,EAJAhT,EACAC,EAhBF08R,KAQArzL,GA2EoB;4BACtB,MApEIrpG,EACAqD,EACApH,EACA8W,EAJAhT,EAfF28R,KAQArzL,GA4EoB;4BACtB,MAtEItpG,EACAC,EACAqD,EACApH,EACA8W,EAnBF2pR,KAQArzL,GA6EoB;4BACtB,MAnEIt2F,EAJAhT,EACAC,EACAqD,EACApH,EAlBFygS,KAQArzL,GA8EoB;4BACtB,MArEIptG,EACA8W,EAJAhT,EACAC,EACAqD,EAjBFq5R,KAQArzL,GA+EoB;4BACtB,MAvEIhmG,EACApH,EACA8W,EAJAhT,EACAC,EAhBF08R,KAQArzL,GAgFoB;4BACtB,MAzEIrpG,EACAqD,EACApH,EACA8W,EAJAhT,EAfF28R,KAQArzL,GAiFoB;4BACtB,MA3EItpG,EACAC,EACAqD,EACApH,EACA8W,EAnBF2pR,KAQArzL,GAkFoB;4BACtB,MAxEIt2F,EAJAhT,EACAC,EACAqD,EACApH,EAlBFygS,KAQArzL,GAmFoB;4BACtB,MA1EIptG,EACA8W,EAJAhT,EACAC,EACAqD,EAjBFq5R,KAQArzL,GAoFoB;4BACtB,MA5EIhmG,EACApH,EACA8W,EAJAhT,EACAC,EAhBF08R,KAQArzL,GAqFoB;4BACtB,MA9EIrpG,EACAqD,EACApH,EACA8W,EAJAhT,EAfF28R,KAQArzL,GAsFoB;4BACtB,MAhFItpG,EACAC,EACAqD,EACApH,EACA8W,EAnBF2pR,KAQArzL,GAuFoB;4BACtB,MA7EIt2F,EAJAhT,EACAC,EACAqD,EACApH,EAlBFygS,KAQArzL,GAwFoB;4BACtB,MA/EIptG,EACA8W,EAJAhT,EACAC,EACAqD,EAjBFq5R,KAQArzL,GAyFoB;4BACtB,MAjFIhmG,EACApH,EACA8W,EAJAhT,EACAC,EAhBF08R,KAQArzL,GA0FoB;4BACtB,MAnFIrpG,EACAqD,EACApH,E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G,OqJvpCJ/xL,oBrJupCI+rL;mEACA+F;6BAFAG;;gCqcr0CFlrD;gD,OhT+KF/mI;gCrJspCI8rL;mEACAkG;6BA4DAG,UA7DAD;6BA6DAE,sCACAX;sCADAW;mCqB7vCFjtH;qCrB4vCFmtH,cqBzvCMriL;8B,OATN86K,kCASM96K;;;;mCAHJxsH;;6BrB+rCF8uS;;gCqcp0CE7rD;yCrcq0CWz2H,S,OwE/1Cf89H,sBxE+1Ce99H;gCqBhsCXoiL;;6BrB+rCFG,OwE91CFzkD,sBxE81CEwkD;oCwE91CFxkD,sBxE81CEykD;;6BA5IEE;;gCqJppBF9qL;yCrJoyBaw6I;2CAxDX+J,YAwDWl8I;oC,OwEl2Cf89H,sBxEk2Ce99H;;mCAxDXA,IwE1yCJ89H,gBxE0yCIoe,YAwDW/J;mCAxDXtqF,sBAwDWr0K;oDqJpyBbmkH,iBrJ4uBEukJ,kBAwDW1oQ;gCAJbgvS;;mCqB/rCEhvS;;;6BrBmjCAkvS;8BwEltCJ5kD;yCxEmtCc99H;;;;;;;gCADVyiL;;;;;6BAsBFK,wBAtBED;;qCA7vBF3wC,YAqxBalyI;;;;qCAiLbqiL,cAjLariL;qCAiLbqiL,cAjLax6H;;;6BArxBb7nD,eqc3bEy2H,erc2bFyb,YAmxBA4wC;6BAnxBAj7H,iBqc3bE4uE,erc2bFyb;;8C0R0Ha3e,e1R1Hb2e;;;;;;;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;;;gC0RqGa9f;yC1RlFOpyH;kC,kBqJsFpBrI,iBrJzGAu6I,YAmBoBlyI;gCAnBpBkzI;;;yCqJyGAv7I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;6BAmxBAuB;yCqJ1qBA97I,iBrJzGAu6I;oDAmxBAuB;mCqBzkCE7uK;4B,IAAAo7B,IwLcFlH;;qCxL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iBAA1BA;sCAAU;;sCAAVxsB;;yD2GjGTwgI,W3GiGS9M,YAAM;;8CAANzvH,O2GjGTq8H,a3GiGS9zD,oCAA6C,EAAE;;;sBjErH1D6nB;sBI4HFsV;sB6bxDgB;uB0H7EL;;uBCEA;;;;;;;uBCDE;;;;uBCGG;;;;;;;;;uBCFL;;;;uBCDE;;;;;;;;;;;;;;uBCDF;;uBCAA;;uBCAA;;uBCAA;;;;uBCAA;;;;;;;;;;;;;;;;;;;;;;;;;;uBCAA;;uBCCD;;;uBCDC;;;uBCCE;;uBCDF;;;;;;;;;;;uBCAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wB;;;;;;;;;;;;;;;;;;sB1I6EF;yBlQ3DhBh2I,SACAu0D;;uB;;;;;;4CADAv0D,M;;;;;;;;;;sBkQ2DgB;;;;;;;6ClQ7DhBs0D;;;;;;;sBkQ6DgB;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2CtOsNdynB;2C5BnRFznB;sBkQ6DgB;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCtQ+ed7C;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gDP/CE;gD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BwC4CuC;0B,SAUxB2lR,W;mCADDC,W;;oCAAAA;oCACCD;oCACAD;oCACCD;kC;;;;;;;;;;;;;;;;;;sCrMpkBFp8S;;;;;0B;;;;;;;4B6J4gBd;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uC7QgcZ,oB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4E0CvgBF62D;;uB;;;;;;;sBmOuEc;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;;;;;;uB;;;sBAAA;uB;;;;;sBAAA;;;;0B;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kC7QgcZ;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCwCqpBAe;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BxCrpBA,yB;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4D1QqvBd/gC;;qC;;;;;;gD8BxyBF+wB;;;;;+C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gDAAAA;;;;;;;;;;;8B;;;;gDAAAA;;;;;;8B;;;;;gDAAAA;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BjCmfI,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2CO+CFjxB;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oEAAAA;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4CAAAA;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCP/CE;;iD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2CAAA;;;;;;;;;;;2C;;;;;;;;;;;2DwZ5cG6lR,M;;;;;;6CrjBhEWx8S;4B;;;gEsMgBlBhwB,a;;;;;;;;;;;;;;;;;;;;;;;;0BzC4fI;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEwZ5cGwsU;0B;;;;;;;0BxZ4cH;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;kC;;;;;;;;;kEmB5dJ39Q,4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6CEwCO;6CD+HT,uBADS30E;4CACT,SAAIuC;uDADKvC;;8CAGC,wBAFNuC,GAEM,MAFNA,UAEM;;oDACR/E;gDAAsB;;6EAJfwC,EAIPxC;mD,mCAAAA;wEADI6D,EACJ7D;kDAAsB,UAAtBA;;;8CADQ,UAAJ6D;4C;;;;;;;;;;;;;;;;;;;;;;8CX3GDkB,WAAH5C,W,OAAAA,K,OAAAA;0C;;;;;;wEAAG4C;;;;;;kC;;;;;;;;;;;;0B+B0vBuC;;;;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEgXxyBnC+vV;mC;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B,mDAAAA;0B;;;;;;;;;;;;;;sB3IYS,uB;;;;;sBAAA;;;;;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wC2IZTA;uB;;;;;;;;;;;;;;;0BxZ4cH;0B;;;;;;;;;;;;;;;;yCwZ5cGA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;qEAAAA;0B;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;qEAAAA;0B;;;;qEAAAA;0B;;;;;qEAAAA;0B;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;qEAAAA;0B;;;;qEAAAA;0B;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;qEAAAA;0B;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;qEAAAA;0B;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxZ4cH;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDarfJpiR;iC;;;;;;kDAAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BbqfI;;uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;;;;;;;;;;;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;sE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wE+BpYgB6lF,I;yEAAAA,I;qEAAAA,M;kEAAAA,M;;;2CyXxEbu8L;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BtlBoJT;;;8B;;;;;;;8B8LwTM,c;;;8B9LxTN;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB2cxIkB;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oC4IrCH,WAAJ90V;oCAAI,YAAJA;;;;;mC;;2CAAAA,E,gDAAAA;iC;;;kC1XkGX;wCAAIma,IADkBo+I;oCACtB,GADsBA,UAClBp+I,IACoB,OAFFo+I,IAHpB51E;oCAIF;qCAC4D,MAFtC41E;qCXmftB;;wC;qCAAA;sDAGkB;oCACT;qCAGA;sCAMA;wCAOA,mBAQF;wCAPH;8CWvgBAp+I;yCXugBA;0CApBA68B,MAoBI4vI;;6CAEH,qBWzgBDzsK;6CX0gBC,UW1gBDA;6CX2gBC,UW3gBDA;6CX4gBC,UALGysK;;;uCAPJ;+CWhgBAzsK;wCXggBA;yCAbA68B,MAaI+9S;;4CAEH,qBWlgBD56U;4CXmgBC,UWngBDA;4CXogBC,UAJG46U;;;sCANJ;8CW1fA56U;uCX0fA;wCAPA68B,MAOIg+S;;2CAEH,qBW5fD76U;2CX6fC,UAHG66U;;;sCAHJ,qBWvfA76U,eAEArV;;sCAEE,OALgByzJ,IAHpB51E;oCASG,SALDxoE,MAEArV;;;;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iC/BiYE;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;;;;;;;;;;;;;;uD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,gB;;;;;;;;;;;;;;;0BAAA,+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,qB;;;;0DGqTFqqE;mC;;;;;;;;iCAhyBFe,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BH2eI,mB;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;0B7QgcZ;;qD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;;;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;;;;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;;;;;;;;;;;;;;;;;;;;;;0E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,gB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2CwCqpBAggC;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BxCrpBA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCwZ5cG4kP;;;2B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxZ4cH;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kD2IZTA,Q;;;;;;;;;;;;;;;;;;;;;;;;6BAAAA;;;;6B;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAAA;;;;;4B;;;;;;;;;;;;sCAAAA;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB3IYS;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6B2IZTA;;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yBAAAA;;;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCxZ4cH;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8B7QgcZ;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ;;;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAAA;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8CwZ5cGA,mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4CAAAA,M;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BxZ4cH;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BAAA,qB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iDAAA;;8C;;;mDgBtfJ7gR;;uD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BhBsfI;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ,uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gEwZ5cG6gR;6B;;;;;;;;;;;;;;;;;;;;;;;;;kEAAAA;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB3IYS;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gE2IZTA;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8CAAAA;;;6B;;;;;;;;sB3IYS;uB;;;;;;;;;;;;;;;;;0B7QgcZ;4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wDejcArhR,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB8PCY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8B7QgcZ;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEwZ5cGqhR;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxZ4cH;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDarfJpiR;;0B;;;;;;;;;;;;;;;;;;;;;;qCbqfI;sC;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mC7QgcZ,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;;;;;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;;;;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCAAA;;;;;;;;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;gC;;;;;;;;;;;;;;;;;;4BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0B7QgcZ;;;;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDAAA;8D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,kB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAAA;gD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4CAAA;4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAAA;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2CAAA;oD;;;;;;;;;0BAAA;;;;;;;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;;;;;;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAAA;wD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;+B;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;sC7QgcZ,mB;;;;;;;;;;;;;;;;;;sB6QhcY;mD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gD2IZToiR;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mChXimCH5kP;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDAAAA,oBCjpCJ5nF;yC;;;;;;;;;;;;;;;;uDtBsBA4uD,K;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCnBseI;;;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ;4B;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;gEpQ3ChB3C,oB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCT2eI,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA,sB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCAAA;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;qD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA,sB;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;gD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCSyDN,SAAQ0qJ,OAAO10E,MAAMp3E;oCACnB,SADao3E;sCAGX;;kEAAmBpwG,IAAIl4C,GAAK,UAALA,EAAJk4C,IAAe,QAHjBg5B;oCAKR,qBALQA;oCAKR;0CAEMF,cAAHhxE;sCAAiB,UAAjBA,EAAiB,OAPlBsoJ,cAOIt3E;oCADF,QACqC;kCAPtD,0BADSI;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BTxDH;;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCwCqpBA68B;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CxCrpBA,sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAAA;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iC7QgcZ;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uEwZ5cG4kP;;;;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxZ4cH,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;0B;;;;;;;;sBAAA;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mCrOqlCZ5kP;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxCrpBA;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCgBpfM;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BhBofN;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;;;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDAAA;mD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ;;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,mB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mEwZ5cG4kP;;;;;;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCvY3CP3gR,sB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB4PuDgB;;;;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0B7QgcZ;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCwCqpBA+7B;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDgXjmCG4kP;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BxZ4cH,+C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDAAA;;;0D;;;uEwZ5cGA;0D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BxZ4cH;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAAA;wD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8CAAA;8C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0B7QgcZ;mC;;;;;;;;;;;;;;;;;;;;;;;;;8BwZ5cGA;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BxZ4cH;wE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8DwZ5cGA,kB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCxZ4cH;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;;;;;;;;;;;;;;;;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;;2B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;;;;;;;;;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2BAAA;;;;;;;;;;;;;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6CAAA,gB;;;;;;;;;;;;;;;;4BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;kC;;;;;;;;;;;;;;;;;;8BAAA;;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gFwZ5cGA,S;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4ChYpBPt8Q;;;;mC;;;;;;;;;4CzNjBiBO;;;;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BiMifb;qC;;;;;;;;;;;;;;;;;;;;;;;;yES3dJl9D;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEAAAA;;;;gC;;;;;;;;;;;;;;;;;uEAAAA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gEAAAA;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iEAAAA;;;;mD;;;;;;;;;;;;;;;;;;;;6CMlBIq3D;kC;;;gEAAAA,6B;4DAuBAI;4B,OAlCJT;0B,IAEO5wE,E;iDAAO,UAAPA,EAFP4wE,O;;;;;;;iEN6BAh3D;6B;;;;;;;0CM7BAg3D;kC;;;;;;;;;2CAWIK,+B;;;;;;;;;;+DAXJL;oC;;;;;;;;;6CAWIK;kC;4DAuBAI;4B;;;;;qCAvBAJ;0B,OAXJL,K;;;;;;;wDAWIK,uB;;;;;;;;;;;uENkBJr3D;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEAAAA;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDT2dI;;mD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDezeAu3D;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BfyeA;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA;;;;;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA,qB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAAA;;;sC;;;;;;;;;;;;;;;;;;;qCAAA;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;;;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAAA;;;;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;+B;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;;;;2D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCwCqpBA88B,oD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBqOrlCY;;;0B;;;;;;;;;;;;;;;;;;;;;8B7QgcZ;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAAA;;;;wD;;;;;;;;;;;;;;;;0BAAA;;;;;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAAA;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qFiB9fJ/0F;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BjB8fI;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,mB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sEwZ5cG25U;;4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BxZ4cH;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCuB3UN;;;;iCACa90V;gCACX;qCADWA,MADT8E;;;oCAGQ,qBAFC9E,G;;;;;;;;8CAEqB,QAFrBA;oCAED;;;;;;;;uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BvBwUN;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCAAA;;;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,2B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gDAAA;kD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA;;;yD;;;;;;;;;;;;;sFwZ5cG80V,M;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCxZ4cH;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDwZ5cGA,Q;;;2EAAAA;oC,kCAAAA,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kEAAAA;;;;;;;;;;;;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BxZ4cH;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDAAA;oD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCGqTF3lR;;;;;8BHrTE;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDhQrDhBuD;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+E2YyCOoiR,yB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6CxZ4cH;wD;;;;;;;iFwZ5cGA,O;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCxZ4cH;kD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uEwZ5cGA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2DxZ4cH;;;;;;;2D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yDAAA;;;;;;;yD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yDAAA,yB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2EwZ5cGA;oD;;;yEAAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB3IYS;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kErOqlCZ5kP,oBCjpCJ5nF;uD;;;;;;;;;;kEDipCI4nF,oBCjpCJ5nF;uD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBoO4DgB;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kC7QgcZ;;;;;;;;oC;;;;;;;;;;;;;;;;0BAAA,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uDarfJoqD;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0DAAAA;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDAAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kEAAAA;iD;;;;;;;;;;;;;;;;;;;;;;;;;;;gDbqfI,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2DarfJA;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yEAAAA;oC;;;;;;;;;2EAAAA;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sDAAAA;oC;;;;;;;;;;;;;;;;;;;;sBgQqDgB;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kC7QgcZ;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CwZ5cGoiR;;;;;uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxZ4cH;uD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8DgBvfJ/gR,sB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BhBufI;;;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0DwZ5cG+gR,a;;;;;;;;;;0DAAAA;;;;;iE;;;sB3IYS;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6B7QgcZ;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAAA;oG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wEgBxfJhhR,+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BhBwfI;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gD2IZTghR,uB;;;uEAAAA,K;;;wDjZ2fL7lR,gB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAAAA;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BP/CE;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yEwZ5cG6lR;;;;;;0D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCxZ4cH;;;;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;;kC;;;;;;;;;;;;4BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCarfJpiR;;0B;;;;;;;;;;;oE/M6BAL;;;qEAJAF;;6C;;;;;;;;;;;;;;;;;;;;;;;;;sB+c4BgB;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8B7QgcZ;;;;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mDQ7dAjD,MD4gBFD,kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BP/CE;;;;;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAAA;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDAAA,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iEQ7dAC,MD4gBFD;;;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0DP/CE;0D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6CAAA,qC;;;wDO+CFA;uC;;;;;;;;;;;;;;;uCP/CE;uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEQ7dAC,MD4gBFD;8C;;;;;;;;;;iEC5gBEC,MD4gBFD;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iEAAAA;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCP/CE;;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,gB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qC7P7DhB2E,K;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BhB6fI;;;0BiBzfO;4BAAqB,IAALpvE;4B,4BAAAA;;;0BAA2B,Y;;;;;;;;;;;;;;;;;;;;;sCR6K/CO,0BAAJ3C,WAAFD;kCAAc,sBAAdA,iBAAM4C;iDAAJ3C;;;4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BT4UC;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;;;8B;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,a;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;;;mE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,mB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;;;2B;;;;;;;;;;;;;;;;;;;;;;;;uC/c1BhBgwE;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BkM0dI,mB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDwZ5cG0iR;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BxZ4cH;uC;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6ClMxdJziR;6C;;;;;;;;;;;;;;;;;;;+CAAAA,oB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BkMwdI,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4CAAA;qD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+B7QgcZ,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAAA,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;;;4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;;;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA,a;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;;;sB;;;;;;sBAAA;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0B7QgcZ;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCAAA,Y;;;;;;;;;;;;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imB;0BAEf,sB;0BAAA,eAMGz+c;4BAAL,MAAKA,KACc,cADqBvD;4BACtC;mCADGuD,CAEA;0BANZ;;iDAGO,MA5CL8mO,4BAuCA7qI;2BAEF;;;2BAUQ,0BAXFojI,IR2uCY8lO,UAWAC;0BQ3uCV,eACsC3oc,GAAW,kBAZ3C2hc,MAY2C,UAAX3hc,GAAsB;0BAD5D;kCAANslO;2CACmBtlO,GAAa,4BAZvBgD,EAYUhD,GAAkB;wCAA8B;uBAnDrE,ORivCE8/a;uBQjvCF,yBRivCEA;uBQjvCF,SRivCEA;uBQjvCF,aRivCEA;uBQjvCF,MRivCEA;uBQjvCF,URivCEA;uBQjvCF,QRivCEA;uBQjvCF,YRivCEA;uBQjvCF,eRivCEA;uBQjvCF,YRivCEA;uBQjvCF,oBRivCEA;uBQjvCF,SRivCEA;uBQjvCF,YRivCEA;uBQjvCF,URivCEA;uBQjvCF,SRivCEA;uBQjvCF,aRivCEA;uBQjvCF,cRivCEA;uBQjvCF,gBRivCEA;uBQjvCF,YRivCEA;uBQjvCF,iBRivCEA;uBQjvCF,kBRivCEA;uBQjvCF,URivCEA;uBQjvCF,URivCEA;uBQjvCF,SRivCEA;uBQjvCF,gBRivCEA;uBQjvCF,SRivCEA;uBQjvCF,mBRivCEA;uBQjvCF,KRivCEA;uBQjvCF,aRivCEA;uBQjvCF,eRivCEA;uBQjvCF,oBRivCEA;uBQjvCF,mBRivCEA;uBQjvCF,wBRivCEA;uBQjvCF,wBRivCEA;uBQjvCF,gBRivCEA;uBQjvCF,gBRivCEA;uBQjvCF,oBRivCEA;uBQjvCF,yBRivCEA;uBQjvCF,YRivCEA;uBQjvCF,QRivCEA;uBQjvCF,mBRivCEA;uBQjvCF,wBRivCEA;uBQjvCF,0BRivCEA;uBQjvCF,YRivCEA;uBQjvCF,yBRivCEA;uBQjvCF,WRivCEA;uBQjvCF,cRivCEA;uBQjvCF,SRivCEA;uBQjvCF,aRivCEA;sBQjvCF,QRivCEA;sBoWhwCY;uB5Ved,eRivCEA;uBQjvCF;;;2BAmFmB;;;4BAGd,gCAHE4hC,UACAzpO;2BAEF,SAEEj1O,EAAEhD;6BACJ,IAAIwB,QRwpCPs+a;6BQvpCM,gCADC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IC;0BAAmCC;;0BAA7C;;;;mEAAMF,UAANnvZ;;;;;yCAAUovZ,+BAAVnvZ;;gEAA6CovZ,aAA7CtvP,IAaqD;uBAbrD;;0BAAMwvP;0BAAIC;0BAAmCC;0BAA7Cvtc;;;;;;;4CAAMqtc,QAANrtc;;uCAAUstc,+BAAVttc;4CAA6Cutc,WAA7Cvtc,aAaqD;uBAbrD;;0BAAMytc,KAAIC,+BAAmCC,QAA7C3tc;0BASI;kDATEytc,KAANztc;2BAUI;uCAVM0tc,+BAAV1tc;2BAWI,wCAXyC2tc,QAA7C3tc;0BAWI;kCAFA4tc;kCACA19M;kCACAs3L,6BAEiD;uBAbrD;iCAiBSgf;;2BAGP9e;2BADAj3L;2BADAo4L;0BAQA;kCARAA;kCADO2d;kCAEP/1M;kCAOA,OANAi3L,2BqjBiJA6f;uBrjB5HA;;;;;;;4BgYxBQx2H;8B3Y5BI2uG;gCvCERxzJ,0BuQyPsBjmD,ezUnMvBg4M;;uBoHJH;uBAK+C;wC,UAL/C6vB;uBAK+C;iCgY7B/C1od;0B,qB3K+N0B8gP,cuFvKxB/5D;gD,O9VlFNggH;mCkb0BSrsH,iB,O3Y5BT8/Q;4CgO2P8Bh0M,c2K/NrB9rE,UAAL16K;uBhY6B+C;iCgY7B/C4a;0B,qB3K+N0BmmO,euFvKxB/5D;;4B,O9VlFNggH;mCkb0BSrsH;4B,O3Y5BT+/Q;;8CgO2P8Bj0M,e2K/NrB9rE,SAAL//J,UhY6B+C;;iCgY7B/CA;0B,qB3K+N0BomO,cuFvKxB/5D;;4B,O9VlFNggH;mCkb0BS9rJ;4B,O3Y5BTy/S;;8CgO2P8Bl0M,c2K/NrBvrG,MAALvgI,YhY6B+C;uBAL/C;uCAAK+tc;sB0VwBO;uB1VxBZ;iCAWJ3nd;0B;0BACE,sB,OlD9DFqmS;0BkD8DE;mCgY/BF9/C;mD,O3YjCA2zM;mCW+DAl6b;uBAXI;iCAWJhB;0B;uDlD7DAwnS;;mCkb+BAhgD;mD,O3YjCA6zM;mCW+DAr7b;uBAXI;iCAWJmwH;0B;mCgY9BAg3H;4ChY+BEh3H;qC,OXhEFqrU;uDWgEErrU;gD,OlD9DFw3K,2BkD8DEx3K;;;mCADFA;;uBAXI;;;;2BAqCkCmyU;2BAAjCj3L;0BAID;kCAJCA;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H;gD,OuCFAyzJ;;+CgO2P8B15M,cuFvKxB/5D;mCtTslBOkoS;4B,OxCxqBbloL;0BwCuqBM;2BAAO0zJ,6B+N9aiB35M,cuFvKxB/5D;2BtTqlBA,KaxoBFgoS;2BbwoBE,KaxoBFA;2BbiZE,KAuPAvzU;2BAvPA,KAuPAA;2BAvPA,KAuPAA;2BArbE,KA8LFH;2BA9LE,KA8LFA;2BA9LE,KA8LFA;2BAzYI,KA2MF8B;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME;;;;4DAgoBGs9S,kBAhoBHi1B;;;4DAgoBGj1B,kBAhoBH3uJ;;;;;;;;8BlFuHd7hH,kBkF0gBiBglS,yBAjoBHO;2B3DmKR,G2DnKQD;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR;;;;;;;2B2DwCM;;;;;;gCA3ME78N;gC3DmKR;2B2DwCM;0D0YnMJo5F,oB1YmMIwjI;2BA8LF;;;;8BA9LE;2BA8LF;2BAuPA;;;;8BAvPA;;;2CajZIX,+BbiZJQ;2BajZF;;;;8BbwoBE;;;2CaxoBmCP,+BbwoBnCM;2BaxoBF;mCxEkoCQU;4B,OvBngChB7nS;0BuBmgCM;;gCwEloCE+mS;2BxEkoCF,KwEloCEA;2BxEkoCF;mCAnCYe;;6BAoCUl3Z;;0DADZi3Z,kBACYl3Z;8DADZk3Z,kBACYj3Z;0BApCpB;gCAmCF+iF;2BAnCE,KAmCFA;2BACa4sM,KApCX/9N;2BAoCWsxB,KApCXtxB;2BAoCW6nI;2BApCX;;;;oDAoCWA;2BADb;;;;;2CAnCEF,OAzqBF3B,cAyqBYs/N,gBAAVhrU;2BwE/lCA;;;;8BxEkoCF;2BiE/+BF,KOnJIgqU;2BPmJJ,KOnJIA;2BPmJJ,MOnJIA;2BPmJJ,MOnJIA;2BPnBF,KAsKFqB;2BAtKE,KAsKFA;2BAtKE,KAsKFA;;2BAtKE;;;;;;gCyN6O4B1pO;;;mCzN1OrB7tL;;;;;;gCAHPsrF;;;2BAMMivG;;;2BANN;;;;;2CAMMA;2BAgKR;;;;;;gCAtKEq9N;;kCyN6O4B/rO;;;qCzNrOrB7rL;;;;;;kCARPw3Z;2BA0CA,IA4HFF;2BA5HE,GA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE;;;;;;gCyNmM4BzpO;;;mCzNhMrB7tL;;;;;;gCAHP0rF;;;;;;gCyNmM4BmiG;;;mCzN7LrB7tL;;;;;;gCANPo4Z;;;2BAQQK;;;2BARR;;;;;2CAQQA;2BARR;;;;;gCyNmM4B9tO;;;mCzNzLrB3qL;;;;;;gCAVPk4Z;;;2BAaMW;;;2BAbN;;;;;2CAaMA;2BAbN;;2BAeMG;;;2BAfN;;;;;2CAeMA;2BAfN;;2BAiBMG;;;2BAjBN;;;;;2CAiBMA;2BAjBN;;2BAmBMG;;;2BAnBN;;;;;2CAmBMA;2BAnBN;;2BAqBMI;;;2BArBN;;;;;2CAqBMA;2BArBN;;2BAuBMI;;;2BAqGR;;;;;;gCA5HEH;;6CAuBMG;2BAqGR;;;;;;mCOnJI3C;;;qCPmJJ6C;qCjEgiCI1oN;;;0CiE3hCItxM;;;;;;;uCALRo3Z,OOvHmD;uBA5B/C;;0BAAM8C;0BAA+BC;0BxEmoC3Bl4c;0BwEnoCV82C;;;;;;;4CkN0N0BqvL,euFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA0zJ;;+CgO2P8B35M,euFvKxB/5D;mCtTslBO+rS;4B,OxCxqBb/rL;0BwCuqBM;2BAAO2zJ,2B+N9aiB55M,euFvKxB/5D;2BtTqlBA,KaxoBF+nS;2BbwoBE,KaxoBFA;2BbiZE,KAuPAvzU;2BAvPA,KAuPAA;2BAvPA,KAuPAA;2BArbE,KA8LFH;2BA9LE,KA8LFA;2BA9LE,KA8LFA;2BAzYI,KA2MF8B;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,8B3D2nCIviI,IwEnoCV82C,ObQMsrF;6CAgoBG29S,gB3D2fC//a,I2D3nCJutC;6CAgoBGwyY,gB3D2fC//a,I2D3nCJ2tC;yD3D2nCI3tC,I2D3nCJ0tC;;4BlFuHd4hI,mBkF0gBiB6oS,uB3D0fCn4c,I2D3nCJkuC;2B3DmKR,G2DnKQyma;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,oBAw9BY30c,I2D3nCJ42C,O3DmKRkH;iDAw9BY99C,IAx9BZjF;iDAw9BYiF,IAx9BZwnC;iDAw9BYxnC,IAx9BZ4nC;iDAw9BY5nC,IAx9BZoqC;iDAw9BYpqC,IAx9BZmqC;iDAw9BYnqC,IAx9BZssC;iDAw9BYtsC,IAx9BZgtC;2B2DwCM2J,O0YnMJw6R,qBrcmnCUnxU,I2Dh7BN+sC;2BA8LFsB,wB3DkvBQruC,I2Dh7BN22C;2BA8LF,oB3DkvBQ32C,I2DlvBRquC;;uCajZI4pa,+BxEmoCIj4c,I2DlvBRouC;2B3DkvBQO;uCwEnoC2Bupa,+BxEmoC3Bl4c,I2D3fRmuC;;mC3D0fMiqa;4B,OvBngChBhrS;0BuBmgCM,oCwEloCE8mS,SxEkoCF,KwEloCEA;0BxEkoCF,SAnCYmE,cAoCAr4c;;6BAAU+9C;;mCADZq6Z,gBACEp4c,QAAU89C;mCADZs6Z,gBACEp4c,IAAUwnC;0BApCpB;gCAmCFs5F;2BAnCE,KAmCFA;2BACa4sM,KApCX/9N;2BAoCWsxB,KApCXtxB;2BAoCW7iE,uBAAD9sC,WAACihI;2BApCXp0F,uBAoCU7sC,IAAC8sC;2BADb+J,OA5sBA0hM,eAyqBY8/N,cAoCAr4c,IApCV6sC;2BwE/lCAD,uBxEmoCU5sC,IADZ62C;2BiE/+BF,KOnJIo9Z;2BPmJJ,KOnJIA;2BPmJJ,MOnJIA;2BPmJJ,MOnJIA;2BPnBF,KAsKFqB;2BAtKE,KAsKFA;2BAtKE,KAsKFA;2BAtKE5ma;;;gCyN6O4Bm9L;yCzN1OtB7rO;;mCAAC+9C;;yEAAD/9C,QAAC89C;yEAAD99C,IAACwnC;8BjEmpCKxnC;8BwEnoCV4sC;8BPnBFy8F;2BAMMqsU,KANNF;2BAMMhsU,KANNgsU;2BAMMzka,uCjEgpCM/wC,IiEtpCZ0uC,OAMM86F;2BANN/2F,uCjEspCYzyC,IiEhpCN+wC;2BAgKRyB;;;gCyNuE8Bq3L;yCzNrOtB7pO;;mCAAC+9C;;yEAAD/9C,QAAC89C;yEAAD99C,IAACwnC;8BjE8oCKxnC;8BiEtpCZyyC;;2BA0CA,IA4HF4ia;2BA5HE,GA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE9ia;;;gCyNmM4Bs5L;yCzNhMtB7rO;;mCAAC+9C;;yEAAD/9C,QAAC89C;yEAAD99C,IAACwnC;8BjEymCKxnC;8BiEh/BdwyC;8BA5HEi3F;;;;gCyNmM4BoiG;yCzN7LtB7rO;;mCAAC+9C;;yEAAD/9C,QAAC89C;yEAAD99C,IAACwnC;8BjEsmCKxnC;8BiE5mCZuyC;;2BAQQgka,MARRL;2BAQQlsU,MARRksU;2BAQQ7ja,uCjEomCIryC,IiE5mCZsyC,OAQQ03F;2BARRt1F,uCjE4mCY10C,IiEpmCJqyC;2BARRoC;;;gCyNmM4Bk0L;yCzNzLtB3oO;;mCAAC+9C;;yEAAD/9C,QAAC89C;yEAAD99C,IAACwnC;8BjEkmCKxnC;8BiE5mCZ00C;;2BAaMiia,MAbNX;2BAaM9U,MAbN8U;2BAaMxha,uCjE+lCMx0C,IiE5mCZy0C,OAaMysZ;2BAbN3sZ,uCjE4mCYv0C,IiE/lCNw0C;2BAEAsia,MAfNf;2BAeM5U,MAfN4U;2BAeMzha,uCjE6lCMt0C,IiE5mCZu0C,OAeM4sZ;2BAfN9sZ,uCjE4mCYr0C,IiE7lCNs0C;2BAEA2ia,MAjBNnB;2BAiBM1U,MAjBN0U;2BAiBM1ha,uCjE2lCMp0C,IiE5mCZq0C,OAiBM+sZ;2BAjBNtrZ,uCjE4mCY91C,IiE3lCNo0C;2BAEAgja,MAnBNvB;2BAmBMxU,MAnBNwU;2BAmBM3/Z,uCjEylCMl2C,IiE5mCZ81C,OAmBMurZ;2BAnBNprZ,uCjE4mCYj2C,IiEzlCNk2C;2BAEAqha,MArBN3gO;2BAqBM4gO,MArBN5gO;2BAqBMtgM,uCjEulCMt2C,IiE5mCZi2C,OAqBMuha;2BArBNlga,uCjE4mCYt3C,IiEvlCNs2C;2BAEAqha,MAvBNhhO;2BAuBMihO,MAvBNjhO;2BAuBMt/L,uCjEqlCMr3C,IiE5mCZs3C,OAuBMsga;2BAqGRxga,uCjEg/Bcp3C,IiErlCNq3C;2BAqGR,uCjEg/Bcr3C,IiEh/Bdo3C;;iCjEgiCIo4M;4CiE3hCExvP;;sCAAE+9C;;4EAAF/9C,QAAE89C;4EAAF99C,IAAEwnC;;mCjE2+BMxnC;mCiEh/Bdm3C;wCOvHmD;uBA5B/C;;0BAAMoha;0BAA+BC;0BAArCx4c;;;2EA4B+C;uBA5B/C;;0BAAMu4c;0BAA+BC;0BxEmoCnCx4c;;0BwEnoCF;;4CkN0N0BomO,cuFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA2zJ;;+CgO2P8B55M,cuFvKxB/5D;mCtTslBOqsS;4B,OxCxqBbrsL;0BwCiDc;2BAsnBD4zJ,wB+N9aiB75M,cuFvKxB/5D;2BtTjCQ,4B3DinCRrsK;2B2DhnCQ,kBAqnBDigb,a3D2fPjgb;2B2D/mCQ,mBAonBDigb,a3D2fPjgb;2B2D9mCQ,2B3D8mCRA;2B2D7mCQ+4c;4BlFyGlBxpS,kBkF0gBiBmpS,oB3D0fP14c;2BAv9BA,+BAu9BAA;2BAt9BA,+BAs9BAA;2BAr9BA,oCAq9BAA;2BAp9BA,oCAo9BAA;2BAn9BA,sBAm9BAA;2BAl9BA,sBAk9BAA;2BAj9BA,yBAi9BAA;2BAh9BA,iCAg9BAA;2BAh9BA;;6BAPAg5c;6BACAC;6BACAC;6BACAC;6BACAC;6BACAC;6BACA9nL;6BACA+nL;2B2DkDME;;6BAnNEb;6BACAC;6BACAC;6BACAC;6BACAC;6BACAQ;2BAmNFE,yB0Y1NRroI,oBrcmnCEpxU;2B2Dx5BM,+B3Dw5BNA;2B2Dx5BM;+BANAw5c,QAKAC,yBACAC;2BAmMF,yC3DqtBJ15c;2B2DptBI;uCa/aAu4c,+BxEmoCJv4c;2B2DptBI;;6BATA25c;6BAQAC;6BACAC;2BAyPA;uCaxqB+BrB,+BxEmoCnCx4c;2B2D3dI,eAVA85c,cAUAC;;mC3D0dEE;4B,OvBngChB5sS;;0BuBmgCM,SAnCY6sS,WAoCRl6c;;6BAAkB89C,GADZm8Z,aACNj6c;6BAAkB+9C,GADZk8Z,aACNj6c;sCAAkB89C;0BAClB;2BADSA,oBAAT99C;2BAAS+9C,oBAAT/9C;2BAnCEm6c,kBAmCOr8Z;2BAnCYs8Z,UA1qBzB5hO,cAyqBY0hO,WAoCRl6c;sCAnCEm6c,eAAmBC;2BAoCrB,4BADAp6c;2BACA,gBADA4xR,QACAC;2BiErpCAT;;;gCyN2OwBtlD;yCzN3OxB9rO;;mCACG89C,mCADH99C;mCACG+9C,mCADH/9C;4CACG89C;8BjEmpCH99C;;2BiEhpCE2vG,qCjEgpCF3vG;2BiEhpCEiqI,qCjEgpCFjqI;2BiEjpCAqxR,YACE1hL;2BACF2hL;;;gCyNsOwBxnD;yCzNtOxB9pO;;mCACG89C,mCADH99C;mCACG+9C,mCADH/9C;4CACG89C;8BjE8oCH99C;;2BiE/+BFihc,iBArKE7vK,SAGAC,SAEAC;2BAqCA74C;;;gCyNiMwB3M;yCzNjMxB9rO;;mCACG89C,mCADH99C;mCACG+9C,mCADH/9C;4CACG89C;8BjEymCH99C;;2BiEvmCA04O;;;gCyN8LwB5M;yCzN9LxB9rO;;mCACG89C,mCADH99C;mCACG+9C,mCADH/9C;4CACG89C;8BjEsmCH99C;;2BiEpmCI8gI,qCjEomCJ9gI;2BiEpmCIixR,qCjEomCJjxR;2BiEpmCA24O,OAAI73G;2BACJ83G;;;gCyN0LwBhQ;yCzN1LxB5oO;;mCACG89C,mCADH99C;mCACG+9C,mCADH/9C;4CACG89C;8BjEkmCH99C;;2BiE/lCEihI,qCjE+lCFjhI;2BiE/lCE0tU,qCjE+lCF1tU;2BiEhmCA64O,sBACE53G;2BAEAmB,qCjE6lCFpiI;2BiE7lCE80c,qCjE6lCF90c;2BiE9lCA84O,uBACE12G;2BAEAG,qCjE2lCFviI;2BiE3lCE00c,qCjE2lCF10c;2BiE5lCA+4O,2BACEx2G;2BAEA9B,qCjEylCFzgI;2BiEzlCEw0c,qCjEylCFx0c;2BiE1lCAg5O,kBACEv4G;2BAEAG,qCjEulCF5gI;2BiEvlCEs0c,qCjEulCFt0c;2BiExlCAi5O,mBACEr4G;2BAEAyI,qCjEqlCFrpI;2BiErlCEw1c,qCjEqlCFx1c;2BiEtlCAk5O,6BACE7vG;2BAuGJ23T;;6BA5HEvoN;6BAGAC;6BAGAC;6BACAC;6BAGAC;6BAEAC;6BAEAC;6BAEAC;6BAEAC;6BAEAC;2BAyGF,6CjE6+BEl5O;2BiE7+BF;2BACA+gc;4BjE4hCApxM;uCiE5hCA3vP;;iCACI89C,mCADJ99C;iCACI+9C,mCADJ/9C;0CACI89C;;8BjE2+BF99C;;2BwEzmCE2xR;+BP0HJsvK,cACAD,cACAsZ,aACAvZ;oCOnJIiZ,YAkBAK,aAIA1oL,QAE2C;uBA5B/C;iCA4EgBruS,EAAeJ,EAClCq3d,kBAA8B57B;0BAEZ,IAAjB67B,GAAiB,WpDgEjB7nI,gBAtGAD;0BoDsCiB,SACjB5qV,EAAEzE,KAAM,sBAANA,IADFm3d,GAC4B;0BADX,SAEjBC,SAASp3d;4BAAM;qCAANA,oBAAkC,kByjBhG7Ckpd,OzjBgGoD,EAAC;0BAFlC;8CqjB3GnBz1b;2BrjB2GmB;;8BqjB3GnBA;4C9dkBAw8C,iB8dlBAx8C;2BrjByKW,MADIm4O;2BACJ,MADIA;2BAMQ,iByjBnKvBq9M;2BzjBkKuB,iByjBlKvBA;0BzjBkKuB,sBADA,UAjErBkO,MAiE6B;0BADZ;;;uCAAW,sCAhE5BA;;;2BAyDmB,QAtDnBvO;2BAqDmB,QArDnBA;2BAkDE;;oCAEiB,OApDnBA,WAFAnkd;2BA4EK;;8BwjBhMPqkd;uCxjBgMgEzmd;gCACxC,mBADwCA,GACpD,mBADoDA,SAC7B;2BAId,iByjBhLrB6md;2BzjBgLY,oByjBhLZA,ezjB0KSx2c;2BAUS,SANTmic,GAMS,WyjBpLlBqU;2BzjB0IY;mCA9CXgO,kCA+Ce,OkjBqBDr/c,KljBrB0B;2BAG7B;;;;+BAlDXq/c;;iCAmDe,uBqjB5HZnic;iCrjB4HY;0CqjB5HZA;wD9ddJk7C,iB8dcIl7C,MrjB4HwC;;2BAZ5B,aAxCmBl1B,kBAwCQ,O0jBpHzCwpd,W1jBoHkE;2BAApD,mBqjBjGZlkC;2BrjBiGY;;8BqjBjGZA;4C9d7BJl1W,iB8d6BIk1W;2BrjB6FQ;2BAEoC;2BAf5B,2BAtBWmW;0BAsBX,GAtBnB47B;;;0CAoBuB;;;;;;0BA8CL;2BArCM;2BADC,iByjBtH1Bt5B;2BzjBqHyB,iByjBrHzBA;0BzjBoH0B;;;;;4EvEo9BhB/3Y;sCynB16BKhuC;;;;;;0CljBqBd;uBAtKG;;;;;mCA6KJ4oO,UA7IArgJ;yDPmHA;4BAKM,eACE5gG,sCAA8B;4BAlIpC;6BA4HF+3d;;;;;;;sCAKQ;;;gDAAiC,0BALzCngV;;;iDAKQ,0BALRizG,aAKuE;;;+BALvEitO;;0CAGe,qCAHfC;;6BA5HE;6BAuBM;;sCAAiC,0BAvBvCjqL;;;;;gDAuBM,0BAvBNC;;;6BAqBM;;sCAAiC,0BArBvCJ;;;;;gDAqBM,0BArBNC;;;6BAmBM;;sCAAiC,0BAnBvCuqL;;;;;gDAmBM,0BAnBNC;;;6BAiBM;;sCAAiC,0BAjBvCE;;;;;gDAiBM,0BAjBNC;;;6BAeM;;sCAAiC,0BAfvCE;;;;;gDAeM,0BAfNC;;;6BAaM;;sCAAiC,0BAbvCE;;;;;gDAaM,0BAbNC;;;;;;;;;oCyN4LFnyO;;sCzNlLS;;;gDAAiC,0BAVxC9uG;;;iDAUO,0BAVPizG,aAUsE;;+BAVtEiuO;;6BAQQ;;sCAAiC,0BARzCE;;;;;gDAQQ,0BARRC;;;;;;;;;oCyN4LFrvO;;sCzNtLS;;;gDAAiC,0BANxChyG;;;iDAMO,0BANPizG,aAMsE;;+BANtEquO;;;;;;;;oCyN4LFtvO;;sCzNzLS;;;gDAAiC,0BAHxChyG;;;iDAGO,0BAHPizG,aAGsE;;+BAHtEsuO;6BA4HFE,mCA5HED,YA4HFpB;;6BAtKE;;;;;;;;oCyNsOFtwO;;sCzN9NS;;;gDAAiC,0BARxC9vG;;;iDAQO,0BARPizG,aAQsE;;+BARtEyuO;;6BAMM;;sCAAiC,0BANvCrrL;;;;;gDAMM,0BANNC;;;;;;;;;oCyNsOFtkD;;sCzNnOS;;;gDAAiC,0BAHxChyG;;;iDAGO,0BAHPizG,aAGsE;;+BAHtE2uO;6BAsKFE,mCAtKED,YAsKFJ;6BOnHAM,mCPmHAD,YOnHA7B;;4BAgBiB,SxEklCf+B,ewEllC8B55d;;;;6FAAY,EAAZA,IAAkB;4BAAjC,SxEklCf4qP,OwEllCgB5qP,sCAAY;4BxEolCxB;;;4BADQ,SApCV65d;8BAoCoB;;;+BADtB;iFACyC;4BApCvC;;;;;6BAoCW;;6BADb;6BAnCE79N;0DAmCF,sBAnCED;6BAmCFG,mCAnCEF,WAmCFC;6BwElmCF69N,mCxEkmCE59N,YwElmCFy9N;;4BAKM,SbmmBAI,UahmBE/5d,yBAAI;4BAHN,SbmmBAg6d,sBalmBEh6d;8BANR;6DAMQA,mCAAoB;uCAApBA,EAAuC;4BADzC,SbmmBAu9b,eanmBEv9b,mCAAoB;4BbmmBtB,+BU9pBJ;4BG2MI;8BARN;;kDAQMA;2CARN;;+DAQMA;wDARN;uFAQMA,mCAAoB;iEAApBA,EAAuC;oDAAvCA,EAA+D;uCAA/DA,EACa;;6BH5MjBm6d;;;;gCGmMF;;+BHnMED;;4BG0MI,kDAAmB;4BHjMnB;6BATJE;;;;gCGmMF;;+BHnMED;6BASI,iCATJC;6BV8pBIE,mCU9pBJD,YV8pBIJ;;6BAvPA;;6BArEA;;4Ba7JA,e6X/KMj6d;8BhY+BV,SgY/BFkhP,OhY+BElhP;gCADF;;oDACEA;6CADF;4EACEA,mCAAoB;sDAApBA,EAAuC;yCAAvCA,EAA+D;8BgY/BjE,6B3KmNA4pP,Y2KnNA1I,QAAYlhP,E7XgLJ;4BbxKE;6BAoUJi9P;;wCa/JN;+Bb+JMD;;0Ca9JA,kCb8JAC;6BAqEAG,mCArEAF,YAqEAC;mDavWE,4BbuWFC;;6BA9LEP,sBarKA;;6BbqKAC;;;;gCanLR;;6CAYQ98P;sCAZR;;0DAYQA;mDAZR;kFAYQA,mCAAoB;4DAApBA,EAAuC;+CAAvCA,EAA+D;;+BbuK/D68P;;6BA3ME;6B3D2KJ;6BADA,0CAPJrjC;6BAMI,0CANJ6H;6BAKI,0CALJo6B;6BAII,0CAJJC;6BAGI,0CAHJC;6BAEI,0CAFJC;6BACI,0CADJC;6B2DnKQO,mC3DmKRN;;4B2DrJ6B;;;;4BAdrB;;6BAaI;2EAbJQ;6BAYI,gDAZJE;6BAWI,gDAXJE;6BAUI;2EAVJC;6BA2MFI,mCA3MEH,YA2MFE;6BA8LF09N,mCA9LEz9N,YA8LFw9N;6BAuPAE,mCAvPAD,YAuPAF;6BaxmBNI,mCbwmBMD,YaxmBNX;0DAyJa;mCAZb34O,UACEnuK;4B,UAAAA;8BA9IF,UA8IEA,SA9IF4nZ;;;;;;;;;;;sCAKM;uCADFI,MAJJJ;uCAIIK;uCACE;;0C;4CAGE;sDAWuC;uCAdzC;iDACEj7d;0CANR;yEAMQA,mCAAoB;mDAApBA,EAAuC;uCADzC,wBAAEA,mCAAoB;;gDADxBi7d;;;4CbomBEC,MapmBFD,QbomBEE;;;;;;kDAgCIC,MAhCJD,SAgCIE;;;;oDU9rBRC,MV8rBQD,QU9rBRE;;;;;;;;;sDGmMF;uDH1LMI,MATJJ;uDASIK;uDG0LN,oBH1LMA;uDATJ92Z;6DASI62Z;uDATJ33Z;;;sDG0MI;uDHhMA63Z,MAVJN;uDAUIO;uDGgMA,kDAAmB;uDH1MvBz3Z;;;yDGmMF;4GHzLMy3Z;yDAVJN;6DAUIK;uDAVJ73Z;;;sDG2MI;uDHhMA+3Z,MAXJR;uDAWIS;uDGgMA;;0DARN;;8EAQMh8d;uEARN;;2FAQMA;oFARN;mHAQMA,mCAAoB;6FAApBA,EAAuC;gFAAvCA,EAA+D;mEAA/DA,EACa;uDH5MjBskE;;;;yDGmMF;4GHxLM03Z;uDAXJT,MAWIQ;uDAXJ/3Z;;;;;;;;;0D,gBAAA6zE;;;;;iIAaqD;yDAbrD4jV;;;kDV8pBI/7Z,gCAgCI07Z,MAhCJl8Z;;;kDAsBI+8Z,MAtBJd,SAsBIe;;;;oDA7QJC,MA6QID,QA7QJE;;;;;;;;;0DAqBIE,MArBJF,SAqBIG;;;;4DAnNFr8N,MAmNEq8N,QAnNFC;;;;;;;;;;+DAwBIC,MAxBJD;+DAwBI77N;+DAxBJjlM,0BarKA,iBb6LIilM;+DAxBJ67N,MAwBIC;+DAxBJzka;;;;+DAuBI0ka,MAvBJF;+DAuBI37N;+DAvBJrlM;;;iEanLR;;8EAYQx7D;uEAZR;;2FAYQA;oFAZR;mHAYQA,mCAAoB;6FAApBA,EAAuC;gFAAvCA,EAA+D;mEb8L3D6gQ;iEAvBJgtC;qEAuBI6uL;+DAvBJ1ka;;;kEAkBI2ka,MAlBJH,SAkBI/8N;;;;oEA7NFG,MA6NEH,QA7NFC;;;;;;;;;;;;;uEAUIU,MAVJV;uEAUIC;uEAVJ;;+FAUIA;yEAVJw4N;;;;;6EAUI/3N;uEAVJjuM;;;;uEAWImuM,MAXJZ;uEAWIG;uEAXJ;iGAWIA,MAXJmuC;6EAWI1tC;uEAXJnuM;;;0EAeIquM,MAfJd,SAeIK;;;;wE3DoJZ,O2DpJYA,Q3DoJZ3iH;;;;;;;;;;;;;;;+EAGIkiH,KAHJliH;+EAGI3gC;+EAHJ;uGAGIA,KAHJkiJ;oFAGIW;+EAHJx5M;;;;+EAIIy5M,KAJJniH;+EAII/gC;+EAJJ;4GAIIA,KAJJqiJ;oFAIIa;+EAJJz5M;;;;+EAOI+4M,KAPJzhH;+EAOIlhC;+EAPJ;2HAOIA,KAPJqiJ;oFAOIM;+EAPJ/4M;;;;+EACIg5M,KADJ1hH;+EACIphC;+EADJ;6FACIA,KADJ47B;oFACIknH;+EADJh5M;;;;+EAEIi5M,KAFJ3hH;+EAEIl8C;+EAFJ;kGAEIA,KAFJ22C;oFAEIknH;+EAFJj5M;;;;+EAMIk5M,KANJ5hH;+EAMIr8C;+EANJ;sHAMIA,KANJy9J;oFAMIQ;+EANJl5M;;;;+EAQIm5M,KARJ7hH;+EAQIx8C;+EARJ;gIAQIA;+EARJw8C,KAQI6hH;+EARJn5M;;;;+EAKIq3F,KALJC;+EAKIp9I;+EALJ,yCAKIA,GALJy+P;oFAKIthH;+EALJr3F;;;;;;;;;kF,gBAAAy4M;;;;;;;;;;;;;;;;;;;;;;uNAUsD;iFAVtDC;;;;uE2DnKQu+N;6EAeIv8N;uEAfJruM;;;;uEAYIuuM,MAZJhB;uEAYIjD;uEAZJ;wGAYIA,MAZJ29C;6EAYI15C;uEAZJvuM;;;0EAcIyuM,MAdJlB,SAcInD;sEAAiB,iBAAjBA;;;uEAAiB;0GAAwB;8EAAxB,oCAAjBA;;uEAdJtqM;6EAcI2uM;uEAdJzuM;;;;uEAaIqtM,MAbJE;uEAaIrD;uEAbJ;;;;;+FAaIA;yEAbJwgO;;6EAaIr9N;uEAbJrtM;;;;;;;;;0E,gBAAAssM;;;;;;;;;;;;;;;4LAiBsD;yEAjBtDo+N;;;;+DA2MFjka;qEAkBI+ja;+DAlBJ3ka;;;;;;;;;kE,gBAAA6/E;;;;;yIA0B+C;iEA1B/CygV;;;;uDA8LFn5Z;6DAqBIm9Z;uDArBJx+Z;;;0DA8BIk/Z,MA9BJZ,SA8BIj8N;;;;wDAnGJ,UAmGIA,QAnGJ+8N;;;;;;;+DAOIC,MAPJD;+DAOI38N;+DAPJhjM,Ya9JA,uBbqKIgjM,MAPJk4N;qEAOI0E;+DAPJnga;;;8Da7JA;+DbqKIoga,MARJF;+DAQIz8N;+DarKJ;yE6X/KMzgQ;kEhY+BV,SgY/BFkhP,OhY+BElhP;oEADF;;wFACEA;iFADF;gHACEA,mCAAoB;0FAApBA,EAAuC;6EAAvCA,EAA+D;kEgY/BjE,6B3KmNA6pP,Y2KnNA3I,QAAYlhP,E7XgLJ;+Db4JFw9D;0Ea/JN,yCbuKUijM;+DARJy8N,MAQIE;+DARJpga;;;;;;;;;kE,gBAAA46E;;yHAUsD;iEAVtD8gV;;;;uDAqEAj6Z;6DA8BIu+Z;uDA9BJl/Z;;;;uDA6BIu/Z,MA7BJjB;uDA6BI/7N;uDA7BJ3hM,mBavWE,iBboYE2hM,MA7BJg8N;6DA6BIgB;uDA7BJv/Z;;;;;;;;;0D,gBAAA+5E;;;;;iIAkC+C;yDAlC/C+gV;;;kDAuPA35Z,gCAsBIg9Z,MAtBJ/8Z;;;;;;;;;kD,gBAAA04E;;yGAkC+C;iDAlC/CqhV;;sCuF7JF;sC1EtcE;uCALNr0Z;6CAIIo2Z;uCAJJn2Z;;wCAiBIy4Z,MAjBJ1C,SAiBI2C;;;;sCPkGJ,UOlGIA,QPkGJE;;;;;;;;;;4CAKM;6CADFM,MAJJN;6CAIIO;6CACE,eACEh+d,sCAA8B;6CANtCikE;;;;;;;;qD;;;;;;4DAAA2zE;;;;+DAKQ,eALRizG,MAKQ,aALRA,WAKuE;sEgW1LvEt4B,chW0LQ,0BALRs4B,YAKuE;kEgW1LvEt4B,chW0LyC,0BALzC36E;qDAKQ,YAKuC;;iDAN3ComV;6CAJJP,MAIIM;6CAJJL;;;gDACIO,MADJR,SACIS;;8CAvKF,UAuKEA,QAvKFE;;;;;;;;;;qDAOII,MAPJJ;qDAOIK;qDAPJC;;;;;;2DyNsOF/2O;;6D;;;;;;oEzNtOE/vG;;;;uEAQO,eARPizG,MAQO,aARPA,WAQsE;8EgWvBxEt4B,chWuBS,0BARPs4B,YAQsE;0EgWvBxEt4B,chWuB0C,0BARxC36E;6DAQO,YAGwC;yDAJ3C6mV;qDAPJL,MAOII;qDAPJ/+Z;;;;qDAEIk/Z,MAFJP;qDAEIQ;qDAFJh+Z;;;;2DyNsOFipL;;6D;;;;;;oEzNtOEjyG;;;;uEAGO,eAHPizG,MAGO,aAHPA,WAGsE;8EgWlBxEt4B,chWkBS,0BAHPs4B,YAGsE;0EgWlBxEt4B,chWkB0C,0BAHxC36E;6DAGO,YAQwC;yDAT3CgnV;uDAFJN;;2DAEIK;qDAFJl/Z;;;wDAKIo/Z,MALJT,SAKIU;;;;;;;2DALJC;;;;+D,gBAAAnnV;iEAMM,eANNizG,MAMM,aANNA,WAMqE;wEgWrBvEt4B,chWqBQ,0BANNs4B,YAMqE;8DANrEm0O;iEgWfFzsQ,chWqByC,0BANvCwsQ;;;;;2DAKIF;qDALJp/Z;;;;;;;;;wD,gBAAAo4E;;;;;+HAW+C;uDAX/CymV;;;;;;6CAsKF76Z;mDACIw6Z;6CADJP;;;gDAEIuB,MAFJxB,SAEIyB;;8CA9HF;qDA8HEA;+CA9HF;;;;;;;;;;;;;;;;;;;;;;8DAkBIpgO,KAlBJ1hH,QAkBIphC;;;;;;;iEAlBJ2xL;;;;qE,gBAAA/1J;uEAmBM,eAnBNizG,MAmBM,aAnBNA,WAmBqE;8EgW5EvEt4B,chW4EQ,0BAnBNs4B,YAmBqE;oEAnBrE+iD;uEgWzDFr7E,chW4EyC,0BAnBvCo7E;;;;;;gEAkBI7uC;2DAlBJ94M;;;8DAcI+4M,KAdJ3hH,QAcIl8C;;;;;;;iEAdJ4sM;;;;qE,gBAAAl2J;uEAeM,eAfNizG,MAeM,aAfNA,WAeqE;8EgWxEvEt4B,chWwEQ,0BAfNs4B,YAeqE;oEAfrEkjD;uEgWzDFx7E,chWwEyC,0BAfvCu7E;;;;;;gEAcI/uC;2DAdJ/4M;;;;2DASIg5M,KATJ5hH;2DASIr8C;2DATJl7C;;;;;;;iEyN4LF8gM;;mE;;;;;;0EzN5LE/uG;;;;6EAUO,eAVPizG,MAUO,aAVPA,WAUsE;oFgWnExEt4B,chWmES,0BAVPs4B,YAUsE;gFgWnExEt4B,chWmE0C,0BAVxC36E;mEAUO,YAewC;+DAhB3C72C;6DATJ29J;;;;;;gEASIM;2DATJh5M;;;;2DAEIi5M,KAFJ7hH;2DAEIx8C;2DAFJ96C;;;;iEyN4LF+jM;;mE;;;;;;0EzN5LEjyG;;;;6EAGO,eAHPizG,MAGO,aAHPA,WAGsE;oFgW5DxEt4B,chW4DS,0BAHPs4B,YAGsE;gFgW5DxEt4B,chW4D0C,0BAHxC36E;mEAGO,YAsBwC;+DAvB3Ch3C;6DAFJg3C;;;;;;;;;gEAEIqnH;2DAFJj5M;;;8DAQIm3F,KARJC,QAQIp9I;;;;;;;iEARJiuS;;;;qE,gBAAAr2J;uEAQQ,eARRizG,MAQQ,aARRA,WAQuE;8EgWjEzEt4B,chWiEU,0BARRs4B,YAQuE;oEARvEqjD;uEgWzDF37E,chWiE2C,0BARzC07E;;0DiFodE;;2DjFpdFloP;;gEAQIo3F;2DARJn3F;;;;;2DAKIo5M,MALJhiH;2DAKItgC;2DALJx3D;;;;;iEyN4LFukM;;mE;;;;;;0EzN5LEjyG;;;;6EAMO,eANPizG,MAMO,aANPA,WAMsE;oFgW/DxEt4B,chW+DS,0BANPs4B,YAMsE;gFgW/DxEt4B,chW+D0C,0BANxC36E;mEAMO,YAmBwC;+DApB3C96B;6DALJ+6B;;;;;;;;gEAKIunH;2DALJp5M;;;8DAgBIq5M,KAhBJjiH,QAgBIxgC;;;;;;;iEAhBJg8W;;;;qE,gBAAAhhV;uEAiBM,eAjBNizG,MAiBM,aAjBNA,WAiBqE;8EgW1EvEt4B,chW0EQ,0BAjBNs4B,YAiBqE;oEAjBrEguO;uEgWzDFtmQ,chW0EyC,0BAjBvCqmQ;;;;;;gEAgBIv5N;2DAhBJr5M;;;8DAoBIs5M,KApBJliH,QAoBI3gC;;;;;;;iEApBJg8W;;;;qE,gBAAA7gV;uEAqBM,eArBNizG,MAqBM,aArBNA,WAqBqE;8EgW9EvEt4B,chW8EQ,0BArBNs4B,YAqBqE;oEArBrE6tO;uEgWzDFnmQ,chW8EyC,0BArBvCkmQ;;;;;;gEAoBIn5N;2DApBJt5M;;;8DAsBIu5M,KAtBJniH,QAsBI/gC;;;;;;;iEAtBJi8W;;;;qE,gBAAA1gV;uEAuBM,eAvBNizG,MAuBM,aAvBNA,WAuBqE;8EgWhFvEt4B,chWgFQ,0BAvBNs4B,YAuBqE;oEAvBrE0tO;uEgWzDFhmQ,chWgFyC,0BAvBvC+lQ;;;;;;gEAsBI/4N;2DAtBJv5M;;;8DAYI64M,KAZJzhH,QAYIlhC;;;;;;;iEAZJi8W;;;;qE,gBAAAvgV;uEAaM,eAbNizG,MAaM,aAbNA,WAaqE;8EgWtEvEt4B,chWsEQ,0BAbNs4B,YAaqE;oEAbrEutO;uEgWzDF7lQ,chWsEyC,0BAbvC4lQ;;;;;;gEAYIt5N;2DAZJ74M;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gOAyB+C;qDAzB/C;;;;6CA4HF0d;mDAEIu7Z;6CAFJvB;;;;6CAGI0B,MAHJ3B;6CAGI4B;6CAHJ17Z;iEAGe,0BAAX07Z,MAHJ1B;mDAGIyB;6CAHJ1B;;;;;;;;;gD,gBAAA/+N;;;;;;;;uIAU+C;+CAV/Ci/N;;;;qCOnHAj5Z;2CAiBI24Z;qCAjBJz4Z;;kCAgBiB;mCAAby6Z,MAhBJ1E;mCAgBI2E;mCAAa;;sC;4CAAejsZ;;;kGAAY,QAAZA;;kDAGe;mCAH9B,gBAACtzE,sCAAY;;4CAA1Bu/d;;;wCxEklCF3gO,MwEllCE2gO,QxEklCFt/N;;;;;;0CACY;2CAARH,MADJG;2CACI9D;2CAAQ;qDADZ09N;uDAnCED;gD;;;;;;uDAmCFhiV;;;;0DACsB,eADtBizG,MACsB,aADtBA,WACyC;0DADzC,8CACyC;sDADzC;gDACsB,YAGgC;qDAvCpD+uO;2CAoCU,4BADZA;;oDACIz9N;;;gDApCFkD,KAoCElD,QApCFiD;;;;;;;mDACuBF,MADvBE;mDACuBtiJ;mDADvBtyD,uDACuBsyD;mDADvBsiJ,MACuBF;mDADvB75M;;;sDACI85M,MADJC,SACIxiJ;;;;;;;yDAkCN+wL;;;;6D,gBAAA/1J;+DACa,eADbizG,MACa,aADbA,WACoB;+DADpB,wCACoB;4DADpB+iD;;;;sDAnCEvjP,gCACI80M,MADJ95M;;;;;;;;;sD,gBAAAuyF;;6GAEsD;qDAFtDs2J;;;0CAoCU,IADZ79O,gCACIyvM,MADJ5vM;;;;2CAEI8vM,MAFJC;2CAEI7iJ;2CAFJ,0BAEIA;2CAFJ6iJ,MAEID;2CAFJ9vM;;;;;;;;;8C,gBAAA0nF;;qGAIsD;6CAJtDm2J;;;kCwEllCe;mCAhBjBrpO;yCAgBI46Z;mCAhBJz6Z;;;;;;;;;mHAmB+C;4BAnB/C,YAyJa;mCAZbmW;4BA9HM,GA8HN6sL,gBA9HM;sCA8HNC,SA9HM,MA8HND;4Bb0fY;iCaxnBN43N;;8BbwnBM;8BA1PA;mCA0PAniX;;gCA1PA;gCApME;qCAoMFJ;;kCApME;;;;6CanMN28L;sCAAqB;wDAArBE;2FAAoB;+CAApBF;qDbiMyB;mCAEnB;6CapMNF;gFbiMkB;kCApNJ;uCAuNR38L;;oCAvNQ;;sCACD;;wCACC;;0CACD;;4CAC4B;;;;;yDAAlBq1L;0FAAiB;;;4CAAC;8CACb;8C3DqJf;mD2D6DPr1L;;gD3D7DO;;kDACA;;oDACK;;sDACA;;wDACd;;0DACA;;2DACG;;2EACQ,oCADRlB;;+D2DuDDkB,K3DxDFnB;;6D2DwDEmB,K3DzDFpB;;2D2DyDEoB,K3D1DYrB;;yD2D0DZqB,K3D3DYvqC;;uD2D2DZuqC,K3D5DOr1D;;qD2D4DPq1D,K3D7DOn6G;;iD2D6DPm6G,KAnNmCD;;+CAmNnCC,KApNOH;;6CAoNPG,KArNQL;;2CAqNRK,KAtNOR;;yCAsNPQ,KAvNQZ;2CAuNRY;mCACuB;;;oCa7L7B;;gDADA+lJ;yCAAwC;2DAAxCj7G;oDAAqB;sEAArBm7G;yGAAoB;6DAApBn7G;mEAAuC;kDAAvCi7G;wDAA+D;;;oCbiY3D7lJ,WAnMyBqyL,Ka5L7B,oCb4L6BA;;uCAmMzBryL,KApMEF;yCAoMFE;kCanYJ,IboYqCyiX,KapYrC;2CboYqCA;oCACJ;oCA5FG;;;sCarKtC,IbqKsCC,KarKtC;+CbqKsCA;uCACL;;;wCanKjC;kD6XjLNjzO;2CAAe;oD3K6TblD;6DrN9RApsE;sDAAwC;wEAAxCk1H;iEAAqB;mFAArBE;sHAAoB;0EAApBF;gFAAuC;+DAAvCl1H;qEgY/BY;oDAAdsvE;0D7XgLQ;8CACF;;iDbkKsCizO;oCA4FH,IAwP7BtiX;;4CAzPiCqiX;;qCAyPjCriX,KA1PAJ;uCA0PAI;gCAC6B;gCUrrBvB;;;kCGgMZ,IHhMYuiX,KGgMZ;2CHhMYA;oCACuB;;;qCGgMf;+CAApBC;mFAAmB;qCAAC;;6CHhMeE;qCACN;;;sCGkM7B;gDAFAC;yCACA;2DADAE;oDAAwC;sEAAxCE;+DAAqB;iFAArBE;oHAAoB;wEAApBF;8EAAuC;6DAAvCF;mEAA+D;kDAA/DF;wDACa;;uCACb;;+CHnMmCD;;6CADvBH;gCVqrBuB,IaznBnCJ;;wCbwnBMniX;qCaxnBNmiX;8BAC8C;qCA6HpD33N;+BA7HoD,MA6HpDD;+BA7HoD;yCAApBtE;kCAAa;oDAAbE;0FAAY;2CAAZF;iDAAkB;+BAAE;yCAAlCF;+EAAY;8BxEmlCe;mCwEnlCOq9N;;gCxEmlCP;gCAnCtB;qCAmCsBvkX;;kCAnCtB;;;mCAmCR;;;;;iDAAK,MAALwkX;2CAnCQ5kX;mCAAqB;;;oCAmCCI;qCAnCD;gDAmCpB4kX;;;;;;;wDAAW,YAAXE,cAnCmB;;;;uCAmCE9kX,IAnCtBJ;gCAmCsB,IwEnlCO2kX,WxEmlCPvkX,IAC5B,yBAD4BA;uCwEnlCOukX;gCACxC,UA4HZ54N,SA5HY,MA4HZD;gCPzBkB;gCOnGN,IPmGM;gCAnKV;qCAmKU2nC;;kCAnKV;;;;;sCyN4UN/lD;+CzN7UO19D;;;;;;;uDAAiC,0BAAjCs1S,cAA+D;;;kCAChE;oCAEA;;;;;;;;sDAAiC,0BAAjCG;oCAA+D;qCAG/D;;;sCA8JUhyL;uCA9JV;yCyNuUNjoD;kDzNxUO36D;;;;;;;0DAAiC,0BAAjCg1S,cAA+D;;;;yCA+JtDpyL;;4CAnKV/xL;yCAmKU+xL;kCACA;kCA1HV;uCA0HUK;;oCA1HV;;;;;wCyNkSNpmD;iDzNnSOkf;;;;;;;yDAAiC,0BAAjCq5N,cAA+D;;;oCAChE;sCAGA;;;;;0CyN+RNv4O;mDzNhSOw2O;;;;;;;2DAAiC,0BAAjCmC,cAA+D;;;sCAChE;wCACE;;;;;;;;0DAAiC,0BAAjCI;wCAA+D;0CAGjE;;;;;8CyN2RNj8O;uDzN5ROq8O;;;;;;;+DAAiC,0BAAjCE,cAA+D;;;0CAChE;4CAEA;;;;;;;;8DAAiC,0BAAjCI;4CAA+D;8CAE/D;;;;;;;;gEAAiC,0BAAjCI;8CAA+D;gDAE/D;;;;;;;;kEAAiC,0BAAjCI;gDAA+D;kDAE/D;;;;;;;;oEAAiC,0BAAjCI;kDAA+D;oDAE/D;;;;;;;;sEAAiC,0BAAjCI;oDAA+D;qDAE/D;;;;;;;;sEAAiC,0BAAjCI;;yDAuGUz0L;;;;;;;;;;oDAnHVvrC;;6CAmHUurC;;gDAvHV7rC;;yCAuHU6rC,KA1HVhsC;2CA0HUgsC;oCACH;;sCAIT;;;;iDADEgH;uFAA8B;sCAChC;wDAFE6tL;;;;;;;gEAAiC,0BAAjCE,cAA+D;;;;oCAFxD;kCADG;gCADA;8BOpGkC;4BAD9C,WA0IO;mCAZb5nT;4B;4BAQM,sB,OrDpNN4sH;4BqDoNM;;;gC6XhKNn/C;gD,O3YtDAgzM;6BcsNM;6BADA;;6BALA;qDHjJN4tB;6BGiJM;4BA/IN,SA6IA9nd,KA7IA,0CA6IAA;4BAQM;6BArJN,YA6IAA;6BA7IA;;;;;;8B;8BAAA;;;;;;;;;;wC0E2cI;0C1E3cJ;;;;;;;;;4FA6IAA,EA1H+C;qDAnB/C47I;;;;;;;6CAII;uEAJJF;;+CAII;;;gDAQI;;oD,8BrD3ER2qJ;;gDqD2EQ;;mD6XvBRn/C;mD7XuBQ;sD,8Bd7ERgzM;;gDcwEQ;gDADA;;4DbkmBFo4B;qD,OxCvqBNjsL;0DwCuqBMisL;gDalmBE;;+CbkmBF;oDapmBFj8N,UbomBE;;;;kDAsBIyrO;kDAUAC;kDAhCJ5rK;;;;;;;;;;;;;;;;;;;;;;;oHAkC+C;wEAlC/Cv6K;;;;;;+DAsBI;2FAtBJu6K;;iEAsBI,IA7QJ3uC,OA6QI;iEA7QJ;sEA6QI7xB,UA7QJ;;;;oEAqBIqsO;oEAQAlgC;oEACAmgC;oEA9BJh4K;;;;;;;;;;;;;;;;;;;;;;;sIAkC+C;0FAlC/CruK;;;;;;;kFA6BI;8GA7BJquK;;oFA6BI;;;;;iFACA;6GA9BJA;;mFA8BI,IAnGJv5C,OAmGI;mFAnGJ;wFAmGI/1D,UAnGJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wJAUsD;4GAVtD/+D;;;;;;mGAQI;+HARJ6lK;;qGAQI;;;kHARJ0/I,0BAQI7mP;;;kGADA;8HAPJmnG;;oGAOI;;;;iGAPJ;;;;;yFAmGI9mG;0FAnGJ;;;;0FAmGIA;2FAnGJ;;;iGAOI0vD;2FAPJ,MAQI63N;;;;;4FADA53N;4FA4FA3vD;;8FA5FA2vD;8FACA63N;;;;;4FA2FAxnR;6FAnGJ;;;;yGAOI0vD;4GACA63N;;mFA2FAD;;gFATA;4GArBJh4K;;kFAqBI,IAnNF1iC,OAmNE;kFAnNF;uFAmNE9xB,UAnNF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uJA0B+C;2GA1B/C75G;;;;;;;mGAkBI;+HAlBJgwK;;qGAkBI,IA7NF77C,OA6NE;qGA7NF;0GA6NEh2D,SA7NF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0KAiBsD;8HAjBtDn+D;;;;;;;;;;yHAaI;qJAbJg0H;;2HAaI;;;;;wHACA;oJAdJA;;0HAcI;;oI0FghBZlvJ,e1FkGI4xW,oBAlnBQtyR;;;uHAFA;mJAZJ4vE;;yHAYI;;;;;sHAGA;kJAfJA;;wHAeI;;kI3DoJZxiB,a2D6dIltI,UAjnBQ0/E;;;qHAJA;iJAXJgwE;;uHAWI;;;;;oHADA;gJAVJA;;sHAUI;;;;mHAVJ;;;;;2GA6NE71D;4GA7NF;;;;4GA6NEA;6GA7NF;;;mHAUIwoR;6GAVJ,MAWIC;6GAXJ,MAYIC;6GAZJ,MAaIC;6GAbJ,MAcIC;6GAdJ,MAeIC;;;;;+GADAE;+GADAC;+GADAC;+GADAC;+GADAC;+GAmNFnpR;;iHAnNEmpR;iHACAD;iHACAD;iHACAD;iHACAD;iHACAD;;;;8GA8MF9oR;+GA7NF;;;;2HAUIwoR;;4HACAC;;6HACAC;;8HACAC;;+HACAC;kIACAC;;qGA8MFR;;kGAKA;8HAvBJx2K;;oGAuBI;;0HA8ZNg2K,YA9ZM5nR;;;iGACA;6HAxBJ4xG;;mGAwBI;;;;gGAxBJ;;;;;wFAmNEn2D;yFAnNF;;;;yFAmNEA;0FAnNF;;;gGAkBI2sO;0FAlBJ,MAuBIC;0FAvBJ,MAwBIC;;;;;2FADAc;2FALAC;2FAiMF5tO;;6FAjME4tO;6FAKAD;6FACAD;;;;;2FA2LF1tO;4FAnNF;;;;wGAkBI2sO;;yGAKAC;4GACAC;;kFA2LFN;+EArBJ;;;;;uEA6QIrsO;wEA7QJ;;;;wEA6QIA;yEA7QJ;;;+EAqBIqsO;yEArBJ,MA6BIlgC;yEA7BJ,MA8BImgC;;;;;0EADAsB;0EARAC;0EAwPA7tO;;4EAxPA6tO;4EAQAD;4EACAD;;;;;0EA+OA3tO;2EA7QJ;;;;uFAqBIqsO;;wFAQAlgC;2FACAmgC;;iEA+OAH;;8DAUA;0FAhCJ3rK;;gEAgCI,IU9rBRstK,OV8rBQ;gEU9rBR;qEV8rBQ5tO,UU9rBR;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qIAaqD;yFAbrDj6G;;;;;;;iFAWI;6GAXJwoK;;mFAWI;;yGAXJmjK,QAWIzxN;;;gFADA;4GAVJsuD;;kFAUI;;;+FAVJkjK,+BAUItxN;;;+EADA;2GATJouD;;iFASI;;;;8EATJ;;;;;sEV8rBQvuD;uEU9rBR;;;;uEV8rBQA;wEU9rBR;;;8EASI6tO;wEATJ,MAUIC;wEAVJ,MAWIC;;;;;yEADAE;yEADAC;yEVqrBIluO;;2EUrrBJkuO;2EACAD;2EACAD;;;;;yEVmrBIhuO;0EU9rBR;;;;sFASI6tO;;uFACAC;;wFACAC;;;gEVmrBI7B;6DAhCJ;;;;;qDapmBF1rO;sDbomBE;;;;sDapmBFA;uDbomBE;;;6DAsBIyrO;uDAtBJ,MAgCIC;;;;;wDAVAkC;wDa1nBN5tO;4Db0nBM4tO,kBAUAD;;;;;wDapoBN3tO;yDbomBE;;;;qEAsBIyrO;wEAUAC;;+CapoBNN;;4CAaA;sEAjBJ/lV;;8CAiBI,IPkGJwoV,OOlGI;8CPkGJ;mDOlGI3tO,UPkGJ;;;;;;;;;;;;oDACI4tO;oDACAC;oDACAj0N;oDACAm0N;oDAJJ5oV;;;;sD;sDAAA;;;;;;;;;;gEiFwVI;kEjFxVJ;;;;;;;;;yHAU+C;6EAV/CE;;;;;;;;sEAGI;gGAHJF;;wEAGI;;;;;qEADA;+FAFJA;;uEAEI,IA9HF8zH,OA8HE;uEA9HF;4EA8HEzvE,SA9HF;;;;;;;;;;;;;;;;;;6EAEIg0D;6EAGAC;6EAGAC;6EACAC;6EAGAC;6EAEAC;6EAEAC;6EAEAC;6EAEAC;6EAEAC;6EAtBJ94G;;;;+E;+EAAA;;;;;;;;;;yFiFodE;2FjFpdF;;;;;;;;;kJAyB+C;sGAzB/CE;;;;;;;;;;;;iGAQI;2HARJF;;mGAQI;;;;;;yGAAI;;;;;0GAAJG,UAAItqF;;;;qGAAJsqF;sGAAI,yBARRrsF,YAQIqrI;;;gGANA;0HAFJn/C;;kGAEI;;;;sGoYzBN6qG;+GpY0BSxmI;wGAAD,SAACA;;;;;;;;;;;wIAHPvwD,YAGOuwD,KACsB;sGAFzB+6E;;;+FAOA;yHATJp/C;;iGASI;;;;qGyN2KyB2nG;8GzN1KtBtjI;uGAAD,SAACA;;;;;;;;;;;uIAVPvwD,YAUOuwD,KAC8B;qGAFjCi7E;;;8FAKA;wHAdJt/C;;gGAcI;;;;;;sGACE;;;;;uGADFmkD,YACEpjD;;;;kGADFojD;mGACE,yBAfNrwI,YAcIorI;;;6FAIA;uHAlBJl/C;;+FAkBI;;;;;;qGACE;;;;;sGADFqkD,YACE/kD;;;;iGADF+kD;kGACE,yBAnBNvwI,YAkBIswI;;;;;;;;;;iGANA;2HAZJpkD;;mGAYI;;;;;;yGACE;;;;;0GADFukD,YACE9kD;;;;qGADF8kD;sGACE,yBAbNzwI,YAYIwwI;;;gGAUA;0HAtBJtkD;;kGAsBI;;;;;;wGACE;;;;;yGADFykD,YACE7jD;;;;oGADF6jD;qGACE,yBAvBN3wI,YAsBI0wI;;;+FAFA;yHApBJxkD;;iGAoBI;;;;;;uGACE;;;;;wGADF+9D,YACEl+D;;;;mGADFk+D;oGACE,yBArBNjqJ,YAoBIowI;;;8FAJA;wHAhBJlkD;;gGAgBI;;;;;;sGACE;;;;;uGADFi+D,YACE/+D;;;;kGADF++D;mGACE,yBAjBNnqJ,YAgBIkqJ;;;6FAXA;uHALJh+D;;+FAKI;;;;mGoY5BN6qG;4GpY6BSxmI;qGAAD,SAACA;;;;;;;;;;;qIANPvwD,YAMOuwD,KACsB;mGAFzB65F;;uGALJ;;;;0FAyB+C;oFAzB/CnvI;;;6EAEIspL;6EAGAC;6EAGAC;6EACAC;6EAGAC;6EAEAC;6EAEAC;6EAEAC;6EAEAC;6EAEAC;6EAtBJuc;;;;;;2EA8HEhxE;4EA9HF;;;;4EA8HEA;6EA9HF;;;mFAEIg0D;6EAFJ,MAKIC;6EALJ,MAQIC;6EARJ,MASIC;6EATJ,MAYIC;6EAZJ,MAcIC;6EAdJ,MAgBIC;6EAhBJ,MAkBIC;6EAlBJ,MAoBIC;6EApBJ,MAsBIC;;;;;;;;;;;;;;;;;;;;;;;;+EAFAgD;+EAFAC;+EAFAC;+EAFAC;+EAFAC;+EAHAC;+EADAC;+EAHAC;+EAHAC;+EA4HFj4D;;iFA5HEi4D;iFAGAD;iFAGAD;iFACAD;iFAGAD;iFAEAD;iFAEAD;iFAEAD;iFAEAD;iFAEAD;;;;8EAwGFx3D;+EA9HF;;;;2FAEIg0D;;4FAGAC;;6FAGAC;;8FACAC;;+FAGAC;;gGAEAC;;iGAEAC;;kGAEAC;;mGAEAC;sGAEAC;uEAwGF4vO;;oEADA;8FADJ1oV;;sEACI,IAvKFq0H,OAuKE;sEAvKF;2EAuKE9vE,SAvKF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2IAW+C;+FAX/CrkD;;;;;;;uFAKI;mHALJw0H;;yFAKI;;;;;;+FACE;;;;;gGADFv0H,UACEtqF;;;;2FADFsqF;4FACE,yBANNtsF,YAKIsrI;;;sFAHA;kHAFJu1E;;wFAEI;;;;4FoYiBN7pB;qGpYhBSxmI;8FAAD,SAACA;;;;;;;;;;;8HAHPxwD,YAGOwwD,KACsB;4FAFzB+6E;;;qFAKA;iHAPJs1E;;uFAOI;;;;2FyNuNyB/rB;oGzNtNtBtkI;6FAAD,SAACA;;;;;;;;;;;6HARPxwD,YAQOwwD,KACkC;2FAFrCi7E;;oFAPJ;;;;;4EAuKEiF;6EAvKF;;;;6EAuKEA;8EAvKF;;;oFAEI2wE;8EAFJ,MAKIC;8EALJ,MAOIC;;;;;+EAFAS;+EAHAC;+EAqKFvxE,YArKEuxE,aAGAD,aAEAD;;;;;+EAgKFrxE;gFAvKF;;;;4FAEI2wE;;6FAGAC;gGAEAC;;sEAgKFqzN;;mEAGA;6FAJJzoV;;qEAII;;;;;kFACI37B;2EAAF,SAAEA;;;;;;;;;;;2GALRtwD,YAKQswD,KAE0C;;yEAH9CigF;;kEAJJ;;;iEAU+C;2DAV/Cv1H;;;oDACI05Z;oDACAC;oDACAC;oDACAC;oDAJJjxK;;;;;;kDOlGI98D;mDPkGJ;;;;mDOlGIA;oDPkGJ;;;0DACI4tO;oDADJ,MAEIC;oDAFJ,MAGIC;oDAHJ,MAIIC;;;;;qDADAE;qDADAC;qDADAC;qDOnGAnuO;;uDPmGAmuO;uDACAD;uDACAD;uDACAD;;;;;qDOtGAhuO;sDPkGJ;;;;kEACI4tO;;mEACAC;;oEACAC;uEACAC;8COtGAr0N;;2CADA;qEAhBJv0H;;6CAgBI;;;8CAA4B;;0DxEklC9Bo4U;mD,OqJ99BA7yW;wDrJ89BA6yW;8CwEllC8B;;6CxEklC9B;kDwEllCE1uK,UxEklCF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kHAIsD;sEAJtDxpK;;;;;;6DAEI;yFAFJm1H;;+DAEI;;;;;4DADA;wFADJA;;8DACI;;;yEADJ+iN;2EAnCED,aAoCoB9zW;oEAAV,SAAUA;;;;;;;;;;;oGADtB78D,YACsB68D,KAAkD;yEApCtE8zW;+DAoCE,wBADJA;8DAnCE;mEAoCEh0R,SApCF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mIAEsD;uFAFtDjkD;;;;;;8EACI;0GADJw0H;;gFACI;gFAmCM,SAACrwJ;;;;;;;;;;uFAnCP87B,UAmCOtqF;;;qFAnCPsqF,OAmCO,yBADb34F,YACa68D;gFAnCPglX;;6EAAmB;yGADvB30N;;+EACuB;;yFA1qBzB7S,aAyqBEu2N,WACuBj5R;;4EADvB;;;;;oEAoCEgF;qEApCF;;;;qEAoCEA;sEApCF;;;4EACIklS;sEADJ,MACuB70N;;;;;uEAAnB80N;uEAmCFnlS,YAnCEmlS,mBAAmBx0N;;;;;uEAmCrB3wE;wEApCF;;;;oFACIklS;uFAAmB70N;;8DAmCrB20N;2DADJ;;;;;mDwEllCEz/K;oDxEklCF;;;;oDwEllCEA;qDxEklCF;;;2DACIy/K;qDADJ,MAEI10N;;;;;sDADA80N;sDwEnlCF7/K,axEmlCE6/K,cACA10N;;;;;sDwEplCF60C;uDxEklCF;;;;mEACIy/K;sEACA10N;;6CwEplCFuxN;0CAhBJ;;;yCAmB+C;4BAnB/C;;oFA6IA1he;4BA7IA;2EA6IAA;4BA7IA;mCAIIyhe;6BAJJ,MAgBIC;6BAhBJ,MAiBIzxN;;;;+BADAi1N;+BAZAC;wDAYAD,iBACAz0N;4BAjBJ;;qCA6IAzwQ;;+CAzIIyhe;;gDAYAC;mDACAzxN;mCA4HJniJ;4B;yDrD5MA04K;4BqD+DA;;;gC6XXAr/C;gD,O3YtDAkzM;6BWWEktB;;;6BVkWIpmB;qDU9SN4mB;6BGEA,QA6IA/od;6BA7IA,aA6IAA;6BA7IA,YA6IAA;;6BA5HI;;;qCxEilCF60d;8B,OqJx9BA30W;4BrJw9BA;;wCwEllCE+0W;6BxEklCF,UwEllCEA;6BxEolCE;;qCArCFH;;+BAoCoBp8Z;;oCADtBm8Z,aACsBz0d;oCADtBy0d,aACsBn8Z;;4BApCpB;qCAoCEs8Z;6BApCF,eAoCEA;6BAnCqB92Q,MA1qBzBsgD,aAyqBEs2N,WACuBtoL;;6BAmCZ9zO,GAnCPq8Z;6BAmCO30d,GAnCP20d;6BAmCOxia;;6BAnCPisJ,aAmCOjsJ;6BAnCP4rJ,qCAAmBF;6BAmCrBG,SAnCED;6BAmCFI,qCACAF;6BwEplCFK,UxEmlCEH;6BwEnlCFkzF,sCACAZ;;kD,OrDhFJrJ;;6BwCuqBMo7L;;gC0YnnBNz6O;gD,O3YtDAkzM;;qCCyqBMi4B;8B,OxCvqBN9rL;4BwCuqBM;;4DapmBFotL;6BbomBE,capmBFA;6BH1DF;8BV8rBQD;6BU9rBR;8BV8rBQA;6BU9rBR,YV8rBQA;6BUnrBJ,kBAXJpM,QAWI6d;;6BADA;;gCAVJ9d;gCAUI+d;mEACAh1L;6BAFA;mEACAE;6BADA;6BVqrBIN;6BAvRJ,+BA6QIyjL;6BA7QJ,+BA6QIA;6BA7QJ,kBA6QIA;6BAlVJ;8BAmGID;6BAnGJ;8BAmGIA;6BA3FA;;gCARJtyB,0BAQIC;;6BADA;mEACAljM;6BADA;6BA4FAI;6BADA;mEACAA;6BA5NF,cAmNEi1N;6BAnNF,yBAmNEA;6BAnNF,QAmNEA;6BA3LE;;6BADA,kBA8ZNqO,YA9ZMvO;mEACAz1N;6BAnOF,gBA6NEw1N;6BA7NF,iBA6NEA;6BA7NF,OA6NEA;6BA7NF,QA6NEA;6BA7NF,OA6NEA;6BA7NF,QA6NEA;6B3D1DV,iB2DpJYD;6B3DoJZ,S2DpJYA;6B3DoJZ,M2DpJYA;6B3DoJZ,M2DpJYA;6B3DoJZ,oB2DpJYA;6B3DoJZ,oB2DpJYA;6B3DoJZ,e2DpJYA;6B3DoJZ,e2DpJYA;6B3D4JR;;6BADA;iEACAt2U;6BAFA;iEACAC;6BAFA;iEACA4G;6BAFA;iEACAC;6BAFA;iEACA4S;6BAFA;iEACA4qC;6BAFA;iEACAC;6BADA;6B2DrJQqc;6BADAG,O0FshBZ9+F,e1F4FIwzW,oBAlnBQK;mEACAl1Q;6BAFA;mEACAE;6BAFA;mEACAE;6BAFA;mEACAE;6BAFA;mEACAE;6BADA;6BAmNF+/C,sCAKAF;6BA4LFK,UAjMEH;6BAiMF+xC,sCAQAvxC;6BAgPAwxC,UAxPAD;6BAwPAI,sCAUAF;6BapoBNC,Ub0nBMC;6Ba1nBNS,sCAYAH;sCAZAG;mCAyIJvoL;4B,UAAA1lH;qCb2dM4ie,2BalmBEp2W;8B,OrDrERw3K,2BqDqEQx3K;;;;;;6Bb9BE6yI,OAgoBJujO,2Ba3dND;6BbrKUrjO;;oCAgoBJsjO,2BAhoBIrjO;6B3DmKRE;;gCqJoXAt7I;gC1FyGIy+W;gCAhoBIpjO;;;6B3DmKRhzI;;;;;;;6BwE/HMwyI,+BxE+HND;;6B2DwCM8jO;;gC0Y9LR1+O;yC7XuBQ33H;kC,Od7ERqrU;oDc6EQrrU;6C,OrD3ERw3K,2BqD2EQx3K;;;;;6BbqWFkzI,wBA9LEmjO;6BarCJjjO,wBbmOEF;;6BalOAC,+BADFC;6BAKAkjO;qDHrJJzd,eGiJM1lN;;6BAKAojO,iCADFD;6BAEEE;;;;gCADAD;;;2CACAv2W;8B;uC6XhKN23H;gD7XgKM33H;yC,OdtNNqrU;2DcsNMrrU;oD,OrDpNNw3K,2BqDoNMx3K;;;;;;6BArJNy2W;;qEAqJMD;mCARNhje;qCxEq9BEkje,oBwEllC8B12W;8B,OA/EhC89H,gCA+EgC99H;;qCxE+iC5B22W,kBAoCoB32W;;;;qCADtB02W,oBACsB12W;qCADtB02W,oBACsB7uT;;;;6BAATp/F;;oDwEnmCfguZ,OxEmmCer6N;6BApCXzJ,uBAoCWD;6BADbD,MA5sBAR,eAyqBE0kO;6BwE/jCJ/jO,wBxEkmCEH;mCwEr9BFj/P;;;6BPhME6/P;;gCoYmBFrc;yCpYhBSh3H;;;;;;;gCOgDT4yI;;;6BP7CQhqL;;+DANNyqL,OAMMujO;6BANNrjO,kCAMMD;;6BAgKRE;;gCyN4KE1e;yCzN1UO90H;;;;;;;gCARPuzI;;;;6BA0CAE;;gCoYvBFzc;yCpY0BSh3H;;;;;;;gCAyHTwzI;;;6BA5HEkvC;;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5D;;4B,O9VlFNggH;;4B,OuCFA0zJ;;;;8B4QoIAzjL;;gC,O+HnFI80E;4C/HmFJ90E;;4B,OjQzHE+wM;;;4CqNgP4BjnO,enO9LrBpmE;;iCiB5BLi4S;;qC,Ob4UE9wB;;mCapCFlnb;;qCAkB+C;;iCAD7CA;0B,qBkN/FwBomO,cuFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA2zJ;;;;8B4QoIA1jL;;gC,O+HnFI80E;4C/HmFJ90E;;4B,OjQzHEkxM;;4CqNgP4BpnO,crNvM1B4nO;;iCGnBAsK;;qC,Ob4UEjxB;;mCanBArnb;;;uBAC6C;iCAlB/CA;0B,qBkN9E0BomO,cuFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA2zJ;;;;8B4QoIA1jL;;gC,O+HnFI80E;4C/HmFJ90E;;4B,OjQzHEkxM;;4CqNgP4BpnO,crNvM1B4nO;;iCGnBAyK;;qC,Ob4UEpxB;;mCapCFrnb;2CAkB+C;uBAlB/C;uCAAKuxd;sBuV7PO;uBvV6PZ;;;;;;;;;;;;gCAuCWe;uBAvCX;;yBAAKf;yBAALC;;;;mD;uBAAA;;;;;;;;uBAmCF;;sBuVhSc;uBvVgSd;;;;;;;;;;;4C;;wBjB1RUp1C;0B8YjCAnrG;4B3YjDIyuG;8BvCERxzJ,0BuQyPsBjmD,ezUnMvBg4M;uBuHoTL;6BjB1RU7B;;;2B,OcvE0C0wB,gB5FqJ1Dx8R;;6B8EnGgB2rQ,gBcTH8xB;;;wC,OVyTiCjnB;uBaiCtC;;;;;;;4C,OA7WoE+sB;;uBA6WpE;uBAmB+C;wC,UAnB/Cqf;uBAmB+C;iCAnB/C9te;0B,qBkNnJ0B8gP,cuFvKxB/5D;gD,O9VlFNggH;gD,OuCFAyzJ;gD,O2YiDI1uG;gD,O9YiCAmrG;;gD,OAAAA;;4B,OcvEF2wB;yCdkDE5nd;4B,kBmO8L0B8gP,cnO9LrBpmE,UAAL16K;;iCiB5BA0ud;mD,Ob4UE/sB;;mCaiCF3hc;uBAmB+C;iCAnB/C4a;0B,qBkNnJ0BmmO,euFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA0zJ;;4B,O2YiDI3uG;;4B,O9YiCAmrG;;;4B,OAAAA;;4B,OcvEF8wB;;yCdkDEptc;4B;gDmO8L0BmmO,enO9LrBpmE,SAAL//J;;iCiB5BAg4c;;qC,Ob4UE9wB;;mCaiCFlnb;;qCAmB+C;;iCAD7CA;0B,qBkNrKwBomO,cuFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA2zJ;;4B,O2YiDI5uG;;4B,O9YiCAmrG;;;4B,OAAAA;;4B,OcvEFixB;;4B,OdkDEtxB,ccTA8xB;;iCGnBAsK;;qC,Ob4UEjxB;;mCamDArnb;;;uBAC6C;iCAnB/CA;0B,qBkNnJ0BomO,cuFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA2zJ;;4B,O2YiDI5uG;;4B,O9YiCAmrG;;;4B,OAAAA;;4B,OcvEFixB;;4B,OdkDEtxB,ccTA8xB;;iCGnBAyK;;qC,Ob4UEpxB;;mCaiCFrnb;2CAmB+C;uBAnB/C;uCAAKmzd;sBuVlUO;uBvVkUZ;;;;;;;;;;;;;gCAwCWe;uBAxCX;;yBAAKf;yBAALC;;;;mD;uBAAA;;;;;;;;uBAoCF;;sBuVtWc;uBvVsWd;;;;;;;;;;sBAoBH;;sB1G9bGt0V;sBI4HFsV;sB6bxDgB;;;;;;;;;;;;;;;;;;;;;;;;;;;sB7buDhBD;sBJ5HEtV;sBsqBVN;;sBrO+EoB;uBqO/EpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAEkD;;sBtqBS5CC;sBI4HFsV;sBADAD;sBJ5HEtV;sB2GVN;;sBAiBM;;;;;;;;;;;;;;;;sBsV8Dc;uBtV3DR;iCAM+B8+H;0BACzB,IAAZ4wM,UAAY,sCADyB5wM;0BAGzB;uEAFZ4wM,WAEwC;uBATlC;;;;;;;;;;;;;;;;;;uBAgBC;uBAII,uBAhCbr7H,uBdu0CIyvF;uBcvyCS;;;;yBAhCbzvF;;;uBAgCa;wC,aduyCTyvF;uBcvyCS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2BA8BTjsX;2BA5CJ29a;uBAca;;;;;;;;;;;;;;0B;;sCduyCT1xD;;;;mCcv0CJzvF,uBA6E6B;sBsVNb;;;uBtV+BJ,kBrDqEVrlD,cAtGA0kD;uBqDiCU;kCdiuCRowF;uBcjuCQ,OdiuCRA;uBcjuCQ,KdiuCRA;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;qCukB3PXqa;;;;;;;;oC9oBmCMjD;oC2gBzFSyV;mC3gBqHXlxK;;mCuEtFJxsE;;qC;;;;;;;;;;;;;;kCvE/DE2xO;kCAEAlvT;;;;;;kCA+PAs/T;kCASAE;uBAxTN;;2B;;;;;;;uBAAA;;;sBAykF6C;;sBnCjkFvChlX;sBI4HFsV;sBADAD;sBJ5HEtV;sB2rBTN;;sB1P8EoB;uB0P9EhBioX;;;2BAIK;;;;;8CjDkIPzyE;;4BiDlIYz7Q,eAALxuB;+CAC6CpqI;6BjDiIpD,sCiDjIoDouI;oCAD7CorB;;;8BjDmIH,qBiDnIGx5J;8BjDoIH,4BiDpIGA;8BjD0GO,qBiD1GPA;8BjD0Ge,qBiD1GfA;8BjD0Ge,sBAAR24O,IAAQsuQ;8BA4BlB,2BiDtIGjnf;8BjD8HO,qBiD9HPA;8BjD8He,qBiD9HfA;8BjD8He,UAARonf,IAAQC;;qCAKlBN;qCACAC;qCACAE;qCACAC;qCACAG,OiDrIkC;+BAF/B7tV;;6BjDkIP;;iCiDlIOr0K;8BjDkIP,GiDlIOA;8BjDkIP,GiDlIOA;8BjDkIP,KiDlIOA;8BjDkIP,KiDlIOA;8BjDkIP;;8BAxBA,GAwBAy4N;8BAxBA,GAwBAA;8BAxBA;8BAwBA;;;;iCAxBA;8BAwBA;8BAJA,KAIAm5B;8BAJA,KAIAA;8BAJA;;;sCAIAI;sCAJA;oCiD9HOh+E;;;8BjDkIP,GiDlIOh0K;8BjDkIP,GiDlIOA;8BjDkIP,GiDlIOA;8BjDkIP,KiDlIOA;8BjDkIP,KiDlIOA;8BjDkIP,uBiDlIO4a,UjDkIP8gI;qDiDlIO9gI,IjDkIPoqC;8BAxBA,GAwBAyzK;8BAxBA,GAwBAA;8BAxBA,qBiD1GO79M,IjD0GPmqC;qDiD1GOnqC,IjD0GPjF;8BAwBA,uBiDlIOiF,IjDkIPwnC;8BAJA,KAIAwvM;8BAJA,KAIAA;8BAJA,uBiD9HOh3O,IjD8HPssC;qDiD9HOtsC,IjD8HP4nC,WiD5HsC;;4BAF/ByxH;qCAAKT,YAALS;;;;;;;qCAAKT;qCAALS;;;0CAE+B;sBAGi0B;;sB3rBCn2Bv6B;sBI4HFsV;sBADAD;sBJ5HEtV;sB4rBVN;;sBAAS,wBnDcLqoE;sBmD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DlrS;4BAE1C,iDACN;uBAHV;uBAeM;;;;;;;4C,OylBnBsBswgB,8BhT+LnBxlV;;uBzS5KH;uBAA8D;wC,UAA9DqmV;;uCAAKC;sB6UgDO;uB7UhDkD;uBAA9D;;;;;;;;4C,OylBnBF7uN;8BhT+LKz3H;;uBzS5KH;uBAA8D;wC,UAA9DymV;;;;;;;;;yCzGoIRlmV,2ByGpIammV;;uBAAL;uBAA8D;wC,UAA9DC;uBAA8D,mBAA9DlugB,iBAA8D;;iCAA9D4Z;;mDsD0EA6rK,ctD1EA7rK;6BylBnBFwzf,erjBmBEtH,oBpCAAlsf;;;0BAA8D,OAA9D5Z,CAA8D;;iCAA9D4Z;;;;;;;0BAA8D,OAA9D5Z,CAA8D;0CAA9DqugB;uBAA8D;iCAA9DrugB;;;;;mEsD0EAulL,ctD1EA7tH;;mDylBnBF61c,crjBkBA3H,mBpCCEjuc,IAA8D;;iCAA9D/9C;;;;;0CsD0EA4rK,etD1EA5rK;iCylBnBF4zf,erjBkBA3H,oBpCCEjsf,WAA8D;0CAA9D40f;uBAA8D,YAA9DL;uBAA8D;uBAchE;;;;;;;4C,OylBjCwBpB,8BhT+LnBxlV;;uBzS9JL;uBAuBG,mB,UAvBHqnV;uBAuBG;iCAtBDn/b;0BylBlCF;8BzlBkCEA;2BylBlCF,GzlBkCEA;2BylBlCF,wCrjBkBAm2b,cqjBlBAluc;;uBzlBwDG;iCylBxDH99C,UzlBkCE61D;0BylBlCF;8BzlBkCEA;2BylBlCF,GzlBkCEA;2BylBlCF,erjBkBAo2b,eqjBlBAjsf;4DzlBmCmC;uBAqBhC,mBwC4IIi1f;uBxC5IJ;iCAtB6Cj1f,IylBlChDouI,QzlBkCgDmrB;0BylBlChD;uBzlBwDG;iCylBxDHv5J;0BAEI;0CrjBiBFksf,eqjBnBFlsf;2BAEgB,yBAFhBA;0BAEgB,UAAZyzf,IAAYC,SzlBiCmB;uBAqBhC,mBwC4II2B,MAqCPD;uBxCjLG,YwCuJElyN,GxC9KLiyN,gBACEG;uBAsBC;;iCAtBD17V;0BylBhCM,GzlBgCNA,gBylBhCM;0BzlBgCK,qB6DmlCTyyV,S7DnlCFzyV;sEAA8D;uBAsB7D;iCAtBDmD;0BylBhCM,GzlBgCNA,gBylB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P;uBAGqD;;0BAHrD;;;6BP/KA,GO+KAz0b;6BP/KA,GO+KAA;;6BP/KA;;;;;0BO+KA,kBHlLF,KGkLEG;;gDHlLF,0CGqLuD;;iCAHrDjhI;;;;;6BP/KA,GO+KA8gI;6BP/KA,GO+KAA;6BPtJF;6BAzBE,aO+KA9gI,IPtJFoqC,MAzBE0T;oDO+KA99C,IP/KAjF;0BO+KA;;;2BHlLF,KGkLEkmI;2BHlLF,yBGkLEjhI,IHlLFmqC;0CGkLEnqC,IHlLFwnC,WGqLuD;;iCAHrDxnC;;;4BPtJF;;6BArBM,oBO2KJA;6BP3K+B,0BO2K/BA;6BP3K+B,SAA3B41jB,cAA2BC;sCO2K/Bn5Z;;4BHlLF,4BGkLE18J;4BHlLF;6BACsB;mDGiLpBA;yCHjLoB81jB;;iCGiLpBh9W,QHlLF,uBGkLE1qE;;mEAGqD;;iCAHrDjoC;;;;;;;;;;;;4B8BmVE,c9BnVF;;;;;;;;;;;;;;;;;;;;kCHlLF,SGkLE3gH;;;;;;;2DHlLF,2BGkLEA;;;;;;;;;;;;;0CHlLF;;;;;;;;;;;;;;;;;;;;;uDACsB;mFADtBgxQ;;;;0EACsBp1E,aADtBv+L;;8DACsBu+L,aADtB,sCGkLE57L;yDHjLoB;;sDADtB;;;;;8CGkLEmyD;+CHlLF,mDGkLEnyD;;6CHlLF;kDGkLEmyD,KHlLF,0CGkLEnyD;;+CHlLF,UACsBwwkB;+CADtB;gFGkLEr+gB,QHjLoBs+gB;;;iDGiLpBt+gB;kDHlLF;;oDGkLEnyD;gEHjLoBwwkB;;;2CGiLpBr+gB,KHlLF,mCGkLEnyD;;8CHlLF,kCGkLEA;uDHlLF,2BGkLEA;;;;;;;gCP/KA,SO+KAo9I;0CP/KA,oCO+KAA;;kCP/KA;+CO+KAA;mCP/KA;;;;;;;;;;;;;;;;;;;;;;;;;iGO+KAA,KP1KsD;yDALtDZ;;;;;;gDAII;0EAJJF;;kDAII;;;;;+CAA2B;yEAJ/BA;;iDAI+B;;;;8CAJ/B;;;;;sCO+KAe;uCP/KA,iDO+KAD;;qCP/KA;0CO+KAC,KP/KA,wCO+KAD;;uCP/KA;8CAIIszb;wCAJJ,MAI+BC;;;;;yCAA3BE;yCO2KJxzb,QP3KIwzb,kBAA2BD;;;;;yCO2K/Bvzb;0CP/KA;;4CO+KAD;;sDP3KIszb;yDAA2BC;;0CO2K/Btzb;;iEAGqD;;;0BAHrD;4BACE;;6BPhLF,SOgLED;6BPhLF,cOgLEA;6BP5K6B;;6BAA3B;iEAA2BK;6BAA3B;kDO4KFz9I;0BACA;;2BHpLJ,eGoLIq9I;2BHnLkB;;;gDGmLlBlrF,SACmD;;iCAHrDylH;0B,SAAAr0K;4BACE;gCADFA;6BACE,iCADFq0K;;6BP/KA7nD,eawOA0gZ,eb/MFvuQ,MOuJIxY;oDPhLF35H,IOgLE25H;0BACA,SAFFnmP,OAEE,iCAFFq0K;4CMyDA64V,eT1OAtuQ,MGmLEk+E;uBAFF;uCAAK2vP;sB2S7GS;uB3SwHd;;;;;;;;;0CPvJGrd;6CI5BA2N;;uBGmLH;uBAMqD;wC,UANrD2Q;uBAMqD;;0BANrD;;;6BP/KA,GO+KA31b;6BP/KA,GO+KAA;6BP/KA,GO+KAA;6BP/KA,GO+KAA;;6BP/KA;;;sE6lBPFg0a,c7lBOEj3V;;;;;0BO+KA;;2BHnLF,KGmLE58E;2BHnLF,KGmLEA;2BHnLF;;;;kFGyLuD;;iCANrDjhI;;;;;6BP/KA,GO+KA8gI;6BP/KA,GO+KAA;6BP/KA,GO+KAA;6BP/KA,GO+KAA;6BPvJF;6BAxBE,aO+KA9gI,IPvJFgtC,MAxBE8Q;4CO+KA99C,IP/KAjF;8C6lBPFg6iB,etlBsLE/0iB,IP/KAwnC;oDO+KAxnC,IP/KA4nC;0BO+KA;;;2BHnLF,KGmLEq5F;2BHnLF,KGmLEA;2BHnLF,yBGmLEjhI,IHnLF+sC;0CGmLE/sC,IHnLFoqC;0CGmLEpqC,IHnLFmqC,WGyLuD;;iCANrDnqC;;;4BPvJF;;6BAvBM,kBO8KJA;6BP7KI,oBO6KJA;6BP5KI,sB6lBVNg1iB,etlBsLEh1iB;6BP3KI,0BO2KJA;6BP3KI,SAHA82jB,YACAlB,cACAmB,WACAlB;sCO2KJn5Z;;4BHnLF,4BGmLE18J;4BHnLF;6BAEQ;gDGiLNA;8BHhLM,qBGgLNA;yCHjLMg3jB,YACAlB;;iCGgLNh9W,QHnLF,uBGmLE1qE;;mEAMqD;;iCANrDjoC;;;;;;;;;;;;4B8BwUE,c9BxUF;;;;;;;;;;;;;;;;;;;;kCHnLF,SGmLE3gH;;;;;;;2DHnLF,2BGmLEA;;;;;;;;;;;;;0CHnLF;;;;;;;;;;;;;;;;;;;;;;;;;;;yGGmLEA,GH9K6C;iEAL/Cw8I;;;;;;wDAGQ;oFAHRw0H;;0DAGQ;;;;;uDADA;mFAFRA;;yDAEQ;;;;sDAFR;;;;;8CGmLE7+M;+CHnLF,mDGmLEnyD;;6CHnLF;kDGmLEmyD,KHnLF,0CGmLEnyD;;+CHnLF;sDAEQ0xkB;gDAFR,MAGQlB;;;;;iDADAmB;iDGiLNx/gB,QHjLMw/gB,gBACAlB;;;;;iDGgLNt+gB;kDHnLF;;oDGmLEnyD;;8DHjLM0xkB;iEACAlB;;;2CGgLNr+gB,KHnLF,mCGmLEnyD;;8CHnLF,kCGmLEA;uDHnLF,2BGmLEA;;;;;;;gCP/KA,SO+KAo9I;0CP/KA,oCO+KAA;;kCP/KA;+CO+KAA;mCP/KA;;;;;;;;;;;;;;;;;;;;;;;;;;;iGO+KAA,KPzKsD;yDANtDZ;;;;;;;;kDAGI;4EAHJF;;oDAGI;;uE6lBVNmza,c7lBUMh0X;;;iDAFA;2EADJn/C;;mDACI;;;;;gDACA;0EAFJA;;kDAEI;;;;;+CAEA;yEAJJA;;iDAII;;;;8CAJJ;;;;;sCO+KAe;uCP/KA,iDO+KAD;;qCP/KA;0CO+KAC,KP/KA,wCO+KAD;;uCP/KA;8CACIw0b;wCADJ,MAEIlB;wCAFJ,MAGImB;wCAHJ,MAIIlB;;;;;yCADAmB;yCADAjB;yCADAkB;yCO8KJ10b;;2CP9KI00b;2CACAlB;2CACAiB;2CACAlB;;;;;yCO2KJvzb;0CP/KA;;4CO+KAD;;sDP9KIw0b;;uDACAlB;;wDACAmB;2DACAlB;;0CO2KJtzb;;iEAMqD;;;0BANrD;4BACE;;6BPhLF,SOgLED;6BPhLF,WOgLEA;6BPhLF,cOgLEA;6BPhLF,YOgLEA;6BP5KE;;6BADA,iB6lBVNsya,c7lBUM6hB;iEACA9zb;6BAFA;iEACAC;6BAFA;iEACA4G;6BADA;kDO+KFtkJ;0BACA;;2BHrLJ,eGqLIq9I;2BHrLJ,YGqLIA;2BHlLI;;2BADA;+DACA8Z;2BADA;gDGmLJhlG,SAImD;;iCANrDiwM;0B,SAAA7+P;4BACE;gCADFA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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wC;uBAAA;;;;;;;;;;;;;;;;;sBA2d6C;sBvJldvCloc;sBADAD;sBwJNN;sByS2EoB;uBzS3EpB,8BkBsWU81T,elBxVFhyY;uBAdR;;;;;;;;;;uBA0BM;;uBAEG;wC,UAFHwkhB;uBAEG,mBAFHn7E;uBAEG,mBADDE,ekBsVEC;uBlBrVD;2BI2LEi7E,mBJ7LLC,gBACEC;uBACC,iBADDzklB,6BAAsE;uBACrE,gB6iB+GLgpgB,Y7iBhHIC;uBACC;;;2B6iB+GLF;2B7iBjHEI;;2BACEE;2BkBsVEC;2Bd1JCi7E;2BJ7LLC;2BACEC;;;2B6iBgHJz7E;2B7iBhHIE;;uBACC;uBAFH;uCI6LKq7E;sBqS5IS;uBzS9BdM;wBACF,iBAAQ,oBAAC;sBAkFV;sBxJzHG5oc;sBADAD;sBmvBNN;sBlT2EoB;uBkT3EpB;;;;;;;;;;;sBAA4C;sBnvBOtCC;sBADAD;sByJVN;sBwS+EoB;uBxS/EpB;0CAMMm2T,eAFApyY;uBAJN;;;sBASY,2BwBwtCFwpc;sBgRlpCU;uBxS7DhB;;uBAEG;wC,UAFHu7E;uBAEG,mBDUD37E;uBCVC,mBDWCE,ekBsVEC;uBjBjWH,YADIy7E,gBADPC,gBACEC;uBACC,iBADDjllB,6BAAsE;sBACrE,U4iB2HHgpgB,Y7iBhHIC;sBCXD;;yB4iB2HHF;yB7iBjHEI;;yBACEE;yBkBsVEC;yBjBlWCy7E;yBADPC;yBACEC;;yBDYEh8E;yB6iBgHJD;yB7iBhHIE;yBCZFi8E;sBwS4Dc,IxS7DhBC;uCACOL;sBAc+C;sBzJtBpD9oc;sBADAD;sBovBTN;sBnT8EoB;uBmTtEd;;;;;;;;;uCzuB0JNuwC,mB8IhJWw4Z;0CGwMAxlC;;uBwlBlNL;uBAImC;wC,UAJnC8lC;;uCAAKC;sBnTsES,ImTtEd;sBA8BA;;;;;;0C,O/mBhCY5tC;4B+mBEP4tC;;sBAoDR;sBpvBlDGrpc;sBADAD;sB0JRN;sBuS6EoB;;uBvSzDd;;;;;;;;;;iCAAQ97I,G,UAARsllB,mBAAQtllB,KAC8C;uBADtD;;0BAiCJ;oCAAuB41H,WAAiB3wH,QAAsC;uBAjC1E;;0BAiCJ;oCAAuB2wH,QAAiB3wH,KAAsC;uBAjC1E;iCAmCW6ijB,oBAAiChljB;0BAED;2BAFPmC;2BAAT2wH;2BAEgB,iBAFC9yH,EAARmC;0BAE7B;6CAAS,WAFL6ijB,cAAgBlyb;uBAnC3B;iCA2CUvyH,EAAGquE;0BACf,GADYruE,GAKR,IADG4B,KAJK5B,KAKR,YADG4B;0BADH,YAHWysE,UAKa;uBAhD1B;;8BAkDqBzsE,cAAT2wH;iDAAS3wH;uBAlDrB;iCAoDKnC;8BAAamC,cAAT2wH;0BAAoC,UAApCA,QAAoC,WAAxC9yH,EAAamC;uBApDlB;iCA+DI5B;0BACN;;4DADMA;mCA9BRmilB;;;+CAgC4E;uBAjExE;iCAmEY9zgB,UAAQruE;0BACtB,sB,OAzBEsilB,kBAwBYj0gB;0BACA,iBADQruE;0BACR,gDAlBZuilB,YAkB+D;uBApE/D;iCAsEiBl0gB,UAAQruE;0BAC3B,eACcA;4BAAK;gDAFAquE;6BAEA;;gCAFAA;8CuClEnBnB,iBvCkEmBmB;4BAEqB,mBAA1BruE,QAA8C;0BAD9C,iBADaA;0BACb,gDArBZuilB,YAuBe;uBASf;;;;;;;;;;iCAAQ5llB,G,UAARimlB,mBAAQjmlB,KAGuC;uBAH/C;iCAAK+8K;0BAAL;;sEAAKA,UAALhiH;kCAG+C;uBAH/C;iCAAKiiH,QAAL//J;;;8CAAK+/J,QAAL//J;8DAG+C;uBAH/C;iCAAKugI,KAALvgI;;;iDAAKugI,KAALvgI;iFAG+C;uBAH/C;;;;;;;;;;;;;4B0BuaE,c1BvaF;;;;;;;;;;;;;;;;;;;;;;;iEAG+C;uBAH/C;;;4BACE,gCADFugI,KACE/6I;;0BACA,YAC6C;uBAH/C;;;;;;8BACW,IAAT2vS,MADFhF,SACW,kBADXtrJ,YACEswJ;;iCADFhF,SAG+C;uBAH/C;;0B,GAAApnS;4BACE,OADFA,OACE,iCADFwsH;4BACE,kBADFkyI,YACErqF;0BACA,kCAFF7nD;;;;;;;;;;;;;;4B0BuaE,c1BvaF;;;;;;;;;;;;;;;;;;;;;;;iEAG+C;uBAH/C;;;4BACE,gCADFgrB,KACE/6I;;0BACA,YAC6C;uBAH/C;iCAOIY,EAAGP;0BAAI,GAAPO,GAA4C,IAALvD,EAAvCuD,KAAgD,qBAA7CP,EAAoChD,IAAX,QAAyB;uBAPzD;;0BASY,UAAkB,IAALA,WAAK,UAALA,GAAsB,QAAI;uBATnD;;0BAWY,UAAmB,IAALA,WAAK,UAALA,GAAqB,QAAI;uBAXnD,uBAeS,gBAAmC;uBAf5C,wBAiBU,gBAAkC;uBAjB5C;iCAmBQ6hL,MAAMn5K;0BAGqC;;2BAAf,iBAH5Bm5K,MAGqC;2BAAK;;mDAXlDmla,YAFAD,kBAUcr+kB,IAIX;uBAvBH;iCAyBI2+kB;0BACN;mCQu/CIznb;4CRr/CKz/J;qCACT,OADSA;sDAHHknlB,eAKKnnlB,GACT,oBADSA,GACK;8CACX,YAAW;uBAhCd;iCAmFO8iP,MAAMz/O;0BAEX,qBAFKy/O,MAAMz/O;0BAEX;2DA5EFwjlB,YAEAC,YA2EkC;uBAtFlC;iCA6FIjwd,UAAW+4H,UAAUvsP;0BACzB;4BAMQ;8BAEA,IADsCvD;8BAClC,0BAAkB,WAT1B+2H,UAQ0C/2H;4BAGtC,QAAM;0BAVd;4BACS;8BAED,IADEA,WACsC,uBAJjC8vP,aAGL9vP;4BAGuC,uBANlC8vP,aAMoD;0BALrD,iBADWvsP;0BACX,sDAUA;uBAxGd;iCA0GYA,EAAUP,GACtB,4BAAmD7C,GAC9C,OAD8CA,CAC7C,EAFMoD,EAAUP,EAEE;uBA5GxB;iCA2HSO,EAASquE,UAAS5uE;0BAE3B;6CAAmC,YAF1BO,GAASquE;2BAtKEzsE;2BAAT2wH;2BACTj3C,OADSi3C,QAAS3wH,KAsKFysE;iCA1KlBg0gB,YArDF59B,iBAyDalyb,QACTj3C,QAqKyB77E,EAEsB;uBAOjD;;;;;;;;;;iCAAQ9C,G,UAARwnlB,mBAAQxnlB,KAGuC;uBAH/C;iCAAK+8K;0BAAL;;sEAAKA,UAALhiH;kCAG+C;uBAH/C;iCAAKiiH,QAAL//J;;;8CAAK+/J,QAAL//J;8DAG+C;uBAH/C;iCAAKugI,KAALvgI;;;iDAAKugI,KAALvgI;iFAG+C;uBAH/C;;;;;;;;;;;;;4B0BmSE,c1BnSF;;;;;;;;;;;;;;;;;;;;;;;iEAG+C;uBAH/C;;;4BACE,gCADFugI,KACE/6I;;0BACA,YAC6C;uBAH/C;;;;;;8BACa,IAAX26K,MADFF,SACa,kBADbp7B,YACEs7B;;iCADFF,SAG+C;uBAH/C;;0B,GAAAl3K;4BACE,OADFA,OACE,iCADFwsH;4BACE,kBADFkyI,YACErqF;0BACA,kCAFF7nD;;;;4BACE,gCADFgrB,KACE/6I;;0BACA,YAC6C;uBAH/C;;;;;;8BACa,IAAXqpL,MADFF,SACa,kBADb9pC,YACEgqC;;iCADFF,SAG+C;uBAH/C;iCAOIu7Z;0BACN;mCQq4CIznb;4CRn4CKz/J;qCACT,OADSA;qDAHHknlB,eAKInnlB,GACR,UADQA,EACD;8CACJ,YAAa;uBAdhB;;0BAgBY,UAAqC,IAALF,WAAK,UAALA,GAAb,QAAwB;uBAhBvD;;0BAkBY,UAAoC,IAALA,WAAK,UAALA,GAAd,QAA0B;uBAlBvD;iCAoBcm5iB,QAAQt3X,MAAMn5K;0BAGQ;;2BAAf,iBAHCm5K,MAGQ;2BAAK;wEAHrBs3X;0BAGqB;mDALnCovC,YAFAD,kBAI4B5/kB,IAIzB;uBAxBH;iCA0BQm5K,MAAMn5K,KAAM,sBAAZm5K,MAAMn5K,IAAoD;uBA1BlE;iCAwDWnF,EAAGP,GACd,4BAAmD7C,GAC9C,OAD8CA,CAC7C,EAFKoD,EAAGP,EAEU;uBA1DxB;iCAqEsB4llB,OAAQrllB;0BAE5B,qBAFoBqllB,OAAQrllB;0BAE5B;2DAvDF+klB,YAEAC,YAsDkC;uBAelC;;uBACqD;wC,UADrDM;;uCAAKC;sBuSpPS;uBvSoPd;;0BAQF,0CAAc9+W,OAAUp5J,SAA+B;uBARrD;;0BAQF;oCAAco5J,IAAUp5J,MAA+B;uBARrD;;0BAegC;mCAE9B;mCAEA;oCAEA,aAA6B;uBArB/B,yBAuBgC,8BAM3B;uBA6BP;;;;0BAlDAo4gB;;;;sBAkDA,mCA3CEE,SAQAC;sBAmCF;;;;;;;;sBuS9SgB,IvSsUhBC;;;;;;;;;;0BAIa,4BAJbA,oBAIuD;;sB1J9YrDntc;sBADAD;sBqvBRN;sBpT6EoB;uBoT7EpB;iCAOez4I;0BAGT,qBloB+FF0ngB,akoB/Fc,iBAHH1ngB;0BAGT,sDAAuD;uBAG3D,mCAAqB,uBAA4C;uBAAjE;iCAMIA;0B;0BhnBLN,SgnBKMA,KhnBLN,2CgnBKMA;0BhnBLN;uCgnBKMA;2BhnBLN;;;;;;;;;;;;;;;oC+C+fQ;sC/C/fR;;;;;;;;;yFgnBKMA,EhnBJgD;iDADtD47I;;;;;;wCAA0D;kEAA1DF;;0CAA0D;;;;;uCAAX;iEAA/CA;;yCAA+C;;;;sCAA/C;;;;qFgnBKM17I;4BhnBLN;4EgnBKMA;4BhnBLN,UAA+Cu6T,cAA/C,MAA0Di6O;;sDAAXv5O;mDAAWw5O;4BAA1D;;qCgnBKMz0iB;;+ChnBLyCu6T;kDAAWi6O;uBgnBDxD;iCAMIx1iB,G,OhnBLNg2iB,mCgnBKMh2iB;uBANJ;iCAMIw0K;0BhnBLgD,GgnBKhDA,gBhnBLgD;0BgnBKtC,2BAAVA;;mCAA0C,2BAA1CA;wCAA0D;uBAN9D;iCAMIwD;;;2BhnBLN7nD,qBgnBKM6nD;kDhnBLN7nD,IgnBKMxsH;uBANJ,uBAmBoB3C,GAAS,OAATA,IAAe;uBAnBnC;iCAqBmBu4B,IAEF,IAAPw7D,KAAO,UAFEx7D,IAEF,UAFEA,GAETw7D,KACU;uBAxBpB,QAmBQqyf,cAEAC;uBArBR;;mD;uBAAA;;;;uBAKE;;sBA2BA;sBrvBpCE3tc;sBADAD;sBseVN;sBrC+EoB;uBqC/Dd;;;;;;;uC1K8O4B8rG;;uB0K9O5B;iCAAQ5nP,G,UAAR4plB,mBAAQ5plB,KACuC;uBAD/C;iCAAK+8K,UAAL16K;0B,kB1K8O4BwlP,c0K9OvB9qE,UAAL16K;;iCAAK26K,QAAL//J;0B;8C1K8O4B6qO,e0K9OvB9qE,SAAL//J,UAC+C;uBAD/C;iCAAKugI,KAALvgI;0B;8C1K8O4B8qO,c0K9OvBvqG,MAALvgI,YAC+C;uBAD/C,gBAmBE5Z,GAAI,aAAJA,gBAAiC;uBAUnC;;;wCA7BQwmlB;uBA6BR;uBAC+C;wC,UAD/CK;uBAC+C;iCAD/C7mlB;0B,kBA7BAglP,kCA6BAhlP;;uC3UoJyEyic;sBsSlH3D;uBqClCd;iCAYQzic,EAAYP,GACL,2BADPO,EAAYP,G/YpCpBkxb,S+YqCgE;uBAbhE;iCAeMryQ,MAAMn5K;0BAIX;;2BADoD,iBAH/Cm5K,MAGwD;2BAA1C;2BAA+C;;8BAAlB,WAAjD;0BAAmE;mDArCnEgnE,cAEAvI,gBAgCY53O,IAKX;;sBtetDDuzI;sBADAD;sB2JRN;sBsS6EoB;uBtS7EpB;iCAMEz4I,G,O4BgMIihH,c/BzKEykZ,cGvBN1lgB;uBANF;iCAMEhB,G,O4BsMIkgH,c/B/KEymZ,cGvBN3mgB;uBANF;iCAQYvC,GAAS,6CAATA,EAAkE;uBAaxC;sBAAJ,iB;sBsSwDd;uBtSxDc;;mCAWhCg7E;4BAAiB;8CAARk/F;uCA1BQ;yDAARpC;oE0iBuIPkxV,Y1iBvIOlxV,YAAO;gDA0BPoC;sDAAO;qCAAhBpB;2CAAqB;mCAArBkE,a,O4B0cI14D,a5BpeJmme,cA0BAlnlB;gD,O4BgdIg/G,a5B1eJmoe,cA0BAnolB;0BAGE,IADEqolB,WACF;mCAEEC,UAAU3yiB,IAAIo/C;4BAC4B,4CADhCp/C,IAAIo/C,MAC2C;0BAH3D,SAKEwzf,WAAW5yiB,IAAIoD;4BAAsB,iBAA1BpD,IAA0B,QAAtBoD,OAAwC;0BALzD,SAOEg8C,KAAMt3F;4BAE4B;qCAF5BA;2D,YAFN8qlB;qCANAF,WAUwD;0BAMlD,IAANhoX,IAAM,OARNtrI;0BAQM,SAEN03b,aAAchvhB,GAAW,kBAAXA,EAAkC;0BAF1C,SAIN44b,WAAU54b,GAA2C,qBAA3CA,GAAmD;0BAJvD,SAMN+qlB,qBAAsBC,OAAe93kB;4BAGrC;;;;;;;mCACa;+DAVb0vN,IAMsBooX;oCAMD,0BANgB93kB;oCAM/B,iCAN+BA;mCAM/B,UADEw6D,GADAD,GAII;gCAdZm1J;6BAmBA,MAXEp9N;6BA3CJ,gCAyCuC0N;6BAWrC,+BAXsB83kB;4BAUxB;mCARIxllB,GAYD;0BApBK,SAwBNyllB,sBAAuBD;4BAIhB;0CAtEPL;6BAsEO,gCA5BP/nX;6BA2BA;;;;;;mCAGU,kCA9BVA,IAwBuBooX;mCAMb;yCAGKE,kBAAT5viB;qDAAS4viB;mCADP,gBAVR7qhB,gBAYuB;;6BAPvB;;6BAYA,MAfuB2qhB;6BAavB,+BAXMv9gB,MAAJC;4BAUJ;sCAVIA,GAAID,GAcA;0BAxCA,SA4CN9U,QAAQjwD;4BAEG;;;wCAAQ,uBAAY;6BAApB;4BAEF;;qD,OMjDXsojB,UN+CIg6B;;;qCAFMtilB,IAK4B;0BAjD9B;kCAlBVsyE;;;kCAEI4vgB;kCAGAC;kCAGAC;kCAEAxzf;kCAQAsrI;kCAEAosT;kCAEAp2F;kCAEAmyJ;kCAgBA1qhB;kCAEA4qhB;kCAoBAtyhB;uBAzE4B;uCAmF1B2H,YAEAsvc,YAEArvc;uBAvF0B;;;;;uCA6F1BC,cAEAqvc,cAEApvc;uBAjG0B;;;;;;uBA0G9B,oCADIC;uBACJ;;iCAyBe1gE;0BAAgB,mBAAP,sBAATA,GA8BjB4rlB;;wDA9BgE;uBAzB9D;iCA2BkBtoe;0BACF,IAAN99G,IAAM,WiB9HZyiL,ajB6Hc3kE;0BAEZ,SADI99G;0BACJ,OADIA,GACW;uBA7BrB,8BAmBa,YAAM;uBAnBnB,uBAkDuBxF,GAAI,SAAJA,GAAI,OAAJA,CAAe;uBAlDtC,SAgDY+rlB,cAEAC;uBAlDZ;;;yBoKFAn+b;yB/HqCApD;yB6HqHAsB;;uBlKxJA,4B;uBAAA;;;;uBAkBE;;sBsSpEc;;;;;;6CrI+Kc04F;;;;uBjK7D5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCyB8UE;sCzB9UF;;;;;;;;;8FASqE;iDATrEtlG;;;;;;;;;;;6CAGI;uEAHJF;;+CAGI;;kEAHJqtc,iBAGIluZ;;;4CAIA;sEAPJn/C;;8CAOI;;mEAPJstc,aAOIluZ;;;2CALA;qEAFJp/C;;6CAEI;;kEAFJotc,MAEI9tZ;;;0CAIA;oEANJt/C;;4CAMI;;iEANJh9B,QAMIk8E;;;yCADA;mEALJl/C;;2CAKI;;gEALJwqa,QAKIpmX;;;wCAJA;kEADJpkD;;0CACI;;+DADJmtc,aACI7oZ;;;uCAGA;iEAJJtkD;;yCAII;;8DiK0XSimG,ajK9Xb7f,SAII5hC;;sCAJJ;;;;;;;;;mCACIwjS;6BADJ,MAEIulH;6BAFJ,MAGIC;6BAHJ,MAIIC;6BAJJ,MAKIC;6BALJ,MAMIC;6BANJ,MAOIC;;;;;;;;;;;;;;;;;+BADAE;+BADAC;+BADAC;+BADAC;+BADAC;+BADA7lH;;;sCACA6lH;sCACAD;sCACAD;sCACAD;sCACAD;sCACAD;4BAPJ;;;;+CACI7lH;;gDACAulH;;iDACAC;;kDACAC;;mDACAC;;oDACAC;uDACAC,wCAEiE;uBATrE;;;;;;;;;;;kCACI7mJ;;mCACAinD;;oCACAugG;;qCACAD;wCACAD,oBACAD,gBACA/+E,kBAEiE;uBATrE;;;;;;;;;;;;;;;;;kCACItoE;kCACAinD;kCACAugG;kCACAD;kCACAD;kCACAD;kCACA/+E,UAEiE;uBATrE,qBAOI1sgB,cAAS;uBAPb,sBAMIA,cAAY;uBANhB,0BAKIA,cAAgB;uBALpB,sBAIIA,cAAY;uBAJhB,uBAGIA,cAAa;uBAHjB,0BAEIA,cAAgB;uBAFpB,qBACIA,cAAS;uBADb;iCAOIA,+CAAS;uBAPb;;2CAOI,QAAS,cAAT8rlB;uBAPJ;iCAMI9rlB,+CAAY;uBANhB;;2CAMI,QAAY,cAAZyrlB;uBANJ;iCAKIzrlB,+CAAgB;uBALpB;;;yCAKI,QAAgB;;;yBAAhB0rlB;;uBALJ;iCAII1rlB,+CAAY;uBAJhB;;2CAII,QAAY,cAAZ2rlB;uBAJJ;iCAGI3rlB,+CAAa;uBAHjB;;;yCAGI,QAAa;;;yBAAb4rlB;;uBAHJ;iCAEI5rlB,+CAAgB;uBAFpB;;;yCAEI,QAAgB;;;yBAAhBqrf;;uBAFJ;iCACIrrf,+CAAS;uBADb;;2CACI,QAAS,cAAT8hd;uBADJ;;;;;;;;;;;;;;oCASqE;uBATrE,4CASqE;uBATrE;;;uBAAyE5nb,GhJ9B/EywJ;uBgJ8BM;uBA8BF;;;;;;;qCA9B2E+hV;+B;uCAAzE49E;;;wCAAyElmJ;;;uEkQUpEl7Q,UlQVoEwjV;;;uBA8B3E;uBAS+C;wC,UAT/C8/E;uBAS+C;iCAT/C7rlB;0BA9BE;8BA8BFA;2BA9BE,GA8BFA;2BA9BE,GA8BFA;2BA9BE,GA8BFA;2BA9BE,GA8BFA;2BA9BE,GA8BFA;2BA9BE,GA8BFA;;;;2BA9BE;;2C2UjLAynlB,mC3UiLA/uhB;;uDhJ9BNuxH,wBgJ8BMtxH;;;;2DiK6D4BwpL,oBjK7D5B0P;;;;uBAuC6C;iC2U3L7Cj3O,U3UkLF5a;0BA9BE;8BA8BFA;2BA9BE,GA8BFA;2BA9BE,GA8BFA;2BA9BE,GA8BFA;2BA9BE,GA8BFA;2BA9BE,GA8BFA;2BA9BE,GA8BFA;;;;2BA9BEknD,M2UjLAwgiB,oCA6BA9skB,U3UoJA89C;iChJ9BNwxH,yB2dtHMtvK,I3UoJAssC;gD2UpJAtsC,I3UoJAgtC;;kDiK6D4Bw6L,sB0KjN5BxnO,I3UoJAjF;kD2UpJAiF,I3UoJAwnC;iD2UpJAxnC,I3UoJA4nC;kD2UpJA5nC,I3UoJAoqC,SAuC6C;;iC2U3L7CpqC;0B3UkLF;;;;2BA7BM4tc,Y2UlLJm/H,oCA6BA/skB;2B3UsJIsxkB,mBhJhCV/ha,wB2dtHMvvK;2B3UuJI,iC2UvJJA;2B3UwJIwxkB;kDiKyDwB/pW,qB0KjN5BznO;2B3UyJI,oC2UzJJA;2B3U0JI,+B2U1JJA;2B3U2JI,6B2U3JJA;0B3U2JI;kCANA4tc;kCACA0jI;kCACAC;kCACAC;kCACAC;kCACAC;kCACAC,YAgCyC;;iCAT/CvrlB;;;;;0BAEI;mC2UpLF8mlB;mD,O/S6hBApme,e8jBrjBAsle;;;;mCxpBupBI9le;mC8DpfRqoe;mCAuCEvolB;uBAS+C;iCAT/ChB;0BA9BE;uCA8BFA;2BA9BE,eA8BFA;2BA9BE,mBA8BFA;2BA9BE,eA8BFA;2BA9BE,gBA8BFA;2BA9BE,mBA8BFA;2BA9BE,YA8BFA;;;;2BAvBM,iBiBzKF2lL,ajByKE4ma;;2BADA;+DACA1uc;2BAFA;+DACAC;2BAFAv/C,iBiK0XSqkJ,mBjK1XTwpW;+DACA1nc;2BAFA;+DACAC;2BAFA7lD,M4B6YJghB,e8jB3jBAmne,c1lB8KIiF;+DACA30b;2BAFA5zJ;uC2UlLJsiP,kC3UkLIuiO;6DACArmR;oCADAC;uBA6BN;uCAAK0pZ;sBsShJW;uBtSgJhB;;;2BA4F+C,yBsBs6BzC9kF;uBtBlgCN;iCA8FoB6lF;0BACtB,GADsBA;4BAQhB;uCARgBA;6BAQL;;iCAAX,sBALG9gF;4BAMH;8BANGA;;uCAMqCvwgB,QAChCyF;gC,IAEJG;gCAEE;kCAAsB;0CALY5F,aAGpC4F;mCAEwB,sBAJpBH,SAEJG;kCAEE,iBANF2vC;kCAMwB,UAFxB3vC;;kCAXV,SAcc;4BAPR;6BAPF4qE;8BAeE;gCACE,KATEj7B,cASiBnzC,GAAM,wBAANA,KAAyB;;2BAE9C;+CAtBJ+ulB;4BAsBI;;+BAtBJA;;iCsChSAz+gB,iBtCgSAy+gB;;4BAIE3ghB;0BAoBJ,qBxCvOE08b,awCmNE18b;0BAoBJ,iDACwD;uBApHtD;iCAsHgB+/b;0BAAsB,6BAAtBA,WAAyD;uBAiBvE,gBMhViB+gF;uBNgVjB;uBAHA,wBU+7BA5lF;uBV/7BA,eAF6CzpgB,GAAK,uBAALA,EAAuB;uBAEpE,sB,OtB5UF24iB;uBsB4UE,sB,kBsGHsBxib;uBtGGtB,sB,OtB5UFwib;uBsB4UE,sB,kBsGHsBxib;uBtGHpB,atBxUJuib;uBsBsUE;;;2CACiD,uBAvCvD4wC,iBAuCuE;;uBADjE;;uBADA,gBUw8BA7/E;uBVz8BJ;;;;0BAxJI2jF;;;;uBAwJJ;iCAoBqB9+E,WACgB,wBADhBA,WACwC;uBArB7D;;;yBAkDSq9E;;uBAlDT;6CA8CQ,sBAAM;uBADV;;;;;;yB4jBhXJ5+D;;;uB5jBgXI;iCAYMxphB;0BAjCV,SACIP,EAAEksa,GAAGh3X,IAAI6qD;4BAAQ,qBAAfmsU,GAAkB,MAAXnsU,MAgCHx/F,IAhCD20C,IAAqD;0BAD9D,SAEI8tZ,UAAUzjc,GAC+B,iCAD/BA,GACgE;0BAYjE,eADDpC,GAAyC,+BAAzCA,MAA4D;0BALnC,qBArEvCmplB;0BAqEuC,sB,0BtBrWnC5wC;0BsBoWK;4B,OKlMC/nb,UrB3DAyjU;0BgBwRsC;;;8BxCzS5C62E;;gCwCuQEjogB;kCALFuslB;kCAKEvslB;;;;;wCACAgjc;wCADAhjc;;oDACAgjc,YAjLIioJ,aACAD;0CACAD;wCACAD;sCACAD;oCACAD;kCACAD;gCpEnLJz5J;0BoE+X0C,qDAA0B;uBAdpE,oC,OAYFs7J,SApKJ/2S;uBAwJM;iCAwBmB/vS;0BAEsB;;2BAAV;2BAAtB;2BAE2B,iBAFpCinlB,OAE4C;0BAAR;mDiKtDpCxtW,YAEAwD,iBjKgDmBj9O,IAIoC;uBA5BvD;iCA6CKgpa;yCAGD39Y;4BACuB,yBAJtB29Y;4BAIsB,uCADvB39Y,OAC4D;0BADnD;;uBAFf;;uBAJA67jB;6CAcI,oCAAW;uBADf;;iCAGOpC;yCACAsC;2CACAC;6CACDzhF;gCAKwB;wCAZ5BuhF;;wCAIKrC;wCAQuB,uBAPvBsC,UAGL3vhB;wC4jB9aJ4sd;;wC5jB6aQze,UASP;mEA5BCshF;;0BAiBmB;;;sBAWpB;sB3JjcG3zc;sBADAD;sB4JNN;sBqS2EoB;uBrS9Dd,sCjJkJNqvC;uBiJlJM;uBAEG;wC,UAFH2ka;uBAEG,mBcsFDlna;uBdtFC,mBcsFDE;uBdtFC,YADIina,gBADPC,gBACEC;uBACC,iBADDnwlB,mBAAwD;uBACvD;;;2BADD6rH;2BcuFAi9D;;;;2BdvFKmna;2BADPC;2BACEC;;2B2BqWFxse;;2Bb9QEwb;2BdvFAkxd;uBACC;;uBAFH;uCACOJ;sBADP;;;yBcwFEnna;;;;yBdvFKmna;yBADPC;yBACEC;;yB2BqWFxse;;yBb9QEwb;;sBuR1BY;uBrS9Dd;;iCAiFan/H;0BAAgB,mBAAP,sBAATA,GA8BjBuwlB;;wDA9BgE;uBAjF5D;iCAmFgBjte;0BACF,IAAN99G,IAAM,WgBtEZyiL,ahBqEc3kE;0BAEZ,SADI99G;0BACJ,OADIA,GACW;uBArFnB,8BA2EW,YAAM;uBA3EjB,uBA0GqBxF,GAAI,SAAJA,GAAI,OAAJA,CAAe;uBA1GpC,SAwGU0wlB,cAEAC;uBA1GV;;;yBmK8GF9ic;yB/HqCApD;yB6HqHAsB;;uBjKxQE,4B;uBAAA;;;;uBA0EA;;sBqSZc;uBrS0DH;;iCAqBD/rJ;0BACE;;;qCAnBd;;gDAA6CjC;yCACzC,IAAIgzlB,WADqChzlB;yCAEtC,mBADCgzlB,WAAJ,sBAiBQ/wlB;2CAfE,IAAJwD,EAAI,gBAeFxD,EAjBJ+wlB;kEAEEvtlB,UAHmCzF;yCAKpC,QAAK,IAc0C;uBAtB3C;iCAwBDiC,GACwB,4BADxBA,GAxBV6wlB,YAyBuD;uBAzB5C;iCA+BEttlB;yCACN4hS;4BAQT,+BATe5hS,EACN4hS,OAQ0B;0BAPjC;;;;gCAEM;sEAnCN0rT,Y/BsDEtze,Q+BvBWh6G;iCAIP;uCADQ0nhB,aAIG;0BALjB;uBAjCW;iCA6CDjrhB;0BAEV;;;8BACG,KAAW,iBAHJA,GA7CV6wlB;2BAYA;;8BAFQjwf;6CAE2D5gG;gCAAnB;;;;uCAAmBA;iCAC3Ds0E,IAD8C9wE,aAAGG;gCAElD,uBAFkDA;mDAEhC,WADjB2wE,KADoD48gB;4CACpD58gB,IADiD3wE,UAAGutlB,MAEiB;;2BAF7E;;;0BAIK,mBALH1tlB;4BAMG,mBANAG;oCAAGutlB;8BuGq1BZ;;;;gCvG70BsB;;wDA8BH;uBAjDJ,OSypCXznF;uBTpmCF;;;;;4BADS0nF;;;;;;4BArBPh/jB;0BAVA2+jB;0BAwBAG;uBAQF,wBAIgBjxlB,GAAW,iBAAXA,EAzDd6wlB,YAyDyE;;;;;;;;;;;uBAczE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2BAYIz2E;2BACAo6D;2BACAwd;2BACAC;2BACArhB;2BACAshB;2BACAC;2BACAC;2BACAC;2BACAC;2BACAC;2BAtBJtzc;;;;;;;;;;;;;oCwB+TE;sCxB/TF;;;;;;;;;8FAwBqE;iDAxBrEE;;;;;;;;;;;;;6CAsBI;uEAtBJF;;+CAsBI;;kEAtBJ8yc,aAsBI3zZ;;;4CAHA;sEAnBJn/C;;8CAmBI;;mEAnBJ4yc,cAmBIxzZ;;;2CALA;qEAdJp/C;;6CAcI;;kEAdJwyc,gBAcIlzZ;;;0CADA;oEAbJt/C;;4CAaI;;iEAbJuyc,MAaIrzZ;;;yCAOA;mEApBJl/C;;2CAoBI;;gEApBJ6yc,UAoBIzuZ;;;wCAHA;kEAjBJpkD;;0CAiBI;;+DAjBJ0yc,sBAiBIpuZ;;;;;;;;;;4CALA;sEAZJtkD;;8CAYI;;mEAZJuzX,MAYI/uU;;;2CASA;qEArBJxkD;;6CAqBI;;kEArBJm9a,eAqBIj5X;;;0CALA;oEAhBJlkD;;4CAgBI;;iEAhBJyyc,SAgBIz0Y;;;yCAEA;mEAlBJh+D;;2CAkBI;;gEAlBJ2yc,YAkBIz0Y;;;wCAHA;kEAfJl+D;;0CAeI;;+DAfJ2qa,UAeIvsW;;kDAfJ;;;;;;;;;;mCAYI+8T;6BAZJ,MAaIo6D;6BAbJ,MAcIwd;6BAdJ,MAeIC;6BAfJ,MAgBIrhB;6BAhBJ,MAiBIshB;6BAjBJ,MAkBIC;6BAlBJ,MAmBIC;6BAnBJ,MAoBIC;6BApBJ,MAqBIC;6BArBJ,MAsBIC;;;;;;;;;;;;;;;;;;;;;;;;;+BADAE;+BADAC;+BADAC;+BADAC;+BADAC;+BADA5hB;+BADA6hB;+BADAC;+BADAte;+BADAl6D;;;sCACAk6D;sCACAse;sCACAD;sCACA7hB;sCACA4hB;sCACAD;sCACAD;sCACAD;sCACAD;sCACAD;4BAtBJ;;;;+CAYIp4E;;gDACAo6D;;iDACAwd;;kDACAC;;mDACArhB;;oDACAshB;;qDACAC;;sDACAC;;uDACAC;;wDACAC;2DACAC,wCAEiE;uBAxBrE,eAsBI3wlB,eAAK;uBAtBT,uBAqBIA,eAAW;uBArBf,kBAoBIA,cAAM;uBApBV,oBAmBIA,cAAU;uBAnBd,kBAkBIA,cAAQ;uBAlBZ,8BAiBIA,cAAkB;uBAjBtB,iBAgBIA,cAAK;uBAhBT,mBAeIA,cAAO;uBAfX,sBAcIA,cAAY;uBAdhB,iBAaIA,cAAQ;uBAbZ,sBAYIA,cAAU;uBAZd;iCAsBIA;;;;;;;;;;;;oCAAK;uBAtBT;;2CAsBI,QAAK,cAALoxlB;uBAtBJ;iCAqBIpxlB;;;;;;;;;;;;wCAAW;uBArBf;;;yCAqBI,QAAW;;;yBAAXqxlB;;uBArBJ;iCAoBIrxlB;;;;;;;;;;;;wCAAM;uBApBV;;2CAoBI,QAAM,cAANsxlB;uBApBJ;iCAmBItxlB;;;;;;;;;;;;wCAAU;uBAnBd;;2CAmBI,QAAU,cAAVuxlB;uBAnBJ;iCAkBIvxlB;;;;;;;;;;;;wCAAQ;uBAlBZ;;2CAkBI,QAAQ,cAARwxlB;uBAlBJ;iCAiBIxxlB;;;;;;;;;;;;wCAAkB;uBAjBtB;;;yCAiBI,QAAkB;;;yBAAlByxlB;;uBAjBJ;iCAgBIzxlB;;;;;;;;;;;;wCAAK;uBAhBT;;2CAgBI,QAAK,cAAL0xlB;uBAhBJ;iCAeI1xlB;;;;;;;;;;;;wCAAO;uBAfX;;2CAeI,QAAO,cAAP2xlB;uBAfJ;iCAcI3xlB;;;;;;;;;;;;wCAAY;uBAdhB;;2CAcI,QAAY,cAAZ4xlB;uBAdJ;iCAaI5xlB;;;;;;;;;;;;wCAAQ;uBAbZ;;2CAaI,QAAQ,cAkBd6xlB;uBA/BE;iCAYI7xlB;;;;;;;;;;;;wCAAU;uBAZd;;2CAYI,QAAU,cAAV8xlB;uBAZJ;;0BAWKtukB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oFACDivkB;qDACAD;mDACAD;iDACAD;+CACAD;6CACAD;2CACAD;yCACAD;uCACAD;qCACAD;mCACAD,QAXE;uBAXN;;;;;;;;;;;;;;;kCAYIjgF;;mCACA+0C;;oCACA+qC;;qCACA58c;;sCACAq4b;;uCACAsV;;wCACA6O;2CACAD,cACA3oC,UACAyR,eACA+2B,kBAEiE;uBAxBrE;;;;;;;;;;;;;;;;;;;;;;;;;kCAYIt/E;kCACA+0C;kCACA+qC;kCACA58c;kCACAq4b;kCACAsV;kCACA6O;kCACAD;kCACA3oC;kCACAyR;kCACA+2B,MAEiE;uBAxBrE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gDAwBqE;uBAxBrE,4CAwBqE;uBAarE,sCA1BK3yS;uBA0BL;uBAC+C;wC,UAD/Ci1S;;uCAAKC;sBqStKS;6BtboFpBhpa,mBgJ4DS8ha;uBCJEoH,WjJxDXlpa,mBiJwDW8zH;uBA0BL;;;uBAkBA;;;;;;;qCA5CKs1S;+B;uCAXLrE;;;wCAWKjxS;;;;;;;;;;;;;;;;uBA4CL;uBAc+C;wC,UAd/Cq1S;uBAc+C;iCAd/CnzlB;0BAvDA;+BAuDAA;2BAvDA,IAuDAA;2BAvDA,GAuDAA;2BAvDA,GAuDAA;2BAvDA,GAuDAA;2BAvDA,GAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;;;2BAvDA;;oEglBzMF8ujB,chlByMEjqa;;;;;oEJlLA+hX,cIkLAj1Q;;;gDjJ7CN1nE,kBiJ6Ca4lV,WAAPn+Q;;oEJlLAk1Q,cIkLAn1Q;;;;;0BhB3LA,GgB2LAD;2BhB3LA;+BgB2LAA;4BhB3LAK,GgB2LAL;4BhB3LA/4B,GgB2LA+4B;4BhB3LA74L,GgB2LA64L;4BhB3LA94L,GgB2LA84L;4BhB3LA;;;;;;;0BgB2LA;;;;;sDjJ7CNvnE,kBgJ4DI8ha,cCfEz6V;uBAqE+C;iChB/OjD12O,IgBiOEkuC;0BAvDA;+BAuDA9oD;2BAvDA,IAuDAA;2BAvDA,GAuDAA;2BAvDA,GAuDAA;2BAvDA,GAuDAA;2BAvDA,GAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;;;2BAvDA,ehB1KF4a,IgBiOEkuC,OAvDAyhE;4CglBzMFwkc,ehmB+BAn0iB,IgB0KEssC;kDhB1KFtsC,IgB0KEgtC;kDhB1KFhtC,IgB0KE+sC;kDhB1KF/sC,IgB0KE8sC;4CJlLAm/c,eZQFjsf,IgB0KE6sC;kCjJ7CNyiI,mBiJ6Ca4lV,ShB1KTl1f,IgB0KE4sC;6CJlLAq/c,eZQFjsf,IgB0KEquC;2BhB1KF;;;;0BAjBE,GgB2LAuoM;2BhB3LA;+BgB2LAA;4BhB3LAK,GgB2LAL;4BhB3LA/4B,GgB2LA+4B;4BhB3LA74L,GgB2LA64L;4BhB3LA94L,GgB2LA84L;4BhB3LA,uBAiBF52O;4BAjBE,uBAiBFA,IAjBEjF;mDAiBFiF,IAjBEwnC;mDAiBFxnC,IAjBE4nC;mDAiBF5nC,IAjBEoqC;4BgB2LAuD,OhB3LA,iBAiBF3tC,IAjBEmqC;;+BgB2LAwD,OhB3LA,mBAiBF3tC;0BgB0KE,6BhB1KFA,IgB0KE2tC;iCjJ7CN2hI,mBgJ4DI8ha,efzLApxkB,IgB0KE0tC,WAqE+C;;iCAD7C1tC;0BApEF,sCAoEEouI;uBAC6C;iChB/OjDpuI;0BgBsLM;;;8ChBtLNA;2BgBuLM,sBglBtNNo0iB,ehmB+BAp0iB;2BgBwLM,gChBxLNA;2BgByLM,2BhBzLNA;2BgB0LM,yBhB1LNA;2BgB2LM,gCJlMFksf,eZOJls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;2BH/wBF,GEDAuqH;2BFCA,GEDAA;;;2BFCA;oDHoOA86d,cF9MAz+E,cKtBAluc;2BEDA;;;;oDFCAj2D,KG4JA45lB,oBH5JA1jiB;2BEDA;;gDLqOA0shB,cF9MAz+E,cOvBA/hX;;;gDLqOAwgc,cF9MAz+E,cOvBAnuS;;;gDLqOA4sX,cF9MAz+E,cOvBA/0Q;8DC6JAwqW,oBD7JAzqW;uBCyxBiD;iCHxxBjDh3O,QG+wBE5a;0BDhxBF;8BCgxBEA;2BDhxBF,GCgxBEA;2BDhxBF,GCgxBEA;2BDhxBF,KCgxBEA;2BDhxBF,KCgxBEA;2BH/wBF,GEDAuqH;2BFCA,GEDAA;2BCgxBE;;2BH/wBFrjE,MHoOAo+hB,eF9MAz+E,eKtBAjsf;2BEDAmqC,MC6JAu3iB,qBH5JA1hlB;2BEDAoqC,MLqOAsgiB,eF9MAz+E,eKtBAjsf,IEDAmqC;iCLqOAugiB,eF9MAz+E,eKtBAjsf,IEDAoqC;iCLqOAsgiB,eF9MAz+E,eKtBAjsf,IEDA4nC;iCC6JA85iB,qBH5JA1hlB,IEDAwnC,SCyxBiD;;iCHxxBjDxnC;0BG+wBE;;;2BH3wBE+6hB,OHgOJ4vC,eF7MEz+E,eKvBFlsf;2BAIyB2nlB,iBGwJzBhG,qBH5JA3hlB;2BEWI4nlB,YFPA7sD,OAAqB4sD;2BEQrBE,OLwNJld,eF7MEz+E,eKvBFlsf;2BEaI8nlB;4BLuNJnd,eF7MEz+E,eKvBFlsf;2BEgBI+nlB,kBLoNJpd,eF7MEz+E,eKvBFlsf;2BEiBIgolB,eC2IJrG,qBH5JA3hlB;;kCEWI4nlB;kCACAC;kCACAC;kCAGAC;kCACAC,eCuwB6C;;iCAT/C5hmB;0BAII;0BDpxBN,SCgxBEA,KDhxBF,2CCgxBEA;0BAII;2BDpxBN,cCgxBEA;2BDhxBF;;;;;;;;;;;;;;;;;;oCqBwgBE;sCrBxgBF;;;;;;;;;yFCgxBEA,ED5vBmE;iDApBrE47I;;;;;;;;;2CAcI;uEAdJw0H;;6CAcI;;uDLuNJo0U,cF7ME9+E,cOVE9qU;;;0CADA;sEAbJw1E;;4CAaI;;sDLwNJo0U,cF7ME9+E,cOXE5lU;;;yCAIA;qEAjBJswE;;2CAiBI;;qDLoNJo0U,cF7ME9+E,cOPE1lU;;;wCALA;oEAZJowE;;0CAYI,IFXJrwJ,KEWI;0CFXJ;+CEWI87B,OFXJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gHAKqE;mEALrED;;;;;;0DAIyB;oFAJzBF;;4DAIyB;;sEGwJzB8/c,oBHxJyB3ga;;;yDAArB;mFAJJn/C;;2DAII;;qEHgOJ8oc,cF7ME9+E,cKnBE5qU;;wDAJJ;;;;;gDEWIj/C;iDFXJ;;;oDEWIA,OFXJ;;;wDAII24Z;kDAJJ,MAIyB2tD;;;;;mDAArB1tD;mDEOA54Z,UFPA44Z,WAAqB2tD;;;;;mDEOrBvmd;oDFXJ;;;;gEAII24Z;mEAAqB2tD;;0CEOrBL;;uCAMA;mEAlBJ1xV;;yCAkBI;;mDC2IJorV,oBD3IIt7Z;;sCAlBJ;;;;uFCgxBElgM;4BDhxBF;8ECgxBEA;4BDhxBF;mCAYI8hmB;6BAZJ,MAaIC;6BAbJ,MAcIC;6BAdJ,MAiBIC;6BAjBJ,MAkBIC;;;;+BADAI;+BAHAC;+BADAC;+BADAC;;;sCACAD;sCACAD;sCAGAD;sCACAD;4BAlBJ;;qCCgxBErimB;;+CDpwBE8hmB;;gDACAC;;iDACAC;;kDAGAC;qDACAC;uBCuwB6C;iCAT/CljmB;0BDhxBF;0CCgxBEA;2BDhxBF,kBCgxBEA;2BDhxBF,mBCgxBEA;2BDhxBF,OCgxBEA;2BDhxBF,SCgxBEA;;2BD9vBEwlD,MC2IJq3iB,2BD3II+F;;2BADA1kgB,MLoNJunf,cF7ME9+E,cOPEg8F;+DACAj+c;2BAJAtmD,MLuNJqnf,cF7ME9+E,cOVE+7F;+DAGA/9c;2BAJApmD,MLwNJknf,cF7ME9+E,cOXE87F;+DACAlrc;2BFbJ,iBEWIirc;2BFXJ,OEWIA;2BFPqB9jgB,MGwJzBm+f,oBHxJyB0F;;2BAArBzjgB,MHgOJ2mf,cF7ME9+E,cKnBEgvC;+DAAqB93Z;2BEOrBl6I,OFPAm6I;2BEOAskD,kCACAD;oCADAC;uBC6wB6C;iCARzCjyE,IADNxsH;;;2BAEM8+P,MN7iBRkjV,qBM4iBQx1d;2BAGFqyI,MAvnBNs6V,+BAqnBQr6V;2BAGFF,MNhjBNojV,qBM+iBMnjV,MAJJ7+P;2B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BArgCA;;;;;;8BoUnqBAs3H;gD,O5UwFA3D,4BQ2kBAzoc;;;iDR3kBAyoc,cEwGOj0E,WMmePhkO;;0DR3kBAi4S,oBQ2kBAz0H;;;iDR3kBAy0H,cEiHOnqB,oBM0dP9oG;;;iDR3kBAizH,cRpFAx+Z,cgB+pBAsrS;;0DR3kBAkzH,oBQ2kBAnzH;;;iDR3kBAmzH,cQ2aEsrB,cAgKFoQ;2BAygBA;;;;;2CAzgBAxsX,QR3kBA8wV,cF1EAl9E,cUqpBAn2C;2BtC9qBF,GsCurCEV;2BtCvrCF;2BsCurCE;0DtCvrCF;2BsCurCE;;;;;;2BAxLA,KAwLAv+N;2BAxLA,KAwLAA;2BAxLA,KAwLAA;2BAxLA;;;;mCFzGSiuX;4B,OAvvBTpjB;0BAsvBE;gCE0GF7gd;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE;oDN9qBF6pc,cF9MAz+E,cQ43BE5pX;;;;yDAtvBFq/c,oBAsvBE5sI;;0DAtvBF4sI,oBAsvBE7sI;;;2BE0GF;;;;8BF1GE;2BA1cF,GEojBAlnI;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,KEojBAA;2BFpjBA;oDA5SA+zQ,6BA4SAxgd;;yDA5SAwgd,0BA4SA1jiB;;;gDNpOA0shB,cF9MAz+E,cQkbAnuS;;yDNpOA4sX,cE5BOx1E,WIgQPh+Q;;;;;;8BsUhcA41V;gD,O5U4NApC,4BMoOAzzV;;;gDNpOAyzV,mCMoOA1zV;+DNpOA0zV,mBMoOA3zV;2BEojBA;;;;oDFpjBAQ,ONpOAmzV,mBMoOA5zV;2BE4uBA;;;;;2CAxLA8+N,QFh2BA8rI,0BEg2BAltI;2BAwLA;;;0BAjqCA,UAiqCA/9N;;;2BAjqCA;iCAiqCAA;;6BAjqCA,mCVGAw1Q,cUHAzpX;0BF+3BE;2BE8xBF+0U;;uEA5fAH;0BpBlrCF,UoB8qDEzC;;;2BpB9qDF,SoB8qDEA;4BpB9qDF;kCoB8qDEA;;8BpB9qDF;;;kCoB8qDEA;mCpB9qDF;uDoB8qDE4C,cAE8D;;iC1ClrDhEt3c,I0CgrDE2uC;;;;2BA5fA,IA4fA66F;2BA5fA,IA4fAA;2BA5fA,IA4fAA;2BA5fA,IA4fAA;2BA5fA,GA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,e1CprCFxpI,I0CgrDE2uC,OA5fA06F;4C0kBrrCF8qa,epnBCAn0iB,I0CorCE6sC;2BAzgBA,KAygBA0oa;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA;;4BoUnqBAu3H;;gC,O5UwFA3D;8BlChGFnpkB;8B0C2qBE4sC;;kCR3kBAu8hB,eEwGOj0E,SpCxMTl1f,I0C2qBEo0C;kCR3kBA+0hB,qBlChGFnpkB,I0C2qBE81C;kCR3kBAqzhB,eEiHOnqB,kBpCjNTh/iB,I0C2qBEk2C;kCR3kBAizhB,eRpFAx+Z,e1BZF3qK,I0C2qBEi2C;kCR3kBAkzhB,qBlChGFnpkB,I0C2qBEs2C;kCR3kBA6yhB,eQ2aEsrB,e1C3gBJz0lB,I0C2qBEs3C;2BAygBAF,ORplCA+xhB,eF1EAl9E,ehCtBFjsf,I0C2qBEq3C;2BtC9qBF,GsCurCE89Z;2BtCvrCF,GsCurCEA;2BtCvrCF,8BJGAn1c,I0CorCEo3C,OtCvrCF0G;2BJGA;4BIHAC;8BJGA;;2B0CorCE,uB1CprCF/9C,I0CorCEwnC;iD1CprCFxnC,I0CorCEutC;iD1CprCFvtC,I0CorCE2tC;kE1CprCF3tC,I0CorCE0tC;2BAxLA,KAwLAkpM;2BAxLA,KAwLAA;2BAxLA,KAwLAA;2BFtPA;;;mCA3CSmuX;4B,OAvvBTrjB;0BAsvBE;gCE0GF9gd;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GEpuF,ON9qBFk4hB,eF9MAz+E,ehCtBFjsf,I0C4/BEkuC,OF1GEk0F;8CxCl5BJpiI,IwCk5BIwyC;8CxCl5BJxyC,IwCk5BImqC;kCAtvBFu3iB,qBxC5JF1hlB,IwCk5BIssC;kCAtvBFo1iB,qBxC5JF1hlB,IwCk5BI+wC;kDxCl5BJ/wC,IwCk5BIyyC;kDxCl5BJzyC,IwCk5BIgtC;2BA1cF,GEojBA8na;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,KEojBAA;2BFpjBA,KEojBAA;2BFpjBAvia,OA5SAmviB,8BxC5JF1hlB,I0C4/BE+sC,MFpjBAk0F;kCA5SAygd,2BxC5JF1hlB,IwCwcEuyC;kCNpOAm4hB,eF9MAz+E,ehCtBFjsf,IwCwcEsyC;kCNpOAo4hB,eE5BOx1E,SpCxMTl1f,IwCwcEqyC;;;4BsUhcAy6hB;;gC,O5U4NApC;8BlCpOF1qkB;8BwCwcE00C;;kCNpOAg2hB,oClCpOF1qkB,IwCwcEy0C;kCNpOAi2hB,oBlCpOF1qkB,IwCwcEw0C;2BEojBAF,ORxxBAo2hB,oBlCpOF1qkB,IwCwcEu0C;2BE4uBAF,OFxhCAqtiB,2BxC5JF1hlB,I0C4/BEs0C;2BAwLA,uB1CprCFt0C,I0CorCEq0C;kD1CprCFr0C,I0CorCEquC;0BA5hCA,OA4hCAooM;8CA5hCA,mB1CxJFz2O,I0CwJEouC;uCA4hCAD,OA5hCA,mB1CxJFnuC,I0CwJEouC;wCA4hCAD,OA5hCA,mB1CxJFnuC,I0CwJEouC;0BArIA,UAiqCAooM;2BAjqCA;4BA6pDA9nM;6BA5fA8nM;+BAjqCA,mB1CnBFx2O,I0CorCEmuC;+BAjqCA,mB1CnBFnuC,I0CorCEmuC;;2BAjqCA;iCAiqCAqoM;4BAjqCA,yB1CnBFx2O,I0CorCEmuC;4BA4fAO,OA7pDA,WVGAu9c,ehCtBFjsf,I0CmBE8sC;0BpBjBF,UoB8qDE0na;2BpB9qDF,0BtBFAx0c,I0CgrDE0uC;;4BpB9qDF,SoB8qDE8la;8BpB9qDF,SoB8qDEA,QpB9qDF,yBtBFAx0c,I0CgrDE0uC;8BpB9qDF,oCtBFA1uC,IsBEA4nC;qCoB8qDE4sa,QpB9qDF,yBtBFAx0c,I0CgrDE0uC;4BpB9qDF,sBtBFA1uC,IsBEAoqC,YoBgrDgE;;iC1ClrDhEpqC;0B0CqrCM;8C1CrrCNA;2B0CsrCM,sB0kBvrCNo0iB,epnBCAp0iB;2B0C2qBE;2BACI4tc;4BoUpqBJm/H;;gC,O5UwFA3D;8BlChGFppkB;;2B0C8qBMilmB,aR9kBJ77B,eEwGO/zE,MpCxMTr1f;2B0C+qBMsxkB,mBR/kBJlI,qBlChGFppkB;2B0CirBMy5kB,cRjlBJrQ,eEiHOnqB,epCjNTj/iB;2B0CkrBM2xkB,YRllBJvI,eRpFAx+Z,c1BZF5qK;2B0CmrBM84kB,eRnlBJ1P,qBlChGFppkB;2B0CqrBMm5kB,SRrlBJ/P,eQ2aEsrB,e1C3gBJ10lB;2B0CsrBMk5kB,aRtlBJ9P,eFzEEl9E,ehCvBJlsf;2B0CurCMwgmB;;6BA3gBA5yJ;6BAEAq3J;6BACA3zB;6BAEAmI;6BACA9H;6BACAmH;6BAEAK;6BACAD;2BtCvrBF,sCJCJl5kB;;;;;;2B0CwrCMugmB,oBtCzrCFzvF,YAAwBD;2BsC2rCtB,kC1C1rCN7wgB;2B0C2rCM,wB1C3rCNA;2B0C4rCM,yB1C5rCNA;2B0C6rCM,4C1C7rCNA;2BwC87BE;;;mCA3CS2qlB;4B,OAvvBThJ;0BAwwBM;2BADA8L;4BN/rBN9iB,eF7MEz+E,ehCvBJlsf;2BwCo6BQ,8BxCp6BRA;2BwCg7BQ,+BxCh7BRA;2BwCi7BQ2nlB,iBArxBNhG,qBxC5JF3hlB;2BwCk7BQstlB;4BAtxBN3L,qBxC5JF3hlB;2BwCm7BQ,mCxCn7BRA;2BwCo7BQ,gCxCp7BRA;2BwCo7BQ;;6BAjBAytlB;6BACAD;6BAYAD;6BACA5F;6BACA2F;6BACAD;6BACAD;2BA3eFrU,UA7SJ4I,8BxC5JF3hlB;2BwC0cMizjB,QA9SJ0uB,2BxC5JF3hlB;2BwC2cMg5kB;4BNvOJrO,eF7MEz+E,ehCvBJlsf;2BwC4cMi5kB,WNxOJtO,eE5BOt1E,MpCxMTr1f;;2BwC6cMkjT;4BsUrcJ6pR;;gC,O5U4NApC;8BlCpOF3qkB;;2BwC8cMwxkB;4BN1OJ7G,oClCp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;;oCACIjsC,cADJ,MAC6BisC;;6DAAzBhsC;iDAAyBytC;0BAD7B;;;;6CACI1tC;gDAAyBisC,sCACiC;;;0BAF9D;0BpB9qDF,UoB+qD+BF;;;2BpB/qD/B,SoB+qD+BA;4BpB9qD7B;gCoB8qD6BA;6BpB9qD7B;6BoB8qD6Bn8mB,mBpB9qD7B4uD;;4BACA;kCoB6qD6ButjB;6BpB7qD7B;6BoB6qD6Bn8mB,mBpB7qD7B85I;0BoB4qDA;2BAC6BK,kCAD7BD;2BACI;+DAAyBC;0BAAzB,iBAC0D;;iCAF9D+pV;;;2BA5fA50L,kBNv8BA49N,eMm8CAhpC;2BArgCAp1L,kB0kB5qBF48Q,e1kBqrCEp8Q;;;2BAzgBAzvC;;8BoUnqBA5d;uCpUqqBMz1H;gC,OR7kBNi0d,qCQ6kBMj0d;8BAFNsiL;;kCR3kBA2xS,eE6IAvzE,eM8bArtQ;kCR3kBA4gV,e2lBnFA+C,enlB8pBA1jV;kCR3kBA2gV,eToRF5nB,eiBuTE94T;kCR3kBA0gV,ekBzEEt+Z,eVopBF69E;kCR3kBAygV,ekBzEEt+Z,eVopBF89E;kCR3kBAwgV,eQ2aEqrB,eAgKF58T;2BAygBAE,ORplCAqxS,qBQ2kBAtxS;;2B1C3qBF3iL,+B0CorCE4iL;;;8B1CprCsC,2BAAxC5iL;8BAAoC,2BAApCA;2B0CorCEuiL;kCAjGE2jU,eAiGF3jU;kCAjGE2jU,eAiGF1jU;2BFrPIJ,wCEqPJK;;;mCFlSEgvU,iBA8CEzxf;4B,OApyBJ2se,4BAoyBI3se;;2BA9CFmzI,ON9qBFqiV,qBM2tBIpzS;2BA7CFvvC;2BAgDEC,OAhDF2+W;2BA+CEx+W,OAryBJ05V,+BAsyBI75V;2BAhDFI,OAtvBFy5V,4BAqyBI15V;2BA/CFF;2BE0GFC,OF1GEwgW;;2BA1cFnhW,MA5SAs6V,+BEg2BA35V;2BFpjBAV,MA5SAq6V,4BA4SAt6V;iCNpOAmjV,qBMoOAljV;iCNpOAkjV,eESA90E,eI2NAnuQ;;;;8BsUhcA9c;uCtUqcYz1H;gC,ONzOZw1d,qCMyOYx1d;8BALZwyI;;iCNpOAgjV,qCMoOA/iV;iCNpOA+iV,6BMoOA9iV;2BEojBAE,ORxxBA4iV,6BMoOA7iV;2BE4uBAkwC,OFxhCA8pT,4BEg2BA/5V;2BAwLAykO;2BA5hCAC,gCA4hCAD;;;wCA3hCE,2BADFC;;iCA4hCAG,OAvhCE,2BALFH;wCA4hCAG,OAlhCE,2BAVFH;;;2BArHE;4BA6oDFO;;+BA7oDE,2BAipCFJ;+BA/pCE,2BA+pCFA;;2BA9pCE;;8DA8pCFA;4BA4fAI,OA1pDE,WmiBiHJw+B,eniBjHIjjQ;oCA0pDF5/P;;2BpB3qDA,kCoB2qDAqke;;;8BpB7qDA,iDoB6qDAA;8BpB7qDA;4BACA;;8DoB4qDAA;4BpB5qDA;uBoB8qD8D;iCAF9Dvqe;0B,IAAA0yH,I6EtgDAlH;;mC1EmJA04f,yBHm3CAxxf,OAE8D;uBAF9D;uCAAK+uf;sB+RzmDS;uB/RymDd;;;;;;;;;;;4B;4BAAA;;;;;;;;;;sCkBzqCE;wClByqCF;;;;;;;;;gGAE8D;mDAF9Dtie;;;;;;0CACI;oEADJF;;4CACI,IA7fJ8zH,OA6fI;4CA7fJ;iDA6fI3zH,OA7fJ;;;;;;;;;;;;;;;;;;;;;kDACIg7X;kDACAo6D;kDACAguC;kDACAC;kDAEA5kD;kDACA6kD;kDACAC;kDACAC;kDACAC;kDACAC;kDACAtG;kDACAuG;kDACAC;kDAdJ/je;;;;oD;oDAAA;;;;;;;;;;8DkB7qBE;gElB6qBF;;;;;;;;;wHAgBqE;2EAhBrEE;;;;;;;;;;;;;;wEAWI;kGAXJF;;0EAWI;;;;;uEARA;iGAHJA;;yEAGI,IA5gBJ8zH,OA4gBI;yEA5gBJ;8EA4gBIr1D,UA5gBJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+IAaqE;kGAbrEv+D;;;;;;;;;;;;+FAOI;2HAPJw0H;;iGAOI;;yGRllBJizU,ckBzEE3+Z,aV2pBEmW;;;8FAIA;0HAXJu1E;;gGAWI;;0GRtlBJizU,oBQslBIvoZ;;;6FAPA;yHAJJs1E;;+FAII;;yGR/kBJizU,c2lBnFA2C,cnlBkqBIhrZ;;;4FAIA;wHARJo1E;;8FAQI;;wGRnlBJizU,cEwBJ6J,cM2jBQtyZ;;;2FAEA;uHAVJw1E;;6FAUI;;uGRrlBJizU,cQ2aEwrB,cA0KE/ua;;;0FAJA;sHANJswE;;4FAMI;;sGRjlBJizU,cToRF1pB,ciB6TM35X;;;yFAHA;qHAHJowE;;2FAGI;;qGR9kBJizU,cJ7CEzzE,cY2nBE1vU;;;wFAFA;oHADJkwE;;0FACI;;;;;8FoU/pBRhrB;8FpUgqBU;iG,8BR7kBNi+V;;8FQ4kBIzjZ;;uFADJ;;;;;+EA4gBIua;gFA5gBJ;;;;gFA4gBIA;iFA5gBJ;;;uFACIupR;iFADJ,MAGIkrH;iFAHJ,MAII3F;iFAJJ,MAMI8F;iFANJ,MAOIzF;iFAPJ,MAQImF;iFARJ,MAUIK;iFAVJ,MAWID;;;;;;;;;;;;;;;;;;;;mFADAM;mFAFAK;mFADAjG;mFADA2F;mFAFAtF;mFADAyF;mFAFAtrH;mFA2gBA5pR;;qFA3gBA4pR;qFAEAsrH;qFACAzF;qFAEAsF;qFACA3F;qFACAiG;qFAEAL;qFACAC;;;;kFAigBAj1Y;mFA5gBJ;;;;+FACIupR;;gGAEAkrH;;iGACA3F;;kGAEA8F;;mGACAzF;;oGACAmF;;qGAEAK;wGACAD;;yEAigBAowB;;sEADA;gGAFJvje;;wEAEI;;8F0kBvrCNuya,c1kBurCM3zW;;;qEADA;+FADJ5+D;;uEACI;;;;;oEASA;8FAVJA;;sEAUI,IAlMJq0H,OAkMI;sEAlMJ;2EAkMIt1D,UAlMJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4IAOqE;+FAPrE7+D;;;;;;;uFAGI;mHAHJm1H;;yFAGI;;mGFn2BJyqV,oBEm2BI5hZ;;;sFAFA;kHADJm3D;;wFACI;;;;;qFACA;iHAFJA;;uFAEI;;;;oFAFJ;;;;;4EAkMIt2D;6EAlMJ;;;;6EAkMIA;8EAlMJ;;;oFACIila;8EADJ,MAEIC;8EAFJ,MAGIC;;;;;+EADAE;+EADAC;+EAiMAtla,aAjMAsla,cACAD,cACAD;;;;;+EA+LApla;gFAlMJ;;;;4FACIila;;6FACAC;gGACAC;;sEA+LAN;;mEAGA;6FAbJ5je;;qEAaI;qEAziCJ;;;;;;;;;;;;;;;+FAyiCIi/D;;;;iFAziCJ+1D;;;;;;;;;;;;;;;;;;;qFAyiCI/1D,UAziCJ;;;;mFAyiCIA,UAziCJ;;8FAyiCIA,UAziCJ;;8EAyiCIA,UAziCJ;;4EAyiCIA,UAziCJ;;0EAyiCIA,UAziCJ;qEAyiCI6ka;;kEAPA;4FANJ9je;;oEAMI;;;;;;;;;;;;;uEAMA;iGAZJA;;yEAYI;;;;;sEALA;gGAPJA;;wEAOI;;;;;qEAEA;+FATJA;;uEASI;;;;;oEALA;8FAJJA;;sEAII;;;wEtC3rCNuuY,uBJGAlS,c0CwrCMjiR;;;mEAUA;6FAdJp6G;;qEAcI;qEA/qCJ;;;;;;;;;;;;;;;+FA+qCIy6G;;yFA/qCJ;;0FA+qCIA;;iFA/qCJoxB;;;;;;;;;;;;;;;;;;;qFA+qCIpxB,UA/qCJ;;;;;;;;kGVIEuvQ,cUJFtmgB;kFA+qCI+2P,aA/qCJ5kM;;;;;kFA+qCI4kM;mFA/qCJ;;8FA+qCIA,UA/qCJ;;8EA+qCIA,UA/qCJ;;4EA+qCIA,UA/qCJ;;0EA+qCIA,UA/qCJ;qEA+qCIspX;;kEANA;4FARJ/je;;oEAQI;;;;4EARJ;;;;+DAgBqE;yDAhBrEjxE;;;kDACIosc;kDACAo6D;kDACAguC;kDACAC;kDAEA5kD;kDACA6kD;kDACAC;kDACAC;kDACAC;kDACAC;kDACAtG;kDACAuG;kDACAC;kDAdJrvW;;;;;;gDA6fIv0H;iDA7fJ;;;;iDA6fIA;kDA7fJ;;;wDACIg7X;kDADJ,MAEIo6D;kDAFJ,MAGIguC;kDAHJ,MAIIC;kDAJJ,MAMI5kD;kDANJ,MAOI6kD;kDAPJ,MAQIC;kDARJ,MASIC;kDATJ,MAUIC;kDAVJ,MAWIC;kDAXJ,MAYItG;kDAZJ,MAaIuG;kDAbJ,MAcIC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDADAQ;oDADAlI;oDADAmI;oDADAC;oDADAC;oDADAC;oDADAC;oDADA3lD;oDAFA4lD;oDADAC;oDADAtvC;oDADAl6D;oDA4fAn7X;;sDA5fAm7X;sDACAk6D;sDACAsvC;sDACAD;sDAEA5lD;sDACA2lD;sDACAD;sDACAD;sDACAD;sDACAD;sDACAnI;sDACAkI;sDACAD;;;;mDA+eAnke;oDA7fJ;;;;gEACIg7X;;iEACAo6D;;kEACAguC;;mEACAC;;oEAEA5kD;;qEACA6kD;;sEACAC;;uEACAC;;wEACAC;;yEACAC;;0EACAtG;;2EACAuG;8EACAC;4CA+eA1sC;;yCAAyB;mEAD7Br3b;;2CAC6B;2CpB/qD/B;;;;;;;;;;;;;;;;uDoB+qD+Bq/C,SpB/qD/B;;;;qDoB+qD+BA,SpB/qD/B;;+DoB+qD+BA;;uDpB/qD/Bg1E;;;;;;;;;;;;;;;;;;;;;;;;0DoB+qD+Bh1E,YpB/qD/BxpI;;;;;;0DoB+qD+BwpI;2DpB/qD/B;;;;;;;;;wDoB+qD+BA,YpB/qD/Bt+C;;;;;wDoB+qD+Bs+C;yDpB/qD/B;;mEoB+qD+BA,SpB/qD/B;;oDoB+qD+BA,SpB/qD/B;;kDoB+qD+BA,SpB/qD/B;2DoB+qD+BA,SpB/qD/B;2CoB+qD+Bikb;wCAD7B;;;uCAE8D;0BAF9D;;;;;;oCACIjsC,cADJ,MAC6BisC;;6DAAzBhsC;iDAAyBytC;0BAD7B;;;;6CACI1tC;gDAAyBisC,sCACiC;uBAF9D;;;;;2BAC6B;;2BA7f7B,qBA6fIpsC;2BA7fJ,gBA6fIA;2BA7fJ,+BA6fIA;2BA7fJ,sBA6fIA;2BA7fJ,gBA6fIA;2BA7fJ,YA6fIA;2BA7fJ,UA6fIA;2BA7fJ,SA6fIA;2BA7fJ,kBA6fIA;2BA7fJ,iBA6fIA;2BA7fJ,SA6fIA;2BA7fJ,WA6fIA;2BA7fJ,aA6fIA;2BA7fJ;0BAjqCA,UA+qCI+mC;2BA/pCF,IA+pCEj8Z;;2BA5qCF;+BA4qCEi8Z;4BA5qCF,gBVCAh0G,cUDAvmgB;4BA4qCEs+M,sBA5qCFnsJ;0BA0pDF,IA9eIksJ,sCAdJF;0BA5hCA,OAyiCIq8Z;;;;0BA+eJ;2BA/eIj8Z,sCACAF;2BAFA;iEACAE;2BAFA;iEACAE;2BApMJ,cAkMIk8Z;2BAlMJ,UAkMIA;2BAlMJ,UAkMIA;2BA/LA78Z,MFn2BJ2+Y,oBEm2BIwe;;2BADA;+DACAp9Z;2BAFA;gEACAE;2BADA;2BAiMAc,sCACAF;2BAFA;iEACAE;2BAFA;iEACAy/C;2BAFA;iEACAE;2BAFA;iEACAE;2BAHAG;4BtC3rCNusR,uBJGAxS,c0CwrCMmiG;iEAEAn8W;2BA/gBJ,aA4gBIo8W;2BA5gBJ,SA4gBIA;2BA5gBJ,eA4gBIA;2BA5gBJ,YA4gBIA;2BA5gBJ,cA4gBIA;2BA5gBJ,mBA4gBIA;2BA5gBJ,WA4gBIA;2BA5gBJ,YA4gBIA;2BAjgBAz3mB,IRtlBJ2glB,oBQslBIwP;;2BADAtuiB,MRrlBJ8+hB,cQ2aEwrB,cA0KE/b;+DACAl2c;2BAHA3/C,MRnlBJomf,ckBzEE3+Z,aV4pBE+ta;+DAEA51c;2BAHA1/C,MRllBJkmf,ckBzEE3+Z,aV2pBE4ma;+DACA7nc;2BAFAnmD,MRjlBJ+lf,cEwGAhoB,iBMyeI+3B;+DACA1vc;2BAHAjmD,MR/kBJ4lf,c2lBnFA2C,cnlBkqBIiF;+DAEA30b;2BAHAz4D,MR9kBJwlf,cEwGA3zE,QMseIkjF;+DACA1xZ;;2BAHAjjG;;8BoU/pBRmnJ;8C,O5UmFIi+V;8BQ4kBI97H;+DAEApmR;2BAygBA4b,SA3gBAD;2BA2gBAqhD,qCACAF;2BAFA,kB0kBvrCNgwT,c1kBurCMyiB;iEACAvyU;2BAFA;iEACAE;2BADA;2BA4fA2xC,sCAAyBF;oCAAzBE,QAC0D;uBAF9D;;8BAQyBy7Q,uBAANnyb;0BACG,0BADHA,MAAMmyb;uBARzB;;8BAiB0BA,uBAApBnyb;yCAAoBmyb;;sDAApBmxD,eAMJ5wD;uBAGFi1D;;;;8BAHEx1D,uBADInyb;yCACJmyb;;sDADIuxD,eACJhxD;;sBAMJ,WGh5CE00D,yBHm3CAE;sB+RzmDc;uB/RyoDhB,kBAKUxE,MAAOr8mB,GAAS,qBAAhBq8mB,MAAOr8mB,KAAkC;uBALnD,oBAUYq8mB,MAAOr8mB,GAAS,mBAAhBq8mB,MAAOr8mB,EAAqC;uBAQtD;;;;;;;;;uCApcOg7mB;0CrBhxCJhxD;;uBqBotDH;uBAI8D;wC,UAJ9Dq3D;uBAI8D;iCAJ9D7/W;;;2BApcEryI,eNjjCF0gZ,eMq/CAruQ;2BApcExqF;;uCqBnuBFlwD,8BrBmuBEkwD;2BAocFuqF,8BApcED;iCrBhxCJipT,eqBotDEhpT;uBAI8D;iCAJ9D9kQ;0B,IAAA0yH,I6ExjDAlH;;mC7EwjDAs5f,sBAI8D;uBAJ9D;uCAAKD;sB+R3pDS;uB/R2pDd;;;;oCAI8D;uBAJ9D,6CAI8D;uBAJ9D,yBAEIjjnB,cAAa;uBAFjB,gBACIA,cAAI;uBADR,eAEIA,sBAAa;uBAFjB;;;yCAEI,QAAa;;;yBAAbujnB;;uBAFJ,eACIvjnB,sBAAI;uBADR;;2CACI,QAAI,cAAJwjnB;uBGpgCQG;+BH4kBVpG,gBAmcIrif,MACR,UADQA,KACJmyb,cACmB;sBAKvB,WAnBE61D;sB+R3pDc;uB/RirDhB;iCAUUp8mB;0BACV;mCACIwkE;4B;;;;8DAlCF+3iB;0BAoCe;sDpB5pDjBx1D;2BoB2pD8B,kBA1c1B2vD;2BAuaG,0BACDkG,OA+BI58mB;2BAhCH;;;yDAED28mB,gBAFC9vE;;;;;;;;;4DAAC;6BAADC;;yDAAL0vE,2BAqC0C;uBAf5C;iCAoBY3hnB,GACd,kBukB5sDA8ljB,UvkB2sDc9ljB,gBACqC;uBArBjD;;8BA2BsB0rjB,uBAANnyb;0BACgC,uBADhCA,SAAMmyb;uBA3BtB,0BAoCgB1rjB,GAA2B,OAA3BA,OAAgD;uBApChE,sBA6CYA,GAAmC,OAAnCA,OAAoD;uBA7ChE,oBA+CUA,GAAsB,OAAtBA,OAAqC;uBA/C/C,2BAsDiBA,GAAgB,OAAhBA,OAAsC;;sBlK3yDrD04I;sBADAD;sByvBVN;sBAwFG;sBzvB7EGC;sBADAD;sBmKVN;sB8R+EoB;;uB9R1EhB;;;;;;;;;;iCAAkB97I;0B,UAAlB4lnB,mBAAkB5lnB,eAGiD;uBAHnE;iCAAM+8K,UAAIgpc;0BAAV;;;mEAAMhpc,UAANhiH;;8DAAUgrjB,cAAV/qjB,IAGmE;uBAHnE;iCAAMgiH,QAAIipc,YAAVhpmB;;;;4CAAM+/J,QAAN//J;4CAAUgpmB,YAAVhpmB,aAGmE;uBAHnE;iCAAMugI,KAAI2nF,SAAVloN;0BAEI;4CAFEugI,KAANvgI;2BAEc,wBAFJkoN,SAAVloN;0BAEc,UAAVkpmB,MAAUC,aACqD;uBAHnE;;;;;;;;;;;;;;;;;;;;;oCiB0gBI;sCjB1gBJ;;;;;;;;;8FAGmE;iDAHnEnne;;;;;;wCAEc;kEAFdF;;0CAEc;;6DAFdomF,SAEcjnC;;;uCAAV;iEAFJn/C;;yCAEI;;8DAFJvB,KAEI2gD;;sCAFJ;;;;;;;;sCAEImob,aAFJ,MAEcC;;4DAAVE;kDAAUD;4BAFd;;;;+CAEIF;kDAAUC,oCACqD;uBAHnE;;;;;2BAEc,eAFdphZ,SAEcihZ;;2BAAV,iBAFJ5oe,KAEI2oe;+DAAUjme;0BAAV,iBAC+D;uBAHnE;;0BAEU,GAFV22B,gBAEU;2CAFV/0B;0BAEU,eAAiB,WAF3B8ke,6BAEUjknB,CAAE;uBAFZ;;0B,IAAA03K;;sBAOmC;sBnKDjCt+B;sBADAD;sBoKVN;sB6R+EoB;uB7R1EhB;;;;;;;;;;0ChBsdK6vb;;uBgBtdL;iCAAQ3rkB,G,UAAR+mnB,mBAAQ/mnB,KAEyC;uBAFjD;;;;;;;;;;;;;;;;;;;;;oCgB0gBI;sChB1gBJ;;;;;;;;;8FAEiD;iDAFjDi/I;;;;;;wCACe;kEADfF;;0CACe;0ChBqdf;;;;;;;;;;;oDgBrdeG,OhBqdf;8DgBrdeA;;sDhBqdf2zH;;;;;;;;;;;;;;;;;;uDA/Ya;;0E,OmCgaXzuJ,anCpeAs/c;0DAmdF9ugB;uDgBrdesqF,UhBqdfz8I;;;;0DgBrdey8I,OhBqdf;;kEgBrdeA,OhBqdf;;mDgBrdeA,OhBqdf;;iDgBrdeA,OhBqdf;0DgBrdeA,OhBqdf;0CgBrdegoe;;uCAAX;iEADJnoe;;yCACI;;8DADJvB,KACI0gD;;sCADJ;;;;;;;;sCACI0/H,cADJ,MACespT;;wDAAX5oT;mDAAW6oT;4BADf;;;;+CACIvpT;kDAAWspT,gCACkC;uBAFjD;;;0BhBsdA,GgBrdeG;2BhBudb;iCgBvdaA;4BhBudb5knB;6BmCqBA4/G;+C,OAAAA,anC1eAshd;+BAqdA/ugB;4BgBvda5uD,mBhBudbvD;;+BgBvdauD;0BADf;2BACem6I,kCADfD;2BACI,iBADJ1C,KACIg7L;+DAAWr4L;0BAAX,iBAC6C;uBAFjD;iCASKr9I;8BAAU0hG,gBAANv/F;0BAA0B,qBAA9BnC,EAAImC,MAAMu/F;sBAMoC;sBpKTjDu3C;sBADAD;sBqKVN;sB4R+EoB;;;;uB5R/EpB;;;6C;;;;;0B1JmKAwvC;4C,OwJ9JsBu6b;;;uBEKd;;;;;;;;;;;0BAAMrE;0BAAiBiG;0BAAwBlpL;;0BAA/C;;;;;;sDAAMijL,uBAANzmjB;;;;;yCAAuB0sjB,8BAAvBzsjB;;4B,OAAAwsjB;qCAAMhG;qCAAiBiG;qCAAwBlpL;;;;mCAA/C7zV;mC1JyJR6gF;;uC,OwJ9JIu6b,oBEKmDvnL;qCAA/CzjO,IAa+C;uBAb/C;;0BAAMinZ;0BAAiB4F;0BAAwBnpL;0BAA/Cvhb;;;;;;;4CAAM8kmB,qBAAN9kmB;4CAAuB0qmB,4BAAvB1qmB;;4B,OAAAyqmB;qCAAM3F;qCAAiB4F;qCAAwBnpL;;;;iC1JyJvDhzQ;;qC,OwJ9JIw6b,qBEKmDxnL;mCAA/Cvhb;;sCAa+C;uBAb/C;;0BAAMglmB;0BAAiB4F;0BAAwBlpL;0BAA/C1hb;;0BAKI;uDALEglmB,kBAANhlmB;2BAMI;uCANmB4qmB,yBAAvB5qmB;;4B,OAAA2qmB;qCAAM3F;qCAAiB4F;qCAAwBlpL;;;;2BAO3CqpL;4B1JkJZv8b;;gC,OwJ9JIy6b,qBEKmDvnL;8BAA/C1hb;;oCAKI6qmB,iBACAC,wBACAC,QAM2C;uBAb/C;;;;;;;;;;;;;;;;;;;;;;;;;;;oCeqgBA;sCfrgBA;;;;;;;;;8FAa+C;iDAb/C/oe;;;;;;;yCAOI;mEAPJF;;2CAOI;;4CACI;;+CARRkpe;;;;4CAOI/oe;6CkB2dN96B;+ClB1dQ;kD;2DFbViigB,oBEKI1nL;;+CAOIzgQ;;;wCADA;kEANJn/C;;0CAMI;;+DANJ8oe,yBAMI1pb;;;uCADA;iEALJp/C;;yCAKI;;8DALJkje,kBAKI5jb;;sCALJ;;;;;;;;;mCAKI6pb;6BALJ,MAMIC;6BANJ,MAOIC;;;;+BADAE;+BADAC;;;sCACAD;sCACAD;4BAPJ;;;;+CAKIH;;gDACAC;mDACAC,gCAM2C;sB4RwDnC;uB5RrEZ;;;;;;;;;4B,OAAAI;;0BAMI;2BACAxinB;4BkBieNq8G;;gC,OpB7eFqkgB,oBEKI/nL;8BAOIqpL;6DAPJ9ne;2BAMI;uCANJ2ne,yBAMIE;+DACA5ne;2BAFA,iBALJ8he,kBAKI6F;+DACA/ge;0BADA,iBAQ2C;uBAb/C;;;;;;;0BAKqB,GALrB8vB,gBAKqB;2CALrB6xc;0BAKqB;4BACO;;yCAN5BC;4BAM4B;8BAKtB,UAXN11jB,SAWM,MAXN4jH;8BAWM;gDAHAe;yCAEA,eADEu1H;6DATRy7U,WASQz7U,YAAO;yCACT;2DAFEv0H;oDAAmD,eAATwC;wEARlDwtc,WAQkDxtc,YAAO;oDAAE,eAAjCqxE;wEAR1Bk8X,0BAQ0Bl8X,YAAsB;oDAAW;sEAAlDzyE;iFART0uc,mBAQS1uc,YAAe;;;6DAAhBpB;mEAAoD;;kDAAtDhB;wDAE2B;;;4BAJL;0BADP,QAAe;uBALpC;;;;;;;;;;;;;;4CAQMplD;qC,OFbVq0f;uDEaYr0f;gD,OARRq2f;;;;yDAQQr2f;;8CARR2sU;8CAQM3sU;;mCARNmyI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCeqgBA;sCfrgBA;;;;;;;;;8FAa+C;iDAb/C1lH;;;;;;;yCAOI;mEAPJF;;2CAOI;;4CACI;;+CARRgqe;;;;4CAOI7pe;6CkB2dN96B;+ClB1dQ,SFbVo5B;kD,gBAAAp6B;;;;;;;;;;;;;;;;;;;;8DiB0gBI;gEjB1gBJ;;;;;;;;;wHAGmE;2EAHnE67B;;;;;;kEAEc;4FAFdF;;oEAEc;;uFEGV4/S,UFHUzgQ;;;iEAAV;2FAFJn/C;;mEAEI;;wFAFJvB,KAEI2gD;;gEAFJ;;;;;;;;gEAEImob,aAFJ,MAEcC;;sFAAVE;4EAAUD;sDAFd;;;;yEAEIF;4EAAUC;iDAFd/oe;+CEYQ0gD;;;wCADA;kEANJn/C;;0CAMI;;+DANJ8oe,yBAMI1pb;;;uCADA;iEALJp/C;;yCAKI;;8DALJkje,kBAKI5jb;;sCALJ;;;;;;;;;mCAKI6pb;6BALJ,MAMIC;6BANJ,MAOIC;;;;+BADAE;+BADAC;;;sCACAD;sCACAD;4BAPJ;;;;+CAKIH;;gDACAC;mDACAC,gCAM2C;sB4RwDnC;uB5RrEZ;iCAmBiBj6f,GAI0CrrH,EAJAoiB;0BAC7D;mCADmBipG;mCAA0CjpG;4CAIGA;qCAH1C,iBAGG+jmB,MAHQnkd,OAGxBokd,eAHwBpkd;qCAIN,eADFmkd,MAAoCnmnB,EAClC,WADkCA,EAAGoiB,KAAvDgkmB,gBAFkB;uBArBzB;iCA8DyBrrnB,EAAEi1E,MAAGhwE;kCAALjF,gBAAEi1E;;;8BAKc;+BADlCq7C;+BAAL9qH;+BACuC,MADvCA;+BAZiB,0BAQWP;+BAPjB,kDAOiBA;+BAPjB;;sCADXomnB,wBACGD;2CAYMnkd,IADTzhK;mCACMT;;uCADDurH;;4BADC,iCAKD;uBAtEP;iCA4GYrrH,EAAEO;0BAAI,IA7BJxF;iCAChB;oCADgBA,EA6BAwF,WA5BqBxF,EA4BWiC,SAAK,kBAAvCgD,EAAkChD,EA3B1B;qCA2B4C;uBA5GhE;;8BA4ME4iO,oBAEAsF;mCAOA+Y,UAASjhP;qEAAyC;mCAAlDktE,OAASltE;qEAAyC;0BAAlD;;2BAAK+1K,eAALxuB;;;;;;;oCAAKwuB,YAALS;;;;;;;;sEAC+C;0BAD/C;wCAAKT;0BAAL,2CAC+C;0BAD/C,qCAC+C;0BAD/C,iCAC+C;0BAD/C;;;;mCA6BAsuE,YAASrkP;qEAAyC;0BA7BlD,SA6BAwmH,SAASxmH;qEAAyC;0BAAlD;;;2BAAKq2K,iBAALspG;;;;;;;sCAAKtpG,cAALmB;;;;;;;;wEAC+C;0BAD/C;0CAAKnB;0BAAL,6CAC+C;0BAD/C,uCAC+C;0BAD/C,mCAC+C;0BAD/C;;;;2BAYU,gCYy9BVkzV;0BZz9BU,SAER93S,KAAKn6H,KAAKkyhB;4BACZ,4CADOlyhB,KAAKkyhB,MAEmD;0BAJrD,SASVC,OAAKnyhB,KAAKkyhB;4BAEV;2EAFKlyhB,KAAKkyhB,MAEM;0BAXN,SAkBVjkY,YAASvlP;qEAAyC;0BAlBxC,SAkBV0mH,SAAS1mH;qEAAyC;0BAAlD;;;2BAAKq3K,iBAAL40W;;;;;;;sCAAK50W,cAALmB;;;;;;;;wEAC+C;0BAD/C;0CAAKnB;0BAAL,6CAC+C;0BAD/C,uCAC+C;0BAD/C,mCAC+C;0BAD/C;;;;mCAYEp/F,OAASmxiB,eACPD;4BACJ;kEAFWC,eACPD,OAGuC;0BAhB3C,SAmBA10d;gCAA8B00d,eAAOS;+BAAPT;6BAGW,MAHXA,SAE5BU,WAC6B32mB;;iCAD7B22mB,WYk7BFtgH;4BZ96BA;;wCANqCqgH,sBAEnCC;0BArBF;;;;qCA3DA5oY;;;;;;qCAAKlrE;qCAALS;;;;;;;;;;;;;;;;;;iEAYEmuc,WAEArkC;mCAvBF19W;mCAEAsF;mCHqgDJw8Y;mCG1+CI1E;;;;qCASA37X;;;;;;qCAAKhuE;qCAALmB;;;;;;;;;;;;;;;;;;+DAYE5mG,MAEA6gJ;mCApDFmR;mCAEAsF;mCYygCAqhS;mCZh9BAkgH;;;;qCASAlkY;;;;;;qCAAKluE;qCAALmB;;;;;;;;;;;;;;;;;;mEAYEvgG;mCAhFF2qJ;mCAEAsF;mCAqFAzzE;uBAnSF;wC;;;;uBAAwDm1d;;uBAAxD;;iCAAwD56b;2B;mCAAxDy4b;;sCAAwD2B;;uBA2T1D;;;;;;;4B1JlKN59b;8C,OwJ9JsBu6b;;uBEgUhB;iCAAwDqD;0B;kCAAxDU;;qCAAwDV,uDAKT;uBAL/C;;;0BACI;;;8BA5TFjB;8BA2TFhG;;;0BACE;;qC,OFjUJoE,oBEgUE1nL;;;;;;4B,OA3TE6pL;qCA2TFvG;iCkB6KA5/f;;qC,OpB7eFqkgB,oBEgUE/nL;;uBAe0B;;sBAO5B;wBAAKsrL;;;2BAAL;6DAAKA;4BAAL;;;;;+CAASC;wC;;;6DAASE;sD;;iEAAbznd,uBAAaynd;;uEALZvpd,uBAKYupd;;kDAATF;;;sB4R5QO,I3G1ER/qd;sBjLsVR;wBiLtVQA;;;2BAAS,SjLsVZmrd,sBiLtVwBxqnB,EAAGgF,KAAMsyF;6BAAQ;iDAAtC+nE;8BAAsC;;iCAAtCA;+CrJqBR5uF,iBqJrBQ4uF;6BAA8C,qBAAzBr/J,EAAGgF,KAAMsyF,KAA4C;2CjLsVlFmzhB;;;oDTzUI5+f,cSyUJ8+f;;;;kDAAkBI;;sCAAME;sCAANC;;+CAHZrkd,oBAGYqkd;;+CAAbV,sBAAmBS,MAANF;;iCAADH;iCAAjBF;;8CAAuD;sB4R5QvC,I5R4QXW;sBAAL;wBAAKA;;;2BAAL,IAAKpnd,oBAAL,UAAKond;2BAAL;;4CAAiBC,O,UAAAA;;;;yC4FKOrzf;;;;mD5FLAszf,eAANC;8DAAMD,O,UAANC,MAAMD;;;;;oD4FKAtzf,kB5FLnBgsC,oBAAmBsnd;;8DAANC,O,UAAAA,MAAMD;;;;2D4FKAtzf,kB5FZlBiyf,sBAOYsB;;2CAADF;;8CAAsC;sB4R5QvC;uB5R4QhB;iCA+B+BtonB,EAC3B0onB,qBAAoCC;0BAExC,GAFwCA;4BAMxB;6BADTvtY,GALiCutY;6BAKtC70mB,EALsC60mB;6BAMxB,iBANZD,qBAKF50mB;;6BAEgB80mB,SAFXxtY;;iCAEWwtY;;;kCACsB,2BARpCF,yBAMIpje;kC8FwlBgB,+B9FvlBNsje;8B8FwlBX;;+B9F9kBA;uDAlBwB5onB,EAC3B0onB,qBAOcE;+BAMA;uDAda5onB,EAC3B0onB,qBAOI13E;8BAIwB,2BAZDhxiB,EAM7B8T;0BADE,QAa2D;uBAjD/D;iCAsD0B9T,EAAGswE;0BAC7B,SAAQw4iB,QAAQxje,MAAOh1E,GAAUp7B;gCAAVklG,QAAUzqF;4BAC/B;iCADqByqF;gCAQjB;iCADCD,KAPgBC;;iCAIO+re;iCAAhBC;iCAIR;;oCARU9ge;oCAIc6ge;uCAIxB,WAToBnmnB,EACVslJ,MAIF8ge,gBAJmBz2jB;iCAAVyqF,KAOhBD;iCAP0BxqF;;8BAG3B,OAH2BA,MAUR;0BAEhB,8BAboB2gB,MAaH;uBAnE1B;;0BA2GS,UAIL,IADFtzE,WACE,OADFA;0BADE,sBAE4B;uBA/GhC;iCAiIyBisnB,oBAAqB34iB;0BACrC,SAALygJ;4B,OADEi4Z,kBAAmBC;0BAChB,GADqC34iB;4BAS9B;6BADX8pE,KARyC9pE;;6BAKlB61iB;6BAAhBC;6BAII,WAJYD;6BAKf,QAFR/re;6BAM2B;;+BATpBgse;+BASoB,WAdP6C,oBAKb7C;+BAIJ8C;6BAQY,qCANZ7oc;6BAOoD,cARpDlmC;4BAQuB;uCAPvBkmC,KAOuB,2BADvB8oc;oCAPAhve;0BANJ,QAeK;uBApJT;;;mCH61COske;uBGzrCH;;;;;;;4C,OA1LsDsI;;;uBA0LtD;iCAAW5knB,M,UAAXinnB,mBAAWjnnB,QAKoC;uBAL/C;;;uBAkDA;;;;;;;;+B,OA5OsD4knB,gBHm3CnDtI;;;uBGvoCH;uBAK+C;wC,UAL/C6K;;uCAAKC;sB4RleO;uB5RkeZ;;uBA2DF;;;;;;;;;uCH8nCK1H;0CvJvkDXr5b,iBuJ++Cak1b;;uBGtiCP;uBAK+C;wC,UAL/CgM;;uCAAKC;sB4R7hBS;uB5R6hBd;uBAiBA;;;;;;;;;uCH6mCK9H;0CvJvkDXr5b,iBuJsgDa81b;;uBG5iCP;uBAK+C;wC,UAL/CuL;;wCAAKC;sB4R9iBS;uB5R8iBd;;iCA6BAxpgB;;;;;;;;;;;4B;4BAAA;;;;;;;;;;sCe3IE;wCf2IF;;;;;;;;;gGAS8D;mDAT9D67B;;;;;;;2CAOI;qEAPJF;;6CAOI;;;;;0CANA;oEADJA;;4CACI,IH+kCJq0H,OG/kCI;4CH+kCJ;iDG/kCIt2D,SH+kCJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kHAI8D;qEAJ9D79D;;;;;;4DACI;wFADJm1H;;8DACI,IArcFvB,OAqcE;8DArcF;mEAqcEzvE,SArcF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oIAOqE;uFAPrEnkD;;;;;;;;gFAGI;4GAHJw0H;;kFAGI;;0FqB/tBN1vJ,4BrB+tBMm6E;;;+EAFA;2GADJu1E;;iFACI;;;;;8EAIA;0GALJA;;gFAKI;;;;;6EAHA;yGAFJA;;+EAEI;;;;4EAFJ;;;;;oEAqcErwE;qEArcF;;;;qEAqcEA;sEArcF;;;4EACI82U;sEADJ,MAEIs2D;sEAFJ,MAGIG;sEAHJ,MAKID;;;;;uEAFAI;uEADAG;uEADA52D;uEAocFj3U;2EApcEi3U,iBACA42D,UACAH,kBAEAC;;;;;uEAgcF3tY;wEArcF;;;;oFACI82U;;qFACAs2D;;sFACAG;yFAEAD;;8DAgcF0F;;2DACA;uFAFJhiU;;6DAEI;;;;0DAFJ;;;;;kDG/kCIt3D;mDH+kCJ;;;;mDG/kCIA;oDH+kCJ;;;0DACIs5X;oDADJ,MAEIisC;;;;;qDADAhsC;qDGhlCAv5X,YHglCAu5X,WACAytC;;;;;qDGjlCAhna;sDH+kCJ;;;;kEACIs5X;qEACAisC;;4CGjlCA2K;;yCACA;mEAFJjue;;2CAEI;;;6CAvVJ+qe;+CHm3CA1H;;;+CG5hCIrla;;wCAFJ;;;uCAS8D;0BAT9D;;;;;;;iCACIiwa;2BADJ,MAEIC;2BAFJ,MAOIr8C;;;;6BALAs8C;6BADAC;sDACAD,sBAKAr8C;0BAPJ;;;;6CACIm8C;;8CACAC;iDAKAr8C,8BAE0D;uBAtC9D;;0BA6BA;;;;2BAOI;;2BALAvwX;4BAvVJ0pa;8BHm3CAhG;;;8BG5hCIsJ;+DAKA5ob;2BHykCJ,gBG/kCI6ob;2BH+kCJ,OG/kCIA;2BHilCA;;2BAtcF,QAqcEr3C;2BArcF,cAqcEA;2BArcF,MAqcEA;2BArcF,aAqcEA;2BAhcE;;2BAFApuhB,MqBztBNs6D,4BrBytBMgud;+DAEAjwb;2BAHA;+DACAC;2BAFA;+DACA4G;2BADA;2BAocFy9C,oCACA5qC;2BGjlCAz4D,SHglCAqjG;2BGhlCA8b,oCACAF;oCADAE,OAQ0D;uBAtC9D;iCA6BAkta;0BACgB,GADhBA,gBACgB;oCADhBC,SACgB,MADhBD;0BHilCW;+BGhlCK7xgB;;4BHglCL;4BApcQ;iCAocRF;;8BApcQ;;gCACP;;iCAC8C;;;;;8CAAtCiygB;kFAAqC;;;kCAAC,cAE5C,2CAF4Cn7iB;;qCAkc/CkpC,IAncCh0D;;mCAmcDg0D,IApcQ94G;4BAocR,IGhlCKg5G,UHglCLF,IACS,+BADTA;mCGhlCKE;4BAKV;mCANN8xgB;6BAMM,MANND;6BAMM;uCADEE;oFAAyB;6BAtV/B;;yCAHAr0U;kCAEA,eADEt3C,2CAAO;kCACT;oDAFEw3C;6CAAmD,eAATM,2CAAO;6CAAE,eAwV/C+zU;mGAxVoC;6CAAW;+DAuV/CE;wDH4hCG,GG5hCHA,gBH4hCG;0EG5hCHA;wDH4hCG;0DAAkC,UG5hCrCC,SH4hCqC,MG5hCrCD;0DvBnpBV;;;6DAGE;;+EADA;;4DAFF;;;gEACa,IAAX96jB;gEAAW,2CAAXA;;;;6DACA;;;+DAAe,IAAfqoH,eAAe,yBAAfA;0DADA;wDoB8qDW,QGn3CS;;;sDAAhBk+H;4DAAmE;;2CAArEF;iDAE2B;;;yCAwVvB39L;qCACK,wBAPX8xgB;qCAMM9xgB;0BALU,UAAoC;uBA9BpD;iCA6BA2+D;;2BArVAsqF,MHq6CAigX,eGhlCAvqc;;;;;;;uCApVE7nD;gC,OFjUJq0f;kDEiUMr0f;2C,OA5TFq2f;oDA2TF7E,qCACIxxf;;yCAAFA;;8BADFmyI;;yDAqVAnyI;uBA7BA;;uBA8CM;;;;;;;;;uCH+jCDmyf;;;;;mC,OGr6CmDkF;4CHm3CnDtI,gBvJrhDXh0b;;;;uB0JwgBY;uBAS+C;wC,UAT/C0gc;uBAS+C;;0BAT/C;;;;2BH+jCN,KG/jCMlwe;2BH+jCN,KG/jCMA;2BH2nBJ,GAocFnxB;2BApcE,GAocFA;2BApcE,GAocFA;2BApcE,GAocFA;2BApcE;;;;;gDvJnoCR0/D,8BuJmoCQwuC;2BAocF;;;;8BApcE;2BG3nBI;;;;8BH+jCN;;4B,OGhuDE0sZ;qCA2TIhG;0BAsWA;;;;;8B1JxgBZj2b;;kC,OwJ9JIu6b;gCEsqBQ53U;;kFAS+C;;iCAT/CjxR;;;;;2BH+jCN,KG/jCM8gI;2BH+jCN,KG/jCMA;2BH2nBJ,GAocFnxB;2BApcE,GAocFA;2BApcE,GAocFA;2BApcE,GAocFA;2BApcE,aG3nBI3vG,UH2nBJ89C;2DG3nBI99C,IH2nBJjF;iCvJnoCRu0K,+B0JwgBYtvK,IH2nBJwnC;2BAocFI,6BG/jCM5nC,IH2nBJssC;2BG3nBIlC,MxBrpBRkmgB,ewBqpBQtwiB,IH+jCN4nC;;4B,OGhuDE6ikB;qCA2TI3F;;;;;;;2BAsWA93jB;4B1JxgBZuhI;;gC,OwJ9JIw6b;;8BEsqBQ/omB;;;uEAS+C;;iCAT/CA;2EAS+C;;iCAT/CA;0BH4nBA;8CG5nBAA;2BH6nBA,gCG7nBAA;2BH8nBAkzjB,cvJtoCZ3jZ,8B0JwgBYvvK;2BHgoBA,+BGhoBAA;2BHgoBA,UAJAu9f,aACAw1D,MACAG,cAEAD;2BAicF,+BGjkCEjzjB;2BHikCF,eADAg5jB,OACAksC;;4B,OGluDFyF;qCA2TI3F;0BA6WI;2BALAoL;4B1J1gBhB5hc;;gC,OwJ9JIy6b;8BEsqBQjpmB;;2BAOI,8BAPJA;0BAOI,UANAqwmB,YACAD,kBAKAj9C,OAE2C;uBAT/C;wCAAK89C;sB4R5lBG;uB5RypBNM;wBAfF;mCAIWC;2CAHEC;8BACT;oCAEOzF,eADIC;8DACJD;;;;qDHq/BjB1E,uBGr/BiBkK;qC3JvkBjB9uc;uC2JokBmB+uc,wDAUH;;wD3JhlBhBrud;;6B2JmlBYgld,+BACJmJ;sB4RzpBM;uB5R8pBV;iCAqBSnrnB;0BACX;;;;4BAAQurnB;4C,oBACJC;0BAgBJ;4BAhBIA;;8BAAc;8BAYE;yCATV3F,iBASU,WAbZ0F,cAME3F;wCASH;0BAfP,IAiBA,MAlBW5lnB,KAoBS,iBAnBZurnB,cADGvrnB;0BAoBS,UApBTA,iBAqBV;uBA1CC;iCAkDiBA;0BApGjB,eAAoCuT;4BACzB,GADyBA;0DAGgB;0BAHpD,OAoGiBvT;0BAtCnB;iCAsCmBA;2BAtCnB,MAsCmBA;2BAnCf;;uCAEgCuT,GACzB,oCADyBA,EACK;0BAHrC,UAmCevT,iBAA4B;uBAlD7C,SA4DVsrnB,QAVgBG;uBAlDN;;yBAlEOZ;yBAALC;;;;uBAkEF,4B;uBAAA;;;;;;;;uBAnFJ;;sB4R3kBc;uB5R2kBd;;uBAS8D;wC,UAT9Da;;;;;;;;uC1JvfN7jc,2B0JufM8jc;;sB4R3kBc;uB5RolBgD;iCAT9D9omB;;;;;oCAS8D;4DAT9D,QAS8D;;iCAT9Di9F;;;;;;;;;;;4B;4BAAA;;;;;;;;;;sCe3IE;wCf2IF;;;;;;;;;gGAS8D;mDAT9D67B;;;;;;;2CAOI;qEAPJF;;6CAOI;;;;;0CANA;oEADJA;;4CACI,IH+kCJq0H,OG/kCI;4CH+kCJ;iDG/kCIt2D,SH+kCJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kHAI8D;qEAJ9D79D;;;;;;4DACI;wFADJm1H;;8DACI,IArcFvB,OAqcE;8DArcF;mEAqcEzvE,SArcF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oIAOqE;uFAPrEnkD;;;;;;;;gFAGI;4GAHJw0H;;kFAGI;;0FqB/tBN1vJ,qBrB+tBMm6E;;;+EAFA;2GADJu1E;;iFACI;;;;;8EAIA;0GALJA;;gFAKI;;;;;6EAHA;yGAFJA;;+EAEI;;;;4EAFJ;;;;;oEAqcErwE;qEArcF;;;;qEAqcEA;sEArcF;;;4EACI82U;sEADJ,MAEIs2D;sEAFJ,MAGIG;sEAHJ,MAKID;;;;;uEAFAI;uEADAG;uEADA52D;uEAocFj3U;2EApcEi3U,iBACA42D,UACAH,kBAEAC;;;;;uEAgcF3tY;wEArcF;;;;oFACI82U;;qFACAs2D;;sFACAG;yFAEAD;;8DAgcF0F;;2DACA;uFAFJhiU;;6DAEI;;;;0DAFJ;;;;;kDG/kCIt3D;mDH+kCJ;;;;mDG/kCIA;oDH+kCJ;;;0DACIs5X;oDADJ,MAEIisC;;;;;qDADAhsC;qDGhlCAv5X,YHglCAu5X,WACAytC;;;;;qDGjlCAhna;sDH+kCJ;;;;kEACIs5X;qEACAisC;;4CGjlCA2K;;yCACA;mEAFJjue;;2CAEI;;;6CAvVJ+qe;+CHm3CA1F,4CG5hCIrna;;wCAFJ;;;uCAS8D;0BAT9D;;;;;;;iCACIiwa;2BADJ,MAEIC;2BAFJ,MAOIr8C;;;;6BALAs8C;6BADAC;sDACAD,sBAKAr8C;0BAPJ;;;;6CACIm8C;;8CACAC;iDAKAr8C,8BAE0D;;;0BAT9D;;;;2BAOI;;2BALAvwX;4BAvVJ0pa;8BHm3CA1F;;;8BG5hCIgJ;+DAKA5ob;2BHykCJ,gBG/kCI6ob;2BH+kCJ,OG/kCIA;2BHilCA;;2BAtcF,QAqcEr3C;2BArcF,cAqcEA;2BArcF,MAqcEA;2BArcF,aAqcEA;2BAhcE;;2BAFApuhB,MqBztBNs6D,qBrBytBMgud;+DAEAjwb;2BAHA;+DACAC;2BAFA;+DACA4G;2BADA;2BAocFy9C,oCACA5qC;2BGjlCAz4D,SHglCAqjG;2BGhlCA8b,oCACAF;oCADAE,OAQ0D;uCAF1D5+M,cAAI;uBAEsD,yBAP1DA,cAAe;uBAO2C,qBAR1DA,cAAS;uBAQiD,eAF1DA,2BAAI;uBAEsD;;2CAF1D,QAAI,cAAJgoiB;uBAE0D,eAP1DhoiB,2BAAe;uBAO2C;;;yCAP1D,QAAe;;;yBAAf+pnB;;uBAO0D,eAR1D/pnB,2BAAS;uBAQiD;;2CAR1D,QAAS,cAATk+kB;uBAQ0D;iCA2NrDv8kB;0B,kBokBrzBb8ljB,UpkBqzBa9ljB,WwP4BT2vjB,exP3BuD;uBA5NO;iCA6P3C3vjB;0BACvB,sBAAgD,IAAMq5kB,iBAAN,OAAMA,OACzC;0BAVC;kDAQSr5kB;2BANQ;0BAE/B,eAAiD20C,IAAIphC;4BAChD,wBADgDA,GAHjD84mB,YAG6C13kB,IACG;;mCADpD;uEAIuB30C,WARnB6hB;yCAUS;uBA/PqD,eAmQvDjlB,EAAGulO,KAAOC,QAAQ,OAAlBxlO,EAAGulO,KAAOC,MAAkC;uBAnQW;;;;uBA2Z9D;;;;;;;;;uCH4qBKk/Y;;;;gCG3uCQwH;kC1J5VnB9/b;oD,O0H5JkBmrX;;;uBgCujCZ;uBAU+C;wC,UAV/Co4E;;wCAAKC;sB4R/+BS;uB5R++Bd;iCAyOiBxsnB,EAAQ2snB,UACvBC;0BAEF;;sCAHyBD,UACvBC,eADe5snB,GAGwB;uBA5OzC,oBA6PUA,GAFmB,eAEnBA,KAC8D;uBA4DtE;;;uBAC+C;wC,UAD/C6snB;;wCAAKC;sB4RzyCO;uB5RozCd;;;uBAE+C;wC,UAF/CE;uBAE+C;iCAF/CjtgB;;;;;;;;;;;;;;;;;;;oCep3BE;sCfo3BF;;;;uCACI;iEADJ27B;;;;0DACIE,WADJn/I;;8CACIm/I,WADJ;yCACI;;sCADJ;;;;;;;;sCACIuxe;4BADJ;kCACIC;8BADJ,UACIA;4BADJ;;;iDACID,sCAC2C;;;0BAF/C;;2BACI;;yCAC2C;;iCAF/Ch+f,S,OAzuBAw7f,eAyuBAx7f;;wCAAK89f;sB4RpzCS;uB5RozCd;iCA8BsB9nnB;0BAC1B,SAAIuonB,4BAphCyCtF;4BAshC3C,SAthCsBD,qBAuhCQ50mB,GAC1B,OAD0BA,OACT;4BAFrB;6BAn7BiCw8D;8BAm7BjC;gCH4REkxiB;gCGjzCF;kD;kCADsBkH;kCAAqBC;4BAqG3C,SAAIM,oBAAqBn1mB;8BACvB,oCADuBA,EACO;4BADhC,yBAAIm1mB,oBAF6B34iB,GAu7BA;0BANnC,SAOI49iB,4BAA6B9yY;4BAE/B;8CAC+C91F,MAAMxxI;;wCHuR1Bm4iB,cGvR0Bn4iB;wCHuRhCgmH,KGvRgChmH;wCH7JhD4imB,mBAobgB58e;wCArbhB68e,cAqbgB78e;wCAtbhB88e,8BAsbgB98e;wCAvbhB+8e,oBAubgB/8e;wCAxbhBg9e,cAwbgBh9e;wCAzbhBk9e,UAybgBl9e;wCA1bhBm9e,QA0bgBn9e;wCA3bhBkud,OA2bgBlud;wCA5bhB67b,gBA4bgB77b;wCA7bhBi+a,eA6bgBj+a;wCA9bhBl+C,OA8bgBk+C;wCA/bhB2rb,SA+bgB3rb;wCAhchB42Y,WAgcgB52Y;;;gDAhchB42Y;gDACA+0C;gDACA7pe;gDACAm8d;gDACA4d;gDACAqyB;gDACAivB;gDACAD;gDGkK0C1xd;gDHjK1Cwxd;gDACAD;gDACAD;gDACAD;gDACAD;+CAobsBzqD,cGtR8B;qCAJ1B7wU,GAI4B;0BAGQ;;2BAAhD,iBAAuC;2BAAK,iBAArD;0BAAqD;;mCAd7D6yY;mCAOAC;mCAOArvc;mCAfsBn5K,IAiBf;uBA/CP;iCAgEM1I;0BAAgD,qCAd1D;mCACIktE;4B;;;;8DA5xBAkijB;0BAgyBI;;2BADW,6BAxBjB4B;2BAuBW,uBHkVTxL;2BGhnCK,+BACDkK,YAyxBEhnnB;2BA1xBD;;;;kDAED+mnB,kBAFCl6E;;;uDAODi6E,OAPCh6E;;;;;;;;;;wEAAC;6BAADE;0BAyyB6B;;;sEAzyBlC25E;mCAyyBMrvnB,EAAiE;;;;;;;;;wCAwhB3E,uBAj0CIgtnB,aAi0CqB;;sBrKh9DrB/we;sBADAD;sB0vBRN;sBzT6EoB;;uByTjEd;;;;;;;;;;iCAAWu5H,M,UAAXk8W,mBAAWl8W,QACqB;uBADhC;;;oCAAiB6zW,kBAAwBD,SACT;uBADhC;;;oCAAiBC,eAAwBD,MACT;uBAYlC;;;wCAbauI;uBAab;uBACyB;wC,UADzBG;;wCAAKC;sBAqDP;;2BrlBktCIroH;wBqlBpxCAkoH;;;;sBAqEsB;sB1vBxEtB11e;sBADAD;sB2vBVN;sB1T+EoB;sB0TjEM;sB3vBHpBC;sBADAD;sB4vBVN;sBAmGI,2BvlBydIywe;sB4R7eY;uB2ToBhB;;0BAuKS;oCAAcuF,OAARhjc,OAA8D;uBAvK7E;;0BAwKU;oCAAwBA,OAAegjc,OAC1B;uBAzKvB;;0BA6JS,IAAeA;0BAAf;4CAEM5I,gBAAkB,OAAlBA,cAAgC,EAFvB4I,OAGT;uBAhKf;iCAiKeA;0BAER;;;uCACU5I,gBAAkB,OAAlBA,cAAgC,EAHlC4I;0BACR,kBADQA,cAIE;uBAVoB;uBAAlC;uBAAL;;sBAcyB;sB5vBjQrB/1e;sBADAD;sBsKVN;sB2R+EoB;;uB3RzEd;;;;;;;;;;iCAAcvqE,K,UAAdwgjB,mBAAcxgjB,WAIiC;uBAJ/C;;;;;;;;;;;;;4BcygBE,cdzgBF;;;;;;;;;;;;;;;;;;;;;;;;;;;;iEAI+C;uBAJ/C;;;4BAEE,gCAFF2gjB,KAEEzvnB;;0BACA,kCAHFiod,KAGE7qU;yDAC6C;uBAJ/C;;;;;;8BAEsB,IAApBg4B,MAFF5kH,SAEsB,kBAFtBo/jB,YAEEx6c;;oCAFFhB;4CAEE;0BACmB,IAAnBgC,MAHF5lH;0BAGqB,kBAHrBq/jB,YAGEz5c,MAC6C;uBAJ/C;;0B,SAAA7yK;4BAEE,OAFFA,OAEE,iCAFFwsH;4BAEE,kBAFFgggB,YAEEn4c;0BACA,SAHFr0K,OAGE,iCAHFwsH;0BAGE,kBAHFiggB,YAGE9tX;;sBAOF;;;;;;;;sB2R+Dc;uB3R/Dd;;mCAiBA+tX,kBAAkB5vnB;4BACpB,cADoBA,WACeQ,GAAK,UAALA,EAAqB,EAAC;mCAIvD+okB;4BAASqU,UAAWz9a,QAAS8ra,MAAO4K,WAAYwG;4BAEhD;;+CAFSO,UAAWz9a,QAAS8ra,QAAO4K,WAAYwG,aAEc;mCAE9DU;4BAAkCH,UAAWv9a,KAAM4ra,MAAO4K,WACzDwG;4BAED;;+CAHkCO,UAAWv9a,KAAM4ra,QAAO4K,WACzDwG,aAGiB;mCAElB7T,iBAAkBrpa,QAAS8ra,MAAOoR;4BAClB;wDADEl9a,QAAS8ra,MAAOoR,aAC8B;mCAEhEW;4BAA2C39a,KAAM4ra,MAAOoR;4BAExD;wDAF2Ch9a,KAAM4ra,MAAOoR,aAEc;mCAEtEz6a,SAAU/nK,OAAQ+ilB,UAAU1glB;4BAC9B,eAEuBsD,GAAK,UAALA,EAAqB;4BAF5C,sB;4BACE,iCAFU3F,OAAQ+ilB,UAAU1glB,SAGgB;;kCAzB5C0ynB;kCAKArmD;kCAIAwU;kCAMAvU;kCAGAwU;kCAIAp7a;uBAvCA;;iCAkDKvC;0BAIiD,kBAJjDA;0BAIiD,wDACpB;uBARpCwvd,mBAIA,qB/C3BA93G;sB+CiCM,kBAVN83G;sB2RgBgB;uB3RNV;;uBAKN;;;;;;;4C,OAxEgBX;;uBAwEhB;uBAE+C;wC,UAF/CY;uBAE+C;iCAF/CvvnB;0B,OAxEE4unB,2BDopBAlF,cC5kBF1pnB;uBAE+C;iCAF/ChB;0B,OAxEE8vnB,2BDopBA/E,cC5kBF/qnB;uBAE+C;iCAF/CmwH;0B,OAxEE+/f,4BDopBAvE,eC5kBFx7f;;wCAAKqggB;sB2RCW;;;;;sB3RsDd;;;;;;;;sB2RtDc;uB3RsDd;;uBAUA;;;;;;;4C,OAzIcb;8BDwjCTnC;;uBC/6BL;uBAI+C;wC,UAJ/CqD;;wCAAKC;sB2RhES;uB3RgEd;;uBAiKA;;;;;;;4C,OA1ScnB;8BD63CT1B;;uBCnlCL;uBAI+C;wC,UAJ/C+C;uBAI+C;iCAJ/ChwnB;0B,OA1SA4unB,6BD63CA1B,cCnlCAltnB;uBAI+C;iCAJ/ChB;0B,OA1SA8vnB,6BD63CAzB,cCnlCArunB;uBAI+C;iCAJ/CmwH;0B,OA1SA+/f;mDD63CA3B,eCnlCAp+f;;wCAAK8ggB;sBAkJ6B;sBtKvblCv3e;sBADAD;sB6vBVN;sBAwGG;sB7vB7FGC;sBADAD;sBuKVN;sB0R+EoB;uB1R/EpB;;mCAkBQilG;;gDAGgB,aAHhBjhP;;0CAEU,0BAFVA;;0CACkB,Wgf+EpBgzgB,ahfhFEhzgB;yDAK+C;mCAL/CktE;4B;8BAAA;;;;;;;;;uCACIiwE,KADJC;uCACIp9I;uCADJgmD,WACkB,WgfiFpBitd,ahfjFMjzgB,GADJ43I;4CACIuF;uCADJr4H;;;qCAGIm6O,KAHJ7hH;qCAGIx8C;qCAHJ76C,qBAGgB,WAAZ66C;qCAHJw8C,KAGI6hH;qCAHJn6O;;;mCAEIk6O,KAFJ5hH;mCAEIr8C;mCAFJj7C,gBAEU,0BAANi7C,KAFJ82C;wCAEImnH;mCAFJl6O;;;;;;;;;gHAK+C;4BAL/C,YAK+C;0BAL/C;;;;;;;;;;2CXyMGu7R;;;2BWzMEtqI,eAALxuB;;;;;;;;;;kEqkBXJ8pa,crkBWIr2V,IAK+C;mCAL/CzkD;;;;;;;8CqkBXJ+6Y,erkBWIn0iB,aAK+C;8BAL/Cq5J;;6EAK+C;mCAL/CG;4BACI;iDADJx5J;6BAEI,gCAFJA;6BAGI,uBqkBdRo0iB,erkBWIp0iB;4BAGI,UAFA41jB,cACA7C,MACA0B,YAE2C;;2BAL/Ch7Z;oCAAKb,YAALS;;;;;;;;;;;;;;;;;;;;;;;sCa6fA;wCb7fA;;;;;;;;;gGAK+C;mDAL/Cr3B;;;;;;;2CACI;qEADJF;;6CACI;;;;;0CAEA;oEAHJA;;4CAGI;;iEqkBdRuya,crkBcQnzX;;;yCADA;mEAFJp/C;;2CAEI;;;;wCAFJ;;;;;;;;;qCACIo0b;+BADJ,MAEI3C;+BAFJ,MAGIoB;;;;iCADAX;iCADAqC;4DACArC,UACAY;8BAHJ;;;;iDACIsB;;kDACA3C;qDACAoB,oCAE2C;mCAL/Czgd;;;;;6BAGI,eqkBdRogc,crkBcQmgB;;6BADA;iEACAxxb;6BAFA;iEACAC;4BADA,iBAI2C;mCAL/CrlE;4BACkB,GADlB+7F,gBACkB;gDADlBA;4BACkB;8BACR,mCAFVA;8BAEU;uCACM,WqkBdpB46Y,YrkBWI56Y;uCAEUpvH;4BADQ,QAAiC;mCADnDyqB;4BACkB,GADlB0lG,gBACkB;gDADlBA;4BACkB;8BACR,qCAFVA;8BAEU,2BqkBbd45Y,SrkBWI55Y;8BAEU;;;wCADyC;mCADnDlsD;;8CXmOFwnZ,eWnOE1gZ;;8CqkBXJk/b,erkBWI/sT;;4B,IAAAnyI,IwEgKFlH;oExEhKEI,mBAK+C;0BAL/C;wCAAKmqD;0BAAL;;gDAGgB,aAHhB/1K;kDAEU,qBAFVA;kDACkB,iBADlBA;yDAK+C;0BAL/C;4B;8BAAA;;;;;;;;;uCACIm9I,KADJC;uCACIp9I;uCADJgmD,WACkB,iBAAdhmD,GADJ43I;4CACIuF;uCADJr4H;;;qCAGIm6O,KAHJ7hH;qCAGIx8C;qCAHJ76C,qBAGgB,WAAZ66C;qCAHJw8C,KAGI6hH;qCAHJn6O;;;mCAEIk6O,KAFJ5hH;mCAEIr8C;mCAFJj7C,gBAEU,qBAANi7C,KAFJ82C;wCAEImnH;mCAFJl6O;;;;;;;;;gHAK+C;4BAL/C,YAK+C;0BAL/C;;;;;;;;;;;;;;;;;;;;;sCa6fA;wCb7fA;;;;;;;;;gGAK+C;mDAL/Cq6H;;;;;;;2CACI;qEADJF;;6CACI;;;;;0CAEA;oEAHJA;;4CAGI;;iEqkBdRuya,crkBcQnzX;;;yCADA;mEAFJp/C;;2CAEI;;;;wCAFJ;;;;;;;;;qCACIo0b;+BADJ,MAEI3C;+BAFJ,MAGIoB;;;;iCADAX;iCADAqC;4DACArC,UACAY;8BAHJ;;;;iDACIsB;;kDACA3C;qDACAoB,oCAE2C;0BAL/C;;;;;6BAGI,eqkBdRrgB,crkBcQmgB;;6BADA;iEACAxxb;6BAFA;iEACAC;4BADA,iBAI2C;0BAL/C;;;;;;4B,IAAA3tB,IwEgKFlH;;qCxEhKEo8D,qBAK+C;0BAL/C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAK7R;+BAALS;;;+BASI3yG;+BCHF+tY;2BDNF;;;mCAqBA35X,OAAQ6hgB,YAAanlD,IAAK0lD;4BAAY,UAA9BP,YAAanlD,IAAK0lD,UAA2C;0BArBrE,SAuBAP;4B,IAAcA;0BAvBd,SAyBAJ;gCAAwBW,mBAAbP;8CkkB8BjBzwB,UlkB9BiBywB,YAAaO;0BAzBxB,SA4BA1lD,W,IAAMA;0BA5BN,SAgHF0lD;4B,IAlFcA;0BA9BZ,SAiCEw5C,sBAAwBh4kB,IAAc2kiB,QAASznjB,MAAMsqI;4BAEvD,GAF0BxnH,IAAU,QAAVA,eAAU27B,aAAV+ogB;4BAE1B,eAIU/+H,SAAW,kBAAXA,WAAyD;4BADjE;8CALqDn+S;6BAKrD;;6BAGA,+BARwBk9a,QAAcC;6BAQtC;;;;+BACEnG;+BAFA1lD;+BAJImlD;oDAIJnlD,IAEA0lD;;iEAFA53a,eAP6C1pI;iEAGzCmuM;6EAOuB;0BA3C/B,WAiCE2sZ;0BAjCF,SAkDFxvY,YAASrxK;qC7B9DXkuK,O6B8DWlhP,sBAAkB;4B7B9D7B,c6B8DWgzE;8B7B9DX;qC6B8DWA;+B7B9DX4kE;;;;4BAAY,M6B8DD5kE;4B7B9DC,8C6B8DwC;0BAlDhD,SAkDFm0C,S7B9DUqgL;4B6B8DD,S7B9DXtmD,O6B8DWlhP,mBAAkB;sC7B9DjBwnS;;;;;;;;;;;;;2CAAZ5vJ;;;;8CAAY,eAAZizG,MAAY,wBAAZA,YAA4C;8CAA5C,wCAA4C;0CAA5C;;;;sCAAY,yDAAgC;sCAAhC;wC6B8DwC;0BAAlD;;;;+C7B9DFu7T,mB6BYSrwY;2BAkDFM,iBAALspG;;4B7B9DF,c6B8DEp9Q;;+B7B9DUwR,K6B8DVxR;+B7B9DiC24D,GAAvBnnD;+BAAuBknD,GAAvBlnD;+BAAuB/O,6B6BY/BsxK,W7BZ+Br7G;+BAAvBw+G,gCAAuBz0K,K6BY/BsxK,W7BZ+Bp7G;2DAAvBu+G;uC6B8DVl3K,K7B9DUuxnB,Y6BYRx9c,W7BZQl/D;;mC6B8DVmgE;4B7B9DF,c6B8DEh1K;;+B7B9DUwR,K6B8DVxR;+B7B9DU2V,IsDyXZkzI,sBzB3TEjuI;+B7B9DiC+9C,GAAvBnnD;+BAAuBknD,GAAvBlnD;+BAAuB4wC,M6BY/B4xH,YAkDFp5J,I7B9DUjF,IAAuB+iD;qC6BY/Bs7G,YAkDFp5J,I7B9DiCwnC;;6BAAvByyD,O6B8DV70G;6B7B9DUwiD,MsDyXZqmG,sBzB3TEjuI;mCAlDEo5J,YAkDFp5J,I7B9DU4nC,a6B+DqC;8BAD/CyyH;gDAA4Br6J;4B,O7B9D9BkpiB,e6BYI1vY,aAkD0Bx5J;mCAA5Bu6J;4B,O7B9DF4uY,e6BYI3vY,aAkDFx5J,YAC+C;;2BAD/Cw6J;sCAAKtB,cAALmB;;;4B,gB7B9DFl0D;;gE6BYI05D,U7BZJ15D;;;;;oDAC+C;qC6B6D7C//G;;4B7B9DF,c6B8DEhB;;+B7B9DUI,G6B8DVJ;+B7B9DiC04D,GAAvBt4D;+BAAuBmyD,KAAvBnyD;+BAAuBo9I,K6BY/B1uB,U7BZ+Bv8D;oC6BY/Bu8D,U7BZ+Bp2D;;gCAAvB+kF,K6B8DVz9I;kDAlDE8uH,U7BZQ2uB;mC6B8DVtoC;4BAA4B,S7B9D9BsqC,M6B8DWK,wCAAkB;4B7B9D7B,G6B8DE0xe,gB7B9DF;0C6B8DEA;;gC7B9DiC;iCAAnCv4c,U6B8DEp5B;iC7B9DFq5B,S6B8DEs4c;iC7B9DiC5oI,MAAnC1vU;iCAAmC2vU,MAAnC3vU;iCAAmC4vU,MAAnC7vU;iCAAmC8vU,MAAnC9vU;iCAAmC;+CAAK,MAAL2vU;;uC6B8DjC/oW;mC7B9DF6oW,U6B8DE7oW,S7B9DF8oW,S6B8DE6oI;sC7B9D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+BADzBxpB;yDiDkgBiD;0BAJ/C;;;;;;;;gCjD9f2B68S;;;;;2BiD8ftB0hH,kBAALD;;4BjD9fF;gCiD8fEp9nB;6BjD9fF,GiD8fEA;6BjD9fF,GiD8fEA;;;;6BjD9fF;;;;;gC9G8HNkpL;;;qC8G7HqBvwH;;;;wEiDmEb4tH,cjDnEa5tH;kCADfD;;sEiDoEE6tH,cjDpEF5tH;;uDA7BAkhd,0BA6BAphT;mCiD8fEt9C;4BjD9fF;gCiD8fEn7K;6BjD9fF,GiD8fEA;6BjD9fF,GiD8fEA;;;;6BjD9fFwiD;8B9G8HN2mI;yC8G7HoBvuK;;mCAAC+9C;;0DAAD/9C,QAAC89C;oDiDmEb8tH,ejDnEY5rK,IAACwnC;gCiD6fbxnC;;gCjD9fF89C;4CiDoEE8tH,eA0bA5rK,IjD9fF4nC;mCA7BAw3d,2BiD2hBEp/f,IjD9fFjF,OiDmgB8B;8BAL5B2nnB;iDAIE1inB;4BjDlgBJ,sCiDkgBIouI;mCAJFu0e;;;;;6BjD7fEnhH;8B9G6HVhzV;yC8G7HUxuK;;mCAAW89C,oBAAX99C;mCAAW+9C,ciDmEb8tH,cjDnEE7rK;4CAAW89C;gCiD6fb99C;;6BjD5fE,mBiDkEF6rK,cA0bA7rK;6BjD3fEshgB,OAhCJ/B,2BiD2hBEv/f;sCjD7fEwhgB,UACAD,QACAD,OiDggB0B;;2BAL5BshH;uCAAKH,eAALC;;;;;;;;4BjD9fF,SiD8fEt8nB,KjD9fF,2CiD8fEA;4BjD9fF;yCiD8fEA;6BjD9fF;;;;;;;;;;;;;;;;sC2D0eE;wC3D1eF;;;;;;;;;2FiD8fEA,EjDzfuB;mDALzB47I;;;;;;;2CAGI;qEAHJF;;6CAGI;;gEAhCJ89X,0BAgCI3+U;;;0CAFA;oEADJn/C;;4CACI;;;8C8DscJ36B;yD9DtcehB;kDAAD,SAACA;;;;;;;;;;;kFADf/qD,aACe+qD,KAAgB;gDAA3B+6E;;;yCACA;mEAFJp/C;;2CAEI;;;;wCAFJ;;;;uFiD8fE17I;8BjD9fF;8EiD8fEA;8BjD9fF;qCACI46gB;+BADJ,MAEIC;+BAFJ,MAGIC;;;;iCADAE;iCADAC;wDACAD,YACAD;8BAHJ;;uCiD8fE/6gB;;iDj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","sourcesContent":[null,"//\n// strftime\n// github.com/samsonjs/strftime\n// @_sjs\n//\n// Copyright 2010 - 2015 Sami Samhuri \n//\n// MIT License\n// http://sjs.mit-license.org\n//\n\n;(function() {\n\n var DefaultLocale = {\n days: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n shortDays: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n months: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],\n shortMonths: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n AM: 'AM',\n PM: 'PM',\n am: 'am',\n pm: 'pm',\n formats: {\n D: '%m/%d/%y',\n F: '%Y-%m-%d',\n R: '%H:%M',\n T: '%H:%M:%S',\n X: '%T',\n c: '%a %b %d %X %Y',\n r: '%I:%M:%S %p',\n v: '%e-%b-%Y',\n x: '%D'\n }\n },\n defaultStrftime = new Strftime(DefaultLocale, 0, false),\n isCommonJS = typeof module !== 'undefined',\n namespace;\n\n // CommonJS / Node module\n if (isCommonJS) {\n namespace = module.exports = adaptedStrftime;\n namespace.strftime = deprecatedStrftime;\n if(joo_global_object) joo_global_object.strftime = adaptedStrftime;\n }\n // Browsers and other environments\n else {\n // Get the global object. Works in ES3, ES5, and ES5 strict mode.\n namespace = joo_global_object || (function() { return this || (1,eval)('this'); }());\n namespace.strftime = adaptedStrftime;\n }\n\n // Deprecated API, to be removed in v1.0\n var _require = isCommonJS ? \"require('strftime')\" : \"strftime\";\n var _deprecationWarnings = {};\n function deprecationWarning(name, instead) {\n if (!_deprecationWarnings[name]) {\n if (typeof console !== 'undefined' && typeof console.warn == 'function') {\n console.warn(\"[WARNING] \" + name + \" is deprecated and will be removed in version 1.0. Instead, use `\" + instead + \"`.\");\n }\n _deprecationWarnings[name] = true;\n }\n }\n\n namespace.strftimeTZ = deprecatedStrftimeTZ;\n namespace.strftimeUTC = deprecatedStrftimeUTC;\n namespace.localizedStrftime = deprecatedStrftimeLocalized;\n\n // Adapt the old API while preserving the new API.\n function adaptForwards(fn) {\n fn.localize = defaultStrftime.localize.bind(defaultStrftime);\n fn.timezone = defaultStrftime.timezone.bind(defaultStrftime);\n fn.utc = defaultStrftime.utc.bind(defaultStrftime);\n }\n\n adaptForwards(adaptedStrftime);\n function adaptedStrftime(fmt, d, locale) {\n // d and locale are optional, check if this is (format, locale)\n if (d && d.days) {\n locale = d;\n d = undefined;\n }\n if (locale) {\n deprecationWarning(\"`\" + _require + \"(format, [date], [locale])`\", \"var s = \" + _require + \".localize(locale); s(format, [date])\");\n }\n var strftime = locale ? defaultStrftime.localize(locale) : defaultStrftime;\n return strftime(fmt, d);\n }\n\n adaptForwards(deprecatedStrftime);\n function deprecatedStrftime(fmt, d, locale) {\n if (locale) {\n deprecationWarning(\"`\" + _require + \".strftime(format, [date], [locale])`\", \"var s = \" + _require + \".localize(locale); s(format, [date])\");\n }\n else {\n deprecationWarning(\"`\" + _require + \".strftime(format, [date])`\", _require + \"(format, [date])\");\n }\n var strftime = locale ? defaultStrftime.localize(locale) : defaultStrftime;\n return strftime(fmt, d);\n }\n\n function deprecatedStrftimeTZ(fmt, d, locale, timezone) {\n // locale is optional, check if this is (format, date, timezone)\n if ((typeof locale == 'number' || typeof locale == 'string') && timezone == null) {\n timezone = locale;\n locale = undefined;\n }\n\n if (locale) {\n deprecationWarning(\"`\" + _require + \".strftimeTZ(format, date, locale, tz)`\", \"var s = \" + _require + \".localize(locale).timezone(tz); s(format, [date])` or `var s = \" + _require + \".localize(locale); s.timezone(tz)(format, [date])\");\n }\n else {\n deprecationWarning(\"`\" + _require + \".strftimeTZ(format, date, tz)`\", \"var s = \" + _require + \".timezone(tz); s(format, [date])` or `\" + _require + \".timezone(tz)(format, [date])\");\n }\n\n var strftime = (locale ? defaultStrftime.localize(locale) : defaultStrftime).timezone(timezone);\n return strftime(fmt, d);\n }\n\n var utcStrftime = defaultStrftime.utc();\n function deprecatedStrftimeUTC(fmt, d, locale) {\n if (locale) {\n deprecationWarning(\"`\" + _require + \".strftimeUTC(format, date, locale)`\", \"var s = \" + _require + \".localize(locale).utc(); s(format, [date])\");\n }\n else {\n deprecationWarning(\"`\" + _require + \".strftimeUTC(format, [date])`\", \"var s = \" + _require + \".utc(); s(format, [date])\");\n }\n var strftime = locale ? utcStrftime.localize(locale) : utcStrftime;\n return strftime(fmt, d);\n }\n\n function deprecatedStrftimeLocalized(locale) {\n deprecationWarning(\"`\" + _require + \".localizedStrftime(locale)`\", _require + \".localize(locale)\");\n return defaultStrftime.localize(locale);\n }\n // End of deprecated API\n\n // Polyfill Date.now for old browsers.\n if (typeof Date.now !== 'function') {\n Date.now = function() {\n return +new Date();\n };\n }\n\n function Strftime(locale, customTimezoneOffset, useUtcTimezone) {\n var _locale = locale || DefaultLocale,\n _customTimezoneOffset = customTimezoneOffset || 0,\n _useUtcBasedDate = useUtcTimezone || false,\n\n // we store unix timestamp value here to not create new Date() each iteration (each millisecond)\n // Date.now() is 2 times faster than new Date()\n // while millisecond precise is enough here\n // this could be very helpful when strftime triggered a lot of times one by one\n _cachedDateTimestamp = 0,\n _cachedDate;\n\n function _strftime(format, date) {\n var timestamp;\n\n if (!date) {\n var currentTimestamp = Date.now();\n if (currentTimestamp > _cachedDateTimestamp) {\n _cachedDateTimestamp = currentTimestamp;\n _cachedDate = new Date(_cachedDateTimestamp);\n\n timestamp = _cachedDateTimestamp;\n\n if (_useUtcBasedDate) {\n // how to avoid duplication of date instantiation for utc here?\n // we tied to getTimezoneOffset of the current date\n _cachedDate = new Date(_cachedDateTimestamp + getTimestampToUtcOffsetFor(_cachedDate) + _customTimezoneOffset);\n }\n }\n date = _cachedDate;\n }\n else {\n timestamp = date.getTime();\n\n if (_useUtcBasedDate) {\n date = new Date(date.getTime() + getTimestampToUtcOffsetFor(date) + _customTimezoneOffset);\n }\n }\n\n return _processFormat(format, date, _locale, timestamp);\n }\n\n function _processFormat(format, date, locale, timestamp) {\n var resultString = '',\n padding = null,\n isInScope = false,\n length = format.length,\n extendedTZ = false;\n\n for (var i = 0; i < length; i++) {\n\n var currentCharCode = format.charCodeAt(i);\n\n if (isInScope === true) {\n // '-'\n if (currentCharCode === 45) {\n padding = '';\n continue;\n }\n // '_'\n else if (currentCharCode === 95) {\n padding = ' ';\n continue;\n }\n // '0'\n else if (currentCharCode === 48) {\n padding = '0';\n continue;\n }\n // ':'\n else if (currentCharCode === 58) {\n if (extendedTZ) {\n if (typeof console !== 'undefined' && typeof console.warn == 'function') {\n console.warn(\"[WARNING] detected use of unsupported %:: or %::: modifiers to strftime\");\n }\n }\n extendedTZ = true;\n continue;\n }\n\n switch (currentCharCode) {\n\n // Examples for new Date(0) in GMT\n\n // 'Thursday'\n // case 'A':\n case 65:\n resultString += locale.days[date.getDay()];\n break;\n\n // 'January'\n // case 'B':\n case 66:\n resultString += locale.months[date.getMonth()];\n break;\n\n // '19'\n // case 'C':\n case 67:\n resultString += padTill2(Math.floor(date.getFullYear() / 100), padding);\n break;\n\n // '01/01/70'\n // case 'D':\n case 68:\n resultString += _processFormat(locale.formats.D, date, locale, timestamp);\n break;\n\n // '1970-01-01'\n // case 'F':\n case 70:\n resultString += _processFormat(locale.formats.F, date, locale, timestamp);\n break;\n\n // '00'\n // case 'H':\n case 72:\n resultString += padTill2(date.getHours(), padding);\n break;\n\n // '12'\n // case 'I':\n case 73:\n resultString += padTill2(hours12(date.getHours()), padding);\n break;\n\n // '000'\n // case 'L':\n case 76:\n resultString += padTill3(Math.floor(timestamp % 1000));\n break;\n\n // '00'\n // case 'M':\n case 77:\n resultString += padTill2(date.getMinutes(), padding);\n break;\n\n // 'am'\n // case 'P':\n case 80:\n resultString += date.getHours() < 12 ? locale.am : locale.pm;\n break;\n\n // '00:00'\n // case 'R':\n case 82:\n resultString += _processFormat(locale.formats.R, date, locale, timestamp);\n break;\n\n // '00'\n // case 'S':\n case 83:\n resultString += padTill2(date.getSeconds(), padding);\n break;\n\n // '00:00:00'\n // case 'T':\n case 84:\n resultString += _processFormat(locale.formats.T, date, locale, timestamp);\n break;\n\n // '00'\n // case 'U':\n case 85:\n resultString += padTill2(weekNumber(date, 'sunday'), padding);\n break;\n\n // '00'\n // case 'W':\n case 87:\n resultString += padTill2(weekNumber(date, 'monday'), padding);\n break;\n\n // '16:00:00'\n // case 'X':\n case 88:\n resultString += _processFormat(locale.formats.X, date, locale, timestamp);\n break;\n\n // '1970'\n // case 'Y':\n case 89:\n resultString += date.getFullYear();\n break;\n\n // 'GMT'\n // case 'Z':\n case 90:\n if (_useUtcBasedDate && _customTimezoneOffset === 0) {\n resultString += \"GMT\";\n }\n else {\n // fixme optimize\n var tzString = date.toString().match(/\\(([\\w\\s]+)\\)/);\n resultString += tzString && tzString[1] || '';\n }\n break;\n\n // 'Thu'\n // case 'a':\n case 97:\n resultString += locale.shortDays[date.getDay()];\n break;\n\n // 'Jan'\n // case 'b':\n case 98:\n resultString += locale.shortMonths[date.getMonth()];\n break;\n\n // ''\n // case 'c':\n case 99:\n resultString += _processFormat(locale.formats.c, date, locale, timestamp);\n break;\n\n // '01'\n // case 'd':\n case 100:\n resultString += padTill2(date.getDate(), padding);\n break;\n\n // ' 1'\n // case 'e':\n case 101:\n resultString += padTill2(date.getDate(), padding == null ? ' ' : padding);\n break;\n\n // 'Jan'\n // case 'h':\n case 104:\n resultString += locale.shortMonths[date.getMonth()];\n break;\n\n // '000'\n // case 'j':\n case 106:\n var y = new Date(date.getFullYear(), 0, 1);\n var day = Math.ceil((date.getTime() - y.getTime()) / (1000 * 60 * 60 * 24));\n resultString += padTill3(day);\n break;\n\n // ' 0'\n // case 'k':\n case 107:\n resultString += padTill2(date.getHours(), padding == null ? ' ' : padding);\n break;\n\n // '12'\n // case 'l':\n case 108:\n resultString += padTill2(hours12(date.getHours()), padding == null ? ' ' : padding);\n break;\n\n // '01'\n // case 'm':\n case 109:\n resultString += padTill2(date.getMonth() + 1, padding);\n break;\n\n // '\\n'\n // case 'n':\n case 110:\n resultString += '\\n';\n break;\n\n // '1st'\n // case 'o':\n case 111:\n resultString += String(date.getDate()) + ordinal(date.getDate());\n break;\n\n // 'AM'\n // case 'p':\n case 112:\n resultString += date.getHours() < 12 ? locale.AM : locale.PM;\n break;\n\n // '12:00:00 AM'\n // case 'r':\n case 114:\n resultString += _processFormat(locale.formats.r, date, locale, timestamp);\n break;\n\n // '0'\n // case 's':\n case 115:\n resultString += Math.floor(timestamp / 1000);\n break;\n\n // '\\t'\n // case 't':\n case 116:\n resultString += '\\t';\n break;\n\n // '4'\n // case 'u':\n case 117:\n var day = date.getDay();\n resultString += day === 0 ? 7 : day;\n break; // 1 - 7, Monday is first day of the week\n\n // ' 1-Jan-1970'\n // case 'v':\n case 118:\n resultString += _processFormat(locale.formats.v, date, locale, timestamp);\n break;\n\n // '4'\n // case 'w':\n case 119:\n resultString += date.getDay();\n break; // 0 - 6, Sunday is first day of the week\n\n // '12/31/69'\n // case 'x':\n case 120:\n resultString += _processFormat(locale.formats.x, date, locale, timestamp);\n break;\n\n // '70'\n // case 'y':\n case 121:\n resultString += ('' + date.getFullYear()).slice(2);\n break;\n\n // '+0000'\n // case 'z':\n case 122:\n if (_useUtcBasedDate && _customTimezoneOffset === 0) {\n resultString += extendedTZ ? \"+00:00\" : \"+0000\";\n }\n else {\n var off;\n if (_customTimezoneOffset !== 0) {\n off = _customTimezoneOffset / (60 * 1000);\n }\n else {\n off = -date.getTimezoneOffset();\n }\n var sign = off < 0 ? '-' : '+';\n var sep = extendedTZ ? ':' : '';\n var hours = Math.floor(Math.abs(off / 60));\n var mins = Math.abs(off % 60);\n resultString += sign + padTill2(hours) + sep + padTill2(mins);\n }\n break;\n\n default:\n resultString += format[i];\n break;\n }\n\n padding = null;\n isInScope = false;\n continue;\n }\n\n // '%'\n if (currentCharCode === 37) {\n isInScope = true;\n continue;\n }\n\n resultString += format[i];\n }\n\n return resultString;\n }\n\n var strftime = _strftime;\n\n strftime.localize = function(locale) {\n return new Strftime(locale || _locale, _customTimezoneOffset, _useUtcBasedDate);\n };\n\n strftime.timezone = function(timezone) {\n var customTimezoneOffset = _customTimezoneOffset;\n var useUtcBasedDate = _useUtcBasedDate;\n\n var timezoneType = typeof timezone;\n if (timezoneType === 'number' || timezoneType === 'string') {\n useUtcBasedDate = true;\n\n // ISO 8601 format timezone string, [-+]HHMM\n if (timezoneType === 'string') {\n var sign = timezone[0] === '-' ? -1 : 1,\n hours = parseInt(timezone.slice(1, 3), 10),\n minutes = parseInt(timezone.slice(3, 5), 10);\n\n customTimezoneOffset = sign * ((60 * hours) + minutes) * 60 * 1000;\n // in minutes: 420\n }\n else if (timezoneType === 'number') {\n customTimezoneOffset = timezone * 60 * 1000;\n }\n }\n\n return new Strftime(_locale, customTimezoneOffset, useUtcBasedDate);\n };\n\n strftime.utc = function() {\n return new Strftime(_locale, _customTimezoneOffset, true);\n };\n\n return strftime;\n }\n\n function padTill2(numberToPad, paddingChar) {\n if (paddingChar === '' || numberToPad > 9) {\n return numberToPad;\n }\n if (paddingChar == null) {\n paddingChar = '0';\n }\n return paddingChar + numberToPad;\n }\n\n function padTill3(numberToPad) {\n if (numberToPad > 99) {\n return numberToPad;\n }\n if (numberToPad > 9) {\n return '0' + numberToPad;\n }\n return '00' + numberToPad;\n }\n\n function hours12(hour) {\n if (hour === 0) {\n return 12;\n }\n else if (hour > 12) {\n return hour - 12;\n }\n return hour;\n }\n\n // firstWeekday: 'sunday' or 'monday', default is 'sunday'\n //\n // Pilfered & ported from Ruby's strftime implementation.\n function weekNumber(date, firstWeekday) {\n firstWeekday = firstWeekday || 'sunday';\n\n // This works by shifting the weekday back by one day if we\n // are treating Monday as the first day of the week.\n var weekday = date.getDay();\n if (firstWeekday === 'monday') {\n if (weekday === 0) // Sunday\n weekday = 6;\n else\n weekday--;\n }\n\n var firstDayOfYearUtc = Date.UTC(date.getFullYear(), 0, 1),\n dateUtc = Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()),\n yday = Math.floor((dateUtc - firstDayOfYearUtc) / 86400000),\n weekNum = (yday + 7 - weekday) / 7;\n\n return Math.floor(weekNum);\n }\n\n // Get the ordinal suffix for a number: st, nd, rd, or th\n function ordinal(number) {\n var i = number % 10;\n var ii = number % 100;\n\n if ((ii >= 11 && ii <= 13) || i === 0 || i >= 4) {\n return 'th';\n }\n switch (i) {\n case 1: return 'st';\n case 2: return 'nd';\n case 3: return 'rd';\n }\n }\n\n function getTimestampToUtcOffsetFor(date) {\n return (date.getTimezoneOffset() || 0) * 60000;\n }\n\n}());\n","//Provides: Base_int_math_int_popcount const\nfunction Base_int_math_int_popcount(v) {\n v = v - ((v >>> 1) & 0x55555555);\n v = (v & 0x33333333) + ((v >>> 2) & 0x33333333);\n return ((v + (v >>> 4) & 0xF0F0F0F) * 0x1010101) >>> 24;\n}\n\n//Provides: Base_clear_caml_backtrace_pos const\nfunction Base_clear_caml_backtrace_pos(x) {\n return 0;\n}\n\n//Provides: Base_int_math_int32_clz const\nfunction Base_int_math_int32_clz(x) {\n var n = 32;\n var y;\n y = x >>16; if (y != 0) { n = n -16; x = y; }\n y = x >> 8; if (y != 0) { n = n - 8; x = y; }\n y = x >> 4; if (y != 0) { n = n - 4; x = y; }\n y = x >> 2; if (y != 0) { n = n - 2; x = y; }\n y = x >> 1; if (y != 0) return n - 2;\n return n - x;\n}\n\n//Provides: Base_int_math_int_clz const\n//Requires: Base_int_math_int32_clz\nfunction Base_int_math_int_clz(x) { return Base_int_math_int32_clz(x); }\n\n//Provides: Base_int_math_nativeint_clz const\n//Requires: Base_int_math_int32_clz\nfunction Base_int_math_nativeint_clz(x) { return Base_int_math_int32_clz(x); }\n\n//Provides: Base_int_math_int64_clz const\n//Requires: caml_int64_shift_right_unsigned, caml_int64_is_zero, caml_int64_to_int32\nfunction Base_int_math_int64_clz(x) {\n var n = 64;\n var y;\n y = caml_int64_shift_right_unsigned(x, 32);\n if (!caml_int64_is_zero(y)) { n = n -32; x = y; }\n y = caml_int64_shift_right_unsigned(x, 16);\n if (!caml_int64_is_zero(y)) { n = n -16; x = y; }\n y = caml_int64_shift_right_unsigned(x, 8);\n if (!caml_int64_is_zero(y)) { n = n - 8; x = y; }\n y = caml_int64_shift_right_unsigned(x, 4);\n if (!caml_int64_is_zero(y)) { n = n - 4; x = y; }\n y = caml_int64_shift_right_unsigned(x, 2);\n if (!caml_int64_is_zero(y)) { n = n - 2; x = y; }\n y = caml_int64_shift_right_unsigned(x, 1);\n if (!caml_int64_is_zero(y)) return n - 2;\n return n - caml_int64_to_int32(x);\n}\n\n//Provides: Base_int_math_int32_ctz const\nfunction Base_int_math_int32_ctz(x) {\n if (x === 0) { return 32; }\n var n = 1;\n if ( (x & 0x0000FFFF) === 0) { n = n + 16; x = x >> 16; }\n if ( (x & 0x000000FF) === 0) { n = n + 8; x = x >> 8; }\n if ( (x & 0x0000000F) === 0) { n = n + 4; x = x >> 4; }\n if ( (x & 0x00000003) === 0) { n = n + 2; x = x >> 2; }\n return n - (x & 1);\n}\n\n//Provides: Base_int_math_int_ctz const\n//Requires: Base_int_math_int32_ctz\nfunction Base_int_math_int_ctz(x) { return Base_int_math_int32_ctz(x); }\n\n//Provides: Base_int_math_nativeint_ctz const\n//Requires: Base_int_math_int32_ctz\nfunction Base_int_math_nativeint_ctz(x) { return Base_int_math_int32_ctz(x); }\n\n//Provides: Base_int_math_int64_ctz const\n//Requires: caml_int64_shift_right_unsigned, caml_int64_is_zero, caml_int64_to_int32\n//Requires: caml_int64_and, caml_int64_of_int32, caml_int64_create_lo_mi_hi\nfunction Base_int_math_int64_ctz(x) {\n if (caml_int64_is_zero(x)) { return 64; }\n var n = 1;\n function is_zero (x) { return caml_int64_is_zero(x); }\n function land (x,y) { return caml_int64_and(x, y); }\n function small_int64(x) { return caml_int64_create_lo_mi_hi(x,0,0); }\n if (is_zero(land(x, caml_int64_create_lo_mi_hi(0xFFFFFF, 0x0000FF, 0x0000)))) {\n n = n + 32; x = caml_int64_shift_right_unsigned(x, 32);\n }\n if (is_zero(land(x, small_int64(0x00FFFF)))) {\n n = n + 16; x = caml_int64_shift_right_unsigned(x, 16);\n }\n if (is_zero(land(x, small_int64(0x0000FF)))) {\n n = n + 8; x = caml_int64_shift_right_unsigned(x, 8);\n }\n if (is_zero(land(x, small_int64(0x00000F)))) {\n n = n + 4; x = caml_int64_shift_right_unsigned(x, 4);\n }\n if (is_zero(land(x, small_int64(0x000003)))) {\n n = n + 2; x = caml_int64_shift_right_unsigned(x, 2);\n }\n return n - (caml_int64_to_int32(caml_int64_and(x, small_int64(0x000001))));\n}\n\n//Provides: Base_int_math_int_pow_stub const\nfunction Base_int_math_int_pow_stub(base, exponent) {\n var one = 1;\n var mul = [one, base, one, one];\n var res = one;\n while (!exponent==0) {\n mul[1] = (mul[1] * mul[3]) | 0;\n mul[2] = (mul[1] * mul[1]) | 0;\n mul[3] = (mul[2] * mul[1]) | 0;\n res = (res * mul[exponent & 3]) | 0;\n exponent = exponent >> 2;\n }\n return res;\n}\n\n//Provides: Base_int_math_int64_pow_stub const\n//Requires: caml_int64_mul, caml_int64_is_zero, caml_int64_shift_right_unsigned\n//Requires: caml_int64_create_lo_hi, caml_int64_lo32\nfunction Base_int_math_int64_pow_stub(base, exponent) {\n var one = caml_int64_create_lo_hi(1,0);\n var mul = [one, base, one, one];\n var res = one;\n while (!caml_int64_is_zero(exponent)) {\n mul[1] = caml_int64_mul(mul[1], mul[3]);\n mul[2] = caml_int64_mul(mul[1], mul[1]);\n mul[3] = caml_int64_mul(mul[2], mul[1]);\n res = caml_int64_mul(res, mul[caml_int64_lo32(exponent) & 3]);\n exponent = caml_int64_shift_right_unsigned(exponent, 2);\n }\n return res;\n}\n\n//Provides: Base_hash_string mutable\n//Requires: caml_hash\nfunction Base_hash_string(s) {\n return caml_hash(1,1,0,s)\n}\n//Provides: Base_hash_double const\n//Requires: caml_hash\nfunction Base_hash_double(d) {\n return caml_hash(1,1,0,d);\n}\n\n//Provides: Base_am_testing const\n//Weakdef\nfunction Base_am_testing(x) {\n return 0;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_format_int const (const, const)\n//Requires: caml_parse_format, caml_finish_formatting, caml_str_repeat\n//Requires: caml_string_of_jsbytes, caml_jsbytes_of_string\nfunction caml_format_int(fmt, i) {\n if (caml_jsbytes_of_string(fmt) == \"%d\") return caml_string_of_jsbytes(\"\"+i);\n var f = caml_parse_format(fmt);\n if (i < 0) { if (f.signedconv) { f.sign = -1; i = -i; } else i >>>= 0; }\n var s = i.toString(f.base);\n if (f.prec >= 0) {\n f.filler = ' ';\n var n = f.prec - s.length;\n if (n > 0) s = caml_str_repeat (n, '0') + s;\n }\n return caml_finish_formatting(f, s);\n}\n\n//Provides: caml_parse_sign_and_base\n//Requires: caml_string_unsafe_get, caml_ml_string_length\nfunction caml_parse_sign_and_base (s) {\n var i = 0, len = caml_ml_string_length(s), base = 10, sign = 1;\n if (len > 0) {\n switch (caml_string_unsafe_get(s,i)) {\n case 45: i++; sign = -1; break;\n case 43: i++; sign = 1; break;\n }\n }\n if (i + 1 < len && caml_string_unsafe_get(s, i) == 48)\n switch (caml_string_unsafe_get(s, i + 1)) {\n case 120: case 88: base = 16; i += 2; break;\n case 111: case 79: base = 8; i += 2; break;\n case 98: case 66: base = 2; i += 2; break;\n case 117: case 85: i += 2; break;\n }\n return [i, sign, base];\n}\n\n//Provides: caml_parse_digit\nfunction caml_parse_digit(c) {\n if (c >= 48 && c <= 57) return c - 48;\n if (c >= 65 && c <= 90) return c - 55;\n if (c >= 97 && c <= 122) return c - 87;\n return -1;\n}\n\n//Provides: caml_int_of_string (const)\n//Requires: caml_ml_string_length, caml_string_unsafe_get\n//Requires: caml_parse_sign_and_base, caml_parse_digit, caml_failwith\nfunction caml_int_of_string (s) {\n var r = caml_parse_sign_and_base (s);\n var i = r[0], sign = r[1], base = r[2];\n var len = caml_ml_string_length(s);\n var threshold = -1 >>> 0;\n var c = (i < len)?caml_string_unsafe_get(s, i):0;\n var d = caml_parse_digit(c);\n if (d < 0 || d >= base) caml_failwith(\"int_of_string\");\n var res = d;\n for (i++;i= base) break;\n res = base * res + d;\n if (res > threshold) caml_failwith(\"int_of_string\");\n }\n if (i != len) caml_failwith(\"int_of_string\");\n // For base different from 10, we expect an unsigned representation,\n // hence any value of 'res' (less than 'threshold') is acceptable.\n // But we have to convert the result back to a signed integer.\n res = sign * res;\n if ((base == 10) && ((res | 0) != res))\n /* Signed representation expected, allow -2^(nbits-1) to 2^(nbits-1) - 1 */\n caml_failwith(\"int_of_string\");\n return res | 0;\n}\n\n//Provides: caml_mul const\nfunction caml_mul(a,b){\n return Math.imul(a,b);\n}\n\n//Provides: caml_div\n//Requires: caml_raise_zero_divide\nfunction caml_div(x,y) {\n if (y == 0) caml_raise_zero_divide ();\n return (x/y)|0;\n}\n\n//Provides: caml_mod\n//Requires: caml_raise_zero_divide\nfunction caml_mod(x,y) {\n if (y == 0) caml_raise_zero_divide ();\n return x%y;\n}\n\n//Provides: caml_bswap16\nfunction caml_bswap16(x) {\n return ((((x & 0x00FF) << 8) |\n ((x & 0xFF00) >> 8)));\n}\n//Provides: caml_int32_bswap\nfunction caml_int32_bswap(x) {\n return (((x & 0x000000FF) << 24) |\n ((x & 0x0000FF00) << 8) |\n ((x & 0x00FF0000) >>> 8) |\n ((x & 0xFF000000) >>> 24));\n}\n//Provides: caml_int64_bswap\n//Requires: caml_int64_to_bytes, caml_int64_of_bytes\nfunction caml_int64_bswap(x) {\n var y = caml_int64_to_bytes(x);\n return caml_int64_of_bytes([y[7], y[6], y[5], y[4], y[3], y[2], y[1], y[0]]);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Hashtbl\n\n//Provides: caml_hash_univ_param mutable\n//Requires: caml_is_ml_string, caml_is_ml_bytes\n//Requires: caml_ml_bytes_content\n//Requires: caml_int64_to_bytes, caml_int64_bits_of_float, caml_custom_ops\n//Requires: caml_ml_bytes_length, caml_jsbytes_of_string\nfunction caml_hash_univ_param (count, limit, obj) {\n var hash_accu = 0;\n function hash_aux (obj) {\n limit --;\n if (count < 0 || limit < 0) return;\n if (obj instanceof Array && obj[0] === (obj[0]|0)) {\n switch (obj[0]) {\n case 248:\n // Object\n count --;\n hash_accu = (hash_accu * 65599 + obj[2]) | 0;\n break;\n case 250:\n // Forward\n limit++; hash_aux(obj); break;\n default:\n count --;\n hash_accu = (hash_accu * 19 + obj[0]) | 0;\n for (var i = obj.length - 1; i > 0; i--) hash_aux (obj[i]);\n }\n } else if (caml_is_ml_bytes(obj)) {\n count --;\n var content = caml_ml_bytes_content(obj);\n if(typeof content === \"string\") {\n\tfor (var b = content, l = b.length, i = 0; i < l; i++)\n hash_accu = (hash_accu * 19 + b.charCodeAt(i)) | 0;\n } else { /* ARRAY */\n for (var a = content, l = a.length, i = 0; i < l; i++)\n hash_accu = (hash_accu * 19 + a[i]) | 0;\n }\n } else if (caml_is_ml_string(obj)) {\n var jsbytes = caml_jsbytes_of_string(obj);\n for (var b = jsbytes, l = jsbytes.length, i = 0; i < l; i++)\n hash_accu = (hash_accu * 19 + b.charCodeAt(i)) | 0;\n } else if (typeof obj === \"string\") {\n for (var b = obj, l = obj.length, i = 0; i < l; i++)\n hash_accu = (hash_accu * 19 + b.charCodeAt(i)) | 0;\n } else if (obj === (obj|0)) {\n // Integer\n count --;\n hash_accu = (hash_accu * 65599 + obj) | 0;\n } else if (obj === +obj) {\n // Float\n count--;\n var p = caml_int64_to_bytes (caml_int64_bits_of_float (obj));\n for (var i = 7; i >= 0; i--) hash_accu = (hash_accu * 19 + p[i]) | 0;\n } else if(obj && obj.caml_custom) {\n if(caml_custom_ops[obj.caml_custom] && caml_custom_ops[obj.caml_custom].hash) {\n var h = caml_custom_ops[obj.caml_custom].hash(obj) | 0;\n hash_accu = (hash_accu * 65599 + h) | 0;\n }\n }\n }\n hash_aux (obj);\n return hash_accu & 0x3FFFFFFF;\n}\n\n//function ROTL32(x,n) { return ((x << n) | (x >>> (32-n))); }\n//Provides: caml_hash_mix_int\n//Requires: caml_mul\nfunction caml_hash_mix_int(h,d) {\n d = caml_mul(d, 0xcc9e2d51|0);\n d = ((d << 15) | (d >>> (32-15))); // ROTL32(d, 15);\n d = caml_mul(d, 0x1b873593);\n h ^= d;\n h = ((h << 13) | (h >>> (32-13))); //ROTL32(h, 13);\n return (((h + (h << 2))|0) + (0xe6546b64|0))|0;\n}\n\n//Provides: caml_hash_mix_final\n//Requires: caml_mul\nfunction caml_hash_mix_final(h) {\n h ^= h >>> 16;\n h = caml_mul (h, 0x85ebca6b|0);\n h ^= h >>> 13;\n h = caml_mul (h, 0xc2b2ae35|0);\n h ^= h >>> 16;\n return h;\n}\n\n//Provides: caml_hash_mix_float\n//Requires: caml_int64_bits_of_float, caml_hash_mix_int64\nfunction caml_hash_mix_float (h, v0) {\n return caml_hash_mix_int64(h, caml_int64_bits_of_float (v0));\n}\n//Provides: caml_hash_mix_int64\n//Requires: caml_hash_mix_int\n//Requires: caml_int64_lo32, caml_int64_hi32\nfunction caml_hash_mix_int64 (h, v) {\n h = caml_hash_mix_int(h, caml_int64_lo32(v));\n h = caml_hash_mix_int(h, caml_int64_hi32(v));\n return h;\n}\n\n//Provides: caml_hash_mix_jsbytes\n//Requires: caml_hash_mix_int\nfunction caml_hash_mix_jsbytes(h, s) {\n var len = s.length, i, w;\n for (i = 0; i + 4 <= len; i += 4) {\n w = s.charCodeAt(i)\n | (s.charCodeAt(i+1) << 8)\n | (s.charCodeAt(i+2) << 16)\n | (s.charCodeAt(i+3) << 24);\n h = caml_hash_mix_int(h, w);\n }\n w = 0;\n switch (len & 3) {\n case 3: w = s.charCodeAt(i+2) << 16;\n case 2: w |= s.charCodeAt(i+1) << 8;\n case 1:\n w |= s.charCodeAt(i);\n h = caml_hash_mix_int(h, w);\n default:\n }\n h ^= len;\n return h;\n}\n\n//Provides: caml_hash_mix_bytes_arr\n//Requires: caml_hash_mix_int\nfunction caml_hash_mix_bytes_arr(h, s) {\n var len = s.length, i, w;\n for (i = 0; i + 4 <= len; i += 4) {\n w = s[i]\n | (s[i+1] << 8)\n | (s[i+2] << 16)\n | (s[i+3] << 24);\n h = caml_hash_mix_int(h, w);\n }\n w = 0;\n switch (len & 3) {\n case 3: w = s[i+2] << 16;\n case 2: w |= s[i+1] << 8;\n case 1: w |= s[i];\n h = caml_hash_mix_int(h, w);\n default:\n }\n h ^= len;\n return h;\n}\n\n//Provides: caml_hash_mix_bytes\n//Requires: caml_ml_bytes_content\n//Requires: caml_hash_mix_jsbytes\n//Requires: caml_hash_mix_bytes_arr\nfunction caml_hash_mix_bytes(h, v) {\n var content = caml_ml_bytes_content(v);\n if(typeof content === \"string\")\n return caml_hash_mix_jsbytes(h, content)\n else /* ARRAY */\n return caml_hash_mix_bytes_arr(h, content);\n}\n\n//Provides: caml_hash_mix_string\n//Requires: caml_hash_mix_jsbytes, caml_jsbytes_of_string\nfunction caml_hash_mix_string(h, v) {\n return caml_hash_mix_jsbytes(h, caml_jsbytes_of_string(v));\n}\n\n\n//Provides: caml_hash mutable\n//Requires: caml_is_ml_string, caml_is_ml_bytes\n//Requires: caml_hash_mix_int, caml_hash_mix_final\n//Requires: caml_hash_mix_float, caml_hash_mix_string, caml_hash_mix_bytes, caml_custom_ops\n//Requires: caml_hash_mix_jsbytes\nfunction caml_hash (count, limit, seed, obj) {\n var queue, rd, wr, sz, num, h, v, i, len;\n sz = limit;\n if (sz < 0 || sz > 256) sz = 256;\n num = count;\n h = seed;\n queue = [obj]; rd = 0; wr = 1;\n while (rd < wr && num > 0) {\n v = queue[rd++];\n if (v && v.caml_custom){\n if(caml_custom_ops[v.caml_custom] && caml_custom_ops[v.caml_custom].hash) {\n var hh = caml_custom_ops[v.caml_custom].hash(v);\n h = caml_hash_mix_int (h, hh);\n num --;\n }\n }\n else if (v instanceof Array && v[0] === (v[0]|0)) {\n switch (v[0]) {\n case 248:\n // Object\n h = caml_hash_mix_int(h, v[2]);\n num--;\n break;\n case 250:\n // Forward\n queue[--rd] = v[1];\n break;\n default:\n var tag = ((v.length - 1) << 10) | v[0];\n h = caml_hash_mix_int(h, tag);\n for (i = 1, len = v.length; i < len; i++) {\n if (wr >= sz) break;\n queue[wr++] = v[i];\n }\n break;\n }\n } else if (caml_is_ml_bytes(v)) {\n h = caml_hash_mix_bytes(h,v)\n num--;\n } else if (caml_is_ml_string(v)) {\n h = caml_hash_mix_string(h,v)\n num--;\n } else if (typeof v === \"string\") {\n h = caml_hash_mix_jsbytes(h,v)\n num--;\n } else if (v === (v|0)) {\n // Integer\n h = caml_hash_mix_int(h, v+v+1);\n num--;\n } else if (v === +v) {\n // Float\n h = caml_hash_mix_float(h,v);\n num--;\n }\n }\n h = caml_hash_mix_final(h);\n return h & 0x3FFFFFFF;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: jsoo_floor_log2\nvar log2_ok = Math.log2 && Math.log2(1.1235582092889474E+307) == 1020\nfunction jsoo_floor_log2(x) {\n if(log2_ok) return Math.floor(Math.log2(x))\n var i = 0;\n if (x == 0) return -Infinity;\n if(x>=1) {while (x>=2) {x/=2; i++} }\n else {while (x < 1) {x*=2; i--} };\n return i;\n}\n\n//Provides: caml_int64_bits_of_float const\n//Requires: jsoo_floor_log2, caml_int64_create_lo_mi_hi\nfunction caml_int64_bits_of_float (x) {\n if (!isFinite(x)) {\n if (isNaN(x))\n return caml_int64_create_lo_mi_hi(1, 0, 0x7ff0);\n if (x > 0)\n return caml_int64_create_lo_mi_hi(0, 0, 0x7ff0)\n else\n return caml_int64_create_lo_mi_hi(0, 0, 0xfff0)\n }\n var sign = (x==0 && 1/x == -Infinity)?0x8000:(x>=0)?0:0x8000;\n if (sign) x = -x;\n // Int64.bits_of_float 1.1235582092889474E+307 = 0x7fb0000000000000L\n // using Math.LOG2E*Math.log(x) in place of Math.log2 result in precision lost\n var exp = jsoo_floor_log2(x) + 1023;\n if (exp <= 0) {\n exp = 0;\n x /= Math.pow(2,-1026);\n } else {\n x /= Math.pow(2,exp-1027);\n if (x < 16) {\n x *= 2; exp -=1; }\n if (exp == 0) {\n x /= 2; }\n }\n var k = Math.pow(2,24);\n var r3 = x|0;\n x = (x - r3) * k;\n var r2 = x|0;\n x = (x - r2) * k;\n var r1 = x|0;\n r3 = (r3 &0xf) | sign | exp << 4;\n return caml_int64_create_lo_mi_hi(r1, r2, r3);\n}\n\n//Provides: caml_int32_bits_of_float const\n//Requires: jsoo_floor_log2\nfunction caml_int32_bits_of_float (x) {\n var float32a = new globalThis.Float32Array(1);\n float32a[0] = x;\n var int32a = new globalThis.Int32Array(float32a.buffer);\n return int32a[0] | 0;\n}\n\n//FP literals can be written using the hexadecimal\n//notation 0xp from ISO C99.\n//https://github.com/dankogai/js-hexfloat/blob/master/hexfloat.js\n//Provides: caml_hexstring_of_float const\n//Requires: caml_string_of_jsstring, caml_str_repeat\nfunction caml_hexstring_of_float (x, prec, style) {\n if (!isFinite(x)) {\n if (isNaN(x)) return caml_string_of_jsstring(\"nan\");\n return caml_string_of_jsstring ((x > 0)?\"infinity\":\"-infinity\");\n }\n var sign = (x==0 && 1/x == -Infinity)?1:(x>=0)?0:1;\n if(sign) x = -x;\n var exp = 0;\n if (x == 0) { }\n else if (x < 1) {\n while (x < 1 && exp > -1022) { x *= 2; exp-- }\n } else {\n while (x >= 2) { x /= 2; exp++ }\n }\n var exp_sign = exp < 0 ? '' : '+';\n var sign_str = '';\n if (sign) sign_str = '-'\n else {\n switch(style){\n case 43 /* '+' */: sign_str = '+'; break;\n case 32 /* ' ' */: sign_str = ' '; break;\n default: break;\n }\n }\n if (prec >= 0 && prec < 13) {\n /* If a precision is given, and is small, round mantissa accordingly */\n var cst = Math.pow(2,prec * 4);\n x = Math.round(x * cst) / cst;\n }\n var x_str = x.toString(16);\n if(prec >= 0){\n var idx = x_str.indexOf('.');\n if(idx<0) {\n x_str += '.' + caml_str_repeat(prec, '0');\n }\n else {\n var size = idx+1+prec;\n if(x_str.length < size)\n x_str += caml_str_repeat(size - x_str.length, '0');\n else\n x_str = x_str.substr(0,size);\n }\n }\n return caml_string_of_jsstring (sign_str + '0x' + x_str + 'p' + exp_sign + exp.toString(10));\n}\n\n//Provides: caml_int64_float_of_bits const\nfunction caml_int64_float_of_bits (x) {\n var lo = x.lo;\n var mi = x.mi;\n var hi = x.hi;\n var exp = (hi & 0x7fff) >> 4;\n if (exp == 2047) {\n if ((lo|mi|(hi&0xf)) == 0)\n return (hi & 0x8000)?(-Infinity):Infinity;\n else\n return NaN;\n }\n var k = Math.pow(2,-24);\n var res = (lo*k+mi)*k+(hi&0xf);\n if (exp > 0) {\n res += 16;\n res *= Math.pow(2,exp-1027);\n } else\n res *= Math.pow(2,-1026);\n if (hi & 0x8000) res = - res;\n return res;\n}\n\n//Provides: caml_nextafter_float const\n//Requires: caml_int64_float_of_bits, caml_int64_bits_of_float, caml_int64_add, caml_int64_sub,caml_int64_of_int32\nfunction caml_nextafter_float (x,y) {\n if(isNaN(x) || isNaN(y)) return NaN;\n if(x==y) return y;\n if(x==0){\n if(y < 0)\n return -Math.pow(2, -1074)\n else\n return Math.pow(2, -1074)\n }\n var bits = caml_int64_bits_of_float(x);\n var one = caml_int64_of_int32(1);\n if ((x0))\n bits = caml_int64_add(bits, one)\n else\n bits = caml_int64_sub(bits, one)\n return caml_int64_float_of_bits(bits);\n}\n\n//Provides: caml_trunc_float\nfunction caml_trunc_float(x){\n return Math.trunc(x);\n}\n\n//Provides: caml_int32_float_of_bits const\nfunction caml_int32_float_of_bits (x) {\n var int32a = new globalThis.Int32Array(1);\n int32a[0] = x;\n var float32a = new globalThis.Float32Array(int32a.buffer);\n return float32a[0];\n}\n\n//Provides: caml_classify_float const\nfunction caml_classify_float (x) {\n if (isFinite (x)) {\n if (Math.abs(x) >= 2.2250738585072014e-308) return 0;\n if (x != 0) return 1;\n return 2;\n }\n return isNaN(x)?4:3;\n}\n//Provides: caml_modf_float const\nfunction caml_modf_float (x) {\n if (isFinite (x)) {\n var neg = (1/x) < 0;\n x = Math.abs(x);\n var i = Math.floor (x);\n var f = x - i;\n if (neg) { i = -i; f = -f; }\n return [0, f, i];\n }\n if (isNaN (x)) return [0, NaN, NaN];\n return [0, 1/x, x];\n}\n//Provides: caml_ldexp_float const\nfunction caml_ldexp_float (x,exp) {\n exp |= 0;\n if (exp > 1023) {\n exp -= 1023;\n x *= Math.pow(2, 1023);\n if (exp > 1023) { // in case x is subnormal\n exp -= 1023;\n x *= Math.pow(2, 1023);\n }\n }\n if (exp < -1023) {\n exp += 1023;\n x *= Math.pow(2, -1023);\n }\n x *= Math.pow(2, exp);\n return x;\n}\n//Provides: caml_frexp_float const\n//Requires: jsoo_floor_log2\nfunction caml_frexp_float (x) {\n if ((x == 0) || !isFinite(x)) return [0, x, 0];\n var neg = x < 0;\n if (neg) x = - x;\n var exp = Math.max(-1023, jsoo_floor_log2(x) + 1);\n x *= Math.pow(2,-exp);\n while (x < 0.5) {\n x *= 2;\n exp--;\n }\n while (x >= 1) {\n x *= 0.5;\n exp++;\n }\n if (neg) x = - x;\n return [0, x, exp];\n}\n\n//Provides: caml_float_compare const\nfunction caml_float_compare (x, y) {\n if (x === y) return 0;\n if (x < y) return -1;\n if (x > y) return 1;\n if (x === x) return 1;\n if (y === y) return -1;\n return 0;\n}\n\n//Provides: caml_copysign_float const\nfunction caml_copysign_float (x, y) {\n if (y == 0) y = 1 / y;\n x = Math.abs(x);\n return (y < 0)?(-x):x;\n}\n\n//Provides: caml_signbit_float const\nfunction caml_signbit_float(x) {\n if (x == 0) x = 1 / x;\n return (x < 0)?1:0;\n}\n\n//Provides: caml_expm1_float const\nfunction caml_expm1_float (x) { return Math.expm1(x); }\n//Provides: caml_exp2_float const\nfunction caml_exp2_float(x) { return Math.pow(2, x); }\n//Provides: caml_log1p_float const\nfunction caml_log1p_float(x) { return Math.log1p(x); }\n//Provides: caml_log2_float const\nfunction caml_log2_float(x) { return Math.log2(x); }\n//Provides: caml_hypot_float const\nfunction caml_hypot_float (x, y) { return Math.hypot(x, y); }\n//Provides: caml_log10_float const\nfunction caml_log10_float (x) { return Math.log10(x); }\n//Provides: caml_cosh_float const\nfunction caml_cosh_float (x) { return Math.cosh(x); }\n//Provides: caml_acosh_float const\nfunction caml_acosh_float (x) { return Math.acosh(x); }\n//Provides: caml_sinh_float const\nfunction caml_sinh_float (x) { return Math.sinh(x); }\n//Provides: caml_asinh_float const\nfunction caml_asinh_float (x) { return Math.asinh(x); }\n//Provides: caml_tanh_float const\nfunction caml_tanh_float (x) { return Math.tanh(x); }\n//Provides: caml_atanh_float const\nfunction caml_atanh_float (x) { return Math.atanh(x); }\n//Provides: caml_round_float const\nfunction caml_round_float (x) { return Math.round(x); }\n//Provides: caml_cbrt_float const\nfunction caml_cbrt_float (x) { return Math.cbrt(x); }\n\n//Provides: caml_erf_float const\nfunction caml_erf_float(x) {\n var a1 = 0.254829592;\n var a2 = -0.284496736;\n var a3 = 1.421413741;\n var a4 = -1.453152027;\n var a5 = 1.061405429;\n var p = 0.3275911;\n\n var sign = 1;\n if (x < 0) {\n sign = -1;\n }\n x = Math.abs(x);\n var t = 1.0 / (1.0 + p * x);\n var y = 1.0 - ((((a5 * t + a4) * t + a3) * t + a2) * t + a1) * t * Math.exp(-x * x);\n\n return sign * y;\n}\n\n//Provides: caml_erfc_float const\n//Requires: caml_erf_float\nfunction caml_erfc_float(x) {\n return 1 - caml_erf_float(x);\n}\n\n\n//Provides: caml_fma_float const\nfunction caml_fma_float(x, y, z) {\n var SPLIT = Math.pow(2, 27) + 1;\n var MIN_VALUE = Math.pow(2, -1022);\n var EPSILON = Math.pow(2, -52);\n var C = 416;\n var A = Math.pow(2, +C);\n var B = Math.pow(2, -C);\n\n function multiply (a, b) {\n var at = SPLIT * a;\n var ahi = at - (at - a);\n var alo = a - ahi;\n var bt = SPLIT * b;\n var bhi = bt - (bt - b);\n var blo = b - bhi;\n var p = a * b;\n var e = ((ahi * bhi - p) + ahi * blo + alo * bhi) + alo * blo;\n return {\n p: p,\n e: e\n };\n };\n\n function add (a, b) {\n var s = a + b;\n var v = s - a;\n var e = (a - (s - v)) + (b - v);\n return {\n s: s,\n e: e\n };\n };\n\n function adjust (x, y) {\n return x !== 0 && y !== 0 && SPLIT * x - (SPLIT * x - x) === x ? x * (1 + (x < 0 ? -1 : +1) * (y < 0 ? -1 : +1) * EPSILON) : x;\n };\n\n if (x === 0 || x !== x || x === +1 / 0 || x === -1 / 0 ||\n y === 0 || y !== y || y === +1 / 0 || y === -1 / 0) {\n return x * y + z;\n }\n if (z === 0) {\n return x * y;\n }\n if (z !== z || z === +1 / 0 || z === -1 / 0) {\n return z;\n }\n\n var scale = 1;\n while (Math.abs(x) > A) {\n scale *= A;\n x *= B;\n }\n while (Math.abs(y) > A) {\n scale *= A;\n y *= B;\n }\n if (scale === 1 / 0) {\n return x * y * scale;\n }\n while (Math.abs(x) < B) {\n scale *= B;\n x *= A;\n }\n while (Math.abs(y) < B) {\n scale *= B;\n y *= A;\n }\n if (scale === 0) {\n return z;\n }\n\n var xs = x;\n var ys = y;\n var zs = z / scale;\n\n if (Math.abs(zs) > Math.abs(xs * ys) * 4 / EPSILON) {\n return z;\n }\n if (Math.abs(zs) < Math.abs(xs * ys) * EPSILON / 4 * EPSILON / 4) {\n zs = (z < 0 ? -1 : +1) * MIN_VALUE;\n }\n\n var xy = multiply(xs, ys);\n var s = add(xy.p, zs);\n var u = add(xy.e, s.e);\n var i = add(s.s, u.s);\n\n var f = i.s + adjust(i.e, u.e);\n if (f === 0) {\n return f;\n }\n\n var fs = f * scale;\n if (Math.abs(fs) > MIN_VALUE) {\n return fs;\n }\n\n // It is possible that there was extra rounding for a denormalized value.\n return fs + adjust(f - fs / scale, i.e) * scale;\n}\n\n//Provides: caml_format_float const\n//Requires: caml_parse_format, caml_finish_formatting\nfunction caml_format_float (fmt, x) {\n function toFixed(x,dp) {\n if (Math.abs(x) < 1.0) {\n return x.toFixed(dp);\n } else {\n var e = parseInt(x.toString().split('+')[1]);\n if (e > 20) {\n e -= 20;\n x /= Math.pow(10,e);\n x += (new Array(e+1)).join('0');\n if(dp > 0) {\n x = x + '.' + (new Array(dp+1)).join('0');\n }\n return x;\n }\n else return x.toFixed(dp)\n }\n }\n var s, f = caml_parse_format(fmt);\n var prec = (f.prec < 0)?6:f.prec;\n if (x < 0 || (x == 0 && 1/x == -Infinity)) { f.sign = -1; x = -x; }\n if (isNaN(x)) { s = \"nan\"; f.filler = ' '; }\n else if (!isFinite(x)) { s = \"inf\"; f.filler = ' '; }\n else\n switch (f.conv) {\n case 'e':\n var s = x.toExponential(prec);\n // exponent should be at least two digits\n var i = s.length;\n if (s.charAt(i - 3) == 'e')\n s = s.slice (0, i - 1) + '0' + s.slice (i - 1);\n break;\n case 'f':\n s = toFixed(x, prec); break;\n case 'g':\n prec = prec?prec:1;\n s = x.toExponential(prec - 1);\n var j = s.indexOf('e');\n var exp = +s.slice(j + 1);\n if (exp < -4 || x >= 1e21 || x.toFixed(0).length > prec) {\n // remove trailing zeroes\n var i = j - 1; while (s.charAt(i) == '0') i--;\n if (s.charAt(i) == '.') i--;\n s = s.slice(0, i + 1) + s.slice(j);\n i = s.length;\n if (s.charAt(i - 3) == 'e')\n s = s.slice (0, i - 1) + '0' + s.slice (i - 1);\n break;\n } else {\n var p = prec;\n if (exp < 0) { p -= exp + 1; s = x.toFixed(p); }\n else while (s = x.toFixed(p), s.length > prec + 1) p--;\n if (p) {\n // remove trailing zeroes\n var i = s.length - 1; while (s.charAt(i) == '0') i--;\n if (s.charAt(i) == '.') i--;\n s = s.slice(0, i + 1);\n }\n }\n break;\n }\n return caml_finish_formatting(f, s);\n}\n\n//Provides: caml_float_of_string (const)\n//Requires: caml_failwith, caml_jsbytes_of_string\nfunction caml_float_of_string(s) {\n var res;\n s = caml_jsbytes_of_string(s)\n res = +s;\n if ((s.length > 0) && (res === res)) return res;\n s = s.replace(/_/g,\"\");\n res = +s;\n if (((s.length > 0) && (res === res)) || /^[+-]?nan$/i.test(s)) return res;\n var m = /^ *([+-]?)0x([0-9a-f]+)\\.?([0-9a-f]*)(p([+-]?[0-9]+))?/i.exec(s);\n // 1 2 3 5\n if(m){\n var m3 = m[3].replace(/0+$/,'');\n var mantissa = parseInt(m[1] + m[2] + m3, 16);\n var exponent = (m[5]|0) - 4*m3.length;\n res = mantissa * Math.pow(2, exponent);\n return res;\n }\n if(/^\\+?inf(inity)?$/i.test(s)) return Infinity;\n if(/^-inf(inity)?$/i.test(s)) return -Infinity;\n caml_failwith(\"float_of_string\");\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_int64_offset\nvar caml_int64_offset = Math.pow(2, -24);\n\n//Provides: MlInt64\n//Requires: caml_int64_offset, caml_raise_zero_divide\nfunction MlInt64 (lo,mi,hi) {\n this.lo = lo & 0xffffff;\n this.mi = mi & 0xffffff;\n this.hi = hi & 0xffff;\n}\nMlInt64.prototype.caml_custom = \"_j\"\nMlInt64.prototype.copy = function () {\n return new MlInt64(this.lo,this.mi,this.hi);\n}\n\nMlInt64.prototype.ucompare = function (x) {\n if (this.hi > x.hi) return 1;\n if (this.hi < x.hi) return -1;\n if (this.mi > x.mi) return 1;\n if (this.mi < x.mi) return -1;\n if (this.lo > x.lo) return 1;\n if (this.lo < x.lo) return -1;\n return 0;\n}\nMlInt64.prototype.compare = function (x) {\n var hi = this.hi << 16;\n var xhi = x.hi << 16;\n if (hi > xhi) return 1;\n if (hi < xhi) return -1;\n if (this.mi > x.mi) return 1;\n if (this.mi < x.mi) return -1;\n if (this.lo > x.lo) return 1;\n if (this.lo < x.lo) return -1;\n return 0;\n}\nMlInt64.prototype.neg = function () {\n var lo = - this.lo;\n var mi = - this.mi + (lo >> 24);\n var hi = - this.hi + (mi >> 24);\n return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.add = function (x) {\n var lo = this.lo + x.lo;\n var mi = this.mi + x.mi + (lo >> 24);\n var hi = this.hi + x.hi + (mi >> 24);\n return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.sub = function (x) {\n var lo = this.lo - x.lo;\n var mi = this.mi - x.mi + (lo >> 24);\n var hi = this.hi - x.hi + (mi >> 24);\n return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.mul = function (x) {\n var lo = this.lo * x.lo;\n var mi = ((lo * caml_int64_offset) | 0) + this.mi * x.lo + this.lo * x.mi;\n var hi = ((mi * caml_int64_offset) | 0) + this.hi * x.lo + this.mi * x.mi + this.lo * x.hi;\n return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.isZero = function () {\n return (this.lo|this.mi|this.hi) == 0;\n}\nMlInt64.prototype.isNeg = function () {\n return (this.hi << 16) < 0;\n}\nMlInt64.prototype.and = function (x) {\n return new MlInt64(this.lo & x.lo, this.mi & x.mi, this.hi & x.hi);\n}\nMlInt64.prototype.or = function (x) {\n return new MlInt64(this.lo|x.lo, this.mi|x.mi, this.hi|x.hi);\n}\nMlInt64.prototype.xor = function (x) {\n return new MlInt64(this.lo^x.lo, this.mi^x.mi, this.hi^x.hi);\n}\nMlInt64.prototype.shift_left = function (s) {\n s = s & 63;\n if (s == 0) return this;\n if (s < 24) {\n return new MlInt64 (this.lo << s,\n (this.mi << s) | (this.lo >> (24 - s)),\n (this.hi << s) | (this.mi >> (24 - s)));\n }\n if (s < 48)\n return new MlInt64 (0,\n this.lo << (s - 24),\n (this.mi << (s - 24)) | (this.lo >> (48 - s)));\n return new MlInt64(0, 0, this.lo << (s - 48))\n}\nMlInt64.prototype.shift_right_unsigned = function (s) {\n s = s & 63;\n if (s == 0) return this;\n if (s < 24)\n return new MlInt64 (\n (this.lo >> s) | (this.mi << (24 - s)),\n (this.mi >> s) | (this.hi << (24 - s)),\n (this.hi >> s));\n if (s < 48)\n return new MlInt64 (\n (this.mi >> (s - 24)) | (this.hi << (48 - s)),\n (this.hi >> (s - 24)),\n 0);\n return new MlInt64 (this.hi >> (s - 48), 0, 0);\n}\nMlInt64.prototype.shift_right = function (s) {\n s = s & 63;\n if (s == 0) return this;\n var h = (this.hi << 16) >> 16;\n if (s < 24)\n return new MlInt64 (\n (this.lo >> s) | (this.mi << (24 - s)),\n (this.mi >> s) | (h << (24 - s)),\n ((this.hi << 16) >> s) >>> 16);\n var sign = (this.hi << 16) >> 31;\n if (s < 48)\n return new MlInt64 (\n (this.mi >> (s - 24)) | (this.hi << (48 - s)),\n (this.hi << 16) >> (s - 24) >> 16,\n sign & 0xffff);\n return new MlInt64 ((this.hi << 16) >> (s - 32), sign, sign);\n}\nMlInt64.prototype.lsl1 = function () {\n this.hi = (this.hi << 1) | (this.mi >> 23);\n this.mi = ((this.mi << 1) | (this.lo >> 23)) & 0xffffff;\n this.lo = (this.lo << 1) & 0xffffff;\n}\nMlInt64.prototype.lsr1 = function () {\n this.lo = ((this.lo >>> 1) | (this.mi << 23)) & 0xffffff;\n this.mi = ((this.mi >>> 1) | (this.hi << 23)) & 0xffffff;\n this.hi = this.hi >>> 1;\n}\nMlInt64.prototype.udivmod = function (x) {\n var offset = 0;\n var modulus = this.copy();\n var divisor = x.copy();\n var quotient = new MlInt64(0,0,0);\n while (modulus.ucompare(divisor) > 0) {\n offset++;\n divisor.lsl1();\n }\n while (offset >= 0) {\n offset --;\n quotient.lsl1();\n if (modulus.ucompare(divisor) >= 0) {\n quotient.lo ++;\n modulus = modulus.sub(divisor);\n }\n divisor.lsr1();\n }\n return { quotient : quotient, modulus : modulus };\n}\nMlInt64.prototype.div = function (y)\n{\n var x = this;\n if (y.isZero()) caml_raise_zero_divide ();\n var sign = x.hi ^ y.hi;\n if (x.hi & 0x8000) x = x.neg();\n if (y.hi & 0x8000) y = y.neg();\n var q = x.udivmod(y).quotient;\n if (sign & 0x8000) q = q.neg();\n return q;\n}\nMlInt64.prototype.mod = function (y)\n{\n var x = this;\n if (y.isZero()) caml_raise_zero_divide ();\n var sign = x.hi;\n if (x.hi & 0x8000) x = x.neg();\n if (y.hi & 0x8000) y = y.neg();\n var r = x.udivmod(y).modulus;\n if (sign & 0x8000) r = r.neg();\n return r;\n}\nMlInt64.prototype.toInt = function () {\n return this.lo | (this.mi << 24);\n}\nMlInt64.prototype.toFloat = function () {\n return ((this.hi << 16) * Math.pow(2, 32) + this.mi * Math.pow(2, 24)) + this.lo;\n}\nMlInt64.prototype.toArray = function () {\n return [this.hi >> 8,\n this.hi & 0xff,\n this.mi >> 16,\n (this.mi >> 8) & 0xff,\n this.mi & 0xff,\n this.lo >> 16,\n (this.lo >> 8) & 0xff,\n this.lo & 0xff];\n}\nMlInt64.prototype.lo32 = function () {\n return this.lo | ((this.mi & 0xff) << 24);\n}\nMlInt64.prototype.hi32 = function () {\n return ((this.mi >>> 8) & 0xffff) | (this.hi << 16);\n}\n\n//Provides: caml_int64_ult const\nfunction caml_int64_ult(x,y) { return x.ucompare(y) < 0; }\n\n//Provides: caml_int64_compare const\nfunction caml_int64_compare(x,y, total) { return x.compare(y) }\n\n//Provides: caml_int64_neg const\nfunction caml_int64_neg (x) { return x.neg() }\n\n//Provides: caml_int64_add const\nfunction caml_int64_add (x, y) { return x.add(y) }\n\n//Provides: caml_int64_sub const\nfunction caml_int64_sub (x, y) { return x.sub(y) }\n\n//Provides: caml_int64_mul const\n//Requires: caml_int64_offset\nfunction caml_int64_mul(x,y) { return x.mul(y) }\n\n//Provides: caml_int64_is_zero const\nfunction caml_int64_is_zero(x) { return +x.isZero(); }\n\n//Provides: caml_int64_is_negative const\nfunction caml_int64_is_negative(x) { return +x.isNeg(); }\n\n//Provides: caml_int64_and const\nfunction caml_int64_and (x, y) { return x.and(y); }\n\n//Provides: caml_int64_or const\nfunction caml_int64_or (x, y) { return x.or(y); }\n\n//Provides: caml_int64_xor const\nfunction caml_int64_xor (x, y) { return x.xor(y) }\n\n//Provides: caml_int64_shift_left const\nfunction caml_int64_shift_left (x, s) { return x.shift_left(s) }\n\n//Provides: caml_int64_shift_right_unsigned const\nfunction caml_int64_shift_right_unsigned (x, s) { return x.shift_right_unsigned(s) }\n\n//Provides: caml_int64_shift_right const\nfunction caml_int64_shift_right (x, s) { return x.shift_right(s) }\n\n//Provides: caml_int64_div const\nfunction caml_int64_div (x, y) { return x.div(y) }\n\n//Provides: caml_int64_mod const\nfunction caml_int64_mod (x, y) { return x.mod(y) }\n\n//Provides: caml_int64_of_int32 const\n//Requires: MlInt64\nfunction caml_int64_of_int32 (x) {\n return new MlInt64(x & 0xffffff, (x >> 24) & 0xffffff, (x >> 31) & 0xffff)\n}\n\n//Provides: caml_int64_to_int32 const\nfunction caml_int64_to_int32 (x) { return x.toInt() }\n\n//Provides: caml_int64_to_float const\nfunction caml_int64_to_float (x) { return x.toFloat () }\n\n//Provides: caml_int64_of_float const\n//Requires: caml_int64_offset, MlInt64\nfunction caml_int64_of_float (x) {\n if (x < 0) x = Math.ceil(x);\n return new MlInt64(\n x & 0xffffff,\n Math.floor(x * caml_int64_offset) & 0xffffff,\n Math.floor(x * caml_int64_offset * caml_int64_offset) & 0xffff);\n}\n\n//Provides: caml_int64_format const\n//Requires: caml_parse_format, caml_finish_formatting\n//Requires: caml_int64_is_negative, caml_int64_neg\n//Requires: caml_int64_of_int32, caml_int64_to_int32\n//Requires: caml_int64_is_zero, caml_str_repeat\nfunction caml_int64_format (fmt, x) {\n var f = caml_parse_format(fmt);\n if (f.signedconv && caml_int64_is_negative(x)) {\n f.sign = -1; x = caml_int64_neg(x);\n }\n var buffer = \"\";\n var wbase = caml_int64_of_int32(f.base);\n var cvtbl = \"0123456789abcdef\";\n do {\n var p = x.udivmod(wbase);\n x = p.quotient;\n buffer = cvtbl.charAt(caml_int64_to_int32(p.modulus)) + buffer;\n } while (! caml_int64_is_zero(x));\n if (f.prec >= 0) {\n f.filler = ' ';\n var n = f.prec - buffer.length;\n if (n > 0) buffer = caml_str_repeat (n, '0') + buffer;\n }\n return caml_finish_formatting(f, buffer);\n}\n\n//Provides: caml_int64_of_string\n//Requires: caml_parse_sign_and_base, caml_failwith, caml_parse_digit\n//Requires: caml_int64_of_int32, caml_int64_ult\n//Requires: caml_int64_add, caml_int64_mul, caml_int64_neg\n//Requires: caml_ml_string_length,caml_string_unsafe_get, MlInt64\nfunction caml_int64_of_string(s) {\n var r = caml_parse_sign_and_base (s);\n var i = r[0], sign = r[1], base = r[2];\n var base64 = caml_int64_of_int32(base);\n var threshold =\n new MlInt64(0xffffff, 0xfffffff, 0xffff).udivmod(base64).quotient;\n var c = caml_string_unsafe_get(s, i);\n var d = caml_parse_digit(c);\n if (d < 0 || d >= base) caml_failwith(\"int_of_string\");\n var res = caml_int64_of_int32(d);\n for (;;) {\n i++;\n c = caml_string_unsafe_get(s, i);\n if (c == 95) continue;\n d = caml_parse_digit(c);\n if (d < 0 || d >= base) break;\n /* Detect overflow in multiplication base * res */\n if (caml_int64_ult(threshold, res)) caml_failwith(\"int_of_string\");\n d = caml_int64_of_int32(d);\n res = caml_int64_add(caml_int64_mul(base64, res), d);\n /* Detect overflow in addition (base * res) + d */\n if (caml_int64_ult(res, d)) caml_failwith(\"int_of_string\");\n }\n if (i != caml_ml_string_length(s)) caml_failwith(\"int_of_string\");\n if (base == 10 && caml_int64_ult(new MlInt64(0, 0, 0x8000), res))\n caml_failwith(\"int_of_string\");\n if (sign < 0) res = caml_int64_neg(res);\n return res;\n}\n\n//Provides: caml_int64_create_lo_mi_hi const\n//Requires: MlInt64\nfunction caml_int64_create_lo_mi_hi(lo, mi, hi){\n return new MlInt64(lo, mi, hi)\n}\n//Provides: caml_int64_create_lo_hi const\n//Requires: MlInt64\nfunction caml_int64_create_lo_hi(lo, hi){\n return new MlInt64 (\n lo & 0xffffff,\n ((lo >>> 24) & 0xff) | ((hi & 0xffff) << 8),\n (hi >>> 16) & 0xffff);\n}\n//Provides: caml_int64_lo32 const\nfunction caml_int64_lo32(v){ return v.lo32() }\n\n//Provides: caml_int64_hi32 const\nfunction caml_int64_hi32(v){ return v.hi32() }\n\n//Provides: caml_int64_of_bytes const\n//Requires: MlInt64\nfunction caml_int64_of_bytes(a) {\n return new MlInt64(a[7] << 0 | (a[6] << 8) | (a[5] << 16),\n a[4] << 0 | (a[3] << 8) | (a[2] << 16),\n a[1] << 0 | (a[0] << 8));\n}\n//Provides: caml_int64_to_bytes const\nfunction caml_int64_to_bytes(x) { return x.toArray() }\n\n//Provides: caml_int64_hash const\nfunction caml_int64_hash(v){\n return (v.lo32()) ^ (v.hi32())\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Raise exception\n\n//Provides: caml_raise_constant (const)\nfunction caml_raise_constant (tag) { throw tag; }\n\n//Provides: caml_return_exn_constant (const)\nfunction caml_return_exn_constant (tag) { return tag; }\n\n//Provides: caml_raise_with_arg (const, const)\nfunction caml_raise_with_arg (tag, arg) { throw [0, tag, arg]; }\n\n//Provides: caml_raise_with_args (const, const)\nfunction caml_raise_with_args (tag, args) { throw [0, tag].concat(args); }\n\n//Provides: caml_raise_with_string (const, const)\n//Requires: caml_raise_with_arg, caml_string_of_jsbytes\nfunction caml_raise_with_string (tag, msg) {\n caml_raise_with_arg (tag, caml_string_of_jsbytes(msg));\n}\n\n//Provides: caml_failwith (const)\n//Requires: caml_raise_with_string, caml_global_data, caml_string_of_jsbytes\nfunction caml_failwith (msg) {\n if(!caml_global_data.Failure)\n caml_global_data.Failure=[248,caml_string_of_jsbytes(\"Failure\"),-3];\n caml_raise_with_string(caml_global_data.Failure, msg);\n}\n\n\n//Provides: caml_invalid_argument (const)\n//Requires: caml_raise_with_string, caml_global_data\nfunction caml_invalid_argument (msg) {\n caml_raise_with_string(caml_global_data.Invalid_argument, msg);\n}\n\n//Provides: caml_raise_end_of_file\n//Requires: caml_raise_constant, caml_global_data\nfunction caml_raise_end_of_file () {\n caml_raise_constant(caml_global_data.End_of_file);\n}\n\n//Provides: caml_raise_zero_divide\n//Requires: caml_raise_constant, caml_global_data\nfunction caml_raise_zero_divide () {\n caml_raise_constant(caml_global_data.Division_by_zero);\n}\n\n//Provides: caml_raise_not_found\n//Requires: caml_raise_constant, caml_global_data\nfunction caml_raise_not_found () {\n caml_raise_constant(caml_global_data.Not_found); }\n\n\n//Provides: caml_array_bound_error\n//Requires: caml_invalid_argument\nfunction caml_array_bound_error () {\n caml_invalid_argument(\"index out of bounds\");\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_call_gen (const, shallow)\n//Weakdef\nfunction caml_call_gen(f, args) {\n if(f.fun)\n return caml_call_gen(f.fun, args);\n //FIXME, can happen with too many arguments\n if(typeof f !== \"function\") return f;\n var n = f.length | 0;\n if(n === 0) return f.apply(null,args);\n var argsLen = args.length | 0;\n var d = n - argsLen | 0;\n if (d == 0)\n return f.apply(null, args);\n else if (d < 0) {\n return caml_call_gen(f.apply(null,args.slice(0,n)),args.slice(n));\n }\n else {\n return function (){\n var extra_args = (arguments.length == 0)?1:arguments.length;\n var nargs = new Array(args.length+extra_args);\n for(var i = 0; i < args.length; i++ ) nargs[i] = args[i];\n for(var i = 0; i < arguments.length; i++ ) nargs[args.length+i] = arguments[i];\n return caml_call_gen(f, nargs)\n }\n }\n}\n\n//Provides: caml_named_values\nvar caml_named_values = {};\n\n//Provides: caml_register_named_value (const,const)\n//Requires: caml_named_values, caml_jsbytes_of_string\nfunction caml_register_named_value(nm,v) {\n caml_named_values[caml_jsbytes_of_string(nm)] = v;\n return 0;\n}\n\n//Provides: caml_named_value\n//Requires: caml_named_values\nfunction caml_named_value(nm) {\n return caml_named_values[nm]\n}\n\n//Provides: caml_global_data\nvar caml_global_data = [0];\n\n//Provides: caml_register_global (const, shallow, const)\n//Requires: caml_global_data\nfunction caml_register_global (n, v, name_opt) {\n if(name_opt && globalThis.toplevelReloc)\n n = globalThis.toplevelReloc(name_opt);\n caml_global_data[n + 1] = v;\n if(name_opt) caml_global_data[name_opt] = v;\n}\n\n//Provides: caml_get_global_data mutable\n//Requires: caml_global_data\nfunction caml_get_global_data () { return caml_global_data; }\n\n//Provides: caml_is_printable const (const)\nfunction caml_is_printable(c) { return +(c > 31 && c < 127); }\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010-2014 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n// An OCaml string is an object with three fields:\n// - tag 't'\n// - length 'l'\n// - contents 'c'\n//\n// The contents of the string can be either a JavaScript array or\n// a JavaScript string. The length of this string can be less than the\n// length of the OCaml string. In this case, remaining bytes are\n// assumed to be zeroes. Arrays are mutable but consumes more memory\n// than strings. A common pattern is to start from an empty string and\n// progressively fill it from the start. Partial strings makes it\n// possible to implement this efficiently.\n//\n// When converting to and from UTF-16, we keep track of whether the\n// string is composed only of ASCII characters (in which case, no\n// conversion needs to be performed) or not.\n//\n// The string tag can thus take the following values:\n// full string BYTE | UNKNOWN: 0\n// BYTE | ASCII: 9\n// BYTE | NOT_ASCII: 8\n// string prefix PARTIAL: 2\n// array ARRAY: 4\n//\n// One can use bit masking to discriminate these different cases:\n// known_encoding(x) = x&8\n// is_ascii(x) = x&1\n// kind(x) = x&6\n\n//Provides: caml_str_repeat\nfunction caml_str_repeat(n, s) {\n if(n == 0) return \"\";\n if (s.repeat) {return s.repeat(n);} // ECMAscript 6 and Firefox 24+\n var r = \"\", l = 0;\n for(;;) {\n if (n & 1) r += s;\n n >>= 1;\n if (n == 0) return r;\n s += s;\n l++;\n if (l == 9) {\n s.slice(0,1); // flatten the string\n // then, the flattening of the whole string will be faster,\n // as it will be composed of larger pieces\n }\n }\n}\n\n//Provides: caml_subarray_to_jsbytes\n//Weakdef\n// Pre ECMAScript 5, [apply] would not support array-like object.\n// In such setup, Typed_array would be implemented as polyfill, and [f.apply] would\n// fail here. Mark the primitive as Weakdef, so that people can override it easily.\nfunction caml_subarray_to_jsbytes (a, i, len) {\n var f = String.fromCharCode;\n if (i == 0 && len <= 4096 && len == a.length) return f.apply (null, a);\n var s = \"\";\n for (; 0 < len; i += 1024,len-=1024)\n s += f.apply (null, a.slice(i,i + Math.min(len, 1024)));\n return s;\n}\n\n//Provides: caml_utf8_of_utf16\nfunction caml_utf8_of_utf16(s) {\n for (var b = \"\", t = b, c, d, i = 0, l = s.length; i < l; i++) {\n c = s.charCodeAt(i);\n if (c < 0x80) {\n for (var j = i + 1; (j < l) && (c = s.charCodeAt(j)) < 0x80; j++);\n if (j - i > 512) { t.substr(0, 1); b += t; t = \"\"; b += s.slice(i, j) }\n else t += s.slice(i, j);\n if (j == l) break;\n i = j;\n }\n if (c < 0x800) {\n t += String.fromCharCode(0xc0 | (c >> 6));\n t += String.fromCharCode(0x80 | (c & 0x3f));\n } else if (c < 0xd800 || c >= 0xdfff) {\n t += String.fromCharCode(0xe0 | (c >> 12),\n 0x80 | ((c >> 6) & 0x3f),\n 0x80 | (c & 0x3f));\n } else if (c >= 0xdbff || i + 1 == l ||\n (d = s.charCodeAt(i + 1)) < 0xdc00 || d > 0xdfff) {\n // Unmatched surrogate pair, replaced by \\ufffd (replacement character)\n t += \"\\xef\\xbf\\xbd\";\n } else {\n i++;\n c = (c << 10) + d - 0x35fdc00;\n t += String.fromCharCode(0xf0 | (c >> 18),\n 0x80 | ((c >> 12) & 0x3f),\n 0x80 | ((c >> 6) & 0x3f),\n 0x80 | (c & 0x3f));\n }\n if (t.length > 1024) {t.substr(0, 1); b += t; t = \"\";}\n }\n return b+t;\n}\n\n//Provides: caml_utf16_of_utf8\nfunction caml_utf16_of_utf8(s) {\n for (var b = \"\", t = \"\", c, c1, c2, v, i = 0, l = s.length; i < l; i++) {\n c1 = s.charCodeAt(i);\n if (c1 < 0x80) {\n for (var j = i + 1; (j < l) && (c1 = s.charCodeAt(j)) < 0x80; j++);\n if (j - i > 512) { t.substr(0, 1); b += t; t = \"\"; b += s.slice(i, j) }\n else t += s.slice(i, j);\n if (j == l) break;\n i = j;\n }\n v = 1;\n if ((++i < l) && (((c2 = s.charCodeAt(i)) & -64) == 128)) {\n c = c2 + (c1 << 6);\n if (c1 < 0xe0) {\n v = c - 0x3080;\n if (v < 0x80) v = 1;\n } else {\n v = 2;\n if ((++i < l) && (((c2 = s.charCodeAt(i)) & -64) == 128)) {\n c = c2 + (c << 6);\n if (c1 < 0xf0) {\n v = c - 0xe2080;\n if ((v < 0x800) || ((v >= 0xd7ff) && (v < 0xe000))) v = 2;\n } else {\n v = 3;\n if ((++i < l) && (((c2 = s.charCodeAt(i)) & -64) == 128) &&\n (c1 < 0xf5)) {\n v = c2 - 0x3c82080 + (c << 6);\n if (v < 0x10000 || v > 0x10ffff) v = 3;\n }\n }\n }\n }\n }\n if (v < 4) { // Invalid sequence\n i -= v;\n t += \"\\ufffd\";\n } else if (v > 0xffff)\n t += String.fromCharCode(0xd7c0 + (v >> 10), 0xdc00 + (v & 0x3FF))\n else\n t += String.fromCharCode(v);\n if (t.length > 1024) {t.substr(0, 1); b += t; t = \"\";}\n }\n return b+t;\n}\n\n//Provides: jsoo_is_ascii\nfunction jsoo_is_ascii (s) {\n // The regular expression gets better at around this point for all browsers\n if (s.length < 24) {\n // Spidermonkey gets much slower when s.length >= 24 (on 64 bit archs)\n for (var i = 0; i < s.length; i++) if (s.charCodeAt(i) > 127) return false;\n return true;\n } else\n return !/[^\\x00-\\x7f]/.test(s);\n}\n\n//Provides: caml_bytes_unsafe_get mutable\nfunction caml_bytes_unsafe_get (s, i) {\n switch (s.t & 6) {\n default: /* PARTIAL */\n if (i >= s.c.length) return 0;\n case 0: /* BYTES */\n return s.c.charCodeAt(i);\n case 4: /* ARRAY */\n return s.c[i]\n }\n}\n\n//Provides: caml_bytes_unsafe_set\n//Requires: caml_convert_bytes_to_array\nfunction caml_bytes_unsafe_set (s, i, c) {\n // The OCaml compiler uses Char.unsafe_chr on integers larger than 255!\n c &= 0xff;\n if (s.t != 4 /* ARRAY */) {\n if (i == s.c.length) {\n s.c += String.fromCharCode (c);\n if (i + 1 == s.l) s.t = 0; /*BYTES | UNKOWN*/\n return 0;\n }\n caml_convert_bytes_to_array (s);\n }\n s.c[i] = c;\n return 0;\n}\n\n//Provides: caml_string_bound_error\n//Requires: caml_invalid_argument\nfunction caml_string_bound_error () {\n caml_invalid_argument (\"index out of bounds\");\n}\n\n//Provides: caml_bytes_bound_error\n//Requires: caml_invalid_argument\nfunction caml_bytes_bound_error () {\n caml_invalid_argument (\"index out of bounds\");\n}\n\n//Provides: caml_string_get\n//Requires: caml_string_bound_error, caml_string_unsafe_get\n//Requires: caml_ml_string_length\nfunction caml_string_get (s, i) {\n if (i >>> 0 >= caml_ml_string_length(s)) caml_string_bound_error();\n return caml_string_unsafe_get (s, i);\n}\n\n//Provides: caml_string_get16\n//Requires: caml_string_unsafe_get, caml_string_bound_error\n//Requires: caml_ml_string_length\nfunction caml_string_get16(s,i) {\n if (i >>> 0 >= caml_ml_string_length(s) - 1) caml_string_bound_error();\n var b1 = caml_string_unsafe_get (s, i),\n b2 = caml_string_unsafe_get (s, i + 1);\n return (b2 << 8 | b1);\n}\n\n//Provides: caml_bytes_get16\n//Requires: caml_bytes_unsafe_get, caml_bytes_bound_error\nfunction caml_bytes_get16(s,i) {\n if (i >>> 0 >= s.l - 1) caml_bytes_bound_error();\n var b1 = caml_bytes_unsafe_get (s, i),\n b2 = caml_bytes_unsafe_get (s, i + 1);\n return (b2 << 8 | b1);\n}\n\n//Provides: caml_string_get32\n//Requires: caml_string_unsafe_get, caml_string_bound_error\n//Requires: caml_ml_string_length\nfunction caml_string_get32(s,i) {\n if (i >>> 0 >= caml_ml_string_length(s) - 3) caml_string_bound_error();\n var b1 = caml_string_unsafe_get (s, i),\n b2 = caml_string_unsafe_get (s, i + 1),\n b3 = caml_string_unsafe_get (s, i + 2),\n b4 = caml_string_unsafe_get (s, i + 3);\n return (b4 << 24 | b3 << 16 | b2 << 8 | b1);\n}\n\n//Provides: caml_bytes_get32\n//Requires: caml_bytes_unsafe_get, caml_bytes_bound_error\nfunction caml_bytes_get32(s,i) {\n if (i >>> 0 >= s.l - 3) caml_bytes_bound_error();\n var b1 = caml_bytes_unsafe_get (s, i),\n b2 = caml_bytes_unsafe_get (s, i + 1),\n b3 = caml_bytes_unsafe_get (s, i + 2),\n b4 = caml_bytes_unsafe_get (s, i + 3);\n return (b4 << 24 | b3 << 16 | b2 << 8 | b1);\n}\n\n//Provides: caml_string_get64\n//Requires: caml_string_unsafe_get, caml_string_bound_error\n//Requires: caml_int64_of_bytes\n//Requires: caml_ml_string_length\nfunction caml_string_get64(s,i) {\n if (i >>> 0 >= caml_ml_string_length(s) - 7) caml_string_bound_error();\n var a = new Array(8);\n for(var j = 0; j < 8; j++){\n a[7 - j] = caml_string_unsafe_get (s, i + j);\n }\n return caml_int64_of_bytes(a);\n}\n\n//Provides: caml_bytes_get64\n//Requires: caml_bytes_unsafe_get, caml_bytes_bound_error\n//Requires: caml_int64_of_bytes\nfunction caml_bytes_get64(s,i) {\n if (i >>> 0 >= s.l - 7) caml_bytes_bound_error();\n var a = new Array(8);\n for(var j = 0; j < 8; j++){\n a[7 - j] = caml_bytes_unsafe_get (s, i + j);\n }\n return caml_int64_of_bytes(a);\n}\n\n//Provides: caml_bytes_get\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_get\nfunction caml_bytes_get (s, i) {\n if (i >>> 0 >= s.l) caml_bytes_bound_error();\n return caml_bytes_unsafe_get (s, i);\n}\n\n//Provides: caml_string_set\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set (s, i, c) {\n caml_failwith(\"caml_string_set\");\n}\n\n//Provides: caml_string_set\n//Requires: caml_string_unsafe_set, caml_string_bound_error\n//If: !js-string\nfunction caml_string_set (s, i, c) {\n if (i >>> 0 >= s.l) caml_string_bound_error();\n return caml_string_unsafe_set (s, i, c);\n}\n\n//Provides: caml_bytes_set16\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\nfunction caml_bytes_set16(s,i,i16){\n if (i >>> 0 >= s.l - 1) caml_bytes_bound_error();\n var b2 = 0xFF & i16 >> 8,\n b1 = 0xFF & i16;\n caml_bytes_unsafe_set (s, i + 0, b1);\n caml_bytes_unsafe_set (s, i + 1, b2);\n return 0\n}\n\n//Provides: caml_string_set16\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set16(s,i,i16){\n caml_failwith(\"caml_string_set16\");\n}\n\n//Provides: caml_string_set16\n//Requires: caml_bytes_set16\n//If: !js-string\nfunction caml_string_set16(s,i,i16){\n return caml_bytes_set16(s,i,i16);\n}\n\n//Provides: caml_bytes_set32\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\nfunction caml_bytes_set32(s,i,i32){\n if (i >>> 0 >= s.l - 3) caml_bytes_bound_error();\n var b4 = 0xFF & i32 >> 24,\n b3 = 0xFF & i32 >> 16,\n b2 = 0xFF & i32 >> 8,\n b1 = 0xFF & i32;\n caml_bytes_unsafe_set (s, i + 0, b1);\n caml_bytes_unsafe_set (s, i + 1, b2);\n caml_bytes_unsafe_set (s, i + 2, b3);\n caml_bytes_unsafe_set (s, i + 3, b4);\n return 0\n}\n\n//Provides: caml_string_set32\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set32(s,i,i32){\n caml_failwith(\"caml_string_set32\");\n}\n\n//Provides: caml_string_set32\n//Requires: caml_bytes_set32\n//If: !js-string\nfunction caml_string_set32(s,i,i32){\n return caml_bytes_set32(s,i,i32);\n}\n\n//Provides: caml_bytes_set64\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\n//Requires: caml_int64_to_bytes\nfunction caml_bytes_set64(s,i,i64){\n if (i >>> 0 >= s.l - 7) caml_bytes_bound_error();\n var a = caml_int64_to_bytes(i64);\n for(var j = 0; j < 8; j++) {\n caml_bytes_unsafe_set (s, i + 7 - j, a[j]);\n }\n return 0\n}\n\n//Provides: caml_string_set64\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set64(s,i,i64){\n caml_failwith(\"caml_string_set64\");\n}\n\n//Provides: caml_string_set64\n//Requires: caml_bytes_set64\n//If: !js-string\nfunction caml_string_set64(s,i,i64){\n return caml_bytes_set64(s,i,i64);\n}\n\n//Provides: caml_bytes_set\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\nfunction caml_bytes_set (s, i, c) {\n if (i >>> 0 >= s.l) caml_bytes_bound_error();\n return caml_bytes_unsafe_set (s, i, c);\n}\n\n//Provides: caml_bytes_of_utf16_jsstring\n//Requires: jsoo_is_ascii, caml_utf8_of_utf16, MlBytes\nfunction caml_bytes_of_utf16_jsstring (s) {\n var tag = 9 /* BYTES | ASCII */;\n if (!jsoo_is_ascii(s))\n tag = 8 /* BYTES | NOT_ASCII */, s = caml_utf8_of_utf16(s);\n return new MlBytes(tag, s, s.length);\n}\n\n\n//Provides: MlBytes\n//Requires: caml_convert_string_to_bytes, jsoo_is_ascii, caml_utf16_of_utf8\nfunction MlBytes (tag, contents, length) {\n this.t=tag; this.c=contents; this.l=length;\n}\nMlBytes.prototype.toString = function(){\n switch (this.t) {\n case 9: /*BYTES | ASCII*/\n return this.c;\n default:\n caml_convert_string_to_bytes(this);\n case 0: /*BYTES | UNKOWN*/\n if (jsoo_is_ascii(this.c)) {\n this.t = 9; /*BYTES | ASCII*/\n return this.c;\n }\n this.t = 8; /*BYTES | NOT_ASCII*/\n case 8: /*BYTES | NOT_ASCII*/\n return this.c;\n }\n};\nMlBytes.prototype.toUtf16 = function (){\n var r = this.toString();\n if(this.t == 9) return r\n return caml_utf16_of_utf8(r);\n}\nMlBytes.prototype.slice = function (){\n var content = this.t == 4 ? this.c.slice() : this.c;\n return new MlBytes(this.t,content,this.l);\n}\n\n//Provides: caml_convert_string_to_bytes\n//Requires: caml_str_repeat, caml_subarray_to_jsbytes\nfunction caml_convert_string_to_bytes (s) {\n /* Assumes not BYTES */\n if (s.t == 2 /* PARTIAL */)\n s.c += caml_str_repeat(s.l - s.c.length, '\\0')\n else\n s.c = caml_subarray_to_jsbytes (s.c, 0, s.c.length);\n s.t = 0; /*BYTES | UNKOWN*/\n}\n\n//Provides: caml_convert_bytes_to_array\nfunction caml_convert_bytes_to_array (s) {\n /* Assumes not ARRAY */\n if(globalThis.Uint8Array) {\n var a = new globalThis.Uint8Array(s.l);\n } else {\n var a = new Array(s.l);\n }\n var b = s.c, l = b.length, i = 0;\n for (; i < l; i++) a[i] = b.charCodeAt(i);\n for (l = s.l; i < l; i++) a[i] = 0;\n s.c = a;\n s.t = 4; /* ARRAY */\n return a;\n}\n\n//Provides: caml_array_of_bytes mutable\n//Requires: caml_convert_bytes_to_array\nfunction caml_array_of_bytes (s) {\n if (s.t != 4 /* ARRAY */) caml_convert_bytes_to_array(s);\n return s.c;\n}\n\n//Provides: caml_array_of_string mutable\n//Requires: caml_convert_bytes_to_array\n//Requires: caml_ml_string_length, caml_string_unsafe_get\nfunction caml_array_of_string (s) {\n var l = caml_ml_string_length(s);\n var a = new Array(l);\n var i = 0;\n for (; i < l; i++) a[i] = caml_string_unsafe_get(s,i);\n return a;\n}\n\n//Provides: caml_create_string const\n//Requires: MlBytes, caml_invalid_argument\n//If: !js-string\nfunction caml_create_string(len) {\n if(len < 0) caml_invalid_argument(\"String.create\");\n return new MlBytes(len?2:9,\"\",len);\n}\n\n//Provides: caml_create_string const\n//Requires: caml_invalid_argument\n//If: js-string\nfunction caml_create_string(len) {\n caml_invalid_argument(\"String.create\");\n}\n\n//Provides: caml_create_bytes const\n//Requires: MlBytes,caml_invalid_argument\nfunction caml_create_bytes(len) {\n if (len < 0) caml_invalid_argument(\"Bytes.create\");\n return new MlBytes(len?2:9,\"\",len);\n}\n\n//Provides: caml_string_of_array\n//Requires: caml_subarray_to_jsbytes, caml_string_of_jsbytes\nfunction caml_string_of_array (a) {\n return caml_string_of_jsbytes(caml_subarray_to_jsbytes(a,0,a.length));\n}\n\n//Provides: caml_bytes_of_array\n//Requires: MlBytes\nfunction caml_bytes_of_array (a) {\n return new MlBytes(4,a,a.length);\n}\n\n//Provides: caml_bytes_compare mutable\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_compare(s1, s2) {\n (s1.t & 6) && caml_convert_string_to_bytes(s1);\n (s2.t & 6) && caml_convert_string_to_bytes(s2);\n return (s1.c < s2.c)?-1:(s1.c > s2.c)?1:0;\n}\n\n\n//Provides: caml_bytes_equal mutable (const, const)\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_equal(s1, s2) {\n if(s1 === s2) return 1;\n (s1.t & 6) && caml_convert_string_to_bytes(s1);\n (s2.t & 6) && caml_convert_string_to_bytes(s2);\n return (s1.c == s2.c)?1:0;\n}\n\n//Provides: caml_string_notequal mutable (const, const)\n//Requires: caml_string_equal\nfunction caml_string_notequal(s1, s2) { return 1-caml_string_equal(s1, s2); }\n\n//Provides: caml_bytes_notequal mutable (const, const)\n//Requires: caml_bytes_equal\nfunction caml_bytes_notequal(s1, s2) { return 1-caml_bytes_equal(s1, s2); }\n\n//Provides: caml_bytes_lessequal mutable\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_lessequal(s1, s2) {\n (s1.t & 6) && caml_convert_string_to_bytes(s1);\n (s2.t & 6) && caml_convert_string_to_bytes(s2);\n return (s1.c <= s2.c)?1:0;\n}\n\n//Provides: caml_bytes_lessthan mutable\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_lessthan(s1, s2) {\n (s1.t & 6) && caml_convert_string_to_bytes(s1);\n (s2.t & 6) && caml_convert_string_to_bytes(s2);\n return (s1.c < s2.c)?1:0;\n}\n\n//Provides: caml_string_greaterequal\n//Requires: caml_string_lessequal\nfunction caml_string_greaterequal(s1, s2) {\n return caml_string_lessequal(s2,s1);\n}\n//Provides: caml_bytes_greaterequal\n//Requires: caml_bytes_lessequal\nfunction caml_bytes_greaterequal(s1, s2) {\n return caml_bytes_lessequal(s2,s1);\n}\n\n//Provides: caml_string_greaterthan\n//Requires: caml_string_lessthan\nfunction caml_string_greaterthan(s1, s2) {\n return caml_string_lessthan(s2, s1);\n}\n\n//Provides: caml_bytes_greaterthan\n//Requires: caml_bytes_lessthan\nfunction caml_bytes_greaterthan(s1, s2) {\n return caml_bytes_lessthan(s2, s1);\n}\n\n//Provides: caml_fill_bytes\n//Requires: caml_str_repeat, caml_convert_bytes_to_array\nfunction caml_fill_bytes(s, i, l, c) {\n if (l > 0) {\n if (i == 0 && (l >= s.l || (s.t == 2 /* PARTIAL */ && l >= s.c.length))) {\n if (c == 0) {\n s.c = \"\";\n s.t = 2; /* PARTIAL */\n } else {\n s.c = caml_str_repeat (l, String.fromCharCode(c));\n s.t = (l == s.l)?0 /* BYTES | UNKOWN */ :2; /* PARTIAL */\n }\n } else {\n if (s.t != 4 /* ARRAY */) caml_convert_bytes_to_array(s);\n for (l += i; i < l; i++) s.c[i] = c;\n }\n }\n return 0;\n}\n\n//Provides: caml_fill_string\n//Requires: caml_fill_bytes\nvar caml_fill_string = caml_fill_bytes\n\n//Provides: caml_blit_bytes\n//Requires: caml_subarray_to_jsbytes, caml_convert_bytes_to_array\nfunction caml_blit_bytes(s1, i1, s2, i2, len) {\n if (len == 0) return 0;\n if ((i2 == 0) &&\n (len >= s2.l || (s2.t == 2 /* PARTIAL */ && len >= s2.c.length))) {\n s2.c = (s1.t == 4 /* ARRAY */)?\n caml_subarray_to_jsbytes(s1.c, i1, len):\n (i1 == 0 && s1.c.length == len)?s1.c:s1.c.substr(i1, len);\n s2.t = (s2.c.length == s2.l)?0 /* BYTES | UNKOWN */ :2; /* PARTIAL */\n } else if (s2.t == 2 /* PARTIAL */ && i2 == s2.c.length) {\n s2.c += (s1.t == 4 /* ARRAY */)?\n caml_subarray_to_jsbytes(s1.c, i1, len):\n (i1 == 0 && s1.c.length == len)?s1.c:s1.c.substr(i1, len);\n s2.t = (s2.c.length == s2.l)?0 /* BYTES | UNKOWN */ :2; /* PARTIAL */\n } else {\n if (s2.t != 4 /* ARRAY */) caml_convert_bytes_to_array(s2);\n var c1 = s1.c, c2 = s2.c;\n if (s1.t == 4 /* ARRAY */) {\n if (i2 <= i1) {\n for (var i = 0; i < len; i++) c2 [i2 + i] = c1 [i1 + i];\n } else {\n for (var i = len - 1; i >= 0; i--) c2 [i2 + i] = c1 [i1 + i];\n }\n } else {\n var l = Math.min (len, c1.length - i1);\n for (var i = 0; i < l; i++) c2 [i2 + i] = c1.charCodeAt(i1 + i);\n for (; i < len; i++) c2 [i2 + i] = 0;\n }\n }\n return 0;\n}\n\n//Provides: caml_blit_string\n//Requires: caml_blit_bytes, caml_bytes_of_string\nfunction caml_blit_string(a,b,c,d,e) {\n caml_blit_bytes(caml_bytes_of_string(a),b,c,d,e);\n return 0\n}\n\n//Provides: caml_ml_bytes_length const\nfunction caml_ml_bytes_length(s) { return s.l }\n\n//Provides: caml_string_unsafe_get const\n//If: js-string\nfunction caml_string_unsafe_get (s, i) {\n return s.charCodeAt(i);\n}\n\n//Provides: caml_string_unsafe_set\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_unsafe_set (s, i, c) {\n caml_failwith(\"caml_string_unsafe_set\");\n}\n\n//Provides: caml_ml_string_length const\n//If: js-string\nfunction caml_ml_string_length(s) {\n return s.length\n}\n\n//Provides: caml_string_compare const\n//If: js-string\nfunction caml_string_compare(s1, s2) {\n return (s1 < s2)?-1:(s1 > s2)?1:0;\n}\n\n//Provides: caml_string_equal const\n//If: js-string\nfunction caml_string_equal(s1, s2) {\n if(s1 === s2) return 1;\n return 0;\n}\n\n//Provides: caml_string_lessequal const\n//If: js-string\nfunction caml_string_lessequal(s1, s2) {\n return (s1 <= s2)?1:0;\n}\n\n//Provides: caml_string_lessthan const\n//If: js-string\nfunction caml_string_lessthan(s1, s2) {\n return (s1 < s2)?1:0;\n}\n\n//Provides: caml_string_of_bytes\n//Requires: caml_convert_string_to_bytes, caml_string_of_jsbytes\n//If: js-string\nfunction caml_string_of_bytes(s) {\n (s.t & 6) && caml_convert_string_to_bytes(s);\n return caml_string_of_jsbytes(s.c);\n}\n\n//Provides: caml_bytes_of_string const\n//Requires: caml_bytes_of_jsbytes, caml_jsbytes_of_string\n//If: js-string\nfunction caml_bytes_of_string(s) {\n return caml_bytes_of_jsbytes(caml_jsbytes_of_string(s));\n}\n\n//Provides: caml_string_of_jsbytes const\n//If: js-string\nfunction caml_string_of_jsbytes(x) { return x }\n\n//Provides: caml_jsbytes_of_string const\n//If: js-string\nfunction caml_jsbytes_of_string(x) { return x }\n\n//Provides: caml_jsstring_of_string const\n//Requires: jsoo_is_ascii, caml_utf16_of_utf8\n//If: js-string\nfunction caml_jsstring_of_string(s) {\n if(jsoo_is_ascii(s))\n return s;\n return caml_utf16_of_utf8(s); }\n\n//Provides: caml_string_of_jsstring const\n//Requires: jsoo_is_ascii, caml_utf8_of_utf16, caml_string_of_jsbytes\n//If: js-string\nfunction caml_string_of_jsstring (s) {\n if (jsoo_is_ascii(s))\n return caml_string_of_jsbytes(s)\n else return caml_string_of_jsbytes(caml_utf8_of_utf16(s));\n}\n\n//Provides: caml_bytes_of_jsbytes const\n//Requires: MlBytes\nfunction caml_bytes_of_jsbytes(s) { return new MlBytes(0,s,s.length); }\n\n\n// The section below should be used when use-js-string=false\n\n//Provides: caml_string_unsafe_get const\n//Requires: caml_bytes_unsafe_get\n//If: !js-string\nfunction caml_string_unsafe_get (s, i) {\n return caml_bytes_unsafe_get(s,i);\n}\n\n//Provides: caml_string_unsafe_set\n//Requires: caml_bytes_unsafe_set\n//If: !js-string\nfunction caml_string_unsafe_set (s, i, c) {\n return caml_bytes_unsafe_set(s,i,c);\n}\n\n//Provides: caml_ml_string_length const\n//Requires: caml_ml_bytes_length\n//If: !js-string\nfunction caml_ml_string_length(s) {\n return caml_ml_bytes_length(s)\n}\n\n//Provides: caml_string_compare\n//Requires: caml_bytes_compare\n//If: !js-string\nfunction caml_string_compare(s1, s2) {\n return caml_bytes_compare(s1,s2)\n}\n\n//Provides: caml_string_equal\n//Requires: caml_bytes_equal\n//If: !js-string\nfunction caml_string_equal(s1, s2) {\n return caml_bytes_equal(s1,s2)\n}\n\n//Provides: caml_string_lessequal\n//Requires: caml_bytes_lessequal\n//If: !js-string\nfunction caml_string_lessequal(s1, s2) {\n return caml_bytes_lessequal(s1,s2)\n}\n\n//Provides: caml_string_lessthan\n//Requires: caml_bytes_lessthan\n//If: !js-string\nfunction caml_string_lessthan(s1, s2) {\n return caml_bytes_lessthan(s1,s2)\n}\n\n//Provides: caml_string_of_bytes\n//If: !js-string\nfunction caml_string_of_bytes(s) { return s }\n\n//Provides: caml_bytes_of_string const\n//If: !js-string\nfunction caml_bytes_of_string(s) { return s }\n\n//Provides: caml_string_of_jsbytes const\n//Requires: caml_bytes_of_jsbytes\n//If: !js-string\nfunction caml_string_of_jsbytes(s) { return caml_bytes_of_jsbytes(s); }\n\n//Provides: caml_jsbytes_of_string const\n//Requires: caml_convert_string_to_bytes\n//If: !js-string\nfunction caml_jsbytes_of_string(s) {\n (s.t & 6) && caml_convert_string_to_bytes(s);\n return s.c }\n\n//Provides: caml_jsstring_of_string mutable (const)\n//If: !js-string\nfunction caml_jsstring_of_string(s){\n return s.toUtf16()\n}\n\n//Provides: caml_string_of_jsstring\n//Requires: caml_bytes_of_utf16_jsstring\n//If: !js-string\nfunction caml_string_of_jsstring (s) {\n return caml_bytes_of_utf16_jsstring(s);\n}\n\n//Provides: caml_is_ml_bytes\n//Requires: MlBytes\nfunction caml_is_ml_bytes(s) {\n return (s instanceof MlBytes);\n}\n\n//Provides: caml_ml_bytes_content\n//Requires: MlBytes, caml_convert_string_to_bytes\nfunction caml_ml_bytes_content(s) {\n switch (s.t & 6) {\n default: /* PARTIAL */\n caml_convert_string_to_bytes(s);\n case 0: /* BYTES */\n return s.c;\n case 4:\n return s.c\n }\n}\n\n//Provides: caml_is_ml_string\n//Requires: jsoo_is_ascii\n//If: js-string\nfunction caml_is_ml_string(s) {\n return (typeof s === \"string\" && !/[^\\x00-\\xff]/.test(s));\n}\n\n//Provides: caml_is_ml_string\n//Requires: caml_is_ml_bytes\n//If: !js-string\nfunction caml_is_ml_string(s) {\n return caml_is_ml_bytes(s);\n}\n\n// The functions below are deprecated\n\n//Provides: caml_js_to_byte_string const\n//Requires: caml_string_of_jsbytes\nfunction caml_js_to_byte_string(s) { return caml_string_of_jsbytes(s) }\n\n//Provides: caml_new_string\n//Requires: caml_string_of_jsbytes\nfunction caml_new_string (s) { return caml_string_of_jsbytes(s) }\n\n//Provides: caml_js_from_string mutable (const)\n//Requires: caml_jsstring_of_string\nfunction caml_js_from_string(s) {\n return caml_jsstring_of_string(s)\n}\n\n//Provides: caml_to_js_string mutable (const)\n//Requires: caml_jsstring_of_string\nfunction caml_to_js_string(s) {\n return caml_jsstring_of_string(s)\n}\n\n//Provides: caml_js_to_string const\n//Requires: caml_string_of_jsstring\nfunction caml_js_to_string (s) {\n return caml_string_of_jsstring(s);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard, Andy Ray\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n//\n// Bigarray.\n//\n// - all bigarray types including Int64 and Complex.\n// - fortran + c layouts\n// - sub/slice/reshape\n// - retain fast path for 1d array access\n\n//Provides: caml_ba_init const\nfunction caml_ba_init() {\n return 0;\n}\n\n//Provides: caml_ba_get_size\n//Requires: caml_invalid_argument\nfunction caml_ba_get_size(dims) {\n var n_dims = dims.length;\n var size = 1;\n for (var i = 0; i < n_dims; i++) {\n if (dims[i] < 0)\n caml_invalid_argument(\"Bigarray.create: negative dimension\");\n size = size * dims[i];\n }\n return size;\n}\n\n//Provides: caml_ba_get_size_per_element\nfunction caml_ba_get_size_per_element(kind){\n switch(kind){\n case 7: case 10: case 11: return 2;\n default: return 1;\n }\n}\n\n//Provides: caml_ba_create_buffer\n//Requires: caml_ba_get_size_per_element\n//Requires: caml_invalid_argument\nfunction caml_ba_create_buffer(kind, size){\n var g = globalThis;\n var view;\n switch(kind){\n case 0: view = g.Float32Array; break;\n case 1: view = g.Float64Array; break;\n case 2: view = g.Int8Array; break;\n case 3: view = g.Uint8Array; break;\n case 4: view = g.Int16Array; break;\n case 5: view = g.Uint16Array; break;\n case 6: view = g.Int32Array; break;\n case 7: view = g.Int32Array; break;\n case 8: view = g.Int32Array; break;\n case 9: view = g.Int32Array; break;\n case 10: view = g.Float32Array; break;\n case 11: view = g.Float64Array; break;\n case 12: view = g.Uint8Array; break;\n }\n if (!view) caml_invalid_argument(\"Bigarray.create: unsupported kind\");\n var data = new view(size * caml_ba_get_size_per_element(kind));\n return data;\n}\n\n//Provides: caml_ba_custom_name\n//Version: < 4.11\nvar caml_ba_custom_name = \"_bigarray\"\n\n//Provides: caml_ba_custom_name\n//Version: >= 4.11\nvar caml_ba_custom_name = \"_bigarr02\"\n\n//Provides: Ml_Bigarray\n//Requires: caml_array_bound_error, caml_invalid_argument, caml_ba_custom_name\n//Requires: caml_int64_create_lo_hi, caml_int64_hi32, caml_int64_lo32\nfunction Ml_Bigarray (kind, layout, dims, buffer) {\n\n this.kind = kind ;\n this.layout = layout;\n this.dims = dims;\n this.data = buffer;\n}\n\nMl_Bigarray.prototype.caml_custom = caml_ba_custom_name;\n\nMl_Bigarray.prototype.offset = function (arg) {\n var ofs = 0;\n if(typeof arg === \"number\") arg = [arg];\n if (! (arg instanceof Array)) caml_invalid_argument(\"bigarray.js: invalid offset\");\n if (this.dims.length != arg.length)\n caml_invalid_argument(\"Bigarray.get/set: bad number of dimensions\");\n if(this.layout == 0 /* c_layout */) {\n for (var i = 0; i < this.dims.length; i++) {\n if (arg[i] < 0 || arg[i] >= this.dims[i])\n caml_array_bound_error();\n ofs = (ofs * this.dims[i]) + arg[i];\n }\n } else {\n for (var i = this.dims.length - 1; i >= 0; i--) {\n if (arg[i] < 1 || arg[i] > this.dims[i]){\n caml_array_bound_error();\n }\n ofs = (ofs * this.dims[i]) + (arg[i] - 1);\n }\n }\n return ofs;\n}\n\nMl_Bigarray.prototype.get = function (ofs) {\n switch(this.kind){\n case 7:\n // Int64\n var l = this.data[ofs * 2 + 0];\n var h = this.data[ofs * 2 + 1];\n return caml_int64_create_lo_hi(l,h);\n case 10: case 11:\n // Complex32, Complex64\n var r = this.data[ofs * 2 + 0];\n var i = this.data[ofs * 2 + 1];\n return [254, r, i];\n default:\n return this.data[ofs]\n }\n}\n\nMl_Bigarray.prototype.set = function (ofs,v) {\n switch(this.kind){\n case 7:\n // Int64\n this.data[ofs * 2 + 0] = caml_int64_lo32(v);\n this.data[ofs * 2 + 1] = caml_int64_hi32(v);\n break;\n case 10: case 11:\n // Complex32, Complex64\n this.data[ofs * 2 + 0] = v[1];\n this.data[ofs * 2 + 1] = v[2];\n break;\n default:\n this.data[ofs] = v;\n break;\n }\n return 0\n}\n\n\nMl_Bigarray.prototype.fill = function (v) {\n switch(this.kind){\n case 7:\n // Int64\n var a = caml_int64_lo32(v);\n var b = caml_int64_hi32(v);\n if(a == b){\n this.data.fill(a);\n }\n else {\n for(var i = 0; i y)\n return 1;\n if (x != y) {\n if (!total) return NaN;\n if (x == x) return 1;\n if (y == y) return -1;\n }\n }\n break;\n case 7:\n // Int64\n for (var i = 0; i < this.data.length; i+=2) {\n // Check highest bits first\n if (this.data[i+1] < b.data[i+1])\n return -1;\n if (this.data[i+1] > b.data[i+1])\n return 1;\n if ((this.data[i] >>> 0) < (b.data[i] >>> 0))\n return -1;\n if ((this.data[i] >>> 0) > (b.data[i] >>> 0))\n return 1;\n }\n break;\n case 2:\n case 3:\n case 4:\n case 5:\n case 6:\n case 8:\n case 9:\n case 12:\n for (var i = 0; i < this.data.length; i++) {\n if (this.data[i] < b.data[i])\n return -1;\n if (this.data[i] > b.data[i])\n return 1;\n }\n break;\n }\n return 0;\n}\n\n//Provides: Ml_Bigarray_c_1_1\n//Requires: Ml_Bigarray, caml_array_bound_error, caml_invalid_argument\nfunction Ml_Bigarray_c_1_1(kind, layout, dims, buffer) {\n this.kind = kind ;\n this.layout = layout;\n this.dims = dims;\n this.data = buffer;\n}\n\nMl_Bigarray_c_1_1.prototype = new Ml_Bigarray()\nMl_Bigarray_c_1_1.prototype.offset = function (arg) {\n if(typeof arg !== \"number\"){\n if((arg instanceof Array) && arg.length == 1)\n arg = arg[0];\n else caml_invalid_argument(\"Ml_Bigarray_c_1_1.offset\");\n }\n if (arg < 0 || arg >= this.dims[0])\n caml_array_bound_error();\n return arg;\n}\n\nMl_Bigarray_c_1_1.prototype.get = function (ofs) {\n return this.data[ofs];\n}\n\nMl_Bigarray_c_1_1.prototype.set = function (ofs,v) {\n this.data[ofs] = v;\n return 0\n}\n\nMl_Bigarray_c_1_1.prototype.fill = function (v) {\n this.data.fill(v);\n return 0\n}\n\n//Provides: caml_ba_compare\nfunction caml_ba_compare(a,b,total){\n return a.compare(b,total)\n}\n\n//Provides: caml_ba_create_unsafe\n//Requires: Ml_Bigarray, Ml_Bigarray_c_1_1, caml_ba_get_size, caml_ba_get_size_per_element\n//Requires: caml_invalid_argument\nfunction caml_ba_create_unsafe(kind, layout, dims, data){\n var size_per_element = caml_ba_get_size_per_element(kind);\n if(caml_ba_get_size(dims) * size_per_element != data.length) {\n caml_invalid_argument(\"length doesn't match dims\");\n }\n if(layout == 0 && // c_layout\n dims.length == 1 && // Array1\n size_per_element == 1) // 1-to-1 mapping\n return new Ml_Bigarray_c_1_1(kind, layout, dims, data);\n return new Ml_Bigarray(kind, layout, dims, data);\n\n}\n\n\n//Provides: caml_ba_create\n//Requires: caml_js_from_array\n//Requires: caml_ba_get_size, caml_ba_create_unsafe\n//Requires: caml_ba_create_buffer\nfunction caml_ba_create(kind, layout, dims_ml) {\n var dims = caml_js_from_array(dims_ml);\n var data = caml_ba_create_buffer(kind, caml_ba_get_size(dims));\n return caml_ba_create_unsafe(kind, layout, dims, data);\n}\n\n//Provides: caml_ba_change_layout\n//Requires: caml_ba_create_unsafe\nfunction caml_ba_change_layout(ba, layout) {\n if(ba.layout == layout) return ba;\n var new_dims = []\n for(var i = 0; i < ba.dims.length; i++) new_dims[i] = ba.dims[ba.dims.length - i - 1];\n return caml_ba_create_unsafe(ba.kind, layout, new_dims, ba.data);\n}\n\n//Provides: caml_ba_kind\nfunction caml_ba_kind(ba) {\n return ba.kind;\n}\n\n//Provides: caml_ba_layout\nfunction caml_ba_layout(ba) {\n return ba.layout;\n}\n\n//Provides: caml_ba_num_dims\nfunction caml_ba_num_dims(ba) {\n return ba.dims.length;\n}\n\n//Provides: caml_ba_dim\n//Requires: caml_invalid_argument\nfunction caml_ba_dim(ba, i) {\n if (i < 0 || i >= ba.dims.length)\n caml_invalid_argument(\"Bigarray.dim\");\n return ba.dims[i];\n}\n\n//Provides: caml_ba_dim_1\n//Requires: caml_ba_dim\nfunction caml_ba_dim_1(ba) {\n return caml_ba_dim(ba, 0);\n}\n\n//Provides: caml_ba_dim_2\n//Requires: caml_ba_dim\nfunction caml_ba_dim_2(ba) {\n return caml_ba_dim(ba, 1);\n}\n\n//Provides: caml_ba_dim_3\n//Requires: caml_ba_dim\nfunction caml_ba_dim_3(ba) {\n return caml_ba_dim(ba, 2);\n}\n\n//Provides: caml_ba_get_generic\n//Requires: caml_js_from_array\nfunction caml_ba_get_generic(ba, i) {\n var ofs = ba.offset(caml_js_from_array(i));\n return ba.get(ofs);\n}\n\n//Provides: caml_ba_uint8_get16\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_get16(ba, i0) {\n var ofs = ba.offset(i0);\n if(ofs + 1 >= ba.data.length) caml_array_bound_error();\n var b1 = ba.get(ofs);\n var b2 = ba.get(ofs + 1);\n return (b1 | (b2 << 8));\n}\n\n//Provides: caml_ba_uint8_get32\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_get32(ba, i0) {\n var ofs = ba.offset(i0);\n if(ofs + 3 >= ba.data.length) caml_array_bound_error();\n var b1 = ba.get(ofs+0);\n var b2 = ba.get(ofs+1);\n var b3 = ba.get(ofs+2);\n var b4 = ba.get(ofs+3);\n return ( (b1 << 0) |\n (b2 << 8) |\n (b3 << 16) |\n (b4 << 24) );\n}\n\n//Provides: caml_ba_uint8_get64\n//Requires: caml_array_bound_error, caml_int64_of_bytes\nfunction caml_ba_uint8_get64(ba, i0) {\n var ofs = ba.offset(i0);\n if(ofs + 7 >= ba.data.length) caml_array_bound_error();\n var b1 = ba.get(ofs+0);\n var b2 = ba.get(ofs+1);\n var b3 = ba.get(ofs+2);\n var b4 = ba.get(ofs+3);\n var b5 = ba.get(ofs+4);\n var b6 = ba.get(ofs+5);\n var b7 = ba.get(ofs+6);\n var b8 = ba.get(ofs+7);\n return caml_int64_of_bytes([b8,b7,b6,b5,b4,b3,b2,b1]);\n}\n\n//Provides: caml_ba_get_1\nfunction caml_ba_get_1(ba, i0) {\n return ba.get(ba.offset(i0));\n}\n\n//Provides: caml_ba_get_2\nfunction caml_ba_get_2(ba, i0, i1) {\n return ba.get(ba.offset([i0,i1]));\n}\n\n//Provides: caml_ba_get_3\nfunction caml_ba_get_3(ba, i0, i1, i2) {\n return ba.get(ba.offset([i0,i1,i2]));\n}\n\n//Provides: caml_ba_set_generic\n//Requires: caml_js_from_array\nfunction caml_ba_set_generic(ba, i, v) {\n ba.set(ba.offset(caml_js_from_array(i)), v);\n return 0\n}\n\n//Provides: caml_ba_uint8_set16\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_set16(ba, i0, v) {\n var ofs = ba.offset(i0);\n if(ofs + 1 >= ba.data.length) caml_array_bound_error();\n ba.set(ofs+0, v & 0xff);\n ba.set(ofs+1, (v >>> 8) & 0xff);\n return 0;\n}\n\n//Provides: caml_ba_uint8_set32\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_set32(ba, i0, v) {\n var ofs = ba.offset(i0);\n if(ofs + 3 >= ba.data.length) caml_array_bound_error();\n ba.set(ofs+0, v & 0xff);\n ba.set(ofs+1, (v >>> 8) & 0xff);\n ba.set(ofs+2, (v >>> 16) & 0xff);\n ba.set(ofs+3, (v >>> 24) & 0xff);\n return 0;\n}\n\n//Provides: caml_ba_uint8_set64\n//Requires: caml_array_bound_error, caml_int64_to_bytes\nfunction caml_ba_uint8_set64(ba, i0, v) {\n var ofs = ba.offset(i0);\n if(ofs + 7 >= ba.data.length) caml_array_bound_error();\n var v = caml_int64_to_bytes(v);\n for(var i = 0; i < 8; i++) ba.set(ofs+i, v[7-i])\n return 0;\n}\n\n//Provides: caml_ba_set_1\nfunction caml_ba_set_1(ba, i0, v) {\n ba.set(ba.offset(i0), v);\n return 0\n}\n\n//Provides: caml_ba_set_2\nfunction caml_ba_set_2(ba, i0, i1, v) {\n ba.set(ba.offset([i0,i1]), v);\n return 0;\n}\n\n//Provides: caml_ba_set_3\nfunction caml_ba_set_3(ba, i0, i1, i2, v) {\n ba.set(ba.offset([i0,i1,i2]), v);\n return 0;\n}\n\n//Provides: caml_ba_fill\nfunction caml_ba_fill(ba, v) {\n ba.fill(v);\n return 0;\n}\n\n//Provides: caml_ba_blit\n//Requires: caml_invalid_argument\nfunction caml_ba_blit(src, dst) {\n if (dst.dims.length != src.dims.length)\n caml_invalid_argument(\"Bigarray.blit: dimension mismatch\");\n for (var i = 0; i < dst.dims.length; i++)\n if (dst.dims[i] != src.dims[i])\n caml_invalid_argument(\"Bigarray.blit: dimension mismatch\");\n dst.data.set(src.data);\n return 0;\n}\n\n//Provides: caml_ba_sub\n//Requires: caml_invalid_argument, caml_ba_create_unsafe, caml_ba_get_size\n//Requires: caml_ba_get_size_per_element\nfunction caml_ba_sub(ba, ofs, len) {\n var changed_dim;\n var mul = 1;\n if (ba.layout == 0) {\n for (var i = 1; i < ba.dims.length; i++)\n mul = mul * ba.dims[i];\n changed_dim = 0;\n } else {\n for (var i = 0; i < (ba.dims.length - 1); i++)\n mul = mul * ba.dims[i];\n changed_dim = ba.dims.length - 1;\n ofs = ofs - 1;\n }\n if (ofs < 0 || len < 0 || (ofs + len) > ba.dims[changed_dim]){\n caml_invalid_argument(\"Bigarray.sub: bad sub-array\");\n }\n var new_dims = [];\n for (var i = 0; i < ba.dims.length; i++)\n new_dims[i] = ba.dims[i];\n new_dims[changed_dim] = len;\n mul *= caml_ba_get_size_per_element(ba.kind);\n var new_data = ba.data.subarray(ofs * mul, (ofs + len) * mul);\n return caml_ba_create_unsafe(ba.kind, ba.layout, new_dims, new_data);\n}\n\n//Provides: caml_ba_slice\n//Requires: caml_js_from_array, caml_ba_create_unsafe, caml_invalid_argument, caml_ba_get_size\n//Requires: caml_ba_get_size_per_element\nfunction caml_ba_slice(ba, vind) {\n vind = caml_js_from_array(vind);\n var num_inds = vind.length;\n var index = [];\n var sub_dims = [];\n var ofs;\n\n if (num_inds > ba.dims.length)\n caml_invalid_argument(\"Bigarray.slice: too many indices\");\n\n // Compute offset and check bounds\n if (ba.layout == 0) {\n for (var i = 0; i < num_inds; i++)\n index[i] = vind[i];\n for (; i < ba.dims.length; i++)\n index[i] = 0;\n sub_dims = ba.dims.slice(num_inds);\n } else {\n for (var i = 0; i < num_inds; i++)\n index[ba.dims.length - num_inds + i] = vind[i];\n for (var i = 0; i < ba.dims.length - num_inds; i++)\n index[i] = 1;\n sub_dims = ba.dims.slice(0, ba.dims.length - num_inds);\n }\n ofs = ba.offset(index);\n var size = caml_ba_get_size(sub_dims);\n var size_per_element = caml_ba_get_size_per_element(ba.kind);\n var new_data = ba.data.subarray(ofs * size_per_element, (ofs + size) * size_per_element);\n return caml_ba_create_unsafe(ba.kind, ba.layout, sub_dims, new_data);\n}\n\n//Provides: caml_ba_reshape\n//Requires: caml_js_from_array, caml_invalid_argument, caml_ba_create_unsafe, caml_ba_get_size\nfunction caml_ba_reshape(ba, vind) {\n vind = caml_js_from_array(vind);\n var new_dim = [];\n var num_dims = vind.length;\n\n if (num_dims < 0 || num_dims > 16){\n caml_invalid_argument(\"Bigarray.reshape: bad number of dimensions\");\n }\n var num_elts = 1;\n for (var i = 0; i < num_dims; i++) {\n new_dim[i] = vind[i];\n if (new_dim[i] < 0)\n caml_invalid_argument(\"Bigarray.reshape: negative dimension\");\n num_elts = num_elts * new_dim[i];\n }\n\n var size = caml_ba_get_size(ba.dims);\n // Check that sizes agree\n if (num_elts != size)\n caml_invalid_argument(\"Bigarray.reshape: size mismatch\");\n return caml_ba_create_unsafe(ba.kind, ba.layout, new_dim, ba.data);\n}\n\n//Provides: caml_ba_serialize\n//Requires: caml_int64_bits_of_float, caml_int64_to_bytes\n//Requires: caml_int32_bits_of_float\nfunction caml_ba_serialize(writer, ba, sz) {\n writer.write(32, ba.dims.length);\n writer.write(32, (ba.kind | (ba.layout << 8)));\n if(ba.caml_custom == \"_bigarr02\")\n for(var i = 0; i < ba.dims.length; i++) {\n if(ba.dims[i] < 0xffff)\n writer.write(16, ba.dims[i]);\n else {\n writer.write(16, 0xffff);\n writer.write(32, 0);\n writer.write(32, ba.dims[i]);\n }\n }\n else\n for(var i = 0; i < ba.dims.length; i++) writer.write(32,ba.dims[i])\n switch(ba.kind){\n case 2: //Int8Array\n case 3: //Uint8Array\n case 12: //Uint8Array\n for(var i = 0; i < ba.data.length; i++){\n writer.write(8, ba.data[i]);\n }\n break;\n case 4: // Int16Array\n case 5: // Uint16Array\n for(var i = 0; i < ba.data.length; i++){\n writer.write(16, ba.data[i]);\n }\n break;\n case 6: // Int32Array (int32)\n for(var i = 0; i < ba.data.length; i++){\n writer.write(32, ba.data[i]);\n }\n break;\n case 8: // Int32Array (int)\n case 9: // Int32Array (nativeint)\n writer.write(8,0);\n for(var i = 0; i < ba.data.length; i++){\n writer.write(32, ba.data[i]);\n }\n break;\n case 7: // Int32Array (int64)\n for(var i = 0; i < ba.data.length / 2; i++){\n var b = caml_int64_to_bytes(ba.get(i));\n for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n }\n break;\n case 1: // Float64Array\n for(var i = 0; i < ba.data.length; i++){\n var b = caml_int64_to_bytes(caml_int64_bits_of_float(ba.get(i)));\n for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n }\n break;\n case 0: // Float32Array\n for(var i = 0; i < ba.data.length; i++){\n var b = caml_int32_bits_of_float(ba.get(i));\n writer.write(32, b);\n }\n break;\n case 10: // Float32Array (complex32)\n for(var i = 0; i < ba.data.length / 2; i++){\n var j = ba.get(i);\n writer.write(32, caml_int32_bits_of_float(j[1]));\n writer.write(32, caml_int32_bits_of_float(j[2]));\n }\n break;\n case 11: // Float64Array (complex64)\n for(var i = 0; i < ba.data.length / 2; i++){\n var complex = ba.get(i);\n var b = caml_int64_to_bytes(caml_int64_bits_of_float(complex[1]));\n for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n var b = caml_int64_to_bytes(caml_int64_bits_of_float(complex[2]));\n for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n }\n break;\n }\n sz[0] = (4 + ba.dims.length) * 4;\n sz[1] = (4 + ba.dims.length) * 8;\n}\n\n//Provides: caml_ba_deserialize\n//Requires: caml_ba_create_unsafe, caml_failwith\n//Requires: caml_ba_get_size\n//Requires: caml_int64_of_bytes, caml_int64_float_of_bits\n//Requires: caml_int32_float_of_bits\n//Requires: caml_ba_create_buffer\nfunction caml_ba_deserialize(reader, sz, name){\n var num_dims = reader.read32s();\n if (num_dims < 0 || num_dims > 16)\n caml_failwith(\"input_value: wrong number of bigarray dimensions\");\n var tag = reader.read32s();\n var kind = tag & 0xff\n var layout = (tag >> 8) & 1;\n var dims = []\n if(name == \"_bigarr02\")\n for (var i = 0; i < num_dims; i++) {\n var size_dim = reader.read16u();\n if(size_dim == 0xffff){\n var size_dim_hi = reader.read32u();\n var size_dim_lo = reader.read32u();\n if(size_dim_hi != 0)\n caml_failwith(\"input_value: bigarray dimension overflow in 32bit\");\n size_dim = size_dim_lo;\n }\n dims.push(size_dim);\n }\n else\n for (var i = 0; i < num_dims; i++) dims.push(reader.read32u());\n var size = caml_ba_get_size(dims);\n var data = caml_ba_create_buffer(kind, size);\n var ba = caml_ba_create_unsafe(kind, layout, dims, data);\n switch(kind){\n case 2: //Int8Array\n for(var i = 0; i < size; i++){\n data[i] = reader.read8s();\n }\n break;\n case 3: //Uint8Array\n case 12: //Uint8Array\n for(var i = 0; i < size; i++){\n data[i] = reader.read8u();\n }\n break;\n case 4: // Int16Array\n for(var i = 0; i < size; i++){\n data[i] = reader.read16s();\n }\n break;\n case 5: // Uint16Array\n for(var i = 0; i < size; i++){\n data[i] = reader.read16u();\n }\n break;\n case 6: // Int32Array (int32)\n for(var i = 0; i < size; i++){\n data[i] = reader.read32s();\n }\n break;\n case 8: // Int32Array (int)\n case 9: // Int32Array (nativeint)\n var sixty = reader.read8u();\n if(sixty) caml_failwith(\"input_value: cannot read bigarray with 64-bit OCaml ints\");\n for(var i = 0; i < size; i++){\n data[i] = reader.read32s();\n }\n break;\n case 7: // (int64)\n var t = new Array(8);;\n for(var i = 0; i < size; i++){\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n var int64 = caml_int64_of_bytes(t);\n ba.set(i,int64);\n }\n break;\n case 1: // Float64Array\n var t = new Array(8);;\n for(var i = 0; i < size; i++){\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n var f = caml_int64_float_of_bits(caml_int64_of_bytes(t));\n ba.set(i,f);\n }\n break;\n case 0: // Float32Array\n for(var i = 0; i < size; i++){\n var f = caml_int32_float_of_bits(reader.read32s());\n ba.set(i,f);\n }\n break;\n case 10: // Float32Array (complex32)\n for(var i = 0; i < size; i++){\n var re = caml_int32_float_of_bits(reader.read32s());\n var im = caml_int32_float_of_bits(reader.read32s());\n ba.set(i,[254,re,im]);\n }\n break;\n case 11: // Float64Array (complex64)\n var t = new Array(8);;\n for(var i = 0; i < size; i++){\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n var re = caml_int64_float_of_bits(caml_int64_of_bytes(t));\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n var im = caml_int64_float_of_bits(caml_int64_of_bytes(t));\n ba.set(i,[254,re,im]);\n }\n break\n }\n sz[0] = (4 + num_dims) * 4;\n return caml_ba_create_unsafe(kind, layout, dims, data);\n}\n\n//Deprecated\n//Provides: caml_ba_create_from\n//Requires: caml_ba_create_unsafe, caml_invalid_argument, caml_ba_get_size_per_element\nfunction caml_ba_create_from(data1, data2, jstyp, kind, layout, dims){\n if(data2 || caml_ba_get_size_per_element(kind) == 2){\n caml_invalid_argument(\"caml_ba_create_from: use return caml_ba_create_unsafe\");\n }\n return caml_ba_create_unsafe(kind, layout, dims, data1);\n}\n\n//Provides: caml_ba_hash const\n//Requires: caml_ba_get_size, caml_hash_mix_int, caml_hash_mix_float\nfunction caml_ba_hash(ba){\n var num_elts = caml_ba_get_size(ba.dims);\n var h = 0;\n switch(ba.kind){\n case 2: //Int8Array\n case 3: //Uint8Array\n case 12: //Uint8Array\n if(num_elts > 256) num_elts = 256;\n var w = 0, i =0;\n for(i = 0; i + 4 <= ba.data.length; i+=4){\n w = ba.data[i+0] | (ba.data[i+1] << 8) | (ba.data[i+2] << 16) | (ba.data[i+3] << 24);\n h = caml_hash_mix_int(h,w);\n }\n w = 0;\n switch (num_elts & 3) {\n case 3: w = ba.data[i+2] << 16; /* fallthrough */\n case 2: w |= ba.data[i+1] << 8; /* fallthrough */\n case 1: w |= ba.data[i+0];\n h = caml_hash_mix_int(h, w);\n }\n break;\n case 4: // Int16Array\n case 5: // Uint16Array\n if(num_elts > 128) num_elts = 128;\n var w = 0, i =0;\n for(i = 0; i + 2 <= ba.data.length; i+=2){\n w = ba.data[i+0] | (ba.data[i+1] << 16);\n h = caml_hash_mix_int(h,w);\n }\n if ((num_elts & 1) != 0)\n h = caml_hash_mix_int(h, ba.data[i]);\n break;\n case 6: // Int32Array (int32)\n if (num_elts > 64) num_elts = 64;\n for (var i = 0; i < num_elts; i++) h = caml_hash_mix_int(h, ba.data[i]);\n break;\n case 8: // Int32Array (int)\n case 9: // Int32Array (nativeint)\n if (num_elts > 64) num_elts = 64;\n for (var i = 0; i < num_elts; i++) h = caml_hash_mix_int(h, ba.data[i]);\n break;\n case 7: // Int32Array (int64)\n if (num_elts > 32) num_elts = 32;\n num_elts *= 2\n for (var i = 0; i < num_elts; i++) {\n h = caml_hash_mix_int(h, ba.data[i]);\n }\n break;\n case 10: // Float32Array (complex32)\n num_elts *=2; /* fallthrough */\n case 0: // Float32Array\n if (num_elts > 64) num_elts = 64;\n for (var i = 0; i < num_elts; i++) h = caml_hash_mix_float(h, ba.data[i]);\n break;\n case 11: // Float64Array (complex64)\n num_elts *=2; /* fallthrough */\n case 1: // Float64Array\n if (num_elts > 32) num_elts = 32;\n for (var i = 0; i < num_elts; i++) h = caml_hash_mix_float(h, ba.data[i]);\n break;\n }\n return h;\n}\n\n//Provides: caml_ba_to_typed_array mutable\nfunction caml_ba_to_typed_array(ba){\n return ba.data;\n}\n\n//Provides: caml_ba_kind_of_typed_array mutable\n//Requires: caml_invalid_argument\nfunction caml_ba_kind_of_typed_array(ta){\n var g = globalThis;\n var kind;\n if (ta instanceof g.Float32Array) kind = 0;\n else if (ta instanceof g.Float64Array) kind = 1;\n else if (ta instanceof g.Int8Array) kind = 2;\n else if (ta instanceof g.Uint8Array) kind = 3;\n else if (ta instanceof g.Int16Array) kind = 4;\n else if (ta instanceof g.Uint16Array) kind = 5;\n else if (ta instanceof g.Int32Array) kind = 6;\n else if (ta instanceof g.Uint32Array) kind = 6;\n else caml_invalid_argument(\"caml_ba_kind_of_typed_array: unsupported kind\");\n return kind;\n}\n\n//Provides: caml_ba_from_typed_array mutable\n//Requires: caml_ba_kind_of_typed_array\n//Requires: caml_ba_create_unsafe\nfunction caml_ba_from_typed_array(ta){\n var kind = caml_ba_kind_of_typed_array(ta);\n return caml_ba_create_unsafe(kind, 0, [ta.length], ta);\n}\n","/* global globalThis\n */\n\n//Provides: caml_raise_with_string (const, const)\nfunction caml_raise_with_string(tag, msg) {\n throw globalThis.Error(msg.c);\n}\n\n//Provides: custom_reraise_exn\nfunction custom_reraise_exn(exn, fallbackMessage) {\n // this handles the common case of a JS Error reraised by OCaml\n // in that case, the error will first be wrapped in OCaml with \"caml_wrap_exception\"\n // (defined in js_of_ocaml-compiler / jslib.js)\n // which results in [0, caml_named_value(\"jsError\"), err]\n var err = exn[2];\n if (err instanceof globalThis.Error) {\n throw err;\n } else {\n throw Error(fallbackMessage);\n }\n}\n\n/**\n * This overrides the handler for uncaught exceptions in js_of_ocaml,\n * fixing the flaw that by default, no actual `Error`s are thrown,\n * but other objects (arrays) which are missing an error trace.\n * This override should make it much easier to find the source of an error.\n */\n//Provides: caml_fatal_uncaught_exception\nfunction caml_fatal_uncaught_exception(err) {\n // first, we search for an actual error inside `err`,\n // since this is the best thing to throw\n function throw_errors(err) {\n if (err instanceof Error) throw err;\n else if (Array.isArray(err)) {\n err.forEach(throw_errors);\n }\n }\n throw_errors(err);\n // if this didn't throw an error, let's log whatever we got\n console.dir(err, { depth: 20 });\n // now, try to collect all strings in the error and throw that\n function collect_strings(err, acc) {\n var str = undefined;\n if (typeof err === 'string') {\n str = err;\n } else if (err && err.constructor && err.constructor.name === 'MlBytes') {\n str = err.c;\n } else if (Array.isArray(err)) {\n err.forEach(function (e) {\n collect_strings(e, acc);\n });\n }\n if (!str) return acc.string;\n if (acc.string === undefined) acc.string = str;\n else acc.string = acc.string + '\\n' + str;\n return acc.string;\n }\n var str = collect_strings(err, {});\n if (str !== undefined) throw globalThis.Error(str);\n // otherwise, just throw an unhelpful error\n console.dir(err, { depth: 10 });\n throw globalThis.Error('Unknown error thrown from OCaml');\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_marshal_constants\nvar caml_marshal_constants = {\n PREFIX_SMALL_BLOCK: 0x80,\n PREFIX_SMALL_INT: 0x40,\n PREFIX_SMALL_STRING: 0x20,\n CODE_INT8: 0x00,\n CODE_INT16: 0x01,\n CODE_INT32: 0x02,\n CODE_INT64: 0x03,\n CODE_SHARED8: 0x04,\n CODE_SHARED16: 0x05,\n CODE_SHARED32: 0x06,\n CODE_BLOCK32: 0x08,\n CODE_BLOCK64: 0x13,\n CODE_STRING8: 0x09,\n CODE_STRING32: 0x0A,\n CODE_DOUBLE_BIG: 0x0B,\n CODE_DOUBLE_LITTLE: 0x0C,\n CODE_DOUBLE_ARRAY8_BIG: 0x0D,\n CODE_DOUBLE_ARRAY8_LITTLE: 0x0E,\n CODE_DOUBLE_ARRAY32_BIG: 0x0F,\n CODE_DOUBLE_ARRAY32_LITTLE: 0x07,\n CODE_CODEPOINTER: 0x10,\n CODE_INFIXPOINTER: 0x11,\n CODE_CUSTOM: 0x12,\n CODE_CUSTOM_LEN: 0x18,\n CODE_CUSTOM_FIXED: 0x19\n}\n\n\n//Provides: MlStringReader\n//Requires: caml_string_of_jsbytes, caml_jsbytes_of_string\nfunction MlStringReader (s, i) { this.s = caml_jsbytes_of_string(s); this.i = i; }\nMlStringReader.prototype = {\n read8u:function () { return this.s.charCodeAt(this.i++); },\n read8s:function () { return this.s.charCodeAt(this.i++) << 24 >> 24; },\n read16u:function () {\n var s = this.s, i = this.i;\n this.i = i + 2;\n return (s.charCodeAt(i) << 8) | s.charCodeAt(i + 1)\n },\n read16s:function () {\n var s = this.s, i = this.i;\n this.i = i + 2;\n return (s.charCodeAt(i) << 24 >> 16) | s.charCodeAt(i + 1);\n },\n read32u:function () {\n var s = this.s, i = this.i;\n this.i = i + 4;\n return ((s.charCodeAt(i) << 24) | (s.charCodeAt(i+1) << 16) |\n (s.charCodeAt(i+2) << 8) | s.charCodeAt(i+3)) >>> 0;\n },\n read32s:function () {\n var s = this.s, i = this.i;\n this.i = i + 4;\n return (s.charCodeAt(i) << 24) | (s.charCodeAt(i+1) << 16) |\n (s.charCodeAt(i+2) << 8) | s.charCodeAt(i+3);\n },\n readstr:function (len) {\n var i = this.i;\n this.i = i + len;\n return caml_string_of_jsbytes(this.s.substring(i, i + len));\n }\n}\n\n//Provides: BigStringReader\n//Requires: caml_string_of_array, caml_ba_get_1\nfunction BigStringReader (bs, i) { this.s = bs; this.i = i; }\nBigStringReader.prototype = {\n read8u:function () { return caml_ba_get_1(this.s,this.i++); },\n read8s:function () { return caml_ba_get_1(this.s,this.i++) << 24 >> 24; },\n read16u:function () {\n var s = this.s, i = this.i;\n this.i = i + 2;\n return (caml_ba_get_1(s,i) << 8) | caml_ba_get_1(s,i + 1)\n },\n read16s:function () {\n var s = this.s, i = this.i;\n this.i = i + 2;\n return (caml_ba_get_1(s,i) << 24 >> 16) | caml_ba_get_1(s,i + 1);\n },\n read32u:function () {\n var s = this.s, i = this.i;\n this.i = i + 4;\n return ((caml_ba_get_1(s,i) << 24) | (caml_ba_get_1(s,i+1) << 16) |\n (caml_ba_get_1(s,i+2) << 8) | caml_ba_get_1(s,i+3) ) >>> 0;\n },\n read32s:function () {\n var s = this.s, i = this.i;\n this.i = i + 4;\n return (caml_ba_get_1(s,i) << 24) | (caml_ba_get_1(s,i+1) << 16) |\n (caml_ba_get_1(s,i+2) << 8) | caml_ba_get_1(s,i+3);\n },\n readstr:function (len) {\n var i = this.i;\n var arr = new Array(len)\n for(var j = 0; j < len; j++){\n arr[j] = caml_ba_get_1(this.s, i+j);\n }\n this.i = i + len;\n return caml_string_of_array(arr);\n }\n}\n\n\n\n//Provides: caml_float_of_bytes\n//Requires: caml_int64_float_of_bits, caml_int64_of_bytes\nfunction caml_float_of_bytes (a) {\n return caml_int64_float_of_bits (caml_int64_of_bytes (a));\n}\n\n//Provides: caml_input_value_from_string mutable\n//Requires: MlStringReader, caml_input_value_from_reader\nfunction caml_input_value_from_string(s,ofs) {\n var reader = new MlStringReader (s, typeof ofs==\"number\"?ofs:ofs[0]);\n return caml_input_value_from_reader(reader, ofs)\n}\n\n//Provides: caml_input_value_from_bytes mutable\n//Requires: MlStringReader, caml_input_value_from_reader, caml_string_of_bytes\nfunction caml_input_value_from_bytes(s,ofs) {\n var reader = new MlStringReader (caml_string_of_bytes(s), typeof ofs==\"number\"?ofs:ofs[0]);\n return caml_input_value_from_reader(reader, ofs)\n}\n\n//Provides: caml_int64_unmarshal\n//Requires: caml_int64_of_bytes\nfunction caml_int64_unmarshal(reader, size){\n var t = new Array(8);;\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n size[0] = 8;\n return caml_int64_of_bytes (t);\n}\n\n//Provides: caml_int64_marshal\n//Requires: caml_int64_to_bytes\nfunction caml_int64_marshal(writer, v, sizes) {\n var b = caml_int64_to_bytes (v);\n for (var i = 0; i < 8; i++) writer.write (8, b[i]);\n sizes[0] = 8; sizes[1] = 8;\n}\n\n//Provides: caml_int32_unmarshal\nfunction caml_int32_unmarshal(reader, size){\n size[0] = 4;\n return reader.read32s ();\n}\n\n//Provides: caml_nativeint_unmarshal\n//Requires: caml_failwith\nfunction caml_nativeint_unmarshal(reader, size){\n switch (reader.read8u ()) {\n case 1:\n size[0] = 4;\n return reader.read32s ();\n case 2:\n caml_failwith(\"input_value: native integer value too large\");\n default: caml_failwith(\"input_value: ill-formed native integer\");\n }\n}\n\n//Provides: caml_custom_ops\n//Requires: caml_int64_unmarshal, caml_int64_marshal, caml_int64_compare, caml_int64_hash\n//Requires: caml_int32_unmarshal, caml_nativeint_unmarshal\n//Requires: caml_ba_serialize, caml_ba_deserialize, caml_ba_compare, caml_ba_hash\nvar caml_custom_ops =\n {\"_j\": {\n deserialize : caml_int64_unmarshal,\n serialize : caml_int64_marshal,\n fixed_length : 8,\n compare : caml_int64_compare,\n hash : caml_int64_hash\n },\n \"_i\": {\n deserialize : caml_int32_unmarshal,\n fixed_length : 4,\n },\n \"_n\": {\n deserialize : caml_nativeint_unmarshal,\n fixed_length : 4,\n },\n \"_bigarray\":{\n deserialize : (function (reader, sz) {return caml_ba_deserialize (reader,sz,\"_bigarray\")}),\n serialize : caml_ba_serialize,\n compare : caml_ba_compare,\n hash: caml_ba_hash,\n },\n \"_bigarr02\":{\n deserialize : (function (reader, sz) {return caml_ba_deserialize (reader,sz,\"_bigarr02\")}),\n serialize : caml_ba_serialize,\n compare : caml_ba_compare,\n hash: caml_ba_hash,\n }\n }\n\n//Provides: caml_input_value_from_reader mutable\n//Requires: caml_failwith\n//Requires: caml_float_of_bytes, caml_custom_ops\n\nfunction caml_input_value_from_reader(reader, ofs) {\n var _magic = reader.read32u ()\n var _block_len = reader.read32u ();\n var num_objects = reader.read32u ();\n var _size_32 = reader.read32u ();\n var _size_64 = reader.read32u ();\n var stack = [];\n var intern_obj_table = (num_objects > 0)?[]:null;\n var obj_counter = 0;\n function intern_rec () {\n var code = reader.read8u ();\n if (code >= 0x40 /*cst.PREFIX_SMALL_INT*/) {\n if (code >= 0x80 /*cst.PREFIX_SMALL_BLOCK*/) {\n var tag = code & 0xF;\n var size = (code >> 4) & 0x7;\n var v = [tag];\n if (size == 0) return v;\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n stack.push(v, size);\n return v;\n } else\n return (code & 0x3F);\n } else {\n if (code >= 0x20/*cst.PREFIX_SMALL_STRING */) {\n var len = code & 0x1F;\n var v = reader.readstr (len);\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n } else {\n switch(code) {\n case 0x00: //cst.CODE_INT8:\n return reader.read8s ();\n case 0x01: //cst.CODE_INT16:\n return reader.read16s ();\n case 0x02: //cst.CODE_INT32:\n return reader.read32s ();\n case 0x03: //cst.CODE_INT64:\n caml_failwith(\"input_value: integer too large\");\n break;\n case 0x04: //cst.CODE_SHARED8:\n var offset = reader.read8u ();\n return intern_obj_table[obj_counter - offset];\n case 0x05: //cst.CODE_SHARED16:\n var offset = reader.read16u ();\n return intern_obj_table[obj_counter - offset];\n case 0x06: //cst.CODE_SHARED32:\n var offset = reader.read32u ();\n return intern_obj_table[obj_counter - offset];\n case 0x08: //cst.CODE_BLOCK32:\n var header = reader.read32u ();\n var tag = header & 0xFF;\n var size = header >> 10;\n var v = [tag];\n if (size == 0) return v;\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n stack.push(v, size);\n return v;\n case 0x13: //cst.CODE_BLOCK64:\n caml_failwith (\"input_value: data block too large\");\n break;\n case 0x09: //cst.CODE_STRING8:\n var len = reader.read8u();\n var v = reader.readstr (len);\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n case 0x0A: //cst.CODE_STRING32:\n var len = reader.read32u();\n var v = reader.readstr (len);\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n case 0x0C: //cst.CODE_DOUBLE_LITTLE:\n var t = new Array(8);;\n for (var i = 0;i < 8;i++) t[7 - i] = reader.read8u ();\n var v = caml_float_of_bytes (t);\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n case 0x0B: //cst.CODE_DOUBLE_BIG:\n var t = new Array(8);;\n for (var i = 0;i < 8;i++) t[i] = reader.read8u ();\n var v = caml_float_of_bytes (t);\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n case 0x0E: //cst.CODE_DOUBLE_ARRAY8_LITTLE:\n var len = reader.read8u();\n var v = new Array(len+1);\n v[0] = 254;\n var t = new Array(8);;\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n for (var i = 1;i <= len;i++) {\n for (var j = 0;j < 8;j++) t[7 - j] = reader.read8u();\n v[i] = caml_float_of_bytes (t);\n }\n return v;\n case 0x0D: //cst.CODE_DOUBLE_ARRAY8_BIG:\n var len = reader.read8u();\n var v = new Array(len+1);\n v[0] = 254;\n var t = new Array(8);;\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n for (var i = 1;i <= len;i++) {\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n v [i] = caml_float_of_bytes (t);\n }\n return v;\n case 0x07: //cst.CODE_DOUBLE_ARRAY32_LITTLE:\n var len = reader.read32u();\n var v = new Array(len+1);\n v[0] = 254;\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n var t = new Array(8);;\n for (var i = 1;i <= len;i++) {\n for (var j = 0;j < 8;j++) t[7 - j] = reader.read8u();\n v[i] = caml_float_of_bytes (t);\n }\n return v;\n case 0x0F: //cst.CODE_DOUBLE_ARRAY32_BIG:\n var len = reader.read32u();\n var v = new Array(len+1);\n v[0] = 254;\n var t = new Array(8);;\n for (var i = 1;i <= len;i++) {\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n v [i] = caml_float_of_bytes (t);\n }\n return v;\n case 0x10: //cst.CODE_CODEPOINTER:\n case 0x11: //cst.CODE_INFIXPOINTER:\n caml_failwith (\"input_value: code pointer\");\n break;\n case 0x12: //cst.CODE_CUSTOM:\n case 0x18: //cst.CODE_CUSTOM_LEN:\n case 0x19: //cst.CODE_CUSTOM_FIXED:\n var c, s = \"\";\n while ((c = reader.read8u ()) != 0) s += String.fromCharCode (c);\n var ops = caml_custom_ops[s];\n var expected_size;\n if(!ops)\n caml_failwith(\"input_value: unknown custom block identifier\");\n switch(code){\n case 0x12: // cst.CODE_CUSTOM (deprecated)\n break;\n case 0x19: // cst.CODE_CUSTOM_FIXED\n if(!ops.fixed_length)\n caml_failwith(\"input_value: expected a fixed-size custom block\");\n expected_size = ops.fixed_length;\n break;\n case 0x18: // cst.CODE_CUSTOM_LEN\n expected_size = reader.read32u ();\n // Skip size64\n reader.read32s(); reader.read32s();\n break;\n }\n var old_pos = reader.i;\n var size = [0];\n var v = ops.deserialize(reader, size);\n if(expected_size != undefined){\n if(expected_size != size[0])\n caml_failwith(\"input_value: incorrect length of serialized custom block\");\n }\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n default:\n caml_failwith (\"input_value: ill-formed message\");\n }\n }\n }\n }\n var res = intern_rec ();\n while (stack.length > 0) {\n var size = stack.pop();\n var v = stack.pop();\n var d = v.length;\n if (d < size) stack.push(v, size);\n v[d] = intern_rec ();\n }\n if (typeof ofs!=\"number\") ofs[0] = reader.i;\n return res;\n}\n\n//Provides: caml_marshal_data_size mutable\n//Requires: caml_failwith, caml_bytes_unsafe_get\nfunction caml_marshal_data_size (s, ofs) {\n function get32(s,i) {\n return (caml_bytes_unsafe_get(s, i) << 24) |\n (caml_bytes_unsafe_get(s, i + 1) << 16) |\n (caml_bytes_unsafe_get(s, i + 2) << 8) |\n caml_bytes_unsafe_get(s, i + 3);\n }\n if (get32(s, ofs) != (0x8495A6BE|0))\n caml_failwith(\"Marshal.data_size: bad object\");\n return (get32(s, ofs + 4));\n}\n\n//Provides: MlObjectTable\nvar MlObjectTable;\nif (typeof globalThis.WeakMap === 'undefined') {\n MlObjectTable = function() {\n /* polyfill (using linear search) */\n function NaiveLookup(objs) { this.objs = objs; }\n NaiveLookup.prototype.get = function(v) {\n for (var i = 0; i < this.objs.length; i++) {\n if (this.objs[i] === v) return i;\n }\n };\n NaiveLookup.prototype.set = function() {\n // Do nothing here. [MlObjectTable.store] will push to [this.objs] directly.\n };\n\n return function MlObjectTable() {\n this.objs = []; this.lookup = new NaiveLookup(this.objs);\n };\n }();\n}\nelse {\n MlObjectTable = function MlObjectTable() {\n this.objs = []; this.lookup = new globalThis.WeakMap();\n };\n}\n\nMlObjectTable.prototype.store = function(v) {\n this.lookup.set(v, this.objs.length);\n this.objs.push(v);\n}\n\nMlObjectTable.prototype.recall = function(v) {\n var i = this.lookup.get(v);\n return (i === undefined)\n ? undefined : this.objs.length - i; /* index is relative */\n}\n\n//Provides: caml_legacy_custom_code\n//Version: >= 4.08\nvar caml_legacy_custom_code = false\n\n//Provides: caml_legacy_custom_code\n//Version: < 4.08\nvar caml_legacy_custom_code = true\n\n//Provides: caml_output_val\n//Requires: caml_int64_to_bytes, caml_failwith\n//Requires: caml_int64_bits_of_float\n//Requires: caml_is_ml_bytes, caml_ml_bytes_length, caml_bytes_unsafe_get\n//Requires: caml_is_ml_string, caml_ml_string_length, caml_string_unsafe_get\n//Requires: MlObjectTable, caml_list_to_js_array, caml_legacy_custom_code, caml_custom_ops\n//Requires: caml_invalid_argument,caml_string_of_jsbytes\nvar caml_output_val = function (){\n function Writer () { this.chunk = []; }\n Writer.prototype = {\n chunk_idx:20, block_len:0, obj_counter:0, size_32:0, size_64:0,\n write:function (size, value) {\n for (var i = size - 8;i >= 0;i -= 8)\n this.chunk[this.chunk_idx++] = (value >> i) & 0xFF;\n },\n write_at:function (pos, size, value) {\n var pos = pos;\n for (var i = size - 8;i >= 0;i -= 8)\n this.chunk[pos++] = (value >> i) & 0xFF;\n },\n write_code:function (size, code, value) {\n this.chunk[this.chunk_idx++] = code;\n for (var i = size - 8;i >= 0;i -= 8)\n this.chunk[this.chunk_idx++] = (value >> i) & 0xFF;\n },\n write_shared:function (offset) {\n if (offset < (1 << 8)) this.write_code(8, 0x04 /*cst.CODE_SHARED8*/, offset);\n else if (offset < (1 << 16)) this.write_code(16, 0x05 /*cst.CODE_SHARED16*/, offset);\n else this.write_code(32, 0x06 /*cst.CODE_SHARED32*/, offset);\n },\n pos:function () { return this.chunk_idx },\n finalize:function () {\n this.block_len = this.chunk_idx - 20;\n this.chunk_idx = 0;\n this.write (32, 0x8495A6BE);\n this.write (32, this.block_len);\n this.write (32, this.obj_counter);\n this.write (32, this.size_32);\n this.write (32, this.size_64);\n return this.chunk;\n }\n }\n return function (v, flags) {\n flags = caml_list_to_js_array(flags);\n\n var no_sharing = (flags.indexOf(0 /*Marshal.No_sharing*/) !== -1),\n closures = (flags.indexOf(1 /*Marshal.Closures*/) !== -1);\n /* Marshal.Compat_32 is redundant since integers are 32-bit anyway */\n\n if (closures)\n globalThis.console.warn(\"in caml_output_val: flag Marshal.Closures is not supported.\");\n\n var writer = new Writer ();\n var stack = [];\n var intern_obj_table = no_sharing ? null : new MlObjectTable();\n\n function memo(v) {\n if (no_sharing) return false;\n var existing_offset = intern_obj_table.recall(v);\n if (existing_offset) { writer.write_shared(existing_offset); return true; }\n else { intern_obj_table.store(v); return false; }\n }\n\n function extern_rec (v) {\n if (v.caml_custom) {\n if (memo(v)) return;\n var name = v.caml_custom;\n var ops = caml_custom_ops[name];\n var sz_32_64 = [0,0];\n if(!ops.serialize)\n caml_invalid_argument(\"output_value: abstract value (Custom)\");\n if(caml_legacy_custom_code) {\n writer.write (8, 0x12 /*cst.CODE_CUSTOM*/);\n for (var i = 0; i < name.length; i++)\n writer.write (8, name.charCodeAt(i));\n writer.write(8, 0);\n ops.serialize(writer, v, sz_32_64);\n } else if(ops.fixed_length == undefined){\n writer.write (8, 0x18 /*cst.CODE_CUSTOM_LEN*/);\n for (var i = 0; i < name.length; i++)\n writer.write (8, name.charCodeAt(i));\n writer.write(8, 0);\n var header_pos = writer.pos ();\n for(var i = 0; i < 12; i++) {\n writer.write(8, 0);\n }\n ops.serialize(writer, v, sz_32_64);\n writer.write_at(header_pos, 32, sz_32_64[0]);\n writer.write_at(header_pos + 4, 32, 0); // zero\n writer.write_at(header_pos + 8, 32, sz_32_64[1]);\n } else {\n writer.write (8, 0x19 /*cst.CODE_CUSTOM_FIXED*/);\n for (var i = 0; i < name.length; i++)\n writer.write (8, name.charCodeAt(i));\n writer.write(8, 0);\n var old_pos = writer.pos();\n ops.serialize(writer, v, sz_32_64);\n if (ops.fixed_length != writer.pos() - old_pos)\n caml_failwith(\"output_value: incorrect fixed sizes specified by \" + name);\n }\n writer.size_32 += 2 + ((sz_32_64[0] + 3) >> 2);\n writer.size_64 += 2 + ((sz_32_64[1] + 7) >> 3);\n }\n else if (v instanceof Array && v[0] === (v[0]|0)) {\n if (v[0] == 251) {\n caml_failwith(\"output_value: abstract value (Abstract)\");\n }\n if (v.length > 1 && memo(v)) return;\n if (v[0] < 16 && v.length - 1 < 8)\n writer.write (8, 0x80 /*cst.PREFIX_SMALL_BLOCK*/ + v[0] + ((v.length - 1)<<4));\n else\n writer.write_code(32, 0x08 /*cst.CODE_BLOCK32*/, ((v.length-1) << 10) | v[0]);\n writer.size_32 += v.length;\n writer.size_64 += v.length;\n if (v.length > 1) stack.push (v, 1);\n } else if (caml_is_ml_bytes(v)) {\n if(!(caml_is_ml_bytes(caml_string_of_jsbytes(\"\")))) {\n caml_failwith(\"output_value: [Bytes.t] cannot safely be marshaled with [--enable use-js-string]\");\n }\n if (memo(v)) return;\n var len = caml_ml_bytes_length(v);\n if (len < 0x20)\n writer.write (8, 0x20 /*cst.PREFIX_SMALL_STRING*/ + len);\n else if (len < 0x100)\n writer.write_code (8, 0x09/*cst.CODE_STRING8*/, len);\n else\n writer.write_code (32, 0x0A /*cst.CODE_STRING32*/, len);\n for (var i = 0;i < len;i++)\n writer.write (8, caml_bytes_unsafe_get(v,i));\n writer.size_32 += 1 + (((len + 4) / 4)|0);\n writer.size_64 += 1 + (((len + 8) / 8)|0);\n } else if (caml_is_ml_string(v)) {\n var len = caml_ml_string_length(v);\n if (len < 0x20)\n writer.write (8, 0x20 /*cst.PREFIX_SMALL_STRING*/ + len);\n else if (len < 0x100)\n writer.write_code (8, 0x09/*cst.CODE_STRING8*/, len);\n else\n writer.write_code (32, 0x0A /*cst.CODE_STRING32*/, len);\n for (var i = 0;i < len;i++)\n writer.write (8, caml_string_unsafe_get(v,i));\n writer.size_32 += 1 + (((len + 4) / 4)|0);\n writer.size_64 += 1 + (((len + 8) / 8)|0);\n } else {\n if (v != (v|0)){\n var type_of_v = typeof v;\n //\n // If a float happens to be an integer it is serialized as an integer\n // (Js_of_ocaml cannot tell whether the type of an integer number is\n // float or integer.) This can result in unexpected crashes when\n // unmarshalling using the standard runtime. It seems better to\n // systematically fail on marshalling.\n //\n // if(type_of_v != \"number\")\n caml_failwith(\"output_value: abstract value (\"+type_of_v+\")\");\n // var t = caml_int64_to_bytes(caml_int64_bits_of_float(v));\n // writer.write (8, 0x0B /*cst.CODE_DOUBLE_BIG*/);\n // for(var i = 0; i<8; i++){writer.write(8,t[i])}\n }\n else if (v >= 0 && v < 0x40) {\n writer.write (8, 0X40 /*cst.PREFIX_SMALL_INT*/ + v);\n } else {\n if (v >= -(1 << 7) && v < (1 << 7))\n writer.write_code(8, 0x00 /*cst.CODE_INT8*/, v);\n else if (v >= -(1 << 15) && v < (1 << 15))\n writer.write_code(16, 0x01 /*cst.CODE_INT16*/, v);\n else\n writer.write_code(32, 0x02 /*cst.CODE_INT32*/, v);\n }\n }\n }\n extern_rec (v);\n while (stack.length > 0) {\n var i = stack.pop ();\n var v = stack.pop ();\n if (i + 1 < v.length) stack.push (v, i + 1);\n extern_rec (v[i]);\n }\n if (intern_obj_table) writer.obj_counter = intern_obj_table.objs.length;\n writer.finalize();\n return writer.chunk;\n }\n} ();\n\n//Provides: caml_output_value_to_string mutable\n//Requires: caml_output_val, caml_string_of_array\nfunction caml_output_value_to_string (v, flags) {\n return caml_string_of_array (caml_output_val (v, flags));\n}\n\n//Provides: caml_output_value_to_bytes mutable\n//Requires: caml_output_val, caml_bytes_of_array\nfunction caml_output_value_to_bytes (v, flags) {\n return caml_bytes_of_array (caml_output_val (v, flags));\n}\n\n//Provides: caml_output_value_to_buffer\n//Requires: caml_output_val, caml_failwith, caml_blit_bytes\nfunction caml_output_value_to_buffer (s, ofs, len, v, flags) {\n var t = caml_output_val (v, flags);\n if (t.length > len) caml_failwith (\"Marshal.to_buffer: buffer overflow\");\n caml_blit_bytes(t, 0, s, ofs, t.length);\n return 0;\n}\n","//Provides: Base_internalhash_fold_int64\n//Requires: caml_hash_mix_int64\nvar Base_internalhash_fold_int64 = caml_hash_mix_int64;\n//Provides: Base_internalhash_fold_int\n//Requires: caml_hash_mix_int\nvar Base_internalhash_fold_int = caml_hash_mix_int;\n//Provides: Base_internalhash_fold_float\n//Requires: caml_hash_mix_float\nvar Base_internalhash_fold_float = caml_hash_mix_float;\n//Provides: Base_internalhash_fold_string\n//Requires: caml_hash_mix_string\nvar Base_internalhash_fold_string = caml_hash_mix_string;\n//Provides: Base_internalhash_get_hash_value\n//Requires: caml_hash_mix_final\nfunction Base_internalhash_get_hash_value(seed) {\n var h = caml_hash_mix_final(seed);\n return h & 0x3FFFFFFF;\n}\n","//Provides: initialize_nat\n//Requires: caml_custom_ops\n//Requires: serialize_nat, deserialize_nat, caml_hash_nat\nfunction initialize_nat() {\n caml_custom_ops[\"_nat\"] =\n { deserialize : deserialize_nat,\n serialize : serialize_nat,\n hash : caml_hash_nat\n }\n}\n\n//Provides: MlNat\nfunction MlNat(x){\n this.data = new globalThis.Int32Array(x);\n // length_nat isn't external, so we have to make the Obj.size\n // work out right. The +2 to array length seems to work.\n this.length = this.data.length + 2\n}\n\nMlNat.prototype.caml_custom = \"_nat\";\n\n//Provides: caml_hash_nat\n//Requires: caml_hash_mix_int, num_digits_nat\nfunction caml_hash_nat(x) {\n var len = num_digits_nat(x, 0, x.data.length);\n var h = 0;\n for (var i = 0; i < len; i++) {\n h = caml_hash_mix_int(h, x.data[i]);\n }\n return h;\n}\n\n\n//Provides: nat_of_array\n//Requires: MlNat\nfunction nat_of_array(l){\n return new MlNat(l);\n}\n\n//Provides: create_nat\n//Requires: MlNat\nfunction create_nat(size) {\n var arr = new MlNat(size);\n for(var i = 0; i < size; i++) {\n arr.data[i] = -1;\n }\n return arr;\n}\n\n//Provides: set_to_zero_nat\nfunction set_to_zero_nat(nat, ofs, len) {\n for(var i = 0; i < len; i++) {\n nat.data[ofs+i] = 0;\n }\n return 0;\n}\n\n//Provides: blit_nat\nfunction blit_nat(nat1, ofs1, nat2, ofs2, len) {\n for(var i = 0; i < len; i++) {\n nat1.data[ofs1+i] = nat2.data[ofs2+i];\n }\n return 0;\n}\n\n//Provides: set_digit_nat\nfunction set_digit_nat(nat, ofs, digit) {\n nat.data[ofs] = digit;\n return 0;\n}\n\n//Provides: nth_digit_nat\nfunction nth_digit_nat(nat, ofs) {\n return nat.data[ofs];\n}\n\n//Provides: set_digit_nat_native\nfunction set_digit_nat_native(nat, ofs, digit) {\n nat.data[ofs] = digit;\n return 0;\n}\n\n//Provides: nth_digit_nat_native\nfunction nth_digit_nat_native(nat, ofs) {\n return nat.data[ofs];\n}\n\n//Provides: num_digits_nat\nfunction num_digits_nat(nat, ofs, len) {\n for(var i = len - 1; i >= 0; i--) {\n if(nat.data[ofs+i] != 0) return i+1;\n }\n return 1; // 0 counts as 1 digit\n}\n\n//Provides: num_leading_zero_bits_in_digit\nfunction num_leading_zero_bits_in_digit(nat, ofs) {\n var a = nat.data[ofs];\n var b = 0;\n if(a & 0xFFFF0000) { b +=16; a >>>=16; }\n if(a & 0xFF00) { b += 8; a >>>= 8; }\n if(a & 0xF0) { b += 4; a >>>= 4; }\n if(a & 12) { b += 2; a >>>= 2; }\n if(a & 2) { b += 1; a >>>= 1; }\n if(a & 1) { b += 1; }\n return 32 - b;\n}\n\n//Provides: is_digit_int\nfunction is_digit_int(nat, ofs) {\n if (nat.data[ofs] >= 0) return 1\n return 0;\n}\n\n//Provides: is_digit_zero\nfunction is_digit_zero(nat, ofs) {\n if(nat.data[ofs] == 0) return 1;\n return 0;\n}\n\n//Provides: is_digit_odd\nfunction is_digit_odd(nat, ofs) {\n if(nat.data[ofs] & 1) return 1;\n return 0;\n}\n\n//Provides: incr_nat\nfunction incr_nat(nat, ofs, len, carry_in) {\n var carry = carry_in;\n for(var i = 0; i < len; i++) {\n var x = (nat.data[ofs+i] >>> 0) + carry;\n nat.data[ofs+i] = (x | 0);\n if(x == (x >>> 0)) {\n carry = 0;\n break;\n } else {\n carry = 1;\n }\n }\n return carry;\n}\n\n// len1 >= len2\n//Provides: add_nat\n//Requires: incr_nat\nfunction add_nat(nat1, ofs1, len1, nat2, ofs2, len2, carry_in) {\n var carry = carry_in;\n for(var i = 0; i < len2; i++) {\n var x = (nat1.data[ofs1+i] >>> 0) + (nat2.data[ofs2+i] >>> 0) + carry;\n nat1.data[ofs1+i] = x\n if(x == (x >>> 0)) {\n carry = 0;\n } else {\n carry = 1;\n }\n }\n return incr_nat(nat1, ofs1+len2, len1-len2, carry);\n}\n\n//Provides: complement_nat\nfunction complement_nat(nat, ofs, len) {\n for(var i = 0; i < len; i++) {\n nat.data[ofs+i] = (-1 >>> 0) - (nat.data[ofs+i] >>> 0);\n }\n}\n\n// ocaml flips carry_in\n//Provides: decr_nat\nfunction decr_nat(nat, ofs, len, carry_in) {\n var borrow = (carry_in == 1) ? 0 : 1;\n for(var i = 0; i < len; i++) {\n var x = (nat.data[ofs+i] >>>0) - borrow;\n nat.data[ofs+i] = x;\n if (x >= 0) {\n borrow = 0;\n break;\n } else {\n borrow = 1;\n }\n }\n return (borrow == 1) ? 0 : 1;\n}\n\n// ocaml flips carry_in\n// len1 >= len2\n//Provides: sub_nat\n//Requires: decr_nat\nfunction sub_nat(nat1, ofs1, len1, nat2, ofs2, len2, carry_in) {\n var borrow = (carry_in == 1) ? 0 : 1;\n for(var i = 0; i < len2; i++) {\n var x = (nat1.data[ofs1+i] >>> 0) - (nat2.data[ofs2+i] >>> 0) - borrow;\n nat1.data[ofs1+i] = x;\n if (x >= 0) {\n borrow = 0;\n } else {\n borrow = 1;\n }\n }\n return decr_nat(nat1, ofs1+len2, len1-len2, (borrow==1)?0:1);\n}\n\n// nat1 += nat2 * nat3[ofs3]\n// len1 >= len2\n//Provides: mult_digit_nat\n//Requires: add_nat, nat_of_array\nfunction mult_digit_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat3, ofs3) {\n var carry = 0;\n var a = (nat3.data[ofs3] >>> 0);\n for(var i = 0; i < len2; i++) {\n var x1 = (nat1.data[ofs1+i] >>> 0) + (nat2.data[ofs2+i] >>> 0) * (a & 0x0000FFFF) + carry;\n var x2 = (nat2.data[ofs2+i] >>> 0) * (a >>> 16);\n carry = Math.floor(x2/65536);\n var x3 = x1 + (x2 % 65536) * 65536;\n nat1.data[ofs1+i] = x3;\n carry += Math.floor(x3/4294967296);\n }\n\n if(len2 < len1 && carry) {\n return add_nat(nat1, ofs1+len2, len1-len2, nat_of_array([carry]), 0, 1, 0);\n } else {\n return carry;\n }\n}\n\n// nat1 += nat2 * nat3\n// len1 >= len2 + len3.\n//Provides: mult_nat\n//Requires: mult_digit_nat\nfunction mult_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat3, ofs3, len3) {\n var carry = 0;\n for(var i = 0; i < len3; i++) {\n carry += mult_digit_nat(nat1, ofs1+i, len1-i, nat2, ofs2, len2, nat3, ofs3+i);\n }\n return carry;\n}\n\n// nat1 = 2 * nat1 + nat2 * nat2\n// len1 >= 2 * len2\n//Provides: square_nat\n//Requires: mult_nat, add_nat\nfunction square_nat(nat1, ofs1, len1, nat2, ofs2, len2) {\n var carry = 0;\n carry += add_nat(nat1, ofs1, len1, nat1, ofs1, len1, 0);\n carry += mult_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat2, ofs2, len2);\n return carry;\n}\n\n\n// 0 <= shift < 32\n//Provides: shift_left_nat\nfunction shift_left_nat(nat1, ofs1, len1, nat2, ofs2, nbits) {\n if(nbits == 0) {\n nat2.data[ofs2] = 0;\n return 0;\n }\n var wrap = 0;\n for(var i = 0; i < len1; i++) {\n var a = (nat1.data[ofs1+i] >>> 0);\n nat1.data[ofs1+i] = (a << nbits) | wrap;\n wrap = a >>> (32 - nbits);\n }\n nat2.data[ofs2] = wrap;\n return 0;\n}\n\n// Assuming c > a, returns [quotient, remainder] of (a<<32 + b)/c\n//Provides: div_helper\nfunction div_helper(a, b, c) {\n var x = a * 65536 + (b>>>16);\n var y = Math.floor(x/c) * 65536;\n var z = (x % c) * 65536;\n var w = z + (b & 0x0000FFFF);\n return [y + Math.floor(w/c), w % c];\n}\n\n// nat1[ofs1+len] < nat2[ofs2]\n//Provides: div_digit_nat\n//Requires: div_helper\nfunction div_digit_nat(natq, ofsq, natr, ofsr, nat1, ofs1, len, nat2, ofs2) {\n var rem = (nat1.data[ofs1+len-1] >>>0);\n // natq[ofsq+len-1] is guaranteed to be zero (due to the MSD requirement),\n // and should not be written to.\n for(var i = len-2; i >= 0; i--) {\n var x = div_helper(rem, (nat1.data[ofs1+i] >>> 0), (nat2.data[ofs2] >>> 0));\n natq.data[ofsq+i] = x[0];\n rem = x[1];\n }\n natr.data[ofsr] = rem;\n return 0;\n}\n\n// nat1[nat2:] := nat1 / nat2\n// nat1[:nat2] := nat1 % nat2\n// len1 > len2, nat2[ofs2+len2-1] > nat1[ofs1+len1-1]\n//Provides: div_nat\n//Requires: div_digit_nat, div_helper, num_leading_zero_bits_in_digit, shift_left_nat, shift_right_nat, create_nat, set_to_zero_nat, mult_digit_nat, sub_nat, compare_nat, nat_of_array\nfunction div_nat(nat1, ofs1, len1, nat2, ofs2, len2) {\n if(len2 == 1) {\n div_digit_nat(nat1, ofs1+1, nat1, ofs1, nat1, ofs1, len1, nat2, ofs2);\n return 0;\n }\n\n var s = num_leading_zero_bits_in_digit(nat2, ofs2+len2-1);\n shift_left_nat(nat2, ofs2, len2, nat_of_array([0]), 0, s);\n shift_left_nat(nat1, ofs1, len1, nat_of_array([0]), 0, s);\n\n var d = (nat2.data[ofs2+len2-1] >>> 0) + 1;\n var a = create_nat(len2+1);\n for (var i = len1 - 1; i >= len2; i--) {\n // Decent lower bound on quo\n var quo = d == 4294967296 ? (nat1.data[ofs1+i] >>> 0) : div_helper((nat1.data[ofs1+i] >>> 0), (nat1.data[ofs1+i-1] >>>0), d)[0];\n set_to_zero_nat(a, 0, len2+1);\n mult_digit_nat(a, 0, len2+1, nat2, ofs2, len2, nat_of_array([quo]), 0);\n sub_nat(nat1, ofs1+i-len2, len2+1, a, 0, len2+1, 1);\n\n while (nat1.data[ofs1+i] != 0 || compare_nat(nat1, ofs1+i-len2, len2, nat2, ofs2, len2) >= 0) {\n quo = quo + 1;\n sub_nat(nat1, ofs1+i-len2, len2+1, nat2, ofs2, len2, 1);\n }\n\n nat1.data[ofs1+i] = quo;\n }\n\n shift_right_nat(nat1, ofs1, len2, nat_of_array([0]), 0, s); // shift remainder\n shift_right_nat(nat2, ofs2, len2, nat_of_array([0]), 0, s); // restore\n return 0;\n}\n\n\n// 0 <= shift < 32\n//Provides: shift_right_nat\nfunction shift_right_nat(nat1, ofs1, len1, nat2, ofs2, nbits) {\n if(nbits == 0) {\n nat2.data[ofs2] = 0;\n return 0;\n }\n var wrap = 0;\n for(var i = len1-1; i >= 0; i--) {\n var a = nat1.data[ofs1+i] >>> 0;\n nat1.data[ofs1+i] = (a >>> nbits) | wrap;\n wrap = a << (32 - nbits);\n }\n nat2.data[ofs2] = wrap;\n return 0;\n}\n\n//Provides: compare_digits_nat\nfunction compare_digits_nat(nat1, ofs1, nat2, ofs2) {\n if(nat1.data[ofs1] > nat2.data[ofs2]) return 1;\n if(nat1.data[ofs1] < nat2.data[ofs2]) return -1;\n return 0;\n}\n\n//Provides: compare_nat\n//Requires: num_digits_nat\nfunction compare_nat(nat1, ofs1, len1, nat2, ofs2, len2) {\n var a = num_digits_nat(nat1, ofs1, len1);\n var b = num_digits_nat(nat2, ofs2, len2);\n if(a > b) return 1;\n if(a < b) return -1;\n for(var i = len1 - 1; i >= 0; i--) {\n if ((nat1.data[ofs1+i] >>> 0) > (nat2.data[ofs2+i] >>> 0)) return 1;\n if ((nat1.data[ofs1+i] >>> 0) < (nat2.data[ofs2+i] >>> 0)) return -1;\n }\n return 0;\n}\n\n//Provides: compare_nat_real\n//Requires: compare_nat\nfunction compare_nat_real(nat1,nat2){\n return compare_nat(nat1,0,nat1.data.length,nat2,0,nat2.data.length);\n}\n\n//Provides: land_digit_nat\nfunction land_digit_nat(nat1, ofs1, nat2, ofs2) {\n nat1.data[ofs1] &= nat2.data[ofs2];\n return 0;\n}\n\n//Provides: lor_digit_nat\nfunction lor_digit_nat(nat1, ofs1, nat2, ofs2) {\n nat1.data[ofs1] |= nat2.data[ofs2];\n return 0;\n}\n\n//Provides: lxor_digit_nat\nfunction lxor_digit_nat(nat1, ofs1, nat2, ofs2) {\n nat1.data[ofs1] ^= nat2.data[ofs2];\n return 0;\n}\n\n\n//Provides: serialize_nat\nfunction serialize_nat(writer, nat, sz){\n var len = nat.data.length;\n writer.write(32, len);\n for(var i = 0; i < len; i++){\n writer.write(32, nat.data[i]);\n }\n sz[0] = len * 4;\n sz[1] = len * 8;\n}\n\n//Provides: deserialize_nat\n//Requires: MlNat\nfunction deserialize_nat(reader, sz){\n var len = reader.read32s();\n var nat = new MlNat(len);\n for(var i = 0; i < len; i++){\n nat.data[i] = reader.read32s();\n }\n sz[0] = len * 4;\n return nat;\n}\n","// Js_of_ocaml library\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Jslib\n\n//Provides: caml_js_pure_expr const\nfunction caml_js_pure_expr (f) { return f(); }\n\n//Provides: caml_js_set (mutable, const, const)\nfunction caml_js_set(o,f,v) { o[f]=v;return 0}\n//Provides: caml_js_get mutable (const, const)\nfunction caml_js_get(o,f) { return o[f]; }\n//Provides: caml_js_delete (mutable, const)\nfunction caml_js_delete(o,f) { delete o[f]; return 0}\n\n//Provides: caml_js_instanceof (const, const)\nfunction caml_js_instanceof(o,c) { return (o instanceof c) ? 1 : 0; }\n\n//Provides: caml_js_typeof (const)\nfunction caml_js_typeof(o) { return typeof o; }\n\n//Provides:caml_trampoline\nfunction caml_trampoline(res) {\n var c = 1;\n while(res && res.joo_tramp){\n res = res.joo_tramp.apply(null, res.joo_args);\n c++;\n }\n return res;\n}\n\n//Provides:caml_trampoline_return\nfunction caml_trampoline_return(f,args) {\n return {joo_tramp:f,joo_args:args};\n}\n\n//Provides: js_print_stdout (const)\n//Requires: caml_utf16_of_utf8\nfunction js_print_stdout(s) {\n var s = caml_utf16_of_utf8(s);\n var g = globalThis;\n if (g.process && g.process.stdout && g.process.stdout.write) {\n g.process.stdout.write(s)\n } else {\n // Do not output the last \\n if present\n // as console logging display a newline at the end\n if(s.charCodeAt(s.length - 1) == 10)\n s = s.substr(0,s.length - 1 );\n var v = g.console;\n v && v.log && v.log(s);\n }\n}\n//Provides: js_print_stderr (const)\n//Requires: caml_utf16_of_utf8\nfunction js_print_stderr(s) {\n var s = caml_utf16_of_utf8(s);\n var g = globalThis;\n if (g.process && g.process.stdout && g.process.stdout.write) {\n g.process.stderr.write(s)\n } else {\n // Do not output the last \\n if present\n // as console logging display a newline at the end\n if(s.charCodeAt(s.length - 1) == 10)\n s = s.substr(0,s.length - 1 );\n var v = g.console;\n v && v.error && v.error(s);\n }\n}\n\n//Provides: caml_is_js\nfunction caml_is_js() {\n return 1;\n}\n\n//Provides: caml_wrap_exception const (const)\n//Requires: caml_global_data,caml_string_of_jsstring,caml_named_value\n//Requires: caml_return_exn_constant\nfunction caml_wrap_exception(e) {\n if(e instanceof Array) return e;\n //Stack_overflow: chrome, safari\n if(globalThis.RangeError\n && e instanceof globalThis.RangeError\n && e.message\n && e.message.match(/maximum call stack/i))\n return caml_return_exn_constant(caml_global_data.Stack_overflow);\n //Stack_overflow: firefox\n if(globalThis.InternalError\n && e instanceof globalThis.InternalError\n && e.message\n && e.message.match(/too much recursion/i))\n return caml_return_exn_constant(caml_global_data.Stack_overflow);\n //Wrap Error in Js.Error exception\n if(e instanceof globalThis.Error && caml_named_value(\"jsError\"))\n return [0,caml_named_value(\"jsError\"),e];\n //fallback: wrapped in Failure\n return [0,caml_global_data.Failure,caml_string_of_jsstring (String(e))];\n}\n\n// Experimental\n//Provides: caml_exn_with_js_backtrace\n//Requires: caml_global_data\nfunction caml_exn_with_js_backtrace(exn, force) {\n //never reraise for constant exn\n if(!exn.js_error || force || exn[0] == 248) exn.js_error = new globalThis.Error(\"Js exception containing backtrace\");\n return exn;\n}\n\n\n//Provides: caml_js_error_option_of_exception\nfunction caml_js_error_option_of_exception(exn) {\n if(exn.js_error) { return [0, exn.js_error]; }\n return 0;\n}\n\n\n\n//Provides: caml_js_from_bool const (const)\nfunction caml_js_from_bool(x) { return !!x; }\n//Provides: caml_js_to_bool const (const)\nfunction caml_js_to_bool(x) { return +x; }\n//Provides: caml_js_from_float const (const)\nfunction caml_js_from_float(x) { return x; }\n//Provides: caml_js_to_float const (const)\nfunction caml_js_to_float(x) { return x; }\n\n//Provides: caml_js_from_array mutable (shallow)\nfunction caml_js_from_array(a) {\n return a.slice(1);\n}\n//Provides: caml_js_to_array mutable (shallow)\nfunction caml_js_to_array(a) {\n var len = a.length;\n var b = new Array(len+1);\n b[0] = 0;\n for(var i=0;i=0; i--){\n var e = a[i];\n l = [0,e,l];\n }\n return l\n}\n\n//Provides: caml_list_to_js_array const (const)\nfunction caml_list_to_js_array(l){\n var a = [];\n for(; l !== 0; l = l[2]) {\n a.push(l[1]);\n }\n return a;\n}\n\n//Provides: caml_js_var mutable (const)\n//Requires: js_print_stderr\n//Requires: caml_jsstring_of_string\nfunction caml_js_var(x) {\n var x = caml_jsstring_of_string(x);\n //Checks that x has the form ident[.ident]*\n if(!x.match(/^[a-zA-Z_$][a-zA-Z_$0-9]*(\\.[a-zA-Z_$][a-zA-Z_$0-9]*)*$/)){\n js_print_stderr(\"caml_js_var: \\\"\" + x + \"\\\" is not a valid JavaScript variable. continuing ..\");\n //globalThis.console.error(\"Js.Unsafe.eval_string\")\n }\n return eval(x);\n}\n//Provides: caml_js_call (const, mutable, shallow)\n//Requires: caml_js_from_array\nfunction caml_js_call(f, o, args) { return f.apply(o, caml_js_from_array(args)); }\n//Provides: caml_js_fun_call (const, shallow)\n//Requires: caml_js_from_array\nfunction caml_js_fun_call(f, a) {\n switch (a.length) {\n case 1: return f();\n case 2: return f (a[1]);\n case 3: return f (a[1],a[2]);\n case 4: return f (a[1],a[2],a[3]);\n case 5: return f (a[1],a[2],a[3],a[4]);\n case 6: return f (a[1],a[2],a[3],a[4],a[5]);\n case 7: return f (a[1],a[2],a[3],a[4],a[5],a[6]);\n case 8: return f (a[1],a[2],a[3],a[4],a[5],a[6],a[7]);\n }\n return f.apply(null, caml_js_from_array(a));\n}\n//Provides: caml_js_meth_call (mutable, const, shallow)\n//Requires: caml_jsstring_of_string\n//Requires: caml_js_from_array\nfunction caml_js_meth_call(o, f, args) {\n return o[caml_jsstring_of_string(f)].apply(o, caml_js_from_array(args));\n}\n//Provides: caml_js_new (const, shallow)\n//Requires: caml_js_from_array\nfunction caml_js_new(c, a) {\n switch (a.length) {\n case 1: return new c;\n case 2: return new c (a[1]);\n case 3: return new c (a[1],a[2]);\n case 4: return new c (a[1],a[2],a[3]);\n case 5: return new c (a[1],a[2],a[3],a[4]);\n case 6: return new c (a[1],a[2],a[3],a[4],a[5]);\n case 7: return new c (a[1],a[2],a[3],a[4],a[5],a[6]);\n case 8: return new c (a[1],a[2],a[3],a[4],a[5],a[6],a[7]);\n }\n function F() { return c.apply(this, caml_js_from_array(a)); }\n F.prototype = c.prototype;\n return new F;\n}\n//Provides: caml_ojs_new_arr (const, shallow)\n//Requires: caml_js_from_array\nfunction caml_ojs_new_arr(c, a) {\n switch (a.length) {\n case 0: return new c;\n case 1: return new c (a[0]);\n case 2: return new c (a[0],a[1]);\n case 3: return new c (a[0],a[1],a[2]);\n case 4: return new c (a[0],a[1],a[2],a[3]);\n case 5: return new c (a[0],a[1],a[2],a[3],a[4]);\n case 6: return new c (a[0],a[1],a[2],a[3],a[4],a[5]);\n case 7: return new c (a[0],a[1],a[2],a[3],a[4],a[5],a[6]);\n }\n function F() { return c.apply(this, a); }\n F.prototype = c.prototype;\n return new F;\n}\n//Provides: caml_js_wrap_callback const (const)\n//Requires: caml_call_gen\nfunction caml_js_wrap_callback(f) {\n return function () {\n var len = arguments.length;\n if(len > 0){\n var args = new Array(len);\n for (var i = 0; i < len; i++) args[i] = arguments[i];\n return caml_call_gen(f, args);\n } else {\n return caml_call_gen(f, [undefined]);\n }\n }\n}\n\n//Provides: caml_js_wrap_callback_arguments\n//Requires: caml_call_gen\nfunction caml_js_wrap_callback_arguments(f) {\n return function() {\n var len = arguments.length;\n var args = new Array(len);\n for (var i = 0; i < len; i++) args[i] = arguments[i];\n return caml_call_gen(f, [args]);\n }\n}\n//Provides: caml_js_wrap_callback_strict const\n//Requires: caml_call_gen\nfunction caml_js_wrap_callback_strict(arity, f) {\n return function () {\n var n = arguments.length;\n if(n == arity && f.length == arity) return f.apply(null, arguments);\n var args = new Array(arity);\n var len = Math.min(arguments.length, arity)\n for (var i = 0; i < len; i++) args[i] = arguments[i];\n return caml_call_gen(f, args);\n };\n}\n//Provides: caml_js_wrap_meth_callback const (const)\n//Requires: caml_call_gen\nfunction caml_js_wrap_meth_callback(f) {\n return function () {\n var len = arguments.length;\n var args = new Array(len + 1);\n args[0] = this;\n for (var i = 0; i < len; i++) args[i+1] = arguments[i];\n return caml_call_gen(f,args);\n }\n}\n//Provides: caml_js_wrap_meth_callback_arguments const (const)\n//Requires: caml_call_gen\nfunction caml_js_wrap_meth_callback_arguments(f) {\n return function () {\n var len = arguments.length;\n var args = new Array(len);\n for (var i = 0; i < len; i++) args[i] = arguments[i];\n return caml_call_gen(f,[this,args]);\n }\n}\n//Provides: caml_js_wrap_meth_callback_strict const\n//Requires: caml_call_gen\nfunction caml_js_wrap_meth_callback_strict(arity, f) {\n return function () {\n var args = new Array(arity + 1);\n var len = Math.min(arguments.length, arity)\n args[0] = this;\n for (var i = 0; i < len; i++) args[i+1] = arguments[i];\n return caml_call_gen(f, args);\n };\n}\n//Provides: caml_js_wrap_meth_callback_unsafe const (const)\n//Requires: caml_call_gen\nfunction caml_js_wrap_meth_callback_unsafe(f) {\n return function () {\n var len = arguments.length;\n var args = new Array(len + 1);\n args[0] = this;\n for (var i = 0; i < len; i++) args[i+1] = arguments[i];\n return f.apply(null, args); }\n}\n//Provides: caml_js_equals mutable (const, const)\nfunction caml_js_equals (x, y) { return +(x == y); }\n\n//Provides: caml_js_eval_string (const)\n//Requires: caml_jsstring_of_string\nfunction caml_js_eval_string (s) {return eval(caml_jsstring_of_string(s));}\n\n//Provides: caml_js_expr (const)\n//Requires: js_print_stderr\n//Requires: caml_jsstring_of_string\nfunction caml_js_expr(s) {\n js_print_stderr(\"caml_js_expr: fallback to runtime evaluation\\n\");\n return eval(caml_jsstring_of_string(s));}\n\n//Provides: caml_pure_js_expr const (const)\n//Requires: js_print_stderr\n//Requires: caml_jsstring_of_string\nfunction caml_pure_js_expr (s){\n js_print_stderr(\"caml_pure_js_expr: fallback to runtime evaluation\\n\");\n return eval(caml_jsstring_of_string(s));}\n\n//Provides: caml_js_object (object_literal)\n//Requires: caml_jsstring_of_string\nfunction caml_js_object (a) {\n var o = {};\n for (var i = 1; i < a.length; i++) {\n var p = a[i];\n o[caml_jsstring_of_string(p[1])] = p[2];\n }\n return o;\n}\n","///////// BIGSTRING\n\n//Provides: bigstring_alloc\n//Requires: caml_ba_create\nfunction bigstring_alloc(_,size){\n return caml_ba_create(12, 0, [0,size]);\n}\n\n//Provides: bigstring_is_mmapped_stub\nfunction bigstring_is_mmapped_stub(x){\n return 0;\n}\n\n//Provides: bigstring_blit_stub\n//Requires: caml_bigstring_blit_ba_to_ba\nfunction bigstring_blit_stub(s1, i1, s2, i2, len){\n return caml_bigstring_blit_ba_to_ba(s1,i1,s2,i2,len);\n}\n\n//Provides: bigstring_blit_bytes_bigstring_stub\n//Requires: caml_bigstring_blit_bytes_to_ba\nfunction bigstring_blit_bytes_bigstring_stub(src, src_pos, dst, dst_pos, len){\n return caml_bigstring_blit_bytes_to_ba(src,src_pos,dst,dst_pos,len);\n}\n\n//Provides: bigstring_blit_bigstring_bytes_stub\n//Requires: caml_bigstring_blit_ba_to_bytes\nfunction bigstring_blit_bigstring_bytes_stub(src, src_pos, dst, dst_pos, len){\n return caml_bigstring_blit_ba_to_bytes(src,src_pos,dst,dst_pos,len);\n}\n\n//Provides: bigstring_blit_string_bigstring_stub\n//Requires: caml_bigstring_blit_string_to_ba\nfunction bigstring_blit_string_bigstring_stub(src, src_pos, dst, dst_pos, len){\n return caml_bigstring_blit_string_to_ba(src,src_pos,dst,dst_pos,len);\n}\n\n//Provides: bigstring_memset_stub\n//Requires: caml_ba_set_1\nfunction bigstring_memset_stub(bigstring, v_pos, v_len, v_char) {\n for (var i = 0; i < v_len; i++) {\n caml_ba_set_1(bigstring, v_pos + i, v_char);\n }\n}\n\n//Provides: bigstring_memcmp_stub\n//Requires: caml_ba_get_1\nfunction bigstring_memcmp_stub(v_s1, v_s1_pos, v_s2, v_s2_pos, v_len){\n for (var i = 0; i < v_len; i++) {\n var a = caml_ba_get_1(v_s1,v_s1_pos + i);\n var b = caml_ba_get_1(v_s2,v_s2_pos + i);\n if (a < b) return -1;\n if (a > b) return 1;\n }\n return 0;\n}\n\n//Provides: internalhash_fold_bigstring\n//Requires: caml_hash_mix_bigstring\nvar internalhash_fold_bigstring = caml_hash_mix_bigstring\n\n//Provides: bigstring_find\n//Requires: caml_ba_get_1\nfunction bigstring_find(bs, chr, pos, len){\n while(len > 0){\n if(caml_ba_get_1(bs,pos) == chr) return pos;\n pos++;\n len--;\n }\n return -1;\n}\n","///////// BIGSTRING\n\n//Provides: caml_hash_mix_bigstring\n//Requires: caml_hash_mix_bytes_arr\nfunction caml_hash_mix_bigstring(h, bs) {\n return caml_hash_mix_bytes_arr(h,bs.data);\n}\n\n//Provides: bigstring_to_array_buffer mutable\nfunction bigstring_to_array_buffer(bs) {\n return bs.data.buffer\n}\n\n//Provides: bigstring_to_typed_array mutable\nfunction bigstring_to_typed_array(bs) {\n return bs.data\n}\n\n//Provides: bigstring_of_array_buffer mutable\n//Requires: caml_ba_create_unsafe\nfunction bigstring_of_array_buffer(ab) {\n var ta = new globalThis.Uint8Array(ab);\n return caml_ba_create_unsafe(12, 0, [ta.length], ta);\n}\n\n//Provides: bigstring_of_typed_array mutable\n//Requires: caml_ba_create_unsafe\nfunction bigstring_of_typed_array(ba) {\n var ta = new globalThis.Uint8Array(ba.buffer, ba.byteOffset, ba.length * ba.BYTES_PER_ELEMENT);\n return caml_ba_create_unsafe(12, 0, [ta.length], ta);\n}\n\n//Provides: caml_bigstring_memcmp\n//Requires: caml_ba_get_1\nfunction caml_bigstring_memcmp(s1, pos1, s2, pos2, len){\n for (var i = 0; i < len; i++) {\n var a = caml_ba_get_1(s1,pos1 + i);\n var b = caml_ba_get_1(s2,pos2 + i);\n if (a < b) return -1;\n if (a > b) return 1;\n }\n return 0;\n}\n\n//Provides: caml_bigstring_blit_ba_to_ba\n//Requires: caml_invalid_argument, caml_array_bound_error\nfunction caml_bigstring_blit_ba_to_ba(ba1, pos1, ba2, pos2, len){\n if(12 != ba1.kind)\n caml_invalid_argument(\"caml_bigstring_blit_ba_to_ba: kind mismatch\");\n if(12 != ba2.kind)\n caml_invalid_argument(\"caml_bigstring_blit_ba_to_ba: kind mismatch\");\n if(len == 0) return 0;\n var ofs1 = ba1.offset(pos1);\n var ofs2 = ba2.offset(pos2);\n if(ofs1 + len > ba1.data.length){\n caml_array_bound_error();\n }\n if(ofs2 + len > ba2.data.length){\n caml_array_bound_error();\n }\n var slice = ba1.data.subarray(ofs1,ofs1+len);\n ba2.data.set(slice,pos2);\n return 0\n}\n\n//Provides: caml_bigstring_blit_string_to_ba\n//Requires: caml_invalid_argument, caml_array_bound_error, caml_array_of_string\n//Requires: caml_ml_string_length\nfunction caml_bigstring_blit_string_to_ba(str1, pos1, ba2, pos2, len){\n if(12 != ba2.kind)\n caml_invalid_argument(\"caml_bigstring_blit_string_to_ba: kind mismatch\");\n if(len == 0) return 0;\n var ofs2 = ba2.offset(pos2);\n if(pos1 + len > caml_ml_string_length(str1)) {\n caml_array_bound_error();\n }\n if(ofs2 + len > ba2.data.length) {\n caml_array_bound_error();\n }\n var slice = caml_array_of_string(str1).slice(pos1,pos1 + len);\n ba2.data.set(slice,ofs2);\n return 0\n}\n\n//Provides: caml_bigstring_blit_bytes_to_ba\n//Requires: caml_invalid_argument, caml_array_bound_error, caml_array_of_bytes\n//Requires: caml_ml_bytes_length\nfunction caml_bigstring_blit_bytes_to_ba(str1, pos1, ba2, pos2, len){\n if(12 != ba2.kind)\n caml_invalid_argument(\"caml_bigstring_blit_string_to_ba: kind mismatch\");\n if(len == 0) return 0;\n var ofs2 = ba2.offset(pos2);\n if(pos1 + len > caml_ml_bytes_length(str1)) {\n caml_array_bound_error();\n }\n if(ofs2 + len > ba2.data.length) {\n caml_array_bound_error();\n }\n var slice = caml_array_of_bytes(str1).slice(pos1,pos1 + len);\n ba2.data.set(slice,ofs2);\n return 0\n}\n\n//Provides: caml_bigstring_blit_ba_to_bytes\n//Requires: caml_invalid_argument, caml_array_bound_error\n//Requires: caml_blit_bytes, caml_bytes_of_array\n//Requires: caml_ml_bytes_length\nfunction caml_bigstring_blit_ba_to_bytes(ba1, pos1, bytes2, pos2, len){\n if(12 != ba1.kind)\n caml_invalid_argument(\"caml_bigstring_blit_string_to_ba: kind mismatch\");\n if(len == 0) return 0;\n var ofs1 = ba1.offset(pos1);\n if(ofs1 + len > ba1.data.length){\n caml_array_bound_error();\n }\n if(pos2 + len > caml_ml_bytes_length(bytes2)){\n caml_array_bound_error();\n }\n var slice = ba1.data.slice(ofs1, ofs1+len);\n caml_blit_bytes(caml_bytes_of_array(slice), 0, bytes2, pos2, len);\n return 0\n}\n","/*----------------------------------------------------------------------------\n Copyright (c) 2017 Inhabited Type LLC.\n\n All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions\n are met:\n\n 1. Redistributions of source code must retain the above copyright\n notice, this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in the\n documentation and/or other materials provided with the distribution.\n\n 3. Neither the name of the author nor the names of his contributors\n may be used to endorse or promote products derived from this software\n without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS ``AS IS'' AND ANY EXPRESS\n OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR\n ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\n STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN\n ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n POSSIBILITY OF SUCH DAMAGE.\n ----------------------------------------------------------------------------*/\n\n//Provides: bigstringaf_blit_to_bytes\n//Requires: caml_string_unsafe_set, caml_ba_get_1\nfunction bigstringaf_blit_to_bytes(src, src_off, dst, dst_off, len) {\n for (var i = 0; i < len; i++) {\n caml_string_unsafe_set(dst, dst_off + i, caml_ba_get_1(src, src_off + i));\n }\n}\n\n//Provides: bigstringaf_blit_to_bigstring\n//Requires: caml_ba_set_1, caml_ba_get_1\nfunction bigstringaf_blit_to_bigstring(src, src_off, dst, dst_off, len) {\n for (var i = 0; i < len; i++) {\n caml_ba_set_1(dst, dst_off + i, caml_ba_get_1(src, src_off + i));\n }\n}\n\n//Provides: bigstringaf_blit_from_bytes\n//Requires: caml_ba_set_1, caml_string_unsafe_get\nfunction bigstringaf_blit_from_bytes(src, src_off, dst, dst_off, len) {\n for (var i = 0; i < len; i++) {\n caml_ba_set_1(dst, dst_off + i, caml_string_unsafe_get(src, src_off + i));\n }\n}\n\n//Provides: bigstringaf_memcmp_bigstring\n//Requires: caml_ba_get_1, caml_int_compare\nfunction bigstringaf_memcmp_bigstring(ba1, ba1_off, ba2, ba2_off, len) {\n for (var i = 0; i < len; i++) {\n var c = caml_int_compare(caml_ba_get_1(ba1, ba1_off + i), caml_ba_get_1(ba2, ba2_off + i));\n if (c != 0) return c\n }\n return 0;\n}\n\n//Provides: bigstringaf_memcmp_string\n//Requires: caml_ba_get_1, caml_int_compare, caml_string_unsafe_get\nfunction bigstringaf_memcmp_string(ba, ba_off, str, str_off, len) {\n for (var i = 0; i < len; i++) {\n var c = caml_int_compare(caml_ba_get_1(ba, ba_off + i), caml_string_unsafe_get(str, str_off + i));\n if (c != 0) return c\n }\n return 0;\n}\n","///////// BIN_PROT\n\n//Provides: caml_check_bound_bigstring\n//Requires: caml_array_bound_error\nfunction caml_check_bound_bigstring(bigstring, i){\n if (i >>> 0 >= bigstring.data.length) caml_array_bound_error();\n}\n\n//Provides: bin_prot_blit_buf_float_array_stub\n//Requires: caml_check_bound, caml_check_bound_bigstring\nfunction bin_prot_blit_buf_float_array_stub(src_pos, src, dst_pos, dst, len){\n if(len == 0) return 0;\n caml_check_bound(dst,dst_pos); // first pos\n caml_check_bound(dst,dst_pos+len-1); // last pos\n caml_check_bound_bigstring(src, src_pos); /* first pos */\n caml_check_bound_bigstring(src, src_pos + len * 8 - 1); /* last pos */\n var view = new joo_global_object.Float64Array(len);\n var buffer = new joo_global_object.Uint8Array(view.buffer);\n buffer.set(src.data.subarray(src_pos, src_pos + (len * 8)));\n for(var i = 0; i < len; i++){\n // [+ 1] because the tag is at pos 0 \n dst[dst_pos+i+1] = view[i];\n }\n return 0\n}\n//Provides: bin_prot_blit_buf_bytes_stub\n//Requires: caml_bigstring_blit_ba_to_bytes\nfunction bin_prot_blit_buf_bytes_stub(src_pos, src, dst_pos, dst, len){\n return caml_bigstring_blit_ba_to_bytes(src, src_pos, dst, dst_pos, len);\n}\n//Provides: bin_prot_blit_float_array_buf_stub\n//Requires: caml_check_bound, caml_check_bound_bigstring\nfunction bin_prot_blit_float_array_buf_stub(src_pos,src, dst_pos, dst, len){\n if(len == 0) return 0 \n caml_check_bound (src, src_pos); // first pos \n caml_check_bound (src, src_pos + len - 1); // last pos\n caml_check_bound_bigstring(dst, dst_pos); /* first pos */\n caml_check_bound_bigstring(dst, dst_pos + len * 8 - 1); /* last pos */\n // [+ 1] because the tag is at pos 0\n src_pos = src_pos + 1\n var float64 = new joo_global_object.Float64Array(src.slice(src_pos,src_pos + len));\n var float64_uint8 = new joo_global_object.Uint8Array(float64.buffer);\n var view = dst.data.subarray(dst_pos, dst_pos + (len * 8));\n view.set(float64_uint8);\n return 0\n}\n//Provides: bin_prot_blit_string_buf_stub\n//Requires: caml_bigstring_blit_string_to_ba\nfunction bin_prot_blit_string_buf_stub (src_pos, src, dst_pos, dst, len){\n return caml_bigstring_blit_string_to_ba(src,src_pos, dst, dst_pos,len);\n}\n//Provides: bin_prot_blit_bytes_buf_stub\n//Requires: caml_bigstring_blit_string_to_ba\nfunction bin_prot_blit_bytes_buf_stub (src_pos, src, dst_pos, dst, len){\n return caml_bigstring_blit_string_to_ba(src,src_pos, dst, dst_pos,len);\n}\n\n//Provides: bin_prot_blit_buf_stub\n//Requires: caml_bigstring_blit_ba_to_ba, bigstring_of_typed_array\nfunction bin_prot_blit_buf_stub (src_pos, src, dst_pos, dst, len){\n // [bin_prot_blit_buf_stub] is used with mixed bigarray kinds.\n // Converter everything to bigarray of char before the blit.\n if(src.kind != 12) // 12 is the char kind\n src = bigstring_of_typed_array(src.data);\n if(dst.kind != 12) // 12 is the char kind\n dst = bigstring_of_typed_array(dst.data);\n return caml_bigstring_blit_ba_to_ba(src,src_pos,dst,dst_pos,len);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Array\n\n//Provides: caml_array_sub mutable\nfunction caml_array_sub (a, i, len) {\n var a2 = new Array(len+1);\n a2[0]=0;\n for(var i2 = 1, i1= i+1; i2 <= len; i2++,i1++ ){\n a2[i2]=a[i1];\n }\n return a2;\n}\n\n//Provides: caml_array_append mutable\nfunction caml_array_append(a1, a2) {\n var l1 = a1.length, l2 = a2.length;\n var l = l1+l2-1\n var a = new Array(l);\n a[0] = 0;\n var i = 1,j = 1;\n for(;i= 1; j--) a2[i2 + j] = a1[i1 + j];\n };\n return 0;\n}\n\n//Provides: caml_floatarray_blit\nfunction caml_floatarray_blit(a1, i1, a2, i2, len) {\n if (i2 <= i1) {\n for (var j = 1; j <= len; j++) a2[i2 + j] = a1[i1 + j];\n } else {\n for (var j = len; j >= 1; j--) a2[i2 + j] = a1[i1 + j];\n };\n return 0;\n}\n\n///////////// Pervasive\n//Provides: caml_array_set (mutable, const, const)\n//Requires: caml_array_bound_error\nfunction caml_array_set (array, index, newval) {\n if ((index < 0) || (index >= array.length - 1)) caml_array_bound_error();\n array[index+1]=newval; return 0;\n}\n\n//Provides: caml_array_get mutable (const, const)\n//Requires: caml_array_bound_error\nfunction caml_array_get (array, index) {\n if ((index < 0) || (index >= array.length - 1)) caml_array_bound_error();\n return array[index+1];\n}\n\n//Provides: caml_array_fill\nfunction caml_array_fill(array, ofs, len, v){\n for(var i = 0; i < len; i++){\n array[ofs+i+1] = v;\n }\n return 0;\n}\n\n//Provides: caml_check_bound (const, const)\n//Requires: caml_array_bound_error\nfunction caml_check_bound (array, index) {\n if (index >>> 0 >= array.length - 1) caml_array_bound_error();\n return array;\n}\n\n//Provides: caml_make_vect const (const, const)\n//Requires: caml_array_bound_error\nfunction caml_make_vect (len, init) {\n if (len < 0) caml_array_bound_error();\n var len = len + 1 | 0;\n var b = new Array(len);\n b[0]=0;\n for (var i = 1; i < len; i++) b[i] = init;\n return b;\n}\n\n//Provides: caml_make_float_vect const (const)\n//Requires: caml_array_bound_error\nfunction caml_make_float_vect(len){\n if (len < 0) caml_array_bound_error();\n var len = len + 1 | 0;\n var b = new Array(len);\n b[0]=254;\n for (var i = 1; i < len; i++) b[i] = 0;\n return b\n}\n//Provides: caml_floatarray_create const (const)\n//Requires: caml_array_bound_error\nfunction caml_floatarray_create(len){\n if (len < 0) caml_array_bound_error();\n var len = len + 1 | 0;\n var b = new Array(len);\n b[0]=254;\n for (var i = 1; i < len; i++) b[i] = 0;\n return b\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_ml_debug_info_status const\nfunction caml_ml_debug_info_status () { return 0; }\n//Provides: caml_backtrace_status const\nfunction caml_backtrace_status () { return 0; }\n//Provides: caml_get_exception_backtrace const\nfunction caml_get_exception_backtrace () { return 0; }\n//Provides: caml_get_exception_raw_backtrace const\nfunction caml_get_exception_raw_backtrace () { return [0]; }\n//Provides: caml_record_backtrace\nfunction caml_record_backtrace () { return 0; }\n//Provides: caml_convert_raw_backtrace const\nfunction caml_convert_raw_backtrace () { return [0]; }\n//Provides: caml_raw_backtrace_length\nfunction caml_raw_backtrace_length() { return 0; }\n//Provides: caml_raw_backtrace_next_slot\nfunction caml_raw_backtrace_next_slot() { return 0 }\n//Provides: caml_raw_backtrace_slot\n//Requires: caml_invalid_argument\nfunction caml_raw_backtrace_slot () {\n caml_invalid_argument(\"Printexc.get_raw_backtrace_slot: index out of bounds\");\n}\n//Provides: caml_restore_raw_backtrace\nfunction caml_restore_raw_backtrace(exn, bt) { return 0 }\n//Provides: caml_get_current_callstack const\nfunction caml_get_current_callstack () { return [0]; }\n\n//Provides: caml_convert_raw_backtrace_slot\n//Requires: caml_failwith\nfunction caml_convert_raw_backtrace_slot(){\n caml_failwith(\"caml_convert_raw_backtrace_slot\");\n}\n","// Provides: plonk_wasm\nvar plonk_wasm = require('./plonk_wasm.js');\n","/* global globalThis, plonk_wasm, caml_js_to_bool, caml_jsstring_of_string,\n caml_string_of_jsstring\n caml_create_bytes, caml_bytes_unsafe_set, caml_bytes_unsafe_get, caml_ml_bytes_length,\n UInt64, caml_int64_of_int32\n*/\n\n// Provides: tsBindings\nvar tsBindings = globalThis.__snarkyTsBindings;\n\n// Provides: getTsBindings\n// Requires: tsBindings\nfunction getTsBindings() {\n return tsBindings;\n}\n\n// Provides: caml_bytes_of_uint8array\n// Requires: caml_create_bytes, caml_bytes_unsafe_set\nvar caml_bytes_of_uint8array = function (uint8array) {\n var length = uint8array.length;\n var ocaml_bytes = caml_create_bytes(length);\n for (var i = 0; i < length; i++) {\n // No need to convert here: OCaml Char.t is just an int under the hood.\n caml_bytes_unsafe_set(ocaml_bytes, i, uint8array[i]);\n }\n return ocaml_bytes;\n};\n\n// Provides: caml_bytes_to_uint8array\n// Requires: caml_ml_bytes_length, caml_bytes_unsafe_get\nvar caml_bytes_to_uint8array = function (ocaml_bytes) {\n var length = caml_ml_bytes_length(ocaml_bytes);\n var bytes = new globalThis.Uint8Array(length);\n for (var i = 0; i < length; i++) {\n // No need to convert here: OCaml Char.t is just an int under the hood.\n bytes[i] = caml_bytes_unsafe_get(ocaml_bytes, i);\n }\n return bytes;\n};\n\n// Provides: caml_bigint_256_of_numeral\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_bigint_256_of_numeral = function (s, len, base) {\n return plonk_wasm.caml_bigint_256_of_numeral(\n caml_jsstring_of_string(s),\n len,\n base\n );\n};\n\n// Provides: caml_bigint_256_of_decimal_string\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_bigint_256_of_decimal_string = function (s) {\n return plonk_wasm.caml_bigint_256_of_decimal_string(\n caml_jsstring_of_string(s)\n );\n};\n\n// Provides: caml_bigint_256_num_limbs\n// Requires: plonk_wasm\nvar caml_bigint_256_num_limbs = plonk_wasm.caml_bigint_256_num_limbs;\n\n// Provides: caml_bigint_256_bytes_per_limb\n// Requires: plonk_wasm\nvar caml_bigint_256_bytes_per_limb = plonk_wasm.caml_bigint_256_bytes_per_limb;\n\n// Provides: caml_bigint_256_div\n// Requires: plonk_wasm\nvar caml_bigint_256_div = plonk_wasm.caml_bigint_256_div;\n\n// Provides: caml_bigint_256_compare\n// Requires: plonk_wasm\nvar caml_bigint_256_compare = plonk_wasm.caml_bigint_256_compare;\n\n// Provides: caml_bigint_256_print\n// Requires: plonk_wasm\nvar caml_bigint_256_print = plonk_wasm.caml_bigint_256_print;\n\n// Provides: caml_bigint_256_to_string\n// Requires: plonk_wasm, caml_string_of_jsstring\nvar caml_bigint_256_to_string = function (x) {\n return caml_string_of_jsstring(plonk_wasm.caml_bigint_256_to_string(x));\n};\n\n// Provides: caml_bigint_256_test_bit\n// Requires: plonk_wasm, caml_js_to_bool\nvar caml_bigint_256_test_bit = function (x, i) {\n return caml_js_to_bool(plonk_wasm.caml_bigint_256_test_bit(x, i));\n};\n\n// Provides: caml_bigint_256_to_bytes\n// Requires: plonk_wasm, caml_bytes_of_uint8array\nvar caml_bigint_256_to_bytes = function (x) {\n return caml_bytes_of_uint8array(plonk_wasm.caml_bigint_256_to_bytes(x));\n};\n\n// Provides: caml_bigint_256_of_bytes\n// Requires: plonk_wasm, caml_bytes_to_uint8array\nvar caml_bigint_256_of_bytes = function (ocaml_bytes) {\n return plonk_wasm.caml_bigint_256_of_bytes(\n caml_bytes_to_uint8array(ocaml_bytes)\n );\n};\n\n// Provides: caml_bigint_256_deep_copy\n// Requires: plonk_wasm\nvar caml_bigint_256_deep_copy = plonk_wasm.caml_bigint_256_deep_copy;\n\n// Provides: caml_pasta_fp_copy\nvar caml_pasta_fp_copy = function (x, y) {\n for (var i = 0, l = x.length; i < l; i++) {\n x[i] = y[i];\n }\n};\n\n// Provides: caml_option_of_maybe_undefined\nvar caml_option_of_maybe_undefined = function (x) {\n if (x === undefined) {\n return 0; // None\n } else {\n return [0, x]; // Some(x)\n }\n};\n\n// Provides: caml_option_to_maybe_undefined\nvar caml_option_to_maybe_undefined = function (x) {\n if (x === 0) {\n // None\n return undefined;\n } else {\n return x[1];\n }\n};\n\n// Provides: caml_pasta_fp_size_in_bits\n// Requires: plonk_wasm\nvar caml_pasta_fp_size_in_bits = plonk_wasm.caml_pasta_fp_size_in_bits;\n\n// Provides: caml_pasta_fp_size\n// Requires: plonk_wasm\nvar caml_pasta_fp_size = plonk_wasm.caml_pasta_fp_size;\n\n// Provides: caml_pasta_fp_add\n// Requires: plonk_wasm\nvar caml_pasta_fp_add = plonk_wasm.caml_pasta_fp_add;\n\n// Provides: caml_pasta_fp_sub\n// Requires: plonk_wasm\nvar caml_pasta_fp_sub = plonk_wasm.caml_pasta_fp_sub;\n\n// Provides: caml_pasta_fp_negate\n// Requires: plonk_wasm\nvar caml_pasta_fp_negate = plonk_wasm.caml_pasta_fp_negate;\n\n// Provides: caml_pasta_fp_mul\n// Requires: plonk_wasm\nvar caml_pasta_fp_mul = plonk_wasm.caml_pasta_fp_mul;\n\n// Provides: caml_pasta_fp_div\n// Requires: plonk_wasm\nvar caml_pasta_fp_div = plonk_wasm.caml_pasta_fp_div;\n\n// Provides: caml_pasta_fp_inv\n// Requires: plonk_wasm, caml_option_of_maybe_undefined\nvar caml_pasta_fp_inv = function (x) {\n return caml_option_of_maybe_undefined(plonk_wasm.caml_pasta_fp_inv(x));\n};\n\n// Provides: caml_pasta_fp_square\n// Requires: plonk_wasm\nvar caml_pasta_fp_square = plonk_wasm.caml_pasta_fp_square;\n\n// Provides: caml_pasta_fp_is_square\n// Requires: plonk_wasm, caml_js_to_bool\nvar caml_pasta_fp_is_square = function (x) {\n return caml_js_to_bool(plonk_wasm.caml_pasta_fp_is_square(x));\n};\n\n// Provides: caml_pasta_fp_sqrt\n// Requires: plonk_wasm, caml_option_of_maybe_undefined\nvar caml_pasta_fp_sqrt = function (x) {\n return caml_option_of_maybe_undefined(plonk_wasm.caml_pasta_fp_sqrt(x));\n};\n\n// Provides: caml_pasta_fp_of_int\n// Requires: plonk_wasm\nvar caml_pasta_fp_of_int = plonk_wasm.caml_pasta_fp_of_int;\n\n// Provides: caml_pasta_fp_to_string\n// Requires: plonk_wasm, caml_string_of_jsstring\nvar caml_pasta_fp_to_string = function (x) {\n return caml_string_of_jsstring(plonk_wasm.caml_pasta_fp_to_string(x));\n};\n\n// Provides: caml_pasta_fp_of_string\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fp_of_string = function (x) {\n return plonk_wasm.caml_pasta_fp_of_string(caml_jsstring_of_string(x));\n};\n\n// Provides: caml_pasta_fp_print\n// Requires: plonk_wasm\nvar caml_pasta_fp_print = plonk_wasm.caml_pasta_fp_print;\n\n// Provides: caml_pasta_fp_mut_add\n// Requires: caml_pasta_fp_copy, caml_pasta_fp_add\nvar caml_pasta_fp_mut_add = function (x, y) {\n caml_pasta_fp_copy(x, caml_pasta_fp_add(x, y));\n};\n\n// Provides: caml_pasta_fp_mut_sub\n// Requires: caml_pasta_fp_copy, caml_pasta_fp_sub\nvar caml_pasta_fp_mut_sub = function (x, y) {\n caml_pasta_fp_copy(x, caml_pasta_fp_sub(x, y));\n};\n\n// Provides: caml_pasta_fp_mut_mul\n// Requires: caml_pasta_fp_copy, caml_pasta_fp_mul\nvar caml_pasta_fp_mut_mul = function (x, y) {\n caml_pasta_fp_copy(x, caml_pasta_fp_mul(x, y));\n};\n\n// Provides: caml_pasta_fp_mut_square\n// Requires: caml_pasta_fp_copy, caml_pasta_fp_square\nvar caml_pasta_fp_mut_square = function (x) {\n caml_pasta_fp_copy(x, caml_pasta_fp_square(x));\n};\n\n// Provides: caml_pasta_fp_compare\n// Requires: plonk_wasm\nvar caml_pasta_fp_compare = plonk_wasm.caml_pasta_fp_compare;\n\n// Provides: caml_pasta_fp_equal\n// Requires: plonk_wasm\nvar caml_pasta_fp_equal = plonk_wasm.caml_pasta_fp_equal;\n\n// Provides: caml_pasta_fp_random\n// Requires: plonk_wasm\nvar caml_pasta_fp_random = plonk_wasm.caml_pasta_fp_random;\n\n// Provides: caml_pasta_fp_rng\n// Requires: plonk_wasm\nvar caml_pasta_fp_rng = plonk_wasm.caml_pasta_fp_rng;\n\n// Provides: caml_pasta_fp_to_bigint\n// Requires: plonk_wasm\nvar caml_pasta_fp_to_bigint = plonk_wasm.caml_pasta_fp_to_bigint;\n\n// Provides: caml_pasta_fp_of_bigint\n// Requires: plonk_wasm\nvar caml_pasta_fp_of_bigint = plonk_wasm.caml_pasta_fp_of_bigint;\n\n// Provides: caml_pasta_fp_two_adic_root_of_unity\n// Requires: plonk_wasm\nvar caml_pasta_fp_two_adic_root_of_unity =\n plonk_wasm.caml_pasta_fp_two_adic_root_of_unity;\n\n// Provides: caml_pasta_fp_domain_generator\n// Requires: plonk_wasm\nvar caml_pasta_fp_domain_generator = plonk_wasm.caml_pasta_fp_domain_generator;\n\n// Provides: caml_pasta_fp_to_bytes\n// Requires: plonk_wasm, caml_bytes_of_uint8array\nvar caml_pasta_fp_to_bytes = function (x) {\n var res = plonk_wasm.caml_pasta_fp_to_bytes(x);\n return caml_bytes_of_uint8array(plonk_wasm.caml_pasta_fp_to_bytes(x));\n};\n\n// Provides: caml_pasta_fp_of_bytes\n// Requires: plonk_wasm, caml_bytes_to_uint8array\nvar caml_pasta_fp_of_bytes = function (ocaml_bytes) {\n return plonk_wasm.caml_pasta_fp_of_bytes(\n caml_bytes_to_uint8array(ocaml_bytes)\n );\n};\n\n// Provides: caml_pasta_fp_deep_copy\n// Requires: plonk_wasm\nvar caml_pasta_fp_deep_copy = plonk_wasm.caml_pasta_fp_deep_copy;\n\n// Provides: caml_pasta_fq_copy\nvar caml_pasta_fq_copy = function (x, y) {\n for (var i = 0, l = x.length; i < l; i++) {\n x[i] = y[i];\n }\n};\n\n// Provides: caml_pasta_fq_size_in_bits\n// Requires: plonk_wasm\nvar caml_pasta_fq_size_in_bits = plonk_wasm.caml_pasta_fq_size_in_bits;\n\n// Provides: caml_pasta_fq_size\n// Requires: plonk_wasm\nvar caml_pasta_fq_size = plonk_wasm.caml_pasta_fq_size;\n\n// Provides: caml_pasta_fq_add\n// Requires: plonk_wasm\nvar caml_pasta_fq_add = plonk_wasm.caml_pasta_fq_add;\n\n// Provides: caml_pasta_fq_sub\n// Requires: plonk_wasm\nvar caml_pasta_fq_sub = plonk_wasm.caml_pasta_fq_sub;\n\n// Provides: caml_pasta_fq_negate\n// Requires: plonk_wasm\nvar caml_pasta_fq_negate = plonk_wasm.caml_pasta_fq_negate;\n\n// Provides: caml_pasta_fq_mul\n// Requires: plonk_wasm\nvar caml_pasta_fq_mul = plonk_wasm.caml_pasta_fq_mul;\n\n// Provides: caml_pasta_fq_div\n// Requires: plonk_wasm\nvar caml_pasta_fq_div = plonk_wasm.caml_pasta_fq_div;\n\n// Provides: caml_pasta_fq_inv\n// Requires: plonk_wasm, caml_option_of_maybe_undefined\nvar caml_pasta_fq_inv = function (x) {\n return caml_option_of_maybe_undefined(plonk_wasm.caml_pasta_fq_inv(x));\n};\n\n// Provides: caml_pasta_fq_square\n// Requires: plonk_wasm\nvar caml_pasta_fq_square = plonk_wasm.caml_pasta_fq_square;\n\n// Provides: caml_pasta_fq_is_square\n// Requires: plonk_wasm, caml_js_to_bool\nvar caml_pasta_fq_is_square = function (x) {\n return caml_js_to_bool(plonk_wasm.caml_pasta_fq_is_square(x));\n};\n\n// Provides: caml_pasta_fq_sqrt\n// Requires: plonk_wasm, caml_option_of_maybe_undefined\nvar caml_pasta_fq_sqrt = function (x) {\n return caml_option_of_maybe_undefined(plonk_wasm.caml_pasta_fq_sqrt(x));\n};\n\n// Provides: caml_pasta_fq_of_int\n// Requires: plonk_wasm\nvar caml_pasta_fq_of_int = plonk_wasm.caml_pasta_fq_of_int;\n\n// Provides: caml_pasta_fq_to_string\n// Requires: plonk_wasm, caml_string_of_jsstring\nvar caml_pasta_fq_to_string = function (x) {\n return caml_string_of_jsstring(plonk_wasm.caml_pasta_fq_to_string(x));\n};\n\n// Provides: caml_pasta_fq_of_string\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fq_of_string = function (x) {\n return plonk_wasm.caml_pasta_fq_of_string(caml_jsstring_of_string(x));\n};\n\n// Provides: caml_pasta_fq_print\n// Requires: plonk_wasm\nvar caml_pasta_fq_print = plonk_wasm.caml_pasta_fq_print;\n\n// Provides: caml_pasta_fq_mut_add\n// Requires: caml_pasta_fq_copy, caml_pasta_fq_add\nvar caml_pasta_fq_mut_add = function (x, y) {\n caml_pasta_fq_copy(x, caml_pasta_fq_add(x, y));\n};\n\n// Provides: caml_pasta_fq_mut_sub\n// Requires: caml_pasta_fq_copy, caml_pasta_fq_sub\nvar caml_pasta_fq_mut_sub = function (x, y) {\n caml_pasta_fq_copy(x, caml_pasta_fq_sub(x, y));\n};\n\n// Provides: caml_pasta_fq_mut_mul\n// Requires: caml_pasta_fq_copy, caml_pasta_fq_mul\nvar caml_pasta_fq_mut_mul = function (x, y) {\n caml_pasta_fq_copy(x, caml_pasta_fq_mul(x, y));\n};\n\n// Provides: caml_pasta_fq_mut_square\n// Requires: caml_pasta_fq_copy, caml_pasta_fq_square\nvar caml_pasta_fq_mut_square = function (x) {\n caml_pasta_fq_copy(x, caml_pasta_fq_square(x));\n};\n\n// Provides: caml_pasta_fq_compare\n// Requires: plonk_wasm\nvar caml_pasta_fq_compare = plonk_wasm.caml_pasta_fq_compare;\n\n// Provides: caml_pasta_fq_equal\n// Requires: plonk_wasm\nvar caml_pasta_fq_equal = plonk_wasm.caml_pasta_fq_equal;\n\n// Provides: caml_pasta_fq_random\n// Requires: plonk_wasm\nvar caml_pasta_fq_random = plonk_wasm.caml_pasta_fq_random;\n\n// Provides: caml_pasta_fq_rng\n// Requires: plonk_wasm\nvar caml_pasta_fq_rng = plonk_wasm.caml_pasta_fq_rng;\n\n// Provides: caml_pasta_fq_to_bigint\n// Requires: plonk_wasm\nvar caml_pasta_fq_to_bigint = plonk_wasm.caml_pasta_fq_to_bigint;\n\n// Provides: caml_pasta_fq_of_bigint\n// Requires: plonk_wasm\nvar caml_pasta_fq_of_bigint = plonk_wasm.caml_pasta_fq_of_bigint;\n\n// Provides: caml_pasta_fq_two_adic_root_of_unity\n// Requires: plonk_wasm\nvar caml_pasta_fq_two_adic_root_of_unity =\n plonk_wasm.caml_pasta_fq_two_adic_root_of_unity;\n\n// Provides: caml_pasta_fq_domain_generator\n// Requires: plonk_wasm\nvar caml_pasta_fq_domain_generator = plonk_wasm.caml_pasta_fq_domain_generator;\n\n// Provides: caml_pasta_fq_to_bytes\n// Requires: plonk_wasm, caml_bytes_of_uint8array\nvar caml_pasta_fq_to_bytes = function (x) {\n var res = plonk_wasm.caml_pasta_fq_to_bytes(x);\n return caml_bytes_of_uint8array(plonk_wasm.caml_pasta_fq_to_bytes(x));\n};\n\n// Provides: caml_pasta_fq_of_bytes\n// Requires: plonk_wasm, caml_bytes_to_uint8array\nvar caml_pasta_fq_of_bytes = function (ocaml_bytes) {\n return plonk_wasm.caml_pasta_fq_of_bytes(\n caml_bytes_to_uint8array(ocaml_bytes)\n );\n};\n\n// Provides: caml_pasta_fq_deep_copy\n// Requires: plonk_wasm\nvar caml_pasta_fq_deep_copy = plonk_wasm.caml_pasta_fq_deep_copy;\n\n// Provides: caml_u8array_vector_to_rust_flat_vector\nvar caml_u8array_vector_to_rust_flat_vector = function (v) {\n var i = 1; // The first entry is the OCaml tag for arrays\n var len = v.length - i;\n if (len === 0) {\n return new globalThis.Uint8Array(0);\n }\n var inner_len = v[i].length;\n var res = new globalThis.Uint8Array(len * inner_len);\n for (var pos = 0; i <= len; i++) {\n for (var j = 0; j < inner_len; j++, pos++) {\n res[pos] = v[i][j];\n }\n }\n return res;\n};\n\n// Provides: caml_u8array_vector_of_rust_flat_vector\nvar caml_u8array_vector_of_rust_flat_vector = function (v, inner_len) {\n var len = v.length;\n var output_len = len / inner_len;\n var res = new Array(output_len + 1);\n res[0] = 0; // OCaml tag before array contents, so that we can use this with arrays or vectors\n for (var i = 1, pos = 0; i <= output_len; i++) {\n var inner_res = new globalThis.Uint8Array(inner_len);\n for (var j = 0; j < inner_len; j++, pos++) {\n inner_res[j] = v[pos];\n }\n res[i] = inner_res;\n }\n return res;\n};\n\n// Provides: js_class_vector_to_rust_vector\nvar js_class_vector_to_rust_vector = function (v) {\n var len = v.length;\n var res = new globalThis.Uint32Array(len);\n for (var i = 0; i < len; i++) {\n // Beware: caller may need to do finalizer things to avoid these\n // pointers disappearing out from under us.\n res[i] = v[i].ptr;\n }\n return res;\n};\n\n// Provides: js_class_vector_of_rust_vector\nvar js_class_vector_of_rust_vector = function (v, klass) {\n // return v.map(klass.__wrap)\n var len = v.length;\n var res = new Array(len);\n for (var i = 0; i < len; i++) {\n // Beware: the caller may need to add finalizers to these.\n res[i] = klass.__wrap(v[i]);\n }\n return res;\n};\n\n// Provides: caml_fp_vector_create\nvar caml_fp_vector_create = function () {\n return [0]; // OCaml tag for arrays, so that we can use the same utility fns on both\n};\n\n// Provides: caml_fp_vector_length\nvar caml_fp_vector_length = function (v) {\n return v.length - 1;\n};\n\n// Provides: caml_fp_vector_emplace_back\nvar caml_fp_vector_emplace_back = function (v, x) {\n v.push(x);\n};\n\n// Provides: caml_fp_vector_get\nvar caml_fp_vector_get = function (v, i) {\n var value = v[i + 1];\n if (value === undefined) {\n throw Error(\n 'caml_fp_vector_get: Index out of bounds, got ' + i + '/' + (v.length - 1)\n );\n }\n return new globalThis.Uint8Array(value);\n};\n\n// Provides: caml_fp_vector_to_rust\n// Requires: caml_u8array_vector_to_rust_flat_vector\nvar caml_fp_vector_to_rust = function (v) {\n return caml_u8array_vector_to_rust_flat_vector(v);\n};\n\n// Provides: caml_fp_vector_of_rust\n// Requires: caml_u8array_vector_of_rust_flat_vector\nvar caml_fp_vector_of_rust = function (v) {\n // TODO: Hardcoding this is a little brittle\n return caml_u8array_vector_of_rust_flat_vector(v, 32);\n};\n\n// Provides: caml_fq_vector_create\nvar caml_fq_vector_create = function () {\n return [0]; // OCaml tag for arrays, so that we can use the same utility fns on both\n};\n\n// Provides: caml_fq_vector_length\nvar caml_fq_vector_length = function (v) {\n return v.length - 1;\n};\n\n// Provides: caml_fq_vector_emplace_back\nvar caml_fq_vector_emplace_back = function (v, x) {\n v.push(x);\n};\n\n// Provides: caml_fq_vector_get\nvar caml_fq_vector_get = function (v, i) {\n var value = v[i + 1];\n if (value === undefined) {\n throw Error(\n 'caml_fq_vector_get: Index out of bounds, got ' + i + '/' + (v.length - 1)\n );\n }\n return new globalThis.Uint8Array(value);\n};\n\n// Provides: caml_fq_vector_to_rust\n// Requires: caml_u8array_vector_to_rust_flat_vector\nvar caml_fq_vector_to_rust = function (v) {\n return caml_u8array_vector_to_rust_flat_vector(v);\n};\n\n// Provides: caml_fq_vector_of_rust\n// Requires: caml_u8array_vector_of_rust_flat_vector\nvar caml_fq_vector_of_rust = function (v) {\n // TODO: Hardcoding this is a little brittle\n return caml_u8array_vector_of_rust_flat_vector(v, 32);\n};\n\n// Provides: free_finalization_registry\nvar free_finalization_registry = new globalThis.FinalizationRegistry(function (\n instance_representative\n) {\n instance_representative.free();\n});\n\n// Provides: free_on_finalize\n// Requires: free_finalization_registry\nvar free_on_finalize = function (x) {\n // This is an unfortunate hack: we're creating a second instance of the\n // class to be able to call free on it. We can't pass the value itself,\n // since the registry holds a strong reference to the representative value.\n //\n // However, the class is only really a wrapper around a pointer, with a\n // reference to the class' prototype as its __prototype__.\n //\n // It might seem cleaner to call the destructor here on the pointer\n // directly, but unfortunately the destructor name is some mangled internal\n // string generated by wasm_bindgen. For now, this is the best,\n // least-brittle way to free once the original class instance gets collected.\n var instance_representative = x.constructor.__wrap(x.ptr);\n free_finalization_registry.register(x, instance_representative, x);\n return x;\n};\n\n// Provides: rust_affine_to_caml_affine\nvar rust_affine_to_caml_affine = function (pt) {\n var infinity = pt.infinity;\n if (infinity) {\n pt.free();\n return 0;\n } else {\n var x = pt.x;\n var y = pt.y;\n pt.free();\n return [0, [0, x, y]];\n }\n};\n\n// Provides: rust_affine_of_caml_affine\nvar rust_affine_of_caml_affine = function (pt, klass) {\n var res = new klass();\n if (pt === 0) {\n res.infinity = true;\n } else {\n // Layout is [0, [0, x, y]]\n // First 0 is the tag (it's the 0th constructor that takes arguments)\n // Second 0 is the block marker for the anonymous tuple arguments\n res.x = pt[1][1];\n res.y = pt[1][2];\n }\n return res;\n};\n\n// Provides: caml_pallas_one\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_one = function () {\n var res = plonk_wasm.caml_pallas_one();\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_add\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_add = function (x, y) {\n var res = plonk_wasm.caml_pallas_add(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_sub\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_sub = function (x, y) {\n var res = plonk_wasm.caml_pallas_sub(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_negate\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_negate = function (x) {\n var res = plonk_wasm.caml_pallas_negate(x);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_double\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_double = function (x) {\n var res = plonk_wasm.caml_pallas_double(x);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_scale\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_scale = function (x, y) {\n var res = plonk_wasm.caml_pallas_scale(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_random\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_random = function () {\n var res = plonk_wasm.caml_pallas_random();\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_rng\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_rng = function (i) {\n var res = plonk_wasm.caml_pallas_rng(i);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_to_affine\n// Requires: plonk_wasm, rust_affine_to_caml_affine\nvar caml_pallas_to_affine = function (pt) {\n var res = plonk_wasm.caml_pallas_to_affine(pt);\n return rust_affine_to_caml_affine(res);\n};\n\n// Provides: caml_pallas_of_affine\n// Requires: plonk_wasm, rust_affine_of_caml_affine, free_on_finalize\nvar caml_pallas_of_affine = function (pt) {\n var res = plonk_wasm.caml_pallas_of_affine(\n rust_affine_of_caml_affine(pt, plonk_wasm.caml_pallas_affine_one)\n );\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_of_affine_coordinates\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_of_affine_coordinates = function (x, y) {\n var res = plonk_wasm.caml_pallas_of_affine_coordinates(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_endo_base\n// Requires: plonk_wasm\nvar caml_pallas_endo_base = plonk_wasm.caml_pallas_endo_base;\n\n// Provides: caml_pallas_endo_scalar\n// Requires: plonk_wasm\nvar caml_pallas_endo_scalar = plonk_wasm.caml_pallas_endo_scalar;\n\n// Provides: caml_pallas_affine_deep_copy\n// Requires: plonk_wasm, rust_affine_of_caml_affine, rust_affine_to_caml_affine\nvar caml_pallas_affine_deep_copy = function (pt) {\n return rust_affine_to_caml_affine(\n plonk_wasm.caml_pallas_affine_deep_copy(\n rust_affine_of_caml_affine(pt, plonk_wasm.caml_pallas_affine_one)\n )\n );\n};\n\n// Provides: caml_vesta_one\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_one = function () {\n var res = plonk_wasm.caml_vesta_one();\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_add\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_add = function (x, y) {\n var res = plonk_wasm.caml_vesta_add(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_sub\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_sub = function (x, y) {\n var res = plonk_wasm.caml_vesta_sub(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_negate\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_negate = function (x) {\n var res = plonk_wasm.caml_vesta_negate(x);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_double\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_double = function (x) {\n var res = plonk_wasm.caml_vesta_double(x);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_scale\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_scale = function (x, y) {\n var res = plonk_wasm.caml_vesta_scale(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_random\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_random = function () {\n var res = plonk_wasm.caml_vesta_random();\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_rng\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_rng = function (i) {\n var res = plonk_wasm.caml_vesta_rng(i);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_to_affine\n// Requires: plonk_wasm, rust_affine_to_caml_affine\nvar caml_vesta_to_affine = function (pt) {\n var res = plonk_wasm.caml_vesta_to_affine(pt);\n return rust_affine_to_caml_affine(res);\n};\n\n// Provides: caml_vesta_of_affine\n// Requires: plonk_wasm, rust_affine_of_caml_affine, free_on_finalize\nvar caml_vesta_of_affine = function (pt) {\n var res = plonk_wasm.caml_vesta_of_affine(\n rust_affine_of_caml_affine(pt, plonk_wasm.caml_vesta_affine_one)\n );\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_of_affine_coordinates\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_of_affine_coordinates = function (x, y) {\n var res = plonk_wasm.caml_vesta_of_affine_coordinates(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_endo_base\n// Requires: plonk_wasm\nvar caml_vesta_endo_base = plonk_wasm.caml_vesta_endo_base;\n\n// Provides: caml_vesta_endo_scalar\n// Requires: plonk_wasm\nvar caml_vesta_endo_scalar = plonk_wasm.caml_vesta_endo_scalar;\n\n// Provides: caml_vesta_affine_deep_copy\n// Requires: plonk_wasm, rust_affine_of_caml_affine, rust_affine_to_caml_affine\nvar caml_vesta_affine_deep_copy = function (pt) {\n return rust_affine_to_caml_affine(\n plonk_wasm.caml_vesta_affine_deep_copy(\n rust_affine_of_caml_affine(pt, plonk_wasm.caml_vesta_affine_one)\n )\n );\n};\n\n// Provides: caml_array_of_rust_vector\n// Requires: js_class_vector_of_rust_vector\nvar caml_array_of_rust_vector = function (v, klass, convert, should_free) {\n v = js_class_vector_of_rust_vector(v, klass);\n var len = v.length;\n var res = new Array(len + 1);\n res[0] = 0; // OCaml tag before array contents\n for (var i = 0; i < len; i++) {\n var rust_val = v[i];\n res[i + 1] = convert(rust_val);\n if (should_free) {\n rust_val.free();\n }\n }\n return res;\n};\n\n// Provides: caml_array_to_rust_vector\n// Requires: js_class_vector_to_rust_vector, free_finalization_registry\nvar caml_array_to_rust_vector = function (v, convert, mk_new) {\n v = v.slice(1); // Copy, dropping OCaml tag\n for (var i = 0, l = v.length; i < l; i++) {\n var class_val = convert(v[i], mk_new);\n v[i] = class_val;\n // Don't free when GC runs; rust will free on its end.\n free_finalization_registry.unregister(class_val);\n }\n return js_class_vector_to_rust_vector(v);\n};\n\n// Provides: caml_poly_comm_of_rust_poly_comm\n// Requires: rust_affine_to_caml_affine, caml_array_of_rust_vector\nvar caml_poly_comm_of_rust_poly_comm = function (\n poly_comm,\n klass,\n should_free\n) {\n var rust_shifted = poly_comm.shifted;\n var rust_unshifted = poly_comm.unshifted;\n var caml_shifted;\n if (rust_shifted === undefined) {\n caml_shifted = 0;\n } else {\n caml_shifted = [0, rust_affine_to_caml_affine(rust_shifted)];\n }\n var caml_unshifted = caml_array_of_rust_vector(\n rust_unshifted,\n klass,\n rust_affine_to_caml_affine,\n should_free\n );\n return [0, caml_unshifted, caml_shifted];\n};\n\n// Provides: caml_poly_comm_to_rust_poly_comm\n// Requires: rust_affine_of_caml_affine, caml_array_to_rust_vector\nvar caml_poly_comm_to_rust_poly_comm = function (\n poly_comm,\n poly_comm_class,\n mk_affine\n) {\n var caml_unshifted = poly_comm[1];\n var caml_shifted = poly_comm[2];\n var rust_shifted = undefined;\n if (caml_shifted !== 0) {\n rust_shifted = rust_affine_of_caml_affine(caml_shifted[1], mk_affine);\n }\n var rust_unshifted = caml_array_to_rust_vector(\n caml_unshifted,\n rust_affine_of_caml_affine,\n mk_affine\n );\n return new poly_comm_class(rust_unshifted, rust_shifted);\n};\n\n// Provides: caml_vesta_poly_comm_of_rust\n// Requires: plonk_wasm, caml_poly_comm_of_rust_poly_comm\nvar caml_vesta_poly_comm_of_rust = function (x) {\n return caml_poly_comm_of_rust_poly_comm(x, plonk_wasm.WasmGVesta, false);\n};\n\n// Provides: caml_vesta_poly_comm_to_rust\n// Requires: plonk_wasm, caml_poly_comm_to_rust_poly_comm\nvar caml_vesta_poly_comm_to_rust = function (x) {\n return caml_poly_comm_to_rust_poly_comm(\n x,\n plonk_wasm.WasmFpPolyComm,\n plonk_wasm.caml_vesta_affine_one\n );\n};\n\n// Provides: caml_pallas_poly_comm_of_rust\n// Requires: plonk_wasm, caml_poly_comm_of_rust_poly_comm\nvar caml_pallas_poly_comm_of_rust = function (x) {\n return caml_poly_comm_of_rust_poly_comm(x, plonk_wasm.WasmGPallas, false);\n};\n\n// Provides: caml_pallas_poly_comm_to_rust\n// Requires: plonk_wasm, caml_poly_comm_to_rust_poly_comm\nvar caml_pallas_poly_comm_to_rust = function (x) {\n return caml_poly_comm_to_rust_poly_comm(\n x,\n plonk_wasm.WasmFqPolyComm,\n plonk_wasm.caml_pallas_affine_one\n );\n};\n\n// Provides: caml_fp_srs_create\n// Requires: plonk_wasm, free_on_finalize\nvar caml_fp_srs_create = function (i) {\n return free_on_finalize(plonk_wasm.caml_fp_srs_create(i));\n};\n\n// Provides: caml_fp_srs_write\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_fp_srs_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_fp_srs_write(append, t, caml_jsstring_of_string(path));\n};\n\n// Provides: caml_fp_srs_read\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_fp_srs_read = function (offset, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n var res = plonk_wasm.caml_fp_srs_read(offset, caml_jsstring_of_string(path));\n if (res) {\n return [0, res]; // Some(res)\n } else {\n return 0; // None\n }\n};\n\n// Provides: caml_fp_srs_lagrange_commitment\n// Requires: plonk_wasm, caml_vesta_poly_comm_of_rust\nvar caml_fp_srs_lagrange_commitment = function (t, domain_size, i) {\n var res = plonk_wasm.caml_fp_srs_lagrange_commitment(t, domain_size, i);\n return caml_vesta_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fp_srs_commit_evaluations\n// Requires: plonk_wasm, caml_vesta_poly_comm_of_rust, caml_fp_vector_to_rust\nvar caml_fp_srs_commit_evaluations = function (t, domain_size, fps) {\n var res = plonk_wasm.caml_fp_srs_commit_evaluations(\n t,\n domain_size,\n caml_fp_vector_to_rust(fps)\n );\n return caml_vesta_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fp_srs_b_poly_commitment\n// Requires: plonk_wasm, caml_vesta_poly_comm_of_rust, caml_u8array_vector_to_rust_flat_vector\nvar caml_fp_srs_b_poly_commitment = function (srs, chals) {\n var res = plonk_wasm.caml_fp_srs_b_poly_commitment(\n srs,\n caml_u8array_vector_to_rust_flat_vector(chals)\n );\n return caml_vesta_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fp_srs_batch_accumulator_check\n// Requires: plonk_wasm, rust_affine_of_caml_affine, caml_array_to_rust_vector, caml_fp_vector_to_rust\nvar caml_fp_srs_batch_accumulator_check = function (srs, comms, chals) {\n var rust_comms = caml_array_to_rust_vector(\n comms,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_vesta_affine_one\n );\n var rust_chals = caml_fp_vector_to_rust(chals);\n var ok = plonk_wasm.caml_fp_srs_batch_accumulator_check(\n srs,\n rust_comms,\n rust_chals\n );\n return ok;\n};\n\n// Provides: caml_fp_srs_batch_accumulator_generate\n// Requires: plonk_wasm, rust_affine_to_caml_affine, caml_array_of_rust_vector, caml_fp_vector_to_rust\nvar caml_fp_srs_batch_accumulator_generate = function (srs, comms, chals) {\n var rust_chals = caml_fp_vector_to_rust(chals);\n var rust_comms = plonk_wasm.caml_fp_srs_batch_accumulator_generate(\n srs,\n comms,\n rust_chals\n );\n return caml_array_of_rust_vector(\n rust_comms,\n plonk_wasm.WasmGVesta,\n rust_affine_to_caml_affine,\n false\n );\n};\n\n// Provides: caml_fp_srs_h\n// Requires: plonk_wasm, rust_affine_to_caml_affine\nvar caml_fp_srs_h = function (t) {\n return rust_affine_to_caml_affine(plonk_wasm.caml_fp_srs_h(t));\n};\n\n// Provides: caml_fq_srs_create\n// Requires: plonk_wasm, free_on_finalize\nvar caml_fq_srs_create = function (i) {\n return free_on_finalize(plonk_wasm.caml_fq_srs_create(i));\n};\n\n// Provides: caml_fq_srs_write\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_fq_srs_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_fq_srs_write(append, t, caml_jsstring_of_string(path));\n};\n\n// Provides: caml_fq_srs_read\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_fq_srs_read = function (offset, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n var res = plonk_wasm.caml_fq_srs_read(offset, caml_jsstring_of_string(path));\n if (res) {\n return [0, res]; // Some(res)\n } else {\n return 0; // None\n }\n};\n\n// Provides: caml_fq_srs_lagrange_commitment\n// Requires: plonk_wasm, caml_pallas_poly_comm_of_rust\nvar caml_fq_srs_lagrange_commitment = function (t, domain_size, i) {\n var res = plonk_wasm.caml_fq_srs_lagrange_commitment(t, domain_size, i);\n return caml_pallas_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fq_srs_commit_evaluations\n// Requires: plonk_wasm, caml_pallas_poly_comm_of_rust, caml_fq_vector_to_rust\nvar caml_fq_srs_commit_evaluations = function (t, domain_size, fqs) {\n var res = plonk_wasm.caml_fq_srs_commit_evaluations(\n t,\n domain_size,\n caml_fq_vector_to_rust(fqs)\n );\n return caml_pallas_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fq_srs_b_poly_commitment\n// Requires: plonk_wasm, caml_pallas_poly_comm_of_rust, caml_u8array_vector_to_rust_flat_vector\nvar caml_fq_srs_b_poly_commitment = function (srs, chals) {\n var res = plonk_wasm.caml_fq_srs_b_poly_commitment(\n srs,\n caml_u8array_vector_to_rust_flat_vector(chals)\n );\n return caml_pallas_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fq_srs_batch_accumulator_check\n// Requires: plonk_wasm, rust_affine_of_caml_affine, caml_array_to_rust_vector, caml_fq_vector_to_rust\nvar caml_fq_srs_batch_accumulator_check = function (srs, comms, chals) {\n var rust_comms = caml_array_to_rust_vector(\n comms,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_pallas_affine_one\n );\n var rust_chals = caml_fq_vector_to_rust(chals);\n var ok = plonk_wasm.caml_fq_srs_batch_accumulator_check(\n srs,\n rust_comms,\n rust_chals\n );\n return ok;\n};\n\n// Provides: caml_fq_srs_batch_accumulator_generate\n// Requires: plonk_wasm, rust_affine_to_caml_affine, caml_array_of_rust_vector, caml_fq_vector_to_rust\nvar caml_fq_srs_batch_accumulator_generate = function (srs, comms, chals) {\n var rust_chals = caml_fq_vector_to_rust(chals);\n var rust_comms = plonk_wasm.caml_fq_srs_batch_accumulator_generate(\n srs,\n comms,\n rust_chals\n );\n return caml_array_of_rust_vector(\n rust_comms,\n plonk_wasm.WasmGPallas,\n rust_affine_to_caml_affine,\n false\n );\n};\n\n// Provides: caml_fq_srs_h\n// Requires: plonk_wasm, rust_affine_to_caml_affine\nvar caml_fq_srs_h = function (t) {\n return rust_affine_to_caml_affine(plonk_wasm.caml_fq_srs_h(t));\n};\n\n// Provides: caml_fq_srs_add_lagrange_basis\n// Requires: plonk_wasm\nfunction caml_fq_srs_add_lagrange_basis(srs, log2_size) {\n return plonk_wasm.caml_fq_srs_add_lagrange_basis(srs, log2_size);\n}\n\n// Provides: caml_plonk_wire_of_rust\nvar caml_plonk_wire_of_rust = function (wire) {\n var res = [0, wire.row, wire.col];\n wire.free();\n return res;\n};\n\n// Provides: caml_plonk_wire_to_rust\n// Requires: plonk_wasm\nvar caml_plonk_wire_to_rust = function (wire) {\n return plonk_wasm.Wire.create(wire[1], wire[2]);\n};\n\n// Provides: caml_plonk_wires_of_rust\n// Requires: caml_plonk_wire_of_rust\nvar caml_plonk_wires_of_rust = function (wires) {\n var res = [\n 0,\n caml_plonk_wire_of_rust(wires[0]),\n caml_plonk_wire_of_rust(wires[1]),\n caml_plonk_wire_of_rust(wires[2]),\n caml_plonk_wire_of_rust(wires[3]),\n caml_plonk_wire_of_rust(wires[4]),\n caml_plonk_wire_of_rust(wires[5]),\n caml_plonk_wire_of_rust(wires[6]),\n ];\n wires.free();\n return res;\n};\n\n// Provides: caml_plonk_wires_to_rust\n// Requires: plonk_wasm, caml_plonk_wire_to_rust\nvar caml_plonk_wires_to_rust = function (wires) {\n return new plonk_wasm.WasmGateWires(\n caml_plonk_wire_to_rust(wires[1]),\n caml_plonk_wire_to_rust(wires[2]),\n caml_plonk_wire_to_rust(wires[3]),\n caml_plonk_wire_to_rust(wires[4]),\n caml_plonk_wire_to_rust(wires[5]),\n caml_plonk_wire_to_rust(wires[6]),\n caml_plonk_wire_to_rust(wires[7])\n );\n};\n\n// Provides: caml_plonk_gate_of_rust\n// Requires: caml_plonk_wires_of_rust, caml_u8array_vector_of_rust_flat_vector\nvar caml_plonk_gate_of_rust = function (gate) {\n // TODO: Hardcoding 32 here is a little brittle\n var res = [\n 0,\n gate.typ,\n caml_plonk_wires_of_rust(gate.wires),\n caml_u8array_vector_of_rust_flat_vector(gate.c, 32),\n ];\n gate.free();\n return res;\n};\n\n// Provides: caml_fp_plonk_gate_to_rust\n// Requires: plonk_wasm, caml_plonk_wires_to_rust, caml_u8array_vector_to_rust_flat_vector\nvar caml_fp_plonk_gate_to_rust = function (gate) {\n return new plonk_wasm.WasmFpGate(\n gate[1],\n caml_plonk_wires_to_rust(gate[2]),\n caml_u8array_vector_to_rust_flat_vector(gate[3])\n );\n};\n\n// Provides: caml_fq_plonk_gate_to_rust\n// Requires: plonk_wasm, caml_plonk_wires_to_rust, caml_u8array_vector_to_rust_flat_vector\nvar caml_fq_plonk_gate_to_rust = function (gate) {\n // TODO: Hardcoding 32 here is a little brittle\n return new plonk_wasm.WasmFqGate(\n gate[1],\n caml_plonk_wires_to_rust(gate[2]),\n caml_u8array_vector_to_rust_flat_vector(gate[3])\n );\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_create\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pasta_fp_plonk_gate_vector_create = function () {\n return free_on_finalize(plonk_wasm.caml_pasta_fp_plonk_gate_vector_create());\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_add\n// Requires: plonk_wasm, caml_fp_plonk_gate_to_rust\nvar caml_pasta_fp_plonk_gate_vector_add = function (v, x) {\n return plonk_wasm.caml_pasta_fp_plonk_gate_vector_add(\n v,\n caml_fp_plonk_gate_to_rust(x)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_get\n// Requires: plonk_wasm, caml_plonk_gate_of_rust\nvar caml_pasta_fp_plonk_gate_vector_get = function (v, i) {\n return caml_plonk_gate_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_gate_vector_get(v, i)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_len\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_gate_vector_len = function (v) {\n return plonk_wasm.caml_pasta_fp_plonk_gate_vector_len(v);\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_wrap\n// Requires: plonk_wasm, caml_plonk_wire_to_rust\nvar caml_pasta_fp_plonk_gate_vector_wrap = function (v, x, y) {\n return plonk_wasm.caml_pasta_fp_plonk_gate_vector_wrap(\n v,\n caml_plonk_wire_to_rust(x),\n caml_plonk_wire_to_rust(y)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_digest\n// Requires: plonk_wasm, caml_bytes_of_uint8array\nvar caml_pasta_fp_plonk_gate_vector_digest = function (\n public_input_size,\n gate_vector\n) {\n var uint8array = plonk_wasm.caml_pasta_fp_plonk_gate_vector_digest(\n public_input_size,\n gate_vector\n );\n return caml_bytes_of_uint8array(uint8array);\n};\n\n// Provides: caml_pasta_fp_plonk_circuit_serialize\n// Requires: plonk_wasm, caml_string_of_jsstring\nvar caml_pasta_fp_plonk_circuit_serialize = function (\n public_input_size,\n gate_vector\n) {\n return caml_string_of_jsstring(\n plonk_wasm.caml_pasta_fp_plonk_circuit_serialize(\n public_input_size,\n gate_vector\n )\n );\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_create\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pasta_fq_plonk_gate_vector_create = function () {\n return free_on_finalize(plonk_wasm.caml_pasta_fq_plonk_gate_vector_create());\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_add\n// Requires: plonk_wasm, caml_fq_plonk_gate_to_rust\nvar caml_pasta_fq_plonk_gate_vector_add = function (v, x) {\n return plonk_wasm.caml_pasta_fq_plonk_gate_vector_add(\n v,\n caml_fq_plonk_gate_to_rust(x)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_get\n// Requires: plonk_wasm, caml_plonk_gate_of_rust\nvar caml_pasta_fq_plonk_gate_vector_get = function (v, i) {\n return caml_plonk_gate_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_gate_vector_get(v, i)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_len\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_gate_vector_len = function (v) {\n return plonk_wasm.caml_pasta_fq_plonk_gate_vector_len(v);\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_wrap\n// Requires: plonk_wasm, caml_plonk_wire_to_rust\nvar caml_pasta_fq_plonk_gate_vector_wrap = function (v, x, y) {\n return plonk_wasm.caml_pasta_fq_plonk_gate_vector_wrap(\n v,\n caml_plonk_wire_to_rust(x),\n caml_plonk_wire_to_rust(y)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_digest\n// Requires: plonk_wasm, caml_bytes_of_uint8array\nvar caml_pasta_fq_plonk_gate_vector_digest = function (\n public_input_size,\n gate_vector\n) {\n var uint8array = plonk_wasm.caml_pasta_fq_plonk_gate_vector_digest(\n public_input_size,\n gate_vector\n );\n return caml_bytes_of_uint8array(uint8array);\n};\n\n// Provides: caml_pasta_fq_plonk_circuit_serialize\n// Requires: plonk_wasm, caml_string_of_jsstring\nvar caml_pasta_fq_plonk_circuit_serialize = function (\n public_input_size,\n gate_vector\n) {\n return caml_string_of_jsstring(\n plonk_wasm.caml_pasta_fq_plonk_circuit_serialize(\n public_input_size,\n gate_vector\n )\n );\n};\n\n// Provides: caml_fp_runtime_table_cfg_to_rust\n// Requires: plonk_wasm, caml_fp_vector_to_rust\nvar caml_fp_runtime_table_cfg_to_rust = function (\n caml_runtime_table_cfg,\n mk_class\n) {\n // A value caml_runtime_table_cfg is a record on the OCaml side.\n // The converter should be changed if CamlRuntimeTableCfg is modified.\n // id field: int32\n var caml_runtime_table_cfg_id = caml_runtime_table_cfg[1];\n // first_column field: Caml array of fq element\n var caml_runtime_table_cfg_first_column = caml_runtime_table_cfg[2];\n var res = new mk_class(\n caml_runtime_table_cfg_id,\n caml_fp_vector_to_rust(caml_runtime_table_cfg_first_column)\n );\n return res;\n};\n\n// Provides: caml_fp_lookup_table_to_rust\n// Requires: plonk_wasm, caml_fp_vector_of_rust\nvar caml_fp_lookup_table_to_rust = function (caml_lookup_table, mk_class) {\n // A value lookup table is a caml record with an id and a data field.\n // The converter should be changed if CamlLookupTable is modified.\n // id field: int32\n var caml_lookup_table_id = caml_lookup_table[1];\n // data field: caml array of fq vectors\n var caml_lookup_table_data = caml_lookup_table[2];\n // caml_lookup_table_data is a Caml array, starting with 0 for the runtime repr.\n // removing 1 for the 0 used by jsoo to represent values.\n var lt_data_length = caml_lookup_table_data.length - 1;\n var data = new plonk_wasm.WasmVecVecFp(lt_data_length);\n for (var i = 1; i < lt_data_length; i++) {\n data.push(caml_fp_vector_of_rust(caml_lookup_table_data.get(i - 1)));\n }\n var res = new mk_class(caml_lookup_table_id, data);\n return res;\n};\n\n// Provides: caml_fq_lookup_table_to_rust\n// Requires: plonk_wasm, caml_fq_vector_to_rust\nvar caml_fq_lookup_table_to_rust = function (caml_lookup_table, mk_class) {\n // A value lookup table is a caml record with an id and a data field.\n // The converter should be changed if CamlLookupTable is modified.\n // id field: int32\n var caml_lookup_table_id = caml_lookup_table[1];\n // data field: caml array of fq vectors\n var caml_lookup_table_data = caml_lookup_table[2];\n // caml_lookup_table_data is a Caml array, starting with 0 for the runtime repr.\n // removing 1 for the 0 used by jsoo to represent values.\n var lt_data_length = caml_lookup_table_data.length - 1;\n var data = new plonk_wasm.WasmVecVecFq(lt_data_length);\n for (var i = 1; i < lt_data_length; i++) {\n data.push(caml_fq_vector_to_rust(caml_lookup_table_data.get(i - 1)));\n }\n var res = new mk_class(caml_lookup_table_id, data);\n return res;\n};\n\n// Provides: caml_pasta_fp_plonk_index_create\n// Requires: plonk_wasm, free_on_finalize, caml_array_to_rust_vector, caml_fp_runtime_table_cfg_to_rust, caml_fp_lookup_table_to_rust\nvar caml_pasta_fp_plonk_index_create = function (\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n) {\n var wasm_lookup_tables = caml_array_to_rust_vector(\n caml_lookup_tables,\n caml_fp_lookup_table_to_rust,\n plonk_wasm.WasmPastaFpLookupTable\n );\n\n var wasm_runtime_table_cfgs = caml_array_to_rust_vector(\n caml_runtime_table_cfgs,\n caml_fp_runtime_table_cfg_to_rust,\n plonk_wasm.WasmPastaFpRuntimeTableCfg\n );\n\n var t = plonk_wasm.caml_pasta_fp_plonk_index_create(\n gates,\n public_inputs,\n wasm_lookup_tables,\n wasm_runtime_table_cfgs,\n prev_challenges,\n urs\n );\n return free_on_finalize(t);\n};\n\n// Provides: caml_pasta_fp_plonk_index_create_bytecode\n// Requires: caml_pasta_fp_plonk_index_create\nvar caml_pasta_fp_plonk_index_create_bytecode = function (\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n) {\n return caml_pasta_fp_plonk_index_create(\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n );\n};\n\n// Provides: caml_pasta_fp_plonk_index_max_degree\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_index_max_degree =\n plonk_wasm.caml_pasta_fp_plonk_index_max_degree;\n\n// Provides: caml_pasta_fp_plonk_index_public_inputs\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_index_public_inputs =\n plonk_wasm.caml_pasta_fp_plonk_index_public_inputs;\n\n// Provides: caml_pasta_fp_plonk_index_domain_d1_size\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_index_domain_d1_size =\n plonk_wasm.caml_pasta_fp_plonk_index_domain_d1_size;\n\n// Provides: caml_pasta_fp_plonk_index_domain_d4_size\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_index_domain_d4_size =\n plonk_wasm.caml_pasta_fp_plonk_index_domain_d4_size;\n\n// Provides: caml_pasta_fp_plonk_index_domain_d8_size\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_index_domain_d8_size =\n plonk_wasm.caml_pasta_fp_plonk_index_domain_d8_size;\n\n// Provides: caml_pasta_fp_plonk_index_read\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fp_plonk_index_read = function (offset, urs, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n return plonk_wasm.caml_pasta_fp_plonk_index_read(\n offset,\n urs,\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_index_write\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fp_plonk_index_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_pasta_fp_plonk_index_write(\n append,\n t,\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_fq_runtime_table_cfg_to_rust\n// Requires: plonk_wasm, caml_fq_vector_to_rust\nvar caml_fq_runtime_table_cfg_to_rust = function (\n caml_runtime_table_cfg,\n mk_class\n) {\n // A value caml_runtime_table_cfg is a record on the OCaml side.\n // The converter should be changed if CamlRuntimeTableCfg is modified.\n // id field: int32\n var caml_runtime_table_cfg_id = caml_runtime_table_cfg[1];\n // first_column field: Caml array of fq element\n var caml_runtime_table_cfg_first_column = caml_runtime_table_cfg[2];\n var res = new mk_class(\n caml_runtime_table_cfg_id,\n caml_fq_vector_to_rust(caml_runtime_table_cfg_first_column)\n );\n return res;\n};\n\n// Provides: caml_pasta_fq_plonk_index_create\n// Requires: plonk_wasm, free_on_finalize, caml_array_to_rust_vector, caml_fq_runtime_table_cfg_to_rust, caml_fq_lookup_table_to_rust\nvar caml_pasta_fq_plonk_index_create = function (\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n) {\n var wasm_lookup_tables = caml_array_to_rust_vector(\n caml_lookup_tables,\n caml_fq_lookup_table_to_rust,\n plonk_wasm.WasmPastaFqLookupTable\n );\n\n var wasm_runtime_table_cfgs = caml_array_to_rust_vector(\n caml_runtime_table_cfgs,\n caml_fq_runtime_table_cfg_to_rust,\n plonk_wasm.WasmPastaFqRuntimeTableCfg\n );\n\n return free_on_finalize(\n plonk_wasm.caml_pasta_fq_plonk_index_create(\n gates,\n public_inputs,\n wasm_lookup_tables,\n wasm_runtime_table_cfgs,\n prev_challenges,\n urs\n )\n );\n};\n\n// Provides: caml_pasta_fq_plonk_index_create_bytecode\n// Requires: caml_pasta_fq_plonk_index_create\nvar caml_pasta_fq_plonk_index_create_bytecode = function (\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n) {\n return caml_pasta_fq_plonk_index_create(\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n );\n};\n\n// Provides: caml_pasta_fq_plonk_index_max_degree\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_index_max_degree =\n plonk_wasm.caml_pasta_fq_plonk_index_max_degree;\n\n// Provides: caml_pasta_fq_plonk_index_public_inputs\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_index_public_inputs =\n plonk_wasm.caml_pasta_fq_plonk_index_public_inputs;\n\n// Provides: caml_pasta_fq_plonk_index_domain_d1_size\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_index_domain_d1_size =\n plonk_wasm.caml_pasta_fq_plonk_index_domain_d1_size;\n\n// Provides: caml_pasta_fq_plonk_index_domain_d4_size\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_index_domain_d4_size =\n plonk_wasm.caml_pasta_fq_plonk_index_domain_d4_size;\n\n// Provides: caml_pasta_fq_plonk_index_domain_d8_size\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_index_domain_d8_size =\n plonk_wasm.caml_pasta_fq_plonk_index_domain_d8_size;\n\n// Provides: caml_pasta_fq_plonk_index_read\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fq_plonk_index_read = function (offset, urs, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n return plonk_wasm.caml_pasta_fq_plonk_index_read(\n offset,\n urs,\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_index_write\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fq_plonk_index_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_pasta_fq_plonk_index_write(\n append,\n t,\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_plonk_domain_of_rust\nvar caml_plonk_domain_of_rust = function (x) {\n var log_size_of_group = x.log_size_of_group;\n var group_gen = x.group_gen;\n x.free();\n return [0, log_size_of_group, group_gen];\n};\n\n// Provides: caml_plonk_domain_to_rust\n// Requires: free_on_finalize\nvar caml_plonk_domain_to_rust = function (x, klass) {\n // TODO: Check if this gets finalized\n return new klass(x[1], x[2]);\n};\n\n// Provides: caml_plonk_verification_evals_of_rust\n// Requires: caml_poly_comm_of_rust_poly_comm, js_class_vector_of_rust_vector, plonk_wasm\nvar caml_plonk_verification_evals_of_rust = function (x, affine_klass) {\n var convert = function (poly_comm) {\n return caml_poly_comm_of_rust_poly_comm(poly_comm, affine_klass, false);\n };\n\n var convert_opt = function (poly_comm_opt) {\n // Borrowing from caml_option_of_maybe_undefined\n if (poly_comm_opt === undefined) {\n return 0;\n }\n return [\n 0,\n caml_poly_comm_of_rust_poly_comm(poly_comm_opt, affine_klass, false),\n ];\n };\n\n // var convertArray = function(comms) {\n // var n = comms.length;\n // var res = new Array(n-1);\n // for (var i = 1; i < n; i++) {\n // res[i-1] = convert(comms[i]);\n // }\n // return js_class_vector_to_rust_vector(res);\n // };\n\n // should be inverse of the above ^\n // TODO: make work for both Wasm..PolyComm types\n var convertArray = function (comms) {\n comms = js_class_vector_of_rust_vector(comms, plonk_wasm.WasmFqPolyComm);\n // comms = js_class_vector_of_rust_vector(comms, plonk_wasm.WasmFpPolyComm);\n return [0].concat(comms.map(convert));\n };\n\n var sigma_comm = convertArray(x.sigma_comm);\n var coefficients_comm = convertArray(x.coefficients_comm);\n var generic_comm = convert(x.generic_comm);\n var psm_comm = convert(x.psm_comm);\n var complete_add_comm = convert(x.complete_add_comm);\n var mul_comm = convert(x.mul_comm);\n var emul_comm = convert(x.emul_comm);\n var endomul_scalar_comm = convert(x.endomul_scalar_comm);\n\n var xor_comm = convert_opt(x.xor_comm);\n var range_check0_comm = convert_opt(x.range_check0_comm);\n var range_check1_comm = convert_opt(x.range_check1_comm);\n var foreign_field_add_comm = convert_opt(x.foreign_field_add_comm);\n var foreign_field_mul_comm = convert_opt(x.foreign_field_mul_comm);\n var rot_comm = convert_opt(x.rot_comm);\n\n x.free();\n return [\n 0,\n sigma_comm,\n coefficients_comm,\n generic_comm,\n psm_comm,\n complete_add_comm,\n mul_comm,\n emul_comm,\n endomul_scalar_comm,\n xor_comm,\n range_check0_comm,\n range_check1_comm,\n foreign_field_add_comm,\n foreign_field_mul_comm,\n rot_comm,\n ];\n};\n\n// Provides: caml_plonk_verification_evals_to_rust\n// Requires: caml_poly_comm_to_rust_poly_comm, js_class_vector_to_rust_vector\nvar caml_plonk_verification_evals_to_rust = function (\n x,\n klass,\n poly_comm_to_rust\n) {\n var convert_opt = function (poly_comm_opt) {\n // Borrowing from caml_option_to_maybe_undefined\n if (poly_comm_opt === 0) {\n return undefined;\n }\n return poly_comm_to_rust(poly_comm_opt[1]);\n };\n\n var convertArray = function (comms) {\n var n = comms.length;\n var res = new Array(n - 1);\n for (var i = 1; i < n; i++) {\n res[i - 1] = poly_comm_to_rust(comms[i]);\n }\n return js_class_vector_to_rust_vector(res);\n };\n\n var sigma_comm = convertArray(x[1]);\n var coefficients_comm = convertArray(x[2]);\n var generic_comm = poly_comm_to_rust(x[3]);\n var psm_comm = poly_comm_to_rust(x[4]);\n var complete_add_comm = poly_comm_to_rust(x[5]);\n var mul_comm = poly_comm_to_rust(x[6]);\n var emul_comm = poly_comm_to_rust(x[7]);\n var endomul_scalar_comm = poly_comm_to_rust(x[8]);\n\n var xor_comm = convert_opt(x[9]);\n var range_check0_comm = convert_opt(x[10]);\n var range_check1_comm = convert_opt(x[11]);\n var foreign_field_add_comm = convert_opt(x[12]);\n var foreign_field_mul_comm = convert_opt(x[13]);\n var rot_comm = convert_opt(x[14]);\n\n return new klass(\n sigma_comm,\n coefficients_comm,\n generic_comm,\n psm_comm,\n complete_add_comm,\n mul_comm,\n emul_comm,\n endomul_scalar_comm,\n xor_comm,\n range_check0_comm,\n range_check1_comm,\n foreign_field_add_comm,\n foreign_field_mul_comm,\n rot_comm\n );\n};\n\n// Provides: caml_plonk_verification_shifts_of_rust\nvar caml_plonk_verification_shifts_of_rust = function (x) {\n var res = [0, x.s0, x.s1, x.s2, x.s3, x.s4, x.s5, x.s6];\n x.free();\n return res;\n};\n\n// Provides: caml_plonk_verification_shifts_to_rust\nvar caml_plonk_verification_shifts_to_rust = function (x, klass) {\n return new klass(x[1], x[2], x[3], x[4], x[5], x[6], x[7]);\n};\n\n// Provides: column_of_rust\nfunction column_of_rust(col) {\n // type nonrec column = Witness of int | Z | LookupSorted of int | LookupAggreg | LookupTable | LookupKindIndex of int | Index of gate_type | Coefficient of int\n var tag = col.tag;\n var gate_type = col.gate_type;\n var i = col.i;\n col.free();\n return (\n {\n 0: [tag, i],\n 2: [tag, i],\n 5: [tag, i],\n 6: [tag, gate_type],\n 7: [tag, i],\n }[tag] || tag\n );\n}\n\n// Provides: variable_of_rust\n// Requires: column_of_rust\nfunction variable_of_rust(variable) {\n // col * row\n var col = variable.col;\n var row = variable.row; // 0, 1\n variable.free();\n return [0, column_of_rust(col), row];\n}\n\n// Provides: polish_token_of_rust\n// Requires: variable_of_rust\nfunction polish_token_of_rust(token) {\n var tag = token.tag;\n var i0 = token.i0;\n var i1 = token.i1;\n var f = token.f;\n var v = variable_of_rust(token.v);\n token.free();\n return (\n {\n 5: [5, i0, i1],\n 6: [6, f],\n 7: [7, v],\n 9: [9, i0],\n 14: [14, i0],\n 16: [16, i0],\n }[tag] || tag\n );\n}\n\n// Provides: index_term_of_rust\n// Requires: column_of_rust, js_class_vector_of_rust_vector, polish_token_of_rust\nfunction index_term_of_rust(term, token_class) {\n // pub column: WasmColumn,\n // pub coefficient: WasmVector,\n var column = column_of_rust(term.column);\n var coefficient = js_class_vector_of_rust_vector(\n term.coefficient,\n token_class\n );\n coefficient = coefficient.map(polish_token_of_rust);\n coefficient = [0].concat(coefficient);\n term.free();\n return [0, column, coefficient];\n}\n\n// Provides: wrap\nfunction wrap(ptr, klass) {\n var obj = Object.create(klass.prototype);\n obj.ptr = ptr;\n return obj;\n}\n\n// Provides: linearization_of_rust\n// Requires: plonk_wasm, js_class_vector_of_rust_vector, polish_token_of_rust, wrap, index_term_of_rust\nfunction linearization_of_rust(linearization, affine_class) {\n var F = affine_class === plonk_wasm.WasmGVesta ? 'Fq' : 'Fp';\n var WasmPolishToken = plonk_wasm['Wasm' + F + 'PolishToken'];\n var WasmIndexTerm = plonk_wasm['Wasm' + F + 'IndexTerm'];\n\n var constant_term = js_class_vector_of_rust_vector(\n linearization.constant_term,\n WasmPolishToken\n );\n constant_term = constant_term.map(polish_token_of_rust);\n constant_term = [0].concat(constant_term);\n\n var index_terms = Array.from(linearization.index_terms).map(function (ptr) {\n var wasmIndexTerm = wrap(ptr, WasmIndexTerm);\n return index_term_of_rust(wasmIndexTerm, WasmPolishToken);\n });\n index_terms = [0].concat(index_terms);\n\n linearization.free();\n return [0, constant_term, index_terms];\n}\n\n// Provides: None\nvar None = 0;\n\n// Provides: caml_is_none\n// Requires: None\nvar caml_is_none = function (v) {\n return v === None;\n};\n\n// Provides: caml_map_of_rust_vector\n// Requires: js_class_vector_of_rust_vector\nvar caml_map_of_rust_vector = function (v, klass, converter_to_rust) {\n var a = js_class_vector_of_rust_vector(v, klass);\n var res = [0];\n for (var i = 0; i < a.length; ++i) {\n res.push(converter_to_rust(a[i]));\n }\n return res;\n};\n\n// Provides: caml_opt_of_rust\n// Requires: None\nvar caml_opt_of_rust = function (value, value_of_rust) {\n if (value === undefined) {\n return None;\n } else {\n return [0, value_of_rust(value)];\n }\n};\n\n// Provides: caml_bool_of_rust\nvar caml_bool_of_rust = function (bool) {\n return bool;\n};\n\n// Provides: caml_lookup_patterns_of_rust\n// Requires: plonk_wasm, caml_bool_of_rust\nvar caml_lookup_patterns_of_rust = function (wasm_lookup_patterns) {\n return [\n 0,\n caml_bool_of_rust(wasm_lookup_patterns.xor),\n caml_bool_of_rust(wasm_lookup_patterns.lookup),\n caml_bool_of_rust(wasm_lookup_patterns.range_check),\n caml_bool_of_rust(wasm_lookup_patterns.foreign_field_mul),\n ];\n};\n\n// Provides: caml_lookup_features_of_rust\n// Requires: plonk_wasm, caml_lookup_patterns_of_rust, caml_bool_of_rust\nvar caml_lookup_features_of_rust = function (wasm_lookup_features) {\n var caml_lookup_patterns = caml_lookup_patterns_of_rust(\n wasm_lookup_features.patterns\n );\n var caml_joint_lookup_used = caml_bool_of_rust(\n wasm_lookup_features.joint_lookup_used\n );\n var caml_uses_runtime_tables = caml_bool_of_rust(\n wasm_lookup_features.uses_runtime_tables\n );\n\n return [\n 0,\n caml_lookup_patterns,\n caml_joint_lookup_used,\n caml_uses_runtime_tables,\n ];\n};\n\n// Provides: caml_lookup_info_of_rust\n// Requires: plonk_wasm, caml_lookup_features_of_rust\nvar caml_lookup_info_of_rust = function (wasm_lookup_info) {\n var caml_max_per_row = wasm_lookup_info.max_per_row;\n var caml_max_joint_size = wasm_lookup_info.max_joint_size;\n var caml_lookup_features = caml_lookup_features_of_rust(\n wasm_lookup_info.features\n );\n\n return [0, caml_max_per_row, caml_max_joint_size, caml_lookup_features];\n};\n\n// Provides: caml_lookup_selectors_of_rust\n// Requires: plonk_wasm, caml_opt_of_rust\nvar caml_lookup_selectors_of_rust = function (\n wasm_lookup_selectors,\n poly_comm_of_rust\n) {\n var xor = caml_opt_of_rust(wasm_lookup_selectors.xor, poly_comm_of_rust);\n var lookup = caml_opt_of_rust(\n wasm_lookup_selectors.lookup,\n poly_comm_of_rust\n );\n var range_check = caml_opt_of_rust(\n wasm_lookup_selectors.range_check,\n poly_comm_of_rust\n );\n var ffmul = caml_opt_of_rust(wasm_lookup_selectors.ffmul, poly_comm_of_rust);\n\n return [0, xor, lookup, range_check, ffmul];\n};\n\n// Provides: caml_lookup_verifier_index_of_rust\n// Requires: plonk_wasm, caml_map_of_rust_vector, caml_bool_of_rust, caml_lookup_selectors_of_rust, caml_opt_of_rust, caml_lookup_info_of_rust\nvar caml_lookup_verifier_index_of_rust = function (\n wasm_lookup_index,\n poly_comm_class,\n poly_comm_of_rust\n) {\n var caml_joint_lookup_used = caml_bool_of_rust(\n wasm_lookup_index.join_lookup_used\n );\n\n // lookup table\n var caml_lookup_table = caml_map_of_rust_vector(\n wasm_lookup_index.lookup_table,\n poly_comm_class,\n poly_comm_of_rust\n );\n\n var caml_lookup_selectors = caml_lookup_selectors_of_rust(\n wasm_lookup_index.lookup_selectors,\n poly_comm_of_rust\n );\n\n var caml_table_ids = caml_opt_of_rust(\n wasm_lookup_index.table_ids,\n poly_comm_of_rust\n );\n\n var caml_lookup_info = caml_lookup_info_of_rust(\n wasm_lookup_index.lookup_info\n );\n\n var caml_runtime_tables_selector = caml_opt_of_rust(\n wasm_lookup_index.runtime_tables_selector,\n poly_comm_of_rust\n );\n\n return [\n 0,\n caml_joint_lookup_used,\n caml_lookup_table,\n caml_lookup_selectors,\n caml_table_ids,\n caml_lookup_info,\n caml_runtime_tables_selector,\n ];\n};\n\n// Provides: caml_plonk_verifier_index_of_rust\n// Requires: linearization_of_rust, caml_plonk_domain_of_rust, caml_plonk_verification_evals_of_rust, caml_plonk_verification_shifts_of_rust, free_on_finalize, None, caml_opt_of_rust, caml_lookup_verifier_index_of_rust\nvar caml_plonk_verifier_index_of_rust = function (x, affine_class) {\n var domain = caml_plonk_domain_of_rust(x.domain);\n var max_poly_size = x.max_poly_size;\n var public_ = x.public_;\n var prev_challenges = x.prev_challenges;\n var srs = free_on_finalize(x.srs);\n var evals = caml_plonk_verification_evals_of_rust(x.evals, affine_class);\n var shifts = caml_plonk_verification_shifts_of_rust(x.shifts);\n // TODO: Handle linearization correctly!\n // var linearization = linearization_of_rust(x.linearization, affine_class);\n\n var caml_lookup_index = caml_opt_of_rust(\n x.lookup_index,\n caml_lookup_verifier_index_of_rust\n );\n\n x.free();\n return [\n 0,\n domain,\n max_poly_size,\n public_,\n prev_challenges,\n srs,\n evals,\n shifts,\n caml_lookup_index,\n ];\n};\n\n// Provides: caml_opt_to_rust\n// Requires: caml_is_none, None\nvar caml_opt_to_rust = function (caml_optional_value, to_rust) {\n // to_rust expects the parameters of the variant. A `Some vx` is represented\n // as [0, vx]\n if (caml_is_none(caml_optional_value)) {\n return undefined;\n } else {\n return to_rust(caml_optional_value[1]);\n }\n};\n\n// Provides: caml_lookup_selectors_to_rust\n// Requires: plonk_wasm, caml_opt_to_rust\nvar caml_lookup_selectors_to_rust = function (\n wasm_lookup_selectors,\n klass,\n poly_comm_to_rust\n) {\n var xor = caml_opt_to_rust(wasm_lookup_selectors[1], poly_comm_to_rust);\n var lookup = caml_opt_to_rust(wasm_lookup_selectors[2], poly_comm_to_rust);\n var range_check = caml_opt_to_rust(\n wasm_lookup_selectors[3],\n poly_comm_to_rust\n );\n var ffmul = caml_opt_to_rust(wasm_lookup_selectors[4], poly_comm_to_rust);\n\n return new klass(xor, lookup, range_check, ffmul);\n};\n\n// Provides: caml_lookup_table_to_rust\n// Requires: plonk_wasm, caml_array_to_rust_vector, rust_affine_of_caml_affine\nvar caml_lookup_table_to_rust = function (wasm_lookup_table, mk_affine) {\n return caml_array_to_rust_vector(\n wasm_lookup_table,\n rust_affine_of_caml_affine,\n mk_affine\n );\n};\n\n// Provides: caml_lookup_patterns_to_rust\n// Requires: plonk_wasm\nvar caml_lookup_patterns_to_rust = function (wasm_lookup_patterns, klass) {\n var xor = wasm_lookup_patterns[1];\n var lookup = wasm_lookup_patterns[2];\n var range_check = wasm_lookup_patterns[3];\n var foreign_field_mul = wasm_lookup_patterns[4];\n\n return new plonk_wasm.LookupPatterns(\n xor,\n lookup,\n range_check,\n foreign_field_mul\n );\n};\n\n// Provides: caml_lookup_features_to_rust\n// Requires: plonk_wasm, caml_lookup_patterns_to_rust\nvar caml_lookup_features_to_rust = function (wasm_lookup_features) {\n var patterns = caml_lookup_patterns_to_rust(wasm_lookup_features[1]);\n var joint_lookup_used = wasm_lookup_features[2];\n var uses_runtime_tables = wasm_lookup_features[3];\n\n return new plonk_wasm.LookupFeatures(\n patterns,\n joint_lookup_used,\n uses_runtime_tables\n );\n};\n\n// Provides: caml_lookup_info_to_rust\n// Requires: plonk_wasm, caml_lookup_features_to_rust\nvar caml_lookup_info_to_rust = function (wasm_lookup_info) {\n var max_per_row = wasm_lookup_info[1];\n var max_poly_size = wasm_lookup_info[2];\n var features = caml_lookup_features_to_rust(wasm_lookup_info[3]);\n\n return new plonk_wasm.LookupInfo(max_per_row, max_poly_size, features);\n};\n\n// Provides: caml_plonk_lookup_verifier_index_to_rust\n// Requires: plonk_wasm, caml_lookup_table_to_rust, caml_lookup_selectors_to_rust, caml_lookup_info_to_rust, caml_opt_to_rust\nvar caml_plonk_lookup_verifier_index_to_rust = function (\n caml_lookup_verifier_index,\n klass,\n poly_comm_to_rust,\n lookup_selectors_class,\n mk_affine\n) {\n // joint_lookup_used\n var joint_lookup_used = caml_lookup_verifier_index[1];\n\n // lookup_table\n var lookup_table = caml_lookup_table_to_rust(\n caml_lookup_verifier_index[2],\n mk_affine\n );\n\n // lookup_selectors\n var lookup_selectors = caml_lookup_selectors_to_rust(\n caml_lookup_verifier_index[3],\n lookup_selectors_class,\n poly_comm_to_rust\n );\n\n // table_ids\n var table_ids = caml_opt_to_rust(\n caml_lookup_verifier_index[4],\n poly_comm_to_rust\n );\n\n // lookup_info\n var lookup_info = caml_lookup_info_to_rust(caml_lookup_verifier_index[5]);\n\n // runtime_tables_selector\n var runtime_tables_selector = caml_opt_to_rust(\n caml_lookup_verifier_index[6],\n poly_comm_to_rust\n );\n\n return new klass(\n joint_lookup_used,\n lookup_table,\n lookup_selectors,\n table_ids,\n lookup_info,\n runtime_tables_selector\n );\n};\n\n// Provides: caml_plonk_verifier_index_to_rust\n// Requires: caml_plonk_domain_to_rust, caml_plonk_verification_evals_to_rust, caml_plonk_verification_shifts_to_rust, free_finalization_registry, caml_plonk_lookup_verifier_index_to_rust, caml_opt_to_rust, caml_poly_comm_to_rust_poly_comm\nvar caml_plonk_verifier_index_to_rust = function (\n x,\n klass,\n domain_class,\n verification_evals_class,\n poly_comm_class,\n mk_affine,\n verification_shifts_class,\n lookup_verifier_index_class,\n lookup_selectors_class\n) {\n // Defining how to translate polynomial commitments from OCaml back to Rust\n var poly_comm_to_rust = function (poly_comm) {\n return caml_poly_comm_to_rust_poly_comm(\n poly_comm,\n poly_comm_class,\n mk_affine\n );\n };\n\n var domain = caml_plonk_domain_to_rust(x[1], domain_class);\n var max_poly_size = x[2];\n var public_ = x[3];\n var prev_challenges = x[4];\n var srs = x[5];\n\n var evals = caml_plonk_verification_evals_to_rust(\n x[6],\n verification_evals_class,\n poly_comm_to_rust\n );\n\n var shifts = caml_plonk_verification_shifts_to_rust(\n x[7],\n verification_shifts_class\n );\n\n //////////////////////////////////////////////////////////////////////////////\n // The lookup_index_to_rust function is defined only in order to be able to //\n // use the generic caml_opt_to_rust function. //\n // //\n // We could as well inline it but I preferred not having to think about //\n // internal representation of values yet again. //\n //////////////////////////////////////////////////////////////////////////////\n var lookup_index_to_rust = function (lidx) {\n return caml_plonk_lookup_verifier_index_to_rust(\n lidx,\n lookup_verifier_index_class,\n poly_comm_to_rust,\n lookup_selectors_class,\n mk_affine\n );\n };\n\n var wasm_lookup_index = caml_opt_to_rust(x[8], lookup_index_to_rust);\n\n return new klass(\n domain,\n max_poly_size,\n public_,\n prev_challenges,\n srs,\n evals,\n shifts,\n wasm_lookup_index\n );\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_of_rust\n// Requires: plonk_wasm, caml_plonk_verifier_index_of_rust\nvar caml_pasta_fp_plonk_verifier_index_of_rust = function (x) {\n return caml_plonk_verifier_index_of_rust(x, plonk_wasm.WasmGVesta);\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_to_rust\n// Requires: plonk_wasm, caml_plonk_verifier_index_to_rust\nvar caml_pasta_fp_plonk_verifier_index_to_rust = function (x) {\n return caml_plonk_verifier_index_to_rust(\n x,\n plonk_wasm.WasmFpPlonkVerifierIndex,\n plonk_wasm.WasmFpDomain,\n plonk_wasm.WasmFpPlonkVerificationEvals,\n plonk_wasm.WasmFpPolyComm,\n plonk_wasm.caml_vesta_affine_one,\n plonk_wasm.WasmFpShifts,\n plonk_wasm.WasmFpLookupVerifierIndex,\n plonk_wasm.WasmFpLookupSelectors\n );\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_create\n// Requires: plonk_wasm, caml_pasta_fp_plonk_verifier_index_of_rust\nvar caml_pasta_fp_plonk_verifier_index_create = function (x) {\n var vk = plonk_wasm.caml_pasta_fp_plonk_verifier_index_create(x);\n var vk_caml = caml_pasta_fp_plonk_verifier_index_of_rust(vk);\n return vk_caml;\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_read\n// Requires: plonk_wasm, caml_jsstring_of_string, caml_pasta_fp_plonk_verifier_index_of_rust\nvar caml_pasta_fp_plonk_verifier_index_read = function (offset, urs, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n return caml_pasta_fp_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_verifier_index_read(\n offset,\n urs,\n caml_jsstring_of_string(path)\n )\n );\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_write\n// Requires: plonk_wasm, caml_jsstring_of_string, caml_pasta_fp_plonk_verifier_index_to_rust\nvar caml_pasta_fp_plonk_verifier_index_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_pasta_fp_plonk_verifier_index_write(\n append,\n caml_pasta_fp_plonk_verifier_index_to_rust(t),\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_shifts\n// Requires: plonk_wasm, caml_plonk_verification_shifts_of_rust\nvar caml_pasta_fp_plonk_verifier_index_shifts = function (log2_size) {\n return caml_plonk_verification_shifts_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_verifier_index_shifts(log2_size)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_dummy\n// Requires: plonk_wasm, caml_pasta_fp_plonk_verifier_index_of_rust\nvar caml_pasta_fp_plonk_verifier_index_dummy = function () {\n var res = plonk_wasm.caml_pasta_fp_plonk_verifier_index_dummy();\n return caml_pasta_fp_plonk_verifier_index_of_rust(res);\n // return caml_pasta_fp_plonk_verifier_index_of_rust(plonk_wasm.caml_pasta_fp_plonk_verifier_index_dummy());\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_deep_copy\n// Requires: plonk_wasm, caml_pasta_fp_plonk_verifier_index_of_rust, caml_pasta_fp_plonk_verifier_index_to_rust\nvar caml_pasta_fp_plonk_verifier_index_deep_copy = function (x) {\n return caml_pasta_fp_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_verifier_index_deep_copy(\n caml_pasta_fp_plonk_verifier_index_to_rust(x)\n )\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_of_rust\n// Requires: plonk_wasm, caml_plonk_verifier_index_of_rust\nvar caml_pasta_fq_plonk_verifier_index_of_rust = function (x) {\n return caml_plonk_verifier_index_of_rust(x, plonk_wasm.WasmGPallas);\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_to_rust\n// Requires: plonk_wasm, caml_plonk_verifier_index_to_rust\nvar caml_pasta_fq_plonk_verifier_index_to_rust = function (x) {\n return caml_plonk_verifier_index_to_rust(\n x,\n plonk_wasm.WasmFqPlonkVerifierIndex,\n plonk_wasm.WasmFqDomain,\n plonk_wasm.WasmFqPlonkVerificationEvals,\n plonk_wasm.WasmFqPolyComm,\n plonk_wasm.caml_pallas_affine_one,\n plonk_wasm.WasmFqShifts,\n plonk_wasm.WasmFqLookupVerifierIndex,\n plonk_wasm.WasmFqLookupSelectors\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_create\n// Requires: plonk_wasm, caml_pasta_fq_plonk_verifier_index_of_rust\nvar caml_pasta_fq_plonk_verifier_index_create = function (x) {\n return caml_pasta_fq_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_verifier_index_create(x)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_read\n// Requires: plonk_wasm, caml_jsstring_of_string, caml_pasta_fq_plonk_verifier_index_of_rust\nvar caml_pasta_fq_plonk_verifier_index_read = function (offset, urs, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n return caml_pasta_fq_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_verifier_index_read(\n offset,\n urs,\n caml_jsstring_of_string(path)\n )\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_write\n// Requires: plonk_wasm, caml_jsstring_of_string, caml_pasta_fq_plonk_verifier_index_to_rust\nvar caml_pasta_fq_plonk_verifier_index_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_pasta_fq_plonk_verifier_index_write(\n append,\n caml_pasta_fq_plonk_verifier_index_to_rust(t),\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_shifts\n// Requires: plonk_wasm, caml_plonk_verification_shifts_of_rust\nvar caml_pasta_fq_plonk_verifier_index_shifts = function (log2_size) {\n return caml_plonk_verification_shifts_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_verifier_index_shifts(log2_size)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_dummy\n// Requires: plonk_wasm, caml_pasta_fq_plonk_verifier_index_of_rust\nvar caml_pasta_fq_plonk_verifier_index_dummy = function () {\n return caml_pasta_fq_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_verifier_index_dummy()\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_deep_copy\n// Requires: plonk_wasm, caml_pasta_fq_plonk_verifier_index_of_rust, caml_pasta_fq_plonk_verifier_index_to_rust\nvar caml_pasta_fq_plonk_verifier_index_deep_copy = function (x) {\n return caml_pasta_fq_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_verifier_index_deep_copy(\n caml_pasta_fq_plonk_verifier_index_to_rust(x)\n )\n );\n};\n\n// Provides: COLUMNS\nvar COLUMNS = 15;\n// Provides: PERMUTS_MINUS_1\nvar PERMUTS_MINUS_1 = 6;\n\n// Provides: caml_pasta_fp_proof_evaluations_to_rust\n// Requires: plonk_wasm, caml_fp_vector_to_rust, PERMUTS_MINUS_1, COLUMNS\nvar caml_pasta_fp_proof_evaluations_to_rust = function (x) {\n return x;\n};\n\n// Provides: caml_pasta_fp_proof_evaluations_of_rust\n// Requires: plonk_wasm, caml_fp_vector_of_rust, COLUMNS, PERMUTS_MINUS_1\nvar caml_pasta_fp_proof_evaluations_of_rust = function (x) {\n return x;\n};\n\n// Provides: caml_pasta_fp_opening_proof_to_rust\n// Requires: plonk_wasm, caml_array_to_rust_vector, rust_affine_of_caml_affine\nvar caml_pasta_fp_opening_proof_to_rust = function (x) {\n var convert_affines = function (affines) {\n return caml_array_to_rust_vector(\n affines,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_vesta_affine_one\n );\n };\n var lr = x[1];\n var delta = rust_affine_of_caml_affine(\n x[2],\n plonk_wasm.caml_vesta_affine_one\n );\n var z1 = x[3];\n var z2 = x[4];\n var sg = rust_affine_of_caml_affine(x[5], plonk_wasm.caml_vesta_affine_one);\n var len = lr.length;\n // We pass l and r as separate vectors over the FFI\n var l_ocaml = new Array(len);\n var r_ocaml = new Array(len);\n for (var i = 1; i < len; i++) {\n l_ocaml[i] = lr[i][1];\n r_ocaml[i] = lr[i][2];\n }\n var l = convert_affines(l_ocaml);\n var r = convert_affines(r_ocaml);\n return new plonk_wasm.WasmFpOpeningProof(l, r, delta, z1, z2, sg);\n};\n\n// Provides: caml_pasta_fp_opening_proof_of_rust\n// Requires: plonk_wasm, caml_array_of_rust_vector, rust_affine_to_caml_affine\nvar caml_pasta_fp_opening_proof_of_rust = function (x) {\n var convert_affines = function (affines) {\n return caml_array_of_rust_vector(\n affines,\n plonk_wasm.WasmGVesta,\n rust_affine_to_caml_affine,\n false\n );\n };\n var l = convert_affines(x.lr_0);\n var r = convert_affines(x.lr_1);\n var delta = rust_affine_to_caml_affine(x.delta);\n var z1 = x.z1;\n var z2 = x.z2;\n var sg = rust_affine_to_caml_affine(x.sg);\n x.free();\n var len = l.length;\n if (len !== r.length) {\n throw new Error(\"l and r lengths don't match\");\n }\n var lr = new Array(len);\n lr[0] = 0;\n for (var i = 1; i < len; i++) {\n var tuple = new Array(3);\n tuple[0] = 0;\n tuple[1] = l[i];\n tuple[2] = r[i];\n lr[i] = tuple;\n }\n return [0, lr, delta, z1, z2, sg];\n};\n\n// Provides: caml_fp_lookup_commitments_to_rust\n// Requires: plonk_wasm, caml_vesta_poly_comm_to_rust, js_class_vector_to_rust_vector\nvar caml_fp_lookup_commitments_to_rust = function (caml_lc) {\n var convertArray = function (v) {\n var n = v.length - 1;\n var res = new Array(n);\n for (var i = 0; i < n; ++i) {\n res[i] = caml_vesta_poly_comm_to_rust(v[i + 1]);\n }\n return js_class_vector_to_rust_vector(res);\n };\n\n var wasm_sorted = convertArray(caml_lc[1]);\n var wasm_aggreg = caml_vesta_poly_comm_to_rust(caml_lc[2]);\n var wasm_runtime;\n if (caml_lc[3] === 0) {\n wasm_runtime = undefined;\n } else {\n wasm_runtime = caml_vesta_poly_comm_to_rust(caml_lc[3][1]);\n }\n return plonk_wasm.WasmFpLookupCommitments(\n wasm_sorted,\n wasm_aggreg,\n wasm_runtime\n );\n};\n\n// Provides: caml_pasta_fp_commitments_to_rust\n// Requires: plonk_wasm, caml_vesta_poly_comm_to_rust, js_class_vector_to_rust_vector, caml_fp_lookup_commitments_to_rust, caml_opt_to_rust\nvar caml_pasta_fp_commitments_to_rust = function (x) {\n var convertArray = function (v) {\n var n = v.length - 1;\n var res = new Array(n);\n for (var i = 0; i < n; ++i) {\n res[i] = caml_vesta_poly_comm_to_rust(v[i + 1]);\n }\n // TODO need to do finalizer things?\n return js_class_vector_to_rust_vector(res);\n };\n\n var w_comm = convertArray(x[1]);\n var z_comm = caml_vesta_poly_comm_to_rust(x[2]);\n var t_comm = caml_vesta_poly_comm_to_rust(x[3]);\n var lookup = caml_opt_to_rust(x[4], caml_fp_lookup_commitments_to_rust);\n return new plonk_wasm.WasmFpProverCommitments(w_comm, z_comm, t_comm, lookup);\n};\n\n// Provides: caml_fp_lookup_commitments_of_rust\n// Requires: caml_vesta_poly_comm_of_rust, js_class_vector_of_rust_vector, plonk_wasm\nvar caml_fp_lookup_commitments_of_rust = function (wasm_lc) {\n var convertArray = function (v) {\n var a = js_class_vector_of_rust_vector(v, plonk_wasm.WasmFpPolyComm);\n var res = [0];\n for (var i = 0; i < a.length; ++i) {\n res.push(caml_vesta_poly_comm_of_rust(a[i]));\n }\n return res;\n };\n\n var sorted = convertArray(wasm_lc.sorted);\n var aggreg = caml_vesta_poly_comm_of_rust(wasm_lc.aggreg);\n var wasm_lc_runtime = wasm_lc.runtime;\n var caml_runtime;\n if (wasm_lc_runtime === undefined) {\n caml_runtime = 0;\n } else {\n caml_runtime = [0, caml_vesta_poly_comm_of_rust(wasm_lc_runtime)];\n }\n wasm_lc.free();\n return [0, sorted, aggreg, caml_runtime];\n};\n\n// Provides: caml_pasta_fp_commitments_of_rust\n// Requires: caml_vesta_poly_comm_of_rust, js_class_vector_of_rust_vector, plonk_wasm, caml_fp_lookup_commitments_of_rust, caml_opt_of_rust\nvar caml_pasta_fp_commitments_of_rust = function (x) {\n var convertArray = function (v) {\n var a = js_class_vector_of_rust_vector(v, plonk_wasm.WasmFpPolyComm);\n var res = [0];\n for (var i = 0; i < a.length; ++i) {\n // TODO Check this. Could be off by 1\n res.push(caml_vesta_poly_comm_of_rust(a[i]));\n }\n return res;\n };\n\n var w_comm = convertArray(x.w_comm);\n var z_comm = caml_vesta_poly_comm_of_rust(x.z_comm);\n var t_comm = caml_vesta_poly_comm_of_rust(x.t_comm);\n var caml_lookup = caml_opt_of_rust(\n x.lookup,\n caml_fp_lookup_commitments_of_rust\n );\n x.free();\n return [0, w_comm, z_comm, t_comm, caml_lookup];\n};\n\n// Provides: caml_pasta_fp_proof_to_rust\n// Requires: plonk_wasm, caml_pasta_fp_commitments_to_rust, caml_pasta_fp_opening_proof_to_rust, caml_pasta_fp_proof_evaluations_to_rust, caml_fp_vector_to_rust, caml_vesta_poly_comm_to_rust, js_class_vector_to_rust_vector\nvar caml_pasta_fp_proof_to_rust = function (x) {\n var public_evals = x[1];\n x = x[2];\n var commitments = caml_pasta_fp_commitments_to_rust(x[1]);\n var proof = caml_pasta_fp_opening_proof_to_rust(x[2]);\n var evals = caml_pasta_fp_proof_evaluations_to_rust(x[3]);\n var evals_actual = new Array(evals.length + 1);\n evals_actual[0] = 0;\n evals_actual[1] = public_evals;\n for (var i = 2, l = evals_actual.length; i < l; i++) {\n evals_actual[i] = evals[i - 1];\n }\n var ft_eval1 = x[4];\n var public_ = caml_fp_vector_to_rust(x[5]);\n var prev_challenges = x[6];\n var chals_len = prev_challenges.length;\n var prev_challenges_scalars = new plonk_wasm.WasmVecVecFp(chals_len - 1);\n var prev_challenges_comms = new Array(chals_len - 1);\n for (var i = 1; i < chals_len; i++) {\n prev_challenges_scalars.push(caml_fp_vector_to_rust(prev_challenges[i][1]));\n prev_challenges_comms[i - 1] = caml_vesta_poly_comm_to_rust(\n prev_challenges[i][2]\n );\n }\n prev_challenges_comms = js_class_vector_to_rust_vector(prev_challenges_comms);\n return new plonk_wasm.WasmFpProverProof(\n commitments,\n proof,\n evals_actual,\n ft_eval1,\n public_,\n prev_challenges_scalars,\n prev_challenges_comms\n );\n};\n\n// Provides: caml_pasta_fp_proof_of_rust\n// Requires: plonk_wasm, caml_pasta_fp_commitments_of_rust, caml_pasta_fp_opening_proof_of_rust, caml_pasta_fp_proof_evaluations_of_rust, caml_fp_vector_of_rust, js_class_vector_of_rust_vector, caml_vesta_poly_comm_of_rust\nvar caml_pasta_fp_proof_of_rust = function (x) {\n var messages = caml_pasta_fp_commitments_of_rust(x.commitments);\n var proof = caml_pasta_fp_opening_proof_of_rust(x.proof);\n var evals = caml_pasta_fp_proof_evaluations_of_rust(x.evals);\n var public_evals = evals[1];\n var evals_actual = new Array(evals.length - 1);\n evals_actual[0] = 0;\n for (var i = 2, l = evals.length; i < l; i++) {\n evals_actual[i - 1] = evals[i];\n }\n var ft_eval1 = x.ft_eval1;\n var public_ = caml_fp_vector_of_rust(x.public_);\n var prev_challenges_scalars = x.prev_challenges_scalars;\n var prev_challenges_comms = js_class_vector_of_rust_vector(\n x.prev_challenges_comms,\n plonk_wasm.WasmFpPolyComm\n );\n var chals_len = prev_challenges_comms.length;\n var prev_challenges = new Array(chals_len);\n prev_challenges[0] = 0;\n for (var i = 1; i < chals_len; i++) {\n var res = new Array(3);\n res[0] = 0;\n res[1] = caml_fp_vector_of_rust(prev_challenges_scalars.get(i - 1));\n // TODO Check this. Could be off by 1\n res[2] = caml_vesta_poly_comm_of_rust(prev_challenges_comms[i]);\n prev_challenges[i] = res;\n }\n return [\n 0,\n public_evals,\n [0, messages, proof, evals_actual, ft_eval1, public_, prev_challenges],\n ];\n};\n\n// Provides: caml_fp_runtime_table_to_rust\n// Requires: plonk_wasm, caml_fp_vector_to_rust\nvar caml_fp_runtime_table_to_rust = function (caml_runtime_table, mk_class) {\n // A value caml_runtime_table is a record on the OCaml side.\n // id field: int32\n var caml_runtime_table_id = caml_runtime_table[1];\n // data field: Caml array of fq elements\n var caml_runtime_table_data = caml_runtime_table[2];\n var res = new mk_class(\n caml_runtime_table_id,\n caml_fp_vector_to_rust(caml_runtime_table_data)\n );\n return res;\n};\n\n// Provides: caml_pasta_fp_plonk_proof_create\n// Requires: plonk_wasm, caml_fp_vector_to_rust, caml_array_to_rust_vector, rust_affine_of_caml_affine, caml_pasta_fp_proof_of_rust, caml_fp_runtime_table_to_rust\nvar caml_pasta_fp_plonk_proof_create = function (\n index,\n witness_cols,\n caml_runtime_tables,\n prev_challenges,\n prev_sgs\n) {\n var w = new plonk_wasm.WasmVecVecFp(witness_cols.length - 1);\n for (var i = 1; i < witness_cols.length; i++) {\n w.push(caml_fp_vector_to_rust(witness_cols[i]));\n }\n witness_cols = w;\n prev_challenges = caml_fp_vector_to_rust(prev_challenges);\n var wasm_runtime_tables = caml_array_to_rust_vector(\n caml_runtime_tables,\n caml_fp_runtime_table_to_rust,\n plonk_wasm.WasmFpRuntimeTable\n );\n prev_sgs = caml_array_to_rust_vector(\n prev_sgs,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_vesta_affine_one\n );\n var res = plonk_wasm.caml_pasta_fp_plonk_proof_create(\n index,\n witness_cols,\n wasm_runtime_tables,\n prev_challenges,\n prev_sgs\n );\n var proof = caml_pasta_fp_proof_of_rust(res);\n return proof;\n};\n\n// Provides: caml_pasta_fp_plonk_proof_verify\n// Requires: plonk_wasm, caml_array_to_rust_vector, caml_vesta_poly_comm_to_rust, caml_pasta_fp_plonk_verifier_index_to_rust, caml_pasta_fp_proof_to_rust\nvar caml_pasta_fp_plonk_proof_verify = function (index, proof) {\n index = caml_pasta_fp_plonk_verifier_index_to_rust(index);\n proof = caml_pasta_fp_proof_to_rust(proof);\n return plonk_wasm.caml_pasta_fp_plonk_proof_verify(index, proof);\n};\n\n// Provides: caml_pasta_fp_plonk_proof_batch_verify\n// Requires: plonk_wasm, caml_array_to_rust_vector, caml_vesta_poly_comm_to_rust, caml_pasta_fp_plonk_verifier_index_to_rust, caml_pasta_fp_proof_to_rust\nvar caml_pasta_fp_plonk_proof_batch_verify = function (indexes, proofs) {\n indexes = caml_array_to_rust_vector(\n indexes,\n caml_pasta_fp_plonk_verifier_index_to_rust\n );\n proofs = caml_array_to_rust_vector(proofs, caml_pasta_fp_proof_to_rust);\n return plonk_wasm.caml_pasta_fp_plonk_proof_batch_verify(indexes, proofs);\n};\n\n// Provides: caml_pasta_fp_plonk_proof_dummy\n// Requires: plonk_wasm, caml_pasta_fp_proof_of_rust\nvar caml_pasta_fp_plonk_proof_dummy = function () {\n return caml_pasta_fp_proof_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_proof_dummy()\n );\n};\n\n// Provides: caml_pasta_fp_plonk_proof_deep_copy\n// Requires: plonk_wasm, caml_pasta_fp_proof_to_rust, caml_pasta_fp_proof_of_rust\nvar caml_pasta_fp_plonk_proof_deep_copy = function (proof) {\n return caml_pasta_fp_proof_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_proof_deep_copy(\n caml_pasta_fp_proof_to_rust(proof)\n )\n );\n};\n\n// Provides: caml_pasta_fq_proof_evaluations_to_rust\n// Requires: plonk_wasm, caml_fq_vector_to_rust, PERMUTS_MINUS_1, COLUMNS\nvar caml_pasta_fq_proof_evaluations_to_rust = function (x) {\n return x;\n};\n\n// Provides: caml_pasta_fq_proof_evaluations_of_rust\n// Requires: plonk_wasm, caml_fq_vector_of_rust, COLUMNS, PERMUTS_MINUS_1\nvar caml_pasta_fq_proof_evaluations_of_rust = function (x) {\n return x;\n};\n\n// Provides: caml_pasta_fq_opening_proof_to_rust\n// Requires: plonk_wasm, caml_array_to_rust_vector, rust_affine_of_caml_affine\nvar caml_pasta_fq_opening_proof_to_rust = function (x) {\n var convert_affines = function (affines) {\n return caml_array_to_rust_vector(\n affines,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_pallas_affine_one\n );\n };\n var lr = x[1];\n var delta = rust_affine_of_caml_affine(\n x[2],\n plonk_wasm.caml_pallas_affine_one\n );\n var z1 = x[3];\n var z2 = x[4];\n var sg = rust_affine_of_caml_affine(x[5], plonk_wasm.caml_pallas_affine_one);\n var len = lr.length;\n // We pass l and r as separate vectors over the FFI\n var l_ocaml = new Array(len);\n var r_ocaml = new Array(len);\n for (var i = 1; i < len; i++) {\n l_ocaml[i] = lr[i][1];\n r_ocaml[i] = lr[i][2];\n }\n var l = convert_affines(l_ocaml);\n var r = convert_affines(r_ocaml);\n return new plonk_wasm.WasmFqOpeningProof(l, r, delta, z1, z2, sg);\n};\n\n// Provides: caml_pasta_fq_opening_proof_of_rust\n// Requires: plonk_wasm, caml_array_of_rust_vector, rust_affine_to_caml_affine\nvar caml_pasta_fq_opening_proof_of_rust = function (x) {\n var convert_affines = function (affines) {\n return caml_array_of_rust_vector(\n affines,\n plonk_wasm.WasmGPallas,\n rust_affine_to_caml_affine,\n false\n );\n };\n var l = convert_affines(x.lr_0);\n var r = convert_affines(x.lr_1);\n var delta = rust_affine_to_caml_affine(x.delta);\n var z1 = x.z1;\n var z2 = x.z2;\n var sg = rust_affine_to_caml_affine(x.sg);\n x.free();\n var len = l.length;\n if (len !== r.length) {\n throw new Error(\"l and r lengths don't match\");\n }\n var lr = new Array(len);\n lr[0] = 0;\n for (var i = 1; i < len; i++) {\n var tuple = new Array(3);\n tuple[0] = 0;\n tuple[1] = l[i];\n tuple[2] = r[i];\n lr[i] = tuple;\n }\n return [0, lr, delta, z1, z2, sg];\n};\n\n// Provides: caml_fq_lookup_commitments_to_rust\n// Requires: plonk_wasm, caml_pallas_poly_comm_to_rust, js_class_vector_to_rust_vector, caml_opt_to_rust\nvar caml_fq_lookup_commitments_to_rust = function (caml_lc) {\n var convertArray = function (v) {\n var n = v.length - 1;\n var res = new Array(n);\n for (var i = 0; i < n; ++i) {\n res[i] = caml_pallas_poly_comm_to_rust(v[i + 1]);\n }\n return js_class_vector_to_rust_vector(res);\n };\n\n var wasm_sorted = convertArray(caml_lc[1]);\n var wasm_aggreg = caml_pallas_poly_comm_to_rust(caml_lc[2]);\n var wasm_runtime = caml_opt_to_rust(\n caml_lc[3],\n caml_pallas_poly_comm_to_rust\n );\n return plonk_wasm.WasmFqLookupCommitments(\n wasm_sorted,\n wasm_aggreg,\n wasm_runtime\n );\n};\n\n// Provides: caml_pasta_fq_commitments_to_rust\n// Requires: plonk_wasm, caml_pallas_poly_comm_to_rust, js_class_vector_to_rust_vector, caml_fq_lookup_commitments_to_rust, caml_opt_to_rust\nvar caml_pasta_fq_commitments_to_rust = function (x) {\n var convertArray = function (v) {\n var n = v.length - 1;\n var res = new Array(n);\n for (var i = 0; i < n; ++i) {\n res[i] = caml_pallas_poly_comm_to_rust(v[i + 1]);\n }\n return js_class_vector_to_rust_vector(res);\n };\n\n var w_comm = convertArray(x[1]);\n var z_comm = caml_pallas_poly_comm_to_rust(x[2]);\n var t_comm = caml_pallas_poly_comm_to_rust(x[3]);\n var lookup = caml_opt_to_rust(x[4], caml_fq_lookup_commitments_to_rust);\n return new plonk_wasm.WasmFqProverCommitments(w_comm, z_comm, t_comm, lookup);\n};\n\n// Provides: caml_fq_lookup_commitments_of_rust\n// Requires: caml_pallas_poly_comm_of_rust, js_class_vector_of_rust_vector, plonk_wasm\nvar caml_fq_lookup_commitments_of_rust = function (wasm_lc) {\n var convertArray = function (v) {\n var a = js_class_vector_of_rust_vector(v, plonk_wasm.WasmFqPolyComm);\n var res = [0];\n for (var i = 0; i < a.length; ++i) {\n res.push(caml_pallas_poly_comm_of_rust(a[i]));\n }\n return res;\n };\n\n var sorted = convertArray(wasm_lc.sorted);\n var aggreg = caml_pallas_poly_comm_of_rust(wasm_lc.aggreg);\n var wasm_lc_runtime = wasm_lc.runtime;\n var caml_runtime;\n if (wasm_lc_runtime === undefined) {\n caml_runtime = 0;\n } else {\n caml_runtime = [0, caml_pallas_poly_comm_of_rust(wasm_lc_runtime)];\n }\n wasm_lc.free();\n return [0, sorted, aggreg, caml_runtime];\n};\n\n// Provides: caml_pasta_fq_commitments_of_rust\n// Requires: caml_pallas_poly_comm_of_rust, js_class_vector_of_rust_vector, plonk_wasm, caml_fq_lookup_commitments_of_rust, caml_opt_of_rust\nvar caml_pasta_fq_commitments_of_rust = function (x) {\n var convertArray = function (v) {\n var a = js_class_vector_of_rust_vector(v, plonk_wasm.WasmFqPolyComm);\n var res = [0];\n for (var i = 0; i < a.length; ++i) {\n // TODO Check this. Could be off by 1\n res.push(caml_pallas_poly_comm_of_rust(a[i]));\n }\n return res;\n };\n\n var w_comm = convertArray(x.w_comm);\n var z_comm = caml_pallas_poly_comm_of_rust(x.z_comm);\n var t_comm = caml_pallas_poly_comm_of_rust(x.t_comm);\n var caml_lookup = caml_opt_of_rust(\n x.lookup,\n caml_fq_lookup_commitments_of_rust\n );\n x.free();\n return [0, w_comm, z_comm, t_comm, caml_lookup];\n};\n\n// Provides: caml_pasta_fq_proof_to_rust\n// Requires: plonk_wasm, caml_pasta_fq_commitments_to_rust, caml_pasta_fq_opening_proof_to_rust, caml_pasta_fq_proof_evaluations_to_rust, caml_fq_vector_to_rust, caml_pallas_poly_comm_to_rust, js_class_vector_to_rust_vector\nvar caml_pasta_fq_proof_to_rust = function (x) {\n var public_evals = x[1];\n x = x[2];\n var messages = caml_pasta_fq_commitments_to_rust(x[1]);\n var proof = caml_pasta_fq_opening_proof_to_rust(x[2]);\n var evals = caml_pasta_fq_proof_evaluations_to_rust(x[3]);\n var evals_actual = new Array(evals.length + 1);\n evals_actual[0] = 0;\n evals_actual[1] = public_evals;\n for (var i = 2, l = evals_actual.length; i < l; i++) {\n evals_actual[i] = evals[i - 1];\n }\n var ft_eval1 = x[4];\n var public_ = caml_fq_vector_to_rust(x[5]);\n var prev_challenges = x[6];\n var chals_len = prev_challenges.length;\n var prev_challenges_scalars = new plonk_wasm.WasmVecVecFq(chals_len - 1);\n var prev_challenges_comms = new Array(chals_len - 1);\n for (var i = 1; i < chals_len; i++) {\n prev_challenges_scalars.push(caml_fq_vector_to_rust(prev_challenges[i][1]));\n prev_challenges_comms[i - 1] = caml_pallas_poly_comm_to_rust(\n prev_challenges[i][2]\n );\n }\n prev_challenges_comms = js_class_vector_to_rust_vector(prev_challenges_comms);\n return new plonk_wasm.WasmFqProverProof(\n messages,\n proof,\n evals_actual,\n ft_eval1,\n public_,\n prev_challenges_scalars,\n prev_challenges_comms\n );\n};\n\n// Provides: caml_pasta_fq_proof_of_rust\n// Requires: plonk_wasm, caml_pasta_fq_commitments_of_rust, caml_pasta_fq_opening_proof_of_rust, caml_pasta_fq_proof_evaluations_of_rust, caml_fq_vector_of_rust, js_class_vector_of_rust_vector, caml_pallas_poly_comm_of_rust\nvar caml_pasta_fq_proof_of_rust = function (x) {\n var messages = caml_pasta_fq_commitments_of_rust(x.commitments);\n var proof = caml_pasta_fq_opening_proof_of_rust(x.proof);\n var evals = caml_pasta_fq_proof_evaluations_of_rust(x.evals);\n var public_evals = evals[1];\n var evals_actual = new Array(evals.length - 1);\n evals_actual[0] = 0;\n for (var i = 2, l = evals.length; i < l; i++) {\n evals_actual[i - 1] = evals[i];\n }\n var ft_eval1 = x.ft_eval1;\n var public_ = caml_fq_vector_of_rust(x.public_);\n var prev_challenges_scalars = x.prev_challenges_scalars;\n var prev_challenges_comms = js_class_vector_of_rust_vector(\n x.prev_challenges_comms,\n plonk_wasm.WasmFqPolyComm\n );\n var chals_len = prev_challenges_comms.length;\n var prev_challenges = new Array(chals_len);\n prev_challenges[0] = 0;\n for (var i = 1; i < chals_len; i++) {\n var res = new Array(3);\n res[0] = 0;\n res[1] = caml_fq_vector_of_rust(prev_challenges_scalars.get(i - 1));\n res[2] = caml_pallas_poly_comm_of_rust(prev_challenges_comms[i]);\n prev_challenges[i] = res;\n }\n return [\n 0,\n public_evals,\n [0, messages, proof, evals_actual, ft_eval1, public_, prev_challenges],\n ];\n};\n\n// Provides: caml_fq_runtime_table_to_rust\n// Requires: plonk_wasm, caml_fq_vector_to_rust\nvar caml_fq_runtime_table_to_rust = function (caml_runtime_table, mk_class) {\n // A value caml_runtime_table is a record on the OCaml side.\n // id field: int32\n var caml_runtime_table_id = caml_runtime_table[1];\n // data field: Caml array of fq elements\n var caml_runtime_table_data = caml_runtime_table[2];\n var res = new mk_class(\n caml_runtime_table_id,\n caml_fq_vector_to_rust(caml_runtime_table_data)\n );\n return res;\n};\n\n// Provides: caml_pasta_fq_plonk_proof_create\n// Requires: plonk_wasm, caml_fq_vector_to_rust, caml_array_to_rust_vector, rust_affine_of_caml_affine, caml_pasta_fq_proof_of_rust, caml_fq_runtime_table_to_rust\nvar caml_pasta_fq_plonk_proof_create = function (\n index,\n witness_cols,\n caml_runtime_tables,\n prev_challenges,\n prev_sgs\n) {\n var w = new plonk_wasm.WasmVecVecFq(witness_cols.length - 1);\n for (var i = 1; i < witness_cols.length; i++) {\n w.push(caml_fq_vector_to_rust(witness_cols[i]));\n }\n witness_cols = w;\n prev_challenges = caml_fq_vector_to_rust(prev_challenges);\n var wasm_runtime_tables = caml_array_to_rust_vector(\n caml_runtime_tables,\n caml_fq_runtime_table_to_rust,\n plonk_wasm.WasmFqRuntimeTable\n );\n prev_sgs = caml_array_to_rust_vector(\n prev_sgs,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_pallas_affine_one\n );\n var res = plonk_wasm.caml_pasta_fq_plonk_proof_create(\n index,\n witness_cols,\n wasm_runtime_tables,\n prev_challenges,\n prev_sgs\n );\n var proof = caml_pasta_fq_proof_of_rust(res);\n return proof;\n};\n\n// Provides: caml_pasta_fq_plonk_proof_verify\n// Requires: plonk_wasm, caml_array_to_rust_vector, caml_pallas_poly_comm_to_rust, caml_pasta_fq_plonk_verifier_index_to_rust, caml_pasta_fq_proof_to_rust\nvar caml_pasta_fq_plonk_proof_verify = function (index, proof) {\n index = caml_pasta_fq_plonk_verifier_index_to_rust(index);\n proof = caml_pasta_fq_proof_to_rust(proof);\n return plonk_wasm.caml_pasta_fq_plonk_proof_verify(index, proof);\n};\n\n// Provides: caml_pasta_fq_plonk_proof_batch_verify\n// Requires: plonk_wasm, caml_array_to_rust_vector, caml_pallas_poly_comm_to_rust, caml_pasta_fq_plonk_verifier_index_to_rust, caml_pasta_fq_proof_to_rust\nvar caml_pasta_fq_plonk_proof_batch_verify = function (indexes, proofs) {\n indexes = caml_array_to_rust_vector(\n indexes,\n caml_pasta_fq_plonk_verifier_index_to_rust\n );\n proofs = caml_array_to_rust_vector(proofs, caml_pasta_fq_proof_to_rust);\n return plonk_wasm.caml_pasta_fq_plonk_proof_batch_verify(indexes, proofs);\n};\n\n// Provides: caml_pasta_fq_plonk_proof_dummy\n// Requires: plonk_wasm, caml_pasta_fq_proof_of_rust\nvar caml_pasta_fq_plonk_proof_dummy = function () {\n return caml_pasta_fq_proof_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_proof_dummy()\n );\n};\n\n// Provides: caml_pasta_fq_plonk_proof_deep_copy\n// Requires: plonk_wasm, caml_pasta_fq_proof_to_rust, caml_pasta_fq_proof_of_rust\nvar caml_pasta_fq_plonk_proof_deep_copy = function (proof) {\n return caml_pasta_fq_proof_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_proof_deep_copy(\n caml_pasta_fq_proof_to_rust(proof)\n )\n );\n};\n\n// Provides: caml_random_oracles_of_rust\n// Requires: caml_u8array_vector_of_rust_flat_vector, caml_option_of_maybe_undefined\nvar caml_random_oracles_of_rust = function (x) {\n var joint_combiner_chal = x.joint_combiner_chal;\n var joint_combiner = x.joint_combiner;\n var joint_combiner_ocaml = undefined;\n if (joint_combiner_chal !== undefined && joint_combiner !== undefined) {\n joint_combiner_ocaml = [0, [0, joint_combiner_chal], joint_combiner];\n }\n return [\n 0,\n caml_option_of_maybe_undefined(joint_combiner_ocaml),\n x.beta,\n x.gamma,\n [0, x.alpha_chal],\n x.alpha,\n x.zeta,\n x.v,\n x.u,\n [0, x.zeta_chal],\n [0, x.v_chal],\n [0, x.u_chal],\n ];\n};\n\n// Provides: caml_random_oracles_to_rust\n// Requires: caml_u8array_vector_to_rust_flat_vector, caml_option_to_maybe_undefined\nvar caml_random_oracles_to_rust = function (x, roKlass) {\n // var caml_vector = [0, x[1], x[2], x[3][1], x[4], x[5], x[6], x[7], x[8][1], x[9][1], x[10][1]];\n var joint_combiner_ocaml = caml_option_to_maybe_undefined(x[1]);\n var joint_combiner_chal = undefined;\n var joint_combiner = undefined;\n if (joint_combiner_ocaml !== undefined) {\n joint_combiner_chal = joint_combiner_ocaml[1][1];\n joint_combiner = joint_combiner_ocaml[2];\n }\n return new roKlass(\n joint_combiner_chal,\n joint_combiner,\n x[2],\n x[3],\n x[4][1],\n x[5],\n x[6],\n x[7],\n x[8],\n x[9][1],\n x[10][1],\n x[11][1]\n );\n};\n\n// Provides: caml_oracles_of_rust\n// Requires: caml_u8array_vector_of_rust_flat_vector, caml_random_oracles_of_rust\nvar caml_oracles_of_rust = function (x) {\n return [\n 0,\n caml_random_oracles_of_rust(x.o),\n [0, x.p_eval0, x.p_eval1],\n caml_u8array_vector_of_rust_flat_vector(\n x.opening_prechallenges,\n 32 /* TODO: Don't hardcode */\n ),\n x.digest_before_evaluations,\n ];\n};\n\n// Provides: caml_oracles_to_rust\n// Requires: caml_u8array_vector_to_rust_flat_vector, caml_random_oracles_to_rust\nvar caml_oracles_to_rust = function (x, klass, roKlass) {\n return new klass(\n caml_random_oracles_to_rust(x[1], roKlass),\n x[2][1],\n x[2][2],\n caml_u8array_vector_to_rust_flat_vector(x[3]),\n x[4]\n );\n};\n\n// Provides: fp_oracles_create\n// Requires: plonk_wasm, caml_oracles_of_rust, caml_array_to_rust_vector, caml_vesta_poly_comm_to_rust, caml_pasta_fp_plonk_verifier_index_to_rust, caml_pasta_fp_proof_to_rust\nvar fp_oracles_create = function (lgr_comm, verifier_index, proof) {\n return caml_oracles_of_rust(\n plonk_wasm.fp_oracles_create(\n caml_array_to_rust_vector(lgr_comm, caml_vesta_poly_comm_to_rust),\n caml_pasta_fp_plonk_verifier_index_to_rust(verifier_index),\n caml_pasta_fp_proof_to_rust(proof)\n )\n );\n};\n\n// Provides: fp_oracles_create_no_public\n// Requires: fp_oracles_create\nvar fp_oracles_create_no_public = function (lgr_comm, verifier_index, proof) {\n return fp_oracles_create(lgr_comm, verifier_index, [0, 0, proof]);\n};\n\n// Provides: fp_oracles_dummy\n// Requires: plonk_wasm, caml_oracles_of_rust\nvar fp_oracles_dummy = function () {\n return caml_oracles_of_rust(plonk_wasm.fp_oracles_dummy());\n};\n\n// Provides: fp_oracles_deep_copy\n// Requires: plonk_wasm, caml_oracles_of_rust, caml_oracles_to_rust\nvar fp_oracles_deep_copy = function (x) {\n return caml_oracles_of_rust(\n plonk_wasm.fp_oracles_deep_copy(\n caml_oracles_to_rust(\n x,\n plonk_wasm.WasmFpOracles,\n plonk_wasm.WasmFpRandomOracles\n )\n )\n );\n};\n\n// Provides: fq_oracles_create\n// Requires: plonk_wasm, caml_oracles_of_rust, caml_array_to_rust_vector, caml_pallas_poly_comm_to_rust, caml_pasta_fq_plonk_verifier_index_to_rust, caml_pasta_fq_proof_to_rust\nvar fq_oracles_create = function (lgr_comm, verifier_index, proof) {\n return caml_oracles_of_rust(\n plonk_wasm.fq_oracles_create(\n caml_array_to_rust_vector(lgr_comm, caml_pallas_poly_comm_to_rust),\n caml_pasta_fq_plonk_verifier_index_to_rust(verifier_index),\n caml_pasta_fq_proof_to_rust(proof)\n )\n );\n};\n\n// Provides: fq_oracles_create_no_public\n// Requires: fq_oracles_create\nvar fq_oracles_create_no_public = function (lgr_comm, verifier_index, proof) {\n return fq_oracles_create(lgr_comm, verifier_index, [0, 0, proof]);\n};\n\n// Provides: fq_oracles_dummy\n// Requires: plonk_wasm, caml_oracles_of_rust\nvar fq_oracles_dummy = function () {\n return caml_oracles_of_rust(plonk_wasm.fq_oracles_dummy());\n};\n\n// Provides: fq_oracles_deep_copy\n// Requires: plonk_wasm, caml_oracles_of_rust, caml_oracles_to_rust\nvar fq_oracles_deep_copy = function (x) {\n return caml_oracles_of_rust(\n plonk_wasm.fq_oracles_deep_copy(\n caml_oracles_to_rust(\n x,\n plonk_wasm.WasmFqOracles,\n plonk_wasm.WasmFqRandomOracles\n )\n )\n );\n};\n\n// This is fake -- parameters are only needed on the Rust side, so no need to return something meaningful\n// Provides: caml_pasta_fp_poseidon_params_create\nfunction caml_pasta_fp_poseidon_params_create() {\n return [0];\n}\n// Provides: caml_pasta_fq_poseidon_params_create\nfunction caml_pasta_fq_poseidon_params_create() {\n return [0];\n}\n\n// Provides: caml_pasta_fp_poseidon_block_cipher\n// Requires: plonk_wasm, caml_fp_vector_to_rust, caml_fp_vector_of_rust\nfunction caml_pasta_fp_poseidon_block_cipher(_fake_params, fp_vector) {\n // 1. get permuted field vector from rust\n var wasm_flat_vector = plonk_wasm.caml_pasta_fp_poseidon_block_cipher(\n caml_fp_vector_to_rust(fp_vector)\n );\n var new_fp_vector = caml_fp_vector_of_rust(wasm_flat_vector);\n // 2. write back modified field vector to original one\n new_fp_vector.forEach(function (a, i) {\n fp_vector[i] = a;\n });\n}\n\n// Provides: caml_pasta_fq_poseidon_block_cipher\n// Requires: plonk_wasm, caml_fq_vector_to_rust, caml_fq_vector_of_rust\nfunction caml_pasta_fq_poseidon_block_cipher(_fake_params, fq_vector) {\n // 1. get permuted field vector from rust\n var wasm_flat_vector = plonk_wasm.caml_pasta_fq_poseidon_block_cipher(\n caml_fq_vector_to_rust(fq_vector)\n );\n var new_fq_vector = caml_fq_vector_of_rust(wasm_flat_vector);\n // 2. write back modified field vector to original one\n new_fq_vector.forEach(function (a, i) {\n fq_vector[i] = a;\n });\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_lookup\nfunction caml_pasta_fp_plonk_proof_example_with_lookup() {\n // This is only used in the pickles unit tests\n throw new Error(\n 'Unimplemented caml_pasta_fp_plonk_proof_example_with_lookup'\n );\n}\n\n// Provides: prover_to_json\n// Requires: plonk_wasm\nvar prover_to_json = plonk_wasm.prover_to_json;\n\n// Provides: integers_uint64_of_uint32\n// Requires: UInt64, caml_int64_of_int32\nfunction integers_uint64_of_uint32(i) {\n // Same as integers_uint64_of_int\n return new UInt64(caml_int64_of_int32(i));\n}\n\n/////////////////////////////////////////////////////////////////////////////\n// The *_example_* functions below are only used in the pickles unit tests //\n/////////////////////////////////////////////////////////////////////////////\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_ffadd\nfunction caml_pasta_fp_plonk_proof_example_with_ffadd() {\n throw new Error('Unimplemented caml_pasta_fp_plonk_proof_example_with_ffadd');\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_foreign_field_mul\nfunction caml_pasta_fp_plonk_proof_example_with_foreign_field_mul() {\n throw new Error(\n 'Unimplemented caml_pasta_fp_plonk_proof_example_with_foreign_field_mul'\n );\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_range_check\nfunction caml_pasta_fp_plonk_proof_example_with_range_check() {\n throw new Error(\n 'Unimplemented caml_pasta_fp_plonk_proof_example_with_range_check'\n );\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_range_check0\nfunction caml_pasta_fp_plonk_proof_example_with_range_check0() {\n throw new Error(\n 'Unimplemented caml_pasta_fp_plonk_proof_example_with_range_check0'\n );\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_rot\nfunction caml_pasta_fp_plonk_proof_example_with_rot() {\n throw new Error('Unimplemented caml_pasta_fp_plonk_proof_example_with_rot');\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_xor\nfunction caml_pasta_fp_plonk_proof_example_with_xor() {\n throw new Error('Unimplemented caml_pasta_fp_plonk_proof_example_with_xor');\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_compare_val_tag\n//Requires: caml_is_ml_string, caml_is_ml_bytes\nfunction caml_compare_val_tag(a){\n if (typeof a === \"number\") return 1000; // int_tag (we use it for all numbers)\n else if (caml_is_ml_bytes(a)) return 252; // string_tag\n else if (caml_is_ml_string(a)) return 1252; // ocaml string (if different from bytes)\n else if (a instanceof Array && a[0] === (a[0]>>>0) && a[0] <= 255) {\n // Look like an ocaml block\n var tag = a[0] | 0;\n // ignore double_array_tag because we cannot accurately set\n // this tag when we create an array of float.\n return (tag == 254)?0:tag\n }\n else if (a instanceof String) return 12520; // javascript string, like string_tag (252)\n else if (typeof a == \"string\") return 12520; // javascript string, like string_tag (252)\n else if (a instanceof Number) return 1000; // int_tag (we use it for all numbers)\n else if (a && a.caml_custom) return 1255; // like custom_tag (255)\n else if (a && a.compare) return 1256; // like custom_tag (255)\n else if (typeof a == \"function\") return 1247; // like closure_tag (247)\n else if (typeof a == \"symbol\") return 1251;\n return 1001; //out_of_heap_tag\n}\n\n//Provides: caml_compare_val_get_custom\n//Requires: caml_custom_ops\nfunction caml_compare_val_get_custom(a){\n return caml_custom_ops[a.caml_custom] && caml_custom_ops[a.caml_custom].compare;\n}\n\n//Provides: caml_compare_val_number_custom\n//Requires: caml_compare_val_get_custom\nfunction caml_compare_val_number_custom(num, custom, swap, total) {\n var comp = caml_compare_val_get_custom(custom);\n if(comp) {\n var x = (swap > 0)?comp(custom,num,total):comp(num,custom,total);\n if(total && x != x) return swap; // total && nan\n if(+x != +x) return +x; // nan\n if((x | 0) != 0) return (x | 0); // !nan\n }\n return swap\n}\n\n//Provides: caml_compare_val (const, const, const)\n//Requires: caml_int_compare, caml_string_compare, caml_bytes_compare\n//Requires: caml_invalid_argument, caml_compare_val_get_custom, caml_compare_val_tag\n//Requires: caml_compare_val_number_custom\n//Requires: caml_jsbytes_of_string\nfunction caml_compare_val (a, b, total) {\n var stack = [];\n for(;;) {\n if (!(total && a === b)) {\n var tag_a = caml_compare_val_tag(a);\n // forward_tag ?\n if(tag_a == 250) { a = a[1]; continue }\n\n var tag_b = caml_compare_val_tag(b);\n // forward_tag ?\n if(tag_b == 250) { b = b[1]; continue }\n\n // tags are different\n if(tag_a !== tag_b) {\n if(tag_a == 1000) {\n if(tag_b == 1255) { //immediate can compare against custom\n return caml_compare_val_number_custom(a, b, -1, total);\n }\n return -1\n }\n if(tag_b == 1000) {\n if(tag_a == 1255) { //immediate can compare against custom\n return caml_compare_val_number_custom(b, a, 1, total);\n }\n return 1\n }\n return (tag_a < tag_b)?-1:1;\n }\n switch(tag_a){\n // 246: Lazy_tag handled bellow\n case 247: // Closure_tag\n // Cannot happen\n caml_invalid_argument(\"compare: functional value\");\n break\n case 248: // Object\n var x = caml_int_compare(a[2], b[2]);\n if (x != 0) return (x | 0);\n break;\n case 249: // Infix\n // Cannot happen\n caml_invalid_argument(\"compare: functional value\");\n break\n case 250: // Forward tag\n // Cannot happen, handled above\n caml_invalid_argument(\"equal: got Forward_tag, should not happen\");\n break;\n case 251: //Abstract\n caml_invalid_argument(\"equal: abstract value\");\n break;\n case 252: // OCaml bytes\n if (a !== b) {\n var x = caml_bytes_compare(a, b);\n if (x != 0) return (x | 0);\n };\n break;\n case 253: // Double_tag\n // Cannot happen\n caml_invalid_argument(\"equal: got Double_tag, should not happen\");\n break;\n case 254: // Double_array_tag\n // Cannot happen, handled above\n caml_invalid_argument(\"equal: got Double_array_tag, should not happen\");\n break\n case 255: // Custom_tag\n caml_invalid_argument(\"equal: got Custom_tag, should not happen\");\n break;\n case 1247: // Function\n caml_invalid_argument(\"compare: functional value\");\n break;\n case 1255: // Custom\n var comp = caml_compare_val_get_custom(a);\n if(comp != caml_compare_val_get_custom(b)){\n return (a.caml_custom b) return 1;\n if (a != b) {\n if (!total) return NaN;\n if (a == a) return 1;\n if (b == b) return -1;\n }\n break;\n case 1001: // The rest\n // Here we can be in the following cases:\n // 1. JavaScript primitive types\n // 2. JavaScript object that can be coerced to primitive types\n // 3. JavaScript object than cannot be coerced to primitive types\n //\n // (3) will raise a [TypeError]\n // (2) will coerce to primitive types using [valueOf] or [toString]\n // (2) and (3), after eventual coercion\n // - if a and b are strings, apply lexicographic comparison\n // - if a or b are not strings, convert a and b to number\n // and apply standard comparison\n //\n // Exception: `!=` will not coerce/convert if both a and b are objects\n if (a < b) return -1;\n if (a > b) return 1;\n if (a != b) {\n if (!total) return NaN;\n if (a == a) return 1;\n if (b == b) return -1;\n }\n break;\n case 1251: // JavaScript Symbol, no ordering.\n if(a !== b) {\n if (!total) return NaN;\n return 1;\n }\n break;\n case 1252: // ocaml strings\n var a = caml_jsbytes_of_string(a);\n var b = caml_jsbytes_of_string(b);\n if(a !== b) {\n if(a < b) return -1;\n if(a > b) return 1;\n }\n break;\n case 12520: // javascript strings\n var a = a.toString();\n var b = b.toString();\n if(a !== b) {\n if(a < b) return -1;\n if(a > b) return 1;\n }\n break;\n case 246: // Lazy_tag\n case 254: // Double_array\n default: // Block with other tag\n if (a.length != b.length) return (a.length < b.length)?-1:1;\n if (a.length > 1) stack.push(a, b, 1);\n break;\n }\n }\n if (stack.length == 0) return 0;\n var i = stack.pop();\n b = stack.pop();\n a = stack.pop();\n if (i + 1 < a.length) stack.push(a, b, i + 1);\n a = a[i];\n b = b[i];\n }\n}\n//Provides: caml_compare (const, const)\n//Requires: caml_compare_val\nfunction caml_compare (a, b) { return caml_compare_val (a, b, true); }\n//Provides: caml_int_compare mutable (const, const)\nfunction caml_int_compare (a, b) {\n if (a < b) return (-1); if (a == b) return 0; return 1;\n}\n//Provides: caml_equal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_equal (x, y) { return +(caml_compare_val(x,y,false) == 0); }\n//Provides: caml_notequal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_notequal (x, y) { return +(caml_compare_val(x,y,false) != 0); }\n//Provides: caml_greaterequal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_greaterequal (x, y) { return +(caml_compare_val(x,y,false) >= 0); }\n//Provides: caml_greaterthan mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_greaterthan (x, y) { return +(caml_compare_val(x,y,false) > 0); }\n//Provides: caml_lessequal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_lessequal (x, y) { return +(caml_compare_val(x,y,false) <= 0); }\n//Provides: caml_lessthan mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_lessthan (x, y) { return +(caml_compare_val(x,y,false) < 0); }\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n// Weak API, but without the weak semantics\n\n//Provides: caml_ephe_key_offset\nvar caml_ephe_key_offset = 3\n\n//Provides: caml_ephe_data_offset\nvar caml_ephe_data_offset = 2\n\n//Provides: caml_weak_create\n//Requires: caml_ephe_key_offset, caml_invalid_argument\nfunction caml_weak_create (n) {\n if (n < 0) caml_invalid_argument (\"Weak.create\");\n var x = [251,\"caml_ephe_list_head\"];\n x.length = caml_ephe_key_offset + n;\n return x;\n}\n\n//Provides: caml_weak_set\n//Requires: caml_ephe_key_offset, caml_invalid_argument\nfunction caml_weak_set(x, i, v) {\n if(i < 0 || caml_ephe_key_offset + i >= x.length)\n caml_invalid_argument (\"Weak.set\");\n x[caml_ephe_key_offset + i] = v;\n return 0;\n}\n//Provides: caml_weak_get\n//Requires: caml_ephe_key_offset, caml_invalid_argument\nfunction caml_weak_get(x, i) {\n if(i < 0 || caml_ephe_key_offset + i >= x.length)\n caml_invalid_argument (\"Weak.get_key\");\n return (x[caml_ephe_key_offset + i ]===undefined)?0:x[caml_ephe_key_offset + i];\n}\n//Provides: caml_weak_get_copy\n//Requires: caml_weak_get,caml_ephe_key_offset\n//Requires: caml_obj_dup, caml_invalid_argument\nfunction caml_weak_get_copy(x, i) {\n if(i < 0 || caml_ephe_key_offset + i >= x.length)\n caml_invalid_argument (\"Weak.get_copy\");\n var y = caml_weak_get(x, i);\n if (y === 0) return y;\n var z = y[1];\n if (z instanceof Array) return [0, caml_obj_dup(z)];\n return y;\n}\n\n//Provides: caml_weak_check mutable\n//Requires: caml_ephe_key_offset\nfunction caml_weak_check(x, i) {\n if(x[caml_ephe_key_offset + i]!==undefined && x[caml_ephe_key_offset + i] !==0)\n return 1;\n else\n return 0;\n}\n\n//Provides: caml_weak_blit\n//Requires: caml_array_blit\n//Requires: caml_ephe_key_offset\nfunction caml_weak_blit(a1, i1, a2, i2, len) {\n // minus one because caml_array_blit works on ocaml array\n caml_array_blit(a1, caml_ephe_key_offset + i1 - 1,\n a2, caml_ephe_key_offset + i2 - 1,\n len);\n return 0;\n}\n\n//Provides: caml_ephe_create\n//Requires: caml_weak_create\nvar caml_ephe_create = caml_weak_create\n\n//Provides: caml_ephe_blit_key\n//Requires: caml_weak_blit\nvar caml_ephe_blit_key = caml_weak_blit\n\n//Provides: caml_ephe_get_key\n//Requires: caml_weak_get\nvar caml_ephe_get_key = caml_weak_get\n\n//Provides: caml_ephe_get_key_copy\n//Requires: caml_weak_get_copy\nvar caml_ephe_get_key_copy = caml_weak_get_copy\n\n//Provides: caml_ephe_check_key\n//Requires: caml_weak_check\nvar caml_ephe_check_key = caml_weak_check\n\n//Provides: caml_ephe_set_key\n//Requires: caml_weak_set\nfunction caml_ephe_set_key(x, i, v) {\n return caml_weak_set(x, i, [0, v])\n}\n\n//Provides: caml_ephe_unset_key\n//Requires: caml_weak_set\nfunction caml_ephe_unset_key(x, i) {\n return caml_weak_set(x, i, 0)\n}\n\n//Provides: caml_ephe_blit_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_blit_data(src, dst){\n dst[caml_ephe_data_offset] = src[caml_ephe_data_offset];\n return 0;\n}\n\n//Provides: caml_ephe_get_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_get_data(x){\n if(x[caml_ephe_data_offset] === undefined)\n return 0;\n else\n return [0, x[caml_ephe_data_offset]];\n}\n\n//Provides: caml_ephe_get_data_copy\n//Requires: caml_ephe_data_offset\n//Requires: caml_obj_dup\nfunction caml_ephe_get_data_copy(x){\n if(x[caml_ephe_data_offset] === undefined)\n return 0;\n else\n return [0, caml_obj_dup(x[caml_ephe_data_offset])];\n}\n\n//Provides: caml_ephe_set_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_set_data(x, data){\n x[caml_ephe_data_offset] = data;\n return 0;\n}\n\n//Provides: caml_ephe_unset_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_unset_data(x, data){\n x[caml_ephe_data_offset] = undefined;\n return 0;\n}\n\n//Provides: caml_ephe_check_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_check_data(x){\n if(x[caml_ephe_data_offset] === undefined)\n return 0;\n else\n return 1;\n}\n","\n\n//Provides: caml_gc_minor\nfunction caml_gc_minor(){ return 0}\n//Provides: caml_gc_major\nfunction caml_gc_major(){ return 0}\n//Provides: caml_gc_full_major\nfunction caml_gc_full_major(){ return 0}\n//Provides: caml_gc_compaction\nfunction caml_gc_compaction(){ return 0}\n//Provides: caml_gc_counters\nfunction caml_gc_counters() { return [254,0,0,0] }\n//Provides: caml_gc_quick_stat\nfunction caml_gc_quick_stat(){\n return [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]\n}\n//Provides: caml_gc_stat\nfunction caml_gc_stat() {\n return [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]\n}\n\n//Provides: caml_gc_set\nfunction caml_gc_set(_control) {\n return 0;\n}\n\n//Provides: caml_gc_get\nfunction caml_gc_get(){\n return [0,0,0,0,0,0,0,0,0]\n}\n\n//Provides: caml_memprof_set\nfunction caml_memprof_set(_control) {\n return 0;\n}\n\n//Provides: caml_final_register const\nfunction caml_final_register () { return 0; }\n//Provides: caml_final_register_called_without_value const\nfunction caml_final_register_called_without_value () { return 0; }\n//Provides: caml_final_release const\nfunction caml_final_release () { return 0; }\n\n//Provides: caml_memprof_start\nfunction caml_memprof_start(rate,stack_size,tracker){\n return 0;\n}\n\n//Provides: caml_memprof_stop\nfunction caml_memprof_stop(unit) {\n return 0;\n}\n\n//Provides: caml_eventlog_resume\nfunction caml_eventlog_resume(unit) { return 0; }\n\n//Provides: caml_eventlog_pause\nfunction caml_eventlog_pause(unit) { return 0; }\n\n//Provides: caml_gc_huge_fallback_count\nfunction caml_gc_huge_fallback_count(unit) { return 0; }\n\n//Provides: caml_gc_major_slice\nfunction caml_gc_major_slice(work) { return 0; }\n\n//Provides: caml_gc_minor_words\nfunction caml_gc_minor_words(unit) { return 0; }\n\n//Provides: caml_get_minor_free\nfunction caml_get_minor_free(unit) { return 0; }\n\n//Provides: caml_get_major_bucket\nfunction caml_get_major_bucket(n) { return 0; }\n\n//Provides: caml_get_major_credit\nfunction caml_get_major_credit(n) { return 0; }\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Format\n\n//Provides: caml_parse_format\n//Requires: caml_jsbytes_of_string, caml_invalid_argument\nfunction caml_parse_format (fmt) {\n fmt = caml_jsbytes_of_string(fmt);\n var len = fmt.length;\n if (len > 31) caml_invalid_argument(\"format_int: format too long\");\n var f =\n { justify:'+', signstyle:'-', filler:' ', alternate:false,\n base:0, signedconv:false, width:0, uppercase:false,\n sign:1, prec:-1, conv:'f' };\n for (var i = 0; i < len; i++) {\n var c = fmt.charAt(i);\n switch (c) {\n case '-':\n f.justify = '-'; break;\n case '+': case ' ':\n f.signstyle = c; break;\n case '0':\n f.filler = '0'; break;\n case '#':\n f.alternate = true; break;\n case '1': case '2': case '3': case '4': case '5':\n case '6': case '7': case '8': case '9':\n f.width = 0;\n while (c=fmt.charCodeAt(i) - 48, c >= 0 && c <= 9) {\n f.width = f.width * 10 + c; i++\n }\n i--;\n break;\n case '.':\n f.prec = 0;\n i++;\n while (c=fmt.charCodeAt(i) - 48, c >= 0 && c <= 9) {\n f.prec = f.prec * 10 + c; i++\n }\n i--;\n case 'd': case 'i':\n f.signedconv = true; /* fallthrough */\n case 'u':\n f.base = 10; break;\n case 'x':\n f.base = 16; break;\n case 'X':\n f.base = 16; f.uppercase = true; break;\n case 'o':\n f.base = 8; break;\n case 'e': case 'f': case 'g':\n f.signedconv = true; f.conv = c; break;\n case 'E': case 'F': case 'G':\n f.signedconv = true; f.uppercase = true;\n f.conv = c.toLowerCase (); break;\n }\n }\n return f;\n}\n\n//Provides: caml_finish_formatting\n//Requires: caml_string_of_jsbytes\nfunction caml_finish_formatting(f, rawbuffer) {\n if (f.uppercase) rawbuffer = rawbuffer.toUpperCase();\n var len = rawbuffer.length;\n /* Adjust len to reflect additional chars (sign, etc) */\n if (f.signedconv && (f.sign < 0 || f.signstyle != '-')) len++;\n if (f.alternate) {\n if (f.base == 8) len += 1;\n if (f.base == 16) len += 2;\n }\n /* Do the formatting */\n var buffer = \"\";\n if (f.justify == '+' && f.filler == ' ')\n for (var i = len; i < f.width; i++) buffer += ' ';\n if (f.signedconv) {\n if (f.sign < 0) buffer += '-';\n else if (f.signstyle != '-') buffer += f.signstyle;\n }\n if (f.alternate && f.base == 8) buffer += '0';\n if (f.alternate && f.base == 16) buffer += \"0x\";\n if (f.justify == '+' && f.filler == '0')\n for (var i = len; i < f.width; i++) buffer += '0';\n buffer += rawbuffer;\n if (f.justify == '-')\n for (var i = len; i < f.width; i++) buffer += ' ';\n return caml_string_of_jsbytes(buffer);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_update_dummy\nfunction caml_update_dummy (x, y) {\n if( typeof y===\"function\" ) { x.fun = y; return 0; }\n if( y.fun ) { x.fun = y.fun; return 0; }\n var i = y.length; while (i--) x[i] = y[i]; return 0;\n}\n\n//Provides: caml_obj_is_block const (const)\nfunction caml_obj_is_block (x) { return +(x instanceof Array); }\n\n\n//Provides: caml_obj_tag\n//Requires: caml_is_ml_bytes, caml_is_ml_string\nfunction caml_obj_tag (x) {\n if ((x instanceof Array) && x[0] == (x[0] >>> 0))\n return x[0]\n else if (caml_is_ml_bytes(x))\n return 252\n else if (caml_is_ml_string(x))\n return 252\n else if ((x instanceof Function) || typeof x == \"function\")\n return 247\n else if (x && x.caml_custom)\n return 255\n else\n return 1000\n}\n\n//Provides: caml_obj_set_tag (mutable, const)\nfunction caml_obj_set_tag (x, tag) { x[0] = tag; return 0; }\n//Provides: caml_obj_block const (const,const)\nfunction caml_obj_block (tag, size) {\n var o = new Array(size+1);\n o[0]=tag;\n for (var i = 1; i <= size; i++) o[i] = 0;\n return o;\n}\n\n//Provides: caml_obj_with_tag\nfunction caml_obj_with_tag(tag,x) {\n var l = x.length;\n var a = new Array(l);\n a[0] = tag;\n for(var i = 1; i < l; i++ ) a[i] = x[i];\n return a;\n}\n\n//Provides: caml_obj_dup mutable (const)\nfunction caml_obj_dup (x) {\n var l = x.length;\n var a = new Array(l);\n for(var i = 0; i < l; i++ ) a[i] = x[i];\n return a;\n}\n\n//Provides: caml_obj_truncate (mutable, const)\n//Requires: caml_invalid_argument\nfunction caml_obj_truncate (x, s) {\n if (s<=0 || s + 1 > x.length)\n caml_invalid_argument (\"Obj.truncate\");\n if (x.length != s + 1) x.length = s + 1;\n return 0;\n}\n\n//Provides: caml_obj_make_forward\nfunction caml_obj_make_forward (b,v) {\n b[0]=250;\n b[1]=v;\n return 0\n}\n\n//Provides: caml_lazy_make_forward const (const)\nfunction caml_lazy_make_forward (v) { return [250, v]; }\n\n///////////// CamlinternalOO\n//Provides: caml_get_public_method const\nvar caml_method_cache = [];\nfunction caml_get_public_method (obj, tag, cacheid) {\n var meths = obj[1];\n var ofs = caml_method_cache[cacheid];\n if (ofs === undefined) {\n // Make sure the array is not sparse\n for (var i = caml_method_cache.length; i < cacheid; i++)\n caml_method_cache[i] = 0;\n } else if (meths[ofs] === tag) {\n return meths[ofs - 1];\n }\n var li = 3, hi = meths[1] * 2 + 1, mi;\n while (li < hi) {\n mi = ((li+hi) >> 1) | 1;\n if (tag < meths[mi+1]) hi = mi-2;\n else li = mi;\n }\n caml_method_cache[cacheid] = li + 1;\n /* return 0 if tag is not there */\n return (tag == meths[li+1] ? meths[li] : 0);\n}\n\n//Provides: caml_oo_last_id\nvar caml_oo_last_id = 0;\n\n//Provides: caml_set_oo_id\n//Requires: caml_oo_last_id\nfunction caml_set_oo_id (b) {\n b[2]=caml_oo_last_id++;\n return b;\n}\n\n//Provides: caml_fresh_oo_id const\n//Requires: caml_oo_last_id\nfunction caml_fresh_oo_id() {\n return caml_oo_last_id++;\n}\n\n//Provides: caml_obj_raw_field\nfunction caml_obj_raw_field(o,i) { return o[i+1] }\n\n//Provides: caml_obj_set_raw_field\nfunction caml_obj_set_raw_field(o,i,v) { return o[i+1] = v }\n\n//Provides: caml_obj_reachable_words\nfunction caml_obj_reachable_words(o) { return 0; }\n\n//Provides: caml_obj_add_offset\n//Requires: caml_failwith\nfunction caml_obj_add_offset(v,offset) {\n caml_failwith(\"Obj.add_offset is not supported\");\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: fs_node_supported\nfunction fs_node_supported () {\n return (\n typeof globalThis.process !== 'undefined'\n && typeof globalThis.process.versions !== 'undefined'\n && typeof globalThis.process.versions.node !== 'undefined')\n}\n//Provides: fs_node_supported\n//If: browser\nfunction fs_node_supported () {\n return false\n}\n\n\n//Provides: MlNodeDevice\n//Requires: MlNodeFile, caml_raise_sys_error, caml_raise_with_args\n//Requires: make_unix_err_args, caml_named_value, caml_string_of_jsstring\nfunction MlNodeDevice(root) {\n this.fs = require('fs');\n this.root = root;\n}\nMlNodeDevice.prototype.nm = function(name) {\n return (this.root + name);\n}\nMlNodeDevice.prototype.exists = function(name) {\n try {\n return this.fs.existsSync(this.nm(name))?1:0;\n } catch (err) {\n return 0;\n }\n}\nMlNodeDevice.prototype.mkdir = function(name, mode, raise_unix) {\n try {\n this.fs.mkdirSync(this.nm(name),{mode:mode});\n return 0\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.rmdir = function(name, raise_unix) {\n try {\n this.fs.rmdirSync(this.nm(name));\n return 0\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.readdir = function(name, raise_unix) {\n try {\n return this.fs.readdirSync(this.nm(name));\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.is_dir = function(name) {\n try {\n return this.fs.statSync(this.nm(name)).isDirectory()?1:0;\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n}\nMlNodeDevice.prototype.unlink = function(name, raise_unix) {\n try {\n var b = this.fs.existsSync(this.nm(name))?1:0;\n this.fs.unlinkSync(this.nm(name));\n return b;\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.open = function(name, f, raise_unix) {\n var consts = require('constants');\n var res = 0;\n for(var key in f){\n switch(key){\n case \"rdonly\" : res |= consts.O_RDONLY; break;\n case \"wronly\" : res |= consts.O_WRONLY; break;\n case \"append\" :\n res |= consts.O_WRONLY | consts.O_APPEND;\n break;\n case \"create\" : res |= consts.O_CREAT; break;\n case \"truncate\" : res |= consts.O_TRUNC; break;\n case \"excl\" : res |= consts.O_EXCL; break;\n case \"binary\" : res |= consts.O_BINARY; break;\n case \"text\" : res |= consts.O_TEXT; break;\n case \"nonblock\" : res |= consts.O_NONBLOCK; break;\n }\n }\n try {\n var fd = this.fs.openSync(this.nm(name), res);\n return new MlNodeFile(fd);\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\n\nMlNodeDevice.prototype.rename = function(o, n, raise_unix) {\n try {\n this.fs.renameSync(this.nm(o), this.nm(n));\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.stat = function(name, raise_unix) {\n try {\n var js_stats = this.fs.statSync(this.nm(name));\n return this.stats_from_js(js_stats);\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.lstat = function(name, raise_unix) {\n try {\n var js_stats = this.fs.lstatSync(this.nm(name));\n return this.stats_from_js(js_stats);\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.symlink = function(to_dir, target, path, raise_unix) {\n try {\n this.fs.symlinkSync(this.nm(target), this.nm(path), to_dir ? 'dir' : 'file');\n return 0;\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.readlink = function(name, raise_unix) {\n try {\n var link = this.fs.readlinkSync(this.nm(name), 'utf8');\n return caml_string_of_jsstring(link);\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.raise_nodejs_error = function(err, raise_unix) {\n var unix_error = caml_named_value(\"Unix.Unix_error\");\n if (raise_unix && unix_error) {\n var args = make_unix_err_args(err.code, err.syscall, err.path, err.errno);\n caml_raise_with_args(unix_error, args);\n } else {\n caml_raise_sys_error(err.toString());\n }\n}\nMlNodeDevice.prototype.stats_from_js = function(js_stats) {\n /* ===Unix.file_kind===\n * type file_kind =\n * S_REG (** Regular file *)\n * | S_DIR (** Directory *)\n * | S_CHR (** Character device *)\n * | S_BLK (** Block device *)\n * | S_LNK (** Symbolic link *)\n * | S_FIFO (** Named pipe *)\n * | S_SOCK (** Socket *)\n */\n var file_kind;\n if (js_stats.isFile()) {\n file_kind = 0;\n } else if (js_stats.isDirectory()) {\n file_kind = 1;\n } else if (js_stats.isCharacterDevice()) {\n file_kind = 2;\n } else if (js_stats.isBlockDevice()) {\n file_kind = 3;\n } else if (js_stats.isSymbolicLink()) {\n file_kind = 4;\n } else if (js_stats.isFIFO()) {\n file_kind = 5;\n } else if (js_stats.isSocket()) {\n file_kind = 6;\n }\n /* ===Unix.stats===\n * type stats =\n * { st_dev : int; (** Device number *)\n * st_ino : int; (** Inode number *)\n * st_kind : file_kind; (** Kind of the file *)\n * st_perm : file_perm; (** Access rights *)\n * st_nlink : int; (** Number of links *)\n * st_uid : int; (** User id of the owner *)\n * st_gid : int; (** Group ID of the file's group *)\n * st_rdev : int; (** Device ID (if special file) *)\n * st_size : int; (** Size in bytes *)\n * st_atime : float; (** Last access time *)\n * st_mtime : float; (** Last modification time *)\n * st_ctime : float; (** Last status change time *)\n * }\n */\n return BLOCK(\n 0,\n js_stats.dev,\n js_stats.ino,\n file_kind,\n js_stats.mode,\n js_stats.nlink,\n js_stats.uid,\n js_stats.gid,\n js_stats.rdev,\n js_stats.size,\n js_stats.atimeMs,\n js_stats.mtimeMs,\n js_stats.ctimeMs\n );\n}\n\nMlNodeDevice.prototype.constructor = MlNodeDevice\n\n//Provides: MlNodeDevice\n//If: browser\nfunction MlNodeDevice() {\n}\n\n//Provides: MlNodeFile\n//Requires: MlFile, caml_array_of_string, caml_array_of_bytes, caml_bytes_set, caml_raise_sys_error\nfunction MlNodeFile(fd){\n this.fs = require('fs');\n this.fd = fd;\n}\nMlNodeFile.prototype = new MlFile ();\n\nMlNodeFile.prototype.truncate = function(len){\n try {\n this.fs.ftruncateSync(this.fd,len|0)\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n}\nMlNodeFile.prototype.length = function () {\n try {\n return this.fs.fstatSync(this.fd).size;\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n}\nMlNodeFile.prototype.write = function(offset,buf,buf_offset,len){\n var a = caml_array_of_string(buf);\n if(! (a instanceof globalThis.Uint8Array))\n a = new globalThis.Uint8Array(a);\n var buffer = globalThis.Buffer.from(a);\n try {\n this.fs.writeSync(this.fd, buffer, buf_offset, len, offset);\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n return 0;\n}\nMlNodeFile.prototype.read = function(offset,buf,buf_offset,len){\n var a = caml_array_of_bytes(buf);\n if(! (a instanceof globalThis.Uint8Array))\n a = new globalThis.Uint8Array(a);\n var buffer = globalThis.Buffer.from(a);\n try {\n this.fs.readSync(this.fd, buffer, buf_offset, len, offset);\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n for(var i = 0; i < len; i++){\n caml_bytes_set(buf,buf_offset + i,buffer[buf_offset+i]);\n }\n return 0\n}\nMlNodeFile.prototype.read_one = function(offset){\n var a = new globalThis.Uint8Array(1);\n var buffer = globalThis.Buffer.from(a);\n try {\n this.fs.readSync(this.fd, buffer, 0, 1, offset);\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n return buffer[0];\n}\nMlNodeFile.prototype.close = function(){\n try {\n this.fs.closeSync(this.fd);\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n}\n\nMlNodeFile.prototype.constructor = MlNodeFile;\n\n//Provides: MlNodeFile\n//If: browser\nfunction MlNodeFile(){\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Dummy filesystem\n\n//Provides: caml_trailing_slash\nfunction caml_trailing_slash(name){\n return (name.slice(-1) !== \"/\") ? (name + \"/\") : name;\n}\n\n//Provides: caml_current_dir\n//Requires: caml_trailing_slash, fs_node_supported\nif(fs_node_supported () && globalThis.process && globalThis.process.cwd)\n var caml_current_dir = globalThis.process.cwd().replace(/\\\\/g,'/');\nelse\n var caml_current_dir = \"/static\";\ncaml_current_dir = caml_trailing_slash(caml_current_dir);\n\n//Provides: caml_get_root\n//Requires: path_is_absolute\nfunction caml_get_root(path){\n var x = path_is_absolute(path);\n if (!x) return;\n return x[0] + \"/\"}\n\n//Provides: caml_root\n//Requires: caml_get_root, caml_current_dir, caml_failwith\nvar caml_root = caml_get_root(caml_current_dir) || caml_failwith(\"unable to compute caml_root\");\n\n\n//Provides: MlFile\nfunction MlFile(){ }\n\n//Provides: path_is_absolute\n//Requires: fs_node_supported\nfunction make_path_is_absolute() {\n function posix(path) {\n if (path.charAt(0) === '/') return [\"\", path.substring(1)];\n return;\n }\n\n function win32(path) {\n // https://github.com/nodejs/node/blob/b3fcc245fb25539909ef1d5eaa01dbf92e168633/lib/path.js#L56\n var splitDeviceRe = /^([a-zA-Z]:|[\\\\/]{2}[^\\\\/]+[\\\\/]+[^\\\\/]+)?([\\\\/])?([\\s\\S]*?)$/;\n var result = splitDeviceRe.exec(path);\n var device = result[1] || '';\n var isUnc = Boolean(device && device.charAt(1) !== ':');\n\n // UNC paths are always absolute\n if (Boolean(result[2] || isUnc)) {\n var root = (result[1] || '');\n var sep = (result[2] || '');\n return [root, path.substring(root.length + sep.length)]\n }\n return;\n }\n if(fs_node_supported () && globalThis.process && globalThis.process.platform) {\n return globalThis.process.platform === 'win32' ? win32 : posix;\n }\n else return posix\n}\nvar path_is_absolute = make_path_is_absolute();\n\n//Provides: caml_make_path\n//Requires: caml_current_dir\n//Requires: caml_jsstring_of_string, path_is_absolute\nfunction caml_make_path (name) {\n name=caml_jsstring_of_string(name);\n if( !path_is_absolute(name) )\n name = caml_current_dir + name;\n var comp0 = path_is_absolute(name);\n var comp = comp0[1].split(\"/\");\n var ncomp = []\n for(var i = 0; i1) ncomp.pop(); break;\n case \".\": break;\n default: ncomp.push(comp[i]);break\n }\n }\n ncomp.unshift(comp0[0]);\n ncomp.orig = name;\n return ncomp;\n}\n\n//Provides:jsoo_mount_point\n//Requires: MlFakeDevice, MlNodeDevice, caml_root, fs_node_supported\nvar jsoo_mount_point = []\nif (fs_node_supported()) {\n jsoo_mount_point.push({path:caml_root,device:new MlNodeDevice(caml_root)});\n} else {\n jsoo_mount_point.push({path:caml_root,device:new MlFakeDevice(caml_root)});\n}\njsoo_mount_point.push({path:\"/static/\", device:new MlFakeDevice(\"/static/\")});\n\n//Provides:caml_list_mount_point\n//Requires: jsoo_mount_point, caml_string_of_jsbytes\nfunction caml_list_mount_point(){\n var prev = 0\n for(var i = 0; i < jsoo_mount_point.length; i++){\n var old = prev;\n prev = [0, caml_string_of_jsbytes(jsoo_mount_point[i].path), old]\n }\n return prev;\n}\n\n//Provides: resolve_fs_device\n//Requires: caml_make_path, jsoo_mount_point, caml_raise_sys_error, caml_get_root, MlNodeDevice, caml_trailing_slash, fs_node_supported\nfunction resolve_fs_device(name){\n var path = caml_make_path(name);\n var name = path.join(\"/\");\n var name_slash = caml_trailing_slash(name);\n var res;\n for(var i = 0; i < jsoo_mount_point.length; i++) {\n var m = jsoo_mount_point[i];\n if(name_slash.search(m.path) == 0\n && (!res || res.path.length < m.path.length))\n res = {path:m.path,device:m.device,rest:name.substring(m.path.length,name.length)};\n }\n if( !res && fs_node_supported()) {\n var root = caml_get_root(name);\n if (root && root.match(/^[a-zA-Z]:\\/$/)){\n var m = {path:root,device:new MlNodeDevice(root)};\n jsoo_mount_point.push(m);\n res = {path:m.path,device:m.device,rest:name.substring(m.path.length,name.length)};\n }\n }\n if( res ) return res;\n caml_raise_sys_error(\"no device found for \" + name_slash);\n}\n\n//Provides: caml_mount_autoload\n//Requires: MlFakeDevice, caml_make_path, jsoo_mount_point, caml_trailing_slash\nfunction caml_mount_autoload(name,f){\n var path = caml_make_path(name);\n var name = caml_trailing_slash(path.join(\"/\"));\n jsoo_mount_point.push({path:name,device:new MlFakeDevice(name,f)})\n return 0;\n}\n\n//Provides: caml_unmount\n//Requires: jsoo_mount_point, caml_make_path, caml_trailing_slash\nfunction caml_unmount(name){\n var path = caml_make_path(name);\n var name = caml_trailing_slash(path.join(\"/\"));\n var idx = -1;\n for(var i = 0; i < jsoo_mount_point.length; i++)\n if(jsoo_mount_point[i].path == name) idx = i;\n if(idx > -1) jsoo_mount_point.splice(idx,1);\n return 0\n}\n\n//Provides: caml_sys_getcwd\n//Requires: caml_current_dir, caml_string_of_jsbytes\nfunction caml_sys_getcwd() {\n return caml_string_of_jsbytes(caml_current_dir);\n}\n\n//Provides: caml_sys_chdir\n//Requires: caml_current_dir, caml_raise_no_such_file, resolve_fs_device, caml_trailing_slash, caml_jsbytes_of_string\nfunction caml_sys_chdir(dir) {\n var root = resolve_fs_device(dir);\n if(root.device.exists(root.rest)) {\n if(root.rest) caml_current_dir = caml_trailing_slash(root.path + root.rest);\n else caml_current_dir = root.path;\n return 0;\n }\n else {\n caml_raise_no_such_file(caml_jsbytes_of_string(dir));\n }\n}\n\n//Provides: caml_raise_no_such_file\n//Requires: caml_raise_sys_error\nfunction caml_raise_no_such_file(name){\n caml_raise_sys_error (name + \": No such file or directory\");\n}\n\n//Provides: caml_raise_not_a_dir\n//Requires: caml_raise_sys_error\nfunction caml_raise_not_a_dir(name){\n caml_raise_sys_error (name + \": Not a directory\");\n}\n\n//Provides: caml_sys_file_exists\n//Requires: resolve_fs_device\nfunction caml_sys_file_exists (name) {\n var root = resolve_fs_device(name);\n return root.device.exists(root.rest);\n}\n\n//Provides: caml_sys_read_directory\n//Requires: caml_string_of_jsbytes\n//Requires: caml_raise_not_a_dir, resolve_fs_device\nfunction caml_sys_read_directory(name){\n var root = resolve_fs_device(name);\n var a = root.device.readdir(root.rest);\n var l = new Array(a.length + 1);\n l[0] = 0;\n for(var i=0;i start) r+=\", \";\n var v = bucket[i]\n if(typeof v == \"number\")\n r+= v.toString();\n else if(v instanceof MlBytes){\n r+= '\"' + v.toString() + '\"';\n }\n else if(typeof v == \"string\"){\n r+= '\"' + v.toString() + '\"';\n }\n else r += \"_\";\n }\n r += \")\"\n } else if (exn[0] == 248){\n r += exn[1]\n }\n return r\n}\n\n//Provides: caml_fatal_uncaught_exception\n//Requires: caml_named_value, caml_format_exception\nfunction caml_fatal_uncaught_exception(err){\n if(err instanceof Array && (err[0] == 0 || err[0] == 248)) {\n var handler = caml_named_value(\"Printexc.handle_uncaught_exception\");\n if(handler) handler(err,false);\n else {\n var msg = caml_format_exception(err);\n var at_exit = caml_named_value(\"Pervasives.do_at_exit\");\n if(at_exit) { at_exit(0) }\n globalThis.console.error(\"Fatal error: exception \" + msg + \"\\n\");\n }\n }\n else {\n throw err\n }\n}\n\n\n//Provides: caml_set_static_env\nfunction caml_set_static_env(k,v){\n if(!globalThis.jsoo_static_env)\n globalThis.jsoo_static_env = {}\n globalThis.jsoo_static_env[k] = v;\n return 0;\n}\n//Provides: caml_sys_getenv (const)\n//Requires: caml_raise_not_found\n//Requires: caml_string_of_jsstring\n//Requires: caml_jsstring_of_string\nfunction caml_sys_getenv (name) {\n var g = globalThis;\n var n = caml_jsstring_of_string(name);\n //nodejs env\n if(g.process\n && g.process.env\n && g.process.env[n] != undefined)\n return caml_string_of_jsstring(g.process.env[n]);\n if(globalThis.jsoo_static_env\n && globalThis.jsoo_static_env[n])\n return caml_string_of_jsstring(globalThis.jsoo_static_env[n])\n caml_raise_not_found ();\n}\n\n//Provides: caml_sys_unsafe_getenv\n//Requires: caml_sys_getenv\nfunction caml_sys_unsafe_getenv(name){\n return caml_sys_getenv (name);\n}\n\n//Provides: caml_argv\n//Requires: caml_string_of_jsstring\nvar caml_argv = ((function () {\n var g = globalThis;\n var main = \"a.out\";\n var args = []\n\n if(g.process\n && g.process.argv\n && g.process.argv.length > 1) {\n var argv = g.process.argv\n //nodejs\n main = argv[1];\n args = argv.slice(2);\n }\n\n var p = caml_string_of_jsstring(main);\n var args2 = [0, p];\n for(var i = 0; i < args.length; i++)\n args2.push(caml_string_of_jsstring(args[i]));\n return args2;\n})())\n\n//Provides: caml_executable_name\n//Requires: caml_argv\nvar caml_executable_name = caml_argv[1]\n\n//Provides: caml_sys_get_argv\n//Requires: caml_argv\nfunction caml_sys_get_argv (a) {\n return [0, caml_argv[1], caml_argv];\n}\n\n//Provides: caml_sys_argv\n//Requires: caml_argv\nfunction caml_sys_argv (a) {\n return caml_argv;\n}\n\n//Provides: caml_sys_modify_argv\n//Requires: caml_argv\nfunction caml_sys_modify_argv(arg){\n caml_argv = arg;\n return 0;\n}\n\n//Provides: caml_sys_executable_name const\n//Requires: caml_executable_name\nfunction caml_sys_executable_name(a){\n return caml_executable_name\n}\n\n//Provides: caml_sys_system_command\n//Requires: caml_jsstring_of_string\nfunction caml_sys_system_command(cmd){\n var cmd = caml_jsstring_of_string(cmd);\n if (typeof require != \"undefined\"\n && require('child_process')\n && require('child_process').execSync) {\n try {require('child_process').execSync(cmd,{stdio: 'inherit'}); return 0}\n catch (e) {return 1}\n }\n else return 127;\n}\n\n//Provides: caml_sys_time mutable\nvar caml_initial_time = (new Date()).getTime() * 0.001;\nfunction caml_sys_time () {\n var now = (new Date()).getTime();\n return now * 0.001 - caml_initial_time;\n}\n\n//Provides: caml_sys_time_include_children\n//Requires: caml_sys_time\nfunction caml_sys_time_include_children(b) {\n return caml_sys_time();\n}\n\n//Provides: caml_sys_random_seed mutable\n//The function needs to return an array since OCaml 4.0...\nfunction caml_sys_random_seed () {\n if(globalThis.crypto) {\n if(typeof globalThis.crypto.getRandomValues === 'function'){\n // Webbrowsers\n var a = new globalThis.Uint32Array(1);\n globalThis.crypto.getRandomValues(a);\n return [0,a[0]];\n } else if(globalThis.crypto.randomBytes === 'function'){\n // Nodejs\n var buff = globalThis.crypto.randomBytes(4);\n var a = new globalThis.Uint32Array(buff);\n return [0,a[0]];\n }\n }\n var now = (new Date()).getTime();\n var x = now^0xffffffff*Math.random();\n return [0,x];\n}\n\n//Provides: caml_sys_const_big_endian const\nfunction caml_sys_const_big_endian () { return 0; }\n\n//Provides: caml_sys_const_word_size const\nfunction caml_sys_const_word_size () { return 32; }\n\n//Provides: caml_sys_const_int_size const\nfunction caml_sys_const_int_size () { return 32; }\n\n//Provides: caml_sys_const_max_wosize const\n// max_int / 4 so that the following does not overflow\n//let max_string_length = word_size / 8 * max_array_length - 1;;\nfunction caml_sys_const_max_wosize () { return (0x7FFFFFFF/4) | 0;}\n\n//Provides: caml_sys_const_ostype_unix const\n//Requires: os_type\nfunction caml_sys_const_ostype_unix () { return os_type == \"Unix\" ? 1 : 0; }\n//Provides: caml_sys_const_ostype_win32 const\n//Requires: os_type\nfunction caml_sys_const_ostype_win32 () { return os_type == \"Win32\" ? 1 : 0; }\n//Provides: caml_sys_const_ostype_cygwin const\n//Requires: os_type\nfunction caml_sys_const_ostype_cygwin () { return os_type == \"Cygwin\" ? 1 : 0; }\n\n//Provides: caml_sys_const_backend_type const\n//Requires: caml_string_of_jsbytes\nfunction caml_sys_const_backend_type () {\n return [0, caml_string_of_jsbytes(\"js_of_ocaml\")];\n}\n\n//Provides: os_type\nvar os_type = (globalThis.process &&\n globalThis.process.platform &&\n globalThis.process.platform == \"win32\") ? \"Cygwin\" : \"Unix\";\n\n\n//Provides: caml_sys_get_config const\n//Requires: caml_string_of_jsbytes, os_type\nfunction caml_sys_get_config () {\n return [0, caml_string_of_jsbytes(os_type), 32, 0];\n}\n\n//Provides: caml_sys_isatty\nfunction caml_sys_isatty(_chan) {\n return 0;\n}\n\n//Provides: caml_runtime_variant\n//Requires: caml_string_of_jsbytes\nfunction caml_runtime_variant(_unit) {\n return caml_string_of_jsbytes(\"\");\n}\n//Provides: caml_runtime_parameters\n//Requires: caml_string_of_jsbytes\nfunction caml_runtime_parameters(_unit) {\n return caml_string_of_jsbytes(\"\");\n}\n\n//Provides: caml_install_signal_handler const\nfunction caml_install_signal_handler(){return 0}\n\n//Provides: unix_inet_addr_of_string\nfunction unix_inet_addr_of_string () {return 0;}\n\n\n\n//Provides: caml_runtime_warnings\nvar caml_runtime_warnings = 0;\n\n//Provides: caml_ml_enable_runtime_warnings\n//Requires: caml_runtime_warnings\nfunction caml_ml_enable_runtime_warnings (bool) {\n caml_runtime_warnings = bool;\n return 0;\n}\n\n//Provides: caml_ml_runtime_warnings_enabled\n//Requires: caml_runtime_warnings\nfunction caml_ml_runtime_warnings_enabled (_unit) {\n return caml_runtime_warnings;\n}\n\n\n//Provides: caml_spacetime_enabled const (const)\nfunction caml_spacetime_enabled(_unit) {\n return 0;\n}\n\n//Provides: caml_sys_const_naked_pointers_checked const (const)\nfunction caml_sys_const_naked_pointers_checked(_unit) {\n return 0;\n}\n\n//Provides: caml_register_channel_for_spacetime const (const)\nfunction caml_register_channel_for_spacetime(_channel) {\n return 0;\n}\n\n//Provides: caml_spacetime_only_works_for_native_code\n//Requires: caml_failwith\nfunction caml_spacetime_only_works_for_native_code() {\n caml_failwith(\"Spacetime profiling only works for native code\");\n}\n\n//Always\n//Requires: caml_fatal_uncaught_exception\nfunction caml_setup_uncaught_exception_handler() {\n var g = globalThis;\n if(g.process && g.process.on) {\n g.process.on('uncaughtException', function (err, origin) {\n caml_fatal_uncaught_exception(err);\n g.process.exit (2);\n })\n }\n else if(g.addEventListener){\n g.addEventListener('error', function(event){\n if(event.error){\n caml_fatal_uncaught_exception(event.error);\n }\n });\n }\n}\ncaml_setup_uncaught_exception_handler();\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: MlFakeDevice\n//Requires: MlFakeFile, caml_create_bytes\n//Requires: caml_raise_sys_error, caml_raise_no_such_file\n//Requires: caml_string_of_jsbytes, caml_string_of_jsstring\n//Requires: caml_bytes_of_array, caml_bytes_of_string, caml_bytes_of_jsbytes\n//Requires: caml_is_ml_bytes, caml_is_ml_string\n//Requires: caml_named_value, caml_raise_with_args, caml_named_values\n//Requires: make_unix_err_args\nfunction MlFakeDevice (root, f) {\n this.content={};\n this.root = root;\n this.lookupFun = f;\n}\nMlFakeDevice.prototype.nm = function(name) {\n return (this.root + name);\n}\nMlFakeDevice.prototype.create_dir_if_needed = function(name) {\n var comp = name.split(\"/\");\n var res = \"\";\n for(var i = 0; i < comp.length - 1; i++){\n res += comp[i] + \"/\";\n if(this.content[res]) continue;\n this.content[res] = Symbol(\"directory\");\n }\n}\nMlFakeDevice.prototype.slash = function(name){\n return /\\/$/.test(name)?name:(name + \"/\");\n}\nMlFakeDevice.prototype.lookup = function(name) {\n if(!this.content[name] && this.lookupFun) {\n var res = this.lookupFun(caml_string_of_jsbytes(this.root), caml_string_of_jsbytes(name));\n if(res !== 0) {\n this.create_dir_if_needed(name);\n this.content[name]=new MlFakeFile(caml_bytes_of_string(res[1]));\n }\n }\n}\nMlFakeDevice.prototype.exists = function(name) {\n // The root of the device exists\n if(name == \"\") return 1;\n // Check if a directory exists\n var name_slash = this.slash(name);\n if(this.content[name_slash]) return 1;\n // Check if a file exists\n this.lookup(name);\n return this.content[name]?1:0;\n}\nMlFakeDevice.prototype.mkdir = function(name,mode, raise_unix) {\n var unix_error = raise_unix && caml_named_value('Unix.Unix_error');\n if(this.exists(name)) {\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"EEXIST\", \"mkdir\", this.nm(name)));\n }\n else {\n caml_raise_sys_error(name + \": File exists\");\n }\n }\n var parent = /^(.*)\\/[^/]+/.exec(name);\n parent = (parent && parent[1]) || '';\n if(!this.exists(parent)){\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"ENOENT\", \"mkdir\", this.nm(parent)));\n }\n else {\n caml_raise_sys_error(parent + \": No such file or directory\");\n }\n }\n if(!this.is_dir(parent)){\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"ENOTDIR\", \"mkdir\", this.nm(parent)));\n }\n else {\n caml_raise_sys_error(parent + \": Not a directory\");\n }\n }\n this.create_dir_if_needed(this.slash(name));\n}\nMlFakeDevice.prototype.rmdir = function(name, raise_unix) {\n var unix_error = raise_unix && caml_named_value('Unix.Unix_error');\n var name_slash = (name == \"\")?\"\":(this.slash(name));\n var r = new RegExp(\"^\" + name_slash + \"([^/]+)\");\n if(!this.exists(name)) {\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"ENOENT\", \"rmdir\", this.nm(name)));\n }\n else {\n caml_raise_sys_error(name + \": No such file or directory\");\n }\n }\n if(!this.is_dir(name)) {\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"ENOTDIR\", \"rmdir\", this.nm(name)));\n }\n else {\n caml_raise_sys_error(name + \": Not a directory\");\n }\n }\n for(var n in this.content) {\n if(n.match(r)) {\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"ENOTEMPTY\", \"rmdir\", this.nm(name)));\n } else {\n caml_raise_sys_error(this.nm(name) + \": Directory not empty\");\n }\n }\n }\n delete this.content[name_slash];\n}\nMlFakeDevice.prototype.readdir = function(name) {\n var name_slash = (name == \"\")?\"\":(this.slash(name));\n if(!this.exists(name)) {\n caml_raise_sys_error(name + \": No such file or directory\");\n }\n if(!this.is_dir(name)) {\n caml_raise_sys_error(name + \": Not a directory\");\n }\n var r = new RegExp(\"^\" + name_slash + \"([^/]+)\");\n var seen = {}\n var a = [];\n for(var n in this.content) {\n var m = n.match(r);\n if(m && !seen[m[1]]) {seen[m[1]] = true; a.push(m[1])}\n }\n return a;\n}\nMlFakeDevice.prototype.is_dir = function(name) {\n if(name == \"\") return true;\n var name_slash = this.slash(name);\n return this.content[name_slash]?1:0;\n}\nMlFakeDevice.prototype.unlink = function(name) {\n var ok = this.content[name]?true:false;\n delete this.content[name];\n return ok;\n}\nMlFakeDevice.prototype.open = function(name, f) {\n if(f.rdonly && f.wronly)\n caml_raise_sys_error(this.nm(name) + \" : flags Open_rdonly and Open_wronly are not compatible\");\n if(f.text && f.binary)\n caml_raise_sys_error(this.nm(name) + \" : flags Open_text and Open_binary are not compatible\");\n this.lookup(name);\n if (this.content[name]) {\n if (this.is_dir(name)) caml_raise_sys_error(this.nm(name) + \" : is a directory\");\n if (f.create && f.excl) caml_raise_sys_error(this.nm(name) + \" : file already exists\");\n var file = this.content[name];\n if(f.truncate) file.truncate();\n return file;\n } else if (f.create) {\n this.create_dir_if_needed(name);\n this.content[name] = new MlFakeFile(caml_create_bytes(0));\n return this.content[name];\n } else {\n caml_raise_no_such_file (this.nm(name));\n }\n}\n\nMlFakeDevice.prototype.register= function (name,content){\n var file;\n if(this.content[name]) caml_raise_sys_error(this.nm(name) + \" : file already exists\");\n if(caml_is_ml_bytes(content))\n file = new MlFakeFile(content);\n if(caml_is_ml_string(content))\n file = new MlFakeFile(caml_bytes_of_string(content));\n else if(content instanceof Array)\n file = new MlFakeFile(caml_bytes_of_array(content));\n else if(typeof content === \"string\")\n file = new MlFakeFile(caml_bytes_of_jsbytes(content));\n else if(content.toString) {\n var bytes = caml_bytes_of_string(caml_string_of_jsstring(content.toString()));\n file = new MlFakeFile(bytes);\n }\n if(file){\n this.create_dir_if_needed(name);\n this.content[name] = file;\n }\n else caml_raise_sys_error(this.nm(name) + \" : registering file with invalid content type\");\n}\n\nMlFakeDevice.prototype.constructor = MlFakeDevice\n\n//Provides: MlFakeFile\n//Requires: MlFile\n//Requires: caml_create_bytes, caml_ml_bytes_length, caml_blit_bytes, caml_blit_string\n//Requires: caml_bytes_get\nfunction MlFakeFile(content){\n this.data = content;\n}\nMlFakeFile.prototype = new MlFile ();\nMlFakeFile.prototype.truncate = function(len){\n var old = this.data;\n this.data = caml_create_bytes(len|0);\n caml_blit_bytes(old, 0, this.data, 0, len);\n}\nMlFakeFile.prototype.length = function () {\n return caml_ml_bytes_length(this.data);\n}\nMlFakeFile.prototype.write = function(offset,buf,pos,len){\n var clen = this.length();\n if(offset + len >= clen) {\n var new_str = caml_create_bytes(offset + len);\n var old_data = this.data;\n this.data = new_str;\n caml_blit_bytes(old_data, 0, this.data, 0, clen);\n }\n caml_blit_string(buf, pos, this.data, offset, len);\n return 0\n}\nMlFakeFile.prototype.read = function(offset,buf,pos,len){\n var clen = this.length();\n caml_blit_bytes(this.data, offset, buf, pos, len);\n return 0\n}\nMlFakeFile.prototype.read_one = function(offset){\n return caml_bytes_get(this.data, offset);\n}\nMlFakeFile.prototype.close = function(){\n\n}\nMlFakeFile.prototype.constructor = MlFakeFile\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Io\n\n//Provides: caml_sys_close\n//Requires: caml_global_data\nfunction caml_sys_close(fd) {\n delete caml_global_data.fds[fd];\n return 0;\n}\n\n//Provides: caml_std_output\n//Requires: caml_string_of_jsbytes, caml_ml_string_length, caml_ml_channels\nfunction caml_std_output(chanid,s){\n var chan = caml_ml_channels[chanid];\n var str = caml_string_of_jsbytes(s);\n var slen = caml_ml_string_length(str);\n chan.file.write(chan.offset, str, 0, slen);\n chan.offset += slen;\n return 0;\n}\n\n//Provides: caml_sys_open\n//Requires: caml_raise_sys_error, caml_global_data\n//Requires: caml_create_bytes,MlFakeFile\n//Requires: js_print_stderr, js_print_stdout\n//Requires: caml_std_output\n//Requires: resolve_fs_device\n//Requires: caml_jsbytes_of_string\nfunction caml_sys_open_internal(idx,output,file,flags) {\n if(caml_global_data.fds === undefined) caml_global_data.fds = new Array();\n flags=flags?flags:{};\n var info = {};\n info.file = file;\n info.offset = flags.append?file.length():0;\n info.flags = flags;\n info.output = output;\n caml_global_data.fds[idx] = info;\n if(!caml_global_data.fd_last_idx || idx > caml_global_data.fd_last_idx)\n caml_global_data.fd_last_idx = idx;\n return idx;\n}\nfunction caml_sys_open (name, flags, _perms) {\n var f = {};\n while(flags){\n switch(flags[1]){\n case 0: f.rdonly = 1;break;\n case 1: f.wronly = 1;break;\n case 2: f.append = 1;break;\n case 3: f.create = 1;break;\n case 4: f.truncate = 1;break;\n case 5: f.excl = 1; break;\n case 6: f.binary = 1;break;\n case 7: f.text = 1;break;\n case 8: f.nonblock = 1;break;\n }\n flags=flags[2];\n }\n if(f.rdonly && f.wronly)\n caml_raise_sys_error(caml_jsbytes_of_string(name) + \" : flags Open_rdonly and Open_wronly are not compatible\");\n if(f.text && f.binary)\n caml_raise_sys_error(caml_jsbytes_of_string(name) + \" : flags Open_text and Open_binary are not compatible\");\n var root = resolve_fs_device(name);\n var file = root.device.open(root.rest,f);\n var idx = caml_global_data.fd_last_idx?caml_global_data.fd_last_idx:0;\n return caml_sys_open_internal (idx+1,caml_std_output,file,f);\n}\ncaml_sys_open_internal(0,caml_std_output, new MlFakeFile(caml_create_bytes(0))); //stdin\ncaml_sys_open_internal(1,js_print_stdout, new MlFakeFile(caml_create_bytes(0))); //stdout\ncaml_sys_open_internal(2,js_print_stderr, new MlFakeFile(caml_create_bytes(0))); //stderr\n\n\n// ocaml Channels\n\n//Provides: caml_ml_set_channel_name\nfunction caml_ml_set_channel_name() {\n return 0\n}\n\n//Provides: caml_ml_channels\nvar caml_ml_channels = new Array();\n\n//Provides: caml_ml_out_channels_list\n//Requires: caml_ml_channels\nfunction caml_ml_out_channels_list () {\n var l = 0;\n for(var c = 0; c < caml_ml_channels.length; c++){\n if(caml_ml_channels[c] && caml_ml_channels[c].opened && caml_ml_channels[c].out)\n l=[0,caml_ml_channels[c].fd,l];\n }\n return l;\n}\n\n\n//Provides: caml_ml_open_descriptor_out\n//Requires: caml_ml_channels, caml_global_data\n//Requires: caml_raise_sys_error\nfunction caml_ml_open_descriptor_out (fd) {\n var data = caml_global_data.fds[fd];\n if(data.flags.rdonly) caml_raise_sys_error(\"fd \"+ fd + \" is readonly\");\n var channel = {\n file:data.file,\n offset:data.offset,\n fd:fd,\n opened:true,\n out:true,\n buffer:\"\"\n };\n caml_ml_channels[channel.fd]=channel;\n return channel.fd;\n}\n\n//Provides: caml_ml_open_descriptor_in\n//Requires: caml_global_data,caml_sys_open,caml_raise_sys_error, caml_ml_channels\n//Requires: fs_node_supported, caml_string_of_jsstring\nfunction caml_ml_open_descriptor_in (fd) {\n var data = caml_global_data.fds[fd];\n if(data.flags.wronly) caml_raise_sys_error(\"fd \"+ fd + \" is writeonly\");\n var refill = null;\n if(fd == 0 && fs_node_supported()){\n var fs = require('fs');\n refill = function () {\n return caml_string_of_jsstring(fs.readFileSync(0, 'utf8'))};\n }\n var channel = {\n file:data.file,\n offset:data.offset,\n fd:fd,\n opened:true,\n out: false,\n refill:refill\n };\n caml_ml_channels[channel.fd]=channel;\n return channel.fd;\n}\n\n\n//Provides: caml_channel_descriptor\n//Requires: caml_global_data, caml_ml_channels\nfunction caml_channel_descriptor(chanid){\n var chan = caml_ml_channels[chanid];\n return chan.fd;\n}\n\n//Provides: win_filedescr_of_channel\n//Requires: caml_channel_descriptor\nvar win_filedescr_of_channel = caml_channel_descriptor\n\n//Provides: caml_ml_set_binary_mode\n//Requires: caml_global_data, caml_ml_channels\nfunction caml_ml_set_binary_mode(chanid,mode){\n var chan = caml_ml_channels[chanid];\n var data = caml_global_data.fds[chan.fd];\n data.flags.text = !mode\n data.flags.binary = mode\n return 0;\n}\n\n//Input from in_channel\n\n//Provides: caml_ml_close_channel\n//Requires: caml_ml_flush, caml_ml_channels\n//Requires: caml_sys_close\nfunction caml_ml_close_channel (chanid) {\n var chan = caml_ml_channels[chanid];\n caml_ml_flush(chanid);\n chan.opened = false;\n chan.file.close();\n caml_sys_close(chan.fd)\n return 0;\n}\n\n//Provides: caml_ml_channel_size\n//Requires: caml_ml_channels\nfunction caml_ml_channel_size(chanid) {\n var chan = caml_ml_channels[chanid];\n return chan.file.length();\n}\n\n//Provides: caml_ml_channel_size_64\n//Requires: caml_int64_of_float,caml_ml_channels\nfunction caml_ml_channel_size_64(chanid) {\n var chan = caml_ml_channels[chanid];\n return caml_int64_of_float(chan.file.length ());\n}\n\n//Provides: caml_ml_set_channel_output\n//Requires: caml_ml_channels, caml_global_data\nfunction caml_ml_set_channel_output(chanid,f) {\n var chan = caml_ml_channels[chanid];\n caml_global_data.fds[chan.fd].output = f;\n return 0;\n}\n\n//Provides: caml_ml_set_channel_refill\n//Requires: caml_ml_channels, caml_global_data\nfunction caml_ml_set_channel_refill(chanid,f) {\n caml_ml_channels[chanid].refill = f;\n return 0;\n}\n\n//Provides: caml_ml_refill_input\n//Requires: caml_ml_string_length\nfunction caml_ml_refill_input (chan) {\n var str = chan.refill();\n var str_len = caml_ml_string_length(str);\n if (str_len == 0) chan.refill = null;\n chan.file.write(chan.file.length(), str, 0, str_len);\n return str_len;\n}\n\n//Provides: caml_ml_may_refill_input\n//Requires: caml_ml_refill_input, caml_ml_channels\nfunction caml_ml_may_refill_input (chanid) {\n var chan = caml_ml_channels[chanid];\n if (chan.refill == null) return;\n if (chan.file.length() != chan.offset) return;\n caml_ml_refill_input (chan);\n}\n\n//Provides: caml_ml_input\n//Requires: caml_ml_refill_input, caml_ml_channels\nfunction caml_ml_input (chanid, s, i, l) {\n var chan = caml_ml_channels[chanid];\n var l2 = chan.file.length() - chan.offset;\n if (l2 == 0 && chan.refill != null) l2 = caml_ml_refill_input(chan);\n if (l2 < l) l = l2;\n chan.file.read(chan.offset, s, i, l);\n chan.offset += l;\n return l;\n}\n\n//Provides: caml_input_value\n//Requires: caml_marshal_data_size, caml_input_value_from_bytes, caml_create_bytes, caml_ml_channels\nfunction caml_input_value (chanid) {\n var chan = caml_ml_channels[chanid];\n\n var buf = caml_create_bytes(8);\n chan.file.read(chan.offset,buf,0,8);\n\n // Header is 20 bytes\n var len = caml_marshal_data_size (buf, 0) + 20;\n\n var buf = caml_create_bytes(len);\n chan.file.read(chan.offset,buf,0,len);\n\n var offset = [0];\n var res = caml_input_value_from_bytes(buf, offset);\n chan.offset = chan.offset + offset[0];\n return res;\n}\n\n//Provides: caml_ml_input_char\n//Requires: caml_raise_end_of_file, caml_array_bound_error\n//Requires: caml_ml_may_refill_input, caml_ml_channels\nfunction caml_ml_input_char (chanid) {\n var chan = caml_ml_channels[chanid];\n caml_ml_may_refill_input(chanid);\n if (chan.offset >= chan.file.length())\n caml_raise_end_of_file();\n var res = chan.file.read_one(chan.offset);\n chan.offset++;\n return res;\n}\n\n//Provides: caml_ml_input_int\n//Requires: caml_raise_end_of_file\n//Requires: caml_ml_refill_input, caml_ml_channels\nfunction caml_ml_input_int (chanid) {\n var chan = caml_ml_channels[chanid];\n var file = chan.file;\n while ((chan.offset + 3) >= file.length()) {\n var l = caml_ml_refill_input(chan);\n if (l == 0) caml_raise_end_of_file();\n }\n var o = chan.offset;\n var r =(file.read_one(o ) << 24)\n | (file.read_one(o+1) << 16)\n | (file.read_one(o+2) << 8)\n | (file.read_one(o+3));\n chan.offset+=4;\n return r;\n}\n\n//Provides: caml_ml_seek_in\n//Requires: caml_raise_sys_error, caml_ml_channels\nfunction caml_ml_seek_in(chanid,pos){\n var chan = caml_ml_channels[chanid];\n if (chan.refill != null) caml_raise_sys_error(\"Illegal seek\");\n chan.offset = pos;\n return 0;\n}\n\n//Provides: caml_ml_seek_in_64\n//Requires: caml_int64_to_float, caml_raise_sys_error, caml_ml_channels\nfunction caml_ml_seek_in_64(chanid,pos){\n var chan = caml_ml_channels[chanid];\n if (chan.refill != null) caml_raise_sys_error(\"Illegal seek\");\n chan.offset = caml_int64_to_float(pos);\n return 0;\n}\n\n//Provides: caml_ml_pos_in\n//Requires: caml_ml_channels\nfunction caml_ml_pos_in(chanid) {return caml_ml_channels[chanid].offset}\n\n//Provides: caml_ml_pos_in_64\n//Requires: caml_int64_of_float, caml_ml_channels\nfunction caml_ml_pos_in_64(chanid) {return caml_int64_of_float(caml_ml_channels[chanid].offset)}\n\n//Provides: caml_ml_input_scan_line\n//Requires: caml_array_bound_error\n//Requires: caml_ml_may_refill_input, caml_ml_channels\nfunction caml_ml_input_scan_line(chanid){\n var chan = caml_ml_channels[chanid];\n caml_ml_may_refill_input(chanid);\n var p = chan.offset;\n var len = chan.file.length();\n if(p >= len) { return 0;}\n while(true) {\n if(p >= len) return - (p - chan.offset);\n if(chan.file.read_one(p) == 10) return p - chan.offset + 1;\n p++;\n }\n}\n\n//Provides: caml_ml_flush\n//Requires: caml_raise_sys_error, caml_global_data, caml_ml_channels\nfunction caml_ml_flush (chanid) {\n var chan = caml_ml_channels[chanid];\n if(! chan.opened) caml_raise_sys_error(\"Cannot flush a closed channel\");\n if(!chan.buffer || chan.buffer == \"\") return 0;\n if(chan.fd\n && caml_global_data.fds[chan.fd]\n && caml_global_data.fds[chan.fd].output) {\n var output = caml_global_data.fds[chan.fd].output;\n switch(output.length){\n case 2: output(chanid,chan.buffer);break;\n default: output(chan.buffer)\n };\n }\n chan.buffer = \"\";\n return 0;\n}\n\n//output to out_channel\n\n//Provides: caml_ml_output_bytes\n//Requires: caml_ml_flush,caml_ml_bytes_length\n//Requires: caml_create_bytes, caml_blit_bytes, caml_raise_sys_error, caml_ml_channels, caml_string_of_bytes\n//Requires: caml_jsbytes_of_string\nfunction caml_ml_output_bytes(chanid,buffer,offset,len) {\n var chan = caml_ml_channels[chanid];\n if(! chan.opened) caml_raise_sys_error(\"Cannot output to a closed channel\");\n var bytes;\n if(offset == 0 && caml_ml_bytes_length(buffer) == len)\n bytes = buffer;\n else {\n bytes = caml_create_bytes(len);\n caml_blit_bytes(buffer,offset,bytes,0,len);\n }\n var string = caml_string_of_bytes(bytes);\n var jsstring = caml_jsbytes_of_string(string);\n var id = jsstring.lastIndexOf(\"\\n\");\n if(id < 0)\n chan.buffer+=jsstring;\n else {\n chan.buffer+=jsstring.substr(0,id+1);\n caml_ml_flush (chanid);\n chan.buffer += jsstring.substr(id+1);\n }\n return 0;\n}\n\n//Provides: caml_ml_output\n//Requires: caml_ml_output_bytes, caml_bytes_of_string\nfunction caml_ml_output(chanid,buffer,offset,len){\n return caml_ml_output_bytes(chanid,caml_bytes_of_string(buffer),offset,len);\n}\n\n//Provides: caml_ml_output_char\n//Requires: caml_ml_output\n//Requires: caml_string_of_jsbytes\nfunction caml_ml_output_char (chanid,c) {\n var s = caml_string_of_jsbytes(String.fromCharCode(c));\n caml_ml_output(chanid,s,0,1);\n return 0;\n}\n\n//Provides: caml_output_value\n//Requires: caml_output_value_to_string, caml_ml_output,caml_ml_string_length\nfunction caml_output_value (chanid,v,flags) {\n var s = caml_output_value_to_string(v, flags);\n caml_ml_output(chanid,s,0,caml_ml_string_length(s));\n return 0;\n}\n\n\n//Provides: caml_ml_seek_out\n//Requires: caml_ml_channels, caml_ml_flush\nfunction caml_ml_seek_out(chanid,pos){\n caml_ml_flush(chanid);\n caml_ml_channels[chanid].offset = pos;\n return 0;\n}\n\n//Provides: caml_ml_seek_out_64\n//Requires: caml_int64_to_float, caml_ml_channels, caml_ml_flush\nfunction caml_ml_seek_out_64(chanid,pos){\n caml_ml_flush(chanid);\n caml_ml_channels[chanid].offset = caml_int64_to_float(pos);\n return 0;\n}\n\n//Provides: caml_ml_pos_out\n//Requires: caml_ml_channels, caml_ml_flush\nfunction caml_ml_pos_out(chanid) {\n caml_ml_flush(chanid);\n return caml_ml_channels[chanid].offset\n}\n\n//Provides: caml_ml_pos_out_64\n//Requires: caml_int64_of_float, caml_ml_channels, caml_ml_flush\nfunction caml_ml_pos_out_64(chanid) {\n caml_ml_flush(chanid);\n return caml_int64_of_float (caml_ml_channels[chanid].offset);\n}\n\n//Provides: caml_ml_output_int\n//Requires: caml_ml_output\n//Requires: caml_string_of_array\nfunction caml_ml_output_int (chanid,i) {\n var arr = [(i>>24) & 0xFF,(i>>16) & 0xFF,(i>>8) & 0xFF,i & 0xFF ];\n var s = caml_string_of_array(arr);\n caml_ml_output(chanid,s,0,4);\n return 0\n}\n\n//Provides: caml_ml_is_buffered\nfunction caml_ml_is_buffered(c) { return 1 }\n\n//Provides: caml_ml_set_buffered\nfunction caml_ml_set_buffered(c,v) { return 0 }\n","/***********************************************************************/\n/* */\n/* Objective Caml */\n/* */\n/* Xavier Leroy, projet Cristal, INRIA Rocquencourt */\n/* */\n/* Copyright 1996 Institut National de Recherche en Informatique et */\n/* en Automatique. All rights reserved. This file is distributed */\n/* under the terms of the GNU Lesser General Public License, with */\n/* the special exception on linking described in file ../LICENSE. */\n/* */\n/***********************************************************************/\n\n/* $Id: lexing.c 6045 2004-01-01 16:42:43Z doligez $ */\n\n/* The table-driven automaton for lexers generated by camllex. */\n\n//Provides: caml_lex_array\n//Requires: caml_jsbytes_of_string\nfunction caml_lex_array(s) {\n s = caml_jsbytes_of_string(s);\n var l = s.length / 2;\n var a = new Array(l);\n for (var i = 0; i < l; i++)\n a[i] = (s.charCodeAt(2 * i) | (s.charCodeAt(2 * i + 1) << 8)) << 16 >> 16;\n return a;\n}\n\n//Provides: caml_lex_engine\n//Requires: caml_failwith, caml_lex_array, caml_array_of_bytes\nfunction caml_lex_engine(tbl, start_state, lexbuf) {\n var lex_buffer = 2;\n var lex_buffer_len = 3;\n var lex_start_pos = 5;\n var lex_curr_pos = 6;\n var lex_last_pos = 7;\n var lex_last_action = 8;\n var lex_eof_reached = 9;\n var lex_base = 1;\n var lex_backtrk = 2;\n var lex_default = 3;\n var lex_trans = 4;\n var lex_check = 5;\n\n if (!tbl.lex_default) {\n tbl.lex_base = caml_lex_array (tbl[lex_base]);\n tbl.lex_backtrk = caml_lex_array (tbl[lex_backtrk]);\n tbl.lex_check = caml_lex_array (tbl[lex_check]);\n tbl.lex_trans = caml_lex_array (tbl[lex_trans]);\n tbl.lex_default = caml_lex_array (tbl[lex_default]);\n }\n\n var c, state = start_state;\n\n var buffer = caml_array_of_bytes(lexbuf[lex_buffer]);\n\n if (state >= 0) {\n /* First entry */\n lexbuf[lex_last_pos] = lexbuf[lex_start_pos] = lexbuf[lex_curr_pos];\n lexbuf[lex_last_action] = -1;\n } else {\n /* Reentry after refill */\n state = -state - 1;\n }\n for(;;) {\n /* Lookup base address or action number for current state */\n var base = tbl.lex_base[state];\n if (base < 0) return -base-1;\n /* See if it's a backtrack point */\n var backtrk = tbl.lex_backtrk[state];\n if (backtrk >= 0) {\n lexbuf[lex_last_pos] = lexbuf[lex_curr_pos];\n lexbuf[lex_last_action] = backtrk;\n }\n /* See if we need a refill */\n if (lexbuf[lex_curr_pos] >= lexbuf[lex_buffer_len]){\n if (lexbuf[lex_eof_reached] == 0)\n return -state - 1;\n else\n c = 256;\n }else{\n /* Read next input char */\n c = buffer[lexbuf[lex_curr_pos]];\n lexbuf[lex_curr_pos] ++;\n }\n /* Determine next state */\n if (tbl.lex_check[base + c] == state)\n state = tbl.lex_trans[base + c];\n else\n state = tbl.lex_default[state];\n /* If no transition on this char, return to last backtrack point */\n if (state < 0) {\n lexbuf[lex_curr_pos] = lexbuf[lex_last_pos];\n if (lexbuf[lex_last_action] == -1)\n caml_failwith(\"lexing: empty token\");\n else\n return lexbuf[lex_last_action];\n }else{\n /* Erase the EOF condition only if the EOF pseudo-character was\n consumed by the automaton (i.e. there was no backtrack above)\n */\n if (c == 256) lexbuf[lex_eof_reached] = 0;\n }\n }\n}\n\n/***********************************************/\n/* New lexer engine, with memory of positions */\n/***********************************************/\n\n//Provides: caml_new_lex_engine\n//Requires: caml_failwith, caml_lex_array\n//Requires: caml_jsbytes_of_string, caml_array_of_bytes\nfunction caml_lex_run_mem(s, i, mem, curr_pos) {\n for (;;) {\n var dst = s.charCodeAt(i); i++;\n if (dst == 0xff) return;\n var src = s.charCodeAt(i); i++;\n if (src == 0xff)\n mem [dst + 1] = curr_pos;\n else\n mem [dst + 1] = mem [src + 1];\n }\n}\n\nfunction caml_lex_run_tag(s, i, mem) {\n for (;;) {\n var dst = s.charCodeAt(i); i++;\n if (dst == 0xff) return ;\n var src = s.charCodeAt(i); i++;\n if (src == 0xff)\n mem [dst + 1] = -1;\n else\n mem [dst + 1] = mem [src + 1];\n }\n}\n\nfunction caml_new_lex_engine(tbl, start_state, lexbuf) {\n var lex_buffer = 2;\n var lex_buffer_len = 3;\n var lex_start_pos = 5;\n var lex_curr_pos = 6;\n var lex_last_pos = 7;\n var lex_last_action = 8;\n var lex_eof_reached = 9;\n var lex_mem = 10;\n var lex_base = 1;\n var lex_backtrk = 2;\n var lex_default = 3;\n var lex_trans = 4;\n var lex_check = 5;\n var lex_base_code = 6;\n var lex_backtrk_code = 7;\n var lex_default_code = 8;\n var lex_trans_code = 9;\n var lex_check_code = 10;\n var lex_code = 11;\n\n if (!tbl.lex_default) {\n tbl.lex_base = caml_lex_array (tbl[lex_base]);\n tbl.lex_backtrk = caml_lex_array (tbl[lex_backtrk]);\n tbl.lex_check = caml_lex_array (tbl[lex_check]);\n tbl.lex_trans = caml_lex_array (tbl[lex_trans]);\n tbl.lex_default = caml_lex_array (tbl[lex_default]);\n }\n if (!tbl.lex_default_code) {\n tbl.lex_base_code = caml_lex_array (tbl[lex_base_code]);\n tbl.lex_backtrk_code = caml_lex_array (tbl[lex_backtrk_code]);\n tbl.lex_check_code = caml_lex_array (tbl[lex_check_code]);\n tbl.lex_trans_code = caml_lex_array (tbl[lex_trans_code]);\n tbl.lex_default_code = caml_lex_array (tbl[lex_default_code]);\n }\n if (tbl.lex_code == null) tbl.lex_code = caml_jsbytes_of_string(tbl[lex_code]);\n\n var c, state = start_state;\n\n var buffer = caml_array_of_bytes(lexbuf[lex_buffer]);\n\n if (state >= 0) {\n /* First entry */\n lexbuf[lex_last_pos] = lexbuf[lex_start_pos] = lexbuf[lex_curr_pos];\n lexbuf[lex_last_action] = -1;\n } else {\n /* Reentry after refill */\n state = -state - 1;\n }\n for(;;) {\n /* Lookup base address or action number for current state */\n var base = tbl.lex_base[state];\n if (base < 0) {\n var pc_off = tbl.lex_base_code[state];\n caml_lex_run_tag(tbl.lex_code, pc_off, lexbuf[lex_mem]);\n return -base-1;\n }\n /* See if it's a backtrack point */\n var backtrk = tbl.lex_backtrk[state];\n if (backtrk >= 0) {\n var pc_off = tbl.lex_backtrk_code[state];\n caml_lex_run_tag(tbl.lex_code, pc_off, lexbuf[lex_mem]);\n lexbuf[lex_last_pos] = lexbuf[lex_curr_pos];\n lexbuf[lex_last_action] = backtrk;\n }\n /* See if we need a refill */\n if (lexbuf[lex_curr_pos] >= lexbuf[lex_buffer_len]){\n if (lexbuf[lex_eof_reached] == 0)\n return -state - 1;\n else\n c = 256;\n }else{\n /* Read next input char */\n c = buffer[lexbuf[lex_curr_pos]];\n lexbuf[lex_curr_pos] ++;\n }\n /* Determine next state */\n var pstate = state ;\n if (tbl.lex_check[base + c] == state)\n state = tbl.lex_trans[base + c];\n else\n state = tbl.lex_default[state];\n /* If no transition on this char, return to last backtrack point */\n if (state < 0) {\n lexbuf[lex_curr_pos] = lexbuf[lex_last_pos];\n if (lexbuf[lex_last_action] == -1)\n caml_failwith(\"lexing: empty token\");\n else\n return lexbuf[lex_last_action];\n }else{\n /* If some transition, get and perform memory moves */\n var base_code = tbl.lex_base_code[pstate], pc_off;\n if (tbl.lex_check_code[base_code + c] == pstate)\n pc_off = tbl.lex_trans_code[base_code + c];\n else\n pc_off = tbl.lex_default_code[pstate];\n if (pc_off > 0)\n caml_lex_run_mem\n (tbl.lex_code, pc_off, lexbuf[lex_mem], lexbuf[lex_curr_pos]);\n /* Erase the EOF condition only if the EOF pseudo-character was\n consumed by the automaton (i.e. there was no backtrack above)\n */\n if (c == 256) lexbuf[lex_eof_reached] = 0;\n }\n }\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n\n//Provides: caml_md5_chan\n//Requires: caml_md5_string, caml_string_of_array,caml_ml_channels\n//Requires: caml_raise_end_of_file, caml_create_bytes, caml_string_of_bytes\nfunction caml_md5_chan(chanid,len){\n var chan = caml_ml_channels[chanid];\n var chan_len = chan.file.length();\n if(len<0) len = chan_len - chan.offset;\n if(chan.offset + len > chan_len) caml_raise_end_of_file();\n var buf = caml_create_bytes(len);\n chan.file.read(chan.offset,buf,0,len);\n return caml_md5_string(caml_string_of_bytes(buf),0,len);\n}\n\n//Provides: caml_md5_string\n//Requires: caml_bytes_of_string, caml_md5_bytes\nfunction caml_md5_string(s, ofs, len) {\n return caml_md5_bytes(caml_bytes_of_string(s),ofs,len);\n}\n\n//Provides: caml_md5_bytes\n//Requires: caml_string_of_array, caml_ml_bytes_content\nvar caml_md5_bytes = function () {\n function add (x, y) { return (x + y) | 0; }\n function xx(q,a,b,x,s,t) {\n a = add(add(a, q), add(x, t));\n return add((a << s) | (a >>> (32 - s)), b);\n }\n function ff(a,b,c,d,x,s,t) {\n return xx((b & c) | ((~b) & d), a, b, x, s, t);\n }\n function gg(a,b,c,d,x,s,t) {\n return xx((b & d) | (c & (~d)), a, b, x, s, t);\n }\n function hh(a,b,c,d,x,s,t) { return xx(b ^ c ^ d, a, b, x, s, t); }\n function ii(a,b,c,d,x,s,t) { return xx(c ^ (b | (~d)), a, b, x, s, t); }\n\n function md5(buffer, length) {\n var i = length;\n buffer[i >> 2] |= 0x80 << (8 * (i & 3));\n for (i = (i & ~0x3) + 8;(i & 0x3F) < 60 ;i += 4)\n buffer[(i >> 2) - 1] = 0;\n buffer[(i >> 2) -1] = length << 3;\n buffer[i >> 2] = (length >> 29) & 0x1FFFFFFF;\n\n var w = [0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476];\n\n for(i = 0; i < buffer.length; i += 16) {\n var a = w[0], b = w[1], c = w[2], d = w[3];\n\n a = ff(a, b, c, d, buffer[i+ 0], 7, 0xD76AA478);\n d = ff(d, a, b, c, buffer[i+ 1], 12, 0xE8C7B756);\n c = ff(c, d, a, b, buffer[i+ 2], 17, 0x242070DB);\n b = ff(b, c, d, a, buffer[i+ 3], 22, 0xC1BDCEEE);\n a = ff(a, b, c, d, buffer[i+ 4], 7, 0xF57C0FAF);\n d = ff(d, a, b, c, buffer[i+ 5], 12, 0x4787C62A);\n c = ff(c, d, a, b, buffer[i+ 6], 17, 0xA8304613);\n b = ff(b, c, d, a, buffer[i+ 7], 22, 0xFD469501);\n a = ff(a, b, c, d, buffer[i+ 8], 7, 0x698098D8);\n d = ff(d, a, b, c, buffer[i+ 9], 12, 0x8B44F7AF);\n c = ff(c, d, a, b, buffer[i+10], 17, 0xFFFF5BB1);\n b = ff(b, c, d, a, buffer[i+11], 22, 0x895CD7BE);\n a = ff(a, b, c, d, buffer[i+12], 7, 0x6B901122);\n d = ff(d, a, b, c, buffer[i+13], 12, 0xFD987193);\n c = ff(c, d, a, b, buffer[i+14], 17, 0xA679438E);\n b = ff(b, c, d, a, buffer[i+15], 22, 0x49B40821);\n\n a = gg(a, b, c, d, buffer[i+ 1], 5, 0xF61E2562);\n d = gg(d, a, b, c, buffer[i+ 6], 9, 0xC040B340);\n c = gg(c, d, a, b, buffer[i+11], 14, 0x265E5A51);\n b = gg(b, c, d, a, buffer[i+ 0], 20, 0xE9B6C7AA);\n a = gg(a, b, c, d, buffer[i+ 5], 5, 0xD62F105D);\n d = gg(d, a, b, c, buffer[i+10], 9, 0x02441453);\n c = gg(c, d, a, b, buffer[i+15], 14, 0xD8A1E681);\n b = gg(b, c, d, a, buffer[i+ 4], 20, 0xE7D3FBC8);\n a = gg(a, b, c, d, buffer[i+ 9], 5, 0x21E1CDE6);\n d = gg(d, a, b, c, buffer[i+14], 9, 0xC33707D6);\n c = gg(c, d, a, b, buffer[i+ 3], 14, 0xF4D50D87);\n b = gg(b, c, d, a, buffer[i+ 8], 20, 0x455A14ED);\n a = gg(a, b, c, d, buffer[i+13], 5, 0xA9E3E905);\n d = gg(d, a, b, c, buffer[i+ 2], 9, 0xFCEFA3F8);\n c = gg(c, d, a, b, buffer[i+ 7], 14, 0x676F02D9);\n b = gg(b, c, d, a, buffer[i+12], 20, 0x8D2A4C8A);\n\n a = hh(a, b, c, d, buffer[i+ 5], 4, 0xFFFA3942);\n d = hh(d, a, b, c, buffer[i+ 8], 11, 0x8771F681);\n c = hh(c, d, a, b, buffer[i+11], 16, 0x6D9D6122);\n b = hh(b, c, d, a, buffer[i+14], 23, 0xFDE5380C);\n a = hh(a, b, c, d, buffer[i+ 1], 4, 0xA4BEEA44);\n d = hh(d, a, b, c, buffer[i+ 4], 11, 0x4BDECFA9);\n c = hh(c, d, a, b, buffer[i+ 7], 16, 0xF6BB4B60);\n b = hh(b, c, d, a, buffer[i+10], 23, 0xBEBFBC70);\n a = hh(a, b, c, d, buffer[i+13], 4, 0x289B7EC6);\n d = hh(d, a, b, c, buffer[i+ 0], 11, 0xEAA127FA);\n c = hh(c, d, a, b, buffer[i+ 3], 16, 0xD4EF3085);\n b = hh(b, c, d, a, buffer[i+ 6], 23, 0x04881D05);\n a = hh(a, b, c, d, buffer[i+ 9], 4, 0xD9D4D039);\n d = hh(d, a, b, c, buffer[i+12], 11, 0xE6DB99E5);\n c = hh(c, d, a, b, buffer[i+15], 16, 0x1FA27CF8);\n b = hh(b, c, d, a, buffer[i+ 2], 23, 0xC4AC5665);\n\n a = ii(a, b, c, d, buffer[i+ 0], 6, 0xF4292244);\n d = ii(d, a, b, c, buffer[i+ 7], 10, 0x432AFF97);\n c = ii(c, d, a, b, buffer[i+14], 15, 0xAB9423A7);\n b = ii(b, c, d, a, buffer[i+ 5], 21, 0xFC93A039);\n a = ii(a, b, c, d, buffer[i+12], 6, 0x655B59C3);\n d = ii(d, a, b, c, buffer[i+ 3], 10, 0x8F0CCC92);\n c = ii(c, d, a, b, buffer[i+10], 15, 0xFFEFF47D);\n b = ii(b, c, d, a, buffer[i+ 1], 21, 0x85845DD1);\n a = ii(a, b, c, d, buffer[i+ 8], 6, 0x6FA87E4F);\n d = ii(d, a, b, c, buffer[i+15], 10, 0xFE2CE6E0);\n c = ii(c, d, a, b, buffer[i+ 6], 15, 0xA3014314);\n b = ii(b, c, d, a, buffer[i+13], 21, 0x4E0811A1);\n a = ii(a, b, c, d, buffer[i+ 4], 6, 0xF7537E82);\n d = ii(d, a, b, c, buffer[i+11], 10, 0xBD3AF235);\n c = ii(c, d, a, b, buffer[i+ 2], 15, 0x2AD7D2BB);\n b = ii(b, c, d, a, buffer[i+ 9], 21, 0xEB86D391);\n\n w[0] = add(a, w[0]);\n w[1] = add(b, w[1]);\n w[2] = add(c, w[2]);\n w[3] = add(d, w[3]);\n }\n\n var t = new Array(16);\n for (var i = 0; i < 4; i++)\n for (var j = 0; j < 4; j++)\n t[i * 4 + j] = (w[i] >> (8 * j)) & 0xFF;\n return t;\n }\n\n return function (s, ofs, len) {\n // FIX: maybe we should perform the computation by chunk of 64 bytes\n // as in http://www.myersdaily.org/joseph/javascript/md5.js\n var buf = [];\n var content = caml_ml_bytes_content(s);\n if(typeof content === \"string\"){\n var b = content;\n for (var i = 0; i < len; i+=4) {\n var j = i + ofs;\n buf[i>>2] =\n b.charCodeAt(j) | (b.charCodeAt(j+1) << 8) |\n (b.charCodeAt(j+2) << 16) | (b.charCodeAt(j+3) << 24);\n }\n for (; i < len; i++) buf[i>>2] |= b.charCodeAt(i + ofs) << (8 * (i & 3));\n } else { /* ARRAY */\n var a = content;\n for (var i = 0; i < len; i+=4) {\n var j = i + ofs;\n buf[i>>2] = a[j] | (a[j+1] << 8) | (a[j+2] << 16) | (a[j+3] << 24);\n }\n for (; i < len; i++) buf[i>>2] |= a[i + ofs] << (8 * (i & 3));\n }\n return caml_string_of_array(md5(buf, len));\n }\n} ();\n","//Provides: expect_test_collector_saved_stdout\nvar expect_test_collector_saved_stdout \n//Provides: expect_test_collector_saved_stderr\nvar expect_test_collector_saved_stderr\n\n//Provides: expect_test_collector_before_test\n//Requires: caml_global_data, caml_ml_channels\n//Requires: expect_test_collector_saved_stderr, expect_test_collector_saved_stdout\nfunction expect_test_collector_before_test (voutput, vstdout, vstderr){\n expect_test_collector_saved_stderr = caml_ml_channels[vstderr];\n expect_test_collector_saved_stdout = caml_ml_channels[vstdout];\n var output = caml_ml_channels[voutput];\n caml_ml_channels[vstdout] = output;\n caml_ml_channels[vstderr] = output;\n return 0;\n}\n\n//Provides: expect_test_collector_after_test\n//Requires: caml_global_data, caml_ml_channels\n//Requires: expect_test_collector_saved_stderr, expect_test_collector_saved_stdout\nfunction expect_test_collector_after_test (vstdout, vstderr){\n caml_ml_channels[vstdout] = expect_test_collector_saved_stdout;\n caml_ml_channels[vstderr] = expect_test_collector_saved_stderr;\n return 0;\n}\n\n//Provides:caml_out_channel_pos_fd\n//Requires: caml_global_data, caml_ml_channels\nfunction caml_out_channel_pos_fd(chan){\n var info = caml_ml_channels[chan];\n return info.offset\n}\n","///////// CORE_KERNEL\n\n//Provides: core_array_unsafe_int_blit\n//Requires: caml_array_blit\nvar core_array_unsafe_int_blit = caml_array_blit\n//Provides: core_array_unsafe_float_blit\n//Requires: caml_array_blit\nvar core_array_unsafe_float_blit = caml_array_blit\n\n//Provides: core_kernel_time_ns_format\n//Requires: caml_jsbytes_of_string, caml_string_of_jsbytes\nfunction core_kernel_time_ns_format(time,format){\n var d = new Date(time * 1000);\n var formatjs = caml_jsbytes_of_string(format);\n var jstring = joo_global_object.strftime(formatjs, d);\n return caml_string_of_jsbytes(jstring);\n}\n\n//Provides: core_kernel_gc_compactions\nfunction core_kernel_gc_compactions () { return 0 }\n//Provides: core_kernel_gc_heap_chunks\nfunction core_kernel_gc_heap_chunks () { return 0 }\n//Provides: core_kernel_gc_heap_words\nfunction core_kernel_gc_heap_words () { return 0 }\n//Provides: core_kernel_gc_major_collections\nfunction core_kernel_gc_major_collections () { return 0 }\n//Provides: core_kernel_gc_major_plus_minor_words\nfunction core_kernel_gc_major_plus_minor_words () { return 0 }\n//Provides: core_kernel_gc_major_words\nfunction core_kernel_gc_major_words () { return 0 }\n//Provides: core_kernel_gc_minor_collections\nfunction core_kernel_gc_minor_collections () { return 0 }\n//Provides: core_kernel_gc_minor_words\nfunction core_kernel_gc_minor_words () { return 0 }\n//Provides: core_kernel_gc_promoted_words\nfunction core_kernel_gc_promoted_words () { return 0 }\n//Provides: core_kernel_gc_top_heap_words\nfunction core_kernel_gc_top_heap_words () { return 0 }\n\n//Provides: Core_kernel_heap_block_is_heap_block\nfunction Core_kernel_heap_block_is_heap_block(x){\n return +(x instanceof Array);\n}\n\n//Provides: core_md5_fd\n//Requires: caml_ml_open_descriptor_in, caml_md5_chan, caml_ml_close_channel\nfunction core_md5_fd(fd){\n var ic = caml_ml_open_descriptor_in(fd);\n try {\n return caml_md5_chan(ic, -1);\n } finally {\n caml_ml_close_channel(ic);\n }\n}\n\n//Provides: core_md5_digest_subbigstring\n//Requires: caml_md5_string, caml_blit_string, caml_create_bytes\n//Requires: bigstring_blit_bigstring_bytes_stub, caml_string_of_bytes\nfunction core_md5_digest_subbigstring(buf, ofs, len, res){\n var bytes = caml_create_bytes(len);\n bigstring_blit_bigstring_bytes_stub(buf, ofs, bytes, 0, len);\n var res2 = caml_md5_string(caml_string_of_bytes(bytes), 0, len);\n caml_blit_string(res2, 0, res, 0, 16);\n return 0;\n}\n\n//Bigstring\n\n//Provides: bigstring_destroy_stub\n//Requires: caml_invalid_argument\nfunction bigstring_destroy_stub(v_bstr) {\n if (v_bstr.hasOwnProperty('__is_deallocated')) {\n caml_invalid_argument(\"bigstring_destroy: bigstring is already deallocated\");\n }\n // Mutate the original bigstring in-place, to simulate what the C version does\n v_bstr.__is_deallocated = true;\n v_bstr.data = new v_bstr.data.__proto__.constructor(0);\n v_bstr.dims = [ 0 ];\n return 0;\n}\n\n//Provides: bigstring_realloc\n//Requires: caml_invalid_argument, caml_ba_create_unsafe, bigstring_destroy_stub\nfunction bigstring_realloc(bigstring, size) {\n if (bigstring.hasOwnProperty('__is_deallocated')) {\n caml_invalid_argument(\"bigstring_realloc: bigstring is already deallocated\");\n }\n\n var new_data = new bigstring.data.__proto__.constructor(size);\n new_data.set(bigstring.data.slice(0, size));\n var new_bigstring = caml_ba_create_unsafe(bigstring.kind, bigstring.layout, [size], new_data);\n bigstring_destroy_stub(bigstring);\n\n return new_bigstring;\n}\n","// Provides: deferred_run\nfunction deferred_run(func) {\n var deferred = {\n promise: Promise.resolve()\n .then(func) // the ocaml types don't know this, but func can actually be async or sync\n .then(function (value) {\n deferred.value = value;\n deferred.isDetermined = true;\n return value;\n })\n .catch(function (err) {\n deferred.error = err;\n deferred.isError = true;\n deferred.isDetermined = true;\n throw err;\n }),\n isError: false,\n isDetermined: false,\n };\n return deferred;\n}\n\n// Provides: deferred_map\nfunction deferred_map(deferred, func) {\n var newDeferred = {\n promise: deferred.promise\n .then(func) // the ocaml types don't know this, but func can actually be async or sync\n .then(function (value) {\n newDeferred.value = value;\n newDeferred.isDetermined = true;\n return value;\n })\n .catch(function (err) {\n newDeferred.error = err;\n newDeferred.isError = true;\n newDeferred.isDetermined = true;\n throw err;\n }),\n isError: false,\n isDetermined: false,\n };\n return newDeferred;\n}\n\n// Provides: deferred_bind\nfunction deferred_bind(deferred, func) {\n var newDeferred = {\n promise: deferred.promise\n .then(func)\n .then(function (anotherDeferred) {\n return anotherDeferred.promise;\n })\n .then(function (value) {\n newDeferred.value = value;\n newDeferred.isDetermined = true;\n return value;\n })\n .catch(function (err) {\n newDeferred.error = err;\n newDeferred.isError = true;\n newDeferred.isDetermined = true;\n throw err;\n }),\n isError: false,\n isDetermined: false,\n };\n return newDeferred;\n}\n\n// Provides: deferred_upon\nfunction deferred_upon(deferred, func) {\n deferred.promise\n .then(function () {\n func(deferred.value);\n })\n .catch(function () {});\n}\n\n// Provides: deferred_upon_exn\nfunction deferred_upon_exn(deferred, func) {\n deferred.promise.then(function () {\n func(deferred.value);\n });\n}\n\n// Provides: deferred_is_determined\nfunction deferred_is_determined(deferred) {\n return deferred.isDetermined;\n}\n\n// Provides: deferred_peek\nfunction deferred_peek(deferred) {\n if (!deferred.isDetermined || deferred.isError) {\n return 0;\n }\n return [0, deferred.value];\n}\n\n// Provides: deferred_value_exn\nfunction deferred_value_exn(deferred) {\n if (!deferred.isDetermined) {\n throw Error(\"Deferred has not returned yet.\");\n }\n if (deferred.isError) {\n throw deferred.error;\n }\n return deferred.value;\n}\n\n// Provides: deferred_return\nfunction deferred_return(value) {\n return {\n promise: Promise.resolve(value),\n value: value,\n isError: false,\n isDetermined: true,\n };\n}\n\n// Provides: deferred_create\nfunction deferred_create(promise_creator) {\n var deferred = {\n promise: new Promise(function (resolve) {\n promise_creator(resolve);\n })\n .then(function (value) {\n deferred.value = value;\n deferred.isDetermined = true;\n })\n .catch(function (err) {\n deferred.error = err;\n deferred.isError = true;\n deferred.isDetermined = true;\n throw err;\n }),\n isError: false,\n isDetermined: false,\n };\n return deferred;\n}\n\n// Provides: deferred_to_promise\nfunction deferred_to_promise(deferred) {\n return deferred.promise;\n}\n\n// Provides: deferred_of_promise\nfunction deferred_of_promise(promise) {\n var deferred = {\n promise: promise\n .then(function (value) {\n deferred.value = value;\n deferred.isDetermined = true;\n return value;\n })\n .catch(function (err) {\n deferred.error = err;\n deferred.isError = true;\n deferred.isDetermined = true;\n throw err;\n }),\n isError: false,\n isDetermined: false,\n };\n return deferred;\n}\n","// This code supports both Array and MlInt64 implementations of int64 in\n// js_of_ocaml (pre- vs post-887507db1eb8efd779070cbedab3774098a52939).\n//\n// Compilation is currently broken on the MlInt64 implementation, due to\n// removed internal js_of_ocaml primitives. Removing these (and the Array\n// implementations, signalled by [instanceof Array] checks) will cause\n// compilation to succeed.\n//\n// TODO: build-time magic to stub the unavailable primitives on later versions.\n\n//Provides: UInt32 const\nvar UInt32 = (function() {\n var UInt32 = function(x) {\n this.value = x >>> 0;\n };\n UInt32.prototype.caml_custom = \"integers:uint32\";\n return UInt32;\n})();\n\n//Provides: integers_int32_of_uint32\nfunction integers_int32_of_uint32(i) {\n return (i.value | 0);\n}\n\n//Provides: integers_size_t_size\nfunction integers_size_t_size(unit) {\n return 4; // Set size_t = u32\n}\n\n//Provides: integers_uint16_of_string\n//Requires: integers_uint32_of_string\nfunction integers_uint16_of_string(x) {\n var y = integers_uint32_of_string(x);\n return (y.value & 0xFFFF);\n}\n\n//Provides: integers_uint32_add\n//Requires: UInt32\nfunction integers_uint32_add(x, y) {\n return new UInt32(x.value + y.value);\n}\n\n//Provides: integers_uint32_sub\n//Requires: UInt32\nfunction integers_uint32_sub(x, y) {\n return new UInt32(x.value - y.value);\n}\n\n//Provides: integers_uint32_div\n//Requires: UInt32\nfunction integers_uint32_div(x, y) {\n return new UInt32(x.value / y.value);\n}\n\n//Provides: integers_uint32_logand\n//Requires: UInt32\nfunction integers_uint32_logand(x, y) {\n return new UInt32(x.value & y.value);\n}\n\n//Provides: integers_uint32_logor\n//Requires: UInt32\nfunction integers_uint32_logor(x, y) {\n return new UInt32(x.value | y.value);\n}\n\n//Provides: integers_uint32_logxor\n//Requires: UInt32\nfunction integers_uint32_logxor(x, y) {\n return new UInt32(x.value ^ y.value);\n}\n\n//Provides: integers_uint32_max\n//Requires: UInt32\nfunction integers_uint32_max(unit) {\n return new UInt32(0xFFFFFFFF);\n}\n\n//Provides: integers_uint32_mul\n//Requires: integers_uint32_to_int64, caml_int64_mul, caml_int64_to_int32, UInt32\nfunction integers_uint32_mul(x, y) {\n // Convert to 64-bit and compute there.\n var x_64 = integers_uint32_to_int64(x);\n var y_64 = integers_uint32_to_int64(y);\n return new UInt32 (caml_int64_to_int32(caml_int64_mul(x_64, y_64)));\n}\n\n//Provides: integers_uint32_of_int\n//Requires: UInt32\nfunction integers_uint32_of_int(i) {\n return new UInt32(i);\n}\n\n//Provides: integers_uint32_of_int32\n//Requires: UInt32\nfunction integers_uint32_of_int32(i) {\n return new UInt32(i);\n}\n\n//Provides: integers_uint32_of_int64\n//Requires: caml_int64_to_int32, UInt32\nfunction integers_uint32_of_int64(i) {\n return new UInt32(caml_int64_to_int32(i));\n}\n\n//Provides: integers_uint32_of_string\n//Requires: integers_uint_of_string, integers_uint32_of_int64, caml_int64_create_lo_mi_hi\nfunction integers_uint32_of_string(s) {\n // To match the C implementation, we should parse the string as an uint64\n // and then downcast.\n var max_val = caml_int64_create_lo_mi_hi(0xffffff, 0xffffff, 0xffff);\n return integers_uint32_of_int64(integers_uint_of_string(s, max_val));\n}\n\n//Provides: integers_uint32_rem\n//Requires: caml_raise_zero_divide, UInt32\nfunction integers_uint32_rem(x, y) {\n if (y.value == 0) {\n caml_raise_zero_divide();\n }\n return new UInt32(x.value % y.value);\n}\n\n//Provides: integers_uint32_shift_left\n//Requires: UInt32\nfunction integers_uint32_shift_left(x, y) {\n return new UInt32(x.value << y);\n}\n\n//Provides: integers_uint32_shift_right\n//Requires: UInt32\nfunction integers_uint32_shift_right(x, y) {\n return new UInt32(x.value >>> y);\n}\n\n//Provides: integers_uint32_to_int\nfunction integers_uint32_to_int(i) {\n return (i.value | 0);\n}\n\n//Provides: integers_uint32_to_int64\n//Requires: caml_int64_create_lo_mi_hi\nfunction integers_uint32_to_int64(i) {\n return caml_int64_create_lo_mi_hi(i.value & 0xffffff, (i.value >>> 24) & 0xffffff, 0);\n}\n\n//Provides: integers_uint32_to_string\n//Requires: caml_new_string\nfunction integers_uint32_to_string(i) {\n return caml_new_string(i.value.toString());\n}\n\n//Provides: UInt64 const\nvar UInt64 = (function () {\n var UInt64 = function (x) {\n this.value = x; // x is an MlInt64\n };\n UInt64.prototype.caml_custom = \"integers:uint64\";\n return UInt64;\n})();\n\n//Provides: integers_uint64_add\n//Requires: caml_int64_add, UInt64\nfunction integers_uint64_add(x, y) {\n return new UInt64(caml_int64_add(x.value, y.value));\n}\n\n//Provides: integers_uint64_div\n//Requires: caml_raise_zero_divide, UInt64\nfunction integers_uint64_div(x, y) {\n if (y.value.isZero()) {\n caml_raise_zero_divide();\n }\n // Coerce the high parts to be unsigned before division.\n x.value.hi = x.value.hi >>> 0;\n y.value.hi = y.value.hi >>> 0;\n return new UInt64(x.value.udivmod(y.value).quotient);\n}\n\n//Provides: integers_uint64_logand\n//Requires: caml_int64_and, UInt64\nfunction integers_uint64_logand(x, y) {\n return new UInt64(caml_int64_and(x.value, y.value));\n}\n\n//Provides: integers_uint64_logor\n//Requires: caml_int64_or, UInt64\nfunction integers_uint64_logor(x, y) {\n return new UInt64(caml_int64_or(x.value, y.value));\n}\n\n//Provides: integers_uint64_logxor\n//Requires: caml_int64_xor, UInt64\nfunction integers_uint64_logxor(x, y) {\n return new UInt64(caml_int64_xor(x.value, y.value));\n}\n\n//Provides: integers_uint64_max\n//Requires: caml_int64_create_lo_mi_hi, UInt64\nfunction integers_uint64_max(unit) {\n var x = caml_int64_create_lo_mi_hi(0xffffff, 0xffffff, 0xffff);\n x.hi = x.hi >>> 0;\n return new UInt64(x);\n}\n\n//Provides: integers_uint64_mul\n//Requires: caml_int64_mul, UInt64\nfunction integers_uint64_mul(x, y) {\n return new UInt64(caml_int64_mul(x.value, y.value));\n}\n\n//Provides: integers_uint64_of_int\n//Requires: caml_int64_of_int32, UInt64\nfunction integers_uint64_of_int(i) {\n return new UInt64(caml_int64_of_int32(i));\n}\n\n//Provides: integers_uint64_of_int64\n//Requires: caml_int64_create_lo_mi_hi, UInt64\nfunction integers_uint64_of_int64(i) {\n return new UInt64(caml_int64_create_lo_mi_hi(i.lo, i.mi, i.hi >>> 0));\n}\n\n//Provides: integers_uint_of_string\n//Requires: caml_ml_string_length, caml_failwith, caml_string_unsafe_get, caml_int64_create_lo_mi_hi, caml_int64_of_int32, caml_parse_digit, caml_int64_ult, caml_int64_add, caml_int64_mul, caml_int64_neg\nfunction integers_uint_of_string(s, max_val) {\n // Note: This code matches the behavior of the C function.\n // In particular,\n // - only base-10 numbers are accepted\n // - negative numbers are accepted and coerced to 2's-complement uint64\n // - the longest numeric prefix is accepted, only raising an error when there\n // isn't a numeric prefix\n var i = 0, len = caml_ml_string_length(s), negative = false;\n if (i >= len) {\n caml_failwith(\"int_of_string\");\n }\n var c = caml_string_unsafe_get(s, i);\n if (c === 45) { // Minus sign\n i++;\n negative = true;\n } else if (c === 43) { // Plus sign\n i++;\n }\n var no_digits = true;\n // Ensure that the high byte is unsigned before division.\n max_val.hi = max_val.hi >>> 0;\n var ten = caml_int64_of_int32(10);\n var max_base_10 = max_val.udivmod(ten).quotient;\n var res = caml_int64_of_int32(0);\n for (; i < len; i++) {\n var c = caml_string_unsafe_get(s, i);\n var d = caml_parse_digit(c);\n if (d < 0 || d >= 10) {\n break;\n }\n no_digits = false;\n // Any digit here would overflow. Pin to the maximum value.\n if (caml_int64_ult(max_base_10, res)) {\n return max_val;\n }\n d = caml_int64_of_int32(d);\n res = caml_int64_add(caml_int64_mul(ten, res), d);\n // The given digit was too large. Pin to the maximum value.\n if (caml_int64_ult(res, d)) {\n return max_val;\n }\n }\n if (no_digits) {\n caml_failwith(\"int_of_string\");\n }\n if (negative) {\n res = caml_int64_neg(res);\n }\n // Set the high byte as unsigned.\n res.hi = res.hi >>> 0;\n return res;\n}\n\n//Provides: integers_uint64_of_string\n//Requires: integers_uint_of_string, caml_int64_create_lo_mi_hi, UInt64\nfunction integers_uint64_of_string(s) {\n var max_val = caml_int64_create_lo_mi_hi(0xffffff, 0xffffff, 0xffff);\n return new UInt64(integers_uint_of_string(s, max_val));\n}\n\n//Provides: integers_uint64_rem\n//Requires: caml_raise_zero_divide, caml_int64_is_zero, UInt64\nfunction integers_uint64_rem(x, y) {\n if (y.value.isZero()) {\n caml_raise_zero_divide();\n }\n // Coerce the high parts to be unsigned before division.\n x.value.hi = x.value.hi >>> 0;\n y.value.hi = y.value.hi >>> 0;\n return new UInt64(x.value.udivmod(y.value).modulus);\n}\n\n//Provides: integers_uint64_shift_left\n//Requires: caml_int64_shift_left, UInt64\nfunction integers_uint64_shift_left(x, y) {\n return new UInt64(caml_int64_shift_left(x.value, y));\n}\n\n//Provides: integers_uint64_shift_right\n//Requires: caml_int64_shift_right_unsigned, UInt64\nfunction integers_uint64_shift_right(x, y) {\n return new UInt64(caml_int64_shift_right_unsigned(x.value, y));\n}\n\n//Provides: integers_uint64_sub\n//Requires: caml_int64_sub, UInt64\nfunction integers_uint64_sub(x, y) {\n return new UInt64(caml_int64_sub(x.value, y.value));\n}\n\n//Provides: integers_uint64_to_int\n//Requires: caml_int64_to_int32\nfunction integers_uint64_to_int(i) {\n return caml_int64_to_int32(i.value);\n}\n\n//Provides: integers_uint64_to_int64\n//Requires: caml_int64_create_lo_mi_hi\nfunction integers_uint64_to_int64(i) {\n i = i.value;\n return caml_int64_create_lo_mi_hi(i.lo, i.mi, i.hi | 0);\n}\n\n//Provides: integers_uint64_to_string\n//Requires: caml_int64_format, caml_new_string\nfunction integers_uint64_to_string(i) {\n return caml_int64_format(caml_new_string(\"%u\"), i.value);\n}\n\n//Provides: integers_uint64_unmarshal\n//Requires: caml_int64_unmarshal, UInt64\nfunction integers_uint64_unmarshal(reader, size){\n return new UInt64(caml_int64_unmarshal(reader, size));\n}\n \n//Provides: integers_uint64_marshal\n//Requires: caml_int64_marshal\nfunction integers_uint64_marshal(writer, v, sizes) {\n caml_int64_marshal(writer, v.value, sizes);\n}\n\n//Provides: integers_uint64_hash\n//Requires: caml_int64_hash\nfunction integers_uint64_hash(v) {\n return caml_int64_hash(v.value);\n}\n\n//Provides: integers_uint8_of_string\n//Requires: integers_uint32_of_string\nfunction integers_uint8_of_string(x) {\n var y = integers_uint32_of_string(x);\n return (x.value & 0xFF);\n}\n\n//Provides: integers_uint_size\nfunction integers_uint_size(unit) {\n return 4;\n}\n\n//Provides: integers_ulong_size\nfunction integers_ulong_size(unit) {\n return 4;\n}\n\n//Provides: integers_ulonglong_size\nfunction integers_ulonglong_size(unit) {\n return 8;\n}\n\n//Provides: integers_unsigned_init\n//Requires: caml_custom_ops, integers_uint8_deserialize, integers_uint16_deserialize, integers_uint32_serialize, integers_uint32_deserialize, integers_uint32_hash, integers_uint32_compare, integers_uint64_compare, integers_uint64_hash, integers_uint64_marshal, integers_uint64_unmarshal\nfunction integers_unsigned_init(unit) {\n caml_custom_ops[\"integers:uint8\"] =\n { deserialize: integers_uint8_deserialize\n , fixed_length: 1 };\n caml_custom_ops[\"integers:uint16\"] =\n { deserialize: integers_uint16_deserialize\n , fixed_length: 2 };\n caml_custom_ops[\"integers:uint32\"] =\n { serialize: integers_uint32_serialize\n , deserialize: integers_uint32_deserialize\n , fixed_length: 4\n , hash: integers_uint32_hash\n , compare: integers_uint32_compare };\n caml_custom_ops[\"integers:uint64\"] =\n { serialize: integers_uint64_marshal\n , deserialize: integers_uint64_unmarshal\n , hash: integers_uint64_hash\n , compare: integers_uint64_compare };\n return unit;\n}\n\n//Provides: integers_ushort_size\nfunction integers_ushort_size(unit) {\n return 4;\n}\n\n//Provides: integers_uint32_serialize\nfunction integers_uint32_serialize(writer, v, size) {\n writer.write(32, v.value);\n size[0] = 4;\n size[1] = 4;\n}\n\n//Provides: integers_uint8_deserialize\nfunction integers_uint8_deserialize(reader, size) {\n size[0] = 1;\n return reader.read8u();\n}\n\n//Provides: integers_uint16_deserialize\nfunction integers_uint16_deserialize(reader, size) {\n size[0] = 2;\n return reader.read16u();\n}\n\n//Provides: integers_uint32_deserialize\n//Requires: UInt32\nfunction integers_uint32_deserialize(reader, size) {\n size[0] = 4;\n return new UInt32(reader.read32u());\n}\n\n//Provides: integers_uint32_hash\nfunction integers_uint32_hash(v) {\n return v.value;\n}\n\n//Provides: integers_uint32_compare\nfunction integers_uint32_compare(x, y) {\n if (x.value > y.value) { return 1; }\n if (x.value < y.value) { return -1; }\n return 0;\n}\n\n//Provides: integers_uint64_compare\n//Requires: caml_int64_compare\nfunction integers_uint64_compare(x, y) {\n x.value.hi = x.value.hi >>> 0;\n y.value.hi = y.value.hi >>> 0;\n return x.value.ucompare(y.value);\n}\n","//Imported from https://github.com/peterolson/BigInteger.js#4e99b15b7951338f164728377c906caae5a78202\n\n//Provides: bigInt const\nvar bigInt = (function (undefined) {\n \"use strict\";\n\n var BASE = 1e7,\n LOG_BASE = 7,\n MAX_INT = 9007199254740992,\n MAX_INT_ARR = smallToArray(MAX_INT),\n DEFAULT_ALPHABET = \"0123456789abcdefghijklmnopqrstuvwxyz\";\n\n var BigInt = joo_global_object.BigInt;\n\n var supportsNativeBigInt = typeof BigInt === \"function\";\n\n function Integer(v, radix, alphabet, caseSensitive) {\n if (typeof v === \"undefined\") return Integer[0];\n if (typeof radix !== \"undefined\") return +radix === 10 && !alphabet ? parseValue(v) : parseBase(v, radix, alphabet, caseSensitive);\n return parseValue(v);\n }\n\n function BigInteger(value, sign) {\n this.value = value;\n this.sign = sign;\n this.isSmall = false;\n this.caml_custom = '_z';\n }\n BigInteger.prototype = Object.create(Integer.prototype);\n\n function SmallInteger(value) {\n this.value = value;\n this.sign = value < 0;\n this.isSmall = true;\n this.caml_custom = '_z';\n }\n SmallInteger.prototype = Object.create(Integer.prototype);\n\n function NativeBigInt(value) {\n this.value = value;\n this.caml_custom = '_z';\n }\n NativeBigInt.prototype = Object.create(Integer.prototype);\n\n function isPrecise(n) {\n return -MAX_INT < n && n < MAX_INT;\n }\n\n function smallToArray(n) { // For performance reasons doesn't reference BASE, need to change this function if BASE changes\n if (n < 1e7)\n return [n];\n if (n < 1e14)\n return [n % 1e7, Math.floor(n / 1e7)];\n return [n % 1e7, Math.floor(n / 1e7) % 1e7, Math.floor(n / 1e14)];\n }\n\n function arrayToSmall(arr) { // If BASE changes this function may need to change\n trim(arr);\n var length = arr.length;\n if (length < 4 && compareAbs(arr, MAX_INT_ARR) < 0) {\n switch (length) {\n case 0: return 0;\n case 1: return arr[0];\n case 2: return arr[0] + arr[1] * BASE;\n default: return arr[0] + (arr[1] + arr[2] * BASE) * BASE;\n }\n }\n return arr;\n }\n\n function trim(v) {\n var i = v.length;\n while (v[--i] === 0);\n v.length = i + 1;\n }\n\n function createArray(length) { // function shamelessly stolen from Yaffle's library https://github.com/Yaffle/BigInteger\n var x = new Array(length);\n var i = -1;\n while (++i < length) {\n x[i] = 0;\n }\n return x;\n }\n\n function truncate(n) {\n if (n > 0) return Math.floor(n);\n return Math.ceil(n);\n }\n\n function add(a, b) { // assumes a and b are arrays with a.length >= b.length\n var l_a = a.length,\n l_b = b.length,\n r = new Array(l_a),\n carry = 0,\n base = BASE,\n sum, i;\n for (i = 0; i < l_b; i++) {\n sum = a[i] + b[i] + carry;\n carry = sum >= base ? 1 : 0;\n r[i] = sum - carry * base;\n }\n while (i < l_a) {\n sum = a[i] + carry;\n carry = sum === base ? 1 : 0;\n r[i++] = sum - carry * base;\n }\n if (carry > 0) r.push(carry);\n return r;\n }\n\n function addAny(a, b) {\n if (a.length >= b.length) return add(a, b);\n return add(b, a);\n }\n\n function addSmall(a, carry) { // assumes a is array, carry is number with 0 <= carry < MAX_INT\n var l = a.length,\n r = new Array(l),\n base = BASE,\n sum, i;\n for (i = 0; i < l; i++) {\n sum = a[i] - base + carry;\n carry = Math.floor(sum / base);\n r[i] = sum - carry * base;\n carry += 1;\n }\n while (carry > 0) {\n r[i++] = carry % base;\n carry = Math.floor(carry / base);\n }\n return r;\n }\n\n BigInteger.prototype.add = function (v) {\n var n = parseValue(v);\n if (this.sign !== n.sign) {\n return this.subtract(n.negate());\n }\n var a = this.value, b = n.value;\n if (n.isSmall) {\n return new BigInteger(addSmall(a, Math.abs(b)), this.sign);\n }\n return new BigInteger(addAny(a, b), this.sign);\n };\n BigInteger.prototype.plus = BigInteger.prototype.add;\n\n SmallInteger.prototype.add = function (v) {\n var n = parseValue(v);\n var a = this.value;\n if (a < 0 !== n.sign) {\n return this.subtract(n.negate());\n }\n var b = n.value;\n if (n.isSmall) {\n if (isPrecise(a + b)) return new SmallInteger(a + b);\n b = smallToArray(Math.abs(b));\n }\n return new BigInteger(addSmall(b, Math.abs(a)), a < 0);\n };\n SmallInteger.prototype.plus = SmallInteger.prototype.add;\n\n NativeBigInt.prototype.add = function (v) {\n return new NativeBigInt(this.value + parseValue(v).value);\n }\n NativeBigInt.prototype.plus = NativeBigInt.prototype.add;\n\n function subtract(a, b) { // assumes a and b are arrays with a >= b\n var a_l = a.length,\n b_l = b.length,\n r = new Array(a_l),\n borrow = 0,\n base = BASE,\n i, difference;\n for (i = 0; i < b_l; i++) {\n difference = a[i] - borrow - b[i];\n if (difference < 0) {\n difference += base;\n borrow = 1;\n } else borrow = 0;\n r[i] = difference;\n }\n for (i = b_l; i < a_l; i++) {\n difference = a[i] - borrow;\n if (difference < 0) difference += base;\n else {\n r[i++] = difference;\n break;\n }\n r[i] = difference;\n }\n for (; i < a_l; i++) {\n r[i] = a[i];\n }\n trim(r);\n return r;\n }\n\n function subtractAny(a, b, sign) {\n var value;\n if (compareAbs(a, b) >= 0) {\n value = subtract(a, b);\n } else {\n value = subtract(b, a);\n sign = !sign;\n }\n value = arrayToSmall(value);\n if (typeof value === \"number\") {\n if (sign) value = -value;\n return new SmallInteger(value);\n }\n return new BigInteger(value, sign);\n }\n\n function subtractSmall(a, b, sign) { // assumes a is array, b is number with 0 <= b < MAX_INT\n var l = a.length,\n r = new Array(l),\n carry = -b,\n base = BASE,\n i, difference;\n for (i = 0; i < l; i++) {\n difference = a[i] + carry;\n carry = Math.floor(difference / base);\n difference %= base;\n r[i] = difference < 0 ? difference + base : difference;\n }\n r = arrayToSmall(r);\n if (typeof r === \"number\") {\n if (sign) r = -r;\n return new SmallInteger(r);\n } return new BigInteger(r, sign);\n }\n\n BigInteger.prototype.subtract = function (v) {\n var n = parseValue(v);\n if (this.sign !== n.sign) {\n return this.add(n.negate());\n }\n var a = this.value, b = n.value;\n if (n.isSmall)\n return subtractSmall(a, Math.abs(b), this.sign);\n return subtractAny(a, b, this.sign);\n };\n BigInteger.prototype.minus = BigInteger.prototype.subtract;\n\n SmallInteger.prototype.subtract = function (v) {\n var n = parseValue(v);\n var a = this.value;\n if (a < 0 !== n.sign) {\n return this.add(n.negate());\n }\n var b = n.value;\n if (n.isSmall) {\n return new SmallInteger(a - b);\n }\n return subtractSmall(b, Math.abs(a), a >= 0);\n };\n SmallInteger.prototype.minus = SmallInteger.prototype.subtract;\n\n NativeBigInt.prototype.subtract = function (v) {\n return new NativeBigInt(this.value - parseValue(v).value);\n }\n NativeBigInt.prototype.minus = NativeBigInt.prototype.subtract;\n\n BigInteger.prototype.negate = function () {\n return new BigInteger(this.value, !this.sign);\n };\n SmallInteger.prototype.negate = function () {\n var sign = this.sign;\n var small = new SmallInteger(-this.value);\n small.sign = !sign;\n return small;\n };\n NativeBigInt.prototype.negate = function () {\n return new NativeBigInt(-this.value);\n }\n\n BigInteger.prototype.abs = function () {\n return new BigInteger(this.value, false);\n };\n SmallInteger.prototype.abs = function () {\n return new SmallInteger(Math.abs(this.value));\n };\n NativeBigInt.prototype.abs = function () {\n return new NativeBigInt(this.value >= 0 ? this.value : -this.value);\n }\n\n\n function multiplyLong(a, b) {\n var a_l = a.length,\n b_l = b.length,\n l = a_l + b_l,\n r = createArray(l),\n base = BASE,\n product, carry, i, a_i, b_j;\n for (i = 0; i < a_l; ++i) {\n a_i = a[i];\n for (var j = 0; j < b_l; ++j) {\n b_j = b[j];\n product = a_i * b_j + r[i + j];\n carry = Math.floor(product / base);\n r[i + j] = product - carry * base;\n r[i + j + 1] += carry;\n }\n }\n trim(r);\n return r;\n }\n\n function multiplySmall(a, b) { // assumes a is array, b is number with |b| < BASE\n var l = a.length,\n r = new Array(l),\n base = BASE,\n carry = 0,\n product, i;\n for (i = 0; i < l; i++) {\n product = a[i] * b + carry;\n carry = Math.floor(product / base);\n r[i] = product - carry * base;\n }\n while (carry > 0) {\n r[i++] = carry % base;\n carry = Math.floor(carry / base);\n }\n return r;\n }\n\n function shiftLeft(x, n) {\n var r = [];\n while (n-- > 0) r.push(0);\n return r.concat(x);\n }\n\n function multiplyKaratsuba(x, y) {\n var n = Math.max(x.length, y.length);\n\n if (n <= 30) return multiplyLong(x, y);\n n = Math.ceil(n / 2);\n\n var b = x.slice(n),\n a = x.slice(0, n),\n d = y.slice(n),\n c = y.slice(0, n);\n\n var ac = multiplyKaratsuba(a, c),\n bd = multiplyKaratsuba(b, d),\n abcd = multiplyKaratsuba(addAny(a, b), addAny(c, d));\n\n var product = addAny(addAny(ac, shiftLeft(subtract(subtract(abcd, ac), bd), n)), shiftLeft(bd, 2 * n));\n trim(product);\n return product;\n }\n\n // The following function is derived from a surface fit of a graph plotting the performance difference\n // between long multiplication and karatsuba multiplication versus the lengths of the two arrays.\n function useKaratsuba(l1, l2) {\n return -0.012 * l1 - 0.012 * l2 + 0.000015 * l1 * l2 > 0;\n }\n\n BigInteger.prototype.multiply = function (v) {\n var n = parseValue(v),\n a = this.value, b = n.value,\n sign = this.sign !== n.sign,\n abs;\n if (n.isSmall) {\n if (b === 0) return Integer[0];\n if (b === 1) return this;\n if (b === -1) return this.negate();\n abs = Math.abs(b);\n if (abs < BASE) {\n return new BigInteger(multiplySmall(a, abs), sign);\n }\n b = smallToArray(abs);\n }\n if (useKaratsuba(a.length, b.length)) // Karatsuba is only faster for certain array sizes\n return new BigInteger(multiplyKaratsuba(a, b), sign);\n return new BigInteger(multiplyLong(a, b), sign);\n };\n\n BigInteger.prototype.times = BigInteger.prototype.multiply;\n\n function multiplySmallAndArray(a, b, sign) { // a >= 0\n if (a < BASE) {\n return new BigInteger(multiplySmall(b, a), sign);\n }\n return new BigInteger(multiplyLong(b, smallToArray(a)), sign);\n }\n SmallInteger.prototype._multiplyBySmall = function (a) {\n if (isPrecise(a.value * this.value)) {\n return new SmallInteger(a.value * this.value);\n }\n return multiplySmallAndArray(Math.abs(a.value), smallToArray(Math.abs(this.value)), this.sign !== a.sign);\n };\n BigInteger.prototype._multiplyBySmall = function (a) {\n if (a.value === 0) return Integer[0];\n if (a.value === 1) return this;\n if (a.value === -1) return this.negate();\n return multiplySmallAndArray(Math.abs(a.value), this.value, this.sign !== a.sign);\n };\n SmallInteger.prototype.multiply = function (v) {\n return parseValue(v)._multiplyBySmall(this);\n };\n SmallInteger.prototype.times = SmallInteger.prototype.multiply;\n\n NativeBigInt.prototype.multiply = function (v) {\n return new NativeBigInt(this.value * parseValue(v).value);\n }\n NativeBigInt.prototype.times = NativeBigInt.prototype.multiply;\n\n function square(a) {\n //console.assert(2 * BASE * BASE < MAX_INT);\n var l = a.length,\n r = createArray(l + l),\n base = BASE,\n product, carry, i, a_i, a_j;\n for (i = 0; i < l; i++) {\n a_i = a[i];\n carry = 0 - a_i * a_i;\n for (var j = i; j < l; j++) {\n a_j = a[j];\n product = 2 * (a_i * a_j) + r[i + j] + carry;\n carry = Math.floor(product / base);\n r[i + j] = product - carry * base;\n }\n r[i + l] = carry;\n }\n trim(r);\n return r;\n }\n\n BigInteger.prototype.square = function () {\n return new BigInteger(square(this.value), false);\n };\n\n SmallInteger.prototype.square = function () {\n var value = this.value * this.value;\n if (isPrecise(value)) return new SmallInteger(value);\n return new BigInteger(square(smallToArray(Math.abs(this.value))), false);\n };\n\n NativeBigInt.prototype.square = function (v) {\n return new NativeBigInt(this.value * this.value);\n }\n\n function divMod1(a, b) { // Left over from previous version. Performs faster than divMod2 on smaller input sizes.\n var a_l = a.length,\n b_l = b.length,\n base = BASE,\n result = createArray(b.length),\n divisorMostSignificantDigit = b[b_l - 1],\n // normalization\n lambda = Math.ceil(base / (2 * divisorMostSignificantDigit)),\n remainder = multiplySmall(a, lambda),\n divisor = multiplySmall(b, lambda),\n quotientDigit, shift, carry, borrow, i, l, q;\n if (remainder.length <= a_l) remainder.push(0);\n divisor.push(0);\n divisorMostSignificantDigit = divisor[b_l - 1];\n for (shift = a_l - b_l; shift >= 0; shift--) {\n quotientDigit = base - 1;\n if (remainder[shift + b_l] !== divisorMostSignificantDigit) {\n quotientDigit = Math.floor((remainder[shift + b_l] * base + remainder[shift + b_l - 1]) / divisorMostSignificantDigit);\n }\n // quotientDigit <= base - 1\n carry = 0;\n borrow = 0;\n l = divisor.length;\n for (i = 0; i < l; i++) {\n carry += quotientDigit * divisor[i];\n q = Math.floor(carry / base);\n borrow += remainder[shift + i] - (carry - q * base);\n carry = q;\n if (borrow < 0) {\n remainder[shift + i] = borrow + base;\n borrow = -1;\n } else {\n remainder[shift + i] = borrow;\n borrow = 0;\n }\n }\n while (borrow !== 0) {\n quotientDigit -= 1;\n carry = 0;\n for (i = 0; i < l; i++) {\n carry += remainder[shift + i] - base + divisor[i];\n if (carry < 0) {\n remainder[shift + i] = carry + base;\n carry = 0;\n } else {\n remainder[shift + i] = carry;\n carry = 1;\n }\n }\n borrow += carry;\n }\n result[shift] = quotientDigit;\n }\n // denormalization\n remainder = divModSmall(remainder, lambda)[0];\n return [arrayToSmall(result), arrayToSmall(remainder)];\n }\n\n function divMod2(a, b) { // Implementation idea shamelessly stolen from Silent Matt's library http://silentmatt.com/biginteger/\n // Performs faster than divMod1 on larger input sizes.\n var a_l = a.length,\n b_l = b.length,\n result = [],\n part = [],\n base = BASE,\n guess, xlen, highx, highy, check;\n while (a_l) {\n part.unshift(a[--a_l]);\n trim(part);\n if (compareAbs(part, b) < 0) {\n result.push(0);\n continue;\n }\n xlen = part.length;\n highx = part[xlen - 1] * base + part[xlen - 2];\n highy = b[b_l - 1] * base + b[b_l - 2];\n if (xlen > b_l) {\n highx = (highx + 1) * base;\n }\n guess = Math.ceil(highx / highy);\n do {\n check = multiplySmall(b, guess);\n if (compareAbs(check, part) <= 0) break;\n guess--;\n } while (guess);\n result.push(guess);\n part = subtract(part, check);\n }\n result.reverse();\n return [arrayToSmall(result), arrayToSmall(part)];\n }\n\n function divModSmall(value, lambda) {\n var length = value.length,\n quotient = createArray(length),\n base = BASE,\n i, q, remainder, divisor;\n remainder = 0;\n for (i = length - 1; i >= 0; --i) {\n divisor = remainder * base + value[i];\n q = truncate(divisor / lambda);\n remainder = divisor - q * lambda;\n quotient[i] = q | 0;\n }\n return [quotient, remainder | 0];\n }\n\n function divModAny(self, v) {\n var value, n = parseValue(v);\n if (supportsNativeBigInt) {\n return [new NativeBigInt(self.value / n.value), new NativeBigInt(self.value % n.value)];\n }\n var a = self.value, b = n.value;\n var quotient;\n if (b === 0) throw new Error(\"Cannot divide by zero\");\n if (self.isSmall) {\n if (n.isSmall) {\n return [new SmallInteger(truncate(a / b)), new SmallInteger(a % b)];\n }\n return [Integer[0], self];\n }\n if (n.isSmall) {\n if (b === 1) return [self, Integer[0]];\n if (b == -1) return [self.negate(), Integer[0]];\n var abs = Math.abs(b);\n if (abs < BASE) {\n value = divModSmall(a, abs);\n quotient = arrayToSmall(value[0]);\n var remainder = value[1];\n if (self.sign) remainder = -remainder;\n if (typeof quotient === \"number\") {\n if (self.sign !== n.sign) quotient = -quotient;\n return [new SmallInteger(quotient), new SmallInteger(remainder)];\n }\n return [new BigInteger(quotient, self.sign !== n.sign), new SmallInteger(remainder)];\n }\n b = smallToArray(abs);\n }\n var comparison = compareAbs(a, b);\n if (comparison === -1) return [Integer[0], self];\n if (comparison === 0) return [Integer[self.sign === n.sign ? 1 : -1], Integer[0]];\n\n // divMod1 is faster on smaller input sizes\n if (a.length + b.length <= 200)\n value = divMod1(a, b);\n else value = divMod2(a, b);\n\n quotient = value[0];\n var qSign = self.sign !== n.sign,\n mod = value[1],\n mSign = self.sign;\n if (typeof quotient === \"number\") {\n if (qSign) quotient = -quotient;\n quotient = new SmallInteger(quotient);\n } else quotient = new BigInteger(quotient, qSign);\n if (typeof mod === \"number\") {\n if (mSign) mod = -mod;\n mod = new SmallInteger(mod);\n } else mod = new BigInteger(mod, mSign);\n return [quotient, mod];\n }\n\n BigInteger.prototype.divmod = function (v) {\n var result = divModAny(this, v);\n return {\n quotient: result[0],\n remainder: result[1]\n };\n };\n NativeBigInt.prototype.divmod = SmallInteger.prototype.divmod = BigInteger.prototype.divmod;\n\n\n BigInteger.prototype.divide = function (v) {\n return divModAny(this, v)[0];\n };\n NativeBigInt.prototype.over = NativeBigInt.prototype.divide = function (v) {\n return new NativeBigInt(this.value / parseValue(v).value);\n };\n SmallInteger.prototype.over = SmallInteger.prototype.divide = BigInteger.prototype.over = BigInteger.prototype.divide;\n\n BigInteger.prototype.mod = function (v) {\n return divModAny(this, v)[1];\n };\n NativeBigInt.prototype.mod = NativeBigInt.prototype.remainder = function (v) {\n return new NativeBigInt(this.value % parseValue(v).value);\n };\n SmallInteger.prototype.remainder = SmallInteger.prototype.mod = BigInteger.prototype.remainder = BigInteger.prototype.mod;\n\n BigInteger.prototype.pow = function (v) {\n var n = parseValue(v),\n a = this.value,\n b = n.value,\n value, x, y;\n if (b === 0) return Integer[1];\n if (a === 0) return Integer[0];\n if (a === 1) return Integer[1];\n if (a === -1) return n.isEven() ? Integer[1] : Integer[-1];\n if (n.sign) {\n return Integer[0];\n }\n if (!n.isSmall) throw new Error(\"The exponent \" + n.toString() + \" is too large.\");\n if (this.isSmall) {\n if (isPrecise(value = Math.pow(a, b)))\n return new SmallInteger(truncate(value));\n }\n x = this;\n y = Integer[1];\n while (true) {\n if (b & 1 === 1) {\n y = y.times(x);\n --b;\n }\n if (b === 0) break;\n b /= 2;\n x = x.square();\n }\n return y;\n };\n SmallInteger.prototype.pow = BigInteger.prototype.pow;\n\n NativeBigInt.prototype.pow = function (v) {\n var n = parseValue(v);\n var a = this.value, b = n.value;\n var _0 = BigInt(0), _1 = BigInt(1), _2 = BigInt(2);\n if (b === _0) return Integer[1];\n if (a === _0) return Integer[0];\n if (a === _1) return Integer[1];\n if (a === BigInt(-1)) return n.isEven() ? Integer[1] : Integer[-1];\n if (n.isNegative()) return new NativeBigInt(_0);\n var x = this;\n var y = Integer[1];\n while (true) {\n if ((b & _1) === _1) {\n y = y.times(x);\n --b;\n }\n if (b === _0) break;\n b /= _2;\n x = x.square();\n }\n return y;\n }\n\n BigInteger.prototype.modPow = function (exp, mod) {\n exp = parseValue(exp);\n mod = parseValue(mod);\n if (mod.isZero()) throw new Error(\"Cannot take modPow with modulus 0\");\n var r = Integer[1],\n base = this.mod(mod);\n if (exp.isNegative()) {\n exp = exp.multiply(Integer[-1]);\n base = base.modInv(mod);\n }\n while (exp.isPositive()) {\n if (base.isZero()) return Integer[0];\n if (exp.isOdd()) r = r.multiply(base).mod(mod);\n exp = exp.divide(2);\n base = base.square().mod(mod);\n }\n return r;\n };\n NativeBigInt.prototype.modPow = SmallInteger.prototype.modPow = BigInteger.prototype.modPow;\n\n function compareAbs(a, b) {\n if (a.length !== b.length) {\n return a.length > b.length ? 1 : -1;\n }\n for (var i = a.length - 1; i >= 0; i--) {\n if (a[i] !== b[i]) return a[i] > b[i] ? 1 : -1;\n }\n return 0;\n }\n\n BigInteger.prototype.compareAbs = function (v) {\n var n = parseValue(v),\n a = this.value,\n b = n.value;\n if (n.isSmall) return 1;\n return compareAbs(a, b);\n };\n SmallInteger.prototype.compareAbs = function (v) {\n var n = parseValue(v),\n a = Math.abs(this.value),\n b = n.value;\n if (n.isSmall) {\n b = Math.abs(b);\n return a === b ? 0 : a > b ? 1 : -1;\n }\n return -1;\n };\n NativeBigInt.prototype.compareAbs = function (v) {\n var a = this.value;\n var b = parseValue(v).value;\n a = a >= 0 ? a : -a;\n b = b >= 0 ? b : -b;\n return a === b ? 0 : a > b ? 1 : -1;\n }\n\n BigInteger.prototype.compare = function (v) {\n // See discussion about comparison with Infinity:\n // https://github.com/peterolson/BigInteger.js/issues/61\n if (v === Infinity) {\n return -1;\n }\n if (v === -Infinity) {\n return 1;\n }\n\n var n = parseValue(v),\n a = this.value,\n b = n.value;\n if (this.sign !== n.sign) {\n return n.sign ? 1 : -1;\n }\n if (n.isSmall) {\n return this.sign ? -1 : 1;\n }\n return compareAbs(a, b) * (this.sign ? -1 : 1);\n };\n BigInteger.prototype.compareTo = BigInteger.prototype.compare;\n\n SmallInteger.prototype.compare = function (v) {\n if (v === Infinity) {\n return -1;\n }\n if (v === -Infinity) {\n return 1;\n }\n\n var n = parseValue(v),\n a = this.value,\n b = n.value;\n if (n.isSmall) {\n return a == b ? 0 : a > b ? 1 : -1;\n }\n if (a < 0 !== n.sign) {\n return a < 0 ? -1 : 1;\n }\n return a < 0 ? 1 : -1;\n };\n SmallInteger.prototype.compareTo = SmallInteger.prototype.compare;\n\n NativeBigInt.prototype.compare = function (v) {\n if (v === Infinity) {\n return -1;\n }\n if (v === -Infinity) {\n return 1;\n }\n var a = this.value;\n var b = parseValue(v).value;\n return a === b ? 0 : a > b ? 1 : -1;\n }\n NativeBigInt.prototype.compareTo = NativeBigInt.prototype.compare;\n\n BigInteger.prototype.equals = function (v) {\n return this.compare(v) === 0;\n };\n NativeBigInt.prototype.eq = NativeBigInt.prototype.equals = SmallInteger.prototype.eq = SmallInteger.prototype.equals = BigInteger.prototype.eq = BigInteger.prototype.equals;\n\n BigInteger.prototype.notEquals = function (v) {\n return this.compare(v) !== 0;\n };\n NativeBigInt.prototype.neq = NativeBigInt.prototype.notEquals = SmallInteger.prototype.neq = SmallInteger.prototype.notEquals = BigInteger.prototype.neq = BigInteger.prototype.notEquals;\n\n BigInteger.prototype.greater = function (v) {\n return this.compare(v) > 0;\n };\n NativeBigInt.prototype.gt = NativeBigInt.prototype.greater = SmallInteger.prototype.gt = SmallInteger.prototype.greater = BigInteger.prototype.gt = BigInteger.prototype.greater;\n\n BigInteger.prototype.lesser = function (v) {\n return this.compare(v) < 0;\n };\n NativeBigInt.prototype.lt = NativeBigInt.prototype.lesser = SmallInteger.prototype.lt = SmallInteger.prototype.lesser = BigInteger.prototype.lt = BigInteger.prototype.lesser;\n\n BigInteger.prototype.greaterOrEquals = function (v) {\n return this.compare(v) >= 0;\n };\n NativeBigInt.prototype.geq = NativeBigInt.prototype.greaterOrEquals = SmallInteger.prototype.geq = SmallInteger.prototype.greaterOrEquals = BigInteger.prototype.geq = BigInteger.prototype.greaterOrEquals;\n\n BigInteger.prototype.lesserOrEquals = function (v) {\n return this.compare(v) <= 0;\n };\n NativeBigInt.prototype.leq = NativeBigInt.prototype.lesserOrEquals = SmallInteger.prototype.leq = SmallInteger.prototype.lesserOrEquals = BigInteger.prototype.leq = BigInteger.prototype.lesserOrEquals;\n\n BigInteger.prototype.isEven = function () {\n return (this.value[0] & 1) === 0;\n };\n SmallInteger.prototype.isEven = function () {\n return (this.value & 1) === 0;\n };\n NativeBigInt.prototype.isEven = function () {\n return (this.value & BigInt(1)) === BigInt(0);\n }\n\n BigInteger.prototype.isOdd = function () {\n return (this.value[0] & 1) === 1;\n };\n SmallInteger.prototype.isOdd = function () {\n return (this.value & 1) === 1;\n };\n NativeBigInt.prototype.isOdd = function () {\n return (this.value & BigInt(1)) === BigInt(1);\n }\n\n BigInteger.prototype.isPositive = function () {\n return !this.sign;\n };\n SmallInteger.prototype.isPositive = function () {\n return this.value > 0;\n };\n NativeBigInt.prototype.isPositive = SmallInteger.prototype.isPositive;\n\n BigInteger.prototype.isNegative = function () {\n return this.sign;\n };\n SmallInteger.prototype.isNegative = function () {\n return this.value < 0;\n };\n NativeBigInt.prototype.isNegative = SmallInteger.prototype.isNegative;\n\n BigInteger.prototype.isUnit = function () {\n return false;\n };\n SmallInteger.prototype.isUnit = function () {\n return Math.abs(this.value) === 1;\n };\n NativeBigInt.prototype.isUnit = function () {\n return this.abs().value === BigInt(1);\n }\n\n BigInteger.prototype.isZero = function () {\n return false;\n };\n SmallInteger.prototype.isZero = function () {\n return this.value === 0;\n };\n NativeBigInt.prototype.isZero = function () {\n return this.value === BigInt(0);\n }\n\n BigInteger.prototype.isDivisibleBy = function (v) {\n var n = parseValue(v);\n if (n.isZero()) return false;\n if (n.isUnit()) return true;\n if (n.compareAbs(2) === 0) return this.isEven();\n return this.mod(n).isZero();\n };\n NativeBigInt.prototype.isDivisibleBy = SmallInteger.prototype.isDivisibleBy = BigInteger.prototype.isDivisibleBy;\n\n function isBasicPrime(v) {\n var n = v.abs();\n if (n.isUnit()) return false;\n if (n.equals(2) || n.equals(3) || n.equals(5)) return true;\n if (n.isEven() || n.isDivisibleBy(3) || n.isDivisibleBy(5)) return false;\n if (n.lesser(49)) return true;\n // we don't know if it's prime: let the other functions figure it out\n }\n\n function millerRabinTest(n, a) {\n var nPrev = n.prev(),\n b = nPrev,\n r = 0,\n d, t, i, x;\n while (b.isEven()) b = b.divide(2), r++;\n next: for (i = 0; i < a.length; i++) {\n if (n.lesser(a[i])) continue;\n x = bigInt(a[i]).modPow(b, n);\n if (x.isUnit() || x.equals(nPrev)) continue;\n for (d = r - 1; d != 0; d--) {\n x = x.square().mod(n);\n if (x.isUnit()) return false;\n if (x.equals(nPrev)) continue next;\n }\n return false;\n }\n return true;\n }\n\n // Set \"strict\" to true to force GRH-supported lower bound of 2*log(N)^2\n BigInteger.prototype.isPrime = function (strict) {\n var isPrime = isBasicPrime(this);\n if (isPrime !== undefined) return isPrime;\n var n = this.abs();\n var bits = n.bitLength();\n if (bits <= 64)\n return millerRabinTest(n, [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37]);\n var logN = Math.log(2) * bits.toJSNumber();\n var t = Math.ceil((strict === true) ? (2 * Math.pow(logN, 2)) : logN);\n for (var a = [], i = 0; i < t; i++) {\n a.push(bigInt(i + 2));\n }\n return millerRabinTest(n, a);\n };\n NativeBigInt.prototype.isPrime = SmallInteger.prototype.isPrime = BigInteger.prototype.isPrime;\n\n BigInteger.prototype.isProbablePrime = function (iterations) {\n var isPrime = isBasicPrime(this);\n if (isPrime !== undefined) return isPrime;\n var n = this.abs();\n var t = iterations === undefined ? 5 : iterations;\n for (var a = [], i = 0; i < t; i++) {\n a.push(bigInt.randBetween(2, n.minus(2)));\n }\n return millerRabinTest(n, a);\n };\n NativeBigInt.prototype.isProbablePrime = SmallInteger.prototype.isProbablePrime = BigInteger.prototype.isProbablePrime;\n\n BigInteger.prototype.modInv = function (n) {\n var t = bigInt.zero, newT = bigInt.one, r = parseValue(n), newR = this.abs(), q, lastT, lastR;\n while (!newR.isZero()) {\n q = r.divide(newR);\n lastT = t;\n lastR = r;\n t = newT;\n r = newR;\n newT = lastT.subtract(q.multiply(newT));\n newR = lastR.subtract(q.multiply(newR));\n }\n if (!r.isUnit()) throw new Error(this.toString() + \" and \" + n.toString() + \" are not co-prime\");\n if (t.compare(0) === -1) {\n t = t.add(n);\n }\n if (this.isNegative()) {\n return t.negate();\n }\n return t;\n };\n\n NativeBigInt.prototype.modInv = SmallInteger.prototype.modInv = BigInteger.prototype.modInv;\n\n BigInteger.prototype.next = function () {\n var value = this.value;\n if (this.sign) {\n return subtractSmall(value, 1, this.sign);\n }\n return new BigInteger(addSmall(value, 1), this.sign);\n };\n SmallInteger.prototype.next = function () {\n var value = this.value;\n if (value + 1 < MAX_INT) return new SmallInteger(value + 1);\n return new BigInteger(MAX_INT_ARR, false);\n };\n NativeBigInt.prototype.next = function () {\n return new NativeBigInt(this.value + BigInt(1));\n }\n\n BigInteger.prototype.prev = function () {\n var value = this.value;\n if (this.sign) {\n return new BigInteger(addSmall(value, 1), true);\n }\n return subtractSmall(value, 1, this.sign);\n };\n SmallInteger.prototype.prev = function () {\n var value = this.value;\n if (value - 1 > -MAX_INT) return new SmallInteger(value - 1);\n return new BigInteger(MAX_INT_ARR, true);\n };\n NativeBigInt.prototype.prev = function () {\n return new NativeBigInt(this.value - BigInt(1));\n }\n\n var powersOfTwo = [1];\n while (2 * powersOfTwo[powersOfTwo.length - 1] <= BASE) powersOfTwo.push(2 * powersOfTwo[powersOfTwo.length - 1]);\n var powers2Length = powersOfTwo.length, highestPower2 = powersOfTwo[powers2Length - 1];\n\n function shift_isSmall(n) {\n return Math.abs(n) <= BASE;\n }\n\n BigInteger.prototype.shiftLeft = function (v) {\n var n = parseValue(v).toJSNumber();\n if (!shift_isSmall(n)) {\n throw new Error(String(n) + \" is too large for shifting.\");\n }\n if (n < 0) return this.shiftRight(-n);\n var result = this;\n if (result.isZero()) return result;\n while (n >= powers2Length) {\n result = result.multiply(highestPower2);\n n -= powers2Length - 1;\n }\n return result.multiply(powersOfTwo[n]);\n };\n NativeBigInt.prototype.shiftLeft = SmallInteger.prototype.shiftLeft = BigInteger.prototype.shiftLeft;\n\n BigInteger.prototype.shiftRight = function (v) {\n var remQuo;\n var n = parseValue(v).toJSNumber();\n if (!shift_isSmall(n)) {\n throw new Error(String(n) + \" is too large for shifting.\");\n }\n if (n < 0) return this.shiftLeft(-n);\n var result = this;\n while (n >= powers2Length) {\n if (result.isZero() || (result.isNegative() && result.isUnit())) return result;\n remQuo = divModAny(result, highestPower2);\n result = remQuo[1].isNegative() ? remQuo[0].prev() : remQuo[0];\n n -= powers2Length - 1;\n }\n remQuo = divModAny(result, powersOfTwo[n]);\n return remQuo[1].isNegative() ? remQuo[0].prev() : remQuo[0];\n };\n NativeBigInt.prototype.shiftRight = SmallInteger.prototype.shiftRight = BigInteger.prototype.shiftRight;\n\n function bitwise(x, y, fn) {\n y = parseValue(y);\n var xSign = x.isNegative(), ySign = y.isNegative();\n var xRem = xSign ? x.not() : x,\n yRem = ySign ? y.not() : y;\n var xDigit = 0, yDigit = 0;\n var xDivMod = null, yDivMod = null;\n var result = [];\n while (!xRem.isZero() || !yRem.isZero()) {\n xDivMod = divModAny(xRem, highestPower2);\n xDigit = xDivMod[1].toJSNumber();\n if (xSign) {\n xDigit = highestPower2 - 1 - xDigit; // two's complement for negative numbers\n }\n\n yDivMod = divModAny(yRem, highestPower2);\n yDigit = yDivMod[1].toJSNumber();\n if (ySign) {\n yDigit = highestPower2 - 1 - yDigit; // two's complement for negative numbers\n }\n\n xRem = xDivMod[0];\n yRem = yDivMod[0];\n result.push(fn(xDigit, yDigit));\n }\n var sum = fn(xSign ? 1 : 0, ySign ? 1 : 0) !== 0 ? bigInt(-1) : bigInt(0);\n for (var i = result.length - 1; i >= 0; i -= 1) {\n sum = sum.multiply(highestPower2).add(bigInt(result[i]));\n }\n return sum;\n }\n\n BigInteger.prototype.not = function () {\n return this.negate().prev();\n };\n NativeBigInt.prototype.not = SmallInteger.prototype.not = BigInteger.prototype.not;\n\n BigInteger.prototype.and = function (n) {\n return bitwise(this, n, function (a, b) { return a & b; });\n };\n NativeBigInt.prototype.and = SmallInteger.prototype.and = BigInteger.prototype.and;\n\n BigInteger.prototype.or = function (n) {\n return bitwise(this, n, function (a, b) { return a | b; });\n };\n NativeBigInt.prototype.or = SmallInteger.prototype.or = BigInteger.prototype.or;\n\n BigInteger.prototype.xor = function (n) {\n return bitwise(this, n, function (a, b) { return a ^ b; });\n };\n NativeBigInt.prototype.xor = SmallInteger.prototype.xor = BigInteger.prototype.xor;\n\n var LOBMASK_I = 1 << 30, LOBMASK_BI = (BASE & -BASE) * (BASE & -BASE) | LOBMASK_I;\n function roughLOB(n) { // get lowestOneBit (rough)\n // SmallInteger: return Min(lowestOneBit(n), 1 << 30)\n // BigInteger: return Min(lowestOneBit(n), 1 << 14) [BASE=1e7]\n var v = n.value,\n x = typeof v === \"number\" ? v | LOBMASK_I :\n typeof v === \"bigint\" ? v | BigInt(LOBMASK_I) :\n v[0] + v[1] * BASE | LOBMASK_BI;\n return x & -x;\n }\n\n function integerLogarithm(value, base) {\n if (base.compareTo(value) <= 0) {\n var tmp = integerLogarithm(value, base.square(base));\n var p = tmp.p;\n var e = tmp.e;\n var t = p.multiply(base);\n return t.compareTo(value) <= 0 ? { p: t, e: e * 2 + 1 } : { p: p, e: e * 2 };\n }\n return { p: bigInt(1), e: 0 };\n }\n\n BigInteger.prototype.bitLength = function () {\n var n = this;\n if (n.compareTo(bigInt(0)) < 0) {\n n = n.negate().subtract(bigInt(1));\n }\n if (n.compareTo(bigInt(0)) === 0) {\n return bigInt(0);\n }\n return bigInt(integerLogarithm(n, bigInt(2)).e).add(bigInt(1));\n }\n NativeBigInt.prototype.bitLength = SmallInteger.prototype.bitLength = BigInteger.prototype.bitLength;\n\n function max(a, b) {\n a = parseValue(a);\n b = parseValue(b);\n return a.greater(b) ? a : b;\n }\n function min(a, b) {\n a = parseValue(a);\n b = parseValue(b);\n return a.lesser(b) ? a : b;\n }\n function gcd(a, b) {\n a = parseValue(a).abs();\n b = parseValue(b).abs();\n if (a.equals(b)) return a;\n if (a.isZero()) return b;\n if (b.isZero()) return a;\n var c = Integer[1], d, t;\n while (a.isEven() && b.isEven()) {\n d = min(roughLOB(a), roughLOB(b));\n a = a.divide(d);\n b = b.divide(d);\n c = c.multiply(d);\n }\n while (a.isEven()) {\n a = a.divide(roughLOB(a));\n }\n do {\n while (b.isEven()) {\n b = b.divide(roughLOB(b));\n }\n if (a.greater(b)) {\n t = b; b = a; a = t;\n }\n b = b.subtract(a);\n } while (!b.isZero());\n return c.isUnit() ? a : a.multiply(c);\n }\n function lcm(a, b) {\n a = parseValue(a).abs();\n b = parseValue(b).abs();\n return a.divide(gcd(a, b)).multiply(b);\n }\n function randBetween(a, b) {\n a = parseValue(a);\n b = parseValue(b);\n var low = min(a, b), high = max(a, b);\n var range = high.subtract(low).add(1);\n if (range.isSmall) return low.add(Math.floor(Math.random() * range));\n var digits = toBase(range, BASE).value;\n var result = [], restricted = true;\n for (var i = 0; i < digits.length; i++) {\n var top = restricted ? digits[i] : BASE;\n var digit = truncate(Math.random() * top);\n result.push(digit);\n if (digit < top) restricted = false;\n }\n return low.add(Integer.fromArray(result, BASE, false));\n }\n\n var parseBase = function (text, base, alphabet, caseSensitive) {\n alphabet = alphabet || DEFAULT_ALPHABET;\n text = String(text);\n if (!caseSensitive) {\n text = text.toLowerCase();\n alphabet = alphabet.toLowerCase();\n }\n var length = text.length;\n var i;\n var absBase = Math.abs(base);\n var alphabetValues = {};\n for (i = 0; i < alphabet.length; i++) {\n alphabetValues[alphabet[i]] = i;\n }\n for (i = 0; i < length; i++) {\n var c = text[i];\n if (c === \"-\") continue;\n if (c in alphabetValues) {\n if (alphabetValues[c] >= absBase) {\n if (c === \"1\" && absBase === 1) continue;\n throw new Error(c + \" is not a valid digit in base \" + base + \".\");\n }\n }\n }\n base = parseValue(base);\n var digits = [];\n var isNegative = text[0] === \"-\";\n for (i = isNegative ? 1 : 0; i < text.length; i++) {\n var c = text[i];\n if (c in alphabetValues) digits.push(parseValue(alphabetValues[c]));\n else if (c === \"<\") {\n var start = i;\n do { i++; } while (text[i] !== \">\" && i < text.length);\n digits.push(parseValue(text.slice(start + 1, i)));\n }\n else throw new Error(c + \" is not a valid character\");\n }\n return parseBaseFromArray(digits, base, isNegative);\n };\n\n function parseBaseFromArray(digits, base, isNegative) {\n var val = Integer[0], pow = Integer[1], i;\n for (i = digits.length - 1; i >= 0; i--) {\n val = val.add(digits[i].times(pow));\n pow = pow.times(base);\n }\n return isNegative ? val.negate() : val;\n }\n\n function stringify(digit, alphabet) {\n alphabet = alphabet || DEFAULT_ALPHABET;\n if (digit < alphabet.length) {\n return alphabet[digit];\n }\n return \"<\" + digit + \">\";\n }\n\n function toBase(n, base) {\n base = bigInt(base);\n if (base.isZero()) {\n if (n.isZero()) return { value: [0], isNegative: false };\n throw new Error(\"Cannot convert nonzero numbers to base 0.\");\n }\n if (base.equals(-1)) {\n if (n.isZero()) return { value: [0], isNegative: false };\n if (n.isNegative())\n return {\n value: [].concat.apply([], Array.apply(null, Array(-n.toJSNumber()))\n .map(Array.prototype.valueOf, [1, 0])\n ),\n isNegative: false\n };\n\n var arr = Array.apply(null, Array(n.toJSNumber() - 1))\n .map(Array.prototype.valueOf, [0, 1]);\n arr.unshift([1]);\n return {\n value: [].concat.apply([], arr),\n isNegative: false\n };\n }\n\n var neg = false;\n if (n.isNegative() && base.isPositive()) {\n neg = true;\n n = n.abs();\n }\n if (base.isUnit()) {\n if (n.isZero()) return { value: [0], isNegative: false };\n\n return {\n value: Array.apply(null, Array(n.toJSNumber()))\n .map(Number.prototype.valueOf, 1),\n isNegative: neg\n };\n }\n var out = [];\n var left = n, divmod;\n while (left.isNegative() || left.compareAbs(base) >= 0) {\n divmod = left.divmod(base);\n left = divmod.quotient;\n var digit = divmod.remainder;\n if (digit.isNegative()) {\n digit = base.minus(digit).abs();\n left = left.next();\n }\n out.push(digit.toJSNumber());\n }\n out.push(left.toJSNumber());\n return { value: out.reverse(), isNegative: neg };\n }\n\n function toBaseString(n, base, alphabet) {\n var arr = toBase(n, base);\n return (arr.isNegative ? \"-\" : \"\") + arr.value.map(function (x) {\n return stringify(x, alphabet);\n }).join('');\n }\n\n BigInteger.prototype.toArray = function (radix) {\n return toBase(this, radix);\n };\n\n SmallInteger.prototype.toArray = function (radix) {\n return toBase(this, radix);\n };\n\n NativeBigInt.prototype.toArray = function (radix) {\n return toBase(this, radix);\n };\n\n BigInteger.prototype.toString = function (radix, alphabet) {\n if (radix === undefined) radix = 10;\n if (radix !== 10) return toBaseString(this, radix, alphabet);\n var v = this.value, l = v.length, str = String(v[--l]), zeros = \"0000000\", digit;\n while (--l >= 0) {\n digit = String(v[l]);\n str += zeros.slice(digit.length) + digit;\n }\n var sign = this.sign ? \"-\" : \"\";\n return sign + str;\n };\n\n SmallInteger.prototype.toString = function (radix, alphabet) {\n if (radix === undefined) radix = 10;\n if (radix != 10) return toBaseString(this, radix, alphabet);\n return String(this.value);\n };\n\n NativeBigInt.prototype.toString = SmallInteger.prototype.toString;\n\n NativeBigInt.prototype.toJSON = BigInteger.prototype.toJSON = SmallInteger.prototype.toJSON = function () { return this.toString(); }\n\n BigInteger.prototype.valueOf = function () {\n return parseInt(this.toString(), 10);\n };\n BigInteger.prototype.toJSNumber = BigInteger.prototype.valueOf;\n\n SmallInteger.prototype.valueOf = function () {\n return this.value;\n };\n SmallInteger.prototype.toJSNumber = SmallInteger.prototype.valueOf;\n NativeBigInt.prototype.valueOf = NativeBigInt.prototype.toJSNumber = function () {\n return parseInt(this.toString(), 10);\n }\n\n function parseStringValue(v) {\n if (isPrecise(+v)) {\n var x = +v;\n if (x === truncate(x))\n return supportsNativeBigInt ? new NativeBigInt(BigInt(x)) : new SmallInteger(x);\n throw new Error(\"Invalid integer: \" + v);\n }\n var sign = v[0] === \"-\";\n if (sign) v = v.slice(1);\n var split = v.split(/e/i);\n if (split.length > 2) throw new Error(\"Invalid integer: \" + split.join(\"e\"));\n if (split.length === 2) {\n var exp = split[1];\n if (exp[0] === \"+\") exp = exp.slice(1);\n exp = +exp;\n if (exp !== truncate(exp) || !isPrecise(exp)) throw new Error(\"Invalid integer: \" + exp + \" is not a valid exponent.\");\n var text = split[0];\n var decimalPlace = text.indexOf(\".\");\n if (decimalPlace >= 0) {\n exp -= text.length - decimalPlace - 1;\n text = text.slice(0, decimalPlace) + text.slice(decimalPlace + 1);\n }\n if (exp < 0) throw new Error(\"Cannot include negative exponent part for integers\");\n text += (new Array(exp + 1)).join(\"0\");\n v = text;\n }\n var isValid = /^([0-9][0-9]*)$/.test(v);\n if (!isValid) throw new Error(\"Invalid integer: \" + v);\n if (supportsNativeBigInt) {\n return new NativeBigInt(BigInt(sign ? \"-\" + v : v));\n }\n var r = [], max = v.length, l = LOG_BASE, min = max - l;\n while (max > 0) {\n r.push(+v.slice(min, max));\n min -= l;\n if (min < 0) min = 0;\n max -= l;\n }\n trim(r);\n return new BigInteger(r, sign);\n }\n\n function parseNumberValue(v) {\n if (supportsNativeBigInt) {\n return new NativeBigInt(BigInt(v));\n }\n if (isPrecise(v)) {\n if (v !== truncate(v)) throw new Error(v + \" is not an integer.\");\n return new SmallInteger(v);\n }\n return parseStringValue(v.toString());\n }\n\n function parseValue(v) {\n if (typeof v === \"number\") {\n return parseNumberValue(v);\n }\n if (typeof v === \"string\") {\n return parseStringValue(v);\n }\n if (typeof v === \"bigint\") {\n return new NativeBigInt(v);\n }\n return v;\n }\n // Pre-define numbers in range [-999,999]\n for (var i = 0; i < 1000; i++) {\n Integer[i] = parseValue(i);\n if (i > 0) Integer[-i] = parseValue(-i);\n }\n // Backwards compatibility\n Integer.one = Integer[1];\n Integer.zero = Integer[0];\n Integer.minusOne = Integer[-1];\n Integer.max = max;\n Integer.min = min;\n Integer.gcd = gcd;\n Integer.lcm = lcm;\n Integer.isInstance = function (x) { return x instanceof BigInteger || x instanceof SmallInteger || x instanceof NativeBigInt; };\n Integer.randBetween = randBetween;\n\n Integer.fromArray = function (digits, base, isNegative) {\n return parseBaseFromArray(digits.map(parseValue), parseValue(base || 10), isNegative);\n };\n\n return Integer;\n})();\n","/* global bigInt */\n/* eslint-disable no-unused-vars */\n\n// We represent a [Z.t] as a javascript 32bit integers if it fits or as a bigInt.\n\n//Provides: ml_z_normalize\n//Requires: bigInt\nfunction ml_z_normalize(x){\n var y = x.toJSNumber () | 0;\n if(x.equals(bigInt(y))) return y;\n return x;\n}\n\n//Provides: ml_z_mul_overflows\nfunction ml_z_mul_overflows(x,y){\n var z = x*y;\n return z != (z|0);\n}\n\n//external init: unit -> unit\n//Provides: ml_z_init\n//Requires: caml_zarith_marshal, caml_zarith_unmarshal, caml_custom_ops, ml_z_hash, ml_z_compare\nfunction ml_z_init(unit) {\n caml_custom_ops['_z'] =\n { serialize : caml_zarith_marshal,\n deserialize : caml_zarith_unmarshal,\n hash : ml_z_hash,\n compare : ml_z_compare,\n };\n return 0 }\n\n//external ml_z_install_frametable: unit -> unit\n//Provides: ml_z_install_frametable const\nfunction ml_z_install_frametable(unit) { return 0 }\n\n//external neg: t -> t\n//Provides: ml_z_neg const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_neg(z1) {\n return ml_z_normalize(bigInt(z1).negate());\n}\n\n//external add: t -> t -> t\n//Provides: ml_z_add const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_add(z1, z2) {\n return ml_z_normalize(bigInt(z1).add(bigInt(z2)));\n}\n\n//external sub: t -> t -> t\n//Provides: ml_z_sub const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_sub(z1, z2) {\n return ml_z_normalize(bigInt(z1).subtract(bigInt(z2)));\n}\n\n//external mul: t -> t -> t\n//Provides: ml_z_mul const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_mul(z1, z2) {\n return ml_z_normalize(bigInt(z1).multiply(bigInt(z2)));\n}\n\n//external div: t -> t -> t\n//Provides: ml_z_div\n//Requires: bigInt, caml_raise_zero_divide, ml_z_normalize\nfunction ml_z_div(z1, z2) {\n z2 = bigInt(z2)\n if(z2.equals(bigInt(0))) caml_raise_zero_divide();\n return ml_z_normalize(bigInt(z1).divide(bigInt(z2)))\n}\n\n//external cdiv: t -> t -> t\n//Provides: ml_z_cdiv\n//Requires: bigInt, ml_z_div, ml_z_sign, ml_z_add\nfunction ml_z_cdiv(z1, z2) {\n var z1_pos = ml_z_sign(z1);\n var z2_pos = ml_z_sign(z2);\n if (z1_pos * z2_pos > 0) /* Multiplication is like a signwise xor */ {\n if (!bigInt(z1).mod(bigInt(z2)).equals(bigInt(0))) {\n return ml_z_add(ml_z_div(z1, z2), bigInt(1)) ;\n }\n }\n return ml_z_div(z1, z2);\n}\n\n//external fdiv: t -> t -> t\n//Provides: ml_z_fdiv\n//Requires: bigInt, ml_z_div, ml_z_sign, ml_z_sub\nfunction ml_z_fdiv(z1, z2) {\n var z1_pos = ml_z_sign(z1);\n var z2_pos = ml_z_sign(z2);\n if (z1_pos * z2_pos < 0) /* Multiplication is like a signwise xor */ {\n if (!bigInt(z1).mod(bigInt(z2)).equals(bigInt(0))) {\n return ml_z_sub(ml_z_div(z1, z2), bigInt(1)) ;\n }\n }\n return ml_z_div(z1, z2);\n}\n\n//external rem: t -> t -> t\n//Provides: ml_z_rem\n//Requires: bigInt, caml_raise_zero_divide, ml_z_normalize\nfunction ml_z_rem(z1, z2) {\n z2 = bigInt(z2);\n if (z2.equals(bigInt(0))) {\n caml_raise_zero_divide();\n }\n return ml_z_normalize(bigInt(z1).mod(z2));\n}\n\n//external div_rem: t -> t -> (t * t)\n//Provides: ml_z_div_rem\n//Requires: ml_z_div, ml_z_rem\nfunction ml_z_div_rem(z1, z2) {\n return [0, ml_z_div(z1,z2), ml_z_rem(z1, z2)]\n}\n//external succ: t -> t\n//Provides: ml_z_succ const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_succ(z1) {\n return ml_z_normalize(bigInt(z1).next());\n}\n\n//external pred: t -> t\n//Provides: ml_z_pred const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_pred(z1) {\n return ml_z_normalize(bigInt(z1).prev());\n}\n\n//external abs: t -> t\n//Provides: ml_z_abs const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_abs(z1) {\n return ml_z_normalize(bigInt(z1).abs());\n}\n\n//external logand: t -> t -> t\n//Provides: ml_z_logand const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_logand(z1, z2) {\n return ml_z_normalize(bigInt(z1).and(bigInt(z2)));\n}\n\n//external logor: t -> t -> t\n//Provides: ml_z_logor const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_logor(z1, z2) {\n return ml_z_normalize(bigInt(z1).or(bigInt(z2)));\n}\n\n//external logxor: t -> t -> t\n//Provides: ml_z_logxor const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_logxor(z1, z2) {\n return ml_z_normalize(bigInt(z1).xor(bigInt(z2)));\n}\n\n//external lognot: t -> t\n//Provides: ml_z_lognot const\n//Requires: bigInt,ml_z_normalize\nfunction ml_z_lognot(z1) {\n return ml_z_normalize(bigInt(z1).not());\n}\n\n//external shift_left: t -> int -> t\n//Provides: ml_z_shift_left const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_shift_left(z1, amt) {\n return ml_z_normalize(bigInt(z1).shiftLeft(amt));\n}\n\n//external shift_right: t -> int -> t\n//Provides: ml_z_shift_right const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_shift_right(z1, amt) {\n return ml_z_normalize(bigInt(z1).shiftRight(amt));\n}\n\n//external shift_right_trunc: t -> int -> t\n//Provides: ml_z_shift_right_trunc const\n//Requires: bigInt, ml_z_div\nfunction ml_z_shift_right_trunc(z1, z2) {\n return ml_z_div(bigInt(z1), bigInt(2).pow(z2))\n}\n\n//external of_int: int -> t\n//Provides: ml_z_of_int const\n//Requires: bigInt\nfunction ml_z_of_int(i) {\n return i | 0;\n}\n\n//external of_int32: int32 -> t\n//Provides: ml_z_of_int32 const\n//Requires: ml_z_of_int\nfunction ml_z_of_int32(i32) {\n return ml_z_of_int(i32);\n}\n\n//external of_nativeint: nativeint -> t\n//Provides: ml_z_of_nativeint const\n//Requires: ml_z_of_int\nfunction ml_z_of_nativeint(z) {\n return ml_z_of_int(z)\n}\n\n//external of_int64: int64 -> t\n//Provides: ml_z_of_int64 const\n//Requires: bigInt, caml_int64_compare, caml_int64_neg, ml_z_normalize\n//Requires: caml_int64_create_lo_hi,caml_int64_hi32,caml_int64_lo32\nfunction ml_z_of_int64(i64) {\n var neg = false;\n if(caml_int64_compare(i64, caml_int64_create_lo_hi(0,0)) < 0) {\n neg = true;\n i64 = caml_int64_neg(i64)\n }\n var lo = caml_int64_lo32(i64) >>> 0;\n var hi = caml_int64_hi32(i64) >>> 0;\n var x = bigInt(lo).add(bigInt(hi).shiftLeft(32));\n if(neg) { x = x.negate() };\n return ml_z_normalize(x)\n}\n\n//external of_float: float -> t\n//Provides: ml_z_of_float\n//Requires: bigInt, caml_raise_constant, caml_named_value, ml_z_normalize\nfunction ml_z_of_float(f1) {\n if(f1 == Infinity || f1 == -Infinity || f1 != f1)\n caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n return ml_z_normalize(bigInt(f1<0?Math.ceil(f1):Math.floor(f1)));\n}\n\n//external to_int: t -> int\n//Provides: ml_z_to_int\n//Requires: bigInt, caml_raise_constant, caml_named_value\nfunction ml_z_to_int(z1) {\n if (z1 == (z1 | 0)) return z1 | 0;\n caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n}\n\n//external to_int32: t -> int32\n//Provides: ml_z_to_int32\n//Requires: ml_z_to_int\nfunction ml_z_to_int32(z1) { return ml_z_to_int(z1) }\n\n//external to_int64: t -> int64\n//Provides: ml_z_to_int64\n//Requires: bigInt, ml_z_fits_int64, caml_raise_constant, caml_named_value\n//Requires: caml_int64_create_lo_hi\nfunction ml_z_to_int64(z1) {\n z1 = bigInt(z1)\n if(!ml_z_fits_int64(z1)) {\n caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n }\n var mask = bigInt(0xffffffff)\n var lo = z1.and(mask).toJSNumber();\n var hi = z1.shiftRight(32).and(mask).toJSNumber();\n var x = caml_int64_create_lo_hi(lo, hi);\n return x;\n}\n\n//external testbit: t -> bool\n//Provides: ml_z_testbit\n//Requires: bigInt\nfunction ml_z_testbit(z,pos){\n z = bigInt(z);\n return (z.shiftRight(pos).and(bigInt(1)).toJSNumber())|0;\n}\n\n//external to_nativeint: t -> nativeint\n//Provides: ml_z_to_nativeint\n//Requires: ml_z_to_int\nfunction ml_z_to_nativeint(z1) { return ml_z_to_int(z1) }\n\n//external format: string -> t -> string\n//Provides: ml_z_format \n//Requires: bigInt\n//Requires: caml_jsbytes_of_string, caml_failwith, caml_string_of_jsbytes, ml_z_normalize\nfunction ml_z_format(fmt, z1) {\n z1 = bigInt(z1);\n var fmt = caml_jsbytes_of_string(fmt);\n // https://github.com/ocaml/Zarith/blob/d0555d451ce295c4497f24a8d9993f8dd23097df/z.mlip#L297\n var base = 10;\n var cas = 0;\n var width = 0;\n var alt = 0;\n var dir = 0;\n var sign = '';\n var pad = ' ';\n var idx = 0;\n var prefix=\"\";\n while(fmt[idx] == '%') idx++;\n for(;; idx++) {\n if(fmt[idx] == '#') alt = 1;\n else if (fmt[idx] == '0') pad = '0';\n else if (fmt[idx] == '-') dir = 1;\n else if (fmt[idx] == ' ' || fmt[idx] == '+') sign = fmt[idx];\n else break;\n }\n if(z1.lt(bigInt(0))){sign = '-';z1 = z1.negate()};\n for(;fmt[idx]>='0' && fmt[idx] <='9';idx++)\n width=10*width + (+fmt[idx]);\n switch(fmt[idx]){\n case 'i': case 'd': case 'u': break;\n case 'b': base = 2; if(alt) prefix = \"0b\"; break;\n case 'o': base = 8; if(alt) prefix = \"0o\"; break;\n case 'x': base = 16; if(alt) prefix = \"0x\"; break;\n case 'X': base = 16; if(alt) prefix = \"0X\"; cas = 1; break;\n default:\n caml_failwith(\"Unsupported format '\" + fmt + \"'\");\n }\n if (dir) pad = ' ';\n var res = z1.toString(base);\n if (cas === 1) {\n res = res.toUpperCase();\n }\n var size = res.length;\n if (pad == ' ') {\n if(dir) {\n res = sign + prefix + res;\n for(;res.length= 48 && code <= 57) return code - 48;\n if(code >= 97 && code <= 102) return code - 97 + 10;\n if(code >= 65 && code <= 70) return code - 65 + 10;\n }\n var i = 0;\n if(s[i] == '-') i++;\n for( ; i < s.length ; i++){\n var c = digit(s.charCodeAt(i));\n if(c == undefined || c >= base)\n caml_invalid_argument(\"Z.of_substring_base: invalid digit\");\n }\n return ml_z_normalize(bigInt(s, base));\n \n}\n\n//external of_substring_base: int -> string -> pos:int -> len:int -> t\n//Provides: ml_z_of_substring_base\n//Requires: jsoo_z_of_js_string_base, caml_jsbytes_of_string, caml_invalid_argument, caml_ml_string_length\nfunction ml_z_of_substring_base(base, s, pos, len) {\n s = caml_jsbytes_of_string(s);\n if(pos != 0 || len != s.length) {\n if (s.length - pos < len) {\n caml_invalid_argument(\"Z.of_substring_base: invalid offset or length\");\n }\n s = s.slice(pos,pos+len);\n }\n return jsoo_z_of_js_string_base(base, s);\n}\n\n//external compare: t -> t -> int\n//Provides: ml_z_compare const\n//Requires: bigInt\nfunction ml_z_compare(z1, z2) {\n return bigInt(z1).compare(bigInt(z2));\n}\n\n//external equal: t -> t -> bool\n//Provides: ml_z_equal const\n//Requires: bigInt\nfunction ml_z_equal(z1, z2) {\n return bigInt(z1).equals(bigInt(z2));\n}\n\n//external sign: t -> int\n//Provides: ml_z_sign const\n//Requires: bigInt\nfunction ml_z_sign(z1) {\n return bigInt(z1).compare(bigInt.zero);\n}\n\n//external gcd: t -> t -> t\n//Provides: ml_z_gcd\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_gcd(z1, z2) {\n return ml_z_normalize(bigInt.gcd(bigInt(z1), bigInt(z2)).abs());\n}\n\n//external numbits: t -> int\n//Provides: ml_z_numbits const\n//Requires: bigInt\nfunction ml_z_numbits(z1) {\n z1 = bigInt(z1).abs();\n var n = 0;\n var upperBound = bigInt.one;\n while (upperBound.leq(z1)) {\n n += 1;\n upperBound = upperBound.multiply(2);\n }\n return n; // 2^{n-1} <= |x| < 2^n\n}\n\n//external fits_int: t -> bool\n//Provides: ml_z_fits_int const\n//Requires: bigInt\nfunction ml_z_fits_int(z1) {\n if(z1 == (z1 | 0)) return 1;\n else return 0;\n}\n\n//external fits_int32: t -> bool\n//Provides: ml_z_fits_int32\n//Requires: ml_z_fits_int\nfunction ml_z_fits_int32(z1) {\n return ml_z_fits_int(z1);\n}\n\n//external fits_int64: t -> bool\n//Provides: ml_z_fits_int64\n//Requires: bigInt\nfunction ml_z_fits_int64(z1) {\n z1 = bigInt(z1)\n if (z1.compare(bigInt(\"9223372036854775807\")) <= 0 && z1.compare(bigInt(\"-9223372036854775808\")) >= 0)\n return 1\n else\n return 0\n}\n\n//external fits_nativeint: t -> bool\n//Provides: ml_z_fits_nativeint\n//Requires: ml_z_fits_int\nfunction ml_z_fits_nativeint(z1) {\n return ml_z_fits_int(z1);\n}\n\n//external powm: t -> t -> t -> t\n//Provides: ml_z_powm\n//Requires: bigInt, ml_z_normalize, ml_z_invert, caml_raise_zero_divide\nfunction ml_z_powm(z1, z2, z3) {\n var zero = bigInt(0);\n var one = bigInt(1);\n z1 = bigInt(z1);\n z2 = bigInt(z2);\n z3 = bigInt(z3);\n if(z3.equals(zero)) caml_raise_zero_divide();\n if(z3.abs().equals(one)) return 0;\n if(z2.equals(zero)) return 1;\n if(z2.lt(0)) {\n var inv = bigInt(ml_z_invert(z1, z3));\n var r = inv.modPow(z2.negate(), z3);\n if(r.lt(zero)) r = r.add(z3.abs());\n return ml_z_normalize(r);\n } else {\n var r = bigInt(z1).modPow(z2, z3);\n if(r.lt(zero)) r = r.add(z3.abs());\n return ml_z_normalize(r);\n }\n}\n\n//external pown: t -> t -> t\n//Provides: ml_z_pow\n//Requires: bigInt, caml_failwith, ml_z_normalize, caml_invalid_argument\nfunction ml_z_pow(z1, i1) {\n i1 = bigInt(i1);\n if (i1.lt(bigInt(0))) {\n caml_invalid_argument(\"Z.pow: exponent must be nonnegative\");\n }\n return ml_z_normalize(bigInt(z1).pow(i1));\n}\n\n//external hash: t -> int\n//Provides: ml_z_hash const\n//Requires: bigInt, caml_hash_mix_int\nfunction ml_z_hash(z1) {\n var a = bigInt(z1).toArray(Math.pow(2, 32));\n var acc = 0;\n for (var i = 0; i < a.value.length; i++) {\n acc = caml_hash_mix_int(acc, a.value[i]);\n }\n if(a.value.length % 2 != 0) {\n acc = caml_hash_mix_int(acc, 0);\n }\n if(a.isNegative){\n acc = acc + 1\n }\n return acc | 0\n}\n\n//external to_bits: t -> string\n//Provides: ml_z_to_bits const\n//Requires: caml_string_of_jsbytes, caml_str_repeat, bigInt\nfunction ml_z_to_bits(z1) {\n z1 = bigInt(z1).abs();\n var res = \"\";\n while(!z1.equals(bigInt(0))){\n res += String.fromCharCode(z1.mod(bigInt(256)));\n z1 = z1.divide(bigInt(256));\n }\n while(res.length % 4 != 0){\n res += String.fromCharCode(0);\n }\n return caml_string_of_jsbytes(res);\n}\n\n//external of_bits: string -> t\n//Provides: ml_z_of_bits const\n//Requires: caml_string_unsafe_get, caml_ml_string_length, bigInt, ml_z_normalize\nfunction ml_z_of_bits(z1) {\n var r = bigInt.zero\n var base1 = bigInt(256);\n var base = bigInt.one;\n for(var i = 0; i < caml_ml_string_length(z1); i++){\n var d = caml_string_unsafe_get(z1,i);\n r = bigInt(base).multiply(d).add(r);\n base = bigInt(base).multiply(base1);\n }\n return ml_z_normalize(r);\n}\n\n//external powm_sec: t -> t -> t -> t\n//Provides: ml_z_powm_sec\n//Requires: bigInt, caml_failwith, ml_z_powm, caml_invalid_argument\nfunction ml_z_powm_sec(z1, z2, z3) {\n z3 = bigInt(z3).abs();\n // powm_sec requires that the exponent be positive\n var one = bigInt(1);\n if (bigInt(z2).lt(one)) {\n caml_invalid_argument(\"Z.powm_sec: exponent must be positive\");\n }\n if (!bigInt(z3).and(one).equals(one)) {\n caml_invalid_argument(\"Z.powm_sec: modulus must be odd\");\n }\n return ml_z_powm(z1, z2, z3)\n}\n\n//external root: t -> int -> t\n//Provides: ml_z_root\n//Requires: ml_z_pow, bigInt, ml_z_normalize, caml_invalid_argument\nfunction ml_z_root(z, i) {\n var zero = bigInt(0);\n var one = bigInt(1);\n z = bigInt(z);\n\n if (i % 2 === 0 && z.lt(zero)) {\n caml_invalid_argument(\"Z.root: even root of a negative number\");\n }\n\n if (z.equals(zero) || z.equals(one)) {\n return ml_z_normalize(z);\n }\n\n var start = zero;\n var end = z;\n var ans = null;\n\n var two = bigInt(2);\n\n while (start.leq(end))\n {\n var mid = start.add(end).divide(two);\n var po = mid.pow(i);\n if (po.equals(z)) {\n return ml_z_normalize(mid);\n } else if (po.lt(z)) {\n start = mid.next();\n ans = mid;\n } else {\n end = mid.prev();\n }\n }\n return ml_z_normalize(ans);\n}\n\n//external invert: t -> t -> t\n//Provides: ml_z_invert\n//Requires: bigInt, caml_raise_zero_divide, ml_z_gcdext_intern, ml_z_normalize\nfunction ml_z_invert(a, n) {\n // Because [a.modInv(n)] produces different results for edge cases,\n // we wrote our own implementation based on gcdext_intern.\n a = bigInt(a);\n n = bigInt(n);\n var zero = bigInt(0);\n var one = bigInt(1);\n if(n.abs().equals(one))\n return 0;\n if (n.equals(zero) && a.abs().equals(one)) {\n return a;\n }\n if (n.equals(zero) || a.equals(zero)) {\n caml_raise_zero_divide();\n }\n var x = ml_z_gcdext_intern(a, n);\n var r = bigInt(x[2]);\n var tmp = bigInt(a).multiply(r).mod(n);\n if(tmp.lt(zero)) tmp = tmp.add(n.abs());\n if(r.lt(zero)) r = r.add(n.abs());\n if(tmp.equals(one)) {\n return ml_z_normalize(r);\n }\n caml_raise_zero_divide();\n}\n\n//external perfect_power: t -> bool\n//Provides: ml_z_perfect_power\n//Requires: bigInt, caml_failwith, ml_z_numbits, ml_z_root, ml_z_pow\nfunction ml_z_perfect_power(z) {\n // Return true if op is a perfect power, i.e., if there exist integers a and\n // b, with b > 1, such that op = a^b.\n // Otherwise false.\n z = bigInt(z);\n var zero = bigInt(0);\n var one = bigInt(1);\n\n if (z.equals(zero) || z.equals(one) || z.equals(one.negate())) {\n return 1;\n }\n var log2z = ml_z_numbits(z.abs());\n for (var b = 2; b <= log2z; b++) {\n if(z.lt(zero) && b % 2 == 0) continue;\n var zp = z.abs();\n var p = bigInt(ml_z_root(zp, b));\n if(z.lt(zero)) p = p.negate();\n var r = bigInt(ml_z_pow(p, b));\n if (z.equals(r)) {\n return 1;\n }\n }\n return 0;\n}\n\n//external perfect_square: t -> bool\n//Provides: ml_z_perfect_square\n//Requires: bigInt, ml_z_root\nfunction ml_z_perfect_square(z) {\n z = bigInt(z);\n if (z.lt(bigInt(0))) {\n return 0;\n }\n var root = bigInt(ml_z_root(z, 2));\n if (root.multiply(root).eq(z)) {\n return 1;\n }\n else {\n return 0\n };\n}\n\n//external probab_prime: t -> int -> int\n//Provides: ml_z_probab_prime const\n//Requires: bigInt\nfunction ml_z_probab_prime(z, i) {\n if (bigInt(z).isProbablePrime(i)) {\n return 1;\n } else {\n return 0;\n }\n}\n\n//external nextprime: t -> t\n//Provides: ml_z_nextprime const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_nextprime(z1) {\n // Interestingly, the zarith next_prime only returns \n // probabalistic primes. We do the same, with the \n // same probablistic parameter of 25.\n // https://fossies.org/dox/gmp-6.1.2/mpz_2nextprime_8c_source.html\n \n z1 = bigInt(z1)\n var one = bigInt(1);\n var two = bigInt(2);\n\n if (z1.lt(one) || z1.equals(one)) {\n return 2;\n }\n\n if (z1.and(one).equals(one)) {\n z1 = z1.add(two);\n } else {\n z1 = z1.add(one);\n }\n\n while (true) {\n if (z1.isProbablePrime(25)) {\n return ml_z_normalize(z1);\n } else {\n z1 = z1.add(two)\n }\n }\n}\n\n//external extract: t -> int -> int -> t\n//Provides: ml_z_extract\n//Requires: caml_failwith, bigInt, ml_z_normalize\nfunction ml_z_extract(z1, pos, len) {\n z1 = bigInt(z1);\n return ml_z_normalize(z1.shiftRight(pos).and(bigInt(2).pow(len).subtract(1)));\n}\n\n//external gcdext_intern: t -> t -> (t * t * bool)\n//Provides: ml_z_gcdext_intern\n//Requires: bigInt, caml_raise_zero_divide, ml_z_normalize\nfunction ml_z_gcdext_intern(z1, z2) {\n z1 = bigInt(z1);\n z2 = bigInt(z2);\n var gcd = bigInt.gcd(z1,z2);\n var a = z1;\n var b = z2;\n var x = bigInt(0);\n var lastx = bigInt(1);\n var y = bigInt(1);\n var lasty = bigInt(1);\n var q, t, r;\n if(z1.equals(bigInt(0))) {\n caml_raise_zero_divide();\n }\n while(!b.equals(bigInt(0))) {\n q = a.divide(b);\n r = a.subtract(q.multiply(b));\n t = x;\n x = lastx.subtract(q.multiply(x));\n lastx = t;\n t = y;\n y = lasty.subtract(q.multiply(y));\n lasty = t;\n a = b;\n b = r;\n }\n if(a.lt(bigInt(0)))\n return [0,ml_z_normalize(a.negate()),ml_z_normalize(lastx.negate()),1]\n else\n return [0,ml_z_normalize(a),ml_z_normalize(lastx),1]\n}\n\n//external sqrt: t -> t\n//Provides: ml_z_sqrt\n//Requires: bigInt, ml_z_root, caml_invalid_argument\nfunction ml_z_sqrt(z1) {\n var z = bigInt(z1);\n var zero = bigInt(0);\n if (z.lt(zero)) {\n caml_invalid_argument(\"Z.sqrt: square root of a negative number\");\n }\n return ml_z_root(z, 2);\n}\n\n//external sqrt_rem: t -> (t * t)\n//Provides: ml_z_sqrt_rem\n//Requires: bigInt, ml_z_root, caml_invalid_argument, ml_z_normalize\nfunction ml_z_sqrt_rem(z) {\n z = bigInt(z);\n var zero = bigInt(0);\n if (z.lt(zero)) {\n caml_invalid_argument(\"Z.sqrt_rem: square root of a negative number\");\n }\n var root = bigInt(ml_z_root(z, 2));\n var mul = root.multiply(root);\n var diff = z.subtract(mul);\n return [0, ml_z_normalize(root), ml_z_normalize(diff)]\n}\n\n//external trailing_zeros: t -> int\n//Provides: ml_z_trailing_zeros const\n//Requires: bigInt\nfunction ml_z_trailing_zeros(z) {\n z = bigInt(z).abs();\n var zero = bigInt(0);\n var one = bigInt(1);\n if (z.equals(zero)) {\n // max_int in 32bit\n return 0x7fffffff;\n }\n var i = 0\n z = z.xor(z.prev()).shiftRight(1);\n for (i = 0; !z.equals(bigInt.zero); i++) {\n z = z.shiftRight(1);\n }\n return i;\n}\n\n//external popcount: t -> int\n//Provides: ml_z_popcount\n//Requires: bigInt, caml_raise_constant, caml_named_value\nfunction ml_z_popcount(z) {\n z = bigInt(z);\n var zero = bigInt(0);\n var one = bigInt(1);\n if (z.lt(zero)) {\n caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n }\n var i;\n for (i = 0; !z.equals(zero); i++) {\n z = z.and(z.prev());\n }\n if(i != (i|0)) caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n return i|0;\n}\n\n//external hamdist: t -> t -> int\n//Provides: ml_z_hamdist\n//Requires: bigInt, ml_z_popcount, caml_invalid_argument, caml_raise_constant, caml_named_value\nfunction ml_z_hamdist(z1, z2) {\n if(bigInt(z1).isNegative() != bigInt(z2).isNegative ()){\n caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n }\n if((z1 != (z1 | 0) || z2 != (z2 | 0)) && (bigInt(z1).isNegative() || bigInt(z2).isNegative ())){\n caml_invalid_argument(\"Z.hamdist: negative arguments\");\n }\n return ml_z_popcount(bigInt(z1).xor(bigInt(z2)));\n}\n\n//external size: t -> int\n//Provides: ml_z_size const\n//Requires: bigInt\nfunction ml_z_size(z1) {\n // Claim to be a 32-bit architecture.\n return bigInt(z1).toArray(Math.pow(2, 32)).value.length;\n}\n\n//external divexact: t -> t -> t\n//Provides: ml_z_divexact\n//Requires: bigInt, ml_z_div\nfunction ml_z_divexact(z1, z2) {\n return ml_z_div(z1, z2);\n}\n\n//Provides: caml_zarith_marshal\n//Requires: bigInt\nfunction caml_zarith_marshal(writer, v, sz) {\n v = bigInt(v);\n var bits = v.toArray(Math.pow(2, 32));\n writer.write(8, bits.isNegative ?1 : 0);\n var block = bits.value.length;\n var len = block * 4;\n writer.write(32, len);\n for(var i = block - 1; i >= 0; i --){\n writer.write(8, (bits.value[i] >>> 0 ) & 0xff);\n writer.write(8, (bits.value[i] >>> 8 ) & 0xff);\n writer.write(8, (bits.value[i] >>> 16) & 0xff);\n writer.write(8, (bits.value[i] >>> 24) & 0xff);\n }\n sz[0] = 4 * (1 + (((len + 3) / 4) | 0));\n sz[1] = 8 * (1 + (((len + 7) / 8) | 0));\n}\n\n//Provides: caml_zarith_unmarshal\n//Requires: bigInt, caml_failwith, ml_z_normalize\nfunction caml_zarith_unmarshal(reader, sz) {\n var negate;\n switch(reader.read8u ()) {\n case 1: negate = true; break;\n case 0: negate = false; break;\n default: caml_failwith(\"input_value: z (malformed input)\");\n }\n var len = reader.read32u();\n var x = bigInt(0);\n for(var i = 0; i < len / 4; i++){\n var y = bigInt(reader.read8u());\n y = y.add((reader.read8u()) << 8);\n y = y.add((reader.read8u()) << 16);\n y = y.add(((reader.read8u()) << 24) >>> 0);\n x = y.shiftLeft(i * 32).add(x);\n }\n if(negate) x = x.negate();\n sz[0] = len + 4;\n return ml_z_normalize(x)\n}\n","///////// TIME_NOW\n\n//Provides: time_now_nanoseconds_since_unix_epoch_or_zero\n//Requires: caml_int64_mul, caml_int64_of_float, caml_int64_of_int32\nvar ms_to_nano = caml_int64_of_int32(1000*1000);\nfunction time_now_nanoseconds_since_unix_epoch_or_zero(){\n var ms = Date.now();\n // multiple by two - int63 integers are shifted to the left\n var ms_i63 = caml_int64_of_float(ms*2);\n return caml_int64_mul(ms_i63,ms_to_nano);\n}\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Operations on internal representations of values *)\n\ntype t\n\ntype raw_data = nativeint\n\nexternal repr : 'a -> t = \"%identity\"\nexternal obj : t -> 'a = \"%identity\"\nexternal magic : 'a -> 'b = \"%identity\"\nexternal is_int : t -> bool = \"%obj_is_int\"\nlet [@inline always] is_block a = not (is_int a)\nexternal tag : t -> int = \"caml_obj_tag\" [@@noalloc]\nexternal set_tag : t -> int -> unit = \"caml_obj_set_tag\"\nexternal size : t -> int = \"%obj_size\"\nexternal reachable_words : t -> int = \"caml_obj_reachable_words\"\nexternal field : t -> int -> t = \"%obj_field\"\nexternal set_field : t -> int -> t -> unit = \"%obj_set_field\"\nexternal floatarray_get : floatarray -> int -> float = \"caml_floatarray_get\"\nexternal floatarray_set :\n floatarray -> int -> float -> unit = \"caml_floatarray_set\"\nlet [@inline always] double_field x i = floatarray_get (obj x : floatarray) i\nlet [@inline always] set_double_field x i v =\n floatarray_set (obj x : floatarray) i v\nexternal raw_field : t -> int -> raw_data = \"caml_obj_raw_field\"\nexternal set_raw_field : t -> int -> raw_data -> unit\n = \"caml_obj_set_raw_field\"\n\nexternal new_block : int -> int -> t = \"caml_obj_block\"\nexternal dup : t -> t = \"caml_obj_dup\"\nexternal truncate : t -> int -> unit = \"caml_obj_truncate\"\nexternal add_offset : t -> Int32.t -> t = \"caml_obj_add_offset\"\nexternal with_tag : int -> t -> t = \"caml_obj_with_tag\"\n\nlet first_non_constant_constructor_tag = 0\nlet last_non_constant_constructor_tag = 245\n\nlet lazy_tag = 246\nlet closure_tag = 247\nlet object_tag = 248\nlet infix_tag = 249\nlet forward_tag = 250\n\nlet no_scan_tag = 251\n\nlet abstract_tag = 251\nlet string_tag = 252\nlet double_tag = 253\nlet double_array_tag = 254\nlet custom_tag = 255\nlet final_tag = custom_tag\n\n\nlet int_tag = 1000\nlet out_of_heap_tag = 1001\nlet unaligned_tag = 1002\n\nmodule Closure = struct\n type info = {\n arity: int;\n start_env: int;\n }\n\n let info_of_raw (info : nativeint) =\n let open Nativeint in\n let arity =\n (* signed: negative for tupled functions *)\n if Sys.word_size = 64 then\n to_int (shift_right info 56)\n else\n to_int (shift_right info 24)\n in\n let start_env =\n (* start_env is unsigned, but we know it can always fit an OCaml\n integer so we use [to_int] instead of [unsigned_to_int]. *)\n to_int (shift_right_logical (shift_left info 8) 9) in\n { arity; start_env }\n\n (* note: we expect a closure, not an infix pointer *)\n let info (obj : t) =\n assert (tag obj = closure_tag);\n info_of_raw (raw_field obj 1)\nend\n\nmodule Extension_constructor =\nstruct\n type t = extension_constructor\n let of_val x =\n let x = repr x in\n let slot =\n if (is_block x) && (tag x) <> object_tag && (size x) >= 1 then field x 0\n else x\n in\n let name =\n if (is_block slot) && (tag slot) = object_tag then field slot 0\n else invalid_arg \"Obj.extension_constructor\"\n in\n if (tag name) = string_tag then (obj slot : t)\n else invalid_arg \"Obj.extension_constructor\"\n\n let [@inline always] name (slot : t) =\n (obj (field (repr slot) 0) : string)\n\n let [@inline always] id (slot : t) =\n (obj (field (repr slot) 1) : int)\nend\n\nlet extension_constructor = Extension_constructor.of_val\nlet extension_name = Extension_constructor.name\nlet extension_id = Extension_constructor.id\n\nmodule Ephemeron = struct\n type obj_t = t\n\n type t (** ephemeron *)\n\n (** To change in sync with weak.h *)\n let additional_values = 2\n let max_ephe_length = Sys.max_array_length - additional_values\n\n external create : int -> t = \"caml_ephe_create\";;\n let create l =\n if not (0 <= l && l <= max_ephe_length) then\n invalid_arg \"Obj.Ephemeron.create\";\n create l\n\n let length x = size(repr x) - additional_values\n\n let raise_if_invalid_offset e o msg =\n if not (0 <= o && o < length e) then\n invalid_arg msg\n\n external get_key: t -> int -> obj_t option = \"caml_ephe_get_key\"\n let get_key e o =\n raise_if_invalid_offset e o \"Obj.Ephemeron.get_key\";\n get_key e o\n\n external get_key_copy: t -> int -> obj_t option = \"caml_ephe_get_key_copy\"\n let get_key_copy e o =\n raise_if_invalid_offset e o \"Obj.Ephemeron.get_key_copy\";\n get_key_copy e o\n\n external set_key: t -> int -> obj_t -> unit = \"caml_ephe_set_key\"\n let set_key e o x =\n raise_if_invalid_offset e o \"Obj.Ephemeron.set_key\";\n set_key e o x\n\n external unset_key: t -> int -> unit = \"caml_ephe_unset_key\"\n let unset_key e o =\n raise_if_invalid_offset e o \"Obj.Ephemeron.unset_key\";\n unset_key e o\n\n external check_key: t -> int -> bool = \"caml_ephe_check_key\"\n let check_key e o =\n raise_if_invalid_offset e o \"Obj.Ephemeron.check_key\";\n check_key e o\n\n external blit_key : t -> int -> t -> int -> int -> unit\n = \"caml_ephe_blit_key\"\n\n let blit_key e1 o1 e2 o2 l =\n if l < 0 || o1 < 0 || o1 > length e1 - l\n || o2 < 0 || o2 > length e2 - l\n then invalid_arg \"Obj.Ephemeron.blit_key\"\n else if l <> 0 then blit_key e1 o1 e2 o2 l\n\n external get_data: t -> obj_t option = \"caml_ephe_get_data\"\n external get_data_copy: t -> obj_t option = \"caml_ephe_get_data_copy\"\n external set_data: t -> obj_t -> unit = \"caml_ephe_set_data\"\n external unset_data: t -> unit = \"caml_ephe_unset_data\"\n external check_data: t -> bool = \"caml_ephe_check_data\"\n external blit_data : t -> t -> unit = \"caml_ephe_blit_data\"\n\nend\n","open Core_kernel\nopen Pickles_types\n\ntype 'n t = (Int64.t, 'n) Vector.t [@@deriving sexp_of]\n\nlet to_bits t =\n Vector.to_list t\n |> List.concat_map ~f:(fun n ->\n let test_bit i = Int64.(shift_right n i land one = one) in\n List.init 64 ~f:test_bit )\n\nmodule Hex64 = struct\n module T = struct\n type t = Int64.t [@@deriving yojson]\n\n (* Modify the [of_yojson] handler to add a case for [`String].\n This isn't necessary when using Yojson's parser, because it will\n correctly infer [`Intlit] for any possible value that appears here.\n However, if this json was constructed from a GraphQL query then it will\n be encoded as a [`String] and the conversion will fail unless we handle\n it ourselves.\n *)\n let of_yojson yojson =\n match yojson with\n | `String x -> (\n try Result.Ok (Int64.of_string x)\n with _ -> Result.Error \"Constant.Make.Hex64.t\" )\n | _ ->\n of_yojson yojson\n\n include (Int64 : module type of Int64 with type t := t)\n\n let to_hex t =\n let lo = t land of_int 0xffffff in\n let mi = (t lsr 24) land of_int 0xffffff in\n let hi = (t lsr 48) land of_int 0xffff in\n sprintf \"%04x%06x%06x\" (to_int_exn hi) (to_int_exn mi) (to_int_exn lo)\n\n let of_hex h =\n let f s = Hex.of_string (\"0x\" ^ s) in\n let hi, lo = String.(f (sub h ~pos:0 ~len:8), f (sub h ~pos:8 ~len:8)) in\n (hi lsl 32) lor lo\n\n let%test_unit \"int64 hex\" =\n Quickcheck.test (Int64.gen_incl zero max_value) ~f:(fun x ->\n assert (equal x (of_hex (to_hex x))) )\n\n let sexp_of_t = Fn.compose String.sexp_of_t to_hex\n\n let t_of_sexp = Fn.compose of_hex String.t_of_sexp\n end\n\n include T\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t = (T.t[@version_asserted])\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Make (N : Pickles_types.Nat.Intf) = struct\n module A = Vector.With_length (N)\n\n let length = 64 * Nat.to_int N.n\n\n type t = Hex64.t A.t [@@deriving sexp, compare, yojson, hash, equal]\n\n let to_bits = to_bits\n\n let of_bits bits =\n let pack =\n List.foldi ~init:Int64.zero ~f:(fun i acc b ->\n if b then Int64.(acc lor shift_left one i) else acc )\n in\n let bits =\n List.groupi ~break:(fun i _ _ -> i mod 64 = 0) bits |> List.map ~f:pack\n in\n let n = List.length bits in\n let n_expected = Nat.to_int N.n in\n assert (n <= n_expected) ;\n let bits = bits @ List.init (n_expected - n) ~f:(fun _ -> Int64.zero) in\n Vector.of_list_and_length_exn bits N.n\n\n let of_tick_field x =\n of_bits (List.take (Backend.Tick.Field.to_bits x) length)\n\n let of_tock_field x =\n of_bits (List.take (Backend.Tock.Field.to_bits x) length)\n\n let to_tick_field t = Backend.Tick.Field.of_bits (to_bits t)\n\n let to_tock_field t = Backend.Tock.Field.of_bits (to_bits t)\n\n let dummy : t = Vector.init N.n ~f:(fun _ -> Int64.one)\n\n let zero : t = Vector.init N.n ~f:(fun _ -> Int64.zero)\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Int64]: 64-bit integers *)\n\nexternal neg : int64 -> int64 = \"%int64_neg\"\nexternal add : int64 -> int64 -> int64 = \"%int64_add\"\nexternal sub : int64 -> int64 -> int64 = \"%int64_sub\"\nexternal mul : int64 -> int64 -> int64 = \"%int64_mul\"\nexternal div : int64 -> int64 -> int64 = \"%int64_div\"\nexternal rem : int64 -> int64 -> int64 = \"%int64_mod\"\nexternal logand : int64 -> int64 -> int64 = \"%int64_and\"\nexternal logor : int64 -> int64 -> int64 = \"%int64_or\"\nexternal logxor : int64 -> int64 -> int64 = \"%int64_xor\"\nexternal shift_left : int64 -> int -> int64 = \"%int64_lsl\"\nexternal shift_right : int64 -> int -> int64 = \"%int64_asr\"\nexternal shift_right_logical : int64 -> int -> int64 = \"%int64_lsr\"\nexternal of_int : int -> int64 = \"%int64_of_int\"\nexternal to_int : int64 -> int = \"%int64_to_int\"\nexternal of_float : float -> int64\n = \"caml_int64_of_float\" \"caml_int64_of_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal to_float : int64 -> float\n = \"caml_int64_to_float\" \"caml_int64_to_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal of_int32 : int32 -> int64 = \"%int64_of_int32\"\nexternal to_int32 : int64 -> int32 = \"%int64_to_int32\"\nexternal of_nativeint : nativeint -> int64 = \"%int64_of_nativeint\"\nexternal to_nativeint : int64 -> nativeint = \"%int64_to_nativeint\"\n\nlet zero = 0L\nlet one = 1L\nlet minus_one = -1L\nlet succ n = add n 1L\nlet pred n = sub n 1L\nlet abs n = if n >= 0L then n else neg n\nlet min_int = 0x8000000000000000L\nlet max_int = 0x7FFFFFFFFFFFFFFFL\nlet lognot n = logxor n (-1L)\n\nlet unsigned_to_int =\n let max_int = of_int Stdlib.max_int in\n fun n ->\n if compare zero n <= 0 && compare n max_int <= 0 then\n Some (to_int n)\n else\n None\n\nexternal format : string -> int64 -> string = \"caml_int64_format\"\nlet to_string n = format \"%d\" n\n\nexternal of_string : string -> int64 = \"caml_int64_of_string\"\n\nlet of_string_opt s =\n (* TODO: expose a non-raising primitive directly. *)\n try Some (of_string s)\n with Failure _ -> None\n\n\n\nexternal bits_of_float : float -> int64\n = \"caml_int64_bits_of_float\" \"caml_int64_bits_of_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal float_of_bits : int64 -> float\n = \"caml_int64_float_of_bits\" \"caml_int64_float_of_bits_unboxed\"\n [@@unboxed] [@@noalloc]\n\ntype t = int64\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nlet equal (x: t) (y: t) = compare x y = 0\n\nlet unsigned_compare n m =\n compare (sub n min_int) (sub m min_int)\n\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\n\n(* Unsigned division from signed division of the same\n bitness. See Warren Jr., Henry S. (2013). Hacker's Delight (2 ed.), Sec 9-3.\n*)\nlet unsigned_div n d =\n if d < zero then\n if unsigned_compare n d < 0 then zero else one\n else\n let q = shift_left (div (shift_right_logical n 1) d) 1 in\n let r = sub n (mul q d) in\n if unsigned_compare r d >= 0 then succ q else q\n\nlet unsigned_rem n d =\n sub n (mul (unsigned_div n d) d)\n","open! Import\nmodule Array = Array0\nmodule Int = Int0\nmodule Char = Char0\n\n(* Unfortunately, because the standard library does not expose\n [Caml.Random.State.default], we have to construct our own. We then build the\n [Caml.Random.int], [Caml.Random.bool] functions and friends using that default state in\n exactly the same way as the standard library.\n\n One other trickiness is that we need access to the unexposed [Caml.Random.State.assign]\n function, which accesses the unexposed state representation. So, we copy the\n [State.repr] type definition and [assign] function to here from the standard library,\n and use [Obj.magic] to get access to the underlying implementation. *)\n\n(* Regression tests ought to be deterministic because that way anyone who breaks the test\n knows that it's their code that broke the test. If tests are nondeterministic, a test\n failure may instead happen because the test runner got unlucky and uncovered an\n existing bug in the code supposedly being \"protected\" by the test in question. *)\nlet forbid_nondeterminism_in_tests ~allow_in_tests =\n if am_testing\n then (\n match allow_in_tests with\n | Some true -> ()\n | None | Some false ->\n failwith\n \"initializing Random with a nondeterministic seed is forbidden in inline tests\")\n;;\n\nexternal random_seed : unit -> int array = \"caml_sys_random_seed\"\n\nlet random_seed ?allow_in_tests () =\n forbid_nondeterminism_in_tests ~allow_in_tests;\n random_seed ()\n;;\n\nmodule State = struct\n (* We allow laziness only for the definition of [default], below, which may lazily call\n [make_self_init]. For all other purposes, we create and use [t] eagerly. *)\n type t = Caml.Random.State.t Lazy.t\n\n let bits t = Caml.Random.State.bits (Lazy.force t)\n let bool t = Caml.Random.State.bool (Lazy.force t)\n let int t x = Caml.Random.State.int (Lazy.force t) x\n let int32 t x = Caml.Random.State.int32 (Lazy.force t) x\n let int64 t x = Caml.Random.State.int64 (Lazy.force t) x\n let nativeint t x = Caml.Random.State.nativeint (Lazy.force t) x\n let make seed = Lazy.from_val (Caml.Random.State.make seed)\n let copy t = Lazy.from_val (Caml.Random.State.copy (Lazy.force t))\n let char t = int t 256 |> Char.unsafe_of_int\n let ascii t = int t 128 |> Char.unsafe_of_int\n\n let make_self_init ?allow_in_tests () =\n forbid_nondeterminism_in_tests ~allow_in_tests;\n Lazy.from_val (Caml.Random.State.make_self_init ())\n ;;\n\n module Repr = struct\n type t =\n { st : int array\n ; mutable idx : int\n }\n\n let of_state : Caml.Random.State.t -> t = Caml.Obj.magic\n end\n\n let assign t1 t2 =\n let t1 = Repr.of_state (Lazy.force t1) in\n let t2 = Repr.of_state (Lazy.force t2) in\n Array.blit ~src:t2.st ~src_pos:0 ~dst:t1.st ~dst_pos:0 ~len:(Array.length t1.st);\n t1.idx <- t2.idx\n ;;\n\n let full_init t seed = assign t (make seed)\n\n let default =\n if am_testing\n then (\n (* We define Base's default random state as a copy of OCaml's default random state.\n This means that programs that use Base.Random will see the same sequence of\n random bits as if they had used Caml.Random. However, because [get_state] returns\n a copy, Base.Random and OCaml.Random are not using the same state. If a program\n used both, each of them would go through the same sequence of random bits. To\n avoid that, we reset OCaml's random state to a different seed, giving it a\n different sequence. *)\n let t = Caml.Random.get_state () in\n Caml.Random.init 137;\n Lazy.from_val t)\n else\n lazy\n (* Outside of tests, we initialize random state nondeterministically and lazily.\n We force the random initialization to be lazy so that we do not pay any cost\n for it in programs that do not use randomness. *)\n (Lazy.force (make_self_init ()))\n ;;\n\n let int_on_64bits t bound =\n if bound <= 0x3FFFFFFF (* (1 lsl 30) - 1 *)\n then int t bound\n else Caml.Int64.to_int (int64 t (Caml.Int64.of_int bound))\n ;;\n\n let int_on_32bits t bound =\n (* Not always true with the JavaScript backend. *)\n if bound <= 0x3FFFFFFF (* (1 lsl 30) - 1 *)\n then int t bound\n else Caml.Int32.to_int (int32 t (Caml.Int32.of_int bound))\n ;;\n\n let int =\n match Word_size.word_size with\n | W64 -> int_on_64bits\n | W32 -> int_on_32bits\n ;;\n\n let full_range_int64 =\n let open Caml.Int64 in\n let bits state = of_int (bits state) in\n fun state ->\n logxor\n (bits state)\n (logxor (shift_left (bits state) 30) (shift_left (bits state) 60))\n ;;\n\n let full_range_int32 =\n let open Caml.Int32 in\n let bits state = of_int (bits state) in\n fun state -> logxor (bits state) (shift_left (bits state) 30)\n ;;\n\n let full_range_int_on_64bits state = Caml.Int64.to_int (full_range_int64 state)\n let full_range_int_on_32bits state = Caml.Int32.to_int (full_range_int32 state)\n\n let full_range_int =\n match Word_size.word_size with\n | W64 -> full_range_int_on_64bits\n | W32 -> full_range_int_on_32bits\n ;;\n\n let full_range_nativeint_on_64bits state =\n Caml.Int64.to_nativeint (full_range_int64 state)\n ;;\n\n let full_range_nativeint_on_32bits state =\n Caml.Nativeint.of_int32 (full_range_int32 state)\n ;;\n\n let full_range_nativeint =\n match Word_size.word_size with\n | W64 -> full_range_nativeint_on_64bits\n | W32 -> full_range_nativeint_on_32bits\n ;;\n\n let raise_crossed_bounds name lower_bound upper_bound string_of_bound =\n Printf.failwithf\n \"Random.%s: crossed bounds [%s > %s]\"\n name\n (string_of_bound lower_bound)\n (string_of_bound upper_bound)\n ()\n [@@cold] [@@inline never] [@@local never] [@@specialise never]\n ;;\n\n let int_incl =\n let rec in_range state lo hi =\n let int = full_range_int state in\n if int >= lo && int <= hi then int else in_range state lo hi\n in\n fun state lo hi ->\n if lo > hi then raise_crossed_bounds \"int\" lo hi Int.to_string;\n let diff = hi - lo in\n if diff = Int.max_value\n then lo + (full_range_int state land Int.max_value)\n else if diff >= 0\n then lo + int state (Int.succ diff)\n else in_range state lo hi\n ;;\n\n let int32_incl =\n let open Int32_replace_polymorphic_compare in\n let rec in_range state lo hi =\n let int = full_range_int32 state in\n if int >= lo && int <= hi then int else in_range state lo hi\n in\n let open Caml.Int32 in\n fun state lo hi ->\n if lo > hi then raise_crossed_bounds \"int32\" lo hi to_string;\n let diff = sub hi lo in\n if diff = max_int\n then add lo (logand (full_range_int32 state) max_int)\n else if diff >= 0l\n then add lo (int32 state (succ diff))\n else in_range state lo hi\n ;;\n\n let nativeint_incl =\n let open Nativeint_replace_polymorphic_compare in\n let rec in_range state lo hi =\n let int = full_range_nativeint state in\n if int >= lo && int <= hi then int else in_range state lo hi\n in\n let open Caml.Nativeint in\n fun state lo hi ->\n if lo > hi then raise_crossed_bounds \"nativeint\" lo hi to_string;\n let diff = sub hi lo in\n if diff = max_int\n then add lo (logand (full_range_nativeint state) max_int)\n else if diff >= 0n\n then add lo (nativeint state (succ diff))\n else in_range state lo hi\n ;;\n\n let int64_incl =\n let open Int64_replace_polymorphic_compare in\n let rec in_range state lo hi =\n let int = full_range_int64 state in\n if int >= lo && int <= hi then int else in_range state lo hi\n in\n let open Caml.Int64 in\n fun state lo hi ->\n if lo > hi then raise_crossed_bounds \"int64\" lo hi to_string;\n let diff = sub hi lo in\n if diff = max_int\n then add lo (logand (full_range_int64 state) max_int)\n else if diff >= 0L\n then add lo (int64 state (succ diff))\n else in_range state lo hi\n ;;\n\n (* Return a uniformly random float in [0, 1). *)\n let rec rawfloat state =\n let open Float_replace_polymorphic_compare in\n let scale = 0x1p-30 in\n (* 2^-30 *)\n let r1 = Caml.float_of_int (bits state) in\n let r2 = Caml.float_of_int (bits state) in\n let result = ((r1 *. scale) +. r2) *. scale in\n (* With very small probability, result can round up to 1.0, so in that case, we just\n try again. *)\n if result < 1.0 then result else rawfloat state\n ;;\n\n let float state hi = rawfloat state *. hi\n\n let float_range state lo hi =\n let open Float_replace_polymorphic_compare in\n if lo > hi then raise_crossed_bounds \"float\" lo hi Caml.string_of_float;\n lo +. float state (hi -. lo)\n ;;\nend\n\nlet default = State.default\nlet bits () = State.bits default\nlet int x = State.int default x\nlet int32 x = State.int32 default x\nlet nativeint x = State.nativeint default x\nlet int64 x = State.int64 default x\nlet float x = State.float default x\nlet int_incl x y = State.int_incl default x y\nlet int32_incl x y = State.int32_incl default x y\nlet nativeint_incl x y = State.nativeint_incl default x y\nlet int64_incl x y = State.int64_incl default x y\nlet float_range x y = State.float_range default x y\nlet bool () = State.bool default\nlet char () = State.char default\nlet ascii () = State.ascii default\nlet full_init seed = State.full_init default seed\nlet init seed = full_init [| seed |]\nlet self_init ?allow_in_tests () = full_init (random_seed ?allow_in_tests ())\nlet set_state s = State.assign default s\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* The run-time library for lexers generated by camllex *)\n\ntype position = {\n pos_fname : string;\n pos_lnum : int;\n pos_bol : int;\n pos_cnum : int;\n}\n\nlet dummy_pos = {\n pos_fname = \"\";\n pos_lnum = 0;\n pos_bol = 0;\n pos_cnum = -1;\n}\n\ntype lexbuf =\n { refill_buff : lexbuf -> unit;\n mutable lex_buffer : bytes;\n mutable lex_buffer_len : int;\n mutable lex_abs_pos : int;\n mutable lex_start_pos : int;\n mutable lex_curr_pos : int;\n mutable lex_last_pos : int;\n mutable lex_last_action : int;\n mutable lex_eof_reached : bool;\n mutable lex_mem : int array;\n mutable lex_start_p : position;\n mutable lex_curr_p : position;\n }\n\ntype lex_tables =\n { lex_base: string;\n lex_backtrk: string;\n lex_default: string;\n lex_trans: string;\n lex_check: string;\n lex_base_code : string;\n lex_backtrk_code : string;\n lex_default_code : string;\n lex_trans_code : string;\n lex_check_code : string;\n lex_code: string;}\n\nexternal c_engine : lex_tables -> int -> lexbuf -> int = \"caml_lex_engine\"\nexternal c_new_engine : lex_tables -> int -> lexbuf -> int\n = \"caml_new_lex_engine\"\n\nlet engine tbl state buf =\n let result = c_engine tbl state buf in\n if result >= 0 && buf.lex_curr_p != dummy_pos then begin\n buf.lex_start_p <- buf.lex_curr_p;\n buf.lex_curr_p <- {buf.lex_curr_p\n with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n end;\n result\n\n\nlet new_engine tbl state buf =\n let result = c_new_engine tbl state buf in\n if result >= 0 && buf.lex_curr_p != dummy_pos then begin\n buf.lex_start_p <- buf.lex_curr_p;\n buf.lex_curr_p <- {buf.lex_curr_p\n with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n end;\n result\n\nlet lex_refill read_fun aux_buffer lexbuf =\n let read =\n read_fun aux_buffer (Bytes.length aux_buffer) in\n let n =\n if read > 0\n then read\n else (lexbuf.lex_eof_reached <- true; 0) in\n (* Current state of the buffer:\n <-------|---------------------|----------->\n | junk | valid data | junk |\n ^ ^ ^ ^\n 0 start_pos buffer_end Bytes.length buffer\n *)\n if lexbuf.lex_buffer_len + n > Bytes.length lexbuf.lex_buffer then begin\n (* There is not enough space at the end of the buffer *)\n if lexbuf.lex_buffer_len - lexbuf.lex_start_pos + n\n <= Bytes.length lexbuf.lex_buffer\n then begin\n (* But there is enough space if we reclaim the junk at the beginning\n of the buffer *)\n Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos\n lexbuf.lex_buffer 0\n (lexbuf.lex_buffer_len - lexbuf.lex_start_pos)\n end else begin\n (* We must grow the buffer. Doubling its size will provide enough\n space since n <= String.length aux_buffer <= String.length buffer.\n Watch out for string length overflow, though. *)\n let newlen =\n Int.min (2 * Bytes.length lexbuf.lex_buffer) Sys.max_string_length in\n if lexbuf.lex_buffer_len - lexbuf.lex_start_pos + n > newlen\n then failwith \"Lexing.lex_refill: cannot grow buffer\";\n let newbuf = Bytes.create newlen in\n (* Copy the valid data to the beginning of the new buffer *)\n Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos\n newbuf 0\n (lexbuf.lex_buffer_len - lexbuf.lex_start_pos);\n lexbuf.lex_buffer <- newbuf\n end;\n (* Reallocation or not, we have shifted the data left by\n start_pos characters; update the positions *)\n let s = lexbuf.lex_start_pos in\n lexbuf.lex_abs_pos <- lexbuf.lex_abs_pos + s;\n lexbuf.lex_curr_pos <- lexbuf.lex_curr_pos - s;\n lexbuf.lex_start_pos <- 0;\n lexbuf.lex_last_pos <- lexbuf.lex_last_pos - s;\n lexbuf.lex_buffer_len <- lexbuf.lex_buffer_len - s ;\n let t = lexbuf.lex_mem in\n for i = 0 to Array.length t-1 do\n let v = t.(i) in\n if v >= 0 then\n t.(i) <- v-s\n done\n end;\n (* There is now enough space at the end of the buffer *)\n Bytes.blit aux_buffer 0 lexbuf.lex_buffer lexbuf.lex_buffer_len n;\n lexbuf.lex_buffer_len <- lexbuf.lex_buffer_len + n\n\nlet zero_pos = {\n pos_fname = \"\";\n pos_lnum = 1;\n pos_bol = 0;\n pos_cnum = 0;\n}\n\nlet from_function ?(with_positions = true) f =\n { refill_buff = lex_refill f (Bytes.create 512);\n lex_buffer = Bytes.create 1024;\n lex_buffer_len = 0;\n lex_abs_pos = 0;\n lex_start_pos = 0;\n lex_curr_pos = 0;\n lex_last_pos = 0;\n lex_last_action = 0;\n lex_mem = [||];\n lex_eof_reached = false;\n lex_start_p = if with_positions then zero_pos else dummy_pos;\n lex_curr_p = if with_positions then zero_pos else dummy_pos;\n }\n\nlet from_channel ?with_positions ic =\n from_function ?with_positions (fun buf n -> input ic buf 0 n)\n\nlet from_string ?(with_positions = true) s =\n { refill_buff = (fun lexbuf -> lexbuf.lex_eof_reached <- true);\n lex_buffer = Bytes.of_string s; (* have to make a copy for compatibility\n with unsafe-string mode *)\n lex_buffer_len = String.length s;\n lex_abs_pos = 0;\n lex_start_pos = 0;\n lex_curr_pos = 0;\n lex_last_pos = 0;\n lex_last_action = 0;\n lex_mem = [||];\n lex_eof_reached = true;\n lex_start_p = if with_positions then zero_pos else dummy_pos;\n lex_curr_p = if with_positions then zero_pos else dummy_pos;\n }\n\nlet set_position lexbuf position =\n lexbuf.lex_curr_p <- {position with pos_fname = lexbuf.lex_curr_p.pos_fname};\n lexbuf.lex_abs_pos <- position.pos_cnum\n\nlet set_filename lexbuf fname =\n lexbuf.lex_curr_p <- {lexbuf.lex_curr_p with pos_fname = fname}\n\nlet with_positions lexbuf = lexbuf.lex_curr_p != dummy_pos\n\nlet lexeme lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n Bytes.sub_string lexbuf.lex_buffer lexbuf.lex_start_pos len\n\nlet sub_lexeme lexbuf i1 i2 =\n let len = i2-i1 in\n Bytes.sub_string lexbuf.lex_buffer i1 len\n\nlet sub_lexeme_opt lexbuf i1 i2 =\n if i1 >= 0 then begin\n let len = i2-i1 in\n Some (Bytes.sub_string lexbuf.lex_buffer i1 len)\n end else begin\n None\n end\n\nlet sub_lexeme_char lexbuf i = Bytes.get lexbuf.lex_buffer i\n\nlet sub_lexeme_char_opt lexbuf i =\n if i >= 0 then\n Some (Bytes.get lexbuf.lex_buffer i)\n else\n None\n\n\nlet lexeme_char lexbuf i =\n Bytes.get lexbuf.lex_buffer (lexbuf.lex_start_pos + i)\n\nlet lexeme_start lexbuf = lexbuf.lex_start_p.pos_cnum\nlet lexeme_end lexbuf = lexbuf.lex_curr_p.pos_cnum\n\nlet lexeme_start_p lexbuf = lexbuf.lex_start_p\nlet lexeme_end_p lexbuf = lexbuf.lex_curr_p\n\nlet new_line lexbuf =\n let lcp = lexbuf.lex_curr_p in\n if lcp != dummy_pos then\n lexbuf.lex_curr_p <-\n { lcp with\n pos_lnum = lcp.pos_lnum + 1;\n pos_bol = lcp.pos_cnum;\n }\n\n\n\n(* Discard data left in lexer buffer. *)\n\nlet flush_input lb =\n lb.lex_curr_pos <- 0;\n lb.lex_abs_pos <- 0;\n let lcp = lb.lex_curr_p in\n if lcp != dummy_pos then\n lb.lex_curr_p <- {zero_pos with pos_fname = lcp.pos_fname};\n lb.lex_buffer_len <- 0;\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Benoit Vaugon, ENSTA *)\n(* *)\n(* Copyright 2014 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nopen CamlinternalFormatBasics\n\n(******************************************************************************)\n (* Tools to manipulate scanning set of chars (see %[...]) *)\n\ntype mutable_char_set = bytes\n\n(* Create a fresh, empty, mutable char set. *)\nlet create_char_set () = Bytes.make 32 '\\000'\n\n(* Add a char in a mutable char set. *)\nlet add_in_char_set char_set c =\n let ind = int_of_char c in\n let str_ind = ind lsr 3 and mask = 1 lsl (ind land 0b111) in\n Bytes.set char_set str_ind\n (char_of_int (int_of_char (Bytes.get char_set str_ind) lor mask))\n\nlet freeze_char_set char_set =\n Bytes.to_string char_set\n\n(* Compute the complement of a char set. *)\nlet rev_char_set char_set =\n let char_set' = create_char_set () in\n for i = 0 to 31 do\n Bytes.set char_set' i\n (char_of_int (int_of_char (String.get char_set i) lxor 0xFF));\n done;\n Bytes.unsafe_to_string char_set'\n\n(* Return true if a `c' is in `char_set'. *)\nlet is_in_char_set char_set c =\n let ind = int_of_char c in\n let str_ind = ind lsr 3 and mask = 1 lsl (ind land 0b111) in\n (int_of_char (String.get char_set str_ind) land mask) <> 0\n\n\n(******************************************************************************)\n (* Ignored param conversion *)\n\n(* GADT used to abstract an existential type parameter. *)\n(* See param_format_of_ignored_format. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) param_format_ebb = Param_format_EBB :\n ('x -> 'a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) param_format_ebb\n\n(* Compute a padding associated to a pad_option (see \"%_42d\"). *)\nlet pad_of_pad_opt pad_opt = match pad_opt with\n | None -> No_padding\n | Some width -> Lit_padding (Right, width)\n\n(* Compute a precision associated to a prec_option (see \"%_.42f\"). *)\nlet prec_of_prec_opt prec_opt = match prec_opt with\n | None -> No_precision\n | Some ndec -> Lit_precision ndec\n\n(* Turn an ignored param into its equivalent not-ignored format node. *)\n(* Used for format pretty-printing and Scanf. *)\nlet param_format_of_ignored_format : type a b c d e f x y .\n (a, b, c, d, y, x) ignored -> (x, b, c, y, e, f) fmt ->\n (a, b, c, d, e, f) param_format_ebb =\nfun ign fmt -> match ign with\n | Ignored_char ->\n Param_format_EBB (Char fmt)\n | Ignored_caml_char ->\n Param_format_EBB (Caml_char fmt)\n | Ignored_string pad_opt ->\n Param_format_EBB (String (pad_of_pad_opt pad_opt, fmt))\n | Ignored_caml_string pad_opt ->\n Param_format_EBB (Caml_string (pad_of_pad_opt pad_opt, fmt))\n | Ignored_int (iconv, pad_opt) ->\n Param_format_EBB (Int (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n | Ignored_int32 (iconv, pad_opt) ->\n Param_format_EBB\n (Int32 (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n | Ignored_nativeint (iconv, pad_opt) ->\n Param_format_EBB\n (Nativeint (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n | Ignored_int64 (iconv, pad_opt) ->\n Param_format_EBB\n (Int64 (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n | Ignored_float (pad_opt, prec_opt) ->\n Param_format_EBB\n (Float ((Float_flag_, Float_f),\n pad_of_pad_opt pad_opt, prec_of_prec_opt prec_opt, fmt))\n | Ignored_bool pad_opt ->\n Param_format_EBB (Bool (pad_of_pad_opt pad_opt, fmt))\n | Ignored_format_arg (pad_opt, fmtty) ->\n Param_format_EBB (Format_arg (pad_opt, fmtty, fmt))\n | Ignored_format_subst (pad_opt, fmtty) ->\n Param_format_EBB\n (Format_subst (pad_opt, fmtty, fmt))\n | Ignored_reader ->\n Param_format_EBB (Reader fmt)\n | Ignored_scan_char_set (width_opt, char_set) ->\n Param_format_EBB (Scan_char_set (width_opt, char_set, fmt))\n | Ignored_scan_get_counter counter ->\n Param_format_EBB (Scan_get_counter (counter, fmt))\n | Ignored_scan_next_char ->\n Param_format_EBB (Scan_next_char fmt)\n\n\n(******************************************************************************)\n (* Types *)\n\ntype ('b, 'c) acc_formatting_gen =\n | Acc_open_tag of ('b, 'c) acc\n | Acc_open_box of ('b, 'c) acc\n\n(* Reversed list of printing atoms. *)\n(* Used to accumulate printf arguments. *)\nand ('b, 'c) acc =\n | Acc_formatting_lit of ('b, 'c) acc * formatting_lit\n (* Special fmtting (box) *)\n | Acc_formatting_gen of ('b, 'c) acc * ('b, 'c) acc_formatting_gen\n (* Special fmtting (box) *)\n | Acc_string_literal of ('b, 'c) acc * string (* Literal string *)\n | Acc_char_literal of ('b, 'c) acc * char (* Literal char *)\n | Acc_data_string of ('b, 'c) acc * string (* Generated string *)\n | Acc_data_char of ('b, 'c) acc * char (* Generated char *)\n | Acc_delay of ('b, 'c) acc * ('b -> 'c)\n (* Delayed printing (%a, %t) *)\n | Acc_flush of ('b, 'c) acc (* Flush *)\n | Acc_invalid_arg of ('b, 'c) acc * string\n (* Raise Invalid_argument msg *)\n | End_of_acc\n\n(* List of heterogeneous values. *)\n(* Used to accumulate scanf callback arguments. *)\ntype ('a, 'b) heter_list =\n | Cons : 'c * ('a, 'b) heter_list -> ('c -> 'a, 'b) heter_list\n | Nil : ('b, 'b) heter_list\n\n(* Existential Black Boxes. *)\n(* Used to abstract some existential type parameters. *)\n\n(* GADT type associating a padding and an fmtty. *)\n(* See the type_padding function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) padding_fmtty_ebb = Padding_fmtty_EBB :\n ('x, 'y) padding * ('y, 'b, 'c, 'd, 'e, 'f) fmtty ->\n ('x, 'b, 'c, 'd, 'e, 'f) padding_fmtty_ebb\n\n(* GADT type associating a padding, a precision and an fmtty. *)\n(* See the type_padprec function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) padprec_fmtty_ebb = Padprec_fmtty_EBB :\n ('x, 'y) padding * ('y, 'z) precision * ('z, 'b, 'c, 'd, 'e, 'f) fmtty ->\n ('x, 'b, 'c, 'd, 'e, 'f) padprec_fmtty_ebb\n\n(* GADT type associating a padding and an fmt. *)\n(* See make_padding_fmt_ebb and parse_format functions. *)\ntype ('a, 'b, 'c, 'e, 'f) padding_fmt_ebb = Padding_fmt_EBB :\n (_, 'x -> 'a) padding *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'e, 'f) padding_fmt_ebb\n\n(* GADT type associating a precision and an fmt. *)\n(* See make_precision_fmt_ebb and parse_format functions. *)\ntype ('a, 'b, 'c, 'e, 'f) precision_fmt_ebb = Precision_fmt_EBB :\n (_, 'x -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'e, 'f) precision_fmt_ebb\n\n(* GADT type associating a padding, a precision and an fmt. *)\n(* See make_padprec_fmt_ebb and parse_format functions. *)\ntype ('p, 'b, 'c, 'e, 'f) padprec_fmt_ebb = Padprec_fmt_EBB :\n ('x, 'y) padding * ('y, 'p -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('p, 'b, 'c, 'e, 'f) padprec_fmt_ebb\n\n(* Abstract the 'a and 'd parameters of an fmt. *)\n(* Output type of the format parsing function. *)\ntype ('b, 'c, 'e, 'f) fmt_ebb = Fmt_EBB :\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('b, 'c, 'e, 'f) fmt_ebb\n\n(* GADT type associating an fmtty and an fmt. *)\n(* See the type_format_gen function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) fmt_fmtty_ebb = Fmt_fmtty_EBB :\n ('a, 'b, 'c, 'd, 'y, 'x) fmt *\n ('x, 'b, 'c, 'y, 'e, 'f) fmtty ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt_fmtty_ebb\n\n(* GADT type associating an fmtty and an fmt. *)\n(* See the type_ignored_format_substitution function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) fmtty_fmt_ebb = Fmtty_fmt_EBB :\n ('a, 'b, 'c, 'd, 'y, 'x) fmtty *\n ('x, 'b, 'c, 'y, 'e, 'f) fmt_fmtty_ebb ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmtty_fmt_ebb\n\n(* Abstract all fmtty type parameters. *)\n(* Used to compare format types. *)\ntype fmtty_ebb = Fmtty_EBB : ('a, 'b, 'c, 'd, 'e, 'f) fmtty -> fmtty_ebb\n\n(* Abstract all padding type parameters. *)\n(* Used to compare paddings. *)\ntype padding_ebb = Padding_EBB : ('a, 'b) padding -> padding_ebb\n\n(* Abstract all precision type parameters. *)\n(* Used to compare precisions. *)\ntype precision_ebb = Precision_EBB : ('a, 'b) precision -> precision_ebb\n\n(******************************************************************************)\n (* Constants *)\n\n(* Default precision for float printing. *)\nlet default_float_precision fconv =\n match snd fconv with\n | Float_f | Float_e | Float_E | Float_g | Float_G | Float_h | Float_H\n | Float_CF -> -6\n (* For %h %H and %#F formats, a negative precision means \"as many digits as\n necessary\". For the other FP formats, we take the absolute value\n of the precision, hence 6 digits by default. *)\n | Float_F -> 12\n (* Default precision for OCaml float printing (%F). *)\n\n(******************************************************************************)\n (* Externals *)\n\nexternal format_float: string -> float -> string\n = \"caml_format_float\"\nexternal format_int: string -> int -> string\n = \"caml_format_int\"\nexternal format_int32: string -> int32 -> string\n = \"caml_int32_format\"\nexternal format_nativeint: string -> nativeint -> string\n = \"caml_nativeint_format\"\nexternal format_int64: string -> int64 -> string\n = \"caml_int64_format\"\nexternal hexstring_of_float: float -> int -> char -> string\n = \"caml_hexstring_of_float\"\n\n(******************************************************************************)\n (* Tools to pretty-print formats *)\n\n(* Type of extensible character buffers. *)\ntype buffer = {\n mutable ind : int;\n mutable bytes : bytes;\n}\n\n(* Create a fresh buffer. *)\nlet buffer_create init_size = { ind = 0; bytes = Bytes.create init_size }\n\n(* Check size of the buffer and grow it if needed. *)\nlet buffer_check_size buf overhead =\n let len = Bytes.length buf.bytes in\n let min_len = buf.ind + overhead in\n if min_len > len then (\n let new_len = Int.max (len * 2) min_len in\n let new_str = Bytes.create new_len in\n Bytes.blit buf.bytes 0 new_str 0 len;\n buf.bytes <- new_str;\n )\n\n(* Add the character `c' to the buffer `buf'. *)\nlet buffer_add_char buf c =\n buffer_check_size buf 1;\n Bytes.set buf.bytes buf.ind c;\n buf.ind <- buf.ind + 1\n\n(* Add the string `s' to the buffer `buf'. *)\nlet buffer_add_string buf s =\n let str_len = String.length s in\n buffer_check_size buf str_len;\n String.blit s 0 buf.bytes buf.ind str_len;\n buf.ind <- buf.ind + str_len\n\n(* Get the content of the buffer. *)\nlet buffer_contents buf =\n Bytes.sub_string buf.bytes 0 buf.ind\n\n(***)\n\n(* Convert an integer conversion to char. *)\nlet char_of_iconv iconv = match iconv with\n | Int_d | Int_pd | Int_sd | Int_Cd -> 'd' | Int_i | Int_pi | Int_si\n | Int_Ci -> 'i' | Int_x | Int_Cx -> 'x' | Int_X | Int_CX -> 'X' | Int_o\n | Int_Co -> 'o' | Int_u | Int_Cu -> 'u'\n\n(* Convert a float conversion to char. *)\n(* `cF' will be 'F' for displaying format and 'g' to call libc printf *)\nlet char_of_fconv ?(cF='F') fconv = match snd fconv with\n | Float_f -> 'f' | Float_e -> 'e'\n | Float_E -> 'E' | Float_g -> 'g'\n | Float_G -> 'G' | Float_F -> cF\n | Float_h -> 'h' | Float_H -> 'H'\n | Float_CF -> 'F'\n\n\n(* Convert a scanning counter to char. *)\nlet char_of_counter counter = match counter with\n | Line_counter -> 'l'\n | Char_counter -> 'n'\n | Token_counter -> 'N'\n\n(***)\n\n(* Print a char_set in a buffer with the OCaml format lexical convention. *)\nlet bprint_char_set buf char_set =\n let rec print_start set =\n let is_alone c =\n let before, after = Char.(chr (code c - 1), chr (code c + 1)) in\n is_in_char_set set c\n && not (is_in_char_set set before && is_in_char_set set after) in\n if is_alone ']' then buffer_add_char buf ']';\n print_out set 1;\n if is_alone '-' then buffer_add_char buf '-';\n and print_out set i =\n if i < 256 then\n if is_in_char_set set (char_of_int i) then print_first set i\n else print_out set (i + 1)\n and print_first set i =\n match char_of_int i with\n | '\\255' -> print_char buf 255;\n | ']' | '-' -> print_out set (i + 1);\n | _ -> print_second set (i + 1);\n and print_second set i =\n if is_in_char_set set (char_of_int i) then\n match char_of_int i with\n | '\\255' ->\n print_char buf 254;\n print_char buf 255;\n | ']' | '-' when not (is_in_char_set set (char_of_int (i + 1))) ->\n print_char buf (i - 1);\n print_out set (i + 1);\n | _ when not (is_in_char_set set (char_of_int (i + 1))) ->\n print_char buf (i - 1);\n print_char buf i;\n print_out set (i + 2);\n | _ ->\n print_in set (i - 1) (i + 2);\n else (\n print_char buf (i - 1);\n print_out set (i + 1);\n )\n and print_in set i j =\n if j = 256 || not (is_in_char_set set (char_of_int j)) then (\n print_char buf i;\n print_char buf (int_of_char '-');\n print_char buf (j - 1);\n if j < 256 then print_out set (j + 1);\n ) else\n print_in set i (j + 1);\n and print_char buf i = match char_of_int i with\n | '%' -> buffer_add_char buf '%'; buffer_add_char buf '%';\n | '@' -> buffer_add_char buf '%'; buffer_add_char buf '@';\n | c -> buffer_add_char buf c;\n in\n buffer_add_char buf '[';\n print_start (\n if is_in_char_set char_set '\\000'\n then ( buffer_add_char buf '^'; rev_char_set char_set )\n else char_set\n );\n buffer_add_char buf ']'\n\n(***)\n\n(* Print a padty in a buffer with the format-like syntax. *)\nlet bprint_padty buf padty = match padty with\n | Left -> buffer_add_char buf '-'\n | Right -> ()\n | Zeros -> buffer_add_char buf '0'\n\n(* Print the '_' of an ignored flag if needed. *)\nlet bprint_ignored_flag buf ign_flag =\n if ign_flag then buffer_add_char buf '_'\n\n(***)\n\nlet bprint_pad_opt buf pad_opt = match pad_opt with\n | None -> ()\n | Some width -> buffer_add_string buf (Int.to_string width)\n\n(***)\n\n(* Print padding in a buffer with the format-like syntax. *)\nlet bprint_padding : type a b . buffer -> (a, b) padding -> unit =\nfun buf pad -> match pad with\n | No_padding -> ()\n | Lit_padding (padty, n) ->\n bprint_padty buf padty;\n buffer_add_string buf (Int.to_string n);\n | Arg_padding padty ->\n bprint_padty buf padty;\n buffer_add_char buf '*'\n\n(* Print precision in a buffer with the format-like syntax. *)\nlet bprint_precision : type a b . buffer -> (a, b) precision -> unit =\n fun buf prec -> match prec with\n | No_precision -> ()\n | Lit_precision n ->\n buffer_add_char buf '.';\n buffer_add_string buf (Int.to_string n);\n | Arg_precision ->\n buffer_add_string buf \".*\"\n\n(***)\n\n(* Print the optional '+', ' ' or '#' associated to an int conversion. *)\nlet bprint_iconv_flag buf iconv = match iconv with\n | Int_pd | Int_pi -> buffer_add_char buf '+'\n | Int_sd | Int_si -> buffer_add_char buf ' '\n | Int_Cx | Int_CX | Int_Co | Int_Cd | Int_Ci | Int_Cu ->\n buffer_add_char buf '#'\n | Int_d | Int_i | Int_x | Int_X | Int_o | Int_u -> ()\n\n(* Print an complete int format in a buffer (ex: \"%3.*d\"). *)\nlet bprint_int_fmt buf ign_flag iconv pad prec =\n buffer_add_char buf '%';\n bprint_ignored_flag buf ign_flag;\n bprint_iconv_flag buf iconv;\n bprint_padding buf pad;\n bprint_precision buf prec;\n buffer_add_char buf (char_of_iconv iconv)\n\n(* Print a complete int32, nativeint or int64 format in a buffer. *)\nlet bprint_altint_fmt buf ign_flag iconv pad prec c =\n buffer_add_char buf '%';\n bprint_ignored_flag buf ign_flag;\n bprint_iconv_flag buf iconv;\n bprint_padding buf pad;\n bprint_precision buf prec;\n buffer_add_char buf c;\n buffer_add_char buf (char_of_iconv iconv)\n\n(***)\n\n(* Print the optional '+', ' ' and/or '#' associated to a float conversion. *)\nlet bprint_fconv_flag buf fconv =\n begin match fst fconv with\n | Float_flag_p -> buffer_add_char buf '+'\n | Float_flag_s -> buffer_add_char buf ' '\n | Float_flag_ -> () end;\n match snd fconv with\n | Float_CF -> buffer_add_char buf '#'\n | Float_f | Float_e | Float_E | Float_g | Float_G\n | Float_F | Float_h | Float_H -> ()\n\n(* Print a complete float format in a buffer (ex: \"%+*.3f\"). *)\nlet bprint_float_fmt buf ign_flag fconv pad prec =\n buffer_add_char buf '%';\n bprint_ignored_flag buf ign_flag;\n bprint_fconv_flag buf fconv;\n bprint_padding buf pad;\n bprint_precision buf prec;\n buffer_add_char buf (char_of_fconv fconv)\n\n(* Compute the literal string representation of a Formatting_lit. *)\n(* Used by Printf and Scanf where formatting is not interpreted. *)\nlet string_of_formatting_lit formatting_lit = match formatting_lit with\n | Close_box -> \"@]\"\n | Close_tag -> \"@}\"\n | Break (str, _, _) -> str\n | FFlush -> \"@?\"\n | Force_newline -> \"@\\n\"\n | Flush_newline -> \"@.\"\n | Magic_size (str, _) -> str\n | Escaped_at -> \"@@\"\n | Escaped_percent -> \"@%\"\n | Scan_indic c -> \"@\" ^ (String.make 1 c)\n\n(***)\n\n(* Print a literal char in a buffer, escape '%' by \"%%\". *)\nlet bprint_char_literal buf chr = match chr with\n | '%' -> buffer_add_string buf \"%%\"\n | _ -> buffer_add_char buf chr\n\n(* Print a literal string in a buffer, escape all '%' by \"%%\". *)\nlet bprint_string_literal buf str =\n for i = 0 to String.length str - 1 do\n bprint_char_literal buf str.[i]\n done\n\n(******************************************************************************)\n (* Format pretty-printing *)\n\n(* Print a complete format type (an fmtty) in a buffer. *)\nlet rec bprint_fmtty : type a b c d e f g h i j k l .\n buffer -> (a, b, c, d, e, f, g, h, i, j, k, l) fmtty_rel -> unit =\nfun buf fmtty -> match fmtty with\n | Char_ty rest -> buffer_add_string buf \"%c\"; bprint_fmtty buf rest;\n | String_ty rest -> buffer_add_string buf \"%s\"; bprint_fmtty buf rest;\n | Int_ty rest -> buffer_add_string buf \"%i\"; bprint_fmtty buf rest;\n | Int32_ty rest -> buffer_add_string buf \"%li\"; bprint_fmtty buf rest;\n | Nativeint_ty rest -> buffer_add_string buf \"%ni\"; bprint_fmtty buf rest;\n | Int64_ty rest -> buffer_add_string buf \"%Li\"; bprint_fmtty buf rest;\n | Float_ty rest -> buffer_add_string buf \"%f\"; bprint_fmtty buf rest;\n | Bool_ty rest -> buffer_add_string buf \"%B\"; bprint_fmtty buf rest;\n | Alpha_ty rest -> buffer_add_string buf \"%a\"; bprint_fmtty buf rest;\n | Theta_ty rest -> buffer_add_string buf \"%t\"; bprint_fmtty buf rest;\n | Any_ty rest -> buffer_add_string buf \"%?\"; bprint_fmtty buf rest;\n | Reader_ty rest -> buffer_add_string buf \"%r\"; bprint_fmtty buf rest;\n\n | Ignored_reader_ty rest ->\n buffer_add_string buf \"%_r\";\n bprint_fmtty buf rest;\n\n | Format_arg_ty (sub_fmtty, rest) ->\n buffer_add_string buf \"%{\"; bprint_fmtty buf sub_fmtty;\n buffer_add_string buf \"%}\"; bprint_fmtty buf rest;\n | Format_subst_ty (sub_fmtty, _, rest) ->\n buffer_add_string buf \"%(\"; bprint_fmtty buf sub_fmtty;\n buffer_add_string buf \"%)\"; bprint_fmtty buf rest;\n\n | End_of_fmtty -> ()\n\n(***)\n\nlet rec int_of_custom_arity : type a b c .\n (a, b, c) custom_arity -> int =\n function\n | Custom_zero -> 0\n | Custom_succ x -> 1 + int_of_custom_arity x\n\n(* Print a complete format in a buffer. *)\nlet bprint_fmt buf fmt =\n let rec fmtiter : type a b c d e f .\n (a, b, c, d, e, f) fmt -> bool -> unit =\n fun fmt ign_flag -> match fmt with\n | String (pad, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_padding buf pad; buffer_add_char buf 's';\n fmtiter rest false;\n | Caml_string (pad, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_padding buf pad; buffer_add_char buf 'S';\n fmtiter rest false;\n\n | Int (iconv, pad, prec, rest) ->\n bprint_int_fmt buf ign_flag iconv pad prec;\n fmtiter rest false;\n | Int32 (iconv, pad, prec, rest) ->\n bprint_altint_fmt buf ign_flag iconv pad prec 'l';\n fmtiter rest false;\n | Nativeint (iconv, pad, prec, rest) ->\n bprint_altint_fmt buf ign_flag iconv pad prec 'n';\n fmtiter rest false;\n | Int64 (iconv, pad, prec, rest) ->\n bprint_altint_fmt buf ign_flag iconv pad prec 'L';\n fmtiter rest false;\n | Float (fconv, pad, prec, rest) ->\n bprint_float_fmt buf ign_flag fconv pad prec;\n fmtiter rest false;\n\n | Char rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf 'c'; fmtiter rest false;\n | Caml_char rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf 'C'; fmtiter rest false;\n | Bool (pad, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_padding buf pad; buffer_add_char buf 'B';\n fmtiter rest false;\n | Alpha rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf 'a'; fmtiter rest false;\n | Theta rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf 't'; fmtiter rest false;\n | Custom (arity, _, rest) ->\n for _i = 1 to int_of_custom_arity arity do\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf '?';\n done;\n fmtiter rest false;\n | Reader rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf 'r'; fmtiter rest false;\n | Flush rest ->\n buffer_add_string buf \"%!\";\n fmtiter rest ign_flag;\n\n | String_literal (str, rest) ->\n bprint_string_literal buf str;\n fmtiter rest ign_flag;\n | Char_literal (chr, rest) ->\n bprint_char_literal buf chr;\n fmtiter rest ign_flag;\n\n | Format_arg (pad_opt, fmtty, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_pad_opt buf pad_opt; buffer_add_char buf '{';\n bprint_fmtty buf fmtty; buffer_add_char buf '%'; buffer_add_char buf '}';\n fmtiter rest false;\n | Format_subst (pad_opt, fmtty, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_pad_opt buf pad_opt; buffer_add_char buf '(';\n bprint_fmtty buf fmtty; buffer_add_char buf '%'; buffer_add_char buf ')';\n fmtiter rest false;\n\n | Scan_char_set (width_opt, char_set, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_pad_opt buf width_opt; bprint_char_set buf char_set;\n fmtiter rest false;\n | Scan_get_counter (counter, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf (char_of_counter counter);\n fmtiter rest false;\n | Scan_next_char rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_string_literal buf \"0c\"; fmtiter rest false;\n\n | Ignored_param (ign, rest) ->\n let Param_format_EBB fmt' = param_format_of_ignored_format ign rest in\n fmtiter fmt' true;\n\n | Formatting_lit (fmting_lit, rest) ->\n bprint_string_literal buf (string_of_formatting_lit fmting_lit);\n fmtiter rest ign_flag;\n | Formatting_gen (fmting_gen, rest) ->\n begin match fmting_gen with\n | Open_tag (Format (_, str)) ->\n buffer_add_string buf \"@{\"; buffer_add_string buf str\n | Open_box (Format (_, str)) ->\n buffer_add_string buf \"@[\"; buffer_add_string buf str\n end;\n fmtiter rest ign_flag;\n\n | End_of_format -> ()\n\n in fmtiter fmt false\n\n(***)\n\n(* Convert a format to string. *)\nlet string_of_fmt fmt =\n let buf = buffer_create 16 in\n bprint_fmt buf fmt;\n buffer_contents buf\n\n(******************************************************************************)\n (* Type extraction *)\n\ntype (_, _) eq = Refl : ('a, 'a) eq\n\n(* Invariant: this function is the identity on values.\n\n In particular, if (ty1, ty2) have equal values, then\n (trans (symm ty1) ty2) respects the 'trans' precondition. *)\nlet rec symm : type a1 b1 c1 d1 e1 f1 a2 b2 c2 d2 e2 f2 .\n (a1, b1, c1, d1, e1, f1,\n a2, b2, c2, d2, e2, f2) fmtty_rel\n-> (a2, b2, c2, d2, e2, f2,\n a1, b1, c1, d1, e1, f1) fmtty_rel\n= function\n | Char_ty rest -> Char_ty (symm rest)\n | Int_ty rest -> Int_ty (symm rest)\n | Int32_ty rest -> Int32_ty (symm rest)\n | Int64_ty rest -> Int64_ty (symm rest)\n | Nativeint_ty rest -> Nativeint_ty (symm rest)\n | Float_ty rest -> Float_ty (symm rest)\n | Bool_ty rest -> Bool_ty (symm rest)\n | String_ty rest -> String_ty (symm rest)\n | Theta_ty rest -> Theta_ty (symm rest)\n | Alpha_ty rest -> Alpha_ty (symm rest)\n | Any_ty rest -> Any_ty (symm rest)\n | Reader_ty rest -> Reader_ty (symm rest)\n | Ignored_reader_ty rest -> Ignored_reader_ty (symm rest)\n | Format_arg_ty (ty, rest) ->\n Format_arg_ty (ty, symm rest)\n | Format_subst_ty (ty1, ty2, rest) ->\n Format_subst_ty (ty2, ty1, symm rest)\n | End_of_fmtty -> End_of_fmtty\n\nlet rec fmtty_rel_det : type a1 b c d1 e1 f1 a2 d2 e2 f2 .\n (a1, b, c, d1, e1, f1,\n a2, b, c, d2, e2, f2) fmtty_rel ->\n ((f1, f2) eq -> (a1, a2) eq)\n * ((a1, a2) eq -> (f1, f2) eq)\n * ((e1, e2) eq -> (d1, d2) eq)\n * ((d1, d2) eq -> (e1, e2) eq)\n= function\n | End_of_fmtty ->\n (fun Refl -> Refl),\n (fun Refl -> Refl),\n (fun Refl -> Refl),\n (fun Refl -> Refl)\n | Char_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | String_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Int_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Int32_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Int64_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Nativeint_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Float_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Bool_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n\n | Theta_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Alpha_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Any_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Reader_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n (fun Refl -> let Refl = ed Refl in Refl),\n (fun Refl -> let Refl = de Refl in Refl)\n | Ignored_reader_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n (fun Refl -> let Refl = ed Refl in Refl),\n (fun Refl -> let Refl = de Refl in Refl)\n | Format_arg_ty (_ty, rest) ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Format_subst_ty (ty1, ty2, rest) ->\n let fa, af, ed, de = fmtty_rel_det rest in\n let ty = trans (symm ty1) ty2 in\n let ag, ga, dj, jd = fmtty_rel_det ty in\n (fun Refl -> let Refl = fa Refl in let Refl = ag Refl in Refl),\n (fun Refl -> let Refl = ga Refl in let Refl = af Refl in Refl),\n (fun Refl -> let Refl = ed Refl in let Refl = dj Refl in Refl),\n (fun Refl -> let Refl = jd Refl in let Refl = de Refl in Refl)\n\n(* Precondition: we assume that the two fmtty_rel arguments have equal\n values (at possibly distinct types); this invariant comes from the way\n fmtty_rel witnesses are produced by the type-checker\n\n The code below uses (assert false) when this assumption is broken. The\n code pattern is the following:\n\n | Foo x, Foo y ->\n (* case where indeed both values\n start with constructor Foo *)\n | Foo _, _\n | _, Foo _ ->\n (* different head constructors: broken precondition *)\n assert false\n*)\nand trans : type\n a1 b1 c1 d1 e1 f1\n a2 b2 c2 d2 e2 f2\n a3 b3 c3 d3 e3 f3\n.\n (a1, b1, c1, d1, e1, f1,\n a2, b2, c2, d2, e2, f2) fmtty_rel\n-> (a2, b2, c2, d2, e2, f2,\n a3, b3, c3, d3, e3, f3) fmtty_rel\n-> (a1, b1, c1, d1, e1, f1,\n a3, b3, c3, d3, e3, f3) fmtty_rel\n= fun ty1 ty2 -> match ty1, ty2 with\n | Char_ty rest1, Char_ty rest2 -> Char_ty (trans rest1 rest2)\n | String_ty rest1, String_ty rest2 -> String_ty (trans rest1 rest2)\n | Bool_ty rest1, Bool_ty rest2 -> Bool_ty (trans rest1 rest2)\n | Int_ty rest1, Int_ty rest2 -> Int_ty (trans rest1 rest2)\n | Int32_ty rest1, Int32_ty rest2 -> Int32_ty (trans rest1 rest2)\n | Int64_ty rest1, Int64_ty rest2 -> Int64_ty (trans rest1 rest2)\n | Nativeint_ty rest1, Nativeint_ty rest2 -> Nativeint_ty (trans rest1 rest2)\n | Float_ty rest1, Float_ty rest2 -> Float_ty (trans rest1 rest2)\n\n | Alpha_ty rest1, Alpha_ty rest2 -> Alpha_ty (trans rest1 rest2)\n | Alpha_ty _, _ -> assert false\n | _, Alpha_ty _ -> assert false\n\n | Theta_ty rest1, Theta_ty rest2 -> Theta_ty (trans rest1 rest2)\n | Theta_ty _, _ -> assert false\n | _, Theta_ty _ -> assert false\n\n | Any_ty rest1, Any_ty rest2 -> Any_ty (trans rest1 rest2)\n | Any_ty _, _ -> assert false\n | _, Any_ty _ -> assert false\n\n | Reader_ty rest1, Reader_ty rest2 -> Reader_ty (trans rest1 rest2)\n | Reader_ty _, _ -> assert false\n | _, Reader_ty _ -> assert false\n\n | Ignored_reader_ty rest1, Ignored_reader_ty rest2 ->\n Ignored_reader_ty (trans rest1 rest2)\n | Ignored_reader_ty _, _ -> assert false\n | _, Ignored_reader_ty _ -> assert false\n\n | Format_arg_ty (ty1, rest1), Format_arg_ty (ty2, rest2) ->\n Format_arg_ty (trans ty1 ty2, trans rest1 rest2)\n | Format_arg_ty _, _ -> assert false\n | _, Format_arg_ty _ -> assert false\n\n | Format_subst_ty (ty11, ty12, rest1),\n Format_subst_ty (ty21, ty22, rest2) ->\n let ty = trans (symm ty12) ty21 in\n let _, f2, _, f4 = fmtty_rel_det ty in\n let Refl = f2 Refl in\n let Refl = f4 Refl in\n Format_subst_ty (ty11, ty22, trans rest1 rest2)\n | Format_subst_ty _, _ -> assert false\n | _, Format_subst_ty _ -> assert false\n\n | End_of_fmtty, End_of_fmtty -> End_of_fmtty\n | End_of_fmtty, _ -> assert false\n | _, End_of_fmtty -> assert false\n\nlet rec fmtty_of_formatting_gen : type a b c d e f .\n (a, b, c, d, e, f) formatting_gen ->\n (a, b, c, d, e, f) fmtty =\nfun formatting_gen -> match formatting_gen with\n | Open_tag (Format (fmt, _)) -> fmtty_of_fmt fmt\n | Open_box (Format (fmt, _)) -> fmtty_of_fmt fmt\n\n(* Extract the type representation (an fmtty) of a format. *)\nand fmtty_of_fmt : type a b c d e f .\n (a, b, c, d, e, f) fmt -> (a, b, c, d, e, f) fmtty =\nfun fmtty -> match fmtty with\n | String (pad, rest) ->\n fmtty_of_padding_fmtty pad (String_ty (fmtty_of_fmt rest))\n | Caml_string (pad, rest) ->\n fmtty_of_padding_fmtty pad (String_ty (fmtty_of_fmt rest))\n\n | Int (_, pad, prec, rest) ->\n let ty_rest = fmtty_of_fmt rest in\n let prec_ty = fmtty_of_precision_fmtty prec (Int_ty ty_rest) in\n fmtty_of_padding_fmtty pad prec_ty\n | Int32 (_, pad, prec, rest) ->\n let ty_rest = fmtty_of_fmt rest in\n let prec_ty = fmtty_of_precision_fmtty prec (Int32_ty ty_rest) in\n fmtty_of_padding_fmtty pad prec_ty\n | Nativeint (_, pad, prec, rest) ->\n let ty_rest = fmtty_of_fmt rest in\n let prec_ty = fmtty_of_precision_fmtty prec (Nativeint_ty ty_rest) in\n fmtty_of_padding_fmtty pad prec_ty\n | Int64 (_, pad, prec, rest) ->\n let ty_rest = fmtty_of_fmt rest in\n let prec_ty = fmtty_of_precision_fmtty prec (Int64_ty ty_rest) in\n fmtty_of_padding_fmtty pad prec_ty\n | Float (_, pad, prec, rest) ->\n let ty_rest = fmtty_of_fmt rest in\n let prec_ty = fmtty_of_precision_fmtty prec (Float_ty ty_rest) in\n fmtty_of_padding_fmtty pad prec_ty\n\n | Char rest -> Char_ty (fmtty_of_fmt rest)\n | Caml_char rest -> Char_ty (fmtty_of_fmt rest)\n | Bool (pad, rest) ->\n fmtty_of_padding_fmtty pad (Bool_ty (fmtty_of_fmt rest))\n | Alpha rest -> Alpha_ty (fmtty_of_fmt rest)\n | Theta rest -> Theta_ty (fmtty_of_fmt rest)\n | Custom (arity, _, rest) -> fmtty_of_custom arity (fmtty_of_fmt rest)\n | Reader rest -> Reader_ty (fmtty_of_fmt rest)\n\n | Format_arg (_, ty, rest) ->\n Format_arg_ty (ty, fmtty_of_fmt rest)\n | Format_subst (_, ty, rest) ->\n Format_subst_ty (ty, ty, fmtty_of_fmt rest)\n\n | Flush rest -> fmtty_of_fmt rest\n | String_literal (_, rest) -> fmtty_of_fmt rest\n | Char_literal (_, rest) -> fmtty_of_fmt rest\n\n | Scan_char_set (_, _, rest) -> String_ty (fmtty_of_fmt rest)\n | Scan_get_counter (_, rest) -> Int_ty (fmtty_of_fmt rest)\n | Scan_next_char rest -> Char_ty (fmtty_of_fmt rest)\n | Ignored_param (ign, rest) -> fmtty_of_ignored_format ign rest\n | Formatting_lit (_, rest) -> fmtty_of_fmt rest\n | Formatting_gen (fmting_gen, rest) ->\n concat_fmtty (fmtty_of_formatting_gen fmting_gen) (fmtty_of_fmt rest)\n\n | End_of_format -> End_of_fmtty\n\nand fmtty_of_custom : type x y a b c d e f .\n (a, x, y) custom_arity -> (a, b, c, d, e, f) fmtty ->\n (y, b, c, d, e, f) fmtty =\nfun arity fmtty -> match arity with\n | Custom_zero -> fmtty\n | Custom_succ arity -> Any_ty (fmtty_of_custom arity fmtty)\n\n(* Extract the fmtty of an ignored parameter followed by the rest of\n the format. *)\nand fmtty_of_ignored_format : type x y a b c d e f .\n (a, b, c, d, y, x) ignored ->\n (x, b, c, y, e, f) fmt ->\n (a, b, c, d, e, f) fmtty =\nfun ign fmt -> match ign with\n | Ignored_char -> fmtty_of_fmt fmt\n | Ignored_caml_char -> fmtty_of_fmt fmt\n | Ignored_string _ -> fmtty_of_fmt fmt\n | Ignored_caml_string _ -> fmtty_of_fmt fmt\n | Ignored_int (_, _) -> fmtty_of_fmt fmt\n | Ignored_int32 (_, _) -> fmtty_of_fmt fmt\n | Ignored_nativeint (_, _) -> fmtty_of_fmt fmt\n | Ignored_int64 (_, _) -> fmtty_of_fmt fmt\n | Ignored_float (_, _) -> fmtty_of_fmt fmt\n | Ignored_bool _ -> fmtty_of_fmt fmt\n | Ignored_format_arg _ -> fmtty_of_fmt fmt\n | Ignored_format_subst (_, fmtty) -> concat_fmtty fmtty (fmtty_of_fmt fmt)\n | Ignored_reader -> Ignored_reader_ty (fmtty_of_fmt fmt)\n | Ignored_scan_char_set _ -> fmtty_of_fmt fmt\n | Ignored_scan_get_counter _ -> fmtty_of_fmt fmt\n | Ignored_scan_next_char -> fmtty_of_fmt fmt\n\n(* Add an Int_ty node if padding is taken as an extra argument (ex: \"%*s\"). *)\nand fmtty_of_padding_fmtty : type x a b c d e f .\n (x, a) padding -> (a, b, c, d, e, f) fmtty -> (x, b, c, d, e, f) fmtty =\n fun pad fmtty -> match pad with\n | No_padding -> fmtty\n | Lit_padding _ -> fmtty\n | Arg_padding _ -> Int_ty fmtty\n\n(* Add an Int_ty node if precision is taken as an extra argument (ex: \"%.*f\").*)\nand fmtty_of_precision_fmtty : type x a b c d e f .\n (x, a) precision -> (a, b, c, d, e, f) fmtty -> (x, b, c, d, e, f) fmtty =\n fun prec fmtty -> match prec with\n | No_precision -> fmtty\n | Lit_precision _ -> fmtty\n | Arg_precision -> Int_ty fmtty\n\n(******************************************************************************)\n (* Format typing *)\n\n(* Exception raised when a format does not match a given format type. *)\nexception Type_mismatch\n\n(* Type a padding. *)\n(* Take an Int_ty from the fmtty if the integer should be kept as argument. *)\n(* Raise Type_mismatch in case of type mismatch. *)\nlet type_padding : type a b c d e f x y .\n (x, y) padding -> (a, b, c, d, e, f) fmtty ->\n (a, b, c, d, e, f) padding_fmtty_ebb =\nfun pad fmtty -> match pad, fmtty with\n | No_padding, _ -> Padding_fmtty_EBB (No_padding, fmtty)\n | Lit_padding (padty, w), _ -> Padding_fmtty_EBB (Lit_padding (padty,w),fmtty)\n | Arg_padding padty, Int_ty rest -> Padding_fmtty_EBB (Arg_padding padty,rest)\n | _ -> raise Type_mismatch\n\n(* Convert a (upadding, uprecision) to a (padding, precision). *)\n(* Take one or two Int_ty from the fmtty if needed. *)\n(* Raise Type_mismatch in case of type mismatch. *)\nlet type_padprec : type a b c d e f x y z .\n (x, y) padding -> (y, z) precision -> (a, b, c, d, e, f) fmtty ->\n (a, b, c, d, e, f) padprec_fmtty_ebb =\nfun pad prec fmtty -> match prec, type_padding pad fmtty with\n | No_precision, Padding_fmtty_EBB (pad, rest) ->\n Padprec_fmtty_EBB (pad, No_precision, rest)\n | Lit_precision p, Padding_fmtty_EBB (pad, rest) ->\n Padprec_fmtty_EBB (pad, Lit_precision p, rest)\n | Arg_precision, Padding_fmtty_EBB (pad, Int_ty rest) ->\n Padprec_fmtty_EBB (pad, Arg_precision, rest)\n | _, Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n\n(* Type a format according to an fmtty. *)\n(* If typing succeed, generate a copy of the format with the same\n type parameters as the fmtty. *)\n(* Raise [Failure] with an error message in case of type mismatch. *)\nlet rec type_format :\n type a1 b1 c1 d1 e1 f1\n a2 b2 c2 d2 e2 f2 .\n (a1, b1, c1, d1, e1, f1) fmt\n -> (a2, b2, c2, d2, e2, f2) fmtty\n -> (a2, b2, c2, d2, e2, f2) fmt\n= fun fmt fmtty -> match type_format_gen fmt fmtty with\n | Fmt_fmtty_EBB (fmt', End_of_fmtty) -> fmt'\n | _ -> raise Type_mismatch\n\nand type_format_gen :\n type a1 b1 c1 d1 e1 f1\n a2 b2 c2 d2 e2 f2 .\n (a1, b1, c1, d1, e1, f1) fmt\n -> (a2, b2, c2, d2, e2, f2) fmtty\n -> (a2, b2, c2, d2, e2, f2) fmt_fmtty_ebb\n= fun fmt fmtty -> match fmt, fmtty with\n | Char fmt_rest, Char_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Char fmt', fmtty')\n | Caml_char fmt_rest, Char_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Caml_char fmt', fmtty')\n | String (pad, fmt_rest), _ -> (\n match type_padding pad fmtty with\n | Padding_fmtty_EBB (pad, String_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (String (pad, fmt'), fmtty')\n | Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n )\n | Caml_string (pad, fmt_rest), _ -> (\n match type_padding pad fmtty with\n | Padding_fmtty_EBB (pad, String_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Caml_string (pad, fmt'), fmtty')\n | Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n )\n | Int (iconv, pad, prec, fmt_rest), _ -> (\n match type_padprec pad prec fmtty with\n | Padprec_fmtty_EBB (pad, prec, Int_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Int (iconv, pad, prec, fmt'), fmtty')\n | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n )\n | Int32 (iconv, pad, prec, fmt_rest), _ -> (\n match type_padprec pad prec fmtty with\n | Padprec_fmtty_EBB (pad, prec, Int32_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Int32 (iconv, pad, prec, fmt'), fmtty')\n | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n )\n | Nativeint (iconv, pad, prec, fmt_rest), _ -> (\n match type_padprec pad prec fmtty with\n | Padprec_fmtty_EBB (pad, prec, Nativeint_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Nativeint (iconv, pad, prec, fmt'), fmtty')\n | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n )\n | Int64 (iconv, pad, prec, fmt_rest), _ -> (\n match type_padprec pad prec fmtty with\n | Padprec_fmtty_EBB (pad, prec, Int64_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Int64 (iconv, pad, prec, fmt'), fmtty')\n | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n )\n | Float (fconv, pad, prec, fmt_rest), _ -> (\n match type_padprec pad prec fmtty with\n | Padprec_fmtty_EBB (pad, prec, Float_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Float (fconv, pad, prec, fmt'), fmtty')\n | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n )\n | Bool (pad, fmt_rest), _ -> (\n match type_padding pad fmtty with\n | Padding_fmtty_EBB (pad, Bool_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Bool (pad, fmt'), fmtty')\n | Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n )\n | Flush fmt_rest, fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Flush fmt', fmtty')\n\n | String_literal (str, fmt_rest), fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (String_literal (str, fmt'), fmtty')\n | Char_literal (chr, fmt_rest), fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Char_literal (chr, fmt'), fmtty')\n\n | Format_arg (pad_opt, sub_fmtty, fmt_rest),\n Format_arg_ty (sub_fmtty', fmtty_rest) ->\n if Fmtty_EBB sub_fmtty <> Fmtty_EBB sub_fmtty' then raise Type_mismatch;\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Format_arg (pad_opt, sub_fmtty', fmt'), fmtty')\n | Format_subst (pad_opt, sub_fmtty, fmt_rest),\n Format_subst_ty (sub_fmtty1, _sub_fmtty2, fmtty_rest) ->\n if Fmtty_EBB (erase_rel sub_fmtty) <> Fmtty_EBB (erase_rel sub_fmtty1) then\n raise Type_mismatch;\n let Fmt_fmtty_EBB (fmt', fmtty') =\n type_format_gen fmt_rest (erase_rel fmtty_rest)\n in\n Fmt_fmtty_EBB (Format_subst (pad_opt, sub_fmtty1, fmt'), fmtty')\n (* Printf and Format specific constructors: *)\n | Alpha fmt_rest, Alpha_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Alpha fmt', fmtty')\n | Theta fmt_rest, Theta_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Theta fmt', fmtty')\n\n (* Format specific constructors: *)\n | Formatting_lit (formatting_lit, fmt_rest), fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Formatting_lit (formatting_lit, fmt'), fmtty')\n | Formatting_gen (formatting_gen, fmt_rest), fmtty_rest ->\n type_formatting_gen formatting_gen fmt_rest fmtty_rest\n\n (* Scanf specific constructors: *)\n | Reader fmt_rest, Reader_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Reader fmt', fmtty')\n | Scan_char_set (width_opt, char_set, fmt_rest), String_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Scan_char_set (width_opt, char_set, fmt'), fmtty')\n | Scan_get_counter (counter, fmt_rest), Int_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Scan_get_counter (counter, fmt'), fmtty')\n | Ignored_param (ign, rest), fmtty_rest ->\n type_ignored_param ign rest fmtty_rest\n\n | End_of_format, fmtty_rest -> Fmt_fmtty_EBB (End_of_format, fmtty_rest)\n\n | _ -> raise Type_mismatch\n\nand type_formatting_gen : type a1 a3 b1 b3 c1 c3 d1 d3 e1 e2 e3 f1 f2 f3 .\n (a1, b1, c1, d1, e1, f1) formatting_gen ->\n (f1, b1, c1, e1, e2, f2) fmt ->\n (a3, b3, c3, d3, e3, f3) fmtty ->\n (a3, b3, c3, d3, e3, f3) fmt_fmtty_ebb =\nfun formatting_gen fmt0 fmtty0 -> match formatting_gen with\n | Open_tag (Format (fmt1, str)) ->\n let Fmt_fmtty_EBB (fmt2, fmtty2) = type_format_gen fmt1 fmtty0 in\n let Fmt_fmtty_EBB (fmt3, fmtty3) = type_format_gen fmt0 fmtty2 in\n Fmt_fmtty_EBB (Formatting_gen (Open_tag (Format (fmt2, str)), fmt3), fmtty3)\n | Open_box (Format (fmt1, str)) ->\n let Fmt_fmtty_EBB (fmt2, fmtty2) = type_format_gen fmt1 fmtty0 in\n let Fmt_fmtty_EBB (fmt3, fmtty3) = type_format_gen fmt0 fmtty2 in\n Fmt_fmtty_EBB (Formatting_gen (Open_box (Format (fmt2, str)), fmt3), fmtty3)\n\n(* Type an Ignored_param node according to an fmtty. *)\nand type_ignored_param : type p q x y z t u v a b c d e f .\n (x, y, z, t, q, p) ignored ->\n (p, y, z, q, u, v) fmt ->\n (a, b, c, d, e, f) fmtty ->\n (a, b, c, d, e, f) fmt_fmtty_ebb =\nfun ign fmt fmtty -> match ign with\n | Ignored_char as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_caml_char as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_string _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_caml_string _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_int _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_int32 _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_nativeint _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_int64 _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_float _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_bool _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_scan_char_set _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_scan_get_counter _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_scan_next_char as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_format_arg (pad_opt, sub_fmtty) ->\n type_ignored_param_one (Ignored_format_arg (pad_opt, sub_fmtty)) fmt fmtty\n | Ignored_format_subst (pad_opt, sub_fmtty) ->\n let Fmtty_fmt_EBB (sub_fmtty', Fmt_fmtty_EBB (fmt', fmtty')) =\n type_ignored_format_substitution sub_fmtty fmt fmtty in\n Fmt_fmtty_EBB (Ignored_param (Ignored_format_subst (pad_opt, sub_fmtty'),\n fmt'),\n fmtty')\n | Ignored_reader -> (\n match fmtty with\n | Ignored_reader_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt fmtty_rest in\n Fmt_fmtty_EBB (Ignored_param (Ignored_reader, fmt'), fmtty')\n | _ -> raise Type_mismatch\n )\n\nand type_ignored_param_one : type a1 a2 b1 b2 c1 c2 d1 d2 e1 e2 f1 f2 .\n (a2, b2, c2, d2, d2, a2) ignored ->\n (a1, b1, c1, d1, e1, f1) fmt ->\n (a2, b2, c2, d2, e2, f2) fmtty ->\n (a2, b2, c2, d2, e2, f2) fmt_fmtty_ebb\n= fun ign fmt fmtty ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt fmtty in\n Fmt_fmtty_EBB (Ignored_param (ign, fmt'), fmtty')\n\n(* Typing of the complex case: \"%_(...%)\". *)\nand type_ignored_format_substitution : type w x y z p s t u a b c d e f .\n (w, x, y, z, s, p) fmtty ->\n (p, x, y, s, t, u) fmt ->\n (a, b, c, d, e, f) fmtty -> (a, b, c, d, e, f) fmtty_fmt_ebb =\nfun sub_fmtty fmt fmtty -> match sub_fmtty, fmtty with\n | Char_ty sub_fmtty_rest, Char_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Char_ty sub_fmtty_rest', fmt')\n | String_ty sub_fmtty_rest, String_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (String_ty sub_fmtty_rest', fmt')\n | Int_ty sub_fmtty_rest, Int_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Int_ty sub_fmtty_rest', fmt')\n | Int32_ty sub_fmtty_rest, Int32_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Int32_ty sub_fmtty_rest', fmt')\n | Nativeint_ty sub_fmtty_rest, Nativeint_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Nativeint_ty sub_fmtty_rest', fmt')\n | Int64_ty sub_fmtty_rest, Int64_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Int64_ty sub_fmtty_rest', fmt')\n | Float_ty sub_fmtty_rest, Float_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Float_ty sub_fmtty_rest', fmt')\n | Bool_ty sub_fmtty_rest, Bool_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Bool_ty sub_fmtty_rest', fmt')\n | Alpha_ty sub_fmtty_rest, Alpha_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Alpha_ty sub_fmtty_rest', fmt')\n | Theta_ty sub_fmtty_rest, Theta_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Theta_ty sub_fmtty_rest', fmt')\n | Reader_ty sub_fmtty_rest, Reader_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Reader_ty sub_fmtty_rest', fmt')\n | Ignored_reader_ty sub_fmtty_rest, Ignored_reader_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Ignored_reader_ty sub_fmtty_rest', fmt')\n\n | Format_arg_ty (sub2_fmtty, sub_fmtty_rest),\n Format_arg_ty (sub2_fmtty', fmtty_rest) ->\n if Fmtty_EBB sub2_fmtty <> Fmtty_EBB sub2_fmtty' then raise Type_mismatch;\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Format_arg_ty (sub2_fmtty', sub_fmtty_rest'), fmt')\n | Format_subst_ty (sub1_fmtty, sub2_fmtty, sub_fmtty_rest),\n Format_subst_ty (sub1_fmtty', sub2_fmtty', fmtty_rest) ->\n (* TODO define Fmtty_rel_EBB to remove those erase_rel *)\n if Fmtty_EBB (erase_rel sub1_fmtty) <> Fmtty_EBB (erase_rel sub1_fmtty')\n then raise Type_mismatch;\n if Fmtty_EBB (erase_rel sub2_fmtty) <> Fmtty_EBB (erase_rel sub2_fmtty')\n then raise Type_mismatch;\n let sub_fmtty' = trans (symm sub1_fmtty') sub2_fmtty' in\n let _, f2, _, f4 = fmtty_rel_det sub_fmtty' in\n let Refl = f2 Refl in\n let Refl = f4 Refl in\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution (erase_rel sub_fmtty_rest) fmt fmtty_rest\n in\n Fmtty_fmt_EBB (Format_subst_ty (sub1_fmtty', sub2_fmtty',\n symm sub_fmtty_rest'),\n fmt')\n | End_of_fmtty, fmtty ->\n Fmtty_fmt_EBB (End_of_fmtty, type_format_gen fmt fmtty)\n | _ -> raise Type_mismatch\n\n(* This implementation of `recast` is a bit disappointing. The\n invariant provided by the type are very strong: the input format's\n type is in relation to the output type's as witnessed by the\n fmtty_rel argument. One would at first expect this function to be\n total, and implementable by exhaustive pattern matching. Instead,\n we reuse the highly partial and much less well-defined function\n `type_format` that has lost all knowledge of the correspondence\n between the argument's types.\n\n Besides the fact that this function reuses a lot of the\n `type_format` logic (eg.: seeing Int_ty in the fmtty parameter does\n not let you match on Int only, as you may in fact have Float\n (Arg_padding, ...) (\"%.*d\") beginning with an Int_ty), it is also\n a partial function, because the typing information in a format is\n not quite enough to reconstruct it unambiguously. For example, the\n format types of \"%d%_r\" and \"%_r%d\" have the same format6\n parameters, but they are not at all exchangeable, and putting one\n in place of the other must result in a dynamic failure.\n\n Given that:\n - we'd have to duplicate a lot of non-trivial typing logic from type_format\n - this wouldn't even eliminate (all) the dynamic failures\n we decided to just reuse type_format directly for now.\n*)\nlet recast :\n type a1 b1 c1 d1 e1 f1\n a2 b2 c2 d2 e2 f2\n .\n (a1, b1, c1, d1, e1, f1) fmt\n -> (a1, b1, c1, d1, e1, f1,\n a2, b2, c2, d2, e2, f2) fmtty_rel\n -> (a2, b2, c2, d2, e2, f2) fmt\n= fun fmt fmtty ->\n type_format fmt (erase_rel (symm fmtty))\n\n(******************************************************************************)\n (* Printing tools *)\n\n(* Add padding spaces around a string. *)\nlet fix_padding padty width str =\n let len = String.length str in\n let width, padty =\n abs width,\n (* while literal padding widths are always non-negative,\n dynamically-set widths (Arg_padding, eg. %*d) may be negative;\n we interpret those as specifying a padding-to-the-left; this\n means that '0' may get dropped even if it was explicitly set,\n but:\n - this is what the legacy implementation does, and\n we preserve compatibility if possible\n - we could only signal this issue by failing at runtime,\n which is not very nice... *)\n if width < 0 then Left else padty in\n if width <= len then str else\n let res = Bytes.make width (if padty = Zeros then '0' else ' ') in\n begin match padty with\n | Left -> String.blit str 0 res 0 len\n | Right -> String.blit str 0 res (width - len) len\n | Zeros when len > 0 && (str.[0] = '+' || str.[0] = '-' || str.[0] = ' ') ->\n Bytes.set res 0 str.[0];\n String.blit str 1 res (width - len + 1) (len - 1)\n | Zeros when len > 1 && str.[0] = '0' && (str.[1] = 'x' || str.[1] = 'X') ->\n Bytes.set res 1 str.[1];\n String.blit str 2 res (width - len + 2) (len - 2)\n | Zeros ->\n String.blit str 0 res (width - len) len\n end;\n Bytes.unsafe_to_string res\n\n(* Add '0' padding to int, int32, nativeint or int64 string representation. *)\nlet fix_int_precision prec str =\n let prec = abs prec in\n let len = String.length str in\n match str.[0] with\n | ('+' | '-' | ' ') as c when prec + 1 > len ->\n let res = Bytes.make (prec + 1) '0' in\n Bytes.set res 0 c;\n String.blit str 1 res (prec - len + 2) (len - 1);\n Bytes.unsafe_to_string res\n | '0' when prec + 2 > len && len > 1 && (str.[1] = 'x' || str.[1] = 'X') ->\n let res = Bytes.make (prec + 2) '0' in\n Bytes.set res 1 str.[1];\n String.blit str 2 res (prec - len + 4) (len - 2);\n Bytes.unsafe_to_string res\n | '0' .. '9' | 'a' .. 'f' | 'A' .. 'F' when prec > len ->\n let res = Bytes.make prec '0' in\n String.blit str 0 res (prec - len) len;\n Bytes.unsafe_to_string res\n | _ ->\n str\n\n(* Escape a string according to the OCaml lexing convention. *)\nlet string_to_caml_string str =\n let str = String.escaped str in\n let l = String.length str in\n let res = Bytes.make (l + 2) '\\\"' in\n String.unsafe_blit str 0 res 1 l;\n Bytes.unsafe_to_string res\n\n(* Generate the format_int/int32/nativeint/int64 first argument\n from an int_conv. *)\nlet format_of_iconv = function\n | Int_d | Int_Cd -> \"%d\" | Int_pd -> \"%+d\" | Int_sd -> \"% d\"\n | Int_i | Int_Ci -> \"%i\" | Int_pi -> \"%+i\" | Int_si -> \"% i\"\n | Int_x -> \"%x\" | Int_Cx -> \"%#x\"\n | Int_X -> \"%X\" | Int_CX -> \"%#X\"\n | Int_o -> \"%o\" | Int_Co -> \"%#o\"\n | Int_u | Int_Cu -> \"%u\"\n\nlet format_of_iconvL = function\n | Int_d | Int_Cd -> \"%Ld\" | Int_pd -> \"%+Ld\" | Int_sd -> \"% Ld\"\n | Int_i | Int_Ci -> \"%Li\" | Int_pi -> \"%+Li\" | Int_si -> \"% Li\"\n | Int_x -> \"%Lx\" | Int_Cx -> \"%#Lx\"\n | Int_X -> \"%LX\" | Int_CX -> \"%#LX\"\n | Int_o -> \"%Lo\" | Int_Co -> \"%#Lo\"\n | Int_u | Int_Cu -> \"%Lu\"\n\nlet format_of_iconvl = function\n | Int_d | Int_Cd -> \"%ld\" | Int_pd -> \"%+ld\" | Int_sd -> \"% ld\"\n | Int_i | Int_Ci -> \"%li\" | Int_pi -> \"%+li\" | Int_si -> \"% li\"\n | Int_x -> \"%lx\" | Int_Cx -> \"%#lx\"\n | Int_X -> \"%lX\" | Int_CX -> \"%#lX\"\n | Int_o -> \"%lo\" | Int_Co -> \"%#lo\"\n | Int_u | Int_Cu -> \"%lu\"\n\nlet format_of_iconvn = function\n | Int_d | Int_Cd -> \"%nd\" | Int_pd -> \"%+nd\" | Int_sd -> \"% nd\"\n | Int_i | Int_Ci -> \"%ni\" | Int_pi -> \"%+ni\" | Int_si -> \"% ni\"\n | Int_x -> \"%nx\" | Int_Cx -> \"%#nx\"\n | Int_X -> \"%nX\" | Int_CX -> \"%#nX\"\n | Int_o -> \"%no\" | Int_Co -> \"%#no\"\n | Int_u | Int_Cu -> \"%nu\"\n\n(* Generate the format_float first argument from a float_conv. *)\nlet format_of_fconv fconv prec =\n let prec = abs prec in\n let symb = char_of_fconv ~cF:'g' fconv in\n let buf = buffer_create 16 in\n buffer_add_char buf '%';\n bprint_fconv_flag buf fconv;\n buffer_add_char buf '.';\n buffer_add_string buf (Int.to_string prec);\n buffer_add_char buf symb;\n buffer_contents buf\n\nlet transform_int_alt iconv s =\n match iconv with\n | Int_Cd | Int_Ci | Int_Cu ->\n let digits =\n let n = ref 0 in\n for i = 0 to String.length s - 1 do\n match String.unsafe_get s i with\n | '0'..'9' -> incr n\n | _ -> ()\n done;\n !n\n in\n let buf = Bytes.create (String.length s + (digits - 1) / 3) in\n let pos = ref 0 in\n let put c = Bytes.set buf !pos c; incr pos in\n let left = ref ((digits - 1) mod 3 + 1) in\n for i = 0 to String.length s - 1 do\n match String.unsafe_get s i with\n | '0'..'9' as c ->\n if !left = 0 then (put '_'; left := 3); decr left; put c\n | c -> put c\n done;\n Bytes.unsafe_to_string buf\n | _ -> s\n\n(* Convert an integer to a string according to a conversion. *)\nlet convert_int iconv n =\n transform_int_alt iconv (format_int (format_of_iconv iconv) n)\nlet convert_int32 iconv n =\n transform_int_alt iconv (format_int32 (format_of_iconvl iconv) n)\nlet convert_nativeint iconv n =\n transform_int_alt iconv (format_nativeint (format_of_iconvn iconv) n)\nlet convert_int64 iconv n =\n transform_int_alt iconv (format_int64 (format_of_iconvL iconv) n)\n\n(* Convert a float to string. *)\n(* Fix special case of \"OCaml float format\". *)\nlet convert_float fconv prec x =\n let hex () =\n let sign =\n match fst fconv with\n | Float_flag_p -> '+'\n | Float_flag_s -> ' '\n | _ -> '-' in\n hexstring_of_float x prec sign in\n let add_dot_if_needed str =\n let len = String.length str in\n let rec is_valid i =\n if i = len then false else\n match str.[i] with\n | '.' | 'e' | 'E' -> true\n | _ -> is_valid (i + 1) in\n if is_valid 0 then str else str ^ \".\" in\n let caml_special_val str = match classify_float x with\n | FP_normal | FP_subnormal | FP_zero -> str\n | FP_infinite -> if x < 0.0 then \"neg_infinity\" else \"infinity\"\n | FP_nan -> \"nan\" in\n match snd fconv with\n | Float_h -> hex ()\n | Float_H -> String.uppercase_ascii (hex ())\n | Float_CF -> caml_special_val (hex ())\n | Float_F ->\n let str = format_float (format_of_fconv fconv prec) x in\n caml_special_val (add_dot_if_needed str)\n | Float_f | Float_e | Float_E | Float_g | Float_G ->\n format_float (format_of_fconv fconv prec) x\n\n(* Convert a char to a string according to the OCaml lexical convention. *)\nlet format_caml_char c =\n let str = Char.escaped c in\n let l = String.length str in\n let res = Bytes.make (l + 2) '\\'' in\n String.unsafe_blit str 0 res 1 l;\n Bytes.unsafe_to_string res\n\n(* Convert a format type to string *)\nlet string_of_fmtty fmtty =\n let buf = buffer_create 16 in\n bprint_fmtty buf fmtty;\n buffer_contents buf\n\n(******************************************************************************)\n (* Generic printing function *)\n\n(* Make a generic printing function. *)\n(* Used to generate Printf and Format printing functions. *)\n(* Parameters:\n k: a continuation finally applied to the output stream and the accumulator.\n o: the output stream (see k, %a and %t).\n acc: rev list of printing entities (string, char, flush, formatting, ...).\n fmt: the format. *)\nlet rec make_printf : type a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt -> a =\nfun k acc fmt -> match fmt with\n | Char rest ->\n fun c ->\n let new_acc = Acc_data_char (acc, c) in\n make_printf k new_acc rest\n | Caml_char rest ->\n fun c ->\n let new_acc = Acc_data_string (acc, format_caml_char c) in\n make_printf k new_acc rest\n | String (pad, rest) ->\n make_padding k acc rest pad (fun str -> str)\n | Caml_string (pad, rest) ->\n make_padding k acc rest pad string_to_caml_string\n | Int (iconv, pad, prec, rest) ->\n make_int_padding_precision k acc rest pad prec convert_int iconv\n | Int32 (iconv, pad, prec, rest) ->\n make_int_padding_precision k acc rest pad prec convert_int32 iconv\n | Nativeint (iconv, pad, prec, rest) ->\n make_int_padding_precision k acc rest pad prec convert_nativeint iconv\n | Int64 (iconv, pad, prec, rest) ->\n make_int_padding_precision k acc rest pad prec convert_int64 iconv\n | Float (fconv, pad, prec, rest) ->\n make_float_padding_precision k acc rest pad prec fconv\n | Bool (pad, rest) ->\n make_padding k acc rest pad string_of_bool\n | Alpha rest ->\n fun f x -> make_printf k (Acc_delay (acc, fun o -> f o x)) rest\n | Theta rest ->\n fun f -> make_printf k (Acc_delay (acc, f)) rest\n | Custom (arity, f, rest) ->\n make_custom k acc rest arity (f ())\n | Reader _ ->\n (* This case is impossible, by typing of formats. *)\n (* Indeed, since printf and co. take a format4 as argument, the 'd and 'e\n type parameters of fmt are obviously equals. The Reader is the\n only constructor which touch 'd and 'e type parameters of the format\n type, it adds an (->) to the 'd parameters. Consequently, a format4\n cannot contain a Reader node, except in the sub-format associated to\n an %{...%}. It's not a problem because make_printf do not call\n itself recursively on the sub-format associated to %{...%}. *)\n assert false\n | Flush rest ->\n make_printf k (Acc_flush acc) rest\n\n | String_literal (str, rest) ->\n make_printf k (Acc_string_literal (acc, str)) rest\n | Char_literal (chr, rest) ->\n make_printf k (Acc_char_literal (acc, chr)) rest\n\n | Format_arg (_, sub_fmtty, rest) ->\n let ty = string_of_fmtty sub_fmtty in\n (fun str ->\n ignore str;\n make_printf k (Acc_data_string (acc, ty)) rest)\n | Format_subst (_, fmtty, rest) ->\n fun (Format (fmt, _)) -> make_printf k acc\n (concat_fmt (recast fmt fmtty) rest)\n\n | Scan_char_set (_, _, rest) ->\n let new_acc = Acc_invalid_arg (acc, \"Printf: bad conversion %[\") in\n fun _ -> make_printf k new_acc rest\n | Scan_get_counter (_, rest) ->\n (* This case should be refused for Printf. *)\n (* Accepted for backward compatibility. *)\n (* Interpret %l, %n and %L as %u. *)\n fun n ->\n let new_acc = Acc_data_string (acc, format_int \"%u\" n) in\n make_printf k new_acc rest\n | Scan_next_char rest ->\n fun c ->\n let new_acc = Acc_data_char (acc, c) in\n make_printf k new_acc rest\n | Ignored_param (ign, rest) ->\n make_ignored_param k acc ign rest\n\n | Formatting_lit (fmting_lit, rest) ->\n make_printf k (Acc_formatting_lit (acc, fmting_lit)) rest\n | Formatting_gen (Open_tag (Format (fmt', _)), rest) ->\n let k' kacc =\n make_printf k (Acc_formatting_gen (acc, Acc_open_tag kacc)) rest in\n make_printf k' End_of_acc fmt'\n | Formatting_gen (Open_box (Format (fmt', _)), rest) ->\n let k' kacc =\n make_printf k (Acc_formatting_gen (acc, Acc_open_box kacc)) rest in\n make_printf k' End_of_acc fmt'\n\n | End_of_format ->\n k acc\n\n(* Delay the error (Invalid_argument \"Printf: bad conversion %_\"). *)\n(* Generate functions to take remaining arguments (after the \"%_\"). *)\nand make_ignored_param : type x y a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, y, x) ignored ->\n (x, b, c, y, e, f) fmt -> a =\nfun k acc ign fmt -> match ign with\n | Ignored_char -> make_invalid_arg k acc fmt\n | Ignored_caml_char -> make_invalid_arg k acc fmt\n | Ignored_string _ -> make_invalid_arg k acc fmt\n | Ignored_caml_string _ -> make_invalid_arg k acc fmt\n | Ignored_int (_, _) -> make_invalid_arg k acc fmt\n | Ignored_int32 (_, _) -> make_invalid_arg k acc fmt\n | Ignored_nativeint (_, _) -> make_invalid_arg k acc fmt\n | Ignored_int64 (_, _) -> make_invalid_arg k acc fmt\n | Ignored_float (_, _) -> make_invalid_arg k acc fmt\n | Ignored_bool _ -> make_invalid_arg k acc fmt\n | Ignored_format_arg _ -> make_invalid_arg k acc fmt\n | Ignored_format_subst (_, fmtty) -> make_from_fmtty k acc fmtty fmt\n | Ignored_reader -> assert false\n | Ignored_scan_char_set _ -> make_invalid_arg k acc fmt\n | Ignored_scan_get_counter _ -> make_invalid_arg k acc fmt\n | Ignored_scan_next_char -> make_invalid_arg k acc fmt\n\n\n(* Special case of printf \"%_(\". *)\nand make_from_fmtty : type x y a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, y, x) fmtty ->\n (x, b, c, y, e, f) fmt -> a =\nfun k acc fmtty fmt -> match fmtty with\n | Char_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | String_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Int_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Int32_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Nativeint_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Int64_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Float_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Bool_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Alpha_ty rest -> fun _ _ -> make_from_fmtty k acc rest fmt\n | Theta_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Any_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Reader_ty _ -> assert false\n | Ignored_reader_ty _ -> assert false\n | Format_arg_ty (_, rest) -> fun _ -> make_from_fmtty k acc rest fmt\n | End_of_fmtty -> make_invalid_arg k acc fmt\n | Format_subst_ty (ty1, ty2, rest) ->\n let ty = trans (symm ty1) ty2 in\n fun _ -> make_from_fmtty k acc (concat_fmtty ty rest) fmt\n\n(* Insert an Acc_invalid_arg in the accumulator and continue to generate\n closures to get the remaining arguments. *)\nand make_invalid_arg : type a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt -> a =\nfun k acc fmt ->\n make_printf k (Acc_invalid_arg (acc, \"Printf: bad conversion %_\")) fmt\n\n(* Fix padding, take it as an extra integer argument if needed. *)\nand make_padding : type x z a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt ->\n (x, z -> a) padding -> (z -> string) -> x =\n fun k acc fmt pad trans -> match pad with\n | No_padding ->\n fun x ->\n let new_acc = Acc_data_string (acc, trans x) in\n make_printf k new_acc fmt\n | Lit_padding (padty, width) ->\n fun x ->\n let new_acc = Acc_data_string (acc, fix_padding padty width (trans x)) in\n make_printf k new_acc fmt\n | Arg_padding padty ->\n fun w x ->\n let new_acc = Acc_data_string (acc, fix_padding padty w (trans x)) in\n make_printf k new_acc fmt\n\n(* Fix padding and precision for int, int32, nativeint or int64. *)\n(* Take one or two extra integer arguments if needed. *)\nand make_int_padding_precision : type x y z a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt ->\n (x, y) padding -> (y, z -> a) precision -> (int_conv -> z -> string) ->\n int_conv -> x =\n fun k acc fmt pad prec trans iconv -> match pad, prec with\n | No_padding, No_precision ->\n fun x ->\n let str = trans iconv x in\n make_printf k (Acc_data_string (acc, str)) fmt\n | No_padding, Lit_precision p ->\n fun x ->\n let str = fix_int_precision p (trans iconv x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | No_padding, Arg_precision ->\n fun p x ->\n let str = fix_int_precision p (trans iconv x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Lit_padding (padty, w), No_precision ->\n fun x ->\n let str = fix_padding padty w (trans iconv x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Lit_padding (padty, w), Lit_precision p ->\n fun x ->\n let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Lit_padding (padty, w), Arg_precision ->\n fun p x ->\n let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Arg_padding padty, No_precision ->\n fun w x ->\n let str = fix_padding padty w (trans iconv x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Arg_padding padty, Lit_precision p ->\n fun w x ->\n let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Arg_padding padty, Arg_precision ->\n fun w p x ->\n let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n make_printf k (Acc_data_string (acc, str)) fmt\n\n(* Convert a float, fix padding and precision if needed. *)\n(* Take the float argument and one or two extra integer arguments if needed. *)\nand make_float_padding_precision : type x y a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt ->\n (x, y) padding -> (y, float -> a) precision -> float_conv -> x =\n fun k acc fmt pad prec fconv -> match pad, prec with\n | No_padding, No_precision ->\n fun x ->\n let str = convert_float fconv (default_float_precision fconv) x in\n make_printf k (Acc_data_string (acc, str)) fmt\n | No_padding, Lit_precision p ->\n fun x ->\n let str = convert_float fconv p x in\n make_printf k (Acc_data_string (acc, str)) fmt\n | No_padding, Arg_precision ->\n fun p x ->\n let str = convert_float fconv p x in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Lit_padding (padty, w), No_precision ->\n fun x ->\n let str = convert_float fconv (default_float_precision fconv) x in\n let str' = fix_padding padty w str in\n make_printf k (Acc_data_string (acc, str')) fmt\n | Lit_padding (padty, w), Lit_precision p ->\n fun x ->\n let str = fix_padding padty w (convert_float fconv p x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Lit_padding (padty, w), Arg_precision ->\n fun p x ->\n let str = fix_padding padty w (convert_float fconv p x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Arg_padding padty, No_precision ->\n fun w x ->\n let str = convert_float fconv (default_float_precision fconv) x in\n let str' = fix_padding padty w str in\n make_printf k (Acc_data_string (acc, str')) fmt\n | Arg_padding padty, Lit_precision p ->\n fun w x ->\n let str = fix_padding padty w (convert_float fconv p x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Arg_padding padty, Arg_precision ->\n fun w p x ->\n let str = fix_padding padty w (convert_float fconv p x) in\n make_printf k (Acc_data_string (acc, str)) fmt\nand make_custom : type x y a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt ->\n (a, x, y) custom_arity -> x -> y =\n fun k acc rest arity f -> match arity with\n | Custom_zero -> make_printf k (Acc_data_string (acc, f)) rest\n | Custom_succ arity ->\n fun x ->\n make_custom k acc rest arity (f x)\n\nlet const x _ = x\n\nlet rec make_iprintf : type a b c d e f state.\n (state -> f) -> state -> (a, b, c, d, e, f) fmt -> a =\n fun k o fmt -> match fmt with\n | Char rest ->\n const (make_iprintf k o rest)\n | Caml_char rest ->\n const (make_iprintf k o rest)\n | String (No_padding, rest) ->\n const (make_iprintf k o rest)\n | String (Lit_padding _, rest) ->\n const (make_iprintf k o rest)\n | String (Arg_padding _, rest) ->\n const (const (make_iprintf k o rest))\n | Caml_string (No_padding, rest) ->\n const (make_iprintf k o rest)\n | Caml_string (Lit_padding _, rest) ->\n const (make_iprintf k o rest)\n | Caml_string (Arg_padding _, rest) ->\n const (const (make_iprintf k o rest))\n | Int (_, pad, prec, rest) ->\n fn_of_padding_precision k o rest pad prec\n | Int32 (_, pad, prec, rest) ->\n fn_of_padding_precision k o rest pad prec\n | Nativeint (_, pad, prec, rest) ->\n fn_of_padding_precision k o rest pad prec\n | Int64 (_, pad, prec, rest) ->\n fn_of_padding_precision k o rest pad prec\n | Float (_, pad, prec, rest) ->\n fn_of_padding_precision k o rest pad prec\n | Bool (No_padding, rest) ->\n const (make_iprintf k o rest)\n | Bool (Lit_padding _, rest) ->\n const (make_iprintf k o rest)\n | Bool (Arg_padding _, rest) ->\n const (const (make_iprintf k o rest))\n | Alpha rest ->\n const (const (make_iprintf k o rest))\n | Theta rest ->\n const (make_iprintf k o rest)\n | Custom (arity, _, rest) ->\n fn_of_custom_arity k o rest arity\n | Reader _ ->\n (* This case is impossible, by typing of formats. See the\n note in the corresponding case for make_printf. *)\n assert false\n | Flush rest ->\n make_iprintf k o rest\n | String_literal (_, rest) ->\n make_iprintf k o rest\n | Char_literal (_, rest) ->\n make_iprintf k o rest\n | Format_arg (_, _, rest) ->\n const (make_iprintf k o rest)\n | Format_subst (_, fmtty, rest) ->\n fun (Format (fmt, _)) ->\n make_iprintf k o\n (concat_fmt (recast fmt fmtty) rest)\n | Scan_char_set (_, _, rest) ->\n const (make_iprintf k o rest)\n | Scan_get_counter (_, rest) ->\n const (make_iprintf k o rest)\n | Scan_next_char rest ->\n const (make_iprintf k o rest)\n | Ignored_param (ign, rest) ->\n make_ignored_param (fun _ -> k o) (End_of_acc) ign rest\n | Formatting_lit (_, rest) ->\n make_iprintf k o rest\n | Formatting_gen (Open_tag (Format (fmt', _)), rest) ->\n make_iprintf (fun koc -> make_iprintf k koc rest) o fmt'\n | Formatting_gen (Open_box (Format (fmt', _)), rest) ->\n make_iprintf (fun koc -> make_iprintf k koc rest) o fmt'\n | End_of_format ->\n k o\nand fn_of_padding_precision :\n type x y z a b c d e f state.\n (state -> f) -> state -> (a, b, c, d, e, f) fmt ->\n (x, y) padding -> (y, z -> a) precision -> x =\n fun k o fmt pad prec -> match pad, prec with\n | No_padding , No_precision ->\n const (make_iprintf k o fmt)\n | No_padding , Lit_precision _ ->\n const (make_iprintf k o fmt)\n | No_padding , Arg_precision ->\n const (const (make_iprintf k o fmt))\n | Lit_padding _, No_precision ->\n const (make_iprintf k o fmt)\n | Lit_padding _, Lit_precision _ ->\n const (make_iprintf k o fmt)\n | Lit_padding _, Arg_precision ->\n const (const (make_iprintf k o fmt))\n | Arg_padding _, No_precision ->\n const (const (make_iprintf k o fmt))\n | Arg_padding _, Lit_precision _ ->\n const (const (make_iprintf k o fmt))\n | Arg_padding _, Arg_precision ->\n const (const (const (make_iprintf k o fmt)))\nand fn_of_custom_arity : type x y a b c d e f state.\n (state -> f) ->\n state -> (a, b, c, d, e, f) fmt -> (a, x, y) custom_arity -> y =\n fun k o fmt -> function\n | Custom_zero ->\n make_iprintf k o fmt\n | Custom_succ arity ->\n const (fn_of_custom_arity k o fmt arity)\n\n(******************************************************************************)\n (* Continuations for make_printf *)\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n printing entities (string, char, flus, ...) in an output_stream. *)\n(* Used as a continuation of make_printf. *)\nlet rec output_acc o acc = match acc with\n | Acc_formatting_lit (p, fmting_lit) ->\n let s = string_of_formatting_lit fmting_lit in\n output_acc o p; output_string o s;\n | Acc_formatting_gen (p, Acc_open_tag acc') ->\n output_acc o p; output_string o \"@{\"; output_acc o acc';\n | Acc_formatting_gen (p, Acc_open_box acc') ->\n output_acc o p; output_string o \"@[\"; output_acc o acc';\n | Acc_string_literal (p, s)\n | Acc_data_string (p, s) -> output_acc o p; output_string o s\n | Acc_char_literal (p, c)\n | Acc_data_char (p, c) -> output_acc o p; output_char o c\n | Acc_delay (p, f) -> output_acc o p; f o\n | Acc_flush p -> output_acc o p; flush o\n | Acc_invalid_arg (p, msg) -> output_acc o p; invalid_arg msg;\n | End_of_acc -> ()\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n printing entities (string, char, flus, ...) in a buffer. *)\n(* Used as a continuation of make_printf. *)\nlet rec bufput_acc b acc = match acc with\n | Acc_formatting_lit (p, fmting_lit) ->\n let s = string_of_formatting_lit fmting_lit in\n bufput_acc b p; Buffer.add_string b s;\n | Acc_formatting_gen (p, Acc_open_tag acc') ->\n bufput_acc b p; Buffer.add_string b \"@{\"; bufput_acc b acc';\n | Acc_formatting_gen (p, Acc_open_box acc') ->\n bufput_acc b p; Buffer.add_string b \"@[\"; bufput_acc b acc';\n | Acc_string_literal (p, s)\n | Acc_data_string (p, s) -> bufput_acc b p; Buffer.add_string b s\n | Acc_char_literal (p, c)\n | Acc_data_char (p, c) -> bufput_acc b p; Buffer.add_char b c\n | Acc_delay (p, f) -> bufput_acc b p; f b\n | Acc_flush p -> bufput_acc b p;\n | Acc_invalid_arg (p, msg) -> bufput_acc b p; invalid_arg msg;\n | End_of_acc -> ()\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n printing entities (string, char, flus, ...) in a buffer. *)\n(* Differ from bufput_acc by the interpretation of %a and %t. *)\n(* Used as a continuation of make_printf. *)\nlet rec strput_acc b acc = match acc with\n | Acc_formatting_lit (p, fmting_lit) ->\n let s = string_of_formatting_lit fmting_lit in\n strput_acc b p; Buffer.add_string b s;\n | Acc_formatting_gen (p, Acc_open_tag acc') ->\n strput_acc b p; Buffer.add_string b \"@{\"; strput_acc b acc';\n | Acc_formatting_gen (p, Acc_open_box acc') ->\n strput_acc b p; Buffer.add_string b \"@[\"; strput_acc b acc';\n | Acc_string_literal (p, s)\n | Acc_data_string (p, s) -> strput_acc b p; Buffer.add_string b s\n | Acc_char_literal (p, c)\n | Acc_data_char (p, c) -> strput_acc b p; Buffer.add_char b c\n | Acc_delay (p, f) -> strput_acc b p; Buffer.add_string b (f ())\n | Acc_flush p -> strput_acc b p;\n | Acc_invalid_arg (p, msg) -> strput_acc b p; invalid_arg msg;\n | End_of_acc -> ()\n\n(******************************************************************************)\n (* Error management *)\n\n(* Raise [Failure] with a pretty-printed error message. *)\nlet failwith_message (Format (fmt, _)) =\n let buf = Buffer.create 256 in\n let k acc = strput_acc buf acc; failwith (Buffer.contents buf) in\n make_printf k End_of_acc fmt\n\n(******************************************************************************)\n (* Formatting tools *)\n\n(* Convert a string to an open block description (indent, block_type) *)\nlet open_box_of_string str =\n if str = \"\" then (0, Pp_box) else\n let len = String.length str in\n let invalid_box () = failwith_message \"invalid box description %S\" str in\n let rec parse_spaces i =\n if i = len then i else\n match str.[i] with\n | ' ' | '\\t' -> parse_spaces (i + 1)\n | _ -> i\n and parse_lword i j =\n if j = len then j else\n match str.[j] with\n | 'a' .. 'z' -> parse_lword i (j + 1)\n | _ -> j\n and parse_int i j =\n if j = len then j else\n match str.[j] with\n | '0' .. '9' | '-' -> parse_int i (j + 1)\n | _ -> j in\n let wstart = parse_spaces 0 in\n let wend = parse_lword wstart wstart in\n let box_name = String.sub str wstart (wend - wstart) in\n let nstart = parse_spaces wend in\n let nend = parse_int nstart nstart in\n let indent =\n if nstart = nend then 0 else\n try int_of_string (String.sub str nstart (nend - nstart))\n with Failure _ -> invalid_box () in\n let exp_end = parse_spaces nend in\n if exp_end <> len then invalid_box ();\n let box_type = match box_name with\n | \"\" | \"b\" -> Pp_box\n | \"h\" -> Pp_hbox\n | \"v\" -> Pp_vbox\n | \"hv\" -> Pp_hvbox\n | \"hov\" -> Pp_hovbox\n | _ -> invalid_box () in\n (indent, box_type)\n\n(******************************************************************************)\n (* Parsing tools *)\n\n(* Create a padding_fmt_ebb from a padding and a format. *)\n(* Copy the padding to disjoin the type parameters of argument and result. *)\nlet make_padding_fmt_ebb : type x y .\n (x, y) padding -> (_, _, _, _, _, _) fmt ->\n (_, _, _, _, _) padding_fmt_ebb =\nfun pad fmt -> match pad with\n | No_padding -> Padding_fmt_EBB (No_padding, fmt)\n | Lit_padding (s, w) -> Padding_fmt_EBB (Lit_padding (s, w), fmt)\n | Arg_padding s -> Padding_fmt_EBB (Arg_padding s, fmt)\n\n(* Create a precision_fmt_ebb from a precision and a format. *)\n(* Copy the precision to disjoin the type parameters of argument and result. *)\nlet make_precision_fmt_ebb : type x y .\n (x, y) precision -> (_, _, _, _, _, _) fmt ->\n (_, _, _, _, _) precision_fmt_ebb =\nfun prec fmt -> match prec with\n | No_precision -> Precision_fmt_EBB (No_precision, fmt)\n | Lit_precision p -> Precision_fmt_EBB (Lit_precision p, fmt)\n | Arg_precision -> Precision_fmt_EBB (Arg_precision, fmt)\n\n(* Create a padprec_fmt_ebb from a padding, a precision and a format. *)\n(* Copy the padding and the precision to disjoin type parameters of arguments\n and result. *)\nlet make_padprec_fmt_ebb : type x y z t .\n (x, y) padding -> (z, t) precision ->\n (_, _, _, _, _, _) fmt ->\n (_, _, _, _, _) padprec_fmt_ebb =\nfun pad prec fmt ->\n let Precision_fmt_EBB (prec, fmt') = make_precision_fmt_ebb prec fmt in\n match pad with\n | No_padding -> Padprec_fmt_EBB (No_padding, prec, fmt')\n | Lit_padding (s, w) -> Padprec_fmt_EBB (Lit_padding (s, w), prec, fmt')\n | Arg_padding s -> Padprec_fmt_EBB (Arg_padding s, prec, fmt')\n\n(******************************************************************************)\n (* Format parsing *)\n\n(* Parse a string representing a format and create a fmt_ebb. *)\n(* Raise [Failure] in case of invalid format. *)\nlet fmt_ebb_of_string ?legacy_behavior str =\n (* Parameters naming convention: *)\n (* - lit_start: start of the literal sequence. *)\n (* - str_ind: current index in the string. *)\n (* - end_ind: end of the current (sub-)format. *)\n (* - pct_ind: index of the '%' in the current micro-format. *)\n (* - zero: is the '0' flag defined in the current micro-format. *)\n (* - minus: is the '-' flag defined in the current micro-format. *)\n (* - plus: is the '+' flag defined in the current micro-format. *)\n (* - hash: is the '#' flag defined in the current micro-format. *)\n (* - space: is the ' ' flag defined in the current micro-format. *)\n (* - ign: is the '_' flag defined in the current micro-format. *)\n (* - pad: padding of the current micro-format. *)\n (* - prec: precision of the current micro-format. *)\n (* - symb: char representing the conversion ('c', 's', 'd', ...). *)\n (* - char_set: set of characters as bitmap (see scanf %[...]). *)\n\n let legacy_behavior = match legacy_behavior with\n | Some flag -> flag\n | None -> true\n (* When this flag is enabled, the format parser tries to behave as\n the <4.02 implementations, in particular it ignores most benine\n nonsensical format. When the flag is disabled, it will reject any\n format that is not accepted by the specification.\n\n A typical example would be \"%+ d\": specifying both '+' (if the\n number is positive, pad with a '+' to get the same width as\n negative numbers) and ' ' (if the number is positive, pad with\n a space) does not make sense, but the legacy (< 4.02)\n implementation was happy to just ignore the space.\n *)\n in\n\n (* Raise [Failure] with a friendly error message. *)\n let invalid_format_message str_ind msg =\n failwith_message\n \"invalid format %S: at character number %d, %s\"\n str str_ind msg\n in\n\n (* Used when the end of the format (or the current sub-format) was encountered\n unexpectedly. *)\n let unexpected_end_of_format end_ind =\n invalid_format_message end_ind\n \"unexpected end of format\"\n in\n\n (* Used for %0c: no other widths are implemented *)\n let invalid_nonnull_char_width str_ind =\n invalid_format_message str_ind\n \"non-zero widths are unsupported for %c conversions\"\n in\n (* Raise [Failure] with a friendly error message about an option dependency\n problem. *)\n let invalid_format_without str_ind c s =\n failwith_message\n \"invalid format %S: at character number %d, '%c' without %s\"\n str str_ind c s\n in\n\n (* Raise [Failure] with a friendly error message about an unexpected\n character. *)\n let expected_character str_ind expected read =\n failwith_message\n \"invalid format %S: at character number %d, %s expected, read %C\"\n str str_ind expected read\n in\n\n (* Parse the string from beg_ind (included) to end_ind (excluded). *)\n let rec parse : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n fun beg_ind end_ind -> parse_literal beg_ind beg_ind end_ind\n\n (* Read literal characters up to '%' or '@' special characters. *)\n and parse_literal : type e f . int -> int -> int -> (_, _, e, f) fmt_ebb =\n fun lit_start str_ind end_ind ->\n if str_ind = end_ind then add_literal lit_start str_ind End_of_format else\n match str.[str_ind] with\n | '%' ->\n let Fmt_EBB fmt_rest = parse_format str_ind end_ind in\n add_literal lit_start str_ind fmt_rest\n | '@' ->\n let Fmt_EBB fmt_rest = parse_after_at (str_ind + 1) end_ind in\n add_literal lit_start str_ind fmt_rest\n | _ ->\n parse_literal lit_start (str_ind + 1) end_ind\n\n (* Parse a format after '%' *)\n and parse_format : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n fun pct_ind end_ind -> parse_ign pct_ind (pct_ind + 1) end_ind\n\n and parse_ign : type e f . int -> int -> int -> (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind ->\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | '_' -> parse_flags pct_ind (str_ind+1) end_ind true\n | _ -> parse_flags pct_ind str_ind end_ind false\n\n and parse_flags : type e f . int -> int -> int -> bool -> (_, _, e, f) fmt_ebb\n =\n fun pct_ind str_ind end_ind ign ->\n let zero = ref false and minus = ref false\n and plus = ref false and space = ref false\n and hash = ref false in\n let set_flag str_ind flag =\n (* in legacy mode, duplicate flags are accepted *)\n if !flag && not legacy_behavior then\n failwith_message\n \"invalid format %S: at character number %d, duplicate flag %C\"\n str str_ind str.[str_ind];\n flag := true;\n in\n let rec read_flags str_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n begin match str.[str_ind] with\n | '0' -> set_flag str_ind zero; read_flags (str_ind + 1)\n | '-' -> set_flag str_ind minus; read_flags (str_ind + 1)\n | '+' -> set_flag str_ind plus; read_flags (str_ind + 1)\n | '#' -> set_flag str_ind hash; read_flags (str_ind + 1)\n | ' ' -> set_flag str_ind space; read_flags (str_ind + 1)\n | _ ->\n parse_padding pct_ind str_ind end_ind\n !zero !minus !plus !hash !space ign\n end\n in\n read_flags str_ind\n\n (* Try to read a digital or a '*' padding. *)\n and parse_padding : type e f .\n int -> int -> int -> bool -> bool -> bool -> bool -> bool -> bool ->\n (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind zero minus plus hash space ign ->\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n let padty = match zero, minus with\n | false, false -> Right\n | false, true -> Left\n | true, false -> Zeros\n | true, true ->\n if legacy_behavior then Left\n else incompatible_flag pct_ind str_ind '-' \"0\" in\n match str.[str_ind] with\n | '0' .. '9' ->\n let new_ind, width = parse_positive str_ind end_ind 0 in\n parse_after_padding pct_ind new_ind end_ind minus plus hash space ign\n (Lit_padding (padty, width))\n | '*' ->\n parse_after_padding pct_ind (str_ind + 1) end_ind minus plus hash space\n ign (Arg_padding padty)\n | _ ->\n begin match padty with\n | Left ->\n if not legacy_behavior then\n invalid_format_without (str_ind - 1) '-' \"padding\";\n parse_after_padding pct_ind str_ind end_ind minus plus hash space ign\n No_padding\n | Zeros ->\n (* a '0' padding indication not followed by anything should\n be interpreted as a Right padding of width 0. This is used\n by scanning conversions %0s and %0c *)\n parse_after_padding pct_ind str_ind end_ind minus plus hash space ign\n (Lit_padding (Right, 0))\n | Right ->\n parse_after_padding pct_ind str_ind end_ind minus plus hash space ign\n No_padding\n end\n\n (* Is precision defined? *)\n and parse_after_padding : type x e f .\n int -> int -> int -> bool -> bool -> bool -> bool -> bool ->\n (x, _) padding -> (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind minus plus hash space ign pad ->\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | '.' ->\n parse_precision pct_ind (str_ind + 1) end_ind minus plus hash space ign\n pad\n | symb ->\n parse_conversion pct_ind (str_ind + 1) end_ind plus hash space ign pad\n No_precision pad symb\n\n (* Read the digital or '*' precision. *)\n and parse_precision : type x e f .\n int -> int -> int -> bool -> bool -> bool -> bool -> bool ->\n (x, _) padding -> (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind minus plus hash space ign pad ->\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n let parse_literal minus str_ind =\n let new_ind, prec = parse_positive str_ind end_ind 0 in\n parse_after_precision pct_ind new_ind end_ind minus plus hash space ign\n pad (Lit_precision prec) in\n match str.[str_ind] with\n | '0' .. '9' -> parse_literal minus str_ind\n | ('+' | '-') as symb when legacy_behavior ->\n (* Legacy mode would accept and ignore '+' or '-' before the\n integer describing the desired precision; note that this\n cannot happen for padding width, as '+' and '-' already have\n a semantics there.\n\n That said, the idea (supported by this tweak) that width and\n precision literals are \"integer literals\" in the OCaml sense is\n still blatantly wrong, as 123_456 or 0xFF are rejected. *)\n parse_literal (minus || symb = '-') (str_ind + 1)\n | '*' ->\n parse_after_precision pct_ind (str_ind + 1) end_ind minus plus hash space\n ign pad Arg_precision\n | _ ->\n if legacy_behavior then\n (* note that legacy implementation did not ignore '.' without\n a number (as it does for padding indications), but\n interprets it as '.0' *)\n parse_after_precision pct_ind str_ind end_ind minus plus hash space ign\n pad (Lit_precision 0)\n else\n invalid_format_without (str_ind - 1) '.' \"precision\"\n\n (* Try to read the conversion. *)\n and parse_after_precision : type x y z t e f .\n int -> int -> int -> bool -> bool -> bool -> bool -> bool ->\n (x, y) padding -> (z, t) precision -> (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind minus plus hash space ign pad prec ->\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n let parse_conv (type u) (type v) (padprec : (u, v) padding) =\n parse_conversion pct_ind (str_ind + 1) end_ind plus hash space ign pad\n prec padprec str.[str_ind] in\n (* in legacy mode, some formats (%s and %S) accept a weird mix of\n padding and precision, which is merged as a single padding\n information. For example, in %.10s the precision is implicitly\n understood as padding %10s, but the left-padding component may\n be specified either as a left padding or a negative precision:\n %-.3s and %.-3s are equivalent to %-3s *)\n match pad with\n | No_padding -> (\n match minus, prec with\n | _, No_precision -> parse_conv No_padding\n | false, Lit_precision n -> parse_conv (Lit_padding (Right, n))\n | true, Lit_precision n -> parse_conv (Lit_padding (Left, n))\n | false, Arg_precision -> parse_conv (Arg_padding Right)\n | true, Arg_precision -> parse_conv (Arg_padding Left)\n )\n | pad -> parse_conv pad\n\n (* Case analysis on conversion. *)\n and parse_conversion : type x y z t u v e f .\n int -> int -> int -> bool -> bool -> bool -> bool -> (x, y) padding ->\n (z, t) precision -> (u, v) padding -> char -> (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind plus hash space ign pad prec padprec symb ->\n (* Flags used to check option usages/compatibilities. *)\n let plus_used = ref false and hash_used = ref false\n and space_used = ref false and ign_used = ref false\n and pad_used = ref false and prec_used = ref false in\n\n (* Access to options, update flags. *)\n let get_plus () = plus_used := true; plus\n and get_hash () = hash_used := true; hash\n and get_space () = space_used := true; space\n and get_ign () = ign_used := true; ign\n and get_pad () = pad_used := true; pad\n and get_prec () = prec_used := true; prec\n and get_padprec () = pad_used := true; padprec in\n\n let get_int_pad () : (x,y) padding =\n (* %5.3d is accepted and meaningful: pad to length 5 with\n spaces, but first pad with zeros upto length 3 (0-padding\n is the interpretation of \"precision\" for integer formats).\n\n %05.3d is redundant: pad to length 5 *with zeros*, but\n first pad with zeros... To add insult to the injury, the\n legacy implementation ignores the 0-padding indication and\n does the 5 padding with spaces instead. We reuse this\n interpretation for compatibility, but statically reject this\n format when the legacy mode is disabled, to protect strict\n users from this corner case. *)\n match get_pad (), get_prec () with\n | pad, No_precision -> pad\n | No_padding, _ -> No_padding\n | Lit_padding (Zeros, n), _ ->\n if legacy_behavior then Lit_padding (Right, n)\n else incompatible_flag pct_ind str_ind '0' \"precision\"\n | Arg_padding Zeros, _ ->\n if legacy_behavior then Arg_padding Right\n else incompatible_flag pct_ind str_ind '0' \"precision\"\n | Lit_padding _ as pad, _ -> pad\n | Arg_padding _ as pad, _ -> pad in\n\n (* Check that padty <> Zeros. *)\n let check_no_0 symb (type a b) (pad : (a, b) padding) : (a,b) padding =\n match pad with\n | No_padding -> pad\n | Lit_padding ((Left | Right), _) -> pad\n | Arg_padding (Left | Right) -> pad\n | Lit_padding (Zeros, width) ->\n if legacy_behavior then Lit_padding (Right, width)\n else incompatible_flag pct_ind str_ind symb \"0\"\n | Arg_padding Zeros ->\n if legacy_behavior then Arg_padding Right\n else incompatible_flag pct_ind str_ind symb \"0\"\n in\n\n (* Get padding as a pad_option (see \"%_\", \"%{\", \"%(\" and \"%[\").\n (no need for legacy mode tweaking, those were rejected by the\n legacy parser as well) *)\n let opt_of_pad c (type a) (type b) (pad : (a, b) padding) = match pad with\n | No_padding -> None\n | Lit_padding (Right, width) -> Some width\n | Lit_padding (Zeros, width) ->\n if legacy_behavior then Some width\n else incompatible_flag pct_ind str_ind c \"'0'\"\n | Lit_padding (Left, width) ->\n if legacy_behavior then Some width\n else incompatible_flag pct_ind str_ind c \"'-'\"\n | Arg_padding _ -> incompatible_flag pct_ind str_ind c \"'*'\"\n in\n let get_pad_opt c = opt_of_pad c (get_pad ()) in\n let get_padprec_opt c = opt_of_pad c (get_padprec ()) in\n\n (* Get precision as a prec_option (see \"%_f\").\n (no need for legacy mode tweaking, those were rejected by the\n legacy parser as well) *)\n let get_prec_opt () = match get_prec () with\n | No_precision -> None\n | Lit_precision ndec -> Some ndec\n | Arg_precision -> incompatible_flag pct_ind str_ind '_' \"'*'\"\n in\n\n let fmt_result = match symb with\n | ',' ->\n parse str_ind end_ind\n | 'c' ->\n let char_format fmt_rest = (* %c *)\n if get_ign ()\n then Fmt_EBB (Ignored_param (Ignored_char, fmt_rest))\n else Fmt_EBB (Char fmt_rest)\n in\n let scan_format fmt_rest = (* %0c *)\n if get_ign ()\n then Fmt_EBB (Ignored_param (Ignored_scan_next_char, fmt_rest))\n else Fmt_EBB (Scan_next_char fmt_rest)\n in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n begin match get_pad_opt 'c' with\n | None -> char_format fmt_rest\n | Some 0 -> scan_format fmt_rest\n | Some _n ->\n if not legacy_behavior\n then invalid_nonnull_char_width str_ind\n else (* legacy ignores %c widths *) char_format fmt_rest\n end\n | 'C' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then Fmt_EBB (Ignored_param (Ignored_caml_char,fmt_rest))\n else Fmt_EBB (Caml_char fmt_rest)\n | 's' ->\n let pad = check_no_0 symb (get_padprec ()) in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then\n let ignored = Ignored_string (get_padprec_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padding_fmt_EBB (pad', fmt_rest') =\n make_padding_fmt_ebb pad fmt_rest in\n Fmt_EBB (String (pad', fmt_rest'))\n | 'S' ->\n let pad = check_no_0 symb (get_padprec ()) in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then\n let ignored = Ignored_caml_string (get_padprec_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padding_fmt_EBB (pad', fmt_rest') =\n make_padding_fmt_ebb pad fmt_rest in\n Fmt_EBB (Caml_string (pad', fmt_rest'))\n | 'd' | 'i' | 'x' | 'X' | 'o' | 'u' ->\n let iconv = compute_int_conv pct_ind str_ind (get_plus ()) (get_hash ())\n (get_space ()) symb in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then\n let ignored = Ignored_int (iconv, get_pad_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n Fmt_EBB (Int (iconv, pad', prec', fmt_rest'))\n | 'N' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n let counter = Token_counter in\n if get_ign () then\n let ignored = Ignored_scan_get_counter counter in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n Fmt_EBB (Scan_get_counter (counter, fmt_rest))\n | 'l' | 'n' | 'L' when str_ind=end_ind || not (is_int_base str.[str_ind]) ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n let counter = counter_of_char symb in\n if get_ign () then\n let ignored = Ignored_scan_get_counter counter in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n Fmt_EBB (Scan_get_counter (counter, fmt_rest))\n | 'l' ->\n let iconv =\n compute_int_conv pct_ind (str_ind + 1) (get_plus ()) (get_hash ())\n (get_space ()) str.[str_ind] in\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n if get_ign () then\n let ignored = Ignored_int32 (iconv, get_pad_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n Fmt_EBB (Int32 (iconv, pad', prec', fmt_rest'))\n | 'n' ->\n let iconv =\n compute_int_conv pct_ind (str_ind + 1) (get_plus ())\n (get_hash ()) (get_space ()) str.[str_ind] in\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n if get_ign () then\n let ignored = Ignored_nativeint (iconv, get_pad_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n Fmt_EBB (Nativeint (iconv, pad', prec', fmt_rest'))\n | 'L' ->\n let iconv =\n compute_int_conv pct_ind (str_ind + 1) (get_plus ()) (get_hash ())\n (get_space ()) str.[str_ind] in\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n if get_ign () then\n let ignored = Ignored_int64 (iconv, get_pad_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n Fmt_EBB (Int64 (iconv, pad', prec', fmt_rest'))\n | 'f' | 'e' | 'E' | 'g' | 'G' | 'F' | 'h' | 'H' ->\n let fconv =\n compute_float_conv pct_ind str_ind\n (get_plus ()) (get_hash ()) (get_space ()) symb in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then\n let ignored = Ignored_float (get_pad_opt '_', get_prec_opt ()) in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n make_padprec_fmt_ebb (get_pad ()) (get_prec ()) fmt_rest in\n Fmt_EBB (Float (fconv, pad', prec', fmt_rest'))\n | 'b' | 'B' ->\n let pad = check_no_0 symb (get_padprec ()) in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then\n let ignored = Ignored_bool (get_padprec_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padding_fmt_EBB (pad', fmt_rest') =\n make_padding_fmt_ebb pad fmt_rest in\n Fmt_EBB (Bool (pad', fmt_rest'))\n | 'a' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Alpha fmt_rest)\n | 't' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Theta fmt_rest)\n | 'r' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then Fmt_EBB (Ignored_param (Ignored_reader, fmt_rest))\n else Fmt_EBB (Reader fmt_rest)\n | '!' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Flush fmt_rest)\n | ('%' | '@') as c ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Char_literal (c, fmt_rest))\n | '{' ->\n let sub_end = search_subformat_end str_ind end_ind '}' in\n let Fmt_EBB sub_fmt = parse str_ind sub_end in\n let Fmt_EBB fmt_rest = parse (sub_end + 2) end_ind in\n let sub_fmtty = fmtty_of_fmt sub_fmt in\n if get_ign () then\n let ignored = Ignored_format_arg (get_pad_opt '_', sub_fmtty) in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n Fmt_EBB (Format_arg (get_pad_opt '{', sub_fmtty, fmt_rest))\n | '(' ->\n let sub_end = search_subformat_end str_ind end_ind ')' in\n let Fmt_EBB fmt_rest = parse (sub_end + 2) end_ind in\n let Fmt_EBB sub_fmt = parse str_ind sub_end in\n let sub_fmtty = fmtty_of_fmt sub_fmt in\n if get_ign () then\n let ignored = Ignored_format_subst (get_pad_opt '_', sub_fmtty) in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n Fmt_EBB (Format_subst (get_pad_opt '(', sub_fmtty, fmt_rest))\n | '[' ->\n let next_ind, char_set = parse_char_set str_ind end_ind in\n let Fmt_EBB fmt_rest = parse next_ind end_ind in\n if get_ign () then\n let ignored = Ignored_scan_char_set (get_pad_opt '_', char_set) in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n Fmt_EBB (Scan_char_set (get_pad_opt '[', char_set, fmt_rest))\n | '-' | '+' | '#' | ' ' | '_' ->\n failwith_message\n \"invalid format %S: at character number %d, \\\n flag %C is only allowed after the '%%', before padding and precision\"\n str pct_ind symb\n | _ ->\n failwith_message\n \"invalid format %S: at character number %d, \\\n invalid conversion \\\"%%%c\\\"\" str (str_ind - 1) symb\n in\n (* Check for unused options, and reject them as incompatible.\n\n Such checks need to be disabled in legacy mode, as the legacy\n parser silently ignored incompatible flags. *)\n if not legacy_behavior then begin\n if not !plus_used && plus then\n incompatible_flag pct_ind str_ind symb \"'+'\";\n if not !hash_used && hash then\n incompatible_flag pct_ind str_ind symb \"'#'\";\n if not !space_used && space then\n incompatible_flag pct_ind str_ind symb \"' '\";\n if not !pad_used && Padding_EBB pad <> Padding_EBB No_padding then\n incompatible_flag pct_ind str_ind symb \"`padding'\";\n if not !prec_used && Precision_EBB prec <> Precision_EBB No_precision then\n incompatible_flag pct_ind str_ind (if ign then '_' else symb)\n \"`precision'\";\n if ign && plus then incompatible_flag pct_ind str_ind '_' \"'+'\";\n end;\n (* this last test must not be disabled in legacy mode,\n as ignoring it would typically result in a different typing\n than what the legacy parser used *)\n if not !ign_used && ign then\n begin match symb with\n (* argument-less formats can safely be ignored in legacy mode *)\n | ('@' | '%' | '!' | ',') when legacy_behavior -> ()\n | _ ->\n incompatible_flag pct_ind str_ind symb \"'_'\"\n end;\n fmt_result\n\n (* Parse formatting information (after '@'). *)\n and parse_after_at : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n fun str_ind end_ind ->\n if str_ind = end_ind then Fmt_EBB (Char_literal ('@', End_of_format))\n else\n match str.[str_ind] with\n | '[' ->\n parse_tag false (str_ind + 1) end_ind\n | ']' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Close_box, fmt_rest))\n | '{' ->\n parse_tag true (str_ind + 1) end_ind\n | '}' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Close_tag, fmt_rest))\n | ',' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Break (\"@,\", 0, 0), fmt_rest))\n | ' ' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Break (\"@ \", 1, 0), fmt_rest))\n | ';' ->\n parse_good_break (str_ind + 1) end_ind\n | '?' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (FFlush, fmt_rest))\n | '\\n' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Force_newline, fmt_rest))\n | '.' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Flush_newline, fmt_rest))\n | '<' ->\n parse_magic_size (str_ind + 1) end_ind\n | '@' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Escaped_at, fmt_rest))\n | '%' when str_ind + 1 < end_ind && str.[str_ind + 1] = '%' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 2) end_ind in\n Fmt_EBB (Formatting_lit (Escaped_percent, fmt_rest))\n | '%' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Char_literal ('@', fmt_rest))\n | c ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Scan_indic c, fmt_rest))\n\n (* Try to read the optional after \"@{\" or \"@[\". *)\n and parse_tag : type e f . bool -> int -> int -> (_, _, e, f) fmt_ebb =\n fun is_open_tag str_ind end_ind ->\n try\n if str_ind = end_ind then raise Not_found;\n match str.[str_ind] with\n | '<' ->\n let ind = String.index_from str (str_ind + 1) '>' in\n if ind >= end_ind then raise Not_found;\n let sub_str = String.sub str str_ind (ind - str_ind + 1) in\n let Fmt_EBB fmt_rest = parse (ind + 1) end_ind in\n let Fmt_EBB sub_fmt = parse str_ind (ind + 1) in\n let sub_format = Format (sub_fmt, sub_str) in\n let formatting =\n if is_open_tag then Open_tag sub_format else Open_box sub_format in\n Fmt_EBB (Formatting_gen (formatting, fmt_rest))\n | _ ->\n raise Not_found\n with Not_found ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n let sub_format = Format (End_of_format, \"\") in\n let formatting =\n if is_open_tag then Open_tag sub_format else Open_box sub_format in\n Fmt_EBB (Formatting_gen (formatting, fmt_rest))\n\n (* Try to read the optional after \"@;\". *)\n and parse_good_break : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n fun str_ind end_ind ->\n let next_ind, formatting_lit =\n try\n if str_ind = end_ind || str.[str_ind] <> '<' then raise Not_found;\n let str_ind_1 = parse_spaces (str_ind + 1) end_ind in\n match str.[str_ind_1] with\n | '0' .. '9' | '-' -> (\n let str_ind_2, width = parse_integer str_ind_1 end_ind in\n let str_ind_3 = parse_spaces str_ind_2 end_ind in\n match str.[str_ind_3] with\n | '>' ->\n let s = String.sub str (str_ind-2) (str_ind_3-str_ind+3) in\n str_ind_3 + 1, Break (s, width, 0)\n | '0' .. '9' | '-' ->\n let str_ind_4, offset = parse_integer str_ind_3 end_ind in\n let str_ind_5 = parse_spaces str_ind_4 end_ind in\n if str.[str_ind_5] <> '>' then raise Not_found;\n let s = String.sub str (str_ind-2) (str_ind_5-str_ind+3) in\n str_ind_5 + 1, Break (s, width, offset)\n | _ -> raise Not_found\n )\n | _ -> raise Not_found\n with Not_found | Failure _ ->\n str_ind, Break (\"@;\", 1, 0)\n in\n let Fmt_EBB fmt_rest = parse next_ind end_ind in\n Fmt_EBB (Formatting_lit (formatting_lit, fmt_rest))\n\n (* Parse the size in a . *)\n and parse_magic_size : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n fun str_ind end_ind ->\n match\n try\n let str_ind_1 = parse_spaces str_ind end_ind in\n match str.[str_ind_1] with\n | '0' .. '9' | '-' ->\n let str_ind_2, size = parse_integer str_ind_1 end_ind in\n let str_ind_3 = parse_spaces str_ind_2 end_ind in\n if str.[str_ind_3] <> '>' then raise Not_found;\n let s = String.sub str (str_ind - 2) (str_ind_3 - str_ind + 3) in\n Some (str_ind_3 + 1, Magic_size (s, size))\n | _ -> None\n with Not_found | Failure _ ->\n None\n with\n | Some (next_ind, formatting_lit) ->\n let Fmt_EBB fmt_rest = parse next_ind end_ind in\n Fmt_EBB (Formatting_lit (formatting_lit, fmt_rest))\n | None ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Formatting_lit (Scan_indic '<', fmt_rest))\n\n (* Parse and construct a char set. *)\n and parse_char_set str_ind end_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n\n let char_set = create_char_set () in\n let add_char c =\n add_in_char_set char_set c;\n in\n let add_range c c' =\n for i = int_of_char c to int_of_char c' do\n add_in_char_set char_set (char_of_int i);\n done;\n in\n\n let fail_single_percent str_ind =\n failwith_message\n \"invalid format %S: '%%' alone is not accepted in character sets, \\\n use %%%% instead at position %d.\" str str_ind\n in\n\n (* Parse the first character of a char set. *)\n let rec parse_char_set_start str_ind end_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n let c = str.[str_ind] in\n parse_char_set_after_char (str_ind + 1) end_ind c\n\n (* Parse the content of a char set until the first ']'. *)\n and parse_char_set_content str_ind end_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | ']' ->\n str_ind + 1\n | '-' ->\n add_char '-';\n parse_char_set_content (str_ind + 1) end_ind\n | c ->\n parse_char_set_after_char (str_ind + 1) end_ind c\n\n (* Test for range in char set. *)\n and parse_char_set_after_char str_ind end_ind c =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | ']' ->\n add_char c;\n str_ind + 1\n | '-' ->\n parse_char_set_after_minus (str_ind + 1) end_ind c\n | ('%' | '@') as c' when c = '%' ->\n add_char c';\n parse_char_set_content (str_ind + 1) end_ind\n | c' ->\n if c = '%' then fail_single_percent str_ind;\n (* note that '@' alone is accepted, as done by the legacy\n implementation; the documentation specifically requires %@\n so we could warn on that *)\n add_char c;\n parse_char_set_after_char (str_ind + 1) end_ind c'\n\n (* Manage range in char set (except if the '-' the last char before ']') *)\n and parse_char_set_after_minus str_ind end_ind c =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | ']' ->\n add_char c;\n add_char '-';\n str_ind + 1\n | '%' ->\n if str_ind + 1 = end_ind then unexpected_end_of_format end_ind;\n begin match str.[str_ind + 1] with\n | ('%' | '@') as c' ->\n add_range c c';\n parse_char_set_content (str_ind + 2) end_ind\n | _ -> fail_single_percent str_ind\n end\n | c' ->\n add_range c c';\n parse_char_set_content (str_ind + 1) end_ind\n in\n let str_ind, reverse =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | '^' -> str_ind + 1, true\n | _ -> str_ind, false in\n let next_ind = parse_char_set_start str_ind end_ind in\n let char_set = freeze_char_set char_set in\n next_ind, (if reverse then rev_char_set char_set else char_set)\n\n (* Consume all next spaces, raise an Failure if end_ind is reached. *)\n and parse_spaces str_ind end_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n if str.[str_ind] = ' ' then parse_spaces (str_ind + 1) end_ind else str_ind\n\n (* Read a positive integer from the string, raise a Failure if end_ind is\n reached. *)\n and parse_positive str_ind end_ind acc =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | '0' .. '9' as c ->\n let new_acc = acc * 10 + (int_of_char c - int_of_char '0') in\n if new_acc > Sys.max_string_length then\n failwith_message\n \"invalid format %S: integer %d is greater than the limit %d\"\n str new_acc Sys.max_string_length\n else\n parse_positive (str_ind + 1) end_ind new_acc\n | _ -> str_ind, acc\n\n (* Read a positive or negative integer from the string, raise a Failure\n if end_ind is reached. *)\n and parse_integer str_ind end_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | '0' .. '9' -> parse_positive str_ind end_ind 0\n | '-' -> (\n if str_ind + 1 = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind + 1] with\n | '0' .. '9' ->\n let next_ind, n = parse_positive (str_ind + 1) end_ind 0 in\n next_ind, -n\n | c ->\n expected_character (str_ind + 1) \"digit\" c\n )\n | _ -> assert false\n\n (* Add a literal to a format from a literal character sub-sequence. *)\n and add_literal : type a d e f .\n int -> int -> (a, _, _, d, e, f) fmt ->\n (_, _, e, f) fmt_ebb =\n fun lit_start str_ind fmt -> match str_ind - lit_start with\n | 0 -> Fmt_EBB fmt\n | 1 -> Fmt_EBB (Char_literal (str.[lit_start], fmt))\n | size -> Fmt_EBB (String_literal (String.sub str lit_start size, fmt))\n\n (* Search the end of the current sub-format\n (i.e. the corresponding \"%}\" or \"%)\") *)\n and search_subformat_end str_ind end_ind c =\n if str_ind = end_ind then\n failwith_message\n \"invalid format %S: unclosed sub-format, \\\n expected \\\"%%%c\\\" at character number %d\" str c end_ind;\n match str.[str_ind] with\n | '%' ->\n if str_ind + 1 = end_ind then unexpected_end_of_format end_ind;\n if str.[str_ind + 1] = c then (* End of format found *) str_ind else\n begin match str.[str_ind + 1] with\n | '_' ->\n (* Search for \"%_(\" or \"%_{\". *)\n if str_ind + 2 = end_ind then unexpected_end_of_format end_ind;\n begin match str.[str_ind + 2] with\n | '{' ->\n let sub_end = search_subformat_end (str_ind + 3) end_ind '}' in\n search_subformat_end (sub_end + 2) end_ind c\n | '(' ->\n let sub_end = search_subformat_end (str_ind + 3) end_ind ')' in\n search_subformat_end (sub_end + 2) end_ind c\n | _ -> search_subformat_end (str_ind + 3) end_ind c\n end\n | '{' ->\n (* %{...%} sub-format found. *)\n let sub_end = search_subformat_end (str_ind + 2) end_ind '}' in\n search_subformat_end (sub_end + 2) end_ind c\n | '(' ->\n (* %(...%) sub-format found. *)\n let sub_end = search_subformat_end (str_ind + 2) end_ind ')' in\n search_subformat_end (sub_end + 2) end_ind c\n | '}' ->\n (* Error: %(...%}. *)\n expected_character (str_ind + 1) \"character ')'\" '}'\n | ')' ->\n (* Error: %{...%). *)\n expected_character (str_ind + 1) \"character '}'\" ')'\n | _ ->\n search_subformat_end (str_ind + 2) end_ind c\n end\n | _ -> search_subformat_end (str_ind + 1) end_ind c\n\n (* Check if symb is a valid int conversion after \"%l\", \"%n\" or \"%L\" *)\n and is_int_base symb = match symb with\n | 'd' | 'i' | 'x' | 'X' | 'o' | 'u' -> true\n | _ -> false\n\n (* Convert a char (l, n or L) to its associated counter. *)\n and counter_of_char symb = match symb with\n | 'l' -> Line_counter | 'n' -> Char_counter\n | 'L' -> Token_counter | _ -> assert false\n\n (* Convert (plus, symb) to its associated int_conv. *)\n and compute_int_conv pct_ind str_ind plus hash space symb =\n match plus, hash, space, symb with\n | false, false, false, 'd' -> Int_d | false, false, false, 'i' -> Int_i\n | false, false, true, 'd' -> Int_sd | false, false, true, 'i' -> Int_si\n | true, false, false, 'd' -> Int_pd | true, false, false, 'i' -> Int_pi\n | false, false, false, 'x' -> Int_x | false, false, false, 'X' -> Int_X\n | false, true, false, 'x' -> Int_Cx | false, true, false, 'X' -> Int_CX\n | false, false, false, 'o' -> Int_o\n | false, true, false, 'o' -> Int_Co\n | false, false, false, 'u' -> Int_u\n | false, true, false, 'd' -> Int_Cd\n | false, true, false, 'i' -> Int_Ci\n | false, true, false, 'u' -> Int_Cu\n | _, true, _, 'x' when legacy_behavior -> Int_Cx\n | _, true, _, 'X' when legacy_behavior -> Int_CX\n | _, true, _, 'o' when legacy_behavior -> Int_Co\n | _, true, _, ('d' | 'i' | 'u') ->\n if legacy_behavior then (* ignore *)\n compute_int_conv pct_ind str_ind plus false space symb\n else incompatible_flag pct_ind str_ind symb \"'#'\"\n | true, _, true, _ ->\n if legacy_behavior then\n (* plus and space: legacy implementation prefers plus *)\n compute_int_conv pct_ind str_ind plus hash false symb\n else incompatible_flag pct_ind str_ind ' ' \"'+'\"\n | false, _, true, _ ->\n if legacy_behavior then (* ignore *)\n compute_int_conv pct_ind str_ind plus hash false symb\n else incompatible_flag pct_ind str_ind symb \"' '\"\n | true, _, false, _ ->\n if legacy_behavior then (* ignore *)\n compute_int_conv pct_ind str_ind false hash space symb\n else incompatible_flag pct_ind str_ind symb \"'+'\"\n | false, _, false, _ -> assert false\n\n (* Convert (plus, space, symb) to its associated float_conv. *)\n and compute_float_conv pct_ind str_ind plus hash space symb =\n let flag = match plus, space with\n | false, false -> Float_flag_\n | false, true -> Float_flag_s\n | true, false -> Float_flag_p\n | true, true ->\n (* plus and space: legacy implementation prefers plus *)\n if legacy_behavior then Float_flag_p\n else incompatible_flag pct_ind str_ind ' ' \"'+'\" in\n let kind = match hash, symb with\n | _, 'f' -> Float_f\n | _, 'e' -> Float_e\n | _, 'E' -> Float_E\n | _, 'g' -> Float_g\n | _, 'G' -> Float_G\n | _, 'h' -> Float_h\n | _, 'H' -> Float_H\n | false, 'F' -> Float_F\n | true, 'F' -> Float_CF\n | _ -> assert false in\n flag, kind\n\n (* Raise [Failure] with a friendly error message about incompatible options.*)\n and incompatible_flag : type a . int -> int -> char -> string -> a =\n fun pct_ind str_ind symb option ->\n let subfmt = String.sub str pct_ind (str_ind - pct_ind) in\n failwith_message\n \"invalid format %S: at character number %d, \\\n %s is incompatible with '%c' in sub-format %S\"\n str pct_ind option symb subfmt\n\n in parse 0 (String.length str)\n\n(******************************************************************************)\n (* Guarded string to format conversions *)\n\n(* Convert a string to a format according to an fmtty. *)\n(* Raise [Failure] with an error message in case of type mismatch. *)\nlet format_of_string_fmtty str fmtty =\n let Fmt_EBB fmt = fmt_ebb_of_string str in\n try Format (type_format fmt fmtty, str)\n with Type_mismatch ->\n failwith_message\n \"bad input: format type mismatch between %S and %S\"\n str (string_of_fmtty fmtty)\n\n(* Convert a string to a format compatible with an other format. *)\n(* Raise [Failure] with an error message in case of type mismatch. *)\nlet format_of_string_format str (Format (fmt', str')) =\n let Fmt_EBB fmt = fmt_ebb_of_string str in\n try Format (type_format fmt (fmtty_of_fmt fmt'), str)\n with Type_mismatch ->\n failwith_message\n \"bad input: format type mismatch between %S and %S\" str str'\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nopen Printf\n\ntype t = exn = ..\n\nlet printers = Atomic.make []\n\nlet locfmt = format_of_string \"File \\\"%s\\\", line %d, characters %d-%d: %s\"\n\nlet field x i =\n let f = Obj.field x i in\n if not (Obj.is_block f) then\n sprintf \"%d\" (Obj.magic f : int) (* can also be a char *)\n else if Obj.tag f = Obj.string_tag then\n sprintf \"%S\" (Obj.magic f : string)\n else if Obj.tag f = Obj.double_tag then\n string_of_float (Obj.magic f : float)\n else\n \"_\"\n\nlet rec other_fields x i =\n if i >= Obj.size x then \"\"\n else sprintf \", %s%s\" (field x i) (other_fields x (i+1))\n\nlet fields x =\n match Obj.size x with\n | 0 -> \"\"\n | 1 -> \"\"\n | 2 -> sprintf \"(%s)\" (field x 1)\n | _ -> sprintf \"(%s%s)\" (field x 1) (other_fields x 2)\n\nlet use_printers x =\n let rec conv = function\n | hd :: tl ->\n (match hd x with\n | None | exception _ -> conv tl\n | Some s -> Some s)\n | [] -> None in\n conv (Atomic.get printers)\n\nlet to_string_default = function\n | Out_of_memory -> \"Out of memory\"\n | Stack_overflow -> \"Stack overflow\"\n | Match_failure(file, line, char) ->\n sprintf locfmt file line char (char+5) \"Pattern matching failed\"\n | Assert_failure(file, line, char) ->\n sprintf locfmt file line char (char+6) \"Assertion failed\"\n | Undefined_recursive_module(file, line, char) ->\n sprintf locfmt file line char (char+6) \"Undefined recursive module\"\n | x ->\n let x = Obj.repr x in\n if Obj.tag x <> 0 then\n (Obj.magic (Obj.field x 0) : string)\n else\n let constructor =\n (Obj.magic (Obj.field (Obj.field x 0) 0) : string) in\n constructor ^ (fields x)\n\nlet to_string e =\n match use_printers e with\n | Some s -> s\n | None -> to_string_default e\n\nlet print fct arg =\n try\n fct arg\n with x ->\n eprintf \"Uncaught exception: %s\\n\" (to_string x);\n flush stderr;\n raise x\n\nlet catch fct arg =\n try\n fct arg\n with x ->\n flush stdout;\n eprintf \"Uncaught exception: %s\\n\" (to_string x);\n exit 2\n\ntype raw_backtrace_slot\ntype raw_backtrace_entry = private int\ntype raw_backtrace = raw_backtrace_entry array\n\nlet raw_backtrace_entries bt = bt\n\nexternal get_raw_backtrace:\n unit -> raw_backtrace = \"caml_get_exception_raw_backtrace\"\n\nexternal raise_with_backtrace: exn -> raw_backtrace -> 'a\n = \"%raise_with_backtrace\"\n\ntype backtrace_slot =\n | Known_location of {\n is_raise : bool;\n filename : string;\n line_number : int;\n start_char : int;\n end_char : int;\n is_inline : bool;\n defname : string;\n }\n | Unknown_location of {\n is_raise : bool\n }\n\n(* to avoid warning *)\nlet _ = [Known_location { is_raise = false; filename = \"\";\n line_number = 0; start_char = 0; end_char = 0;\n is_inline = false; defname = \"\" };\n Unknown_location { is_raise = false }]\n\nexternal convert_raw_backtrace_slot:\n raw_backtrace_slot -> backtrace_slot = \"caml_convert_raw_backtrace_slot\"\n\nexternal convert_raw_backtrace:\n raw_backtrace -> backtrace_slot array = \"caml_convert_raw_backtrace\"\n\nlet convert_raw_backtrace bt =\n try Some (convert_raw_backtrace bt)\n with Failure _ -> None\n\nlet format_backtrace_slot pos slot =\n let info is_raise =\n if is_raise then\n if pos = 0 then \"Raised at\" else \"Re-raised at\"\n else\n if pos = 0 then \"Raised by primitive operation at\" else \"Called from\"\n in\n match slot with\n | Unknown_location l ->\n if l.is_raise then\n (* compiler-inserted re-raise, skipped *) None\n else\n Some (sprintf \"%s unknown location\" (info false))\n | Known_location l ->\n Some (sprintf \"%s %s in file \\\"%s\\\"%s, line %d, characters %d-%d\"\n (info l.is_raise) l.defname l.filename\n (if l.is_inline then \" (inlined)\" else \"\")\n l.line_number l.start_char l.end_char)\n\nlet print_exception_backtrace outchan backtrace =\n match backtrace with\n | None ->\n fprintf outchan\n \"(Program not linked with -g, cannot print stack backtrace)\\n\"\n | Some a ->\n for i = 0 to Array.length a - 1 do\n match format_backtrace_slot i a.(i) with\n | None -> ()\n | Some str -> fprintf outchan \"%s\\n\" str\n done\n\nlet print_raw_backtrace outchan raw_backtrace =\n print_exception_backtrace outchan (convert_raw_backtrace raw_backtrace)\n\n(* confusingly named: prints the global current backtrace *)\nlet print_backtrace outchan =\n print_raw_backtrace outchan (get_raw_backtrace ())\n\nlet backtrace_to_string backtrace =\n match backtrace with\n | None ->\n \"(Program not linked with -g, cannot print stack backtrace)\\n\"\n | Some a ->\n let b = Buffer.create 1024 in\n for i = 0 to Array.length a - 1 do\n match format_backtrace_slot i a.(i) with\n | None -> ()\n | Some str -> bprintf b \"%s\\n\" str\n done;\n Buffer.contents b\n\nlet raw_backtrace_to_string raw_backtrace =\n backtrace_to_string (convert_raw_backtrace raw_backtrace)\n\nlet backtrace_slot_is_raise = function\n | Known_location l -> l.is_raise\n | Unknown_location l -> l.is_raise\n\nlet backtrace_slot_is_inline = function\n | Known_location l -> l.is_inline\n | Unknown_location _ -> false\n\ntype location = {\n filename : string;\n line_number : int;\n start_char : int;\n end_char : int;\n}\n\nlet backtrace_slot_location = function\n | Unknown_location _ -> None\n | Known_location l ->\n Some {\n filename = l.filename;\n line_number = l.line_number;\n start_char = l.start_char;\n end_char = l.end_char;\n }\n\nlet backtrace_slot_defname = function\n | Unknown_location _\n | Known_location { defname = \"\" } -> None\n | Known_location l -> Some l.defname\n\nlet backtrace_slots raw_backtrace =\n (* The documentation of this function guarantees that Some is\n returned only if a part of the trace is usable. This gives us\n a bit more work than just convert_raw_backtrace, but it makes the\n API more user-friendly -- otherwise most users would have to\n reimplement the \"Program not linked with -g, sorry\" logic\n themselves. *)\n match convert_raw_backtrace raw_backtrace with\n | None -> None\n | Some backtrace ->\n let usable_slot = function\n | Unknown_location _ -> false\n | Known_location _ -> true in\n let rec exists_usable = function\n | (-1) -> false\n | i -> usable_slot backtrace.(i) || exists_usable (i - 1) in\n if exists_usable (Array.length backtrace - 1)\n then Some backtrace\n else None\n\nlet backtrace_slots_of_raw_entry entry =\n backtrace_slots [| entry |]\n\nmodule Slot = struct\n type t = backtrace_slot\n let format = format_backtrace_slot\n let is_raise = backtrace_slot_is_raise\n let is_inline = backtrace_slot_is_inline\n let location = backtrace_slot_location\n let name = backtrace_slot_defname\nend\n\nlet raw_backtrace_length bt = Array.length bt\n\nexternal get_raw_backtrace_slot :\n raw_backtrace -> int -> raw_backtrace_slot = \"caml_raw_backtrace_slot\"\n\nexternal get_raw_backtrace_next_slot :\n raw_backtrace_slot -> raw_backtrace_slot option\n = \"caml_raw_backtrace_next_slot\"\n\n(* confusingly named:\n returns the *string* corresponding to the global current backtrace *)\nlet get_backtrace () = raw_backtrace_to_string (get_raw_backtrace ())\n\nexternal record_backtrace: bool -> unit = \"caml_record_backtrace\"\nexternal backtrace_status: unit -> bool = \"caml_backtrace_status\"\n\nlet rec register_printer fn =\n let old_printers = Atomic.get printers in\n let new_printers = fn :: old_printers in\n let success = Atomic.compare_and_set printers old_printers new_printers in\n if not success then register_printer fn\n\nexternal get_callstack: int -> raw_backtrace = \"caml_get_current_callstack\"\n\nlet exn_slot x =\n let x = Obj.repr x in\n if Obj.tag x = 0 then Obj.field x 0 else x\n\nlet exn_slot_id x =\n let slot = exn_slot x in\n (Obj.obj (Obj.field slot 1) : int)\n\nlet exn_slot_name x =\n let slot = exn_slot x in\n (Obj.obj (Obj.field slot 0) : string)\n\nexternal get_debug_info_status : unit -> int = \"caml_ml_debug_info_status\"\n\n(* Descriptions for errors in startup.h. See also backtrace.c *)\nlet errors = [| \"\";\n (* FILE_NOT_FOUND *)\n \"(Cannot print locations:\\n \\\n bytecode executable program file not found)\";\n (* BAD_BYTECODE *)\n \"(Cannot print locations:\\n \\\n bytecode executable program file appears to be corrupt)\";\n (* WRONG_MAGIC *)\n \"(Cannot print locations:\\n \\\n bytecode executable program file has wrong magic number)\";\n (* NO_FDS *)\n \"(Cannot print locations:\\n \\\n bytecode executable program file cannot be opened;\\n \\\n -- too many open files. Try running with OCAMLRUNPARAM=b=2)\"\n|]\n\nlet default_uncaught_exception_handler exn raw_backtrace =\n eprintf \"Fatal error: exception %s\\n\" (to_string exn);\n print_raw_backtrace stderr raw_backtrace;\n let status = get_debug_info_status () in\n if status < 0 then\n prerr_endline errors.(abs status);\n flush stderr\n\nlet uncaught_exception_handler = ref default_uncaught_exception_handler\n\nlet set_uncaught_exception_handler fn = uncaught_exception_handler := fn\n\nlet empty_backtrace : raw_backtrace = [| |]\n\nlet try_get_raw_backtrace () =\n try\n get_raw_backtrace ()\n with _ (* Out_of_memory? *) ->\n empty_backtrace\n\nlet handle_uncaught_exception' exn debugger_in_use =\n try\n (* Get the backtrace now, in case one of the [at_exit] function\n destroys it. *)\n let raw_backtrace =\n if debugger_in_use (* Same test as in [runtime/printexc.c] *) then\n empty_backtrace\n else\n try_get_raw_backtrace ()\n in\n (try Stdlib.do_at_exit () with _ -> ());\n try\n !uncaught_exception_handler exn raw_backtrace\n with exn' ->\n let raw_backtrace' = try_get_raw_backtrace () in\n eprintf \"Fatal error: exception %s\\n\" (to_string exn);\n print_raw_backtrace stderr raw_backtrace;\n eprintf \"Fatal error in uncaught exception handler: exception %s\\n\"\n (to_string exn');\n print_raw_backtrace stderr raw_backtrace';\n flush stderr\n with\n | Out_of_memory ->\n prerr_endline\n \"Fatal error: out of memory in uncaught exception handler\"\n\n(* This function is called by [caml_fatal_uncaught_exception] in\n [runtime/printexc.c] which expects no exception is raised. *)\nlet handle_uncaught_exception exn debugger_in_use =\n try\n handle_uncaught_exception' exn debugger_in_use\n with _ ->\n (* There is not much we can do at this point *)\n ()\n\nexternal register_named_value : string -> 'a -> unit\n = \"caml_register_named_value\"\n\nlet () =\n register_named_value \"Printexc.handle_uncaught_exception\"\n handle_uncaught_exception\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy and Damien Doligez, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nlet generic_quote quotequote s =\n let l = String.length s in\n let b = Buffer.create (l + 20) in\n Buffer.add_char b '\\'';\n for i = 0 to l - 1 do\n if s.[i] = '\\''\n then Buffer.add_string b quotequote\n else Buffer.add_char b s.[i]\n done;\n Buffer.add_char b '\\'';\n Buffer.contents b\n\n(* This function implements the Open Group specification found here:\n [[1]] http://pubs.opengroup.org/onlinepubs/9699919799/utilities/basename.html\n In step 1 of [[1]], we choose to return \".\" for empty input.\n (for compatibility with previous versions of OCaml)\n In step 2, we choose to process \"//\" normally.\n Step 6 is not implemented: we consider that the [suffix] operand is\n always absent. Suffixes are handled by [chop_suffix] and [chop_extension].\n*)\nlet generic_basename is_dir_sep current_dir_name name =\n let rec find_end n =\n if n < 0 then String.sub name 0 1\n else if is_dir_sep name n then find_end (n - 1)\n else find_beg n (n + 1)\n and find_beg n p =\n if n < 0 then String.sub name 0 p\n else if is_dir_sep name n then String.sub name (n + 1) (p - n - 1)\n else find_beg (n - 1) p\n in\n if name = \"\"\n then current_dir_name\n else find_end (String.length name - 1)\n\n(* This function implements the Open Group specification found here:\n [[2]] http://pubs.opengroup.org/onlinepubs/9699919799/utilities/dirname.html\n In step 6 of [[2]], we choose to process \"//\" normally.\n*)\nlet generic_dirname is_dir_sep current_dir_name name =\n let rec trailing_sep n =\n if n < 0 then String.sub name 0 1\n else if is_dir_sep name n then trailing_sep (n - 1)\n else base n\n and base n =\n if n < 0 then current_dir_name\n else if is_dir_sep name n then intermediate_sep n\n else base (n - 1)\n and intermediate_sep n =\n if n < 0 then String.sub name 0 1\n else if is_dir_sep name n then intermediate_sep (n - 1)\n else String.sub name 0 (n + 1)\n in\n if name = \"\"\n then current_dir_name\n else trailing_sep (String.length name - 1)\n\nmodule type SYSDEPS = sig\n val null : string\n val current_dir_name : string\n val parent_dir_name : string\n val dir_sep : string\n val is_dir_sep : string -> int -> bool\n val is_relative : string -> bool\n val is_implicit : string -> bool\n val check_suffix : string -> string -> bool\n val chop_suffix_opt : suffix:string -> string -> string option\n val temp_dir_name : string\n val quote : string -> string\n val quote_command :\n string -> ?stdin: string -> ?stdout: string -> ?stderr: string\n -> string list -> string\n val basename : string -> string\n val dirname : string -> string\nend\n\nmodule Unix : SYSDEPS = struct\n let null = \"/dev/null\"\n let current_dir_name = \".\"\n let parent_dir_name = \"..\"\n let dir_sep = \"/\"\n let is_dir_sep s i = s.[i] = '/'\n let is_relative n = String.length n < 1 || n.[0] <> '/'\n let is_implicit n =\n is_relative n\n && (String.length n < 2 || String.sub n 0 2 <> \"./\")\n && (String.length n < 3 || String.sub n 0 3 <> \"../\")\n let check_suffix name suff =\n String.ends_with ~suffix:suff name\n\n let chop_suffix_opt ~suffix filename =\n let len_s = String.length suffix and len_f = String.length filename in\n if len_f >= len_s then\n let r = String.sub filename (len_f - len_s) len_s in\n if r = suffix then\n Some (String.sub filename 0 (len_f - len_s))\n else\n None\n else\n None\n\n let temp_dir_name =\n try Sys.getenv \"TMPDIR\" with Not_found -> \"/tmp\"\n let quote = generic_quote \"'\\\\''\"\n let quote_command cmd ?stdin ?stdout ?stderr args =\n String.concat \" \" (List.map quote (cmd :: args))\n ^ (match stdin with None -> \"\" | Some f -> \" <\" ^ quote f)\n ^ (match stdout with None -> \"\" | Some f -> \" >\" ^ quote f)\n ^ (match stderr with None -> \"\" | Some f -> if stderr = stdout\n then \" 2>&1\"\n else \" 2>\" ^ quote f)\n let basename = generic_basename is_dir_sep current_dir_name\n let dirname = generic_dirname is_dir_sep current_dir_name\nend\n\nmodule Win32 : SYSDEPS = struct\n let null = \"NUL\"\n let current_dir_name = \".\"\n let parent_dir_name = \"..\"\n let dir_sep = \"\\\\\"\n let is_dir_sep s i = let c = s.[i] in c = '/' || c = '\\\\' || c = ':'\n let is_relative n =\n (String.length n < 1 || n.[0] <> '/')\n && (String.length n < 1 || n.[0] <> '\\\\')\n && (String.length n < 2 || n.[1] <> ':')\n let is_implicit n =\n is_relative n\n && (String.length n < 2 || String.sub n 0 2 <> \"./\")\n && (String.length n < 2 || String.sub n 0 2 <> \".\\\\\")\n && (String.length n < 3 || String.sub n 0 3 <> \"../\")\n && (String.length n < 3 || String.sub n 0 3 <> \"..\\\\\")\n let check_suffix name suff =\n String.length name >= String.length suff &&\n (let s = String.sub name (String.length name - String.length suff)\n (String.length suff) in\n String.lowercase_ascii s = String.lowercase_ascii suff)\n\n let chop_suffix_opt ~suffix filename =\n let len_s = String.length suffix and len_f = String.length filename in\n if len_f >= len_s then\n let r = String.sub filename (len_f - len_s) len_s in\n if String.lowercase_ascii r = String.lowercase_ascii suffix then\n Some (String.sub filename 0 (len_f - len_s))\n else\n None\n else\n None\n\n\n let temp_dir_name =\n try Sys.getenv \"TEMP\" with Not_found -> \".\"\n let quote s =\n let l = String.length s in\n let b = Buffer.create (l + 20) in\n Buffer.add_char b '\\\"';\n let rec loop i =\n if i = l then Buffer.add_char b '\\\"' else\n match s.[i] with\n | '\\\"' -> loop_bs 0 i;\n | '\\\\' -> loop_bs 0 i;\n | c -> Buffer.add_char b c; loop (i+1);\n and loop_bs n i =\n if i = l then begin\n Buffer.add_char b '\\\"';\n add_bs n;\n end else begin\n match s.[i] with\n | '\\\"' -> add_bs (2*n+1); Buffer.add_char b '\\\"'; loop (i+1);\n | '\\\\' -> loop_bs (n+1) (i+1);\n | _ -> add_bs n; loop i\n end\n and add_bs n = for _j = 1 to n do Buffer.add_char b '\\\\'; done\n in\n loop 0;\n Buffer.contents b\n(*\nQuoting commands for execution by cmd.exe is difficult.\n1- Each argument is first quoted using the \"quote\" function above, to\n protect it against the processing performed by the C runtime system,\n then cmd.exe's special characters are escaped with '^', using\n the \"quote_cmd\" function below. For more details, see\n https://blogs.msdn.microsoft.com/twistylittlepassagesallalike/2011/04/23\n2- The command and the redirection files, if any, must be double-quoted\n in case they contain spaces. This quoting is interpreted by cmd.exe,\n not by the C runtime system, hence the \"quote\" function above\n cannot be used. The two characters we don't know how to quote\n inside a double-quoted cmd.exe string are double-quote and percent.\n We just fail if the command name or the redirection file names\n contain a double quote (not allowed in Windows file names, anyway)\n or a percent. See function \"quote_cmd_filename\" below.\n3- The whole string passed to Sys.command is then enclosed in double\n quotes, which are immediately stripped by cmd.exe. Otherwise,\n some of the double quotes from step 2 above can be misparsed.\n See e.g. https://stackoverflow.com/a/9965141\n*)\n let quote_cmd s =\n let b = Buffer.create (String.length s + 20) in\n String.iter\n (fun c ->\n match c with\n | '(' | ')' | '!' | '^' | '%' | '\\\"' | '<' | '>' | '&' | '|' ->\n Buffer.add_char b '^'; Buffer.add_char b c\n | _ ->\n Buffer.add_char b c)\n s;\n Buffer.contents b\n let quote_cmd_filename f =\n if String.contains f '\\\"' || String.contains f '%' then\n failwith (\"Filename.quote_command: bad file name \" ^ f)\n else if String.contains f ' ' then\n \"\\\"\" ^ f ^ \"\\\"\"\n else\n f\n (* Redirections in cmd.exe: see https://ss64.com/nt/syntax-redirection.html\n and https://docs.microsoft.com/en-us/previous-versions/windows/it-pro/windows-xp/bb490982(v=technet.10)\n *)\n let quote_command cmd ?stdin ?stdout ?stderr args =\n String.concat \"\" [\n \"\\\"\";\n quote_cmd_filename cmd;\n \" \";\n quote_cmd (String.concat \" \" (List.map quote args));\n (match stdin with None -> \"\" | Some f -> \" <\" ^ quote_cmd_filename f);\n (match stdout with None -> \"\" | Some f -> \" >\" ^ quote_cmd_filename f);\n (match stderr with None -> \"\" | Some f ->\n if stderr = stdout\n then \" 2>&1\"\n else \" 2>\" ^ quote_cmd_filename f);\n \"\\\"\"\n ]\n let has_drive s =\n let is_letter = function\n | 'A' .. 'Z' | 'a' .. 'z' -> true\n | _ -> false\n in\n String.length s >= 2 && is_letter s.[0] && s.[1] = ':'\n let drive_and_path s =\n if has_drive s\n then (String.sub s 0 2, String.sub s 2 (String.length s - 2))\n else (\"\", s)\n let dirname s =\n let (drive, path) = drive_and_path s in\n let dir = generic_dirname is_dir_sep current_dir_name path in\n drive ^ dir\n let basename s =\n let (_drive, path) = drive_and_path s in\n generic_basename is_dir_sep current_dir_name path\nend\n\nmodule Cygwin : SYSDEPS = struct\n let null = \"/dev/null\"\n let current_dir_name = \".\"\n let parent_dir_name = \"..\"\n let dir_sep = \"/\"\n let is_dir_sep = Win32.is_dir_sep\n let is_relative = Win32.is_relative\n let is_implicit = Win32.is_implicit\n let check_suffix = Win32.check_suffix\n let chop_suffix_opt = Win32.chop_suffix_opt\n let temp_dir_name = Unix.temp_dir_name\n let quote = Unix.quote\n let quote_command = Unix.quote_command\n let basename = generic_basename is_dir_sep current_dir_name\n let dirname = generic_dirname is_dir_sep current_dir_name\nend\n\nmodule Sysdeps =\n (val (match Sys.os_type with\n | \"Win32\" -> (module Win32: SYSDEPS)\n | \"Cygwin\" -> (module Cygwin: SYSDEPS)\n | _ -> (module Unix: SYSDEPS)))\n\ninclude Sysdeps\n\nlet concat dirname filename =\n let l = String.length dirname in\n if l = 0 || is_dir_sep dirname (l-1)\n then dirname ^ filename\n else dirname ^ dir_sep ^ filename\n\nlet chop_suffix name suff =\n if check_suffix name suff\n then String.sub name 0 (String.length name - String.length suff)\n else invalid_arg \"Filename.chop_suffix\"\n\nlet extension_len name =\n let rec check i0 i =\n if i < 0 || is_dir_sep name i then 0\n else if name.[i] = '.' then check i0 (i - 1)\n else String.length name - i0\n in\n let rec search_dot i =\n if i < 0 || is_dir_sep name i then 0\n else if name.[i] = '.' then check i (i - 1)\n else search_dot (i - 1)\n in\n search_dot (String.length name - 1)\n\nlet extension name =\n let l = extension_len name in\n if l = 0 then \"\" else String.sub name (String.length name - l) l\n\nlet chop_extension name =\n let l = extension_len name in\n if l = 0 then invalid_arg \"Filename.chop_extension\"\n else String.sub name 0 (String.length name - l)\n\nlet remove_extension name =\n let l = extension_len name in\n if l = 0 then name else String.sub name 0 (String.length name - l)\n\nexternal open_desc: string -> open_flag list -> int -> int = \"caml_sys_open\"\nexternal close_desc: int -> unit = \"caml_sys_close\"\n\nlet prng = lazy(Random.State.make_self_init ())\n\nlet temp_file_name temp_dir prefix suffix =\n let rnd = (Random.State.bits (Lazy.force prng)) land 0xFFFFFF in\n concat temp_dir (Printf.sprintf \"%s%06x%s\" prefix rnd suffix)\n\n\nlet current_temp_dir_name = ref temp_dir_name\n\nlet set_temp_dir_name s = current_temp_dir_name := s\nlet get_temp_dir_name () = !current_temp_dir_name\n\nlet temp_file ?(temp_dir = !current_temp_dir_name) prefix suffix =\n let rec try_name counter =\n let name = temp_file_name temp_dir prefix suffix in\n try\n close_desc(open_desc name [Open_wronly; Open_creat; Open_excl] 0o600);\n name\n with Sys_error _ as e ->\n if counter >= 1000 then raise e else try_name (counter + 1)\n in try_name 0\n\nlet open_temp_file ?(mode = [Open_text]) ?(perms = 0o600)\n ?(temp_dir = !current_temp_dir_name) prefix suffix =\n let rec try_name counter =\n let name = temp_file_name temp_dir prefix suffix in\n try\n (name,\n open_out_gen (Open_wronly::Open_creat::Open_excl::mode) perms name)\n with Sys_error _ as e ->\n if counter >= 1000 then raise e else try_name (counter + 1)\n in try_name 0\n","open! Import\n\ntype t = exn [@@deriving_inline sexp_of]\n\nlet sexp_of_t = (sexp_of_exn : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n[@@@end]\n\nlet exit = Caml.exit\n\nexception Finally of t * t [@@deriving_inline sexp]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add [%extension_constructor Finally] (function\n | Finally (v0, v1) ->\n let v0 = sexp_of_t v0\n and v1 = sexp_of_t v1 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"exn.ml.Finally\"; v0; v1 ]\n | _ -> assert false)\n;;\n\n[@@@end]\n\nexception Reraised of string * t [@@deriving_inline sexp]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add [%extension_constructor Reraised] (function\n | Reraised (v0, v1) ->\n let v0 = sexp_of_string v0\n and v1 = sexp_of_t v1 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"exn.ml.Reraised\"; v0; v1 ]\n | _ -> assert false)\n;;\n\n[@@@end]\n\nexception Sexp of Sexp.t\n\n(* We install a custom exn-converter rather than use:\n\n {[\n exception Sexp of Sexp.t [@@deriving_inline sexp]\n (* ... *)\n [@@@end]\n ]}\n\n to eliminate the extra wrapping of [(Sexp ...)]. *)\nlet () =\n Sexplib.Conv.Exn_converter.add [%extension_constructor Sexp] (function\n | Sexp t -> t\n | _ ->\n (* Reaching this branch indicates a bug in sexplib. *)\n assert false)\n;;\n\nlet create_s sexp = Sexp sexp\nlet reraise exc str = raise (Reraised (str, exc))\nlet reraisef exc format = Printf.ksprintf (fun str () -> reraise exc str) format\nlet to_string exc = Sexp.to_string_hum ~indent:2 (sexp_of_exn exc)\nlet to_string_mach exc = Sexp.to_string_mach (sexp_of_exn exc)\nlet sexp_of_t = sexp_of_exn\n\nlet protectx ~f x ~(finally : _ -> unit) =\n match f x with\n | res ->\n finally x;\n res\n | exception exn ->\n raise\n (match finally x with\n | () -> exn\n | exception final_exn -> Finally (exn, final_exn))\n;;\n\nlet protect ~f ~finally = protectx ~f () ~finally\n\nlet does_raise (type a) (f : unit -> a) =\n try\n ignore (f () : a);\n false\n with\n | _ -> true\n;;\n\ninclude Pretty_printer.Register_pp (struct\n type t = exn\n\n let pp ppf t =\n match sexp_of_exn_opt t with\n | Some sexp -> Sexp.pp_hum ppf sexp\n | None -> Caml.Format.pp_print_string ppf (Caml.Printexc.to_string t)\n ;;\n\n let module_name = \"Base.Exn\"\n end)\n\nlet print_with_backtrace exc raw_backtrace =\n Caml.Format.eprintf \"@[<2>Uncaught exception:@\\n@\\n@[%a@]@]@\\n@.\" pp exc;\n if Caml.Printexc.backtrace_status ()\n then Caml.Printexc.print_raw_backtrace Caml.stderr raw_backtrace;\n Caml.flush Caml.stderr\n;;\n\nlet set_uncaught_exception_handler () =\n Caml.Printexc.set_uncaught_exception_handler print_with_backtrace\n;;\n\nlet handle_uncaught_aux ~do_at_exit ~exit f =\n try f () with\n | exc ->\n let raw_backtrace = Caml.Printexc.get_raw_backtrace () in\n (* One reason to run [do_at_exit] handlers before printing out the error message is\n that it helps curses applications bring the terminal in a good state, otherwise the\n error message might get corrupted. Also, the OCaml top-level uncaught exception\n handler does the same. *)\n if do_at_exit\n then (\n try Caml.do_at_exit () with\n | _ -> ());\n (try print_with_backtrace exc raw_backtrace with\n | _ ->\n (try\n Caml.Printf.eprintf \"Exn.handle_uncaught could not print; exiting anyway\\n%!\"\n with\n | _ -> ()));\n exit 1\n;;\n\nlet handle_uncaught_and_exit f = handle_uncaught_aux f ~exit ~do_at_exit:true\n\nlet handle_uncaught ~exit:must_exit f =\n handle_uncaught_aux f ~exit:(if must_exit then exit else ignore) ~do_at_exit:must_exit\n;;\n\nlet reraise_uncaught str func =\n try func () with\n | exn -> raise (Reraised (str, exn))\n;;\n\nexternal clear_backtrace : unit -> unit = \"Base_clear_caml_backtrace_pos\" [@@noalloc]\n\nlet raise_without_backtrace e =\n (* We clear the backtrace to reduce confusion, so that people don't think whatever\n is stored corresponds to this raise. *)\n clear_backtrace ();\n Caml.raise_notrace e\n;;\n\nlet initialize_module () = set_uncaught_exception_handler ()\n\nmodule Private = struct\n let clear_backtrace = clear_backtrace\nend\n","(* This is broken off to avoid circular dependency between Sign and Comparable. *)\n\nopen! Import\n\ntype t =\n | Neg\n | Zero\n | Pos\n[@@deriving_inline sexp, compare, hash, enumerate]\n\nlet t_of_sexp =\n (let _tp_loc = \"sign0.ml.t\" in\n function\n | Ppx_sexp_conv_lib.Sexp.Atom (\"neg\" | \"Neg\") -> Neg\n | Ppx_sexp_conv_lib.Sexp.Atom (\"zero\" | \"Zero\") -> Zero\n | Ppx_sexp_conv_lib.Sexp.Atom (\"pos\" | \"Pos\") -> Pos\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"neg\" | \"Neg\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"zero\" | \"Zero\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"pos\" | \"Pos\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> t)\n;;\n\nlet sexp_of_t =\n (function\n | Neg -> Ppx_sexp_conv_lib.Sexp.Atom \"Neg\"\n | Zero -> Ppx_sexp_conv_lib.Sexp.Atom \"Zero\"\n | Pos -> Ppx_sexp_conv_lib.Sexp.Atom \"Pos\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\nlet compare = (Ppx_compare_lib.polymorphic_compare : t -> t -> int)\n\nlet (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n (fun hsv arg ->\n match arg with\n | Neg -> Ppx_hash_lib.Std.Hash.fold_int hsv 0\n | Zero -> Ppx_hash_lib.Std.Hash.fold_int hsv 1\n | Pos -> Ppx_hash_lib.Std.Hash.fold_int hsv 2\n : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state)\n;;\n\nlet (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func arg =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (let hsv = Ppx_hash_lib.Std.Hash.create () in\n hash_fold_t hsv arg)\n in\n fun x -> func x\n;;\n\nlet all = ([ Neg; Zero; Pos ] : t list)\n\n[@@@end]\n\nmodule Replace_polymorphic_compare = struct\n let ( < ) (x : t) y = Poly.( < ) x y\n let ( <= ) (x : t) y = Poly.( <= ) x y\n let ( <> ) (x : t) y = Poly.( <> ) x y\n let ( = ) (x : t) y = Poly.( = ) x y\n let ( > ) (x : t) y = Poly.( > ) x y\n let ( >= ) (x : t) y = Poly.( >= ) x y\n let ascending (x : t) y = Poly.ascending x y\n let descending (x : t) y = Poly.descending x y\n let compare (x : t) y = Poly.compare x y\n let equal (x : t) y = Poly.equal x y\n let max (x : t) y = if x >= y then x else y\n let min (x : t) y = if x <= y then x else y\nend\n\nlet of_string s = t_of_sexp (sexp_of_string s)\nlet to_string t = string_of_sexp (sexp_of_t t)\n\nlet to_int = function\n | Neg -> -1\n | Zero -> 0\n | Pos -> 1\n;;\n\nlet _ = hash\n\n(* Ignore the hash function produced by [@@deriving_inline hash] *)\nlet hash = to_int\nlet module_name = \"Base.Sign\"\nlet of_int n = if n < 0 then Neg else if n = 0 then Zero else Pos\n","# 1 \"src/hex_lexer.mll\"\n \ntype result =\n| Neg of string\n| Pos of string\n\n# 8 \"src/hex_lexer.ml\"\nlet __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\000\\000\\001\\000\\001\\000\\002\\000\\027\\000\\082\\000\\105\\000\\\n \";\n Lexing.lex_backtrk =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\001\\000\\\n \";\n Lexing.lex_default =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\002\\000\\000\\000\\000\\000\\\n \\001\\000\\003\\000\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\005\\000\\005\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\000\\000\\000\\000\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\000\\000\\000\\000\\000\\000\\\n \\006\\000\\004\\000\\000\\000\\000\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\000\\000\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\006\\000\\004\\000\\005\\000\\000\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\007\\000\\007\\000\\007\\000\\007\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\007\\000\\007\\000\\007\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\000\\000\\000\\000\\000\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\007\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\007\\000\\000\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\000\\000\\002\\000\\004\\000\\004\\000\\004\\000\\004\\000\\004\\000\\004\\000\\\n \\004\\000\\004\\000\\004\\000\\004\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\004\\000\\004\\000\\004\\000\\004\\000\\004\\000\\\n \\004\\000\\255\\255\\255\\255\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\255\\255\\255\\255\\255\\255\\\n \\001\\000\\003\\000\\255\\255\\255\\255\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\255\\255\\004\\000\\004\\000\\004\\000\\004\\000\\004\\000\\\n \\004\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\001\\000\\003\\000\\005\\000\\255\\255\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\006\\000\\006\\000\\006\\000\\006\\000\\006\\000\\006\\000\\\n \\006\\000\\006\\000\\006\\000\\006\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\006\\000\\006\\000\\006\\000\\006\\000\\006\\000\\\n \\006\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\007\\000\\007\\000\\007\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\255\\255\\255\\255\\255\\255\\006\\000\\006\\000\\006\\000\\006\\000\\006\\000\\\n \\006\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\007\\000\\255\\255\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec parse_hex lexbuf =\n __ocaml_lex_parse_hex_rec lexbuf 0\nand __ocaml_lex_parse_hex_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n# 8 \"src/hex_lexer.mll\"\n body\n# 135 \"src/hex_lexer.ml\"\n= Lexing.sub_lexeme lexbuf (lexbuf.Lexing.lex_start_pos + 3) lexbuf.Lexing.lex_curr_pos in\n# 14 \"src/hex_lexer.mll\"\n ( Neg body )\n# 139 \"src/hex_lexer.ml\"\n\n | 1 ->\nlet\n# 8 \"src/hex_lexer.mll\"\n body\n# 145 \"src/hex_lexer.ml\"\n= Lexing.sub_lexeme lexbuf (lexbuf.Lexing.lex_start_pos + 2) lexbuf.Lexing.lex_curr_pos in\n# 15 \"src/hex_lexer.mll\"\n ( Pos body )\n# 149 \"src/hex_lexer.ml\"\n\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_parse_hex_rec lexbuf __ocaml_lex_state\n\n;;\n\n","open! Import\n\n(* C stub for int popcount to use the POPCNT instruction where possible *)\nexternal int_popcount : int -> int = \"Base_int_math_int_popcount\" [@@noalloc]\n\n(* To maintain javascript compatibility and enable unboxing, we implement popcount in\n OCaml rather than use C stubs. Implementation adapted from:\n https://en.wikipedia.org/wiki/Hamming_weight#Efficient_implementation *)\nlet int64_popcount =\n let open Caml.Int64 in\n let ( + ) = add in\n let ( - ) = sub in\n let ( * ) = mul in\n let ( lsr ) = shift_right_logical in\n let ( land ) = logand in\n let m1 = 0x5555555555555555L in\n (* 0b01010101... *)\n let m2 = 0x3333333333333333L in\n (* 0b00110011... *)\n let m4 = 0x0f0f0f0f0f0f0f0fL in\n (* 0b00001111... *)\n let h01 = 0x0101010101010101L in\n (* 1 bit set per byte *)\n fun [@inline] x ->\n (* gather the bit count for every pair of bits *)\n let x = x - ((x lsr 1) land m1) in\n (* gather the bit count for every 4 bits *)\n let x = (x land m2) + ((x lsr 2) land m2) in\n (* gather the bit count for every byte *)\n let x = (x + (x lsr 4)) land m4 in\n (* sum the bit counts in the top byte and shift it down *)\n to_int ((x * h01) lsr 56)\n;;\n\nlet int32_popcount =\n (* On 64-bit systems, this is faster than implementing using [int32] arithmetic. *)\n let mask = 0xffff_ffffL in\n fun [@inline] x -> int64_popcount (Caml.Int64.logand (Caml.Int64.of_int32 x) mask)\n;;\n\nlet nativeint_popcount =\n match Caml.Nativeint.size with\n | 32 -> fun [@inline] x -> int32_popcount (Caml.Nativeint.to_int32 x)\n | 64 -> fun [@inline] x -> int64_popcount (Caml.Int64.of_nativeint x)\n | _ -> assert false\n;;\n","(* A 63bit integer is a 64bit integer with its bits shifted to the left\n and its lowest bit set to 0.\n This is the same kind of encoding as OCaml int on 64bit architecture.\n The only difference being the lowest bit (immediate bit) set to 1. *)\n\nopen! Import\ninclude Int64_replace_polymorphic_compare\n\n\nmodule T0 = struct\n module T = struct\n type t = int64 [@@deriving_inline compare, hash, sexp, sexp_grammar]\n\n let compare = (compare_int64 : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int64\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int64 in\n fun x -> func x\n ;;\n\n let t_of_sexp = (int64_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_int64 : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group)\n =\n { implicit_vars = [ \"int64\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ int64_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"int63_emul.ml.T0.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n end\n\n include T\n include Comparator.Make (T)\nend\n\nmodule Conv = Int_conversions\n\nmodule W : sig\n\n type t = int64\n\n include module type of struct\n include T0\n end\n with type t := t\n\n val wrap_exn : Caml.Int64.t -> t\n val wrap_modulo : Caml.Int64.t -> t\n val unwrap : t -> Caml.Int64.t\n\n (** Returns a non-negative int64 that is equal to the input int63 modulo 2^63. *)\n val unwrap_unsigned : t -> Caml.Int64.t\n\n val invariant : t -> unit\n val add : t -> t -> t\n val sub : t -> t -> t\n val neg : t -> t\n val abs : t -> t\n val succ : t -> t\n val pred : t -> t\n val mul : t -> t -> t\n val pow : t -> t -> t\n val div : t -> t -> t\n val rem : t -> t -> t\n val popcount : t -> int\n val bit_not : t -> t\n val bit_xor : t -> t -> t\n val bit_or : t -> t -> t\n val bit_and : t -> t -> t\n val shift_left : t -> int -> t\n val shift_right : t -> int -> t\n val shift_right_logical : t -> int -> t\n val min_value : t\n val max_value : t\n val to_int64 : t -> Caml.Int64.t\n val of_int64 : Caml.Int64.t -> t option\n val of_int64_exn : Caml.Int64.t -> t\n val of_int64_trunc : Caml.Int64.t -> t\n val compare : t -> t -> int\n val ceil_pow2 : t -> t\n val floor_pow2 : t -> t\n val ceil_log2 : t -> int\n val floor_log2 : t -> int\n val is_pow2 : t -> bool\n val clz : t -> int\n val ctz : t -> int\nend = struct\n type t = int64\n\n include (\n T0 :\n module type of struct\n include T0\n end\n with type t := t)\n\n let wrap_exn x =\n (* Raises if the int64 value does not fit on int63. *)\n Conv.int64_fit_on_int63_exn x;\n Caml.Int64.mul x 2L\n ;;\n\n let wrap x =\n if Conv.int64_is_representable_as_int63 x then Some (Caml.Int64.mul x 2L) else None\n ;;\n\n let wrap_modulo x = Caml.Int64.mul x 2L\n let unwrap x = Caml.Int64.shift_right x 1\n let unwrap_unsigned x = Caml.Int64.shift_right_logical x 1\n\n (* This does not use wrap or unwrap to avoid generating exceptions in the case of\n overflows. This is to preserve the semantics of int type on 64 bit architecture. *)\n let f2 f a b =\n Caml.Int64.mul (f (Caml.Int64.shift_right a 1) (Caml.Int64.shift_right b 1)) 2L\n ;;\n\n let mask = 0xffff_ffff_ffff_fffeL\n let m x = Caml.Int64.logand x mask\n let invariant t = assert (m t = t)\n let add x y = Caml.Int64.add x y\n let sub x y = Caml.Int64.sub x y\n let neg x = Caml.Int64.neg x\n let abs x = Caml.Int64.abs x\n let one = wrap_exn 1L\n let succ a = add a one\n let pred a = sub a one\n let min_value = m Caml.Int64.min_int\n let max_value = m Caml.Int64.max_int\n let bit_not x = m (Caml.Int64.lognot x)\n let bit_and = Caml.Int64.logand\n let bit_xor = Caml.Int64.logxor\n let bit_or = Caml.Int64.logor\n let shift_left x i = Caml.Int64.shift_left x i\n let shift_right x i = m (Caml.Int64.shift_right x i)\n let shift_right_logical x i = m (Caml.Int64.shift_right_logical x i)\n let pow = f2 Int_math.Private.int63_pow_on_int64\n let mul a b = Caml.Int64.mul a (Caml.Int64.shift_right b 1)\n let div a b = wrap_modulo (Caml.Int64.div a b)\n let rem a b = Caml.Int64.rem a b\n let popcount x = Popcount.int64_popcount x\n let to_int64 t = unwrap t\n let of_int64 t = wrap t\n let of_int64_exn t = wrap_exn t\n let of_int64_trunc t = wrap_modulo t\n let t_of_sexp x = wrap_exn (int64_of_sexp x)\n let sexp_of_t x = sexp_of_int64 (unwrap x)\n let compare (x : t) y = compare x y\n let is_pow2 x = Int64.is_pow2 (unwrap x)\n\n let clz x =\n (* We run Int64.clz directly on the wrapped int63 value. This is correct because the\n bits of the int63_emul are left-aligned in the Int64. *)\n Int64.clz x\n ;;\n\n let ctz x = Int64.ctz (unwrap x)\n let floor_pow2 x = Int64.floor_pow2 (unwrap x) |> wrap_exn\n let ceil_pow2 x = Int64.floor_pow2 (unwrap x) |> wrap_exn\n let floor_log2 x = Int64.floor_log2 (unwrap x)\n let ceil_log2 x = Int64.ceil_log2 (unwrap x)\nend\n\nopen W\n\nmodule T = struct\n type t = W.t [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n W.hash_fold_t\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = W.hash in\n fun x -> func x\n ;;\n\n let t_of_sexp = (W.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (W.sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"W.t\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ W.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"int63_emul.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n type comparator_witness = W.comparator_witness\n\n let comparator = W.comparator\n let compare = W.compare\n let invariant = W.invariant\n\n (* We don't expect [hash] to follow the behavior of int in 64bit architecture *)\n let _ = hash\n let hash (x : t) = Caml.Hashtbl.hash x\n let invalid_str x = Printf.failwithf \"Int63.of_string: invalid input %S\" x ()\n\n (*\n \"sign\" refers to whether the number starts with a '-'\n \"signedness = false\" means the rest of the number is parsed as unsigned and then cast\n to signed with wrap-around modulo 2^i\n \"signedness = true\" means no such craziness happens\n\n The terminology and the logic is due to the code in byterun/ints.c in ocaml 4.03\n ([parse_sign_and_base] function).\n\n Signedness equals true for plain decimal number (e.g. 1235, -6789)\n\n Signedness equals false in the following cases:\n - [0xffff], [-0xffff] (hexadecimal representation)\n - [0b0101], [-0b0101] (binary representation)\n - [0o1237], [-0o1237] (octal representation)\n - [0u9812], [-0u9812] (unsigned decimal representation - available from OCaml 4.03) *)\n let sign_and_signedness x =\n let len = String.length x in\n let open Int_replace_polymorphic_compare in\n let pos, sign =\n if 0 < len\n then (\n match x.[0] with\n | '-' -> 1, `Neg\n | '+' -> 1, `Pos\n | _ -> 0, `Pos)\n else 0, `Pos\n in\n if pos + 2 < len\n then (\n let c1 = x.[pos] in\n let c2 = x.[pos + 1] in\n match c1, c2 with\n | '0', '0' .. '9' -> sign, true\n | '0', _ -> sign, false\n | _ -> sign, true)\n else sign, true\n ;;\n\n let to_string x = Caml.Int64.to_string (unwrap x)\n\n let of_string str =\n try\n let sign, signedness = sign_and_signedness str in\n if signedness\n then of_int64_exn (Caml.Int64.of_string str)\n else (\n let pos_str =\n match sign with\n | `Neg -> String.sub str ~pos:1 ~len:(String.length str - 1)\n | `Pos -> str\n in\n let int64 = Caml.Int64.of_string pos_str in\n (* unsigned 63-bit int must parse as a positive signed 64-bit int *)\n if Int64_replace_polymorphic_compare.( < ) int64 0L then invalid_str str;\n let int63 = wrap_modulo int64 in\n match sign with\n | `Neg -> neg int63\n | `Pos -> int63)\n with\n | _ -> invalid_str str\n ;;\n\n let bswap16 t = wrap_modulo (Int64.bswap16 (unwrap t))\n let bswap32 t = wrap_modulo (Int64.bswap32 (unwrap t))\n let bswap48 t = wrap_modulo (Int64.bswap48 (unwrap t))\nend\n\ninclude T\n\nlet num_bits = 63\nlet float_lower_bound = Float0.lower_bound_for_int num_bits\nlet float_upper_bound = Float0.upper_bound_for_int num_bits\nlet shift_right_logical = shift_right_logical\nlet shift_right = shift_right\nlet shift_left = shift_left\nlet bit_not = bit_not\nlet bit_xor = bit_xor\nlet bit_or = bit_or\nlet bit_and = bit_and\nlet popcount = popcount\nlet abs = abs\nlet pred = pred\nlet succ = succ\nlet pow = pow\nlet rem = rem\nlet neg = neg\nlet max_value = max_value\nlet min_value = min_value\nlet minus_one = wrap_exn Caml.Int64.minus_one\nlet one = wrap_exn Caml.Int64.one\nlet zero = wrap_exn Caml.Int64.zero\nlet is_pow2 = is_pow2\nlet floor_pow2 = floor_pow2\nlet ceil_pow2 = ceil_pow2\nlet floor_log2 = floor_log2\nlet ceil_log2 = ceil_log2\nlet clz = clz\nlet ctz = ctz\nlet to_float x = Caml.Int64.to_float (unwrap x)\nlet of_float_unchecked x = wrap_modulo (Caml.Int64.of_float x)\n\nlet of_float t =\n let open Float_replace_polymorphic_compare in\n if t >= float_lower_bound && t <= float_upper_bound\n then wrap_modulo (Caml.Int64.of_float t)\n else\n Printf.invalid_argf\n \"Int63.of_float: argument (%f) is out of range or NaN\"\n (Float0.box t)\n ()\n;;\n\nlet of_int64 = of_int64\nlet of_int64_exn = of_int64_exn\nlet of_int64_trunc = of_int64_trunc\nlet to_int64 = to_int64\n\ninclude Comparable.Validate_with_zero (struct\n include T\n\n let zero = zero\n end)\n\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet ( / ) = div\nlet ( * ) = mul\nlet ( - ) = sub\nlet ( + ) = add\nlet ( ~- ) = neg\nlet ( ** ) b e = pow b e\nlet incr r = r := !r + one\nlet decr r = r := !r - one\n\n(* We can reuse conversion function from/to int64 here. *)\nlet of_int x = wrap_exn (Conv.int_to_int64 x)\nlet of_int_exn x = of_int x\nlet to_int x = Conv.int64_to_int (unwrap x)\nlet to_int_exn x = Conv.int64_to_int_exn (unwrap x)\nlet to_int_trunc x = Conv.int64_to_int_trunc (unwrap x)\nlet of_int32 x = wrap_exn (Conv.int32_to_int64 x)\nlet of_int32_exn x = of_int32 x\nlet to_int32 x = Conv.int64_to_int32 (unwrap x)\nlet to_int32_exn x = Conv.int64_to_int32_exn (unwrap x)\nlet to_int32_trunc x = Conv.int64_to_int32_trunc (unwrap x)\nlet of_nativeint x = of_int64 (Conv.nativeint_to_int64 x)\nlet of_nativeint_exn x = wrap_exn (Conv.nativeint_to_int64 x)\nlet of_nativeint_trunc x = of_int64_trunc (Conv.nativeint_to_int64 x)\nlet to_nativeint x = Conv.int64_to_nativeint (unwrap x)\nlet to_nativeint_exn x = Conv.int64_to_nativeint_exn (unwrap x)\nlet to_nativeint_trunc x = Conv.int64_to_nativeint_trunc (unwrap x)\n\ninclude Conv.Make (T)\n\ninclude Conv.Make_hex (struct\n type t = T.t [@@deriving_inline compare, hash]\n\n let compare = (T.compare : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n T.hash_fold_t\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = T.hash in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let zero = zero\n let neg = ( ~- )\n let ( < ) = ( < )\n\n let to_string i =\n (* the use of [unwrap_unsigned] here is important for the case of [min_value] *)\n Printf.sprintf \"%Lx\" (unwrap_unsigned i)\n ;;\n\n let of_string s = of_string (\"0x\" ^ s)\n let module_name = \"Base.Int63.Hex\"\n end)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string x = to_string x\n let module_name = \"Base.Int63\"\n end)\n\nmodule Pre_O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Int64_replace_polymorphic_compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int_exn = of_int_exn\nend\n\nmodule O = struct\n include Pre_O\n\n include Int_math.Make (struct\n type nonrec t = t\n\n include Pre_O\n\n let rem = rem\n let to_float = to_float\n let of_float = of_float\n let of_string = T.of_string\n let to_string = T.to_string\n end)\n\n let ( land ) = bit_and\n let ( lor ) = bit_or\n let ( lxor ) = bit_xor\n let lnot = bit_not\n let ( lsl ) = shift_left\n let ( asr ) = shift_right\n let ( lsr ) = shift_right_logical\nend\n\ninclude O\n\n(* [Int63] and [Int63.O] agree value-wise *)\n\nmodule Repr = struct\n type emulated = t\n\n type ('underlying_type, 'intermediate_type) t =\n | Int : (int, int) t\n | Int64 : (int64, emulated) t\nend\n\nlet repr = Repr.Int64\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Int64_replace_polymorphic_compare\n","open! Import\nmodule Sys = Sys0\n\ntype t = Caml.Printexc.raw_backtrace\n\nlet elide = ref am_testing\nlet elided_message = \"\"\n\nlet get ?(at_most_num_frames = Int.max_value) () =\n Caml.Printexc.get_callstack at_most_num_frames\n;;\n\nlet to_string t =\n if !elide then elided_message else Caml.Printexc.raw_backtrace_to_string t\n;;\n\nlet to_string_list t = String.split_lines (to_string t)\nlet sexp_of_t t = Sexp.List (List.map (to_string_list t) ~f:(fun x -> Sexp.Atom x))\n\nmodule Exn = struct\n let set_recording = Caml.Printexc.record_backtrace\n let am_recording = Caml.Printexc.backtrace_status\n let most_recent () = Caml.Printexc.get_raw_backtrace ()\n\n (* We turn on backtraces by default if OCAMLRUNPARAM doesn't explicitly mention them. *)\n let maybe_set_recording () =\n let ocamlrunparam_mentions_backtraces =\n match Sys.getenv \"OCAMLRUNPARAM\" with\n | None -> false\n | Some x -> List.exists (String.split x ~on:',') ~f:(String.is_prefix ~prefix:\"b\")\n in\n if not ocamlrunparam_mentions_backtraces then set_recording true\n ;;\n\n (* the caller set something, they are responsible *)\n\n let with_recording b ~f =\n let saved = am_recording () in\n set_recording b;\n Exn.protect ~f ~finally:(fun () -> set_recording saved)\n ;;\nend\n\nlet initialize_module () = Exn.maybe_set_recording ()\n","let unique_id =\n let r = ref 0 in\n fun () -> incr r; !r\n\n(* Used to track the current libname in such a way that for functor applications, it is\n the calling libraries name that gets registered. *)\nmodule Current_libname = struct\n let null = \"\"\n let libname_ref = ref null\n\n let set str = libname_ref := str\n let unset () = libname_ref := null\n let get () = !libname_ref\nend\n\nmodule Current_bench_module_stack = struct\n let t = ref []\n\n let push s = t := s :: !t\n\n let pop_exn () = t := List.tl !t\n\n let to_name () =\n match !t with\n | [] -> None\n | ms -> Some (String.concat \".\" (List.rev ms))\nend\n\n(* This is the main data structure of this module. An [Entry.t] represents a benchmark\n along with some metadata about is position, arguments etc. *)\nmodule Entry = struct\n\n type 'a indexed_spec = {\n arg_name : string;\n arg_values : int list;\n thunk : int -> unit -> 'a;\n }\n\n type test_spec =\n | Regular_thunk : ([`init] -> unit -> 'a) -> test_spec\n | Indexed_thunk : 'a indexed_spec -> test_spec\n\n type t = {\n unique_id : int;\n code : string;\n type_conv_path : string;\n name : string;\n filename : string;\n line : int;\n startpos : int;\n endpos : int;\n test_spec : test_spec;\n bench_module_name : string option;\n }\n\n let compare t1 t2 = compare t1.unique_id t2.unique_id\n\n let get_indexed_arg_name t =\n match t.test_spec with\n | Regular_thunk _ -> None\n | Indexed_thunk {arg_name; _} -> Some arg_name\n\n (* Extracts module name from [\"filename.ml.Module\"], which is the format of [ext_name]\n as set by [typeconv]. *)\n let get_module_name_opt t =\n let str = t.type_conv_path in\n let len = String.length str in\n let rec loop i =\n if i + 4 <= len\n then\n if String.sub str i 4 = \".ml.\"\n then Some (String.sub str (i + 4) (len - i - 4))\n else loop (i + 1)\n else None\n in\n loop 0\nend\n\n(* Inspect system environment variables to decide if benchmarks are being run. This is\n called by the code generated by the [pa_bench] syntax to decide if the global hashtable\n should be populated. *)\nlet add_environment_var =\n let v =\n try Sys.getenv \"BENCHMARKS_RUNNER\" with\n | Not_found -> \"\"\n in\n v = \"TRUE\"\n\n(* This hashtable contains all the benchmarks from all the of libraries that have been\n loaded. At the time the benchmarks are registering themselves with [ppx_bench_lib] we\n don't yet know which libraries will need to be run. *)\nlet libs_to_entries : (string, Entry.t list) Hashtbl.t = Hashtbl.create 10\n\nlet lookup_rev_lib ~libname =\n try Hashtbl.find libs_to_entries libname\n with Not_found -> []\n\nlet lookup_lib ~libname =\n List.rev (lookup_rev_lib ~libname)\n\nlet force_drop =\n (* Useful for js_of_ocaml to perform deadcode elimination.\n see ppx/ppx_inline_test/runtime-lib/runtime.ml [Action.get] for more details *)\n try ignore (Sys.getenv \"FORCE_DROP_BENCH\" : string); true\n with Not_found -> false\n\nlet get_mode () =\n if force_drop\n then `Ignore\n else `Collect\n\nlet[@inline never] add_bench\n ~name\n ~code\n ~filename\n ~type_conv_path\n ~line\n ~startpos\n ~endpos\n test_spec\n =\n match get_mode () with\n | `Ignore -> ()\n | `Collect ->\n let libname = Current_libname.get () in\n let entry = { Entry.\n code; unique_id = unique_id ();\n type_conv_path; bench_module_name = Current_bench_module_stack.to_name ();\n name; filename; line; startpos; endpos; test_spec;\n } in\n Hashtbl.add libs_to_entries libname (entry :: lookup_rev_lib ~libname)\n\nlet[@inline never] add_bench_module\n ~name\n ~code:_\n ~type_conv_path:_\n ~filename:_\n ~line:_\n ~startpos:_\n ~endpos:_\n f =\n match get_mode () with\n | `Ignore -> ()\n | `Collect ->\n (* Running f registers the benchmarks using BENCH *)\n Current_bench_module_stack.push name;\n try\n f ();\n Current_bench_module_stack.pop_exn ();\n with ex ->\n Current_bench_module_stack.pop_exn ();\n raise ex\n","open! Base\n\nmodule Location : sig\n include Identifiable.S\nend = struct\n include String\nend\n\nmodule Uuid : sig\n include Identifiable.S\nend = struct\n include String\nend\n\nlet eval_fail loc fmt =\n Printf.ksprintf (fun s -> failwith (Printf.sprintf !\"%{Location}: %s\" loc s)) fmt\n;;\n\nlet equal_option equal a b =\n match a, b with\n | Some _, None | None, Some _ -> false\n | None, None -> true\n | Some x, Some y -> equal x y\n;;\n\nmodule Sorted_table : sig\n type 'a t [@@deriving compare, sexp]\n\n val create : Location.t -> eq:('a -> 'a -> bool) -> (string * 'a) list -> 'a t\n val expose : 'a t -> (string * 'a) list\n val map : 'a t -> f:('a -> 'b) -> 'b t\nend = struct\n type 'a t = { sorted : (string * 'a) list } [@@deriving compare, sexp]\n\n let merge_check_adjacent_dups\n : eq:('a -> 'a -> bool) -> (string * 'a) list\n -> [ `Ok of (string * 'a) list | `Mismatch of string ]\n =\n fun ~eq ->\n let rec loop acc ~last_key ~last_value = function\n | [] -> `Ok (List.rev acc)\n | (key, value) :: xs ->\n if String.(last_key = key)\n then\n if eq last_value value\n then loop acc ~last_key ~last_value xs\n else `Mismatch key\n else loop ((key, value) :: acc) ~last_key:key ~last_value:value xs\n in\n function\n | [] -> `Ok []\n | (key, value) :: xs -> loop [ key, value ] ~last_key:key ~last_value:value xs\n ;;\n\n let create loc ~eq xs =\n let sorted = List.sort ~compare:(fun (s1, _) (s2, _) -> String.compare s1 s2) xs in\n match merge_check_adjacent_dups ~eq sorted with\n | `Ok sorted -> { sorted }\n | `Mismatch s ->\n eval_fail loc \"Different shapes for duplicated polymorphic constructor: `%s\" s ()\n ;;\n\n let expose t = t.sorted\n let map t ~f = { sorted = List.map t.sorted ~f:(fun (k, v) -> k, f v) }\nend\n\nmodule Digest : sig\n type t = Md5_lib.t [@@deriving compare, sexp]\n\n val to_md5 : t -> Md5_lib.t\n val of_md5 : Md5_lib.t -> t\n val to_hex : t -> string\n val constructor : string -> t list -> t\n val list : t list -> t\n val pair : t -> t -> t\n val string : string -> t\n val uuid : Uuid.t -> t\n val int : int -> t\n val option : t option -> t\nend = struct\n include Md5_lib\n\n let to_md5 t = t\n let of_md5 t = t\n let sexp_of_t t = t |> to_hex |> sexp_of_string\n let t_of_sexp s = s |> string_of_sexp |> of_hex_exn\n let uuid u = string (Uuid.to_string u)\n let int x = string (Int.to_string x)\n let pair x y = string (to_binary x ^ to_binary y)\n let list l = string (String.concat ~sep:\"\" (List.map ~f:to_binary l))\n let constructor s l = string (s ^ to_binary (list l))\n\n let option = function\n | None -> constructor \"none\" []\n | Some x -> constructor \"some\" [ x ]\n ;;\nend\n\nmodule Canonical_exp_constructor = struct\n (* ['a t] is a non-recursive type, used to represent 1-layer of expression. The\n recursive knot is tied below in [Canonical_full.Exp.t]. *)\n type 'a t =\n | Annotate of Uuid.t * 'a\n | Base of Uuid.t * 'a list\n | Tuple of 'a list\n | Record of (string * 'a) list\n | Variant of (string * 'a list) list\n (* Polymorphic variants are insensitive to the order the constructors are listed *)\n | Poly_variant of 'a option Sorted_table.t\n (* Left-hand-side of [Application] is a potentially recursive definition: it\n can refer to itself using [Rec_app (i, _)] where [i] is the depth of this\n application node (how many application nodes are above it).\n It also has its own scope of type variables so it can not refer to type variables\n of the enclosing scope.\n *)\n | Application of 'a * 'a list\n | Rec_app of int * 'a list\n | Var of int\n [@@deriving sexp, compare]\n\n let map x ~f =\n match x with\n | Annotate (u, x) -> Annotate (u, f x)\n | Base (s, xs) -> Base (s, List.map ~f xs)\n | Tuple xs -> Tuple (List.map ~f xs)\n | Record l -> Record (List.map l ~f:(fun (s, x) -> s, f x))\n | Variant l -> Variant (List.map l ~f:(fun (s, xs) -> s, List.map ~f xs))\n | Poly_variant t -> Poly_variant (Sorted_table.map t ~f:(Option.map ~f))\n | Application (x, l) -> Application (f x, List.map ~f l)\n | Rec_app (t, l) -> Rec_app (t, List.map ~f l)\n | Var v -> Var v\n ;;\n\n let to_string t = Sexp.to_string (sexp_of_t (fun _ -> Atom \"...\") t)\nend\n\nmodule Create_digest : sig\n (* Digest various expression forms *)\n\n val digest_layer : Digest.t Canonical_exp_constructor.t -> Digest.t\nend = struct\n let digest_layer = function\n | Canonical_exp_constructor.Annotate (u, x) ->\n Digest.constructor \"annotate\" [ Digest.uuid u; x ]\n | Base (u, l) -> Digest.constructor \"base\" [ Digest.uuid u; Digest.list l ]\n | Tuple l -> Digest.constructor \"tuple\" [ Digest.list l ]\n | Record l ->\n Digest.constructor\n \"record\"\n [ Digest.list (List.map l ~f:(fun (s, t) -> Digest.pair (Digest.string s) t)) ]\n | Variant l ->\n Digest.constructor\n \"variant\"\n [ Digest.list\n (List.map l ~f:(fun (s, l) -> Digest.pair (Digest.string s) (Digest.list l)))\n ]\n | Poly_variant table ->\n Digest.constructor\n \"poly_variant\"\n [ Digest.list\n (List.map (Sorted_table.expose table) ~f:(fun (x, y) ->\n Digest.pair (Digest.string x) (Digest.option y)))\n ]\n | Application (x, l) -> Digest.constructor \"application\" [ x; Digest.list l ]\n | Rec_app (n, l) -> Digest.constructor \"rec_app\" [ Digest.int n; Digest.list l ]\n | Var n -> Digest.constructor \"var\" [ Digest.int n ]\n ;;\nend\n\nmodule Visibility = struct\n type visible = Visible\n type opaque = Opaque\n\n let _ = Visible\n let _ = Opaque\nend\n\nmodule type Canonical = sig\n type t\n\n val to_digest : t -> Digest.t\n\n module Exp1 : sig\n type _ t\n\n val var : int -> _ t\n val recurse : int -> _ t list -> _ t\n val apply : 'a t -> 'a t list -> _ t\n val opaque : _ t -> Visibility.opaque t\n\n val get_poly_variant\n : Visibility.visible t\n -> (Visibility.opaque t option Sorted_table.t, string) Result.t\n end\n\n module Def : sig\n type t = Visibility.visible Exp1.t\n end\n\n module Create : sig\n val annotate : Uuid.t -> _ Exp1.t -> _ Exp1.t\n val basetype : Uuid.t -> _ Exp1.t list -> _ Exp1.t\n val tuple : _ Exp1.t list -> _ Exp1.t\n val poly_variant : Location.t -> (string * _ Exp1.t option) list -> _ Exp1.t\n val var : int -> _ Exp1.t\n val recurse : int -> _ Exp1.t list -> _ Exp1.t\n val apply : 'a Exp1.t -> 'a Exp1.t list -> _ Exp1.t\n val define : Visibility.visible Exp1.t -> Def.t\n val record : (string * _ Exp1.t) list -> _ Exp1.t\n val variant : (string * _ Exp1.t list) list -> _ Exp1.t\n val create : _ Exp1.t -> t\n end\nend\n\nmodule Canonical_digest : Canonical = struct\n type t = Canonical of Digest.t\n\n let to_digest (Canonical x) = x\n\n module CD = Create_digest\n\n module Exp1 = struct\n type opaque = Digest.t\n\n type 'a t =\n | Poly_variant of opaque option Sorted_table.t\n | Non_poly_variant of (string * opaque)\n | Opaque : opaque -> Visibility.opaque t\n\n let to_digest (type a) (x : a t) =\n match x with\n | Opaque x -> x\n | Non_poly_variant (_, x) -> x\n | Poly_variant x -> CD.digest_layer (Poly_variant x)\n ;;\n\n let equal (type a) (x : a t) (y : a t) =\n Digest.compare (to_digest x) (to_digest y) = 0\n ;;\n\n let opaque x = Opaque (to_digest x)\n\n let create x =\n let x = Canonical_exp_constructor.map ~f:to_digest x in\n let desc = Canonical_exp_constructor.to_string x in\n match x with\n | Canonical_exp_constructor.Poly_variant l -> Poly_variant l\n | Base _ -> Non_poly_variant (desc, CD.digest_layer x)\n | Annotate _ ->\n (* It's unsafe to use deriving bin_io when inheriting from a polymorphic variant\n that has a custom bin_io. If we forbid that, we can happily reject here\n anything that's annotated. *)\n Non_poly_variant (desc, CD.digest_layer x)\n | Application _ ->\n (* Application can really be a poly-variant you can inherit from! But it's a\n rare situation that mostly (only?) arises with inheritance from recursive\n polymorpic variants, which we've not seen anywhere yet. So we reject it. *)\n Non_poly_variant (desc, CD.digest_layer x)\n | Rec_app _ ->\n (* You can only get the [Rec_app] constructor for type-references within the\n mutual group being defined. References which\n follow after the current group will always be [Application]s.\n\n And since ocaml rejects references in `inheritance' position to types within\n the current group (see example) with:\n\n Error: The type constructor t\n is not yet completely defined\n\n then its ok to say that a rec-app is something that can't be inherited from and\n return [Non_poly_variant].\n\n And unlike the [Application] case, it should never be possible to see\n an error message with the [desc] = [Rec_app].\n\n Example: [type t = [`a of [ | t] ]]\n Here, [| t] would be an example of inheritance from a Rec_app, which\n is rejected by the compiler.\n *)\n Non_poly_variant (desc, CD.digest_layer x)\n | Var _ | Tuple _ | Record _ | Variant _ ->\n Non_poly_variant (desc, CD.digest_layer x)\n ;;\n\n let var x = create (Var x)\n let apply def l = create (Application (def, l))\n let recurse tid l = create (Rec_app (tid, l))\n\n let get_poly_variant (x : Visibility.visible t) =\n match x with\n | Non_poly_variant (desc, _) -> Error desc\n | Poly_variant l -> Ok (Sorted_table.map ~f:(Option.map ~f:(fun x -> Opaque x)) l)\n ;;\n end\n\n module Def = struct\n type t = Visibility.visible Exp1.t\n end\n\n module Create = struct\n let annotate u x = Exp1.create (Annotate (u, x))\n let basetype u l = Exp1.create (Base (u, l))\n let tuple l = Exp1.create (Tuple l)\n\n let poly_variant loc l =\n Exp1.create\n (Poly_variant (Sorted_table.create loc ~eq:(equal_option Exp1.equal) l))\n ;;\n\n let var x = Exp1.create (Var x)\n let apply x l = Exp1.create (Application (x, l))\n let recurse t l = Exp1.create (Rec_app (t, l))\n let define x = x\n let record l = Exp1.create (Record l)\n let variant l = Exp1.create (Variant l)\n let create e = Canonical (Exp1.to_digest e)\n end\nend\n\nmodule Canonical_full : sig\n type t [@@deriving compare, sexp]\n\n include Canonical with type t := t\n\n val to_string_hum : t -> string\nend = struct\n module CD = Create_digest\n\n module Exp1 = struct\n type t0 = Exp of t0 Canonical_exp_constructor.t [@@deriving compare, sexp]\n\n let equal_t0 x y = compare_t0 x y = 0\n\n type 'a t = t0 [@@deriving compare, sexp]\n\n let var x = Exp (Canonical_exp_constructor.Var x)\n let apply d xs = Exp (Canonical_exp_constructor.Application (d, xs))\n let recurse r xs = Exp (Canonical_exp_constructor.Rec_app (r, xs))\n\n let poly_variant loc xs =\n Exp\n (Canonical_exp_constructor.Poly_variant\n (Sorted_table.create loc ~eq:(equal_option equal_t0) xs))\n ;;\n\n let get_poly_variant = function\n | Exp (Poly_variant tab) -> Ok tab\n | Exp cc -> Error (Canonical_exp_constructor.to_string cc)\n ;;\n\n let opaque t = t\n\n let rec to_digest = function\n | Exp e -> CD.digest_layer (Canonical_exp_constructor.map ~f:to_digest e)\n ;;\n end\n\n module Def = struct\n (* A [Def.t] is an expression which may be applied *)\n type t = Exp1.t0 [@@deriving compare, sexp]\n end\n\n (* A canonical shape [t] is an [Exp1.t]. *)\n type t = Exp1.t0 [@@deriving compare, sexp]\n\n let to_digest e = Exp1.to_digest e\n\n module Create = struct\n let annotate u x = Exp1.Exp (Annotate (u, x))\n let basetype u xs = Exp1.Exp (Base (u, xs))\n let tuple xs = Exp1.Exp (Tuple xs)\n let poly_variant loc xs = Exp1.poly_variant loc xs\n let var n = Exp1.Exp (Var n)\n let recurse r xs = Exp1.recurse r xs\n let apply d xs = Exp1.apply d xs\n let define x = x\n let record xs = Exp1.Exp (Record xs)\n let variant xs = Exp1.Exp (Variant xs)\n let create exp = exp\n end\n\n let to_string_hum t = Sexp.to_string_hum (sexp_of_t t)\nend\n\nmodule Tid : sig\n include Identifiable.S\nend = struct\n include String\nend\n\nmodule Vid : sig\n include Identifiable.S\nend = struct\n include String\nend\n\nmodule Gid : sig\n (* unique group-id, used as key for Tenv below *)\n type t [@@deriving compare, sexp_of]\n\n val create : unit -> t\nend = struct\n type t = int [@@deriving compare, sexp_of]\n\n let r = ref 0\n\n let create () =\n let u = !r in\n r := 1 + u;\n u\n ;;\nend\n\nmodule Expression = struct\n type 't poly_constr =\n [ `Constr of string * 't option\n | `Inherit of Location.t * 't\n ]\n [@@deriving compare, sexp_of]\n\n module Group : sig\n type 'a t [@@deriving compare, sexp_of]\n\n val create : Location.t -> (Tid.t * Vid.t list * 'a) list -> 'a t\n val id : 'a t -> Gid.t\n val lookup : 'a t -> Tid.t -> Vid.t list * 'a\n end = struct\n type 'a t =\n { gid : Gid.t\n ; loc : Location.t\n ; members : (Tid.t * (Vid.t list * 'a)) list\n }\n [@@deriving compare, sexp_of]\n\n let create loc trips =\n let gid = Gid.create () in\n let members = List.map trips ~f:(fun (x, vs, t) -> x, (vs, t)) in\n { gid; loc; members }\n ;;\n\n let id g = g.gid\n\n let lookup g tid =\n match List.Assoc.find g.members ~equal:Tid.( = ) tid with\n | Some scheme -> scheme\n | None ->\n eval_fail\n g.loc\n !\"impossible: lookup_group, unbound type-identifier: %{Tid}\"\n tid\n ()\n ;;\n end\n\n type t =\n | Annotate of Uuid.t * t\n | Base of Uuid.t * t list\n | Record of (string * t) list\n | Variant of (string * t list) list\n | Tuple of t list\n | Poly_variant of (Location.t * t poly_constr list)\n | Var of (Location.t * Vid.t)\n | Rec_app of Tid.t * t list\n | Top_app of t Group.t * Tid.t * t list\n [@@deriving variants, sexp_of]\n\n type group = t Group.t\n\n let group = Group.create\n\n type poly_variant_row = t poly_constr\n\n let constr s t = `Constr (s, t)\n let inherit_ loc t = `Inherit (loc, t)\n let var loc t = Var (loc, t)\n let poly_variant loc xs = Poly_variant (loc, xs)\n let basetype = base\n\n (* \"VR\" stands for \"variant or record\" *)\n\n let is_cyclic_0 ~(via_VR : bool) : group -> Tid.t -> bool =\n fun group tid ->\n let set = ref [] in\n let visited tid = List.mem !set tid ~equal:Tid.equal in\n let add tid = set := tid :: !set in\n let rec trav = function\n (* We look for cycles by traversing the structure of type-expressions *)\n | Annotate (_, t) -> trav t\n | Base (_, ts) | Tuple ts | Top_app (_, _, ts) -> List.iter ts ~f:trav\n (* ..including poly-variants *)\n | Poly_variant (_, cs) ->\n List.iter cs ~f:(function\n | `Constr (_, None) -> ()\n | `Constr (_, Some t) -> trav t\n | `Inherit (_loc, t) -> trav t)\n (* .. and records & (normal) variants *)\n | Record xs -> if via_VR then List.iter xs ~f:(fun (_, t) -> trav t) else ()\n | Variant xs ->\n if via_VR then List.iter xs ~f:(fun (_, ts) -> List.iter ~f:trav ts) else ()\n (* We dont follow type-vars *)\n | Var _ -> ()\n (* traverse (recursive) type-apps when first encountered *)\n | Rec_app (tid, ts) ->\n if visited tid\n then ()\n else (\n add tid;\n trav_tid tid);\n List.iter ts ~f:trav\n and trav_tid tid =\n let _, body = Group.lookup group tid in\n trav body\n in\n trav_tid tid;\n let res = visited tid in\n (*let _ss = String.concat ~sep:\",\" (List.map (!set) ~f:(sprintf !\"%{Tid}\")) in*)\n (*Printf.printf !\"is_cylic: %{Tid} --> (%s) %b -- %s%!\" tid _ss res (Group.loc group);*)\n res\n ;;\n\n let is_cyclic = is_cyclic_0 ~via_VR:true\n let is_cyclic_with_no_intervening_VR = is_cyclic_0 ~via_VR:false\nend\n\ninclude Expression\n\nmodule Evaluation (Canonical : Canonical) = struct\n (* [Venv.t]\n Environment for resolving type-vars *)\n module Venv : sig\n type t\n\n val lookup : t -> Vid.t -> Visibility.visible Canonical.Exp1.t option\n val create : (Vid.t * Visibility.visible Canonical.Exp1.t) list -> t\n end = struct\n type t = Visibility.visible Canonical.Exp1.t Map.M(Vid).t\n\n let create =\n List.fold\n ~init:(Map.empty (module Vid))\n ~f:(fun t (k, v) -> Map.set ~key:k ~data:v t)\n ;;\n\n let lookup t k = Map.find t k\n end\n\n module Applicand = struct\n type t =\n | Recursion_level of int\n | Definition of Canonical.Def.t\n end\n\n (* [Tenv.t]\n Environment for resolving type-definitions *)\n module Tenv : sig\n type key = Gid.t * Tid.t\n type t\n\n val find : t -> key -> [ `Recursion_level of int ] option\n val empty : t\n val extend : t -> key -> [ `Recursion_level of int ] -> t\n end = struct\n module Key = struct\n module T = struct\n type t = Gid.t * Tid.t [@@deriving compare, sexp_of]\n end\n\n include T\n include Comparator.Make (T)\n end\n\n type key = Key.t\n type t = [ `Recursion_level of int ] Map.M(Key).t\n\n let find t k = Map.find t k\n let empty = Map.empty (module Key)\n let extend t k v = Map.set ~key:k ~data:v t\n end\n\n (* [Defining.t]\n Monad for managing un-rolling depth, and maintaing a [Tenv.t] *)\n module Defining : sig\n type 'a t\n\n val return : 'a -> 'a t\n val bind : 'a t -> ('a -> 'b t) -> 'b t\n val look_env : Tenv.key -> Applicand.t option t\n val extend_new_tid : Tenv.key -> Canonical.Def.t t -> Applicand.t t\n val exec : 'a t -> 'a\n end = struct\n type 'a t = depth:int -> Tenv.t -> 'a\n\n let return x ~depth:_ _tenv = x\n\n let bind t f ~depth tenv =\n let x = t ~depth tenv in\n (f x) ~depth tenv\n ;;\n\n let look_env key ~depth:_ tenv =\n let result = Tenv.find tenv key in\n Option.map ~f:(fun (`Recursion_level x) -> Applicand.Recursion_level x) result\n ;;\n\n let extend_new_tid key def_t ~depth tenv =\n Applicand.Definition\n (let value = `Recursion_level depth in\n let tenv = Tenv.extend tenv key value in\n def_t ~depth:(depth + 1) tenv)\n ;;\n\n let exec t = t ~depth:0 Tenv.empty\n end\n\n type 'a defining = 'a Defining.t\n\n let ( >>= ) = Defining.bind\n let return = Defining.return\n\n let sequence_defining : 'a list -> f:('a -> 'b defining) -> 'b list defining =\n fun xs ~f ->\n let rec loop acc_ys = function\n | [] -> return (List.rev acc_ys)\n | x :: xs -> f x >>= fun y -> loop (y :: acc_ys) xs\n in\n loop [] xs\n ;;\n\n (*\n Shape evaluation.\n\n Shapes are evaluated to canonical-shape (expressions), with additional defs collected\n in the [defining] monad, which also manages generation/mapping to [Canonical.Tid.t]\n\n There is downwards context of [group] and [Venv.t]\n The (current) [group] changes when the case for [Top_app] calls [eval_app].\n\n The current [Venv.t] is abandoned when [eval_app] is called, and then re-created after\n the decision has been made to either inline the type-application, or make a reference\n to a type-definition, which is created at most once for each (Gid.t * Tid.t).\n\n We make a type-definition always for Records and Variants, and in addition for any\n other cyclic type-definition.\n *)\n\n let rec eval : group -> Venv.t -> t -> Visibility.visible Canonical.Exp1.t defining =\n fun group venv t ->\n match t with\n | Record binds ->\n sequence_defining binds ~f:(fun (s, x) ->\n eval group venv x >>= fun y -> return (s, y))\n >>= fun binds -> return (Canonical.Create.record binds)\n | Variant alts ->\n sequence_defining alts ~f:(fun (s, xs) ->\n eval_list group venv xs >>= fun ys -> return (s, ys))\n >>= fun alts -> return (Canonical.Create.variant alts)\n | Var (loc, vid) ->\n (match Venv.lookup venv vid with\n | Some x -> return x\n | None -> eval_fail loc !\"Free type variable: '%{Vid}\" vid ())\n | Annotate (s, t) ->\n eval group venv t >>= fun v -> return (Canonical.Create.annotate s v)\n | Base (s, ts) ->\n eval_list group venv ts >>= fun vs -> return (Canonical.Create.basetype s vs)\n | Tuple ts ->\n eval_list group venv ts >>= fun vs -> return (Canonical.Create.tuple vs)\n | Top_app (in_group, tid, args) ->\n eval_list group venv args\n >>= fun args ->\n (* args evaluated in current group *)\n eval_app in_group tid args\n (* group changed here *)\n | Rec_app (tid, args) ->\n eval_list group venv args >>= fun args -> eval_app group tid args\n | Poly_variant (loc, cs) ->\n sequence_defining ~f:(eval_poly_constr group venv) cs\n >>= fun xss -> return (Canonical.Create.poly_variant loc (List.concat xss))\n\n and eval_list : group -> Venv.t -> t list -> _ Canonical.Exp1.t list defining =\n fun group venv ts -> sequence_defining ts ~f:(eval group venv)\n\n and eval_poly_constr\n : group -> Venv.t -> t poly_constr\n -> (string * Visibility.opaque Canonical.Exp1.t option) list defining\n =\n fun group venv c ->\n match c with\n | `Constr (s, None) -> return [ s, None ]\n | `Constr (s, Some t) ->\n eval group venv t >>= fun v -> return [ s, Some (Canonical.Exp1.opaque v) ]\n | `Inherit (loc, t) ->\n eval group venv t\n >>= fun v ->\n (match Canonical.Exp1.get_poly_variant v with\n | Ok tab -> return (Sorted_table.expose tab)\n | Error desc ->\n eval_fail\n loc\n \"The shape for an inherited type is not described as a polymorphic-variant: %s\"\n desc\n ())\n\n and eval_definition : group -> Vid.t list -> t -> Canonical.Def.t defining =\n fun group formals body ->\n let venv = Venv.create (List.mapi formals ~f:(fun i x -> x, Canonical.Exp1.var i)) in\n eval group venv body >>= fun v -> return (Canonical.Create.define v)\n\n and eval_app : group -> Tid.t -> _ Canonical.Exp1.t list -> _ Canonical.Exp1.t defining\n =\n fun group tid args ->\n let gid = Group.id group in\n let formals, body = Group.lookup group tid in\n let record_or_normal_variant =\n match body with\n | Record _ | Variant _ -> true\n | Tuple _ | Annotate _ | Base _ | Poly_variant _ | Var _ | Rec_app _ | Top_app _ ->\n false\n in\n let cyclic = is_cyclic group tid in\n let cyclic_no_VR = is_cyclic_with_no_intervening_VR group tid in\n if (record_or_normal_variant && cyclic) || cyclic_no_VR\n then\n Defining.look_env (gid, tid)\n >>= (function\n | Some recurse -> return recurse\n | None ->\n Defining.extend_new_tid (gid, tid) (eval_definition group formals body))\n >>= function\n | Recursion_level r -> return (Canonical.Exp1.recurse r args)\n | Definition def -> return (Canonical.Exp1.apply def args)\n else (\n let venv =\n match List.zip formals args with\n | Ok x -> Venv.create x\n | Unequal_lengths -> failwith \"apply, incorrect type application arity\"\n in\n eval group venv body)\n ;;\n\n (* top level entry point for evaluation *)\n let eval : t -> Canonical.t =\n fun t ->\n let group = group (Location.of_string \"top-level\") [] in\n let venv = Venv.create [] in\n let v = Defining.exec (eval group venv t) in\n Canonical.Create.create v\n ;;\nend\n\nmodule Canonical = struct\n include Canonical_full\n\n module Exp = struct\n type t = Visibility.visible Exp1.t\n end\nend\n\ninclude Evaluation (Canonical_full)\nmodule Canonical_selected = Canonical_digest\nmodule Evaluation_to_digest = Evaluation (Canonical_selected)\n\nlet eval_to_digest exp = Canonical_selected.to_digest (Evaluation_to_digest.eval exp)\nlet eval_to_digest_string exp = Digest.to_hex (eval_to_digest exp)\n\nmodule For_typerep = struct\n exception Not_a_tuple of t [@@deriving sexp_of]\n\n let deconstruct_tuple_exn t =\n match t with\n | Tuple ts -> ts\n | _ -> raise (Not_a_tuple t)\n ;;\nend\n","open! Base\nopen! Import\n\ntype t = Caml.in_channel\n\nlet equal (t1 : t) t2 = phys_equal t1 t2\n\nlet seek = Caml.LargeFile.seek_in\nlet pos = Caml.LargeFile.pos_in\nlet length = Caml.LargeFile.in_channel_length\n\nlet stdin = Caml.stdin\n\nlet create ?(binary = true) file =\n let flags = [Open_rdonly] in\n let flags = if binary then Open_binary :: flags else flags in\n Caml.open_in_gen flags 0o000 file\n;;\n\nlet close = Caml.close_in\n\nlet with_file ?binary file ~f = Exn.protectx (create ?binary file) ~f ~finally:close\n\nlet may_eof f = try Some (f ()) with End_of_file -> None\n\nlet input t ~buf ~pos ~len = Caml.input t buf pos len\nlet really_input t ~buf ~pos ~len =\n may_eof (fun () -> Caml.really_input t buf pos len)\nlet really_input_exn t ~buf ~pos ~len =\n Caml.really_input t buf pos len\nlet input_byte t = may_eof (fun () -> Caml.input_byte t)\nlet input_char t = may_eof (fun () -> Caml.input_char t)\nlet input_binary_int t = may_eof (fun () -> Caml.input_binary_int t)\nlet unsafe_input_value t = may_eof (fun () -> Caml.input_value t)\nlet input_buffer t buf ~len = may_eof (fun () -> Caml.Buffer.add_channel buf t len)\n\nlet set_binary_mode = Caml.set_binary_mode_in\n\nlet input_all t =\n (* We use 65536 because that is the size of OCaml's IO buffers. *)\n let chunk_size = 65536 in\n let buffer = Buffer.create chunk_size in\n let rec loop () =\n Caml.Buffer.add_channel buffer t chunk_size;\n loop ()\n in\n try loop () with\n | End_of_file -> Buffer.contents buffer\n;;\n\nlet trim ~fix_win_eol line =\n if fix_win_eol then begin\n let len = String.length line in\n if len > 0\n && Char.equal (String.get line (len - 1)) '\\r'\n then String.sub line ~pos:0 ~len:(len - 1)\n else line\n end\n else line\n\nlet input_line ?(fix_win_eol = true) t =\n match may_eof (fun () -> Caml.input_line t) with\n | None -> None\n | Some line -> Some (trim ~fix_win_eol line)\n;;\n\nlet input_line_exn ?(fix_win_eol = true) t =\n let line = Caml.input_line t in\n trim ~fix_win_eol line\n\nlet fold_lines ?fix_win_eol t ~init ~f =\n let rec loop ac =\n match input_line ?fix_win_eol t with\n | None -> ac\n | Some line -> loop (f ac line)\n in\n loop init\n;;\n\nlet input_lines ?fix_win_eol t =\n List.rev\n (fold_lines ?fix_win_eol t ~init:[] ~f:(fun lines line -> line :: lines))\n;;\n\nlet iter_lines ?fix_win_eol t ~f =\n fold_lines ?fix_win_eol t ~init:() ~f:(fun () line -> f line)\n;;\n\nlet read_lines ?fix_win_eol fname = with_file fname ~f:(input_lines ?fix_win_eol)\n\nlet read_all fname = with_file fname ~f:input_all\n","open! Base\nopen! Import\n\ntype t = Caml.out_channel\n\nlet equal (t1 : t) t2 = phys_equal t1 t2\n\nlet seek = Caml.LargeFile.seek_out\nlet pos = Caml.LargeFile.pos_out\nlet length = Caml.LargeFile.out_channel_length\n\nlet stdout = Caml.stdout\nlet stderr = Caml.stderr\n\nlet sexp_of_t t =\n if phys_equal t stderr\n then Sexp.Atom \"\"\n else if phys_equal t stdout\n then Sexp.Atom \"\"\n else Sexp.Atom \"\"\n;;\n\ntype 'a with_create_args =\n ?binary:bool\n -> ?append:bool\n -> ?fail_if_exists:bool\n -> ?perm:int\n -> 'a\n\nlet create ?(binary = true) ?(append = false) ?(fail_if_exists = false) ?(perm = 0o666) file =\n let flags = [Open_wronly; Open_creat] in\n let flags = (if binary then Open_binary else Open_text) :: flags in\n let flags = (if append then Open_append else Open_trunc) :: flags in\n let flags = (if fail_if_exists then Open_excl :: flags else flags) in\n Caml.open_out_gen flags perm file\n;;\n\nlet set_binary_mode = Caml.set_binary_mode_out\n\nlet flush = Caml.flush\n\nlet close = Caml.close_out\nlet close_no_err = Caml.close_out_noerr\n\nlet output t ~buf ~pos ~len = Caml.output t buf pos len\nlet output_substring t ~buf ~pos ~len = Caml.output_substring t buf pos len\nlet output_string = Caml.output_string\nlet output_bytes = Caml.output_bytes\nlet output_char = Caml.output_char\nlet output_byte = Caml.output_byte\nlet output_binary_int = Caml.output_binary_int\nlet output_buffer = Caml.Buffer.output_buffer\nlet output_value = Caml.output_value\n\nlet newline t = output_string t \"\\n\"\n\nlet output_lines t lines =\n List.iter lines ~f:(fun line -> output_string t line; newline t)\n;;\n\nlet printf = Caml.Printf.printf\nlet eprintf = Caml.Printf.eprintf\nlet fprintf = Caml.Printf.fprintf\nlet kfprintf = Caml.Printf.kfprintf\n\nlet print_string = Caml.print_string\nlet print_endline = Caml.print_endline\nlet prerr_endline = Caml.prerr_endline\n\nlet print_s ?mach sexp =\n print_endline\n (match mach with\n | Some () -> Sexp.to_string_mach sexp\n | None -> Sexp.to_string_hum sexp)\n;;\n\nlet eprint_s ?mach sexp =\n prerr_endline\n (match mach with\n | Some () -> Sexp.to_string_mach sexp\n | None -> Sexp.to_string_hum sexp)\n;;\n\n\nlet with_file ?binary ?append ?fail_if_exists ?perm file ~f =\n Exn.protectx (create ?binary ?append ?fail_if_exists ?perm file) ~f ~finally:close\n;;\n\nlet write_lines file lines = with_file file ~f:(fun t -> output_lines t lines)\n\nlet write_all file ~data = with_file file ~f:(fun t -> output_string t data)\n","open! Base\nmodule Gc = Caml.Gc\n\nexternal __MODULE__ : string = \"%loc_MODULE\"\n\nlet am_recording_environment_variable = \"PPX_MODULE_TIMER\"\n\nlet get_am_recording_environment_variable () =\n (* avoid Caml.Sys.getenv_opt to preserve 4.04.x compatibility *)\n match Caml.Sys.getenv am_recording_environment_variable with\n | value -> Some value\n | exception _ -> None\n;;\n\nlet am_recording_value = get_am_recording_environment_variable ()\nlet am_recording = Option.is_some am_recording_value\n\nmodule Duration = struct\n type t = Int63.t\n\n let to_nanoseconds t = t\n let of_nanoseconds t = t\n\n module type Format = sig\n val of_string : string -> t\n val to_string_with_same_unit : t list -> string list\n end\n\n module Default_format = struct\n let of_string string = String.chop_suffix_exn string ~suffix:\"ns\" |> Int63.of_string\n let to_string nanos = Int63.to_string nanos ^ \"ns\"\n let to_string_with_same_unit list = List.map list ~f:to_string\n end\n\n let format = ref (module Default_format : Format)\n\n let of_string string =\n let (module Format) = !format in\n Format.of_string string\n ;;\n\n let to_string_with_same_unit string =\n let (module Format) = !format in\n Format.to_string_with_same_unit string\n ;;\nend\n\nmodule Gc_events = struct\n type t =\n { minor_collections : int\n ; major_collections : int\n ; compactions : int\n }\nend\n\nmodule Timing_event = struct\n type t =\n { description : string\n ; runtime : Duration.t\n ; gc_events : Gc_events.t\n ; nested_timing_events : t list\n }\nend\n\nmodule Timer = struct\n type t =\n { mutable currently_running_description : string\n ; mutable currently_running_start_time : Duration.t\n ; mutable currently_running_gc_stats : Gc.stat\n ; mutable nested_timer : t option\n ; mutable timing_events_in_reverse_chronological_order : Timing_event.t list\n }\n\n let create ?nested_timer () =\n { currently_running_description = \"\"\n ; currently_running_start_time = Int63.zero\n ; currently_running_gc_stats = Gc.quick_stat ()\n ; nested_timer\n ; timing_events_in_reverse_chronological_order = []\n }\n ;;\n\n let reset t =\n t.currently_running_description <- \"\";\n t.currently_running_start_time <- Int63.zero;\n match t.nested_timer with\n | None -> ()\n | Some nested -> nested.timing_events_in_reverse_chronological_order <- []\n ;;\n\n let record_start t description =\n if am_recording\n then (\n assert (String.is_empty t.currently_running_description);\n t.currently_running_description <- description;\n t.currently_running_gc_stats <- Gc.quick_stat ();\n (* call [Time_now] as late as possible before running the module body *)\n t.currently_running_start_time <- Time_now.nanoseconds_since_unix_epoch ())\n ;;\n\n let record_until t description =\n if am_recording\n then (\n (* compute [Time_now] as soon as possible after running the module body *)\n let until = Time_now.nanoseconds_since_unix_epoch () in\n let start = t.currently_running_start_time in\n let gc_stats_after = Gc.quick_stat () in\n let gc_stats_before = t.currently_running_gc_stats in\n let runtime = Int63.( - ) until start in\n assert (String.equal t.currently_running_description description);\n let gc_events : Gc_events.t =\n { minor_collections =\n gc_stats_after.minor_collections - gc_stats_before.minor_collections\n ; major_collections =\n gc_stats_after.major_collections - gc_stats_before.major_collections\n ; compactions = gc_stats_after.compactions - gc_stats_before.compactions\n }\n in\n let nested_timing_events =\n match t.nested_timer with\n | None -> []\n | Some nested -> List.rev nested.timing_events_in_reverse_chronological_order\n in\n let timing_event : Timing_event.t =\n { description; runtime; gc_events; nested_timing_events }\n in\n t.timing_events_in_reverse_chronological_order\n <- timing_event :: t.timing_events_in_reverse_chronological_order;\n reset t)\n ;;\nend\n\nlet definition_timer = Timer.create ()\nlet module_timer = Timer.create ~nested_timer:definition_timer ()\nlet record_start module_name = Timer.record_start module_timer module_name\nlet record_until module_name = Timer.record_until module_timer module_name\nlet record_definition_start loc = Timer.record_start definition_timer loc\nlet record_definition_until loc = Timer.record_until definition_timer loc\n\nlet gc_events_suffix_string\n ({ minor_collections; major_collections; compactions } : Gc_events.t)\n =\n let to_list description count =\n if count = 0 then [] else [ Int.to_string count ^ \" \" ^ description ]\n in\n let strings =\n to_list \"minor collections\" minor_collections\n @ to_list \"major collections\" major_collections\n @ to_list \"compactions\" compactions\n in\n if List.is_empty strings then \"\" else \"; GC: \" ^ String.concat strings ~sep:\", \"\n;;\n\nlet with_left_column_right_justified list =\n let left_column_width =\n List.fold list ~init:0 ~f:(fun width (left, _) -> Int.max width (String.length left))\n in\n List.map list ~f:(fun (left, right) ->\n Printf.sprintf \"%*s %s\" left_column_width left right)\n;;\n\nlet rec timing_events_to_strings list ~indent =\n let duration_strings =\n List.map list ~f:(fun (timing_event : Timing_event.t) -> timing_event.runtime)\n |> Duration.to_string_with_same_unit\n in\n let prefix = String.make indent ' ' in\n List.map2_exn\n duration_strings\n list\n ~f:(fun duration_string\n { runtime = _; description; gc_events; nested_timing_events }\n ->\n ( duration_string\n , description\n ^ gc_events_suffix_string gc_events\n ^ String.concat\n (List.map\n (timing_events_to_strings nested_timing_events ~indent:(indent + 4))\n ~f:(fun line -> \"\\n\" ^ line)) ))\n |> with_left_column_right_justified\n |> List.map ~f:(fun line -> prefix ^ line)\n;;\n\nlet fake_timing_events =\n let gc_events i : Gc_events.t =\n { minor_collections = (if i % 2 = 1 then 1 else 0)\n ; major_collections = (if i % 4 = 3 then 1 else 0)\n ; compactions = (if i % 8 = 7 then 1 else 0)\n }\n in\n lazy\n (List.init 12 ~f:(fun i ->\n ({ description = Printf.sprintf \"Fake__Dependency_%d\" (i + 1)\n ; runtime = Int63.of_int (900 * (i + 1))\n ; gc_events = gc_events i\n ; nested_timing_events =\n (if (i + 1) % 4 = 0\n then\n List.init (i + 1) ~f:(fun j ->\n ({ description = Printf.sprintf \"Line %d\" (j + 1)\n ; runtime = Int63.of_int (900 * (j + 1))\n ; gc_events = gc_events j\n ; nested_timing_events = []\n }\n : Timing_event.t))\n else [])\n }\n : Timing_event.t)))\n;;\n\nlet print_recorded_timing_events timing_events =\n let notify_of_overriding () =\n Stdio.print_endline \"ppx_module_timer: overriding time measurements for testing\"\n in\n let timing_events =\n match Option.value_exn am_recording_value with\n | \"FAKE_MODULES\" ->\n notify_of_overriding ();\n force fake_timing_events\n | string ->\n (match Duration.of_string string with\n | override ->\n notify_of_overriding ();\n List.mapi timing_events ~f:(fun index (timing_event : Timing_event.t) ->\n let runtime = Int63.( * ) override (Int63.of_int (index + 1)) in\n let nested_timing_events =\n List.mapi\n timing_event.nested_timing_events\n ~f:(fun index nested_timing_event ->\n let runtime = Int63.( * ) override (Int63.of_int (index + 1)) in\n { nested_timing_event with runtime })\n in\n { timing_event with runtime; nested_timing_events })\n | exception _ -> timing_events)\n in\n timing_events |> timing_events_to_strings ~indent:0 |> List.iter ~f:Stdio.print_endline\n;;\n\nlet () =\n if am_recording\n then\n Caml.at_exit (fun () ->\n print_recorded_timing_events\n (List.rev module_timer.timing_events_in_reverse_chronological_order))\n;;\n","module Name_of = struct\n let typename_of_int =\n let module M = Typename.Make0(struct type t = int let name = \"int\" end) in\n M.typename_of_t\n\n let typename_of_int32 =\n let module M = Typename.Make0(struct type t = int32 let name = \"int32\" end) in\n M.typename_of_t\n\n let typename_of_int64 =\n let module M = Typename.Make0(struct type t = int64 let name = \"int64\" end) in\n M.typename_of_t\n\n let typename_of_nativeint =\n let module M = Typename.Make0(struct\n type t = nativeint\n let name = \"nativeint\"\n end) in\n M.typename_of_t\n\n let typename_of_char =\n let module M = Typename.Make0(struct type t = char let name = \"char\" end) in\n M.typename_of_t\n\n let typename_of_float =\n let module M = Typename.Make0(struct type t = float let name = \"float\" end) in\n M.typename_of_t\n\n let typename_of_string =\n let module M = Typename.Make0(struct type t = string let name = \"string\" end) in\n M.typename_of_t\n\n let typename_of_bytes =\n let module M = Typename.Make0(struct type t = bytes let name = \"bytes\" end) in\n M.typename_of_t\n\n let typename_of_bool =\n let module M = Typename.Make0(struct type t = bool let name = \"bool\" end) in\n M.typename_of_t\n\n let typename_of_unit =\n let module M = Typename.Make0(struct type t = unit let name = \"unit\" end) in\n M.typename_of_t\n\n module M_option = Typename.Make1(struct type 'a t = 'a option let name = \"option\" end)\n let typename_of_option = M_option.typename_of_t\n\n module M_list = Typename.Make1(struct type 'a t = 'a list let name = \"list\" end)\n let typename_of_list = M_list.typename_of_t\n\n module M_array = Typename.Make1(struct type 'a t = 'a array let name = \"array\" end)\n let typename_of_array = M_array.typename_of_t\n\n module M_lazy_t = Typename.Make1(struct type 'a t = 'a lazy_t let name = \"lazy_t\" end)\n let typename_of_lazy_t = M_lazy_t.typename_of_t\n\n module M_ref = Typename.Make1(struct type 'a t = 'a ref let name = \"ref\" end)\n let typename_of_ref = M_ref.typename_of_t\n\n module M_function = Typename.Make2(struct\n type ('a, 'b) t = 'a -> 'b\n let name = \"function\"\n end)\n let typename_of_function = M_function.typename_of_t\n\n type tuple0 = unit\n module M_tuple0 = Typename.Make0(struct type t = tuple0 let name = \"tuple0\" end)\n let typename_of_tuple0 = M_tuple0.typename_of_t\n\n module M_tuple2 = Typename.Make2(struct\n type ('a, 'b) t = 'a * 'b\n let name = \"tuple2\"\n end)\n let typename_of_tuple2 = M_tuple2.typename_of_t\n\n module M_tuple3 = Typename.Make3(struct\n type ('a, 'b, 'c) t = 'a * 'b * 'c\n let name = \"tuple3\"\n end)\n let typename_of_tuple3 = M_tuple3.typename_of_t\n\n module M_tuple4 = Typename.Make4(struct\n type ('a, 'b, 'c, 'd) t = 'a * 'b * 'c * 'd\n let name = \"tuple4\"\n end)\n let typename_of_tuple4 = M_tuple4.typename_of_t\n\n module M_tuple5 = Typename.Make5(struct\n type ('a, 'b, 'c, 'd, 'e) t = 'a * 'b * 'c *'d * 'e\n let name = \"tuple5\"\n end)\n let typename_of_tuple5 = M_tuple5.typename_of_t\nend\n\nmodule rec Typerep : sig\n\n type _ t =\n | Int : int t\n | Int32 : int32 t\n | Int64 : int64 t\n | Nativeint : nativeint t\n | Char : char t\n | Float : float t\n | String : string t\n | Bytes : bytes t\n | Bool : bool t\n | Unit : unit t\n | Option : 'a t -> 'a option t\n | List : 'a t -> 'a list t\n | Array : 'a t -> 'a array t\n | Lazy : 'a t -> 'a lazy_t t\n | Ref : 'a t -> 'a ref t\n | Function : ('dom t * 'rng t) -> ('dom -> 'rng) t\n | Tuple : 'a Typerep.Tuple.t -> 'a t\n | Record : 'a Typerep.Record.t -> 'a t\n | Variant : 'a Typerep.Variant.t -> 'a t\n | Named : ('a Typerep.Named.t * 'a t lazy_t option) -> 'a t\n\n type packed = T : 'a t -> packed\n\n module Named : sig\n module type T0 = sig\n type named\n type t\n val typename_of_named : named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, named) Type_equal.t\n end\n module type T1 = sig\n type 'a named\n type a val a : a Typerep.t\n type t\n val typename_of_named : 'a Typename.t -> 'a named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, a named) Type_equal.t\n end\n module type T2 = sig\n type ('a, 'b) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> ('a, 'b) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b) named) Type_equal.t\n end\n module type T3 = sig\n type ('a, 'b, 'c) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> ('a, 'b, 'c) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c) named) Type_equal.t\n end\n module type T4 = sig\n type ('a, 'b, 'c, 'd) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type d val d : d Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> 'd Typename.t\n -> ('a, 'b, 'c, 'd) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c, d) named) Type_equal.t\n end\n module type T5 = sig\n type ('a, 'b, 'c, 'd, 'e) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type d val d : d Typerep.t\n type e val e : e Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> 'd Typename.t\n -> 'e Typename.t\n -> ('a, 'b, 'c, 'd, 'e) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c, d, e) named) Type_equal.t\n end\n (* there the module is necessary because we need to deal with a type [t] with\n parameters whose kind is not representable as a type variable: ['a 't], even with\n a gadt. *)\n type 'a t =\n | T0 of (module T0 with type t = 'a)\n | T1 of (module T1 with type t = 'a)\n | T2 of (module T2 with type t = 'a)\n | T3 of (module T3 with type t = 'a)\n | T4 of (module T4 with type t = 'a)\n | T5 of (module T5 with type t = 'a)\n\n val arity : _ t -> int\n val typename_of_t : 'a t -> 'a Typename.t\n val name : _ t -> string\n end\n\n module Tuple : sig\n (* these constructors could be plunged at toplevel of Typerep.t, however it is less\n verbose that way *)\n type _ t =\n | T2 : ('a Typerep.t * 'b Typerep.t)\n -> ('a * 'b) t\n | T3 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t)\n -> ('a * 'b * 'c) t\n | T4 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t * 'd Typerep.t)\n -> ('a * 'b * 'c * 'd) t\n | T5 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t * 'd Typerep.t * 'e Typerep.t)\n -> ('a * 'b * 'c * 'd * 'e) t\n\n val arity : _ t -> int\n val typename_of_t : 'a t -> 'a Typename.t\n end\n\n include Variant_and_record_intf.S with type 'a t := 'a Typerep.t\n\n val same : _ t -> _ t -> bool\n val same_witness : 'a t -> 'b t -> ('a, 'b) Type_equal.t option\n val same_witness_exn : 'a t -> 'b t -> ('a, 'b) Type_equal.t\n val typename_of_t : 'a t -> 'a Typename.t\n val head : 'a t -> 'a t\nend = struct\n\n type _ t =\n | Int : int t\n | Int32 : int32 t\n | Int64 : int64 t\n | Nativeint : nativeint t\n | Char : char t\n | Float : float t\n | String : string t\n | Bytes : bytes t\n | Bool : bool t\n | Unit : unit t\n | Option : 'a t -> 'a option t\n | List : 'a t -> 'a list t\n | Array : 'a t -> 'a array t\n | Lazy : 'a t -> 'a lazy_t t\n | Ref : 'a t -> 'a ref t\n | Function : ('dom t * 'rng t) -> ('dom -> 'rng) t\n | Tuple : 'a Typerep.Tuple.t -> 'a t\n | Record : 'a Typerep.Record.t -> 'a t\n | Variant : 'a Typerep.Variant.t -> 'a t\n | Named : ('a Typerep.Named.t * 'a t lazy_t option) -> 'a t\n\n type packed = T : 'a t -> packed\n\n module Named = struct\n module type T0 = sig\n type named\n type t\n val typename_of_named : named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, named) Type_equal.t\n end\n module type T1 = sig\n type 'a named\n type a val a : a Typerep.t\n type t\n val typename_of_named : 'a Typename.t -> 'a named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, a named) Type_equal.t\n end\n module type T2 = sig\n type ('a, 'b) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> ('a, 'b) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b) named) Type_equal.t\n end\n module type T3 = sig\n type ('a, 'b, 'c) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> ('a, 'b, 'c) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c) named) Type_equal.t\n end\n module type T4 = sig\n type ('a, 'b, 'c, 'd) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type d val d : d Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> 'd Typename.t\n -> ('a, 'b, 'c, 'd) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c, d) named) Type_equal.t\n end\n module type T5 = sig\n type ('a, 'b, 'c, 'd, 'e) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type d val d : d Typerep.t\n type e val e : e Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> 'd Typename.t\n -> 'e Typename.t\n -> ('a, 'b, 'c, 'd, 'e) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c, d, e) named) Type_equal.t\n end\n (* there the module is necessary because we need to deal with a type [t] with\n parameters whose kind is not representable as a type variable: ['a 't], even with\n a gadt. *)\n type 'a t =\n | T0 of (module T0 with type t = 'a)\n | T1 of (module T1 with type t = 'a)\n | T2 of (module T2 with type t = 'a)\n | T3 of (module T3 with type t = 'a)\n | T4 of (module T4 with type t = 'a)\n | T5 of (module T5 with type t = 'a)\n\n let arity = function\n | T0 _ -> 0\n | T1 _ -> 1\n | T2 _ -> 2\n | T3 _ -> 3\n | T4 _ -> 4\n | T5 _ -> 5\n\n let typename_of_t (type a) = function\n | T0 rep ->\n let module T = (val rep : T0 with type t = a) in\n T.typename_of_t\n | T1 rep ->\n let module T = (val rep : T1 with type t = a) in\n T.typename_of_t\n | T2 rep ->\n let module T = (val rep : T2 with type t = a) in\n T.typename_of_t\n | T3 rep ->\n let module T = (val rep : T3 with type t = a) in\n T.typename_of_t\n | T4 rep ->\n let module T = (val rep : T4 with type t = a) in\n T.typename_of_t\n | T5 rep ->\n let module T = (val rep : T5 with type t = a) in\n T.typename_of_t\n\n let name rep =\n Typename.Uid.name (Typename.uid (typename_of_t rep))\n end\n\n module Tuple = struct\n (* these constructors could be plunged at toplevel of Typerep.t, however it is less\n verbose this way *)\n type _ t =\n | T2 : ('a Typerep.t * 'b Typerep.t)\n -> ('a * 'b) t\n | T3 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t)\n -> ('a * 'b * 'c) t\n | T4 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t * 'd Typerep.t)\n -> ('a * 'b * 'c * 'd) t\n | T5 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t * 'd Typerep.t * 'e Typerep.t)\n -> ('a * 'b * 'c * 'd * 'e) t\n\n let arity : type a. a t -> int = function\n | Typerep.Tuple.T2 _ -> 2\n | Typerep.Tuple.T3 _ -> 3\n | Typerep.Tuple.T4 _ -> 4\n | Typerep.Tuple.T5 _ -> 5\n\n let typename_of_t : type a. a t -> a Typename.t = function\n | T2 (a, b) ->\n Name_of.typename_of_tuple2\n (Typerep.typename_of_t a)\n (Typerep.typename_of_t b)\n | T3 (a, b, c) ->\n Name_of.typename_of_tuple3\n (Typerep.typename_of_t a)\n (Typerep.typename_of_t b)\n (Typerep.typename_of_t c)\n | T4 (a, b, c, d) ->\n Name_of.typename_of_tuple4\n (Typerep.typename_of_t a)\n (Typerep.typename_of_t b)\n (Typerep.typename_of_t c)\n (Typerep.typename_of_t d)\n | T5 (a, b, c, d, e) ->\n Name_of.typename_of_tuple5\n (Typerep.typename_of_t a)\n (Typerep.typename_of_t b)\n (Typerep.typename_of_t c)\n (Typerep.typename_of_t d)\n (Typerep.typename_of_t e)\n end\n\n include Variant_and_record_intf.M (struct type 'a rep = 'a t type 'a t = 'a rep end)\n\n let rec typename_of_t : type a. a t -> a Typename.t = function\n | Int -> Name_of.typename_of_int\n | Int32 -> Name_of.typename_of_int32\n | Int64 -> Name_of.typename_of_int64\n | Nativeint -> Name_of.typename_of_nativeint\n | Char -> Name_of.typename_of_char\n | Float -> Name_of.typename_of_float\n | String -> Name_of.typename_of_string\n | Bytes -> Name_of.typename_of_bytes\n | Bool -> Name_of.typename_of_bool\n | Unit -> Name_of.typename_of_unit\n\n | Option rep -> Name_of.typename_of_option (typename_of_t rep)\n | List rep -> Name_of.typename_of_list (typename_of_t rep)\n | Array rep -> Name_of.typename_of_array (typename_of_t rep)\n | Lazy rep -> Name_of.typename_of_lazy_t (typename_of_t rep)\n | Ref rep -> Name_of.typename_of_ref (typename_of_t rep)\n\n | Function (dom, rng) ->\n Name_of.typename_of_function (typename_of_t dom) (typename_of_t rng)\n\n | Tuple rep -> Typerep.Tuple.typename_of_t rep\n\n | Record rep -> Typerep.Record.typename_of_t rep\n | Variant rep -> Typerep.Variant.typename_of_t rep\n\n | Named (name, _) -> Named.typename_of_t name\n ;;\n\n let rec same_witness : type a b. a t -> b t -> (a, b) Type_equal.t option = fun t1 t2 ->\n let module E = Type_equal in\n match t1, t2 with\n | Named (name1, r1), Named (name2, r2) -> begin\n match Typename.same_witness\n (Named.typename_of_t name1)\n (Named.typename_of_t name2) with\n | Some E.T as x -> x\n | None ->\n match r1, r2 with\n | Some (lazy t1), Some (lazy t2) -> same_witness t1 t2\n | Some (lazy t1), None -> same_witness t1 t2\n | None, Some (lazy t2) -> same_witness t1 t2\n | None, None -> None\n end\n | Named (_, r1), t2 -> begin\n match r1 with\n | Some (lazy t1) -> same_witness t1 t2\n | None -> None\n end\n | t1, Named (_, r2) -> begin\n match r2 with\n | Some (lazy t2) -> same_witness t1 t2\n | None -> None\n end\n | Int , Int -> Some E.T\n | Int32 , Int32 -> Some E.T\n | Int64 , Int64 -> Some E.T\n | Nativeint , Nativeint -> Some E.T\n | Char , Char -> Some E.T\n | Float , Float -> Some E.T\n | String , String -> Some E.T\n | Bytes , Bytes -> Some E.T\n | Bool , Bool -> Some E.T\n | Unit , Unit -> Some E.T\n | Option r1, Option r2 -> begin\n match same_witness r1 r2 with\n | None as x -> x\n | Some E.T as x -> x\n end\n | List r1, List r2 -> begin\n match same_witness r1 r2 with\n | None as x -> x\n | Some E.T as x -> x\n end\n | Array r1, Array r2 -> begin\n match same_witness r1 r2 with\n | None as x -> x\n | Some E.T as x -> x\n end\n | Lazy r1, Lazy r2 -> begin\n match same_witness r1 r2 with\n | None as x -> x\n | Some E.T as x -> x\n end\n | Ref r1, Ref r2 -> begin\n match same_witness r1 r2 with\n | None as x -> x\n | Some E.T as x -> x\n end\n | Function (dom1, rng1), Function (dom2, rng2) -> begin\n match same_witness dom1 dom2, same_witness rng1 rng2 with\n | Some E.T, Some E.T -> Some E.T\n | None, _ | _, None -> None\n end\n | Tuple t1, Tuple t2 -> begin\n let module T = Typerep.Tuple in\n match t1, t2 with\n | T.T2 (a1, b1), T.T2 (a2, b2) -> begin\n match same_witness a1 a2, same_witness b1 b2 with\n | Some E.T, Some E.T -> Some E.T\n | None, _ | _, None -> None\n end\n | T.T3 (a1, b1, c1), T.T3 (a2, b2, c2) -> begin\n match\n same_witness a1 a2,\n same_witness b1 b2,\n same_witness c1 c2\n with\n | Some E.T, Some E.T, Some E.T -> Some E.T\n | None, _, _\n | _, None, _\n | _, _, None\n -> None\n end\n | T.T4 (a1, b1, c1, d1), T.T4 (a2, b2, c2, d2) -> begin\n match\n same_witness a1 a2,\n same_witness b1 b2,\n same_witness c1 c2,\n same_witness d1 d2\n with\n | Some E.T, Some E.T, Some E.T, Some E.T -> Some E.T\n | None, _, _, _\n | _, None, _, _\n | _, _, None, _\n | _, _, _, None\n -> None\n end\n | T.T5 (a1, b1, c1, d1, e1), T.T5 (a2, b2, c2, d2, e2) -> begin\n match\n same_witness a1 a2,\n same_witness b1 b2,\n same_witness c1 c2,\n same_witness d1 d2,\n same_witness e1 e2\n with\n | Some E.T, Some E.T, Some E.T, Some E.T, Some E.T -> Some E.T\n | None, _, _, _, _\n | _, None, _, _, _\n | _, _, None, _, _\n | _, _, _, None, _\n | _, _, _, _, None\n -> None\n end\n | T.T2 _, _ -> None\n | T.T3 _, _ -> None\n | T.T4 _, _ -> None\n | T.T5 _, _ -> None\n end\n | Record r1, Record r2 ->\n Typename.same_witness\n (Typerep.Record.typename_of_t r1)\n (Typerep.Record.typename_of_t r2)\n | Variant r1, Variant r2 ->\n Typename.same_witness\n (Typerep.Variant.typename_of_t r1)\n (Typerep.Variant.typename_of_t r2)\n | Int, _ -> None\n | Int32, _ -> None\n | Int64, _ -> None\n | Nativeint, _ -> None\n | Char, _ -> None\n | Float, _ -> None\n | String, _ -> None\n | Bytes, _ -> None\n | Bool, _ -> None\n | Unit, _ -> None\n | Option _, _ -> None\n | List _, _ -> None\n | Array _, _ -> None\n | Lazy _, _ -> None\n | Ref _, _ -> None\n | Function _, _ -> None\n | Tuple _, _ -> None\n | Record _, _ -> None\n | Variant _, _ -> None\n ;;\n\n let same a b = same_witness a b <> None\n let same_witness_exn a b =\n match same_witness a b with\n | Some proof -> proof\n | None -> assert false\n\n let rec head = function\n | Typerep.Named (_, Some (lazy t)) -> head t\n | t -> t\nend\n\nlet typerep_of_int = Typerep.Int\nlet typerep_of_int32 = Typerep.Int32\nlet typerep_of_int64 = Typerep.Int64\nlet typerep_of_nativeint = Typerep.Nativeint\nlet typerep_of_char = Typerep.Char\nlet typerep_of_float = Typerep.Float\nlet typerep_of_string = Typerep.String\nlet typerep_of_bytes = Typerep.Bytes\nlet typerep_of_bool = Typerep.Bool\nlet typerep_of_unit = Typerep.Unit\n\nlet typerep_of_option rep = Typerep.Option rep\nlet typerep_of_list rep = Typerep.List rep\nlet typerep_of_array rep = Typerep.Array rep\nlet typerep_of_lazy_t rep = Typerep.Lazy rep\nlet typerep_of_ref rep = Typerep.Ref rep\n\nlet typerep_of_function dom rng = Typerep.Function (dom, rng)\n\nlet typerep_of_tuple0 = Typerep.Unit\nlet typerep_of_tuple2 a b = Typerep.Tuple (Typerep.Tuple.T2 (a, b))\nlet typerep_of_tuple3 a b c = Typerep.Tuple (Typerep.Tuple.T3 (a, b, c))\nlet typerep_of_tuple4 a b c d = Typerep.Tuple (Typerep.Tuple.T4 (a, b, c, d))\nlet typerep_of_tuple5 a b c d e = Typerep.Tuple (Typerep.Tuple.T5 (a, b, c, d, e))\n\ninclude Name_of\nlet value_tuple0 = ()\n\nlet typerep_of_int63, typename_of_int63 =\n let typerep_and_typename_of_int63_repr\n : type a b . (a, b) Base.Int63.Private.Repr.t -> a Typerep.t * a Typename.t\n = function\n | Base.Int63.Private.Repr.Int -> typerep_of_int, typename_of_int\n | Base.Int63.Private.Repr.Int64 -> typerep_of_int64, typename_of_int64\n in\n typerep_and_typename_of_int63_repr Base.Int63.Private.repr\n","let __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\000\\000\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\005\\000\\000\\000\\000\\000\\001\\000\\255\\255\\002\\000\\000\\000\\000\\000\\\n \\001\\000\\000\\000\\002\\000\\001\\000\\003\\000\\000\\000\\003\\000\\003\\000\\\n \\000\\000\\001\\000\\009\\000\\005\\000\\002\\000\\004\\000\\017\\000\\012\\000\\\n \\014\\000\\004\\000\\017\\000\\018\\000\\026\\000\\028\\000\\005\\000\\027\\000\\\n \\016\\000\\020\\000\\023\\000\\006\\000\\085\\000\\253\\255\\254\\255\\001\\000\\\n \\046\\000\\047\\000\\040\\000\\031\\000\\046\\000\\048\\000\\007\\000\\079\\000\\\n \\028\\000\\062\\000\\008\\000\\255\\255\\009\\000\\067\\000\\067\\000\\103\\000\\\n \\100\\000\\105\\000\\095\\000\\107\\000\\095\\000\\113\\000\\010\\000\\104\\000\\\n \\104\\000\\116\\000\\104\\000\\122\\000\\104\\000\\116\\000\\111\\000\\113\\000\\\n \\011\\000\\116\\000\\117\\000\\125\\000\\127\\000\\012\\000\\126\\000\\115\\000\\\n \\119\\000\\122\\000\\013\\000\";\n Lexing.lex_backtrk =\n \"\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\";\n Lexing.lex_default =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\047\\000\\000\\000\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\008\\000\\012\\000\\014\\000\\024\\000\\012\\000\\039\\000\\012\\000\\055\\000\\\n \\059\\000\\061\\000\\071\\000\\059\\000\\086\\000\\059\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\001\\000\\048\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\002\\000\\049\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\034\\000\\003\\000\\029\\000\\007\\000\\006\\000\\010\\000\\009\\000\\\n \\023\\000\\004\\000\\017\\000\\019\\000\\021\\000\\018\\000\\027\\000\\025\\000\\\n \\015\\000\\026\\000\\016\\000\\005\\000\\011\\000\\020\\000\\022\\000\\028\\000\\\n \\030\\000\\013\\000\\031\\000\\032\\000\\033\\000\\035\\000\\036\\000\\037\\000\\\n \\038\\000\\040\\000\\041\\000\\042\\000\\043\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\081\\000\\\n \\050\\000\\051\\000\\052\\000\\053\\000\\054\\000\\060\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\057\\000\\056\\000\\058\\000\\062\\000\\046\\000\\063\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\064\\000\\065\\000\\066\\000\\067\\000\\068\\000\\069\\000\\070\\000\\072\\000\\\n \\073\\000\\074\\000\\075\\000\\076\\000\\077\\000\\078\\000\\079\\000\\080\\000\\\n \\082\\000\\083\\000\\084\\000\\085\\000\\087\\000\\088\\000\\089\\000\\090\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\045\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\007\\000\\011\\000\\013\\000\\023\\000\\033\\000\\038\\000\\043\\000\\054\\000\\\n \\058\\000\\060\\000\\070\\000\\080\\000\\085\\000\\090\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\047\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\047\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\001\\000\\002\\000\\028\\000\\006\\000\\005\\000\\008\\000\\008\\000\\\n \\022\\000\\003\\000\\016\\000\\018\\000\\020\\000\\017\\000\\026\\000\\024\\000\\\n \\014\\000\\025\\000\\015\\000\\004\\000\\010\\000\\019\\000\\021\\000\\027\\000\\\n \\029\\000\\009\\000\\030\\000\\031\\000\\032\\000\\034\\000\\035\\000\\036\\000\\\n \\037\\000\\039\\000\\040\\000\\041\\000\\042\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\048\\000\\\n \\049\\000\\050\\000\\051\\000\\052\\000\\053\\000\\056\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\055\\000\\055\\000\\057\\000\\061\\000\\044\\000\\062\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\063\\000\\064\\000\\065\\000\\066\\000\\067\\000\\068\\000\\069\\000\\071\\000\\\n \\072\\000\\073\\000\\074\\000\\075\\000\\076\\000\\077\\000\\078\\000\\079\\000\\\n \\081\\000\\082\\000\\083\\000\\084\\000\\086\\000\\087\\000\\088\\000\\089\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\044\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec check lexbuf =\n __ocaml_lex_check_rec lexbuf 0\nand __ocaml_lex_check_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n# 4 \"collector/check_backtraces.mll\"\n ( true )\n# 163 \"collector/check_backtraces.ml\"\n\n | 1 ->\n# 5 \"collector/check_backtraces.mll\"\n ( not_at_bos lexbuf )\n# 168 \"collector/check_backtraces.ml\"\n\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_check_rec lexbuf __ocaml_lex_state\n\nand not_at_bos lexbuf =\n __ocaml_lex_not_at_bos_rec lexbuf 44\nand __ocaml_lex_not_at_bos_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n# 8 \"collector/check_backtraces.mll\"\n ( true )\n# 180 \"collector/check_backtraces.ml\"\n\n | 1 ->\n# 9 \"collector/check_backtraces.mll\"\n ( not_at_bos lexbuf )\n# 185 \"collector/check_backtraces.ml\"\n\n | 2 ->\n# 10 \"collector/check_backtraces.mll\"\n ( false )\n# 190 \"collector/check_backtraces.ml\"\n\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_not_at_bos_rec lexbuf __ocaml_lex_state\n\n;;\n\n# 12 \"collector/check_backtraces.mll\"\n \n let contains_backtraces s = check (Lexing.from_string s)\n\n# 201 \"collector/check_backtraces.ml\"\n","(** This module implements \"Fast Splittable Pseudorandom Number Generators\" by Steele et.\n al. (1). The paper's algorithm provides decent randomness for most purposes, but\n sacrifices cryptographic-quality randomness in favor of performance. The original\n implementation was tested with DieHarder and BigCrush; see the paper for details.\n\n Our implementation is a port from Java to OCaml of the paper's algorithm. Other than\n the choice of initial seed for [create], our port should be faithful. We have not\n re-run the DieHarder or BigCrush tests on our implementation. Our port is also not as\n performant as the original; two factors that hurt us are boxed [int64] values and lack\n of a POPCNT primitive.\n\n (1) http://2014.splashcon.org/event/oopsla2014-fast-splittable-pseudorandom-number-generators\n (also mirrored at http://gee.cs.oswego.edu/dl/papers/oopsla14.pdf)\n\n Beware when implementing this interface; it is easy to implement a [split] operation\n whose output is not as \"independent\" as it seems (2). This bug caused problems for\n Haskell's Quickcheck library for a long time.\n\n (2) Schaathun, \"Evaluation of splittable pseudo-random generators\", JFP 2015.\n http://www.hg.schaathun.net/research/Papers/hgs2015jfp.pdf\n*)\n\nopen! Base\nopen Int64.O\n\nlet is_odd x = x lor 1L = x\n\nlet popcount = Int64.popcount\n\nmodule State = struct\n\n type t =\n { mutable seed : int64\n ; odd_gamma : int64\n }\n\n let golden_gamma = 0x9e37_79b9_7f4a_7c15L\n\n let of_int seed =\n { seed = Int64.of_int seed\n ; odd_gamma = golden_gamma\n }\n\n let copy { seed ; odd_gamma } = { seed ; odd_gamma }\n\n let mix_bits z n =\n z lxor (z lsr n)\n\n let mix64 z =\n let z = (mix_bits z 33) * 0xff51_afd7_ed55_8ccdL in\n let z = (mix_bits z 33) * 0xc4ce_b9fe_1a85_ec53L in\n mix_bits z 33\n\n let mix64_variant13 z =\n let z = (mix_bits z 30) * 0xbf58_476d_1ce4_e5b9L in\n let z = (mix_bits z 27) * 0x94d0_49bb_1331_11ebL in\n mix_bits z 31\n\n let mix_odd_gamma z =\n let z = (mix64_variant13 z) lor 1L in\n let n = popcount (z lxor (z lsr 1)) in\n (* The original paper uses [>=] in the conditional immediately below; however this is\n a typo, and we correct it by using [<]. This was fixed in response to [1] and [2].\n\n [1] https://github.com/janestreet/splittable_random/issues/1\n [2] http://www.pcg-random.org/posts/bugs-in-splitmix.html\n *)\n if Int.( < ) n 24\n then z lxor 0xaaaa_aaaa_aaaa_aaaaL\n else z\n\n let%test_unit \"odd gamma\" =\n for input = -1_000_000 to 1_000_000 do\n let output = mix_odd_gamma (Int64.of_int input) in\n if not (is_odd output) then\n Error.raise_s [%message\n \"gamma value is not odd\"\n (input : int)\n (output : int64)]\n done\n\n let next_seed t =\n let next = t.seed + t.odd_gamma in\n t.seed <- next;\n next\n\n let of_seed_and_gamma ~seed ~gamma =\n let seed = mix64 seed in\n let odd_gamma = mix_odd_gamma gamma in\n { seed; odd_gamma }\n\n let random_int64 random_state =\n Random.State.int64_incl random_state Int64.min_value Int64.max_value\n\n let create random_state =\n let seed = random_int64 random_state in\n let gamma = random_int64 random_state in\n of_seed_and_gamma ~seed ~gamma\n\n let split t =\n let seed = next_seed t in\n let gamma = next_seed t in\n of_seed_and_gamma ~seed ~gamma\n\n let next_int64 t = mix64 (next_seed t)\n\n (* [perturb] is not from any external source, but provides a way to mix in external\n entropy with a pseudo-random state. *)\n let perturb t salt =\n let next = t.seed + mix64 (Int64.of_int salt) in\n t.seed <- next\n\nend\n\nlet bool state = is_odd (State.next_int64 state)\n\n(* We abuse terminology and refer to individual values as biased or unbiased. More\n properly, what is unbiased is the sampler that results if we keep only these \"unbiased\"\n values. *)\nlet remainder_is_unbiased\n ~draw\n ~remainder\n ~draw_maximum\n ~remainder_maximum\n =\n let open Int64.O in\n draw - remainder <= draw_maximum - remainder_maximum\n\nlet%test_unit \"remainder_is_unbiased\" =\n (* choosing a range of 10 values based on a range of 105 values *)\n let draw_maximum = 104L in\n let remainder_maximum = 9L in\n let is_unbiased draw =\n let remainder = Int64.rem draw (Int64.succ remainder_maximum) in\n remainder_is_unbiased ~draw ~remainder ~draw_maximum ~remainder_maximum\n in\n for i = 0 to 99 do\n [%test_result: bool]\n (is_unbiased (Int64.of_int i))\n ~expect:true\n ~message:(Int.to_string i)\n done;\n for i = 100 to 104 do\n [%test_result: bool]\n (is_unbiased (Int64.of_int i))\n ~expect:false\n ~message:(Int.to_string i)\n done\n\n(* This implementation of bounded randomness is adapted from [Random.State.int*] in the\n OCaml standard library. The purpose is to use the minimum number of calls to\n [next_int64] to produce a number uniformly chosen within the given range. *)\nlet int64 =\n let open Int64.O in\n let rec between state ~lo ~hi =\n let draw = State.next_int64 state in\n if lo <= draw && draw <= hi\n then draw\n else between state ~lo ~hi\n in\n let rec non_negative_up_to state maximum =\n let draw = State.next_int64 state land Int64.max_value in\n let remainder = Int64.rem draw (Int64.succ maximum) in\n if remainder_is_unbiased\n ~draw\n ~remainder\n ~draw_maximum:Int64.max_value\n ~remainder_maximum:maximum\n then remainder\n else non_negative_up_to state maximum\n in\n fun state ~lo ~hi ->\n if lo > hi then begin\n Error.raise_s [%message \"int64: crossed bounds\" (lo : int64) (hi : int64)]\n end;\n let diff = hi - lo in\n if diff = Int64.max_value\n then ((State.next_int64 state) land Int64.max_value) + lo\n else if diff >= 0L\n then (non_negative_up_to state diff) + lo\n else between state ~lo ~hi\n\nlet int state ~lo ~hi =\n let lo = Int64.of_int lo in\n let hi = Int64.of_int hi in\n (* truncate unneeded bits *)\n Int64.to_int_trunc (int64 state ~lo ~hi)\n\nlet int32 state ~lo ~hi =\n let lo = Int64.of_int32 lo in\n let hi = Int64.of_int32 hi in\n (* truncate unneeded bits *)\n Int64.to_int32_trunc (int64 state ~lo ~hi)\n\nlet nativeint state ~lo ~hi =\n let lo = Int64.of_nativeint lo in\n let hi = Int64.of_nativeint hi in\n (* truncate unneeded bits *)\n Int64.to_nativeint_trunc (int64 state ~lo ~hi)\n\nlet int63 state ~lo ~hi =\n let lo = Int63.to_int64 lo in\n let hi = Int63.to_int64 hi in\n (* truncate unneeded bits *)\n Int63.of_int64_trunc (int64 state ~lo ~hi)\n\nlet double_ulp = 2. **. -53.\n\nlet%test_unit \"double_ulp\" =\n let open Float.O in\n match Word_size.word_size with\n | W64 ->\n assert (1.0 -. double_ulp < 1.0);\n assert (1.0 -. (double_ulp /. 2.0) = 1.0)\n | W32 ->\n (* 32-bit OCaml uses a 64-bit float representation but 80-bit float instructions, so\n rounding works differently due to the conversion back and forth. *)\n assert (1.0 -. double_ulp < 1.0);\n assert (1.0 -. (double_ulp /. 2.0) <= 1.0)\n\nlet unit_float_from_int64 int64 =\n (Int64.to_float (int64 lsr 11)) *. double_ulp\n\nlet%test_unit \"unit_float_from_int64\" = begin\n let open Float.O in\n assert (unit_float_from_int64 0x0000_0000_0000_0000L = 0.);\n assert (unit_float_from_int64 0xffff_ffff_ffff_ffffL < 1.0);\n assert (unit_float_from_int64 0xffff_ffff_ffff_ffffL = (1.0 -. double_ulp));\nend\n\nlet unit_float state =\n unit_float_from_int64 (State.next_int64 state)\n\n(* Note about roundoff error:\n\n Although [float state ~lo ~hi] is nominally inclusive of endpoints, we are relying on\n the fact that [unit_float] never returns 1., because there are pairs [(lo,hi)] for\n which [lo +. 1. *. (hi -. lo) > hi]. There are also pairs [(lo,hi)] and values of [x]\n with [x < 1.] such that [lo +. x *. (hi -. lo) = hi], so it would not be correct to\n document this as being exclusive of [hi].\n*)\nlet float =\n let rec finite_float state ~lo ~hi =\n let range = hi -. lo in\n if Float.is_finite range\n then (lo +. (unit_float state *. range))\n else begin\n (* If [hi - lo] is infinite, then [hi + lo] is finite because [hi] and [lo] have\n opposite signs. *)\n let mid = (hi +. lo) /. 2. in\n if bool state\n (* Depending on rounding, the recursion with [~hi:mid] might be inclusive of [mid],\n which would mean the two cases overlap on [mid]. The alternative is to increment\n or decrement [mid] using [one_ulp] in either of the calls, but then if the first\n case is exclusive we leave a \"gap\" between the two ranges. There's no perfectly\n uniform solution, so we use the simpler code that does not call [one_ulp]. *)\n then finite_float state ~lo ~hi:mid\n else finite_float state ~lo:mid ~hi\n end\n in\n fun state ~lo ~hi ->\n if not (Float.is_finite lo && Float.is_finite hi)\n then begin\n raise_s [%message\n \"float: bounds are not finite numbers\"\n (lo : float)\n (hi : float)]\n end;\n if Float.( > ) lo hi\n then begin\n raise_s [%message\n \"float: bounds are crossed\"\n (lo : float)\n (hi : float)]\n end;\n finite_float state ~lo ~hi\n\nlet%bench_fun \"unit_float_from_int64\" =\n let int64 = 1L in\n fun () -> unit_float_from_int64 int64\n\nmodule Log_uniform = struct\n module Make (M : sig include Int.S val uniform : State.t -> lo:t -> hi:t -> t end) : sig\n val log_uniform : State.t -> lo:M.t -> hi:M.t -> M.t\n end = struct\n open M\n\n let bits_to_represent t =\n assert (t >= zero);\n let t = ref t in\n let n = ref 0 in\n while !t > zero do\n t := shift_right !t 1;\n Int.incr n;\n done;\n !n\n\n let%test_unit \"bits_to_represent\" =\n let test n expect = [%test_result: int] (bits_to_represent n) ~expect in\n test (M.of_int_exn 0) 0;\n test (M.of_int_exn 1) 1;\n test (M.of_int_exn 2) 2;\n test (M.of_int_exn 3) 2;\n test (M.of_int_exn 4) 3;\n test (M.of_int_exn 5) 3;\n test (M.of_int_exn 6) 3;\n test (M.of_int_exn 7) 3;\n test (M.of_int_exn 8) 4;\n test (M.of_int_exn 100) 7;\n test M.max_value (Int.pred M.num_bits);\n ;;\n\n let min_represented_by_n_bits n =\n if Int.equal n 0\n then zero\n else shift_left one (Int.pred n)\n\n let%test_unit \"min_represented_by_n_bits\" =\n let test n expect = [%test_result: M.t] (min_represented_by_n_bits n) ~expect in\n test 0 (M.of_int_exn 0);\n test 1 (M.of_int_exn 1);\n test 2 (M.of_int_exn 2);\n test 3 (M.of_int_exn 4);\n test 4 (M.of_int_exn 8);\n test 7 (M.of_int_exn 64);\n test (Int.pred M.num_bits) (M.shift_right_logical M.min_value 1);\n ;;\n\n let max_represented_by_n_bits n =\n pred (shift_left one n)\n\n let%test_unit \"max_represented_by_n_bits\" =\n let test n expect = [%test_result: M.t] (max_represented_by_n_bits n) ~expect in\n test 0 (M.of_int_exn 0);\n test 1 (M.of_int_exn 1);\n test 2 (M.of_int_exn 3);\n test 3 (M.of_int_exn 7);\n test 4 (M.of_int_exn 15);\n test 7 (M.of_int_exn 127);\n test (Int.pred M.num_bits) M.max_value;\n ;;\n\n let log_uniform state ~lo ~hi =\n let min_bits = bits_to_represent lo in\n let max_bits = bits_to_represent hi in\n let bits = int state ~lo:min_bits ~hi:max_bits in\n uniform state\n ~lo:(min_represented_by_n_bits bits |> max lo)\n ~hi:(max_represented_by_n_bits bits |> min hi)\n end\n\n module For_int = Make (struct include Int let uniform = int end)\n module For_int32 = Make (struct include Int32 let uniform = int32 end)\n module For_int63 = Make (struct include Int63 let uniform = int63 end)\n module For_int64 = Make (struct include Int64 let uniform = int64 end)\n module For_nativeint = Make (struct include Nativeint let uniform = nativeint end)\n\n let int = For_int.log_uniform\n let int32 = For_int32.log_uniform\n let int63 = For_int63.log_uniform\n let int64 = For_int64.log_uniform\n let nativeint = For_nativeint.log_uniform\nend\n\n","(* This module builds a buffer of \"instructions\", in order to represent a compact sequence\n of delimiting positions and newlines. The parser stores the positions of each:\n\n - newline\n - beginning of atom\n - end of atom\n - left parenthesis\n - right parenthesis\n\n Instructions are encoded as a sequence bits. The next instruction is determined by\n looking at the next few bits:\n\n - bit 0 represents a saved position followed by an offset increment\n - bits 10 represent an offset increment\n - bits 110 are followed by 5 bits of payload. The 5-bit payloads of any subsequent 110-\n instructions are squashed to form a number (least significant 5-bit chunk first).\n This number + 5 represents an offset increment\n - bits 1110 marks the beginning of a new line (with offset incremented)\n - bits 1111 represent a position saved twice followed by an offset increment\n\n For instance let's consider the following sexp:\n\n {[\n {|\n(abc\n \"foo\n bar\"\n)\n|}\n ]}\n\n the sequence of instructions to record in order to reconstruct the position of any\n sub-sexp is:\n\n - 0 save position and advance 1: first '('\n - 0 save position and advance 1: start of \"abc\"\n - 10 advance 1\n - 0 save position and advance 1: end of \"abc\"\n - 1110 newline\n - 1100_0001 advance 6\n - 0 save position and advance 1: start of \"foo\\n bar\"\n - 10 advance 1\n - 10 advance 1\n - 10 advance 1\n - 1110 newline\n - 1100_0000 advance 5\n - 0 save position and advance 1: end of \"foo\\n bar\"\n - 1110 newline\n - 0 save position and advance 1: last ')'\n\n (we save the position after the closing parenthesis)\n\n The total sequence is 42 bits, so we need 6 bytes to store it\n\n The sequence of bits is encoded as a sequence of 16-bit values, where the earlier bits\n are most significant.\n\n Note that the parser stores the end positions as inclusive. This way only single\n character atoms require a double positions. If we were storing end positions as\n exclusive, we would need double positions for [)(] and [a(], which are likely to be\n frequent in s-expressions printed with the non [_hum] printer. We expect single\n character atoms to be less frequent so it makes sense to penalize them instead.\n*)\n\nopen! Import\n\ntype pos =\n { line : int\n ; col : int\n ; offset : int\n }\n[@@deriving_inline sexp_of]\n\nlet sexp_of_pos =\n (function\n | { line = v_line; col = v_col; offset = v_offset } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_int v_offset in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"offset\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_col in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"col\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_line in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"line\"; arg ] :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : pos -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet compare_pos = Caml.compare\nlet beginning_of_file = { line = 1; col = 0; offset = 0 }\nlet shift_pos pos ~cols = { pos with col = pos.col + cols; offset = pos.offset + cols }\n\ntype range =\n { start_pos : pos\n ; end_pos : pos\n }\n[@@deriving_inline sexp_of]\n\nlet sexp_of_range =\n (function\n | { start_pos = v_start_pos; end_pos = v_end_pos } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_pos v_end_pos in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"end_pos\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_pos v_start_pos in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"start_pos\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : range -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet compare_range = Caml.compare\n\nlet make_range_incl ~start_pos ~last_pos =\n { start_pos; end_pos = shift_pos last_pos ~cols:1 }\n;;\n\nmodule Chunk : sig\n (** Represents an array of [length/2] signed 16-bit values *)\n type t\n\n (** Length in bytes. *)\n val length : int\n\n val alloc : unit -> t\n\n (** [get16 ~pos] and [set16 ~pos] manipulate the [pos/2]th stored value.\n [pos] must be even.\n [set16 x] only uses the 16 least significant bits of [x]. *)\n val get16 : t -> pos:int -> int\n\n val set16 : t -> pos:int -> int -> unit\nend = struct\n type t = bytes\n\n (* OCaml strings always waste two bytes at the end, so we take a power of two minus two\n to be sure we don't waste space. *)\n let length = 62\n let alloc () = Bytes.create length\n let get16 = Bytes0.get16\n let set16 = Bytes0.set16\n\n (* If we want to make a [Positions.t] serializable:\n\n {[\n external bswap16 : int -> int = \"%bswap16\";;\n\n let get16 =\n if Caml.Sys.arch_big_endian then\n fun buf ~pos -> get16 buf ~pos |> bswap16\n else\n get16\n\n let set16 =\n if Caml.Sys.arch_big_endian then\n fun buf ~pos x -> set16 buf ~pos (bswap16 x)\n else\n set16\n ]}\n\n *)\nend\n\ntype t_ =\n { chunks : Chunk.t list\n ; (* [num_bytes * 8 + extra_bits] is the number of bits stored in [chunks].\n The last [extra_bits] bits will be stored as the *least* significant bits\n of the appropriate pair of bytes of the last chunk. *)\n num_bytes : int\n ; extra_bits : int\n ; initial_pos : pos\n }\n\ntype t = t_ Lazy.t\n\nlet memory_footprint_in_bytes (lazy t) =\n let num_fields = 4 in\n let header_words = 1 in\n let word_bytes =\n match Sys.word_size with\n | 32 -> 4\n | 64 -> 8\n | _ -> assert false\n in\n let chunk_words =\n let div_ceil a b = (a + b - 1) / b in\n let n =\n div_ceil\n (Chunk.length\n + 1 (* NUL terminating bytes *)\n + 1 (* number of wasted bytes to fill a word *))\n word_bytes\n in\n n + header_words\n in\n let pos_fields = 3 in\n let pos_words = header_words + pos_fields in\n let list_cons_words = header_words + 2 in\n (header_words\n + num_fields\n + pos_words\n + (List.length t.chunks * (chunk_words + list_cons_words)))\n * word_bytes\n;;\n\nmodule Builder = struct\n type t =\n { mutable chunk : Chunk.t\n ; mutable chunk_pos : int\n ; mutable filled_chunks : Chunk.t list (* Filled chunks in reverse order *)\n ; mutable offset : int\n (* Offset of the last saved position or newline plus\n one, or [initial_pos] *)\n ; mutable int_buf : int\n (* the [num_bits] least significant bits of [int_buf]\n are the bits not yet pushed to [chunk]. *)\n ; mutable num_bits : int (* number of bits stored in [int_buf] *)\n ; mutable initial_pos : pos\n }\n\n let invariant t =\n assert (t.chunk_pos >= 0 && t.chunk_pos <= Chunk.length);\n assert (t.offset >= t.initial_pos.offset);\n assert (t.num_bits <= 15)\n ;;\n\n let check_invariant = false\n let invariant t = if check_invariant then invariant t\n\n let create ?(initial_pos = beginning_of_file) () =\n { chunk = Chunk.alloc ()\n ; chunk_pos = 0\n ; filled_chunks = []\n ; offset = initial_pos.offset\n ; int_buf = 0\n ; num_bits = 0\n ; initial_pos\n }\n ;;\n\n let reset t (pos : pos) =\n (* We need a new chunk as [contents] keeps the current chunk in the closure of the\n lazy value. *)\n t.chunk <- Chunk.alloc ();\n t.chunk_pos <- 0;\n t.filled_chunks <- [];\n t.offset <- pos.offset;\n t.int_buf <- 0;\n t.num_bits <- 0;\n t.initial_pos <- pos\n ;;\n\n let[@inlined never] alloc_new_chunk t =\n t.filled_chunks <- t.chunk :: t.filled_chunks;\n t.chunk <- Chunk.alloc ();\n t.chunk_pos <- 0\n ;;\n\n let add_uint16 t n =\n if t.chunk_pos = Chunk.length then alloc_new_chunk t;\n Chunk.set16 t.chunk ~pos:t.chunk_pos n\n ;;\n\n let add_bits t n ~num_bits =\n let int_buf = (t.int_buf lsl num_bits) lor n in\n let num_bits = t.num_bits + num_bits in\n t.int_buf <- int_buf;\n if num_bits < 16\n then t.num_bits <- num_bits\n else (\n let num_bits = num_bits - 16 in\n t.num_bits <- num_bits;\n add_uint16 t (int_buf lsr num_bits);\n t.chunk_pos <- t.chunk_pos + 2\n (* no need to clear the bits of int_buf we just wrote, as further set16 will ignore\n these extra bits. *))\n ;;\n\n let contents t =\n (* Flush the current [t.int_buf] *)\n add_uint16 t t.int_buf;\n let rev_chunks = t.chunk :: t.filled_chunks in\n let chunk_pos = t.chunk_pos in\n let extra_bits = t.num_bits in\n let initial_pos = t.initial_pos in\n lazy\n { chunks = List.rev rev_chunks\n ; num_bytes = ((List.length rev_chunks - 1) * Chunk.length) + chunk_pos\n ; extra_bits\n ; initial_pos\n }\n ;;\n\n let long_shift t n =\n let n = ref (n - 5) in\n while !n > 0 do\n add_bits t (0b1100_0000 lor (!n land 0b0001_1111)) ~num_bits:8;\n n := !n lsr 5\n done\n ;;\n\n (* precondition: n >= 5 *)\n let[@inlined never] add_gen_slow t n ~instr ~instr_bits =\n long_shift t n;\n add_bits t instr ~num_bits:instr_bits\n ;;\n\n let shift4 = 0b10_10_10_10\n\n let[@inline always] add_gen t ~offset ~instr ~instr_bits =\n invariant t;\n let n = offset - t.offset in\n t.offset <- offset + 1;\n match n with\n | 0 | 1 | 2 | 3 | 4 ->\n let num_bits = (n lsl 1) + instr_bits in\n add_bits\n t\n ((shift4 lsl instr_bits) lor instr land ((1 lsl num_bits) - 1))\n ~num_bits\n | 5\n | 6\n | 7\n | 8\n | 9\n | 10\n | 11\n | 12\n | 13\n | 14\n | 15\n | 16\n | 17\n | 18\n | 19\n | 20\n | 21\n | 22\n | 23\n | 24\n | 25\n | 26\n | 27\n | 28\n | 29\n | 30\n | 31\n | 32\n | 33\n | 34\n | 35\n | 36 ->\n add_bits\n t\n (((0b1100_0000 lor (n - 5)) lsl instr_bits) lor instr)\n ~num_bits:(8 + instr_bits)\n | _ ->\n if n < 0 then invalid_arg \"Parsexp.Positions.add_gen\";\n add_gen_slow t n ~instr ~instr_bits\n ;;\n\n let add t ~offset = add_gen t ~offset ~instr:0b0 ~instr_bits:1\n let add_twice t ~offset = add_gen t ~offset ~instr:0b1111 ~instr_bits:4\n let add_newline t ~offset = add_gen t ~offset ~instr:0b1110 ~instr_bits:4\nend\n\ntype positions = t\n\nmodule Iterator : sig\n type t\n\n val create : positions -> t\n\n exception No_more\n\n (* [advance t ~skip] ignores [skip] saved positions and returns the next saved position.\n Raises [No_more] when reaching the end of the position set. *)\n val advance_exn : t -> skip:int -> pos\nend = struct\n type t =\n { mutable chunk : Chunk.t\n ; mutable chunks : Chunk.t list\n ; (* [num_bytes * 8 + extra_bits] is the number of bits available from [instr_pos] in\n [chunk :: chunks]. *)\n mutable num_bytes : int\n ; extra_bits : int\n ; mutable instr_pos : int (* position in [chunk] *)\n ; mutable offset : int\n ; mutable line : int\n ; mutable bol : int\n ; mutable int_buf : int\n ; mutable num_bits : int (* Number of bits not yet consumed in [int_buf] *)\n ; mutable pending : pos option\n }\n\n let create ((lazy p) : positions) =\n match p.chunks with\n | [] -> assert false\n | chunk :: chunks ->\n { chunk\n ; chunks\n ; num_bytes = p.num_bytes\n ; extra_bits = p.extra_bits\n ; instr_pos = 0\n ; offset = p.initial_pos.offset\n ; line = p.initial_pos.line\n ; bol = p.initial_pos.offset - p.initial_pos.col\n ; int_buf = 0\n ; num_bits = 0\n ; pending = None\n }\n ;;\n\n exception No_more\n\n let no_more () = raise_notrace No_more\n\n let[@inlined never] fetch_chunk t =\n match t.chunks with\n | [] -> assert false\n | chunk :: chunks ->\n t.instr_pos <- 0;\n t.num_bytes <- t.num_bytes - Chunk.length;\n t.chunk <- chunk;\n t.chunks <- chunks\n ;;\n\n let fetch t =\n if t.instr_pos > t.num_bytes then no_more ();\n if t.instr_pos = Chunk.length then fetch_chunk t;\n let v = Chunk.get16 t.chunk ~pos:t.instr_pos in\n let added_bits = if t.instr_pos = t.num_bytes then t.extra_bits else 16 in\n t.int_buf <- (t.int_buf lsl added_bits) lor (v land ((1 lsl added_bits) - 1));\n t.num_bits <- t.num_bits + added_bits;\n t.instr_pos <- t.instr_pos + 2\n ;;\n\n let next_instruction_bits t ~num_bits =\n if t.num_bits < num_bits\n then (\n fetch t;\n if t.num_bits < num_bits then no_more ());\n let n = (t.int_buf lsr (t.num_bits - num_bits)) land ((1 lsl num_bits) - 1) in\n t.num_bits <- t.num_bits - num_bits;\n n\n ;;\n\n (* [offset_shift] and [offset_shift_num_bits] encode the offset number\n specified by the immediately preceding [110] instructions. *)\n let rec advance t ~skip ~offset_shift ~offset_shift_num_bits =\n match next_instruction_bits t ~num_bits:1 with\n | 0 ->\n (* bit seq 0 -> new item *)\n let offset = t.offset + offset_shift in\n t.offset <- offset + 1;\n if skip = 0\n then { line = t.line; col = offset - t.bol; offset }\n else advance t ~skip:(skip - 1) ~offset_shift:0 ~offset_shift_num_bits:0\n | _ ->\n (match next_instruction_bits t ~num_bits:1 with\n | 0 ->\n (* bit seq 10 -> shift *)\n t.offset <- t.offset + offset_shift + 1;\n advance t ~skip ~offset_shift:0 ~offset_shift_num_bits:0\n | _ ->\n (match next_instruction_bits t ~num_bits:1 with\n | 0 ->\n (* bit seq 110 -> long shift *)\n let n = next_instruction_bits t ~num_bits:5 in\n let offset_shift = if offset_shift_num_bits = 0 then 5 else offset_shift in\n advance\n t\n ~skip\n ~offset_shift:(offset_shift + (n lsl offset_shift_num_bits))\n ~offset_shift_num_bits:(offset_shift_num_bits + 5)\n | _ ->\n (match next_instruction_bits t ~num_bits:1 with\n | 0 ->\n (* bit seq 1110 -> newline *)\n t.offset <- t.offset + offset_shift + 1;\n t.bol <- t.offset;\n t.line <- t.line + 1;\n advance t ~skip ~offset_shift:0 ~offset_shift_num_bits:0\n | _ ->\n (* bit seq 1111 -> 2 new items *)\n let offset = t.offset + offset_shift in\n t.offset <- offset + 1;\n if skip <= 1\n then (\n let pos = { line = t.line; col = offset - t.bol; offset } in\n if skip = 0 then t.pending <- Some pos;\n pos)\n else advance t ~skip:(skip - 2) ~offset_shift:0 ~offset_shift_num_bits:0)))\n ;;\n\n let advance_exn t ~skip =\n match t.pending with\n | Some pos ->\n t.pending <- None;\n if skip = 0\n then pos\n else advance t ~skip:(skip - 1) ~offset_shift:0 ~offset_shift_num_bits:0\n | None -> advance t ~skip ~offset_shift:0 ~offset_shift_num_bits:0\n ;;\nend\n\nlet find t a b =\n if a < 0 || b <= a then invalid_arg \"Parsexp.Positions.find\";\n let iter = Iterator.create t in\n try\n let start_pos = Iterator.advance_exn iter ~skip:a in\n let last_pos = Iterator.advance_exn iter ~skip:(b - a - 1) in\n make_range_incl ~start_pos ~last_pos\n with\n | Iterator.No_more -> failwith \"Parsexp.Position.find\"\n;;\n\nlet rec sub_sexp_count (sexp : Sexp.t) =\n match sexp with\n | Atom _ -> 1\n | List l -> List.fold_left l ~init:1 ~f:(fun acc x -> acc + sub_sexp_count x)\n;;\n\nmodule Sexp_search = struct\n exception Found of int\n\n let rec loop ~sub index (sexp : Sexp.t) =\n if sexp == sub\n then raise_notrace (Found index)\n else (\n match sexp with\n | Atom _ -> index + 2\n | List l ->\n let index = loop_list ~sub (index + 1) l in\n index + 1)\n\n and loop_list ~sub index (sexps : Sexp.t list) =\n List.fold_left sexps ~init:index ~f:(loop ~sub)\n ;;\n\n let finalize t ~sub a =\n let b = a + (sub_sexp_count sub * 2) - 1 in\n Some (find t a b)\n ;;\n\n let find_sub_sexp_phys t sexp ~sub =\n match loop ~sub 0 sexp with\n | (_ : int) -> None\n | exception Found n -> finalize t ~sub n\n ;;\n\n let find_sub_sexp_in_list_phys t sexps ~sub =\n match loop_list ~sub 0 sexps with\n | (_ : int) -> None\n | exception Found n -> finalize t ~sub n\n ;;\nend\n\nlet find_sub_sexp_phys = Sexp_search.find_sub_sexp_phys\nlet find_sub_sexp_in_list_phys = Sexp_search.find_sub_sexp_in_list_phys\n\nlet to_list t =\n let iter = Iterator.create t in\n let rec loop acc =\n match Iterator.advance_exn iter ~skip:0 with\n | exception Iterator.No_more -> List.rev acc\n | pos -> loop (pos :: acc)\n in\n loop []\n;;\n\nlet to_array t = to_list t |> Array.of_list\nlet compare t1 t2 = Caml.compare (to_array t1) (to_array t2)\nlet sexp_of_t t = sexp_of_array sexp_of_pos (to_array t)\n","open! Import\nmodule Binable = Binable0\n\n(* All the types as exposed in the mli are defined in this [Types] module. The rest of\n this file is simply overriding all the bin_io, compare, and sexp functions to raise\n exceptions. *)\nmodule Types = struct\n module Nobody = struct\n type t [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Nobody\"\n end\n\n module Me = struct\n type t [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Me\"\n end\n\n module Read = struct\n type t = [ `Read ] [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Read\"\n end\n\n module Write = struct\n type t = [ `Who_can_write of Me.t ] [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Write\"\n end\n\n module Immutable = struct\n type t =\n [ Read.t\n | `Who_can_write of Nobody.t\n ]\n [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Immutable\"\n end\n\n module Read_write = struct\n type t =\n [ Read.t\n | Write.t\n ]\n [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Read_write\"\n end\n\n module Upper_bound = struct\n type 'a t =\n [ Read.t\n | `Who_can_write of 'a\n ]\n [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Upper_bound\"\n end\nend\n\nlet failwithf = Printf.failwithf\n\n(* This is an explicit module type instead of just given inline as the return signature of\n [Only_used_as_phantom_type1] to avoid an unused value warning with bin_io values. *)\nmodule type Sexpable_binable_comparable = sig\n type 'a t = 'a [@@deriving bin_io, compare, hash, sexp]\nend\n\n(* Override all bin_io, sexp, compare functions to raise exceptions *)\nmodule Only_used_as_phantom_type1 (Name : sig\n val name : string\n end) : Sexpable_binable_comparable = struct\n type 'a t = 'a\n\n let sexp_of_t _ _ = failwithf \"Unexpectedly called [%s.sexp_of_t]\" Name.name ()\n let t_of_sexp _ _ = failwithf \"Unexpectedly called [%s.t_of_sexp]\" Name.name ()\n let compare _ _ _ = failwithf \"Unexpectedly called [%s.compare]\" Name.name ()\n let hash_fold_t _ _ _ = failwithf \"Unexpectedly called [%s.hash_fold_t]\" Name.name ()\n\n include Binable.Of_binable1_without_uuid [@alert \"-legacy\"]\n (struct\n type 'a t = 'a [@@deriving bin_io]\n end)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable _ =\n failwithf \"Unexpectedly used %s bin_io serialization\" Name.name ()\n ;;\n\n let of_binable _ =\n failwithf \"Unexpectedly used %s bin_io deserialization\" Name.name ()\n ;;\n end)\nend\n\nmodule Only_used_as_phantom_type0 (T : sig\n type t [@@deriving bin_io, compare, hash, sexp]\n\n val name : string\n end) : sig\n type t = T.t [@@deriving bin_io, compare, hash, sexp_poly]\nend = struct\n module M = Only_used_as_phantom_type1 (T)\n\n type t = T.t M.t [@@deriving bin_io, compare, hash, sexp]\n\n let __t_of_sexp__ = t_of_sexp\nend\n\nmodule Stable = struct\n module V1 = struct\n module Nobody = Only_used_as_phantom_type0 (Types.Nobody)\n module Me = Only_used_as_phantom_type0 (Types.Me)\n module Read = Only_used_as_phantom_type0 (Types.Read)\n module Write = Only_used_as_phantom_type0 (Types.Write)\n module Read_write = Only_used_as_phantom_type0 (Types.Read_write)\n module Immutable = Only_used_as_phantom_type0 (Types.Immutable)\n\n type nobody = Nobody.t [@@deriving bin_io, compare, hash, sexp]\n type me = Me.t [@@deriving bin_io, compare, hash, sexp]\n\n module Upper_bound = struct\n module M = Only_used_as_phantom_type1 (Types.Upper_bound)\n\n type 'a t = 'a Types.Upper_bound.t M.t [@@deriving bin_io, compare, hash, sexp]\n\n let __t_of_sexp__ = t_of_sexp\n end\n end\n\n module Export = struct\n type read = V1.Read.t [@@deriving bin_io, compare, hash, sexp]\n type write = V1.Write.t [@@deriving compare, hash, sexp]\n type immutable = V1.Immutable.t [@@deriving bin_io, compare, hash, sexp]\n type read_write = V1.Read_write.t [@@deriving bin_io, compare, hash, sexp]\n type 'a perms = 'a V1.Upper_bound.t [@@deriving bin_io, compare, hash, sexp]\n end\nend\n\ninclude Stable.V1\nmodule Export = Stable.Export\n","open! Import\nopen Quickcheck_intf\nopen Base_quickcheck\nmodule Array = Base.Array\nmodule Bool = Base.Bool\nmodule Char = Base.Char\nmodule Float = Base.Float\nmodule Int = Base.Int\nmodule List = Base.List\nmodule Option = Base.Option\nmodule Type_equal = Base.Type_equal\n\nmodule Polymorphic_types = struct\n type ('a, 'b) variant2 =\n [ `A of 'a\n | `B of 'b\n ]\n [@@deriving quickcheck]\n\n type ('a, 'b, 'c) variant3 =\n [ `A of 'a\n | `B of 'b\n | `C of 'c\n ]\n [@@deriving quickcheck]\n\n type ('a, 'b, 'c, 'd) variant4 =\n [ `A of 'a\n | `B of 'b\n | `C of 'c\n | `D of 'd\n ]\n [@@deriving quickcheck]\n\n type ('a, 'b, 'c, 'd, 'e) variant5 =\n [ `A of 'a\n | `B of 'b\n | `C of 'c\n | `D of 'd\n | `E of 'e\n ]\n [@@deriving quickcheck]\n\n type ('a, 'b, 'c, 'd, 'e, 'f) variant6 =\n [ `A of 'a\n | `B of 'b\n | `C of 'c\n | `D of 'd\n | `E of 'e\n | `F of 'f\n ]\n [@@deriving quickcheck]\n\n type ('a, 'b) tuple2 = 'a * 'b [@@deriving quickcheck]\n type ('a, 'b, 'c) tuple3 = 'a * 'b * 'c [@@deriving quickcheck]\n type ('a, 'b, 'c, 'd) tuple4 = 'a * 'b * 'c * 'd [@@deriving quickcheck]\n type ('a, 'b, 'c, 'd, 'e) tuple5 = 'a * 'b * 'c * 'd * 'e [@@deriving quickcheck]\n\n type ('a, 'b, 'c, 'd, 'e, 'f) tuple6 = 'a * 'b * 'c * 'd * 'e * 'f\n [@@deriving quickcheck]\n\n type (-'a, -'b, 'r) fn2 = 'a -> 'b -> 'r [@@deriving quickcheck]\n type (-'a, -'b, -'c, 'r) fn3 = 'a -> 'b -> 'c -> 'r [@@deriving quickcheck]\n type (-'a, -'b, -'c, -'d, 'r) fn4 = 'a -> 'b -> 'c -> 'd -> 'r [@@deriving quickcheck]\n\n type (-'a, -'b, -'c, -'d, -'e, 'r) fn5 = 'a -> 'b -> 'c -> 'd -> 'e -> 'r\n [@@deriving quickcheck]\n\n type (-'a, -'b, -'c, -'d, -'e, -'f, 'r) fn6 = 'a -> 'b -> 'c -> 'd -> 'e -> 'f -> 'r\n [@@deriving quickcheck]\nend\n\nmodule Observer = struct\n include Observer\n\n let of_hash (type a) (module M : Deriving_hash with type t = a) =\n of_hash_fold M.hash_fold_t\n ;;\n\n let variant2 = Polymorphic_types.quickcheck_observer_variant2\n let variant3 = Polymorphic_types.quickcheck_observer_variant3\n let variant4 = Polymorphic_types.quickcheck_observer_variant4\n let variant5 = Polymorphic_types.quickcheck_observer_variant5\n let variant6 = Polymorphic_types.quickcheck_observer_variant6\n let tuple2 = Polymorphic_types.quickcheck_observer_tuple2\n let tuple3 = Polymorphic_types.quickcheck_observer_tuple3\n let tuple4 = Polymorphic_types.quickcheck_observer_tuple4\n let tuple5 = Polymorphic_types.quickcheck_observer_tuple5\n let tuple6 = Polymorphic_types.quickcheck_observer_tuple6\n let of_predicate a b ~f = unmap (variant2 a b) ~f:(fun x -> if f x then `A x else `B x)\n let singleton () = opaque\n let doubleton f = of_predicate (singleton ()) (singleton ()) ~f\n let enum _ ~f = unmap int ~f\n\n let of_list list ~equal =\n let f x =\n match List.findi list ~f:(fun _ y -> equal x y) with\n | None -> failwith \"Quickcheck.Observer.of_list: value not found\"\n | Some (i, _) -> i\n in\n enum (List.length list) ~f\n ;;\n\n let of_fun f = create (fun x ~size ~hash -> observe (f ()) x ~size ~hash)\n\n let comparison ~compare ~eq ~lt ~gt =\n unmap\n (variant3 lt (singleton ()) gt)\n ~f:(fun x ->\n let c = compare x eq in\n if c < 0 then `A x else if c > 0 then `C x else `B x)\n ;;\nend\n\nmodule Generator = struct\n include Generator\n open Let_syntax\n\n let singleton = return\n\n let doubleton x y =\n create (fun ~size:_ ~random -> if Splittable_random.bool random then x else y)\n ;;\n\n let of_fun f = create (fun ~size ~random -> generate (f ()) ~size ~random)\n\n let of_sequence ~p seq =\n if Float.( <= ) p 0. || Float.( > ) p 1.\n then\n failwith (Printf.sprintf \"Generator.of_sequence: probability [%f] out of bounds\" p);\n Sequence.delayed_fold\n seq\n ~init:()\n ~finish:(fun () -> failwith \"Generator.of_sequence: ran out of values\")\n ~f:(fun () x ~k -> weighted_union [ p, singleton x; 1. -. p, of_fun k ])\n ;;\n\n let rec bounded_geometric ~p ~maximum init =\n if init = maximum\n then singleton maximum\n else\n weighted_union\n [ p, singleton init\n ; 1. -. p, of_fun (fun () -> bounded_geometric ~p ~maximum (init + 1))\n ]\n ;;\n\n let geometric ~p init = bounded_geometric ~p ~maximum:Int.max_value init\n let small_non_negative_int = small_positive_or_zero_int\n let small_positive_int = small_strictly_positive_int\n let list_with_length length t = list_with_length t ~length\n let variant2 = Polymorphic_types.quickcheck_generator_variant2\n let variant3 = Polymorphic_types.quickcheck_generator_variant3\n let variant4 = Polymorphic_types.quickcheck_generator_variant4\n let variant5 = Polymorphic_types.quickcheck_generator_variant5\n let variant6 = Polymorphic_types.quickcheck_generator_variant6\n let tuple2 = Polymorphic_types.quickcheck_generator_tuple2\n let tuple3 = Polymorphic_types.quickcheck_generator_tuple3\n let tuple4 = Polymorphic_types.quickcheck_generator_tuple4\n let tuple5 = Polymorphic_types.quickcheck_generator_tuple5\n let tuple6 = Polymorphic_types.quickcheck_generator_tuple6\n let fn2 = Polymorphic_types.quickcheck_generator_fn2\n let fn3 = Polymorphic_types.quickcheck_generator_fn3\n let fn4 = Polymorphic_types.quickcheck_generator_fn4\n let fn5 = Polymorphic_types.quickcheck_generator_fn5\n let fn6 = Polymorphic_types.quickcheck_generator_fn6\n\n let compare_fn dom =\n fn dom int >>| fun get_index x y -> [%compare: int] (get_index x) (get_index y)\n ;;\n\n let equal_fn dom = compare_fn dom >>| fun cmp x y -> Int.( = ) (cmp x y) 0\nend\n\nmodule Shrinker = struct\n include Shrinker\n\n let empty () = atomic\n let variant2 = Polymorphic_types.quickcheck_shrinker_variant2\n let variant3 = Polymorphic_types.quickcheck_shrinker_variant3\n let variant4 = Polymorphic_types.quickcheck_shrinker_variant4\n let variant5 = Polymorphic_types.quickcheck_shrinker_variant5\n let variant6 = Polymorphic_types.quickcheck_shrinker_variant6\n let tuple2 = Polymorphic_types.quickcheck_shrinker_tuple2\n let tuple3 = Polymorphic_types.quickcheck_shrinker_tuple3\n let tuple4 = Polymorphic_types.quickcheck_shrinker_tuple4\n let tuple5 = Polymorphic_types.quickcheck_shrinker_tuple5\n let tuple6 = Polymorphic_types.quickcheck_shrinker_tuple6\nend\n\nmodule Let_syntax = struct\n module Let_syntax = struct\n include Generator\n module Open_on_rhs = Generator\n end\n\n include Generator.Monad_infix\n\n let return = Generator.return\nend\n\nmodule Configure (Config : Quickcheck_config) = struct\n include Config\n\n let nondeterministic_state = lazy (Random.State.make_self_init ())\n\n let random_state_of_seed seed =\n match seed with\n | `Nondeterministic -> Splittable_random.State.create (force nondeterministic_state)\n | `Deterministic str -> Splittable_random.State.of_int ([%hash: string] str)\n ;;\n\n let make_seed seed : Test.Config.Seed.t =\n match seed with\n | `Nondeterministic -> Nondeterministic\n | `Deterministic string -> Deterministic string\n ;;\n\n let make_shrink_count = function\n | `Exhaustive -> Int.max_value\n | `Limit n -> n\n ;;\n\n let make_config ~seed ~sizes ~trials ~shrink_attempts : Test.Config.t =\n { seed = make_seed (Option.value seed ~default:default_seed)\n ; sizes = Option.value sizes ~default:default_sizes\n ; test_count = Option.value trials ~default:default_trial_count\n ; shrink_count =\n make_shrink_count (Option.value shrink_attempts ~default:default_shrink_attempts)\n }\n ;;\n\n let make_test_m (type a) ~gen ~shrinker ~sexp_of : (module Test.S with type t = a) =\n let module M = struct\n type t = a\n\n let quickcheck_generator = gen\n let quickcheck_shrinker = Option.value shrinker ~default:Shrinker.atomic\n let sexp_of_t = Option.value sexp_of ~default:[%sexp_of: _]\n end\n in\n (module M)\n ;;\n\n let random_value ?(seed = default_seed) ?(size = 30) gen =\n let random = random_state_of_seed seed in\n Generator.generate gen ~size ~random\n ;;\n\n let random_sequence ?seed ?sizes gen =\n let config =\n make_config ~seed ~sizes ~trials:(Some Int.max_value) ~shrink_attempts:None\n in\n let return = ref Sequence.empty in\n Test.with_sample_exn ~config gen ~f:(fun sequence -> return := sequence);\n !return\n ;;\n\n let iter ?seed ?sizes ?trials gen ~f =\n let config = make_config ~seed ~sizes ~trials ~shrink_attempts:None in\n Test.with_sample_exn ~config gen ~f:(fun sequence -> Sequence.iter sequence ~f)\n ;;\n\n let test ?seed ?sizes ?trials ?shrinker ?shrink_attempts ?sexp_of ?examples gen ~f =\n let config = make_config ~seed ~sizes ~trials ~shrink_attempts in\n let test_m = make_test_m ~gen ~shrinker ~sexp_of in\n Test.run_exn ~config ?examples ~f test_m\n ;;\n\n let test_or_error\n ?seed\n ?sizes\n ?trials\n ?shrinker\n ?shrink_attempts\n ?sexp_of\n ?examples\n gen\n ~f\n =\n let config = make_config ~seed ~sizes ~trials ~shrink_attempts in\n let test_m = make_test_m ~gen ~shrinker ~sexp_of in\n Test.run ~config ?examples ~f test_m\n ;;\n\n let test_distinct_values\n (type key)\n ?seed\n ?sizes\n ?sexp_of\n gen\n ~trials\n ~distinct_values\n ~compare\n =\n let module S =\n Caml.Set.Make (struct\n type t = key\n\n let compare = compare\n end)\n in\n let fail set =\n let expect_count = distinct_values in\n let actual_count = S.cardinal set in\n let values =\n match sexp_of with\n | None -> None\n | Some sexp_of_elt -> Some [%sexp (S.elements set : elt list)]\n in\n raise_s\n [%message\n \"insufficient distinct values\"\n (trials : int)\n (expect_count : int)\n (actual_count : int)\n (values : (Base.Sexp.t option[@sexp.option]))]\n in\n with_return (fun r ->\n let set = ref S.empty in\n iter ?seed ?sizes ~trials gen ~f:(fun elt ->\n set := S.add elt !set;\n if S.cardinal !set >= distinct_values then r.return ());\n fail !set)\n ;;\n\n let test_can_generate\n ?seed\n ?sizes\n ?(trials = default_can_generate_trial_count)\n ?sexp_of\n gen\n ~f\n =\n let r = ref [] in\n let f_and_enqueue return x = if f x then return `Can_generate else r := x :: !r in\n match\n With_return.with_return (fun return ->\n iter ?seed ?sizes ~trials gen ~f:(f_and_enqueue return.return);\n `Cannot_generate)\n with\n | `Can_generate -> ()\n | `Cannot_generate ->\n (match sexp_of with\n | None -> failwith \"cannot generate\"\n | Some sexp_of_value ->\n Error.raise_s [%message \"cannot generate\" ~attempts:(!r : value list)])\n ;;\nend\n\ninclude Configure (struct\n let default_seed = `Deterministic \"an arbitrary but deterministic string\"\n\n let default_trial_count =\n match Word_size.word_size with\n | W64 -> 10_000\n | W32 -> 1_000\n ;;\n\n let default_can_generate_trial_count = 10_000\n let default_shrink_attempts = `Limit 1000\n\n let default_sizes =\n Sequence.cycle_list_exn (List.range 0 30 ~stop:`inclusive)\n ;;\n end)\n\nmodule type S = S\nmodule type S1 = S1\nmodule type S2 = S2\nmodule type S_int = S_int\nmodule type S_range = S_range\n\ntype nonrec seed = seed\ntype nonrec shrink_attempts = shrink_attempts\n\nmodule type Quickcheck_config = Quickcheck_config\nmodule type Quickcheck_configured = Quickcheck_configured\n","(* We don't just include Sexplib.Std because one can only define Hashtbl once in this\n module. *)\n\nopen! Import\n\n(** [include]d first so that everything else shadows it *)\ninclude Core_pervasives\n\ninclude Int.Replace_polymorphic_compare\ninclude Base_quickcheck.Export\ninclude Deprecate_pipe_bang\ninclude Either.Export\ninclude From_sexplib\ninclude Interfaces\ninclude List.Infix\ninclude Never_returns\ninclude Ordering.Export\ninclude Perms.Export\ninclude Result.Export\n\ntype -'a return = 'a With_return.return = private { return : 'b. 'a -> 'b } [@@unboxed]\n\ninclude struct\n exception Bug of string [@deprecated \"[since 2020-03] Don't use [Bug]\"]\n [@@deriving sexp]\nend [@@alert \"-deprecated\"]\n\n\n(** Raised if malloc in C bindings fail (errno * size). *)\nexception C_malloc_exn of int * int\n\n(* errno, size *)\nlet () = Callback.register_exception \"C_malloc_exn\" (C_malloc_exn (0, 0))\n\nexception Finally = Exn.Finally\n\nlet fst3 (x, _, _) = x\nlet snd3 (_, y, _) = y\nlet trd3 (_, _, z) = z\n\nlet[@deprecated \"[since 2018-12] Use [Option.value_exn]\"] uw = function\n | Some x -> x\n | None ->\n raise Caml.Not_found\n;;\n\n(** [phys_same] is like [phys_equal], but with a more general type. [phys_same] is useful\n when dealing with existential types, when one has a packed value and an unpacked value\n that one wants to check are physically equal. One can't use [phys_equal] in such a\n situation because the types are different. *)\nlet phys_same (type a b) (a : a) (b : b) = phys_equal a (Obj.magic b : a)\n\nlet ( % ) = Int.( % )\nlet ( /% ) = Int.( /% )\nlet ( // ) = Int.( // )\nlet ( ==> ) a b = (not a) || b\nlet bprintf = Printf.bprintf\nlet const = Fn.const\nlet eprintf = Printf.eprintf\nlet error = Or_error.error\nlet error_s = Or_error.error_s\nlet failwithf = Base.Printf.failwithf\n\nlet failwithp =\n (Error.failwithp [@alert \"-deprecated\"])\n[@@deprecated \"[since 2020-03] Use [failwiths] instead.\"]\n;;\n\nlet failwiths = Error.failwiths\nlet force = Base.Lazy.force\nlet fprintf = Printf.fprintf\nlet ident = Fn.id\n\nlet invalid_argf = Base.Printf.invalid_argf\nlet ifprintf = Printf.ifprintf\nlet is_none = Option.is_none\nlet is_some = Option.is_some\nlet ksprintf = Printf.ksprintf\nlet ok_exn = Or_error.ok_exn\nlet phys_equal = Base.phys_equal\nlet phys_same = phys_same\nlet print_s = Stdio.print_s\nlet eprint_s = Stdio.eprint_s\nlet printf = Printf.printf\nlet protect = Exn.protect\nlet protectx = Exn.protectx\nlet raise_s = Error.raise_s\nlet round = Float.round\nlet ( **. ) = Base.( **. )\n\nlet sprintf = Printf.sprintf\nlet stage = Staged.stage\nlet unstage = Staged.unstage\nlet with_return = With_return.with_return\nlet with_return_option = With_return.with_return_option\n\n(* With the following aliases, we are just making extra sure that the toplevel sexp\n converters line up with the ones in our modules. *)\n\n\ninclude Typerep_lib.Std_internal\n\ninclude (\nstruct\n (* [deriving hash] is missing for [array], [bytes], and [ref] since these types are\n mutable. *)\n type 'a array = 'a Array.t\n [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n\n type bool = Bool.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type char = Char.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type float = Float.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type int = Int.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type int32 = Int32.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type int64 = Int64.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type 'a lazy_t = 'a Lazy.t\n [@@deriving bin_io, compare, hash, sexp, sexp_grammar, typerep]\n\n type 'a list = 'a List.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type nativeint = Nativeint.t\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type 'a option = 'a Option.t\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type string = String.t\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type bytes = Bytes.t [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n\n type 'a ref = 'a Ref.t\n [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n\n type unit = Unit.t\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n (* Bin_prot has optimized functions for float arrays *)\n type float_array = Bin_prot.Std.float_array [@@deriving bin_io]\n\n include (\n struct\n type float_array = Float.t array\n [@@deriving compare, sexp, sexp_grammar, typerep]\n end :\n sig\n type float_array [@@deriving compare, sexp, sexp_grammar, typerep]\n end\n with type float_array := float_array)\nend :\nsig\n type 'a array [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n type bool [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type char [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type float [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type int [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type int32 [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type int64 [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type 'a lazy_t [@@deriving bin_io, compare, hash, sexp, sexp_grammar, typerep]\n type 'a list [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type nativeint\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type 'a option\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type string [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type bytes [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n type 'a ref [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n type unit [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type float_array = float array\n [@@deriving bin_io, compare, sexp, sexp_grammar, typerep]\nend\nwith type 'a array := 'a array\nwith type bool := bool\nwith type char := char\nwith type float := float\nwith type int := int\nwith type int32 := int32\nwith type int64 := int64\nwith type 'a list := 'a list\nwith type nativeint := nativeint\nwith type 'a option := 'a option\nwith type string := string\nwith type bytes := bytes\nwith type 'a lazy_t := 'a lazy_t\nwith type 'a ref := 'a ref\nwith type unit := unit)\n\nlet sexp_of_exn = Exn.sexp_of_t\n\n\n(* The below declarations define converters for the special types recognized by pa-sexp.\n E.g. this allows the following to work:\n\n type t = { foo : int sexp_option } [@@deriving bin_io, compare, hash, sexp] *)\ninclude struct\n [@@@ocaml.warning \"-3\"]\n\n type 'a sexp_array = 'a array\n [@@deriving bin_io, compare, typerep]\n [@@deprecated \"[since 2019-03] use [@sexp.array] instead\"]\n\n type sexp_bool = bool\n [@@deriving bin_io, compare, hash, typerep]\n [@@deprecated \"[since 2019-03] use [@sexp.bool] instead\"]\n\n type 'a sexp_list = 'a list\n [@@deriving bin_io, compare, hash, typerep]\n [@@deprecated \"[since 2019-03] use [@sexp.list] instead\"]\n\n type 'a sexp_option = 'a option\n [@@deriving bin_io, compare, hash, typerep]\n [@@deprecated \"[since 2019-03] use [@sexp.option] instead\"]\n\n type 'a sexp_opaque = 'a\n [@@deriving bin_io, compare, hash, typerep]\n [@@deprecated \"[since 2019-03] use [@sexp.opaque] instead\"]\nend\n\n(* The code below checks that the signatures in core_map.mli and core_set.mli are\n consistent with the generic map and set signatures defined in map_intf.ml\n and core_set_intf.ml. *)\n\nlet () =\n let module T = struct\n type 'a elt = 'a\n type 'a cmp = 'a\n end\n in\n let module M : sig\n open Set_intf\n\n module Tree : sig\n type ('a, 'b) t\n\n include\n Creators_and_accessors2_with_comparator\n with type ('a, 'b) set := ('a, 'b) t\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) t\n with type ('a, 'b) named := ('a, 'b) Tree.Named.t\n end\n\n type ('a, 'b) t\n\n include\n Accessors2\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type ('a, 'b) named := ('a, 'b) Named.t\n\n include\n Creators_generic\n with type ('a, 'b) set := ('a, 'b) t\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type 'a elt := 'a T.elt\n with type 'a cmp := 'a T.cmp\n with type ('a, 'cmp, 'z) options :=\n ('a, 'cmp, 'z) Set_intf.With_first_class_module.t\n end =\n Set\n in\n ()\n;;\n\nlet () =\n let module T = struct\n type 'k key = 'k\n type 'c cmp = 'c\n end\n in\n let module M : sig\n open Map_intf\n\n module Tree : sig\n type ('a, 'b, 'c) t\n\n include\n Creators_and_accessors3_with_comparator\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) t\n end\n\n type ('a, 'b, 'c) t\n\n include\n Accessors3\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n\n include\n Creators_generic\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n with type ('a, 'cmp, 'z) options :=\n ('a, 'cmp, 'z) Map_intf.With_first_class_module.t\n with type 'k key := 'k T.key\n with type 'c cmp := 'c T.cmp\n end =\n Map\n in\n ()\n;;\n\n","open! Import\nopen Std_internal\nopen! Int.Replace_polymorphic_compare\n\nmodule Stable = struct\n module V1 = struct\n module Parts = struct\n type t =\n { sign : Sign.t\n ; hr : int\n ; min : int\n ; sec : int\n ; ms : int\n ; us : int\n ; ns : int\n }\n [@@deriving compare, sexp]\n end\n\n module type Like_a_float = sig\n type t [@@deriving bin_io, hash, quickcheck, typerep]\n\n include Comparable.S_common with type t := t\n include Comparable.With_zero with type t := t\n include Floatable with type t := t\n\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val zero : t\n val robust_comparison_tolerance : t\n val abs : t -> t\n val neg : t -> t\n val scale : t -> float -> t\n end\n\n module T : sig\n type underlying = float [@@deriving hash]\n type t = private underlying [@@deriving bin_io, hash]\n\n include Like_a_float with type t := t\n include Robustly_comparable with type t := t\n\n module Constant : sig\n val nanoseconds_per_second : float\n val microseconds_per_second : float\n val milliseconds_per_second : float\n val nanosecond : t\n val microsecond : t\n val millisecond : t\n val second : t\n val minute : t\n val hour : t\n val day : t\n end\n\n val to_parts : t -> Parts.t\n val next : t -> t\n val prev : t -> t\n end = struct\n type underlying = float [@@deriving hash]\n type t = underlying [@@deriving hash]\n\n let next t = Float.one_ulp `Up t\n let prev t = Float.one_ulp `Down t\n\n (* IF THIS REPRESENTATION EVER CHANGES, ENSURE THAT EITHER\n (1) all values serialize the same way in both representations, or\n (2) you add a new Time.Span version to stable.ml *)\n include (\n struct\n include Float\n\n let sign = sign_exn\n end :\n Like_a_float with type t := t)\n\n (* due to precision limitations in float we can't expect better than microsecond\n precision *)\n include Float.Robust_compare.Make (struct\n let robust_comparison_tolerance = 1E-6\n end)\n\n (* this prevents any worry about having these very common names redefined below and\n makes their usage within this module safer. Constant is included at the very\n bottom to re-export these constants in a more convenient way *)\n module Constant = struct\n let nanoseconds_per_second = 1E9\n let microseconds_per_second = 1E6\n let milliseconds_per_second = 1E3\n\n (* spans are stored as a float in seconds *)\n let nanosecond = of_float (1. /. nanoseconds_per_second)\n let microsecond = of_float (1. /. microseconds_per_second)\n let millisecond = of_float (1. /. milliseconds_per_second)\n let second = of_float 1.\n let minute = of_float 60.\n let hour = of_float (60. *. 60.)\n let day = of_float (24. *. 60. *. 60.)\n end\n\n\n let to_parts t : Parts.t =\n let sign = Float.sign_exn t in\n let t = abs t in\n let integral = Float.round_down t in\n let fractional = t -. integral in\n let seconds = Float.iround_down_exn integral in\n let nanoseconds = Float.iround_nearest_exn (fractional *. 1E9) in\n let seconds, nanoseconds =\n if Int.equal nanoseconds 1_000_000_000\n then Int.succ seconds, 0\n else seconds, nanoseconds\n in\n let sec = seconds mod 60 in\n let minutes = seconds / 60 in\n let min = minutes mod 60 in\n let hr = minutes / 60 in\n let ns = nanoseconds mod 1000 in\n let microseconds = nanoseconds / 1000 in\n let us = microseconds mod 1000 in\n let milliseconds = microseconds / 1000 in\n let ms = milliseconds in\n { sign; hr; min; sec; ms; us; ns }\n ;;\n end\n\n let ( / ) t f = T.of_float ((t : T.t :> float) /. f)\n let ( // ) (f : T.t) (t : T.t) = (f :> float) /. (t :> float)\n\n (* Multiplying by 1E3 is more accurate than division by 1E-3 *)\n let to_ns (x : T.t) = (x :> float) *. T.Constant.nanoseconds_per_second\n let to_us (x : T.t) = (x :> float) *. T.Constant.microseconds_per_second\n let to_ms (x : T.t) = (x :> float) *. T.Constant.milliseconds_per_second\n let to_sec (x : T.t) = (x :> float)\n let to_min x = x // T.Constant.minute\n let to_hr x = x // T.Constant.hour\n let to_day x = x // T.Constant.day\n let to_int63_seconds_round_down_exn x = Float.int63_round_down_exn (to_sec x)\n let ( ** ) f (t : T.t) = T.of_float (f *. (t :> float))\n\n (* Division by 1E3 is more accurate than multiplying by 1E-3 *)\n let of_ns x = T.of_float (x /. T.Constant.nanoseconds_per_second)\n let of_us x = T.of_float (x /. T.Constant.microseconds_per_second)\n let of_ms x = T.of_float (x /. T.Constant.milliseconds_per_second)\n let of_sec x = T.of_float x\n let of_int_sec x = of_sec (Float.of_int x)\n let of_int32_seconds sec = of_sec (Int32.to_float sec)\n\n (* Note that [Int63.to_float] can lose precision, but only on inputs large enough that\n [of_sec] in either the Time_ns or Time_float case would lose precision (or just be\n plain out of bounds) anyway. *)\n let of_int63_seconds sec = of_sec (Int63.to_float sec)\n let of_min x = x ** T.Constant.minute\n let of_hr x = x ** T.Constant.hour\n let of_day x = x ** T.Constant.day\n\n let divide_by_unit_of_time t unit_of_time =\n match (unit_of_time : Unit_of_time.t) with\n | Nanosecond -> to_ns t\n | Microsecond -> to_us t\n | Millisecond -> to_ms t\n | Second -> to_sec t\n | Minute -> to_min t\n | Hour -> to_hr t\n | Day -> to_day t\n ;;\n\n let scale_by_unit_of_time float unit_of_time =\n match (unit_of_time : Unit_of_time.t) with\n | Nanosecond -> of_ns float\n | Microsecond -> of_us float\n | Millisecond -> of_ms float\n | Second -> of_sec float\n | Minute -> of_min float\n | Hour -> of_hr float\n | Day -> of_day float\n ;;\n\n let create\n ?(sign = Sign.Pos)\n ?(day = 0)\n ?(hr = 0)\n ?(min = 0)\n ?(sec = 0)\n ?(ms = 0)\n ?(us = 0)\n ?(ns = 0)\n ()\n =\n let ( + ) = T.( + ) in\n let t =\n of_day (Float.of_int day)\n + of_hr (Float.of_int hr)\n + of_min (Float.of_int min)\n + of_sec (Float.of_int sec)\n + of_ms (Float.of_int ms)\n + of_us (Float.of_int us)\n + of_ns (Float.of_int ns)\n in\n match sign with\n | Neg -> T.( - ) T.zero t\n | Pos | Zero -> t\n ;;\n\n include T\n include Constant\n\n let randomize t ~percent = Span_helpers.randomize t ~percent ~scale\n\n let to_short_string t =\n let ({ sign; hr; min; sec; ms; us; ns } : Parts.t) = to_parts t in\n Span_helpers.short_string ~sign ~hr ~min ~sec ~ms ~us ~ns\n ;;\n\n (* WARNING: if you are going to change this function in any material way, make sure\n you update Stable appropriately. *)\n let of_string_v1_v2 (s : string) ~is_v2 =\n try\n match s with\n | \"\" -> failwith \"empty string\"\n | _ ->\n let float n =\n match String.drop_suffix s n with\n | \"\" -> failwith \"no number given\"\n | s ->\n let v = Float.of_string s in\n Validate.maybe_raise (Float.validate_ordinary v);\n v\n in\n let len = String.length s in\n (match s.[Int.( - ) len 1] with\n | 's' ->\n if Int.( >= ) len 2 && Char.( = ) s.[Int.( - ) len 2] 'm'\n then of_ms (float 2)\n else if is_v2 && Int.( >= ) len 2 && Char.( = ) s.[Int.( - ) len 2] 'u'\n then of_us (float 2)\n else if is_v2 && Int.( >= ) len 2 && Char.( = ) s.[Int.( - ) len 2] 'n'\n then of_ns (float 2)\n else T.of_float (float 1)\n | 'm' -> of_min (float 1)\n | 'h' -> of_hr (float 1)\n | 'd' -> of_day (float 1)\n | _ ->\n if is_v2\n then failwith \"Time spans must end in ns, us, ms, s, m, h, or d.\"\n else failwith \"Time spans must end in ms, s, m, h, or d.\")\n with\n | exn ->\n invalid_argf \"Span.of_string could not parse '%s': %s\" s (Exn.to_string exn) ()\n ;;\n\n let of_sexp_error_exn exn sexp = of_sexp_error (Exn.to_string exn) sexp\n\n exception T_of_sexp of Sexp.t * exn [@@deriving sexp]\n exception T_of_sexp_expected_atom_but_got of Sexp.t [@@deriving sexp]\n\n let t_of_sexp_v1_v2 sexp ~is_v2 =\n match sexp with\n | Sexp.Atom x ->\n (try of_string_v1_v2 x ~is_v2 with\n | exn -> of_sexp_error_exn (T_of_sexp (sexp, exn)) sexp)\n | Sexp.List _ -> of_sexp_error_exn (T_of_sexp_expected_atom_but_got sexp) sexp\n ;;\n\n let string ~is_v2 suffix float =\n if is_v2\n (* This is the same float-to-string conversion used in [Float.sexp_of_t]. It's like\n [Float.to_string], but may leave off trailing period. *)\n then !Sexplib.Conv.default_string_of_float float ^ suffix\n else sprintf \"%g%s\" float suffix\n ;;\n\n (* WARNING: if you are going to change this function in any material way, make sure\n you update Stable appropriately. *)\n (* I'd like it to be the case that you could never construct an infinite span, but I\n can't think of a good way to enforce it. So this to_string function can produce\n strings that will raise an exception when they are fed to of_string *)\n let to_string_v1_v2 (t : T.t) ~is_v2 =\n (* this is a sad broken abstraction... *)\n let module C = Float.Class in\n match Float.classify (t :> float) with\n | C.Subnormal | C.Zero -> \"0s\"\n | C.Infinite -> if T.( > ) t T.zero then \"inf\" else \"-inf\"\n | C.Nan -> \"nan\"\n | C.Normal ->\n let ( < ) = T.( < ) in\n let abs_t = T.of_float (Float.abs (t :> float)) in\n if is_v2 && abs_t < T.Constant.microsecond\n then string ~is_v2 \"ns\" (to_ns t)\n else if is_v2 && abs_t < T.Constant.millisecond\n then string ~is_v2 \"us\" (to_us t)\n else if abs_t < T.Constant.second\n then string ~is_v2 \"ms\" (to_ms t)\n else if abs_t < T.Constant.minute\n then string ~is_v2 \"s\" (to_sec t)\n else if abs_t < T.Constant.hour\n then string ~is_v2 \"m\" (to_min t)\n else if abs_t < T.Constant.day\n then string ~is_v2 \"h\" (to_hr t)\n else string ~is_v2 \"d\" (to_day t)\n ;;\n\n let sexp_of_t_v1_v2 t ~is_v2 = Sexp.Atom (to_string_v1_v2 t ~is_v2)\n let t_of_sexp sexp = t_of_sexp_v1_v2 sexp ~is_v2:false\n let sexp_of_t t = sexp_of_t_v1_v2 t ~is_v2:false\n end\n\n module V2 = struct\n include V1\n\n let t_of_sexp sexp = t_of_sexp_v1_v2 sexp ~is_v2:true\n let sexp_of_t t = sexp_of_t_v1_v2 t ~is_v2:true\n end\n\n module V3 = struct\n include V1\n\n let to_unit_of_time t : Unit_of_time.t =\n let open T in\n let open Constant in\n let abs_t = T.abs t in\n if abs_t >= day\n then Day\n else if abs_t >= hour\n then Hour\n else if abs_t >= minute\n then Minute\n else if abs_t >= second\n then Second\n else if abs_t >= millisecond\n then Millisecond\n else if abs_t >= microsecond\n then Microsecond\n else Nanosecond\n ;;\n\n let of_unit_of_time : Unit_of_time.t -> T.t =\n let open T.Constant in\n function\n | Nanosecond -> nanosecond\n | Microsecond -> microsecond\n | Millisecond -> millisecond\n | Second -> second\n | Minute -> minute\n | Hour -> hour\n | Day -> day\n ;;\n\n let suffix_of_unit_of_time unit_of_time =\n match (unit_of_time : Unit_of_time.t) with\n | Nanosecond -> \"ns\"\n | Microsecond -> \"us\"\n | Millisecond -> \"ms\"\n | Second -> \"s\"\n | Minute -> \"m\"\n | Hour -> \"h\"\n | Day -> \"d\"\n ;;\n\n module Of_string = struct\n let invalid_string string ~reason =\n let message = \"Time.Span.of_string: \" ^ reason in\n raise_s [%message message string]\n ;;\n\n let rec find_unit_of_time_by_suffix string ~index unit_of_time_list =\n match unit_of_time_list with\n | [] -> invalid_string string ~reason:\"invalid span part suffix\"\n | unit_of_time :: rest ->\n let suffix = suffix_of_unit_of_time unit_of_time in\n if String.is_substring_at string ~pos:index ~substring:suffix\n then unit_of_time\n else find_unit_of_time_by_suffix string ~index rest\n ;;\n\n let parse_suffix string ~index =\n (* We rely on the fact that \"ms\" comes before \"m\" in [Unit_of_time.all] to get a\n correct match on millisecond timestamps. This assumption is demonstrated in the\n expect test below. *)\n find_unit_of_time_by_suffix string ~index Unit_of_time.all\n ;;\n\n (* We validate magnitude strings so that we know where the unit-of-time suffix\n begins, and so that only sensible strings are allowed. We do not want to be as\n permissive as [Float.of_string]; for example, hexadecimal span magnitudes are not\n allowed. After validation, we still use [Float.of_string] to produce the actual\n value. *)\n module Float_parser = struct\n (* [In_decimal_have_digit] includes having a digit before the decimal point. *)\n type state =\n | In_integer_need_digit\n | In_integer_have_digit\n | In_decimal_need_digit\n | In_decimal_have_digit\n | In_exponent_need_digit_or_sign\n | In_exponent_need_digit\n | In_exponent_have_digit\n\n type token =\n | Digit\n | Point\n | Under\n | Sign\n | Expt\n\n let state_is_final = function\n | In_integer_have_digit | In_decimal_have_digit | In_exponent_have_digit ->\n true\n | In_integer_need_digit\n | In_decimal_need_digit\n | In_exponent_need_digit_or_sign\n | In_exponent_need_digit -> false\n ;;\n\n let token_of_char = function\n | '0' .. '9' -> Some Digit\n | '.' -> Some Point\n | '_' -> Some Under\n | '-' | '+' -> Some Sign\n | 'E' | 'e' -> Some Expt\n | _ -> None\n ;;\n\n let invalid_string string =\n invalid_string string ~reason:\"invalid span part magnitude\"\n ;;\n\n let rec find_index_after_float_in_state string ~index ~len ~state =\n let open Int.O in\n if index = len\n then if state_is_final state then index else invalid_string string\n else (\n match token_of_char string.[index] with\n | None -> if state_is_final state then index else invalid_string string\n | Some token ->\n let state =\n match state, token with\n | In_integer_need_digit, Digit -> In_integer_have_digit\n | In_integer_need_digit, Point -> In_decimal_need_digit\n | In_integer_need_digit, Under\n | In_integer_need_digit, Sign\n | In_integer_need_digit, Expt -> invalid_string string\n | In_integer_have_digit, Digit | In_integer_have_digit, Under ->\n In_integer_have_digit\n | In_integer_have_digit, Point -> In_decimal_have_digit\n | In_integer_have_digit, Expt -> In_exponent_need_digit_or_sign\n | In_integer_have_digit, Sign -> invalid_string string\n | In_decimal_need_digit, Digit -> In_decimal_have_digit\n | In_decimal_need_digit, Point\n | In_decimal_need_digit, Under\n | In_decimal_need_digit, Expt\n | In_decimal_need_digit, Sign -> invalid_string string\n | In_decimal_have_digit, Digit | In_decimal_have_digit, Under ->\n In_decimal_have_digit\n | In_decimal_have_digit, Expt -> In_exponent_need_digit_or_sign\n | In_decimal_have_digit, Point | In_decimal_have_digit, Sign ->\n invalid_string string\n | In_exponent_need_digit_or_sign, Digit -> In_exponent_have_digit\n | In_exponent_need_digit_or_sign, Sign -> In_exponent_need_digit\n | In_exponent_need_digit_or_sign, Point\n | In_exponent_need_digit_or_sign, Under\n | In_exponent_need_digit_or_sign, Expt -> invalid_string string\n | In_exponent_need_digit, Digit -> In_exponent_have_digit\n | In_exponent_need_digit, Point\n | In_exponent_need_digit, Under\n | In_exponent_need_digit, Expt\n | In_exponent_need_digit, Sign -> invalid_string string\n | In_exponent_have_digit, Digit | In_exponent_have_digit, Under ->\n In_exponent_have_digit\n | In_exponent_have_digit, Point\n | In_exponent_have_digit, Expt\n | In_exponent_have_digit, Sign -> invalid_string string\n in\n find_index_after_float_in_state string ~index:(index + 1) ~len ~state)\n ;;\n\n let find_index_after_float string ~index ~len =\n find_index_after_float_in_state string ~index ~len ~state:In_integer_need_digit\n ;;\n end\n\n let rec accumulate_magnitude string ~magnitude ~index ~len =\n if Int.equal index len\n then magnitude\n else (\n let suffix_index = Float_parser.find_index_after_float string ~index ~len in\n let unit_of_time = parse_suffix string ~index:suffix_index in\n let until_index =\n Int.( + ) suffix_index (String.length (suffix_of_unit_of_time unit_of_time))\n in\n let float_string =\n String.sub string ~pos:index ~len:(Int.( - ) suffix_index index)\n in\n let float = Float.of_string float_string in\n let magnitude = magnitude + scale_by_unit_of_time float unit_of_time in\n accumulate_magnitude string ~magnitude ~index:until_index ~len)\n ;;\n\n let parse_magnitude string ~index ~len =\n accumulate_magnitude string ~magnitude:T.zero ~index ~len\n ;;\n\n let of_string string =\n let open Int.O in\n match string with\n | \"NANs\" -> of_sec Float.nan\n | \"-INFs\" -> of_sec Float.neg_infinity\n | \"INFs\" -> of_sec Float.infinity\n | _ ->\n let len = String.length string in\n if len = 0 then invalid_string string ~reason:\"empty input\";\n let negative, index =\n match string.[0] with\n | '-' -> true, 1\n | '+' -> false, 1\n | _ -> false, 0\n in\n if index >= len then invalid_string string ~reason:\"empty input\";\n let magnitude = parse_magnitude string ~index ~len in\n if negative then T.neg magnitude else magnitude\n ;;\n end\n\n let of_string = Of_string.of_string\n\n module To_string = struct\n let string_of_float_without_trailing_decimal float =\n let string = Float.to_string float in\n let suffix = \".\" in\n if String.is_suffix string ~suffix\n then String.chop_suffix_exn string ~suffix\n else string\n ;;\n\n (* As we build up a string, we keep a running sum of the value that will be read\n back in, so that we can compute the remainder that needs to be generated. *)\n let sum ~sum_t ~unit_of_time ~magnitude =\n sum_t + scale_by_unit_of_time magnitude unit_of_time\n ;;\n\n (* For some units (very large numbers of days, or seconds and smaller) we just\n render a float directly, with a fix for roundoff error. *)\n let to_float_string ~abs_t ~unit_of_time ~fixup_unit_of_time =\n let magnitude = divide_by_unit_of_time abs_t unit_of_time in\n let sum_t = sum ~sum_t:zero ~unit_of_time ~magnitude in\n if sum_t = abs_t\n then\n string_of_float_without_trailing_decimal magnitude\n ^ suffix_of_unit_of_time unit_of_time\n else (\n let magnitude =\n if sum_t < abs_t\n then magnitude\n else divide_by_unit_of_time (prev abs_t) unit_of_time\n in\n let sum_t = sum ~sum_t:zero ~unit_of_time ~magnitude in\n let rem_t = abs_t - sum_t in\n let fixup_magnitude = divide_by_unit_of_time rem_t fixup_unit_of_time in\n string_of_float_without_trailing_decimal magnitude\n ^ suffix_of_unit_of_time unit_of_time\n (* [rem_t] is at ULP size of [abs_t], it needs just one bit of precision *)\n ^ sprintf \"%.1g\" fixup_magnitude\n ^ suffix_of_unit_of_time fixup_unit_of_time)\n ;;\n\n (* For non-decimal units (minutes and greater), we render an integer magnitude, and\n return that with the running sum so the remainder can be rendered at a smaller\n unit. *)\n let to_int_string_and_sum unit_of_time ~abs_t ~sum_t =\n let unit_span = of_unit_of_time unit_of_time in\n let rem_t = abs_t - sum_t in\n (* We calculate the approximate multiple of [unit_of_time] that needs to be\n added to [sum_t]. Due to rounding, this can be off by one (we've never seen a\n case off by two or more), so we re-compute the remainder and correct if\n necessary. *)\n let magnitude = Float.round_down (rem_t // unit_span) in\n let new_sum_t = sum ~sum_t ~unit_of_time ~magnitude in\n let new_rem_t = abs_t - new_sum_t in\n let magnitude =\n if new_rem_t = zero\n then magnitude\n else if new_rem_t < zero\n then magnitude -. 1.\n else (\n let next_magnitude = magnitude +. 1. in\n let next_sum_t = sum ~sum_t ~unit_of_time ~magnitude:next_magnitude in\n let next_rem_t = abs_t - next_sum_t in\n if next_rem_t < zero then magnitude else next_magnitude)\n in\n if Float.( <= ) magnitude 0.\n then \"\", sum_t\n else (\n let new_sum_t = sum ~sum_t ~unit_of_time ~magnitude in\n let string =\n Int63.to_string (Int63.of_float magnitude)\n ^ suffix_of_unit_of_time unit_of_time\n in\n string, new_sum_t)\n ;;\n\n let decimal_order_of_magnitude t = Float.log10 (to_sec t)\n\n (* The final seconds-or-smaller unit needs to be printed with enough digits to\n round-trip the whole span (which is minutes or greater); this can be\n significantly fewer digits than would be needed for the seconds-or-smaller\n remainder itself. *)\n let to_float_string_after_int_strings ~sum_t ~abs_t =\n if sum_t >= abs_t\n then \"\"\n else (\n let rem_t = abs_t - sum_t in\n let unit_of_time = to_unit_of_time rem_t in\n let unit_span = of_unit_of_time unit_of_time in\n let magnitude = rem_t // unit_span in\n let new_sum_t = sum ~sum_t ~unit_of_time ~magnitude in\n let new_rem_t = abs_t - new_sum_t in\n if abs rem_t <= abs new_rem_t\n then \"\"\n else (\n let order_of_magnitude_of_first_digit =\n Float.iround_down_exn (decimal_order_of_magnitude rem_t)\n in\n let half_ulp = (abs_t - prev abs_t) / 2. in\n let order_of_magnitude_of_final_digit =\n (* This works out to rounding down, except in the case of exact integers,\n which are decremented. This makes sure we always stop at a digit with\n strictly more precision than half the ULP. *)\n Int.pred (Float.iround_up_exn (decimal_order_of_magnitude half_ulp))\n in\n let number_of_digits =\n let open Int.O in\n 1 + order_of_magnitude_of_first_digit - order_of_magnitude_of_final_digit\n in\n let suffix = suffix_of_unit_of_time unit_of_time in\n sprintf \"%.*g\" number_of_digits magnitude ^ suffix))\n ;;\n\n (* This helper avoids unnecessary allocation, because for our use below, it is\n common to have either or both arguments be empty. Currently (2018-02), the\n built-in [^] allocates even when appending to an empty string. *)\n let ( ^? ) x y =\n if String.is_empty x then y else if String.is_empty y then x else x ^ y\n ;;\n\n let to_string t =\n let float = to_float t in\n if not (Float.is_finite float)\n then\n if (* We print specific special strings for non-finite floats *)\n Float.is_nan float\n then \"NANs\"\n else if Float.is_negative float\n then \"-INFs\"\n else \"INFs\"\n else if t = zero\n then \"0s\"\n else (\n let unit_of_time = to_unit_of_time t in\n let abs_t = abs t in\n let sign = if t < zero then \"-\" else \"\" in\n let magnitude_string =\n match unit_of_time with\n (* We can use normal float notation for seconds and sub-second units, they are\n readable with a decimal point. *)\n | Nanosecond | Microsecond | Millisecond | Second ->\n to_float_string ~abs_t ~unit_of_time ~fixup_unit_of_time:Nanosecond\n (* For large enough values that the ULP is a day or more, we can use float\n notation because we are expressing a single, very large integer. *)\n | Day when next abs_t - abs_t >= day ->\n to_float_string ~abs_t ~unit_of_time ~fixup_unit_of_time:Day\n (* For everything in between, we need to use integer units of days, hours,\n and/or minutes, because those units are not readable as decimals, and we\n tack on a decimal remainder of a seconds-or-smaller unit if necessary. *)\n | Minute | Hour | Day ->\n let sum_t = zero in\n let day_string, sum_t = to_int_string_and_sum ~abs_t ~sum_t Day in\n let hour_string, sum_t = to_int_string_and_sum ~abs_t ~sum_t Hour in\n let minute_string, sum_t = to_int_string_and_sum ~abs_t ~sum_t Minute in\n let float_string = to_float_string_after_int_strings ~abs_t ~sum_t in\n day_string ^? hour_string ^? minute_string ^? float_string\n in\n sign ^? magnitude_string)\n ;;\n end\n\n let to_string = To_string.to_string\n let sexp_of_t t = Sexp.Atom (to_string t)\n\n let t_of_sexp s =\n match s with\n | Sexp.Atom x ->\n (try of_string x with\n | exn -> of_sexp_error (Exn.to_string exn) s)\n | Sexp.List _ ->\n of_sexp_error \"Time.Span.Stable.V3.t_of_sexp: sexp must be an Atom\" s\n ;;\n end\nend\n\ninclude Stable.V3\n\nlet to_proportional_float = to_float\n\nlet to_string_hum\n ?(delimiter = '_')\n ?(decimals = 3)\n ?(align_decimal = false)\n ?unit_of_time\n t\n =\n let float, suffix =\n match Option.value unit_of_time ~default:(to_unit_of_time t) with\n | Day -> to_day t, \"d\"\n | Hour -> to_hr t, \"h\"\n | Minute -> to_min t, \"m\"\n | Second -> to_sec t, \"s\"\n | Millisecond -> to_ms t, \"ms\"\n | Microsecond -> to_us t, \"us\"\n | Nanosecond -> to_ns t, \"ns\"\n in\n let prefix =\n Float.to_string_hum float ~delimiter ~decimals ~strip_zero:(not align_decimal)\n in\n let suffix =\n if align_decimal && Int.( = ) (String.length suffix) 1 then suffix ^ \" \" else suffix\n in\n prefix ^ suffix\n;;\n\nlet gen_incl lo hi =\n Float.gen_incl (to_sec lo) (to_sec hi) |> Quickcheck.Generator.map ~f:of_sec\n;;\n\nlet gen_uniform_incl lo hi =\n (* Technically exclusive rather than inclusive, but otherwise satisfies the contract to\n within 1ulp of the given bounds. *)\n Float.gen_uniform_excl (to_sec lo) (to_sec hi) |> Quickcheck.Generator.map ~f:of_sec\n;;\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Core_kernel.Time.Span\"\n end)\n\ninclude Hashable.Make_binable (struct\n type nonrec t = t [@@deriving bin_io, compare, hash, sexp_of]\n\n (* Previous versions rendered hash-based containers using float serialization rather\n than time serialization, so when reading hash-based containers in we accept either\n serialization. *)\n let t_of_sexp sexp =\n match Float.t_of_sexp sexp with\n | float -> of_float float\n | exception _ -> t_of_sexp sexp\n ;;\n end)\n\nmodule C = struct\n type t = T.t [@@deriving bin_io]\n type comparator_witness = T.comparator_witness\n\n let comparator = T.comparator\n\n (* In 108.06a and earlier, spans in sexps of Maps and Sets were raw floats. From 108.07\n through 109.13, the output format remained raw as before, but both the raw and pretty\n format were accepted as input. From 109.14 on, the output format was changed from\n raw to pretty, while continuing to accept both formats. Once we believe most\n programs are beyond 109.14, we will switch the input format to no longer accept\n raw. *)\n let sexp_of_t = sexp_of_t\n\n let t_of_sexp sexp =\n match Option.try_with (fun () -> T.of_float (Float.t_of_sexp sexp)) with\n | Some t -> t\n | None -> t_of_sexp sexp\n ;;\nend\n\nmodule Map = Map.Make_binable_using_comparator (C)\nmodule Set = Set.Make_binable_using_comparator (C)\n\nmodule Private = struct\n let suffix_of_unit_of_time = suffix_of_unit_of_time\n let parse_suffix = Stable.V3.Of_string.parse_suffix\nend\n","open! Import\n\nmodule type T = sig\n type t\nend\n\nmodule Make (T1 : T) (T2 : T) = struct\n type t = T1.t * T2.t\nend\n\nmodule T2 = struct\n type ('a, 'b) t = 'a * 'b [@@deriving sexp, typerep]\n\n let create a b = a, b\n\n let curry f =\n ();\n fun a b -> f (a, b)\n ;;\n\n let uncurry f =\n ();\n fun (a, b) -> f a b\n ;;\n\n external get1 : ('a, _) t -> 'a = \"%field0\"\n external get2 : (_, 'a) t -> 'a = \"%field1\"\n\n let map1 ~f (x, y) = f x, y\n let map2 ~f (x, y) = x, f y\n let map (x, y) ~f = f x, f y\n let map_fst (x, y) ~f = f x, y\n let map_snd (x, y) ~f = x, f y\n\n let compare ~cmp1 ~cmp2 (x, y) (x', y') =\n match cmp1 x x' with\n | 0 -> cmp2 y y'\n | i -> i\n ;;\n\n let equal ~eq1 ~eq2 (x, y) (x', y') = eq1 x x' && eq2 y y'\n let swap (a, b) = b, a\n\n include Comparator.Derived2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t [@@deriving sexp_of]\n\n let compare cmp1 cmp2 = compare ~cmp1 ~cmp2\n end)\nend\n\nmodule T3 = struct\n type ('a, 'b, 'c) t = 'a * 'b * 'c [@@deriving sexp, typerep]\n\n let create a b c = a, b, c\n\n let curry f =\n ();\n fun a b c -> f (a, b, c)\n ;;\n\n let uncurry f =\n ();\n fun (a, b, c) -> f a b c\n ;;\n\n let map1 ~f (x, y, z) = f x, y, z\n let map2 ~f (x, y, z) = x, f y, z\n let map3 ~f (x, y, z) = x, y, f z\n let map (x, y, z) ~f = f x, f y, f z\n let map_fst (x, y, z) ~f = f x, y, z\n let map_snd (x, y, z) ~f = x, f y, z\n let map_trd (x, y, z) ~f = x, y, f z\n\n external get1 : ('a, _, _) t -> 'a = \"%field0\"\n external get2 : (_, 'a, _) t -> 'a = \"%field1\"\n\n (* There's no %field2....*)\n let get3 (_, _, a) = a\n\n (* lexicographic comparison *)\n let compare ~cmp1 ~cmp2 ~cmp3 (x, y, z) (x', y', z') =\n let c1 = cmp1 x x' in\n if c1 <> 0\n then c1\n else (\n let c2 = cmp2 y y' in\n if c2 <> 0 then c2 else cmp3 z z')\n ;;\n\n let equal ~eq1 ~eq2 ~eq3 (x, y, z) (x', y', z') = eq1 x x' && eq2 y y' && eq3 z z'\nend\n\nmodule type Comparable_sexpable = sig\n type t [@@deriving sexp]\n\n include Comparable.S with type t := t\nend\n\nmodule type Hashable_sexpable = sig\n type t [@@deriving sexp]\n\n include Hashable.S with type t := t\nend\n\nmodule type Hasher_sexpable = sig\n type t [@@deriving compare, hash, sexp]\nend\n\nmodule Sexpable (S1 : Sexpable.S) (S2 : Sexpable.S) = struct\n type t = S1.t * S2.t [@@deriving sexp]\nend\n\nmodule Binable (B1 : Binable.S) (B2 : Binable.S) = struct\n type t = B1.t * B2.t [@@deriving bin_io]\nend\n\nmodule Comparable_plain (S1 : Comparable.S_plain) (S2 : Comparable.S_plain) = struct\n module T = struct\n type t = S1.t * S2.t\n\n type comparator_witness =\n (S1.comparator_witness, S2.comparator_witness) T2.comparator_witness\n\n let comparator = T2.comparator S1.comparator S2.comparator\n let sexp_of_t = comparator.sexp_of_t\n end\n\n include T\n include Comparable.Make_plain_using_comparator (T)\nend\n\nmodule Comparable (S1 : Comparable_sexpable) (S2 : Comparable_sexpable) = struct\n module T = struct\n include Sexpable (S1) (S2)\n\n let compare (s1, s2) (s1', s2') =\n match S1.compare s1 s1' with\n | 0 -> S2.compare s2 s2'\n | x -> x\n ;;\n end\n\n include T\n include Comparable.Make (T)\nend\n\nmodule Hasher (H1 : Hasher_sexpable) (H2 : Hasher_sexpable) = struct\n module T = struct\n type t = H1.t * H2.t [@@deriving compare, hash, sexp]\n end\n\n include T\n include Hashable.Make (T)\nend\n\nmodule Hasher_sexpable_of_hashable_sexpable (S : Hashable_sexpable) :\n Hasher_sexpable with type t = S.t = struct\n include S\n\n let hash_fold_t state t = hash_fold_int state (hash t)\nend\n\nmodule Hashable_t (S1 : Hashable_sexpable) (S2 : Hashable_sexpable) =\n Hasher\n (Hasher_sexpable_of_hashable_sexpable\n (S1))\n (Hasher_sexpable_of_hashable_sexpable (S2))\n\nmodule Hashable = Hashable_t\n","open! Import\nopen Std_internal\nopen Int.Replace_polymorphic_compare\n\nmodule Round = struct\n type t =\n | Toward_positive_infinity\n | Toward_negative_infinity\n [@@deriving compare, sexp_of]\nend\n\nlet module_name = \"Digit_string_helpers\"\nlet int63_two = Int63.of_int 2\nlet int63_ten = Int63.of_int 10\nlet int63_twenty = Int63.of_int 20\nlet int63_billion = Int63.of_int 1_000_000_000\nlet max_billions = Int63.( / ) Int63.max_value int63_billion\n\nlet rec digits_of_positive_int63 n =\n if Int63.( < ) n int63_ten\n then 1\n else Int.succ (digits_of_positive_int63 (Int63.( / ) n int63_ten))\n;;\n\nlet digits_of_int63_max_value = digits_of_positive_int63 Int63.max_value\n\nlet rec max_int63_with ~digits =\n match digits with\n | 1 -> Int63.of_int 9\n | 2 -> Int63.of_int 99\n | 3 -> Int63.of_int 999\n | 4 -> Int63.of_int 9_999\n | 5 -> Int63.of_int 99_999\n | 6 -> Int63.of_int 999_999\n | 7 -> Int63.of_int 9_999_999\n | 8 -> Int63.of_int 99_999_999\n | 9 -> Int63.of_int 999_999_999\n | _ ->\n if digits >= digits_of_int63_max_value\n then Int63.max_value\n else (\n let billions = Int63.succ (max_int63_with ~digits:(digits - 9)) in\n Int63.pred (Int63.( * ) int63_billion billions))\n;;\n\nmodule Unsafe = struct\n let unsafe_char_of_digit n = Char.unsafe_of_int (Char.to_int '0' + n)\n let digit_of_char char = Char.get_digit_exn char\n\n let write_1_digit_int bytes ~pos int =\n Bytes.unsafe_set bytes pos (unsafe_char_of_digit int)\n ;;\n\n let return_tens_and_write_ones bytes ~pos int =\n let tens = int / 10 in\n let ones = int - (tens * 10) in\n write_1_digit_int bytes ~pos ones;\n tens\n ;;\n\n let write_2_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 1) int in\n write_1_digit_int bytes ~pos tens\n ;;\n\n let write_3_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 2) int in\n write_2_digit_int bytes ~pos tens\n ;;\n\n let write_4_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 3) int in\n write_3_digit_int bytes ~pos tens\n ;;\n\n let write_5_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 4) int in\n write_4_digit_int bytes ~pos tens\n ;;\n\n let write_6_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 5) int in\n write_5_digit_int bytes ~pos tens\n ;;\n\n let write_7_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 6) int in\n write_6_digit_int bytes ~pos tens\n ;;\n\n let write_8_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 7) int in\n write_7_digit_int bytes ~pos tens\n ;;\n\n let write_9_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 8) int in\n write_8_digit_int bytes ~pos tens\n ;;\n\n let return_billions_and_write_remainder bytes ~pos int63 =\n let billions = Int63.( / ) int63 int63_billion in\n let remainder = Int63.( - ) int63 (Int63.( * ) billions int63_billion) in\n write_9_digit_int bytes ~pos (Int63.to_int_exn remainder);\n billions\n ;;\n\n let rec write_int63 bytes ~pos ~digits int63 =\n match digits with\n | 1 -> write_1_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 2 -> write_2_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 3 -> write_3_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 4 -> write_4_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 5 -> write_5_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 6 -> write_6_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 7 -> write_7_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 8 -> write_8_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 9 -> write_9_digit_int bytes ~pos (Int63.to_int_exn int63)\n | _ ->\n let digits_of_billions = digits - 9 in\n let billions =\n return_billions_and_write_remainder bytes ~pos:(pos + digits_of_billions) int63\n in\n write_int63 bytes ~pos ~digits:digits_of_billions billions\n ;;\n\n let read_1_digit_int string ~pos = digit_of_char (String.unsafe_get string pos)\n\n let read_2_digit_int string ~pos =\n (read_1_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 1)\n ;;\n\n let read_3_digit_int string ~pos =\n (read_2_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 2)\n ;;\n\n let read_4_digit_int string ~pos =\n (read_3_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 3)\n ;;\n\n let read_5_digit_int string ~pos =\n (read_4_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 4)\n ;;\n\n let read_6_digit_int string ~pos =\n (read_5_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 5)\n ;;\n\n let read_7_digit_int string ~pos =\n (read_6_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 6)\n ;;\n\n let read_8_digit_int string ~pos =\n (read_7_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 7)\n ;;\n\n let read_9_digit_int string ~pos =\n (read_8_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 8)\n ;;\n\n let raise_int63_overflow name =\n invalid_argf \"%s.%s: overflow reading int63\" module_name name ()\n ;;\n\n let rec read_int63 string ~pos ~digits =\n match digits with\n | 1 -> Int63.of_int (read_1_digit_int string ~pos)\n | 2 -> Int63.of_int (read_2_digit_int string ~pos)\n | 3 -> Int63.of_int (read_3_digit_int string ~pos)\n | 4 -> Int63.of_int (read_4_digit_int string ~pos)\n | 5 -> Int63.of_int (read_5_digit_int string ~pos)\n | 6 -> Int63.of_int (read_6_digit_int string ~pos)\n | 7 -> Int63.of_int (read_7_digit_int string ~pos)\n | 8 -> Int63.of_int (read_8_digit_int string ~pos)\n | 9 -> Int63.of_int (read_9_digit_int string ~pos)\n | _ ->\n let digits_of_billions = digits - 9 in\n let billions = read_int63 string ~pos ~digits:digits_of_billions in\n let remainder =\n Int63.of_int (read_9_digit_int string ~pos:(pos + digits_of_billions))\n in\n if Int63.( > ) billions max_billions then raise_int63_overflow \"read_int63\";\n let sum = Int63.( + ) (Int63.( * ) billions int63_billion) remainder in\n if Int63.( < ) sum Int63.zero then raise_int63_overflow \"read_int63\";\n sum\n ;;\n\n let divide_and_round_up ~numerator ~denominator =\n let open Int63.O in\n (numerator + denominator - Int63.one) /% denominator\n ;;\n\n let raise_invalid_decimal name =\n invalid_argf \"%s.%s: invalid decimal character\" module_name name ()\n ;;\n\n (* Reads the portion of string between [pos] and [pos+decimals-1], inclusive, and\n interperets it as a positive decimal part of a number, which we call [x].\n\n Let [i] and [r] be the integer part and remaining fractional part of\n [x * scale / divisor].\n\n If [r < round_at/divisor], returns [i].\n If [r = round_at/divisor], returns [i] or [i+1] based on [round_exact].\n If [r > round_at/divisor], returns [i+1].\n\n Assumes without checking that [scale] and [divisor] are both positive and\n less than [Int63.max_value / 10] (to avoid internal overflow during the algorithm\n when multiplying by 10), and that [round_at >= 0] and [round_at < divisor]. *)\n let read_int63_decimal_rounded\n string\n ~pos:start\n ~decimals\n ~scale\n ~divisor\n ~round_at\n ~round_exact\n ~allow_underscore\n =\n let open Int63.O in\n let until = Int.( + ) start decimals in\n (* The loop invariant is that each iteration, we strip off the next decimal digit and\n update [sum], [round_at], and [divisor] such that the desired result is:\n\n [ sum + round(remaining_digits_of_x_parsed_as_decimal * scale / divisor) ]\n where \"round\" rounds based on the new value of [round_at].\n *)\n let divisor = ref divisor in\n let round_at = ref round_at in\n let sum = ref Int63.zero in\n let pos = ref start in\n (* Stop if we run out of characters, or if further digits cannot increase our sum. *)\n while Int.( <> ) !pos until && !round_at < scale do\n (match String.unsafe_get string !pos with\n | '0' .. '9' as char ->\n let digit = Int63.of_int (digit_of_char char) in\n (* Every new decimal place implicitly scales our numerator by a factor of ten,\n so must also effectively scale our denominator.\n\n 0.abcdef * scale/divisor [round at round_at]\n = a.bcdef * scale/(divisor*10) [round at round_at*10]\n\n Then redefine divisor := divisor*10 and round_at := round_at*10, so we have:\n a.bcdef * scale/divisor [round at round_at] *)\n divisor := !divisor * int63_ten;\n round_at := !round_at * int63_ten;\n (* Next we work out the part of the sum based on our current digit:\n\n a.bcdef * scale/divisor [round at round_at]\n = a.bcdef * scale/divisor - round_at / divisor [round at 0]\n = (a*scale-round_at) / divisor + 0.bcdef * scale/divisor [round at 0]\n\n Decompose the first term into integer and remainder parts.\n Since we have already subtracted [round_at], we decompose based\n on the ceiling rather than the floor of the division,\n e.g. 5/3 would decompose as 2 + (-1)/3, rather than 1 + (2/3).\n\n = increment + remainder/divisor + 0.bcdef * scale/divisor [round at 0]\n = increment + 0.bcdef * scale/divisor [round at -remainder]\n *)\n let numerator = (digit * scale) - !round_at in\n let denominator = !divisor in\n let increment = divide_and_round_up ~numerator ~denominator in\n let remainder = numerator - (increment * denominator) in\n (* Now just accumulate the new increment and iterate on the remaining part:\n 0.bcdef * scale/divisor [round at -remainder].\n\n Since [remainder] is between [-(divisor-1)] and [0] inclusive, the new\n [round_at] will be within [0] and [divisor-1] inclusive. *)\n round_at := -remainder;\n sum := !sum + increment;\n (* This line prevents the divisor from growing without bound and overflowing. If\n this line actually changes the divisor, then the divisor is larger than the\n scale, so the sum will increase if and only if [parsed_remaining_digits *\n scale (> or >=) round_at], which doesn't depend on how much larger the\n divisor is. So this change is safe. *)\n divisor := Int63.min denominator scale\n | '_' when allow_underscore -> ()\n | _ -> raise_invalid_decimal \"read_int63_decimal\");\n pos := Int.succ !pos\n done;\n if !round_at = zero\n then (\n match round_exact with\n | Round.Toward_negative_infinity -> ()\n | Round.Toward_positive_infinity -> sum := !sum + Int63.one);\n !sum\n ;;\n\n let read_int63_decimal string ~pos ~decimals ~scale ~round_ties ~allow_underscore =\n read_int63_decimal_rounded\n string\n ~pos\n ~decimals\n ~scale:(Int63.( * ) scale int63_two)\n ~divisor:int63_two\n ~round_at:Int63.one\n ~round_exact:round_ties\n ~allow_underscore\n ;;\nend\n\nlet min_scale = Int63.one\nlet max_scale = Int63.( / ) Int63.max_value int63_twenty\n\nlet raise_negative_decimals name ~decimals =\n invalid_argf \"%s.%s: decimals=%d is negative\" module_name name decimals ()\n;;\n\nlet raise_non_positive_digits name ~digits =\n invalid_argf \"%s.%s: digits=%d is not a positive number\" module_name name digits ()\n;;\n\nlet raise_scale_out_of_bounds name ~scale =\n invalid_argf\n \"%s.%s: scale=%Ld out of range [%Ld, %Ld]\"\n module_name\n name\n (Int63.to_int64 scale)\n (Int63.to_int64 min_scale)\n (Int63.to_int64 max_scale)\n ()\n;;\n\nlet raise_pos_out_of_bounds name ~len ~pos ~digits =\n if pos < 0 || pos >= len\n then\n invalid_argf\n \"%s.%s: pos=%d out of range for string of length %d\"\n module_name\n name\n pos\n len\n ()\n else\n invalid_argf\n \"%s.%s: %d digits do not fit at pos %d in string of length %d\"\n module_name\n name\n digits\n pos\n len\n ()\n;;\n\nlet raise_int_out_of_bounds name ~max int =\n invalid_argf \"%s.%s: %d out of range [0, %d]\" module_name name int max ()\n;;\n\nlet raise_int63_out_of_bounds name ~max int63 =\n invalid_argf\n !\"%s.%s: %{Int63} out of range [0, %{Int63}]\"\n module_name\n name\n int63\n max\n ()\n;;\n\nlet check_decimals name ~decimals =\n if decimals < 0 then raise_negative_decimals name ~decimals\n;;\n\nlet check_digits name ~digits = if digits < 1 then raise_non_positive_digits name ~digits\n\nlet check_pos name ~len ~pos ~digits =\n if pos < 0 || pos + digits > len then raise_pos_out_of_bounds name ~len ~pos ~digits\n;;\n\nlet check_int name ~max int =\n if int < 0 || int > max then raise_int_out_of_bounds name ~max int\n;;\n\nlet check_int63 name ~max int63 =\n if Int63.( < ) int63 Int63.zero || Int63.( > ) int63 max\n then raise_int63_out_of_bounds name ~max int63\n;;\n\nlet check_scale name ~scale =\n if Int63.( < ) scale min_scale || Int63.( > ) scale max_scale\n then raise_scale_out_of_bounds name ~scale\n;;\n\nlet check_write name ~bytes ~pos ~digits ~max int =\n let len = Bytes.length bytes in\n check_pos name ~digits ~len ~pos;\n check_int name ~max int\n;;\n\nlet check_write63 name ~bytes ~pos ~digits int63 =\n check_digits name ~digits;\n let max = max_int63_with ~digits in\n let len = Bytes.length bytes in\n check_pos name ~digits ~len ~pos;\n check_int63 name ~max int63\n;;\n\nlet write_1_digit_int bytes ~pos int =\n check_write \"write_1_digit_int\" ~bytes ~pos ~digits:1 ~max:9 int;\n Unsafe.write_1_digit_int bytes ~pos int\n;;\n\nlet write_2_digit_int bytes ~pos int =\n check_write \"write_2_digit_int\" ~bytes ~pos ~digits:2 ~max:99 int;\n Unsafe.write_2_digit_int bytes ~pos int\n;;\n\nlet write_3_digit_int bytes ~pos int =\n check_write \"write_3_digit_int\" ~bytes ~pos ~digits:3 ~max:999 int;\n Unsafe.write_3_digit_int bytes ~pos int\n;;\n\nlet write_4_digit_int bytes ~pos int =\n check_write \"write_4_digit_int\" ~bytes ~pos ~digits:4 ~max:9_999 int;\n Unsafe.write_4_digit_int bytes ~pos int\n;;\n\nlet write_5_digit_int bytes ~pos int =\n check_write \"write_5_digit_int\" ~bytes ~pos ~digits:5 ~max:99_999 int;\n Unsafe.write_5_digit_int bytes ~pos int\n;;\n\nlet write_6_digit_int bytes ~pos int =\n check_write \"write_6_digit_int\" ~bytes ~pos ~digits:6 ~max:999_999 int;\n Unsafe.write_6_digit_int bytes ~pos int\n;;\n\nlet write_7_digit_int bytes ~pos int =\n check_write \"write_7_digit_int\" ~bytes ~pos ~digits:7 ~max:9_999_999 int;\n Unsafe.write_7_digit_int bytes ~pos int\n;;\n\nlet write_8_digit_int bytes ~pos int =\n check_write \"write_8_digit_int\" ~bytes ~pos ~digits:8 ~max:99_999_999 int;\n Unsafe.write_8_digit_int bytes ~pos int\n;;\n\nlet write_9_digit_int bytes ~pos int =\n check_write \"write_9_digit_int\" ~bytes ~pos ~digits:9 ~max:999_999_999 int;\n Unsafe.write_9_digit_int bytes ~pos int\n;;\n\nlet write_int63 bytes ~pos ~digits int63 =\n check_write63 \"write_int63\" ~bytes ~pos ~digits int63;\n Unsafe.write_int63 bytes ~pos ~digits int63\n;;\n\nlet check_read name ~string ~pos ~digits =\n let len = String.length string in\n check_pos name ~digits ~len ~pos\n;;\n\nlet check_read63 name ~string ~pos ~digits =\n check_digits name ~digits;\n let len = String.length string in\n check_pos name ~digits ~len ~pos\n;;\n\nlet check_read63_decimal name ~string ~pos ~decimals ~scale =\n let len = String.length string in\n check_decimals name ~decimals;\n check_scale name ~scale;\n check_pos name ~digits:decimals ~len ~pos\n;;\n\nlet read_1_digit_int string ~pos =\n check_read \"read_1_digit_int\" ~string ~pos ~digits:1;\n Unsafe.read_1_digit_int string ~pos\n;;\n\nlet read_2_digit_int string ~pos =\n check_read \"read_2_digit_int\" ~string ~pos ~digits:2;\n Unsafe.read_2_digit_int string ~pos\n;;\n\nlet read_3_digit_int string ~pos =\n check_read \"read_3_digit_int\" ~string ~pos ~digits:3;\n Unsafe.read_3_digit_int string ~pos\n;;\n\nlet read_4_digit_int string ~pos =\n check_read \"read_4_digit_int\" ~string ~pos ~digits:4;\n Unsafe.read_4_digit_int string ~pos\n;;\n\nlet read_5_digit_int string ~pos =\n check_read \"read_5_digit_int\" ~string ~pos ~digits:5;\n Unsafe.read_5_digit_int string ~pos\n;;\n\nlet read_6_digit_int string ~pos =\n check_read \"read_6_digit_int\" ~string ~pos ~digits:6;\n Unsafe.read_6_digit_int string ~pos\n;;\n\nlet read_7_digit_int string ~pos =\n check_read \"read_7_digit_int\" ~string ~pos ~digits:7;\n Unsafe.read_7_digit_int string ~pos\n;;\n\nlet read_8_digit_int string ~pos =\n check_read \"read_8_digit_int\" ~string ~pos ~digits:8;\n Unsafe.read_8_digit_int string ~pos\n;;\n\nlet read_9_digit_int string ~pos =\n check_read \"read_9_digit_int\" ~string ~pos ~digits:9;\n Unsafe.read_9_digit_int string ~pos\n;;\n\nlet read_int63 string ~pos ~digits =\n check_read63 \"read_int63\" ~string ~pos ~digits;\n Unsafe.read_int63 string ~pos ~digits\n;;\n\nlet read_int63_decimal string ~pos ~decimals ~scale ~round_ties ~allow_underscore =\n check_read63_decimal \"read_int63_decimal\" ~string ~pos ~decimals ~scale;\n Unsafe.read_int63_decimal string ~pos ~decimals ~scale ~round_ties ~allow_underscore\n;;\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n type t =\n | Jan\n | Feb\n | Mar\n | Apr\n | May\n | Jun\n | Jul\n | Aug\n | Sep\n | Oct\n | Nov\n | Dec\n [@@deriving sexp, compare, hash, variants, equal]\n\n let failwithf = Printf.failwithf\n\n let of_int_exn i : t =\n match i with\n | 1 -> Jan\n | 2 -> Feb\n | 3 -> Mar\n | 4 -> Apr\n | 5 -> May\n | 6 -> Jun\n | 7 -> Jul\n | 8 -> Aug\n | 9 -> Sep\n | 10 -> Oct\n | 11 -> Nov\n | 12 -> Dec\n | _ -> failwithf \"Month.of_int_exn %d\" i ()\n ;;\n\n let of_int i =\n try Some (of_int_exn i) with\n | _ -> None\n ;;\n\n let to_int (t : t) =\n match t with\n | Jan -> 1\n | Feb -> 2\n | Mar -> 3\n | Apr -> 4\n | May -> 5\n | Jun -> 6\n | Jul -> 7\n | Aug -> 8\n | Sep -> 9\n | Oct -> 10\n | Nov -> 11\n | Dec -> 12\n ;;\n\n include Binable.Stable.Of_binable.V1 [@alert \"-legacy\"]\n (Int)\n (struct\n type nonrec t = t\n\n let to_binable t = to_int t - 1\n let of_binable i = of_int_exn (i + 1)\n end)\n end\nend\n\nlet num_months = 12\n\nmodule T = struct\n include Stable.V1\n\n let all = [ Jan; Feb; Mar; Apr; May; Jun; Jul; Aug; Sep; Oct; Nov; Dec ]\n let hash = to_int\nend\n\ninclude T\n\ninclude (\n Hashable.Make_binable (struct\n include T\n end) :\n Hashable.S_binable with type t := t)\n\ninclude Comparable.Make_binable (struct\n include T\n\n (* In 108.06a and earlier, months in sexps of Maps and Sets were raw ints. From 108.07\n through 109.13, the output format remained raw as before, but both the raw and\n pretty format were accepted as input. From 109.14 on, the output format was\n changed from raw to pretty, while continuing to accept both formats. Once we believe\n most programs are beyond 109.14, we will switch the input format to no longer accept\n raw. *)\n let t_of_sexp sexp =\n match Option.try_with (fun () -> Int.t_of_sexp sexp) with\n | Some i -> of_int_exn (i + 1)\n | None -> T.t_of_sexp sexp\n ;;\n end)\n\n(* Replace the overriden sexp converters from [Comparable.Make_binable] with the ordinary\n symbolic converters. *)\nlet sexp_of_t = T.sexp_of_t\nlet t_of_sexp = T.t_of_sexp\nlet shift t i = of_int_exn (1 + Int.( % ) (to_int t - 1 + i) num_months)\n\nlet all_strings =\n lazy\n (Array.of_list (List.map all ~f:(fun variant -> Sexp.to_string (sexp_of_t variant))))\n;;\n\nlet to_string (t : t) =\n let all_strings = Lazy.force all_strings in\n all_strings.(to_int t - 1)\n;;\n\nlet of_string =\n let table =\n lazy\n (let module T = String.Table in\n let table = T.create ~size:num_months () in\n Array.iteri (Lazy.force all_strings) ~f:(fun i s ->\n let t = of_int_exn (i + 1) in\n Hashtbl.set table ~key:s ~data:t;\n Hashtbl.set table ~key:(String.lowercase s) ~data:t;\n Hashtbl.set table ~key:(String.uppercase s) ~data:t);\n table)\n in\n fun str ->\n match Hashtbl.find (Lazy.force table) str with\n | Some x -> x\n | None -> failwithf \"Invalid month: %s\" str ()\n;;\n\nmodule Export = struct\n type month = t =\n | Jan\n | Feb\n | Mar\n | Apr\n | May\n | Jun\n | Jul\n | Aug\n | Sep\n | Oct\n | Nov\n | Dec\nend\n","open! Import\nopen Std_internal\nopen Digit_string_helpers\n\nlet is_leap_year ~year = (year mod 4 = 0 && not (year mod 100 = 0)) || year mod 400 = 0\n\n(* Create a local private date type to ensure that all dates are created via\n Date.create_exn.\n*)\nmodule Stable = struct\n module V1 = struct\n module Without_comparable = struct\n module T : sig\n type t [@@immediate] [@@deriving bin_io, hash, typerep]\n\n val create_exn : y:int -> m:Month.Stable.V1.t -> d:int -> t\n val year : t -> int\n val month : t -> Month.Stable.V1.t\n val day : t -> int\n val days_in_month : year:int -> month:Month.t -> int\n val to_int : t -> int\n val of_int_exn : int -> t\n val invalid_value__for_internal_use_only : t\n end = struct\n (* We used to store dates like this:\n type t = { y: int; m: Month.Stable.V1.t; d: int; }\n In the below we make sure that the bin_io representation is\n identical (and the stable unit tests check this)\n\n In memory we use the following much more compact representation:\n 2 bytes year\n 1 byte month\n 1 byte day\n\n all packed into a single immediate int (so from 4 words down to 1).\n *)\n type t = int\n [@@deriving\n hash, typerep, bin_shape ~basetype:\"899ee3e0-490a-11e6-a10a-a3734f733566\"]\n\n let create0 ~year ~month ~day =\n (* create_exn's validation make sure that each value fits *)\n (year lsl 16) lor (Month.to_int month lsl 8) lor day\n ;;\n\n let year t = t lsr 16\n let month t = Month.of_int_exn ((t lsr 8) land 0xff)\n let day t = t land 0xff\n\n let days_in_month ~year ~month =\n match (month : Month.t) with\n | Jan | Mar | May | Jul | Aug | Oct | Dec -> 31\n | Apr | Jun | Sep | Nov -> 30\n | Feb -> if is_leap_year ~year then 29 else 28\n ;;\n\n let create_exn ~y:year ~m:month ~d:day =\n (* year, month, and day need to be passed as parameters to avoid allocating\n a closure (see unit test below) *)\n let invalid ~year ~month ~day msg =\n invalid_argf\n !\"Date.create_exn ~y:%d ~m:%{Month} ~d:%d error: %s\"\n year\n month\n day\n msg\n ()\n in\n if year < 0 || year > 9999\n then invalid ~year ~month ~day \"year outside of [0..9999]\";\n if day <= 0 then invalid ~year ~month ~day \"day <= 0\";\n let days_in_month = days_in_month ~year ~month in\n if day > days_in_month\n then invalid ~year ~month ~day (sprintf \"%d day month violation\" days_in_month);\n create0 ~year ~month ~day\n ;;\n\n (* We don't use Make_binable here, because that would go via an immediate\n tuple or record. That is exactly the 32 bytes we worked so hard above to\n get rid of. We also don't want to just bin_io the integer directly\n because that would mean a new bin_io format. *)\n\n let bin_read_t buf ~pos_ref =\n let year = Int.bin_read_t buf ~pos_ref in\n let month = Month.Stable.V1.bin_read_t buf ~pos_ref in\n let day = Int.bin_read_t buf ~pos_ref in\n create0 ~year ~month ~day\n ;;\n\n let __bin_read_t__ _buf ~pos_ref =\n (* __bin_read_t is only needed for variants *)\n Bin_prot.Common.raise_variant_wrong_type \"Date.t\" !pos_ref\n ;;\n\n let bin_reader_t =\n { Bin_prot.Type_class.read = bin_read_t; vtag_read = __bin_read_t__ }\n ;;\n\n let bin_size_t t =\n Int.bin_size_t (year t) + Month.bin_size_t (month t) + Int.bin_size_t (day t)\n ;;\n\n let bin_write_t buf ~pos t =\n let pos = Int.bin_write_t buf ~pos (year t) in\n let pos = Month.bin_write_t buf ~pos (month t) in\n Int.bin_write_t buf ~pos (day t)\n ;;\n\n let bin_writer_t = { Bin_prot.Type_class.size = bin_size_t; write = bin_write_t }\n\n let bin_t =\n { Bin_prot.Type_class.reader = bin_reader_t\n ; writer = bin_writer_t\n ; shape = bin_shape_t\n }\n ;;\n\n let to_int t = t\n let of_int_exn n = create_exn ~y:(year n) ~m:(month n) ~d:(day n)\n let invalid_value__for_internal_use_only = 0\n\n let%test \"invalid value\" =\n Exn.does_raise (fun () ->\n (of_int_exn invalid_value__for_internal_use_only : t))\n ;;\n end\n\n include T\n\n\n (** YYYY-MM-DD *)\n let to_string_iso8601_extended t =\n let buf = Bytes.create 10 in\n write_4_digit_int buf ~pos:0 (year t);\n Bytes.set buf 4 '-';\n write_2_digit_int buf ~pos:5 (Month.to_int (month t));\n Bytes.set buf 7 '-';\n write_2_digit_int buf ~pos:8 (day t);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf\n ;;\n\n let to_string = to_string_iso8601_extended\n\n (** YYYYMMDD *)\n let to_string_iso8601_basic t =\n let buf = Bytes.create 8 in\n write_4_digit_int buf ~pos:0 (year t);\n write_2_digit_int buf ~pos:4 (Month.to_int (month t));\n write_2_digit_int buf ~pos:6 (day t);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf\n ;;\n\n (** MM/DD/YYYY *)\n let to_string_american t =\n let buf = Bytes.create 10 in\n write_2_digit_int buf ~pos:0 (Month.to_int (month t));\n Bytes.set buf 2 '/';\n write_2_digit_int buf ~pos:3 (day t);\n Bytes.set buf 5 '/';\n write_4_digit_int buf ~pos:6 (year t);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf\n ;;\n\n let parse_year4 str pos = read_4_digit_int str ~pos\n let parse_month str pos = Month.of_int_exn (read_2_digit_int str ~pos)\n let parse_day str pos = read_2_digit_int str ~pos\n\n (** YYYYMMDD *)\n let of_string_iso8601_basic str ~pos =\n if pos + 8 > String.length str\n then invalid_arg \"Date.of_string_iso8601_basic: pos + 8 > string length\";\n create_exn\n ~y:(parse_year4 str pos)\n ~m:(parse_month str (pos + 4))\n ~d:(parse_day str (pos + 6))\n ;;\n\n (* WARNING: if you are going to change this function in a material way, be sure you\n understand the implications of working in Stable *)\n let of_string s =\n let invalid () = failwith (\"invalid date: \" ^ s) in\n let ensure b = if not b then invalid () in\n let month_num ~year ~month ~day =\n create_exn\n ~y:(parse_year4 s year)\n ~m:(parse_month s month)\n ~d:(parse_day s day)\n in\n let month_abrv ~year ~month ~day =\n create_exn\n ~y:(parse_year4 s year)\n ~m:(Month.of_string (String.sub s ~pos:month ~len:3))\n ~d:(parse_day s day)\n in\n if String.contains s '/'\n then (\n let y, m, d =\n match String.split s ~on:'/' with\n | [ a; b; c ] ->\n if String.length a = 4 then a, b, c (* y/m/d *) else c, a, b (* m/d/y *)\n | _ -> invalid ()\n in\n let year = Int.of_string y in\n let year =\n if year >= 100 then year else if year < 75 then 2000 + year else 1900 + year\n in\n let month = Month.of_int_exn (Int.of_string m) in\n let day = Int.of_string d in\n create_exn ~y:year ~m:month ~d:day)\n else if String.contains s '-'\n then (\n (* yyyy-mm-dd *)\n ensure (String.length s = 10 && Char.( = ) s.[4] '-' && Char.( = ) s.[7] '-');\n month_num ~year:0 ~month:5 ~day:8)\n else if String.contains s ' '\n then\n if String.length s = 11 && Char.( = ) s.[2] ' ' && Char.( = ) s.[6] ' '\n then (* DD MMM YYYY *)\n month_abrv ~day:0 ~month:3 ~year:7\n else (\n (* YYYY MMM DD *)\n ensure (String.length s = 11 && Char.( = ) s.[4] ' ' && Char.( = ) s.[8] ' ');\n month_abrv ~day:9 ~month:5 ~year:0)\n else if String.length s = 9\n then (* DDMMMYYYY *)\n month_abrv ~day:0 ~month:2 ~year:5\n else if String.length s = 8\n then (* assume YYYYMMDD *)\n month_num ~year:0 ~month:4 ~day:6\n else invalid ()\n ;;\n\n let of_string s =\n try of_string s with\n | exn -> invalid_argf \"Date.of_string (%s): %s\" s (Exn.to_string exn) ()\n ;;\n\n module Sexpable = struct\n module Old_date = struct\n type t =\n { y : int\n ; m : int\n ; d : int\n }\n [@@deriving sexp]\n\n let to_date t = T.create_exn ~y:t.y ~m:(Month.of_int_exn t.m) ~d:t.d\n end\n\n let t_of_sexp = function\n | Sexp.Atom s -> of_string s\n | Sexp.List _ as sexp -> Old_date.to_date (Old_date.t_of_sexp sexp)\n ;;\n\n let t_of_sexp s =\n try t_of_sexp s with\n | Of_sexp_error _ as exn -> raise exn\n | Invalid_argument a -> of_sexp_error a s\n ;;\n\n let sexp_of_t t = Sexp.Atom (to_string t)\n end\n\n include Sexpable\n\n let compare t1 t2 =\n let n = Int.compare (year t1) (year t2) in\n if n <> 0\n then n\n else (\n let n = Month.compare (month t1) (month t2) in\n if n <> 0 then n else Int.compare (day t1) (day t2))\n ;;\n\n include (val Comparator.Stable.V1.make ~compare ~sexp_of_t)\n end\n\n include Without_comparable\n include Comparable.Stable.V1.Make (Without_comparable)\n end\n\n module Option = struct\n module V1 = struct\n type t = int\n [@@deriving\n bin_io\n , bin_shape ~basetype:\"826a3e79-3321-451a-9707-ed6c03b84e2f\"\n , compare\n , hash\n , typerep]\n\n let none = V1.(to_int invalid_value__for_internal_use_only)\n let is_none t = t = none\n let is_some t = not (is_none t)\n let some_is_representable _ = true\n let some t = V1.to_int t\n let unchecked_value = V1.of_int_exn\n let to_option t = if is_some t then Some (unchecked_value t) else None\n\n let of_option opt =\n match opt with\n | None -> none\n | Some v -> some v\n ;;\n\n let value_exn t =\n if is_some t\n then unchecked_value t\n else raise_s [%message [%here] \"Date.Option.value_exn none\"]\n ;;\n\n let value t ~default = if is_some t then unchecked_value t else default\n let sexp_of_t t = to_option t |> Option.sexp_of_t V1.sexp_of_t\n let t_of_sexp sexp = (Option.t_of_sexp V1.t_of_sexp) sexp |> of_option\n end\n end\nend\n\nmodule Without_comparable = Stable.V1.Without_comparable\ninclude Without_comparable\nmodule C = Comparable.Make_binable_using_comparator (Without_comparable)\ninclude C\n\nmodule O = struct\n include (C : Comparable.Infix with type t := t)\nend\n\ninclude (\n Hashable.Make_binable (struct\n include T\n include Sexpable\n include Binable\n\n let compare (a : t) (b : t) = compare a b\n end) :\n Hashable.S_binable with type t := t)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let module_name = \"Core_kernel.Date\"\n let to_string = to_string\n end)\n\nlet unix_epoch = create_exn ~y:1970 ~m:Jan ~d:1\n\n(* The Days module is used for calculations that involve adding or removing a known number\n of days from a date. Internally the date is translated to a day number, the days are\n added, and the new date is returned. Those interested in the math can read:\n\n http://alcor.concordia.ca/~gpkatch/gdate-method.html\n\n note: unit tests are in lib_test/time_test.ml\n*)\nmodule Days : sig\n type date = t\n type t [@@immediate]\n\n val of_date : date -> t\n val to_date : t -> date\n val diff : t -> t -> int\n val add_days : t -> int -> t\n val unix_epoch : t\nend\nwith type date := t = struct\n open Int\n\n type t = int\n\n let of_year y = (365 * y) + (y / 4) - (y / 100) + (y / 400)\n\n let of_date date =\n let m = (Month.to_int (month date) + 9) % 12 in\n let y = year date - (m / 10) in\n of_year y + (((m * 306) + 5) / 10) + (day date - 1)\n ;;\n\n let c_10_000 = Int63.of_int 10_000\n let c_14_780 = Int63.of_int 14_780\n let c_3_652_425 = Int63.of_int 3_652_425\n\n let to_date days =\n let y =\n let open Int63 in\n to_int_exn (((c_10_000 * of_int days) + c_14_780) / c_3_652_425)\n in\n let ddd = days - of_year y in\n let y, ddd =\n if ddd < 0\n then (\n let y = y - 1 in\n y, days - of_year y)\n else y, ddd\n in\n let mi = ((100 * ddd) + 52) / 3_060 in\n let y = y + ((mi + 2) / 12) in\n let m = ((mi + 2) % 12) + 1 in\n let d = ddd - (((mi * 306) + 5) / 10) + 1 in\n create_exn ~y ~m:(Month.of_int_exn m) ~d\n ;;\n\n let unix_epoch = of_date unix_epoch\n let add_days t days = t + days\n let diff t1 t2 = t1 - t2\nend\n\nlet add_days t days = Days.to_date (Days.add_days (Days.of_date t) days)\nlet diff t1 t2 = Days.diff (Days.of_date t1) (Days.of_date t2)\n\nlet add_months t n =\n let total_months = Month.to_int (month t) + n in\n let y = year t + (total_months /% 12) in\n let m = total_months % 12 in\n (* correct for december *)\n let y, m = if Int.( = ) m 0 then y - 1, m + 12 else y, m in\n let m = Month.of_int_exn m in\n (* handle invalid dates for months with fewer number of days *)\n let rec try_create d =\n try create_exn ~y ~m ~d with\n | _exn ->\n assert (Int.( >= ) d 1);\n try_create (d - 1)\n in\n try_create (day t)\n;;\n\nlet add_years t n = add_months t (n * 12)\n\n(* http://en.wikipedia.org/wiki/Determination_of_the_day_of_the_week#Purely_mathematical_methods\n\n note: unit tests in lib_test/time_test.ml\n*)\nlet day_of_week =\n let table = [| 0; 3; 2; 5; 0; 3; 5; 1; 4; 6; 2; 4 |] in\n fun t ->\n let m = Month.to_int (month t) in\n let y = if Int.( < ) m 3 then year t - 1 else year t in\n Day_of_week.of_int_exn\n ((y + (y / 4) - (y / 100) + (y / 400) + table.(m - 1) + day t) % 7)\n;;\n\n(* http://en.wikipedia.org/wiki/Ordinal_date *)\nlet non_leap_year_table = [| 0; 31; 59; 90; 120; 151; 181; 212; 243; 273; 304; 334 |]\nlet leap_year_table = [| 0; 31; 60; 91; 121; 152; 182; 213; 244; 274; 305; 335 |]\n\nlet ordinal_date t =\n let table =\n if is_leap_year ~year:(year t) then leap_year_table else non_leap_year_table\n in\n let offset = table.(Month.to_int (month t) - 1) in\n day t + offset\n;;\n\nlet last_week_of_year y =\n let first_of_year = create_exn ~y ~m:Jan ~d:1 in\n let is t day = Day_of_week.equal (day_of_week t) day in\n if is first_of_year Thu || (is_leap_year ~year:y && is first_of_year Wed)\n then 53\n else 52\n;;\n\n(* See http://en.wikipedia.org/wiki/ISO_week_date or ISO 8601 for the details of this\n algorithm.\n\n Uses a [~f] argument to avoid allocating a tuple when called by [week_number].\n*)\nlet call_with_week_and_year t ~f =\n let ordinal = ordinal_date t in\n let weekday = Day_of_week.iso_8601_weekday_number (day_of_week t) in\n (* [ordinal - weekday + 4] is the ordinal of this week's Thursday, then (n + 6) / 7 is\n division by 7 rounding up *)\n let week = (ordinal - weekday + 10) / 7 in\n let year = year t in\n if Int.( < ) week 1\n then f ~week:(last_week_of_year (year - 1)) ~year:(year - 1)\n else if Int.( > ) week (last_week_of_year year)\n then f ~week:1 ~year:(year + 1)\n else f ~week ~year\n;;\n\nlet week_number_and_year t = call_with_week_and_year t ~f:(fun ~week ~year -> week, year)\nlet week_number t = call_with_week_and_year t ~f:(fun ~week ~year:_ -> week)\nlet is_weekend t = Day_of_week.is_sun_or_sat (day_of_week t)\nlet is_weekday t = not (is_weekend t)\nlet is_business_day t ~is_holiday = is_weekday t && not (is_holiday t)\n\nlet rec diff_weekend_days t1 t2 =\n if t1 < t2\n then -diff_weekend_days t2 t1\n else (\n (* Basic date diff *)\n let diff = diff t1 t2 in\n (* Compute the number of Saturday -> Sunday crossings *)\n let d1 = day_of_week t1 in\n let d2 = day_of_week t2 in\n let num_satsun_crossings =\n if Int.( < ) (Day_of_week.to_int d1) (Day_of_week.to_int d2)\n then 1 + (diff / 7)\n else diff / 7\n in\n (num_satsun_crossings * 2)\n + (if Day_of_week.( = ) d2 Day_of_week.Sun then 1 else 0)\n + if Day_of_week.( = ) d1 Day_of_week.Sun then -1 else 0)\n;;\n\nlet diff_weekdays t1 t2 = diff t1 t2 - diff_weekend_days t1 t2\n\nlet add_days_skipping t ~skip n =\n let step = if Int.( >= ) n 0 then 1 else -1 in\n let rec loop t k =\n let t_next = add_days t step in\n if skip t then loop t_next k else if Int.( = ) k 0 then t else loop t_next (k - 1)\n in\n loop t (abs n)\n;;\n\nlet rec first_day_satisfying t ~step ~condition =\n if condition t then t else first_day_satisfying (add_days t step) ~step ~condition\n;;\n\nlet next_day_satisfying t ~step ~condition =\n let next_day = add_days t step in\n first_day_satisfying next_day ~step ~condition\n;;\n\nlet following_weekday t = next_day_satisfying t ~step:1 ~condition:is_weekday\nlet previous_weekday t = next_day_satisfying t ~step:(-1) ~condition:is_weekday\nlet round_forward_to_weekday t = first_day_satisfying t ~step:1 ~condition:is_weekday\nlet round_backward_to_weekday t = first_day_satisfying t ~step:(-1) ~condition:is_weekday\n\nlet round_forward_to_business_day t ~is_holiday =\n first_day_satisfying t ~step:1 ~condition:(is_business_day ~is_holiday)\n;;\n\nlet round_backward_to_business_day t ~is_holiday =\n first_day_satisfying t ~step:(-1) ~condition:(is_business_day ~is_holiday)\n;;\n\nlet add_weekdays t n = add_days_skipping t ~skip:is_weekend n\nlet add_weekdays_rounding_in_direction_of_step = add_weekdays\n\nlet add_weekdays_rounding_forward t n =\n add_days_skipping (round_forward_to_weekday t) ~skip:is_weekend n\n;;\n\nlet add_weekdays_rounding_backward t n =\n add_days_skipping (round_backward_to_weekday t) ~skip:is_weekend n\n;;\n\nlet add_business_days t ~is_holiday n =\n add_days_skipping t n ~skip:(fun d -> is_weekend d || is_holiday d)\n;;\n\nlet add_business_days_rounding_in_direction_of_step = add_business_days\n\nlet add_business_days_rounding_forward t ~is_holiday n =\n add_days_skipping (round_forward_to_business_day ~is_holiday t) n ~skip:(fun d ->\n not (is_business_day ~is_holiday d))\n;;\n\nlet add_business_days_rounding_backward t ~is_holiday n =\n add_days_skipping (round_backward_to_business_day ~is_holiday t) n ~skip:(fun d ->\n not (is_business_day ~is_holiday d))\n;;\n\nlet dates_between ~min:t1 ~max:t2 =\n let rec loop t l = if t < t1 then l else loop (add_days t (-1)) (t :: l) in\n loop t2 []\n;;\n\nlet weekdays_between ~min ~max =\n let all_dates = dates_between ~min ~max in\n Option.value_map (List.hd all_dates) ~default:[] ~f:(fun first_date ->\n (* to avoid a system call on every date, we just get the weekday for the first\n date and use it to get all the other weekdays *)\n let first_weekday = day_of_week first_date in\n let date_and_weekdays =\n List.mapi all_dates ~f:(fun i date -> date, Day_of_week.shift first_weekday i)\n in\n List.filter_map date_and_weekdays ~f:(fun (date, weekday) ->\n if Day_of_week.is_sun_or_sat weekday then None else Some date))\n;;\n\nlet business_dates_between ~min ~max ~is_holiday =\n weekdays_between ~min ~max |> List.filter ~f:(fun d -> not (is_holiday d))\n;;\n\nlet first_strictly_after t ~on:dow =\n let dow = Day_of_week.to_int dow in\n let tplus1 = add_days t 1 in\n let cur = Day_of_week.to_int (day_of_week tplus1) in\n let diff = (dow + 7 - cur) mod 7 in\n add_days tplus1 diff\n;;\n\nmodule For_quickcheck = struct\n open Quickcheck\n\n let gen_uniform_incl d1 d2 =\n if d1 > d2\n then\n raise_s\n [%message\n \"Date.gen_uniform_incl: bounds are crossed\"\n ~lower_bound:(d1 : t)\n ~upper_bound:(d2 : t)];\n Generator.map (Int.gen_uniform_incl 0 (diff d2 d1)) ~f:(fun days -> add_days d1 days)\n ;;\n\n let gen_incl d1 d2 =\n Generator.weighted_union\n [ 1., Generator.return d1; 1., Generator.return d2; 18., gen_uniform_incl d1 d2 ]\n ;;\n\n let quickcheck_generator = gen_incl (of_string \"1900-01-01\") (of_string \"2100-01-01\")\n let quickcheck_observer = Observer.create (fun t ~size:_ ~hash -> hash_fold_t hash t)\n let quickcheck_shrinker = Shrinker.empty ()\nend\n\nlet quickcheck_generator = For_quickcheck.quickcheck_generator\nlet gen_incl = For_quickcheck.gen_incl\nlet gen_uniform_incl = For_quickcheck.gen_uniform_incl\nlet quickcheck_observer = For_quickcheck.quickcheck_observer\nlet quickcheck_shrinker = For_quickcheck.quickcheck_shrinker\n\nmodule Private = struct\n let leap_year_table = leap_year_table\n let non_leap_year_table = non_leap_year_table\n let ordinal_date = ordinal_date\nend\n\nmodule Option = struct\n module Stable = Stable.Option\n include Stable.V1\n\n module Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n let unsafe_value = unchecked_value\n end\n end\n\n let quickcheck_generator =\n Quickcheck.Generator.map\n (Option.quickcheck_generator quickcheck_generator)\n ~f:of_option\n ;;\n\n let quickcheck_shrinker =\n Quickcheck.Shrinker.map\n (Option.quickcheck_shrinker quickcheck_shrinker)\n ~f:of_option\n ~f_inverse:to_option\n ;;\n\n let quickcheck_observer =\n Quickcheck.Observer.of_hash\n (module struct\n type nonrec t = t [@@deriving hash]\n end)\n ;;\n\n include Comparable.Make_plain (struct\n type nonrec t = t [@@deriving compare, sexp_of]\n end)\nend\n","open! Import\nopen Std_internal\n\nmodule Stable = struct\n module V1 = struct\n type t = (float[@quickcheck.generator Float.gen_finite])\n [@@deriving compare, hash, quickcheck, typerep]\n\n let of_mult f = f\n let to_mult t = t\n let of_percentage f = f /. 100.\n let to_percentage t = t *. 100.\n let of_bp f = f /. 10_000.\n let to_bp t = t *. 10_000.\n let of_bp_int i = of_bp (Float.of_int i)\n let to_bp_int t = Float.to_int (to_bp t)\n\n let round_significant p ~significant_digits =\n Float.round_significant p ~significant_digits\n ;;\n\n let round_decimal_mult p ~decimal_digits = Float.round_decimal p ~decimal_digits\n\n let round_decimal_percentage p ~decimal_digits =\n Float.round_decimal (p *. 100.) ~decimal_digits /. 100.\n ;;\n\n let round_decimal_bp p ~decimal_digits =\n Float.round_decimal (p *. 10000.) ~decimal_digits /. 10000.\n ;;\n\n module Format = struct\n type t =\n | Exponent of int\n | Exponent_E of int\n | Decimal of int\n | Ocaml\n | Compact of int\n | Compact_E of int\n | Hex of int\n | Hex_E of int\n [@@deriving sexp_of]\n\n let exponent ~precision = Exponent precision\n let exponent_E ~precision = Exponent_E precision\n let decimal ~precision = Decimal precision\n let ocaml = Ocaml\n let compact ~precision = Compact precision\n let compact_E ~precision = Compact_E precision\n let hex ~precision = Hex precision\n let hex_E ~precision = Hex_E precision\n\n let format_float t =\n match t with\n | Exponent precision -> sprintf \"%.*e\" precision\n | Exponent_E precision -> sprintf \"%.*E\" precision\n | Decimal precision -> sprintf \"%.*f\" precision\n | Ocaml -> sprintf \"%F\"\n | Compact precision -> sprintf \"%.*g\" precision\n | Compact_E precision -> sprintf \"%.*G\" precision\n | Hex precision -> sprintf \"%.*h\" precision\n | Hex_E precision -> sprintf \"%.*H\" precision\n ;;\n end\n\n let format x format =\n let x_abs = Float.abs x in\n let string float = Format.format_float format float in\n if Float.( = ) x_abs 0.\n then \"0x\"\n else if Float.( >= ) x_abs 1.\n then string (x *. 1.) ^ \"x\"\n else if Float.( >= ) x_abs 0.01\n then string (x *. 100.) ^ \"%\"\n else string (x *. 10_000.) ^ \"bp\"\n ;;\n\n module Stringable = struct\n type t = float\n\n (* WARNING - PLEASE READ BEFORE EDITING THESE FUNCTIONS:\n\n The string converters in Stable.V1 should never change. If you are changing the\n semantics of anything that affects the sexp or bin-io representation of values of\n this type (this includes to_string and of_string) make a Stable.V2 and make your\n changes there. Thanks! *)\n let to_string x =\n let x_abs = Float.abs x in\n let string float = sprintf \"%.6G\" float in\n if Float.( = ) x_abs 0.\n then \"0x\"\n else if Float.( >= ) x_abs 1.\n then string (x *. 1.) ^ \"x\"\n else if Float.( >= ) x_abs 0.01\n then string (x *. 100.) ^ \"%\"\n else string (x *. 10_000.) ^ \"bp\"\n ;;\n\n let really_of_string str float_of_string =\n match String.chop_suffix str ~suffix:\"x\" with\n | Some str -> float_of_string str\n | None ->\n (match String.chop_suffix str ~suffix:\"%\" with\n | Some str -> float_of_string str *. 0.01\n | None ->\n (match String.chop_suffix str ~suffix:\"bp\" with\n | Some str -> of_bp (float_of_string str)\n | None -> failwithf \"Percent.of_string: must end in x, %%, or bp: %s\" str ()))\n ;;\n\n let of_string str =\n let float str = Float_with_finite_only_serialization.t_of_sexp (Sexp.Atom str) in\n really_of_string str float\n ;;\n\n let of_string_allow_nan_and_inf str = really_of_string str Float.of_string\n end\n\n include (\n Stringable :\n sig\n type t\n\n val of_string : string -> t\n val to_string : t -> string\n end\n with type t := t)\n\n include (Sexpable.Stable.Of_stringable.V1 (Stringable) : Sexpable.S with type t := t)\n include (Float : Binable with type t := t)\n\n include Comparable.Make_binable (struct\n type nonrec t = t [@@deriving compare, sexp_of, bin_io]\n\n (* Previous versions rendered comparable-based containers using float\n serialization rather than percent serialization, so when reading\n comparable-based containers in we accept either serialization. *)\n let t_of_sexp sexp =\n match Float.t_of_sexp sexp with\n | float -> float\n | exception _ -> t_of_sexp sexp\n ;;\n end)\n end\n\n module Option = struct\n module V1 = struct\n type t = V1.t [@@deriving bin_io, compare, hash, typerep]\n\n let none = Float.nan\n let is_none t = Float.is_nan t\n let is_some t = not (is_none t)\n let some_is_representable = is_some\n let some = Fn.id\n let unchecked_value = Fn.id\n let to_option t = if is_some t then Some (unchecked_value t) else None\n\n let of_option opt =\n match opt with\n | None -> none\n | Some v -> some v\n ;;\n\n let value_exn t =\n if is_some t\n then unchecked_value t\n else raise_s [%message [%here] \"Percent.Option.value_exn none\"]\n ;;\n\n let value t ~default = if is_some t then unchecked_value t else default\n let sexp_of_t t = to_option t |> Option.sexp_of_t V1.sexp_of_t\n let t_of_sexp sexp = (Option.t_of_sexp V1.t_of_sexp) sexp |> of_option\n end\n end\nend\n\ninclude Stable.V1\n\nmodule Option = struct\n module Stable = Stable.Option\n include Stable.V1\n\n module Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n let unsafe_value = unchecked_value\n end\n end\nend\n\nlet is_zero t = t = 0.\nlet apply t f = t *. f\nlet scale t f = t *. f\n\ninclude (\nstruct\n include Float\n\n let sign = sign_exn\nend :\nsig\n val zero : t\n val ( * ) : t -> t -> t\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val abs : t -> t\n val neg : t -> t\n val is_nan : t -> bool\n val is_inf : t -> bool\n val sign_exn : t -> Sign.t\n\n include Comparable.With_zero with type t := t\n include Robustly_comparable with type t := t\nend)\n\nlet validate = Float.validate_ordinary\nlet of_string_allow_nan_and_inf s = Stringable.of_string_allow_nan_and_inf s\nlet t_of_sexp_allow_nan_and_inf sexp = of_string_allow_nan_and_inf (Sexp.to_string sexp)\n","open! Import\nopen Std_internal\nopen Digit_string_helpers\nopen! Int.Replace_polymorphic_compare\nmodule Span = Span_float\n\n(* Create an abstract type for Ofday to prevent us from confusing it with\n other floats.\n*)\nmodule Stable = struct\n module V1 = struct\n module T : sig\n type underlying = float\n type t = private underlying [@@deriving bin_io, hash, typerep]\n\n include Comparable.S_common with type t := t\n include Robustly_comparable with type t := t\n include Floatable with type t := t\n\n val add : t -> Span.t -> t option\n val sub : t -> Span.t -> t option\n val next : t -> t option\n val prev : t -> t option\n val diff : t -> t -> Span.t\n val of_span_since_start_of_day_exn : Span.t -> t\n val of_span_since_start_of_day_unchecked : Span.t -> t\n val span_since_start_of_day_is_valid : Span.t -> bool\n val to_span_since_start_of_day : t -> Span.t\n val start_of_day : t\n val start_of_next_day : t\n end = struct\n (* Number of seconds since midnight. *)\n type underlying = Float.t\n\n include (\n struct\n include Float\n\n let sign = sign_exn\n end :\n sig\n type t = underlying [@@deriving bin_io, hash, typerep]\n\n include Comparable.S_common with type t := t\n include Comparable.With_zero with type t := t\n include Robustly_comparable with type t := t\n include Floatable with type t := t\n end)\n\n (* IF THIS REPRESENTATION EVER CHANGES, ENSURE THAT EITHER\n (1) all values serialize the same way in both representations, or\n (2) you add a new Time.Ofday version to stable.ml *)\n\n (* due to precision limitations in float we can't expect better than microsecond\n precision *)\n include Float.Robust_compare.Make (struct\n let robust_comparison_tolerance = 1E-6\n end)\n\n let to_span_since_start_of_day t = Span.of_sec t\n\n (* Another reasonable choice would be only allowing Ofday.t to be < 24hr, but this\n choice was made early on and people became used to being able to easily call 24hr\n the end of the day. It's a bit sad because it shares that moment with the\n beginning of the next day, and round trips oddly if passed through\n Time.to_date_ofday/Time.of_date_ofday.\n\n Note: [Schedule.t] requires that the end of day be representable, as it's the\n only way to write a schedule in terms of [Ofday.t]s that spans two weekdays. *)\n (* ofday must be >= 0 and <= 24h *)\n let is_valid (t : t) =\n let t = to_span_since_start_of_day t in\n Span.( <= ) Span.zero t && Span.( <= ) t Span.day\n ;;\n\n let of_span_since_start_of_day_unchecked span = Span.to_sec span\n\n let span_since_start_of_day_is_valid span =\n is_valid (of_span_since_start_of_day_unchecked span)\n ;;\n\n let of_span_since_start_of_day_exn span =\n let module C = Float.Class in\n let s = Span.to_sec span in\n match Float.classify s with\n | C.Infinite ->\n invalid_arg \"Ofday.of_span_since_start_of_day_exn: infinite value\"\n | C.Nan -> invalid_arg \"Ofday.of_span_since_start_of_day_exn: NaN value\"\n | C.Normal | C.Subnormal | C.Zero ->\n if not (is_valid s)\n then invalid_argf !\"Ofday out of range: %{Span}\" span ()\n else s\n ;;\n\n let start_of_day = 0.\n let start_of_next_day = of_span_since_start_of_day_exn Span.day\n\n let add (t : t) (span : Span.t) =\n let t = t +. Span.to_sec span in\n if is_valid t then Some t else None\n ;;\n\n let sub (t : t) (span : Span.t) =\n let t = t -. Span.to_sec span in\n if is_valid t then Some t else None\n ;;\n\n let next t =\n let candidate = Float.one_ulp `Up t in\n if is_valid candidate then Some candidate else None\n ;;\n\n let prev t =\n let candidate = Float.one_ulp `Down t in\n if is_valid candidate then Some candidate else None\n ;;\n\n let diff t1 t2 =\n Span.( - ) (to_span_since_start_of_day t1) (to_span_since_start_of_day t2)\n ;;\n end\n\n let approximate_end_of_day =\n Option.value_exn (T.sub T.start_of_next_day Span.microsecond)\n ;;\n\n (* [create] chops off any subsecond part when [sec = 60] to handle leap seconds. In\n particular it's trying to be generous about reading in times on things like fix\n messages that might include an extra unlikely second.\n\n Other ways of writing a time, like 1000ms, while mathematically valid, don't match\n ways that people actually write times down, so we didn't see the need to support\n them. That is, a clock might legitimately read 23:59:60 (or, with 60 seconds at\n times of day other than 23:59, depending on the time zone), but it doesn't seem\n reasonable for a clock to read \"23:59:59 and 1000ms\". *)\n let create ?hr ?min ?sec ?ms ?us ?ns () =\n let ms, us, ns =\n match sec with\n | Some 60 -> Some 0, Some 0, Some 0\n | _ -> ms, us, ns\n in\n T.of_span_since_start_of_day_exn (Span.create ?hr ?min ?sec ?ms ?us ?ns ())\n ;;\n\n let to_parts t = Span.to_parts (T.to_span_since_start_of_day t)\n\n let to_string_gen ~drop_ms ~drop_us ~trim t =\n let ( / ) = Int63.( / ) in\n let ( ! ) = Int63.of_int in\n let ( mod ) = Int63.rem in\n let i = Int63.to_int_exn in\n assert (if drop_ms then drop_us else true);\n let float_sec = Span.to_sec (T.to_span_since_start_of_day t) in\n let us = Float.int63_round_nearest_exn (float_sec *. 1e6) in\n let ms, us = us / !1000, us mod !1000 |> i in\n let sec, ms = ms / !1000, ms mod !1000 |> i in\n let min, sec = sec / !60, sec mod !60 |> i in\n let hr, min = min / !60, min mod !60 |> i in\n let hr = i hr in\n let dont_print_us = drop_us || (trim && us = 0) in\n let dont_print_ms = drop_ms || (trim && ms = 0 && dont_print_us) in\n let dont_print_s = trim && sec = 0 && dont_print_ms in\n let len =\n if dont_print_s\n then 5\n else if dont_print_ms\n then 8\n else if dont_print_us\n then 12\n else 15\n in\n let buf = Bytes.create len in\n write_2_digit_int buf ~pos:0 hr;\n Bytes.set buf 2 ':';\n write_2_digit_int buf ~pos:3 min;\n if dont_print_s\n then ()\n else (\n Bytes.set buf 5 ':';\n write_2_digit_int buf ~pos:6 sec;\n if dont_print_ms\n then ()\n else (\n Bytes.set buf 8 '.';\n write_3_digit_int buf ~pos:9 ms;\n if dont_print_us then () else write_3_digit_int buf ~pos:12 us));\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf\n ;;\n\n let to_string_trimmed t = to_string_gen ~drop_ms:false ~drop_us:false ~trim:true t\n let to_sec_string t = to_string_gen ~drop_ms:true ~drop_us:true ~trim:false t\n\n let to_millisecond_string t =\n to_string_gen ~drop_ms:false ~drop_us:true ~trim:false t\n ;;\n\n let small_diff =\n let hour = 3600. in\n fun ofday1 ofday2 ->\n let ofday1 = Span.to_sec (T.to_span_since_start_of_day ofday1) in\n let ofday2 = Span.to_sec (T.to_span_since_start_of_day ofday2) in\n let diff = ofday1 -. ofday2 in\n (* d1 is in (-hour; hour) *)\n let d1 = Float.mod_float diff hour in\n (* d2 is in (0;hour) *)\n let d2 = Float.mod_float (d1 +. hour) hour in\n let d = if Float.( > ) d2 (hour /. 2.) then d2 -. hour else d2 in\n Span.of_sec d\n ;;\n\n include T\n\n let to_string t = to_string_gen ~drop_ms:false ~drop_us:false ~trim:false t\n\n include Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Core_kernel.Time.Ofday\"\n end)\n\n let create_from_parsed string ~hr ~min ~sec ~subsec_pos ~subsec_len =\n let subsec =\n if Int.equal subsec_len 0\n then 0.\n else Float.of_string (String.sub string ~pos:subsec_pos ~len:subsec_len)\n in\n Float.of_int ((hr * 3600) + (min * 60) + sec) +. subsec\n |> Span.of_sec\n |> T.of_span_since_start_of_day_exn\n ;;\n\n let of_string s = Ofday_helpers.parse s ~f:create_from_parsed\n\n let t_of_sexp sexp =\n match sexp with\n | Sexp.Atom s ->\n (try of_string s with\n | Invalid_argument s -> of_sexp_error (\"Ofday.t_of_sexp: \" ^ s) sexp)\n | _ -> of_sexp_error \"Ofday.t_of_sexp\" sexp\n ;;\n\n let sexp_of_t span = Sexp.Atom (to_string span)\n\n let of_string_iso8601_extended ?pos ?len str =\n try Ofday_helpers.parse_iso8601_extended ?pos ?len str ~f:create_from_parsed with\n | exn ->\n invalid_argf\n \"Ofday.of_string_iso8601_extended(%s): %s\"\n (String.subo str ?pos ?len)\n (Exn.to_string exn)\n ()\n ;;\n end\nend\n\ninclude Stable.V1\n\nlet gen_incl lo hi =\n Span.gen_incl (to_span_since_start_of_day lo) (to_span_since_start_of_day hi)\n |> Quickcheck.Generator.map ~f:of_span_since_start_of_day_exn\n;;\n\nlet gen_uniform_incl lo hi =\n Span.gen_uniform_incl (to_span_since_start_of_day lo) (to_span_since_start_of_day hi)\n |> Quickcheck.Generator.map ~f:of_span_since_start_of_day_exn\n;;\n\nlet quickcheck_generator = gen_incl start_of_day start_of_next_day\n\nlet quickcheck_observer =\n Quickcheck.Observer.unmap Span.quickcheck_observer ~f:to_span_since_start_of_day\n;;\n\nlet quickcheck_shrinker = Quickcheck.Shrinker.empty ()\n\ninclude Hashable.Make_binable (struct\n type nonrec t = t [@@deriving bin_io, compare, hash, sexp_of]\n\n (* Previous versions rendered hash-based containers using float serialization rather\n than time serialization, so when reading hash-based containers in we accept either\n serialization. *)\n let t_of_sexp sexp =\n match Float.t_of_sexp sexp with\n | float -> of_float float\n | exception _ -> t_of_sexp sexp\n ;;\n end)\n\nmodule C = struct\n type t = T.t [@@deriving bin_io]\n type comparator_witness = T.comparator_witness\n\n let comparator = T.comparator\n\n (* In 108.06a and earlier, ofdays in sexps of Maps and Sets were raw floats. From\n 108.07 through 109.13, the output format remained raw as before, but both the raw and\n pretty format were accepted as input. From 109.14 on, the output format was changed\n from raw to pretty, while continuing to accept both formats. Once we believe most\n programs are beyond 109.14, we will switch the input format to no longer accept\n raw. *)\n let sexp_of_t = sexp_of_t\n\n let t_of_sexp sexp =\n match Option.try_with (fun () -> T.of_float (Float.t_of_sexp sexp)) with\n | Some t -> t\n | None -> t_of_sexp sexp\n ;;\nend\n\nmodule Map = Map.Make_binable_using_comparator (C)\nmodule Set = Set.Make_binable_using_comparator (C)\n\nlet of_span_since_start_of_day = of_span_since_start_of_day_exn\nlet to_millisec_string = to_millisecond_string\n","open! Import\nopen Std_internal\nopen! Int63.O\n\nlet module_name = \"Core_kernel.Time_ns.Span\"\n\ntype underlying = Int63.t\n\nlet arch_sixtyfour = Int.equal Sys.word_size 64\nlet round_nearest = Float.int63_round_nearest_exn\nlet float x = Int63.to_float x\n\n(* [Span] is basically a [Int63]. It even silently ignores overflow. *)\nmodule T = struct\n type t = Int63.t (* nanoseconds *) [@@deriving hash, bin_io, quickcheck, typerep]\n\n module Replace_polymorphic_compare = Int63.Replace_polymorphic_compare\n\n let zero = Int63.zero\nend\n\ninclude T\nopen Replace_polymorphic_compare\n\nmodule Parts = struct\n type t =\n { sign : Sign.t\n ; hr : int\n ; min : int\n ; sec : int\n ; ms : int\n ; us : int\n ; ns : int\n }\n [@@deriving compare, sexp]\nend\n\nlet next t = Int63.succ t\nlet prev t = Int63.pred t\nlet nanosecond = Int63.of_int 1\nlet microsecond = Int63.(of_int 1000 * nanosecond)\nlet millisecond = Int63.(of_int 1000 * microsecond)\nlet second = Int63.(of_int 1000 * millisecond)\nlet minute = Int63.(of_int 60 * second)\nlet hour = Int63.(of_int 60 * minute)\nlet day = Int63.(of_int 24 * hour)\n\n(* Beyond [min_value_for_1us_rounding..max_value_for_1us_rounding], not every microsecond\n can be represented as a [float] number of seconds. (In fact, it is around 135y, but we\n leave a small margin.)\n\n In the presence of silently ignored overflow, note that [t] is not actually bound to\n stay between these limits. *)\nlet max_value_for_1us_rounding = Int63.(of_int 135 * of_int 365 * day)\nlet min_value_for_1us_rounding = Int63.neg max_value_for_1us_rounding\n\nlet create\n ?sign:(sign_ = Sign.Pos (* rebind so not shadowed by [open Int63] below *))\n ?day:(days = 0)\n ?(hr = 0)\n ?min:(minutes = 0)\n ?(sec = 0)\n ?(ms = 0)\n ?(us = 0)\n ?(ns = 0)\n ()\n =\n let open Int63 in\n let t =\n (of_int days * day)\n + (of_int hr * hour)\n + (of_int minutes * minute)\n + (of_int sec * second)\n + (of_int ms * millisecond)\n + (of_int us * microsecond)\n + (of_int ns * nanosecond)\n in\n match sign_ with\n | Neg -> neg t\n | Pos | Zero -> t\n;;\n\nlet to_parts t =\n let open Int63 in\n let mag = abs t in\n { Parts.sign = (if t < zero then Neg else if t > zero then Pos else Zero)\n ; hr = to_int_exn (mag / hour)\n ; min = to_int_exn (rem mag hour / minute)\n ; sec = to_int_exn (rem mag minute / second)\n ; ms = to_int_exn (rem mag second / millisecond)\n ; us = to_int_exn (rem mag millisecond / microsecond)\n ; ns = to_int_exn (rem mag microsecond / nanosecond)\n }\n;;\n\nlet of_parts { Parts.sign; hr; min; sec; ms; us; ns } =\n create ~sign ~hr ~min ~sec ~ms ~us ~ns ()\n;;\n\nlet of_ns f = round_nearest f\nlet of_int63_ns i = i\nlet of_int_us i = Int63.(of_int i * microsecond)\nlet of_int_ms i = Int63.(of_int i * millisecond)\nlet of_int_sec i = Int63.(of_int i * second)\nlet of_us f = round_nearest (f *. float microsecond)\nlet of_ms f = round_nearest (f *. float millisecond)\nlet of_sec f = round_nearest (f *. float second)\nlet of_min f = round_nearest (f *. float minute)\nlet of_hr f = round_nearest (f *. float hour)\nlet of_day f = round_nearest (f *. float day)\n\nlet of_sec_with_microsecond_precision sec =\n let us = round_nearest (sec *. 1e6) in\n of_int63_ns Int63.(us * of_int 1000)\n;;\n\nlet of_int63_seconds x = x * second\nlet of_int32_seconds x = of_int63_seconds (Int63.of_int32 x)\n\nlet to_ns t = float t\nlet to_int63_ns t = t\nlet to_us t = float t /. float microsecond\nlet to_ms t = float t /. float millisecond\nlet to_sec t = float t /. float second\nlet to_min t = float t /. float minute\nlet to_hr t = float t /. float hour\nlet to_day t = float t /. float day\nlet to_int_us t = Int63.(to_int_exn (t / microsecond))\nlet to_int_ms t = Int63.(to_int_exn (t / millisecond))\nlet to_int_sec t = Int63.(to_int_exn (t / second))\nlet to_int63_seconds_round_down_exn t = t /% second\nlet of_int_ns i = of_int63_ns (Int63.of_int i)\n\nlet to_int_ns =\n if arch_sixtyfour\n then fun t -> Int63.to_int_exn (to_int63_ns t)\n else fun _ -> failwith \"Time_ns.Span.to_int_ns: unsupported on 32bit machines\"\n;;\n\nlet ( + ) t u = Int63.( + ) t u\nlet ( - ) t u = Int63.( - ) t u\nlet abs = Int63.abs\nlet neg = Int63.neg\nlet scale t f = round_nearest (float t *. f)\nlet scale_int63 t i = Int63.( * ) t i\nlet scale_int t i = scale_int63 t (Int63.of_int i)\nlet div = Int63.( /% )\nlet ( / ) t f = round_nearest (float t /. f)\nlet ( // ) = Int63.( // )\nlet to_proportional_float t = Int63.to_float t\n\nlet of_unit_of_time u =\n match (u : Unit_of_time.t) with\n | Nanosecond -> nanosecond\n | Microsecond -> microsecond\n | Millisecond -> millisecond\n | Second -> second\n | Minute -> minute\n | Hour -> hour\n | Day -> day\n;;\n\nlet to_unit_of_time t : Unit_of_time.t =\n let abs_t = abs t in\n if abs_t >= day\n then Day\n else if abs_t >= hour\n then Hour\n else if abs_t >= minute\n then Minute\n else if abs_t >= second\n then Second\n else if abs_t >= millisecond\n then Millisecond\n else if abs_t >= microsecond\n then Microsecond\n else Nanosecond\n;;\n\nmodule Stable = struct\n module V2 = struct\n module T = struct\n module T0 = struct\n type nonrec t = t [@@deriving bin_io, compare, hash]\n\n let of_int63_exn t = of_int63_ns t\n let to_int63 t = to_int63_ns t\n\n module To_string = struct\n let number_of_digits_to_write ~span_part_magnitude =\n let open Int.O in\n if span_part_magnitude = 0\n then 0\n else if span_part_magnitude < 10\n then 1\n else if span_part_magnitude < 100\n then 2\n else if span_part_magnitude < 1_000\n then 3\n else if span_part_magnitude < 10_000\n then 4\n else if span_part_magnitude < 100_000\n then 5\n else assert false\n ;;\n\n (* span part magnitudes are always < 100_000 *)\n\n let number_of_decimal_places_to_write ~billionths =\n let open Int.O in\n assert (billionths >= 0 && billionths <= 999_999_999);\n if billionths = 0\n then 0\n else if billionths % 10 <> 0\n then 9\n else if billionths % 100 <> 0\n then 8\n else if billionths % 1_000 <> 0\n then 7\n else if billionths % 10_000 <> 0\n then 6\n else if billionths % 100_000 <> 0\n then 5\n else if billionths % 1_000_000 <> 0\n then 4\n else if billionths % 10_000_000 <> 0\n then 3\n else if billionths % 100_000_000 <> 0\n then 2\n else 1\n ;;\n\n let write_char buf ~pos char =\n let open Int.O in\n Bytes.unsafe_set buf pos char;\n pos + 1\n ;;\n\n let write_2_chars buf ~pos char1 char2 =\n let open Int.O in\n Bytes.unsafe_set buf pos char1;\n Bytes.unsafe_set buf (pos + 1) char2;\n pos + 2\n ;;\n\n let write_digits buf ~pos ~digits int =\n let open Int.O in\n Digit_string_helpers.write_int63 buf ~pos ~digits (Int63.of_int int);\n pos + digits\n ;;\n\n let write_decimals buf ~pos ~decimals ~billionths =\n let open Int.O in\n Digit_string_helpers.write_int63\n buf\n ~pos\n ~digits:decimals\n (Int63.of_int (billionths / Int.pow 10 (9 - decimals)));\n pos + decimals\n ;;\n\n let write_if_non_empty buf ~pos ~digits int suffix =\n let open Int.O in\n if digits = 0\n then pos\n else (\n let pos = write_digits buf ~pos ~digits int in\n let pos = write_char buf ~pos suffix in\n pos)\n ;;\n\n let nanos_of_millisecond = to_int63_ns millisecond |> Int63.to_int_exn\n let nanos_of_microsecond = to_int63_ns microsecond |> Int63.to_int_exn\n let int63_60 = Int63.of_int 60\n let int63_24 = Int63.of_int 24\n\n (* Units of seconds and smaller can be written in decimal notation without\n worrying about non-power-of-ten factors. *)\n module Decimal_unit = struct\n type t =\n | Second\n | Millisecond\n | Microsecond\n | Nanosecond\n | None\n [@@deriving compare, sexp_of]\n\n let create ~s ~ns =\n let open Int.O in\n if s > 0\n then Second\n else if ns >= nanos_of_millisecond\n then Millisecond\n else if ns >= nanos_of_microsecond\n then Microsecond\n else if ns >= 1\n then Nanosecond\n else None\n ;;\n\n let integer t ~s ~ns =\n let open Int.O in\n match t with\n | Second -> s\n | Millisecond -> ns / nanos_of_millisecond\n | Microsecond -> ns / nanos_of_microsecond\n | Nanosecond -> ns\n | None -> 0\n ;;\n\n let billionths t ~ns =\n let open Int.O in\n match t with\n | Second -> ns\n | Millisecond -> ns % nanos_of_millisecond * 1_000\n | Microsecond -> ns % nanos_of_microsecond * 1_000_000\n | Nanosecond -> 0\n | None -> 0\n ;;\n\n let length t ~digits ~decimals =\n let open Int.O in\n let digits_len =\n match t with\n | Second -> digits + 1\n | Millisecond | Microsecond | Nanosecond -> digits + 2\n | None -> 0\n in\n let decimals_len = if decimals > 0 then decimals + 1 else 0 in\n digits_len + decimals_len\n ;;\n\n let write_suffix t buf ~pos =\n match t with\n | Second -> write_char buf ~pos 's'\n | Millisecond -> write_2_chars buf ~pos 'm' 's'\n | Microsecond -> write_2_chars buf ~pos 'u' 's'\n | Nanosecond -> write_2_chars buf ~pos 'n' 's'\n | None -> pos\n ;;\n\n let write t buf ~pos ~integer ~digits ~billionths ~decimals =\n let open Int.O in\n if digits = 0\n then pos\n else (\n let pos = write_digits buf ~pos integer ~digits in\n let pos =\n if decimals = 0\n then pos\n else (\n let pos = write_char buf ~pos '.' in\n write_decimals buf ~pos ~billionths ~decimals)\n in\n write_suffix t buf ~pos)\n ;;\n end\n\n let to_string t =\n if equal t zero\n then \"0s\"\n else (\n let is_negative = t < zero in\n let seconds = Int63.( / ) (to_int63_ns t) (to_int63_ns second) in\n let ns =\n Int63.rem (to_int63_ns t) (to_int63_ns second) |> Int63.to_int_exn\n in\n let seconds = Int63.abs seconds in\n let ns = Int.abs ns in\n let s = Int63.rem seconds int63_60 |> Int63.to_int_exn in\n let minutes = Int63.( / ) seconds int63_60 in\n let m = Int63.rem minutes int63_60 |> Int63.to_int_exn in\n let hours = Int63.( / ) minutes int63_60 in\n let h = Int63.rem hours int63_24 |> Int63.to_int_exn in\n let d = Int63.( / ) hours int63_24 |> Int63.to_int_exn in\n let open Int.O in\n let digits_of_d = number_of_digits_to_write ~span_part_magnitude:d in\n let digits_of_h = number_of_digits_to_write ~span_part_magnitude:h in\n let digits_of_m = number_of_digits_to_write ~span_part_magnitude:m in\n let decimal_unit = Decimal_unit.create ~s ~ns in\n let decimal_unit_integer = Decimal_unit.integer decimal_unit ~s ~ns in\n let decimal_unit_billionths = Decimal_unit.billionths decimal_unit ~ns in\n let digits_of_decimal_unit =\n number_of_digits_to_write ~span_part_magnitude:decimal_unit_integer\n in\n let decimals_of_decimal_unit =\n number_of_decimal_places_to_write ~billionths:decimal_unit_billionths\n in\n let string_length =\n let sign_len = if is_negative then 1 else 0 in\n let d_len = if digits_of_d > 0 then digits_of_d + 1 else 0 in\n let h_len = if digits_of_h > 0 then digits_of_h + 1 else 0 in\n let m_len = if digits_of_m > 0 then digits_of_m + 1 else 0 in\n let decimal_unit_len =\n Decimal_unit.length\n decimal_unit\n ~digits:digits_of_decimal_unit\n ~decimals:decimals_of_decimal_unit\n in\n sign_len + d_len + h_len + m_len + decimal_unit_len\n in\n assert (string_length > 0);\n let buf = Bytes.create string_length in\n let pos = 0 in\n let pos = if is_negative then write_char buf ~pos '-' else pos in\n let pos = write_if_non_empty buf ~pos ~digits:digits_of_d d 'd' in\n let pos = write_if_non_empty buf ~pos ~digits:digits_of_h h 'h' in\n let pos = write_if_non_empty buf ~pos ~digits:digits_of_m m 'm' in\n let pos =\n Decimal_unit.write\n decimal_unit\n buf\n ~pos\n ~integer:decimal_unit_integer\n ~digits:digits_of_decimal_unit\n ~billionths:decimal_unit_billionths\n ~decimals:decimals_of_decimal_unit\n in\n assert (pos = string_length);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf)\n ;;\n end\n\n let to_string = To_string.to_string\n\n module Of_string = struct\n (* We do computations using negative numbers everywhere and test against\n things related to [Int63.min_value] rather than using positive numbers\n and testing against things related to [Int63.max_value] because the\n negative integer range is one wider than the positive integer range\n (-2**63 vs 2**63-1), and we need that to be able to handle Int63.min_value\n nicely. *)\n\n let int63_10 = Int63.of_int 10\n let min_mult10_without_underflow = Int63.(min_value / int63_10)\n\n let[@cold] invalid_string string ~reason =\n raise_s\n [%message\n \"Time_ns.Span.of_string: invalid string\"\n (string : string)\n (reason : string)]\n ;;\n\n (* Assumes x and y are both nonpositive *)\n let add_without_underflow ~string x y =\n let open Int63.O in\n let sum = x + y in\n if sum > x\n then invalid_string string ~reason:\"span would be outside of int63 range\";\n sum\n ;;\n\n let add_neg_digit ~string int63 char =\n let open Int63.O in\n let digit = Int63.of_int (Char.get_digit_exn char) in\n if int63 < min_mult10_without_underflow\n then invalid_string string ~reason:\"span would be outside of int63 range\";\n add_without_underflow ~string (int63 * int63_10) (-digit)\n ;;\n\n let min_factor_of span = Int63.( / ) Int63.min_value (to_int63_ns span)\n let min_days_without_underflow = min_factor_of day\n let min_hours_without_underflow = min_factor_of hour\n let min_minutes_without_underflow = min_factor_of minute\n let min_seconds_without_underflow = min_factor_of second\n let min_milliseconds_without_underflow = min_factor_of millisecond\n let min_microseconds_without_underflow = min_factor_of microsecond\n let min_nanoseconds_without_underflow = min_factor_of nanosecond\n\n let min_without_underflow_of_unit_of_time unit_of_time =\n match (unit_of_time : Unit_of_time.t) with\n | Day -> min_days_without_underflow\n | Hour -> min_hours_without_underflow\n | Minute -> min_minutes_without_underflow\n | Second -> min_seconds_without_underflow\n | Millisecond -> min_milliseconds_without_underflow\n | Microsecond -> min_microseconds_without_underflow\n | Nanosecond -> min_nanoseconds_without_underflow\n ;;\n\n let negative_part\n string\n ~neg_integer\n ~decimal_pos\n ~end_pos\n ~unit_of_time\n ~round_ties_before_negating\n =\n let open Int.O in\n let scale = to_int63_ns (of_unit_of_time unit_of_time) in\n let min_without_underflow =\n min_without_underflow_of_unit_of_time unit_of_time\n in\n if Int63.( < ) neg_integer min_without_underflow\n then invalid_string string ~reason:\"span would be outside of int63 range\";\n let neg_integer_ns = Int63.( * ) neg_integer scale in\n let fraction_pos = decimal_pos + 1 in\n if fraction_pos >= end_pos\n then neg_integer_ns\n else (\n let decimal_ns =\n Digit_string_helpers.read_int63_decimal\n string\n ~pos:fraction_pos\n ~scale\n ~decimals:(end_pos - fraction_pos)\n ~allow_underscore:true\n ~round_ties:round_ties_before_negating\n in\n add_without_underflow ~string neg_integer_ns (Int63.( ~- ) decimal_ns))\n ;;\n\n let of_string string =\n let open Int.O in\n let neg_ns = ref Int63.zero in\n let pos = ref 0 in\n let len = String.length string in\n if len = 0 then invalid_string string ~reason:\"empty string\";\n let is_negative =\n match String.unsafe_get string !pos with\n | '-' ->\n incr pos;\n true\n | '+' ->\n incr pos;\n false\n | _ -> false\n in\n let round_ties_before_negating : Digit_string_helpers.Round.t =\n (* Ultimately, we always round parsed spans towards positive infinity when\n the nearest round ns are equidistant. For example, \"1.5ns\" is read as\n 2.0ns, and \"-1.5ns\" is read as -1ns. Since we read absolute values before\n applying the sign, we must choose our rounding direction based on the\n sign. Rounding decimal values happens before negating their magnitude. *)\n match is_negative with\n | false -> Toward_positive_infinity\n | true -> Toward_negative_infinity\n in\n (* Loop over parts, like \"5m\" in \"1h5m30s\" *)\n while !pos < len do\n let has_digit = ref false in\n let neg_integer =\n let i = ref Int63.zero in\n let end_of_digits = ref false in\n while !pos < len && not !end_of_digits do\n let c = String.unsafe_get string !pos in\n match c with\n | '0' .. '9' ->\n i := add_neg_digit ~string !i c;\n has_digit := true;\n incr pos\n | '_' -> incr pos\n | _ -> end_of_digits := true\n done;\n !i\n in\n let decimal_pos = !pos in\n if !pos < len && Char.equal '.' (String.unsafe_get string !pos)\n then (\n incr pos;\n let end_of_decimals = ref false in\n while !pos < len && not !end_of_decimals do\n match String.unsafe_get string !pos with\n | '0' .. '9' ->\n has_digit := true;\n incr pos\n | '_' -> incr pos\n | _ -> end_of_decimals := true\n done);\n let end_pos = !pos in\n if not !has_digit\n then invalid_string string ~reason:\"no digits before unit suffix\";\n let unit_of_time : Unit_of_time.t =\n if !pos + 1 < len && Char.equal 's' (String.unsafe_get string (!pos + 1))\n then (\n match String.unsafe_get string !pos with\n | 'm' ->\n pos := !pos + 2;\n Millisecond\n | 'u' ->\n pos := !pos + 2;\n Microsecond\n | 'n' ->\n pos := !pos + 2;\n Nanosecond\n | _ -> invalid_string string ~reason:\"unparseable unit suffix\")\n else if !pos < len\n then (\n match String.unsafe_get string !pos with\n | 'd' ->\n incr pos;\n Day\n | 'h' ->\n incr pos;\n Hour\n | 'm' ->\n incr pos;\n Minute\n | 's' ->\n incr pos;\n Second\n | _ -> invalid_string string ~reason:\"unparseable unit suffix\")\n else invalid_string string ~reason:\"no unit suffix after digits\"\n in\n let neg_nanos_of_part =\n negative_part\n string\n ~neg_integer\n ~decimal_pos\n ~end_pos\n ~unit_of_time\n ~round_ties_before_negating\n in\n neg_ns := add_without_underflow ~string !neg_ns neg_nanos_of_part\n done;\n let ns =\n if is_negative\n then !neg_ns\n else if Int63.( = ) !neg_ns Int63.min_value\n then invalid_string string ~reason:\"span would be outside of int63 range\"\n else Int63.( ~- ) !neg_ns\n in\n of_int63_ns ns\n ;;\n end\n\n let of_string = Of_string.of_string\n let sexp_of_t t = Sexp.Atom (to_string t)\n\n let t_of_sexp sexp =\n match sexp with\n | Sexp.Atom x ->\n (try of_string x with\n | exn -> of_sexp_error (Exn.to_string exn) sexp)\n | Sexp.List _ ->\n of_sexp_error \"Time_ns.Span.Stable.V2.t_of_sexp: sexp must be an Atom\" sexp\n ;;\n end\n\n include T0\n include Comparator.Stable.V1.Make (T0)\n end\n\n include T\n include Comparable.Stable.V1.Make (T)\n end\nend\n\nlet to_string = Stable.V2.to_string\nlet of_string = Stable.V2.of_string\nlet sexp_of_t = Stable.V2.sexp_of_t\nlet t_of_sexp = Stable.V2.t_of_sexp\n\nmodule Alternate_sexp = struct\n type nonrec t = t [@@deriving sexp]\nend\n\ninclude Comparable.Validate_with_zero (struct\n type nonrec t = t [@@deriving compare, sexp]\n\n let zero = zero\n end)\n\n(* Functions required by [Robustly_comparable]: allows for [robust_comparison_tolerance]\n granularity.\n\n A microsecond is a reasonable granularity because there is very little network\n activity that can be measured to sub-microsecond resolution. *)\nlet robust_comparison_tolerance = microsecond\nlet ( >=. ) t u = t >= Int63.(u - robust_comparison_tolerance)\nlet ( <=. ) t u = t <= Int63.(u + robust_comparison_tolerance)\nlet ( =. ) t u = Int63.(abs (t - u)) <= robust_comparison_tolerance\nlet ( >. ) t u = t > Int63.(u + robust_comparison_tolerance)\nlet ( <. ) t u = t < Int63.(u - robust_comparison_tolerance)\nlet ( <>. ) t u = Int63.(abs (t - u)) > robust_comparison_tolerance\nlet robustly_compare t u = if t <. u then -1 else if t >. u then 1 else 0\n\n(* We don't just convert to [Time.Span.t] and use the conversion there because our\n [to_span] conversion is limited to microsecond precision. *)\nlet to_string_hum\n ?(delimiter = '_')\n ?(decimals = 3)\n ?(align_decimal = false)\n ?unit_of_time\n t\n =\n let float, suffix =\n match Option.value unit_of_time ~default:(to_unit_of_time t) with\n | Day -> to_day t, \"d\"\n | Hour -> to_hr t, \"h\"\n | Minute -> to_min t, \"m\"\n | Second -> to_sec t, \"s\"\n | Millisecond -> to_ms t, \"ms\"\n | Microsecond -> to_us t, \"us\"\n | Nanosecond -> to_ns t, \"ns\"\n in\n let prefix =\n Float.to_string_hum float ~delimiter ~decimals ~strip_zero:(not align_decimal)\n in\n let suffix =\n if align_decimal && Int.( = ) (String.length suffix) 1 then suffix ^ \" \" else suffix\n in\n prefix ^ suffix\n;;\n\nlet since_unix_epoch () = Time_now.nanoseconds_since_unix_epoch () |> of_int63_ns\n\nlet random ?state () =\n Int63.random ?state (max_value_for_1us_rounding + Int63.one)\n - Int63.random ?state (neg min_value_for_1us_rounding + Int63.one)\n;;\n\nlet randomize t ~percent = Span_helpers.randomize t ~percent ~scale\n\nlet to_short_string t =\n let ({ sign; hr; min; sec; ms; us; ns } : Parts.t) = to_parts t in\n Span_helpers.short_string ~sign ~hr ~min ~sec ~ms ~us ~ns\n;;\n\nlet gen_incl = Int63.gen_incl\nlet gen_uniform_incl = Int63.gen_uniform_incl\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = module_name\n end)\n\ninclude Hashable.Make_binable (struct\n type nonrec t = t [@@deriving bin_io, compare, hash, sexp]\n end)\n\ntype comparator_witness = Stable.V2.comparator_witness\n\ninclude Comparable.Make_binable_using_comparator (struct\n type nonrec t = t [@@deriving bin_io, compare, sexp]\n type nonrec comparator_witness = comparator_witness\n\n let comparator = Stable.V2.comparator\n end)\n\n(* re-include [Replace_polymorphic_compare] and its comparisons to shadow the\n un-inlineable ones from [Comparable] *)\nmodule Replace_polymorphic_compare = T.Replace_polymorphic_compare\ninclude Replace_polymorphic_compare\n\nlet to_span_float_round_nearest t = Span_float.of_sec (to_sec t)\nlet of_span_float_round_nearest s = of_sec (Span_float.to_sec s)\nlet half_microsecond = Int63.of_int 500\nlet nearest_microsecond t = Int63.((to_int63_ns t + half_microsecond) /% of_int 1000)\n\nlet[@cold] invalid_range_for_1us_rounding t =\n raise_s\n [%message\n \"Span.t exceeds limits\"\n (t : t)\n (min_value_for_1us_rounding : t)\n (max_value_for_1us_rounding : t)]\n;;\n\nlet check_range_for_1us_rounding t =\n if t < min_value_for_1us_rounding || t > max_value_for_1us_rounding\n then invalid_range_for_1us_rounding t\n else t\n;;\n\nlet to_span_float_round_nearest_microsecond t =\n Span_float.of_us\n (Int63.to_float (nearest_microsecond (check_range_for_1us_rounding t)))\n;;\n\nlet min_span_float_value_for_1us_rounding =\n to_span_float_round_nearest min_value_for_1us_rounding\n;;\n\nlet max_span_float_value_for_1us_rounding =\n to_span_float_round_nearest max_value_for_1us_rounding\n;;\n\nlet of_span_float_round_nearest_microsecond s =\n if Span_float.( > ) s max_span_float_value_for_1us_rounding\n || Span_float.( < ) s min_span_float_value_for_1us_rounding\n then\n failwiths\n ~here:[%here]\n \"Time_ns.Span does not support this span\"\n s\n [%sexp_of: Span_float.t];\n (* Using [Time.Span.to_sec] (being the identity) so that\n we make don't apply too many conversion\n - Too many : `[Span.t] -> [a] -> [t]`\n - Only One : `[Span.t]==[a] -> [t]`. *)\n of_sec_with_microsecond_precision (Span_float.to_sec s)\n;;\n\nlet min_value_representable = of_int63_ns Int63.min_value\nlet max_value_representable = of_int63_ns Int63.max_value\n\nmodule Private = struct\n module Parts = Parts\n\n let of_parts = of_parts\n let to_parts = to_parts\nend\n\n(* Legacy definitions based on rounding to the nearest microsecond. *)\nlet min_value = min_value_for_1us_rounding\nlet max_value = max_value_for_1us_rounding\nlet of_span = of_span_float_round_nearest_microsecond\nlet to_span = to_span_float_round_nearest_microsecond\n","open! Import\nmodule Span = Span_ns\n\ntype underlying = Int63.t\n\ntype t = Span.t (* since wall-clock midnight *)\n[@@deriving bin_io, compare, hash, typerep]\n\ninclude (Span : Robustly_comparable.S with type t := t)\n\nlet to_parts t = Span.to_parts t\n\n\nlet start_of_day : t = Span.zero\nlet start_of_next_day : t = Span.day\nlet approximate_end_of_day = Span.( - ) start_of_next_day Span.nanosecond\nlet to_span_since_start_of_day t = t\n\nlet[@cold] input_out_of_bounds span =\n raise_s\n [%message\n \"Time_ns.Ofday.of_span_since_start_of_day_exn: input out of bounds\"\n ~_:(span : Span.t)]\n;;\n\nlet[@inline always] is_invalid span =\n (* Why we use [Span.( > )] rather than [( >= )] below:\n\n We allow to represent the end-of-day sentinel value ([24.000000000h]), which is not\n itself a valid clock face time. However, since valid clock face times readily\n round up to it, it's better to allow it to be represented. *)\n Span.( < ) span start_of_day || Span.( > ) span start_of_next_day\n;;\n\nlet span_since_start_of_day_is_valid span = not (is_invalid span)\nlet of_span_since_start_of_day_unchecked span = span\n\nlet of_span_since_start_of_day_exn span =\n if is_invalid span then input_out_of_bounds span else span\n;;\n\nlet of_span_since_start_of_day_opt span = if is_invalid span then None else Some span\nlet add_exn t span = of_span_since_start_of_day_exn (Span.( + ) t span)\nlet sub_exn t span = of_span_since_start_of_day_exn (Span.( - ) t span)\nlet add t span = of_span_since_start_of_day_opt (Span.( + ) t span)\nlet sub t span = of_span_since_start_of_day_opt (Span.( - ) t span)\nlet next t = of_span_since_start_of_day_opt (Span.next t)\nlet prev t = of_span_since_start_of_day_opt (Span.prev t)\nlet diff t u = Span.( - ) t u\n\nlet create ?hr ?min ?sec ?ms ?us ?ns () =\n (* Similar to [Time.Ofday.create], if we detect a leap second we strip off all\n sub-second elements so that HH:MM:60.XXXXXXXXX is all mapped to HH:MM:60. *)\n let ms, us, ns =\n match sec with\n | Some 60 -> Some 0, Some 0, Some 0\n | _ -> ms, us, ns\n in\n of_span_since_start_of_day_exn (Span.create ?hr ?min ?sec ?ms ?us ?ns ())\n;;\n\nmodule Stable = struct\n module V1 = struct\n module T = struct\n type nonrec t = t [@@deriving compare, bin_io]\n\n let to_string_with_unit =\n let ( / ) = Int63.( / ) in\n let ( mod ) = Int63.rem in\n let ( ! ) = Int63.of_int in\n let i = Int63.to_int_exn in\n fun t ~unit ->\n if Span.( < ) t start_of_day || Span.( < ) start_of_next_day t\n then \"Incorrect day\"\n else (\n let sixty = !60 in\n let thousand = !1000 in\n let ns = Span.to_int63_ns t in\n let us = ns / thousand in\n let ns = ns mod thousand |> i in\n let ms = us / thousand in\n let us = us mod thousand |> i in\n let s = ms / thousand in\n let ms = ms mod thousand |> i in\n let m = s / sixty in\n let s = s mod sixty |> i in\n let h = m / sixty |> i in\n let m = m mod sixty |> i in\n let unit =\n match unit with\n | (`Nanosecond | `Millisecond | `Second) as unit -> unit\n | `Minute_or_less ->\n if ns <> 0\n then `Nanosecond\n else if us <> 0\n then `Microsecond\n else if ms <> 0\n then `Millisecond\n else if s <> 0\n then `Second\n else `Minute\n in\n let len =\n match unit with\n | `Minute -> 5\n | `Second -> 8\n | `Millisecond -> 12\n | `Microsecond -> 15\n | `Nanosecond -> 18\n in\n let str = Bytes.create len in\n Digit_string_helpers.write_2_digit_int str ~pos:0 h;\n Bytes.set str 2 ':';\n Digit_string_helpers.write_2_digit_int str ~pos:3 m;\n (match unit with\n | `Minute -> ()\n | (`Second | `Millisecond | `Microsecond | `Nanosecond) as unit ->\n Bytes.set str 5 ':';\n Digit_string_helpers.write_2_digit_int str ~pos:6 s;\n (match unit with\n | `Second -> ()\n | (`Millisecond | `Microsecond | `Nanosecond) as unit ->\n Bytes.set str 8 '.';\n Digit_string_helpers.write_3_digit_int str ~pos:9 ms;\n (match unit with\n | `Millisecond -> ()\n | (`Microsecond | `Nanosecond) as unit ->\n Digit_string_helpers.write_3_digit_int str ~pos:12 us;\n (match unit with\n | `Microsecond -> ()\n | `Nanosecond -> Digit_string_helpers.write_3_digit_int str ~pos:15 ns))));\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:str)\n ;;\n\n let parse_nanoseconds string ~pos ~until =\n let open Int.O in\n let digits = ref 0 in\n let num_digits = ref 0 in\n let pos = ref pos in\n (* read up to 10 digits; store the first 9, use the 10th to round *)\n while !pos < until && !num_digits < 10 do\n let c = string.[!pos] in\n if Char.is_digit c\n then (\n incr num_digits;\n if !num_digits < 10\n then digits := (!digits * 10) + Char.get_digit_exn c\n else if Char.get_digit_exn c >= 5\n then incr digits\n else ());\n incr pos\n done;\n (* if there are missing digits, add zeroes *)\n if !num_digits < 9 then digits := !digits * Int.pow 10 (9 - !num_digits);\n !digits\n ;;\n\n let create_from_parsed string ~hr ~min ~sec ~subsec_pos ~subsec_len =\n let nanoseconds =\n if Int.equal subsec_len 0\n then 0\n else\n parse_nanoseconds\n string\n ~pos:(subsec_pos + 1)\n ~until:(subsec_pos + subsec_len)\n in\n Span.of_int63_ns (Int63.of_int nanoseconds)\n |> Span.( + ) (Span.scale_int Span.second sec)\n |> Span.( + ) (Span.scale_int Span.minute min)\n |> Span.( + ) (Span.scale_int Span.hour hr)\n |> of_span_since_start_of_day_exn\n ;;\n\n let of_string string = Ofday_helpers.parse string ~f:create_from_parsed\n\n let t_of_sexp sexp : t =\n match sexp with\n | Sexp.List _ -> of_sexp_error \"expected an atom\" sexp\n | Sexp.Atom s ->\n (try of_string s with\n | exn -> of_sexp_error_exn exn sexp)\n ;;\n\n let to_string (t : t) = to_string_with_unit t ~unit:`Nanosecond\n let sexp_of_t (t : t) = Sexp.Atom (to_string t)\n let to_int63 t = Span_ns.Stable.V2.to_int63 t\n\n let of_int63_exn t =\n of_span_since_start_of_day_exn (Span_ns.Stable.V2.of_int63_exn t)\n ;;\n end\n\n include T\n include Comparator.Stable.V1.Make (T)\n end\nend\n\nlet sexp_of_t = Stable.V1.sexp_of_t\nlet t_of_sexp = Stable.V1.t_of_sexp\nlet of_string = Stable.V1.of_string\nlet to_string = Stable.V1.to_string\nlet to_millisecond_string t = Stable.V1.to_string_with_unit t ~unit:`Millisecond\nlet to_sec_string t = Stable.V1.to_string_with_unit t ~unit:`Second\nlet to_string_trimmed t = Stable.V1.to_string_with_unit t ~unit:`Minute_or_less\n\nlet of_string_iso8601_extended ?pos ?len str =\n try\n Ofday_helpers.parse_iso8601_extended ?pos ?len str ~f:Stable.V1.create_from_parsed\n with\n | exn ->\n raise_s\n [%message\n \"Time_ns.Ofday.of_string_iso8601_extended: cannot parse string\"\n ~_:(String.subo str ?pos ?len : string)\n ~_:(exn : exn)]\n;;\n\nlet every =\n let rec every_valid_ofday_span span ~start ~stop ~acc =\n (* Assumes [span], [start], and [stop] are valid ofdays. Assumes [start < stop].\n Assumes [span > 0]. *)\n let acc = start :: acc in\n let start = Span.( + ) start span in\n if Span.( > ) start stop (* cannot overflow *)\n then List.rev acc\n else every_valid_ofday_span span ~start ~stop ~acc\n in\n (* internal [every] named to show up in stack traces *)\n let every span ~start ~stop =\n if Span.( > ) start stop\n then\n Or_error.error_s\n [%message\n \"[Time_ns.Ofday.every] called with [start] > [stop]\" (start : t) (stop : t)]\n else if Span.( <= ) span Span.zero\n then\n Or_error.error_s\n [%message \"[Time_ns.Ofday.every] called with negative span\" ~_:(span : Span.t)]\n else if is_invalid span\n then Ok [ start ]\n else Ok (every_valid_ofday_span span ~start ~stop ~acc:[])\n in\n every\n;;\n\nlet small_diff =\n let hour = Span.to_int63_ns Span.hour in\n fun ofday1 ofday2 ->\n let open Int63.O in\n let ofday1 = Span.to_int63_ns (to_span_since_start_of_day ofday1) in\n let ofday2 = Span.to_int63_ns (to_span_since_start_of_day ofday2) in\n let diff = ofday1 - ofday2 in\n (* d1 is in (-hour; hour) *)\n let d1 = Int63.rem diff hour in\n (* d2 is in (0;hour) *)\n let d2 = Int63.rem (d1 + hour) hour in\n let d = if d2 > hour / Int63.of_int 2 then d2 - hour else d2 in\n Span.of_int63_ns d\n;;\n\nlet%expect_test \"small_diff\" =\n let test x y =\n let diff = small_diff x y in\n printf !\"small_diff %s %s = %s\\n\" (to_string x) (to_string y) (Span.to_string diff)\n in\n let examples =\n List.map\n ~f:(fun (x, y) -> of_string x, of_string y)\n [ \"12:00\", \"12:05\"; \"12:58\", \"13:02\"; \"00:52\", \"23:19\"; \"00:00\", \"24:00\" ]\n in\n List.iter examples ~f:(fun (x, y) ->\n test x y;\n test y x);\n [%expect\n {|\n small_diff 12:00:00.000000000 12:05:00.000000000 = -5m\n small_diff 12:05:00.000000000 12:00:00.000000000 = 5m\n small_diff 12:58:00.000000000 13:02:00.000000000 = -4m\n small_diff 13:02:00.000000000 12:58:00.000000000 = 4m\n small_diff 00:52:00.000000000 23:19:00.000000000 = -27m\n small_diff 23:19:00.000000000 00:52:00.000000000 = 27m\n small_diff 00:00:00.000000000 24:00:00.000000000 = 0s\n small_diff 24:00:00.000000000 00:00:00.000000000 = 0s |}]\n;;\n\nlet gen_incl = Span.gen_incl\nlet gen_uniform_incl = Span.gen_uniform_incl\nlet quickcheck_generator = gen_incl start_of_day start_of_next_day\nlet quickcheck_observer = Span.quickcheck_observer\nlet quickcheck_shrinker = Quickcheck.Shrinker.empty ()\n\ninclude Identifiable.Make (struct\n type nonrec t = t [@@deriving bin_io, compare, hash, sexp]\n\n let module_name = \"Core.Time_ns.Ofday\"\n let hash = Span.hash\n let of_string, to_string = of_string, to_string\n end)\n\ninclude (Span : Comparisons.S with type t := t)\n\n(* deprecated bindings *)\nlet of_span_since_start_of_day = of_span_since_start_of_day_exn\nlet to_millisec_string = to_millisecond_string\n","open! Import\n\nmodule Stable = struct\n module Allocation_policy = struct\n module V1 = struct\n type t =\n | Next_fit\n | First_fit\n | Best_fit\n [@@deriving bin_io, compare, equal, hash, sexp]\n end\n end\nend\n\ninclude Caml.Gc\n\nmodule Stat = struct\n module T = struct\n [%%if ocaml_version >= (4, 12, 0)]\n\n type t = Caml.Gc.stat =\n { minor_words : float\n ; promoted_words : float\n ; major_words : float\n ; minor_collections : int\n ; major_collections : int\n ; heap_words : int\n ; heap_chunks : int\n ; live_words : int\n ; live_blocks : int\n ; free_words : int\n ; free_blocks : int\n ; largest_free : int\n ; fragments : int\n ; compactions : int\n ; top_heap_words : int\n ; stack_size : int\n ; forced_major_collections : int\n }\n [@@deriving compare, hash, bin_io, sexp, fields]\n\n [%%else]\n\n type t = Caml.Gc.stat =\n { minor_words : float\n ; promoted_words : float\n ; major_words : float\n ; minor_collections : int\n ; major_collections : int\n ; heap_words : int\n ; heap_chunks : int\n ; live_words : int\n ; live_blocks : int\n ; free_words : int\n ; free_blocks : int\n ; largest_free : int\n ; fragments : int\n ; compactions : int\n ; top_heap_words : int\n ; stack_size : int\n }\n [@@deriving compare, hash, bin_io, sexp, fields]\n\n [%%endif]\n end\n\n include T\n include Comparable.Make (T)\nend\n\nmodule Control = struct\n module T = struct\n [%%if\n ocaml_version < (4, 08, 0)]\n\n type t = Caml.Gc.control =\n { mutable minor_heap_size : int\n ; mutable major_heap_increment : int\n ; mutable space_overhead : int\n ; mutable verbose : int\n ; mutable max_overhead : int\n ; mutable stack_limit : int\n ; mutable allocation_policy : int\n ; window_size : int\n }\n [@@deriving compare, bin_io, sexp, fields]\n\n [%%else]\n\n [@@@ocaml.warning \"-3\"]\n\n type t = Caml.Gc.control =\n { mutable minor_heap_size : int\n ; mutable major_heap_increment : int\n ; mutable space_overhead : int\n ; mutable verbose : int\n ; mutable max_overhead : int\n ; mutable stack_limit : int\n ; mutable allocation_policy : int\n ; window_size : int\n ; custom_major_ratio : int\n ; custom_minor_ratio : int\n ; custom_minor_max_size : int\n }\n [@@deriving compare, bin_io, sexp, fields]\n\n [%%endif]\n end\n\n include T\n include Comparable.Make (T)\nend\n\nmodule Allocation_policy = struct\n include Stable.Allocation_policy.V1\n\n let to_int = function\n | Next_fit -> 0\n | First_fit -> 1\n | Best_fit -> 2\n ;;\nend\n\n[%%if\n ocaml_version < (4, 08, 0)]\n\nlet tune\n ?logger\n ?minor_heap_size\n ?major_heap_increment\n ?space_overhead\n ?verbose\n ?max_overhead\n ?stack_limit\n ?allocation_policy\n ?window_size\n ()\n =\n let old_control_params = get () in\n let f opt to_string field =\n let old_value = Field.get field old_control_params in\n match opt with\n | None -> old_value\n | Some new_value ->\n Option.iter logger ~f:(fun f ->\n Printf.ksprintf\n f\n \"Gc.Control.%s: %s -> %s\"\n (Field.name field)\n (to_string old_value)\n (to_string new_value));\n new_value\n in\n let allocation_policy = Option.map allocation_policy ~f:Allocation_policy.to_int in\n let new_control_params =\n Control.Fields.map\n ~minor_heap_size:(f minor_heap_size string_of_int)\n ~major_heap_increment:(f major_heap_increment string_of_int)\n ~space_overhead:(f space_overhead string_of_int)\n ~verbose:(f verbose string_of_int)\n ~max_overhead:(f max_overhead string_of_int)\n ~stack_limit:(f stack_limit string_of_int)\n ~allocation_policy:(f allocation_policy string_of_int)\n ~window_size:(f window_size string_of_int)\n in\n set new_control_params\n;;\n\n[%%else]\n\nlet tune\n ?logger\n ?minor_heap_size\n ?major_heap_increment\n ?space_overhead\n ?verbose\n ?max_overhead\n ?stack_limit\n ?allocation_policy\n ?window_size\n ?custom_major_ratio\n ?custom_minor_ratio\n ?custom_minor_max_size\n ()\n =\n let old_control_params = get () in\n let f opt to_string field =\n let old_value = Field.get field old_control_params in\n match opt with\n | None -> old_value\n | Some new_value ->\n Option.iter logger ~f:(fun f ->\n Printf.ksprintf\n f\n \"Gc.Control.%s: %s -> %s\"\n (Field.name field)\n (to_string old_value)\n (to_string new_value));\n new_value\n in\n let allocation_policy = Option.map allocation_policy ~f:Allocation_policy.to_int in\n let new_control_params =\n Control.Fields.map\n ~minor_heap_size:(f minor_heap_size string_of_int)\n ~major_heap_increment:(f major_heap_increment string_of_int)\n ~space_overhead:(f space_overhead string_of_int)\n ~verbose:(f verbose string_of_int)\n ~max_overhead:(f max_overhead string_of_int)\n ~stack_limit:(f stack_limit string_of_int)\n ~allocation_policy:(f allocation_policy string_of_int)\n ~window_size:(f window_size string_of_int)\n ~custom_major_ratio:(f custom_major_ratio string_of_int)\n ~custom_minor_ratio:(f custom_minor_ratio string_of_int)\n ~custom_minor_max_size:(f custom_minor_max_size string_of_int)\n in\n set new_control_params\n;;\n\n[%%endif]\n\nlet disable_compaction ?logger ~allocation_policy () =\n let allocation_policy =\n match allocation_policy with\n | `Don't_change -> None\n | `Set_to policy -> Some policy\n in\n (* The value 1_000_000, according to\n http://caml.inria.fr/pub/docs/manual-ocaml-4.02/libref/Gc.html\n will disable compactions.\n *)\n tune ?logger ?allocation_policy ~max_overhead:1_000_000 ()\n;;\n\nexternal minor_words : unit -> int = \"core_kernel_gc_minor_words\"\nexternal major_words : unit -> int = \"core_kernel_gc_major_words\" [@@noalloc]\nexternal promoted_words : unit -> int = \"core_kernel_gc_promoted_words\" [@@noalloc]\nexternal minor_collections : unit -> int = \"core_kernel_gc_minor_collections\" [@@noalloc]\nexternal major_collections : unit -> int = \"core_kernel_gc_major_collections\" [@@noalloc]\nexternal heap_words : unit -> int = \"core_kernel_gc_heap_words\" [@@noalloc]\nexternal heap_chunks : unit -> int = \"core_kernel_gc_heap_chunks\" [@@noalloc]\nexternal compactions : unit -> int = \"core_kernel_gc_compactions\" [@@noalloc]\nexternal top_heap_words : unit -> int = \"core_kernel_gc_top_heap_words\" [@@noalloc]\nexternal major_plus_minor_words : unit -> int = \"core_kernel_gc_major_plus_minor_words\"\nexternal allocated_words : unit -> int = \"core_kernel_gc_allocated_words\"\n\nlet zero = Sys.opaque_identity (int_of_string \"0\")\n\n(* The compiler won't optimize int_of_string away so it won't\n perform constant folding below. *)\nlet rec keep_alive o = if zero <> 0 then keep_alive (Sys.opaque_identity o)\n\nmodule For_testing = struct\n let prepare_heap_to_count_minor_allocation () =\n (* We call [minor] to empty the minor heap, so that our allocation is unlikely to\n trigger a minor gc. *)\n minor ();\n (* We allocate two words in case the [Gc.minor] finishes a major gc cycle, in which\n case it requests a minor gc to occur at the next minor allocation. We don't want\n the subsequent minor allocation to trigger a minor GC, because there is a bug\n (https://github.com/ocaml/ocaml/issues/7798) in the OCaml runtime that double\n counts [Gc.minor_words] in that case. *)\n ignore (Sys.opaque_identity (ref (Sys.opaque_identity 1)) : int ref)\n ;;\n\n (* We disable inlining for this function so the GC stats and the call to [f] are never\n rearranged. *)\n let[@cold] measure_internal ~on_result f =\n let minor_words_before = minor_words () in\n let major_words_before = major_words () in\n (* We wrap [f ()] with [Sys.opaque_identity] to prevent the return value from being\n optimized away. *)\n let x = Sys.opaque_identity (f ()) in\n let minor_words_after = minor_words () in\n let major_words_after = major_words () in\n let major_words_allocated = major_words_after - major_words_before in\n let minor_words_allocated = minor_words_after - minor_words_before in\n on_result ~major_words_allocated ~minor_words_allocated x\n ;;\n\n let is_zero_alloc (type a) (f : unit -> a) =\n (* Instead of using [Allocation_report.measure], and matching on the result, we use\n this construction, in order to have [is_zero_alloc] not allocate itself. This\n enables [is_zero_alloc] to be used in a nested way.\n\n This also means we cannot call [prepare_heap_to_count_minor_allocation]. This is\n okay, since we do not need a precise count, we only need to check if the count is\n zero or not. *)\n measure_internal\n f\n ~on_result:(fun ~major_words_allocated ~minor_words_allocated value ->\n ignore (Sys.opaque_identity value : a);\n major_words_allocated == 0 && minor_words_allocated == 0)\n ;;\n\n module Allocation_report = struct\n type t =\n { major_words_allocated : int\n ; minor_words_allocated : int\n }\n\n let create ~major_words_allocated ~minor_words_allocated =\n { major_words_allocated; minor_words_allocated }\n ;;\n end\n\n let measure_allocation f =\n prepare_heap_to_count_minor_allocation ();\n measure_internal f ~on_result:(fun ~major_words_allocated ~minor_words_allocated x ->\n x, Allocation_report.create ~major_words_allocated ~minor_words_allocated)\n ;;\nend\n\nmodule Expert = struct\n let add_finalizer x f =\n try Caml.Gc.finalise (fun x -> Exn.handle_uncaught_and_exit (fun () -> f x)) x with\n | Invalid_argument _ ->\n (* The type of add_finalizer ensures that the only possible failure\n is due to [x] being static data. In this case, we simply drop the\n finalizer since static data would never have been collected by the\n GC anyway. *)\n ()\n ;;\n\n (* [add_finalizer_exn] is the same as [add_finalizer]. However, their types in\n core_gc.mli are different, and the type of [add_finalizer] guarantees that it always\n receives a heap block, which ensures that it will not raise, while\n [add_finalizer_exn] accepts any type, and so may raise. *)\n let add_finalizer_exn x f =\n try Caml.Gc.finalise (fun x -> Exn.handle_uncaught_and_exit (fun () -> f x)) x with\n | Invalid_argument _ ->\n ignore (Heap_block.create x : _ Heap_block.t option);\n (* If [Heap_block.create] succeeds then [x] is static data and so\n we can simply drop the finaliser. *)\n ()\n ;;\n\n let add_finalizer_last x f =\n try Caml.Gc.finalise_last (fun () -> Exn.handle_uncaught_and_exit f) x with\n | Invalid_argument _ ->\n (* The type of add_finalizer_last ensures that the only possible failure\n is due to [x] being static data. In this case, we simply drop the\n finalizer since static data would never have been collected by the\n GC anyway. *)\n ()\n ;;\n\n let add_finalizer_last_exn x f =\n try Caml.Gc.finalise_last (fun () -> Exn.handle_uncaught_and_exit f) x with\n | Invalid_argument _ ->\n ignore (Heap_block.create x : _ Heap_block.t option);\n (* If [Heap_block.create] succeeds then [x] is static data and so\n we can simply drop the finaliser. *)\n ()\n ;;\n\n let finalize_release = Caml.Gc.finalise_release\n\n module Alarm = struct\n type t = alarm\n\n let sexp_of_t _ = \"\" |> [%sexp_of: string]\n let create f = create_alarm (fun () -> Exn.handle_uncaught_and_exit f)\n let delete = delete_alarm\n end\nend\n","open Format\n\nlet rev_split l =\n let rec inner xs ys = function\n | (x, y) :: xys ->\n inner (x::xs) (y::ys) xys\n | [] -> (xs, ys)\n in\n inner [] [] l\n\ntype wrap = [\n | `Wrap_atoms\n | `Always_wrap\n | `Never_wrap\n | `Force_breaks\n | `Force_breaks_rec\n | `No_breaks\n]\n\ntype label_break = [\n | `Auto\n | `Always\n | `Always_rec\n | `Never\n]\n\ntype style_name = string\ntype style = {\n tag_open : string;\n tag_close : string\n}\n\ntype atom_param = {\n atom_style : style_name option;\n}\n\nlet atom = {\n atom_style = None\n}\n\ntype list_param = {\n space_after_opening : bool;\n space_after_separator : bool;\n space_before_separator : bool;\n separators_stick_left : bool;\n space_before_closing : bool;\n stick_to_label : bool;\n align_closing : bool;\n wrap_body : wrap;\n indent_body : int;\n list_style : style_name option;\n opening_style : style_name option;\n body_style : style_name option;\n separator_style : style_name option;\n closing_style : style_name option;\n}\n\nlet list = {\n space_after_opening = true;\n space_after_separator = true;\n space_before_separator = false;\n separators_stick_left = true;\n space_before_closing = true;\n stick_to_label = true;\n align_closing = true;\n wrap_body = `Wrap_atoms;\n indent_body = 2;\n list_style = None;\n opening_style = None;\n body_style = None;\n separator_style = None;\n closing_style = None;\n}\n\ntype label_param = {\n label_break: label_break;\n space_after_label : bool;\n indent_after_label : int;\n label_style : style_name option;\n}\n\nlet label = {\n label_break = `Auto;\n space_after_label = true;\n indent_after_label = 2;\n label_style = None;\n}\n\ntype t =\n Atom of string * atom_param\n | List of (string * string * string * list_param) * t list\n | Label of (t * label_param) * t\n | Custom of (formatter -> unit)\n\ntype escape =\n [ `None\n | `Escape of\n ((string -> int -> int -> unit) -> string -> int -> int -> unit)\n | `Escape_string of (string -> string) ]\n\ntype styles = (style_name * style) list\n\n(*\n Transform a tree starting from the leaves, propagating and merging\n accumulators until reaching the root.\n*)\nlet propagate_from_leaf_to_root\n ~init_acc (* create initial accumulator for a leaf *)\n ~merge_acc (* merge two accumulators coming from child nodes *)\n ~map_node (* (node, acc) -> (node, acc) *)\n x =\n\n let rec aux x =\n match x with\n | Atom _ ->\n let acc = init_acc x in\n map_node x acc\n | List (param, children) ->\n let new_children, accs = rev_split (List.rev_map aux children) in\n let acc = List.fold_left merge_acc (init_acc x) accs in\n map_node (List (param, new_children)) acc\n | Label ((x1, param), x2) ->\n let acc0 = init_acc x in\n let new_x1, acc1 = aux x1 in\n let new_x2, acc2 = aux x2 in\n let acc = merge_acc (merge_acc acc0 acc1) acc2 in\n map_node (Label ((new_x1, param), new_x2)) acc\n | Custom _ ->\n let acc = init_acc x in\n map_node x acc\n in\n aux x\n\n(*\n Convert wrappable lists into vertical lists if any of their descendants\n has the attribute wrap_body = `Force_breaks_rec.\n*)\nlet propagate_forced_breaks x =\n (* acc = whether to force breaks in wrappable lists or labels *)\n let init_acc = function\n | List ((_, _, _, { wrap_body = `Force_breaks_rec; _ }), _)\n | Label ((_, { label_break = `Always_rec; _ }), _) -> true\n | Atom _\n | Label _\n | Custom _\n | List _ -> false\n in\n let merge_acc force_breaks1 force_breaks2 =\n force_breaks1 || force_breaks2\n in\n let map_node x force_breaks =\n match x with\n | List ((_, _, _, { wrap_body = `Force_breaks_rec; _ }), _) -> x, true\n | List ((_, _, _, { wrap_body = `Force_breaks; _ }), _) -> x, force_breaks\n\n | List ((op, sep, cl, ({ wrap_body = (`Wrap_atoms\n | `Never_wrap\n | `Always_wrap); _ } as p)),\n children) ->\n if force_breaks then\n let p = { p with wrap_body = `Force_breaks } in\n List ((op, sep, cl, p), children), true\n else\n x, false\n\n | Label ((a, ({ label_break = `Auto; _ } as lp)), b) ->\n if force_breaks then\n let lp = { lp with label_break = `Always } in\n Label ((a, lp), b), true\n else\n x, false\n\n | List ((_, _, _, { wrap_body = `No_breaks; _ }), _)\n | Label ((_, { label_break = (`Always | `Always_rec | `Never); _ }), _)\n | Atom _\n | Custom _ -> x, force_breaks\n in\n let new_x, _forced_breaks =\n propagate_from_leaf_to_root\n ~init_acc\n ~merge_acc\n ~map_node\n x\n in\n new_x\n\nmodule Pretty =\nstruct\n (*\n Rewrite the tree to be printed.\n Currently, this is used only to handle `Force_breaks_rec.\n *)\n let rewrite x = propagate_forced_breaks x\n\n (*\n Relies on the fact that mark_open_tag and mark_close_tag\n are called exactly once before calling pp_output_string once.\n It's a reasonable assumption although not guaranteed by the\n documentation of the Format module.\n *)\n let set_escape fmt escape =\n let print0, flush0 = pp_get_formatter_output_functions fmt () in\n let tagf0 = pp_get_formatter_tag_functions fmt () in\n\n let is_tag = ref false in\n\n let mot tag =\n is_tag := true;\n tagf0.mark_open_tag tag\n in\n\n let mct tag =\n is_tag := true;\n tagf0.mark_close_tag tag\n in\n\n let print s p n =\n if !is_tag then\n (print0 s p n;\n is_tag := false)\n else\n escape print0 s p n\n in\n\n let tagf = {\n tagf0 with\n mark_open_tag = mot;\n mark_close_tag = mct\n }\n in\n pp_set_formatter_output_functions fmt print flush0;\n pp_set_formatter_tag_functions fmt tagf\n\n\n let set_escape_string fmt esc =\n let escape print s p n =\n let s0 = String.sub s p n in\n let s1 = esc s0 in\n print s1 0 (String.length s1)\n in\n set_escape fmt escape\n\n\n let define_styles fmt escape l =\n if l <> [] then (\n pp_set_tags fmt true;\n let tbl1 = Hashtbl.create (2 * List.length l) in\n let tbl2 = Hashtbl.create (2 * List.length l) in\n List.iter (\n fun (style_name, style) ->\n Hashtbl.add tbl1 style_name style.tag_open;\n Hashtbl.add tbl2 style_name style.tag_close\n ) l;\n let mark_open_tag style_name =\n try Hashtbl.find tbl1 style_name\n with Not_found -> \"\"\n in\n let mark_close_tag style_name =\n try Hashtbl.find tbl2 style_name\n with Not_found -> \"\"\n in\n\n let tagf = {\n (pp_get_formatter_tag_functions fmt ()) with\n mark_open_tag = mark_open_tag;\n mark_close_tag = mark_close_tag\n }\n in\n pp_set_formatter_tag_functions fmt tagf\n );\n\n (match escape with\n `None -> ()\n | `Escape esc -> set_escape fmt esc\n | `Escape_string esc -> set_escape_string fmt esc)\n\n\n let pp_open_xbox fmt p indent =\n match p.wrap_body with\n `Always_wrap\n | `Never_wrap\n | `Wrap_atoms -> pp_open_hvbox fmt indent\n | `Force_breaks\n | `Force_breaks_rec -> pp_open_vbox fmt indent\n | `No_breaks -> pp_open_hbox fmt ()\n\n let extra_box p l =\n let wrap =\n match p.wrap_body with\n `Always_wrap -> true\n | `Never_wrap\n | `Force_breaks\n | `Force_breaks_rec\n | `No_breaks -> false\n | `Wrap_atoms ->\n List.for_all (function Atom _ -> true | _ -> false) l\n in\n if wrap then\n ((fun fmt -> pp_open_hovbox fmt 0),\n (fun fmt -> pp_close_box fmt ()))\n else\n ((fun _ -> ()),\n (fun _ -> ()))\n\n\n let pp_open_nonaligned_box fmt p indent l =\n match p.wrap_body with\n `Always_wrap -> pp_open_hovbox fmt indent\n | `Never_wrap -> pp_open_hvbox fmt indent\n | `Wrap_atoms ->\n if List.for_all (function Atom _ -> true | _ -> false) l then\n pp_open_hovbox fmt indent\n else\n pp_open_hvbox fmt indent\n | `Force_breaks\n | `Force_breaks_rec -> pp_open_vbox fmt indent\n | `No_breaks -> pp_open_hbox fmt ()\n\n\n let open_tag fmt = function\n None -> ()\n | Some s -> pp_open_tag fmt s\n\n let close_tag fmt = function\n None -> ()\n | Some _ -> pp_close_tag fmt ()\n\n let tag_string fmt o s =\n match o with\n None -> pp_print_string fmt s\n | Some tag ->\n pp_open_tag fmt tag;\n pp_print_string fmt s;\n pp_close_tag fmt ()\n\n let rec fprint_t fmt = function\n Atom (s, p) ->\n tag_string fmt p.atom_style s;\n\n | List ((_, _, _, p) as param, l) ->\n open_tag fmt p.list_style;\n if p.align_closing then\n fprint_list fmt None param l\n else\n fprint_list2 fmt param l;\n close_tag fmt p.list_style\n\n | Label (label, x) -> fprint_pair fmt label x\n | Custom f -> f fmt\n\n and fprint_list_body_stick_left fmt p sep hd tl =\n open_tag fmt p.body_style;\n fprint_t fmt hd;\n List.iter (\n fun x ->\n if p.space_before_separator then\n pp_print_string fmt \" \";\n tag_string fmt p.separator_style sep;\n if p.space_after_separator then\n pp_print_space fmt ()\n else\n pp_print_cut fmt ();\n fprint_t fmt x\n ) tl;\n close_tag fmt p.body_style\n\n and fprint_list_body_stick_right fmt p sep hd tl =\n open_tag fmt p.body_style;\n fprint_t fmt hd;\n List.iter (\n fun x ->\n if p.space_before_separator then\n pp_print_space fmt ()\n else\n pp_print_cut fmt ();\n tag_string fmt p.separator_style sep;\n if p.space_after_separator then\n pp_print_string fmt \" \";\n fprint_t fmt x\n ) tl;\n close_tag fmt p.body_style\n\n and fprint_opt_label fmt = function\n None -> ()\n | Some (lab, lp) ->\n open_tag fmt lp.label_style;\n fprint_t fmt lab;\n close_tag fmt lp.label_style;\n if lp.space_after_label then\n pp_print_string fmt \" \"\n\n (* Either horizontal or vertical list *)\n and fprint_list fmt label ((op, _sep, cl, p) as param) = function\n [] ->\n fprint_opt_label fmt label;\n tag_string fmt p.opening_style op;\n if p.space_after_opening || p.space_before_closing then\n pp_print_string fmt \" \";\n tag_string fmt p.closing_style cl\n\n | hd :: tl as l ->\n\n if tl = [] || p.separators_stick_left then\n fprint_list_stick_left fmt label param hd tl l\n else\n fprint_list_stick_right fmt label param hd tl l\n\n\n and fprint_list_stick_left fmt label (op, sep, cl, p) hd tl l =\n let indent = p.indent_body in\n pp_open_xbox fmt p indent;\n fprint_opt_label fmt label;\n\n tag_string fmt p.opening_style op;\n\n if p.space_after_opening then\n pp_print_space fmt ()\n else\n pp_print_cut fmt ();\n\n let open_extra, close_extra = extra_box p l in\n open_extra fmt;\n fprint_list_body_stick_left fmt p sep hd tl;\n close_extra fmt;\n\n if p.space_before_closing then\n pp_print_break fmt 1 (-indent)\n else\n pp_print_break fmt 0 (-indent);\n tag_string fmt p.closing_style cl;\n pp_close_box fmt ()\n\n and fprint_list_stick_right fmt label (op, sep, cl, p) hd tl l =\n let base_indent = p.indent_body in\n let sep_indent =\n String.length sep + (if p.space_after_separator then 1 else 0)\n in\n let indent = base_indent + sep_indent in\n\n pp_open_xbox fmt p indent;\n fprint_opt_label fmt label;\n\n tag_string fmt p.opening_style op;\n\n if p.space_after_opening then\n pp_print_space fmt ()\n else\n pp_print_cut fmt ();\n\n let open_extra, close_extra = extra_box p l in\n open_extra fmt;\n\n fprint_t fmt hd;\n List.iter (\n fun x ->\n if p.space_before_separator then\n pp_print_break fmt 1 (-sep_indent)\n else\n pp_print_break fmt 0 (-sep_indent);\n tag_string fmt p.separator_style sep;\n if p.space_after_separator then\n pp_print_string fmt \" \";\n fprint_t fmt x\n ) tl;\n\n close_extra fmt;\n\n if p.space_before_closing then\n pp_print_break fmt 1 (-indent)\n else\n pp_print_break fmt 0 (-indent);\n tag_string fmt p.closing_style cl;\n pp_close_box fmt ()\n\n\n\n (* align_closing = false *)\n and fprint_list2 fmt (op, sep, cl, p) = function\n [] ->\n tag_string fmt p.opening_style op;\n if p.space_after_opening || p.space_before_closing then\n pp_print_string fmt \" \";\n tag_string fmt p.closing_style cl\n\n | hd :: tl as l ->\n tag_string fmt p.opening_style op;\n if p.space_after_opening then\n pp_print_string fmt \" \";\n\n pp_open_nonaligned_box fmt p 0 l ;\n if p.separators_stick_left then\n fprint_list_body_stick_left fmt p sep hd tl\n else\n fprint_list_body_stick_right fmt p sep hd tl;\n pp_close_box fmt ();\n\n if p.space_before_closing then\n pp_print_string fmt \" \";\n tag_string fmt p.closing_style cl\n\n\n (* Printing a label:value pair.\n\n The opening bracket stays on the same line as the key, no matter what,\n and the closing bracket is either on the same line\n or vertically aligned with the beginning of the key.\n *)\n and fprint_pair fmt ((lab, lp) as label) x =\n match x with\n List ((op, sep, cl, p), l) when p.stick_to_label && p.align_closing ->\n fprint_list fmt (Some label) (op, sep, cl, p) l\n\n | _ ->\n let indent = lp.indent_after_label in\n pp_open_hvbox fmt 0;\n\n open_tag fmt lp.label_style;\n fprint_t fmt lab;\n close_tag fmt lp.label_style;\n\n (match lp.label_break with\n | `Auto ->\n if lp.space_after_label then\n pp_print_break fmt 1 indent\n else\n pp_print_break fmt 0 indent\n | `Always\n | `Always_rec ->\n pp_force_newline fmt ();\n pp_print_string fmt (String.make indent ' ')\n | `Never ->\n if lp.space_after_label then\n pp_print_char fmt ' '\n else\n ()\n );\n fprint_t fmt x;\n pp_close_box fmt ()\n\n let to_formatter fmt x =\n let x = rewrite x in\n fprint_t fmt x;\n pp_print_flush fmt ()\n\n let to_buffer ?(escape = `None) ?(styles = []) buf x =\n let fmt = Format.formatter_of_buffer buf in\n define_styles fmt escape styles;\n to_formatter fmt x\n\n let to_string ?escape ?styles x =\n let buf = Buffer.create 500 in\n to_buffer ?escape ?styles buf x;\n Buffer.contents buf\n\n let to_channel ?(escape = `None) ?(styles = []) oc x =\n let fmt = formatter_of_out_channel oc in\n define_styles fmt escape styles;\n to_formatter fmt x\n\n let to_stdout ?escape ?styles x = to_channel ?escape ?styles stdout x\n let to_stderr ?escape ?styles x = to_channel ?escape ?styles stderr x\n\nend\n\n\n\n\nmodule Compact =\nstruct\n open Printf\n\n let rec fprint_t buf = function\n Atom (s, _) -> Buffer.add_string buf s\n | List (param, l) -> fprint_list buf param l\n | Label (label, x) -> fprint_pair buf label x\n | Custom f ->\n (* Will most likely not be compact *)\n let fmt = formatter_of_buffer buf in\n f fmt;\n pp_print_flush fmt ()\n\n and fprint_list buf (op, sep, cl, _) = function\n [] -> bprintf buf \"%s%s\" op cl\n | x :: tl ->\n Buffer.add_string buf op;\n fprint_t buf x;\n List.iter (\n fun x ->\n Buffer.add_string buf sep;\n fprint_t buf x\n ) tl;\n Buffer.add_string buf cl\n\n and fprint_pair buf (label, _) x =\n fprint_t buf label;\n fprint_t buf x\n\n\n let to_buffer buf x = fprint_t buf x\n\n let to_string x =\n let buf = Buffer.create 500 in\n to_buffer buf x;\n Buffer.contents buf\n\n let to_formatter fmt x =\n let s = to_string x in\n Format.fprintf fmt \"%s\" s;\n pp_print_flush fmt ()\n\n let to_channel oc x =\n let buf = Buffer.create 500 in\n to_buffer buf x;\n Buffer.output_buffer oc buf\n\n let to_stdout x = to_channel stdout x\n let to_stderr x = to_channel stderr x\nend\n\n\n\n\n(* Obsolete *)\nmodule Param =\nstruct\n let list_true = {\n space_after_opening = true;\n space_after_separator = true;\n space_before_separator = true;\n separators_stick_left = true;\n space_before_closing = true;\n stick_to_label = true;\n align_closing = true;\n wrap_body = `Wrap_atoms;\n indent_body = 2;\n list_style = None;\n opening_style = None;\n body_style = None;\n separator_style = None;\n closing_style = None;\n }\n\n let list_false = {\n space_after_opening = false;\n space_after_separator = false;\n space_before_separator = false;\n separators_stick_left = false;\n space_before_closing = false;\n stick_to_label = false;\n align_closing = false;\n wrap_body = `Wrap_atoms;\n indent_body = 2;\n list_style = None;\n opening_style = None;\n body_style = None;\n separator_style = None;\n closing_style = None;\n }\n\n let label_true = {\n label_break = `Auto;\n space_after_label = true;\n indent_after_label = 2;\n label_style = None;\n }\n\n let label_false = {\n label_break = `Auto;\n space_after_label = false;\n indent_after_label = 2;\n label_style = None;\n }\nend\n","# 1 \"common.ml\"\nlet version = \"1.7.0\"\n\nexception Json_error of string\n\nlet json_error s = raise (Json_error s)\n\nexception End_of_array\nexception End_of_object\nexception End_of_tuple\nexception End_of_input\n\ntype in_param = {\n string_buf : Buffer.t\n}\n\nlet create_in_param ?(len = 256) () = {\n string_buf = Buffer.create len\n}\n\n\nlet utf8_of_code buf x =\n let add = Bi_outbuf.add_char in\n\n (* Straight <= doesn't work with signed 31-bit ints *)\n let maxbits n x = x lsr n = 0 in\n\n if maxbits 7 x then\n (* 7 *)\n add buf (Char.chr x)\n else if maxbits 11 x then (\n (* 5 + 6 *)\n add buf (Char.chr (0b11000000 lor ((x lsr 6) land 0b00011111)));\n add buf (Char.chr (0b10000000 lor (x land 0b00111111)))\n )\n else if maxbits 16 x then (\n (* 4 + 6 + 6 *)\n add buf (Char.chr (0b11100000 lor ((x lsr 12) land 0b00001111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 6) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor (x land 0b00111111)))\n )\n else if maxbits 21 x then (\n (* 3 + 6 + 6 + 6 *)\n add buf (Char.chr (0b11110000 lor ((x lsr 18) land 0b00000111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 12) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 6) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor (x land 0b00111111)));\n )\n else if maxbits 26 x then (\n (* 2 + 6 + 6 + 6 + 6 *)\n add buf (Char.chr (0b11111000 lor ((x lsr 24) land 0b00000011)));\n add buf (Char.chr (0b10000000 lor ((x lsr 18) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 12) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 6) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor (x land 0b00111111)));\n )\n else (\n assert (maxbits 31 x);\n (* 1 + 6 + 6 + 6 + 6 + 6 *)\n add buf (Char.chr (0b11111100 lor ((x lsr 30) land 0b00000001)));\n add buf (Char.chr (0b10000000 lor ((x lsr 24) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 18) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 12) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 6) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor (x land 0b00111111)));\n )\n\nlet code_of_surrogate_pair i j =\n let high10 = i - 0xD800 in\n let low10 = j - 0xDC00 in\n 0x10000 + ((high10 lsl 10) lor low10)\n\nlet utf8_of_surrogate_pair buf i j =\n utf8_of_code buf (code_of_surrogate_pair i j)\n\nlet is_object_or_array x =\n match x with\n `List _\n | `Assoc _ -> true\n | _ -> false\n\n\ntype lexer_state = {\n buf : Bi_outbuf.t;\n (* Buffer used to accumulate substrings *)\n\n mutable lnum : int;\n (* Current line number (starting from 1) *)\n\n mutable bol : int;\n (* Absolute position of the first character of the current line\n (starting from 0) *)\n\n mutable fname : string option;\n (* Name describing the input file *)\n}\n\nmodule Lexer_state =\nstruct\n type t = lexer_state = {\n buf : Bi_outbuf.t;\n mutable lnum : int;\n mutable bol : int;\n mutable fname : string option;\n }\nend\n\nlet init_lexer ?buf ?fname ?(lnum = 1) () =\n let buf =\n match buf with\n\tNone -> Bi_outbuf.create 256\n | Some buf -> buf\n in\n {\n buf = buf;\n lnum = lnum;\n bol = 0;\n fname = fname\n }\n\n# 1 \"type.ml\"\n(** {3 Type of the JSON tree} *)\n\ntype t =\n [\n | `Null\n | `Bool of bool\n \n# 8 \"type.ml\"\n | `Int of int\n \n# 11 \"type.ml\"\n | `Intlit of string\n \n# 14 \"type.ml\"\n | `Float of float\n \n# 17 \"type.ml\"\n | `Floatlit of string\n \n# 20 \"type.ml\"\n | `String of string\n \n# 23 \"type.ml\"\n | `Stringlit of string\n \n# 25 \"type.ml\"\n | `Assoc of (string * t) list\n | `List of t list\n \n# 28 \"type.ml\"\n | `Tuple of t list\n \n# 31 \"type.ml\"\n | `Variant of (string * t option)\n \n# 33 \"type.ml\"\n ]\n(**\nAll possible cases defined in Yojson:\n- `Null: JSON null\n- `Bool of bool: JSON boolean\n- `Int of int: JSON number without decimal point or exponent.\n- `Intlit of string: JSON number without decimal point or exponent,\n\t preserved as a string.\n- `Float of float: JSON number, Infinity, -Infinity or NaN.\n- `Floatlit of string: JSON number, Infinity, -Infinity or NaN,\n\t preserved as a string.\n- `String of string: JSON string. Bytes in the range 128-255 are preserved\n\t as-is without encoding validation for both reading\n\t and writing.\n- `Stringlit of string: JSON string literal including the double quotes.\n- `Assoc of (string * json) list: JSON object.\n- `List of json list: JSON array.\n- `Tuple of json list: Tuple (non-standard extension of JSON).\n\t Syntax: [(\"abc\", 123)].\n- `Variant of (string * json option): Variant (non-standard extension of JSON).\n\t Syntax: [<\"Foo\">] or [<\"Bar\":123>].\n*)\n\ntype json = t [@@deprecated \"json types are being renamed and will be removed in the next Yojson major version. Use type t instead\"]\n(**\n * Compatibility type alias for type `t`\n *)\n\n(*\n Note to adventurers: ocamldoc does not support inline comments\n on each polymorphic variant, and cppo doesn't allow to concatenate\n comments, so it would be complicated to document only the\n cases that are preserved by cppo in the type definition.\n*)\n# 12 \"yojson.cppo.ml\"\ntype json_max = t\n# 1 \"write.ml\"\n(* included: type.ml *)\n\nlet hex n =\n Char.chr (\n if n < 10 then n + 48\n else n + 87\n )\n\nlet write_special src start stop ob str =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n Bi_outbuf.add_string ob str;\n start := stop + 1\n\nlet write_control_char src start stop ob c =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n let i = Bi_outbuf.alloc ob 6 in\n let dst = ob.o_s in\n Bytes.blit_string \"\\\\u00\" 0 dst i 4;\n Bytes.set dst (i+4) (hex (Char.code c lsr 4));\n Bytes.set dst (i+5) (hex (Char.code c land 0xf));\n start := stop + 1\n\nlet finish_string src start ob =\n try\n Bi_outbuf.add_substring ob src !start (String.length src - !start)\n with exc ->\n Printf.eprintf \"src=%S start=%i len=%i\\n%!\"\n src !start (String.length src - !start);\n raise exc\n\nlet write_string_body ob s =\n let start = ref 0 in\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '\"' -> write_special s start i ob \"\\\\\\\"\"\n | '\\\\' -> write_special s start i ob \"\\\\\\\\\"\n | '\\b' -> write_special s start i ob \"\\\\b\"\n | '\\012' -> write_special s start i ob \"\\\\f\"\n | '\\n' -> write_special s start i ob \"\\\\n\"\n | '\\r' -> write_special s start i ob \"\\\\r\"\n | '\\t' -> write_special s start i ob \"\\\\t\"\n | '\\x00'..'\\x1F'\n | '\\x7F' as c -> write_control_char s start i ob c\n | _ -> ()\n done;\n finish_string s start ob\n\nlet write_string ob s =\n Bi_outbuf.add_char ob '\"';\n write_string_body ob s;\n Bi_outbuf.add_char ob '\"'\n\nlet json_string_of_string s =\n let ob = Bi_outbuf.create 10 in\n write_string ob s;\n Bi_outbuf.contents ob\n\nlet test_string () =\n let s = Bytes.create 256 in\n for i = 0 to 255 do\n Bytes.set s i (Char.chr i)\n done;\n json_string_of_string (Bytes.to_string s)\n\n\nlet write_null ob () =\n Bi_outbuf.add_string ob \"null\"\n\nlet write_bool ob x =\n Bi_outbuf.add_string ob (if x then \"true\" else \"false\")\n\n\nlet max_digits =\n max\n (String.length (string_of_int max_int))\n (String.length (string_of_int min_int))\n\nlet dec n =\n Char.chr (n + 48)\n\nlet rec write_digits s pos x =\n if x = 0 then pos\n else\n let d = x mod 10 in\n let pos = write_digits s pos (x / 10) in\n Bytes.set s pos (dec (abs d));\n pos + 1\n\nlet write_int ob x =\n Bi_outbuf.extend ob max_digits;\n if x > 0 then\n ob.o_len <- write_digits ob.o_s ob.o_len x\n else if x < 0 then (\n let s = ob.o_s in\n let pos = ob.o_len in\n Bytes.set s pos '-';\n ob.o_len <- write_digits s (pos + 1) x\n )\n else\n Bi_outbuf.add_char ob '0'\n\n\nlet json_string_of_int i =\n string_of_int i\n\n\n(*\n Ensure that the float is not printed as an int.\n This is not required by JSON, but useful in order to guarantee\n reversibility.\n*)\nlet float_needs_period s =\n try\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '0'..'9' | '-' -> ()\n | _ -> raise Exit\n done;\n true\n with Exit ->\n false\n\n(*\n Both write_float_fast and write_float guarantee\n that a sufficient number of digits are printed in order to\n allow reversibility.\n\n The _fast version is faster but often produces unnecessarily long numbers.\n*)\nlet write_float_fast ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_normal_float_prec significant_figures ob x =\n let open Printf in\n let s =\n match significant_figures with\n 1 -> sprintf \"%.1g\" x\n | 2 -> sprintf \"%.2g\" x\n | 3 -> sprintf \"%.3g\" x\n | 4 -> sprintf \"%.4g\" x\n | 5 -> sprintf \"%.5g\" x\n | 6 -> sprintf \"%.6g\" x\n | 7 -> sprintf \"%.7g\" x\n | 8 -> sprintf \"%.8g\" x\n | 9 -> sprintf \"%.9g\" x\n | 10 -> sprintf \"%.10g\" x\n | 11 -> sprintf \"%.11g\" x\n | 12 -> sprintf \"%.12g\" x\n | 13 -> sprintf \"%.13g\" x\n | 14 -> sprintf \"%.14g\" x\n | 15 -> sprintf \"%.15g\" x\n | 16 -> sprintf \"%.16g\" x\n | _ -> sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_float ob x;\n Bi_outbuf.contents ob\n\n\nlet write_std_float_fast ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet std_json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_std_float ob x;\n Bi_outbuf.contents ob\n\n\nlet test_float () =\n let l = [ 0.; 1.; -1. ] in\n let l = l @ List.map (fun x -> 2. *. x +. 1.) l in\n let l = l @ List.map (fun x -> x /. sqrt 2.) l in\n let l = l @ List.map (fun x -> x *. sqrt 3.) l in\n let l = l @ List.map cos l in\n let l = l @ List.map (fun x -> x *. 1.23e50) l in\n let l = l @ [ infinity; neg_infinity ] in\n List.iter (\n fun x ->\n let s = Printf.sprintf \"%.17g\" x in\n let y = float_of_string s in\n Printf.printf \"%g %g %S %B\\n\" x y s (x = y)\n )\n l\n\n(*\nlet () = test_float ()\n*)\n\nlet write_intlit = Bi_outbuf.add_string\nlet write_floatlit = Bi_outbuf.add_string\nlet write_stringlit = Bi_outbuf.add_string\n\nlet rec iter2_aux f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_sep x;\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet iter2 f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet f_sep ob =\n Bi_outbuf.add_char ob ','\n\nlet rec write_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 299 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 302 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 305 \"write.ml\"\n | `Float f -> write_float ob f\n \n# 308 \"write.ml\"\n | `Floatlit s -> Bi_outbuf.add_string ob s\n \n# 311 \"write.ml\"\n | `String s -> write_string ob s\n \n# 314 \"write.ml\"\n | `Stringlit s -> Bi_outbuf.add_string ob s\n \n# 316 \"write.ml\"\n | `Assoc l -> write_assoc ob l\n | `List l -> write_list ob l\n \n# 319 \"write.ml\"\n | `Tuple l -> write_tuple ob l\n \n# 322 \"write.ml\"\n | `Variant (s, o) -> write_variant ob s o\n\n# 325 \"write.ml\"\nand write_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 341 \"write.ml\"\nand write_tuple ob l =\n Bi_outbuf.add_char ob '(';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ')'\n\n# 348 \"write.ml\"\nand write_variant ob s o =\n Bi_outbuf.add_char ob '<';\n write_string ob s;\n (match o with\n None -> ()\n | Some x ->\n Bi_outbuf.add_char ob ':';\n write_json ob x\n );\n Bi_outbuf.add_char ob '>'\n\n# 360 \"write.ml\"\nlet write_t = write_json\n\nlet rec write_std_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 367 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 370 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 373 \"write.ml\"\n | `Float f -> write_std_float ob f\n \n# 376 \"write.ml\"\n | `Floatlit s -> Bi_outbuf.add_string ob s\n \n# 379 \"write.ml\"\n | `String s -> write_string ob s\n \n# 382 \"write.ml\"\n | `Stringlit s -> Bi_outbuf.add_string ob s\n \n# 384 \"write.ml\"\n | `Assoc l -> write_std_assoc ob l\n | `List l -> write_std_list ob l\n \n# 387 \"write.ml\"\n | `Tuple l -> write_std_tuple ob l\n \n# 390 \"write.ml\"\n | `Variant (s, o) -> write_std_variant ob s o\n\n# 393 \"write.ml\"\nand write_std_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_std_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_std_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\nand write_std_tuple ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 414 \"write.ml\"\nand write_std_variant ob s o =\n match o with\n None -> write_string ob s\n | Some x ->\n Bi_outbuf.add_char ob '[';\n write_string ob s;\n Bi_outbuf.add_char ob ',';\n write_std_json ob x;\n Bi_outbuf.add_char ob ']'\n\n\n# 426 \"write.ml\"\nlet to_outbuf ?(std = false) ob x =\n if std then (\n if not (is_object_or_array x) then\n json_error \"Root is not an object or array\"\n else\n write_std_json ob x\n )\n else\n write_json ob x\n\n\nlet to_string ?buf ?(len = 256) ?std x =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n to_outbuf ?std ob x;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet to_channel ?buf ?len ?std oc x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_channel_writer ob\n\nlet to_output ?buf ?len ?std out x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_output_writer ?len out\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_output_writer ob\n\nlet to_file ?len ?std file x =\n let oc = open_out file in\n try\n to_channel ?len ?std oc x;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\nlet stream_to_outbuf ?std ob st =\n Stream.iter (to_outbuf ?std ob) st\n\nlet stream_to_string ?buf ?(len = 256) ?std st =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n stream_to_outbuf ?std ob st;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet stream_to_channel ?buf ?len ?std oc st =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n stream_to_outbuf ?std ob st;\n Bi_outbuf.flush_channel_writer ob\n\nlet stream_to_file ?len ?std file st =\n let oc = open_out file in\n try\n stream_to_channel ?len ?std oc st;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\n\nlet rec sort = function\n | `Assoc l ->\n let l = List.rev (List.rev_map (fun (k, v) -> (k, sort v)) l) in\n `Assoc (List.stable_sort (fun (a, _) (b, _) -> String.compare a b) l)\n | `List l ->\n `List (List.rev (List.rev_map sort l))\n \n# 519 \"write.ml\"\n | `Tuple l ->\n `Tuple (List.rev (List.rev_map sort l))\n \n# 523 \"write.ml\"\n | `Variant (k, Some v) as x ->\n let v' = sort v in\n if v == v' then x\n else\n `Variant (k, Some v')\n \n# 529 \"write.ml\"\n | x -> x\n# 1 \"monomorphic.ml\"\nlet rec pp fmt =\n function\n | `Null -> Format.pp_print_string fmt \"`Null\"\n | `Bool x ->\n Format.fprintf fmt \"`Bool (@[\";\n Format.fprintf fmt \"%B\" x;\n Format.fprintf fmt \"@])\"\n \n# 9 \"monomorphic.ml\"\n | `Int x ->\n Format.fprintf fmt \"`Int (@[\";\n Format.fprintf fmt \"%d\" x;\n Format.fprintf fmt \"@])\"\n \n# 15 \"monomorphic.ml\"\n | `Intlit x ->\n Format.fprintf fmt \"`Intlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 21 \"monomorphic.ml\"\n | `Float x ->\n Format.fprintf fmt \"`Float (@[\";\n Format.fprintf fmt \"%F\" x;\n Format.fprintf fmt \"@])\"\n \n# 27 \"monomorphic.ml\"\n | `Floatlit x ->\n Format.fprintf fmt \"`Floatlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 33 \"monomorphic.ml\"\n | `String x ->\n Format.fprintf fmt \"`String (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 39 \"monomorphic.ml\"\n | `Stringlit x ->\n Format.fprintf fmt \"`Stringlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 44 \"monomorphic.ml\"\n | `Assoc xs ->\n Format.fprintf fmt \"`Assoc (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep (key, value) ->\n if sep then\n Format.fprintf fmt \";@ \";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" key;\n Format.fprintf fmt \",@ \";\n pp fmt value;\n Format.fprintf fmt \"@])\";\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n | `List xs ->\n Format.fprintf fmt \"`List (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep x ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt x;\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 71 \"monomorphic.ml\"\n | `Tuple tup ->\n Format.fprintf fmt \"`Tuple (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep e ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt e;\n true) false tup);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 84 \"monomorphic.ml\"\n | `Variant (name, value) ->\n Format.fprintf fmt \"`Variant (@[\";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" name;\n Format.fprintf fmt \",@ \";\n (match value with\n | None -> Format.pp_print_string fmt \"None\"\n | Some x ->\n Format.pp_print_string fmt \"(Some \";\n pp fmt x;\n Format.pp_print_string fmt \")\");\n Format.fprintf fmt \"@])\";\n Format.fprintf fmt \"@])\"\n\n# 99 \"monomorphic.ml\"\nlet show x =\n Format.asprintf \"%a\" pp x\n\nlet rec equal a b =\n match a, b with\n | `Null, `Null -> true\n | `Bool a, `Bool b -> a = b\n \n# 107 \"monomorphic.ml\"\n | `Int a, `Int b -> a = b\n \n# 110 \"monomorphic.ml\"\n | `Intlit a, `Intlit b -> a = b\n \n# 113 \"monomorphic.ml\"\n | `Float a, `Float b -> a = b\n \n# 116 \"monomorphic.ml\"\n | `Floatlit a, `Floatlit b -> a = b\n \n# 119 \"monomorphic.ml\"\n | `String a, `String b -> a = b\n \n# 122 \"monomorphic.ml\"\n | `Stringlit a, `Stringlit b -> a = b\n \n# 124 \"monomorphic.ml\"\n | `Assoc xs, `Assoc ys ->\n let compare_keys = fun (key, _) (key', _) -> String.compare key key' in\n let xs = List.stable_sort compare_keys xs in\n let ys = List.stable_sort compare_keys ys in\n (match List.for_all2 (fun (key, value) (key', value') ->\n match key = key' with\n | false -> false\n | true -> equal value value') xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 137 \"monomorphic.ml\"\n | `Tuple xs, `Tuple ys\n \n# 139 \"monomorphic.ml\"\n | `List xs, `List ys ->\n (match List.for_all2 equal xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 146 \"monomorphic.ml\"\n | `Variant (name, value), `Variant (name', value') ->\n (match name = name' with\n | false -> false\n | true ->\n match value, value' with\n | None, None -> true\n | Some x, Some y -> equal x y\n | _ -> false)\n \n# 155 \"monomorphic.ml\"\n | _ -> false\n# 15 \"yojson.cppo.ml\"\nmodule Pretty =\nstruct\n# 1 \"pretty.ml\"\nopen Printf\n\nlet array = Easy_format.list\nlet record = Easy_format.list\nlet tuple = { Easy_format.list with\n space_after_opening = false;\n space_before_closing = false;\n align_closing = false }\nlet variant = { Easy_format.list with\n space_before_closing = false; }\n\nlet rec format std (x : t) =\n match x with\n `Null -> Easy_format.Atom (\"null\", Easy_format.atom)\n | `Bool x -> Easy_format.Atom ((if x then \"true\" else \"false\"), Easy_format.atom)\n | `Int x -> Easy_format.Atom (json_string_of_int x, Easy_format.atom)\n | `Float x ->\n let s =\n if std then std_json_string_of_float x\n else json_string_of_float x\n in\n Easy_format.Atom (s, Easy_format.atom)\n | `String s -> Easy_format.Atom (json_string_of_string s, Easy_format.atom)\n | `Intlit s\n | `Floatlit s\n | `Stringlit s -> Easy_format.Atom (s, Easy_format.atom)\n | `List [] -> Easy_format.Atom (\"[]\", Easy_format.atom)\n | `List l -> Easy_format.List ((\"[\", \",\", \"]\", array), List.map (format std) l)\n | `Assoc [] -> Easy_format.Atom (\"{}\", Easy_format.atom)\n | `Assoc l -> Easy_format.List ((\"{\", \",\", \"}\", record), List.map (format_field std) l)\n | `Tuple l ->\n if std then\n format std (`List l)\n else\n if l = [] then\n Easy_format.Atom (\"()\", Easy_format.atom)\n else\n Easy_format.List ((\"(\", \",\", \")\", tuple), List.map (format std) l)\n\n | `Variant (s, None) ->\n if std then\n format std (`String s)\n else\n Easy_format.Atom (\"<\" ^ json_string_of_string s ^ \">\", Easy_format.atom)\n\n | `Variant (s, Some x) ->\n if std then\n format std (`List [ `String s; x ])\n else\n let op = \"<\" ^ json_string_of_string s ^ \":\" in\n Easy_format.List ((op, \"\", \">\", variant), [format std x])\n\nand format_field std (name, x) =\n let s = sprintf \"%s:\" (json_string_of_string name) in\n Easy_format.Label ((Easy_format.Atom (s, Easy_format.atom), Easy_format.label), format std x)\n\n\nlet format ?(std = false) x =\n if std && not (is_object_or_array x) then\n json_error\n \"Root is not an object or array as requested by the JSON standard\"\n else\n format std (x :> t)\n\nlet to_string ?std x =\n Easy_format.Pretty.to_string (format ?std x)\n\nlet to_channel ?std oc x =\n Easy_format.Pretty.to_channel oc (format ?std x)\n# 18 \"yojson.cppo.ml\"\nend\n# 1 \"write2.ml\"\nlet pretty_format ?std (x : t) =\n Pretty.format ?std (x :> json_max)\n\nlet pretty_print ?std out (x : t) =\n Easy_format.Pretty.to_formatter out (pretty_format ?std x)\n\nlet pretty_to_string ?std (x : t) =\n Pretty.to_string ?std (x :> json_max)\n\nlet pretty_to_channel ?std oc (x : t) =\n Pretty.to_channel ?std oc (x :> json_max)\n\n# 29 \"yojson.cppo.ml\"\nmodule Basic =\nstruct\n# 1 \"type.ml\"\n(** {3 Type of the JSON tree} *)\n\ntype t =\n [\n | `Null\n | `Bool of bool\n \n# 8 \"type.ml\"\n | `Int of int\n \n# 14 \"type.ml\"\n | `Float of float\n \n# 20 \"type.ml\"\n | `String of string\n \n# 25 \"type.ml\"\n | `Assoc of (string * t) list\n | `List of t list\n \n# 33 \"type.ml\"\n ]\n(**\nAll possible cases defined in Yojson:\n- `Null: JSON null\n- `Bool of bool: JSON boolean\n- `Int of int: JSON number without decimal point or exponent.\n- `Intlit of string: JSON number without decimal point or exponent,\n\t preserved as a string.\n- `Float of float: JSON number, Infinity, -Infinity or NaN.\n- `Floatlit of string: JSON number, Infinity, -Infinity or NaN,\n\t preserved as a string.\n- `String of string: JSON string. Bytes in the range 128-255 are preserved\n\t as-is without encoding validation for both reading\n\t and writing.\n- `Stringlit of string: JSON string literal including the double quotes.\n- `Assoc of (string * json) list: JSON object.\n- `List of json list: JSON array.\n- `Tuple of json list: Tuple (non-standard extension of JSON).\n\t Syntax: [(\"abc\", 123)].\n- `Variant of (string * json option): Variant (non-standard extension of JSON).\n\t Syntax: [<\"Foo\">] or [<\"Bar\":123>].\n*)\n\ntype json = t [@@deprecated \"json types are being renamed and will be removed in the next Yojson major version. Use type t instead\"]\n(**\n * Compatibility type alias for type `t`\n *)\n\n(*\n Note to adventurers: ocamldoc does not support inline comments\n on each polymorphic variant, and cppo doesn't allow to concatenate\n comments, so it would be complicated to document only the\n cases that are preserved by cppo in the type definition.\n*)\n# 1 \"write.ml\"\n(* included: type.ml *)\n\nlet hex n =\n Char.chr (\n if n < 10 then n + 48\n else n + 87\n )\n\nlet write_special src start stop ob str =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n Bi_outbuf.add_string ob str;\n start := stop + 1\n\nlet write_control_char src start stop ob c =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n let i = Bi_outbuf.alloc ob 6 in\n let dst = ob.o_s in\n Bytes.blit_string \"\\\\u00\" 0 dst i 4;\n Bytes.set dst (i+4) (hex (Char.code c lsr 4));\n Bytes.set dst (i+5) (hex (Char.code c land 0xf));\n start := stop + 1\n\nlet finish_string src start ob =\n try\n Bi_outbuf.add_substring ob src !start (String.length src - !start)\n with exc ->\n Printf.eprintf \"src=%S start=%i len=%i\\n%!\"\n src !start (String.length src - !start);\n raise exc\n\nlet write_string_body ob s =\n let start = ref 0 in\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '\"' -> write_special s start i ob \"\\\\\\\"\"\n | '\\\\' -> write_special s start i ob \"\\\\\\\\\"\n | '\\b' -> write_special s start i ob \"\\\\b\"\n | '\\012' -> write_special s start i ob \"\\\\f\"\n | '\\n' -> write_special s start i ob \"\\\\n\"\n | '\\r' -> write_special s start i ob \"\\\\r\"\n | '\\t' -> write_special s start i ob \"\\\\t\"\n | '\\x00'..'\\x1F'\n | '\\x7F' as c -> write_control_char s start i ob c\n | _ -> ()\n done;\n finish_string s start ob\n\nlet write_string ob s =\n Bi_outbuf.add_char ob '\"';\n write_string_body ob s;\n Bi_outbuf.add_char ob '\"'\n\nlet json_string_of_string s =\n let ob = Bi_outbuf.create 10 in\n write_string ob s;\n Bi_outbuf.contents ob\n\nlet test_string () =\n let s = Bytes.create 256 in\n for i = 0 to 255 do\n Bytes.set s i (Char.chr i)\n done;\n json_string_of_string (Bytes.to_string s)\n\n\nlet write_null ob () =\n Bi_outbuf.add_string ob \"null\"\n\nlet write_bool ob x =\n Bi_outbuf.add_string ob (if x then \"true\" else \"false\")\n\n\nlet max_digits =\n max\n (String.length (string_of_int max_int))\n (String.length (string_of_int min_int))\n\nlet dec n =\n Char.chr (n + 48)\n\nlet rec write_digits s pos x =\n if x = 0 then pos\n else\n let d = x mod 10 in\n let pos = write_digits s pos (x / 10) in\n Bytes.set s pos (dec (abs d));\n pos + 1\n\nlet write_int ob x =\n Bi_outbuf.extend ob max_digits;\n if x > 0 then\n ob.o_len <- write_digits ob.o_s ob.o_len x\n else if x < 0 then (\n let s = ob.o_s in\n let pos = ob.o_len in\n Bytes.set s pos '-';\n ob.o_len <- write_digits s (pos + 1) x\n )\n else\n Bi_outbuf.add_char ob '0'\n\n\nlet json_string_of_int i =\n string_of_int i\n\n\n(*\n Ensure that the float is not printed as an int.\n This is not required by JSON, but useful in order to guarantee\n reversibility.\n*)\nlet float_needs_period s =\n try\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '0'..'9' | '-' -> ()\n | _ -> raise Exit\n done;\n true\n with Exit ->\n false\n\n(*\n Both write_float_fast and write_float guarantee\n that a sufficient number of digits are printed in order to\n allow reversibility.\n\n The _fast version is faster but often produces unnecessarily long numbers.\n*)\nlet write_float_fast ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_normal_float_prec significant_figures ob x =\n let open Printf in\n let s =\n match significant_figures with\n 1 -> sprintf \"%.1g\" x\n | 2 -> sprintf \"%.2g\" x\n | 3 -> sprintf \"%.3g\" x\n | 4 -> sprintf \"%.4g\" x\n | 5 -> sprintf \"%.5g\" x\n | 6 -> sprintf \"%.6g\" x\n | 7 -> sprintf \"%.7g\" x\n | 8 -> sprintf \"%.8g\" x\n | 9 -> sprintf \"%.9g\" x\n | 10 -> sprintf \"%.10g\" x\n | 11 -> sprintf \"%.11g\" x\n | 12 -> sprintf \"%.12g\" x\n | 13 -> sprintf \"%.13g\" x\n | 14 -> sprintf \"%.14g\" x\n | 15 -> sprintf \"%.15g\" x\n | 16 -> sprintf \"%.16g\" x\n | _ -> sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_float ob x;\n Bi_outbuf.contents ob\n\n\nlet write_std_float_fast ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet std_json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_std_float ob x;\n Bi_outbuf.contents ob\n\n\nlet test_float () =\n let l = [ 0.; 1.; -1. ] in\n let l = l @ List.map (fun x -> 2. *. x +. 1.) l in\n let l = l @ List.map (fun x -> x /. sqrt 2.) l in\n let l = l @ List.map (fun x -> x *. sqrt 3.) l in\n let l = l @ List.map cos l in\n let l = l @ List.map (fun x -> x *. 1.23e50) l in\n let l = l @ [ infinity; neg_infinity ] in\n List.iter (\n fun x ->\n let s = Printf.sprintf \"%.17g\" x in\n let y = float_of_string s in\n Printf.printf \"%g %g %S %B\\n\" x y s (x = y)\n )\n l\n\n(*\nlet () = test_float ()\n*)\n\nlet write_intlit = Bi_outbuf.add_string\nlet write_floatlit = Bi_outbuf.add_string\nlet write_stringlit = Bi_outbuf.add_string\n\nlet rec iter2_aux f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_sep x;\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet iter2 f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet f_sep ob =\n Bi_outbuf.add_char ob ','\n\nlet rec write_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 299 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 305 \"write.ml\"\n | `Float f -> write_float ob f\n \n# 311 \"write.ml\"\n | `String s -> write_string ob s\n \n# 316 \"write.ml\"\n | `Assoc l -> write_assoc ob l\n | `List l -> write_list ob l\n\n# 325 \"write.ml\"\nand write_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n\n\n# 360 \"write.ml\"\nlet write_t = write_json\n\nlet rec write_std_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 367 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 373 \"write.ml\"\n | `Float f -> write_std_float ob f\n \n# 379 \"write.ml\"\n | `String s -> write_string ob s\n \n# 384 \"write.ml\"\n | `Assoc l -> write_std_assoc ob l\n | `List l -> write_std_list ob l\n\n# 393 \"write.ml\"\nand write_std_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_std_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_std_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\nand write_std_tuple ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n\n\n# 426 \"write.ml\"\nlet to_outbuf ?(std = false) ob x =\n if std then (\n if not (is_object_or_array x) then\n json_error \"Root is not an object or array\"\n else\n write_std_json ob x\n )\n else\n write_json ob x\n\n\nlet to_string ?buf ?(len = 256) ?std x =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n to_outbuf ?std ob x;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet to_channel ?buf ?len ?std oc x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_channel_writer ob\n\nlet to_output ?buf ?len ?std out x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_output_writer ?len out\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_output_writer ob\n\nlet to_file ?len ?std file x =\n let oc = open_out file in\n try\n to_channel ?len ?std oc x;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\nlet stream_to_outbuf ?std ob st =\n Stream.iter (to_outbuf ?std ob) st\n\nlet stream_to_string ?buf ?(len = 256) ?std st =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n stream_to_outbuf ?std ob st;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet stream_to_channel ?buf ?len ?std oc st =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n stream_to_outbuf ?std ob st;\n Bi_outbuf.flush_channel_writer ob\n\nlet stream_to_file ?len ?std file st =\n let oc = open_out file in\n try\n stream_to_channel ?len ?std oc st;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\n\nlet rec sort = function\n | `Assoc l ->\n let l = List.rev (List.rev_map (fun (k, v) -> (k, sort v)) l) in\n `Assoc (List.stable_sort (fun (a, _) (b, _) -> String.compare a b) l)\n | `List l ->\n `List (List.rev (List.rev_map sort l))\n \n# 529 \"write.ml\"\n | x -> x\n# 1 \"monomorphic.ml\"\nlet rec pp fmt =\n function\n | `Null -> Format.pp_print_string fmt \"`Null\"\n | `Bool x ->\n Format.fprintf fmt \"`Bool (@[\";\n Format.fprintf fmt \"%B\" x;\n Format.fprintf fmt \"@])\"\n \n# 9 \"monomorphic.ml\"\n | `Int x ->\n Format.fprintf fmt \"`Int (@[\";\n Format.fprintf fmt \"%d\" x;\n Format.fprintf fmt \"@])\"\n \n# 21 \"monomorphic.ml\"\n | `Float x ->\n Format.fprintf fmt \"`Float (@[\";\n Format.fprintf fmt \"%F\" x;\n Format.fprintf fmt \"@])\"\n \n# 33 \"monomorphic.ml\"\n | `String x ->\n Format.fprintf fmt \"`String (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 44 \"monomorphic.ml\"\n | `Assoc xs ->\n Format.fprintf fmt \"`Assoc (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep (key, value) ->\n if sep then\n Format.fprintf fmt \";@ \";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" key;\n Format.fprintf fmt \",@ \";\n pp fmt value;\n Format.fprintf fmt \"@])\";\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n | `List xs ->\n Format.fprintf fmt \"`List (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep x ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt x;\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n\n# 99 \"monomorphic.ml\"\nlet show x =\n Format.asprintf \"%a\" pp x\n\nlet rec equal a b =\n match a, b with\n | `Null, `Null -> true\n | `Bool a, `Bool b -> a = b\n \n# 107 \"monomorphic.ml\"\n | `Int a, `Int b -> a = b\n \n# 113 \"monomorphic.ml\"\n | `Float a, `Float b -> a = b\n \n# 119 \"monomorphic.ml\"\n | `String a, `String b -> a = b\n \n# 124 \"monomorphic.ml\"\n | `Assoc xs, `Assoc ys ->\n let compare_keys = fun (key, _) (key', _) -> String.compare key key' in\n let xs = List.stable_sort compare_keys xs in\n let ys = List.stable_sort compare_keys ys in\n (match List.for_all2 (fun (key, value) (key', value') ->\n match key = key' with\n | false -> false\n | true -> equal value value') xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 139 \"monomorphic.ml\"\n | `List xs, `List ys ->\n (match List.for_all2 equal xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 155 \"monomorphic.ml\"\n | _ -> false\n# 1 \"write2.ml\"\nlet pretty_format ?std (x : t) =\n Pretty.format ?std (x :> json_max)\n\nlet pretty_print ?std out (x : t) =\n Easy_format.Pretty.to_formatter out (pretty_format ?std x)\n\nlet pretty_to_string ?std (x : t) =\n Pretty.to_string ?std (x :> json_max)\n\nlet pretty_to_channel ?std oc (x : t) =\n Pretty.to_channel ?std oc (x :> json_max)\n\n# 1 \"lib/read.mll\"\n \n \n# 2 \"lib/read.mll\"\n module Lexing =\n (*\n We override Lexing.engine in order to avoid creating a new position\n record each time a rule is matched.\n This reduces total parsing time by about 31%.\n *)\n struct\n include Lexing\n\n external c_engine : lex_tables -> int -> lexbuf -> int = \"caml_lex_engine\"\n\n let engine tbl state buf =\n let result = c_engine tbl state buf in\n (*\n if result >= 0 then begin\n buf.lex_start_p <- buf.lex_curr_p;\n buf.lex_curr_p <- {buf.lex_curr_p\n with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n end;\n *)\n result\n end\n\n open Printf\n open Lexing\n\n (* see description in common.mli *)\n type lexer_state = Lexer_state.t = {\n buf : Bi_outbuf.t;\n mutable lnum : int;\n mutable bol : int;\n mutable fname : string option;\n }\n\n let dec c =\n Char.code c - 48\n\n let hex c =\n match c with\n '0'..'9' -> int_of_char c - int_of_char '0'\n | 'a'..'f' -> int_of_char c - int_of_char 'a' + 10\n | 'A'..'F' -> int_of_char c - int_of_char 'A' + 10\n | _ -> assert false\n\n let custom_error descr v lexbuf =\n let offs = lexbuf.lex_abs_pos - 1 in\n let bol = v.bol in\n let pos1 = offs + lexbuf.lex_start_pos - bol - 1 in\n let pos2 = max pos1 (offs + lexbuf.lex_curr_pos - bol) in\n let file_line =\n match v.fname with\n None -> \"Line\"\n | Some s ->\n sprintf \"File %s, line\" s\n in\n let bytes =\n if pos1 = pos2 then\n sprintf \"byte %i\" (pos1+1)\n else\n sprintf \"bytes %i-%i\" (pos1+1) (pos2+1)\n in\n let msg = sprintf \"%s %i, %s:\\n%s\" file_line v.lnum bytes descr in\n json_error msg\n\n\n let lexer_error descr v lexbuf =\n custom_error\n (sprintf \"%s '%s'\" descr (Lexing.lexeme lexbuf))\n v lexbuf\n\n let read_junk = ref (fun _ -> assert false)\n\n let long_error descr v lexbuf =\n let junk = Lexing.lexeme lexbuf in\n let extra_junk = !read_junk lexbuf in\n custom_error\n (sprintf \"%s '%s%s'\" descr junk extra_junk)\n v lexbuf\n\n let min10 = min_int / 10 - (if min_int mod 10 = 0 then 0 else 1)\n let max10 = max_int / 10 + (if max_int mod 10 = 0 then 0 else 1)\n\n exception Int_overflow\n\n let extract_positive_int lexbuf =\n let start = lexbuf.lex_start_pos in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n >= max10 then\n raise Int_overflow\n else\n n := 10 * !n + dec (Bytes.get s i)\n done;\n if !n < 0 then\n raise Int_overflow\n else\n !n\n\n let make_positive_int v lexbuf =\n \n# 104 \"lib/read.mll\"\n try `Int (extract_positive_int lexbuf)\n with Int_overflow ->\n \n# 110 \"lib/read.mll\"\n lexer_error \"Int overflow\" v lexbuf\n\n \n# 113 \"lib/read.mll\"\n let extract_negative_int lexbuf =\n let start = lexbuf.lex_start_pos + 1 in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n <= min10 then\n raise Int_overflow\n else\n n := 10 * !n - dec (Bytes.get s i)\n done;\n if !n > 0 then\n raise Int_overflow\n else\n !n\n\n let make_negative_int v lexbuf =\n \n# 131 \"lib/read.mll\"\n try `Int (extract_negative_int lexbuf)\n with Int_overflow ->\n \n# 137 \"lib/read.mll\"\n lexer_error \"Int overflow\" v lexbuf\n\n\n \n# 141 \"lib/read.mll\"\n let set_file_name v fname =\n v.fname <- fname\n\n let newline v lexbuf =\n v.lnum <- v.lnum + 1;\n v.bol <- lexbuf.lex_abs_pos + lexbuf.lex_curr_pos\n\n let add_lexeme buf lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n Bi_outbuf.add_subbytes buf lexbuf.lex_buffer lexbuf.lex_start_pos len\n\n let map_lexeme f lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n f (Bytes.to_string lexbuf.lex_buffer) lexbuf.lex_start_pos len\n\n type variant_kind = [ `Edgy_bracket | `Square_bracket | `Double_quote ]\n type tuple_kind = [ `Parenthesis | `Square_bracket ]\n\n\n# 161 \"lib/read.ml\"\n# 161 \"lib/read.ml\"\nlet __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\236\\255\\237\\255\\003\\000\\239\\255\\016\\000\\242\\255\\243\\255\\\n \\244\\255\\245\\255\\000\\000\\031\\000\\249\\255\\085\\000\\001\\000\\000\\000\\\n \\000\\000\\001\\000\\000\\000\\001\\000\\002\\000\\255\\255\\000\\000\\000\\000\\\n \\003\\000\\254\\255\\001\\000\\004\\000\\253\\255\\011\\000\\252\\255\\003\\000\\\n \\001\\000\\003\\000\\002\\000\\003\\000\\000\\000\\251\\255\\021\\000\\097\\000\\\n \\010\\000\\022\\000\\020\\000\\016\\000\\022\\000\\012\\000\\008\\000\\250\\255\\\n \\119\\000\\129\\000\\139\\000\\161\\000\\171\\000\\181\\000\\193\\000\\209\\000\\\n \\240\\255\\011\\000\\038\\000\\252\\255\\065\\000\\254\\255\\255\\255\\110\\000\\\n \\252\\255\\163\\000\\254\\255\\255\\255\\234\\000\\247\\255\\248\\255\\048\\001\\\n \\250\\255\\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\071\\001\\126\\001\\\n \\149\\001\\249\\255\\039\\000\\253\\255\\254\\255\\038\\000\\187\\001\\210\\001\\\n \\248\\001\\015\\002\\255\\255\\220\\000\\253\\255\\255\\255\\245\\000\\039\\002\\\n \\109\\002\\014\\001\\088\\002\\164\\002\\187\\002\\225\\002\\013\\000\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\014\\000\\253\\255\\254\\255\\255\\255\\030\\000\\\n \\253\\255\\254\\255\\255\\255\\015\\000\\253\\255\\254\\255\\255\\255\\017\\001\\\n \\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\019\\000\\252\\255\\253\\255\\\n \\254\\255\\015\\000\\255\\255\\016\\000\\255\\255\\008\\001\\005\\000\\253\\255\\\n \\023\\000\\254\\255\\020\\000\\255\\255\\046\\000\\253\\255\\254\\255\\042\\000\\\n \\052\\000\\053\\000\\255\\255\\053\\000\\048\\000\\091\\000\\092\\000\\255\\255\\\n \\027\\001\\250\\255\\251\\255\\137\\000\\104\\000\\089\\000\\088\\000\\106\\000\\\n \\255\\255\\143\\000\\137\\000\\177\\000\\254\\255\\183\\000\\168\\000\\166\\000\\\n \\183\\000\\002\\000\\253\\255\\177\\000\\172\\000\\187\\000\\004\\000\\252\\255\\\n \\053\\002\\251\\255\\252\\255\\253\\255\\103\\001\\255\\255\\248\\002\\254\\255\\\n \\006\\003\\030\\003\\252\\255\\253\\255\\254\\255\\255\\255\\040\\003\\050\\003\\\n \\074\\003\\252\\255\\253\\255\\254\\255\\255\\255\\061\\003\\084\\003\\108\\003\\\n \\249\\255\\250\\255\\251\\255\\244\\000\\120\\003\\142\\003\\179\\000\\194\\000\\\n \\015\\000\\255\\255\\190\\000\\188\\000\\187\\000\\193\\000\\183\\000\\179\\000\\\n \\254\\255\\191\\000\\201\\000\\200\\000\\196\\000\\203\\000\\193\\000\\189\\000\\\n \\253\\255\\157\\003\\095\\003\\174\\003\\196\\003\\206\\003\\216\\003\\228\\003\\\n \\239\\003\\060\\000\\253\\255\\254\\255\\255\\255\\012\\004\\252\\255\\253\\255\\\n \\087\\004\\255\\255\\145\\004\\252\\255\\253\\255\\221\\004\\255\\255\\229\\000\\\n \\253\\255\\254\\255\\255\\255\\231\\000\\253\\255\\254\\255\\255\\255\\002\\000\\\n \\255\\255\\018\\001\\252\\255\\253\\255\\254\\255\\255\\255\\034\\001\\253\\255\\\n \\254\\255\\255\\255\\000\\000\\255\\255\\003\\000\\254\\255\\255\\255\\038\\001\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\120\\001\\251\\255\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\208\\000\\253\\255\\254\\255\\255\\255\\211\\000\\253\\255\\\n \\254\\255\\255\\255\\189\\000\\255\\255\\143\\001\\252\\255\\253\\255\\254\\255\\\n \\255\\255\\013\\001\\253\\255\\254\\255\\255\\255\\095\\001\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\050\\001\\253\\255\\254\\255\\255\\255\\026\\001\\253\\255\\\n \\254\\255\\255\\255\\233\\000\\253\\255\\254\\255\\255\\255\\222\\000\\253\\255\\\n \\254\\255\\255\\255\\079\\005\\237\\255\\238\\255\\010\\000\\240\\255\\044\\001\\\n \\243\\255\\244\\255\\245\\255\\246\\255\\061\\001\\002\\004\\249\\255\\045\\005\\\n \\209\\000\\228\\000\\211\\000\\232\\000\\225\\000\\223\\000\\240\\000\\255\\255\\\n \\235\\000\\234\\000\\008\\001\\254\\255\\004\\001\\023\\001\\253\\255\\054\\001\\\n \\252\\255\\031\\001\\029\\001\\032\\001\\039\\001\\049\\001\\045\\001\\251\\255\\\n \\057\\001\\082\\001\\080\\001\\078\\001\\084\\001\\074\\001\\086\\001\\250\\255\\\n \\110\\005\\012\\004\\123\\005\\155\\005\\165\\005\\177\\005\\187\\005\\197\\005\\\n \\241\\255\\199\\001\\077\\002\\253\\255\\255\\255\\154\\002\\222\\005\\209\\005\\\n \\155\\002\\239\\005\\053\\006\\076\\006\\114\\006\\016\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\152\\006\\252\\255\\253\\255\\227\\006\\255\\255\\085\\007\\\n \\244\\255\\245\\255\\011\\000\\247\\255\\076\\002\\250\\255\\251\\255\\252\\255\\\n \\253\\255\\254\\255\\031\\002\\243\\005\\051\\007\\100\\001\\115\\001\\104\\001\\\n \\133\\001\\118\\001\\154\\001\\171\\001\\255\\255\\173\\001\\176\\001\\191\\001\\\n \\185\\001\\187\\001\\253\\001\\230\\001\\230\\001\\234\\001\\247\\001\\237\\001\\\n \\234\\001\\009\\002\\019\\002\\019\\002\\015\\002\\021\\002\\011\\002\\007\\002\\\n \\142\\006\\152\\006\\116\\007\\170\\007\\180\\007\\190\\007\\200\\007\\210\\007\\\n \\248\\255\\120\\002\\167\\002\\253\\255\\255\\255\\216\\002\\082\\007\\220\\007\\\n \\236\\002\\244\\007\\058\\008\\081\\008\\119\\008\\076\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\157\\008\\252\\255\\253\\255\\232\\008\\255\\255\\135\\002\\\n \\120\\002\\253\\255\\100\\002\\254\\255\\182\\002\\255\\255\\011\\002\\255\\255\\\n \\204\\002\\252\\255\\253\\255\\254\\255\\255\\255\\046\\002\\255\\255\\178\\002\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\023\\000\\255\\255\\183\\002\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\187\\002\\253\\255\\254\\255\\255\\255\\121\\002\\\n \\253\\255\\254\\255\\255\\255\\184\\002\\252\\255\\253\\255\\254\\255\\019\\000\\\n \\255\\255\\140\\001\\146\\001\\255\\255\\150\\001\\151\\001\\154\\001\\168\\001\\\n \\170\\001\\171\\001\\172\\001\\173\\001\\181\\001\\184\\001\\185\\001\\187\\001\\\n \\191\\001\\193\\001\\195\\001\\196\\001\\197\\001\\200\\001\\203\\001\\223\\001\\\n \\225\\001\\228\\001\\249\\001\\251\\001\\002\\002\\004\\002\\011\\002\\012\\002\\\n \\013\\002\\000\\000\";\n Lexing.lex_backtrk =\n \"\\255\\255\\255\\255\\255\\255\\017\\000\\255\\255\\019\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\008\\000\\008\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\\n \\255\\255\\014\\000\\255\\255\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\003\\000\\255\\255\\001\\000\\255\\255\\004\\000\\003\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\004\\000\\004\\000\\004\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\000\\000\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\003\\000\\005\\000\\005\\000\\005\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\003\\000\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\016\\000\\255\\255\\018\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\\n \\255\\255\\013\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\011\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\000\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\006\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\004\\000\\\n \\003\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\";\n Lexing.lex_default =\n \"\\001\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\057\\000\\060\\000\\000\\000\\060\\000\\000\\000\\000\\000\\065\\000\\\n \\000\\000\\065\\000\\000\\000\\000\\000\\070\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\084\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\094\\000\\000\\000\\000\\000\\097\\000\\255\\255\\\n \\255\\255\\097\\000\\255\\255\\255\\255\\255\\255\\255\\255\\104\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\109\\000\\000\\000\\000\\000\\000\\000\\113\\000\\\n \\000\\000\\000\\000\\000\\000\\117\\000\\000\\000\\000\\000\\000\\000\\121\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\126\\000\\000\\000\\000\\000\\\n \\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\000\\000\\138\\000\\000\\000\\142\\000\\000\\000\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\154\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\178\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\\n \\255\\255\\187\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\194\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\201\\000\\\n \\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\235\\000\\000\\000\\000\\000\\000\\000\\239\\000\\000\\000\\000\\000\\\n \\255\\255\\000\\000\\244\\000\\000\\000\\000\\000\\255\\255\\000\\000\\249\\000\\\n \\000\\000\\000\\000\\000\\000\\253\\000\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\003\\001\\000\\000\\000\\000\\000\\000\\000\\000\\008\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\017\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\022\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\028\\001\\000\\000\\000\\000\\000\\000\\032\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\038\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\043\\001\\000\\000\\000\\000\\000\\000\\047\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\052\\001\\000\\000\\000\\000\\000\\000\\056\\001\\000\\000\\\n \\000\\000\\000\\000\\060\\001\\000\\000\\000\\000\\000\\000\\064\\001\\000\\000\\\n \\000\\000\\000\\000\\067\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\121\\001\\125\\001\\000\\000\\000\\000\\128\\001\\255\\255\\255\\255\\\n \\128\\001\\255\\255\\255\\255\\255\\255\\255\\255\\135\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\140\\001\\000\\000\\000\\000\\255\\255\\000\\000\\144\\001\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\193\\001\\197\\001\\000\\000\\000\\000\\200\\001\\255\\255\\255\\255\\\n \\200\\001\\255\\255\\255\\255\\255\\255\\255\\255\\207\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\212\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\000\\000\\220\\001\\000\\000\\255\\255\\000\\000\\\n \\226\\001\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\233\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\240\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\245\\001\\000\\000\\000\\000\\000\\000\\249\\001\\\n \\000\\000\\000\\000\\000\\000\\252\\001\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\002\\002\\004\\002\\000\\000\\005\\002\\006\\002\\007\\002\\008\\002\\\n \\009\\002\\010\\002\\011\\002\\012\\002\\013\\002\\014\\002\\015\\002\\016\\002\\\n \\017\\002\\018\\002\\019\\002\\020\\002\\021\\002\\022\\002\\023\\002\\024\\002\\\n \\025\\002\\026\\002\\027\\002\\028\\002\\029\\002\\030\\002\\031\\002\\032\\002\\\n \\033\\002\\003\\002\";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\003\\000\\004\\000\\000\\000\\003\\000\\003\\000\\134\\000\\000\\000\\\n \\003\\000\\000\\000\\134\\000\\069\\001\\146\\001\\255\\255\\000\\000\\069\\001\\\n \\146\\001\\000\\000\\000\\000\\000\\000\\000\\000\\127\\000\\139\\000\\000\\000\\\n \\003\\000\\000\\000\\012\\000\\003\\000\\170\\000\\134\\000\\175\\000\\000\\000\\\n \\007\\000\\011\\001\\069\\001\\146\\001\\014\\001\\013\\000\\049\\000\\005\\000\\\n \\010\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\056\\000\\118\\000\\006\\000\\129\\000\\130\\000\\057\\000\\\n \\237\\001\\137\\000\\000\\002\\049\\000\\000\\000\\048\\000\\138\\000\\106\\000\\\n \\062\\000\\014\\000\\110\\000\\105\\000\\000\\000\\049\\000\\015\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\030\\000\\048\\000\\008\\000\\114\\000\\209\\000\\236\\000\\000\\001\\\n \\013\\001\\029\\000\\022\\000\\255\\255\\048\\000\\048\\000\\017\\000\\021\\000\\\n \\025\\000\\032\\000\\033\\000\\035\\000\\023\\000\\027\\000\\016\\000\\031\\000\\\n \\028\\000\\034\\000\\019\\000\\024\\000\\018\\000\\026\\000\\020\\000\\036\\000\\\n \\041\\000\\037\\000\\048\\000\\009\\000\\042\\000\\043\\000\\044\\000\\045\\000\\\n \\046\\000\\047\\000\\061\\000\\085\\000\\048\\000\\038\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\049\\000\\\n \\067\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\086\\000\\143\\000\\255\\255\\040\\000\\144\\000\\\n \\145\\000\\146\\000\\055\\000\\148\\000\\055\\000\\149\\000\\048\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\255\\255\\048\\000\\150\\000\\\n \\151\\000\\161\\000\\066\\000\\158\\000\\053\\000\\159\\000\\053\\000\\160\\000\\\n \\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\165\\000\\\n \\051\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\162\\000\\163\\000\\166\\000\\093\\000\\255\\255\\\n \\002\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\255\\255\\077\\000\\103\\000\\108\\000\\116\\000\\\n \\132\\000\\134\\000\\135\\000\\128\\000\\139\\000\\134\\000\\164\\000\\093\\000\\\n \\171\\000\\077\\000\\167\\000\\168\\000\\169\\000\\172\\000\\112\\000\\173\\000\\\n \\174\\000\\210\\000\\226\\000\\208\\000\\211\\000\\212\\000\\059\\000\\083\\000\\\n \\134\\000\\213\\000\\214\\000\\215\\000\\216\\000\\218\\000\\141\\000\\219\\000\\\n \\093\\000\\220\\000\\221\\000\\123\\000\\222\\000\\223\\000\\224\\000\\136\\000\\\n \\095\\000\\225\\000\\035\\001\\065\\001\\234\\000\\155\\000\\005\\001\\097\\001\\\n \\250\\000\\255\\255\\254\\000\\057\\001\\061\\001\\095\\001\\077\\000\\044\\001\\\n \\092\\001\\088\\001\\009\\001\\029\\001\\076\\000\\124\\000\\033\\001\\018\\001\\\n \\075\\000\\098\\000\\019\\001\\085\\001\\086\\001\\087\\001\\120\\001\\089\\001\\\n \\074\\000\\225\\000\\053\\001\\121\\001\\073\\000\\090\\001\\072\\000\\071\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\098\\000\\113\\001\\122\\000\\091\\001\\064\\000\\004\\001\\\n \\093\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\079\\000\\156\\000\\112\\001\\094\\001\\096\\001\\098\\001\\099\\001\\049\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\100\\001\\157\\000\\\n \\101\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\183\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\184\\000\\024\\001\\112\\001\\255\\255\\025\\001\\102\\001\\103\\001\\105\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\\n \\106\\001\\107\\001\\048\\001\\040\\001\\108\\001\\109\\001\\110\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\081\\000\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\111\\001\\\n \\027\\001\\255\\255\\171\\001\\031\\001\\170\\001\\023\\001\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\092\\000\\168\\001\\063\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\248\\000\\165\\001\\252\\000\\\n \\162\\001\\059\\001\\069\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\255\\255\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\039\\001\\042\\001\\255\\255\\163\\001\\\n \\164\\001\\120\\000\\002\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\166\\001\\055\\001\\153\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\007\\001\\167\\001\\164\\001\\169\\001\\016\\001\\164\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\089\\000\\051\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\090\\000\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\\n \\090\\000\\097\\000\\137\\001\\164\\001\\172\\001\\185\\001\\136\\001\\173\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\097\\000\\179\\000\\\n \\174\\001\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\046\\001\\\n \\175\\001\\176\\001\\180\\000\\164\\001\\184\\001\\181\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\124\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\192\\001\\178\\001\\\n \\021\\001\\179\\001\\097\\000\\193\\001\\180\\001\\181\\001\\182\\001\\183\\001\\\n \\164\\001\\216\\001\\255\\255\\097\\000\\184\\001\\216\\001\\209\\001\\097\\000\\\n \\223\\001\\097\\000\\208\\001\\230\\001\\003\\002\\097\\000\\219\\001\\037\\001\\\n \\216\\001\\217\\001\\003\\002\\220\\001\\216\\001\\097\\000\\003\\002\\003\\002\\\n \\216\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\216\\001\\\n \\003\\002\\126\\001\\003\\002\\003\\002\\003\\002\\003\\002\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\097\\000\\003\\002\\218\\001\\250\\001\\\n \\003\\002\\003\\002\\097\\000\\003\\002\\124\\001\\124\\001\\097\\000\\003\\002\\\n \\221\\001\\003\\002\\253\\001\\003\\002\\003\\002\\003\\002\\097\\000\\255\\255\\\n \\003\\002\\196\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\235\\001\\003\\002\\\n \\241\\001\\003\\002\\255\\001\\242\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\246\\001\\129\\001\\129\\001\\\n \\228\\001\\003\\002\\196\\001\\003\\002\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\003\\002\\198\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\003\\002\\003\\002\\003\\002\\196\\001\\234\\001\\\n \\134\\001\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\097\\000\\097\\000\\097\\000\\000\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\000\\000\\000\\000\\201\\001\\177\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\188\\000\\000\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\201\\001\\227\\001\\000\\000\\191\\000\\206\\001\\123\\001\\189\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\189\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\195\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\198\\000\\\n \\255\\255\\248\\001\\196\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\196\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\202\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\227\\000\\205\\000\\255\\255\\255\\255\\203\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\226\\000\\195\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\232\\001\\000\\000\\000\\000\\206\\000\\221\\001\\239\\001\\\n \\254\\001\\000\\000\\207\\000\\244\\001\\000\\000\\225\\000\\203\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\232\\000\\000\\000\\232\\000\\000\\000\\225\\001\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\217\\000\\\n \\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\225\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\000\\000\\230\\000\\\n \\000\\000\\230\\000\\000\\000\\228\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\000\\000\\228\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\186\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\241\\000\\000\\000\\\n \\113\\001\\000\\000\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\000\\000\\112\\001\\\n \\000\\000\\000\\000\\193\\000\\000\\000\\000\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\112\\001\\\n \\000\\000\\000\\000\\000\\000\\240\\000\\200\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\000\\000\\246\\000\\000\\000\\000\\000\\240\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\245\\000\\000\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\238\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\069\\001\\070\\001\\000\\000\\000\\000\\069\\001\\076\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\069\\001\\\n \\000\\000\\078\\001\\000\\000\\000\\000\\000\\000\\000\\000\\104\\001\\073\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\079\\001\\000\\000\\071\\001\\076\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\000\\000\\000\\000\\072\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\243\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\080\\001\\119\\001\\000\\000\\119\\001\\000\\000\\081\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\000\\000\\000\\000\\074\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\083\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\082\\001\\000\\000\\000\\000\\\n \\115\\001\\000\\000\\000\\000\\084\\001\\000\\000\\000\\000\\117\\001\\000\\000\\\n \\117\\001\\000\\000\\075\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\000\\000\\\n \\115\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\000\\000\\\n \\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\\n \\000\\000\\185\\001\\000\\000\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\184\\001\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\128\\001\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\128\\001\\128\\001\\000\\000\\000\\000\\068\\001\\\n \\128\\001\\128\\001\\128\\001\\127\\001\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\184\\001\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\000\\000\\128\\001\\127\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\128\\001\\128\\001\\128\\001\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\191\\001\\142\\001\\191\\001\\000\\000\\000\\000\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\\n \\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\141\\001\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\146\\001\\147\\001\\\n \\000\\000\\000\\000\\146\\001\\154\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\146\\001\\000\\000\\153\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\177\\001\\150\\001\\000\\000\\000\\000\\\n \\000\\000\\200\\001\\156\\001\\000\\000\\148\\001\\154\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\\n \\000\\000\\149\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\139\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\157\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\158\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\200\\001\\000\\000\\\n \\151\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\187\\001\\000\\000\\160\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\159\\001\\200\\001\\000\\000\\200\\001\\199\\001\\\n \\000\\000\\161\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\152\\001\\000\\000\\000\\000\\000\\000\\000\\000\\189\\001\\000\\000\\189\\001\\\n \\000\\000\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\145\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\\n \\200\\001\\199\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\\n \\200\\001\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\000\\000\\214\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\000\\000\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\211\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\000\\000\\255\\255\\003\\000\\000\\000\\134\\000\\255\\255\\\n \\003\\000\\255\\255\\134\\000\\069\\001\\146\\001\\057\\000\\255\\255\\069\\001\\\n \\146\\001\\255\\255\\255\\255\\255\\255\\255\\255\\125\\000\\138\\000\\255\\255\\\n \\000\\000\\255\\255\\000\\000\\003\\000\\169\\000\\134\\000\\174\\000\\255\\255\\\n \\000\\000\\010\\001\\069\\001\\146\\001\\012\\001\\000\\000\\010\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\005\\000\\115\\000\\000\\000\\125\\000\\129\\000\\005\\000\\\n \\236\\001\\136\\000\\255\\001\\038\\000\\255\\255\\010\\000\\136\\000\\102\\000\\\n \\058\\000\\000\\000\\107\\000\\102\\000\\255\\255\\011\\000\\000\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\029\\000\\038\\000\\000\\000\\111\\000\\208\\000\\233\\000\\255\\000\\\n \\012\\001\\015\\000\\017\\000\\060\\000\\011\\000\\010\\000\\000\\000\\020\\000\\\n \\024\\000\\031\\000\\032\\000\\034\\000\\022\\000\\026\\000\\000\\000\\014\\000\\\n \\027\\000\\033\\000\\018\\000\\023\\000\\000\\000\\016\\000\\019\\000\\035\\000\\\n \\040\\000\\036\\000\\038\\000\\000\\000\\041\\000\\042\\000\\043\\000\\044\\000\\\n \\045\\000\\046\\000\\058\\000\\082\\000\\011\\000\\013\\000\\013\\000\\013\\000\\\n \\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\039\\000\\\n \\063\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\085\\000\\140\\000\\060\\000\\013\\000\\143\\000\\\n \\144\\000\\145\\000\\048\\000\\147\\000\\048\\000\\148\\000\\039\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\065\\000\\039\\000\\149\\000\\\n \\150\\000\\156\\000\\063\\000\\157\\000\\051\\000\\158\\000\\051\\000\\159\\000\\\n \\050\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\155\\000\\\n \\050\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\161\\000\\162\\000\\155\\000\\091\\000\\065\\000\\\n \\000\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\057\\000\\068\\000\\102\\000\\107\\000\\115\\000\\\n \\131\\000\\133\\000\\133\\000\\125\\000\\138\\000\\133\\000\\163\\000\\094\\000\\\n \\165\\000\\068\\000\\166\\000\\167\\000\\168\\000\\171\\000\\111\\000\\172\\000\\\n \\173\\000\\206\\000\\203\\000\\207\\000\\210\\000\\211\\000\\058\\000\\082\\000\\\n \\133\\000\\212\\000\\213\\000\\214\\000\\215\\000\\217\\000\\140\\000\\218\\000\\\n \\097\\000\\219\\000\\220\\000\\119\\000\\221\\000\\222\\000\\223\\000\\133\\000\\\n \\091\\000\\203\\000\\034\\001\\062\\001\\233\\000\\152\\000\\001\\001\\080\\001\\\n \\247\\000\\060\\000\\251\\000\\054\\001\\058\\001\\081\\001\\068\\000\\041\\001\\\n \\082\\001\\083\\001\\006\\001\\026\\001\\068\\000\\119\\000\\030\\001\\015\\001\\\n \\068\\000\\094\\000\\015\\001\\084\\001\\085\\001\\086\\001\\071\\001\\088\\001\\\n \\068\\000\\203\\000\\050\\001\\071\\001\\068\\000\\089\\001\\068\\000\\068\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\097\\000\\076\\001\\119\\000\\090\\001\\063\\000\\001\\001\\\n \\092\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\152\\000\\076\\001\\093\\001\\095\\001\\097\\001\\098\\001\\045\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\099\\001\\152\\000\\\n \\100\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\180\\000\\\n \\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\\n \\180\\000\\020\\001\\076\\001\\065\\000\\020\\001\\101\\001\\102\\001\\104\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\105\\001\\106\\001\\045\\001\\036\\001\\107\\001\\108\\001\\109\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\110\\001\\\n \\026\\001\\121\\001\\157\\001\\030\\001\\158\\001\\020\\001\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\091\\000\\159\\001\\062\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\247\\000\\160\\001\\251\\000\\\n \\161\\001\\058\\001\\068\\000\\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\094\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\036\\001\\041\\001\\097\\000\\162\\001\\\n \\163\\001\\119\\000\\001\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\165\\001\\054\\001\\152\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\006\\001\\166\\001\\167\\001\\168\\001\\015\\001\\169\\001\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\050\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\089\\000\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\095\\000\\133\\001\\170\\001\\171\\001\\154\\001\\133\\001\\172\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\095\\000\\176\\000\\\n \\173\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\045\\001\\\n \\174\\001\\175\\001\\176\\000\\176\\001\\154\\001\\176\\000\\176\\000\\176\\000\\\n \\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\122\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\148\\001\\177\\001\\\n \\020\\001\\178\\001\\098\\000\\148\\001\\179\\001\\180\\001\\181\\001\\182\\001\\\n \\183\\001\\216\\001\\193\\001\\095\\000\\154\\001\\216\\001\\205\\001\\098\\000\\\n \\222\\001\\095\\000\\205\\001\\229\\001\\001\\002\\095\\000\\218\\001\\036\\001\\\n \\215\\001\\215\\001\\002\\002\\218\\001\\215\\001\\095\\000\\004\\002\\005\\002\\\n \\216\\001\\095\\000\\006\\002\\095\\000\\095\\000\\096\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\215\\001\\\n \\007\\002\\122\\001\\008\\002\\009\\002\\010\\002\\011\\002\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\098\\000\\012\\002\\215\\001\\247\\001\\\n \\013\\002\\014\\002\\098\\000\\015\\002\\125\\001\\128\\001\\098\\000\\016\\002\\\n \\220\\001\\017\\002\\251\\001\\018\\002\\019\\002\\020\\002\\098\\000\\121\\001\\\n \\021\\002\\194\\001\\098\\000\\022\\002\\098\\000\\098\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\099\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\231\\001\\023\\002\\\n \\238\\001\\024\\002\\251\\001\\238\\001\\025\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\243\\001\\125\\001\\128\\001\\\n \\224\\001\\026\\002\\197\\001\\027\\002\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\028\\002\\194\\001\\029\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\030\\002\\031\\002\\032\\002\\200\\001\\231\\001\\\n \\133\\001\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\255\\255\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\255\\255\\255\\255\\197\\001\\176\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\185\\000\\255\\255\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\200\\001\\224\\001\\255\\255\\185\\000\\205\\001\\122\\001\\185\\000\\185\\000\\\n \\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\\n \\191\\000\\191\\000\\191\\000\\191\\000\\192\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\192\\000\\\n \\193\\001\\247\\001\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\\n \\192\\000\\192\\000\\192\\000\\192\\000\\198\\000\\198\\000\\198\\000\\198\\000\\\n \\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\199\\000\\226\\000\\\n \\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\\n \\226\\000\\199\\000\\125\\001\\128\\001\\199\\000\\199\\000\\199\\000\\199\\000\\\n \\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\204\\000\\194\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\231\\001\\255\\255\\255\\255\\199\\000\\220\\001\\238\\001\\\n \\251\\001\\255\\255\\199\\000\\243\\001\\255\\255\\204\\000\\205\\000\\205\\000\\\n \\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\\n \\225\\000\\255\\255\\225\\000\\255\\255\\224\\001\\225\\000\\225\\000\\225\\000\\\n \\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\205\\000\\\n \\197\\001\\255\\255\\255\\255\\255\\255\\255\\255\\204\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\200\\001\\255\\255\\255\\255\\228\\000\\\n \\255\\255\\228\\000\\255\\255\\227\\000\\228\\000\\228\\000\\228\\000\\228\\000\\\n \\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\\n \\230\\000\\230\\000\\255\\255\\227\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\185\\000\\232\\000\\\n \\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\\n \\232\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\237\\000\\255\\255\\\n \\077\\001\\255\\255\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\113\\001\\113\\001\\113\\001\\113\\001\\\n \\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\255\\255\\077\\001\\\n \\255\\255\\255\\255\\192\\000\\255\\255\\255\\255\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\077\\001\\\n \\255\\255\\255\\255\\255\\255\\237\\000\\199\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\255\\255\\242\\000\\255\\255\\255\\255\\240\\000\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\242\\000\\255\\255\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\237\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\066\\001\\066\\001\\255\\255\\255\\255\\066\\001\\079\\001\\079\\001\\079\\001\\\n \\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\\n \\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\079\\001\\066\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\066\\001\\066\\001\\\n \\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\\n \\066\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\066\\001\\112\\001\\255\\255\\112\\001\\255\\255\\066\\001\\112\\001\\112\\001\\\n \\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\\n \\255\\255\\255\\255\\066\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\066\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\\n \\114\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\115\\001\\255\\255\\\n \\115\\001\\255\\255\\066\\001\\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\\n \\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\255\\255\\\n \\114\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\\n \\117\\001\\117\\001\\117\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\119\\001\\119\\001\\119\\001\\\n \\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\255\\255\\\n \\126\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\127\\001\\127\\001\\127\\001\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\\n \\255\\255\\155\\001\\255\\255\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\155\\001\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\126\\001\\255\\255\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\129\\001\\126\\001\\255\\255\\255\\255\\066\\001\\\n \\126\\001\\129\\001\\126\\001\\126\\001\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\155\\001\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\255\\255\\129\\001\\129\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\131\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\184\\001\\138\\001\\184\\001\\255\\255\\255\\255\\184\\001\\184\\001\\\n \\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\\n \\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\\n \\185\\001\\185\\001\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\138\\001\\\n \\255\\255\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\141\\001\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\143\\001\\143\\001\\\n \\255\\255\\255\\255\\143\\001\\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\\n \\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\156\\001\\143\\001\\255\\255\\255\\255\\\n \\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\143\\001\\143\\001\\143\\001\\\n \\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\255\\255\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\143\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\198\\001\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\198\\001\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\186\\001\\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\255\\255\\255\\255\\143\\001\\198\\001\\255\\255\\198\\001\\198\\001\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\187\\001\\255\\255\\187\\001\\\n \\255\\255\\186\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\\n \\187\\001\\187\\001\\187\\001\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\189\\001\\189\\001\\\n \\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\\n \\191\\001\\191\\001\\191\\001\\191\\001\\199\\001\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\201\\001\\255\\255\\\n \\201\\001\\201\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\255\\255\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\213\\001\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec read_json v lexbuf =\n __ocaml_lex_read_json_rec v lexbuf 0\nand __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 188 \"lib/read.mll\"\n \n# 188 \"lib/read.mll\"\n ( `Bool true )\n\n# 1032 \"lib/read.ml\"\n\n \n# 1033 \"lib/read.ml\"\n | 1 ->\n\n# 189 \"lib/read.mll\"\n \n# 189 \"lib/read.mll\"\n ( `Bool false )\n\n# 1037 \"lib/read.ml\"\n\n \n# 1038 \"lib/read.ml\"\n | 2 ->\n\n# 190 \"lib/read.mll\"\n \n# 190 \"lib/read.mll\"\n ( `Null )\n\n# 1042 \"lib/read.ml\"\n\n \n# 1043 \"lib/read.ml\"\n | 3 ->\n\n# 191 \"lib/read.mll\"\n \n# 191 \"lib/read.mll\"\n (\n \n# 193 \"lib/read.mll\"\n `Float nan\n \n# 197 \"lib/read.mll\"\n )\n\n# 1053 \"lib/read.ml\"\n\n \n# 1054 \"lib/read.ml\"\n | 4 ->\n\n# 198 \"lib/read.mll\"\n \n# 198 \"lib/read.mll\"\n (\n \n# 200 \"lib/read.mll\"\n `Float infinity\n \n# 204 \"lib/read.mll\"\n )\n\n# 1064 \"lib/read.ml\"\n\n \n# 1065 \"lib/read.ml\"\n | 5 ->\n\n# 205 \"lib/read.mll\"\n \n# 205 \"lib/read.mll\"\n (\n \n# 207 \"lib/read.mll\"\n `Float neg_infinity\n \n# 211 \"lib/read.mll\"\n )\n\n# 1075 \"lib/read.ml\"\n\n \n# 1076 \"lib/read.ml\"\n | 6 ->\n\n# 212 \"lib/read.mll\"\n \n# 212 \"lib/read.mll\"\n (\n \n# 214 \"lib/read.mll\"\n Bi_outbuf.clear v.buf;\n `String (finish_string v lexbuf)\n \n# 219 \"lib/read.mll\"\n )\n\n# 1087 \"lib/read.ml\"\n\n \n# 1088 \"lib/read.ml\"\n | 7 ->\n\n# 220 \"lib/read.mll\"\n \n# 220 \"lib/read.mll\"\n ( make_positive_int v lexbuf )\n\n# 1092 \"lib/read.ml\"\n\n \n# 1093 \"lib/read.ml\"\n | 8 ->\n\n# 221 \"lib/read.mll\"\n \n# 221 \"lib/read.mll\"\n ( make_negative_int v lexbuf )\n\n# 1097 \"lib/read.ml\"\n\n \n# 1098 \"lib/read.ml\"\n | 9 ->\n\n# 222 \"lib/read.mll\"\n \n# 222 \"lib/read.mll\"\n (\n \n# 224 \"lib/read.mll\"\n `Float (float_of_string (lexeme lexbuf))\n \n# 228 \"lib/read.mll\"\n )\n\n# 1108 \"lib/read.ml\"\n\n \n# 1109 \"lib/read.ml\"\n | 10 ->\n\n# 230 \"lib/read.mll\"\n \n# 230 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n done;\n assert false\n with End_of_object ->\n `Assoc (List.rev !acc)\n )\n\n# 1135 \"lib/read.ml\"\n\n \n# 1136 \"lib/read.ml\"\n | 11 ->\n\n# 254 \"lib/read.mll\"\n \n# 254 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_json v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_json v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n `List (List.rev !acc)\n )\n\n# 1154 \"lib/read.ml\"\n\n \n# 1155 \"lib/read.ml\"\n | 12 ->\n\n# 270 \"lib/read.mll\"\n \n# 270 \"lib/read.mll\"\n (\n \n# 287 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 289 \"lib/read.mll\"\n )\n\n# 1178 \"lib/read.ml\"\n\n \n# 1179 \"lib/read.ml\"\n | 13 ->\n\n# 291 \"lib/read.mll\"\n \n# 291 \"lib/read.mll\"\n (\n \n# 298 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 300 \"lib/read.mll\"\n )\n\n# 1192 \"lib/read.ml\"\n\n \n# 1193 \"lib/read.ml\"\n | 14 ->\n\n# 302 \"lib/read.mll\"\n \n# 302 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1197 \"lib/read.ml\"\n\n \n# 1198 \"lib/read.ml\"\n | 15 ->\n\n# 303 \"lib/read.mll\"\n \n# 303 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_json v lexbuf )\n\n# 1202 \"lib/read.ml\"\n\n \n# 1203 \"lib/read.ml\"\n | 16 ->\n\n# 304 \"lib/read.mll\"\n \n# 304 \"lib/read.mll\"\n ( newline v lexbuf; read_json v lexbuf )\n\n# 1207 \"lib/read.ml\"\n\n \n# 1208 \"lib/read.ml\"\n | 17 ->\n\n# 305 \"lib/read.mll\"\n \n# 305 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1212 \"lib/read.ml\"\n\n \n# 1213 \"lib/read.ml\"\n | 18 ->\n\n# 306 \"lib/read.mll\"\n \n# 306 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1217 \"lib/read.ml\"\n\n \n# 1218 \"lib/read.ml\"\n | 19 ->\n\n# 307 \"lib/read.mll\"\n \n# 307 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 1222 \"lib/read.ml\"\n\n \n# 1223 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state\n\nand finish_string v lexbuf =\n __ocaml_lex_finish_string_rec v lexbuf 58\nand __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 311 \"lib/read.mll\"\n \n# 311 \"lib/read.mll\"\n ( Bi_outbuf.contents v.buf )\n\n# 1234 \"lib/read.ml\"\n\n \n# 1235 \"lib/read.ml\"\n | 1 ->\n\n# 312 \"lib/read.mll\"\n \n# 312 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n finish_string v lexbuf )\n\n# 1240 \"lib/read.ml\"\n\n \n# 1241 \"lib/read.ml\"\n | 2 ->\n\n# 314 \"lib/read.mll\"\n \n# 314 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n finish_string v lexbuf )\n\n# 1246 \"lib/read.ml\"\n\n \n# 1247 \"lib/read.ml\"\n | 3 ->\n\n# 316 \"lib/read.mll\"\n \n# 316 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1251 \"lib/read.ml\"\n\n \n# 1252 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state\n\nand map_string v f lexbuf =\n __ocaml_lex_map_string_rec v f lexbuf 63\nand __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 319 \"lib/read.mll\"\n \n# 319 \"lib/read.mll\"\n ( let b = v.buf in\n f (Bytes.to_string b.Bi_outbuf.o_s) 0 b.Bi_outbuf.o_len )\n\n# 1264 \"lib/read.ml\"\n\n \n# 1265 \"lib/read.ml\"\n | 1 ->\n\n# 321 \"lib/read.mll\"\n \n# 321 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n map_string v f lexbuf )\n\n# 1270 \"lib/read.ml\"\n\n \n# 1271 \"lib/read.ml\"\n | 2 ->\n\n# 323 \"lib/read.mll\"\n \n# 323 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n map_string v f lexbuf )\n\n# 1276 \"lib/read.ml\"\n\n \n# 1277 \"lib/read.ml\"\n | 3 ->\n\n# 325 \"lib/read.mll\"\n \n# 325 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1281 \"lib/read.ml\"\n\n \n# 1282 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state\n\nand finish_escaped_char v lexbuf =\n __ocaml_lex_finish_escaped_char_rec v lexbuf 68\nand __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n c\n\n# 1294 \"lib/read.ml\"\n# 1294 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf lexbuf.Lexing.lex_start_pos in\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf c )\n\n# 1298 \"lib/read.ml\"\n\n \n# 1299 \"lib/read.ml\"\n | 1 ->\n\n# 331 \"lib/read.mll\"\n \n# 331 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\b' )\n\n# 1303 \"lib/read.ml\"\n\n \n# 1304 \"lib/read.ml\"\n | 2 ->\n\n# 332 \"lib/read.mll\"\n \n# 332 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\012' )\n\n# 1308 \"lib/read.ml\"\n\n \n# 1309 \"lib/read.ml\"\n | 3 ->\n\n# 333 \"lib/read.mll\"\n \n# 333 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n' )\n\n# 1313 \"lib/read.ml\"\n\n \n# 1314 \"lib/read.ml\"\n | 4 ->\n\n# 334 \"lib/read.mll\"\n \n# 334 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\r' )\n\n# 1318 \"lib/read.ml\"\n\n \n# 1319 \"lib/read.ml\"\n | 5 ->\n\n# 335 \"lib/read.mll\"\n \n# 335 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\t' )\n\n# 1323 \"lib/read.ml\"\n\n \n# 1324 \"lib/read.ml\"\n | 6 ->\nlet\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n a\n\n# 1329 \"lib/read.ml\"\n# 1329 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 1)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n b\n\n# 1334 \"lib/read.ml\"\n# 1334 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n c\n\n# 1339 \"lib/read.ml\"\n# 1339 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n d\n\n# 1344 \"lib/read.ml\"\n# 1344 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4) in\n\n# 337 \"lib/read.mll\"\n \n# 337 \"lib/read.mll\"\n ( let x =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if x >= 0xD800 && x <= 0xDBFF then\n finish_surrogate_pair v x lexbuf\n else\n utf8_of_code v.buf x\n )\n\n# 1355 \"lib/read.ml\"\n\n \n# 1356 \"lib/read.ml\"\n | 7 ->\n\n# 345 \"lib/read.mll\"\n \n# 345 \"lib/read.mll\"\n ( long_error \"Invalid escape sequence\" v lexbuf )\n\n# 1360 \"lib/read.ml\"\n\n \n# 1361 \"lib/read.ml\"\n | 8 ->\n\n# 346 \"lib/read.mll\"\n \n# 346 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1365 \"lib/read.ml\"\n\n \n# 1366 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state\n\nand finish_surrogate_pair v x lexbuf =\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf 82\nand __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n a\n\n# 1378 \"lib/read.ml\"\n# 1378 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n b\n\n# 1383 \"lib/read.ml\"\n# 1383 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n c\n\n# 1388 \"lib/read.ml\"\n# 1388 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n d\n\n# 1393 \"lib/read.ml\"\n# 1393 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 5) in\n\n# 350 \"lib/read.mll\"\n \n# 350 \"lib/read.mll\"\n ( let y =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if y >= 0xDC00 && y <= 0xDFFF then\n utf8_of_surrogate_pair v.buf x y\n else\n long_error \"Invalid low surrogate for code point beyond U+FFFF\"\n v lexbuf\n )\n\n# 1405 \"lib/read.ml\"\n\n \n# 1406 \"lib/read.ml\"\n | 1 ->\n\n# 359 \"lib/read.mll\"\n \n# 359 \"lib/read.mll\"\n ( long_error \"Missing escape sequence representing low surrogate \\\n for code point beyond U+FFFF\" v lexbuf )\n\n# 1411 \"lib/read.ml\"\n\n \n# 1412 \"lib/read.ml\"\n | 2 ->\n\n# 361 \"lib/read.mll\"\n \n# 361 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1416 \"lib/read.ml\"\n\n \n# 1417 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state\n\nand finish_stringlit v lexbuf =\n __ocaml_lex_finish_stringlit_rec v lexbuf 91\nand __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 366 \"lib/read.mll\"\n \n# 366 \"lib/read.mll\"\n ( let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n let s = Bytes.create (len+1) in\n Bytes.set s 0 '\"';\n Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos s 1 len;\n Bytes.to_string s\n )\n\n# 1433 \"lib/read.ml\"\n\n \n# 1434 \"lib/read.ml\"\n | 1 ->\n\n# 372 \"lib/read.mll\"\n \n# 372 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 1438 \"lib/read.ml\"\n\n \n# 1439 \"lib/read.ml\"\n | 2 ->\n\n# 373 \"lib/read.mll\"\n \n# 373 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1443 \"lib/read.ml\"\n\n \n# 1444 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_variant v lexbuf =\n __ocaml_lex_finish_variant_rec v lexbuf 102\nand __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 376 \"lib/read.mll\"\n \n# 376 \"lib/read.mll\"\n ( let x = read_json v lexbuf in\n read_space v lexbuf;\n read_gt v lexbuf;\n Some x )\n\n# 1458 \"lib/read.ml\"\n\n \n# 1459 \"lib/read.ml\"\n | 1 ->\n\n# 380 \"lib/read.mll\"\n \n# 380 \"lib/read.mll\"\n ( None )\n\n# 1463 \"lib/read.ml\"\n\n \n# 1464 \"lib/read.ml\"\n | 2 ->\n\n# 381 \"lib/read.mll\"\n \n# 381 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 1468 \"lib/read.ml\"\n\n \n# 1469 \"lib/read.ml\"\n | 3 ->\n\n# 382 \"lib/read.mll\"\n \n# 382 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1473 \"lib/read.ml\"\n\n \n# 1474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state\n\nand read_lt v lexbuf =\n __ocaml_lex_read_lt_rec v lexbuf 107\nand __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 385 \"lib/read.mll\"\n \n# 385 \"lib/read.mll\"\n ( () )\n\n# 1485 \"lib/read.ml\"\n\n \n# 1486 \"lib/read.ml\"\n | 1 ->\n\n# 386 \"lib/read.mll\"\n \n# 386 \"lib/read.mll\"\n ( long_error \"Expected '<' but found\" v lexbuf )\n\n# 1490 \"lib/read.ml\"\n\n \n# 1491 \"lib/read.ml\"\n | 2 ->\n\n# 387 \"lib/read.mll\"\n \n# 387 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1495 \"lib/read.ml\"\n\n \n# 1496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state\n\nand read_gt v lexbuf =\n __ocaml_lex_read_gt_rec v lexbuf 111\nand __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 390 \"lib/read.mll\"\n \n# 390 \"lib/read.mll\"\n ( () )\n\n# 1507 \"lib/read.ml\"\n\n \n# 1508 \"lib/read.ml\"\n | 1 ->\n\n# 391 \"lib/read.mll\"\n \n# 391 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 1512 \"lib/read.ml\"\n\n \n# 1513 \"lib/read.ml\"\n | 2 ->\n\n# 392 \"lib/read.mll\"\n \n# 392 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1517 \"lib/read.ml\"\n\n \n# 1518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state\n\nand read_comma v lexbuf =\n __ocaml_lex_read_comma_rec v lexbuf 115\nand __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 395 \"lib/read.mll\"\n \n# 395 \"lib/read.mll\"\n ( () )\n\n# 1529 \"lib/read.ml\"\n\n \n# 1530 \"lib/read.ml\"\n | 1 ->\n\n# 396 \"lib/read.mll\"\n \n# 396 \"lib/read.mll\"\n ( long_error \"Expected ',' but found\" v lexbuf )\n\n# 1534 \"lib/read.ml\"\n\n \n# 1535 \"lib/read.ml\"\n | 2 ->\n\n# 397 \"lib/read.mll\"\n \n# 397 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1539 \"lib/read.ml\"\n\n \n# 1540 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state\n\nand start_any_variant v lexbuf =\n __ocaml_lex_start_any_variant_rec v lexbuf 119\nand __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 400 \"lib/read.mll\"\n \n# 400 \"lib/read.mll\"\n ( `Edgy_bracket )\n\n# 1551 \"lib/read.ml\"\n\n \n# 1552 \"lib/read.ml\"\n | 1 ->\n\n# 401 \"lib/read.mll\"\n \n# 401 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n `Double_quote )\n\n# 1557 \"lib/read.ml\"\n\n \n# 1558 \"lib/read.ml\"\n | 2 ->\n\n# 403 \"lib/read.mll\"\n \n# 403 \"lib/read.mll\"\n ( `Square_bracket )\n\n# 1562 \"lib/read.ml\"\n\n \n# 1563 \"lib/read.ml\"\n | 3 ->\n\n# 404 \"lib/read.mll\"\n \n# 404 \"lib/read.mll\"\n ( long_error \"Expected '<', '\\\"' or '[' but found\" v lexbuf )\n\n# 1567 \"lib/read.ml\"\n\n \n# 1568 \"lib/read.ml\"\n | 4 ->\n\n# 405 \"lib/read.mll\"\n \n# 405 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1572 \"lib/read.ml\"\n\n \n# 1573 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state\n\nand finish_comment v lexbuf =\n __ocaml_lex_finish_comment_rec v lexbuf 125\nand __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 408 \"lib/read.mll\"\n \n# 408 \"lib/read.mll\"\n ( () )\n\n# 1584 \"lib/read.ml\"\n\n \n# 1585 \"lib/read.ml\"\n | 1 ->\n\n# 409 \"lib/read.mll\"\n \n# 409 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 1589 \"lib/read.ml\"\n\n \n# 1590 \"lib/read.ml\"\n | 2 ->\n\n# 410 \"lib/read.mll\"\n \n# 410 \"lib/read.mll\"\n ( newline v lexbuf; finish_comment v lexbuf )\n\n# 1594 \"lib/read.ml\"\n\n \n# 1595 \"lib/read.ml\"\n | 3 ->\n\n# 411 \"lib/read.mll\"\n \n# 411 \"lib/read.mll\"\n ( finish_comment v lexbuf )\n\n# 1599 \"lib/read.ml\"\n\n \n# 1600 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state\n\nand read_eof lexbuf =\n __ocaml_lex_read_eof_rec lexbuf 131\nand __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 419 \"lib/read.mll\"\n \n# 419 \"lib/read.mll\"\n ( true )\n\n# 1611 \"lib/read.ml\"\n\n \n# 1612 \"lib/read.ml\"\n | 1 ->\n\n# 420 \"lib/read.mll\"\n \n# 420 \"lib/read.mll\"\n ( false )\n\n# 1616 \"lib/read.ml\"\n\n \n# 1617 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state\n\nand read_space v lexbuf =\n __ocaml_lex_read_space_rec v lexbuf 133\nand __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 423 \"lib/read.mll\"\n \n# 423 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1628 \"lib/read.ml\"\n\n \n# 1629 \"lib/read.ml\"\n | 1 ->\n\n# 424 \"lib/read.mll\"\n \n# 424 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_space v lexbuf )\n\n# 1633 \"lib/read.ml\"\n\n \n# 1634 \"lib/read.ml\"\n | 2 ->\n\n# 425 \"lib/read.mll\"\n \n# 425 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1638 \"lib/read.ml\"\n\n \n# 1639 \"lib/read.ml\"\n | 3 ->\n\n# 426 \"lib/read.mll\"\n \n# 426 \"lib/read.mll\"\n ( read_space v lexbuf )\n\n# 1643 \"lib/read.ml\"\n\n \n# 1644 \"lib/read.ml\"\n | 4 ->\n\n# 427 \"lib/read.mll\"\n \n# 427 \"lib/read.mll\"\n ( () )\n\n# 1648 \"lib/read.ml\"\n\n \n# 1649 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state\n\nand read_null v lexbuf =\n __ocaml_lex_read_null_rec v lexbuf 140\nand __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 430 \"lib/read.mll\"\n \n# 430 \"lib/read.mll\"\n ( () )\n\n# 1660 \"lib/read.ml\"\n\n \n# 1661 \"lib/read.ml\"\n | 1 ->\n\n# 431 \"lib/read.mll\"\n \n# 431 \"lib/read.mll\"\n ( long_error \"Expected 'null' but found\" v lexbuf )\n\n# 1665 \"lib/read.ml\"\n\n \n# 1666 \"lib/read.ml\"\n | 2 ->\n\n# 432 \"lib/read.mll\"\n \n# 432 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1670 \"lib/read.ml\"\n\n \n# 1671 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state\n\nand read_null_if_possible v lexbuf =\n __ocaml_lex_read_null_if_possible_rec v lexbuf 147\nand __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 435 \"lib/read.mll\"\n \n# 435 \"lib/read.mll\"\n ( true )\n\n# 1682 \"lib/read.ml\"\n\n \n# 1683 \"lib/read.ml\"\n | 1 ->\n\n# 436 \"lib/read.mll\"\n \n# 436 \"lib/read.mll\"\n ( false )\n\n# 1687 \"lib/read.ml\"\n\n \n# 1688 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state\n\nand read_bool v lexbuf =\n __ocaml_lex_read_bool_rec v lexbuf 152\nand __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 439 \"lib/read.mll\"\n \n# 439 \"lib/read.mll\"\n ( true )\n\n# 1699 \"lib/read.ml\"\n\n \n# 1700 \"lib/read.ml\"\n | 1 ->\n\n# 440 \"lib/read.mll\"\n \n# 440 \"lib/read.mll\"\n ( false )\n\n# 1704 \"lib/read.ml\"\n\n \n# 1705 \"lib/read.ml\"\n | 2 ->\n\n# 443 \"lib/read.mll\"\n \n# 443 \"lib/read.mll\"\n ( true )\n\n# 1709 \"lib/read.ml\"\n\n \n# 1710 \"lib/read.ml\"\n | 3 ->\n\n# 444 \"lib/read.mll\"\n \n# 444 \"lib/read.mll\"\n ( false )\n\n# 1714 \"lib/read.ml\"\n\n \n# 1715 \"lib/read.ml\"\n | 4 ->\n\n# 446 \"lib/read.mll\"\n \n# 446 \"lib/read.mll\"\n ( long_error \"Expected 'true' or 'false' but found\" v lexbuf )\n\n# 1719 \"lib/read.ml\"\n\n \n# 1720 \"lib/read.ml\"\n | 5 ->\n\n# 447 \"lib/read.mll\"\n \n# 447 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1724 \"lib/read.ml\"\n\n \n# 1725 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state\n\nand read_int v lexbuf =\n __ocaml_lex_read_int_rec v lexbuf 176\nand __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 450 \"lib/read.mll\"\n \n# 450 \"lib/read.mll\"\n ( try extract_positive_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1738 \"lib/read.ml\"\n\n \n# 1739 \"lib/read.ml\"\n | 1 ->\n\n# 453 \"lib/read.mll\"\n \n# 453 \"lib/read.mll\"\n ( try extract_negative_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1745 \"lib/read.ml\"\n\n \n# 1746 \"lib/read.ml\"\n | 2 ->\n\n# 456 \"lib/read.mll\"\n \n# 456 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n int_of_string s\n with _ ->\n custom_error\n \"Expected an integer but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1763 \"lib/read.ml\"\n\n \n# 1764 \"lib/read.ml\"\n | 3 ->\n\n# 470 \"lib/read.mll\"\n \n# 470 \"lib/read.mll\"\n ( long_error \"Expected integer but found\" v lexbuf )\n\n# 1768 \"lib/read.ml\"\n\n \n# 1769 \"lib/read.ml\"\n | 4 ->\n\n# 471 \"lib/read.mll\"\n \n# 471 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1773 \"lib/read.ml\"\n\n \n# 1774 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state\n\nand read_int32 v lexbuf =\n __ocaml_lex_read_int32_rec v lexbuf 185\nand __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 474 \"lib/read.mll\"\n \n# 474 \"lib/read.mll\"\n ( try Int32.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1787 \"lib/read.ml\"\n\n \n# 1788 \"lib/read.ml\"\n | 1 ->\n\n# 477 \"lib/read.mll\"\n \n# 477 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int32.of_string s\n with _ ->\n custom_error\n \"Expected an int32 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1805 \"lib/read.ml\"\n\n \n# 1806 \"lib/read.ml\"\n | 2 ->\n\n# 491 \"lib/read.mll\"\n \n# 491 \"lib/read.mll\"\n ( long_error \"Expected int32 but found\" v lexbuf )\n\n# 1810 \"lib/read.ml\"\n\n \n# 1811 \"lib/read.ml\"\n | 3 ->\n\n# 492 \"lib/read.mll\"\n \n# 492 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1815 \"lib/read.ml\"\n\n \n# 1816 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state\n\nand read_int64 v lexbuf =\n __ocaml_lex_read_int64_rec v lexbuf 192\nand __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 495 \"lib/read.mll\"\n \n# 495 \"lib/read.mll\"\n ( try Int64.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1829 \"lib/read.ml\"\n\n \n# 1830 \"lib/read.ml\"\n | 1 ->\n\n# 498 \"lib/read.mll\"\n \n# 498 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int64.of_string s\n with _ ->\n custom_error\n \"Expected an int64 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1847 \"lib/read.ml\"\n\n \n# 1848 \"lib/read.ml\"\n | 2 ->\n\n# 512 \"lib/read.mll\"\n \n# 512 \"lib/read.mll\"\n ( long_error \"Expected int64 but found\" v lexbuf )\n\n# 1852 \"lib/read.ml\"\n\n \n# 1853 \"lib/read.ml\"\n | 3 ->\n\n# 513 \"lib/read.mll\"\n \n# 513 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1857 \"lib/read.ml\"\n\n \n# 1858 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state\n\nand read_number v lexbuf =\n __ocaml_lex_read_number_rec v lexbuf 199\nand __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 516 \"lib/read.mll\"\n \n# 516 \"lib/read.mll\"\n ( nan )\n\n# 1869 \"lib/read.ml\"\n\n \n# 1870 \"lib/read.ml\"\n | 1 ->\n\n# 517 \"lib/read.mll\"\n \n# 517 \"lib/read.mll\"\n ( infinity )\n\n# 1874 \"lib/read.ml\"\n\n \n# 1875 \"lib/read.ml\"\n | 2 ->\n\n# 518 \"lib/read.mll\"\n \n# 518 \"lib/read.mll\"\n ( neg_infinity )\n\n# 1879 \"lib/read.ml\"\n\n \n# 1880 \"lib/read.ml\"\n | 3 ->\n\n# 519 \"lib/read.mll\"\n \n# 519 \"lib/read.mll\"\n ( float_of_string (lexeme lexbuf) )\n\n# 1884 \"lib/read.ml\"\n\n \n# 1885 \"lib/read.ml\"\n | 4 ->\n\n# 520 \"lib/read.mll\"\n \n# 520 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant float will pass,\n including hexadecimal and octal notations,\n and embedded underscores. *)\n float_of_string s\n with _ ->\n match s with\n \"NaN\" -> nan\n | \"Infinity\" -> infinity\n | \"-Infinity\" -> neg_infinity\n | _ ->\n custom_error\n \"Expected a number but found a string that \\\n doesn't even represent a number\"\n v lexbuf\n )\n\n# 1906 \"lib/read.ml\"\n\n \n# 1907 \"lib/read.ml\"\n | 5 ->\n\n# 538 \"lib/read.mll\"\n \n# 538 \"lib/read.mll\"\n ( long_error \"Expected number but found\" v lexbuf )\n\n# 1911 \"lib/read.ml\"\n\n \n# 1912 \"lib/read.ml\"\n | 6 ->\n\n# 539 \"lib/read.mll\"\n \n# 539 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1916 \"lib/read.ml\"\n\n \n# 1917 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state\n\nand read_string v lexbuf =\n __ocaml_lex_read_string_rec v lexbuf 233\nand __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 542 \"lib/read.mll\"\n \n# 542 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1929 \"lib/read.ml\"\n\n \n# 1930 \"lib/read.ml\"\n | 1 ->\n\n# 544 \"lib/read.mll\"\n \n# 544 \"lib/read.mll\"\n ( long_error \"Expected '\\\"' but found\" v lexbuf )\n\n# 1934 \"lib/read.ml\"\n\n \n# 1935 \"lib/read.ml\"\n | 2 ->\n\n# 545 \"lib/read.mll\"\n \n# 545 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1939 \"lib/read.ml\"\n\n \n# 1940 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state\n\nand read_ident v lexbuf =\n __ocaml_lex_read_ident_rec v lexbuf 237\nand __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 548 \"lib/read.mll\"\n \n# 548 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1952 \"lib/read.ml\"\n\n \n# 1953 \"lib/read.ml\"\n | 1 ->\nlet\n\n# 550 \"lib/read.mll\"\n \n# 550 \"lib/read.mll\"\n s\n\n# 1958 \"lib/read.ml\"\n# 1958 \"lib/read.ml\"\n= Lexing.sub_lexeme lexbuf lexbuf.Lexing.lex_start_pos lexbuf.Lexing.lex_curr_pos in\n\n# 551 \"lib/read.mll\"\n \n# 551 \"lib/read.mll\"\n ( s )\n\n# 1962 \"lib/read.ml\"\n\n \n# 1963 \"lib/read.ml\"\n | 2 ->\n\n# 552 \"lib/read.mll\"\n \n# 552 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1967 \"lib/read.ml\"\n\n \n# 1968 \"lib/read.ml\"\n | 3 ->\n\n# 553 \"lib/read.mll\"\n \n# 553 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1972 \"lib/read.ml\"\n\n \n# 1973 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state\n\nand map_ident v f lexbuf =\n __ocaml_lex_map_ident_rec v f lexbuf 242\nand __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 556 \"lib/read.mll\"\n \n# 556 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n map_string v f lexbuf )\n\n# 1985 \"lib/read.ml\"\n\n \n# 1986 \"lib/read.ml\"\n | 1 ->\n\n# 559 \"lib/read.mll\"\n \n# 559 \"lib/read.mll\"\n ( map_lexeme f lexbuf )\n\n# 1990 \"lib/read.ml\"\n\n \n# 1991 \"lib/read.ml\"\n | 2 ->\n\n# 560 \"lib/read.mll\"\n \n# 560 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1995 \"lib/read.ml\"\n\n \n# 1996 \"lib/read.ml\"\n | 3 ->\n\n# 561 \"lib/read.mll\"\n \n# 561 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2000 \"lib/read.ml\"\n\n \n# 2001 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state\n\nand read_sequence read_cell init_acc v lexbuf =\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf 247\nand __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 564 \"lib/read.mll\"\n \n# 564 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell !acc v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell !acc v lexbuf;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2026 \"lib/read.ml\"\n\n \n# 2027 \"lib/read.ml\"\n | 1 ->\n\n# 579 \"lib/read.mll\"\n \n# 579 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2031 \"lib/read.ml\"\n\n \n# 2032 \"lib/read.ml\"\n | 2 ->\n\n# 580 \"lib/read.mll\"\n \n# 580 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2036 \"lib/read.ml\"\n\n \n# 2037 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_list_rev read_cell v lexbuf =\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf 251\nand __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 583 \"lib/read.mll\"\n \n# 583 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2062 \"lib/read.ml\"\n\n \n# 2063 \"lib/read.ml\"\n | 1 ->\n\n# 598 \"lib/read.mll\"\n \n# 598 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2067 \"lib/read.ml\"\n\n \n# 2068 \"lib/read.ml\"\n | 2 ->\n\n# 599 \"lib/read.mll\"\n \n# 599 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2072 \"lib/read.ml\"\n\n \n# 2073 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state\n\nand read_array_end lexbuf =\n __ocaml_lex_read_array_end_rec lexbuf 255\nand __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 602 \"lib/read.mll\"\n \n# 602 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2084 \"lib/read.ml\"\n\n \n# 2085 \"lib/read.ml\"\n | 1 ->\n\n# 603 \"lib/read.mll\"\n \n# 603 \"lib/read.mll\"\n ( () )\n\n# 2089 \"lib/read.ml\"\n\n \n# 2090 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state\n\nand read_array_sep v lexbuf =\n __ocaml_lex_read_array_sep_rec v lexbuf 257\nand __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 606 \"lib/read.mll\"\n \n# 606 \"lib/read.mll\"\n ( () )\n\n# 2101 \"lib/read.ml\"\n\n \n# 2102 \"lib/read.ml\"\n | 1 ->\n\n# 607 \"lib/read.mll\"\n \n# 607 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2106 \"lib/read.ml\"\n\n \n# 2107 \"lib/read.ml\"\n | 2 ->\n\n# 608 \"lib/read.mll\"\n \n# 608 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 2111 \"lib/read.ml\"\n\n \n# 2112 \"lib/read.ml\"\n | 3 ->\n\n# 609 \"lib/read.mll\"\n \n# 609 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2116 \"lib/read.ml\"\n\n \n# 2117 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple read_cell init_acc v lexbuf =\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf 262\nand __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 613 \"lib/read.mll\"\n \n# 613 \"lib/read.mll\"\n (\n \n# 633 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 635 \"lib/read.mll\"\n )\n\n# 2150 \"lib/read.ml\"\n\n \n# 2151 \"lib/read.ml\"\n | 1 ->\n\n# 636 \"lib/read.mll\"\n \n# 636 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2155 \"lib/read.ml\"\n\n \n# 2156 \"lib/read.ml\"\n | 2 ->\n\n# 637 \"lib/read.mll\"\n \n# 637 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2160 \"lib/read.ml\"\n\n \n# 2161 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_tuple_end lexbuf =\n __ocaml_lex_read_tuple_end_rec lexbuf 266\nand __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 640 \"lib/read.mll\"\n \n# 640 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2172 \"lib/read.ml\"\n\n \n# 2173 \"lib/read.ml\"\n | 1 ->\n\n# 641 \"lib/read.mll\"\n \n# 641 \"lib/read.mll\"\n ( () )\n\n# 2177 \"lib/read.ml\"\n\n \n# 2178 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state\n\nand read_tuple_end2 v std lexbuf =\n __ocaml_lex_read_tuple_end2_rec v std lexbuf 268\nand __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 644 \"lib/read.mll\"\n \n# 644 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ')' or '' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2192 \"lib/read.ml\"\n\n \n# 2193 \"lib/read.ml\"\n | 1 ->\n\n# 648 \"lib/read.mll\"\n \n# 648 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ']' or '' but found\" v lexbuf )\n\n# 2200 \"lib/read.ml\"\n\n \n# 2201 \"lib/read.ml\"\n | 2 ->\n\n# 652 \"lib/read.mll\"\n \n# 652 \"lib/read.mll\"\n ( () )\n\n# 2205 \"lib/read.ml\"\n\n \n# 2206 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state\n\nand read_tuple_sep v lexbuf =\n __ocaml_lex_read_tuple_sep_rec v lexbuf 271\nand __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 655 \"lib/read.mll\"\n \n# 655 \"lib/read.mll\"\n ( () )\n\n# 2217 \"lib/read.ml\"\n\n \n# 2218 \"lib/read.ml\"\n | 1 ->\n\n# 656 \"lib/read.mll\"\n \n# 656 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2222 \"lib/read.ml\"\n\n \n# 2223 \"lib/read.ml\"\n | 2 ->\n\n# 657 \"lib/read.mll\"\n \n# 657 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2227 \"lib/read.ml\"\n\n \n# 2228 \"lib/read.ml\"\n | 3 ->\n\n# 658 \"lib/read.mll\"\n \n# 658 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2232 \"lib/read.ml\"\n\n \n# 2233 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple_sep2 v std lexbuf =\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf 276\nand __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 661 \"lib/read.mll\"\n \n# 661 \"lib/read.mll\"\n ( () )\n\n# 2244 \"lib/read.ml\"\n\n \n# 2245 \"lib/read.ml\"\n | 1 ->\n\n# 662 \"lib/read.mll\"\n \n# 662 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ',' or ']' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2252 \"lib/read.ml\"\n\n \n# 2253 \"lib/read.ml\"\n | 2 ->\n\n# 666 \"lib/read.mll\"\n \n# 666 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2260 \"lib/read.ml\"\n\n \n# 2261 \"lib/read.ml\"\n | 3 ->\n\n# 670 \"lib/read.mll\"\n \n# 670 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2265 \"lib/read.ml\"\n\n \n# 2266 \"lib/read.ml\"\n | 4 ->\n\n# 671 \"lib/read.mll\"\n \n# 671 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2270 \"lib/read.ml\"\n\n \n# 2271 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state\n\nand read_abstract_fields read_key read_field init_acc v lexbuf =\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf 282\nand __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 675 \"lib/read.mll\"\n \n# 675 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n done;\n assert false\n with End_of_object ->\n !acc\n )\n\n# 2304 \"lib/read.ml\"\n\n \n# 2305 \"lib/read.ml\"\n | 1 ->\n\n# 698 \"lib/read.mll\"\n \n# 698 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2309 \"lib/read.ml\"\n\n \n# 2310 \"lib/read.ml\"\n | 2 ->\n\n# 699 \"lib/read.mll\"\n \n# 699 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2314 \"lib/read.ml\"\n\n \n# 2315 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state\n\nand read_lcurl v lexbuf =\n __ocaml_lex_read_lcurl_rec v lexbuf 286\nand __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 702 \"lib/read.mll\"\n \n# 702 \"lib/read.mll\"\n ( () )\n\n# 2326 \"lib/read.ml\"\n\n \n# 2327 \"lib/read.ml\"\n | 1 ->\n\n# 703 \"lib/read.mll\"\n \n# 703 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2331 \"lib/read.ml\"\n\n \n# 2332 \"lib/read.ml\"\n | 2 ->\n\n# 704 \"lib/read.mll\"\n \n# 704 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2336 \"lib/read.ml\"\n\n \n# 2337 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state\n\nand read_object_end lexbuf =\n __ocaml_lex_read_object_end_rec lexbuf 290\nand __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 707 \"lib/read.mll\"\n \n# 707 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2348 \"lib/read.ml\"\n\n \n# 2349 \"lib/read.ml\"\n | 1 ->\n\n# 708 \"lib/read.mll\"\n \n# 708 \"lib/read.mll\"\n ( () )\n\n# 2353 \"lib/read.ml\"\n\n \n# 2354 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state\n\nand read_object_sep v lexbuf =\n __ocaml_lex_read_object_sep_rec v lexbuf 292\nand __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 711 \"lib/read.mll\"\n \n# 711 \"lib/read.mll\"\n ( () )\n\n# 2365 \"lib/read.ml\"\n\n \n# 2366 \"lib/read.ml\"\n | 1 ->\n\n# 712 \"lib/read.mll\"\n \n# 712 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2370 \"lib/read.ml\"\n\n \n# 2371 \"lib/read.ml\"\n | 2 ->\n\n# 713 \"lib/read.mll\"\n \n# 713 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 2375 \"lib/read.ml\"\n\n \n# 2376 \"lib/read.ml\"\n | 3 ->\n\n# 714 \"lib/read.mll\"\n \n# 714 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2380 \"lib/read.ml\"\n\n \n# 2381 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state\n\nand read_colon v lexbuf =\n __ocaml_lex_read_colon_rec v lexbuf 297\nand __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 717 \"lib/read.mll\"\n \n# 717 \"lib/read.mll\"\n ( () )\n\n# 2392 \"lib/read.ml\"\n\n \n# 2393 \"lib/read.ml\"\n | 1 ->\n\n# 718 \"lib/read.mll\"\n \n# 718 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 2397 \"lib/read.ml\"\n\n \n# 2398 \"lib/read.ml\"\n | 2 ->\n\n# 719 \"lib/read.mll\"\n \n# 719 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2402 \"lib/read.ml\"\n\n \n# 2403 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state\n\nand start_any_tuple v lexbuf =\n __ocaml_lex_start_any_tuple_rec v lexbuf 301\nand __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 722 \"lib/read.mll\"\n \n# 722 \"lib/read.mll\"\n ( false )\n\n# 2414 \"lib/read.ml\"\n\n \n# 2415 \"lib/read.ml\"\n | 1 ->\n\n# 723 \"lib/read.mll\"\n \n# 723 \"lib/read.mll\"\n ( true )\n\n# 2419 \"lib/read.ml\"\n\n \n# 2420 \"lib/read.ml\"\n | 2 ->\n\n# 724 \"lib/read.mll\"\n \n# 724 \"lib/read.mll\"\n ( long_error \"Expected '(' or '[' but found\" v lexbuf )\n\n# 2424 \"lib/read.ml\"\n\n \n# 2425 \"lib/read.ml\"\n | 3 ->\n\n# 725 \"lib/read.mll\"\n \n# 725 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2429 \"lib/read.ml\"\n\n \n# 2430 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state\n\nand read_lpar v lexbuf =\n __ocaml_lex_read_lpar_rec v lexbuf 306\nand __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 728 \"lib/read.mll\"\n \n# 728 \"lib/read.mll\"\n ( () )\n\n# 2441 \"lib/read.ml\"\n\n \n# 2442 \"lib/read.ml\"\n | 1 ->\n\n# 729 \"lib/read.mll\"\n \n# 729 \"lib/read.mll\"\n ( long_error \"Expected '(' but found\" v lexbuf )\n\n# 2446 \"lib/read.ml\"\n\n \n# 2447 \"lib/read.ml\"\n | 2 ->\n\n# 730 \"lib/read.mll\"\n \n# 730 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2451 \"lib/read.ml\"\n\n \n# 2452 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state\n\nand read_rpar v lexbuf =\n __ocaml_lex_read_rpar_rec v lexbuf 310\nand __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 733 \"lib/read.mll\"\n \n# 733 \"lib/read.mll\"\n ( () )\n\n# 2463 \"lib/read.ml\"\n\n \n# 2464 \"lib/read.ml\"\n | 1 ->\n\n# 734 \"lib/read.mll\"\n \n# 734 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2468 \"lib/read.ml\"\n\n \n# 2469 \"lib/read.ml\"\n | 2 ->\n\n# 735 \"lib/read.mll\"\n \n# 735 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2473 \"lib/read.ml\"\n\n \n# 2474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state\n\nand read_lbr v lexbuf =\n __ocaml_lex_read_lbr_rec v lexbuf 314\nand __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 738 \"lib/read.mll\"\n \n# 738 \"lib/read.mll\"\n ( () )\n\n# 2485 \"lib/read.ml\"\n\n \n# 2486 \"lib/read.ml\"\n | 1 ->\n\n# 739 \"lib/read.mll\"\n \n# 739 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2490 \"lib/read.ml\"\n\n \n# 2491 \"lib/read.ml\"\n | 2 ->\n\n# 740 \"lib/read.mll\"\n \n# 740 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2495 \"lib/read.ml\"\n\n \n# 2496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state\n\nand read_rbr v lexbuf =\n __ocaml_lex_read_rbr_rec v lexbuf 318\nand __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 743 \"lib/read.mll\"\n \n# 743 \"lib/read.mll\"\n ( () )\n\n# 2507 \"lib/read.ml\"\n\n \n# 2508 \"lib/read.ml\"\n | 1 ->\n\n# 744 \"lib/read.mll\"\n \n# 744 \"lib/read.mll\"\n ( long_error \"Expected ']' but found\" v lexbuf )\n\n# 2512 \"lib/read.ml\"\n\n \n# 2513 \"lib/read.ml\"\n | 2 ->\n\n# 745 \"lib/read.mll\"\n \n# 745 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2517 \"lib/read.ml\"\n\n \n# 2518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state\n\nand skip_json v lexbuf =\n __ocaml_lex_skip_json_rec v lexbuf 322\nand __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 751 \"lib/read.mll\"\n \n# 751 \"lib/read.mll\"\n ( () )\n\n# 2529 \"lib/read.ml\"\n\n \n# 2530 \"lib/read.ml\"\n | 1 ->\n\n# 752 \"lib/read.mll\"\n \n# 752 \"lib/read.mll\"\n ( () )\n\n# 2534 \"lib/read.ml\"\n\n \n# 2535 \"lib/read.ml\"\n | 2 ->\n\n# 753 \"lib/read.mll\"\n \n# 753 \"lib/read.mll\"\n ( () )\n\n# 2539 \"lib/read.ml\"\n\n \n# 2540 \"lib/read.ml\"\n | 3 ->\n\n# 754 \"lib/read.mll\"\n \n# 754 \"lib/read.mll\"\n ( () )\n\n# 2544 \"lib/read.ml\"\n\n \n# 2545 \"lib/read.ml\"\n | 4 ->\n\n# 755 \"lib/read.mll\"\n \n# 755 \"lib/read.mll\"\n ( () )\n\n# 2549 \"lib/read.ml\"\n\n \n# 2550 \"lib/read.ml\"\n | 5 ->\n\n# 756 \"lib/read.mll\"\n \n# 756 \"lib/read.mll\"\n ( () )\n\n# 2554 \"lib/read.ml\"\n\n \n# 2555 \"lib/read.ml\"\n | 6 ->\n\n# 757 \"lib/read.mll\"\n \n# 757 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2559 \"lib/read.ml\"\n\n \n# 2560 \"lib/read.ml\"\n | 7 ->\n\n# 758 \"lib/read.mll\"\n \n# 758 \"lib/read.mll\"\n ( () )\n\n# 2564 \"lib/read.ml\"\n\n \n# 2565 \"lib/read.ml\"\n | 8 ->\n\n# 759 \"lib/read.mll\"\n \n# 759 \"lib/read.mll\"\n ( () )\n\n# 2569 \"lib/read.ml\"\n\n \n# 2570 \"lib/read.ml\"\n | 9 ->\n\n# 761 \"lib/read.mll\"\n \n# 761 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_object_end lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2595 \"lib/read.ml\"\n\n \n# 2596 \"lib/read.ml\"\n | 10 ->\n\n# 784 \"lib/read.mll\"\n \n# 784 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_array_end lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2613 \"lib/read.ml\"\n\n \n# 2614 \"lib/read.ml\"\n | 11 ->\n\n# 799 \"lib/read.mll\"\n \n# 799 \"lib/read.mll\"\n (\n \n# 815 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 817 \"lib/read.mll\"\n )\n\n# 2636 \"lib/read.ml\"\n\n \n# 2637 \"lib/read.ml\"\n | 12 ->\n\n# 819 \"lib/read.mll\"\n \n# 819 \"lib/read.mll\"\n (\n \n# 826 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 828 \"lib/read.mll\"\n )\n\n# 2650 \"lib/read.ml\"\n\n \n# 2651 \"lib/read.ml\"\n | 13 ->\n\n# 830 \"lib/read.mll\"\n \n# 830 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2655 \"lib/read.ml\"\n\n \n# 2656 \"lib/read.ml\"\n | 14 ->\n\n# 831 \"lib/read.mll\"\n \n# 831 \"lib/read.mll\"\n ( finish_comment v lexbuf; skip_json v lexbuf )\n\n# 2660 \"lib/read.ml\"\n\n \n# 2661 \"lib/read.ml\"\n | 15 ->\n\n# 832 \"lib/read.mll\"\n \n# 832 \"lib/read.mll\"\n ( newline v lexbuf; skip_json v lexbuf )\n\n# 2665 \"lib/read.ml\"\n\n \n# 2666 \"lib/read.ml\"\n | 16 ->\n\n# 833 \"lib/read.mll\"\n \n# 833 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2670 \"lib/read.ml\"\n\n \n# 2671 \"lib/read.ml\"\n | 17 ->\n\n# 834 \"lib/read.mll\"\n \n# 834 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2675 \"lib/read.ml\"\n\n \n# 2676 \"lib/read.ml\"\n | 18 ->\n\n# 835 \"lib/read.mll\"\n \n# 835 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2680 \"lib/read.ml\"\n\n \n# 2681 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_stringlit v lexbuf =\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf 378\nand __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 841 \"lib/read.mll\"\n \n# 841 \"lib/read.mll\"\n ( () )\n\n# 2692 \"lib/read.ml\"\n\n \n# 2693 \"lib/read.ml\"\n | 1 ->\n\n# 842 \"lib/read.mll\"\n \n# 842 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2697 \"lib/read.ml\"\n\n \n# 2698 \"lib/read.ml\"\n | 2 ->\n\n# 843 \"lib/read.mll\"\n \n# 843 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2702 \"lib/read.ml\"\n\n \n# 2703 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_variant v lexbuf =\n __ocaml_lex_finish_skip_variant_rec v lexbuf 389\nand __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 846 \"lib/read.mll\"\n \n# 846 \"lib/read.mll\"\n ( skip_json v lexbuf;\n read_space v lexbuf;\n read_gt v lexbuf )\n\n# 2716 \"lib/read.ml\"\n\n \n# 2717 \"lib/read.ml\"\n | 1 ->\n\n# 849 \"lib/read.mll\"\n \n# 849 \"lib/read.mll\"\n ( () )\n\n# 2721 \"lib/read.ml\"\n\n \n# 2722 \"lib/read.ml\"\n | 2 ->\n\n# 850 \"lib/read.mll\"\n \n# 850 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2726 \"lib/read.ml\"\n\n \n# 2727 \"lib/read.ml\"\n | 3 ->\n\n# 851 \"lib/read.mll\"\n \n# 851 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2731 \"lib/read.ml\"\n\n \n# 2732 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state\n\nand skip_ident v lexbuf =\n __ocaml_lex_skip_ident_rec v lexbuf 394\nand __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 854 \"lib/read.mll\"\n \n# 854 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2743 \"lib/read.ml\"\n\n \n# 2744 \"lib/read.ml\"\n | 1 ->\n\n# 855 \"lib/read.mll\"\n \n# 855 \"lib/read.mll\"\n ( () )\n\n# 2748 \"lib/read.ml\"\n\n \n# 2749 \"lib/read.ml\"\n | 2 ->\n\n# 856 \"lib/read.mll\"\n \n# 856 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2753 \"lib/read.ml\"\n\n \n# 2754 \"lib/read.ml\"\n | 3 ->\n\n# 857 \"lib/read.mll\"\n \n# 857 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2758 \"lib/read.ml\"\n\n \n# 2759 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_json v lexbuf =\n __ocaml_lex_buffer_json_rec v lexbuf 399\nand __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 870 \"lib/read.mll\"\n \n# 870 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2770 \"lib/read.ml\"\n\n \n# 2771 \"lib/read.ml\"\n | 1 ->\n\n# 872 \"lib/read.mll\"\n \n# 872 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2775 \"lib/read.ml\"\n\n \n# 2776 \"lib/read.ml\"\n | 2 ->\n\n# 873 \"lib/read.mll\"\n \n# 873 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '{';\n buffer_space v lexbuf;\n buffer_object_end v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_object_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2802 \"lib/read.ml\"\n\n \n# 2803 \"lib/read.ml\"\n | 3 ->\n\n# 897 \"lib/read.mll\"\n \n# 897 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '[';\n buffer_space v lexbuf;\n buffer_array_end v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_array_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2821 \"lib/read.ml\"\n\n \n# 2822 \"lib/read.ml\"\n | 4 ->\n\n# 913 \"lib/read.mll\"\n \n# 913 \"lib/read.mll\"\n (\n \n# 930 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 932 \"lib/read.mll\"\n )\n\n# 2845 \"lib/read.ml\"\n\n \n# 2846 \"lib/read.ml\"\n | 5 ->\n\n# 934 \"lib/read.mll\"\n \n# 934 \"lib/read.mll\"\n (\n \n# 942 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 944 \"lib/read.mll\"\n )\n\n# 2860 \"lib/read.ml\"\n\n \n# 2861 \"lib/read.ml\"\n | 6 ->\n\n# 946 \"lib/read.mll\"\n \n# 946 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2865 \"lib/read.ml\"\n\n \n# 2866 \"lib/read.ml\"\n | 7 ->\n\n# 947 \"lib/read.mll\"\n \n# 947 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_json v lexbuf )\n\n# 2872 \"lib/read.ml\"\n\n \n# 2873 \"lib/read.ml\"\n | 8 ->\n\n# 950 \"lib/read.mll\"\n \n# 950 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_json v lexbuf )\n\n# 2879 \"lib/read.ml\"\n\n \n# 2880 \"lib/read.ml\"\n | 9 ->\n\n# 953 \"lib/read.mll\"\n \n# 953 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2884 \"lib/read.ml\"\n\n \n# 2885 \"lib/read.ml\"\n | 10 ->\n\n# 954 \"lib/read.mll\"\n \n# 954 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2889 \"lib/read.ml\"\n\n \n# 2890 \"lib/read.ml\"\n | 11 ->\n\n# 955 \"lib/read.mll\"\n \n# 955 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2894 \"lib/read.ml\"\n\n \n# 2895 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_stringlit v lexbuf =\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf 450\nand __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 961 \"lib/read.mll\"\n \n# 961 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\"';\n add_lexeme v.buf lexbuf\n )\n\n# 2908 \"lib/read.ml\"\n\n \n# 2909 \"lib/read.ml\"\n | 1 ->\n\n# 964 \"lib/read.mll\"\n \n# 964 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2913 \"lib/read.ml\"\n\n \n# 2914 \"lib/read.ml\"\n | 2 ->\n\n# 965 \"lib/read.mll\"\n \n# 965 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2918 \"lib/read.ml\"\n\n \n# 2919 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_variant v lexbuf =\n __ocaml_lex_finish_buffer_variant_rec v lexbuf 461\nand __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 968 \"lib/read.mll\"\n \n# 968 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':';\n buffer_json v lexbuf;\n buffer_space v lexbuf;\n buffer_gt v lexbuf )\n\n# 2933 \"lib/read.ml\"\n\n \n# 2934 \"lib/read.ml\"\n | 1 ->\n\n# 972 \"lib/read.mll\"\n \n# 972 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 2938 \"lib/read.ml\"\n\n \n# 2939 \"lib/read.ml\"\n | 2 ->\n\n# 973 \"lib/read.mll\"\n \n# 973 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2943 \"lib/read.ml\"\n\n \n# 2944 \"lib/read.ml\"\n | 3 ->\n\n# 974 \"lib/read.mll\"\n \n# 974 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2948 \"lib/read.ml\"\n\n \n# 2949 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state\n\nand buffer_ident v lexbuf =\n __ocaml_lex_buffer_ident_rec v lexbuf 466\nand __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 977 \"lib/read.mll\"\n \n# 977 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2960 \"lib/read.ml\"\n\n \n# 2961 \"lib/read.ml\"\n | 1 ->\n\n# 978 \"lib/read.mll\"\n \n# 978 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2965 \"lib/read.ml\"\n\n \n# 2966 \"lib/read.ml\"\n | 2 ->\n\n# 979 \"lib/read.mll\"\n \n# 979 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2970 \"lib/read.ml\"\n\n \n# 2971 \"lib/read.ml\"\n | 3 ->\n\n# 980 \"lib/read.mll\"\n \n# 980 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2975 \"lib/read.ml\"\n\n \n# 2976 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_space v lexbuf =\n __ocaml_lex_buffer_space_rec v lexbuf 471\nand __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 983 \"lib/read.mll\"\n \n# 983 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 2990 \"lib/read.ml\"\n\n \n# 2991 \"lib/read.ml\"\n | 1 ->\n\n# 987 \"lib/read.mll\"\n \n# 987 \"lib/read.mll\"\n (\n Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_space v lexbuf )\n\n# 2998 \"lib/read.ml\"\n\n \n# 2999 \"lib/read.ml\"\n | 2 ->\n\n# 991 \"lib/read.mll\"\n \n# 991 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 3006 \"lib/read.ml\"\n\n \n# 3007 \"lib/read.ml\"\n | 3 ->\n\n# 995 \"lib/read.mll\"\n \n# 995 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n buffer_space v lexbuf )\n\n# 3013 \"lib/read.ml\"\n\n \n# 3014 \"lib/read.ml\"\n | 4 ->\n\n# 998 \"lib/read.mll\"\n \n# 998 \"lib/read.mll\"\n ( () )\n\n# 3018 \"lib/read.ml\"\n\n \n# 3019 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_end v lexbuf =\n __ocaml_lex_buffer_object_end_rec v lexbuf 478\nand __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1001 \"lib/read.mll\"\n \n# 1001 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '}';\n raise End_of_object )\n\n# 3032 \"lib/read.ml\"\n\n \n# 3033 \"lib/read.ml\"\n | 1 ->\n\n# 1004 \"lib/read.mll\"\n \n# 1004 \"lib/read.mll\"\n ( () )\n\n# 3037 \"lib/read.ml\"\n\n \n# 3038 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_sep v lexbuf =\n __ocaml_lex_buffer_object_sep_rec v lexbuf 480\nand __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1007 \"lib/read.mll\"\n \n# 1007 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3049 \"lib/read.ml\"\n\n \n# 3050 \"lib/read.ml\"\n | 1 ->\n\n# 1008 \"lib/read.mll\"\n \n# 1008 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '}'; raise End_of_object )\n\n# 3054 \"lib/read.ml\"\n\n \n# 3055 \"lib/read.ml\"\n | 2 ->\n\n# 1009 \"lib/read.mll\"\n \n# 1009 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 3059 \"lib/read.ml\"\n\n \n# 3060 \"lib/read.ml\"\n | 3 ->\n\n# 1010 \"lib/read.mll\"\n \n# 1010 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3064 \"lib/read.ml\"\n\n \n# 3065 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_end v lexbuf =\n __ocaml_lex_buffer_array_end_rec v lexbuf 485\nand __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1013 \"lib/read.mll\"\n \n# 1013 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3076 \"lib/read.ml\"\n\n \n# 3077 \"lib/read.ml\"\n | 1 ->\n\n# 1014 \"lib/read.mll\"\n \n# 1014 \"lib/read.mll\"\n ( () )\n\n# 3081 \"lib/read.ml\"\n\n \n# 3082 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_sep v lexbuf =\n __ocaml_lex_buffer_array_sep_rec v lexbuf 487\nand __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1017 \"lib/read.mll\"\n \n# 1017 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3093 \"lib/read.ml\"\n\n \n# 3094 \"lib/read.ml\"\n | 1 ->\n\n# 1018 \"lib/read.mll\"\n \n# 1018 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3098 \"lib/read.ml\"\n\n \n# 3099 \"lib/read.ml\"\n | 2 ->\n\n# 1019 \"lib/read.mll\"\n \n# 1019 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 3103 \"lib/read.ml\"\n\n \n# 3104 \"lib/read.ml\"\n | 3 ->\n\n# 1020 \"lib/read.mll\"\n \n# 1020 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3108 \"lib/read.ml\"\n\n \n# 3109 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_end v lexbuf =\n __ocaml_lex_buffer_tuple_end_rec v lexbuf 492\nand __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1023 \"lib/read.mll\"\n \n# 1023 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf ')';\n raise End_of_tuple )\n\n# 3122 \"lib/read.ml\"\n\n \n# 3123 \"lib/read.ml\"\n | 1 ->\n\n# 1026 \"lib/read.mll\"\n \n# 1026 \"lib/read.mll\"\n ( () )\n\n# 3127 \"lib/read.ml\"\n\n \n# 3128 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_sep v lexbuf =\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf 494\nand __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1029 \"lib/read.mll\"\n \n# 1029 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3139 \"lib/read.ml\"\n\n \n# 3140 \"lib/read.ml\"\n | 1 ->\n\n# 1030 \"lib/read.mll\"\n \n# 1030 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ')'; raise End_of_tuple )\n\n# 3144 \"lib/read.ml\"\n\n \n# 3145 \"lib/read.ml\"\n | 2 ->\n\n# 1031 \"lib/read.mll\"\n \n# 1031 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 3149 \"lib/read.ml\"\n\n \n# 3150 \"lib/read.ml\"\n | 3 ->\n\n# 1032 \"lib/read.mll\"\n \n# 1032 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3154 \"lib/read.ml\"\n\n \n# 3155 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_colon v lexbuf =\n __ocaml_lex_buffer_colon_rec v lexbuf 499\nand __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1035 \"lib/read.mll\"\n \n# 1035 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':' )\n\n# 3166 \"lib/read.ml\"\n\n \n# 3167 \"lib/read.ml\"\n | 1 ->\n\n# 1036 \"lib/read.mll\"\n \n# 1036 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 3171 \"lib/read.ml\"\n\n \n# 3172 \"lib/read.ml\"\n | 2 ->\n\n# 1037 \"lib/read.mll\"\n \n# 1037 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3176 \"lib/read.ml\"\n\n \n# 3177 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state\n\nand buffer_gt v lexbuf =\n __ocaml_lex_buffer_gt_rec v lexbuf 503\nand __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1040 \"lib/read.mll\"\n \n# 1040 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 3188 \"lib/read.ml\"\n\n \n# 3189 \"lib/read.ml\"\n | 1 ->\n\n# 1041 \"lib/read.mll\"\n \n# 1041 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 3193 \"lib/read.ml\"\n\n \n# 3194 \"lib/read.ml\"\n | 2 ->\n\n# 1042 \"lib/read.mll\"\n \n# 1042 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3198 \"lib/read.ml\"\n\n \n# 3199 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_comment v lexbuf =\n __ocaml_lex_finish_buffer_comment_rec v lexbuf 507\nand __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1045 \"lib/read.mll\"\n \n# 1045 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"*/\" )\n\n# 3210 \"lib/read.ml\"\n\n \n# 3211 \"lib/read.ml\"\n | 1 ->\n\n# 1046 \"lib/read.mll\"\n \n# 1046 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 3215 \"lib/read.ml\"\n\n \n# 3216 \"lib/read.ml\"\n | 2 ->\n\n# 1047 \"lib/read.mll\"\n \n# 1047 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n finish_buffer_comment v lexbuf )\n\n# 3222 \"lib/read.ml\"\n\n \n# 3223 \"lib/read.ml\"\n | 3 ->\n\n# 1050 \"lib/read.mll\"\n \n# 1050 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; finish_buffer_comment v lexbuf )\n\n# 3227 \"lib/read.ml\"\n\n \n# 3228 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state\n\nand junk lexbuf =\n __ocaml_lex_junk_rec lexbuf 513\nand __ocaml_lex_junk_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1053 \"lib/read.mll\"\n \n# 1053 \"lib/read.mll\"\n ( Lexing.lexeme lexbuf )\n\n# 3239 \"lib/read.ml\"\n\n \n# 3240 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_junk_rec lexbuf __ocaml_lex_state\n\n;;\n\n\n# 1055 \"lib/read.mll\"\n \n \n# 1056 \"lib/read.mll\"\n let _ = (read_json : lexer_state -> Lexing.lexbuf -> t)\n\n let read_t = read_json\n\n let () =\n read_junk := junk\n\n let read_int8 v lexbuf =\n let n = read_int v lexbuf in\n if n < 0 || n > 255 then\n lexer_error \"Int8 overflow\" v lexbuf\n else\n char_of_int n\n\n let read_list read_cell v lexbuf =\n List.rev (read_list_rev read_cell v lexbuf)\n\n let array_of_rev_list l =\n match l with\n [] -> [| |]\n | x :: tl ->\n let len = List.length l in\n let a = Array.make len x in\n let r = ref tl in\n for i = len - 2 downto 0 do\n a.(i) <- List.hd !r;\n r := List.tl !r\n done;\n a\n\n let read_array read_cell v lexbuf =\n let l = read_list_rev read_cell v lexbuf in\n array_of_rev_list l\n\n (* Read a JSON object, reading the keys into OCaml strings\n (provided for backward compatibility) *)\n let read_fields read_field init_acc v =\n read_abstract_fields read_ident read_field init_acc v\n\n let finish v lexbuf =\n read_space v lexbuf;\n if not (read_eof lexbuf) then\n long_error \"Junk after end of JSON value:\" v lexbuf\n\n let init_lexer = init_lexer\n\n let from_lexbuf v ?(stream = false) lexbuf =\n read_space v lexbuf;\n\n let x =\n if read_eof lexbuf then\n raise End_of_input\n else\n read_json v lexbuf\n in\n\n if not stream then\n finish v lexbuf;\n\n x\n\n\n let from_string ?buf ?fname ?lnum s =\n try\n let lexbuf = Lexing.from_string s in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_channel ?buf ?fname ?lnum ic =\n try\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n try\n let x = from_channel ?buf ?fname ?lnum ic in\n close_in ic;\n x\n with e ->\n close_in_noerr ic;\n raise e\n\n exception Finally of exn * exn\n\n let stream_from_lexbuf v ?(fin = fun () -> ()) lexbuf =\n let stream = Some true in\n let f i =\n try Some (from_lexbuf v ?stream lexbuf)\n with\n End_of_input ->\n fin ();\n None\n | e ->\n (try fin () with fin_e -> raise (Finally (e, fin_e)));\n raise e\n in\n Stream.from f\n\n let stream_from_string ?buf ?fname ?lnum s =\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v (Lexing.from_string s)\n\n let stream_from_channel ?buf ?fin ?fname ?lnum ic =\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ?fin lexbuf\n\n let stream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ~fin lexbuf\n\n type json_line = [ `Json of t | `Exn of exn ]\n\n let linestream_from_channel\n ?buf ?(fin = fun () -> ()) ?fname ?lnum:(lnum0 = 1) ic =\n let buf =\n match buf with\n None -> Some (Bi_outbuf.create 256)\n | Some _ -> buf\n in\n let f i =\n try\n let line = input_line ic in\n let lnum = lnum0 + i in\n Some (`Json (from_string ?buf ?fname ~lnum line))\n with\n End_of_file -> fin (); None\n | e -> Some (`Exn e)\n in\n Stream.from f\n\n let linestream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n linestream_from_channel ?buf ~fin ?fname ?lnum ic\n\n let prettify ?std s =\n pretty_to_string ?std (from_string s)\n\n let compact ?std s =\n to_string (from_string s)\n\n let validate_json _path _value = None\n\n\n# 3411 \"lib/read.ml\"\n# 39 \"yojson.cppo.ml\"\nmodule Util =\nstruct\n# 1 \"util.ml\"\nexception Type_error of string * t\n\nlet typeof = function\n | `Assoc _ -> \"object\"\n | `Bool _ -> \"bool\"\n | `Float _ -> \"float\"\n | `Int _ -> \"int\"\n | `List _ -> \"array\"\n | `Null -> \"null\"\n | `String _ -> \"string\"\n | `Intlit _ -> \"intlit\"\n | `Tuple _ -> \"tuple\"\n | `Variant _ -> \"variant\"\n\nlet typerr msg js = raise (Type_error (msg ^ typeof js, js))\n\nexception Undefined of string * t\n\nlet ( |> ) = ( |> )\n\nlet assoc name obj =\n try List.assoc name obj\n with Not_found -> `Null\n\nlet member name = function\n | `Assoc obj -> assoc name obj\n | js -> typerr (\"Can't get member '\" ^ name ^ \"' of non-object type \") js\n\nlet index i = function\n | `List l as js ->\n let len = List.length l in\n let wrapped_index = if i < 0 then len + i else i in\n if wrapped_index < 0 || wrapped_index >= len then\n raise (Undefined (\"Index \" ^ string_of_int i ^ \" out of bounds\", js))\n else List.nth l wrapped_index\n | js -> typerr (\"Can't get index \" ^ string_of_int i\n ^ \" of non-array type \") js\n\nlet map f = function\n | `List l -> `List (List.map f l)\n | js -> typerr \"Can't map function over non-array type \" js\n\nlet to_assoc = function\n | `Assoc obj -> obj\n | js -> typerr \"Expected object, got \" js\n\nlet to_option f = function\n | `Null -> None\n | x -> Some (f x)\n\nlet to_bool = function\n | `Bool b -> b\n | js -> typerr \"Expected bool, got \" js\n\nlet to_bool_option = function\n | `Bool b -> Some b\n | `Null -> None\n | js -> typerr \"Expected bool or null, got \" js\n\nlet to_number = function\n | `Int i -> float i\n | `Float f -> f\n | js -> typerr \"Expected number, got \" js\n\nlet to_number_option = function\n | `Int i -> Some (float i)\n | `Float f -> Some f\n | `Null -> None\n | js -> typerr \"Expected number or null, got \" js\n\nlet to_float = function\n | `Float f -> f\n | js -> typerr \"Expected float, got \" js\n\nlet to_float_option = function\n | `Float f -> Some f\n | `Null -> None\n | js -> typerr \"Expected float or null, got \" js\n\nlet to_int = function\n | `Int i -> i\n | js -> typerr \"Expected int, got \" js\n\nlet to_int_option = function\n | `Int i -> Some i\n | `Null -> None\n | js -> typerr \"Expected int or null, got \" js\n\nlet to_list = function\n | `List l -> l\n | js -> typerr \"Expected array, got \" js\n\nlet to_string = function\n | `String s -> s\n | js -> typerr \"Expected string, got \" js\n\nlet to_string_option = function\n | `String s -> Some s\n | `Null -> None\n | js -> typerr \"Expected string or null, got \" js\n\nlet convert_each f = function\n | `List l -> List.map f l\n | js -> typerr \"Can't convert each element of non-array type \" js\n\n\nlet rec rev_filter_map f acc l =\n match l with\n [] -> acc\n | x :: tl ->\n match f x with\n None -> rev_filter_map f acc tl\n | Some y -> rev_filter_map f (y :: acc) tl\n\nlet filter_map f l =\n List.rev (rev_filter_map f [] l)\n\nlet rec rev_flatten acc l =\n match l with\n [] -> acc\n | x :: tl ->\n match x with\n `List l2 -> rev_flatten (List.rev_append l2 acc) tl\n | _ -> rev_flatten acc tl\n\nlet flatten l =\n List.rev (rev_flatten [] l)\n\nlet filter_index i l =\n filter_map (\n function\n `List l ->\n (try Some (List.nth l i)\n with _ -> None)\n | _ -> None\n ) l\n\nlet filter_list l =\n filter_map (\n function\n `List l -> Some l\n | _ -> None\n ) l\n\nlet filter_member k l =\n filter_map (\n function\n `Assoc l ->\n (try Some (List.assoc k l)\n with _ -> None)\n | _ -> None\n ) l\n\nlet filter_assoc l =\n filter_map (\n function\n `Assoc l -> Some l\n | _ -> None\n ) l\n\nlet filter_bool l =\n filter_map (\n function\n `Bool x -> Some x\n | _ -> None\n ) l\n\nlet filter_int l =\n filter_map (\n function\n `Int x -> Some x\n | _ -> None\n ) l\n\nlet filter_float l =\n filter_map (\n function\n `Float x -> Some x\n | _ -> None\n ) l\n\nlet filter_number l =\n filter_map (\n function\n `Int x -> Some (float x)\n | `Float x -> Some x\n | _ -> None\n ) l\n\nlet filter_string l =\n filter_map (\n function\n `String x -> Some x\n | _ -> None\n ) l\n\nlet keys o =\n to_assoc o |> List.map (fun (key, _) -> key)\n\nlet values o =\n to_assoc o |> List.map (fun (_, value) -> value)\n\nlet combine (first : t) (second : t) =\n match (first, second) with\n | (`Assoc a, `Assoc b) -> (`Assoc (a @ b) : t)\n | (a, b) -> raise (Invalid_argument \"Expected two objects, check inputs\")\n# 42 \"yojson.cppo.ml\"\nend\n# 46 \"yojson.cppo.ml\"\nend\n\nmodule Safe =\nstruct\n# 1 \"type.ml\"\n(** {3 Type of the JSON tree} *)\n\ntype t =\n [\n | `Null\n | `Bool of bool\n \n# 8 \"type.ml\"\n | `Int of int\n \n# 11 \"type.ml\"\n | `Intlit of string\n \n# 14 \"type.ml\"\n | `Float of float\n \n# 20 \"type.ml\"\n | `String of string\n \n# 25 \"type.ml\"\n | `Assoc of (string * t) list\n | `List of t list\n \n# 28 \"type.ml\"\n | `Tuple of t list\n \n# 31 \"type.ml\"\n | `Variant of (string * t option)\n \n# 33 \"type.ml\"\n ]\n(**\nAll possible cases defined in Yojson:\n- `Null: JSON null\n- `Bool of bool: JSON boolean\n- `Int of int: JSON number without decimal point or exponent.\n- `Intlit of string: JSON number without decimal point or exponent,\n\t preserved as a string.\n- `Float of float: JSON number, Infinity, -Infinity or NaN.\n- `Floatlit of string: JSON number, Infinity, -Infinity or NaN,\n\t preserved as a string.\n- `String of string: JSON string. Bytes in the range 128-255 are preserved\n\t as-is without encoding validation for both reading\n\t and writing.\n- `Stringlit of string: JSON string literal including the double quotes.\n- `Assoc of (string * json) list: JSON object.\n- `List of json list: JSON array.\n- `Tuple of json list: Tuple (non-standard extension of JSON).\n\t Syntax: [(\"abc\", 123)].\n- `Variant of (string * json option): Variant (non-standard extension of JSON).\n\t Syntax: [<\"Foo\">] or [<\"Bar\":123>].\n*)\n\ntype json = t [@@deprecated \"json types are being renamed and will be removed in the next Yojson major version. Use type t instead\"]\n(**\n * Compatibility type alias for type `t`\n *)\n\n(*\n Note to adventurers: ocamldoc does not support inline comments\n on each polymorphic variant, and cppo doesn't allow to concatenate\n comments, so it would be complicated to document only the\n cases that are preserved by cppo in the type definition.\n*)\n# 1 \"safe.ml\"\nlet rec to_basic : t -> Basic.t = function\n `Null\n | `Bool _\n | `Int _\n | `Float _\n | `String _ as x -> x\n | `Intlit s -> `String s\n | `List l\n | `Tuple l ->\n `List (List.rev (List.rev_map to_basic l))\n | `Assoc l ->\n `Assoc (List.rev (List.rev_map (fun (k, v) -> (k, to_basic v)) l))\n | `Variant (k, None) -> `String k\n | `Variant (k, Some v) -> `List [ `String k; to_basic v ]\n# 1 \"write.ml\"\n(* included: type.ml *)\n\nlet hex n =\n Char.chr (\n if n < 10 then n + 48\n else n + 87\n )\n\nlet write_special src start stop ob str =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n Bi_outbuf.add_string ob str;\n start := stop + 1\n\nlet write_control_char src start stop ob c =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n let i = Bi_outbuf.alloc ob 6 in\n let dst = ob.o_s in\n Bytes.blit_string \"\\\\u00\" 0 dst i 4;\n Bytes.set dst (i+4) (hex (Char.code c lsr 4));\n Bytes.set dst (i+5) (hex (Char.code c land 0xf));\n start := stop + 1\n\nlet finish_string src start ob =\n try\n Bi_outbuf.add_substring ob src !start (String.length src - !start)\n with exc ->\n Printf.eprintf \"src=%S start=%i len=%i\\n%!\"\n src !start (String.length src - !start);\n raise exc\n\nlet write_string_body ob s =\n let start = ref 0 in\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '\"' -> write_special s start i ob \"\\\\\\\"\"\n | '\\\\' -> write_special s start i ob \"\\\\\\\\\"\n | '\\b' -> write_special s start i ob \"\\\\b\"\n | '\\012' -> write_special s start i ob \"\\\\f\"\n | '\\n' -> write_special s start i ob \"\\\\n\"\n | '\\r' -> write_special s start i ob \"\\\\r\"\n | '\\t' -> write_special s start i ob \"\\\\t\"\n | '\\x00'..'\\x1F'\n | '\\x7F' as c -> write_control_char s start i ob c\n | _ -> ()\n done;\n finish_string s start ob\n\nlet write_string ob s =\n Bi_outbuf.add_char ob '\"';\n write_string_body ob s;\n Bi_outbuf.add_char ob '\"'\n\nlet json_string_of_string s =\n let ob = Bi_outbuf.create 10 in\n write_string ob s;\n Bi_outbuf.contents ob\n\nlet test_string () =\n let s = Bytes.create 256 in\n for i = 0 to 255 do\n Bytes.set s i (Char.chr i)\n done;\n json_string_of_string (Bytes.to_string s)\n\n\nlet write_null ob () =\n Bi_outbuf.add_string ob \"null\"\n\nlet write_bool ob x =\n Bi_outbuf.add_string ob (if x then \"true\" else \"false\")\n\n\nlet max_digits =\n max\n (String.length (string_of_int max_int))\n (String.length (string_of_int min_int))\n\nlet dec n =\n Char.chr (n + 48)\n\nlet rec write_digits s pos x =\n if x = 0 then pos\n else\n let d = x mod 10 in\n let pos = write_digits s pos (x / 10) in\n Bytes.set s pos (dec (abs d));\n pos + 1\n\nlet write_int ob x =\n Bi_outbuf.extend ob max_digits;\n if x > 0 then\n ob.o_len <- write_digits ob.o_s ob.o_len x\n else if x < 0 then (\n let s = ob.o_s in\n let pos = ob.o_len in\n Bytes.set s pos '-';\n ob.o_len <- write_digits s (pos + 1) x\n )\n else\n Bi_outbuf.add_char ob '0'\n\n\nlet json_string_of_int i =\n string_of_int i\n\n\n(*\n Ensure that the float is not printed as an int.\n This is not required by JSON, but useful in order to guarantee\n reversibility.\n*)\nlet float_needs_period s =\n try\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '0'..'9' | '-' -> ()\n | _ -> raise Exit\n done;\n true\n with Exit ->\n false\n\n(*\n Both write_float_fast and write_float guarantee\n that a sufficient number of digits are printed in order to\n allow reversibility.\n\n The _fast version is faster but often produces unnecessarily long numbers.\n*)\nlet write_float_fast ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_normal_float_prec significant_figures ob x =\n let open Printf in\n let s =\n match significant_figures with\n 1 -> sprintf \"%.1g\" x\n | 2 -> sprintf \"%.2g\" x\n | 3 -> sprintf \"%.3g\" x\n | 4 -> sprintf \"%.4g\" x\n | 5 -> sprintf \"%.5g\" x\n | 6 -> sprintf \"%.6g\" x\n | 7 -> sprintf \"%.7g\" x\n | 8 -> sprintf \"%.8g\" x\n | 9 -> sprintf \"%.9g\" x\n | 10 -> sprintf \"%.10g\" x\n | 11 -> sprintf \"%.11g\" x\n | 12 -> sprintf \"%.12g\" x\n | 13 -> sprintf \"%.13g\" x\n | 14 -> sprintf \"%.14g\" x\n | 15 -> sprintf \"%.15g\" x\n | 16 -> sprintf \"%.16g\" x\n | _ -> sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_float ob x;\n Bi_outbuf.contents ob\n\n\nlet write_std_float_fast ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet std_json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_std_float ob x;\n Bi_outbuf.contents ob\n\n\nlet test_float () =\n let l = [ 0.; 1.; -1. ] in\n let l = l @ List.map (fun x -> 2. *. x +. 1.) l in\n let l = l @ List.map (fun x -> x /. sqrt 2.) l in\n let l = l @ List.map (fun x -> x *. sqrt 3.) l in\n let l = l @ List.map cos l in\n let l = l @ List.map (fun x -> x *. 1.23e50) l in\n let l = l @ [ infinity; neg_infinity ] in\n List.iter (\n fun x ->\n let s = Printf.sprintf \"%.17g\" x in\n let y = float_of_string s in\n Printf.printf \"%g %g %S %B\\n\" x y s (x = y)\n )\n l\n\n(*\nlet () = test_float ()\n*)\n\nlet write_intlit = Bi_outbuf.add_string\nlet write_floatlit = Bi_outbuf.add_string\nlet write_stringlit = Bi_outbuf.add_string\n\nlet rec iter2_aux f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_sep x;\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet iter2 f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet f_sep ob =\n Bi_outbuf.add_char ob ','\n\nlet rec write_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 299 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 302 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 305 \"write.ml\"\n | `Float f -> write_float ob f\n \n# 311 \"write.ml\"\n | `String s -> write_string ob s\n \n# 316 \"write.ml\"\n | `Assoc l -> write_assoc ob l\n | `List l -> write_list ob l\n \n# 319 \"write.ml\"\n | `Tuple l -> write_tuple ob l\n \n# 322 \"write.ml\"\n | `Variant (s, o) -> write_variant ob s o\n\n# 325 \"write.ml\"\nand write_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 341 \"write.ml\"\nand write_tuple ob l =\n Bi_outbuf.add_char ob '(';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ')'\n\n# 348 \"write.ml\"\nand write_variant ob s o =\n Bi_outbuf.add_char ob '<';\n write_string ob s;\n (match o with\n None -> ()\n | Some x ->\n Bi_outbuf.add_char ob ':';\n write_json ob x\n );\n Bi_outbuf.add_char ob '>'\n\n# 360 \"write.ml\"\nlet write_t = write_json\n\nlet rec write_std_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 367 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 370 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 373 \"write.ml\"\n | `Float f -> write_std_float ob f\n \n# 379 \"write.ml\"\n | `String s -> write_string ob s\n \n# 384 \"write.ml\"\n | `Assoc l -> write_std_assoc ob l\n | `List l -> write_std_list ob l\n \n# 387 \"write.ml\"\n | `Tuple l -> write_std_tuple ob l\n \n# 390 \"write.ml\"\n | `Variant (s, o) -> write_std_variant ob s o\n\n# 393 \"write.ml\"\nand write_std_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_std_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_std_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\nand write_std_tuple ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 414 \"write.ml\"\nand write_std_variant ob s o =\n match o with\n None -> write_string ob s\n | Some x ->\n Bi_outbuf.add_char ob '[';\n write_string ob s;\n Bi_outbuf.add_char ob ',';\n write_std_json ob x;\n Bi_outbuf.add_char ob ']'\n\n\n# 426 \"write.ml\"\nlet to_outbuf ?(std = false) ob x =\n if std then (\n if not (is_object_or_array x) then\n json_error \"Root is not an object or array\"\n else\n write_std_json ob x\n )\n else\n write_json ob x\n\n\nlet to_string ?buf ?(len = 256) ?std x =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n to_outbuf ?std ob x;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet to_channel ?buf ?len ?std oc x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_channel_writer ob\n\nlet to_output ?buf ?len ?std out x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_output_writer ?len out\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_output_writer ob\n\nlet to_file ?len ?std file x =\n let oc = open_out file in\n try\n to_channel ?len ?std oc x;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\nlet stream_to_outbuf ?std ob st =\n Stream.iter (to_outbuf ?std ob) st\n\nlet stream_to_string ?buf ?(len = 256) ?std st =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n stream_to_outbuf ?std ob st;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet stream_to_channel ?buf ?len ?std oc st =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n stream_to_outbuf ?std ob st;\n Bi_outbuf.flush_channel_writer ob\n\nlet stream_to_file ?len ?std file st =\n let oc = open_out file in\n try\n stream_to_channel ?len ?std oc st;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\n\nlet rec sort = function\n | `Assoc l ->\n let l = List.rev (List.rev_map (fun (k, v) -> (k, sort v)) l) in\n `Assoc (List.stable_sort (fun (a, _) (b, _) -> String.compare a b) l)\n | `List l ->\n `List (List.rev (List.rev_map sort l))\n \n# 519 \"write.ml\"\n | `Tuple l ->\n `Tuple (List.rev (List.rev_map sort l))\n \n# 523 \"write.ml\"\n | `Variant (k, Some v) as x ->\n let v' = sort v in\n if v == v' then x\n else\n `Variant (k, Some v')\n \n# 529 \"write.ml\"\n | x -> x\n# 1 \"monomorphic.ml\"\nlet rec pp fmt =\n function\n | `Null -> Format.pp_print_string fmt \"`Null\"\n | `Bool x ->\n Format.fprintf fmt \"`Bool (@[\";\n Format.fprintf fmt \"%B\" x;\n Format.fprintf fmt \"@])\"\n \n# 9 \"monomorphic.ml\"\n | `Int x ->\n Format.fprintf fmt \"`Int (@[\";\n Format.fprintf fmt \"%d\" x;\n Format.fprintf fmt \"@])\"\n \n# 15 \"monomorphic.ml\"\n | `Intlit x ->\n Format.fprintf fmt \"`Intlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 21 \"monomorphic.ml\"\n | `Float x ->\n Format.fprintf fmt \"`Float (@[\";\n Format.fprintf fmt \"%F\" x;\n Format.fprintf fmt \"@])\"\n \n# 33 \"monomorphic.ml\"\n | `String x ->\n Format.fprintf fmt \"`String (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 44 \"monomorphic.ml\"\n | `Assoc xs ->\n Format.fprintf fmt \"`Assoc (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep (key, value) ->\n if sep then\n Format.fprintf fmt \";@ \";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" key;\n Format.fprintf fmt \",@ \";\n pp fmt value;\n Format.fprintf fmt \"@])\";\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n | `List xs ->\n Format.fprintf fmt \"`List (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep x ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt x;\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 71 \"monomorphic.ml\"\n | `Tuple tup ->\n Format.fprintf fmt \"`Tuple (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep e ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt e;\n true) false tup);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 84 \"monomorphic.ml\"\n | `Variant (name, value) ->\n Format.fprintf fmt \"`Variant (@[\";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" name;\n Format.fprintf fmt \",@ \";\n (match value with\n | None -> Format.pp_print_string fmt \"None\"\n | Some x ->\n Format.pp_print_string fmt \"(Some \";\n pp fmt x;\n Format.pp_print_string fmt \")\");\n Format.fprintf fmt \"@])\";\n Format.fprintf fmt \"@])\"\n\n# 99 \"monomorphic.ml\"\nlet show x =\n Format.asprintf \"%a\" pp x\n\nlet rec equal a b =\n match a, b with\n | `Null, `Null -> true\n | `Bool a, `Bool b -> a = b\n \n# 107 \"monomorphic.ml\"\n | `Int a, `Int b -> a = b\n \n# 110 \"monomorphic.ml\"\n | `Intlit a, `Intlit b -> a = b\n \n# 113 \"monomorphic.ml\"\n | `Float a, `Float b -> a = b\n \n# 119 \"monomorphic.ml\"\n | `String a, `String b -> a = b\n \n# 124 \"monomorphic.ml\"\n | `Assoc xs, `Assoc ys ->\n let compare_keys = fun (key, _) (key', _) -> String.compare key key' in\n let xs = List.stable_sort compare_keys xs in\n let ys = List.stable_sort compare_keys ys in\n (match List.for_all2 (fun (key, value) (key', value') ->\n match key = key' with\n | false -> false\n | true -> equal value value') xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 137 \"monomorphic.ml\"\n | `Tuple xs, `Tuple ys\n \n# 139 \"monomorphic.ml\"\n | `List xs, `List ys ->\n (match List.for_all2 equal xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 146 \"monomorphic.ml\"\n | `Variant (name, value), `Variant (name', value') ->\n (match name = name' with\n | false -> false\n | true ->\n match value, value' with\n | None, None -> true\n | Some x, Some y -> equal x y\n | _ -> false)\n \n# 155 \"monomorphic.ml\"\n | _ -> false\n# 1 \"write2.ml\"\nlet pretty_format ?std (x : t) =\n Pretty.format ?std (x :> json_max)\n\nlet pretty_print ?std out (x : t) =\n Easy_format.Pretty.to_formatter out (pretty_format ?std x)\n\nlet pretty_to_string ?std (x : t) =\n Pretty.to_string ?std (x :> json_max)\n\nlet pretty_to_channel ?std oc (x : t) =\n Pretty.to_channel ?std oc (x :> json_max)\n\n# 1 \"lib/read.mll\"\n \n \n# 2 \"lib/read.mll\"\n module Lexing =\n (*\n We override Lexing.engine in order to avoid creating a new position\n record each time a rule is matched.\n This reduces total parsing time by about 31%.\n *)\n struct\n include Lexing\n\n external c_engine : lex_tables -> int -> lexbuf -> int = \"caml_lex_engine\"\n\n let engine tbl state buf =\n let result = c_engine tbl state buf in\n (*\n if result >= 0 then begin\n buf.lex_start_p <- buf.lex_curr_p;\n buf.lex_curr_p <- {buf.lex_curr_p\n with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n end;\n *)\n result\n end\n\n open Printf\n open Lexing\n\n (* see description in common.mli *)\n type lexer_state = Lexer_state.t = {\n buf : Bi_outbuf.t;\n mutable lnum : int;\n mutable bol : int;\n mutable fname : string option;\n }\n\n let dec c =\n Char.code c - 48\n\n let hex c =\n match c with\n '0'..'9' -> int_of_char c - int_of_char '0'\n | 'a'..'f' -> int_of_char c - int_of_char 'a' + 10\n | 'A'..'F' -> int_of_char c - int_of_char 'A' + 10\n | _ -> assert false\n\n let custom_error descr v lexbuf =\n let offs = lexbuf.lex_abs_pos - 1 in\n let bol = v.bol in\n let pos1 = offs + lexbuf.lex_start_pos - bol - 1 in\n let pos2 = max pos1 (offs + lexbuf.lex_curr_pos - bol) in\n let file_line =\n match v.fname with\n None -> \"Line\"\n | Some s ->\n sprintf \"File %s, line\" s\n in\n let bytes =\n if pos1 = pos2 then\n sprintf \"byte %i\" (pos1+1)\n else\n sprintf \"bytes %i-%i\" (pos1+1) (pos2+1)\n in\n let msg = sprintf \"%s %i, %s:\\n%s\" file_line v.lnum bytes descr in\n json_error msg\n\n\n let lexer_error descr v lexbuf =\n custom_error\n (sprintf \"%s '%s'\" descr (Lexing.lexeme lexbuf))\n v lexbuf\n\n let read_junk = ref (fun _ -> assert false)\n\n let long_error descr v lexbuf =\n let junk = Lexing.lexeme lexbuf in\n let extra_junk = !read_junk lexbuf in\n custom_error\n (sprintf \"%s '%s%s'\" descr junk extra_junk)\n v lexbuf\n\n let min10 = min_int / 10 - (if min_int mod 10 = 0 then 0 else 1)\n let max10 = max_int / 10 + (if max_int mod 10 = 0 then 0 else 1)\n\n exception Int_overflow\n\n let extract_positive_int lexbuf =\n let start = lexbuf.lex_start_pos in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n >= max10 then\n raise Int_overflow\n else\n n := 10 * !n + dec (Bytes.get s i)\n done;\n if !n < 0 then\n raise Int_overflow\n else\n !n\n\n let make_positive_int v lexbuf =\n \n# 104 \"lib/read.mll\"\n try `Int (extract_positive_int lexbuf)\n with Int_overflow ->\n \n# 108 \"lib/read.mll\"\n `Intlit (lexeme lexbuf)\n\n \n# 113 \"lib/read.mll\"\n let extract_negative_int lexbuf =\n let start = lexbuf.lex_start_pos + 1 in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n <= min10 then\n raise Int_overflow\n else\n n := 10 * !n - dec (Bytes.get s i)\n done;\n if !n > 0 then\n raise Int_overflow\n else\n !n\n\n let make_negative_int v lexbuf =\n \n# 131 \"lib/read.mll\"\n try `Int (extract_negative_int lexbuf)\n with Int_overflow ->\n \n# 135 \"lib/read.mll\"\n `Intlit (lexeme lexbuf)\n\n\n \n# 141 \"lib/read.mll\"\n let set_file_name v fname =\n v.fname <- fname\n\n let newline v lexbuf =\n v.lnum <- v.lnum + 1;\n v.bol <- lexbuf.lex_abs_pos + lexbuf.lex_curr_pos\n\n let add_lexeme buf lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n Bi_outbuf.add_subbytes buf lexbuf.lex_buffer lexbuf.lex_start_pos len\n\n let map_lexeme f lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n f (Bytes.to_string lexbuf.lex_buffer) lexbuf.lex_start_pos len\n\n type variant_kind = [ `Edgy_bracket | `Square_bracket | `Double_quote ]\n type tuple_kind = [ `Parenthesis | `Square_bracket ]\n\n\n# 161 \"lib/read.ml\"\n# 161 \"lib/read.ml\"\nlet __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\236\\255\\237\\255\\003\\000\\239\\255\\016\\000\\242\\255\\243\\255\\\n \\244\\255\\245\\255\\000\\000\\031\\000\\249\\255\\085\\000\\001\\000\\000\\000\\\n \\000\\000\\001\\000\\000\\000\\001\\000\\002\\000\\255\\255\\000\\000\\000\\000\\\n \\003\\000\\254\\255\\001\\000\\004\\000\\253\\255\\011\\000\\252\\255\\003\\000\\\n \\001\\000\\003\\000\\002\\000\\003\\000\\000\\000\\251\\255\\021\\000\\097\\000\\\n \\010\\000\\022\\000\\020\\000\\016\\000\\022\\000\\012\\000\\008\\000\\250\\255\\\n \\119\\000\\129\\000\\139\\000\\161\\000\\171\\000\\181\\000\\193\\000\\209\\000\\\n \\240\\255\\011\\000\\038\\000\\252\\255\\065\\000\\254\\255\\255\\255\\110\\000\\\n \\252\\255\\163\\000\\254\\255\\255\\255\\234\\000\\247\\255\\248\\255\\048\\001\\\n \\250\\255\\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\071\\001\\126\\001\\\n \\149\\001\\249\\255\\039\\000\\253\\255\\254\\255\\038\\000\\187\\001\\210\\001\\\n \\248\\001\\015\\002\\255\\255\\220\\000\\253\\255\\255\\255\\245\\000\\039\\002\\\n \\109\\002\\014\\001\\088\\002\\164\\002\\187\\002\\225\\002\\013\\000\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\014\\000\\253\\255\\254\\255\\255\\255\\030\\000\\\n \\253\\255\\254\\255\\255\\255\\015\\000\\253\\255\\254\\255\\255\\255\\017\\001\\\n \\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\019\\000\\252\\255\\253\\255\\\n \\254\\255\\015\\000\\255\\255\\016\\000\\255\\255\\008\\001\\005\\000\\253\\255\\\n \\023\\000\\254\\255\\020\\000\\255\\255\\046\\000\\253\\255\\254\\255\\042\\000\\\n \\052\\000\\053\\000\\255\\255\\053\\000\\048\\000\\091\\000\\092\\000\\255\\255\\\n \\027\\001\\250\\255\\251\\255\\137\\000\\104\\000\\089\\000\\088\\000\\106\\000\\\n \\255\\255\\143\\000\\137\\000\\177\\000\\254\\255\\183\\000\\168\\000\\166\\000\\\n \\183\\000\\002\\000\\253\\255\\177\\000\\172\\000\\187\\000\\004\\000\\252\\255\\\n \\053\\002\\251\\255\\252\\255\\253\\255\\103\\001\\255\\255\\248\\002\\254\\255\\\n \\006\\003\\030\\003\\252\\255\\253\\255\\254\\255\\255\\255\\040\\003\\050\\003\\\n \\074\\003\\252\\255\\253\\255\\254\\255\\255\\255\\061\\003\\084\\003\\108\\003\\\n \\249\\255\\250\\255\\251\\255\\244\\000\\120\\003\\142\\003\\179\\000\\194\\000\\\n \\015\\000\\255\\255\\190\\000\\188\\000\\187\\000\\193\\000\\183\\000\\179\\000\\\n \\254\\255\\191\\000\\201\\000\\200\\000\\196\\000\\203\\000\\193\\000\\189\\000\\\n \\253\\255\\157\\003\\095\\003\\174\\003\\196\\003\\206\\003\\216\\003\\228\\003\\\n \\239\\003\\060\\000\\253\\255\\254\\255\\255\\255\\012\\004\\252\\255\\253\\255\\\n \\087\\004\\255\\255\\145\\004\\252\\255\\253\\255\\221\\004\\255\\255\\229\\000\\\n \\253\\255\\254\\255\\255\\255\\231\\000\\253\\255\\254\\255\\255\\255\\002\\000\\\n \\255\\255\\018\\001\\252\\255\\253\\255\\254\\255\\255\\255\\034\\001\\253\\255\\\n \\254\\255\\255\\255\\000\\000\\255\\255\\003\\000\\254\\255\\255\\255\\038\\001\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\120\\001\\251\\255\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\208\\000\\253\\255\\254\\255\\255\\255\\211\\000\\253\\255\\\n \\254\\255\\255\\255\\189\\000\\255\\255\\143\\001\\252\\255\\253\\255\\254\\255\\\n \\255\\255\\013\\001\\253\\255\\254\\255\\255\\255\\095\\001\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\050\\001\\253\\255\\254\\255\\255\\255\\026\\001\\253\\255\\\n \\254\\255\\255\\255\\233\\000\\253\\255\\254\\255\\255\\255\\222\\000\\253\\255\\\n \\254\\255\\255\\255\\079\\005\\237\\255\\238\\255\\010\\000\\240\\255\\044\\001\\\n \\243\\255\\244\\255\\245\\255\\246\\255\\061\\001\\002\\004\\249\\255\\045\\005\\\n \\209\\000\\228\\000\\211\\000\\232\\000\\225\\000\\223\\000\\240\\000\\255\\255\\\n \\235\\000\\234\\000\\008\\001\\254\\255\\004\\001\\023\\001\\253\\255\\054\\001\\\n \\252\\255\\031\\001\\029\\001\\032\\001\\039\\001\\049\\001\\045\\001\\251\\255\\\n \\057\\001\\082\\001\\080\\001\\078\\001\\084\\001\\074\\001\\086\\001\\250\\255\\\n \\110\\005\\012\\004\\123\\005\\155\\005\\165\\005\\177\\005\\187\\005\\197\\005\\\n \\241\\255\\199\\001\\077\\002\\253\\255\\255\\255\\154\\002\\222\\005\\209\\005\\\n \\155\\002\\239\\005\\053\\006\\076\\006\\114\\006\\016\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\152\\006\\252\\255\\253\\255\\227\\006\\255\\255\\085\\007\\\n \\244\\255\\245\\255\\011\\000\\247\\255\\076\\002\\250\\255\\251\\255\\252\\255\\\n \\253\\255\\254\\255\\031\\002\\243\\005\\051\\007\\100\\001\\115\\001\\104\\001\\\n \\133\\001\\118\\001\\154\\001\\171\\001\\255\\255\\173\\001\\176\\001\\191\\001\\\n \\185\\001\\187\\001\\253\\001\\230\\001\\230\\001\\234\\001\\247\\001\\237\\001\\\n \\234\\001\\009\\002\\019\\002\\019\\002\\015\\002\\021\\002\\011\\002\\007\\002\\\n \\142\\006\\152\\006\\116\\007\\170\\007\\180\\007\\190\\007\\200\\007\\210\\007\\\n \\248\\255\\120\\002\\167\\002\\253\\255\\255\\255\\216\\002\\082\\007\\220\\007\\\n \\236\\002\\244\\007\\058\\008\\081\\008\\119\\008\\076\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\157\\008\\252\\255\\253\\255\\232\\008\\255\\255\\135\\002\\\n \\120\\002\\253\\255\\100\\002\\254\\255\\182\\002\\255\\255\\011\\002\\255\\255\\\n \\204\\002\\252\\255\\253\\255\\254\\255\\255\\255\\046\\002\\255\\255\\178\\002\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\023\\000\\255\\255\\183\\002\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\187\\002\\253\\255\\254\\255\\255\\255\\121\\002\\\n \\253\\255\\254\\255\\255\\255\\184\\002\\252\\255\\253\\255\\254\\255\\019\\000\\\n \\255\\255\\140\\001\\146\\001\\255\\255\\150\\001\\151\\001\\154\\001\\168\\001\\\n \\170\\001\\171\\001\\172\\001\\173\\001\\181\\001\\184\\001\\185\\001\\187\\001\\\n \\191\\001\\193\\001\\195\\001\\196\\001\\197\\001\\200\\001\\203\\001\\223\\001\\\n \\225\\001\\228\\001\\249\\001\\251\\001\\002\\002\\004\\002\\011\\002\\012\\002\\\n \\013\\002\\000\\000\";\n Lexing.lex_backtrk =\n \"\\255\\255\\255\\255\\255\\255\\017\\000\\255\\255\\019\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\008\\000\\008\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\\n \\255\\255\\014\\000\\255\\255\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\003\\000\\255\\255\\001\\000\\255\\255\\004\\000\\003\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\004\\000\\004\\000\\004\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\000\\000\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\003\\000\\005\\000\\005\\000\\005\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\003\\000\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\016\\000\\255\\255\\018\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\\n \\255\\255\\013\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\011\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\000\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\006\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\004\\000\\\n \\003\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\";\n Lexing.lex_default =\n \"\\001\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\057\\000\\060\\000\\000\\000\\060\\000\\000\\000\\000\\000\\065\\000\\\n \\000\\000\\065\\000\\000\\000\\000\\000\\070\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\084\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\094\\000\\000\\000\\000\\000\\097\\000\\255\\255\\\n \\255\\255\\097\\000\\255\\255\\255\\255\\255\\255\\255\\255\\104\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\109\\000\\000\\000\\000\\000\\000\\000\\113\\000\\\n \\000\\000\\000\\000\\000\\000\\117\\000\\000\\000\\000\\000\\000\\000\\121\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\126\\000\\000\\000\\000\\000\\\n \\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\000\\000\\138\\000\\000\\000\\142\\000\\000\\000\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\154\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\178\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\\n \\255\\255\\187\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\194\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\201\\000\\\n \\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\235\\000\\000\\000\\000\\000\\000\\000\\239\\000\\000\\000\\000\\000\\\n \\255\\255\\000\\000\\244\\000\\000\\000\\000\\000\\255\\255\\000\\000\\249\\000\\\n \\000\\000\\000\\000\\000\\000\\253\\000\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\003\\001\\000\\000\\000\\000\\000\\000\\000\\000\\008\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\017\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\022\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\028\\001\\000\\000\\000\\000\\000\\000\\032\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\038\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\043\\001\\000\\000\\000\\000\\000\\000\\047\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\052\\001\\000\\000\\000\\000\\000\\000\\056\\001\\000\\000\\\n \\000\\000\\000\\000\\060\\001\\000\\000\\000\\000\\000\\000\\064\\001\\000\\000\\\n \\000\\000\\000\\000\\067\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\121\\001\\125\\001\\000\\000\\000\\000\\128\\001\\255\\255\\255\\255\\\n \\128\\001\\255\\255\\255\\255\\255\\255\\255\\255\\135\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\140\\001\\000\\000\\000\\000\\255\\255\\000\\000\\144\\001\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\193\\001\\197\\001\\000\\000\\000\\000\\200\\001\\255\\255\\255\\255\\\n \\200\\001\\255\\255\\255\\255\\255\\255\\255\\255\\207\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\212\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\000\\000\\220\\001\\000\\000\\255\\255\\000\\000\\\n \\226\\001\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\233\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\240\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\245\\001\\000\\000\\000\\000\\000\\000\\249\\001\\\n \\000\\000\\000\\000\\000\\000\\252\\001\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\002\\002\\004\\002\\000\\000\\005\\002\\006\\002\\007\\002\\008\\002\\\n \\009\\002\\010\\002\\011\\002\\012\\002\\013\\002\\014\\002\\015\\002\\016\\002\\\n \\017\\002\\018\\002\\019\\002\\020\\002\\021\\002\\022\\002\\023\\002\\024\\002\\\n \\025\\002\\026\\002\\027\\002\\028\\002\\029\\002\\030\\002\\031\\002\\032\\002\\\n \\033\\002\\003\\002\";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\003\\000\\004\\000\\000\\000\\003\\000\\003\\000\\134\\000\\000\\000\\\n \\003\\000\\000\\000\\134\\000\\069\\001\\146\\001\\255\\255\\000\\000\\069\\001\\\n \\146\\001\\000\\000\\000\\000\\000\\000\\000\\000\\127\\000\\139\\000\\000\\000\\\n \\003\\000\\000\\000\\012\\000\\003\\000\\170\\000\\134\\000\\175\\000\\000\\000\\\n \\007\\000\\011\\001\\069\\001\\146\\001\\014\\001\\013\\000\\049\\000\\005\\000\\\n \\010\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\056\\000\\118\\000\\006\\000\\129\\000\\130\\000\\057\\000\\\n \\237\\001\\137\\000\\000\\002\\049\\000\\000\\000\\048\\000\\138\\000\\106\\000\\\n \\062\\000\\014\\000\\110\\000\\105\\000\\000\\000\\049\\000\\015\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\030\\000\\048\\000\\008\\000\\114\\000\\209\\000\\236\\000\\000\\001\\\n \\013\\001\\029\\000\\022\\000\\255\\255\\048\\000\\048\\000\\017\\000\\021\\000\\\n \\025\\000\\032\\000\\033\\000\\035\\000\\023\\000\\027\\000\\016\\000\\031\\000\\\n \\028\\000\\034\\000\\019\\000\\024\\000\\018\\000\\026\\000\\020\\000\\036\\000\\\n \\041\\000\\037\\000\\048\\000\\009\\000\\042\\000\\043\\000\\044\\000\\045\\000\\\n \\046\\000\\047\\000\\061\\000\\085\\000\\048\\000\\038\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\049\\000\\\n \\067\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\086\\000\\143\\000\\255\\255\\040\\000\\144\\000\\\n \\145\\000\\146\\000\\055\\000\\148\\000\\055\\000\\149\\000\\048\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\255\\255\\048\\000\\150\\000\\\n \\151\\000\\161\\000\\066\\000\\158\\000\\053\\000\\159\\000\\053\\000\\160\\000\\\n \\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\165\\000\\\n \\051\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\162\\000\\163\\000\\166\\000\\093\\000\\255\\255\\\n \\002\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\255\\255\\077\\000\\103\\000\\108\\000\\116\\000\\\n \\132\\000\\134\\000\\135\\000\\128\\000\\139\\000\\134\\000\\164\\000\\093\\000\\\n \\171\\000\\077\\000\\167\\000\\168\\000\\169\\000\\172\\000\\112\\000\\173\\000\\\n \\174\\000\\210\\000\\226\\000\\208\\000\\211\\000\\212\\000\\059\\000\\083\\000\\\n \\134\\000\\213\\000\\214\\000\\215\\000\\216\\000\\218\\000\\141\\000\\219\\000\\\n \\093\\000\\220\\000\\221\\000\\123\\000\\222\\000\\223\\000\\224\\000\\136\\000\\\n \\095\\000\\225\\000\\035\\001\\065\\001\\234\\000\\155\\000\\005\\001\\097\\001\\\n \\250\\000\\255\\255\\254\\000\\057\\001\\061\\001\\095\\001\\077\\000\\044\\001\\\n \\092\\001\\088\\001\\009\\001\\029\\001\\076\\000\\124\\000\\033\\001\\018\\001\\\n \\075\\000\\098\\000\\019\\001\\085\\001\\086\\001\\087\\001\\120\\001\\089\\001\\\n \\074\\000\\225\\000\\053\\001\\121\\001\\073\\000\\090\\001\\072\\000\\071\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\098\\000\\113\\001\\122\\000\\091\\001\\064\\000\\004\\001\\\n \\093\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\079\\000\\156\\000\\112\\001\\094\\001\\096\\001\\098\\001\\099\\001\\049\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\100\\001\\157\\000\\\n \\101\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\183\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\184\\000\\024\\001\\112\\001\\255\\255\\025\\001\\102\\001\\103\\001\\105\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\\n \\106\\001\\107\\001\\048\\001\\040\\001\\108\\001\\109\\001\\110\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\081\\000\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\111\\001\\\n \\027\\001\\255\\255\\171\\001\\031\\001\\170\\001\\023\\001\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\092\\000\\168\\001\\063\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\248\\000\\165\\001\\252\\000\\\n \\162\\001\\059\\001\\069\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\255\\255\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\039\\001\\042\\001\\255\\255\\163\\001\\\n \\164\\001\\120\\000\\002\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\166\\001\\055\\001\\153\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\007\\001\\167\\001\\164\\001\\169\\001\\016\\001\\164\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\089\\000\\051\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\090\\000\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\\n \\090\\000\\097\\000\\137\\001\\164\\001\\172\\001\\185\\001\\136\\001\\173\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\097\\000\\179\\000\\\n \\174\\001\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\046\\001\\\n \\175\\001\\176\\001\\180\\000\\164\\001\\184\\001\\181\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\124\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\192\\001\\178\\001\\\n \\021\\001\\179\\001\\097\\000\\193\\001\\180\\001\\181\\001\\182\\001\\183\\001\\\n \\164\\001\\216\\001\\255\\255\\097\\000\\184\\001\\216\\001\\209\\001\\097\\000\\\n \\223\\001\\097\\000\\208\\001\\230\\001\\003\\002\\097\\000\\219\\001\\037\\001\\\n \\216\\001\\217\\001\\003\\002\\220\\001\\216\\001\\097\\000\\003\\002\\003\\002\\\n \\216\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\216\\001\\\n \\003\\002\\126\\001\\003\\002\\003\\002\\003\\002\\003\\002\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\097\\000\\003\\002\\218\\001\\250\\001\\\n \\003\\002\\003\\002\\097\\000\\003\\002\\124\\001\\124\\001\\097\\000\\003\\002\\\n \\221\\001\\003\\002\\253\\001\\003\\002\\003\\002\\003\\002\\097\\000\\255\\255\\\n \\003\\002\\196\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\235\\001\\003\\002\\\n \\241\\001\\003\\002\\255\\001\\242\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\246\\001\\129\\001\\129\\001\\\n \\228\\001\\003\\002\\196\\001\\003\\002\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\003\\002\\198\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\003\\002\\003\\002\\003\\002\\196\\001\\234\\001\\\n \\134\\001\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\097\\000\\097\\000\\097\\000\\000\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\000\\000\\000\\000\\201\\001\\177\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\188\\000\\000\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\201\\001\\227\\001\\000\\000\\191\\000\\206\\001\\123\\001\\189\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\189\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\195\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\198\\000\\\n \\255\\255\\248\\001\\196\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\196\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\202\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\227\\000\\205\\000\\255\\255\\255\\255\\203\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\226\\000\\195\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\232\\001\\000\\000\\000\\000\\206\\000\\221\\001\\239\\001\\\n \\254\\001\\000\\000\\207\\000\\244\\001\\000\\000\\225\\000\\203\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\232\\000\\000\\000\\232\\000\\000\\000\\225\\001\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\217\\000\\\n \\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\225\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\000\\000\\230\\000\\\n \\000\\000\\230\\000\\000\\000\\228\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\000\\000\\228\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\186\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\241\\000\\000\\000\\\n \\113\\001\\000\\000\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\000\\000\\112\\001\\\n \\000\\000\\000\\000\\193\\000\\000\\000\\000\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\112\\001\\\n \\000\\000\\000\\000\\000\\000\\240\\000\\200\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\000\\000\\246\\000\\000\\000\\000\\000\\240\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\245\\000\\000\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\238\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\069\\001\\070\\001\\000\\000\\000\\000\\069\\001\\076\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\069\\001\\\n \\000\\000\\078\\001\\000\\000\\000\\000\\000\\000\\000\\000\\104\\001\\073\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\079\\001\\000\\000\\071\\001\\076\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\000\\000\\000\\000\\072\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\243\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\080\\001\\119\\001\\000\\000\\119\\001\\000\\000\\081\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\000\\000\\000\\000\\074\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\083\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\082\\001\\000\\000\\000\\000\\\n \\115\\001\\000\\000\\000\\000\\084\\001\\000\\000\\000\\000\\117\\001\\000\\000\\\n \\117\\001\\000\\000\\075\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\000\\000\\\n \\115\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\000\\000\\\n \\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\\n \\000\\000\\185\\001\\000\\000\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\184\\001\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\128\\001\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\128\\001\\128\\001\\000\\000\\000\\000\\068\\001\\\n \\128\\001\\128\\001\\128\\001\\127\\001\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\184\\001\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\000\\000\\128\\001\\127\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\128\\001\\128\\001\\128\\001\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\191\\001\\142\\001\\191\\001\\000\\000\\000\\000\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\\n \\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\141\\001\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\146\\001\\147\\001\\\n \\000\\000\\000\\000\\146\\001\\154\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\146\\001\\000\\000\\153\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\177\\001\\150\\001\\000\\000\\000\\000\\\n \\000\\000\\200\\001\\156\\001\\000\\000\\148\\001\\154\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\\n \\000\\000\\149\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\139\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\157\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\158\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\200\\001\\000\\000\\\n \\151\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\187\\001\\000\\000\\160\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\159\\001\\200\\001\\000\\000\\200\\001\\199\\001\\\n \\000\\000\\161\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\152\\001\\000\\000\\000\\000\\000\\000\\000\\000\\189\\001\\000\\000\\189\\001\\\n \\000\\000\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\145\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\\n \\200\\001\\199\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\\n \\200\\001\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\000\\000\\214\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\000\\000\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\211\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\000\\000\\255\\255\\003\\000\\000\\000\\134\\000\\255\\255\\\n \\003\\000\\255\\255\\134\\000\\069\\001\\146\\001\\057\\000\\255\\255\\069\\001\\\n \\146\\001\\255\\255\\255\\255\\255\\255\\255\\255\\125\\000\\138\\000\\255\\255\\\n \\000\\000\\255\\255\\000\\000\\003\\000\\169\\000\\134\\000\\174\\000\\255\\255\\\n \\000\\000\\010\\001\\069\\001\\146\\001\\012\\001\\000\\000\\010\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\005\\000\\115\\000\\000\\000\\125\\000\\129\\000\\005\\000\\\n \\236\\001\\136\\000\\255\\001\\038\\000\\255\\255\\010\\000\\136\\000\\102\\000\\\n \\058\\000\\000\\000\\107\\000\\102\\000\\255\\255\\011\\000\\000\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\029\\000\\038\\000\\000\\000\\111\\000\\208\\000\\233\\000\\255\\000\\\n \\012\\001\\015\\000\\017\\000\\060\\000\\011\\000\\010\\000\\000\\000\\020\\000\\\n \\024\\000\\031\\000\\032\\000\\034\\000\\022\\000\\026\\000\\000\\000\\014\\000\\\n \\027\\000\\033\\000\\018\\000\\023\\000\\000\\000\\016\\000\\019\\000\\035\\000\\\n \\040\\000\\036\\000\\038\\000\\000\\000\\041\\000\\042\\000\\043\\000\\044\\000\\\n \\045\\000\\046\\000\\058\\000\\082\\000\\011\\000\\013\\000\\013\\000\\013\\000\\\n \\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\039\\000\\\n \\063\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\085\\000\\140\\000\\060\\000\\013\\000\\143\\000\\\n \\144\\000\\145\\000\\048\\000\\147\\000\\048\\000\\148\\000\\039\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\065\\000\\039\\000\\149\\000\\\n \\150\\000\\156\\000\\063\\000\\157\\000\\051\\000\\158\\000\\051\\000\\159\\000\\\n \\050\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\155\\000\\\n \\050\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\161\\000\\162\\000\\155\\000\\091\\000\\065\\000\\\n \\000\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\057\\000\\068\\000\\102\\000\\107\\000\\115\\000\\\n \\131\\000\\133\\000\\133\\000\\125\\000\\138\\000\\133\\000\\163\\000\\094\\000\\\n \\165\\000\\068\\000\\166\\000\\167\\000\\168\\000\\171\\000\\111\\000\\172\\000\\\n \\173\\000\\206\\000\\203\\000\\207\\000\\210\\000\\211\\000\\058\\000\\082\\000\\\n \\133\\000\\212\\000\\213\\000\\214\\000\\215\\000\\217\\000\\140\\000\\218\\000\\\n \\097\\000\\219\\000\\220\\000\\119\\000\\221\\000\\222\\000\\223\\000\\133\\000\\\n \\091\\000\\203\\000\\034\\001\\062\\001\\233\\000\\152\\000\\001\\001\\080\\001\\\n \\247\\000\\060\\000\\251\\000\\054\\001\\058\\001\\081\\001\\068\\000\\041\\001\\\n \\082\\001\\083\\001\\006\\001\\026\\001\\068\\000\\119\\000\\030\\001\\015\\001\\\n \\068\\000\\094\\000\\015\\001\\084\\001\\085\\001\\086\\001\\071\\001\\088\\001\\\n \\068\\000\\203\\000\\050\\001\\071\\001\\068\\000\\089\\001\\068\\000\\068\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\097\\000\\076\\001\\119\\000\\090\\001\\063\\000\\001\\001\\\n \\092\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\152\\000\\076\\001\\093\\001\\095\\001\\097\\001\\098\\001\\045\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\099\\001\\152\\000\\\n \\100\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\180\\000\\\n \\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\\n \\180\\000\\020\\001\\076\\001\\065\\000\\020\\001\\101\\001\\102\\001\\104\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\105\\001\\106\\001\\045\\001\\036\\001\\107\\001\\108\\001\\109\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\110\\001\\\n \\026\\001\\121\\001\\157\\001\\030\\001\\158\\001\\020\\001\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\091\\000\\159\\001\\062\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\247\\000\\160\\001\\251\\000\\\n \\161\\001\\058\\001\\068\\000\\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\094\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\036\\001\\041\\001\\097\\000\\162\\001\\\n \\163\\001\\119\\000\\001\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\165\\001\\054\\001\\152\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\006\\001\\166\\001\\167\\001\\168\\001\\015\\001\\169\\001\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\050\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\089\\000\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\095\\000\\133\\001\\170\\001\\171\\001\\154\\001\\133\\001\\172\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\095\\000\\176\\000\\\n \\173\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\045\\001\\\n \\174\\001\\175\\001\\176\\000\\176\\001\\154\\001\\176\\000\\176\\000\\176\\000\\\n \\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\122\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\148\\001\\177\\001\\\n \\020\\001\\178\\001\\098\\000\\148\\001\\179\\001\\180\\001\\181\\001\\182\\001\\\n \\183\\001\\216\\001\\193\\001\\095\\000\\154\\001\\216\\001\\205\\001\\098\\000\\\n \\222\\001\\095\\000\\205\\001\\229\\001\\001\\002\\095\\000\\218\\001\\036\\001\\\n \\215\\001\\215\\001\\002\\002\\218\\001\\215\\001\\095\\000\\004\\002\\005\\002\\\n \\216\\001\\095\\000\\006\\002\\095\\000\\095\\000\\096\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\215\\001\\\n \\007\\002\\122\\001\\008\\002\\009\\002\\010\\002\\011\\002\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\098\\000\\012\\002\\215\\001\\247\\001\\\n \\013\\002\\014\\002\\098\\000\\015\\002\\125\\001\\128\\001\\098\\000\\016\\002\\\n \\220\\001\\017\\002\\251\\001\\018\\002\\019\\002\\020\\002\\098\\000\\121\\001\\\n \\021\\002\\194\\001\\098\\000\\022\\002\\098\\000\\098\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\099\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\231\\001\\023\\002\\\n \\238\\001\\024\\002\\251\\001\\238\\001\\025\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\243\\001\\125\\001\\128\\001\\\n \\224\\001\\026\\002\\197\\001\\027\\002\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\028\\002\\194\\001\\029\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\030\\002\\031\\002\\032\\002\\200\\001\\231\\001\\\n \\133\\001\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\255\\255\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\255\\255\\255\\255\\197\\001\\176\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\185\\000\\255\\255\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\200\\001\\224\\001\\255\\255\\185\\000\\205\\001\\122\\001\\185\\000\\185\\000\\\n \\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\\n \\191\\000\\191\\000\\191\\000\\191\\000\\192\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\192\\000\\\n \\193\\001\\247\\001\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\\n \\192\\000\\192\\000\\192\\000\\192\\000\\198\\000\\198\\000\\198\\000\\198\\000\\\n \\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\199\\000\\226\\000\\\n \\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\\n \\226\\000\\199\\000\\125\\001\\128\\001\\199\\000\\199\\000\\199\\000\\199\\000\\\n \\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\204\\000\\194\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\231\\001\\255\\255\\255\\255\\199\\000\\220\\001\\238\\001\\\n \\251\\001\\255\\255\\199\\000\\243\\001\\255\\255\\204\\000\\205\\000\\205\\000\\\n \\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\\n \\225\\000\\255\\255\\225\\000\\255\\255\\224\\001\\225\\000\\225\\000\\225\\000\\\n \\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\205\\000\\\n \\197\\001\\255\\255\\255\\255\\255\\255\\255\\255\\204\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\200\\001\\255\\255\\255\\255\\228\\000\\\n \\255\\255\\228\\000\\255\\255\\227\\000\\228\\000\\228\\000\\228\\000\\228\\000\\\n \\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\\n \\230\\000\\230\\000\\255\\255\\227\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\185\\000\\232\\000\\\n \\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\\n \\232\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\237\\000\\255\\255\\\n \\077\\001\\255\\255\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\113\\001\\113\\001\\113\\001\\113\\001\\\n \\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\255\\255\\077\\001\\\n \\255\\255\\255\\255\\192\\000\\255\\255\\255\\255\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\077\\001\\\n \\255\\255\\255\\255\\255\\255\\237\\000\\199\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\255\\255\\242\\000\\255\\255\\255\\255\\240\\000\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\242\\000\\255\\255\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\237\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\066\\001\\066\\001\\255\\255\\255\\255\\066\\001\\079\\001\\079\\001\\079\\001\\\n \\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\\n \\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\079\\001\\066\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\066\\001\\066\\001\\\n \\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\\n \\066\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\066\\001\\112\\001\\255\\255\\112\\001\\255\\255\\066\\001\\112\\001\\112\\001\\\n \\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\\n \\255\\255\\255\\255\\066\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\066\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\\n \\114\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\115\\001\\255\\255\\\n \\115\\001\\255\\255\\066\\001\\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\\n \\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\255\\255\\\n \\114\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\\n \\117\\001\\117\\001\\117\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\119\\001\\119\\001\\119\\001\\\n \\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\255\\255\\\n \\126\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\127\\001\\127\\001\\127\\001\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\\n \\255\\255\\155\\001\\255\\255\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\155\\001\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\126\\001\\255\\255\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\129\\001\\126\\001\\255\\255\\255\\255\\066\\001\\\n \\126\\001\\129\\001\\126\\001\\126\\001\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\155\\001\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\255\\255\\129\\001\\129\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\131\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\184\\001\\138\\001\\184\\001\\255\\255\\255\\255\\184\\001\\184\\001\\\n \\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\\n \\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\\n \\185\\001\\185\\001\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\138\\001\\\n \\255\\255\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\141\\001\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\143\\001\\143\\001\\\n \\255\\255\\255\\255\\143\\001\\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\\n \\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\156\\001\\143\\001\\255\\255\\255\\255\\\n \\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\143\\001\\143\\001\\143\\001\\\n \\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\255\\255\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\143\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\198\\001\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\198\\001\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\186\\001\\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\255\\255\\255\\255\\143\\001\\198\\001\\255\\255\\198\\001\\198\\001\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\187\\001\\255\\255\\187\\001\\\n \\255\\255\\186\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\\n \\187\\001\\187\\001\\187\\001\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\189\\001\\189\\001\\\n \\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\\n \\191\\001\\191\\001\\191\\001\\191\\001\\199\\001\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\201\\001\\255\\255\\\n \\201\\001\\201\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\255\\255\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\213\\001\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec read_json v lexbuf =\n __ocaml_lex_read_json_rec v lexbuf 0\nand __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 188 \"lib/read.mll\"\n \n# 188 \"lib/read.mll\"\n ( `Bool true )\n\n# 1032 \"lib/read.ml\"\n\n \n# 1033 \"lib/read.ml\"\n | 1 ->\n\n# 189 \"lib/read.mll\"\n \n# 189 \"lib/read.mll\"\n ( `Bool false )\n\n# 1037 \"lib/read.ml\"\n\n \n# 1038 \"lib/read.ml\"\n | 2 ->\n\n# 190 \"lib/read.mll\"\n \n# 190 \"lib/read.mll\"\n ( `Null )\n\n# 1042 \"lib/read.ml\"\n\n \n# 1043 \"lib/read.ml\"\n | 3 ->\n\n# 191 \"lib/read.mll\"\n \n# 191 \"lib/read.mll\"\n (\n \n# 193 \"lib/read.mll\"\n `Float nan\n \n# 197 \"lib/read.mll\"\n )\n\n# 1053 \"lib/read.ml\"\n\n \n# 1054 \"lib/read.ml\"\n | 4 ->\n\n# 198 \"lib/read.mll\"\n \n# 198 \"lib/read.mll\"\n (\n \n# 200 \"lib/read.mll\"\n `Float infinity\n \n# 204 \"lib/read.mll\"\n )\n\n# 1064 \"lib/read.ml\"\n\n \n# 1065 \"lib/read.ml\"\n | 5 ->\n\n# 205 \"lib/read.mll\"\n \n# 205 \"lib/read.mll\"\n (\n \n# 207 \"lib/read.mll\"\n `Float neg_infinity\n \n# 211 \"lib/read.mll\"\n )\n\n# 1075 \"lib/read.ml\"\n\n \n# 1076 \"lib/read.ml\"\n | 6 ->\n\n# 212 \"lib/read.mll\"\n \n# 212 \"lib/read.mll\"\n (\n \n# 214 \"lib/read.mll\"\n Bi_outbuf.clear v.buf;\n `String (finish_string v lexbuf)\n \n# 219 \"lib/read.mll\"\n )\n\n# 1087 \"lib/read.ml\"\n\n \n# 1088 \"lib/read.ml\"\n | 7 ->\n\n# 220 \"lib/read.mll\"\n \n# 220 \"lib/read.mll\"\n ( make_positive_int v lexbuf )\n\n# 1092 \"lib/read.ml\"\n\n \n# 1093 \"lib/read.ml\"\n | 8 ->\n\n# 221 \"lib/read.mll\"\n \n# 221 \"lib/read.mll\"\n ( make_negative_int v lexbuf )\n\n# 1097 \"lib/read.ml\"\n\n \n# 1098 \"lib/read.ml\"\n | 9 ->\n\n# 222 \"lib/read.mll\"\n \n# 222 \"lib/read.mll\"\n (\n \n# 224 \"lib/read.mll\"\n `Float (float_of_string (lexeme lexbuf))\n \n# 228 \"lib/read.mll\"\n )\n\n# 1108 \"lib/read.ml\"\n\n \n# 1109 \"lib/read.ml\"\n | 10 ->\n\n# 230 \"lib/read.mll\"\n \n# 230 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n done;\n assert false\n with End_of_object ->\n `Assoc (List.rev !acc)\n )\n\n# 1135 \"lib/read.ml\"\n\n \n# 1136 \"lib/read.ml\"\n | 11 ->\n\n# 254 \"lib/read.mll\"\n \n# 254 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_json v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_json v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n `List (List.rev !acc)\n )\n\n# 1154 \"lib/read.ml\"\n\n \n# 1155 \"lib/read.ml\"\n | 12 ->\n\n# 270 \"lib/read.mll\"\n \n# 270 \"lib/read.mll\"\n (\n \n# 272 \"lib/read.mll\"\n let acc = ref [] in\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n acc := read_json v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n acc := read_json v lexbuf :: !acc;\n done;\n assert false\n with End_of_tuple ->\n `Tuple (List.rev !acc)\n \n# 289 \"lib/read.mll\"\n )\n\n# 1178 \"lib/read.ml\"\n\n \n# 1179 \"lib/read.ml\"\n | 13 ->\n\n# 291 \"lib/read.mll\"\n \n# 291 \"lib/read.mll\"\n (\n \n# 293 \"lib/read.mll\"\n read_space v lexbuf;\n let cons = read_ident v lexbuf in\n read_space v lexbuf;\n `Variant (cons, finish_variant v lexbuf)\n \n# 300 \"lib/read.mll\"\n )\n\n# 1192 \"lib/read.ml\"\n\n \n# 1193 \"lib/read.ml\"\n | 14 ->\n\n# 302 \"lib/read.mll\"\n \n# 302 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1197 \"lib/read.ml\"\n\n \n# 1198 \"lib/read.ml\"\n | 15 ->\n\n# 303 \"lib/read.mll\"\n \n# 303 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_json v lexbuf )\n\n# 1202 \"lib/read.ml\"\n\n \n# 1203 \"lib/read.ml\"\n | 16 ->\n\n# 304 \"lib/read.mll\"\n \n# 304 \"lib/read.mll\"\n ( newline v lexbuf; read_json v lexbuf )\n\n# 1207 \"lib/read.ml\"\n\n \n# 1208 \"lib/read.ml\"\n | 17 ->\n\n# 305 \"lib/read.mll\"\n \n# 305 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1212 \"lib/read.ml\"\n\n \n# 1213 \"lib/read.ml\"\n | 18 ->\n\n# 306 \"lib/read.mll\"\n \n# 306 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1217 \"lib/read.ml\"\n\n \n# 1218 \"lib/read.ml\"\n | 19 ->\n\n# 307 \"lib/read.mll\"\n \n# 307 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 1222 \"lib/read.ml\"\n\n \n# 1223 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state\n\nand finish_string v lexbuf =\n __ocaml_lex_finish_string_rec v lexbuf 58\nand __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 311 \"lib/read.mll\"\n \n# 311 \"lib/read.mll\"\n ( Bi_outbuf.contents v.buf )\n\n# 1234 \"lib/read.ml\"\n\n \n# 1235 \"lib/read.ml\"\n | 1 ->\n\n# 312 \"lib/read.mll\"\n \n# 312 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n finish_string v lexbuf )\n\n# 1240 \"lib/read.ml\"\n\n \n# 1241 \"lib/read.ml\"\n | 2 ->\n\n# 314 \"lib/read.mll\"\n \n# 314 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n finish_string v lexbuf )\n\n# 1246 \"lib/read.ml\"\n\n \n# 1247 \"lib/read.ml\"\n | 3 ->\n\n# 316 \"lib/read.mll\"\n \n# 316 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1251 \"lib/read.ml\"\n\n \n# 1252 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state\n\nand map_string v f lexbuf =\n __ocaml_lex_map_string_rec v f lexbuf 63\nand __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 319 \"lib/read.mll\"\n \n# 319 \"lib/read.mll\"\n ( let b = v.buf in\n f (Bytes.to_string b.Bi_outbuf.o_s) 0 b.Bi_outbuf.o_len )\n\n# 1264 \"lib/read.ml\"\n\n \n# 1265 \"lib/read.ml\"\n | 1 ->\n\n# 321 \"lib/read.mll\"\n \n# 321 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n map_string v f lexbuf )\n\n# 1270 \"lib/read.ml\"\n\n \n# 1271 \"lib/read.ml\"\n | 2 ->\n\n# 323 \"lib/read.mll\"\n \n# 323 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n map_string v f lexbuf )\n\n# 1276 \"lib/read.ml\"\n\n \n# 1277 \"lib/read.ml\"\n | 3 ->\n\n# 325 \"lib/read.mll\"\n \n# 325 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1281 \"lib/read.ml\"\n\n \n# 1282 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state\n\nand finish_escaped_char v lexbuf =\n __ocaml_lex_finish_escaped_char_rec v lexbuf 68\nand __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n c\n\n# 1294 \"lib/read.ml\"\n# 1294 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf lexbuf.Lexing.lex_start_pos in\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf c )\n\n# 1298 \"lib/read.ml\"\n\n \n# 1299 \"lib/read.ml\"\n | 1 ->\n\n# 331 \"lib/read.mll\"\n \n# 331 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\b' )\n\n# 1303 \"lib/read.ml\"\n\n \n# 1304 \"lib/read.ml\"\n | 2 ->\n\n# 332 \"lib/read.mll\"\n \n# 332 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\012' )\n\n# 1308 \"lib/read.ml\"\n\n \n# 1309 \"lib/read.ml\"\n | 3 ->\n\n# 333 \"lib/read.mll\"\n \n# 333 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n' )\n\n# 1313 \"lib/read.ml\"\n\n \n# 1314 \"lib/read.ml\"\n | 4 ->\n\n# 334 \"lib/read.mll\"\n \n# 334 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\r' )\n\n# 1318 \"lib/read.ml\"\n\n \n# 1319 \"lib/read.ml\"\n | 5 ->\n\n# 335 \"lib/read.mll\"\n \n# 335 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\t' )\n\n# 1323 \"lib/read.ml\"\n\n \n# 1324 \"lib/read.ml\"\n | 6 ->\nlet\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n a\n\n# 1329 \"lib/read.ml\"\n# 1329 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 1)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n b\n\n# 1334 \"lib/read.ml\"\n# 1334 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n c\n\n# 1339 \"lib/read.ml\"\n# 1339 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n d\n\n# 1344 \"lib/read.ml\"\n# 1344 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4) in\n\n# 337 \"lib/read.mll\"\n \n# 337 \"lib/read.mll\"\n ( let x =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if x >= 0xD800 && x <= 0xDBFF then\n finish_surrogate_pair v x lexbuf\n else\n utf8_of_code v.buf x\n )\n\n# 1355 \"lib/read.ml\"\n\n \n# 1356 \"lib/read.ml\"\n | 7 ->\n\n# 345 \"lib/read.mll\"\n \n# 345 \"lib/read.mll\"\n ( long_error \"Invalid escape sequence\" v lexbuf )\n\n# 1360 \"lib/read.ml\"\n\n \n# 1361 \"lib/read.ml\"\n | 8 ->\n\n# 346 \"lib/read.mll\"\n \n# 346 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1365 \"lib/read.ml\"\n\n \n# 1366 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state\n\nand finish_surrogate_pair v x lexbuf =\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf 82\nand __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n a\n\n# 1378 \"lib/read.ml\"\n# 1378 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n b\n\n# 1383 \"lib/read.ml\"\n# 1383 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n c\n\n# 1388 \"lib/read.ml\"\n# 1388 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n d\n\n# 1393 \"lib/read.ml\"\n# 1393 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 5) in\n\n# 350 \"lib/read.mll\"\n \n# 350 \"lib/read.mll\"\n ( let y =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if y >= 0xDC00 && y <= 0xDFFF then\n utf8_of_surrogate_pair v.buf x y\n else\n long_error \"Invalid low surrogate for code point beyond U+FFFF\"\n v lexbuf\n )\n\n# 1405 \"lib/read.ml\"\n\n \n# 1406 \"lib/read.ml\"\n | 1 ->\n\n# 359 \"lib/read.mll\"\n \n# 359 \"lib/read.mll\"\n ( long_error \"Missing escape sequence representing low surrogate \\\n for code point beyond U+FFFF\" v lexbuf )\n\n# 1411 \"lib/read.ml\"\n\n \n# 1412 \"lib/read.ml\"\n | 2 ->\n\n# 361 \"lib/read.mll\"\n \n# 361 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1416 \"lib/read.ml\"\n\n \n# 1417 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state\n\nand finish_stringlit v lexbuf =\n __ocaml_lex_finish_stringlit_rec v lexbuf 91\nand __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 366 \"lib/read.mll\"\n \n# 366 \"lib/read.mll\"\n ( let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n let s = Bytes.create (len+1) in\n Bytes.set s 0 '\"';\n Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos s 1 len;\n Bytes.to_string s\n )\n\n# 1433 \"lib/read.ml\"\n\n \n# 1434 \"lib/read.ml\"\n | 1 ->\n\n# 372 \"lib/read.mll\"\n \n# 372 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 1438 \"lib/read.ml\"\n\n \n# 1439 \"lib/read.ml\"\n | 2 ->\n\n# 373 \"lib/read.mll\"\n \n# 373 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1443 \"lib/read.ml\"\n\n \n# 1444 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_variant v lexbuf =\n __ocaml_lex_finish_variant_rec v lexbuf 102\nand __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 376 \"lib/read.mll\"\n \n# 376 \"lib/read.mll\"\n ( let x = read_json v lexbuf in\n read_space v lexbuf;\n read_gt v lexbuf;\n Some x )\n\n# 1458 \"lib/read.ml\"\n\n \n# 1459 \"lib/read.ml\"\n | 1 ->\n\n# 380 \"lib/read.mll\"\n \n# 380 \"lib/read.mll\"\n ( None )\n\n# 1463 \"lib/read.ml\"\n\n \n# 1464 \"lib/read.ml\"\n | 2 ->\n\n# 381 \"lib/read.mll\"\n \n# 381 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 1468 \"lib/read.ml\"\n\n \n# 1469 \"lib/read.ml\"\n | 3 ->\n\n# 382 \"lib/read.mll\"\n \n# 382 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1473 \"lib/read.ml\"\n\n \n# 1474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state\n\nand read_lt v lexbuf =\n __ocaml_lex_read_lt_rec v lexbuf 107\nand __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 385 \"lib/read.mll\"\n \n# 385 \"lib/read.mll\"\n ( () )\n\n# 1485 \"lib/read.ml\"\n\n \n# 1486 \"lib/read.ml\"\n | 1 ->\n\n# 386 \"lib/read.mll\"\n \n# 386 \"lib/read.mll\"\n ( long_error \"Expected '<' but found\" v lexbuf )\n\n# 1490 \"lib/read.ml\"\n\n \n# 1491 \"lib/read.ml\"\n | 2 ->\n\n# 387 \"lib/read.mll\"\n \n# 387 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1495 \"lib/read.ml\"\n\n \n# 1496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state\n\nand read_gt v lexbuf =\n __ocaml_lex_read_gt_rec v lexbuf 111\nand __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 390 \"lib/read.mll\"\n \n# 390 \"lib/read.mll\"\n ( () )\n\n# 1507 \"lib/read.ml\"\n\n \n# 1508 \"lib/read.ml\"\n | 1 ->\n\n# 391 \"lib/read.mll\"\n \n# 391 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 1512 \"lib/read.ml\"\n\n \n# 1513 \"lib/read.ml\"\n | 2 ->\n\n# 392 \"lib/read.mll\"\n \n# 392 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1517 \"lib/read.ml\"\n\n \n# 1518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state\n\nand read_comma v lexbuf =\n __ocaml_lex_read_comma_rec v lexbuf 115\nand __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 395 \"lib/read.mll\"\n \n# 395 \"lib/read.mll\"\n ( () )\n\n# 1529 \"lib/read.ml\"\n\n \n# 1530 \"lib/read.ml\"\n | 1 ->\n\n# 396 \"lib/read.mll\"\n \n# 396 \"lib/read.mll\"\n ( long_error \"Expected ',' but found\" v lexbuf )\n\n# 1534 \"lib/read.ml\"\n\n \n# 1535 \"lib/read.ml\"\n | 2 ->\n\n# 397 \"lib/read.mll\"\n \n# 397 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1539 \"lib/read.ml\"\n\n \n# 1540 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state\n\nand start_any_variant v lexbuf =\n __ocaml_lex_start_any_variant_rec v lexbuf 119\nand __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 400 \"lib/read.mll\"\n \n# 400 \"lib/read.mll\"\n ( `Edgy_bracket )\n\n# 1551 \"lib/read.ml\"\n\n \n# 1552 \"lib/read.ml\"\n | 1 ->\n\n# 401 \"lib/read.mll\"\n \n# 401 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n `Double_quote )\n\n# 1557 \"lib/read.ml\"\n\n \n# 1558 \"lib/read.ml\"\n | 2 ->\n\n# 403 \"lib/read.mll\"\n \n# 403 \"lib/read.mll\"\n ( `Square_bracket )\n\n# 1562 \"lib/read.ml\"\n\n \n# 1563 \"lib/read.ml\"\n | 3 ->\n\n# 404 \"lib/read.mll\"\n \n# 404 \"lib/read.mll\"\n ( long_error \"Expected '<', '\\\"' or '[' but found\" v lexbuf )\n\n# 1567 \"lib/read.ml\"\n\n \n# 1568 \"lib/read.ml\"\n | 4 ->\n\n# 405 \"lib/read.mll\"\n \n# 405 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1572 \"lib/read.ml\"\n\n \n# 1573 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state\n\nand finish_comment v lexbuf =\n __ocaml_lex_finish_comment_rec v lexbuf 125\nand __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 408 \"lib/read.mll\"\n \n# 408 \"lib/read.mll\"\n ( () )\n\n# 1584 \"lib/read.ml\"\n\n \n# 1585 \"lib/read.ml\"\n | 1 ->\n\n# 409 \"lib/read.mll\"\n \n# 409 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 1589 \"lib/read.ml\"\n\n \n# 1590 \"lib/read.ml\"\n | 2 ->\n\n# 410 \"lib/read.mll\"\n \n# 410 \"lib/read.mll\"\n ( newline v lexbuf; finish_comment v lexbuf )\n\n# 1594 \"lib/read.ml\"\n\n \n# 1595 \"lib/read.ml\"\n | 3 ->\n\n# 411 \"lib/read.mll\"\n \n# 411 \"lib/read.mll\"\n ( finish_comment v lexbuf )\n\n# 1599 \"lib/read.ml\"\n\n \n# 1600 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state\n\nand read_eof lexbuf =\n __ocaml_lex_read_eof_rec lexbuf 131\nand __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 419 \"lib/read.mll\"\n \n# 419 \"lib/read.mll\"\n ( true )\n\n# 1611 \"lib/read.ml\"\n\n \n# 1612 \"lib/read.ml\"\n | 1 ->\n\n# 420 \"lib/read.mll\"\n \n# 420 \"lib/read.mll\"\n ( false )\n\n# 1616 \"lib/read.ml\"\n\n \n# 1617 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state\n\nand read_space v lexbuf =\n __ocaml_lex_read_space_rec v lexbuf 133\nand __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 423 \"lib/read.mll\"\n \n# 423 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1628 \"lib/read.ml\"\n\n \n# 1629 \"lib/read.ml\"\n | 1 ->\n\n# 424 \"lib/read.mll\"\n \n# 424 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_space v lexbuf )\n\n# 1633 \"lib/read.ml\"\n\n \n# 1634 \"lib/read.ml\"\n | 2 ->\n\n# 425 \"lib/read.mll\"\n \n# 425 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1638 \"lib/read.ml\"\n\n \n# 1639 \"lib/read.ml\"\n | 3 ->\n\n# 426 \"lib/read.mll\"\n \n# 426 \"lib/read.mll\"\n ( read_space v lexbuf )\n\n# 1643 \"lib/read.ml\"\n\n \n# 1644 \"lib/read.ml\"\n | 4 ->\n\n# 427 \"lib/read.mll\"\n \n# 427 \"lib/read.mll\"\n ( () )\n\n# 1648 \"lib/read.ml\"\n\n \n# 1649 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state\n\nand read_null v lexbuf =\n __ocaml_lex_read_null_rec v lexbuf 140\nand __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 430 \"lib/read.mll\"\n \n# 430 \"lib/read.mll\"\n ( () )\n\n# 1660 \"lib/read.ml\"\n\n \n# 1661 \"lib/read.ml\"\n | 1 ->\n\n# 431 \"lib/read.mll\"\n \n# 431 \"lib/read.mll\"\n ( long_error \"Expected 'null' but found\" v lexbuf )\n\n# 1665 \"lib/read.ml\"\n\n \n# 1666 \"lib/read.ml\"\n | 2 ->\n\n# 432 \"lib/read.mll\"\n \n# 432 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1670 \"lib/read.ml\"\n\n \n# 1671 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state\n\nand read_null_if_possible v lexbuf =\n __ocaml_lex_read_null_if_possible_rec v lexbuf 147\nand __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 435 \"lib/read.mll\"\n \n# 435 \"lib/read.mll\"\n ( true )\n\n# 1682 \"lib/read.ml\"\n\n \n# 1683 \"lib/read.ml\"\n | 1 ->\n\n# 436 \"lib/read.mll\"\n \n# 436 \"lib/read.mll\"\n ( false )\n\n# 1687 \"lib/read.ml\"\n\n \n# 1688 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state\n\nand read_bool v lexbuf =\n __ocaml_lex_read_bool_rec v lexbuf 152\nand __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 439 \"lib/read.mll\"\n \n# 439 \"lib/read.mll\"\n ( true )\n\n# 1699 \"lib/read.ml\"\n\n \n# 1700 \"lib/read.ml\"\n | 1 ->\n\n# 440 \"lib/read.mll\"\n \n# 440 \"lib/read.mll\"\n ( false )\n\n# 1704 \"lib/read.ml\"\n\n \n# 1705 \"lib/read.ml\"\n | 2 ->\n\n# 443 \"lib/read.mll\"\n \n# 443 \"lib/read.mll\"\n ( true )\n\n# 1709 \"lib/read.ml\"\n\n \n# 1710 \"lib/read.ml\"\n | 3 ->\n\n# 444 \"lib/read.mll\"\n \n# 444 \"lib/read.mll\"\n ( false )\n\n# 1714 \"lib/read.ml\"\n\n \n# 1715 \"lib/read.ml\"\n | 4 ->\n\n# 446 \"lib/read.mll\"\n \n# 446 \"lib/read.mll\"\n ( long_error \"Expected 'true' or 'false' but found\" v lexbuf )\n\n# 1719 \"lib/read.ml\"\n\n \n# 1720 \"lib/read.ml\"\n | 5 ->\n\n# 447 \"lib/read.mll\"\n \n# 447 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1724 \"lib/read.ml\"\n\n \n# 1725 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state\n\nand read_int v lexbuf =\n __ocaml_lex_read_int_rec v lexbuf 176\nand __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 450 \"lib/read.mll\"\n \n# 450 \"lib/read.mll\"\n ( try extract_positive_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1738 \"lib/read.ml\"\n\n \n# 1739 \"lib/read.ml\"\n | 1 ->\n\n# 453 \"lib/read.mll\"\n \n# 453 \"lib/read.mll\"\n ( try extract_negative_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1745 \"lib/read.ml\"\n\n \n# 1746 \"lib/read.ml\"\n | 2 ->\n\n# 456 \"lib/read.mll\"\n \n# 456 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n int_of_string s\n with _ ->\n custom_error\n \"Expected an integer but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1763 \"lib/read.ml\"\n\n \n# 1764 \"lib/read.ml\"\n | 3 ->\n\n# 470 \"lib/read.mll\"\n \n# 470 \"lib/read.mll\"\n ( long_error \"Expected integer but found\" v lexbuf )\n\n# 1768 \"lib/read.ml\"\n\n \n# 1769 \"lib/read.ml\"\n | 4 ->\n\n# 471 \"lib/read.mll\"\n \n# 471 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1773 \"lib/read.ml\"\n\n \n# 1774 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state\n\nand read_int32 v lexbuf =\n __ocaml_lex_read_int32_rec v lexbuf 185\nand __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 474 \"lib/read.mll\"\n \n# 474 \"lib/read.mll\"\n ( try Int32.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1787 \"lib/read.ml\"\n\n \n# 1788 \"lib/read.ml\"\n | 1 ->\n\n# 477 \"lib/read.mll\"\n \n# 477 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int32.of_string s\n with _ ->\n custom_error\n \"Expected an int32 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1805 \"lib/read.ml\"\n\n \n# 1806 \"lib/read.ml\"\n | 2 ->\n\n# 491 \"lib/read.mll\"\n \n# 491 \"lib/read.mll\"\n ( long_error \"Expected int32 but found\" v lexbuf )\n\n# 1810 \"lib/read.ml\"\n\n \n# 1811 \"lib/read.ml\"\n | 3 ->\n\n# 492 \"lib/read.mll\"\n \n# 492 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1815 \"lib/read.ml\"\n\n \n# 1816 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state\n\nand read_int64 v lexbuf =\n __ocaml_lex_read_int64_rec v lexbuf 192\nand __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 495 \"lib/read.mll\"\n \n# 495 \"lib/read.mll\"\n ( try Int64.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1829 \"lib/read.ml\"\n\n \n# 1830 \"lib/read.ml\"\n | 1 ->\n\n# 498 \"lib/read.mll\"\n \n# 498 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int64.of_string s\n with _ ->\n custom_error\n \"Expected an int64 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1847 \"lib/read.ml\"\n\n \n# 1848 \"lib/read.ml\"\n | 2 ->\n\n# 512 \"lib/read.mll\"\n \n# 512 \"lib/read.mll\"\n ( long_error \"Expected int64 but found\" v lexbuf )\n\n# 1852 \"lib/read.ml\"\n\n \n# 1853 \"lib/read.ml\"\n | 3 ->\n\n# 513 \"lib/read.mll\"\n \n# 513 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1857 \"lib/read.ml\"\n\n \n# 1858 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state\n\nand read_number v lexbuf =\n __ocaml_lex_read_number_rec v lexbuf 199\nand __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 516 \"lib/read.mll\"\n \n# 516 \"lib/read.mll\"\n ( nan )\n\n# 1869 \"lib/read.ml\"\n\n \n# 1870 \"lib/read.ml\"\n | 1 ->\n\n# 517 \"lib/read.mll\"\n \n# 517 \"lib/read.mll\"\n ( infinity )\n\n# 1874 \"lib/read.ml\"\n\n \n# 1875 \"lib/read.ml\"\n | 2 ->\n\n# 518 \"lib/read.mll\"\n \n# 518 \"lib/read.mll\"\n ( neg_infinity )\n\n# 1879 \"lib/read.ml\"\n\n \n# 1880 \"lib/read.ml\"\n | 3 ->\n\n# 519 \"lib/read.mll\"\n \n# 519 \"lib/read.mll\"\n ( float_of_string (lexeme lexbuf) )\n\n# 1884 \"lib/read.ml\"\n\n \n# 1885 \"lib/read.ml\"\n | 4 ->\n\n# 520 \"lib/read.mll\"\n \n# 520 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant float will pass,\n including hexadecimal and octal notations,\n and embedded underscores. *)\n float_of_string s\n with _ ->\n match s with\n \"NaN\" -> nan\n | \"Infinity\" -> infinity\n | \"-Infinity\" -> neg_infinity\n | _ ->\n custom_error\n \"Expected a number but found a string that \\\n doesn't even represent a number\"\n v lexbuf\n )\n\n# 1906 \"lib/read.ml\"\n\n \n# 1907 \"lib/read.ml\"\n | 5 ->\n\n# 538 \"lib/read.mll\"\n \n# 538 \"lib/read.mll\"\n ( long_error \"Expected number but found\" v lexbuf )\n\n# 1911 \"lib/read.ml\"\n\n \n# 1912 \"lib/read.ml\"\n | 6 ->\n\n# 539 \"lib/read.mll\"\n \n# 539 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1916 \"lib/read.ml\"\n\n \n# 1917 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state\n\nand read_string v lexbuf =\n __ocaml_lex_read_string_rec v lexbuf 233\nand __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 542 \"lib/read.mll\"\n \n# 542 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1929 \"lib/read.ml\"\n\n \n# 1930 \"lib/read.ml\"\n | 1 ->\n\n# 544 \"lib/read.mll\"\n \n# 544 \"lib/read.mll\"\n ( long_error \"Expected '\\\"' but found\" v lexbuf )\n\n# 1934 \"lib/read.ml\"\n\n \n# 1935 \"lib/read.ml\"\n | 2 ->\n\n# 545 \"lib/read.mll\"\n \n# 545 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1939 \"lib/read.ml\"\n\n \n# 1940 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state\n\nand read_ident v lexbuf =\n __ocaml_lex_read_ident_rec v lexbuf 237\nand __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 548 \"lib/read.mll\"\n \n# 548 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1952 \"lib/read.ml\"\n\n \n# 1953 \"lib/read.ml\"\n | 1 ->\nlet\n\n# 550 \"lib/read.mll\"\n \n# 550 \"lib/read.mll\"\n s\n\n# 1958 \"lib/read.ml\"\n# 1958 \"lib/read.ml\"\n= Lexing.sub_lexeme lexbuf lexbuf.Lexing.lex_start_pos lexbuf.Lexing.lex_curr_pos in\n\n# 551 \"lib/read.mll\"\n \n# 551 \"lib/read.mll\"\n ( s )\n\n# 1962 \"lib/read.ml\"\n\n \n# 1963 \"lib/read.ml\"\n | 2 ->\n\n# 552 \"lib/read.mll\"\n \n# 552 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1967 \"lib/read.ml\"\n\n \n# 1968 \"lib/read.ml\"\n | 3 ->\n\n# 553 \"lib/read.mll\"\n \n# 553 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1972 \"lib/read.ml\"\n\n \n# 1973 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state\n\nand map_ident v f lexbuf =\n __ocaml_lex_map_ident_rec v f lexbuf 242\nand __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 556 \"lib/read.mll\"\n \n# 556 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n map_string v f lexbuf )\n\n# 1985 \"lib/read.ml\"\n\n \n# 1986 \"lib/read.ml\"\n | 1 ->\n\n# 559 \"lib/read.mll\"\n \n# 559 \"lib/read.mll\"\n ( map_lexeme f lexbuf )\n\n# 1990 \"lib/read.ml\"\n\n \n# 1991 \"lib/read.ml\"\n | 2 ->\n\n# 560 \"lib/read.mll\"\n \n# 560 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1995 \"lib/read.ml\"\n\n \n# 1996 \"lib/read.ml\"\n | 3 ->\n\n# 561 \"lib/read.mll\"\n \n# 561 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2000 \"lib/read.ml\"\n\n \n# 2001 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state\n\nand read_sequence read_cell init_acc v lexbuf =\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf 247\nand __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 564 \"lib/read.mll\"\n \n# 564 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell !acc v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell !acc v lexbuf;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2026 \"lib/read.ml\"\n\n \n# 2027 \"lib/read.ml\"\n | 1 ->\n\n# 579 \"lib/read.mll\"\n \n# 579 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2031 \"lib/read.ml\"\n\n \n# 2032 \"lib/read.ml\"\n | 2 ->\n\n# 580 \"lib/read.mll\"\n \n# 580 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2036 \"lib/read.ml\"\n\n \n# 2037 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_list_rev read_cell v lexbuf =\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf 251\nand __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 583 \"lib/read.mll\"\n \n# 583 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2062 \"lib/read.ml\"\n\n \n# 2063 \"lib/read.ml\"\n | 1 ->\n\n# 598 \"lib/read.mll\"\n \n# 598 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2067 \"lib/read.ml\"\n\n \n# 2068 \"lib/read.ml\"\n | 2 ->\n\n# 599 \"lib/read.mll\"\n \n# 599 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2072 \"lib/read.ml\"\n\n \n# 2073 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state\n\nand read_array_end lexbuf =\n __ocaml_lex_read_array_end_rec lexbuf 255\nand __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 602 \"lib/read.mll\"\n \n# 602 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2084 \"lib/read.ml\"\n\n \n# 2085 \"lib/read.ml\"\n | 1 ->\n\n# 603 \"lib/read.mll\"\n \n# 603 \"lib/read.mll\"\n ( () )\n\n# 2089 \"lib/read.ml\"\n\n \n# 2090 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state\n\nand read_array_sep v lexbuf =\n __ocaml_lex_read_array_sep_rec v lexbuf 257\nand __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 606 \"lib/read.mll\"\n \n# 606 \"lib/read.mll\"\n ( () )\n\n# 2101 \"lib/read.ml\"\n\n \n# 2102 \"lib/read.ml\"\n | 1 ->\n\n# 607 \"lib/read.mll\"\n \n# 607 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2106 \"lib/read.ml\"\n\n \n# 2107 \"lib/read.ml\"\n | 2 ->\n\n# 608 \"lib/read.mll\"\n \n# 608 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 2111 \"lib/read.ml\"\n\n \n# 2112 \"lib/read.ml\"\n | 3 ->\n\n# 609 \"lib/read.mll\"\n \n# 609 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2116 \"lib/read.ml\"\n\n \n# 2117 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple read_cell init_acc v lexbuf =\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf 262\nand __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 613 \"lib/read.mll\"\n \n# 613 \"lib/read.mll\"\n (\n \n# 615 \"lib/read.mll\"\n let pos = ref 0 in\n let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n acc := read_cell !pos !acc v lexbuf;\n incr pos;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell !pos !acc v lexbuf;\n incr pos;\n done;\n assert false\n with End_of_tuple ->\n !acc\n \n# 635 \"lib/read.mll\"\n )\n\n# 2150 \"lib/read.ml\"\n\n \n# 2151 \"lib/read.ml\"\n | 1 ->\n\n# 636 \"lib/read.mll\"\n \n# 636 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2155 \"lib/read.ml\"\n\n \n# 2156 \"lib/read.ml\"\n | 2 ->\n\n# 637 \"lib/read.mll\"\n \n# 637 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2160 \"lib/read.ml\"\n\n \n# 2161 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_tuple_end lexbuf =\n __ocaml_lex_read_tuple_end_rec lexbuf 266\nand __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 640 \"lib/read.mll\"\n \n# 640 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2172 \"lib/read.ml\"\n\n \n# 2173 \"lib/read.ml\"\n | 1 ->\n\n# 641 \"lib/read.mll\"\n \n# 641 \"lib/read.mll\"\n ( () )\n\n# 2177 \"lib/read.ml\"\n\n \n# 2178 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state\n\nand read_tuple_end2 v std lexbuf =\n __ocaml_lex_read_tuple_end2_rec v std lexbuf 268\nand __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 644 \"lib/read.mll\"\n \n# 644 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ')' or '' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2192 \"lib/read.ml\"\n\n \n# 2193 \"lib/read.ml\"\n | 1 ->\n\n# 648 \"lib/read.mll\"\n \n# 648 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ']' or '' but found\" v lexbuf )\n\n# 2200 \"lib/read.ml\"\n\n \n# 2201 \"lib/read.ml\"\n | 2 ->\n\n# 652 \"lib/read.mll\"\n \n# 652 \"lib/read.mll\"\n ( () )\n\n# 2205 \"lib/read.ml\"\n\n \n# 2206 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state\n\nand read_tuple_sep v lexbuf =\n __ocaml_lex_read_tuple_sep_rec v lexbuf 271\nand __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 655 \"lib/read.mll\"\n \n# 655 \"lib/read.mll\"\n ( () )\n\n# 2217 \"lib/read.ml\"\n\n \n# 2218 \"lib/read.ml\"\n | 1 ->\n\n# 656 \"lib/read.mll\"\n \n# 656 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2222 \"lib/read.ml\"\n\n \n# 2223 \"lib/read.ml\"\n | 2 ->\n\n# 657 \"lib/read.mll\"\n \n# 657 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2227 \"lib/read.ml\"\n\n \n# 2228 \"lib/read.ml\"\n | 3 ->\n\n# 658 \"lib/read.mll\"\n \n# 658 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2232 \"lib/read.ml\"\n\n \n# 2233 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple_sep2 v std lexbuf =\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf 276\nand __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 661 \"lib/read.mll\"\n \n# 661 \"lib/read.mll\"\n ( () )\n\n# 2244 \"lib/read.ml\"\n\n \n# 2245 \"lib/read.ml\"\n | 1 ->\n\n# 662 \"lib/read.mll\"\n \n# 662 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ',' or ']' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2252 \"lib/read.ml\"\n\n \n# 2253 \"lib/read.ml\"\n | 2 ->\n\n# 666 \"lib/read.mll\"\n \n# 666 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2260 \"lib/read.ml\"\n\n \n# 2261 \"lib/read.ml\"\n | 3 ->\n\n# 670 \"lib/read.mll\"\n \n# 670 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2265 \"lib/read.ml\"\n\n \n# 2266 \"lib/read.ml\"\n | 4 ->\n\n# 671 \"lib/read.mll\"\n \n# 671 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2270 \"lib/read.ml\"\n\n \n# 2271 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state\n\nand read_abstract_fields read_key read_field init_acc v lexbuf =\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf 282\nand __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 675 \"lib/read.mll\"\n \n# 675 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n done;\n assert false\n with End_of_object ->\n !acc\n )\n\n# 2304 \"lib/read.ml\"\n\n \n# 2305 \"lib/read.ml\"\n | 1 ->\n\n# 698 \"lib/read.mll\"\n \n# 698 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2309 \"lib/read.ml\"\n\n \n# 2310 \"lib/read.ml\"\n | 2 ->\n\n# 699 \"lib/read.mll\"\n \n# 699 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2314 \"lib/read.ml\"\n\n \n# 2315 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state\n\nand read_lcurl v lexbuf =\n __ocaml_lex_read_lcurl_rec v lexbuf 286\nand __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 702 \"lib/read.mll\"\n \n# 702 \"lib/read.mll\"\n ( () )\n\n# 2326 \"lib/read.ml\"\n\n \n# 2327 \"lib/read.ml\"\n | 1 ->\n\n# 703 \"lib/read.mll\"\n \n# 703 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2331 \"lib/read.ml\"\n\n \n# 2332 \"lib/read.ml\"\n | 2 ->\n\n# 704 \"lib/read.mll\"\n \n# 704 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2336 \"lib/read.ml\"\n\n \n# 2337 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state\n\nand read_object_end lexbuf =\n __ocaml_lex_read_object_end_rec lexbuf 290\nand __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 707 \"lib/read.mll\"\n \n# 707 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2348 \"lib/read.ml\"\n\n \n# 2349 \"lib/read.ml\"\n | 1 ->\n\n# 708 \"lib/read.mll\"\n \n# 708 \"lib/read.mll\"\n ( () )\n\n# 2353 \"lib/read.ml\"\n\n \n# 2354 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state\n\nand read_object_sep v lexbuf =\n __ocaml_lex_read_object_sep_rec v lexbuf 292\nand __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 711 \"lib/read.mll\"\n \n# 711 \"lib/read.mll\"\n ( () )\n\n# 2365 \"lib/read.ml\"\n\n \n# 2366 \"lib/read.ml\"\n | 1 ->\n\n# 712 \"lib/read.mll\"\n \n# 712 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2370 \"lib/read.ml\"\n\n \n# 2371 \"lib/read.ml\"\n | 2 ->\n\n# 713 \"lib/read.mll\"\n \n# 713 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 2375 \"lib/read.ml\"\n\n \n# 2376 \"lib/read.ml\"\n | 3 ->\n\n# 714 \"lib/read.mll\"\n \n# 714 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2380 \"lib/read.ml\"\n\n \n# 2381 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state\n\nand read_colon v lexbuf =\n __ocaml_lex_read_colon_rec v lexbuf 297\nand __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 717 \"lib/read.mll\"\n \n# 717 \"lib/read.mll\"\n ( () )\n\n# 2392 \"lib/read.ml\"\n\n \n# 2393 \"lib/read.ml\"\n | 1 ->\n\n# 718 \"lib/read.mll\"\n \n# 718 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 2397 \"lib/read.ml\"\n\n \n# 2398 \"lib/read.ml\"\n | 2 ->\n\n# 719 \"lib/read.mll\"\n \n# 719 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2402 \"lib/read.ml\"\n\n \n# 2403 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state\n\nand start_any_tuple v lexbuf =\n __ocaml_lex_start_any_tuple_rec v lexbuf 301\nand __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 722 \"lib/read.mll\"\n \n# 722 \"lib/read.mll\"\n ( false )\n\n# 2414 \"lib/read.ml\"\n\n \n# 2415 \"lib/read.ml\"\n | 1 ->\n\n# 723 \"lib/read.mll\"\n \n# 723 \"lib/read.mll\"\n ( true )\n\n# 2419 \"lib/read.ml\"\n\n \n# 2420 \"lib/read.ml\"\n | 2 ->\n\n# 724 \"lib/read.mll\"\n \n# 724 \"lib/read.mll\"\n ( long_error \"Expected '(' or '[' but found\" v lexbuf )\n\n# 2424 \"lib/read.ml\"\n\n \n# 2425 \"lib/read.ml\"\n | 3 ->\n\n# 725 \"lib/read.mll\"\n \n# 725 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2429 \"lib/read.ml\"\n\n \n# 2430 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state\n\nand read_lpar v lexbuf =\n __ocaml_lex_read_lpar_rec v lexbuf 306\nand __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 728 \"lib/read.mll\"\n \n# 728 \"lib/read.mll\"\n ( () )\n\n# 2441 \"lib/read.ml\"\n\n \n# 2442 \"lib/read.ml\"\n | 1 ->\n\n# 729 \"lib/read.mll\"\n \n# 729 \"lib/read.mll\"\n ( long_error \"Expected '(' but found\" v lexbuf )\n\n# 2446 \"lib/read.ml\"\n\n \n# 2447 \"lib/read.ml\"\n | 2 ->\n\n# 730 \"lib/read.mll\"\n \n# 730 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2451 \"lib/read.ml\"\n\n \n# 2452 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state\n\nand read_rpar v lexbuf =\n __ocaml_lex_read_rpar_rec v lexbuf 310\nand __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 733 \"lib/read.mll\"\n \n# 733 \"lib/read.mll\"\n ( () )\n\n# 2463 \"lib/read.ml\"\n\n \n# 2464 \"lib/read.ml\"\n | 1 ->\n\n# 734 \"lib/read.mll\"\n \n# 734 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2468 \"lib/read.ml\"\n\n \n# 2469 \"lib/read.ml\"\n | 2 ->\n\n# 735 \"lib/read.mll\"\n \n# 735 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2473 \"lib/read.ml\"\n\n \n# 2474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state\n\nand read_lbr v lexbuf =\n __ocaml_lex_read_lbr_rec v lexbuf 314\nand __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 738 \"lib/read.mll\"\n \n# 738 \"lib/read.mll\"\n ( () )\n\n# 2485 \"lib/read.ml\"\n\n \n# 2486 \"lib/read.ml\"\n | 1 ->\n\n# 739 \"lib/read.mll\"\n \n# 739 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2490 \"lib/read.ml\"\n\n \n# 2491 \"lib/read.ml\"\n | 2 ->\n\n# 740 \"lib/read.mll\"\n \n# 740 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2495 \"lib/read.ml\"\n\n \n# 2496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state\n\nand read_rbr v lexbuf =\n __ocaml_lex_read_rbr_rec v lexbuf 318\nand __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 743 \"lib/read.mll\"\n \n# 743 \"lib/read.mll\"\n ( () )\n\n# 2507 \"lib/read.ml\"\n\n \n# 2508 \"lib/read.ml\"\n | 1 ->\n\n# 744 \"lib/read.mll\"\n \n# 744 \"lib/read.mll\"\n ( long_error \"Expected ']' but found\" v lexbuf )\n\n# 2512 \"lib/read.ml\"\n\n \n# 2513 \"lib/read.ml\"\n | 2 ->\n\n# 745 \"lib/read.mll\"\n \n# 745 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2517 \"lib/read.ml\"\n\n \n# 2518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state\n\nand skip_json v lexbuf =\n __ocaml_lex_skip_json_rec v lexbuf 322\nand __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 751 \"lib/read.mll\"\n \n# 751 \"lib/read.mll\"\n ( () )\n\n# 2529 \"lib/read.ml\"\n\n \n# 2530 \"lib/read.ml\"\n | 1 ->\n\n# 752 \"lib/read.mll\"\n \n# 752 \"lib/read.mll\"\n ( () )\n\n# 2534 \"lib/read.ml\"\n\n \n# 2535 \"lib/read.ml\"\n | 2 ->\n\n# 753 \"lib/read.mll\"\n \n# 753 \"lib/read.mll\"\n ( () )\n\n# 2539 \"lib/read.ml\"\n\n \n# 2540 \"lib/read.ml\"\n | 3 ->\n\n# 754 \"lib/read.mll\"\n \n# 754 \"lib/read.mll\"\n ( () )\n\n# 2544 \"lib/read.ml\"\n\n \n# 2545 \"lib/read.ml\"\n | 4 ->\n\n# 755 \"lib/read.mll\"\n \n# 755 \"lib/read.mll\"\n ( () )\n\n# 2549 \"lib/read.ml\"\n\n \n# 2550 \"lib/read.ml\"\n | 5 ->\n\n# 756 \"lib/read.mll\"\n \n# 756 \"lib/read.mll\"\n ( () )\n\n# 2554 \"lib/read.ml\"\n\n \n# 2555 \"lib/read.ml\"\n | 6 ->\n\n# 757 \"lib/read.mll\"\n \n# 757 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2559 \"lib/read.ml\"\n\n \n# 2560 \"lib/read.ml\"\n | 7 ->\n\n# 758 \"lib/read.mll\"\n \n# 758 \"lib/read.mll\"\n ( () )\n\n# 2564 \"lib/read.ml\"\n\n \n# 2565 \"lib/read.ml\"\n | 8 ->\n\n# 759 \"lib/read.mll\"\n \n# 759 \"lib/read.mll\"\n ( () )\n\n# 2569 \"lib/read.ml\"\n\n \n# 2570 \"lib/read.ml\"\n | 9 ->\n\n# 761 \"lib/read.mll\"\n \n# 761 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_object_end lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2595 \"lib/read.ml\"\n\n \n# 2596 \"lib/read.ml\"\n | 10 ->\n\n# 784 \"lib/read.mll\"\n \n# 784 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_array_end lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2613 \"lib/read.ml\"\n\n \n# 2614 \"lib/read.ml\"\n | 11 ->\n\n# 799 \"lib/read.mll\"\n \n# 799 \"lib/read.mll\"\n (\n \n# 801 \"lib/read.mll\"\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_tuple ->\n ()\n \n# 817 \"lib/read.mll\"\n )\n\n# 2636 \"lib/read.ml\"\n\n \n# 2637 \"lib/read.ml\"\n | 12 ->\n\n# 819 \"lib/read.mll\"\n \n# 819 \"lib/read.mll\"\n (\n \n# 821 \"lib/read.mll\"\n read_space v lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n finish_skip_variant v lexbuf\n \n# 828 \"lib/read.mll\"\n )\n\n# 2650 \"lib/read.ml\"\n\n \n# 2651 \"lib/read.ml\"\n | 13 ->\n\n# 830 \"lib/read.mll\"\n \n# 830 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2655 \"lib/read.ml\"\n\n \n# 2656 \"lib/read.ml\"\n | 14 ->\n\n# 831 \"lib/read.mll\"\n \n# 831 \"lib/read.mll\"\n ( finish_comment v lexbuf; skip_json v lexbuf )\n\n# 2660 \"lib/read.ml\"\n\n \n# 2661 \"lib/read.ml\"\n | 15 ->\n\n# 832 \"lib/read.mll\"\n \n# 832 \"lib/read.mll\"\n ( newline v lexbuf; skip_json v lexbuf )\n\n# 2665 \"lib/read.ml\"\n\n \n# 2666 \"lib/read.ml\"\n | 16 ->\n\n# 833 \"lib/read.mll\"\n \n# 833 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2670 \"lib/read.ml\"\n\n \n# 2671 \"lib/read.ml\"\n | 17 ->\n\n# 834 \"lib/read.mll\"\n \n# 834 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2675 \"lib/read.ml\"\n\n \n# 2676 \"lib/read.ml\"\n | 18 ->\n\n# 835 \"lib/read.mll\"\n \n# 835 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2680 \"lib/read.ml\"\n\n \n# 2681 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_stringlit v lexbuf =\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf 378\nand __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 841 \"lib/read.mll\"\n \n# 841 \"lib/read.mll\"\n ( () )\n\n# 2692 \"lib/read.ml\"\n\n \n# 2693 \"lib/read.ml\"\n | 1 ->\n\n# 842 \"lib/read.mll\"\n \n# 842 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2697 \"lib/read.ml\"\n\n \n# 2698 \"lib/read.ml\"\n | 2 ->\n\n# 843 \"lib/read.mll\"\n \n# 843 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2702 \"lib/read.ml\"\n\n \n# 2703 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_variant v lexbuf =\n __ocaml_lex_finish_skip_variant_rec v lexbuf 389\nand __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 846 \"lib/read.mll\"\n \n# 846 \"lib/read.mll\"\n ( skip_json v lexbuf;\n read_space v lexbuf;\n read_gt v lexbuf )\n\n# 2716 \"lib/read.ml\"\n\n \n# 2717 \"lib/read.ml\"\n | 1 ->\n\n# 849 \"lib/read.mll\"\n \n# 849 \"lib/read.mll\"\n ( () )\n\n# 2721 \"lib/read.ml\"\n\n \n# 2722 \"lib/read.ml\"\n | 2 ->\n\n# 850 \"lib/read.mll\"\n \n# 850 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2726 \"lib/read.ml\"\n\n \n# 2727 \"lib/read.ml\"\n | 3 ->\n\n# 851 \"lib/read.mll\"\n \n# 851 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2731 \"lib/read.ml\"\n\n \n# 2732 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state\n\nand skip_ident v lexbuf =\n __ocaml_lex_skip_ident_rec v lexbuf 394\nand __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 854 \"lib/read.mll\"\n \n# 854 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2743 \"lib/read.ml\"\n\n \n# 2744 \"lib/read.ml\"\n | 1 ->\n\n# 855 \"lib/read.mll\"\n \n# 855 \"lib/read.mll\"\n ( () )\n\n# 2748 \"lib/read.ml\"\n\n \n# 2749 \"lib/read.ml\"\n | 2 ->\n\n# 856 \"lib/read.mll\"\n \n# 856 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2753 \"lib/read.ml\"\n\n \n# 2754 \"lib/read.ml\"\n | 3 ->\n\n# 857 \"lib/read.mll\"\n \n# 857 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2758 \"lib/read.ml\"\n\n \n# 2759 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_json v lexbuf =\n __ocaml_lex_buffer_json_rec v lexbuf 399\nand __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 870 \"lib/read.mll\"\n \n# 870 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2770 \"lib/read.ml\"\n\n \n# 2771 \"lib/read.ml\"\n | 1 ->\n\n# 872 \"lib/read.mll\"\n \n# 872 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2775 \"lib/read.ml\"\n\n \n# 2776 \"lib/read.ml\"\n | 2 ->\n\n# 873 \"lib/read.mll\"\n \n# 873 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '{';\n buffer_space v lexbuf;\n buffer_object_end v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_object_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2802 \"lib/read.ml\"\n\n \n# 2803 \"lib/read.ml\"\n | 3 ->\n\n# 897 \"lib/read.mll\"\n \n# 897 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '[';\n buffer_space v lexbuf;\n buffer_array_end v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_array_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2821 \"lib/read.ml\"\n\n \n# 2822 \"lib/read.ml\"\n | 4 ->\n\n# 913 \"lib/read.mll\"\n \n# 913 \"lib/read.mll\"\n (\n \n# 915 \"lib/read.mll\"\n try\n Bi_outbuf.add_char v.buf '(';\n buffer_space v lexbuf;\n buffer_tuple_end v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_tuple_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_tuple ->\n ()\n \n# 932 \"lib/read.mll\"\n )\n\n# 2845 \"lib/read.ml\"\n\n \n# 2846 \"lib/read.ml\"\n | 5 ->\n\n# 934 \"lib/read.mll\"\n \n# 934 \"lib/read.mll\"\n (\n \n# 936 \"lib/read.mll\"\n Bi_outbuf.add_char v.buf '<';\n buffer_space v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n finish_buffer_variant v lexbuf\n \n# 944 \"lib/read.mll\"\n )\n\n# 2860 \"lib/read.ml\"\n\n \n# 2861 \"lib/read.ml\"\n | 6 ->\n\n# 946 \"lib/read.mll\"\n \n# 946 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2865 \"lib/read.ml\"\n\n \n# 2866 \"lib/read.ml\"\n | 7 ->\n\n# 947 \"lib/read.mll\"\n \n# 947 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_json v lexbuf )\n\n# 2872 \"lib/read.ml\"\n\n \n# 2873 \"lib/read.ml\"\n | 8 ->\n\n# 950 \"lib/read.mll\"\n \n# 950 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_json v lexbuf )\n\n# 2879 \"lib/read.ml\"\n\n \n# 2880 \"lib/read.ml\"\n | 9 ->\n\n# 953 \"lib/read.mll\"\n \n# 953 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2884 \"lib/read.ml\"\n\n \n# 2885 \"lib/read.ml\"\n | 10 ->\n\n# 954 \"lib/read.mll\"\n \n# 954 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2889 \"lib/read.ml\"\n\n \n# 2890 \"lib/read.ml\"\n | 11 ->\n\n# 955 \"lib/read.mll\"\n \n# 955 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2894 \"lib/read.ml\"\n\n \n# 2895 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_stringlit v lexbuf =\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf 450\nand __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 961 \"lib/read.mll\"\n \n# 961 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\"';\n add_lexeme v.buf lexbuf\n )\n\n# 2908 \"lib/read.ml\"\n\n \n# 2909 \"lib/read.ml\"\n | 1 ->\n\n# 964 \"lib/read.mll\"\n \n# 964 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2913 \"lib/read.ml\"\n\n \n# 2914 \"lib/read.ml\"\n | 2 ->\n\n# 965 \"lib/read.mll\"\n \n# 965 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2918 \"lib/read.ml\"\n\n \n# 2919 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_variant v lexbuf =\n __ocaml_lex_finish_buffer_variant_rec v lexbuf 461\nand __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 968 \"lib/read.mll\"\n \n# 968 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':';\n buffer_json v lexbuf;\n buffer_space v lexbuf;\n buffer_gt v lexbuf )\n\n# 2933 \"lib/read.ml\"\n\n \n# 2934 \"lib/read.ml\"\n | 1 ->\n\n# 972 \"lib/read.mll\"\n \n# 972 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 2938 \"lib/read.ml\"\n\n \n# 2939 \"lib/read.ml\"\n | 2 ->\n\n# 973 \"lib/read.mll\"\n \n# 973 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2943 \"lib/read.ml\"\n\n \n# 2944 \"lib/read.ml\"\n | 3 ->\n\n# 974 \"lib/read.mll\"\n \n# 974 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2948 \"lib/read.ml\"\n\n \n# 2949 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state\n\nand buffer_ident v lexbuf =\n __ocaml_lex_buffer_ident_rec v lexbuf 466\nand __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 977 \"lib/read.mll\"\n \n# 977 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2960 \"lib/read.ml\"\n\n \n# 2961 \"lib/read.ml\"\n | 1 ->\n\n# 978 \"lib/read.mll\"\n \n# 978 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2965 \"lib/read.ml\"\n\n \n# 2966 \"lib/read.ml\"\n | 2 ->\n\n# 979 \"lib/read.mll\"\n \n# 979 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2970 \"lib/read.ml\"\n\n \n# 2971 \"lib/read.ml\"\n | 3 ->\n\n# 980 \"lib/read.mll\"\n \n# 980 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2975 \"lib/read.ml\"\n\n \n# 2976 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_space v lexbuf =\n __ocaml_lex_buffer_space_rec v lexbuf 471\nand __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 983 \"lib/read.mll\"\n \n# 983 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 2990 \"lib/read.ml\"\n\n \n# 2991 \"lib/read.ml\"\n | 1 ->\n\n# 987 \"lib/read.mll\"\n \n# 987 \"lib/read.mll\"\n (\n Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_space v lexbuf )\n\n# 2998 \"lib/read.ml\"\n\n \n# 2999 \"lib/read.ml\"\n | 2 ->\n\n# 991 \"lib/read.mll\"\n \n# 991 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 3006 \"lib/read.ml\"\n\n \n# 3007 \"lib/read.ml\"\n | 3 ->\n\n# 995 \"lib/read.mll\"\n \n# 995 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n buffer_space v lexbuf )\n\n# 3013 \"lib/read.ml\"\n\n \n# 3014 \"lib/read.ml\"\n | 4 ->\n\n# 998 \"lib/read.mll\"\n \n# 998 \"lib/read.mll\"\n ( () )\n\n# 3018 \"lib/read.ml\"\n\n \n# 3019 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_end v lexbuf =\n __ocaml_lex_buffer_object_end_rec v lexbuf 478\nand __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1001 \"lib/read.mll\"\n \n# 1001 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '}';\n raise End_of_object )\n\n# 3032 \"lib/read.ml\"\n\n \n# 3033 \"lib/read.ml\"\n | 1 ->\n\n# 1004 \"lib/read.mll\"\n \n# 1004 \"lib/read.mll\"\n ( () )\n\n# 3037 \"lib/read.ml\"\n\n \n# 3038 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_sep v lexbuf =\n __ocaml_lex_buffer_object_sep_rec v lexbuf 480\nand __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1007 \"lib/read.mll\"\n \n# 1007 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3049 \"lib/read.ml\"\n\n \n# 3050 \"lib/read.ml\"\n | 1 ->\n\n# 1008 \"lib/read.mll\"\n \n# 1008 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '}'; raise End_of_object )\n\n# 3054 \"lib/read.ml\"\n\n \n# 3055 \"lib/read.ml\"\n | 2 ->\n\n# 1009 \"lib/read.mll\"\n \n# 1009 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 3059 \"lib/read.ml\"\n\n \n# 3060 \"lib/read.ml\"\n | 3 ->\n\n# 1010 \"lib/read.mll\"\n \n# 1010 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3064 \"lib/read.ml\"\n\n \n# 3065 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_end v lexbuf =\n __ocaml_lex_buffer_array_end_rec v lexbuf 485\nand __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1013 \"lib/read.mll\"\n \n# 1013 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3076 \"lib/read.ml\"\n\n \n# 3077 \"lib/read.ml\"\n | 1 ->\n\n# 1014 \"lib/read.mll\"\n \n# 1014 \"lib/read.mll\"\n ( () )\n\n# 3081 \"lib/read.ml\"\n\n \n# 3082 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_sep v lexbuf =\n __ocaml_lex_buffer_array_sep_rec v lexbuf 487\nand __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1017 \"lib/read.mll\"\n \n# 1017 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3093 \"lib/read.ml\"\n\n \n# 3094 \"lib/read.ml\"\n | 1 ->\n\n# 1018 \"lib/read.mll\"\n \n# 1018 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3098 \"lib/read.ml\"\n\n \n# 3099 \"lib/read.ml\"\n | 2 ->\n\n# 1019 \"lib/read.mll\"\n \n# 1019 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 3103 \"lib/read.ml\"\n\n \n# 3104 \"lib/read.ml\"\n | 3 ->\n\n# 1020 \"lib/read.mll\"\n \n# 1020 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3108 \"lib/read.ml\"\n\n \n# 3109 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_end v lexbuf =\n __ocaml_lex_buffer_tuple_end_rec v lexbuf 492\nand __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1023 \"lib/read.mll\"\n \n# 1023 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf ')';\n raise End_of_tuple )\n\n# 3122 \"lib/read.ml\"\n\n \n# 3123 \"lib/read.ml\"\n | 1 ->\n\n# 1026 \"lib/read.mll\"\n \n# 1026 \"lib/read.mll\"\n ( () )\n\n# 3127 \"lib/read.ml\"\n\n \n# 3128 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_sep v lexbuf =\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf 494\nand __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1029 \"lib/read.mll\"\n \n# 1029 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3139 \"lib/read.ml\"\n\n \n# 3140 \"lib/read.ml\"\n | 1 ->\n\n# 1030 \"lib/read.mll\"\n \n# 1030 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ')'; raise End_of_tuple )\n\n# 3144 \"lib/read.ml\"\n\n \n# 3145 \"lib/read.ml\"\n | 2 ->\n\n# 1031 \"lib/read.mll\"\n \n# 1031 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 3149 \"lib/read.ml\"\n\n \n# 3150 \"lib/read.ml\"\n | 3 ->\n\n# 1032 \"lib/read.mll\"\n \n# 1032 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3154 \"lib/read.ml\"\n\n \n# 3155 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_colon v lexbuf =\n __ocaml_lex_buffer_colon_rec v lexbuf 499\nand __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1035 \"lib/read.mll\"\n \n# 1035 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':' )\n\n# 3166 \"lib/read.ml\"\n\n \n# 3167 \"lib/read.ml\"\n | 1 ->\n\n# 1036 \"lib/read.mll\"\n \n# 1036 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 3171 \"lib/read.ml\"\n\n \n# 3172 \"lib/read.ml\"\n | 2 ->\n\n# 1037 \"lib/read.mll\"\n \n# 1037 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3176 \"lib/read.ml\"\n\n \n# 3177 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state\n\nand buffer_gt v lexbuf =\n __ocaml_lex_buffer_gt_rec v lexbuf 503\nand __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1040 \"lib/read.mll\"\n \n# 1040 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 3188 \"lib/read.ml\"\n\n \n# 3189 \"lib/read.ml\"\n | 1 ->\n\n# 1041 \"lib/read.mll\"\n \n# 1041 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 3193 \"lib/read.ml\"\n\n \n# 3194 \"lib/read.ml\"\n | 2 ->\n\n# 1042 \"lib/read.mll\"\n \n# 1042 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3198 \"lib/read.ml\"\n\n \n# 3199 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_comment v lexbuf =\n __ocaml_lex_finish_buffer_comment_rec v lexbuf 507\nand __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1045 \"lib/read.mll\"\n \n# 1045 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"*/\" )\n\n# 3210 \"lib/read.ml\"\n\n \n# 3211 \"lib/read.ml\"\n | 1 ->\n\n# 1046 \"lib/read.mll\"\n \n# 1046 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 3215 \"lib/read.ml\"\n\n \n# 3216 \"lib/read.ml\"\n | 2 ->\n\n# 1047 \"lib/read.mll\"\n \n# 1047 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n finish_buffer_comment v lexbuf )\n\n# 3222 \"lib/read.ml\"\n\n \n# 3223 \"lib/read.ml\"\n | 3 ->\n\n# 1050 \"lib/read.mll\"\n \n# 1050 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; finish_buffer_comment v lexbuf )\n\n# 3227 \"lib/read.ml\"\n\n \n# 3228 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state\n\nand junk lexbuf =\n __ocaml_lex_junk_rec lexbuf 513\nand __ocaml_lex_junk_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1053 \"lib/read.mll\"\n \n# 1053 \"lib/read.mll\"\n ( Lexing.lexeme lexbuf )\n\n# 3239 \"lib/read.ml\"\n\n \n# 3240 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_junk_rec lexbuf __ocaml_lex_state\n\n;;\n\n\n# 1055 \"lib/read.mll\"\n \n \n# 1056 \"lib/read.mll\"\n let _ = (read_json : lexer_state -> Lexing.lexbuf -> t)\n\n let read_t = read_json\n\n let () =\n read_junk := junk\n\n let read_int8 v lexbuf =\n let n = read_int v lexbuf in\n if n < 0 || n > 255 then\n lexer_error \"Int8 overflow\" v lexbuf\n else\n char_of_int n\n\n let read_list read_cell v lexbuf =\n List.rev (read_list_rev read_cell v lexbuf)\n\n let array_of_rev_list l =\n match l with\n [] -> [| |]\n | x :: tl ->\n let len = List.length l in\n let a = Array.make len x in\n let r = ref tl in\n for i = len - 2 downto 0 do\n a.(i) <- List.hd !r;\n r := List.tl !r\n done;\n a\n\n let read_array read_cell v lexbuf =\n let l = read_list_rev read_cell v lexbuf in\n array_of_rev_list l\n\n (* Read a JSON object, reading the keys into OCaml strings\n (provided for backward compatibility) *)\n let read_fields read_field init_acc v =\n read_abstract_fields read_ident read_field init_acc v\n\n let finish v lexbuf =\n read_space v lexbuf;\n if not (read_eof lexbuf) then\n long_error \"Junk after end of JSON value:\" v lexbuf\n\n let init_lexer = init_lexer\n\n let from_lexbuf v ?(stream = false) lexbuf =\n read_space v lexbuf;\n\n let x =\n if read_eof lexbuf then\n raise End_of_input\n else\n read_json v lexbuf\n in\n\n if not stream then\n finish v lexbuf;\n\n x\n\n\n let from_string ?buf ?fname ?lnum s =\n try\n let lexbuf = Lexing.from_string s in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_channel ?buf ?fname ?lnum ic =\n try\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n try\n let x = from_channel ?buf ?fname ?lnum ic in\n close_in ic;\n x\n with e ->\n close_in_noerr ic;\n raise e\n\n exception Finally of exn * exn\n\n let stream_from_lexbuf v ?(fin = fun () -> ()) lexbuf =\n let stream = Some true in\n let f i =\n try Some (from_lexbuf v ?stream lexbuf)\n with\n End_of_input ->\n fin ();\n None\n | e ->\n (try fin () with fin_e -> raise (Finally (e, fin_e)));\n raise e\n in\n Stream.from f\n\n let stream_from_string ?buf ?fname ?lnum s =\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v (Lexing.from_string s)\n\n let stream_from_channel ?buf ?fin ?fname ?lnum ic =\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ?fin lexbuf\n\n let stream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ~fin lexbuf\n\n type json_line = [ `Json of t | `Exn of exn ]\n\n let linestream_from_channel\n ?buf ?(fin = fun () -> ()) ?fname ?lnum:(lnum0 = 1) ic =\n let buf =\n match buf with\n None -> Some (Bi_outbuf.create 256)\n | Some _ -> buf\n in\n let f i =\n try\n let line = input_line ic in\n let lnum = lnum0 + i in\n Some (`Json (from_string ?buf ?fname ~lnum line))\n with\n End_of_file -> fin (); None\n | e -> Some (`Exn e)\n in\n Stream.from f\n\n let linestream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n linestream_from_channel ?buf ~fin ?fname ?lnum ic\n\n let prettify ?std s =\n pretty_to_string ?std (from_string s)\n\n let compact ?std s =\n to_string (from_string s)\n\n let validate_json _path _value = None\n\n\n# 3411 \"lib/read.ml\"\n# 62 \"yojson.cppo.ml\"\nmodule Util =\nstruct\n# 1 \"util.ml\"\nexception Type_error of string * t\n\nlet typeof = function\n | `Assoc _ -> \"object\"\n | `Bool _ -> \"bool\"\n | `Float _ -> \"float\"\n | `Int _ -> \"int\"\n | `List _ -> \"array\"\n | `Null -> \"null\"\n | `String _ -> \"string\"\n | `Intlit _ -> \"intlit\"\n | `Tuple _ -> \"tuple\"\n | `Variant _ -> \"variant\"\n\nlet typerr msg js = raise (Type_error (msg ^ typeof js, js))\n\nexception Undefined of string * t\n\nlet ( |> ) = ( |> )\n\nlet assoc name obj =\n try List.assoc name obj\n with Not_found -> `Null\n\nlet member name = function\n | `Assoc obj -> assoc name obj\n | js -> typerr (\"Can't get member '\" ^ name ^ \"' of non-object type \") js\n\nlet index i = function\n | `List l as js ->\n let len = List.length l in\n let wrapped_index = if i < 0 then len + i else i in\n if wrapped_index < 0 || wrapped_index >= len then\n raise (Undefined (\"Index \" ^ string_of_int i ^ \" out of bounds\", js))\n else List.nth l wrapped_index\n | js -> typerr (\"Can't get index \" ^ string_of_int i\n ^ \" of non-array type \") js\n\nlet map f = function\n | `List l -> `List (List.map f l)\n | js -> typerr \"Can't map function over non-array type \" js\n\nlet to_assoc = function\n | `Assoc obj -> obj\n | js -> typerr \"Expected object, got \" js\n\nlet to_option f = function\n | `Null -> None\n | x -> Some (f x)\n\nlet to_bool = function\n | `Bool b -> b\n | js -> typerr \"Expected bool, got \" js\n\nlet to_bool_option = function\n | `Bool b -> Some b\n | `Null -> None\n | js -> typerr \"Expected bool or null, got \" js\n\nlet to_number = function\n | `Int i -> float i\n | `Float f -> f\n | js -> typerr \"Expected number, got \" js\n\nlet to_number_option = function\n | `Int i -> Some (float i)\n | `Float f -> Some f\n | `Null -> None\n | js -> typerr \"Expected number or null, got \" js\n\nlet to_float = function\n | `Float f -> f\n | js -> typerr \"Expected float, got \" js\n\nlet to_float_option = function\n | `Float f -> Some f\n | `Null -> None\n | js -> typerr \"Expected float or null, got \" js\n\nlet to_int = function\n | `Int i -> i\n | js -> typerr \"Expected int, got \" js\n\nlet to_int_option = function\n | `Int i -> Some i\n | `Null -> None\n | js -> typerr \"Expected int or null, got \" js\n\nlet to_list = function\n | `List l -> l\n | js -> typerr \"Expected array, got \" js\n\nlet to_string = function\n | `String s -> s\n | js -> typerr \"Expected string, got \" js\n\nlet to_string_option = function\n | `String s -> Some s\n | `Null -> None\n | js -> typerr \"Expected string or null, got \" js\n\nlet convert_each f = function\n | `List l -> List.map f l\n | js -> typerr \"Can't convert each element of non-array type \" js\n\n\nlet rec rev_filter_map f acc l =\n match l with\n [] -> acc\n | x :: tl ->\n match f x with\n None -> rev_filter_map f acc tl\n | Some y -> rev_filter_map f (y :: acc) tl\n\nlet filter_map f l =\n List.rev (rev_filter_map f [] l)\n\nlet rec rev_flatten acc l =\n match l with\n [] -> acc\n | x :: tl ->\n match x with\n `List l2 -> rev_flatten (List.rev_append l2 acc) tl\n | _ -> rev_flatten acc tl\n\nlet flatten l =\n List.rev (rev_flatten [] l)\n\nlet filter_index i l =\n filter_map (\n function\n `List l ->\n (try Some (List.nth l i)\n with _ -> None)\n | _ -> None\n ) l\n\nlet filter_list l =\n filter_map (\n function\n `List l -> Some l\n | _ -> None\n ) l\n\nlet filter_member k l =\n filter_map (\n function\n `Assoc l ->\n (try Some (List.assoc k l)\n with _ -> None)\n | _ -> None\n ) l\n\nlet filter_assoc l =\n filter_map (\n function\n `Assoc l -> Some l\n | _ -> None\n ) l\n\nlet filter_bool l =\n filter_map (\n function\n `Bool x -> Some x\n | _ -> None\n ) l\n\nlet filter_int l =\n filter_map (\n function\n `Int x -> Some x\n | _ -> None\n ) l\n\nlet filter_float l =\n filter_map (\n function\n `Float x -> Some x\n | _ -> None\n ) l\n\nlet filter_number l =\n filter_map (\n function\n `Int x -> Some (float x)\n | `Float x -> Some x\n | _ -> None\n ) l\n\nlet filter_string l =\n filter_map (\n function\n `String x -> Some x\n | _ -> None\n ) l\n\nlet keys o =\n to_assoc o |> List.map (fun (key, _) -> key)\n\nlet values o =\n to_assoc o |> List.map (fun (_, value) -> value)\n\nlet combine (first : t) (second : t) =\n match (first, second) with\n | (`Assoc a, `Assoc b) -> (`Assoc (a @ b) : t)\n | (a, b) -> raise (Invalid_argument \"Expected two objects, check inputs\")\n# 65 \"yojson.cppo.ml\"\nend\n# 72 \"yojson.cppo.ml\"\nend\n\nmodule Raw =\nstruct\n# 1 \"type.ml\"\n(** {3 Type of the JSON tree} *)\n\ntype t =\n [\n | `Null\n | `Bool of bool\n \n# 11 \"type.ml\"\n | `Intlit of string\n \n# 17 \"type.ml\"\n | `Floatlit of string\n \n# 23 \"type.ml\"\n | `Stringlit of string\n \n# 25 \"type.ml\"\n | `Assoc of (string * t) list\n | `List of t list\n \n# 28 \"type.ml\"\n | `Tuple of t list\n \n# 31 \"type.ml\"\n | `Variant of (string * t option)\n \n# 33 \"type.ml\"\n ]\n(**\nAll possible cases defined in Yojson:\n- `Null: JSON null\n- `Bool of bool: JSON boolean\n- `Int of int: JSON number without decimal point or exponent.\n- `Intlit of string: JSON number without decimal point or exponent,\n\t preserved as a string.\n- `Float of float: JSON number, Infinity, -Infinity or NaN.\n- `Floatlit of string: JSON number, Infinity, -Infinity or NaN,\n\t preserved as a string.\n- `String of string: JSON string. Bytes in the range 128-255 are preserved\n\t as-is without encoding validation for both reading\n\t and writing.\n- `Stringlit of string: JSON string literal including the double quotes.\n- `Assoc of (string * json) list: JSON object.\n- `List of json list: JSON array.\n- `Tuple of json list: Tuple (non-standard extension of JSON).\n\t Syntax: [(\"abc\", 123)].\n- `Variant of (string * json option): Variant (non-standard extension of JSON).\n\t Syntax: [<\"Foo\">] or [<\"Bar\":123>].\n*)\n\ntype json = t [@@deprecated \"json types are being renamed and will be removed in the next Yojson major version. Use type t instead\"]\n(**\n * Compatibility type alias for type `t`\n *)\n\n(*\n Note to adventurers: ocamldoc does not support inline comments\n on each polymorphic variant, and cppo doesn't allow to concatenate\n comments, so it would be complicated to document only the\n cases that are preserved by cppo in the type definition.\n*)\n# 1 \"write.ml\"\n(* included: type.ml *)\n\nlet hex n =\n Char.chr (\n if n < 10 then n + 48\n else n + 87\n )\n\nlet write_special src start stop ob str =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n Bi_outbuf.add_string ob str;\n start := stop + 1\n\nlet write_control_char src start stop ob c =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n let i = Bi_outbuf.alloc ob 6 in\n let dst = ob.o_s in\n Bytes.blit_string \"\\\\u00\" 0 dst i 4;\n Bytes.set dst (i+4) (hex (Char.code c lsr 4));\n Bytes.set dst (i+5) (hex (Char.code c land 0xf));\n start := stop + 1\n\nlet finish_string src start ob =\n try\n Bi_outbuf.add_substring ob src !start (String.length src - !start)\n with exc ->\n Printf.eprintf \"src=%S start=%i len=%i\\n%!\"\n src !start (String.length src - !start);\n raise exc\n\nlet write_string_body ob s =\n let start = ref 0 in\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '\"' -> write_special s start i ob \"\\\\\\\"\"\n | '\\\\' -> write_special s start i ob \"\\\\\\\\\"\n | '\\b' -> write_special s start i ob \"\\\\b\"\n | '\\012' -> write_special s start i ob \"\\\\f\"\n | '\\n' -> write_special s start i ob \"\\\\n\"\n | '\\r' -> write_special s start i ob \"\\\\r\"\n | '\\t' -> write_special s start i ob \"\\\\t\"\n | '\\x00'..'\\x1F'\n | '\\x7F' as c -> write_control_char s start i ob c\n | _ -> ()\n done;\n finish_string s start ob\n\nlet write_string ob s =\n Bi_outbuf.add_char ob '\"';\n write_string_body ob s;\n Bi_outbuf.add_char ob '\"'\n\nlet json_string_of_string s =\n let ob = Bi_outbuf.create 10 in\n write_string ob s;\n Bi_outbuf.contents ob\n\nlet test_string () =\n let s = Bytes.create 256 in\n for i = 0 to 255 do\n Bytes.set s i (Char.chr i)\n done;\n json_string_of_string (Bytes.to_string s)\n\n\nlet write_null ob () =\n Bi_outbuf.add_string ob \"null\"\n\nlet write_bool ob x =\n Bi_outbuf.add_string ob (if x then \"true\" else \"false\")\n\n\nlet max_digits =\n max\n (String.length (string_of_int max_int))\n (String.length (string_of_int min_int))\n\nlet dec n =\n Char.chr (n + 48)\n\nlet rec write_digits s pos x =\n if x = 0 then pos\n else\n let d = x mod 10 in\n let pos = write_digits s pos (x / 10) in\n Bytes.set s pos (dec (abs d));\n pos + 1\n\nlet write_int ob x =\n Bi_outbuf.extend ob max_digits;\n if x > 0 then\n ob.o_len <- write_digits ob.o_s ob.o_len x\n else if x < 0 then (\n let s = ob.o_s in\n let pos = ob.o_len in\n Bytes.set s pos '-';\n ob.o_len <- write_digits s (pos + 1) x\n )\n else\n Bi_outbuf.add_char ob '0'\n\n\nlet json_string_of_int i =\n string_of_int i\n\n\n(*\n Ensure that the float is not printed as an int.\n This is not required by JSON, but useful in order to guarantee\n reversibility.\n*)\nlet float_needs_period s =\n try\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '0'..'9' | '-' -> ()\n | _ -> raise Exit\n done;\n true\n with Exit ->\n false\n\n(*\n Both write_float_fast and write_float guarantee\n that a sufficient number of digits are printed in order to\n allow reversibility.\n\n The _fast version is faster but often produces unnecessarily long numbers.\n*)\nlet write_float_fast ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_normal_float_prec significant_figures ob x =\n let open Printf in\n let s =\n match significant_figures with\n 1 -> sprintf \"%.1g\" x\n | 2 -> sprintf \"%.2g\" x\n | 3 -> sprintf \"%.3g\" x\n | 4 -> sprintf \"%.4g\" x\n | 5 -> sprintf \"%.5g\" x\n | 6 -> sprintf \"%.6g\" x\n | 7 -> sprintf \"%.7g\" x\n | 8 -> sprintf \"%.8g\" x\n | 9 -> sprintf \"%.9g\" x\n | 10 -> sprintf \"%.10g\" x\n | 11 -> sprintf \"%.11g\" x\n | 12 -> sprintf \"%.12g\" x\n | 13 -> sprintf \"%.13g\" x\n | 14 -> sprintf \"%.14g\" x\n | 15 -> sprintf \"%.15g\" x\n | 16 -> sprintf \"%.16g\" x\n | _ -> sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_float ob x;\n Bi_outbuf.contents ob\n\n\nlet write_std_float_fast ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet std_json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_std_float ob x;\n Bi_outbuf.contents ob\n\n\nlet test_float () =\n let l = [ 0.; 1.; -1. ] in\n let l = l @ List.map (fun x -> 2. *. x +. 1.) l in\n let l = l @ List.map (fun x -> x /. sqrt 2.) l in\n let l = l @ List.map (fun x -> x *. sqrt 3.) l in\n let l = l @ List.map cos l in\n let l = l @ List.map (fun x -> x *. 1.23e50) l in\n let l = l @ [ infinity; neg_infinity ] in\n List.iter (\n fun x ->\n let s = Printf.sprintf \"%.17g\" x in\n let y = float_of_string s in\n Printf.printf \"%g %g %S %B\\n\" x y s (x = y)\n )\n l\n\n(*\nlet () = test_float ()\n*)\n\nlet write_intlit = Bi_outbuf.add_string\nlet write_floatlit = Bi_outbuf.add_string\nlet write_stringlit = Bi_outbuf.add_string\n\nlet rec iter2_aux f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_sep x;\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet iter2 f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet f_sep ob =\n Bi_outbuf.add_char ob ','\n\nlet rec write_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 302 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 308 \"write.ml\"\n | `Floatlit s -> Bi_outbuf.add_string ob s\n \n# 314 \"write.ml\"\n | `Stringlit s -> Bi_outbuf.add_string ob s\n \n# 316 \"write.ml\"\n | `Assoc l -> write_assoc ob l\n | `List l -> write_list ob l\n \n# 319 \"write.ml\"\n | `Tuple l -> write_tuple ob l\n \n# 322 \"write.ml\"\n | `Variant (s, o) -> write_variant ob s o\n\n# 325 \"write.ml\"\nand write_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 341 \"write.ml\"\nand write_tuple ob l =\n Bi_outbuf.add_char ob '(';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ')'\n\n# 348 \"write.ml\"\nand write_variant ob s o =\n Bi_outbuf.add_char ob '<';\n write_string ob s;\n (match o with\n None -> ()\n | Some x ->\n Bi_outbuf.add_char ob ':';\n write_json ob x\n );\n Bi_outbuf.add_char ob '>'\n\n# 360 \"write.ml\"\nlet write_t = write_json\n\nlet rec write_std_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 370 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 376 \"write.ml\"\n | `Floatlit s -> Bi_outbuf.add_string ob s\n \n# 382 \"write.ml\"\n | `Stringlit s -> Bi_outbuf.add_string ob s\n \n# 384 \"write.ml\"\n | `Assoc l -> write_std_assoc ob l\n | `List l -> write_std_list ob l\n \n# 387 \"write.ml\"\n | `Tuple l -> write_std_tuple ob l\n \n# 390 \"write.ml\"\n | `Variant (s, o) -> write_std_variant ob s o\n\n# 393 \"write.ml\"\nand write_std_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_std_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_std_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\nand write_std_tuple ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 414 \"write.ml\"\nand write_std_variant ob s o =\n match o with\n None -> write_string ob s\n | Some x ->\n Bi_outbuf.add_char ob '[';\n write_string ob s;\n Bi_outbuf.add_char ob ',';\n write_std_json ob x;\n Bi_outbuf.add_char ob ']'\n\n\n# 426 \"write.ml\"\nlet to_outbuf ?(std = false) ob x =\n if std then (\n if not (is_object_or_array x) then\n json_error \"Root is not an object or array\"\n else\n write_std_json ob x\n )\n else\n write_json ob x\n\n\nlet to_string ?buf ?(len = 256) ?std x =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n to_outbuf ?std ob x;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet to_channel ?buf ?len ?std oc x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_channel_writer ob\n\nlet to_output ?buf ?len ?std out x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_output_writer ?len out\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_output_writer ob\n\nlet to_file ?len ?std file x =\n let oc = open_out file in\n try\n to_channel ?len ?std oc x;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\nlet stream_to_outbuf ?std ob st =\n Stream.iter (to_outbuf ?std ob) st\n\nlet stream_to_string ?buf ?(len = 256) ?std st =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n stream_to_outbuf ?std ob st;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet stream_to_channel ?buf ?len ?std oc st =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n stream_to_outbuf ?std ob st;\n Bi_outbuf.flush_channel_writer ob\n\nlet stream_to_file ?len ?std file st =\n let oc = open_out file in\n try\n stream_to_channel ?len ?std oc st;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\n\nlet rec sort = function\n | `Assoc l ->\n let l = List.rev (List.rev_map (fun (k, v) -> (k, sort v)) l) in\n `Assoc (List.stable_sort (fun (a, _) (b, _) -> String.compare a b) l)\n | `List l ->\n `List (List.rev (List.rev_map sort l))\n \n# 519 \"write.ml\"\n | `Tuple l ->\n `Tuple (List.rev (List.rev_map sort l))\n \n# 523 \"write.ml\"\n | `Variant (k, Some v) as x ->\n let v' = sort v in\n if v == v' then x\n else\n `Variant (k, Some v')\n \n# 529 \"write.ml\"\n | x -> x\n# 1 \"monomorphic.ml\"\nlet rec pp fmt =\n function\n | `Null -> Format.pp_print_string fmt \"`Null\"\n | `Bool x ->\n Format.fprintf fmt \"`Bool (@[\";\n Format.fprintf fmt \"%B\" x;\n Format.fprintf fmt \"@])\"\n \n# 15 \"monomorphic.ml\"\n | `Intlit x ->\n Format.fprintf fmt \"`Intlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 27 \"monomorphic.ml\"\n | `Floatlit x ->\n Format.fprintf fmt \"`Floatlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 39 \"monomorphic.ml\"\n | `Stringlit x ->\n Format.fprintf fmt \"`Stringlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 44 \"monomorphic.ml\"\n | `Assoc xs ->\n Format.fprintf fmt \"`Assoc (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep (key, value) ->\n if sep then\n Format.fprintf fmt \";@ \";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" key;\n Format.fprintf fmt \",@ \";\n pp fmt value;\n Format.fprintf fmt \"@])\";\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n | `List xs ->\n Format.fprintf fmt \"`List (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep x ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt x;\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 71 \"monomorphic.ml\"\n | `Tuple tup ->\n Format.fprintf fmt \"`Tuple (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep e ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt e;\n true) false tup);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 84 \"monomorphic.ml\"\n | `Variant (name, value) ->\n Format.fprintf fmt \"`Variant (@[\";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" name;\n Format.fprintf fmt \",@ \";\n (match value with\n | None -> Format.pp_print_string fmt \"None\"\n | Some x ->\n Format.pp_print_string fmt \"(Some \";\n pp fmt x;\n Format.pp_print_string fmt \")\");\n Format.fprintf fmt \"@])\";\n Format.fprintf fmt \"@])\"\n\n# 99 \"monomorphic.ml\"\nlet show x =\n Format.asprintf \"%a\" pp x\n\nlet rec equal a b =\n match a, b with\n | `Null, `Null -> true\n | `Bool a, `Bool b -> a = b\n \n# 110 \"monomorphic.ml\"\n | `Intlit a, `Intlit b -> a = b\n \n# 116 \"monomorphic.ml\"\n | `Floatlit a, `Floatlit b -> a = b\n \n# 122 \"monomorphic.ml\"\n | `Stringlit a, `Stringlit b -> a = b\n \n# 124 \"monomorphic.ml\"\n | `Assoc xs, `Assoc ys ->\n let compare_keys = fun (key, _) (key', _) -> String.compare key key' in\n let xs = List.stable_sort compare_keys xs in\n let ys = List.stable_sort compare_keys ys in\n (match List.for_all2 (fun (key, value) (key', value') ->\n match key = key' with\n | false -> false\n | true -> equal value value') xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 137 \"monomorphic.ml\"\n | `Tuple xs, `Tuple ys\n \n# 139 \"monomorphic.ml\"\n | `List xs, `List ys ->\n (match List.for_all2 equal xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 146 \"monomorphic.ml\"\n | `Variant (name, value), `Variant (name', value') ->\n (match name = name' with\n | false -> false\n | true ->\n match value, value' with\n | None, None -> true\n | Some x, Some y -> equal x y\n | _ -> false)\n \n# 155 \"monomorphic.ml\"\n | _ -> false\n# 1 \"write2.ml\"\nlet pretty_format ?std (x : t) =\n Pretty.format ?std (x :> json_max)\n\nlet pretty_print ?std out (x : t) =\n Easy_format.Pretty.to_formatter out (pretty_format ?std x)\n\nlet pretty_to_string ?std (x : t) =\n Pretty.to_string ?std (x :> json_max)\n\nlet pretty_to_channel ?std oc (x : t) =\n Pretty.to_channel ?std oc (x :> json_max)\n\n# 1 \"lib/read.mll\"\n \n \n# 2 \"lib/read.mll\"\n module Lexing =\n (*\n We override Lexing.engine in order to avoid creating a new position\n record each time a rule is matched.\n This reduces total parsing time by about 31%.\n *)\n struct\n include Lexing\n\n external c_engine : lex_tables -> int -> lexbuf -> int = \"caml_lex_engine\"\n\n let engine tbl state buf =\n let result = c_engine tbl state buf in\n (*\n if result >= 0 then begin\n buf.lex_start_p <- buf.lex_curr_p;\n buf.lex_curr_p <- {buf.lex_curr_p\n with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n end;\n *)\n result\n end\n\n open Printf\n open Lexing\n\n (* see description in common.mli *)\n type lexer_state = Lexer_state.t = {\n buf : Bi_outbuf.t;\n mutable lnum : int;\n mutable bol : int;\n mutable fname : string option;\n }\n\n let dec c =\n Char.code c - 48\n\n let hex c =\n match c with\n '0'..'9' -> int_of_char c - int_of_char '0'\n | 'a'..'f' -> int_of_char c - int_of_char 'a' + 10\n | 'A'..'F' -> int_of_char c - int_of_char 'A' + 10\n | _ -> assert false\n\n let custom_error descr v lexbuf =\n let offs = lexbuf.lex_abs_pos - 1 in\n let bol = v.bol in\n let pos1 = offs + lexbuf.lex_start_pos - bol - 1 in\n let pos2 = max pos1 (offs + lexbuf.lex_curr_pos - bol) in\n let file_line =\n match v.fname with\n None -> \"Line\"\n | Some s ->\n sprintf \"File %s, line\" s\n in\n let bytes =\n if pos1 = pos2 then\n sprintf \"byte %i\" (pos1+1)\n else\n sprintf \"bytes %i-%i\" (pos1+1) (pos2+1)\n in\n let msg = sprintf \"%s %i, %s:\\n%s\" file_line v.lnum bytes descr in\n json_error msg\n\n\n let lexer_error descr v lexbuf =\n custom_error\n (sprintf \"%s '%s'\" descr (Lexing.lexeme lexbuf))\n v lexbuf\n\n let read_junk = ref (fun _ -> assert false)\n\n let long_error descr v lexbuf =\n let junk = Lexing.lexeme lexbuf in\n let extra_junk = !read_junk lexbuf in\n custom_error\n (sprintf \"%s '%s%s'\" descr junk extra_junk)\n v lexbuf\n\n let min10 = min_int / 10 - (if min_int mod 10 = 0 then 0 else 1)\n let max10 = max_int / 10 + (if max_int mod 10 = 0 then 0 else 1)\n\n exception Int_overflow\n\n let extract_positive_int lexbuf =\n let start = lexbuf.lex_start_pos in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n >= max10 then\n raise Int_overflow\n else\n n := 10 * !n + dec (Bytes.get s i)\n done;\n if !n < 0 then\n raise Int_overflow\n else\n !n\n\n let make_positive_int v lexbuf =\n \n# 108 \"lib/read.mll\"\n `Intlit (lexeme lexbuf)\n\n \n# 113 \"lib/read.mll\"\n let extract_negative_int lexbuf =\n let start = lexbuf.lex_start_pos + 1 in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n <= min10 then\n raise Int_overflow\n else\n n := 10 * !n - dec (Bytes.get s i)\n done;\n if !n > 0 then\n raise Int_overflow\n else\n !n\n\n let make_negative_int v lexbuf =\n \n# 135 \"lib/read.mll\"\n `Intlit (lexeme lexbuf)\n\n\n \n# 141 \"lib/read.mll\"\n let set_file_name v fname =\n v.fname <- fname\n\n let newline v lexbuf =\n v.lnum <- v.lnum + 1;\n v.bol <- lexbuf.lex_abs_pos + lexbuf.lex_curr_pos\n\n let add_lexeme buf lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n Bi_outbuf.add_subbytes buf lexbuf.lex_buffer lexbuf.lex_start_pos len\n\n let map_lexeme f lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n f (Bytes.to_string lexbuf.lex_buffer) lexbuf.lex_start_pos len\n\n type variant_kind = [ `Edgy_bracket | `Square_bracket | `Double_quote ]\n type tuple_kind = [ `Parenthesis | `Square_bracket ]\n\n\n# 161 \"lib/read.ml\"\n# 161 \"lib/read.ml\"\nlet __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\236\\255\\237\\255\\003\\000\\239\\255\\016\\000\\242\\255\\243\\255\\\n \\244\\255\\245\\255\\000\\000\\031\\000\\249\\255\\085\\000\\001\\000\\000\\000\\\n \\000\\000\\001\\000\\000\\000\\001\\000\\002\\000\\255\\255\\000\\000\\000\\000\\\n \\003\\000\\254\\255\\001\\000\\004\\000\\253\\255\\011\\000\\252\\255\\003\\000\\\n \\001\\000\\003\\000\\002\\000\\003\\000\\000\\000\\251\\255\\021\\000\\097\\000\\\n \\010\\000\\022\\000\\020\\000\\016\\000\\022\\000\\012\\000\\008\\000\\250\\255\\\n \\119\\000\\129\\000\\139\\000\\161\\000\\171\\000\\181\\000\\193\\000\\209\\000\\\n \\240\\255\\011\\000\\038\\000\\252\\255\\065\\000\\254\\255\\255\\255\\110\\000\\\n \\252\\255\\163\\000\\254\\255\\255\\255\\234\\000\\247\\255\\248\\255\\048\\001\\\n \\250\\255\\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\071\\001\\126\\001\\\n \\149\\001\\249\\255\\039\\000\\253\\255\\254\\255\\038\\000\\187\\001\\210\\001\\\n \\248\\001\\015\\002\\255\\255\\220\\000\\253\\255\\255\\255\\245\\000\\039\\002\\\n \\109\\002\\014\\001\\088\\002\\164\\002\\187\\002\\225\\002\\013\\000\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\014\\000\\253\\255\\254\\255\\255\\255\\030\\000\\\n \\253\\255\\254\\255\\255\\255\\015\\000\\253\\255\\254\\255\\255\\255\\017\\001\\\n \\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\019\\000\\252\\255\\253\\255\\\n \\254\\255\\015\\000\\255\\255\\016\\000\\255\\255\\008\\001\\005\\000\\253\\255\\\n \\023\\000\\254\\255\\020\\000\\255\\255\\046\\000\\253\\255\\254\\255\\042\\000\\\n \\052\\000\\053\\000\\255\\255\\053\\000\\048\\000\\091\\000\\092\\000\\255\\255\\\n \\027\\001\\250\\255\\251\\255\\137\\000\\104\\000\\089\\000\\088\\000\\106\\000\\\n \\255\\255\\143\\000\\137\\000\\177\\000\\254\\255\\183\\000\\168\\000\\166\\000\\\n \\183\\000\\002\\000\\253\\255\\177\\000\\172\\000\\187\\000\\004\\000\\252\\255\\\n \\053\\002\\251\\255\\252\\255\\253\\255\\103\\001\\255\\255\\248\\002\\254\\255\\\n \\006\\003\\030\\003\\252\\255\\253\\255\\254\\255\\255\\255\\040\\003\\050\\003\\\n \\074\\003\\252\\255\\253\\255\\254\\255\\255\\255\\061\\003\\084\\003\\108\\003\\\n \\249\\255\\250\\255\\251\\255\\244\\000\\120\\003\\142\\003\\179\\000\\194\\000\\\n \\015\\000\\255\\255\\190\\000\\188\\000\\187\\000\\193\\000\\183\\000\\179\\000\\\n \\254\\255\\191\\000\\201\\000\\200\\000\\196\\000\\203\\000\\193\\000\\189\\000\\\n \\253\\255\\157\\003\\095\\003\\174\\003\\196\\003\\206\\003\\216\\003\\228\\003\\\n \\239\\003\\060\\000\\253\\255\\254\\255\\255\\255\\012\\004\\252\\255\\253\\255\\\n \\087\\004\\255\\255\\145\\004\\252\\255\\253\\255\\221\\004\\255\\255\\229\\000\\\n \\253\\255\\254\\255\\255\\255\\231\\000\\253\\255\\254\\255\\255\\255\\002\\000\\\n \\255\\255\\018\\001\\252\\255\\253\\255\\254\\255\\255\\255\\034\\001\\253\\255\\\n \\254\\255\\255\\255\\000\\000\\255\\255\\003\\000\\254\\255\\255\\255\\038\\001\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\120\\001\\251\\255\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\208\\000\\253\\255\\254\\255\\255\\255\\211\\000\\253\\255\\\n \\254\\255\\255\\255\\189\\000\\255\\255\\143\\001\\252\\255\\253\\255\\254\\255\\\n \\255\\255\\013\\001\\253\\255\\254\\255\\255\\255\\095\\001\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\050\\001\\253\\255\\254\\255\\255\\255\\026\\001\\253\\255\\\n \\254\\255\\255\\255\\233\\000\\253\\255\\254\\255\\255\\255\\222\\000\\253\\255\\\n \\254\\255\\255\\255\\079\\005\\237\\255\\238\\255\\010\\000\\240\\255\\044\\001\\\n \\243\\255\\244\\255\\245\\255\\246\\255\\061\\001\\002\\004\\249\\255\\045\\005\\\n \\209\\000\\228\\000\\211\\000\\232\\000\\225\\000\\223\\000\\240\\000\\255\\255\\\n \\235\\000\\234\\000\\008\\001\\254\\255\\004\\001\\023\\001\\253\\255\\054\\001\\\n \\252\\255\\031\\001\\029\\001\\032\\001\\039\\001\\049\\001\\045\\001\\251\\255\\\n \\057\\001\\082\\001\\080\\001\\078\\001\\084\\001\\074\\001\\086\\001\\250\\255\\\n \\110\\005\\012\\004\\123\\005\\155\\005\\165\\005\\177\\005\\187\\005\\197\\005\\\n \\241\\255\\199\\001\\077\\002\\253\\255\\255\\255\\154\\002\\222\\005\\209\\005\\\n \\155\\002\\239\\005\\053\\006\\076\\006\\114\\006\\016\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\152\\006\\252\\255\\253\\255\\227\\006\\255\\255\\085\\007\\\n \\244\\255\\245\\255\\011\\000\\247\\255\\076\\002\\250\\255\\251\\255\\252\\255\\\n \\253\\255\\254\\255\\031\\002\\243\\005\\051\\007\\100\\001\\115\\001\\104\\001\\\n \\133\\001\\118\\001\\154\\001\\171\\001\\255\\255\\173\\001\\176\\001\\191\\001\\\n \\185\\001\\187\\001\\253\\001\\230\\001\\230\\001\\234\\001\\247\\001\\237\\001\\\n \\234\\001\\009\\002\\019\\002\\019\\002\\015\\002\\021\\002\\011\\002\\007\\002\\\n \\142\\006\\152\\006\\116\\007\\170\\007\\180\\007\\190\\007\\200\\007\\210\\007\\\n \\248\\255\\120\\002\\167\\002\\253\\255\\255\\255\\216\\002\\082\\007\\220\\007\\\n \\236\\002\\244\\007\\058\\008\\081\\008\\119\\008\\076\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\157\\008\\252\\255\\253\\255\\232\\008\\255\\255\\135\\002\\\n \\120\\002\\253\\255\\100\\002\\254\\255\\182\\002\\255\\255\\011\\002\\255\\255\\\n \\204\\002\\252\\255\\253\\255\\254\\255\\255\\255\\046\\002\\255\\255\\178\\002\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\023\\000\\255\\255\\183\\002\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\187\\002\\253\\255\\254\\255\\255\\255\\121\\002\\\n \\253\\255\\254\\255\\255\\255\\184\\002\\252\\255\\253\\255\\254\\255\\019\\000\\\n \\255\\255\\140\\001\\146\\001\\255\\255\\150\\001\\151\\001\\154\\001\\168\\001\\\n \\170\\001\\171\\001\\172\\001\\173\\001\\181\\001\\184\\001\\185\\001\\187\\001\\\n \\191\\001\\193\\001\\195\\001\\196\\001\\197\\001\\200\\001\\203\\001\\223\\001\\\n \\225\\001\\228\\001\\249\\001\\251\\001\\002\\002\\004\\002\\011\\002\\012\\002\\\n \\013\\002\\000\\000\";\n Lexing.lex_backtrk =\n \"\\255\\255\\255\\255\\255\\255\\017\\000\\255\\255\\019\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\008\\000\\008\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\\n \\255\\255\\014\\000\\255\\255\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\003\\000\\255\\255\\001\\000\\255\\255\\004\\000\\003\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\004\\000\\004\\000\\004\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\000\\000\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\003\\000\\005\\000\\005\\000\\005\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\003\\000\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\016\\000\\255\\255\\018\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\\n \\255\\255\\013\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\011\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\000\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\006\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\004\\000\\\n \\003\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\";\n Lexing.lex_default =\n \"\\001\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\057\\000\\060\\000\\000\\000\\060\\000\\000\\000\\000\\000\\065\\000\\\n \\000\\000\\065\\000\\000\\000\\000\\000\\070\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\084\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\094\\000\\000\\000\\000\\000\\097\\000\\255\\255\\\n \\255\\255\\097\\000\\255\\255\\255\\255\\255\\255\\255\\255\\104\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\109\\000\\000\\000\\000\\000\\000\\000\\113\\000\\\n \\000\\000\\000\\000\\000\\000\\117\\000\\000\\000\\000\\000\\000\\000\\121\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\126\\000\\000\\000\\000\\000\\\n \\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\000\\000\\138\\000\\000\\000\\142\\000\\000\\000\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\154\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\178\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\\n \\255\\255\\187\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\194\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\201\\000\\\n \\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\235\\000\\000\\000\\000\\000\\000\\000\\239\\000\\000\\000\\000\\000\\\n \\255\\255\\000\\000\\244\\000\\000\\000\\000\\000\\255\\255\\000\\000\\249\\000\\\n \\000\\000\\000\\000\\000\\000\\253\\000\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\003\\001\\000\\000\\000\\000\\000\\000\\000\\000\\008\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\017\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\022\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\028\\001\\000\\000\\000\\000\\000\\000\\032\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\038\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\043\\001\\000\\000\\000\\000\\000\\000\\047\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\052\\001\\000\\000\\000\\000\\000\\000\\056\\001\\000\\000\\\n \\000\\000\\000\\000\\060\\001\\000\\000\\000\\000\\000\\000\\064\\001\\000\\000\\\n \\000\\000\\000\\000\\067\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\121\\001\\125\\001\\000\\000\\000\\000\\128\\001\\255\\255\\255\\255\\\n \\128\\001\\255\\255\\255\\255\\255\\255\\255\\255\\135\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\140\\001\\000\\000\\000\\000\\255\\255\\000\\000\\144\\001\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\193\\001\\197\\001\\000\\000\\000\\000\\200\\001\\255\\255\\255\\255\\\n \\200\\001\\255\\255\\255\\255\\255\\255\\255\\255\\207\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\212\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\000\\000\\220\\001\\000\\000\\255\\255\\000\\000\\\n \\226\\001\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\233\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\240\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\245\\001\\000\\000\\000\\000\\000\\000\\249\\001\\\n \\000\\000\\000\\000\\000\\000\\252\\001\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\002\\002\\004\\002\\000\\000\\005\\002\\006\\002\\007\\002\\008\\002\\\n \\009\\002\\010\\002\\011\\002\\012\\002\\013\\002\\014\\002\\015\\002\\016\\002\\\n \\017\\002\\018\\002\\019\\002\\020\\002\\021\\002\\022\\002\\023\\002\\024\\002\\\n \\025\\002\\026\\002\\027\\002\\028\\002\\029\\002\\030\\002\\031\\002\\032\\002\\\n \\033\\002\\003\\002\";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\003\\000\\004\\000\\000\\000\\003\\000\\003\\000\\134\\000\\000\\000\\\n \\003\\000\\000\\000\\134\\000\\069\\001\\146\\001\\255\\255\\000\\000\\069\\001\\\n \\146\\001\\000\\000\\000\\000\\000\\000\\000\\000\\127\\000\\139\\000\\000\\000\\\n \\003\\000\\000\\000\\012\\000\\003\\000\\170\\000\\134\\000\\175\\000\\000\\000\\\n \\007\\000\\011\\001\\069\\001\\146\\001\\014\\001\\013\\000\\049\\000\\005\\000\\\n \\010\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\056\\000\\118\\000\\006\\000\\129\\000\\130\\000\\057\\000\\\n \\237\\001\\137\\000\\000\\002\\049\\000\\000\\000\\048\\000\\138\\000\\106\\000\\\n \\062\\000\\014\\000\\110\\000\\105\\000\\000\\000\\049\\000\\015\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\030\\000\\048\\000\\008\\000\\114\\000\\209\\000\\236\\000\\000\\001\\\n \\013\\001\\029\\000\\022\\000\\255\\255\\048\\000\\048\\000\\017\\000\\021\\000\\\n \\025\\000\\032\\000\\033\\000\\035\\000\\023\\000\\027\\000\\016\\000\\031\\000\\\n \\028\\000\\034\\000\\019\\000\\024\\000\\018\\000\\026\\000\\020\\000\\036\\000\\\n \\041\\000\\037\\000\\048\\000\\009\\000\\042\\000\\043\\000\\044\\000\\045\\000\\\n \\046\\000\\047\\000\\061\\000\\085\\000\\048\\000\\038\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\049\\000\\\n \\067\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\086\\000\\143\\000\\255\\255\\040\\000\\144\\000\\\n \\145\\000\\146\\000\\055\\000\\148\\000\\055\\000\\149\\000\\048\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\255\\255\\048\\000\\150\\000\\\n \\151\\000\\161\\000\\066\\000\\158\\000\\053\\000\\159\\000\\053\\000\\160\\000\\\n \\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\165\\000\\\n \\051\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\162\\000\\163\\000\\166\\000\\093\\000\\255\\255\\\n \\002\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\255\\255\\077\\000\\103\\000\\108\\000\\116\\000\\\n \\132\\000\\134\\000\\135\\000\\128\\000\\139\\000\\134\\000\\164\\000\\093\\000\\\n \\171\\000\\077\\000\\167\\000\\168\\000\\169\\000\\172\\000\\112\\000\\173\\000\\\n \\174\\000\\210\\000\\226\\000\\208\\000\\211\\000\\212\\000\\059\\000\\083\\000\\\n \\134\\000\\213\\000\\214\\000\\215\\000\\216\\000\\218\\000\\141\\000\\219\\000\\\n \\093\\000\\220\\000\\221\\000\\123\\000\\222\\000\\223\\000\\224\\000\\136\\000\\\n \\095\\000\\225\\000\\035\\001\\065\\001\\234\\000\\155\\000\\005\\001\\097\\001\\\n \\250\\000\\255\\255\\254\\000\\057\\001\\061\\001\\095\\001\\077\\000\\044\\001\\\n \\092\\001\\088\\001\\009\\001\\029\\001\\076\\000\\124\\000\\033\\001\\018\\001\\\n \\075\\000\\098\\000\\019\\001\\085\\001\\086\\001\\087\\001\\120\\001\\089\\001\\\n \\074\\000\\225\\000\\053\\001\\121\\001\\073\\000\\090\\001\\072\\000\\071\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\098\\000\\113\\001\\122\\000\\091\\001\\064\\000\\004\\001\\\n \\093\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\079\\000\\156\\000\\112\\001\\094\\001\\096\\001\\098\\001\\099\\001\\049\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\100\\001\\157\\000\\\n \\101\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\183\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\184\\000\\024\\001\\112\\001\\255\\255\\025\\001\\102\\001\\103\\001\\105\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\\n \\106\\001\\107\\001\\048\\001\\040\\001\\108\\001\\109\\001\\110\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\081\\000\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\111\\001\\\n \\027\\001\\255\\255\\171\\001\\031\\001\\170\\001\\023\\001\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\092\\000\\168\\001\\063\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\248\\000\\165\\001\\252\\000\\\n \\162\\001\\059\\001\\069\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\255\\255\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\039\\001\\042\\001\\255\\255\\163\\001\\\n \\164\\001\\120\\000\\002\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\166\\001\\055\\001\\153\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\007\\001\\167\\001\\164\\001\\169\\001\\016\\001\\164\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\089\\000\\051\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\090\\000\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\\n \\090\\000\\097\\000\\137\\001\\164\\001\\172\\001\\185\\001\\136\\001\\173\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\097\\000\\179\\000\\\n \\174\\001\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\046\\001\\\n \\175\\001\\176\\001\\180\\000\\164\\001\\184\\001\\181\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\124\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\192\\001\\178\\001\\\n \\021\\001\\179\\001\\097\\000\\193\\001\\180\\001\\181\\001\\182\\001\\183\\001\\\n \\164\\001\\216\\001\\255\\255\\097\\000\\184\\001\\216\\001\\209\\001\\097\\000\\\n \\223\\001\\097\\000\\208\\001\\230\\001\\003\\002\\097\\000\\219\\001\\037\\001\\\n \\216\\001\\217\\001\\003\\002\\220\\001\\216\\001\\097\\000\\003\\002\\003\\002\\\n \\216\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\216\\001\\\n \\003\\002\\126\\001\\003\\002\\003\\002\\003\\002\\003\\002\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\097\\000\\003\\002\\218\\001\\250\\001\\\n \\003\\002\\003\\002\\097\\000\\003\\002\\124\\001\\124\\001\\097\\000\\003\\002\\\n \\221\\001\\003\\002\\253\\001\\003\\002\\003\\002\\003\\002\\097\\000\\255\\255\\\n \\003\\002\\196\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\235\\001\\003\\002\\\n \\241\\001\\003\\002\\255\\001\\242\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\246\\001\\129\\001\\129\\001\\\n \\228\\001\\003\\002\\196\\001\\003\\002\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\003\\002\\198\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\003\\002\\003\\002\\003\\002\\196\\001\\234\\001\\\n \\134\\001\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\097\\000\\097\\000\\097\\000\\000\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\000\\000\\000\\000\\201\\001\\177\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\188\\000\\000\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\201\\001\\227\\001\\000\\000\\191\\000\\206\\001\\123\\001\\189\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\189\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\195\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\198\\000\\\n \\255\\255\\248\\001\\196\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\196\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\202\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\227\\000\\205\\000\\255\\255\\255\\255\\203\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\226\\000\\195\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\232\\001\\000\\000\\000\\000\\206\\000\\221\\001\\239\\001\\\n \\254\\001\\000\\000\\207\\000\\244\\001\\000\\000\\225\\000\\203\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\232\\000\\000\\000\\232\\000\\000\\000\\225\\001\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\217\\000\\\n \\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\225\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\000\\000\\230\\000\\\n \\000\\000\\230\\000\\000\\000\\228\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\000\\000\\228\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\186\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\241\\000\\000\\000\\\n \\113\\001\\000\\000\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\000\\000\\112\\001\\\n \\000\\000\\000\\000\\193\\000\\000\\000\\000\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\112\\001\\\n \\000\\000\\000\\000\\000\\000\\240\\000\\200\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\000\\000\\246\\000\\000\\000\\000\\000\\240\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\245\\000\\000\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\238\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\069\\001\\070\\001\\000\\000\\000\\000\\069\\001\\076\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\069\\001\\\n \\000\\000\\078\\001\\000\\000\\000\\000\\000\\000\\000\\000\\104\\001\\073\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\079\\001\\000\\000\\071\\001\\076\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\000\\000\\000\\000\\072\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\243\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\080\\001\\119\\001\\000\\000\\119\\001\\000\\000\\081\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\000\\000\\000\\000\\074\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\083\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\082\\001\\000\\000\\000\\000\\\n \\115\\001\\000\\000\\000\\000\\084\\001\\000\\000\\000\\000\\117\\001\\000\\000\\\n \\117\\001\\000\\000\\075\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\000\\000\\\n \\115\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\000\\000\\\n \\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\\n \\000\\000\\185\\001\\000\\000\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\184\\001\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\128\\001\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\128\\001\\128\\001\\000\\000\\000\\000\\068\\001\\\n \\128\\001\\128\\001\\128\\001\\127\\001\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\184\\001\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\000\\000\\128\\001\\127\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\128\\001\\128\\001\\128\\001\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\191\\001\\142\\001\\191\\001\\000\\000\\000\\000\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\\n \\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\141\\001\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\146\\001\\147\\001\\\n \\000\\000\\000\\000\\146\\001\\154\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\146\\001\\000\\000\\153\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\177\\001\\150\\001\\000\\000\\000\\000\\\n \\000\\000\\200\\001\\156\\001\\000\\000\\148\\001\\154\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\\n \\000\\000\\149\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\139\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\157\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\158\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\200\\001\\000\\000\\\n \\151\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\187\\001\\000\\000\\160\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\159\\001\\200\\001\\000\\000\\200\\001\\199\\001\\\n \\000\\000\\161\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\152\\001\\000\\000\\000\\000\\000\\000\\000\\000\\189\\001\\000\\000\\189\\001\\\n \\000\\000\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\145\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\\n \\200\\001\\199\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\\n \\200\\001\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\000\\000\\214\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\000\\000\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\211\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\000\\000\\255\\255\\003\\000\\000\\000\\134\\000\\255\\255\\\n \\003\\000\\255\\255\\134\\000\\069\\001\\146\\001\\057\\000\\255\\255\\069\\001\\\n \\146\\001\\255\\255\\255\\255\\255\\255\\255\\255\\125\\000\\138\\000\\255\\255\\\n \\000\\000\\255\\255\\000\\000\\003\\000\\169\\000\\134\\000\\174\\000\\255\\255\\\n \\000\\000\\010\\001\\069\\001\\146\\001\\012\\001\\000\\000\\010\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\005\\000\\115\\000\\000\\000\\125\\000\\129\\000\\005\\000\\\n \\236\\001\\136\\000\\255\\001\\038\\000\\255\\255\\010\\000\\136\\000\\102\\000\\\n \\058\\000\\000\\000\\107\\000\\102\\000\\255\\255\\011\\000\\000\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\029\\000\\038\\000\\000\\000\\111\\000\\208\\000\\233\\000\\255\\000\\\n \\012\\001\\015\\000\\017\\000\\060\\000\\011\\000\\010\\000\\000\\000\\020\\000\\\n \\024\\000\\031\\000\\032\\000\\034\\000\\022\\000\\026\\000\\000\\000\\014\\000\\\n \\027\\000\\033\\000\\018\\000\\023\\000\\000\\000\\016\\000\\019\\000\\035\\000\\\n \\040\\000\\036\\000\\038\\000\\000\\000\\041\\000\\042\\000\\043\\000\\044\\000\\\n \\045\\000\\046\\000\\058\\000\\082\\000\\011\\000\\013\\000\\013\\000\\013\\000\\\n \\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\039\\000\\\n \\063\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\085\\000\\140\\000\\060\\000\\013\\000\\143\\000\\\n \\144\\000\\145\\000\\048\\000\\147\\000\\048\\000\\148\\000\\039\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\065\\000\\039\\000\\149\\000\\\n \\150\\000\\156\\000\\063\\000\\157\\000\\051\\000\\158\\000\\051\\000\\159\\000\\\n \\050\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\155\\000\\\n \\050\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\161\\000\\162\\000\\155\\000\\091\\000\\065\\000\\\n \\000\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\057\\000\\068\\000\\102\\000\\107\\000\\115\\000\\\n \\131\\000\\133\\000\\133\\000\\125\\000\\138\\000\\133\\000\\163\\000\\094\\000\\\n \\165\\000\\068\\000\\166\\000\\167\\000\\168\\000\\171\\000\\111\\000\\172\\000\\\n \\173\\000\\206\\000\\203\\000\\207\\000\\210\\000\\211\\000\\058\\000\\082\\000\\\n \\133\\000\\212\\000\\213\\000\\214\\000\\215\\000\\217\\000\\140\\000\\218\\000\\\n \\097\\000\\219\\000\\220\\000\\119\\000\\221\\000\\222\\000\\223\\000\\133\\000\\\n \\091\\000\\203\\000\\034\\001\\062\\001\\233\\000\\152\\000\\001\\001\\080\\001\\\n \\247\\000\\060\\000\\251\\000\\054\\001\\058\\001\\081\\001\\068\\000\\041\\001\\\n \\082\\001\\083\\001\\006\\001\\026\\001\\068\\000\\119\\000\\030\\001\\015\\001\\\n \\068\\000\\094\\000\\015\\001\\084\\001\\085\\001\\086\\001\\071\\001\\088\\001\\\n \\068\\000\\203\\000\\050\\001\\071\\001\\068\\000\\089\\001\\068\\000\\068\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\097\\000\\076\\001\\119\\000\\090\\001\\063\\000\\001\\001\\\n \\092\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\152\\000\\076\\001\\093\\001\\095\\001\\097\\001\\098\\001\\045\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\099\\001\\152\\000\\\n \\100\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\180\\000\\\n \\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\\n \\180\\000\\020\\001\\076\\001\\065\\000\\020\\001\\101\\001\\102\\001\\104\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\105\\001\\106\\001\\045\\001\\036\\001\\107\\001\\108\\001\\109\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\110\\001\\\n \\026\\001\\121\\001\\157\\001\\030\\001\\158\\001\\020\\001\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\091\\000\\159\\001\\062\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\247\\000\\160\\001\\251\\000\\\n \\161\\001\\058\\001\\068\\000\\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\094\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\036\\001\\041\\001\\097\\000\\162\\001\\\n \\163\\001\\119\\000\\001\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\165\\001\\054\\001\\152\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\006\\001\\166\\001\\167\\001\\168\\001\\015\\001\\169\\001\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\050\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\089\\000\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\095\\000\\133\\001\\170\\001\\171\\001\\154\\001\\133\\001\\172\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\095\\000\\176\\000\\\n \\173\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\045\\001\\\n \\174\\001\\175\\001\\176\\000\\176\\001\\154\\001\\176\\000\\176\\000\\176\\000\\\n \\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\122\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\148\\001\\177\\001\\\n \\020\\001\\178\\001\\098\\000\\148\\001\\179\\001\\180\\001\\181\\001\\182\\001\\\n \\183\\001\\216\\001\\193\\001\\095\\000\\154\\001\\216\\001\\205\\001\\098\\000\\\n \\222\\001\\095\\000\\205\\001\\229\\001\\001\\002\\095\\000\\218\\001\\036\\001\\\n \\215\\001\\215\\001\\002\\002\\218\\001\\215\\001\\095\\000\\004\\002\\005\\002\\\n \\216\\001\\095\\000\\006\\002\\095\\000\\095\\000\\096\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\215\\001\\\n \\007\\002\\122\\001\\008\\002\\009\\002\\010\\002\\011\\002\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\098\\000\\012\\002\\215\\001\\247\\001\\\n \\013\\002\\014\\002\\098\\000\\015\\002\\125\\001\\128\\001\\098\\000\\016\\002\\\n \\220\\001\\017\\002\\251\\001\\018\\002\\019\\002\\020\\002\\098\\000\\121\\001\\\n \\021\\002\\194\\001\\098\\000\\022\\002\\098\\000\\098\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\099\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\231\\001\\023\\002\\\n \\238\\001\\024\\002\\251\\001\\238\\001\\025\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\243\\001\\125\\001\\128\\001\\\n \\224\\001\\026\\002\\197\\001\\027\\002\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\028\\002\\194\\001\\029\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\030\\002\\031\\002\\032\\002\\200\\001\\231\\001\\\n \\133\\001\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\255\\255\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\255\\255\\255\\255\\197\\001\\176\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\185\\000\\255\\255\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\200\\001\\224\\001\\255\\255\\185\\000\\205\\001\\122\\001\\185\\000\\185\\000\\\n \\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\\n \\191\\000\\191\\000\\191\\000\\191\\000\\192\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\192\\000\\\n \\193\\001\\247\\001\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\\n \\192\\000\\192\\000\\192\\000\\192\\000\\198\\000\\198\\000\\198\\000\\198\\000\\\n \\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\199\\000\\226\\000\\\n \\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\\n \\226\\000\\199\\000\\125\\001\\128\\001\\199\\000\\199\\000\\199\\000\\199\\000\\\n \\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\204\\000\\194\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\231\\001\\255\\255\\255\\255\\199\\000\\220\\001\\238\\001\\\n \\251\\001\\255\\255\\199\\000\\243\\001\\255\\255\\204\\000\\205\\000\\205\\000\\\n \\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\\n \\225\\000\\255\\255\\225\\000\\255\\255\\224\\001\\225\\000\\225\\000\\225\\000\\\n \\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\205\\000\\\n \\197\\001\\255\\255\\255\\255\\255\\255\\255\\255\\204\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\200\\001\\255\\255\\255\\255\\228\\000\\\n \\255\\255\\228\\000\\255\\255\\227\\000\\228\\000\\228\\000\\228\\000\\228\\000\\\n \\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\\n \\230\\000\\230\\000\\255\\255\\227\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\185\\000\\232\\000\\\n \\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\\n \\232\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\237\\000\\255\\255\\\n \\077\\001\\255\\255\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\113\\001\\113\\001\\113\\001\\113\\001\\\n \\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\255\\255\\077\\001\\\n \\255\\255\\255\\255\\192\\000\\255\\255\\255\\255\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\077\\001\\\n \\255\\255\\255\\255\\255\\255\\237\\000\\199\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\255\\255\\242\\000\\255\\255\\255\\255\\240\\000\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\242\\000\\255\\255\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\237\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\066\\001\\066\\001\\255\\255\\255\\255\\066\\001\\079\\001\\079\\001\\079\\001\\\n \\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\\n \\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\079\\001\\066\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\066\\001\\066\\001\\\n \\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\\n \\066\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\066\\001\\112\\001\\255\\255\\112\\001\\255\\255\\066\\001\\112\\001\\112\\001\\\n \\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\\n \\255\\255\\255\\255\\066\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\066\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\\n \\114\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\115\\001\\255\\255\\\n \\115\\001\\255\\255\\066\\001\\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\\n \\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\255\\255\\\n \\114\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\\n \\117\\001\\117\\001\\117\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\119\\001\\119\\001\\119\\001\\\n \\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\255\\255\\\n \\126\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\127\\001\\127\\001\\127\\001\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\\n \\255\\255\\155\\001\\255\\255\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\155\\001\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\126\\001\\255\\255\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\129\\001\\126\\001\\255\\255\\255\\255\\066\\001\\\n \\126\\001\\129\\001\\126\\001\\126\\001\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\155\\001\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\255\\255\\129\\001\\129\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\131\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\184\\001\\138\\001\\184\\001\\255\\255\\255\\255\\184\\001\\184\\001\\\n \\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\\n \\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\\n \\185\\001\\185\\001\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\138\\001\\\n \\255\\255\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\141\\001\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\143\\001\\143\\001\\\n \\255\\255\\255\\255\\143\\001\\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\\n \\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\156\\001\\143\\001\\255\\255\\255\\255\\\n \\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\143\\001\\143\\001\\143\\001\\\n \\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\255\\255\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\143\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\198\\001\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\198\\001\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\186\\001\\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\255\\255\\255\\255\\143\\001\\198\\001\\255\\255\\198\\001\\198\\001\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\187\\001\\255\\255\\187\\001\\\n \\255\\255\\186\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\\n \\187\\001\\187\\001\\187\\001\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\189\\001\\189\\001\\\n \\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\\n \\191\\001\\191\\001\\191\\001\\191\\001\\199\\001\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\201\\001\\255\\255\\\n \\201\\001\\201\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\255\\255\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\213\\001\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec read_json v lexbuf =\n __ocaml_lex_read_json_rec v lexbuf 0\nand __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 188 \"lib/read.mll\"\n \n# 188 \"lib/read.mll\"\n ( `Bool true )\n\n# 1032 \"lib/read.ml\"\n\n \n# 1033 \"lib/read.ml\"\n | 1 ->\n\n# 189 \"lib/read.mll\"\n \n# 189 \"lib/read.mll\"\n ( `Bool false )\n\n# 1037 \"lib/read.ml\"\n\n \n# 1038 \"lib/read.ml\"\n | 2 ->\n\n# 190 \"lib/read.mll\"\n \n# 190 \"lib/read.mll\"\n ( `Null )\n\n# 1042 \"lib/read.ml\"\n\n \n# 1043 \"lib/read.ml\"\n | 3 ->\n\n# 191 \"lib/read.mll\"\n \n# 191 \"lib/read.mll\"\n (\n \n# 195 \"lib/read.mll\"\n `Floatlit \"NaN\"\n \n# 197 \"lib/read.mll\"\n )\n\n# 1053 \"lib/read.ml\"\n\n \n# 1054 \"lib/read.ml\"\n | 4 ->\n\n# 198 \"lib/read.mll\"\n \n# 198 \"lib/read.mll\"\n (\n \n# 202 \"lib/read.mll\"\n `Floatlit \"Infinity\"\n \n# 204 \"lib/read.mll\"\n )\n\n# 1064 \"lib/read.ml\"\n\n \n# 1065 \"lib/read.ml\"\n | 5 ->\n\n# 205 \"lib/read.mll\"\n \n# 205 \"lib/read.mll\"\n (\n \n# 209 \"lib/read.mll\"\n `Floatlit \"-Infinity\"\n \n# 211 \"lib/read.mll\"\n )\n\n# 1075 \"lib/read.ml\"\n\n \n# 1076 \"lib/read.ml\"\n | 6 ->\n\n# 212 \"lib/read.mll\"\n \n# 212 \"lib/read.mll\"\n (\n \n# 217 \"lib/read.mll\"\n `Stringlit (finish_stringlit v lexbuf)\n \n# 219 \"lib/read.mll\"\n )\n\n# 1087 \"lib/read.ml\"\n\n \n# 1088 \"lib/read.ml\"\n | 7 ->\n\n# 220 \"lib/read.mll\"\n \n# 220 \"lib/read.mll\"\n ( make_positive_int v lexbuf )\n\n# 1092 \"lib/read.ml\"\n\n \n# 1093 \"lib/read.ml\"\n | 8 ->\n\n# 221 \"lib/read.mll\"\n \n# 221 \"lib/read.mll\"\n ( make_negative_int v lexbuf )\n\n# 1097 \"lib/read.ml\"\n\n \n# 1098 \"lib/read.ml\"\n | 9 ->\n\n# 222 \"lib/read.mll\"\n \n# 222 \"lib/read.mll\"\n (\n \n# 226 \"lib/read.mll\"\n `Floatlit (lexeme lexbuf)\n \n# 228 \"lib/read.mll\"\n )\n\n# 1108 \"lib/read.ml\"\n\n \n# 1109 \"lib/read.ml\"\n | 10 ->\n\n# 230 \"lib/read.mll\"\n \n# 230 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n done;\n assert false\n with End_of_object ->\n `Assoc (List.rev !acc)\n )\n\n# 1135 \"lib/read.ml\"\n\n \n# 1136 \"lib/read.ml\"\n | 11 ->\n\n# 254 \"lib/read.mll\"\n \n# 254 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_json v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_json v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n `List (List.rev !acc)\n )\n\n# 1154 \"lib/read.ml\"\n\n \n# 1155 \"lib/read.ml\"\n | 12 ->\n\n# 270 \"lib/read.mll\"\n \n# 270 \"lib/read.mll\"\n (\n \n# 272 \"lib/read.mll\"\n let acc = ref [] in\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n acc := read_json v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n acc := read_json v lexbuf :: !acc;\n done;\n assert false\n with End_of_tuple ->\n `Tuple (List.rev !acc)\n \n# 289 \"lib/read.mll\"\n )\n\n# 1178 \"lib/read.ml\"\n\n \n# 1179 \"lib/read.ml\"\n | 13 ->\n\n# 291 \"lib/read.mll\"\n \n# 291 \"lib/read.mll\"\n (\n \n# 293 \"lib/read.mll\"\n read_space v lexbuf;\n let cons = read_ident v lexbuf in\n read_space v lexbuf;\n `Variant (cons, finish_variant v lexbuf)\n \n# 300 \"lib/read.mll\"\n )\n\n# 1192 \"lib/read.ml\"\n\n \n# 1193 \"lib/read.ml\"\n | 14 ->\n\n# 302 \"lib/read.mll\"\n \n# 302 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1197 \"lib/read.ml\"\n\n \n# 1198 \"lib/read.ml\"\n | 15 ->\n\n# 303 \"lib/read.mll\"\n \n# 303 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_json v lexbuf )\n\n# 1202 \"lib/read.ml\"\n\n \n# 1203 \"lib/read.ml\"\n | 16 ->\n\n# 304 \"lib/read.mll\"\n \n# 304 \"lib/read.mll\"\n ( newline v lexbuf; read_json v lexbuf )\n\n# 1207 \"lib/read.ml\"\n\n \n# 1208 \"lib/read.ml\"\n | 17 ->\n\n# 305 \"lib/read.mll\"\n \n# 305 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1212 \"lib/read.ml\"\n\n \n# 1213 \"lib/read.ml\"\n | 18 ->\n\n# 306 \"lib/read.mll\"\n \n# 306 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1217 \"lib/read.ml\"\n\n \n# 1218 \"lib/read.ml\"\n | 19 ->\n\n# 307 \"lib/read.mll\"\n \n# 307 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 1222 \"lib/read.ml\"\n\n \n# 1223 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state\n\nand finish_string v lexbuf =\n __ocaml_lex_finish_string_rec v lexbuf 58\nand __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 311 \"lib/read.mll\"\n \n# 311 \"lib/read.mll\"\n ( Bi_outbuf.contents v.buf )\n\n# 1234 \"lib/read.ml\"\n\n \n# 1235 \"lib/read.ml\"\n | 1 ->\n\n# 312 \"lib/read.mll\"\n \n# 312 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n finish_string v lexbuf )\n\n# 1240 \"lib/read.ml\"\n\n \n# 1241 \"lib/read.ml\"\n | 2 ->\n\n# 314 \"lib/read.mll\"\n \n# 314 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n finish_string v lexbuf )\n\n# 1246 \"lib/read.ml\"\n\n \n# 1247 \"lib/read.ml\"\n | 3 ->\n\n# 316 \"lib/read.mll\"\n \n# 316 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1251 \"lib/read.ml\"\n\n \n# 1252 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state\n\nand map_string v f lexbuf =\n __ocaml_lex_map_string_rec v f lexbuf 63\nand __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 319 \"lib/read.mll\"\n \n# 319 \"lib/read.mll\"\n ( let b = v.buf in\n f (Bytes.to_string b.Bi_outbuf.o_s) 0 b.Bi_outbuf.o_len )\n\n# 1264 \"lib/read.ml\"\n\n \n# 1265 \"lib/read.ml\"\n | 1 ->\n\n# 321 \"lib/read.mll\"\n \n# 321 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n map_string v f lexbuf )\n\n# 1270 \"lib/read.ml\"\n\n \n# 1271 \"lib/read.ml\"\n | 2 ->\n\n# 323 \"lib/read.mll\"\n \n# 323 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n map_string v f lexbuf )\n\n# 1276 \"lib/read.ml\"\n\n \n# 1277 \"lib/read.ml\"\n | 3 ->\n\n# 325 \"lib/read.mll\"\n \n# 325 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1281 \"lib/read.ml\"\n\n \n# 1282 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state\n\nand finish_escaped_char v lexbuf =\n __ocaml_lex_finish_escaped_char_rec v lexbuf 68\nand __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n c\n\n# 1294 \"lib/read.ml\"\n# 1294 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf lexbuf.Lexing.lex_start_pos in\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf c )\n\n# 1298 \"lib/read.ml\"\n\n \n# 1299 \"lib/read.ml\"\n | 1 ->\n\n# 331 \"lib/read.mll\"\n \n# 331 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\b' )\n\n# 1303 \"lib/read.ml\"\n\n \n# 1304 \"lib/read.ml\"\n | 2 ->\n\n# 332 \"lib/read.mll\"\n \n# 332 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\012' )\n\n# 1308 \"lib/read.ml\"\n\n \n# 1309 \"lib/read.ml\"\n | 3 ->\n\n# 333 \"lib/read.mll\"\n \n# 333 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n' )\n\n# 1313 \"lib/read.ml\"\n\n \n# 1314 \"lib/read.ml\"\n | 4 ->\n\n# 334 \"lib/read.mll\"\n \n# 334 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\r' )\n\n# 1318 \"lib/read.ml\"\n\n \n# 1319 \"lib/read.ml\"\n | 5 ->\n\n# 335 \"lib/read.mll\"\n \n# 335 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\t' )\n\n# 1323 \"lib/read.ml\"\n\n \n# 1324 \"lib/read.ml\"\n | 6 ->\nlet\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n a\n\n# 1329 \"lib/read.ml\"\n# 1329 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 1)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n b\n\n# 1334 \"lib/read.ml\"\n# 1334 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n c\n\n# 1339 \"lib/read.ml\"\n# 1339 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n d\n\n# 1344 \"lib/read.ml\"\n# 1344 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4) in\n\n# 337 \"lib/read.mll\"\n \n# 337 \"lib/read.mll\"\n ( let x =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if x >= 0xD800 && x <= 0xDBFF then\n finish_surrogate_pair v x lexbuf\n else\n utf8_of_code v.buf x\n )\n\n# 1355 \"lib/read.ml\"\n\n \n# 1356 \"lib/read.ml\"\n | 7 ->\n\n# 345 \"lib/read.mll\"\n \n# 345 \"lib/read.mll\"\n ( long_error \"Invalid escape sequence\" v lexbuf )\n\n# 1360 \"lib/read.ml\"\n\n \n# 1361 \"lib/read.ml\"\n | 8 ->\n\n# 346 \"lib/read.mll\"\n \n# 346 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1365 \"lib/read.ml\"\n\n \n# 1366 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state\n\nand finish_surrogate_pair v x lexbuf =\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf 82\nand __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n a\n\n# 1378 \"lib/read.ml\"\n# 1378 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n b\n\n# 1383 \"lib/read.ml\"\n# 1383 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n c\n\n# 1388 \"lib/read.ml\"\n# 1388 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n d\n\n# 1393 \"lib/read.ml\"\n# 1393 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 5) in\n\n# 350 \"lib/read.mll\"\n \n# 350 \"lib/read.mll\"\n ( let y =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if y >= 0xDC00 && y <= 0xDFFF then\n utf8_of_surrogate_pair v.buf x y\n else\n long_error \"Invalid low surrogate for code point beyond U+FFFF\"\n v lexbuf\n )\n\n# 1405 \"lib/read.ml\"\n\n \n# 1406 \"lib/read.ml\"\n | 1 ->\n\n# 359 \"lib/read.mll\"\n \n# 359 \"lib/read.mll\"\n ( long_error \"Missing escape sequence representing low surrogate \\\n for code point beyond U+FFFF\" v lexbuf )\n\n# 1411 \"lib/read.ml\"\n\n \n# 1412 \"lib/read.ml\"\n | 2 ->\n\n# 361 \"lib/read.mll\"\n \n# 361 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1416 \"lib/read.ml\"\n\n \n# 1417 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state\n\nand finish_stringlit v lexbuf =\n __ocaml_lex_finish_stringlit_rec v lexbuf 91\nand __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 366 \"lib/read.mll\"\n \n# 366 \"lib/read.mll\"\n ( let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n let s = Bytes.create (len+1) in\n Bytes.set s 0 '\"';\n Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos s 1 len;\n Bytes.to_string s\n )\n\n# 1433 \"lib/read.ml\"\n\n \n# 1434 \"lib/read.ml\"\n | 1 ->\n\n# 372 \"lib/read.mll\"\n \n# 372 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 1438 \"lib/read.ml\"\n\n \n# 1439 \"lib/read.ml\"\n | 2 ->\n\n# 373 \"lib/read.mll\"\n \n# 373 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1443 \"lib/read.ml\"\n\n \n# 1444 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_variant v lexbuf =\n __ocaml_lex_finish_variant_rec v lexbuf 102\nand __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 376 \"lib/read.mll\"\n \n# 376 \"lib/read.mll\"\n ( let x = read_json v lexbuf in\n read_space v lexbuf;\n read_gt v lexbuf;\n Some x )\n\n# 1458 \"lib/read.ml\"\n\n \n# 1459 \"lib/read.ml\"\n | 1 ->\n\n# 380 \"lib/read.mll\"\n \n# 380 \"lib/read.mll\"\n ( None )\n\n# 1463 \"lib/read.ml\"\n\n \n# 1464 \"lib/read.ml\"\n | 2 ->\n\n# 381 \"lib/read.mll\"\n \n# 381 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 1468 \"lib/read.ml\"\n\n \n# 1469 \"lib/read.ml\"\n | 3 ->\n\n# 382 \"lib/read.mll\"\n \n# 382 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1473 \"lib/read.ml\"\n\n \n# 1474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state\n\nand read_lt v lexbuf =\n __ocaml_lex_read_lt_rec v lexbuf 107\nand __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 385 \"lib/read.mll\"\n \n# 385 \"lib/read.mll\"\n ( () )\n\n# 1485 \"lib/read.ml\"\n\n \n# 1486 \"lib/read.ml\"\n | 1 ->\n\n# 386 \"lib/read.mll\"\n \n# 386 \"lib/read.mll\"\n ( long_error \"Expected '<' but found\" v lexbuf )\n\n# 1490 \"lib/read.ml\"\n\n \n# 1491 \"lib/read.ml\"\n | 2 ->\n\n# 387 \"lib/read.mll\"\n \n# 387 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1495 \"lib/read.ml\"\n\n \n# 1496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state\n\nand read_gt v lexbuf =\n __ocaml_lex_read_gt_rec v lexbuf 111\nand __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 390 \"lib/read.mll\"\n \n# 390 \"lib/read.mll\"\n ( () )\n\n# 1507 \"lib/read.ml\"\n\n \n# 1508 \"lib/read.ml\"\n | 1 ->\n\n# 391 \"lib/read.mll\"\n \n# 391 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 1512 \"lib/read.ml\"\n\n \n# 1513 \"lib/read.ml\"\n | 2 ->\n\n# 392 \"lib/read.mll\"\n \n# 392 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1517 \"lib/read.ml\"\n\n \n# 1518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state\n\nand read_comma v lexbuf =\n __ocaml_lex_read_comma_rec v lexbuf 115\nand __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 395 \"lib/read.mll\"\n \n# 395 \"lib/read.mll\"\n ( () )\n\n# 1529 \"lib/read.ml\"\n\n \n# 1530 \"lib/read.ml\"\n | 1 ->\n\n# 396 \"lib/read.mll\"\n \n# 396 \"lib/read.mll\"\n ( long_error \"Expected ',' but found\" v lexbuf )\n\n# 1534 \"lib/read.ml\"\n\n \n# 1535 \"lib/read.ml\"\n | 2 ->\n\n# 397 \"lib/read.mll\"\n \n# 397 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1539 \"lib/read.ml\"\n\n \n# 1540 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state\n\nand start_any_variant v lexbuf =\n __ocaml_lex_start_any_variant_rec v lexbuf 119\nand __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 400 \"lib/read.mll\"\n \n# 400 \"lib/read.mll\"\n ( `Edgy_bracket )\n\n# 1551 \"lib/read.ml\"\n\n \n# 1552 \"lib/read.ml\"\n | 1 ->\n\n# 401 \"lib/read.mll\"\n \n# 401 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n `Double_quote )\n\n# 1557 \"lib/read.ml\"\n\n \n# 1558 \"lib/read.ml\"\n | 2 ->\n\n# 403 \"lib/read.mll\"\n \n# 403 \"lib/read.mll\"\n ( `Square_bracket )\n\n# 1562 \"lib/read.ml\"\n\n \n# 1563 \"lib/read.ml\"\n | 3 ->\n\n# 404 \"lib/read.mll\"\n \n# 404 \"lib/read.mll\"\n ( long_error \"Expected '<', '\\\"' or '[' but found\" v lexbuf )\n\n# 1567 \"lib/read.ml\"\n\n \n# 1568 \"lib/read.ml\"\n | 4 ->\n\n# 405 \"lib/read.mll\"\n \n# 405 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1572 \"lib/read.ml\"\n\n \n# 1573 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state\n\nand finish_comment v lexbuf =\n __ocaml_lex_finish_comment_rec v lexbuf 125\nand __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 408 \"lib/read.mll\"\n \n# 408 \"lib/read.mll\"\n ( () )\n\n# 1584 \"lib/read.ml\"\n\n \n# 1585 \"lib/read.ml\"\n | 1 ->\n\n# 409 \"lib/read.mll\"\n \n# 409 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 1589 \"lib/read.ml\"\n\n \n# 1590 \"lib/read.ml\"\n | 2 ->\n\n# 410 \"lib/read.mll\"\n \n# 410 \"lib/read.mll\"\n ( newline v lexbuf; finish_comment v lexbuf )\n\n# 1594 \"lib/read.ml\"\n\n \n# 1595 \"lib/read.ml\"\n | 3 ->\n\n# 411 \"lib/read.mll\"\n \n# 411 \"lib/read.mll\"\n ( finish_comment v lexbuf )\n\n# 1599 \"lib/read.ml\"\n\n \n# 1600 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state\n\nand read_eof lexbuf =\n __ocaml_lex_read_eof_rec lexbuf 131\nand __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 419 \"lib/read.mll\"\n \n# 419 \"lib/read.mll\"\n ( true )\n\n# 1611 \"lib/read.ml\"\n\n \n# 1612 \"lib/read.ml\"\n | 1 ->\n\n# 420 \"lib/read.mll\"\n \n# 420 \"lib/read.mll\"\n ( false )\n\n# 1616 \"lib/read.ml\"\n\n \n# 1617 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state\n\nand read_space v lexbuf =\n __ocaml_lex_read_space_rec v lexbuf 133\nand __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 423 \"lib/read.mll\"\n \n# 423 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1628 \"lib/read.ml\"\n\n \n# 1629 \"lib/read.ml\"\n | 1 ->\n\n# 424 \"lib/read.mll\"\n \n# 424 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_space v lexbuf )\n\n# 1633 \"lib/read.ml\"\n\n \n# 1634 \"lib/read.ml\"\n | 2 ->\n\n# 425 \"lib/read.mll\"\n \n# 425 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1638 \"lib/read.ml\"\n\n \n# 1639 \"lib/read.ml\"\n | 3 ->\n\n# 426 \"lib/read.mll\"\n \n# 426 \"lib/read.mll\"\n ( read_space v lexbuf )\n\n# 1643 \"lib/read.ml\"\n\n \n# 1644 \"lib/read.ml\"\n | 4 ->\n\n# 427 \"lib/read.mll\"\n \n# 427 \"lib/read.mll\"\n ( () )\n\n# 1648 \"lib/read.ml\"\n\n \n# 1649 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state\n\nand read_null v lexbuf =\n __ocaml_lex_read_null_rec v lexbuf 140\nand __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 430 \"lib/read.mll\"\n \n# 430 \"lib/read.mll\"\n ( () )\n\n# 1660 \"lib/read.ml\"\n\n \n# 1661 \"lib/read.ml\"\n | 1 ->\n\n# 431 \"lib/read.mll\"\n \n# 431 \"lib/read.mll\"\n ( long_error \"Expected 'null' but found\" v lexbuf )\n\n# 1665 \"lib/read.ml\"\n\n \n# 1666 \"lib/read.ml\"\n | 2 ->\n\n# 432 \"lib/read.mll\"\n \n# 432 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1670 \"lib/read.ml\"\n\n \n# 1671 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state\n\nand read_null_if_possible v lexbuf =\n __ocaml_lex_read_null_if_possible_rec v lexbuf 147\nand __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 435 \"lib/read.mll\"\n \n# 435 \"lib/read.mll\"\n ( true )\n\n# 1682 \"lib/read.ml\"\n\n \n# 1683 \"lib/read.ml\"\n | 1 ->\n\n# 436 \"lib/read.mll\"\n \n# 436 \"lib/read.mll\"\n ( false )\n\n# 1687 \"lib/read.ml\"\n\n \n# 1688 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state\n\nand read_bool v lexbuf =\n __ocaml_lex_read_bool_rec v lexbuf 152\nand __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 439 \"lib/read.mll\"\n \n# 439 \"lib/read.mll\"\n ( true )\n\n# 1699 \"lib/read.ml\"\n\n \n# 1700 \"lib/read.ml\"\n | 1 ->\n\n# 440 \"lib/read.mll\"\n \n# 440 \"lib/read.mll\"\n ( false )\n\n# 1704 \"lib/read.ml\"\n\n \n# 1705 \"lib/read.ml\"\n | 2 ->\n\n# 443 \"lib/read.mll\"\n \n# 443 \"lib/read.mll\"\n ( true )\n\n# 1709 \"lib/read.ml\"\n\n \n# 1710 \"lib/read.ml\"\n | 3 ->\n\n# 444 \"lib/read.mll\"\n \n# 444 \"lib/read.mll\"\n ( false )\n\n# 1714 \"lib/read.ml\"\n\n \n# 1715 \"lib/read.ml\"\n | 4 ->\n\n# 446 \"lib/read.mll\"\n \n# 446 \"lib/read.mll\"\n ( long_error \"Expected 'true' or 'false' but found\" v lexbuf )\n\n# 1719 \"lib/read.ml\"\n\n \n# 1720 \"lib/read.ml\"\n | 5 ->\n\n# 447 \"lib/read.mll\"\n \n# 447 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1724 \"lib/read.ml\"\n\n \n# 1725 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state\n\nand read_int v lexbuf =\n __ocaml_lex_read_int_rec v lexbuf 176\nand __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 450 \"lib/read.mll\"\n \n# 450 \"lib/read.mll\"\n ( try extract_positive_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1738 \"lib/read.ml\"\n\n \n# 1739 \"lib/read.ml\"\n | 1 ->\n\n# 453 \"lib/read.mll\"\n \n# 453 \"lib/read.mll\"\n ( try extract_negative_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1745 \"lib/read.ml\"\n\n \n# 1746 \"lib/read.ml\"\n | 2 ->\n\n# 456 \"lib/read.mll\"\n \n# 456 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n int_of_string s\n with _ ->\n custom_error\n \"Expected an integer but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1763 \"lib/read.ml\"\n\n \n# 1764 \"lib/read.ml\"\n | 3 ->\n\n# 470 \"lib/read.mll\"\n \n# 470 \"lib/read.mll\"\n ( long_error \"Expected integer but found\" v lexbuf )\n\n# 1768 \"lib/read.ml\"\n\n \n# 1769 \"lib/read.ml\"\n | 4 ->\n\n# 471 \"lib/read.mll\"\n \n# 471 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1773 \"lib/read.ml\"\n\n \n# 1774 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state\n\nand read_int32 v lexbuf =\n __ocaml_lex_read_int32_rec v lexbuf 185\nand __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 474 \"lib/read.mll\"\n \n# 474 \"lib/read.mll\"\n ( try Int32.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1787 \"lib/read.ml\"\n\n \n# 1788 \"lib/read.ml\"\n | 1 ->\n\n# 477 \"lib/read.mll\"\n \n# 477 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int32.of_string s\n with _ ->\n custom_error\n \"Expected an int32 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1805 \"lib/read.ml\"\n\n \n# 1806 \"lib/read.ml\"\n | 2 ->\n\n# 491 \"lib/read.mll\"\n \n# 491 \"lib/read.mll\"\n ( long_error \"Expected int32 but found\" v lexbuf )\n\n# 1810 \"lib/read.ml\"\n\n \n# 1811 \"lib/read.ml\"\n | 3 ->\n\n# 492 \"lib/read.mll\"\n \n# 492 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1815 \"lib/read.ml\"\n\n \n# 1816 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state\n\nand read_int64 v lexbuf =\n __ocaml_lex_read_int64_rec v lexbuf 192\nand __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 495 \"lib/read.mll\"\n \n# 495 \"lib/read.mll\"\n ( try Int64.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1829 \"lib/read.ml\"\n\n \n# 1830 \"lib/read.ml\"\n | 1 ->\n\n# 498 \"lib/read.mll\"\n \n# 498 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int64.of_string s\n with _ ->\n custom_error\n \"Expected an int64 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1847 \"lib/read.ml\"\n\n \n# 1848 \"lib/read.ml\"\n | 2 ->\n\n# 512 \"lib/read.mll\"\n \n# 512 \"lib/read.mll\"\n ( long_error \"Expected int64 but found\" v lexbuf )\n\n# 1852 \"lib/read.ml\"\n\n \n# 1853 \"lib/read.ml\"\n | 3 ->\n\n# 513 \"lib/read.mll\"\n \n# 513 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1857 \"lib/read.ml\"\n\n \n# 1858 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state\n\nand read_number v lexbuf =\n __ocaml_lex_read_number_rec v lexbuf 199\nand __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 516 \"lib/read.mll\"\n \n# 516 \"lib/read.mll\"\n ( nan )\n\n# 1869 \"lib/read.ml\"\n\n \n# 1870 \"lib/read.ml\"\n | 1 ->\n\n# 517 \"lib/read.mll\"\n \n# 517 \"lib/read.mll\"\n ( infinity )\n\n# 1874 \"lib/read.ml\"\n\n \n# 1875 \"lib/read.ml\"\n | 2 ->\n\n# 518 \"lib/read.mll\"\n \n# 518 \"lib/read.mll\"\n ( neg_infinity )\n\n# 1879 \"lib/read.ml\"\n\n \n# 1880 \"lib/read.ml\"\n | 3 ->\n\n# 519 \"lib/read.mll\"\n \n# 519 \"lib/read.mll\"\n ( float_of_string (lexeme lexbuf) )\n\n# 1884 \"lib/read.ml\"\n\n \n# 1885 \"lib/read.ml\"\n | 4 ->\n\n# 520 \"lib/read.mll\"\n \n# 520 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant float will pass,\n including hexadecimal and octal notations,\n and embedded underscores. *)\n float_of_string s\n with _ ->\n match s with\n \"NaN\" -> nan\n | \"Infinity\" -> infinity\n | \"-Infinity\" -> neg_infinity\n | _ ->\n custom_error\n \"Expected a number but found a string that \\\n doesn't even represent a number\"\n v lexbuf\n )\n\n# 1906 \"lib/read.ml\"\n\n \n# 1907 \"lib/read.ml\"\n | 5 ->\n\n# 538 \"lib/read.mll\"\n \n# 538 \"lib/read.mll\"\n ( long_error \"Expected number but found\" v lexbuf )\n\n# 1911 \"lib/read.ml\"\n\n \n# 1912 \"lib/read.ml\"\n | 6 ->\n\n# 539 \"lib/read.mll\"\n \n# 539 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1916 \"lib/read.ml\"\n\n \n# 1917 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state\n\nand read_string v lexbuf =\n __ocaml_lex_read_string_rec v lexbuf 233\nand __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 542 \"lib/read.mll\"\n \n# 542 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1929 \"lib/read.ml\"\n\n \n# 1930 \"lib/read.ml\"\n | 1 ->\n\n# 544 \"lib/read.mll\"\n \n# 544 \"lib/read.mll\"\n ( long_error \"Expected '\\\"' but found\" v lexbuf )\n\n# 1934 \"lib/read.ml\"\n\n \n# 1935 \"lib/read.ml\"\n | 2 ->\n\n# 545 \"lib/read.mll\"\n \n# 545 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1939 \"lib/read.ml\"\n\n \n# 1940 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state\n\nand read_ident v lexbuf =\n __ocaml_lex_read_ident_rec v lexbuf 237\nand __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 548 \"lib/read.mll\"\n \n# 548 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1952 \"lib/read.ml\"\n\n \n# 1953 \"lib/read.ml\"\n | 1 ->\nlet\n\n# 550 \"lib/read.mll\"\n \n# 550 \"lib/read.mll\"\n s\n\n# 1958 \"lib/read.ml\"\n# 1958 \"lib/read.ml\"\n= Lexing.sub_lexeme lexbuf lexbuf.Lexing.lex_start_pos lexbuf.Lexing.lex_curr_pos in\n\n# 551 \"lib/read.mll\"\n \n# 551 \"lib/read.mll\"\n ( s )\n\n# 1962 \"lib/read.ml\"\n\n \n# 1963 \"lib/read.ml\"\n | 2 ->\n\n# 552 \"lib/read.mll\"\n \n# 552 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1967 \"lib/read.ml\"\n\n \n# 1968 \"lib/read.ml\"\n | 3 ->\n\n# 553 \"lib/read.mll\"\n \n# 553 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1972 \"lib/read.ml\"\n\n \n# 1973 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state\n\nand map_ident v f lexbuf =\n __ocaml_lex_map_ident_rec v f lexbuf 242\nand __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 556 \"lib/read.mll\"\n \n# 556 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n map_string v f lexbuf )\n\n# 1985 \"lib/read.ml\"\n\n \n# 1986 \"lib/read.ml\"\n | 1 ->\n\n# 559 \"lib/read.mll\"\n \n# 559 \"lib/read.mll\"\n ( map_lexeme f lexbuf )\n\n# 1990 \"lib/read.ml\"\n\n \n# 1991 \"lib/read.ml\"\n | 2 ->\n\n# 560 \"lib/read.mll\"\n \n# 560 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1995 \"lib/read.ml\"\n\n \n# 1996 \"lib/read.ml\"\n | 3 ->\n\n# 561 \"lib/read.mll\"\n \n# 561 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2000 \"lib/read.ml\"\n\n \n# 2001 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state\n\nand read_sequence read_cell init_acc v lexbuf =\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf 247\nand __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 564 \"lib/read.mll\"\n \n# 564 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell !acc v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell !acc v lexbuf;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2026 \"lib/read.ml\"\n\n \n# 2027 \"lib/read.ml\"\n | 1 ->\n\n# 579 \"lib/read.mll\"\n \n# 579 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2031 \"lib/read.ml\"\n\n \n# 2032 \"lib/read.ml\"\n | 2 ->\n\n# 580 \"lib/read.mll\"\n \n# 580 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2036 \"lib/read.ml\"\n\n \n# 2037 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_list_rev read_cell v lexbuf =\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf 251\nand __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 583 \"lib/read.mll\"\n \n# 583 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2062 \"lib/read.ml\"\n\n \n# 2063 \"lib/read.ml\"\n | 1 ->\n\n# 598 \"lib/read.mll\"\n \n# 598 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2067 \"lib/read.ml\"\n\n \n# 2068 \"lib/read.ml\"\n | 2 ->\n\n# 599 \"lib/read.mll\"\n \n# 599 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2072 \"lib/read.ml\"\n\n \n# 2073 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state\n\nand read_array_end lexbuf =\n __ocaml_lex_read_array_end_rec lexbuf 255\nand __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 602 \"lib/read.mll\"\n \n# 602 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2084 \"lib/read.ml\"\n\n \n# 2085 \"lib/read.ml\"\n | 1 ->\n\n# 603 \"lib/read.mll\"\n \n# 603 \"lib/read.mll\"\n ( () )\n\n# 2089 \"lib/read.ml\"\n\n \n# 2090 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state\n\nand read_array_sep v lexbuf =\n __ocaml_lex_read_array_sep_rec v lexbuf 257\nand __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 606 \"lib/read.mll\"\n \n# 606 \"lib/read.mll\"\n ( () )\n\n# 2101 \"lib/read.ml\"\n\n \n# 2102 \"lib/read.ml\"\n | 1 ->\n\n# 607 \"lib/read.mll\"\n \n# 607 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2106 \"lib/read.ml\"\n\n \n# 2107 \"lib/read.ml\"\n | 2 ->\n\n# 608 \"lib/read.mll\"\n \n# 608 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 2111 \"lib/read.ml\"\n\n \n# 2112 \"lib/read.ml\"\n | 3 ->\n\n# 609 \"lib/read.mll\"\n \n# 609 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2116 \"lib/read.ml\"\n\n \n# 2117 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple read_cell init_acc v lexbuf =\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf 262\nand __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 613 \"lib/read.mll\"\n \n# 613 \"lib/read.mll\"\n (\n \n# 615 \"lib/read.mll\"\n let pos = ref 0 in\n let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n acc := read_cell !pos !acc v lexbuf;\n incr pos;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell !pos !acc v lexbuf;\n incr pos;\n done;\n assert false\n with End_of_tuple ->\n !acc\n \n# 635 \"lib/read.mll\"\n )\n\n# 2150 \"lib/read.ml\"\n\n \n# 2151 \"lib/read.ml\"\n | 1 ->\n\n# 636 \"lib/read.mll\"\n \n# 636 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2155 \"lib/read.ml\"\n\n \n# 2156 \"lib/read.ml\"\n | 2 ->\n\n# 637 \"lib/read.mll\"\n \n# 637 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2160 \"lib/read.ml\"\n\n \n# 2161 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_tuple_end lexbuf =\n __ocaml_lex_read_tuple_end_rec lexbuf 266\nand __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 640 \"lib/read.mll\"\n \n# 640 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2172 \"lib/read.ml\"\n\n \n# 2173 \"lib/read.ml\"\n | 1 ->\n\n# 641 \"lib/read.mll\"\n \n# 641 \"lib/read.mll\"\n ( () )\n\n# 2177 \"lib/read.ml\"\n\n \n# 2178 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state\n\nand read_tuple_end2 v std lexbuf =\n __ocaml_lex_read_tuple_end2_rec v std lexbuf 268\nand __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 644 \"lib/read.mll\"\n \n# 644 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ')' or '' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2192 \"lib/read.ml\"\n\n \n# 2193 \"lib/read.ml\"\n | 1 ->\n\n# 648 \"lib/read.mll\"\n \n# 648 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ']' or '' but found\" v lexbuf )\n\n# 2200 \"lib/read.ml\"\n\n \n# 2201 \"lib/read.ml\"\n | 2 ->\n\n# 652 \"lib/read.mll\"\n \n# 652 \"lib/read.mll\"\n ( () )\n\n# 2205 \"lib/read.ml\"\n\n \n# 2206 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state\n\nand read_tuple_sep v lexbuf =\n __ocaml_lex_read_tuple_sep_rec v lexbuf 271\nand __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 655 \"lib/read.mll\"\n \n# 655 \"lib/read.mll\"\n ( () )\n\n# 2217 \"lib/read.ml\"\n\n \n# 2218 \"lib/read.ml\"\n | 1 ->\n\n# 656 \"lib/read.mll\"\n \n# 656 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2222 \"lib/read.ml\"\n\n \n# 2223 \"lib/read.ml\"\n | 2 ->\n\n# 657 \"lib/read.mll\"\n \n# 657 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2227 \"lib/read.ml\"\n\n \n# 2228 \"lib/read.ml\"\n | 3 ->\n\n# 658 \"lib/read.mll\"\n \n# 658 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2232 \"lib/read.ml\"\n\n \n# 2233 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple_sep2 v std lexbuf =\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf 276\nand __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 661 \"lib/read.mll\"\n \n# 661 \"lib/read.mll\"\n ( () )\n\n# 2244 \"lib/read.ml\"\n\n \n# 2245 \"lib/read.ml\"\n | 1 ->\n\n# 662 \"lib/read.mll\"\n \n# 662 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ',' or ']' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2252 \"lib/read.ml\"\n\n \n# 2253 \"lib/read.ml\"\n | 2 ->\n\n# 666 \"lib/read.mll\"\n \n# 666 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2260 \"lib/read.ml\"\n\n \n# 2261 \"lib/read.ml\"\n | 3 ->\n\n# 670 \"lib/read.mll\"\n \n# 670 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2265 \"lib/read.ml\"\n\n \n# 2266 \"lib/read.ml\"\n | 4 ->\n\n# 671 \"lib/read.mll\"\n \n# 671 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2270 \"lib/read.ml\"\n\n \n# 2271 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state\n\nand read_abstract_fields read_key read_field init_acc v lexbuf =\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf 282\nand __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 675 \"lib/read.mll\"\n \n# 675 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n done;\n assert false\n with End_of_object ->\n !acc\n )\n\n# 2304 \"lib/read.ml\"\n\n \n# 2305 \"lib/read.ml\"\n | 1 ->\n\n# 698 \"lib/read.mll\"\n \n# 698 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2309 \"lib/read.ml\"\n\n \n# 2310 \"lib/read.ml\"\n | 2 ->\n\n# 699 \"lib/read.mll\"\n \n# 699 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2314 \"lib/read.ml\"\n\n \n# 2315 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state\n\nand read_lcurl v lexbuf =\n __ocaml_lex_read_lcurl_rec v lexbuf 286\nand __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 702 \"lib/read.mll\"\n \n# 702 \"lib/read.mll\"\n ( () )\n\n# 2326 \"lib/read.ml\"\n\n \n# 2327 \"lib/read.ml\"\n | 1 ->\n\n# 703 \"lib/read.mll\"\n \n# 703 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2331 \"lib/read.ml\"\n\n \n# 2332 \"lib/read.ml\"\n | 2 ->\n\n# 704 \"lib/read.mll\"\n \n# 704 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2336 \"lib/read.ml\"\n\n \n# 2337 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state\n\nand read_object_end lexbuf =\n __ocaml_lex_read_object_end_rec lexbuf 290\nand __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 707 \"lib/read.mll\"\n \n# 707 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2348 \"lib/read.ml\"\n\n \n# 2349 \"lib/read.ml\"\n | 1 ->\n\n# 708 \"lib/read.mll\"\n \n# 708 \"lib/read.mll\"\n ( () )\n\n# 2353 \"lib/read.ml\"\n\n \n# 2354 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state\n\nand read_object_sep v lexbuf =\n __ocaml_lex_read_object_sep_rec v lexbuf 292\nand __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 711 \"lib/read.mll\"\n \n# 711 \"lib/read.mll\"\n ( () )\n\n# 2365 \"lib/read.ml\"\n\n \n# 2366 \"lib/read.ml\"\n | 1 ->\n\n# 712 \"lib/read.mll\"\n \n# 712 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2370 \"lib/read.ml\"\n\n \n# 2371 \"lib/read.ml\"\n | 2 ->\n\n# 713 \"lib/read.mll\"\n \n# 713 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 2375 \"lib/read.ml\"\n\n \n# 2376 \"lib/read.ml\"\n | 3 ->\n\n# 714 \"lib/read.mll\"\n \n# 714 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2380 \"lib/read.ml\"\n\n \n# 2381 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state\n\nand read_colon v lexbuf =\n __ocaml_lex_read_colon_rec v lexbuf 297\nand __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 717 \"lib/read.mll\"\n \n# 717 \"lib/read.mll\"\n ( () )\n\n# 2392 \"lib/read.ml\"\n\n \n# 2393 \"lib/read.ml\"\n | 1 ->\n\n# 718 \"lib/read.mll\"\n \n# 718 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 2397 \"lib/read.ml\"\n\n \n# 2398 \"lib/read.ml\"\n | 2 ->\n\n# 719 \"lib/read.mll\"\n \n# 719 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2402 \"lib/read.ml\"\n\n \n# 2403 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state\n\nand start_any_tuple v lexbuf =\n __ocaml_lex_start_any_tuple_rec v lexbuf 301\nand __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 722 \"lib/read.mll\"\n \n# 722 \"lib/read.mll\"\n ( false )\n\n# 2414 \"lib/read.ml\"\n\n \n# 2415 \"lib/read.ml\"\n | 1 ->\n\n# 723 \"lib/read.mll\"\n \n# 723 \"lib/read.mll\"\n ( true )\n\n# 2419 \"lib/read.ml\"\n\n \n# 2420 \"lib/read.ml\"\n | 2 ->\n\n# 724 \"lib/read.mll\"\n \n# 724 \"lib/read.mll\"\n ( long_error \"Expected '(' or '[' but found\" v lexbuf )\n\n# 2424 \"lib/read.ml\"\n\n \n# 2425 \"lib/read.ml\"\n | 3 ->\n\n# 725 \"lib/read.mll\"\n \n# 725 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2429 \"lib/read.ml\"\n\n \n# 2430 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state\n\nand read_lpar v lexbuf =\n __ocaml_lex_read_lpar_rec v lexbuf 306\nand __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 728 \"lib/read.mll\"\n \n# 728 \"lib/read.mll\"\n ( () )\n\n# 2441 \"lib/read.ml\"\n\n \n# 2442 \"lib/read.ml\"\n | 1 ->\n\n# 729 \"lib/read.mll\"\n \n# 729 \"lib/read.mll\"\n ( long_error \"Expected '(' but found\" v lexbuf )\n\n# 2446 \"lib/read.ml\"\n\n \n# 2447 \"lib/read.ml\"\n | 2 ->\n\n# 730 \"lib/read.mll\"\n \n# 730 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2451 \"lib/read.ml\"\n\n \n# 2452 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state\n\nand read_rpar v lexbuf =\n __ocaml_lex_read_rpar_rec v lexbuf 310\nand __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 733 \"lib/read.mll\"\n \n# 733 \"lib/read.mll\"\n ( () )\n\n# 2463 \"lib/read.ml\"\n\n \n# 2464 \"lib/read.ml\"\n | 1 ->\n\n# 734 \"lib/read.mll\"\n \n# 734 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2468 \"lib/read.ml\"\n\n \n# 2469 \"lib/read.ml\"\n | 2 ->\n\n# 735 \"lib/read.mll\"\n \n# 735 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2473 \"lib/read.ml\"\n\n \n# 2474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state\n\nand read_lbr v lexbuf =\n __ocaml_lex_read_lbr_rec v lexbuf 314\nand __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 738 \"lib/read.mll\"\n \n# 738 \"lib/read.mll\"\n ( () )\n\n# 2485 \"lib/read.ml\"\n\n \n# 2486 \"lib/read.ml\"\n | 1 ->\n\n# 739 \"lib/read.mll\"\n \n# 739 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2490 \"lib/read.ml\"\n\n \n# 2491 \"lib/read.ml\"\n | 2 ->\n\n# 740 \"lib/read.mll\"\n \n# 740 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2495 \"lib/read.ml\"\n\n \n# 2496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state\n\nand read_rbr v lexbuf =\n __ocaml_lex_read_rbr_rec v lexbuf 318\nand __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 743 \"lib/read.mll\"\n \n# 743 \"lib/read.mll\"\n ( () )\n\n# 2507 \"lib/read.ml\"\n\n \n# 2508 \"lib/read.ml\"\n | 1 ->\n\n# 744 \"lib/read.mll\"\n \n# 744 \"lib/read.mll\"\n ( long_error \"Expected ']' but found\" v lexbuf )\n\n# 2512 \"lib/read.ml\"\n\n \n# 2513 \"lib/read.ml\"\n | 2 ->\n\n# 745 \"lib/read.mll\"\n \n# 745 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2517 \"lib/read.ml\"\n\n \n# 2518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state\n\nand skip_json v lexbuf =\n __ocaml_lex_skip_json_rec v lexbuf 322\nand __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 751 \"lib/read.mll\"\n \n# 751 \"lib/read.mll\"\n ( () )\n\n# 2529 \"lib/read.ml\"\n\n \n# 2530 \"lib/read.ml\"\n | 1 ->\n\n# 752 \"lib/read.mll\"\n \n# 752 \"lib/read.mll\"\n ( () )\n\n# 2534 \"lib/read.ml\"\n\n \n# 2535 \"lib/read.ml\"\n | 2 ->\n\n# 753 \"lib/read.mll\"\n \n# 753 \"lib/read.mll\"\n ( () )\n\n# 2539 \"lib/read.ml\"\n\n \n# 2540 \"lib/read.ml\"\n | 3 ->\n\n# 754 \"lib/read.mll\"\n \n# 754 \"lib/read.mll\"\n ( () )\n\n# 2544 \"lib/read.ml\"\n\n \n# 2545 \"lib/read.ml\"\n | 4 ->\n\n# 755 \"lib/read.mll\"\n \n# 755 \"lib/read.mll\"\n ( () )\n\n# 2549 \"lib/read.ml\"\n\n \n# 2550 \"lib/read.ml\"\n | 5 ->\n\n# 756 \"lib/read.mll\"\n \n# 756 \"lib/read.mll\"\n ( () )\n\n# 2554 \"lib/read.ml\"\n\n \n# 2555 \"lib/read.ml\"\n | 6 ->\n\n# 757 \"lib/read.mll\"\n \n# 757 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2559 \"lib/read.ml\"\n\n \n# 2560 \"lib/read.ml\"\n | 7 ->\n\n# 758 \"lib/read.mll\"\n \n# 758 \"lib/read.mll\"\n ( () )\n\n# 2564 \"lib/read.ml\"\n\n \n# 2565 \"lib/read.ml\"\n | 8 ->\n\n# 759 \"lib/read.mll\"\n \n# 759 \"lib/read.mll\"\n ( () )\n\n# 2569 \"lib/read.ml\"\n\n \n# 2570 \"lib/read.ml\"\n | 9 ->\n\n# 761 \"lib/read.mll\"\n \n# 761 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_object_end lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2595 \"lib/read.ml\"\n\n \n# 2596 \"lib/read.ml\"\n | 10 ->\n\n# 784 \"lib/read.mll\"\n \n# 784 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_array_end lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2613 \"lib/read.ml\"\n\n \n# 2614 \"lib/read.ml\"\n | 11 ->\n\n# 799 \"lib/read.mll\"\n \n# 799 \"lib/read.mll\"\n (\n \n# 801 \"lib/read.mll\"\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_tuple ->\n ()\n \n# 817 \"lib/read.mll\"\n )\n\n# 2636 \"lib/read.ml\"\n\n \n# 2637 \"lib/read.ml\"\n | 12 ->\n\n# 819 \"lib/read.mll\"\n \n# 819 \"lib/read.mll\"\n (\n \n# 821 \"lib/read.mll\"\n read_space v lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n finish_skip_variant v lexbuf\n \n# 828 \"lib/read.mll\"\n )\n\n# 2650 \"lib/read.ml\"\n\n \n# 2651 \"lib/read.ml\"\n | 13 ->\n\n# 830 \"lib/read.mll\"\n \n# 830 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2655 \"lib/read.ml\"\n\n \n# 2656 \"lib/read.ml\"\n | 14 ->\n\n# 831 \"lib/read.mll\"\n \n# 831 \"lib/read.mll\"\n ( finish_comment v lexbuf; skip_json v lexbuf )\n\n# 2660 \"lib/read.ml\"\n\n \n# 2661 \"lib/read.ml\"\n | 15 ->\n\n# 832 \"lib/read.mll\"\n \n# 832 \"lib/read.mll\"\n ( newline v lexbuf; skip_json v lexbuf )\n\n# 2665 \"lib/read.ml\"\n\n \n# 2666 \"lib/read.ml\"\n | 16 ->\n\n# 833 \"lib/read.mll\"\n \n# 833 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2670 \"lib/read.ml\"\n\n \n# 2671 \"lib/read.ml\"\n | 17 ->\n\n# 834 \"lib/read.mll\"\n \n# 834 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2675 \"lib/read.ml\"\n\n \n# 2676 \"lib/read.ml\"\n | 18 ->\n\n# 835 \"lib/read.mll\"\n \n# 835 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2680 \"lib/read.ml\"\n\n \n# 2681 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_stringlit v lexbuf =\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf 378\nand __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 841 \"lib/read.mll\"\n \n# 841 \"lib/read.mll\"\n ( () )\n\n# 2692 \"lib/read.ml\"\n\n \n# 2693 \"lib/read.ml\"\n | 1 ->\n\n# 842 \"lib/read.mll\"\n \n# 842 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2697 \"lib/read.ml\"\n\n \n# 2698 \"lib/read.ml\"\n | 2 ->\n\n# 843 \"lib/read.mll\"\n \n# 843 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2702 \"lib/read.ml\"\n\n \n# 2703 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_variant v lexbuf =\n __ocaml_lex_finish_skip_variant_rec v lexbuf 389\nand __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 846 \"lib/read.mll\"\n \n# 846 \"lib/read.mll\"\n ( skip_json v lexbuf;\n read_space v lexbuf;\n read_gt v lexbuf )\n\n# 2716 \"lib/read.ml\"\n\n \n# 2717 \"lib/read.ml\"\n | 1 ->\n\n# 849 \"lib/read.mll\"\n \n# 849 \"lib/read.mll\"\n ( () )\n\n# 2721 \"lib/read.ml\"\n\n \n# 2722 \"lib/read.ml\"\n | 2 ->\n\n# 850 \"lib/read.mll\"\n \n# 850 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2726 \"lib/read.ml\"\n\n \n# 2727 \"lib/read.ml\"\n | 3 ->\n\n# 851 \"lib/read.mll\"\n \n# 851 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2731 \"lib/read.ml\"\n\n \n# 2732 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state\n\nand skip_ident v lexbuf =\n __ocaml_lex_skip_ident_rec v lexbuf 394\nand __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 854 \"lib/read.mll\"\n \n# 854 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2743 \"lib/read.ml\"\n\n \n# 2744 \"lib/read.ml\"\n | 1 ->\n\n# 855 \"lib/read.mll\"\n \n# 855 \"lib/read.mll\"\n ( () )\n\n# 2748 \"lib/read.ml\"\n\n \n# 2749 \"lib/read.ml\"\n | 2 ->\n\n# 856 \"lib/read.mll\"\n \n# 856 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2753 \"lib/read.ml\"\n\n \n# 2754 \"lib/read.ml\"\n | 3 ->\n\n# 857 \"lib/read.mll\"\n \n# 857 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2758 \"lib/read.ml\"\n\n \n# 2759 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_json v lexbuf =\n __ocaml_lex_buffer_json_rec v lexbuf 399\nand __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 870 \"lib/read.mll\"\n \n# 870 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2770 \"lib/read.ml\"\n\n \n# 2771 \"lib/read.ml\"\n | 1 ->\n\n# 872 \"lib/read.mll\"\n \n# 872 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2775 \"lib/read.ml\"\n\n \n# 2776 \"lib/read.ml\"\n | 2 ->\n\n# 873 \"lib/read.mll\"\n \n# 873 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '{';\n buffer_space v lexbuf;\n buffer_object_end v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_object_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2802 \"lib/read.ml\"\n\n \n# 2803 \"lib/read.ml\"\n | 3 ->\n\n# 897 \"lib/read.mll\"\n \n# 897 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '[';\n buffer_space v lexbuf;\n buffer_array_end v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_array_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2821 \"lib/read.ml\"\n\n \n# 2822 \"lib/read.ml\"\n | 4 ->\n\n# 913 \"lib/read.mll\"\n \n# 913 \"lib/read.mll\"\n (\n \n# 915 \"lib/read.mll\"\n try\n Bi_outbuf.add_char v.buf '(';\n buffer_space v lexbuf;\n buffer_tuple_end v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_tuple_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_tuple ->\n ()\n \n# 932 \"lib/read.mll\"\n )\n\n# 2845 \"lib/read.ml\"\n\n \n# 2846 \"lib/read.ml\"\n | 5 ->\n\n# 934 \"lib/read.mll\"\n \n# 934 \"lib/read.mll\"\n (\n \n# 936 \"lib/read.mll\"\n Bi_outbuf.add_char v.buf '<';\n buffer_space v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n finish_buffer_variant v lexbuf\n \n# 944 \"lib/read.mll\"\n )\n\n# 2860 \"lib/read.ml\"\n\n \n# 2861 \"lib/read.ml\"\n | 6 ->\n\n# 946 \"lib/read.mll\"\n \n# 946 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2865 \"lib/read.ml\"\n\n \n# 2866 \"lib/read.ml\"\n | 7 ->\n\n# 947 \"lib/read.mll\"\n \n# 947 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_json v lexbuf )\n\n# 2872 \"lib/read.ml\"\n\n \n# 2873 \"lib/read.ml\"\n | 8 ->\n\n# 950 \"lib/read.mll\"\n \n# 950 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_json v lexbuf )\n\n# 2879 \"lib/read.ml\"\n\n \n# 2880 \"lib/read.ml\"\n | 9 ->\n\n# 953 \"lib/read.mll\"\n \n# 953 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2884 \"lib/read.ml\"\n\n \n# 2885 \"lib/read.ml\"\n | 10 ->\n\n# 954 \"lib/read.mll\"\n \n# 954 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2889 \"lib/read.ml\"\n\n \n# 2890 \"lib/read.ml\"\n | 11 ->\n\n# 955 \"lib/read.mll\"\n \n# 955 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2894 \"lib/read.ml\"\n\n \n# 2895 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_stringlit v lexbuf =\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf 450\nand __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 961 \"lib/read.mll\"\n \n# 961 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\"';\n add_lexeme v.buf lexbuf\n )\n\n# 2908 \"lib/read.ml\"\n\n \n# 2909 \"lib/read.ml\"\n | 1 ->\n\n# 964 \"lib/read.mll\"\n \n# 964 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2913 \"lib/read.ml\"\n\n \n# 2914 \"lib/read.ml\"\n | 2 ->\n\n# 965 \"lib/read.mll\"\n \n# 965 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2918 \"lib/read.ml\"\n\n \n# 2919 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_variant v lexbuf =\n __ocaml_lex_finish_buffer_variant_rec v lexbuf 461\nand __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 968 \"lib/read.mll\"\n \n# 968 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':';\n buffer_json v lexbuf;\n buffer_space v lexbuf;\n buffer_gt v lexbuf )\n\n# 2933 \"lib/read.ml\"\n\n \n# 2934 \"lib/read.ml\"\n | 1 ->\n\n# 972 \"lib/read.mll\"\n \n# 972 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 2938 \"lib/read.ml\"\n\n \n# 2939 \"lib/read.ml\"\n | 2 ->\n\n# 973 \"lib/read.mll\"\n \n# 973 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2943 \"lib/read.ml\"\n\n \n# 2944 \"lib/read.ml\"\n | 3 ->\n\n# 974 \"lib/read.mll\"\n \n# 974 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2948 \"lib/read.ml\"\n\n \n# 2949 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state\n\nand buffer_ident v lexbuf =\n __ocaml_lex_buffer_ident_rec v lexbuf 466\nand __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 977 \"lib/read.mll\"\n \n# 977 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2960 \"lib/read.ml\"\n\n \n# 2961 \"lib/read.ml\"\n | 1 ->\n\n# 978 \"lib/read.mll\"\n \n# 978 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2965 \"lib/read.ml\"\n\n \n# 2966 \"lib/read.ml\"\n | 2 ->\n\n# 979 \"lib/read.mll\"\n \n# 979 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2970 \"lib/read.ml\"\n\n \n# 2971 \"lib/read.ml\"\n | 3 ->\n\n# 980 \"lib/read.mll\"\n \n# 980 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2975 \"lib/read.ml\"\n\n \n# 2976 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_space v lexbuf =\n __ocaml_lex_buffer_space_rec v lexbuf 471\nand __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 983 \"lib/read.mll\"\n \n# 983 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 2990 \"lib/read.ml\"\n\n \n# 2991 \"lib/read.ml\"\n | 1 ->\n\n# 987 \"lib/read.mll\"\n \n# 987 \"lib/read.mll\"\n (\n Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_space v lexbuf )\n\n# 2998 \"lib/read.ml\"\n\n \n# 2999 \"lib/read.ml\"\n | 2 ->\n\n# 991 \"lib/read.mll\"\n \n# 991 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 3006 \"lib/read.ml\"\n\n \n# 3007 \"lib/read.ml\"\n | 3 ->\n\n# 995 \"lib/read.mll\"\n \n# 995 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n buffer_space v lexbuf )\n\n# 3013 \"lib/read.ml\"\n\n \n# 3014 \"lib/read.ml\"\n | 4 ->\n\n# 998 \"lib/read.mll\"\n \n# 998 \"lib/read.mll\"\n ( () )\n\n# 3018 \"lib/read.ml\"\n\n \n# 3019 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_end v lexbuf =\n __ocaml_lex_buffer_object_end_rec v lexbuf 478\nand __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1001 \"lib/read.mll\"\n \n# 1001 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '}';\n raise End_of_object )\n\n# 3032 \"lib/read.ml\"\n\n \n# 3033 \"lib/read.ml\"\n | 1 ->\n\n# 1004 \"lib/read.mll\"\n \n# 1004 \"lib/read.mll\"\n ( () )\n\n# 3037 \"lib/read.ml\"\n\n \n# 3038 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_sep v lexbuf =\n __ocaml_lex_buffer_object_sep_rec v lexbuf 480\nand __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1007 \"lib/read.mll\"\n \n# 1007 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3049 \"lib/read.ml\"\n\n \n# 3050 \"lib/read.ml\"\n | 1 ->\n\n# 1008 \"lib/read.mll\"\n \n# 1008 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '}'; raise End_of_object )\n\n# 3054 \"lib/read.ml\"\n\n \n# 3055 \"lib/read.ml\"\n | 2 ->\n\n# 1009 \"lib/read.mll\"\n \n# 1009 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 3059 \"lib/read.ml\"\n\n \n# 3060 \"lib/read.ml\"\n | 3 ->\n\n# 1010 \"lib/read.mll\"\n \n# 1010 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3064 \"lib/read.ml\"\n\n \n# 3065 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_end v lexbuf =\n __ocaml_lex_buffer_array_end_rec v lexbuf 485\nand __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1013 \"lib/read.mll\"\n \n# 1013 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3076 \"lib/read.ml\"\n\n \n# 3077 \"lib/read.ml\"\n | 1 ->\n\n# 1014 \"lib/read.mll\"\n \n# 1014 \"lib/read.mll\"\n ( () )\n\n# 3081 \"lib/read.ml\"\n\n \n# 3082 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_sep v lexbuf =\n __ocaml_lex_buffer_array_sep_rec v lexbuf 487\nand __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1017 \"lib/read.mll\"\n \n# 1017 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3093 \"lib/read.ml\"\n\n \n# 3094 \"lib/read.ml\"\n | 1 ->\n\n# 1018 \"lib/read.mll\"\n \n# 1018 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3098 \"lib/read.ml\"\n\n \n# 3099 \"lib/read.ml\"\n | 2 ->\n\n# 1019 \"lib/read.mll\"\n \n# 1019 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 3103 \"lib/read.ml\"\n\n \n# 3104 \"lib/read.ml\"\n | 3 ->\n\n# 1020 \"lib/read.mll\"\n \n# 1020 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3108 \"lib/read.ml\"\n\n \n# 3109 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_end v lexbuf =\n __ocaml_lex_buffer_tuple_end_rec v lexbuf 492\nand __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1023 \"lib/read.mll\"\n \n# 1023 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf ')';\n raise End_of_tuple )\n\n# 3122 \"lib/read.ml\"\n\n \n# 3123 \"lib/read.ml\"\n | 1 ->\n\n# 1026 \"lib/read.mll\"\n \n# 1026 \"lib/read.mll\"\n ( () )\n\n# 3127 \"lib/read.ml\"\n\n \n# 3128 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_sep v lexbuf =\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf 494\nand __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1029 \"lib/read.mll\"\n \n# 1029 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3139 \"lib/read.ml\"\n\n \n# 3140 \"lib/read.ml\"\n | 1 ->\n\n# 1030 \"lib/read.mll\"\n \n# 1030 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ')'; raise End_of_tuple )\n\n# 3144 \"lib/read.ml\"\n\n \n# 3145 \"lib/read.ml\"\n | 2 ->\n\n# 1031 \"lib/read.mll\"\n \n# 1031 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 3149 \"lib/read.ml\"\n\n \n# 3150 \"lib/read.ml\"\n | 3 ->\n\n# 1032 \"lib/read.mll\"\n \n# 1032 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3154 \"lib/read.ml\"\n\n \n# 3155 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_colon v lexbuf =\n __ocaml_lex_buffer_colon_rec v lexbuf 499\nand __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1035 \"lib/read.mll\"\n \n# 1035 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':' )\n\n# 3166 \"lib/read.ml\"\n\n \n# 3167 \"lib/read.ml\"\n | 1 ->\n\n# 1036 \"lib/read.mll\"\n \n# 1036 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 3171 \"lib/read.ml\"\n\n \n# 3172 \"lib/read.ml\"\n | 2 ->\n\n# 1037 \"lib/read.mll\"\n \n# 1037 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3176 \"lib/read.ml\"\n\n \n# 3177 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state\n\nand buffer_gt v lexbuf =\n __ocaml_lex_buffer_gt_rec v lexbuf 503\nand __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1040 \"lib/read.mll\"\n \n# 1040 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 3188 \"lib/read.ml\"\n\n \n# 3189 \"lib/read.ml\"\n | 1 ->\n\n# 1041 \"lib/read.mll\"\n \n# 1041 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 3193 \"lib/read.ml\"\n\n \n# 3194 \"lib/read.ml\"\n | 2 ->\n\n# 1042 \"lib/read.mll\"\n \n# 1042 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3198 \"lib/read.ml\"\n\n \n# 3199 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_comment v lexbuf =\n __ocaml_lex_finish_buffer_comment_rec v lexbuf 507\nand __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1045 \"lib/read.mll\"\n \n# 1045 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"*/\" )\n\n# 3210 \"lib/read.ml\"\n\n \n# 3211 \"lib/read.ml\"\n | 1 ->\n\n# 1046 \"lib/read.mll\"\n \n# 1046 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 3215 \"lib/read.ml\"\n\n \n# 3216 \"lib/read.ml\"\n | 2 ->\n\n# 1047 \"lib/read.mll\"\n \n# 1047 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n finish_buffer_comment v lexbuf )\n\n# 3222 \"lib/read.ml\"\n\n \n# 3223 \"lib/read.ml\"\n | 3 ->\n\n# 1050 \"lib/read.mll\"\n \n# 1050 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; finish_buffer_comment v lexbuf )\n\n# 3227 \"lib/read.ml\"\n\n \n# 3228 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state\n\nand junk lexbuf =\n __ocaml_lex_junk_rec lexbuf 513\nand __ocaml_lex_junk_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1053 \"lib/read.mll\"\n \n# 1053 \"lib/read.mll\"\n ( Lexing.lexeme lexbuf )\n\n# 3239 \"lib/read.ml\"\n\n \n# 3240 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_junk_rec lexbuf __ocaml_lex_state\n\n;;\n\n\n# 1055 \"lib/read.mll\"\n \n \n# 1056 \"lib/read.mll\"\n let _ = (read_json : lexer_state -> Lexing.lexbuf -> t)\n\n let read_t = read_json\n\n let () =\n read_junk := junk\n\n let read_int8 v lexbuf =\n let n = read_int v lexbuf in\n if n < 0 || n > 255 then\n lexer_error \"Int8 overflow\" v lexbuf\n else\n char_of_int n\n\n let read_list read_cell v lexbuf =\n List.rev (read_list_rev read_cell v lexbuf)\n\n let array_of_rev_list l =\n match l with\n [] -> [| |]\n | x :: tl ->\n let len = List.length l in\n let a = Array.make len x in\n let r = ref tl in\n for i = len - 2 downto 0 do\n a.(i) <- List.hd !r;\n r := List.tl !r\n done;\n a\n\n let read_array read_cell v lexbuf =\n let l = read_list_rev read_cell v lexbuf in\n array_of_rev_list l\n\n (* Read a JSON object, reading the keys into OCaml strings\n (provided for backward compatibility) *)\n let read_fields read_field init_acc v =\n read_abstract_fields read_ident read_field init_acc v\n\n let finish v lexbuf =\n read_space v lexbuf;\n if not (read_eof lexbuf) then\n long_error \"Junk after end of JSON value:\" v lexbuf\n\n let init_lexer = init_lexer\n\n let from_lexbuf v ?(stream = false) lexbuf =\n read_space v lexbuf;\n\n let x =\n if read_eof lexbuf then\n raise End_of_input\n else\n read_json v lexbuf\n in\n\n if not stream then\n finish v lexbuf;\n\n x\n\n\n let from_string ?buf ?fname ?lnum s =\n try\n let lexbuf = Lexing.from_string s in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_channel ?buf ?fname ?lnum ic =\n try\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n try\n let x = from_channel ?buf ?fname ?lnum ic in\n close_in ic;\n x\n with e ->\n close_in_noerr ic;\n raise e\n\n exception Finally of exn * exn\n\n let stream_from_lexbuf v ?(fin = fun () -> ()) lexbuf =\n let stream = Some true in\n let f i =\n try Some (from_lexbuf v ?stream lexbuf)\n with\n End_of_input ->\n fin ();\n None\n | e ->\n (try fin () with fin_e -> raise (Finally (e, fin_e)));\n raise e\n in\n Stream.from f\n\n let stream_from_string ?buf ?fname ?lnum s =\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v (Lexing.from_string s)\n\n let stream_from_channel ?buf ?fin ?fname ?lnum ic =\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ?fin lexbuf\n\n let stream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ~fin lexbuf\n\n type json_line = [ `Json of t | `Exn of exn ]\n\n let linestream_from_channel\n ?buf ?(fin = fun () -> ()) ?fname ?lnum:(lnum0 = 1) ic =\n let buf =\n match buf with\n None -> Some (Bi_outbuf.create 256)\n | Some _ -> buf\n in\n let f i =\n try\n let line = input_line ic in\n let lnum = lnum0 + i in\n Some (`Json (from_string ?buf ?fname ~lnum line))\n with\n End_of_file -> fin (); None\n | e -> Some (`Exn e)\n in\n Stream.from f\n\n let linestream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n linestream_from_channel ?buf ~fin ?fname ?lnum ic\n\n let prettify ?std s =\n pretty_to_string ?std (from_string s)\n\n let compact ?std s =\n to_string (from_string s)\n\n let validate_json _path _value = None\n\n\n# 3411 \"lib/read.ml\"\n# 91 \"yojson.cppo.ml\"\nend\n","open Core_kernel\nmodule Z = Zarith.Z\n\ntype t = Z.t [@@deriving typerep ~abstract]\n\nlet module_name = \"Bigint\"\nlet invariant (_ : t) = ()\n\nmodule Stringable_t = struct\n type nonrec t = t\n\n let to_string = Z.to_string\n\n let rec is_integer_suffix s i ~len ~char_is_digit =\n if i < len\n then (\n let c = s.[i] in\n if char_is_digit c || Char.equal c '_'\n then is_integer_suffix s (i + 1) ~len ~char_is_digit\n else false)\n else true\n ;;\n\n let is_integer_string s ~char_is_digit =\n let len = String.length s in\n if 0 < len\n then (\n let i = if Char.equal s.[0] '-' then 1 else 0 in\n if i < len\n then\n if char_is_digit s.[i]\n then is_integer_suffix s (i + 1) ~len ~char_is_digit\n else false\n else false)\n else false\n ;;\n\n let of_string_base str ~name ~of_string_no_underscores ~char_is_digit =\n try of_string_no_underscores str with\n | _ ->\n if is_integer_string str ~char_is_digit\n then of_string_no_underscores (String.filter str ~f:(fun c -> Char.( <> ) c '_'))\n else failwithf \"%s.%s: invalid argument %S\" name module_name str ()\n ;;\n\n let of_string str =\n of_string_base\n str\n ~name:\"of_string\"\n ~of_string_no_underscores:Z.of_string\n ~char_is_digit:Char.is_digit\n ;;\nend\n\nmodule Stable = struct\n module V1 = struct\n module Bin_rep = struct\n type t =\n | Zero\n | Pos of string\n | Neg of string\n [@@deriving bin_io]\n end\n\n module Bin_rep_conversion = struct\n type nonrec t = t\n\n let to_binable t =\n let s = Z.sign t in\n if s > 0\n then Bin_rep.Pos (Z.to_bits t)\n else if s < 0\n then Bin_rep.Neg (Z.to_bits t)\n else Bin_rep.Zero\n ;;\n\n let of_binable = function\n | Bin_rep.Zero -> Z.zero\n | Bin_rep.Pos bits -> Z.of_bits bits\n | Bin_rep.Neg bits -> Z.of_bits bits |> Z.neg\n ;;\n end\n\n type nonrec t = t\n\n let compare = Z.compare\n\n include Sexpable.Stable.Of_stringable.V1 (Stringable_t)\n\n include Binable.Stable.Of_binable.V1 [@alert \"-legacy\"]\n (Bin_rep)\n (Bin_rep_conversion)\n end\n\n module V2 = struct\n type nonrec t = t\n\n let compare = Z.compare\n\n include Sexpable.Stable.Of_stringable.V1 (Stringable_t)\n\n let compute_size_in_bytes x =\n let numbits = Z.numbits x in\n Int.round_up ~to_multiple_of:8 numbits / 8\n ;;\n\n let compute_tag ~size_in_bytes ~negative =\n let open Int63 in\n let sign_bit = if negative then one else zero in\n (* Can't overflow:\n size <= String.length bits < 2 * max_string_length < max_int63\n *)\n shift_left (of_int size_in_bytes) 1 + sign_bit\n ;;\n\n let bin_size_t : t Bin_prot.Size.sizer =\n fun x ->\n let size_in_bytes = compute_size_in_bytes x in\n if size_in_bytes = 0\n then Int63.bin_size_t Int63.zero\n else (\n let negative = Z.sign x = -1 in\n let tag = compute_tag ~size_in_bytes ~negative in\n Int63.bin_size_t tag + size_in_bytes)\n ;;\n\n let bin_write_t : t Bin_prot.Write.writer =\n fun buf ~pos x ->\n let size_in_bytes = compute_size_in_bytes x in\n if size_in_bytes = 0\n then Int63.bin_write_t buf ~pos Int63.zero\n else (\n let bits = Z.to_bits x in\n let negative = Z.sign x = -1 in\n let tag = compute_tag ~size_in_bytes ~negative in\n let pos = Int63.bin_write_t buf ~pos tag in\n Bin_prot.Common.blit_string_buf bits ~dst_pos:pos buf ~len:size_in_bytes;\n pos + size_in_bytes)\n ;;\n\n let bin_read_t : t Bin_prot.Read.reader =\n fun buf ~pos_ref ->\n let tag = Core_kernel.Int63.bin_read_t buf ~pos_ref in\n if Int63.equal tag Int63.zero\n then Z.zero\n else (\n let negative = Int63.(tag land one = one) in\n let size_in_bytes = Int63.(to_int_exn (shift_right tag 1)) in\n (* Even though we could cache a buffer for small sizes, the extra logic leads to\n a decrease in performance *)\n let bytes = Bytes.create size_in_bytes in\n Bin_prot.Common.blit_buf_bytes ~src_pos:!pos_ref buf bytes ~len:size_in_bytes;\n let abs =\n Z.of_bits (Bytes.unsafe_to_string ~no_mutation_while_string_reachable:bytes)\n in\n pos_ref := !pos_ref + size_in_bytes;\n if negative then Z.neg abs else abs)\n ;;\n\n let module_name = \"Bigint.Stable.V2.t\"\n\n let bin_writer_t : t Bin_prot.Type_class.writer =\n { size = bin_size_t; write = bin_write_t }\n ;;\n\n let __bin_read_t__ _buf ~pos_ref _vint =\n Bin_prot.Common.raise_variant_wrong_type module_name !pos_ref\n ;;\n\n let bin_reader_t : t Bin_prot.Type_class.reader =\n { read = bin_read_t; vtag_read = __bin_read_t__ }\n ;;\n\n let bin_shape_t : Bin_prot.Shape.t =\n Bin_prot.Shape.basetype\n (Bin_prot.Shape.Uuid.of_string \"7a8cceb2-f3a2-11e9-b7cb-aae95a547ff6\")\n []\n ;;\n\n let bin_t : t Bin_prot.Type_class.t =\n { shape = bin_shape_t; writer = bin_writer_t; reader = bin_reader_t }\n ;;\n end\nend\n\nmodule Unstable = struct\n include Stable.V1\n include Stringable_t\n\n let t_sexp_grammar = [%sexp_grammar: String.t]\n let of_zarith_bigint t = t\n let to_zarith_bigint t = t\n\n let ( /% ) x y =\n if Z.sign y >= 0\n then Z.ediv x y\n else\n failwithf\n \"%s.(%s /%% %s) : divisor must be positive\"\n module_name\n (to_string x)\n (to_string y)\n ()\n ;;\n\n let ( % ) x y =\n if Z.sign y >= 0\n then Z.erem x y\n else\n failwithf\n \"%s.(%s %% %s) : divisor must be positive\"\n module_name\n (to_string x)\n (to_string y)\n ()\n ;;\n\n let hash_fold_t state t = Int.hash_fold_t state (Z.hash t)\n let hash = Z.hash\n let compare = Z.compare\n let ( - ) = Z.( - )\n let ( + ) = Z.( + )\n let ( * ) = Z.( * )\n let ( / ) = Z.( / )\n let rem = Z.rem\n let ( ~- ) = Z.( ~- )\n let neg = Z.neg\n let abs = Z.abs\n let succ = Z.succ\n let pred = Z.pred\n let equal = Z.equal\n let ( = ) = Z.equal\n let ( < ) = Z.lt\n let ( > ) = Z.gt\n let ( <= ) = Z.leq\n let ( >= ) = Z.geq\n let max = Z.max\n let min = Z.min\n let ascending = compare\n let shift_right = Z.shift_right\n let shift_left = Z.shift_left\n let bit_not = Z.lognot\n let bit_xor = Z.logxor\n let bit_or = Z.logor\n let bit_and = Z.logand\n let ( land ) = bit_and\n let ( lor ) = bit_or\n let ( lxor ) = bit_xor\n let lnot = bit_not\n let ( lsl ) = shift_left\n let ( asr ) = shift_right\n let of_int = Z.of_int\n let of_int32 = Z.of_int32\n let of_int64 = Z.of_int64\n let of_nativeint = Z.of_nativeint\n let of_float_unchecked = Z.of_float\n let of_float = Z.of_float\n let of_int_exn = of_int\n let of_int32_exn = of_int32\n let of_int64_exn = of_int64\n let of_nativeint_exn = of_nativeint\n let to_int_exn = Z.to_int\n let to_int32_exn = Z.to_int32\n let to_int64_exn = Z.to_int64\n let to_nativeint_exn = Z.to_nativeint\n let to_float = Z.to_float\n let zero = Z.zero\n let one = Z.one\n let minus_one = Z.minus_one\n let to_int t = if Z.fits_int t then Some (Z.to_int t) else None\n let to_int32 t = if Z.fits_int32 t then Some (Z.to_int32 t) else None\n let to_int64 t = if Z.fits_int64 t then Some (Z.to_int64 t) else None\n let to_nativeint t = if Z.fits_nativeint t then Some (Z.to_nativeint t) else None\n let ( <> ) x y = not (equal x y)\n let incr cell = cell := succ !cell\n let decr cell = cell := pred !cell\n let pow x y = Z.pow x (to_int_exn y)\n let ( ** ) x y = pow x y\n let popcount x = Z.popcount x\nend\n\nmodule T_math = Int_math.Make (Unstable)\nmodule T_conversions = Int_conversions.Make (Unstable)\nmodule T_comparable_with_zero = Comparable.Validate_with_zero (Unstable)\n\nmodule T_identifiable = Identifiable.Make (struct\n let module_name = module_name\n\n include Unstable\n end)\n\n(* Including in opposite order to shadow functorized bindings with direct bindings. *)\nmodule O = struct\n include T_identifiable\n include T_comparable_with_zero\n include T_conversions\n include T_math\n include Unstable\nend\n\ninclude (O : module type of O with type t := t)\n\nmodule Make_random (State : sig\n type t\n\n val bits : t -> int\n val int : t -> int -> int\n end) : sig\n val random : state:State.t -> t -> t\nend = struct\n (* Uniform random generation of Bigint values.\n\n [random ~state range] chooses a [depth] and generates random values using\n [Random.State.bits state], called [1 lsl depth] times and concatenated. The\n preliminary result [n] therefore satisfies [0 <= n < 1 lsl (30 lsl depth)].\n\n In order for the random choice to be uniform between [0] and [range-1], there must\n exist [k > 0] such that [n < k * range <= 1 lsl (30 lsl depth)]. If so, [n % range]\n is returned. Otherwise the random choice process is repeated from scratch.\n\n The [depth] value is chosen so that repeating is uncommon (1 in 1,000 or less). *)\n\n let bits_at_depth ~depth = Int.shift_left 30 depth\n let range_at_depth ~depth = shift_left one (bits_at_depth ~depth)\n\n let rec choose_bit_depth_for_range_from ~range ~depth =\n if range_at_depth ~depth >= range\n then depth\n else choose_bit_depth_for_range_from ~range ~depth:(Int.succ depth)\n ;;\n\n let choose_bit_depth_for_range ~range = choose_bit_depth_for_range_from ~range ~depth:0\n\n let rec random_bigint_at_depth ~state ~depth =\n if Int.equal depth 0\n then of_int (State.bits state)\n else (\n let prev_depth = Int.pred depth in\n let prefix = random_bigint_at_depth ~state ~depth:prev_depth in\n let suffix = random_bigint_at_depth ~state ~depth:prev_depth in\n bit_or (shift_left prefix (bits_at_depth ~depth:prev_depth)) suffix)\n ;;\n\n let random_value_is_uniform_in_range ~range ~depth n =\n let k = range_at_depth ~depth / range in\n n < k * range\n ;;\n\n let rec large_random_at_depth ~state ~range ~depth =\n let result = random_bigint_at_depth ~state ~depth in\n if random_value_is_uniform_in_range ~range ~depth result\n then result % range\n else large_random_at_depth ~state ~range ~depth\n ;;\n\n let large_random ~state ~range =\n let tolerance_factor = of_int 1_000 in\n let depth = choose_bit_depth_for_range ~range:(range * tolerance_factor) in\n large_random_at_depth ~state ~range ~depth\n ;;\n\n let random ~state range =\n if range <= zero\n then\n failwithf \"Bigint.random: argument %s <= 0\" (to_string_hum range) ()\n (* Note that it's not safe to do [1 lsl 30] on a 32-bit machine (with 31-bit signed\n integers) *)\n else if range < shift_left one 30\n then of_int (State.int state (to_int_exn range))\n else large_random ~state ~range\n ;;\nend\n\nmodule Random_internal = Make_random (Random.State)\n\nlet random ?(state = Random.State.default) range = Random_internal.random ~state range\n\nmodule For_quickcheck : sig\n include Quickcheckable.S_int with type t := t\n\n val gen_negative : t Quickcheck.Generator.t\n val gen_positive : t Quickcheck.Generator.t\nend = struct\n module Generator = Quickcheck.Generator\n open Generator.Let_syntax\n\n module Uniform = Make_random (struct\n type t = Splittable_random.State.t\n\n let int t range = Splittable_random.int t ~lo:0 ~hi:(Int.pred range)\n let bits t = int t (Int.shift_left 1 30)\n end)\n\n let random_uniform ~state lo hi = lo + Uniform.random ~state (succ (hi - lo))\n\n let gen_uniform_incl lower_bound upper_bound =\n if lower_bound > upper_bound\n then\n raise_s\n [%message\n \"Bigint.gen_uniform_incl: bounds are crossed\"\n (lower_bound : t)\n (upper_bound : t)];\n Generator.create (fun ~size:_ ~random:state ->\n random_uniform ~state lower_bound upper_bound)\n ;;\n\n let gen_incl lower_bound upper_bound =\n Generator.weighted_union\n [ 0.05, Generator.return lower_bound\n ; 0.05, Generator.return upper_bound\n ; 0.9, gen_uniform_incl lower_bound upper_bound\n ]\n ;;\n\n let min_represented_by_n_bits n =\n if Int.equal n 0 then zero else shift_left one (Int.pred n)\n ;;\n\n let max_represented_by_n_bits n = pred (shift_left one n)\n\n let gen_log_uniform_incl lower_bound upper_bound =\n if lower_bound < zero || lower_bound > upper_bound\n then\n raise_s\n [%message\n \"Bigint.gen_log_incl: invalid bounds\" (lower_bound : t) (upper_bound : t)];\n let min_bits = Z.numbits lower_bound in\n let max_bits = Z.numbits upper_bound in\n let%bind bits = Int.gen_uniform_incl min_bits max_bits in\n gen_uniform_incl\n (max lower_bound (min_represented_by_n_bits bits))\n (min upper_bound (max_represented_by_n_bits bits))\n ;;\n\n let gen_log_incl lower_bound upper_bound =\n Generator.weighted_union\n [ 0.05, Generator.return lower_bound\n ; 0.05, Generator.return upper_bound\n ; 0.9, gen_log_uniform_incl lower_bound upper_bound\n ]\n ;;\n\n let gen_positive =\n let%bind extra_bytes = Generator.size in\n let num_bytes = Int.succ extra_bytes in\n let num_bits = Int.( * ) num_bytes 8 in\n gen_log_uniform_incl one (pred (shift_left one num_bits))\n ;;\n\n let gen_negative = Generator.map gen_positive ~f:neg\n\n let quickcheck_generator =\n Generator.weighted_union\n [ 0.45, gen_positive; 0.1, Generator.return zero; 0.45, gen_negative ]\n ;;\n\n let quickcheck_observer =\n Quickcheck.Observer.create (fun t ~size:_ ~hash -> hash_fold_t hash t)\n ;;\n\n let quickcheck_shrinker = Quickcheck.Shrinker.empty ()\nend\n\ninclude For_quickcheck\n\nmodule Hex = struct\n type nonrec t = t [@@deriving bin_io, typerep]\n\n module M = Base.Int_conversions.Make_hex (struct\n type nonrec t = t [@@deriving hash, compare]\n\n let to_string i = Z.format \"%x\" i\n\n let char_is_hex_digit = function\n | '0' .. '9' | 'a' .. 'f' | 'A' .. 'F' -> true\n | _ -> false\n ;;\n\n let of_hex_string_no_underscores str = Z.of_string_base 16 str\n\n let of_string str =\n of_string_base\n str\n ~name:\"Hex.of_string\"\n ~char_is_digit:char_is_hex_digit\n ~of_string_no_underscores:of_hex_string_no_underscores\n ;;\n\n let ( < ) = ( < )\n let neg = neg\n let zero = zero\n let module_name = module_name ^ \".Hex\"\n end)\n\n include (\n M.Hex :\n module type of struct\n include M.Hex\n end\n with type t := t)\nend\n","open Core_kernel\n\ntype 'f t =\n | Constant of 'f\n | Var of int\n | Add of 'f t * 'f t\n | Scale of 'f * 'f t\n[@@deriving sexp]\n\ntype 'f cvar = 'f t [@@deriving sexp]\n\nlet to_constant_and_terms ~equal ~add ~mul ~zero ~one =\n let rec go scale constant terms = function\n | Constant c ->\n (add constant (mul scale c), terms)\n | Var v ->\n (constant, (scale, v) :: terms)\n | Scale (s, t) ->\n go (mul s scale) constant terms t\n | Add (x1, x2) ->\n let c1, terms1 = go scale constant terms x1 in\n go scale c1 terms1 x2\n in\n fun t ->\n let c, ts = go one zero [] t in\n let c = if equal c zero then None else Some c in\n (c, ts)\n\nmodule Unsafe = struct\n let of_index v = Var v\nend\n\nmodule Make (Field : Snarky_intf.Field.Extended) = struct\n type t = Field.t cvar [@@deriving sexp]\n\n let length _ = failwith \"TODO\"\n\n module Unsafe = Unsafe\n\n let scratch = Field.of_int 0\n\n let eval (`Return_values_will_be_mutated context) t0 =\n let open Field in\n let rec go = function\n | Constant c, Some scale ->\n c * scale\n | Constant c, None ->\n c\n | Var v, Some scale ->\n context v * scale\n | Var v, None ->\n context v\n | Scale (s, t), Some scale ->\n go (t, Some (scale * s))\n | Scale (s, t), None ->\n go (t, Some s)\n | Add (t1, t2), Some scale ->\n (go (t1, None) + go (t2, None)) * scale\n | Add (t1, t2), None ->\n go (t1, None) + go (t2, None)\n in\n go (t0, None)\n\n let constant c = Constant c\n\n let to_constant_and_terms =\n let rec go scale constant terms = function\n | Constant c ->\n (Field.add constant (Field.mul scale c), terms)\n | Var v ->\n (constant, (scale, v) :: terms)\n | Scale (s, t) ->\n go (Field.mul s scale) constant terms t\n | Add (x1, x2) ->\n let c1, terms1 = go scale constant terms x1 in\n go scale c1 terms1 x2\n in\n fun t ->\n let c, ts = go Field.one Field.zero [] t in\n let c = if Field.equal c Field.zero then None else Some c in\n (c, ts)\n\n let add x y =\n match (x, y) with\n | Constant x, _ when Field.(equal x zero) ->\n y\n | _, Constant y when Field.(equal y zero) ->\n x\n | Constant x, Constant y ->\n Constant (Field.add x y)\n | _, _ ->\n Add (x, y)\n\n let scale x s =\n if Field.(equal s zero) then Constant Field.zero\n else if Field.(equal s one) then x\n else\n match x with\n | Constant x ->\n Constant (Field.mul x s)\n | Scale (sx, x) ->\n Scale (Field.mul sx s, x)\n | _ ->\n Scale (s, x)\n\n let neg_one = Field.(sub zero one)\n\n let sub t1 t2 =\n match (t1, t2) with\n | Constant x, Constant y ->\n Constant (Field.sub x y)\n | _ ->\n add t1 (scale t2 neg_one)\n\n let linear_combination (terms : (Field.t * t) list) : t =\n List.fold terms ~init:(constant Field.zero) ~f:(fun acc (c, t) ->\n add acc (scale t c) )\n\n let sum vs = linear_combination (List.map vs ~f:(fun v -> (Field.one, v)))\n\n let ( + ) = add\n\n let ( - ) = sub\n\n let ( * ) c x = scale x c\n\n let negate x = scale x neg_one\n\n let to_json x =\n let singleton = Map.singleton (module Int) in\n let join = Map.merge_skewed ~combine:(fun ~key:_ -> Field.add) in\n let rec go scale = function\n | Constant f ->\n singleton 0 (Field.mul scale f)\n | Var i ->\n singleton i scale\n | Add (x, y) ->\n join (go scale x) (go scale y)\n | Scale (s, x) ->\n go Field.(scale * s) x\n in\n let map = go Field.one x in\n `Assoc\n (List.filter_map (Map.to_alist map) ~f:(fun (i, f) ->\n if Field.(equal f zero) then None\n else Some (Int.to_string i, `String (Field.to_string f)) ) )\nend\n","open Base\n\ntype ('var, 'field) basic = ..\n\nmodule Conv (F : sig\n type (_, _) t\nend) =\nstruct\n type t =\n { to_basic : 'v 'f. ('v, 'f) F.t -> ('v, 'f) basic\n ; of_basic : 'v 'f. ('v, 'f) basic -> ('v, 'f) F.t\n }\nend\n\nmodule type S = sig\n type (_, _) t [@@deriving sexp]\n\n val map : ('a, 'f) t -> f:('a -> 'b) -> ('b, 'f) t\n\n (* TODO: Try making this a functor and seeing how it affects performance *)\n val eval :\n (module Snarky_intf.Field.S with type t = 'f)\n -> ('v -> 'f)\n -> ('v, 'f) t\n -> bool\nend\n\nmodule Basic = struct\n type ('v, 'f) t = ('v, 'f) basic\n\n module type S_with_conv = sig\n include S\n\n val to_basic : ('v, 'f) t -> ('v, 'f) basic\n\n val of_basic : ('v, 'f) basic -> ('v, 'f) t\n end\n\n module Entry = struct\n type t = (module S_with_conv)\n end\n\n let cases : Entry.t list ref = ref []\n\n let add_case m = cases := m :: !cases\n\n let case f =\n List.find_map_exn !cases ~f:(fun m -> Option.try_with (fun () -> f m))\n\n let sexp_of_t f1 f2 t =\n case (fun (module M) -> M.sexp_of_t f1 f2 (M.of_basic t))\n\n let t_of_sexp f1 f2 s =\n case (fun (module M) -> M.to_basic (M.t_of_sexp f1 f2 s))\n\n let eval (type f) (fm : (module Snarky_intf.Field.S with type t = f))\n (f : 'v -> f) (t : ('v, f) basic) : bool =\n case (fun (module M) -> M.eval fm f (M.of_basic t))\n\n let map t ~f = case (fun (module M) -> M.to_basic (M.map (M.of_basic t) ~f))\nend\n\nmodule Add_kind (C : S) : sig\n type ('v, 'f) basic += T of ('v, 'f) C.t\nend = struct\n type ('v, 'f) basic += T of ('v, 'f) C.t\n\n module M = struct\n include C\n\n let to_basic x = T x\n\n let of_basic = function T x -> x | _ -> failwith \"different constructor\"\n end\n\n let () = Basic.add_case (module M)\nend\n\n(* We special case these for compatibility with existing code. *)\ntype ('var, _) basic +=\n | Boolean of 'var\n | Equal of 'var * 'var\n | Square of 'var * 'var\n | R1CS of 'var * 'var * 'var\n\nlet basic_of_sexp = Basic.t_of_sexp\n\nlet sexp_of_basic = Basic.sexp_of_t\n\nlet () =\n let unhandled s = Core_kernel.failwithf \"%s: non-basic constraint\" s () in\n let module Essential = struct\n type 'var t =\n | Boolean of 'var\n | Equal of 'var * 'var\n | Square of 'var * 'var\n | R1CS of 'var * 'var * 'var\n [@@deriving sexp]\n\n let to_basic : 'v t -> ('v, _) basic = function\n | Boolean x ->\n Boolean x\n | Equal (x, y) ->\n Equal (x, y)\n | Square (x, y) ->\n Square (x, y)\n | R1CS (x, y, z) ->\n R1CS (x, y, z)\n\n let of_basic : ('v, _) basic -> 'v t = function\n | Boolean x ->\n Boolean x\n | Equal (x, y) ->\n Equal (x, y)\n | Square (x, y) ->\n Square (x, y)\n | R1CS (x, y, z) ->\n R1CS (x, y, z)\n | _ ->\n unhandled \"of_basic\"\n end in\n let module M = struct\n type ('v, 'f) t = ('v, 'f) basic\n\n let sexp_of_t f _ t = Essential.(sexp_of_t f (of_basic t))\n\n let t_of_sexp f _ s = Essential.(to_basic (t_of_sexp f s))\n\n let of_basic = Fn.id\n\n let to_basic = Fn.id\n\n let map t ~f =\n match t with\n | Boolean v ->\n Boolean (f v)\n | Equal (v1, v2) ->\n Equal (f v1, f v2)\n | R1CS (v1, v2, v3) ->\n R1CS (f v1, f v2, f v3)\n | Square (a, c) ->\n Square (f a, f c)\n | _ ->\n unhandled \"map\"\n\n let eval (type f v) (module Field : Snarky_intf.Field.S with type t = f)\n (get_value : v -> f) (t : (v, f) basic) : bool =\n match t with\n | Boolean v ->\n let x = get_value v in\n Field.(equal x zero || equal x one)\n | Equal (v1, v2) ->\n Field.equal (get_value v1) (get_value v2)\n | R1CS (v1, v2, v3) ->\n Field.(equal (mul (get_value v1) (get_value v2)) (get_value v3))\n | Square (a, c) ->\n Field.equal (Field.square (get_value a)) (get_value c)\n | _ ->\n unhandled \"eval\"\n end in\n Basic.add_case (module M)\n\ntype ('v, 'f) basic_with_annotation =\n { basic : ('v, 'f) basic; annotation : string option }\n[@@deriving sexp]\n\ntype ('v, 'f) t = ('v, 'f) basic_with_annotation [@@deriving sexp]\n\nmodule T = struct\n let create_basic ?label basic = { basic; annotation = label }\n\n let override_label { basic; annotation = a } label_opt =\n { basic\n ; annotation = (match label_opt with Some x -> Some x | None -> a)\n }\n\n let equal ?label x y = create_basic ?label (Equal (x, y))\n\n let boolean ?label x = create_basic ?label (Boolean x)\n\n let r1cs ?label a b c = create_basic ?label (R1CS (a, b, c))\n\n let square ?label a c = create_basic ?label (Square (a, c))\n\n let annotation (t : _ t) =\n match t.annotation with Some str -> str | None -> \"\"\nend\n\ninclude T\n","open Core_kernel\nmodule Bignum_bigint = Bigint\n\n(** Yojson-compatible JSON type. *)\ntype 'a json =\n [> `String of string\n | `Assoc of (string * 'a json) list\n | `List of 'a json list ]\n as\n 'a\n\nmodule type S = sig\n module Field : Snarky_intf.Field.Full\n\n module Bigint : sig\n include Snarky_intf.Bigint_intf.Extended with type field := Field.t\n\n val of_bignum_bigint : Bignum_bigint.t -> t\n\n val to_bignum_bigint : t -> Bignum_bigint.t\n end\n\n module Cvar : sig\n type t = Field.t Cvar.t [@@deriving sexp]\n\n val length : t -> int\n\n module Unsafe : sig\n val of_index : int -> t\n end\n\n val eval :\n [ `Return_values_will_be_mutated of int -> Field.t ] -> t -> Field.t\n\n val constant : Field.t -> t\n\n val to_constant_and_terms : t -> Field.t option * (Field.t * int) list\n\n val add : t -> t -> t\n\n val negate : t -> t\n\n val scale : t -> Field.t -> t\n\n val sub : t -> t -> t\n\n val linear_combination : (Field.t * t) list -> t\n\n val sum : t list -> t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val ( * ) : Field.t -> t -> t\n\n val var_indices : t -> int list\n\n val to_constant : t -> Field.t option\n end\n\n module R1CS_constraint_system :\n Backend_intf.Constraint_system_intf with module Field := Field\n\n module Constraint : sig\n type t = (Cvar.t, Field.t) Constraint.t [@@deriving sexp]\n\n type 'k with_constraint_args = ?label:string -> 'k\n\n val boolean : (Cvar.t -> t) with_constraint_args\n\n val equal : (Cvar.t -> Cvar.t -> t) with_constraint_args\n\n val r1cs : (Cvar.t -> Cvar.t -> Cvar.t -> t) with_constraint_args\n\n val square : (Cvar.t -> Cvar.t -> t) with_constraint_args\n\n val annotation : t -> string\n\n val eval :\n (Cvar.t, Field.t) Constraint.basic_with_annotation\n -> (Cvar.t -> Field.t)\n -> bool\n end\nend\n\nmodule Make (Backend : Backend_intf.S) :\n S\n with type Field.t = Backend.Field.t\n and type Field.Vector.t = Backend.Field.Vector.t\n and type Bigint.t = Backend.Bigint.t\n and type R1CS_constraint_system.t = Backend.R1CS_constraint_system.t =\nstruct\n open Backend\n\n module Bigint = struct\n include Bigint\n\n let of_bignum_bigint n = of_decimal_string (Bignum_bigint.to_string n)\n\n let to_bignum_bigint n =\n let rec go i two_to_the_i acc =\n if i = Field.size_in_bits then acc\n else\n let acc' =\n if test_bit n i then Bignum_bigint.(acc + two_to_the_i) else acc\n in\n go (i + 1) Bignum_bigint.(two_to_the_i + two_to_the_i) acc'\n in\n go 0 Bignum_bigint.one Bignum_bigint.zero\n end\n\n module Field = struct\n include Field\n\n let size = Bigint.to_bignum_bigint Backend.field_size\n\n let inv x = if equal x zero then failwith \"Field.inv: zero\" else inv x\n\n (* TODO: Optimize *)\n let div x y = mul x (inv y)\n\n let negate x = sub zero x\n\n let unpack x =\n let n = Bigint.of_field x in\n List.init size_in_bits ~f:(fun i -> Bigint.test_bit n i)\n\n let project_reference =\n let rec go x acc = function\n | [] ->\n acc\n | b :: bs ->\n go (Field.add x x) (if b then Field.add acc x else acc) bs\n in\n fun bs -> go Field.one Field.zero bs\n\n let _project bs =\n (* todo: 32-bit and ARM support. basically this code needs to always match the loop in the C++ of_data implementation. *)\n assert (Sys.word_size = 64 && not Sys.big_endian) ;\n let chunks_of n xs =\n List.groupi ~break:(fun i _ _ -> Int.equal (i mod n) 0) xs\n in\n let chunks64 = chunks_of 64 bs in\n let z = Char.of_int_exn 0 in\n let arr =\n Bigstring.init (8 * Backend.Bigint.length_in_bytes) ~f:(fun _ -> z)\n in\n List.(\n iteri ~f:(fun i elt ->\n Bigstring.set_int64_t_le arr ~pos:(i * 8)\n Int64.(\n foldi ~init:zero\n ~f:(fun i acc el ->\n acc + if el then shift_left one i else zero )\n elt) ))\n chunks64 ;\n Backend.Bigint.(of_data arr ~bitcount:(List.length bs) |> to_field)\n\n let project = project_reference\n\n let compare t1 t2 = Bigint.(compare (of_field t1) (of_field t2))\n\n let hash_fold_t s x =\n Bignum_bigint.hash_fold_t s Bigint.(to_bignum_bigint (of_field x))\n\n let hash = Hash.of_fold hash_fold_t\n\n let to_bignum_bigint = Fn.compose Bigint.to_bignum_bigint Bigint.of_field\n\n let of_bignum_bigint = Fn.compose Bigint.to_field Bigint.of_bignum_bigint\n\n let sexp_of_t = Fn.compose Bignum_bigint.sexp_of_t to_bignum_bigint\n\n let t_of_sexp = Fn.compose of_bignum_bigint Bignum_bigint.t_of_sexp\n\n let%test_unit \"project correctness\" =\n Quickcheck.test\n Quickcheck.Generator.(\n small_positive_int >>= fun x -> list_with_length x bool)\n ~f:(fun bs ->\n [%test_eq: string]\n (project bs |> to_string)\n (project_reference bs |> to_string) )\n\n let ( + ) = add\n\n let ( * ) = mul\n\n let ( - ) = sub\n\n let ( / ) = div\n end\n\n module Cvar = struct\n include Cvar.Make (Field)\n\n let var_indices t =\n let _, terms = to_constant_and_terms t in\n List.map ~f:(fun (_, v) -> v) terms\n\n let to_constant : t -> Field.t option = function\n | Constant x ->\n Some x\n | _ ->\n None\n end\n\n module Constraint = struct\n open Constraint\n include Constraint.T\n\n type 'k with_constraint_args = ?label:string -> 'k\n\n type t = (Cvar.t, Field.t) Constraint.t [@@deriving sexp]\n\n let m = (module Field : Snarky_intf.Field.S with type t = Field.t)\n\n let eval { basic; _ } get_value = Constraint.Basic.eval m get_value basic\n end\n\n module R1CS_constraint_system = R1CS_constraint_system\nend\n","open Core_kernel\nmodule Constraint0 = Constraint\n\nlet stack_to_string = String.concat ~sep:\"\\n\"\n\nlet eval_constraints = ref true\n\nlet eval_constraints_ref = eval_constraints\n\nmodule Simple = struct\n module Types = struct\n module Checked = struct\n type ('a, 'f) t =\n | Pure of 'a\n | Function of ('f Run_state.t -> 'f Run_state.t * 'a)\n end\n\n module Typ = struct\n include Types.Typ.T\n\n type ('var, 'value, 'f) t = ('var, 'value, 'f, (unit, 'f) Checked.t) typ\n end\n\n module Provider = struct\n include Types.Provider.T\n\n type ('a, 'f) t =\n (('a Request.t, 'f) As_prover0.t, ('a, 'f) As_prover0.t) provider\n end\n end\n\n type 'f field = 'f\n\n type ('a, 'f) t = ('a, 'f field) Types.Checked.t\n\n let eval (t : ('a, 'f) t) : 'f field Run_state.t -> 'f field Run_state.t * 'a\n =\n match t with Pure a -> fun s -> (s, a) | Function g -> g\n\n include Monad_let.Make2 (struct\n type ('a, 'f) t = ('a, 'f field) Types.Checked.t\n\n let return x : _ t = Pure x\n\n let map =\n `Custom\n (fun (x : _ t) ~f : _ t ->\n match x with\n | Pure a ->\n Pure (f a)\n | Function g ->\n Function\n (fun s ->\n let s, a = g s in\n (s, f a) ) )\n\n let bind (x : _ t) ~f : _ t =\n match x with\n | Pure a ->\n f a\n | Function g ->\n Function\n (fun s ->\n let s, a = g s in\n eval (f a) s )\n end)\nend\n\nmodule Make_checked\n (Backend : Backend_extended.S)\n (As_prover : As_prover_intf.Basic with type 'f field := Backend.Field.t) =\nstruct\n type run_state = Backend.Field.t Run_state.t\n\n module Types = struct\n module Checked = struct\n type ('a, 'f) t = ('a, Backend.Field.t) Simple.Types.Checked.t\n end\n\n module Typ = struct\n include Types.Typ.T\n\n type ('var, 'value, 'f) t = ('var, 'value, 'f, (unit, 'f) Checked.t) typ\n end\n\n module Provider = struct\n include Types.Provider.T\n\n type ('a, 'f) t =\n (('a Request.t, 'f) As_prover.t, ('a, 'f) As_prover.t) provider\n end\n end\n\n type 'f field = Backend.Field.t\n\n include Types.Checked\n\n let eval : ('a, 'f) t -> run_state -> run_state * 'a = Simple.eval\n\n include Monad_let.Make2 (struct\n include Types.Checked\n\n let map = `Custom Simple.map\n\n let bind = Simple.bind\n\n let return = Simple.return\n end)\n\n open Constraint\n open Backend\n\n let get_value (t : Field.t Run_state.t) : Cvar.t -> Field.t =\n let get_one i = Run_state.get_variable_value t i in\n Cvar.eval (`Return_values_will_be_mutated get_one)\n\n let run_as_prover x state =\n match (x, Run_state.has_witness state) with\n | Some x, true ->\n let old = Run_state.as_prover state in\n Run_state.set_as_prover state true ;\n let y = As_prover.run x (get_value state) in\n Run_state.set_as_prover state old ;\n (state, Some y)\n | _, _ ->\n (state, None)\n\n let as_prover x : _ Simple.t =\n Function\n (fun s ->\n let s', (_ : unit option) = run_as_prover (Some x) s in\n (s', ()) )\n\n let mk_lazy x : _ Simple.t =\n Function\n (fun s ->\n let old_stack = Run_state.stack s in\n ( s\n , Lazy.from_fun (fun () ->\n let stack = Run_state.stack s in\n\n (* Add a label to indicate that the new stack is the point at which\n this was forced. When printed for errors, this will split the\n stack into\n\n ...\n stack to lazy\n ...\n\n Lazy value forced at:\n ...\n stack to lazy forcing point\n ...\n *)\n let label = \"\\nLazy value forced at:\" in\n let _s', y =\n Simple.eval (x ())\n (Run_state.set_stack s (old_stack @ (label :: stack)))\n in\n y ) ) )\n\n let with_label lab t : _ Simple.t =\n Function\n (fun s ->\n let stack = Run_state.stack s in\n Option.iter (Run_state.log_constraint s) ~f:(fun f ->\n f ~at_label_boundary:(`Start, lab) None ) ;\n let s', y = Simple.eval (t ()) (Run_state.set_stack s (lab :: stack)) in\n Option.iter (Run_state.log_constraint s) ~f:(fun f ->\n f ~at_label_boundary:(`End, lab) None ) ;\n (Run_state.set_stack s' stack, y) )\n\n let log_constraint { basic; _ } s =\n match basic with\n | Boolean var ->\n Format.(asprintf \"Boolean %s\" (Field.to_string (get_value s var)))\n | Equal (var1, var2) ->\n Format.(\n asprintf \"Equal %s %s\"\n (Field.to_string (get_value s var1))\n (Field.to_string (get_value s var2)))\n | Square (var1, var2) ->\n Format.(\n asprintf \"Square %s %s\"\n (Field.to_string (get_value s var1))\n (Field.to_string (get_value s var2)))\n | R1CS (var1, var2, var3) ->\n Format.(\n asprintf \"R1CS %s %s %s\"\n (Field.to_string (get_value s var1))\n (Field.to_string (get_value s var2))\n (Field.to_string (get_value s var3)))\n | _ ->\n Format.asprintf\n !\"%{sexp:(Field.t, Field.t) Constraint0.basic}\"\n (Constraint0.Basic.map basic ~f:(get_value s))\n\n let add_constraint ~stack ({ basic; annotation } : Constraint.t)\n (Constraint_system.T ((module C), system) : Field.t Constraint_system.t) =\n let label = Option.value annotation ~default:\"\" in\n C.add_constraint system basic ~label:(stack_to_string (label :: stack))\n\n let add_constraint c : _ Simple.t =\n Function\n (fun s ->\n if Run_state.as_prover s then\n (* Don't add constraints as the prover, or the constraint system won't match! *)\n (s, ())\n else (\n Option.iter (Run_state.log_constraint s) ~f:(fun f -> f (Some c)) ;\n if\n Run_state.eval_constraints s\n && !eval_constraints\n && not (Constraint.eval c (get_value s))\n then\n failwithf\n \"Constraint unsatisfied (unreduced):\\n\\\n %s\\n\\\n %s\\n\\n\\\n Constraint:\\n\\\n %s\\n\\\n Data:\\n\\\n %s\"\n (Constraint.annotation c)\n (stack_to_string (Run_state.stack s))\n (Sexp.to_string (Constraint.sexp_of_t c))\n (log_constraint c s) () ;\n if not (Run_state.as_prover s) then\n Option.iter (Run_state.system s) ~f:(fun system ->\n add_constraint ~stack:(Run_state.stack s) c system ) ;\n (s, ()) ) )\n\n let with_handler h t : _ Simple.t =\n Function\n (fun s ->\n let handler = Run_state.handler s in\n let s', y =\n Simple.eval (t ())\n (Run_state.set_handler s (Request.Handler.push handler h))\n in\n (Run_state.set_handler s' handler, y) )\n\n let exists\n (Types.Typ.Typ\n { Types.Typ.var_of_fields\n ; value_to_fields\n ; size_in_field_elements\n ; check\n ; constraint_system_auxiliary\n ; _\n } :\n (_, _, _, _ Simple.t) Types.Typ.typ ) p : _ Simple.t =\n Function\n (fun s ->\n if Run_state.has_witness s then (\n let old = Run_state.as_prover s in\n Run_state.set_as_prover s true ;\n let value =\n As_prover.Provider.run p (Run_state.stack s) (get_value s)\n (Run_state.handler s)\n in\n Run_state.set_as_prover s old ;\n let var =\n let store_value =\n if Run_state.as_prover s then\n (* If we're nested in a prover block, create constants instead of\n storing.\n *)\n Cvar.constant\n else Run_state.store_field_elt s\n in\n let fields, aux = value_to_fields value in\n let field_vars = Array.map ~f:store_value fields in\n var_of_fields (field_vars, aux)\n in\n (* TODO: Push a label onto the stack here *)\n let s, () = Simple.eval (check var) s in\n (s, { Handle.var; value = Some value }) )\n else\n let var =\n var_of_fields\n ( Array.init size_in_field_elements ~f:(fun _ ->\n Run_state.alloc_var s () )\n , constraint_system_auxiliary () )\n in\n (* TODO: Push a label onto the stack here *)\n let s, () = Simple.eval (check var) s in\n (s, { Handle.var; value = None }) )\n\n let next_auxiliary () : _ Simple.t =\n Function (fun s -> (s, Run_state.next_auxiliary s))\n\n let direct f : _ Simple.t = Function f\n\n let constraint_count ?(weight = Fn.const 1)\n ?(log = fun ?start:_ _lab _pos -> ()) (t : unit -> _ Simple.t) =\n (* TODO: Integrate log with log_constraint *)\n let count = ref 0 in\n let log_constraint ?at_label_boundary c =\n ( match at_label_boundary with\n | None ->\n ()\n | Some (pos, lab) ->\n let start = match pos with `Start -> true | _ -> false in\n log ~start lab !count ) ;\n count := !count + Option.value_map ~default:0 ~f:weight c\n in\n let state =\n Run_state.make ~num_inputs:0 ~input:Run_state.Vector.null\n ~next_auxiliary:(ref 1) ~aux:Run_state.Vector.null\n ~eval_constraints:false ~log_constraint ~with_witness:false ()\n in\n let _ = Simple.eval (t ()) state in\n !count\nend\n\nmodule type Run_extras = sig\n type field\n\n type cvar\n\n module Types : Types.Types\n\n val get_value : field Run_state.t -> cvar -> field\n\n val run_as_prover :\n ('a, field) As_prover0.t option\n -> field Run_state.t\n -> field Run_state.t * 'a option\nend\n\nmodule Make (Backend : Backend_extended.S) = struct\n open Backend\n\n type 'f field = 'f\n\n let constraint_logger = ref None\n\n let set_constraint_logger f = constraint_logger := Some f\n\n let clear_constraint_logger () = constraint_logger := None\n\n module Checked_runner = Make_checked (Backend) (As_prover0)\n\n type run_state = Checked_runner.run_state\n\n type state = run_state\n\n type ('a, 't) run = 't -> run_state -> run_state * 'a\n\n include (\n Checked_runner :\n sig\n include\n Checked_intf.Basic\n with module Types := Checked_runner.Types\n with type 'f field := 'f Checked_runner.field\n\n include\n Run_extras\n with module Types := Checked_runner.Types\n with type field := Backend.Field.t\n and type cvar := Backend.Cvar.t\n end )\n\n module Types = Checked_runner.Types\n\n let run = Simple.eval\n\n let dummy_vector = Run_state.Vector.null\n\n let fake_state next_auxiliary stack =\n Run_state.make ~num_inputs:0 ~input:Run_state.Vector.null ~next_auxiliary\n ~aux:Run_state.Vector.null ~eval_constraints:false ~stack\n ~with_witness:false ()\n\n module State = struct\n let make ~num_inputs ~input ~next_auxiliary ~aux ?system\n ?(eval_constraints = !eval_constraints_ref) ?handler ~with_witness\n ?log_constraint () =\n let log_constraint =\n match log_constraint with\n | Some _ ->\n log_constraint\n | None ->\n !constraint_logger\n in\n (* We can't evaluate the constraints if we are not computing over a value. *)\n let eval_constraints = eval_constraints && with_witness in\n Option.iter\n (system : R1CS_constraint_system.t option)\n ~f:(fun system ->\n R1CS_constraint_system.set_primary_input_size system num_inputs ) ;\n let system =\n Option.map system ~f:(fun sys ->\n let module M = struct\n module Field = struct\n type nonrec t = Field.t\n end\n\n include R1CS_constraint_system\n end in\n Constraint_system.T ((module M), sys) )\n in\n Run_state.make ~num_inputs ~input ~next_auxiliary ~aux ?system\n ~eval_constraints ?log_constraint ?handler ~with_witness ()\n end\nend\n\nmodule type S = sig\n include Run_extras\n\n type constr\n\n type r1cs\n\n val set_constraint_logger :\n (?at_label_boundary:[ `Start | `End ] * string -> constr -> unit) -> unit\n\n val clear_constraint_logger : unit -> unit\n\n type run_state = field Run_state.t\n\n type state = run_state\n\n type ('a, 't) run = 't -> run_state -> run_state * 'a\n\n val run : ('a, field) Types.Checked.t -> run_state -> run_state * 'a\n\n module State : sig\n val make :\n num_inputs:int\n -> input:field Run_state.Vector.t\n -> next_auxiliary:int ref\n -> aux:field Run_state.Vector.t\n -> ?system:r1cs\n -> ?eval_constraints:bool\n -> ?handler:Request.Handler.t\n -> with_witness:bool\n -> ?log_constraint:\n ( ?at_label_boundary:[ `End | `Start ] * string\n -> (field Cvar.t, field) Constraint.t option\n -> unit )\n -> unit\n -> field Run_state.t\n end\nend\n","open Core_kernel\nmodule Cvar0 = Cvar\nmodule Runner = Checked_runner\n\nlet set_eval_constraints b = Runner.eval_constraints := b\n\nmodule Make\n (Backend : Backend_extended.S)\n (Checked : Checked_intf.Extended with type field = Backend.Field.t)\n (As_prover : As_prover0.Extended with type field := Backend.Field.t)\n (Runner : Runner.S\n with module Types := Checked.Types\n with type field := Backend.Field.t\n and type cvar := Backend.Cvar.t\n and type constr := Backend.Constraint.t option\n and type r1cs := Backend.R1CS_constraint_system.t) =\nstruct\n open Backend\n\n open Runners.Make (Backend) (Checked) (As_prover) (Runner)\n\n module Typ = struct\n include Types.Typ.T\n module T = Typ.Make (Checked_intf.Unextend (Checked))\n include T.T\n\n type ('var, 'value) t = ('var, 'value, Field.t) T.t\n\n let unit : (unit, unit) t = unit ()\n\n let field : (Cvar.t, Field.t) t = field ()\n end\n\n open (\n Checked :\n Checked_intf.Extended\n with module Types := Checked.Types\n with type field := field )\n\n (* [equal_constraints z z_inv r] asserts that\n if z = 0 then r = 1, or\n if z <> 0 then r = 0 and z * z_inv = 1\n *)\n let equal_constraints (z : Cvar.t) (z_inv : Cvar.t) (r : Cvar.t) =\n Checked.assert_all\n [ Constraint.r1cs ~label:\"equals_1\" z_inv z Cvar.(constant Field.one - r)\n ; Constraint.r1cs ~label:\"equals_2\" r z (Cvar.constant Field.zero)\n ]\n\n (* [equal_vars z] computes [(r, z_inv)] that satisfy the constraints in\n [equal_constraints z z_inv r].\n\n In particular, [r] is [1] if [z = 0] and [0] otherwise.\n *)\n let equal_vars (z : Cvar.t) : (Field.t * Field.t) As_prover.t =\n let open As_prover.Let_syntax in\n let%map z = As_prover.read_var z in\n if Field.equal z Field.zero then (Field.one, Field.zero)\n else (Field.zero, Field.inv z)\n\n let constant (Typ typ : _ Typ.t) x =\n let fields, aux = typ.value_to_fields x in\n let field_vars = Array.map fields ~f:(fun x -> Cvar0.Constant x) in\n typ.var_of_fields (field_vars, aux)\n\n let equal (x : Cvar.t) (y : Cvar.t) : Cvar.t Boolean.t Checked.t =\n match (x, y) with\n | Constant x, Constant y ->\n Checked.return\n (Boolean.Unsafe.create\n (Cvar.constant\n (if Field.equal x y then Field.one else Field.zero) ) )\n | _ ->\n let z = Cvar.(x - y) in\n let%bind r, inv =\n Checked.exists Typ.(tuple2 field field) ~compute:(equal_vars z)\n in\n let%map () = equal_constraints z inv r in\n Boolean.Unsafe.create r\n\n let mul ?(label = \"Checked.mul\") (x : Cvar.t) (y : Cvar.t) =\n match (x, y) with\n | Constant x, Constant y ->\n return (Cvar.constant (Field.mul x y))\n | Constant x, _ ->\n return (Cvar.scale y x)\n | _, Constant y ->\n return (Cvar.scale x y)\n | _, _ ->\n with_label label (fun () ->\n let open Let_syntax in\n let%bind z =\n Checked.exists Typ.field\n ~compute:As_prover.(map2 (read_var x) (read_var y) ~f:Field.mul)\n in\n let%map () = assert_r1cs x y z in\n z )\n\n let square ?(label = \"Checked.square\") (x : Cvar.t) =\n match x with\n | Constant x ->\n return (Cvar.constant (Field.square x))\n | _ ->\n with_label label (fun () ->\n let open Let_syntax in\n let%bind z =\n exists Typ.field\n ~compute:As_prover.(map (read_var x) ~f:Field.square)\n in\n let%map () = assert_square x z in\n z )\n\n (* We get a better stack trace by failing at the call to is_satisfied, so we\n put a bogus value for the inverse to make the constraint system unsat if\n x is zero. *)\n let inv ?(label = \"Checked.inv\") (x : Cvar.t) =\n match x with\n | Constant x ->\n return (Cvar.constant (Field.inv x))\n | _ ->\n with_label label (fun () ->\n let open Let_syntax in\n let%bind x_inv =\n exists Typ.field\n ~compute:\n As_prover.(\n map (read_var x) ~f:(fun x ->\n if Field.(equal zero x) then Field.zero\n else Backend.Field.inv x ))\n in\n let%map () =\n assert_r1cs ~label:\"field_inverse\" x x_inv\n (Cvar.constant Field.one)\n in\n x_inv )\n\n let div ?(label = \"Checked.div\") (x : Cvar.t) (y : Cvar.t) =\n match (x, y) with\n | Constant x, Constant y ->\n return (Cvar.constant (Field.( / ) x y))\n | _ ->\n with_label label (fun () ->\n let open Let_syntax in\n let%bind y_inv = inv y in\n mul x y_inv )\n\n let%snarkydef_ if_ (b : Cvar.t Boolean.t) ~(then_ : Cvar.t) ~(else_ : Cvar.t)\n =\n let open Let_syntax in\n (* r = e + b (t - e)\n r - e = b (t - e)\n *)\n let b = (b :> Cvar.t) in\n match b with\n | Constant b ->\n if Field.(equal b one) then return then_ else return else_\n | _ -> (\n match (then_, else_) with\n | Constant t, Constant e ->\n return Cvar.((t * b) + (e * (constant Field0.one - b)))\n | _, _ ->\n let%bind r =\n exists Typ.field\n ~compute:\n (let open As_prover in\n let open Let_syntax in\n let%bind b = read_var b in\n read Typ.field\n (if Field.equal b Field.one then then_ else else_))\n in\n let%map () = assert_r1cs b Cvar.(then_ - else_) Cvar.(r - else_) in\n r )\n\n let%snarkydef_ assert_non_zero (v : Cvar.t) =\n let open Let_syntax in\n let%map _ = inv v in\n ()\n\n module Boolean = struct\n open Boolean.Unsafe\n\n type var = Cvar.t Boolean.t\n\n type value = bool\n\n let true_ : var = create (Cvar.constant Field.one)\n\n let false_ : var = create (Cvar.constant Field.zero)\n\n let not (x : var) : var = create Cvar.((true_ :> Cvar.t) - (x :> Cvar.t))\n\n let if_ b ~(then_ : var) ~(else_ : var) =\n map ~f:create (if_ b ~then_:(then_ :> Cvar.t) ~else_:(else_ :> Cvar.t))\n\n (* This is unused for now as we are not using any square constraint system based\n backends. *)\n let _and_for_square_constraint_systems (x : var) (y : var) =\n (* (x + y)^2 = 2 z + x + y\n\n x^2 + 2 x*y + y^2 = 2 z + x + y\n x + 2 x*y + y = 2 z + x + y\n 2 x*y = 2 z\n x * y = z\n *)\n let x = (x :> Cvar.t) in\n let y = (y :> Cvar.t) in\n let open Let_syntax in\n let%bind z =\n exists Typ.field\n ~compute:\n (let open As_prover in\n let open Let_syntax in\n let%map x = read_var x and y = read_var y in\n if Field.(equal one x) && Field.(equal one y) then Field.one\n else Field.zero)\n in\n let%map () =\n let x_plus_y = Cvar.add x y in\n assert_square x_plus_y Cvar.((Field.of_int 2 * z) + x_plus_y)\n in\n create z\n\n let ( && ) (x : var) (y : var) : var Checked.t =\n Checked.map ~f:create (mul (x :> Cvar.t) (y :> Cvar.t))\n\n let ( &&& ) = ( && )\n\n let ( || ) x y =\n let open Let_syntax in\n let%map both_false = (not x) && not y in\n not both_false\n\n let ( ||| ) = ( || )\n\n let any = function\n | [] ->\n return false_\n | [ b1 ] ->\n return b1\n | [ b1; b2 ] ->\n b1 || b2\n | bs ->\n let open Let_syntax in\n let%map all_zero =\n equal (Cvar.sum (bs :> Cvar.t list)) (Cvar.constant Field.zero)\n in\n not all_zero\n\n let all = function\n | [] ->\n return true_\n | [ b1 ] ->\n return b1\n | [ b1; b2 ] ->\n b1 && b2\n | bs ->\n equal\n (Cvar.constant (Field.of_int (List.length bs)))\n (Cvar.sum (bs :> Cvar.t list))\n\n let to_constant (b : var) =\n Option.map (Cvar.to_constant (b :> Cvar.t)) ~f:Field.(equal one)\n\n let var_of_value b = if b then true_ else false_\n\n let typ : (var, value) Typ.t =\n let (Typ typ) =\n Typ.field\n |> Typ.transport\n ~there:(function true -> Field.one | false -> Field.zero)\n ~back:(fun x -> if Field.equal x Field.zero then false else true)\n |> Typ.transport_var\n ~there:(fun (b : var) -> (b :> Cvar.t))\n ~back:create\n in\n Typ\n { typ with\n check =\n (fun v ->\n Checked.assert_\n (Constraint.boolean ~label:\"boolean-alloc\" (v :> Cvar.t)) )\n }\n\n let typ_unchecked : (var, value) Typ.t =\n let (Typ typ) = typ in\n Typ { typ with check = (fun _ -> Checked.return ()) }\n\n let%test_unit \"all\" =\n let gen =\n let open Quickcheck.Generator in\n let open Let_syntax in\n let%bind length = small_positive_int in\n list_with_length length bool\n in\n Quickcheck.test gen ~sexp_of:[%sexp_of: bool list] ~f:(fun x ->\n let r =\n run_and_check\n (Checked.map ~f:(As_prover.read typ)\n (all (List.map ~f:(constant typ_unchecked) x)) )\n |> Or_error.ok_exn\n in\n [%test_eq: bool] r (List.for_all x ~f:Fn.id) )\n\n let ( lxor ) b1 b2 =\n match (to_constant b1, to_constant b2) with\n | Some b1, Some b2 ->\n return (constant typ (Caml.not (Bool.equal b1 b2)))\n | Some true, None ->\n return (not b2)\n | None, Some true ->\n return (not b1)\n | Some false, None ->\n return b2\n | None, Some false ->\n return b1\n | None, None ->\n (* (1 - 2 a) (1 - 2 b) = 1 - 2 c\n 1 - 2 (a + b) + 4 a b = 1 - 2 c\n - 2 (a + b) + 4 a b = - 2 c\n (a + b) - 2 a b = c\n 2 a b = a + b - c\n *)\n let open Let_syntax in\n let%bind res =\n exists typ_unchecked\n ~compute:\n As_prover.(\n map2 ~f:Bool.( <> ) (read typ_unchecked b1)\n (read typ_unchecked b2))\n in\n let%map () =\n let a = (b1 :> Cvar.t) in\n let b = (b2 :> Cvar.t) in\n let c = (res :> Cvar.t) in\n let open Cvar in\n assert_r1cs (a + a) b (a + b - c)\n in\n res\n\n module Array = struct\n let num_true (bs : var array) =\n Array.fold bs ~init:(Cvar.constant Field.zero) ~f:(fun x y ->\n Cvar.add x (y :> Cvar.t) )\n\n let any = function\n | [||] ->\n return false_\n | [| b1 |] ->\n return b1\n | [| b1; b2 |] ->\n b1 || b2\n | bs ->\n let open Let_syntax in\n let%map all_zero = equal (num_true bs) (Cvar.constant Field.zero) in\n not all_zero\n\n let all = function\n | [||] ->\n return true_\n | [| b1 |] ->\n return b1\n | [| b1; b2 |] ->\n b1 && b2\n | bs ->\n equal (Cvar.constant (Field.of_int (Array.length bs))) (num_true bs)\n\n module Assert = struct\n let any bs = assert_non_zero (num_true bs)\n\n let all bs =\n assert_equal (num_true bs)\n (Cvar.constant (Field.of_int (Array.length bs)))\n end\n end\n\n let equal (a : var) (b : var) = a lxor b >>| not\n\n let of_field x =\n let open Let_syntax in\n let%map () = assert_ (Constraint.boolean x) in\n create x\n\n module Unsafe = struct\n let of_cvar (t : Cvar.t) : var = create t\n end\n\n module Assert = struct\n let ( = ) (x : var) (y : var) = assert_equal (x :> Cvar.t) (y :> Cvar.t)\n\n let is_true (v : var) = v = true_\n\n let%snarkydef_ any (bs : var list) =\n assert_non_zero (Cvar.sum (bs :> Cvar.t list))\n\n let%snarkydef_ all (bs : var list) =\n assert_equal\n (Cvar.sum (bs :> Cvar.t list))\n (Cvar.constant (Field.of_int (List.length bs)))\n\n let%snarkydef_ exactly_one (bs : var list) =\n assert_equal (Cvar.sum (bs :> Cvar.t list)) (Cvar.constant Field.one)\n end\n\n module Expr = struct\n type t = Var of var | And of t list | Or of t list | Not of t\n\n let rec eval t =\n let open Let_syntax in\n match t with\n | Not t ->\n eval t >>| not\n | Var v ->\n return v\n | And ts ->\n Checked.all (List.map ~f:eval ts) >>= all\n | Or ts ->\n Checked.all (List.map ~f:eval ts) >>= any\n\n let assert_ t = eval t >>= Assert.is_true\n\n let ( ! ) v = Var v\n\n let ( && ) x y = And [ x; y ]\n\n let ( &&& ) = ( && )\n\n let ( || ) x y = Or [ x; y ]\n\n let ( ||| ) = ( || )\n\n let not t = Not t\n\n let any xs = Or xs\n\n let all xs = And xs\n end\n end\n\n module Typ2 = Typ\nend\n","open Core_kernel\n\nmodule Address = struct\n type t = int\nend\n\nmodule Free_hash = struct\n type 'a t = Hash_value of 'a | Hash_empty | Merge of 'a t * 'a t\n [@@deriving sexp]\n\n let diff t1 t2 =\n let module M = struct\n exception Done of bool list\n end in\n let rec go path t1 t2 =\n match (t1, t2) with\n | Hash_empty, Hash_empty ->\n None\n | Hash_value x, Hash_value y ->\n (* poly equality; we don't know type of x and y *)\n if Caml.( = ) x y then None else raise (M.Done path)\n | Merge (l1, r1), Merge (l2, r2) ->\n ignore (go (false :: path) l1 l2) ;\n ignore (go (true :: path) r1 r2) ;\n None\n | Hash_empty, Hash_value _\n | Hash_empty, Merge _\n | Hash_value _, Hash_empty\n | Hash_value _, Merge _\n | Merge _, Hash_empty\n | Merge _, Hash_value _ ->\n raise (M.Done path)\n in\n try go [] t1 t2 with M.Done addr -> Some addr\n\n let rec run t ~hash ~merge =\n match t with\n | Hash_value x ->\n hash (Some x)\n | Hash_empty ->\n hash None\n | Merge (l, r) ->\n merge (run ~hash ~merge l) (run ~hash ~merge r)\nend\n\ntype ('hash, 'a) non_empty_tree =\n | Node of 'hash * ('hash, 'a) tree * ('hash, 'a) tree\n | Leaf of 'hash * 'a\n\nand ('hash, 'a) tree = Non_empty of ('hash, 'a) non_empty_tree | Empty\n[@@deriving sexp]\n\ntype ('hash, 'a) t =\n { tree : ('hash, 'a) non_empty_tree\n ; depth : int\n ; count : int\n ; hash : 'a option -> 'hash\n ; merge : 'hash -> 'hash -> 'hash\n }\n[@@deriving sexp]\n\nlet check_exn { tree; hash; merge; _ } =\n let default = hash None in\n let rec check_hash = function\n | Non_empty t ->\n check_hash_non_empty t\n | Empty ->\n default\n and check_hash_non_empty = function\n | Leaf (h, x) ->\n (* poly equality; don't know the hash type *)\n assert (Caml.( = ) h (hash (Some x))) ;\n h\n | Node (h, l, r) ->\n (* poly equality *)\n assert (Caml.( = ) (merge (check_hash l) (check_hash r)) h) ;\n h\n in\n ignore (check_hash_non_empty tree)\n\nlet non_empty_hash = function Node (h, _, _) -> h | Leaf (h, _) -> h\n\nlet depth { depth; _ } = depth\n\nlet tree_hash ~default = function\n | Empty ->\n default\n | Non_empty t ->\n non_empty_hash t\n\nlet to_list : ('hash, 'a) t -> 'a list =\n let rec go acc = function\n | Empty ->\n acc\n | Non_empty (Leaf (_, x)) ->\n x :: acc\n | Non_empty (Node (_h, l, r)) ->\n let acc' = go acc r in\n go acc' l\n in\n fun t -> go [] (Non_empty t.tree)\n\nlet left_tree hash merge depth x =\n let empty_hash = hash None in\n let rec go i h acc =\n if i = depth then (h, acc)\n else\n let h' = merge h empty_hash in\n go (i + 1) h' (Node (h', Non_empty acc, Empty))\n in\n let h = hash (Some x) in\n go 0 h (Leaf (h, x))\n\nlet insert hash merge t0 mask0 address x =\n let default = hash None in\n let rec go mask t =\n if mask = 0 then\n match t with\n | Empty ->\n Leaf (hash (Some x), x)\n | Non_empty _ ->\n failwith \"Tree should be empty\"\n else\n let go_left = mask land address = 0 in\n let mask' = mask lsr 1 in\n match t with\n | Empty ->\n if go_left then\n let t_l' = go mask' Empty in\n Node (merge (non_empty_hash t_l') default, Non_empty t_l', Empty)\n else\n let t_r' = go mask' Empty in\n Node (merge default (non_empty_hash t_r'), Empty, Non_empty t_r')\n | Non_empty (Node (_h, t_l, t_r)) ->\n if go_left then\n let t_l' = go mask' t_l in\n Node\n ( merge (non_empty_hash t_l') (tree_hash ~default t_r)\n , Non_empty t_l'\n , t_r )\n else\n let t_r' = go mask' t_r in\n Node\n ( merge (tree_hash ~default t_l) (non_empty_hash t_r')\n , t_l\n , Non_empty t_r' )\n | Non_empty (Leaf _) ->\n failwith \"Cannot insert into leaf\"\n in\n go mask0 t0\n\nlet ith_bit n i = (n lsr i) land 1 = 1\n\nlet get { tree; depth; _ } addr0 =\n let rec get t i =\n match t with Empty -> None | Non_empty t -> get_non_empty t i\n and get_non_empty t i =\n match t with\n | Node (_, l, r) ->\n let go_right = ith_bit addr0 i in\n if go_right then get r (i - 1) else get l (i - 1)\n | Leaf (_, x) ->\n Some x\n in\n get_non_empty tree (depth - 1)\n\nlet get_exn t addr = Option.value_exn (get t addr)\n\nlet set_dirty default tree addr x =\n let rec go tree addr =\n match (tree, addr) with\n | Empty, go_right :: bs ->\n let t = Non_empty (go Empty bs) in\n let l, r = if go_right then (Empty, t) else (t, Empty) in\n Node (default, l, r)\n | Empty, [] ->\n Leaf (default, x)\n | Non_empty t, _ ->\n go_non_empty t addr\n and go_non_empty tree addr =\n match (tree, addr) with\n | Leaf _, [] ->\n Leaf (default, x)\n | Node (_, l, r), go_right :: bs ->\n let l', r' =\n if go_right then (l, Non_empty (go r bs)) else (Non_empty (go l bs), r)\n in\n Node (default, l', r')\n | Leaf _, _ :: _ | Node _, [] ->\n failwith \"Merkle_tree.set_dirty (go_non_empty): Mismatch\"\n in\n go_non_empty tree (List.rev addr)\n\nlet recompute_hashes { tree; hash; merge; _ } =\n let h =\n let default = hash None in\n fun t -> tree_hash ~default t\n in\n let rec go = function\n | Non_empty t ->\n Non_empty (go_non_empty t)\n | Empty ->\n Empty\n and go_non_empty = function\n | Leaf (_, x) ->\n Leaf (hash (Some x), x)\n | Node (_, l, r) ->\n let l' = go l in\n let r' = go r in\n Node (merge (h l') (h r'), l', r')\n in\n go_non_empty tree\n\nlet address_of_int ~depth n : bool list =\n List.init depth ~f:(fun i -> n land (1 lsl i) <> 0)\n\nlet add_many t xs =\n let default = t.hash None in\n let left_tree_dirty depth x =\n let rec go i acc =\n if i = depth then acc\n else go (i + 1) (Node (default, Non_empty acc, Empty))\n in\n go 0 (Leaf (default, x))\n in\n let add_one_dirty { tree; depth; count; hash; merge } x =\n if count = 1 lsl depth then\n let t_r = left_tree_dirty depth x in\n { tree = Node (default, Non_empty tree, Non_empty t_r)\n ; count = count + 1\n ; depth = depth + 1\n ; hash\n ; merge\n }\n else\n { tree = set_dirty default tree (address_of_int ~depth count) x\n ; count = count + 1\n ; depth\n ; hash\n ; merge\n }\n in\n let t = List.fold_left xs ~init:t ~f:add_one_dirty in\n { t with tree = recompute_hashes t }\n\nlet add { tree; depth; count; hash; merge } x =\n if count = 1 lsl depth then\n let h_r, t_r = left_tree hash merge depth x in\n let h_l = non_empty_hash tree in\n { tree = Node (merge h_l h_r, Non_empty tree, Non_empty t_r)\n ; count = count + 1\n ; depth = depth + 1\n ; hash\n ; merge\n }\n else\n { tree = insert hash merge (Non_empty tree) (1 lsl (depth - 1)) count x\n ; count = count + 1\n ; depth\n ; hash\n ; merge\n }\n\nlet root { tree; _ } = non_empty_hash tree\n\nlet create ~hash ~merge x =\n { tree = Leaf (hash (Some x), x); count = 1; depth = 0; hash; merge }\n\nlet get_path { tree; hash; depth; _ } addr0 =\n let default = hash None in\n let rec go acc t i =\n if i < 0 then acc\n else\n let go_right = ith_bit addr0 i in\n if go_right then\n match t with\n | Leaf _ ->\n failwith \"get_path\"\n | Node (_h, _t_l, Empty) ->\n failwith \"get_path\"\n | Node (_h, t_l, Non_empty t_r) ->\n go (tree_hash ~default t_l :: acc) t_r (i - 1)\n else\n match t with\n | Leaf _ ->\n failwith \"get_path\"\n | Node (_h, Empty, _t_r) ->\n failwith \"get_path\"\n | Node (_h, Non_empty t_l, t_r) ->\n go (tree_hash ~default t_r :: acc) t_l (i - 1)\n in\n go [] tree (depth - 1)\n\nlet implied_root ~merge addr0 entry_hash path0 =\n let rec go acc i path =\n match path with\n | [] ->\n acc\n | h :: hs ->\n go (if ith_bit addr0 i then merge h acc else merge acc h) (i + 1) hs\n in\n go entry_hash 0 path0\n\nlet rec free_tree_hash = function\n | Empty ->\n Free_hash.Hash_empty\n | Non_empty (Leaf (_, x)) ->\n Hash_value x\n | Non_empty (Node (_, l, r)) ->\n Merge (free_tree_hash l, free_tree_hash r)\n\nlet free_root { tree; _ } = free_tree_hash (Non_empty tree)\n\nlet get_free_path { tree; depth; _ } addr0 =\n let rec go acc t i =\n if i < 0 then acc\n else\n let go_right = ith_bit addr0 i in\n if go_right then\n match t with\n | Leaf _ ->\n failwith \"get_path\"\n | Node (_h, _t_l, Empty) ->\n failwith \"get_path\"\n | Node (_h, t_l, Non_empty t_r) ->\n go (free_tree_hash t_l :: acc) t_r (i - 1)\n else\n match t with\n | Leaf _ ->\n failwith \"get_path\"\n | Node (_h, Empty, _t_r) ->\n failwith \"get_path\"\n | Node (_h, Non_empty t_l, t_r) ->\n go (free_tree_hash t_r :: acc) t_l (i - 1)\n in\n go [] tree (depth - 1)\n\nlet implied_free_root addr0 x path0 =\n implied_root\n ~merge:(fun a b -> Free_hash.Merge (a, b))\n addr0 (Hash_value x) path0\n\ntype ('hash, 'a) merkle_tree = ('hash, 'a) t\n\nmodule Checked\n (Impl : Snark_intf.Basic) (Hash : sig\n type var\n\n type value\n\n val typ : (var, value) Impl.Typ.t\n\n val merge : height:int -> var -> var -> var Impl.Checked.t\n\n val if_ : Impl.Boolean.var -> then_:var -> else_:var -> var Impl.Checked.t\n\n val assert_equal : var -> var -> unit Impl.Checked.t\n end) (Elt : sig\n type var\n\n type value\n\n val typ : (var, value) Impl.Typ.t\n\n val hash : var -> Hash.var Impl.Checked.t\n end) =\nstruct\n open Impl\n\n module Address = struct\n type var = Boolean.var list\n\n type value = int\n\n let typ ~depth : (var, value) Typ.t =\n Typ.transport\n (Typ.list ~length:depth Boolean.typ)\n ~there:(address_of_int ~depth)\n ~back:\n (List.foldi ~init:0 ~f:(fun i acc b ->\n if b then acc lor (1 lsl i) else acc ) )\n end\n\n module Path = struct\n type value = Hash.value list\n\n type var = Hash.var list\n\n let typ ~depth : (var, value) Typ.t = Typ.(list ~length:depth Hash.typ)\n end\n\n let implied_root entry_hash addr0 path0 =\n let rec go height acc addr path =\n let open Let_syntax in\n match (addr, path) with\n | [], [] ->\n return acc\n | b :: bs, h :: hs ->\n let%bind l = Hash.if_ b ~then_:h ~else_:acc\n and r = Hash.if_ b ~then_:acc ~else_:h in\n let%bind acc' = Hash.merge ~height l r in\n go (height + 1) acc' bs hs\n | _, _ ->\n failwith\n \"Merkle_tree.Checked.implied_root: address, path length mismatch\"\n in\n go 0 entry_hash addr0 path0\n\n type _ Request.t +=\n | Get_element : Address.value -> (Elt.value * Path.value) Request.t\n | Get_path : Address.value -> Path.value Request.t\n | Set : Address.value * Elt.value -> unit Request.t\n\n (* addr0 should have least significant bit first *)\n let%snarkydef_ fetch_and_update_req ~(depth : int) root addr0 ~f :\n (Hash.var * [ `Old of Elt.var ] * [ `New of Elt.var ]) Checked.t =\n let open Let_syntax in\n let%bind prev, prev_path =\n request_witness\n Typ.(Elt.typ * Path.typ ~depth)\n As_prover.(\n read (Address.typ ~depth) addr0 >>| fun addr -> Get_element addr)\n in\n let%bind () =\n let%bind prev_entry_hash = Elt.hash prev in\n implied_root prev_entry_hash addr0 prev_path >>= Hash.assert_equal root\n in\n let%bind next = f prev in\n let%bind next_entry_hash = Elt.hash next in\n let%bind () =\n perform\n (let open As_prover in\n let open Let_syntax in\n let%map addr = read (Address.typ ~depth) addr0\n and next = read Elt.typ next in\n Set (addr, next))\n in\n let%map new_root = implied_root next_entry_hash addr0 prev_path in\n (new_root, `Old prev, `New next)\n\n (* addr0 should have least significant bit first *)\n let%snarkydef_ modify_req ~(depth : int) root addr0 ~f : Hash.var Checked.t =\n let%map root, _, _ = fetch_and_update_req ~depth root addr0 ~f in\n root\n\n (* addr0 should have least significant bit first *)\n let%snarkydef_ get_req ~(depth : int) root addr0 : Elt.var Checked.t =\n let open Let_syntax in\n let%bind prev, prev_path =\n request_witness\n Typ.(Elt.typ * Path.typ ~depth)\n As_prover.(\n map (read (Address.typ ~depth) addr0) ~f:(fun a -> Get_element a))\n in\n let%bind () =\n let%bind prev_entry_hash = Elt.hash prev in\n implied_root prev_entry_hash addr0 prev_path >>= Hash.assert_equal root\n in\n return prev\n\n (* addr0 should have least significant bit first *)\n let%snarkydef_ update_req ~(depth : int) ~root ~prev ~next addr0 :\n Hash.var Checked.t =\n let open Let_syntax in\n let%bind prev_entry_hash = Elt.hash prev\n and next_entry_hash = Elt.hash next\n and prev_path =\n request_witness (Path.typ ~depth)\n As_prover.(\n map (read (Address.typ ~depth) addr0) ~f:(fun a -> Get_path a))\n in\n let%bind () =\n implied_root prev_entry_hash addr0 prev_path >>= Hash.assert_equal root\n in\n let%bind () =\n perform\n (let open As_prover in\n let open Let_syntax in\n let%map addr = read (Address.typ ~depth) addr0\n and next = read Elt.typ next in\n Set (addr, next))\n in\n implied_root next_entry_hash addr0 prev_path\nend\n\nmodule Run = struct\n module Make\n (Impl : Snark_intf.Run_basic) (Hash : sig\n type var\n\n type value\n\n val typ : (var, value) Impl.Typ.t\n\n val merge : height:int -> var -> var -> var\n\n val if_ : Impl.Boolean.var -> then_:var -> else_:var -> var\n\n val assert_equal : var -> var -> unit\n end) (Elt : sig\n type var\n\n type value\n\n val typ : (var, value) Impl.Typ.t\n\n val hash : var -> Hash.var\n end) =\n struct\n open Impl\n\n include\n Checked\n (Impl.Internal_Basic)\n (struct\n include Hash\n\n let merge ~height x y = make_checked (fun () -> merge ~height x y)\n\n let if_ x ~then_ ~else_ = make_checked (fun () -> if_ x ~then_ ~else_)\n\n let assert_equal x y = make_checked (fun () -> assert_equal x y)\n end)\n (struct\n include Elt\n\n let hash var = make_checked (fun () -> hash var)\n end)\n\n let implied_root entry_hash addr0 path0 =\n run_checked (implied_root entry_hash addr0 path0)\n\n let modify_req ~depth root addr0 ~f =\n run_checked\n (modify_req ~depth root addr0 ~f:(fun x -> make_checked (fun () -> f x)))\n\n let get_req ~depth root addr0 = run_checked (get_req ~depth root addr0)\n\n let update_req ~depth ~root ~prev ~next addr0 =\n run_checked (update_req ~depth ~root ~prev ~next addr0)\n end\nend\n","open Core_kernel\nmodule Cvar0 = Cvar\nmodule Bignum_bigint = Bigint\n\nexception Runtime_error of string list * exn * string\n\nmodule Runner = Checked_runner\n\nlet set_eval_constraints b = Runner.eval_constraints := b\n\nmodule Make_basic\n (Backend : Backend_extended.S)\n (Checked : Checked_intf.Extended with type field = Backend.Field.t)\n (As_prover : As_prover0.Extended with type field := Backend.Field.t)\n (Ref : As_prover_ref.S\n with module Types := Checked.Types\n and type 'f field := Backend.Field.t\n and type ('a, 'f) checked := 'a Checked.t)\n (Runner : Runner.S\n with module Types := Checked.Types\n with type field := Backend.Field.t\n and type cvar := Backend.Cvar.t\n and type constr := Backend.Constraint.t option\n and type r1cs := Backend.R1CS_constraint_system.t) =\nstruct\n open Backend\n module Checked_S = Checked_intf.Unextend (Checked)\n include Runners.Make (Backend) (Checked) (As_prover) (Runner)\n module Bigint = Bigint\n module Field0 = Field\n module Cvar = Cvar\n module Constraint = Constraint\n\n module Handler = struct\n type t = Request.request -> Request.response\n end\n\n module Typ = struct\n include Types.Typ.T\n module T = Typ.Make (Checked_S)\n include T.T\n\n type ('var, 'value) t = ('var, 'value, Field.t) T.t\n\n let unit : (unit, unit) t = unit ()\n\n let field : (Cvar.t, Field.t) t = field ()\n end\n\n let constant (Typ typ : _ Typ.t) x =\n let fields, aux = typ.value_to_fields x in\n let field_vars = Array.map fields ~f:(fun x -> Cvar0.Constant x) in\n typ.var_of_fields (field_vars, aux)\n\n module As_prover = struct\n include As_prover\n\n type 'a as_prover = 'a t\n\n module Ref = Ref\n end\n\n module Handle = struct\n include Handle\n\n let value = As_prover.Handle.value\n end\n\n module Checked = struct\n include (\n Checked :\n Checked_intf.Extended\n with module Types := Checked.Types\n with type field := field )\n\n let perform req = request_witness Typ.unit req\n\n module Runner = Runner\n\n type run_state = Runner.run_state\n\n include Utils.Make (Backend) (Checked) (As_prover) (Runner)\n\n module Control = struct end\n\n let two_to_the n =\n let rec go acc i =\n if i = 0 then acc else go (Field0.add acc acc) (i - 1)\n in\n go Field0.one n\n\n type _ Request.t += Choose_preimage : Field.t * int -> bool list Request.t\n\n let choose_preimage_unchecked v ~length =\n exists\n (Typ.list Boolean.typ ~length)\n ~request:\n As_prover.(map (read_var v) ~f:(fun x -> Choose_preimage (x, length)))\n ~compute:\n (let open As_prover.Let_syntax in\n let%map x = As_prover.read_var v in\n let x = Bigint.of_field x in\n List.init length ~f:(fun i -> Bigint.test_bit x i))\n\n let packing_sum (bits : Boolean.var list) =\n let ts, _ =\n List.fold_left bits ~init:([], Field.one) ~f:(fun (acc, c) v ->\n ((c, (v :> Cvar.t)) :: acc, Field.add c c) )\n in\n Cvar.linear_combination ts\n\n let choose_preimage (v : Cvar.t) ~length : Boolean.var list t =\n let open Let_syntax in\n let%bind bits = choose_preimage_unchecked v ~length in\n let lc = packing_sum bits in\n let%map () =\n assert_r1cs ~label:\"Choose_preimage\" lc (Cvar.constant Field.one) v\n in\n bits\n\n let choose_preimage_flagged (v : Cvar.t) ~length =\n let open Let_syntax in\n let%bind bits = choose_preimage_unchecked v ~length in\n let lc = packing_sum bits in\n let%map success = equal lc v in\n (bits, `Success success)\n\n module List =\n Monad_sequence.List\n (Checked)\n (struct\n type t = Boolean.var\n\n include Boolean\n end)\n\n module Array =\n Monad_sequence.Array\n (Checked)\n (struct\n type t = Boolean.var\n\n let any = Boolean.Array.any\n\n let all = Boolean.Array.all\n end)\n end\n\n module Cvar1 = struct\n include Cvar\n\n let project =\n let two = Field.of_int 2 in\n fun (vars : Checked.Boolean.var list) ->\n let rec go res = function\n | [] ->\n res\n | v :: vs ->\n go Cvar0.(Add (v, Scale (two, res))) vs\n in\n match List.rev (vars :> Cvar.t list) with\n | [] ->\n Cvar0.Constant Field.zero\n | v :: vs ->\n go v vs\n\n let pack vars =\n assert (List.length vars < Field.size_in_bits) ;\n project vars\n\n let unpack v ~length =\n assert (length < Field.size_in_bits) ;\n Checked.choose_preimage v ~length\n\n let unpack_flagged v ~length =\n assert (length < Field.size_in_bits) ;\n Checked.choose_preimage_flagged v ~length\n end\n\n module Field = struct\n include Field0\n\n let gen =\n Quickcheck.Generator.map\n Bignum_bigint.(gen_incl zero (size - one))\n ~f:(fun x -> Bigint.(to_field (of_bignum_bigint x)))\n\n let gen_incl lo hi =\n let lo_bigint = Bigint.(to_bignum_bigint @@ of_field lo) in\n let hi_bigint = Bigint.(to_bignum_bigint @@ of_field hi) in\n Quickcheck.Generator.map\n Bignum_bigint.(gen_incl lo_bigint hi_bigint)\n ~f:(fun x -> Bigint.(to_field (of_bignum_bigint x)))\n\n let gen_uniform =\n Quickcheck.Generator.map\n Bignum_bigint.(gen_uniform_incl zero (size - one))\n ~f:(fun x -> Bigint.(to_field (of_bignum_bigint x)))\n\n let gen_uniform_incl lo hi =\n let lo_bigint = Bigint.(to_bignum_bigint @@ of_field lo) in\n let hi_bigint = Bigint.(to_bignum_bigint @@ of_field hi) in\n Quickcheck.Generator.map\n Bignum_bigint.(gen_uniform_incl lo_bigint hi_bigint)\n ~f:(fun x -> Bigint.(to_field (of_bignum_bigint x)))\n\n let typ = Typ.field\n\n module Var = Cvar1\n\n let parity x = Bigint.(test_bit (of_field x) 0)\n\n module Checked = struct\n include Cvar1\n\n let equal = Checked.equal\n\n let mul x y = Checked.mul ~label:\"Field.Checked.mul\" x y\n\n let square x = Checked.square ~label:\"Field.Checked.square\" x\n\n let div x y = Checked.div ~label:\"Field.Checked.div\" x y\n\n let inv x = Checked.inv ~label:\"Field.Checked.inv\" x\n\n let sqrt (x : Cvar.t) : Cvar.t Checked.t =\n match x with\n | Constant x ->\n Checked.return (Cvar.constant (Field.sqrt x))\n | _ ->\n let open Checked in\n let open Let_syntax in\n let%bind y =\n exists ~compute:As_prover.(map (read_var x) ~f:Field.sqrt) typ\n in\n let%map () = assert_square y x in\n y\n\n let quadratic_nonresidue =\n lazy\n (let rec go i =\n let x = Field.of_int i in\n if not (Field.is_square x) then x else go Int.(i + 1)\n in\n go 2 )\n\n (* The trick here is the following.\n\n Let beta be a known non-square.\n\n x is not a square iff beta*x is a square\n\n So we guess the result [is_square] and y a sqrt of one of {x, beta*x} and assert\n\n y * y = is_square * x + (1 - is_square) * (beta * x)\n\n which, letting B = beta*x holds iff\n\n y * y\n = is_square * x + B - is_square * B\n = is_square * (x - B) + B\n *)\n let sqrt_check x =\n let open Checked in\n let open Let_syntax in\n let%bind is_square =\n exists\n ~compute:As_prover.(map (read_var x) ~f:Field.is_square)\n Boolean.typ\n in\n let%bind y =\n exists typ\n ~compute:\n As_prover.(\n Let_syntax.(\n let%map is_square = read Boolean.typ is_square\n and x = read_var x in\n if is_square then Field.sqrt x\n else Field.(sqrt (Lazy.force quadratic_nonresidue * x))))\n in\n let b = scale x (Lazy.force quadratic_nonresidue) in\n let%bind t = mul (is_square :> Var.t) (x - b) in\n let%map () = assert_square y (t + b) in\n (y, is_square)\n\n let is_square x =\n let open Checked.Let_syntax in\n let%map _, b = sqrt_check x in\n b\n\n let%test_unit \"is_square\" =\n let x = Field.random () in\n let typf = Typ.field in\n let x2 = Field.square x in\n assert (Field.(equal (x * x) x2)) ;\n let run elt =\n let answer =\n run_and_check\n (Checked.map\n ~f:(As_prover.read Checked.Boolean.typ)\n Checked.(\n Let_syntax.(\n let%bind x = exists typf ~compute:(As_prover.return elt) in\n is_square x)) )\n |> Or_error.ok_exn\n in\n answer\n in\n assert (run x2) ;\n assert (not (run (Field.mul (Lazy.force quadratic_nonresidue) x2)))\n\n let choose_preimage_var = Checked.choose_preimage\n\n type comparison_result =\n { less : Checked.Boolean.var; less_or_equal : Checked.Boolean.var }\n\n let if_ = Checked.if_\n\n let compare ~bit_length a b =\n (* Overview of the logic:\n let n = bit_length\n We have 0 <= a < 2^n, 0 <= b < 2^n, and so\n -2^n < b - a < 2^n\n If (b - a) >= 0, then\n 2^n <= 2^n + b - a < 2^{n+1},\n and so the n-th bit must be set.\n If (b - a) < 0 then\n 0 < 2^n + b - a < 2^n\n and so the n-th bit must not be set.\n Thus, we can use the n-th bit of 2^n + b - a to determine whether\n (b - a) >= 0 <-> a <= b.\n\n We also need that the maximum value\n 2^n + (2^n - 1) - 0 = 2^{n+1} - 1\n fits inside the field, so for the max field element f,\n 2^{n+1} - 1 <= f -> n+1 <= log2(f) = size_in_bits - 1\n *)\n assert (Int.(bit_length <= size_in_bits - 2)) ;\n let open Checked in\n let open Let_syntax in\n [%with_label_ \"compare\"] (fun () ->\n let alpha_packed =\n Cvar.(constant (two_to_the bit_length) + b - a)\n in\n let%bind alpha = unpack alpha_packed ~length:Int.(bit_length + 1) in\n let prefix, less_or_equal =\n match Core_kernel.List.split_n alpha bit_length with\n | p, [ l ] ->\n (p, l)\n | _ ->\n failwith \"compare: Invalid alpha\"\n in\n let%bind not_all_zeros = Boolean.any prefix in\n let%map less = Boolean.(less_or_equal && not_all_zeros) in\n { less; less_or_equal } )\n\n module Assert = struct\n let lt ~bit_length (x : Cvar.t) (y : Cvar.t) =\n match (x, y) with\n | Constant x, Constant y ->\n assert (Field.compare x y < 0) ;\n Checked.return ()\n | _ ->\n let open Checked in\n let open Let_syntax in\n let%bind { less; _ } = compare ~bit_length x y in\n Boolean.Assert.is_true less\n\n let lte ~bit_length (x : Cvar.t) (y : Cvar.t) =\n match (x, y) with\n | Constant x, Constant y ->\n assert (Field.compare x y <= 0) ;\n Checked.return ()\n | _ ->\n let open Checked in\n let open Let_syntax in\n let%bind { less_or_equal; _ } = compare ~bit_length x y in\n Boolean.Assert.is_true less_or_equal\n\n let gt ~bit_length x y = lt ~bit_length y x\n\n let gte ~bit_length x y = lte ~bit_length y x\n\n let non_zero (v : Cvar.t) =\n match v with\n | Constant v ->\n if Field.(equal zero v) then\n failwithf \"assert_non_zero: failed on constant %s\"\n (Field.to_string v) () ;\n Checked.return ()\n | _ ->\n Checked.assert_non_zero v\n\n let equal x y = Checked.assert_equal ~label:\"Checked.Assert.equal\" x y\n\n let not_equal (x : t) (y : t) =\n match (x, y) with\n | Constant x, Constant y ->\n if Field.(equal x y) then\n failwithf \"not_equal: failed on constants %s and %s\"\n (Field.to_string x) (Field.to_string y) () ;\n Checked.return ()\n | _, _ ->\n Checked.with_label \"Checked.Assert.not_equal\" (fun () ->\n non_zero (sub x y) )\n end\n\n let lt_bitstring_value =\n let module Boolean = Checked.Boolean in\n let module Expr = struct\n module Binary = struct\n type 'a t = Lit of 'a | And of 'a * 'a t | Or of 'a * 'a t\n end\n\n module Nary = struct\n type 'a t = Lit of 'a | And of 'a t list | Or of 'a t list\n\n let rec of_binary : 'a Binary.t -> 'a t = function\n | Lit x ->\n Lit x\n | And (x, And (y, t)) ->\n And [ Lit x; Lit y; of_binary t ]\n | Or (x, Or (y, t)) ->\n Or [ Lit x; Lit y; of_binary t ]\n | And (x, t) ->\n And [ Lit x; of_binary t ]\n | Or (x, t) ->\n Or [ Lit x; of_binary t ]\n\n let rec eval =\n let open Checked.Let_syntax in\n function\n | Lit x ->\n return x\n | And xs ->\n Checked.List.map xs ~f:eval >>= Boolean.all\n | Or xs ->\n Checked.List.map xs ~f:eval >>= Boolean.any\n end\n end in\n let rec lt_binary xs ys : Boolean.var Expr.Binary.t =\n match (xs, ys) with\n | [], [] ->\n Lit Boolean.false_\n | [ _x ], [ false ] ->\n Lit Boolean.false_\n | [ x ], [ true ] ->\n Lit (Boolean.not x)\n | [ x1; _x2 ], [ true; false ] ->\n Lit (Boolean.not x1)\n | [ _x1; _x2 ], [ false; false ] ->\n Lit Boolean.false_\n | x :: xs, false :: ys ->\n And (Boolean.not x, lt_binary xs ys)\n | x :: xs, true :: ys ->\n Or (Boolean.not x, lt_binary xs ys)\n | _ :: _, [] | [], _ :: _ ->\n failwith \"lt_bitstring_value: Got unequal length strings\"\n in\n fun (xs : Boolean.var Bitstring_lib.Bitstring.Msb_first.t)\n (ys : bool Bitstring_lib.Bitstring.Msb_first.t) ->\n let open Expr.Nary in\n eval\n (of_binary (lt_binary (xs :> Boolean.var list) (ys :> bool list)))\n\n let field_size_bits =\n lazy\n ( List.init Field.size_in_bits ~f:(fun i ->\n Z.testbit\n (Bignum_bigint.to_zarith_bigint Field.size)\n Stdlib.(Field.size_in_bits - 1 - i) )\n |> Bitstring_lib.Bitstring.Msb_first.of_list )\n\n let unpack_full x =\n let module Bitstring = Bitstring_lib.Bitstring in\n let open Checked.Let_syntax in\n let%bind res =\n choose_preimage_var x ~length:Field.size_in_bits\n >>| Bitstring.Lsb_first.of_list\n in\n let%map () =\n lt_bitstring_value\n (Bitstring.Msb_first.of_lsb_first res)\n (Lazy.force field_size_bits)\n >>= Checked.Boolean.Assert.is_true\n in\n res\n\n let parity ?length x =\n let open Checked in\n let unpack =\n let unpack_full x =\n unpack_full x >>| Bitstring_lib.Bitstring.Lsb_first.to_list\n in\n match length with\n | None ->\n unpack_full\n | Some length ->\n let length = Int.min length Field.size_in_bits in\n if Int.equal length Field.size_in_bits then unpack_full\n else choose_preimage_var ~length\n in\n unpack x >>| Base.List.hd_exn\n end\n end\n\n module Bitstring_checked = struct\n type t = Checked.Boolean.var list\n\n let lt_value = Field.Checked.lt_bitstring_value\n\n let chunk_for_equality (t1 : t) (t2 : t) =\n let chunk_size = Field.size_in_bits - 1 in\n let rec go acc t1 t2 =\n match (t1, t2) with\n | [], [] ->\n acc\n | _, _ ->\n let t1_a, t1_b = List.split_n t1 chunk_size in\n let t2_a, t2_b = List.split_n t2 chunk_size in\n go ((t1_a, t2_a) :: acc) t1_b t2_b\n in\n go [] t1 t2\n\n let equal t1 t2 =\n let open Checked in\n all\n (Base.List.map (chunk_for_equality t1 t2) ~f:(fun (x1, x2) ->\n equal (Cvar1.pack x1) (Cvar1.pack x2) ) )\n >>= Boolean.all\n\n let equal_expect_true t1 t2 =\n let open Checked in\n all\n (Core_kernel.List.map (chunk_for_equality t1 t2) ~f:(fun (x1, x2) ->\n (* Inlined [Field.equal], but skip creating the field element for\n this chunk if possible.\n *)\n let z = Cvar1.(pack x1 - pack x2) in\n let%bind r, inv =\n exists\n Typ.(field * field)\n ~compute:\n As_prover.(\n match\n Core_kernel.List.map2 x1 x2 ~f:(fun x1 x2 ->\n let%map x1 = read_var (x1 :> Cvar.t)\n and x2 = read_var (x2 :> Cvar.t) in\n Field.equal x1 x2 )\n with\n | Ok res ->\n let%bind res = all res in\n if Core_kernel.List.for_all ~f:Fn.id res then\n return (Field.one, Field.zero)\n else equal_vars z\n | _ ->\n equal_vars z)\n in\n let%map () = equal_constraints z inv r in\n Boolean.Unsafe.of_cvar r ) )\n >>= Boolean.all\n\n module Assert = struct\n let equal t1 t2 =\n let open Checked in\n Base.List.map (chunk_for_equality t1 t2) ~f:(fun (x1, x2) ->\n Constraint.equal (Cvar1.pack x1) (Cvar1.pack x2) )\n |> assert_all ~label:\"Bitstring.Assert.equal\"\n end\n end\n\n let%test_unit \"lt_bitstring_value\" =\n let gen =\n let open Quickcheck.Generator in\n let open Let_syntax in\n let%bind length = small_positive_int in\n let%map x = list_with_length length bool\n and y = list_with_length length bool in\n (x, y)\n in\n Quickcheck.test gen ~f:(fun (x, y) ->\n let correct_answer = [%compare: bool list] x y < 0 in\n let lt =\n run_and_check\n (Checked.map\n ~f:(As_prover.read Checked.Boolean.typ)\n (Field.Checked.lt_bitstring_value\n (Bitstring_lib.Bitstring.Msb_first.of_list\n (List.map ~f:Checked.(constant Boolean.typ) x) )\n (Bitstring_lib.Bitstring.Msb_first.of_list y) ) )\n |> Or_error.ok_exn\n in\n assert (Bool.equal lt correct_answer) )\n\n include Checked\n\n let%snarkydef_ if_ (b : Boolean.var) ~typ:(Typ typ : ('var, _) Typ.t)\n ~(then_ : 'var) ~(else_ : 'var) =\n let then_, then_aux = typ.var_to_fields then_ in\n let else_, else_aux = typ.var_to_fields else_ in\n let%bind res =\n Array.all\n (Core_kernel.Array.map2_exn then_ else_ ~f:(fun then_ else_ ->\n if_ b ~then_ ~else_ ) )\n in\n let%map res_aux =\n (* Abstraction leak.. *)\n let res_aux = ref None in\n let%map () =\n as_prover\n As_prover.(\n if%map read Boolean.typ b then res_aux := Some then_aux\n else res_aux := Some else_aux)\n in\n match !res_aux with\n | Some res_aux ->\n res_aux\n | None ->\n typ.constraint_system_auxiliary ()\n in\n typ.var_of_fields (res, res_aux)\n\n module Test = struct\n let checked_to_unchecked typ1 typ2 checked input =\n let checked_result =\n run_and_check\n (let open Let_syntax in\n let%bind input = exists typ1 ~compute:(As_prover.return input) in\n let%map result = checked input in\n As_prover.read typ2 result)\n |> Or_error.ok_exn\n in\n checked_result\n\n let test_equal (type a) ?(sexp_of_t = sexp_of_opaque) ?(equal = Caml.( = ))\n typ1 typ2 checked unchecked input =\n let checked_result = checked_to_unchecked typ1 typ2 checked input in\n let sexp_of_a = sexp_of_t in\n let compare_a x y = if equal x y then 0 else 1 in\n [%test_eq: a] checked_result (unchecked input)\n end\n\n module R1CS_constraint_system = struct\n include R1CS_constraint_system\n end\nend\n\n(** The main functor for the monadic interface. \n See [Run.Make] for the same thing but for the imperative interface. *)\nmodule Make (Backend : Backend_intf.S) = struct\n module Backend_extended = Backend_extended.Make (Backend)\n module Runner0 = Runner.Make (Backend_extended)\n module Checked_runner = Runner0.Checked_runner\n module Checked1 = Checked.Make (Backend.Field) (Checked_runner) (As_prover0)\n\n module Field_T = struct\n type field = Backend_extended.Field.t\n end\n\n module As_prover_ext = As_prover0.Make_extended (Field_T) (As_prover0)\n\n module Ref :\n As_prover_ref.S\n with module Types = Checked1.Types\n and type ('a, 'f) checked := ('a, 'f) Checked1.t\n and type 'f field := Backend_extended.Field.t =\n As_prover_ref.Make (Checked1) (As_prover0)\n\n module Checked_for_basic = struct\n include (\n Checked1 :\n Checked_intf.S\n with module Types = Checked1.Types\n with type ('a, 'f) t := ('a, 'f) Checked1.t\n and type 'f field := Backend_extended.Field.t )\n\n type field = Backend_extended.Field.t\n\n type 'a t = ('a, field) Types.Checked.t\n\n let run = Runner0.run\n end\n\n module Basic =\n Make_basic (Backend_extended) (Checked_for_basic) (As_prover_ext) (Ref)\n (Runner0)\n include Basic\n module Number = Number.Make (Basic)\n module Enumerable = Enumerable.Make (Basic)\nend\n\nmodule Typ0 = Typ\n\nmodule Run = struct\n let functor_counter = ref 0\n\n let active_counters = ref []\n\n let is_active_functor_id num =\n match !active_counters with\n | [] ->\n (* Show the usual error, the functor isn't wrong as far as we can tell.\n *)\n true\n | active :: _ ->\n Int.equal active num\n\n let active_functor_id () = List.hd_exn !active_counters\n\n module Make_basic (Backend : Backend_intf.S) = struct\n module Snark = Make (Backend)\n open Run_state\n open Snark\n\n let set_constraint_logger = set_constraint_logger\n\n let clear_constraint_logger = clear_constraint_logger\n\n let this_functor_id = incr functor_counter ; !functor_counter\n\n let state =\n ref\n (Run_state.make ~input:(field_vec ()) ~aux:(field_vec ())\n ~eval_constraints:false ~num_inputs:0 ~next_auxiliary:(ref 0)\n ~with_witness:false ~stack:[] ~is_running:false () )\n\n let dump () = Run_state.dump !state\n\n let in_prover () : bool = Run_state.has_witness !state\n\n let in_checked_computation () : bool =\n is_active_functor_id this_functor_id && Run_state.is_running !state\n\n let run (checked : _ Checked.t) =\n match checked with\n | Pure a ->\n a\n | _ ->\n if not (is_active_functor_id this_functor_id) then\n failwithf\n \"Could not run this function.\\n\\n\\\n Hint: The module used to create this function had internal ID \\\n %i, but the module used to run it had internal ID %i. The same \\\n instance of Snarky.Snark.Run.Make must be used for both.\"\n this_functor_id (active_functor_id ()) ()\n else if not (Run_state.is_running !state) then\n failwith\n \"This function can't be run outside of a checked computation.\" ;\n let state', x = Runner.run checked !state in\n state := state' ;\n x\n\n let as_stateful x state' =\n state := state' ;\n let a = x () in\n (!state, a)\n\n let make_checked (type a) (f : unit -> a) : _ Checked.t =\n let g : run_state -> run_state * a = as_stateful f in\n Function g\n\n module R1CS_constraint_system = Snark.R1CS_constraint_system\n\n type field = Snark.field\n\n module Bigint = Snark.Bigint\n module Constraint = Snark.Constraint\n\n module Typ = struct\n open Snark.Typ\n\n type nonrec ('var, 'value) t = ('var, 'value) t\n\n let unit = unit\n\n let field = field\n\n let tuple2 = tuple2\n\n let ( * ) = ( * )\n\n let tuple3 = tuple3\n\n let list = list\n\n let array = array\n\n let hlist = hlist\n\n let transport = transport\n\n let transport_var = transport_var\n\n let of_hlistable = of_hlistable\n\n module Internal = Internal\n end\n\n let constant (Typ typ : _ Typ.t) x =\n let fields, aux = typ.value_to_fields x in\n let field_vars = Core_kernel.Array.map ~f:Cvar.constant fields in\n typ.var_of_fields (field_vars, aux)\n\n module Boolean = struct\n open Snark.Boolean\n\n type nonrec var = var\n\n type value = bool\n\n let true_ = true_\n\n let false_ = false_\n\n let if_ b ~then_ ~else_ = run (if_ b ~then_ ~else_)\n\n let not = not\n\n let ( && ) x y = run (x && y)\n\n let ( &&& ) = ( && )\n\n let ( || ) x y = run (x || y)\n\n let ( ||| ) = ( || )\n\n let ( lxor ) x y = run (x lxor y)\n\n let any l = run (any l)\n\n let all l = run (all l)\n\n let of_field x = run (of_field x)\n\n let var_of_value = var_of_value\n\n let typ = typ\n\n let typ_unchecked = typ_unchecked\n\n let equal x y = run (equal x y)\n\n module Expr = struct\n open Snark.Boolean.Expr\n\n type nonrec t = t\n\n let ( ! ) = ( ! )\n\n let ( && ) = ( && )\n\n let ( &&& ) = ( && )\n\n let ( || ) = ( || )\n\n let ( ||| ) = ( ||| )\n\n let any = any\n\n let all = all\n\n let not = not\n\n let eval x = run (eval x)\n\n let assert_ x = run (assert_ x)\n end\n\n module Unsafe = Unsafe\n\n module Assert = struct\n open Snark.Boolean.Assert\n\n let ( = ) x y = run (x = y)\n\n let is_true x = run (is_true x)\n\n let any l = run (any l)\n\n let all l = run (all l)\n\n let exactly_one l = run (exactly_one l)\n end\n\n module Array = struct\n open Snark.Boolean.Array\n\n let any x = run (any x)\n\n let all x = run (all x)\n\n module Assert = struct\n let any x = run (Assert.any x)\n\n let all x = run (Assert.all x)\n end\n end\n end\n\n module Field = struct\n open Snark.Field\n\n let size_in_bits = size_in_bits\n\n let size = size\n\n module Constant = struct\n type t = Snark.Field.t [@@deriving bin_io, sexp, hash, compare, eq]\n\n let gen = gen\n\n let gen_uniform = gen_uniform\n\n module T = struct\n let bin_shape_t = bin_shape_t\n\n let bin_writer_t = bin_writer_t\n\n let bin_write_t = bin_write_t\n\n let bin_size_t = bin_size_t\n\n let bin_reader_t = bin_reader_t\n\n let __bin_read_t__ = __bin_read_t__\n\n let bin_read_t = bin_read_t\n\n let bin_t = bin_t\n\n let sexp_of_t = sexp_of_t\n\n let t_of_sexp = t_of_sexp\n\n let of_int = of_int\n\n let one = one\n\n let zero = zero\n\n let add = add\n\n let sub = sub\n\n let mul = mul\n\n let inv = inv\n\n let square = square\n\n let sqrt = sqrt\n\n let is_square = is_square\n\n let equal = equal\n\n let size_in_bits = size_in_bits\n\n let print = print\n\n let to_string = to_string\n\n let random = random\n\n module Vector = Vector\n\n let negate = negate\n\n let ( + ) = ( + )\n\n let ( - ) = ( - )\n\n let ( * ) = ( * )\n\n let ( / ) = ( / )\n\n let of_string = of_string\n\n let to_string = to_string\n\n let unpack = unpack\n\n let project = project\n\n let parity = parity\n end\n\n include T\n end\n\n open Snark.Field.Var\n\n type nonrec t = t\n\n let length = length\n\n let var_indices = var_indices\n\n let to_constant_and_terms = to_constant_and_terms\n\n let constant = constant\n\n let to_constant = to_constant\n\n let linear_combination = linear_combination\n\n let sum = sum\n\n let add = add\n\n let negate = negate\n\n let sub = sub\n\n let scale = scale\n\n let project = project\n\n let pack = pack\n\n (* New definitions *)\n\n let of_int i = constant (Constant.of_int i)\n\n let one = constant Constant.one\n\n let zero = constant Constant.zero\n\n open Snark.Field.Checked\n\n let mul x y = run (mul x y)\n\n let square x = run (square x)\n\n let div x y = run (div x y)\n\n let inv x = run (inv x)\n\n let is_square x = run (is_square x)\n\n let sqrt x = run (sqrt x)\n\n let sqrt_check x = run (sqrt_check x)\n\n let equal x y = run (equal x y)\n\n let unpack x ~length = run (unpack x ~length)\n\n let unpack_flagged x ~length = run (unpack_flagged x ~length)\n\n let unpack_full x = run (unpack_full x)\n\n let parity ?length x = run (parity ?length x)\n\n let choose_preimage_var x ~length = run (choose_preimage_var x ~length)\n\n type nonrec comparison_result = comparison_result =\n { less : Boolean.var; less_or_equal : Boolean.var }\n\n let compare ~bit_length x y = run (compare ~bit_length x y)\n\n let if_ b ~then_ ~else_ = run (if_ b ~then_ ~else_)\n\n let ( + ) = add\n\n let ( - ) = sub\n\n let ( * ) = mul\n\n let ( / ) = div\n\n module Unsafe = Unsafe\n\n module Assert = struct\n open Snark.Field.Checked.Assert\n\n let lte ~bit_length x y = run (lte ~bit_length x y)\n\n let gte ~bit_length x y = run (gte ~bit_length x y)\n\n let lt ~bit_length x y = run (lt ~bit_length x y)\n\n let gt ~bit_length x y = run (gt ~bit_length x y)\n\n let not_equal x y = run (not_equal x y)\n\n let equal x y = run (equal x y)\n\n let non_zero x = run (non_zero x)\n end\n\n let typ = typ\n end\n\n module Proof_inputs = Proof_inputs\n\n module Bitstring_checked = struct\n open Snark.Bitstring_checked\n\n type nonrec t = t\n\n let equal x y = run (equal x y)\n\n let equal_expect_true x y = run (equal_expect_true x y)\n\n let lt_value x y = run (lt_value x y)\n\n module Assert = struct\n open Snark.Bitstring_checked.Assert\n\n let equal x y = run (equal x y)\n end\n end\n\n module As_prover = struct\n type 'a t = 'a\n\n type 'a as_prover = 'a t\n\n let eval_as_prover f =\n if Run_state.as_prover !state && Run_state.has_witness !state then\n let a = f (Runner.get_value !state) in\n a\n else failwith \"Can't evaluate prover code outside an as_prover block\"\n\n let in_prover_block () = Run_state.as_prover !state\n\n let read_var var = eval_as_prover (As_prover.read_var var)\n\n let read typ var = eval_as_prover (As_prover.read typ var)\n\n include Field.Constant.T\n\n module Ref = struct\n type 'a t = 'a As_prover_ref.t\n\n let create f = run As_prover.(Ref.create (map (return ()) ~f))\n\n let get r = eval_as_prover (As_prover.Ref.get r)\n\n let set r x = eval_as_prover (As_prover.Ref.set r x)\n end\n\n let run_prover f _tbl =\n (* Allow for nesting of prover blocks, by caching the current value and\n restoring it once we're done.\n *)\n let old = Run_state.as_prover !state in\n Run_state.set_as_prover !state true ;\n let a = f () in\n Run_state.set_as_prover !state old ;\n a\n end\n\n module Handle = struct\n type ('var, 'value) t = ('var, 'value) Handle.t\n\n let value handle () = As_prover.eval_as_prover (Handle.value handle)\n\n let var = Handle.var\n end\n\n let mark_active ~f =\n let counters = !active_counters in\n active_counters := this_functor_id :: counters ;\n try\n let ret = f () in\n active_counters := counters ;\n ret\n with exn ->\n active_counters := counters ;\n raise exn\n\n let mark_active_deferred (type a ma) ~(map : ma -> f:(a -> a) -> ma) ~f =\n let counters = !active_counters in\n active_counters := this_functor_id :: counters ;\n try\n map (f ()) ~f:(fun (ret : a) ->\n active_counters := counters ;\n ret )\n with exn ->\n active_counters := counters ;\n raise exn\n\n let assert_ ?label c = run (assert_ ?label c)\n\n let assert_all ?label c = run (assert_all ?label c)\n\n let assert_r1cs ?label a b c = run (assert_r1cs ?label a b c)\n\n let assert_square ?label x y = run (assert_square ?label x y)\n\n let as_prover p = run (as_prover (As_prover.run_prover p))\n\n let next_auxiliary () = run (next_auxiliary ())\n\n let request_witness typ p =\n run (request_witness typ (As_prover.run_prover p))\n\n let perform p = run (perform (As_prover.run_prover p))\n\n let request ?such_that typ r =\n match such_that with\n | None ->\n request_witness typ (fun () -> r)\n | Some such_that ->\n let x = request_witness typ (fun () -> r) in\n such_that x ; x\n\n let exists ?request ?compute typ =\n let request = Option.map request ~f:As_prover.run_prover in\n let compute = Option.map compute ~f:As_prover.run_prover in\n run (exists ?request ?compute typ)\n\n let exists_handle ?request ?compute typ =\n let request = Option.map request ~f:As_prover.run_prover in\n let compute = Option.map compute ~f:As_prover.run_prover in\n run (exists_handle ?request ?compute typ)\n\n type nonrec response = response\n\n let unhandled = unhandled\n\n type request = Request.request =\n | With :\n { request : 'a Request.t\n ; respond : 'a Request.Response.t -> response\n }\n -> request\n\n module Handler = Handler\n\n let handle x h =\n let h = Request.Handler.create_single h in\n let handler = Run_state.handler !state in\n state := Run_state.set_handler !state (Request.Handler.push handler h) ;\n let a = x () in\n state := Run_state.set_handler !state handler ;\n a\n\n let handle_as_prover x h =\n let h = h () in\n handle x h\n\n let if_ b ~typ ~then_ ~else_ = run (if_ b ~typ ~then_ ~else_)\n\n let with_label lbl x =\n let stack = Run_state.stack !state in\n let log_constraint = Run_state.log_constraint !state in\n state := Run_state.set_stack !state (lbl :: stack) ;\n Option.iter log_constraint ~f:(fun f ->\n f ~at_label_boundary:(`Start, lbl) None ) ;\n let a = x () in\n Option.iter log_constraint ~f:(fun f ->\n f ~at_label_boundary:(`End, lbl) None ) ;\n state := Run_state.set_stack !state stack ;\n a\n\n let inject_wrapper :\n type r_var input_var.\n f:(r_var -> r_var) -> (input_var -> r_var) -> input_var -> r_var =\n fun ~f x a ->\n let inject_wrapper ~f x = f x in\n inject_wrapper ~f (x a)\n\n (** Caches the global [state] before running [f]. \n It is expected that [f] will reset the global state for its own use only, \n hence why we need to reset it after running [f].*)\n let finalize_is_running f =\n let cached_state = !state in\n let x =\n match f () with\n | exception e ->\n (* Warning: it is important to clean the global state before reraising the exception.\n Imagine if a user of snarky catches exceptions instead of letting the program panic,\n then the next usage of snarky might be messed up. *)\n state := cached_state ;\n raise e\n | x ->\n x\n in\n state := cached_state ;\n x\n\n let constraint_system ~input_typ ~return_typ x : R1CS_constraint_system.t =\n finalize_is_running (fun () ->\n let x = inject_wrapper x ~f:(fun x () -> mark_active ~f:x) in\n Perform.constraint_system ~run:as_stateful ~input_typ ~return_typ x )\n\n let generate_public_input t x : As_prover.Vector.t =\n finalize_is_running (fun () -> generate_public_input t x)\n\n let generate_witness ~input_typ ~return_typ x a : Proof_inputs.t =\n finalize_is_running (fun () ->\n let x = inject_wrapper x ~f:(fun x () -> mark_active ~f:x) in\n Perform.generate_witness ~run:as_stateful ~input_typ ~return_typ x a )\n\n let generate_witness_conv (type out)\n ~(f : Proof_inputs.t -> 'r_value -> out) ~input_typ ~return_typ x input\n : out =\n finalize_is_running (fun () ->\n let x = inject_wrapper x ~f:(fun x () -> mark_active ~f:x) in\n Perform.generate_witness_conv ~run:as_stateful ~f ~input_typ\n ~return_typ x input )\n\n let run_unchecked x =\n finalize_is_running (fun () ->\n Perform.run_unchecked ~run:as_stateful (fun () -> mark_active ~f:x) )\n\n let run_and_check_exn (type a) (x : unit -> (unit -> a) As_prover.t) : a =\n finalize_is_running (fun () ->\n let res =\n Perform.run_and_check_exn ~run:as_stateful (fun () ->\n mark_active ~f:(fun () ->\n let prover_block = x () in\n Run_state.set_as_prover !state true ;\n As_prover.run_prover prover_block ) )\n in\n Run_state.set_as_prover !state true ;\n res )\n\n let run_and_check (type a) (x : unit -> (unit -> a) As_prover.t) :\n a Or_error.t =\n finalize_is_running (fun () ->\n let res =\n Perform.run_and_check ~run:as_stateful (fun () ->\n mark_active ~f:(fun () ->\n let prover_block = x () in\n Run_state.set_as_prover !state true ;\n As_prover.run_prover prover_block ) )\n in\n Run_state.set_as_prover !state true ;\n res )\n\n module Run_and_check_deferred (M : sig\n type _ t\n\n val return : 'a -> 'a t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n end) =\n struct\n open M\n\n let run_and_check_exn ~run t =\n map (run_and_check_deferred_exn' ~run t ~map) ~f:(fun (x, get_value) ->\n let x = Basic.As_prover.run x get_value in\n x )\n\n let run_and_check ~run t =\n map\n (run_and_check_deferred' ~run t ~map ~return)\n ~f:\n (Or_error.map ~f:(fun (x, get_value) ->\n let x = Basic.As_prover.run x get_value in\n x ) )\n\n let as_stateful x state' =\n state := state' ;\n map (x ()) ~f:(fun a -> (!state, a))\n\n let run_and_check_exn (type a) (x : unit -> (unit -> a) As_prover.t M.t) :\n a M.t =\n finalize_is_running (fun () ->\n let mark_active = mark_active_deferred ~map in\n let res =\n run_and_check_exn ~run:as_stateful (fun () ->\n mark_active ~f:(fun () ->\n map (x ()) ~f:(fun prover_block ->\n Run_state.set_as_prover !state true ;\n As_prover.run_prover prover_block ) ) )\n in\n Run_state.set_as_prover !state true ;\n res )\n\n let run_and_check (type a) (x : unit -> (unit -> a) As_prover.t M.t) :\n a Or_error.t M.t =\n finalize_is_running (fun () ->\n let mark_active = mark_active_deferred ~map in\n let res =\n run_and_check ~run:as_stateful (fun () ->\n mark_active ~f:(fun () ->\n map (x ()) ~f:(fun prover_block ->\n Run_state.set_as_prover !state true ;\n As_prover.run_prover prover_block ) ) )\n in\n Run_state.set_as_prover !state true ;\n res )\n end\n\n let check_exn x : unit =\n finalize_is_running (fun () -> Perform.check_exn ~run:as_stateful x)\n\n let check x : unit Or_error.t =\n finalize_is_running (fun () -> Perform.check ~run:as_stateful x)\n\n let constraint_count ?(weight = Fn.const 1) ?log x =\n let count = ref 0 in\n let log_constraint ?at_label_boundary c =\n ( match at_label_boundary with\n | None ->\n ()\n | Some (pos, lab) ->\n Option.iter log ~f:(fun f ->\n let start =\n Some (match pos with `Start -> true | _ -> false)\n in\n f ?start lab !count ) ) ;\n count := !count + Option.value_map ~default:0 ~f:weight c\n in\n (* TODO(mrmr1993): Enable label-level logging for the imperative API. *)\n let old = !state in\n state :=\n Runner.State.make ~num_inputs:0 ~input:Vector.null ~aux:Vector.null\n ~next_auxiliary:(ref 0) ~eval_constraints:false ~with_witness:false\n ~log_constraint () ;\n ignore (mark_active ~f:x) ;\n state := old ;\n !count\n\n module Internal_Basic = Snark\n\n let run_checked = run\n end\n\n module Make (Backend : Backend_intf.S) = struct\n module Basic = Make_basic (Backend)\n include Basic\n module Number = Number.Run.Make (Basic)\n module Enumerable = Enumerable.Run.Make (Basic)\n end\nend\n\ntype 'field m = (module Snark_intf.Run with type field = 'field)\n\nlet make (type field) (module Backend : Backend_intf.S with type Field.t = field)\n : field m =\n (module Run.Make (Backend))\n","type bigstring =\n (char, Bigarray.int8_unsigned_elt, Bigarray.c_layout) Bigarray.Array1.t\n\ntype t = bigstring\n\nlet create size = Bigarray.(Array1.create char c_layout size)\nlet empty = create 0\n\nmodule BA1 = Bigarray.Array1\n\nlet length t = BA1.dim t\n\nexternal get : t -> int -> char = \"%caml_ba_ref_1\"\nexternal set : t -> int -> char -> unit = \"%caml_ba_set_1\"\n\nexternal unsafe_get : t -> int -> char = \"%caml_ba_unsafe_ref_1\"\nexternal unsafe_set : t -> int -> char -> unit = \"%caml_ba_unsafe_set_1\"\n\nexternal unsafe_blit : t -> src_off:int -> t -> dst_off:int -> len:int -> unit =\n \"bigstringaf_blit_to_bigstring\" [@@noalloc]\n\nexternal unsafe_blit_to_bytes : t -> src_off:int -> Bytes.t -> dst_off:int -> len:int -> unit =\n \"bigstringaf_blit_to_bytes\" [@@noalloc]\n\nexternal unsafe_blit_from_bytes : Bytes.t -> src_off:int -> t -> dst_off:int -> len:int -> unit =\n \"bigstringaf_blit_from_bytes\" [@@noalloc]\n\nexternal unsafe_blit_from_string : string -> src_off:int -> t -> dst_off:int -> len:int -> unit =\n \"bigstringaf_blit_from_bytes\" [@@noalloc]\n\nexternal unsafe_memcmp : t -> int -> t -> int -> int -> int =\n \"bigstringaf_memcmp_bigstring\" [@@noalloc]\n\nexternal unsafe_memcmp_string : t -> int -> string -> int -> int -> int =\n \"bigstringaf_memcmp_string\" [@@noalloc]\n\nlet sub t ~off ~len =\n BA1.sub t off len\n\nlet[@inline never] invalid_bounds op buffer_len off len =\n let message =\n Printf.sprintf \"Bigstringaf.%s invalid range: { buffer_len: %d, off: %d, len: %d }\"\n op buffer_len off len\n in\n raise (Invalid_argument message)\n;;\n\nlet[@inline never] invalid_bounds_blit op src_len src_off dst_len dst_off len =\n let message =\n Printf.sprintf \"Bigstringaf.%s invalid range: { src_len: %d, src_off: %d, dst_len: %d, dst_off: %d, len: %d }\"\n op src_len src_off dst_len dst_off len\n in\n raise (Invalid_argument message)\n;;\n\nlet[@inline never] invalid_bounds_memcmp op buf1_len buf1_off buf2_len buf2_off len =\n let message =\n Printf.sprintf \"Bigstringaf.%s invalid range: { buf1_len: %d, buf1_off: %d, buf2_len: %d, buf2_off: %d, len: %d }\"\n op buf1_len buf1_off buf2_len buf2_off len\n in\n raise (Invalid_argument message)\n;;\n\n(* A note on bounds checking.\n *\n * The code should perform the following check to ensure that the blit doesn't\n * run off the end of the input buffer:\n *\n * {[off + len <= buffer_len]}\n *\n * However, this may lead to an interger overflow for large values of [off],\n * e.g., [max_int], which will cause the comparison to return [true] when it\n * should really return [false].\n *\n * An equivalent comparison that does not run into this integer overflow\n * problem is:\n *\n * {[buffer_len - off => len]}\n *\n * This is checking that the input buffer, less the offset, is sufficiently\n * long to perform the blit. Since the expression is subtracting [off] rather\n * than adding it, it doesn't suffer from the overflow that the previous\n * inequality did. As long as there is check to ensure that [off] is not\n * negative, it won't underflow either. *)\n\nlet copy t ~off ~len =\n let buffer_len = length t in\n if len < 0 || off < 0 || buffer_len - off < len\n then invalid_bounds \"copy\" buffer_len off len;\n let dst = create len in\n unsafe_blit t ~src_off:off dst ~dst_off:0 ~len;\n dst\n;;\n\nlet substring t ~off ~len =\n let buffer_len = length t in\n if len < 0 || off < 0 || buffer_len - off < len\n then invalid_bounds \"substring\" buffer_len off len;\n let b = Bytes.create len in\n unsafe_blit_to_bytes t ~src_off:off b ~dst_off:0 ~len;\n Bytes.unsafe_to_string b\n;;\n\nlet to_string t =\n let len = length t in\n let b = Bytes.create len in\n unsafe_blit_to_bytes t ~src_off:0 b ~dst_off:0 ~len;\n Bytes.unsafe_to_string b\n;;\n\nlet of_string ~off ~len s =\n let buffer_len = String.length s in\n if len < 0 || off < 0 || buffer_len - off < len\n then invalid_bounds \"of_string\" buffer_len off len;\n let b = create len in\n unsafe_blit_from_string s ~src_off:off b ~dst_off:0 ~len;\n b\n;;\n\nlet blit src ~src_off dst ~dst_off ~len =\n let src_len = length src in\n let dst_len = length dst in\n if len < 0\n then invalid_bounds_blit \"blit\" src_len src_off dst_len dst_off len;\n if src_off < 0 || src_len - src_off < len\n then invalid_bounds_blit \"blit\" src_len src_off dst_len dst_off len;\n if dst_off < 0 || dst_len - dst_off < len\n then invalid_bounds_blit \"blit\" src_len src_off dst_len dst_off len;\n unsafe_blit src ~src_off dst ~dst_off ~len\n;;\n\nlet blit_from_string src ~src_off dst ~dst_off ~len =\n let src_len = String.length src in\n let dst_len = length dst in\n if len < 0\n then invalid_bounds_blit \"blit_from_string\" src_len src_off dst_len dst_off len;\n if src_off < 0 || src_len - src_off < len\n then invalid_bounds_blit \"blit_from_string\" src_len src_off dst_len dst_off len;\n if dst_off < 0 || dst_len - dst_off < len\n then invalid_bounds_blit \"blit_from_string\" src_len src_off dst_len dst_off len;\n unsafe_blit_from_string src ~src_off dst ~dst_off ~len\n;;\n\nlet blit_from_bytes src ~src_off dst ~dst_off ~len =\n let src_len = Bytes.length src in\n let dst_len = length dst in\n if len < 0\n then invalid_bounds_blit \"blit_from_bytes\" src_len src_off dst_len dst_off len;\n if src_off < 0 || src_len - src_off < len\n then invalid_bounds_blit \"blit_from_bytes\" src_len src_off dst_len dst_off len;\n if dst_off < 0 || dst_len - dst_off < len\n then invalid_bounds_blit \"blit_from_bytes\" src_len src_off dst_len dst_off len;\n unsafe_blit_from_bytes src ~src_off dst ~dst_off ~len\n;;\n\nlet blit_to_bytes src ~src_off dst ~dst_off ~len =\n let src_len = length src in\n let dst_len = Bytes.length dst in\n if len < 0\n then invalid_bounds_blit \"blit_to_bytes\" src_len src_off dst_len dst_off len;\n if src_off < 0 || src_len - src_off < len\n then invalid_bounds_blit \"blit_to_bytes\" src_len src_off dst_len dst_off len;\n if dst_off < 0 || dst_len - dst_off < len\n then invalid_bounds_blit \"blit_to_bytes\" src_len src_off dst_len dst_off len;\n unsafe_blit_to_bytes src ~src_off dst ~dst_off ~len\n;;\n\nlet memcmp buf1 buf1_off buf2 buf2_off len =\n let buf1_len = length buf1 in\n let buf2_len = length buf2 in\n if len < 0\n then invalid_bounds_memcmp \"memcmp\" buf1_len buf1_off buf2_len buf2_off len;\n if buf1_off < 0 || buf1_len - buf1_off < len\n then invalid_bounds_memcmp \"memcmp\" buf1_len buf1_off buf2_len buf2_off len;\n if buf2_off < 0 || buf2_len - buf2_off < len\n then invalid_bounds_memcmp \"memcmp\" buf1_len buf1_off buf2_len buf2_off len;\n unsafe_memcmp buf1 buf1_off buf2 buf2_off len\n;;\n\nlet memcmp_string buf1 buf1_off buf2 buf2_off len =\n let buf1_len = length buf1 in\n let buf2_len = String.length buf2 in\n if len < 0\n then invalid_bounds_memcmp \"memcmp_string\" buf1_len buf1_off buf2_len buf2_off len;\n if buf1_off < 0 || buf1_len - buf1_off < len\n then invalid_bounds_memcmp \"memcmp_string\" buf1_len buf1_off buf2_len buf2_off len;\n if buf2_off < 0 || buf2_len - buf2_off < len\n then invalid_bounds_memcmp \"memcmp_string\" buf1_len buf1_off buf2_len buf2_off len;\n unsafe_memcmp_string buf1 buf1_off buf2 buf2_off len\n;;\n\n\n(* Safe operations *)\n\nexternal caml_bigstring_set_16 : bigstring -> int -> int -> unit = \"%caml_bigstring_set16\"\nexternal caml_bigstring_set_32 : bigstring -> int -> int32 -> unit = \"%caml_bigstring_set32\"\nexternal caml_bigstring_set_64 : bigstring -> int -> int64 -> unit = \"%caml_bigstring_set64\"\n\nexternal caml_bigstring_get_16 : bigstring -> int -> int = \"%caml_bigstring_get16\"\nexternal caml_bigstring_get_32 : bigstring -> int -> int32 = \"%caml_bigstring_get32\"\nexternal caml_bigstring_get_64 : bigstring -> int -> int64 = \"%caml_bigstring_get64\"\n\nmodule Swap = struct\n external bswap16 : int -> int = \"%bswap16\"\n external bswap_int32 : int32 -> int32 = \"%bswap_int32\"\n external bswap_int64 : int64 -> int64 = \"%bswap_int64\"\n\n let caml_bigstring_set_16 bs off i =\n caml_bigstring_set_16 bs off (bswap16 i)\n\n let caml_bigstring_set_32 bs off i =\n caml_bigstring_set_32 bs off (bswap_int32 i)\n\n let caml_bigstring_set_64 bs off i =\n caml_bigstring_set_64 bs off (bswap_int64 i)\n\n let caml_bigstring_get_16 bs off =\n bswap16 (caml_bigstring_get_16 bs off)\n\n let caml_bigstring_get_32 bs off =\n bswap_int32 (caml_bigstring_get_32 bs off)\n\n let caml_bigstring_get_64 bs off =\n bswap_int64 (caml_bigstring_get_64 bs off)\n\n let get_int16_sign_extended x off =\n ((caml_bigstring_get_16 x off) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\nend\n\nlet set_int16_le, set_int16_be =\n if Sys.big_endian\n then Swap.caml_bigstring_set_16, caml_bigstring_set_16\n else caml_bigstring_set_16 , Swap.caml_bigstring_set_16\n\nlet set_int32_le, set_int32_be =\n if Sys.big_endian\n then Swap.caml_bigstring_set_32, caml_bigstring_set_32\n else caml_bigstring_set_32 , Swap.caml_bigstring_set_32\n\nlet set_int64_le, set_int64_be =\n if Sys.big_endian\n then Swap.caml_bigstring_set_64, caml_bigstring_set_64\n else caml_bigstring_set_64 , Swap.caml_bigstring_set_64\n\nlet get_int16_le, get_int16_be =\n if Sys.big_endian\n then Swap.caml_bigstring_get_16, caml_bigstring_get_16\n else caml_bigstring_get_16 , Swap.caml_bigstring_get_16\n\nlet get_int16_sign_extended_noswap x off =\n ((caml_bigstring_get_16 x off) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int16_sign_extended_le, get_int16_sign_extended_be =\n if Sys.big_endian\n then Swap.get_int16_sign_extended , get_int16_sign_extended_noswap\n else get_int16_sign_extended_noswap, Swap.get_int16_sign_extended\n\nlet get_int32_le, get_int32_be =\n if Sys.big_endian\n then Swap.caml_bigstring_get_32, caml_bigstring_get_32\n else caml_bigstring_get_32 , Swap.caml_bigstring_get_32\n\nlet get_int64_le, get_int64_be =\n if Sys.big_endian\n then Swap.caml_bigstring_get_64, caml_bigstring_get_64\n else caml_bigstring_get_64 , Swap.caml_bigstring_get_64\n\n(* Unsafe operations *)\n\nexternal caml_bigstring_unsafe_set_16 : bigstring -> int -> int -> unit = \"%caml_bigstring_set16u\"\nexternal caml_bigstring_unsafe_set_32 : bigstring -> int -> int32 -> unit = \"%caml_bigstring_set32u\"\nexternal caml_bigstring_unsafe_set_64 : bigstring -> int -> int64 -> unit = \"%caml_bigstring_set64u\"\n\nexternal caml_bigstring_unsafe_get_16 : bigstring -> int -> int = \"%caml_bigstring_get16u\"\nexternal caml_bigstring_unsafe_get_32 : bigstring -> int -> int32 = \"%caml_bigstring_get32u\"\nexternal caml_bigstring_unsafe_get_64 : bigstring -> int -> int64 = \"%caml_bigstring_get64u\"\n\nmodule USwap = struct\n external bswap16 : int -> int = \"%bswap16\"\n external bswap_int32 : int32 -> int32 = \"%bswap_int32\"\n external bswap_int64 : int64 -> int64 = \"%bswap_int64\"\n\n let caml_bigstring_unsafe_set_16 bs off i =\n caml_bigstring_unsafe_set_16 bs off (bswap16 i)\n\n let caml_bigstring_unsafe_set_32 bs off i =\n caml_bigstring_unsafe_set_32 bs off (bswap_int32 i)\n\n let caml_bigstring_unsafe_set_64 bs off i =\n caml_bigstring_unsafe_set_64 bs off (bswap_int64 i)\n\n let caml_bigstring_unsafe_get_16 bs off =\n bswap16 (caml_bigstring_unsafe_get_16 bs off)\n\n let caml_bigstring_unsafe_get_32 bs off =\n bswap_int32 (caml_bigstring_unsafe_get_32 bs off)\n\n let caml_bigstring_unsafe_get_64 bs off =\n bswap_int64 (caml_bigstring_unsafe_get_64 bs off)\nend\n\nlet unsafe_set_int16_le, unsafe_set_int16_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_set_16, caml_bigstring_unsafe_set_16\n else caml_bigstring_unsafe_set_16 , USwap.caml_bigstring_unsafe_set_16\n\nlet unsafe_set_int32_le, unsafe_set_int32_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_set_32, caml_bigstring_unsafe_set_32\n else caml_bigstring_unsafe_set_32 , USwap.caml_bigstring_unsafe_set_32\n\nlet unsafe_set_int64_le, unsafe_set_int64_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_set_64, caml_bigstring_unsafe_set_64\n else caml_bigstring_unsafe_set_64 , USwap.caml_bigstring_unsafe_set_64\n\nlet unsafe_get_int16_le, unsafe_get_int16_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_get_16, caml_bigstring_unsafe_get_16\n else caml_bigstring_unsafe_get_16 , USwap.caml_bigstring_unsafe_get_16\n\nlet unsafe_get_int16_sign_extended_le x off =\n ((unsafe_get_int16_le x off) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet unsafe_get_int16_sign_extended_be x off =\n ((unsafe_get_int16_be x off ) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet unsafe_get_int32_le, unsafe_get_int32_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_get_32, caml_bigstring_unsafe_get_32\n else caml_bigstring_unsafe_get_32 , USwap.caml_bigstring_unsafe_get_32\n\nlet unsafe_get_int64_le, unsafe_get_int64_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_get_64, caml_bigstring_unsafe_get_64\n else caml_bigstring_unsafe_get_64 , USwap.caml_bigstring_unsafe_get_64\n","open Core_kernel\n\nmodule type Field_intf = sig\n type t\n\n val size_in_bits : int\n\n val negate : t -> t\n\n val ( - ) : t -> t -> t\n\n val ( + ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n\n val ( / ) : t -> t -> t\n\n val inv : t -> t\n\n val zero : t\n\n val one : t\n\n val of_int : int -> t\nend\n\nlet two_to_the (type f) (module F : Field_intf with type t = f) =\n let rec two_to_the n =\n if n = 0 then F.one\n else\n let r = two_to_the (n - 1) in\n F.(r + r)\n in\n two_to_the\n\n(* Our custom constraints let us efficiently compute\n\n f = fun (g, t) -> (2 * t + 1 + 2^len(t)) g\n\n We want to compute\n\n f' = fun (g, s) -> s * g\n\n Let n be the field size in bits.\n\n For a scalar s, let t = (s - 2^n - 1)/2.\n t can be represented with an n bit string.\n\n Then\n\n f (g, t)\n = (2 t + 2^n + 1) * g\n = (2 (s - 2^n - 1)/2 + 2^n + 1) * g\n = (s - 2^n - 1 + 2^n + 1) * g\n = s * g\n = f' (g, s)\n\n as desired.\n*)\n\nmodule type S = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type 'f t [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n\n val typ :\n ('a, 'b, 'f) Snarky_backendless.Typ.t\n -> ('a t, 'b t, 'f) Snarky_backendless.Typ.t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n module Shift : sig\n type _ t\n\n val create : (module Field_intf with type t = 'f) -> 'f t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n end\n\n val of_field :\n (module Field_intf with type t = 'f) -> shift:'f Shift.t -> 'f -> 'f t\n\n val to_field :\n (module Field_intf with type t = 'f) -> shift:'f Shift.t -> 'f t -> 'f\n\n val equal : ('f, 'res) Sigs.rel2 -> ('f t, 'res) Sigs.rel2\nend\n\n[@@@warning \"-4\"]\n\nmodule Type1 = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'f t = Shifted_value of 'f\n [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n\n let typ f =\n let there (Shifted_value x) = x in\n let back x = Shifted_value x in\n Snarky_backendless.Typ.(\n transport_var (transport f ~there ~back) ~there ~back)\n\n let map (Shifted_value x) ~f = Shifted_value (f x)\n\n module Shift : sig\n type 'f t = private { c : 'f; scale : 'f }\n\n val create : (module Field_intf with type t = 'f) -> 'f t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n end = struct\n type 'f t = { c : 'f; scale : 'f }\n\n let map t ~f = { c = f t.c; scale = f t.scale }\n\n (* 2^{field size in bits} + 1 *)\n let create (type f) (module F : Field_intf with type t = f) : f t =\n { c = F.(two_to_the (module F) size_in_bits + one)\n ; scale = F.(inv (of_int 2))\n }\n end\n\n let of_field (type f) (module F : Field_intf with type t = f)\n ~(shift : f Shift.t) (s : f) : f t =\n Shifted_value F.((s - shift.c) * shift.scale)\n\n let to_field (type f) (module F : Field_intf with type t = f)\n ~(shift : f Shift.t) (Shifted_value t : f t) : f =\n F.(t + t + shift.c)\n\n let equal equal (Shifted_value t1) (Shifted_value t2) = equal t1 t2\nend\n\n(* When the scalar field is larger than the inner field of the circuit,\n we need to encode a scalar [s] as a pair ((s >> 1), s & 1). In other\n words, the high bits, and then the low bit separately.\n\n We can then efficiently compute the function\n\n f = fun (g, s) -> (2 * (s >> 1) + (s & 1) + 2^(5 * ceil(len(s >> 1) / 5))) g\n = fun (g, s) -> (s + 2^field_size_in_bits) g\n\n This is a different notion of shifted value, so we have a separate type for it.\n*)\n\nmodule Type2 = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'f t = Shifted_value of 'f\n [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n\n let typ f =\n let there (Shifted_value x) = x in\n let back x = Shifted_value x in\n Snarky_backendless.Typ.(\n transport_var (transport f ~there ~back) ~there ~back)\n\n let map (Shifted_value x) ~f = Shifted_value (f x)\n\n module Shift : sig\n type 'f t = private 'f\n\n val create : (module Field_intf with type t = 'f) -> 'f t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n end = struct\n type 'f t = 'f\n\n let map t ~f = f t\n\n (* 2^{field size in bits} *)\n let create (type f) (module F : Field_intf with type t = f) : f t =\n two_to_the (module F) F.size_in_bits\n end\n\n let of_field (type f) (module F : Field_intf with type t = f)\n ~(shift : f Shift.t) (s : f) : f t =\n Shifted_value F.(s - (shift :> t))\n\n let to_field (type f) (module F : Field_intf with type t = f)\n ~(shift : f Shift.t) (Shifted_value t : f t) : f =\n F.(t + (shift :> t))\n\n let equal equal (Shifted_value t1) (Shifted_value t2) = equal t1 t2\nend\n","open Core_kernel\n\nlet padded_array_typ ~length ~dummy elt =\n Snarky_backendless.Typ.array ~length elt\n |> Snarky_backendless.Typ.transport\n ~there:(fun a ->\n let n = Array.length a in\n if n > length then failwithf \"Expected %d <= %d\" n length () ;\n Array.append a (Array.create ~len:(length - n) dummy) )\n ~back:Fn.id\n\nlet hash_fold_array f s x = hash_fold_list f s (Array.to_list x)\n\nmodule Columns = Nat.N15\nmodule Columns_vec = Vector.Vector_15\nmodule Permuts_minus_1 = Nat.N6\nmodule Permuts_minus_1_vec = Vector.Vector_6\nmodule Permuts = Nat.N7\nmodule Permuts_vec = Vector.Vector_7\nmodule Lookup_sorted_minus_1 = Nat.N4\nmodule Lookup_sorted_minus_1_vec = Vector.Vector_4\nmodule Lookup_sorted = Nat.N5\nmodule Lookup_sorted_vec = Vector.Vector_5\n\nmodule Features = struct\n module Full = struct\n type 'bool t =\n { range_check0 : 'bool\n ; range_check1 : 'bool\n ; foreign_field_add : 'bool\n ; foreign_field_mul : 'bool\n ; xor : 'bool\n ; rot : 'bool\n ; lookup : 'bool\n ; runtime_tables : 'bool\n ; uses_lookups : 'bool\n ; table_width_at_least_1 : 'bool\n ; table_width_at_least_2 : 'bool\n ; table_width_3 : 'bool\n ; lookups_per_row_3 : 'bool\n ; lookups_per_row_4 : 'bool\n ; lookup_pattern_xor : 'bool\n ; lookup_pattern_range_check : 'bool\n }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n\n let get_feature_flag (feature_flags : _ t)\n (feature : Kimchi_types.feature_flag) =\n match feature with\n | RangeCheck0 ->\n Some feature_flags.range_check0\n | RangeCheck1 ->\n Some feature_flags.range_check1\n | ForeignFieldAdd ->\n Some feature_flags.foreign_field_add\n | ForeignFieldMul ->\n Some feature_flags.foreign_field_mul\n | Xor ->\n Some feature_flags.xor\n | Rot ->\n Some feature_flags.rot\n | LookupTables ->\n Some feature_flags.uses_lookups\n | RuntimeLookupTables ->\n Some feature_flags.runtime_tables\n | TableWidth 3 ->\n Some feature_flags.table_width_3\n | TableWidth 2 ->\n Some feature_flags.table_width_at_least_2\n | TableWidth i when i <= 1 ->\n Some feature_flags.table_width_at_least_1\n | TableWidth _ ->\n None\n | LookupsPerRow 4 ->\n Some feature_flags.lookups_per_row_4\n | LookupsPerRow i when i <= 3 ->\n Some feature_flags.lookups_per_row_3\n | LookupsPerRow _ ->\n None\n | LookupPattern Lookup ->\n Some feature_flags.lookup\n | LookupPattern Xor ->\n Some feature_flags.lookup_pattern_xor\n | LookupPattern RangeCheck ->\n Some feature_flags.lookup_pattern_range_check\n | LookupPattern ForeignFieldMul ->\n Some feature_flags.foreign_field_mul\n\n let map\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; rot\n ; xor\n ; lookup\n ; runtime_tables\n ; uses_lookups\n ; table_width_at_least_1\n ; table_width_at_least_2\n ; table_width_3\n ; lookups_per_row_3\n ; lookups_per_row_4\n ; lookup_pattern_xor\n ; lookup_pattern_range_check\n } ~f =\n { range_check0 = f range_check0\n ; range_check1 = f range_check1\n ; foreign_field_add = f foreign_field_add\n ; foreign_field_mul = f foreign_field_mul\n ; xor = f xor\n ; rot = f rot\n ; lookup = f lookup\n ; runtime_tables = f runtime_tables\n ; uses_lookups = f uses_lookups\n ; table_width_at_least_1 = f table_width_at_least_1\n ; table_width_at_least_2 = f table_width_at_least_2\n ; table_width_3 = f table_width_3\n ; lookups_per_row_3 = f lookups_per_row_3\n ; lookups_per_row_4 = f lookups_per_row_4\n ; lookup_pattern_xor = f lookup_pattern_xor\n ; lookup_pattern_range_check = f lookup_pattern_range_check\n }\n\n let map2 x1 x2 ~f =\n { range_check0 = f x1.range_check0 x2.range_check0\n ; range_check1 = f x1.range_check1 x2.range_check1\n ; foreign_field_add = f x1.foreign_field_add x2.foreign_field_add\n ; foreign_field_mul = f x1.foreign_field_mul x2.foreign_field_mul\n ; xor = f x1.xor x2.xor\n ; rot = f x1.rot x2.rot\n ; lookup = f x1.lookup x2.lookup\n ; runtime_tables = f x1.runtime_tables x2.runtime_tables\n ; uses_lookups = f x1.uses_lookups x2.uses_lookups\n ; table_width_at_least_1 =\n f x1.table_width_at_least_1 x2.table_width_at_least_1\n ; table_width_at_least_2 =\n f x1.table_width_at_least_2 x2.table_width_at_least_2\n ; table_width_3 = f x1.table_width_3 x2.table_width_3\n ; lookups_per_row_3 = f x1.lookups_per_row_3 x2.lookups_per_row_3\n ; lookups_per_row_4 = f x1.lookups_per_row_4 x2.lookups_per_row_4\n ; lookup_pattern_xor = f x1.lookup_pattern_xor x2.lookup_pattern_xor\n ; lookup_pattern_range_check =\n f x1.lookup_pattern_range_check x2.lookup_pattern_range_check\n }\n\n let none =\n { range_check0 = Opt.Flag.No\n ; range_check1 = Opt.Flag.No\n ; foreign_field_add = Opt.Flag.No\n ; foreign_field_mul = Opt.Flag.No\n ; xor = Opt.Flag.No\n ; rot = Opt.Flag.No\n ; lookup = Opt.Flag.No\n ; runtime_tables = Opt.Flag.No\n ; uses_lookups = Opt.Flag.No\n ; table_width_at_least_1 = Opt.Flag.No\n ; table_width_at_least_2 = Opt.Flag.No\n ; table_width_3 = Opt.Flag.No\n ; lookups_per_row_3 = Opt.Flag.No\n ; lookups_per_row_4 = Opt.Flag.No\n ; lookup_pattern_xor = Opt.Flag.No\n ; lookup_pattern_range_check = Opt.Flag.No\n }\n\n let maybe =\n { range_check0 = Opt.Flag.Maybe\n ; range_check1 = Opt.Flag.Maybe\n ; foreign_field_add = Opt.Flag.Maybe\n ; foreign_field_mul = Opt.Flag.Maybe\n ; xor = Opt.Flag.Maybe\n ; rot = Opt.Flag.Maybe\n ; lookup = Opt.Flag.Maybe\n ; runtime_tables = Opt.Flag.Maybe\n ; uses_lookups = Opt.Flag.Maybe\n ; table_width_at_least_1 = Opt.Flag.Maybe\n ; table_width_at_least_2 = Opt.Flag.Maybe\n ; table_width_3 = Opt.Flag.Maybe\n ; lookups_per_row_3 = Opt.Flag.Maybe\n ; lookups_per_row_4 = Opt.Flag.Maybe\n ; lookup_pattern_xor = Opt.Flag.Maybe\n ; lookup_pattern_range_check = Opt.Flag.Maybe\n }\n\n let none_bool =\n { range_check0 = false\n ; range_check1 = false\n ; foreign_field_add = false\n ; foreign_field_mul = false\n ; xor = false\n ; rot = false\n ; lookup = false\n ; runtime_tables = false\n ; uses_lookups = false\n ; table_width_at_least_1 = false\n ; table_width_at_least_2 = false\n ; table_width_3 = false\n ; lookups_per_row_3 = false\n ; lookups_per_row_4 = false\n ; lookup_pattern_xor = false\n ; lookup_pattern_range_check = false\n }\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'bool t =\n { range_check0 : 'bool\n ; range_check1 : 'bool\n ; foreign_field_add : 'bool\n ; foreign_field_mul : 'bool\n ; xor : 'bool\n ; rot : 'bool\n ; lookup : 'bool\n ; runtime_tables : 'bool\n }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n let of_full\n ({ range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n ; uses_lookups = _\n ; table_width_at_least_1 = _\n ; table_width_at_least_2 = _\n ; table_width_3 = _\n ; lookups_per_row_3 = _\n ; lookups_per_row_4 = _\n ; lookup_pattern_xor = _\n ; lookup_pattern_range_check = _\n } :\n 'bool Full.t ) =\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n }\n\n let to_full ~or_:( ||| )\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n } : _ Full.t =\n let lookup_pattern_range_check =\n (* RangeCheck, Rot gates use RangeCheck lookup pattern *)\n range_check0 ||| range_check1 ||| rot\n in\n let lookup_pattern_xor =\n (* Xor lookup pattern *)\n xor\n in\n (* Make sure these stay up-to-date with the layouts!! *)\n let table_width_3 =\n (* Xor have max_joint_size = 3 *)\n lookup_pattern_xor\n in\n let table_width_at_least_2 =\n (* Lookup has max_joint_size = 2 *)\n table_width_3 ||| lookup\n in\n let table_width_at_least_1 =\n (* RangeCheck, ForeignFieldMul have max_joint_size = 1 *)\n table_width_at_least_2 ||| lookup_pattern_range_check\n ||| foreign_field_mul\n in\n let lookups_per_row_4 =\n (* Xor, RangeCheckGate, ForeignFieldMul, have max_lookups_per_row = 4 *)\n lookup_pattern_xor ||| lookup_pattern_range_check ||| foreign_field_mul\n in\n let lookups_per_row_3 =\n (* Lookup has max_lookups_per_row = 3 *)\n lookups_per_row_4 ||| lookup\n in\n { uses_lookups = lookups_per_row_3\n ; table_width_at_least_1\n ; table_width_at_least_2\n ; table_width_3\n ; lookups_per_row_3\n ; lookups_per_row_4\n ; lookup_pattern_xor\n ; lookup_pattern_range_check\n ; range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n }\n\n type options = Opt.Flag.t t\n\n type flags = bool t\n\n let to_data\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n } : _ Hlist.HlistId.t =\n [ range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n ]\n\n let of_data\n ([ range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n ] :\n _ Hlist.HlistId.t ) =\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n }\n\n let typ bool\n ~feature_flags:\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n } =\n (* TODO: This should come from snarky. *)\n let constant (type var value)\n (typ : (var, value, _) Snarky_backendless.Typ.t) (x : value) : var =\n let (Typ typ) = typ in\n let fields, aux = typ.value_to_fields x in\n let fields =\n Array.map ~f:(fun x -> Snarky_backendless.Cvar.Constant x) fields\n in\n typ.var_of_fields (fields, aux)\n in\n let constant_typ ~there value =\n let open Snarky_backendless.Typ in\n unit ()\n |> transport ~there ~back:(fun () -> value)\n |> transport_var ~there:(fun _ -> ()) ~back:(fun () -> constant bool value)\n in\n let bool_typ_of_flag = function\n | Opt.Flag.Yes ->\n constant_typ\n ~there:(function true -> () | false -> assert false)\n true\n | Opt.Flag.No ->\n constant_typ\n ~there:(function false -> () | true -> assert false)\n false\n | Opt.Flag.Maybe ->\n bool\n in\n Snarky_backendless.Typ.of_hlistable\n [ bool_typ_of_flag range_check0\n ; bool_typ_of_flag range_check1\n ; bool_typ_of_flag foreign_field_add\n ; bool_typ_of_flag foreign_field_mul\n ; bool_typ_of_flag xor\n ; bool_typ_of_flag rot\n ; bool_typ_of_flag lookup\n ; bool_typ_of_flag runtime_tables\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n let none =\n { range_check0 = Opt.Flag.No\n ; range_check1 = Opt.Flag.No\n ; foreign_field_add = Opt.Flag.No\n ; foreign_field_mul = Opt.Flag.No\n ; xor = Opt.Flag.No\n ; rot = Opt.Flag.No\n ; lookup = Opt.Flag.No\n ; runtime_tables = Opt.Flag.No\n }\n\n let maybe =\n { range_check0 = Opt.Flag.Maybe\n ; range_check1 = Opt.Flag.Maybe\n ; foreign_field_add = Opt.Flag.Maybe\n ; foreign_field_mul = Opt.Flag.Maybe\n ; xor = Opt.Flag.Maybe\n ; rot = Opt.Flag.Maybe\n ; lookup = Opt.Flag.Maybe\n ; runtime_tables = Opt.Flag.Maybe\n }\n\n let none_bool =\n { range_check0 = false\n ; range_check1 = false\n ; foreign_field_add = false\n ; foreign_field_mul = false\n ; xor = false\n ; rot = false\n ; lookup = false\n ; runtime_tables = false\n }\n\n let map\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; rot\n ; xor\n ; lookup\n ; runtime_tables\n } ~f =\n { range_check0 = f range_check0\n ; range_check1 = f range_check1\n ; foreign_field_add = f foreign_field_add\n ; foreign_field_mul = f foreign_field_mul\n ; xor = f xor\n ; rot = f rot\n ; lookup = f lookup\n ; runtime_tables = f runtime_tables\n }\n\n let map2 x1 x2 ~f =\n { range_check0 = f x1.range_check0 x2.range_check0\n ; range_check1 = f x1.range_check1 x2.range_check1\n ; foreign_field_add = f x1.foreign_field_add x2.foreign_field_add\n ; foreign_field_mul = f x1.foreign_field_mul x2.foreign_field_mul\n ; xor = f x1.xor x2.xor\n ; rot = f x1.rot x2.rot\n ; lookup = f x1.lookup x2.lookup\n ; runtime_tables = f x1.runtime_tables x2.runtime_tables\n }\nend\n\nmodule Evals = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type 'a t =\n { w : 'a Columns_vec.Stable.V1.t\n ; coefficients : 'a Columns_vec.Stable.V1.t\n ; z : 'a\n ; s : 'a Permuts_minus_1_vec.Stable.V1.t\n ; generic_selector : 'a\n ; poseidon_selector : 'a\n ; complete_add_selector : 'a\n ; mul_selector : 'a\n ; emul_selector : 'a\n ; endomul_scalar_selector : 'a\n ; range_check0_selector : 'a option\n ; range_check1_selector : 'a option\n ; foreign_field_add_selector : 'a option\n ; foreign_field_mul_selector : 'a option\n ; xor_selector : 'a option\n ; rot_selector : 'a option\n ; lookup_aggregation : 'a option\n ; lookup_table : 'a option\n ; lookup_sorted : 'a option Lookup_sorted_vec.Stable.V1.t\n ; runtime_lookup_table : 'a option\n ; runtime_lookup_table_selector : 'a option\n ; xor_lookup_selector : 'a option\n ; lookup_gate_lookup_selector : 'a option\n ; range_check_lookup_selector : 'a option\n ; foreign_field_mul_lookup_selector : 'a option\n }\n [@@deriving fields, sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n let validate_feature_flags ~feature_flags:(f : bool Features.t)\n { w = _\n ; coefficients = _\n ; z = _\n ; s = _\n ; generic_selector = _\n ; poseidon_selector = _\n ; complete_add_selector = _\n ; mul_selector = _\n ; emul_selector = _\n ; endomul_scalar_selector = _\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } =\n let enable_if x flag = Bool.(Option.is_some x = flag) in\n let range_check_lookup = f.range_check0 || f.range_check1 || f.rot in\n let lookups_per_row_4 =\n f.xor || range_check_lookup || f.foreign_field_mul\n in\n let lookups_per_row_3 = lookups_per_row_4 || f.lookup in\n let lookups_per_row_2 = lookups_per_row_3 in\n Array.reduce_exn ~f:( && )\n [| enable_if range_check0_selector f.range_check0\n ; enable_if range_check1_selector f.range_check1\n ; enable_if foreign_field_add_selector f.foreign_field_add\n ; enable_if foreign_field_mul_selector f.foreign_field_mul\n ; enable_if xor_selector f.xor\n ; enable_if rot_selector f.rot\n ; enable_if lookup_aggregation lookups_per_row_2\n ; enable_if lookup_table lookups_per_row_2\n ; Vector.foldi lookup_sorted ~init:true ~f:(fun i acc x ->\n let flag =\n (* NB: lookups_per_row + 1 in sorted, due to the lookup table. *)\n match i with\n | 0 | 1 | 2 ->\n lookups_per_row_2\n | 3 ->\n lookups_per_row_3\n | 4 ->\n lookups_per_row_4\n | _ ->\n assert false\n in\n acc && enable_if x flag )\n ; enable_if runtime_lookup_table f.runtime_tables\n ; enable_if runtime_lookup_table_selector f.runtime_tables\n ; enable_if xor_lookup_selector f.xor\n ; enable_if lookup_gate_lookup_selector f.lookup\n ; enable_if range_check_lookup_selector range_check_lookup\n ; enable_if foreign_field_mul_lookup_selector f.foreign_field_mul\n |]\n\n let to_absorption_sequence\n { w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } : _ list =\n let always_present =\n [ z\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ]\n @ Vector.to_list w\n @ Vector.to_list coefficients\n @ Vector.to_list s\n in\n let optional_gates =\n List.filter_map ~f:Fn.id\n [ range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ]\n in\n let lookup_final_terms =\n List.filter_map ~f:Fn.id\n [ runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n ]\n in\n always_present @ optional_gates\n @ List.filter_map ~f:Fn.id (Vector.to_list lookup_sorted)\n @ lookup_final_terms\n\n module In_circuit = struct\n type ('f, 'bool) t =\n { w : 'f Columns_vec.t\n ; coefficients : 'f Columns_vec.t\n ; z : 'f\n ; s : 'f Permuts_minus_1_vec.t\n ; generic_selector : 'f\n ; poseidon_selector : 'f\n ; complete_add_selector : 'f\n ; mul_selector : 'f\n ; emul_selector : 'f\n ; endomul_scalar_selector : 'f\n ; range_check0_selector : ('f, 'bool) Opt.t\n ; range_check1_selector : ('f, 'bool) Opt.t\n ; foreign_field_add_selector : ('f, 'bool) Opt.t\n ; foreign_field_mul_selector : ('f, 'bool) Opt.t\n ; xor_selector : ('f, 'bool) Opt.t\n ; rot_selector : ('f, 'bool) Opt.t\n ; lookup_aggregation : ('f, 'bool) Opt.t\n ; lookup_table : ('f, 'bool) Opt.t\n ; lookup_sorted : ('f, 'bool) Opt.t Lookup_sorted_vec.t\n ; runtime_lookup_table : ('f, 'bool) Opt.t\n ; runtime_lookup_table_selector : ('f, 'bool) Opt.t\n ; xor_lookup_selector : ('f, 'bool) Opt.t\n ; lookup_gate_lookup_selector : ('f, 'bool) Opt.t\n ; range_check_lookup_selector : ('f, 'bool) Opt.t\n ; foreign_field_mul_lookup_selector : ('f, 'bool) Opt.t\n }\n [@@deriving hlist, fields]\n\n let map (type bool a b)\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } :\n (a, bool) t ) ~(f : a -> b) : (b, bool) t =\n { w = Vector.map w ~f\n ; coefficients = Vector.map coefficients ~f\n ; z = f z\n ; s = Vector.map s ~f\n ; generic_selector = f generic_selector\n ; poseidon_selector = f poseidon_selector\n ; complete_add_selector = f complete_add_selector\n ; mul_selector = f mul_selector\n ; emul_selector = f emul_selector\n ; endomul_scalar_selector = f endomul_scalar_selector\n ; range_check0_selector = Opt.map ~f range_check0_selector\n ; range_check1_selector = Opt.map ~f range_check1_selector\n ; foreign_field_add_selector = Opt.map ~f foreign_field_add_selector\n ; foreign_field_mul_selector = Opt.map ~f foreign_field_mul_selector\n ; xor_selector = Opt.map ~f xor_selector\n ; rot_selector = Opt.map ~f rot_selector\n ; lookup_aggregation = Opt.map ~f lookup_aggregation\n ; lookup_table = Opt.map ~f lookup_table\n ; lookup_sorted = Vector.map ~f:(Opt.map ~f) lookup_sorted\n ; runtime_lookup_table = Opt.map ~f runtime_lookup_table\n ; runtime_lookup_table_selector = Opt.map ~f runtime_lookup_table_selector\n ; xor_lookup_selector = Opt.map ~f xor_lookup_selector\n ; lookup_gate_lookup_selector = Opt.map ~f lookup_gate_lookup_selector\n ; range_check_lookup_selector = Opt.map ~f range_check_lookup_selector\n ; foreign_field_mul_lookup_selector =\n Opt.map ~f foreign_field_mul_lookup_selector\n }\n\n let to_list\n { w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } =\n let always_present =\n List.map ~f:Opt.just\n ( [ z\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ]\n @ Vector.to_list w\n @ Vector.to_list coefficients\n @ Vector.to_list s )\n in\n let optional_gates =\n [ range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ]\n in\n always_present @ optional_gates\n @ Vector.to_list lookup_sorted\n @ [ lookup_aggregation\n ; lookup_table\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n ]\n\n let to_absorption_sequence\n { w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } : _ Opt.Early_stop_sequence.t =\n let always_present =\n [ z\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ]\n @ Vector.to_list w\n @ Vector.to_list coefficients\n @ Vector.to_list s\n in\n let optional_gates =\n [ range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ]\n in\n\n List.map ~f:Opt.just always_present\n @ optional_gates\n @ Vector.to_list lookup_sorted\n @ [ runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n ]\n end\n\n let to_in_circuit (type bool a)\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } :\n a t ) : (a, bool) In_circuit.t =\n { w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector = Opt.of_option range_check0_selector\n ; range_check1_selector = Opt.of_option range_check1_selector\n ; foreign_field_add_selector = Opt.of_option foreign_field_add_selector\n ; foreign_field_mul_selector = Opt.of_option foreign_field_mul_selector\n ; xor_selector = Opt.of_option xor_selector\n ; rot_selector = Opt.of_option rot_selector\n ; lookup_aggregation = Opt.of_option lookup_aggregation\n ; lookup_table = Opt.of_option lookup_table\n ; lookup_sorted = Vector.map ~f:Opt.of_option lookup_sorted\n ; runtime_lookup_table = Opt.of_option runtime_lookup_table\n ; runtime_lookup_table_selector =\n Opt.of_option runtime_lookup_table_selector\n ; xor_lookup_selector = Opt.of_option xor_lookup_selector\n ; lookup_gate_lookup_selector = Opt.of_option lookup_gate_lookup_selector\n ; range_check_lookup_selector = Opt.of_option range_check_lookup_selector\n ; foreign_field_mul_lookup_selector =\n Opt.of_option foreign_field_mul_lookup_selector\n }\n\n let map (type a b)\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } :\n a t ) ~(f : a -> b) : b t =\n { w = Vector.map w ~f\n ; coefficients = Vector.map coefficients ~f\n ; z = f z\n ; s = Vector.map s ~f\n ; generic_selector = f generic_selector\n ; poseidon_selector = f poseidon_selector\n ; complete_add_selector = f complete_add_selector\n ; mul_selector = f mul_selector\n ; emul_selector = f emul_selector\n ; endomul_scalar_selector = f endomul_scalar_selector\n ; range_check0_selector = Option.map ~f range_check0_selector\n ; range_check1_selector = Option.map ~f range_check1_selector\n ; foreign_field_add_selector = Option.map ~f foreign_field_add_selector\n ; foreign_field_mul_selector = Option.map ~f foreign_field_mul_selector\n ; xor_selector = Option.map ~f xor_selector\n ; rot_selector = Option.map ~f rot_selector\n ; lookup_aggregation = Option.map ~f lookup_aggregation\n ; lookup_table = Option.map ~f lookup_table\n ; lookup_sorted = Vector.map ~f:(Option.map ~f) lookup_sorted\n ; runtime_lookup_table = Option.map ~f runtime_lookup_table\n ; runtime_lookup_table_selector =\n Option.map ~f runtime_lookup_table_selector\n ; xor_lookup_selector = Option.map ~f xor_lookup_selector\n ; lookup_gate_lookup_selector = Option.map ~f lookup_gate_lookup_selector\n ; range_check_lookup_selector = Option.map ~f range_check_lookup_selector\n ; foreign_field_mul_lookup_selector =\n Option.map ~f foreign_field_mul_lookup_selector\n }\n\n let map2 (type a b c) (t1 : a t) (t2 : b t) ~(f : a -> b -> c) : c t =\n { w = Vector.map2 t1.w t2.w ~f\n ; coefficients = Vector.map2 t1.coefficients t2.coefficients ~f\n ; z = f t1.z t2.z\n ; s = Vector.map2 t1.s t2.s ~f\n ; generic_selector = f t1.generic_selector t2.generic_selector\n ; poseidon_selector = f t1.poseidon_selector t2.poseidon_selector\n ; complete_add_selector =\n f t1.complete_add_selector t2.complete_add_selector\n ; mul_selector = f t1.mul_selector t2.mul_selector\n ; emul_selector = f t1.emul_selector t2.emul_selector\n ; endomul_scalar_selector =\n f t1.endomul_scalar_selector t2.endomul_scalar_selector\n ; range_check0_selector =\n Option.map2 ~f t1.range_check0_selector t2.range_check0_selector\n ; range_check1_selector =\n Option.map2 ~f t1.range_check1_selector t2.range_check1_selector\n ; foreign_field_add_selector =\n Option.map2 ~f t1.foreign_field_add_selector\n t2.foreign_field_add_selector\n ; foreign_field_mul_selector =\n Option.map2 ~f t1.foreign_field_mul_selector\n t2.foreign_field_mul_selector\n ; xor_selector = Option.map2 ~f t1.xor_selector t2.xor_selector\n ; rot_selector = Option.map2 ~f t1.rot_selector t2.rot_selector\n ; lookup_aggregation =\n Option.map2 ~f t1.lookup_aggregation t2.lookup_aggregation\n ; lookup_table = Option.map2 ~f t1.lookup_table t2.lookup_table\n ; lookup_sorted =\n Vector.map2 ~f:(Option.map2 ~f) t1.lookup_sorted t2.lookup_sorted\n ; runtime_lookup_table =\n Option.map2 ~f t1.runtime_lookup_table t2.runtime_lookup_table\n ; runtime_lookup_table_selector =\n Option.map2 ~f t1.runtime_lookup_table_selector\n t2.runtime_lookup_table_selector\n ; xor_lookup_selector =\n Option.map2 ~f t1.xor_lookup_selector t2.xor_lookup_selector\n ; lookup_gate_lookup_selector =\n Option.map2 ~f t1.lookup_gate_lookup_selector\n t2.lookup_gate_lookup_selector\n ; range_check_lookup_selector =\n Option.map2 ~f t1.range_check_lookup_selector\n t2.range_check_lookup_selector\n ; foreign_field_mul_lookup_selector =\n Option.map2 ~f t1.foreign_field_mul_lookup_selector\n t2.foreign_field_mul_lookup_selector\n }\n\n (*\n This is in the same order as the evaluations in the opening proof:\n added later:\n - old sg polynomials\n - public input polynomial\n - ft\n here:\n - z\n - generic selector\n - poseidon selector\n - complete_add_selector\n - mul_selector\n - emul_selector\n - endomul_scalar_selector\n - w (witness columns)\n - coefficients\n - s (sigma columns)\n\n then optionally:\n - lookup sorted\n - lookup aggreg\n - lookup table\n - lookup runtime\n *)\n\n let to_list\n { w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } =\n let always_present =\n [ z\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ]\n @ Vector.to_list w\n @ Vector.to_list coefficients\n @ Vector.to_list s\n in\n let optional_gates =\n List.filter_map ~f:Fn.id\n [ range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ]\n in\n always_present @ optional_gates\n @ List.filter_map ~f:Fn.id (Vector.to_list lookup_sorted)\n @ List.filter_map ~f:Fn.id\n [ lookup_aggregation\n ; lookup_table\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n ]\n\n let typ (type f a_var a)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ~dummy e\n ({ uses_lookups; lookups_per_row_3; lookups_per_row_4; _ } as\n feature_flags :\n _ Features.Full.t ) :\n ((a_var, Impl.Boolean.var) In_circuit.t, a t, f) Snarky_backendless.Typ.t\n =\n let open Impl in\n let opt flag = Opt.typ Impl.Boolean.typ flag e ~dummy in\n let lookup_sorted =\n let lookups_per_row_3 = opt lookups_per_row_3 in\n let lookups_per_row_4 = opt lookups_per_row_4 in\n Vector.typ'\n [ lookups_per_row_3\n ; lookups_per_row_3\n ; lookups_per_row_3\n ; lookups_per_row_3\n ; lookups_per_row_4\n ]\n in\n Typ.of_hlistable\n [ Vector.typ e Columns.n\n ; Vector.typ e Columns.n\n ; e\n ; Vector.typ e Permuts_minus_1.n\n ; e\n ; e\n ; e\n ; e\n ; e\n ; e\n ; opt feature_flags.range_check0\n ; opt feature_flags.range_check1\n ; opt feature_flags.foreign_field_add\n ; opt feature_flags.foreign_field_mul\n ; opt feature_flags.xor\n ; opt feature_flags.rot\n ; opt uses_lookups\n ; opt uses_lookups\n ; lookup_sorted\n ; opt feature_flags.runtime_tables\n ; opt feature_flags.runtime_tables\n ; opt feature_flags.lookup_pattern_xor\n ; opt feature_flags.lookup\n ; opt feature_flags.lookup_pattern_range_check\n ; opt feature_flags.foreign_field_mul\n ]\n ~var_to_hlist:In_circuit.to_hlist ~var_of_hlist:In_circuit.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\nend\n\nmodule All_evals = struct\n module With_public_input = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('f, 'f_multi) t =\n { public_input : 'f; evals : 'f_multi Evals.Stable.V2.t }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n module In_circuit = struct\n type ('f, 'f_multi, 'bool) t =\n { public_input : 'f; evals : ('f_multi, 'bool) Evals.In_circuit.t }\n [@@deriving hlist]\n\n let factor (type f f_multi bool)\n ({ public_input = p1, p2; evals } : (f * f, f_multi * f_multi, bool) t)\n : (f, f_multi, bool) t Tuple_lib.Double.t =\n ( { evals = Evals.In_circuit.map ~f:fst evals; public_input = p1 }\n , { evals = Evals.In_circuit.map ~f:snd evals; public_input = p2 } )\n end\n\n let map (type a1 a2 b1 b2) (t : (a1, a2) t) ~(f1 : a1 -> b1) ~(f2 : a2 -> b2)\n : (b1, b2) t =\n { public_input = f1 t.public_input; evals = Evals.map ~f:f2 t.evals }\n\n let typ impl feature_flags f f_multi ~dummy =\n let evals = Evals.typ impl f_multi feature_flags ~dummy in\n let open Snarky_backendless.Typ in\n of_hlistable [ f; evals ] ~var_to_hlist:In_circuit.to_hlist\n ~var_of_hlist:In_circuit.of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n [@@@warning \"-4\"]\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('f, 'f_multi) t =\n { evals : ('f * 'f, 'f_multi * 'f_multi) With_public_input.Stable.V1.t\n ; ft_eval1 : 'f\n }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n module In_circuit = struct\n type ('f, 'f_multi, 'bool) t =\n { evals :\n ('f * 'f, 'f_multi * 'f_multi, 'bool) With_public_input.In_circuit.t\n ; ft_eval1 : 'f\n }\n [@@deriving hlist]\n end\n\n let map (type a1 a2 b1 b2) (t : (a1, a2) t) ~(f1 : a1 -> b1) ~(f2 : a2 -> b2)\n : (b1, b2) t =\n { evals =\n With_public_input.map t.evals\n ~f1:(Tuple_lib.Double.map ~f:f1)\n ~f2:(Tuple_lib.Double.map ~f:f2)\n ; ft_eval1 = f1 t.ft_eval1\n }\n\n let typ (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n feature_flags =\n let open Impl.Typ in\n let single = array ~length:1 field in\n let evals =\n With_public_input.typ\n (module Impl)\n feature_flags (tuple2 field field) (tuple2 single single)\n ~dummy:Impl.Field.Constant.([| zero |], [| zero |])\n in\n of_hlistable [ evals; Impl.Field.typ ] ~var_to_hlist:In_circuit.to_hlist\n ~var_of_hlist:In_circuit.of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\nend\n\nmodule Openings = struct\n [@@@warning \"-4\"] (* Deals with the 2 sexp-deriving types below *)\n\n module Bulletproof = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('g, 'fq) t =\n { lr : ('g * 'g) array\n ; z_1 : 'fq\n ; z_2 : 'fq\n ; delta : 'g\n ; challenge_polynomial_commitment : 'g\n }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n let typ fq g ~length =\n let open Snarky_backendless.Typ in\n of_hlistable\n [ array ~length (g * g); fq; fq; g; g ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('g, 'fq, 'fqv) t =\n { proof : ('g, 'fq) Bulletproof.Stable.V1.t\n ; evals : ('fqv * 'fqv) Evals.Stable.V2.t\n ; ft_eval1 : 'fq\n }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n end\n end]\nend\n\nmodule Poly_comm = struct\n module With_degree_bound = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'g_opt t = { unshifted : 'g_opt array; shifted : 'g_opt }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n end\n end]\n\n let padded_array_typ0 = padded_array_typ\n\n let typ (type f g g_var bool_var)\n (g : (g_var, g, f) Snarky_backendless.Typ.t) ~length\n ~dummy_group_element\n ~(bool : (bool_var, bool, f) Snarky_backendless.Typ.t) :\n ((bool_var * g_var) t, g Or_infinity.t t, f) Snarky_backendless.Typ.t =\n let open Snarky_backendless.Typ in\n let g_inf =\n transport (tuple2 bool g)\n ~there:(function\n | Or_infinity.Infinity ->\n (false, dummy_group_element)\n | Finite x ->\n (true, x) )\n ~back:(fun (b, x) -> if b then Infinity else Finite x)\n in\n let arr = padded_array_typ0 ~length ~dummy:Or_infinity.Infinity g_inf in\n of_hlistable [ arr; g_inf ] ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n end\n\n module Without_degree_bound = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'g t = 'g array [@@deriving sexp, compare, yojson, hash, equal]\n end\n end]\n end\nend\n\nmodule Messages = struct\n open Poly_comm\n\n module Poly = struct\n type ('w, 'z, 't) t = { w : 'w; z : 'z; t : 't }\n [@@deriving sexp, compare, yojson, fields, hash, equal, hlist]\n end\n\n module Lookup = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'g t = { sorted : 'g array; aggreg : 'g; runtime : 'g option }\n [@@deriving fields, sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n type 'g t =\n { sorted : 'g Lookup_sorted_minus_1_vec.t\n ; sorted_5th_column : 'g option\n ; aggreg : 'g\n ; runtime : 'g option\n }\n [@@deriving fields, sexp, compare, yojson, hash, equal, hlist]\n\n module In_circuit = struct\n type ('g, 'bool) t =\n { sorted : 'g Lookup_sorted_minus_1_vec.t\n ; sorted_5th_column : ('g, 'bool) Opt.t\n ; aggreg : 'g\n ; runtime : ('g, 'bool) Opt.t\n }\n [@@deriving hlist]\n end\n\n let dummy z =\n { aggreg = z\n ; sorted = Vector.init Lookup_sorted_minus_1.n ~f:(fun _ -> z)\n ; sorted_5th_column = None\n ; runtime = None\n }\n\n let typ bool_typ e ~lookups_per_row_4 ~runtime_tables ~dummy =\n Snarky_backendless.Typ.of_hlistable\n [ Vector.typ e Lookup_sorted_minus_1.n\n ; Opt.typ bool_typ lookups_per_row_4 e ~dummy\n ; e\n ; Opt.typ bool_typ runtime_tables e ~dummy\n ]\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n ~var_to_hlist:In_circuit.to_hlist ~var_of_hlist:In_circuit.of_hlist\n\n let opt_typ bool_typ ~(uses_lookup : Opt.Flag.t)\n ~(lookups_per_row_4 : Opt.Flag.t) ~(runtime_tables : Opt.Flag.t)\n ~dummy:z elt =\n Opt.typ bool_typ uses_lookup ~dummy:(dummy z)\n (typ bool_typ ~lookups_per_row_4 ~runtime_tables ~dummy:z elt)\n end\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type 'g t =\n { w_comm : 'g Without_degree_bound.Stable.V1.t Columns_vec.Stable.V1.t\n ; z_comm : 'g Without_degree_bound.Stable.V1.t\n ; t_comm : 'g Without_degree_bound.Stable.V1.t\n ; lookup : 'g Without_degree_bound.Stable.V1.t Lookup.Stable.V1.t option\n }\n [@@deriving sexp, compare, yojson, fields, hash, equal, hlist]\n end\n end]\n\n type 'g t =\n { w_comm : 'g Without_degree_bound.t Columns_vec.t\n ; z_comm : 'g Without_degree_bound.t\n ; t_comm : 'g Without_degree_bound.t\n ; lookup : 'g Without_degree_bound.t Lookup.t option\n }\n [@@deriving sexp, compare, yojson, fields, hash, equal, hlist]\n\n module In_circuit = struct\n type ('g, 'bool) t =\n { w_comm : 'g Without_degree_bound.t Columns_vec.t\n ; z_comm : 'g Without_degree_bound.t\n ; t_comm : 'g Without_degree_bound.t\n ; lookup :\n (('g Without_degree_bound.t, 'bool) Lookup.In_circuit.t, 'bool) Opt.t\n }\n [@@deriving hlist, fields]\n end\n\n let typ (type n f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) g\n ({ runtime_tables; uses_lookups; lookups_per_row_4; _ } :\n Opt.Flag.t Features.Full.t ) ~dummy\n ~(commitment_lengths : (((int, n) Vector.t as 'v), int, int) Poly.t) ~bool\n =\n let open Snarky_backendless.Typ in\n let { Poly.w = w_lens; z; t } = commitment_lengths in\n let array ~length elt = padded_array_typ ~dummy ~length elt in\n let wo n = array ~length:(Vector.reduce_exn n ~f:Int.max) g in\n let _w n =\n With_degree_bound.typ g\n ~length:(Vector.reduce_exn n ~f:Int.max)\n ~dummy_group_element:dummy ~bool\n in\n let lookup =\n Lookup.opt_typ Impl.Boolean.typ ~uses_lookup:uses_lookups\n ~lookups_per_row_4 ~runtime_tables ~dummy:[| dummy |]\n (wo [ 1 ])\n in\n of_hlistable\n [ Vector.typ (wo w_lens) Columns.n; wo [ z ]; wo [ t ]; lookup ]\n ~var_to_hlist:In_circuit.to_hlist ~var_of_hlist:In_circuit.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\nend\n\nmodule Proof = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type ('g, 'fq, 'fqv) t =\n { messages : 'g Messages.Stable.V2.t\n ; openings : ('g, 'fq, 'fqv) Openings.Stable.V2.t\n }\n [@@deriving sexp, compare, yojson, hash, equal]\n end\n end]\n\n type ('g, 'fq, 'fqv) t =\n { messages : 'g Messages.t; openings : ('g, 'fq, 'fqv) Openings.t }\n [@@deriving sexp, compare, yojson, hash, equal]\nend\n\nmodule Shifts = struct\n open Core_kernel\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type 'field t = 'field array [@@deriving sexp, compare, yojson, equal]\n end\n end]\nend\n","(** Pickles implementation *)\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Pickles\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Pickles_intf.S\n with type Side_loaded.Verification_key.Stable.V2.t =\n A.Side_loaded.Verification_key.V2.t\n and type ('a, 'b) Proof.t = ('a, 'b) A.Proof.t\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n module Endo = Endo\n module P = Proof\n\n module type Statement_intf = Intf.Statement\n\n module type Statement_var_intf = Intf.Statement_var\n\n module type Statement_value_intf = Intf.Statement_value\n\n module Common = Common\n module Scalar_challenge = Scalar_challenge\n module SC = Scalar_challenge\n open Core_kernel\n open Async_kernel\n open Import\n open Pickles_types\n open Hlist\n open Common\n open Backend\n module Backend = Backend\n module Sponge_inputs = Sponge_inputs\n module Util = Util\n module Tick_field_sponge = Tick_field_sponge\n module Impls = Impls\n module Inductive_rule = Inductive_rule\n module Tag = Tag\n module Types_map = Types_map\n module Dirty = Dirty\n module Cache_handle = Cache_handle\n module Step_main_inputs = Step_main_inputs\n module Step_verifier = Step_verifier\n module Proof_cache = Proof_cache\n\n exception Return_digest = Compile.Return_digest\n\n let verify_promise = Verify.verify\n\n let verify max_proofs_verified statement key proofs =\n verify_promise max_proofs_verified statement key proofs\n |> Promise.to_deferred\n\n (* This file (as you can see from the mli) defines a compiler which turns an inductive\n definition of a set into an inductive SNARK system for proving using those rules.\n\n The two ingredients we use are two SNARKs.\n - A step based SNARK for a field Fp, using the group G1/Fq (whose scalar field is Fp)\n - A DLOG based SNARK for a field Fq, using the group G/Fp (whose scalar field is Fq)\n\n For convenience in this discussion, let's define\n (F_0, G_0) := (Fp, G1)\n (F_1, G_1) := (Fq, G)\n So ScalarField(G_i) = F_i and G_i / F_{1-i}.\n\n An inductive set A is defined by a sequence of inductive rules.\n An inductive rule is intuitively described by something of the form\n\n a1 ∈ A1, ..., an ∈ An\n f [ a0, ... a1 ] a\n ----------------------\n a ∈ A\n\n where f is a snarky function defined over an Impl with Field.t = Fp\n and each Ai is itself an inductive rule (possibly equal to A itself).\n\n a1, ..., an can be seen as previous statements, i.e.\n\n prev_statement_1 ∈ A1, ..., prev_statement_n ∈ An\n f [ prev_statement_1; ...; prev_statement_n ] new_statement = true\n -------------------------------------------------------------------\n new_statement ∈ A\n\n In the case of a blockchain, the description of the sets A1, ..., An, A can\n be blockchain state, and f would be a function updating the state:\n\n prev_blockchain_state ∈ A\n update_blockchain_state [prev_blockchain_state] new_blockchain_state = true\n ---------------------------------------------------------------------------\n new_blockchain_state ∈ A\n\n We pursue the \"step\" then \"wrap\" approach for proof composition.\n\n The main source of complexity is that we must \"wrap\" proofs whose verifiers are\n slightly different.\n\n The main sources of complexity are twofold:\n 1. Each SNARK verifier includes group operations and scalar field operations.\n This is problematic because the group operations use the base field, which is\n not equal to the scalar field.\n\n Schematically, from the circuit point-of-view, we can say a proof is\n - a sequence of F_0 elements xs_0\n - a sequence of F_1 elements xs_1\n and a verifier is a pair of \"snarky functions\"\n - check_0 : F_0 list -> F_1 list -> unit which uses the Impl with Field.t = F_0\n - check_1 : F_0 list -> F_1 list -> unit which uses the Impl with Field.t = F_1\n - subset_00 : 'a list -> 'a list\n - subset_01 : 'a list -> 'a list\n - subset_10 : 'a list -> 'a list\n - subset_11 : 'a list -> 'a list\n and a proof verifies if\n ( check_0 (subset_00 xs_0) (subset_01 xs_1) ;\n check_1 (subset_10 xs_0) (subset_11 xs_1) )\n\n When verifying a proof, we perform the parts of the verifier involving group operations\n and expose as public input the scalar-field elements we need to perform the final checks.\n\n In the F_0 circuit, we witness xs_0 and xs_1,\n execute `check_0 (subset_00 xs_0) (subset_01 xs_1)` and\n expose `subset_10 xs_0` and `subset_11 xs_1` as public inputs.\n\n So the \"public inputs\" contain within them an \"unfinalized proof\".\n\n Then, the next time we verify that proof within an F_1 circuit we \"finalize\" those\n unfinalized proofs by running `check_1 xs_0_subset xs_1_subset`.\n\n I didn't implement it exactly this way (although in retrospect probably I should have) but\n that's the basic idea.\n\n **The complexity this causes:**\n When you prove a rule that includes k recursive verifications, you expose k unfinalized\n proofs. So, the shape of a statement depends on how many \"predecessor statements\" it has\n or in other words, how many verifications were performed within it.\n\n Say we have an inductive set given by inductive rules R_1, ... R_n such that\n each rule R_i has k_i predecessor statements.\n\n In the \"wrap\" circuit, we must be able to verify a proof coming from any of the R_i.\n So, we must pad the statement for the proof we're wrapping to have `max_i k_i`\n unfinalized proof components.\n\n 2. The verifier for each R_i looks a little different depending on the complexity of the \"step\"\n circuit corresponding to R_i has. Namely, it is dependent on the \"domains\" H and K for this\n circuit.\n\n So, when the \"wrap\" circuit proves the statement,\n \"there exists some index i in 1,...,n and a proof P such that verifies(P)\"\n \"verifies(P)\" must also take the index \"i\", compute the correct domain sizes correspond to rule \"i\"\n and use *that* in the \"verifies\" computation.\n *)\n open Kimchi_backend\n module Proof = P\n\n module Statement_with_proof = struct\n type ('s, 'max_width, _) t =\n (* TODO: use Max local max proofs verified instead of max_width *)\n ('max_width, 'max_width) Proof.t\n end\n\n module Verification_key = struct\n include Verification_key\n\n module Id = struct\n include Cache.Wrap.Key.Verification\n\n let dummy_id = Type_equal.Id.(uid (create ~name:\"dummy\" sexp_of_opaque))\n\n let dummy : unit -> t =\n let header =\n { Snark_keys_header.header_version = Snark_keys_header.header_version\n ; kind = { type_ = \"verification key\"; identifier = \"dummy\" }\n ; constraint_constants =\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ; commits = { mina = \"\"; marlin = \"\" }\n ; length = 0\n ; commit_date = \"\"\n ; constraint_system_hash = \"\"\n ; identifying_hash = \"\"\n }\n in\n let t = lazy (dummy_id, header, Md5.digest_string \"\") in\n fun () -> Lazy.force t\n end\n\n (* TODO: Make async *)\n let load ~cache id =\n Key_cache.Sync.read cache\n (Key_cache.Sync.Disk_storable.of_binable Id.to_string\n (module Verification_key.Stable.Latest) )\n id\n |> Deferred.return\n end\n\n module type Proof_intf = Compile.Proof_intf\n\n module Prover = Compile.Prover\n\n module Side_loaded = struct\n module V = Verification_key\n\n module Verification_key = struct\n include Side_loaded_verification_key\n\n let to_input (t : t) =\n to_input ~field_of_int:Impls.Step.Field.Constant.of_int t\n\n let of_compiled tag : t =\n let d = Types_map.lookup_compiled tag.Tag.id in\n let actual_wrap_domain_size =\n Common.actual_wrap_domain_size\n ~log_2_domain_size:(Lazy.force d.wrap_vk).domain.log_size_of_group\n in\n { wrap_vk = Some (Lazy.force d.wrap_vk)\n ; wrap_index = Lazy.force d.wrap_key\n ; max_proofs_verified =\n Pickles_base.Proofs_verified.of_nat\n (Nat.Add.n d.max_proofs_verified)\n ; actual_wrap_domain_size\n }\n\n module Max_width = Width.Max\n end\n\n let in_circuit tag vk =\n Types_map.set_ephemeral tag { index = `In_circuit vk }\n\n let in_prover tag vk = Types_map.set_ephemeral tag { index = `In_prover vk }\n\n let create ~name ~max_proofs_verified ~feature_flags ~typ =\n Types_map.add_side_loaded ~name\n { max_proofs_verified\n ; public_input = typ\n ; branches = Verification_key.Max_branches.n\n ; feature_flags =\n Plonk_types.(Features.to_full ~or_:Opt.Flag.( ||| ) feature_flags)\n }\n\n module Proof = struct\n include Proof.Proofs_verified_max\n\n let of_proof : _ Proof.t -> t = Wrap_hack.pad_proof\n end\n\n let verify_promise (type t) ~(typ : (_, t) Impls.Step.Typ.t)\n (ts : (Verification_key.t * t * Proof.t) list) =\n let m =\n ( module struct\n type nonrec t = t\n\n let to_field_elements =\n let (Typ typ) = typ in\n fun x -> fst (typ.value_to_fields x)\n end : Intf.Statement_value\n with type t = t )\n in\n (* TODO: This should be the actual max width on a per proof basis *)\n let max_proofs_verified =\n (module Verification_key.Max_width : Nat.Intf\n with type n = Verification_key.Max_width.n )\n in\n with_return (fun { return } ->\n List.map ts ~f:(fun (vk, x, p) ->\n let vk : V.t =\n { commitments = vk.wrap_index\n ; index =\n ( match vk.wrap_vk with\n | None ->\n return\n (Promise.return\n (Or_error.errorf\n \"Pickles.verify: wrap_vk not found\" ) )\n | Some x ->\n x )\n ; data =\n (* This isn't used in verify_heterogeneous, so we can leave this dummy *)\n { constraints = 0 }\n }\n in\n Verify.Instance.T (max_proofs_verified, m, vk, x, p) )\n |> Verify.verify_heterogenous )\n\n let verify ~typ ts = verify_promise ~typ ts |> Promise.to_deferred\n\n let srs_precomputation () : unit =\n let srs = Tock.Keypair.load_urs () in\n List.iter [ 0; 1; 2 ] ~f:(fun i ->\n Kimchi_bindings.Protocol.SRS.Fq.add_lagrange_basis srs\n (Domain.log2_size (Common.wrap_domains ~proofs_verified:i).h) )\n end\n\n let compile_with_wrap_main_override_promise =\n Compile.compile_with_wrap_main_override_promise\n\n let compile_promise ?self ?cache ?proof_cache ?disk_keys\n ?return_early_digest_exception ?override_wrap_domain ~public_input\n ~auxiliary_typ ~branches ~max_proofs_verified ~name ~constraint_constants\n ~choices () =\n compile_with_wrap_main_override_promise ?self ?cache ?proof_cache ?disk_keys\n ?return_early_digest_exception ?override_wrap_domain ~public_input\n ~auxiliary_typ ~branches ~max_proofs_verified ~name ~constraint_constants\n ~choices ()\n\n let compile ?self ?cache ?proof_cache ?disk_keys ?override_wrap_domain\n ~public_input ~auxiliary_typ ~branches ~max_proofs_verified ~name\n ~constraint_constants ~choices () =\n let self, cache_handle, proof_module, provers =\n compile_promise ?self ?cache ?proof_cache ?disk_keys ?override_wrap_domain\n ~public_input ~auxiliary_typ ~branches ~max_proofs_verified ~name\n ~constraint_constants ~choices ()\n in\n let rec adjust_provers :\n type a1 a2 a3 s1 s2_inner.\n (a1, a2, a3, s1, s2_inner Promise.t) H3_2.T(Prover).t\n -> (a1, a2, a3, s1, s2_inner Deferred.t) H3_2.T(Prover).t = function\n | [] ->\n []\n | prover :: tl ->\n (fun ?handler public_input ->\n Promise.to_deferred (prover ?handler public_input) )\n :: adjust_provers tl\n in\n (self, cache_handle, proof_module, adjust_provers provers)\n\n module Provers = H3_2.T (Prover)\n module Proof0 = Proof\n\n let%test_module \"test no side-loaded\" =\n ( module struct\n let () = Tock.Keypair.set_urs_info []\n\n let () = Tick.Keypair.set_urs_info []\n\n let () = Backtrace.elide := false\n\n open Impls.Step\n\n let () = Snarky_backendless.Snark0.set_eval_constraints true\n\n (* Currently, a circuit must have at least 1 of every type of constraint. *)\n let dummy_constraints () =\n Impl.(\n let x =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3)\n in\n let g =\n exists Step_main_inputs.Inner_curve.typ ~compute:(fun _ ->\n Tick.Inner_curve.(to_affine_exn one) )\n in\n ignore\n ( SC.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t ))\n\n module No_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let _example_input, _example_proof = example\n end\n\n module No_recursion_return = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Output Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun _ ->\n dummy_constraints () ;\n { previous_proof_statements = []\n ; public_output = Field.zero\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let res, (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step ()) )\n in\n assert (Field.Constant.(equal zero) res) ;\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (res, b0) ] ) ) ;\n (res, b0)\n\n let _example_input, _example_proof = example\n end\n\n [@@@warning \"-60\"]\n\n module Simple_chain = struct\n type _ Snarky_backendless.Request.t +=\n | Prev_input : Field.Constant.t Snarky_backendless.Request.t\n | Proof : (Nat.N1.n, Nat.N1.n) Proof.t Snarky_backendless.Request.t\n\n let handler (prev_input : Field.Constant.t) (proof : _ Proof.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Prev_input ->\n respond (Provide prev_input)\n | Proof ->\n respond (Provide proof)\n | _ ->\n respond Unhandled\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N1)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self ->\n [ { identifier = \"main\"\n ; prevs = [ self ]\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n let prev =\n exists Field.typ ~request:(fun () -> Prev_input)\n in\n let proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Proof )\n in\n let is_base_case = Field.equal Field.zero self in\n let proof_must_verify = Boolean.not is_base_case in\n let self_correct = Field.(equal (one + prev) self) in\n Boolean.Assert.any [ self_correct; is_base_case ] ;\n { previous_proof_statements =\n [ { public_input = prev\n ; proof\n ; proof_must_verify\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let s_neg_one = Field.Constant.(negate one) in\n let b_neg_one : (Nat.N1.n, Nat.N1.n) Proof0.t =\n Proof0.dummy Nat.N1.n Nat.N1.n Nat.N1.n ~domain_log2:14\n in\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:(handler s_neg_one b_neg_one)\n Field.Constant.zero ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n let (), (), b1 =\n Common.time \"b1\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:(handler Field.Constant.zero b0)\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b1) ] ) ) ;\n (Field.Constant.one, b1)\n\n let _example_input, _example_proof = example\n end\n\n module Tree_proof = struct\n type _ Snarky_backendless.Request.t +=\n | No_recursion_input : Field.Constant.t Snarky_backendless.Request.t\n | No_recursion_proof :\n (Nat.N0.n, Nat.N0.n) Proof.t Snarky_backendless.Request.t\n | Recursive_input : Field.Constant.t Snarky_backendless.Request.t\n | Recursive_proof :\n (Nat.N2.n, Nat.N2.n) Proof.t Snarky_backendless.Request.t\n\n let handler\n ((no_recursion_input, no_recursion_proof) :\n Field.Constant.t * _ Proof.t )\n ((recursion_input, recursion_proof) : Field.Constant.t * _ Proof.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | No_recursion_input ->\n respond (Provide no_recursion_input)\n | No_recursion_proof ->\n respond (Provide no_recursion_proof)\n | Recursive_input ->\n respond (Provide recursion_input)\n | Recursive_proof ->\n respond (Provide recursion_proof)\n | _ ->\n respond Unhandled\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~override_wrap_domain:Pickles_base.Proofs_verified.N1\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = [ No_recursion.tag; self ]\n ; main =\n (fun { public_input = self } ->\n let no_recursive_input =\n exists Field.typ ~request:(fun () ->\n No_recursion_input )\n in\n let no_recursive_proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n No_recursion_proof )\n in\n let prev =\n exists Field.typ ~request:(fun () ->\n Recursive_input )\n in\n let prev_proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Recursive_proof )\n in\n let is_base_case = Field.equal Field.zero self in\n let proof_must_verify = Boolean.not is_base_case in\n let self_correct = Field.(equal (one + prev) self) in\n Boolean.Assert.any [ self_correct; is_base_case ] ;\n { previous_proof_statements =\n [ { public_input = no_recursive_input\n ; proof = no_recursive_proof\n ; proof_must_verify = Boolean.true_\n }\n ; { public_input = prev\n ; proof = prev_proof\n ; proof_must_verify\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example1, example2 =\n let s_neg_one = Field.Constant.(negate one) in\n let b_neg_one : (Nat.N2.n, Nat.N2.n) Proof0.t =\n Proof0.dummy Nat.N2.n Nat.N2.n Nat.N2.n ~domain_log2:15\n in\n let (), (), b0 =\n Common.time \"tree b0\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler No_recursion.example (s_neg_one, b_neg_one))\n Field.Constant.zero ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n let (), (), b1 =\n Common.time \"tree b1\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler No_recursion.example (Field.Constant.zero, b0))\n Field.Constant.one ) )\n in\n ((Field.Constant.zero, b0), (Field.Constant.one, b1))\n\n let examples = [ example1; example2 ]\n\n let _example1_input, _example_proof = example1\n\n let _example2_input, _example2_proof = example2\n end\n\n let%test_unit \"verify\" =\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Tree_proof.Proof.verify_promise Tree_proof.examples ) )\n\n module Tree_proof_return = struct\n type _ Snarky_backendless.Request.t +=\n | Is_base_case : bool Snarky_backendless.Request.t\n | No_recursion_input : Field.Constant.t Snarky_backendless.Request.t\n | No_recursion_proof :\n (Nat.N0.n, Nat.N0.n) Proof.t Snarky_backendless.Request.t\n | Recursive_input : Field.Constant.t Snarky_backendless.Request.t\n | Recursive_proof :\n (Nat.N2.n, Nat.N2.n) Proof.t Snarky_backendless.Request.t\n\n let handler (is_base_case : bool)\n ((no_recursion_input, no_recursion_proof) :\n Field.Constant.t * _ Proof.t )\n ((recursion_input, recursion_proof) : Field.Constant.t * _ Proof.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Is_base_case ->\n respond (Provide is_base_case)\n | No_recursion_input ->\n respond (Provide no_recursion_input)\n | No_recursion_proof ->\n respond (Provide no_recursion_proof)\n | Recursive_input ->\n respond (Provide recursion_input)\n | Recursive_proof ->\n respond (Provide recursion_proof)\n | _ ->\n respond Unhandled\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Output Field.typ)\n ~override_wrap_domain:Pickles_base.Proofs_verified.N1\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = [ No_recursion_return.tag; self ]\n ; main =\n (fun { public_input = () } ->\n let no_recursive_input =\n exists Field.typ ~request:(fun () ->\n No_recursion_input )\n in\n let no_recursive_proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n No_recursion_proof )\n in\n let prev =\n exists Field.typ ~request:(fun () ->\n Recursive_input )\n in\n let prev_proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Recursive_proof )\n in\n let is_base_case =\n exists Boolean.typ ~request:(fun () -> Is_base_case)\n in\n let proof_must_verify = Boolean.not is_base_case in\n let self =\n Field.(\n if_ is_base_case ~then_:zero ~else_:(one + prev))\n in\n { previous_proof_statements =\n [ { public_input = no_recursive_input\n ; proof = no_recursive_proof\n ; proof_must_verify = Boolean.true_\n }\n ; { public_input = prev\n ; proof = prev_proof\n ; proof_must_verify\n }\n ]\n ; public_output = self\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example1, example2 =\n let s_neg_one = Field.Constant.(negate one) in\n let b_neg_one : (Nat.N2.n, Nat.N2.n) Proof0.t =\n Proof0.dummy Nat.N2.n Nat.N2.n Nat.N2.n ~domain_log2:15\n in\n let s0, (), b0 =\n Common.time \"tree b0\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler true No_recursion_return.example\n (s_neg_one, b_neg_one) )\n () ) )\n in\n assert (Field.Constant.(equal zero) s0) ;\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (s0, b0) ] ) ) ;\n let s1, (), b1 =\n Common.time \"tree b1\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler false No_recursion_return.example (s0, b0))\n () ) )\n in\n assert (Field.Constant.(equal one) s1) ;\n ((s0, b0), (s1, b1))\n\n let examples = [ example1; example2 ]\n\n let _example1_input, _example1_proof = example1\n\n let _example2_input, _example2_proof = example2\n end\n\n let%test_unit \"verify\" =\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Tree_proof_return.Proof.verify_promise Tree_proof_return.examples )\n )\n\n module Add_one_return = struct\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise ()\n ~public_input:(Input_and_output (Field.typ, Field.typ))\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = []\n ; main =\n (fun { public_input = x } ->\n dummy_constraints () ;\n { previous_proof_statements = []\n ; public_output = Field.(add one) x\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let input = Field.Constant.of_int 42 in\n let res, (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step input) )\n in\n assert (Field.Constant.(equal (of_int 43)) res) ;\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ ((input, res), b0) ] ) ) ;\n ((input, res), b0)\n\n let _example_input, _example_proof = example\n end\n\n module Auxiliary_return = struct\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise ()\n ~public_input:(Input_and_output (Field.typ, Field.typ))\n ~auxiliary_typ:Field.typ\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = []\n ; main =\n (fun { public_input = input } ->\n dummy_constraints () ;\n let sponge =\n Step_main_inputs.Sponge.create\n Step_main_inputs.sponge_params\n in\n let blinding_value =\n exists Field.typ ~compute:Field.Constant.random\n in\n Step_main_inputs.Sponge.absorb sponge (`Field input) ;\n Step_main_inputs.Sponge.absorb sponge\n (`Field blinding_value) ;\n let result = Step_main_inputs.Sponge.squeeze sponge in\n { previous_proof_statements = []\n ; public_output = result\n ; auxiliary_output = blinding_value\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let input = Field.Constant.of_int 42 in\n let result, blinding_value, b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step input) )\n in\n let sponge =\n Tick_field_sponge.Field.create Tick_field_sponge.params\n in\n Tick_field_sponge.Field.absorb sponge input ;\n Tick_field_sponge.Field.absorb sponge blinding_value ;\n let result' = Tick_field_sponge.Field.squeeze sponge in\n assert (Field.Constant.equal result result') ;\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ ((input, result), b0) ] ) ) ;\n ((input, result), b0)\n\n let _example_input, _example_proof = example\n end\n end )\n\n let%test_module \"test uncorrelated bulletproof_challenges\" =\n ( module struct\n let () = Backtrace.elide := false\n\n let () = Snarky_backendless.Snark0.set_eval_constraints true\n\n module Statement = struct\n type t = unit\n\n let to_field_elements () = [||]\n end\n\n module A = Statement\n module A_value = Statement\n\n let typ = Impls.Step.Typ.unit\n\n module Branches = Nat.N1\n module Max_proofs_verified = Nat.N2\n\n let constraint_constants : Snark_keys_header.Constraint_constants.t =\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n\n let tag =\n let tagname = \"\" in\n Tag.create ~kind:Compiled tagname\n\n let rule : _ Inductive_rule.t =\n let open Impls.Step in\n { identifier = \"main\"\n ; prevs = [ tag; tag ]\n ; main =\n (fun { public_input = () } ->\n let dummy_proof =\n As_prover.Ref.create (fun () ->\n Proof0.dummy Nat.N2.n Nat.N2.n Nat.N2.n ~domain_log2:15 )\n in\n { previous_proof_statements =\n [ { public_input = ()\n ; proof = dummy_proof\n ; proof_must_verify = Boolean.false_\n }\n ; { public_input = ()\n ; proof = dummy_proof\n ; proof_must_verify = Boolean.false_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n ; feature_flags = Plonk_types.Features.none_bool\n }\n\n module M = struct\n module IR = Inductive_rule.T (A) (A_value) (A) (A_value) (A) (A_value)\n\n let max_local_max_proofs_verifieds ~self (type n)\n (module Max_proofs_verified : Nat.Intf with type n = n) branches\n choices =\n let module Local_max_proofs_verifieds = struct\n type t = (int, Max_proofs_verified.n) Vector.t\n end in\n let module M =\n H4.Map (IR) (E04 (Local_max_proofs_verifieds))\n (struct\n module V = H4.To_vector (Int)\n module HT = H4.T (Tag)\n\n module M =\n H4.Map (Tag) (E04 (Int))\n (struct\n let f (type a b c d) (t : (a, b, c, d) Tag.t) : int =\n if Type_equal.Id.same t.id self then\n Nat.to_int Max_proofs_verified.n\n else\n let (module M) = Types_map.max_proofs_verified t in\n Nat.to_int M.n\n end)\n\n let f :\n type a b c d.\n (a, b, c, d) IR.t -> Local_max_proofs_verifieds.t =\n fun rule ->\n let (T (_, l)) = HT.length rule.prevs in\n Vector.extend_front_exn\n (V.f l (M.f rule.prevs))\n Max_proofs_verified.n 0\n end)\n in\n let module V = H4.To_vector (Local_max_proofs_verifieds) in\n let padded = V.f branches (M.f choices) |> Vector.transpose in\n (padded, Maxes.m padded)\n\n module Lazy_keys = struct\n type t =\n (Impls.Step.Keypair.t * Dirty.t) Lazy.t\n * (Kimchi_bindings.Protocol.VerifierIndex.Fp.t * Dirty.t) Lazy.t\n\n (* TODO Think this is right.. *)\n end\n\n let compile :\n ( unit\n -> (Max_proofs_verified.n, Max_proofs_verified.n) Proof.t Promise.t\n )\n * _\n * _ =\n let self = tag in\n let snark_keys_header kind constraint_system_hash =\n { Snark_keys_header.header_version =\n Snark_keys_header.header_version\n ; kind\n ; constraint_constants\n ; commits =\n { mina = Mina_version.commit_id\n ; marlin = Mina_version.marlin_commit_id\n }\n ; length = (* This is a dummy, it gets filled in on read/write. *) 0\n ; commit_date = Mina_version.commit_date\n ; constraint_system_hash\n ; identifying_hash =\n (* TODO: Proper identifying hash. *)\n constraint_system_hash\n }\n in\n let T = Max_proofs_verified.eq in\n let prev_varss_n = Branches.n in\n let prev_varss_length : _ Length.t = S Z in\n let T = Nat.eq_exn prev_varss_n Branches.n in\n let padded, (module Maxes) =\n max_local_max_proofs_verifieds\n (module Max_proofs_verified)\n prev_varss_length [ rule ] ~self:self.id\n in\n let full_signature =\n { Full_signature.padded; maxes = (module Maxes) }\n in\n let feature_flags = Plonk_types.Features.Full.none in\n let actual_feature_flags = Plonk_types.Features.none_bool in\n let wrap_domains =\n let module M =\n Wrap_domains.Make (A) (A_value) (A) (A_value) (A) (A_value)\n in\n M.f full_signature prev_varss_n prev_varss_length ~feature_flags\n ~max_proofs_verified:(module Max_proofs_verified)\n in\n let module Branch_data = struct\n type ('vars, 'vals, 'n, 'm) t =\n ( A.t\n , A_value.t\n , A.t\n , A_value.t\n , A.t\n , A_value.t\n , Max_proofs_verified.n\n , Branches.n\n , 'vars\n , 'vals\n , 'n\n , 'm )\n Step_branch_data.t\n end in\n let proofs_verifieds = Vector.singleton 2 in\n let (T inner_step_data as step_data) =\n Step_branch_data.create ~index:0 ~feature_flags\n ~actual_feature_flags ~max_proofs_verified:Max_proofs_verified.n\n ~branches:Branches.n ~self ~public_input:(Input typ)\n ~auxiliary_typ:typ A.to_field_elements A_value.to_field_elements\n rule ~wrap_domains ~proofs_verifieds\n in\n let step_domains = Vector.singleton inner_step_data.domains in\n let step_keypair =\n let etyp =\n Impls.Step.input ~proofs_verified:Max_proofs_verified.n\n ~wrap_rounds:Tock.Rounds.n\n in\n let (T (typ, _conv, conv_inv)) = etyp in\n let main () () =\n let res = inner_step_data.main ~step_domains () in\n Impls.Step.with_label \"conv_inv\" (fun () -> conv_inv res)\n in\n let open Impls.Step in\n let k_p =\n lazy\n (let cs =\n constraint_system ~input_typ:Typ.unit ~return_typ:typ main\n in\n let cs_hash = Md5.to_hex (R1CS_constraint_system.digest cs) in\n ( Type_equal.Id.uid self.id\n , snark_keys_header\n { type_ = \"step-proving-key\"\n ; identifier = inner_step_data.rule.identifier\n }\n cs_hash\n , inner_step_data.index\n , cs ) )\n in\n let k_v =\n lazy\n (let id, _header, index, cs = Lazy.force k_p in\n let digest = R1CS_constraint_system.digest cs in\n ( id\n , snark_keys_header\n { type_ = \"step-verification-key\"\n ; identifier = inner_step_data.rule.identifier\n }\n (Md5.to_hex digest)\n , index\n , digest ) )\n in\n Cache.Step.read_or_generate\n ~prev_challenges:\n (Nat.to_int (fst inner_step_data.proofs_verified))\n [] k_p k_v\n (Snarky_backendless.Typ.unit ())\n typ main\n in\n let step_vks =\n lazy\n (Vector.map [ step_keypair ] ~f:(fun (_, vk) ->\n Tick.Keypair.vk_commitments (fst (Lazy.force vk)) ) )\n in\n let wrap_main _ =\n let module SC' = SC in\n let open Impls.Wrap in\n let open Wrap_main_inputs in\n let x =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3)\n in\n let y =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 0)\n in\n let z =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 0)\n in\n let g = Inner_curve.one in\n let sponge = Sponge.create sponge_params in\n Sponge.absorb sponge x ;\n ignore (Sponge.squeeze_field sponge : Field.t) ;\n ignore\n ( SC'.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore\n (Ops.scale_fast g ~num_bits:5 (Shifted_value x) : Inner_curve.t) ;\n ignore\n ( Wrap_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t ) ;\n for _i = 0 to 64000 do\n assert_r1cs x y z\n done\n in\n let (wrap_pk, wrap_vk), disk_key =\n let open Impls.Wrap in\n let (T (typ, conv, _conv_inv)) = input ~feature_flags () in\n let main x () : unit = wrap_main (conv x) in\n let self_id = Type_equal.Id.uid self.id in\n let disk_key_prover =\n lazy\n (let cs =\n constraint_system ~input_typ:typ ~return_typ:Typ.unit main\n in\n let cs_hash = Md5.to_hex (R1CS_constraint_system.digest cs) in\n ( self_id\n , snark_keys_header\n { type_ = \"wrap-proving-key\"; identifier = \"\" }\n cs_hash\n , cs ) )\n in\n let disk_key_verifier =\n lazy\n (let id, _header, cs = Lazy.force disk_key_prover in\n let digest = R1CS_constraint_system.digest cs in\n ( id\n , snark_keys_header\n { type_ = \"wrap-verification-key\"; identifier = \"\" }\n (Md5.to_hex digest)\n , digest ) )\n in\n let r =\n Common.time \"wrap read or generate \" (fun () ->\n Cache.Wrap.read_or_generate ~prev_challenges:2 []\n disk_key_prover disk_key_verifier typ Typ.unit main )\n in\n (r, disk_key_verifier)\n in\n let wrap_vk = Lazy.map wrap_vk ~f:fst in\n let module S = Step.Make (A) (A_value) (Max_proofs_verified) in\n let prover =\n let f :\n ( unit * (unit * unit)\n , unit * (unit * unit)\n , Nat.N2.n * (Nat.N2.n * unit)\n , Nat.N1.n * (Nat.N1.n * unit) )\n Branch_data.t\n -> Lazy_keys.t\n -> unit\n -> (Max_proofs_verified.n, Max_proofs_verified.n) Proof.t\n Promise.t =\n fun (T b as branch_data) (step_pk, step_vk) () ->\n let (_ : (Max_proofs_verified.n, Maxes.ns) Requests.Wrap.t) =\n Requests.Wrap.create ()\n in\n let _, prev_vars_length = b.proofs_verified in\n let step =\n let wrap_vk = Lazy.force wrap_vk in\n S.f branch_data () ~feature_flags ~prevs_length:prev_vars_length\n ~self ~public_input:(Input typ)\n ~auxiliary_typ:Impls.Step.Typ.unit ~step_domains\n ~self_dlog_plonk_index:wrap_vk.commitments\n (Impls.Step.Keypair.pk (fst (Lazy.force step_pk)))\n wrap_vk.index\n in\n let pairing_vk = fst (Lazy.force step_vk) in\n let wrap =\n let wrap_vk = Lazy.force wrap_vk in\n let%bind.Promise proof, (), (), _ =\n step ~proof_cache:None ~maxes:(module Maxes)\n in\n let proof =\n { proof with\n statement =\n { proof.statement with\n messages_for_next_wrap_proof =\n Compile.pad_messages_for_next_wrap_proof\n (module Maxes)\n proof.statement.messages_for_next_wrap_proof\n }\n }\n in\n let%map.Promise proof =\n (* The prover for wrapping a proof *)\n let wrap (type actual_branching)\n ~(max_proofs_verified : Max_proofs_verified.n Nat.t)\n (module Max_local_max_proofs_verifieds : Hlist.Maxes.S\n with type ns = Maxes.ns\n and type length = Max_proofs_verified.n )\n ~dlog_plonk_index wrap_main to_field_elements ~pairing_vk\n ~step_domains:_ ~wrap_domains:_ ~pairing_plonk_indices:_\n pk\n ({ statement = prev_statement\n ; prev_evals = _\n ; proof\n ; index = _which_index\n } :\n ( _\n , _\n , (_, actual_branching) Vector.t\n , (_, actual_branching) Vector.t\n , Maxes.ns\n H1.T\n (P.Base.Messages_for_next_proof_over_same_field.Wrap)\n .t\n , ( ( Tock.Field.t\n , Tock.Field.t array )\n Plonk_types.All_evals.t\n , Max_proofs_verified.n )\n Vector.t )\n P.Base.Step.t ) =\n let prev_messages_for_next_wrap_proof =\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap)\n (P.Base.Messages_for_next_proof_over_same_field.Wrap\n .Prepared)\n (struct\n let f =\n P.Base.Messages_for_next_proof_over_same_field\n .Wrap\n .prepare\n end)\n in\n M.f prev_statement.messages_for_next_wrap_proof\n in\n let prev_statement_with_hashes : _ Types.Step.Statement.t =\n { proof_state =\n { prev_statement.proof_state with\n messages_for_next_step_proof =\n (* TODO: Careful here... the length of\n old_buletproof_challenges inside the messages_for_next_wrap_proof\n might not be correct *)\n Common.hash_messages_for_next_step_proof\n ~app_state:to_field_elements\n (P.Base.Messages_for_next_proof_over_same_field\n .Step\n .prepare ~dlog_plonk_index\n prev_statement.proof_state\n .messages_for_next_step_proof )\n }\n ; messages_for_next_wrap_proof =\n (let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field\n .Wrap\n .Prepared)\n (E01 (Digest.Constant))\n (struct\n let f (type n)\n (m :\n n\n P.Base\n .Messages_for_next_proof_over_same_field\n .Wrap\n .Prepared\n .t ) =\n let T =\n Nat.eq_exn max_proofs_verified\n (Vector.length\n m.old_bulletproof_challenges )\n in\n Wrap_hack.hash_messages_for_next_wrap_proof\n max_proofs_verified m\n end)\n in\n let module V = H1.To_vector (Digest.Constant) in\n V.f Max_local_max_proofs_verifieds.length\n (M.f prev_messages_for_next_wrap_proof) )\n }\n in\n let module O = Tick.Oracles in\n let public_input =\n tick_public_input_of_statement ~max_proofs_verified\n prev_statement_with_hashes\n in\n let prev_challenges =\n Vector.map ~f:Ipa.Step.compute_challenges\n prev_statement.proof_state.messages_for_next_step_proof\n .old_bulletproof_challenges\n in\n let actual_proofs_verified =\n Vector.length prev_challenges\n in\n let lte =\n Nat.lte_exn actual_proofs_verified\n (Length.to_nat Max_local_max_proofs_verifieds.length)\n in\n let o =\n let sgs =\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap\n .Prepared)\n (E01 (Tick.Curve.Affine))\n (struct\n let f :\n type n.\n n\n P.Base\n .Messages_for_next_proof_over_same_field\n .Wrap\n .Prepared\n .t\n -> _ =\n fun t -> t.challenge_polynomial_commitment\n end)\n in\n let module V = H1.To_vector (Tick.Curve.Affine) in\n V.f Max_local_max_proofs_verifieds.length\n (M.f prev_messages_for_next_wrap_proof)\n in\n O.create pairing_vk\n Vector.(\n map2 (Vector.trim_front sgs lte) prev_challenges\n ~f:(fun commitment cs ->\n { Tick.Proof.Challenge_polynomial.commitment\n ; challenges = Vector.to_array cs\n } )\n |> to_list)\n public_input proof\n in\n let x_hat = O.(p_eval_1 o, p_eval_2 o) in\n let step_vk, _ = Lazy.force step_vk in\n let next_statement : _ Types.Wrap.Statement.In_circuit.t =\n let scalar_chal f =\n Scalar_challenge.map ~f:Challenge.Constant.of_tick_field\n (f o)\n in\n let sponge_digest_before_evaluations =\n O.digest_before_evaluations o\n in\n let plonk0 =\n { Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal\n .alpha = scalar_chal O.alpha\n ; beta = O.beta o\n ; gamma = O.gamma o\n ; zeta = scalar_chal O.zeta\n ; joint_combiner =\n Option.map (O.joint_combiner_chal o)\n ~f:\n (Scalar_challenge.map\n ~f:Challenge.Constant.of_tick_field )\n ; feature_flags = Plonk_types.Features.none_bool\n }\n in\n let r = scalar_chal O.u in\n let xi = scalar_chal O.v in\n let to_field =\n SC.to_field_constant\n (module Tick.Field)\n ~endo:Endo.Wrap_inner_curve.scalar\n in\n let module As_field = struct\n let r = to_field r\n\n let xi = to_field xi\n\n let zeta = to_field plonk0.zeta\n\n let alpha = to_field plonk0.alpha\n\n let joint_combiner =\n Option.map ~f:to_field plonk0.joint_combiner\n end in\n let domain =\n Domain.Pow_2_roots_of_unity\n step_vk.domain.log_size_of_group\n in\n let w = step_vk.domain.group_gen in\n (* Debug *)\n [%test_eq: Tick.Field.t] w\n (Tick.Field.domain_generator\n ~log2_size:(Domain.log2_size domain) ) ;\n let zetaw = Tick.Field.mul As_field.zeta w in\n let tick_plonk_minimal =\n { plonk0 with\n zeta = As_field.zeta\n ; alpha = As_field.alpha\n ; joint_combiner = As_field.joint_combiner\n }\n in\n let tick_combined_evals =\n Plonk_checks.evals_of_split_evals\n (module Tick.Field)\n proof.openings.evals\n ~rounds:(Nat.to_int Tick.Rounds.n) ~zeta:As_field.zeta\n ~zetaw\n in\n let tick_domain =\n Plonk_checks.domain\n (module Tick.Field)\n domain ~shifts:Common.tick_shifts\n ~domain_generator:Backend.Tick.Field.domain_generator\n in\n let tick_combined_evals =\n Plonk_types.Evals.to_in_circuit tick_combined_evals\n in\n let tick_env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tick.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ =\n if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~endo:Endo.Step_inner_curve.base\n ~mds:Tick_field_sponge.params.mds\n ~srs_length_log2:Common.Max_degree.step_log2\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fp.of_bigint )\n ~domain:tick_domain tick_plonk_minimal\n tick_combined_evals\n in\n let combined_inner_product =\n let open As_field in\n Wrap.combined_inner_product\n (* Note: We do not pad here. *)\n ~actual_proofs_verified:\n (Nat.Add.create actual_proofs_verified)\n { evals = proof.openings.evals; public_input = x_hat }\n ~r ~xi ~zeta ~zetaw\n ~old_bulletproof_challenges:prev_challenges\n ~env:tick_env ~domain:tick_domain\n ~ft_eval1:proof.openings.ft_eval1\n ~plonk:tick_plonk_minimal\n in\n let chal = Challenge.Constant.of_tick_field in\n let sg_new, new_bulletproof_challenges, b =\n let prechals =\n Array.map (O.opening_prechallenges o) ~f:(fun x ->\n let x =\n Scalar_challenge.map\n ~f:Challenge.Constant.of_tick_field x\n in\n x )\n in\n let chals =\n Array.map prechals ~f:(fun x ->\n Ipa.Step.compute_challenge x )\n in\n let challenge_polynomial =\n unstage (Wrap.challenge_polynomial chals)\n in\n let open As_field in\n let b =\n let open Tick.Field in\n challenge_polynomial zeta\n + (r * challenge_polynomial zetaw)\n in\n let overwritten_prechals =\n Array.map prechals\n ~f:\n (Scalar_challenge.map ~f:(fun _ ->\n Challenge.Constant.of_tick_field\n (Impls.Step.Field.Constant.of_int 100) ) )\n in\n let chals =\n Array.map overwritten_prechals ~f:(fun x ->\n Ipa.Step.compute_challenge x )\n in\n let sg_new =\n let urs = Backend.Tick.Keypair.load_urs () in\n Kimchi_bindings.Protocol.SRS.Fp\n .batch_accumulator_generate urs 1 chals\n in\n let[@warning \"-4\"] sg_new =\n match sg_new with\n | [| Kimchi_types.Finite x |] ->\n x\n | _ ->\n assert false\n in\n let overwritten_prechals =\n Array.map overwritten_prechals\n ~f:Bulletproof_challenge.unpack\n in\n\n (sg_new, overwritten_prechals, b)\n in\n let plonk =\n let module Field = struct\n include Tick.Field\n end in\n Wrap.Type1.derive_plonk\n (module Field)\n ~shift:Shifts.tick1 ~env:tick_env tick_plonk_minimal\n tick_combined_evals\n in\n let shift_value =\n Shifted_value.Type1.of_field\n (module Tick.Field)\n ~shift:Shifts.tick1\n in\n let branch_data : Composition_types.Branch_data.t =\n { proofs_verified =\n ( match actual_proofs_verified with\n | Z ->\n Composition_types.Branch_data.Proofs_verified.N0\n | S Z ->\n N1\n | S (S Z) ->\n N2\n | S _ ->\n assert false )\n ; domain_log2 =\n Composition_types.Branch_data.Domain_log2.of_int_exn\n step_vk.domain.log_size_of_group\n }\n in\n let messages_for_next_wrap_proof :\n _\n P.Base.Messages_for_next_proof_over_same_field.Wrap.t\n =\n { challenge_polynomial_commitment = sg_new\n ; old_bulletproof_challenges =\n Vector.map\n prev_statement.proof_state.unfinalized_proofs\n ~f:(fun t ->\n t.deferred_values.bulletproof_challenges )\n }\n in\n { proof_state =\n { deferred_values =\n { xi\n ; b = shift_value b\n ; bulletproof_challenges =\n Vector.of_array_and_length_exn\n new_bulletproof_challenges Tick.Rounds.n\n ; combined_inner_product =\n shift_value combined_inner_product\n ; branch_data\n ; plonk =\n { plonk with\n zeta = plonk0.zeta\n ; alpha = plonk0.alpha\n ; beta = chal plonk0.beta\n ; gamma = chal plonk0.gamma\n ; joint_combiner = Opt.nothing\n }\n }\n ; sponge_digest_before_evaluations =\n Digest.Constant.of_tick_field\n sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n }\n ; messages_for_next_step_proof =\n prev_statement.proof_state\n .messages_for_next_step_proof\n }\n in\n let messages_for_next_wrap_proof_prepared =\n P.Base.Messages_for_next_proof_over_same_field.Wrap\n .prepare\n next_statement.proof_state.messages_for_next_wrap_proof\n in\n let%map.Promise next_proof =\n let (T (input, conv, _conv_inv)) =\n Impls.Wrap.input ~feature_flags ()\n in\n Common.time \"wrap proof\" (fun () ->\n Impls.Wrap.generate_witness_conv\n ~f:(fun { Impls.Wrap.Proof_inputs.auxiliary_inputs\n ; public_inputs\n } () ->\n Backend.Tock.Proof.create_async\n ~primary:public_inputs\n ~auxiliary:auxiliary_inputs pk\n ~message:\n ( Vector.map2\n (Vector.extend_front_exn\n prev_statement.proof_state\n .messages_for_next_step_proof\n .challenge_polynomial_commitments\n max_proofs_verified\n (Lazy.force Dummy.Ipa.Wrap.sg) )\n messages_for_next_wrap_proof_prepared\n .old_bulletproof_challenges\n ~f:(fun sg chals ->\n { Tock.Proof.Challenge_polynomial\n .commitment = sg\n ; challenges = Vector.to_array chals\n } )\n |> Wrap_hack.pad_accumulator ) )\n ~input_typ:input\n ~return_typ:(Snarky_backendless.Typ.unit ())\n (fun x () : unit -> wrap_main (conv x))\n { messages_for_next_step_proof =\n prev_statement_with_hashes.proof_state\n .messages_for_next_step_proof\n ; proof_state =\n { next_statement.proof_state with\n messages_for_next_wrap_proof =\n Wrap_hack.hash_messages_for_next_wrap_proof\n max_proofs_verified\n messages_for_next_wrap_proof_prepared\n ; deferred_values =\n { next_statement.proof_state.deferred_values with\n plonk =\n { next_statement.proof_state\n .deferred_values\n .plonk\n with\n joint_combiner = None\n }\n }\n }\n } )\n in\n ( { proof = Wrap_wire_proof.of_kimchi_proof next_proof.proof\n ; statement =\n Types.Wrap.Statement.to_minimal\n ~to_option:Opt.to_option next_statement\n ; prev_evals =\n { Plonk_types.All_evals.evals =\n { public_input = x_hat\n ; evals = proof.openings.evals\n }\n ; ft_eval1 = proof.openings.ft_eval1\n }\n }\n : _ P.Base.Wrap.t )\n in\n wrap ~max_proofs_verified:Max_proofs_verified.n\n full_signature.maxes ~dlog_plonk_index:wrap_vk.commitments\n wrap_main A_value.to_field_elements ~pairing_vk\n ~step_domains:b.domains\n ~pairing_plonk_indices:(Lazy.force step_vks) ~wrap_domains\n (Impls.Wrap.Keypair.pk (fst (Lazy.force wrap_pk)))\n proof\n in\n Proof.T\n { proof with\n statement =\n { proof.statement with\n messages_for_next_step_proof =\n { proof.statement.messages_for_next_step_proof with\n app_state = ()\n }\n }\n }\n in\n wrap\n in\n f step_data step_keypair\n in\n let data : _ Types_map.Compiled.t =\n { branches = Branches.n\n ; feature_flags\n ; proofs_verifieds\n ; max_proofs_verified = (module Max_proofs_verified)\n ; public_input = typ\n ; wrap_key = Lazy.map wrap_vk ~f:Verification_key.commitments\n ; wrap_vk = Lazy.map wrap_vk ~f:Verification_key.index\n ; wrap_domains\n ; step_domains\n }\n in\n Types_map.add_exn self data ;\n (prover, wrap_vk, disk_key)\n end\n\n let step, wrap_vk, wrap_disk_key = M.compile\n\n module Proof = struct\n module Max_local_max_proofs_verified = Max_proofs_verified\n include Proof.Make (Max_proofs_verified) (Max_local_max_proofs_verified)\n\n let _id = wrap_disk_key\n\n let verification_key = wrap_vk\n\n let verify ts =\n verify_promise\n (module Max_proofs_verified)\n (module A_value)\n (Lazy.force verification_key)\n ts\n\n let _statement (T p : t) =\n p.statement.messages_for_next_step_proof.app_state\n end\n\n let proof_with_stmt =\n let p = Promise.block_on_async_exn (fun () -> step ()) in\n ((), p)\n\n let%test \"should not be able to verify invalid proof\" =\n Or_error.is_error\n @@ Promise.block_on_async_exn (fun () ->\n Proof.verify [ proof_with_stmt ] )\n\n module Recurse_on_bad_proof = struct\n open Impls.Step\n\n let _dummy_proof =\n Proof0.dummy Nat.N2.n Nat.N2.n Nat.N2.n ~domain_log2:15\n\n type _ Snarky_backendless.Request.t +=\n | Proof : (Nat.N2.n, Nat.N2.n) Proof0.t Snarky_backendless.Request.t\n\n let handler (proof : _ Proof0.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Proof ->\n respond (Provide proof)\n | _ ->\n respond Unhandled\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Typ.unit)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"recurse-on-bad\" ~constraint_constants\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = [ tag; tag ]\n ; main =\n (fun { public_input = () } ->\n let proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Proof )\n in\n { previous_proof_statements =\n [ { public_input = ()\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ; { public_input = ()\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n end\n\n let%test \"should not be able to create a recursive proof from an invalid \\\n proof\" =\n try\n let (), (), proof =\n Promise.block_on_async_exn (fun () ->\n Recurse_on_bad_proof.step\n ~handler:(Recurse_on_bad_proof.handler (snd proof_with_stmt))\n () )\n in\n Or_error.is_error\n @@ Promise.block_on_async_exn (fun () ->\n Recurse_on_bad_proof.Proof.verify_promise [ ((), proof) ] )\n with _ -> true\n end )\n\n let%test_module \"adversarial_tests\" =\n ( module struct\n [@@@warning \"-60\"]\n\n let () = Backtrace.elide := false\n\n let () = Snarky_backendless.Snark0.set_eval_constraints true\n\n let%test_module \"test domain size too large\" =\n ( module Compile.Make_adversarial_test (struct\n let tweak_statement (stmt : _ Import.Types.Wrap.Statement.In_circuit.t)\n =\n (* Modify the statement to use an invalid domain size. *)\n { stmt with\n proof_state =\n { stmt.proof_state with\n deferred_values =\n { stmt.proof_state.deferred_values with\n branch_data =\n { stmt.proof_state.deferred_values.branch_data with\n Branch_data.domain_log2 =\n Branch_data.Domain_log2.of_int_exn\n (Nat.to_int Kimchi_pasta.Basic.Rounds.Step.n + 1)\n }\n }\n }\n }\n\n let check_verifier_error err =\n (* Convert to JSON to make it easy to parse. *)\n err |> Error_json.error_to_yojson\n |> Yojson.Safe.Util.member \"multiple\"\n |> Yojson.Safe.Util.to_list\n |> List.find_exn ~f:(fun json ->\n let error =\n json\n |> Yojson.Safe.Util.member \"string\"\n |> Yojson.Safe.Util.to_string\n in\n String.equal error \"domain size is small enough\" )\n |> fun _ -> ()\n end) )\n end )\n\n let%test_module \"domain too small\" =\n ( module struct\n open Impls.Step\n\n (* Currently, a circuit must have at least 1 of every type of constraint. *)\n let dummy_constraints () =\n Impl.(\n let x =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3)\n in\n let g =\n exists Step_main_inputs.Inner_curve.typ ~compute:(fun _ ->\n Tick.Inner_curve.(to_affine_exn one) )\n in\n ignore\n ( SC.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t ))\n\n module No_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n module Fake_1_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N1)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n module Fake_2_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~override_wrap_domain:Pickles_base.Proofs_verified.N1\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n [@@@warning \"-60\"]\n\n module Simple_chain = struct\n type _ Snarky_backendless.Request.t +=\n | Prev_input : Field.Constant.t Snarky_backendless.Request.t\n | Proof : Side_loaded.Proof.t Snarky_backendless.Request.t\n | Verifier_index :\n Side_loaded.Verification_key.t Snarky_backendless.Request.t\n\n let handler (prev_input : Field.Constant.t) (proof : _ Proof.t)\n (verifier_index : Side_loaded.Verification_key.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Prev_input ->\n respond (Provide prev_input)\n | Proof ->\n respond (Provide proof)\n | Verifier_index ->\n respond (Provide verifier_index)\n | _ ->\n respond Unhandled\n\n let side_loaded_tag =\n Side_loaded.create ~name:\"foo\"\n ~max_proofs_verified:(Nat.Add.create Nat.N2.n)\n ~feature_flags:Plonk_types.Features.none ~typ:Field.typ\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N1)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = [ side_loaded_tag ]\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n let prev =\n exists Field.typ ~request:(fun () -> Prev_input)\n in\n let proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Proof )\n in\n let vk =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Verifier_index )\n in\n as_prover (fun () ->\n let vk = As_prover.Ref.get vk in\n Side_loaded.in_prover side_loaded_tag vk ) ;\n let vk =\n exists Side_loaded_verification_key.typ\n ~compute:(fun () -> As_prover.Ref.get vk)\n in\n Side_loaded.in_circuit side_loaded_tag vk ;\n let is_base_case = Field.equal Field.zero self in\n let self_correct = Field.(equal (one + prev) self) in\n Boolean.Assert.any [ self_correct; is_base_case ] ;\n { previous_proof_statements =\n [ { public_input = prev\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let _example1 =\n let (), (), b1 =\n Common.time \"b1\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler No_recursion.example_input\n (Side_loaded.Proof.of_proof\n No_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n No_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b1) ] ) ) ;\n (Field.Constant.one, b1)\n\n let _example2 =\n let (), (), b2 =\n Common.time \"b2\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler Fake_1_recursion.example_input\n (Side_loaded.Proof.of_proof\n Fake_1_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n Fake_1_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b2) ] ) ) ;\n (Field.Constant.one, b2)\n\n let _example3 =\n let (), (), b3 =\n Common.time \"b3\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler Fake_2_recursion.example_input\n (Side_loaded.Proof.of_proof\n Fake_2_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n Fake_2_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b3) ] ) ) ;\n (Field.Constant.one, b3)\n end\n end )\n\n let%test_module \"side-loaded with feature flags\" =\n ( module struct\n open Impls.Step\n\n [@@@warning \"-60\"]\n\n module Statement = struct\n [@@@warning \"-32-34\"]\n\n type t = Field.t\n\n let to_field_elements x = [| x |]\n\n module Constant = struct\n type t = Field.Constant.t [@@deriving bin_io]\n\n [@@@warning \"-32\"]\n\n let to_field_elements x = [| x |]\n end\n end\n\n (* Currently, a circuit must have at least 1 of every type of constraint. *)\n let dummy_constraints () =\n Impl.(\n let x =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3)\n in\n let g =\n exists Step_main_inputs.Inner_curve.typ ~compute:(fun _ ->\n Tick.Inner_curve.(to_affine_exn one) )\n in\n ignore\n ( SC.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t ))\n\n module No_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n module Fake_1_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N1)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n module Fake_2_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~override_wrap_domain:Pickles_base.Proofs_verified.N1\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n [@@@warning \"-60\"]\n\n module Simple_chain = struct\n type _ Snarky_backendless.Request.t +=\n | Prev_input : Field.Constant.t Snarky_backendless.Request.t\n | Proof : Side_loaded.Proof.t Snarky_backendless.Request.t\n | Verifier_index :\n Side_loaded.Verification_key.t Snarky_backendless.Request.t\n\n let handler (prev_input : Field.Constant.t) (proof : _ Proof.t)\n (verifier_index : Side_loaded.Verification_key.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Prev_input ->\n respond (Provide prev_input)\n | Proof ->\n respond (Provide proof)\n | Verifier_index ->\n respond (Provide verifier_index)\n | _ ->\n respond Unhandled\n\n let maybe_features =\n Plonk_types.Features.(map none ~f:(fun _ -> Opt.Flag.Maybe))\n\n let side_loaded_tag =\n Side_loaded.create ~name:\"foo\"\n ~max_proofs_verified:(Nat.Add.create Nat.N2.n)\n ~feature_flags:maybe_features ~typ:Field.typ\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N1)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = [ side_loaded_tag ]\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n let prev =\n exists Field.typ ~request:(fun () -> Prev_input)\n in\n let proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Proof )\n in\n let vk =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Verifier_index )\n in\n as_prover (fun () ->\n let vk = As_prover.Ref.get vk in\n Side_loaded.in_prover side_loaded_tag vk ) ;\n let vk =\n exists Side_loaded_verification_key.typ\n ~compute:(fun () -> As_prover.Ref.get vk)\n in\n Side_loaded.in_circuit side_loaded_tag vk ;\n let is_base_case = Field.equal Field.zero self in\n let self_correct = Field.(equal (one + prev) self) in\n Boolean.Assert.any [ self_correct; is_base_case ] ;\n { previous_proof_statements =\n [ { public_input = prev\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let _example1 =\n let (), (), b1 =\n Common.time \"b1\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler No_recursion.example_input\n (Side_loaded.Proof.of_proof\n No_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n No_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b1) ] ) ) ;\n (Field.Constant.one, b1)\n\n let _example2 =\n let (), (), b2 =\n Common.time \"b2\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler Fake_1_recursion.example_input\n (Side_loaded.Proof.of_proof\n Fake_1_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n Fake_1_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b2) ] ) ) ;\n (Field.Constant.one, b2)\n\n let _example3 =\n let (), (), b3 =\n Common.time \"b3\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler Fake_2_recursion.example_input\n (Side_loaded.Proof.of_proof\n Fake_2_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n Fake_2_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b3) ] ) ) ;\n (Field.Constant.one, b3)\n end\n end )\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nmodule H_list = Snarky_backendless.H_list\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'comm t =\n { sigma_comm : 'comm Plonk_types.Permuts_vec.Stable.V1.t\n ; coefficients_comm : 'comm Plonk_types.Columns_vec.Stable.V1.t\n ; generic_comm : 'comm\n ; psm_comm : 'comm\n ; complete_add_comm : 'comm\n ; mul_comm : 'comm\n ; emul_comm : 'comm\n ; endomul_scalar_comm : 'comm\n }\n [@@deriving sexp, equal, compare, hash, yojson, hlist, fields]\n (* TODO: Remove unused annotations *)\n end\nend]\n\n(* TODO: Remove unused functions *)\n\nlet map\n { sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n } ~f =\n { sigma_comm = Vector.map ~f sigma_comm\n ; coefficients_comm = Vector.map ~f coefficients_comm\n ; generic_comm = f generic_comm\n ; psm_comm = f psm_comm\n ; complete_add_comm = f complete_add_comm\n ; mul_comm = f mul_comm\n ; emul_comm = f emul_comm\n ; endomul_scalar_comm = f endomul_scalar_comm\n }\n\nlet map2 t1 t2 ~f =\n { sigma_comm = Vector.map2 ~f t1.sigma_comm t2.sigma_comm\n ; coefficients_comm = Vector.map2 ~f t1.coefficients_comm t2.coefficients_comm\n ; generic_comm = f t1.generic_comm t2.generic_comm\n ; psm_comm = f t1.psm_comm t2.psm_comm\n ; complete_add_comm = f t1.complete_add_comm t2.complete_add_comm\n ; mul_comm = f t1.mul_comm t2.mul_comm\n ; emul_comm = f t1.emul_comm t2.emul_comm\n ; endomul_scalar_comm = f t1.endomul_scalar_comm t2.endomul_scalar_comm\n }\n\nlet typ g =\n Snarky_backendless.Typ.of_hlistable\n [ Vector.typ g Plonk_types.Permuts.n\n ; Vector.typ g Plonk_types.Columns.n\n ; g\n ; g\n ; g\n ; g\n ; g\n ; g\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\nmodule Step = struct\n type ('comm, 'opt_comm) t =\n { sigma_comm : 'comm Plonk_types.Permuts_vec.t\n ; coefficients_comm : 'comm Plonk_types.Columns_vec.t\n ; generic_comm : 'comm\n ; psm_comm : 'comm\n ; complete_add_comm : 'comm\n ; mul_comm : 'comm\n ; emul_comm : 'comm\n ; endomul_scalar_comm : 'comm\n ; xor_comm : 'opt_comm\n ; range_check0_comm : 'opt_comm\n ; range_check1_comm : 'opt_comm\n ; foreign_field_add_comm : 'opt_comm\n ; foreign_field_mul_comm : 'opt_comm\n ; rot_comm : 'opt_comm\n ; lookup_table_comm : 'opt_comm Plonk_types.Lookup_sorted_minus_1_vec.t\n ; lookup_table_ids : 'opt_comm\n ; runtime_tables_selector : 'opt_comm\n ; lookup_selector_lookup : 'opt_comm\n ; lookup_selector_xor : 'opt_comm\n ; lookup_selector_range_check : 'opt_comm\n ; lookup_selector_ffmul : 'opt_comm\n }\n [@@deriving sexp, equal, compare, hash, yojson, hlist, fields]\n\n let map\n { sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n ; xor_comm\n ; range_check0_comm\n ; range_check1_comm\n ; foreign_field_add_comm\n ; foreign_field_mul_comm\n ; rot_comm\n ; lookup_table_comm\n ; lookup_table_ids\n ; runtime_tables_selector\n ; lookup_selector_lookup\n ; lookup_selector_xor\n ; lookup_selector_range_check\n ; lookup_selector_ffmul\n } ~f ~f_opt =\n { sigma_comm = Vector.map ~f sigma_comm\n ; coefficients_comm = Vector.map ~f coefficients_comm\n ; generic_comm = f generic_comm\n ; psm_comm = f psm_comm\n ; complete_add_comm = f complete_add_comm\n ; mul_comm = f mul_comm\n ; emul_comm = f emul_comm\n ; endomul_scalar_comm = f endomul_scalar_comm\n ; xor_comm = f_opt xor_comm\n ; range_check0_comm = f_opt range_check0_comm\n ; range_check1_comm = f_opt range_check1_comm\n ; foreign_field_add_comm = f_opt foreign_field_add_comm\n ; foreign_field_mul_comm = f_opt foreign_field_mul_comm\n ; rot_comm = f_opt rot_comm\n ; lookup_table_comm = Vector.map ~f:f_opt lookup_table_comm\n ; lookup_table_ids = f_opt lookup_table_ids\n ; runtime_tables_selector = f_opt runtime_tables_selector\n ; lookup_selector_lookup = f_opt lookup_selector_lookup\n ; lookup_selector_xor = f_opt lookup_selector_xor\n ; lookup_selector_range_check = f_opt lookup_selector_range_check\n ; lookup_selector_ffmul = f_opt lookup_selector_ffmul\n }\n\n let map2 t1 t2 ~f ~f_opt =\n { sigma_comm = Vector.map2 ~f t1.sigma_comm t2.sigma_comm\n ; coefficients_comm =\n Vector.map2 ~f t1.coefficients_comm t2.coefficients_comm\n ; generic_comm = f t1.generic_comm t2.generic_comm\n ; psm_comm = f t1.psm_comm t2.psm_comm\n ; complete_add_comm = f t1.complete_add_comm t2.complete_add_comm\n ; mul_comm = f t1.mul_comm t2.mul_comm\n ; emul_comm = f t1.emul_comm t2.emul_comm\n ; endomul_scalar_comm = f t1.endomul_scalar_comm t2.endomul_scalar_comm\n ; xor_comm = f_opt t1.xor_comm t2.xor_comm\n ; range_check0_comm = f_opt t1.range_check0_comm t2.range_check0_comm\n ; range_check1_comm = f_opt t1.range_check1_comm t2.range_check1_comm\n ; foreign_field_add_comm =\n f_opt t1.foreign_field_add_comm t2.foreign_field_add_comm\n ; foreign_field_mul_comm =\n f_opt t1.foreign_field_mul_comm t2.foreign_field_mul_comm\n ; rot_comm = f_opt t1.rot_comm t2.rot_comm\n ; lookup_table_comm =\n Vector.map2 ~f:f_opt t1.lookup_table_comm t2.lookup_table_comm\n ; lookup_table_ids = f_opt t1.lookup_table_ids t2.lookup_table_ids\n ; runtime_tables_selector =\n f_opt t1.runtime_tables_selector t2.runtime_tables_selector\n ; lookup_selector_lookup =\n f_opt t1.lookup_selector_lookup t2.lookup_selector_lookup\n ; lookup_selector_xor = f_opt t1.lookup_selector_xor t2.lookup_selector_xor\n ; lookup_selector_range_check =\n f_opt t1.lookup_selector_range_check t2.lookup_selector_range_check\n ; lookup_selector_ffmul =\n f_opt t1.lookup_selector_ffmul t2.lookup_selector_ffmul\n }\n\n let typ g g_opt =\n Snarky_backendless.Typ.of_hlistable\n [ Vector.typ g Plonk_types.Permuts.n\n ; Vector.typ g Plonk_types.Columns.n\n ; g\n ; g\n ; g\n ; g\n ; g\n ; g\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ; Vector.typ g_opt Plonk_types.Lookup_sorted_minus_1.n\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n let forget_optional_commitments\n { sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n ; xor_comm = _\n ; range_check0_comm = _\n ; range_check1_comm = _\n ; foreign_field_add_comm = _\n ; foreign_field_mul_comm = _\n ; rot_comm = _\n ; lookup_table_comm = _\n ; lookup_table_ids = _\n ; runtime_tables_selector = _\n ; lookup_selector_lookup = _\n ; lookup_selector_xor = _\n ; lookup_selector_range_check = _\n ; lookup_selector_ffmul = _\n } : _ Stable.Latest.t =\n { sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n }\nend\n","open Core_kernel\nmodule Intf = Intf\n\nmodule Params = struct\n include Params\n\n let bn128 = Constants.params_Bn128\n\n let mnt4_298 = Constants.params_Mnt4_298\n\n let mnt4_753 = Constants.params_Mnt4_753\n\n let bn382_p = Constants.params_Bn382_p\n\n let bn382_q = Constants.params_Bn382_q\n\n let tweedle_p = Constants.params_Tweedle_p\n\n let tweedle_q = Constants.params_Tweedle_q\n\n let pasta_p_legacy = Constants.params_Pasta_p_legacy\n\n let pasta_q_legacy = Constants.params_Pasta_q_legacy\n\n let pasta_p_kimchi = Constants.params_Pasta_p_kimchi\n\n let pasta_q_kimchi = Constants.params_Pasta_q_kimchi\nend\n\nmodule State = Array\n\nlet for_ n ~init ~f =\n let rec go i acc = if Int.(i = n) then acc else go (i + 1) (f i acc) in\n go 0 init\n\nmodule Make_operations (Field : Intf.Field) = struct\n let add_assign ~state i x = state.(i) <- Field.( + ) state.(i) x\n\n let apply_affine_map (matrix, constants) v =\n let dotv row =\n Array.reduce_exn (Array.map2_exn row v ~f:Field.( * )) ~f:Field.( + )\n in\n let res = Array.map matrix ~f:dotv in\n for i = 0 to Array.length res - 1 do\n res.(i) <- Field.( + ) res.(i) constants.(i)\n done ;\n res\n\n let copy = Array.copy\nend\n\nlet m = 3\n\nmodule Bn382_inputs (Field : Intf.Field_mutable) = struct\n let rounds_full = 8\n\n let initial_ark = true\n\n let rounds_partial = 30\n\n module Field = Field\n\n let alpha = 17\n\n (* alpha = 17 *)\n let to_the_alpha x =\n let open Field in\n let res = square x in\n Mutable.square res ;\n (* x^4 *)\n Mutable.square res ;\n (* x^8 *)\n Mutable.square res ;\n (* x^16 *)\n res *= x ;\n res\n\n module Operations = struct\n let add_assign ~state i x = Field.(state.(i) += x)\n\n (* Sparse pseudo-MDS matrix *)\n let apply_affine_map (_rows, c) v =\n let open Field in\n let res = [| v.(0) + v.(2); v.(0) + v.(1); v.(1) + v.(2) |] in\n Array.iteri res ~f:(fun i ri -> ri += c.(i)) ;\n res\n\n let copy a = Array.map a ~f:(fun x -> Field.(x + zero))\n end\nend\n\nmodule Rescue (Inputs : Intf.Inputs.Rescue) = struct\n (*\n We refer below to this paper: https://eprint.iacr.org/2019/426.pdf.\n\nI arrived at this value for the number of rounds in the following way.\nAs mentioned on page 34, the cost of performing the Grobner basis attack is estimated as\n\n( (n + d) choose d ) ^ omega\nwhere\n\n- omega is some number which is known to be >= 2\n- n = 1 + m*N is the number of variables in the system of equations on page 3\n- d is a quantity which they estimate as ((alpha - 1)(m*N + 1) + 1) / 2\n- m is the state size, which we can choose\n- N is the number of rounds which we can choose\n\nFor the MNT curves, `alpha = 11`, and I took `m = 3` which is optimal for binary Merkle trees.\nEvaluating the above formula with these values and `N = 11` and `omega = 2` yields an attack complexity\nof a little over 2^257, which if we take the same factor of 2 security margin as they use in the paper,\ngives us a security level of 257/2 ~= 128.\n\nNB: As you can see from the analysis this is really specialized to alpha = 11 and the number of rounds\nshould be higher for smaller alpha.\n*)\n\n open Inputs\n include Operations\n module Field = Field\n\n let sbox0, sbox1 = (alphath_root, to_the_alpha)\n\n let add_block ~state block = Array.iteri block ~f:(add_assign ~state)\n\n let block_cipher { Params.round_constants; mds } state =\n add_block ~state round_constants.(0) ;\n for_ (2 * rounds) ~init:state ~f:(fun r state ->\n let sbox = if Int.(r mod 2 = 0) then sbox0 else sbox1 in\n Array.map_inplace state ~f:sbox ;\n apply_affine_map (mds, round_constants.(r + 1)) state )\nend\n\nmodule Poseidon (Inputs : Intf.Inputs.Poseidon) = struct\n open Inputs\n include Operations\n module Field = Field\n\n let first_half_rounds_full = rounds_full / 2\n\n let add_block ~state block = Array.iteri block ~f:(add_assign ~state)\n\n (* Poseidon goes\n\n ARK_0 -> SBOX -> MDS\n -> ARK_1 -> SBOX -> MDS\n -> ...\n -> ARK_{half_rounds_full - 1} -> SBOX -> MDS\n -> ARK_{half_rounds_full} -> SBOX0 -> MDS\n -> ...\n -> ARK_{half_rounds_full + rounds_partial - 1} -> SBOX0 -> MDS\n -> ARK_{half_rounds_full + rounds_partial} -> SBOX -> MDS\n -> ...\n -> ARK_{half_rounds_full + rounds_partial + half_rounds_full - 1} -> SBOX -> MDS\n\n It is best to apply the matrix and add the round constants at the same\n time for Marlin constraint efficiency, so that is how this implementation does it.\n Like,\n\n ARK_0\n -> SBOX -> (MDS -> ARK_1)\n -> SBOX -> (MDS -> ARK_2)\n -> ...\n -> SBOX -> (MDS -> ARK_{half_rounds_full - 1})\n -> SBOX -> (MDS -> ARK_{half_rounds_full})\n -> SBOX0 -> (MDS -> ARK_{half_rounds_full + 1})\n -> ...\n -> SBOX0 -> (MDS -> ARK_{half_rounds_full + rounds_partial - 1})\n -> SBOX0 -> (MDS -> ARK_{half_rounds_full + rounds_partial})\n -> SBOX -> (MDS -> ARK_{half_rounds_full + rounds_partial + 1})\n -> ...\n -> SBOX -> (MDS -> ARK_{half_rounds_full + rounds_partial + half_rounds_full - 1})\n -> SBOX -> MDS ->* ARK_{half_rounds_full + rounds_partial + half_rounds_full}\n\n *this last round is a deviation from standard poseidon made for efficiency reasons.\n clearly it does not impact security to add round constants\n *)\n let block_cipher { Params.round_constants; mds } state =\n let sbox = to_the_alpha in\n let state = ref state in\n let constant_offset =\n if initial_ark then (\n add_block ~state:!state round_constants.(0) ;\n 1 )\n else 0\n in\n let range =\n (constant_offset, constant_offset + first_half_rounds_full - 1)\n in\n for i = fst range to snd range do\n (* SBOX -> MDS -> ARK *)\n Array.map_inplace !state ~f:sbox ;\n state := apply_affine_map (mds, round_constants.(i)) !state\n done ;\n let range = (snd range + 1, snd range + rounds_partial) in\n for i = fst range to snd range do\n !state.(0) <- sbox !state.(0) ;\n state := apply_affine_map (mds, round_constants.(i)) !state\n done ;\n let second_half_rounds_full = rounds_full - first_half_rounds_full in\n let range = (snd range + 1, snd range + second_half_rounds_full) in\n for i = fst range to snd range do\n Array.map_inplace !state ~f:sbox ;\n state := apply_affine_map (mds, round_constants.(i)) !state\n done ;\n !state\nend\n\nmodule Make_hash (P : Intf.Permutation) = struct\n open P\n\n let state_size = m\n\n let rate = state_size - 1\n\n let add_block ~state block = Array.iteri block ~f:(add_assign ~state)\n\n let sponge perm blocks ~state =\n Array.fold ~init:state blocks ~f:(fun state block ->\n add_block ~state block ; perm state )\n\n (* takes an array of field elements, and spread them into blocks/arrays that can contain [rate] fied elements *)\n let to_blocks rate field_elems =\n let n = Array.length field_elems in\n let num_blocks = if n = 0 then 1 else (n + rate - 1) / rate in\n let fill_block block_idx pos =\n let global_pos = (rate * block_idx) + pos in\n if global_pos < n then field_elems.(global_pos)\n else (* padding *) Field.zero\n in\n let create_block idx = Array.init rate ~f:(fill_block idx) in\n Array.init num_blocks ~f:create_block\n\n let%test_unit \"empty field_elems to_blocks\" =\n let blocks = to_blocks 2 [||] in\n assert (Array.length blocks = 1) ;\n [%test_eq: unit array array]\n (Array.map blocks ~f:(Array.map ~f:ignore))\n [| [| (); () |] |]\n\n let%test_unit \"block\" =\n let z = Field.zero in\n [%test_eq: unit array array]\n (Array.map (to_blocks 2 [| z; z; z |]) ~f:(Array.map ~f:ignore))\n [| [| (); () |]; [| (); () |] |]\n\n let update params ~state inputs =\n let state = copy state in\n sponge (block_cipher params) (to_blocks rate inputs) ~state\n\n let digest state = state.(0)\n\n let initial_state = Array.init state_size ~f:(fun _ -> Field.zero)\n\n let hash ?(init = initial_state) params inputs =\n update params ~state:init inputs |> digest\nend\n\ntype sponge_state = Absorbed of int | Squeezed of int [@@deriving sexp]\n\ntype 'f t =\n { mutable state : 'f State.t\n ; params : 'f Params.t\n ; mutable sponge_state : sponge_state\n ; id : int\n }\n\nlet id = ref (-1)\n\nlet make ~state ~params ~sponge_state =\n incr id ;\n { state; params; sponge_state; id = !id }\n\nmodule Make_sponge (P : Intf.Permutation) = struct\n open P\n\n let make = make\n\n let capacity = 1\n\n type sponge_state = Absorbed of int | Squeezed of int [@@deriving sexp]\n\n type nonrec t = Field.t t\n\n let state { state; _ } = copy state\n\n let initial_state = Array.init m ~f:(fun _ -> Field.zero)\n\n let create ?(init = initial_state) params =\n make ~state:(copy init) ~sponge_state:(Absorbed 0) ~params\n\n let copy { state; params; sponge_state; id } =\n { state = copy state; params; sponge_state; id }\n\n let rate = m - capacity\n\n let absorb t x =\n match t.sponge_state with\n | Absorbed n ->\n if n = rate then (\n t.state <- block_cipher t.params t.state ;\n add_assign ~state:t.state 0 x ;\n t.sponge_state <- Absorbed 1 )\n else (\n add_assign ~state:t.state n x ;\n t.sponge_state <- Absorbed (n + 1) )\n | Squeezed _ ->\n add_assign ~state:t.state 0 x ;\n t.sponge_state <- Absorbed 1\n\n let squeeze t =\n (* to prevent giving a reference to the internal state *)\n let copy x = (P.copy [| x |]).(0) in\n match t.sponge_state with\n | Squeezed n ->\n if n = rate then (\n t.state <- block_cipher t.params t.state ;\n t.sponge_state <- Squeezed 1 ;\n copy t.state.(0) )\n else (\n t.sponge_state <- Squeezed (n + 1) ;\n copy t.state.(n) )\n | Absorbed _ ->\n t.state <- block_cipher t.params t.state ;\n t.sponge_state <- Squeezed 1 ;\n copy t.state.(0)\nend\n\nmodule Make_debug_sponge (P : sig\n include Intf.Permutation\n\n module Circuit : Snarky_backendless.Snark_intf.Run\n\n val sponge_name : string\n\n val debug_helper_fn : Field.t -> string\nend) =\nstruct\n include Make_sponge (P)\n\n (* In sponge debug mode, prints a standard sponge debug line, otherwise does nothing.\n Note: standard sponge debug line must match the output of Kimchi's sponge debug mode *)\n let debug (operation : string) (sponge : t) (input : P.Field.t option) =\n match Sys.getenv_opt P.sponge_name with\n | Some s -> (\n match String.lowercase s with\n | \"t\" | \"1\" | \"true\" ->\n P.Circuit.as_prover (fun () ->\n (* Convert sponge_state to match Rust style debug string *)\n let sponge_state =\n match sponge.sponge_state with\n | Absorbed n ->\n Printf.sprintf \"Absorbed(%d)\" n\n | Squeezed n ->\n Printf.sprintf \"Squeezed(%d)\" n\n in\n (* Print debug header, operation and sponge_state *)\n Format.eprintf \"debug_sponge: %s%d %s state %s\" P.sponge_name\n sponge.id operation sponge_state ;\n (* Print sponge's state array *)\n Array.iter sponge.state ~f:(fun fe ->\n Format.eprintf \" %s\" (P.debug_helper_fn fe) ) ;\n Format.eprintf \"@.\" ;\n (* Print optional input *)\n match input with\n | Some input ->\n Format.eprintf \"debug_sponge: %s%d %s input %s@.\"\n P.sponge_name sponge.id operation\n (P.debug_helper_fn input)\n | None ->\n () )\n | _ ->\n () )\n | None ->\n ()\n\n let make ~state ~params ~sponge_state =\n let t = make ~state ~params ~sponge_state in\n debug \"make\" t None ; t\n\n let absorb t x = debug \"absorb\" t (Some x) ; absorb t x\n\n let squeeze t = debug \"squeeze\" t None ; squeeze t\nend\n\nmodule Bit_sponge = struct\n type ('s, 'bool) t =\n { underlying : 's\n (* TODO: Have to be careful about these bits. They aren't perfectly uniform. *)\n ; mutable last_squeezed : 'bool list\n }\n\n let map (type a b) t ~(f : a -> b) : (b, _) t =\n { t with underlying = f t.underlying }\n\n let make ?(last_squeezed = []) underlying = { underlying; last_squeezed }\n\n let underlying { underlying; last_squeezed = _ } = underlying\n\n module Make\n (Bool : Intf.T) (Field : sig\n type t\n\n val to_bits : t -> Bool.t list\n\n val finalize_discarded : Bool.t list -> unit\n\n val high_entropy_bits : int\n end)\n (Input : Intf.T)\n (S : Intf.Sponge\n with module State := State\n and module Field := Field\n and type digest := Field.t\n and type input := Input.t) =\n struct\n type nonrec t = (S.t, Bool.t) t\n\n let state t = S.state t.underlying\n\n let high_entropy_bits = Field.high_entropy_bits\n\n let create ?init params =\n { underlying = S.create ?init params; last_squeezed = [] }\n\n let copy { underlying; last_squeezed } =\n { underlying = S.copy underlying; last_squeezed }\n\n let absorb t x =\n S.absorb t.underlying x ;\n t.last_squeezed <- []\n\n let rec squeeze t ~length =\n if List.length t.last_squeezed >= length then (\n let digest, remaining = List.split_n t.last_squeezed length in\n t.last_squeezed <- remaining ;\n digest )\n else\n let x = S.squeeze t.underlying in\n let hi =\n let hi, lo = List.split_n (Field.to_bits x) high_entropy_bits in\n Field.finalize_discarded lo ;\n hi\n in\n t.last_squeezed <- t.last_squeezed @ hi ;\n squeeze ~length t\n\n let squeeze_field t =\n t.last_squeezed <- [] ;\n S.squeeze t.underlying\n end\nend\n","open! Core_kernel\nopen! Import\nopen Tuple_pool_intf\nmodule Tuple_type = Tuple_type\n\nlet failwiths = Error.failwiths\nlet phys_equal = Caml.( == )\nlet arch_sixtyfour = Sys.word_size = 64\n\nmodule Int = struct\n let num_bits = Int.num_bits\n let max_value = Caml.max_int\n let to_string = string_of_int\nend\n\nlet sprintf = Printf.sprintf\nlet concat l = Base.String.concat ~sep:\"\" l\n\nmodule type S = S\n\nmodule Pool = struct\n let grow_capacity ~capacity ~old_capacity =\n match capacity with\n | None -> if old_capacity = 0 then 1 else old_capacity * 2\n | Some capacity ->\n if capacity <= old_capacity\n then\n failwiths\n ~here:[%here]\n \"Pool.grow got too small capacity\"\n (`capacity capacity, `old_capacity old_capacity)\n [%sexp_of: [ `capacity of int ] * [ `old_capacity of int ]];\n capacity\n ;;\n\n module Slots = Tuple_type.Slots\n\n let max_slot = 14\n\n (* The pool is represented as a single [Uniform_array.t], where index zero has the\n metadata about the pool and the remaining indices are the tuples layed out one after\n the other. Each tuple takes [1 + slots_per_tuple] indices in the pool, where the\n first index holds a header and the remaining indices hold the tuple's slots:\n\n {v\n | header | s0 | s1 | ... | s |\n v}\n\n A [Pointer.t] to a tuple contains the integer index where its header is, as well as\n (a mask of) the tuple's unique id.\n\n The free tuples are singly linked via the headers.\n\n When a tuple is in use, its header is marked to indicate so, and also to include the\n tuple's unique id. This allows us to check in constant time whether a pointer is\n valid, by comparing the id in the pointer with the id in the header.\n\n When a tuple is not in use, its header is part of the free list, and its tuple slots\n have dummy values of the appropriate types, from the [dummy] tuple supplied to\n [create]. We must have dummy values of the correct type to prevent a segfault in\n code that (mistakenly) uses a pointer to a free tuple.\n\n For [Pool.Unsafe], a slot in a free object is guaranteed to be an int; it must not be\n pointer to prevent a space leak. However, the int in the slot may not represent a\n valid value of the type.\n *)\n\n module Slot = struct\n type ('slots, 'a) t = int [@@deriving sexp_of]\n\n let equal (t1 : (_, _) t) t2 = t1 = t2\n let t0 = 1\n let t1 = 2\n let t2 = 3\n let t3 = 4\n let t4 = 5\n let t5 = 6\n let t6 = 7\n let t7 = 8\n let t8 = 9\n let t9 = 10\n let t10 = 11\n let t11 = 12\n let t12 = 13\n let t13 = 14\n\n let%test _ = t13 = max_slot\n end\n\n (* We only have [Int.num_bits] bits available for pool pointers. The bits of a pool\n pointer encode two things:\n\n - the tuple's array index in the pool\n - the tuple's identifier (not necessarily unique)\n\n We choose [array_index_num_bits] as large as needed for the maximum pool capacity\n that we want to support, and use the remaining [masked_tuple_id_num_bits] bits for\n the identifier. 64-bit and 32-bit architectures typically have very different\n address-space sizes, so we choose [array_index_num_bits] differently. *)\n\n let array_index_num_bits =\n if arch_sixtyfour\n then (\n assert (Int.num_bits = 63);\n 30)\n else (\n assert (Int.num_bits = 31 || Int.num_bits = 32);\n 22)\n ;;\n\n let masked_tuple_id_num_bits = Int.num_bits - array_index_num_bits\n\n let%test _ = array_index_num_bits > 0\n let%test _ = masked_tuple_id_num_bits > 0\n let%test _ = array_index_num_bits + masked_tuple_id_num_bits <= Int.num_bits\n\n let max_array_length = 1 lsl array_index_num_bits\n\n module Tuple_id : sig\n type t = private int [@@deriving sexp_of]\n\n include Invariant.S with type t := t\n\n val to_string : t -> string\n val equal : t -> t -> bool\n val init : t\n val next : t -> t\n val of_int : int -> t\n val to_int : t -> int\n val examples : t list\n end = struct\n type t = int [@@deriving sexp_of]\n\n (* We guarantee that tuple ids are nonnegative so that they can be encoded in\n headers. *)\n let invariant t = assert (t >= 0)\n let to_string = Int.to_string\n let equal (t1 : t) t2 = t1 = t2\n let init = 0\n let next t = if arch_sixtyfour then t + 1 else if t = Int.max_value then 0 else t + 1\n let to_int t = t\n\n let of_int i =\n if i < 0\n then failwiths ~here:[%here] \"Tuple_id.of_int got negative int\" i [%sexp_of: int];\n i\n ;;\n\n let examples = [ 0; 1; 0x1FFF_FFFF; Int.max_value ]\n end\n\n let tuple_id_mask = (1 lsl masked_tuple_id_num_bits) - 1\n\n module Pointer : sig\n (* [Pointer.t] is an encoding as an [int] of the following sum type:\n\n {[\n | Null\n | Normal of { header_index : int; masked_tuple_id : int }\n ]}\n\n The encoding is chosen to optimize the most common operation, namely tuple-slot\n access, the [slot_index] function. The encoding is designed so that [slot_index]\n produces a negative number for [Null], which will cause the subsequent array bounds\n check to fail. *)\n\n type 'slots t = private int [@@deriving sexp_of, typerep]\n\n include Invariant.S1 with type 'a t := 'a t\n\n val phys_compare : 'a t -> 'a t -> int\n val phys_equal : 'a t -> 'a t -> bool\n\n (* The null pointer. [null] is a function due to issues with the value restriction. *)\n\n val null : unit -> _ t\n val is_null : _ t -> bool\n\n (* Normal pointers. *)\n\n val create : header_index:int -> Tuple_id.t -> _ t\n val header_index : _ t -> int\n val masked_tuple_id : _ t -> int\n val slot_index : _ t -> (_, _) Slot.t -> int\n val first_slot_index : _ t -> int\n\n module Id : sig\n type t [@@deriving bin_io, sexp]\n\n val to_int63 : t -> Int63.t\n val of_int63 : Int63.t -> t\n end\n\n val to_id : _ t -> Id.t\n val of_id_exn : Id.t -> _ t\n end = struct\n (* A pointer is either [null] or the (positive) index in the pool of the next-free\n field preceeding the tuple's slots. *)\n type 'slots t = int [@@deriving typerep]\n\n let sexp_of_t _ t = Sexp.Atom (sprintf \"\" t)\n let phys_equal (t1 : _ t) t2 = phys_equal t1 t2\n let phys_compare = compare\n let null () = -max_slot - 1\n let is_null t = phys_equal t (null ())\n\n (* [null] must be such that [null + slot] is an invalid array index for all slots.\n Otherwise get/set on the null pointer may lead to a segfault. *)\n let%test _ = null () + max_slot < 0\n\n let create ~header_index (tuple_id : Tuple_id.t) =\n header_index\n lor ((Tuple_id.to_int tuple_id land tuple_id_mask) lsl array_index_num_bits)\n ;;\n\n let header_index_mask = (1 lsl array_index_num_bits) - 1\n let masked_tuple_id t = t lsr array_index_num_bits\n let header_index t = t land header_index_mask\n let invariant _ t = if not (is_null t) then assert (header_index t > 0)\n\n let%test_unit _ = invariant ignore (null ())\n\n let%test_unit _ =\n List.iter Tuple_id.examples ~f:(fun tuple_id ->\n invariant ignore (create ~header_index:1 tuple_id))\n ;;\n\n let slot_index t slot = header_index t + slot\n let first_slot_index t = slot_index t Slot.t0\n\n module Id = struct\n include Int63\n\n let to_int63 t = t\n let of_int63 i = i\n end\n\n let to_id t = Id.of_int t\n\n let of_id_exn id =\n try\n let t = Id.to_int_exn id in\n if is_null t\n then t\n else (\n let should_equal =\n create ~header_index:(header_index t) (Tuple_id.of_int (masked_tuple_id t))\n in\n if phys_equal t should_equal\n then t\n else failwiths ~here:[%here] \"should equal\" should_equal [%sexp_of: _ t])\n with\n | exn ->\n failwiths\n ~here:[%here]\n \"Pointer.of_id_exn got strange id\"\n (id, exn)\n [%sexp_of: Id.t * exn]\n ;;\n end\n\n module Header : sig\n (* A [Header.t] is an encoding as an [int] of the following type:\n\n {[\n | Null\n | Free of { next_free_header_index : int }\n | Used of { tuple_id : int }\n ]}\n\n If a tuple is free, its header is set to either [Null] or [Free] with\n [next_free_header_index] indicating the header of the next tuple on the free list.\n If a tuple is in use, it header is set to [Used]. *)\n\n type t = private int [@@deriving sexp_of]\n\n val null : t\n val is_null : t -> bool\n val free : next_free_header_index:int -> t\n val is_free : t -> bool\n val next_free_header_index : t -> int\n\n (* only valid if [is_free t] *)\n\n val used : Tuple_id.t -> t\n val is_used : t -> bool\n val tuple_id : t -> Tuple_id.t\n\n (* only valid if [is_used t] *)\n end = struct\n type t = int\n\n let null = 0\n let is_null t = t = 0\n\n (* We know that header indices are [> 0], because index [0] holds the metadata. *)\n let free ~next_free_header_index = next_free_header_index\n let is_free t = t > 0\n let next_free_header_index t = t\n let used (tuple_id : Tuple_id.t) = -1 - (tuple_id :> int)\n let is_used t = t < 0\n let tuple_id t = Tuple_id.of_int (-(t + 1))\n\n let%test_unit _ =\n List.iter Tuple_id.examples ~f:(fun id ->\n let t = used id in\n assert (is_used t);\n assert (Tuple_id.equal (tuple_id t) id))\n ;;\n\n let sexp_of_t t =\n if is_null t\n then Sexp.Atom \"null\"\n else if is_free t\n then Sexp.(List [ Atom \"Free\"; Atom (Int.to_string (next_free_header_index t)) ])\n else Sexp.(List [ Atom \"Used\"; Atom (Tuple_id.to_string (tuple_id t)) ])\n ;;\n end\n\n let metadata_index = 0\n let start_of_tuples_index = 1\n\n let max_capacity ~slots_per_tuple =\n (max_array_length - start_of_tuples_index) / (1 + slots_per_tuple)\n ;;\n\n let%test_unit _ =\n for slots_per_tuple = 1 to max_slot do\n assert (\n start_of_tuples_index + ((1 + slots_per_tuple) * max_capacity ~slots_per_tuple)\n <= max_array_length)\n done\n ;;\n\n module Metadata = struct\n type 'slots t =\n { (* [slots_per_tuple] is number of slots in a tuple as seen by the user; i.e. not\n counting the next-free pointer. *)\n slots_per_tuple : int\n ; capacity : int\n ; mutable length : int\n ; mutable next_id : Tuple_id.t\n ; mutable first_free : Header.t\n (* [dummy] is [None] in an unsafe pool. In a safe pool, [dummy] is [Some a], with\n [Uniform_array.length a = slots_per_tuple]. [dummy] is actually a tuple value\n with the correct type (corresponding to ['slots]), but we make the type of\n [dummy] be [Obj.t Uniform_array.t] because we can't write that type here. Also,\n the purpose of [dummy] is to initialize a pool element, making [dummy] an [Obj.t\n Uniform_array.t] lets us initialize a pool element using [Uniform_array.blit]\n from [dummy] to the pool, which is an [Obj.t Uniform_array.t]. *)\n ; dummy : (Obj.t Uniform_array.t[@sexp.opaque]) option\n }\n [@@deriving fields, sexp_of]\n\n let array_indices_per_tuple t = 1 + t.slots_per_tuple\n let array_length t = start_of_tuples_index + (t.capacity * array_indices_per_tuple t)\n\n let header_index_to_tuple_num t ~header_index =\n (header_index - start_of_tuples_index) / array_indices_per_tuple t\n ;;\n\n let tuple_num_to_header_index t tuple_num =\n start_of_tuples_index + (tuple_num * array_indices_per_tuple t)\n ;;\n\n let tuple_num_to_first_slot_index t tuple_num =\n tuple_num_to_header_index t tuple_num + 1\n ;;\n\n let is_full t = t.length = t.capacity\n end\n\n open Metadata\n\n (* We use type [Obj.t] because the array holds a mix of integers as well as OCaml values\n of arbitrary type. *)\n type 'slots t = Obj.t Uniform_array.t\n\n let metadata (type slots) (t : slots t) =\n Uniform_array.unsafe_get t metadata_index |> (Obj.obj : _ -> slots Metadata.t)\n ;;\n\n let length t = (metadata t).length\n let sexp_of_t sexp_of_ty t = Metadata.sexp_of_t sexp_of_ty (metadata t)\n\n (* Because [unsafe_header] and [unsafe_set_header] do not do a bounds check, one must be\n sure that one has a valid [header_index] before calling them. *)\n let unsafe_header t ~header_index =\n Uniform_array.unsafe_get t header_index |> (Obj.obj : _ -> Header.t)\n ;;\n\n let unsafe_set_header t ~header_index (header : Header.t) =\n Uniform_array.unsafe_set_int_assuming_currently_int t header_index (header :> int)\n ;;\n\n let header_index_is_in_bounds t ~header_index =\n header_index >= start_of_tuples_index && header_index < Uniform_array.length t\n ;;\n\n let unsafe_pointer_is_live t pointer =\n let header_index = Pointer.header_index pointer in\n let header = unsafe_header t ~header_index in\n Header.is_used header\n && Tuple_id.to_int (Header.tuple_id header) land tuple_id_mask\n = Pointer.masked_tuple_id pointer\n ;;\n\n let pointer_is_valid t pointer =\n header_index_is_in_bounds t ~header_index:(Pointer.header_index pointer)\n (* At this point, we know the pointer isn't [null] and is in bounds, so we know it is\n the index of a header, since we maintain the invariant that all pointers other than\n [null] are. *)\n && unsafe_pointer_is_live t pointer\n ;;\n\n let id_of_pointer _t pointer = Pointer.to_id pointer\n\n let is_valid_header_index t ~header_index =\n let metadata = metadata t in\n header_index_is_in_bounds t ~header_index\n && 0\n = (header_index - start_of_tuples_index)\n mod Metadata.array_indices_per_tuple metadata\n ;;\n\n let pointer_of_id_exn t id =\n try\n let pointer = Pointer.of_id_exn id in\n if not (Pointer.is_null pointer)\n then (\n let header_index = Pointer.header_index pointer in\n if not (is_valid_header_index t ~header_index)\n then failwiths ~here:[%here] \"invalid header index\" header_index [%sexp_of: int];\n if not (unsafe_pointer_is_live t pointer) then failwith \"pointer not live\");\n pointer\n with\n | exn ->\n failwiths\n ~here:[%here]\n \"Pool.pointer_of_id_exn got invalid id\"\n (id, t, exn)\n [%sexp_of: Pointer.Id.t * _ t * exn]\n ;;\n\n let invariant _invariant_a t : unit =\n try\n let metadata = metadata t in\n let check f field = f (Field.get field metadata) in\n Metadata.Fields.iter\n ~slots_per_tuple:(check (fun slots_per_tuple -> assert (slots_per_tuple > 0)))\n ~capacity:\n (check (fun capacity ->\n assert (capacity >= 0);\n assert (Uniform_array.length t = Metadata.array_length metadata)))\n ~length:\n (check (fun length ->\n assert (length >= 0);\n assert (length <= metadata.capacity)))\n ~next_id:(check Tuple_id.invariant)\n ~first_free:\n (check (fun first_free ->\n let free = Array.create ~len:metadata.capacity false in\n let r = ref first_free in\n while not (Header.is_null !r) do\n let header = !r in\n assert (Header.is_free header);\n let header_index = Header.next_free_header_index header in\n assert (is_valid_header_index t ~header_index);\n let tuple_num = header_index_to_tuple_num metadata ~header_index in\n if free.(tuple_num)\n then\n failwiths ~here:[%here] \"cycle in free list\" tuple_num [%sexp_of: int];\n free.(tuple_num) <- true;\n r := unsafe_header t ~header_index\n done))\n ~dummy:\n (check (function\n | Some dummy ->\n assert (Uniform_array.length dummy = metadata.slots_per_tuple)\n | None ->\n for tuple_num = 0 to metadata.capacity - 1 do\n let header_index = tuple_num_to_header_index metadata tuple_num in\n let header = unsafe_header t ~header_index in\n if Header.is_free header\n then (\n let first_slot = tuple_num_to_first_slot_index metadata tuple_num in\n for slot = 0 to metadata.slots_per_tuple - 1 do\n assert (Obj.is_int (Uniform_array.get t (first_slot + slot)))\n done)\n done))\n with\n | exn ->\n failwiths ~here:[%here] \"Pool.invariant failed\" (exn, t) [%sexp_of: exn * _ t]\n ;;\n\n let capacity t = (metadata t).capacity\n let is_full t = Metadata.is_full (metadata t)\n\n let unsafe_add_to_free_list t metadata ~header_index =\n unsafe_set_header t ~header_index metadata.first_free;\n metadata.first_free <- Header.free ~next_free_header_index:header_index\n ;;\n\n let set_metadata (type slots) (t : slots t) metadata =\n Uniform_array.set t metadata_index (Obj.repr (metadata : slots Metadata.t))\n ;;\n\n let create_array (type slots) (metadata : slots Metadata.t) : slots t =\n let t = Uniform_array.create_obj_array ~len:(Metadata.array_length metadata) in\n set_metadata t metadata;\n t\n ;;\n\n (* Initialize tuples numbered from [lo] (inclusive) up to [hi] (exclusive). For each\n tuple, this puts dummy values in the tuple's slots and adds the tuple to the free\n list. *)\n let unsafe_init_range t metadata ~lo ~hi =\n (match metadata.dummy with\n | None -> ()\n | Some dummy ->\n for tuple_num = lo to hi - 1 do\n Uniform_array.blit\n ~src:dummy\n ~src_pos:0\n ~dst:t\n ~dst_pos:(tuple_num_to_first_slot_index metadata tuple_num)\n ~len:metadata.slots_per_tuple\n done);\n for tuple_num = hi - 1 downto lo do\n unsafe_add_to_free_list\n t\n metadata\n ~header_index:(tuple_num_to_header_index metadata tuple_num)\n done\n ;;\n\n let create_with_dummy slots ~capacity ~dummy =\n if capacity < 0\n then\n failwiths ~here:[%here] \"Pool.create got invalid capacity\" capacity [%sexp_of: int];\n let slots_per_tuple = Slots.slots_per_tuple slots in\n let max_capacity = max_capacity ~slots_per_tuple in\n if capacity > max_capacity\n then\n failwiths\n ~here:[%here]\n \"Pool.create got too large capacity\"\n (capacity, `max max_capacity)\n [%sexp_of: int * [ `max of int ]];\n let metadata =\n { Metadata.slots_per_tuple\n ; capacity\n ; length = 0\n ; next_id = Tuple_id.init\n ; first_free = Header.null\n ; dummy\n }\n in\n let t = create_array metadata in\n unsafe_init_range t metadata ~lo:0 ~hi:capacity;\n t\n ;;\n\n let create (type tuple) (slots : (tuple, _) Slots.t) ~capacity ~dummy =\n let dummy =\n if Slots.slots_per_tuple slots = 1\n then Uniform_array.singleton (Obj.repr (dummy : tuple))\n else (Obj.magic (dummy : tuple) : Obj.t Uniform_array.t)\n in\n create_with_dummy slots ~capacity ~dummy:(Some dummy)\n ;;\n\n (* Purge a pool and make it unusable. *)\n let destroy t =\n let metadata = metadata t in\n (* We clear out all the pool's entries, which causes all pointers to be invalid. This\n also prevents the destroyed pool from unnecessarily keeping heap blocks alive.\n This is similar to [free]ing all the entries with the difference that we make the\n free list empty as well. *)\n (match metadata.dummy with\n | None ->\n for i = start_of_tuples_index to Uniform_array.length t - 1 do\n Uniform_array.unsafe_set t i (Obj.repr 0)\n done\n | Some dummy ->\n for tuple_num = 0 to metadata.capacity - 1 do\n let header_index = tuple_num_to_header_index metadata tuple_num in\n unsafe_set_header t ~header_index Header.null;\n Uniform_array.blit\n ~src:dummy\n ~src_pos:0\n ~dst:t\n ~dst_pos:(header_index + 1)\n ~len:metadata.slots_per_tuple\n done);\n let metadata =\n { Metadata.slots_per_tuple = metadata.slots_per_tuple\n ; capacity = 0\n ; length = 0\n ; next_id = metadata.next_id\n ; first_free = Header.null\n ; dummy = metadata.dummy\n }\n in\n set_metadata t metadata\n ;;\n\n let[@cold] grow ?capacity t =\n let { Metadata.slots_per_tuple\n ; capacity = old_capacity\n ; length\n ; next_id\n ; first_free = _\n ; dummy\n }\n =\n metadata t\n in\n let capacity =\n min (max_capacity ~slots_per_tuple) (grow_capacity ~capacity ~old_capacity)\n in\n if capacity = old_capacity\n then\n failwiths\n ~here:[%here]\n \"Pool.grow cannot grow pool; capacity already at maximum\"\n capacity\n [%sexp_of: int];\n let metadata =\n { Metadata.slots_per_tuple\n ; capacity\n ; length\n ; next_id\n ; first_free = Header.null\n ; dummy\n }\n in\n let t' = create_array metadata in\n Uniform_array.blit\n ~src:t\n ~src_pos:start_of_tuples_index\n ~dst:t'\n ~dst_pos:start_of_tuples_index\n ~len:(old_capacity * Metadata.array_indices_per_tuple metadata);\n destroy t;\n unsafe_init_range t' metadata ~lo:old_capacity ~hi:capacity;\n for tuple_num = old_capacity - 1 downto 0 do\n let header_index = tuple_num_to_header_index metadata tuple_num in\n let header = unsafe_header t' ~header_index in\n if not (Header.is_used header)\n then unsafe_add_to_free_list t' metadata ~header_index\n done;\n t'\n ;;\n\n let[@cold] raise_malloc_full t =\n failwiths ~here:[%here] \"Pool.malloc of full pool\" t [%sexp_of: _ t]\n ;;\n\n let malloc (type slots) (t : slots t) : slots Pointer.t =\n let metadata = metadata t in\n let first_free = metadata.first_free in\n if Header.is_null first_free then raise_malloc_full t;\n let header_index = Header.next_free_header_index first_free in\n metadata.first_free <- unsafe_header t ~header_index;\n metadata.length <- metadata.length + 1;\n let tuple_id = metadata.next_id in\n unsafe_set_header t ~header_index (Header.used tuple_id);\n metadata.next_id <- Tuple_id.next tuple_id;\n Pointer.create ~header_index tuple_id\n ;;\n\n let unsafe_free (type slots) (t : slots t) (pointer : slots Pointer.t) =\n let metadata = metadata t in\n metadata.length <- metadata.length - 1;\n unsafe_add_to_free_list t metadata ~header_index:(Pointer.header_index pointer);\n match metadata.dummy with\n | None ->\n let pos = Pointer.first_slot_index pointer in\n for i = 0 to metadata.slots_per_tuple - 1 do\n Uniform_array.unsafe_clear_if_pointer t (pos + i)\n done\n | Some dummy ->\n Uniform_array.unsafe_blit\n ~src:dummy\n ~src_pos:0\n ~len:metadata.slots_per_tuple\n ~dst:t\n ~dst_pos:(Pointer.first_slot_index pointer)\n ;;\n\n let free (type slots) (t : slots t) (pointer : slots Pointer.t) =\n (* Check [pointer_is_valid] to:\n - avoid freeing a null pointer\n - avoid freeing a free pointer (this would lead to a pool inconsistency)\n - be able to use unsafe functions after. *)\n if not (pointer_is_valid t pointer)\n then\n failwiths\n ~here:[%here]\n \"Pool.free of invalid pointer\"\n (pointer, t)\n [%sexp_of: _ Pointer.t * _ t];\n unsafe_free t pointer\n ;;\n\n let new1 t a0 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n pointer\n ;;\n\n let new2 t a0 a1 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n pointer\n ;;\n\n let new3 t a0 a1 a2 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n pointer\n ;;\n\n let new4 t a0 a1 a2 a3 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n pointer\n ;;\n\n let new5 t a0 a1 a2 a3 a4 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n pointer\n ;;\n\n let new6 t a0 a1 a2 a3 a4 a5 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n pointer\n ;;\n\n let new7 t a0 a1 a2 a3 a4 a5 a6 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n pointer\n ;;\n\n let new8 t a0 a1 a2 a3 a4 a5 a6 a7 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n pointer\n ;;\n\n let new9 t a0 a1 a2 a3 a4 a5 a6 a7 a8 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n pointer\n ;;\n\n let new10 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n Uniform_array.unsafe_set t (offset + 10) (Obj.repr a9);\n pointer\n ;;\n\n let new11 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n Uniform_array.unsafe_set t (offset + 10) (Obj.repr a9);\n Uniform_array.unsafe_set t (offset + 11) (Obj.repr a10);\n pointer\n ;;\n\n let new12 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n Uniform_array.unsafe_set t (offset + 10) (Obj.repr a9);\n Uniform_array.unsafe_set t (offset + 11) (Obj.repr a10);\n Uniform_array.unsafe_set t (offset + 12) (Obj.repr a11);\n pointer\n ;;\n\n let new13 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n Uniform_array.unsafe_set t (offset + 10) (Obj.repr a9);\n Uniform_array.unsafe_set t (offset + 11) (Obj.repr a10);\n Uniform_array.unsafe_set t (offset + 12) (Obj.repr a11);\n Uniform_array.unsafe_set t (offset + 13) (Obj.repr a12);\n pointer\n ;;\n\n let new14 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n Uniform_array.unsafe_set t (offset + 10) (Obj.repr a9);\n Uniform_array.unsafe_set t (offset + 11) (Obj.repr a10);\n Uniform_array.unsafe_set t (offset + 12) (Obj.repr a11);\n Uniform_array.unsafe_set t (offset + 13) (Obj.repr a12);\n Uniform_array.unsafe_set t (offset + 14) (Obj.repr a13);\n pointer\n ;;\n\n let get t p slot = Obj.obj (Uniform_array.get t (Pointer.slot_index p slot))\n\n let unsafe_get t p slot =\n Obj.obj (Uniform_array.unsafe_get t (Pointer.slot_index p slot))\n ;;\n\n let set t p slot x = Uniform_array.set t (Pointer.slot_index p slot) (Obj.repr x)\n\n let unsafe_set t p slot x =\n Uniform_array.unsafe_set t (Pointer.slot_index p slot) (Obj.repr x)\n ;;\n\n let get_tuple (type tuple) (t : (tuple, _) Slots.t t) pointer =\n let metadata = metadata t in\n let len = metadata.slots_per_tuple in\n if len = 1\n then get t pointer Slot.t0\n else\n (Obj.magic\n (Uniform_array.sub t ~pos:(Pointer.first_slot_index pointer) ~len\n : Obj.t Uniform_array.t)\n : tuple)\n ;;\nend\n\ninclude Pool\n\nmodule Unsafe = struct\n include Pool\n\n let create slots ~capacity = create_with_dummy slots ~capacity ~dummy:None\nend\n\nmodule Debug (Pool : S) = struct\n open Pool\n\n let check_invariant = ref true\n let show_messages = ref true\n\n let debug name ts arg sexp_of_arg sexp_of_result f =\n let prefix = \"Pool.\" in\n if !check_invariant then List.iter ts ~f:(invariant ignore);\n if !show_messages then Debug.eprints (concat [ prefix; name ]) arg sexp_of_arg;\n let result_or_exn = Result.try_with f in\n if !show_messages\n then\n Debug.eprints\n (concat [ prefix; name; \" result\" ])\n result_or_exn\n [%sexp_of: (result, exn) Result.t];\n Result.ok_exn result_or_exn\n ;;\n\n module Slots = Slots\n module Slot = Slot\n\n module Pointer = struct\n open Pointer\n\n type nonrec 'slots t = 'slots t [@@deriving sexp_of, typerep]\n\n let phys_compare t1 t2 =\n debug\n \"Pointer.phys_compare\"\n []\n (t1, t2)\n [%sexp_of: _ t * _ t]\n [%sexp_of: int]\n (fun () -> phys_compare t1 t2)\n ;;\n\n let phys_equal t1 t2 =\n debug\n \"Pointer.phys_equal\"\n []\n (t1, t2)\n [%sexp_of: _ t * _ t]\n [%sexp_of: bool]\n (fun () -> phys_equal t1 t2)\n ;;\n\n let is_null t =\n debug \"Pointer.is_null\" [] t [%sexp_of: _ t] [%sexp_of: bool] (fun () -> is_null t)\n ;;\n\n let null = null\n\n module Id = struct\n open Id\n\n type nonrec t = t [@@deriving bin_io, sexp]\n\n let of_int63 i =\n debug \"Pointer.Id.of_int63\" [] i [%sexp_of: Int63.t] [%sexp_of: t] (fun () ->\n of_int63 i)\n ;;\n\n let to_int63 t =\n debug \"Pointer.Id.to_int63\" [] t [%sexp_of: t] [%sexp_of: Int63.t] (fun () ->\n to_int63 t)\n ;;\n end\n end\n\n type nonrec 'slots t = 'slots t [@@deriving sexp_of]\n\n let invariant = invariant\n let length = length\n\n let id_of_pointer t pointer =\n debug\n \"id_of_pointer\"\n [ t ]\n pointer\n [%sexp_of: _ Pointer.t]\n [%sexp_of: Pointer.Id.t]\n (fun () -> id_of_pointer t pointer)\n ;;\n\n let pointer_of_id_exn t id =\n debug\n \"pointer_of_id_exn\"\n [ t ]\n id\n [%sexp_of: Pointer.Id.t]\n [%sexp_of: _ Pointer.t]\n (fun () -> pointer_of_id_exn t id)\n ;;\n\n let pointer_is_valid t pointer =\n debug\n \"pointer_is_valid\"\n [ t ]\n pointer\n [%sexp_of: _ Pointer.t]\n [%sexp_of: bool]\n (fun () -> pointer_is_valid t pointer)\n ;;\n\n let create slots ~capacity ~dummy =\n debug \"create\" [] capacity [%sexp_of: int] [%sexp_of: _ t] (fun () ->\n create slots ~capacity ~dummy)\n ;;\n\n let max_capacity ~slots_per_tuple =\n debug \"max_capacity\" [] slots_per_tuple [%sexp_of: int] [%sexp_of: int] (fun () ->\n max_capacity ~slots_per_tuple)\n ;;\n\n let capacity t =\n debug \"capacity\" [ t ] t [%sexp_of: _ t] [%sexp_of: int] (fun () -> capacity t)\n ;;\n\n let grow ?capacity t =\n debug\n \"grow\"\n [ t ]\n (`capacity capacity)\n [%sexp_of: [ `capacity of int option ]]\n [%sexp_of: _ t]\n (fun () -> grow ?capacity t)\n ;;\n\n let is_full t =\n debug \"is_full\" [ t ] t [%sexp_of: _ t] [%sexp_of: bool] (fun () -> is_full t)\n ;;\n\n let unsafe_free t p =\n debug \"unsafe_free\" [ t ] p [%sexp_of: _ Pointer.t] [%sexp_of: unit] (fun () ->\n unsafe_free t p)\n ;;\n\n let free t p =\n debug \"free\" [ t ] p [%sexp_of: _ Pointer.t] [%sexp_of: unit] (fun () -> free t p)\n ;;\n\n let debug_new t f = debug \"new\" [ t ] () [%sexp_of: unit] [%sexp_of: _ Pointer.t] f\n let new1 t a0 = debug_new t (fun () -> new1 t a0)\n let new2 t a0 a1 = debug_new t (fun () -> new2 t a0 a1)\n let new3 t a0 a1 a2 = debug_new t (fun () -> new3 t a0 a1 a2)\n let new4 t a0 a1 a2 a3 = debug_new t (fun () -> new4 t a0 a1 a2 a3)\n let new5 t a0 a1 a2 a3 a4 = debug_new t (fun () -> new5 t a0 a1 a2 a3 a4)\n let new6 t a0 a1 a2 a3 a4 a5 = debug_new t (fun () -> new6 t a0 a1 a2 a3 a4 a5)\n let new7 t a0 a1 a2 a3 a4 a5 a6 = debug_new t (fun () -> new7 t a0 a1 a2 a3 a4 a5 a6)\n\n let new8 t a0 a1 a2 a3 a4 a5 a6 a7 =\n debug_new t (fun () -> new8 t a0 a1 a2 a3 a4 a5 a6 a7)\n ;;\n\n let new9 t a0 a1 a2 a3 a4 a5 a6 a7 a8 =\n debug_new t (fun () -> new9 t a0 a1 a2 a3 a4 a5 a6 a7 a8)\n ;;\n\n let new10 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 =\n debug_new t (fun () -> new10 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9)\n ;;\n\n let new11 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 =\n debug_new t (fun () -> new11 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10)\n ;;\n\n let new12 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 =\n debug_new t (fun () -> new12 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11)\n ;;\n\n let new13 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 =\n debug_new t (fun () -> new13 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12)\n ;;\n\n let new14 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13 =\n debug_new t (fun () -> new14 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13)\n ;;\n\n let get_tuple t pointer =\n debug \"get_tuple\" [ t ] pointer [%sexp_of: _ Pointer.t] [%sexp_of: _] (fun () ->\n get_tuple t pointer)\n ;;\n\n let debug_get name f t pointer =\n debug name [ t ] pointer [%sexp_of: _ Pointer.t] [%sexp_of: _] (fun () ->\n f t pointer)\n ;;\n\n let get t pointer slot = debug_get \"get\" get t pointer slot\n let unsafe_get t pointer slot = debug_get \"unsafe_get\" unsafe_get t pointer slot\n\n let debug_set name f t pointer slot a =\n debug name [ t ] pointer [%sexp_of: _ Pointer.t] [%sexp_of: unit] (fun () ->\n f t pointer slot a)\n ;;\n\n let set t pointer slot a = debug_set \"set\" set t pointer slot a\n let unsafe_set t pointer slot a = debug_set \"unsafe_set\" unsafe_set t pointer slot a\nend\n\nmodule Error_check (Pool : S) = struct\n open Pool\n module Slots = Slots\n module Slot = Slot\n\n module Pointer = struct\n type 'slots t =\n { mutable is_valid : bool\n ; pointer : 'slots Pointer.t\n }\n [@@deriving sexp_of, typerep]\n\n let create pointer = { is_valid = true; pointer }\n let null () = { is_valid = false; pointer = Pointer.null () }\n let phys_compare t1 t2 = Pointer.phys_compare t1.pointer t2.pointer\n let phys_equal t1 t2 = Pointer.phys_equal t1.pointer t2.pointer\n let is_null t = Pointer.is_null t.pointer\n\n let follow t =\n if not t.is_valid\n then failwiths ~here:[%here] \"attempt to use invalid pointer\" t [%sexp_of: _ t];\n t.pointer\n ;;\n\n let invalidate t = t.is_valid <- false\n\n module Id = Pointer.Id\n end\n\n type 'slots t = 'slots Pool.t [@@deriving sexp_of]\n\n let invariant = invariant\n let length = length\n\n let pointer_is_valid t { Pointer.is_valid; pointer } =\n is_valid && pointer_is_valid t pointer\n ;;\n\n (* We don't do [Pointer.follow pointer], because that would disallow [id_of_pointer t\n (Pointer.null ())]. *)\n let id_of_pointer t pointer = id_of_pointer t pointer.Pointer.pointer\n\n let pointer_of_id_exn t id =\n let pointer = pointer_of_id_exn t id in\n let is_valid = Pool.pointer_is_valid t pointer in\n { Pointer.is_valid; pointer }\n ;;\n\n let create = create\n let capacity = capacity\n let max_capacity = max_capacity\n let grow = grow\n let is_full = is_full\n let get_tuple t p = get_tuple t (Pointer.follow p)\n let get t p = get t (Pointer.follow p)\n let unsafe_get t p = unsafe_get t (Pointer.follow p)\n let set t p slot v = set t (Pointer.follow p) slot v\n let unsafe_set t p slot v = unsafe_set t (Pointer.follow p) slot v\n\n let unsafe_free t p =\n unsafe_free t (Pointer.follow p);\n Pointer.invalidate p\n ;;\n\n let free t p =\n free t (Pointer.follow p);\n Pointer.invalidate p\n ;;\n\n let new1 t a0 = Pointer.create (Pool.new1 t a0)\n let new2 t a0 a1 = Pointer.create (Pool.new2 t a0 a1)\n let new3 t a0 a1 a2 = Pointer.create (Pool.new3 t a0 a1 a2)\n let new4 t a0 a1 a2 a3 = Pointer.create (Pool.new4 t a0 a1 a2 a3)\n let new5 t a0 a1 a2 a3 a4 = Pointer.create (Pool.new5 t a0 a1 a2 a3 a4)\n let new6 t a0 a1 a2 a3 a4 a5 = Pointer.create (Pool.new6 t a0 a1 a2 a3 a4 a5)\n let new7 t a0 a1 a2 a3 a4 a5 a6 = Pointer.create (Pool.new7 t a0 a1 a2 a3 a4 a5 a6)\n\n let new8 t a0 a1 a2 a3 a4 a5 a6 a7 =\n Pointer.create (Pool.new8 t a0 a1 a2 a3 a4 a5 a6 a7)\n ;;\n\n let new9 t a0 a1 a2 a3 a4 a5 a6 a7 a8 =\n Pointer.create (Pool.new9 t a0 a1 a2 a3 a4 a5 a6 a7 a8)\n ;;\n\n let new10 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 =\n Pointer.create (Pool.new10 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9)\n ;;\n\n let new11 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 =\n Pointer.create (Pool.new11 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10)\n ;;\n\n let new12 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 =\n Pointer.create (Pool.new12 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11)\n ;;\n\n let new13 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 =\n Pointer.create (Pool.new13 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12)\n ;;\n\n let new14 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13 =\n Pointer.create (Pool.new14 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13)\n ;;\nend\n","open! Import\nmodule Int = Int0\nmodule String = String0\n\n(** Each single_error is a path indicating the location within the datastructure in\n question that is being validated, along with an error message. *)\ntype single_error =\n { path : string list\n ; error : Error.t\n }\n\ntype t = single_error list\ntype 'a check = 'a -> t\n\nlet pass : t = []\n\nlet fails message a sexp_of_a =\n [ { path = []; error = Error.create message a sexp_of_a } ]\n;;\n\nlet fail message = [ { path = []; error = Error.of_string message } ]\nlet failf format = Printf.ksprintf fail format\nlet fail_s sexp = [ { path = []; error = Error.create_s sexp } ]\nlet combine t1 t2 = t1 @ t2\nlet of_list = List.concat\n\nlet name name t =\n match t with\n | [] -> [] (* when successful, avoid the allocation of a closure for [~f], below *)\n | _ -> List.map t ~f:(fun { path; error } -> { path = name :: path; error })\n;;\n\nlet name_list n l = name n (of_list l)\nlet fail_fn message _ = fail message\nlet pass_bool (_ : bool) = pass\nlet pass_unit (_ : unit) = pass\n\nlet protect f v =\n try f v with\n | exn ->\n fail_s (Sexp.message \"Exception raised during validation\" [ \"\", sexp_of_exn exn ])\n;;\n\nlet try_with f =\n protect\n (fun () ->\n f ();\n pass)\n ()\n;;\n\nlet path_string path = String.concat ~sep:\".\" path\n\nlet errors t =\n List.map t ~f:(fun { path; error } ->\n Error.to_string_hum (Error.tag error ~tag:(path_string path)))\n;;\n\nlet result_fail t =\n Or_error.error\n \"validation errors\"\n (List.map t ~f:(fun { path; error } -> path_string path, error))\n (sexp_of_list (sexp_of_pair sexp_of_string Error.sexp_of_t))\n[@@cold] [@@inline never] [@@local never] [@@specialise never]\n;;\n\n(** [result] is carefully implemented so that it can be inlined -- calling [result_fail],\n which is not inlineable, is key to this. *)\nlet result t = if List.is_empty t then Ok () else result_fail t\n\nlet maybe_raise t = Or_error.ok_exn (result t)\nlet valid_or_error x check = Or_error.map (result (protect check x)) ~f:(fun () -> x)\n\nlet field record fld f =\n let v = Field.get fld record in\n let result = protect f v in\n name (Field.name fld) result\n;;\n\nlet field_folder record check =\n ();\n fun acc fld -> field record fld check :: acc\n;;\n\nlet field_direct_folder check =\n Staged.stage (fun acc fld _record v ->\n match protect check v with\n | [] -> acc\n | result -> name (Field.name fld) result :: acc)\n;;\n\nlet all checks v =\n let rec loop checks v errs =\n match checks with\n | [] -> errs\n | check :: checks ->\n (match protect check v with\n | [] -> loop checks v errs\n | err -> loop checks v (err :: errs))\n in\n of_list (List.rev (loop checks v []))\n;;\n\nlet of_result f =\n protect (fun v ->\n match f v with\n | Ok () -> pass\n | Error error -> fail error)\n;;\n\nlet of_error f =\n protect (fun v ->\n match f v with\n | Ok () -> pass\n | Error error -> [ { path = []; error } ])\n;;\n\nlet booltest f ~if_false = protect (fun v -> if f v then pass else fail if_false)\n\nlet pair ~fst ~snd (fst_value, snd_value) =\n of_list [ name \"fst\" (protect fst fst_value); name \"snd\" (protect snd snd_value) ]\n;;\n\nlet list_indexed check list =\n List.mapi list ~f:(fun i el -> name (Int.to_string (i + 1)) (protect check el))\n |> of_list\n;;\n\nlet list ~name:extract_name check list =\n List.map list ~f:(fun el ->\n match protect check el with\n | [] -> []\n | t ->\n (* extra level of protection in case extract_name throws an exception *)\n protect (fun t -> name (extract_name el) t) t)\n |> of_list\n;;\n\nlet alist ~name f list' = list (fun (_, x) -> f x) list' ~name:(fun (key, _) -> name key)\nlet first_failure t1 t2 = if List.is_empty t1 then t2 else t1\n\nlet of_error_opt = function\n | None -> pass\n | Some error -> fail error\n;;\n\nlet bounded ~name ~lower ~upper ~compare x =\n match Maybe_bound.compare_to_interval_exn ~lower ~upper ~compare x with\n | In_range -> pass\n | Below_lower_bound ->\n (match lower with\n | Unbounded -> assert false\n | Incl incl -> fail (Printf.sprintf \"value %s < bound %s\" (name x) (name incl))\n | Excl excl -> fail (Printf.sprintf \"value %s <= bound %s\" (name x) (name excl)))\n | Above_upper_bound ->\n (match upper with\n | Unbounded -> assert false\n | Incl incl -> fail (Printf.sprintf \"value %s > bound %s\" (name x) (name incl))\n | Excl excl -> fail (Printf.sprintf \"value %s >= bound %s\" (name x) (name excl)))\n;;\n\nmodule Infix = struct\n let ( ++ ) t1 t2 = combine t1 t2\nend\n","open! Core_kernel\nopen! Import\n\nmodule Cpuset = struct\n include Validated.Make (struct\n type t = Int.Set.t [@@deriving sexp]\n\n let here = [%here]\n\n let validate t =\n Validate.first_failure\n (Int.validate_lbound ~min:(Incl 1) (Int.Set.length t))\n (Int.Set.to_list t\n |> List.map ~f:Int.validate_non_negative\n |> Validate.name_list \"Thread_pool_cpuset\")\n ;;\n end)\n\n let equal t1 t2 = Int.Set.equal (t1 |> raw) (t2 |> raw)\nend\n\ntype t =\n | Inherit\n | Cpuset of Cpuset.t\n[@@deriving sexp]\n","open Core_kernel\n\ntype 'a t = 'a\n\n(* This [Obj.magic] is OK because we never allow user code access to [none] (except via\n [unsafe_value]. We disallow [_ Uopt.t Uopt.t], so there is no chance of confusing\n [none] with [some none]. And [float Uopt.t array] is similarly disallowed. *)\nlet none = \"Uopt.none\" |> (Obj.magic : string -> _ t)\nlet is_none t = phys_equal t none\nlet is_some t = not (is_none t)\nlet invariant invariant_a t = if is_some t then invariant_a t\nlet sexp_of_t sexp_of_a t = if is_none t then [%sexp None] else [%sexp Some (t : a)]\nlet some a = a\nlet value_exn t = if is_none t then failwith \"Uopt.value_exn\" else t\nlet unsafe_value t = t\nlet to_option t = if is_none t then None else Some t\n\nlet of_option = function\n | None -> none\n | Some a -> some a\n;;\n\nmodule Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n let unsafe_value = unsafe_value\n end\nend\n","(* Be sure and first read the implementation overview in timing_wheel_intf.ml.\n\n A timing wheel is represented as an array of \"levels\", where each level is an array of\n \"slots\". Each slot represents a range of keys, and holds elements associated with\n those keys. Each level is determined by two parameters: [bits], the number of key bits\n that that level is responsible for distinguishing, and [bits_per_slot], the size of the\n range of keys that correspond to a single slot in the array. Conceptually, each level\n breaks up all possible keys into ranges of size [2^bits_per_slot]. The length of a\n level array is [2^bits], and the array is used like a circular buffer to traverse the\n ranges as the timing wheel's [min_allowed_key] increases. A key [k], if stored in the\n level, is stored at index [(k / 2^bits_per_slot) mod 2^bits].\n\n The settings of the [bits] values are configurable by user code using [Level_bits],\n although there is a reasonable default setting. Given the [bits] values, the\n [bits_per_slot] are chosen so that [bits_per_slot] at level [i] is the sum of the\n [bits] at all lower levels. Thus, a slot's range at level [i] is as large as the\n entire range of the array at level [i - 1].\n\n Each level has a [min_allowed_key] and a [max_allowed_key] that determine the range of\n keys that it currently represents. The crucial invariant of the timing wheel data\n structure is that the [min_allowed_key] at level [i] is no more than the\n [max_allowed_key + 1] of level [i - 1]. This ensures that the levels can represent all\n keys from the [min_allowed_key] of the lowest level to the [max_allowed_key] of the\n highest level. The [increase_min_allowed_key] function is responsible for restoring\n this invariant.\n\n At level 0, [bits_per_slot = 0], and so the size of each slot is [1]. That is, level 0\n precisely distinguishes all the keys between its [min_allowed_key] (which is the same\n as the [min_allowed_key] of the entire timing wheel) and [max_allowed_key]. As the\n levels increase, the [min_allowed_key] increases, the [bits_per_slot] increases, and\n the range of keys stored in the level increases (dramatically).\n\n The idea of the implementation is similar to the hierarchical approach described in:\n\n {v\n Hashed and Hierarchical Timing Wheels:\n Efficient Data Structures for Implementing a Timer Facility\n\n Varghese & Lauck, 1996\n v}\n\n However, the code is completely new. *)\n\nopen! Core_kernel\nopen! Import\nopen! Timing_wheel_intf\nmodule Pool = Tuple_pool\nmodule Time_ns = Core_kernel_private.Time_ns_alternate_sexp\n\nlet sexp_of_t_style : [ `Pretty | `Internal ] ref = ref `Pretty\n\n(* [{max,min}_time] are bounds on the times supported by a timing wheel. *)\n\nlet max_time = Time_ns.max_value_representable\nlet min_time = Time_ns.epoch\n\nmodule Num_key_bits : sig\n type t = private int [@@deriving compare, sexp]\n\n include Comparable with type t := t\n include Invariant.S with type t := t\n\n val zero : t\n\n (* val min_value : t *)\n\n val max_value : t\n val to_int : t -> int\n val of_int : int -> t\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val pow2 : t -> Int63.t\nend = struct\n include Int\n\n let min_value = 0\n\n (** We support all non-negative [Time_ns.t] values. *)\n let max_value = Int63.num_bits - 1\n\n let invariant t =\n assert (t >= min_value);\n assert (t <= max_value)\n ;;\n\n let of_int i =\n invariant i;\n i\n ;;\n\n let ( + ) t1 t2 =\n let t = t1 + t2 in\n invariant t;\n t\n ;;\n\n let ( - ) t1 t2 =\n let t = t1 - t2 in\n invariant t;\n t\n ;;\n\n let pow2 t = Int63.shift_left Int63.one t\nend\n\nmodule Level_bits = struct\n type t = Num_key_bits.t list [@@deriving compare, sexp]\n\n let max_num_bits = (Num_key_bits.max_value :> int)\n let num_bits_internal t = List.fold t ~init:Num_key_bits.zero ~f:Num_key_bits.( + )\n let num_bits t = (num_bits_internal t :> int)\n\n let invariant t =\n assert (not (List.is_empty t));\n List.iter t ~f:(fun num_key_bits ->\n Num_key_bits.invariant num_key_bits;\n assert (Num_key_bits.( > ) num_key_bits Num_key_bits.zero));\n Num_key_bits.invariant (num_bits_internal t)\n ;;\n\n let t_of_sexp sexp =\n let t = sexp |> [%of_sexp: t] in\n invariant t;\n t\n ;;\n\n let create_exn ?(extend_to_max_num_bits = false) ints =\n if List.is_empty ints then failwith \"Level_bits.create_exn requires a nonempty list\";\n if List.exists ints ~f:(fun bits -> bits <= 0)\n then\n raise_s\n [%message \"Level_bits.create_exn got nonpositive num bits\" ~_:(ints : int list)];\n let num_bits = List.fold ints ~init:0 ~f:( + ) in\n if num_bits > max_num_bits\n then\n raise_s\n [%message\n \"Level_bits.create_exn got too many bits\"\n ~_:(ints : int list)\n ~got:(num_bits : int)\n (max_num_bits : int)];\n let ints =\n if extend_to_max_num_bits\n then ints @ List.init (max_num_bits - num_bits) ~f:(const 1)\n else ints\n in\n List.map ints ~f:Num_key_bits.of_int\n ;;\n\n let default = create_exn [ 11; 10; 10; 10; 10; 10; 1 ]\n\n let trim t ~max_num_bits =\n if Num_key_bits.( <= ) (num_bits_internal t) max_num_bits\n then t\n else (\n let rec loop t ~remaining =\n match t with\n | [] -> []\n | b :: t ->\n if Num_key_bits.( >= ) b remaining\n then [ remaining ]\n else b :: loop t ~remaining:(Num_key_bits.( - ) remaining b)\n in\n loop t ~remaining:max_num_bits)\n ;;\nend\n\nmodule Alarm_precision : sig\n include Alarm_precision\n\n val num_key_bits : t -> Num_key_bits.t\n val interval_num : t -> Time_ns.t -> Int63.t\n val interval_num_start : t -> Int63.t -> Time_ns.t\nend = struct\n (** [t] is represented as the log2 of a number of nanoseconds. *)\n type t = int [@@deriving compare, hash]\n\n let equal = [%compare.equal: t]\n let num_key_bits t = t |> Num_key_bits.of_int\n\n let to_span t =\n if t < 0\n then\n raise_s\n [%message\n \"[Alarm_precision.to_span] of negative power of two nanoseconds\" ~_:(t : int)];\n Int63.(shift_left one) t |> Time_ns.Span.of_int63_ns\n ;;\n\n let sexp_of_t t = [%sexp (t |> to_span : Time_ns.Span.t)]\n let one_nanosecond = 0\n let about_one_microsecond = 10\n let about_one_millisecond = 20\n let about_one_second = 30\n let about_one_day = 46\n let mul t ~pow2 = t + pow2\n let div t ~pow2 = t - pow2\n let interval_num t time = Int63.shift_right (time |> Time_ns.to_int63_ns_since_epoch) t\n\n let interval_num_start t interval_num =\n Int63.shift_left interval_num t |> Time_ns.of_int63_ns_since_epoch\n ;;\n\n let of_span_floor_pow2_ns span =\n if Time_ns.Span.( <= ) span Time_ns.Span.zero\n then\n raise_s\n [%message\n \"[Alarm_precision.of_span_floor_pow2_ns] got non-positive span\"\n (span : Time_ns.Span.t)];\n span |> Time_ns.Span.to_int63_ns |> Int63.floor_log2\n ;;\n\n let of_span = of_span_floor_pow2_ns\n\n module Unstable = struct\n module T = struct\n type nonrec t = t [@@deriving compare]\n\n let of_binable = of_span_floor_pow2_ns\n let to_binable = to_span\n let of_sexpable = of_span_floor_pow2_ns\n let to_sexpable = to_span\n end\n\n include T\n include Binable.Of_binable_without_uuid [@alert \"-legacy\"] (Time_ns.Span) (T)\n include Sexpable.Of_sexpable (Time_ns.Span) (T)\n end\nend\n\nmodule Config = struct\n let level_bits_default = Level_bits.default\n\n type t =\n { alarm_precision : Alarm_precision.Unstable.t\n ; level_bits : Level_bits.t [@default level_bits_default]\n ; capacity : int option [@sexp.option]\n }\n [@@deriving fields, sexp]\n\n let alarm_precision t = Alarm_precision.to_span t.alarm_precision\n\n (* [max_num_level_bits alarm_precision] returns the number of level bits needed for a\n timing wheel with the specified [alarm_precision] to be able to represent all\n possible times from [Time_ns.epoch] onward. Since non-negative times have 62 bits,\n we require [L <= 62 - A], where [A] is the number of alarm bits and [L] is the\n number of level bits. *)\n let max_num_level_bits alarm_precision =\n Num_key_bits.( - )\n Num_key_bits.max_value\n (Alarm_precision.num_key_bits alarm_precision)\n ;;\n\n let invariant t =\n Invariant.invariant [%here] t [%sexp_of: t] (fun () ->\n assert (\n Num_key_bits.( <= )\n (Level_bits.num_bits_internal t.level_bits)\n (max_num_level_bits t.alarm_precision));\n let check f = Invariant.check_field t f in\n Fields.iter\n ~alarm_precision:ignore\n ~capacity:ignore\n ~level_bits:(check Level_bits.invariant))\n ;;\n\n let create ?capacity ?(level_bits = level_bits_default) ~alarm_precision () =\n let level_bits =\n Level_bits.trim level_bits ~max_num_bits:(max_num_level_bits alarm_precision)\n in\n { alarm_precision; level_bits; capacity }\n ;;\n\n let microsecond_precision () =\n create\n ()\n ~alarm_precision:Alarm_precision.about_one_microsecond\n ~level_bits:(Level_bits.create_exn [ 10; 10; 6; 6; 5 ])\n ;;\n\n let durations t =\n List.folding_map\n t.level_bits\n ~init:(Alarm_precision.num_key_bits t.alarm_precision |> Num_key_bits.to_int)\n ~f:(fun num_bits_accum level_num_bits ->\n let num_bits_accum = num_bits_accum + (level_num_bits |> Num_key_bits.to_int) in\n let duration =\n Time_ns.Span.of_int63_ns\n (if num_bits_accum = Int63.num_bits - 1\n then Int63.max_value\n else Int63.shift_left Int63.one num_bits_accum)\n in\n num_bits_accum, duration)\n ;;\nend\n\n\n(** Timing wheel is implemented as a priority queue in which the keys are\n non-negative integers corresponding to the intervals of time. The priority queue is\n unlike a typical priority queue in that rather than having a \"delete min\" operation,\n it has a nondecreasing minimum allowed key, which corresponds to the current time,\n and an [increase_min_allowed_key] operation, which implements [advance_clock].\n [increase_min_allowed_key] as a side effect removes all elements from the timing\n wheel whose key is smaller than the new minimum, which implements firing the alarms\n whose time has expired.\n\n Adding elements to and removing elements from a timing wheel takes constant time,\n unlike a heap-based priority queue which takes log(N), where N is the number of\n elements in the heap. [increase_min_allowed_key] takes time proportional to the\n amount of increase in the min-allowed key, as compared to log(N) for a heap. It is\n these performance differences that motivate the existence of timing wheels and make\n them a good choice for maintaing a set of alarms. With a timing wheel, one can\n support any number of alarms paying constant overhead per alarm, while paying a\n small constant overhead per unit of time passed.\n\n As the minimum allowed key increases, the timing wheel does a lazy radix sort of the\n element keys, with level 0 handling the least significant [b_0] bits in a key, and\n each subsequent level [i] handling the next most significant [b_i] bits. The levels\n hold increasingly larger ranges of keys, where the union of all the levels can hold\n any key from [min_allowed_key t] to [max_allowed_key t]. When a key is added to the\n timing wheel, it is added at the lowest possible level that can store the key. As\n the minimum allowed key increases, timing-wheel elements move down levels until they\n reach level 0, and then are eventually removed. *)\nmodule Priority_queue : sig\n type 'a t [@@deriving sexp_of]\n type 'a priority_queue = 'a t\n\n module Key : Interval_num\n\n module Elt : sig\n (** An [Elt.t] represents an element that was added to a timing wheel. *)\n type 'a t [@@deriving sexp_of]\n\n val at : 'a priority_queue -> 'a t -> Time_ns.t\n val key : 'a priority_queue -> 'a t -> Key.t\n val value : 'a priority_queue -> 'a t -> 'a\n val null : unit -> 'a t\n end\n\n module Internal_elt : sig\n module Pool : sig\n type 'a t\n end\n\n type 'a t\n\n val key : 'a Pool.t -> 'a t -> Key.t\n val max_alarm_time : 'a Pool.t -> 'a t -> with_key:Key.t -> Time_ns.t\n val is_null : _ t -> bool\n val to_external : 'a t -> 'a Elt.t\n end\n\n val pool : 'a t -> 'a Internal_elt.Pool.t\n\n include Invariant.S1 with type 'a t := 'a t\n\n (** [create ?level_bits ()] creates a new empty timing wheel, [t], with [length t = 0]\n and [min_allowed_key t = 0]. *)\n val create : ?capacity:int -> ?level_bits:Level_bits.t -> unit -> 'a t\n\n (** [length t] returns the number of elements in the timing wheel. *)\n val length : _ t -> int\n\n (** [min_allowed_key t] is the minimum key that can be stored in [t]. This only\n indicates the possibility; there need not be an element [elt] in [t] with [Elt.key\n elt = min_allowed_key t]. This is not the same as the \"min_key\" operation in a\n typical priority queue.\n\n [min_allowed_key t] can increase over time, via calls to\n [increase_min_allowed_key]. *)\n val min_allowed_key : _ t -> Key.t\n\n (** [max_allowed_key t] is the maximum allowed key that can be stored in [t]. As\n [min_allowed_key] increases, so does [max_allowed_key]; however it is not the case\n that [max_allowed_key t - min_allowed_key t] is a constant. It is guaranteed that\n [max_allowed_key t >= min_allowed_key t + 2^B - 1],\n where [B] is the sum of the b_i in [level_bits]. *)\n val max_allowed_key : _ t -> Key.t\n\n val min_elt_ : 'a t -> 'a Internal_elt.t\n val internal_add : 'a t -> key:Key.t -> at:Time_ns.t -> 'a -> 'a Internal_elt.t\n\n (** [remove t elt] removes [elt] from [t]. It is an error if [elt] is not currently\n in [t], and this error may or may not be detected. *)\n val remove : 'a t -> 'a Elt.t -> unit\n\n val change : 'a t -> 'a Elt.t -> key:Key.t -> at:Time_ns.t -> unit\n\n (** [clear t] removes all elts from [t]. *)\n val clear : _ t -> unit\n\n val mem : 'a t -> 'a Elt.t -> bool\n\n (** [increase_min_allowed_key t ~key ~handle_removed] increases the minimum allowed\n key in [t] to [key], and removes all elements with keys less than [key], applying\n [handle_removed] to each element that is removed. If [key <= min_allowed_key t],\n then [increase_min_allowed_key] does nothing. Otherwise, if\n [increase_min_allowed_key] returns successfully, [min_allowed_key t = key].\n\n [increase_min_allowed_key] takes time proportional to [key - min_allowed_key t],\n although possibly less time.\n\n Behavior is unspecified if [handle_removed] accesses [t] in any way other than\n [Elt] functions. *)\n val increase_min_allowed_key\n : 'a t\n -> key:Key.t\n -> handle_removed:('a Elt.t -> unit)\n -> unit\n\n val iter : 'a t -> f:('a Elt.t -> unit) -> unit\n\n val fire_past_alarms\n : 'a t\n -> handle_fired:('a Elt.t -> unit)\n -> key:Key.t\n -> now:Time_ns.t\n -> unit\nend = struct\n (** Each slot in a level is a (possibly null) pointer to a circular doubly-linked list\n of elements. We pool the elements so that we can reuse them after they are removed\n from the timing wheel (either via [remove] or [increase_min_allowed_key]). In\n addition to storing the [key], [at], and [value] in the element, we store the\n [level_index] so that we can quickly get to the level holding an element when we\n [remove] it.\n\n We distinguish between [External_elt] and [Internal_elt], which are the same\n underneath. We maintain the invariant that an [Internal_elt] is either [null] or a\n valid pointer. On the other hand, [External_elt]s are returned to user code, so\n there is no guarantee of validity -- we always validate an [External_elt] before\n doing anything with it.\n\n It is therefore OK to use [Pool.Unsafe], because we will never attempt to access a\n slot of an invalid pointer. *)\n module Pool = Pool.Unsafe\n\n module Pointer = Pool.Pointer\n\n module Key : sig\n (** [Interval_num] is the public API. Everything following in the signature is\n for internal use. *)\n include\n Timing_wheel_intf.Interval_num\n\n (** [add_clamp_to_max] doesn't work at all with negative spans *)\n val add_clamp_to_max : t -> Span.t -> t\n\n val succ_clamp_to_max : t -> t\n\n (** [Slots_mask] is used to quickly determine a key's slot in a given level. *)\n module Slots_mask : sig\n type t = private Int63.t [@@deriving compare, sexp_of]\n\n val create : level_bits:Num_key_bits.t -> t\n val next_slot : t -> int -> int\n end\n\n (** [Min_key_in_same_slot_mask] is used to quickly determine the minimum key in the\n same slot as a given key. *)\n module Min_key_in_same_slot_mask : sig\n type t = private Int63.t [@@deriving compare, sexp_of]\n\n include Equal.S with type t := t\n\n val create : bits_per_slot:Num_key_bits.t -> t\n end\n\n val num_keys : Num_key_bits.t -> Span.t\n val min_key_in_same_slot : t -> Min_key_in_same_slot_mask.t -> t\n val slot : t -> bits_per_slot:Num_key_bits.t -> slots_mask:Slots_mask.t -> int\n end = struct\n module Slots_mask = struct\n type t = Int63.t [@@deriving compare, sexp_of]\n\n let create ~level_bits = Int63.( - ) (Num_key_bits.pow2 level_bits) Int63.one\n let next_slot t slot = (slot + 1) land Int63.to_int_exn t\n end\n\n let num_keys num_bits = Num_key_bits.pow2 num_bits\n\n module Min_key_in_same_slot_mask = struct\n include Int63\n\n let create ~bits_per_slot = bit_not (Num_key_bits.pow2 bits_per_slot - one)\n end\n\n module Span = struct\n include Int63\n\n let to_int63 t = t\n let of_int63 i = i\n let scale_int t i = t * of_int i\n end\n\n include Int63\n\n let of_int63 i = i\n let to_int63 t = t\n let add t i = t + i\n let add_clamp_to_max t i = if t > max_value - i then max_value else t + i\n let succ_clamp_to_max t = if t = max_value then max_value else succ t\n let sub t i = t - i\n let diff t1 t2 = t1 - t2\n\n let slot t ~(bits_per_slot : Num_key_bits.t) ~slots_mask =\n to_int_exn (bit_and (shift_right t (bits_per_slot :> int)) slots_mask)\n ;;\n\n let min_key_in_same_slot t min_key_in_same_slot_mask =\n bit_and t min_key_in_same_slot_mask\n ;;\n end\n\n module Min_key_in_same_slot_mask = Key.Min_key_in_same_slot_mask\n module Slots_mask = Key.Slots_mask\n\n module External_elt = struct\n\n (** The [pool_slots] here has nothing to do with the slots in a level array. This is\n for the slots in the pool tuple representing a level element. *)\n type 'a pool_slots =\n ( Key.t\n , Time_ns.t\n , 'a\n , int\n , 'a pool_slots Pointer.t\n , 'a pool_slots Pointer.t )\n Pool.Slots.t6\n [@@deriving sexp_of]\n\n type 'a t = 'a pool_slots Pointer.t [@@deriving sexp_of]\n\n let null = Pointer.null\n end\n\n module Internal_elt : sig\n module Pool : sig\n type 'a t [@@deriving sexp_of]\n\n include Invariant.S1 with type 'a t := 'a t\n\n val create : ?capacity:int -> unit -> _ t\n val is_full : _ t -> bool\n val grow : ?capacity:int -> 'a t -> 'a t\n end\n\n type 'a t = private 'a External_elt.t [@@deriving sexp_of]\n\n val null : unit -> _ t\n val is_null : _ t -> bool\n val is_valid : 'a Pool.t -> 'a t -> bool\n\n (** Dealing with [External_elt]s. *)\n\n val external_is_valid : 'a Pool.t -> 'a External_elt.t -> bool\n val to_external : 'a t -> 'a External_elt.t\n val of_external_exn : 'a Pool.t -> 'a External_elt.t -> 'a t\n val equal : 'a t -> 'a t -> bool\n val invariant : 'a Pool.t -> ('a -> unit) -> 'a t -> unit\n\n (** [create] returns an element whose [next] and [prev] are [null]. *)\n val create\n : 'a Pool.t\n -> key:Key.t\n (** [at] is used when the priority queue is used to implement a timing wheel. If\n unused, it will be [Time_ns.epoch]. *)\n -> at:Time_ns.t\n -> value:'a\n -> level_index:int\n -> 'a t\n\n val free : 'a Pool.t -> 'a t -> unit\n\n (** accessors *)\n\n val key : 'a Pool.t -> 'a t -> Key.t\n val at : 'a Pool.t -> 'a t -> Time_ns.t\n val level_index : 'a Pool.t -> 'a t -> int\n val next : 'a Pool.t -> 'a t -> 'a t\n val value : 'a Pool.t -> 'a t -> 'a\n\n (** mutators *)\n\n val set_key : 'a Pool.t -> 'a t -> Key.t -> unit\n val set_at : 'a Pool.t -> 'a t -> Time_ns.t -> unit\n val set_level_index : 'a Pool.t -> 'a t -> int -> unit\n\n (** [insert_at_end pool t ~to_add] treats [t] as the head of the list and adds [to_add]\n to the end of it. *)\n val insert_at_end : 'a Pool.t -> 'a t -> to_add:'a t -> unit\n\n (** [link_to_self pool t] makes [t] be a singleton circular doubly-linked list. *)\n val link_to_self : 'a Pool.t -> 'a t -> unit\n\n (** [unlink p t] unlinks [t] from the circularly doubly-linked list that it is in. It\n changes the pointers of [t]'s [prev] and [next] elts, but not [t]'s [prev] and\n [next] pointers. [unlink] is meaningless if [t] is a singleton. *)\n val unlink : 'a Pool.t -> 'a t -> unit\n\n (** Iterators. [iter p t ~init ~f] visits each element in the doubly-linked list\n containing [t], starting at [t], and following [next] pointers. [length] counts\n by visiting each element in the list. *)\n val iter : 'a Pool.t -> 'a t -> f:('a t -> unit) -> unit\n\n val length : 'a Pool.t -> 'a t -> int\n\n (** [max_alarm_time t elt ~with_key] finds the max [at] in [elt]'s list among the elts\n whose key is [with_key], returning [Time_ns.epoch] if the list is empty. *)\n val max_alarm_time : 'a Pool.t -> 'a t -> with_key:Key.t -> Time_ns.t\n end = struct\n type 'a pool_slots = 'a External_elt.pool_slots [@@deriving sexp_of]\n type 'a t = 'a External_elt.t [@@deriving sexp_of]\n\n let null = Pointer.null\n let is_null = Pointer.is_null\n let equal t1 t2 = Pointer.phys_equal t1 t2\n\n let create pool ~key ~at ~value ~level_index =\n Pool.new6 pool key at value level_index (null ()) (null ())\n ;;\n\n let free = Pool.free\n let key p t = Pool.get p t Pool.Slot.t0\n let set_key p t k = Pool.set p t Pool.Slot.t0 k\n let at p t = Pool.get p t Pool.Slot.t1\n let set_at p t x = Pool.set p t Pool.Slot.t1 x\n let value p t = Pool.get p t Pool.Slot.t2\n let level_index p t = Pool.get p t Pool.Slot.t3\n let set_level_index p t i = Pool.set p t Pool.Slot.t3 i\n let prev p t = Pool.get p t Pool.Slot.t4\n let set_prev p t x = Pool.set p t Pool.Slot.t4 x\n let next p t = Pool.get p t Pool.Slot.t5\n let set_next p t x = Pool.set p t Pool.Slot.t5 x\n let is_valid p t = Pool.pointer_is_valid p t\n let external_is_valid = is_valid\n\n let invariant pool invariant_a t =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n assert (is_valid pool t);\n invariant_a (value pool t);\n let n = next pool t in\n assert (is_null n || Pointer.phys_equal t (prev pool n));\n let p = prev pool t in\n assert (is_null p || Pointer.phys_equal t (next pool p)))\n ;;\n\n module Pool = struct\n type 'a t = 'a pool_slots Pool.t [@@deriving sexp_of]\n\n let invariant _invariant_a t = Pool.invariant ignore t\n let create ?(capacity = 1) () = Pool.create Pool.Slots.t6 ~capacity\n let grow = Pool.grow\n let is_full = Pool.is_full\n end\n\n let to_external t = t\n\n let of_external_exn pool t =\n if is_valid pool t then t else raise_s [%message \"Timing_wheel got invalid alarm\"]\n ;;\n\n let unlink pool t =\n set_next pool (prev pool t) (next pool t);\n set_prev pool (next pool t) (prev pool t)\n ;;\n\n let link pool prev next =\n set_next pool prev next;\n set_prev pool next prev\n ;;\n\n let link_to_self pool t = link pool t t\n\n let insert_at_end pool t ~to_add =\n let prev = prev pool t in\n link pool prev to_add;\n link pool to_add t\n ;;\n\n let iter pool first ~f =\n let current = ref first in\n let continue = ref true in\n while !continue do\n (* We get [next] before calling [f] so that [f] can modify or [free] [!current]. *)\n let next = next pool !current in\n f !current;\n if phys_equal next first then continue := false else current := next\n done\n ;;\n\n let length pool first =\n let r = ref 0 in\n let current = ref first in\n let continue = ref true in\n while !continue do\n incr r;\n let next = next pool !current in\n if phys_equal next first then continue := false else current := next\n done;\n !r\n ;;\n\n let max_alarm_time pool first ~with_key =\n let max_alarm_time = ref Time_ns.epoch in\n let current = ref first in\n let continue = ref true in\n while !continue do\n let next = next pool !current in\n if Key.equal (key pool !current) with_key\n then max_alarm_time := Time_ns.max (at pool !current) !max_alarm_time;\n if phys_equal next first then continue := false else current := next\n done;\n !max_alarm_time\n ;;\n end\n\n module Level = struct\n (** For given level, one can break the bits into a key into three regions:\n\n {v\n | higher levels | this level | lower levels |\n v}\n\n \"Lower levels\" is [bits_per_slot] bits wide. \"This level\" is [bits] wide. *)\n type 'a t =\n { (* The [index] in the timing wheel's array of levels where this level is. *)\n index : int\n ; (* How many [bits] this level is responsible for. *)\n bits : Num_key_bits.t\n ; (* [slots_mask = Slots_mask.create ~level_bits:t.bits]. *)\n slots_mask : Slots_mask.t\n ; (* [bits_per_slot] is how many bits each slot distinguishes, and is the sum of of\n the [bits] of all the lower levels. *)\n bits_per_slot : Num_key_bits.t\n ; keys_per_slot : Key.Span.t\n ; min_key_in_same_slot_mask : Min_key_in_same_slot_mask.t\n ; (* [diff_max_min_allowed_key = keys_per_slot * Array.length slots - 1] *)\n diff_max_min_allowed_key : Key.Span.t\n ; (* [length] is the number of elts currently in this level. *)\n mutable length : int\n ; (* All elements at this level have their [key] satisfy [min_allowed_key <= key <=\n max_allowed_key]. Also, [min_allowed_key] is a multiple of [keys_per_slot]. *)\n mutable min_allowed_key : Key.t\n ; mutable max_allowed_key : Key.t\n ; (* [slots] holds the (possibly null) pointers to the circular doubly-linked lists\n of elts. [Array.length slots = 1 lsl bits]. *)\n slots : ('a Internal_elt.t array[@sexp.opaque])\n }\n [@@deriving fields, sexp_of]\n\n let slot t ~key =\n Key.slot key ~bits_per_slot:t.bits_per_slot ~slots_mask:t.slots_mask\n ;;\n\n let next_slot t slot = Slots_mask.next_slot t.slots_mask slot\n\n let min_key_in_same_slot t ~key =\n Key.min_key_in_same_slot key t.min_key_in_same_slot_mask\n ;;\n\n let compute_min_allowed_key t ~prev_level_max_allowed_key =\n (* This computation ensures that [t]'s [min_allowed_key] is as large as possible\n subject to the constraint that there is no inter-level gap. *)\n if Key.equal prev_level_max_allowed_key Key.max_value\n then Key.max_value\n else min_key_in_same_slot t ~key:(Key.succ prev_level_max_allowed_key)\n ;;\n end\n\n type 'a t =\n { mutable length : int\n ; mutable pool : 'a Internal_elt.Pool.t\n ; (* [min_elt] is either null or an element whose key is [elt_key_lower_bound]. *)\n mutable min_elt : 'a Internal_elt.t\n ; (* All elements in the priority queue have their key [>= elt_key_lower_bound]. *)\n mutable elt_key_lower_bound : Key.t\n ; levels : 'a Level.t array\n }\n [@@deriving fields, sexp_of]\n\n type 'a priority_queue = 'a t\n\n module Elt = struct\n type 'a t = 'a External_elt.t [@@deriving sexp_of]\n\n let null = External_elt.null\n let at p t = Internal_elt.at p.pool (Internal_elt.of_external_exn p.pool t)\n let key p t = Internal_elt.key p.pool (Internal_elt.of_external_exn p.pool t)\n let value p t = Internal_elt.value p.pool (Internal_elt.of_external_exn p.pool t)\n end\n\n let sexp_of_t_internal = sexp_of_t\n let is_empty t = length t = 0\n let num_levels t = Array.length t.levels\n let min_allowed_key t = Level.min_allowed_key t.levels.(0)\n let max_allowed_key t = Level.max_allowed_key t.levels.(num_levels t - 1)\n\n let internal_iter t ~f =\n if t.length > 0\n then (\n let pool = t.pool in\n let levels = t.levels in\n for level_index = 0 to Array.length levels - 1 do\n let level = levels.(level_index) in\n if level.length > 0\n then (\n let slots = level.slots in\n for slot_index = 0 to Array.length slots - 1 do\n let elt = slots.(slot_index) in\n if not (Internal_elt.is_null elt) then Internal_elt.iter pool elt ~f\n done)\n done)\n ;;\n\n let iter t ~f = internal_iter t ~f:(f : _ Elt.t -> unit :> _ Internal_elt.t -> unit)\n\n module Pretty = struct\n module Elt = struct\n type 'a t =\n { key : Key.t\n ; value : 'a\n }\n [@@deriving sexp_of]\n end\n\n type 'a t =\n { min_allowed_key : Key.t\n ; max_allowed_key : Key.t\n ; elts : 'a Elt.t list\n }\n [@@deriving sexp_of]\n end\n\n let pretty t =\n let pool = t.pool in\n { Pretty.min_allowed_key = min_allowed_key t\n ; max_allowed_key = max_allowed_key t\n ; elts =\n (let r = ref [] in\n internal_iter t ~f:(fun elt ->\n r\n := { Pretty.Elt.key = Internal_elt.key pool elt\n ; value = Internal_elt.value pool elt\n }\n :: !r);\n List.rev !r)\n }\n ;;\n\n let sexp_of_t sexp_of_a t =\n match !sexp_of_t_style with\n | `Internal -> [%sexp (t : a t_internal)]\n | `Pretty -> [%sexp (pretty t : a Pretty.t)]\n ;;\n\n let compute_diff_max_min_allowed_key ~level_bits ~bits_per_slot =\n let bits = Num_key_bits.( + ) level_bits bits_per_slot in\n if Num_key_bits.equal bits Num_key_bits.max_value\n then Key.Span.max_value\n else Key.Span.pred (Key.num_keys bits)\n ;;\n\n let invariant invariant_a t : unit =\n let pool = t.pool in\n let level_invariant level =\n Invariant.invariant [%here] level [%sexp_of: _ Level.t] (fun () ->\n let check f = Invariant.check_field level f in\n Level.Fields.iter\n ~index:(check (fun index -> assert (index >= 0)))\n ~bits:\n (check (fun bits -> assert (Num_key_bits.( > ) bits Num_key_bits.zero)))\n ~slots_mask:\n (check\n ([%test_result: Slots_mask.t]\n ~expect:(Slots_mask.create ~level_bits:level.bits)))\n ~bits_per_slot:\n (check (fun bits_per_slot ->\n assert (Num_key_bits.( >= ) bits_per_slot Num_key_bits.zero)))\n ~keys_per_slot:\n (check (fun keys_per_slot ->\n [%test_result: Key.Span.t]\n keys_per_slot\n ~expect:(Key.num_keys level.bits_per_slot)))\n ~min_key_in_same_slot_mask:\n (check (fun min_key_in_same_slot_mask ->\n assert (\n Min_key_in_same_slot_mask.equal\n min_key_in_same_slot_mask\n (Min_key_in_same_slot_mask.create\n ~bits_per_slot:level.bits_per_slot))))\n ~diff_max_min_allowed_key:\n (check\n ([%test_result: Key.Span.t]\n ~expect:\n (compute_diff_max_min_allowed_key\n ~level_bits:level.bits\n ~bits_per_slot:level.bits_per_slot)))\n ~length:\n (check (fun length ->\n assert (\n length\n = Array.fold level.slots ~init:0 ~f:(fun n elt ->\n if Internal_elt.is_null elt\n then n\n else n + Internal_elt.length pool elt))))\n ~min_allowed_key:\n (check (fun min_allowed_key ->\n assert (Key.( >= ) min_allowed_key Key.zero);\n if Key.( < ) min_allowed_key Key.max_value\n then\n [%test_result: Key.Span.t]\n (Key.rem min_allowed_key level.keys_per_slot)\n ~expect:Key.Span.zero))\n ~max_allowed_key:\n (check (fun max_allowed_key ->\n [%test_result: Key.t]\n max_allowed_key\n ~expect:\n (Key.add_clamp_to_max\n level.min_allowed_key\n level.diff_max_min_allowed_key)))\n ~slots:\n (check (fun slots ->\n Array.iter slots ~f:(fun elt ->\n if not (Internal_elt.is_null elt)\n then (\n Internal_elt.invariant pool invariant_a elt;\n Internal_elt.iter pool elt ~f:(fun elt ->\n assert (\n Key.( >= )\n (Internal_elt.key pool elt)\n level.min_allowed_key);\n assert (\n Key.( <= )\n (Internal_elt.key pool elt)\n level.max_allowed_key);\n assert (\n Key.( >= )\n (Internal_elt.key pool elt)\n t.elt_key_lower_bound);\n assert (Internal_elt.level_index pool elt = level.index);\n invariant_a (Internal_elt.value pool elt)))))))\n in\n Invariant.invariant [%here] t [%sexp_of: _ t_internal] (fun () ->\n let check f = Invariant.check_field t f in\n assert (Key.( >= ) (min_allowed_key t) Key.zero);\n assert (Key.( >= ) (max_allowed_key t) (min_allowed_key t));\n Fields.iter\n ~length:(check (fun length -> assert (length >= 0)))\n ~pool:(check (Internal_elt.Pool.invariant ignore))\n ~min_elt:\n (check (fun elt_ ->\n if not (Internal_elt.is_null elt_)\n then (\n assert (Internal_elt.is_valid t.pool elt_);\n assert (Key.equal t.elt_key_lower_bound (Internal_elt.key t.pool elt_)))))\n ~elt_key_lower_bound:\n (check (fun elt_key_lower_bound ->\n assert (Key.( >= ) elt_key_lower_bound (min_allowed_key t));\n assert (Key.( <= ) elt_key_lower_bound (max_allowed_key t));\n if not (Internal_elt.is_null t.min_elt)\n then\n assert (\n Key.equal elt_key_lower_bound (Internal_elt.key t.pool t.min_elt))))\n ~levels:\n (check (fun levels ->\n assert (num_levels t > 0);\n Array.iteri levels ~f:(fun level_index level ->\n assert (level_index = Level.index level);\n level_invariant level;\n if level_index > 0\n then (\n let prev_level = levels.(level_index - 1) in\n let module L = Level in\n [%test_result: Key.Span.t]\n (L.keys_per_slot level)\n ~expect:(Key.Span.succ prev_level.diff_max_min_allowed_key);\n [%test_result: Key.t]\n level.min_allowed_key\n ~expect:\n (Level.compute_min_allowed_key\n level\n ~prev_level_max_allowed_key:prev_level.max_allowed_key))))))\n ;;\n\n (** [min_elt_] returns [null] if it can't find the desired element. We wrap it up\n afterwards to return an [option]. *)\n let min_elt_ t =\n if is_empty t\n then Internal_elt.null ()\n else if not (Internal_elt.is_null t.min_elt)\n then t.min_elt\n else (\n let pool = t.pool in\n let min_elt_already_found = ref (Internal_elt.null ()) in\n let min_key_already_found = ref Key.max_value in\n let level_index = ref 0 in\n let num_levels = num_levels t in\n while !level_index < num_levels do\n let level = t.levels.(!level_index) in\n if Key.( > ) (Level.min_allowed_key level) !min_key_already_found\n then\n (* We don't need to consider any more levels. Quit the loop. *)\n level_index := num_levels\n else if level.length = 0\n then incr level_index\n else (\n (* Look in [level]. *)\n let slots = level.slots in\n let slot_min_key =\n ref\n (Level.min_key_in_same_slot\n level\n ~key:(Key.max level.min_allowed_key t.elt_key_lower_bound))\n in\n let slot = ref (Level.slot level ~key:!slot_min_key) in\n (* Find the first nonempty slot with a small enough [slot_min_key]. *)\n while\n Internal_elt.is_null slots.(!slot)\n && Key.( < ) !slot_min_key !min_key_already_found\n do\n slot := Level.next_slot level !slot;\n slot_min_key := Key.add !slot_min_key level.keys_per_slot\n done;\n let first = slots.(!slot) in\n if not (Internal_elt.is_null first)\n then (\n (* Visit all of the elts in this slot and find one with minimum key. *)\n let continue = ref true in\n let current = ref first in\n while !continue do\n let current_key = Internal_elt.key pool !current in\n if Key.( <= ) current_key !min_key_already_found\n then (\n min_elt_already_found := !current;\n min_key_already_found := current_key);\n let next = Internal_elt.next pool !current in\n (* If [!level_index = 0] then all elts in this slot have the same [key],\n i.e. [!slot_min_key]. So, we don't have to check any elements after\n [first]. This is a useful short cut in the common case that there are\n multiple elements in the same min slot in level 0. *)\n if phys_equal next first || !level_index = 0\n then continue := false\n else current := next\n done);\n (* Finished looking in [level]. Move up to the next level. *)\n incr level_index)\n done;\n t.min_elt <- !min_elt_already_found;\n t.elt_key_lower_bound <- !min_key_already_found;\n t.min_elt)\n ;;\n\n let[@cold] raise_add_elt_key_out_of_bounds t key =\n raise_s\n [%message\n \"Priority_queue.add_elt key out of bounds\"\n (key : Key.t)\n (min_allowed_key t : Key.t)\n (max_allowed_key t : Key.t)\n ~priority_queue:(t : _ t)]\n ;;\n\n let[@cold] raise_add_elt_key_out_of_level_bounds key level =\n raise_s\n [%message\n \"Priority_queue.add_elt key out of level bounds\"\n (key : Key.t)\n (level : _ Level.t)]\n ;;\n\n let add_elt t elt =\n let pool = t.pool in\n let key = Internal_elt.key pool elt in\n if not (Key.( >= ) key (min_allowed_key t) && Key.( <= ) key (max_allowed_key t))\n then raise_add_elt_key_out_of_bounds t key;\n (* Find the lowest level that will hold [elt]. *)\n let level_index =\n let level_index = ref 0 in\n while Key.( > ) key (Level.max_allowed_key t.levels.(!level_index)) do\n incr level_index\n done;\n !level_index\n in\n let level = t.levels.(level_index) in\n if not (Key.( >= ) key level.min_allowed_key && Key.( <= ) key level.max_allowed_key)\n then raise_add_elt_key_out_of_level_bounds key level;\n level.length <- level.length + 1;\n Internal_elt.set_level_index pool elt level_index;\n let slot = Level.slot level ~key in\n let slots = level.slots in\n let first = slots.(slot) in\n if not (Internal_elt.is_null first)\n then Internal_elt.insert_at_end pool first ~to_add:elt\n else (\n slots.(slot) <- elt;\n Internal_elt.link_to_self pool elt)\n ;;\n\n let internal_add_elt t elt =\n let key = Internal_elt.key t.pool elt in\n if Key.( < ) key t.elt_key_lower_bound\n then (\n t.min_elt <- elt;\n t.elt_key_lower_bound <- key);\n add_elt t elt;\n t.length <- t.length + 1\n ;;\n\n let[@cold] raise_got_invalid_key t key =\n raise_s\n [%message\n \"Timing_wheel.add_at_interval_num got invalid interval num\"\n ~interval_num:(key : Key.t)\n ~min_allowed_alarm_interval_num:(min_allowed_key t : Key.t)\n ~max_allowed_alarm_interval_num:(max_allowed_key t : Key.t)]\n ;;\n\n let ensure_valid_key t ~key =\n if Key.( < ) key (min_allowed_key t) || Key.( > ) key (max_allowed_key t)\n then raise_got_invalid_key t key\n ;;\n\n let internal_add t ~key ~at value =\n ensure_valid_key t ~key;\n if Internal_elt.Pool.is_full t.pool then t.pool <- Internal_elt.Pool.grow t.pool;\n let elt = Internal_elt.create t.pool ~key ~at ~value ~level_index:(-1) in\n internal_add_elt t elt;\n elt\n ;;\n\n (** [remove_or_re_add_elts] visits each element in the circular doubly-linked list\n [first]. If the element's key is [>= t_min_allowed_key], then it adds the element\n back at a lower level. If not, then it calls [handle_removed] and [free]s the\n element. *)\n let remove_or_re_add_elts\n t\n (level : _ Level.t)\n first\n ~t_min_allowed_key\n ~handle_removed\n =\n let pool = t.pool in\n let current = ref first in\n let continue = ref true in\n while !continue do\n (* We extract [next] from [current] first, because we will modify or [free]\n [current] before continuing the loop. *)\n let next = Internal_elt.next pool !current in\n level.length <- level.length - 1;\n if Key.( >= ) (Internal_elt.key pool !current) t_min_allowed_key\n then add_elt t !current\n else (\n t.length <- t.length - 1;\n handle_removed (Internal_elt.to_external !current);\n Internal_elt.free pool !current);\n if phys_equal next first then continue := false else current := next\n done\n ;;\n\n (** [increase_level_min_allowed_key] increases the [min_allowed_key] of [level] to as\n large a value as possible, but no more than [max_level_min_allowed_key].\n [t_min_allowed_key] is the minimum allowed key for the entire timing wheel. As\n elements are encountered, they are removed from the timing wheel if their key is\n smaller than [t_min_allowed_key], or added at a lower level if not. *)\n let increase_level_min_allowed_key\n t\n (level : _ Level.t)\n ~prev_level_max_allowed_key\n ~t_min_allowed_key\n ~handle_removed\n =\n let desired_min_allowed_key =\n Level.compute_min_allowed_key level ~prev_level_max_allowed_key\n in\n (* We require that [mod level.min_allowed_key level.keys_per_slot = 0]. So,\n we start [level_min_allowed_key] where that is true, and then increase it by\n [keys_per_slot] each iteration of the loop. *)\n let level_min_allowed_key =\n Level.min_key_in_same_slot\n level\n ~key:\n (Key.min\n desired_min_allowed_key\n (Key.max level.min_allowed_key t.elt_key_lower_bound))\n in\n let level_min_allowed_key = ref level_min_allowed_key in\n let slot = ref (Level.slot level ~key:!level_min_allowed_key) in\n let keys_per_slot = level.keys_per_slot in\n let slots = level.slots in\n while Key.( < ) !level_min_allowed_key desired_min_allowed_key do\n if level.length = 0\n then\n (* If no elements remain at this level, we can just set [min_allowed_key] to the\n desired value. *)\n level_min_allowed_key := desired_min_allowed_key\n else (\n let first = slots.(!slot) in\n if not (Internal_elt.is_null first)\n then (\n slots.(!slot) <- Internal_elt.null ();\n remove_or_re_add_elts t level first ~t_min_allowed_key ~handle_removed);\n slot := Level.next_slot level !slot;\n level_min_allowed_key\n := Key.add_clamp_to_max !level_min_allowed_key keys_per_slot)\n done;\n level.min_allowed_key <- desired_min_allowed_key;\n level.max_allowed_key\n <- Key.add_clamp_to_max desired_min_allowed_key level.diff_max_min_allowed_key\n ;;\n\n let increase_min_allowed_key t ~key ~handle_removed =\n if Key.( > ) key (min_allowed_key t)\n then (\n (* We increase the [min_allowed_key] of levels in order to restore the invariant\n that they have as large as possible a [min_allowed_key], while leaving no gaps\n in keys. *)\n let level_index = ref 0 in\n let prev_level_max_allowed_key = ref (Key.pred key) in\n let levels = t.levels in\n let num_levels = num_levels t in\n while !level_index < num_levels do\n let level = levels.(!level_index) in\n let min_allowed_key_before = level.min_allowed_key in\n increase_level_min_allowed_key\n t\n level\n ~prev_level_max_allowed_key:!prev_level_max_allowed_key\n ~t_min_allowed_key:key\n ~handle_removed;\n if Key.equal (Level.min_allowed_key level) min_allowed_key_before\n then\n (* This level did not shift. Don't shift any higher levels. *)\n level_index := num_levels\n else (\n (* Level [level_index] shifted. Consider shifting higher levels. *)\n level_index := !level_index + 1;\n prev_level_max_allowed_key := Level.max_allowed_key level)\n done;\n if Key.( > ) key t.elt_key_lower_bound\n then (\n (* We have removed [t.min_elt] or it was already null, so just set it to\n null. *)\n t.min_elt <- Internal_elt.null ();\n t.elt_key_lower_bound <- min_allowed_key t))\n ;;\n\n let create ?capacity ?level_bits () =\n let level_bits =\n match level_bits with\n | Some l -> l\n | None -> Level_bits.default\n in\n let _, _, levels =\n List.foldi\n level_bits\n ~init:(Num_key_bits.zero, Key.zero, [])\n ~f:(fun index\n (bits_per_slot, max_level_min_allowed_key, levels)\n (level_bits : Num_key_bits.t)\n ->\n let keys_per_slot = Key.num_keys bits_per_slot in\n let diff_max_min_allowed_key =\n compute_diff_max_min_allowed_key ~level_bits ~bits_per_slot\n in\n let min_key_in_same_slot_mask =\n Min_key_in_same_slot_mask.create ~bits_per_slot\n in\n let min_allowed_key =\n Key.min_key_in_same_slot max_level_min_allowed_key min_key_in_same_slot_mask\n in\n let max_allowed_key =\n Key.add_clamp_to_max min_allowed_key diff_max_min_allowed_key\n in\n let level =\n { Level.index\n ; bits = level_bits\n ; slots_mask = Slots_mask.create ~level_bits\n ; bits_per_slot\n ; keys_per_slot\n ; min_key_in_same_slot_mask\n ; diff_max_min_allowed_key\n ; length = 0\n ; min_allowed_key\n ; max_allowed_key\n ; slots =\n Array.create\n ~len:(Int63.to_int_exn (Num_key_bits.pow2 level_bits))\n (Internal_elt.null ())\n }\n in\n ( Num_key_bits.( + ) level_bits bits_per_slot\n , Key.succ_clamp_to_max max_allowed_key\n , level :: levels ))\n in\n { length = 0\n ; pool = Internal_elt.Pool.create ?capacity ()\n ; min_elt = Internal_elt.null ()\n ; elt_key_lower_bound = Key.zero\n ; levels = Array.of_list_rev levels\n }\n ;;\n\n let mem t elt = Internal_elt.external_is_valid t.pool elt\n\n let internal_remove t elt =\n let pool = t.pool in\n if Internal_elt.equal elt t.min_elt\n then\n t.min_elt <- Internal_elt.null ()\n (* We keep [t.elt_lower_bound] since it is valid even though [t.min_elt] is being\n removed. *);\n t.length <- t.length - 1;\n let level = t.levels.(Internal_elt.level_index pool elt) in\n level.length <- level.length - 1;\n let slots = level.slots in\n let slot = Level.slot level ~key:(Internal_elt.key pool elt) in\n let first = slots.(slot) in\n if phys_equal elt (Internal_elt.next pool elt)\n then (* [elt] is the only element in the slot *)\n slots.(slot) <- Internal_elt.null ()\n else (\n if phys_equal elt first then slots.(slot) <- Internal_elt.next pool elt;\n Internal_elt.unlink pool elt)\n ;;\n\n let remove t elt =\n let pool = t.pool in\n let elt = Internal_elt.of_external_exn pool elt in\n internal_remove t elt;\n Internal_elt.free pool elt\n ;;\n\n let fire_past_alarms t ~handle_fired ~key ~now =\n let level = t.levels.(0) in\n if level.length > 0\n then (\n let slot = Level.slot level ~key in\n let slots = level.slots in\n let pool = t.pool in\n let first = ref slots.(slot) in\n if not (Internal_elt.is_null !first)\n then (\n let current = ref !first in\n let continue = ref true in\n while !continue do\n let elt = !current in\n let next = Internal_elt.next pool elt in\n if phys_equal next !first then continue := false else current := next;\n if Time_ns.( <= ) (Internal_elt.at pool elt) now\n then (\n handle_fired (Internal_elt.to_external elt);\n internal_remove t elt;\n Internal_elt.free pool elt;\n (* We recompute [first] because [internal_remove] may have changed it. *)\n first := slots.(slot))\n done))\n ;;\n\n let change t elt ~key ~at =\n ensure_valid_key t ~key;\n let pool = t.pool in\n let elt = Internal_elt.of_external_exn pool elt in\n internal_remove t elt;\n Internal_elt.set_key pool elt key;\n Internal_elt.set_at pool elt at;\n internal_add_elt t elt\n ;;\n\n let clear t =\n if not (is_empty t)\n then (\n t.length <- 0;\n let pool = t.pool in\n let free_elt elt = Internal_elt.free pool elt in\n let levels = t.levels in\n for level_index = 0 to Array.length levels - 1 do\n let level = levels.(level_index) in\n if level.length > 0\n then (\n level.length <- 0;\n let slots = level.slots in\n for slot_index = 0 to Array.length slots - 1 do\n let elt = slots.(slot_index) in\n if not (Internal_elt.is_null elt)\n then (\n Internal_elt.iter pool elt ~f:free_elt;\n slots.(slot_index) <- Internal_elt.null ())\n done)\n done)\n ;;\nend\n\nmodule Internal_elt = Priority_queue.Internal_elt\nmodule Key = Priority_queue.Key\nmodule Interval_num = Key\n\nlet min_interval_num = Interval_num.zero\n\n(* All time from the epoch onwards is broken into half-open intervals of size\n [Config.alarm_precision config]. The intervals are numbered starting at zero, and a\n time's interval number serves as its key in [priority_queue]. *)\ntype 'a t =\n { config : Config.t\n ; start : Time_ns.t\n ; (* [max_interval_num] is the interval number of [max_time]. *)\n max_interval_num : Interval_num.t\n ; mutable now : Time_ns.t\n ; mutable now_interval_num_start : Time_ns.t\n ; mutable max_allowed_alarm_time : Time_ns.t\n ; priority_queue : 'a Priority_queue.t\n }\n[@@deriving fields, sexp_of]\n\ntype 'a timing_wheel = 'a t\ntype 'a t_now = 'a t\n\nlet sexp_of_t_now _ t = [%sexp (t.now : Time_ns.t)]\nlet alarm_precision t = Config.alarm_precision t.config\n\nmodule Alarm = struct\n type 'a t = 'a Priority_queue.Elt.t [@@deriving sexp_of]\n\n let null = Priority_queue.Elt.null\n let at tw t = Priority_queue.Elt.at tw.priority_queue t\n let value tw t = Priority_queue.Elt.value tw.priority_queue t\n let interval_num tw t = Priority_queue.Elt.key tw.priority_queue t\nend\n\nlet sexp_of_t_internal = sexp_of_t\nlet iter t ~f = Priority_queue.iter t.priority_queue ~f\n\nmodule Pretty = struct\n module Alarm = struct\n type 'a t =\n { at : Time_ns.t\n ; value : 'a\n }\n [@@deriving fields, sexp_of]\n\n let create t alarm = { at = Alarm.at t alarm; value = Alarm.value t alarm }\n let compare t1 t2 = Time_ns.compare (at t1) (at t2)\n end\n\n type 'a t =\n { config : Config.t\n ; start : Time_ns.t\n ; max_interval_num : Interval_num.t\n ; now : Time_ns.t\n ; alarms : 'a Alarm.t list\n }\n [@@deriving sexp_of]\nend\n\nlet pretty\n ({ config\n ; start\n ; max_interval_num\n ; now\n ; now_interval_num_start = _\n ; max_allowed_alarm_time = _\n ; priority_queue = _\n } as t)\n =\n let r = ref [] in\n iter t ~f:(fun a -> r := Pretty.Alarm.create t a :: !r);\n let alarms = List.sort !r ~compare:Pretty.Alarm.compare in\n { Pretty.config; start; max_interval_num; now; alarms }\n;;\n\nlet sexp_of_t sexp_of_a t =\n match !sexp_of_t_style with\n | `Internal -> sexp_of_t_internal sexp_of_a t\n | `Pretty -> [%sexp (pretty t : a Pretty.t)]\n;;\n\nlet length t = Priority_queue.length t.priority_queue\nlet is_empty t = length t = 0\n\nlet interval_num_internal ~time ~alarm_precision =\n Interval_num.of_int63 (Alarm_precision.interval_num alarm_precision time)\n;;\n\nlet interval_num_unchecked t time =\n interval_num_internal ~time ~alarm_precision:t.config.alarm_precision\n;;\n\nlet interval_num t time =\n if Time_ns.( < ) time min_time\n then\n raise_s\n [%message\n \"Timing_wheel.interval_num got time too far in the past\" (time : Time_ns.t)];\n interval_num_unchecked t time\n;;\n\nlet interval_num_start_unchecked t interval_num =\n Alarm_precision.interval_num_start\n t.config.alarm_precision\n (interval_num |> Interval_num.to_int63)\n;;\n\nlet[@cold] raise_interval_num_start_got_too_small interval_num =\n raise_s\n [%message\n \"Timing_wheel.interval_num_start got too small interval_num\"\n (interval_num : Interval_num.t)\n (min_interval_num : Interval_num.t)]\n;;\n\nlet[@cold] raise_interval_num_start_got_too_large t interval_num =\n raise_s\n [%message\n \"Timing_wheel.interval_num_start got too large interval_num\"\n (interval_num : Interval_num.t)\n (t.max_interval_num : Interval_num.t)]\n;;\n\nlet interval_num_start t interval_num =\n if Interval_num.( < ) interval_num min_interval_num\n then raise_interval_num_start_got_too_small interval_num;\n if Interval_num.( > ) interval_num t.max_interval_num\n then raise_interval_num_start_got_too_large t interval_num;\n interval_num_start_unchecked t interval_num\n;;\n\nlet compute_max_allowed_alarm_time t =\n let max_allowed_key = Priority_queue.max_allowed_key t.priority_queue in\n if Interval_num.( >= ) max_allowed_key t.max_interval_num\n then max_time\n else\n Time_ns.add\n (interval_num_start_unchecked t max_allowed_key)\n (Time_ns.Span.( - ) (alarm_precision t) Time_ns.Span.nanosecond)\n;;\n\nlet now_interval_num t = Priority_queue.min_allowed_key t.priority_queue\nlet min_allowed_alarm_interval_num = now_interval_num\nlet max_allowed_alarm_interval_num t = interval_num t (max_allowed_alarm_time t)\nlet interval_start t time = interval_num_start_unchecked t (interval_num t time)\n\nlet invariant invariant_a t =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~config:(check Config.invariant)\n ~start:\n (check (fun start ->\n assert (Time_ns.( >= ) start min_time);\n assert (Time_ns.( <= ) start max_time)))\n ~max_interval_num:\n (check (fun max_interval_num ->\n [%test_result: Interval_num.t]\n ~expect:max_interval_num\n (interval_num t max_time);\n [%test_result: Interval_num.t]\n ~expect:max_interval_num\n (interval_num t (interval_num_start t max_interval_num))))\n ~now:\n (check (fun now ->\n assert (Time_ns.( >= ) now t.start);\n assert (Time_ns.( <= ) now max_time);\n assert (\n Interval_num.equal\n (interval_num t t.now)\n (Priority_queue.min_allowed_key t.priority_queue))))\n ~now_interval_num_start:\n (check (fun now_interval_num_start ->\n [%test_result: Time_ns.t]\n now_interval_num_start\n ~expect:(interval_num_start t (now_interval_num t))))\n ~max_allowed_alarm_time:\n (check (fun max_allowed_alarm_time ->\n [%test_result: Time_ns.t]\n max_allowed_alarm_time\n ~expect:(compute_max_allowed_alarm_time t)))\n ~priority_queue:(check (Priority_queue.invariant invariant_a));\n iter t ~f:(fun alarm ->\n assert (\n Interval_num.equal\n (Alarm.interval_num t alarm)\n (interval_num t (Alarm.at t alarm)));\n assert (\n Time_ns.( >= )\n (interval_start t (Alarm.at t alarm))\n (interval_start t (now t)));\n assert (\n Time_ns.( > ) (Alarm.at t alarm) (Time_ns.sub (now t) (alarm_precision t)))))\n;;\n\nlet advance_clock t ~to_ ~handle_fired =\n if Time_ns.( > ) to_ (now t)\n then (\n t.now <- to_;\n let key = interval_num_unchecked t to_ in\n t.now_interval_num_start <- interval_num_start_unchecked t key;\n Priority_queue.increase_min_allowed_key\n t.priority_queue\n ~key\n ~handle_removed:handle_fired;\n t.max_allowed_alarm_time <- compute_max_allowed_alarm_time t)\n;;\n\nlet create ~config ~start =\n if Time_ns.( < ) start Time_ns.epoch\n then\n raise_s\n [%message \"Timing_wheel.create got start before the epoch\" (start : Time_ns.t)];\n let t =\n { config\n ; start\n ; max_interval_num =\n interval_num_internal ~time:max_time ~alarm_precision:config.alarm_precision\n ; now = Time_ns.min_value_for_1us_rounding (* set by [advance_clock] below *)\n ; now_interval_num_start =\n Time_ns.min_value_for_1us_rounding (* set by [advance_clock] below *)\n ; max_allowed_alarm_time = max_time (* set by [advance_clock] below *)\n ; priority_queue =\n Priority_queue.create ?capacity:config.capacity ~level_bits:config.level_bits ()\n }\n in\n advance_clock t ~to_:start ~handle_fired:(fun _ -> assert false);\n t\n;;\n\nlet add_at_interval_num t ~at value =\n Internal_elt.to_external\n (Priority_queue.internal_add\n t.priority_queue\n ~key:at\n ~at:(interval_num_start t at)\n value)\n;;\n\nlet[@cold] raise_that_far_in_the_future t at =\n raise_s\n [%message\n \"Timing_wheel cannot schedule alarm that far in the future\"\n (at : Time_ns.t)\n ~max_allowed_alarm_time:(t.max_allowed_alarm_time : Time_ns.t)]\n;;\n\nlet[@cold] raise_before_start_of_current_interval t at =\n raise_s\n [%message\n \"Timing_wheel cannot schedule alarm before start of current interval\"\n (at : Time_ns.t)\n ~now_interval_num_start:(t.now_interval_num_start : Time_ns.t)]\n;;\n\nlet ensure_can_schedule_alarm t ~at =\n if Time_ns.( > ) at t.max_allowed_alarm_time then raise_that_far_in_the_future t at;\n if Time_ns.( < ) at t.now_interval_num_start\n then raise_before_start_of_current_interval t at\n;;\n\nlet add t ~at value =\n ensure_can_schedule_alarm t ~at;\n Internal_elt.to_external\n (Priority_queue.internal_add\n t.priority_queue\n ~key:(interval_num_unchecked t at)\n ~at\n value)\n;;\n\nlet remove t alarm = Priority_queue.remove t.priority_queue alarm\nlet clear t = Priority_queue.clear t.priority_queue\nlet mem t alarm = Priority_queue.mem t.priority_queue alarm\n\nlet reschedule_gen t alarm ~key ~at =\n if not (mem t alarm)\n then failwith \"Timing_wheel cannot reschedule alarm not in timing wheel\";\n ensure_can_schedule_alarm t ~at;\n Priority_queue.change t.priority_queue alarm ~key ~at\n;;\n\nlet reschedule t alarm ~at =\n reschedule_gen t alarm ~key:(interval_num_unchecked t at) ~at\n;;\n\nlet reschedule_at_interval_num t alarm ~at =\n reschedule_gen t alarm ~key:at ~at:(interval_num_start t at)\n;;\n\nlet pool t = Priority_queue.pool t.priority_queue\n\nlet min_alarm_interval_num t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt then None else Some (Internal_elt.key (pool t) elt)\n;;\n\nlet min_alarm_interval_num_exn t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt\n then\n raise_s\n [%message\n \"Timing_wheel.min_alarm_interval_num_exn of empty timing_wheel\"\n ~timing_wheel:(t : _ t)]\n else Internal_elt.key (pool t) elt\n;;\n\nlet max_alarm_time_in_list t elt =\n let pool = pool t in\n Internal_elt.max_alarm_time pool elt ~with_key:(Internal_elt.key pool elt)\n;;\n\nlet max_alarm_time_in_min_interval t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt then None else Some (max_alarm_time_in_list t elt)\n;;\n\nlet max_alarm_time_in_min_interval_exn t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt\n then\n raise_s\n [%message\n \"Timing_wheel.max_alarm_time_in_min_interval_exn of empty timing wheel\"\n ~timing_wheel:(t : _ t)];\n max_alarm_time_in_list t elt\n;;\n\nlet next_alarm_fires_at_internal t key =\n (* [interval_num_start t key] is the key corresponding to the start of the time interval\n holding the first alarm in [t]. Advancing to that would not be enough, since the\n alarms in that interval don't fire until the clock is advanced to the start of the\n next interval. So, we use [succ key] to advance to the start of the next\n interval. *)\n interval_num_start t (Key.succ key)\n;;\n\nlet next_alarm_fires_at t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt\n then None\n else (\n let key = Internal_elt.key (pool t) elt in\n if Interval_num.equal key t.max_interval_num\n then None\n else Some (next_alarm_fires_at_internal t key))\n;;\n\nlet[@cold] raise_next_alarm_fires_at_exn_of_empty_timing_wheel t =\n raise_s\n [%message\n \"Timing_wheel.next_alarm_fires_at_exn of empty timing wheel\"\n ~timing_wheel:(t : _ t)]\n;;\n\nlet[@cold] raise_next_alarm_fires_at_with_all_alarms_in_max_interval t =\n raise_s\n [%message\n \"Timing_wheel.next_alarm_fires_at_exn with all alarms in max interval\"\n ~timing_wheel:(t : _ t)]\n;;\n\nlet next_alarm_fires_at_exn t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt then raise_next_alarm_fires_at_exn_of_empty_timing_wheel t;\n let key = Internal_elt.key (pool t) elt in\n if Interval_num.equal key t.max_interval_num\n then raise_next_alarm_fires_at_with_all_alarms_in_max_interval t;\n next_alarm_fires_at_internal t key\n;;\n\nlet fire_past_alarms t ~handle_fired =\n Priority_queue.fire_past_alarms\n t.priority_queue\n ~handle_fired\n ~key:(now_interval_num t)\n ~now:t.now\n;;\n\nmodule Private = struct\n module Num_key_bits = Num_key_bits\n\n let interval_num_internal = interval_num_internal\n let max_time = max_time\nend\n","module Inria_sys = Sys\nmodule Time_ns_in_this_directory = Time_ns\nopen Core_kernel\nopen Poly\nmodule Time_ns = Time_ns_in_this_directory\n\nlet sec = Time_ns.Span.of_sec\nlet concat = String.concat\n\nmodule Epoll_max_ready_events = Validated.Make (struct\n include Int\n\n let here = [%here]\n let validate = Int.validate_positive\n end)\n\nmodule Max_inter_cycle_timeout = Validated.Make (struct\n include Time_ns.Span\n\n let here = [%here]\n let validate = Time_ns.Span.validate_non_negative\n end)\n\nmodule Min_inter_cycle_timeout = Validated.Make (struct\n include Time_ns.Span\n\n let here = [%here]\n let validate = Time_ns.Span.validate_non_negative\n end)\n\nmodule Max_num_open_file_descrs = struct\n include Validated.Make (struct\n include Int\n\n let here = [%here]\n let validate = Int.validate_positive\n end)\n\n let default = create_exn (1 lsl 16)\n let equal (t1 : t) t2 = t1 = t2\nend\n\nmodule Max_num_threads = Validated.Make (struct\n include Int\n\n let here = [%here]\n let validate = Int.validate_positive\n end)\n\nmodule Max_num_jobs_per_priority_per_cycle = Validated.Make (struct\n include Int\n\n let here = [%here]\n let validate = Int.validate_positive\n end)\n\nmodule Dump_core_on_job_delay = struct\n module How_to_dump = struct\n type t =\n | Default\n | Call_abort\n | Call_gcore\n [@@deriving sexp]\n end\n\n type watch =\n { dump_if_delayed_by : Time_ns.Span.t\n ; how_to_dump : How_to_dump.t\n }\n [@@deriving sexp]\n\n type t =\n | Watch of watch\n | Do_not_watch\n [@@deriving sexp]\nend\n\nmodule Debug_tag = struct\n module T = struct\n type t =\n | All\n | Clock\n | Fd\n | File_descr_watcher\n | Finalizers\n | Interruptor\n | Monitor\n | Monitor_send_exn\n | Parallel\n | Reader\n | Scheduler\n | Shutdown\n | Thread_pool\n | Thread_safe\n | Writer\n [@@deriving compare, sexp]\n\n let equal = [%compare.equal: t]\n end\n\n include T\n include Sexpable.To_stringable (T)\n\n let list =\n [ All\n ; Clock\n ; Fd\n ; File_descr_watcher\n ; Finalizers\n ; Interruptor\n ; Monitor\n ; Monitor_send_exn\n ; Parallel\n ; Reader\n ; Scheduler\n ; Shutdown\n ; Thread_pool\n ; Thread_safe\n ; Writer\n ]\n ;;\nend\n\nmodule File_descr_watcher = struct\n module T = struct\n type t =\n | Epoll_if_timerfd\n | Epoll\n | Select\n [@@deriving sexp]\n end\n\n include T\n include Sexpable.To_stringable (T)\n\n let list = [ Epoll_if_timerfd; Epoll; Select ]\nend\n\ntype t =\n { abort_after_thread_pool_stuck_for : Time_ns.Span.t option [@sexp.option]\n ; check_invariants : bool option [@sexp.option]\n ; detect_invalid_access_from_thread : bool option [@sexp.option]\n ; dump_core_on_job_delay : Dump_core_on_job_delay.t option [@sexp.option]\n ; epoll_max_ready_events : Epoll_max_ready_events.t option [@sexp.option]\n ; file_descr_watcher : File_descr_watcher.t option [@sexp.option]\n ; max_inter_cycle_timeout : Max_inter_cycle_timeout.t option [@sexp.option]\n ; max_num_open_file_descrs : Max_num_open_file_descrs.t option [@sexp.option]\n ; max_num_threads : Max_num_threads.t option [@sexp.option]\n ; max_num_jobs_per_priority_per_cycle : Max_num_jobs_per_priority_per_cycle.t option\n [@sexp.option]\n ; min_inter_cycle_timeout : Min_inter_cycle_timeout.t option [@sexp.option]\n ; print_debug_messages_for : Debug_tag.t list option [@sexp.option]\n ; record_backtraces : bool option [@sexp.option]\n ; report_thread_pool_stuck_for : Time_ns.Span.t option [@sexp.option]\n ; thread_pool_cpu_affinity : Thread_pool_cpu_affinity.t option [@sexp.option]\n ; timing_wheel_config : Timing_wheel.Config.t option [@sexp.option]\n }\n[@@deriving fields, sexp]\n\nlet empty =\n { abort_after_thread_pool_stuck_for = None\n ; check_invariants = None\n ; detect_invalid_access_from_thread = None\n ; dump_core_on_job_delay = None\n ; epoll_max_ready_events = None\n ; file_descr_watcher = None\n ; max_inter_cycle_timeout = None\n ; max_num_open_file_descrs = None\n ; max_num_threads = None\n ; max_num_jobs_per_priority_per_cycle = None\n ; min_inter_cycle_timeout = None\n ; print_debug_messages_for = None\n ; record_backtraces = None\n ; report_thread_pool_stuck_for = None\n ; thread_pool_cpu_affinity = None\n ; timing_wheel_config = None\n }\n;;\n\nlet default_timing_wheel_config_for_word_size (word_size : Word_size.t) =\n let module Alarm_precision = Timing_wheel.Alarm_precision in\n let alarm_precision, level_bits =\n match word_size with\n | W32 -> Alarm_precision.about_one_millisecond, [ 10; 10; 9 ]\n | W64 -> Alarm_precision.(div about_one_millisecond ~pow2:3), [ 14; 15; 9; 6 ]\n in\n Timing_wheel.Config.create\n ~alarm_precision\n ~level_bits:(Timing_wheel.Level_bits.create_exn level_bits)\n ()\n;;\n\nlet default_timing_wheel_config =\n default_timing_wheel_config_for_word_size Word_size.word_size\n;;\n\nlet default =\n (* For [file_descr_watcher] and [max_num_open_file_descrs] we choose the default for the\n common case that [epoll] is available. There is some additional code in\n [Async_unix.Config] that checks whether [epoll] is actually available, and if not,\n uses [select] and a smaller number of file descriptors. *)\n { abort_after_thread_pool_stuck_for = Some (sec 60.)\n ; check_invariants = Some false\n ; detect_invalid_access_from_thread = Some false\n ; dump_core_on_job_delay = Some Do_not_watch\n ; epoll_max_ready_events = Some (Epoll_max_ready_events.create_exn 256)\n ; file_descr_watcher = Some Epoll_if_timerfd\n ; max_inter_cycle_timeout = Some (Max_inter_cycle_timeout.create_exn (sec 0.05))\n ; max_num_open_file_descrs = Some Max_num_open_file_descrs.default\n ; max_num_threads = Some (Max_num_threads.create_exn 50)\n ; max_num_jobs_per_priority_per_cycle =\n Some (Max_num_jobs_per_priority_per_cycle.create_exn 500)\n ; min_inter_cycle_timeout = Some (Min_inter_cycle_timeout.create_exn (sec 0.))\n ; print_debug_messages_for = Some []\n ; record_backtraces = Some false\n ; report_thread_pool_stuck_for = Some (sec 1.)\n ; thread_pool_cpu_affinity = Some Inherit\n ; timing_wheel_config = Some default_timing_wheel_config\n }\n;;\n\nlet example =\n { default with\n print_debug_messages_for = Some Debug_tag.[ Fd; Scheduler ]\n ; thread_pool_cpu_affinity =\n Some\n (Cpuset\n ([ 0; 1; 2 ] |> Int.Set.of_list |> Thread_pool_cpu_affinity.Cpuset.create_exn))\n }\n;;\n\nlet environment_variable = \"ASYNC_CONFIG\"\n\nlet field_descriptions () : string =\n let field to_sexp description ac field =\n (Field.name field, to_sexp (Option.value_exn (Field.get field default)), description)\n :: ac\n in\n let fields =\n Fields.fold\n ~init:[]\n ~abort_after_thread_pool_stuck_for:\n (field\n [%sexp_of: Time_ns.Span.t]\n [ {|\n By default, Async will send an exception to the toplevel monitor\n if it detects that the thread pool is stuck for longer than this.\n|}\n ])\n ~check_invariants:\n (field\n [%sexp_of: bool]\n [ {|\n If true, causes Async to regularly check invariants of its internal\n data structures. This can substantially slow down your program.\n|}\n ])\n ~detect_invalid_access_from_thread:\n (field\n [%sexp_of: bool]\n [ {|\n If true, causes Async routines to check if they are being accessed\n from some thread other than the thread currently holding the Async\n lock, which is not allowed and can lead to very confusing behavior.\n|}\n ])\n ~dump_core_on_job_delay:\n (field\n [%sexp_of: Dump_core_on_job_delay.t]\n [ {|\n Can be set to [Do_not_watch] or:\n\n (Watch ((dump_if_delayed_by SPAN) (how_to_dump HOW)))\n\n If set to [Watch], then on program start this will start a regular\n Async job that increments a counter, and a C thread that will\n detect if that job is delayed by [dump_if_delayed_by], and if so,\n will core dump the program. If available, [/usr/bin/gcore] is\n used by default to dump the core, which should allow the program\n to continue running. Otherwise, [abort] will be called from C,\n which will kill the program while causing a core dump. One can\n force [abort] or [gcore] via [how_to_dump], which should be one of:\n [Call_abort], [Call_gcore], or [Default].\n|}\n ])\n ~epoll_max_ready_events:\n (field\n [%sexp_of: Epoll_max_ready_events.t]\n [ {|\n The maximum number of ready events that Async's call to [Epoll.wait]\n will handle.\n|}\n ])\n ~file_descr_watcher:\n (field\n [%sexp_of: File_descr_watcher.t]\n [ {|\n This determines what OS subsystem Async uses to watch file descriptors for being ready.\n The default is to use [epoll] if timerfd's are supported and if not, use [select].\n\n Allowed values are:|}\n ; concat\n ~sep:\", \"\n (List.map File_descr_watcher.list ~f:File_descr_watcher.to_string)\n ; {|.\n|}\n ])\n ~max_num_open_file_descrs:\n (field\n (fun default ->\n [%message\n \"\"\n ~_:\n (concat\n [ \"min \"\n ; default |> Max_num_open_file_descrs.raw |> Int.to_string_hum\n ; \" [ulimit -n -H]\"\n ]\n : string)])\n [ {|\n The maximum number of open file descriptors allowed at any one time.|} ])\n ~max_num_threads:\n (field\n [%sexp_of: Max_num_threads.t]\n [ {|\n The maximum number of threads that Async will create to do blocking\n system calls and handle calls to [In_thread.run].\n|}\n ])\n ~max_inter_cycle_timeout:\n (field\n [%sexp_of: Max_inter_cycle_timeout.t]\n [ {|\n The maximum amount of time the scheduler will pause between cycles\n when it has no jobs and is going to wait for I/O. In principle one\n doesn't need this, and we could use an infinite timeout. We instead\n use a small timeout (by default), to be more robust to bugs that\n could prevent Async from waking up and servicing events. For\n example, as of 2013-01, the OCaml runtime has a bug that causes it\n to not necessarily run an OCaml signal handler in a timely manner.\n This in turn can cause a simple Async program that is waiting on a\n signal to hang, when in fact it should handle the signal.\n\n We use 50ms as the default timeout, because it is infrequent enough\n to have a negligible performance impact, and frequent enough that\n the latency would typically be not noticeable. Also, 50ms is what\n the OCaml ticker thread uses.\n|}\n ])\n ~max_num_jobs_per_priority_per_cycle:\n (field\n [%sexp_of: Max_num_jobs_per_priority_per_cycle.t]\n [ {|\n The maximum number of jobs that will be done at each priority within\n each Async cycle. This limits how many jobs the scheduler will run\n before pausing to check for I/O.\n|}\n ])\n ~min_inter_cycle_timeout:\n (field\n [%sexp_of: Min_inter_cycle_timeout.t]\n [ {|\n The minimum timeout the scheduler will pass to the OS when it checks\n for I/O between cycles. This is zero by default. Setting it to a\n nonzero value is used to increase thread fairness between the scheduler\n and other threads. A plausible setting is 1us. This is also\n configurable in OCaml via [Scheduler.set_min_inter_cycle_timeout].\n|}\n ])\n ~print_debug_messages_for:\n (field\n [%sexp_of: Debug_tag.t list]\n [ {|\n A list of tags specifying which Async functions should print debug\n messages to stderr. Each tag identifies a group of related Async\n functions. The tag [all] means to print debug messages for all\n functions. Allowed values are:\n\n|}\n ; concat\n (List.map Debug_tag.list ~f:(fun d ->\n concat [ \" \"; Debug_tag.to_string d; \"\\n\" ]))\n ; {|\n Turning on debug messages will substantially slow down most programs.\n|}\n ])\n ~record_backtraces:\n (field\n [%sexp_of: bool]\n [ {|\n If true, this will cause Async to keep in the execution context the\n history of stack backtraces (obtained via [Backtrace.get]) that led\n to the current job. If an Async job has an unhandled exception,\n this backtrace history will be recorded in the exception. In\n particular the history will appear in an unhandled exception that\n reaches the main monitor. This can have a substantial performance\n impact, both in running time and space usage.\n|}\n ])\n ~report_thread_pool_stuck_for:\n (field\n [%sexp_of: Time_ns.Span.t]\n [ {|\n By default, Async will print a message to stderr every second if\n the thread pool is stuck for longer than this.\n|}\n ])\n ~thread_pool_cpu_affinity:\n (field\n [%sexp_of: Thread_pool_cpu_affinity.t]\n [ {|\n Whether and how threads in the thread pool should be affinitized to CPUs.\n|}\n ])\n ~timing_wheel_config:\n (field\n [%sexp_of: Timing_wheel.Config.t]\n [ {|\n This is used to adjust the time/space tradeoff in the timing wheel\n used to implement Async's clock. Time is split into intervals of\n size [alarm_precision], and alarms with times in the same interval\n fire in the same cycle. Level [i] in the timing wheel has an\n array of size [2^b], where [b] is the [i]'th entry in [level_bits].\n|}\n ])\n in\n concat\n (List.map\n (List.sort fields ~compare:(fun (name1, _, _) (name2, _, _) ->\n String.compare name1 name2))\n ~f:(fun (name, default, description) ->\n concat\n (\"\\n\" :: name :: \" (default \" :: Sexp.to_string default :: \")\" :: description)))\n;;\n\nlet help_message () =\n concat\n [ \"The \"\n ; environment_variable\n ; {| environment variable affects Async\nin various ways. Its value should be a sexp of the following form,\nwhere all fields are optional:\n\n|}\n ; Sexp.to_string_hum (sexp_of_t example)\n ; {|\n\nHere is an explanation of each field.\n|}\n ; field_descriptions ()\n ]\n;;\n\nlet usage () =\n eprintf \"%s%!\" (help_message ());\n exit 1\n;;\n\nlet t =\n match Option.try_with (fun () -> Inria_sys.getenv environment_variable) with\n | None -> empty\n | Some \"\" -> usage ()\n | Some string ->\n (match Result.try_with (fun () -> t_of_sexp (Sexp.of_string string)) with\n | Ok t -> t\n | Error exn ->\n eprintf\n \"%s\\n\\n\"\n (Sexp.to_string_hum\n (Error.sexp_of_t\n (Error.create\n (sprintf\n \"invalid value for %s environment variable\"\n environment_variable)\n exn\n [%sexp_of: exn])));\n usage ())\n;;\n\nmodule Print_debug_messages_for = struct\n let print_debug_messages_for tag =\n match t.print_debug_messages_for with\n | None -> false\n | Some l -> List.mem l tag ~equal:Debug_tag.equal\n ;;\n\n let all = print_debug_messages_for All\n let debug tag = all || print_debug_messages_for tag\n let clock = debug Clock\n let fd = debug Fd\n let file_descr_watcher = debug File_descr_watcher\n let finalizers = debug Finalizers\n let interruptor = debug Interruptor\n let monitor = debug Monitor\n let monitor_send_exn = debug Monitor_send_exn\n let parallel = debug Parallel\n let reader = debug Reader\n let scheduler = debug Scheduler\n let shutdown = debug Shutdown\n let thread_pool = debug Thread_pool\n let thread_safe = debug Thread_safe\n let writer = debug Writer\nend\n\nlet ( !! ) field =\n Option.value (Field.get field t) ~default:(Option.value_exn (Field.get field default))\n;;\n\nlet abort_after_thread_pool_stuck_for = !!Fields.abort_after_thread_pool_stuck_for\nlet check_invariants = !!Fields.check_invariants\nlet detect_invalid_access_from_thread = !!Fields.detect_invalid_access_from_thread\nlet epoll_max_ready_events = !!Fields.epoll_max_ready_events\nlet thread_pool_cpu_affinity = !!Fields.thread_pool_cpu_affinity\nlet file_descr_watcher = !!Fields.file_descr_watcher\nlet max_inter_cycle_timeout = !!Fields.max_inter_cycle_timeout\nlet max_num_open_file_descrs = !!Fields.max_num_open_file_descrs\nlet max_num_threads = !!Fields.max_num_threads\nlet max_num_jobs_per_priority_per_cycle = !!Fields.max_num_jobs_per_priority_per_cycle\nlet min_inter_cycle_timeout = !!Fields.min_inter_cycle_timeout\nlet record_backtraces = !!Fields.record_backtraces\nlet report_thread_pool_stuck_for = !!Fields.report_thread_pool_stuck_for\nlet timing_wheel_config = !!Fields.timing_wheel_config\nlet dump_core_on_job_delay = !!Fields.dump_core_on_job_delay\n\nlet t =\n { abort_after_thread_pool_stuck_for = Some abort_after_thread_pool_stuck_for\n ; check_invariants = Some check_invariants\n ; detect_invalid_access_from_thread = Some detect_invalid_access_from_thread\n ; dump_core_on_job_delay = Some dump_core_on_job_delay\n ; thread_pool_cpu_affinity = Some thread_pool_cpu_affinity\n ; epoll_max_ready_events = Some epoll_max_ready_events\n ; file_descr_watcher = Some file_descr_watcher\n ; max_inter_cycle_timeout = Some max_inter_cycle_timeout\n ; max_num_open_file_descrs = Some max_num_open_file_descrs\n ; max_num_threads = Some max_num_threads\n ; max_num_jobs_per_priority_per_cycle = Some max_num_jobs_per_priority_per_cycle\n ; min_inter_cycle_timeout = Some min_inter_cycle_timeout\n ; print_debug_messages_for = t.print_debug_messages_for\n ; record_backtraces = Some record_backtraces\n ; report_thread_pool_stuck_for = Some report_thread_pool_stuck_for\n ; timing_wheel_config = Some timing_wheel_config\n }\n;;\n\nlet task_id = ref (fun () -> Sexp.Atom \"\")\n","open Core_kernel\nopen Import\nopen Deferred_std\nmodule Deferred = Deferred1\nmodule Scheduler = Scheduler1\nmodule Stream = Tail.Stream\nmodule Monitor = Monitor0\ninclude Monitor\n\ntype monitor = t [@@deriving sexp_of]\n\nlet invariant t =\n Invariant.invariant [%here] t [%sexp_of: t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~name:ignore\n ~here:ignore\n ~id:ignore\n ~parent:ignore\n ~next_error:(check (fun next_error -> assert (Ivar.is_empty next_error)))\n ~handlers_for_all_errors:ignore\n ~tails_for_all_errors:ignore\n ~has_seen_error:ignore\n ~is_detached:ignore)\n;;\n\nlet current_execution_context () = Scheduler.(current_execution_context (t ()))\nlet current () = Execution_context.monitor (current_execution_context ())\n\nlet depth t =\n let rec loop t n =\n match t.parent with\n | None -> n\n | Some t -> loop t (n + 1)\n in\n loop t 0\n;;\n\ntype 'a with_optional_monitor_name =\n ?here:Source_code_position.t -> ?info:Info.t -> ?name:string -> 'a\n\nlet detach t = t.is_detached <- true\n\ntype handler_state =\n | Uninitialized\n | Running of (Execution_context.t * (exn -> unit)) Bag.Elt.t\n | Terminated\n\nlet detach_and_iter_errors t ~f =\n detach t;\n let scheduler = Scheduler.t () in\n let execution_context = Scheduler.current_execution_context scheduler in\n let handler_state_ref = ref Uninitialized in\n let run_f exn =\n match !handler_state_ref with\n | Uninitialized -> assert false\n | Terminated -> ()\n | Running bag_elt ->\n (try f exn with\n | inner_exn ->\n handler_state_ref := Terminated;\n Bag.remove t.handlers_for_all_errors bag_elt;\n (* [run_f] always runs in [execution_context]. Hence, [raise inner_exn] sends\n [inner_exn] to [execution_context]'s monitor, i.e. the monitor in effect when\n [detach_and_iter_errors] was called. *)\n raise inner_exn)\n in\n handler_state_ref\n := Running (Bag.add t.handlers_for_all_errors (execution_context, run_f))\n;;\n\nlet detach_and_get_error_stream t =\n detach t;\n let tail = Tail.create () in\n t.tails_for_all_errors <- tail :: t.tails_for_all_errors;\n Tail.collect tail\n;;\n\nlet get_next_error t = Ivar.read t.next_error\n\nlet detach_and_get_next_error t =\n detach t;\n get_next_error t\n;;\n\nlet create ?here ?info ?name () =\n let parent = current () in\n create_with_parent ?here ?info ?name (Some parent)\n;;\n\nmodule Exn_for_monitor = struct\n type t =\n { exn : exn\n ; backtrace : Backtrace.t option\n ; backtrace_history : Backtrace.t list\n ; monitor : Monitor.t\n }\n\n let backtrace_truncation_heuristics =\n let job_queue = \"Called from file \\\"job_queue.ml\\\"\" in\n let deferred0 = \"Called from file \\\"deferred0.ml\\\"\" in\n let deferred1 = \"Called from file \\\"deferred1.ml\\\"\" in\n let monitor = \"Called from file \\\"monitor.ml\\\"\" in\n let import0 = \"Raised at file \\\"import0.ml\\\"\" in\n let error = \"Called from file \\\"error.ml\\\"\" in\n fun traces ->\n (* ../test/test_try_with_error_display.ml makes sure this stays up-to-date. *)\n let traces =\n match traces with\n | t1 :: rest when String.is_prefix t1 ~prefix:import0 ->\n (match rest with\n | t2 :: rest when String.is_prefix t2 ~prefix:error ->\n (match rest with\n | t3 :: rest when String.is_prefix t3 ~prefix:error -> rest\n | _ -> rest)\n | _ -> rest)\n | _ -> traces\n in\n match List.rev traces with\n | t1 :: rest when String.is_prefix t1 ~prefix:job_queue ->\n (match rest with\n | t2 :: rest when String.is_prefix t2 ~prefix:job_queue ->\n (match rest with\n | t2 :: rest\n when String.is_prefix t2 ~prefix:deferred0\n (* bind *)\n || String.is_prefix t2 ~prefix:deferred1\n (* map *)\n || String.is_prefix t2 ~prefix:monitor\n (* try_with *) -> List.rev rest\n | _ -> List.rev rest)\n | _ -> List.rev rest)\n | _ -> traces\n ;;\n\n let sexp_of_t { exn; backtrace; backtrace_history; monitor } =\n let monitor =\n let name =\n match Info.to_string_hum monitor.name with\n | \"\" -> None\n | s -> Some s\n in\n let pos =\n match monitor.here with\n | None -> None\n | Some here ->\n (* We display the full filename, whereas backtraces only have basenames, but\n perhaps that's what should change. *)\n let column = here.pos_cnum - here.pos_bol in\n Some\n (sprintf\n \"file %S, line %d, characters %d-%d\"\n here.pos_fname\n here.pos_lnum\n column\n column)\n in\n match pos, name with\n | None, None -> []\n | Some pos, None -> [ sprintf \"Caught by monitor at %s\" pos ]\n | None, Some name -> [ sprintf \"Caught by monitor %s\" name ]\n | Some pos, Some name -> [ sprintf \"Caught by monitor %s at %s\" name pos ]\n in\n let backtrace =\n let backtrace =\n match backtrace with\n | None -> []\n | Some backtrace -> Backtrace.to_string_list backtrace\n in\n backtrace_truncation_heuristics backtrace @ monitor\n in\n let list_if_not_empty = function\n | [] -> None\n | _ :: _ as l -> Some l\n in\n [%sexp\n (exn : exn)\n , (list_if_not_empty backtrace : (string list option[@sexp.option]))\n , `backtrace_history\n (list_if_not_empty backtrace_history : (Backtrace.t list option[@sexp.option]))]\n ;;\nend\n\nexception Error_ of Exn_for_monitor.t\n\nlet () =\n Sexplib.Conv.Exn_converter.add [%extension_constructor Error_] (function\n | Error_ t -> [%sexp \"monitor.ml.Error\" :: (t : Exn_for_monitor.t)]\n | _ ->\n (* Reaching this branch indicates a bug in sexplib. *)\n assert false)\n;;\n\nlet extract_exn exn =\n match exn with\n | Error_ error -> error.exn\n | exn -> exn\n;;\n\nlet send_exn t ?backtrace exn =\n let exn =\n match exn with\n | Error_ _ -> exn\n | _ ->\n let backtrace =\n match backtrace with\n | None -> None\n | Some `Get -> Some (Backtrace.Exn.most_recent ())\n | Some (`This b) -> Some b\n in\n let backtrace_history = (current_execution_context ()).backtrace_history in\n Error_ { Exn_for_monitor.exn; backtrace; backtrace_history; monitor = t }\n in\n if Debug.monitor_send_exn\n then Debug.log \"Monitor.send_exn\" (t, exn) [%sexp_of: t * exn];\n t.has_seen_error <- true;\n let scheduler = Scheduler.t () in\n let rec loop t =\n Ivar.fill t.next_error exn;\n t.next_error <- Ivar.create ();\n if t.is_detached\n then (\n if Debug.monitor_send_exn\n then\n Debug.log \"Monitor.send_exn found listening monitor\" (t, exn) [%sexp_of: t * exn];\n Bag.iter t.handlers_for_all_errors ~f:(fun (execution_context, f) ->\n Scheduler.enqueue scheduler execution_context f exn);\n List.iter t.tails_for_all_errors ~f:(fun tail -> Tail.extend tail exn))\n else (\n match t.parent with\n | Some t' -> loop t'\n | None ->\n (* Do not change this branch to print the exception or to exit. Having the\n scheduler raise an uncaught exception is the necessary behavior for programs\n that call [Scheduler.go] and want to handle it. *)\n Scheduler.(got_uncaught_exn (t ())) exn (!Async_kernel_config.task_id ()))\n in\n loop t\n;;\n\nmodule Exported_for_scheduler = struct\n let within_context context f =\n Scheduler.(with_execution_context (t ())) context ~f:(fun () ->\n match Result.try_with f with\n | Ok x -> Ok x\n | Error exn ->\n send_exn (Execution_context.monitor context) exn ~backtrace:`Get;\n Error ())\n ;;\n\n type 'a with_options = ?monitor:t -> ?priority:Priority.t -> 'a\n\n let within_gen ?monitor ?priority f =\n let tmp_context =\n Execution_context.create_like (current_execution_context ()) ?monitor ?priority\n in\n within_context tmp_context f\n ;;\n\n let within' ?monitor ?priority f =\n match within_gen ?monitor ?priority f with\n | Error () -> Deferred.never ()\n | Ok d -> d\n ;;\n\n let within_v ?monitor ?priority f =\n match within_gen ?monitor ?priority f with\n | Error () -> None\n | Ok x -> Some x\n ;;\n\n let within ?monitor ?priority f =\n match within_gen ?monitor ?priority f with\n | Error () -> ()\n | Ok () -> ()\n ;;\n\n let schedule_with_data ?monitor ?priority work x =\n let scheduler = Scheduler.t () in\n Scheduler.enqueue\n scheduler\n (Execution_context.create_like\n (Scheduler.current_execution_context scheduler)\n ?monitor\n ?priority)\n work\n x\n ;;\n\n let schedule ?monitor ?priority work = schedule_with_data ?monitor ?priority work ()\n\n let schedule' =\n (* For performance, we use [schedule_with_data] with a closed function, and inline\n [Deferred.create]. *)\n let upon_work_fill_i (work, i) = upon (work ()) (fun a -> Ivar.fill i a) in\n fun ?monitor ?priority work ->\n let i = Ivar.create () in\n schedule_with_data ?monitor ?priority upon_work_fill_i (work, i);\n Ivar.read i\n ;;\n\n let preserve_execution_context f =\n let scheduler = Scheduler.t () in\n let execution_context = Scheduler.current_execution_context scheduler in\n stage (fun a -> Scheduler.enqueue scheduler execution_context f a)\n ;;\n\n let preserve_execution_context' f =\n let scheduler = Scheduler.t () in\n let execution_context = Scheduler.current_execution_context scheduler in\n let call_and_fill (f, a, i) = upon (f a) (fun r -> Ivar.fill i r) in\n stage (fun a ->\n Deferred.create (fun i ->\n Scheduler.enqueue scheduler execution_context call_and_fill (f, a, i)))\n ;;\nend\n\nopen Exported_for_scheduler\n\nlet stream_iter stream ~f =\n let rec loop stream =\n Stream.next stream\n >>> function\n | Nil -> ()\n | Cons (v, stream) ->\n loop stream;\n f v\n in\n loop stream\n;;\n\n(* An ['a Ok_and_exns.t] represents the output of a computation running in a detached\n monitor. *)\nmodule Ok_and_exns = struct\n type 'a t =\n { ok : 'a Deferred.t\n ; exns : exn Stream.t\n }\n [@@deriving fields, sexp_of]\n\n let create ?here ?info ?name ~run f =\n (* We call [create_with_parent None] because [monitor] does not need a parent. It\n does not because we call [detach_and_get_error_stream monitor] and deal with the\n errors explicitly, thus [send_exn] would never propagate an exn past [monitor]. *)\n let monitor = create_with_parent ?here ?info ?name None in\n let exns = detach_and_get_error_stream monitor in\n let ok =\n match run with\n | `Now -> within' ~monitor f\n | `Schedule -> schedule' ~monitor f\n in\n { ok; exns }\n ;;\nend\n\nlet fill_result_and_handle_background_errors\n result_filler\n result\n exns\n handle_exns_after_result\n =\n if Ivar_filler.is_empty result_filler\n then (\n Ivar_filler.fill result_filler result;\n handle_exns_after_result exns)\n;;\n\nmodule Expert = struct\n let try_with_log_exn : (exn -> unit) ref =\n ref (fun exn ->\n raise_s\n [%message \"failed to set [Monitor.Expert.try_with_log_exn]\" (exn : Exn.t)])\n ;;\nend\n\nlet make_handle_exn rest =\n match rest with\n | `Log ->\n (* We are careful to not close over current context, which is not needed. *)\n !Expert.try_with_log_exn\n | `Raise ->\n let parent = current () in\n fun exn -> send_exn parent exn ?backtrace:None\n | `Call f ->\n let parent = current () in\n fun exn -> within ~monitor:parent (fun () -> f exn)\n;;\n\nlet try_with\n ?here\n ?info\n ?(name = \"\")\n ?extract_exn:(do_extract_exn = false)\n ?(run = `Schedule)\n ?(rest = `Log)\n f\n =\n let { Ok_and_exns.ok; exns } = Ok_and_exns.create ?here ?info ~name ~run f in\n let handle_exn = make_handle_exn rest in\n let handle_exns_after_result exns = stream_iter exns ~f:handle_exn in\n (* We run [within' ~monitor:main] to avoid holding on to references to the evaluation\n context in which [try_with] was called. This avoids a space leak when a chain of\n [try_with]'s are run each nested within the previous one. Without the [within'], the\n error handling for the innermost [try_with] would keep alive the entire chain. *)\n within' ~monitor:main (fun () ->\n if Deferred.is_determined ok\n then (\n handle_exns_after_result exns;\n return (Ok (Deferred.value_exn ok)))\n else (\n let result_filler, result = Ivar_filler.create () in\n upon ok (fun res ->\n fill_result_and_handle_background_errors\n result_filler\n (Ok res)\n exns\n handle_exns_after_result);\n upon (Stream.next exns) (function\n | Nil -> assert false\n | Cons (exn, exns) ->\n let exn = if do_extract_exn then extract_exn exn else exn in\n fill_result_and_handle_background_errors\n result_filler\n (Error exn)\n exns\n handle_exns_after_result);\n result))\n;;\n\nlet try_with_or_error ?here ?info ?(name = \"try_with_or_error\") ?extract_exn f =\n try_with f ?here ?info ~name ?extract_exn ~run:`Now ~rest:`Log\n >>| Or_error.of_exn_result\n;;\n\nlet try_with_join_or_error ?here ?info ?(name = \"try_with_join_or_error\") ?extract_exn f =\n try_with_or_error f ?here ?info ~name ?extract_exn >>| Or_error.join\n;;\n\nlet protect ?here ?info ?(name = \"Monitor.protect\") ?extract_exn ?run f ~finally =\n let%bind r = try_with ?extract_exn ?here ?info ?run ~name f in\n let%map fr = try_with ~extract_exn:false ?here ?info ~name:\"finally\" finally in\n match r, fr with\n | Error exn, Error finally_exn ->\n raise_s [%message \"Async finally\" (exn : exn) (finally_exn : exn)]\n | Error e, Ok () | Ok _, Error e -> raise e\n | Ok r, Ok () -> r\n;;\n\nlet handle_errors ?here ?info ?name f handler =\n let { Ok_and_exns.ok; exns } = Ok_and_exns.create ?here ?info ?name ~run:`Now f in\n stream_iter exns ~f:handler;\n ok\n;;\n\nlet catch_stream ?here ?info ?name f =\n let { Ok_and_exns.exns; _ } =\n Ok_and_exns.create ?here ?info ?name ~run:`Now (fun () ->\n f ();\n return ())\n in\n exns\n;;\n\nlet catch ?here ?info ?name f =\n match%map Stream.next (catch_stream ?here ?info ?name f) with\n | Cons (x, _) -> x\n | Nil -> raise_s [%message \"Monitor.catch got unexpected empty stream\"]\n;;\n\nlet catch_error ?here ?info ?name f = catch ?here ?info ?name f >>| Error.of_exn\n","(** Contains Async's core data structures, like {{!Async_kernel.Deferred}[Deferred]},\n {{!Async_kernel.Ivar}[Ivar]}, and {{!Async_kernel.Clock_intf.Clock}[Clock]}.\n\n [Async_kernel] is designed to depend only on {{!Core_kernel}[Core_kernel]} (as opposed\n to {{!Core}[Core]}), and so is more platform-independent. *)\n\nopen! Core_kernel\nopen! Import\nmodule Async_kernel_config = Async_kernel_config\nmodule Async_kernel_require_explicit_time_source = Require_explicit_time_source\nmodule Async_kernel_scheduler = Async_kernel_scheduler\nmodule Bvar = Bvar\nmodule Clock_ns = Clock_ns\nmodule Condition = Async_condition\nmodule Deferred = Deferred\nmodule Execution_context = Execution_context\nmodule Gc = Async_gc\nmodule Invariant = Async_invariant\nmodule Ivar = Ivar\nmodule Lazy_deferred = Lazy_deferred\nmodule Monad_sequence = Monad_sequence\nmodule Monitor = Monitor\nmodule Mvar = Mvar\nmodule Pipe = Pipe\nmodule Priority = Priority\nmodule Sequencer = Throttle.Sequencer\nmodule Stream = Async_stream\nmodule Synchronous_time_source = Synchronous_time_source\nmodule Tail = Tail\nmodule Throttle = Throttle\nmodule Time_source = Time_source\nmodule Tracing = Tracing\n\n(** {2 Toplevel functions }\n\n The functions below are broadly useful when writing Async programs, and so are made\n available at the toplevel. *)\n\nlet after = Clock_ns.after\nlet at = Clock_ns.at\nlet catch = Monitor.catch\nlet choice = Deferred.choice\nlet choose = Deferred.choose\nlet don't_wait_for = Deferred.don't_wait_for\nlet every = Clock_ns.every\nlet never = Deferred.never\nlet schedule = Scheduler.schedule\nlet schedule' = Scheduler.schedule'\nlet try_with = Monitor.try_with\nlet upon = Deferred.upon\nlet with_timeout = Clock_ns.with_timeout\nlet within = Scheduler.within\nlet within' = Scheduler.within'\n\n(** {2 Infix operators and [Let_syntax] support} *)\n\ninclude (Deferred : Monad.Infix with type 'a t := 'a Deferred.t)\n\n(** equivalent to {!Deferred.upon}. *)\nlet ( >>> ) = Deferred.Infix.( >>> )\n\n(** equivalent to {!Deferred.Result.bind}. *)\nlet ( >>=? ) = Deferred.Result.( >>= )\n\n(** equivalent to {!Deferred.Result.map}. *)\nlet ( >>|? ) = Deferred.Result.( >>| )\n\ninclude Deferred.Let_syntax\n\n(**/**)\n\n(** The modules in [Async_kernel_private] are used for constructing and testing Async, and\n should not otherwise be used. *)\nmodule Async_kernel_private = struct\n module Debug = Debug\n module Ivar0 = Ivar0\n module Ivar_filler = Ivar_filler\n module Job = Job\n module Stack_or_counter = Stack_or_counter\nend\n\n(**/**)\n\n(* This test must be in this library, because it requires [return] to be inlined. Moving\n it to another library will cause it to break with [X_LIBRARY_INLINING=false]. *)\nlet%test_unit \"[return ()] does not allocate\" =\n let w1 = Gc.minor_words () in\n ignore (Sys.opaque_identity (return ()) : _ Deferred.t);\n ignore (Sys.opaque_identity (Deferred.return ()) : _ Deferred.t);\n ignore (Sys.opaque_identity (Deferred.Let_syntax.return ()) : _ Deferred.t);\n ignore (Sys.opaque_identity (Deferred.Let_syntax.Let_syntax.return ()) : _ Deferred.t);\n let w2 = Gc.minor_words () in\n [%test_result: int] w2 ~expect:w1\n;;\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nlet failwith fmt = Format.kasprintf failwith fmt\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let lnot = Int32.lognot\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\n\n let ror32 a n = (a lsr n) lor (a lsl (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\n\n let ( lsr ) = Int64.shift_right_logical\n\n let ( lor ) = Int64.logor\n\n let ( asr ) = Int64.shift_right\n\n let ( lxor ) = Int64.logxor\n\n let ( + ) = Int64.add\n\n let rol64 a n = (a lsl n) lor (a lsr (64 - n))\n\n let ror64 a n = (a lsr n) lor (a lsl (64 - n))\nend\n\nmodule type S = sig\n type ctx\n\n type kind = [ `BLAKE2B ]\n\n val init : unit -> ctx\n\n val with_outlen_and_bytes_key : int -> By.t -> int -> int -> ctx\n\n val with_outlen_and_bigstring_key : int -> Bi.t -> int -> int -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\n\n val max_outlen : int\nend\n\nmodule Unsafe : S = struct\n type kind = [ `BLAKE2B ]\n\n type param = {\n digest_length : int;\n key_length : int;\n fanout : int;\n depth : int;\n leaf_length : int32;\n node_offset : int32;\n xof_length : int32;\n node_depth : int;\n inner_length : int;\n reserved : int array;\n salt : int array;\n personal : int array;\n }\n\n type ctx = {\n mutable buflen : int;\n outlen : int;\n mutable last_node : int;\n buf : Bytes.t;\n h : int64 array;\n t : int64 array;\n f : int64 array;\n }\n\n let dup ctx =\n {\n buflen = ctx.buflen;\n outlen = ctx.outlen;\n last_node = ctx.last_node;\n buf = By.copy ctx.buf;\n h = Array.copy ctx.h;\n t = Array.copy ctx.t;\n f = Array.copy ctx.f;\n }\n\n let param_to_bytes param =\n let arr =\n [|\n param.digest_length land 0xFF;\n param.key_length land 0xFF;\n param.fanout land 0xFF;\n param.depth land 0xFF (* store to little-endian *);\n Int32.(to_int ((param.leaf_length lsr 0) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 8) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 16) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 24) land 0xFFl))\n (* store to little-endian *);\n Int32.(to_int ((param.node_offset lsr 0) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 8) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 16) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 24) land 0xFFl))\n (* store to little-endian *);\n Int32.(to_int ((param.xof_length lsr 0) land 0xFFl));\n Int32.(to_int ((param.xof_length lsr 8) land 0xFFl));\n Int32.(to_int ((param.xof_length lsr 16) land 0xFFl));\n Int32.(to_int ((param.xof_length lsr 24) land 0xFFl));\n param.node_depth land 0xFF;\n param.inner_length land 0xFF;\n param.reserved.(0) land 0xFF;\n param.reserved.(1) land 0xFF;\n param.reserved.(2) land 0xFF;\n param.reserved.(3) land 0xFF;\n param.reserved.(4) land 0xFF;\n param.reserved.(5) land 0xFF;\n param.reserved.(6) land 0xFF;\n param.reserved.(7) land 0xFF;\n param.reserved.(8) land 0xFF;\n param.reserved.(9) land 0xFF;\n param.reserved.(10) land 0xFF;\n param.reserved.(11) land 0xFF;\n param.reserved.(12) land 0xFF;\n param.reserved.(13) land 0xFF;\n param.salt.(0) land 0xFF;\n param.salt.(1) land 0xFF;\n param.salt.(2) land 0xFF;\n param.salt.(3) land 0xFF;\n param.salt.(4) land 0xFF;\n param.salt.(5) land 0xFF;\n param.salt.(6) land 0xFF;\n param.salt.(7) land 0xFF;\n param.salt.(8) land 0xFF;\n param.salt.(9) land 0xFF;\n param.salt.(10) land 0xFF;\n param.salt.(11) land 0xFF;\n param.salt.(12) land 0xFF;\n param.salt.(13) land 0xFF;\n param.salt.(14) land 0xFF;\n param.salt.(15) land 0xFF;\n param.personal.(0) land 0xFF;\n param.personal.(1) land 0xFF;\n param.personal.(2) land 0xFF;\n param.personal.(3) land 0xFF;\n param.personal.(4) land 0xFF;\n param.personal.(5) land 0xFF;\n param.personal.(6) land 0xFF;\n param.personal.(7) land 0xFF;\n param.personal.(8) land 0xFF;\n param.personal.(9) land 0xFF;\n param.personal.(10) land 0xFF;\n param.personal.(11) land 0xFF;\n param.personal.(12) land 0xFF;\n param.personal.(13) land 0xFF;\n param.personal.(14) land 0xFF;\n param.personal.(15) land 0xFF;\n |] in\n By.init 64 (fun i -> Char.unsafe_chr arr.(i))\n\n let max_outlen = 64\n\n let default_param =\n {\n digest_length = max_outlen;\n key_length = 0;\n fanout = 1;\n depth = 1;\n leaf_length = 0l;\n node_offset = 0l;\n xof_length = 0l;\n node_depth = 0;\n inner_length = 0;\n reserved = [| 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0 |];\n salt = [| 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0 |];\n personal = [| 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0 |];\n }\n\n let iv =\n [|\n 0x6a09e667f3bcc908L;\n 0xbb67ae8584caa73bL;\n 0x3c6ef372fe94f82bL;\n 0xa54ff53a5f1d36f1L;\n 0x510e527fade682d1L;\n 0x9b05688c2b3e6c1fL;\n 0x1f83d9abfb41bd6bL;\n 0x5be0cd19137e2179L;\n |]\n\n let increment_counter ctx inc =\n let open Int64 in\n ctx.t.(0) <- ctx.t.(0) + inc ;\n ctx.t.(1) <- (ctx.t.(1) + if ctx.t.(0) < inc then 1L else 0L)\n\n let set_lastnode ctx = ctx.f.(1) <- Int64.minus_one\n\n let set_lastblock ctx =\n if ctx.last_node <> 0 then set_lastnode ctx ;\n ctx.f.(0) <- Int64.minus_one\n\n let init () =\n let buf = By.make 128 '\\x00' in\n By.fill buf 0 128 '\\x00' ;\n let ctx =\n {\n buflen = 0;\n outlen = default_param.digest_length;\n last_node = 0;\n buf;\n h = Array.make 8 0L;\n t = Array.make 2 0L;\n f = Array.make 2 0L;\n } in\n let param_bytes = param_to_bytes default_param in\n for i = 0 to 7 do\n ctx.h.(i) <- Int64.(iv.(i) lxor By.le64_to_cpu param_bytes (i * 8))\n done ;\n ctx\n\n let sigma =\n [|\n [| 0; 1; 2; 3; 4; 5; 6; 7; 8; 9; 10; 11; 12; 13; 14; 15 |];\n [| 14; 10; 4; 8; 9; 15; 13; 6; 1; 12; 0; 2; 11; 7; 5; 3 |];\n [| 11; 8; 12; 0; 5; 2; 15; 13; 10; 14; 3; 6; 7; 1; 9; 4 |];\n [| 7; 9; 3; 1; 13; 12; 11; 14; 2; 6; 5; 10; 4; 0; 15; 8 |];\n [| 9; 0; 5; 7; 2; 4; 10; 15; 14; 1; 11; 12; 6; 8; 3; 13 |];\n [| 2; 12; 6; 10; 0; 11; 8; 3; 4; 13; 7; 5; 15; 14; 1; 9 |];\n [| 12; 5; 1; 15; 14; 13; 4; 10; 0; 7; 6; 3; 9; 2; 8; 11 |];\n [| 13; 11; 7; 14; 12; 1; 3; 9; 5; 0; 15; 4; 8; 6; 2; 10 |];\n [| 6; 15; 14; 9; 11; 3; 0; 8; 12; 2; 13; 7; 1; 4; 10; 5 |];\n [| 10; 2; 8; 4; 7; 6; 1; 5; 15; 11; 9; 14; 3; 12; 13; 0 |];\n [| 0; 1; 2; 3; 4; 5; 6; 7; 8; 9; 10; 11; 12; 13; 14; 15 |];\n [| 14; 10; 4; 8; 9; 15; 13; 6; 1; 12; 0; 2; 11; 7; 5; 3 |];\n |]\n\n let compress :\n type a. le64_to_cpu:(a -> int -> int64) -> ctx -> a -> int -> unit =\n fun ~le64_to_cpu ctx block off ->\n let v = Array.make 16 0L in\n let m = Array.make 16 0L in\n let g r i a_idx b_idx c_idx d_idx =\n let ( ++ ) = ( + ) in\n let open Int64 in\n v.(a_idx) <- v.(a_idx) + v.(b_idx) + m.(sigma.(r).((2 * i) ++ 0)) ;\n v.(d_idx) <- ror64 (v.(d_idx) lxor v.(a_idx)) 32 ;\n v.(c_idx) <- v.(c_idx) + v.(d_idx) ;\n v.(b_idx) <- ror64 (v.(b_idx) lxor v.(c_idx)) 24 ;\n v.(a_idx) <- v.(a_idx) + v.(b_idx) + m.(sigma.(r).((2 * i) ++ 1)) ;\n v.(d_idx) <- ror64 (v.(d_idx) lxor v.(a_idx)) 16 ;\n v.(c_idx) <- v.(c_idx) + v.(d_idx) ;\n v.(b_idx) <- ror64 (v.(b_idx) lxor v.(c_idx)) 63 in\n let r r =\n g r 0 0 4 8 12 ;\n g r 1 1 5 9 13 ;\n g r 2 2 6 10 14 ;\n g r 3 3 7 11 15 ;\n g r 4 0 5 10 15 ;\n g r 5 1 6 11 12 ;\n g r 6 2 7 8 13 ;\n g r 7 3 4 9 14 in\n for i = 0 to 15 do\n m.(i) <- le64_to_cpu block (off + (i * 8))\n done ;\n for i = 0 to 7 do\n v.(i) <- ctx.h.(i)\n done ;\n v.(8) <- iv.(0) ;\n v.(9) <- iv.(1) ;\n v.(10) <- iv.(2) ;\n v.(11) <- iv.(3) ;\n v.(12) <- Int64.(iv.(4) lxor ctx.t.(0)) ;\n v.(13) <- Int64.(iv.(5) lxor ctx.t.(1)) ;\n v.(14) <- Int64.(iv.(6) lxor ctx.f.(0)) ;\n v.(15) <- Int64.(iv.(7) lxor ctx.f.(1)) ;\n r 0 ;\n r 1 ;\n r 2 ;\n r 3 ;\n r 4 ;\n r 5 ;\n r 6 ;\n r 7 ;\n r 8 ;\n r 9 ;\n r 10 ;\n r 11 ;\n let ( ++ ) = ( + ) in\n for i = 0 to 7 do\n ctx.h.(i) <- Int64.(ctx.h.(i) lxor v.(i) lxor v.(i ++ 8))\n done ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n le64_to_cpu:(a -> int -> int64) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~le64_to_cpu ctx buf off len ->\n let in_off = ref off in\n let in_len = ref len in\n if !in_len > 0\n then (\n let left = ctx.buflen in\n let fill = 128 - left in\n if !in_len > fill\n then (\n ctx.buflen <- 0 ;\n blit buf !in_off ctx.buf left fill ;\n increment_counter ctx 128L ;\n compress ~le64_to_cpu:By.le64_to_cpu ctx ctx.buf 0 ;\n in_off := !in_off + fill ;\n in_len := !in_len - fill ;\n while !in_len > 128 do\n increment_counter ctx 128L ;\n compress ~le64_to_cpu ctx buf !in_off ;\n in_off := !in_off + 128 ;\n in_len := !in_len - 128\n done) ;\n blit buf !in_off ctx.buf ctx.buflen !in_len ;\n ctx.buflen <- ctx.buflen + !in_len) ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~le64_to_cpu:By.le64_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~le64_to_cpu:Bi.le64_to_cpu\n\n let with_outlen_and_key ~blit outlen key off len =\n if outlen > max_outlen\n then\n failwith \"out length can not be upper than %d (out length: %d)\" max_outlen\n outlen ;\n let buf = By.make 128 '\\x00' in\n let ctx =\n {\n buflen = 0;\n outlen;\n last_node = 0;\n buf;\n h = Array.make 8 0L;\n t = Array.make 2 0L;\n f = Array.make 2 0L;\n } in\n let param_bytes =\n param_to_bytes\n { default_param with digest_length = outlen; key_length = len } in\n for i = 0 to 7 do\n ctx.h.(i) <- Int64.(iv.(i) lxor By.le64_to_cpu param_bytes (i * 8))\n done ;\n if len > 0\n then (\n let block = By.make 128 '\\x00' in\n blit key off block 0 len ;\n unsafe_feed_bytes ctx block 0 128) ;\n ctx\n\n let with_outlen_and_bytes_key outlen key off len =\n with_outlen_and_key ~blit:By.blit outlen key off len\n\n let with_outlen_and_bigstring_key outlen key off len =\n with_outlen_and_key ~blit:By.blit_from_bigstring outlen key off len\n\n let unsafe_get ctx =\n let res = By.make default_param.digest_length '\\x00' in\n increment_counter ctx (Int64.of_int ctx.buflen) ;\n set_lastblock ctx ;\n By.fill ctx.buf ctx.buflen (128 - ctx.buflen) '\\x00' ;\n compress ~le64_to_cpu:By.le64_to_cpu ctx ctx.buf 0 ;\n for i = 0 to 7 do\n By.cpu_to_le64 res (i * 8) ctx.h.(i)\n done ;\n if ctx.outlen < default_param.digest_length\n then By.sub res 0 ctx.outlen\n else if ctx.outlen > default_param.digest_length\n then\n assert false\n (* XXX(dinosaure): [ctx] can not be initialized with [outlen > digest_length = max_outlen]. *)\n else res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nlet failwith fmt = Format.kasprintf failwith fmt\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let lnot = Int32.lognot\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\n\n let ror32 a n = (a lsr n) lor (a lsl (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\n\n let ( lsr ) = Int64.shift_right_logical\n\n let ( lor ) = Int64.logor\n\n let ( asr ) = Int64.shift_right\n\n let ( lxor ) = Int64.logxor\n\n let ( + ) = Int64.add\n\n let rol64 a n = (a lsl n) lor (a lsr (64 - n))\n\n let ror64 a n = (a lsr n) lor (a lsl (64 - n))\nend\n\nmodule type S = sig\n type ctx\n\n type kind = [ `BLAKE2S ]\n\n val init : unit -> ctx\n\n val with_outlen_and_bytes_key : int -> By.t -> int -> int -> ctx\n\n val with_outlen_and_bigstring_key : int -> Bi.t -> int -> int -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\n\n val max_outlen : int\nend\n\nmodule Unsafe : S = struct\n type kind = [ `BLAKE2S ]\n\n type param = {\n digest_length : int;\n key_length : int;\n fanout : int;\n depth : int;\n leaf_length : int32;\n node_offset : int32;\n xof_length : int;\n node_depth : int;\n inner_length : int;\n salt : int array;\n personal : int array;\n }\n\n type ctx = {\n mutable buflen : int;\n outlen : int;\n mutable last_node : int;\n buf : Bytes.t;\n h : int32 array;\n t : int32 array;\n f : int32 array;\n }\n\n let dup ctx =\n {\n buflen = ctx.buflen;\n outlen = ctx.outlen;\n last_node = ctx.last_node;\n buf = By.copy ctx.buf;\n h = Array.copy ctx.h;\n t = Array.copy ctx.t;\n f = Array.copy ctx.f;\n }\n\n let param_to_bytes param =\n let arr =\n [|\n param.digest_length land 0xFF;\n param.key_length land 0xFF;\n param.fanout land 0xFF;\n param.depth land 0xFF (* store to little-endian *);\n Int32.(to_int ((param.leaf_length lsr 0) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 8) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 16) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 24) land 0xFFl))\n (* store to little-endian *);\n Int32.(to_int ((param.node_offset lsr 0) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 8) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 16) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 24) land 0xFFl))\n (* store to little-endian *);\n (param.xof_length lsr 0) land 0xFF;\n (param.xof_length lsr 8) land 0xFF;\n param.node_depth land 0xFF;\n param.inner_length land 0xFF;\n param.salt.(0) land 0xFF;\n param.salt.(1) land 0xFF;\n param.salt.(2) land 0xFF;\n param.salt.(3) land 0xFF;\n param.salt.(4) land 0xFF;\n param.salt.(5) land 0xFF;\n param.salt.(6) land 0xFF;\n param.salt.(7) land 0xFF;\n param.personal.(0) land 0xFF;\n param.personal.(1) land 0xFF;\n param.personal.(2) land 0xFF;\n param.personal.(3) land 0xFF;\n param.personal.(4) land 0xFF;\n param.personal.(5) land 0xFF;\n param.personal.(6) land 0xFF;\n param.personal.(7) land 0xFF;\n |] in\n By.init 32 (fun i -> Char.unsafe_chr arr.(i))\n\n let max_outlen = 32\n\n let default_param =\n {\n digest_length = max_outlen;\n key_length = 0;\n fanout = 1;\n depth = 1;\n leaf_length = 0l;\n node_offset = 0l;\n xof_length = 0;\n node_depth = 0;\n inner_length = 0;\n salt = [| 0; 0; 0; 0; 0; 0; 0; 0 |];\n personal = [| 0; 0; 0; 0; 0; 0; 0; 0 |];\n }\n\n let iv =\n [|\n 0x6A09E667l;\n 0xBB67AE85l;\n 0x3C6EF372l;\n 0xA54FF53Al;\n 0x510E527Fl;\n 0x9B05688Cl;\n 0x1F83D9ABl;\n 0x5BE0CD19l;\n |]\n\n let increment_counter ctx inc =\n let open Int32 in\n ctx.t.(0) <- ctx.t.(0) + inc ;\n ctx.t.(1) <- (ctx.t.(1) + if ctx.t.(0) < inc then 1l else 0l)\n\n let set_lastnode ctx = ctx.f.(1) <- Int32.minus_one\n\n let set_lastblock ctx =\n if ctx.last_node <> 0 then set_lastnode ctx ;\n ctx.f.(0) <- Int32.minus_one\n\n let init () =\n let buf = By.make 64 '\\x00' in\n let ctx =\n {\n buflen = 0;\n outlen = default_param.digest_length;\n last_node = 0;\n buf;\n h = Array.make 8 0l;\n t = Array.make 2 0l;\n f = Array.make 2 0l;\n } in\n let param_bytes = param_to_bytes default_param in\n for i = 0 to 7 do\n ctx.h.(i) <- Int32.(iv.(i) lxor By.le32_to_cpu param_bytes (i * 4))\n done ;\n ctx\n\n let sigma =\n [|\n [| 0; 1; 2; 3; 4; 5; 6; 7; 8; 9; 10; 11; 12; 13; 14; 15 |];\n [| 14; 10; 4; 8; 9; 15; 13; 6; 1; 12; 0; 2; 11; 7; 5; 3 |];\n [| 11; 8; 12; 0; 5; 2; 15; 13; 10; 14; 3; 6; 7; 1; 9; 4 |];\n [| 7; 9; 3; 1; 13; 12; 11; 14; 2; 6; 5; 10; 4; 0; 15; 8 |];\n [| 9; 0; 5; 7; 2; 4; 10; 15; 14; 1; 11; 12; 6; 8; 3; 13 |];\n [| 2; 12; 6; 10; 0; 11; 8; 3; 4; 13; 7; 5; 15; 14; 1; 9 |];\n [| 12; 5; 1; 15; 14; 13; 4; 10; 0; 7; 6; 3; 9; 2; 8; 11 |];\n [| 13; 11; 7; 14; 12; 1; 3; 9; 5; 0; 15; 4; 8; 6; 2; 10 |];\n [| 6; 15; 14; 9; 11; 3; 0; 8; 12; 2; 13; 7; 1; 4; 10; 5 |];\n [| 10; 2; 8; 4; 7; 6; 1; 5; 15; 11; 9; 14; 3; 12; 13; 0 |];\n |]\n\n let compress :\n type a. le32_to_cpu:(a -> int -> int32) -> ctx -> a -> int -> unit =\n fun ~le32_to_cpu ctx block off ->\n let v = Array.make 16 0l in\n let m = Array.make 16 0l in\n let g r i a_idx b_idx c_idx d_idx =\n let ( ++ ) = ( + ) in\n let open Int32 in\n v.(a_idx) <- v.(a_idx) + v.(b_idx) + m.(sigma.(r).((2 * i) ++ 0)) ;\n v.(d_idx) <- ror32 (v.(d_idx) lxor v.(a_idx)) 16 ;\n v.(c_idx) <- v.(c_idx) + v.(d_idx) ;\n v.(b_idx) <- ror32 (v.(b_idx) lxor v.(c_idx)) 12 ;\n v.(a_idx) <- v.(a_idx) + v.(b_idx) + m.(sigma.(r).((2 * i) ++ 1)) ;\n v.(d_idx) <- ror32 (v.(d_idx) lxor v.(a_idx)) 8 ;\n v.(c_idx) <- v.(c_idx) + v.(d_idx) ;\n v.(b_idx) <- ror32 (v.(b_idx) lxor v.(c_idx)) 7 in\n let r r =\n g r 0 0 4 8 12 ;\n g r 1 1 5 9 13 ;\n g r 2 2 6 10 14 ;\n g r 3 3 7 11 15 ;\n g r 4 0 5 10 15 ;\n g r 5 1 6 11 12 ;\n g r 6 2 7 8 13 ;\n g r 7 3 4 9 14 in\n for i = 0 to 15 do\n m.(i) <- le32_to_cpu block (off + (i * 4))\n done ;\n for i = 0 to 7 do\n v.(i) <- ctx.h.(i)\n done ;\n v.(8) <- iv.(0) ;\n v.(9) <- iv.(1) ;\n v.(10) <- iv.(2) ;\n v.(11) <- iv.(3) ;\n v.(12) <- Int32.(iv.(4) lxor ctx.t.(0)) ;\n v.(13) <- Int32.(iv.(5) lxor ctx.t.(1)) ;\n v.(14) <- Int32.(iv.(6) lxor ctx.f.(0)) ;\n v.(15) <- Int32.(iv.(7) lxor ctx.f.(1)) ;\n r 0 ;\n r 1 ;\n r 2 ;\n r 3 ;\n r 4 ;\n r 5 ;\n r 6 ;\n r 7 ;\n r 8 ;\n r 9 ;\n let ( ++ ) = ( + ) in\n for i = 0 to 7 do\n ctx.h.(i) <- Int32.(ctx.h.(i) lxor v.(i) lxor v.(i ++ 8))\n done ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n le32_to_cpu:(a -> int -> int32) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~le32_to_cpu ctx buf off len ->\n let in_off = ref off in\n let in_len = ref len in\n if !in_len > 0\n then (\n let left = ctx.buflen in\n let fill = 64 - left in\n if !in_len > fill\n then (\n ctx.buflen <- 0 ;\n blit buf !in_off ctx.buf left fill ;\n increment_counter ctx 64l ;\n compress ~le32_to_cpu:By.le32_to_cpu ctx ctx.buf 0 ;\n in_off := !in_off + fill ;\n in_len := !in_len - fill ;\n while !in_len > 64 do\n increment_counter ctx 64l ;\n compress ~le32_to_cpu ctx buf !in_off ;\n in_off := !in_off + 64 ;\n in_len := !in_len - 64\n done) ;\n blit buf !in_off ctx.buf ctx.buflen !in_len ;\n ctx.buflen <- ctx.buflen + !in_len) ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~le32_to_cpu:By.le32_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~le32_to_cpu:Bi.le32_to_cpu\n\n let with_outlen_and_key ~blit outlen key off len =\n if outlen > max_outlen\n then\n failwith \"out length can not be upper than %d (out length: %d)\" max_outlen\n outlen ;\n let buf = By.make 64 '\\x00' in\n let ctx =\n {\n buflen = 0;\n outlen;\n last_node = 0;\n buf;\n h = Array.make 8 0l;\n t = Array.make 2 0l;\n f = Array.make 2 0l;\n } in\n let param_bytes =\n param_to_bytes\n { default_param with key_length = len; digest_length = outlen } in\n for i = 0 to 7 do\n ctx.h.(i) <- Int32.(iv.(i) lxor By.le32_to_cpu param_bytes (i * 4))\n done ;\n if len > 0\n then (\n let block = By.make 64 '\\x00' in\n blit key off block 0 len ;\n unsafe_feed_bytes ctx block 0 64) ;\n ctx\n\n let with_outlen_and_bytes_key outlen key off len =\n with_outlen_and_key ~blit:By.blit outlen key off len\n\n let with_outlen_and_bigstring_key outlen key off len =\n with_outlen_and_key ~blit:By.blit_from_bigstring outlen key off len\n\n let unsafe_get ctx =\n let res = By.make default_param.digest_length '\\x00' in\n increment_counter ctx (Int32.of_int ctx.buflen) ;\n set_lastblock ctx ;\n By.fill ctx.buf ctx.buflen (64 - ctx.buflen) '\\x00' ;\n compress ~le32_to_cpu:By.le32_to_cpu ctx ctx.buf 0 ;\n for i = 0 to 7 do\n By.cpu_to_le32 res (i * 4) ctx.h.(i)\n done ;\n if ctx.outlen < default_param.digest_length\n then By.sub res 0 ctx.outlen\n else if ctx.outlen > default_param.digest_length\n then\n assert false\n (* XXX(dinosaure): [ctx] can not be initialized with [outlen > digest_length = max_outlen]. *)\n else res\nend\n","type bigstring =\n ( char,\n Bigarray_compat.int8_unsigned_elt,\n Bigarray_compat.c_layout )\n Bigarray_compat.Array1.t\n\ntype 'a iter = ('a -> unit) -> unit\n\ntype 'a compare = 'a -> 'a -> int\n\ntype 'a equal = 'a -> 'a -> bool\n\ntype 'a pp = Format.formatter -> 'a -> unit\n\nmodule By = Digestif_by\nmodule Bi = Digestif_bi\nmodule Eq = Digestif_eq\nmodule Hash = Digestif_hash\nmodule Conv = Digestif_conv\n\nlet failwith fmt = Format.ksprintf failwith fmt\n\nmodule type S = sig\n val digest_size : int\n\n type ctx\n\n type kind\n\n type t\n\n val kind : kind\n\n val empty : ctx\n\n val init : unit -> ctx\n\n val feed_bytes : ctx -> ?off:int -> ?len:int -> Bytes.t -> ctx\n\n val feed_string : ctx -> ?off:int -> ?len:int -> String.t -> ctx\n\n val feed_bigstring : ctx -> ?off:int -> ?len:int -> bigstring -> ctx\n\n val feedi_bytes : ctx -> Bytes.t iter -> ctx\n\n val feedi_string : ctx -> String.t iter -> ctx\n\n val feedi_bigstring : ctx -> bigstring iter -> ctx\n\n val get : ctx -> t\n\n val digest_bytes : ?off:int -> ?len:int -> Bytes.t -> t\n\n val digest_string : ?off:int -> ?len:int -> String.t -> t\n\n val digest_bigstring : ?off:int -> ?len:int -> bigstring -> t\n\n val digesti_bytes : Bytes.t iter -> t\n\n val digesti_string : String.t iter -> t\n\n val digesti_bigstring : bigstring iter -> t\n\n val digestv_bytes : Bytes.t list -> t\n\n val digestv_string : String.t list -> t\n\n val digestv_bigstring : bigstring list -> t\n\n val hmac_bytes : key:Bytes.t -> ?off:int -> ?len:int -> Bytes.t -> t\n\n val hmac_string : key:String.t -> ?off:int -> ?len:int -> String.t -> t\n\n val hmac_bigstring : key:bigstring -> ?off:int -> ?len:int -> bigstring -> t\n\n val hmaci_bytes : key:Bytes.t -> Bytes.t iter -> t\n\n val hmaci_string : key:String.t -> String.t iter -> t\n\n val hmaci_bigstring : key:bigstring -> bigstring iter -> t\n\n val hmacv_bytes : key:Bytes.t -> Bytes.t list -> t\n\n val hmacv_string : key:String.t -> String.t list -> t\n\n val hmacv_bigstring : key:bigstring -> bigstring list -> t\n\n val unsafe_compare : t compare\n\n val equal : t equal\n\n val pp : t pp\n\n val of_hex : string -> t\n\n val of_hex_opt : string -> t option\n\n val consistent_of_hex : string -> t\n\n val consistent_of_hex_opt : string -> t option\n\n val to_hex : t -> string\n\n val of_raw_string : string -> t\n\n val of_raw_string_opt : string -> t option\n\n val to_raw_string : t -> string\nend\n\nmodule type MAC = sig\n type t\n\n val mac_bytes : key:Bytes.t -> ?off:int -> ?len:int -> Bytes.t -> t\n\n val mac_string : key:String.t -> ?off:int -> ?len:int -> String.t -> t\n\n val mac_bigstring : key:bigstring -> ?off:int -> ?len:int -> bigstring -> t\n\n val maci_bytes : key:Bytes.t -> Bytes.t iter -> t\n\n val maci_string : key:String.t -> String.t iter -> t\n\n val maci_bigstring : key:bigstring -> bigstring iter -> t\n\n val macv_bytes : key:Bytes.t -> Bytes.t list -> t\n\n val macv_string : key:String.t -> String.t list -> t\n\n val macv_bigstring : key:bigstring -> bigstring list -> t\nend\n\nmodule type Desc = sig\n type kind\n\n val digest_size : int\n\n val block_size : int\n\n val kind : kind\nend\n\nmodule type Hash = sig\n type ctx\n\n type kind\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe (Hash : Hash) (D : Desc) = struct\n open Hash\n\n let digest_size = D.digest_size\n\n let block_size = D.block_size\n\n let empty = init ()\n\n let init = init\n\n let unsafe_feed_bytes ctx ?off ?len buf =\n let off, len =\n match (off, len) with\n | Some off, Some len -> (off, len)\n | Some off, None -> (off, By.length buf - off)\n | None, Some len -> (0, len)\n | None, None -> (0, By.length buf) in\n if off < 0 || len < 0 || off > By.length buf - len\n then invalid_arg \"offset out of bounds\"\n else unsafe_feed_bytes ctx buf off len\n\n let unsafe_feed_string ctx ?off ?len buf =\n unsafe_feed_bytes ctx ?off ?len (By.unsafe_of_string buf)\n\n let unsafe_feed_bigstring ctx ?off ?len buf =\n let off, len =\n match (off, len) with\n | Some off, Some len -> (off, len)\n | Some off, None -> (off, Bi.length buf - off)\n | None, Some len -> (0, len)\n | None, None -> (0, Bi.length buf) in\n if off < 0 || len < 0 || off > Bi.length buf - len\n then invalid_arg \"offset out of bounds\"\n else unsafe_feed_bigstring ctx buf off len\n\n let unsafe_get = unsafe_get\nend\n\nmodule Core (Hash : Hash) (D : Desc) = struct\n type t = string\n\n type ctx = Hash.ctx\n\n type kind = Hash.kind\n\n include Unsafe (Hash) (D)\n include Conv.Make (D)\n include Eq.Make (D)\n\n let kind = D.kind\n\n let get t =\n let t = Hash.dup t in\n unsafe_get t |> By.unsafe_to_string\n\n let feed_bytes t ?off ?len buf =\n let t = Hash.dup t in\n unsafe_feed_bytes t ?off ?len buf ;\n t\n\n let feed_string t ?off ?len buf =\n let t = Hash.dup t in\n unsafe_feed_string t ?off ?len buf ;\n t\n\n let feed_bigstring t ?off ?len buf =\n let t = Hash.dup t in\n unsafe_feed_bigstring t ?off ?len buf ;\n t\n\n let feedi_bytes t iter =\n let t = Hash.dup t in\n let feed buf = unsafe_feed_bytes t buf in\n iter feed ;\n t\n\n let feedi_string t iter =\n let t = Hash.dup t in\n let feed buf = unsafe_feed_string t buf in\n iter feed ;\n t\n\n let feedi_bigstring t iter =\n let t = Hash.dup t in\n let feed buf = unsafe_feed_bigstring t buf in\n iter feed ;\n t\n\n let digest_bytes ?off ?len buf = feed_bytes empty ?off ?len buf |> get\n\n let digest_string ?off ?len buf = feed_string empty ?off ?len buf |> get\n\n let digest_bigstring ?off ?len buf = feed_bigstring empty ?off ?len buf |> get\n\n let digesti_bytes iter = feedi_bytes empty iter |> get\n\n let digesti_string iter = feedi_string empty iter |> get\n\n let digesti_bigstring iter = feedi_bigstring empty iter |> get\n\n let digestv_bytes lst = digesti_bytes (fun f -> List.iter f lst)\n\n let digestv_string lst = digesti_string (fun f -> List.iter f lst)\n\n let digestv_bigstring lst = digesti_bigstring (fun f -> List.iter f lst)\nend\n\nmodule Make (H : Hash) (D : Desc) = struct\n include Core (H) (D)\n\n let bytes_opad = By.init block_size (fun _ -> '\\x5c')\n\n let bytes_ipad = By.init block_size (fun _ -> '\\x36')\n\n let rec norm_bytes key =\n match Stdlib.compare (By.length key) block_size with\n | 1 -> norm_bytes (By.unsafe_of_string (digest_bytes key))\n | -1 -> By.rpad key block_size '\\000'\n | _ -> key\n\n let bigstring_opad = Bi.init block_size (fun _ -> '\\x5c')\n\n let bigstring_ipad = Bi.init block_size (fun _ -> '\\x36')\n\n let norm_bigstring key =\n let key = Bi.to_string key in\n let res0 = norm_bytes (By.unsafe_of_string key) in\n let res1 = Bi.create (By.length res0) in\n Bi.blit_from_bytes res0 0 res1 0 (By.length res0) ;\n res1\n\n let hmaci_bytes ~key iter =\n let key = norm_bytes key in\n let outer = Xor.Bytes.xor key bytes_opad in\n let inner = Xor.Bytes.xor key bytes_ipad in\n let res =\n digesti_bytes (fun f ->\n f inner ;\n iter f) in\n digesti_bytes (fun f ->\n f outer ;\n f (By.unsafe_of_string res))\n\n let hmaci_string ~key iter =\n let key = norm_bytes (By.unsafe_of_string key) in\n (* XXX(dinosaure): safe, [rpad] and [digest] have a read-only access. *)\n let outer = Xor.Bytes.xor key bytes_opad in\n let inner = Xor.Bytes.xor key bytes_ipad in\n let ctx = feed_bytes empty inner in\n let res = feedi_string ctx iter |> get in\n let ctx = feed_bytes empty outer in\n feed_string ctx (res :> string) |> get\n\n let hmaci_bigstring ~key iter =\n let key = norm_bigstring key in\n let outer = Xor.Bigstring.xor key bigstring_opad in\n let inner = Xor.Bigstring.xor key bigstring_ipad in\n let res =\n digesti_bigstring (fun f ->\n f inner ;\n iter f) in\n let ctx = feed_bigstring empty outer in\n feed_string ctx (res :> string) |> get\n\n let hmac_bytes ~key ?off ?len buf =\n let buf =\n match (off, len) with\n | Some off, Some len -> By.sub buf off len\n | Some off, None -> By.sub buf off (By.length buf - off)\n | None, Some len -> By.sub buf 0 len\n | None, None -> buf in\n hmaci_bytes ~key (fun f -> f buf)\n\n let hmac_string ~key ?off ?len buf =\n let buf =\n match (off, len) with\n | Some off, Some len -> String.sub buf off len\n | Some off, None -> String.sub buf off (String.length buf - off)\n | None, Some len -> String.sub buf 0 len\n | None, None -> buf in\n hmaci_string ~key (fun f -> f buf)\n\n let hmac_bigstring ~key ?off ?len buf =\n let buf =\n match (off, len) with\n | Some off, Some len -> Bi.sub buf off len\n | Some off, None -> Bi.sub buf off (Bi.length buf - off)\n | None, Some len -> Bi.sub buf 0 len\n | None, None -> buf in\n hmaci_bigstring ~key (fun f -> f buf)\n\n let hmacv_bytes ~key bufs = hmaci_bytes ~key (fun f -> List.iter f bufs)\n\n let hmacv_string ~key bufs = hmaci_string ~key (fun f -> List.iter f bufs)\n\n let hmacv_bigstring ~key bufs =\n hmaci_bigstring ~key (fun f -> List.iter f bufs)\nend\n\nmodule type Hash_BLAKE2 = sig\n type ctx\n\n type kind\n\n val with_outlen_and_bytes_key : int -> By.t -> int -> int -> ctx\n\n val with_outlen_and_bigstring_key : int -> Bi.t -> int -> int -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\n\n val max_outlen : int\nend\n\nmodule Make_BLAKE2 (H : Hash_BLAKE2) (D : Desc) = struct\n let () =\n if D.digest_size > H.max_outlen\n then\n failwith \"Invalid digest_size:%d to make a BLAKE2{S,B} implementation\"\n D.digest_size\n\n include Make\n (struct\n type ctx = H.ctx\n\n type kind = H.kind\n\n let init () =\n H.with_outlen_and_bytes_key D.digest_size By.empty 0 0\n\n let unsafe_feed_bytes = H.unsafe_feed_bytes\n\n let unsafe_feed_bigstring = H.unsafe_feed_bigstring\n\n let unsafe_get = H.unsafe_get\n\n let dup = H.dup\n end)\n (D)\n\n type outer = t\n\n module Keyed = struct\n type t = outer\n\n let maci_bytes ~key iter =\n let ctx = H.with_outlen_and_bytes_key digest_size key 0 (By.length key) in\n feedi_bytes ctx iter |> get\n\n let maci_string ~key iter =\n let ctx =\n H.with_outlen_and_bytes_key digest_size (By.unsafe_of_string key) 0\n (String.length key) in\n feedi_string ctx iter |> get\n\n let maci_bigstring ~key iter =\n let ctx =\n H.with_outlen_and_bigstring_key digest_size key 0 (Bi.length key) in\n feedi_bigstring ctx iter |> get\n\n let mac_bytes ~key ?off ?len buf : t =\n let buf =\n match (off, len) with\n | Some off, Some len -> By.sub buf off len\n | Some off, None -> By.sub buf off (By.length buf - off)\n | None, Some len -> By.sub buf 0 len\n | None, None -> buf in\n maci_bytes ~key (fun f -> f buf)\n\n let mac_string ~key ?off ?len buf =\n let buf =\n match (off, len) with\n | Some off, Some len -> String.sub buf off len\n | Some off, None -> String.sub buf off (String.length buf - off)\n | None, Some len -> String.sub buf 0 len\n | None, None -> buf in\n maci_string ~key (fun f -> f buf)\n\n let mac_bigstring ~key ?off ?len buf =\n let buf =\n match (off, len) with\n | Some off, Some len -> Bi.sub buf off len\n | Some off, None -> Bi.sub buf off (Bi.length buf - off)\n | None, Some len -> Bi.sub buf 0 len\n | None, None -> buf in\n maci_bigstring ~key (fun f -> f buf)\n\n let macv_bytes ~key bufs = maci_bytes ~key (fun f -> List.iter f bufs)\n\n let macv_string ~key bufs = maci_string ~key (fun f -> List.iter f bufs)\n\n let macv_bigstring ~key bufs =\n maci_bigstring ~key (fun f -> List.iter f bufs)\n end\nend\n\nmodule MD5 : S with type kind = [ `MD5 ] =\n Make\n (Baijiu_md5.Unsafe)\n (struct\n let digest_size, block_size = (16, 64)\n\n type kind = [ `MD5 ]\n\n let kind = `MD5\n end)\n\nmodule SHA1 : S with type kind = [ `SHA1 ] =\n Make\n (Baijiu_sha1.Unsafe)\n (struct\n let digest_size, block_size = (20, 64)\n\n type kind = [ `SHA1 ]\n\n let kind = `SHA1\n end)\n\nmodule SHA224 : S with type kind = [ `SHA224 ] =\n Make\n (Baijiu_sha224.Unsafe)\n (struct\n let digest_size, block_size = (28, 64)\n\n type kind = [ `SHA224 ]\n\n let kind = `SHA224\n end)\n\nmodule SHA256 : S with type kind = [ `SHA256 ] =\n Make\n (Baijiu_sha256.Unsafe)\n (struct\n let digest_size, block_size = (32, 64)\n\n type kind = [ `SHA256 ]\n\n let kind = `SHA256\n end)\n\nmodule SHA384 : S with type kind = [ `SHA384 ] =\n Make\n (Baijiu_sha384.Unsafe)\n (struct\n let digest_size, block_size = (48, 128)\n\n type kind = [ `SHA384 ]\n\n let kind = `SHA384\n end)\n\nmodule SHA512 : S with type kind = [ `SHA512 ] =\n Make\n (Baijiu_sha512.Unsafe)\n (struct\n let digest_size, block_size = (64, 128)\n\n type kind = [ `SHA512 ]\n\n let kind = `SHA512\n end)\n\nmodule SHA3_224 : S with type kind = [ `SHA3_224 ] =\n Make\n (Baijiu_sha3_224.Unsafe)\n (struct\n let digest_size, block_size = (28, 144)\n\n type kind = [ `SHA3_224 ]\n\n let kind = `SHA3_224\n end)\n\nmodule SHA3_256 : S with type kind = [ `SHA3_256 ] =\n Make\n (Baijiu_sha3_256.Unsafe)\n (struct\n let digest_size, block_size = (32, 136)\n\n type kind = [ `SHA3_256 ]\n\n let kind = `SHA3_256\n end)\n\nmodule SHA3_384 : S with type kind = [ `SHA3_384 ] =\n Make\n (Baijiu_sha3_384.Unsafe)\n (struct\n let digest_size, block_size = (48, 104)\n\n type kind = [ `SHA3_384 ]\n\n let kind = `SHA3_384\n end)\n\nmodule SHA3_512 : S with type kind = [ `SHA3_512 ] =\n Make\n (Baijiu_sha3_512.Unsafe)\n (struct\n let digest_size, block_size = (64, 72)\n\n type kind = [ `SHA3_512 ]\n\n let kind = `SHA3_512\n end)\n\nmodule WHIRLPOOL : S with type kind = [ `WHIRLPOOL ] =\n Make\n (Baijiu_whirlpool.Unsafe)\n (struct\n let digest_size, block_size = (64, 64)\n\n type kind = [ `WHIRLPOOL ]\n\n let kind = `WHIRLPOOL\n end)\n\nmodule BLAKE2B : sig\n include S with type kind = [ `BLAKE2B ]\n\n module Keyed : MAC with type t = t\nend =\n Make_BLAKE2\n (Baijiu_blake2b.Unsafe)\n (struct\n let digest_size, block_size = (64, 128)\n\n type kind = [ `BLAKE2B ]\n\n let kind = `BLAKE2B\n end)\n\nmodule BLAKE2S : sig\n include S with type kind = [ `BLAKE2S ]\n\n module Keyed : MAC with type t = t\nend =\n Make_BLAKE2\n (Baijiu_blake2s.Unsafe)\n (struct\n let digest_size, block_size = (32, 64)\n\n type kind = [ `BLAKE2S ]\n\n let kind = `BLAKE2S\n end)\n\nmodule RMD160 : S with type kind = [ `RMD160 ] =\n Make\n (Baijiu_rmd160.Unsafe)\n (struct\n let digest_size, block_size = (20, 64)\n\n type kind = [ `RMD160 ]\n\n let kind = `RMD160\n end)\n\nmodule Make_BLAKE2B (D : sig\n val digest_size : int\nend) : S with type kind = [ `BLAKE2B ] = struct\n include Make_BLAKE2\n (Baijiu_blake2b.Unsafe)\n (struct\n let digest_size, block_size = (D.digest_size, 128)\n\n type kind = [ `BLAKE2B ]\n\n let kind = `BLAKE2B\n end)\nend\n\nmodule Make_BLAKE2S (D : sig\n val digest_size : int\nend) : S with type kind = [ `BLAKE2S ] = struct\n include Make_BLAKE2\n (Baijiu_blake2s.Unsafe)\n (struct\n let digest_size, block_size = (D.digest_size, 64)\n\n type kind = [ `BLAKE2S ]\n\n let kind = `BLAKE2S\n end)\nend\n\ninclude Hash\n\ntype blake2b = (module S with type kind = [ `BLAKE2B ])\n\ntype blake2s = (module S with type kind = [ `BLAKE2S ])\n\nlet module_of : type k. k hash -> (module S with type kind = k) =\n fun hash ->\n let b2b : (int, blake2b) Hashtbl.t = Hashtbl.create 13 in\n let b2s : (int, blake2s) Hashtbl.t = Hashtbl.create 13 in\n match hash with\n | MD5 -> (module MD5)\n | SHA1 -> (module SHA1)\n | RMD160 -> (module RMD160)\n | SHA224 -> (module SHA224)\n | SHA256 -> (module SHA256)\n | SHA384 -> (module SHA384)\n | SHA512 -> (module SHA512)\n | SHA3_224 -> (module SHA3_224)\n | SHA3_256 -> (module SHA3_256)\n | SHA3_384 -> (module SHA3_384)\n | SHA3_512 -> (module SHA3_512)\n | WHIRLPOOL -> (module WHIRLPOOL)\n | BLAKE2B digest_size -> (\n match Hashtbl.find b2b digest_size with\n | exception Not_found ->\n let m : (module S with type kind = [ `BLAKE2B ]) =\n (module Make_BLAKE2B (struct\n let digest_size = digest_size\n end) : S\n with type kind = [ `BLAKE2B ]) in\n Hashtbl.replace b2b digest_size m ;\n m\n | m -> m)\n | BLAKE2S digest_size ->\n match Hashtbl.find b2s digest_size with\n | exception Not_found ->\n let m =\n (module Make_BLAKE2S (struct\n let digest_size = digest_size\n end) : S\n with type kind = [ `BLAKE2S ]) in\n Hashtbl.replace b2s digest_size m ;\n m\n | m -> m\n\ntype 'kind t = string\n\nlet digest_bytes : type k. k hash -> Bytes.t -> k t =\n fun hash buf ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digest_bytes buf) : H.kind t)\n\nlet digest_string : type k. k hash -> String.t -> k t =\n fun hash buf ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digest_string buf) : H.kind t)\n\nlet digest_bigstring : type k. k hash -> bigstring -> k t =\n fun hash buf ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digest_bigstring buf) : H.kind t)\n\nlet digesti_bytes : type k. k hash -> Bytes.t iter -> k t =\n fun hash iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digesti_bytes iter) : H.kind t)\n\nlet digesti_string : type k. k hash -> String.t iter -> k t =\n fun hash iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digesti_string iter) : H.kind t)\n\nlet digesti_bigstring : type k. k hash -> bigstring iter -> k t =\n fun hash iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digesti_bigstring iter) : H.kind t)\n\nlet hmaci_bytes : type k. k hash -> key:Bytes.t -> Bytes.t iter -> k t =\n fun hash ~key iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.hmaci_bytes ~key iter) : H.kind t)\n\nlet hmaci_string : type k. k hash -> key:String.t -> String.t iter -> k t =\n fun hash ~key iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.hmaci_string ~key iter) : H.kind t)\n\nlet hmaci_bigstring : type k. k hash -> key:bigstring -> bigstring iter -> k t =\n fun hash ~key iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.hmaci_bigstring ~key iter) : H.kind t)\n\n(* XXX(dinosaure): unsafe part to avoid overhead. *)\n\nlet unsafe_compare : type k. k hash -> k t -> k t -> int =\n fun hash a b ->\n let module H = (val module_of hash) in\n let unsafe : 'k t -> H.t = H.of_raw_string in\n H.unsafe_compare (unsafe a) (unsafe b)\n\nlet equal : type k. k hash -> k t equal =\n fun hash a b ->\n let module H = (val module_of hash) in\n let unsafe : 'k t -> H.t = H.of_raw_string in\n H.equal (unsafe a) (unsafe b)\n\nlet pp : type k. k hash -> k t pp =\n fun hash ppf t ->\n let module H = (val module_of hash) in\n let unsafe : 'k t -> H.t = H.of_raw_string in\n H.pp ppf (unsafe t)\n\nlet of_hex : type k. k hash -> string -> k t =\n fun hash hex ->\n let module H = (val module_of hash) in\n H.to_raw_string (H.of_hex hex)\n\nlet of_hex_opt : type k. k hash -> string -> k t option =\n fun hash hex ->\n let module H = (val module_of hash) in\n match H.of_hex_opt hex with\n | None -> None\n | Some digest -> Some (H.to_raw_string digest)\n\nlet consistent_of_hex : type k. k hash -> string -> k t =\n fun hash hex ->\n let module H = (val module_of hash) in\n H.to_raw_string (H.consistent_of_hex hex)\n\nlet consistent_of_hex_opt : type k. k hash -> string -> k t option =\n fun hash hex ->\n let module H = (val module_of hash) in\n match H.consistent_of_hex_opt hex with\n | None -> None\n | Some digest -> Some (H.to_raw_string digest)\n\nlet to_hex : type k. k hash -> k t -> string =\n fun hash t ->\n let module H = (val module_of hash) in\n let unsafe : 'k t -> H.t = H.of_raw_string in\n H.to_hex (unsafe t)\n\nlet of_raw_string : type k. k hash -> string -> k t =\n fun hash s ->\n let module H = (val module_of hash) in\n let unsafe : H.t -> 'k t = H.to_raw_string in\n unsafe (H.of_raw_string s)\n\nlet of_raw_string_opt : type k. k hash -> string -> k t option =\n fun hash s ->\n let module H = (val module_of hash) in\n let unsafe : H.t -> 'k t = H.to_raw_string in\n match H.of_raw_string_opt s with\n | None -> None\n | Some digest -> Some (unsafe digest)\n\nlet to_raw_string : type k. k hash -> k t -> string = fun _ t -> t\n\nlet of_digest (type hash kind)\n (module H : S with type t = hash and type kind = kind) (hash : H.t) : kind t\n =\n H.to_raw_string hash\n\nlet of_md5 hash = of_raw_string md5 (MD5.to_raw_string hash)\n\nlet of_sha1 hash = of_raw_string sha1 (SHA1.to_raw_string hash)\n\nlet of_rmd160 hash = of_raw_string rmd160 (RMD160.to_raw_string hash)\n\nlet of_sha224 hash = of_raw_string sha224 (SHA224.to_raw_string hash)\n\nlet of_sha256 hash = of_raw_string sha256 (SHA256.to_raw_string hash)\n\nlet of_sha384 hash = of_raw_string sha384 (SHA384.to_raw_string hash)\n\nlet of_sha512 hash = of_raw_string sha512 (SHA512.to_raw_string hash)\n\nlet of_sha3_224 hash = of_raw_string sha3_224 (SHA3_224.to_raw_string hash)\n\nlet of_sha3_256 hash = of_raw_string sha3_256 (SHA3_256.to_raw_string hash)\n\nlet of_sha3_384 hash = of_raw_string sha3_384 (SHA3_384.to_raw_string hash)\n\nlet of_sha3_512 hash = of_raw_string sha3_512 (SHA3_512.to_raw_string hash)\n\nlet of_whirlpool hash = of_raw_string whirlpool (WHIRLPOOL.to_raw_string hash)\n\nlet of_blake2b hash =\n of_raw_string (blake2b BLAKE2B.digest_size) (BLAKE2B.to_raw_string hash)\n\nlet of_blake2s hash =\n of_raw_string (blake2s BLAKE2S.digest_size) (BLAKE2S.to_raw_string hash)\n","open Core_kernel\n\nmodule Digit = struct\n (* A number between 0 and 15 *)\n type t =\n | H0\n | H1\n | H2\n | H3\n | H4\n | H5\n | H6\n | H7\n | H8\n | H9\n | H10\n | H11\n | H12\n | H13\n | H14\n | H15\n\n let of_char_exn c =\n match Char.lowercase c with\n | '0' ->\n H0\n | '1' ->\n H1\n | '2' ->\n H2\n | '3' ->\n H3\n | '4' ->\n H4\n | '5' ->\n H5\n | '6' ->\n H6\n | '7' ->\n H7\n | '8' ->\n H8\n | '9' ->\n H9\n | 'a' ->\n H10\n | 'b' ->\n H11\n | 'c' ->\n H12\n | 'd' ->\n H13\n | 'e' ->\n H14\n | 'f' ->\n H15\n | _ ->\n failwithf \"bad hex digit %c\" c ()\n\n let to_int = function\n | H0 ->\n 0\n | H1 ->\n 1\n | H2 ->\n 2\n | H3 ->\n 3\n | H4 ->\n 4\n | H5 ->\n 5\n | H6 ->\n 6\n | H7 ->\n 7\n | H8 ->\n 8\n | H9 ->\n 9\n | H10 ->\n 10\n | H11 ->\n 11\n | H12 ->\n 12\n | H13 ->\n 13\n | H14 ->\n 14\n | H15 ->\n 15\nend\n\nlet hex_char_of_int_exn = function\n | 0 ->\n '0'\n | 1 ->\n '1'\n | 2 ->\n '2'\n | 3 ->\n '3'\n | 4 ->\n '4'\n | 5 ->\n '5'\n | 6 ->\n '6'\n | 7 ->\n '7'\n | 8 ->\n '8'\n | 9 ->\n '9'\n | 10 ->\n 'a'\n | 11 ->\n 'b'\n | 12 ->\n 'c'\n | 13 ->\n 'd'\n | 14 ->\n 'e'\n | 15 ->\n 'f'\n | d ->\n failwithf \"bad hex digit %d\" d ()\n\nmodule Sequence_be = struct\n type t = Digit.t array\n\n let decode ?(pos = 0) s =\n let n = String.length s - pos in\n Array.init n ~f:(fun i -> Digit.of_char_exn s.[pos + i])\n\n let to_bytes_like ~init (t : t) =\n let n = Array.length t in\n let k = n / 2 in\n assert (n = k + k) ;\n init k ~f:(fun i ->\n Char.of_int_exn\n ((16 * Digit.to_int t.(2 * i)) + Digit.to_int t.((2 * i) + 1)) )\n\n let to_string = to_bytes_like ~init:String.init\n\n let to_bytes = to_bytes_like ~init:Bytes.init\n\n let to_bigstring = to_bytes_like ~init:Bigstring.init\nend\n\nlet decode ?(reverse = false) ?(pos = 0) ~init t =\n let n = String.length t - pos in\n let k = n / 2 in\n assert (n = k + k) ;\n let h j = Digit.(to_int (of_char_exn t.[pos + j])) in\n init k ~f:(fun i ->\n let i = if reverse then k - 1 - i else i in\n Char.of_int_exn ((16 * h (2 * i)) + h ((2 * i) + 1)) )\n\nlet encode ?(reverse = false) t =\n let n = String.length t in\n String.init (2 * n) ~f:(fun i ->\n let c =\n let byte = i / 2 in\n Char.to_int t.[if reverse then n - 1 - byte else byte]\n in\n let c = if i mod 2 = 0 then (* hi *)\n c lsr 4 else (* lo *)\n c in\n hex_char_of_int_exn (c land 15) )\n\nlet%test_unit \"decode\" =\n let t = String.init 100 ~f:(fun _ -> Char.of_int_exn (Random.int 256)) in\n let h = encode t in\n assert (String.equal t (decode ~init:String.init h)) ;\n assert (\n String.equal t\n (decode ~reverse:true ~init:String.init (encode ~reverse:true t)) ) ;\n assert (String.equal t Sequence_be.(to_string (decode h)))\n\n(* TODO: Better deduplicate the hex coding between these two implementations #5711 *)\nmodule Safe = struct\n (** to_hex : {0x0-0xff}* -> [A-F0-9]* *)\n let to_hex (data : string) : string =\n String.to_list data\n |> List.map ~f:(fun c ->\n let charify u4 =\n match u4 with\n | x when x <= 9 && x >= 0 ->\n Char.(of_int_exn @@ (x + to_int '0'))\n | x when x <= 15 && x >= 10 ->\n Char.(of_int_exn @@ (x - 10 + to_int 'A'))\n | _ ->\n failwith \"Unexpected u4 has only 4bits of information\"\n in\n let high = charify @@ ((Char.to_int c land 0xF0) lsr 4) in\n let lo = charify (Char.to_int c land 0x0F) in\n String.of_char_list [ high; lo ] )\n |> String.concat\n\n let%test_unit \"to_hex sane\" =\n let start = \"a\" in\n let hexified = to_hex start in\n let expected = \"61\" in\n if String.equal expected hexified then ()\n else\n failwithf \"start: %s ; hexified : %s ; expected: %s\" start hexified\n expected ()\n\n (** of_hex : [a-fA-F0-9]* -> {0x0-0xff}* option *)\n let of_hex (hex : string) : string option =\n let to_u4 c =\n let open Char in\n assert (is_alphanum c) ;\n match c with\n | _ when is_digit c ->\n to_int c - to_int '0'\n | _ when is_uppercase c ->\n to_int c - to_int 'A' + 10\n | _ (* when is_alpha *) ->\n to_int c - to_int 'a' + 10\n in\n String.to_list hex |> List.chunks_of ~length:2\n |> List.fold_result ~init:[] ~f:(fun acc chunk ->\n match chunk with\n | [ a; b ] when Char.is_alphanum a && Char.is_alphanum b ->\n Or_error.return\n @@ (Char.((to_u4 a lsl 4) lor to_u4 b |> of_int_exn) :: acc)\n | _ ->\n Or_error.error_string \"invalid hex\" )\n |> Or_error.ok\n |> Option.map ~f:(Fn.compose String.of_char_list List.rev)\n\n let%test_unit \"partial isomorphism\" =\n Quickcheck.test ~sexp_of:[%sexp_of: string] ~examples:[ \"\\243\"; \"abc\" ]\n Quickcheck.Generator.(map (list char) ~f:String.of_char_list)\n ~f:(fun s ->\n let hexified = to_hex s in\n let actual = Option.value_exn (of_hex hexified) in\n let expected = s in\n if String.equal actual expected then ()\n else\n failwithf\n !\"expected: %s ; hexified: %s ; actual: %s\"\n expected hexified actual () )\nend\n","(* logger.ml : the fake one *)\n\nopen Core_kernel\n\nlet not_implemented () = failwith \"Not implemented\"\n\nmodule Level = struct\n type t =\n | Internal\n | Spam\n | Trace\n | Debug\n | Info\n | Warn\n | Error\n | Faulty_peer\n | Fatal\n [@@deriving sexp, equal, compare, show { with_path = false }, enumerate]\n\n let of_string _ = not_implemented ()\n\n let to_yojson _ = not_implemented ()\n\n let of_yojson _ = not_implemented ()\nend\n\n(* Core modules extended with Yojson converters *)\nmodule Time = struct\n include Time\n\n let to_yojson _ = not_implemented ()\n\n let of_yojson _ = not_implemented ()\n\n let pp _ _ = not_implemented ()\n\n let set_pretty_to_string _ = not_implemented ()\n\n let pretty_to_string _ = not_implemented ()\nend\n\nmodule Source = struct\n type t = { module_ : string [@key \"module\"]; location : string }\n [@@deriving yojson]\n\n let create ~module_:_ ~location:_ = not_implemented ()\nend\n\nmodule Metadata = struct\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n type t = Yojson.Safe.t String.Map.t\n\n let to_latest = Fn.id\n\n let to_yojson _ = not_implemented ()\n\n let of_yojson _ = not_implemented ()\n\n include\n Binable.Of_binable_without_uuid\n (Core_kernel.String.Stable.V1)\n (struct\n type nonrec t = t\n\n let to_binable _ = not_implemented ()\n\n let of_binable _ = not_implemented ()\n end)\n end\n end]\n\n [%%define_locally Stable.Latest.(to_yojson, of_yojson)]\n\n let empty = String.Map.empty\nend\n\nlet append_to_global_metadata _ = not_implemented ()\n\nmodule Message = struct\n type t =\n { timestamp : Time.t\n ; level : Level.t\n ; source : Source.t option [@default None]\n ; message : string\n ; metadata : Metadata.t\n ; event_id : Structured_log_events.id option [@default None]\n }\n [@@deriving yojson]\nend\n\nmodule Processor = struct\n module type S = sig\n type t\n\n val process : t -> Message.t -> string option\n end\n\n type t\n\n let create _ _ = not_implemented ()\n\n let raw ?log_level:_ () = not_implemented ()\n\n let raw_structured_log_events _ = not_implemented ()\n\n let pretty ~log_level:_ ~config:_ = not_implemented ()\nend\n\nmodule Transport = struct\n module type S = sig\n type t\n\n val transport : t -> string -> unit\n end\n\n type t\n\n let create _ _ = not_implemented ()\n\n let raw _ = not_implemented ()\n\n let stdout () = not_implemented ()\nend\n\nmodule Consumer_registry = struct\n type id = string\n\n let register ~id:_ ~processor:_ ~transport:_ = not_implemented ()\nend\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = { null : bool; metadata : Metadata.Stable.V1.t; id : string }\n\n let to_latest = Fn.id\n end\nend]\n\nlet metadata t = t.metadata\n\nlet create ?metadata:_ ?(id = \"default\") () =\n { null = false; metadata = Metadata.empty; id }\n\nlet null () = { null = true; metadata = Metadata.empty; id = \"default\" }\n\nlet extend t _ = t\n\nlet change_id { null; metadata; id = _ } ~id = { null; metadata; id }\n\nlet raw _ _ = not_implemented ()\n\nlet log _t ~level:_ ~module_:_ ~location:_ ?metadata:_ ?event_id:_ fmt =\n let f _message = () in\n ksprintf f fmt\n\ntype 'a log_function =\n t\n -> module_:string\n -> location:string\n -> ?metadata:(string, Yojson.Safe.t) List.Assoc.t\n -> ?event_id:Structured_log_events.id\n -> ('a, unit, string, unit) format4\n -> 'a\n\nlet trace = log ~level:Level.Trace\n\nlet internal = log ~level:Level.Internal\n\nlet debug = log ~level:Level.Debug\n\nlet info = log ~level:Level.Info\n\nlet warn = log ~level:Level.Warn\n\nlet error = log ~level:Level.Error\n\nlet fatal = log ~level:Level.Fatal\n\nlet faulty_peer_without_punishment = log ~level:Level.Faulty_peer\n\nlet spam = log ~level:Level.Spam ~module_:\"\" ~location:\"\" ?event_id:None\n\n(* deprecated, use Trust_system.record instead *)\nlet faulty_peer = faulty_peer_without_punishment\n\nmodule Structured = struct\n type log_function =\n t\n -> module_:string\n -> location:string\n -> ?metadata:(string, Yojson.Safe.t) List.Assoc.t\n -> Structured_log_events.t\n -> unit\n\n let log _t ~level:_ ~module_:_ ~location:_ ?metadata:_ _event = ()\n\n let trace : log_function = log ~level:Level.Trace\n\n let debug = log ~level:Level.Debug\n\n let info = log ~level:Level.Info\n\n let warn = log ~level:Level.Warn\n\n let error = log ~level:Level.Error\n\n let fatal = log ~level:Level.Fatal\n\n let faulty_peer_without_punishment = log ~level:Level.Faulty_peer\n\n let best_tip_diff = log ~level:Level.Spam ~module_:\"\" ~location:\"\"\nend\n\nmodule Str = Structured\n\nmodule Logger_id = struct\n let invalid = \"fake\"\n\n let mina = invalid\n\n let best_tip_diff = invalid\n\n let rejected_blocks = invalid\n\n let snark_worker = invalid\n\n let oversized_logs = invalid\nend\n","open Core_kernel\n\n(** immutable, serializable statistics derived from allocation data *)\nmodule Allocation_statistics = struct\n (* times represented in ms *)\n type quartiles = { q1 : float; q2 : float; q3 : float; q4 : float }\n [@@deriving yojson]\n\n let make_quartiles n = { q1 = n; q2 = n; q3 = n; q4 = n }\n\n let empty_quartiles = make_quartiles 0.0\n\n type t = { count : int; lifetimes : quartiles } [@@deriving yojson]\n\n let write_metrics { count; lifetimes } object_id =\n let open Mina_metrics in\n let open Mina_metrics.Object_lifetime_statistics in\n let { q1; q2; q3; q4 } = lifetimes in\n let q x = lifetime_quartile_ms ~name:object_id ~quartile:x in\n Gauge.set (live_count ~name:object_id) (Int.to_float count) ;\n Gauge.set (q `Q1) q1 ;\n Gauge.set (q `Q2) q2 ;\n Gauge.set (q `Q3) q3 ;\n Gauge.set (q `Q4) q4\nend\n\n(** mutable data for an object we track allocations of (one exists per object type) *)\nmodule Allocation_data = struct\n (* stops being unique after 2^{30,62} values; perhaps we should use guids instead *)\n type allocation_id = int\n\n let initial_allocation_id = Int.min_value\n\n (* indexed queue data structure would be more effecient here, but keeping this simple for now *)\n type t =\n { allocation_times : (allocation_id * Time.t) Queue.t\n ; mutable next_allocation_id : allocation_id\n }\n\n let create () =\n { allocation_times = Queue.create ()\n ; next_allocation_id = initial_allocation_id\n }\n\n let register_allocation data =\n let id = data.next_allocation_id in\n Queue.enqueue data.allocation_times (id, Time.now ()) ;\n data.next_allocation_id <- data.next_allocation_id + 1 ;\n id\n\n (* currently O(n) wrt queue size *)\n let unregister_allocation data id =\n Queue.filter_inplace data.allocation_times ~f:(fun (id', _) -> id = id')\n\n let compute_statistics { allocation_times; _ } =\n let now = Time.now () in\n let count = Queue.length allocation_times in\n let lifetime_ms_of_time time = Time.Span.to_ms (Time.diff now time) in\n let get_lifetime_ms i =\n lifetime_ms_of_time (snd @@ Queue.get allocation_times i)\n in\n let mean_indices max_len =\n let m = max_len - 1 in\n if m mod 2 = 0 then [ m / 2 ] else [ m / 2; (m / 2) + 1 ]\n in\n let mean offset length =\n let indices =\n mean_indices length |> List.filter ~f:(fun x -> x < count)\n in\n let sum =\n List.fold_left indices ~init:0.0 ~f:(fun acc i ->\n acc +. get_lifetime_ms (count - 1 - (i + offset)) )\n in\n sum /. Int.to_float (List.length indices)\n in\n let lifetimes =\n match count with\n | 0 ->\n Allocation_statistics.empty_quartiles\n | 1 ->\n Allocation_statistics.make_quartiles (get_lifetime_ms 0)\n | _ ->\n let q1 = mean 0 (count / 2) in\n let q2 = mean 0 count in\n let q3_offset = if count mod 2 = 0 then 0 else 1 in\n let q3 = mean ((count / 2) + q3_offset) (count / 2) in\n let q4 = get_lifetime_ms 0 in\n Allocation_statistics.{ q1; q2; q3; q4 }\n in\n Allocation_statistics.{ count; lifetimes }\n\n let compute_statistics t =\n try compute_statistics t\n with _ ->\n Allocation_statistics.\n { count = 0; lifetimes = Allocation_statistics.make_quartiles 0. }\n\n let%test_module \"Allocation_data unit tests\" =\n ( module struct\n open Allocation_statistics\n\n module Float_compare = Float.Robust_compare.Make (struct\n let robust_comparison_tolerance = 0.04\n end)\n\n type robust_float = float [@@deriving sexp]\n\n let compare_robust_float = Float_compare.robustly_compare\n\n (* time_offsets passed in here should be ordered monotonically (to match real world behavior) *)\n let run_test time_offsets expected_quartiles =\n let now = Time.now () in\n (* ids do not need to be unique in this test *)\n let data =\n { allocation_times =\n Queue.of_list\n @@ List.map (List.rev time_offsets) ~f:(fun offset ->\n (0, Time.sub now (Time.Span.of_ms offset)) )\n ; next_allocation_id = 0\n }\n in\n let stats = compute_statistics data in\n [%test_eq: int] stats.count (List.length time_offsets) ;\n [%test_eq: robust_float] stats.lifetimes.q1 expected_quartiles.q1 ;\n [%test_eq: robust_float] stats.lifetimes.q2 expected_quartiles.q2 ;\n [%test_eq: robust_float] stats.lifetimes.q3 expected_quartiles.q3 ;\n [%test_eq: robust_float] stats.lifetimes.q4 expected_quartiles.q4\n\n let%test_unit \"quartiles of empty list\" =\n run_test [] { q1 = 0.0; q2 = 0.0; q3 = 0.0; q4 = 0.0 }\n\n let%test_unit \"quartiles of singleton list\" =\n run_test [ 1.0 ] { q1 = 1.0; q2 = 1.0; q3 = 1.0; q4 = 1.0 }\n\n let%test_unit \"quartiles of 2 element list\" =\n run_test [ 1.0; 2.0 ] { q1 = 1.0; q2 = 1.5; q3 = 2.0; q4 = 2.0 }\n\n let%test_unit \"quartiles of 3 element list\" =\n run_test [ 1.0; 2.0; 3.0 ] { q1 = 1.0; q2 = 2.0; q3 = 3.0; q4 = 3.0 }\n\n let%test_unit \"quartiles of even list (> 3)\" =\n run_test\n [ 1.0; 2.0; 3.0; 4.0; 5.0; 6.0 ]\n { q1 = 2.0; q2 = 3.5; q3 = 5.0; q4 = 6.0 }\n\n let%test_unit \"quartiles of odd list with even split (> 3)\" =\n run_test\n [ 1.0; 2.0; 3.0; 4.0; 5.0; 6.0; 7.0 ]\n { q1 = 2.0; q2 = 4.0; q3 = 6.0; q4 = 7.0 }\n\n let%test_unit \"quartiles of odd list with odd split (> 3)\" =\n run_test\n [ 1.0; 2.0; 3.0; 4.0; 5.0; 6.0; 7.0; 8.0; 9.0 ]\n { q1 = 2.5; q2 = 5.0; q3 = 7.5; q4 = 9.0 }\n end )\nend\n\n(** correlation of allocation data and derived statistics *)\nmodule Allocation_info = struct\n type t = { statistics : Allocation_statistics.t; data : Allocation_data.t }\nend\n\nlet table = String.Table.create ()\n\nlet capture object_id =\n let open Allocation_info in\n let info_opt = String.Table.find table object_id in\n let data_opt = Option.map info_opt ~f:(fun { data; _ } -> data) in\n let data =\n Lazy.(\n force\n @@ Option.value_map data_opt\n ~default:(lazy (Allocation_data.create ()))\n ~f:Lazy.return)\n in\n let allocation_id = Allocation_data.register_allocation data in\n let statistics = Allocation_data.compute_statistics data in\n String.Table.set table ~key:object_id ~data:{ data; statistics } ;\n Allocation_statistics.write_metrics statistics object_id ;\n Mina_metrics.(\n Counter.inc_one (Object_lifetime_statistics.allocated_count ~name:object_id)) ;\n allocation_id\n\n(* release is currently O(n), where n = number of active allocations for this object type; this can be improved by implementing indexed queues (with decent random delete computational complexity) in ocaml *)\nlet release ~object_id ~allocation_id =\n let open Allocation_info in\n let info = String.Table.find_exn table object_id in\n Allocation_data.unregister_allocation info.data allocation_id ;\n let statistics = Allocation_data.compute_statistics info.data in\n String.Table.set table ~key:object_id ~data:{ info with statistics } ;\n Allocation_statistics.write_metrics statistics object_id ;\n Mina_metrics.(\n Counter.inc_one (Object_lifetime_statistics.collected_count ~name:object_id))\n\nlet attach_finalizer object_id obj =\n let allocation_id = capture object_id in\n Gc.Expert.add_finalizer_exn obj (fun _ -> release ~object_id ~allocation_id) ;\n obj\n\nlet dump () =\n let open Allocation_info in\n let entries =\n String.Table.to_alist table\n |> List.Assoc.map ~f:(fun { statistics; _ } ->\n Allocation_statistics.to_yojson statistics )\n in\n `Assoc entries\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'a t =\n { accs : ('a * 'a) array\n ; bits : 'a array\n ; ss : 'a array\n ; base : 'a * 'a\n ; n_prev : 'a\n ; n_next : 'a\n }\n [@@deriving sexp, fields, hlist]\n end\nend]\n\nlet map { accs; bits; ss; base; n_prev; n_next } ~f =\n { accs = Array.map accs ~f:(fun (x, y) -> (f x, f y))\n ; bits = Array.map bits ~f\n ; ss = Array.map ss ~f\n ; base = (f (fst base), f (snd base))\n ; n_prev = f n_prev\n ; n_next = f n_next\n }\n\nlet map2 t1 t2 ~f =\n { accs =\n Array.map (Array.zip_exn t1.accs t2.accs) ~f:(fun ((x1, y1), (x2, y2)) ->\n (f x1 x2, f y1 y2) )\n ; bits =\n Array.map (Array.zip_exn t1.bits t2.bits) ~f:(fun (x1, x2) -> f x1 x2)\n ; ss = Array.map (Array.zip_exn t1.ss t2.ss) ~f:(fun (x1, x2) -> f x1 x2)\n ; base = (f (fst t1.base) (fst t2.base), f (snd t1.base) (snd t2.base))\n ; n_prev = f t1.n_prev t2.n_prev\n ; n_next = f t1.n_next t2.n_next\n }\n\nlet fold { accs; bits; ss; base; n_prev; n_next } ~f ~init =\n let t = Array.fold accs ~init ~f:(fun acc (x, y) -> f [ x; y ] acc) in\n let t = Array.fold bits ~init:t ~f:(fun acc x -> f [ x ] acc) in\n let t = Array.fold ss ~init:t ~f:(fun acc x -> f [ x ] acc) in\n let t = f [ fst base; snd base ] t in\n let t = f [ n_prev ] t in\n let t = f [ n_next ] t in\n t\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'f t = 'f Kimchi_types.scalar_challenge = { inner : 'f }\n [@@deriving sexp, compare, equal, yojson, hash]\n end\nend]\n\nlet create t = { inner = t }\n\nlet typ f =\n let there { inner = x } = x in\n let back x = create x in\n Snarky_backendless.Typ.(transport_var (transport f ~there ~back) ~there ~back)\n\nlet map { inner = x } ~f = create (f x)\n","open Intf\nopen Core_kernel\n\nmodule type Input_intf = sig\n module BaseField : sig\n type t\n end\n\n module ScalarField : sig\n type t\n end\n\n module Affine : sig\n type t = BaseField.t Kimchi_types.or_infinity\n end\n\n type t\n\n val to_affine : t -> Affine.t\n\n val of_affine_coordinates : BaseField.t -> BaseField.t -> t\n\n val add : t -> t -> t\n\n val double : t -> t\n\n val scale : t -> ScalarField.t -> t\n\n val sub : t -> t -> t\n\n val negate : t -> t\n\n val random : unit -> t\n\n val one : unit -> t\nend\n\nmodule type Field_intf = sig\n module Stable : sig\n module Latest : sig\n type t [@@deriving bin_io, equal, sexp, compare, yojson, hash]\n end\n end\n\n type t = Stable.Latest.t\n\n val ( + ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n\n val one : t\n\n val square : t -> t\n\n val is_square : t -> bool\n\n val sqrt : t -> t\n\n val random : unit -> t\nend\n\nmodule Make\n (BaseField : Field_intf) (ScalarField : sig\n type t\n end) (Params : sig\n val a : BaseField.t\n\n val b : BaseField.t\n end)\n (C : Input_intf\n with module BaseField := BaseField\n and module ScalarField := ScalarField) =\nstruct\n include (C : module type of C with type t = C.t with module Affine := C.Affine)\n\n module Base_field = BaseField\n\n let one = one ()\n\n (* TODO: wouldn't be easier if Input_intf exposed a `zero`? *)\n let zero = sub one one\n\n let y_squared x =\n let open BaseField in\n Params.b + (x * (Params.a + square x))\n\n module Affine = struct\n module Backend = struct\n include C.Affine\n\n let zero () = Kimchi_types.Infinity\n\n let create x y = Kimchi_types.Finite (x, y)\n end\n\n module Stable = struct\n module V1 = struct\n module T = struct\n type t = BaseField.Stable.Latest.t * BaseField.Stable.Latest.t\n [@@deriving equal, bin_io, sexp, compare, yojson, hash]\n end\n\n (* asserts the versioned-ness of V1\n to do this properly, we'd move the Stable module outside the functor\n *)\n let __versioned__ = ()\n\n include T\n\n exception Invalid_curve_point of t\n\n include\n Binable.Of_binable\n (T)\n (struct\n let on_curve (x, y) =\n BaseField.Stable.Latest.equal (y_squared x) (BaseField.square y)\n\n type t = T.t\n\n let to_binable = Fn.id\n\n let of_binable t =\n if not (on_curve t) then raise (Invalid_curve_point t) ;\n t\n end)\n end\n\n module Latest = V1\n end\n\n let%test \"cannot deserialize invalid points\" =\n (* y^2 = x^3 + a x + b\n\n pick c at random\n let (x, y) = (c^2, c^3)\n\n Then the above equation becomes\n c^6 = c^6 + (a c^2 + b)\n\n a c^3 + b is almost certainly nonzero (and for our curves, with a = 0, it always is)\n so this point is almost certainly (and for our curves, always) invalid\n *)\n let invalid =\n let open BaseField in\n let c = random () in\n let c2 = square c in\n (c2, c2 * c)\n in\n match\n Binable.to_string (module Stable.Latest) invalid\n |> Binable.of_string (module Stable.Latest)\n with\n | exception Stable.V1.Invalid_curve_point _ ->\n true\n | _ ->\n false\n\n include Stable.Latest\n\n let to_backend :\n (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t -> Backend.t =\n function\n | Infinity ->\n Infinity\n | Finite (x, y) ->\n Finite (x, y)\n\n let of_backend :\n Backend.t -> (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t =\n function\n | Infinity ->\n Infinity\n | Finite (x, y) ->\n Finite (x, y)\n end\n\n let to_affine_or_infinity = C.to_affine\n\n let to_affine_exn t =\n match C.to_affine t with\n | Infinity ->\n failwith \"to_affine_exn: Got identity\"\n | Finite (x, y) ->\n (x, y)\n\n let of_affine (x, y) = C.of_affine_coordinates x y\n\n include\n Binable.Of_binable\n (Affine)\n (struct\n type nonrec t = t\n\n let to_binable = to_affine_exn\n\n let of_binable = of_affine\n end)\n\n let ( + ) = add\n\n let ( * ) s t = scale t s\n\n let find_y x =\n let open BaseField in\n let y2 = y_squared x in\n if is_square y2 then Some (sqrt y2) else None\n\n let point_near_x (x : BaseField.t) =\n let rec go x = function\n | Some y ->\n of_affine (x, y)\n | None ->\n let x' = BaseField.(one + x) in\n go x' (find_y x')\n in\n go x (find_y x)\nend\n","open Core_kernel\nopen Async_kernel\nopen Pickles_types\n\nlet tuple15_to_vec\n (w0, w1, w2, w3, w4, w5, w6, w7, w8, w9, w10, w11, w12, w13, w14) =\n Vector.[ w0; w1; w2; w3; w4; w5; w6; w7; w8; w9; w10; w11; w12; w13; w14 ]\n\nlet tuple15_of_vec\n Vector.[ w0; w1; w2; w3; w4; w5; w6; w7; w8; w9; w10; w11; w12; w13; w14 ] =\n (w0, w1, w2, w3, w4, w5, w6, w7, w8, w9, w10, w11, w12, w13, w14)\n\nlet tuple6_to_vec (w0, w1, w2, w3, w4, w5) = Vector.[ w0; w1; w2; w3; w4; w5 ]\n\nlet tuple6_of_vec Vector.[ w0; w1; w2; w3; w4; w5 ] = (w0, w1, w2, w3, w4, w5)\n\nmodule type Stable_v1 = sig\n module Stable : sig\n module V1 : sig\n type t [@@deriving version, bin_io, sexp, compare, yojson, hash, equal]\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t [@@deriving sexp, compare, yojson, hash, equal]\nend\n\nmodule type Inputs_intf = sig\n open Intf\n\n val id : string\n\n module Scalar_field : sig\n include Stable_v1\n\n val one : t\n\n module Vector : Snarky_intf.Vector.S with type elt = t\n end\n\n module Base_field : sig\n type t\n end\n\n module Curve : sig\n module Affine : sig\n include Stable_v1 with type Stable.V1.t = Base_field.t * Base_field.t\n\n module Backend : sig\n type t = Base_field.t Kimchi_types.or_infinity\n end\n\n val of_backend :\n Backend.t -> (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t\n\n val to_backend :\n (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t -> Backend.t\n end\n end\n\n module Poly_comm : sig\n type t = Base_field.t Poly_comm.t\n\n module Backend : sig\n type t = Curve.Affine.Backend.t Kimchi_types.poly_comm\n end\n\n val of_backend_with_degree_bound : Backend.t -> t\n\n val of_backend_without_degree_bound : Backend.t -> t\n\n val to_backend : t -> Backend.t\n end\n\n module Opening_proof_backend : sig\n type t = (Curve.Affine.Backend.t, Scalar_field.t) Kimchi_types.opening_proof\n end\n\n module Evaluations_backend : sig\n type t = Scalar_field.t Kimchi_types.proof_evaluations\n end\n\n module Index : sig\n type t\n end\n\n module Verifier_index : sig\n type t\n end\n\n module Backend : sig\n type with_public_evals =\n (Curve.Affine.Backend.t, Scalar_field.t) Kimchi_types.proof_with_public\n\n type t = (Curve.Affine.Backend.t, Scalar_field.t) Kimchi_types.prover_proof\n\n val create :\n Index.t\n -> primary:Scalar_field.Vector.t\n -> auxiliary:Scalar_field.Vector.t\n -> prev_chals:Scalar_field.t array\n -> prev_comms:Curve.Affine.Backend.t array\n -> with_public_evals\n\n val create_async :\n Index.t\n -> primary:Scalar_field.Vector.t\n -> auxiliary:Scalar_field.Vector.t\n -> prev_chals:Scalar_field.t array\n -> prev_comms:Curve.Affine.Backend.t array\n -> with_public_evals Promise.t\n\n val verify : Verifier_index.t -> with_public_evals -> bool\n\n val batch_verify :\n Verifier_index.t array -> with_public_evals array -> bool Promise.t\n end\nend\n\nmodule Challenge_polynomial = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('g, 'fq) t = { challenges : 'fq array; commitment : 'g }\n [@@deriving version, bin_io, sexp, compare, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Make (Inputs : Inputs_intf) = struct\n open Inputs\n module Backend = Backend\n module Fq = Scalar_field\n module G = Curve\n\n module Challenge_polynomial = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( G.Affine.Stable.V1.t\n , Fq.Stable.V1.t )\n Challenge_polynomial.Stable.V1.t\n [@@deriving sexp, compare, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n type ('g, 'fq) t_ = ('g, 'fq) Challenge_polynomial.t =\n { challenges : 'fq array; commitment : 'g }\n end\n\n type message = Challenge_polynomial.t list\n\n let hash_fold_array f s x = hash_fold_list f s (Array.to_list x)\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n module T = struct\n type t =\n ( G.Affine.Stable.V1.t\n , Fq.Stable.V1.t\n , Fq.Stable.V1.t array )\n Pickles_types.Plonk_types.Proof.Stable.V2.t\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let id = \"plong_dlog_proof_\" ^ Inputs.id\n\n type 'a creator =\n messages:G.Affine.t Pickles_types.Plonk_types.Messages.Stable.V2.t\n -> openings:\n ( G.Affine.t\n , Fq.t\n , Fq.t array )\n Pickles_types.Plonk_types.Openings.Stable.V2.t\n -> 'a\n\n let map_creator c ~f ~messages ~openings = f (c ~messages ~openings)\n\n let create ~messages ~openings =\n let open Pickles_types.Plonk_types.Proof.Stable.Latest in\n { messages; openings }\n end\n\n include T\n\n include (\n Allocation_functor.Make.Full\n (T) :\n Allocation_functor.Intf.Output.Full_intf\n with type t := t\n and type 'a creator := 'a creator )\n\n let to_latest = Fn.id\n end\n end]\n\n module T = struct\n type t = (G.Affine.t, Fq.t, Fq.t array) Pickles_types.Plonk_types.Proof.t\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let id = \"plong_dlog_proof_\" ^ Inputs.id\n\n type 'a creator =\n messages:G.Affine.t Pickles_types.Plonk_types.Messages.t\n -> openings:\n (G.Affine.t, Fq.t, Fq.t array) Pickles_types.Plonk_types.Openings.t\n -> 'a\n\n let map_creator c ~f ~messages ~openings = f (c ~messages ~openings)\n\n let create ~messages ~openings =\n let open Pickles_types.Plonk_types.Proof in\n { messages; openings }\n end\n\n include T\n\n include (\n struct\n include Allocation_functor.Make.Basic (T)\n include Allocation_functor.Make.Partial.Sexp (T)\n include Allocation_functor.Make.Partial.Yojson (T)\n end :\n sig\n include\n Allocation_functor.Intf.Output.Basic_intf\n with type t := t\n and type 'a creator := 'a creator\n\n include\n Allocation_functor.Intf.Output.Sexp_intf\n with type t := t\n and type 'a creator := 'a creator\n\n include\n Allocation_functor.Intf.Output.Yojson_intf\n with type t := t\n and type 'a creator := 'a creator\n end )\n\n type with_public_evals =\n { proof : t\n ; public_evals : (Scalar_field.t array * Scalar_field.t array) option\n }\n\n let g t f = G.Affine.of_backend (f t)\n\n let fq_array_to_vec arr =\n let vec = Fq.Vector.create () in\n Array.iter arr ~f:(fun fe -> Fq.Vector.emplace_back vec fe) ;\n vec\n\n (** Note that this function will panic if any of the points are points at\n infinity *)\n let opening_proof_of_backend_exn (t : Opening_proof_backend.t) =\n let g (x : G.Affine.Backend.t) : G.Affine.t =\n G.Affine.of_backend x |> Pickles_types.Or_infinity.finite_exn\n in\n let gpair ((g1, g2) : G.Affine.Backend.t * G.Affine.Backend.t) :\n G.Affine.t * G.Affine.t =\n (g g1, g g2)\n in\n { Pickles_types.Plonk_types.Openings.Bulletproof.lr =\n Array.map ~f:gpair t.lr\n ; z_1 = t.z1\n ; z_2 = t.z2\n ; delta = g t.delta\n ; challenge_polynomial_commitment = g t.sg\n }\n\n let eval_of_backend\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } :\n Evaluations_backend.t ) : _ Pickles_types.Plonk_types.Evals.t =\n { w = tuple15_to_vec w\n ; coefficients = tuple15_to_vec coefficients\n ; z\n ; s = tuple6_to_vec s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted =\n Vector.init Nat.N5.n ~f:(fun i ->\n Option.try_with_join (fun () -> lookup_sorted.(i)) )\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n }\n\n let evals_to_tuple ({ zeta; zeta_omega } : _ Kimchi_types.point_evaluations) =\n (zeta, zeta_omega)\n\n let of_backend (t : Backend.t) : t =\n let proof = opening_proof_of_backend_exn t.proof in\n let evals =\n Plonk_types.Evals.map ~f:evals_to_tuple (eval_of_backend t.evals)\n in\n let wo x : Inputs.Curve.Affine.t array =\n match Poly_comm.of_backend_without_degree_bound x with\n | `Without_degree_bound gs ->\n gs\n | _ ->\n assert false\n in\n let w_comm =\n tuple15_to_vec t.commitments.w_comm |> Pickles_types.Vector.map ~f:wo\n in\n create\n ~messages:\n { w_comm\n ; z_comm = wo t.commitments.z_comm\n ; t_comm = wo t.commitments.t_comm\n ; lookup =\n Option.map t.commitments.lookup\n ~f:(fun l : _ Pickles_types.Plonk_types.Messages.Lookup.t ->\n { sorted =\n Vector.init\n Pickles_types.Plonk_types.Lookup_sorted_minus_1.n\n ~f:(fun i -> wo l.sorted.(i))\n ; sorted_5th_column =\n (* TODO: This is ugly and error-prone *)\n Option.try_with (fun () ->\n wo\n l.sorted.(Nat.to_int\n Pickles_types.Plonk_types\n .Lookup_sorted_minus_1\n .n) )\n ; aggreg = wo l.aggreg\n ; runtime = Option.map ~f:wo l.runtime\n } )\n }\n ~openings:{ proof; evals; ft_eval1 = t.ft_eval1 }\n\n let of_backend_with_public_evals (t : Backend.with_public_evals) :\n with_public_evals =\n { proof = of_backend t.proof\n ; public_evals = Option.map ~f:evals_to_tuple t.public_evals\n }\n\n let eval_to_backend\n { Pickles_types.Plonk_types.Evals.w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } : Evaluations_backend.t =\n { w = tuple15_of_vec w\n ; coefficients = tuple15_of_vec coefficients\n ; z\n ; s = tuple6_of_vec s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted = Vector.to_array lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n }\n\n let vec_to_array (type t elt)\n (module V : Snarky_intf.Vector.S with type t = t and type elt = elt)\n (v : t) =\n Array.init (V.length v) ~f:(V.get v)\n\n let evals_of_tuple (zeta, zeta_omega) : _ Kimchi_types.point_evaluations =\n { zeta; zeta_omega }\n\n let to_backend' (chal_polys : Challenge_polynomial.t list) primary_input\n ({ messages = { w_comm; z_comm; t_comm; lookup }\n ; openings =\n { proof = { lr; z_1; z_2; delta; challenge_polynomial_commitment }\n ; evals\n ; ft_eval1\n }\n } :\n t ) : Backend.t =\n let g x = G.Affine.to_backend (Pickles_types.Or_infinity.Finite x) in\n let pcwo t = Poly_comm.to_backend (`Without_degree_bound t) in\n let lr = Array.map lr ~f:(fun (x, y) -> (g x, g y)) in\n { commitments =\n { w_comm = tuple15_of_vec (Pickles_types.Vector.map ~f:pcwo w_comm)\n ; z_comm = pcwo z_comm\n ; t_comm = pcwo t_comm\n ; lookup =\n Option.map lookup ~f:(fun t : _ Kimchi_types.lookup_commitments ->\n { sorted =\n Array.map ~f:pcwo\n (Array.append (Vector.to_array t.sorted)\n (Option.to_array t.sorted_5th_column) )\n ; aggreg = pcwo t.aggreg\n ; runtime = Option.map ~f:pcwo t.runtime\n } )\n }\n ; proof =\n { lr\n ; delta = g delta\n ; z1 = z_1\n ; z2 = z_2\n ; sg = g challenge_polynomial_commitment\n }\n ; evals = eval_to_backend (Plonk_types.Evals.map ~f:evals_of_tuple evals)\n ; ft_eval1\n ; public = primary_input\n ; prev_challenges =\n Array.of_list_map chal_polys\n ~f:(fun { Challenge_polynomial.commitment = x, y; challenges } ->\n { Kimchi_types.chals = challenges\n ; comm =\n { Kimchi_types.shifted = None\n ; unshifted = [| Kimchi_types.Finite (x, y) |]\n }\n } )\n }\n\n let to_backend chal_polys primary_input t =\n to_backend' chal_polys (List.to_array primary_input) t\n\n let to_backend_with_public_evals' (chal_polys : Challenge_polynomial.t list)\n primary_input ({ proof; public_evals } : with_public_evals) :\n Backend.with_public_evals =\n { proof = to_backend' chal_polys primary_input proof\n ; public_evals = Option.map ~f:evals_of_tuple public_evals\n }\n\n let to_backend_with_public_evals chal_polys primary_input t =\n to_backend_with_public_evals' chal_polys (List.to_array primary_input) t\n\n let create ?message pk ~primary ~auxiliary =\n let chal_polys =\n match (message : message option) with Some s -> s | None -> []\n in\n let challenges =\n List.map chal_polys ~f:(fun { Challenge_polynomial.challenges; _ } ->\n challenges )\n |> Array.concat\n in\n let commitments =\n Array.of_list_map chal_polys\n ~f:(fun { Challenge_polynomial.commitment; _ } ->\n G.Affine.to_backend (Finite commitment) )\n in\n let res =\n Backend.create pk ~primary ~auxiliary ~prev_chals:challenges\n ~prev_comms:commitments\n in\n of_backend_with_public_evals res\n\n let create_async ?message pk ~primary ~auxiliary =\n let chal_polys =\n match (message : message option) with Some s -> s | None -> []\n in\n let challenges =\n List.map chal_polys ~f:(fun { Challenge_polynomial.challenges; _ } ->\n challenges )\n |> Array.concat\n in\n let commitments =\n Array.of_list_map chal_polys\n ~f:(fun { Challenge_polynomial.commitment; _ } ->\n G.Affine.to_backend (Finite commitment) )\n in\n let%map.Promise res =\n Backend.create_async pk ~primary ~auxiliary ~prev_chals:challenges\n ~prev_comms:commitments\n in\n of_backend_with_public_evals res\n\n let batch_verify' (conv : 'a -> Fq.t array)\n (ts : (Verifier_index.t * with_public_evals * 'a * message option) list) =\n let logger = Internal_tracing_context_logger.get () in\n [%log internal] \"Batch_verify_backend_convert_inputs\" ;\n let vks_and_v =\n Array.of_list_map ts ~f:(fun (vk, t, xs, m) ->\n let p =\n to_backend_with_public_evals'\n (Option.value ~default:[] m)\n (conv xs) t\n in\n (vk, p) )\n in\n [%log internal] \"Batch_verify_backend_convert_inputs_done\" ;\n [%log internal] \"Batch_verify_backend\" ;\n let%map.Promise result =\n Backend.batch_verify\n (Array.map ~f:fst vks_and_v)\n (Array.map ~f:snd vks_and_v)\n in\n [%log internal] \"Batch_verify_backend_done\" ;\n result\n\n let batch_verify = batch_verify' (fun xs -> List.to_array xs)\n\n let verify ?message t vk xs : bool =\n Backend.verify vk\n (to_backend_with_public_evals'\n (Option.value ~default:[] message)\n (vec_to_array (module Scalar_field.Vector) xs)\n t )\nend\n","open Core_kernel\n\nmodule type Bindings = sig\n type t\n\n val num_limbs : unit -> int\n\n val bytes_per_limb : unit -> int\n\n val compare : t -> t -> int\n\n val div : t -> t -> t\n\n val test_bit : t -> int -> bool\n\n val print : t -> unit\n\n val to_string : t -> string\n\n val of_numeral : string -> int -> int -> t\n\n val of_decimal_string : string -> t\n\n val to_bytes : t -> Bytes.t\n\n val of_bytes : Bytes.t -> t\nend\n\nmodule type Intf = sig\n type t [@@deriving bin_io, sexp, compare]\n\n include Bindings with type t := t\n\n val num_limbs : int\n\n val bytes_per_limb : int\n\n val length_in_bytes : int\n\n val to_hex : t -> string\n\n val to_hex_string : t -> string\n\n val of_hex_string : ?reverse:bool -> string -> t\n\n val of_numeral : string -> base:int -> t\nend\n\nmodule Make\n (B : Bindings) (M : sig\n val length_in_bytes : int\n end) : Intf with type t = B.t = struct\n include B\n\n let num_limbs = num_limbs ()\n\n let bytes_per_limb = bytes_per_limb ()\n\n let length_in_bytes = num_limbs * bytes_per_limb\n\n let to_hex t =\n let data = to_bytes t in\n String.uppercase (Hex.encode ~reverse:true (Bytes.to_string data))\n\n let to_hex_string t = \"0x\" ^ to_hex t\n\n let sexp_of_t t = to_hex_string t |> Sexp.of_string\n\n let of_hex_string ?(reverse = true) s =\n assert (Char.equal s.[0] '0' && Char.equal s.[1] 'x') ;\n let s = String.drop_prefix s 2 in\n Option.try_with (fun () -> Hex.decode ~init:Bytes.init ~reverse s)\n |> Option.value_exn ~here:[%here]\n |> of_bytes\n\n let%test_unit \"hex test\" =\n let bytes =\n String.init length_in_bytes ~f:(fun _ -> Char.of_int_exn (Random.int 255))\n in\n let h = \"0x\" ^ Hex.encode bytes in\n [%test_eq: string] h (String.lowercase (to_hex_string (of_hex_string h)))\n\n let t_of_sexp s = of_hex_string (String.t_of_sexp s)\n\n include Bin_prot.Utils.Of_minimal (struct\n type nonrec t = t\n\n (* increment if serialization changes *)\n let version = 1\n\n let bin_shape_t =\n Bin_prot.Shape.basetype\n (Bin_prot.Shape.Uuid.of_string\n (sprintf \"kimchi_backend_bigint_%d_V%d\" M.length_in_bytes version) )\n []\n\n let __bin_read_t__ _buf ~pos_ref _vint =\n Bin_prot.Common.raise_variant_wrong_type \"Bigint.t\" !pos_ref\n\n let bin_size_t _ = length_in_bytes\n\n let bin_write_t buf ~pos t =\n let bytes = to_bytes t in\n let len = length_in_bytes in\n Bigstring.From_bytes.blit ~src:bytes ~src_pos:0 ~len:length_in_bytes\n ~dst:buf ~dst_pos:pos ;\n pos + len\n\n let bin_read_t buf ~pos_ref =\n let remaining_bytes = Bigstring.length buf - !pos_ref in\n let len = length_in_bytes in\n if remaining_bytes < len then\n failwithf \"Bigint.bin_read_t: Expected %d bytes, got %d\"\n M.length_in_bytes remaining_bytes () ;\n let bytes = Bigstring.To_bytes.sub ~pos:!pos_ref ~len buf in\n pos_ref := len + !pos_ref ;\n of_bytes bytes\n end)\n\n let of_numeral s ~base = of_numeral s (String.length s) base\nend\n","open Core_kernel\nmodule H_list = Snarky_backendless.H_list\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'a t =\n { xt : 'a\n ; yt : 'a\n ; xp : 'a\n ; yp : 'a\n ; n_acc : 'a\n ; xr : 'a\n ; yr : 'a\n ; s1 : 'a\n ; s3 : 'a\n ; b1 : 'a\n ; b2 : 'a\n ; b3 : 'a\n ; b4 : 'a\n }\n [@@deriving sexp, fields, hlist]\n end\nend]\n\nlet map { xt; yt; xp; yp; n_acc; xr; yr; s1; s3; b1; b2; b3; b4 } ~f =\n { xt = f xt\n ; yt = f yt\n ; xp = f xp\n ; yp = f yp\n ; n_acc = f n_acc\n ; xr = f xr\n ; yr = f yr\n ; s1 = f s1\n ; s3 = f s3\n ; b1 = f b1\n ; b2 = f b2\n ; b3 = f b3\n ; b4 = f b4\n }\n\nlet map2 t1 t2 ~f =\n { xt = f t1.xt t2.xt\n ; yt = f t1.yt t2.yt\n ; xp = f t1.xp t2.xp\n ; yp = f t1.yp t2.yp\n ; n_acc = f t1.n_acc t2.n_acc\n ; xr = f t1.xr t2.xr\n ; yr = f t1.yr t2.yr\n ; s1 = f t1.s1 t2.s1\n ; s3 = f t1.s3 t2.s3\n ; b1 = f t1.b1 t2.b1\n ; b2 = f t1.b2 t2.b2\n ; b3 = f t1.b3 t2.b3\n ; b4 = f t1.b4 t2.b4\n }\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'a t =\n { n0 : 'a\n ; n8 : 'a\n ; a0 : 'a\n ; b0 : 'a\n ; a8 : 'a\n ; b8 : 'a\n ; x0 : 'a\n ; x1 : 'a\n ; x2 : 'a\n ; x3 : 'a\n ; x4 : 'a\n ; x5 : 'a\n ; x6 : 'a\n ; x7 : 'a\n }\n [@@deriving sexp, fields, hlist]\n end\nend]\n\nlet map { n0; n8; a0; b0; a8; b8; x0; x1; x2; x3; x4; x5; x6; x7 } ~f =\n { n0 = f n0\n ; n8 = f n8\n ; a0 = f a0\n ; b0 = f b0\n ; a8 = f a8\n ; b8 = f b8\n ; x0 = f x0\n ; x1 = f x1\n ; x2 = f x2\n ; x3 = f x3\n ; x4 = f x4\n ; x5 = f x5\n ; x6 = f x6\n ; x7 = f x7\n }\n\nlet map2 t1 t2 ~f =\n { n0 = f t1.n0 t2.n0\n ; n8 = f t1.n8 t2.n8\n ; a0 = f t1.a0 t2.a0\n ; b0 = f t1.b0 t2.b0\n ; a8 = f t1.a8 t2.a8\n ; b8 = f t1.b8 t2.b8\n ; x0 = f t1.x0 t2.x0\n ; x1 = f t1.x1 t2.x1\n ; x2 = f t1.x2 t2.x2\n ; x3 = f t1.x3 t2.x3\n ; x4 = f t1.x4 t2.x4\n ; x5 = f t1.x5 t2.x5\n ; x6 = f t1.x6 t2.x6\n ; x7 = f t1.x7 t2.x7\n }\n","open Intf\nopen Core_kernel\nmodule Bignum_bigint = Snarky_backendless.Backend_extended.Bignum_bigint\n\nmodule type Input_intf = sig\n type t\n\n module Bigint : Bigint.Intf\n\n val size : unit -> Bigint.t\n\n val size_in_bits : unit -> int\n\n val to_bigint : t -> Bigint.t\n\n val of_bigint : Bigint.t -> t\n\n val of_int : int -> t\n\n val domain_generator : int -> t\n\n val add : t -> t -> t\n\n val sub : t -> t -> t\n\n val mul : t -> t -> t\n\n val div : t -> t -> t\n\n val inv : t -> t option\n\n val negate : t -> t\n\n val square : t -> t\n\n val sqrt : t -> t option\n\n val is_square : t -> bool\n\n val equal : t -> t -> bool\n\n val print : t -> unit\n\n val to_string : t -> string\n\n val of_string : string -> t\n\n val random : unit -> t\n\n val rng : int -> t\n\n val two_adic_root_of_unity : unit -> t\n\n val mut_add : t -> t -> unit\n\n val mut_mul : t -> t -> unit\n\n val mut_square : t -> unit\n\n val mut_sub : t -> t -> unit\n\n val copy : t -> t -> unit\n\n val to_bytes : t -> bytes\n\n val of_bytes : bytes -> t\n\n val domain_generator : int -> t\n\n module Vector : Snarky_intf.Vector.S with type elt = t\nend\n\nmodule type S = sig\n type t [@@deriving sexp, compare, yojson, bin_io, hash]\n\n include Input_intf with type t := t\n\n val size : Bigint.t\n\n val domain_generator : log2_size:int -> t\n\n val one : t\n\n val zero : t\n\n val inv : t -> t\n\n val sqrt : t -> t\n\n val size_in_bits : int\n\n val to_bits : t -> bool list\n\n val of_bits : bool list -> t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n\n val ( / ) : t -> t -> t\n\n module Mutable : sig\n val add : t -> other:t -> unit\n\n val mul : t -> other:t -> unit\n\n val square : t -> unit\n\n val sub : t -> other:t -> unit\n\n val copy : over:t -> t -> unit\n end\n\n val ( += ) : t -> t -> unit\n\n val ( *= ) : t -> t -> unit\n\n val ( -= ) : t -> t -> unit\nend\n\nmodule type S_with_version = sig\n [%%versioned:\n module Stable : sig\n [@@@no_toplevel_latest_type]\n\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t [@@deriving version, sexp, bin_io, compare, yojson, hash, equal]\n end\n end]\n\n include S with type t = Stable.Latest.t\nend\n\nmodule Make (F : Input_intf) :\n S_with_version\n with type Stable.V1.t = F.t\n and module Bigint = F.Bigint\n and module Vector = F.Vector = struct\n include F\n\n let size = size ()\n\n let size_in_bits = size_in_bits ()\n\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = (F.t[@version_asserted]) [@@deriving version]\n\n let to_latest = Fn.id\n\n include\n Binable.Of_binable\n (Bigint)\n (struct\n type nonrec t = t\n\n let to_binable = to_bigint\n\n let of_binable = of_bigint\n end)\n\n include\n Sexpable.Of_sexpable\n (Bigint)\n (struct\n type nonrec t = t\n\n let to_sexpable = to_bigint\n\n let of_sexpable = of_bigint\n end)\n\n let to_bignum_bigint n =\n let rec go i two_to_the_i acc =\n if Int.equal i size_in_bits then acc\n else\n let acc' =\n if Bigint.test_bit n i then Bignum_bigint.(acc + two_to_the_i)\n else acc\n in\n go (i + 1) Bignum_bigint.(two_to_the_i + two_to_the_i) acc'\n in\n go 0 Bignum_bigint.one Bignum_bigint.zero\n\n let hash_fold_t s x =\n Bignum_bigint.hash_fold_t s (to_bignum_bigint (to_bigint x))\n\n let hash = Hash.of_fold hash_fold_t\n\n let compare t1 t2 = Bigint.compare (to_bigint t1) (to_bigint t2)\n\n let equal = equal\n\n let to_yojson t : Yojson.Safe.t =\n `String (Bigint.to_hex_string (to_bigint t))\n\n let of_yojson j =\n match j with\n | `String h ->\n Ok (of_bigint (Bigint.of_hex_string h))\n | _ ->\n Error \"expected hex string\"\n end\n end]\n\n include (\n Stable.Latest : module type of Stable.Latest with type t := Stable.Latest.t )\n\n let domain_generator ~log2_size = domain_generator log2_size\n\n let one = of_int 1\n\n let zero = of_int 0\n\n (* TODO: Improve snarky interface so these aren't necessary.. *)\n let inv x = Option.value (inv x) ~default:zero\n\n let sqrt x = Option.value (sqrt x) ~default:zero\n\n let to_bits t =\n (* Avoids allocation *)\n let n = F.to_bigint t in\n List.init size_in_bits ~f:(Bigint.test_bit n)\n\n let of_bits bs =\n List.fold (List.rev bs) ~init:zero ~f:(fun acc b ->\n let acc = add acc acc in\n if b then add acc one else acc )\n\n let%test_unit \"sexp round trip\" =\n let t = random () in\n assert (equal t (t_of_sexp (sexp_of_t t)))\n\n let%test_unit \"bin_io round trip\" =\n let t = random () in\n [%test_eq: Stable.Latest.t] t\n (Binable.of_string\n (module Stable.Latest)\n (Binable.to_string (module Stable.Latest) t) )\n\n let ( + ) = add\n\n let ( - ) = sub\n\n let ( * ) = mul\n\n let ( / ) = div\n\n module Mutable = struct\n let add t ~other = mut_add t other\n\n let mul t ~other = mut_mul t other\n\n let square = mut_square\n\n let sub t ~other = mut_sub t other\n\n let copy ~over t = copy over t\n end\n\n let op f t other = f t ~other\n\n let ( += ) = op Mutable.add\n\n let ( *= ) = op Mutable.mul\n\n let ( -= ) = op Mutable.sub\n\n let%test \"of_bits to_bits\" =\n let x = random () in\n equal x (of_bits (to_bits x))\n\n let%test_unit \"to_bits of_bits\" =\n Quickcheck.test\n (Quickcheck.Generator.list_with_length\n Int.(size_in_bits - 1)\n Bool.quickcheck_generator )\n ~f:(fun bs ->\n [%test_eq: bool list] (bs @ [ false ]) (to_bits (of_bits bs)) )\nend\n","(* TODO: remove these openings *)\nopen Sponge\nopen Unsigned.Size_t\n\n(* TODO: open Core here instead of opening it multiple times below *)\n\nmodule Kimchi_gate_type = struct\n (* Alias to allow deriving sexp *)\n type t = Kimchi_types.gate_type =\n | Zero\n | Generic\n | Poseidon\n | CompleteAdd\n | VarBaseMul\n | EndoMul\n | EndoMulScalar\n | Lookup\n | CairoClaim\n | CairoInstruction\n | CairoFlags\n | CairoTransition\n | RangeCheck0\n | RangeCheck1\n | ForeignFieldAdd\n | ForeignFieldMul\n | Xor16\n | Rot64\n [@@deriving sexp]\nend\n\n(** A gate interface, parameterized by a field. *)\nmodule type Gate_vector_intf = sig\n open Unsigned\n\n type field\n\n type t\n\n val create : unit -> t\n\n val add : t -> field Kimchi_types.circuit_gate -> unit\n\n val get : t -> int -> field Kimchi_types.circuit_gate\n\n val len : t -> int\n\n val digest : int -> t -> bytes\n\n val to_json : int -> t -> string\nend\n\n(** A row indexing in a constraint system. *)\nmodule Row = struct\n open Core_kernel\n\n (** Either a public input row,\n or a non-public input row that starts at index 0.\n *)\n type t = Public_input of int | After_public_input of int\n [@@deriving hash, sexp, compare]\n\n let to_absolute ~public_input_size = function\n | Public_input i ->\n i\n | After_public_input i ->\n (* the first i rows are public-input rows *)\n i + public_input_size\nend\n\n(* TODO: rename module Position to Permutation/Wiring? *)\n\n(** A position represents the position of a cell in the constraint system. *)\nmodule Position = struct\n open Core_kernel\n\n (** A position is a row and a column. *)\n type 'row t = { row : 'row; col : int } [@@deriving hash, sexp, compare]\n\n (** Generates a full row of positions that each points to itself. *)\n let create_cols (row : 'row) : _ t array =\n Array.init Constants.permutation_cols ~f:(fun i -> { row; col = i })\n\n (** Given a number of columns,\n append enough column wires to get an entire row.\n The wire appended will simply point to themselves,\n so as to not take part in the permutation argument.\n *)\n let append_cols (row : 'row) (cols : _ t array) : _ t array =\n let padding_offset = Array.length cols in\n assert (padding_offset <= Constants.permutation_cols) ;\n let padding_len = Constants.permutation_cols - padding_offset in\n let padding =\n Array.init padding_len ~f:(fun i -> { row; col = i + padding_offset })\n in\n Array.append cols padding\n\n (** Converts an array of [Constants.columns] to [Constants.permutation_cols].\n This is useful to truncate arrays of cells to the ones that only matter for the permutation argument.\n *)\n let cols_to_perms cols = Array.slice cols 0 Constants.permutation_cols\n\n (** Converts a [Position.t] into the Rust-compatible type [Kimchi_types.wire].\n *)\n let to_rust_wire { row; col } : Kimchi_types.wire = { row; col }\nend\n\n(** A gate. *)\nmodule Gate_spec = struct\n open Core_kernel\n\n (* TODO: split kind/coeffs from row/wired_to *)\n\n (** A gate/row/constraint consists of a type (kind), a row, the other cells its columns/cells are connected to (wired_to), and the selector polynomial associated with the gate. *)\n type ('row, 'f) t =\n { kind : Kimchi_gate_type.t\n ; wired_to : 'row Position.t array\n ; coeffs : 'f array\n }\n [@@deriving sexp_of]\n\n (** Applies a function [f] to the [row] of [t] and all the rows of its [wired_to]. *)\n let map_rows (t : (_, _) t) ~f : (_, _) t =\n (* { wire with row = f row } *)\n let wired_to =\n Array.map\n ~f:(fun (pos : _ Position.t) -> { pos with row = f pos.row })\n t.wired_to\n in\n { t with wired_to }\n\n (* TODO: just send the array to Rust directly *)\n let to_rust_gate { kind; wired_to; coeffs } : _ Kimchi_types.circuit_gate =\n let typ = kind in\n let wired_to = Array.map ~f:Position.to_rust_wire wired_to in\n let wires =\n ( wired_to.(0)\n , wired_to.(1)\n , wired_to.(2)\n , wired_to.(3)\n , wired_to.(4)\n , wired_to.(5)\n , wired_to.(6) )\n in\n { typ; wires; coeffs }\nend\n\n(** The PLONK constraints. *)\nmodule Plonk_constraint = struct\n open Core_kernel\n\n (** A PLONK constraint (or gate) can be [Basic], [Poseidon], [EC_add_complete], [EC_scale], [EC_endoscale], [EC_endoscalar], [RangeCheck0], [RangeCheck1], [Xor] *)\n module T = struct\n type ('v, 'f) t =\n | Basic of { l : 'f * 'v; r : 'f * 'v; o : 'f * 'v; m : 'f; c : 'f }\n (** the Poseidon state is an array of states (and states are arrays of size 3). *)\n | Poseidon of { state : 'v array array }\n | EC_add_complete of\n { p1 : 'v * 'v\n ; p2 : 'v * 'v\n ; p3 : 'v * 'v\n ; inf : 'v\n ; same_x : 'v\n ; slope : 'v\n ; inf_z : 'v\n ; x21_inv : 'v\n }\n | EC_scale of { state : 'v Scale_round.t array }\n | EC_endoscale of\n { state : 'v Endoscale_round.t array; xs : 'v; ys : 'v; n_acc : 'v }\n | EC_endoscalar of { state : 'v Endoscale_scalar_round.t array }\n | Lookup of\n { w0 : 'v; w1 : 'v; w2 : 'v; w3 : 'v; w4 : 'v; w5 : 'v; w6 : 'v }\n | RangeCheck0 of\n { v0 : 'v (* Value to constrain to 88-bits *)\n ; v0p0 : 'v (* MSBs *)\n ; v0p1 : 'v (* vpX are 12-bit plookup chunks *)\n ; v0p2 : 'v\n ; v0p3 : 'v\n ; v0p4 : 'v\n ; v0p5 : 'v\n ; v0c0 : 'v (* vcX are 2-bit crumbs *)\n ; v0c1 : 'v\n ; v0c2 : 'v\n ; v0c3 : 'v\n ; v0c4 : 'v\n ; v0c5 : 'v\n ; v0c6 : 'v\n ; v0c7 : 'v (* LSBs *)\n ; (* Coefficients *)\n compact : 'f\n (* Limbs mode coefficient: 0 (standard 3-limb) or 1 (compact 2-limb) *)\n }\n | RangeCheck1 of\n { (* Current row *)\n v2 : 'v (* Value to constrain to 88-bits *)\n ; v12 : 'v (* Optional value used in compact 2-limb mode *)\n ; v2c0 : 'v (* MSBs, 2-bit crumb *)\n ; v2p0 : 'v (* vpX are 12-bit plookup chunks *)\n ; v2p1 : 'v\n ; v2p2 : 'v\n ; v2p3 : 'v\n ; v2c1 : 'v (* vcX are 2-bit crumbs *)\n ; v2c2 : 'v\n ; v2c3 : 'v\n ; v2c4 : 'v\n ; v2c5 : 'v\n ; v2c6 : 'v\n ; v2c7 : 'v\n ; v2c8 : 'v (* LSBs *)\n ; (* Next row *) v2c9 : 'v\n ; v2c10 : 'v\n ; v2c11 : 'v\n ; v0p0 : 'v\n ; v0p1 : 'v\n ; v1p0 : 'v\n ; v1p1 : 'v\n ; v2c12 : 'v\n ; v2c13 : 'v\n ; v2c14 : 'v\n ; v2c15 : 'v\n ; v2c16 : 'v\n ; v2c17 : 'v\n ; v2c18 : 'v\n ; v2c19 : 'v\n }\n | Xor of\n { in1 : 'v\n ; in2 : 'v\n ; out : 'v\n ; in1_0 : 'v\n ; in1_1 : 'v\n ; in1_2 : 'v\n ; in1_3 : 'v\n ; in2_0 : 'v\n ; in2_1 : 'v\n ; in2_2 : 'v\n ; in2_3 : 'v\n ; out_0 : 'v\n ; out_1 : 'v\n ; out_2 : 'v\n ; out_3 : 'v\n }\n | ForeignFieldAdd of\n { left_input_lo : 'v\n ; left_input_mi : 'v\n ; left_input_hi : 'v\n ; right_input_lo : 'v\n ; right_input_mi : 'v\n ; right_input_hi : 'v\n ; field_overflow : 'v\n ; carry : 'v\n ; (* Coefficients *) foreign_field_modulus0 : 'f\n ; foreign_field_modulus1 : 'f\n ; foreign_field_modulus2 : 'f\n ; sign : 'f\n }\n | ForeignFieldMul of\n { left_input0 : 'v\n ; left_input1 : 'v\n ; left_input2 : 'v\n ; right_input0 : 'v\n ; right_input1 : 'v\n ; right_input2 : 'v\n ; remainder01 : 'v\n ; remainder2 : 'v\n ; quotient0 : 'v\n ; quotient1 : 'v\n ; quotient2 : 'v\n ; quotient_hi_bound : 'v\n ; product1_lo : 'v\n ; product1_hi_0 : 'v\n ; product1_hi_1 : 'v\n ; carry0 : 'v\n ; carry1_0 : 'v\n ; carry1_12 : 'v\n ; carry1_24 : 'v\n ; carry1_36 : 'v\n ; carry1_48 : 'v\n ; carry1_60 : 'v\n ; carry1_72 : 'v\n ; carry1_84 : 'v\n ; carry1_86 : 'v\n ; carry1_88 : 'v\n ; carry1_90 : 'v\n ; (* Coefficients *) foreign_field_modulus2 : 'f\n ; neg_foreign_field_modulus0 : 'f\n ; neg_foreign_field_modulus1 : 'f\n ; neg_foreign_field_modulus2 : 'f\n }\n | Rot64 of\n { (* Current row *)\n word : 'v\n ; rotated : 'v\n ; excess : 'v\n ; bound_limb0 : 'v\n ; bound_limb1 : 'v\n ; bound_limb2 : 'v\n ; bound_limb3 : 'v\n ; bound_crumb0 : 'v\n ; bound_crumb1 : 'v\n ; bound_crumb2 : 'v\n ; bound_crumb3 : 'v\n ; bound_crumb4 : 'v\n ; bound_crumb5 : 'v\n ; bound_crumb6 : 'v\n ; bound_crumb7 : 'v\n ; (* Coefficients *) two_to_rot : 'f (* Rotation scalar 2^rot *)\n }\n | AddFixedLookupTable of { id : int32; data : 'f array array }\n | AddRuntimeTableCfg of { id : int32; first_column : 'f array }\n | Raw of\n { kind : Kimchi_gate_type.t; values : 'v array; coeffs : 'f array }\n [@@deriving sexp]\n\n (** map t *)\n let map (type a b f) (t : (a, f) t) ~(f : a -> b) =\n let fp (x, y) = (f x, f y) in\n match t with\n | Basic { l; r; o; m; c } ->\n let p (x, y) = (x, f y) in\n Basic { l = p l; r = p r; o = p o; m; c }\n | Poseidon { state } ->\n Poseidon { state = Array.map ~f:(fun x -> Array.map ~f x) state }\n | EC_add_complete { p1; p2; p3; inf; same_x; slope; inf_z; x21_inv } ->\n EC_add_complete\n { p1 = fp p1\n ; p2 = fp p2\n ; p3 = fp p3\n ; inf = f inf\n ; same_x = f same_x\n ; slope = f slope\n ; inf_z = f inf_z\n ; x21_inv = f x21_inv\n }\n | EC_scale { state } ->\n EC_scale\n { state = Array.map ~f:(fun x -> Scale_round.map ~f x) state }\n | EC_endoscale { state; xs; ys; n_acc } ->\n EC_endoscale\n { state = Array.map ~f:(fun x -> Endoscale_round.map ~f x) state\n ; xs = f xs\n ; ys = f ys\n ; n_acc = f n_acc\n }\n | EC_endoscalar { state } ->\n EC_endoscalar\n { state =\n Array.map ~f:(fun x -> Endoscale_scalar_round.map ~f x) state\n }\n | Lookup { w0; w1; w2; w3; w4; w5; w6 } ->\n Lookup\n { w0 = f w0\n ; w1 = f w1\n ; w2 = f w2\n ; w3 = f w3\n ; w4 = f w4\n ; w5 = f w5\n ; w6 = f w6\n }\n | RangeCheck0\n { v0\n ; v0p0\n ; v0p1\n ; v0p2\n ; v0p3\n ; v0p4\n ; v0p5\n ; v0c0\n ; v0c1\n ; v0c2\n ; v0c3\n ; v0c4\n ; v0c5\n ; v0c6\n ; v0c7\n ; compact\n } ->\n RangeCheck0\n { v0 = f v0\n ; v0p0 = f v0p0\n ; v0p1 = f v0p1\n ; v0p2 = f v0p2\n ; v0p3 = f v0p3\n ; v0p4 = f v0p4\n ; v0p5 = f v0p5\n ; v0c0 = f v0c0\n ; v0c1 = f v0c1\n ; v0c2 = f v0c2\n ; v0c3 = f v0c3\n ; v0c4 = f v0c4\n ; v0c5 = f v0c5\n ; v0c6 = f v0c6\n ; v0c7 = f v0c7\n ; compact\n }\n | RangeCheck1\n { (* Current row *) v2\n ; v12\n ; v2c0\n ; v2p0\n ; v2p1\n ; v2p2\n ; v2p3\n ; v2c1\n ; v2c2\n ; v2c3\n ; v2c4\n ; v2c5\n ; v2c6\n ; v2c7\n ; v2c8\n ; (* Next row *) v2c9\n ; v2c10\n ; v2c11\n ; v0p0\n ; v0p1\n ; v1p0\n ; v1p1\n ; v2c12\n ; v2c13\n ; v2c14\n ; v2c15\n ; v2c16\n ; v2c17\n ; v2c18\n ; v2c19\n } ->\n RangeCheck1\n { (* Current row *) v2 = f v2\n ; v12 = f v12\n ; v2c0 = f v2c0\n ; v2p0 = f v2p0\n ; v2p1 = f v2p1\n ; v2p2 = f v2p2\n ; v2p3 = f v2p3\n ; v2c1 = f v2c1\n ; v2c2 = f v2c2\n ; v2c3 = f v2c3\n ; v2c4 = f v2c4\n ; v2c5 = f v2c5\n ; v2c6 = f v2c6\n ; v2c7 = f v2c7\n ; v2c8 = f v2c8\n ; (* Next row *) v2c9 = f v2c9\n ; v2c10 = f v2c10\n ; v2c11 = f v2c11\n ; v0p0 = f v0p0\n ; v0p1 = f v0p1\n ; v1p0 = f v1p0\n ; v1p1 = f v1p1\n ; v2c12 = f v2c12\n ; v2c13 = f v2c13\n ; v2c14 = f v2c14\n ; v2c15 = f v2c15\n ; v2c16 = f v2c16\n ; v2c17 = f v2c17\n ; v2c18 = f v2c18\n ; v2c19 = f v2c19\n }\n | Xor\n { in1\n ; in2\n ; out\n ; in1_0\n ; in1_1\n ; in1_2\n ; in1_3\n ; in2_0\n ; in2_1\n ; in2_2\n ; in2_3\n ; out_0\n ; out_1\n ; out_2\n ; out_3\n } ->\n Xor\n { in1 = f in1\n ; in2 = f in2\n ; out = f out\n ; in1_0 = f in1_0\n ; in1_1 = f in1_1\n ; in1_2 = f in1_2\n ; in1_3 = f in1_3\n ; in2_0 = f in2_0\n ; in2_1 = f in2_1\n ; in2_2 = f in2_2\n ; in2_3 = f in2_3\n ; out_0 = f out_0\n ; out_1 = f out_1\n ; out_2 = f out_2\n ; out_3 = f out_3\n }\n | ForeignFieldAdd\n { left_input_lo\n ; left_input_mi\n ; left_input_hi\n ; right_input_lo\n ; right_input_mi\n ; right_input_hi\n ; field_overflow\n ; carry\n ; (* Coefficients *) foreign_field_modulus0\n ; foreign_field_modulus1\n ; foreign_field_modulus2\n ; sign\n } ->\n ForeignFieldAdd\n { left_input_lo = f left_input_lo\n ; left_input_mi = f left_input_mi\n ; left_input_hi = f left_input_hi\n ; right_input_lo = f right_input_lo\n ; right_input_mi = f right_input_mi\n ; right_input_hi = f right_input_hi\n ; field_overflow = f field_overflow\n ; carry = f carry\n ; (* Coefficients *) foreign_field_modulus0\n ; foreign_field_modulus1\n ; foreign_field_modulus2\n ; sign\n }\n | ForeignFieldMul\n { left_input0\n ; left_input1\n ; left_input2\n ; right_input0\n ; right_input1\n ; right_input2\n ; remainder01\n ; remainder2\n ; quotient0\n ; quotient1\n ; quotient2\n ; quotient_hi_bound\n ; product1_lo\n ; product1_hi_0\n ; product1_hi_1\n ; carry0\n ; carry1_0\n ; carry1_12\n ; carry1_24\n ; carry1_36\n ; carry1_48\n ; carry1_60\n ; carry1_72\n ; carry1_84\n ; carry1_86\n ; carry1_88\n ; carry1_90\n ; (* Coefficients *) foreign_field_modulus2\n ; neg_foreign_field_modulus0\n ; neg_foreign_field_modulus1\n ; neg_foreign_field_modulus2\n } ->\n ForeignFieldMul\n { left_input0 = f left_input0\n ; left_input1 = f left_input1\n ; left_input2 = f left_input2\n ; right_input0 = f right_input0\n ; right_input1 = f right_input1\n ; right_input2 = f right_input2\n ; remainder01 = f remainder01\n ; remainder2 = f remainder2\n ; quotient0 = f quotient0\n ; quotient1 = f quotient1\n ; quotient2 = f quotient2\n ; quotient_hi_bound = f quotient_hi_bound\n ; product1_lo = f product1_lo\n ; product1_hi_0 = f product1_hi_0\n ; product1_hi_1 = f product1_hi_1\n ; carry0 = f carry0\n ; carry1_0 = f carry1_0\n ; carry1_12 = f carry1_12\n ; carry1_24 = f carry1_24\n ; carry1_36 = f carry1_36\n ; carry1_48 = f carry1_48\n ; carry1_60 = f carry1_60\n ; carry1_72 = f carry1_72\n ; carry1_84 = f carry1_84\n ; carry1_86 = f carry1_86\n ; carry1_88 = f carry1_88\n ; carry1_90 = f carry1_90\n ; (* Coefficients *) foreign_field_modulus2\n ; neg_foreign_field_modulus0\n ; neg_foreign_field_modulus1\n ; neg_foreign_field_modulus2\n }\n | Rot64\n { (* Current row *) word\n ; rotated\n ; excess\n ; bound_limb0\n ; bound_limb1\n ; bound_limb2\n ; bound_limb3\n ; bound_crumb0\n ; bound_crumb1\n ; bound_crumb2\n ; bound_crumb3\n ; bound_crumb4\n ; bound_crumb5\n ; bound_crumb6\n ; bound_crumb7\n ; (* Coefficients *) two_to_rot\n } ->\n Rot64\n { word = f word\n ; rotated = f rotated\n ; excess = f excess\n ; bound_limb0 = f bound_limb0\n ; bound_limb1 = f bound_limb1\n ; bound_limb2 = f bound_limb2\n ; bound_limb3 = f bound_limb3\n ; bound_crumb0 = f bound_crumb0\n ; bound_crumb1 = f bound_crumb1\n ; bound_crumb2 = f bound_crumb2\n ; bound_crumb3 = f bound_crumb3\n ; bound_crumb4 = f bound_crumb4\n ; bound_crumb5 = f bound_crumb5\n ; bound_crumb6 = f bound_crumb6\n ; bound_crumb7 = f bound_crumb7\n ; (* Coefficients *) two_to_rot\n }\n | AddFixedLookupTable { id; data } ->\n (* TODO: see a possible better API -\n https://github.com/MinaProtocol/mina/issues/13984 *)\n AddFixedLookupTable { id; data }\n | AddRuntimeTableCfg { id; first_column } ->\n AddRuntimeTableCfg { id; first_column }\n | Raw { kind; values; coeffs } ->\n Raw { kind; values = Array.map ~f values; coeffs }\n\n (** [eval (module F) get_variable gate] checks that [gate]'s polynomial is\n satisfied by the assignments given by [get_variable].\n Warning: currently only implemented for the [Basic] gate.\n *)\n let eval (type v f)\n (module F : Snarky_backendless.Field_intf.S with type t = f)\n (eval_one : v -> f) (t : (v, f) t) =\n match t with\n (* cl * vl + cr * vr + co * vo + m * vl*vr + c = 0 *)\n | Basic { l = cl, vl; r = cr, vr; o = co, vo; m; c } ->\n let vl = eval_one vl in\n let vr = eval_one vr in\n let vo = eval_one vo in\n let open F in\n let res =\n List.reduce_exn ~f:add\n [ mul cl vl; mul cr vr; mul co vo; mul m (mul vl vr); c ]\n in\n if not (equal zero res) then (\n eprintf\n !\"%{sexp:t} * %{sexp:t}\\n\\\n + %{sexp:t} * %{sexp:t}\\n\\\n + %{sexp:t} * %{sexp:t}\\n\\\n + %{sexp:t} * %{sexp:t}\\n\\\n + %{sexp:t}\\n\\\n = %{sexp:t}%!\"\n cl vl cr vr co vo m (mul vl vr) c res ;\n false )\n else true\n | _ ->\n true\n end\n\n include T\n\n (* Adds our constraint enum to the list of constraints handled by Snarky. *)\n include Snarky_backendless.Constraint.Add_kind (T)\nend\n\nmodule Internal_var = Core_kernel.Unique_id.Int ()\n\nmodule V = struct\n open Core_kernel\n\n module T = struct\n (** Variables linking uses of the same data between different gates.\n\n Every internal variable is computable from a finite list of external\n variables and internal variables.\n Currently, in fact, every internal variable is a linear combination of\n external variables and previously generated internal variables.\n *)\n type t =\n | External of int\n (** An external variable (generated by snarky, via [exists]). *)\n | Internal of Internal_var.t\n (** An internal variable is generated to hold an intermediate value\n (e.g., in reducing linear combinations to single PLONK positions).\n *)\n [@@deriving compare, hash, sexp]\n end\n\n include T\n include Comparable.Make (T)\n include Hashable.Make (T)\nend\n\n(** Keeps track of a circuit (which is a list of gates)\n while it is being written.\n *)\ntype ('f, 'rust_gates) circuit =\n | Unfinalized_rev of (unit, 'f) Gate_spec.t list\n (** A circuit still being written. *)\n | Compiled of Core_kernel.Md5.t * 'rust_gates\n (** Once finalized, a circuit is represented as a digest\n and a list of gates that corresponds to the circuit.\n *)\n\ntype 'f fixed_lookup_tables =\n | Unfinalized_fixed_lookup_tables_rev of 'f Kimchi_types.lookup_table list\n | Compiled_fixed_lookup_tables of 'f Kimchi_types.lookup_table array\n\ntype 'f runtime_tables_cfg =\n | Unfinalized_runtime_tables_cfg_rev of 'f Kimchi_types.runtime_table_cfg list\n | Compiled_runtime_tables_cfg of 'f Kimchi_types.runtime_table_cfg array\n\n(** The constraint system. *)\ntype ('f, 'rust_gates) t =\n { (* Map of cells that share the same value (enforced by to the permutation). *)\n equivalence_classes : Row.t Position.t list V.Table.t\n ; (* How to compute each internal variable (as a linear combination of other variables). *)\n internal_vars : (('f * V.t) list * 'f option) Internal_var.Table.t\n ; (* The variables that hold each witness value for each row, in reverse order. *)\n mutable rows_rev : V.t option array list\n ; (* A circuit is described by a series of gates.\n A gate is finalized once [finalize_and_get_gates] is called.\n The finalized tag contains the digest of the circuit.\n *)\n mutable gates : ('f, 'rust_gates) circuit\n (* Witnesses values corresponding to each runtime lookups *)\n ; mutable runtime_lookups_rev : (V.t * (V.t * V.t)) list\n (* The user-provided lookup tables associated with this circuit. *)\n ; mutable fixed_lookup_tables : 'f fixed_lookup_tables\n (* The user-provided runtime table configurations associated with this\n circuit. *)\n ; mutable runtime_tables_cfg : 'f runtime_tables_cfg\n ; (* The row to use the next time we add a constraint. *)\n mutable next_row : int\n ; (* The size of the public input (which fills the first rows of our constraint system. *)\n public_input_size : int Core_kernel.Set_once.t\n ; (* The number of previous recursion challenges. *)\n prev_challenges : int Core_kernel.Set_once.t\n ; (* Whatever is not public input. *)\n mutable auxiliary_input_size : int\n ; (* Queue (of size 1) of generic gate. *)\n mutable pending_generic_gate :\n (V.t option * V.t option * V.t option * 'f array) option\n ; (* V.t's corresponding to constant values. We reuse them so we don't need to\n use a fresh generic constraint each time to create a constant.\n *)\n cached_constants : ('f, V.t) Core_kernel.Hashtbl.t\n (* The [equivalence_classes] field keeps track of the positions which must be\n enforced to be equivalent due to the fact that they correspond to the same V.t value.\n I.e., positions that are different usages of the same [V.t].\n\n We use a union-find data structure to track equalities that a constraint system wants\n enforced *between* [V.t] values. Then, at the end, for all [V.t]s that have been unioned\n together, we combine their equivalence classes in the [equivalence_classes] table into\n a single equivalence class, so that the permutation argument enforces these desired equalities\n as well.\n *)\n ; union_finds : V.t Core_kernel.Union_find.t V.Table.t\n }\n\nlet get_public_input_size sys = sys.public_input_size\n\nlet get_rows_len sys = List.length sys.rows_rev\n\nlet get_prev_challenges sys = sys.prev_challenges\n\nlet set_prev_challenges sys challenges =\n Core_kernel.Set_once.set_exn sys.prev_challenges [%here] challenges\n\nlet get_concatenated_fixed_lookup_table_size sys =\n match sys.fixed_lookup_tables with\n | Unfinalized_fixed_lookup_tables_rev _ ->\n failwith\n \"Cannot get the fixed lookup tables before finalizing the constraint \\\n system\"\n | Compiled_fixed_lookup_tables flts ->\n let get_table_size (flt : _ Kimchi_types.lookup_table) =\n if Array.length flt.data = 0 then 0\n else Array.length (Array.get flt.data 0)\n in\n Array.fold_left (fun acc flt -> acc + get_table_size flt) 0 flts\n\nlet get_concatenated_runtime_lookup_table_size sys =\n match sys.runtime_tables_cfg with\n | Unfinalized_runtime_tables_cfg_rev _ ->\n failwith\n \"Cannot get the runtime table configurations before finalizing the \\\n constraint system\"\n | Compiled_runtime_tables_cfg rt_cfgs ->\n Array.fold_left\n (fun acc (rt_cfg : _ Kimchi_types.runtime_table_cfg) ->\n acc + Array.length rt_cfg.first_column )\n 0 rt_cfgs\n\nlet finalize_fixed_lookup_tables sys =\n match sys.fixed_lookup_tables with\n | Unfinalized_fixed_lookup_tables_rev fixed_lt_rev ->\n sys.fixed_lookup_tables <-\n Compiled_fixed_lookup_tables\n (Core_kernel.Array.of_list_rev fixed_lt_rev)\n | Compiled_fixed_lookup_tables _ ->\n failwith \"Fixed lookup tables have already been finalized\"\n\nlet finalize_runtime_lookup_tables sys =\n match sys.runtime_tables_cfg with\n | Unfinalized_runtime_tables_cfg_rev rt_cfgs_rev ->\n sys.runtime_tables_cfg <-\n Compiled_runtime_tables_cfg (Core_kernel.Array.of_list_rev rt_cfgs_rev)\n | Compiled_runtime_tables_cfg _ ->\n failwith \"Runtime table configurations have already been finalized\"\n\n(* TODO: shouldn't that Make create something bounded by a signature? As we know what a back end should be? Check where this is used *)\n\n(* TODO: glossary of terms in this file (terms, reducing, feeding) + module doc *)\n\n(* TODO: rename Fp to F or Field *)\n\n(** ? *)\nmodule Make\n (Fp : Field.S)\n (* We create a type for gate vector, instead of using `Gate.t list`. If we did, we would have to convert it to a `Gate.t array` to pass it across the FFI boundary, where then it gets converted to a `Vec`; it's more efficient to just create the `Vec` directly.\n *)\n (Gates : Gate_vector_intf with type field := Fp.t)\n (Params : sig\n val params : Fp.t Params.t\n end) : sig\n open Core_kernel\n\n type nonrec t = (Fp.t, Gates.t) t\n\n val create : unit -> t\n\n val get_public_input_size : t -> int Set_once.t\n\n val get_primary_input_size : t -> int\n\n val set_primary_input_size : t -> int -> unit\n\n val get_auxiliary_input_size : t -> int\n\n val set_auxiliary_input_size : t -> int -> unit\n\n val get_prev_challenges : t -> int option\n\n val set_prev_challenges : t -> int -> unit\n\n val get_rows_len : t -> int\n\n val next_row : t -> int\n\n val get_concatenated_fixed_lookup_table_size : t -> int\n\n val get_concatenated_runtime_lookup_table_size : t -> int\n\n (** Finalize the fixed lookup tables. The function can not be called twice *)\n val finalize_fixed_lookup_tables : t -> unit\n\n (** Finalize the runtime lookup table configurations. The function can not be\n called twice. *)\n val finalize_runtime_lookup_tables : t -> unit\n\n val add_constraint :\n ?label:string\n -> t\n -> ( Fp.t Snarky_backendless.Cvar.t\n , Fp.t )\n Snarky_backendless.Constraint.basic\n -> unit\n\n val compute_witness :\n t\n -> (int -> Fp.t)\n -> Fp.t array array * Fp.t Kimchi_types.runtime_table array\n\n val finalize : t -> unit\n\n val finalize_and_get_gates :\n t\n -> Gates.t\n * Fp.t Kimchi_types.lookup_table array\n * Fp.t Kimchi_types.runtime_table_cfg array\n\n val num_constraints : t -> int\n\n val digest : t -> Md5.t\n\n val to_json : t -> string\nend = struct\n open Core_kernel\n open Pickles_types\n\n (* Used by compute_witness to build the runtime tables from the Lookup\n constraint *)\n module MapRuntimeTable = struct\n module T = struct\n type t = int32 * Fp.t [@@deriving hash, sexp, compare]\n end\n\n include T\n include Core_kernel.Hashable.Make (T)\n end\n\n type nonrec t = (Fp.t, Gates.t) t\n\n (** Converts the set of permutations (equivalence_classes) to\n a hash table that maps each position to the next one.\n For example, if one of the equivalence class is [pos1, pos3, pos7],\n the function will return a hashtable that maps pos1 to pos3,\n pos3 to pos7, and pos7 to pos1.\n *)\n let equivalence_classes_to_hashtbl sys =\n let module Relative_position = struct\n module T = struct\n type t = Row.t Position.t [@@deriving hash, sexp, compare]\n end\n\n include T\n include Core_kernel.Hashable.Make (T)\n end in\n let equivalence_classes = V.Table.create () in\n Hashtbl.iteri sys.equivalence_classes ~f:(fun ~key ~data ->\n let u = Hashtbl.find_exn sys.union_finds key in\n Hashtbl.update equivalence_classes (Union_find.get u) ~f:(function\n | None ->\n Relative_position.Hash_set.of_list data\n | Some ps ->\n List.iter ~f:(Hash_set.add ps) data ;\n ps ) ) ;\n let res = Relative_position.Table.create () in\n Hashtbl.iter equivalence_classes ~f:(fun ps ->\n let rotate_left = function [] -> [] | x :: xs -> xs @ [ x ] in\n let ps =\n Hash_set.to_list ps |> List.sort ~compare:[%compare: Row.t Position.t]\n in\n List.iter2_exn ps (rotate_left ps) ~f:(fun input output ->\n Hashtbl.add_exn res ~key:input ~data:output ) ) ;\n res\n\n (** Compute the witness, given the constraint system `sys`\n and a function that converts the indexed secret inputs to their concrete values.\n *)\n let compute_witness (sys : t) (external_values : int -> Fp.t) :\n Fp.t array array * Fp.t Kimchi_types.runtime_table array =\n let internal_values : Fp.t Internal_var.Table.t =\n Internal_var.Table.create ()\n in\n let public_input_size = Set_once.get_exn sys.public_input_size [%here] in\n let num_rows = public_input_size + sys.next_row in\n let res =\n Array.init Constants.columns ~f:(fun _ ->\n Array.create ~len:num_rows Fp.zero )\n in\n (* Public input *)\n for i = 0 to public_input_size - 1 do\n res.(0).(i) <- external_values i\n done ;\n let find t k =\n match Hashtbl.find t k with\n | None ->\n failwithf !\"Could not find %{sexp:Internal_var.t}\\n%!\" k ()\n | Some x ->\n x\n in\n (* Compute an internal variable associated value. *)\n let compute ((lc, c) : (Fp.t * V.t) list * Fp.t option) =\n List.fold lc ~init:(Option.value c ~default:Fp.zero) ~f:(fun acc (s, x) ->\n let x =\n match x with\n | External x ->\n external_values x\n | Internal x ->\n find internal_values x\n in\n Fp.(acc + (s * x)) )\n in\n (* Update the witness table with the value of the variables from each row. *)\n List.iteri (List.rev sys.rows_rev) ~f:(fun i_after_input cols ->\n let row_idx = i_after_input + public_input_size in\n Array.iteri cols ~f:(fun col_idx var ->\n match var with\n | None ->\n ()\n | Some (External var) ->\n res.(col_idx).(row_idx) <- external_values var\n | Some (Internal var) ->\n let lc = find sys.internal_vars var in\n let value = compute lc in\n res.(col_idx).(row_idx) <- value ;\n Hashtbl.set internal_values ~key:var ~data:value ) ) ;\n\n let map_runtime_tables = MapRuntimeTable.Table.create () in\n let runtime_tables : Fp.t Kimchi_types.runtime_table array =\n match sys.runtime_tables_cfg with\n | Unfinalized_runtime_tables_cfg_rev _ ->\n failwith\n \"Attempted to generate a witness for an unfinalized constraint \\\n system\"\n | Compiled_runtime_tables_cfg cfgs ->\n Array.mapi cfgs ~f:(fun rt_idx { Kimchi_types.id; first_column } ->\n let data =\n Array.mapi first_column ~f:(fun i v ->\n ignore\n (* `add` leaves the value unchanged if the index has been\n already used. Therefore, it keeps the first value.\n This handles the case that the first column has\n duplicated index values.\n *)\n @@ MapRuntimeTable.Table.add map_runtime_tables ~key:(id, v)\n ~data:(i, rt_idx) ;\n (* default padding value for lookup *)\n Fp.zero )\n in\n let rt : Fp.t Kimchi_types.runtime_table = { id; data } in\n rt )\n in\n\n (* Fill in the used entries of the runtime lookup tables. *)\n List.iter (List.rev sys.runtime_lookups_rev) ~f:(fun (id, (idx, v)) ->\n let compute_value x = compute ([ (Fp.one, x) ], None) in\n let vid = compute_value id in\n let vidx = compute_value idx in\n let vv = compute_value v in\n (* FIXME: we should have a int32 here. We are not sure the ID will be a\n int32. We should enforce that.\n See https://github.com/MinaProtocol/mina/issues/13955\n *)\n let id_int32 = Int32.of_string @@ Fp.to_string vid in\n (* Using find allows to handle fixed lookup tables\n As the map has been built from the runtime table configurations,\n except in the case that a runtime table and a fixed table shares the\n same ID, the lookups in fixed lookup tables will return None.\n See https://github.com/MinaProtocol/mina/issues/14016\n *)\n let v =\n MapRuntimeTable.Table.find map_runtime_tables (id_int32, vidx)\n in\n if Option.is_some v then\n let i, rt_idx = Option.value_exn v in\n let rt = runtime_tables.(rt_idx) in\n (* Important note: we do not check if the value has been set before.\n Therefore, it will always use the latest value *)\n rt.data.(i) <- vv ) ;\n (* Return the witness. *)\n (res, runtime_tables)\n\n let union_find sys v =\n Hashtbl.find_or_add sys.union_finds v ~default:(fun () ->\n Union_find.create v )\n\n (** Creates an internal variable and assigns it the value lc and constant. *)\n let create_internal ?constant sys lc : V.t =\n let v = Internal_var.create () in\n ignore (union_find sys (Internal v) : _ Union_find.t) ;\n Hashtbl.add_exn sys.internal_vars ~key:v ~data:(lc, constant) ;\n V.Internal v\n\n (* Initializes a constraint system. *)\n let create () : t =\n { public_input_size = Set_once.create ()\n ; prev_challenges = Set_once.create ()\n ; internal_vars = Internal_var.Table.create ()\n ; gates = Unfinalized_rev [] (* Gates.create () *)\n ; runtime_lookups_rev = []\n ; fixed_lookup_tables = Unfinalized_fixed_lookup_tables_rev []\n ; runtime_tables_cfg = Unfinalized_runtime_tables_cfg_rev []\n ; rows_rev = []\n ; next_row = 0\n ; equivalence_classes = V.Table.create ()\n ; auxiliary_input_size = 0\n ; pending_generic_gate = None\n ; cached_constants = Hashtbl.create (module Fp)\n ; union_finds = V.Table.create ()\n }\n\n (** Returns the number of auxiliary inputs. *)\n let get_auxiliary_input_size t = t.auxiliary_input_size\n\n (** Returns the number of public inputs. *)\n let get_primary_input_size t = Set_once.get_exn t.public_input_size [%here]\n\n (** Returns the number of previous challenges. *)\n let get_prev_challenges t = Set_once.get t.prev_challenges\n\n (* Non-public part of the witness. *)\n let set_auxiliary_input_size t x = t.auxiliary_input_size <- x\n\n (** Sets the number of public-input. It must and can only be called once. *)\n let set_primary_input_size (sys : t) num_pub_inputs =\n Set_once.set_exn sys.public_input_size [%here] num_pub_inputs\n\n (** Sets the number of previous challenges. It must and can only be called once. *)\n let set_prev_challenges (sys : t) num_prev_challenges =\n Set_once.set_exn sys.prev_challenges [%here] num_prev_challenges\n\n let get_public_input_size (sys : t) = get_public_input_size sys\n\n let get_rows_len (sys : t) = get_rows_len sys\n\n let next_row (sys : t) = sys.next_row\n\n let get_concatenated_fixed_lookup_table_size (sys : t) =\n get_concatenated_fixed_lookup_table_size sys\n\n let get_concatenated_runtime_lookup_table_size (sys : t) =\n get_concatenated_runtime_lookup_table_size sys\n\n let finalize_fixed_lookup_tables = finalize_fixed_lookup_tables\n\n let finalize_runtime_lookup_tables = finalize_runtime_lookup_tables\n\n (** Adds {row; col} to the system's wiring under a specific key.\n A key is an external or internal variable.\n The row must be given relative to the start of the circuit\n (so at the start of the public-input rows). *)\n let wire' sys key row (col : int) =\n ignore (union_find sys key : V.t Union_find.t) ;\n V.Table.add_multi sys.equivalence_classes ~key ~data:{ row; col }\n\n (* TODO: rename to wire_abs and wire_rel? or wire_public and wire_after_public? or force a single use function that takes a Row.t? *)\n\n (** Same as wire', except that the row must be given relatively to the end of the public-input rows. *)\n let wire sys key row col = wire' sys key (Row.After_public_input row) col\n\n (** Adds a row/gate/constraint to a constraint system `sys`. *)\n let add_row sys (vars : V.t option array) kind coeffs =\n match sys.gates with\n | Compiled _ ->\n failwith \"add_row called on finalized constraint system\"\n | Unfinalized_rev gates ->\n (* As we're adding a row, we're adding new cells.\n If these cells (the first 7) contain variables,\n make sure that they are wired\n *)\n let num_vars = min Constants.permutation_cols (Array.length vars) in\n let vars_for_perm = Array.slice vars 0 num_vars in\n Array.iteri vars_for_perm ~f:(fun col x ->\n Option.iter x ~f:(fun x -> wire sys x sys.next_row col) ) ;\n (* Add to gates. *)\n let open Position in\n sys.gates <- Unfinalized_rev ({ kind; wired_to = [||]; coeffs } :: gates) ;\n (* Increment row. *)\n sys.next_row <- sys.next_row + 1 ;\n (* Add to row. *)\n sys.rows_rev <- vars :: sys.rows_rev\n\n (** Adds zero-knowledgeness to the gates/rows,\n and convert into Rust type [Gates.t].\n This can only be called once.\n *)\n let rec finalize_and_get_gates sys =\n match sys with\n | { gates = Compiled (_, gates)\n ; fixed_lookup_tables = Compiled_fixed_lookup_tables fixed_lookup_tables\n ; runtime_tables_cfg = Compiled_runtime_tables_cfg runtime_tables_cfg\n ; _\n } ->\n (gates, fixed_lookup_tables, runtime_tables_cfg)\n (* Finalizing lookup tables and runtime table cfgs first *)\n | { fixed_lookup_tables = Unfinalized_fixed_lookup_tables_rev _; _ } ->\n finalize_fixed_lookup_tables sys ;\n finalize_and_get_gates sys\n | { runtime_tables_cfg = Unfinalized_runtime_tables_cfg_rev _; _ } ->\n finalize_runtime_lookup_tables sys ;\n finalize_and_get_gates sys\n | { pending_generic_gate = Some (l, r, o, coeffs); _ } ->\n (* Finalize any pending generic constraint first. *)\n add_row sys [| l; r; o |] Generic coeffs ;\n sys.pending_generic_gate <- None ;\n finalize_and_get_gates sys\n | { gates = Unfinalized_rev gates_rev\n ; fixed_lookup_tables = Compiled_fixed_lookup_tables fixed_lookup_tables\n ; runtime_tables_cfg = Compiled_runtime_tables_cfg runtime_tables_cfg\n ; _\n } ->\n let rust_gates = Gates.create () in\n\n (* Create rows for public input. *)\n let public_input_size =\n Set_once.get_exn sys.public_input_size [%here]\n in\n let pub_selectors = [| Fp.one; Fp.zero; Fp.zero; Fp.zero; Fp.zero |] in\n let pub_input_gate_specs_rev = ref [] in\n for row = 0 to public_input_size - 1 do\n let public_var = V.External row in\n wire' sys public_var (Row.Public_input row) 0 ;\n pub_input_gate_specs_rev :=\n { Gate_spec.kind = Generic\n ; wired_to = [||]\n ; coeffs = pub_selectors\n }\n :: !pub_input_gate_specs_rev\n done ;\n\n (* Construct permutation hashmap. *)\n let pos_map = equivalence_classes_to_hashtbl sys in\n let permutation (pos : Row.t Position.t) : Row.t Position.t =\n Option.value (Hashtbl.find pos_map pos) ~default:pos\n in\n\n let update_gate_with_permutation_info (row : Row.t)\n (gate : (unit, _) Gate_spec.t) : (Row.t, _) Gate_spec.t =\n { gate with\n wired_to =\n Array.init Constants.permutation_cols ~f:(fun col ->\n permutation { row; col } )\n }\n in\n\n (* Process public gates. *)\n let public_gates = List.rev !pub_input_gate_specs_rev in\n let public_gates =\n List.mapi public_gates ~f:(fun absolute_row gate ->\n update_gate_with_permutation_info (Row.Public_input absolute_row)\n gate )\n in\n\n (* construct all the other gates (except zero-knowledge rows) *)\n let gates = List.rev gates_rev in\n let gates =\n List.mapi gates ~f:(fun relative_row gate ->\n update_gate_with_permutation_info\n (Row.After_public_input relative_row) gate )\n in\n\n (* concatenate and convert to absolute rows *)\n let to_absolute_row =\n Gate_spec.map_rows ~f:(Row.to_absolute ~public_input_size)\n in\n\n (* convert all the gates into our Gates.t Rust vector type *)\n let add_gates gates =\n List.iter gates ~f:(fun g ->\n let g = to_absolute_row g in\n Gates.add rust_gates (Gate_spec.to_rust_gate g) )\n in\n add_gates public_gates ;\n add_gates gates ;\n\n (* compute the circuit's digest *)\n let digest = Gates.digest public_input_size rust_gates in\n let md5_digest = Md5.digest_bytes digest in\n\n (* drop the gates, we don't need them anymore *)\n sys.gates <- Compiled (md5_digest, rust_gates) ;\n\n (* return the gates *)\n (rust_gates, fixed_lookup_tables, runtime_tables_cfg)\n\n (** Calls [finalize_and_get_gates] and ignores the result. *)\n let finalize t =\n ignore\n ( finalize_and_get_gates t\n : Gates.t\n * Fp.t Kimchi_types.lookup_table array\n * Fp.t Kimchi_types.runtime_table_cfg array )\n\n let num_constraints sys =\n let gates, _, _ = finalize_and_get_gates sys in\n Gates.len gates\n\n let to_json (sys : t) : string =\n (* TODO: add lookup tables and runtime table cfgs *)\n (* https://github.com/MinaProtocol/mina/issues/13886 *)\n let gates, _, _ = finalize_and_get_gates sys in\n let public_input_size = Set_once.get_exn sys.public_input_size [%here] in\n Gates.to_json public_input_size gates\n\n (* Returns a hash of the circuit. *)\n let rec digest (sys : t) =\n match sys.gates with\n | Unfinalized_rev _ ->\n finalize sys ; digest sys\n | Compiled (digest, _) ->\n digest\n\n (** Regroup terms that share the same variable.\n For example, (3, i2) ; (2, i2) can be simplified to (5, i2).\n It assumes that the list of given terms is sorted,\n and that i0 is the smallest one.\n For example, `i0 = 1` and `terms = [(_, 2); (_, 2); (_; 4); ...]`\n\n Returns `(last_scalar, last_variable, terms, terms_length)`\n where terms does not contain the last scalar and last variable observed.\n *)\n let accumulate_terms terms =\n List.fold terms ~init:Int.Map.empty ~f:(fun acc (x, i) ->\n Map.change acc i ~f:(fun y ->\n let res = match y with None -> x | Some y -> Fp.add x y in\n if Fp.(equal zero res) then None else Some res ) )\n\n (** Converts a [Cvar.t] to a `(terms, terms_length, has_constant)`.\n if `has_constant` is set, then terms start with a constant term in the form of (c, 0).\n *)\n let canonicalize x =\n let c, terms =\n Fp.(\n Snarky_backendless.Cvar.to_constant_and_terms ~add ~mul ~zero:(of_int 0)\n ~equal ~one:(of_int 1))\n x\n in\n (* Note: [(c, 0)] represents the field element [c] multiplied by the 0th\n variable, which is held constant as [Field.one].\n *)\n let terms = match c with None -> terms | Some c -> (c, 0) :: terms in\n let has_constant_term = Option.is_some c in\n let terms = accumulate_terms terms in\n let terms_list =\n Map.fold_right ~init:[] terms ~f:(fun ~key ~data acc ->\n (data, key) :: acc )\n in\n Some (terms_list, Map.length terms, has_constant_term)\n\n (** Adds a generic constraint to the constraint system.\n As there are two generic gates per row, we queue\n every other generic gate.\n *)\n let add_generic_constraint ?l ?r ?o coeffs sys : unit =\n match sys.pending_generic_gate with\n (* if the queue of generic gate is empty, queue this *)\n | None ->\n sys.pending_generic_gate <- Some (l, r, o, coeffs)\n (* otherwise empty the queue and create the row *)\n | Some (l2, r2, o2, coeffs2) ->\n let coeffs = Array.append coeffs coeffs2 in\n add_row sys [| l; r; o; l2; r2; o2 |] Generic coeffs ;\n sys.pending_generic_gate <- None\n\n (** Converts a number of scaled additions \\sum s_i * x_i\n to as many constraints as needed,\n creating temporary variables for each new row/constraint,\n and returning the output variable.\n\n For example, [(s1, x1), (s2, x2)] is transformed into:\n - internal_var_1 = s1 * x1 + s2 * x2\n - return (1, internal_var_1)\n\n and [(s1, x1), (s2, x2), (s3, x3)] is transformed into:\n - internal_var_1 = s1 * x1 + s2 * x2\n - internal_var_2 = 1 * internal_var_1 + s3 * x3\n - return (1, internal_var_2)\n\n It assumes that the list of terms is not empty. *)\n let completely_reduce sys (terms : (Fp.t * int) list) =\n (* just adding constrained variables without values *)\n let rec go = function\n | [] ->\n assert false\n | [ (s, x) ] ->\n (s, V.External x)\n | (ls, lx) :: t ->\n let lx = V.External lx in\n (* TODO: this should be rewritten to be tail-optimized *)\n let rs, rx = go t in\n let s1x1_plus_s2x2 = create_internal sys [ (ls, lx); (rs, rx) ] in\n add_generic_constraint ~l:lx ~r:rx ~o:s1x1_plus_s2x2\n [| ls; rs; Fp.(negate one); Fp.zero; Fp.zero |]\n sys ;\n (Fp.one, s1x1_plus_s2x2)\n in\n go terms\n\n (** Converts a linear combination of variables into a set of constraints.\n It returns the output variable as (1, `Var res),\n unless the output is a constant, in which case it returns (c, `Constant).\n *)\n let reduce_lincom sys (x : Fp.t Snarky_backendless.Cvar.t) =\n let constant, terms =\n Fp.(\n Snarky_backendless.Cvar.to_constant_and_terms ~add ~mul ~zero:(of_int 0)\n ~equal ~one:(of_int 1))\n x\n in\n let terms = accumulate_terms terms in\n let terms_list =\n Map.fold_right ~init:[] terms ~f:(fun ~key ~data acc ->\n (data, key) :: acc )\n in\n match (constant, Map.is_empty terms) with\n | Some c, true ->\n (c, `Constant)\n | None, true ->\n (Fp.zero, `Constant)\n | _ -> (\n match terms_list with\n | [] ->\n assert false\n | [ (ls, lx) ] -> (\n match constant with\n | None ->\n (ls, `Var (V.External lx))\n | Some c ->\n (* res = ls * lx + c *)\n let res =\n create_internal ~constant:c sys [ (ls, External lx) ]\n in\n add_generic_constraint ~l:(External lx) ~o:res\n [| ls; Fp.zero; Fp.(negate one); Fp.zero; c |]\n (* Could be here *)\n sys ;\n (Fp.one, `Var res) )\n | (ls, lx) :: tl ->\n (* reduce the terms, then add the constant *)\n let rs, rx = completely_reduce sys tl in\n let res =\n create_internal ?constant sys [ (ls, External lx); (rs, rx) ]\n in\n (* res = ls * lx + rs * rx + c *)\n add_generic_constraint ~l:(External lx) ~r:rx ~o:res\n [| ls\n ; rs\n ; Fp.(negate one)\n ; Fp.zero\n ; (match constant with Some x -> x | None -> Fp.zero)\n |]\n (* Could be here *)\n sys ;\n (Fp.one, `Var res) )\n\n (** Adds a constraint to the constraint system. *)\n let add_constraint ?label:_ sys\n (constr :\n ( Fp.t Snarky_backendless.Cvar.t\n , Fp.t )\n Snarky_backendless.Constraint.basic ) =\n let red = reduce_lincom sys in\n (* reduce any [Cvar.t] to a single internal variable *)\n let reduce_to_v (x : Fp.t Snarky_backendless.Cvar.t) : V.t =\n match red x with\n | s, `Var x ->\n if Fp.equal s Fp.one then x\n else\n let sx = create_internal sys [ (s, x) ] in\n (* s * x - sx = 0 *)\n add_generic_constraint ~l:x ~o:sx\n [| s; Fp.zero; Fp.(negate one); Fp.zero; Fp.zero |]\n sys ;\n sx\n | s, `Constant -> (\n match Hashtbl.find sys.cached_constants s with\n | Some x ->\n x\n | None ->\n let x = create_internal sys ~constant:s [] in\n add_generic_constraint ~l:x\n [| Fp.one; Fp.zero; Fp.zero; Fp.zero; Fp.negate s |]\n sys ;\n Hashtbl.set sys.cached_constants ~key:s ~data:x ;\n x )\n in\n match constr with\n | Snarky_backendless.Constraint.Square (v1, v2) -> (\n match (red v1, red v2) with\n | (sl, `Var xl), (so, `Var xo) ->\n (* (sl * xl)^2 = so * xo\n sl^2 * xl * xl - so * xo = 0\n *)\n add_generic_constraint ~l:xl ~r:xl ~o:xo\n [| Fp.zero; Fp.zero; Fp.negate so; Fp.(sl * sl); Fp.zero |]\n sys\n | (sl, `Var xl), (so, `Constant) ->\n (* TODO: it's hard to read the array of selector values, name them! *)\n add_generic_constraint ~l:xl ~r:xl\n [| Fp.zero; Fp.zero; Fp.zero; Fp.(sl * sl); Fp.negate so |]\n sys\n | (sl, `Constant), (so, `Var xo) ->\n (* sl^2 = so * xo *)\n add_generic_constraint ~o:xo\n [| Fp.zero; Fp.zero; so; Fp.zero; Fp.negate (Fp.square sl) |]\n sys\n | (sl, `Constant), (so, `Constant) ->\n assert (Fp.(equal (square sl) so)) )\n | Snarky_backendless.Constraint.R1CS (v1, v2, v3) -> (\n match (red v1, red v2, red v3) with\n | (s1, `Var x1), (s2, `Var x2), (s3, `Var x3) ->\n (* s1 x1 * s2 x2 = s3 x3\n - s1 s2 (x1 x2) + s3 x3 = 0\n *)\n add_generic_constraint ~l:x1 ~r:x2 ~o:x3\n [| Fp.zero; Fp.zero; s3; Fp.(negate s1 * s2); Fp.zero |]\n sys\n | (s1, `Var x1), (s2, `Var x2), (s3, `Constant) ->\n add_generic_constraint ~l:x1 ~r:x2\n [| Fp.zero; Fp.zero; Fp.zero; Fp.(s1 * s2); Fp.negate s3 |]\n sys\n | (s1, `Var x1), (s2, `Constant), (s3, `Var x3) ->\n (* s1 x1 * s2 = s3 x3\n *)\n add_generic_constraint ~l:x1 ~o:x3\n [| Fp.(s1 * s2); Fp.zero; Fp.negate s3; Fp.zero; Fp.zero |]\n sys\n | (s1, `Constant), (s2, `Var x2), (s3, `Var x3) ->\n add_generic_constraint ~r:x2 ~o:x3\n [| Fp.zero; Fp.(s1 * s2); Fp.negate s3; Fp.zero; Fp.zero |]\n sys\n | (s1, `Var x1), (s2, `Constant), (s3, `Constant) ->\n add_generic_constraint ~l:x1\n [| Fp.(s1 * s2); Fp.zero; Fp.zero; Fp.zero; Fp.negate s3 |]\n sys\n | (s1, `Constant), (s2, `Var x2), (s3, `Constant) ->\n add_generic_constraint ~r:x2\n [| Fp.zero; Fp.(s1 * s2); Fp.zero; Fp.zero; Fp.negate s3 |]\n sys\n | (s1, `Constant), (s2, `Constant), (s3, `Var x3) ->\n add_generic_constraint ~o:x3\n [| Fp.zero; Fp.zero; s3; Fp.zero; Fp.(negate s1 * s2) |]\n sys\n | (s1, `Constant), (s2, `Constant), (s3, `Constant) ->\n assert (Fp.(equal s3 Fp.(s1 * s2))) )\n | Snarky_backendless.Constraint.Boolean v -> (\n let s, x = red v in\n match x with\n | `Var x ->\n (* -x + x * x = 0 *)\n add_generic_constraint ~l:x ~r:x\n [| Fp.(negate one); Fp.zero; Fp.zero; Fp.one; Fp.zero |]\n sys\n | `Constant ->\n assert (Fp.(equal s (s * s))) )\n | Snarky_backendless.Constraint.Equal (v1, v2) -> (\n let (s1, x1), (s2, x2) = (red v1, red v2) in\n match (x1, x2) with\n | `Var x1, `Var x2 ->\n if Fp.equal s1 s2 then (\n if not (Fp.equal s1 Fp.zero) then\n Union_find.union (union_find sys x1) (union_find sys x2) )\n else if (* s1 x1 - s2 x2 = 0\n *)\n not (Fp.equal s1 s2) then\n add_generic_constraint ~l:x1 ~r:x2\n [| s1; Fp.(negate s2); Fp.zero; Fp.zero; Fp.zero |]\n sys\n else\n add_generic_constraint ~l:x1 ~r:x2\n [| s1; Fp.(negate s2); Fp.zero; Fp.zero; Fp.zero |]\n sys\n | `Var x1, `Constant -> (\n (* s1 * x1 = s2\n x1 = s2 / s1\n *)\n let ratio = Fp.(s2 / s1) in\n match Hashtbl.find sys.cached_constants ratio with\n | Some x2 ->\n Union_find.union (union_find sys x1) (union_find sys x2)\n | None ->\n add_generic_constraint ~l:x1\n [| s1; Fp.zero; Fp.zero; Fp.zero; Fp.negate s2 |]\n sys ;\n Hashtbl.set sys.cached_constants ~key:ratio ~data:x1 )\n | `Constant, `Var x2 -> (\n (* s1 = s2 * x2\n x2 = s1 / s2\n *)\n let ratio = Fp.(s1 / s2) in\n match Hashtbl.find sys.cached_constants ratio with\n | Some x1 ->\n Union_find.union (union_find sys x1) (union_find sys x2)\n | None ->\n add_generic_constraint ~r:x2\n [| Fp.zero; s2; Fp.zero; Fp.zero; Fp.negate s1 |]\n sys ;\n Hashtbl.set sys.cached_constants ~key:ratio ~data:x2 )\n | `Constant, `Constant ->\n assert (Fp.(equal s1 s2)) )\n | Plonk_constraint.T (Basic { l; r; o; m; c }) ->\n (* 0\n = l.s * l.x\n + r.s * r.x\n + o.s * o.x\n + m * (l.x * r.x)\n + c\n =\n l.s * l.s' * l.x'\n + r.s * r.s' * r.x'\n + o.s * o.s' * o.x'\n + m * (l.s' * l.x' * r.s' * r.x')\n + c\n =\n (l.s * l.s') * l.x'\n + (r.s * r.s') * r.x'\n + (o.s * o.s') * o.x'\n + (m * l.s' * r.s') * l.x' r.x'\n + c\n *)\n (* TODO: This is sub-optimal *)\n let c = ref c in\n let red_pr (s, x) =\n match red x with\n | s', `Constant ->\n c := Fp.add !c Fp.(s * s') ;\n (* No need to have a real term. *)\n (s', None)\n | s', `Var x ->\n (s', Some (Fp.(s * s'), x))\n in\n (* l.s * l.x\n + r.s * r.x\n + o.s * o.x\n + m * (l.x * r.x)\n + c\n =\n l.s * l.s' * l.x'\n + r.s * r.x\n + o.s * o.x\n + m * (l.x * r.x)\n + c\n =\n *)\n let l_s', l = red_pr l in\n let r_s', r = red_pr r in\n let _, o = red_pr o in\n let var = Option.map ~f:snd in\n let coeff = Option.value_map ~default:Fp.zero ~f:fst in\n let m =\n match (l, r) with\n | Some _, Some _ ->\n Fp.(l_s' * r_s' * m)\n | _ ->\n (* TODO: Figure this out later. *)\n failwith \"Must use non-constant cvar in plonk constraints\"\n in\n add_generic_constraint ?l:(var l) ?r:(var r) ?o:(var o)\n [| coeff l; coeff r; coeff o; m; !c |]\n sys\n (* | w0 | w1 | w2 | w3 | w4 | w5\n state = [ x , x , x ], [ y, y, y ], ... ]\n i=0, perm^ i=1, perm^\n *)\n | Plonk_constraint.T (Poseidon { state }) ->\n (* reduce the state *)\n let reduce_state sys (s : Fp.t Snarky_backendless.Cvar.t array array) :\n V.t array array =\n Array.map ~f:(Array.map ~f:reduce_to_v) s\n in\n let state = reduce_state sys state in\n (* add_round_state adds a row that contains 5 rounds of permutation *)\n let add_round_state ~round (s1, s2, s3, s4, s5) =\n let vars =\n [| Some s1.(0)\n ; Some s1.(1)\n ; Some s1.(2)\n ; Some s5.(0) (* the last state is in 2nd position *)\n ; Some s5.(1)\n ; Some s5.(2)\n ; Some s2.(0)\n ; Some s2.(1)\n ; Some s2.(2)\n ; Some s3.(0)\n ; Some s3.(1)\n ; Some s3.(2)\n ; Some s4.(0)\n ; Some s4.(1)\n ; Some s4.(2)\n |]\n in\n let coeffs =\n [| Params.params.round_constants.(round).(0)\n ; Params.params.round_constants.(round).(1)\n ; Params.params.round_constants.(round).(2)\n ; Params.params.round_constants.(round + 1).(0)\n ; Params.params.round_constants.(round + 1).(1)\n ; Params.params.round_constants.(round + 1).(2)\n ; Params.params.round_constants.(round + 2).(0)\n ; Params.params.round_constants.(round + 2).(1)\n ; Params.params.round_constants.(round + 2).(2)\n ; Params.params.round_constants.(round + 3).(0)\n ; Params.params.round_constants.(round + 3).(1)\n ; Params.params.round_constants.(round + 3).(2)\n ; Params.params.round_constants.(round + 4).(0)\n ; Params.params.round_constants.(round + 4).(1)\n ; Params.params.round_constants.(round + 4).(2)\n |]\n in\n add_row sys vars Poseidon coeffs\n in\n (* add_last_row adds the last row containing the output *)\n let add_last_row state =\n let vars =\n [| Some state.(0)\n ; Some state.(1)\n ; Some state.(2)\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n |]\n in\n add_row sys vars Zero [||]\n in\n (* go through the states row by row (a row contains 5 states) *)\n let rec process_5_states_at_a_time ~round = function\n | [ s1; s2; s3; s4; s5; last ] ->\n add_round_state ~round (s1, s2, s3, s4, s5) ;\n add_last_row last\n | s1 :: s2 :: s3 :: s4 :: s5 :: tl ->\n add_round_state ~round (s1, s2, s3, s4, s5) ;\n process_5_states_at_a_time ~round:(round + 5) tl\n | _ ->\n failwith \"incorrect number of states given\"\n in\n process_5_states_at_a_time ~round:0 (Array.to_list state)\n | Plonk_constraint.T\n (EC_add_complete { p1; p2; p3; inf; same_x; slope; inf_z; x21_inv }) ->\n let reduce_curve_point (x, y) = (reduce_to_v x, reduce_to_v y) in\n\n (*\n //! 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14\n //! x1 y1 x2 y2 x3 y3 inf same_x s inf_z x21_inv\n *)\n let x1, y1 = reduce_curve_point p1 in\n let x2, y2 = reduce_curve_point p2 in\n let x3, y3 = reduce_curve_point p3 in\n let vars =\n [| Some x1\n ; Some y1\n ; Some x2\n ; Some y2\n ; Some x3\n ; Some y3\n ; Some (reduce_to_v inf)\n ; Some (reduce_to_v same_x)\n ; Some (reduce_to_v slope)\n ; Some (reduce_to_v inf_z)\n ; Some (reduce_to_v x21_inv)\n ; None\n ; None\n ; None\n ; None\n |]\n in\n add_row sys vars CompleteAdd [||]\n | Plonk_constraint.T (EC_scale { state }) ->\n let i = ref 0 in\n (*\n 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14\n xT yT x0 y0 n n' x1 y1 x2 y2 x3 y3 x4 y4\n x5 y5 b0 b1 b2 b3 b4 s0 s1 s2 s3 s4\n *)\n let add_ecscale_round\n Scale_round.{ accs; bits; ss; base = xt, yt; n_prev; n_next } =\n let curr_row =\n [| Some xt\n ; Some yt\n ; Some (fst accs.(0))\n ; Some (snd accs.(0))\n ; Some n_prev\n ; Some n_next\n ; None\n ; Some (fst accs.(1))\n ; Some (snd accs.(1))\n ; Some (fst accs.(2))\n ; Some (snd accs.(2))\n ; Some (fst accs.(3))\n ; Some (snd accs.(3))\n ; Some (fst accs.(4))\n ; Some (snd accs.(4))\n |]\n in\n let next_row =\n [| Some (fst accs.(5))\n ; Some (snd accs.(5))\n ; Some bits.(0)\n ; Some bits.(1)\n ; Some bits.(2)\n ; Some bits.(3)\n ; Some bits.(4)\n ; Some ss.(0)\n ; Some ss.(1)\n ; Some ss.(2)\n ; Some ss.(3)\n ; Some ss.(4)\n ; None\n ; None\n ; None\n |]\n in\n add_row sys curr_row VarBaseMul [||] ;\n add_row sys next_row Zero [||]\n in\n\n Array.iter\n ~f:(fun round -> add_ecscale_round round ; incr i)\n (Array.map state ~f:(Scale_round.map ~f:reduce_to_v)) ;\n ()\n | Plonk_constraint.T (EC_endoscale { state; xs; ys; n_acc }) ->\n (* Reduce state. *)\n let state = Array.map state ~f:(Endoscale_round.map ~f:reduce_to_v) in\n (* Add round function. *)\n let add_endoscale_round (round : V.t Endoscale_round.t) =\n let row =\n [| Some round.xt\n ; Some round.yt\n ; None\n ; None\n ; Some round.xp\n ; Some round.yp\n ; Some round.n_acc\n ; Some round.xr\n ; Some round.yr\n ; Some round.s1\n ; Some round.s3\n ; Some round.b1\n ; Some round.b2\n ; Some round.b3\n ; Some round.b4\n |]\n in\n add_row sys row Kimchi_types.EndoMul [||]\n in\n Array.iter state ~f:add_endoscale_round ;\n (* Last row. *)\n let vars =\n [| None\n ; None\n ; None\n ; None\n ; Some (reduce_to_v xs)\n ; Some (reduce_to_v ys)\n ; Some (reduce_to_v n_acc)\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n |]\n in\n add_row sys vars Zero [||]\n | Plonk_constraint.T\n (EC_endoscalar { state : 'v Endoscale_scalar_round.t array }) ->\n (* Add round function. *)\n let add_endoscale_scalar_round (round : V.t Endoscale_scalar_round.t) =\n let row =\n [| Some round.n0\n ; Some round.n8\n ; Some round.a0\n ; Some round.b0\n ; Some round.a8\n ; Some round.b8\n ; Some round.x0\n ; Some round.x1\n ; Some round.x2\n ; Some round.x3\n ; Some round.x4\n ; Some round.x5\n ; Some round.x6\n ; Some round.x7\n ; None\n |]\n in\n add_row sys row Kimchi_types.EndoMulScalar [||]\n in\n Array.iter state\n ~f:\n (Fn.compose add_endoscale_scalar_round\n (Endoscale_scalar_round.map ~f:reduce_to_v) )\n | Plonk_constraint.T (Lookup { w0; w1; w2; w3; w4; w5; w6 }) ->\n (* table ID *)\n let red_w0 = reduce_to_v w0 in\n (* idx1 *)\n let red_w1 = reduce_to_v w1 in\n (* v1 *)\n let red_w2 = reduce_to_v w2 in\n (* idx2 *)\n let red_w3 = reduce_to_v w3 in\n (* v2 *)\n let red_w4 = reduce_to_v w4 in\n (* idx3 *)\n let red_w5 = reduce_to_v w5 in\n (* v3 *)\n let red_w6 = reduce_to_v w6 in\n let vars =\n [| Some red_w0\n ; Some red_w1\n ; Some red_w2\n ; Some red_w3\n ; Some red_w4\n ; Some red_w5\n ; Some red_w6\n |]\n in\n let lookup1 = (red_w0, (red_w1, red_w2)) in\n let lookup2 = (red_w0, (red_w3, red_w4)) in\n let lookup3 = (red_w0, (red_w5, red_w6)) in\n (* We populate with the first lookup. In the case the user uses the same\n index multiple times, the last value will be used *)\n sys.runtime_lookups_rev <-\n lookup3 :: lookup2 :: lookup1 :: sys.runtime_lookups_rev ;\n add_row sys vars Lookup [||]\n | Plonk_constraint.T\n (RangeCheck0\n { v0\n ; v0p0\n ; v0p1\n ; v0p2\n ; v0p3\n ; v0p4\n ; v0p5\n ; v0c0\n ; v0c1\n ; v0c2\n ; v0c3\n ; v0c4\n ; v0c5\n ; v0c6\n ; v0c7\n ; compact\n } ) ->\n (*\n //! 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14\n //! v vp0 vp1 vp2 vp3 vp4 vp5 vc0 vc1 vc2 vc3 vc4 vc5 vc6 vc7\n *)\n let vars =\n [| Some (reduce_to_v v0)\n ; Some (reduce_to_v v0p0) (* MSBs *)\n ; Some (reduce_to_v v0p1)\n ; Some (reduce_to_v v0p2)\n ; Some (reduce_to_v v0p3)\n ; Some (reduce_to_v v0p4)\n ; Some (reduce_to_v v0p5)\n ; Some (reduce_to_v v0c0)\n ; Some (reduce_to_v v0c1)\n ; Some (reduce_to_v v0c2)\n ; Some (reduce_to_v v0c3)\n ; Some (reduce_to_v v0c4)\n ; Some (reduce_to_v v0c5)\n ; Some (reduce_to_v v0c6)\n ; Some (reduce_to_v v0c7) (* LSBs *)\n |]\n in\n let coeff = if Fp.equal compact Fp.one then Fp.one else Fp.zero in\n add_row sys vars RangeCheck0 [| coeff |]\n | Plonk_constraint.T\n (RangeCheck1\n { (* Current row *) v2\n ; v12\n ; v2c0\n ; v2p0\n ; v2p1\n ; v2p2\n ; v2p3\n ; v2c1\n ; v2c2\n ; v2c3\n ; v2c4\n ; v2c5\n ; v2c6\n ; v2c7\n ; v2c8\n ; (* Next row *) v2c9\n ; v2c10\n ; v2c11\n ; v0p0\n ; v0p1\n ; v1p0\n ; v1p1\n ; v2c12\n ; v2c13\n ; v2c14\n ; v2c15\n ; v2c16\n ; v2c17\n ; v2c18\n ; v2c19\n } ) ->\n (*\n //! 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14\n //! Curr: v2 v12 v2c0 v2p0 v2p1 v2p2 v2p3 v2c1 v2c2 v2c3 v2c4 v2c5 v2c6 v2c7 v2c8\n //! Next: v2c9 v2c10 v2c11 v0p0 v0p1 v1p0 v1p1 v2c12 v2c13 v2c14 v2c15 v2c16 v2c17 v2c18 v2c19\n *)\n let vars_curr =\n [| (* Current row *) Some (reduce_to_v v2)\n ; Some (reduce_to_v v12)\n ; Some (reduce_to_v v2c0) (* MSBs *)\n ; Some (reduce_to_v v2p0)\n ; Some (reduce_to_v v2p1)\n ; Some (reduce_to_v v2p2)\n ; Some (reduce_to_v v2p3)\n ; Some (reduce_to_v v2c1)\n ; Some (reduce_to_v v2c2)\n ; Some (reduce_to_v v2c3)\n ; Some (reduce_to_v v2c4)\n ; Some (reduce_to_v v2c5)\n ; Some (reduce_to_v v2c6)\n ; Some (reduce_to_v v2c7)\n ; Some (reduce_to_v v2c8) (* LSBs *)\n |]\n in\n let vars_next =\n [| (* Next row *) Some (reduce_to_v v2c9)\n ; Some (reduce_to_v v2c10)\n ; Some (reduce_to_v v2c11)\n ; Some (reduce_to_v v0p0)\n ; Some (reduce_to_v v0p1)\n ; Some (reduce_to_v v1p0)\n ; Some (reduce_to_v v1p1)\n ; Some (reduce_to_v v2c12)\n ; Some (reduce_to_v v2c13)\n ; Some (reduce_to_v v2c14)\n ; Some (reduce_to_v v2c15)\n ; Some (reduce_to_v v2c16)\n ; Some (reduce_to_v v2c17)\n ; Some (reduce_to_v v2c18)\n ; Some (reduce_to_v v2c19)\n |]\n in\n add_row sys vars_curr RangeCheck1 [||] ;\n add_row sys vars_next Zero [||]\n | Plonk_constraint.T\n (Xor\n { in1\n ; in2\n ; out\n ; in1_0\n ; in1_1\n ; in1_2\n ; in1_3\n ; in2_0\n ; in2_1\n ; in2_2\n ; in2_3\n ; out_0\n ; out_1\n ; out_2\n ; out_3\n } ) ->\n (* | Column | Curr | Next (gadget responsibility) |\n | ------ | ---------------- | ---------------------------- |\n | 0 | copy `in1` | copy `in1'` |\n | 1 | copy `in2` | copy `in2'` |\n | 2 | copy `out` | copy `out'` |\n | 3 | plookup0 `in1_0` | |\n | 4 | plookup1 `in1_1` | |\n | 5 | plookup2 `in1_2` | |\n | 6 | plookup3 `in1_3` | |\n | 7 | plookup0 `in2_0` | |\n | 8 | plookup1 `in2_1` | |\n | 9 | plookup2 `in2_2` | |\n | 10 | plookup3 `in2_3` | |\n | 11 | plookup0 `out_0` | |\n | 12 | plookup1 `out_1` | |\n | 13 | plookup2 `out_2` | |\n | 14 | plookup3 `out_3` | |\n *)\n let curr_row =\n [| Some (reduce_to_v in1)\n ; Some (reduce_to_v in2)\n ; Some (reduce_to_v out)\n ; Some (reduce_to_v in1_0)\n ; Some (reduce_to_v in1_1)\n ; Some (reduce_to_v in1_2)\n ; Some (reduce_to_v in1_3)\n ; Some (reduce_to_v in2_0)\n ; Some (reduce_to_v in2_1)\n ; Some (reduce_to_v in2_2)\n ; Some (reduce_to_v in2_3)\n ; Some (reduce_to_v out_0)\n ; Some (reduce_to_v out_1)\n ; Some (reduce_to_v out_2)\n ; Some (reduce_to_v out_3)\n |]\n in\n (* The raw gate after a Xor16 gate is a Const to check that all values are zero.\n For that, the first coefficient is 1 and the rest will be zero.\n This will be included in the gadget for a chain of Xors, not here.*)\n add_row sys curr_row Xor16 [||]\n | Plonk_constraint.T\n (ForeignFieldAdd\n { left_input_lo\n ; left_input_mi\n ; left_input_hi\n ; right_input_lo\n ; right_input_mi\n ; right_input_hi\n ; field_overflow\n ; carry\n ; (* Coefficients *) foreign_field_modulus0\n ; foreign_field_modulus1\n ; foreign_field_modulus2\n ; sign\n } ) ->\n (*\n //! | Gate | `ForeignFieldAdd` | Circuit/gadget responsibility |\n //! | ------ | ------------------------ | ------------------------------ |\n //! | Column | `Curr` | `Next` |\n //! | ------ | ------------------------ | ------------------------------ |\n //! | 0 | `left_input_lo` (copy) | `result_lo` (copy) |\n //! | 1 | `left_input_mi` (copy) | `result_mi` (copy) |\n //! | 2 | `left_input_hi` (copy) | `result_hi` (copy) |\n //! | 3 | `right_input_lo` (copy) | |\n //! | 4 | `right_input_mi` (copy) | |\n //! | 5 | `right_input_hi` (copy) | |\n //! | 6 | `field_overflow` (copy?) | |\n //! | 7 | `carry` | |\n //! | 8 | | |\n //! | 9 | | |\n //! | 10 | | |\n //! | 11 | | |\n //! | 12 | | |\n //! | 13 | | |\n //! | 14 | | |\n *)\n let vars =\n [| (* Current row *) Some (reduce_to_v left_input_lo)\n ; Some (reduce_to_v left_input_mi)\n ; Some (reduce_to_v left_input_hi)\n ; Some (reduce_to_v right_input_lo)\n ; Some (reduce_to_v right_input_mi)\n ; Some (reduce_to_v right_input_hi)\n ; Some (reduce_to_v field_overflow)\n ; Some (reduce_to_v carry)\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n |]\n in\n add_row sys vars ForeignFieldAdd\n [| foreign_field_modulus0\n ; foreign_field_modulus1\n ; foreign_field_modulus2\n ; sign\n |]\n | Plonk_constraint.T\n (ForeignFieldMul\n { left_input0\n ; left_input1\n ; left_input2\n ; right_input0\n ; right_input1\n ; right_input2\n ; remainder01\n ; remainder2\n ; quotient0\n ; quotient1\n ; quotient2\n ; quotient_hi_bound\n ; product1_lo\n ; product1_hi_0\n ; product1_hi_1\n ; carry0\n ; carry1_0\n ; carry1_12\n ; carry1_24\n ; carry1_36\n ; carry1_48\n ; carry1_60\n ; carry1_72\n ; carry1_84\n ; carry1_86\n ; carry1_88\n ; carry1_90\n ; (* Coefficients *) foreign_field_modulus2\n ; neg_foreign_field_modulus0\n ; neg_foreign_field_modulus1\n ; neg_foreign_field_modulus2\n } ) ->\n (*\n | col | `ForeignFieldMul` | `Zero` |\n | --- | ----------------------- | -------------------------- |\n | 0 | `left_input0` (copy) | `remainder01` (copy) |\n | 1 | `left_input1` (copy) | `remainder2` (copy) |\n | 2 | `left_input2` (copy) | `quotient0` (copy) |\n | 3 | `right_input0` (copy) | `quotient1` (copy) |\n | 4 | `right_input1` (copy) | `quotient2` (copy) |\n | 5 | `right_input2` (copy) | `quotient_hi_bound` (copy) |\n | 6 | `product1_lo` (copy) | `product1_hi_0` (copy) |\n | 7 | `carry1_0` (plookup) | `product1_hi_1` (dummy) |\n | 8 | `carry1_12 (plookup) | `carry1_48` (plookup) |\n | 9 | `carry1_24` (plookup) | `carry1_60` (plookup) |\n | 10 | `carry1_36` (plookup) | `carry1_72` (plookup) |\n | 11 | `carry1_84` | `carry0` |\n | 12 | `carry1_86` | |\n | 13 | `carry1_88` | |\n | 14 | `carry1_90` | |\n *)\n (* Current row *)\n let vars_curr =\n [| Some (reduce_to_v left_input0)\n ; Some (reduce_to_v left_input1)\n ; Some (reduce_to_v left_input2)\n ; Some (reduce_to_v right_input0)\n ; Some (reduce_to_v right_input1)\n ; Some (reduce_to_v right_input2)\n ; Some (reduce_to_v product1_lo)\n ; Some (reduce_to_v carry1_0)\n ; Some (reduce_to_v carry1_12)\n ; Some (reduce_to_v carry1_24)\n ; Some (reduce_to_v carry1_36)\n ; Some (reduce_to_v carry1_84)\n ; Some (reduce_to_v carry1_86)\n ; Some (reduce_to_v carry1_88)\n ; Some (reduce_to_v carry1_90)\n |]\n in\n (* Next row *)\n let vars_next =\n [| Some (reduce_to_v remainder01)\n ; Some (reduce_to_v remainder2)\n ; Some (reduce_to_v quotient0)\n ; Some (reduce_to_v quotient1)\n ; Some (reduce_to_v quotient2)\n ; Some (reduce_to_v quotient_hi_bound)\n ; Some (reduce_to_v product1_hi_0)\n ; Some (reduce_to_v product1_hi_1)\n ; Some (reduce_to_v carry1_48)\n ; Some (reduce_to_v carry1_60)\n ; Some (reduce_to_v carry1_72)\n ; Some (reduce_to_v carry0)\n ; None\n ; None\n ; None\n |]\n in\n add_row sys vars_curr ForeignFieldMul\n [| foreign_field_modulus2\n ; neg_foreign_field_modulus0\n ; neg_foreign_field_modulus1\n ; neg_foreign_field_modulus2\n |] ;\n add_row sys vars_next Zero [||]\n | Plonk_constraint.T\n (Rot64\n { word\n ; rotated\n ; excess\n ; bound_limb0\n ; bound_limb1\n ; bound_limb2\n ; bound_limb3\n ; bound_crumb0\n ; bound_crumb1\n ; bound_crumb2\n ; bound_crumb3\n ; bound_crumb4\n ; bound_crumb5\n ; bound_crumb6\n ; bound_crumb7\n ; (* Coefficients *) two_to_rot\n } ) ->\n (*\n //! | Gate | `Rot64` | `RangeCheck0` gadgets (designer's duty) |\n //! | ------ | ------------------- | --------------------------------------------------------- |\n //! | Column | `Curr` | `Next` | `Next` + 1 | `Next`+ 2, if needed |\n //! | ------ | ------------------- | ---------------- | --------------- | -------------------- |\n //! | 0 | copy `word` |`shifted` | copy `excess` | copy `word` |\n //! | 1 | copy `rotated` | 0 | 0 | 0 |\n //! | 2 | `excess` | 0 | 0 | 0 |\n //! | 3 | `bound_limb0` | `shifted_limb0` | `excess_limb0` | `word_limb0` |\n //! | 4 | `bound_limb1` | `shifted_limb1` | `excess_limb1` | `word_limb1` |\n //! | 5 | `bound_limb2` | `shifted_limb2` | `excess_limb2` | `word_limb2` |\n //! | 6 | `bound_limb3` | `shifted_limb3` | `excess_limb3` | `word_limb3` |\n //! | 7 | `bound_crumb0` | `shifted_crumb0` | `excess_crumb0` | `word_crumb0` |\n //! | 8 | `bound_crumb1` | `shifted_crumb1` | `excess_crumb1` | `word_crumb1` |\n //! | 9 | `bound_crumb2` | `shifted_crumb2` | `excess_crumb2` | `word_crumb2` |\n //! | 10 | `bound_crumb3` | `shifted_crumb3` | `excess_crumb3` | `word_crumb3` |\n //! | 11 | `bound_crumb4` | `shifted_crumb4` | `excess_crumb4` | `word_crumb4` |\n //! | 12 | `bound_crumb5` | `shifted_crumb5` | `excess_crumb5` | `word_crumb5` |\n //! | 13 | `bound_crumb6` | `shifted_crumb6` | `excess_crumb6` | `word_crumb6` |\n //! | 14 | `bound_crumb7` | `shifted_crumb7` | `excess_crumb7` | `word_crumb7` |\n *)\n let vars_curr =\n [| (* Current row *) Some (reduce_to_v word)\n ; Some (reduce_to_v rotated)\n ; Some (reduce_to_v excess)\n ; Some (reduce_to_v bound_limb0)\n ; Some (reduce_to_v bound_limb1)\n ; Some (reduce_to_v bound_limb2)\n ; Some (reduce_to_v bound_limb3)\n ; Some (reduce_to_v bound_crumb0)\n ; Some (reduce_to_v bound_crumb1)\n ; Some (reduce_to_v bound_crumb2)\n ; Some (reduce_to_v bound_crumb3)\n ; Some (reduce_to_v bound_crumb4)\n ; Some (reduce_to_v bound_crumb5)\n ; Some (reduce_to_v bound_crumb6)\n ; Some (reduce_to_v bound_crumb7)\n |]\n in\n add_row sys vars_curr Rot64 [| two_to_rot |]\n | Plonk_constraint.T (AddFixedLookupTable { id; data }) -> (\n match sys.fixed_lookup_tables with\n | Unfinalized_fixed_lookup_tables_rev fixed_lookup_tables ->\n let lt : Fp.t Kimchi_types.lookup_table list =\n { id; data } :: fixed_lookup_tables\n in\n sys.fixed_lookup_tables <- Unfinalized_fixed_lookup_tables_rev lt\n | Compiled_fixed_lookup_tables _ ->\n failwith\n \"Trying to add a fixed lookup tables when it has been already \\\n finalized\" )\n | Plonk_constraint.T (AddRuntimeTableCfg { id; first_column }) -> (\n match sys.runtime_tables_cfg with\n | Unfinalized_runtime_tables_cfg_rev runtime_tables_cfg ->\n let rt_cfg : Fp.t Kimchi_types.runtime_table_cfg list =\n { id; first_column } :: runtime_tables_cfg\n in\n sys.runtime_tables_cfg <- Unfinalized_runtime_tables_cfg_rev rt_cfg\n | Compiled_runtime_tables_cfg _ ->\n failwith\n \"Trying to add a runtime table configuration it has been \\\n already finalized\" )\n | Plonk_constraint.T (Raw { kind; values; coeffs }) ->\n let values =\n Array.init 15 ~f:(fun i ->\n (* Insert [None] if the index is beyond the end of the [values]\n array.\n *)\n Option.try_with (fun () -> reduce_to_v values.(i)) )\n in\n add_row sys values kind coeffs\n | constr ->\n failwithf \"Unhandled constraint %s\"\n Obj.(Extension_constructor.name (Extension_constructor.of_val constr))\n ()\nend\n","open Core_kernel\n\ntype ('a, 's) fold = init:'s -> f:('s -> 'a -> 's) -> 's\n\ntype 'a t = { fold : 's. ('a, 's) fold }\n\nlet map (t : 'a t) ~(f : 'a -> 'b) : 'b t =\n { fold =\n (fun ~init ~f:update -> t.fold ~init ~f:(fun acc x -> update acc (f x)))\n }\n\nlet concat (t : 'a t t) : 'a t =\n { fold =\n (fun ~init ~f ->\n t.fold ~init ~f:(fun acc inner -> inner.fold ~init:acc ~f) )\n }\n\nlet concat_map (t : 'a t) ~(f : 'a -> 'b t) : 'b t =\n { fold =\n (fun ~init ~f:update ->\n t.fold ~init ~f:(fun acc x -> (f x).fold ~init:acc ~f:update) )\n }\n\nlet init n ~f:ith_elt =\n { fold =\n (fun ~init ~f ->\n let rec go i acc =\n if i = n then acc else go (i + 1) (f acc (ith_elt i))\n in\n go 0 init )\n }\n\ninclude Monad.Make (struct\n type nonrec 'a t = 'a t\n\n let map = `Custom map\n\n let return x = { fold = (fun ~init ~f -> f init x) }\n\n let bind = concat_map\nend)\n\nlet to_list (t : 'a t) : 'a list =\n List.rev (t.fold ~init:[] ~f:(Fn.flip List.cons))\n\nlet of_list (xs : 'a list) : 'a t =\n { fold = (fun ~init ~f -> List.fold xs ~init ~f) }\n\nlet of_array (xs : 'a array) : 'a t =\n { fold = (fun ~init ~f -> Array.fold xs ~init ~f) }\n\nlet%test_unit \"fold-to-list\" =\n Quickcheck.test (Quickcheck.Generator.list Int.quickcheck_generator)\n ~f:(fun xs -> assert ([%equal: Int.t list] xs (to_list (of_list xs))))\n\nlet sexp_of_t f t = List.sexp_of_t f (to_list t)\n\nlet compose (t1 : 'a t) (t2 : 'a t) : 'a t =\n { fold = (fun ~init ~f -> t2.fold ~init:(t1.fold ~init ~f) ~f) }\n\nlet ( +> ) = compose\n\nlet group3 ~default (t : 'a t) : ('a * 'a * 'a) t =\n { fold =\n (fun ~init ~f ->\n let pt, bs =\n t.fold ~init:(init, []) ~f:(fun (pt, bs) b ->\n match bs with\n | [ b2; b1; b0 ] ->\n let pt' = f pt (b0, b1, b2) in\n (pt', [ b ])\n | _ ->\n (pt, b :: bs) )\n in\n match bs with\n | [ b2; b1; b0 ] ->\n f pt (b0, b1, b2)\n | [ b1; b0 ] ->\n f pt (b0, b1, default)\n | [ b0 ] ->\n f pt (b0, default, default)\n | [] ->\n pt\n | _x1 :: _x2 :: _x3 :: _x4 :: _ ->\n assert false )\n }\n\nlet%test_unit \"group3\" =\n Quickcheck.test (Quickcheck.Generator.list Int.quickcheck_generator)\n ~f:(fun xs ->\n let default = 0 in\n let n = List.length xs in\n let tuples = to_list (group3 ~default (of_list xs)) in\n let k = List.length tuples in\n let r = n mod 3 in\n (let padded =\n xs @ if r = 0 then [] else List.init (3 - r) ~f:(fun _ -> default)\n in\n let concated =\n List.concat_map ~f:(fun (b1, b2, b3) -> [ b1; b2; b3 ]) tuples\n in\n [%test_eq: int list] padded concated ) ;\n assert ((n + 2) / 3 = k) )\n\nlet string_bits s =\n let ith_bit_int n i = (n lsr i) land 1 = 1 in\n { fold =\n (fun ~init ~f ->\n String.fold s ~init ~f:(fun acc c ->\n let c = Char.to_int c in\n let update i acc = f acc (ith_bit_int c i) in\n update 0 acc |> update 1 |> update 2 |> update 3 |> update 4\n |> update 5 |> update 6 |> update 7 ) )\n }\n\nlet bool_t_to_string =\n let module State = struct\n type t = { curr : int; acc : char list; i : int }\n end in\n let open State in\n fun t ->\n let { curr; i; acc } =\n t.fold ~init:{ curr = 0; acc = []; i = 0 } ~f:(fun { curr; acc; i } b ->\n let curr = if b then curr lor (1 lsl i) else curr in\n if i = 7 then { i = 0; acc = Char.of_int_exn curr :: acc; curr = 0 }\n else { i = i + 1; acc; curr } )\n in\n let cs = if i = 0 then acc else Char.of_int_exn curr :: acc in\n String.of_char_list cs\n\nlet string_triples s = group3 ~default:false (string_bits s)\n","open Core_kernel\nopen Fold_lib\nopen Tuple_lib\n\nlet ( = ) = `Don't_use_polymorphic_equality\n\nmodule type Basic_intf = sig\n module Nat : Nat_intf.S\n\n type t [@@deriving eq]\n\n val order : Nat.t\n\n val one : t\n\n val zero : t\n\n val ( + ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val ( / ) : t -> t -> t\n\n val square : t -> t\nend\n\nmodule type Intf = sig\n type t [@@deriving bin_io, sexp, yojson, compare, hash]\n\n include Basic_intf with type t := t\n\n val gen : t Quickcheck.Generator.t\n\n val gen_incl : t -> t -> t Quickcheck.Generator.t\n\n val gen_uniform : t Quickcheck.Generator.t\n\n val gen_uniform_incl : t -> t -> t Quickcheck.Generator.t\n\n val random : unit -> t\n\n val negate : t -> t\n\n val inv : t -> t\n\n val parity : t -> bool\nend\n\nmodule type Sqrt_field_intf = sig\n include Intf\n\n val is_square : t -> bool\n\n val sqrt : t -> t\nend\n\nmodule type Extended_intf = sig\n include Sqrt_field_intf\n\n val ( ** ) : t -> Nat.t -> t\nend\n\nmodule type Fp_intf = sig\n include Intf\n\n include Stringable.S with type t := t\n\n include Stringable.S with type t := t\n\n val of_int : int -> t\n\n val of_bits : bool list -> t option\n\n val to_bigint : t -> Nat.t\n\n val of_bigint : Nat.t -> t\n\n val fold_bits : t -> bool Fold.t\n\n val fold : t -> bool Triple.t Fold.t\n\n val to_bits : t -> bool list\n\n val length_in_bits : int\n\n val is_square : t -> bool\n\n val sqrt : t -> t\nend\n\nmodule type Extension_intf = sig\n type base\n\n include Extended_intf\n\n val scale : t -> base -> t\n\n val of_base : base -> t\n\n val project_to_base : t -> base\n\n val to_list : t -> base list\nend\n\nmodule Extend (F : Basic_intf) = struct\n open F\n\n let ( ** ) x n =\n let k = Nat.num_bits n in\n let rec go acc i =\n if Int.(i < 0) then acc\n else\n let acc = square acc in\n let acc = if Nat.test_bit n i then acc * x else acc in\n go acc Int.(i - 1)\n in\n go one Int.(k - 1)\n\n let is_square =\n let euler = Nat.((order - of_int 1) // of_int 2) in\n fun x -> equal (x ** euler) one\n\n module Sqrt_params = struct\n let two_adicity n =\n let rec go i = if Nat.test_bit n i then i else go Int.(i + 1) in\n go 0\n\n type nonrec t =\n { two_adicity : int\n ; quadratic_non_residue_to_t : t\n ; t_minus_1_over_2 : Nat.t\n }\n\n let first f =\n let rec go i = match f i with Some x -> x | None -> go (i + one) in\n go one\n\n let create () =\n let p_minus_one = Nat.(order - of_int 1) in\n let s = two_adicity p_minus_one in\n let t = Nat.shift_right p_minus_one s in\n let quadratic_non_residue =\n first (fun i -> Option.some_if (not (is_square i)) i)\n in\n { two_adicity = s\n ; quadratic_non_residue_to_t = quadratic_non_residue ** t\n ; t_minus_1_over_2 = Nat.((t - of_int 1) // of_int 2)\n }\n\n let t = lazy (create ())\n end\n\n let rec loop ~while_ ~init f =\n if while_ init then loop ~while_ ~init:(f init) f else init\n\n let rec pow2 b n = if n > 0 then pow2 (square b) Int.(n - 1) else b\n\n let sqrt =\n let pow2_order b =\n loop\n ~while_:(fun (b2m, _) -> not (equal b2m one))\n ~init:(b, 0)\n (fun (b2m, m) -> (square b2m, Int.succ m))\n |> snd\n in\n let module Loop_params = struct\n type nonrec t = { z : t; b : t; x : t; v : int }\n end in\n let open Loop_params in\n fun a ->\n let { Sqrt_params.two_adicity = v\n ; quadratic_non_residue_to_t = z\n ; t_minus_1_over_2\n } =\n Lazy.force Sqrt_params.t\n in\n let w = a ** t_minus_1_over_2 in\n let x = a * w in\n let b = x * w in\n let { x; _ } =\n loop\n ~while_:(fun p -> not (equal p.b one))\n ~init:{ z; b; x; v }\n (fun { z; b; x; v } ->\n let m = pow2_order b in\n let w = pow2 z Int.(v - m - 1) in\n let z = square w in\n { z; b = b * z; x = x * w; v = m } )\n in\n x\nend\n\nmodule Make_fp\n (N : Nat_intf.S) (Info : sig\n val order : N.t\n end) : Fp_intf with module Nat = N and type t = private N.t = struct\n include Info\n\n module T = struct\n let zero = N.of_int 0\n\n let one = N.of_int 1\n\n let length_in_bits = N.num_bits N.(Info.order - one)\n\n module Nat = N\n open Nat\n\n let order = Info.order\n\n (* TODO version *)\n type t = N.t [@@deriving eq, sexp, yojson, compare, hash]\n\n let length_in_bytes = Int.((length_in_bits + 7) / 8)\n\n (** serialization meant to be identical to field serializations in snarky *)\n include Bin_prot.Utils.Of_minimal (struct\n type nonrec t = t\n\n (* increment if serialization changes *)\n let version = 1\n\n let bin_shape_t =\n Bin_prot.Shape.basetype\n (Bin_prot.Shape.Uuid.of_string\n (sprintf \"snarkette_field_%d_V%d\" length_in_bytes version) )\n []\n\n let __bin_read_t__ _buf ~pos_ref _vint =\n Bin_prot.Common.raise_variant_wrong_type \"Fp.t\" !pos_ref\n\n let bin_size_t _ = length_in_bytes\n\n let bin_write_t buf ~pos t =\n let bs = Bigstring.of_string (N.to_bytes t) in\n let n = Bigstring.length bs in\n Bigstring.blit ~src:bs ~dst:buf ~src_pos:0 ~dst_pos:pos ~len:n ;\n if Int.(n < length_in_bytes) then\n for i = n to Int.(length_in_bytes - 1) do\n Bigstring.set buf Int.(pos + i) '\\000'\n done ;\n Int.(pos + length_in_bytes)\n\n let bin_read_t buf ~pos_ref =\n let open Int in\n let remaining_bytes = Bigstring.length buf - !pos_ref in\n if remaining_bytes < length_in_bytes then\n failwithf \"Field.bin_read_t: Expected %d bytes, got %d\"\n length_in_bytes remaining_bytes () ;\n let t =\n N.of_bytes\n (Bigstring.to_string buf ~pos:!pos_ref ~len:length_in_bytes)\n in\n pos_ref := length_in_bytes + !pos_ref ;\n t\n end)\n\n let ( + ) x y = (x + y) % Info.order\n\n let ( - ) x y = (x - y) % Info.order\n\n let ( * ) x y = x * y % Info.order\n\n let square x = x * x\n\n let rec extended_euclidean a b =\n if equal b zero then (a, one, zero)\n else\n match extended_euclidean b (a % b) with\n | d, x, y ->\n (d, y, x - (a // b * y))\n\n let inv_no_mod x =\n let _, a, _b = extended_euclidean x Info.order in\n a\n\n let inv x = inv_no_mod x % Info.order\n\n let ( / ) x y = x * inv_no_mod y\n end\n\n include Extend (T)\n include T\n\n let of_bigint x = N.(x % Info.order)\n\n let to_bigint = Fn.id\n\n let parity t = N.test_bit (to_bigint t) 0\n\n let make_gen gen lo hi =\n let t_of_bignum_bigint n = Bigint.to_string n |> N.of_string in\n Quickcheck.Generator.map (gen lo hi) ~f:t_of_bignum_bigint\n\n (* fix zero, size - 1 bounds *)\n let make_gen_full gen =\n let size = order |> N.to_string |> Bigint.of_string in\n make_gen gen Bigint.zero Bigint.(size - one)\n\n let gen = make_gen_full Bigint.gen_incl\n\n let gen_incl lo hi =\n let bignum_bigint_of_t t = N.to_string t |> Bigint.of_string in\n make_gen Bigint.gen_incl (bignum_bigint_of_t lo) (bignum_bigint_of_t hi)\n\n let gen_uniform = make_gen_full Bigint.gen_uniform_incl\n\n let gen_uniform_incl lo hi =\n let bignum_bigint_of_t t = N.to_string t |> Bigint.of_string in\n make_gen Bigint.gen_uniform_incl (bignum_bigint_of_t lo)\n (bignum_bigint_of_t hi)\n\n let random () = Quickcheck.random_value gen_uniform\n\n let fold_bits n : bool Fold_lib.Fold.t =\n { fold =\n (fun ~init ~f ->\n let rec go acc i =\n if Int.(i = length_in_bits) then acc\n else go (f acc (N.test_bit n i)) Int.(i + 1)\n in\n go init 0 )\n }\n\n let to_bits = Fn.compose Fold_lib.Fold.to_list fold_bits\n\n let fold n = Fold_lib.Fold.group3 ~default:false (fold_bits n)\n\n let of_bits bits =\n let rec go acc i = function\n | [] ->\n acc\n | b :: bs ->\n let acc = if b then N.log_or acc (N.shift_left one i) else acc in\n go acc Int.(i + 1) bs\n in\n let r = go zero 0 bits in\n if N.( < ) r Info.order then Some r else None\n\n open N\n\n let of_int = N.of_int\n\n let of_string = N.of_string\n\n let to_string = N.to_string\n\n let negate x = N.( - ) Info.order x\n\n let%test_unit \"exp test\" = [%test_eq: t] (of_int 8) (of_int 2 ** of_int 3)\n\n let%test_unit \"pow2\" =\n let b = 7 in\n if N.(of_int Int.(7 ** 8) < order) then\n [%test_eq: t] (pow2 (of_int b) 3) (of_int Int.(7 ** 8))\n else ()\n\n let%test_unit \"sqrt agrees with integer square root on small values\" =\n let rec mem a = function\n | [] ->\n ()\n | x :: xs -> (\n try [%test_eq: t] a x with _ -> mem a xs )\n in\n let gen = Int.gen_incl 1 Int.max_value_30_bits in\n Quickcheck.test ~trials:10 gen ~f:(fun n ->\n let n = abs n in\n let n2 = Int.(n * n) in\n mem (sqrt (of_int n2)) [ of_int n; Info.order - of_int n ] )\nend\n\nmodule type Degree_2_extension_intf = sig\n type base\n\n include Extension_intf with type base := base and type t = base * base\nend\n\nmodule type Degree_3_extension_intf = sig\n type base\n\n include Extension_intf with type base := base and type t = base * base * base\nend\n\nlet ( % ) x n =\n let r = x mod n in\n if r < 0 then r + n else r\n\nlet find_wnaf (type t) (module N : Nat_intf.S with type t = t) window_size\n scalar =\n let one = N.of_int 1 in\n let first_k_bits c k =\n let k_bits = N.(shift_left one k - one) in\n N.to_int_exn (N.log_and k_bits c)\n in\n let length = N.num_bits scalar in\n let res = Array.init (length + 1) ~f:(fun _ -> 0) in\n let zero = N.of_int 0 in\n let rec go c j =\n if N.equal zero c then ()\n else\n let u, c =\n if N.test_bit c 0 then\n let u =\n let u = first_k_bits c (window_size + 1) in\n if u > 1 lsl window_size then u - (1 lsl (window_size + 1)) else u\n in\n let c = N.(c - of_int u) in\n (u, c)\n else (0, c)\n in\n res.(j) <- u ;\n go (N.shift_right c 1) (j + 1)\n in\n go scalar 0 ; res\n\nmodule Make_fp3\n (Fp : Intf) (Info : sig\n val non_residue : Fp.t\n\n val frobenius_coeffs_c1 : Fp.t array\n\n val frobenius_coeffs_c2 : Fp.t array\n end) : sig\n include Degree_3_extension_intf with type base = Fp.t and module Nat = Fp.Nat\n\n val non_residue : Fp.t\n\n val frobenius : t -> int -> t\nend = struct\n include Info\n\n type base = Fp.t\n\n let componentwise f (x1, x2, x3) (y1, y2, y3) = (f x1 y1, f x2 y2, f x3 y3)\n\n let of_base x = (x, Fp.zero, Fp.zero)\n\n module T = struct\n module Nat = Fp.Nat\n\n let order = Nat.(Fp.order * Fp.order * Fp.order)\n\n type t = Fp.t * Fp.t * Fp.t\n [@@deriving eq, bin_io, sexp, yojson, compare, hash]\n\n let ( + ) = componentwise Fp.( + )\n\n let ( - ) = componentwise Fp.( - )\n\n let ( * ) (a1, b1, c1) (a2, b2, c2) =\n let a = Fp.(a1 * a2) in\n let b = Fp.(b1 * b2) in\n let c = Fp.(c1 * c2) in\n let open Fp in\n ( a + (non_residue * (((b1 + c1) * (b2 + c2)) - b - c))\n , ((a1 + b1) * (a2 + b2)) - a - b + (non_residue * c)\n , ((a1 + c1) * (a2 + c2)) - a + b - c )\n\n let square (a, b, c) =\n let s0 = Fp.square a in\n let ab = Fp.(a * b) in\n let s1 = Fp.(ab + ab) in\n let s2 = Fp.(square (a - b + c)) in\n let bc = Fp.(b * c) in\n let s3 = Fp.(bc + bc) in\n let s4 = Fp.square c in\n let open Fp in\n (s0 + (non_residue * s3), s1 + (non_residue * s4), s1 + s2 + s3 - s0 - s4)\n\n let inv (a, b, c) =\n let open Fp in\n let t0 = square a in\n let t1 = square b in\n let t2 = square c in\n let t3 = a * b in\n let t4 = a * c in\n let t5 = b * c in\n let c0 = t0 - (non_residue * t5) in\n let c1 = (non_residue * t2) - t3 in\n let c2 = t1 - t4 in\n let t6 = (a * c0) + (non_residue * ((c * c1) + (b * c2))) |> inv in\n (t6 * c0, t6 * c1, t6 * c2)\n\n let ( / ) x y = x * inv y\n\n let one = of_base Fp.one\n\n let zero = of_base Fp.zero\n end\n\n include T\n include Extend (T)\n\n let gen = Quickcheck.Generator.tuple3 Fp.gen Fp.gen Fp.gen\n\n let gen_incl (lo1, lo2, lo3) (hi1, hi2, hi3) =\n Quickcheck.Generator.tuple3 (Fp.gen_incl lo1 hi1) (Fp.gen_incl lo2 hi2)\n (Fp.gen_incl lo3 hi3)\n\n let gen_uniform =\n Quickcheck.Generator.tuple3 Fp.gen_uniform Fp.gen_uniform Fp.gen_uniform\n\n let gen_uniform_incl (lo1, lo2, lo3) (hi1, hi2, hi3) =\n Quickcheck.Generator.tuple3\n (Fp.gen_uniform_incl lo1 hi1)\n (Fp.gen_uniform_incl lo2 hi2)\n (Fp.gen_uniform_incl lo3 hi3)\n\n let random () = Quickcheck.random_value gen_uniform\n\n let to_list (x, y, z) = [ x; y; z ]\n\n let project_to_base (x, _, _) = x\n\n let parity = Fn.compose Fp.parity project_to_base\n\n let scale (x1, x2, x3) s = Fp.(s * x1, s * x2, s * x3)\n\n let negate (x1, x2, x3) = Fp.(negate x1, negate x2, negate x3)\n\n let frobenius (c0, c1, c2) power =\n let open Fp in\n let open Info in\n let i = power mod 3 in\n (c0, frobenius_coeffs_c1.(i) * c1, frobenius_coeffs_c2.(i) * c2)\nend\n\nmodule Make_fp2\n (Fp : Intf) (Info : sig\n val non_residue : Fp.t\n end) : sig\n include Degree_2_extension_intf with type base = Fp.t and module Nat = Fp.Nat\nend = struct\n type base = Fp.t\n\n let of_base x = (x, Fp.zero)\n\n let componentwise f (x1, x2) (y1, y2) = (f x1 y1, f x2 y2)\n\n module T = struct\n type t = Fp.t * Fp.t [@@deriving eq, yojson, bin_io, sexp, compare, hash]\n\n module Nat = Fp.Nat\n\n let order = Nat.(Fp.order * Fp.order)\n\n let one = of_base Fp.one\n\n let zero = of_base Fp.zero\n\n let ( + ) = componentwise Fp.( + )\n\n let ( - ) = componentwise Fp.( - )\n\n let square (a, b) =\n let open Info in\n let ab = Fp.(a * b) in\n Fp.(((a + b) * (a + (non_residue * b))) - ab - (non_residue * ab), ab + ab)\n\n let ( * ) (a1, b1) (a2, b2) =\n let open Fp in\n let a = a1 * a2 in\n let b = b1 * b2 in\n (a + (Info.non_residue * b), ((a1 + b1) * (a2 + b2)) - a - b)\n\n let inv (a, b) =\n let open Fp in\n let t0 = square a in\n let t1 = square b in\n let t2 = t0 - (Info.non_residue * t1) in\n let t3 = inv t2 in\n let c0 = a * t3 in\n let c1 = negate (b * t3) in\n (c0, c1)\n\n let ( / ) x y = x * inv y\n end\n\n include T\n include Extend (T)\n\n let gen = Quickcheck.Generator.tuple2 Fp.gen Fp.gen\n\n let gen_incl (lo1, lo2) (hi1, hi2) =\n Quickcheck.Generator.tuple2 (Fp.gen_incl lo1 hi1) (Fp.gen_incl lo2 hi2)\n\n let gen_uniform = Quickcheck.Generator.tuple2 Fp.gen_uniform Fp.gen_uniform\n\n let gen_uniform_incl (lo1, lo2) (hi1, hi2) =\n Quickcheck.Generator.tuple2\n (Fp.gen_uniform_incl lo1 hi1)\n (Fp.gen_uniform_incl lo2 hi2)\n\n let random () = Quickcheck.random_value gen_uniform\n\n let to_list (x, y) = [ x; y ]\n\n let project_to_base (x, _) = x\n\n let parity = Fn.compose Fp.parity project_to_base\n\n let scale (x1, x2) s = Fp.(s * x1, s * x2)\n\n let negate (a, b) = Fp.(negate a, negate b)\nend\n\nmodule Make_fp6\n (N : Nat_intf.S)\n (Fp : Intf)\n (Fp2 : Degree_2_extension_intf with type base = Fp.t) (Fp3 : sig\n include Degree_3_extension_intf with type base = Fp.t\n\n val frobenius : t -> int -> t\n\n val non_residue : Fp.t\n end) (Info : sig\n val non_residue : Fp.t\n\n val frobenius_coeffs_c1 : Fp.t array\n end) : sig\n include Degree_2_extension_intf with type base = Fp3.t and module Nat = Fp.Nat\n\n val mul_by_2345 : t -> t -> t\n\n val frobenius : t -> int -> t\n\n val cyclotomic_exp : t -> N.t -> t\n\n val unitary_inverse : t -> t\nend = struct\n module T = struct\n module Nat = Fp.Nat\n\n let of_base x = (x, Fp3.zero)\n\n let componentwise f (x1, x2) (y1, y2) = (f x1 y1, f x2 y2)\n\n type t = Fp3.t * Fp3.t [@@deriving eq, yojson, bin_io, sexp, compare, hash]\n\n let order =\n let open Nat in\n let square x = x * x in\n let p = Fp.order in\n square (p * square p)\n\n let zero = of_base Fp3.zero\n\n let one = of_base Fp3.one\n\n let ( + ) = componentwise Fp3.( + )\n\n let ( - ) = componentwise Fp3.( - )\n\n let mul_by_non_residue ((c0, c1, c2) : Fp3.t) =\n Fp.(Info.non_residue * c2, c0, c1)\n\n let square (a, b) =\n let ab = Fp3.(a * b) in\n let open Fp3 in\n ( ((a + b) * (a + mul_by_non_residue b)) - ab - mul_by_non_residue ab\n , ab + ab )\n\n let ( * ) (a1, b1) (a2, b2) =\n let a = Fp3.(a1 * a2) in\n let b = Fp3.(b1 * b2) in\n let beta_b = mul_by_non_residue b in\n Fp3.(a + beta_b, ((a1 + b1) * (a2 + b2)) - a - b)\n\n let inv (a, b) =\n let t1 = Fp3.square b in\n let t0 = Fp3.(square a - mul_by_non_residue t1) in\n let new_t1 = Fp3.inv t0 in\n Fp3.(a * new_t1, negate (b * new_t1))\n\n let ( / ) x y = x * inv y\n end\n\n include T\n include Extend (T)\n\n type base = Fp3.t\n\n let gen = Quickcheck.Generator.tuple2 Fp3.gen Fp3.gen\n\n let gen_incl (lo1, lo2) (hi1, hi2) =\n Quickcheck.Generator.tuple2 (Fp3.gen_incl lo1 hi1) (Fp3.gen_incl lo2 hi2)\n\n let gen_uniform = Quickcheck.Generator.tuple2 Fp3.gen_uniform Fp3.gen_uniform\n\n let gen_uniform_incl (lo1, lo2) (hi1, hi2) =\n Quickcheck.Generator.tuple2\n (Fp3.gen_uniform_incl lo1 hi1)\n (Fp3.gen_uniform_incl lo2 hi2)\n\n let random () = Quickcheck.random_value gen_uniform\n\n let to_list (x, y) = [ x; y ]\n\n let project_to_base (x, _) = x\n\n let parity = Fn.compose Fp3.parity project_to_base\n\n let scale (x1, x2) s = Fp3.(s * x1, s * x2)\n\n let mul_by_2345 (a1, b1) (a2, b2) =\n let open Info in\n let a1_0, a1_1, a1_2 = a1 in\n let _, _, a2_2 = a2 in\n (let a2_0, a2_1, _ = a2 in\n assert (Fp.(equal a2_0 zero)) ;\n assert (Fp.(equal a2_1 zero)) ) ;\n let a =\n Fp.(a1_1 * a2_2 * non_residue, a1_2 * a2_2 * non_residue, a1_0 * a2_2)\n in\n let b = Fp3.(b1 * b2) in\n let beta_b = mul_by_non_residue b in\n Fp3.(a + beta_b, ((a1 + b2) * (a2 + b2)) - a - b)\n\n let negate (a, b) = Fp3.(negate a, negate b)\n\n let unitary_inverse (x, y) = (x, Fp3.negate y)\n\n let cyclotomic_square ((c00, c01, c02), (c10, c11, c12)) =\n let a : Fp2.t = (c00, c11) in\n let b : Fp2.t = (c10, c02) in\n let c : Fp2.t = (c01, c12) in\n let asq = Fp2.square a in\n let bsq = Fp2.square b in\n let csq = Fp2.square c in\n let a_a =\n let open Fp in\n let a_a = fst asq - fst a in\n a_a + a_a + fst asq\n in\n let a_b =\n let open Fp in\n let a_b = snd asq + snd a in\n a_b + a_b + snd asq\n in\n let b_a =\n let open Fp in\n let b_tmp = Fp3.non_residue * snd csq in\n let b_a = b_tmp + fst b in\n b_a + b_a + b_tmp\n in\n let b_b =\n let open Fp in\n let b_b = fst csq - snd b in\n b_b + b_b + fst csq\n in\n let c_a =\n let open Fp in\n let c_a = fst bsq - fst c in\n c_a + c_a + fst bsq\n in\n let c_b =\n let open Fp in\n let c_b = snd bsq + snd c in\n c_b + c_b + snd bsq\n in\n ((a_a, c_a, b_b), (b_a, a_b, c_b))\n\n let cyclotomic_exp x exponent =\n let x_inv = inv x in\n let naf = find_wnaf (module N) 1 exponent in\n let rec go found_nonzero res i =\n if i < 0 then res\n else\n let res = if found_nonzero then cyclotomic_square res else res in\n if naf.(i) <> 0 then\n let found_nonzero = true in\n let res = if naf.(i) > 0 then res * x else res * x_inv in\n go found_nonzero res Int.(i - 1)\n else go found_nonzero res Int.(i - 1)\n in\n go false one Int.(Array.length naf - 1)\n\n let frobenius (c0, c1) power =\n ( Fp3.frobenius c0 power\n , Fp3.(scale (frobenius c1 power) Info.frobenius_coeffs_c1.(power mod 6)) )\nend\n","open Core_kernel\nopen Kimchi_backend_common\nopen Kimchi_pasta_basic\nmodule Field = Fp\nmodule Curve = Vesta\n\nmodule Bigint = struct\n include Field.Bigint\n\n let of_data _ = failwith __LOC__\n\n let to_field = Field.of_bigint\n\n let of_field = Field.to_bigint\nend\n\nlet field_size : Bigint.t = Field.size\n\nmodule Verification_key = struct\n type t =\n ( Pasta_bindings.Fp.t\n , Kimchi_bindings.Protocol.SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm )\n Kimchi_types.VerifierIndex.verifier_index\n\n let to_string _ = failwith __LOC__\n\n let of_string _ = failwith __LOC__\n\n let shifts (t : t) = t.shifts\nend\n\nmodule R1CS_constraint_system =\n Kimchi_pasta_constraint_system.Vesta_constraint_system\n\nlet lagrange srs domain_log2 : _ Kimchi_types.poly_comm array =\n let domain_size = Int.pow 2 domain_log2 in\n Array.init domain_size ~f:(fun i ->\n Kimchi_bindings.Protocol.SRS.Fp.lagrange_commitment srs domain_size i )\n\nlet with_lagrange f (vk : Verification_key.t) =\n f (lagrange vk.srs vk.domain.log_size_of_group) vk\n\nlet with_lagranges f (vks : Verification_key.t array) =\n let lgrs =\n Array.map vks ~f:(fun vk -> lagrange vk.srs vk.domain.log_size_of_group)\n in\n f lgrs vks\n\nmodule Rounds_vector = Rounds.Step_vector\nmodule Rounds = Rounds.Step\n\nmodule Keypair = Dlog_plonk_based_keypair.Make (struct\n let name = \"vesta\"\n\n module Rounds = Rounds\n module Urs = Kimchi_bindings.Protocol.SRS.Fp\n module Index = Kimchi_bindings.Protocol.Index.Fp\n module Curve = Curve\n module Poly_comm = Fp_poly_comm\n module Scalar_field = Field\n module Verifier_index = Kimchi_bindings.Protocol.VerifierIndex.Fp\n module Gate_vector = Kimchi_bindings.Protocol.Gates.Vector.Fp\n module Constraint_system = R1CS_constraint_system\nend)\n\nmodule Proof = Plonk_dlog_proof.Make (struct\n let id = \"pasta_vesta\"\n\n module Scalar_field = Field\n module Base_field = Fq\n\n module Backend = struct\n type t =\n ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.prover_proof\n\n type with_public_evals =\n ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n\n include Kimchi_bindings.Protocol.Proof.Fp\n\n let batch_verify vks ts =\n Promise.run_in_thread (fun () -> batch_verify vks ts)\n\n let create_aux ~f:create (pk : Keypair.t) primary auxiliary prev_chals\n prev_comms =\n (* external values contains [1, primary..., auxiliary ] *)\n let external_values i =\n let open Field.Vector in\n if i < length primary then get primary i\n else get auxiliary (i - length primary)\n in\n\n (* compute witness *)\n let computed_witness, runtime_tables =\n R1CS_constraint_system.compute_witness pk.cs external_values\n in\n let num_rows = Array.length computed_witness.(0) in\n\n (* convert to Rust vector *)\n let witness_cols =\n Array.init Kimchi_backend_common.Constants.columns ~f:(fun col ->\n let witness = Field.Vector.create () in\n for row = 0 to num_rows - 1 do\n Field.Vector.emplace_back witness computed_witness.(col).(row)\n done ;\n witness )\n in\n create pk.index witness_cols runtime_tables prev_chals prev_comms\n\n let create_async (pk : Keypair.t) ~primary ~auxiliary ~prev_chals\n ~prev_comms =\n create_aux pk primary auxiliary prev_chals prev_comms\n ~f:(fun pk auxiliary_input runtime_tables prev_challenges prev_sgs ->\n Promise.run_in_thread (fun () ->\n create pk auxiliary_input runtime_tables prev_challenges prev_sgs ) )\n\n let create (pk : Keypair.t) ~primary ~auxiliary ~prev_chals ~prev_comms =\n create_aux pk primary auxiliary prev_chals prev_comms ~f:create\n end\n\n module Verifier_index = Kimchi_bindings.Protocol.VerifierIndex.Fp\n module Index = Keypair\n\n module Evaluations_backend = struct\n type t = Scalar_field.t Kimchi_types.proof_evaluations\n end\n\n module Opening_proof_backend = struct\n type t = (Curve.Affine.Backend.t, Scalar_field.t) Kimchi_types.opening_proof\n end\n\n module Poly_comm = Fp_poly_comm\n module Curve = Curve\nend)\n\nmodule Proving_key = struct\n type t = Keypair.t\n\n include\n Core_kernel.Binable.Of_binable\n (Core_kernel.Unit)\n (struct\n type nonrec t = t\n\n let to_binable _ = ()\n\n let of_binable () = failwith \"TODO\"\n end)\n\n let is_initialized _ = `Yes\n\n let set_constraint_system _ _ = ()\n\n let to_string _ = failwith \"TODO\"\n\n let of_string _ = failwith \"TODO\"\nend\n\nmodule Oracles = Plonk_dlog_oracles.Make (struct\n module Verifier_index = Verification_key\n module Field = Field\n module Proof = Proof\n\n module Backend = struct\n include Kimchi_bindings.Protocol.Oracles.Fp\n\n let create = with_lagrange create\n\n let create_with_public_evals = with_lagrange create_with_public_evals\n end\nend)\n","open Core_kernel\nopen Kimchi_backend_common\nopen Kimchi_pasta_basic\nmodule Field = Fq\nmodule Curve = Pallas\n\nmodule Bigint = struct\n include Field.Bigint\n\n let of_data _ = failwith __LOC__\n\n let to_field = Field.of_bigint\n\n let of_field = Field.to_bigint\nend\n\nlet field_size : Bigint.t = Field.size\n\nmodule Verification_key = struct\n type t =\n ( Pasta_bindings.Fq.t\n , Kimchi_bindings.Protocol.SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm )\n Kimchi_types.VerifierIndex.verifier_index\n\n let to_string _ = failwith __LOC__\n\n let of_string _ = failwith __LOC__\n\n let shifts (t : t) : Field.t array = t.shifts\nend\n\n(* TODO: change name *)\nmodule R1CS_constraint_system =\n Kimchi_pasta_constraint_system.Pallas_constraint_system\n\nlet lagrange srs domain_log2 : _ Kimchi_types.poly_comm array =\n let domain_size = Int.pow 2 domain_log2 in\n Array.init domain_size ~f:(fun i ->\n Kimchi_bindings.Protocol.SRS.Fq.lagrange_commitment srs domain_size i )\n\nlet with_lagrange f (vk : Verification_key.t) =\n f (lagrange vk.srs vk.domain.log_size_of_group) vk\n\nlet with_lagranges f (vks : Verification_key.t array) =\n let lgrs =\n Array.map vks ~f:(fun vk -> lagrange vk.srs vk.domain.log_size_of_group)\n in\n f lgrs vks\n\nmodule Rounds_vector = Rounds.Wrap_vector\nmodule Rounds = Rounds.Wrap\n\nmodule Keypair = Dlog_plonk_based_keypair.Make (struct\n let name = \"pallas\"\n\n module Rounds = Rounds\n module Urs = Kimchi_bindings.Protocol.SRS.Fq\n module Index = Kimchi_bindings.Protocol.Index.Fq\n module Curve = Curve\n module Poly_comm = Fq_poly_comm\n module Scalar_field = Field\n module Verifier_index = Kimchi_bindings.Protocol.VerifierIndex.Fq\n module Gate_vector = Kimchi_bindings.Protocol.Gates.Vector.Fq\n module Constraint_system = R1CS_constraint_system\nend)\n\nmodule Proof = Plonk_dlog_proof.Make (struct\n let id = \"pasta_pallas\"\n\n module Scalar_field = Field\n module Base_field = Fp\n\n module Backend = struct\n type t =\n ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.prover_proof\n\n type with_public_evals =\n ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n\n include Kimchi_bindings.Protocol.Proof.Fq\n\n let batch_verify vks ts =\n Promise.run_in_thread (fun () -> batch_verify vks ts)\n\n let create_aux ~f:create (pk : Keypair.t) ~primary ~auxiliary ~prev_chals\n ~prev_comms =\n (* external values contains [1, primary..., auxiliary ] *)\n let external_values i =\n let open Field.Vector in\n if i < length primary then get primary i\n else get auxiliary (i - length primary)\n in\n\n (* compute witness *)\n let computed_witness, runtime_tables =\n R1CS_constraint_system.compute_witness pk.cs external_values\n in\n let num_rows = Array.length computed_witness.(0) in\n\n (* convert to Rust vector *)\n let witness_cols =\n Array.init Kimchi_backend_common.Constants.columns ~f:(fun col ->\n let witness = Field.Vector.create () in\n for row = 0 to num_rows - 1 do\n Field.Vector.emplace_back witness computed_witness.(col).(row)\n done ;\n witness )\n in\n create pk.index witness_cols runtime_tables prev_chals prev_comms\n\n let create_async (pk : Keypair.t) ~primary ~auxiliary ~prev_chals\n ~prev_comms =\n create_aux pk ~primary ~auxiliary ~prev_chals ~prev_comms\n ~f:(fun pk auxiliary_input runtime_tables prev_challenges prev_sgs ->\n Promise.run_in_thread (fun () ->\n create pk auxiliary_input runtime_tables prev_challenges prev_sgs ) )\n\n let create (pk : Keypair.t) ~primary ~auxiliary ~prev_chals ~prev_comms =\n create_aux pk ~primary ~auxiliary ~prev_chals ~prev_comms ~f:create\n end\n\n module Verifier_index = Kimchi_bindings.Protocol.VerifierIndex.Fq\n module Index = Keypair\n\n module Evaluations_backend = struct\n type t = Scalar_field.t Kimchi_types.proof_evaluations\n end\n\n module Opening_proof_backend = struct\n type t = (Curve.Affine.Backend.t, Scalar_field.t) Kimchi_types.opening_proof\n end\n\n module Poly_comm = Fq_poly_comm\n module Curve = Curve\nend)\n\nmodule Proving_key = struct\n type t = Keypair.t\n\n include\n Core_kernel.Binable.Of_binable\n (Core_kernel.Unit)\n (struct\n type nonrec t = t\n\n let to_binable _ = ()\n\n let of_binable () = failwith \"TODO\"\n end)\n\n let is_initialized _ = `Yes\n\n let set_constraint_system _ _ = ()\n\n let to_string _ = failwith \"TODO\"\n\n let of_string _ = failwith \"TODO\"\nend\n\nmodule Oracles = Plonk_dlog_oracles.Make (struct\n module Verifier_index = Verification_key\n module Field = Field\n module Proof = Proof\n\n module Backend = struct\n include Kimchi_bindings.Protocol.Oracles.Fq\n\n let create = with_lagrange create\n\n let create_with_public_evals = with_lagrange create_with_public_evals\n end\nend)\n","open Core_kernel\n\nmodule Make () = struct\n let digest_size_in_bits = 256\n\n let digest_size_in_bytes = digest_size_in_bits / 8\n\n module T0 = struct\n include Digestif.Make_BLAKE2B (struct\n let digest_size = digest_size_in_bytes\n end)\n\n let hash = Fn.compose String.hash to_raw_string\n\n let hash_fold_t state t = Hash.fold_string state (to_raw_string t)\n\n let compare = unsafe_compare\n\n let of_string = of_raw_string\n\n let to_string = to_raw_string\n\n let gen =\n let char_generator =\n Base_quickcheck.Generator.of_list\n [ '0'\n ; '1'\n ; '2'\n ; '3'\n ; '4'\n ; '5'\n ; '6'\n ; '7'\n ; '8'\n ; '9'\n ; 'A'\n ; 'B'\n ; 'C'\n ; 'D'\n ; 'E'\n ; 'F'\n ]\n in\n String.gen_with_length (digest_size_in_bytes * 2) char_generator\n |> Quickcheck.Generator.map ~f:of_hex\n end\n\n module T1 = struct\n include T0\n include Sexpable.Of_stringable (T0)\n end\n\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n type t = T1.t [@@deriving hash, sexp, compare, equal]\n\n let to_latest = Fn.id\n\n let to_yojson t : Yojson.Safe.t = `String (T1.to_hex t)\n\n let of_yojson (v : Yojson.Safe.t) =\n let open Ppx_deriving_yojson_runtime in\n match v with\n | `String s ->\n Option.value_map ~default:(Result.Error \"not a hex string\")\n ~f:(fun x -> Result.Ok x)\n (T1.of_hex_opt s)\n | _ ->\n Result.Error \"not a string\"\n\n module Arg = struct\n type nonrec t = t\n\n [%%define_locally T1.(to_string, of_string)]\n end\n\n include Binable.Of_stringable_without_uuid (Arg)\n end\n end]\n\n [%%define_locally Stable.Latest.(to_yojson, of_yojson)]\n\n [%%define_locally\n T1.\n ( of_raw_string\n , to_raw_string\n , digest_string\n , digest_bigstring\n , to_hex\n , of_hex\n , gen )]\n\n (* do not create bin_io serialization *)\n include Hashable.Make (T1)\n include Comparable.Make (T1)\n\n (* Little endian *)\n let bits_to_string bits =\n let n = Array.length bits in\n let rec make_byte offset acc (i : int) =\n let finished = Int.(i = 8 || offset + i >= n) in\n if finished then Char.of_int_exn acc\n else\n let acc = if bits.(offset + i) then acc lor (1 lsl i) else acc in\n make_byte offset acc (i + 1)\n in\n let len = (n + 7) / 8 in\n String.init len ~f:(fun i -> make_byte (8 * i) 0 0)\n\n let string_to_bits s =\n Array.init\n (8 * String.length s)\n ~f:(fun i ->\n let c = Char.to_int s.[i / 8] in\n let j = i mod 8 in\n Int.((c lsr j) land 1 = 1) )\nend\n\ninclude Make ()\n\nlet%test_unit \"bits_to_string\" =\n [%test_eq: string]\n (bits_to_string [| true; false |])\n (String.of_char_list [ Char.of_int_exn 1 ])\n\nlet%test_unit \"string to bits\" =\n Quickcheck.test ~trials:5 String.quickcheck_generator ~f:(fun s ->\n [%test_eq: string] s (bits_to_string (string_to_bits s)) )\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * Location.t * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | NoVariance\n\n type injectivity (*IF_CURRENT = Asttypes.injectivity *) =\n | Injective\n | NoInjectivity\nend\n\nmodule Parsetree = struct\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * Location.t * string option\n (* \"constant\"\n {delim|other constant|delim}\n\n The location span the content of the string, without the delimiters.\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n type location_stack = Location.t list\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: location_stack;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: location_stack;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P) Some \"P\"\n (module _) None\n\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: location_stack;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * (variance * injectivity)) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * (variance * injectivity)) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n*)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * (variance * injectivity)) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and functor_parameter (*IF_CURRENT = Parsetree.functor_parameter *) =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n (* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string option loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string option loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M029\"\n let ast_intf_magic_number = \"Caml1999N029\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Thomas Gazagnaire, OCamlPro *)\n(* Fabrice Le Fessant, INRIA Saclay *)\n(* Hongbo Zhang, University of Pennsylvania *)\n(* *)\n(* Copyright 2007 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Original Code from Ber-metaocaml, modified for 3.12.0 and fixed *)\n(* Printing code expressions *)\n(* Authors: Ed Pizzi, Fabrice Le Fessant *)\n(* Extensive Rewrite: Hongbo Zhang: University of Pennsylvania *)\n(* TODO more fine-grained precedence pretty-printing *)\n\nopen Ast_412\nopen Asttypes\nopen Format\nopen Location\nopen Longident\nopen Parsetree\n\nlet varify_type_constructors var_names t =\n let check_variable vl loc v =\n if List.mem v vl then\n Location.raise_errorf ~loc \"variable in scope syntax error: %s\" v\n in\n let var_names = List.map (fun v -> v.txt) var_names in\n let rec loop t =\n let desc =\n match t.ptyp_desc with\n | Ptyp_any -> Ptyp_any\n | Ptyp_var x ->\n check_variable var_names t.ptyp_loc x;\n Ptyp_var x\n | Ptyp_arrow (label, core_type, core_type') ->\n Ptyp_arrow (label, loop core_type, loop core_type')\n | Ptyp_tuple lst -> Ptyp_tuple (List.map loop lst)\n | Ptyp_constr ({ txt = Longident.Lident s }, []) when List.mem s var_names\n ->\n Ptyp_var s\n | Ptyp_constr (longident, lst) ->\n Ptyp_constr (longident, List.map loop lst)\n | Ptyp_object (lst, o) -> Ptyp_object (List.map loop_object_field lst, o)\n | Ptyp_class (longident, lst) -> Ptyp_class (longident, List.map loop lst)\n | Ptyp_alias (core_type, string) ->\n check_variable var_names t.ptyp_loc string;\n Ptyp_alias (loop core_type, string)\n | Ptyp_variant (row_field_list, flag, lbl_lst_option) ->\n Ptyp_variant\n (List.map loop_row_field row_field_list, flag, lbl_lst_option)\n | Ptyp_poly (string_lst, core_type) ->\n List.iter\n (fun v -> check_variable var_names t.ptyp_loc v.txt)\n string_lst;\n Ptyp_poly (string_lst, loop core_type)\n | Ptyp_package (longident, lst) ->\n Ptyp_package (longident, List.map (fun (n, typ) -> (n, loop typ)) lst)\n | Ptyp_extension (s, arg) -> Ptyp_extension (s, arg)\n in\n { t with ptyp_desc = desc }\n and loop_row_field field =\n let prf_desc =\n match field.prf_desc with\n | Rtag (label, flag, lst) -> Rtag (label, flag, List.map loop lst)\n | Rinherit t -> Rinherit (loop t)\n in\n { field with prf_desc }\n and loop_object_field field =\n let pof_desc =\n match field.pof_desc with\n | Otag (label, t) -> Otag (label, loop t)\n | Oinherit t -> Oinherit (loop t)\n in\n { field with pof_desc }\n in\n loop t\n\nlet prefix_symbols = [ '!'; '?'; '~' ]\n\nlet infix_symbols =\n [ '='; '<'; '>'; '@'; '^'; '|'; '&'; '+'; '-'; '*'; '/'; '$'; '%'; '#' ]\n\n(* type fixity = Infix| Prefix *)\nlet special_infix_strings =\n [ \"asr\"; \"land\"; \"lor\"; \"lsl\"; \"lsr\"; \"lxor\"; \"mod\"; \"or\"; \":=\"; \"!=\"; \"::\" ]\n\nlet letop s =\n String.length s > 3\n && s.[0] = 'l'\n && s.[1] = 'e'\n && s.[2] = 't'\n && List.mem s.[3] infix_symbols\n\nlet andop s =\n String.length s > 3\n && s.[0] = 'a'\n && s.[1] = 'n'\n && s.[2] = 'd'\n && List.mem s.[3] infix_symbols\n\n(* determines if the string is an infix string.\n checks backwards, first allowing a renaming postfix (\"_102\") which\n may have resulted from Pexp -> Texp -> Pexp translation, then checking\n if all the characters in the beginning of the string are valid infix\n characters. *)\nlet fixity_of_string = function\n | \"\" -> `Normal\n | s when List.mem s special_infix_strings -> `Infix s\n | s when List.mem s.[0] infix_symbols -> `Infix s\n | s when List.mem s.[0] prefix_symbols -> `Prefix s\n | s when s.[0] = '.' -> `Mixfix s\n | s when letop s -> `Letop s\n | s when andop s -> `Andop s\n | _ -> `Normal\n\nlet view_fixity_of_exp = function\n | { pexp_desc = Pexp_ident { txt = Lident l; _ }; pexp_attributes = [] } ->\n fixity_of_string l\n | _ -> `Normal\n\nlet is_infix = function `Infix _ -> true | _ -> false\nlet is_mixfix = function `Mixfix _ -> true | _ -> false\nlet is_kwdop = function `Letop _ | `Andop _ -> true | _ -> false\nlet first_is c str = str <> \"\" && str.[0] = c\nlet last_is c str = str <> \"\" && str.[String.length str - 1] = c\nlet first_is_in cs str = str <> \"\" && List.mem str.[0] cs\n\n(* which identifiers are in fact operators needing parentheses *)\nlet needs_parens txt =\n let fix = fixity_of_string txt in\n is_infix fix || is_mixfix fix || is_kwdop fix\n || first_is_in prefix_symbols txt\n\n(* some infixes need spaces around parens to avoid clashes with comment\n syntax *)\nlet needs_spaces txt = first_is '*' txt || last_is '*' txt\n\n(* add parentheses to binders when they are in fact infix or prefix operators *)\nlet protect_ident ppf txt =\n let format : (_, _, _) format =\n if not (needs_parens txt) then \"%s\"\n else if needs_spaces txt then \"(@;%s@;)\"\n else \"(%s)\"\n in\n fprintf ppf format txt\n\nlet protect_longident ppf print_longident longprefix txt =\n let format : (_, _, _) format =\n if not (needs_parens txt) then \"%a.%s\"\n else if needs_spaces txt then \"%a.(@;%s@;)\"\n else \"%a.(%s)\"\n in\n fprintf ppf format print_longident longprefix txt\n\ntype space_formatter = (unit, Format.formatter, unit) format\n\nlet override = function Override -> \"!\" | Fresh -> \"\"\n\n(* variance encoding: need to sync up with the [parser.mly] *)\nlet type_variance = function\n | NoVariance -> \"\"\n | Covariant -> \"+\"\n | Contravariant -> \"-\"\n\nlet type_injectivity = function NoInjectivity -> \"\" | Injective -> \"!\"\n\ntype construct =\n [ `cons of expression list\n | `list of expression list\n | `nil\n | `normal\n | `simple of Longident.t\n | `tuple ]\n\nlet view_expr x =\n match x.pexp_desc with\n | Pexp_construct ({ txt = Lident \"()\"; _ }, _) -> `tuple\n | Pexp_construct ({ txt = Lident \"[]\"; _ }, _) -> `nil\n | Pexp_construct ({ txt = Lident \"::\"; _ }, Some _) ->\n let rec loop exp acc =\n match exp with\n | {\n pexp_desc = Pexp_construct ({ txt = Lident \"[]\"; _ }, _);\n pexp_attributes = [];\n } ->\n (List.rev acc, true)\n | {\n pexp_desc =\n Pexp_construct\n ( { txt = Lident \"::\"; _ },\n Some { pexp_desc = Pexp_tuple [ e1; e2 ]; pexp_attributes = [] }\n );\n pexp_attributes = [];\n } ->\n loop e2 (e1 :: acc)\n | e -> (List.rev (e :: acc), false)\n in\n let ls, b = loop x [] in\n if b then `list ls else `cons ls\n | Pexp_construct (x, None) -> `simple x.txt\n | _ -> `normal\n\nlet is_simple_construct : construct -> bool = function\n | `nil | `tuple | `list _ | `simple _ -> true\n | `cons _ | `normal -> false\n\nlet pp = fprintf\n\ntype ctxt = { pipe : bool; semi : bool; ifthenelse : bool }\n\nlet reset_ctxt = { pipe = false; semi = false; ifthenelse = false }\nlet under_pipe ctxt = { ctxt with pipe = true }\nlet under_semi ctxt = { ctxt with semi = true }\nlet under_ifthenelse ctxt = { ctxt with ifthenelse = true }\n(*\nlet reset_semi ctxt = { ctxt with semi=false }\nlet reset_ifthenelse ctxt = { ctxt with ifthenelse=false }\nlet reset_pipe ctxt = { ctxt with pipe=false }\n*)\n\nlet list :\n 'a.\n ?sep:space_formatter ->\n ?first:space_formatter ->\n ?last:space_formatter ->\n (Format.formatter -> 'a -> unit) ->\n Format.formatter ->\n 'a list ->\n unit =\n fun ?sep ?first ?last fu f xs ->\n let first = match first with Some x -> x | None -> (\"\" : _ format6)\n and last = match last with Some x -> x | None -> (\"\" : _ format6)\n and sep = match sep with Some x -> x | None -> (\"@ \" : _ format6) in\n let aux f = function\n | [] -> ()\n | [ x ] -> fu f x\n | xs ->\n let rec loop f = function\n | [ x ] -> fu f x\n | x :: xs ->\n fu f x;\n pp f sep;\n loop f xs\n | _ -> assert false\n in\n pp f first;\n loop f xs;\n pp f last\n in\n aux f xs\n\nlet option :\n 'a.\n ?first:space_formatter ->\n ?last:space_formatter ->\n (Format.formatter -> 'a -> unit) ->\n Format.formatter ->\n 'a option ->\n unit =\n fun ?first ?last fu f a ->\n let first = match first with Some x -> x | None -> (\"\" : _ format6)\n and last = match last with Some x -> x | None -> (\"\" : _ format6) in\n match a with\n | None -> ()\n | Some x ->\n pp f first;\n fu f x;\n pp f last\n\nlet paren :\n 'a.\n ?first:space_formatter ->\n ?last:space_formatter ->\n bool ->\n (Format.formatter -> 'a -> unit) ->\n Format.formatter ->\n 'a ->\n unit =\n fun ?(first = (\"\" : _ format6)) ?(last = (\"\" : _ format6)) b fu f x ->\n if b then (\n pp f \"(\";\n pp f first;\n fu f x;\n pp f last;\n pp f \")\")\n else fu f x\n\nlet rec longident f = function\n | Lident s -> protect_ident f s\n | Ldot (y, s) -> protect_longident f longident y s\n | Lapply (y, s) -> pp f \"%a(%a)\" longident y longident s\n\nlet longident_loc f x = pp f \"%a\" longident x.txt\n\nlet constant f = function\n | Pconst_char i -> pp f \"%C\" i\n | Pconst_string (i, _, None) -> pp f \"%S\" i\n | Pconst_string (i, _, Some delim) -> pp f \"{%s|%s|%s}\" delim i delim\n | Pconst_integer (i, None) -> paren (first_is '-' i) (fun f -> pp f \"%s\") f i\n | Pconst_integer (i, Some m) ->\n paren (first_is '-' i) (fun f (i, m) -> pp f \"%s%c\" i m) f (i, m)\n | Pconst_float (i, None) -> paren (first_is '-' i) (fun f -> pp f \"%s\") f i\n | Pconst_float (i, Some m) ->\n paren (first_is '-' i) (fun f (i, m) -> pp f \"%s%c\" i m) f (i, m)\n\n(* trailing space*)\nlet mutable_flag f = function Immutable -> () | Mutable -> pp f \"mutable@;\"\nlet virtual_flag f = function Concrete -> () | Virtual -> pp f \"virtual@;\"\n\n(* trailing space added *)\nlet rec_flag f rf =\n match rf with Nonrecursive -> () | Recursive -> pp f \"rec \"\n\nlet nonrec_flag f rf =\n match rf with Nonrecursive -> pp f \"nonrec \" | Recursive -> ()\n\nlet direction_flag f = function\n | Upto -> pp f \"to@ \"\n | Downto -> pp f \"downto@ \"\n\nlet private_flag f = function Public -> () | Private -> pp f \"private@ \"\nlet iter_loc f ctxt { txt; loc = _ } = f ctxt txt\nlet constant_string f s = pp f \"%S\" s\n\nlet tyvar ppf s =\n if String.length s >= 2 && s.[1] = '\\'' then\n (* without the space, this would be parsed as\n a character literal *)\n Format.fprintf ppf \"' %s\" s\n else Format.fprintf ppf \"'%s\" s\n\nlet tyvar_loc f str = tyvar f str.txt\nlet string_quot f x = pp f \"`%s\" x\n\n(* c ['a,'b] *)\nlet rec class_params_def ctxt f = function\n | [] -> ()\n | l -> pp f \"[%a] \" (* space *) (list (type_param ctxt) ~sep:\",\") l\n\nand type_with_label ctxt f (label, c) =\n match label with\n | Nolabel -> core_type1 ctxt f c (* otherwise parenthesize *)\n | Labelled s -> pp f \"%s:%a\" s (core_type1 ctxt) c\n | Optional s -> pp f \"?%s:%a\" s (core_type1 ctxt) c\n\nand core_type ctxt f x =\n if x.ptyp_attributes <> [] then\n pp f \"((%a)%a)\" (core_type ctxt)\n { x with ptyp_attributes = [] }\n (attributes ctxt) x.ptyp_attributes\n else\n match x.ptyp_desc with\n | Ptyp_arrow (l, ct1, ct2) ->\n pp f \"@[<2>%a@;->@;%a@]\" (* FIXME remove parens later *)\n (type_with_label ctxt) (l, ct1) (core_type ctxt) ct2\n | Ptyp_alias (ct, s) ->\n pp f \"@[<2>%a@;as@;%a@]\" (core_type1 ctxt) ct tyvar s\n | Ptyp_poly ([], ct) -> core_type ctxt f ct\n | Ptyp_poly (sl, ct) ->\n pp f \"@[<2>%a%a@]\"\n (fun f l ->\n pp f \"%a\"\n (fun f l ->\n match l with\n | [] -> ()\n | _ -> pp f \"%a@;.@;\" (list tyvar_loc ~sep:\"@;\") l)\n l)\n sl (core_type ctxt) ct\n | _ -> pp f \"@[<2>%a@]\" (core_type1 ctxt) x\n\nand core_type1 ctxt f x =\n if x.ptyp_attributes <> [] then core_type ctxt f x\n else\n match x.ptyp_desc with\n | Ptyp_any -> pp f \"_\"\n | Ptyp_var s -> tyvar f s\n | Ptyp_tuple l -> pp f \"(%a)\" (list (core_type1 ctxt) ~sep:\"@;*@;\") l\n | Ptyp_constr (li, l) ->\n pp f (* \"%a%a@;\" *) \"%a%a\"\n (fun f l ->\n match l with\n | [] -> ()\n | [ x ] -> pp f \"%a@;\" (core_type1 ctxt) x\n | _ -> list ~first:\"(\" ~last:\")@;\" (core_type ctxt) ~sep:\",@;\" f l)\n l longident_loc li\n | Ptyp_variant (l, closed, low) ->\n let first_is_inherit =\n match l with\n | { Parsetree.prf_desc = Rinherit _ } :: _ -> true\n | _ -> false\n in\n let type_variant_helper f x =\n match x.prf_desc with\n | Rtag (l, _, ctl) ->\n pp f \"@[<2>%a%a@;%a@]\" (iter_loc string_quot) l\n (fun f l ->\n match l with\n | [] -> ()\n | _ -> pp f \"@;of@;%a\" (list (core_type ctxt) ~sep:\"&\") ctl)\n ctl (attributes ctxt) x.prf_attributes\n | Rinherit ct -> core_type ctxt f ct\n in\n pp f \"@[<2>[%a%a]@]\"\n (fun f l ->\n match (l, closed) with\n | [], Closed -> ()\n | [], Open -> pp f \">\" (* Cf #7200: print [>] correctly *)\n | _ ->\n pp f \"%s@;%a\"\n (match (closed, low) with\n | Closed, None -> if first_is_inherit then \" |\" else \"\"\n | Closed, Some _ -> \"<\" (* FIXME desugar the syntax sugar*)\n | Open, _ -> \">\")\n (list type_variant_helper ~sep:\"@;<1 -2>| \")\n l)\n l\n (fun f low ->\n match low with\n | Some [] | None -> ()\n | Some xs -> pp f \">@ %a\" (list string_quot) xs)\n low\n | Ptyp_object (l, o) ->\n let core_field_type f x =\n match x.pof_desc with\n | Otag (l, ct) ->\n (* Cf #7200 *)\n pp f \"@[%s: %a@ %a@ @]\" l.txt (core_type ctxt) ct\n (attributes ctxt) x.pof_attributes\n | Oinherit ct -> pp f \"@[%a@ @]\" (core_type ctxt) ct\n in\n let field_var f = function\n | Asttypes.Closed -> ()\n | Asttypes.Open -> (\n match l with [] -> pp f \"..\" | _ -> pp f \" ;..\")\n in\n pp f \"@[<@ %a%a@ > @]\"\n (list core_field_type ~sep:\";\")\n l field_var o\n (* Cf #7200 *)\n | Ptyp_class (li, l) ->\n (*FIXME*)\n pp f \"@[%a#%a@]\"\n (list (core_type ctxt) ~sep:\",\" ~first:\"(\" ~last:\")\")\n l longident_loc li\n | Ptyp_package (lid, cstrs) -> (\n let aux f (s, ct) =\n pp f \"type %a@ =@ %a\" longident_loc s (core_type ctxt) ct\n in\n match cstrs with\n | [] -> pp f \"@[(module@ %a)@]\" longident_loc lid\n | _ ->\n pp f \"@[(module@ %a@ with@ %a)@]\" longident_loc lid\n (list aux ~sep:\"@ and@ \") cstrs)\n | Ptyp_extension e -> extension ctxt f e\n | _ -> paren true (core_type ctxt) f x\n\n(********************pattern********************)\n(* be cautious when use [pattern], [pattern1] is preferred *)\nand pattern ctxt f x =\n let rec list_of_pattern acc = function\n (* only consider ((A|B)|C)*)\n | { ppat_desc = Ppat_or (p1, p2); ppat_attributes = [] } ->\n list_of_pattern (p2 :: acc) p1\n | x -> x :: acc\n in\n if x.ppat_attributes <> [] then\n pp f \"((%a)%a)\" (pattern ctxt)\n { x with ppat_attributes = [] }\n (attributes ctxt) x.ppat_attributes\n else\n match x.ppat_desc with\n | Ppat_alias (p, s) ->\n pp f \"@[<2>%a@;as@;%a@]\" (pattern ctxt) p protect_ident s.txt (* RA*)\n | Ppat_or _ ->\n (* *)\n pp f \"@[%a@]\"\n (list ~sep:\"@,|\" (pattern ctxt))\n (list_of_pattern [] x)\n | _ -> pattern1 ctxt f x\n\nand pattern1 ctxt (f : Format.formatter) (x : pattern) : unit =\n let rec pattern_list_helper f = function\n | {\n ppat_desc =\n Ppat_construct\n ( { txt = Lident \"::\"; _ },\n Some { ppat_desc = Ppat_tuple [ pat1; pat2 ]; _ } );\n ppat_attributes = [];\n } ->\n pp f \"%a::%a\" (simple_pattern ctxt) pat1 pattern_list_helper pat2 (*RA*)\n | p -> pattern1 ctxt f p\n in\n if x.ppat_attributes <> [] then pattern ctxt f x\n else\n match x.ppat_desc with\n | Ppat_variant (l, Some p) ->\n pp f \"@[<2>`%s@;%a@]\" l (simple_pattern ctxt) p\n | Ppat_construct ({ txt = Lident (\"()\" | \"[]\"); _ }, _) ->\n simple_pattern ctxt f x\n | Ppat_construct (({ txt; _ } as li), po) -> (\n if (* FIXME The third field always false *)\n txt = Lident \"::\" then pp f \"%a\" pattern_list_helper x\n else\n match po with\n | Some x -> pp f \"%a@;%a\" longident_loc li (simple_pattern ctxt) x\n | None -> pp f \"%a\" longident_loc li)\n | _ -> simple_pattern ctxt f x\n\nand simple_pattern ctxt (f : Format.formatter) (x : pattern) : unit =\n if x.ppat_attributes <> [] then pattern ctxt f x\n else\n match x.ppat_desc with\n | Ppat_construct ({ txt = Lident ((\"()\" | \"[]\") as x); _ }, _) ->\n pp f \"%s\" x\n | Ppat_any -> pp f \"_\"\n | Ppat_var { txt; _ } -> protect_ident f txt\n | Ppat_array l -> pp f \"@[<2>[|%a|]@]\" (list (pattern1 ctxt) ~sep:\";\") l\n | Ppat_unpack { txt = None } -> pp f \"(module@ _)@ \"\n | Ppat_unpack { txt = Some s } -> pp f \"(module@ %s)@ \" s\n | Ppat_type li -> pp f \"#%a\" longident_loc li\n | Ppat_record (l, closed) -> (\n let longident_x_pattern f (li, p) =\n match (li, p) with\n | ( { txt = Lident s; _ },\n { ppat_desc = Ppat_var { txt; _ }; ppat_attributes = []; _ } )\n when s = txt ->\n pp f \"@[<2>%a@]\" longident_loc li\n | _ -> pp f \"@[<2>%a@;=@;%a@]\" longident_loc li (pattern1 ctxt) p\n in\n match closed with\n | Closed ->\n pp f \"@[<2>{@;%a@;}@]\" (list longident_x_pattern ~sep:\";@;\") l\n | _ -> pp f \"@[<2>{@;%a;_}@]\" (list longident_x_pattern ~sep:\";@;\") l)\n | Ppat_tuple l ->\n pp f \"@[<1>(%a)@]\" (list ~sep:\",@;\" (pattern1 ctxt)) l (* level1*)\n | Ppat_constant c -> pp f \"%a\" constant c\n | Ppat_interval (c1, c2) -> pp f \"%a..%a\" constant c1 constant c2\n | Ppat_variant (l, None) -> pp f \"`%s\" l\n | Ppat_constraint (p, ct) ->\n pp f \"@[<2>(%a@;:@;%a)@]\" (pattern1 ctxt) p (core_type ctxt) ct\n | Ppat_lazy p -> pp f \"@[<2>(lazy@;%a)@]\" (pattern1 ctxt) p\n | Ppat_exception p -> pp f \"@[<2>exception@;%a@]\" (pattern1 ctxt) p\n | Ppat_extension e -> extension ctxt f e\n | Ppat_open (lid, p) ->\n let with_paren =\n match p.ppat_desc with\n | Ppat_array _ | Ppat_record _\n | Ppat_construct ({ txt = Lident (\"()\" | \"[]\"); _ }, _) ->\n false\n | _ -> true\n in\n pp f \"@[<2>%a.%a @]\" longident_loc lid\n (paren with_paren @@ pattern1 ctxt)\n p\n | _ -> paren true (pattern ctxt) f x\n\nand label_exp ctxt f (l, opt, p) =\n match l with\n | Nolabel ->\n (* single case pattern parens needed here *)\n pp f \"%a@ \" (simple_pattern ctxt) p\n | Optional rest -> (\n match p with\n | { ppat_desc = Ppat_var { txt; _ }; ppat_attributes = [] }\n when txt = rest -> (\n match opt with\n | Some o -> pp f \"?(%s=@;%a)@;\" rest (expression ctxt) o\n | None -> pp f \"?%s@ \" rest)\n | _ -> (\n match opt with\n | Some o ->\n pp f \"?%s:(%a=@;%a)@;\" rest (pattern1 ctxt) p (expression ctxt) o\n | None -> pp f \"?%s:%a@;\" rest (simple_pattern ctxt) p))\n | Labelled l -> (\n match p with\n | { ppat_desc = Ppat_var { txt; _ }; ppat_attributes = [] } when txt = l\n ->\n pp f \"~%s@;\" l\n | _ -> pp f \"~%s:%a@;\" l (simple_pattern ctxt) p)\n\nand sugar_expr ctxt f e =\n if e.pexp_attributes <> [] then false\n else\n match e.pexp_desc with\n | Pexp_apply\n ( { pexp_desc = Pexp_ident { txt = id; _ }; pexp_attributes = []; _ },\n args )\n when List.for_all (fun (lab, _) -> lab = Nolabel) args -> (\n let print_indexop a path_prefix assign left right print_index indices\n rem_args =\n let print_path ppf = function\n | None -> ()\n | Some m -> pp ppf \".%a\" longident m\n in\n match (assign, rem_args) with\n | false, [] ->\n pp f \"@[%a%a%s%a%s@]\" (simple_expr ctxt) a print_path path_prefix\n left\n (list ~sep:\",\" print_index)\n indices right;\n true\n | true, [ v ] ->\n pp f \"@[%a%a%s%a%s@ <-@;<1 2>%a@]\" (simple_expr ctxt) a print_path\n path_prefix left\n (list ~sep:\",\" print_index)\n indices right (simple_expr ctxt) v;\n true\n | _ -> false\n in\n match (id, List.map snd args) with\n | Lident \"!\", [ e ] ->\n pp f \"@[!%a@]\" (simple_expr ctxt) e;\n true\n | Ldot (path, ((\"get\" | \"set\") as func)), a :: other_args -> (\n let assign = func = \"set\" in\n let print = print_indexop a None assign in\n match (path, other_args) with\n | Lident \"Array\", i :: rest ->\n print \".(\" \")\" (expression ctxt) [ i ] rest\n | Lident \"String\", i :: rest ->\n print \".[\" \"]\" (expression ctxt) [ i ] rest\n | Ldot (Lident \"Bigarray\", \"Array1\"), i1 :: rest ->\n print \".{\" \"}\" (simple_expr ctxt) [ i1 ] rest\n | Ldot (Lident \"Bigarray\", \"Array2\"), i1 :: i2 :: rest ->\n print \".{\" \"}\" (simple_expr ctxt) [ i1; i2 ] rest\n | Ldot (Lident \"Bigarray\", \"Array3\"), i1 :: i2 :: i3 :: rest ->\n print \".{\" \"}\" (simple_expr ctxt) [ i1; i2; i3 ] rest\n | ( Ldot (Lident \"Bigarray\", \"Genarray\"),\n { pexp_desc = Pexp_array indexes; pexp_attributes = [] } :: rest\n ) ->\n print \".{\" \"}\" (simple_expr ctxt) indexes rest\n | _ -> false)\n | (Lident s | Ldot (_, s)), a :: i :: rest when first_is '.' s ->\n (* extract operator:\n assignment operators end with [right_bracket ^ \"<-\"],\n access operators end with [right_bracket] directly\n *)\n let assign = last_is '-' s in\n let kind =\n (* extract the right end bracket *)\n let n = String.length s in\n if assign then s.[n - 3] else s.[n - 1]\n in\n let left, right =\n match kind with\n | ')' -> ('(', \")\")\n | ']' -> ('[', \"]\")\n | '}' -> ('{', \"}\")\n | _ -> assert false\n in\n let path_prefix =\n match id with Ldot (m, _) -> Some m | _ -> None\n in\n let left = String.sub s 0 (1 + String.index s left) in\n print_indexop a path_prefix assign left right (expression ctxt)\n [ i ] rest\n | _ -> false)\n | _ -> false\n\nand expression ctxt f x =\n if x.pexp_attributes <> [] then\n pp f \"((%a)@,%a)\" (expression ctxt)\n { x with pexp_attributes = [] }\n (attributes ctxt) x.pexp_attributes\n else\n match x.pexp_desc with\n | Pexp_function _ | Pexp_fun _ | Pexp_match _ | Pexp_try _ | Pexp_sequence _\n when ctxt.pipe || ctxt.semi ->\n paren true (expression reset_ctxt) f x\n | (Pexp_ifthenelse _ | Pexp_sequence _) when ctxt.ifthenelse ->\n paren true (expression reset_ctxt) f x\n | Pexp_let _ | Pexp_letmodule _ | Pexp_open _ | Pexp_letexception _\n | Pexp_letop _\n when ctxt.semi ->\n paren true (expression reset_ctxt) f x\n | Pexp_fun (l, e0, p, e) ->\n pp f \"@[<2>fun@;%a->@;%a@]\" (label_exp ctxt) (l, e0, p)\n (expression ctxt) e\n | Pexp_function l -> pp f \"@[function%a@]\" (case_list ctxt) l\n | Pexp_match (e, l) ->\n pp f \"@[@[@[<2>match %a@]@ with@]%a@]\" (expression reset_ctxt)\n e (case_list ctxt) l\n | Pexp_try (e, l) ->\n pp f \"@[<0>@[try@ %a@]@ @[<0>with%a@]@]\"\n (* \"try@;@[<2>%a@]@\\nwith@\\n%a\"*)\n (expression reset_ctxt)\n e (case_list ctxt) l\n | Pexp_let (rf, l, e) ->\n (* pp f \"@[<2>let %a%a in@;<1 -2>%a@]\"\n (*no indentation here, a new line*) *)\n (* rec_flag rf *)\n pp f \"@[<2>%a in@;<1 -2>%a@]\" (bindings reset_ctxt) (rf, l)\n (expression ctxt) e\n | Pexp_apply (e, l) -> (\n if not (sugar_expr ctxt f x) then\n match view_fixity_of_exp e with\n | `Infix s -> (\n match l with\n | [ ((Nolabel, _) as arg1); ((Nolabel, _) as arg2) ] ->\n (* FIXME associativity label_x_expression_param *)\n pp f \"@[<2>%a@;%s@;%a@]\"\n (label_x_expression_param reset_ctxt)\n arg1 s\n (label_x_expression_param ctxt)\n arg2\n | _ ->\n pp f \"@[<2>%a %a@]\" (simple_expr ctxt) e\n (list (label_x_expression_param ctxt))\n l)\n | `Prefix s -> (\n let s =\n if\n List.mem s [ \"~+\"; \"~-\"; \"~+.\"; \"~-.\" ]\n &&\n match l with\n (* See #7200: avoid turning (~- 1) into (- 1) which is\n parsed as an int literal *)\n | [ (_, { pexp_desc = Pexp_constant _ }) ] -> false\n | _ -> true\n then String.sub s 1 (String.length s - 1)\n else s\n in\n match l with\n | [ (Nolabel, x) ] -> pp f \"@[<2>%s@;%a@]\" s (simple_expr ctxt) x\n | _ ->\n pp f \"@[<2>%a %a@]\" (simple_expr ctxt) e\n (list (label_x_expression_param ctxt))\n l)\n | _ ->\n pp f \"@[%a@]\"\n (fun f (e, l) ->\n pp f \"%a@ %a\" (expression2 ctxt) e\n (list (label_x_expression_param reset_ctxt))\n l\n (* reset here only because [function,match,try,sequence]\n are lower priority *))\n (e, l))\n | Pexp_construct (li, Some eo) when not (is_simple_construct (view_expr x))\n -> (\n (* Not efficient FIXME*)\n match view_expr x with\n | `cons ls -> list (simple_expr ctxt) f ls ~sep:\"@;::@;\"\n | `normal -> pp f \"@[<2>%a@;%a@]\" longident_loc li (simple_expr ctxt) eo\n | _ -> assert false)\n | Pexp_setfield (e1, li, e2) ->\n pp f \"@[<2>%a.%a@ <-@ %a@]\" (simple_expr ctxt) e1 longident_loc li\n (simple_expr ctxt) e2\n | Pexp_ifthenelse (e1, e2, eo) ->\n (* @;@[<2>else@ %a@]@] *)\n let fmt : (_, _, _) format =\n \"@[@[<2>if@ %a@]@;@[<2>then@ %a@]%a@]\"\n in\n let expression_under_ifthenelse = expression (under_ifthenelse ctxt) in\n pp f fmt expression_under_ifthenelse e1 expression_under_ifthenelse e2\n (fun f eo ->\n match eo with\n | Some x ->\n pp f \"@;@[<2>else@;%a@]\" (expression (under_semi ctxt)) x\n | None -> ()\n (* pp f \"()\" *))\n eo\n | Pexp_sequence _ ->\n let rec sequence_helper acc = function\n | { pexp_desc = Pexp_sequence (e1, e2); pexp_attributes = [] } ->\n sequence_helper (e1 :: acc) e2\n | v -> List.rev (v :: acc)\n in\n let lst = sequence_helper [] x in\n pp f \"@[%a@]\" (list (expression (under_semi ctxt)) ~sep:\";@;\") lst\n | Pexp_new li -> pp f \"@[new@ %a@]\" longident_loc li\n | Pexp_setinstvar (s, e) ->\n pp f \"@[%s@ <-@ %a@]\" s.txt (expression ctxt) e\n | Pexp_override l ->\n (* FIXME *)\n let string_x_expression f (s, e) =\n pp f \"@[%s@ =@ %a@]\" s.txt (expression ctxt) e\n in\n pp f \"@[{<%a>}@]\" (list string_x_expression ~sep:\";\") l\n | Pexp_letmodule (s, me, e) ->\n pp f \"@[let@ module@ %s@ =@ %a@ in@ %a@]\"\n (match s.txt with None -> \"_\" | Some s -> s)\n (module_expr reset_ctxt) me (expression ctxt) e\n | Pexp_letexception (cd, e) ->\n pp f \"@[let@ exception@ %a@ in@ %a@]\"\n (extension_constructor ctxt)\n cd (expression ctxt) e\n | Pexp_assert e -> pp f \"@[assert@ %a@]\" (simple_expr ctxt) e\n | Pexp_lazy e -> pp f \"@[lazy@ %a@]\" (simple_expr ctxt) e\n (* Pexp_poly: impossible but we should print it anyway, rather than\n assert false *)\n | Pexp_poly (e, None) -> pp f \"@[!poly!@ %a@]\" (simple_expr ctxt) e\n | Pexp_poly (e, Some ct) ->\n pp f \"@[(!poly!@ %a@ : %a)@]\" (simple_expr ctxt) e\n (core_type ctxt) ct\n | Pexp_open (o, e) ->\n pp f \"@[<2>let open%s %a in@;%a@]\"\n (override o.popen_override)\n (module_expr ctxt) o.popen_expr (expression ctxt) e\n | Pexp_variant (l, Some eo) -> pp f \"@[<2>`%s@;%a@]\" l (simple_expr ctxt) eo\n | Pexp_letop { let_; ands; body } ->\n pp f \"@[<2>@[%a@,%a@] in@;<1 -2>%a@]\" (binding_op ctxt) let_\n (list ~sep:\"@,\" (binding_op ctxt))\n ands (expression ctxt) body\n | Pexp_extension e -> extension ctxt f e\n | Pexp_unreachable -> pp f \".\"\n | _ -> expression1 ctxt f x\n\nand expression1 ctxt f x =\n if x.pexp_attributes <> [] then expression ctxt f x\n else\n match x.pexp_desc with\n | Pexp_object cs -> pp f \"%a\" (class_structure ctxt) cs\n | _ -> expression2 ctxt f x\n(* used in [Pexp_apply] *)\n\nand expression2 ctxt f x =\n if x.pexp_attributes <> [] then expression ctxt f x\n else\n match x.pexp_desc with\n | Pexp_field (e, li) ->\n pp f \"@[%a.%a@]\" (simple_expr ctxt) e longident_loc li\n | Pexp_send (e, s) -> pp f \"@[%a#%s@]\" (simple_expr ctxt) e s.txt\n | _ -> simple_expr ctxt f x\n\nand simple_expr ctxt f x =\n if x.pexp_attributes <> [] then expression ctxt f x\n else\n match x.pexp_desc with\n | Pexp_construct _ when is_simple_construct (view_expr x) -> (\n match view_expr x with\n | `nil -> pp f \"[]\"\n | `tuple -> pp f \"()\"\n | `list xs ->\n pp f \"@[[%a]@]\"\n (list (expression (under_semi ctxt)) ~sep:\";@;\")\n xs\n | `simple x -> longident f x\n | _ -> assert false)\n | Pexp_ident li -> longident_loc f li\n (* (match view_fixity_of_exp x with *)\n (* |`Normal -> longident_loc f li *)\n (* | `Prefix _ | `Infix _ -> pp f \"( %a )\" longident_loc li) *)\n | Pexp_constant c -> constant f c\n | Pexp_pack me -> pp f \"(module@;%a)\" (module_expr ctxt) me\n | Pexp_newtype (lid, e) ->\n pp f \"fun@;(type@;%s)@;->@;%a\" lid.txt (expression ctxt) e\n | Pexp_tuple l ->\n pp f \"@[(%a)@]\" (list (simple_expr ctxt) ~sep:\",@;\") l\n | Pexp_constraint (e, ct) ->\n pp f \"(%a : %a)\" (expression ctxt) e (core_type ctxt) ct\n | Pexp_coerce (e, cto1, ct) ->\n pp f \"(%a%a :> %a)\" (expression ctxt) e\n (option (core_type ctxt) ~first:\" : \" ~last:\" \")\n cto1\n (* no sep hint*) (core_type ctxt)\n ct\n | Pexp_variant (l, None) -> pp f \"`%s\" l\n | Pexp_record (l, eo) ->\n let longident_x_expression f (li, e) =\n match e with\n | { pexp_desc = Pexp_ident { txt; _ }; pexp_attributes = []; _ }\n when li.txt = txt ->\n pp f \"@[%a@]\" longident_loc li\n | _ ->\n pp f \"@[%a@;=@;%a@]\" longident_loc li (simple_expr ctxt) e\n in\n pp f \"@[@[{@;%a%a@]@;}@]\" (* \"@[{%a%a}@]\" *)\n (option ~last:\" with@;\" (simple_expr ctxt))\n eo\n (list longident_x_expression ~sep:\";@;\")\n l\n | Pexp_array l ->\n pp f \"@[<0>@[<2>[|%a|]@]@]\"\n (list (simple_expr (under_semi ctxt)) ~sep:\";\")\n l\n | Pexp_while (e1, e2) ->\n let fmt : (_, _, _) format = \"@[<2>while@;%a@;do@;%a@;done@]\" in\n pp f fmt (expression ctxt) e1 (expression ctxt) e2\n | Pexp_for (s, e1, e2, df, e3) ->\n let fmt : (_, _, _) format =\n \"@[@[@[<2>for %a =@;%a@;%a%a@;do@]@;%a@]@;done@]\"\n in\n let expression = expression ctxt in\n pp f fmt (pattern ctxt) s expression e1 direction_flag df expression e2\n expression e3\n | _ -> paren true (expression ctxt) f x\n\nand attributes ctxt f l = List.iter (attribute ctxt f) l\nand item_attributes ctxt f l = List.iter (item_attribute ctxt f) l\n\nand attribute ctxt f a =\n pp f \"@[<2>[@@%s@ %a]@]\" a.attr_name.txt (payload ctxt) a.attr_payload\n\nand item_attribute ctxt f a =\n pp f \"@[<2>[@@@@%s@ %a]@]\" a.attr_name.txt (payload ctxt) a.attr_payload\n\nand floating_attribute ctxt f a =\n pp f \"@[<2>[@@@@@@%s@ %a]@]\" a.attr_name.txt (payload ctxt) a.attr_payload\n\nand value_description ctxt f x =\n (* note: value_description has an attribute field,\n but they're already printed by the callers this method *)\n pp f \"@[%a%a@]\" (core_type ctxt) x.pval_type\n (fun f x ->\n if x.pval_prim <> [] then\n pp f \"@ =@ %a\" (list constant_string) x.pval_prim)\n x\n\nand extension ctxt f (s, e) = pp f \"@[<2>[%%%s@ %a]@]\" s.txt (payload ctxt) e\n\nand item_extension ctxt f (s, e) =\n pp f \"@[<2>[%%%%%s@ %a]@]\" s.txt (payload ctxt) e\n\nand exception_declaration ctxt f x =\n pp f \"@[exception@ %a@]%a\"\n (extension_constructor ctxt)\n x.ptyexn_constructor (item_attributes ctxt) x.ptyexn_attributes\n\nand class_type_field ctxt f x =\n match x.pctf_desc with\n | Pctf_inherit ct ->\n pp f \"@[<2>inherit@ %a@]%a\" (class_type ctxt) ct (item_attributes ctxt)\n x.pctf_attributes\n | Pctf_val (s, mf, vf, ct) ->\n pp f \"@[<2>val @ %a%a%s@ :@ %a@]%a\" mutable_flag mf virtual_flag vf s.txt\n (core_type ctxt) ct (item_attributes ctxt) x.pctf_attributes\n | Pctf_method (s, pf, vf, ct) ->\n pp f \"@[<2>method %a %a%s :@;%a@]%a\" private_flag pf virtual_flag vf s.txt\n (core_type ctxt) ct (item_attributes ctxt) x.pctf_attributes\n | Pctf_constraint (ct1, ct2) ->\n pp f \"@[<2>constraint@ %a@ =@ %a@]%a\" (core_type ctxt) ct1\n (core_type ctxt) ct2 (item_attributes ctxt) x.pctf_attributes\n | Pctf_attribute a -> floating_attribute ctxt f a\n | Pctf_extension e ->\n item_extension ctxt f e;\n item_attributes ctxt f x.pctf_attributes\n\nand class_signature ctxt f { pcsig_self = ct; pcsig_fields = l; _ } =\n pp f \"@[@[object@[<1>%a@]@ %a@]@ end@]\"\n (fun f -> function\n | { ptyp_desc = Ptyp_any; ptyp_attributes = []; _ } -> ()\n | ct -> pp f \" (%a)\" (core_type ctxt) ct)\n ct\n (list (class_type_field ctxt) ~sep:\"@;\")\n l\n\n(* call [class_signature] called by [class_signature] *)\nand class_type ctxt f x =\n match x.pcty_desc with\n | Pcty_signature cs ->\n class_signature ctxt f cs;\n attributes ctxt f x.pcty_attributes\n | Pcty_constr (li, l) ->\n pp f \"%a%a%a\"\n (fun f l ->\n match l with\n | [] -> ()\n | _ -> pp f \"[%a]@ \" (list (core_type ctxt) ~sep:\",\") l)\n l longident_loc li (attributes ctxt) x.pcty_attributes\n | Pcty_arrow (l, co, cl) ->\n pp f \"@[<2>%a@;->@;%a@]\" (* FIXME remove parens later *)\n (type_with_label ctxt) (l, co) (class_type ctxt) cl\n | Pcty_extension e ->\n extension ctxt f e;\n attributes ctxt f x.pcty_attributes\n | Pcty_open (o, e) ->\n pp f \"@[<2>let open%s %a in@;%a@]\"\n (override o.popen_override)\n longident_loc o.popen_expr (class_type ctxt) e\n\n(* [class type a = object end] *)\nand class_type_declaration_list ctxt f l =\n let class_type_declaration kwd f x =\n let { pci_params = ls; pci_name = { txt; _ }; _ } = x in\n pp f \"@[<2>%s %a%a%s@ =@ %a@]%a\" kwd virtual_flag x.pci_virt\n (class_params_def ctxt) ls txt (class_type ctxt) x.pci_expr\n (item_attributes ctxt) x.pci_attributes\n in\n match l with\n | [] -> ()\n | [ x ] -> class_type_declaration \"class type\" f x\n | x :: xs ->\n pp f \"@[%a@,%a@]\"\n (class_type_declaration \"class type\")\n x\n (list ~sep:\"@,\" (class_type_declaration \"and\"))\n xs\n\nand class_field ctxt f x =\n match x.pcf_desc with\n | Pcf_inherit (ovf, ce, so) ->\n pp f \"@[<2>inherit@ %s@ %a%a@]%a\" (override ovf) (class_expr ctxt) ce\n (fun f so ->\n match so with None -> () | Some s -> pp f \"@ as %s\" s.txt)\n so (item_attributes ctxt) x.pcf_attributes\n | Pcf_val (s, mf, Cfk_concrete (ovf, e)) ->\n pp f \"@[<2>val%s %a%s =@;%a@]%a\" (override ovf) mutable_flag mf s.txt\n (expression ctxt) e (item_attributes ctxt) x.pcf_attributes\n | Pcf_method (s, pf, Cfk_virtual ct) ->\n pp f \"@[<2>method virtual %a %s :@;%a@]%a\" private_flag pf s.txt\n (core_type ctxt) ct (item_attributes ctxt) x.pcf_attributes\n | Pcf_val (s, mf, Cfk_virtual ct) ->\n pp f \"@[<2>val virtual %a%s :@ %a@]%a\" mutable_flag mf s.txt\n (core_type ctxt) ct (item_attributes ctxt) x.pcf_attributes\n | Pcf_method (s, pf, Cfk_concrete (ovf, e)) ->\n let bind e =\n binding ctxt f\n {\n pvb_pat =\n {\n ppat_desc = Ppat_var s;\n ppat_loc = Location.none;\n ppat_loc_stack = [];\n ppat_attributes = [];\n };\n pvb_expr = e;\n pvb_attributes = [];\n pvb_loc = Location.none;\n }\n in\n pp f \"@[<2>method%s %a%a@]%a\" (override ovf) private_flag pf\n (fun f -> function\n | { pexp_desc = Pexp_poly (e, Some ct); pexp_attributes = []; _ } ->\n pp f \"%s :@;%a=@;%a\" s.txt (core_type ctxt) ct (expression ctxt) e\n | { pexp_desc = Pexp_poly (e, None); pexp_attributes = []; _ } ->\n bind e\n | _ -> bind e)\n e (item_attributes ctxt) x.pcf_attributes\n | Pcf_constraint (ct1, ct2) ->\n pp f \"@[<2>constraint %a =@;%a@]%a\" (core_type ctxt) ct1 (core_type ctxt)\n ct2 (item_attributes ctxt) x.pcf_attributes\n | Pcf_initializer e ->\n pp f \"@[<2>initializer@ %a@]%a\" (expression ctxt) e (item_attributes ctxt)\n x.pcf_attributes\n | Pcf_attribute a -> floating_attribute ctxt f a\n | Pcf_extension e ->\n item_extension ctxt f e;\n item_attributes ctxt f x.pcf_attributes\n\nand class_structure ctxt f { pcstr_self = p; pcstr_fields = l } =\n pp f \"@[@[object%a@;%a@]@;end@]\"\n (fun f p ->\n match p.ppat_desc with\n | Ppat_any -> ()\n | Ppat_constraint _ -> pp f \" %a\" (pattern ctxt) p\n | _ -> pp f \" (%a)\" (pattern ctxt) p)\n p\n (list (class_field ctxt))\n l\n\nand class_expr ctxt f x =\n if x.pcl_attributes <> [] then\n pp f \"((%a)%a)\" (class_expr ctxt)\n { x with pcl_attributes = [] }\n (attributes ctxt) x.pcl_attributes\n else\n match x.pcl_desc with\n | Pcl_structure cs -> class_structure ctxt f cs\n | Pcl_fun (l, eo, p, e) ->\n pp f \"fun@ %a@ ->@ %a\" (label_exp ctxt) (l, eo, p) (class_expr ctxt) e\n | Pcl_let (rf, l, ce) ->\n pp f \"%a@ in@ %a\" (bindings ctxt) (rf, l) (class_expr ctxt) ce\n | Pcl_apply (ce, l) ->\n pp f \"((%a)@ %a)\"\n (* Cf: #7200 *) (class_expr ctxt)\n ce\n (list (label_x_expression_param ctxt))\n l\n | Pcl_constr (li, l) ->\n pp f \"%a%a\"\n (fun f l ->\n if l <> [] then pp f \"[%a]@ \" (list (core_type ctxt) ~sep:\",\") l)\n l longident_loc li\n | Pcl_constraint (ce, ct) ->\n pp f \"(%a@ :@ %a)\" (class_expr ctxt) ce (class_type ctxt) ct\n | Pcl_extension e -> extension ctxt f e\n | Pcl_open (o, e) ->\n pp f \"@[<2>let open%s %a in@;%a@]\"\n (override o.popen_override)\n longident_loc o.popen_expr (class_expr ctxt) e\n\nand module_type ctxt f x =\n if x.pmty_attributes <> [] then\n pp f \"((%a)%a)\" (module_type ctxt)\n { x with pmty_attributes = [] }\n (attributes ctxt) x.pmty_attributes\n else\n match x.pmty_desc with\n | Pmty_functor (Unit, mt2) ->\n pp f \"@[functor () ->@ %a@]\" (module_type ctxt) mt2\n | Pmty_functor (Named (s, mt1), mt2) -> (\n match s.txt with\n | None ->\n pp f \"@[%a@ ->@ %a@]\" (module_type1 ctxt) mt1\n (module_type ctxt) mt2\n | Some name ->\n pp f \"@[functor@ (%s@ :@ %a)@ ->@ %a@]\" name\n (module_type ctxt) mt1 (module_type ctxt) mt2)\n | Pmty_with (mt, []) -> module_type ctxt f mt\n | Pmty_with (mt, l) ->\n let with_constraint f = function\n | Pwith_type (li, ({ ptype_params = ls; _ } as td)) ->\n let ls = List.map fst ls in\n pp f \"type@ %a %a =@ %a\"\n (list (core_type ctxt) ~sep:\",\" ~first:\"(\" ~last:\")\")\n ls longident_loc li (type_declaration ctxt) td\n | Pwith_module (li, li2) ->\n pp f \"module %a =@ %a\" longident_loc li longident_loc li2\n | Pwith_typesubst (li, ({ ptype_params = ls; _ } as td)) ->\n let ls = List.map fst ls in\n pp f \"type@ %a %a :=@ %a\"\n (list (core_type ctxt) ~sep:\",\" ~first:\"(\" ~last:\")\")\n ls longident_loc li (type_declaration ctxt) td\n | Pwith_modsubst (li, li2) ->\n pp f \"module %a :=@ %a\" longident_loc li longident_loc li2\n in\n pp f \"@[%a@ with@ %a@]\" (module_type1 ctxt) mt\n (list with_constraint ~sep:\"@ and@ \")\n l\n | _ -> module_type1 ctxt f x\n\nand module_type1 ctxt f x =\n if x.pmty_attributes <> [] then module_type ctxt f x\n else\n match x.pmty_desc with\n | Pmty_ident li -> pp f \"%a\" longident_loc li\n | Pmty_alias li -> pp f \"(module %a)\" longident_loc li\n | Pmty_signature s ->\n pp f \"@[@[sig@ %a@]@ end@]\" (* \"@[sig@ %a@ end@]\" *)\n (list (signature_item ctxt))\n s\n (* FIXME wrong indentation*)\n | Pmty_typeof me ->\n pp f \"@[module@ type@ of@ %a@]\" (module_expr ctxt) me\n | Pmty_extension e -> extension ctxt f e\n | _ -> paren true (module_type ctxt) f x\n\nand signature ctxt f x = list ~sep:\"@\\n\" (signature_item ctxt) f x\n\nand signature_item ctxt f x : unit =\n match x.psig_desc with\n | Psig_type (rf, l) -> type_def_list ctxt f (rf, true, l)\n | Psig_typesubst l ->\n (* Psig_typesubst is never recursive, but we specify [Recursive] here to\n avoid printing a [nonrec] flag, which would be rejected by the parser.\n *)\n type_def_list ctxt f (Recursive, false, l)\n | Psig_value vd ->\n let intro = if vd.pval_prim = [] then \"val\" else \"external\" in\n pp f \"@[<2>%s@ %a@ :@ %a@]%a\" intro protect_ident vd.pval_name.txt\n (value_description ctxt) vd (item_attributes ctxt) vd.pval_attributes\n | Psig_typext te -> type_extension ctxt f te\n | Psig_exception ed -> exception_declaration ctxt f ed\n | Psig_class l -> (\n let class_description kwd f\n ({ pci_params = ls; pci_name = { txt; _ }; _ } as x) =\n pp f \"@[<2>%s %a%a%s@;:@;%a@]%a\" kwd virtual_flag x.pci_virt\n (class_params_def ctxt) ls txt (class_type ctxt) x.pci_expr\n (item_attributes ctxt) x.pci_attributes\n in\n match l with\n | [] -> ()\n | [ x ] -> class_description \"class\" f x\n | x :: xs ->\n pp f \"@[%a@,%a@]\"\n (class_description \"class\")\n x\n (list ~sep:\"@,\" (class_description \"and\"))\n xs)\n | Psig_module\n ({\n pmd_type = { pmty_desc = Pmty_alias alias; pmty_attributes = []; _ };\n _;\n } as pmd) ->\n pp f \"@[module@ %s@ =@ %a@]%a\"\n (match pmd.pmd_name.txt with None -> \"_\" | Some s -> s)\n longident_loc alias (item_attributes ctxt) pmd.pmd_attributes\n | Psig_module pmd ->\n pp f \"@[module@ %s@ :@ %a@]%a\"\n (match pmd.pmd_name.txt with None -> \"_\" | Some s -> s)\n (module_type ctxt) pmd.pmd_type (item_attributes ctxt)\n pmd.pmd_attributes\n | Psig_modsubst pms ->\n pp f \"@[module@ %s@ :=@ %a@]%a\" pms.pms_name.txt longident_loc\n pms.pms_manifest (item_attributes ctxt) pms.pms_attributes\n | Psig_open od ->\n pp f \"@[open%s@ %a@]%a\"\n (override od.popen_override)\n longident_loc od.popen_expr (item_attributes ctxt) od.popen_attributes\n | Psig_include incl ->\n pp f \"@[include@ %a@]%a\" (module_type ctxt) incl.pincl_mod\n (item_attributes ctxt) incl.pincl_attributes\n | Psig_modtype { pmtd_name = s; pmtd_type = md; pmtd_attributes = attrs } ->\n pp f \"@[module@ type@ %s%a@]%a\" s.txt\n (fun f md ->\n match md with\n | None -> ()\n | Some mt ->\n pp_print_space f ();\n pp f \"@ =@ %a\" (module_type ctxt) mt)\n md (item_attributes ctxt) attrs\n | Psig_class_type l -> class_type_declaration_list ctxt f l\n | Psig_recmodule decls ->\n let rec string_x_module_type_list f ?(first = true) l =\n match l with\n | [] -> ()\n | pmd :: tl ->\n if not first then\n pp f \"@ @[and@ %s:@ %a@]%a\"\n (match pmd.pmd_name.txt with None -> \"_\" | Some s -> s)\n (module_type1 ctxt) pmd.pmd_type (item_attributes ctxt)\n pmd.pmd_attributes\n else\n pp f \"@[module@ rec@ %s:@ %a@]%a\"\n (match pmd.pmd_name.txt with None -> \"_\" | Some s -> s)\n (module_type1 ctxt) pmd.pmd_type (item_attributes ctxt)\n pmd.pmd_attributes;\n string_x_module_type_list f ~first:false tl\n in\n string_x_module_type_list f decls\n | Psig_attribute a -> floating_attribute ctxt f a\n | Psig_extension (e, a) ->\n item_extension ctxt f e;\n item_attributes ctxt f a\n\nand module_expr ctxt f x =\n if x.pmod_attributes <> [] then\n pp f \"((%a)%a)\" (module_expr ctxt)\n { x with pmod_attributes = [] }\n (attributes ctxt) x.pmod_attributes\n else\n match x.pmod_desc with\n | Pmod_structure s ->\n pp f \"@[struct@;@[<0>%a@]@;<1 -2>end@]\"\n (list (structure_item ctxt) ~sep:\"@\\n\")\n s\n | Pmod_constraint (me, mt) ->\n pp f \"@[(%a@ :@ %a)@]\" (module_expr ctxt) me (module_type ctxt) mt\n | Pmod_ident li -> pp f \"%a\" longident_loc li\n | Pmod_functor (Unit, me) -> pp f \"functor ()@;->@;%a\" (module_expr ctxt) me\n | Pmod_functor (Named (s, mt), me) ->\n pp f \"functor@ (%s@ :@ %a)@;->@;%a\"\n (match s.txt with None -> \"_\" | Some s -> s)\n (module_type ctxt) mt (module_expr ctxt) me\n | Pmod_apply (me1, me2) ->\n pp f \"(%a)(%a)\" (module_expr ctxt) me1 (module_expr ctxt) me2\n (* Cf: #7200 *)\n | Pmod_unpack e -> pp f \"(val@ %a)\" (expression ctxt) e\n | Pmod_extension e -> extension ctxt f e\n\nand structure ctxt f x = list ~sep:\"@\\n\" (structure_item ctxt) f x\n\nand payload ctxt f = function\n | PStr [ { pstr_desc = Pstr_eval (e, attrs) } ] ->\n pp f \"@[<2>%a@]%a\" (expression ctxt) e (item_attributes ctxt) attrs\n | PStr x -> structure ctxt f x\n | PTyp x ->\n pp f \":@ \";\n core_type ctxt f x\n | PSig x ->\n pp f \":@ \";\n signature ctxt f x\n | PPat (x, None) ->\n pp f \"?@ \";\n pattern ctxt f x\n | PPat (x, Some e) ->\n pp f \"?@ \";\n pattern ctxt f x;\n pp f \" when \";\n expression ctxt f e\n\n(* transform [f = fun g h -> ..] to [f g h = ... ] could be improved *)\nand binding ctxt f { pvb_pat = p; pvb_expr = x; _ } =\n (* .pvb_attributes have already been printed by the caller, #bindings *)\n let rec pp_print_pexp_function f x =\n if x.pexp_attributes <> [] then pp f \"=@;%a\" (expression ctxt) x\n else\n match x.pexp_desc with\n | Pexp_fun (label, eo, p, e) ->\n if label = Nolabel then\n pp f \"%a@ %a\" (simple_pattern ctxt) p pp_print_pexp_function e\n else\n pp f \"%a@ %a\" (label_exp ctxt) (label, eo, p) pp_print_pexp_function\n e\n | Pexp_newtype (str, e) ->\n pp f \"(type@ %s)@ %a\" str.txt pp_print_pexp_function e\n | _ -> pp f \"=@;%a\" (expression ctxt) x\n in\n let tyvars_str tyvars = List.map (fun v -> v.txt) tyvars in\n let is_desugared_gadt p e =\n let gadt_pattern =\n match p with\n | {\n ppat_desc =\n Ppat_constraint\n ( ({ ppat_desc = Ppat_var _ } as pat),\n { ptyp_desc = Ptyp_poly (args_tyvars, rt) } );\n ppat_attributes = [];\n } ->\n Some (pat, args_tyvars, rt)\n | _ -> None\n in\n let rec gadt_exp tyvars e =\n match e with\n | { pexp_desc = Pexp_newtype (tyvar, e); pexp_attributes = [] } ->\n gadt_exp (tyvar :: tyvars) e\n | { pexp_desc = Pexp_constraint (e, ct); pexp_attributes = [] } ->\n Some (List.rev tyvars, e, ct)\n | _ -> None\n in\n let gadt_exp = gadt_exp [] e in\n match (gadt_pattern, gadt_exp) with\n | Some (p, pt_tyvars, pt_ct), Some (e_tyvars, e, e_ct)\n when tyvars_str pt_tyvars = tyvars_str e_tyvars ->\n let ety = varify_type_constructors e_tyvars e_ct in\n if ety = pt_ct then Some (p, pt_tyvars, e_ct, e) else None\n | _ -> None\n in\n if x.pexp_attributes <> [] then\n match p with\n | {\n ppat_desc =\n Ppat_constraint\n ( ({ ppat_desc = Ppat_var _; _ } as pat),\n ({ ptyp_desc = Ptyp_poly _; _ } as typ) );\n ppat_attributes = [];\n _;\n } ->\n pp f \"%a@;: %a@;=@;%a\" (simple_pattern ctxt) pat (core_type ctxt) typ\n (expression ctxt) x\n | _ -> pp f \"%a@;=@;%a\" (pattern ctxt) p (expression ctxt) x\n else\n match is_desugared_gadt p x with\n | Some (p, [], ct, e) ->\n pp f \"%a@;: %a@;=@;%a\" (simple_pattern ctxt) p (core_type ctxt) ct\n (expression ctxt) e\n | Some (p, tyvars, ct, e) ->\n pp f \"%a@;: type@;%a.@;%a@;=@;%a\" (simple_pattern ctxt) p\n (list pp_print_string ~sep:\"@;\")\n (tyvars_str tyvars) (core_type ctxt) ct (expression ctxt) e\n | None -> (\n match p with\n | { ppat_desc = Ppat_constraint (p, ty); ppat_attributes = [] } -> (\n (* special case for the first*)\n match ty with\n | { ptyp_desc = Ptyp_poly _; ptyp_attributes = [] } ->\n pp f \"%a@;:@;%a@;=@;%a\" (simple_pattern ctxt) p (core_type ctxt)\n ty (expression ctxt) x\n | _ ->\n pp f \"(%a@;:@;%a)@;=@;%a\" (simple_pattern ctxt) p\n (core_type ctxt) ty (expression ctxt) x)\n | { ppat_desc = Ppat_var _; ppat_attributes = [] } ->\n pp f \"%a@ %a\" (simple_pattern ctxt) p pp_print_pexp_function x\n | _ -> pp f \"%a@;=@;%a\" (pattern ctxt) p (expression ctxt) x)\n\n(* [in] is not printed *)\nand bindings ctxt f (rf, l) =\n let binding kwd rf f x =\n pp f \"@[<2>%s %a%a@]%a\" kwd rec_flag rf (binding ctxt) x\n (item_attributes ctxt) x.pvb_attributes\n in\n match l with\n | [] -> ()\n | [ x ] -> binding \"let\" rf f x\n | x :: xs ->\n pp f \"@[%a@,%a@]\" (binding \"let\" rf) x\n (list ~sep:\"@,\" (binding \"and\" Nonrecursive))\n xs\n\nand binding_op ctxt f x =\n pp f \"@[<2>%s %a@;=@;%a@]\" x.pbop_op.txt (pattern ctxt) x.pbop_pat\n (expression ctxt) x.pbop_exp\n\nand structure_item ctxt f x =\n match x.pstr_desc with\n | Pstr_eval (e, attrs) ->\n pp f \"@[;;%a@]%a\" (expression ctxt) e (item_attributes ctxt) attrs\n | Pstr_type (_, []) -> assert false\n | Pstr_type (rf, l) -> type_def_list ctxt f (rf, true, l)\n | Pstr_value (rf, l) ->\n (* pp f \"@[let %a%a@]\" rec_flag rf bindings l *)\n pp f \"@[<2>%a@]\" (bindings ctxt) (rf, l)\n | Pstr_typext te -> type_extension ctxt f te\n | Pstr_exception ed -> exception_declaration ctxt f ed\n | Pstr_module x ->\n let rec module_helper = function\n | { pmod_desc = Pmod_functor (arg_opt, me'); pmod_attributes = [] } ->\n (match arg_opt with\n | Unit -> pp f \"()\"\n | Named (s, mt) ->\n pp f \"(%s:%a)\"\n (match s.txt with None -> \"_\" | Some s -> s)\n (module_type ctxt) mt);\n module_helper me'\n | me -> me\n in\n pp f \"@[module %s%a@]%a\"\n (match x.pmb_name.txt with None -> \"_\" | Some s -> s)\n (fun f me ->\n let me = module_helper me in\n match me with\n | {\n pmod_desc =\n Pmod_constraint\n (me', ({ pmty_desc = Pmty_ident _ | Pmty_signature _; _ } as mt));\n pmod_attributes = [];\n } ->\n pp f \" :@;%a@;=@;%a@;\" (module_type ctxt) mt (module_expr ctxt)\n me'\n | _ -> pp f \" =@ %a\" (module_expr ctxt) me)\n x.pmb_expr (item_attributes ctxt) x.pmb_attributes\n | Pstr_open od ->\n pp f \"@[<2>open%s@;%a@]%a\"\n (override od.popen_override)\n (module_expr ctxt) od.popen_expr (item_attributes ctxt)\n od.popen_attributes\n | Pstr_modtype { pmtd_name = s; pmtd_type = md; pmtd_attributes = attrs } ->\n pp f \"@[module@ type@ %s%a@]%a\" s.txt\n (fun f md ->\n match md with\n | None -> ()\n | Some mt ->\n pp_print_space f ();\n pp f \"@ =@ %a\" (module_type ctxt) mt)\n md (item_attributes ctxt) attrs\n | Pstr_class l -> (\n let extract_class_args cl =\n let rec loop acc = function\n | { pcl_desc = Pcl_fun (l, eo, p, cl'); pcl_attributes = [] } ->\n loop ((l, eo, p) :: acc) cl'\n | cl -> (List.rev acc, cl)\n in\n let args, cl = loop [] cl in\n let constr, cl =\n match cl with\n | { pcl_desc = Pcl_constraint (cl', ct); pcl_attributes = [] } ->\n (Some ct, cl')\n | _ -> (None, cl)\n in\n (args, constr, cl)\n in\n let class_constraint f ct = pp f \": @[%a@] \" (class_type ctxt) ct in\n let class_declaration kwd f\n ({ pci_params = ls; pci_name = { txt; _ }; _ } as x) =\n let args, constr, cl = extract_class_args x.pci_expr in\n pp f \"@[<2>%s %a%a%s %a%a=@;%a@]%a\" kwd virtual_flag x.pci_virt\n (class_params_def ctxt) ls txt\n (list (label_exp ctxt))\n args (option class_constraint) constr (class_expr ctxt) cl\n (item_attributes ctxt) x.pci_attributes\n in\n match l with\n | [] -> ()\n | [ x ] -> class_declaration \"class\" f x\n | x :: xs ->\n pp f \"@[%a@,%a@]\"\n (class_declaration \"class\")\n x\n (list ~sep:\"@,\" (class_declaration \"and\"))\n xs)\n | Pstr_class_type l -> class_type_declaration_list ctxt f l\n | Pstr_primitive vd ->\n pp f \"@[external@ %a@ :@ %a@]%a\" protect_ident vd.pval_name.txt\n (value_description ctxt) vd (item_attributes ctxt) vd.pval_attributes\n | Pstr_include incl ->\n pp f \"@[include@ %a@]%a\" (module_expr ctxt) incl.pincl_mod\n (item_attributes ctxt) incl.pincl_attributes\n | Pstr_recmodule decls -> (\n (* 3.07 *)\n let aux f = function\n | { pmb_expr = { pmod_desc = Pmod_constraint (expr, typ) } } as pmb ->\n pp f \"@[@ and@ %s:%a@ =@ %a@]%a\"\n (match pmb.pmb_name.txt with None -> \"_\" | Some s -> s)\n (module_type ctxt) typ (module_expr ctxt) expr\n (item_attributes ctxt) pmb.pmb_attributes\n | pmb ->\n pp f \"@[@ and@ %s@ =@ %a@]%a\"\n (match pmb.pmb_name.txt with None -> \"_\" | Some s -> s)\n (module_expr ctxt) pmb.pmb_expr (item_attributes ctxt)\n pmb.pmb_attributes\n in\n match decls with\n | ({ pmb_expr = { pmod_desc = Pmod_constraint (expr, typ) } } as pmb)\n :: l2 ->\n pp f \"@[@[module@ rec@ %s:%a@ =@ %a@]%a@ %a@]\"\n (match pmb.pmb_name.txt with None -> \"_\" | Some s -> s)\n (module_type ctxt) typ (module_expr ctxt) expr\n (item_attributes ctxt) pmb.pmb_attributes\n (fun f l2 -> List.iter (aux f) l2)\n l2\n | pmb :: l2 ->\n pp f \"@[@[module@ rec@ %s@ =@ %a@]%a@ %a@]\"\n (match pmb.pmb_name.txt with None -> \"_\" | Some s -> s)\n (module_expr ctxt) pmb.pmb_expr (item_attributes ctxt)\n pmb.pmb_attributes\n (fun f l2 -> List.iter (aux f) l2)\n l2\n | _ -> assert false)\n | Pstr_attribute a -> floating_attribute ctxt f a\n | Pstr_extension (e, a) ->\n item_extension ctxt f e;\n item_attributes ctxt f a\n\nand type_param ctxt f (ct, (a, b)) =\n pp f \"%s%s%a\" (type_variance a) (type_injectivity b) (core_type ctxt) ct\n\nand type_params ctxt f = function\n | [] -> ()\n | l -> pp f \"%a \" (list (type_param ctxt) ~first:\"(\" ~last:\")\" ~sep:\",@;\") l\n\nand type_def_list ctxt f (rf, exported, l) =\n let type_decl kwd rf f x =\n let eq =\n if x.ptype_kind = Ptype_abstract && x.ptype_manifest = None then \"\"\n else if exported then \" =\"\n else \" :=\"\n in\n pp f \"@[<2>%s %a%a%s%s%a@]%a\" kwd nonrec_flag rf (type_params ctxt)\n x.ptype_params x.ptype_name.txt eq (type_declaration ctxt) x\n (item_attributes ctxt) x.ptype_attributes\n in\n match l with\n | [] -> assert false\n | [ x ] -> type_decl \"type\" rf f x\n | x :: xs ->\n pp f \"@[%a@,%a@]\" (type_decl \"type\" rf) x\n (list ~sep:\"@,\" (type_decl \"and\" Recursive))\n xs\n\nand record_declaration ctxt f lbls =\n let type_record_field f pld =\n pp f \"@[<2>%a%s:@;%a@;%a@]\" mutable_flag pld.pld_mutable pld.pld_name.txt\n (core_type ctxt) pld.pld_type (attributes ctxt) pld.pld_attributes\n in\n pp f \"{@\\n%a}\" (list type_record_field ~sep:\";@\\n\") lbls\n\nand type_declaration ctxt f x =\n (* type_declaration has an attribute field,\n but it's been printed by the caller of this method *)\n let priv f =\n match x.ptype_private with Public -> () | Private -> pp f \"@;private\"\n in\n let manifest f =\n match x.ptype_manifest with\n | None -> ()\n | Some y ->\n if x.ptype_kind = Ptype_abstract then\n pp f \"%t@;%a\" priv (core_type ctxt) y\n else pp f \"@;%a\" (core_type ctxt) y\n in\n let constructor_declaration f pcd =\n pp f \"|@;\";\n constructor_declaration ctxt f\n (pcd.pcd_name.txt, pcd.pcd_args, pcd.pcd_res, pcd.pcd_attributes)\n in\n let repr f =\n let intro f = if x.ptype_manifest = None then () else pp f \"@;=\" in\n match x.ptype_kind with\n | Ptype_variant xs ->\n let variants fmt xs =\n if xs = [] then pp fmt \" |\"\n else pp fmt \"@\\n%a\" (list ~sep:\"@\\n\" constructor_declaration) xs\n in\n pp f \"%t%t%a\" intro priv variants xs\n | Ptype_abstract -> ()\n | Ptype_record l -> pp f \"%t%t@;%a\" intro priv (record_declaration ctxt) l\n | Ptype_open -> pp f \"%t%t@;..\" intro priv\n in\n let constraints f =\n List.iter\n (fun (ct1, ct2, _) ->\n pp f \"@[@ constraint@ %a@ =@ %a@]\" (core_type ctxt) ct1\n (core_type ctxt) ct2)\n x.ptype_cstrs\n in\n pp f \"%t%t%t\" manifest repr constraints\n\nand type_extension ctxt f x =\n let extension_constructor f x =\n pp f \"@\\n|@;%a\" (extension_constructor ctxt) x\n in\n pp f \"@[<2>type %a%a += %a@ %a@]%a\"\n (fun f -> function\n | [] -> ()\n | l ->\n pp f \"%a@;\" (list (type_param ctxt) ~first:\"(\" ~last:\")\" ~sep:\",\") l)\n x.ptyext_params longident_loc x.ptyext_path private_flag\n x.ptyext_private (* Cf: #7200 *)\n (list ~sep:\"\" extension_constructor)\n x.ptyext_constructors (item_attributes ctxt) x.ptyext_attributes\n\nand constructor_declaration ctxt f (name, args, res, attrs) =\n let name = match name with \"::\" -> \"(::)\" | s -> s in\n match res with\n | None ->\n pp f \"%s%a@;%a\" name\n (fun f -> function\n | Pcstr_tuple [] -> ()\n | Pcstr_tuple l ->\n pp f \"@;of@;%a\" (list (core_type1 ctxt) ~sep:\"@;*@;\") l\n | Pcstr_record l -> pp f \"@;of@;%a\" (record_declaration ctxt) l)\n args (attributes ctxt) attrs\n | Some r ->\n pp f \"%s:@;%a@;%a\" name\n (fun f -> function\n | Pcstr_tuple [] -> core_type1 ctxt f r\n | Pcstr_tuple l ->\n pp f \"%a@;->@;%a\"\n (list (core_type1 ctxt) ~sep:\"@;*@;\")\n l (core_type1 ctxt) r\n | Pcstr_record l ->\n pp f \"%a@;->@;%a\" (record_declaration ctxt) l (core_type1 ctxt) r)\n args (attributes ctxt) attrs\n\nand extension_constructor ctxt f x =\n (* Cf: #7200 *)\n match x.pext_kind with\n | Pext_decl (l, r) ->\n constructor_declaration ctxt f (x.pext_name.txt, l, r, x.pext_attributes)\n | Pext_rebind li ->\n pp f \"%s@;=@;%a%a\" x.pext_name.txt longident_loc li (attributes ctxt)\n x.pext_attributes\n\nand case_list ctxt f l : unit =\n let aux f { pc_lhs; pc_guard; pc_rhs } =\n pp f \"@;| @[<2>%a%a@;->@;%a@]\" (pattern ctxt) pc_lhs\n (option (expression ctxt) ~first:\"@;when@;\")\n pc_guard\n (expression (under_pipe ctxt))\n pc_rhs\n in\n list aux f l ~sep:\"\"\n\nand label_x_expression_param ctxt f (l, e) =\n let simple_name =\n match e with\n | { pexp_desc = Pexp_ident { txt = Lident l; _ }; pexp_attributes = [] } ->\n Some l\n | _ -> None\n in\n match l with\n | Nolabel -> expression2 ctxt f e (* level 2*)\n | Optional str ->\n if Some str = simple_name then pp f \"?%s\" str\n else pp f \"?%s:%a\" str (simple_expr ctxt) e\n | Labelled lbl ->\n if Some lbl = simple_name then pp f \"~%s\" lbl\n else pp f \"~%s:%a\" lbl (simple_expr ctxt) e\n\nand directive_argument f x =\n match x.pdira_desc with\n | Pdir_string s -> pp f \"@ %S\" s\n | Pdir_int (n, None) -> pp f \"@ %s\" n\n | Pdir_int (n, Some m) -> pp f \"@ %s%c\" n m\n | Pdir_ident li -> pp f \"@ %a\" longident li\n | Pdir_bool b -> pp f \"@ %s\" (string_of_bool b)\n\nlet toplevel_phrase f x =\n match x with\n | Ptop_def s -> pp f \"@[%a@]\" (list (structure_item reset_ctxt)) s\n (* pp_open_hvbox f 0; *)\n (* pp_print_list structure_item f s ; *)\n (* pp_close_box f (); *)\n | Ptop_dir { pdir_name; pdir_arg = None; _ } ->\n pp f \"@[#%s@]\" pdir_name.txt\n | Ptop_dir { pdir_name; pdir_arg = Some pdir_arg; _ } ->\n pp f \"@[#%s@ %a@]\" pdir_name.txt directive_argument pdir_arg\n\nlet expression f x = pp f \"@[%a@]\" (expression reset_ctxt) x\n\nlet string_of_expression x =\n ignore (flush_str_formatter ());\n let f = str_formatter in\n expression f x;\n flush_str_formatter ()\n\nlet string_of_structure x =\n ignore (flush_str_formatter ());\n let f = str_formatter in\n structure reset_ctxt f x;\n flush_str_formatter ()\n\nlet top_phrase f x =\n pp_print_newline f ();\n toplevel_phrase f x;\n pp f \";;\";\n pp_print_newline f ()\n\nlet core_type = core_type reset_ctxt\nlet pattern = pattern reset_ctxt\nlet signature = signature reset_ctxt\nlet structure = structure reset_ctxt\nlet class_expr = class_expr reset_ctxt\nlet class_field = class_field reset_ctxt\nlet class_type = class_type reset_ctxt\nlet class_signature = class_signature reset_ctxt\nlet class_type_field = class_type_field reset_ctxt\nlet module_expr = module_expr reset_ctxt\nlet module_type = module_type reset_ctxt\nlet signature_item = signature_item reset_ctxt\nlet structure_item = structure_item reset_ctxt\nlet type_declaration = type_declaration reset_ctxt\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * Location.t * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | NoVariance\n\n type injectivity (*IF_CURRENT = Asttypes.injectivity *) =\n | Injective\n | NoInjectivity\nend\n\nmodule Parsetree = struct\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * Location.t * string option\n (* \"constant\"\n {delim|other constant|delim}\n\n The location span the content of the string, without the delimiters.\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n type location_stack = Location.t list\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: location_stack;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: location_stack;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * (string loc list * pattern) option\n (* C None\n C P Some ([], P)\n C (P1, ..., Pn) Some ([], Ppat_tuple [P1; ...; Pn])\n C (type a b) P Some ([a; b], P)\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P) Some \"P\"\n (module _) None\n\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: location_stack;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * (variance * injectivity)) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * (variance * injectivity)) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n*)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * (variance * injectivity)) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and functor_parameter (*IF_CURRENT = Parsetree.functor_parameter *) =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n (* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_modtypesubst of module_type_declaration\n (* module type S := ... *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string option loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_modtype of Longident.t loc * module_type\n (* with module type X.Y = Z *)\n | Pwith_modtypesubst of Longident.t loc * module_type\n (* with module type X.Y := sig end *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string option loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M030\"\n let ast_intf_magic_number = \"Caml1999N030\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * Location.t * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | NoVariance\n\n type injectivity (*IF_CURRENT = Asttypes.injectivity *) =\n | Injective\n | NoInjectivity\nend\n\nmodule Parsetree = struct\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * Location.t * string option\n (* \"constant\"\n {delim|other constant|delim}\n\n The location span the content of the string, without the delimiters.\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n type location_stack = Location.t list\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: location_stack;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n\n - As the pval_type field of a value_description.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ | t ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: location_stack;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * (string loc list * pattern) option\n (* C None\n C P Some ([], P)\n C (P1, ..., Pn) Some ([], Ppat_tuple [P1; ...; Pn])\n C (type a b) P Some ([a; b], P)\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P) Some \"P\"\n (module _) None\n\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: location_stack;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * (variance * injectivity)) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_vars: string loc list;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * (variance * injectivity)) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n*)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of string loc list * constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([], [T1; ...; Tn], None)\n | C: T0 ([], [], Some T0)\n | C: T1 * ... * Tn -> T0 ([], [T1; ...; Tn], Some T0)\n | C: 'a... . T1... -> T0 (['a;...]; [T1;...], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * (variance * injectivity)) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and functor_parameter (*IF_CURRENT = Parsetree.functor_parameter *) =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n (* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_modtypesubst of module_type_declaration\n (* module type S := ... *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string option loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_modtype of Longident.t loc * module_type\n (* with module type X.Y = Z *)\n | Pwith_modtypesubst of Longident.t loc * module_type\n (* with module type X.Y := sig end *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string option loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M031\"\n let ast_intf_magic_number = \"Caml1999N031\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * Location.t * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * Location.t * string option\n (* \"constant\"\n {delim|other constant|delim}\n\n The location span the content of the string, without the delimiters.\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n type location_stack = Location.t list\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: location_stack;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: location_stack;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P) Some \"P\"\n (module _) None\n\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: location_stack;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n*)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and functor_parameter (*IF_CURRENT = Parsetree.functor_parameter *) =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n (* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string option loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string option loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M028\"\n let ast_intf_magic_number = \"Caml1999N028\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n type location_stack = Location.t list\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: location_stack;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: location_stack;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P) Some \"P\"\n (module _) None\n\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: location_stack;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n*)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and functor_parameter (*IF_CURRENT = Parsetree.functor_parameter *) =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n (* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string option loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string option loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M027\"\n let ast_intf_magic_number = \"Caml1999N027\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\n\nend\n\nmodule Parsetree = struct\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: Location.t list;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and typ = core_type\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: Location.t list;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pat = pattern\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: Location.t list;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expr = expression\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of cases\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * cases\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * cases\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and cases = case list\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M026\"\n let ast_intf_magic_number = \"Caml1999N026\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Ast ported on Thu Mar 21 09:50:42 GMT 2019\n OCaml was:\n commit 55c9ba466362f303eb4d5ed511f6fda142879137 (HEAD -> 4.08, origin/4.08)\n Author: Nicolás Ojeda Bär \n Date: Tue Mar 19 08:11:02 2019 +0100\n\n Merge pull request #8521 from nojb/fix_unix_tests_408\n\n Actually run all lib-unix tests [4.08]\n*)\n\nmodule Asttypes = struct\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\n\nend\n\nmodule Parsetree = struct\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: Location.t list;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and typ = core_type\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: Location.t list;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pat = pattern\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: Location.t list;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expr = expression\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of cases\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * cases\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * cases\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and cases = case list\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M025\"\n let ast_intf_magic_number = \"Caml1999N025\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Ast ported on Wed Apr 18 10:33:29 BST 2018\n OCaml trunk was:\n commit c0bd6a27e138911560f43dc75d5fde2ade4d6cfe (HEAD, tag: 4.07.0+beta2)\n Author: Damien Doligez \n Date: Tue Apr 10 14:50:48 2018 +0200\n\n change VERSION for 4.07.0+beta2\n*)\n\nmodule Asttypes = struct\n (** Auxiliary AST types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {1 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label loc * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) =\n | Otag of label loc * attributes * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n (*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of override_flag * Longident.t loc * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of override_flag * Longident.t loc * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M023\"\n let ast_intf_magic_number = \"Caml1999N023\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Ast ported on Mon Oct 2 11:25:57 CEST 2017\n OCaml trunk was:\n commit 65940a2c6be43c42f75c6c6b255974f7e6de03ca (HEAD -> 4.06, origin/4.06)\n Author: Christophe Raffalli \n Date: Sun Oct 1 18:27:07 2017 +0200\n\n fixed position of last optional last semicolumn in sequence (#1387)\n*)\n\nmodule Asttypes = struct\n (** Auxiliary AST types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {2 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {2 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label loc * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) =\n | Otag of label loc * attributes * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n (* Invariant: non-empty list *)\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n (*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {2 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of override_flag * Longident.t loc * class_type\n (* let open M in CT *)\n\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of override_flag * Longident.t loc * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {2 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {2 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M022\"\n let ast_intf_magic_number = \"Caml1999N022\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n (** Auxiliary AST types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {2 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {2 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Otional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of (string loc * attributes * core_type) list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * string loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of string loc * expression\n (* x <- 2 *)\n | Pexp_override of (string loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n (* Invariant: non-empty list *)\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l [@id1] [@id2] : T *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n (*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {2 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (string loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (string loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (string loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (string loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {2 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of type_declaration\n (* with type t := ... *)\n | Pwith_modsubst of string loc * Longident.t loc\n (* with module X := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {2 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M020\"\n let ast_intf_magic_number = \"Caml1999N018\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n (** Auxiliary AST types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {2 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {2 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Otional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of (string * attributes * core_type) list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * string\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of string loc * expression\n (* x <- 2 *)\n | Pexp_override of (string loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* let open M in E\n let! open M in E\n *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n (* Invariant: non-empty list *)\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l [@id1] [@id2] : T *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n (*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {2 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (string * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (string * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (string loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (string loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {2 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of type_declaration\n (* with type t := ... *)\n | Pwith_modsubst of string loc * Longident.t loc\n (* with module X := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {2 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M020\"\n let ast_intf_magic_number = \"Caml1999N018\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n (* Auxiliary a.s.t. types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {2 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {2 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Otional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of (string * attributes * core_type) list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * string\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of string loc * expression\n (* x <- 2 *)\n | Pexp_override of (string loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* let open M in E\n let! open M in E\n *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n (* Invariant: non-empty list *)\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l [@id1] [@id2] : T *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n (*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {2 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (string * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (string * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (string loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (string loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {2 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of type_declaration\n (* with type t := ... *)\n | Pwith_modsubst of string loc * Longident.t loc\n (* with module X := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {2 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M019\"\n let ast_intf_magic_number = \"Caml1999N018\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n (* Auxiliary a.s.t. types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n (** {2 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {2 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of label * core_type * core_type\n (* T1 -> T2 (label = \"\")\n ~l:T1 -> T2 (label = \"l\")\n ?l:T1 -> T2 (label = \"?l\")\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of (string * attributes * core_type) list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of label * expression option * pattern * expression\n (* fun P -> E1 (lab = \"\", None)\n fun ~l:P -> E1 (lab = \"l\", None)\n fun ?l:P -> E1 (lab = \"?l\", None)\n fun ?l:(P = E0) -> E1 (lab = \"?l\", Some E0)\n\n Notes:\n - If E0 is provided, lab must start with '?'.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * string\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of string loc * expression\n (* x <- 2 *)\n | Pexp_override of (string loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* let open M in E\n let! open M in E\n *)\n | Pexp_extension of extension\n (* [%id] *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n\n Note: when used under Pstr_primitive, prim cannot be empty\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n (* Invariant: non-empty list *)\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l [@id1] [@id2] : T *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: core_type list;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n (*\n | C of T1 * ... * Tn (res = None)\n | C: T0 (args = [], res = Some T0)\n | C: T1 * ... * Tn -> T0 (res = Some T0)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of core_type list * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {2 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of label * core_type * class_type\n (* T -> CT (label = \"\")\n ~l:T -> CT (label = \"l\")\n ?l:T -> CT (label = \"?l\")\n *)\n | Pcty_extension of extension\n (* [%id] *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (string * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (string * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of label * expression option * pattern * class_expr\n (* fun P -> CE (lab = \"\", None)\n fun ~l:P -> CE (lab = \"l\", None)\n fun ?l:P -> CE (lab = \"?l\", None)\n fun ?l:(P = E0) -> CE (lab = \"?l\", Some E0)\n *)\n | Pcl_apply of class_expr * (label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (string loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (string loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {2 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of type_declaration\n (* with type t := ... *)\n | Pwith_modsubst of string loc * Longident.t loc\n (* with module X := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {2 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of int\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M016\"\n let ast_intf_magic_number = \"Caml1999N015\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_403\nmodule To = Ast_402\n\nlet inject_predef_option label d =\n let open To in\n let open Parsetree in\n match label with\n | From.Asttypes.Optional _ ->\n let loc = { d.ptyp_loc with Location.loc_ghost = true } in\n let txt = Longident.Ldot (Longident.Lident \"*predef*\", \"option\") in\n let ident = { Location.txt; loc } in\n {\n ptyp_desc = Ptyp_constr (ident, [ d ]);\n ptyp_loc = loc;\n ptyp_attributes = [];\n }\n | _ -> d\n\nlet from_loc { Location.txt = _; loc } = loc\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.03\" missing_feature\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_loc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc loc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant loc x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable ->\n migration_error loc \"unreachable patterns\"\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_loc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc loc :\n From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant loc x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant loc x0, copy_constant loc x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n ( copy_arg_label x0,\n inject_predef_option x0 (copy_core_type x1),\n copy_core_type x2 )\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly (List.map (fun x -> x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload (from_loc x0) x1)\n\nand copy_payload loc : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig _x0 -> migration_error loc \"signatures in attribute\"\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type (type_declarations x0 x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n (copy_override_flag x0, copy_class_expr x1, copy_option (fun x -> x) x2)\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type (type_declarations x0 x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n ( copy_arg_label x0,\n inject_predef_option x0 (copy_core_type x1),\n copy_class_type x2 )\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_mutable_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_private_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload (from_loc x0) x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind =\n copy_extension_constructor_kind (from_loc pext_name) pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind loc :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments loc x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args =\n copy_constructor_arguments (from_loc pcd_name) pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments loc :\n From.Parsetree.constructor_arguments -> To.Parsetree.core_type list =\n function\n | From.Parsetree.Pcstr_tuple x0 -> List.map copy_core_type x0\n | From.Parsetree.Pcstr_record _x0 -> migration_error loc \"inline records\"\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> string = function\n | From.Asttypes.Nolabel -> \"\"\n | From.Asttypes.Labelled x0 -> x0\n | From.Asttypes.Optional x0 -> \"?\" ^ x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant loc : From.Parsetree.constant -> To.Asttypes.constant =\n function\n | From.Parsetree.Pconst_integer (x0, x1) -> (\n match x1 with\n | None -> To.Asttypes.Const_int (int_of_string x0)\n | Some 'l' -> To.Asttypes.Const_int32 (Int32.of_string x0)\n | Some 'L' -> To.Asttypes.Const_int64 (Int64.of_string x0)\n | Some 'n' -> To.Asttypes.Const_nativeint (Nativeint.of_string x0)\n | Some _ -> migration_error loc \"custom integer literals\")\n | From.Parsetree.Pconst_char x0 -> To.Asttypes.Const_char x0\n | From.Parsetree.Pconst_string (x0, x1) -> To.Asttypes.Const_string (x0, x1)\n | From.Parsetree.Pconst_float (x0, x1) -> (\n match x1 with\n | None -> To.Asttypes.Const_float x0\n | Some _ -> migration_error loc \"custom float literals\")\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nand type_declarations recflag types =\n match (recflag, List.map copy_type_declaration types) with\n | From.Asttypes.Recursive, types -> types\n | From.Asttypes.Nonrecursive, [] -> []\n | From.Asttypes.Nonrecursive, x :: xs ->\n let pos =\n {\n Lexing.pos_fname = \"_none_\";\n pos_lnum = 1;\n pos_bol = 0;\n pos_cnum = -1;\n }\n in\n let loc = { Location.loc_start = pos; loc_end = pos; loc_ghost = true } in\n let ptype_attributes =\n ({ To.Asttypes.txt = \"nonrec\"; loc }, To.Parsetree.PStr [])\n :: x.To.Parsetree.ptype_attributes\n in\n { x with To.Parsetree.ptype_attributes } :: xs\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, _x1) ->\n To.Parsetree.Pdir_int (int_of_string x0)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino, Jane Street Europe *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* BEGIN of BLACK MAGIC *)\n(*$ open Ast_cinaps_helpers $*)\n\ntype _ witnesses = ..\n\ntype _ migration = ..\ntype _ migration += Undefined : _ migration\n\ntype 'a migration_info = {\n mutable next_version : 'a migration;\n mutable previous_version : 'a migration;\n}\n\n(** Abstract view of a version of an OCaml Ast *)\nmodule type Ast = sig\n (*$ foreach_module (fun m types ->\n printf \" module %s : sig\\n\" m;\n List.iter types ~f:(printf \" type %s\\n\");\n printf \" end\\n\"\n )\n *)\n module Parsetree : sig\n type structure\n type signature\n type toplevel_phrase\n type core_type\n type expression\n type pattern\n type case\n type type_declaration\n type type_extension\n type extension_constructor\n end\n(*$*)\n module Config : sig\n val ast_impl_magic_number : string\n val ast_intf_magic_number : string\n end\nend\n\n(* Shortcuts for talking about ast types outside of the module language *)\n\ntype 'a _types = 'a constraint 'a\n = <\n (*$ foreach_type (fun _ s -> printf \" %-21s : _;\\n\" s) *)\n structure : _;\n signature : _;\n toplevel_phrase : _;\n core_type : _;\n expression : _;\n pattern : _;\n case : _;\n type_declaration : _;\n type_extension : _;\n extension_constructor : _;\n(*$*)\n >\n;;\n\n(*$ foreach_type (fun _ s ->\n printf \"type 'a get_%s =\\n\" s;\n printf \" 'x constraint 'a _types = < %s : 'x; .. >\\n\" s\n ) *)\ntype 'a get_structure =\n 'x constraint 'a _types = < structure : 'x; .. >\ntype 'a get_signature =\n 'x constraint 'a _types = < signature : 'x; .. >\ntype 'a get_toplevel_phrase =\n 'x constraint 'a _types = < toplevel_phrase : 'x; .. >\ntype 'a get_core_type =\n 'x constraint 'a _types = < core_type : 'x; .. >\ntype 'a get_expression =\n 'x constraint 'a _types = < expression : 'x; .. >\ntype 'a get_pattern =\n 'x constraint 'a _types = < pattern : 'x; .. >\ntype 'a get_case =\n 'x constraint 'a _types = < case : 'x; .. >\ntype 'a get_type_declaration =\n 'x constraint 'a _types = < type_declaration : 'x; .. >\ntype 'a get_type_extension =\n 'x constraint 'a _types = < type_extension : 'x; .. >\ntype 'a get_extension_constructor =\n 'x constraint 'a _types = < extension_constructor : 'x; .. >\n(*$*)\n\nmodule type OCaml_version = sig\n module Ast : Ast\n val version : int\n val string_version : string\n type types = <\n (*$ foreach_type (fun m s -> printf \" %-21s : Ast.%s.%s;\\n\" s m s)*)\n structure : Ast.Parsetree.structure;\n signature : Ast.Parsetree.signature;\n toplevel_phrase : Ast.Parsetree.toplevel_phrase;\n core_type : Ast.Parsetree.core_type;\n expression : Ast.Parsetree.expression;\n pattern : Ast.Parsetree.pattern;\n case : Ast.Parsetree.case;\n type_declaration : Ast.Parsetree.type_declaration;\n type_extension : Ast.Parsetree.type_extension;\n extension_constructor : Ast.Parsetree.extension_constructor;\n(*$*)\n > _types\n type _ witnesses += Version : types witnesses\n val migration_info : types migration_info\nend\n\nmodule Make_witness(Ast : Ast) =\nstruct\n type types = <\n (*$ foreach_type (fun m s -> printf \" %-21s : Ast.%s.%s;\\n\" s m s)*)\n structure : Ast.Parsetree.structure;\n signature : Ast.Parsetree.signature;\n toplevel_phrase : Ast.Parsetree.toplevel_phrase;\n core_type : Ast.Parsetree.core_type;\n expression : Ast.Parsetree.expression;\n pattern : Ast.Parsetree.pattern;\n case : Ast.Parsetree.case;\n type_declaration : Ast.Parsetree.type_declaration;\n type_extension : Ast.Parsetree.type_extension;\n extension_constructor : Ast.Parsetree.extension_constructor;\n(*$*)\n > _types\n type _ witnesses += Version : types witnesses\n let migration_info : types migration_info =\n { next_version = Undefined; previous_version = Undefined }\nend\n\ntype 'types ocaml_version =\n (module OCaml_version\n (*$ let sep = with_then_and () in\n foreach_type (fun m s ->\n printf \" %t type Ast.%s.%s = 'types get_%s\\n\" sep m s s) *)\n with type Ast.Parsetree.structure = 'types get_structure\n and type Ast.Parsetree.signature = 'types get_signature\n and type Ast.Parsetree.toplevel_phrase = 'types get_toplevel_phrase\n and type Ast.Parsetree.core_type = 'types get_core_type\n and type Ast.Parsetree.expression = 'types get_expression\n and type Ast.Parsetree.pattern = 'types get_pattern\n and type Ast.Parsetree.case = 'types get_case\n and type Ast.Parsetree.type_declaration = 'types get_type_declaration\n and type Ast.Parsetree.type_extension = 'types get_type_extension\n and type Ast.Parsetree.extension_constructor = 'types get_extension_constructor\n(*$*)\n )\n\ntype ('from, 'to_) migration_functions = {\n (*$ foreach_type (fun _ s ->\n printf \" copy_%s: 'from get_%s -> 'to_ get_%s;\\n\" s s s) *)\n copy_structure: 'from get_structure -> 'to_ get_structure;\n copy_signature: 'from get_signature -> 'to_ get_signature;\n copy_toplevel_phrase: 'from get_toplevel_phrase -> 'to_ get_toplevel_phrase;\n copy_core_type: 'from get_core_type -> 'to_ get_core_type;\n copy_expression: 'from get_expression -> 'to_ get_expression;\n copy_pattern: 'from get_pattern -> 'to_ get_pattern;\n copy_case: 'from get_case -> 'to_ get_case;\n copy_type_declaration: 'from get_type_declaration -> 'to_ get_type_declaration;\n copy_type_extension: 'from get_type_extension -> 'to_ get_type_extension;\n copy_extension_constructor: 'from get_extension_constructor -> 'to_ get_extension_constructor;\n(*$*)\n}\n\nlet id x = x\nlet migration_identity : ('a, 'a) migration_functions = {\n (*$ foreach_type (fun _ s -> printf \" copy_%s = id;\\n\" s) *)\n copy_structure = id;\n copy_signature = id;\n copy_toplevel_phrase = id;\n copy_core_type = id;\n copy_expression = id;\n copy_pattern = id;\n copy_case = id;\n copy_type_declaration = id;\n copy_type_extension = id;\n copy_extension_constructor = id;\n(*$*)\n}\n\nlet compose f g x = f (g x)\nlet migration_compose (ab : ('a, 'b) migration_functions) (bc : ('b, 'c) migration_functions) : ('a, 'c) migration_functions = {\n (*$ foreach_type (fun _ s ->\n printf \" copy_%-21s = compose bc.copy_%-21s ab.copy_%s;\\n\" s s s) *)\n copy_structure = compose bc.copy_structure ab.copy_structure;\n copy_signature = compose bc.copy_signature ab.copy_signature;\n copy_toplevel_phrase = compose bc.copy_toplevel_phrase ab.copy_toplevel_phrase;\n copy_core_type = compose bc.copy_core_type ab.copy_core_type;\n copy_expression = compose bc.copy_expression ab.copy_expression;\n copy_pattern = compose bc.copy_pattern ab.copy_pattern;\n copy_case = compose bc.copy_case ab.copy_case;\n copy_type_declaration = compose bc.copy_type_declaration ab.copy_type_declaration;\n copy_type_extension = compose bc.copy_type_extension ab.copy_type_extension;\n copy_extension_constructor = compose bc.copy_extension_constructor ab.copy_extension_constructor;\n(*$*)\n}\n\ntype _ migration += Migration : 'from ocaml_version * ('from, 'to_) migration_functions * 'to_ ocaml_version -> 'from migration\n\nmodule type Migrate_module = sig\n module From : Ast\n module To : Ast\n (*$ foreach_type (fun m s ->\n printf \" val copy_%-21s: From.%s.%s -> To.%s.%s\\n\" s m s m s) *)\n val copy_structure : From.Parsetree.structure -> To.Parsetree.structure\n val copy_signature : From.Parsetree.signature -> To.Parsetree.signature\n val copy_toplevel_phrase : From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase\n val copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type\n val copy_expression : From.Parsetree.expression -> To.Parsetree.expression\n val copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern\n val copy_case : From.Parsetree.case -> To.Parsetree.case\n val copy_type_declaration : From.Parsetree.type_declaration -> To.Parsetree.type_declaration\n val copy_type_extension : From.Parsetree.type_extension -> To.Parsetree.type_extension\n val copy_extension_constructor: From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor\n(*$*)\nend\n\nmodule Migration_functions\n (A : OCaml_version) (B : OCaml_version)\n (A_to_B : Migrate_module with module From = A.Ast and module To = B.Ast)\n=\nstruct\n let migration_functions : (A.types, B.types) migration_functions =\n let open A_to_B in\n {\n (*$ foreach_type (fun _ s -> printf \" copy_%s;\\n\" s) *)\n copy_structure;\n copy_signature;\n copy_toplevel_phrase;\n copy_core_type;\n copy_expression;\n copy_pattern;\n copy_case;\n copy_type_declaration;\n copy_type_extension;\n copy_extension_constructor;\n(*$*)\n }\nend\n\nmodule Register_migration (A : OCaml_version) (B : OCaml_version)\n (A_to_B : Migrate_module with module From = A.Ast and module To = B.Ast)\n (B_to_A : Migrate_module with module From = B.Ast and module To = A.Ast)\n=\nstruct\n let () = (\n let is_undefined : type a. a migration -> bool = function\n | Undefined -> true\n | _ -> false\n in\n assert (A.version < B.version);\n assert (is_undefined A.migration_info.next_version);\n assert (is_undefined B.migration_info.previous_version);\n let module A_to_B_fun = Migration_functions(A)(B)(A_to_B) in\n let module B_to_A_fun = Migration_functions(B)(A)(B_to_A) in\n A.migration_info.next_version <-\n Migration ((module A), A_to_B_fun.migration_functions, (module B));\n B.migration_info.previous_version <-\n Migration ((module B), B_to_A_fun.migration_functions, (module A));\n )\nend\n\ntype 'from immediate_migration =\n | No_migration : 'from immediate_migration\n | Immediate_migration\n : ('from, 'to_) migration_functions * 'to_ ocaml_version\n -> 'from immediate_migration\n\nlet immediate_migration\n (*$ foreach_type (fun _ s -> printf \" (type %s)\\n\" s) *)\n (type structure)\n (type signature)\n (type toplevel_phrase)\n (type core_type)\n (type expression)\n (type pattern)\n (type case)\n (type type_declaration)\n (type type_extension)\n (type extension_constructor)\n(*$*)\n ((module A) : <\n (*$ foreach_type (fun _ s -> printf \" %-21s : %s;\\n\" s s) *)\n structure : structure;\n signature : signature;\n toplevel_phrase : toplevel_phrase;\n core_type : core_type;\n expression : expression;\n pattern : pattern;\n case : case;\n type_declaration : type_declaration;\n type_extension : type_extension;\n extension_constructor : extension_constructor;\n(*$*)\n > ocaml_version)\n direction\n =\n let version = match direction with\n | `Next -> A.migration_info.next_version\n | `Previous -> A.migration_info.previous_version\n in\n match version with\n | Undefined -> No_migration\n | Migration (_, funs, to_) -> Immediate_migration (funs, to_)\n | _ -> assert false\n\nlet migrate\n (*$ foreach_type (fun _ s -> printf \" (type %s1) (type %s2)\\n\" s s) *)\n (type structure1) (type structure2)\n (type signature1) (type signature2)\n (type toplevel_phrase1) (type toplevel_phrase2)\n (type core_type1) (type core_type2)\n (type expression1) (type expression2)\n (type pattern1) (type pattern2)\n (type case1) (type case2)\n (type type_declaration1) (type type_declaration2)\n (type type_extension1) (type type_extension2)\n (type extension_constructor1) (type extension_constructor2)\n(*$*)\n ((module A) : <\n (*$ foreach_type (fun _ s -> printf \" %-21s : %s1;\\n\" s s) *)\n structure : structure1;\n signature : signature1;\n toplevel_phrase : toplevel_phrase1;\n core_type : core_type1;\n expression : expression1;\n pattern : pattern1;\n case : case1;\n type_declaration : type_declaration1;\n type_extension : type_extension1;\n extension_constructor : extension_constructor1;\n(*$*)\n > ocaml_version)\n ((module B) : <\n (*$ foreach_type (fun _ s -> printf \" %-21s : %s2;\\n\" s s) *)\n structure : structure2;\n signature : signature2;\n toplevel_phrase : toplevel_phrase2;\n core_type : core_type2;\n expression : expression2;\n pattern : pattern2;\n case : case2;\n type_declaration : type_declaration2;\n type_extension : type_extension2;\n extension_constructor : extension_constructor2;\n(*$*)\n > ocaml_version)\n : (A.types, B.types) migration_functions\n =\n match A.Version with\n | B.Version -> migration_identity\n | _ ->\n let direction = if A.version < B.version then `Next else `Previous in\n let rec migrate (m : A.types immediate_migration) : (A.types, B.types) migration_functions =\n match m with\n | No_migration -> assert false\n | Immediate_migration (f, (module To)) ->\n match To.Version with\n | B.Version -> f\n | _ ->\n match immediate_migration (module To) direction with\n | No_migration -> assert false\n | Immediate_migration (g, to2) ->\n migrate (Immediate_migration (migration_compose f g, to2))\n in\n migrate (immediate_migration (module A) direction)\n\nmodule Convert (A : OCaml_version) (B : OCaml_version) = struct\n let {\n (*$ foreach_type (fun _ s -> printf \" copy_%s;\\n\" s) *)\n copy_structure;\n copy_signature;\n copy_toplevel_phrase;\n copy_core_type;\n copy_expression;\n copy_pattern;\n copy_case;\n copy_type_declaration;\n copy_type_extension;\n copy_extension_constructor;\n(*$*)\n } : (A.types, B.types) migration_functions =\n migrate (module A) (module B)\nend\n\n(*$ foreach_version (fun n version ->\n printf \"module OCaml_%d = struct\\n\" n;\n printf \" module Ast = Astlib.Ast_%d\\n\" n;\n printf \" include Make_witness(Astlib.Ast_%d)\\n\" n;\n printf \" let version = %d\\n\" n;\n printf \" let string_version = %S\\n\" version;\n printf \"end\\n\";\n printf \"let ocaml_%d : OCaml_%d.types ocaml_version = (module OCaml_%d)\\n\"\n n n n;\n )\n*)\nmodule OCaml_402 = struct\n module Ast = Astlib.Ast_402\n include Make_witness(Astlib.Ast_402)\n let version = 402\n let string_version = \"4.02\"\nend\nlet ocaml_402 : OCaml_402.types ocaml_version = (module OCaml_402)\nmodule OCaml_403 = struct\n module Ast = Astlib.Ast_403\n include Make_witness(Astlib.Ast_403)\n let version = 403\n let string_version = \"4.03\"\nend\nlet ocaml_403 : OCaml_403.types ocaml_version = (module OCaml_403)\nmodule OCaml_404 = struct\n module Ast = Astlib.Ast_404\n include Make_witness(Astlib.Ast_404)\n let version = 404\n let string_version = \"4.04\"\nend\nlet ocaml_404 : OCaml_404.types ocaml_version = (module OCaml_404)\nmodule OCaml_405 = struct\n module Ast = Astlib.Ast_405\n include Make_witness(Astlib.Ast_405)\n let version = 405\n let string_version = \"4.05\"\nend\nlet ocaml_405 : OCaml_405.types ocaml_version = (module OCaml_405)\nmodule OCaml_406 = struct\n module Ast = Astlib.Ast_406\n include Make_witness(Astlib.Ast_406)\n let version = 406\n let string_version = \"4.06\"\nend\nlet ocaml_406 : OCaml_406.types ocaml_version = (module OCaml_406)\nmodule OCaml_407 = struct\n module Ast = Astlib.Ast_407\n include Make_witness(Astlib.Ast_407)\n let version = 407\n let string_version = \"4.07\"\nend\nlet ocaml_407 : OCaml_407.types ocaml_version = (module OCaml_407)\nmodule OCaml_408 = struct\n module Ast = Astlib.Ast_408\n include Make_witness(Astlib.Ast_408)\n let version = 408\n let string_version = \"4.08\"\nend\nlet ocaml_408 : OCaml_408.types ocaml_version = (module OCaml_408)\nmodule OCaml_409 = struct\n module Ast = Astlib.Ast_409\n include Make_witness(Astlib.Ast_409)\n let version = 409\n let string_version = \"4.09\"\nend\nlet ocaml_409 : OCaml_409.types ocaml_version = (module OCaml_409)\nmodule OCaml_410 = struct\n module Ast = Astlib.Ast_410\n include Make_witness(Astlib.Ast_410)\n let version = 410\n let string_version = \"4.10\"\nend\nlet ocaml_410 : OCaml_410.types ocaml_version = (module OCaml_410)\nmodule OCaml_411 = struct\n module Ast = Astlib.Ast_411\n include Make_witness(Astlib.Ast_411)\n let version = 411\n let string_version = \"4.11\"\nend\nlet ocaml_411 : OCaml_411.types ocaml_version = (module OCaml_411)\nmodule OCaml_412 = struct\n module Ast = Astlib.Ast_412\n include Make_witness(Astlib.Ast_412)\n let version = 412\n let string_version = \"4.12\"\nend\nlet ocaml_412 : OCaml_412.types ocaml_version = (module OCaml_412)\nmodule OCaml_413 = struct\n module Ast = Astlib.Ast_413\n include Make_witness(Astlib.Ast_413)\n let version = 413\n let string_version = \"4.13\"\nend\nlet ocaml_413 : OCaml_413.types ocaml_version = (module OCaml_413)\nmodule OCaml_414 = struct\n module Ast = Astlib.Ast_414\n include Make_witness(Astlib.Ast_414)\n let version = 414\n let string_version = \"4.14\"\nend\nlet ocaml_414 : OCaml_414.types ocaml_version = (module OCaml_414)\n(*$*)\n\nlet all_versions : (module OCaml_version) list = [\n (*$foreach_version (fun n _ ->\n printf \"(module OCaml_%d : OCaml_version);\\n\" n)*)\n(module OCaml_402 : OCaml_version);\n(module OCaml_403 : OCaml_version);\n(module OCaml_404 : OCaml_version);\n(module OCaml_405 : OCaml_version);\n(module OCaml_406 : OCaml_version);\n(module OCaml_407 : OCaml_version);\n(module OCaml_408 : OCaml_version);\n(module OCaml_409 : OCaml_version);\n(module OCaml_410 : OCaml_version);\n(module OCaml_411 : OCaml_version);\n(module OCaml_412 : OCaml_version);\n(module OCaml_413 : OCaml_version);\n(module OCaml_414 : OCaml_version);\n(*$*)\n]\n\n(*$foreach_version_pair (fun a b ->\n printf \"include Register_migration(OCaml_%d)(OCaml_%d)\\n\" a b;\n printf \" (Astlib.Migrate_%d_%d)(Astlib.Migrate_%d_%d)\\n\" a b b a\n )\n*)\ninclude Register_migration(OCaml_402)(OCaml_403)\n (Astlib.Migrate_402_403)(Astlib.Migrate_403_402)\ninclude Register_migration(OCaml_403)(OCaml_404)\n (Astlib.Migrate_403_404)(Astlib.Migrate_404_403)\ninclude Register_migration(OCaml_404)(OCaml_405)\n (Astlib.Migrate_404_405)(Astlib.Migrate_405_404)\ninclude Register_migration(OCaml_405)(OCaml_406)\n (Astlib.Migrate_405_406)(Astlib.Migrate_406_405)\ninclude Register_migration(OCaml_406)(OCaml_407)\n (Astlib.Migrate_406_407)(Astlib.Migrate_407_406)\ninclude Register_migration(OCaml_407)(OCaml_408)\n (Astlib.Migrate_407_408)(Astlib.Migrate_408_407)\ninclude Register_migration(OCaml_408)(OCaml_409)\n (Astlib.Migrate_408_409)(Astlib.Migrate_409_408)\ninclude Register_migration(OCaml_409)(OCaml_410)\n (Astlib.Migrate_409_410)(Astlib.Migrate_410_409)\ninclude Register_migration(OCaml_410)(OCaml_411)\n (Astlib.Migrate_410_411)(Astlib.Migrate_411_410)\ninclude Register_migration(OCaml_411)(OCaml_412)\n (Astlib.Migrate_411_412)(Astlib.Migrate_412_411)\ninclude Register_migration(OCaml_412)(OCaml_413)\n (Astlib.Migrate_412_413)(Astlib.Migrate_413_412)\ninclude Register_migration(OCaml_413)(OCaml_414)\n (Astlib.Migrate_413_414)(Astlib.Migrate_414_413)\n(*$*)\n\nmodule OCaml_current = OCaml_OCAML_VERSION\n\nmodule Find_version = struct\n type t = Impl of (module OCaml_version) | Intf of (module OCaml_version) | Unknown\n\n let from_magic magic =\n let rec loop = function\n | [] -> Unknown\n | (module Version : OCaml_version) :: tail ->\n if Version.Ast.Config.ast_impl_magic_number = magic then\n Impl (module Version)\n else if Version.Ast.Config.ast_intf_magic_number = magic then\n Intf (module Version)\n else\n loop tail\n in\n loop all_versions\nend\n","module Caml = Stdlib\nopen Caml\nopen StdLabels\nmodule Sexp = Sexplib0.Sexp\nmodule Sexpable = Sexplib0.Sexpable\ninclude Sexplib0.Sexp_conv\n\nmodule type Comparisons = sig\n type t\n\n val compare : t -> t -> int\n val equal : t -> t -> bool\n val ( = ) : t -> t -> bool\n val ( < ) : t -> t -> bool\n val ( > ) : t -> t -> bool\n val ( <> ) : t -> t -> bool\n val ( <= ) : t -> t -> bool\n val ( >= ) : t -> t -> bool\n val min : t -> t -> t\n val max : t -> t -> t\nend\n\nmodule Poly = struct\n let compare = compare\n let equal = ( = )\n let ( = ) = ( = )\n let ( < ) = ( < )\n let ( > ) = ( > )\n let ( <> ) = ( <> )\n let ( <= ) = ( <= )\n let ( >= ) = ( >= )\n let min = min\n let max = max\nend\n\ninclude (Poly : Comparisons with type t := int)\nmodule Array = Array\n\nmodule Bool = struct\n let to_string = string_of_bool\n\n include (Poly : Comparisons with type t := bool)\nend\n\nmodule Bytes = struct\n include Bytes\n\n let sub_string t ~pos ~len = Stdlib.Bytes.sub_string t pos len\n\n let blit_string ~src ~src_pos ~dst ~dst_pos ~len =\n Stdlib.Bytes.blit_string src src_pos dst dst_pos len\nend\n\nmodule Char = struct\n include Char\n include (Poly : Comparisons with type t := char)\nend\n\nmodule Exn = struct\n let protectx x ~f ~finally =\n match f x with\n | y ->\n finally x;\n y\n | exception exn ->\n finally x;\n raise exn\nend\n\nmodule Float = struct\n let to_string = string_of_float\n\n include (Poly : Comparisons with type t := float)\nend\n\nmodule Fn = struct\n let id x = x\nend\n\nmodule Hashtbl = struct\n include Hashtbl\n\n let set t ~key ~data =\n while mem t key do\n remove t key\n done;\n add t key data\n\n let add t ~key ~data =\n if mem t key then Error (Invalid_argument \"Hashtbl.add_exn\")\n else (\n add t key data;\n Ok ())\n\n let add_exn t ~key ~data =\n match add t ~key ~data with Ok () -> () | Error exn -> raise exn\n\n let find_opt t key =\n match find t key with data -> Some data | exception Not_found -> None\n\n let find_or_add t key ~default =\n match find_opt t key with\n | Some data -> data\n | None ->\n let data = default () in\n add_exn t ~key ~data;\n data\n\n let rec add_alist t alist =\n match alist with\n | [] -> Ok ()\n | (key, data) :: tail -> (\n match add t ~key ~data with\n | Ok () -> add_alist t tail\n | Error (_ : exn) -> Error key)\n\n let of_alist ?size alist =\n let size =\n match size with Some size -> size | None -> List.length alist\n in\n let t = create size in\n match add_alist t alist with Ok () -> Ok t | Error _ as error -> error\n\n let of_alist_exn ?size alist =\n match of_alist ?size alist with\n | Ok t -> t\n | Error _ -> raise (Invalid_argument \"Hashtbl.of_alist_exn\")\nend\n\nmodule In_channel = struct\n let create ?(binary = true) file =\n let flags = [ Open_rdonly ] in\n let flags = if binary then Open_binary :: flags else flags in\n open_in_gen flags 0o000 file\n\n let with_file ?binary filename ~f =\n let t = create ?binary filename in\n Exn.protectx t ~f ~finally:close_in\n\n let input_all t =\n let rec read_all_into t buf =\n match input_char t with\n | char ->\n Buffer.add_char buf char;\n read_all_into t buf\n | exception End_of_file -> ()\n in\n let buf = Buffer.create 64 in\n read_all_into t buf;\n Buffer.contents buf\n\n let read_all filename = with_file filename ~f:input_all\nend\n\nmodule Int = struct\n let max_int = max_int\n let to_string = string_of_int\n\n include (Poly : Comparisons with type t := int)\nend\n\nmodule List = struct\n include List\n\n include struct\n (* shadow non-tail-recursive functions *)\n let merge = `not_tail_recursive\n let remove_assoc = `not_tail_recursive\n let remove_assq = `not_tail_recursive\n\n let rev_mapi list ~f =\n let rec rev_mapi_at list i ~f ~acc =\n match list with\n | [] -> acc\n | head :: tail -> rev_mapi_at tail (i + 1) ~f ~acc:(f i head :: acc)\n in\n rev_mapi_at list 0 ~f ~acc:[]\n\n let fold_right2 list1 list2 ~init ~f =\n fold_left2 (rev list1) (rev list2) ~init ~f:(fun acc x y -> f x y acc)\n\n let map list ~f = rev (rev_map list ~f)\n let mapi list ~f = rev (rev_mapi list ~f)\n\n let fold_right list ~init ~f =\n fold_left (List.rev list) ~init ~f:(fun acc x -> f x acc)\n\n let append x y = rev_append (rev x) y\n let concat list = fold_right list ~init:[] ~f:append\n\n let rev_combine list1 list2 =\n fold_left2 list1 list2 ~init:[] ~f:(fun acc x y -> (x, y) :: acc)\n\n let combine list1 list2 = rev (rev_combine list1 list2)\n\n let split list =\n fold_right list ~init:([], []) ~f:(fun (x, y) (xs, ys) ->\n (x :: xs, y :: ys))\n\n let map2 list1 list2 ~f =\n rev (fold_left2 list1 list2 ~init:[] ~f:(fun acc x y -> f x y :: acc))\n end\n\n let init ~len ~f =\n let rec loop ~len ~pos ~f ~acc =\n if pos >= len then List.rev acc\n else loop ~len ~pos:(pos + 1) ~f ~acc:(f pos :: acc)\n in\n loop ~len ~pos:0 ~f ~acc:[]\n\n let is_empty = function [] -> true | _ :: _ -> false\n\n let rev_filter_opt list =\n fold_left list ~init:[] ~f:(fun tail option ->\n match option with None -> tail | Some head -> head :: tail)\n\n let filter_opt list = rev (rev_filter_opt list)\n let filter_map list ~f = rev_filter_opt (rev_map list ~f)\n let concat_map list ~f = concat (map list ~f)\n\n let rec find_map list ~f =\n match list with\n | [] -> None\n | head :: tail -> (\n match f head with Some _ as some -> some | None -> find_map tail ~f)\n\n let find_map_exn list ~f =\n match find_map list ~f with Some x -> x | None -> raise Not_found\n\n let rec last = function\n | [] -> None\n | [ x ] -> Some x\n | _ :: (_ :: _ as rest) -> last rest\n\n let split_while list ~f =\n let rec split_while_into list ~f ~acc =\n match list with\n | head :: tail when f head -> split_while_into tail ~f ~acc:(head :: acc)\n | _ :: _ | [] -> (List.rev acc, list)\n in\n split_while_into list ~f ~acc:[]\n\n let find_a_dup (type elt) list ~compare =\n let module Elt = struct\n type t = elt\n\n let compare = compare\n end in\n let module Elt_set = Set.Make (Elt) in\n let rec find_a_dup_in list ~set =\n match list with\n | [] -> None\n | head :: tail ->\n if Elt_set.mem head set then Some head\n else find_a_dup_in tail ~set:(Elt_set.add head set)\n in\n find_a_dup_in list ~set:Elt_set.empty\n\n let assoc_opt key alist =\n match assoc key alist with x -> Some x | exception Not_found -> None\n\n (* reorders arguments to improve type inference *)\n let iter list ~f = iter list ~f\nend\n\nmodule Option = struct\n let is_some = function None -> false | Some _ -> true\n let iter t ~f = match t with None -> () | Some x -> f x\n let map t ~f = match t with None -> None | Some x -> Some (f x)\n let value t ~default = match t with None -> default | Some x -> x\nend\n\nmodule Out_channel = struct\n let create ?(binary = true) ?(append = false) ?(fail_if_exists = false)\n ?(perm = 0o666) file =\n let flags = [ Open_wronly; Open_creat ] in\n let flags = (if binary then Open_binary else Open_text) :: flags in\n let flags = (if append then Open_append else Open_trunc) :: flags in\n let flags = if fail_if_exists then Open_excl :: flags else flags in\n open_out_gen flags perm file\n\n let with_file ?binary ?append ?fail_if_exists ?perm file ~f =\n let t = create ?binary ?append ?fail_if_exists ?perm file in\n Exn.protectx t ~f ~finally:close_out\n\n let write_all filename ~data =\n with_file filename ~f:(fun t -> output_string t data)\nend\n\nmodule String = struct\n include String\n\n let is_empty (t : t) = length t = 0\n let prefix t len = sub t ~pos:0 ~len\n let suffix t len = sub t ~pos:(length t - len) ~len\n let drop_prefix t len = sub t ~pos:len ~len:(length t - len)\n let drop_suffix t len = sub t ~pos:0 ~len:(length t - len)\n\n let is_prefix t ~prefix =\n let rec is_prefix_from t ~prefix ~pos ~len =\n pos >= len\n || Char.equal (get t pos) (get prefix pos)\n && is_prefix_from t ~prefix ~pos:(pos + 1) ~len\n in\n length t >= length prefix\n && is_prefix_from t ~prefix ~pos:0 ~len:(length prefix)\n\n let is_suffix t ~suffix =\n let rec is_suffix_up_to t ~suffix ~pos ~suffix_offset =\n pos < 0\n || Char.equal (get t (suffix_offset + pos)) (get suffix pos)\n && is_suffix_up_to t ~suffix ~pos:(pos - 1) ~suffix_offset\n in\n length t >= length suffix\n && is_suffix_up_to t ~suffix\n ~pos:(length suffix - 1)\n ~suffix_offset:(length t - length suffix)\n\n let exists t ~f =\n let rec exists_at t ~f ~pos ~len =\n pos < len && (f (get t pos) || exists_at t ~f ~pos:(pos + 1) ~len)\n in\n exists_at t ~f ~pos:0 ~len:(length t)\n\n let for_all t ~f =\n let rec for_all_at t ~f ~pos ~len =\n pos >= len || (f (get t pos) && for_all_at t ~f ~pos:(pos + 1) ~len)\n in\n for_all_at t ~f ~pos:0 ~len:(length t)\n\n let index_opt t char =\n match index t char with i -> Some i | exception Not_found -> None\n\n let rindex_opt t char =\n match rindex t char with i -> Some i | exception Not_found -> None\n\n let index_from_opt t char pos =\n match index_from t char pos with i -> Some i | exception Not_found -> None\n\n let rindex_from_opt t char pos =\n match rindex_from t char pos with\n | i -> Some i\n | exception Not_found -> None\n\n let lsplit2 t ~on =\n match index_opt t on with\n | None -> None\n | Some i ->\n Some (sub t ~pos:0 ~len:i, sub t ~pos:(i + 1) ~len:(length t - i - 1))\n\n let capitalize_ascii = Stdlib.String.capitalize_ascii\n let lowercase_ascii = Stdlib.String.lowercase_ascii\n let uncapitalize_ascii = Stdlib.String.uncapitalize_ascii\n let split_on_char t ~sep = Stdlib.String.split_on_char sep t\n\n include (Poly : Comparisons with type t := string)\n\n module Map = struct\n include Map.Make (String)\n\n let find_opt key t =\n match find key t with x -> Some x | exception Not_found -> None\n end\n\n module Set = Set.Make (String)\nend\n\nlet ( @ ) = List.append\nlet output oc bytes ~pos ~len = output oc bytes pos len\nlet output_substring oc string ~pos ~len = output_substring oc string pos len\n","open! Import\nmodule Format = Caml.Format\n\nlet fold_dot_suffixes name ~init:acc ~f =\n let rec collapse_after_at = function\n | [] -> []\n | part :: parts ->\n if (not (String.is_empty part)) && Char.equal part.[0] '@' then\n [ String.concat (String.drop_prefix part 1 :: parts) ~sep:\".\" ]\n else part :: collapse_after_at parts\n in\n let rec loop acc parts =\n match parts with\n | [] -> acc\n | part :: parts ->\n loop (f (String.concat (part :: parts) ~sep:\".\") acc) parts\n in\n String.split_on_char name ~sep:'.' |> collapse_after_at |> loop acc\n\nlet dot_suffixes name =\n fold_dot_suffixes name ~init:[] ~f:(fun x acc -> x :: acc)\n\nlet split_path =\n let rec loop s i =\n if i = String.length s then (s, None)\n else match s.[i] with '.' -> after_dot s (i + 1) | _ -> loop s (i + 1)\n and after_dot s i =\n if i = String.length s then (s, None)\n else\n match s.[i] with\n | 'A' .. 'Z' -> (String.prefix s (i - 1), Some (String.drop_prefix s i))\n | '.' -> after_dot s (i + 1)\n | _ -> loop s (i + 1)\n in\n fun s -> loop s 0\n\nmodule Pattern = struct\n type t = { name : string; dot_suffixes : String.Set.t }\n\n let make name =\n { name; dot_suffixes = String.Set.of_list (dot_suffixes name) }\n\n let name t = t.name\n let matches t matched = String.Set.mem matched t.dot_suffixes\nend\n\nlet get_outer_namespace name =\n match String.index_opt name '.' with\n | None -> None\n | Some i -> Some (String.sub name ~pos:0 ~len:i)\n\nmodule Whitelisted = struct\n (* White list the following attributes, as well as all their dot suffixes.\n\n Since these attributes are interpreted by the compiler itself, we cannot check\n at the level of a ppx rewriter that they have been properly interpreted, so\n we just accept them anywhere.\n\n Sadly, the compiler silently ignores them if they are misplaced...\n *)\n let create_set fully_qualified_names =\n List.fold_left\n ~f:(fun acc name ->\n fold_dot_suffixes name ~init:acc ~f:(fun x acc -> String.Set.add x acc))\n ~init:String.Set.empty fully_qualified_names\n\n let attributes =\n create_set\n [\n \"ocaml.alert\";\n \"ocaml.boxed\";\n \"ocaml.deprecated\";\n \"ocaml.deprecated_mutable\";\n \"ocaml.doc\";\n \"ocaml.extension_constructor\";\n \"ocaml.immediate\";\n \"ocaml.immediate64\";\n \"ocaml.inline\";\n \"ocaml.inlined\";\n \"ocaml.local\";\n \"ocaml.noalloc\";\n \"ocaml.ppwarning\";\n \"ocaml.remove_aliases\";\n \"ocaml.specialise\";\n \"ocaml.specialised\";\n \"ocaml.tailcall\";\n \"ocaml.text\";\n \"ocaml.unboxed\";\n \"ocaml.unroll\";\n \"ocaml.unrolled\";\n \"ocaml.untagged\";\n \"ocaml.warn_on_literal_pattern\";\n \"ocaml.warnerror\";\n \"ocaml.warning\";\n ]\n\n (* White list the following extensions.\n\n Since these extensions are interpreted by the compiler itself, we cannot check\n at the level of a ppx rewriter that they have been properly interpreted, so\n we just accept them anywhere.\n *)\n let extensions = create_set [ \"ocaml.error\"; \"ocaml.extension_constructor\" ]\n\n let is_whitelisted ~kind name =\n match kind with\n | `Attribute -> String.Set.mem name attributes\n | `Extension -> String.Set.mem name extensions\n\n let get_attribute_list () = String.Set.elements attributes\n let get_extension_list () = String.Set.elements extensions\nend\n\nmodule Reserved_namespaces = struct\n let tbl : (string, unit) Hashtbl.t = Hashtbl.create 16\n let reserve ns = Hashtbl.add_exn tbl ~key:ns ~data:()\n let () = reserve \"merlin\"\n let () = reserve \"reason\"\n let () = reserve \"refmt\"\n let () = reserve \"metaocaml\"\n let () = reserve \"ocamlformat\"\n\n let is_in_reserved_namespaces name =\n match get_outer_namespace name with\n | Some ns -> Hashtbl.mem tbl ns\n | None -> Hashtbl.mem tbl name\n\n let check_not_reserved ~kind name =\n let kind, list =\n match kind with\n | `Attribute -> (\"attribute\", Whitelisted.attributes)\n | `Extension -> (\"extension\", Whitelisted.extensions)\n in\n if String.Set.mem name list then\n Printf.ksprintf failwith\n \"Cannot register %s with name '%s' as it matches an %s reserved by the \\\n compiler\"\n kind name kind\n else if is_in_reserved_namespaces name then\n Printf.ksprintf failwith\n \"Cannot register %s with name '%s' as its namespace is marked as \\\n reserved\"\n kind name\nend\n\nlet ignore_checks name =\n Reserved_namespaces.is_in_reserved_namespaces name\n || String.is_prefix name ~prefix:\"_\"\n\nmodule Registrar = struct\n type element = { fully_qualified_name : string; declared_at : Caller_id.t }\n type all_for_context = { mutable all : element String.Map.t }\n\n type 'a t = {\n all_by_context : ('a, all_for_context) Hashtbl.t;\n skip : string list;\n kind : string;\n string_of_context : 'a -> string option;\n }\n\n let create ~kind ~current_file ~string_of_context =\n {\n all_by_context = Hashtbl.create 16;\n skip = [ current_file; __FILE__ ];\n kind;\n string_of_context;\n }\n\n let get_all_for_context t context =\n Hashtbl.find_or_add t.all_by_context context ~default:(fun () ->\n { all = String.Map.empty })\n\n let check_collisions_local ~caller ~all_for_context t context name =\n match String.Map.find_opt name all_for_context.all with\n | None -> ()\n | Some e ->\n let declared_at = function\n | None -> \"\"\n | Some (loc : Caml.Printexc.location) ->\n Printf.sprintf \" declared at %s:%d\" loc.filename loc.line_number\n in\n let context =\n match t.string_of_context context with\n | None -> \"\"\n | Some s -> \" on \" ^ s ^ \"s\"\n in\n Printf.ksprintf failwith\n \"Some ppx-es tried to register conflicting transformations: %s \\\n '%s'%s%s matches %s '%s'%s\"\n (String.capitalize_ascii t.kind)\n name context (declared_at caller) t.kind e.fully_qualified_name\n (declared_at e.declared_at)\n\n let check_collisions t context name =\n let caller = Caller_id.get ~skip:t.skip in\n let all_for_context = get_all_for_context t context in\n check_collisions_local ~caller ~all_for_context t context name\n\n let register ~kind t context name =\n Reserved_namespaces.check_not_reserved ~kind name;\n let caller = Caller_id.get ~skip:t.skip in\n let all = get_all_for_context t context in\n check_collisions_local ~caller ~all_for_context:all t context name;\n let t = { fully_qualified_name = name; declared_at = caller } in\n all.all <-\n fold_dot_suffixes name ~init:all.all ~f:(fun name acc ->\n String.Map.add name t acc)\n\n let spellcheck t context ?(white_list = []) name =\n let all =\n let all = get_all_for_context t context in\n String.Map.fold (fun key _ acc -> key :: acc) all.all []\n in\n match Spellcheck.spellcheck (all @ white_list) name with\n | Some _ as x -> x\n | None -> (\n let other_contexts =\n Hashtbl.fold\n (fun ctx { all } acc ->\n if Poly.( <> ) context ctx && String.Map.mem name all then\n match t.string_of_context ctx with\n | None -> acc\n | Some s -> (s ^ \"s\") :: acc\n else acc)\n t.all_by_context []\n in\n let pp_text = Format.pp_print_text in\n let current_context ppf =\n match t.string_of_context context with\n | None | Some \"\" -> ()\n | Some s ->\n let a_or_an =\n match s.[0] with\n | 'a' | 'e' | 'i' | 'o' | 'u' | 'y' -> \"an\"\n | _ -> \"a\"\n in\n Format.fprintf ppf\n \"@ but@ is@ used@ here@ in@ the@ context@ of@ %s@ %a\" a_or_an\n pp_text s\n in\n match\n List.sort ~cmp:(fun x y -> -String.compare x y) other_contexts\n with\n | [] -> None\n | [ c ] ->\n Some\n (Format.asprintf\n \"@[Hint:@ `%s'@ is@ available@ for@ %a%t.@]@\\n\\\n Did you put it at the wrong level?\" name pp_text c\n current_context)\n | last :: rev_others ->\n let others = List.rev rev_others in\n Some\n (Format.asprintf\n \"@[Hint:@ `%s'@ is@ available@ for@ %a@ and@ %a%t.@]@\\n\\\n Did you put it at the wrong level?\" name\n (Format.pp_print_list pp_text ~pp_sep:(fun ppf () ->\n Format.fprintf ppf \",@ \"))\n others pp_text last current_context))\n\n (* TODO: hint spelling errors regarding reserved namespaces names and white\n listed names instead of taking an optional [white_list] parameter. *)\n let raise_errorf t context ?white_list fmt (name : string Loc.t) =\n Printf.ksprintf\n (fun msg ->\n match spellcheck t context name.txt ?white_list with\n | None -> Location.raise_errorf ~loc:name.loc \"%s\" msg\n | Some s -> Location.raise_errorf ~loc:name.loc \"%s.\\n%s\" msg s)\n fmt name.txt\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Jerome Vouillon, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2002 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nopen Obj\n\n(**** Object representation ****)\n\nexternal set_id: 'a -> 'a = \"caml_set_oo_id\" [@@noalloc]\n\n(**** Object copy ****)\n\nlet copy o =\n let o = (Obj.obj (Obj.dup (Obj.repr o))) in\n set_id o\n\n(**** Compression options ****)\n(* Parameters *)\ntype params = {\n mutable compact_table : bool;\n mutable copy_parent : bool;\n mutable clean_when_copying : bool;\n mutable retry_count : int;\n mutable bucket_small_size : int\n }\n\nlet params = {\n compact_table = true;\n copy_parent = true;\n clean_when_copying = true;\n retry_count = 3;\n bucket_small_size = 16\n}\n\n(**** Parameters ****)\n\nlet initial_object_size = 2\n\n(**** Items ****)\n\ntype item = DummyA | DummyB | DummyC of int\nlet _ = [DummyA; DummyB; DummyC 0] (* to avoid warnings *)\n\nlet dummy_item = (magic () : item)\n\n(**** Types ****)\n\ntype tag\ntype label = int\ntype closure = item\ntype t = DummyA | DummyB | DummyC of int\nlet _ = [DummyA; DummyB; DummyC 0] (* to avoid warnings *)\n\ntype obj = t array\nexternal ret : (obj -> 'a) -> closure = \"%identity\"\n\n(**** Labels ****)\n\nlet public_method_label s : tag =\n let accu = ref 0 in\n for i = 0 to String.length s - 1 do\n accu := 223 * !accu + Char.code s.[i]\n done;\n (* reduce to 31 bits *)\n accu := !accu land (1 lsl 31 - 1);\n (* make it signed for 64 bits architectures *)\n let tag = if !accu > 0x3FFFFFFF then !accu - (1 lsl 31) else !accu in\n (* Printf.eprintf \"%s = %d\\n\" s tag; flush stderr; *)\n magic tag\n\n(**** Sparse array ****)\n\nmodule Vars =\n Map.Make(struct type t = string let compare (x:t) y = compare x y end)\ntype vars = int Vars.t\n\nmodule Meths =\n Map.Make(struct type t = string let compare (x:t) y = compare x y end)\ntype meths = label Meths.t\nmodule Labs =\n Map.Make(struct type t = label let compare (x:t) y = compare x y end)\ntype labs = bool Labs.t\n\n(* The compiler assumes that the first field of this structure is [size]. *)\ntype table =\n { mutable size: int;\n mutable methods: closure array;\n mutable methods_by_name: meths;\n mutable methods_by_label: labs;\n mutable previous_states:\n (meths * labs * (label * item) list * vars *\n label list * string list) list;\n mutable hidden_meths: (label * item) list;\n mutable vars: vars;\n mutable initializers: (obj -> unit) list }\n\nlet dummy_table =\n { methods = [| dummy_item |];\n methods_by_name = Meths.empty;\n methods_by_label = Labs.empty;\n previous_states = [];\n hidden_meths = [];\n vars = Vars.empty;\n initializers = [];\n size = 0 }\n\nlet table_count = ref 0\n\n(* dummy_met should be a pointer, so use an atom *)\nlet dummy_met : item = obj (Obj.new_block 0 0)\n(* if debugging is needed, this could be a good idea: *)\n(* let dummy_met () = failwith \"Undefined method\" *)\n\nlet rec fit_size n =\n if n <= 2 then n else\n fit_size ((n+1)/2) * 2\n\nlet new_table pub_labels =\n incr table_count;\n let len = Array.length pub_labels in\n let methods = Array.make (len*2+2) dummy_met in\n methods.(0) <- magic len;\n methods.(1) <- magic (fit_size len * Sys.word_size / 8 - 1);\n for i = 0 to len - 1 do methods.(i*2+3) <- magic pub_labels.(i) done;\n { methods = methods;\n methods_by_name = Meths.empty;\n methods_by_label = Labs.empty;\n previous_states = [];\n hidden_meths = [];\n vars = Vars.empty;\n initializers = [];\n size = initial_object_size }\n\nlet resize array new_size =\n let old_size = Array.length array.methods in\n if new_size > old_size then begin\n let new_buck = Array.make new_size dummy_met in\n Array.blit array.methods 0 new_buck 0 old_size;\n array.methods <- new_buck\n end\n\nlet put array label element =\n resize array (label + 1);\n array.methods.(label) <- element\n\n(**** Classes ****)\n\nlet method_count = ref 0\nlet inst_var_count = ref 0\n\n(* type t *)\ntype meth = item\n\nlet new_method table =\n let index = Array.length table.methods in\n resize table (index + 1);\n index\n\nlet get_method_label table name =\n try\n Meths.find name table.methods_by_name\n with Not_found ->\n let label = new_method table in\n table.methods_by_name <- Meths.add name label table.methods_by_name;\n table.methods_by_label <- Labs.add label true table.methods_by_label;\n label\n\nlet get_method_labels table names =\n Array.map (get_method_label table) names\n\nlet set_method table label element =\n incr method_count;\n if Labs.find label table.methods_by_label then\n put table label element\n else\n table.hidden_meths <- (label, element) :: table.hidden_meths\n\nlet get_method table label =\n try List.assoc label table.hidden_meths\n with Not_found -> table.methods.(label)\n\nlet to_list arr =\n if arr == magic 0 then [] else Array.to_list arr\n\nlet narrow table vars virt_meths concr_meths =\n let vars = to_list vars\n and virt_meths = to_list virt_meths\n and concr_meths = to_list concr_meths in\n let virt_meth_labs = List.map (get_method_label table) virt_meths in\n let concr_meth_labs = List.map (get_method_label table) concr_meths in\n table.previous_states <-\n (table.methods_by_name, table.methods_by_label, table.hidden_meths,\n table.vars, virt_meth_labs, vars)\n :: table.previous_states;\n table.vars <-\n Vars.fold\n (fun lab info tvars ->\n if List.mem lab vars then Vars.add lab info tvars else tvars)\n table.vars Vars.empty;\n let by_name = ref Meths.empty in\n let by_label = ref Labs.empty in\n List.iter2\n (fun met label ->\n by_name := Meths.add met label !by_name;\n by_label :=\n Labs.add label\n (try Labs.find label table.methods_by_label with Not_found -> true)\n !by_label)\n concr_meths concr_meth_labs;\n List.iter2\n (fun met label ->\n by_name := Meths.add met label !by_name;\n by_label := Labs.add label false !by_label)\n virt_meths virt_meth_labs;\n table.methods_by_name <- !by_name;\n table.methods_by_label <- !by_label;\n table.hidden_meths <-\n List.fold_right\n (fun ((lab, _) as met) hm ->\n if List.mem lab virt_meth_labs then hm else met::hm)\n table.hidden_meths\n []\n\nlet widen table =\n let (by_name, by_label, saved_hidden_meths, saved_vars, virt_meths, vars) =\n List.hd table.previous_states\n in\n table.previous_states <- List.tl table.previous_states;\n table.vars <-\n List.fold_left\n (fun s v -> Vars.add v (Vars.find v table.vars) s)\n saved_vars vars;\n table.methods_by_name <- by_name;\n table.methods_by_label <- by_label;\n table.hidden_meths <-\n List.fold_right\n (fun ((lab, _) as met) hm ->\n if List.mem lab virt_meths then hm else met::hm)\n table.hidden_meths\n saved_hidden_meths\n\nlet new_slot table =\n let index = table.size in\n table.size <- index + 1;\n index\n\nlet new_variable table name =\n try Vars.find name table.vars\n with Not_found ->\n let index = new_slot table in\n if name <> \"\" then table.vars <- Vars.add name index table.vars;\n index\n\nlet to_array arr =\n if arr = Obj.magic 0 then [||] else arr\n\nlet new_methods_variables table meths vals =\n let meths = to_array meths in\n let nmeths = Array.length meths and nvals = Array.length vals in\n let res = Array.make (nmeths + nvals) 0 in\n for i = 0 to nmeths - 1 do\n res.(i) <- get_method_label table meths.(i)\n done;\n for i = 0 to nvals - 1 do\n res.(i+nmeths) <- new_variable table vals.(i)\n done;\n res\n\nlet get_variable table name =\n try Vars.find name table.vars with Not_found -> assert false\n\nlet get_variables table names =\n Array.map (get_variable table) names\n\nlet add_initializer table f =\n table.initializers <- f::table.initializers\n\n(*\nmodule Keys =\n Map.Make(struct type t = tag array let compare (x:t) y = compare x y end)\nlet key_map = ref Keys.empty\nlet get_key tags : item =\n try magic (Keys.find tags !key_map : tag array)\n with Not_found ->\n key_map := Keys.add tags tags !key_map;\n magic tags\n*)\n\nlet create_table public_methods =\n if public_methods == magic 0 then new_table [||] else\n (* [public_methods] must be in ascending order for bytecode *)\n let tags = Array.map public_method_label public_methods in\n let table = new_table tags in\n Array.iteri\n (fun i met ->\n let lab = i*2+2 in\n table.methods_by_name <- Meths.add met lab table.methods_by_name;\n table.methods_by_label <- Labs.add lab true table.methods_by_label)\n public_methods;\n table\n\nlet init_class table =\n inst_var_count := !inst_var_count + table.size - 1;\n table.initializers <- List.rev table.initializers;\n resize table (3 + magic table.methods.(1) * 16 / Sys.word_size)\n\nlet inherits cla vals virt_meths concr_meths (_, super, _, env) top =\n narrow cla vals virt_meths concr_meths;\n let init =\n if top then super cla env else Obj.repr (super cla) in\n widen cla;\n Array.concat\n [[| repr init |];\n magic (Array.map (get_variable cla) (to_array vals) : int array);\n Array.map\n (fun nm -> repr (get_method cla (get_method_label cla nm) : closure))\n (to_array concr_meths) ]\n\nlet make_class pub_meths class_init =\n let table = create_table pub_meths in\n let env_init = class_init table in\n init_class table;\n (env_init (Obj.repr 0), class_init, env_init, Obj.repr 0)\n\ntype init_table = { mutable env_init: t; mutable class_init: table -> t }\n[@@warning \"-unused-field\"]\n\nlet make_class_store pub_meths class_init init_table =\n let table = create_table pub_meths in\n let env_init = class_init table in\n init_class table;\n init_table.class_init <- class_init;\n init_table.env_init <- env_init\n\nlet dummy_class loc =\n let undef = fun _ -> raise (Undefined_recursive_module loc) in\n (Obj.magic undef, undef, undef, Obj.repr 0)\n\n(**** Objects ****)\n\nlet create_object table =\n (* XXX Appel de [obj_block] | Call to [obj_block] *)\n let obj = Obj.new_block Obj.object_tag table.size in\n (* XXX Appel de [caml_modify] | Call to [caml_modify] *)\n Obj.set_field obj 0 (Obj.repr table.methods);\n Obj.obj (set_id obj)\n\nlet create_object_opt obj_0 table =\n if (Obj.magic obj_0 : bool) then obj_0 else begin\n (* XXX Appel de [obj_block] | Call to [obj_block] *)\n let obj = Obj.new_block Obj.object_tag table.size in\n (* XXX Appel de [caml_modify] | Call to [caml_modify] *)\n Obj.set_field obj 0 (Obj.repr table.methods);\n Obj.obj (set_id obj)\n end\n\nlet rec iter_f obj =\n function\n [] -> ()\n | f::l -> f obj; iter_f obj l\n\nlet run_initializers obj table =\n let inits = table.initializers in\n if inits <> [] then\n iter_f obj inits\n\nlet run_initializers_opt obj_0 obj table =\n if (Obj.magic obj_0 : bool) then obj else begin\n let inits = table.initializers in\n if inits <> [] then iter_f obj inits;\n obj\n end\n\nlet create_object_and_run_initializers obj_0 table =\n if (Obj.magic obj_0 : bool) then obj_0 else begin\n let obj = create_object table in\n run_initializers obj table;\n obj\n end\n\n(* Equivalent primitive below\nlet sendself obj lab =\n (magic obj : (obj -> t) array array).(0).(lab) obj\n*)\nexternal send : obj -> tag -> 'a = \"%send\"\nexternal sendcache : obj -> tag -> t -> int -> 'a = \"%sendcache\"\nexternal sendself : obj -> label -> 'a = \"%sendself\"\nexternal get_public_method : obj -> tag -> closure\n = \"caml_get_public_method\" [@@noalloc]\n\n(**** table collection access ****)\n\ntype tables =\n | Empty\n | Cons of {key : closure; mutable data: tables; mutable next: tables}\n\nlet set_data tables v = match tables with\n | Empty -> assert false\n | Cons tables -> tables.data <- v\nlet set_next tables v = match tables with\n | Empty -> assert false\n | Cons tables -> tables.next <- v\nlet get_key = function\n | Empty -> assert false\n | Cons tables -> tables.key\nlet get_data = function\n | Empty -> assert false\n | Cons tables -> tables.data\nlet get_next = function\n | Empty -> assert false\n | Cons tables -> tables.next\n\nlet build_path n keys tables =\n let res = Cons {key = Obj.magic 0; data = Empty; next = Empty} in\n let r = ref res in\n for i = 0 to n do\n r := Cons {key = keys.(i); data = !r; next = Empty}\n done;\n set_data tables !r;\n res\n\nlet rec lookup_keys i keys tables =\n if i < 0 then tables else\n let key = keys.(i) in\n let rec lookup_key (tables:tables) =\n if get_key tables == key then\n match get_data tables with\n | Empty -> assert false\n | Cons _ as tables_data ->\n lookup_keys (i-1) keys tables_data\n else\n match get_next tables with\n | Cons _ as next -> lookup_key next\n | Empty ->\n let next : tables = Cons {key; data = Empty; next = Empty} in\n set_next tables next;\n build_path (i-1) keys next\n in\n lookup_key tables\n\nlet lookup_tables root keys =\n match get_data root with\n | Cons _ as root_data ->\n lookup_keys (Array.length keys - 1) keys root_data\n | Empty ->\n build_path (Array.length keys - 1) keys root\n\n(**** builtin methods ****)\n\nlet get_const x = ret (fun _obj -> x)\nlet get_var n = ret (fun obj -> Array.unsafe_get obj n)\nlet get_env e n =\n ret (fun obj ->\n Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n)\nlet get_meth n = ret (fun obj -> sendself obj n)\nlet set_var n = ret (fun obj x -> Array.unsafe_set obj n x)\nlet app_const f x = ret (fun _obj -> f x)\nlet app_var f n = ret (fun obj -> f (Array.unsafe_get obj n))\nlet app_env f e n =\n ret (fun obj ->\n f (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n))\nlet app_meth f n = ret (fun obj -> f (sendself obj n))\nlet app_const_const f x y = ret (fun _obj -> f x y)\nlet app_const_var f x n = ret (fun obj -> f x (Array.unsafe_get obj n))\nlet app_const_meth f x n = ret (fun obj -> f x (sendself obj n))\nlet app_var_const f n x = ret (fun obj -> f (Array.unsafe_get obj n) x)\nlet app_meth_const f n x = ret (fun obj -> f (sendself obj n) x)\nlet app_const_env f x e n =\n ret (fun obj ->\n f x (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n))\nlet app_env_const f e n x =\n ret (fun obj ->\n f (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n) x)\nlet meth_app_const n x = ret (fun obj -> (sendself obj n : _ -> _) x)\nlet meth_app_var n m =\n ret (fun obj -> (sendself obj n : _ -> _) (Array.unsafe_get obj m))\nlet meth_app_env n e m =\n ret (fun obj -> (sendself obj n : _ -> _)\n (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) m))\nlet meth_app_meth n m =\n ret (fun obj -> (sendself obj n : _ -> _) (sendself obj m))\nlet send_const m x c =\n ret (fun obj -> sendcache x m (Array.unsafe_get obj 0) c)\nlet send_var m n c =\n ret (fun obj ->\n sendcache (Obj.magic (Array.unsafe_get obj n) : obj) m\n (Array.unsafe_get obj 0) c)\nlet send_env m e n c =\n ret (fun obj ->\n sendcache\n (Obj.magic (Array.unsafe_get\n (Obj.magic (Array.unsafe_get obj e) : obj) n) : obj)\n m (Array.unsafe_get obj 0) c)\nlet send_meth m n c =\n ret (fun obj ->\n sendcache (sendself obj n) m (Array.unsafe_get obj 0) c)\nlet new_cache table =\n let n = new_method table in\n let n =\n if n mod 2 = 0 || n > 2 + magic table.methods.(1) * 16 / Sys.word_size\n then n else new_method table\n in\n table.methods.(n) <- Obj.magic 0;\n n\n\ntype impl =\n GetConst\n | GetVar\n | GetEnv\n | GetMeth\n | SetVar\n | AppConst\n | AppVar\n | AppEnv\n | AppMeth\n | AppConstConst\n | AppConstVar\n | AppConstEnv\n | AppConstMeth\n | AppVarConst\n | AppEnvConst\n | AppMethConst\n | MethAppConst\n | MethAppVar\n | MethAppEnv\n | MethAppMeth\n | SendConst\n | SendVar\n | SendEnv\n | SendMeth\n | Closure of closure\n\nlet method_impl table i arr =\n let next () = incr i; magic arr.(!i) in\n match next() with\n GetConst -> let x : t = next() in get_const x\n | GetVar -> let n = next() in get_var n\n | GetEnv -> let e = next() in let n = next() in get_env e n\n | GetMeth -> let n = next() in get_meth n\n | SetVar -> let n = next() in set_var n\n | AppConst -> let f = next() in let x = next() in app_const f x\n | AppVar -> let f = next() in let n = next () in app_var f n\n | AppEnv ->\n let f = next() in let e = next() in let n = next() in\n app_env f e n\n | AppMeth -> let f = next() in let n = next () in app_meth f n\n | AppConstConst ->\n let f = next() in let x = next() in let y = next() in\n app_const_const f x y\n | AppConstVar ->\n let f = next() in let x = next() in let n = next() in\n app_const_var f x n\n | AppConstEnv ->\n let f = next() in let x = next() in let e = next () in let n = next() in\n app_const_env f x e n\n | AppConstMeth ->\n let f = next() in let x = next() in let n = next() in\n app_const_meth f x n\n | AppVarConst ->\n let f = next() in let n = next() in let x = next() in\n app_var_const f n x\n | AppEnvConst ->\n let f = next() in let e = next () in let n = next() in let x = next() in\n app_env_const f e n x\n | AppMethConst ->\n let f = next() in let n = next() in let x = next() in\n app_meth_const f n x\n | MethAppConst ->\n let n = next() in let x = next() in meth_app_const n x\n | MethAppVar ->\n let n = next() in let m = next() in meth_app_var n m\n | MethAppEnv ->\n let n = next() in let e = next() in let m = next() in\n meth_app_env n e m\n | MethAppMeth ->\n let n = next() in let m = next() in meth_app_meth n m\n | SendConst ->\n let m = next() in let x = next() in send_const m x (new_cache table)\n | SendVar ->\n let m = next() in let n = next () in send_var m n (new_cache table)\n | SendEnv ->\n let m = next() in let e = next() in let n = next() in\n send_env m e n (new_cache table)\n | SendMeth ->\n let m = next() in let n = next () in send_meth m n (new_cache table)\n | Closure _ as clo -> magic clo\n\nlet set_methods table methods =\n let len = Array.length methods in let i = ref 0 in\n while !i < len do\n let label = methods.(!i) in let clo = method_impl table i methods in\n set_method table label clo;\n incr i\n done\n\n(**** Statistics ****)\n\ntype stats =\n { classes: int; methods: int; inst_vars: int; }\n\nlet stats () =\n { classes = !table_count;\n methods = !method_count; inst_vars = !inst_var_count; }\n","open Import\nopen Ast_builder.Default\n\n(* [do_insert_unused_warning_attribute] -- If true, generated code\n contains compiler attribute to disable unused warnings, instead of\n inserting [let _ = ... ]. *)\nlet do_insert_unused_warning_attribute = ref false\nlet keep_w32_impl = ref false\nlet keep_w32_intf = ref false\n\nlet () =\n let keep_w32_spec =\n Caml.Arg.Symbol\n ( [ \"impl\"; \"intf\"; \"both\" ],\n function\n | \"impl\" -> keep_w32_impl := true\n | \"intf\" -> keep_w32_intf := true\n | \"both\" ->\n keep_w32_impl := true;\n keep_w32_intf := true\n | _ -> assert false )\n in\n let conv_w32_spec =\n Caml.Arg.Symbol\n ( [ \"code\"; \"attribute\" ],\n function\n | \"code\" -> do_insert_unused_warning_attribute := false\n | \"attribute\" -> do_insert_unused_warning_attribute := true\n | _ -> assert false )\n in\n Driver.add_arg \"-deriving-keep-w32\" keep_w32_spec\n ~doc:\" Do not try to disable warning 32 for the generated code\";\n Driver.add_arg \"-deriving-disable-w32-method\" conv_w32_spec\n ~doc:\" How to disable warning 32 for the generated code\";\n Driver.add_arg \"-type-conv-keep-w32\" keep_w32_spec\n ~doc:\" Deprecated, use -deriving-keep-w32\";\n Driver.add_arg \"-type-conv-w32\" conv_w32_spec\n ~doc:\" Deprecated, use -deriving-disable-w32-method\"\n\nlet keep_w32_impl () = !keep_w32_impl || Driver.pretty ()\nlet keep_w32_intf () = !keep_w32_intf || Driver.pretty ()\nlet keep_w60_impl = ref false\nlet keep_w60_intf = ref false\n\nlet () =\n let keep_w60_spec =\n Caml.Arg.Symbol\n ( [ \"impl\"; \"intf\"; \"both\" ],\n function\n | \"impl\" -> keep_w60_impl := true\n | \"intf\" -> keep_w60_intf := true\n | \"both\" ->\n keep_w60_impl := true;\n keep_w60_intf := true\n | _ -> assert false )\n in\n Driver.add_arg \"-deriving-keep-w60\" keep_w60_spec\n ~doc:\" Do not try to disable warning 60 for the generated code\"\n\nlet keep_w60_impl () = !keep_w60_impl || Driver.pretty ()\nlet keep_w60_intf () = !keep_w60_intf || Driver.pretty ()\n\nmodule Args = struct\n include (\n Ast_pattern :\n module type of struct\n include Ast_pattern\n end\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) Ast_pattern.t)\n\n type 'a param = {\n name : string;\n pattern : (expression, 'a) Ast_pattern.Packed.t;\n default : 'a;\n }\n\n let arg name pattern =\n {\n name;\n default = None;\n pattern = Ast_pattern.Packed.create pattern (fun x -> Some x);\n }\n\n let flag name =\n let pattern = pexp_ident (lident (string name)) in\n { name; default = false; pattern = Ast_pattern.Packed.create pattern true }\n\n type (_, _) t =\n | Nil : ('m, 'm) t\n | Cons : ('m1, 'a -> 'm2) t * 'a param -> ('m1, 'm2) t\n\n let empty = Nil\n let ( +> ) a b = Cons (a, b)\n\n let rec names : type a b. (a, b) t -> string list = function\n | Nil -> []\n | Cons (t, p) -> p.name :: names t\n\n module Instance = struct\n type (_, _) instance =\n | I_nil : ('m, 'm) instance\n | I_cons : ('m1, 'a -> 'm2) instance * 'a -> ('m1, 'm2) instance\n\n let rec create :\n type a b. (a, b) t -> (string * expression) list -> (a, b) instance =\n fun spec args ->\n match spec with\n | Nil -> I_nil\n | Cons (t, p) ->\n let value =\n match List.assoc_opt p.name args with\n | None -> p.default\n | Some expr -> Ast_pattern.Packed.parse p.pattern expr.pexp_loc expr\n in\n I_cons (create t args, value)\n\n let rec apply : type a b. (a, b) instance -> a -> b =\n fun t f -> match t with I_nil -> f | I_cons (t, x) -> apply t f x\n end\n\n let apply t args f = Instance.apply (Instance.create t args) f\nend\n\n(* +-----------------------------------------------------------------+\n | Generators |\n +-----------------------------------------------------------------+ *)\n\ntype t = string\n\nlet ignore (_ : t) = ()\n\ntype parsed_args =\n | Args of (string * expression) list\n | Unknown_syntax of Location.t * string\n\nmodule Generator = struct\n type deriver = t\n\n type ('a, 'b) t =\n | T : {\n spec : ('c, 'a) Args.t;\n gen : ctxt:Expansion_context.Deriver.t -> 'b -> 'c;\n arg_names : String.Set.t;\n attributes : Attribute.packed list;\n deps : deriver list;\n }\n -> ('a, 'b) t\n\n let deps (T t) = t.deps\n\n module V2 = struct\n let make ?(attributes = []) ?(deps = []) spec gen =\n let arg_names = String.Set.of_list (Args.names spec) in\n T { spec; gen; arg_names; attributes; deps }\n\n let make_noarg ?attributes ?deps gen = make ?attributes ?deps Args.empty gen\n end\n\n let make ?attributes ?deps spec gen =\n V2.make ?attributes ?deps spec\n (Expansion_context.Deriver.with_loc_and_path gen)\n\n let make_noarg ?attributes ?deps gen = make ?attributes ?deps Args.empty gen\n\n let merge_accepted_args l =\n let rec loop acc = function\n | [] -> acc\n | T t :: rest -> loop (String.Set.union acc t.arg_names) rest\n in\n loop String.Set.empty l\n\n let check_arguments name generators (args : (string * expression) list) =\n List.iter args ~f:(fun (label, e) ->\n if String.is_empty label then\n Location.raise_errorf ~loc:e.pexp_loc\n \"Ppxlib.Deriving: generator arguments must be labelled\");\n Option.iter\n (List.find_a_dup args ~compare:(fun (a, _) (b, _) -> String.compare a b))\n ~f:(fun (label, e) ->\n Location.raise_errorf ~loc:e.pexp_loc\n \"Ppxlib.Deriving: argument labelled '%s' appears more than once\" label);\n let accepted_args = merge_accepted_args generators in\n List.iter args ~f:(fun (label, e) ->\n if not (String.Set.mem label accepted_args) then\n let spellcheck_msg =\n match\n Spellcheck.spellcheck (String.Set.elements accepted_args) label\n with\n | None -> \"\"\n | Some s -> \".\\n\" ^ s\n in\n Location.raise_errorf ~loc:e.pexp_loc\n \"Ppxlib.Deriving: generator '%s' doesn't accept argument '%s'%s\"\n name label spellcheck_msg)\n\n let apply (T t) ~name:_ ~ctxt x args = Args.apply t.spec args (t.gen ~ctxt x)\n\n let apply_all ~ctxt entry (name, generators, args) =\n check_arguments name.txt generators args;\n List.concat_map generators ~f:(fun t ->\n apply t ~name:name.txt ~ctxt entry args)\n\n let apply_all ~ctxt entry generators =\n List.concat_map generators ~f:(apply_all ~ctxt entry)\nend\n\nmodule Deriver = struct\n module Actual_deriver = struct\n type t = {\n name : string;\n str_type_decl :\n (structure, rec_flag * type_declaration list) Generator.t option;\n str_type_ext : (structure, type_extension) Generator.t option;\n str_exception : (structure, type_exception) Generator.t option;\n str_module_type_decl :\n (structure, module_type_declaration) Generator.t option;\n sig_type_decl :\n (signature, rec_flag * type_declaration list) Generator.t option;\n sig_type_ext : (signature, type_extension) Generator.t option;\n sig_exception : (signature, type_exception) Generator.t option;\n sig_module_type_decl :\n (signature, module_type_declaration) Generator.t option;\n extension :\n (loc:Location.t -> path:string -> core_type -> expression) option;\n }\n end\n\n module Alias = struct\n type t = {\n str_type_decl : string list;\n str_type_ext : string list;\n str_exception : string list;\n str_module_type_decl : string list;\n sig_type_decl : string list;\n sig_type_ext : string list;\n sig_exception : string list;\n sig_module_type_decl : string list;\n }\n end\n\n module Field = struct\n type kind = Str | Sig\n\n type ('a, 'b) t = {\n name : string;\n kind : kind;\n get : Actual_deriver.t -> ('a, 'b) Generator.t option;\n get_set : Alias.t -> string list;\n }\n\n let str_type_decl =\n {\n kind = Str;\n name = \"type\";\n get = (fun t -> t.str_type_decl);\n get_set = (fun t -> t.str_type_decl);\n }\n\n let str_type_ext =\n {\n kind = Str;\n name = \"type extension\";\n get = (fun t -> t.str_type_ext);\n get_set = (fun t -> t.str_type_ext);\n }\n\n let str_exception =\n {\n kind = Str;\n name = \"exception\";\n get = (fun t -> t.str_exception);\n get_set = (fun t -> t.str_exception);\n }\n\n let str_module_type_decl =\n {\n kind = Str;\n name = \"module type\";\n get = (fun t -> t.str_module_type_decl);\n get_set = (fun t -> t.str_module_type_decl);\n }\n\n let sig_type_decl =\n {\n kind = Sig;\n name = \"signature type\";\n get = (fun t -> t.sig_type_decl);\n get_set = (fun t -> t.sig_type_decl);\n }\n\n let sig_type_ext =\n {\n kind = Sig;\n name = \"signature type extension\";\n get = (fun t -> t.sig_type_ext);\n get_set = (fun t -> t.sig_type_ext);\n }\n\n let sig_exception =\n {\n kind = Sig;\n name = \"signature exception\";\n get = (fun t -> t.sig_exception);\n get_set = (fun t -> t.sig_exception);\n }\n\n let sig_module_type_decl =\n {\n kind = Sig;\n name = \"signature module type\";\n get = (fun t -> t.sig_module_type_decl);\n get_set = (fun t -> t.sig_module_type_decl);\n }\n end\n\n type t = Actual_deriver of Actual_deriver.t | Alias of Alias.t\n type Ppx_derivers.deriver += T of t\n\n let derivers () =\n List.filter_map (Ppx_derivers.derivers ()) ~f:(function\n | name, T t -> Some (name, t)\n | _ -> None)\n\n exception Not_supported of string\n\n let resolve_actual_derivers (field : (_, _) Field.t) name =\n let rec loop name collected =\n if\n List.exists collected ~f:(fun (d : Actual_deriver.t) ->\n String.equal d.name name)\n then collected\n else\n match Ppx_derivers.lookup name with\n | Some (T (Actual_deriver drv)) -> drv :: collected\n | Some (T (Alias alias)) ->\n let set = field.get_set alias in\n List.fold_right set ~init:collected ~f:loop\n | _ -> raise (Not_supported name)\n in\n List.rev (loop name [])\n\n let resolve_internal (field : (_, _) Field.t) name =\n List.map (resolve_actual_derivers field name) ~f:(fun drv ->\n match field.get drv with\n | None -> raise (Not_supported name)\n | Some g -> (drv.name, g))\n\n let supported_for field =\n List.fold_left (derivers ()) ~init:String.Set.empty ~f:(fun acc (name, _) ->\n match resolve_internal field name with\n | _ -> String.Set.add name acc\n | exception Not_supported _ -> acc)\n |> String.Set.elements\n\n let not_supported (field : (_, _) Field.t) ?(spellcheck = true) name =\n let spellcheck_msg =\n if spellcheck then\n match Spellcheck.spellcheck (supported_for field) name.txt with\n | None -> \"\"\n | Some s -> \".\\n\" ^ s\n else \"\"\n in\n Location.raise_errorf ~loc:name.loc\n \"Ppxlib.Deriving: '%s' is not a supported %s deriving generator%s\"\n name.txt field.name spellcheck_msg\n\n let resolve field name =\n try resolve_internal field name.txt\n with Not_supported name' ->\n not_supported field ~spellcheck:(String.equal name.txt name') name\n\n let resolve_all field derivers =\n let derivers_and_args =\n List.filter_map derivers ~f:(fun (name, args) ->\n match Ppx_derivers.lookup name.txt with\n | None -> not_supported field name\n | Some (T _) ->\n (* It's one of ours, parse the arguments now. We can't do it before since\n ppx_deriving uses a different syntax for arguments. *)\n Some\n ( name,\n match args with\n | Args l -> l\n | Unknown_syntax (loc, msg) ->\n Location.raise_errorf ~loc \"Ppxlib.Deriving: %s\" msg )\n | Some _ ->\n (* It's not one of ours, ignore it. *)\n None)\n in\n (* Set of actual deriver names *)\n let seen = Hashtbl.create 16 in\n List.map derivers_and_args ~f:(fun (name, args) ->\n let named_generators = resolve field name in\n List.iter named_generators ~f:(fun (actual_deriver_name, gen) ->\n if\n Options.fail_on_duplicate_derivers\n && Hashtbl.mem seen actual_deriver_name\n then\n Location.raise_errorf ~loc:name.loc \"Deriver %s appears twice\"\n actual_deriver_name;\n List.iter (Generator.deps gen) ~f:(fun dep ->\n List.iter (resolve_actual_derivers field dep) ~f:(fun drv ->\n let dep_name = drv.name in\n if not (Hashtbl.mem seen dep_name) then\n Location.raise_errorf ~loc:name.loc\n \"Deriver %s is needed for %s, you need to add it \\\n before in the list\"\n dep_name name.txt));\n Hashtbl.set seen ~key:actual_deriver_name ~data:());\n (name, List.map named_generators ~f:snd, args))\n\n let add ?str_type_decl ?str_type_ext ?str_exception ?str_module_type_decl\n ?sig_type_decl ?sig_type_ext ?sig_exception ?sig_module_type_decl\n ?extension name =\n let actual_deriver : Actual_deriver.t =\n {\n name;\n str_type_decl;\n str_type_ext;\n str_exception;\n str_module_type_decl;\n sig_type_decl;\n sig_type_ext;\n sig_exception;\n sig_module_type_decl;\n extension;\n }\n in\n Ppx_derivers.register name (T (Actual_deriver actual_deriver));\n (match extension with\n | None -> ()\n | Some f ->\n let extension =\n Extension.declare name Expression Ast_pattern.(ptyp __) f\n in\n Driver.register_transformation\n (\"Ppxlib.Deriving.\" ^ name)\n ~rules:[ Context_free.Rule.extension extension ]);\n name\n\n let add_alias name ?str_type_decl ?str_type_ext ?str_exception\n ?str_module_type_decl ?sig_type_decl ?sig_type_ext ?sig_exception\n ?sig_module_type_decl set =\n let alias : Alias.t =\n let get = function None -> set | Some set -> set in\n {\n str_type_decl = get str_type_decl;\n str_type_ext = get str_type_ext;\n str_exception = get str_exception;\n str_module_type_decl = get str_module_type_decl;\n sig_type_decl = get sig_type_decl;\n sig_type_ext = get sig_type_ext;\n sig_exception = get sig_exception;\n sig_module_type_decl = get sig_module_type_decl;\n }\n in\n Ppx_derivers.register name (T (Alias alias));\n name\nend\n\nlet add = Deriver.add\nlet add_alias = Deriver.add_alias\n\n(* +-----------------------------------------------------------------+\n | [@@deriving ] parsing |\n +-----------------------------------------------------------------+ *)\n\nlet invalid_with ~loc =\n Location.raise_errorf ~loc \"invalid [@@deriving ] attribute syntax\"\n\nlet generator_name_of_id loc id =\n match Longident.flatten_exn id with\n | l -> { loc; txt = String.concat ~sep:\".\" l }\n | exception _ -> invalid_with ~loc\n\nexception Unknown_syntax of Location.t * string\n\nlet parse_arguments l =\n try\n Args\n (match l with\n | [ (Nolabel, e) ] -> (\n match e.pexp_desc with\n | Pexp_record (fields, None) ->\n List.map fields ~f:(fun (id, expr) ->\n let name =\n match id.txt with\n | Lident s -> s\n | _ ->\n raise_notrace\n (Unknown_syntax (id.loc, \"simple identifier expected\"))\n in\n (name, expr))\n | _ ->\n raise_notrace\n (Unknown_syntax\n ( e.pexp_loc,\n \"non-optional labelled argument or record expected\" )))\n | l ->\n List.map l ~f:(fun (label, expr) ->\n match label with\n | Labelled s -> (s, expr)\n | _ ->\n raise_notrace\n (Unknown_syntax\n (expr.pexp_loc, \"non-optional labelled argument expected\"))))\n with Unknown_syntax (loc, msg) -> Unknown_syntax (loc, msg)\n\nlet mk_deriving_attr context ~prefix ~suffix =\n Attribute.declare\n (prefix ^ \"deriving\" ^ suffix)\n context\n Ast_pattern.(\n let generator_name () =\n map' (pexp_ident __) ~f:(fun loc f id ->\n f (generator_name_of_id loc id))\n in\n let generator () =\n map (generator_name ()) ~f:(fun f x -> f (x, Args []))\n ||| pack2\n (pexp_apply (generator_name ())\n (map1 (many __) ~f:parse_arguments))\n in\n let generators =\n pexp_tuple (many (generator ()))\n ||| map (generator ()) ~f:(fun f x -> f [ x ])\n in\n pstr (pstr_eval generators nil ^:: nil))\n (fun x -> x)\n\n(* +-----------------------------------------------------------------+\n | Unused warning stuff + locations check silencing |\n +-----------------------------------------------------------------+ *)\n\nlet disable_warnings_attribute warnings =\n let loc = Location.none in\n let string =\n List.sort warnings ~cmp:Int.compare\n |> List.map ~f:(fun warning -> \"-\" ^ Int.to_string warning)\n |> String.concat ~sep:\"\"\n in\n {\n attr_name = { txt = \"ocaml.warning\"; loc };\n attr_payload = PStr [ pstr_eval ~loc (estring ~loc string) [] ];\n attr_loc = loc;\n }\n\nlet inline_doc_attr =\n let loc = Location.none in\n {\n attr_name = { txt = \"ocaml.doc\"; loc };\n attr_payload = PStr [ pstr_eval ~loc (estring ~loc \"@inline\") [] ];\n attr_loc = loc;\n }\n\nlet wrap_str ~loc ~hide st =\n let include_infos = include_infos ~loc (pmod_structure ~loc st) in\n let pincl_attributes =\n if hide then [ inline_doc_attr; Merlin_helpers.hide_attribute ]\n else [ inline_doc_attr ]\n in\n [ pstr_include ~loc { include_infos with pincl_attributes } ]\n\nlet wrap_str ~loc ~hide st =\n let loc = { loc with loc_ghost = true } in\n let warnings, st =\n if keep_w32_impl () then ([], st)\n else if not !do_insert_unused_warning_attribute then\n ([], Ignore_unused_warning.add_dummy_user_for_values#structure st)\n else ([ 32 ], st)\n in\n let warnings, st =\n if\n keep_w60_impl ()\n || not (Ignore_unused_warning.binds_module_names#structure st false)\n then (warnings, st)\n else (60 :: warnings, st)\n in\n let wrap, st =\n if List.is_empty warnings then (hide, st)\n else (true, pstr_attribute ~loc (disable_warnings_attribute warnings) :: st)\n in\n if wrap then wrap_str ~loc ~hide st else st\n\nlet wrap_sig ~loc ~hide st =\n let include_infos = include_infos ~loc (pmty_signature ~loc st) in\n let pincl_attributes =\n if hide then [ inline_doc_attr; Merlin_helpers.hide_attribute ]\n else [ inline_doc_attr ]\n in\n [ psig_include ~loc { include_infos with pincl_attributes } ]\n\nlet wrap_sig ~loc ~hide sg =\n let loc = { loc with loc_ghost = true } in\n let warnings = if keep_w32_intf () then [] else [ 32 ] in\n let warnings =\n if\n keep_w60_intf ()\n || not (Ignore_unused_warning.binds_module_names#signature sg false)\n then warnings\n else 60 :: warnings\n in\n let wrap, sg =\n if List.is_empty warnings then (hide, sg)\n else (true, psig_attribute ~loc (disable_warnings_attribute warnings) :: sg)\n in\n if wrap then wrap_sig ~loc ~hide sg else sg\n\n(* +-----------------------------------------------------------------+\n | Remove attributes used by syntax extensions |\n +-----------------------------------------------------------------+ *)\n(*\nlet remove generators =\n let attributes =\n List.concat_map generators ~f:(fun (_, actual_generators, _) ->\n List.concat_map actual_generators ~f:(fun (Generator.T g) -> g.attributes))\n in\n object\n inherit Ast_traverse.map\n\n (* Don't recurse through attributes and extensions *)\n method! attribute x = x\n method! extension x = x\n\n method! label_declaration ld =\n Attribute.remove_seen Attribute.Context.label_declaration attributes ld\n\n method! constructor_declaration cd =\n Attribute.remove_seen Attribute.Context.constructor_declaration attributes cd\n end\n*)\n(* +-----------------------------------------------------------------+\n | Main expansion |\n +-----------------------------------------------------------------+ *)\n\nlet types_used_by_deriving (tds : type_declaration list) : structure_item list =\n if keep_w32_impl () then []\n else\n List.map tds ~f:(fun td ->\n let typ = Common.core_type_of_type_declaration td in\n let loc = td.ptype_loc in\n pstr_value ~loc Nonrecursive\n [\n value_binding ~loc ~pat:(ppat_any ~loc)\n ~expr:\n (pexp_fun ~loc Nolabel None\n (ppat_constraint ~loc (ppat_any ~loc) typ)\n (eunit ~loc));\n ])\n\nlet merge_generators field l =\n List.filter_map l ~f:(fun x -> x) |> List.concat |> Deriver.resolve_all field\n\nlet expand_str_type_decls ~ctxt rec_flag tds values =\n let generators = merge_generators Deriver.Field.str_type_decl values in\n (* TODO: instead of disabling the unused warning for types themselves, we\n should add a tag [@@unused]. *)\n let generated =\n types_used_by_deriving tds\n @ Generator.apply_all ~ctxt (rec_flag, tds) generators\n in\n wrap_str\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_sig_type_decls ~ctxt rec_flag tds values =\n let generators = merge_generators Deriver.Field.sig_type_decl values in\n let generated = Generator.apply_all ~ctxt (rec_flag, tds) generators in\n wrap_sig\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_str_module_type_decl ~ctxt mtd generators =\n let generators =\n Deriver.resolve_all Deriver.Field.str_module_type_decl generators\n in\n let generated = Generator.apply_all ~ctxt mtd generators in\n wrap_str\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_sig_module_type_decl ~ctxt mtd generators =\n let generators =\n Deriver.resolve_all Deriver.Field.sig_module_type_decl generators\n in\n let generated = Generator.apply_all ~ctxt mtd generators in\n wrap_sig\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_str_exception ~ctxt ec generators =\n let generators = Deriver.resolve_all Deriver.Field.str_exception generators in\n let generated = Generator.apply_all ~ctxt ec generators in\n wrap_str\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_sig_exception ~ctxt ec generators =\n let generators = Deriver.resolve_all Deriver.Field.sig_exception generators in\n let generated = Generator.apply_all ~ctxt ec generators in\n wrap_sig\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_str_type_ext ~ctxt te generators =\n let generators = Deriver.resolve_all Deriver.Field.str_type_ext generators in\n let generated = Generator.apply_all ~ctxt te generators in\n wrap_str\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_sig_type_ext ~ctxt te generators =\n let generators = Deriver.resolve_all Deriver.Field.sig_type_ext generators in\n let generated = Generator.apply_all ~ctxt te generators in\n wrap_sig\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet rules ~typ ~expand_sig ~expand_str ~rule_str ~rule_sig ~rule_str_expect\n ~rule_sig_expect =\n let prefix = \"ppxlib.\" in\n let deriving_attr = mk_deriving_attr ~suffix:\"\" ~prefix typ in\n let deriving_attr_expect = mk_deriving_attr ~suffix:\"_inline\" ~prefix typ in\n [\n rule_sig deriving_attr expand_sig;\n rule_str deriving_attr expand_str;\n rule_str_expect deriving_attr_expect expand_str;\n rule_sig_expect deriving_attr_expect expand_sig;\n ]\n\nlet rules_type_decl =\n rules ~typ:Type_declaration ~expand_str:expand_str_type_decls\n ~expand_sig:expand_sig_type_decls\n ~rule_str:Context_free.Rule.attr_str_type_decl\n ~rule_sig:Context_free.Rule.attr_sig_type_decl\n ~rule_str_expect:Context_free.Rule.attr_str_type_decl_expect\n ~rule_sig_expect:Context_free.Rule.attr_sig_type_decl_expect\n\nlet rules_type_ext =\n rules ~typ:Type_extension ~expand_str:expand_str_type_ext\n ~expand_sig:expand_sig_type_ext\n ~rule_str:Context_free.Rule.attr_str_type_ext\n ~rule_sig:Context_free.Rule.attr_sig_type_ext\n ~rule_str_expect:Context_free.Rule.attr_str_type_ext_expect\n ~rule_sig_expect:Context_free.Rule.attr_sig_type_ext_expect\n\nlet rules_exception =\n rules ~typ:Type_exception ~expand_str:expand_str_exception\n ~expand_sig:expand_sig_exception\n ~rule_str:Context_free.Rule.attr_str_exception\n ~rule_sig:Context_free.Rule.attr_sig_exception\n ~rule_str_expect:Context_free.Rule.attr_str_exception_expect\n ~rule_sig_expect:Context_free.Rule.attr_sig_exception_expect\n\nlet rules_module_type_decl =\n rules ~typ:Module_type_declaration ~expand_str:expand_str_module_type_decl\n ~expand_sig:expand_sig_module_type_decl\n ~rule_str:Context_free.Rule.attr_str_module_type_decl\n ~rule_sig:Context_free.Rule.attr_sig_module_type_decl\n ~rule_str_expect:Context_free.Rule.attr_str_module_type_decl_expect\n ~rule_sig_expect:Context_free.Rule.attr_sig_module_type_decl_expect\n\nlet () =\n let rules =\n [ rules_type_decl; rules_type_ext; rules_exception; rules_module_type_decl ]\n |> List.concat\n in\n Driver.register_transformation \"deriving\" ~aliases:[ \"type_conv\" ] ~rules\n","open! Import\n\ntype 'a or_raise =\n | Ok of 'a\n | Error of { fail : 'a. loc:location -> 'a }\n\ntype t = (string, expression or_raise, String.comparator_witness) Map.t\n\nlet empty = Map.empty (module String)\n\nlet lookup t ~loc ~tyvar =\n match Map.find t tyvar with\n | Some (Ok expr) -> expr\n | Some (Error { fail }) -> fail ~loc\n | None -> invalid ~loc \"unbound type variable: '%s\" tyvar\n;;\n\nlet of_alist ~loc alist =\n match Map.of_alist (module String) alist with\n | `Ok t -> t\n | `Duplicate_key name -> invalid ~loc \"duplicate type parameter: '%s\" name\n;;\n\nlet create ~loc ~prefix param_list =\n let pat_list, alist =\n List.map param_list ~f:(fun ((core_type, _) as param) ->\n let loc = core_type.ptyp_loc in\n let name = get_type_param_name param in\n let pat, expr = gensym prefix loc in\n pat, (name.txt, Ok expr))\n |> List.unzip\n in\n let t = of_alist ~loc alist in\n pat_list, t\n;;\n\nlet variance_error ~loc ~tyvar ~actual ~expect =\n invalid\n ~loc\n \"misuse of type variable '%s: would confuse %s with %s in generated code; could be \\\n due to a missing or incorrect covariance/contravariance annotation\"\n tyvar\n actual\n expect\n;;\n\nlet create_with_variance ~loc ~covariant ~contravariant param_list =\n let pat_list, by_variance_list =\n List.map param_list ~f:(fun ((core_type, (variance, injectivity)) as param) ->\n let loc = core_type.ptyp_loc in\n let name = get_type_param_name param in\n match (variance, injectivity) with\n | ((NoVariance | Covariant), NoInjectivity) ->\n let pat, expr = gensym covariant loc in\n pat, `Covariant (name.txt, expr)\n | (Contravariant, NoInjectivity) ->\n let pat, expr = gensym contravariant loc in\n pat, `Contravariant (name.txt, expr)\n | (_, Injective) -> Location.raise_errorf ~loc \"Injective type parameters aren't supported.\")\n |> List.unzip\n in\n let covariant_t =\n List.map by_variance_list ~f:(function\n | `Covariant (tyvar, expr) -> tyvar, Ok expr\n | `Contravariant (tyvar, _) ->\n let fail ~loc =\n variance_error ~loc ~tyvar ~expect:covariant ~actual:contravariant\n in\n tyvar, Error { fail })\n |> of_alist ~loc\n in\n let contravariant_t =\n List.map by_variance_list ~f:(function\n | `Contravariant (tyvar, expr) -> tyvar, Ok expr\n | `Covariant (tyvar, _) ->\n let fail ~loc =\n variance_error ~loc ~tyvar ~expect:contravariant ~actual:covariant\n in\n tyvar, Error { fail })\n |> of_alist ~loc\n in\n pat_list, `Covariant covariant_t, `Contravariant contravariant_t\n;;\n","open Core_kernel\n\nmodule Chunked = struct\n (** The input for a random oracle, formed of full field elements and 'chunks'\n of fields that can be combined together into one or more field elements.\n\n The chunks are represented as [(field, length)], where\n [0 <= field < 2^length]. This allows us to efficiently combine values in\n a known range. For example,\n{[\n { field_elements= [||]; packeds= [|(x, 64); (y, 32); (z, 16)|] }\n]}\n results in the chunks being combined as [x * 2^(32+16) + y * 2^(64) + z].\n When the chunks do not fit within a single field element, they are\n greedily concatenated to form field elements, from left to right.\n This packing is performed by the [pack_to_fields] helper function.\n *)\n type 'field t =\n { field_elements : 'field array; packeds : ('field * int) array }\n [@@deriving sexp, compare]\n\n let append (t1 : _ t) (t2 : _ t) =\n { field_elements = Array.append t1.field_elements t2.field_elements\n ; packeds = Array.append t1.packeds t2.packeds\n }\n\n let field_elements (a : 'f array) : 'f t =\n { field_elements = a; packeds = [||] }\n\n let field x : _ t = field_elements [| x |]\n\n (** An input [[|(x_1, l_1); (x_2, l_2); ...|]] includes the values\n [[|x_1; x_2; ...|]] in the input, assuming that `0 <= x_1 < 2^l_1`,\n `0 <= x_2 < 2^l_2`, etc. so that multiple [x_i]s can be combined into a\n single field element when the sum of their [l_i]s are less than the size\n of the field modulus (in bits).\n *)\n let packeds a = { field_elements = [||]; packeds = a }\n\n (** [packed x = packeds [| x |]] *)\n let packed xn : _ t = packeds [| xn |]\n\n module type Field_intf = sig\n type t\n\n val size_in_bits : int\n\n val zero : t\n\n val ( + ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n end\n\n (** Convert the input into a series of field elements, by concatenating\n any chunks of input that fit into a single field element.\n The concatenation is greedy, operating from left to right.\n *)\n let pack_to_fields (type t) (module F : Field_intf with type t = t)\n ~(pow2 : int -> t) { field_elements; packeds } =\n let shift_left acc n = F.( * ) acc (pow2 n) in\n let open F in\n let packed_bits =\n let xs, acc, acc_n =\n Array.fold packeds ~init:([], zero, 0)\n ~f:(fun (xs, acc, acc_n) (x, n) ->\n let n' = Int.(n + acc_n) in\n if Int.(n' < size_in_bits) then (xs, shift_left acc n + x, n')\n else (acc :: xs, x, n) )\n in\n (* if acc_n = 0, packeds was empty (or acc holds 0 bits) and we don't want to append 0 *)\n let xs = if acc_n > 0 then acc :: xs else xs in\n Array.of_list_rev xs\n in\n Array.append field_elements packed_bits\nend\n\nmodule Legacy = struct\n type ('field, 'bool) t =\n { field_elements : 'field array; bitstrings : 'bool list array }\n [@@deriving sexp, compare]\n\n let append t1 t2 =\n { field_elements = Array.append t1.field_elements t2.field_elements\n ; bitstrings = Array.append t1.bitstrings t2.bitstrings\n }\n\n let field_elements x = { field_elements = x; bitstrings = [||] }\n\n let field x = { field_elements = [| x |]; bitstrings = [||] }\n\n let bitstring x = { field_elements = [||]; bitstrings = [| x |] }\n\n let bitstrings x = { field_elements = [||]; bitstrings = x }\n\n let pack_bits ~max_size ~pack { field_elements = _; bitstrings } =\n let rec pack_full_fields rev_fields bits length =\n if length >= max_size then\n let field_bits, bits = List.split_n bits max_size in\n pack_full_fields (pack field_bits :: rev_fields) bits (length - max_size)\n else (rev_fields, bits, length)\n in\n let packed_field_elements, remaining_bits, remaining_length =\n Array.fold bitstrings ~init:([], [], 0)\n ~f:(fun (acc, bits, n) bitstring ->\n let n = n + List.length bitstring in\n let bits = bits @ bitstring in\n let acc, bits, n = pack_full_fields acc bits n in\n (acc, bits, n) )\n in\n if remaining_length = 0 then packed_field_elements\n else pack remaining_bits :: packed_field_elements\n\n let pack_to_fields ~size_in_bits ~pack { field_elements; bitstrings } =\n let max_size = size_in_bits - 1 in\n let packed_bits =\n pack_bits ~max_size ~pack { field_elements; bitstrings }\n in\n Array.append field_elements (Array.of_list_rev packed_bits)\n\n let to_bits ~unpack { field_elements; bitstrings } =\n let field_bits = Array.map ~f:unpack field_elements in\n List.concat @@ Array.to_list @@ Array.append field_bits bitstrings\n\n module Coding = struct\n (** See https://github.com/CodaProtocol/coda/blob/develop/rfcs/0038-rosetta-construction-api.md for details on schema *)\n\n (** Serialize a random oracle input with 32byte fields into bytes according to the RFC0038 specification *)\n let serialize ~string_of_field ~to_bool ~of_bool t =\n let len_to_string x =\n String.of_char_list\n Char.\n [ of_int_exn @@ ((x lsr 24) land 0xff)\n ; of_int_exn @@ ((x lsr 16) land 0xff)\n ; of_int_exn @@ ((x lsr 8) land 0xff)\n ; of_int_exn @@ (x land 0xff)\n ]\n in\n let len1 = len_to_string @@ Array.length t.field_elements in\n let fields =\n (* We only support 32byte fields *)\n let () =\n if Array.length t.field_elements > 0 then\n assert (String.length (string_of_field t.field_elements.(0)) = 32)\n else ()\n in\n Array.map t.field_elements ~f:string_of_field |> String.concat_array\n in\n let len2 =\n len_to_string\n @@ Array.sum (module Int) t.bitstrings ~f:(fun x -> List.length x)\n in\n let packed =\n pack_bits t ~max_size:8 ~pack:(fun bs ->\n let rec go i acc = function\n | [] ->\n acc\n | b :: bs ->\n go (i + 1) ((acc * 2) + if to_bool b then 1 else 0) bs\n in\n let pad =\n List.init (8 - List.length bs) ~f:(Fn.const (of_bool false))\n in\n let combined = bs @ pad in\n assert (List.length combined = 8) ;\n go 0 0 combined )\n |> List.map ~f:Char.of_int_exn\n |> List.rev |> String.of_char_list\n in\n len1 ^ fields ^ len2 ^ packed\n\n module Parser = struct\n (* TODO: Before using this too much; use a solid parser library instead or beef this one up with more debugging info *)\n\n (* The parser is a function over this monad-fail *)\n module M = Result\n\n module T = struct\n type ('a, 'e) t = char list -> ('a * char list, 'e) M.t\n\n let return a cs = M.return (a, cs)\n\n let bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t =\n fun t ~f cs ->\n let open M.Let_syntax in\n let%bind a, rest = t cs in\n f a rest\n\n let map = `Define_using_bind\n end\n\n include Monad.Make2 (T)\n\n let run p cs =\n p cs\n |> M.bind ~f:(fun (a, cs') ->\n match cs' with [] -> M.return a | _ -> M.fail `Expected_eof )\n\n let fail why _ = M.fail why\n\n let char c = function\n | c' :: cs when Char.equal c c' ->\n M.return (c', cs)\n | c' :: _ ->\n M.fail (`Unexpected_char c')\n | [] ->\n M.fail `Unexpected_eof\n\n let u8 = function\n | c :: cs ->\n M.return (c, cs)\n | [] ->\n M.fail `Unexpected_eof\n\n let u32 =\n let open Let_syntax in\n let open Char in\n let%map a = u8 and b = u8 and c = u8 and d = u8 in\n (to_int a lsl 24)\n lor (to_int b lsl 16)\n lor (to_int c lsl 8)\n lor to_int d\n\n let eof = function [] -> M.return ((), []) | _ -> M.fail `Expected_eof\n\n let take n cs =\n if List.length cs < n then M.fail `Unexpected_eof\n else M.return (List.split_n cs n)\n\n (** p zero or more times, never fails *)\n let many p =\n (fun cs ->\n let rec go xs acc =\n match p xs with\n | Ok (a, xs) ->\n go xs (a :: acc)\n | Error _ ->\n (acc, xs)\n in\n M.return @@ go cs [] )\n |> map ~f:List.rev\n\n let%test_unit \"many\" =\n [%test_eq: (char list, [ `Expected_eof ]) Result.t]\n (run (many u8) [ 'a'; 'b'; 'c' ])\n (Result.return [ 'a'; 'b'; 'c' ])\n\n (** p exactly n times *)\n let exactly n p =\n (fun cs ->\n let rec go xs acc = function\n | 0 ->\n M.return (acc, xs)\n | i ->\n let open M.Let_syntax in\n let%bind a, xs = p xs in\n go xs (a :: acc) (i - 1)\n in\n go cs [] n )\n |> map ~f:List.rev\n\n let%test_unit \"exactly\" =\n [%test_eq:\n (char list * char list, [ `Expected_eof | `Unexpected_eof ]) Result.t]\n ((exactly 3 u8) [ 'a'; 'b'; 'c'; 'd' ])\n (Result.return ([ 'a'; 'b'; 'c' ], [ 'd' ]))\n\n let return_res r cs = r |> Result.map ~f:(fun x -> (x, cs))\n end\n\n let bits_of_byte ~of_bool b =\n let b = Char.to_int b in\n let f x =\n of_bool\n ( match x with\n | 0 ->\n false\n | 1 ->\n true\n | _ ->\n failwith \"Unexpected boolean integer\" )\n in\n [ (b land (0x1 lsl 7)) lsr 7\n ; (b land (0x1 lsl 6)) lsr 6\n ; (b land (0x1 lsl 5)) lsr 5\n ; (b land (0x1 lsl 4)) lsr 4\n ; (b land (0x1 lsl 3)) lsr 3\n ; (b land (0x1 lsl 2)) lsr 2\n ; (b land (0x1 lsl 1)) lsr 1\n ; b land 0x1\n ]\n |> List.map ~f\n\n (** Deserialize bytes into a random oracle input with 32byte fields according to the RFC0038 specification *)\n let deserialize ~field_of_string ~of_bool s =\n let field =\n let open Parser.Let_syntax in\n let%bind u8x32 = Parser.take 32 in\n let s = String.of_char_list u8x32 in\n Parser.return_res (field_of_string s)\n in\n let parser =\n let open Parser.Let_syntax in\n let%bind len1 = Parser.u32 in\n let%bind fields = Parser.exactly len1 field in\n let%bind len2 = Parser.u32 in\n let%map bytes = Parser.(many u8) in\n let bits = List.concat_map ~f:(bits_of_byte ~of_bool) bytes in\n let bitstring = List.take bits len2 in\n { field_elements = Array.of_list fields; bitstrings = [| bitstring |] }\n in\n Parser.run parser s\n\n (** String of field as bits *)\n let string_of_field xs =\n List.chunks_of xs ~length:8\n |> List.map ~f:(fun xs ->\n let rec go i acc = function\n | [] ->\n acc\n | b :: bs ->\n go (i + 1) ((acc * 2) + if b then 1 else 0) bs\n in\n let pad = List.init (8 - List.length xs) ~f:(Fn.const false) in\n let combined = xs @ pad in\n assert (List.length combined = 8) ;\n go 0 0 combined )\n |> List.map ~f:Char.of_int_exn\n |> String.of_char_list\n\n (** Field of string as bits *)\n let field_of_string s ~size_in_bits =\n List.concat_map (String.to_list s) ~f:(bits_of_byte ~of_bool:Fn.id)\n |> Fn.flip List.take size_in_bits\n |> Result.return\n end\n\n (** Coding2 is an alternate binary coding setup where we pass two arrays of\n * field elements instead of a single structure to simplify manipulation\n * outside of the Mina construction API\n *\n * This is described as the second mechanism for coding Random_oracle_input in\n * RFC0038\n *\n*)\n module Coding2 = struct\n module Rendered = struct\n (* as bytes, you must hex this later *)\n type 'field t_ = { prefix : 'field array; suffix : 'field array }\n [@@deriving yojson]\n\n type t = string t_ [@@deriving yojson]\n\n let map ~f { prefix; suffix } =\n { prefix = Array.map ~f prefix; suffix = Array.map ~f suffix }\n end\n\n let string_of_field : bool list -> string = Coding.string_of_field\n\n let field_of_string = Coding.field_of_string\n\n let serialize' t ~pack =\n { Rendered.prefix = t.field_elements\n ; suffix = pack_bits ~max_size:254 ~pack t |> Array.of_list_rev\n }\n\n let serialize t ~string_of_field ~pack =\n let () =\n if Array.length t.field_elements > 0 then\n assert (String.length (string_of_field t.field_elements.(0)) = 32)\n else ()\n in\n serialize' t ~pack |> Rendered.map ~f:string_of_field\n end\n\n let%test_module \"random_oracle input\" =\n ( module struct\n let gen_field ~size_in_bits =\n let open Quickcheck.Generator in\n list_with_length size_in_bits bool\n\n let gen_input ?size_in_bits () =\n let open Quickcheck.Generator in\n let open Let_syntax in\n let%bind size_in_bits =\n size_in_bits |> Option.map ~f:return\n |> Option.value ~default:(Int.gen_incl 2 3000)\n in\n let%bind field_elements =\n (* Treat a field as a list of bools of length [size_in_bits]. *)\n list (gen_field ~size_in_bits)\n in\n let%map bitstrings = list (list bool) in\n ( size_in_bits\n , { field_elements = Array.of_list field_elements\n ; bitstrings = Array.of_list bitstrings\n } )\n\n let%test_unit \"coding2 equiv to hash directly\" =\n let size_in_bits = 255 in\n let field = gen_field ~size_in_bits in\n Quickcheck.test ~trials:300\n Quickcheck.Generator.(\n tuple2 (gen_input ~size_in_bits ()) (tuple2 field field))\n ~f:(fun ((_, input), (x, y)) ->\n let middle = [| x; y |] in\n let expected =\n append input (field_elements middle)\n |> pack_to_fields ~size_in_bits ~pack:Fn.id\n in\n let { Coding2.Rendered.prefix; suffix } =\n Coding2.serialize' input ~pack:Fn.id\n in\n let actual = Array.(concat [ prefix; middle; suffix ]) in\n [%test_eq: bool list array] expected actual )\n\n let%test_unit \"field/string partial isomorphism bitstrings\" =\n Quickcheck.test ~trials:300\n Quickcheck.Generator.(list_with_length 255 bool)\n ~f:(fun input ->\n let serialized = Coding.string_of_field input in\n let deserialized =\n Coding.field_of_string serialized ~size_in_bits:255\n in\n [%test_eq: (bool list, unit) Result.t] (input |> Result.return)\n deserialized )\n\n let%test_unit \"serialize/deserialize partial isomorphism 32byte fields\" =\n let size_in_bits = 255 in\n Quickcheck.test ~trials:3000 (gen_input ~size_in_bits ())\n ~f:(fun (_, input) ->\n let serialized =\n Coding.(\n serialize ~string_of_field ~to_bool:Fn.id ~of_bool:Fn.id input)\n in\n let deserialized =\n Coding.(\n deserialize\n (String.to_list serialized)\n ~field_of_string:(field_of_string ~size_in_bits)\n ~of_bool:Fn.id)\n in\n let normalized t =\n { t with\n bitstrings =\n ( t.bitstrings |> Array.to_list |> List.concat\n |> fun xs -> [| xs |] )\n }\n in\n assert (\n Array.for_all input.field_elements ~f:(fun el ->\n List.length el = size_in_bits ) ) ;\n Result.iter deserialized ~f:(fun x ->\n assert (\n Array.for_all x.field_elements ~f:(fun el ->\n List.length el = size_in_bits ) ) ) ;\n [%test_eq:\n ( (bool list, bool) t\n , [ `Expected_eof | `Unexpected_eof ] )\n Result.t]\n (normalized input |> Result.return)\n (deserialized |> Result.map ~f:normalized) )\n\n let%test_unit \"data is preserved by to_bits\" =\n Quickcheck.test ~trials:300 (gen_input ())\n ~f:(fun (size_in_bits, input) ->\n let bits = to_bits ~unpack:Fn.id input in\n let bools_equal = [%equal: bool list] in\n (* Fields are accumulated at the front, check them first. *)\n let bitstring_bits =\n Array.fold ~init:bits input.field_elements ~f:(fun bits field ->\n (* The next chunk of [size_in_bits] bits is for the field\n element.\n *)\n let field_bits, rest = List.split_n bits size_in_bits in\n assert (bools_equal field_bits field) ;\n rest )\n in\n (* Bits come after. *)\n let remaining_bits =\n Array.fold ~init:bitstring_bits input.bitstrings\n ~f:(fun bits bitstring ->\n (* The next bits match the bitstring. *)\n let bitstring_bits, rest =\n List.split_n bits (List.length bitstring)\n in\n assert (bools_equal bitstring_bits bitstring) ;\n rest )\n in\n (* All bits should have been consumed. *)\n assert (List.is_empty remaining_bits) )\n\n let%test_unit \"data is preserved by pack_to_fields\" =\n Quickcheck.test ~trials:300 (gen_input ())\n ~f:(fun (size_in_bits, input) ->\n let fields = pack_to_fields ~size_in_bits ~pack:Fn.id input in\n (* Fields are accumulated at the front, check them first. *)\n let fields = Array.to_list fields in\n let bitstring_fields =\n Array.fold ~init:fields input.field_elements\n ~f:(fun fields input_field ->\n (* The next field element should be the literal field element\n passed in.\n *)\n match fields with\n | [] ->\n failwith \"Too few field elements\"\n | field :: rest ->\n assert ([%equal: bool list] field input_field) ;\n rest )\n in\n (* Check that the remaining fields have the correct size. *)\n let final_field_idx = List.length bitstring_fields - 1 in\n List.iteri bitstring_fields ~f:(fun i field_bits ->\n if i < final_field_idx then\n (* This field should be densely packed, but should contain\n fewer bits than the maximum field element to ensure that it\n doesn't overflow, so we expect [size_in_bits - 1] bits for\n maximum safe density.\n *)\n assert (List.length field_bits = size_in_bits - 1)\n else (\n (* This field will be comprised of the remaining bits, up to a\n maximum of [size_in_bits - 1]. It should not be empty.\n *)\n assert (not (List.is_empty field_bits)) ;\n assert (List.length field_bits < size_in_bits) ) ) ;\n let rec go input_bitstrings packed_fields =\n match (input_bitstrings, packed_fields) with\n | [], [] ->\n (* We have consumed all bitstrings and fields in parallel, with\n no bits left over. Success.\n *)\n ()\n | [] :: input_bitstrings, packed_fields\n | input_bitstrings, [] :: packed_fields ->\n (* We have consumed the whole of an input bitstring or the whole\n of a packed field, move onto the next one.\n *)\n go input_bitstrings packed_fields\n | ( (bi :: input_bitstring) :: input_bitstrings\n , (bp :: packed_field) :: packed_fields ) ->\n (* Consume the next bit from the next input bitstring, and the\n next bit from the next packed field. They must match.\n *)\n assert (Bool.equal bi bp) ;\n go\n (input_bitstring :: input_bitstrings)\n (packed_field :: packed_fields)\n | [], _ ->\n failwith \"Packed fields contain more bits than were provided\"\n | _, [] ->\n failwith\n \"There are input bits that were not present in the packed \\\n fields\"\n in\n (* Check that the bits match between the input bitstring and the\n remaining fields.\n *)\n go (Array.to_list input.bitstrings) bitstring_fields )\n end )\nend\n","open Core_kernel\n\n[@@@warning \"-4\"] (* sexp-related fragile pattern-matching warning *)\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Pickles_base.Proofs_verified.V1.t = N0 | N1 | N2\n [@@deriving sexp, compare, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\nend]\n\n[@@@warning \"+4\"]\n\nlet to_int : t -> int = function N0 -> 0 | N1 -> 1 | N2 -> 2\n\n(** Inside the circuit, we use two different representations for this type,\n depending on what we need it for.\n\n Sometimes, we use it for masking out a list of 2 points by taking the\n a prefix of length 0, 1, or 2. In this setting, we we will represent a value\n of this type as a sequence of 2 bits like so:\n 00: N0\n 10: N1\n 11: N2\n\n We call this a **prefix mask**.\n\n Sometimes, we use it to select something from a list of 3 values. In this\n case, we will represent a value of this type as a sequence of 3 bits like so:\n\n 100: N0\n 010: N1\n 001: N2\n\n We call this a **one-hot vector** as elsewhere.\n*)\n\ntype proofs_verified = t\n\nlet of_nat (type n) (n : n Pickles_types.Nat.t) : t =\n let open Pickles_types.Nat in\n match n with\n | Z ->\n N0\n | S Z ->\n N1\n | S (S Z) ->\n N2\n | S _ ->\n failwithf \"Proofs_verified.of_nat: got %d\" (to_int n) ()\n\nlet of_int (n : int) : t =\n match n with\n | 0 ->\n N0\n | 1 ->\n N1\n | 2 ->\n N2\n | _ ->\n failwithf \"Proofs_verified.of_int: got %d\" n ()\n\ntype 'f boolean = 'f Snarky_backendless.Cvar.t Snarky_backendless.Boolean.t\n\ntype 'a vec2 = ('a, Pickles_types.Nat.N2.n) Pickles_types.Vector.t\n\nmodule Prefix_mask = struct\n module Checked = struct\n type 'f t = 'f boolean vec2\n end\n\n let[@warning \"-40-42\"] there : proofs_verified -> bool vec2 = function\n | N0 ->\n [ false; false ]\n | N1 ->\n [ false; true ]\n | N2 ->\n [ true; true ]\n\n let[@warning \"-40-42\"] back : bool vec2 -> proofs_verified = function\n | [ false; false ] ->\n N0\n | [ false; true ] ->\n N1\n | [ true; true ] ->\n N2\n | [ true; false ] ->\n invalid_arg \"Prefix_mask.back: invalid mask [false; true]\"\n\n let typ (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) :\n (f Checked.t, proofs_verified) Impl.Typ.t =\n let open Impl in\n Typ.transport\n (Pickles_types.Vector.typ Boolean.typ Pickles_types.Nat.N2.n)\n ~there ~back\nend\n\nmodule One_hot = struct\n module Checked = struct\n type 'f t = ('f, Pickles_types.Nat.N3.n) One_hot_vector.t\n\n let to_input (type f) (t : f t) =\n Random_oracle_input.Chunked.packeds\n (Array.map\n Pickles_types.(Vector.to_array (t :> (f boolean, Nat.N3.n) Vector.t))\n ~f:(fun b -> ((b :> f Snarky_backendless.Cvar.t), 1)) )\n end\n\n let there : proofs_verified -> int = function N0 -> 0 | N1 -> 1 | N2 -> 2\n\n let back : int -> proofs_verified = function\n | 0 ->\n N0\n | 1 ->\n N1\n | 2 ->\n N2\n | _ ->\n failwith \"Invalid mask\"\n\n let to_input ~zero ~one (t : t) =\n let one_hot =\n match t with\n | N0 ->\n [| one; zero; zero |]\n | N1 ->\n [| zero; one; zero |]\n | N2 ->\n [| zero; zero; one |]\n in\n Random_oracle_input.Chunked.packeds (Array.map one_hot ~f:(fun b -> (b, 1)))\n\n let typ (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) :\n (f Checked.t, proofs_verified) Impl.Typ.t =\n let module M = One_hot_vector.Make (Impl) in\n let open Impl in\n Typ.transport (M.typ Pickles_types.Nat.N3.n) ~there ~back\nend\n","open Core_kernel\nopen Pickles_types\n\nlet bits ~len n = List.init len ~f:(fun i -> (n lsr i) land 1 = 1)\n\nlet max_log2_degree = 32\n\nmodule Width : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n val of_int_exn : int -> t\n\n val to_int : t -> int\n\n val to_bits : t -> bool list\n\n val zero : t\n\n module Max = Nat.N2\n\n module Max_vector : Vector.With_version(Max).S\n\n module Max_at_most : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type 'a t = ('a, Max.n) At_most.t\n [@@deriving compare, sexp, yojson, hash, equal]\n end\n end]\n end\n\n module Length : Nat.Add.Intf_transparent\nend = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = char [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let zero = Char.of_int_exn 0\n\n module Max = Nat.N2\n\n (* Think about versioning here! These vector types *will* change\n serialization if the numbers above change, and so will require a new\n version number. Thus, it's important that these are modules with new\n versioned types, and not just module aliases to the corresponding vector\n implementation.\n *)\n module Max_vector = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = 'a Vector.Vector_2.Stable.V1.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n type 'a t = 'a Vector.Vector_2.t\n [@@deriving compare, yojson, sexp, hash, equal]\n\n let map = Vector.map\n\n let of_list_exn = Vector.Vector_2.of_list_exn\n\n let to_list = Vector.to_list\n end\n\n module Max_at_most = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = 'a At_most.At_most_2.Stable.V1.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n type 'a t = 'a At_most.At_most_2.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n\n module Length = Nat.N4\n\n let to_int = Char.to_int\n\n let to_bits = Fn.compose (bits ~len:(Nat.to_int Length.n)) to_int\n\n let of_int_exn : int -> t =\n let m = Nat.to_int Max.n in\n fun n ->\n assert (n <= m) ;\n Char.of_int_exn n\nend\n\nmodule Max_branches = struct\n include Nat.N8\n module Log2 = Nat.N3\nend\n\n(* TODO: remove since it looks very much like the Domains module in the same directory *)\nmodule Domains = struct\n [@@@warning \"-40-42\"]\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = { h : 'a }\n [@@deriving sexp, equal, compare, hash, yojson, hlist, fields]\n end\n end]\nend\n\nmodule Repr = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type 'g t =\n { max_proofs_verified : Proofs_verified.Stable.V1.t\n ; actual_wrap_domain_size : Proofs_verified.Stable.V1.t\n ; wrap_index : 'g Plonk_verification_key_evals.Stable.V2.t\n }\n [@@deriving sexp, equal, compare, yojson]\n end\n end]\nend\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('g, 'proofs_verified, 'vk) t =\n ( 'g\n , 'proofs_verified\n , 'vk )\n Mina_wire_types.Pickles_base.Side_loaded_verification_key.Poly.V2.t =\n { max_proofs_verified : 'proofs_verified\n ; actual_wrap_domain_size : 'proofs_verified\n ; wrap_index : 'g Plonk_verification_key_evals.Stable.V2.t\n ; wrap_vk : 'vk option\n }\n [@@deriving hash]\n end\n end]\nend\n\nlet index_to_field_elements (k : 'a Plonk_verification_key_evals.t) ~g =\n let Plonk_verification_key_evals.\n { sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n } =\n k\n in\n List.map\n ( Vector.to_list sigma_comm\n @ Vector.to_list coefficients_comm\n @ [ generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n ] )\n ~f:g\n |> Array.concat\n\nlet wrap_index_to_input (type gs f) (g : gs -> f array) t =\n Random_oracle_input.Chunked.field_elements (index_to_field_elements t ~g)\n\nlet to_input (type a) ~(field_of_int : int -> a) :\n (a * a, _, _) Poly.t -> a Random_oracle_input.Chunked.t =\n let open Random_oracle_input.Chunked in\n fun Poly.\n { max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index\n ; wrap_vk = _\n } : _ Random_oracle_input.Chunked.t ->\n List.reduce_exn ~f:append\n [ Proofs_verified.One_hot.to_input ~zero:(field_of_int 0)\n ~one:(field_of_int 1) max_proofs_verified\n ; Proofs_verified.One_hot.to_input ~zero:(field_of_int 0)\n ~one:(field_of_int 1) actual_wrap_domain_size\n ; wrap_index_to_input\n (Fn.compose Array.of_list (fun (x, y) -> [ x; y ]))\n wrap_index\n ]\n","open Core_kernel\n\n[@@@warning \"-4\"] (* sexp-related fragile pattern-matching warning *)\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = Pow_2_roots_of_unity of int\n [@@unboxed] [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\n[@@@warning \"+4\"]\n\ninclude Hashable.Make (Stable.Latest)\n\nlet log2_size (Pow_2_roots_of_unity k) = k\n\nlet size t = 1 lsl log2_size t\n","(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Pickles_composition_types.Branch_data\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Branch_data_intf.S\n with type Domain_log2.Stable.V1.t = A.Domain_log2.V1.t\n and type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n (** Data specific to a branch of a proof-system that's necessary for\n finalizing the deferred-values in a wrap proof of that branch. *)\n\n module Proofs_verified = Pickles_base.Proofs_verified\n\n module Domain_log2 = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = char [@@deriving compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n let of_int_exn : int -> t = Char.of_int_exn\n\n let of_bits_msb (bs : bool list) : t =\n List.fold bs ~init:0 ~f:(fun acc b ->\n let acc = acc lsl 1 in\n if b then acc + 1 else acc )\n |> of_int_exn\n\n let of_field_exn (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n (x : f) : t =\n Impl.Field.Constant.unpack x\n |> Fn.flip List.take 8 |> List.rev |> of_bits_msb\n end\n\n (* We pack this into a single field element as follows:\n First 2 bits: proofs_verified\n Next 8 bits: domain_log2 *)\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = A.V1.t =\n { proofs_verified : Proofs_verified.Stable.V1.t\n ; domain_log2 : Domain_log2.Stable.V1.t\n }\n [@@deriving hlist, compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n let length_in_bits = 10\n\n let pack (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ({ proofs_verified; domain_log2 } : t) : f =\n let open Impl.Field.Constant in\n let double x = x + x in\n let times4 x = double (double x) in\n let domain_log2 = of_int (Char.to_int domain_log2) in\n (* shift domain_log2 over by 2 bits (multiply by 4) *)\n times4 domain_log2\n + project\n (Pickles_types.Vector.to_list\n (Proofs_verified.Prefix_mask.there proofs_verified) )\n\n let unpack (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n (x : f) : t =\n match Impl.Field.Constant.unpack x with\n | x0 :: x1 :: y0 :: y1 :: y2 :: y3 :: y4 :: y5 :: y6 :: y7 :: _ ->\n { proofs_verified = Proofs_verified.Prefix_mask.back [ x0; x1 ]\n ; domain_log2 =\n Domain_log2.of_bits_msb [ y7; y6; y5; y4; y3; y2; y1; y0 ]\n }\n | _ ->\n assert false\n\n module Checked = struct\n type 'f t =\n { proofs_verified_mask : 'f Proofs_verified.Prefix_mask.Checked.t\n ; domain_log2 : 'f Snarky_backendless.Cvar.t\n }\n [@@deriving hlist]\n\n let pack (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ({ proofs_verified_mask; domain_log2 } : f t) : Impl.Field.t =\n let open Impl.Field in\n let four = of_int 4 in\n (four * domain_log2)\n + pack (Pickles_types.Vector.to_list proofs_verified_mask)\n end\n\n let packed_typ (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) =\n Impl.Typ.transport Impl.Typ.field\n ~there:(pack (module Impl))\n ~back:(unpack (module Impl))\n\n let typ (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ~(* We actually only need it to be less than 252 bits in order to pack\n the whole branch_data struct safely, but it's cheapest to check that it's\n under 16 bits *)\n (assert_16_bits : Impl.Field.t -> unit) : (f Checked.t, t) Impl.Typ.t =\n let open Impl in\n let proofs_verified_mask :\n (f Proofs_verified.Prefix_mask.Checked.t, Proofs_verified.t) Typ.t =\n Proofs_verified.Prefix_mask.typ (module Impl)\n in\n let domain_log2 : (Field.t, Domain_log2.t) Typ.t =\n let (Typ t) =\n Typ.transport Field.typ\n ~there:(fun (x : char) -> Field.Constant.of_int (Char.to_int x))\n ~back:(Domain_log2.of_field_exn (module Impl))\n in\n let check (x : Field.t) = make_checked (fun () -> assert_16_bits x) in\n Typ { t with check }\n in\n Typ.of_hlistable\n [ proofs_verified_mask; domain_log2 ]\n ~value_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n\n let domain { domain_log2; _ } =\n Pickles_base.Domain.Pow_2_roots_of_unity (Char.to_int domain_log2)\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","[%%versioned\nmodule Stable = struct\n module V1 = struct\n type 'challenge t =\n 'challenge Mina_wire_types.Pickles_bulletproof_challenge.V1.t =\n { prechallenge : 'challenge }\n [@@deriving sexp, compare, yojson, hash, equal]\n end\nend]\n\nlet pack { prechallenge } = prechallenge\n\nlet unpack prechallenge = { prechallenge }\n\nlet map { prechallenge } ~f = { prechallenge = f prechallenge }\n\nlet typ chal =\n let there = pack in\n let back = unpack in\n let open Snarky_backendless in\n Typ.transport ~there ~back (Kimchi_backend_common.Scalar_challenge.typ chal)\n |> Typ.transport_var ~there ~back\n","open Pickles_types\nmodule Scalar_challenge = Kimchi_backend_common.Scalar_challenge\nmodule Bulletproof_challenge = Bulletproof_challenge\nmodule Branch_data = Branch_data\nmodule Digest = Digest\nmodule Spec = Spec\nmodule Opt = Opt\nopen Core_kernel\n\ntype 'f impl = 'f Spec.impl\n\nlet index_to_field_elements =\n Pickles_base.Side_loaded_verification_key.index_to_field_elements\n\nmodule Zero_values = struct\n type ('chal, 'fp) single = { challenge : 'chal; scalar : 'fp }\n\n type ('chal, 'chal_var, 'fp, 'fp_var) t =\n { value : ('chal, 'fp) single; var : ('chal_var, 'fp_var) single }\nend\n\nmodule Wrap = struct\n module Proof_state = struct\n (** This module contains structures which contain the scalar-field elements that\n are required to finalize the verification of a proof that is partially verified inside\n a circuit.\n\n Each verifier circuit starts by verifying the parts of a proof involving group operations.\n At the end, there is a sequence of scalar-field computations it must perform. Instead of\n performing them directly, it exposes the values needed for those computations as a part of\n its own public-input, so that the next circuit can do them (since it will use the other curve on the cycle,\n and hence can efficiently perform computations in that scalar field). *)\n module Deferred_values = struct\n module Plonk = struct\n module Minimal = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n (** Challenges from the PLONK IOP. These, plus the evaluations that are already in the proof, are\n all that's needed to derive all the values in the [In_circuit] version below.\n\n See src/lib/pickles/plonk_checks/plonk_checks.ml for the computation of the [In_circuit] value\n from the [Minimal] value.\n *)\n type ('challenge, 'scalar_challenge, 'bool) t =\n ( 'challenge\n , 'scalar_challenge\n , 'bool )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state\n .Deferred_values\n .Plonk\n .Minimal\n .V1\n .t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n ; joint_combiner : 'scalar_challenge option\n ; feature_flags : 'bool Plonk_types.Features.Stable.V1.t\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n let map_challenges t ~f ~scalar =\n { t with\n alpha = scalar t.alpha\n ; beta = f t.beta\n ; gamma = f t.gamma\n ; zeta = scalar t.zeta\n ; joint_combiner = Option.map ~f:scalar t.joint_combiner\n }\n\n module In_circuit = struct\n type ('challenge, 'scalar_challenge, 'bool) t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n ; joint_combiner : ('scalar_challenge, 'bool) Opt.t\n ; feature_flags : 'bool Plonk_types.Features.t\n }\n end\n end\n\n open Pickles_types\n\n module In_circuit = struct\n (** All scalar values deferred by a verifier circuit.\n We expose them so the next guy (who can do scalar arithmetic) can check that they\n were computed correctly from the evaluations in the proof and the challenges.\n *)\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'scalar_challenge_opt\n , 'bool )\n t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n (* TODO: zeta_to_srs_length is kind of unnecessary.\n Try to get rid of it when you can.\n *)\n ; zeta_to_srs_length : 'fp\n ; zeta_to_domain_size : 'fp\n ; perm : 'fp\n (** scalar used on one of the permutation polynomial commitments. *)\n ; feature_flags : 'bool Plonk_types.Features.t\n ; joint_combiner : 'scalar_challenge_opt\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal, fields]\n\n let map_challenges t ~f ~scalar =\n { t with\n alpha = scalar t.alpha\n ; beta = f t.beta\n ; gamma = f t.gamma\n ; joint_combiner = Opt.map ~f:scalar t.joint_combiner\n ; zeta = scalar t.zeta\n }\n\n let map_fields t ~f =\n { t with\n zeta_to_srs_length = f t.zeta_to_srs_length\n ; zeta_to_domain_size = f t.zeta_to_domain_size\n ; perm = f t.perm\n }\n\n let typ (type f fp)\n (module Impl : Snarky_backendless.Snark_intf.Run\n with type field = f ) ~dummy_scalar_challenge ~challenge\n ~scalar_challenge ~bool\n ~feature_flags:\n ({ Plonk_types.Features.Full.uses_lookups; _ } as feature_flags)\n (fp : (fp, _, f) Snarky_backendless.Typ.t) =\n Snarky_backendless.Typ.of_hlistable\n [ Scalar_challenge.typ scalar_challenge\n ; challenge\n ; challenge\n ; Scalar_challenge.typ scalar_challenge\n ; fp\n ; fp\n ; fp\n ; Plonk_types.Features.typ\n ~feature_flags:(Plonk_types.Features.of_full feature_flags)\n bool\n ; Opt.typ Impl.Boolean.typ uses_lookups\n ~dummy:dummy_scalar_challenge\n (Scalar_challenge.typ scalar_challenge)\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n end\n\n let to_minimal (type challenge scalar_challenge fp fp_opt lookup_opt)\n (t :\n ( challenge\n , scalar_challenge\n , fp\n , fp_opt\n , lookup_opt\n , 'bool )\n In_circuit.t ) ~(to_option : lookup_opt -> scalar_challenge option)\n : (challenge, scalar_challenge, 'bool) Minimal.t =\n { alpha = t.alpha\n ; beta = t.beta\n ; zeta = t.zeta\n ; gamma = t.gamma\n ; joint_combiner = to_option t.joint_combiner\n ; feature_flags = t.feature_flags\n }\n end\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n (** All the deferred values needed, comprising values from the PLONK IOP verification,\n values from the inner-product argument, and [which_branch] which is needed to know\n the proper domain to use. *)\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n t =\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state\n .Deferred_values\n .V1\n .t =\n { plonk : 'plonk\n ; combined_inner_product : 'fp\n (** combined_inner_product = sum_{i < num_evaluation_points} sum_{j < num_polys} r^i xi^j f_j(pt_i) *)\n ; b : 'fp\n (** b = challenge_poly plonk.zeta + r * challenge_poly (domain_generrator * plonk.zeta)\n where challenge_poly(x) = \\prod_i (1 + bulletproof_challenges.(i) * x^{2^{k - 1 - i}})\n *)\n ; xi : 'scalar_challenge\n (** The challenge used for combining polynomials *)\n ; bulletproof_challenges : 'bulletproof_challenges\n (** The challenges from the inner-product argument that was partially verified. *)\n ; branch_data : 'branch_data\n (** Data specific to which step branch of the proof-system was verified *)\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n t =\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n Stable.Latest.t =\n { plonk : 'plonk\n ; combined_inner_product : 'fp\n ; b : 'fp\n ; xi : 'scalar_challenge\n ; bulletproof_challenges : 'bulletproof_challenges\n ; branch_data : 'branch_data\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n\n module Minimal = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'bulletproof_challenges\n , 'branch_data )\n t =\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'bulletproof_challenges\n , 'branch_data )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state\n .Deferred_values\n .Minimal\n .V1\n .t =\n { plonk :\n ( 'challenge\n , 'scalar_challenge\n , 'bool )\n Plonk.Minimal.Stable.V1.t\n ; bulletproof_challenges : 'bulletproof_challenges\n ; branch_data : 'branch_data\n }\n [@@deriving sexp, compare, yojson, hash, equal]\n end\n end]\n\n let map_challenges { plonk; bulletproof_challenges; branch_data } ~f\n ~scalar =\n { plonk = Plonk.Minimal.map_challenges ~f ~scalar plonk\n ; bulletproof_challenges\n ; branch_data\n }\n end\n\n let map_challenges\n { plonk\n ; combined_inner_product\n ; b : 'fp\n ; xi\n ; bulletproof_challenges\n ; branch_data\n } ~f:_ ~scalar =\n { xi = scalar xi\n ; combined_inner_product\n ; b\n ; plonk\n ; bulletproof_challenges\n ; branch_data\n }\n\n module In_circuit = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bulletproof_challenges\n , 'branch_data\n , 'bool )\n t =\n ( ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bool )\n Plonk.In_circuit.t\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n Stable.Latest.t\n [@@deriving sexp, compare, yojson, hash, equal]\n\n let to_hlist, of_hlist = (to_hlist, of_hlist)\n\n let typ (type f fp)\n ((module Impl) as impl :\n (module Snarky_backendless.Snark_intf.Run with type field = f) )\n ~dummy_scalar_challenge ~challenge ~scalar_challenge ~feature_flags\n (fp : (fp, _, f) Snarky_backendless.Typ.t) index =\n Snarky_backendless.Typ.of_hlistable\n [ Plonk.In_circuit.typ impl ~dummy_scalar_challenge ~challenge\n ~scalar_challenge ~bool:Impl.Boolean.typ ~feature_flags fp\n ; fp\n ; fp\n ; Scalar_challenge.typ scalar_challenge\n ; Vector.typ\n (Bulletproof_challenge.typ scalar_challenge)\n Backend.Tick.Rounds.n\n ; index\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n end\n\n let to_minimal\n ({ plonk\n ; combined_inner_product = _\n ; b = _\n ; xi = _\n ; bulletproof_challenges\n ; branch_data\n } :\n _ In_circuit.t ) ~to_option : _ Minimal.t =\n { plonk = Plonk.to_minimal ~to_option plonk\n ; bulletproof_challenges\n ; branch_data\n }\n end\n\n (** The component of the proof accumulation state that is only computed on by the\n \"wrapping\" proof system, and that can be handled opaquely by any \"step\" circuits. *)\n module Messages_for_next_wrap_proof = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('g1, 'bulletproof_challenges) t =\n ( 'g1\n , 'bulletproof_challenges )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state\n .Messages_for_next_wrap_proof\n .V1\n .t =\n { challenge_polynomial_commitment : 'g1\n ; old_bulletproof_challenges : 'bulletproof_challenges\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n end\n end]\n\n let to_field_elements (type g f)\n { challenge_polynomial_commitment; old_bulletproof_challenges }\n ~g1:(g1_to_field_elements : g -> f list) =\n Array.concat\n [ Vector.to_array old_bulletproof_challenges\n |> Array.concat_map ~f:Vector.to_array\n ; Array.of_list (g1_to_field_elements challenge_polynomial_commitment)\n ]\n\n let typ g1 chal ~length =\n Snarky_backendless.Typ.of_hlistable\n [ g1; Vector.typ chal length ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n t =\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state.V1.t =\n { deferred_values :\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bp_chals\n , 'index )\n Deferred_values.Stable.V1.t\n ; sponge_digest_before_evaluations : 'digest\n ; messages_for_next_wrap_proof : 'messages_for_next_wrap_proof\n (** Parts of the statement not needed by the other circuit. Represented as a hash inside the\n circuit which is then \"unhashed\". *)\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n end\n end]\n\n module Minimal = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n t =\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state\n .Minimal\n .V1\n .t =\n { deferred_values :\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'bp_chals\n , 'index )\n Deferred_values.Minimal.Stable.V1.t\n ; sponge_digest_before_evaluations : 'digest\n ; messages_for_next_wrap_proof : 'messages_for_next_wrap_proof\n (** Parts of the statement not needed by the other circuit. Represented as a hash inside the\n circuit which is then \"unhashed\". *)\n }\n [@@deriving sexp, compare, yojson, hash, equal]\n end\n end]\n end\n\n module In_circuit = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n t =\n ( ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bool )\n Deferred_values.Plonk.In_circuit.t\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Stable.Latest.t\n [@@deriving sexp, compare, yojson, hash, equal]\n\n let to_hlist, of_hlist = (to_hlist, of_hlist)\n\n let typ (type f fp)\n (impl : (module Snarky_backendless.Snark_intf.Run with type field = f))\n ~dummy_scalar_challenge ~challenge ~scalar_challenge ~feature_flags\n (fp : (fp, _, f) Snarky_backendless.Typ.t)\n messages_for_next_wrap_proof digest index =\n Snarky_backendless.Typ.of_hlistable\n [ Deferred_values.In_circuit.typ impl ~dummy_scalar_challenge\n ~challenge ~scalar_challenge ~feature_flags fp index\n ; digest\n ; messages_for_next_wrap_proof\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n let to_minimal\n ({ deferred_values\n ; sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n } :\n _ In_circuit.t ) ~to_option : _ Minimal.t =\n { deferred_values = Deferred_values.to_minimal ~to_option deferred_values\n ; sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n }\n end\n\n (** The component of the proof accumulation state that is only computed on by the\n \"stepping\" proof system, and that can be handled opaquely by any \"wrap\" circuits. *)\n module Messages_for_next_step_proof = struct\n type ('g, 's, 'challenge_polynomial_commitments, 'bulletproof_challenges) t =\n { app_state : 's\n (** The actual application-level state (e.g., for Mina, this is the protocol state which contains the\n merkle root of the ledger, state related to consensus, etc.) *)\n ; dlog_plonk_index : 'g Plonk_verification_key_evals.t\n (** The verification key corresponding to the wrap-circuit for this recursive proof system.\n It gets threaded through all the circuits so that the step circuits can verify proofs against\n it.\n *)\n ; challenge_polynomial_commitments : 'challenge_polynomial_commitments\n ; old_bulletproof_challenges : 'bulletproof_challenges\n }\n [@@deriving sexp]\n\n let to_field_elements (type g f)\n { app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n } ~app_state:app_state_to_field_elements ~comm ~(g : g -> f list) =\n Array.concat\n [ index_to_field_elements ~g:comm dlog_plonk_index\n ; app_state_to_field_elements app_state\n ; Vector.map2 challenge_polynomial_commitments\n old_bulletproof_challenges ~f:(fun comm chals ->\n Array.append (Array.of_list (g comm)) (Vector.to_array chals) )\n |> Vector.to_list |> Array.concat\n ]\n\n let to_field_elements_without_index (type g f)\n { app_state\n ; dlog_plonk_index = _\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n } ~app_state:app_state_to_field_elements ~(g : g -> f list) =\n Array.concat\n [ app_state_to_field_elements app_state\n ; Vector.map2 challenge_polynomial_commitments\n old_bulletproof_challenges ~f:(fun comm chals ->\n Array.append (Array.of_list (g comm)) (Vector.to_array chals) )\n |> Vector.to_list |> Array.concat\n ]\n\n open Snarky_backendless.H_list\n\n let[@warning \"-45\"] to_hlist\n { app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n } =\n [ app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n ]\n\n let[@warning \"-45\"] of_hlist\n ([ app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n ] :\n (unit, _) t ) =\n { app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n }\n\n let typ comm g s chal proofs_verified =\n Snarky_backendless.Typ.of_hlistable\n [ s\n ; Plonk_verification_key_evals.typ comm\n ; Vector.typ g proofs_verified\n ; chal\n ]\n (* TODO: Should this really just be a vector typ of length Rounds.n ?*)\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n module Lookup_parameters = struct\n (* Values needed for computing lookup parts of the verifier circuit. *)\n type ('chal, 'chal_var, 'fp, 'fp_var) t =\n { zero : ('chal, 'chal_var, 'fp, 'fp_var) Zero_values.t\n ; use : Opt.Flag.t\n }\n\n let opt_spec (type f) ((module Impl) : f impl)\n { zero = { value; var }; use } =\n Spec.T.Opt\n { inner = Struct [ Scalar Challenge ]\n ; flag = use\n ; dummy1 =\n [ Kimchi_backend_common.Scalar_challenge.create value.challenge ]\n ; dummy2 =\n [ Kimchi_backend_common.Scalar_challenge.create var.challenge ]\n ; bool = (module Impl.Boolean)\n }\n end\n\n (** This is the full statement for \"wrap\" proofs which contains\n - the application-level statement (app_state)\n - data needed to perform the final verification of the proof, which correspond\n to parts of incompletely verified proofs.\n *)\n module Statement = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n t =\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n Mina_wire_types.Pickles_composition_types.Wrap.Statement.V1.t =\n { proof_state :\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Proof_state.Stable.V1.t\n ; messages_for_next_step_proof : 'messages_for_next_step_proof\n }\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n module Minimal = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n t =\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n Mina_wire_types.Pickles_composition_types.Wrap.Statement.Minimal\n .V1\n .t =\n { proof_state :\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Proof_state.Minimal.Stable.V1.t\n ; messages_for_next_step_proof : 'messages_for_next_step_proof\n }\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n end\n\n module In_circuit = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n t =\n ( ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bool )\n Proof_state.Deferred_values.Plonk.In_circuit.t\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n Stable.Latest.t\n [@@deriving compare, yojson, sexp, hash, equal]\n\n (** A layout of the raw data in a statement, which is needed for\n representing it inside the circuit. *)\n let spec impl lookup feature_flags =\n let feature_flags_spec =\n let [ f1; f2; f3; f4; f5; f6; f7; f8 ] =\n (* Ensure that layout is the same *)\n Plonk_types.Features.to_data feature_flags\n in\n let constant x =\n Spec.T.Constant (x, (fun x y -> assert (Bool.equal x y)), B Bool)\n in\n let maybe_constant flag =\n match flag with\n | Opt.Flag.Yes ->\n constant true\n | Opt.Flag.No ->\n constant false\n | Opt.Flag.Maybe ->\n Spec.T.B Bool\n in\n Spec.T.Struct\n [ maybe_constant f1\n ; maybe_constant f2\n ; maybe_constant f3\n ; maybe_constant f4\n ; maybe_constant f5\n ; maybe_constant f6\n ; maybe_constant f7\n ; maybe_constant f8\n ]\n in\n Spec.T.Struct\n [ Vector (B Field, Nat.N5.n)\n ; Vector (B Challenge, Nat.N2.n)\n ; Vector (Scalar Challenge, Nat.N3.n)\n ; Vector (B Digest, Nat.N3.n)\n ; Vector (B Bulletproof_challenge, Backend.Tick.Rounds.n)\n ; Vector (B Branch_data, Nat.N1.n)\n ; feature_flags_spec\n ; Lookup_parameters.opt_spec impl lookup\n ]\n\n (** Convert a statement (as structured data) into the flat data-based representation. *)\n let[@warning \"-45\"] to_data\n ({ proof_state =\n { deferred_values =\n { xi\n ; combined_inner_product\n ; b\n ; branch_data\n ; bulletproof_challenges\n ; plonk =\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ; feature_flags\n ; joint_combiner\n }\n }\n ; sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n (* messages_for_next_wrap_proof is represented as a digest (and then unhashed) inside the circuit *)\n }\n ; messages_for_next_step_proof\n (* messages_for_next_step_proof is represented as a digest inside the circuit *)\n } :\n _ t ) ~option_map =\n let open Vector in\n let fp =\n [ combined_inner_product\n ; b\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ]\n in\n let challenge = [ beta; gamma ] in\n let scalar_challenge = [ alpha; zeta; xi ] in\n let digest =\n [ sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n ; messages_for_next_step_proof\n ]\n in\n let index = [ branch_data ] in\n Hlist.HlistId.\n [ fp\n ; challenge\n ; scalar_challenge\n ; digest\n ; bulletproof_challenges\n ; index\n ; Plonk_types.Features.to_data feature_flags\n ; option_map joint_combiner ~f:(fun x -> Hlist.HlistId.[ x ])\n ]\n\n (** Construct a statement (as structured data) from the flat data-based representation. *)\n let[@warning \"-45\"] of_data\n Hlist.HlistId.\n [ fp\n ; challenge\n ; scalar_challenge\n ; digest\n ; bulletproof_challenges\n ; index\n ; feature_flags\n ; joint_combiner\n ] ~option_map : _ t =\n let open Vector in\n let [ combined_inner_product\n ; b\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ] =\n fp\n in\n let [ beta; gamma ] = challenge in\n let [ alpha; zeta; xi ] = scalar_challenge in\n let [ sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n ; messages_for_next_step_proof\n ] =\n digest\n in\n let [ branch_data ] = index in\n let feature_flags = Plonk_types.Features.of_data feature_flags in\n { proof_state =\n { deferred_values =\n { xi\n ; combined_inner_product\n ; b\n ; branch_data\n ; bulletproof_challenges\n ; plonk =\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ; feature_flags\n ; joint_combiner =\n option_map joint_combiner ~f:(fun Hlist.HlistId.[ x ] ->\n x )\n }\n }\n ; sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n }\n ; messages_for_next_step_proof\n }\n end\n\n let to_minimal\n ({ proof_state; messages_for_next_step_proof } : _ In_circuit.t)\n ~to_option : _ Minimal.t =\n { proof_state = Proof_state.to_minimal ~to_option proof_state\n ; messages_for_next_step_proof\n }\n end\nend\n\nmodule Step = struct\n module Plonk_polys = Nat.N10\n\n module Bulletproof = struct\n include Plonk_types.Openings.Bulletproof\n\n module Advice = struct\n (** This is data that can be computed in linear time from the proof + statement.\n\n It doesn't need to be sent on the wire, but it does need to be provided to the verifier\n *)\n type 'fq t =\n { b : 'fq\n ; combined_inner_product : 'fq (* sum_i r^i sum_j xi^j f_j(pt_i) *)\n }\n [@@deriving hlist]\n end\n end\n\n module Proof_state = struct\n module Deferred_values = struct\n module Plonk = struct\n module Minimal = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n (** Challenges from the PLONK IOP. These, plus the evaluations that are already in the proof, are\n all that's needed to derive all the values in the [In_circuit] version below.\n\n See src/lib/pickles/plonk_checks/plonk_checks.ml for the computation of the [In_circuit] value\n from the [Minimal] value.\n *)\n type ('challenge, 'scalar_challenge) t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n end\n end]\n\n let to_wrap ~feature_flags { alpha; beta; gamma; zeta } :\n _ Wrap.Proof_state.Deferred_values.Plonk.Minimal.t =\n { alpha; beta; gamma; zeta; joint_combiner = None; feature_flags }\n\n let of_wrap\n ({ alpha\n ; beta\n ; gamma\n ; zeta\n ; joint_combiner = _\n ; feature_flags = _\n } :\n _ Wrap.Proof_state.Deferred_values.Plonk.Minimal.t ) =\n { alpha; beta; gamma; zeta }\n end\n\n open Pickles_types\n\n module In_circuit = struct\n (** All scalar values deferred by a verifier circuit.\n The values in [vbmul], [complete_add], [endomul], [endomul_scalar], and [perm]\n are all scalars which will have been used to scale selector polynomials during the\n computation of the linearized polynomial commitment.\n\n Then, we expose them so the next guy (who can do scalar arithmetic) can check that they\n were computed correctly from the evaluations in the proof and the challenges.\n *)\n type ('challenge, 'scalar_challenge, 'fp) t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n (* TODO: zeta_to_srs_length is kind of unnecessary.\n Try to get rid of it when you can.\n *)\n ; zeta_to_srs_length : 'fp\n ; zeta_to_domain_size : 'fp\n ; perm : 'fp\n (** scalar used on one of the permutation polynomial commitments. *)\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal, fields]\n\n let to_wrap ~opt_none ~false_\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n } : _ Wrap.Proof_state.Deferred_values.Plonk.In_circuit.t =\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ; feature_flags =\n { range_check0 = false_\n ; range_check1 = false_\n ; foreign_field_add = false_\n ; foreign_field_mul = false_\n ; xor = false_\n ; rot = false_\n ; lookup = false_\n ; runtime_tables = false_\n }\n ; joint_combiner = opt_none\n }\n\n let of_wrap ~assert_none ~assert_false\n ({ alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ; feature_flags\n ; joint_combiner\n } :\n _ Wrap.Proof_state.Deferred_values.Plonk.In_circuit.t ) =\n let () =\n let { Plonk_types.Features.range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n } =\n feature_flags\n in\n assert_false range_check0 ;\n assert_false range_check1 ;\n assert_false foreign_field_add ;\n assert_false foreign_field_mul ;\n assert_false xor ;\n assert_false rot ;\n assert_false lookup ;\n assert_false runtime_tables\n in\n assert_none joint_combiner ;\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n }\n\n let map_challenges t ~f ~scalar =\n { t with\n alpha = scalar t.alpha\n ; beta = f t.beta\n ; gamma = f t.gamma\n ; zeta = scalar t.zeta\n }\n\n let map_fields t ~f =\n { t with\n zeta_to_srs_length = f t.zeta_to_srs_length\n ; zeta_to_domain_size = f t.zeta_to_domain_size\n ; perm = f t.perm\n }\n\n let typ (type f fp) _ ~challenge ~scalar_challenge\n (fp : (fp, _, f) Snarky_backendless.Typ.t) =\n Snarky_backendless.Typ.of_hlistable\n [ Scalar_challenge.typ scalar_challenge\n ; challenge\n ; challenge\n ; Scalar_challenge.typ scalar_challenge\n ; fp\n ; fp\n ; fp\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n end\n\n let to_minimal (type challenge scalar_challenge fp)\n (t : (challenge, scalar_challenge, fp) In_circuit.t) :\n (challenge, scalar_challenge) Minimal.t =\n { alpha = t.alpha; beta = t.beta; zeta = t.zeta; gamma = t.gamma }\n end\n\n (** All the scalar-field values needed to finalize the verification of a proof\n by checking that the correct values were used in the \"group operations\" part of the\n verifier.\n\n Consists of some evaluations of PLONK polynomials (columns, permutation aggregation, etc.)\n and the remainder are things related to the inner product argument.\n*)\n type ('plonk, 'scalar_challenge, 'fq, 'bulletproof_challenges) t_ =\n { plonk : 'plonk\n ; combined_inner_product : 'fq\n (** combined_inner_product = sum_{i < num_evaluation_points} sum_{j < num_polys} r^i xi^j f_j(pt_i) *)\n ; xi : 'scalar_challenge\n (** The challenge used for combining polynomials *)\n ; bulletproof_challenges : 'bulletproof_challenges\n (** The challenges from the inner-product argument that was partially verified. *)\n ; b : 'fq\n (** b = challenge_poly plonk.zeta + r * challenge_poly (domain_generrator * plonk.zeta)\n where challenge_poly(x) = \\prod_i (1 + bulletproof_challenges.(i) * x^{2^{k - 1 - i}})\n *)\n }\n [@@deriving sexp, compare, yojson]\n\n module Minimal = struct\n type ('challenge, 'scalar_challenge, 'fq, 'bulletproof_challenges) t =\n ( ('challenge, 'scalar_challenge) Plonk.Minimal.t\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges )\n t_\n [@@deriving sexp, compare, yojson]\n end\n\n module In_circuit = struct\n type ('challenge, 'scalar_challenge, 'fq, 'bulletproof_challenges) t =\n ( ('challenge, 'scalar_challenge, 'fq) Plonk.In_circuit.t\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges )\n t_\n [@@deriving sexp, compare, yojson]\n end\n end\n\n module Messages_for_next_wrap_proof =\n Wrap.Proof_state.Messages_for_next_wrap_proof\n module Messages_for_next_step_proof = Wrap.Messages_for_next_step_proof\n\n module Per_proof = struct\n (** For each proof that a step circuit verifies, we do not verify the whole proof.\n Specifically,\n - we defer calculations involving the \"other field\" (i.e., the scalar-field of the group\n elements involved in the proof.\n - we do not fully verify the inner-product argument as that would be O(n) and instead\n do the accumulator trick.\n\n As a result, for each proof that a step circuit verifies, we must expose some data\n related to it as part of the step circuit's statement, in order to allow those proofs\n to be fully verified eventually.\n\n This is that data. *)\n type ( 'plonk\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges\n , 'digest\n , 'bool )\n t_ =\n { deferred_values :\n ( 'plonk\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges )\n Deferred_values.t_\n (** Scalar values related to the proof *)\n ; should_finalize : 'bool\n (** We allow circuits in pickles proof systems to decide if it's OK that a proof did\n not recursively verify. In that case, when we expose the unfinalized bits, we need\n to communicate that it's OK if those bits do not \"finalize\". That's what this boolean\n is for. *)\n ; sponge_digest_before_evaluations : 'digest\n }\n [@@deriving sexp, compare, yojson]\n\n module Minimal = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges\n , 'digest\n , 'bool )\n t =\n ( ('challenge, 'scalar_challenge) Deferred_values.Plonk.Minimal.t\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges\n , 'digest\n , 'bool )\n t_\n [@@deriving sexp, compare, yojson]\n end\n\n module In_circuit = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges\n , 'digest\n , 'bool )\n t =\n ( ( 'challenge\n , 'scalar_challenge\n , 'fq )\n Deferred_values.Plonk.In_circuit.t\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges\n , 'digest\n , 'bool )\n t_\n [@@deriving sexp, compare, yojson]\n\n (** A layout of the raw data in this value, which is needed for\n representing it inside the circuit. *)\n let spec bp_log2 =\n Spec.T.Struct\n [ Vector (B Field, Nat.N5.n)\n ; Vector (B Digest, Nat.N1.n)\n ; Vector (B Challenge, Nat.N2.n)\n ; Vector (Scalar Challenge, Nat.N3.n)\n ; Vector (B Bulletproof_challenge, bp_log2)\n ; Vector (B Bool, Nat.N1.n)\n ]\n\n let[@warning \"-45\"] to_data\n ({ deferred_values =\n { xi\n ; bulletproof_challenges\n ; b\n ; combined_inner_product\n ; plonk =\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n }\n }\n ; should_finalize\n ; sponge_digest_before_evaluations\n } :\n _ t ) =\n let open Vector in\n let fq =\n [ combined_inner_product\n ; b\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ]\n in\n let challenge = [ beta; gamma ] in\n let scalar_challenge = [ alpha; zeta; xi ] in\n let digest = [ sponge_digest_before_evaluations ] in\n let bool = [ should_finalize ] in\n let open Hlist.HlistId in\n [ fq\n ; digest\n ; challenge\n ; scalar_challenge\n ; bulletproof_challenges\n ; bool\n ]\n\n let[@warning \"-45\"] of_data\n Hlist.HlistId.\n [ Vector.\n [ combined_inner_product\n ; b\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ]\n ; Vector.[ sponge_digest_before_evaluations ]\n ; Vector.[ beta; gamma ]\n ; Vector.[ alpha; zeta; xi ]\n ; bulletproof_challenges\n ; Vector.[ should_finalize ]\n ] : _ t =\n { deferred_values =\n { xi\n ; bulletproof_challenges\n ; b\n ; combined_inner_product\n ; plonk =\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n }\n }\n ; should_finalize\n ; sponge_digest_before_evaluations\n }\n end\n\n let typ impl fq ~assert_16_bits =\n let open In_circuit in\n Spec.typ impl fq ~assert_16_bits (spec Backend.Tock.Rounds.n)\n |> Snarky_backendless.Typ.transport ~there:to_data ~back:of_data\n |> Snarky_backendless.Typ.transport_var ~there:to_data ~back:of_data\n end\n\n type ('unfinalized_proofs, 'messages_for_next_step_proof) t =\n { unfinalized_proofs : 'unfinalized_proofs\n (** A vector of the \"per-proof\" structures defined above, one for each proof\n that the step-circuit partially verifies. *)\n ; messages_for_next_step_proof : 'messages_for_next_step_proof\n (** The component of the proof accumulation state that is only computed on by the\n \"stepping\" proof system, and that can be handled opaquely by any \"wrap\" circuits. *)\n }\n [@@deriving sexp, compare, yojson, hlist]\n\n let spec unfinalized_proofs messages_for_next_step_proof =\n Spec.T.Struct [ unfinalized_proofs; messages_for_next_step_proof ]\n\n include struct\n open Hlist.HlistId\n\n let _to_data { unfinalized_proofs; messages_for_next_step_proof } =\n [ Vector.map unfinalized_proofs ~f:Per_proof.In_circuit.to_data\n ; messages_for_next_step_proof\n ]\n\n let _of_data [ unfinalized_proofs; messages_for_next_step_proof ] =\n { unfinalized_proofs =\n Vector.map unfinalized_proofs ~f:Per_proof.In_circuit.of_data\n ; messages_for_next_step_proof\n }\n end [@@warning \"-45\"]\n\n let[@warning \"-60\"] typ (type n f)\n ( (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n as impl ) ~assert_16_bits\n (proofs_verified : (Opt.Flag.t Plonk_types.Features.t, n) Vector.t) fq :\n ( ((_, _) Vector.t, _) t\n , ((_, _) Vector.t, _) t\n , _ )\n Snarky_backendless.Typ.t =\n let per_proof _ = Per_proof.typ impl fq ~assert_16_bits in\n let unfinalized_proofs =\n Vector.typ' (Vector.map proofs_verified ~f:per_proof)\n in\n let messages_for_next_step_proof =\n Spec.typ impl fq ~assert_16_bits (B Spec.Digest)\n in\n Snarky_backendless.Typ.of_hlistable\n [ unfinalized_proofs; messages_for_next_step_proof ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n module Statement = struct\n type ( 'unfinalized_proofs\n , 'messages_for_next_step_proof\n , 'messages_for_next_wrap_proof )\n t =\n { proof_state :\n ('unfinalized_proofs, 'messages_for_next_step_proof) Proof_state.t\n ; messages_for_next_wrap_proof : 'messages_for_next_wrap_proof\n (** The component of the proof accumulation state that is only computed on by the\n \"wrapping\" proof system, and that can be handled opaquely by any \"step\" circuits. *)\n }\n [@@deriving sexp, compare, yojson]\n\n let[@warning \"-45\"] to_data\n { proof_state = { unfinalized_proofs; messages_for_next_step_proof }\n ; messages_for_next_wrap_proof\n } =\n let open Hlist.HlistId in\n [ Vector.map unfinalized_proofs\n ~f:Proof_state.Per_proof.In_circuit.to_data\n ; messages_for_next_step_proof\n ; messages_for_next_wrap_proof\n ]\n\n let[@warning \"-45\"] of_data\n Hlist.HlistId.\n [ unfinalized_proofs\n ; messages_for_next_step_proof\n ; messages_for_next_wrap_proof\n ] =\n { proof_state =\n { unfinalized_proofs =\n Vector.map unfinalized_proofs\n ~f:Proof_state.Per_proof.In_circuit.of_data\n ; messages_for_next_step_proof\n }\n ; messages_for_next_wrap_proof\n }\n\n let spec proofs_verified bp_log2 =\n let per_proof = Proof_state.Per_proof.In_circuit.spec bp_log2 in\n Spec.T.Struct\n [ Vector (per_proof, proofs_verified)\n ; B Digest\n ; Vector (B Digest, proofs_verified)\n ]\n end\nend\n\nmodule Nvector = Vector.With_length\nmodule Wrap_bp_vec = Backend.Tock.Rounds_vector\nmodule Step_bp_vec = Backend.Tick.Rounds_vector\n\nmodule Challenges_vector = struct\n type 'n t =\n (Backend.Tock.Field.t Snarky_backendless.Cvar.t Wrap_bp_vec.t, 'n) Vector.t\n\n module Constant = struct\n type 'n t = (Backend.Tock.Field.t Wrap_bp_vec.t, 'n) Vector.t\n end\nend\n","(* This file is generated by gen_scalars/gen_scalars.exe. *)\n\n(* turn off fragile pattern-matching warning from sexp ppx *)\n[@@@warning \"-4\"]\n\ntype curr_or_next = Curr | Next [@@deriving hash, eq, compare, sexp]\n\nmodule Gate_type = struct\n module T = struct\n type t = Kimchi_types.gate_type =\n | Zero\n | Generic\n | Poseidon\n | CompleteAdd\n | VarBaseMul\n | EndoMul\n | EndoMulScalar\n | Lookup\n | CairoClaim\n | CairoInstruction\n | CairoFlags\n | CairoTransition\n | RangeCheck0\n | RangeCheck1\n | ForeignFieldAdd\n | ForeignFieldMul\n | Xor16\n | Rot64\n [@@deriving hash, eq, compare, sexp]\n end\n\n include Core_kernel.Hashable.Make (T)\n include T\nend\n\nmodule Lookup_pattern = struct\n module T = struct\n type t = Kimchi_types.lookup_pattern =\n | Xor\n | Lookup\n | RangeCheck\n | ForeignFieldMul\n [@@deriving hash, eq, compare, sexp]\n end\n\n include Core_kernel.Hashable.Make (T)\n include T\nend\n\nmodule Column = struct\n open Core_kernel\n\n module T = struct\n type t =\n | Witness of int\n | Index of Gate_type.t\n | Coefficient of int\n | LookupTable\n | LookupSorted of int\n | LookupAggreg\n | LookupKindIndex of Lookup_pattern.t\n | LookupRuntimeSelector\n | LookupRuntimeTable\n [@@deriving hash, eq, compare, sexp]\n end\n\n include Hashable.Make (T)\n include T\nend\n\nopen Gate_type\nopen Column\n\nmodule Env = struct\n type 'a t =\n { add : 'a -> 'a -> 'a\n ; sub : 'a -> 'a -> 'a\n ; mul : 'a -> 'a -> 'a\n ; pow : 'a * int -> 'a\n ; square : 'a -> 'a\n ; zk_polynomial : 'a\n ; omega_to_minus_3 : 'a\n ; zeta_to_n_minus_1 : 'a\n ; var : Column.t * curr_or_next -> 'a\n ; field : string -> 'a\n ; cell : 'a -> 'a\n ; alpha_pow : int -> 'a\n ; double : 'a -> 'a\n ; endo_coefficient : 'a\n ; mds : int * int -> 'a\n ; srs_length_log2 : int\n ; vanishes_on_zero_knowledge_and_previous_rows : 'a\n ; joint_combiner : 'a\n ; beta : 'a\n ; gamma : 'a\n ; unnormalized_lagrange_basis : int -> 'a\n ; if_feature : Kimchi_types.feature_flag * (unit -> 'a) * (unit -> 'a) -> 'a\n }\nend\n\nmodule type S = sig\n val constant_term : 'a Env.t -> 'a\n\n val index_terms : 'a Env.t -> 'a Lazy.t Column.Table.t\nend\n\n(* The constraints are basically the same, but the literals in them differ. *)\nmodule Tick : S = struct\n let constant_term (type a)\n ({ add = ( + )\n ; sub = ( - )\n ; mul = ( * )\n ; square\n ; mds\n ; endo_coefficient\n ; pow\n ; var\n ; field\n ; cell\n ; alpha_pow\n ; double\n ; zk_polynomial = _\n ; omega_to_minus_3 = _\n ; zeta_to_n_minus_1 = _\n ; srs_length_log2 = _\n ; vanishes_on_zero_knowledge_and_previous_rows\n ; joint_combiner\n ; beta\n ; gamma\n ; unnormalized_lagrange_basis\n ; if_feature\n } :\n a Env.t ) =\n let x_0 = pow (cell (var (Witness 0, Curr)), 7) in\n let x_1 = pow (cell (var (Witness 1, Curr)), 7) in\n let x_2 = pow (cell (var (Witness 2, Curr)), 7) in\n let x_3 = pow (cell (var (Witness 6, Curr)), 7) in\n let x_4 = pow (cell (var (Witness 7, Curr)), 7) in\n let x_5 = pow (cell (var (Witness 8, Curr)), 7) in\n let x_6 = pow (cell (var (Witness 9, Curr)), 7) in\n let x_7 = pow (cell (var (Witness 10, Curr)), 7) in\n let x_8 = pow (cell (var (Witness 11, Curr)), 7) in\n let x_9 = pow (cell (var (Witness 12, Curr)), 7) in\n let x_10 = pow (cell (var (Witness 13, Curr)), 7) in\n let x_11 = pow (cell (var (Witness 14, Curr)), 7) in\n let x_12 = pow (cell (var (Witness 3, Curr)), 7) in\n let x_13 = pow (cell (var (Witness 4, Curr)), 7) in\n let x_14 = pow (cell (var (Witness 5, Curr)), 7) in\n let x_15 = cell (var (Witness 7, Next)) * cell (var (Witness 7, Next)) in\n let x_16 =\n let x_15 = cell (var (Witness 7, Next)) * cell (var (Witness 7, Next)) in\n cell (var (Witness 2, Curr))\n - (x_15 - cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_17 =\n let x_16 =\n let x_15 =\n cell (var (Witness 7, Next)) * cell (var (Witness 7, Next))\n in\n cell (var (Witness 2, Curr))\n - (x_15 - cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 3, Curr)))\n - (x_16 * cell (var (Witness 7, Next)))\n in\n let x_18 = cell (var (Witness 8, Next)) * cell (var (Witness 8, Next)) in\n let x_19 =\n let x_18 = cell (var (Witness 8, Next)) * cell (var (Witness 8, Next)) in\n cell (var (Witness 7, Curr))\n - (x_18 - cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_20 =\n let x_19 =\n let x_18 =\n cell (var (Witness 8, Next)) * cell (var (Witness 8, Next))\n in\n cell (var (Witness 7, Curr))\n - (x_18 - cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 8, Curr)))\n - (x_19 * cell (var (Witness 8, Next)))\n in\n let x_21 = cell (var (Witness 9, Next)) * cell (var (Witness 9, Next)) in\n let x_22 =\n let x_21 = cell (var (Witness 9, Next)) * cell (var (Witness 9, Next)) in\n cell (var (Witness 9, Curr))\n - (x_21 - cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_23 =\n let x_22 =\n let x_21 =\n cell (var (Witness 9, Next)) * cell (var (Witness 9, Next))\n in\n cell (var (Witness 9, Curr))\n - (x_21 - cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 10, Curr)))\n - (x_22 * cell (var (Witness 9, Next)))\n in\n let x_24 = cell (var (Witness 10, Next)) * cell (var (Witness 10, Next)) in\n let x_25 =\n let x_24 =\n cell (var (Witness 10, Next)) * cell (var (Witness 10, Next))\n in\n cell (var (Witness 11, Curr))\n - (x_24 - cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_26 =\n let x_25 =\n let x_24 =\n cell (var (Witness 10, Next)) * cell (var (Witness 10, Next))\n in\n cell (var (Witness 11, Curr))\n - (x_24 - cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 12, Curr)))\n - (x_25 * cell (var (Witness 10, Next)))\n in\n let x_27 = cell (var (Witness 11, Next)) * cell (var (Witness 11, Next)) in\n let x_28 =\n let x_27 =\n cell (var (Witness 11, Next)) * cell (var (Witness 11, Next))\n in\n cell (var (Witness 13, Curr))\n - (x_27 - cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_29 =\n let x_28 =\n let x_27 =\n cell (var (Witness 11, Next)) * cell (var (Witness 11, Next))\n in\n cell (var (Witness 13, Curr))\n - (x_27 - cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 14, Curr)))\n - (x_28 * cell (var (Witness 11, Next)))\n in\n let x_30 = cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)) in\n let x_31 = cell (var (Witness 3, Curr)) - cell (var (Witness 1, Curr)) in\n let x_32 = cell (var (Witness 0, Curr)) * cell (var (Witness 0, Curr)) in\n let x_33 =\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + cell (var (Witness 11, Curr))\n * ( endo_coefficient\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n * cell (var (Witness 0, Curr))\n in\n let x_34 =\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + cell (var (Witness 13, Curr))\n * ( endo_coefficient\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n * cell (var (Witness 0, Curr))\n in\n let x_35 = square (cell (var (Witness 9, Curr))) in\n let x_36 = square (cell (var (Witness 10, Curr))) in\n let x_37 = cell (var (Witness 4, Curr)) - cell (var (Witness 7, Curr)) in\n let x_38 = cell (var (Witness 7, Curr)) - cell (var (Witness 4, Next)) in\n let x_39 = cell (var (Witness 5, Next)) + cell (var (Witness 8, Curr)) in\n let x_40 = cell (var (Witness 8, Curr)) + cell (var (Witness 5, Curr)) in\n let x_41 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 6, Curr))\n in\n let x_42 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 7, Curr))\n in\n let x_43 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 8, Curr))\n in\n let x_44 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 9, Curr))\n in\n let x_45 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 10, Curr))\n in\n let x_46 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 11, Curr))\n in\n let x_47 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 12, Curr))\n in\n let x_48 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 13, Curr))\n in\n cell (var (Index Poseidon, Curr))\n * ( cell (var (Witness 6, Curr))\n - ( cell (var (Coefficient 0, Curr))\n + (mds (0, 0) * x_0)\n + (mds (0, 1) * x_1)\n + (mds (0, 2) * x_2) )\n + alpha_pow 1\n * ( cell (var (Witness 7, Curr))\n - ( cell (var (Coefficient 1, Curr))\n + (mds (1, 0) * x_0)\n + (mds (1, 1) * x_1)\n + (mds (1, 2) * x_2) ) )\n + alpha_pow 2\n * ( cell (var (Witness 8, Curr))\n - ( cell (var (Coefficient 2, Curr))\n + (mds (2, 0) * x_0)\n + (mds (2, 1) * x_1)\n + (mds (2, 2) * x_2) ) )\n + alpha_pow 3\n * ( cell (var (Witness 9, Curr))\n - ( cell (var (Coefficient 3, Curr))\n + (mds (0, 0) * x_3)\n + (mds (0, 1) * x_4)\n + (mds (0, 2) * x_5) ) )\n + alpha_pow 4\n * ( cell (var (Witness 10, Curr))\n - ( cell (var (Coefficient 4, Curr))\n + (mds (1, 0) * x_3)\n + (mds (1, 1) * x_4)\n + (mds (1, 2) * x_5) ) )\n + alpha_pow 5\n * ( cell (var (Witness 11, Curr))\n - ( cell (var (Coefficient 5, Curr))\n + (mds (2, 0) * x_3)\n + (mds (2, 1) * x_4)\n + (mds (2, 2) * x_5) ) )\n + alpha_pow 6\n * ( cell (var (Witness 12, Curr))\n - ( cell (var (Coefficient 6, Curr))\n + (mds (0, 0) * x_6)\n + (mds (0, 1) * x_7)\n + (mds (0, 2) * x_8) ) )\n + alpha_pow 7\n * ( cell (var (Witness 13, Curr))\n - ( cell (var (Coefficient 7, Curr))\n + (mds (1, 0) * x_6)\n + (mds (1, 1) * x_7)\n + (mds (1, 2) * x_8) ) )\n + alpha_pow 8\n * ( cell (var (Witness 14, Curr))\n - ( cell (var (Coefficient 8, Curr))\n + (mds (2, 0) * x_6)\n + (mds (2, 1) * x_7)\n + (mds (2, 2) * x_8) ) )\n + alpha_pow 9\n * ( cell (var (Witness 3, Curr))\n - ( cell (var (Coefficient 9, Curr))\n + (mds (0, 0) * x_9)\n + (mds (0, 1) * x_10)\n + (mds (0, 2) * x_11) ) )\n + alpha_pow 10\n * ( cell (var (Witness 4, Curr))\n - ( cell (var (Coefficient 10, Curr))\n + (mds (1, 0) * x_9)\n + (mds (1, 1) * x_10)\n + (mds (1, 2) * x_11) ) )\n + alpha_pow 11\n * ( cell (var (Witness 5, Curr))\n - ( cell (var (Coefficient 11, Curr))\n + (mds (2, 0) * x_9)\n + (mds (2, 1) * x_10)\n + (mds (2, 2) * x_11) ) )\n + alpha_pow 12\n * ( cell (var (Witness 0, Next))\n - ( cell (var (Coefficient 12, Curr))\n + (mds (0, 0) * x_12)\n + (mds (0, 1) * x_13)\n + (mds (0, 2) * x_14) ) )\n + alpha_pow 13\n * ( cell (var (Witness 1, Next))\n - ( cell (var (Coefficient 13, Curr))\n + (mds (1, 0) * x_12)\n + (mds (1, 1) * x_13)\n + (mds (1, 2) * x_14) ) )\n + alpha_pow 14\n * ( cell (var (Witness 2, Next))\n - ( cell (var (Coefficient 14, Curr))\n + (mds (2, 0) * x_12)\n + (mds (2, 1) * x_13)\n + (mds (2, 2) * x_14) ) ) )\n + cell (var (Index VarBaseMul, Curr))\n * ( cell (var (Witness 5, Curr))\n - ( cell (var (Witness 6, Next))\n + double\n ( cell (var (Witness 5, Next))\n + double\n ( cell (var (Witness 4, Next))\n + double\n ( cell (var (Witness 3, Next))\n + double\n ( cell (var (Witness 2, Next))\n + double (cell (var (Witness 4, Curr))) ) ) ) ) )\n + alpha_pow 1\n * ( square (cell (var (Witness 2, Next)))\n - cell (var (Witness 2, Next)) )\n + alpha_pow 2\n * ( (cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 7, Next))\n - ( cell (var (Witness 3, Curr))\n - ( double (cell (var (Witness 2, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 3\n * ( (x_17 * x_17)\n - x_16 * x_16\n * ( cell (var (Witness 7, Curr))\n - cell (var (Witness 0, Curr))\n + x_15 ) )\n + alpha_pow 4\n * ( (cell (var (Witness 8, Curr)) + cell (var (Witness 3, Curr)))\n * x_16\n - (cell (var (Witness 2, Curr)) - cell (var (Witness 7, Curr)))\n * x_17 )\n + alpha_pow 5\n * ( square (cell (var (Witness 3, Next)))\n - cell (var (Witness 3, Next)) )\n + alpha_pow 6\n * ( (cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 8, Next))\n - ( cell (var (Witness 8, Curr))\n - ( double (cell (var (Witness 3, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 7\n * ( (x_20 * x_20)\n - x_19 * x_19\n * ( cell (var (Witness 9, Curr))\n - cell (var (Witness 0, Curr))\n + x_18 ) )\n + alpha_pow 8\n * ( (cell (var (Witness 10, Curr)) + cell (var (Witness 8, Curr)))\n * x_19\n - (cell (var (Witness 7, Curr)) - cell (var (Witness 9, Curr)))\n * x_20 )\n + alpha_pow 9\n * ( square (cell (var (Witness 4, Next)))\n - cell (var (Witness 4, Next)) )\n + alpha_pow 10\n * ( (cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 9, Next))\n - ( cell (var (Witness 10, Curr))\n - ( double (cell (var (Witness 4, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 11\n * ( (x_23 * x_23)\n - x_22 * x_22\n * ( cell (var (Witness 11, Curr))\n - cell (var (Witness 0, Curr))\n + x_21 ) )\n + alpha_pow 12\n * ( (cell (var (Witness 12, Curr)) + cell (var (Witness 10, Curr)))\n * x_22\n - (cell (var (Witness 9, Curr)) - cell (var (Witness 11, Curr)))\n * x_23 )\n + alpha_pow 13\n * ( square (cell (var (Witness 5, Next)))\n - cell (var (Witness 5, Next)) )\n + alpha_pow 14\n * ( (cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 10, Next))\n - ( cell (var (Witness 12, Curr))\n - ( double (cell (var (Witness 5, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 15\n * ( (x_26 * x_26)\n - x_25 * x_25\n * ( cell (var (Witness 13, Curr))\n - cell (var (Witness 0, Curr))\n + x_24 ) )\n + alpha_pow 16\n * ( (cell (var (Witness 14, Curr)) + cell (var (Witness 12, Curr)))\n * x_25\n - (cell (var (Witness 11, Curr)) - cell (var (Witness 13, Curr)))\n * x_26 )\n + alpha_pow 17\n * ( square (cell (var (Witness 6, Next)))\n - cell (var (Witness 6, Next)) )\n + alpha_pow 18\n * ( (cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 11, Next))\n - ( cell (var (Witness 14, Curr))\n - ( double (cell (var (Witness 6, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 19\n * ( (x_29 * x_29)\n - x_28 * x_28\n * ( cell (var (Witness 0, Next))\n - cell (var (Witness 0, Curr))\n + x_27 ) )\n + alpha_pow 20\n * ( (cell (var (Witness 1, Next)) + cell (var (Witness 14, Curr)))\n * x_28\n - (cell (var (Witness 13, Curr)) - cell (var (Witness 0, Next)))\n * x_29 ) )\n + cell (var (Index CompleteAdd, Curr))\n * ( (cell (var (Witness 10, Curr)) * x_30)\n - ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n - cell (var (Witness 7, Curr)) )\n + (alpha_pow 1 * (cell (var (Witness 7, Curr)) * x_30))\n + alpha_pow 2\n * ( cell (var (Witness 7, Curr))\n * ( double (cell (var (Witness 8, Curr)))\n * cell (var (Witness 1, Curr))\n - double x_32 - x_32 )\n + ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n - cell (var (Witness 7, Curr)) )\n * ((x_30 * cell (var (Witness 8, Curr))) - x_31) )\n + alpha_pow 3\n * ( cell (var (Witness 0, Curr))\n + cell (var (Witness 2, Curr))\n + cell (var (Witness 4, Curr))\n - (cell (var (Witness 8, Curr)) * cell (var (Witness 8, Curr))) )\n + alpha_pow 4\n * ( cell (var (Witness 8, Curr))\n * (cell (var (Witness 0, Curr)) - cell (var (Witness 4, Curr)))\n - cell (var (Witness 1, Curr))\n - cell (var (Witness 5, Curr)) )\n + alpha_pow 5\n * ( x_31\n * (cell (var (Witness 7, Curr)) - cell (var (Witness 6, Curr))) )\n + alpha_pow 6\n * ( (x_31 * cell (var (Witness 9, Curr)))\n - cell (var (Witness 6, Curr)) ) )\n + cell (var (Index EndoMul, Curr))\n * ( square (cell (var (Witness 11, Curr)))\n - cell (var (Witness 11, Curr))\n + alpha_pow 1\n * ( square (cell (var (Witness 12, Curr)))\n - cell (var (Witness 12, Curr)) )\n + alpha_pow 2\n * ( square (cell (var (Witness 13, Curr)))\n - cell (var (Witness 13, Curr)) )\n + alpha_pow 3\n * ( square (cell (var (Witness 14, Curr)))\n - cell (var (Witness 14, Curr)) )\n + alpha_pow 4\n * ( (x_33 - cell (var (Witness 4, Curr)))\n * cell (var (Witness 9, Curr))\n - ( ( double (cell (var (Witness 12, Curr)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr))\n - cell (var (Witness 5, Curr)) ) )\n + alpha_pow 5\n * ( (double (cell (var (Witness 4, Curr))) - x_35 + x_33)\n * ((x_37 * cell (var (Witness 9, Curr))) + x_40)\n - (double (cell (var (Witness 5, Curr))) * x_37) )\n + alpha_pow 6\n * ( square x_40\n - (square x_37 * (x_35 - x_33 + cell (var (Witness 7, Curr)))) )\n + alpha_pow 7\n * ( (x_34 - cell (var (Witness 7, Curr)))\n * cell (var (Witness 10, Curr))\n - ( ( double (cell (var (Witness 14, Curr)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr))\n - cell (var (Witness 8, Curr)) ) )\n + alpha_pow 8\n * ( (double (cell (var (Witness 7, Curr))) - x_36 + x_34)\n * ((x_38 * cell (var (Witness 10, Curr))) + x_39)\n - (double (cell (var (Witness 8, Curr))) * x_38) )\n + alpha_pow 9\n * ( square x_39\n - (square x_38 * (x_36 - x_34 + cell (var (Witness 4, Next)))) )\n + alpha_pow 10\n * ( double\n ( double\n ( double\n ( double (cell (var (Witness 6, Curr)))\n + cell (var (Witness 11, Curr)) )\n + cell (var (Witness 12, Curr)) )\n + cell (var (Witness 13, Curr)) )\n + cell (var (Witness 14, Curr))\n - cell (var (Witness 6, Next)) ) )\n + cell (var (Index EndoMulScalar, Curr))\n * ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n (cell\n (var\n ( Witness 0\n , Curr ) ) ) )\n + cell\n (var\n (Witness 6, Curr) )\n ) )\n + cell (var (Witness 7, Curr))\n ) )\n + cell (var (Witness 8, Curr)) ) )\n + cell (var (Witness 9, Curr)) ) )\n + cell (var (Witness 10, Curr)) ) )\n + cell (var (Witness 11, Curr)) ) )\n + cell (var (Witness 12, Curr)) ) )\n + cell (var (Witness 13, Curr))\n - cell (var (Witness 1, Curr))\n + alpha_pow 1\n * ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double (cell (var (Witness 2, Curr)))\n + x_41 )\n + x_42 )\n + x_43 )\n + x_44 )\n + x_45 )\n + x_46 )\n + x_47 )\n + x_48\n - cell (var (Witness 4, Curr)) )\n + alpha_pow 2\n * ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double (cell (var (Witness 3, Curr)))\n + ( x_41\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_42\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_43\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_44\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_45\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_46\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_47\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_48\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) )\n - cell (var (Witness 5, Curr)) )\n + alpha_pow 3\n * ( ( ( ( cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 6, Curr)) )\n + alpha_pow 4\n * ( ( ( ( cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 7, Curr)) )\n + alpha_pow 5\n * ( ( ( ( cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 8, Curr)) )\n + alpha_pow 6\n * ( ( ( ( cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 9, Curr)) )\n + alpha_pow 7\n * ( ( ( ( cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 10, Curr)) )\n + alpha_pow 8\n * ( ( ( ( cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 11, Curr)) )\n + alpha_pow 9\n * ( ( ( ( cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 12, Curr)) )\n + alpha_pow 10\n * ( ( ( ( cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 13, Curr)) ) )\n + if_feature\n ( RangeCheck0\n , (fun () ->\n cell (var (Index RangeCheck0, Curr))\n * ( cell (var (Witness 7, Curr))\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n + alpha_pow 1\n * ( cell (var (Witness 8, Curr))\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 2\n * ( cell (var (Witness 9, Curr))\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 3\n * ( cell (var (Witness 10, Curr))\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 4\n * ( cell (var (Witness 11, Curr))\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 5\n * ( cell (var (Witness 12, Curr))\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 6\n * ( cell (var (Witness 13, Curr))\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 7\n * ( cell (var (Witness 14, Curr))\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 8\n * ( cell (var (Witness 14, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 5, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 4, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 3, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 2, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 1, Curr))\n - cell (var (Witness 0, Curr)) )\n + alpha_pow 9\n * ( cell (var (Coefficient 0, Curr))\n * ( cell (var (Witness 1, Next))\n - ( cell (var (Witness 0, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 0, Next)) ) ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( RangeCheck1\n , (fun () ->\n cell (var (Index RangeCheck1, Curr))\n * ( cell (var (Witness 2, Curr))\n * ( cell (var (Witness 2, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 2, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 2, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n + alpha_pow 1\n * ( cell (var (Witness 7, Curr))\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 2\n * ( cell (var (Witness 8, Curr))\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 3\n * ( cell (var (Witness 9, Curr))\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 4\n * ( cell (var (Witness 10, Curr))\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 5\n * ( cell (var (Witness 11, Curr))\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 6\n * ( cell (var (Witness 12, Curr))\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 7\n * ( cell (var (Witness 13, Curr))\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 8\n * ( cell (var (Witness 14, Curr))\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 9\n * ( cell (var (Witness 0, Next))\n * ( cell (var (Witness 0, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 0, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 0, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 10\n * ( cell (var (Witness 1, Next))\n * ( cell (var (Witness 1, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 1, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 1, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 11\n * ( cell (var (Witness 2, Next))\n * ( cell (var (Witness 2, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 2, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 2, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 12\n * ( cell (var (Witness 7, Next))\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 13\n * ( cell (var (Witness 8, Next))\n * ( cell (var (Witness 8, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 8, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 8, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 14\n * ( cell (var (Witness 9, Next))\n * ( cell (var (Witness 9, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 9, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 9, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 15\n * ( cell (var (Witness 10, Next))\n * ( cell (var (Witness 10, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 10, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 10, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 16\n * ( cell (var (Witness 11, Next))\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 17\n * ( cell (var (Witness 12, Next))\n * ( cell (var (Witness 12, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 12, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 12, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 18\n * ( cell (var (Witness 13, Next))\n * ( cell (var (Witness 13, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 13, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 13, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 19\n * ( cell (var (Witness 14, Next))\n * ( cell (var (Witness 14, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 14, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 14, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 20\n * ( cell (var (Witness 14, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 13, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 12, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 11, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 10, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 9, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 8, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 7, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 2, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 1, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 0, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 14, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 5, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 4, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 3, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 2, Curr))\n - cell (var (Witness 0, Curr)) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( ForeignFieldAdd\n , (fun () ->\n cell (var (Index ForeignFieldAdd, Curr))\n * ( cell (var (Witness 6, Curr))\n * ( cell (var (Witness 6, Curr))\n - cell (var (Coefficient 3, Curr)) )\n + alpha_pow 1\n * ( cell (var (Witness 7, Curr))\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n + alpha_pow 2\n * ( cell (var (Witness 0, Curr))\n + cell (var (Witness 1, Curr))\n * field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n + cell (var (Coefficient 3, Curr))\n * ( cell (var (Witness 3, Curr))\n + cell (var (Witness 4, Curr))\n * field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n )\n - cell (var (Witness 6, Curr))\n * ( cell (var (Coefficient 0, Curr))\n + cell (var (Coefficient 1, Curr))\n * field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n )\n - cell (var (Witness 7, Curr))\n * field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n - ( cell (var (Witness 0, Next))\n + cell (var (Witness 1, Next))\n * field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n ) )\n + alpha_pow 3\n * ( cell (var (Witness 2, Curr))\n + cell (var (Coefficient 3, Curr))\n * cell (var (Witness 5, Curr))\n - cell (var (Witness 6, Curr))\n * cell (var (Coefficient 2, Curr))\n + cell (var (Witness 7, Curr))\n - cell (var (Witness 2, Next)) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( ForeignFieldMul\n , (fun () ->\n cell (var (Index ForeignFieldMul, Curr))\n * ( cell (var (Witness 7, Next))\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n + alpha_pow 1\n * ( cell (var (Witness 11, Next))\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 2\n * ( (cell (var (Witness 0, Curr)) * cell (var (Witness 4, Curr)))\n + (cell (var (Witness 1, Curr)) * cell (var (Witness 3, Curr)))\n + cell (var (Witness 2, Next))\n * cell (var (Coefficient 2, Curr))\n + cell (var (Witness 3, Next))\n * cell (var (Coefficient 1, Curr))\n - ( field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * ( field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 7, Next))\n + cell (var (Witness 6, Next)) )\n + cell (var (Witness 6, Curr)) ) )\n + alpha_pow 3\n * ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 11, Next))\n - ( cell (var (Witness 0, Curr))\n * cell (var (Witness 3, Curr))\n + cell (var (Witness 2, Next))\n * cell (var (Coefficient 1, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 6, Curr))\n - cell (var (Witness 0, Next)) ) )\n + alpha_pow 4\n * ( ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 2, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 1, Curr))\n + cell (var (Witness 0, Curr)) )\n * ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 5, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 4, Curr))\n + cell (var (Witness 3, Curr)) )\n + ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 4, Next))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 3, Next))\n + cell (var (Witness 2, Next)) )\n * ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Coefficient 3, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Coefficient 2, Curr))\n + cell (var (Coefficient 1, Curr)) )\n - ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 1, Next))\n + cell (var (Witness 0, Next)) )\n - ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 4, Next))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 3, Next))\n + cell (var (Witness 2, Next)) )\n * field\n \"0x3FFFFFFFFFFFFFFFFFFFFFFFFFFFFF7707E2A8D6D5688AB6E4697CECFFFFFC01\"\n )\n + alpha_pow 5\n * ( cell (var (Witness 11, Curr))\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 6\n * ( cell (var (Witness 12, Curr))\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 7\n * ( cell (var (Witness 13, Curr))\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 8\n * ( square (cell (var (Witness 14, Curr)))\n - cell (var (Witness 14, Curr)) )\n + alpha_pow 9\n * ( field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * ( cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000001000000\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000001000000000\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000001000000000000\"\n * cell (var (Witness 8, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000001000000000000000\"\n * cell (var (Witness 9, Next))\n + field\n \"0x0000000000000000000000000000000000000000000001000000000000000000\"\n * cell (var (Witness 10, Next))\n + field\n \"0x0000000000000000000000000000000000000000001000000000000000000000\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000004000000000000000000000\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000040000000000000000000000\"\n * cell (var (Witness 14, Curr)) )\n - ( cell (var (Witness 0, Curr))\n * cell (var (Witness 5, Curr))\n + cell (var (Witness 2, Curr))\n * cell (var (Witness 3, Curr))\n + cell (var (Witness 1, Curr))\n * cell (var (Witness 4, Curr))\n + cell (var (Witness 2, Next))\n * cell (var (Coefficient 3, Curr))\n + cell (var (Witness 4, Next))\n * cell (var (Coefficient 1, Curr))\n + cell (var (Witness 3, Next))\n * cell (var (Coefficient 2, Curr))\n + ( field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 7, Next))\n + cell (var (Witness 6, Next)) )\n + cell (var (Witness 11, Next))\n - cell (var (Witness 1, Next)) ) )\n + alpha_pow 10\n * ( cell (var (Witness 5, Next))\n - ( cell (var (Witness 4, Next))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n - cell (var (Coefficient 0, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( Xor\n , (fun () ->\n cell (var (Index Xor16, Curr))\n * ( cell (var (Witness 3, Curr))\n + cell (var (Witness 4, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 4 )\n + cell (var (Witness 5, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 8 )\n + cell (var (Witness 6, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 12 )\n + pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 16 )\n * cell (var (Witness 0, Next))\n - cell (var (Witness 0, Curr))\n + alpha_pow 1\n * ( cell (var (Witness 7, Curr))\n + cell (var (Witness 8, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 4 )\n + cell (var (Witness 9, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 8 )\n + cell (var (Witness 10, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 12 )\n + pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 16 )\n * cell (var (Witness 1, Next))\n - cell (var (Witness 1, Curr)) )\n + alpha_pow 2\n * ( cell (var (Witness 11, Curr))\n + cell (var (Witness 12, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 4 )\n + cell (var (Witness 13, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 8 )\n + cell (var (Witness 14, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 12 )\n + pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 16 )\n * cell (var (Witness 2, Next))\n - cell (var (Witness 2, Curr)) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( Rot\n , (fun () ->\n cell (var (Index Rot64, Curr))\n * ( cell (var (Witness 7, Curr))\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n + alpha_pow 1\n * ( cell (var (Witness 8, Curr))\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 2\n * ( cell (var (Witness 9, Curr))\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 3\n * ( cell (var (Witness 10, Curr))\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 4\n * ( cell (var (Witness 11, Curr))\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 5\n * ( cell (var (Witness 12, Curr))\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 6\n * ( cell (var (Witness 13, Curr))\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 7\n * ( cell (var (Witness 14, Curr))\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 8\n * ( cell (var (Witness 0, Curr))\n * cell (var (Coefficient 0, Curr))\n - ( cell (var (Witness 2, Curr))\n * field\n \"0x0000000000000000000000000000000000000000000000010000000000000000\"\n + cell (var (Witness 0, Next)) ) )\n + alpha_pow 9\n * ( cell (var (Witness 1, Curr))\n - (cell (var (Witness 0, Next)) + cell (var (Witness 2, Curr)))\n )\n + alpha_pow 10\n * ( cell (var (Witness 14, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 5, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 4, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 3, Curr))\n - ( cell (var (Witness 2, Curr))\n - cell (var (Coefficient 0, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000010000000000000000\"\n ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + cell (var (Index Generic, Curr))\n * ( (cell (var (Coefficient 0, Curr)) * cell (var (Witness 0, Curr)))\n + (cell (var (Coefficient 1, Curr)) * cell (var (Witness 1, Curr)))\n + (cell (var (Coefficient 2, Curr)) * cell (var (Witness 2, Curr)))\n + cell (var (Coefficient 3, Curr))\n * cell (var (Witness 0, Curr))\n * cell (var (Witness 1, Curr))\n + cell (var (Coefficient 4, Curr))\n + alpha_pow 1\n * ( (cell (var (Coefficient 5, Curr)) * cell (var (Witness 3, Curr)))\n + (cell (var (Coefficient 6, Curr)) * cell (var (Witness 4, Curr)))\n + (cell (var (Coefficient 7, Curr)) * cell (var (Witness 5, Curr)))\n + cell (var (Coefficient 8, Curr))\n * cell (var (Witness 3, Curr))\n * cell (var (Witness 4, Curr))\n + cell (var (Coefficient 9, Curr)) ) )\n + if_feature\n ( LookupTables\n , (fun () ->\n alpha_pow 24\n * ( vanishes_on_zero_knowledge_and_previous_rows\n * ( cell (var (LookupAggreg, Next))\n * ( if_feature\n ( LookupsPerRow 0\n , (fun () ->\n gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupSorted 0, Curr))\n + (beta * cell (var (LookupSorted 0, Next))) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 1\n , (fun () ->\n gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupSorted 1, Next))\n + (beta * cell (var (LookupSorted 1, Curr))) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupSorted 2, Curr))\n + (beta * cell (var (LookupSorted 2, Next))) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupSorted 3, Next))\n + (beta * cell (var (LookupSorted 3, Curr))) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupSorted 4, Curr))\n + (beta * cell (var (LookupSorted 4, Next))) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n - cell (var (LookupAggreg, Curr))\n * ( ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n - ( if_feature\n ( LookupPattern Xor\n , (fun () ->\n cell (var (LookupKindIndex Xor, Curr)) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern Lookup\n , (fun () ->\n cell (var (LookupKindIndex Lookup, Curr)) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern RangeCheck\n , (fun () ->\n cell (var (LookupKindIndex RangeCheck, Curr))\n )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern ForeignFieldMul\n , (fun () ->\n cell\n (var\n (LookupKindIndex ForeignFieldMul, Curr) )\n )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n ) ) )\n * ( if_feature\n ( LookupsPerRow 1\n , (fun () -> gamma)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 2\n , (fun () -> gamma)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () -> gamma)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () -> gamma)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n + if_feature\n ( LookupPattern Xor\n , (fun () ->\n cell (var (LookupKindIndex Xor, Curr))\n * ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( gamma\n + ( joint_combiner\n * ( joint_combiner\n * cell (var (Witness 11, Curr))\n + cell (var (Witness 7, Curr)) )\n + cell (var (Witness 3, Curr)) ) )\n * ( gamma\n + ( joint_combiner\n * ( joint_combiner\n * cell (var (Witness 12, Curr))\n + cell (var (Witness 8, Curr)) )\n + cell (var (Witness 4, Curr)) ) )\n * ( gamma\n + ( joint_combiner\n * ( joint_combiner\n * cell (var (Witness 13, Curr))\n + cell (var (Witness 9, Curr)) )\n + cell (var (Witness 5, Curr)) ) )\n * ( gamma\n + ( joint_combiner\n * ( joint_combiner\n * cell (var (Witness 14, Curr))\n + cell (var (Witness 10, Curr)) )\n + cell (var (Witness 6, Curr)) ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern Lookup\n , (fun () ->\n cell (var (LookupKindIndex Lookup, Curr))\n * ( if_feature\n ( LookupsPerRow 4\n , (fun () -> gamma)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n * ( gamma\n + ( joint_combiner\n * cell (var (Witness 2, Curr))\n + cell (var (Witness 1, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 0, Curr)) ) )\n * ( gamma\n + ( joint_combiner\n * cell (var (Witness 4, Curr))\n + cell (var (Witness 3, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 0, Curr)) ) )\n * ( gamma\n + ( joint_combiner\n * cell (var (Witness 6, Curr))\n + cell (var (Witness 5, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 0, Curr)) ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern RangeCheck\n , (fun () ->\n cell (var (LookupKindIndex RangeCheck, Curr))\n * ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( gamma\n + ( cell (var (Witness 3, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 4, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 5, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 6, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern ForeignFieldMul\n , (fun () ->\n cell (var (LookupKindIndex ForeignFieldMul, Curr))\n * ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( gamma\n + ( cell (var (Witness 7, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 8, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 9, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 10, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n ) )\n * ( gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupTable, Curr))\n + (beta * cell (var (LookupTable, Next))) ) ) ) )\n + alpha_pow 25\n * ( unnormalized_lagrange_basis 0\n * ( cell (var (LookupAggreg, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n + alpha_pow 26\n * ( unnormalized_lagrange_basis (-4)\n * ( cell (var (LookupAggreg, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n + alpha_pow 27\n * if_feature\n ( LookupsPerRow 1\n , (fun () ->\n unnormalized_lagrange_basis (-4)\n * ( cell (var (LookupSorted 0, Curr))\n - cell (var (LookupSorted 1, Curr)) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + alpha_pow 28\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n unnormalized_lagrange_basis 0\n * ( cell (var (LookupSorted 1, Curr))\n - cell (var (LookupSorted 2, Curr)) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + alpha_pow 29\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n unnormalized_lagrange_basis (-4)\n * ( cell (var (LookupSorted 2, Curr))\n - cell (var (LookupSorted 3, Curr)) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + alpha_pow 30\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n unnormalized_lagrange_basis 0\n * ( cell (var (LookupSorted 3, Curr))\n - cell (var (LookupSorted 4, Curr)) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + alpha_pow 31\n * if_feature\n ( RuntimeLookupTables\n , (fun () ->\n cell (var (LookupRuntimeTable, Curr))\n * cell (var (LookupRuntimeSelector, Curr)) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n\n let index_terms (type a) (_ : a Env.t) = Column.Table.of_alist_exn []\nend\n\nmodule Tock : S = struct\n let constant_term (type a)\n ({ add = ( + )\n ; sub = ( - )\n ; mul = ( * )\n ; square\n ; mds\n ; endo_coefficient\n ; pow\n ; var\n ; field\n ; cell\n ; alpha_pow\n ; double\n ; zk_polynomial = _\n ; omega_to_minus_3 = _\n ; zeta_to_n_minus_1 = _\n ; srs_length_log2 = _\n ; vanishes_on_zero_knowledge_and_previous_rows = _\n ; joint_combiner = _\n ; beta = _\n ; gamma = _\n ; unnormalized_lagrange_basis = _\n ; if_feature = _\n } :\n a Env.t ) =\n let x_0 = pow (cell (var (Witness 0, Curr)), 7) in\n let x_1 = pow (cell (var (Witness 1, Curr)), 7) in\n let x_2 = pow (cell (var (Witness 2, Curr)), 7) in\n let x_3 = pow (cell (var (Witness 6, Curr)), 7) in\n let x_4 = pow (cell (var (Witness 7, Curr)), 7) in\n let x_5 = pow (cell (var (Witness 8, Curr)), 7) in\n let x_6 = pow (cell (var (Witness 9, Curr)), 7) in\n let x_7 = pow (cell (var (Witness 10, Curr)), 7) in\n let x_8 = pow (cell (var (Witness 11, Curr)), 7) in\n let x_9 = pow (cell (var (Witness 12, Curr)), 7) in\n let x_10 = pow (cell (var (Witness 13, Curr)), 7) in\n let x_11 = pow (cell (var (Witness 14, Curr)), 7) in\n let x_12 = pow (cell (var (Witness 3, Curr)), 7) in\n let x_13 = pow (cell (var (Witness 4, Curr)), 7) in\n let x_14 = pow (cell (var (Witness 5, Curr)), 7) in\n let x_15 = cell (var (Witness 7, Next)) * cell (var (Witness 7, Next)) in\n let x_16 =\n let x_15 = cell (var (Witness 7, Next)) * cell (var (Witness 7, Next)) in\n cell (var (Witness 2, Curr))\n - (x_15 - cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_17 =\n let x_16 =\n let x_15 =\n cell (var (Witness 7, Next)) * cell (var (Witness 7, Next))\n in\n cell (var (Witness 2, Curr))\n - (x_15 - cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 3, Curr)))\n - (x_16 * cell (var (Witness 7, Next)))\n in\n let x_18 = cell (var (Witness 8, Next)) * cell (var (Witness 8, Next)) in\n let x_19 =\n let x_18 = cell (var (Witness 8, Next)) * cell (var (Witness 8, Next)) in\n cell (var (Witness 7, Curr))\n - (x_18 - cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_20 =\n let x_19 =\n let x_18 =\n cell (var (Witness 8, Next)) * cell (var (Witness 8, Next))\n in\n cell (var (Witness 7, Curr))\n - (x_18 - cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 8, Curr)))\n - (x_19 * cell (var (Witness 8, Next)))\n in\n let x_21 = cell (var (Witness 9, Next)) * cell (var (Witness 9, Next)) in\n let x_22 =\n let x_21 = cell (var (Witness 9, Next)) * cell (var (Witness 9, Next)) in\n cell (var (Witness 9, Curr))\n - (x_21 - cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_23 =\n let x_22 =\n let x_21 =\n cell (var (Witness 9, Next)) * cell (var (Witness 9, Next))\n in\n cell (var (Witness 9, Curr))\n - (x_21 - cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 10, Curr)))\n - (x_22 * cell (var (Witness 9, Next)))\n in\n let x_24 = cell (var (Witness 10, Next)) * cell (var (Witness 10, Next)) in\n let x_25 =\n let x_24 =\n cell (var (Witness 10, Next)) * cell (var (Witness 10, Next))\n in\n cell (var (Witness 11, Curr))\n - (x_24 - cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_26 =\n let x_25 =\n let x_24 =\n cell (var (Witness 10, Next)) * cell (var (Witness 10, Next))\n in\n cell (var (Witness 11, Curr))\n - (x_24 - cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 12, Curr)))\n - (x_25 * cell (var (Witness 10, Next)))\n in\n let x_27 = cell (var (Witness 11, Next)) * cell (var (Witness 11, Next)) in\n let x_28 =\n let x_27 =\n cell (var (Witness 11, Next)) * cell (var (Witness 11, Next))\n in\n cell (var (Witness 13, Curr))\n - (x_27 - cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_29 =\n let x_28 =\n let x_27 =\n cell (var (Witness 11, Next)) * cell (var (Witness 11, Next))\n in\n cell (var (Witness 13, Curr))\n - (x_27 - cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 14, Curr)))\n - (x_28 * cell (var (Witness 11, Next)))\n in\n let x_30 = cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)) in\n let x_31 = cell (var (Witness 3, Curr)) - cell (var (Witness 1, Curr)) in\n let x_32 = cell (var (Witness 0, Curr)) * cell (var (Witness 0, Curr)) in\n let x_33 =\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + cell (var (Witness 11, Curr))\n * ( endo_coefficient\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n * cell (var (Witness 0, Curr))\n in\n let x_34 =\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + cell (var (Witness 13, Curr))\n * ( endo_coefficient\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n * cell (var (Witness 0, Curr))\n in\n let x_35 = square (cell (var (Witness 9, Curr))) in\n let x_36 = square (cell (var (Witness 10, Curr))) in\n let x_37 = cell (var (Witness 4, Curr)) - cell (var (Witness 7, Curr)) in\n let x_38 = cell (var (Witness 7, Curr)) - cell (var (Witness 4, Next)) in\n let x_39 = cell (var (Witness 5, Next)) + cell (var (Witness 8, Curr)) in\n let x_40 = cell (var (Witness 8, Curr)) + cell (var (Witness 5, Curr)) in\n let x_41 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 6, Curr))\n in\n let x_42 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 7, Curr))\n in\n let x_43 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 8, Curr))\n in\n let x_44 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 9, Curr))\n in\n let x_45 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 10, Curr))\n in\n let x_46 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 11, Curr))\n in\n let x_47 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 12, Curr))\n in\n let x_48 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 13, Curr))\n in\n cell (var (Index Poseidon, Curr))\n * ( cell (var (Witness 6, Curr))\n - ( cell (var (Coefficient 0, Curr))\n + (mds (0, 0) * x_0)\n + (mds (0, 1) * x_1)\n + (mds (0, 2) * x_2) )\n + alpha_pow 1\n * ( cell (var (Witness 7, Curr))\n - ( cell (var (Coefficient 1, Curr))\n + (mds (1, 0) * x_0)\n + (mds (1, 1) * x_1)\n + (mds (1, 2) * x_2) ) )\n + alpha_pow 2\n * ( cell (var (Witness 8, Curr))\n - ( cell (var (Coefficient 2, Curr))\n + (mds (2, 0) * x_0)\n + (mds (2, 1) * x_1)\n + (mds (2, 2) * x_2) ) )\n + alpha_pow 3\n * ( cell (var (Witness 9, Curr))\n - ( cell (var (Coefficient 3, Curr))\n + (mds (0, 0) * x_3)\n + (mds (0, 1) * x_4)\n + (mds (0, 2) * x_5) ) )\n + alpha_pow 4\n * ( cell (var (Witness 10, Curr))\n - ( cell (var (Coefficient 4, Curr))\n + (mds (1, 0) * x_3)\n + (mds (1, 1) * x_4)\n + (mds (1, 2) * x_5) ) )\n + alpha_pow 5\n * ( cell (var (Witness 11, Curr))\n - ( cell (var (Coefficient 5, Curr))\n + (mds (2, 0) * x_3)\n + (mds (2, 1) * x_4)\n + (mds (2, 2) * x_5) ) )\n + alpha_pow 6\n * ( cell (var (Witness 12, Curr))\n - ( cell (var (Coefficient 6, Curr))\n + (mds (0, 0) * x_6)\n + (mds (0, 1) * x_7)\n + (mds (0, 2) * x_8) ) )\n + alpha_pow 7\n * ( cell (var (Witness 13, Curr))\n - ( cell (var (Coefficient 7, Curr))\n + (mds (1, 0) * x_6)\n + (mds (1, 1) * x_7)\n + (mds (1, 2) * x_8) ) )\n + alpha_pow 8\n * ( cell (var (Witness 14, Curr))\n - ( cell (var (Coefficient 8, Curr))\n + (mds (2, 0) * x_6)\n + (mds (2, 1) * x_7)\n + (mds (2, 2) * x_8) ) )\n + alpha_pow 9\n * ( cell (var (Witness 3, Curr))\n - ( cell (var (Coefficient 9, Curr))\n + (mds (0, 0) * x_9)\n + (mds (0, 1) * x_10)\n + (mds (0, 2) * x_11) ) )\n + alpha_pow 10\n * ( cell (var (Witness 4, Curr))\n - ( cell (var (Coefficient 10, Curr))\n + (mds (1, 0) * x_9)\n + (mds (1, 1) * x_10)\n + (mds (1, 2) * x_11) ) )\n + alpha_pow 11\n * ( cell (var (Witness 5, Curr))\n - ( cell (var (Coefficient 11, Curr))\n + (mds (2, 0) * x_9)\n + (mds (2, 1) * x_10)\n + (mds (2, 2) * x_11) ) )\n + alpha_pow 12\n * ( cell (var (Witness 0, Next))\n - ( cell (var (Coefficient 12, Curr))\n + (mds (0, 0) * x_12)\n + (mds (0, 1) * x_13)\n + (mds (0, 2) * x_14) ) )\n + alpha_pow 13\n * ( cell (var (Witness 1, Next))\n - ( cell (var (Coefficient 13, Curr))\n + (mds (1, 0) * x_12)\n + (mds (1, 1) * x_13)\n + (mds (1, 2) * x_14) ) )\n + alpha_pow 14\n * ( cell (var (Witness 2, Next))\n - ( cell (var (Coefficient 14, Curr))\n + (mds (2, 0) * x_12)\n + (mds (2, 1) * x_13)\n + (mds (2, 2) * x_14) ) ) )\n + cell (var (Index VarBaseMul, Curr))\n * ( cell (var (Witness 5, Curr))\n - ( cell (var (Witness 6, Next))\n + double\n ( cell (var (Witness 5, Next))\n + double\n ( cell (var (Witness 4, Next))\n + double\n ( cell (var (Witness 3, Next))\n + double\n ( cell (var (Witness 2, Next))\n + double (cell (var (Witness 4, Curr))) ) ) ) ) )\n + alpha_pow 1\n * ( square (cell (var (Witness 2, Next)))\n - cell (var (Witness 2, Next)) )\n + alpha_pow 2\n * ( (cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 7, Next))\n - ( cell (var (Witness 3, Curr))\n - ( double (cell (var (Witness 2, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 3\n * ( (x_17 * x_17)\n - x_16 * x_16\n * ( cell (var (Witness 7, Curr))\n - cell (var (Witness 0, Curr))\n + x_15 ) )\n + alpha_pow 4\n * ( (cell (var (Witness 8, Curr)) + cell (var (Witness 3, Curr)))\n * x_16\n - (cell (var (Witness 2, Curr)) - cell (var (Witness 7, Curr)))\n * x_17 )\n + alpha_pow 5\n * ( square (cell (var (Witness 3, Next)))\n - cell (var (Witness 3, Next)) )\n + alpha_pow 6\n * ( (cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 8, Next))\n - ( cell (var (Witness 8, Curr))\n - ( double (cell (var (Witness 3, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 7\n * ( (x_20 * x_20)\n - x_19 * x_19\n * ( cell (var (Witness 9, Curr))\n - cell (var (Witness 0, Curr))\n + x_18 ) )\n + alpha_pow 8\n * ( (cell (var (Witness 10, Curr)) + cell (var (Witness 8, Curr)))\n * x_19\n - (cell (var (Witness 7, Curr)) - cell (var (Witness 9, Curr)))\n * x_20 )\n + alpha_pow 9\n * ( square (cell (var (Witness 4, Next)))\n - cell (var (Witness 4, Next)) )\n + alpha_pow 10\n * ( (cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 9, Next))\n - ( cell (var (Witness 10, Curr))\n - ( double (cell (var (Witness 4, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 11\n * ( (x_23 * x_23)\n - x_22 * x_22\n * ( cell (var (Witness 11, Curr))\n - cell (var (Witness 0, Curr))\n + x_21 ) )\n + alpha_pow 12\n * ( (cell (var (Witness 12, Curr)) + cell (var (Witness 10, Curr)))\n * x_22\n - (cell (var (Witness 9, Curr)) - cell (var (Witness 11, Curr)))\n * x_23 )\n + alpha_pow 13\n * ( square (cell (var (Witness 5, Next)))\n - cell (var (Witness 5, Next)) )\n + alpha_pow 14\n * ( (cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 10, Next))\n - ( cell (var (Witness 12, Curr))\n - ( double (cell (var (Witness 5, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 15\n * ( (x_26 * x_26)\n - x_25 * x_25\n * ( cell (var (Witness 13, Curr))\n - cell (var (Witness 0, Curr))\n + x_24 ) )\n + alpha_pow 16\n * ( (cell (var (Witness 14, Curr)) + cell (var (Witness 12, Curr)))\n * x_25\n - (cell (var (Witness 11, Curr)) - cell (var (Witness 13, Curr)))\n * x_26 )\n + alpha_pow 17\n * ( square (cell (var (Witness 6, Next)))\n - cell (var (Witness 6, Next)) )\n + alpha_pow 18\n * ( (cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 11, Next))\n - ( cell (var (Witness 14, Curr))\n - ( double (cell (var (Witness 6, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 19\n * ( (x_29 * x_29)\n - x_28 * x_28\n * ( cell (var (Witness 0, Next))\n - cell (var (Witness 0, Curr))\n + x_27 ) )\n + alpha_pow 20\n * ( (cell (var (Witness 1, Next)) + cell (var (Witness 14, Curr)))\n * x_28\n - (cell (var (Witness 13, Curr)) - cell (var (Witness 0, Next)))\n * x_29 ) )\n + cell (var (Index CompleteAdd, Curr))\n * ( (cell (var (Witness 10, Curr)) * x_30)\n - ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n - cell (var (Witness 7, Curr)) )\n + (alpha_pow 1 * (cell (var (Witness 7, Curr)) * x_30))\n + alpha_pow 2\n * ( cell (var (Witness 7, Curr))\n * ( double (cell (var (Witness 8, Curr)))\n * cell (var (Witness 1, Curr))\n - double x_32 - x_32 )\n + ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n - cell (var (Witness 7, Curr)) )\n * ((x_30 * cell (var (Witness 8, Curr))) - x_31) )\n + alpha_pow 3\n * ( cell (var (Witness 0, Curr))\n + cell (var (Witness 2, Curr))\n + cell (var (Witness 4, Curr))\n - (cell (var (Witness 8, Curr)) * cell (var (Witness 8, Curr))) )\n + alpha_pow 4\n * ( cell (var (Witness 8, Curr))\n * (cell (var (Witness 0, Curr)) - cell (var (Witness 4, Curr)))\n - cell (var (Witness 1, Curr))\n - cell (var (Witness 5, Curr)) )\n + alpha_pow 5\n * ( x_31\n * (cell (var (Witness 7, Curr)) - cell (var (Witness 6, Curr))) )\n + alpha_pow 6\n * ( (x_31 * cell (var (Witness 9, Curr)))\n - cell (var (Witness 6, Curr)) ) )\n + cell (var (Index EndoMul, Curr))\n * ( square (cell (var (Witness 11, Curr)))\n - cell (var (Witness 11, Curr))\n + alpha_pow 1\n * ( square (cell (var (Witness 12, Curr)))\n - cell (var (Witness 12, Curr)) )\n + alpha_pow 2\n * ( square (cell (var (Witness 13, Curr)))\n - cell (var (Witness 13, Curr)) )\n + alpha_pow 3\n * ( square (cell (var (Witness 14, Curr)))\n - cell (var (Witness 14, Curr)) )\n + alpha_pow 4\n * ( (x_33 - cell (var (Witness 4, Curr)))\n * cell (var (Witness 9, Curr))\n - ( ( double (cell (var (Witness 12, Curr)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr))\n - cell (var (Witness 5, Curr)) ) )\n + alpha_pow 5\n * ( (double (cell (var (Witness 4, Curr))) - x_35 + x_33)\n * ((x_37 * cell (var (Witness 9, Curr))) + x_40)\n - (double (cell (var (Witness 5, Curr))) * x_37) )\n + alpha_pow 6\n * ( square x_40\n - (square x_37 * (x_35 - x_33 + cell (var (Witness 7, Curr)))) )\n + alpha_pow 7\n * ( (x_34 - cell (var (Witness 7, Curr)))\n * cell (var (Witness 10, Curr))\n - ( ( double (cell (var (Witness 14, Curr)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr))\n - cell (var (Witness 8, Curr)) ) )\n + alpha_pow 8\n * ( (double (cell (var (Witness 7, Curr))) - x_36 + x_34)\n * ((x_38 * cell (var (Witness 10, Curr))) + x_39)\n - (double (cell (var (Witness 8, Curr))) * x_38) )\n + alpha_pow 9\n * ( square x_39\n - (square x_38 * (x_36 - x_34 + cell (var (Witness 4, Next)))) )\n + alpha_pow 10\n * ( double\n ( double\n ( double\n ( double (cell (var (Witness 6, Curr)))\n + cell (var (Witness 11, Curr)) )\n + cell (var (Witness 12, Curr)) )\n + cell (var (Witness 13, Curr)) )\n + cell (var (Witness 14, Curr))\n - cell (var (Witness 6, Next)) ) )\n + cell (var (Index EndoMulScalar, Curr))\n * ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n (cell\n (var\n ( Witness 0\n , Curr ) ) ) )\n + cell\n (var\n (Witness 6, Curr) )\n ) )\n + cell (var (Witness 7, Curr))\n ) )\n + cell (var (Witness 8, Curr)) ) )\n + cell (var (Witness 9, Curr)) ) )\n + cell (var (Witness 10, Curr)) ) )\n + cell (var (Witness 11, Curr)) ) )\n + cell (var (Witness 12, Curr)) ) )\n + cell (var (Witness 13, Curr))\n - cell (var (Witness 1, Curr))\n + alpha_pow 1\n * ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double (cell (var (Witness 2, Curr)))\n + x_41 )\n + x_42 )\n + x_43 )\n + x_44 )\n + x_45 )\n + x_46 )\n + x_47 )\n + x_48\n - cell (var (Witness 4, Curr)) )\n + alpha_pow 2\n * ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double (cell (var (Witness 3, Curr)))\n + ( x_41\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_42\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_43\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_44\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_45\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_46\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_47\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_48\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) )\n - cell (var (Witness 5, Curr)) )\n + alpha_pow 3\n * ( ( ( ( cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 6, Curr)) )\n + alpha_pow 4\n * ( ( ( ( cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 7, Curr)) )\n + alpha_pow 5\n * ( ( ( ( cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 8, Curr)) )\n + alpha_pow 6\n * ( ( ( ( cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 9, Curr)) )\n + alpha_pow 7\n * ( ( ( ( cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 10, Curr)) )\n + alpha_pow 8\n * ( ( ( ( cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 11, Curr)) )\n + alpha_pow 9\n * ( ( ( ( cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 12, Curr)) )\n + alpha_pow 10\n * ( ( ( ( cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 13, Curr)) ) )\n + cell (var (Index Generic, Curr))\n * ( (cell (var (Coefficient 0, Curr)) * cell (var (Witness 0, Curr)))\n + (cell (var (Coefficient 1, Curr)) * cell (var (Witness 1, Curr)))\n + (cell (var (Coefficient 2, Curr)) * cell (var (Witness 2, Curr)))\n + cell (var (Coefficient 3, Curr))\n * cell (var (Witness 0, Curr))\n * cell (var (Witness 1, Curr))\n + cell (var (Coefficient 4, Curr))\n + alpha_pow 1\n * ( (cell (var (Coefficient 5, Curr)) * cell (var (Witness 3, Curr)))\n + (cell (var (Coefficient 6, Curr)) * cell (var (Witness 4, Curr)))\n + (cell (var (Coefficient 7, Curr)) * cell (var (Witness 5, Curr)))\n + cell (var (Coefficient 8, Curr))\n * cell (var (Witness 3, Curr))\n * cell (var (Witness 4, Curr))\n + cell (var (Coefficient 9, Curr)) ) )\n\n let index_terms (type a) (_ : a Env.t) = Column.Table.of_alist_exn []\nend\n","let commit_id = \"[DIRTY]135a53e79bf45642d46cbda07cbc5e29ebc460a9\"\nlet commit_id_short = \"135a53e7\"\nlet branch = \"develop-20230927-temporary\"\nlet commit_date = \"2023-10-03T21:12:09+02:00\"\nlet marlin_commit_id = \"e54a121ad7eff0c510d38cde99425e3649cddc89\"\nlet marlin_commit_id_short = \"e54a121a\"\nlet marlin_commit_date = \"2023-09-27T17:29:38+02:00\"\nlet print_version () = Core_kernel.printf \"Commit %s on branch %s\\n%!\" commit_id branch\n","module Field_intf = struct\n module type Basic = sig\n type t\n\n val ( * ) : t -> t -> t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val inv_exn : t -> t\n\n val negate : t -> t\n\n val square : t -> t\n end\n\n module type Constant = sig\n include Basic\n end\n\n module type Checked = sig\n type field\n\n type bool\n\n include Basic\n\n val if_ : bool -> then_:t -> else_:t -> t\n\n val scale : t -> field -> t\n end\nend\n\nmodule type Constant_intf = sig\n type field\n\n type t\n\n val random : unit -> t\n\n val to_affine_exn : t -> field * field\n\n val of_affine : field * field -> t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\nend\n\nmodule type Inputs_intf = sig\n module Impl : Snarky_backendless.Snark_intf.Run\n\n module F : sig\n include\n Field_intf.Checked\n with type bool := Impl.Boolean.var\n and type field := Impl.field\n\n module Constant : Field_intf.Constant\n\n val assert_square : t -> t -> unit\n\n val assert_r1cs : t -> t -> t -> unit\n\n val typ : (t, Constant.t) Impl.Typ.t\n\n val constant : Constant.t -> t\n end\n\n module Constant : Constant_intf with type field := F.Constant.t\n\n module Params : sig\n val one : F.Constant.t * F.Constant.t\n\n val group_size_in_bits : int\n\n val a : F.Constant.t\n\n val b : F.Constant.t\n end\nend\n\nmodule Make_checked (Inputs : Inputs_intf) = struct\n open Inputs\n open Impl\n\n type t = F.t * F.t\n\n let double ((ax, ay) : t) : t =\n let open F in\n (* A: 1\n B: 1\n C: 1 *)\n let x_squared = square ax in\n let lambda =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n let x_squared = read typ x_squared in\n let ay = read typ ay in\n let open F.Constant in\n (x_squared + x_squared + x_squared + Params.a) * inv_exn (ay + ay))\n in\n let bx =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n let lambda = read typ lambda in\n let ax = read typ ax in\n let open F.Constant in\n square lambda - (ax + ax))\n in\n let by =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n let lambda = read typ lambda\n and ax = read typ ax\n and ay = read typ ay\n and bx = read typ bx in\n F.Constant.((lambda * (ax - bx)) - ay))\n in\n let two = Field.Constant.of_int 2 in\n (* A: 1\n B: 1\n C: 2 *)\n assert_r1cs (F.scale lambda two) ay\n (F.scale x_squared (Field.Constant.of_int 3) + F.constant Params.a) ;\n (* A: 1\n B: 1\n C: 2\n *)\n assert_square lambda (bx + F.scale ax two) ;\n (* A: 1\n B: 2\n C: 2\n *)\n assert_r1cs lambda (ax - bx) (by + ay) ;\n (* Overall:\n A: 4\n B: 5\n C: 7 *)\n (bx, by)\n\n let add' ~div (ax, ay) (bx, by) : t =\n let open F in\n (*\n lambda * (bx - ax) = (by - ay)\n\n A: 1\n B: 2\n C: 2\n *)\n let lambda = div (by - ay) (bx - ax) in\n let cx =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n let ax = read typ ax\n and bx = read typ bx\n and lambda = read typ lambda in\n Constant.(square lambda - (ax + bx)))\n in\n\n (* lambda^2 = cx + ax + bx\n\n A: 1\n B: 1\n C: 3\n *)\n assert_square lambda F.(cx + ax + bx) ;\n let cy =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n let ax = read typ ax\n and ay = read typ ay\n and cx = read typ cx\n and lambda = read typ lambda in\n Constant.((lambda * (ax - cx)) - ay))\n in\n (* A: 1\n B: 2\n C: 2 *)\n assert_r1cs lambda (ax - cx) (cy + ay) ;\n (* Overall\n A: 2\n B: 5\n C: 7 *)\n (cx, cy)\n\n let add_exn p q = add' ~div:(fun x y -> F.(inv_exn y * x)) p q\n\n let to_affine_exn x = x\n\n let constant t =\n let x, y = Constant.to_affine_exn t in\n (F.constant x, F.constant y)\n\n let negate (x, y) = (x, F.negate y)\n\n let one =\n let x, y = Params.one in\n F.(constant x, constant y)\n\n let assert_on_curve (x, y) =\n let open F in\n let x2 = square x in\n let x3 = x2 * x in\n let ax = constant Params.a * x in\n assert_square y (x3 + ax + constant Params.b)\n\n let typ_unchecked : (t, Constant.t) Typ.t =\n Typ.transport\n Typ.(tuple2 F.typ F.typ)\n ~there:Constant.to_affine_exn ~back:Constant.of_affine\n\n let typ : (t, Constant.t) Typ.t =\n let (Typ typ_unchecked) = typ_unchecked in\n Typ\n { typ_unchecked with\n check = (fun t -> Impl.make_checked (fun () -> assert_on_curve t))\n }\n\n let if_ c ~then_:(tx, ty) ~else_:(ex, ey) =\n (F.if_ c ~then_:tx ~else_:ex, F.if_ c ~then_:ty ~else_:ey)\n\n open Bitstring_lib.Bitstring\n\n module Scalar = struct\n type t = Boolean.var Lsb_first.t\n\n let of_field = Field.unpack_full\n\n let to_field t = Field.project (Lsb_first.to_list t)\n end\n\n module type Shifted_intf = sig\n type t\n\n val zero : t\n\n val unshift_nonzero : t -> F.t * F.t\n\n val add : t -> F.t * F.t -> t\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t\n end\n\n module Shifted (M : sig\n val shift : t\n end)\n () : Shifted_intf = struct\n type t = F.t * F.t\n\n let zero = M.shift\n\n let unshift_nonzero t = add_exn t (negate M.shift)\n\n let add t pt = add_exn t pt\n\n let if_ = if_\n end\n\n let shifted () =\n let shift = exists typ ~compute:(fun () -> Constant.random ()) in\n let module S =\n Shifted\n (struct\n let shift = shift\n end)\n ()\n in\n (module S : Shifted_intf)\n\n (* This doesn't have great performance because it uses add_exn. Should be optimized *)\n let scale ?init t (c : Boolean.var Bitstring_lib.Bitstring.Lsb_first.t) =\n let (module S) = shifted () in\n let c = Bitstring_lib.Bitstring.Lsb_first.to_list c in\n let rec go i bs0 acc pt =\n match bs0 with\n | [] ->\n acc\n | b :: bs ->\n let acc' =\n let add_pt = S.add acc pt in\n let don't_add_pt = acc in\n S.if_ b ~then_:add_pt ~else_:don't_add_pt\n and pt' = double pt in\n go (i + 1) bs acc' pt'\n in\n let init =\n match init with None -> S.zero | Some init -> S.(add zero init)\n in\n S.unshift_nonzero (go 0 c init t)\nend\n\nmodule type Native_base_field_inputs = sig\n (** Snarky instance to use. *)\n module Impl : Snarky_backendless.Snark_intf.Run\n\n include\n Inputs_intf\n with module Impl := Impl\n and type F.t = Impl.Field.t\n and type F.Constant.t = Impl.field\nend\n\nmodule For_native_base_field (Inputs : Native_base_field_inputs) = struct\n open Core_kernel\n open Inputs\n open Impl\n include Make_checked (Inputs)\n\n module Window_table = struct\n open Tuple_lib\n\n type t = Constant.t Quadruple.t array\n\n let window_size = 2\n\n let windows = (Params.group_size_in_bits + window_size - 1) / window_size\n\n let shift_left_by_window_size =\n let rec go i acc =\n if i = 0 then acc else go (i - 1) Constant.(acc + acc)\n in\n go window_size\n\n (* (create g).(i) = ( unrelated_base^i + 2^{window_size*i} 0 g, unrelated_base^i + 2^{window_size*i} g, unrelated_base^i + 2^{window_size*i} (2 g), unrelated_base^i + 2^{window_size*i} (3 g) ) *)\n let create ~shifts g =\n let pure_windows =\n (* pure_windows.(i) = 2^{window_size * i} ( g, 2 g, 3 g) *)\n let w0 =\n let g2 = Constant.(g + g) in\n let g3 = Constant.(g2 + g) in\n (g, g2, g3)\n in\n let a = Array.init windows ~f:(fun _ -> w0) in\n for i = 1 to windows - 1 do\n a.(i) <- Triple.map ~f:shift_left_by_window_size a.(i - 1)\n done ;\n a\n in\n Array.mapi pure_windows ~f:(fun i (a, b, c) ->\n let shift = shifts.(i) in\n Constant.(shift, shift + a, shift + b, shift + c) )\n end\n\n let pow2s g =\n let n = Window_table.windows + 1 in\n assert (n < Params.group_size_in_bits) ;\n let a = Array.init n ~f:(fun _ -> g) in\n for i = 1 to n - 1 do\n let x = a.(i - 1) in\n a.(i) <- Constant.(x + x)\n done ;\n a\n\n module Scaling_precomputation = struct\n type t =\n { base : Constant.t; shifts : Constant.t array; table : Window_table.t }\n\n let group_map =\n lazy\n (let params =\n Group_map.Params.create (module Field.Constant) Params.{ a; b }\n in\n Group_map.to_group (module Field.Constant) ~params )\n\n let string_to_bits s =\n List.concat_map (String.to_list s) ~f:(fun c ->\n let c = Char.to_int c in\n List.init 8 ~f:(fun i -> (c lsr i) land 1 = 1) )\n\n let create base =\n let unrelated_base =\n let x, y = Constant.to_affine_exn base in\n Digestif.BLAKE2S.digest_string\n Field.Constant.(to_string x ^ \",\" ^ to_string y)\n |> Digestif.BLAKE2S.to_raw_string |> string_to_bits\n |> Field.Constant.project |> Lazy.force group_map |> Constant.of_affine\n in\n let shifts = pow2s unrelated_base in\n { base; shifts; table = Window_table.create ~shifts base }\n end\n\n let add_unsafe =\n let div_unsafe x y =\n let z =\n exists Field.typ\n ~compute:\n As_prover.(fun () -> Field.Constant.( / ) (read_var x) (read_var y))\n in\n (* z = x / y <=> z * y = x *)\n assert_r1cs z y x ; z\n in\n add' ~div:div_unsafe\n\n let lookup_point (b0, b1) (t1, t2, t3, t4) =\n let b0_and_b1 = Boolean.( && ) b0 b1 in\n let lookup_one (a1, a2, a3, a4) =\n let open Field.Constant in\n let ( * ) x b = F.scale b x in\n let ( +^ ) = Field.( + ) in\n F.constant a1\n +^ ((a2 - a1) * (b0 :> Field.t))\n +^ ((a3 - a1) * (b1 :> Field.t))\n +^ ((a4 + a1 - a2 - a3) * (b0_and_b1 :> Field.t))\n in\n let x1, y1 = Constant.to_affine_exn t1\n and x2, y2 = Constant.to_affine_exn t2\n and x3, y3 = Constant.to_affine_exn t3\n and x4, y4 = Constant.to_affine_exn t4 in\n (* This is optimized for Marlin-style constraints. *)\n let seal a =\n let a' = exists Field.typ ~compute:(fun () -> As_prover.read_var a) in\n Field.Assert.equal a a' ; a'\n in\n (seal (lookup_one (x1, x2, x3, x4)), seal (lookup_one (y1, y2, y3, y4)))\n\n let rec pairs = function\n | [] ->\n []\n | x :: y :: xs ->\n (x, y) :: pairs xs\n | [ x ] ->\n [ (x, Boolean.false_) ]\n\n type shifted = { value : t; shift : Constant.t }\n\n let scale_known (pc : Scaling_precomputation.t) bs =\n let bs =\n let bs = Array.of_list bs in\n let num_bits = Array.length bs in\n Array.init\n ((Array.length bs + 1) / 2)\n ~f:(fun i ->\n let get j = if j < num_bits then bs.(j) else Boolean.false_ in\n (get (2 * i), get ((2 * i) + 1)) )\n in\n let windows_required = Array.length bs in\n let terms =\n Array.mapi bs ~f:(fun i bit_pair -> lookup_point bit_pair pc.table.(i))\n in\n let with_shifts = Array.reduce_exn terms ~f:add_unsafe in\n let shift =\n let unrelated_base = pc.shifts.(0) in\n\n (*\n 0b1111... * unrelated_base = (2^windows_required - 1) * unrelated_base\n\n is what we added and need to take away for the final result. *)\n Constant.(pc.shifts.(windows_required) + negate unrelated_base)\n in\n { value = with_shifts; shift }\n\n let unshift { value; shift } =\n add_exn value (constant (Constant.negate shift))\n\n let multiscale_known pairs =\n Array.map pairs ~f:(fun (s, g) -> scale_known g s)\n |> Array.reduce_exn ~f:(fun t1 t2 ->\n { value = add_exn t1.value t2.value\n ; shift = Constant.(t1.shift + t2.shift)\n } )\n |> unshift\n\n let scale_known pc bs = unshift (scale_known pc bs)\n\n (* b ? t : -t *)\n let conditional_negation (b : Boolean.var) (x, y) =\n let y' =\n exists Field.typ\n ~compute:\n As_prover.(\n fun () ->\n if read Boolean.typ b then read Field.typ y\n else Field.Constant.negate (read Field.typ y))\n in\n assert_r1cs y Field.((of_int 2 * (b :> Field.t)) - of_int 1) y' ;\n (x, y')\n\n let p_plus_q_plus_p ((x1, y1) : t) ((x2, y2) : t) =\n let open Field in\n let ( ! ) = As_prover.read typ in\n let lambda_1 =\n exists typ ~compute:Constant.(fun () -> (!y2 - !y1) / (!x2 - !x1))\n in\n let x3 =\n exists typ\n ~compute:Constant.(fun () -> (!lambda_1 * !lambda_1) - !x1 - !x2)\n in\n let lambda_2 =\n exists typ\n ~compute:Constant.(fun () -> (of_int 2 * !y1 / (!x1 - !x3)) - !lambda_1)\n in\n let x4 =\n exists typ\n ~compute:Constant.(fun () -> (!lambda_2 * !lambda_2) - !x3 - !x1)\n in\n let y4 =\n exists typ ~compute:Constant.(fun () -> ((!x1 - !x4) * !lambda_2) - !y1)\n in\n (* Determines lambda_1 *)\n assert_r1cs (x2 - x1) lambda_1 (y2 - y1) ;\n (* Determines x_3 *)\n assert_square lambda_1 (x1 + x2 + x3) ;\n (* Determines lambda_2 *)\n assert_r1cs (x1 - x3) (lambda_1 + lambda_2) (of_int 2 * y1) ;\n (* Determines x4 *)\n assert_square lambda_2 (x3 + x1 + x4) ;\n (* Determines y4 *)\n assert_r1cs (x1 - x4) lambda_2 (y4 + y1) ;\n (x4, y4)\n\n (* Input:\n t, r (LSB)\n\n Output:\n (2*r + 1 + 2^len(r)) t\n *)\n let scale_fast (t : Field.t * Field.t) (`Times_two_plus_1_plus_2_to_len r) :\n Field.t * Field.t =\n let n = Array.length r in\n let acc = ref (double t) in\n let () =\n for i = 0 to n - 1 do\n let q = conditional_negation r.(i) t in\n acc := p_plus_q_plus_p !acc q\n done\n in\n !acc\n\n (* Input:\n t, k (LSB)\n\n Output:\n (k + 2^{len(k) - 1}) t\n\n Based on [Daira's algorithm](https://github.com/zcash/zcash/issues/3924)\n *)\n let scale_fast t (`Plus_two_to_len_minus_1 k) =\n let m = Array.length k - 1 in\n let r = Array.init m ~f:(fun i -> k.(i + 1)) in\n let two_r_plus_1_plus_two_to_m =\n scale_fast t (`Times_two_plus_1_plus_2_to_len r)\n in\n if_ k.(0) ~then_:two_r_plus_1_plus_two_to_m\n ~else_:(add_exn two_r_plus_1_plus_two_to_m (negate t))\n\n let%test_unit \"scale_fast\" =\n let scale_constant (t, bs) =\n let rec go acc bs =\n match bs with\n | [] ->\n acc\n | b :: bs ->\n let acc = Constant.(acc + acc) in\n let acc = if b then Constant.(acc + t) else acc in\n go acc bs\n in\n let k = Array.length bs in\n go Constant.(t + negate t) (List.init k ~f:(fun i -> bs.(k - 1 - i)))\n in\n let module A = struct\n type t = Impl.Field.Constant.t * Impl.Field.Constant.t\n [@@deriving sexp, compare]\n end in\n let one = Constant.of_affine Params.one in\n [%test_eq: A.t]\n (Constant.to_affine_exn Constant.(one + negate one + one))\n Constant.(to_affine_exn one) ;\n [%test_eq: A.t]\n (Constant.to_affine_exn (scale_constant (one, [| true |])))\n Constant.(to_affine_exn one) ;\n [%test_eq: A.t]\n (Constant.to_affine_exn (scale_constant (one, [| false; true |])))\n Constant.(to_affine_exn (one + one)) ;\n [%test_eq: A.t]\n (Constant.to_affine_exn (scale_constant (one, [| true; true |])))\n Constant.(to_affine_exn (one + one + one)) ;\n [%test_eq: A.t]\n (Constant.to_affine_exn (scale_constant (one, [| false; false; true |])))\n Constant.(to_affine_exn (one + one + one + one)) ;\n [%test_eq: A.t]\n (Constant.to_affine_exn (scale_constant (one, [| true; false; true |])))\n Constant.(to_affine_exn (one + one + one + one + one)) ;\n let g = Typ.tuple2 Field.typ Field.typ in\n let two_to_the m =\n scale_constant (one, Array.init (m + 1) ~f:(fun i -> i = m))\n in\n [%test_eq: A.t]\n (Constant.to_affine_exn (two_to_the 2))\n Constant.(to_affine_exn (one + one + one + one)) ;\n let n = 4 in\n let bits = Array.init n ~f:(fun _ -> Random.bool ()) in\n Internal_Basic.Test.test_equal\n ~equal:[%eq: Field.Constant.t * Field.Constant.t]\n ~sexp_of_t:[%sexp_of: Field.Constant.t * Field.Constant.t]\n (Typ.tuple2 g (Typ.array ~length:n Boolean.typ))\n g\n (fun (t, bs) ->\n make_checked (fun () -> scale_fast t (`Plus_two_to_len_minus_1 bs)) )\n (fun (t, bs) ->\n let open Constant in\n let t = of_affine t in\n to_affine_exn (scale_constant (t, bs) + two_to_the (n - 1)) )\n (Params.one, bits)\nend\n","open Core_kernel\n\n(** The string that preceeds the JSON header, to identify the file kind before\n attempting to parse it.\n*)\nlet header_string = \"MINA_SNARK_KEYS\\n\"\n\nmodule UInt64 = struct\n (* [Unsigned_extended] depends on pickles, manually include what we need here\n to break a dependency cycle\n\n TODO: Separate [Unsigned_extended] into snark and non-snark parts.\n *)\n type t = Unsigned.UInt64.t [@@deriving ord, equal]\n\n let to_yojson x = `String (Unsigned.UInt64.to_string x)\n\n let of_yojson = function\n | `String x ->\n Or_error.try_with (fun () -> Unsigned.UInt64.of_string x)\n |> Result.map_error ~f:(fun err ->\n sprintf\n \"Snark_keys_header.UInt64.of_yojson: Could not parse string \\\n as UInt64: %s\"\n (Error.to_string_hum err) )\n | _ ->\n Error \"Snark_keys_header.UInt64.of_yojson: Expected a string\"\n\n let sexp_of_t x = Sexp.Atom (Unsigned.UInt64.to_string x)\n\n let t_of_sexp = function\n | Sexp.Atom x ->\n Unsigned.UInt64.of_string x\n | _ ->\n failwith \"Snark_keys_header.UInt64.t_of_sexp: Expected an atom\"\nend\n\nmodule Kind = struct\n (** The 'kind' of data in the file.\n For example, a step proving key for the base transaction snark may have the\n kind:\n{[\n {type_= \"step_proving_key\"; identifier= \"transaction_snark_base\"}\n|}\n *)\n type t =\n { type_ : string [@key \"type\"]\n (** Identifies the type of data that the file contains *)\n ; identifier : string\n (** Identifies the specific purpose of the file's data, in a\n human-readable format\n *)\n }\n [@@deriving yojson, sexp, ord, equal]\nend\n\nmodule Constraint_constants = struct\n module Transaction_capacity = struct\n (** Transaction pool capacity *)\n type t = Log_2 of int | Txns_per_second_x10 of int\n [@@deriving sexp, ord, equal]\n\n let to_yojson t : Yojson.Safe.t =\n match t with\n | Log_2 i ->\n `Assoc [ (\"two_to_the\", `Int i) ]\n | Txns_per_second_x10 i ->\n `Assoc [ (\"txns_per_second_x10\", `Int i) ]\n\n let of_yojson (json : Yojson.Safe.t) =\n match json with\n | `Assoc [ (\"two_to_the\", `Int i) ] ->\n Ok (Log_2 i)\n | `Assoc [ (\"txns_per_second_x10\", `Int i) ] ->\n Ok (Txns_per_second_x10 i)\n | `Assoc _ ->\n Error\n \"Snark_keys_header.Constraint_constants.Transaction_capacity.of_yojson: \\\n Expected a JSON object containing the field 'two_to_the' or \\\n 'txns_per_second_x10'\"\n | _ ->\n Error\n \"Snark_keys_header.Constraint_constants.Transaction_capacity.of_yojson: \\\n Expected a JSON object\"\n end\n\n module Fork_config = struct\n (** Fork data *)\n type t =\n { previous_state_hash : string\n ; previous_length : int\n ; genesis_slot : int\n }\n [@@deriving yojson, sexp, ord, equal]\n\n let opt_to_yojson t : Yojson.Safe.t =\n match t with Some t -> to_yojson t | None -> `Assoc []\n\n let opt_of_yojson (json : Yojson.Safe.t) =\n match json with\n | `Assoc [] ->\n Ok None\n | _ ->\n Result.map (of_yojson json) ~f:(fun t -> Some t)\n end\n\n (** The constants used in the constraint system. *)\n type t =\n { sub_windows_per_window : int\n ; ledger_depth : int\n ; work_delay : int\n ; block_window_duration_ms : int\n ; transaction_capacity : Transaction_capacity.t\n ; pending_coinbase_depth : int\n ; coinbase_amount : UInt64.t\n ; supercharged_coinbase_factor : int\n ; account_creation_fee : UInt64.t\n ; fork :\n (Fork_config.t option\n [@to_yojson Fork_config.opt_to_yojson]\n [@of_yojson Fork_config.opt_of_yojson] )\n }\n [@@deriving yojson, sexp, ord, equal]\nend\n\nmodule Commits = struct\n (** Commit identifiers *)\n type t = { mina : string; marlin : string }\n [@@deriving yojson, sexp, ord, equal]\nend\n\nlet header_version = 1\n\n(** Header contents *)\ntype t =\n { header_version : int\n ; kind : Kind.t\n ; constraint_constants : Constraint_constants.t\n ; commits : Commits.t\n ; length : int\n ; commit_date : string\n ; constraint_system_hash : string\n ; identifying_hash : string\n }\n[@@deriving yojson, sexp, ord, equal]\n\nlet prefix = \"MINA_SNARK_KEYS\\n\"\n\nlet prefix_len = String.length prefix\n\nlet parse_prefix (lexbuf : Lexing.lexbuf) =\n let open Or_error.Let_syntax in\n Result.map_error ~f:(fun err ->\n Error.tag_arg err \"Could not read prefix\" (\"prefix\", prefix)\n [%sexp_of: string * string] )\n @@ Or_error.try_with_join (fun () ->\n (* This roughly mirrors the behavior of [Yojson.Safe.read_ident],\n except that we have a known fixed length to parse, and that it is a\n failure to read any string except the prefix. We manually update\n the lexbuf to be consistent with the output of this function.\n *)\n (* Manually step the lexbuffer forward to the [lex_curr_pos], so that\n [refill_buf] will know that we're only interested in buffer\n contents from that position onwards.\n *)\n lexbuf.lex_start_pos <- lexbuf.lex_curr_pos ;\n lexbuf.lex_last_pos <- lexbuf.lex_curr_pos ;\n lexbuf.lex_start_p <- lexbuf.lex_curr_p ;\n let%bind () =\n (* Read more if the buffer doesn't contain the whole prefix. *)\n if lexbuf.lex_buffer_len - lexbuf.lex_curr_pos >= prefix_len then\n return ()\n else if lexbuf.lex_eof_reached then\n Or_error.error_string \"Unexpected end-of-file\"\n else (\n lexbuf.refill_buff lexbuf ;\n if lexbuf.lex_buffer_len - lexbuf.lex_curr_pos >= prefix_len then\n return ()\n else if lexbuf.lex_eof_reached then\n Or_error.error_string \"Unexpected end-of-file\"\n else\n Or_error.error_string\n \"Unexpected short read: broken lexbuffer or end-of-file\" )\n in\n let read_prefix =\n Lexing.sub_lexeme lexbuf lexbuf.lex_curr_pos\n (lexbuf.lex_curr_pos + prefix_len)\n in\n let%map () =\n if String.equal prefix read_prefix then return ()\n else\n Or_error.error \"Incorrect prefix\"\n (\"read prefix\", read_prefix)\n [%sexp_of: string * string]\n in\n (* Update the positions to match our end state *)\n lexbuf.lex_curr_pos <- lexbuf.lex_curr_pos + prefix_len ;\n lexbuf.lex_last_pos <- lexbuf.lex_last_pos ;\n lexbuf.lex_curr_p <-\n { lexbuf.lex_curr_p with\n pos_bol = lexbuf.lex_curr_p.pos_bol + prefix_len\n ; pos_cnum = lexbuf.lex_curr_p.pos_cnum + prefix_len\n } ;\n (* This matches the action given by [Yojson.Safe.read_ident]. *)\n lexbuf.lex_last_action <- 1 )\n\nlet parse_lexbuf (lexbuf : Lexing.lexbuf) =\n let open Or_error.Let_syntax in\n Result.map_error ~f:(Error.tag ~tag:\"Failed to read snark key header\")\n @@ let%bind () = parse_prefix lexbuf in\n Or_error.try_with (fun () ->\n let yojson_parsebuffer = Yojson.init_lexer () in\n (* We use [read_t] here rather than one of the alternatives to avoid\n 'greedy' parsing that will attempt to continue and read the file's\n contents beyond the header.\n *)\n Yojson.Safe.read_t yojson_parsebuffer lexbuf )\n\nlet%test_module \"Check parsing of header\" =\n ( module struct\n let valid_header =\n { header_version = 1\n ; kind = { type_ = \"type\"; identifier = \"identifier\" }\n ; constraint_constants =\n { sub_windows_per_window = 4\n ; ledger_depth = 8\n ; work_delay = 1000\n ; block_window_duration_ms = 1000\n ; transaction_capacity = Log_2 3\n ; pending_coinbase_depth = 12\n ; coinbase_amount = Unsigned.UInt64.of_int 1\n ; supercharged_coinbase_factor = 1\n ; account_creation_fee = Unsigned.UInt64.of_int 1\n ; fork = None\n }\n ; commits =\n { mina = \"7e1fb2cd9138af1d0f24e78477efd40a2a0fcd07\"\n ; marlin = \"75836c41fc4947acce9c938da1b2f506843e90ed\"\n }\n ; length = 4096\n ; commit_date = \"2020-01-01 00:00:00.000000Z\"\n ; constraint_system_hash = \"ABCDEF1234567890\"\n ; identifying_hash = \"ABCDEF1234567890\"\n }\n\n let valid_header_string = Yojson.Safe.to_string (to_yojson valid_header)\n\n let valid_header_with_prefix = prefix ^ valid_header_string\n\n module Tests (Lexing : sig\n val from_string : ?with_positions:bool -> string -> Lexing.lexbuf\n end) =\n struct\n let%test \"doesn't parse without prefix\" =\n parse_lexbuf (Lexing.from_string valid_header_string)\n |> Or_error.is_error\n\n let%test \"doesn't parse with incorrect prefix\" =\n parse_lexbuf (Lexing.from_string (\"BLAH\" ^ valid_header_string))\n |> Or_error.is_error\n\n let%test \"doesn't parse with matching-length prefix\" =\n let fake_prefix = String.init prefix_len ~f:(fun _ -> 'a') in\n parse_lexbuf (Lexing.from_string (fake_prefix ^ valid_header_string))\n |> Or_error.is_error\n\n let%test \"doesn't parse with partial matching prefix\" =\n let partial_prefix =\n String.sub prefix ~pos:0 ~len:(prefix_len - 1) ^ \" \"\n in\n parse_lexbuf (Lexing.from_string (partial_prefix ^ valid_header_string))\n |> Or_error.is_error\n\n let%test \"doesn't parse with short file\" =\n parse_lexbuf (Lexing.from_string \"BLAH\") |> Or_error.is_error\n\n let%test \"doesn't parse with prefix only\" =\n parse_lexbuf (Lexing.from_string prefix) |> Or_error.is_error\n\n let%test_unit \"parses valid header with prefix\" =\n parse_lexbuf (Lexing.from_string valid_header_with_prefix)\n |> Or_error.ok_exn |> ignore\n\n let%test_unit \"parses valid header with prefix and data\" =\n parse_lexbuf\n (Lexing.from_string (valid_header_with_prefix ^ \"DATADATADATA\"))\n |> Or_error.ok_exn |> ignore\n end\n\n let%test_module \"Parsing from the start of the lexbuf\" =\n (module Tests (Lexing))\n\n let%test_module \"Parsing from part-way through a lexbuf\" =\n ( module struct\n include Tests (struct\n let from_string ?with_positions:_ str =\n let prefix = \"AAAAAAAAAA\" in\n let prefix_len = String.length prefix in\n let lexbuf = Lexing.from_string (prefix ^ str) in\n lexbuf.lex_start_pos <- 0 ;\n lexbuf.lex_curr_pos <- prefix_len ;\n lexbuf.lex_last_pos <- prefix_len ;\n lexbuf\n end)\n end )\n\n let%test_module \"Parsing with refill\" =\n ( module struct\n include Tests (struct\n let from_string ?with_positions:_ str =\n let init = ref true in\n let initial_prefix = \"AAAAAAAAAA\" in\n let initial_prefix_len = String.length initial_prefix in\n let offset = ref 0 in\n let str_len = String.length str in\n let lexbuf =\n Lexing.from_function (fun buffer length ->\n match !init with\n | true ->\n init := false ;\n (* Initial read: fill with junk up to the first character\n of the actual prefix\n *)\n Bytes.From_string.blit ~src:initial_prefix ~src_pos:0\n ~dst:buffer ~dst_pos:0 ~len:initial_prefix_len ;\n Bytes.set buffer initial_prefix_len str.[0] ;\n offset := 1 ;\n initial_prefix_len + 1\n | false ->\n (* Subsequent read: fill the rest of the buffer. *)\n let len = Int.min length (str_len - !offset) in\n if len = 0 then 0\n else (\n Bytes.From_string.blit ~src:str ~src_pos:!offset\n ~dst:buffer ~dst_pos:0 ~len ;\n offset := !offset + len ;\n len ) )\n in\n (* Load the initial content into the buffer *)\n lexbuf.refill_buff lexbuf ;\n lexbuf.lex_start_pos <- 0 ;\n lexbuf.lex_curr_pos <- initial_prefix_len ;\n lexbuf.lex_last_pos <- initial_prefix_len ;\n lexbuf\n end)\n end )\n end )\n\nlet write_with_header ~expected_max_size_log2 ~append_data header filename =\n (* In order to write the correct length here, we provide the maximum expected\n size and store that in the initial header. Once the data has been written,\n we record the length and then modify the 'length' field to hold the\n correct data.\n Happily, since the header is JSON-encoded, we can pad the calculated\n length with spaces and the header will still form a valid JSON-encoded\n object.\n This intuitively feels hacky, but the only way this can fail are if we are\n not able to write all of our data to the filesystem, or if the file is\n modified during the writing process. In either of these cases, we would\n have the same issue even if we were to pre-compute the length and do the\n write atomically.\n *)\n let length = 1 lsl expected_max_size_log2 in\n if length <= 0 then\n failwith\n \"Snark_keys_header.write_header: expected_max_size_log2 is too large, \\\n the resulting length underflows\" ;\n let header_string =\n Yojson.Safe.to_string (to_yojson { header with length })\n in\n (* We look for the \"length\" field first, to ensure that we find our length\n and not some other data that happens to match it. Due to the\n JSON-encoding, we will only find the first field named \"length\", which is\n the one that we want to modify.\n *)\n let length_offset =\n String.substr_index_exn header_string ~pattern:\"\\\"length\\\":\"\n in\n let length_string = string_of_int length in\n let length_data_offset =\n prefix_len\n + String.substr_index_exn ~pos:length_offset header_string\n ~pattern:length_string\n in\n (* We use [binary=true] to ensure that line endings aren't converted, so that\n files can be used regardless of the operating system that generated them.\n *)\n Out_channel.with_file ~binary:true filename ~f:(fun out_channel ->\n Out_channel.output_string out_channel prefix ;\n Out_channel.output_string out_channel header_string ;\n (* Newline, to allow [head -n 2 path/to/file | tail -n 1] to easily\n extract the header.\n *)\n Out_channel.output_char out_channel '\\n' ) ;\n append_data filename ;\n (* Core doesn't let us open a file without appending or truncating, so we use\n stdlib instead.\n *)\n let out_channel =\n Stdlib.open_out_gen [ Open_wronly; Open_binary ] 0 filename\n in\n let true_length = Out_channel.length out_channel |> Int.of_int64_exn in\n if true_length > length then\n failwith\n \"Snark_keys_header.write_header: 2^expected_max_size_log2 is less than \\\n the true length of the file\" ;\n let true_length_string = string_of_int true_length in\n let true_length_padding =\n String.init\n (String.length length_string - String.length true_length_string)\n ~f:(fun _ -> ' ')\n in\n (* Go to where we wrote the data *)\n Out_channel.seek out_channel (Int64.of_int length_data_offset) ;\n (* Pad with spaces *)\n Out_channel.output_string out_channel true_length_padding ;\n (* Output the true length *)\n Out_channel.output_string out_channel true_length_string ;\n Out_channel.close out_channel\n\nlet read_with_header ~read_data filename =\n let open Or_error.Let_syntax in\n Or_error.try_with_join (fun () ->\n (* We use [binary=true] to ensure that line endings aren't converted. *)\n let in_channel = In_channel.create ~binary:true filename in\n let file_length = In_channel.length in_channel |> Int.of_int64_exn in\n let lexbuf = Lexing.from_channel in_channel in\n let%bind header_json = parse_lexbuf lexbuf in\n let%bind header =\n of_yojson header_json |> Result.map_error ~f:Error.of_string\n in\n let offset = lexbuf.lex_curr_pos in\n let%bind () =\n In_channel.seek in_channel (Int64.of_int offset) ;\n match In_channel.input_char in_channel with\n | Some '\\n' ->\n Ok ()\n | None ->\n Or_error.error_string\n \"Incomplete header: the newline terminator is missing\"\n | Some c ->\n Or_error.error \"Header was not terminated by a newline character\"\n (\"character\", c) [%sexp_of: string * char]\n in\n (* Bump offset for the newline terminator *)\n let offset = offset + 1 in\n In_channel.close in_channel ;\n let%bind () =\n if header.length = file_length then Ok ()\n else\n Or_error.error\n \"Header length didn't match file length. Was the file only \\\n partially downloaded?\"\n ((\"header length\", header.length), (\"file length\", file_length))\n [%sexp_of: (string * int) * (string * int)]\n in\n let%map data = Or_error.try_with (fun () -> read_data ~offset filename) in\n (header, data) )\n","open Base\n\nlet rec sexp_to_yojson (sexp : Sexp.t) : Yojson.Safe.t =\n match sexp with\n | Atom str ->\n `String str\n | List sexps ->\n `List (List.map ~f:sexp_to_yojson sexps)\n\nlet sexp_record_to_yojson (sexp : Sexp.t) : Yojson.Safe.t =\n let fail () =\n failwith\n (Printf.sprintf\n \"sexp_record_to_yojson called on an s-expression with a non-record \\\n structure %s\"\n (Sexp.to_string_hum sexp) )\n in\n match sexp with\n | List fields ->\n `Assoc\n (List.map fields ~f:(function\n | List [ Atom label; value ] ->\n (label, sexp_to_yojson value)\n | _ ->\n fail () ) )\n | _ ->\n fail ()\n\nlet rec sexp_of_yojson (json : Yojson.Safe.t) : (Sexp.t, string) Result.t =\n match json with\n | `String str ->\n Ok (Sexp.Atom str)\n | `List jsons ->\n let rev_sexps =\n List.fold_until ~init:[] jsons ~finish:Result.return\n ~f:(fun sexps json ->\n match sexp_of_yojson json with\n | Ok sexp ->\n Continue (sexp :: sexps)\n | Error str ->\n Stop (Error str) )\n in\n Result.map ~f:(fun l -> Sexp.List (List.rev l)) rev_sexps\n | _ ->\n Error \"Error_json.sexp_of_yojson: Expected a string or a list\"\n\ntype info_data =\n | Sexp of Sexp.t\n | String of string\n | Exn of exn\n | Of_list of int option * int * Yojson.Safe.t\n\n(* Used to encode sub-lists of infos *)\n\ntype info_tag =\n { tag : string; data : Sexp.t option; loc : Source_code_position.t option }\n\ntype 'a info_repr =\n { base : 'a; rev_tags : info_tag list; backtrace : string option }\n\nlet info_repr_to_yojson (info : info_data info_repr) : Yojson.Safe.t =\n let base_pairs =\n match info.base with\n | Sexp sexp ->\n [ (\"sexp\", sexp_to_yojson sexp) ]\n | String str ->\n [ (\"string\", `String str) ]\n | Exn exn ->\n [ ( \"exn_name\"\n , `String Stdlib.Obj.Extension_constructor.(name @@ of_val exn) )\n ; (\"exn\", sexp_to_yojson (Sexplib.Conv.sexp_of_exn exn))\n ]\n | Of_list (Some trunc_after, length, json) ->\n [ (\"multiple\", json)\n ; (\"length\", `Int length)\n ; (\"truncated_after\", `Int trunc_after)\n ]\n | Of_list (None, length, json) ->\n [ (\"multiple\", json); (\"length\", `Int length) ]\n in\n let tags =\n let tag_to_json { tag; data; loc } =\n let jsons =\n match loc with\n | None ->\n []\n | Some loc ->\n [ (\"loc\", `String (Source_code_position.to_string loc)) ]\n in\n let jsons =\n match data with\n | None ->\n jsons\n | Some data ->\n (\"sexp\", sexp_to_yojson data) :: jsons\n in\n `Assoc ((\"tag\", `String tag) :: jsons)\n in\n match info.rev_tags with\n | [] ->\n []\n | _ :: _ ->\n [ (\"tags\", `List (List.rev_map ~f:tag_to_json info.rev_tags)) ]\n in\n let backtrace =\n match info.backtrace with\n | None ->\n []\n | Some backtrace ->\n (* Split backtrace at lines so that it prints nicely in errors *)\n [ ( \"backtrace\"\n , `List\n (List.map ~f:(fun s -> `String s) (String.split_lines backtrace))\n )\n ]\n in\n `Assoc (base_pairs @ tags @ backtrace)\n\n(* NOTE: Could also add a [of_yojson] version for everything except [Exn]\n (which could be converted to [String]), but it's not clear that it would\n ever be useful.\n*)\n\nlet rec info_internal_repr_to_yojson_aux (info : Info.Internal_repr.t)\n (acc : unit info_repr) : info_data info_repr =\n match info with\n | Could_not_construct sexp ->\n { acc with base = Sexp (List [ Atom \"Could_not_construct\"; sexp ]) }\n | Sexp sexp ->\n { acc with base = Sexp sexp }\n | String str ->\n { acc with base = String str }\n | Exn exn ->\n { acc with base = Exn exn }\n | Tag_sexp (tag, sexp, loc) ->\n { acc with\n base = Sexp sexp\n ; rev_tags = { tag; data = None; loc } :: acc.rev_tags\n }\n | Tag_t (tag, info) ->\n info_internal_repr_to_yojson_aux info\n { acc with rev_tags = { tag; data = None; loc = None } :: acc.rev_tags }\n | Tag_arg (tag, data, info) ->\n info_internal_repr_to_yojson_aux info\n { acc with\n rev_tags = { tag; data = Some data; loc = None } :: acc.rev_tags\n }\n | Of_list (trunc_after, infos) ->\n let rec rev_take i acc_len infos acc_infos =\n match (i, infos) with\n | _, [] ->\n (None, acc_len, acc_infos)\n | None, info :: infos ->\n let json_info = info_internal_repr_to_yojson info in\n rev_take i (acc_len + 1) infos (json_info :: acc_infos)\n | Some i, info :: infos ->\n if i > 0 then\n let json_info = info_internal_repr_to_yojson info in\n rev_take\n (Some (i - 1))\n (acc_len + 1) infos (json_info :: acc_infos)\n else (Some acc_len, acc_len + 1 + List.length infos, acc_infos)\n in\n let trunc_after, length, rev_json_infos =\n rev_take trunc_after 0 infos []\n in\n let json_infos = `List (List.rev rev_json_infos) in\n { acc with base = Of_list (trunc_after, length, json_infos) }\n | With_backtrace (info, backtrace) ->\n info_internal_repr_to_yojson_aux info\n { acc with backtrace = Some backtrace }\n\nand info_internal_repr_to_yojson (info : Info.Internal_repr.t) : Yojson.Safe.t =\n info_internal_repr_to_yojson_aux info\n { base = (); rev_tags = []; backtrace = None }\n |> info_repr_to_yojson\n\nlet info_to_yojson (info : Info.t) : Yojson.Safe.t =\n info_internal_repr_to_yojson (Info.Internal_repr.of_info info)\n\nlet error_to_yojson (err : Error.t) : Yojson.Safe.t =\n match info_to_yojson (err :> Info.t) with\n | `Assoc assocs ->\n `Assoc ((\"commit_id\", `String Mina_version.commit_id) :: assocs)\n | json ->\n `Assoc [ (\"commit_id\", `String Mina_version.commit_id); (\"error\", json) ]\n","open Core_kernel\nopen Pickles_types\nmodule Columns = Nat.N15\nmodule Columns_vec = Vector.Vector_15\nmodule Coefficients = Nat.N15\nmodule Coefficients_vec = Vector.Vector_15\nmodule Quotient_polynomial = Nat.N7\nmodule Quotient_polynomial_vec = Vector.Vector_7\nmodule Permuts_minus_1 = Nat.N6\nmodule Permuts_minus_1_vec = Vector.Vector_6\n\n[@@@warning \"-4\"]\n\nmodule Commitments = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n Mina_wire_types.Pickles.Concrete_.Wrap_wire_proof.Commitments.V1.t =\n { w_comm :\n (Backend.Tick.Field.Stable.V1.t * Backend.Tick.Field.Stable.V1.t)\n Columns_vec.Stable.V1.t\n ; z_comm :\n Backend.Tick.Field.Stable.V1.t * Backend.Tick.Field.Stable.V1.t\n ; t_comm :\n (Backend.Tick.Field.Stable.V1.t * Backend.Tick.Field.Stable.V1.t)\n Quotient_polynomial_vec.Stable.V1.t\n }\n [@@deriving compare, sexp, yojson, hash, equal]\n\n [@@@warning \"+4\"]\n\n let to_latest = Fn.id\n end\n end]\n\n let to_kimchi ({ w_comm; z_comm; t_comm } : t) :\n Backend.Tock.Curve.Affine.t Plonk_types.Messages.t =\n { w_comm = Vector.map ~f:(fun x -> [| x |]) w_comm\n ; z_comm = [| z_comm |]\n ; t_comm = Array.map ~f:(fun x -> x) (Vector.to_array t_comm)\n ; lookup = None\n }\n\n let of_kimchi\n ({ w_comm; z_comm; t_comm; lookup = _ } :\n Backend.Tock.Curve.Affine.t Plonk_types.Messages.t ) : t =\n { w_comm = Vector.map ~f:(fun x -> x.(0)) w_comm\n ; z_comm = z_comm.(0)\n ; t_comm = Vector.of_array_and_length_exn t_comm Quotient_polynomial.n\n }\nend\n\n[@@@warning \"-4\"]\n\nmodule Evaluations = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n Mina_wire_types.Pickles.Concrete_.Wrap_wire_proof.Evaluations.V1.t =\n { w :\n (Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t)\n Columns_vec.Stable.V1.t\n ; coefficients :\n (Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t)\n Columns_vec.Stable.V1.t\n ; z : Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; s :\n (Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t)\n Permuts_minus_1_vec.Stable.V1.t\n ; generic_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; poseidon_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; complete_add_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; mul_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; emul_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; endomul_scalar_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n }\n [@@deriving compare, sexp, yojson, hash, equal]\n\n [@@@warning \"+4\"]\n\n let to_latest = Fn.id\n end\n end]\n\n let to_kimchi\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n } :\n t ) :\n (Backend.Tock.Field.t array * Backend.Tock.Field.t array)\n Plonk_types.Evals.t =\n let conv (x, y) = ([| x |], [| y |]) in\n { w = Vector.map ~f:conv w\n ; coefficients = Vector.map ~f:conv coefficients\n ; z = conv z\n ; s = Vector.map ~f:conv s\n ; generic_selector = conv generic_selector\n ; poseidon_selector = conv poseidon_selector\n ; complete_add_selector = conv complete_add_selector\n ; mul_selector = conv mul_selector\n ; emul_selector = conv emul_selector\n ; endomul_scalar_selector = conv endomul_scalar_selector\n ; range_check0_selector = None\n ; range_check1_selector = None\n ; foreign_field_add_selector = None\n ; foreign_field_mul_selector = None\n ; xor_selector = None\n ; rot_selector = None\n ; lookup_aggregation = None\n ; lookup_table = None\n ; lookup_sorted = [ None; None; None; None; None ]\n ; runtime_lookup_table = None\n ; runtime_lookup_table_selector = None\n ; xor_lookup_selector = None\n ; lookup_gate_lookup_selector = None\n ; range_check_lookup_selector = None\n ; foreign_field_mul_lookup_selector = None\n }\n\n let of_kimchi\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector = _\n ; range_check1_selector = _\n ; foreign_field_add_selector = _\n ; foreign_field_mul_selector = _\n ; xor_selector = _\n ; rot_selector = _\n ; lookup_aggregation = _\n ; lookup_table = _\n ; lookup_sorted = _\n ; runtime_lookup_table = _\n ; runtime_lookup_table_selector = _\n ; xor_lookup_selector = _\n ; lookup_gate_lookup_selector = _\n ; range_check_lookup_selector = _\n ; foreign_field_mul_lookup_selector = _\n } :\n (Backend.Tock.Field.t array * Backend.Tock.Field.t array)\n Plonk_types.Evals.t ) : t =\n let conv (x, y) = (x.(0), y.(0)) in\n { w = Vector.map ~f:conv w\n ; coefficients = Vector.map ~f:conv coefficients\n ; z = conv z\n ; s = Vector.map ~f:conv s\n ; generic_selector = conv generic_selector\n ; poseidon_selector = conv poseidon_selector\n ; complete_add_selector = conv complete_add_selector\n ; mul_selector = conv mul_selector\n ; emul_selector = conv emul_selector\n ; endomul_scalar_selector = conv endomul_scalar_selector\n }\nend\n\n[@@@warning \"-4\"]\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Pickles.Concrete_.Wrap_wire_proof.V1.t =\n { commitments : Commitments.Stable.V1.t\n ; evaluations : Evaluations.Stable.V1.t\n ; ft_eval1 : Backend.Tock.Field.Stable.V1.t\n ; bulletproof :\n ( Backend.Tick.Field.Stable.V1.t * Backend.Tick.Field.Stable.V1.t\n , Backend.Tock.Field.Stable.V1.t )\n Plonk_types.Openings.Bulletproof.Stable.V1.t\n (* TODO-URGENT: Validate bulletproof length on the rust side *)\n }\n [@@deriving compare, sexp, yojson, hash, equal]\n\n [@@@warning \"+4\"]\n\n let to_latest = Fn.id\n end\nend]\n\nlet to_kimchi_proof ({ commitments; bulletproof; evaluations; ft_eval1 } : t) :\n Backend.Tock.Proof.t =\n { messages = Commitments.to_kimchi commitments\n ; openings =\n { proof = bulletproof\n ; evals = Evaluations.to_kimchi evaluations\n ; ft_eval1\n }\n }\n\nlet of_kimchi_proof\n ({ messages; openings = { proof; evals; ft_eval1 } } : Backend.Tock.Proof.t)\n : t =\n { commitments = Commitments.of_kimchi messages\n ; bulletproof = proof\n ; evaluations = Evaluations.of_kimchi evals\n ; ft_eval1\n }\n","open Core_kernel\nopen Import\nmodule SC = Scalar_challenge\n\n(* Implementation of the algorithm described on page 29 of the Halo paper\n https://eprint.iacr.org/2019/1021.pdf\n*)\n\nlet num_bits = 128\n\n(* Has the side effect of checking that [scalar] fits in 128 bits. *)\nlet to_field_checked' (type f) ?(num_bits = num_bits)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n { SC.inner = (scalar : Impl.Field.t) } =\n let open Impl in\n let neg_one = Field.Constant.(negate one) in\n let a_func = function\n | 0 ->\n Field.Constant.zero\n | 1 ->\n Field.Constant.zero\n | 2 ->\n neg_one\n | 3 ->\n Field.Constant.one\n | _ ->\n raise (Invalid_argument \"a_func\")\n in\n let b_func = function\n | 0 ->\n neg_one\n | 1 ->\n Field.Constant.one\n | 2 ->\n Field.Constant.zero\n | 3 ->\n Field.Constant.zero\n | _ ->\n raise (Invalid_argument \"a_func\")\n in\n let ( !! ) = As_prover.read_var in\n (* MSB bits *)\n let bits_msb =\n lazy\n (let open Field.Constant in\n unpack !!scalar |> Fn.flip List.take num_bits |> Array.of_list_rev\n (*\n |> Array.of_list_rev_map ~f:(fun b -> if b then one else zero) *))\n in\n let nybbles_per_row = 8 in\n let bits_per_row = 2 * nybbles_per_row in\n [%test_eq: int] (num_bits mod bits_per_row) 0 ;\n let rows = num_bits / bits_per_row in\n let nybbles_by_row =\n lazy\n (Array.init rows ~f:(fun i ->\n Array.init nybbles_per_row ~f:(fun j ->\n let bit = (bits_per_row * i) + (2 * j) in\n let b0 = (Lazy.force bits_msb).(bit + 1) in\n let b1 = (Lazy.force bits_msb).(bit) in\n Bool.to_int b0 + (2 * Bool.to_int b1) ) ) )\n in\n let two = Field.of_int 2 in\n let a = ref two in\n let b = ref two in\n let n = ref Field.zero in\n let mk f = exists Field.typ ~compute:f in\n let state = ref [] in\n for i = 0 to rows - 1 do\n let n0 = !n in\n let a0 = !a in\n let b0 = !b in\n let xs =\n Array.init nybbles_per_row ~f:(fun j ->\n mk (fun () ->\n Field.Constant.of_int (Lazy.force nybbles_by_row).(i).(j) ) )\n in\n let open Field.Constant in\n let double x = x + x in\n let n8 =\n mk (fun () ->\n Array.fold xs ~init:!!n0 ~f:(fun acc x ->\n (acc |> double |> double) + !!x ) )\n in\n let a8 =\n mk (fun () ->\n Array.fold\n (Lazy.force nybbles_by_row).(i)\n ~init:!!a0\n ~f:(fun acc x -> (acc |> double) + a_func x) )\n in\n let b8 =\n mk (fun () ->\n Array.fold\n (Lazy.force nybbles_by_row).(i)\n ~init:!!b0\n ~f:(fun acc x -> (acc |> double) + b_func x) )\n in\n state :=\n { Kimchi_backend_common.Endoscale_scalar_round.a0\n ; a8\n ; b0\n ; b8\n ; n0\n ; n8\n ; x0 = xs.(0)\n ; x1 = xs.(1)\n ; x2 = xs.(2)\n ; x3 = xs.(3)\n ; x4 = xs.(4)\n ; x5 = xs.(5)\n ; x6 = xs.(6)\n ; x7 = xs.(7)\n }\n :: !state ;\n n := n8 ;\n a := a8 ;\n b := b8 ;\n ()\n done ;\n with_label __LOC__ (fun () ->\n assert_\n Snarky_backendless.Constraint.\n { annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.(\n T (EC_endoscalar { state = Array.of_list_rev !state }))\n } ) ;\n (!a, !b, !n)\n\nlet to_field_checked (type f) ?num_bits\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) ~endo\n ({ SC.inner = (scalar : Impl.Field.t) } as s) =\n let open Impl in\n let a, b, n = to_field_checked' ?num_bits (module Impl) s in\n Field.Assert.equal n scalar ;\n Field.(scale a endo + b)\n\nlet to_field_constant (type f) ~endo\n (module F : Plonk_checks.Field_intf with type t = f) { SC.inner = c } =\n let bits = Array.of_list (Challenge.Constant.to_bits c) in\n let a = ref (F.of_int 2) in\n let b = ref (F.of_int 2) in\n let one = F.of_int 1 in\n let neg_one = F.(of_int 0 - one) in\n for i = (128 / 2) - 1 downto 0 do\n let s = if bits.(2 * i) then one else neg_one in\n (a := F.(!a + !a)) ;\n (b := F.(!b + !b)) ;\n let r_2i1 = bits.((2 * i) + 1) in\n if r_2i1 then a := F.(!a + s) else b := F.(!b + s)\n done ;\n F.((!a * endo) + !b)\n\nlet test (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ~(endo : f) =\n let open Impl in\n let module T = Internal_Basic in\n let n = 128 in\n let module Field_constant = struct\n include Field.Constant\n\n let _if_ b ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Quickcheck.test ~trials:10\n (Quickcheck.Generator.list_with_length n Bool.quickcheck_generator)\n ~f:(fun xs ->\n try\n T.Test.test_equal ~equal:Field.Constant.equal\n ~sexp_of_t:Field.Constant.sexp_of_t\n (Typ.list ~length:n Boolean.typ)\n Field.typ\n (fun s ->\n make_checked (fun () ->\n to_field_checked\n (module Impl)\n ~endo\n (SC.create (Impl.Field.pack s)) ) )\n (fun s ->\n to_field_constant\n (module Field_constant)\n ~endo\n (SC.create (Challenge.Constant.of_bits s)) )\n xs\n with e ->\n eprintf !\"Input %{sexp: bool list}\\n%!\" xs ;\n raise e )\n\nmodule Make\n (Impl : Snarky_backendless.Snark_intf.Run)\n (G : Intf.Group(Impl).S with type t = Impl.Field.t * Impl.Field.t)\n (Challenge : Challenge.S with module Impl := Impl) (Endo : sig\n val base : Impl.Field.Constant.t\n\n val scalar : G.Constant.Scalar.t\n end) =\nstruct\n open Impl\n module Scalar = G.Constant.Scalar\n\n type t = Challenge.t SC.t\n\n module Constant = struct\n type t = Challenge.Constant.t SC.t\n\n let to_field = to_field_constant ~endo:Endo.scalar (module Scalar)\n end\n\n let typ : (t, Constant.t) Typ.t = SC.typ Challenge.typ\n\n let num_bits = 128\n\n let seal = Util.seal (module Impl)\n\n let endo ?(num_bits = num_bits) t { SC.inner = (scalar : Field.t) } =\n let ( !! ) = As_prover.read_var in\n (* MSB bits *)\n let bits =\n lazy\n (let open Field.Constant in\n unpack !!scalar |> Fn.flip List.take num_bits\n |> Array.of_list_rev_map ~f:(fun b -> if b then one else zero))\n in\n let bits () = Lazy.force bits in\n let xt, yt = Tuple_lib.Double.map t ~f:seal in\n let bits_per_row = 4 in\n let rows = num_bits / bits_per_row in\n let acc =\n with_label __LOC__ (fun () ->\n let p = G.( + ) t (seal (Field.scale xt Endo.base), yt) in\n ref G.(p + p) )\n in\n let n_acc = ref Field.zero in\n let mk f = exists Field.typ ~compute:f in\n let rounds_rev = ref [] in\n for i = 0 to rows - 1 do\n let n_acc_prev = !n_acc in\n let b1 = mk (fun () -> (bits ()).(i * bits_per_row)) in\n let b2 = mk (fun () -> (bits ()).((i * bits_per_row) + 1)) in\n let b3 = mk (fun () -> (bits ()).((i * bits_per_row) + 2)) in\n let b4 = mk (fun () -> (bits ()).((i * bits_per_row) + 3)) in\n let open Field.Constant in\n let double x = x + x in\n let xp, yp = !acc in\n let xq1 = mk (fun () -> (one + ((Endo.base - one) * !!b1)) * !!xt) in\n let yq1 = mk (fun () -> (double !!b2 - one) * !!yt) in\n\n let s1 = mk (fun () -> (!!yq1 - !!yp) / (!!xq1 - !!xp)) in\n let s1_squared = mk (fun () -> square !!s1) in\n let s2 =\n mk (fun () ->\n (double !!yp / (double !!xp + !!xq1 - !!s1_squared)) - !!s1 )\n in\n\n let xr = mk (fun () -> !!xq1 + square !!s2 - !!s1_squared) in\n let yr = mk (fun () -> ((!!xp - !!xr) * !!s2) - !!yp) in\n\n let xq2 = mk (fun () -> (one + ((Endo.base - one) * !!b3)) * !!xt) in\n let yq2 = mk (fun () -> (double !!b4 - one) * !!yt) in\n let s3 = mk (fun () -> (!!yq2 - !!yr) / (!!xq2 - !!xr)) in\n let s3_squared = mk (fun () -> square !!s3) in\n let s4 =\n mk (fun () ->\n (double !!yr / (double !!xr + !!xq2 - !!s3_squared)) - !!s3 )\n in\n\n let xs = mk (fun () -> !!xq2 + square !!s4 - !!s3_squared) in\n let ys = mk (fun () -> ((!!xr - !!xs) * !!s4) - !!yr) in\n acc := (xs, ys) ;\n n_acc :=\n mk (fun () ->\n !!n_acc_prev |> double |> ( + ) !!b1 |> double |> ( + ) !!b2\n |> double |> ( + ) !!b3 |> double |> ( + ) !!b4 ) ;\n rounds_rev :=\n { Kimchi_backend_common.Endoscale_round.xt\n ; yt\n ; xp\n ; yp\n ; n_acc = n_acc_prev\n ; xr\n ; yr\n ; s1\n ; s3\n ; b1\n ; b2\n ; b3\n ; b4\n }\n :: !rounds_rev\n done ;\n let xs, ys = !acc in\n with_label __LOC__ (fun () ->\n assert_\n { annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.(\n T\n (EC_endoscale\n { xs\n ; ys\n ; n_acc = !n_acc\n ; state = Array.of_list_rev !rounds_rev\n } ))\n } ) ;\n with_label __LOC__ (fun () -> Field.Assert.equal !n_acc scalar) ;\n !acc\n\n let endo ?num_bits t s = with_label \"endo\" (fun () -> endo ?num_bits t s)\n\n let%test_unit \"endo\" =\n let module T = Internal_Basic in\n let random_point =\n let rec pt x =\n let y2 = G.Params.(T.Field.(b + (x * (a + (x * x))))) in\n if T.Field.is_square y2 then (x, T.Field.sqrt y2)\n else pt T.Field.(x + one)\n in\n G.Constant.of_affine (pt (T.Field.random ()))\n in\n let n = 128 in\n Quickcheck.test ~trials:10\n (Quickcheck.Generator.list_with_length n Bool.quickcheck_generator)\n ~f:(fun xs ->\n try\n T.Test.test_equal ~equal:G.Constant.equal\n ~sexp_of_t:G.Constant.sexp_of_t\n (Typ.tuple2 G.typ (Typ.list ~length:n Boolean.typ))\n G.typ\n (fun (g, s) ->\n make_checked (fun () -> endo g (SC.create (Field.pack s))) )\n (fun (g, s) ->\n let x =\n Constant.to_field (SC.create (Challenge.Constant.of_bits s))\n in\n G.Constant.scale g x )\n (random_point, xs)\n with e ->\n eprintf !\"Input %{sexp: bool list}\\n%!\" xs ;\n raise e )\n\n let endo_inv ((gx, gy) as g) chal =\n let res =\n exists G.typ\n ~compute:\n As_prover.(\n fun () ->\n let x = Constant.to_field (read typ chal) in\n G.Constant.scale (read G.typ g) Scalar.(one / x))\n in\n let x, y = endo res chal in\n Field.Assert.(equal gx x ; equal gy y) ;\n res\nend\n","open Pickles_types\nopen Core_kernel\nopen Import\nopen Backend\nmodule Wrap_impl = Snarky_backendless.Snark.Run.Make (Tock)\n\n(** returns [true] if the [i]th bit of [x] is set to 1 *)\nlet test_bit x i = B.(shift_right x i land one = one)\n\n(* TODO: I think there are other forbidden values as well. *)\n\n(** returns all the values that can fit in [~size_in_bits] bits and that are\n * either congruent with -2^[~size_in_bits] mod [~modulus] \n * or congruent with -2^[~size_in_bits] - 1 mod [~modulus] \n *)\nlet forbidden_shifted_values ~modulus:r ~size_in_bits =\n let two_to_n = B.(pow (of_int 2) (of_int size_in_bits)) in\n (* this function doesn't make sense if the modulus is smaller *)\n assert (B.(r < two_to_n)) ;\n let neg_two_to_n = B.(neg two_to_n) in\n let representatives x =\n let open Sequence in\n (* All values equivalent to x mod r that fit in [size_in_bits]\n many bits. *)\n let fits_in_n_bits x = B.(x < two_to_n) in\n unfold ~init:B.(x % r) ~f:(fun x -> Some (x, B.(x + r)))\n |> take_while ~f:fits_in_n_bits\n |> to_list\n in\n List.concat_map [ neg_two_to_n; B.(neg_two_to_n - one) ] ~f:representatives\n |> List.dedup_and_sort ~compare:B.compare\n\nmodule Step = struct\n module Impl = Snarky_backendless.Snark.Run.Make (Tick)\n include Impl\n module Verification_key = Tick.Verification_key\n module Proving_key = Tick.Proving_key\n\n module Keypair = struct\n type t = { pk : Proving_key.t; vk : Verification_key.t } [@@deriving fields]\n\n let create = Fields.create\n\n let generate ~prev_challenges cs =\n let open Tick.Keypair in\n let keypair = create ~prev_challenges cs in\n { pk = pk keypair; vk = vk keypair }\n end\n\n module Other_field = struct\n (* Tick.Field.t = p < q = Tock.Field.t *)\n\n module Constant = Tock.Field\n\n type t = (* Low bits, high bit *)\n Field.t * Boolean.var\n\n let forbidden_shifted_values =\n lazy\n (let size_in_bits = Constant.size_in_bits in\n let other_mod = Wrap_impl.Bigint.to_bignum_bigint Constant.size in\n let values =\n forbidden_shifted_values ~size_in_bits ~modulus:other_mod\n in\n let f x =\n let open Option.Let_syntax in\n let hi = test_bit x (Field.size_in_bits - 1) in\n let lo = B.shift_right x 1 in\n let%map lo =\n let modulus = Impl.Field.size in\n if B.compare modulus lo <= 0 then None\n else Some Impl.Bigint.(to_field (of_bignum_bigint lo))\n in\n (lo, hi)\n in\n values |> List.filter_map ~f )\n\n let%test_unit \"preserve circuit behavior for Step\" =\n let expected_list =\n [ (\"45560315531506369815346746415080538112\", false)\n ; (\"45560315531506369815346746415080538113\", false)\n ; ( \"14474011154664524427946373126085988481727088556502330059655218120611762012161\"\n , true )\n ; ( \"14474011154664524427946373126085988481727088556502330059655218120611762012161\"\n , true )\n ]\n in\n let str_list =\n List.map (Lazy.force forbidden_shifted_values) ~f:(fun (a, b) ->\n (Tick.Field.to_string a, b) )\n in\n assert ([%equal: (string * bool) list] str_list expected_list)\n\n let typ_unchecked : (t, Constant.t) Typ.t =\n Typ.transport\n (Typ.tuple2 Field.typ Boolean.typ)\n ~there:(fun x ->\n match Tock.Field.to_bits x with\n | [] ->\n assert false\n | low :: high ->\n (Field.Constant.project high, low) )\n ~back:(fun (high, low) ->\n let high = Field.Constant.unpack high in\n Tock.Field.of_bits (low :: high) )\n\n let check t =\n let open Internal_Basic in\n let open Let_syntax in\n let equal (x1, b1) (x2, b2) =\n let%bind x_eq = Field.Checked.equal x1 (Field.Var.constant x2) in\n let b_eq = match b2 with true -> b1 | false -> Boolean.not b1 in\n Boolean.( && ) x_eq b_eq\n in\n let (Typ typ_unchecked) = typ_unchecked in\n let%bind () = typ_unchecked.check t in\n Checked.List.map (Lazy.force forbidden_shifted_values) ~f:(equal t)\n >>= Boolean.any >>| Boolean.not >>= Boolean.Assert.is_true\n\n let typ : _ Snarky_backendless.Typ.t =\n let (Typ typ_unchecked) = typ_unchecked in\n Typ { typ_unchecked with check }\n\n let _to_bits (x, b) =\n Field.unpack x ~length:(Field.size_in_bits - 1) @ [ b ]\n end\n\n module Digest = Digest.Make (Impl)\n module Challenge = Challenge.Make (Impl)\n\n let input ~proofs_verified ~wrap_rounds =\n let open Types.Step.Statement in\n let spec = spec proofs_verified wrap_rounds in\n let (T (typ, f, f_inv)) =\n Spec.packed_typ\n (module Impl)\n (T\n ( Shifted_value.Type2.typ Other_field.typ_unchecked\n , (fun (Shifted_value.Type2.Shifted_value x as t) ->\n Impl.run_checked (Other_field.check x) ;\n t )\n , Fn.id ) )\n spec\n in\n let typ = Typ.transport typ ~there:to_data ~back:of_data in\n Spec.ETyp.T (typ, (fun x -> of_data (f x)), fun x -> f_inv (to_data x))\nend\n\nmodule Wrap = struct\n module Impl = Wrap_impl\n include Impl\n module Challenge = Challenge.Make (Impl)\n module Digest = Digest.Make (Impl)\n module Wrap_field = Tock.Field\n module Step_field = Tick.Field\n module Verification_key = Tock.Verification_key\n module Proving_key = Tock.Proving_key\n\n module Keypair = struct\n type t = { pk : Proving_key.t; vk : Verification_key.t } [@@deriving fields]\n\n let create = Fields.create\n\n let generate ~prev_challenges cs =\n let open Tock.Keypair in\n let keypair = create ~prev_challenges cs in\n { pk = pk keypair; vk = vk keypair }\n end\n\n module Other_field = struct\n module Constant = Tick.Field\n open Impl\n\n type t = Field.t\n\n let forbidden_shifted_values =\n lazy\n (let other_mod = Step.Impl.Bigint.to_bignum_bigint Constant.size in\n let size_in_bits = Constant.size_in_bits in\n let values =\n forbidden_shifted_values ~size_in_bits ~modulus:other_mod\n in\n let f x =\n let modulus = Impl.Field.size in\n if B.compare modulus x <= 0 then None\n else Some Impl.Bigint.(to_field (of_bignum_bigint x))\n in\n values |> List.filter_map ~f )\n\n let%test_unit \"preserve circuit behavior for Wrap\" =\n let expected_list =\n [ \"91120631062839412180561524743370440705\"\n ; \"91120631062839412180561524743370440706\"\n ]\n in\n let str_list =\n List.map (Lazy.force forbidden_shifted_values) ~f:Wrap_field.to_string\n in\n assert ([%equal: string list] str_list expected_list)\n\n let typ_unchecked, check =\n (* Tick -> Tock *)\n let (Typ t0 as typ_unchecked) =\n Typ.transport Field.typ\n ~there:(Fn.compose Tock.Field.of_bits Tick.Field.to_bits)\n ~back:(Fn.compose Tick.Field.of_bits Tock.Field.to_bits)\n in\n let check t =\n let open Internal_Basic in\n let open Let_syntax in\n let equal x1 x2 = Field.Checked.equal x1 (Field.Var.constant x2) in\n let%bind () = t0.check t in\n Checked.List.map (Lazy.force forbidden_shifted_values) ~f:(equal t)\n >>= Boolean.any >>| Boolean.not >>= Boolean.Assert.is_true\n in\n (typ_unchecked, check)\n\n let typ : _ Snarky_backendless.Typ.t =\n let (Typ typ_unchecked) = typ_unchecked in\n Typ { typ_unchecked with check }\n\n let _to_bits x = Field.unpack x ~length:Field.size_in_bits\n end\n\n let input\n ~feature_flags:\n ({ Plonk_types.Features.Full.uses_lookups; _ } as feature_flags) () =\n let feature_flags = Plonk_types.Features.of_full feature_flags in\n let lookup =\n { Types.Wrap.Lookup_parameters.use = uses_lookups\n ; zero =\n { value =\n { challenge = Limb_vector.Challenge.Constant.zero\n ; scalar =\n Shifted_value.Type1.Shifted_value Other_field.Constant.zero\n }\n ; var =\n { challenge = Impl.Field.zero\n ; scalar = Shifted_value.Type1.Shifted_value Impl.Field.zero\n }\n }\n }\n in\n let fp : (Impl.Field.t, Other_field.Constant.t) Typ.t =\n Other_field.typ_unchecked\n in\n let open Types.Wrap.Statement in\n let (T (typ, f, f_inv)) =\n Spec.packed_typ\n (module Impl)\n (T\n ( Shifted_value.Type1.typ fp\n , (fun (Shifted_value x as t) ->\n Impl.run_checked (Other_field.check x) ;\n t )\n , Fn.id ) )\n (In_circuit.spec (module Impl) lookup feature_flags)\n in\n let typ =\n Typ.transport typ\n ~there:(In_circuit.to_data ~option_map:Option.map)\n ~back:(In_circuit.of_data ~option_map:Option.map)\n in\n Spec.ETyp.T\n ( typ\n , (fun x -> In_circuit.of_data ~option_map:Opt.map (f x))\n , fun x -> f_inv (In_circuit.to_data ~option_map:Opt.map x) )\nend\n","open Core_kernel\n\nopen Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint\n\nlet seal i = Tuple_lib.Double.map ~f:(Util.seal i)\n\nlet add_fast (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ?(check_finite = true) ((x1, y1) as p1) ((x2, y2) as p2) :\n Impl.Field.t * Impl.Field.t =\n let p1 = seal (module Impl) p1 in\n let p2 = seal (module Impl) p2 in\n let open Impl in\n let open Field.Constant in\n let bool b = if b then one else zero in\n let eq a b = As_prover.(equal (read_var a) (read_var b)) in\n let same_x_bool = lazy (eq x1 x2) in\n let ( ! ) = Lazy.force in\n let ( !! ) = As_prover.read_var in\n let mk f = exists Field.typ ~compute:f in\n let same_x = mk (fun () -> bool !same_x_bool) in\n let inf =\n if check_finite then Field.zero\n else mk (fun () -> bool (!same_x_bool && not (eq y1 y2)))\n in\n let inf_z =\n mk (fun () ->\n if eq y1 y2 then zero\n else if !same_x_bool then inv (!!y2 - !!y1)\n else zero )\n in\n let x21_inv =\n mk (fun () -> if !same_x_bool then zero else inv (!!x2 - !!x1))\n in\n let s =\n mk (fun () ->\n if !same_x_bool then\n let x1_squared = square !!x1 in\n let y1 = !!y1 in\n (x1_squared + x1_squared + x1_squared) / (y1 + y1)\n else (!!y2 - !!y1) / (!!x2 - !!x1) )\n in\n let x3 = mk (fun () -> square !!s - (!!x1 + !!x2)) in\n let y3 = mk (fun () -> (!!s * (!!x1 - !!x3)) - !!y1) in\n let p3 = (x3, y3) in\n with_label \"add_fast\" (fun () ->\n assert_\n { Snarky_backendless.Constraint.annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.T\n (EC_add_complete\n { p1; p2; p3; inf; same_x; slope = s; inf_z; x21_inv } )\n } ;\n p3 )\n\nmodule Make\n (Impl : Snarky_backendless.Snark_intf.Run)\n (G : Intf.Group(Impl).S with type t = Impl.Field.t * Impl.Field.t) =\nstruct\n open Impl\n\n let seal = seal (module Impl)\n\n let add_fast = add_fast (module Impl)\n\n let bits_per_chunk = 5\n\n (* Number of chunks needed to cover the given number of bits. *)\n let chunks_needed ~num_bits =\n (num_bits + (bits_per_chunk - 1)) / bits_per_chunk\n\n let scale_fast_msb_bits base\n (Pickles_types.Shifted_value.Type1.Shifted_value\n (bits_msb : Boolean.var array) ) : Field.t * Field.t =\n let ((x_base, y_base) as base) = seal base in\n let ( !! ) = As_prover.read_var in\n let mk f = exists Field.typ ~compute:f in\n (* MSB bits *)\n let num_bits = Array.length bits_msb in\n let chunks = num_bits / bits_per_chunk in\n [%test_eq: int] (num_bits mod bits_per_chunk) 0 ;\n let acc = ref (add_fast base base) in\n let n_acc = ref Field.zero in\n let rounds_rev = ref [] in\n for chunk = 0 to chunks - 1 do\n let open Field.Constant in\n let double x = x + x in\n let bs =\n Array.init bits_per_chunk ~f:(fun i ->\n (bits_msb.(Int.((chunk * bits_per_chunk) + i)) :> Field.t) )\n in\n let n_acc_prev = !n_acc in\n n_acc :=\n mk (fun () ->\n Array.fold bs ~init:!!n_acc_prev ~f:(fun acc b -> double acc + !!b) ) ;\n let accs, slopes =\n Array.fold_map bs ~init:!acc ~f:(fun (x_acc, y_acc) b ->\n let s1 =\n mk (fun () ->\n (!!y_acc - (!!y_base * (double !!b - one)))\n / (!!x_acc - !!x_base) )\n in\n let s1_squared = mk (fun () -> square !!s1) in\n let s2 =\n mk (fun () ->\n (double !!y_acc / (double !!x_acc + !!x_base - !!s1_squared))\n - !!s1 )\n in\n let x_res = mk (fun () -> !!x_base + square !!s2 - !!s1_squared) in\n let y_res = mk (fun () -> ((!!x_acc - !!x_res) * !!s2) - !!y_acc) in\n let acc' = (x_res, y_res) in\n (acc', (acc', s1)) )\n |> snd |> Array.unzip\n in\n let accs = Array.append [| !acc |] accs in\n acc := Array.last accs ;\n rounds_rev :=\n { Kimchi_backend_common.Scale_round.accs\n ; bits = bs\n ; ss = slopes\n ; n_prev = n_acc_prev\n ; n_next = !n_acc\n ; base\n }\n :: !rounds_rev\n done ;\n assert_\n { Snarky_backendless.Constraint.annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.T\n (EC_scale { state = Array.of_list_rev !rounds_rev })\n } ;\n (* TODO: Return n_acc ? *)\n !acc\n\n (*\n Computes\n\n fun (g, t) -> (2 * t + 1 + 2^len(t)) g *)\n let scale_fast_unpack base\n (Pickles_types.Shifted_value.Type1.Shifted_value (scalar : Field.t))\n ~num_bits : (Field.t * Field.t) * Boolean.var array =\n let ((x_base, y_base) as base) = seal base in\n let ( !! ) = As_prover.read_var in\n let mk f = exists Field.typ ~compute:f in\n (* MSB bits *)\n (*\n let num_bits = Field.size_in_bits in *)\n let chunks = num_bits / bits_per_chunk in\n [%test_eq: int] (num_bits mod bits_per_chunk) 0 ;\n let bits_msb =\n exists (Typ.array ~length:num_bits Field.typ) ~compute:(fun () ->\n let open Field.Constant in\n unpack !!scalar |> Fn.flip List.take num_bits\n |> Array.of_list_rev_map ~f:(fun b -> if b then one else zero) )\n in\n let acc = ref (add_fast base base) in\n let n_acc = ref Field.zero in\n let rounds_rev = ref [] in\n for chunk = 0 to chunks - 1 do\n let open Field.Constant in\n let double x = x + x in\n let bs =\n Array.init bits_per_chunk ~f:(fun i ->\n bits_msb.(Int.((chunk * bits_per_chunk) + i)) )\n in\n let n_acc_prev = !n_acc in\n n_acc :=\n mk (fun () ->\n Array.fold bs ~init:!!n_acc_prev ~f:(fun acc b -> double acc + !!b) ) ;\n let accs, slopes =\n Array.fold_map bs ~init:!acc ~f:(fun (x_acc, y_acc) b ->\n let s1 =\n mk (fun () ->\n (!!y_acc - (!!y_base * (double !!b - one)))\n / (!!x_acc - !!x_base) )\n in\n let s1_squared = mk (fun () -> square !!s1) in\n let s2 =\n mk (fun () ->\n (double !!y_acc / (double !!x_acc + !!x_base - !!s1_squared))\n - !!s1 )\n in\n let x_res = mk (fun () -> !!x_base + square !!s2 - !!s1_squared) in\n let y_res = mk (fun () -> ((!!x_acc - !!x_res) * !!s2) - !!y_acc) in\n let acc' = (x_res, y_res) in\n (acc', (acc', s1)) )\n |> snd |> Array.unzip\n in\n let accs = Array.append [| !acc |] accs in\n acc := Array.last accs ;\n rounds_rev :=\n { Kimchi_backend_common.Scale_round.accs\n ; bits = bs\n ; ss = slopes\n ; n_prev = n_acc_prev\n ; n_next = !n_acc\n ; base\n }\n :: !rounds_rev\n done ;\n assert_\n { Snarky_backendless.Constraint.annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.T\n (EC_scale { state = Array.of_list_rev !rounds_rev })\n } ;\n Field.Assert.equal !n_acc scalar ;\n let bits_lsb =\n let bs = Array.map bits_msb ~f:Boolean.Unsafe.of_cvar in\n Array.rev_inplace bs ; bs\n in\n (!acc, bits_lsb)\n\n let scale_fast_unpack base scalar ~num_bits :\n (Field.t * Field.t) * Boolean.var array =\n with_label \"scale_fast_unpack\" (fun () ->\n scale_fast_unpack base scalar ~num_bits )\n\n let scale_fast base s ~num_bits =\n let r, _bits = scale_fast_unpack base s ~num_bits in\n r\n\n module type Scalar_field_intf = sig\n module Constant : sig\n include Plonk_checks.Field_intf\n\n val to_bigint : t -> Impl.Bigint.t\n end\n\n type t = Field.t\n\n val typ : (t, Constant.t) Typ.t\n end\n\n (* Computes\n\n (g, s) -> (s + 2^{len(s) - 1})\n\n as\n\n let h = scale_fast g (s >> 1) in\n if s is odd then h else h - g\n ==\n let h = [ 2 * (s >> 1) + 1 + 2^{len(s) - 1} ] * g in\n if s is odd then h else h - g\n\n since if s is odd, then s = 2 * (s >> 1) + 1, and otherwise,\n s = 2 * (s >> 1) + 1 - 1.\n *)\n let scale_fast2 (g : G.t)\n (Pickles_types.Shifted_value.Type2.Shifted_value\n ((s_div_2 : Field.t), (s_odd : Boolean.var)) ) ~(num_bits : int) : G.t =\n let s_div_2_bits = num_bits - 1 in\n (* The number of chunks need for scaling by s_div_2. *)\n let chunks_needed = chunks_needed ~num_bits:s_div_2_bits in\n let actual_bits_used = chunks_needed * bits_per_chunk in\n let h, bits_lsb =\n scale_fast_unpack g (Shifted_value s_div_2) ~num_bits:actual_bits_used\n in\n (* Constrain the top bits of s_div_2 to be 0. *)\n with_label __LOC__ (fun () ->\n for i = s_div_2_bits to Array.length bits_lsb - 1 do\n Field.Assert.equal Field.zero (bits_lsb.(i) :> Field.t)\n done ) ;\n with_label __LOC__ (fun () ->\n G.if_ s_odd ~then_:h ~else_:(add_fast h (G.negate g)) )\n\n let scale_fast2' (type scalar_field)\n (module Scalar_field : Scalar_field_intf\n with type Constant.t = scalar_field ) g (s : Scalar_field.t) ~num_bits =\n let ((s_div_2, s_odd) as s_parts) =\n with_label __LOC__ (fun () ->\n exists\n Typ.(Scalar_field.typ * Boolean.typ)\n ~compute:\n As_prover.(\n fun () ->\n let s = read Scalar_field.typ s in\n let open Scalar_field.Constant in\n let s_odd = Bigint.test_bit (to_bigint s) 0 in\n ((if s_odd then s - one else s) / of_int 2, s_odd)) )\n in\n\n (* In this case, it's safe to use this field to compute\n\n 2 s_div_2 + b\n\n in the other field. *)\n with_label __LOC__ (fun () ->\n Field.Assert.equal Field.((of_int 2 * s_div_2) + (s_odd :> Field.t)) s ) ;\n scale_fast2 g (Pickles_types.Shifted_value.Type2.Shifted_value s_parts)\n ~num_bits\n\n let scale_fast a b = with_label __LOC__ (fun () -> scale_fast a b)\n\n let%test_module \"curve_ops\" =\n ( module struct\n module T = Internal_Basic\n\n let random_point =\n let rec pt x =\n let y2 = G.Params.(T.Field.(b + (x * (a + (x * x))))) in\n if T.Field.is_square y2 then (x, T.Field.sqrt y2)\n else pt T.Field.(x + one)\n in\n G.Constant.of_affine (pt (T.Field.of_int 0))\n\n let n = Field.size_in_bits\n\n let%test_unit \"scale fast 2\" =\n Quickcheck.test ~trials:5 Field.Constant.gen ~f:(fun s ->\n let input =\n let s_odd = T.Bigint.test_bit (T.Bigint.of_field s) 0 in\n Field.Constant.((if s_odd then s - one else s) / of_int 2, s_odd)\n in\n T.Test.test_equal ~equal:G.Constant.equal\n ~sexp_of_t:G.Constant.sexp_of_t\n (Typ.tuple2 G.typ (Typ.tuple2 Field.typ Boolean.typ))\n G.typ\n (fun (g, s) ->\n make_checked (fun () ->\n scale_fast2 ~num_bits:n g\n (Pickles_types.Shifted_value.Type2.Shifted_value s) ) )\n (fun (g, _) ->\n let x =\n let chunks_needed = chunks_needed ~num_bits:(n - 1) in\n let actual_bits_used = chunks_needed * bits_per_chunk in\n Pickles_types.Pcs_batch.pow ~one:G.Constant.Scalar.one\n ~mul:G.Constant.Scalar.( * )\n G.Constant.Scalar.(of_int 2)\n actual_bits_used\n |> G.Constant.Scalar.( + )\n (G.Constant.Scalar.project (Field.Constant.unpack s))\n in\n G.Constant.scale g x )\n (random_point, input) )\n\n let%test_unit \"scale fast\" =\n let open Pickles_types in\n let shift =\n Shifted_value.Type1.Shift.create (module G.Constant.Scalar)\n in\n Quickcheck.test ~trials:10\n Quickcheck.Generator.(\n map (list_with_length n Bool.quickcheck_generator) ~f:(fun bs ->\n Field.Constant.project bs |> Field.Constant.unpack ))\n ~f:(fun xs ->\n try\n T.Test.test_equal ~equal:G.Constant.equal\n ~sexp_of_t:G.Constant.sexp_of_t\n (Typ.tuple2 G.typ (Typ.list ~length:n Boolean.typ))\n G.typ\n (fun (g, s) ->\n make_checked (fun () ->\n scale_fast ~num_bits:n g\n (Pickles_types.Shifted_value.Type1.Shifted_value\n (Field.project s) ) ) )\n (fun (g, s) ->\n let open G.Constant.Scalar in\n let s = project s in\n let x =\n Shifted_value.Type1.to_field\n (module G.Constant.Scalar)\n ~shift (Pickles_types.Shifted_value.Type1.Shifted_value s)\n in\n G.Constant.scale g x )\n (random_point, xs)\n with e ->\n eprintf !\"Input %{sexp: bool list}\\n%!\" xs ;\n raise e )\n end )\nend\n","open Core_kernel\nopen Import\nopen Pickles_types\nopen Common\nopen Backend\n\n(* The step-proof \"reduced\" me-only contains the data of the standard me-only\n but without the wrap verification key. The purpose of this type is for sending\n step me-onlys on the wire. There is no need to send the wrap-key since everyone\n knows it. *)\nmodule Step = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('s, 'challenge_polynomial_commitments, 'bpcs) t =\n ( 's\n , 'challenge_polynomial_commitments\n , 'bpcs )\n Mina_wire_types\n .Pickles_reduced_messages_for_next_proof_over_same_field\n .Step\n .V1\n .t =\n { app_state : 's\n ; challenge_polynomial_commitments : 'challenge_polynomial_commitments\n ; old_bulletproof_challenges : 'bpcs\n }\n [@@deriving sexp, yojson, sexp, compare, hash, equal]\n end\n end]\n\n let prepare ~dlog_plonk_index\n { app_state\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n } =\n { Types.Step.Proof_state.Messages_for_next_step_proof.app_state\n ; challenge_polynomial_commitments\n ; dlog_plonk_index\n ; old_bulletproof_challenges =\n Vector.map ~f:Ipa.Step.compute_challenges old_bulletproof_challenges\n }\nend\n\nmodule Wrap = struct\n module Challenges_vector = struct\n module Vector = Pickles_types.Vector\n module Wrap_bp_vec = Import.Types.Wrap_bp_vec\n open Import\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t =\n Limb_vector.Constant.Hex64.Stable.V1.t Vector.Vector_2.Stable.V1.t\n Scalar_challenge.Stable.V2.t\n Bulletproof_challenge.Stable.V1.t\n Wrap_bp_vec.Stable.V1.t\n [@@deriving sexp, compare, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n type t =\n Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Wrap_bp_vec.t\n [@@deriving sexp, compare, yojson, hash, equal]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n module Prepared = struct\n type t = (Tock.Field.t, Tock.Rounds.n) Vector.t\n end\n end\n\n type 'max_local_max_proofs_verified t =\n ( Tock.Inner_curve.Affine.t\n , (Challenges_vector.t, 'max_local_max_proofs_verified) Vector.t )\n Types.Wrap.Proof_state.Messages_for_next_wrap_proof.t\n\n module Prepared = struct\n type 'max_local_max_proofs_verified t =\n ( Tock.Inner_curve.Affine.t\n , (Challenges_vector.Prepared.t, 'max_local_max_proofs_verified) Vector.t\n )\n Types.Wrap.Proof_state.Messages_for_next_wrap_proof.t\n end\n\n let prepare\n ({ challenge_polynomial_commitment; old_bulletproof_challenges } : _ t) =\n { Types.Wrap.Proof_state.Messages_for_next_wrap_proof\n .challenge_polynomial_commitment\n ; old_bulletproof_challenges =\n Vector.map ~f:Ipa.Wrap.compute_challenges old_bulletproof_challenges\n }\nend\n","open Core_kernel\nopen Common\nopen Backend\nmodule Impl = Impls.Step\n\nlet _high_entropy_bits = 128\n\nlet sponge_params_constant = Kimchi_pasta_basic.poseidon_params_fp\n\nlet tick_field_random_oracle ?(length = Tick.Field.size_in_bits - 1) s =\n Tick.Field.of_bits (Ro.bits_random_oracle ~length s)\n\nlet _unrelated_g =\n let group_map =\n unstage\n (group_map\n (module Tick.Field)\n ~a:Tick.Inner_curve.Params.a ~b:Tick.Inner_curve.Params.b )\n and str = Fn.compose bits_to_bytes Tick.Field.to_bits in\n fun (x, y) -> group_map (tick_field_random_oracle (str x ^ str y))\n\nopen Impl\n\n(* Debug helper to convert step circuit field element to a hex string *)\nlet read_step_circuit_field_element_as_hex fe =\n let prover_fe = As_prover.read Field.typ fe in\n Kimchi_backend.Pasta.Vesta_based_plonk.(\n Bigint.to_hex (Field.to_bigint prover_fe))\n\nmodule Other_field = struct\n type t = Tock.Field.t [@@deriving sexp]\n\n include (Tock.Field : module type of Tock.Field with type t := t)\n\n let size = Impls.Wrap.Bigint.to_bignum_bigint size\nend\n\nlet sponge_params =\n Sponge.Params.(map sponge_params_constant ~f:Impl.Field.constant)\n\n(* module Unsafe = struct\n let _unpack_unboolean ?(length = Field.size_in_bits) x =\n let res =\n exists\n (Typ.list Boolean.typ_unchecked ~length)\n ~compute:\n As_prover.(\n fun () -> List.take (Field.Constant.unpack (read_var x)) length)\n in\n Field.Assert.equal x (Field.project res) ;\n res\n end *)\n\nmodule Sponge = struct\n module Permutation =\n Sponge_inputs.Make\n (Impl)\n (struct\n include Tick_field_sponge.Inputs\n\n let params = Tick_field_sponge.params\n end)\n\n module S = Sponge.Make_debug_sponge (struct\n include Permutation\n module Circuit = Impls.Step\n\n (* Optional sponge name used in debug mode *)\n let sponge_name = \"step\"\n\n (* To enable debug mode, set environment variable [sponge_name] to \"t\", \"1\" or \"true\". *)\n let debug_helper_fn = read_step_circuit_field_element_as_hex\n end)\n\n include S\n\n let squeeze_field t = squeeze t\n\n let squeeze t = squeeze t\n\n let absorb t input =\n match input with\n | `Field x ->\n absorb t x\n | `Bits bs ->\n absorb t (Field.pack bs)\nend\n\nlet%test_unit \"sponge\" =\n let module T = Make_sponge.Test (Impl) (Tick_field_sponge.Field) (Sponge.S) in\n T.test Tick_field_sponge.params\n\n(* module Input_domain = struct\n let domain = Import.Domain.Pow_2_roots_of_unity 6\n\n let _lagrange_commitments =\n lazy\n (let domain_size = Import.Domain.size domain in\n Common.time \"lagrange\" (fun () ->\n Array.init domain_size ~f:(fun i ->\n let v =\n (Kimchi_bindings.Protocol.SRS.Fq.lagrange_commitment\n (Backend.Tock.Keypair.load_urs ())\n domain_size i )\n .unshifted\n in\n assert (Array.length v = 1) ;\n v.(0) |> Common.finite_exn ) ) )\n end *)\n\nmodule Inner_curve = struct\n module C = Kimchi_pasta.Pasta.Pallas\n\n module Inputs = struct\n module Impl = Impl\n\n module Params = struct\n include C.Params\n\n let one = C.to_affine_exn C.one\n\n let group_size_in_bits = Field.size_in_bits\n end\n\n module F = struct\n include struct\n open Impl.Field\n\n type nonrec t = t\n\n let ( * ), ( + ), ( - ), inv_exn, square, scale, if_, typ, constant =\n (( * ), ( + ), ( - ), inv, square, scale, if_, typ, constant)\n\n let negate x = scale x Constant.(negate one)\n end\n\n module Constant = struct\n open Impl.Field.Constant\n\n type nonrec t = t\n\n let ( * ), ( + ), ( - ), inv_exn, square, negate =\n (( * ), ( + ), ( - ), inv, square, negate)\n end\n\n let assert_square x y = Impl.assert_square x y\n\n let assert_r1cs x y z = Impl.assert_r1cs x y z\n end\n\n module Constant = struct\n include C.Affine\n module Scalar = Impls.Wrap.Field.Constant\n\n let scale (t : t) x : t = C.(to_affine_exn (scale (of_affine t) x))\n\n let random () = C.(to_affine_exn (random ()))\n\n let zero = Impl.Field.Constant.(zero, zero)\n\n let ( + ) t1 t2 =\n let is_zero (x, _) = Impl.Field.Constant.(equal zero x) in\n if is_zero t1 then t2\n else if is_zero t2 then t1\n else\n let r = C.(of_affine t1 + of_affine t2) in\n try C.to_affine_exn r with _ -> zero\n\n let negate x = C.(to_affine_exn (negate (of_affine x)))\n\n let to_affine_exn = Fn.id\n\n let of_affine = Fn.id\n end\n end\n\n module Params = Inputs.Params\n module Constant = Inputs.Constant\n module T = Snarky_curve.For_native_base_field (Inputs)\n\n include (\n T :\n module type of T\n with module Scaling_precomputation := T.Scaling_precomputation )\n\n module Scaling_precomputation = T.Scaling_precomputation\n\n let ( + ) t1 t2 = Plonk_curve_ops.add_fast (module Impl) t1 t2\n\n let double t = t + t\n\n let scale t bs =\n with_label __LOC__ (fun () ->\n T.scale t (Bitstring_lib.Bitstring.Lsb_first.of_list bs) )\n\n let to_field_elements (x, y) = [ x; y ]\n\n let assert_equal (x1, y1) (x2, y2) =\n Field.Assert.equal x1 x2 ; Field.Assert.equal y1 y2\n\n let scale_inv t bs =\n let res =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n C.scale\n (C.of_affine (read typ t))\n (Tock.Field.inv\n (Tock.Field.of_bits (List.map ~f:(read Boolean.typ) bs)) )\n |> C.to_affine_exn)\n in\n assert_equal t (scale res bs) ;\n res\n\n let negate = T.negate\n\n let one = T.one\n\n let if_ = T.if_\nend\n\nmodule Ops = Plonk_curve_ops.Make (Impl) (Inner_curve)\n\nlet%test_unit \"scale fast 2'\" =\n let open Impl in\n let module T = Internal_Basic in\n let module G = Inner_curve in\n let n = Field.size_in_bits in\n let module F = struct\n type t = Field.t\n\n let typ = Field.typ\n\n module Constant = struct\n include Field.Constant\n\n let to_bigint = Impl.Bigint.of_field\n end\n end in\n Quickcheck.test ~trials:5 Field.Constant.gen ~f:(fun s ->\n T.Test.test_equal ~equal:G.Constant.equal ~sexp_of_t:G.Constant.sexp_of_t\n (Typ.tuple2 G.typ Field.typ)\n G.typ\n (fun (g, s) ->\n make_checked (fun () -> Ops.scale_fast2' ~num_bits:n (module F) g s)\n )\n (fun (g, _) ->\n let x =\n let chunks_needed = Ops.chunks_needed ~num_bits:(n - 1) in\n let actual_bits_used = chunks_needed * Ops.bits_per_chunk in\n Pickles_types.Pcs_batch.pow ~one:G.Constant.Scalar.one\n ~mul:G.Constant.Scalar.( * )\n G.Constant.Scalar.(of_int 2)\n actual_bits_used\n |> G.Constant.Scalar.( + )\n (G.Constant.Scalar.project (Field.Constant.unpack s))\n in\n G.Constant.scale g x )\n (G.Constant.random (), s) )\n\nlet%test_unit \"scale fast 2 small\" =\n let open Impl in\n let module T = Internal_Basic in\n let module G = Inner_curve in\n let n = 8 in\n let module F = struct\n type t = Field.t\n\n let typ = Field.typ\n\n module Constant = struct\n include Field.Constant\n\n let to_bigint = Impl.Bigint.of_field\n end\n end in\n Quickcheck.test ~trials:5 Field.Constant.gen ~f:(fun s ->\n let s =\n Field.Constant.unpack s |> Fn.flip List.take n |> Field.Constant.project\n in\n T.Test.test_equal ~equal:G.Constant.equal ~sexp_of_t:G.Constant.sexp_of_t\n (Typ.tuple2 G.typ Field.typ)\n G.typ\n (fun (g, s) ->\n make_checked (fun () -> Ops.scale_fast2' ~num_bits:n (module F) g s)\n )\n (fun (g, _) ->\n let x =\n let chunks_needed = Ops.chunks_needed ~num_bits:(n - 1) in\n let actual_bits_used = chunks_needed * Ops.bits_per_chunk in\n Pickles_types.Pcs_batch.pow ~one:G.Constant.Scalar.one\n ~mul:G.Constant.Scalar.( * )\n G.Constant.Scalar.(of_int 2)\n actual_bits_used\n |> G.Constant.Scalar.( + )\n (G.Constant.Scalar.project (Field.Constant.unpack s))\n in\n G.Constant.scale g x )\n (G.Constant.random (), s) )\n\nmodule Generators = struct\n let h =\n lazy\n ( Kimchi_bindings.Protocol.SRS.Fq.urs_h (Backend.Tock.Keypair.load_urs ())\n |> Common.finite_exn )\nend\n","(** A verification key for a pickles proof, whose contents are not fixed within\n the verifier circuit.\n This is used to verify a proof where the verification key is determined by\n some other constraint, for example to use a verification key provided as\n input to the circuit, or loaded from an account that was chosen based upon\n the circuit inputs.\n\n Here and elsewhere, we use the terms\n * **width**:\n - the number of proofs that a proof has verified itself;\n - (equivalently) the maximum number of proofs that a proof depends upon\n directly.\n - NB: This does not include recursively-verified proofs, this only refers\n to proofs that were provided directly to pickles when the proof was\n being generated.\n * **branch**:\n - a single 'rule' or 'circuit' for which a proof can be generated, where\n a verification key verifies a proof for any of these branches.\n - It is common to have a 'base' branch and a 'recursion' branch. For\n example, the transaction snark has a 'transaction' proof that evaluates\n a single transaction and a 'merge' proof that combines two transaction\n snark proofs that prove sequential updates, each of which may be either\n a 'transaction' or a 'merge'.\n*)\n\nopen Core_kernel\nopen Pickles_types\nopen Import\nmodule V = Pickles_base.Side_loaded_verification_key\n\ninclude (\n V :\n module type of V\n with module Width := V.Width\n and module Domains := V.Domains )\n\nlet bits = V.bits\n\nlet input_size ~of_int ~add ~mul w =\n (* This should be an affine function in [a]. *)\n let size a =\n let (T (Typ typ, _conv, _conv_inv)) =\n Impls.Step.input ~proofs_verified:a ~wrap_rounds:Backend.Tock.Rounds.n\n in\n\n typ.size_in_field_elements\n in\n let f0 = size Nat.N0.n in\n let slope = size Nat.N1.n - f0 in\n add (of_int f0) (mul (of_int slope) w)\n\nmodule Width : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t = V.Width.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n open Impls.Step\n\n module Checked : sig\n type t\n\n val to_field : t -> Field.t\n\n val to_bits : t -> Boolean.var list\n end\n\n val typ : (Checked.t, t) Typ.t\n\n module Max = Nat.N2\n\n module Max_vector : Vector.With_version(Max).S\n\n module Max_at_most : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type 'a t = ('a, Max.n) At_most.t\n [@@deriving compare, sexp, yojson, hash, equal]\n end\n end]\n end\n\n module Length : Nat.Add.Intf_transparent\nend = struct\n include V.Width\n open Impls.Step\n\n module Checked = struct\n (* A \"width\" is represented by a 4 bit integer. *)\n type t = (Boolean.var, Length.n) Vector.t\n\n let to_field : t -> Field.t = Fn.compose Field.project Vector.to_list\n\n let to_bits = Vector.to_list\n end\n\n let typ : (Checked.t, t) Typ.t =\n Typ.transport\n (Vector.typ Boolean.typ Length.n)\n ~there:(fun x ->\n let x = to_int x in\n Vector.init Length.n ~f:(fun i -> (x lsr i) land 1 = 1) )\n ~back:(fun v ->\n Vector.foldi v ~init:0 ~f:(fun i acc b ->\n if b then acc lor (1 lsl i) else acc )\n |> of_int_exn )\nend\n\nmodule Domain = struct\n type 'a t = Pow_2_roots_of_unity of 'a [@@deriving sexp]\n\n let log2_size (Pow_2_roots_of_unity x) = x\nend\n[@@warning \"-4\"]\n\nmodule Domains = struct\n include V.Domains\n\n let _typ =\n let open Impls.Step in\n let dom =\n Typ.transport Typ.field\n ~there:(fun (Plonk_checks.Domain.Pow_2_roots_of_unity n) ->\n Field.Constant.of_int n )\n ~back:(fun _ -> assert false)\n |> Typ.transport_var\n ~there:(fun (Domain.Pow_2_roots_of_unity n) -> n)\n ~back:(fun n -> Domain.Pow_2_roots_of_unity n)\n in\n Typ.of_hlistable [ dom ] ~var_to_hlist:to_hlist ~value_to_hlist:to_hlist\n ~var_of_hlist:of_hlist ~value_of_hlist:of_hlist\nend\n\nlet max_domains =\n { Domains.h = Domain.Pow_2_roots_of_unity (Nat.to_int Backend.Tick.Rounds.n) }\n\nmodule Vk = struct\n type t = (Impls.Wrap.Verification_key.t[@sexp.opaque]) [@@deriving sexp]\n\n let hash_fold_t s _ = Unit.hash_fold_t s ()\nend\n\nmodule R = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Backend.Tock.Curve.Affine.Stable.V1.t Repr.Stable.V2.t\n [@@deriving sexp, equal, compare, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\n[%%versioned_binable\nmodule Stable = struct\n module V2 = struct\n module T = struct\n type t =\n ( Backend.Tock.Curve.Affine.t\n , Pickles_base.Proofs_verified.Stable.V1.t\n , Vk.t )\n Poly.Stable.V2.t\n [@@deriving hash]\n\n let to_latest = Fn.id\n\n let description = \"Verification key\"\n\n let version_byte = Base58_check.Version_bytes.verification_key\n\n let to_repr\n { Poly.max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index\n ; wrap_vk = _\n } =\n { Repr.Stable.V2.max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index\n }\n\n let of_repr\n ({ Repr.Stable.V2.max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index = c\n } :\n R.Stable.V2.t ) : t =\n let d =\n (Common.wrap_domains\n ~proofs_verified:\n (Pickles_base.Proofs_verified.to_int actual_wrap_domain_size) )\n .h\n in\n let log2_size = Import.Domain.log2_size d in\n let public =\n let (T (input, _conv, _conv_inv)) =\n Impls.Wrap.input ~feature_flags:Plonk_types.Features.Full.maybe ()\n in\n let (Typ typ) = input in\n typ.size_in_field_elements\n in\n (* we only compute the wrap_vk if the srs can be loaded *)\n let srs =\n try Some (Backend.Tock.Keypair.load_urs ()) with _ -> None\n in\n let wrap_vk =\n Option.map srs ~f:(fun srs : Impls.Wrap.Verification_key.t ->\n { domain =\n { log_size_of_group = log2_size\n ; group_gen = Backend.Tock.Field.domain_generator ~log2_size\n }\n ; max_poly_size = 1 lsl Nat.to_int Backend.Tock.Rounds.n\n ; public\n ; prev_challenges = 2 (* Due to Wrap_hack *)\n ; srs\n ; evals =\n (let g (x, y) =\n { Kimchi_types.unshifted = [| Kimchi_types.Finite (x, y) |]\n ; shifted = None\n }\n in\n { sigma_comm = Array.map ~f:g (Vector.to_array c.sigma_comm)\n ; coefficients_comm =\n Array.map ~f:g (Vector.to_array c.coefficients_comm)\n ; generic_comm = g c.generic_comm\n ; mul_comm = g c.mul_comm\n ; psm_comm = g c.psm_comm\n ; emul_comm = g c.emul_comm\n ; complete_add_comm = g c.complete_add_comm\n ; endomul_scalar_comm = g c.endomul_scalar_comm\n ; xor_comm = None\n ; range_check0_comm = None\n ; range_check1_comm = None\n ; foreign_field_add_comm = None\n ; foreign_field_mul_comm = None\n ; rot_comm = None\n } )\n ; shifts = Common.tock_shifts ~log2_size\n ; lookup_index = None\n } )\n in\n { Poly.max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index = c\n ; wrap_vk\n }\n\n (* Proxy derivers to [R.t]'s, ignoring [wrap_vk] *)\n\n let sexp_of_t t = R.sexp_of_t (to_repr t)\n\n let t_of_sexp sexp = of_repr (R.t_of_sexp sexp)\n\n let _to_yojson t = R.to_yojson (to_repr t)\n\n let _of_yojson json = Result.map ~f:of_repr (R.of_yojson json)\n\n let equal x y = R.equal (to_repr x) (to_repr y)\n\n let compare x y = R.compare (to_repr x) (to_repr y)\n\n include\n Binable.Of_binable\n (R.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable r = to_repr r\n\n let of_binable r = of_repr r\n end)\n end\n\n include T\n include Codable.Make_base58_check (T)\n include Codable.Make_base64 (T)\n end\nend]\n\n[%%define_locally\nStable.Latest.\n ( to_base58_check\n , of_base58_check\n , of_base58_check_exn\n , to_base64\n , of_base64\n , sexp_of_t\n , t_of_sexp\n , to_yojson\n , of_yojson\n , equal\n , compare )]\n\nlet dummy : t =\n { max_proofs_verified = N2\n ; actual_wrap_domain_size = N2\n ; wrap_index =\n (let g = Backend.Tock.Curve.(to_affine_exn one) in\n { sigma_comm = Vector.init Plonk_types.Permuts.n ~f:(fun _ -> g)\n ; coefficients_comm = Vector.init Plonk_types.Columns.n ~f:(fun _ -> g)\n ; generic_comm = g\n ; psm_comm = g\n ; complete_add_comm = g\n ; mul_comm = g\n ; emul_comm = g\n ; endomul_scalar_comm = g\n } )\n ; wrap_vk = None\n }\n\nmodule Checked = struct\n open Step_main_inputs\n open Impl\n\n type t =\n { max_proofs_verified :\n Impl.field Pickles_base.Proofs_verified.One_hot.Checked.t\n (** The maximum of all of the [step_widths]. *)\n ; actual_wrap_domain_size :\n Impl.field Pickles_base.Proofs_verified.One_hot.Checked.t\n (** The actual domain size used by the wrap circuit. *)\n ; wrap_index : Inner_curve.t Plonk_verification_key_evals.t\n (** The plonk verification key for the 'wrapping' proof that this key\n is used to verify.\n *)\n }\n [@@deriving hlist, fields]\n\n (** [log_2] of the width. *)\n let _width_size = Nat.to_int Width.Length.n\n\n let to_input =\n let open Random_oracle_input.Chunked in\n fun { max_proofs_verified; actual_wrap_domain_size; wrap_index } :\n _ Random_oracle_input.Chunked.t ->\n let max_proofs_verified =\n Pickles_base.Proofs_verified.One_hot.Checked.to_input\n max_proofs_verified\n in\n let actual_wrap_domain_size =\n Pickles_base.Proofs_verified.One_hot.Checked.to_input\n actual_wrap_domain_size\n in\n List.reduce_exn ~f:append\n [ max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index_to_input\n (Fn.compose Array.of_list Inner_curve.to_field_elements)\n wrap_index\n ]\nend\n\nlet%test_unit \"input_size\" =\n List.iter\n (List.range 0 (Nat.to_int Width.Max.n) ~stop:`inclusive ~start:`inclusive)\n ~f:(fun n ->\n [%test_eq: int]\n (input_size ~of_int:Fn.id ~add:( + ) ~mul:( * ) n)\n (let (T a) = Nat.of_int n in\n let (T (Typ typ, _conv, _conv_inv)) =\n Impls.Step.input ~proofs_verified:a\n ~wrap_rounds:Backend.Tock.Rounds.n\n in\n typ.size_in_field_elements ) )\n\nlet typ : (Checked.t, t) Impls.Step.Typ.t =\n let open Step_main_inputs in\n let open Impl in\n Typ.of_hlistable\n [ Pickles_base.Proofs_verified.One_hot.typ (module Impls.Step)\n ; Pickles_base.Proofs_verified.One_hot.typ (module Impls.Step)\n ; Plonk_verification_key_evals.typ Inner_curve.typ\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_of_hlist:(fun _ ->\n failwith \"Side_loaded_verification_key: value_of_hlist\" )\n ~value_to_hlist:(fun { Poly.wrap_index\n ; actual_wrap_domain_size\n ; max_proofs_verified\n ; _\n } ->\n [ max_proofs_verified; actual_wrap_domain_size; wrap_index ] )\n","open Core_kernel\nopen Pickles_types\nopen Import\nopen Backend\n\nlet hash_fold_array = Pickles_types.Plonk_types.hash_fold_array\n\nmodule Base = struct\n module Messages_for_next_proof_over_same_field =\n Reduced_messages_for_next_proof_over_same_field\n\n module Step = struct\n type ( 's\n , 'unfinalized_proofs\n , 'sgs\n , 'bp_chals\n , 'messages_for_next_wrap_proof\n , 'prev_evals )\n t =\n { statement :\n ( 'unfinalized_proofs\n , ('s, 'sgs, 'bp_chals) Messages_for_next_proof_over_same_field.Step.t\n , 'messages_for_next_wrap_proof )\n Types.Step.Statement.t\n ; index : int\n ; prev_evals : 'prev_evals\n ; proof : Tick.Proof.t\n }\n end\n\n module Wrap = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type ('messages_for_next_wrap_proof, 'messages_for_next_step_proof) t =\n ( 'messages_for_next_wrap_proof\n , 'messages_for_next_step_proof )\n Mina_wire_types.Pickles.Concrete_.Proof.Base.Wrap.V2.t =\n { statement :\n ( Limb_vector.Constant.Hex64.Stable.V1.t\n Vector.Vector_2.Stable.V1.t\n , Limb_vector.Constant.Hex64.Stable.V1.t\n Vector.Vector_2.Stable.V1.t\n Scalar_challenge.Stable.V2.t\n , Tick.Field.Stable.V1.t Shifted_value.Type1.Stable.V1.t\n , bool\n , 'messages_for_next_wrap_proof\n , Digest.Constant.Stable.V1.t\n , 'messages_for_next_step_proof\n , Limb_vector.Constant.Hex64.Stable.V1.t\n Vector.Vector_2.Stable.V1.t\n Scalar_challenge.Stable.V2.t\n Bulletproof_challenge.Stable.V1.t\n Step_bp_vec.Stable.V1.t\n , Branch_data.Stable.V1.t )\n Types.Wrap.Statement.Minimal.Stable.V1.t\n ; prev_evals :\n ( Tick.Field.Stable.V1.t\n , Tick.Field.Stable.V1.t array )\n Plonk_types.All_evals.Stable.V1.t\n ; proof : Wrap_wire_proof.Stable.V1.t\n }\n [@@deriving compare, sexp, yojson, hash, equal]\n end\n end]\n\n type ('messages_for_next_wrap_proof, 'messages_for_next_step_proof) t =\n ( 'messages_for_next_wrap_proof\n , 'messages_for_next_step_proof )\n Stable.Latest.t =\n { statement :\n ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Tick.Field.t Shifted_value.Type1.t\n , bool\n , 'messages_for_next_wrap_proof\n , Digest.Constant.t\n , 'messages_for_next_step_proof\n , Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n , Branch_data.t )\n Types.Wrap.Statement.Minimal.t\n ; prev_evals : (Tick.Field.t, Tick.Field.t array) Plonk_types.All_evals.t\n ; proof : Wrap_wire_proof.t\n }\n [@@deriving compare, sexp, yojson, hash, equal]\n end\nend\n\ntype ('s, 'mlmb, 'c) with_data =\n ('s, 'mlmb, 'c) Mina_wire_types.Pickles.Concrete_.Proof.with_data =\n | T :\n ( 'mlmb Base.Messages_for_next_proof_over_same_field.Wrap.t\n , ( 's\n , (Tock.Curve.Affine.t, 'most_recent_width) Vector.t\n , ( Challenge.Constant.t Scalar_challenge.Stable.Latest.t\n Bulletproof_challenge.t\n Step_bp_vec.t\n , 'most_recent_width )\n Vector.t )\n Base.Messages_for_next_proof_over_same_field.Step.t )\n Base.Wrap.t\n -> ('s, 'mlmb, _) with_data\n\nmodule With_data = struct\n type ('s, 'mlmb, 'w) t = ('s, 'mlmb, 'w) with_data\nend\n\ntype ('max_width, 'mlmb) t = (unit, 'mlmb, 'max_width) With_data.t\n\nlet dummy (type w h r) (_w : w Nat.t) (h : h Nat.t)\n (most_recent_width : r Nat.t) ~domain_log2 : (w, h) t =\n let open Ro in\n let g0 = Tock.Curve.(to_affine_exn one) in\n let g len = Array.create ~len g0 in\n let tick_arr len = Array.init len ~f:(fun _ -> tick ()) in\n let lengths = Commitment_lengths.default in\n T\n { statement =\n { proof_state =\n { deferred_values =\n { branch_data =\n { proofs_verified =\n ( match most_recent_width with\n | Z ->\n N0\n | S Z ->\n N1\n | S (S Z) ->\n N2\n | S _ ->\n assert false )\n ; domain_log2 =\n Branch_data.Domain_log2.of_int_exn domain_log2\n }\n ; bulletproof_challenges = Dummy.Ipa.Step.challenges\n ; plonk =\n { alpha = scalar_chal ()\n ; beta = chal ()\n ; gamma = chal ()\n ; zeta = scalar_chal ()\n ; joint_combiner = None\n ; feature_flags = Plonk_types.Features.none_bool\n }\n }\n ; sponge_digest_before_evaluations =\n Digest.Constant.of_tock_field Tock.Field.zero\n ; messages_for_next_wrap_proof =\n { challenge_polynomial_commitment = Lazy.force Dummy.Ipa.Step.sg\n ; old_bulletproof_challenges =\n Vector.init h ~f:(fun _ -> Dummy.Ipa.Wrap.challenges)\n }\n }\n ; messages_for_next_step_proof =\n { app_state = ()\n ; old_bulletproof_challenges =\n (* Not sure if this should be w or h honestly ...*)\n Vector.init most_recent_width ~f:(fun _ ->\n Dummy.Ipa.Step.challenges )\n (* TODO: Should this be wrap? *)\n ; challenge_polynomial_commitments =\n Vector.init most_recent_width ~f:(fun _ ->\n Lazy.force Dummy.Ipa.Wrap.sg )\n }\n }\n ; proof =\n Wrap_wire_proof.of_kimchi_proof\n { messages =\n { w_comm = Vector.map lengths.w ~f:g\n ; z_comm = g lengths.z\n ; t_comm = g lengths.t\n ; lookup = None\n }\n ; openings =\n (let evals = Lazy.force Dummy.evals in\n { proof =\n { lr =\n Array.init (Nat.to_int Tock.Rounds.n) ~f:(fun _ ->\n (g0, g0) )\n ; z_1 = Ro.tock ()\n ; z_2 = Ro.tock ()\n ; delta = g0\n ; challenge_polynomial_commitment = g0\n }\n ; evals = evals.evals.evals\n ; ft_eval1 = evals.ft_eval1\n } )\n }\n ; prev_evals =\n (let e =\n Plonk_types.Evals.map Evaluation_lengths.default ~f:(fun n ->\n (tick_arr n, tick_arr n) )\n in\n let ex =\n { Plonk_types.All_evals.With_public_input.public_input =\n (tick (), tick ())\n ; evals = e\n }\n in\n { ft_eval1 = tick (); evals = ex } )\n }\n\nmodule Make (W : Nat.Intf) (MLMB : Nat.Intf) = struct\n module Max_proofs_verified_at_most = At_most.With_length (W)\n module MLMB_vec = Nvector (MLMB)\n\n module Repr = struct\n type t =\n ( ( Tock.Inner_curve.Affine.t\n , Reduced_messages_for_next_proof_over_same_field.Wrap.Challenges_vector\n .t\n MLMB_vec.t )\n Types.Wrap.Proof_state.Messages_for_next_wrap_proof.t\n , ( unit\n , Tock.Curve.Affine.t Max_proofs_verified_at_most.t\n , Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n Max_proofs_verified_at_most.t )\n Base.Messages_for_next_proof_over_same_field.Step.t )\n Base.Wrap.t\n [@@deriving compare, sexp, yojson, hash, equal]\n end\n\n type nonrec t = (W.n, MLMB.n) t\n\n let to_repr (T t) : Repr.t =\n let lte =\n Nat.lte_exn\n (Vector.length\n t.statement.messages_for_next_step_proof\n .challenge_polynomial_commitments )\n W.n\n in\n { t with\n statement =\n { t.statement with\n messages_for_next_step_proof =\n { t.statement.messages_for_next_step_proof with\n challenge_polynomial_commitments =\n At_most.of_vector\n t.statement.messages_for_next_step_proof\n .challenge_polynomial_commitments lte\n ; old_bulletproof_challenges =\n At_most.of_vector\n t.statement.messages_for_next_step_proof\n .old_bulletproof_challenges lte\n }\n }\n }\n\n let of_repr (r : Repr.t) : t =\n let (Vector.T challenge_polynomial_commitments) =\n At_most.to_vector\n r.statement.messages_for_next_step_proof\n .challenge_polynomial_commitments\n in\n let (Vector.T old_bulletproof_challenges) =\n At_most.to_vector\n r.statement.messages_for_next_step_proof.old_bulletproof_challenges\n in\n let T =\n Nat.eq_exn\n (Vector.length challenge_polynomial_commitments)\n (Vector.length old_bulletproof_challenges)\n in\n T\n { r with\n statement =\n { r.statement with\n messages_for_next_step_proof =\n { r.statement.messages_for_next_step_proof with\n challenge_polynomial_commitments\n ; old_bulletproof_challenges\n }\n }\n }\n\n let compare t1 t2 = Repr.compare (to_repr t1) (to_repr t2)\n\n let equal t1 t2 = Repr.equal (to_repr t1) (to_repr t2)\n\n let hash_fold_t s t = Repr.hash_fold_t s (to_repr t)\n\n let hash t = Repr.hash (to_repr t)\n\n include\n Sexpable.Of_sexpable\n (Repr)\n (struct\n type nonrec t = t\n\n let to_sexpable = to_repr\n\n let of_sexpable = of_repr\n end)\n\n let to_base64 t =\n (* assume call to Nat.lte_exn does not raise with a valid instance of t *)\n let sexp = sexp_of_t t in\n (* raises only on invalid optional arguments *)\n Base64.encode_exn (Sexp.to_string sexp)\n\n let of_base64 b64 =\n match Base64.decode b64 with\n | Ok t -> (\n try Ok (t_of_sexp (Sexp.of_string t))\n with exn -> Error (Exn.to_string exn) )\n | Error (`Msg s) ->\n Error s\n\n let to_yojson_full x = Repr.to_yojson (to_repr x)\n\n let to_yojson x = `String (to_base64 x)\n\n let of_yojson = function\n | `String x ->\n of_base64 x\n | _ ->\n Error \"Invalid json for proof. Expecting base64 encoded string\"\nend\n\nmodule Proofs_verified_2 = struct\n module T = Make (Nat.N2) (Nat.N2)\n\n module Repr = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t =\n ( ( Tock.Inner_curve.Affine.Stable.V1.t\n , Reduced_messages_for_next_proof_over_same_field.Wrap\n .Challenges_vector\n .Stable\n .V2\n .t\n Vector.Vector_2.Stable.V1.t )\n Types.Wrap.Proof_state.Messages_for_next_wrap_proof.Stable.V1.t\n , ( unit\n , Tock.Curve.Affine.t At_most.At_most_2.Stable.V1.t\n , Limb_vector.Constant.Hex64.Stable.V1.t Vector.Vector_2.Stable.V1.t\n Scalar_challenge.Stable.V2.t\n Bulletproof_challenge.Stable.V1.t\n Step_bp_vec.Stable.V1.t\n At_most.At_most_2.Stable.V1.t )\n Base.Messages_for_next_proof_over_same_field.Step.Stable.V1.t )\n Base.Wrap.Stable.V2.t\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n include T.Repr\n\n (* Force the typechecker to verify that these types are equal. *)\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n end\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t = T.t\n\n let to_latest = Fn.id\n\n include (T : module type of T with type t := t with module Repr := T.Repr)\n\n include\n Binable.Of_binable\n (Repr.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable = to_repr\n\n let of_binable = of_repr\n end)\n end\n end]\n\n include (T : module type of T with module Repr := T.Repr)\nend\n\nmodule Proofs_verified_max = struct\n module T =\n Make\n (Side_loaded_verification_key.Width.Max)\n (Side_loaded_verification_key.Width.Max)\n\n module Repr = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t =\n ( ( Tock.Inner_curve.Affine.Stable.V1.t\n , Reduced_messages_for_next_proof_over_same_field.Wrap\n .Challenges_vector\n .Stable\n .V2\n .t\n Side_loaded_verification_key.Width.Max_vector.Stable.V1.t )\n Types.Wrap.Proof_state.Messages_for_next_wrap_proof.Stable.V1.t\n , ( unit\n , Tock.Curve.Affine.t\n Side_loaded_verification_key.Width.Max_at_most.Stable.V1.t\n , Limb_vector.Constant.Hex64.Stable.V1.t Vector.Vector_2.Stable.V1.t\n Scalar_challenge.Stable.V2.t\n Bulletproof_challenge.Stable.V1.t\n Step_bp_vec.Stable.V1.t\n Side_loaded_verification_key.Width.Max_at_most.Stable.V1.t )\n Base.Messages_for_next_proof_over_same_field.Step.Stable.V1.t )\n Base.Wrap.Stable.V2.t\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n include T.Repr\n\n (* Force the typechecker to verify that these types are equal. *)\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n end\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t = T.t\n\n let to_latest = Fn.id\n\n include (T : module type of T with type t := t with module Repr := T.Repr)\n\n include\n Binable.Of_binable\n (Repr.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable = to_repr\n\n let of_binable = of_repr\n end)\n end\n end]\n\n include (T : module type of T with module Repr := T.Repr)\nend\n","open Core_kernel\nopen Backend\nmodule Me = Tock\nmodule Other = Tick\nmodule Impl = Impls.Wrap\n\nlet _high_entropy_bits = 128\n\nlet sponge_params_constant = Kimchi_pasta_basic.poseidon_params_fq\n\nlet field_random_oracle ?(length = Me.Field.size_in_bits - 1) s =\n Me.Field.of_bits (Ro.bits_random_oracle ~length s)\n\nlet _unrelated_g =\n let open Common in\n let group_map =\n unstage\n (group_map\n (module Me.Field)\n ~a:Me.Inner_curve.Params.a ~b:Me.Inner_curve.Params.b )\n and str = Fn.compose bits_to_bytes Me.Field.to_bits in\n fun (x, y) -> group_map (field_random_oracle (str x ^ str y))\n\nopen Impl\n\n(* Debug helper to convert wrap circuit field element to a hex string *)\nlet read_wrap_circuit_field_element_as_hex fe =\n let prover_fe = As_prover.read Field.typ fe in\n Kimchi_backend.Pasta.Pallas_based_plonk.(\n Bigint.to_hex (Field.to_bigint prover_fe))\n\nmodule Other_field = struct\n type t = Impls.Step.Field.Constant.t [@@deriving sexp]\n\n include (Tick.Field : module type of Tick.Field with type t := t)\n\n let size = Impls.Step.Bigint.to_bignum_bigint size\nend\n\nlet sponge_params =\n Sponge.Params.(map sponge_params_constant ~f:Impl.Field.constant)\n\nmodule Unsafe = struct\n let unpack_unboolean ?(length = Field.size_in_bits) x =\n let res =\n exists\n (Typ.list Boolean.typ_unchecked ~length)\n ~compute:\n As_prover.(\n fun () -> List.take (Field.Constant.unpack (read_var x)) length)\n in\n Field.Assert.equal x (Field.project res) ;\n res\nend\n\nmodule Sponge = struct\n module Permutation =\n Sponge_inputs.Make\n (Impl)\n (struct\n include Tock_field_sponge.Inputs\n\n let params = Tock_field_sponge.params\n end)\n\n module S = Sponge.Make_debug_sponge (struct\n include Permutation\n module Circuit = Impls.Wrap\n\n (* Optional sponge name used in debug mode *)\n let sponge_name = \"wrap\"\n\n (* To enable debug mode, set environment variable [sponge_name] to \"t\", \"1\" or \"true\". *)\n let debug_helper_fn = read_wrap_circuit_field_element_as_hex\n end)\n\n include S\n\n let squeeze_field = squeeze\n\n let squeeze = squeeze\nend\n\nlet%test_unit \"sponge\" =\n let module T = Make_sponge.Test (Impl) (Tock_field_sponge.Field) (Sponge.S) in\n T.test Tock_field_sponge.params\n\n(* module Input_domain = struct\n let _lagrange_commitments domain : Backend.Tock.Inner_curve.Affine.t array =\n let domain_size = Import.Domain.size domain in\n Common.time \"lagrange\" (fun () ->\n Array.init domain_size ~f:(fun i ->\n (Kimchi_bindings.Protocol.SRS.Fp.lagrange_commitment\n (Backend.Tick.Keypair.load_urs ())\n domain_size i )\n .unshifted.(0)\n |> Common.finite_exn ) )\n\n let _domain = Import.Domain.Pow_2_roots_of_unity 7\n end *)\n\nmodule Inner_curve = struct\n module C = Kimchi_pasta.Pasta.Vesta\n\n module Inputs = struct\n module Impl = Impl\n\n module Params = struct\n include C.Params\n\n let one = C.to_affine_exn C.one\n\n let group_size_in_bits = Field.size_in_bits\n end\n\n module F = struct\n include struct\n open Impl.Field\n\n type nonrec t = t\n\n let ( * ), ( + ), ( - ), inv_exn, square, scale, if_, typ, constant =\n (( * ), ( + ), ( - ), inv, square, scale, if_, typ, constant)\n\n let negate x = scale x Constant.(negate one)\n end\n\n module Constant = struct\n open Impl.Field.Constant\n\n type nonrec t = t\n\n let ( * ), ( + ), ( - ), inv_exn, square, negate =\n (( * ), ( + ), ( - ), inv, square, negate)\n end\n\n let assert_square x y = Impl.assert_square x y\n\n let assert_r1cs x y z = Impl.assert_r1cs x y z\n end\n\n module Constant = struct\n include C.Affine\n module Scalar = Impls.Step.Field.Constant\n\n let scale (t : t) (x : Scalar.t) : t =\n C.(to_affine_exn (scale (of_affine t) x))\n\n let random () : t = C.(to_affine_exn (random ()))\n\n let zero = Impl.Field.Constant.(zero, zero)\n\n let ( + ) t1 t2 : t =\n let is_zero (x, _) = Impl.Field.Constant.(equal zero x) in\n if is_zero t1 then t2\n else if is_zero t2 then t1\n else\n let r = C.(of_affine t1 + of_affine t2) in\n try C.to_affine_exn r with _ -> zero\n\n let negate x : t = C.(to_affine_exn (negate (of_affine x)))\n\n let to_affine_exn = Fn.id\n\n let of_affine = Fn.id\n end\n end\n\n module Params = Inputs.Params\n module Constant = Inputs.Constant\n module T = Snarky_curve.For_native_base_field (Inputs)\n\n include (\n T :\n module type of T\n with module Scaling_precomputation := T.Scaling_precomputation )\n\n module Scaling_precomputation = T.Scaling_precomputation\n\n let ( + ) t1 t2 = Plonk_curve_ops.add_fast (module Impl) t1 t2\n\n let double t = t + t\n\n let scale t bs =\n with_label __LOC__ (fun () ->\n T.scale t (Bitstring_lib.Bitstring.Lsb_first.of_list bs) )\n\n let to_field_elements (x, y) = [ x; y ]\n\n let assert_equal (x1, y1) (x2, y2) =\n Field.Assert.equal x1 x2 ; Field.Assert.equal y1 y2\n\n let scale_inv t bs =\n let res =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n C.scale\n (C.of_affine (read typ t))\n (Other.Field.inv\n (Other.Field.of_bits (List.map ~f:(read Boolean.typ) bs)) )\n |> C.to_affine_exn)\n in\n assert_equal t (scale res bs) ;\n res\n\n let negate = T.negate\n\n let one = T.one\n\n let if_ = T.if_\nend\n\nmodule Ops = Plonk_curve_ops.Make (Impl) (Inner_curve)\n\nmodule Generators = struct\n let h =\n lazy\n ( Kimchi_bindings.Protocol.SRS.Fp.urs_h (Backend.Tick.Keypair.load_urs ())\n |> Common.finite_exn )\nend\n","module S = Sponge\nopen Core_kernel\nopen Util\nmodule SC = Scalar_challenge\nopen Pickles_types\nopen Plonk_types\nopen Tuple_lib\nopen Import\n\n(* G is for Generic. This module is just to protect {!val:challenge_polynomial}\n below from being hidden by the included functor application at the end of\n the module, so that we can re-export it in the end. *)\nmodule G = struct\n (* given [chals], compute\n \\prod_i (1 + chals.(i) * x^{2^{k - 1 - i}}) *)\n let challenge_polynomial (type a)\n (module M : Pickles_types.Shifted_value.Field_intf with type t = a) chals\n : (a -> a) Staged.t =\n stage (fun pt ->\n let k = Array.length chals in\n let pow_two_pows =\n let res = Array.init k ~f:(fun _ -> pt) in\n for i = 1 to k - 1 do\n let y = res.(i - 1) in\n res.(i) <- M.(y * y)\n done ;\n res\n in\n let prod f =\n let r = ref (f 0) in\n for i = 1 to k - 1 do\n r := M.(f i * !r)\n done ;\n !r\n in\n prod (fun i ->\n let idx = k - 1 - i in\n M.(one + (chals.(i) * pow_two_pows.(idx))) ) )\n\n let num_possible_domains = Nat.S Wrap_hack.Padded_length.n\n\n let all_possible_domains =\n Memo.unit (fun () ->\n Vector.init num_possible_domains ~f:(fun proofs_verified ->\n (Common.wrap_domains ~proofs_verified).h ) )\nend\n\nmodule Make\n (Inputs : Intf.Wrap_main_inputs.S\n with type Impl.field = Backend.Tock.Field.t\n and type Impl.Bigint.t = Backend.Tock.Bigint.t\n and type Inner_curve.Constant.Scalar.t = Backend.Tick.Field.t) =\nstruct\n open Inputs\n open Impl\n\n module Other_field = struct\n module Packed = struct\n module Constant = Other_field\n\n type t = Impls.Wrap.Other_field.t\n\n let typ = Impls.Wrap.Other_field.typ\n\n let _to_bits_unsafe (x : t) = Wrap_main_inputs.Unsafe.unpack_unboolean x\n\n let absorb_shifted sponge (x : t Shifted_value.Type1.t) =\n match x with Shifted_value x -> Sponge.absorb sponge x\n end\n\n module With_top_bit0 = struct\n (* When the top bit is 0, there is no need to check that this is not\n equal to one of the forbidden values. The scaling is safe. *)\n module Constant = Other_field\n\n type t = Impls.Wrap.Other_field.t\n\n let typ = Impls.Wrap.Other_field.typ_unchecked\n\n let _absorb_shifted sponge (x : t Pickles_types.Shifted_value.Type1.t) =\n match x with Shifted_value x -> Sponge.absorb sponge x\n end\n end\n\n let num_possible_domains = G.num_possible_domains\n\n let all_possible_domains = G.all_possible_domains\n\n let print_g lab (x, y) =\n if debug then\n as_prover\n As_prover.(\n fun () ->\n printf\n !\"%s: %{sexp:Backend.Tock.Field.t}, %{sexp:Backend.Tock.Field.t}\\n\\\n %!\"\n lab (read_var x) (read_var y))\n\n let _print_w lab gs =\n if Import.debug then\n Array.iteri gs ~f:(fun i (fin, g) ->\n as_prover\n As_prover.(fun () -> printf \"fin=%b %!\" (read Boolean.typ fin)) ;\n ksprintf print_g \"%s[%d]\" lab i g )\n\n let _print_chal lab x =\n if Import.debug then\n as_prover\n As_prover.(\n fun () ->\n printf \"in-snark %s:%!\" lab ;\n Field.Constant.print\n (Field.Constant.project (List.map ~f:(read Boolean.typ) x)) ;\n printf \"\\n%!\")\n\n let print_bool lab x =\n if debug then\n as_prover (fun () ->\n printf \"%s: %b\\n%!\" lab (As_prover.read Boolean.typ x) )\n\n module Challenge = Challenge.Make (Impl)\n module Digest = Digest.Make (Impl)\n module Scalar_challenge =\n SC.Make (Impl) (Inner_curve) (Challenge) (Endo.Wrap_inner_curve)\n module Ops = Plonk_curve_ops.Make (Impl) (Inner_curve)\n\n let _product m f =\n Core_kernel.List.reduce_exn (Core_kernel.List.init m ~f) ~f:Field.( * )\n\n let absorb sponge ty t =\n absorb\n ~mask_g1_opt:(fun () -> assert false)\n ~absorb_field:(Sponge.absorb sponge)\n ~g1_to_field_elements:Inner_curve.to_field_elements\n ~absorb_scalar:(Sponge.absorb sponge) ty t\n\n let scalar_to_field s =\n SC.to_field_checked (module Impl) s ~endo:Endo.Step_inner_curve.scalar\n\n let assert_n_bits ~n a =\n (* Scalar_challenge.to_field_checked has the side effect of\n checking that the input fits in n bits. *)\n ignore\n ( SC.to_field_checked\n (module Impl)\n (Import.Scalar_challenge.create a)\n ~endo:Endo.Step_inner_curve.scalar ~num_bits:n\n : Field.t )\n\n let lowest_128_bits ~constrain_low_bits x =\n let assert_128_bits = assert_n_bits ~n:128 in\n Util.lowest_128_bits ~constrain_low_bits ~assert_128_bits (module Impl) x\n\n let squeeze_challenge sponge : Field.t =\n lowest_128_bits (* I think you may not have to constrain these actually *)\n ~constrain_low_bits:true (Sponge.squeeze sponge)\n\n let squeeze_scalar sponge : Field.t Import.Scalar_challenge.t =\n (* No need to boolean constrain scalar challenges. *)\n Import.Scalar_challenge.create\n (lowest_128_bits ~constrain_low_bits:false (Sponge.squeeze sponge))\n\n let bullet_reduce sponge gammas =\n let absorb t = absorb sponge t in\n let prechallenges =\n Array.map gammas ~f:(fun gammas_i ->\n absorb (PC :: PC) gammas_i ;\n squeeze_scalar sponge )\n in\n let term_and_challenge (l, r) pre =\n let left_term = Scalar_challenge.endo_inv l pre in\n let right_term = Scalar_challenge.endo r pre in\n (Ops.add_fast left_term right_term, Bulletproof_challenge.unpack pre)\n in\n let terms, challenges =\n Array.map2_exn gammas prechallenges ~f:term_and_challenge |> Array.unzip\n in\n\n (Array.reduce_exn terms ~f:(Ops.add_fast ?check_finite:None), challenges)\n\n let equal_g g1 g2 =\n List.map2_exn ~f:Field.equal\n (Inner_curve.to_field_elements g1)\n (Inner_curve.to_field_elements g2)\n |> Boolean.all\n\n module One_hot_vector = One_hot_vector.Make (Impl)\n\n type ('a, 'a_opt) index' = ('a, 'a_opt) Plonk_verification_key_evals.Step.t\n\n (* Mask out the given vector of indices with the given one-hot vector *)\n let choose_key :\n type n.\n n One_hot_vector.t\n -> ( (Inner_curve.t, (Inner_curve.t, Boolean.var) Opt.t) index'\n , n )\n Vector.t\n -> (Inner_curve.t, (Inner_curve.t, Boolean.var) Opt.t) index' =\n let open Tuple_lib in\n fun bs keys ->\n let open Field in\n Vector.map2\n (bs :> (Boolean.var, n) Vector.t)\n keys\n ~f:(fun b key ->\n Plonk_verification_key_evals.Step.map key\n ~f:(fun g -> Double.map g ~f:(( * ) (b :> t)))\n ~f_opt:(function\n (* Here, we split the 3 variants into 3 separate accumulators. This\n allows us to only compute the 'maybe' flag when we need to, and\n allows us to fall back to the basically-free `None` when a\n feature is entirely unused, or to the less expensive `Some` if\n it is used for every circuit.\n In particular, it is important that we generate exactly `None`\n when none of the optional gates are used, otherwise we will\n change the serialization of the protocol circuits.\n *)\n | Opt.Nothing ->\n ([], [], [ b ])\n | Opt.Maybe (b_x, x) ->\n ([], [ (b, b_x, x) ], [])\n | Opt.Just x ->\n ([ (b, x) ], [], []) ) )\n |> Vector.reduce_exn\n ~f:\n (Plonk_verification_key_evals.Step.map2 ~f:(Double.map2 ~f:( + ))\n ~f_opt:(fun (yes_1, maybe_1, no_1) (yes_2, maybe_2, no_2) ->\n (yes_1 @ yes_2, maybe_1 @ maybe_2, no_1 @ no_2) ) )\n |> Plonk_verification_key_evals.Step.map ~f:Fn.id ~f_opt:(function\n | [], [], _nones ->\n (* We only have `None`s, so we can emit exactly `None` without\n further computation.\n *)\n Opt.Nothing\n | somes, [], [] ->\n (* Special case: we don't need to compute the 'maybe' bool\n because we know statically that all entries are `Some`.\n *)\n let sum =\n somes\n |> List.map ~f:(fun ((b : Boolean.var), g) ->\n Double.map g ~f:(( * ) (b :> t)) )\n |> List.reduce_exn ~f:(Double.map2 ~f:( + ))\n in\n Opt.just sum\n | somes, maybes, nones ->\n let is_none =\n List.reduce nones\n ~f:(fun (b1 : Boolean.var) (b2 : Boolean.var) ->\n Boolean.Unsafe.of_cvar Field.(add (b1 :> t) (b2 :> t)) )\n in\n let none_sum =\n Option.map is_none ~f:(fun (b : Boolean.var) ->\n Double.map Inner_curve.one ~f:(( * ) (b :> t)) )\n in\n let some_is_yes, some_sum =\n somes\n |> List.map ~f:(fun ((b : Boolean.var), g) ->\n (b, Double.map g ~f:(( * ) (b :> t))) )\n |> List.reduce\n ~f:(fun ((b1 : Boolean.var), g1) ((b2 : Boolean.var), g2)\n ->\n ( Boolean.Unsafe.of_cvar Field.(add (b1 :> t) (b2 :> t))\n , Double.map2 ~f:( + ) g1 g2 ) )\n |> fun x -> (Option.map ~f:fst x, Option.map ~f:snd x)\n in\n let maybe_is_yes, maybe_sum =\n maybes\n |> List.map\n ~f:(fun ((b : Boolean.var), (b_g : Boolean.var), g) ->\n ( Boolean.Unsafe.of_cvar Field.(mul (b :> t) (b_g :> t))\n , Double.map g ~f:(( * ) (b :> t)) ) )\n |> List.reduce\n ~f:(fun ((b1 : Boolean.var), g1) ((b2 : Boolean.var), g2)\n ->\n ( Boolean.Unsafe.of_cvar Field.(add (b1 :> t) (b2 :> t))\n , Double.map2 ~f:( + ) g1 g2 ) )\n |> fun x -> (Option.map ~f:fst x, Option.map ~f:snd x)\n in\n let is_yes =\n [| some_is_yes; maybe_is_yes |]\n |> Array.filter_map ~f:Fn.id\n |> Array.reduce_exn\n ~f:(fun (b1 : Boolean.var) (b2 : Boolean.var) ->\n Boolean.Unsafe.of_cvar ((b1 :> t) + (b2 :> t)) )\n in\n let sum =\n [| none_sum; maybe_sum; some_sum |]\n |> Array.filter_map ~f:Fn.id\n |> Array.reduce_exn ~f:(Double.map2 ~f:( + ))\n in\n Opt.Maybe (is_yes, sum) )\n\n (* TODO: Unify with the code in step_verifier *)\n let lagrange (type n)\n ~domain:\n ( (which_branch : n One_hot_vector.t)\n , (domains : (Domains.t, n) Vector.t) ) srs i =\n Vector.map domains ~f:(fun d ->\n let d = Int.pow 2 (Domain.log2_size d.h) in\n match[@warning \"-4\"]\n (Kimchi_bindings.Protocol.SRS.Fp.lagrange_commitment srs d i)\n .unshifted\n with\n | [| Finite g |] ->\n let g = Inner_curve.Constant.of_affine g in\n Inner_curve.constant g\n | _ ->\n assert false )\n |> Vector.map2\n (which_branch :> (Boolean.var, n) Vector.t)\n ~f:(fun b (x, y) -> Field.((b :> t) * x, (b :> t) * y))\n |> Vector.reduce_exn ~f:(Double.map2 ~f:Field.( + ))\n\n let scaled_lagrange (type n) c\n ~domain:\n ( (which_branch : n One_hot_vector.t)\n , (domains : (Domains.t, n) Vector.t) ) srs i =\n Vector.map domains ~f:(fun d ->\n let d = Int.pow 2 (Domain.log2_size d.h) in\n match[@warning \"-4\"]\n (Kimchi_bindings.Protocol.SRS.Fp.lagrange_commitment srs d i)\n .unshifted\n with\n | [| Finite g |] ->\n let g = Inner_curve.Constant.of_affine g in\n Inner_curve.Constant.scale g c |> Inner_curve.constant\n | _ ->\n assert false )\n |> Vector.map2\n (which_branch :> (Boolean.var, n) Vector.t)\n ~f:(fun b (x, y) -> Field.((b :> t) * x, (b :> t) * y))\n |> Vector.reduce_exn ~f:(Double.map2 ~f:Field.( + ))\n\n let lagrange_with_correction (type n) ~input_length\n ~domain:\n ( (which_branch : n One_hot_vector.t)\n , (domains : (Domains.t, n) Vector.t) ) srs i : Inner_curve.t Double.t =\n with_label __LOC__ (fun () ->\n let actual_shift =\n (* TODO: num_bits should maybe be input_length - 1. *)\n Ops.bits_per_chunk * Ops.chunks_needed ~num_bits:input_length\n in\n let rec pow2pow x i =\n if i = 0 then x else pow2pow Inner_curve.Constant.(x + x) (i - 1)\n in\n let base_and_correction (h : Domain.t) =\n let d = Int.pow 2 (Domain.log2_size h) in\n match[@warning \"-4\"]\n (Kimchi_bindings.Protocol.SRS.Fp.lagrange_commitment srs d i)\n .unshifted\n with\n | [| Finite g |] ->\n let open Inner_curve.Constant in\n let g = of_affine g in\n ( Inner_curve.constant g\n , Inner_curve.constant (negate (pow2pow g actual_shift)) )\n | xs ->\n failwithf \"expected commitment to have length 1. got %d\"\n (Array.length xs) ()\n in\n match domains with\n | [] ->\n assert false\n | d :: ds ->\n if Vector.for_all ds ~f:(fun d' -> Domain.equal d.h d'.h) then\n base_and_correction d.h\n else\n Vector.map domains ~f:(fun (ds : Domains.t) ->\n base_and_correction ds.h )\n |> Vector.map2\n (which_branch :> (Boolean.var, n) Vector.t)\n ~f:(fun b pr ->\n Double.map pr ~f:(fun (x, y) ->\n Field.((b :> t) * x, (b :> t) * y) ) )\n |> Vector.reduce_exn\n ~f:(Double.map2 ~f:(Double.map2 ~f:Field.( + )))\n |> Double.map ~f:(Double.map ~f:(Util.seal (module Impl))) )\n\n let _h_precomp =\n Lazy.map ~f:Inner_curve.Scaling_precomputation.create Generators.h\n\n let group_map =\n let f =\n lazy\n (let module M =\n Group_map.Bw19.Make (Field.Constant) (Field)\n (struct\n let params =\n Group_map.Bw19.Params.create\n (module Field.Constant)\n { b = Inner_curve.Params.b }\n end)\n in\n let open M in\n Snarky_group_map.Checked.wrap\n (module Impl)\n ~potential_xs\n ~y_squared:(fun ~x ->\n Field.(\n (x * x * x)\n + (constant Inner_curve.Params.a * x)\n + constant Inner_curve.Params.b) )\n |> unstage )\n in\n fun x -> Lazy.force f x\n\n module Split_commitments = struct\n module Point = struct\n type t =\n [ `Finite of Inner_curve.t\n | `Maybe_finite of Boolean.var * Inner_curve.t ]\n\n let finite : t -> Boolean.var = function\n | `Finite _ ->\n Boolean.true_\n | `Maybe_finite (b, _) ->\n b\n\n let add (p : t) (q : Inner_curve.t) =\n match p with\n | `Finite p ->\n Ops.add_fast p q\n | `Maybe_finite (finite, p) ->\n Inner_curve.if_ finite ~then_:(Ops.add_fast p q) ~else_:q\n\n let underlying = function `Finite p -> p | `Maybe_finite (_, p) -> p\n end\n\n module Curve_opt = struct\n type t = { point : Inner_curve.t; non_zero : Boolean.var }\n end\n\n let combine batch ~xi without_bound with_bound =\n let { Curve_opt.non_zero; point } =\n Pcs_batch.combine_split_commitments batch\n ~scale_and_add:(fun ~(acc : Curve_opt.t) ~xi\n (p : (Point.t, Boolean.var) Opt.t) ->\n (* match acc.non_zero, keep with\n | false, false -> acc\n | true, false -> acc\n | false, true -> { point= p; non_zero= true }\n | true, true -> { point= p + xi * acc; non_zero= true }\n *)\n let point keep p =\n let point =\n Inner_curve.(\n if_ keep\n ~then_:\n (if_ acc.non_zero\n ~then_:\n (Point.add p (Scalar_challenge.endo acc.point xi))\n ~else_:\n ((* In this branch, the accumulator was zero, so there is no harm in\n putting the potentially junk underlying point here. *)\n Point.underlying p ) )\n ~else_:acc.point)\n in\n let non_zero =\n Boolean.(keep &&& Point.finite p ||| acc.non_zero)\n in\n { Curve_opt.non_zero; point }\n in\n match p with\n | Opt.Nothing ->\n acc\n | Opt.Maybe (keep, p) ->\n point keep p\n | Opt.Just p ->\n point Boolean.true_ p )\n ~xi\n ~init:(function\n | Opt.Nothing ->\n None\n | Opt.Maybe (keep, p) ->\n Some\n { non_zero = Boolean.(keep &&& Point.finite p)\n ; point = Point.underlying p\n }\n | Opt.Just p ->\n Some\n { non_zero = Boolean.(true_ &&& Point.finite p)\n ; point = Point.underlying p\n } )\n without_bound with_bound\n in\n Boolean.Assert.is_true non_zero ;\n point\n end\n\n let scale_fast = Ops.scale_fast\n\n let check_bulletproof ~pcs_batch ~(sponge : Sponge.t)\n ~(xi : Scalar_challenge.t)\n ~(advice :\n Other_field.Packed.t Shifted_value.Type1.t\n Types.Step.Bulletproof.Advice.t )\n ~polynomials:(without_degree_bound, with_degree_bound)\n ~openings_proof:\n ({ lr; delta; z_1; z_2; challenge_polynomial_commitment } :\n ( Inner_curve.t\n , Other_field.Packed.t Shifted_value.Type1.t )\n Openings.Bulletproof.t ) =\n with_label __LOC__ (fun () ->\n Other_field.Packed.absorb_shifted sponge advice.combined_inner_product ;\n (* combined_inner_product should be equal to\n sum_i < t, r^i pows(beta_i) >\n = sum_i r^i < t, pows(beta_i) >\n\n That is checked later.\n *)\n let u =\n let t = Sponge.squeeze_field sponge in\n group_map t\n in\n let open Inner_curve in\n let combined_polynomial (* Corresponds to xi in figure 7 of WTS *) =\n Split_commitments.combine pcs_batch ~xi without_degree_bound\n with_degree_bound\n in\n let scale_fast =\n scale_fast ~num_bits:Other_field.Packed.Constant.size_in_bits\n in\n let lr_prod, challenges = bullet_reduce sponge lr in\n let p_prime =\n let uc = scale_fast u advice.combined_inner_product in\n combined_polynomial + uc\n in\n let q = p_prime + lr_prod in\n absorb sponge PC delta ;\n let c = squeeze_scalar sponge in\n (* c Q + delta = z1 (G + b U) + z2 H *)\n let lhs =\n let cq = Scalar_challenge.endo q c in\n cq + delta\n in\n let rhs =\n let b_u = scale_fast u advice.b in\n let z_1_g_plus_b_u =\n scale_fast (challenge_polynomial_commitment + b_u) z_1\n in\n let z2_h =\n scale_fast (Inner_curve.constant (Lazy.force Generators.h)) z_2\n in\n z_1_g_plus_b_u + z2_h\n in\n (`Success (equal_g lhs rhs), challenges) )\n\n module Opt = struct\n include Opt_sponge.Make (Impl) (Wrap_main_inputs.Sponge.Permutation)\n\n let challenge (s : t) : Field.t =\n lowest_128_bits (squeeze s) ~constrain_low_bits:true\n\n (* No need to boolean constrain scalar challenges. *)\n let scalar_challenge (s : t) : Scalar_challenge.t =\n Import.Scalar_challenge.create\n (lowest_128_bits (squeeze s) ~constrain_low_bits:false)\n end\n\n (* TODO: This doesn't need to be an opt sponge *)\n let absorb sponge ty t =\n Util.absorb ~absorb_field:(Opt.absorb sponge)\n ~g1_to_field_elements:(fun (b, (x, y)) -> [ (b, x); (b, y) ])\n ~absorb_scalar:(fun x -> Opt.absorb sponge (Boolean.true_, x))\n ~mask_g1_opt:(fun ((finite : Boolean.var), (x, y)) ->\n (Boolean.true_, Field.((finite :> t) * x, (finite :> t) * y)) )\n ty t\n\n module Pseudo = Pseudo.Make (Impl)\n\n let mask (type n) (lengths : (int, n) Vector.t) (choice : n One_hot_vector.t)\n : Boolean.var array =\n let max =\n Option.value_exn\n (List.max_elt ~compare:Int.compare (Vector.to_list lengths))\n in\n let length = Pseudo.choose (choice, lengths) ~f:Field.of_int in\n let (T max) = Nat.of_int max in\n Vector.to_array (ones_vector (module Impl) ~first_zero:length max)\n\n module Plonk = Types.Wrap.Proof_state.Deferred_values.Plonk\n\n (* Just for exhaustiveness over fields *)\n let iter2 ~chal ~scalar_chal\n { Plonk.Minimal.In_circuit.alpha = alpha_0\n ; beta = beta_0\n ; gamma = gamma_0\n ; zeta = zeta_0\n ; joint_combiner = joint_combiner_0\n ; feature_flags = _\n }\n { Plonk.Minimal.In_circuit.alpha = alpha_1\n ; beta = beta_1\n ; gamma = gamma_1\n ; zeta = zeta_1\n ; joint_combiner = joint_combiner_1\n ; feature_flags = _\n } =\n with_label __LOC__ (fun () ->\n match[@warning \"-4\"] (joint_combiner_0, joint_combiner_1) with\n | Nothing, Nothing ->\n ()\n | Maybe (b0, j0), Maybe (b1, j1) ->\n Boolean.Assert.(b0 = b1) ;\n let (Typ { var_to_fields; _ }) = Scalar_challenge.typ in\n Array.iter2_exn ~f:Field.Assert.equal\n (fst @@ var_to_fields j0)\n (fst @@ var_to_fields j1)\n | Just j0, Just j1 ->\n let (Typ { var_to_fields; _ }) = Scalar_challenge.typ in\n Array.iter2_exn ~f:Field.Assert.equal\n (fst @@ var_to_fields j0)\n (fst @@ var_to_fields j1)\n | ( ((Pickles_types.Opt.Just _ | Maybe _ | Nothing) as j0)\n , ((Pickles_types.Opt.Just _ | Maybe _ | Nothing) as j1) ) ->\n let sexp_of t =\n Sexp.to_string\n @@ Types.Opt.sexp_of_t\n (fun _ -> Sexp.Atom \"\")\n (fun _ -> Sexp.Atom \"\")\n t\n in\n failwithf\n \"incompatible optional states for joint_combiners: %s vs %s\"\n (sexp_of j0) (sexp_of j1) () ) ;\n with_label __LOC__ (fun () -> chal beta_0 beta_1) ;\n with_label __LOC__ (fun () -> chal gamma_0 gamma_1) ;\n with_label __LOC__ (fun () -> scalar_chal alpha_0 alpha_1) ;\n with_label __LOC__ (fun () -> scalar_chal zeta_0 zeta_1)\n\n let assert_eq_plonk\n (m1 : (_, Field.t Import.Scalar_challenge.t, _) Plonk.Minimal.In_circuit.t)\n (m2 : (_, Scalar_challenge.t, _) Plonk.Minimal.In_circuit.t) =\n iter2 m1 m2\n ~chal:(fun c1 c2 -> Field.Assert.equal c1 c2)\n ~scalar_chal:(fun ({ inner = t1 } : _ Import.Scalar_challenge.t)\n ({ inner = t2 } : Scalar_challenge.t) ->\n Field.Assert.equal t1 t2 )\n\n let index_to_field_elements ~g (m : _ Plonk_verification_key_evals.Step.t) =\n let { Plonk_verification_key_evals.Step.sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n ; range_check0_comm\n ; range_check1_comm\n ; foreign_field_mul_comm\n ; foreign_field_add_comm\n ; xor_comm\n ; rot_comm\n ; lookup_table_comm\n ; lookup_table_ids\n ; runtime_tables_selector\n ; lookup_selector_xor\n ; lookup_selector_lookup\n ; lookup_selector_range_check\n ; lookup_selector_ffmul\n } =\n m\n in\n let open Pickles_types in\n let g_opt = Opt.map ~f:g in\n List.map\n ( Vector.to_list sigma_comm\n @ Vector.to_list coefficients_comm\n @ [ generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n ] )\n ~f:(fun x -> Opt.just (g x))\n @ [ g_opt range_check0_comm\n ; g_opt range_check1_comm\n ; g_opt foreign_field_mul_comm\n ; g_opt foreign_field_add_comm\n ; g_opt xor_comm\n ; g_opt rot_comm\n ]\n @ List.map ~f:g_opt (Vector.to_list lookup_table_comm)\n @ [ g_opt lookup_table_ids\n ; g_opt runtime_tables_selector\n ; g_opt lookup_selector_xor\n ; g_opt lookup_selector_lookup\n ; g_opt lookup_selector_range_check\n ; g_opt lookup_selector_ffmul\n ]\n\n (** Simulate an [Opt_sponge.t] locally in a block, but without running the\n expensive optional logic that is otherwise required.\n\n Invariant: This requires that the sponge 'state' (i.e. the state after\n absorbing or squeezing) is consistent between the initial state and the\n final state when using the sponge.\n *)\n let simulate_optional_sponge_with_alignment (sponge : Sponge.t) ~f = function\n | Pickles_types.Opt.Nothing ->\n Pickles_types.Opt.Nothing\n | Pickles_types.Opt.Maybe (b, x) ->\n (* Cache the sponge state before *)\n let sponge_state_before = sponge.sponge_state in\n let state_before = Array.copy sponge.state in\n (* Use the sponge *)\n let res = f sponge x in\n (* Check that the sponge ends in a compatible state. *)\n ( match (sponge_state_before, sponge.sponge_state) with\n | Absorbed x, Absorbed y ->\n [%test_eq: int] x y\n | Squeezed x, Squeezed y ->\n [%test_eq: int] x y\n | Absorbed _, Squeezed _ ->\n [%test_eq: string] \"absorbed\" \"squeezed\"\n | Squeezed _, Absorbed _ ->\n [%test_eq: string] \"squeezed\" \"absorbed\" ) ;\n let state =\n Array.map2_exn sponge.state state_before ~f:(fun then_ else_ ->\n Field.if_ b ~then_ ~else_ )\n in\n sponge.state <- state ;\n Pickles_types.Opt.Maybe (b, res)\n | Pickles_types.Opt.Just x ->\n Pickles_types.Opt.Just (f sponge x)\n\n let incrementally_verify_proof (type b)\n (module Max_proofs_verified : Nat.Add.Intf with type n = b)\n ~actual_proofs_verified_mask ~step_domains ~srs\n ~verification_key:(m : _ Plonk_verification_key_evals.Step.t) ~xi ~sponge\n ~(public_input :\n [ `Field of Field.t * Boolean.var | `Packed_bits of Field.t * int ]\n array ) ~(sg_old : (_, Max_proofs_verified.n) Vector.t) ~advice\n ~(messages : _ Messages.In_circuit.t) ~which_branch ~openings_proof\n ~(plonk : _ Types.Wrap.Proof_state.Deferred_values.Plonk.In_circuit.t) =\n let T = Max_proofs_verified.eq in\n let sg_old =\n with_label __LOC__ (fun () ->\n Vector.map2 actual_proofs_verified_mask sg_old ~f:(fun keep sg ->\n [| (keep, sg) |] ) )\n in\n with_label __LOC__ (fun () ->\n let sample () = Opt.challenge sponge in\n let sample_scalar () : Scalar_challenge.t =\n Opt.scalar_challenge sponge\n in\n let index_digest =\n with_label \"absorb verifier index\" (fun () ->\n let index_sponge = Sponge.create sponge_params in\n List.iter\n (index_to_field_elements\n ~g:(fun (z : Inputs.Inner_curve.t) ->\n List.to_array (Inner_curve.to_field_elements z) )\n m )\n ~f:(fun x ->\n let (_ : (unit, _) Pickles_types.Opt.t) =\n simulate_optional_sponge_with_alignment index_sponge x\n ~f:(fun sponge x ->\n Array.iter ~f:(Sponge.absorb sponge) x )\n in\n () ) ;\n Sponge.squeeze_field index_sponge )\n in\n let without = Type.Without_degree_bound in\n let absorb_g gs =\n absorb sponge without (Array.map gs ~f:(fun g -> (Boolean.true_, g)))\n in\n absorb sponge Field (Boolean.true_, index_digest) ;\n Vector.iter ~f:(Array.iter ~f:(absorb sponge PC)) sg_old ;\n let x_hat =\n let domain = (which_branch, step_domains) in\n let public_input =\n Array.concat_map public_input ~f:(function\n | `Field (x, b) ->\n [| `Field (x, Field.size_in_bits)\n ; `Field ((b :> Field.t), 1)\n |]\n | `Packed_bits (x, n) ->\n [| `Field (x, n) |] )\n in\n let constant_part, non_constant_part =\n List.partition_map\n Array.(to_list (mapi public_input ~f:(fun i t -> (i, t))))\n ~f:(fun (i, t) ->\n match[@warning \"-4\"] t with\n | `Field (Constant c, _) ->\n First\n ( if Field.Constant.(equal zero) c then None\n else if Field.Constant.(equal one) c then\n Some (lagrange ~domain srs i)\n else\n Some\n (scaled_lagrange ~domain\n (Inner_curve.Constant.Scalar.project\n (Field.Constant.unpack c) )\n srs i ) )\n | `Field x ->\n Second (i, x) )\n in\n with_label __LOC__ (fun () ->\n let terms =\n List.map non_constant_part ~f:(fun (i, x) ->\n match x with\n | b, 1 ->\n assert_ (Constraint.boolean (b :> Field.t)) ;\n `Cond_add\n (Boolean.Unsafe.of_cvar b, lagrange ~domain srs i)\n | x, n ->\n `Add_with_correction\n ( (x, n)\n , lagrange_with_correction ~input_length:n ~domain srs\n i ) )\n in\n let correction =\n with_label __LOC__ (fun () ->\n List.reduce_exn\n (List.filter_map terms ~f:(function\n | `Cond_add _ ->\n None\n | `Add_with_correction (_, (_, corr)) ->\n Some corr ) )\n ~f:(Ops.add_fast ?check_finite:None) )\n in\n with_label __LOC__ (fun () ->\n let init =\n List.fold\n (List.filter_map ~f:Fn.id constant_part)\n ~init:correction\n ~f:(Ops.add_fast ?check_finite:None)\n in\n List.fold terms ~init ~f:(fun acc term ->\n match term with\n | `Cond_add (b, g) ->\n with_label __LOC__ (fun () ->\n Inner_curve.if_ b ~then_:(Ops.add_fast g acc)\n ~else_:acc )\n | `Add_with_correction ((x, num_bits), (g, _)) ->\n Ops.add_fast acc\n (Ops.scale_fast2'\n (module Other_field.With_top_bit0)\n g x ~num_bits ) ) ) )\n |> Inner_curve.negate\n in\n let x_hat =\n with_label \"x_hat blinding\" (fun () ->\n Ops.add_fast x_hat\n (Inner_curve.constant (Lazy.force Generators.h)) )\n in\n absorb sponge PC (Boolean.true_, x_hat) ;\n let w_comm = messages.w_comm in\n Vector.iter ~f:absorb_g w_comm ;\n let joint_combiner =\n let compute_joint_combiner (l : _ Messages.Lookup.In_circuit.t) =\n let absorb_sorted_1 sponge =\n let (first :: _) = l.sorted in\n let z = Array.map first ~f:(fun z -> (Boolean.true_, z)) in\n absorb sponge Without_degree_bound z\n in\n let absorb_sorted_2_to_4 () =\n let (_ :: rest) = l.sorted in\n Vector.iter rest ~f:(fun z ->\n let z = Array.map z ~f:(fun z -> (Boolean.true_, z)) in\n absorb sponge Without_degree_bound z )\n in\n let absorb_sorted_5 () =\n match l.sorted_5th_column with\n | Nothing ->\n ()\n | Maybe (b, z) ->\n let z = Array.map z ~f:(fun z -> (b, z)) in\n absorb sponge Without_degree_bound z\n | Just z ->\n let z = Array.map z ~f:(fun z -> (Boolean.true_, z)) in\n absorb sponge Without_degree_bound z\n in\n match[@warning \"-4\"]\n (m.lookup_table_comm, m.runtime_tables_selector)\n with\n | _ :: Just _ :: _, _ | _, Just _ ->\n let joint_combiner = sample_scalar () in\n absorb_sorted_1 sponge ;\n absorb_sorted_2_to_4 () ;\n absorb_sorted_5 () ;\n joint_combiner\n | _ :: Nothing :: _, Nothing ->\n absorb_sorted_1 sponge ;\n absorb_sorted_2_to_4 () ;\n absorb_sorted_5 () ;\n { inner = Field.zero }\n | _ :: Maybe (b1, _) :: _, Maybe (b2, _) ->\n let b = Boolean.(b1 ||| b2) in\n let sponge2 = Opt.copy sponge in\n let joint_combiner_if_true =\n let joint_combiner = sample_scalar () in\n absorb_sorted_1 sponge ; joint_combiner\n in\n let joint_combiner_if_false : Scalar_challenge.t =\n absorb_sorted_1 sponge2 ; { inner = Field.zero }\n in\n Opt.recombine b ~original_sponge:sponge2 sponge ;\n absorb_sorted_2_to_4 () ;\n absorb_sorted_5 () ;\n { inner =\n Field.if_ b ~then_:joint_combiner_if_true.inner\n ~else_:joint_combiner_if_false.inner\n }\n | _ :: Maybe (b, _) :: _, _ | _, Maybe (b, _) ->\n let sponge2 = Opt.copy sponge in\n let joint_combiner_if_true =\n let joint_combiner = sample_scalar () in\n absorb_sorted_1 sponge ; joint_combiner\n in\n let joint_combiner_if_false : Scalar_challenge.t =\n absorb_sorted_1 sponge2 ; { inner = Field.zero }\n in\n Opt.recombine b ~original_sponge:sponge2 sponge ;\n absorb_sorted_2_to_4 () ;\n absorb_sorted_5 () ;\n { inner =\n Field.if_ b ~then_:joint_combiner_if_true.inner\n ~else_:joint_combiner_if_false.inner\n }\n in\n match messages.lookup with\n | Nothing ->\n Types.Opt.Nothing\n | Maybe (b, l) ->\n Opt.consume_all_pending sponge ;\n let sponge2 = Opt.copy sponge in\n let joint_combiner = compute_joint_combiner l in\n Opt.consume_all_pending sponge ;\n Opt.recombine b ~original_sponge:sponge2 sponge ;\n (* We explicitly set this, because when we squeeze for [beta], we\n there will be no pending values *but* we don't want to add a\n dedicated permutation.\n *)\n sponge.needs_final_permute_if_empty <- false ;\n Types.Opt.Maybe (b, joint_combiner)\n | Just l ->\n Opt.consume_all_pending sponge ;\n Types.Opt.just (compute_joint_combiner l)\n in\n let lookup_table_comm =\n let compute_lookup_table_comm (l : _ Messages.Lookup.In_circuit.t)\n joint_combiner =\n let (first_column :: second_column :: rest) =\n Vector.map\n ~f:(Types.Opt.map ~f:(fun x -> [| x |]))\n m.lookup_table_comm\n in\n let second_column_with_runtime =\n match (second_column, l.runtime) with\n | Types.Opt.Nothing, comm | comm, Types.Opt.Nothing ->\n comm\n | ( Types.Opt.Maybe (has_second_column, second_column)\n , Types.Opt.Maybe (has_runtime, runtime) ) ->\n let second_with_runtime =\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) second_column runtime\n in\n Array.map2_exn second_column sum\n ~f:(fun second_column sum ->\n Inner_curve.if_ has_runtime ~then_:sum\n ~else_:second_column )\n in\n let res =\n Array.map2_exn second_with_runtime runtime\n ~f:(fun second_with_runtime runtime ->\n Inner_curve.if_ has_second_column\n ~then_:second_with_runtime ~else_:runtime )\n in\n let b = Boolean.(has_second_column ||| has_runtime) in\n Types.Opt.maybe b res\n | ( Types.Opt.Maybe (has_second_column, second_column)\n , Types.Opt.Just runtime ) ->\n let res =\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) second_column runtime\n in\n Array.map2_exn runtime sum ~f:(fun runtime sum ->\n Inner_curve.if_ has_second_column ~then_:sum\n ~else_:runtime )\n in\n Types.Opt.just res\n | ( Types.Opt.Just second_column\n , Types.Opt.Maybe (has_runtime, runtime) ) ->\n let res =\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) second_column runtime\n in\n Array.map2_exn second_column sum\n ~f:(fun second_column sum ->\n Inner_curve.if_ has_runtime ~then_:sum\n ~else_:second_column )\n in\n Types.Opt.just res\n | Types.Opt.Just second_column, Types.Opt.Just runtime ->\n Types.Opt.just\n (Array.map2_exn ~f:Inner_curve.( + ) second_column runtime)\n in\n let rest_rev =\n Vector.rev (first_column :: second_column_with_runtime :: rest)\n in\n let table_ids =\n Types.Opt.map m.lookup_table_ids ~f:(fun x -> [| x |])\n in\n Vector.fold ~init:table_ids rest_rev ~f:(fun acc comm ->\n match acc with\n | Types.Opt.Nothing ->\n comm\n | Types.Opt.Maybe (has_acc, acc) -> (\n match comm with\n | Types.Opt.Nothing ->\n Types.Opt.maybe has_acc acc\n | Types.Opt.Maybe (has_comm, comm) ->\n let scaled_acc =\n Array.map acc ~f:(fun acc ->\n Scalar_challenge.endo acc joint_combiner )\n in\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) scaled_acc comm\n in\n let acc_with_comm =\n Array.map2_exn sum comm ~f:(fun sum comm ->\n Inner_curve.if_ has_acc ~then_:sum ~else_:comm )\n in\n let res =\n Array.map2_exn acc acc_with_comm\n ~f:(fun acc acc_with_comm ->\n Inner_curve.if_ has_comm ~then_:acc_with_comm\n ~else_:acc )\n in\n let b = Boolean.(has_acc ||| has_comm) in\n Types.Opt.maybe b res\n | Types.Opt.Just comm ->\n let scaled_acc =\n Array.map acc ~f:(fun acc ->\n Scalar_challenge.endo acc joint_combiner )\n in\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) scaled_acc comm\n in\n let res =\n Array.map2_exn sum comm ~f:(fun sum comm ->\n Inner_curve.if_ has_acc ~then_:sum ~else_:comm )\n in\n Types.Opt.just res )\n | Types.Opt.Just acc -> (\n match comm with\n | Types.Opt.Nothing ->\n Types.Opt.just acc\n | Types.Opt.Maybe (has_comm, comm) ->\n let scaled_acc =\n Array.map acc ~f:(fun acc ->\n Scalar_challenge.endo acc joint_combiner )\n in\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) scaled_acc comm\n in\n let res =\n Array.map2_exn sum acc ~f:(fun sum acc ->\n Inner_curve.if_ has_comm ~then_:sum ~else_:acc )\n in\n Types.Opt.just res\n | Types.Opt.Just comm ->\n let scaled_acc =\n Array.map acc ~f:(fun acc ->\n Scalar_challenge.endo acc joint_combiner )\n in\n Types.Opt.Just\n (Array.map2_exn ~f:Inner_curve.( + ) scaled_acc comm)\n ) )\n in\n match (messages.lookup, joint_combiner) with\n | Types.Opt.Nothing, Types.Opt.Nothing ->\n Types.Opt.Nothing\n | ( Types.Opt.Maybe (b_l, l)\n , Types.Opt.Maybe (_b_joint_combiner, joint_combiner) ) -> (\n (* NB: b_l = _b_joint_combiner by construction *)\n match compute_lookup_table_comm l joint_combiner with\n | Types.Opt.Nothing ->\n Types.Opt.Nothing\n | Types.Opt.Maybe (b_lookup_table_comm, lookup_table_comm) ->\n Types.Opt.Maybe\n (Boolean.(b_l &&& b_lookup_table_comm), lookup_table_comm)\n | Types.Opt.Just lookup_table_comm ->\n Types.Opt.Maybe (b_l, lookup_table_comm) )\n | Types.Opt.Just l, Types.Opt.Just joint_combiner ->\n compute_lookup_table_comm l joint_combiner\n | ( (Types.Opt.Nothing | Maybe _ | Just _)\n , (Types.Opt.Nothing | Maybe _ | Just _) ) ->\n assert false\n in\n let lookup_sorted =\n let lookup_sorted_minus_1 =\n Nat.to_int Plonk_types.Lookup_sorted_minus_1.n\n in\n Vector.init Plonk_types.Lookup_sorted.n ~f:(fun i ->\n match messages.lookup with\n | Types.Opt.Nothing ->\n Types.Opt.Nothing\n | Types.Opt.Maybe (b, l) ->\n if i = lookup_sorted_minus_1 then l.sorted_5th_column\n else\n Types.Opt.Maybe (b, Option.value_exn (Vector.nth l.sorted i))\n | Types.Opt.Just l ->\n if i = lookup_sorted_minus_1 then l.sorted_5th_column\n else Types.Opt.Just (Option.value_exn (Vector.nth l.sorted i)) )\n in\n let beta = sample () in\n let gamma = sample () in\n let () =\n match messages.lookup with\n | Nothing ->\n ()\n | Maybe (b, l) ->\n let aggreg = Array.map l.aggreg ~f:(fun z -> (b, z)) in\n absorb sponge Without_degree_bound aggreg\n | Just l ->\n let aggreg =\n Array.map l.aggreg ~f:(fun z -> (Boolean.true_, z))\n in\n absorb sponge Without_degree_bound aggreg\n in\n let z_comm = messages.z_comm in\n absorb_g z_comm ;\n let alpha = sample_scalar () in\n let t_comm :\n (Inputs.Impl.Field.t * Inputs.Impl.Field.t)\n Pickles_types__Plonk_types.Poly_comm.Without_degree_bound.t =\n messages.t_comm\n in\n absorb_g t_comm ;\n let zeta = sample_scalar () in\n (* At this point, we should use the previous \"bulletproof_challenges\" to\n compute to compute f(beta_1) outside the snark\n where f is the polynomial corresponding to sg_old\n *)\n let sponge =\n match sponge with\n | { state\n ; sponge_state = Squeezed n\n ; params\n ; needs_final_permute_if_empty = _\n } ->\n S.make ~state ~sponge_state:(Squeezed n) ~params\n | { sponge_state = Absorbing _; _ } ->\n assert false\n in\n let sponge_before_evaluations = Sponge.copy sponge in\n let sponge_digest_before_evaluations = Sponge.squeeze_field sponge in\n\n (* xi, r are sampled here using the other sponge. *)\n (* No need to expose the polynomial evaluations as deferred values as they're\n not needed here for the incremental verification. All we need is a_hat and\n \"combined_inner_product\".\n\n Then, in the other proof, we can witness the evaluations and check their correctness\n against \"combined_inner_product\" *)\n let sigma_comm_init, [ _ ] =\n Vector.split m.sigma_comm (snd (Permuts_minus_1.add Nat.N1.n))\n in\n let scale_fast =\n scale_fast ~num_bits:Other_field.Packed.Constant.size_in_bits\n in\n let ft_comm =\n with_label __LOC__ (fun () ->\n Common.ft_comm\n ~add:(Ops.add_fast ?check_finite:None)\n ~scale:scale_fast ~negate:Inner_curve.negate\n ~endoscale:(Scalar_challenge.endo ?num_bits:None)\n ~verification_key:\n (Plonk_verification_key_evals.Step.forget_optional_commitments\n m )\n ~plonk ~alpha ~t_comm )\n in\n let bulletproof_challenges =\n (* This sponge needs to be initialized with (some derivative of)\n 1. The polynomial commitments\n 2. The combined inner product\n 3. The challenge points.\n\n It should be sufficient to fork the sponge after squeezing beta_3 and then to absorb\n the combined inner product.\n *)\n let len_1, len_1_add = Plonk_types.(Columns.add Permuts_minus_1.n) in\n let len_2, len_2_add = Plonk_types.(Columns.add len_1) in\n let _len_3, len_3_add = Nat.N9.add len_2 in\n let _len_4, len_4_add = Nat.N6.add Plonk_types.Lookup_sorted.n in\n let len_5, len_5_add =\n (* NB: Using explicit 11 because we can't get add on len_4 *)\n Nat.N11.add Nat.N7.n\n in\n let len_6, len_6_add = Nat.N45.add len_5 in\n let num_commitments_without_degree_bound = len_6 in\n let without_degree_bound =\n let append_chain len second first =\n Vector.append first second len\n in\n let undo_chunking =\n Types.Opt.map ~f:(fun x ->\n assert (Array.length x = 1) ;\n x.(0) )\n in\n (* sg_old\n x_hat\n ft_comm\n z_comm\n generic selector\n poseidon selector\n w_comms\n all but last sigma_comm\n *)\n Vector.map sg_old\n ~f:\n (Array.map ~f:(fun (keep, p) ->\n Pickles_types.Opt.Maybe (keep, p) ) )\n |> append_chain\n (snd (Max_proofs_verified.add len_6))\n ( [ [| x_hat |]\n ; [| ft_comm |]\n ; z_comm\n ; [| m.generic_comm |]\n ; [| m.psm_comm |]\n ; [| m.complete_add_comm |]\n ; [| m.mul_comm |]\n ; [| m.emul_comm |]\n ; [| m.endomul_scalar_comm |]\n ]\n |> append_chain len_3_add\n (Vector.append w_comm\n (Vector.append\n (Vector.map m.coefficients_comm ~f:(fun g ->\n [| g |] ) )\n (Vector.map sigma_comm_init ~f:(fun g -> [| g |]))\n len_1_add )\n len_2_add )\n |> Vector.map ~f:(Array.map ~f:Pickles_types.Opt.just)\n |> append_chain len_6_add\n ( [ m.range_check0_comm\n ; m.range_check1_comm\n ; m.foreign_field_add_comm\n ; m.foreign_field_mul_comm\n ; m.xor_comm\n ; m.rot_comm\n ]\n |> append_chain len_4_add\n (Vector.map ~f:undo_chunking lookup_sorted)\n |> append_chain len_5_add\n [ undo_chunking\n @@ Pickles_types.Opt.map messages.lookup\n ~f:(fun l -> l.aggreg)\n ; undo_chunking lookup_table_comm\n ; m.runtime_tables_selector\n ; m.lookup_selector_xor\n ; m.lookup_selector_lookup\n ; m.lookup_selector_range_check\n ; m.lookup_selector_ffmul\n ]\n |> Vector.map ~f:(fun x -> [| x |]) ) )\n in\n check_bulletproof\n ~pcs_batch:\n (Common.dlog_pcs_batch\n (Max_proofs_verified.add num_commitments_without_degree_bound) )\n ~sponge:sponge_before_evaluations ~xi ~advice ~openings_proof\n ~polynomials:\n ( Vector.map without_degree_bound\n ~f:\n (Array.map\n ~f:(Pickles_types.Opt.map ~f:(fun x -> `Finite x)) )\n , [] )\n in\n assert_eq_plonk\n { alpha = plonk.alpha\n ; beta = plonk.beta\n ; gamma = plonk.gamma\n ; zeta = plonk.zeta\n ; joint_combiner = plonk.joint_combiner\n ; feature_flags = plonk.feature_flags\n }\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; joint_combiner\n ; feature_flags = plonk.feature_flags\n } ;\n (sponge_digest_before_evaluations, bulletproof_challenges) )\n\n let _mask_evals (type n)\n ~(lengths :\n (int, n) Pickles_types.Vector.t Pickles_types.Plonk_types.Evals.t )\n (choice : n One_hot_vector.t)\n (e : Field.t array Pickles_types.Plonk_types.Evals.t) :\n (Boolean.var * Field.t) array Pickles_types.Plonk_types.Evals.t =\n Pickles_types.Plonk_types.Evals.map2 lengths e ~f:(fun lengths e ->\n Array.zip_exn (mask lengths choice) e )\n\n let compute_challenges ~scalar chals =\n Vector.map chals ~f:(fun prechallenge ->\n scalar @@ Bulletproof_challenge.pack prechallenge )\n\n let challenge_polynomial = G.challenge_polynomial (module Field)\n\n let pow2pow (pt : Field.t) (n : int) : Field.t =\n with_label __LOC__ (fun () ->\n let rec go acc i =\n if i = 0 then acc else go (Field.square acc) (i - 1)\n in\n go pt n )\n\n let actual_evaluation (e : Field.t array) ~(pt_to_n : Field.t) : Field.t =\n with_label __LOC__ (fun () ->\n match List.rev (Array.to_list e) with\n | e :: es ->\n List.fold ~init:e es ~f:(fun acc y ->\n let acc' =\n exists Field.typ ~compute:(fun () ->\n As_prover.read_var Field.(y + (pt_to_n * acc)) )\n in\n (* acc' = y + pt_n * acc *)\n let pt_n_acc = Field.(pt_to_n * acc) in\n let open\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint in\n (* 0 = - acc' + y + pt_n_acc *)\n let open Field.Constant in\n assert_\n { annotation = None\n ; basic =\n T\n (Basic\n { l = (one, y)\n ; r = (one, pt_n_acc)\n ; o = (negate one, acc')\n ; m = zero\n ; c = zero\n } )\n } ;\n acc' )\n | [] ->\n failwith \"empty list\" )\n\n let _shift1 =\n Pickles_types.Shifted_value.Type1.Shift.(\n map ~f:Field.constant (create (module Field.Constant)))\n\n let shift2 =\n Shifted_value.Type2.Shift.(\n map ~f:Field.constant (create (module Field.Constant)))\n\n let%test_unit \"endo scalar\" =\n SC.test (module Impl) ~endo:Endo.Step_inner_curve.scalar\n\n let map_plonk_to_field plonk =\n Types.Step.Proof_state.Deferred_values.Plonk.In_circuit.map_challenges\n ~f:(Util.seal (module Impl))\n ~scalar:scalar_to_field plonk\n |> Types.Step.Proof_state.Deferred_values.Plonk.In_circuit.map_fields\n ~f:(Shifted_value.Type2.map ~f:(Util.seal (module Impl)))\n\n module Plonk_checks = struct\n include Plonk_checks\n include Plonk_checks.Make (Shifted_value.Type2) (Plonk_checks.Scalars.Tock)\n end\n\n (* This finalizes the \"deferred values\" coming from a previous proof over the same field.\n It\n 1. Checks that [xi] and [r] where sampled correctly. I.e., by absorbing all the\n evaluation openings and then squeezing.\n 2. Checks that the \"combined inner product\" value used in the elliptic curve part of\n the opening proof was computed correctly, in terms of the evaluation openings and the\n evaluation points.\n 3. Check that the \"b\" value was computed correctly.\n 4. Perform the arithmetic checks from marlin. *)\n let finalize_other_proof (type b)\n (module Proofs_verified : Nat.Add.Intf with type n = b) ~domain ~sponge\n ~(old_bulletproof_challenges : (_, b) Vector.t)\n ({ xi; combined_inner_product; bulletproof_challenges; b; plonk } :\n ( _\n , _\n , _ Shifted_value.Type2.t\n , _ )\n Types.Step.Proof_state.Deferred_values.In_circuit.t )\n { Plonk_types.All_evals.In_circuit.ft_eval1; evals } =\n let module Plonk = Types.Step.Proof_state.Deferred_values.Plonk in\n let T = Proofs_verified.eq in\n (* You use the NEW bulletproof challenges to check b. Not the old ones. *)\n let open Field in\n let plonk = map_plonk_to_field plonk in\n let zetaw = Field.mul domain#generator plonk.zeta in\n let sg_evals1, sg_evals2 =\n let sg_olds =\n Vector.map old_bulletproof_challenges ~f:(fun chals ->\n unstage (challenge_polynomial (Vector.to_array chals)) )\n in\n let sg_evals pt = Vector.map sg_olds ~f:(fun f -> f pt) in\n (sg_evals plonk.zeta, sg_evals zetaw)\n in\n let sponge_state =\n (* Absorb bulletproof challenges *)\n let challenge_digest =\n let sponge = Sponge.create sponge_params in\n Vector.iter old_bulletproof_challenges\n ~f:(Vector.iter ~f:(Sponge.absorb sponge)) ;\n Sponge.squeeze sponge\n in\n Sponge.absorb sponge challenge_digest ;\n Sponge.absorb sponge ft_eval1 ;\n Sponge.absorb sponge (fst evals.public_input) ;\n Sponge.absorb sponge (snd evals.public_input) ;\n let xs = Evals.In_circuit.to_absorption_sequence evals.evals in\n (* This is a hacky, but much more efficient, version of the opt sponge.\n This uses the assumption that the sponge 'absorption state' will align\n after each optional absorption, letting us skip the expensive tracking\n that this would otherwise require.\n To future-proof this, we assert that the states are indeed compatible.\n *)\n List.iter xs ~f:(fun opt ->\n let absorb = Array.iter ~f:(fun x -> Sponge.absorb sponge x) in\n match opt with\n | Nothing ->\n ()\n | Just (x1, x2) ->\n absorb x1 ; absorb x2\n | Maybe (b, (x1, x2)) ->\n (* Cache the sponge state before *)\n let sponge_state_before = sponge.sponge_state in\n let state_before = Array.copy sponge.state in\n (* Absorb the points *)\n absorb x1 ;\n absorb x2 ;\n (* Check that the sponge ends in a compatible state. *)\n ( match (sponge_state_before, sponge.sponge_state) with\n | Absorbed x, Absorbed y ->\n [%test_eq: int] x y\n | Squeezed x, Squeezed y ->\n [%test_eq: int] x y\n | Absorbed _, Squeezed _ ->\n [%test_eq: string] \"absorbed\" \"squeezed\"\n | Squeezed _, Absorbed _ ->\n [%test_eq: string] \"squeezed\" \"absorbed\" ) ;\n let state =\n Array.map2_exn sponge.state state_before ~f:(fun then_ else_ ->\n Field.if_ b ~then_ ~else_ )\n in\n sponge.state <- state ) ;\n Array.copy sponge.state\n in\n sponge.state <- sponge_state ;\n let xi_actual = squeeze_scalar sponge in\n let r_actual = squeeze_challenge sponge in\n let xi_correct =\n with_label __LOC__ (fun () ->\n let { Import.Scalar_challenge.inner = xi_actual } = xi_actual in\n let { Import.Scalar_challenge.inner = xi } = xi in\n (* Sample new sg challenge point here *)\n Field.equal xi_actual xi )\n in\n let xi = scalar_to_field xi in\n (* TODO: r actually does not need to be a scalar challenge. *)\n let r = scalar_to_field (Import.Scalar_challenge.create r_actual) in\n let plonk_minimal =\n plonk |> Plonk.to_minimal\n |> Plonk.Minimal.to_wrap\n ~feature_flags:Features.(map ~f:Boolean.var_of_value none_bool)\n in\n let combined_evals =\n let n = Common.Max_degree.wrap_log2 in\n (* TODO: zeta_n is recomputed in [env] below *)\n let zeta_n = pow2pow plonk.zeta n in\n let zetaw_n = pow2pow zetaw n in\n Evals.In_circuit.map evals.evals ~f:(fun (x0, x1) ->\n ( actual_evaluation ~pt_to_n:zeta_n x0\n , actual_evaluation ~pt_to_n:zetaw_n x1 ) )\n in\n let env =\n let module Env_bool = struct\n include Boolean\n\n type t = Boolean.var\n end in\n let module Env_field = struct\n include Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ =\n match Impl.Field.to_constant (b :> t) with\n | Some x ->\n (* We have a constant, only compute the branch we care about. *)\n if Impl.Field.Constant.(equal one) x then then_ () else else_ ()\n | None ->\n if_ b ~then_:(then_ ()) ~else_:(else_ ())\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~srs_length_log2:Common.Max_degree.wrap_log2\n ~endo:(Impl.Field.constant Endo.Wrap_inner_curve.base)\n ~mds:sponge_params.mds\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fq.of_bigint |> Field.constant )\n ~domain plonk_minimal combined_evals\n in\n let combined_inner_product_correct =\n let evals1, evals2 =\n All_evals.With_public_input.In_circuit.factor evals\n in\n with_label __LOC__ (fun () ->\n let ft_eval0 : Field.t =\n with_label __LOC__ (fun () ->\n Plonk_checks.ft_eval0\n (module Field)\n ~env ~domain plonk_minimal combined_evals evals1.public_input )\n in\n (* sum_i r^i sum_j xi^j f_j(beta_i) *)\n let actual_combined_inner_product =\n let combine ~ft ~sg_evals x_hat\n (e : (Field.t array, _) Evals.In_circuit.t) =\n let a =\n Evals.In_circuit.to_list e\n |> List.map ~f:(function\n | Nothing ->\n [||]\n | Just a ->\n Array.map a ~f:Pickles_types.Opt.just\n | Maybe (b, a) ->\n Array.map a ~f:(Pickles_types.Opt.maybe b) )\n in\n let sg_evals =\n Vector.map sg_evals ~f:(fun x -> [| Pickles_types.Opt.just x |])\n |> Vector.to_list\n (* TODO: This was the code before the wrap hack was put in\n match actual_proofs_verified with\n | None ->\n Vector.map sg_olds ~f:(fun f -> [| f pt |])\n | Some proofs_verified ->\n let mask =\n ones_vector\n (module Impl)\n ~first_zero:proofs_verified (Vector.length sg_olds)\n in\n with_label __LOC__ (fun () ->\n Vector.map2 mask sg_olds ~f:(fun b f ->\n [| Field.((b :> t) * f pt) |] ) ) *)\n in\n let v =\n List.append sg_evals\n ( [| Pickles_types.Opt.just x_hat |]\n :: [| Pickles_types.Opt.just ft |]\n :: a )\n in\n Common.combined_evaluation (module Impl) ~xi v\n in\n combine ~ft:ft_eval0 ~sg_evals:sg_evals1 evals1.public_input\n evals1.evals\n + r\n * combine ~ft:ft_eval1 ~sg_evals:sg_evals2 evals2.public_input\n evals2.evals\n in\n with_label __LOC__ (fun () ->\n equal\n (Shifted_value.Type2.to_field\n (module Field)\n ~shift:shift2 combined_inner_product )\n actual_combined_inner_product ) )\n in\n let bulletproof_challenges =\n with_label __LOC__ (fun () ->\n compute_challenges ~scalar:scalar_to_field bulletproof_challenges )\n in\n let b_correct =\n with_label __LOC__ (fun () ->\n let challenge_poly =\n unstage\n (challenge_polynomial (Vector.to_array bulletproof_challenges))\n in\n let b_actual =\n challenge_poly plonk.zeta + (r * challenge_poly zetaw)\n in\n equal\n (Shifted_value.Type2.to_field (module Field) ~shift:shift2 b)\n b_actual )\n in\n let plonk_checks_passed =\n with_label __LOC__ (fun () ->\n (* This proof is a wrap proof; no need to consider features. *)\n Plonk_checks.checked\n (module Impl)\n ~env ~shift:shift2\n (Composition_types.Step.Proof_state.Deferred_values.Plonk.In_circuit\n .to_wrap ~opt_none:Pickles_types.Opt.nothing ~false_:Boolean.false_\n plonk )\n combined_evals )\n in\n print_bool \"xi_correct\" xi_correct ;\n print_bool \"combined_inner_product_correct\" combined_inner_product_correct ;\n print_bool \"plonk_checks_passed\" plonk_checks_passed ;\n print_bool \"b_correct\" b_correct ;\n ( Boolean.all\n [ xi_correct\n ; b_correct\n ; combined_inner_product_correct\n ; plonk_checks_passed\n ]\n , bulletproof_challenges )\n\n let _map_challenges\n { Import.Types.Step.Proof_state.Deferred_values.plonk\n ; combined_inner_product\n ; xi\n ; bulletproof_challenges\n ; b\n } ~f ~scalar =\n { Types.Step.Proof_state.Deferred_values.plonk =\n Types.Step.Proof_state.Deferred_values.Plonk.In_circuit.map_challenges\n plonk ~f ~scalar\n ; combined_inner_product\n ; bulletproof_challenges =\n Vector.map bulletproof_challenges\n ~f:(fun (r : _ Bulletproof_challenge.t) ->\n Bulletproof_challenge.map ~f:scalar r )\n ; xi = scalar xi\n ; b\n }\nend\n\ninclude Make (Wrap_main_inputs)\n\nlet challenge_polynomial = G.challenge_polynomial\n","open Core_kernel\n\n[@@@warning \"-4\"]\n\ntype ('a, 'bool) t = Just of 'a | Nothing | Maybe of 'bool * 'a\n[@@deriving sexp, compare, yojson, hash, equal]\n\nlet just a = Just a\n\nlet nothing = Nothing\n\nlet maybe b x = Maybe (b, x)\n\nlet to_option : ('a, bool) t -> 'a option = function\n | Just x ->\n Some x\n | Maybe (true, x) ->\n Some x\n | Maybe (false, _x) ->\n None\n | Nothing ->\n None\n\nlet to_option_unsafe : ('a, 'bool) t -> 'a option = function\n | Just x ->\n Some x\n | Maybe (_, x) ->\n Some x\n | Nothing ->\n None\n\nlet value_exn = function\n | Just x ->\n x\n | Maybe (_, x) ->\n x\n | Nothing ->\n invalid_arg \"Opt.value_exn\"\n\nlet of_option (t : 'a option) : ('a, 'bool) t =\n match t with None -> Nothing | Some x -> Just x\n\nlet lift ?on_maybe ~nothing f = function\n | Nothing ->\n nothing\n | Just v ->\n f v\n | Maybe (b, v) -> (\n match on_maybe with None -> f v | Some g -> g b v )\n\nmodule Flag = struct\n type t = Yes | No | Maybe [@@deriving sexp, compare, yojson, hash, equal]\n\n let ( ||| ) x y =\n match (x, y) with\n | Yes, _ | _, Yes ->\n Yes\n | Maybe, _ | _, Maybe ->\n Maybe\n | No, No ->\n No\nend\n\nlet map t ~f =\n match t with\n | Nothing ->\n Nothing\n | Just x ->\n Just (f x)\n | Maybe (b, x) ->\n Maybe (b, f x)\n\nlet iter t ~f =\n match t with Nothing -> () | Just x -> f x | Maybe (_, x) -> f x\n\nopen Snarky_backendless\n\nlet some_typ (type a a_var f bool_var) (t : (a_var, a, f) Typ.t) :\n ((a_var, bool_var) t, a option, f) Typ.t =\n Typ.transport t ~there:(fun x -> Option.value_exn x) ~back:Option.return\n |> Typ.transport_var\n ~there:(function\n | Just x ->\n x\n | Maybe _ | Nothing ->\n failwith \"Opt.some_typ: expected Just\" )\n ~back:(fun x -> Just x)\n\nlet none_typ (type a a_var f bool) () : ((a_var, bool) t, a option, f) Typ.t =\n Typ.transport (Typ.unit ())\n ~there:(fun _ -> ())\n ~back:(fun () : _ Option.t -> None)\n |> Typ.transport_var\n ~there:(function\n | Nothing ->\n ()\n | Maybe _ | Just _ ->\n failwith \"Opt.none_typ: expected Nothing\" )\n ~back:(fun () : _ t -> Nothing)\n\nlet maybe_typ (type a a_var bool_var f)\n (bool_typ : (bool_var, bool, f) Snarky_backendless.Typ.t) ~(dummy : a)\n (a_typ : (a_var, a, f) Typ.t) : ((a_var, bool_var) t, a option, f) Typ.t =\n Typ.transport\n (Typ.tuple2 bool_typ a_typ)\n ~there:(fun (t : a option) ->\n match t with None -> (false, dummy) | Some x -> (true, x) )\n ~back:(fun (b, x) -> if b then Some x else None)\n |> Typ.transport_var\n ~there:(fun (t : (a_var, _) t) ->\n match t with\n | Maybe (b, x) ->\n (b, x)\n | Nothing | Just _ ->\n failwith \"Opt.maybe_typ: expected Maybe\" )\n ~back:(fun (b, x) -> Maybe (b, x))\n\nlet constant_layout_typ (type a a_var f) (bool_typ : _ Typ.t) ~true_ ~false_\n (flag : Flag.t) (a_typ : (a_var, a, f) Typ.t) ~(dummy : a)\n ~(dummy_var : a_var) =\n let (Typ bool_typ) = bool_typ in\n let bool_typ : _ Typ.t =\n let check =\n (* No need to boolean constrain in the No or Yes case *)\n match flag with\n | No | Yes ->\n fun _ -> Checked_runner.Simple.return ()\n | Maybe ->\n bool_typ.check\n in\n Typ { bool_typ with check }\n in\n Typ.transport\n (Typ.tuple2 bool_typ a_typ)\n ~there:(fun (t : a option) ->\n match t with None -> (false, dummy) | Some x -> (true, x) )\n ~back:(fun (b, x) -> if b then Some x else None)\n |> Typ.transport_var\n ~there:(fun (t : (a_var, _) t) ->\n match t with\n | Maybe (b, x) ->\n (b, x)\n | Nothing ->\n (false_, dummy_var)\n | Just x ->\n (true_, x) )\n ~back:(fun (b, x) ->\n match flag with No -> Nothing | Yes -> Just x | Maybe -> Maybe (b, x)\n )\n\nlet typ (type a a_var f) bool_typ (flag : Flag.t) (a_typ : (a_var, a, f) Typ.t)\n ~(dummy : a) =\n match flag with\n | Yes ->\n some_typ a_typ\n | No ->\n none_typ ()\n | Maybe ->\n maybe_typ bool_typ ~dummy a_typ\n\nmodule Early_stop_sequence = struct\n (* A sequence that should be considered to have stopped at\n the first No flag *)\n (* TODO: The documentation above makes it sound like the type below is too\n generic: we're not guaranteed to have flags in there *)\n type nonrec ('a, 'bool) t = ('a, 'bool) t list\n\n let fold (type a bool acc res)\n (if_res : bool -> then_:res -> else_:res -> res) (t : (a, bool) t)\n ~(init : acc) ~(f : acc -> a -> acc) ~(finish : acc -> res) =\n let rec go acc = function\n | [] ->\n finish acc\n | Nothing :: xs ->\n go acc xs\n | Just x :: xs ->\n go (f acc x) xs\n | Maybe (b, x) :: xs ->\n (* Computing this first makes mutation in f OK. *)\n let stop_res = finish acc in\n let continue_res = go (f acc x) xs in\n if_res b ~then_:continue_res ~else_:stop_res\n in\n go init t\nend\n","(* q > p *)\nopen Core_kernel\nmodule SC = Scalar_challenge\nopen Import\nopen Common\nopen Util\nopen Types.Step\nopen Pickles_types\n\nmodule Make\n (Inputs : Intf.Step_main_inputs.S\n with type Impl.field = Backend.Tick.Field.t\n and type Impl.Bigint.t = Backend.Tick.Bigint.t\n and type Inner_curve.Constant.Scalar.t = Backend.Tock.Field.t) =\nstruct\n open Inputs\n open Impl\n module Challenge = Challenge.Make (Impl)\n module Digest = Digest.Make (Impl)\n\n (* Other_field.size > Field.size *)\n module Other_field = struct\n let size_in_bits = Field.size_in_bits\n\n type t = Impls.Step.Other_field.t\n\n let typ = Impls.Step.Other_field.typ\n end\n\n let print_fp lab x =\n if debug then\n as_prover\n As_prover.(\n fun () ->\n printf !\"%s: %{sexp:Backend.Tick.Field.t}\\n%!\" lab (read_var x))\n\n let print_bool lab x =\n if debug then\n as_prover (fun () ->\n printf \"%s: %b\\n%!\" lab (As_prover.read Boolean.typ x) )\n\n let equal_g g1 g2 =\n List.map2_exn ~f:Field.equal\n (Inner_curve.to_field_elements g1)\n (Inner_curve.to_field_elements g2)\n |> Boolean.all\n\n let absorb sponge ty t =\n absorb\n ~absorb_field:(fun x -> Sponge.absorb sponge (`Field x))\n ~g1_to_field_elements:Inner_curve.to_field_elements\n ~absorb_scalar:(fun (x, (b : Boolean.var)) ->\n Sponge.absorb sponge (`Field x) ;\n Sponge.absorb sponge (`Bits [ b ]) )\n ~mask_g1_opt:(fun ((b : Boolean.var), (x, y)) ->\n Field.((b :> t) * x, (b :> t) * y) )\n ty t\n\n let _scalar_to_field s =\n SC.to_field_checked (module Impl) s ~endo:Endo.Wrap_inner_curve.scalar\n\n let assert_n_bits ~n a =\n (* Scalar_challenge.to_field_checked has the side effect of\n checking that the input fits in n bits. *)\n ignore\n ( SC.to_field_checked\n (module Impl)\n (Import.Scalar_challenge.create a)\n ~endo:Endo.Wrap_inner_curve.scalar ~num_bits:n\n : Field.t )\n\n let lowest_128_bits ~constrain_low_bits x =\n let assert_128_bits = assert_n_bits ~n:128 in\n Util.lowest_128_bits ~constrain_low_bits ~assert_128_bits (module Impl) x\n\n module Scalar_challenge =\n SC.Make (Impl) (Inner_curve) (Challenge) (Endo.Step_inner_curve)\n module Ops = Step_main_inputs.Ops\n\n module Inner_curve = struct\n include Inner_curve\n\n let ( + ) = Ops.add_fast\n end\n\n module Public_input_scalar = struct\n type t = Field.t\n\n let typ = Field.typ\n\n module Constant = struct\n include Field.Constant\n\n let to_bigint = Impl.Bigint.of_field\n end\n end\n\n let multiscale_known\n (ts :\n ( [ `Field of Field.t | `Packed_bits of Field.t * int ]\n * Inner_curve.Constant.t )\n array ) =\n let module F = Public_input_scalar in\n let rec pow2pow x i =\n if i = 0 then x else pow2pow Inner_curve.Constant.(x + x) (i - 1)\n in\n with_label __LOC__ (fun () ->\n let constant_part, non_constant_part =\n List.partition_map (Array.to_list ts) ~f:(fun (t, g) ->\n match[@warning \"-4\"] t with\n | `Field (Constant c) | `Packed_bits (Constant c, _) ->\n First\n ( if Field.Constant.(equal zero) c then None\n else if Field.Constant.(equal one) c then Some g\n else\n Some\n (Inner_curve.Constant.scale g\n (Inner_curve.Constant.Scalar.project\n (Field.Constant.unpack c) ) ) )\n | `Field x ->\n Second (`Field x, g)\n | `Packed_bits (x, n) ->\n Second (`Packed_bits (x, n), g) )\n in\n let add_opt xo y =\n Option.value_map xo ~default:y ~f:(fun x ->\n Inner_curve.Constant.( + ) x y )\n in\n let constant_part =\n List.filter_map constant_part ~f:Fn.id\n |> List.fold ~init:None ~f:(fun acc x -> Some (add_opt acc x))\n in\n let correction, acc =\n List.map non_constant_part ~f:(fun (s, x) ->\n let rr, n =\n match s with\n | `Packed_bits (s, n) ->\n ( Ops.scale_fast2'\n (module F)\n (Inner_curve.constant x) s ~num_bits:n\n , n )\n | `Field s ->\n ( Ops.scale_fast2'\n (module F)\n (Inner_curve.constant x) s ~num_bits:Field.size_in_bits\n , Field.size_in_bits )\n in\n let n =\n Ops.bits_per_chunk * Ops.chunks_needed ~num_bits:(n - 1)\n in\n let cc = pow2pow x n in\n (cc, rr) )\n |> List.reduce_exn ~f:(fun (a1, b1) (a2, b2) ->\n (Inner_curve.Constant.( + ) a1 a2, Inner_curve.( + ) b1 b2) )\n in\n Inner_curve.(\n acc + constant (Constant.negate correction |> add_opt constant_part)) )\n\n let squeeze_challenge sponge : Field.t =\n lowest_128_bits (Sponge.squeeze sponge) ~constrain_low_bits:true\n\n let squeeze_scalar sponge : Field.t Import.Scalar_challenge.t =\n (* No need to boolean constrain scalar challenges. *)\n Import.Scalar_challenge.create\n (lowest_128_bits ~constrain_low_bits:false (Sponge.squeeze sponge))\n\n let bullet_reduce sponge gammas =\n with_label __LOC__ (fun () ->\n let absorb t = absorb sponge t in\n let prechallenges =\n Array.map gammas ~f:(fun gammas_i ->\n absorb (PC :: PC) gammas_i ;\n squeeze_scalar sponge )\n in\n let term_and_challenge (l, r) pre =\n let left_term = Scalar_challenge.endo_inv l pre in\n let right_term = Scalar_challenge.endo r pre in\n ( Inner_curve.(left_term + right_term)\n , Bulletproof_challenge.unpack pre )\n in\n let terms, challenges =\n Array.map2_exn gammas prechallenges ~f:term_and_challenge\n |> Array.unzip\n in\n (Array.reduce_exn terms ~f:(fun x y -> Inner_curve.(x + y)), challenges) )\n\n let group_map =\n let f =\n lazy\n (let module M =\n Group_map.Bw19.Make (Field.Constant) (Field)\n (struct\n let params =\n Group_map.Bw19.Params.create\n (module Field.Constant)\n { b = Inner_curve.Params.b }\n end)\n in\n let open M in\n Snarky_group_map.Checked.wrap\n (module Impl)\n ~potential_xs\n ~y_squared:(fun ~x ->\n Field.(\n (x * x * x)\n + (constant Inner_curve.Params.a * x)\n + constant Inner_curve.Params.b) )\n |> unstage )\n in\n fun x -> Lazy.force f x\n\n let _scale_fast p s =\n with_label __LOC__ (fun () ->\n Ops.scale_fast p s ~num_bits:Field.size_in_bits )\n\n let scale_fast2 p (s : Other_field.t Shifted_value.Type2.t) =\n with_label __LOC__ (fun () ->\n Ops.scale_fast2 p s ~num_bits:Field.size_in_bits )\n\n let check_bulletproof ~pcs_batch ~(sponge : Sponge.t) ~xi\n ~(* Corresponds to y in figure 7 of WTS *)\n (* sum_i r^i sum_j xi^j f_j(beta_i) *)\n (advice : _ Bulletproof.Advice.t)\n ~polynomials:(without_degree_bound, with_degree_bound)\n ~opening:\n ({ lr; delta; z_1; z_2; challenge_polynomial_commitment } :\n (Inner_curve.t, Other_field.t Shifted_value.Type2.t) Bulletproof.t ) =\n with_label \"check_bulletproof\" (fun () ->\n absorb sponge Scalar\n ( match advice.combined_inner_product with\n | Shifted_value.Type2.Shifted_value x ->\n x ) ;\n (* a_hat should be equal to\n sum_i < t, r^i pows(beta_i) >\n = sum_i r^i < t, pows(beta_i) > *)\n let u =\n let t = Sponge.squeeze_field sponge in\n group_map t\n in\n let open Inner_curve in\n let combined_polynomial (* Corresponds to xi in figure 7 of WTS *) =\n with_label \"combined_polynomial\" (fun () ->\n Pcs_batch.combine_split_commitments pcs_batch\n ~scale_and_add:(fun ~(acc :\n [ `Maybe_finite of\n Boolean.var * Inner_curve.t\n | `Finite of Inner_curve.t ] ) ~xi p ->\n match acc with\n | `Maybe_finite (acc_is_finite, (acc : Inner_curve.t)) -> (\n match p with\n | `Maybe_finite (p_is_finite, p) ->\n let is_finite =\n Boolean.(p_is_finite ||| acc_is_finite)\n in\n let xi_acc = Scalar_challenge.endo acc xi in\n `Maybe_finite\n ( is_finite\n , if_ acc_is_finite ~then_:(p + xi_acc) ~else_:p )\n | `Finite p ->\n let xi_acc = Scalar_challenge.endo acc xi in\n `Finite\n (if_ acc_is_finite ~then_:(p + xi_acc) ~else_:p) )\n | `Finite acc ->\n let xi_acc = Scalar_challenge.endo acc xi in\n `Finite\n ( match p with\n | `Finite p ->\n p + xi_acc\n | `Maybe_finite (p_is_finite, p) ->\n if_ p_is_finite ~then_:(p + xi_acc) ~else_:xi_acc )\n )\n ~xi\n ~init:(function\n | `Finite x ->\n Some (`Finite x)\n | `Maybe_finite x ->\n Some (`Maybe_finite x) )\n (Vector.map without_degree_bound\n ~f:(Array.map ~f:(fun x -> `Finite x)) )\n (Vector.map with_degree_bound\n ~f:\n (let open Plonk_types.Poly_comm.With_degree_bound in\n fun { shifted; unshifted } ->\n let f x = `Maybe_finite x in\n { unshifted = Array.map ~f unshifted\n ; shifted = f shifted\n }) ) )\n |> function `Finite x -> x | `Maybe_finite _ -> assert false\n in\n let lr_prod, challenges = bullet_reduce sponge lr in\n let p_prime =\n let uc = scale_fast2 u advice.combined_inner_product in\n combined_polynomial + uc\n in\n let q = p_prime + lr_prod in\n absorb sponge PC delta ;\n let c = squeeze_scalar sponge in\n print_fp \"c\" c.inner ;\n (* c Q + delta = z1 (G + b U) + z2 H *)\n let lhs =\n let cq = Scalar_challenge.endo q c in\n cq + delta\n in\n let rhs =\n with_label __LOC__ (fun () ->\n let b_u = scale_fast2 u advice.b in\n let z_1_g_plus_b_u =\n scale_fast2 (challenge_polynomial_commitment + b_u) z_1\n in\n let z2_h =\n scale_fast2 (Inner_curve.constant (Lazy.force Generators.h)) z_2\n in\n z_1_g_plus_b_u + z2_h )\n in\n (`Success (equal_g lhs rhs), challenges) )\n\n let assert_eq_deferred_values\n (m1 :\n ( 'a\n , Inputs.Impl.Field.t Import.Scalar_challenge.t\n , _ )\n Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.t )\n (m2 :\n ( Inputs.Impl.Field.t\n , Inputs.Impl.Field.t Import.Scalar_challenge.t\n , _ )\n Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.t ) =\n let open Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal in\n let chal c1 c2 = Field.Assert.equal c1 c2 in\n let scalar_chal\n ({ Import.Scalar_challenge.inner = t1 } : _ Import.Scalar_challenge.t)\n ({ Import.Scalar_challenge.inner = t2 } : _ Import.Scalar_challenge.t) =\n Field.Assert.equal t1 t2\n in\n with_label __LOC__ (fun () -> chal m1.beta m2.beta) ;\n with_label __LOC__ (fun () -> chal m1.gamma m2.gamma) ;\n with_label __LOC__ (fun () -> scalar_chal m1.alpha m2.alpha) ;\n with_label __LOC__ (fun () -> scalar_chal m1.zeta m2.zeta)\n\n let lagrange_commitment ~domain srs i =\n let d = Int.pow 2 (Domain.log2_size domain) in\n match[@warning \"-4\"]\n (Kimchi_bindings.Protocol.SRS.Fq.lagrange_commitment srs d i).unshifted\n with\n | [| Finite g |] ->\n Inner_curve.Constant.of_affine g\n | _ ->\n assert false\n\n module O = One_hot_vector.Make (Impl)\n open Tuple_lib\n\n let public_input_commitment_dynamic (type n) ~srs (which : n O.t)\n (domains : (Domains.t, n) Vector.t)\n ~(public_input :\n [ `Field of Field.t | `Packed_bits of Field.t * int ] array ) =\n (*\n let domains : (Domains.t, Nat.N3.n) Vector.t =\n Vector.map ~f:(fun proofs_verified -> Common.wrap_domains ~proofs_verified)\n [ 0; 1 ; 2 ]\n in *)\n let lagrange_commitment (d : Domains.t) (i : int) : Inner_curve.Constant.t =\n lagrange_commitment ~domain:d.h srs i\n in\n let select_curve_points (type k)\n ~(points_for_domain : Domains.t -> (Inner_curve.Constant.t, k) Vector.t)\n : (Inner_curve.t, k) Vector.t =\n match domains with\n | [] ->\n assert false\n | d :: ds ->\n if Vector.for_all ds ~f:(fun d' -> Domain.equal d.h d'.h) then\n Vector.map ~f:Inner_curve.constant (points_for_domain d)\n else\n Vector.map2\n (which :> (Boolean.var, n) Vector.t)\n domains\n ~f:(fun b d ->\n let points = points_for_domain d in\n Vector.map points ~f:(fun g ->\n let x, y = Inner_curve.constant g in\n Field.((b :> t) * x, (b :> t) * y) ) )\n |> Vector.reduce_exn\n ~f:(Vector.map2 ~f:(Double.map2 ~f:Field.( + )))\n |> Vector.map ~f:(Double.map ~f:(Util.seal (module Impl)))\n in\n let lagrange i =\n select_curve_points ~points_for_domain:(fun d ->\n [ lagrange_commitment d i ] )\n |> Vector.unsingleton\n in\n let lagrange_with_correction ~input_length i :\n (Inner_curve.t, Nat.N2.n) Vector.t =\n let actual_shift =\n (* TODO: num_bits should maybe be input_length - 1. *)\n Ops.bits_per_chunk * Ops.chunks_needed ~num_bits:input_length\n in\n let rec pow2pow x i =\n if i = 0 then x else pow2pow Inner_curve.Constant.(x + x) (i - 1)\n in\n select_curve_points ~points_for_domain:(fun d ->\n let g = lagrange_commitment d i in\n let open Inner_curve.Constant in\n [ g; negate (pow2pow g actual_shift) ] )\n in\n let x_hat =\n let constant_part, non_constant_part =\n List.partition_map\n (Array.to_list (Array.mapi ~f:(fun i t -> (i, t)) public_input))\n ~f:(fun (i, t) ->\n match[@warning \"-4\"] t with\n | `Field (Constant c) | `Packed_bits (Constant c, _) ->\n First\n ( if Field.Constant.(equal zero) c then None\n else if Field.Constant.(equal one) c then Some (lagrange i)\n else\n Some\n ( select_curve_points ~points_for_domain:(fun d ->\n [ Inner_curve.Constant.scale\n (lagrange_commitment d i)\n (Inner_curve.Constant.Scalar.project\n (Field.Constant.unpack c) )\n ] )\n |> Vector.unsingleton ) )\n | `Field x ->\n Second (i, (x, Public_input_scalar.Constant.size_in_bits))\n | `Packed_bits (x, n) ->\n Second (i, (x, n)) )\n in\n let terms =\n List.map non_constant_part ~f:(fun (i, x) ->\n match x with\n | b, 1 ->\n assert_ (Constraint.boolean (b :> Field.t)) ;\n `Cond_add (Boolean.Unsafe.of_cvar b, lagrange i)\n | x, n ->\n `Add_with_correction\n ((x, n), lagrange_with_correction ~input_length:n i) )\n in\n let f = Ops.add_fast ?check_finite:None in\n let correction =\n List.reduce_exn\n (List.filter_map terms ~f:(function\n | `Cond_add _ ->\n None\n | `Add_with_correction (_, [ _; corr ]) ->\n Some corr ) )\n ~f\n in\n let init =\n List.fold (List.filter_map constant_part ~f:Fn.id) ~init:correction ~f\n in\n List.fold terms ~init ~f:(fun acc term ->\n match term with\n | `Cond_add (b, g) ->\n with_label __LOC__ (fun () ->\n Inner_curve.if_ b ~then_:(Ops.add_fast g acc) ~else_:acc )\n | `Add_with_correction ((x, num_bits), [ g; _ ]) ->\n Ops.add_fast acc\n (Ops.scale_fast2' (module Public_input_scalar) g x ~num_bits) )\n |> Inner_curve.negate\n in\n x_hat\n\n let incrementally_verify_proof (type b)\n (module Proofs_verified : Nat.Add.Intf with type n = b) ~srs:_\n ~(domain :\n [ `Known of Domain.t\n | `Side_loaded of\n _ Composition_types.Branch_data.Proofs_verified.One_hot.Checked.t ]\n ) ~srs ~verification_key:(m : _ Plonk_verification_key_evals.t) ~xi\n ~sponge ~sponge_after_index\n ~(public_input :\n [ `Field of Field.t | `Packed_bits of Field.t * int ] array )\n ~(sg_old : (_, Proofs_verified.n) Vector.t) ~advice\n ~proof:({ messages; opening } : Wrap_proof.Checked.t)\n ~(plonk :\n ( _\n , _\n , _ Shifted_value.Type2.t\n , _\n , _\n , _ )\n Types.Wrap.Proof_state.Deferred_values.Plonk.In_circuit.t ) =\n with_label \"incrementally_verify_proof\" (fun () ->\n let receive ty f =\n with_label \"receive\" (fun () ->\n let x = f messages in\n absorb sponge ty x ; x )\n in\n let sample () = squeeze_challenge sponge in\n let sample_scalar () = squeeze_scalar sponge in\n let open Plonk_types.Messages.In_circuit in\n let without = Type.Without_degree_bound in\n let absorb_g gs = absorb sponge without gs in\n let index_digest =\n with_label \"absorb verifier index\" (fun () ->\n let index_sponge = Sponge.copy sponge_after_index in\n Sponge.squeeze_field index_sponge )\n in\n absorb sponge Field index_digest ;\n let sg_old : (_, Wrap_hack.Padded_length.n) Vector.t =\n Wrap_hack.Checked.pad_commitments sg_old\n in\n Vector.iter ~f:(absorb sponge PC) sg_old ;\n let x_hat =\n with_label \"x_hat\" (fun () ->\n match domain with\n | `Known domain ->\n multiscale_known\n (Array.mapi public_input ~f:(fun i x ->\n (x, lagrange_commitment ~domain srs i) ) )\n |> Inner_curve.negate\n | `Side_loaded which ->\n public_input_commitment_dynamic ~srs which\n (Vector.map\n ~f:(fun proofs_verified ->\n Common.wrap_domains ~proofs_verified )\n [ 0; 1; 2 ] )\n ~public_input )\n in\n let x_hat =\n with_label \"x_hat blinding\" (fun () ->\n Ops.add_fast x_hat\n (Inner_curve.constant (Lazy.force Generators.h)) )\n in\n absorb sponge PC x_hat ;\n let w_comm = messages.w_comm in\n Vector.iter ~f:absorb_g w_comm ;\n let beta = sample () in\n let gamma = sample () in\n let z_comm = receive without z_comm in\n let alpha = sample_scalar () in\n let t_comm = receive without t_comm in\n let zeta = sample_scalar () in\n (* At this point, we should use the previous \"bulletproof_challenges\" to\n compute to compute f(beta_1) outside the snark\n where f is the polynomial corresponding to sg_old\n *)\n let sponge_before_evaluations = Sponge.copy sponge in\n let sponge_digest_before_evaluations = Sponge.squeeze_field sponge in\n\n (* xi, r are sampled here using the other sponge. *)\n (* No need to expose the polynomial evaluations as deferred values as they're\n not needed here for the incremental verification. All we need is a_hat and\n \"combined_inner_product\".\n\n Then, in the other proof, we can witness the evaluations and check their correctness\n against \"combined_inner_product\" *)\n let sigma_comm_init, [ _ ] =\n Vector.split m.sigma_comm\n (snd (Plonk_types.Permuts_minus_1.add Nat.N1.n))\n in\n let ft_comm =\n with_label __LOC__ (fun () ->\n Common.ft_comm\n ~add:(Ops.add_fast ?check_finite:None)\n ~scale:scale_fast2 ~negate:Inner_curve.negate\n ~endoscale:(Scalar_challenge.endo ?num_bits:None)\n ~verification_key:m ~plonk ~alpha ~t_comm )\n in\n let bulletproof_challenges =\n (* This sponge needs to be initialized with (some derivative of)\n 1. The polynomial commitments\n 2. The combined inner product\n 3. The challenge points.\n\n It should be sufficient to fork the sponge after squeezing beta_3 and then to absorb\n the combined inner product.\n *)\n let num_commitments_without_degree_bound = Nat.N45.n in\n let without_degree_bound =\n Vector.append\n (Vector.map sg_old ~f:(fun g -> [| g |]))\n ( [| x_hat |] :: [| ft_comm |] :: z_comm :: [| m.generic_comm |]\n :: [| m.psm_comm |] :: [| m.complete_add_comm |]\n :: [| m.mul_comm |] :: [| m.emul_comm |]\n :: [| m.endomul_scalar_comm |]\n :: Vector.append w_comm\n (Vector.append\n (Vector.map m.coefficients_comm ~f:(fun g -> [| g |]))\n (Vector.map sigma_comm_init ~f:(fun g -> [| g |]))\n (snd Plonk_types.(Columns.add Permuts_minus_1.n)) )\n (snd\n Plonk_types.(\n Columns.add (fst (Columns.add Permuts_minus_1.n))) ) )\n (snd\n (Wrap_hack.Padded_length.add\n num_commitments_without_degree_bound ) )\n in\n with_label \"check_bulletproof\" (fun () ->\n check_bulletproof\n ~pcs_batch:\n (Common.dlog_pcs_batch\n (Wrap_hack.Padded_length.add\n num_commitments_without_degree_bound ) )\n ~sponge:sponge_before_evaluations ~xi ~advice ~opening\n ~polynomials:(without_degree_bound, []) )\n in\n let joint_combiner = None in\n assert_eq_deferred_values\n { alpha = plonk.alpha\n ; beta = plonk.beta\n ; gamma = plonk.gamma\n ; zeta = plonk.zeta\n ; joint_combiner\n ; feature_flags = plonk.feature_flags\n }\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; joint_combiner\n ; feature_flags = plonk.feature_flags\n } ;\n (sponge_digest_before_evaluations, bulletproof_challenges) )\n\n let compute_challenges ~scalar chals =\n with_label \"compute_challenges\" (fun () ->\n Vector.map chals ~f:(fun b -> Bulletproof_challenge.pack b |> scalar) )\n\n let challenge_polynomial = Wrap_verifier.challenge_polynomial (module Field)\n\n module Pseudo = Pseudo.Make (Impl)\n\n (* module Bounded = struct\n type t = { max : int; actual : Field.t }\n\n let _of_pseudo ((_, ns) as p : _ Pseudo.t) =\n { max = Vector.reduce_exn ~f:Int.max ns\n ; actual = Pseudo.choose p ~f:Field.of_int\n }\n end *)\n\n let vanishing_polynomial mask =\n with_label \"vanishing_polynomial\" (fun () ->\n let mask = Vector.to_array mask in\n let max = Array.length mask in\n fun x ->\n let rec go acc i =\n if i >= max then acc\n else\n let should_square = mask.(i) in\n let acc =\n Field.if_ should_square ~then_:(Field.square acc) ~else_:acc\n in\n go acc (i + 1)\n in\n Field.sub (go x 0) Field.one )\n\n let shifts ~log2_size = Common.tick_shifts ~log2_size\n\n let domain_generator ~log2_size =\n Backend.Tick.Field.domain_generator ~log2_size |> Impl.Field.constant\n\n let side_loaded_domain =\n let open Side_loaded_verification_key in\n fun ~(log2_size : Field.t) ->\n let domain ~max =\n let (T max_n) = Nat.of_int max in\n let mask = ones_vector (module Impl) max_n ~first_zero:log2_size in\n let log2_sizes =\n ( O.of_index log2_size ~length:(S max_n)\n , Vector.init (S max_n) ~f:Fn.id )\n in\n let shifts = Pseudo.Domain.shifts log2_sizes ~shifts in\n let generator = Pseudo.Domain.generator log2_sizes ~domain_generator in\n let vanishing_polynomial = vanishing_polynomial mask in\n object\n method log2_size = log2_size\n\n method vanishing_polynomial x = vanishing_polynomial x\n\n method shifts = shifts\n\n method generator = generator\n end\n in\n domain ~max:(Domain.log2_size max_domains.h)\n\n let%test_module \"side loaded domains\" =\n ( module struct\n let run k =\n let y =\n run_and_check (fun () ->\n let y = k () in\n fun () -> As_prover.read_var y )\n |> Or_error.ok_exn\n in\n y\n\n let%test_unit \"side loaded domains\" =\n let open Side_loaded_verification_key in\n let domains = [ { Domains.h = 10 }; { h = 15 } ] in\n let pt = Field.Constant.random () in\n List.iter domains ~f:(fun ds ->\n let d_unchecked =\n Plonk_checks.domain\n (module Field.Constant)\n (Pow_2_roots_of_unity ds.h) ~shifts:Common.tick_shifts\n ~domain_generator:Backend.Tick.Field.domain_generator\n in\n let checked_domain () =\n side_loaded_domain ~log2_size:(Field.of_int ds.h)\n in\n [%test_eq: Field.Constant.t]\n (d_unchecked#vanishing_polynomial pt)\n (run (fun () ->\n (checked_domain ())#vanishing_polynomial (Field.constant pt) )\n ) )\n end )\n\n (* module Split_evaluations = struct\n open Plonk_types\n\n let mask' { Bounded.max; actual } : Boolean.var array =\n let (T max) = Nat.of_int max in\n Vector.to_array (ones_vector (module Impl) ~first_zero:actual max)\n\n let mask (type n) ~(lengths : (int, n) Vector.t)\n (choice : n One_hot_vector.T(Impl).t) : Boolean.var array =\n let max =\n Option.value_exn\n (List.max_elt ~compare:Int.compare (Vector.to_list lengths))\n in\n let actual = Pseudo.choose (choice, lengths) ~f:Field.of_int in\n mask' { max; actual }\n\n let _last =\n Array.reduce_exn ~f:(fun (b_acc, x_acc) (b, x) ->\n (Boolean.(b_acc ||| b), Field.if_ b ~then_:x ~else_:x_acc) )\n\n let pow x bits_lsb =\n with_label \"pow\" (fun () ->\n let rec go acc bs =\n match bs with\n | [] ->\n acc\n | b :: bs ->\n let acc = Field.square acc in\n let acc = Field.if_ b ~then_:Field.(x * acc) ~else_:acc in\n go acc bs\n in\n go Field.one (List.rev bits_lsb) )\n\n let _mod_max_degree =\n let k = Nat.to_int Backend.Tick.Rounds.n in\n fun d ->\n let d =\n Number.of_bits\n (Field.unpack\n ~length:Pickles_base.Side_loaded_verification_key.max_log2_degree\n d )\n in\n Number.mod_pow_2 d (`Two_to_the k)\n\n let _mask_evals (type n) ~(lengths : (int, n) Vector.t Evals.t)\n (choice : n One_hot_vector.T(Impl).t) (e : Field.t array Evals.t) :\n (Boolean.var * Field.t) array Evals.t =\n Evals.map2 lengths e ~f:(fun lengths e ->\n Array.zip_exn (mask ~lengths choice) e )\n end *)\n\n let _absorb_field sponge x = Sponge.absorb sponge (`Field x)\n\n (* pt^{2^n} *)\n let pow2_pow (pt : Field.t) (n : int) : Field.t =\n with_label \"pow2_pow\" (fun () ->\n let rec go acc i =\n if i = 0 then acc else go (Field.square acc) (i - 1)\n in\n go pt n )\n\n let actual_evaluation (e : Field.t array) ~(pt_to_n : Field.t) : Field.t =\n with_label \"actual_evaluation\" (fun () ->\n match List.rev (Array.to_list e) with\n | e :: es ->\n List.fold ~init:e es ~f:(fun acc fx -> Field.(fx + (pt_to_n * acc)))\n | [] ->\n Field.zero )\n\n open Plonk_types\n\n module Opt_sponge = struct\n include Opt_sponge.Make (Impl) (Step_main_inputs.Sponge.Permutation)\n\n let _squeeze_challenge sponge : Field.t =\n lowest_128_bits (squeeze sponge) ~constrain_low_bits:true\n end\n\n let shift1 =\n Shifted_value.Type1.Shift.(\n map ~f:Field.constant (create (module Field.Constant)))\n\n let _shift2 =\n Shifted_value.Type2.Shift.(\n map ~f:Field.constant (create (module Field.Constant)))\n\n let%test_unit \"endo scalar\" =\n SC.test (module Impl) ~endo:Endo.Wrap_inner_curve.scalar\n\n module Plonk = Types.Wrap.Proof_state.Deferred_values.Plonk\n\n module Plonk_checks = struct\n include Plonk_checks\n\n include\n Plonk_checks.Make\n (Shifted_value.Type1)\n (struct\n let constant_term = Plonk_checks.Scalars.Tick.constant_term\n\n let index_terms = Plonk_checks.Scalars.Tick.index_terms\n end)\n end\n\n let domain_for_compiled (type branches)\n (domains : (Domains.t, branches) Vector.t)\n (branch_data : Impl.field Branch_data.Checked.t) :\n Field.t Plonk_checks.plonk_domain =\n let (T unique_domains) =\n List.map (Vector.to_list domains) ~f:Domains.h\n |> List.dedup_and_sort ~compare:(fun d1 d2 ->\n Int.compare (Domain.log2_size d1) (Domain.log2_size d2) )\n |> Vector.of_list\n in\n let which_log2 =\n Vector.map unique_domains ~f:(fun d ->\n Field.equal\n (Field.of_int (Domain.log2_size d))\n branch_data.domain_log2 )\n |> O.of_vector_unsafe\n (* This should be ok... think it through a little more *)\n in\n Pseudo.Domain.to_domain\n (which_log2, unique_domains)\n ~shifts ~domain_generator\n\n (* This finalizes the \"deferred values\" coming from a previous proof over the same field.\n It\n 1. Checks that [xi] and [r] where sampled correctly. I.e., by absorbing all the\n evaluation openings and then squeezing.\n 2. Checks that the \"combined inner product\" value used in the elliptic curve part of\n the opening proof was computed correctly, in terms of the evaluation openings and the\n evaluation points.\n 3. Check that the \"b\" value was computed correctly.\n 4. Perform the arithmetic checks from marlin. *)\n (* TODO: This needs to handle the fact of variable length evaluations.\n Meaning it needs opt sponge. *)\n let finalize_other_proof (type b branches)\n (module Proofs_verified : Nat.Add.Intf with type n = b)\n ~(step_domains :\n [ `Known of (Domains.t, branches) Vector.t | `Side_loaded ] )\n ~(* TODO: Add \"actual proofs verified\" so that proofs don't\n carry around dummy \"old bulletproof challenges\" *)\n sponge ~(prev_challenges : (_, b) Vector.t)\n ({ xi\n ; combined_inner_product\n ; bulletproof_challenges\n ; branch_data\n ; b\n ; plonk\n } :\n ( Field.t\n , _\n , Field.t Shifted_value.Type1.t\n , _\n , _\n , _\n , Field.Constant.t Branch_data.Checked.t\n , _ )\n Types.Wrap.Proof_state.Deferred_values.In_circuit.t )\n { Plonk_types.All_evals.In_circuit.ft_eval1; evals } =\n let actual_width_mask = branch_data.proofs_verified_mask in\n let T = Proofs_verified.eq in\n (* You use the NEW bulletproof challenges to check b. Not the old ones. *)\n let scalar =\n SC.to_field_checked (module Impl) ~endo:Endo.Wrap_inner_curve.scalar\n in\n let plonk =\n Types.Wrap.Proof_state.Deferred_values.Plonk.In_circuit.map_challenges\n ~f:Fn.id ~scalar plonk\n in\n let domain =\n match step_domains with\n | `Known ds ->\n domain_for_compiled ds branch_data\n | `Side_loaded ->\n ( side_loaded_domain ~log2_size:branch_data.domain_log2\n :> _ Plonk_checks.plonk_domain )\n in\n let zetaw = Field.mul domain#generator plonk.zeta in\n let sg_olds =\n with_label \"sg_olds\" (fun () ->\n Vector.map prev_challenges ~f:(fun chals ->\n unstage (challenge_polynomial (Vector.to_array chals)) ) )\n in\n let sg_evals1, sg_evals2 =\n let sg_evals pt =\n Vector.map2\n ~f:(fun keep f -> (keep, f pt))\n (Vector.trim_front actual_width_mask\n (Nat.lte_exn Proofs_verified.n Nat.N2.n) )\n sg_olds\n in\n (sg_evals plonk.zeta, sg_evals zetaw)\n in\n let sponge_state =\n let challenge_digest =\n let opt_sponge = Opt_sponge.create sponge_params in\n Vector.iter2\n (Vector.trim_front actual_width_mask\n (Nat.lte_exn Proofs_verified.n Nat.N2.n) )\n prev_challenges\n ~f:(fun keep chals ->\n Vector.iter chals ~f:(fun chal ->\n Opt_sponge.absorb opt_sponge (keep, chal) ) ) ;\n Opt_sponge.squeeze opt_sponge\n in\n Sponge.absorb sponge (`Field challenge_digest) ;\n Sponge.absorb sponge (`Field ft_eval1) ;\n Sponge.absorb sponge (`Field (fst evals.public_input)) ;\n Sponge.absorb sponge (`Field (snd evals.public_input)) ;\n let xs = Evals.In_circuit.to_absorption_sequence evals.evals in\n (* This is a hacky, but much more efficient, version of the opt sponge.\n This uses the assumption that the sponge 'absorption state' will align\n after each optional absorption, letting us skip the expensive tracking\n that this would otherwise require.\n To future-proof this, we assert that the states are indeed compatible.\n *)\n List.iter xs ~f:(fun opt ->\n let absorb =\n Array.iter ~f:(fun x -> Sponge.absorb sponge (`Field x))\n in\n match opt with\n | Nothing ->\n ()\n | Just (x1, x2) ->\n absorb x1 ; absorb x2\n | Maybe (b, (x1, x2)) ->\n (* Cache the sponge state before *)\n let sponge_state_before = sponge.sponge_state in\n let state_before = Array.copy sponge.state in\n (* Absorb the points *)\n absorb x1 ;\n absorb x2 ;\n (* Check that the sponge ends in a compatible state. *)\n ( match (sponge_state_before, sponge.sponge_state) with\n | Absorbed x, Absorbed y ->\n [%test_eq: int] x y\n | Squeezed x, Squeezed y ->\n [%test_eq: int] x y\n | Absorbed _, Squeezed _ ->\n [%test_eq: string] \"absorbed\" \"squeezed\"\n | Squeezed _, Absorbed _ ->\n [%test_eq: string] \"squeezed\" \"absorbed\" ) ;\n let state =\n Array.map2_exn sponge.state state_before ~f:(fun then_ else_ ->\n Field.if_ b ~then_ ~else_ )\n in\n sponge.state <- state ) ;\n Array.copy sponge.state\n in\n sponge.state <- sponge_state ;\n let squeeze () = squeeze_challenge sponge in\n let xi_actual = squeeze () in\n let r_actual = squeeze () in\n let xi_correct =\n Field.equal xi_actual\n (match xi with { Import.Scalar_challenge.inner = xi } -> xi)\n in\n let xi = scalar xi in\n let r = scalar (Import.Scalar_challenge.create r_actual) in\n let plonk_minimal =\n Plonk.to_minimal plonk ~to_option:Opt.to_option_unsafe\n in\n let combined_evals =\n let n = Int.ceil_log2 Max_degree.step in\n let zeta_n : Field.t = pow2_pow plonk.zeta n in\n let zetaw_n : Field.t = pow2_pow zetaw n in\n Evals.In_circuit.map\n ~f:(fun (x0, x1) ->\n ( actual_evaluation ~pt_to_n:zeta_n x0\n , actual_evaluation ~pt_to_n:zetaw_n x1 ) )\n evals.evals\n in\n let env =\n with_label \"scalars_env\" (fun () ->\n let module Env_bool = struct\n include Boolean\n\n type t = Boolean.var\n end in\n let module Env_field = struct\n include Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ =\n match Impl.Field.to_constant (b :> t) with\n | Some x ->\n (* We have a constant, only compute the branch we care about. *)\n if Impl.Field.Constant.(equal one) x then then_ ()\n else else_ ()\n | None ->\n if_ b ~then_:(then_ ()) ~else_:(else_ ())\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~srs_length_log2:Common.Max_degree.step_log2\n ~endo:(Impl.Field.constant Endo.Step_inner_curve.base)\n ~mds:sponge_params.mds\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fp.of_bigint |> Field.constant )\n ~domain plonk_minimal combined_evals )\n in\n let open Field in\n let combined_inner_product_correct =\n let evals1, evals2 =\n All_evals.With_public_input.In_circuit.factor evals\n in\n let ft_eval0 : Field.t =\n with_label \"ft_eval0\" (fun () ->\n Plonk_checks.ft_eval0\n (module Field)\n ~env ~domain plonk_minimal combined_evals evals1.public_input )\n in\n print_fp \"ft_eval0\" ft_eval0 ;\n print_fp \"ft_eval1\" ft_eval1 ;\n (* sum_i r^i sum_j xi^j f_j(beta_i) *)\n let actual_combined_inner_product =\n let combine ~ft ~sg_evals x_hat\n (e : (Field.t array, _) Evals.In_circuit.t) =\n let sg_evals =\n sg_evals |> Vector.to_list\n |> List.map ~f:(fun (keep, eval) -> [| Opt.Maybe (keep, eval) |])\n in\n let a =\n Evals.In_circuit.to_list e\n |> List.map ~f:(function\n | Nothing ->\n [||]\n | Just a ->\n Array.map a ~f:Opt.just\n | Maybe (b, a) ->\n Array.map a ~f:(Opt.maybe b) )\n in\n let v =\n List.append sg_evals ([| Opt.just x_hat |] :: [| Opt.just ft |] :: a)\n in\n Common.combined_evaluation (module Impl) ~xi v\n in\n with_label \"combine\" (fun () ->\n combine ~ft:ft_eval0 ~sg_evals:sg_evals1 evals1.public_input\n evals1.evals\n + r\n * combine ~ft:ft_eval1 ~sg_evals:sg_evals2 evals2.public_input\n evals2.evals )\n in\n let expected =\n Shifted_value.Type1.to_field\n (module Field)\n ~shift:shift1 combined_inner_product\n in\n print_fp \"step_main cip expected\" expected ;\n print_fp \"step_main cip actual\" actual_combined_inner_product ;\n equal expected actual_combined_inner_product\n in\n let bulletproof_challenges =\n compute_challenges ~scalar bulletproof_challenges\n in\n let b_correct =\n with_label \"b_correct\" (fun () ->\n let challenge_poly =\n unstage\n (challenge_polynomial (Vector.to_array bulletproof_challenges))\n in\n let b_actual =\n challenge_poly plonk.zeta + (r * challenge_poly zetaw)\n in\n let b_used =\n Shifted_value.Type1.to_field (module Field) ~shift:shift1 b\n in\n equal b_used b_actual )\n in\n let plonk_checks_passed =\n with_label \"plonk_checks_passed\" (fun () ->\n Plonk_checks.checked\n (module Impl)\n ~env ~shift:shift1 plonk combined_evals )\n in\n print_bool \"xi_correct\" xi_correct ;\n print_bool \"combined_inner_product_correct\" combined_inner_product_correct ;\n print_bool \"plonk_checks_passed\" plonk_checks_passed ;\n print_bool \"b_correct\" b_correct ;\n ( Boolean.all\n [ xi_correct\n ; b_correct\n ; combined_inner_product_correct\n ; plonk_checks_passed\n ]\n , bulletproof_challenges )\n\n let sponge_after_index index =\n let sponge = Sponge.create sponge_params in\n Array.iter\n (Types.index_to_field_elements\n ~g:(fun (z : Inputs.Inner_curve.t) ->\n List.to_array (Inner_curve.to_field_elements z) )\n index )\n ~f:(fun x -> Sponge.absorb sponge (`Field x)) ;\n sponge\n\n let hash_messages_for_next_step_proof (type s) ~index\n (state_to_field_elements : s -> Field.t array) =\n let open Types.Step.Proof_state.Messages_for_next_step_proof in\n let after_index = sponge_after_index index in\n stage (fun (t : _ Types.Step.Proof_state.Messages_for_next_step_proof.t) ->\n let sponge = Sponge.copy after_index in\n Array.iter\n ~f:(fun x -> Sponge.absorb sponge (`Field x))\n (to_field_elements_without_index t ~app_state:state_to_field_elements\n ~g:Inner_curve.to_field_elements ) ;\n Sponge.squeeze_field sponge )\n\n let hash_messages_for_next_step_proof_opt (type s) ~index\n (state_to_field_elements : s -> Field.t array) =\n let open Types.Step.Proof_state.Messages_for_next_step_proof in\n let after_index = sponge_after_index index in\n ( after_index\n , (* TODO: Just get rid of the proofs verified mask and always absorb in full *)\n stage (fun t ~widths:_ ~max_width:_ ~proofs_verified_mask ->\n let sponge = Sponge.copy after_index in\n let t =\n { t with\n old_bulletproof_challenges =\n Vector.map2 proofs_verified_mask t.old_bulletproof_challenges\n ~f:(fun b v -> Vector.map v ~f:(fun x -> `Opt (b, x)))\n ; challenge_polynomial_commitments =\n Vector.map2 proofs_verified_mask\n t.challenge_polynomial_commitments ~f:(fun b g -> (b, g))\n }\n in\n let not_opt x = `Not_opt x in\n let hash_inputs =\n to_field_elements_without_index t\n ~app_state:\n (Fn.compose (Array.map ~f:not_opt) state_to_field_elements)\n ~g:(fun (b, g) ->\n List.map\n ~f:(fun x -> `Opt (b, x))\n (Inner_curve.to_field_elements g) )\n in\n match\n Array.fold hash_inputs ~init:(`Not_opt sponge) ~f:(fun acc t ->\n match (acc, t) with\n | `Not_opt sponge, `Not_opt t ->\n Sponge.absorb sponge (`Field t) ;\n acc\n | `Not_opt sponge, `Opt t ->\n let sponge = Opt_sponge.of_sponge sponge in\n Opt_sponge.absorb sponge t ; `Opt sponge\n | `Opt sponge, `Opt t ->\n Opt_sponge.absorb sponge t ; acc\n | `Opt _, `Not_opt _ ->\n assert false )\n with\n | `Not_opt sponge ->\n (* This means there were no optional inputs. *)\n Sponge.squeeze_field sponge\n | `Opt sponge ->\n Opt_sponge.squeeze sponge ) )\n\n let _accumulation_verifier\n (_accumulator_verification_key : _ Types_map.For_step.t)\n _prev_accumulators _proof _new_accumulator : Boolean.var =\n Boolean.false_\n\n let verify ~proofs_verified ~is_base_case ~sg_old ~sponge_after_index\n ~lookup_parameters ~feature_flags ~(proof : Wrap_proof.Checked.t) ~srs\n ~wrap_domain ~wrap_verification_key statement\n (unfinalized :\n ( _\n , _\n , _ Shifted_value.Type2.t\n , _\n , _\n , _ )\n Types.Step.Proof_state.Per_proof.In_circuit.t ) =\n let public_input :\n [ `Field of Field.t | `Packed_bits of Field.t * int ] array =\n with_label \"pack_statement\" (fun () ->\n Spec.pack\n (module Impl)\n (Types.Wrap.Statement.In_circuit.spec\n (module Impl)\n lookup_parameters feature_flags )\n (Types.Wrap.Statement.In_circuit.to_data ~option_map:Opt.map\n statement ) )\n |> Array.map ~f:(function\n | `Field (Shifted_value.Type1.Shifted_value x) ->\n `Field x\n | `Packed_bits (x, n) ->\n `Packed_bits (x, n) )\n in\n let sponge = Sponge.create sponge_params in\n let { Types.Step.Proof_state.Deferred_values.xi\n ; combined_inner_product\n ; b\n ; _\n } =\n unfinalized.deferred_values\n in\n let ( sponge_digest_before_evaluations_actual\n , (`Success bulletproof_success, bulletproof_challenges_actual) ) =\n incrementally_verify_proof ~srs proofs_verified ~srs ~domain:wrap_domain\n ~xi ~verification_key:wrap_verification_key ~sponge ~sponge_after_index\n ~public_input ~sg_old\n ~advice:{ b; combined_inner_product }\n ~proof\n ~plonk:\n (Composition_types.Step.Proof_state.Deferred_values.Plonk.In_circuit\n .to_wrap ~opt_none:Opt.nothing ~false_:Boolean.false_\n unfinalized.deferred_values.plonk )\n in\n with_label __LOC__ (fun () ->\n with_label __LOC__ (fun () ->\n Field.Assert.equal unfinalized.sponge_digest_before_evaluations\n sponge_digest_before_evaluations_actual ) ;\n Array.iteri\n (Vector.to_array unfinalized.deferred_values.bulletproof_challenges)\n ~f:(fun i c1 ->\n let c2 = bulletproof_challenges_actual.(i) in\n let { Import.Scalar_challenge.inner = c1 } =\n Bulletproof_challenge.pack c1\n in\n let c2 =\n Field.if_ is_base_case ~then_:c1\n ~else_:(match c2.prechallenge with { inner = c2 } -> c2)\n in\n with_label (sprintf \"%s:%d\" __LOC__ i) (fun () ->\n Field.Assert.equal c1 c2 ) ) ) ;\n bulletproof_success\nend\n\ninclude Make (Step_main_inputs)\n","open Core_kernel\n\n[@@@warning \"-4-27\"]\n\nmodule Yojson_map = Map.Make (struct\n type t =\n [ `Null\n | `Bool of bool\n | `Int of int\n | `Intlit of string\n | `Float of float\n | `String of string\n | `Assoc of (string * t) list\n | `List of t list\n | `Tuple of t list\n | `Variant of string * t option ]\n [@@deriving compare, sexp]\nend)\n\n[@@@warning \"+4+27\"]\n\ntype t = Yojson.Safe.t Yojson_map.t Yojson_map.t ref\n\n(* We use a slightly more verbose format here, so that it's easy to debug.\n There are some overheads to handling this, but the amount of computation we\n save by caching the proofs is orders of magnitude higher, so it's not really\n an issue.\n*)\nlet to_yojson t =\n `List\n (Map.fold ~init:[] !t ~f:(fun ~key ~data xs ->\n let proofs =\n Map.fold ~init:[] data ~f:(fun ~key ~data xs ->\n `Assoc [ (\"public_input\", key); (\"proof\", data) ] :: xs )\n in\n `Assoc [ (\"verification_key\", key); (\"proofs\", `List proofs) ] :: xs )\n )\n\n(* This mirrors the format of [to_yojson], carefully ensuring that we can\n decode what we encode, and reporting an error when the format differs from\n what we expect.\n\n Note that, since this is a cache, it should always be possible to regenerate\n proofs for the cache by starting with the empty cache and calling\n [to_yojson] on the result.\n*)\nlet of_yojson t =\n Result.try_with (fun () ->\n match t with\n | `List xs ->\n let for_vks =\n List.map xs ~f:(function\n | `Assoc [ (\"verification_key\", key); (\"proofs\", `List proofs) ]\n ->\n let proofs =\n List.map proofs ~f:(function\n | `Assoc [ (\"public_input\", key); (\"proof\", data) ] ->\n (key, data)\n | _ ->\n failwith\n \"Expected fields `public_input`, `proof` as a \\\n record in that order; received something \\\n different\" )\n in\n (key, Yojson_map.of_alist_exn proofs)\n | _ ->\n failwith\n \"Expected fields `verification_key`, `proofs` as a record \\\n in that order, where `proofs` is a list; received \\\n something different\" )\n in\n ref (Yojson_map.of_alist_exn for_vks)\n | _ ->\n failwith \"Expected a list, got something different\" )\n |> Result.map_error ~f:Exn.to_string\n\n(* Alias types with a [deriving to_yojson] annotation, so that we don't have to\n spell out the serialization explicitly.\n*)\nmodule Json = struct\n type 'f or_infinity = 'f Kimchi_types.or_infinity =\n | Infinity\n | Finite of ('f * 'f)\n [@@deriving to_yojson]\n\n type 'caml_g poly_comm = 'caml_g Kimchi_types.poly_comm =\n { unshifted : 'caml_g array; shifted : 'caml_g option }\n [@@deriving to_yojson]\n\n type lookup_patterns = Kimchi_types.lookup_patterns =\n { xor : bool; lookup : bool; range_check : bool; foreign_field_mul : bool }\n [@@deriving to_yojson]\n\n type lookup_features = Kimchi_types.lookup_features =\n { patterns : lookup_patterns\n ; joint_lookup_used : bool\n ; uses_runtime_tables : bool\n }\n [@@deriving to_yojson]\n\n type lookups_used = Kimchi_types.VerifierIndex.Lookup.lookups_used =\n | Single\n | Joint\n [@@deriving to_yojson]\n\n type lookup_info = Kimchi_types.VerifierIndex.Lookup.lookup_info =\n { max_per_row : int; max_joint_size : int; features : lookup_features }\n [@@deriving to_yojson]\n\n type 't lookup_selectors =\n 't Kimchi_types.VerifierIndex.Lookup.lookup_selectors =\n { lookup : 't option\n ; xor : 't option\n ; range_check : 't option\n ; ffmul : 't option\n }\n [@@deriving to_yojson]\n\n type 'poly_comm lookup = 'poly_comm Kimchi_types.VerifierIndex.Lookup.t =\n { joint_lookup_used : bool\n ; lookup_table : 'poly_comm array\n ; lookup_selectors : 'poly_comm lookup_selectors\n ; table_ids : 'poly_comm option\n ; lookup_info : lookup_info\n ; runtime_tables_selector : 'poly_comm option\n }\n [@@deriving to_yojson]\n\n type 'fr domain = 'fr Kimchi_types.VerifierIndex.domain =\n { log_size_of_group : int; group_gen : 'fr }\n [@@deriving to_yojson]\n\n type 'poly_comm verification_evals =\n 'poly_comm Kimchi_types.VerifierIndex.verification_evals =\n { sigma_comm : 'poly_comm array\n ; coefficients_comm : 'poly_comm array\n ; generic_comm : 'poly_comm\n ; psm_comm : 'poly_comm\n ; complete_add_comm : 'poly_comm\n ; mul_comm : 'poly_comm\n ; emul_comm : 'poly_comm\n ; endomul_scalar_comm : 'poly_comm\n ; xor_comm : 'poly_comm option [@default None]\n ; range_check0_comm : 'poly_comm option [@default None]\n ; range_check1_comm : 'poly_comm option [@default None]\n ; foreign_field_add_comm : 'poly_comm option [@default None]\n ; foreign_field_mul_comm : 'poly_comm option [@default None]\n ; rot_comm : 'poly_comm option [@default None]\n }\n [@@deriving to_yojson]\n\n type ('fr, 'srs, 'poly_comm) verifier_index =\n ('fr, 'srs, 'poly_comm) Kimchi_types.VerifierIndex.verifier_index =\n { domain : 'fr domain\n ; max_poly_size : int\n ; public : int\n ; prev_challenges : int\n ; srs : 'srs\n ; evals : 'poly_comm verification_evals\n ; shifts : 'fr array\n ; lookup_index : 'poly_comm lookup option\n }\n [@@deriving to_yojson]\n\n let srs_to_yojson _ = `Null\n\n let step_verification_key_to_yojson =\n [%to_yojson:\n ( Backend.Tick.Field.t\n , srs\n , Backend.Tock.Field.t or_infinity poly_comm )\n verifier_index]\n\n let wrap_verification_key_to_yojson =\n [%to_yojson:\n ( Backend.Tock.Field.t\n , srs\n , Backend.Tick.Field.t or_infinity poly_comm )\n verifier_index]\nend\n\nlet empty () = ref Yojson_map.empty\n\nlet get_proof t ~verification_key ~public_input =\n let open Option.Let_syntax in\n let%bind for_vk = Map.find !t verification_key in\n Map.find for_vk public_input\n\nlet get_step_proof t ~keypair ~public_input =\n let open Option.Let_syntax in\n let public_input =\n let len = Kimchi_bindings.FieldVectors.Fp.length public_input in\n Array.init len ~f:(fun i ->\n Kimchi_bindings.FieldVectors.Fp.get public_input i )\n |> [%to_yojson: Backend.Tick.Field.t array]\n in\n let verification_key =\n Backend.Tick.Keypair.vk keypair |> Json.step_verification_key_to_yojson\n in\n let%bind proof_json = get_proof t ~verification_key ~public_input in\n Option.try_with (fun () ->\n Result.ok_or_failwith @@ Backend.Tick.Proof.of_yojson proof_json )\n\nlet get_wrap_proof t ~keypair ~public_input =\n let open Option.Let_syntax in\n let public_input =\n let len = Kimchi_bindings.FieldVectors.Fq.length public_input in\n Array.init len ~f:(fun i ->\n Kimchi_bindings.FieldVectors.Fq.get public_input i )\n |> [%to_yojson: Backend.Tock.Field.t array]\n in\n let verification_key =\n Backend.Tock.Keypair.vk keypair |> Json.wrap_verification_key_to_yojson\n in\n let%bind proof_json = get_proof t ~verification_key ~public_input in\n Option.try_with (fun () ->\n Result.ok_or_failwith @@ Backend.Tock.Proof.of_yojson proof_json )\n\nlet set_proof t ~verification_key ~public_input proof =\n t :=\n Map.update !t verification_key ~f:(function\n | None ->\n Yojson_map.singleton public_input proof\n | Some for_vk ->\n Map.set for_vk ~key:public_input ~data:proof )\n\nlet set_step_proof t ~keypair ~public_input proof =\n let public_input =\n let len = Kimchi_bindings.FieldVectors.Fp.length public_input in\n Array.init len ~f:(fun i ->\n Kimchi_bindings.FieldVectors.Fp.get public_input i )\n |> [%to_yojson: Backend.Tick.Field.t array]\n in\n let verification_key =\n Backend.Tick.Keypair.vk keypair |> Json.step_verification_key_to_yojson\n in\n let proof_json = Backend.Tick.Proof.to_yojson proof in\n set_proof t ~verification_key ~public_input proof_json\n\nlet set_wrap_proof t ~keypair ~public_input proof =\n let public_input =\n let len = Kimchi_bindings.FieldVectors.Fq.length public_input in\n Array.init len ~f:(fun i ->\n Kimchi_bindings.FieldVectors.Fq.get public_input i )\n |> [%to_yojson: Backend.Tock.Field.t array]\n in\n let verification_key =\n Backend.Tock.Keypair.vk keypair |> Json.wrap_verification_key_to_yojson\n in\n let proof_json = Backend.Tock.Proof.to_yojson proof in\n set_proof t ~verification_key ~public_input proof_json\n","open Core_kernel\n\nmodule Step = struct\n module Key = struct\n module Proving = struct\n type t =\n Type_equal.Id.Uid.t\n * Snark_keys_header.t\n * int\n * Backend.Tick.R1CS_constraint_system.t\n\n let to_string : t -> _ = function\n | _id, header, n, _h ->\n sprintf !\"step-%s-%s-%d-%s\" header.kind.type_ header.kind.identifier\n n header.identifying_hash\n end\n\n module Verification = struct\n type t = Type_equal.Id.Uid.t * Snark_keys_header.t * int * Md5.t\n [@@deriving sexp]\n\n let to_string : t -> _ = function\n | _id, header, n, _h ->\n sprintf !\"vk-step-%s-%s-%d-%s\" header.kind.type_\n header.kind.identifier n header.identifying_hash\n end\n [@@warning \"-4\"]\n end\n\n let storable =\n Key_cache.Sync.Disk_storable.simple Key.Proving.to_string\n (fun (_, header, _, cs) ~path ->\n Or_error.try_with_join (fun () ->\n let open Or_error.Let_syntax in\n let%map header_read, index =\n Snark_keys_header.read_with_header\n ~read_data:(fun ~offset ->\n Kimchi_bindings.Protocol.Index.Fp.read (Some offset)\n (Backend.Tick.Keypair.load_urs ()) )\n path\n in\n [%test_eq: int] header.header_version header_read.header_version ;\n [%test_eq: Snark_keys_header.Kind.t] header.kind header_read.kind ;\n [%test_eq: Snark_keys_header.Constraint_constants.t]\n header.constraint_constants header_read.constraint_constants ;\n [%test_eq: string] header.constraint_system_hash\n header_read.constraint_system_hash ;\n { Backend.Tick.Keypair.index; cs } ) )\n (fun (_, header, _, _) t path ->\n Or_error.try_with (fun () ->\n Snark_keys_header.write_with_header\n ~expected_max_size_log2:33 (* 8 GB should be enough *)\n ~append_data:\n (Kimchi_bindings.Protocol.Index.Fp.write (Some true)\n t.Backend.Tick.Keypair.index )\n header path ) )\n\n let vk_storable =\n Key_cache.Sync.Disk_storable.simple Key.Verification.to_string\n (fun (_, header, _, _) ~path ->\n Or_error.try_with_join (fun () ->\n let open Or_error.Let_syntax in\n let%map header_read, index =\n Snark_keys_header.read_with_header\n ~read_data:(fun ~offset path ->\n Kimchi_bindings.Protocol.VerifierIndex.Fp.read (Some offset)\n (Backend.Tick.Keypair.load_urs ())\n path )\n path\n in\n [%test_eq: int] header.header_version header_read.header_version ;\n [%test_eq: Snark_keys_header.Kind.t] header.kind header_read.kind ;\n [%test_eq: Snark_keys_header.Constraint_constants.t]\n header.constraint_constants header_read.constraint_constants ;\n [%test_eq: string] header.constraint_system_hash\n header_read.constraint_system_hash ;\n index ) )\n (fun (_, header, _, _) x path ->\n Or_error.try_with (fun () ->\n Snark_keys_header.write_with_header\n ~expected_max_size_log2:33 (* 8 GB should be enough *)\n ~append_data:\n (Kimchi_bindings.Protocol.VerifierIndex.Fp.write (Some true) x)\n header path ) )\n\n let read_or_generate ~prev_challenges cache k_p k_v typ return_typ main =\n let s_p = storable in\n let s_v = vk_storable in\n let open Impls.Step in\n let pk =\n lazy\n ( match\n Common.time \"step keypair read\" (fun () ->\n Key_cache.Sync.read cache s_p (Lazy.force k_p) )\n with\n | Ok (pk, dirty) ->\n Common.time \"step keypair create\" (fun () ->\n (Keypair.create ~pk ~vk:(Backend.Tick.Keypair.vk pk), dirty) )\n | Error _e ->\n let r =\n Common.time \"stepkeygen\" (fun () ->\n constraint_system ~input_typ:typ ~return_typ main\n |> Keypair.generate ~prev_challenges )\n in\n Timer.clock __LOC__ ;\n ignore\n ( Key_cache.Sync.write cache s_p (Lazy.force k_p) (Keypair.pk r)\n : unit Or_error.t ) ;\n (r, `Generated_something) )\n in\n let vk =\n lazy\n (let k_v = Lazy.force k_v in\n match\n Common.time \"step vk read\" (fun () ->\n Key_cache.Sync.read cache s_v k_v )\n with\n | Ok (vk, _) ->\n (vk, `Cache_hit)\n | Error _e ->\n let pk, c = Lazy.force pk in\n let vk = Keypair.vk pk in\n ignore (Key_cache.Sync.write cache s_v k_v vk : unit Or_error.t) ;\n (vk, c) )\n in\n (pk, vk)\nend\n\nmodule Wrap = struct\n module Key = struct\n module Verification = struct\n type t = Type_equal.Id.Uid.t * Snark_keys_header.t * Md5.t\n [@@deriving sexp]\n\n let equal ((_, x1, y1) : t) ((_, x2, y2) : t) =\n [%equal: unit * Md5.t] ((* TODO: *) ignore x1, y1) (ignore x2, y2)\n\n let to_string : t -> _ = function\n | _id, header, _h ->\n sprintf !\"vk-wrap-%s-%s-%s\" header.kind.type_ header.kind.identifier\n header.identifying_hash\n end\n [@@warning \"-4\"]\n\n module Proving = struct\n type t =\n Type_equal.Id.Uid.t\n * Snark_keys_header.t\n * Backend.Tock.R1CS_constraint_system.t\n\n let to_string : t -> _ = function\n | _id, header, _h ->\n sprintf !\"wrap-%s-%s-%s\" header.kind.type_ header.kind.identifier\n header.identifying_hash\n end\n end\n\n let storable =\n Key_cache.Sync.Disk_storable.simple Key.Proving.to_string\n (fun (_, header, cs) ~path ->\n Or_error.try_with_join (fun () ->\n let open Or_error.Let_syntax in\n let%map header_read, index =\n Snark_keys_header.read_with_header\n ~read_data:(fun ~offset ->\n Kimchi_bindings.Protocol.Index.Fq.read (Some offset)\n (Backend.Tock.Keypair.load_urs ()) )\n path\n in\n [%test_eq: int] header.header_version header_read.header_version ;\n [%test_eq: Snark_keys_header.Kind.t] header.kind header_read.kind ;\n [%test_eq: Snark_keys_header.Constraint_constants.t]\n header.constraint_constants header_read.constraint_constants ;\n [%test_eq: string] header.constraint_system_hash\n header_read.constraint_system_hash ;\n { Backend.Tock.Keypair.index; cs } ) )\n (fun (_, header, _) t path ->\n Or_error.try_with (fun () ->\n Snark_keys_header.write_with_header\n ~expected_max_size_log2:33 (* 8 GB should be enough *)\n ~append_data:\n (Kimchi_bindings.Protocol.Index.Fq.write (Some true) t.index)\n header path ) )\n\n let read_or_generate ~prev_challenges cache k_p k_v typ return_typ main =\n let module Vk = Verification_key in\n let open Impls.Wrap in\n let s_p = storable in\n let pk =\n lazy\n (let k = Lazy.force k_p in\n match\n Common.time \"wrap key read\" (fun () ->\n Key_cache.Sync.read cache s_p k )\n with\n | Ok (pk, d) ->\n (Keypair.create ~pk ~vk:(Backend.Tock.Keypair.vk pk), d)\n | Error _e ->\n let r =\n Common.time \"wrapkeygen\" (fun () ->\n constraint_system ~input_typ:typ ~return_typ main\n |> Keypair.generate ~prev_challenges )\n in\n ignore\n ( Key_cache.Sync.write cache s_p k (Keypair.pk r)\n : unit Or_error.t ) ;\n (r, `Generated_something) )\n in\n let vk =\n lazy\n (let k_v = Lazy.force k_v in\n let s_v =\n Key_cache.Sync.Disk_storable.simple Key.Verification.to_string\n (fun (_, header, _cs) ~path ->\n Or_error.try_with_join (fun () ->\n let open Or_error.Let_syntax in\n let%map header_read, index =\n Snark_keys_header.read_with_header\n ~read_data:(fun ~offset:_ path ->\n Binable.of_string\n (module Vk.Stable.Latest)\n (In_channel.read_all path) )\n path\n in\n [%test_eq: int] header.header_version\n header_read.header_version ;\n [%test_eq: Snark_keys_header.Kind.t] header.kind\n header_read.kind ;\n [%test_eq: Snark_keys_header.Constraint_constants.t]\n header.constraint_constants\n header_read.constraint_constants ;\n [%test_eq: string] header.constraint_system_hash\n header_read.constraint_system_hash ;\n index ) )\n (fun (_, header, _) t path ->\n Or_error.try_with (fun () ->\n Snark_keys_header.write_with_header\n ~expected_max_size_log2:33 (* 8 GB should be enough *)\n ~append_data:(fun path ->\n Out_channel.with_file ~append:true path ~f:(fun file ->\n Out_channel.output_string file\n (Binable.to_string (module Vk.Stable.Latest) t) )\n )\n header path ) )\n in\n match Key_cache.Sync.read cache s_v k_v with\n | Ok (vk, d) ->\n (vk, d)\n | Error _e ->\n let kp, _dirty = Lazy.force pk in\n let vk = Keypair.vk kp in\n let pk = Keypair.pk kp in\n let vk : Vk.t =\n { index = vk\n ; commitments =\n Kimchi_pasta.Pallas_based_plonk.Keypair.vk_commitments vk\n ; data =\n (let open Kimchi_bindings.Protocol.Index.Fq in\n { constraints = domain_d1_size pk.index })\n }\n in\n ignore (Key_cache.Sync.write cache s_v k_v vk : unit Or_error.t) ;\n let _vk = Key_cache.Sync.read cache s_v k_v in\n (vk, `Generated_something) )\n in\n (pk, vk)\nend\n","open Core_kernel\nopen Bitstring_lib\nopen Snark_bits\n\nmodule Make_snarkable (Impl : Snarky_backendless.Snark_intf.S) = struct\n open Impl\n\n module type S = sig\n type var\n\n type value\n\n val typ : (var, value) Typ.t\n end\n\n module Bits = struct\n module type Lossy =\n Bits_intf.Snarkable.Lossy\n with type ('a, 'b) typ := ('a, 'b) Typ.t\n and type 'a checked := 'a Checked.t\n and type boolean_var := Boolean.var\n\n module type Faithful =\n Bits_intf.Snarkable.Faithful\n with type ('a, 'b) typ := ('a, 'b) Typ.t\n and type 'a checked := 'a Checked.t\n and type boolean_var := Boolean.var\n\n module type Small =\n Bits_intf.Snarkable.Small\n with type ('a, 'b) typ := ('a, 'b) Typ.t\n and type 'a checked := 'a Checked.t\n and type boolean_var := Boolean.var\n and type comparison_result := Field.Checked.comparison_result\n and type field_var := Field.Var.t\n end\nend\n\nmodule Tock0 = struct\n include Crypto_params.Tock\n module Snarkable = Make_snarkable (Crypto_params.Tock)\nend\n\nmodule Tick0 = struct\n include Crypto_params.Tick\n module Snarkable = Make_snarkable (Crypto_params.Tick)\nend\n\nlet%test_unit \"group-map test\" =\n let params = Crypto_params.Tock.group_map_params () in\n let module M = Crypto_params.Tick.Run in\n Quickcheck.test ~trials:3 Tick0.Field.gen ~f:(fun t ->\n let checked_output =\n M.run_and_check (fun () ->\n let x, y =\n Snarky_group_map.Checked.to_group\n (module M)\n ~params (M.Field.constant t)\n in\n fun () -> M.As_prover.(read_var x, read_var y) )\n |> Or_error.ok_exn\n in\n let ((x, y) as actual) =\n Group_map.to_group (module Tick0.Field) ~params t\n in\n [%test_eq: Tick0.Field.t]\n Tick0.Field.(\n (x * x * x)\n + (Tick0.Inner_curve.Params.a * x)\n + Tick0.Inner_curve.Params.b)\n Tick0.Field.(y * y) ;\n [%test_eq: Tick0.Field.t * Tick0.Field.t] checked_output actual )\n\nmodule Make_inner_curve_scalar (Impl : Snark_intf.S) (Other_impl : Snark_intf.S) =\nstruct\n module T = Other_impl.Field\n\n include (\n T :\n module type of T with module Var := T.Var and module Checked := T.Checked )\n\n let of_bits = Other_impl.Field.project\n\n let length_in_bits = size_in_bits\n\n open Impl\n\n type var = Boolean.var Bitstring.Lsb_first.t\n\n let typ : (var, t) Typ.t =\n Typ.transport_var\n (Typ.transport\n (Typ.list ~length:size_in_bits Boolean.typ)\n ~there:unpack ~back:project )\n ~there:Bitstring.Lsb_first.to_list ~back:Bitstring.Lsb_first.of_list\n\n let gen : t Quickcheck.Generator.t =\n Quickcheck.Generator.map\n (Bignum_bigint.gen_incl Bignum_bigint.one\n Bignum_bigint.(Other_impl.Field.size - one) )\n ~f:(fun x -> Other_impl.Bigint.(to_field (of_bignum_bigint x)))\n\n let test_bit x i = Other_impl.Bigint.(test_bit (of_field x) i)\n\n module Checked = struct\n let equal a b =\n Bitstring_checked.equal\n (Bitstring.Lsb_first.to_list a)\n (Bitstring.Lsb_first.to_list b)\n\n let to_bits = Fn.id\n\n module Assert = struct\n let equal : var -> var -> unit Checked.t =\n fun a b ->\n Bitstring_checked.Assert.equal\n (Bitstring.Lsb_first.to_list a)\n (Bitstring.Lsb_first.to_list b)\n end\n end\nend\n\nmodule Make_inner_curve_aux (Impl : Snark_intf.S) (Other_impl : Snark_intf.S) =\nstruct\n open Impl\n\n type var = Field.Var.t * Field.Var.t\n\n module Scalar = Make_inner_curve_scalar (Impl) (Other_impl)\nend\n\nmodule Tock = struct\n include (\n Tock0 : module type of Tock0 with module Inner_curve := Tock0.Inner_curve )\n\n module Fq = Snarky_field_extensions.Field_extensions.F (Tock0)\n\n module Inner_curve = struct\n include Tock0.Inner_curve\n\n include\n Sexpable.Of_sexpable\n (struct\n type t = Field.t * Field.t [@@deriving sexp]\n end)\n (struct\n type nonrec t = t\n\n let to_sexpable = to_affine_exn\n\n let of_sexpable = of_affine\n end)\n\n include Make_inner_curve_aux (Tock0) (Tick0)\n\n module Checked = struct\n include\n Snarky_curves.Make_weierstrass_checked (Fq) (Scalar)\n (struct\n include Tock0.Inner_curve\n end)\n (Params)\n (struct\n let add = None\n end)\n\n let add_known_unsafe t x = add_unsafe t (constant x)\n end\n\n let typ = Checked.typ\n end\nend\n\nmodule Tick = struct\n include (\n Tick0 :\n module type of Tick0\n with module Field := Tick0.Field\n and module Inner_curve := Tick0.Inner_curve )\n\n module Field = struct\n include Hashable.Make (Tick0.Field)\n include Tick0.Field\n module Bits = Bits.Make_field (Tick0.Field) (Tick0.Bigint)\n\n let size_in_triples = Int.((size_in_bits + 2) / 3)\n end\n\n module Fq = Snarky_field_extensions.Field_extensions.F (Tick0)\n\n module Inner_curve = struct\n include Crypto_params.Tick.Inner_curve\n\n include\n Sexpable.Of_sexpable\n (struct\n type t = Field.t * Field.t [@@deriving sexp]\n end)\n (struct\n type nonrec t = t\n\n let to_sexpable = to_affine_exn\n\n let of_sexpable = of_affine\n end)\n\n include Make_inner_curve_aux (Tick0) (Tock0)\n\n module Checked = struct\n include\n Snarky_curves.Make_weierstrass_checked (Fq) (Scalar)\n (Crypto_params.Tick.Inner_curve)\n (Params)\n (struct\n let add =\n Some\n (fun p1 p2 ->\n Run.make_checked (fun () ->\n Pickles.Step_main_inputs.Ops.add_fast p1 p2 ) )\n end)\n\n let add_known_unsafe t x = add_unsafe t (constant x)\n end\n\n let typ = Checked.typ\n end\n\n module Util = Snark_util.Make (Tick0)\n\n let m : Run.field Snarky_backendless.Snark.m = (module Run)\n\n let make_checked c = Run.make_checked c\nend\n\n(* Let n = Tick.Field.size_in_bits.\n Let k = n - 3.\n The reason k = n - 3 is as follows. Inside [meets_target], we compare\n a value against 2^k. 2^k requires k + 1 bits. The comparison then unpacks\n a (k + 1) + 1 bit number. This number cannot overflow so it is important that\n k + 1 + 1 < n. Thus k < n - 2.\n\n However, instead of using `Field.size_in_bits - 3` we choose `Field.size_in_bits - 8`\n to clamp the easiness. To something not-to-quick on a personal laptop from mid 2010s.\n*)\nlet target_bit_length = Tick.Field.size_in_bits - 8\n\nmodule type Snark_intf = Snark_intf.S\n\nmodule Group_map = struct\n let to_group x =\n Group_map.to_group (module Tick.Field) ~params:(Tock.group_map_params ()) x\n\n module Checked = struct\n let to_group x =\n Snarky_group_map.Checked.to_group\n (module Tick.Run)\n ~params:(Tock.group_map_params ()) x\n end\nend\n","open Core_kernel\nmodule Inputs = Pickles.Tick_field_sponge.Inputs\nmodule Ocaml_permutation = Sponge.Poseidon (Inputs)\nmodule Field = Kimchi_backend.Pasta.Basic.Fp\n\nlet add_assign = Ocaml_permutation.add_assign\n\nlet copy = Ocaml_permutation.copy\n\nlet params = Kimchi_pasta_fp_poseidon.create ()\n\nlet block_cipher _params (s : Field.t array) =\n let v = Kimchi_bindings.FieldVectors.Fp.create () in\n Array.iter s ~f:(Kimchi_bindings.FieldVectors.Fp.emplace_back v) ;\n Kimchi_pasta_fp_poseidon.block_cipher params v ;\n Array.init (Array.length s) ~f:(Kimchi_bindings.FieldVectors.Fp.get v)\n\nlet%test_unit \"check rust implementation of block-cipher\" =\n let params' : Field.t Sponge.Params.t =\n Kimchi_pasta_basic.poseidon_params_fp\n in\n let open Pickles.Impls.Step in\n let module T = Internal_Basic in\n Quickcheck.test (Quickcheck.Generator.list_with_length 3 T.Field.gen)\n ~f:(fun s ->\n let s () = Array.of_list s in\n [%test_eq: T.Field.t array]\n (Ocaml_permutation.block_cipher params' (s ()))\n (block_cipher params' (s ())) )\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n[%%ifdef consensus_mechanism]\n\nopen Pickles.Impls.Step.Internal_Basic\n\n[%%else]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nmodule State = struct\n include Array\n\n let map2 = map2_exn\n\n let to_array t = t\n\n let of_array t = t\nend\n\nmodule Input = Random_oracle_input\n\nlet params : Field.t Sponge.Params.t = Kimchi_pasta_basic.poseidon_params_fp\n\nmodule Operations = struct\n let add_assign ~state i x = Field.(state.(i) <- state.(i) + x)\n\n let apply_affine_map (matrix, constants) v =\n let dotv row =\n Array.reduce_exn (Array.map2_exn row v ~f:Field.( * )) ~f:Field.( + )\n in\n let res = Array.map matrix ~f:dotv in\n Array.map2_exn res constants ~f:Field.( + )\n\n let copy a = Array.map a ~f:Fn.id\nend\n\nmodule Digest = struct\n type t = Field.t\n\n let to_bits ?length x =\n match length with\n | None ->\n Field.unpack x\n | Some length ->\n List.take (Field.unpack x) length\nend\n\ninclude Sponge.Make_hash (Random_oracle_permutation)\n\nlet update ~state = update ~state params\n\nlet hash ?init = hash ?init params\n\nlet pow2 =\n let rec pow2 acc n = if n = 0 then acc else pow2 Field.(acc + acc) (n - 1) in\n Memo.general ~hashable:Int.hashable (fun n -> pow2 Field.one n)\n\n[%%ifdef consensus_mechanism]\n\nmodule Checked = struct\n module Inputs = Pickles.Step_main_inputs.Sponge.Permutation\n\n module Digest = struct\n open Pickles.Impls.Step.Field\n\n type nonrec t = t\n\n let to_bits ?(length = Field.size_in_bits) (x : t) =\n List.take (choose_preimage_var ~length:Field.size_in_bits x) length\n end\n\n include Sponge.Make_hash (Inputs)\n\n let params = Sponge.Params.map ~f:Inputs.Field.constant params\n\n open Inputs.Field\n\n let update ~state xs = update params ~state xs\n\n let hash ?init xs =\n hash ?init:(Option.map init ~f:(State.map ~f:constant)) params xs\n\n let pack_input =\n Input.Chunked.pack_to_fields\n ~pow2:(Fn.compose Field.Var.constant pow2)\n (module Pickles.Impls.Step.Field)\n\n let digest xs = xs.(0)\nend\n\nlet read_typ ({ field_elements; packeds } : _ Input.Chunked.t) =\n let open Pickles.Impls.Step in\n let open As_prover in\n { Input.Chunked.field_elements = Array.map ~f:(read Field.typ) field_elements\n ; packeds = Array.map packeds ~f:(fun (x, i) -> (read Field.typ x, i))\n }\n\nlet read_typ' input : _ Pickles.Impls.Step.Internal_Basic.As_prover.t =\n fun _ -> read_typ input\n\n[%%endif]\n\nlet pack_input = Input.Chunked.pack_to_fields ~pow2 (module Field)\n\nlet prefix_to_field (s : string) =\n let bits_per_character = 8 in\n assert (bits_per_character * String.length s < Field.size_in_bits) ;\n Field.project Fold_lib.Fold.(to_list (string_bits (s :> string)))\n\nlet salt (s : string) = update ~state:initial_state [| prefix_to_field s |]\n\nlet%test_unit \"iterativeness\" =\n let x1 = Field.random () in\n let x2 = Field.random () in\n let x3 = Field.random () in\n let x4 = Field.random () in\n let s_full = update ~state:initial_state [| x1; x2; x3; x4 |] in\n let s_it =\n update ~state:(update ~state:initial_state [| x1; x2 |]) [| x3; x4 |]\n in\n [%test_eq: Field.t array] s_full s_it\n\n[%%ifdef consensus_mechanism]\n\nlet%test_unit \"sponge checked-unchecked\" =\n let open Pickles.Impls.Step in\n let module T = Internal_Basic in\n let x = T.Field.random () in\n let y = T.Field.random () in\n T.Test.test_equal ~equal:T.Field.equal ~sexp_of_t:T.Field.sexp_of_t\n T.Typ.(field * field)\n T.Typ.field\n (fun (x, y) -> make_checked (fun () -> Checked.hash [| x; y |]))\n (fun (x, y) -> hash [| x; y |])\n (x, y)\n\n[%%endif]\n\nmodule Legacy = struct\n module Input = Random_oracle_input.Legacy\n module State = State\n\n let params : Field.t Sponge.Params.t =\n Sponge.Params.(map pasta_p_legacy ~f:Kimchi_pasta_basic.Fp.of_string)\n\n module Rounds = struct\n let rounds_full = 63\n\n let initial_ark = true\n\n let rounds_partial = 0\n end\n\n module Inputs = struct\n module Field = Field\n include Rounds\n\n let alpha = 5\n\n (* Computes x^5 *)\n let to_the_alpha x =\n let open Field in\n let res = x in\n let res = res * res in\n (* x^2 *)\n let res = res * res in\n (* x^4 *)\n res * x\n\n module Operations = Operations\n end\n\n include Sponge.Make_hash (Sponge.Poseidon (Inputs))\n\n let hash ?init = hash ?init params\n\n let update ~state = update ~state params\n\n let salt (s : string) = update ~state:initial_state [| prefix_to_field s |]\n\n let pack_input =\n Input.pack_to_fields ~size_in_bits:Field.size_in_bits ~pack:Field.project\n\n module Digest = Digest\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n let pack_input =\n Input.pack_to_fields ~size_in_bits:Field.size_in_bits ~pack:Field.Var.pack\n\n module Digest = Checked.Digest\n\n module Inputs = struct\n include Rounds\n module Impl = Pickles.Impls.Step\n open Impl\n module Field = Field\n\n let alpha = 5\n\n (* Computes x^5 *)\n let to_the_alpha x =\n let open Field in\n let res = x in\n let res = res * res in\n (* x^2 *)\n let res = res * res in\n (* x^4 *)\n res * x\n\n module Operations = struct\n open Field\n\n let seal = Pickles.Util.seal (module Impl)\n\n let add_assign ~state i x = state.(i) <- seal (state.(i) + x)\n\n let apply_affine_map (matrix, constants) v =\n let dotv row =\n Array.reduce_exn (Array.map2_exn row v ~f:( * )) ~f:( + )\n in\n let res = Array.map matrix ~f:dotv in\n Array.map2_exn res constants ~f:(fun x c -> seal (x + c))\n\n let copy a = Array.map a ~f:Fn.id\n end\n end\n\n include Sponge.Make_hash (Sponge.Poseidon (Inputs))\n\n let params = Sponge.Params.map ~f:Inputs.Field.constant params\n\n open Inputs.Field\n\n let update ~state xs = update params ~state xs\n\n let hash ?init xs =\n hash ?init:(Option.map init ~f:(State.map ~f:constant)) params xs\n end\n\n [%%endif]\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\n[%%ifdef consensus_mechanism]\n\nlet parity y = Bigint.(test_bit (of_field y) 0)\n\n[%%else]\n\nlet parity y = Field.parity y\n\n[%%endif]\n\nlet gen_uncompressed =\n Quickcheck.Generator.filter_map Field.gen_uniform ~f:(fun x ->\n let open Option.Let_syntax in\n let%map y = Inner_curve.find_y x in\n (x, y) )\n\nmodule Compressed = struct\n open Compressed_poly\n\n module Arg = struct\n (* module with same type t as Stable below, to build functor argument *)\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = ((Field.t[@version_asserted]), bool) Poly.Stable.V1.t\n\n let to_latest = Fn.id\n end\n end]\n end\n\n let compress (x, y) = { Poly.x; is_odd = parity y }\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n module T = struct\n type t = ((Field.t[@version_asserted]), bool) Poly.Stable.V1.t\n [@@deriving equal, compare, hash]\n\n let to_latest = Fn.id\n\n module M = struct\n (* for compatibility with legacy Base58Check serialization *)\n include Arg.Stable.V1.With_all_version_tags\n\n let description = \"Non zero curve point compressed\"\n\n let version_byte =\n Base58_check.Version_bytes.non_zero_curve_point_compressed\n end\n\n module Base58 = Codable.Make_base58_check (M)\n include Base58\n\n (* sexp representation is a Base58Check string, like the yojson representation *)\n let sexp_of_t t = to_base58_check t |> Sexp.of_string\n\n let t_of_sexp sexp = Sexp.to_string sexp |> of_base58_check_exn\n end\n\n include T\n include Hashable.Make_binable (T)\n\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%map uncompressed = gen_uncompressed in\n compress uncompressed\n end\n end]\n\n module Poly = Poly\n include Comparable.Make_binable (Stable.Latest)\n include Hashable.Make_binable (Stable.Latest)\n include Stable.Latest.Base58\n\n let to_string = to_base58_check\n\n [%%define_locally Stable.Latest.(sexp_of_t, t_of_sexp, gen)]\n\n let compress (x, y) = { Poly.x; is_odd = parity y }\n\n let empty = Poly.{ x = Field.zero; is_odd = false }\n\n let to_input { Poly.x; is_odd } =\n { Random_oracle.Input.Chunked.field_elements = [| x |]\n ; packeds = [| (Field.project [ is_odd ], 1) |]\n }\n\n let to_input_legacy { Poly.x; is_odd } =\n { Random_oracle.Input.Legacy.field_elements = [| x |]\n ; bitstrings = [| [ is_odd ] |]\n }\n\n [%%ifdef consensus_mechanism]\n\n (* snarky-dependent *)\n\n type var = (Field.Var.t, Boolean.var) Poly.t\n\n let typ : (var, t) Typ.t =\n Typ.of_hlistable [ Field.typ; Boolean.typ ] ~var_to_hlist:Poly.to_hlist\n ~var_of_hlist:Poly.of_hlist ~value_to_hlist:Poly.to_hlist\n ~value_of_hlist:Poly.of_hlist\n\n let var_of_t ({ x; is_odd } : t) : var =\n { x = Field.Var.constant x; is_odd = Boolean.var_of_value is_odd }\n\n let assert_equal (t1 : var) (t2 : var) =\n let%map () = Field.Checked.Assert.equal t1.x t2.x\n and () = Boolean.Assert.(t1.is_odd = t2.is_odd) in\n ()\n\n module Checked = struct\n let equal t1 t2 =\n let%bind x_eq = Field.Checked.equal t1.Poly.x t2.Poly.x in\n let%bind odd_eq = Boolean.equal t1.is_odd t2.is_odd in\n Boolean.(x_eq && odd_eq)\n\n let to_input ({ x; is_odd } : var) =\n { Random_oracle.Input.Chunked.field_elements = [| x |]\n ; packeds = [| ((is_odd :> Field.Var.t), 1) |]\n }\n\n let to_input_legacy = to_input_legacy\n\n let if_ cond ~then_:t1 ~else_:t2 =\n let%map x = Field.Checked.if_ cond ~then_:t1.Poly.x ~else_:t2.Poly.x\n and is_odd = Boolean.if_ cond ~then_:t1.is_odd ~else_:t2.is_odd in\n Poly.{ x; is_odd }\n\n module Assert = struct\n let equal t1 t2 =\n let%map () = Field.Checked.Assert.equal t1.Poly.x t2.Poly.x\n and () = Boolean.Assert.(t1.is_odd = t2.is_odd) in\n ()\n end\n end\n\n (* end snarky-dependent *)\n [%%endif]\nend\n\nmodule Uncompressed = struct\n let decompress ({ x; is_odd } : Compressed.t) =\n Option.map (Inner_curve.find_y x) ~f:(fun y ->\n let y_parity = parity y in\n let y = if Bool.(is_odd = y_parity) then y else Field.negate y in\n (x, y) )\n\n let decompress_exn t =\n match decompress t with\n | Some d ->\n d\n | None ->\n failwith\n (sprintf \"Compressed public key %s could not be decompressed\"\n (Yojson.Safe.to_string @@ Compressed.to_yojson t) )\n\n let of_base58_check_decompress_exn pk_str =\n let pk = Compressed.of_base58_check_exn pk_str in\n decompress_exn pk |> ignore ;\n pk\n\n let compress = Compressed.compress\n\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Field.t * Field.t [@@deriving compare, equal, hash]\n\n let to_latest = Fn.id\n\n include\n Binable.Of_binable_without_uuid\n (Compressed.Stable.V1)\n (struct\n type nonrec t = t\n\n let of_binable = decompress_exn\n\n let to_binable = compress\n end)\n\n let gen : t Quickcheck.Generator.t = gen_uncompressed\n\n let of_bigstring bs =\n let open Or_error.Let_syntax in\n let%map elem, _ = Bigstring.read_bin_prot bs bin_reader_t in\n elem\n\n let to_bigstring elem =\n let bs =\n Bigstring.create (bin_size_t elem + Bin_prot.Utils.size_header_length)\n in\n let _ = Bigstring.write_bin_prot bs bin_writer_t elem in\n bs\n\n (* We reuse the Base58check-based yojson (de)serialization from the\n compressed representation. *)\n\n let of_yojson json =\n let open Result in\n Compressed.of_yojson json\n >>= fun compressed ->\n Result.of_option ~error:\"couldn't decompress, curve point invalid\"\n (decompress compressed)\n\n let to_yojson t = Compressed.to_yojson @@ compress t\n\n (* as for yojson, use the Base58check-based sexps from the compressed representation *)\n let sexp_of_t t = Compressed.sexp_of_t @@ compress t\n\n let t_of_sexp sexp =\n Option.value_exn (decompress @@ Compressed.t_of_sexp sexp)\n end\n end]\n\n (* so we can make sets of public keys *)\n include Comparable.Make_binable (Stable.Latest)\n\n [%%define_locally\n Stable.Latest.\n (of_bigstring, to_bigstring, sexp_of_t, t_of_sexp, to_yojson, of_yojson)]\n\n let gen : t Quickcheck.Generator.t = gen_uncompressed\n\n let ( = ) = equal\n\n let of_inner_curve_exn = Inner_curve.to_affine_exn\n\n let to_inner_curve = Inner_curve.of_affine\n\n let%test_unit \"point-compression: decompress . compress = id\" =\n Quickcheck.test gen ~f:(fun pk ->\n assert (equal (decompress_exn (compress pk)) pk) )\n\n [%%ifdef consensus_mechanism]\n\n (* snarky-dependent *)\n\n type var = Field.Var.t * Field.Var.t\n\n let assert_equal var1 var2 =\n let open Field.Checked.Assert in\n let v1_f1, v1_f2 = var1 in\n let v2_f1, v2_f2 = var2 in\n let%bind () = equal v1_f1 v2_f1 in\n let%map () = equal v1_f2 v2_f2 in\n ()\n\n let var_of_t (x, y) = (Field.Var.constant x, Field.Var.constant y)\n\n let typ : (var, t) Typ.t = Typ.(field * field)\n\n let parity_var y =\n let%map bs = Field.Checked.unpack_full y in\n List.hd_exn (Bitstring_lib.Bitstring.Lsb_first.to_list bs)\n\n let decompress_var ({ x; is_odd } as c : Compressed.var) =\n let open Let_syntax in\n let%bind y =\n exists Typ.field\n ~compute:\n As_prover.(\n map (read Compressed.typ c) ~f:(fun c -> snd (decompress_exn c)))\n in\n let%map () = Inner_curve.Checked.Assert.on_curve (x, y)\n and () = parity_var y >>= Boolean.Assert.(( = ) is_odd) in\n (x, y)\n\n let%snarkydef_ compress_var ((x, y) : var) : Compressed.var Checked.t =\n let open Compressed_poly in\n let%map is_odd = parity_var y in\n { Poly.x; is_odd }\n\n (* end snarky-dependent *)\n [%%endif]\nend\n\ninclude Uncompressed\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = (Inner_curve.Scalar.t[@version_asserted])\n [@@deriving compare, sexp]\n\n (* deriver not working, apparently *)\n let sexp_of_t = [%sexp_of: Inner_curve.Scalar.t]\n\n let t_of_sexp = [%of_sexp: Inner_curve.Scalar.t]\n\n let to_latest = Fn.id\n\n [%%ifdef consensus_mechanism]\n\n let gen =\n let open Snark_params.Tick.Inner_curve.Scalar in\n let upperbound = Bignum_bigint.(pred size |> to_string) |> of_string in\n gen_uniform_incl one upperbound\n\n [%%else]\n\n let gen = Inner_curve.Scalar.(gen_uniform_incl one (zero - one))\n\n [%%endif]\n end\nend]\n\n[%%define_locally Stable.Latest.(gen)]\n\n[%%ifdef consensus_mechanism]\n\nlet create () =\n (* This calls into libsnark which uses /dev/urandom *)\n Inner_curve.Scalar.random ()\n\n[%%else]\n\nlet create () : t =\n let open Js_of_ocaml in\n let random_bytes_32 =\n Js.Unsafe.js_expr\n {js|(function() {\n var topLevel = (typeof self === 'object' && self.self === self && self) ||\n (typeof global === 'object' && global.global === global && global) ||\n this;\n var b;\n\n if (topLevel.crypto && topLevel.crypto.getRandomValues) {\n b = new Uint8Array(32);\n topLevel.crypto.getRandomValues(b);\n } else {\n if (typeof require === 'function') {\n var crypto = require('crypto');\n if (!crypto) {\n throw 'random values not available'\n }\n b = crypto.randomBytes(32);\n } else {\n throw 'random values not available'\n }\n }\n var res = [];\n for (var i = 0; i < 32; ++i) {\n res.push(b[i]);\n }\n res[31] &= 0x3f;\n return res;\n })|js}\n in\n let x : int Js.js_array Js.t = Js.Unsafe.fun_call random_bytes_32 [||] in\n let byte_undefined () = failwith \"byte undefined\" in\n Snarkette.Pasta.Fq.of_bigint\n (Snarkette.Nat.of_bytes\n (String.init 32 ~f:(fun i ->\n Char.of_int_exn (Js.Optdef.get (Js.array_get x i) byte_undefined) )\n ) )\n\n[%%endif]\n\ninclude Comparable.Make_binable (Stable.Latest)\n\n(* for compatibility with existing private key serializations *)\nlet of_bigstring_exn =\n Binable.of_bigstring (module Stable.Latest.With_all_version_tags)\n\nlet to_bigstring =\n Binable.to_bigstring (module Stable.Latest.With_all_version_tags)\n\nmodule Base58_check = Base58_check.Make (struct\n let description = \"Private key\"\n\n let version_byte = Base58_check.Version_bytes.private_key\nend)\n\nlet to_base58_check t =\n Base58_check.encode (to_bigstring t |> Bigstring.to_string)\n\nlet of_base58_check_exn s =\n let decoded = Base58_check.decode_exn s in\n decoded |> Bigstring.of_string |> of_bigstring_exn\n\nlet sexp_of_t t = to_base58_check t |> Sexp.of_string\n\nlet t_of_sexp sexp = Sexp.to_string sexp |> of_base58_check_exn\n\nlet to_yojson t = `String (to_base58_check t)\n\nlet of_yojson = function\n | `String x -> (\n try Ok (of_base58_check_exn x) with\n | Failure str ->\n Error str\n | exn ->\n Error (\"Signature_lib.Private_key.of_yojson: \" ^ Exn.to_string exn) )\n | _ ->\n Error \"Signature_lib.Private_key.of_yojson: Expected a string\"\n","[%%import \"/src/config.mlh\"]\n\nmodule Bignum_bigint = Bigint\nopen Core_kernel\n\nmodule type Message_intf = sig\n type field\n\n type t\n\n type curve\n\n type curve_scalar\n\n val derive :\n ?signature_kind:Mina_signature_kind.t\n -> t\n -> private_key:curve_scalar\n -> public_key:curve\n -> curve_scalar\n\n val derive_for_mainnet :\n t -> private_key:curve_scalar -> public_key:curve -> curve_scalar\n\n val derive_for_testnet :\n t -> private_key:curve_scalar -> public_key:curve -> curve_scalar\n\n val hash :\n ?signature_kind:Mina_signature_kind.t\n -> t\n -> public_key:curve\n -> r:field\n -> curve_scalar\n\n val hash_for_mainnet : t -> public_key:curve -> r:field -> curve_scalar\n\n val hash_for_testnet : t -> public_key:curve -> r:field -> curve_scalar\n\n [%%ifdef consensus_mechanism]\n\n type field_var\n\n type boolean_var\n\n type var\n\n type curve_var\n\n type curve_scalar_var\n\n type _ checked\n\n val hash_checked :\n var -> public_key:curve_var -> r:field_var -> curve_scalar_var checked\n\n [%%endif]\nend\n\n[%%ifdef consensus_mechanism]\n\nmodule type S = sig\n module Impl : Snarky_backendless.Snark_intf.S\n\n open Impl\n\n type curve\n\n type curve_var\n\n type curve_scalar\n\n type curve_scalar_var\n\n module Shifted : sig\n module type S =\n Snarky_curves.Shifted_intf\n with type curve_var := curve_var\n and type boolean_var := Boolean.var\n and type 'a checked := 'a Checked.t\n end\n\n module Message :\n Message_intf\n with type boolean_var := Boolean.var\n and type curve_scalar := curve_scalar\n and type curve_scalar_var := curve_scalar_var\n and type 'a checked := 'a Checked.t\n and type curve := curve\n and type curve_var := curve_var\n and type field := Field.t\n and type field_var := Field.Var.t\n\n module Signature : sig\n type t = field * curve_scalar [@@deriving sexp]\n\n type var = Field.Var.t * curve_scalar_var\n\n val typ : (var, t) Typ.t\n end\n\n module Private_key : sig\n type t = curve_scalar [@@deriving sexp]\n end\n\n module Public_key : sig\n type t = curve [@@deriving sexp]\n\n type var = curve_var\n end\n\n module Checked : sig\n val compress : curve_var -> Boolean.var list Checked.t\n\n val verifies :\n (module Shifted.S with type t = 't)\n -> Signature.var\n -> Public_key.var\n -> Message.var\n -> Boolean.var Checked.t\n\n val assert_verifies :\n (module Shifted.S with type t = 't)\n -> Signature.var\n -> Public_key.var\n -> Message.var\n -> unit Checked.t\n end\n\n val compress : curve -> bool list\n\n val sign :\n ?signature_kind:Mina_signature_kind.t\n -> Private_key.t\n -> Message.t\n -> Signature.t\n\n val verify :\n ?signature_kind:Mina_signature_kind.t\n -> Signature.t\n -> Public_key.t\n -> Message.t\n -> bool\nend\n\nmodule Make\n (Impl : Snarky_backendless.Snark_intf.S) (Curve : sig\n open Impl\n\n module Scalar : sig\n type t [@@deriving sexp, equal]\n\n type var\n\n val typ : (var, t) Typ.t\n\n val zero : t\n\n val ( * ) : t -> t -> t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\n\n module Checked : sig\n val to_bits : var -> Boolean.var Bitstring_lib.Bitstring.Lsb_first.t\n end\n end\n\n type t [@@deriving sexp]\n\n type var = Field.Var.t * Field.Var.t\n\n module Checked :\n Snarky_curves.Weierstrass_checked_intf\n with module Impl := Impl\n and type t = var\n and type unchecked := t\n\n val one : t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\n\n val scale : t -> Scalar.t -> t\n\n val to_affine_exn : t -> Field.t * Field.t\n end)\n (Message : Message_intf\n with type boolean_var := Impl.Boolean.var\n and type curve_scalar_var := Curve.Scalar.var\n and type curve_scalar := Curve.Scalar.t\n and type curve := Curve.t\n and type curve_var := Curve.var\n and type field := Impl.Field.t\n and type field_var := Impl.Field.Var.t\n and type 'a checked := 'a Impl.Checked.t) :\n S\n with module Impl := Impl\n and type curve := Curve.t\n and type curve_var := Curve.var\n and type curve_scalar := Curve.Scalar.t\n and type curve_scalar_var := Curve.Scalar.var\n and module Shifted := Curve.Checked.Shifted\n and module Message := Message = struct\n open Impl\n\n module Signature = struct\n type t = Field.t * Curve.Scalar.t [@@deriving sexp]\n\n type var = Field.Var.t * Curve.Scalar.var\n\n let typ : (var, t) Typ.t = Typ.tuple2 Field.typ Curve.Scalar.typ\n end\n\n module Private_key = struct\n type t = Curve.Scalar.t [@@deriving sexp]\n end\n\n module Public_key : sig\n type t = Curve.t [@@deriving sexp]\n\n type var = Curve.var\n end =\n Curve\n\n let compress (t : Curve.t) =\n let x, _ = Curve.to_affine_exn t in\n Field.unpack x\n\n let is_even (t : Field.t) = not (Bigint.test_bit (Bigint.of_field t) 0)\n\n let sign ?signature_kind (d_prime : Private_key.t) (m : Message.t) =\n let public_key =\n (* TODO: Don't recompute this. *) Curve.scale Curve.one d_prime\n in\n (* TODO: Once we switch to implicit sign-bit we'll have to conditionally negate d_prime. *)\n let d = d_prime in\n let derive = Message.derive ?signature_kind in\n let k_prime = derive m ~public_key ~private_key:d in\n assert (not Curve.Scalar.(equal k_prime zero)) ;\n let r, ry = Curve.(to_affine_exn (scale Curve.one k_prime)) in\n let k = if is_even ry then k_prime else Curve.Scalar.negate k_prime in\n let hash = Message.hash ?signature_kind in\n let e = hash m ~public_key ~r in\n let s = Curve.Scalar.(k + (e * d)) in\n (r, s)\n\n let verify ?signature_kind ((r, s) : Signature.t) (pk : Public_key.t)\n (m : Message.t) =\n let hash = Message.hash ?signature_kind in\n let e = hash ~public_key:pk ~r m in\n let r_pt = Curve.(scale one s + negate (scale pk e)) in\n match Curve.to_affine_exn r_pt with\n | rx, ry ->\n is_even ry && Field.equal rx r\n | exception _ ->\n false\n\n [%%if call_logger]\n\n let verify s pk m =\n Mina_debug.Call_logger.record_call \"Signature_lib.Schnorr.verify\" ;\n if Random.int 1000 = 0 then (\n print_endline \"SCHNORR BACKTRACE:\" ;\n Printexc.print_backtrace stdout ) ;\n verify s pk m\n\n [%%endif]\n\n module Checked = struct\n let to_bits x =\n Field.Checked.choose_preimage_var x ~length:Field.size_in_bits\n\n let compress ((x, _) : Curve.var) = to_bits x\n\n let is_even y =\n let%map bs = Field.Checked.unpack_full y in\n Bitstring_lib.Bitstring.Lsb_first.to_list bs |> List.hd_exn |> Boolean.not\n\n (* returning r_point as a representable point ensures it is nonzero so the nonzero\n * check does not have to explicitly be performed *)\n\n let%snarkydef_ verifier (type s) ~equal ~final_check\n ((module Shifted) as shifted :\n (module Curve.Checked.Shifted.S with type t = s) )\n ((r, s) : Signature.var) (public_key : Public_key.var) (m : Message.var)\n =\n let%bind e = Message.hash_checked m ~public_key ~r in\n (* s * g - e * public_key *)\n let%bind e_pk =\n Curve.Checked.scale shifted\n (Curve.Checked.negate public_key)\n (Curve.Scalar.Checked.to_bits e)\n ~init:Shifted.zero\n in\n let%bind s_g_e_pk =\n Curve.Checked.scale_known shifted Curve.one\n (Curve.Scalar.Checked.to_bits s)\n ~init:e_pk\n in\n let%bind rx, ry = Shifted.unshift_nonzero s_g_e_pk in\n let%bind y_even = is_even ry in\n let%bind r_correct = equal r rx in\n final_check r_correct y_even\n\n let verifies s =\n verifier ~equal:Field.Checked.equal ~final_check:Boolean.( && ) s\n\n let assert_verifies s =\n verifier ~equal:Field.Checked.Assert.equal\n ~final_check:(fun () ry_even -> Boolean.Assert.is_true ry_even)\n s\n end\nend\n\n[%%else]\n\n(* nonconsensus version of the functor; yes, there's some repeated code,\n but seems difficult to abstract over the functors and signatures\n*)\n\nmodule type S = sig\n open Snark_params.Tick\n\n type curve\n\n type curve_scalar\n\n module Message :\n Message_intf\n with type curve_scalar := curve_scalar\n and type curve := curve\n and type field := Field.t\n\n module Signature : sig\n type t = Field.t * curve_scalar [@@deriving sexp]\n end\n\n module Private_key : sig\n type t = curve_scalar [@@deriving sexp]\n end\n\n module Public_key : sig\n type t = curve [@@deriving sexp]\n end\n\n val sign :\n ?signature_kind:Mina_signature_kind.t\n -> Private_key.t\n -> Message.t\n -> Signature.t\n\n val verify :\n ?signature_kind:Mina_signature_kind.t\n -> Signature.t\n -> Public_key.t\n -> Message.t\n -> bool\nend\n\nmodule Make\n (Impl : module type of Snark_params.Tick) (Curve : sig\n open Impl\n\n module Scalar : sig\n type t [@@deriving sexp, equal]\n\n val zero : t\n\n val ( * ) : t -> t -> t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\n end\n\n type t [@@deriving sexp]\n\n val one : t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\n\n val scale : t -> Scalar.t -> t\n\n val to_affine_exn : t -> Field.t * Field.t\n end)\n (Message : Message_intf\n with type curve := Curve.t\n and type curve_scalar := Curve.Scalar.t\n and type field := Impl.Field.t) :\n S\n with type curve := Curve.t\n and type curve_scalar := Curve.Scalar.t\n and module Message := Message = struct\n module Private_key = struct\n type t = Curve.Scalar.t [@@deriving sexp]\n end\n\n module Signature = struct\n type t = Impl.Field.t * Curve.Scalar.t [@@deriving sexp]\n end\n\n module Public_key : sig\n type t = Curve.t [@@deriving sexp]\n end =\n Curve\n\n let is_even (t : Impl.Field.t) = not @@ Impl.Field.parity t\n\n let sign ?signature_kind (d_prime : Private_key.t) m =\n let public_key =\n (* TODO: Don't recompute this. *)\n Curve.scale Curve.one d_prime\n in\n (* TODO: Once we switch to implicit sign-bit we'll have to conditionally negate d_prime. *)\n let d = d_prime in\n let derive = Message.derive ?signature_kind in\n let k_prime = derive m ~public_key ~private_key:d in\n assert (not Curve.Scalar.(equal k_prime zero)) ;\n let r, (ry : Impl.Field.t) =\n Curve.(to_affine_exn (scale Curve.one k_prime))\n in\n let k = if is_even ry then k_prime else Curve.Scalar.negate k_prime in\n let hash = Message.hash ?signature_kind in\n let e = hash m ~public_key ~r in\n let s = Curve.Scalar.(k + (e * d)) in\n (r, s)\n\n let verify ?signature_kind ((r, s) : Signature.t) (pk : Public_key.t)\n (m : Message.t) =\n let hash = Message.hash ?signature_kind in\n let e = hash ~public_key:pk ~r m in\n let r_pt = Curve.(scale one s + negate (scale pk e)) in\n match Curve.to_affine_exn r_pt with\n | rx, ry ->\n is_even ry && Impl.Field.(equal rx r)\n | exception _ ->\n false\nend\n\n[%%endif]\n\nopen Snark_params\n\nmodule Message = struct\n let network_id_mainnet = String.of_char @@ Char.of_int_exn 1\n\n let network_id_testnet = String.of_char @@ Char.of_int_exn 0\n\n let network_id_other chain_name = chain_name\n\n let network_id =\n match Mina_signature_kind.t with\n | Mainnet ->\n network_id_mainnet\n | Testnet ->\n network_id_testnet\n | Other_network chain_name ->\n network_id_other chain_name\n\n module Legacy = struct\n open Tick\n\n type t = (Field.t, bool) Random_oracle.Input.Legacy.t [@@deriving sexp]\n\n let make_derive ~network_id t ~private_key ~public_key =\n let input =\n let x, y = Tick.Inner_curve.to_affine_exn public_key in\n Random_oracle.Input.Legacy.append t\n { field_elements = [| x; y |]\n ; bitstrings =\n [| Tock.Field.unpack private_key\n ; Fold_lib.Fold.(to_list (string_bits network_id))\n |]\n }\n in\n Random_oracle.Input.Legacy.to_bits ~unpack:Field.unpack input\n |> Array.of_list |> Blake2.bits_to_string |> Blake2.digest_string\n |> Blake2.to_raw_string |> Blake2.string_to_bits |> Array.to_list\n |> Fn.flip List.take (Int.min 256 (Tock.Field.size_in_bits - 1))\n |> Tock.Field.project\n\n let derive ?(signature_kind = Mina_signature_kind.t) =\n make_derive\n ~network_id:\n ( match signature_kind with\n | Mainnet ->\n network_id_mainnet\n | Testnet ->\n network_id_testnet\n | Other_network chain_name ->\n network_id_other chain_name )\n\n let derive_for_mainnet = make_derive ~network_id:network_id_mainnet\n\n let derive_for_testnet = make_derive ~network_id:network_id_testnet\n\n let make_hash ~init t ~public_key ~r =\n let input =\n let px, py = Inner_curve.to_affine_exn public_key in\n Random_oracle.Input.Legacy.append t\n { field_elements = [| px; py; r |]; bitstrings = [||] }\n in\n let open Random_oracle.Legacy in\n hash ~init (pack_input input)\n |> Digest.to_bits ~length:Field.size_in_bits\n |> Inner_curve.Scalar.of_bits\n\n let hash ?signature_kind =\n make_hash ~init:(Hash_prefix_states.signature_legacy ?signature_kind)\n\n let hash_for_mainnet =\n make_hash ~init:Hash_prefix_states.signature_for_mainnet_legacy\n\n let hash_for_testnet =\n make_hash ~init:Hash_prefix_states.signature_for_testnet_legacy\n\n [%%ifdef consensus_mechanism]\n\n type var = (Field.Var.t, Boolean.var) Random_oracle.Input.Legacy.t\n\n let%snarkydef_ hash_checked t ~public_key ~r =\n let input =\n let px, py = public_key in\n Random_oracle.Input.Legacy.append t\n { field_elements = [| px; py; r |]; bitstrings = [||] }\n in\n make_checked (fun () ->\n let open Random_oracle.Legacy.Checked in\n hash\n ~init:(Hash_prefix_states.signature_legacy ?signature_kind:None)\n (pack_input input)\n |> Digest.to_bits ~length:Field.size_in_bits\n |> Bitstring_lib.Bitstring.Lsb_first.of_list )\n\n [%%endif]\n end\n\n module Chunked = struct\n open Tick\n\n type t = Field.t Random_oracle.Input.Chunked.t [@@deriving sexp]\n\n let make_derive ~network_id t ~private_key ~public_key =\n let input =\n let x, y = Tick.Inner_curve.to_affine_exn public_key in\n let id = Fold_lib.Fold.(to_list (string_bits network_id)) in\n Random_oracle.Input.Chunked.append t\n { field_elements =\n [| x; y; Field.project (Tock.Field.unpack private_key) |]\n ; packeds = [| (Field.project id, List.length id) |]\n }\n in\n Array.map (Random_oracle.pack_input input) ~f:Tick.Field.unpack\n |> Array.to_list |> List.concat |> Array.of_list |> Blake2.bits_to_string\n |> Blake2.digest_string |> Blake2.to_raw_string |> Blake2.string_to_bits\n |> Array.to_list\n |> Fn.flip List.take (Int.min 256 (Tock.Field.size_in_bits - 1))\n |> Tock.Field.project\n\n let derive ?(signature_kind = Mina_signature_kind.t) =\n make_derive\n ~network_id:\n ( match signature_kind with\n | Mainnet ->\n network_id_mainnet\n | Testnet ->\n network_id_testnet\n | Other_network chain_name ->\n network_id_other chain_name )\n\n let derive_for_mainnet = make_derive ~network_id:network_id_mainnet\n\n let derive_for_testnet = make_derive ~network_id:network_id_testnet\n\n let make_hash ~init t ~public_key ~r =\n let input =\n let px, py = Inner_curve.to_affine_exn public_key in\n Random_oracle.Input.Chunked.append t\n { field_elements = [| px; py; r |]; packeds = [||] }\n in\n let open Random_oracle in\n hash ~init (pack_input input)\n |> Digest.to_bits ~length:Field.size_in_bits\n |> Inner_curve.Scalar.of_bits\n\n let hash ?signature_kind =\n make_hash ~init:(Hash_prefix_states.signature ?signature_kind)\n\n let hash_for_mainnet =\n make_hash ~init:Hash_prefix_states.signature_for_mainnet\n\n let hash_for_testnet =\n make_hash ~init:Hash_prefix_states.signature_for_testnet\n\n [%%ifdef consensus_mechanism]\n\n type var = Field.Var.t Random_oracle.Input.Chunked.t\n\n let%snarkydef_ hash_checked t ~public_key ~r =\n let input =\n let px, py = public_key in\n Random_oracle.Input.Chunked.append t\n { field_elements = [| px; py; r |]; packeds = [||] }\n in\n make_checked (fun () ->\n let open Random_oracle.Checked in\n hash\n ~init:(Hash_prefix_states.signature ?signature_kind:None)\n (pack_input input)\n |> Digest.to_bits ~length:Field.size_in_bits\n |> Bitstring_lib.Bitstring.Lsb_first.of_list )\n\n [%%endif]\n end\nend\n\nmodule Legacy = Make (Tick) (Tick.Inner_curve) (Message.Legacy)\nmodule Chunked = Make (Tick) (Tick.Inner_curve) (Message.Chunked)\n\n[%%ifdef consensus_mechanism]\n\nlet gen_legacy =\n let open Quickcheck.Let_syntax in\n let%map pk = Private_key.gen and msg = Tick.Field.gen in\n (pk, Random_oracle.Input.Legacy.field_elements [| msg |])\n\nlet gen_chunked =\n let open Quickcheck.Let_syntax in\n let%map pk = Private_key.gen and msg = Tick.Field.gen in\n (pk, Random_oracle.Input.Chunked.field_elements [| msg |])\n\n(* Use for reading only. *)\nlet legacy_message_typ () : (Message.Legacy.var, Message.Legacy.t) Tick.Typ.t =\n let to_hlist { Random_oracle.Input.Legacy.field_elements; bitstrings } =\n H_list.[ field_elements; bitstrings ]\n in\n let of_hlist ([ field_elements; bitstrings ] : (unit, _) H_list.t) =\n { Random_oracle.Input.Legacy.field_elements; bitstrings }\n in\n let open Tick.Typ in\n of_hlistable\n [ array ~length:0 Tick.Field.typ\n ; array ~length:0 (list ~length:0 Tick.Boolean.typ)\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n(* Use for reading only. *)\nlet chunked_message_typ () : (Message.Chunked.var, Message.Chunked.t) Tick.Typ.t\n =\n let open Tick.Typ in\n let const_typ =\n Typ\n { check = (fun _ -> Tick.Checked.return ())\n ; var_to_fields = (fun t -> ([||], t))\n ; var_of_fields = (fun (_, t) -> t)\n ; value_to_fields = (fun t -> ([||], t))\n ; value_of_fields = (fun (_, t) -> t)\n ; size_in_field_elements = 0\n ; constraint_system_auxiliary =\n (fun () -> failwith \"Cannot create constant in constraint-system mode\")\n }\n in\n let to_hlist { Random_oracle.Input.Chunked.field_elements; packeds } =\n H_list.[ field_elements; packeds ]\n in\n let of_hlist ([ field_elements; packeds ] : (unit, _) H_list.t) =\n { Random_oracle.Input.Chunked.field_elements; packeds }\n in\n of_hlistable\n [ array ~length:0 Tick.Field.typ\n ; array ~length:0 (Tick.Field.typ * const_typ)\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\nlet%test_unit \"schnorr checked + unchecked\" =\n Quickcheck.test ~trials:5 gen_legacy ~f:(fun (pk, msg) ->\n let s = Legacy.sign pk msg in\n let pubkey = Tick.Inner_curve.(scale one pk) in\n assert (Legacy.verify s pubkey msg) ;\n (Tick.Test.test_equal ~sexp_of_t:[%sexp_of: bool] ~equal:Bool.equal\n Tick.Typ.(\n tuple3 Tick.Inner_curve.typ (legacy_message_typ ())\n Legacy.Signature.typ)\n Tick.Boolean.typ\n (fun (public_key, msg, s) ->\n let open Tick.Checked in\n let%bind (module Shifted) =\n Tick.Inner_curve.Checked.Shifted.create ()\n in\n Legacy.Checked.verifies (module Shifted) s public_key msg )\n (fun _ -> true) )\n (pubkey, msg, s) )\n\nlet%test_unit \"schnorr checked + unchecked\" =\n Quickcheck.test ~trials:5 gen_chunked ~f:(fun (pk, msg) ->\n let s = Chunked.sign pk msg in\n let pubkey = Tick.Inner_curve.(scale one pk) in\n assert (Chunked.verify s pubkey msg) ;\n (Tick.Test.test_equal ~sexp_of_t:[%sexp_of: bool] ~equal:Bool.equal\n Tick.Typ.(\n tuple3 Tick.Inner_curve.typ (chunked_message_typ ())\n Chunked.Signature.typ)\n Tick.Boolean.typ\n (fun (public_key, msg, s) ->\n let open Tick.Checked in\n let%bind (module Shifted) =\n Tick.Inner_curve.Checked.Shifted.create ()\n in\n Chunked.Checked.verifies (module Shifted) s public_key msg )\n (fun _ -> true) )\n (pubkey, msg, s) )\n\n[%%endif]\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t =\n { public_key : Public_key.Stable.V1.t\n ; private_key : (Private_key.Stable.V1.t[@sexp.opaque])\n }\n [@@deriving sexp]\n\n let to_latest = Fn.id\n\n let to_yojson t = Public_key.Stable.V1.to_yojson t.public_key\n end\nend]\n\nmodule T = struct\n type t = Stable.Latest.t =\n { public_key : Public_key.t; private_key : (Private_key.t[@sexp.opaque]) }\n [@@deriving sexp]\n\n let compare { public_key = pk1; private_key = _ }\n { public_key = pk2; private_key = _ } =\n Public_key.compare pk1 pk2\n\n let to_yojson = Stable.Latest.to_yojson\nend\n\ninclude T\ninclude Comparable.Make (T)\n\nlet of_private_key_exn private_key =\n let public_key = Public_key.of_private_key_exn private_key in\n { public_key; private_key }\n\nlet create () = of_private_key_exn (Private_key.create ())\n\nlet gen = Quickcheck.Generator.(map ~f:of_private_key_exn Private_key.gen)\n\nmodule And_compressed_pk = struct\n module T = struct\n type t = T.t * Public_key.Compressed.t [@@deriving sexp]\n\n let compare ({ public_key = pk1; private_key = _ }, _)\n ({ public_key = pk2; private_key = _ }, _) =\n Public_key.compare pk1 pk2\n end\n\n include T\n include Comparable.Make (T)\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = Sgn_type.Sgn.Stable.V1.t = Pos | Neg\n [@@deriving sexp, hash, compare, equal, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\nlet gen =\n Quickcheck.Generator.map Bool.quickcheck_generator ~f:(fun b ->\n if b then Pos else Neg )\n\nlet negate = function Pos -> Neg | Neg -> Pos\n\nlet neg_one = Field.(negate one)\n\nlet to_field = function Pos -> Field.one | Neg -> neg_one\n\nlet of_field_exn x =\n if Field.equal x Field.one then Pos\n else if Field.equal x neg_one then Neg\n else failwith \"Sgn.of_field: Expected positive or negative 1\"\n\n[%%ifdef consensus_mechanism]\n\ntype var = Field.Var.t\n\nlet typ : (var, t) Typ.t =\n let open Typ in\n Typ\n { check = (fun x -> assert_r1cs x x (Field.Var.constant Field.one))\n ; var_to_fields = (fun t -> ([| t |], ()))\n ; var_of_fields = (fun (ts, ()) -> ts.(0))\n ; value_to_fields = (fun t -> ([| to_field t |], ()))\n ; value_of_fields = (fun (ts, ()) -> of_field_exn ts.(0))\n ; size_in_field_elements = 1\n ; constraint_system_auxiliary = (fun () -> ())\n }\n\nmodule Checked = struct\n let two = Field.of_int 2\n\n let neg_two = Field.negate two\n\n let one_half = Field.inv two\n\n let neg_one_half = Field.negate one_half\n\n let is_pos (v : var) =\n Boolean.Unsafe.of_cvar\n (let open Field.Checked in\n one_half * (v + Field.Var.constant Field.one))\n\n let is_neg (v : var) =\n Boolean.Unsafe.of_cvar\n (let open Field.Checked in\n neg_one_half * (v - Field.Var.constant Field.one))\n\n let pos_if_true (b : Boolean.var) =\n let open Field.Checked in\n (two * (b :> Field.Var.t)) - Field.Var.constant Field.one\n\n let neg_if_true (b : Boolean.var) =\n let open Field.Checked in\n (neg_two * (b :> Field.Var.t)) + Field.Var.constant Field.one\n\n let negate t = Field.Var.scale t neg_one\n\n let constant = Fn.compose Field.Var.constant to_field\n\n let neg = constant Neg\n\n let pos = constant Pos\n\n let if_ = Field.Checked.if_\nend\n\n[%%endif]\n","open Core_kernel\n\nmodule Tree = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type ('hash, 'account) t =\n | Account of 'account\n | Hash of 'hash\n | Node of 'hash * ('hash, 'account) t * ('hash, 'account) t\n [@@deriving equal, sexp, yojson]\n\n let rec to_latest acct_to_latest = function\n | Account acct ->\n Account (acct_to_latest acct)\n | Hash hash ->\n Hash hash\n | Node (hash, l, r) ->\n Node (hash, to_latest acct_to_latest l, to_latest acct_to_latest r)\n end\n end]\n\n type ('hash, 'account) t = ('hash, 'account) Stable.Latest.t =\n | Account of 'account\n | Hash of 'hash\n | Node of 'hash * ('hash, 'account) t * ('hash, 'account) t\n [@@deriving equal, sexp, yojson]\nend\n\nmodule T = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type ('hash, 'key, 'account) t =\n { indexes : ('key * int) list\n ; depth : int\n ; tree : ('hash, 'account) Tree.Stable.V1.t\n }\n [@@deriving sexp, yojson]\n end\n end]\n\n type ('hash, 'key, 'account) t = ('hash, 'key, 'account) Stable.Latest.t =\n { indexes : ('key * int) list\n ; depth : int\n ; tree : ('hash, 'account) Tree.t\n }\n [@@deriving sexp, yojson]\nend\n\nmodule type S = sig\n type hash\n\n type account_id\n\n type account\n\n type t = (hash, account_id, account) T.t [@@deriving sexp, yojson]\n\n val of_hash : depth:int -> hash -> t\n\n val get_exn : t -> int -> account\n\n val path_exn : t -> int -> [ `Left of hash | `Right of hash ] list\n\n val set_exn : t -> int -> account -> t\n\n val find_index_exn : t -> account_id -> int\n\n val add_path :\n t -> [ `Left of hash | `Right of hash ] list -> account_id -> account -> t\n\n val iteri : t -> f:(int -> account -> unit) -> unit\n\n val merkle_root : t -> hash\n\n val depth : t -> int\nend\n\nlet tree { T.tree; _ } = tree\n\nlet of_hash ~depth h = { T.indexes = []; depth; tree = Hash h }\n\nmodule Make (Hash : sig\n type t [@@deriving equal, sexp, yojson, compare]\n\n val merge : height:int -> t -> t -> t\nend) (Account_id : sig\n type t [@@deriving equal, sexp, yojson]\nend) (Account : sig\n type t [@@deriving equal, sexp, yojson]\n\n val data_hash : t -> Hash.t\nend) : sig\n include\n S\n with type hash := Hash.t\n and type account_id := Account_id.t\n and type account := Account.t\n\n val hash : (Hash.t, Account.t) Tree.t -> Hash.t\nend = struct\n type t = (Hash.t, Account_id.t, Account.t) T.t [@@deriving sexp, yojson]\n\n let of_hash ~depth (hash : Hash.t) = of_hash ~depth hash\n\n let hash : (Hash.t, Account.t) Tree.t -> Hash.t = function\n | Account a ->\n Account.data_hash a\n | Hash h ->\n h\n | Node (h, _, _) ->\n h\n\n type index = int [@@deriving sexp, yojson]\n\n let depth { T.depth; _ } = depth\n\n let merkle_root { T.tree; _ } = hash tree\n\n let add_path depth0 tree0 path0 account =\n let rec build_tree height p =\n match p with\n | `Left h_r :: path ->\n let l = build_tree (height - 1) path in\n Tree.Node (Hash.merge ~height (hash l) h_r, l, Hash h_r)\n | `Right h_l :: path ->\n let r = build_tree (height - 1) path in\n Node (Hash.merge ~height h_l (hash r), Hash h_l, r)\n | [] ->\n assert (height = -1) ;\n Account account\n in\n let rec union height tree path =\n match (tree, path) with\n | Tree.Hash h, path ->\n let t = build_tree height path in\n [%test_result: Hash.t]\n ~message:\n \"Hashes in union are not equal, something is wrong with your \\\n ledger\"\n ~expect:h (hash t) ;\n t\n | Node (h, l, r), `Left h_r :: path ->\n assert (Hash.equal h_r (hash r)) ;\n let l = union (height - 1) l path in\n Node (h, l, r)\n | Node (h, l, r), `Right h_l :: path ->\n assert (Hash.equal h_l (hash l)) ;\n let r = union (height - 1) r path in\n Node (h, l, r)\n | Node _, [] ->\n failwith \"Path too short\"\n | Account _, _ :: _ ->\n failwith \"Path too long\"\n | Account a, [] ->\n assert (Account.equal a account) ;\n tree\n in\n union (depth0 - 1) tree0 (List.rev path0)\n\n let add_path (t : t) path account_id account =\n let index =\n List.foldi path ~init:0 ~f:(fun i acc x ->\n match x with `Right _ -> acc + (1 lsl i) | `Left _ -> acc )\n in\n { t with\n tree = add_path t.depth t.tree path account\n ; indexes = (account_id, index) :: t.indexes\n }\n\n let iteri (t : t) ~f =\n let rec go acc i tree ~f =\n match tree with\n | Tree.Account a ->\n f acc a\n | Hash _ ->\n ()\n | Node (_, l, r) ->\n go acc (i - 1) l ~f ;\n go (acc + (1 lsl i)) (i - 1) r ~f\n in\n go 0 (t.depth - 1) t.tree ~f\n\n let ith_bit idx i = (idx lsr i) land 1 = 1\n\n let find_index_exn (t : t) aid =\n match List.Assoc.find t.indexes ~equal:Account_id.equal aid with\n | Some x ->\n x\n | None ->\n failwithf\n !\"Sparse_ledger.find_index_exn: %{sexp:Account_id.t} not in %{sexp: \\\n Account_id.t list}\"\n aid\n (List.map t.indexes ~f:fst)\n ()\n\n let get_exn ({ T.tree; depth; _ } as t) idx =\n let rec go i tree =\n match (i < 0, tree) with\n | true, Tree.Account acct ->\n acct\n | false, Node (_, l, r) ->\n let go_right = ith_bit idx i in\n if go_right then go (i - 1) r else go (i - 1) l\n | _ ->\n let expected_kind = if i < 0 then \"n account\" else \" node\" in\n let kind =\n match tree with\n | Account _ ->\n \"n account\"\n | Hash _ ->\n \" hash\"\n | Node _ ->\n \" node\"\n in\n failwithf\n !\"Sparse_ledger.get: Bad index %i. Expected a%s, but got a%s at \\\n depth %i. Tree = %{sexp:t}, tree_depth = %d\"\n idx expected_kind kind (depth - i) t depth ()\n in\n go (depth - 1) tree\n\n let set_exn (t : t) idx acct =\n let rec go i tree =\n match (i < 0, tree) with\n | true, Tree.Account _ ->\n Tree.Account acct\n | false, Node (_, l, r) ->\n let l, r =\n let go_right = ith_bit idx i in\n if go_right then (l, go (i - 1) r) else (go (i - 1) l, r)\n in\n Node (Hash.merge ~height:i (hash l) (hash r), l, r)\n | _ ->\n let expected_kind = if i < 0 then \"n account\" else \" node\" in\n let kind =\n match tree with\n | Account _ ->\n \"n account\"\n | Hash _ ->\n \" hash\"\n | Node _ ->\n \" node\"\n in\n failwithf\n \"Sparse_ledger.set: Bad index %i. Expected a%s, but got a%s at \\\n depth %i.\"\n idx expected_kind kind (t.depth - i) ()\n in\n { t with tree = go (t.depth - 1) t.tree }\n\n let path_exn { T.tree; depth; _ } idx =\n let rec go acc i tree =\n if i < 0 then acc\n else\n match tree with\n | Tree.Account _ ->\n failwithf \"Sparse_ledger.path: Bad depth at index %i.\" idx ()\n | Hash _ ->\n failwithf \"Sparse_ledger.path: Dead end at index %i.\" idx ()\n | Node (_, l, r) ->\n let go_right = ith_bit idx i in\n if go_right then go (`Right (hash l) :: acc) (i - 1) r\n else go (`Left (hash r) :: acc) (i - 1) l\n in\n go [] (depth - 1) tree\nend\n\ntype ('hash, 'key, 'account) t = ('hash, 'key, 'account) T.t [@@deriving yojson]\n\nlet%test_module \"sparse-ledger-test\" =\n ( module struct\n module Hash = struct\n type t = Core_kernel.Md5.t [@@deriving sexp, compare]\n\n let equal h1 h2 = Int.equal (compare h1 h2) 0\n\n let to_yojson md5 = `String (Core_kernel.Md5.to_hex md5)\n\n let of_yojson = function\n | `String x ->\n Or_error.try_with (fun () -> Core_kernel.Md5.of_hex_exn x)\n |> Result.map_error ~f:Error.to_string_hum\n | _ ->\n Error \"Expected a hex-encoded MD5 hash\"\n\n let merge ~height x y =\n let open Md5 in\n digest_string\n (sprintf \"sparse-ledger_%03d\" height ^ to_binary x ^ to_binary y)\n\n let gen =\n Quickcheck.Generator.map String.quickcheck_generator\n ~f:Md5.digest_string\n end\n\n module Account = struct\n module T = struct\n type t = { name : string; favorite_number : int }\n [@@deriving bin_io, equal, sexp, yojson]\n end\n\n include T\n\n let key { name; _ } = name\n\n let data_hash t = Md5.digest_string (Binable.to_string (module T) t)\n\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%map name = String.quickcheck_generator\n and favorite_number = Int.quickcheck_generator in\n { name; favorite_number }\n end\n\n module Account_id = struct\n type t = string [@@deriving sexp, equal, yojson]\n end\n\n include Make (Hash) (Account_id) (Account)\n\n let gen =\n let open Quickcheck.Generator in\n let open Let_syntax in\n let indexes max_depth t =\n let rec go addr d = function\n | Tree.Account a ->\n [ (Account.key a, addr) ]\n | Hash _ ->\n []\n | Node (_, l, r) ->\n go addr (d - 1) l @ go (addr lor (1 lsl d)) (d - 1) r\n in\n go 0 (max_depth - 1) t\n in\n let rec prune_hash_branches = function\n | Tree.Hash h ->\n Tree.Hash h\n | Account a ->\n Account a\n | Node (h, l, r) -> (\n match (prune_hash_branches l, prune_hash_branches r) with\n | Hash _, Hash _ ->\n Hash h\n | l, r ->\n Node (h, l, r) )\n in\n let rec gen depth =\n if depth = 0 then Account.gen >>| fun a -> Tree.Account a\n else\n let t =\n let sub = gen (depth - 1) in\n let%map l = sub and r = sub in\n Tree.Node (Hash.merge ~height:(depth - 1) (hash l) (hash r), l, r)\n in\n weighted_union\n [ (1. /. 3., Hash.gen >>| fun h -> Tree.Hash h); (2. /. 3., t) ]\n in\n let%bind depth = Int.gen_incl 0 16 in\n let%map tree = gen depth >>| prune_hash_branches in\n { T.tree; depth; indexes = indexes depth tree }\n\n let%test_unit \"iteri consistent indices with t.indexes\" =\n Quickcheck.test gen ~f:(fun t ->\n let indexes = Int.Set.of_list (t.indexes |> List.map ~f:snd) in\n iteri t ~f:(fun i _ ->\n [%test_result: bool]\n ~message:\n \"Iteri index should be contained in the indexes auxillary \\\n structure\"\n ~expect:true (Int.Set.mem indexes i) ) )\n\n let%test_unit \"path_test\" =\n Quickcheck.test gen ~f:(fun t ->\n let root = { t with indexes = []; tree = Hash (merkle_root t) } in\n let t' =\n List.fold t.indexes ~init:root ~f:(fun acc (_, index) ->\n let account = get_exn t index in\n add_path acc (path_exn t index) (Account.key account) account )\n in\n assert (Tree.equal Hash.equal Account.equal t'.tree t.tree) )\n end )\n","(* coding.ml -- hex encoding/decoding for Rosetta *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nmodule Field = Snark_params.Tick.Field\nmodule Scalar = Snark_params.Tick.Inner_curve.Scalar\nopen Signature_lib\n\n(* see RFC 0038, section \"marshal-keys\" for a specification *)\n\nlet hex_char_to_bits4 = function\n | '0' ->\n [ false; false; false; false ]\n | '1' ->\n [ false; false; false; true ]\n | '2' ->\n [ false; false; true; false ]\n | '3' ->\n [ false; false; true; true ]\n | '4' ->\n [ false; true; false; false ]\n | '5' ->\n [ false; true; false; true ]\n | '6' ->\n [ false; true; true; false ]\n | '7' ->\n [ false; true; true; true ]\n | '8' ->\n [ true; false; false; false ]\n | '9' ->\n [ true; false; false; true ]\n | 'A' | 'a' ->\n [ true; false; true; false ]\n | 'B' | 'b' ->\n [ true; false; true; true ]\n | 'C' | 'c' ->\n [ true; true; false; false ]\n | 'D' | 'd' ->\n [ true; true; false; true ]\n | 'E' | 'e' ->\n [ true; true; true; false ]\n | 'F' | 'f' ->\n [ true; true; true; true ]\n | _ ->\n failwith \"Expected hex character\"\n\nlet bits4_to_hex_char bits =\n List.mapi bits ~f:(fun i bit -> if bit then Int.pow 2 (3 - i) else 0)\n |> List.fold ~init:0 ~f:( + )\n |> fun n ->\n let s = sprintf \"%0X\" n in\n s.[0]\n\nmodule type Packed = sig\n type t\n\n val unpack : t -> bool list\nend\n\n(* break of the bits byte by byte *)\nlet bits_by_n n bits =\n let rec go bits acc =\n if List.is_empty bits then List.rev acc\n else\n let bitsn, rest = List.split_n bits n in\n go rest (bitsn :: acc)\n in\n go bits []\n\nlet bits_by_4s = bits_by_n 4\n\nlet bits_by_8s = bits_by_n 8\n\nlet of_unpackable (type t) (module M : Packed with type t = t)\n ?(padding_bit = false) (packed : t) =\n let bits0 = M.unpack packed |> List.rev in\n assert (Mina_stdlib.List.Length.Compare.(bits0 = 255)) ;\n (* field elements, scalars are 255 bits, left-pad to get 32 bytes *)\n let bits = padding_bit :: bits0 in\n (* break of the bits byte by byte *)\n (* In our encoding, we want highest bytes at the end and lowest at the\n beginning. *)\n let bytes = bits_by_8s bits in\n let bytes' = List.rev bytes in\n let bits' = List.concat bytes' in\n let cs = List.map (bits_by_4s bits') ~f:bits4_to_hex_char in\n String.of_char_list cs\n\nlet of_field = of_unpackable (module Field)\n\nlet of_scalar = of_unpackable (module Scalar)\n\nmodule type Unpacked = sig\n type t\n\n val project : bool list -> t\nend\n\nlet pack (type t) (module M : Unpacked with type t = t) (raw : string) :\n bool * t =\n (* 256 bits = 64 hex chars *)\n assert (Int.equal (String.length raw) 64) ;\n let bits =\n String.to_list raw |> List.map ~f:hex_char_to_bits4 |> List.concat\n in\n (* In our encoding, we have highest bytes at the end and lowest at the\n beginning. *)\n let bytes = bits_by_8s bits in\n let bytes_rev = List.rev bytes in\n let bits' = List.concat bytes_rev in\n\n let padding_bit = List.hd_exn bits' in\n (* remove padding bit *)\n let bits'' = List.tl_exn bits' |> List.rev in\n (padding_bit, M.project bits'')\n\nlet to_field hex = pack (module Field) hex |> snd\n\nlet to_scalar hex = pack (module Scalar) hex |> snd\n\nlet of_public_key_compressed pk =\n let { Public_key.Compressed.Poly.x; is_odd } = pk in\n of_field ~padding_bit:is_odd x\n\nlet of_public_key pk = of_public_key_compressed (Public_key.compress pk)\n\nlet to_public_key_compressed raw =\n let is_odd, x = pack (module Field) raw in\n { Public_key.Compressed.Poly.x; is_odd }\n\nlet to_public_key raw =\n to_public_key_compressed raw |> Public_key.decompress_exn\n\n(* inline tests hard-to-impossible to setup with JS *)\n\nlet field_hex_roundtrip_test () =\n let field0 = Field.of_int 123123 in\n let hex = of_field field0 in\n let field1 = to_field hex in\n Field.equal field0 field1\n\nlet pk_roundtrip_test () =\n let pk =\n { Public_key.Compressed.Poly.x = Field.of_int 123123; is_odd = true }\n in\n let hex = of_public_key_compressed pk in\n let pk' = to_public_key_compressed hex in\n Public_key.Compressed.equal pk pk'\n\nlet hex_key_odd =\n \"fad1d3e31aede102793fb2cce62b4f1e71a214c94ce18ad5756eba67ef398390\"\n\nlet hex_key_even =\n \"7e406ca640115a8c44ece6ef5d0c56af343b1a993d8c871648ab7980ecaf8230\"\n\nlet pk_compressed_roundtrip_test hex_key () =\n let pk = to_public_key hex_key in\n let hex' = of_public_key pk in\n String.equal (String.lowercase hex_key) (String.lowercase hex')\n\nlet%test \"field_hex round-trip\" = field_hex_roundtrip_test ()\n\nlet%test \"public key round-trip\" = pk_roundtrip_test ()\n\nlet%test \"public key compressed roundtrip odd\" =\n pk_compressed_roundtrip_test hex_key_odd ()\n\nlet%test \"public key compressed roundtrip even\" =\n pk_compressed_roundtrip_test hex_key_even ()\n\n(* for running tests from JS *)\n\nlet unit_tests =\n [ (\"field-hex round-trip\", field_hex_roundtrip_test)\n ; (\"public key round-trip\", pk_roundtrip_test)\n ; ( \"public key compressed round-trip odd\"\n , pk_compressed_roundtrip_test hex_key_odd )\n ; ( \"public key compressed round-trip even\"\n , pk_compressed_roundtrip_test hex_key_even )\n ]\n\nlet run_unit_tests () =\n List.iter unit_tests ~f:(fun (name, test) ->\n printf \"Running %s test\\n%!\" name ;\n assert (test ()) )\n","(* deriving.ml -- deriving ppx for Dhall types *)\n\n(* TODO:\n deriver for signatures\n default values in records\n*)\n\nopen Core_kernel\nopen Ppxlib\n\nlet deriver = \"dhall_type\"\n\nlet field_key_attr =\n Attribute.declare (deriver ^ \".key\") Attribute.Context.Label_declaration\n Ast_pattern.(single_expr_payload (estring __))\n Fn.id\n\nlet make_lident_cmp items lident =\n List.mem items (Longident.name lident.txt) ~equal:String.equal\n\nlet is_bool_lident = make_lident_cmp [ \"bool\"; \"Bool.t\" ]\n\nlet is_int_lident = make_lident_cmp [ \"int\"; \"Int.t\" ]\n\nlet is_float_lident = make_lident_cmp [ \"float\"; \"Float.t\" ]\n\nlet is_string_lident = make_lident_cmp [ \"string\"; \"String.t\" ]\n\nlet is_option_lident = make_lident_cmp [ \"option\"; \"Option.t\" ]\n\nlet is_list_lident = make_lident_cmp [ \"list\"; \"List.t\" ]\n\nlet rec dhall_type_of_core_type core_type =\n let (module Ast_builder) = Ast_builder.make core_type.ptyp_loc in\n let open Ast_builder in\n match core_type.ptyp_desc with\n | Ptyp_constr (lident, []) when is_bool_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.Bool]\n | Ptyp_constr (lident, []) when is_int_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.Integer]\n | Ptyp_constr (lident, []) when is_float_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.Double]\n | Ptyp_constr (lident, []) when is_string_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.Text]\n | Ptyp_constr (lident, [ ty ]) when is_option_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.Optional [%e dhall_type_of_core_type ty]]\n | Ptyp_constr (lident, [ ty ]) when is_list_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.List [%e dhall_type_of_core_type ty]]\n | Ptyp_constr ({ txt = Lident id; _ }, []) ->\n evar (id ^ \"_dhall_type\")\n | Ptyp_constr ({ txt = Lident id; _ }, params) ->\n let dhall_type_fun = evar (id ^ \"_dhall_type\") in\n let args = List.map params ~f:dhall_type_of_core_type in\n eapply dhall_type_fun args\n | Ptyp_constr ({ txt = Ldot (prefix, nm); _ }, []) ->\n let mod_path = Longident.name prefix in\n if String.equal nm \"t\" then evar (mod_path ^ \".dhall_type\")\n else evar (mod_path ^ \".\" ^ nm ^ \"_dhall_type\")\n | Ptyp_constr ({ txt = Ldot (prefix, nm); _ }, params) ->\n let mod_path = Longident.name prefix in\n let dhall_type_fun =\n if String.equal nm \"t\" then evar (mod_path ^ \".dhall_type\")\n else evar (mod_path ^ \".\" ^ nm ^ \"_dhall_type\")\n in\n let args = List.map params ~f:dhall_type_of_core_type in\n eapply dhall_type_fun args\n | Ptyp_var a ->\n evar a\n | _ ->\n Location.raise_errorf ~loc:core_type.ptyp_loc \"Unsupported type\"\n\nlet dhall_variant_from_constructor_declaration ctor_decl =\n let (module Ast_builder) = Ast_builder.make ctor_decl.pcd_name.loc in\n let open Ast_builder in\n let name = estring @@ String.lowercase ctor_decl.pcd_name.txt in\n match ctor_decl.pcd_args with\n | Pcstr_tuple [] ->\n [%expr [%e name], None]\n | Pcstr_tuple [ ty ] ->\n [%expr [%e name], Some [%e dhall_type_of_core_type ty]]\n | Pcstr_tuple tys ->\n let tys_expr = elist (List.map tys ~f:dhall_type_of_core_type) in\n [%expr [%e name], Some (List [%e tys_expr])]\n | Pcstr_record _ ->\n Location.raise_errorf ~loc:ctor_decl.pcd_name.loc\n \"Records not yet supported\"\n\nlet dhall_field_from_label_declaration label_decl =\n let (module Ast_builder) = Ast_builder.make label_decl.pld_name.loc in\n let open Ast_builder in\n let name =\n match Attribute.get field_key_attr label_decl with\n | Some name ->\n estring name\n | None ->\n estring label_decl.pld_name.txt\n in\n let ty = dhall_type_of_core_type label_decl.pld_type in\n [%expr [%e name], [%e ty]]\n\nlet generate_dhall_type type_decl =\n let (module Ast_builder) = Ast_builder.make type_decl.ptype_loc in\n let open Ast_builder in\n let dhall_type =\n match type_decl.ptype_kind with\n | Ptype_abstract -> (\n match type_decl.ptype_manifest with\n | None ->\n Location.raise_errorf ~loc:type_decl.ptype_loc\n \"Abstract type declaration has no manifest (right-hand side)\"\n | Some core_type ->\n dhall_type_of_core_type core_type )\n | Ptype_variant ctor_decls ->\n [%expr\n Ppx_dhall_type.Dhall_type.Union\n [%e\n elist\n (List.map ctor_decls\n ~f:dhall_variant_from_constructor_declaration )]]\n | Ptype_record label_decls ->\n [%expr\n Ppx_dhall_type.Dhall_type.Record\n [%e\n elist (List.map label_decls ~f:dhall_field_from_label_declaration)]]\n | Ptype_open ->\n Location.raise_errorf ~loc:type_decl.ptype_loc\n \"Open types not supported\"\n in\n let ty_name =\n match type_decl.ptype_name.txt with\n | \"t\" ->\n pvar \"dhall_type\"\n | nm ->\n pvar (nm ^ \"_dhall_type\")\n in\n match type_decl.ptype_params with\n | [] ->\n [%stri let [%p ty_name] = [%e dhall_type]]\n | params ->\n let args =\n List.map params ~f:(fun (core_type, _variance) ->\n match core_type.ptyp_desc with\n | Ptyp_var a ->\n pvar a\n | _ ->\n Location.raise_errorf ~loc:type_decl.ptype_loc\n \"Type parameter not a type variable\" )\n in\n let abs = eabstract args dhall_type in\n [%stri let [%p ty_name] = [%e abs]]\n\nlet generate_dhall_types ~loc:_ ~path:_ (_rec_flag, type_decls) =\n List.map type_decls ~f:generate_dhall_type\n\nlet attributes = [ Attribute.T field_key_attr ]\n\nlet str_type_decl =\n Deriving.Generator.make_noarg ~attributes generate_dhall_types\n\nlet () = Deriving.add deriver ~str_type_decl |> Ppxlib.Deriving.ignore\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type ('magnitude, 'sgn) t =\n ('magnitude, 'sgn) Mina_wire_types.Signed_poly.V1.t =\n { magnitude : 'magnitude; sgn : 'sgn }\n [@@deriving annot, sexp, hash, compare, equal, yojson, fields]\n end\nend]\n\nlet map ~f { magnitude; sgn } = { magnitude = f magnitude; sgn }\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_bits\nopen Snark_params\nopen Tick\n\n[%%ifdef consensus_mechanism]\n\nopen Bitstring_lib\nopen Let_syntax\n\n[%%endif]\n\nopen Intf\n\n(** [Currency_oveflow] is being thrown to signal an overflow\n or underflow during conversions from [int] to currency.\n The exception contains the [int] value that caused the\n misbehaviour. *)\nexception Currency_overflow of int\n\ntype uint64 = Unsigned.uint64\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Currency\n\n(** Define the expected full signature of the module, based on the types defined\n in {!Mina_wire_types} *)\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Intf.Full\n (* full interface defined in a separate file, as it would appear\n in the MLI *)\n with type Fee.Stable.V1.t = A.Fee.V1.t\n (* with added type equalities *)\n and type Amount.Stable.V1.t = A.Amount.V1.t\n and type Balance.Stable.V1.t = A.Balance.V1.t\nend\n\n(** Then we make the real module, which has to have a signature of type\n {!Make_sig(A)}. Here, since all types are simple type aliases, we don't need\n to use [A] in the implementation. Otherwise, we would need to add type\n equalities to the corresponding type in [A] in each type definition. *)\nmodule Make_str (A : Wire_types.Concrete) = struct\n module Signed_poly = Signed_poly\n\n [%%ifdef consensus_mechanism]\n\n module Signed_var = struct\n type 'mag repr = ('mag, Sgn.var) Signed_poly.t\n\n (* Invariant: At least one of these is Some *)\n type nonrec 'mag t =\n { repr : 'mag repr; mutable value : Field.Var.t option }\n end\n\n [%%endif]\n\n module Make (Unsigned : sig\n include Unsigned_extended.S\n\n val to_uint64 : t -> uint64\n\n val of_uint64 : uint64 -> t\n end) (M : sig\n val length : int\n end) : sig\n [%%ifdef consensus_mechanism]\n\n include\n S\n with type t = Unsigned.t\n and type var = Field.Var.t\n and type Signed.var = Field.Var.t Signed_var.t\n and type Signed.signed_fee = (Unsigned.t, Sgn.t) Signed_poly.t\n and type Signed.Checked.signed_fee_var = Field.Var.t Signed_var.t\n\n val pack_var : var -> Field.Var.t\n\n [%%else]\n\n include\n S\n with type t = Unsigned.t\n and type Signed.signed_fee := (Unsigned.t, Sgn.t) Signed_poly.t\n\n [%%endif]\n\n val scale : t -> int -> t option\n end = struct\n let max_int = Unsigned.max_int\n\n let length_in_bits = M.length\n\n type t = Unsigned.t [@@deriving sexp, compare, hash]\n\n (* can't be automatically derived *)\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n\n [%%define_locally\n Unsigned.(to_uint64, of_uint64, of_int, to_int, of_string, to_string)]\n\n let precision = 9\n\n let precision_exp = Unsigned.of_int @@ Int.pow 10 precision\n\n let to_mina_string amount =\n let rec go num_stripped_zeros num =\n let open Int in\n if num mod 10 = 0 && num <> 0 then go (num_stripped_zeros + 1) (num / 10)\n else (num_stripped_zeros, num)\n in\n\n let whole = Unsigned.div amount precision_exp in\n let remainder = Unsigned.to_int (Unsigned.rem amount precision_exp) in\n if Int.(remainder = 0) then to_string whole\n else\n let num_stripped_zeros, num = go 0 remainder in\n Printf.sprintf \"%s.%0*d\" (to_string whole)\n Int.(precision - num_stripped_zeros)\n num\n\n let of_mina_string_exn input =\n let parts = String.split ~on:'.' input in\n match parts with\n | [ whole ] ->\n of_string (whole ^ String.make precision '0')\n | [ whole; decimal ] ->\n let decimal_length = String.length decimal in\n if Int.(decimal_length > precision) then\n of_string (whole ^ String.sub decimal ~pos:0 ~len:precision)\n else\n of_string\n ( whole ^ decimal\n ^ String.make Int.(precision - decimal_length) '0' )\n | _ ->\n failwith \"Currency.of_mina_string_exn: Invalid currency input\"\n\n module Arg = struct\n type typ = t [@@deriving sexp, hash, compare]\n\n type t = typ [@@deriving sexp, hash, compare]\n\n let to_string = to_mina_string\n\n let of_string = of_mina_string_exn\n end\n\n include Codable.Make_of_string (Arg)\n include Hashable.Make (Arg)\n include Comparable.Make (Arg)\n\n let gen_incl a b : t Quickcheck.Generator.t =\n let a = Bignum_bigint.of_string Unsigned.(to_string a) in\n let b = Bignum_bigint.of_string Unsigned.(to_string b) in\n Quickcheck.Generator.map\n Bignum_bigint.(gen_incl a b)\n ~f:(fun n -> of_string (Bignum_bigint.to_string n))\n\n let gen : t Quickcheck.Generator.t =\n let m = Bignum_bigint.of_string Unsigned.(to_string max_int) in\n Quickcheck.Generator.map\n Bignum_bigint.(gen_incl zero m)\n ~f:(fun n -> of_string (Bignum_bigint.to_string n))\n\n module Vector = struct\n include M\n include Unsigned\n\n let empty = zero\n\n let get t i = Infix.((t lsr i) land one = one)\n\n let set v i b =\n if b then Infix.(v lor (one lsl i))\n else Infix.(v land lognot (one lsl i))\n end\n\n module B = Bits.Vector.Make (Vector)\n\n include (B : Bits_intf.Convertible_bits with type t := t)\n\n [%%ifdef consensus_mechanism]\n\n type var = Field.Var.t\n\n let pack_var = Fn.id\n\n let equal_var = Field.Checked.equal\n\n let m = Snark_params.Tick.m\n\n let make_checked = Snark_params.Tick.make_checked\n\n let var_to_bits_ (t : var) = Field.Checked.unpack ~length:length_in_bits t\n\n let var_to_bits t = var_to_bits_ t >>| Bitstring.Lsb_first.of_list\n\n let var_to_input (t : var) =\n Random_oracle.Input.Chunked.packed (t, length_in_bits)\n\n let var_to_input_legacy (t : var) =\n var_to_bits_ t >>| Random_oracle.Input.Legacy.bitstring\n\n let var_of_t (t : t) : var = Field.Var.constant (Field.project (to_bits t))\n\n let if_ cond ~then_ ~else_ : var Checked.t =\n Field.Checked.if_ cond ~then_ ~else_\n\n let () = assert (Int.(length_in_bits mod 16 = 0))\n\n (** UNSAFE. Take the field element formed by the final [length_in_bits] bits\n of the argument.\n\n WARNING: The returned value may be chosen arbitrarily by a malicious\n prover, and this is really only useful for the more-efficient bit\n projection. Users of this function must manually assert the relationship\n between the argument and the return value, or the circuit will be\n underconstrained.\n *)\n let image_from_bits_unsafe (t : var) =\n make_checked (fun () ->\n let _, _, actual_packed =\n Pickles.Scalar_challenge.to_field_checked' ~num_bits:length_in_bits\n m\n (Kimchi_backend_common.Scalar_challenge.create t)\n in\n actual_packed )\n\n (** [range_check t] asserts that [0 <= t < 2^length_in_bits].\n\n Any value consumed or returned by functions in this module must satisfy\n this assertion.\n *)\n let range_check t =\n let%bind actual = image_from_bits_unsafe t in\n with_label \"range_check\" (fun () -> Field.Checked.Assert.equal actual t)\n\n let seal x = make_checked (fun () -> Pickles.Util.seal Tick.m x)\n\n let modulus_as_field =\n lazy (Fn.apply_n_times ~n:length_in_bits Field.(mul (of_int 2)) Field.one)\n\n let double_modulus_as_field =\n lazy (Field.(mul (of_int 2)) (Lazy.force modulus_as_field))\n\n (** [range_check_flagged kind t] returns [t'] that fits in [length_in_bits]\n bits, and satisfies [t' = t + k * 2^length_in_bits] for some [k].\n The [`Overflow b] return value is false iff [t' = t].\n\n This function should be used when [t] was computed via addition or\n subtraction, to calculate the equivalent value that would be returned by\n overflowing or underflowing an integer with [length_in_bits] bits.\n\n The [`Add] and [`Sub] values for [kind] are specializations that use\n fewer constraints and perform fewer calculations. Any inputs that satisfy\n the invariants for [`Add] or [`Sub] will return the same value if\n [`Add_or_sub] is used instead.\n\n Invariants:\n * if [kind] is [`Add], [0 <= t < 2 * 2^length_in_bits - 1];\n * if [kind] is [`Sub], [- 2^length_in_bits < t < 2^length_in_bits];\n * if [kind] is [`Add_or_sub],\n [- 2^length_in_bits < t < 2 * 2^length_in_bits - 1].\n *)\n let range_check_flagged (kind : [ `Add | `Sub | `Add_or_sub ]) t =\n let%bind adjustment_factor =\n exists Field.typ\n ~compute:\n As_prover.(\n let%map t = read Field.typ t in\n match kind with\n | `Add ->\n if Int.(Field.compare t (Lazy.force modulus_as_field) < 0)\n then (* Within range. *)\n Field.zero\n else\n (* Overflowed. We compensate by subtracting [modulus_as_field]. *)\n Field.(negate one)\n | `Sub ->\n if Int.(Field.compare t (Lazy.force modulus_as_field) < 0)\n then (* Within range. *)\n Field.zero\n else\n (* Underflowed, but appears as an overflow because of wrapping in\n the field (that is, -1 is the largest field element, -2 is the\n second largest, etc.). Compensate by adding [modulus_as_field].\n *)\n Field.one\n | `Add_or_sub ->\n (* This case is a little more nuanced: -modulus_as_field < t <\n 2*modulus_as_field, and we need to detect which 'side of 0' we\n are. Thus, we have 3 cases:\n *)\n if Int.(Field.compare t (Lazy.force modulus_as_field) < 0)\n then\n (* 1. we are already in the desired range, no adjustment; *)\n Field.zero\n else if\n Int.(\n Field.compare t (Lazy.force double_modulus_as_field) < 0)\n then\n (* 2. we are in the range\n [modulus_as_field <= t < 2 * modulus_as_field],\n so this was an addition that overflowed, and we should\n compensate by subtracting [modulus_as_field];\n *)\n Field.(negate one)\n else\n (* 3. we are outside of either range, so this must be the\n underflow of a subtraction, and we should compensate by\n adding [modulus_as_field].\n *)\n Field.one)\n in\n let%bind out_of_range =\n match kind with\n | `Add ->\n (* 0 or -1 => 0 or 1 *)\n Boolean.of_field (Field.Var.negate adjustment_factor)\n | `Sub ->\n (* Already 0 or 1 *)\n Boolean.of_field adjustment_factor\n | `Add_or_sub ->\n (* The return flag [out_of_range] is a boolean represented by either 0\n when [t] is in range or 1 when [t] is out-of-range.\n Notice that [out_of_range = adjustment_factor^2] gives us exactly\n the desired values, and moreover we can ensure that\n [adjustment_factor] is exactly one of -1, 0 or 1 by checking that\n [out_of_range] is boolean.\n *)\n Field.Checked.mul adjustment_factor adjustment_factor\n >>= Boolean.of_field\n in\n (* [t_adjusted = t + adjustment_factor * modulus_as_field] *)\n let t_adjusted =\n let open Field.Var in\n add t (scale adjustment_factor (Lazy.force modulus_as_field))\n in\n let%bind t_adjusted = seal t_adjusted in\n let%map () = range_check t_adjusted in\n (t_adjusted, `Overflow out_of_range)\n\n let of_field (x : Field.t) : t =\n of_bits (List.take (Field.unpack x) length_in_bits)\n\n let to_field (x : t) : Field.t = Field.project (to_bits x)\n\n let typ : (var, t) Typ.t =\n let (Typ typ) = Field.typ in\n Typ.transport\n (Typ { typ with check = range_check })\n ~there:to_field ~back:of_field\n\n [%%endif]\n\n let zero = Unsigned.zero\n\n let one = Unsigned.one\n\n (* The number of nanounits in a unit. User for unit transformations. *)\n let unit_to_nano = 1_000_000_000\n\n let to_nanomina_int = to_int\n\n let to_mina_int m = to_int m / unit_to_nano\n\n let sub x y = if x < y then None else Some (Unsigned.sub x y)\n\n let sub_flagged x y =\n let z = Unsigned.sub x y in\n (z, `Underflow (x < y))\n\n let add x y =\n let z = Unsigned.add x y in\n if z < x then None else Some z\n\n let add_flagged x y =\n let z = Unsigned.add x y in\n (z, `Overflow (z < x))\n\n let add_signed_flagged x y =\n match y.Signed_poly.sgn with\n | Sgn.Pos ->\n let z, `Overflow b = add_flagged x y.Signed_poly.magnitude in\n (z, `Overflow b)\n | Sgn.Neg ->\n let z, `Underflow b = sub_flagged x y.Signed_poly.magnitude in\n (z, `Overflow b)\n\n let scale u64 i =\n if Int.(i = 0) then Some zero\n else\n let i = Unsigned.of_int i in\n let max_val = Unsigned.(div max_int i) in\n if max_val >= u64 then Some (Unsigned.mul u64 i) else None\n\n let ( + ) = add\n\n let ( - ) = sub\n\n (* The functions below are unsafe, because they could overflow or\n underflow. They perform appropriate checks to guard against this\n and either raise Currency_overflow exception or return None\n depending on the error-handling strategy.\n\n It is advisable to use nanomina and mina wherever possible and\n limit the use of _exn veriants to places where a fixed value is\n being converted and hence overflow cannot happen. *)\n let of_nanomina_int i = if Int.(i >= 0) then Some (of_int i) else None\n\n let of_mina_int i =\n Option.(of_nanomina_int i >>= Fn.flip scale unit_to_nano)\n\n let of_nanomina_int_exn i =\n match of_nanomina_int i with\n | None ->\n raise (Currency_overflow i)\n | Some m ->\n m\n\n let of_mina_int_exn i =\n match of_mina_int i with\n | None ->\n raise (Currency_overflow i)\n | Some m ->\n m\n\n type magnitude = t [@@deriving sexp, hash, compare, yojson]\n\n let to_input (t : t) =\n Random_oracle.Input.Chunked.packed\n (Field.project (to_bits t), length_in_bits)\n\n let to_input_legacy t = Random_oracle.Input.Legacy.bitstring @@ to_bits t\n\n module Signed = struct\n type ('magnitude, 'sgn) typ = ('magnitude, 'sgn) Signed_poly.t =\n { magnitude : 'magnitude; sgn : 'sgn }\n [@@deriving sexp, hash, compare, yojson, hlist]\n\n type t = (Unsigned.t, Sgn.t) Signed_poly.t [@@deriving sexp, hash, yojson]\n\n let compare : t -> t -> int =\n let cmp = [%compare: (Unsigned.t, Sgn.t) Signed_poly.t] in\n fun t1 t2 ->\n if Unsigned.(equal t1.magnitude zero && equal t2.magnitude zero) then\n 0\n else cmp t1 t2\n\n let equal : t -> t -> bool =\n let eq = [%equal: (Unsigned.t, Sgn.t) Signed_poly.t] in\n fun t1 t2 ->\n if Unsigned.(equal t1.magnitude zero && equal t2.magnitude zero) then\n true\n else eq t1 t2\n\n let is_zero (t : t) : bool = Unsigned.(equal t.magnitude zero)\n\n let is_positive (t : t) : bool =\n match t.sgn with\n | Pos ->\n not Unsigned.(equal zero t.magnitude)\n | Neg ->\n false\n\n let is_negative (t : t) : bool =\n match t.sgn with\n | Neg ->\n not Unsigned.(equal zero t.magnitude)\n | Pos ->\n false\n\n type magnitude = Unsigned.t [@@deriving sexp, compare]\n\n let create ~magnitude ~sgn =\n { magnitude\n ; sgn = (if Unsigned.(equal magnitude zero) then Sgn.Pos else sgn)\n }\n\n let sgn { sgn; _ } = sgn\n\n let magnitude { magnitude; _ } = magnitude\n\n let zero : t = { magnitude = zero; sgn = Sgn.Pos }\n\n let gen =\n Quickcheck.Generator.map2 gen Sgn.gen ~f:(fun magnitude sgn ->\n create ~magnitude ~sgn )\n\n let sgn_to_bool = function Sgn.Pos -> true | Neg -> false\n\n let to_bits ({ sgn; magnitude } : t) =\n sgn_to_bool sgn :: to_bits magnitude\n\n let to_input { sgn; magnitude } =\n Random_oracle.Input.Chunked.(\n append (to_input magnitude)\n (packed (Field.project [ sgn_to_bool sgn ], 1)))\n\n let to_input_legacy t = Random_oracle.Input.Legacy.bitstring (to_bits t)\n\n let add (x : t) (y : t) : t option =\n match (x.sgn, y.sgn) with\n | Neg, (Neg as sgn) | Pos, (Pos as sgn) ->\n let open Option.Let_syntax in\n let%map magnitude = add x.magnitude y.magnitude in\n create ~sgn ~magnitude\n | Pos, Neg | Neg, Pos ->\n let c = compare_magnitude x.magnitude y.magnitude in\n Some\n ( if Int.( < ) c 0 then\n create ~sgn:y.sgn\n ~magnitude:Unsigned.Infix.(y.magnitude - x.magnitude)\n else if Int.( > ) c 0 then\n create ~sgn:x.sgn\n ~magnitude:Unsigned.Infix.(x.magnitude - y.magnitude)\n else zero )\n\n let add_flagged (x : t) (y : t) : t * [ `Overflow of bool ] =\n match (x.sgn, y.sgn) with\n | Neg, (Neg as sgn) | Pos, (Pos as sgn) ->\n let magnitude, `Overflow b = add_flagged x.magnitude y.magnitude in\n (create ~sgn ~magnitude, `Overflow b)\n | Pos, Neg | Neg, Pos ->\n let c = compare_magnitude x.magnitude y.magnitude in\n ( ( if Int.( < ) c 0 then\n create ~sgn:y.sgn\n ~magnitude:Unsigned.Infix.(y.magnitude - x.magnitude)\n else if Int.( > ) c 0 then\n create ~sgn:x.sgn\n ~magnitude:Unsigned.Infix.(x.magnitude - y.magnitude)\n else zero )\n , `Overflow false )\n\n let negate t =\n if Unsigned.(equal zero t.magnitude) then zero\n else { t with sgn = Sgn.negate t.sgn }\n\n let of_unsigned magnitude : t = create ~magnitude ~sgn:Sgn.Pos\n\n let ( + ) = add\n\n let to_fee = Fn.id\n\n let of_fee = Fn.id\n\n [%%ifdef consensus_mechanism]\n\n type signed_fee = t\n\n let magnitude_to_field = to_field\n\n let to_field (t : t) : Field.t =\n Field.mul (Sgn.to_field t.sgn) (magnitude_to_field t.magnitude)\n\n type repr = var Signed_var.repr\n\n type nonrec var = var Signed_var.t\n\n let repr_typ : (repr, t) Typ.t =\n Typ.of_hlistable [ typ; Sgn.typ ] ~var_to_hlist:typ_to_hlist\n ~var_of_hlist:typ_of_hlist ~value_to_hlist:typ_to_hlist\n ~value_of_hlist:typ_of_hlist\n\n let typ : (var, t) Typ.t =\n Typ.transport_var repr_typ\n ~back:(fun repr -> { Signed_var.value = None; repr })\n ~there:(fun { Signed_var.repr; _ } -> repr)\n\n let create_var ~magnitude ~sgn : var =\n { repr = { magnitude; sgn }; value = None }\n\n module Checked = struct\n type t = var\n\n type signed_fee_var = t\n\n let repr (t : var) = Checked.return t.repr\n\n let value (t : var) =\n match t.value with\n | Some x ->\n Checked.return x\n | None ->\n let r = t.repr in\n let%map x =\n Field.Checked.mul (r.sgn :> Field.Var.t) r.magnitude\n in\n t.value <- Some x ;\n x\n\n let to_field_var = value\n\n let to_input t =\n let%map { magnitude; sgn } = repr t in\n let mag = var_to_input magnitude in\n Random_oracle.Input.Chunked.(\n append mag (packed ((Sgn.Checked.is_pos sgn :> Field.Var.t), 1)))\n\n let to_input_legacy t =\n let to_bits { magnitude; sgn } =\n let%map magnitude = var_to_bits_ magnitude in\n Sgn.Checked.is_pos sgn :: magnitude\n in\n repr t >>= to_bits >>| Random_oracle.Input.Legacy.bitstring\n\n let constant ({ magnitude; sgn } as t) =\n { Signed_var.repr =\n { magnitude = var_of_t magnitude; sgn = Sgn.Checked.constant sgn }\n ; value = Some (Field.Var.constant (to_field t))\n }\n\n let of_unsigned magnitude : var =\n { repr = { magnitude; sgn = Sgn.Checked.pos }\n ; value = Some magnitude\n }\n\n let negate (t : var) : var =\n { value = Option.map t.value ~f:Field.Var.negate\n ; repr =\n (let { magnitude; sgn } = t.repr in\n { magnitude; sgn = Sgn.Checked.negate sgn } )\n }\n\n let if_repr cond ~then_ ~else_ =\n let%map sgn = Sgn.Checked.if_ cond ~then_:then_.sgn ~else_:else_.sgn\n and magnitude =\n if_ cond ~then_:then_.magnitude ~else_:else_.magnitude\n in\n { sgn; magnitude }\n\n let if_ cond ~(then_ : var) ~(else_ : var) : var Checked.t =\n let%bind repr = if_repr cond ~then_:then_.repr ~else_:else_.repr in\n let%map value =\n match (then_.value, else_.value) with\n | Some v1, Some v2 ->\n Field.Checked.if_ cond ~then_:v1 ~else_:v2 >>| Option.return\n | _ ->\n return None\n in\n { Signed_var.value; repr }\n\n let sgn (t : var) =\n let%map r = repr t in\n r.sgn\n\n let magnitude (t : var) =\n let%map r = repr t in\n r.magnitude\n\n let add_flagged (x : var) (y : var) =\n let%bind xv = value x and yv = value y in\n let%bind sgn =\n exists Sgn.typ\n ~compute:\n (let open As_prover in\n let%map x = read typ x and y = read typ y in\n match add x y with\n | Some r ->\n r.sgn\n | None -> (\n match (x.sgn, y.sgn) with\n | Sgn.Neg, Sgn.Neg ->\n (* Ensure that we provide a value in the range\n [-modulus_as_field < magnitude < 2*modulus_as_field]\n for [range_check_flagged].\n *)\n Sgn.Neg\n | _ ->\n Sgn.Pos ))\n in\n let value = Field.Var.add xv yv in\n let%bind magnitude =\n Tick.Field.Checked.mul (sgn :> Field.Var.t) value\n in\n let%bind res_magnitude, `Overflow overflow =\n range_check_flagged `Add_or_sub magnitude\n in\n (* Recompute the result from [res_magnitude], since it may have been\n adjusted.\n *)\n let%map res_value =\n Field.Checked.mul (sgn :> Field.Var.t) magnitude\n in\n ( { Signed_var.repr = { magnitude = res_magnitude; sgn }\n ; value = Some res_value\n }\n , `Overflow overflow )\n\n let add (x : var) (y : var) =\n let%bind xv = value x and yv = value y in\n let%bind sgn =\n exists Sgn.typ\n ~compute:\n (let open As_prover in\n let%map x = read typ x and y = read typ y in\n Option.value_map (add x y) ~default:Sgn.Pos ~f:(fun r -> r.sgn))\n in\n let%bind res_value = seal (Field.Var.add xv yv) in\n let%bind magnitude =\n Tick.Field.Checked.mul (sgn :> Field.Var.t) res_value\n in\n let%map () = range_check magnitude in\n { Signed_var.repr = { magnitude; sgn }; value = Some res_value }\n\n let ( + ) = add\n\n let equal (t1 : var) (t2 : var) =\n let%bind t1 = value t1 and t2 = value t2 in\n Field.Checked.equal t1 t2\n\n let assert_equal (t1 : var) (t2 : var) =\n let%bind t1 = value t1 and t2 = value t2 in\n Field.Checked.Assert.equal t1 t2\n\n let to_fee = Fn.id\n\n let of_fee = Fn.id\n end\n\n [%%endif]\n end\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n module N = Mina_numbers.Nat.Make_checked (Unsigned) (B)\n\n type t = var\n\n let if_ = if_\n\n (* Unpacking protects against underflow *)\n let sub (x : var) (y : var) =\n let%bind res = seal (Field.Var.sub x y) in\n let%map () = range_check res in\n res\n\n let sub_flagged x y =\n let%bind z = seal (Field.Var.sub x y) in\n let%map z, `Overflow underflow = range_check_flagged `Sub z in\n (z, `Underflow underflow)\n\n let sub_or_zero x y =\n let%bind res, `Underflow underflow = sub_flagged x y in\n Field.Checked.if_ underflow ~then_:Field.(Var.constant zero) ~else_:res\n\n let assert_equal x y = Field.Checked.Assert.equal x y\n\n let equal x y = Field.Checked.equal x y\n\n let ( = ) = equal\n\n let ( < ) x y =\n let%bind diff = seal (Field.Var.sub x y) in\n (* [lt] is true iff [x - y < 0], ie. [x < y] *)\n let%map _res, `Overflow lt = range_check_flagged `Sub diff in\n lt\n\n (* x <= y iff not (y < x) *)\n let ( <= ) x y =\n let%map y_lt_x = y < x in\n Boolean.not y_lt_x\n\n (* x >= y iff y <= x *)\n let ( >= ) x y = y <= x\n\n let ( > ) x y = y < x\n\n (* Unpacking protects against overflow *)\n let add (x : var) (y : var) =\n let%bind res = seal (Field.Var.add x y) in\n let%map () = range_check res in\n res\n\n let add_flagged x y =\n let%bind z = seal (Field.Var.add x y) in\n let%map z, `Overflow overflow = range_check_flagged `Add z in\n (z, `Overflow overflow)\n\n let ( - ) = sub\n\n let ( + ) = add\n\n let add_signed (t : var) (d : Signed.var) =\n let%bind d = Signed.Checked.to_field_var d in\n let%bind res = seal (Field.Var.add t d) in\n let%map () = range_check res in\n res\n\n let add_signed_flagged (t : var) (d : Signed.var) =\n let%bind d = Signed.Checked.to_field_var d in\n let%bind res = seal (Field.Var.add t d) in\n let%map res, `Overflow overflow = range_check_flagged `Add_or_sub res in\n (res, `Overflow overflow)\n\n let scale (f : Field.Var.t) (t : var) =\n let%bind res = Field.Checked.mul t f in\n let%map () = range_check res in\n res\n\n let%test_module \"currency_test\" =\n ( module struct\n let expect_failure err c =\n if Or_error.is_ok (check c) then failwith err\n\n let expect_success err c =\n match check c with\n | Ok () ->\n ()\n | Error e ->\n Error.(raise (tag ~tag:err e))\n\n let to_bigint x = Bignum_bigint.of_string (Unsigned.to_string x)\n\n let of_bigint x = Unsigned.of_string (Bignum_bigint.to_string x)\n\n let gen_incl x y =\n Quickcheck.Generator.map ~f:of_bigint\n (Bignum_bigint.gen_incl (to_bigint x) (to_bigint y))\n\n let shrinker =\n Quickcheck.Shrinker.create (fun i ->\n Sequence.unfold ~init:i ~f:(fun i ->\n if Unsigned.equal i Unsigned.zero then None\n else\n let n = Unsigned.div i (Unsigned.of_int 10) in\n Some (n, n) ) )\n\n (* TODO: When we do something to make snarks run fast for tests, increase the trials *)\n let qc_test_fast = Quickcheck.test ~trials:100\n\n let%test_unit \"subtraction_completeness\" =\n let generator =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = gen_incl Unsigned.zero Unsigned.max_int in\n let%map y = gen_incl Unsigned.zero x in\n (x, y)\n in\n qc_test_fast generator ~f:(fun (lo, hi) ->\n expect_success\n (sprintf !\"subtraction: lo=%{Unsigned} hi=%{Unsigned}\" lo hi)\n (var_of_t lo - var_of_t hi) )\n\n let%test_unit \"subtraction_soundness\" =\n let generator =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = gen_incl Unsigned.zero Unsigned.(sub max_int one) in\n let%map y = gen_incl Unsigned.(add x one) Unsigned.max_int in\n (x, y)\n in\n qc_test_fast generator ~f:(fun (lo, hi) ->\n expect_failure\n (sprintf !\"underflow: lo=%{Unsigned} hi=%{Unsigned}\" lo hi)\n (var_of_t lo - var_of_t hi) )\n\n let%test_unit \"addition_completeness\" =\n let generator =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = gen_incl Unsigned.zero Unsigned.max_int in\n let%map y = gen_incl Unsigned.zero Unsigned.(sub max_int x) in\n (x, y)\n in\n qc_test_fast generator ~f:(fun (x, y) ->\n expect_success\n (sprintf !\"overflow: x=%{Unsigned} y=%{Unsigned}\" x y)\n (var_of_t x + var_of_t y) )\n\n let%test_unit \"addition_soundness\" =\n let generator =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = gen_incl Unsigned.one Unsigned.max_int in\n let%map y =\n gen_incl Unsigned.(add (sub max_int x) one) Unsigned.max_int\n in\n (x, y)\n in\n qc_test_fast generator ~f:(fun (x, y) ->\n expect_failure\n (sprintf !\"overflow: x=%{Unsigned} y=%{Unsigned}\" x y)\n (var_of_t x + var_of_t y) )\n\n let%test_unit \"formatting_roundtrip\" =\n let generator = gen_incl Unsigned.zero Unsigned.max_int in\n qc_test_fast generator ~shrinker ~f:(fun num ->\n match of_mina_string_exn (to_mina_string num) with\n | after_format ->\n if Unsigned.equal after_format num then ()\n else\n Error.(\n raise\n (of_string\n (sprintf\n !\"formatting: num=%{Unsigned} middle=%{String} \\\n after=%{Unsigned}\"\n num (to_mina_string num) after_format ) ))\n | exception e ->\n let err = Error.of_exn e in\n Error.(\n raise\n (tag\n ~tag:(sprintf !\"formatting: num=%{Unsigned}\" num)\n err )) )\n\n let%test_unit \"formatting_trailing_zeros\" =\n let generator = gen_incl Unsigned.zero Unsigned.max_int in\n qc_test_fast generator ~shrinker ~f:(fun num ->\n let formatted = to_mina_string num in\n let has_decimal = String.contains formatted '.' in\n let trailing_zero = String.is_suffix formatted ~suffix:\"0\" in\n if has_decimal && trailing_zero then\n Error.(\n raise\n (of_string\n (sprintf\n !\"formatting: num=%{Unsigned} formatted=%{String}\"\n num (to_mina_string num) ) )) )\n end )\n end\n\n [%%endif]\n end\n\n let currency_length = 64\n\n module Fee = struct\n module T =\n Make\n (Unsigned_extended.UInt64)\n (struct\n let length = currency_length\n end)\n\n include T\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Unsigned_extended.UInt64.Stable.V1.t\n [@@deriving sexp, compare, hash, equal]\n\n [%%define_from_scope to_yojson, of_yojson, dhall_type]\n\n let to_latest = Fn.id\n end\n end]\n\n let (_ : (Signed.t, (t, Sgn.t) Signed_poly.t) Type_equal.t) = Type_equal.T\n\n let minimum_user_command_fee =\n of_mina_string_exn Mina_compile_config.minimum_user_command_fee_string\n\n let default_transaction_fee =\n of_mina_string_exn Mina_compile_config.default_transaction_fee_string\n\n let default_snark_worker_fee =\n of_mina_string_exn Mina_compile_config.default_snark_worker_fee_string\n end\n\n module Amount = struct\n (* See documentation for {!module:Mina_wire_types} *)\n module Make_sig (A : sig\n type t\n end) =\n struct\n module type S = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t = A.t [@@deriving sexp, compare, hash, equal, yojson]\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n end\n end]\n\n [%%ifdef consensus_mechanism]\n\n (* Give a definition to var, it will be hidden at the interface level *)\n include\n Basic\n with type t := Stable.Latest.t\n and type var =\n Pickles.Impls.Step.Impl.Internal_Basic.field\n Snarky_backendless.Cvar.t\n\n [%%else]\n\n include Basic with type t := Stable.Latest.t\n\n [%%endif]\n\n include Arithmetic_intf with type t := t\n\n include Codable.S with type t := t\n\n [%%ifdef consensus_mechanism]\n\n module Signed :\n Signed_intf\n with type magnitude := t\n and type magnitude_var := var\n and type signed_fee := Fee.Signed.t\n and type Checked.signed_fee_var := Fee.Signed.Checked.t\n\n [%%else]\n\n module Signed :\n Signed_intf\n with type magnitude := t\n and type signed_fee := Fee.Signed.t\n\n [%%endif]\n\n (* TODO: Delete these functions *)\n\n val of_fee : Fee.t -> t\n\n val to_fee : t -> Fee.t\n\n val add_fee : t -> Fee.t -> t option\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n include\n Checked_arithmetic_intf\n with type var := var\n and type signed_var := Signed.var\n and type value := t\n\n val add_signed : var -> Signed.var -> var Checked.t\n\n val of_fee : Fee.var -> var\n\n val to_fee : var -> Fee.var\n\n val to_field : var -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> t\n end\n end\n\n [%%endif]\n\n val add_signed_flagged : t -> Signed.t -> t * [ `Overflow of bool ]\n end\n end\n [@@warning \"-32\"]\n\n module Make_str (A : sig\n type t = Unsigned_extended.UInt64.Stable.V1.t\n end) : Make_sig(A).S = struct\n module T =\n Make\n (Unsigned_extended.UInt64)\n (struct\n let length = currency_length\n end)\n\n [%%ifdef consensus_mechanism]\n\n include (\n T :\n module type of T\n with type var = T.var\n and module Signed = T.Signed\n and module Checked := T.Checked )\n\n [%%else]\n\n include (T : module type of T with module Signed = T.Signed)\n\n [%%endif]\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Unsigned_extended.UInt64.Stable.V1.t\n [@@deriving sexp, compare, hash, equal, yojson]\n\n [%%define_from_scope to_yojson, of_yojson, dhall_type]\n\n let to_latest = Fn.id\n end\n end]\n\n let of_fee (fee : Fee.t) : t = fee\n\n let to_fee (fee : t) : Fee.t = fee\n\n let add_fee (t : t) (fee : Fee.t) = add t (of_fee fee)\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n include T.Checked\n\n let of_fee (fee : Fee.var) : var = fee\n\n let to_fee (t : var) : Fee.var = t\n\n let to_field = Fn.id\n\n module Unsafe = struct\n let of_field : Field.Var.t -> var = Fn.id\n end\n end\n\n [%%endif]\n end\n\n include Make_str (struct\n type t = Unsigned_extended.UInt64.Stable.V1.t\n end)\n (*include Wire_types.Make.Amount (Make_sig) (Make_str)*)\n end\n\n module Balance = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Amount.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n\n (* can't be automatically derived *)\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n end\n end]\n\n [%%ifdef consensus_mechanism]\n\n include (Amount : Basic with type t := t with type var = Amount.var)\n\n [%%else]\n\n include (Amount : Basic with type t := t)\n\n [%%endif]\n\n let to_amount = Fn.id\n\n let add_amount = Amount.add\n\n let add_amount_flagged = Amount.add_flagged\n\n let sub_amount = Amount.sub\n\n let sub_amount_flagged = Amount.sub_flagged\n\n let add_signed_amount_flagged = Amount.add_signed_flagged\n\n let ( + ) = add_amount\n\n let ( - ) = sub_amount\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n include Amount.Checked\n\n let to_field = Fn.id\n\n module Unsafe = struct\n let of_field (x : Field.Var.t) : var = x\n end\n\n let to_amount = Fn.id\n\n let add_signed_amount = add_signed\n\n let add_amount = add\n\n let sub_amount = sub\n\n let sub_amount_or_zero = sub_or_zero\n\n let add_amount_flagged = add_flagged\n\n let add_signed_amount_flagged = add_signed_flagged\n\n let sub_amount_flagged = sub_flagged\n\n let ( + ) = add_amount\n\n let ( - ) = sub_amount\n end\n\n [%%endif]\n end\n\n module Fee_rate = struct\n type t = Q.t\n\n let uint64_to_z u64 = Z.of_string @@ Unsigned.UInt64.to_string u64\n\n let uint64_of_z z = Unsigned.UInt64.of_string @@ Z.to_string z\n\n let max_uint64_z = uint64_to_z Unsigned.UInt64.max_int\n\n let fits_uint64 z =\n let open Z in\n leq zero z && leq z max_uint64_z\n\n (** check if a Q.t is in range *)\n let check_q Q.{ num; den } : bool =\n let open Z in\n fits_uint64 num && fits_int32 den\n && if equal zero den then equal zero num else true\n\n let of_q q = if check_q q then Some q else None\n\n let of_q_exn q = Option.value_exn (of_q q)\n\n let to_q = ident\n\n let make fee weight = of_q @@ Q.make (uint64_to_z fee) (Z.of_int weight)\n\n let make_exn fee weight = Option.value_exn (make fee weight)\n\n let to_uint64 Q.{ num; den } =\n if Z.(equal den Z.one) then Some (uint64_of_z num) else None\n\n let to_uint64_exn fr = Option.value_exn (to_uint64 fr)\n\n let add x y = of_q @@ Q.add x y\n\n let add_flagged x y =\n let z = Q.add x y in\n (z, `Overflow (check_q z))\n\n let sub x y = of_q @@ Q.sub x y\n\n let sub_flagged x y =\n let z = Q.sub x y in\n (z, `Underflow (check_q z))\n\n let mul x y = of_q @@ Q.mul x y\n\n let div x y = of_q @@ Q.div x y\n\n let ( + ) = add\n\n let ( - ) = sub\n\n let ( * ) = mul\n\n let scale fr s = fr * Q.of_int s\n\n let scale_exn fr s = Option.value_exn (scale fr s)\n\n let compare = Q.compare\n\n let t_of_sexp sexp =\n let open Ppx_sexp_conv_lib.Conv in\n pair_of_sexp Fee.t_of_sexp int_of_sexp sexp\n |> fun (fee, weight) -> make_exn fee weight\n\n let sexp_of_t Q.{ num = fee; den = weight } =\n let sexp_of_fee fee = Fee.sexp_of_t @@ uint64_of_z fee in\n let sexp_of_weight weight = sexp_of_int @@ Z.to_int weight in\n sexp_of_pair sexp_of_fee sexp_of_weight (fee, weight)\n\n include Comparable.Make (struct\n type nonrec t = t\n\n let compare = compare\n\n let t_of_sexp = t_of_sexp\n\n let sexp_of_t = sexp_of_t\n end)\n end\n\n let%test_module \"sub_flagged module\" =\n ( module struct\n [%%ifdef consensus_mechanism]\n\n open Tick\n\n module type Sub_flagged_S = sig\n type t\n\n type magnitude = t [@@deriving sexp, compare]\n\n type var\n\n (* TODO =\n field Snarky_backendless.Cvar.t Snarky_backendless.Boolean.t list *)\n\n val zero : t\n\n val ( - ) : t -> t -> t option\n\n val typ : (var, t) Typ.t\n\n val gen : t Quickcheck.Generator.t\n\n module Checked : sig\n val sub_flagged :\n var -> var -> (var * [ `Underflow of Boolean.var ]) Tick.Checked.t\n end\n end\n\n let run_test (module M : Sub_flagged_S) =\n let open M in\n let sub_flagged_unchecked (x, y) =\n if compare_magnitude x y < 0 then (zero, true)\n else (Option.value_exn (x - y), false)\n in\n let sub_flagged_checked =\n let f (x, y) =\n Tick.Checked.map (M.Checked.sub_flagged x y)\n ~f:(fun (r, `Underflow u) -> (r, u))\n in\n Test_util.checked_to_unchecked (Typ.tuple2 typ typ)\n (Typ.tuple2 typ Boolean.typ)\n f\n in\n Quickcheck.test ~trials:100 (Quickcheck.Generator.tuple2 gen gen)\n ~f:(fun p ->\n let m, u = sub_flagged_unchecked p in\n let m_checked, u_checked = sub_flagged_checked p in\n assert (Bool.equal u u_checked) ;\n if not u then [%test_eq: M.magnitude] m m_checked )\n\n let%test_unit \"fee sub_flagged\" = run_test (module Fee)\n\n let%test_unit \"amount sub_flagged\" = run_test (module Amount)\n\n [%%endif]\n end )\nend\n\n(** Finally, we use [Make] to create the full module where the types defined\n here and in {!Mina_wire_types} are fully unified. *)\ninclude Wire_types.Make (Make_sig) (Make_str)\n","(*\n RE - A regular expression library\n\n Copyright (C) 2001 Jerome Vouillon\n email: Jerome.Vouillon@pps.jussieu.fr\n\n This library is free software; you can redistribute it and/or\n modify it under the terms of the GNU Lesser General Public\n License as published by the Free Software Foundation, with\n linking exception; either version 2.1 of the License, or (at\n your option) any later version.\n\n This library is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\n Lesser General Public License for more details.\n\n You should have received a copy of the GNU Lesser General Public\n License along with this library; if not, write to the Free Software\n Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA\n*)\n\ntype c = int\ntype t = (c * c) list\n\nlet rec union l l' =\n match l, l' with\n _, [] -> l\n | [], _ -> l'\n | (c1, c2)::r, (c1', c2')::r' ->\n if c2 + 1 < c1' then\n (c1, c2)::union r l'\n else if c2' + 1 < c1 then\n (c1', c2')::union l r'\n else if c2 < c2' then\n union r ((min c1 c1', c2')::r')\n else\n union ((min c1 c1', c2)::r) r'\n\nlet rec inter l l' =\n match l, l' with\n _, [] -> []\n | [], _ -> []\n | (c1, c2)::r, (c1', c2')::r' ->\n if c2 < c1' then\n inter r l'\n else if c2' < c1 then\n inter l r'\n else if c2 < c2' then\n (max c1 c1', c2)::inter r l'\n else\n (max c1 c1', c2')::inter l r'\n\nlet rec diff l l' =\n match l, l' with\n _, [] -> l\n | [], _ -> []\n | (c1, c2)::r, (c1', c2')::r' ->\n if c2 < c1' then\n (c1, c2)::diff r l'\n else if c2' < c1 then\n diff l r'\n else\n let r'' = if c2' < c2 then (c2' + 1, c2) :: r else r in\n if c1 < c1' then\n (c1, c1' - 1)::diff r'' r'\n else\n diff r'' r'\n\nlet single c = [c, c]\n\nlet add c l = union (single c) l\n\nlet seq c c' = if c <= c' then [c, c'] else [c', c]\n\nlet rec offset o l =\n match l with\n [] -> []\n | (c1, c2) :: r -> (c1 + o, c2 + o) :: offset o r\n\nlet empty = []\n\nlet rec mem (c : int) s =\n match s with\n [] -> false\n | (c1, c2) :: rem -> if c <= c2 then c >= c1 else mem c rem\n\n(****)\n\ntype hash = int\n\nlet rec hash_rec = function\n | [] -> 0\n | (i, j)::r -> i + 13 * j + 257 * hash_rec r\nlet hash l = (hash_rec l) land 0x3FFFFFFF\n\n(****)\n\nlet print_one ch (c1, c2) =\n if c1 = c2 then\n Format.fprintf ch \"%d\" c1\n else\n Format.fprintf ch \"%d-%d\" c1 c2\n\nlet pp = Fmt.list print_one\n\nlet rec iter t ~f =\n match t with\n | [] -> ()\n | (x, y)::xs ->\n f x y;\n iter xs ~f\n\nlet one_char = function\n | [i, j] when i = j -> Some i\n | _ -> None\n\n\nmodule CSetMap = Map.Make (struct\n type t = int * (int * int) list\n let compare (i, u) (j, v) =\n let c = compare i j in\n if c <> 0\n then c\n else compare u v\n end)\n\nlet fold_right t ~init ~f = List.fold_right f t init\n\nlet csingle c = single (Char.code c)\n\nlet cany = [0, 255]\n\nlet is_empty = function\n | [] -> true\n | _ -> false\n\nlet rec prepend s x l =\n match s, l with\n | [], _ -> l\n | _r, [] -> []\n | (_c, c') :: r, ([d, _d'], _x') :: _r' when c' < d -> prepend r x l\n | (c, c') :: r, ([d, d'], x') :: r' ->\n if c <= d then begin\n if c' < d'\n then ([d, c'], x @ x') :: prepend r x (([c' + 1, d'], x') :: r')\n else ([d, d'], x @ x') :: prepend s x r'\n end else begin\n if c > d'\n then ([d, d'], x') :: prepend s x r'\n else ([d, c - 1], x') :: prepend s x (([c, d'], x') :: r')\n end\n | _ -> assert false\n\nlet pick = function\n | [] -> invalid_arg \"Re_cset.pick\"\n | (x, _)::_ -> x\n","\nmodule MenhirBasics = struct\n \n exception Error\n \n type token = \n | SUBSCRIPTION\n | STRING of (\n# 8 \"graphql_parser/src/parser.mly\"\n (string)\n# 12 \"graphql_parser/src/parser.ml\"\n )\n | RPAREN\n | RBRACK\n | RBRACE\n | QUERY\n | ON\n | NULL\n | NAME of (\n# 5 \"graphql_parser/src/parser.mly\"\n (string)\n# 23 \"graphql_parser/src/parser.ml\"\n )\n | MUTATION\n | LPAREN\n | LBRACK\n | LBRACE\n | INT of (\n# 6 \"graphql_parser/src/parser.mly\"\n (int)\n# 32 \"graphql_parser/src/parser.ml\"\n )\n | FRAGMENT\n | FLOAT of (\n# 7 \"graphql_parser/src/parser.mly\"\n (float)\n# 38 \"graphql_parser/src/parser.ml\"\n )\n | EQUAL\n | EOF\n | ELLIPSIS\n | DOLLAR\n | COLON\n | BOOL of (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 48 \"graphql_parser/src/parser.ml\"\n )\n | BANG\n | AT\n \nend\n\ninclude MenhirBasics\n\nlet _eRR =\n MenhirBasics.Error\n\ntype _menhir_env = {\n _menhir_lexer: Lexing.lexbuf -> token;\n _menhir_lexbuf: Lexing.lexbuf;\n _menhir_token: token;\n mutable _menhir_error: bool\n}\n\nand _menhir_state = \n | MenhirState133\n | MenhirState125\n | MenhirState124\n | MenhirState119\n | MenhirState114\n | MenhirState108\n | MenhirState102\n | MenhirState100\n | MenhirState99\n | MenhirState96\n | MenhirState90\n | MenhirState89\n | MenhirState87\n | MenhirState86\n | MenhirState84\n | MenhirState81\n | MenhirState80\n | MenhirState79\n | MenhirState78\n | MenhirState71\n | MenhirState70\n | MenhirState67\n | MenhirState66\n | MenhirState65\n | MenhirState64\n | MenhirState63\n | MenhirState61\n | MenhirState59\n | MenhirState57\n | MenhirState55\n | MenhirState51\n | MenhirState44\n | MenhirState38\n | MenhirState34\n | MenhirState31\n | MenhirState29\n | MenhirState28\n | MenhirState24\n | MenhirState22\n | MenhirState21\n | MenhirState20\n | MenhirState19\n | MenhirState13\n | MenhirState12\n | MenhirState4\n | MenhirState0\n\n# 1 \"graphql_parser/src/parser.mly\"\n \nopen Ast\n\n# 119 \"graphql_parser/src/parser.ml\"\n\nlet rec _menhir_goto_nonempty_list_definition_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.document) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState0 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | EOF ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (_1 : (Ast.document))) = _menhir_stack in\n let _v : (Ast.document) = \n# 37 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 137 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.document)) = _v in\n Obj.magic _1\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState133 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.definition))), _, (xs : (Ast.document))) = _menhir_stack in\n let _v : (Ast.document) = \n# 223 \"\"\n ( x :: xs )\n# 156 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_nonempty_list_definition_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_field : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.selection) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.selection)) = _v in\n let _v : (Ast.selection) = \n# 87 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 170 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_selection _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_operation : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.definition) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.definition)) = _v in\n let _v : (Ast.definition) = \n# 41 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 182 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_definition _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_definition : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.definition) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | FRAGMENT ->\n _menhir_run78 _menhir_env (Obj.magic _menhir_stack) MenhirState133\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState133\n | MUTATION ->\n _menhir_run3 _menhir_env (Obj.magic _menhir_stack) MenhirState133\n | QUERY ->\n _menhir_run2 _menhir_env (Obj.magic _menhir_stack) MenhirState133\n | SUBSCRIPTION ->\n _menhir_run1 _menhir_env (Obj.magic _menhir_stack) MenhirState133\n | EOF ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (x : (Ast.definition))) = _menhir_stack in\n let _v : (Ast.document) = \n# 221 \"\"\n ( [ x ] )\n# 209 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_nonempty_list_definition_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState133\n\nand _menhir_goto_loption_selection_set_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.selection list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n match _menhir_s with\n | MenhirState67 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_6 : (Ast.selection list)) = _v in\n let (((((_menhir_stack, _menhir_s, (_1 : (string))), _), _, (_3 : (string))), _, (_4 : ((string * Ast.value) list))), _, (_5 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.selection) = \n# 91 \"graphql_parser/src/parser.mly\"\n (\n Field {\n alias = Some _1;\n name = _3;\n arguments = _4;\n directives = _5;\n selection_set = _6;\n }\n )\n# 236 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_field _menhir_env _menhir_stack _menhir_s _v\n | MenhirState71 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_4 : (Ast.selection list)) = _v in\n let (((_menhir_stack, _menhir_s, (_1 : (string))), _, (_2 : ((string * Ast.value) list))), _, (_3 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.selection) = \n# 101 \"graphql_parser/src/parser.mly\"\n (\n Field {\n alias = None;\n name = _1;\n arguments = _2;\n directives = _3;\n selection_set = _4;\n }\n )\n# 255 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_field _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_nonempty_list_selection_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.selection list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState61 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.selection))), _, (xs : (Ast.selection list))) = _menhir_stack in\n let _v : (Ast.selection list) = \n# 223 \"\"\n ( x :: xs )\n# 272 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_nonempty_list_selection_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState4 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (Ast.selection list))) = _menhir_stack in\n let _v : (Ast.selection list) = \n# 82 \"graphql_parser/src/parser.mly\"\n ( _2 )\n# 288 \"graphql_parser/src/parser.ml\"\n in\n (match _menhir_s with\n | MenhirState55 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_4 : (Ast.selection list)) = _v in\n let (((_menhir_stack, _menhir_s), _, (_2 : (string option))), _, (_3 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.selection) = \n# 125 \"graphql_parser/src/parser.mly\"\n (\n InlineFragment {\n type_condition = _2;\n directives = _3;\n selection_set = _4;\n }\n )\n# 305 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.selection)) = _v in\n let _v : (Ast.selection) = \n# 87 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 313 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_selection _menhir_env _menhir_stack _menhir_s _v\n | MenhirState71 | MenhirState67 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (x : (Ast.selection list)) = _v in\n let _v : (Ast.selection list) = \n# 144 \"\"\n ( x )\n# 323 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_selection_set_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState81 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_5 : (Ast.selection list)) = _v in\n let ((((_menhir_stack, _menhir_s), _, (_2 : (string))), _, (_3 : (string))), _, (_4 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.definition) = \n# 45 \"graphql_parser/src/parser.mly\"\n (\n Fragment {\n name = _2;\n type_condition = _3;\n directives = _4;\n selection_set = _5;\n }\n )\n# 341 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.definition)) = _v in\n let _v : (Ast.definition) = \n# 41 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 349 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_definition _menhir_env _menhir_stack _menhir_s _v\n | MenhirState133 | MenhirState0 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.selection list)) = _v in\n let _v : (Ast.definition) = \n# 56 \"graphql_parser/src/parser.mly\"\n (\n Operation {\n optype = Query;\n name = None;\n variable_definitions = [];\n directives = [];\n selection_set = _1;\n }\n )\n# 367 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_operation _menhir_env _menhir_stack _menhir_s _v\n | MenhirState125 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_5 : (Ast.selection list)) = _v in\n let ((((_menhir_stack, _menhir_s, (_1 : (Ast.optype))), _, (_2 : (string option))), (_3 : (Ast.variable_definition list))), _, (_4 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.definition) = \n# 66 \"graphql_parser/src/parser.mly\"\n (\n Operation {\n optype = _1;\n name = _2;\n variable_definitions = _3;\n directives = _4;\n selection_set = _5;\n }\n )\n# 386 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_operation _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ())\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_list_const_value_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.const_value list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState99 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RBRACK ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (Ast.const_value list))) = _menhir_stack in\n let _v : (Ast.const_value) = \n# 175 \"graphql_parser/src/parser.mly\"\n ( `List _2 )\n# 417 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState114 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.const_value))), _, (xs : (Ast.const_value list))) = _menhir_stack in\n let _v : (Ast.const_value list) = \n# 213 \"\"\n ( x :: xs )\n# 433 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_const_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_list___anonymous_0_const_value__ : _menhir_env -> 'ttv_tail -> _menhir_state -> ((string * Ast.const_value) list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState108 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (((_menhir_stack, _menhir_s, (_1 : (string))), _, (_3 : (Ast.const_value))), _, (xs : ((string * Ast.const_value) list))) = _menhir_stack in\n let _v : ((string * Ast.const_value) list) = let x = \n# 176 \"graphql_parser/src/parser.mly\"\n ( _1, _3 )\n# 450 \"graphql_parser/src/parser.ml\"\n in\n \n# 213 \"\"\n ( x :: xs )\n# 455 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list___anonymous_0_const_value__ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState100 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : ((string * Ast.const_value) list))) = _menhir_stack in\n let _v : (Ast.const_value) = \n# 176 \"graphql_parser/src/parser.mly\"\n ( `Assoc _2 )\n# 471 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_list_value_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.value list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState44 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.value))), _, (xs : (Ast.value list))) = _menhir_stack in\n let _v : (Ast.value list) = \n# 213 \"\"\n ( x :: xs )\n# 494 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_value_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState28 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RBRACK ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (Ast.value list))) = _menhir_stack in\n let _v : (Ast.value) = \n# 175 \"graphql_parser/src/parser.mly\"\n ( `List _2 )\n# 510 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_list___anonymous_0_value__ : _menhir_env -> 'ttv_tail -> _menhir_state -> ((string * Ast.value) list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState38 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (((_menhir_stack, _menhir_s, (_1 : (string))), _, (_3 : (Ast.value))), _, (xs : ((string * Ast.value) list))) = _menhir_stack in\n let _v : ((string * Ast.value) list) = let x = \n# 176 \"graphql_parser/src/parser.mly\"\n ( _1, _3 )\n# 533 \"graphql_parser/src/parser.ml\"\n in\n \n# 213 \"\"\n ( x :: xs )\n# 538 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list___anonymous_0_value__ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState29 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : ((string * Ast.value) list))) = _menhir_stack in\n let _v : (Ast.value) = \n# 176 \"graphql_parser/src/parser.mly\"\n ( `Assoc _2 )\n# 554 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_list_argument_ : _menhir_env -> 'ttv_tail -> _menhir_state -> ((string * Ast.value) list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState22 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RPAREN ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : ((string * Ast.value) list))) = _menhir_stack in\n let _v : ((string * Ast.value) list) = \n# 163 \"graphql_parser/src/parser.mly\"\n ( _2 )\n# 583 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (x : ((string * Ast.value) list)) = _v in\n let _v : ((string * Ast.value) list) = \n# 144 \"\"\n ( x )\n# 591 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_arguments_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState51 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (string * Ast.value))), _, (xs : ((string * Ast.value) list))) = _menhir_stack in\n let _v : ((string * Ast.value) list) = \n# 213 \"\"\n ( x :: xs )\n# 607 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_argument_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_reduce40 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : (Ast.selection list) = \n# 142 \"\"\n ( [] )\n# 618 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_selection_set_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_selection : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.selection) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState61 _v\n | ELLIPSIS ->\n _menhir_run12 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState61 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | RBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (x : (Ast.selection))) = _menhir_stack in\n let _v : (Ast.selection list) = \n# 221 \"\"\n ( [ x ] )\n# 653 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_nonempty_list_selection_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState61\n\nand _menhir_goto_list_variable_definition_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.variable_definition list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState119 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.variable_definition))), _, (xs : (Ast.variable_definition list))) = _menhir_stack in\n let _v : (Ast.variable_definition list) = \n# 213 \"\"\n ( x :: xs )\n# 672 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_variable_definition_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState86 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RPAREN ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _, (_2 : (Ast.variable_definition list))) = _menhir_stack in\n let _v : (Ast.variable_definition list) = \n# 134 \"graphql_parser/src/parser.mly\"\n ( _2 )\n# 688 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (x : (Ast.variable_definition list)) = _v in\n let _v : (Ast.variable_definition list) = \n# 144 \"\"\n ( x )\n# 696 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_variable_definitions_ _menhir_env _menhir_stack _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_reduce30 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : (Ast.const_value list) = \n# 211 \"\"\n ( [] )\n# 713 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_reduce24 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : ((string * Ast.const_value) list) = \n# 211 \"\"\n ( [] )\n# 722 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list___anonymous_0_const_value__ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_option_default_value_ : _menhir_env -> 'ttv_tail -> (Ast.const_value option) -> 'ttv_return =\n fun _menhir_env _menhir_stack _v ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_5 : (Ast.const_value option)) = _v in\n let (((_menhir_stack, _menhir_s), _, (_2 : (string))), _, (_4 : (Ast.typ))) = _menhir_stack in\n let _v : (Ast.variable_definition) = \n# 140 \"graphql_parser/src/parser.mly\"\n (\n {\n name = _2;\n typ = _4;\n default_value = _5;\n }\n )\n# 741 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | DOLLAR ->\n _menhir_run87 _menhir_env (Obj.magic _menhir_stack) MenhirState119\n | RPAREN ->\n _menhir_reduce36 _menhir_env (Obj.magic _menhir_stack) MenhirState119\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState119\n\nand _menhir_run93 : _menhir_env -> 'ttv_tail * _menhir_state * (Ast.typ) -> 'ttv_return =\n fun _menhir_env _menhir_stack ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (_1 : (Ast.typ))) = _menhir_stack in\n let _v : (Ast.typ) = \n# 151 \"graphql_parser/src/parser.mly\"\n ( NonNullType _1 )\n# 765 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_typ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_reduce34 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : (Ast.value list) = \n# 211 \"\"\n ( [] )\n# 774 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_reduce26 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : ((string * Ast.value) list) = \n# 211 \"\"\n ( [] )\n# 783 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list___anonymous_0_value__ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_loption_arguments_ : _menhir_env -> 'ttv_tail -> _menhir_state -> ((string * Ast.value) list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState21 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (((_menhir_stack, _menhir_s), _, (_2 : (string))), _, (_3 : ((string * Ast.value) list))) = _menhir_stack in\n let _v : (Ast.directive) = \n# 155 \"graphql_parser/src/parser.mly\"\n (\n {\n name = _2;\n arguments = _3;\n }\n )\n# 803 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState57\n | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState57\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState57)\n | MenhirState65 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState66\n | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState66\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState66)\n | MenhirState63 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState70\n | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState70\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState70)\n | _ ->\n _menhir_fail ()\n\nand _menhir_reduce28 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : ((string * Ast.value) list) = \n# 211 \"\"\n ( [] )\n# 852 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_argument_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_value_parser_const_value_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.const_value) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.const_value)) = _v in\n let _v : (Ast.const_value) = \n# 183 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 864 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState102 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState108 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState108 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | RBRACE ->\n _menhir_reduce24 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState108)\n | MenhirState114 | MenhirState99 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run105 _menhir_env (Obj.magic _menhir_stack) MenhirState114 _v\n | FLOAT _v ->\n _menhir_run104 _menhir_env (Obj.magic _menhir_stack) MenhirState114 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | INT _v ->\n _menhir_run103 _menhir_env (Obj.magic _menhir_stack) MenhirState114 _v\n | LBRACE ->\n _menhir_run100 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | LBRACK ->\n _menhir_run99 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState114 _v\n | NULL ->\n _menhir_run98 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | STRING _v ->\n _menhir_run97 _menhir_env (Obj.magic _menhir_stack) MenhirState114 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | RBRACK ->\n _menhir_reduce30 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState114)\n | MenhirState96 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _, (_2 : (Ast.const_value))) = _menhir_stack in\n let _v : (Ast.const_value) = \n# 137 \"graphql_parser/src/parser.mly\"\n ( _2 )\n# 937 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (x : (Ast.const_value)) = _v in\n let _v : (Ast.const_value option) = \n# 116 \"\"\n ( Some x )\n# 945 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_default_value_ _menhir_env _menhir_stack _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_value_parser_value_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.value) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.value)) = _v in\n let _v : (Ast.value) = \n# 180 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 959 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_list_directive_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.directive list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState19 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState55\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState55)\n | MenhirState57 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.directive))), _, (xs : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.directive list) = \n# 213 \"\"\n ( x :: xs )\n# 985 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_directive_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState59 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (((_menhir_stack, _menhir_s), _, (_2 : (string))), _, (_3 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.selection) = \n# 113 \"graphql_parser/src/parser.mly\"\n (\n FragmentSpread {\n name = _2;\n directives = _3;\n }\n )\n# 1000 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.selection)) = _v in\n let _v : (Ast.selection) = \n# 87 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 1008 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_selection _menhir_env _menhir_stack _menhir_s _v\n | MenhirState66 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState67\n | BOOL _ | ELLIPSIS | FRAGMENT | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce40 _menhir_env (Obj.magic _menhir_stack) MenhirState67\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState67)\n | MenhirState70 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState71\n | BOOL _ | ELLIPSIS | FRAGMENT | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce40 _menhir_env (Obj.magic _menhir_stack) MenhirState71\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState71)\n | MenhirState80 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState81\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState81)\n | MenhirState124 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState125\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState125)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_loption_variable_definitions_ : _menhir_env -> 'ttv_tail -> (Ast.variable_definition list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _v ->\n let _menhir_stack = (_menhir_stack, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState124\n | LBRACE ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState124\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState124\n\nand _menhir_reduce36 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : (Ast.variable_definition list) = \n# 211 \"\"\n ( [] )\n# 1083 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_variable_definition_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run87 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState87 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState87 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState87\n\nand _menhir_run97 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 8 \"graphql_parser/src/parser.mly\"\n (string)\n# 1117 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 8 \"graphql_parser/src/parser.mly\"\n (string)\n# 1125 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.const_value) = \n# 172 \"graphql_parser/src/parser.mly\"\n ( `String _1 )\n# 1130 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run98 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.const_value) = \n# 169 \"graphql_parser/src/parser.mly\"\n ( `Null )\n# 1141 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run99 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run105 _menhir_env (Obj.magic _menhir_stack) MenhirState99 _v\n | FLOAT _v ->\n _menhir_run104 _menhir_env (Obj.magic _menhir_stack) MenhirState99 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | INT _v ->\n _menhir_run103 _menhir_env (Obj.magic _menhir_stack) MenhirState99 _v\n | LBRACE ->\n _menhir_run100 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | LBRACK ->\n _menhir_run99 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState99 _v\n | NULL ->\n _menhir_run98 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | STRING _v ->\n _menhir_run97 _menhir_env (Obj.magic _menhir_stack) MenhirState99 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | RBRACK ->\n _menhir_reduce30 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState99\n\nand _menhir_run100 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState100 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState100 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | RBRACE ->\n _menhir_reduce24 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState100\n\nand _menhir_run103 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 6 \"graphql_parser/src/parser.mly\"\n (int)\n# 1214 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 6 \"graphql_parser/src/parser.mly\"\n (int)\n# 1222 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.const_value) = \n# 170 \"graphql_parser/src/parser.mly\"\n ( `Int _1 )\n# 1227 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run104 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 7 \"graphql_parser/src/parser.mly\"\n (float)\n# 1234 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 7 \"graphql_parser/src/parser.mly\"\n (float)\n# 1242 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.const_value) = \n# 171 \"graphql_parser/src/parser.mly\"\n ( `Float _1 )\n# 1247 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run105 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 1254 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 1262 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.const_value) = \n# 173 \"graphql_parser/src/parser.mly\"\n ( `Bool _1 )\n# 1267 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_typ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.typ) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState90 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BANG ->\n _menhir_run93 _menhir_env (Obj.magic _menhir_stack)\n | RBRACK ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (Ast.typ))) = _menhir_stack in\n let _v : (Ast.typ) = \n# 150 \"graphql_parser/src/parser.mly\"\n ( ListType _2 )\n# 1290 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_typ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState89 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BANG ->\n _menhir_run93 _menhir_env (Obj.magic _menhir_stack)\n | EQUAL ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run105 _menhir_env (Obj.magic _menhir_stack) MenhirState96 _v\n | FLOAT _v ->\n _menhir_run104 _menhir_env (Obj.magic _menhir_stack) MenhirState96 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | INT _v ->\n _menhir_run103 _menhir_env (Obj.magic _menhir_stack) MenhirState96 _v\n | LBRACE ->\n _menhir_run100 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | LBRACK ->\n _menhir_run99 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState96 _v\n | NULL ->\n _menhir_run98 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | STRING _v ->\n _menhir_run97 _menhir_env (Obj.magic _menhir_stack) MenhirState96 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState96)\n | DOLLAR | RPAREN ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.const_value option) = \n# 114 \"\"\n ( None )\n# 1344 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_default_value_ _menhir_env _menhir_stack _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_run90 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState90 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | LBRACK ->\n _menhir_run90 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState90 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState90\n\nand _menhir_goto_value : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.value) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState31 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState38 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState38 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | RBRACE ->\n _menhir_reduce26 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState38)\n | MenhirState44 | MenhirState28 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run36 _menhir_env (Obj.magic _menhir_stack) MenhirState44 _v\n | DOLLAR ->\n _menhir_run34 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | FLOAT _v ->\n _menhir_run33 _menhir_env (Obj.magic _menhir_stack) MenhirState44 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | INT _v ->\n _menhir_run32 _menhir_env (Obj.magic _menhir_stack) MenhirState44 _v\n | LBRACE ->\n _menhir_run29 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | LBRACK ->\n _menhir_run28 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState44 _v\n | NULL ->\n _menhir_run26 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | STRING _v ->\n _menhir_run25 _menhir_env (Obj.magic _menhir_stack) MenhirState44 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | RBRACK ->\n _menhir_reduce34 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState44)\n | MenhirState24 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (_1 : (string))), _, (_3 : (Ast.value))) = _menhir_stack in\n let _v : (string * Ast.value) = \n# 166 \"graphql_parser/src/parser.mly\"\n ( _1, _3 )\n# 1460 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState51 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState51 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | RPAREN ->\n _menhir_reduce28 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState51)\n | _ ->\n _menhir_fail ()\n\nand _menhir_run25 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 8 \"graphql_parser/src/parser.mly\"\n (string)\n# 1495 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 8 \"graphql_parser/src/parser.mly\"\n (string)\n# 1503 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.value) = \n# 172 \"graphql_parser/src/parser.mly\"\n ( `String _1 )\n# 1508 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run26 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.value) = \n# 169 \"graphql_parser/src/parser.mly\"\n ( `Null )\n# 1519 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run27 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 5 \"graphql_parser/src/parser.mly\"\n (string)\n# 1526 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 5 \"graphql_parser/src/parser.mly\"\n (string)\n# 1534 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (string) = \n# 193 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 1539 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_enum_value _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run28 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run36 _menhir_env (Obj.magic _menhir_stack) MenhirState28 _v\n | DOLLAR ->\n _menhir_run34 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | FLOAT _v ->\n _menhir_run33 _menhir_env (Obj.magic _menhir_stack) MenhirState28 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | INT _v ->\n _menhir_run32 _menhir_env (Obj.magic _menhir_stack) MenhirState28 _v\n | LBRACE ->\n _menhir_run29 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | LBRACK ->\n _menhir_run28 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState28 _v\n | NULL ->\n _menhir_run26 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | STRING _v ->\n _menhir_run25 _menhir_env (Obj.magic _menhir_stack) MenhirState28 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | RBRACK ->\n _menhir_reduce34 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState28\n\nand _menhir_run29 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState29 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState29 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | RBRACE ->\n _menhir_reduce26 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState29\n\nand _menhir_run32 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 6 \"graphql_parser/src/parser.mly\"\n (int)\n# 1614 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 6 \"graphql_parser/src/parser.mly\"\n (int)\n# 1622 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.value) = \n# 170 \"graphql_parser/src/parser.mly\"\n ( `Int _1 )\n# 1627 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run33 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 7 \"graphql_parser/src/parser.mly\"\n (float)\n# 1634 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 7 \"graphql_parser/src/parser.mly\"\n (float)\n# 1642 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.value) = \n# 171 \"graphql_parser/src/parser.mly\"\n ( `Float _1 )\n# 1647 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run34 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState34 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState34 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState34\n\nand _menhir_run36 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 1681 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 1689 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.value) = \n# 173 \"graphql_parser/src/parser.mly\"\n ( `Bool _1 )\n# 1694 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_reduce38 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : ((string * Ast.value) list) = \n# 142 \"\"\n ( [] )\n# 1703 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_arguments_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run22 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState22 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState22 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | RPAREN ->\n _menhir_reduce28 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState22\n\nand _menhir_goto_enum_value : _menhir_env -> 'ttv_tail -> _menhir_state -> (string) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n match _menhir_s with\n | MenhirState24 | MenhirState28 | MenhirState44 | MenhirState31 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (string)) = _v in\n let _v : (Ast.value) = \n# 174 \"graphql_parser/src/parser.mly\"\n ( `Enum _1 )\n# 1746 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState96 | MenhirState114 | MenhirState99 | MenhirState102 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (string)) = _v in\n let _v : (Ast.const_value) = \n# 174 \"graphql_parser/src/parser.mly\"\n ( `Enum _1 )\n# 1756 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_fail : unit -> 'a =\n fun () ->\n Printf.fprintf stderr \"Internal failure -- please contact the parser generator's developers.\\n%!\";\n assert false\n\nand _menhir_reduce32 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : (Ast.directive list) = \n# 211 \"\"\n ( [] )\n# 1772 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_directive_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run20 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState20 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState20 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState20\n\nand _menhir_goto_option_name_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (string option) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | LPAREN ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | DOLLAR ->\n _menhir_run87 _menhir_env (Obj.magic _menhir_stack) MenhirState86\n | RPAREN ->\n _menhir_reduce36 _menhir_env (Obj.magic _menhir_stack) MenhirState86\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState86)\n | AT | LBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.variable_definition list) = \n# 142 \"\"\n ( [] )\n# 1828 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_variable_definitions_ _menhir_env _menhir_stack _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n\nand _menhir_goto_name : _menhir_env -> 'ttv_tail -> _menhir_state -> (string) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState13 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (string))) = _menhir_stack in\n let _v : (string) = \n# 121 \"graphql_parser/src/parser.mly\"\n ( _2 )\n# 1849 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n (match _menhir_s with\n | MenhirState12 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (x : (string))) = _menhir_stack in\n let _v : (string option) = \n# 116 \"\"\n ( Some x )\n# 1860 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_type_condition_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState79 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState80\n | LBRACE ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState80\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState80)\n | _ ->\n _menhir_fail ())\n | MenhirState20 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LPAREN ->\n _menhir_run22 _menhir_env (Obj.magic _menhir_stack) MenhirState21\n | AT | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce38 _menhir_env (Obj.magic _menhir_stack) MenhirState21\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState21)\n | MenhirState51 | MenhirState22 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | COLON ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run36 _menhir_env (Obj.magic _menhir_stack) MenhirState24 _v\n | DOLLAR ->\n _menhir_run34 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | FLOAT _v ->\n _menhir_run33 _menhir_env (Obj.magic _menhir_stack) MenhirState24 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | INT _v ->\n _menhir_run32 _menhir_env (Obj.magic _menhir_stack) MenhirState24 _v\n | LBRACE ->\n _menhir_run29 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | LBRACK ->\n _menhir_run28 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState24 _v\n | NULL ->\n _menhir_run26 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | STRING _v ->\n _menhir_run25 _menhir_env (Obj.magic _menhir_stack) MenhirState24 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState24)\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState38 | MenhirState29 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | COLON ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run36 _menhir_env (Obj.magic _menhir_stack) MenhirState31 _v\n | DOLLAR ->\n _menhir_run34 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | FLOAT _v ->\n _menhir_run33 _menhir_env (Obj.magic _menhir_stack) MenhirState31 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | INT _v ->\n _menhir_run32 _menhir_env (Obj.magic _menhir_stack) MenhirState31 _v\n | LBRACE ->\n _menhir_run29 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | LBRACK ->\n _menhir_run28 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState31 _v\n | NULL ->\n _menhir_run26 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | STRING _v ->\n _menhir_run25 _menhir_env (Obj.magic _menhir_stack) MenhirState31 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState31)\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState34 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (string))) = _menhir_stack in\n let _v : (Ast.value) = \n# 179 \"graphql_parser/src/parser.mly\"\n ( `Variable _2 )\n# 1990 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value _menhir_env _menhir_stack _menhir_s _v\n | MenhirState4 | MenhirState61 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | COLON ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_s = MenhirState63 in\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState64 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState64 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState64)\n | LPAREN ->\n _menhir_run22 _menhir_env (Obj.magic _menhir_stack) MenhirState63\n | AT | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce38 _menhir_env (Obj.magic _menhir_stack) MenhirState63\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState63)\n | MenhirState64 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LPAREN ->\n _menhir_run22 _menhir_env (Obj.magic _menhir_stack) MenhirState65\n | AT | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce38 _menhir_env (Obj.magic _menhir_stack) MenhirState65\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState65)\n | MenhirState87 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | COLON ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState89 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | LBRACK ->\n _menhir_run90 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState89 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState89)\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState89 | MenhirState90 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (_1 : (string))) = _menhir_stack in\n let _v : (Ast.typ) = \n# 149 \"graphql_parser/src/parser.mly\"\n ( NamedType _1 )\n# 2091 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_typ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState108 | MenhirState100 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | COLON ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run105 _menhir_env (Obj.magic _menhir_stack) MenhirState102 _v\n | FLOAT _v ->\n _menhir_run104 _menhir_env (Obj.magic _menhir_stack) MenhirState102 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | INT _v ->\n _menhir_run103 _menhir_env (Obj.magic _menhir_stack) MenhirState102 _v\n | LBRACE ->\n _menhir_run100 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | LBRACK ->\n _menhir_run99 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState102 _v\n | NULL ->\n _menhir_run98 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | STRING _v ->\n _menhir_run97 _menhir_env (Obj.magic _menhir_stack) MenhirState102 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState102)\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState84 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (x : (string))) = _menhir_stack in\n let _v : (string option) = \n# 116 \"\"\n ( Some x )\n# 2145 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_name_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_option_type_condition_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (string option) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState19\n | LBRACE ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState19\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState19\n\nand _menhir_run13 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState13 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState13 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState13\n\nand _menhir_goto_keyword_name : _menhir_env -> 'ttv_tail -> _menhir_state -> (string) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n match _menhir_s with\n | MenhirState84 | MenhirState87 | MenhirState89 | MenhirState100 | MenhirState108 | MenhirState90 | MenhirState78 | MenhirState4 | MenhirState61 | MenhirState64 | MenhirState12 | MenhirState20 | MenhirState51 | MenhirState22 | MenhirState29 | MenhirState38 | MenhirState34 | MenhirState13 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (string)) = _v in\n let _v : (string) = \n# 199 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 2204 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_fragment_name _menhir_env _menhir_stack _menhir_s _v\n | MenhirState96 | MenhirState114 | MenhirState99 | MenhirState102 | MenhirState24 | MenhirState28 | MenhirState44 | MenhirState31 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (string)) = _v in\n let _v : (string) = \n# 193 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 2214 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_enum_value _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_fragment_name : _menhir_env -> 'ttv_tail -> _menhir_state -> (string) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState84 | MenhirState87 | MenhirState89 | MenhirState100 | MenhirState108 | MenhirState90 | MenhirState4 | MenhirState61 | MenhirState64 | MenhirState20 | MenhirState51 | MenhirState22 | MenhirState29 | MenhirState38 | MenhirState34 | MenhirState13 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (_1 : (string))) = _menhir_stack in\n let _v : (string) = \n# 202 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 2231 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_name _menhir_env _menhir_stack _menhir_s _v\n | MenhirState12 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState59\n | BOOL _ | ELLIPSIS | FRAGMENT | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState59\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState59)\n | MenhirState78 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | ON ->\n _menhir_run13 _menhir_env (Obj.magic _menhir_stack) MenhirState79\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState79)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_optype : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.optype) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState84 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState84 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | AT | LBRACE | LPAREN ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_s = MenhirState84 in\n let _v : (string option) = \n# 114 \"\"\n ( None )\n# 2290 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_name_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState84\n\nand _menhir_run7 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 203 \"graphql_parser/src/parser.mly\"\n ( \"on\" )\n# 2305 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run12 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState12 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState12 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | ON ->\n _menhir_run13 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | AT | LBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_s = MenhirState12 in\n let _v : (string option) = \n# 114 \"\"\n ( None )\n# 2337 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_type_condition_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState12\n\nand _menhir_run5 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 188 \"graphql_parser/src/parser.mly\"\n ( \"subscription\" )\n# 2352 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_keyword_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run6 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 186 \"graphql_parser/src/parser.mly\"\n ( \"query\" )\n# 2363 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_keyword_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run8 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 196 \"graphql_parser/src/parser.mly\"\n ( \"null\" )\n# 2374 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_fragment_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run9 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 5 \"graphql_parser/src/parser.mly\"\n (string)\n# 2381 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 5 \"graphql_parser/src/parser.mly\"\n (string)\n# 2389 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (string) = \n# 199 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 2394 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_fragment_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run10 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 187 \"graphql_parser/src/parser.mly\"\n ( \"mutation\" )\n# 2405 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_keyword_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run11 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 189 \"graphql_parser/src/parser.mly\"\n ( \"fragment\" )\n# 2416 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_keyword_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run14 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 2423 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 2431 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (string) = \n# 197 \"graphql_parser/src/parser.mly\"\n ( string_of_bool _1 )\n# 2436 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_fragment_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_errorcase : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n match _menhir_s with\n | MenhirState133 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState125 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState124 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, _), _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState119 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState114 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState108 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState102 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState100 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState99 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState96 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n raise _eRR\n | MenhirState90 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState89 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState87 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState86 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n raise _eRR\n | MenhirState84 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState81 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState80 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState79 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState78 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState71 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState70 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState67 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState66 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState65 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState64 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState63 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState61 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState59 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState57 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState55 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState51 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState44 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState38 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState34 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState31 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState29 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState28 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState24 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState22 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState21 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState20 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState19 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState13 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState12 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState4 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState0 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n raise _eRR\n\nand _menhir_run1 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.optype) = \n# 79 \"graphql_parser/src/parser.mly\"\n ( Subscription )\n# 2632 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_optype _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run2 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.optype) = \n# 77 \"graphql_parser/src/parser.mly\"\n ( Query )\n# 2643 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_optype _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run3 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.optype) = \n# 78 \"graphql_parser/src/parser.mly\"\n ( Mutation )\n# 2654 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_optype _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run4 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState4 _v\n | ELLIPSIS ->\n _menhir_run12 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState4 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState4\n\nand _menhir_run78 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState78 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState78\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState78\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState78 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState78\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState78\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState78\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState78\n\nand _menhir_discard : _menhir_env -> _menhir_env =\n fun _menhir_env ->\n let lexer = _menhir_env._menhir_lexer in\n let lexbuf = _menhir_env._menhir_lexbuf in\n let _tok = lexer lexbuf in\n {\n _menhir_lexer = lexer;\n _menhir_lexbuf = lexbuf;\n _menhir_token = _tok;\n _menhir_error = false;\n }\n\nand doc : (Lexing.lexbuf -> token) -> Lexing.lexbuf -> (Ast.document) =\n fun lexer lexbuf ->\n let _menhir_env = {\n _menhir_lexer = lexer;\n _menhir_lexbuf = lexbuf;\n _menhir_token = Obj.magic ();\n _menhir_error = false;\n } in\n Obj.magic (let _menhir_stack = ((), _menhir_env._menhir_lexbuf.Lexing.lex_curr_p) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | FRAGMENT ->\n _menhir_run78 _menhir_env (Obj.magic _menhir_stack) MenhirState0\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState0\n | MUTATION ->\n _menhir_run3 _menhir_env (Obj.magic _menhir_stack) MenhirState0\n | QUERY ->\n _menhir_run2 _menhir_env (Obj.magic _menhir_stack) MenhirState0\n | SUBSCRIPTION ->\n _menhir_run1 _menhir_env (Obj.magic _menhir_stack) MenhirState0\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState0)\n\n# 269 \"\"\n \n\n# 2754 \"graphql_parser/src/parser.ml\"\n","# 1 \"graphql_parser/src/lexer.mll\"\n \nopen Lexing\nopen Parser\n\nexception Error of string\n\n# 9 \"graphql_parser/src/lexer.ml\"\nlet __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\227\\255\\228\\255\\229\\255\\230\\255\\231\\255\\232\\255\\233\\255\\\n \\234\\255\\235\\255\\001\\000\\237\\255\\238\\255\\239\\255\\240\\255\\078\\000\\\n \\160\\000\\235\\000\\054\\001\\129\\001\\204\\001\\023\\002\\098\\002\\250\\255\\\n \\175\\002\\176\\002\\185\\002\\253\\255\\001\\000\\191\\000\\234\\002\\203\\002\\\n \\231\\002\\241\\002\\007\\003\\017\\003\\027\\003\\039\\003\\049\\003\\059\\003\\\n \\134\\003\\209\\003\\028\\004\\103\\004\\178\\004\\253\\004\\072\\005\\147\\005\\\n \\222\\005\\041\\006\\116\\006\\191\\006\\010\\007\\085\\007\\160\\007\\235\\007\\\n \\054\\008\\129\\008\\204\\008\\023\\009\\098\\009\\173\\009\\248\\009\\067\\010\\\n \\142\\010\\217\\010\\036\\011\\111\\011\\186\\011\\005\\012\\080\\012\\155\\012\\\n \\230\\012\\049\\013\\124\\013\\199\\013\\018\\014\\093\\014\\168\\014\\013\\000\\\n \\236\\255\\025\\015\\026\\015\\006\\015\\255\\255\\247\\255\\248\\255\\249\\255\\\n \\250\\255\\251\\255\\252\\255\\253\\255\\254\\255\";\n Lexing.lex_backtrk =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\027\\000\\255\\255\\255\\255\\255\\255\\255\\255\\014\\000\\\n \\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\255\\255\\\n \\003\\000\\003\\000\\027\\000\\255\\255\\002\\000\\001\\000\\000\\000\\255\\255\\\n \\255\\255\\004\\000\\255\\255\\004\\000\\255\\255\\004\\000\\255\\255\\014\\000\\\n \\014\\000\\014\\000\\014\\000\\006\\000\\014\\000\\014\\000\\014\\000\\014\\000\\\n \\014\\000\\007\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\\n \\008\\000\\014\\000\\014\\000\\009\\000\\010\\000\\014\\000\\014\\000\\014\\000\\\n \\011\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\\n \\014\\000\\014\\000\\014\\000\\012\\000\\014\\000\\014\\000\\013\\000\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\";\n Lexing.lex_default =\n \"\\002\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\029\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\082\\000\\082\\000\\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\030\\000\\027\\000\\027\\000\\000\\000\\028\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\030\\000\\014\\000\\023\\000\\029\\000\\013\\000\\000\\000\\000\\000\\000\\000\\\n \\012\\000\\011\\000\\000\\000\\000\\000\\030\\000\\026\\000\\010\\000\\079\\000\\\n \\025\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\\n \\024\\000\\024\\000\\009\\000\\080\\000\\000\\000\\008\\000\\000\\000\\000\\000\\\n \\007\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\006\\000\\000\\000\\005\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\022\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\021\\000\\020\\000\\019\\000\\\n \\015\\000\\018\\000\\015\\000\\017\\000\\016\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\004\\000\\000\\000\\003\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\255\\255\\000\\000\\000\\000\\255\\255\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\001\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\076\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\065\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\061\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\060\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\057\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\050\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\040\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\039\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\032\\000\\032\\000\\024\\000\\\n \\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\\n \\024\\000\\025\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\\n \\024\\000\\024\\000\\024\\000\\030\\000\\031\\000\\031\\000\\038\\000\\000\\000\\\n \\038\\000\\000\\000\\000\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\\n \\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\030\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\031\\000\\031\\000\\030\\000\\033\\000\\\n \\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\\n \\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\\n \\033\\000\\033\\000\\033\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\036\\000\\000\\000\\036\\000\\000\\000\\034\\000\\035\\000\\\n \\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\\n \\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\\n \\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\\n \\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\000\\000\\034\\000\\037\\000\\\n \\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\\n \\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\\n \\037\\000\\037\\000\\037\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\044\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\041\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\042\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\043\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\045\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\046\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\047\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\048\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\049\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\051\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\052\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\053\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\054\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\055\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\056\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\058\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\059\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\062\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\063\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\064\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\066\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\067\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\015\\000\\015\\000\\068\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\069\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\070\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\071\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\072\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\073\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\074\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\075\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\077\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\078\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\092\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\090\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\084\\000\\255\\255\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\091\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\089\\000\\000\\000\\000\\000\\000\\000\\088\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\087\\000\\083\\000\\255\\255\\000\\000\\\n \\086\\000\\000\\000\\085\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\255\\255\\255\\255\";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\000\\000\\028\\000\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\000\\000\\000\\000\\010\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\079\\000\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\\n \\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\255\\255\\255\\255\\255\\255\\255\\255\\015\\000\\255\\255\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\029\\000\\255\\255\\255\\255\\029\\000\\255\\255\\255\\255\\255\\255\\\n \\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\255\\255\\255\\255\\255\\255\\255\\255\\016\\000\\\n \\000\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\017\\000\\255\\255\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\018\\000\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\255\\255\\255\\255\\255\\255\\255\\255\\018\\000\\255\\255\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\255\\255\\255\\255\\255\\255\\255\\255\\029\\000\\\n \\255\\255\\255\\255\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\019\\000\\255\\255\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\020\\000\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\020\\000\\255\\255\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\021\\000\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\255\\255\\255\\255\\255\\255\\255\\255\\021\\000\\255\\255\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\022\\000\\255\\255\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\024\\000\\025\\000\\024\\000\\\n \\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\\n \\024\\000\\026\\000\\026\\000\\026\\000\\026\\000\\026\\000\\026\\000\\026\\000\\\n \\026\\000\\026\\000\\026\\000\\030\\000\\024\\000\\025\\000\\031\\000\\255\\255\\\n \\031\\000\\255\\255\\255\\255\\031\\000\\031\\000\\031\\000\\031\\000\\031\\000\\\n \\031\\000\\031\\000\\031\\000\\031\\000\\031\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\030\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\024\\000\\025\\000\\030\\000\\032\\000\\\n \\032\\000\\032\\000\\032\\000\\032\\000\\032\\000\\032\\000\\032\\000\\032\\000\\\n \\032\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\\n \\033\\000\\033\\000\\033\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\034\\000\\255\\255\\034\\000\\255\\255\\033\\000\\034\\000\\\n \\034\\000\\034\\000\\034\\000\\034\\000\\034\\000\\034\\000\\034\\000\\034\\000\\\n \\034\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\\n \\035\\000\\035\\000\\035\\000\\036\\000\\036\\000\\036\\000\\036\\000\\036\\000\\\n \\036\\000\\036\\000\\036\\000\\036\\000\\036\\000\\255\\255\\033\\000\\037\\000\\\n \\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\\n \\037\\000\\038\\000\\038\\000\\038\\000\\038\\000\\038\\000\\038\\000\\038\\000\\\n \\038\\000\\038\\000\\038\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\039\\000\\255\\255\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\040\\000\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\255\\255\\255\\255\\255\\255\\255\\255\\040\\000\\255\\255\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\041\\000\\255\\255\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\042\\000\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\042\\000\\255\\255\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\043\\000\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\255\\255\\255\\255\\255\\255\\255\\255\\043\\000\\255\\255\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\044\\000\\255\\255\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\045\\000\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\045\\000\\255\\255\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\255\\255\\255\\255\\255\\255\\255\\255\\046\\000\\\n \\255\\255\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\047\\000\\255\\255\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\048\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\255\\255\\255\\255\\255\\255\\255\\255\\048\\000\\255\\255\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\049\\000\\255\\255\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\050\\000\\255\\255\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\255\\255\\255\\255\\255\\255\\255\\255\\051\\000\\255\\255\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\052\\000\\255\\255\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\053\\000\\255\\255\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\255\\255\\255\\255\\255\\255\\255\\255\\054\\000\\\n \\255\\255\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\055\\000\\255\\255\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\056\\000\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\255\\255\\255\\255\\255\\255\\255\\255\\056\\000\\255\\255\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\057\\000\\255\\255\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\058\\000\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\058\\000\\255\\255\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\059\\000\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\255\\255\\255\\255\\255\\255\\255\\255\\059\\000\\255\\255\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\060\\000\\255\\255\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\061\\000\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\061\\000\\255\\255\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\255\\255\\255\\255\\255\\255\\255\\255\\062\\000\\\n \\255\\255\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\063\\000\\255\\255\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\064\\000\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\255\\255\\255\\255\\255\\255\\255\\255\\064\\000\\255\\255\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\065\\000\\255\\255\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\066\\000\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\066\\000\\255\\255\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\067\\000\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\255\\255\\255\\255\\255\\255\\255\\255\\067\\000\\255\\255\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\068\\000\\255\\255\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\069\\000\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\069\\000\\255\\255\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\255\\255\\255\\255\\255\\255\\255\\255\\070\\000\\\n \\255\\255\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\071\\000\\255\\255\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\072\\000\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\255\\255\\255\\255\\255\\255\\255\\255\\072\\000\\255\\255\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\073\\000\\255\\255\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\074\\000\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\074\\000\\255\\255\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\075\\000\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\255\\255\\255\\255\\255\\255\\255\\255\\075\\000\\255\\255\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\076\\000\\255\\255\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\077\\000\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\077\\000\\255\\255\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\255\\255\\255\\255\\255\\255\\255\\255\\078\\000\\\n \\255\\255\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\081\\000\\082\\000\\255\\255\\081\\000\\082\\000\\\n \\083\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\083\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\081\\000\\082\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\083\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\083\\000\\255\\255\\255\\255\\255\\255\\083\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\083\\000\\081\\000\\082\\000\\255\\255\\\n \\083\\000\\255\\255\\083\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\081\\000\\082\\000\";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec token lexbuf =\n __ocaml_lex_token_rec lexbuf 0\nand __ocaml_lex_token_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n# 21 \"graphql_parser/src/lexer.mll\"\n ( token lexbuf )\n# 1105 \"graphql_parser/src/lexer.ml\"\n\n | 1 ->\n# 22 \"graphql_parser/src/lexer.mll\"\n ( token lexbuf )\n# 1110 \"graphql_parser/src/lexer.ml\"\n\n | 2 ->\n# 23 \"graphql_parser/src/lexer.mll\"\n ( new_line lexbuf; token lexbuf )\n# 1115 \"graphql_parser/src/lexer.ml\"\n\n | 3 ->\n# 25 \"graphql_parser/src/lexer.mll\"\n ( INT (int_of_string (lexeme lexbuf)) )\n# 1120 \"graphql_parser/src/lexer.ml\"\n\n | 4 ->\n# 26 \"graphql_parser/src/lexer.mll\"\n ( FLOAT (float_of_string (lexeme lexbuf)) )\n# 1125 \"graphql_parser/src/lexer.ml\"\n\n | 5 ->\n# 27 \"graphql_parser/src/lexer.mll\"\n ( read_string (Buffer.create 17) lexbuf )\n# 1130 \"graphql_parser/src/lexer.ml\"\n\n | 6 ->\n# 29 \"graphql_parser/src/lexer.mll\"\n ( BOOL false )\n# 1135 \"graphql_parser/src/lexer.ml\"\n\n | 7 ->\n# 30 \"graphql_parser/src/lexer.mll\"\n ( FRAGMENT )\n# 1140 \"graphql_parser/src/lexer.ml\"\n\n | 8 ->\n# 31 \"graphql_parser/src/lexer.mll\"\n ( MUTATION )\n# 1145 \"graphql_parser/src/lexer.ml\"\n\n | 9 ->\n# 32 \"graphql_parser/src/lexer.mll\"\n ( NULL )\n# 1150 \"graphql_parser/src/lexer.ml\"\n\n | 10 ->\n# 33 \"graphql_parser/src/lexer.mll\"\n ( ON )\n# 1155 \"graphql_parser/src/lexer.ml\"\n\n | 11 ->\n# 34 \"graphql_parser/src/lexer.mll\"\n ( QUERY )\n# 1160 \"graphql_parser/src/lexer.ml\"\n\n | 12 ->\n# 35 \"graphql_parser/src/lexer.mll\"\n ( SUBSCRIPTION )\n# 1165 \"graphql_parser/src/lexer.ml\"\n\n | 13 ->\n# 36 \"graphql_parser/src/lexer.mll\"\n ( BOOL true )\n# 1170 \"graphql_parser/src/lexer.ml\"\n\n | 14 ->\n# 37 \"graphql_parser/src/lexer.mll\"\n ( NAME (lexeme lexbuf) )\n# 1175 \"graphql_parser/src/lexer.ml\"\n\n | 15 ->\n# 39 \"graphql_parser/src/lexer.mll\"\n ( BANG )\n# 1180 \"graphql_parser/src/lexer.ml\"\n\n | 16 ->\n# 40 \"graphql_parser/src/lexer.mll\"\n ( DOLLAR )\n# 1185 \"graphql_parser/src/lexer.ml\"\n\n | 17 ->\n# 41 \"graphql_parser/src/lexer.mll\"\n ( LPAREN )\n# 1190 \"graphql_parser/src/lexer.ml\"\n\n | 18 ->\n# 42 \"graphql_parser/src/lexer.mll\"\n ( RPAREN )\n# 1195 \"graphql_parser/src/lexer.ml\"\n\n | 19 ->\n# 43 \"graphql_parser/src/lexer.mll\"\n ( ELLIPSIS )\n# 1200 \"graphql_parser/src/lexer.ml\"\n\n | 20 ->\n# 44 \"graphql_parser/src/lexer.mll\"\n ( COLON )\n# 1205 \"graphql_parser/src/lexer.ml\"\n\n | 21 ->\n# 45 \"graphql_parser/src/lexer.mll\"\n ( EQUAL )\n# 1210 \"graphql_parser/src/lexer.ml\"\n\n | 22 ->\n# 46 \"graphql_parser/src/lexer.mll\"\n ( AT )\n# 1215 \"graphql_parser/src/lexer.ml\"\n\n | 23 ->\n# 47 \"graphql_parser/src/lexer.mll\"\n ( LBRACK )\n# 1220 \"graphql_parser/src/lexer.ml\"\n\n | 24 ->\n# 48 \"graphql_parser/src/lexer.mll\"\n ( RBRACK )\n# 1225 \"graphql_parser/src/lexer.ml\"\n\n | 25 ->\n# 49 \"graphql_parser/src/lexer.mll\"\n ( LBRACE )\n# 1230 \"graphql_parser/src/lexer.ml\"\n\n | 26 ->\n# 50 \"graphql_parser/src/lexer.mll\"\n ( RBRACE )\n# 1235 \"graphql_parser/src/lexer.ml\"\n\n | 27 ->\n# 51 \"graphql_parser/src/lexer.mll\"\n ( raise (Error (\"Unexpected char: \" ^ Lexing.lexeme lexbuf)) )\n# 1240 \"graphql_parser/src/lexer.ml\"\n\n | 28 ->\n# 52 \"graphql_parser/src/lexer.mll\"\n ( EOF )\n# 1245 \"graphql_parser/src/lexer.ml\"\n\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_token_rec lexbuf __ocaml_lex_state\n\nand read_string buf lexbuf =\n __ocaml_lex_read_string_rec buf lexbuf 81\nand __ocaml_lex_read_string_rec buf lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n# 55 \"graphql_parser/src/lexer.mll\"\n ( STRING (Buffer.contents buf) )\n# 1257 \"graphql_parser/src/lexer.ml\"\n\n | 1 ->\n# 56 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\"'; read_string buf lexbuf )\n# 1262 \"graphql_parser/src/lexer.ml\"\n\n | 2 ->\n# 57 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\\\'; read_string buf lexbuf )\n# 1267 \"graphql_parser/src/lexer.ml\"\n\n | 3 ->\n# 58 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '/'; read_string buf lexbuf )\n# 1272 \"graphql_parser/src/lexer.ml\"\n\n | 4 ->\n# 59 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\b'; read_string buf lexbuf )\n# 1277 \"graphql_parser/src/lexer.ml\"\n\n | 5 ->\n# 60 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\012'; read_string buf lexbuf )\n# 1282 \"graphql_parser/src/lexer.ml\"\n\n | 6 ->\n# 61 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\n'; read_string buf lexbuf )\n# 1287 \"graphql_parser/src/lexer.ml\"\n\n | 7 ->\n# 62 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\r'; read_string buf lexbuf )\n# 1292 \"graphql_parser/src/lexer.ml\"\n\n | 8 ->\n# 63 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\t'; read_string buf lexbuf )\n# 1297 \"graphql_parser/src/lexer.ml\"\n\n | 9 ->\n# 65 \"graphql_parser/src/lexer.mll\"\n (\n Buffer.add_string buf (lexeme lexbuf);\n read_string buf lexbuf\n )\n# 1305 \"graphql_parser/src/lexer.ml\"\n\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_string_rec buf lexbuf __ocaml_lex_state\n\n;;\n\n","(* Helper modules *)\nmodule List = struct\n include List\n let assoc_exn = assoc\n let assoc x ys = try Some (assoc_exn x ys) with Not_found -> None\n\n let find_exn = find\n let find cond xs = try Some (find_exn cond xs) with Not_found -> None\n\n module Result = struct\n let rec join ?(memo=[]) = function\n | [] -> Ok (List.rev memo)\n | (Error _ as err)::_ -> err\n | (Ok x)::xs -> join ~memo:(x::memo) xs\n\n let all f xs =\n List.map f xs |> join\n end\nend\n\nmodule Option = struct\n let map x ~f = match x with None -> None | Some y -> Some (f y)\nend\n\n(* IO *)\nmodule type IO = sig\n type +'a t\n\n val return : 'a -> 'a t\n val bind : 'a t -> ('a -> 'b t) -> 'b t\n\n module Stream : sig\n type +'a io\n type 'a t\n\n val map : 'a t -> ('a -> 'b io) -> 'b t\n val iter : 'a t -> ('a -> unit io) -> unit io\n val close : 'a t -> unit\n end with type 'a io := 'a t\nend\n\n(* Field_error *)\nmodule type Field_error = sig\n type t\n val message_of_field_error : t -> string\n val extensions_of_field_error : t -> (string * Yojson.Basic.json [@warning \"-3\"]) list option\nend\n\n(* Schema *)\nmodule Make (Io : IO) (Field_error: Field_error) = struct\n module Io = struct\n include Io\n\n let map x ~f = bind x (fun x' -> return (f x'))\n let ok x = Io.return (Ok x)\n let error x = Io.return (Error x)\n\n let rec all = function\n | [] -> Io.return []\n | x::xs ->\n bind (all xs) (fun xs' ->\n map x ~f:(fun x' -> x'::xs')\n )\n\n module Result = struct\n let bind x f = bind x (function Ok x' -> f x' | Error _ as err -> Io.return err)\n let map_error x ~f = map x ~f:(function Ok _ as ok -> ok | Error err -> Error (f err))\n let map x ~f = map x ~f:(function Ok x' -> Ok (f x') | Error _ as err -> err)\n end\n\n let rec map_s ?(memo=[]) f = function\n | [] -> Io.return (List.rev memo)\n | x::xs ->\n bind (f x) (fun x' -> map_s ~memo:(x'::memo) f xs)\n\n let map_p f xs = List.map f xs |> all\n\n module Infix = struct\n let (>>|) x f = map x ~f\n let (>>=?) = Result.bind\n end\n end\n\n module StringMap = struct\n include Map.Make(String)\n exception Missing_key of string\n let find_exn key t = try find key t with Not_found -> raise (Missing_key key)\n let find k t = try Some (find_exn k t) with Missing_key _ -> None\n end\n\n module StringSet = Set.Make(String)\n\n type field_error = Field_error.t\n\n type variable_map = Graphql_parser.const_value StringMap.t\n\n type deprecated =\n | NotDeprecated\n | Deprecated of string option\n\n type 'a enum_value = {\n name : string;\n doc : string option;\n deprecated : deprecated;\n value : 'a;\n }\n\n type json = Yojson.Basic.json [@warning \"-3\"]\n\n let enum_value ?doc ?(deprecated=NotDeprecated) name ~value =\n { name; doc; deprecated; value; }\n\n let id : 'a. 'a -> 'a = fun x -> x\n\n module Arg = struct\n open Rresult\n\n type _ arg_typ =\n | Scalar : {\n name : string;\n doc : string option;\n coerce : Graphql_parser.const_value -> ('a, string) result;\n } -> 'a option arg_typ\n | Object : {\n name : string;\n doc : string option;\n fields : ('a, 'b) arg_list;\n coerce : 'b;\n } -> 'a option arg_typ\n | Enum : {\n name : string;\n doc : string option;\n values : 'a enum_value list;\n } -> 'a option arg_typ\n | List : 'a arg_typ -> 'a list option arg_typ\n | NonNullable : 'a option arg_typ -> 'a arg_typ\n and _ arg =\n | Arg : {\n name : string;\n doc : string option;\n typ : 'a arg_typ;\n } -> 'a arg\n | DefaultArg : {\n name : string;\n doc : string option;\n typ : 'a option arg_typ;\n default : 'a;\n } -> 'a arg\n and (_, _) arg_list =\n | [] : ('a, 'a) arg_list\n | (::) : 'a arg * ('b, 'c) arg_list -> ('b, 'a -> 'c) arg_list\n\n let arg ?doc name ~typ =\n Arg { name; doc; typ }\n\n let arg' ?doc name ~typ ~default =\n DefaultArg { name; doc; typ; default }\n\n let scalar ?doc name ~coerce =\n Scalar { name; doc; coerce }\n\n let enum ?doc name ~values =\n Enum { name; doc; values }\n\n let obj ?doc name ~fields ~coerce =\n Object { name; doc; fields; coerce }\n\n let rec string_of_const_value : Graphql_parser.const_value -> string = function\n | `Null -> \"null\"\n | `Int i -> string_of_int i\n | `Float f -> string_of_float f\n | `String s -> Printf.sprintf \"\\\"%s\\\"\" s\n | `Bool b -> string_of_bool b\n | `Enum e -> e\n | `List l ->\n let values = List.map (fun i -> string_of_const_value i) l in\n Printf.sprintf \"[%s]\" (String.concat \", \" values)\n | `Assoc a ->\n let values =\n List.map\n (fun (k, v) ->\n Printf.sprintf \"%s: %s\" k (string_of_const_value v) )\n a\n in\n Printf.sprintf \"{%s}\" (String.concat \", \" values)\n\n let rec string_of_arg_typ : type a. a arg_typ -> string = function\n | Scalar a -> a.name\n | Object a -> a.name\n | Enum a -> a.name\n | List a -> Printf.sprintf \"[%s]\" (string_of_arg_typ a)\n | NonNullable a -> Printf.sprintf \"%s!\" (string_of_arg_typ a)\n\n let eval_arg_error ?(field_type=\"field\") ~field_name ~arg_name arg_typ value =\n let found_str =\n match value with\n | Some v -> Printf.sprintf \"found %s\" (string_of_const_value v)\n | None -> \"but not provided\"\n in\n Printf.sprintf \"Argument `%s` of type `%s` expected on %s `%s`, %s.\"\n arg_name\n (string_of_arg_typ arg_typ)\n field_type\n field_name\n found_str\n\n (* Built-in argument types *)\n let int = Scalar {\n name = \"Int\";\n doc = None;\n coerce = function\n | `Int n -> Ok n\n | _ -> Error \"Invalid int\"\n }\n\n let string = Scalar {\n name = \"String\";\n doc = None;\n coerce = function\n | `String s -> Ok s\n | _ -> Error \"Invalid string\"\n }\n\n let float = Scalar {\n name = \"Float\";\n doc = None;\n coerce = function\n | `Float f -> Ok f\n | `Int n -> Ok (float_of_int n)\n | _ -> Error \"Invalid float\"\n }\n\n let bool = Scalar {\n name = \"Boolean\";\n doc = None;\n coerce = function\n | `Bool b -> Ok b\n | _ -> Error \"Invalid boolean\"\n }\n\n let guid = Scalar {\n name = \"ID\";\n doc = None;\n coerce = function\n | `String s -> Ok s\n | `Int n -> Ok (string_of_int n)\n | _ -> Error \"Invalid ID\"\n }\n\n let non_null typ = NonNullable typ\n let list typ = List typ\n\n let rec value_to_const_value variable_map = function\n | `Null -> `Null\n | `Int _ as i -> i\n | `Float _ as f -> f\n | `String _ as s -> s\n | `Bool _ as b -> b\n | `Enum _ as e -> e\n | `Variable v -> StringMap.find_exn v variable_map\n | `List xs -> `List (List.map (value_to_const_value variable_map) xs)\n | `Assoc props ->\n let props' = List.map (fun (name, value) -> name, value_to_const_value variable_map value) props in\n `Assoc props'\n\n let rec eval_arglist\n : type a b. variable_map\n -> ?field_type:string\n -> field_name:string\n -> (a, b) arg_list\n -> (string * Graphql_parser.value) list\n -> b\n -> (a, string) result =\n fun variable_map ?field_type ~field_name arglist key_values f ->\n match arglist with\n | [] -> Ok f\n | (DefaultArg arg)::arglist' ->\n let arglist'' = (Arg { name = arg.name; doc = arg.doc; typ = arg.typ })::arglist' in\n eval_arglist variable_map ?field_type ~field_name arglist'' key_values (function\n | None -> f arg.default\n | Some value -> f value\n )\n | (Arg arg)::arglist' ->\n try\n let value = List.assoc arg.name key_values in\n let const_value = Option.map value ~f:(value_to_const_value variable_map) in\n eval_arg variable_map ?field_type ~field_name ~arg_name:arg.name arg.typ const_value >>= fun coerced ->\n eval_arglist variable_map ?field_type ~field_name arglist' key_values (f coerced)\n with StringMap.Missing_key key -> Error (Format.sprintf \"Missing variable `%s`\" key)\n\n and eval_arg\n : type a. variable_map\n -> ?field_type:string\n -> field_name:string\n -> arg_name:string\n -> a arg_typ\n -> Graphql_parser.const_value option\n -> (a, string) result =\n fun variable_map ?field_type ~field_name ~arg_name typ value ->\n match (typ, value) with\n | NonNullable _, None -> Error (eval_arg_error ?field_type ~field_name ~arg_name typ value)\n | NonNullable _, Some `Null -> Error (eval_arg_error ?field_type ~field_name ~arg_name typ value)\n | Scalar _, None -> Ok None\n | Scalar _, Some `Null -> Ok None\n | Object _, None -> Ok None\n | Object _, Some `Null -> Ok None\n | List _, None -> Ok None\n | List _, Some `Null -> Ok None\n | Enum _, None -> Ok None\n | Enum _, Some `Null -> Ok None\n | Scalar s, Some value ->\n begin match (s.coerce value) with\n | Ok coerced -> Ok (Some coerced)\n | Error _ -> Error (eval_arg_error ?field_type ~field_name ~arg_name typ (Some value))\n end\n | Object o, Some value ->\n begin match value with\n | `Assoc props ->\n let props' = (props :> (string * Graphql_parser.value) list) in\n eval_arglist variable_map ?field_type ~field_name o.fields props' o.coerce >>| fun coerced ->\n Some coerced\n | _ -> Error (eval_arg_error ?field_type ~field_name ~arg_name typ (Some value))\n end\n | List typ, Some value ->\n begin match value with\n | `List values ->\n let option_values = List.map (fun x -> Some x) values in\n List.Result.all (eval_arg variable_map ?field_type ~field_name ~arg_name typ) option_values >>| fun coerced ->\n Some coerced\n | value -> eval_arg variable_map ?field_type ~field_name ~arg_name typ (Some value) >>| fun coerced ->\n (Some [coerced] : a)\n end\n | NonNullable typ, value ->\n eval_arg variable_map ?field_type ~field_name ~arg_name typ value >>= (function\n | Some value -> Ok value\n | None -> Error (eval_arg_error ?field_type ~field_name ~arg_name typ None))\n | Enum e, Some value ->\n begin match value with\n | `Enum v\n | `String v ->\n begin match List.find (fun enum_value -> enum_value.name = v) e.values with\n | Some enum_value -> Ok (Some enum_value.value)\n | None -> Error (Printf.sprintf \"Invalid enum value for argument `%s` on field `%s`\" arg_name field_name)\n end\n | _ -> Error (Printf.sprintf \"Expected enum for argument `%s` on field `%s`\" arg_name field_name)\n end\n end\n\n (* Schema data types *)\n type 'a scalar = {\n name : string;\n doc : string option;\n coerce : 'a -> json;\n }\n\n type 'a enum = {\n name : string;\n doc : string option;\n values : 'a enum_value list;\n }\n\n type fragment_map = Graphql_parser.fragment StringMap.t\n type 'ctx resolve_info = {\n ctx : 'ctx;\n field : Graphql_parser.field;\n fragments : fragment_map;\n variables : variable_map;\n }\n\n type ('ctx, 'src) obj = {\n name : string;\n doc : string option;\n fields : ('ctx, 'src) field list Lazy.t;\n abstracts : abstract list ref;\n }\n and (_, _) field =\n Field : {\n name : string;\n doc : string option;\n deprecated : deprecated;\n typ : ('ctx, 'out) typ;\n args : ('a, 'args) Arg.arg_list;\n resolve : 'ctx resolve_info -> 'src -> 'args;\n lift : 'a -> ('out, field_error) result Io.t;\n } -> ('ctx, 'src) field\n and (_, _) typ =\n | Object : ('ctx, 'src) obj -> ('ctx, 'src option) typ\n | List : ('ctx, 'src) typ -> ('ctx, 'src list option) typ\n | NonNullable : ('ctx, 'src option) typ -> ('ctx, 'src) typ\n | Scalar : 'src scalar -> ('ctx, 'src option) typ\n | Enum : 'src enum -> ('ctx, 'src option) typ\n | Abstract : abstract -> ('ctx, ('ctx, 'a) abstract_value option) typ\n and any_typ =\n | AnyTyp : (_, _) typ -> any_typ\n | AnyArgTyp : _ Arg.arg_typ -> any_typ\n and abstract = {\n name : string;\n doc : string option;\n kind : [`Union | `Interface of abstract_field list Lazy.t];\n mutable types : any_typ list;\n }\n and abstract_field =\n AbstractField : (_, _) field -> abstract_field\n and ('ctx, 'a) abstract_value =\n AbstractValue : ('ctx, 'src option) typ * 'src -> ('ctx, 'a) abstract_value\n\n type 'ctx subscription_field =\n SubscriptionField : {\n name : string;\n doc : string option;\n deprecated : deprecated;\n typ : ('ctx, 'out) typ;\n args : (('out Io.Stream.t, field_error) result Io.t, 'args) Arg.arg_list;\n resolve : 'ctx resolve_info -> 'args;\n } -> 'ctx subscription_field\n\n type 'ctx subscription_obj = {\n name : string;\n doc : string option;\n fields : 'ctx subscription_field list;\n }\n\n type ('ctx, 'a) abstract_typ = ('ctx, ('ctx, 'a) abstract_value option) typ\n\n type directive_location = [\n | `Query\n | `Mutation\n | `Subscription\n | `Field\n | `Fragment_definition\n | `Fragment_spread\n | `Inline_fragment\n | `Variable_definition\n ]\n\n type directive =\n Directive : {\n name : string;\n doc : string option;\n locations : directive_location list;\n args : ([ `Skip | `Include ], 'args) Arg.arg_list;\n resolve : 'args;\n } -> directive\n\n type 'ctx schema = {\n query : ('ctx, unit) obj;\n mutation : ('ctx, unit) obj option;\n subscription : 'ctx subscription_obj option;\n }\n\n let schema ?(mutation_name=\"mutation\")\n ?mutations\n ?(subscription_name=\"subscription\")\n ?subscriptions\n ?(query_name=\"query\")\n fields = {\n query = {\n name = query_name;\n doc = None;\n abstracts = ref [];\n fields = lazy fields;\n };\n mutation = Option.map mutations ~f:(fun fields ->\n {\n name = mutation_name;\n doc = None;\n abstracts = ref [];\n fields = lazy fields;\n }\n );\n subscription = Option.map subscriptions ~f:(fun fields ->\n {\n name = subscription_name;\n doc = None;\n fields;\n }\n )\n }\n\n (* Constructor functions *)\n let obj ?doc name ~fields =\n let rec o = Object { name; doc; fields = lazy (fields o); abstracts = ref []} in\n o\n\n let field ?doc ?(deprecated=NotDeprecated) name ~typ ~args ~resolve =\n Field { name; doc; deprecated; typ; args; resolve; lift = Io.ok }\n\n let io_field ?doc ?(deprecated=NotDeprecated) name ~typ ~args ~resolve =\n Field { name; doc; deprecated; typ; args; resolve; lift = id }\n\n let abstract_field ?doc ?(deprecated=NotDeprecated) name ~typ ~args =\n AbstractField (Field { lift = Io.ok; name; doc; deprecated; typ; args; resolve = Obj.magic () })\n\n let subscription_field ?doc ?(deprecated=NotDeprecated) name ~typ ~args ~resolve =\n SubscriptionField { name; doc; deprecated; typ; args; resolve }\n\n let enum ?doc name ~values =\n Enum { name; doc; values }\n\n let scalar ?doc name ~coerce =\n Scalar { name; doc; coerce }\n\n let list typ =\n List typ\n\n let non_null typ =\n NonNullable typ\n\n let union ?doc name =\n Abstract { name; doc; types = []; kind = `Union }\n\n let interface ?doc name ~fields =\n let rec i = Abstract { name; doc; types = []; kind = `Interface (lazy (fields i)) } in\n i\n\n let add_type abstract_typ typ =\n match (abstract_typ, typ) with\n | Abstract a, Object o ->\n (* TODO add subtype check here *)\n a.types <- (AnyTyp typ)::a.types;\n o.abstracts := a :: !(o.abstracts);\n fun src -> AbstractValue (typ, src)\n | _ ->\n invalid_arg \"Arguments must be Interface/Union and Object\"\n\n let obj_of_subscription_obj {name; doc; fields} =\n let fields = List.map\n (fun (SubscriptionField {name; doc; deprecated; typ; args; resolve}) ->\n Field { lift = Obj.magic (); name; doc; deprecated; typ; args; resolve = (fun ctx () -> resolve ctx) })\n fields\n in\n { name; doc; abstracts = ref []; fields = lazy fields }\n\n (* Built-in scalars *)\n let int : 'ctx. ('ctx, int option) typ = Scalar {\n name = \"Int\";\n doc = None;\n coerce = fun i -> `Int i;\n }\n\n let string : 'ctx. ('ctx, string option) typ = Scalar {\n name = \"String\";\n doc = None;\n coerce = fun s ->`String s;\n }\n\n let bool : 'ctx. ('ctx, bool option) typ = Scalar {\n name = \"Boolean\";\n doc = None;\n coerce = fun b -> `Bool b;\n }\n\n let float : 'ctx. ('ctx, float option) typ = Scalar {\n name = \"Float\";\n doc = None;\n coerce = fun f -> `Float f;\n }\n\n let guid : 'ctx. ('ctx, string option) typ = Scalar {\n name = \"ID\";\n doc = None;\n coerce = fun x -> `String x;\n }\n\n (* Mandatory directives: skip and include *)\n let skip_directive = Directive {\n name = \"skip\";\n doc = Some \"Directs the executor to skip this field or fragment when the `if` argument is true.\";\n locations = [`Field; `Fragment_spread; `Inline_fragment];\n args = Arg.[\n arg \"if\" ~doc:\"Skipped when true.\" ~typ:(non_null bool)\n ];\n resolve = function\n | true -> `Skip\n | false -> `Include\n }\n\n let include_directive = Directive {\n name = \"include\";\n doc = Some \"Directs the executor to include this field or fragment only when the `if` argument is true.\";\n locations = [`Field; `Fragment_spread; `Inline_fragment];\n args = Arg.[\n arg \"if\" ~doc:\"Included when true.\" ~typ:(non_null bool)\n ];\n resolve = function\n | true -> `Include\n | false -> `Skip\n }\n\nmodule Introspection = struct\n (* any_typ, any_field and any_arg hide type parameters to avoid scope escaping errors *)\n type any_field =\n | AnyField : (_, _) field -> any_field\n | AnyArgField : _ Arg.arg -> any_field\n type any_arg = AnyArg : _ Arg.arg -> any_arg\n type any_enum_value = AnyEnumValue : _ enum_value -> any_enum_value\n\n let unless_visited (result, visited) name f =\n if StringSet.mem name visited then\n result, visited\n else\n f (result, visited)\n\n (* Extracts all types contained in a single type *)\n let rec types : type ctx src. ?memo:(any_typ list * StringSet.t) -> (ctx, src) typ -> (any_typ list * StringSet.t) = fun ?(memo=([], StringSet.empty)) typ ->\n match typ with\n | List typ -> types ~memo typ\n | NonNullable typ -> types ~memo typ\n | Scalar s as scalar ->\n unless_visited memo s.name (fun (result, visited) ->\n (AnyTyp scalar)::result, StringSet.add s.name visited\n )\n | Enum e as enum ->\n unless_visited memo e.name (fun (result, visited) ->\n (AnyTyp enum)::result, StringSet.add e.name visited\n )\n | Object o as obj ->\n unless_visited memo o.name (fun (result, visited) ->\n let result' = (AnyTyp obj)::result in\n let visited' = StringSet.add o.name visited in\n let reducer = fun memo (Field f) ->\n let memo' = types ~memo f.typ in\n arg_list_types memo' f.args\n in\n List.fold_left reducer (result', visited') (Lazy.force o.fields)\n )\n | Abstract a as abstract ->\n unless_visited memo a.name (fun (result, visited) ->\n let result' = (AnyTyp abstract)::result in\n let visited' = StringSet.add a.name visited in\n List.fold_left (fun memo typ -> match typ with\n | AnyTyp typ -> types ~memo typ\n | AnyArgTyp _ -> failwith \"Abstracts can't have argument types\")\n (result', visited') a.types\n )\n\n and arg_types : type a. (any_typ list * StringSet.t) -> a Arg.arg_typ -> (any_typ list * StringSet.t) = fun memo argtyp ->\n match argtyp with\n | Arg.List typ -> arg_types memo typ\n | Arg.NonNullable typ -> arg_types memo typ\n | Arg.Scalar s as scalar ->\n unless_visited memo s.name (fun (result, visited) ->\n (AnyArgTyp scalar)::result, StringSet.add s.name visited\n )\n | Arg.Enum e as enum ->\n unless_visited memo e.name (fun (result, visited) ->\n (AnyArgTyp enum)::result, StringSet.add e.name visited\n )\n | Arg.Object o as obj ->\n unless_visited memo o.name (fun (result, visited) ->\n let memo' = (AnyArgTyp obj)::result, StringSet.add o.name visited in\n arg_list_types memo' o.fields\n )\n and arg_list_types : type a b. (any_typ list * StringSet.t) -> (a, b) Arg.arg_list -> (any_typ list * StringSet.t) = fun memo arglist ->\n let open Arg in\n match arglist with\n | [] -> memo\n | arg::args ->\n let memo' = match arg with\n | Arg a -> arg_types memo a.typ\n | DefaultArg a -> arg_types memo a.typ\n in arg_list_types memo' args\n\n let types_of_schema s =\n let types, _ =\n List.fold_left\n (fun memo op ->\n match op with\n | None -> memo\n | Some op -> types ~memo (Object op))\n ([], StringSet.empty)\n [Some s.query; s.mutation; Option.map s.subscription ~f:obj_of_subscription_obj]\n in\n types\n\n let rec args_to_list : type a b. ?memo:any_arg list -> (a, b) Arg.arg_list -> any_arg list = fun ?memo:(memo=[]) arglist ->\n let open Arg in\n match arglist with\n | [] ->\n memo\n | arg::args ->\n let memo' = List.cons (AnyArg arg) memo in\n args_to_list ~memo:memo' args\n\n let no_abstracts = ref []\n\n let __type_kind = Enum {\n name = \"__TypeKind\";\n doc = None;\n values = [\n {\n name=\"SCALAR\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Scalar;\n };\n {\n name=\"OBJECT\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Object;\n };\n {\n name=\"INTERFACE\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Interface;\n };\n {\n name=\"UNION\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Union;\n };\n {\n name=\"ENUM\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Enum;\n };\n {\n name=\"INPUT_OBJECT\";\n doc=None;\n deprecated=NotDeprecated;\n value=`InputObject;\n };\n {\n name=\"LIST\";\n doc=None;\n deprecated=NotDeprecated;\n value=`List;\n };\n {\n name=\"NON_NULL\";\n doc=None;\n deprecated=NotDeprecated;\n value=`NonNull;\n };\n ]\n }\n\n let __enum_value : 'ctx. ('ctx, any_enum_value option) typ = Object {\n name = \"__EnumValue\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"name\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyEnumValue enum_value) -> enum_value.name;\n };\n Field {\n name = \"description\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyEnumValue enum_value) -> enum_value.doc;\n };\n Field {\n name = \"isDeprecated\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable bool;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyEnumValue enum_value) -> enum_value.deprecated <> NotDeprecated;\n };\n Field {\n name = \"deprecationReason\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyEnumValue enum_value) ->\n match enum_value.deprecated with\n | Deprecated reason -> reason\n | NotDeprecated -> None\n }\n ]\n }\n\n let rec __input_value : 'ctx. ('ctx, any_arg option) typ = Object {\n name = \"__InputValue\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"name\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyArg arg) -> match arg with\n | Arg.DefaultArg a -> a.name\n | Arg.Arg a -> a.name\n };\n Field {\n name = \"description\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyArg arg) -> match arg with\n | Arg.DefaultArg a -> a.doc\n | Arg.Arg a -> a.doc\n };\n Field {\n name = \"type\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyArg arg) -> match arg with\n | Arg.DefaultArg a -> AnyArgTyp a.typ\n | Arg.Arg a -> AnyArgTyp a.typ\n };\n Field {\n name = \"defaultValue\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyArg _) -> None\n }\n ]\n }\n\n and __type : 'ctx . ('ctx, any_typ option) typ = Object {\n name = \"__Type\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"kind\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable __type_kind;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Object _) -> `Object\n | AnyTyp (Abstract { kind = `Union; _ }) -> `Union\n | AnyTyp (Abstract { kind = `Interface _; _ }) -> `Interface\n | AnyTyp (List _) -> `List\n | AnyTyp (Scalar _) -> `Scalar\n | AnyTyp (Enum _) -> `Enum\n | AnyTyp (NonNullable _) -> `NonNull\n | AnyArgTyp (Arg.Object _) -> `InputObject\n | AnyArgTyp (Arg.List _) -> `List\n | AnyArgTyp (Arg.Scalar _) -> `Scalar\n | AnyArgTyp (Arg.Enum _) -> `Enum\n | AnyArgTyp (Arg.NonNullable _) -> `NonNull\n };\n Field {\n name = \"name\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Object o) -> Some o.name\n | AnyTyp (Scalar s) -> Some s.name\n | AnyTyp (Enum e) -> Some e.name\n | AnyTyp (Abstract a) -> Some a.name\n | AnyArgTyp (Arg.Object o) -> Some o.name\n | AnyArgTyp (Arg.Scalar s) -> Some s.name\n | AnyArgTyp (Arg.Enum e) -> Some e.name\n | _ -> None;\n };\n Field {\n name = \"description\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Object o) -> o.doc\n | AnyTyp (Scalar s) -> s.doc\n | AnyTyp (Enum e) -> e.doc\n | AnyTyp (Abstract a) -> a.doc\n | AnyArgTyp (Arg.Object o) -> o.doc\n | AnyArgTyp (Arg.Scalar s) -> s.doc\n | AnyArgTyp (Arg.Enum e) -> e.doc\n | _ -> None\n };\n Field {\n name = \"fields\";\n doc = None;\n deprecated = NotDeprecated;\n typ = List (NonNullable __field);\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Object o) ->\n Some (List.map (fun f -> AnyField f) (Lazy.force o.fields))\n | AnyTyp (Abstract { kind = `Interface fields; _ }) ->\n Some (List.map (fun (AbstractField f) -> AnyField f) (Lazy.force fields))\n | AnyArgTyp (Arg.Object o) ->\n let arg_list = args_to_list o.fields in\n Some (List.map (fun (AnyArg f) -> AnyArgField f) arg_list)\n | _ -> None\n };\n Field {\n name = \"interfaces\";\n doc = None;\n deprecated = NotDeprecated;\n typ = List (NonNullable __type);\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Object o) ->\n let interfaces = List.filter (function | { kind = `Interface _; _} -> true | _ -> false) !(o.abstracts) in\n Some (List.map (fun i -> AnyTyp (Abstract i)) interfaces)\n | _ -> None\n };\n Field {\n name = \"possibleTypes\";\n doc = None;\n deprecated = NotDeprecated;\n typ = List (NonNullable __type);\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Abstract a) ->\n Some a.types\n | _ -> None\n };\n Field {\n name = \"ofType\";\n doc = None;\n deprecated = NotDeprecated;\n typ = __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (NonNullable typ) -> Some (AnyTyp typ)\n | AnyTyp (List typ) -> Some (AnyTyp typ)\n | AnyArgTyp (Arg.NonNullable typ) -> Some (AnyArgTyp typ)\n | AnyArgTyp (Arg.List typ) -> Some (AnyArgTyp typ)\n | _ -> None\n };\n Field {\n name = \"inputFields\";\n doc = None;\n deprecated = NotDeprecated;\n typ = List (NonNullable __input_value);\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyArgTyp (Arg.Object o) ->\n Some (args_to_list o.fields)\n | _ -> None\n };\n Field {\n name = \"enumValues\";\n doc = None;\n deprecated = NotDeprecated;\n typ = List (NonNullable __enum_value);\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Enum e) -> Some (List.map (fun x -> AnyEnumValue x) e.values)\n | AnyArgTyp (Arg.Enum e) -> Some (List.map (fun x -> AnyEnumValue x) e.values)\n | _ -> None\n }\n ]\n }\n\n and __field : 'ctx. ('ctx, any_field option) typ = Object {\n name = \"__Field\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"name\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field f) -> f.name\n | AnyArgField (Arg.Arg a) -> a.name\n | AnyArgField (Arg.DefaultArg a) -> a.name\n };\n Field {\n name = \"description\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field f) -> f.doc\n | AnyArgField (Arg.Arg a) -> a.doc\n | AnyArgField (Arg.DefaultArg a) -> a.doc\n };\n Field {\n name = \"args\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable (List (NonNullable __input_value));\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field f) -> args_to_list f.args\n | AnyArgField _ -> []\n };\n Field {\n name = \"type\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field f) -> AnyTyp f.typ\n | AnyArgField (Arg.Arg a) -> AnyArgTyp a.typ\n | AnyArgField (Arg.DefaultArg a) -> AnyArgTyp a.typ\n };\n Field {\n name = \"isDeprecated\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable bool;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field { deprecated = Deprecated _; _ }) -> true\n | _ -> false\n };\n Field {\n name = \"deprecationReason\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field { deprecated = Deprecated reason; _ }) -> reason\n | _ -> None\n }\n ]\n }\n\n let __directive_location = Enum {\n name = \"__DirectiveLocation\";\n doc = None;\n values = [\n {\n name=\"QUERY\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Query;\n };\n {\n name=\"MUTATION\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Mutation;\n };\n {\n name=\"SUBSCRIPTION\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Subscription;\n };\n {\n name=\"FIELD\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Field;\n };\n {\n name=\"FRAGMENT_DEFINITION\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Fragment_definition;\n };\n {\n name=\"FRAGMENT_SPREAD\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Fragment_spread;\n };\n {\n name=\"INLINE_FRAGMENT\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Inline_fragment;\n };\n {\n name=\"VARIABLE_DEFINITION\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Variable_definition;\n };\n ]\n }\n\n let __directive = Object {\n name = \"__Directive\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"name\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (Directive d) -> d.name\n };\n Field {\n name = \"description\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (Directive d) -> d.doc\n };\n Field {\n name = \"locations\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable (List (NonNullable __directive_location));\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (Directive d) -> d.locations\n };\n Field {\n name = \"args\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable (List (NonNullable __input_value));\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (Directive d) -> args_to_list d.args\n }\n ]\n }\n\n let __schema : 'ctx. ('ctx, ('ctx schema * any_typ list) option) typ = Object {\n name = \"__Schema\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"types\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable (List (NonNullable __type));\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (_schema, types) -> types\n };\n Field {\n name = \"queryType\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (schema, _types) -> AnyTyp (Object schema.query)\n };\n Field {\n name = \"mutationType\";\n doc = None;\n deprecated = NotDeprecated;\n typ = __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (schema, _types) -> Option.map schema.mutation ~f:(fun mut -> AnyTyp (Object mut))\n };\n Field {\n name = \"subscriptionType\";\n doc = None;\n deprecated = NotDeprecated;\n typ = __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (schema, _types) ->\n Option.map schema.subscription ~f:(fun subs -> AnyTyp (Object (obj_of_subscription_obj subs)))\n };\n Field {\n name = \"directives\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable (List (NonNullable __directive));\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ _ -> []\n }\n ]\n }\n\n let add_built_in_fields schema =\n let types = types_of_schema schema in\n let schema_field = Field {\n name = \"__schema\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable __schema;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ _ -> (schema, types)\n } in\n let type_field = Field {\n name = \"__type\";\n doc = None;\n deprecated = NotDeprecated;\n typ = __type;\n args = Arg.[arg \"name\" ~typ:(non_null string)];\n lift = Io.ok;\n resolve = fun _ _ name ->\n List.find (fun typ ->\n match typ with\n | AnyTyp (Object o) -> o.name = name\n | AnyTyp (Scalar s) -> s.name = name\n | AnyTyp (Enum e) -> e.name = name\n | AnyTyp (Abstract a) -> a.name = name\n | AnyTyp (List _) -> false\n | AnyTyp (NonNullable _) -> false\n | AnyArgTyp (Arg.Object o) -> o.name = name\n | AnyArgTyp (Arg.Scalar s) -> s.name = name\n | AnyArgTyp (Arg.Enum e) -> e.name = name\n | AnyArgTyp (Arg.List _) -> false\n | AnyArgTyp (Arg.NonNullable _) -> false\n ) types\n } in\n let fields = lazy (schema_field::type_field::(Lazy.force schema.query.fields)) in\n { schema with query = { schema.query with fields } }\nend\n\n (* Execution *)\n type variables = (string * Graphql_parser.const_value) list\n type execution_order = Serial | Parallel\n type 'ctx execution_context = {\n variables : variable_map;\n fragments : fragment_map;\n ctx : 'ctx;\n }\n\n type path = [`String of string | `Int of int] list\n type error = field_error * path\n\n type resolve_error = [\n | `Resolve_error of error\n | `Argument_error of string\n | `Validation_error of string\n ]\n\n type execute_error = [\n resolve_error\n | `Mutations_not_configured\n | `Subscriptions_not_configured\n | `No_operation_found\n | `Operation_name_required\n | `Operation_not_found\n ]\n\n type 'a response = ('a, json) result\n\n let matches_type_condition type_condition (obj : ('ctx, 'src) obj) =\n obj.name = type_condition ||\n List.exists (fun (abstract : abstract) -> abstract.name = type_condition) !(obj.abstracts)\n\n let rec should_include_field ctx (directives : Graphql_parser.directive list) =\n match directives with\n | [] -> Ok true\n | { name = \"skip\"; arguments }::rest ->\n eval_directive ctx skip_directive arguments rest\n | { name = \"include\"; arguments }::rest ->\n eval_directive ctx include_directive arguments rest\n | { name; _ }::_ ->\n let err = Format.sprintf \"Unknown directive: %s\" name in\n Error err\n\n and eval_directive ctx (Directive { name; args; resolve; _ }) arguments rest =\n let open Rresult in\n Arg.eval_arglist ctx.variables ~field_type:\"directive\" ~field_name:name args arguments resolve >>= function\n | `Skip -> Ok false\n | `Include -> should_include_field ctx rest\n\n let alias_or_name : Graphql_parser.field -> string = fun field ->\n match field.alias with\n | Some alias -> alias\n | None -> field.name\n\n let rec merge_selections ?(memo=[]) = function\n | [] -> List.rev memo\n | field::fields ->\n let id = alias_or_name field in\n let matching, rest = List.partition (fun field' -> id = (alias_or_name field')) fields in\n let selection_sets = List.map (fun (field : Graphql_parser.field) -> field.selection_set) (field::matching) in\n let selection_set = List.concat selection_sets in\n merge_selections ~memo:({field with selection_set}::memo) rest\n\n let rec collect_fields : 'ctx execution_context -> ('ctx, 'src) obj -> Graphql_parser.selection list -> (Graphql_parser.field list, string) result =\n fun ctx obj fields ->\n let open Rresult in\n List.map (function\n | Graphql_parser.Field field ->\n should_include_field ctx field.directives >>| fun include_field ->\n if include_field then [field] else []\n | Graphql_parser.FragmentSpread spread ->\n begin match StringMap.find spread.name ctx.fragments with\n | Some { directives; type_condition; selection_set; _ }\n when matches_type_condition type_condition obj ->\n should_include_field ctx directives >>= fun include_field ->\n if include_field then\n collect_fields ctx obj selection_set\n else Ok []\n | _ -> Ok []\n end\n | Graphql_parser.InlineFragment fragment ->\n let matches_type_condition = match fragment.type_condition with\n | None -> true\n | Some condition -> matches_type_condition condition obj\n in\n if matches_type_condition then\n should_include_field ctx fragment.directives >>= fun include_field ->\n if include_field then\n collect_fields ctx obj fragment.selection_set\n else Ok []\n else\n Ok []\n ) fields\n |> List.Result.join\n |> Rresult.R.map List.concat\n |> Rresult.R.map merge_selections\n\n let field_from_object : ('ctx, 'src) obj -> string -> ('ctx, 'src) field option = fun obj field_name ->\n List.find (fun (Field field) -> field.name = field_name) (Lazy.force obj.fields)\n\n let field_from_subscription_object = fun obj field_name ->\n List.find (fun (SubscriptionField field) -> field.name = field_name) obj.fields\n\n let coerce_or_null : 'a option -> ('a -> (json * error list, 'b) result Io.t) -> (json * error list, 'b) result Io.t =\n fun src f ->\n match src with\n | None -> Io.ok (`Null, [])\n | Some src' -> f src'\n\n let map_fields_with_order = function\n | Serial -> Io.map_s ~memo:[]\n | Parallel -> Io.map_p\n\n let error_to_json ?path ?extensions msg =\n let props = match path with\n | Some path -> [\"path\", `List (List.rev path :> json list)]\n | None -> []\n in\n let extension_props = match extensions with\n | None\n | Some [] -> []\n | Some extensions -> [\"extensions\", `Assoc extensions]\n in\n (`Assoc ((\"message\", `String msg)::(List.append props extension_props)) : json)\n\n let error_response ?data ?path ?extensions msg =\n let errors = \"errors\", `List [\n error_to_json ?path ?extensions msg\n ]\n in\n let data = match data with\n | None -> []\n | Some data -> [\"data\", data]\n in\n `Assoc (errors :: data)\n\n let rec present : type ctx src. ctx execution_context -> src -> Graphql_parser.field -> (ctx, src) typ -> path -> (json * error list, [> resolve_error]) result Io.t =\n fun ctx src query_field typ path ->\n match typ with\n | Scalar s -> coerce_or_null src (fun x -> Io.ok (s.coerce x, []))\n | List t ->\n coerce_or_null src (fun src' ->\n List.mapi (fun i x -> present ctx x query_field t ((`Int i)::path)) src'\n |> Io.all\n |> Io.map ~f:List.Result.join\n |> Io.Result.map ~f:(fun xs -> (`List (List.map fst xs), List.map snd xs |> List.concat))\n )\n | NonNullable t -> present ctx (Some src) query_field t path\n | Object o ->\n coerce_or_null src (fun src' ->\n match collect_fields ctx o query_field.selection_set with\n | Ok fields -> resolve_fields ctx src' o fields path\n | Error e -> Io.error (`Argument_error e))\n | Enum e ->\n coerce_or_null src (fun src' ->\n match List.find (fun enum_value -> src' == enum_value.value) e.values with\n | Some enum_value -> Io.ok (`String enum_value.name, [])\n | None -> Io.ok (`Null, [])\n )\n | Abstract _ ->\n coerce_or_null src (fun (AbstractValue (typ', src')) ->\n present ctx (Some src') query_field typ' path\n )\n\n and resolve_field : type ctx src. ctx execution_context -> src -> Graphql_parser.field -> (ctx, src) field -> path -> ((string * json) * error list, [> resolve_error]) result Io.t =\n fun ctx src query_field (Field field) path ->\n let open Io.Infix in\n let name = alias_or_name query_field in\n let path' = (`String name)::path in\n let resolve_info = {\n ctx = ctx.ctx;\n field = query_field;\n fragments = ctx.fragments;\n variables = ctx.variables;\n } in\n let resolver = field.resolve resolve_info src in\n match Arg.eval_arglist ctx.variables ~field_name:field.name field.args query_field.arguments resolver with\n | Ok unlifted_value ->\n let lifted_value =\n field.lift unlifted_value\n |> Io.Result.map_error ~f:(fun err -> `Resolve_error (err, path')) >>=? fun resolved ->\n present ctx resolved query_field field.typ path'\n in\n lifted_value >>| (function\n | Ok (value, errors) ->\n Ok ((name, value), errors)\n | Error (`Argument_error _)\n | Error (`Validation_error _) as error ->\n error\n | Error (`Resolve_error err) as error ->\n match field.typ with\n | NonNullable _ ->\n error\n | _ ->\n Ok ((name, `Null), [err])\n )\n | Error err ->\n Io.error (`Argument_error err)\n\n and resolve_fields : type ctx src. ctx execution_context -> ?execution_order:execution_order -> src -> (ctx, src) obj -> Graphql_parser.field list -> path -> (json * error list, [> resolve_error]) result Io.t =\n fun ctx ?execution_order:(execution_order=Parallel) src obj fields path ->\n map_fields_with_order execution_order (fun (query_field : Graphql_parser.field) ->\n let name = alias_or_name query_field in\n if query_field.name = \"__typename\" then\n Io.ok ((name, `String obj.name), [])\n else\n match field_from_object obj query_field.name with\n | Some field ->\n resolve_field ctx src query_field field path\n | None ->\n let err = Printf.sprintf \"Field '%s' is not defined on type '%s'\" query_field.name obj.name in\n Io.error (`Validation_error err)\n ) fields\n |> Io.map ~f:List.Result.join\n |> Io.Result.map ~f:(fun xs -> (`Assoc (List.map fst xs), List.map snd xs |> List.concat))\n\n let data_to_json = function\n | data, [] -> `Assoc [\"data\", data]\n | data, errors ->\n let errors = List.map\n (fun (field_error, path) ->\n let extensions = Field_error.extensions_of_field_error field_error in\n let msg = Field_error.message_of_field_error field_error in\n error_to_json ~path ?extensions msg)\n errors\n in\n `Assoc [\n \"errors\", `List errors;\n \"data\", data;\n ]\n\n let to_response = function\n | Ok _ as res -> res\n | Error `No_operation_found ->\n Error (error_response \"No operation found\")\n | Error `Operation_not_found ->\n Error (error_response \"Operation not found\")\n | Error `Operation_name_required ->\n Error (error_response \"Operation name required\")\n | Error `Subscriptions_not_configured ->\n Error (error_response \"Subscriptions not configured\")\n | Error `Mutations_not_configured ->\n Error (error_response \"Mutations not configured\")\n | Error (`Validation_error msg) ->\n Error (error_response msg)\n | Error (`Argument_error msg) ->\n Error (error_response ~data:`Null msg)\n | Error (`Resolve_error (field_error, path)) ->\n let extensions = Field_error.extensions_of_field_error field_error in\n let msg = Field_error.message_of_field_error field_error in\n Error (error_response ~data:`Null ~path ?extensions msg)\n\n let subscribe : type ctx. ctx execution_context -> ctx subscription_field -> Graphql_parser.field -> (json response Io.Stream.t, [> resolve_error]) result Io.t\n =\n fun ctx (SubscriptionField subs_field) field ->\n let open Io.Infix in\n let name = alias_or_name field in\n let path = [`String name] in\n let resolve_info = {\n ctx = ctx.ctx;\n field;\n fragments = ctx.fragments;\n variables = ctx.variables\n } in\n let resolver = subs_field.resolve resolve_info in\n match Arg.eval_arglist ctx.variables ~field_name:subs_field.name subs_field.args field.arguments resolver with\n | Ok result ->\n result\n |> Io.Result.map ~f:(fun source_stream ->\n Io.Stream.map source_stream (fun value ->\n present ctx value field subs_field.typ path\n |> Io.Result.map ~f:(fun (data, errors) ->\n data_to_json (`Assoc [name, data], errors)\n )\n >>| to_response\n )\n )\n |> Io.Result.map_error ~f:(fun err ->\n `Resolve_error (err, path)\n )\n | Error err -> Io.error (`Argument_error err)\n\n let execute_operation : 'ctx schema -> 'ctx execution_context -> Graphql_parser.operation -> ([ `Response of json | `Stream of json response Io.Stream.t], [> execute_error]) result Io.t =\n fun schema ctx operation ->\n let open Io.Infix in\n match operation.optype with\n | Graphql_parser.Query ->\n let query = schema.query in\n Io.return (collect_fields ctx query operation.selection_set)\n |> Io.Result.map_error ~f:(fun e -> `Argument_error e) >>=? fun fields ->\n (resolve_fields ctx () query fields [] : (json * error list, resolve_error) result Io.t :> (json * error list, [> execute_error]) result Io.t)\n |> Io.Result.map ~f:(fun data_errs -> `Response (data_to_json data_errs))\n | Graphql_parser.Mutation ->\n begin match schema.mutation with\n | None -> Io.error `Mutations_not_configured\n | Some mut ->\n Io.return (collect_fields ctx mut operation.selection_set)\n |> Io.Result.map_error ~f:(fun e -> `Argument_error e) >>=? fun fields ->\n (resolve_fields ~execution_order:Serial ctx () mut fields [] : (json * error list, resolve_error) result Io.t :> (json * error list, [> execute_error]) result Io.t)\n |> Io.Result.map ~f:(fun data_errs -> `Response (data_to_json data_errs))\n end\n | Graphql_parser.Subscription ->\n begin match schema.subscription with\n | None -> Io.error `Subscriptions_not_configured\n | Some subs ->\n Io.return (collect_fields ctx (obj_of_subscription_obj subs) operation.selection_set)\n |> Io.Result.map_error ~f:(fun e -> `Argument_error e) >>=? fun fields ->\n begin match fields with\n | [field] ->\n (match field_from_subscription_object subs field.name with\n | Some subscription_field ->\n (subscribe ctx subscription_field field : ((json, json) result Io.Stream.t, resolve_error) result Io.t :> ((json, json) result Io.Stream.t, [> execute_error]) result Io.t)\n |> Io.Result.map ~f:(fun stream -> `Stream stream)\n | None -> Io.ok (`Response (`Assoc [(alias_or_name field, `Null)])))\n (* see http://facebook.github.io/graphql/June2018/#sec-Response-root-field *)\n | _ -> Io.error (`Validation_error \"Subscriptions only allow exactly one selection for the operation.\")\n end\n end\n\n let collect_fragments doc =\n List.fold_left (fun memo -> function\n | Graphql_parser.Operation _ -> memo\n | Graphql_parser.Fragment f -> StringMap.add f.name f memo\n ) StringMap.empty doc\n\n exception FragmentCycle of string list\n let rec validate_fragments fragment_map =\n try\n StringMap.iter (fun name _ ->\n validate_fragment fragment_map StringSet.empty name\n ) fragment_map;\n Ok fragment_map\n with FragmentCycle fragment_names ->\n let cycle = String.concat \", \" fragment_names in\n let err = Format.sprintf \"Fragment cycle detected: %s\" cycle in\n Error (`Validation_error err)\n\n and validate_fragment (fragment_map : fragment_map) visited name =\n match StringMap.find name fragment_map with\n | None -> ()\n | Some fragment when StringSet.mem fragment.name visited ->\n raise (FragmentCycle (StringSet.elements visited))\n | Some fragment ->\n let visited' = StringSet.add fragment.name visited in\n List.iter (validate_fragment_selection fragment_map visited') fragment.selection_set\n\n and validate_fragment_selection fragment_map visited selection =\n match selection with\n | Graphql_parser.Field field ->\n List.iter (validate_fragment_selection fragment_map visited) field.selection_set\n | InlineFragment inline_fragment ->\n List.iter (validate_fragment_selection fragment_map visited) inline_fragment.selection_set\n | FragmentSpread fragment_spread ->\n validate_fragment fragment_map visited fragment_spread.name\n\n let collect_and_validate_fragments doc =\n let fragments = collect_fragments doc in\n validate_fragments fragments\n\n let collect_operations doc =\n List.fold_left (fun memo -> function\n | Graphql_parser.Operation op -> op::memo\n | Graphql_parser.Fragment _ -> memo\n ) [] doc\n\n let select_operation ?operation_name doc =\n let operations = collect_operations doc in\n match operation_name, operations with\n | _, [] -> Error `No_operation_found\n | None, [op] -> Ok op\n | None, _::_ -> Error `Operation_name_required\n | Some name, ops ->\n try\n Ok (List.find_exn (fun op -> op.Graphql_parser.name = Some name) ops)\n with Not_found ->\n Error `Operation_not_found\n\n let execute schema ctx ?variables:(variables=[]) ?operation_name doc =\n let open Io.Infix in\n let execute' schema ctx doc =\n Io.return (collect_and_validate_fragments doc) >>=? fun fragments ->\n let schema' = Introspection.add_built_in_fields schema in\n Io.return (select_operation ?operation_name doc) >>=? fun op ->\n let default_variables = List.fold_left (fun memo { Graphql_parser.name; default_value; _ } ->\n match default_value with\n | None -> memo\n | Some value -> StringMap.add name value memo\n ) StringMap.empty op.variable_definitions in\n let variables = List.fold_left (fun memo (name, value) -> StringMap.add name value memo) default_variables variables in\n let execution_ctx = { fragments; ctx; variables } in\n execute_operation schema' execution_ctx op\n in\n execute' schema ctx doc >>| to_response\nend\n","open Core_kernel\n\nmodule Annotations = struct\n module Utils = struct\n let find xs key =\n List.find ~f:(fun (k', _) -> String.equal key k') xs |> Option.map ~f:snd\n\n let find_string xs key =\n find xs key |> Option.join |> Option.map ~f:(fun s -> String.strip s)\n\n let find_bool xs key =\n find xs key\n |> Option.map ~f:(fun _ -> true)\n |> Option.value ~default:false\n end\n\n module Top = struct\n (** Top comment *)\n type t = { name : string; doc : string option }\n [@@deriving annot, sexp, compare, equal]\n\n open Utils\n\n let of_annots ~name t_toplevel_annots =\n let xs = t_toplevel_annots () in\n { name; doc = find_string xs \"ocaml.doc\" }\n\n let%test_unit \"top annots parse\" =\n let t = of_annots ~name:\"Top\" t_toplevel_annots in\n [%test_eq: t] t { name = \"Top\"; doc = Some \"Top comment\" }\n end\n\n module Fields = struct\n module T = struct\n type t =\n { name : string option\n ; doc : string option [@name \"document\"]\n ; skip : bool [@skip]\n ; deprecated : string option [@depr \"foo\"] (** this is deprecated *)\n }\n [@@deriving annot, sexp, compare, equal]\n end\n\n type t = string -> T.t\n\n open Utils\n\n let of_annots t_fields_annots field =\n let xs = t_fields_annots field in\n let s = find_string xs in\n let b = find_bool xs in\n { T.name = s \"name\"\n ; doc = s \"ocaml.doc\"\n ; skip = b \"skip\"\n ; deprecated = s \"depr\"\n }\n\n let%test_unit \"field annots parse\" =\n let annots = of_annots T.t_fields_annots in\n [%test_eq: T.t] (annots \"doc\")\n { name = Some \"document\"; doc = None; skip = false; deprecated = None } ;\n [%test_eq: T.t] (annots \"skip\")\n { name = None; doc = None; skip = true; deprecated = None } ;\n [%test_eq: T.t] (annots \"deprecated\")\n { name = None\n ; doc = Some \"this is deprecated\"\n ; skip = false\n ; deprecated = Some \"foo\"\n }\n end\nend\n\n(** Rewrites underscore_case to camelCase. Note: Keeps leading underscores. *)\nlet under_to_camel s =\n (* take all the underscores *)\n let prefix_us =\n String.take_while s ~f:(function '_' -> true | _ -> false)\n in\n (* remove them from the original *)\n let rest = String.substr_replace_first ~pattern:prefix_us ~with_:\"\" s in\n let ws = String.split rest ~on:'_' in\n let result =\n match ws with\n | [] ->\n \"\"\n | w :: ws ->\n (* capitalize each word separated by underscores *)\n w :: (ws |> List.map ~f:String.capitalize) |> String.concat ?sep:None\n in\n (* add the leading underscoes back *)\n String.concat [ prefix_us; result ]\n\nlet%test_unit \"under_to_camel works as expected\" =\n let open Core_kernel in\n [%test_eq: string] \"fooHello\" (under_to_camel \"foo_hello\") ;\n [%test_eq: string] \"fooHello\" (under_to_camel \"foo_hello___\") ;\n [%test_eq: string] \"_fooHello\" (under_to_camel \"_foo_hello__\")\n\n(** Like Field.name but rewrites underscore_case to camelCase. *)\nlet name_under_to_camel f = Fieldslib.Field.name f |> under_to_camel\n\nlet introspection_query_raw =\n {graphql|\n query IntrospectionQuery {\n __schema {\n queryType { name }\n mutationType { name }\n subscriptionType { name }\n types {\n ...FullType\n }\n directives {\n name\n description\n locations\n args {\n ...InputValue\n }\n }\n }\n }\n fragment FullType on __Type {\n kind\n name\n description\n fields(includeDeprecated: true) {\n name\n description\n args {\n ...InputValue\n }\n type {\n ...TypeRef\n }\n isDeprecated\n deprecationReason\n }\n inputFields {\n ...InputValue\n }\n interfaces {\n ...TypeRef\n }\n enumValues(includeDeprecated: true) {\n name\n description\n isDeprecated\n deprecationReason\n }\n possibleTypes {\n ...TypeRef\n }\n }\n fragment InputValue on __InputValue {\n name\n description\n type { ...TypeRef }\n defaultValue\n }\n fragment TypeRef on __Type {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n }\n }\n }\n }\n }\n }\n }\n }\n |graphql}\n","open Core_kernel\nopen Fieldslib\n\nmodule Graphql_raw = struct\n module Make (Schema : Graphql_intf.Schema) = struct\n module Args = struct\n module Input = struct\n type ('row, 'result, 'ty, 'nullable) t =\n < graphql_arg : (unit -> 'ty Schema.Arg.arg_typ) ref\n ; nullable_graphql_arg : (unit -> 'nullable Schema.Arg.arg_typ) ref\n ; map : ('ty -> 'result) ref\n ; skip : bool ref\n ; .. >\n as\n 'row\n end\n\n module Acc = struct\n module T = struct\n type ('ty, 'fields) t_inner =\n { graphql_arg_fields : ('ty, 'fields) Schema.Arg.arg_list\n ; graphql_arg_coerce : 'fields\n }\n\n type 'ty t = Init | Acc : ('ty, 'fields) t_inner -> 'ty t\n end\n\n type ('row, 'result, 'ty, 'nullable) t =\n < graphql_arg_accumulator : 'result T.t ref ; .. > as 'row\n constraint\n ('row, 'c, 'ty, 'nullable) t =\n ('row, 'c, 'ty, 'nullable) Input.t\n end\n\n module Creator = struct\n type ('row, 'c, 'ty, 'nullable) t = < .. > as 'row\n constraint\n ('row, 'c, 'ty, 'nullable) t =\n ('row, 'c, 'ty, 'nullable) Input.t\n end\n\n module Output = struct\n type ('row, 'c, 'ty, 'nullable) t = < .. > as 'row\n constraint\n ('row, 'c, 'ty, 'nullable) t =\n ('row, 'c, 'ty, 'nullable) Input.t\n end\n\n let add_field (type f f' ty ty' nullable1 nullable2) ?skip_data\n ~t_fields_annots :\n ('f_row, f', f, nullable1) Input.t\n -> ([< `Read | `Set_and_create ], _, _) Field.t_with_perm\n -> ('row, ty', ty, nullable2) Acc.t\n -> (('row, ty', ty, nullable2) Creator.t -> f')\n * ('row_after, ty', ty, nullable2) Acc.t =\n fun f_input field acc ->\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let ref_as_pipe = ref None in\n let name =\n Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field)\n in\n let () =\n let inner_acc = acc#graphql_arg_accumulator in\n if annotations.skip || !(f_input#skip) then ()\n else\n let arg =\n Schema.Arg.arg name ?doc:annotations.doc\n ~typ:(!(f_input#graphql_arg) ())\n in\n match !inner_acc with\n | Init ->\n inner_acc :=\n Acc\n { graphql_arg_coerce =\n (fun x ->\n ref_as_pipe := Some x ;\n !(acc#graphql_creator) acc )\n ; graphql_arg_fields = [ arg ]\n }\n | Acc { graphql_arg_fields; graphql_arg_coerce } -> (\n match graphql_arg_fields with\n | [] ->\n inner_acc :=\n Acc\n { graphql_arg_coerce =\n (fun x ->\n ref_as_pipe := Some x ;\n !(acc#graphql_creator) acc )\n ; graphql_arg_fields = [ arg ]\n }\n | _ ->\n inner_acc :=\n Acc\n { graphql_arg_coerce =\n (fun x ->\n ref_as_pipe := Some x ;\n graphql_arg_coerce )\n ; graphql_arg_fields = arg :: graphql_arg_fields\n } )\n in\n ( (fun _creator_input ->\n !(f_input#map)\n @@\n if annotations.skip || !(f_input#skip) then\n match skip_data with\n | Some data ->\n data\n | None ->\n failwith\n \"If you are skipping a field but intend on building this \\\n field, you must provide skip_data to add_field!\"\n else Option.value_exn !ref_as_pipe )\n , acc )\n\n let finish name ~t_toplevel_annots (type ty result nullable) :\n (('row, result, ty, nullable) Input.t -> result)\n * ('row, result, ty, nullable) Acc.t\n -> _ Output.t =\n fun (creator, acc) ->\n let annotations =\n Fields_derivers.Annotations.Top.of_annots ~name t_toplevel_annots\n in\n acc#graphql_creator := creator ;\n (acc#graphql_arg :=\n fun () ->\n match !(acc#graphql_arg_accumulator) with\n | Init ->\n failwith \"Graphql args need at least one field\"\n | Acc { graphql_arg_fields; graphql_arg_coerce } ->\n (* TODO: Figure out why the typechecker doesn't like this\n * expression and remove Obj.magic. *)\n Obj.magic\n @@ Schema.Arg.(\n obj ?doc:annotations.doc\n (annotations.name ^ \"Input\")\n ~fields:graphql_arg_fields ~coerce:graphql_arg_coerce\n |> non_null) ) ;\n (acc#nullable_graphql_arg :=\n fun () ->\n match !(acc#graphql_arg_accumulator) with\n | Init ->\n failwith \"Graphql args need at least one field\"\n | Acc { graphql_arg_fields; graphql_arg_coerce } ->\n (* TODO: See above *)\n Obj.magic\n @@ Schema.Arg.(\n obj ?doc:annotations.doc\n (annotations.name ^ \"Input\")\n ~fields:graphql_arg_fields ~coerce:graphql_arg_coerce)\n ) ;\n acc\n\n let skip obj =\n obj#skip := true ;\n (obj#graphql_arg :=\n fun () ->\n failwith \"Unexpected: This obj#graphql_arg should be skipped\" ) ;\n obj#map := Fn.id ;\n obj#graphql_arg_accumulator := !(obj#graphql_arg_accumulator) ;\n (obj#nullable_graphql_arg :=\n fun () ->\n failwith \"Unexpected: This obj#graphql_arg should be skipped\" ) ;\n obj\n\n let int obj =\n (obj#graphql_arg := fun () -> Schema.Arg.(non_null int)) ;\n obj#map := Fn.id ;\n obj#graphql_arg_accumulator := !(obj#graphql_arg_accumulator) ;\n (obj#nullable_graphql_arg := fun () -> Schema.Arg.int) ;\n obj\n\n let string obj =\n (obj#graphql_arg := fun () -> Schema.Arg.(non_null string)) ;\n obj#map := Fn.id ;\n obj#graphql_arg_accumulator := !(obj#graphql_arg_accumulator) ;\n (obj#nullable_graphql_arg := fun () -> Schema.Arg.string) ;\n obj\n\n let bool obj =\n (obj#graphql_arg := fun () -> Schema.Arg.(non_null bool)) ;\n obj#map := Fn.id ;\n obj#graphql_arg_accumulator := !(obj#graphql_arg_accumulator) ;\n (obj#nullable_graphql_arg := fun () -> Schema.Arg.bool) ;\n obj\n\n let list x obj : (_, 'result list, 'input_type list, _) Input.t =\n (obj#graphql_arg :=\n fun () -> Schema.Arg.(non_null (list (!(x#graphql_arg) ()))) ) ;\n obj#map := List.map ~f:!(x#map) ;\n obj#graphql_arg_accumulator := !(x#graphql_arg_accumulator) ;\n (obj#nullable_graphql_arg :=\n fun () -> Schema.Arg.(list (!(x#graphql_arg) ())) ) ;\n obj\n\n let option (x : (_, 'result, 'input_type, _) Input.t) obj =\n obj#graphql_arg := !(x#nullable_graphql_arg) ;\n obj#nullable_graphql_arg := !(x#nullable_graphql_arg) ;\n obj#map := Option.map ~f:!(x#map) ;\n obj#graphql_arg_accumulator := !(x#graphql_arg_accumulator) ;\n obj\n\n let map ~(f : 'c -> 'd) (x : (_, 'c, 'input_type, _) Input.t) obj :\n (_, 'd, 'input_type, _) Input.t =\n obj#graphql_arg := !(x#graphql_arg) ;\n (obj#map := fun a -> f (!(x#map) a)) ;\n obj#nullable_graphql_arg := !(x#nullable_graphql_arg) ;\n obj#graphql_arg_accumulator := !(x#graphql_arg_accumulator) ;\n obj\n end\n\n module Fields = struct\n module Input = struct\n module T = struct\n type 'input_type t =\n { run : 'ctx. unit -> ('ctx, 'input_type) Schema.typ }\n end\n\n type ('input_type, 'a, 'c, 'nullable) t =\n < graphql_fields : 'input_type T.t ref\n ; contramap : ('c -> 'input_type) ref\n ; nullable_graphql_fields : 'nullable T.t ref\n ; .. >\n as\n 'a\n end\n\n module Accumulator = struct\n module T = struct\n type 'input_type t =\n { run : 'ctx. unit -> ('ctx, 'input_type) Schema.field option }\n end\n\n (** thunks generating the schema in reverse *)\n type ('input_type, 'a, 'c, 'nullable) t =\n < graphql_fields_accumulator : 'c T.t list ref ; .. > as 'a\n constraint\n ('input_type, 'a, 'c, 'nullable) t =\n ('input_type, 'a, 'c, 'nullable) Input.t\n end\n\n let add_field (type f input_type orig nullable c' nullable')\n ~t_fields_annots :\n (orig, 'a, f, nullable) Input.t\n -> ([< `Read | `Set_and_create ], c', f) Fieldslib.Field.t_with_perm\n -> (input_type, 'row2, c', nullable') Accumulator.t\n -> (_ -> f) * (input_type, 'row2, c', nullable') Accumulator.t =\n fun t_field field acc ->\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let rest = !(acc#graphql_fields_accumulator) in\n acc#graphql_fields_accumulator :=\n { Accumulator.T.run =\n (fun () ->\n if annotations.skip || !(t_field#skip) then None\n else\n Schema.field\n (Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field) )\n ~args:Schema.Arg.[]\n ?doc:annotations.doc\n ~deprecated:\n ( Option.map annotations.deprecated ~f:(fun msg ->\n Schema.Deprecated (Some msg) )\n |> Option.value ~default:Schema.NotDeprecated )\n ~typ:(!(t_field#graphql_fields).Input.T.run ())\n ~resolve:(fun _ x ->\n !(t_field#contramap) (Field.get field x) )\n |> Option.return )\n }\n :: rest ;\n ((fun _ -> failwith \"Unused\"), acc)\n\n let finish name ~t_toplevel_annots ((_creator, obj) : 'u * _ Accumulator.t)\n : _ Input.t =\n let annotations =\n Fields_derivers.Annotations.Top.of_annots ~name t_toplevel_annots\n in\n let graphql_fields_accumulator = !(obj#graphql_fields_accumulator) in\n let graphql_fields =\n { Input.T.run =\n (fun () ->\n Schema.obj annotations.name ?doc:annotations.doc\n ~fields:(fun _ ->\n List.rev\n @@ List.filter_map graphql_fields_accumulator ~f:(fun g ->\n g.Accumulator.T.run () ) )\n |> Schema.non_null )\n }\n in\n let nullable_graphql_fields =\n { Input.T.run =\n (fun () ->\n Schema.obj annotations.name ?doc:annotations.doc\n ~fields:(fun _ ->\n List.rev\n @@ List.filter_map graphql_fields_accumulator ~f:(fun g ->\n g.Accumulator.T.run () ) ) )\n }\n in\n obj#graphql_fields := graphql_fields ;\n obj#nullable_graphql_fields := nullable_graphql_fields ;\n obj#contramap := Fn.id ;\n obj\n\n let skip obj =\n (obj#graphql_fields :=\n Input.T.\n { run =\n (fun () ->\n failwith\n \"Unexpected: This obj#graphql_fields should be skipped\" )\n } ) ;\n obj#contramap := Fn.id ;\n obj#graphql_fields_accumulator := !(obj#graphql_fields_accumulator) ;\n (obj#nullable_graphql_fields :=\n Input.T.\n { run =\n (fun () ->\n failwith\n \"Unexpected: This obj#nullable_graphql_fields should be \\\n skipped\" )\n } ) ;\n obj\n\n let int obj =\n (obj#graphql_fields :=\n Input.T.{ run = (fun () -> Schema.(non_null int)) } ) ;\n obj#contramap := Fn.id ;\n obj#graphql_fields_accumulator := !(obj#graphql_fields_accumulator) ;\n (obj#nullable_graphql_fields := Input.T.{ run = (fun () -> Schema.int) }) ;\n obj\n\n let string obj =\n (obj#graphql_fields :=\n Input.T.{ run = (fun () -> Schema.(non_null string)) } ) ;\n obj#contramap := Fn.id ;\n obj#graphql_fields_accumulator := !(obj#graphql_fields_accumulator) ;\n (obj#nullable_graphql_fields :=\n Input.T.{ run = (fun () -> Schema.string) } ) ;\n obj\n\n let bool obj =\n (obj#graphql_fields :=\n Input.T.{ run = (fun () -> Schema.(non_null bool)) } ) ;\n obj#contramap := Fn.id ;\n obj#graphql_fields_accumulator := !(obj#graphql_fields_accumulator) ;\n (obj#nullable_graphql_fields :=\n Input.T.{ run = (fun () -> Schema.bool) } ) ;\n obj\n\n let list x obj : ('input_type list, _, _, _) Input.t =\n (obj#graphql_fields :=\n Input.T.\n { run =\n (fun () ->\n Schema.(non_null (list (!(x#graphql_fields).run ()))) )\n } ) ;\n obj#contramap := List.map ~f:!(x#contramap) ;\n obj#graphql_fields_accumulator := !(x#graphql_fields_accumulator) ;\n (obj#nullable_graphql_fields :=\n Input.T.\n { run = (fun () -> Schema.(list (!(x#graphql_fields).run ()))) } ) ;\n obj\n\n let option (x : ('input_type, 'b, 'c, 'nullable) Input.t) obj :\n ('input_type option, _, 'c option, _) Input.t =\n obj#graphql_fields := !(x#nullable_graphql_fields) ;\n obj#nullable_graphql_fields := !(x#nullable_graphql_fields) ;\n obj#contramap := Option.map ~f:!(x#contramap) ;\n obj#graphql_fields_accumulator := !(x#graphql_fields_accumulator) ;\n obj\n\n let contramap ~(f : 'd -> 'c)\n (x : ('input_type, 'b, 'c, 'nullable) Input.t) obj :\n ('input_type, _, 'd, _) Input.t =\n obj#graphql_fields := !(x#graphql_fields) ;\n (obj#contramap := fun a -> !(x#contramap) (f a)) ;\n obj#nullable_graphql_fields := !(x#nullable_graphql_fields) ;\n obj#graphql_fields_accumulator := !(x#graphql_fields_accumulator) ;\n obj\n end\n\n let rec arg_to_yojson_rec (arg : Graphql_parser.const_value) : Yojson.Safe.t\n =\n match arg with\n | `Null ->\n `Null\n | `Int x ->\n `Int x\n | `Float x ->\n `Float x\n | `String x ->\n `String x\n | `Bool x ->\n `Bool x\n | `Enum x ->\n `String x\n | `List x ->\n `List (List.map x ~f:arg_to_yojson_rec)\n | `Assoc x ->\n `Assoc\n (List.map x ~f:(fun (key, value) -> (key, arg_to_yojson_rec value)))\n\n let arg_to_yojson arg : (Yojson.Safe.t, string) result =\n Ok (arg_to_yojson_rec arg)\n end\nend\n\nmodule Graphql_query = struct\n module Input = struct\n type 'a t = < graphql_query : string option ref ; .. > as 'a\n end\n\n module Accumulator = struct\n type 'a t =\n < graphql_query_accumulator : (string * string option) option list ref\n ; .. >\n as\n 'a\n constraint 'a t = 'a Input.t\n end\n\n let add_field ~t_fields_annots :\n 'a Input.t -> 'field -> 'obj -> 'creator * 'obj =\n fun t_field field acc_obj ->\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let rest = !(acc_obj#graphql_query_accumulator) in\n acc_obj#graphql_query_accumulator :=\n ( if annotations.skip || !(t_field#skip) then None\n else\n Some\n ( Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field)\n , !(t_field#graphql_query) ) )\n :: rest ;\n ((fun _ -> failwith \"unused\"), acc_obj)\n\n let finish (_creator, obj) =\n let graphql_query_accumulator = !(obj#graphql_query_accumulator) in\n obj#graphql_query :=\n Some\n (sprintf \"{\\n%s\\n}\"\n ( List.filter_map graphql_query_accumulator\n ~f:\n (Option.map ~f:(fun (k, v) ->\n match v with None -> k | Some v -> sprintf \"%s %s\" k v )\n )\n |> List.rev |> String.concat ~sep:\"\\n\" ) ) ;\n obj\n\n let scalar obj =\n obj#graphql_query := None ;\n obj\n\n let skip obj = scalar obj\n\n let int obj = scalar obj\n\n let string obj = scalar obj\n\n let bool obj = scalar obj\n\n (* nullable and lists of things are projected to the inner thing ONLY IF inner\n * projectable. *)\n let wrapped x obj =\n obj#graphql_query := !(x#graphql_query) ;\n obj\n\n let option x obj = wrapped x obj\n\n let list x obj = wrapped x obj\n\n let inner_query obj = !(obj#graphql_query)\nend\n\nmodule IO = struct\n include Async_kernel.Deferred\n\n let bind x f = bind x ~f\n\n module Stream = struct\n type 'a t = 'a Async_kernel.Pipe.Reader.t\n\n let map t f =\n Async_kernel.Pipe.map' t ~f:(fun q ->\n Async_kernel.Deferred.Queue.map q ~f )\n\n let iter t f = Async_kernel.Pipe.iter t ~f\n\n let close = Async_kernel.Pipe.close_read\n end\nend\n\nmodule Field_error = struct\n type t = string\n\n let message_of_field_error t = t\n\n let extensions_of_field_error _t = None\nend\n\nmodule Schema = Graphql_schema.Make (IO) (Field_error)\nmodule Graphql = Graphql_raw.Make (Schema)\n\nmodule Test = struct\n let parse_query str =\n match Graphql_parser.parse str with\n | Ok res ->\n res\n | Error err ->\n failwith err\n\n let introspection_query () =\n parse_query Fields_derivers.introspection_query_raw\nend\n\nlet%test_module \"Test\" =\n ( module struct\n (* Pure -- just like Graphql libraries functor application *)\n module IO = struct\n type +'a t = 'a\n\n let bind t f = f t\n\n let return t = t\n\n module Stream = struct\n type 'a t = 'a Seq.t\n\n let map t f = Seq.map f t\n\n let iter t f = Seq.iter f t\n\n let close _t = ()\n end\n end\n\n module Schema = Graphql_schema.Make (IO) (Field_error)\n module Graphql = Graphql_raw.Make (Schema)\n module Graphql_fields = Graphql.Fields\n module Graphql_args = Graphql.Args\n\n let deriver (type a b c d) () :\n < contramap : (a -> b) ref\n ; graphql_fields : c Graphql_fields.Input.T.t ref\n ; nullable_graphql_fields : d Graphql_fields.Input.T.t ref\n ; .. >\n as\n 'row =\n (* We have to declare these outside of the object, otherwise the method\n * will create a new ref each time it is called. *)\n let open Graphql_fields in\n let graphql_fields =\n ref Input.T.{ run = (fun () -> failwith \"unimplemented1\") }\n in\n let graphql_arg = ref (fun () -> failwith \"unimplemented2\") in\n let contramap = ref (fun _ -> failwith \"unimplemented3\") in\n let map = ref (fun _ -> failwith \"unimplemented4\") in\n let nullable_graphql_fields =\n ref Input.T.{ run = (fun () -> failwith \"unimplemented5\") }\n in\n let nullable_graphql_arg = ref (fun () -> failwith \"unimplemented6\") in\n let graphql_fields_accumulator = ref [] in\n let graphql_arg_accumulator = ref Graphql_args.Acc.T.Init in\n let graphql_creator = ref (fun _ -> failwith \"unimplemented7\") in\n let graphql_query = ref None in\n let graphql_query_accumulator = ref [] in\n let skip = ref false in\n object\n method skip = skip\n\n method graphql_fields = graphql_fields\n\n method graphql_arg = graphql_arg\n\n method contramap = contramap\n\n method map = map\n\n method nullable_graphql_fields = nullable_graphql_fields\n\n method nullable_graphql_arg = nullable_graphql_arg\n\n method graphql_fields_accumulator = graphql_fields_accumulator\n\n method graphql_arg_accumulator = graphql_arg_accumulator\n\n method graphql_creator = graphql_creator\n\n method graphql_query = graphql_query\n\n method graphql_query_accumulator = graphql_query_accumulator\n end\n\n let o () = deriver ()\n\n let raw_server ?(print = false) q c =\n let schema = Schema.(schema [ q ] ~mutations:[] ~subscriptions:[]) in\n let res = Schema.execute schema () c in\n match res with\n | Ok (`Response data) ->\n if print then Yojson.Basic.pretty_print Format.std_formatter data ;\n data |> Yojson.Basic.to_string\n | Error err ->\n failwithf \"Unexpected error: %s\" (Yojson.Basic.to_string err) ()\n | _ ->\n failwith \"Unexpected response\"\n\n let query_schema typ v =\n Schema.(\n field \"query\" ~typ:(non_null typ)\n ~args:Arg.[]\n ~doc:\"sample query\"\n ~resolve:(fun _ _ -> v))\n\n let query_for_all typ v str =\n raw_server (query_schema typ v) (Test.parse_query str)\n\n let hit_server ?print q = raw_server ?print q (Test.introspection_query ())\n\n let hit_server_query (typ : _ Schema.typ) v =\n hit_server (query_schema typ v)\n\n let hit_server_args (arg_typ : 'a Schema.Arg.arg_typ) =\n hit_server\n Schema.(\n field \"args\" ~typ:(non_null int)\n ~args:Arg.[ arg \"input\" ~typ:arg_typ ]\n ~doc:\"sample args query\"\n ~resolve:(fun _ _ _ -> 0))\n\n module T1 = struct\n (** T1 is foo *)\n type t =\n { foo_hello : int option\n ; skipped : int [@skip]\n ; bar : string list [@name \"bar1\"]\n }\n [@@deriving annot, fields]\n\n let _v = { foo_hello = Some 1; skipped = 0; bar = [ \"baz1\"; \"baz2\" ] }\n\n let doc = \"T1 is foo\"\n\n let manual_typ =\n Schema.(\n obj \"T1\" ~doc ~fields:(fun _ ->\n [ field \"fooHello\"\n ~args:Arg.[]\n ~typ:int\n ~resolve:(fun _ t -> t.foo_hello)\n ; field \"bar1\"\n ~args:Arg.[]\n ~typ:(non_null (list (non_null string)))\n ~resolve:(fun _ t -> t.bar)\n ] ))\n\n let derived init =\n let open Graphql_fields in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x (o ())) fd acc in\n Fields.make_creator init\n ~foo_hello:!.(option @@ int @@ o ())\n ~skipped:!.skip\n ~bar:!.(list @@ string @@ o ())\n |> finish \"T1\" ~t_toplevel_annots\n\n module Args = struct\n let manual_typ =\n Schema.Arg.(\n obj \"T1Input\" ~doc\n ~fields:\n [ arg \"bar1\" ~typ:(non_null (list (non_null string)))\n ; arg \"fooHello\" ~typ:int\n ]\n ~coerce:(fun bar foo_hello -> { bar; skipped = 0; foo_hello }))\n\n let derived init =\n let open Graphql_args in\n let ( !. ) ?skip_data x fd acc =\n add_field ?skip_data ~t_fields_annots (x (o ())) fd acc\n in\n Fields.make_creator init\n ~foo_hello:!.(option @@ int @@ o ())\n ~skipped:(( !. ) ~skip_data:0 skip)\n ~bar:!.(list @@ string @@ o ())\n |> finish \"T1\" ~t_toplevel_annots\n end\n\n module Query = struct\n let derived init =\n let open Graphql_query in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x (o ())) fd acc in\n Fields.make_creator init\n ~foo_hello:!.(option @@ int @@ o ())\n ~skipped:!.skip\n ~bar:!.(list @@ string @@ o ())\n |> finish\n end\n end\n\n module Or_ignore_test = struct\n type 'a t = Check of 'a | Ignore\n\n let of_option = function None -> Ignore | Some x -> Check x\n\n let to_option = function Ignore -> None | Check x -> Some x\n\n let derived (x : ('input_type, 'b, 'c, _) Graphql_fields.Input.t) init :\n (_, _, 'c t, _) Graphql_fields.Input.t =\n let open Graphql_fields in\n let opt = option x (o ()) in\n contramap ~f:to_option opt init\n\n module Args = struct\n let derived (x : ('row1, 'c, 'input_type, _) Graphql_args.Input.t) init\n : ('row2, 'c t, 'input_type option, _) Graphql_args.Input.t =\n let open Graphql_args in\n let opt = option x (o ()) in\n map ~f:of_option opt init\n end\n\n module Query = struct\n let derived x init =\n let open Graphql_query in\n option x init\n end\n end\n\n module T2 = struct\n type t = { foo : T1.t Or_ignore_test.t } [@@deriving annot, fields]\n\n let v1 =\n { foo =\n Check\n { T1.foo_hello = Some 1; skipped = 0; bar = [ \"baz1\"; \"baz2\" ] }\n }\n\n let v2 = { foo = Ignore }\n\n let manual_typ =\n Schema.(\n obj \"T2\" ?doc:None ~fields:(fun _ ->\n [ field \"foo\"\n ~args:Arg.[]\n ~typ:T1.manual_typ\n ~resolve:(fun _ t -> Or_ignore_test.to_option t.foo)\n ] ))\n\n let derived init =\n let open Graphql_fields in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x (o ())) fd acc in\n Fields.make_creator init\n ~foo:!.(Or_ignore_test.derived @@ T1.derived @@ o ())\n |> finish \"T2\" ~t_toplevel_annots\n\n module Args = struct\n let manual_typ =\n Schema.Arg.(\n obj \"T2Input\" ?doc:None\n ~fields:[ arg \"foo\" ~typ:T1.Args.manual_typ ]\n ~coerce:(fun foo -> Or_ignore_test.of_option foo))\n\n let derived init =\n let open Graphql_args in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x (o ())) fd acc in\n Fields.make_creator init\n ~foo:!.(Or_ignore_test.Args.derived @@ T1.Args.derived @@ o ())\n |> finish \"T2\" ~t_toplevel_annots\n end\n\n module Query = struct\n let manual =\n {|\n {\n foo {\n fooHello\n bar1\n }\n }\n |}\n\n let derived init =\n let open Graphql_query in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x (o ())) fd acc in\n Fields.make_creator init\n ~foo:!.(Or_ignore_test.Query.derived @@ T1.Query.derived @@ o ())\n |> finish\n end\n end\n\n let%test_unit \"T2 fold\" =\n let open Graphql_fields in\n let generated_typ =\n let typ_input = T2.(option @@ derived @@ o ()) (o ()) in\n !(typ_input#graphql_fields).run ()\n in\n [%test_eq: string]\n (hit_server_query generated_typ T2.v1)\n (hit_server_query T2.manual_typ T2.v1) ;\n [%test_eq: string]\n (hit_server_query generated_typ T2.v2)\n (hit_server_query T2.manual_typ T2.v2)\n\n let%test_unit \"T2 unfold\" =\n let open Graphql_args in\n let generated_arg_typ =\n let obj = T2.(option @@ Args.derived @@ o ()) (o ()) in\n !(obj#graphql_arg) ()\n in\n [%test_eq: string]\n (hit_server_args generated_arg_typ)\n (hit_server_args T2.Args.manual_typ)\n\n let%test_unit \"T2 query expected & parses\" =\n let open Graphql_fields in\n let generated_typ =\n let typ_input = T2.(option @@ derived @@ o ()) (o ()) in\n !(typ_input#graphql_fields).run ()\n in\n let open Graphql_query in\n let generated_query =\n T2.Query.(option @@ derived @@ o ()) (o ())\n |> inner_query |> Option.value_exn\n in\n let prefix = \"query TestQuery { query\" in\n let suffix = \"}\" in\n [%test_eq: string]\n (query_for_all generated_typ T2.v1 (prefix ^ generated_query ^ suffix))\n (query_for_all generated_typ T2.v1 (prefix ^ T2.Query.manual ^ suffix))\n end )\n","open Core_kernel\nopen Fieldslib\n\nmodule To_yojson = struct\n module Input = struct\n type ('input_type, 'a, 'c) t =\n < to_json : ('input_type -> Yojson.Safe.t) ref\n ; contramap : ('c -> 'input_type) ref\n ; skip : bool ref\n ; .. >\n as\n 'a\n end\n\n module Accumulator = struct\n type ('input_type, 'a, 'c) t =\n < to_json_accumulator :\n (string * ('input_type -> Yojson.Safe.t)) option list ref\n ; .. >\n as\n 'a\n constraint ('input_type, 'a, 'c) t = ('input_type, 'a, 'c) Input.t\n end\n\n let add_field ~t_fields_annots t_field field acc =\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let rest = !(acc#to_json_accumulator) in\n acc#to_json_accumulator :=\n ( if annotations.skip || !(t_field#skip) then None\n else\n ( Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field)\n , fun x -> !(t_field#to_json) (!(t_field#contramap) (Field.get field x))\n )\n |> Option.return )\n :: rest ;\n ((fun _ -> failwith \"Unused\"), acc)\n\n let finish (_creator, obj) =\n let to_json_accumulator = !(obj#to_json_accumulator) in\n obj#contramap := Fn.id ;\n (obj#to_json :=\n fun t ->\n `Assoc\n ( List.filter_map to_json_accumulator\n ~f:(Option.map ~f:(fun (name, f) -> (name, f t)))\n |> List.rev ) ) ;\n obj\n\n let skip obj =\n obj#skip := true ;\n obj#contramap := Fn.id ;\n (obj#to_json :=\n fun _ -> failwith \"Unexpected: This obj#to_json should be skipped\" ) ;\n obj\n\n let int obj =\n obj#contramap := Fn.id ;\n (obj#to_json := fun x -> `Int x) ;\n obj\n\n let string obj =\n obj#contramap := Fn.id ;\n (obj#to_json := fun x -> `String x) ;\n obj\n\n let bool obj =\n obj#contramap := Fn.id ;\n (obj#to_json := fun x -> `Bool x) ;\n obj\n\n let list x obj =\n obj#contramap := List.map ~f:!(x#contramap) ;\n (obj#to_json := fun a -> `List (List.map ~f:!(x#to_json) a)) ;\n obj\n\n let option x obj =\n obj#contramap := Option.map ~f:!(x#contramap) ;\n (obj#to_json :=\n fun a_opt -> match a_opt with Some a -> !(x#to_json) a | None -> `Null ) ;\n obj\n\n let contramap ~f x obj =\n (obj#contramap := fun a -> !(x#contramap) (f a)) ;\n obj#to_json := !(x#to_json) ;\n obj\nend\n\nmodule Of_yojson = struct\n module Input = struct\n type ('input_type, 'a, 'c) t =\n < of_json : (Yojson.Safe.t -> 'input_type) ref\n ; map : ('input_type -> 'c) ref\n ; skip : bool ref\n ; .. >\n as\n 'a\n end\n\n module Creator = struct\n type ('input_type, 'a, 'c) t =\n < of_json_creator : Yojson.Safe.t String.Map.t ref ; .. > as 'a\n constraint ('input_type, 'a, 'c) t = ('input_type, 'a, 'c) Input.t\n end\n\n exception Field_not_found of string\n\n let add_field ?skip_data ~t_fields_annots :\n ('t, 'a, 'c) Input.t -> 'field -> 'obj -> 'creator * 'obj =\n fun t_field field acc_obj ->\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let creator finished_obj =\n let map = !(finished_obj#of_json_creator) in\n !(t_field#map)\n ( if annotations.skip || !(t_field#skip) then\n match skip_data with\n | Some x ->\n x\n | None ->\n failwith\n \"If you are skipping a field in of_json but intend on building \\\n this field, you must provide skip_data to add_field!\"\n else\n !(t_field#of_json)\n (let name =\n Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field)\n in\n match Map.find map name with\n | None ->\n raise (Field_not_found name)\n | Some x ->\n x ) )\n in\n (creator, acc_obj)\n\n exception Json_not_object\n\n let finish (creator, obj) =\n let of_json json =\n match json with\n | `Assoc pairs ->\n obj#of_json_creator := String.Map.of_alist_exn pairs ;\n creator obj\n | _ ->\n raise Json_not_object\n in\n obj#map := Fn.id ;\n obj#of_json := of_json ;\n obj\n\n exception Invalid_json_scalar of [ `Int | `String | `Bool | `List ]\n\n let skip obj =\n obj#contramap := Fn.id ;\n (obj#of_json :=\n fun _ -> failwith \"Unexpected: This obj#of_json should be skipped\" ) ;\n obj\n\n let int obj =\n (obj#of_json :=\n function `Int x -> x | _ -> raise (Invalid_json_scalar `Int) ) ;\n obj#map := Fn.id ;\n obj\n\n let string obj =\n (obj#of_json :=\n function `String x -> x | _ -> raise (Invalid_json_scalar `String) ) ;\n obj#map := Fn.id ;\n obj\n\n let bool obj =\n (obj#of_json :=\n function `Bool x -> x | _ -> raise (Invalid_json_scalar `Bool) ) ;\n obj#map := Fn.id ;\n obj\n\n let list x obj =\n (obj#of_json :=\n function\n | `List xs ->\n List.map xs ~f:!(x#of_json)\n | _ ->\n raise (Invalid_json_scalar `List) ) ;\n obj#map := List.map ~f:!(x#map) ;\n obj\n\n let option x obj =\n (obj#of_json :=\n function `Null -> None | other -> Some (!(x#of_json) other) ) ;\n obj#map := Option.map ~f:!(x#map) ;\n obj\n\n let map ~f x obj =\n (obj#map := fun a -> f (!(x#map) a)) ;\n obj#of_json := !(x#of_json) ;\n obj\nend\n\nlet%test_module \"Test\" =\n ( module struct\n type t = { foo_hello : int; skipped : int [@skip]; bar : string list }\n [@@deriving annot, fields]\n\n let v = { foo_hello = 1; skipped = 0; bar = [ \"baz1\"; \"baz2\" ] }\n\n let m =\n {json|{ fooHello: 1, bar: [\"baz1\", \"baz2\"] }|json}\n |> Yojson.Safe.from_string\n\n module Yojson_version = struct\n type t = { foo_hello : int [@key \"fooHello\"]; bar : string list }\n [@@deriving yojson]\n\n let v = { foo_hello = 1; bar = [ \"baz1\"; \"baz2\" ] }\n end\n\n let deriver () =\n let to_json = ref (fun _ -> failwith \"unimplemented\") in\n let of_json = ref (fun _ -> failwith \"unimplemented\") in\n let to_json_accumulator = ref [] in\n let of_json_creator = ref String.Map.empty in\n let map = ref Fn.id in\n let contramap = ref Fn.id in\n let skip = ref false in\n object\n method skip = skip\n\n method to_json = to_json\n\n method map = map\n\n method contramap = contramap\n\n method of_json = of_json\n\n method to_json_accumulator = to_json_accumulator\n\n method of_json_creator = of_json_creator\n end\n\n let o () = deriver ()\n\n (* Explanation: Fields.make_creator roughly executes the following code:\n\n let make_creator ~foo_hello ~bar obj =\n (* Fieldslib.Field is actually a little more complicated *)\n let field_foo = Field { name = \"foo_hello\" ; getter = (fun o -> o.foo_hello) } in\n let field_bar = Field { name = \"bar\"; getter = (fun o -> o.bar) } in\n let creator_foo, obj = foo_hello field_foo obj in\n let creator_bar, obj = bar field_bar obj in\n let creator finished_obj =\n { foo_hello = creator_foo finished_obj ; bar = creator_bar finished_obj }\n in\n (creator, obj)\n *)\n\n let to_json obj =\n let open To_yojson in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x @@ o ()) fd acc in\n Fields.make_creator obj ~foo_hello:!.int ~skipped:!.skip\n ~bar:!.(list @@ string @@ o ())\n |> finish\n\n let of_json obj =\n let open Of_yojson in\n let ( !. ) ?skip_data x fd acc =\n add_field ?skip_data ~t_fields_annots (x @@ o ()) fd acc\n in\n Fields.make_creator obj ~foo_hello:!.int\n ~skipped:(( !. ) ~skip_data:0 skip)\n ~bar:!.(list @@ string @@ o ())\n |> finish\n\n let both_json obj =\n let _a = to_json obj in\n let _b = of_json obj in\n obj\n\n let full_derivers = both_json @@ o ()\n\n let%test_unit \"folding creates a yojson object we expect (modulo camel \\\n casing)\" =\n [%test_eq: string]\n (Yojson_version.to_yojson Yojson_version.v |> Yojson.Safe.to_string)\n (!(full_derivers#to_json) v |> Yojson.Safe.to_string)\n\n let%test_unit \"unfolding creates a yojson object we expect\" =\n let expected =\n Yojson_version.of_yojson m |> Result.ok |> Option.value_exn\n in\n let actual = !(full_derivers#of_json) m in\n [%test_eq: string list] expected.bar actual.bar ;\n [%test_eq: int] expected.foo_hello actual.foo_hello\n\n let%test_unit \"round trip\" =\n [%test_eq: string]\n ( !(full_derivers#to_json) (!(full_derivers#of_json) m)\n |> Yojson.Safe.to_string )\n (m |> Yojson.Safe.to_string)\n end )\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type ('a, 'h) t = ('a, 'h) Mina_wire_types.With_hash.V1.t =\n { data : 'a; hash : 'h }\n [@@deriving annot, sexp, equal, compare, hash, yojson, fields]\n\n let to_latest data_latest hash_latest { data; hash } =\n { data = data_latest data; hash = hash_latest hash }\n end\nend]\n\ntype ('a, 'h) t = ('a, 'h) Stable.Latest.t = { data : 'a; hash : 'h }\n[@@deriving annot, sexp, equal, compare, hash, yojson]\n\nlet data { data; _ } = data\n\nlet hash { hash; _ } = hash\n\nlet map t ~f = { t with data = f t.data }\n\nlet map_hash t ~f = { t with hash = f t.hash }\n\nlet of_data data ~hash_data = { data; hash = hash_data data }\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nmodule Field = Snark_params.Tick.Field\n\nmodule Make (Schema : Graphql_intf.Schema) = struct\n module Graphql = Fields_derivers_graphql.Graphql_raw.Make (Schema)\n\n let derivers () =\n let graphql_fields =\n ref Graphql.Fields.Input.T.{ run = (fun () -> failwith \"unimplemented\") }\n in\n let nullable_graphql_fields =\n ref Graphql.Fields.Input.T.{ run = (fun () -> failwith \"unimplemented\") }\n in\n let graphql_fields_accumulator = ref [] in\n let graphql_arg = ref (fun () -> failwith \"unimplemented\") in\n let nullable_graphql_arg = ref (fun () -> failwith \"unimplemented\") in\n let graphql_arg_accumulator = ref Graphql.Args.Acc.T.Init in\n let graphql_creator = ref (fun _ -> failwith \"unimplemented\") in\n let graphql_query = ref None in\n let graphql_query_accumulator = ref [] in\n\n let to_json = ref (fun _ -> failwith \"unimplemented\") in\n let of_json = ref (fun _ -> failwith \"unimplemented\") in\n let to_json_accumulator = ref [] in\n let of_json_creator = ref String.Map.empty in\n\n let js_layout = ref (`Assoc []) in\n let js_layout_accumulator = ref [] in\n\n let contramap = ref (fun _ -> failwith \"unimplemented\") in\n let map = ref (fun _ -> failwith \"unimplemented\") in\n\n let skip = ref false in\n\n object\n method skip = skip\n\n method graphql_fields = graphql_fields\n\n method nullable_graphql_fields = nullable_graphql_fields\n\n method graphql_fields_accumulator = graphql_fields_accumulator\n\n method graphql_arg = graphql_arg\n\n method nullable_graphql_arg = nullable_graphql_arg\n\n method graphql_arg_accumulator = graphql_arg_accumulator\n\n method graphql_creator = graphql_creator\n\n method graphql_query = graphql_query\n\n method graphql_query_accumulator = graphql_query_accumulator\n\n method to_json = to_json\n\n method of_json = of_json\n\n method to_json_accumulator = to_json_accumulator\n\n method of_json_creator = of_json_creator\n\n method js_layout = js_layout\n\n method js_layout_accumulator = js_layout_accumulator\n\n method contramap = contramap\n\n method map = map\n end\n\n let o () = derivers ()\n\n module Unified_input = struct\n type 'a t = < .. > as 'a\n constraint 'a = _ Fields_derivers_json.To_yojson.Input.t\n constraint 'a = _ Fields_derivers_json.Of_yojson.Input.t\n constraint 'a = _ Graphql.Fields.Input.t\n constraint 'a = _ Graphql.Args.Input.t\n constraint 'a = _ Fields_derivers_graphql.Graphql_query.Input.t\n constraint 'a = _ Fields_derivers_js.Js_layout.Input.t\n end\n\n let yojson obj ?doc ~name ~js_type ~map ~contramap : _ Unified_input.t =\n (obj#graphql_fields :=\n let open Schema in\n Graphql.Fields.Input.T.\n { run =\n (fun () ->\n scalar name ?doc ~coerce:Yojson.Safe.to_basic |> non_null )\n } ) ;\n\n (obj#nullable_graphql_fields :=\n let open Schema in\n Graphql.Fields.Input.T.\n { run = (fun () -> scalar name ?doc ~coerce:Yojson.Safe.to_basic) } ) ;\n\n (obj#graphql_arg :=\n fun () ->\n Schema.Arg.scalar name ?doc ~coerce:Graphql.arg_to_yojson\n |> Schema.Arg.non_null ) ;\n\n (obj#nullable_graphql_arg :=\n fun () -> Schema.Arg.scalar name ?doc ~coerce:Graphql.arg_to_yojson ) ;\n\n obj#to_json := Fn.id ;\n\n obj#of_json := Fn.id ;\n\n obj#contramap := contramap ;\n\n obj#map := map ;\n\n obj#js_layout := Fields_derivers_js.Js_layout.leaf_type js_type ;\n\n Fields_derivers_graphql.Graphql_query.scalar obj\n\n let invalid_scalar_to_string = function\n | `Uint ->\n \"Uint\"\n | `Field ->\n \"Field\"\n | `Token_id ->\n \"Token_id\"\n | `Public_key ->\n \"Public_key\"\n | `Amount ->\n \"Amount\"\n | `Balance ->\n \"Balance\"\n | `Unit ->\n \"Unit\"\n | `Proof ->\n \"Proof\"\n | `Verification_key ->\n \"Verification_key\"\n | `Signature ->\n \"Signature\"\n\n let raise_invalid_scalar t s =\n failwith (\"Invalid rich scalar: \" ^ invalid_scalar_to_string t ^ \" \" ^ s)\n\n let except ~f v (x : string) = try f x with _ -> raise_invalid_scalar v x\n\n let iso_string ?doc ~name ~js_type obj ~(to_string : 'a -> string)\n ~(of_string : string -> 'a) =\n yojson obj ?doc ~name ~js_type\n ~map:(function\n | `String x ->\n of_string x\n | _ ->\n raise (Fields_derivers_json.Of_yojson.Invalid_json_scalar `String)\n )\n ~contramap:(fun x -> `String (to_string x))\n\n let uint64 obj : _ Unified_input.t =\n iso_string obj\n ~doc:\"Unsigned 64-bit integer represented as a string in base10\"\n ~name:\"UInt64\" ~js_type:UInt64 ~to_string:Unsigned.UInt64.to_string\n ~of_string:(except ~f:Unsigned.UInt64.of_string `Uint)\n\n let uint32 obj : _ Unified_input.t =\n iso_string obj\n ~doc:\"Unsigned 32-bit integer represented as a string in base10\"\n ~name:\"UInt32\" ~js_type:UInt32 ~to_string:Unsigned.UInt32.to_string\n ~of_string:(except ~f:Unsigned.UInt32.of_string `Uint)\n\n let field obj : _ Unified_input.t =\n iso_string obj ~name:\"Field\" ~js_type:Field\n ~doc:\"String representing an Fp Field element\" ~to_string:Field.to_string\n ~of_string:(except ~f:Field.of_string `Field)\n\n let public_key obj : _ Unified_input.t =\n iso_string obj ~name:\"PublicKey\" ~js_type:PublicKey\n ~doc:\"String representing a public key in base58\"\n ~to_string:Signature_lib.Public_key.Compressed.to_string\n ~of_string:\n (except ~f:Signature_lib.Public_key.Compressed.of_base58_check_exn\n `Public_key )\n\n let skip obj : _ Unified_input.t =\n let _a = Graphql.Fields.skip obj in\n let _b = Graphql.Args.skip obj in\n let _c = Fields_derivers_json.To_yojson.skip obj in\n let _d = Fields_derivers_graphql.Graphql_query.skip obj in\n let _e = Fields_derivers_js.Js_layout.skip obj in\n Fields_derivers_json.Of_yojson.skip obj\n\n let js_only (js_layout : _ Fields_derivers_js.Js_layout.Input.t -> 'a) obj :\n _ Unified_input.t =\n let _a = Graphql.Fields.skip obj in\n let _b = Graphql.Args.skip obj in\n let _c = Fields_derivers_json.To_yojson.skip obj in\n let _d = Fields_derivers_graphql.Graphql_query.skip obj in\n let _e = js_layout obj in\n Fields_derivers_json.Of_yojson.skip obj\n\n let js_leaf leaf obj =\n js_only Fields_derivers_js.Js_layout.(of_layout @@ leaf_type leaf) obj\n\n let js_record entries obj =\n js_only (Fields_derivers_js.Js_layout.record entries) obj\n\n let int obj : _ Unified_input.t =\n let _a = Graphql.Fields.int obj in\n let _b = Graphql.Args.int obj in\n let _c = Fields_derivers_json.To_yojson.int obj in\n let _d = Fields_derivers_graphql.Graphql_query.int obj in\n let _e = Fields_derivers_js.Js_layout.int obj in\n Fields_derivers_json.Of_yojson.int obj\n\n let string obj : _ Unified_input.t =\n let _a = Graphql.Fields.string obj in\n let _b = Graphql.Args.string obj in\n let _c = Fields_derivers_json.To_yojson.string obj in\n let _d = Fields_derivers_graphql.Graphql_query.string obj in\n let _e = Fields_derivers_js.Js_layout.string obj in\n Fields_derivers_json.Of_yojson.string obj\n\n let bool obj : _ Unified_input.t =\n let _a = Graphql.Fields.bool obj in\n let _b = Graphql.Args.bool obj in\n let _c = Fields_derivers_json.To_yojson.bool obj in\n let _d = Fields_derivers_graphql.Graphql_query.bool obj in\n let _e = Fields_derivers_js.Js_layout.bool obj in\n Fields_derivers_json.Of_yojson.bool obj\n\n let global_slot_since_genesis obj =\n iso_string obj ~name:\"GlobalSlotSinceGenesis\" ~js_type:UInt32\n ~to_string:Mina_numbers.Global_slot_since_genesis.to_string\n ~of_string:\n (except ~f:Mina_numbers.Global_slot_since_genesis.of_string `Uint)\n\n let global_slot_since_hard_fork obj =\n iso_string obj ~name:\"GlobalSlotSinceHardFork\" ~js_type:UInt32\n ~to_string:Mina_numbers.Global_slot_since_hard_fork.to_string\n ~of_string:\n (except ~f:Mina_numbers.Global_slot_since_hard_fork.of_string `Uint)\n\n let global_slot_span obj =\n iso_string obj ~name:\"GlobalSlotSpan\" ~js_type:UInt32\n ~to_string:Mina_numbers.Global_slot_span.to_string\n ~of_string:(except ~f:Mina_numbers.Global_slot_span.of_string `Uint)\n\n let amount obj =\n iso_string obj ~name:\"CurrencyAmount\" ~js_type:UInt64\n ~to_string:Currency.Amount.to_string\n ~of_string:(except ~f:Currency.Amount.of_string `Amount)\n\n let balance obj =\n iso_string obj ~name:\"Balance\" ~js_type:UInt64\n ~to_string:Currency.Balance.to_string\n ~of_string:(except ~f:Currency.Balance.of_string `Balance)\n\n let option (x : _ Unified_input.t) ~js_type obj : _ Unified_input.t =\n let _a = Graphql.Fields.option x obj in\n let _b = Graphql.Args.option x obj in\n let _c = Fields_derivers_json.To_yojson.option x obj in\n let _d = Fields_derivers_graphql.Graphql_query.option x obj in\n let _e = Fields_derivers_js.Js_layout.option ~js_type x obj in\n Fields_derivers_json.Of_yojson.option x obj\n\n let list ?(static_length : int option) (x : _ Unified_input.t) obj :\n _ Unified_input.t =\n let _a = Graphql.Fields.list x obj in\n let _b = Graphql.Args.list x obj in\n let _c = Fields_derivers_json.To_yojson.list x obj in\n let _d = Fields_derivers_graphql.Graphql_query.list x obj in\n let _e = Fields_derivers_js.Js_layout.list ?static_length x obj in\n Fields_derivers_json.Of_yojson.list x obj\n\n let iso ~map ~contramap (x : _ Unified_input.t) obj : _ Unified_input.t =\n let _a = Graphql.Fields.contramap ~f:contramap x obj in\n let _b = Graphql.Args.map ~f:map x obj in\n let _c = Fields_derivers_json.To_yojson.contramap ~f:contramap x obj in\n let _d = Fields_derivers_graphql.Graphql_query.wrapped x obj in\n let _e = Fields_derivers_js.Js_layout.wrapped x obj in\n Fields_derivers_json.Of_yojson.map ~f:map x obj\n\n let iso_record ~of_record ~to_record record_deriver obj =\n iso ~map:of_record ~contramap:to_record (record_deriver @@ o ()) obj\n\n let array inner obj : _ Unified_input.t =\n iso ~map:Array.of_list ~contramap:Array.to_list\n ((list @@ inner @@ o ()) (o ()))\n obj\n\n let add_field ?skip_data ~t_fields_annots (x : _ Unified_input.t) fd acc =\n let _, acc' = Graphql.Fields.add_field ~t_fields_annots x fd acc in\n let c1, acc'' =\n Graphql.Args.add_field ?skip_data ~t_fields_annots x fd acc'\n in\n let _, acc''' =\n Fields_derivers_json.To_yojson.add_field ~t_fields_annots x fd acc''\n in\n let c2, acc'''' =\n Fields_derivers_json.Of_yojson.add_field ?skip_data ~t_fields_annots x fd\n acc'''\n in\n let _, acc''''' =\n Fields_derivers_graphql.Graphql_query.add_field ~t_fields_annots x fd\n acc''''\n in\n let _, acc'''''' =\n Fields_derivers_js.Js_layout.add_field ~t_fields_annots x fd acc'''''\n in\n ((function `Left x -> c1 x | `Right x -> c2 x), acc'''''')\n\n let ( !. ) ?skip_data x fd acc = add_field ?skip_data (x @@ o ()) fd acc\n\n let finish name ~t_toplevel_annots (f, acc) =\n let _a =\n Graphql.Fields.finish name ~t_toplevel_annots ((fun x -> f (`Left x)), acc)\n in\n let _b =\n Graphql.Args.finish name ~t_toplevel_annots ((fun x -> f (`Left x)), acc)\n in\n let _c =\n Fields_derivers_json.To_yojson.finish ((fun x -> f (`Right x)), acc)\n in\n let _d =\n Fields_derivers_graphql.Graphql_query.finish ((fun x -> f (`Left x)), acc)\n in\n let _e =\n Fields_derivers_js.Js_layout.finish name ~t_toplevel_annots\n ((fun x -> f (`Left x)), acc)\n in\n Fields_derivers_json.Of_yojson.finish ((fun x -> f (`Right x)), acc)\n\n let needs_custom_js ~js_type ~name deriver obj =\n Fields_derivers_js.Js_layout.needs_custom_js ~name\n (js_type @@ o ())\n (deriver obj)\n\n let balance_change obj =\n let sign_to_string = function\n | Sgn.Pos ->\n \"Positive\"\n | Sgn.Neg ->\n \"Negative\"\n in\n let sign_of_string = function\n | \"Positive\" ->\n Sgn.Pos\n | \"Negative\" ->\n Sgn.Neg\n | _ ->\n failwith \"impossible\"\n in\n let sign_deriver =\n iso_string ~name:\"Sign\" ~js_type:Sign ~to_string:sign_to_string\n ~of_string:sign_of_string\n in\n let ( !. ) = ( !. ) ~t_fields_annots:Currency.Signed_poly.t_fields_annots in\n Currency.Signed_poly.Fields.make_creator obj ~magnitude:!.amount\n ~sgn:!.sign_deriver\n |> finish \"BalanceChange\"\n ~t_toplevel_annots:Currency.Signed_poly.t_toplevel_annots\n\n let to_json obj x = !(obj#to_json) @@ !(obj#contramap) x\n\n let of_json obj x = !(obj#map) @@ !(obj#of_json) x\n\n let js_layout deriver = !((deriver @@ o ())#js_layout)\n\n let typ obj = !(obj#graphql_fields).Graphql.Fields.Input.T.run ()\n\n let arg_typ obj = !(obj#graphql_arg) ()\n\n let inner_query obj = Fields_derivers_graphql.Graphql_query.inner_query obj\n\n let rec json_to_safe : Yojson.Basic.t -> Yojson.Safe.t = function\n | `Assoc kv ->\n `Assoc (List.map kv ~f:(fun (k, v) -> (k, json_to_safe v)))\n | `Bool b ->\n `Bool b\n | `Float f ->\n `Float f\n | `Int i ->\n `Int i\n | `List xs ->\n `List (List.map xs ~f:json_to_safe)\n | `Null ->\n `Null\n | `String s ->\n `String s\n\n (* TODO: remove this or move to a %test_module once the deriver code is stable *)\n (* Can be used to print the graphql schema, like this:\n Fields_derivers_zkapps.Test.print_schema full ;\n *)\n module Test = struct\n module M = struct\n let ( let* ) = Schema.Io.bind\n\n let return = Schema.Io.return\n end\n\n let print_schema (full : _ Unified_input.t) =\n let typ = !(full#graphql_fields).run () in\n let query_top_level =\n Schema.(\n field \"query\" ~typ:(non_null typ)\n ~args:Arg.[]\n ~doc:\"sample query\"\n ~resolve:(fun _ _ -> ()))\n in\n let schema =\n Schema.(schema [ query_top_level ] ~mutations:[] ~subscriptions:[])\n in\n let res : 'a Schema.Io.t =\n Schema.execute schema ()\n (Fields_derivers_graphql.Test.introspection_query ())\n in\n let open Schema.Io in\n bind res (function\n | Ok (`Response data) ->\n data |> Yojson.Basic.to_string |> printf \"%s\" |> return\n | _ ->\n failwith \"Unexpected response\" )\n\n module Loop = struct\n let rec json_to_string_gql : Yojson.Safe.t -> string = function\n | `Assoc kv ->\n sprintf \"{\\n%s\\n}\"\n ( List.map kv ~f:(fun (k, v) ->\n sprintf \"%s: %s\"\n (Fields_derivers.under_to_camel k)\n (json_to_string_gql v) )\n |> String.concat ~sep:\",\\n\" )\n | `List xs ->\n sprintf \"[\\n%s\\n]\"\n (List.map xs ~f:json_to_string_gql |> String.concat ~sep:\",\\n\")\n | x ->\n Yojson.Safe.to_string x\n\n let arg_query json =\n Printf.sprintf\n {graphql|query LoopIn {\n arg(\n input : %s\n )\n }|graphql}\n (json_to_string_gql json)\n\n let out_query keys =\n Printf.sprintf\n {graphql|\n query LoopOut {\n out %s\n }\n |graphql}\n keys\n\n let run deriver (a : 'a) =\n let schema =\n let in_schema : ('a option ref, unit) Schema.field =\n Schema.(\n field \"arg\" ~typ:(non_null int)\n ~args:Arg.[ arg \"input\" ~typ:(arg_typ deriver) ]\n ~doc:\"sample args query\"\n ~resolve:(fun { ctx; _ } () (input : 'a) ->\n ctx := Some input ;\n 0 ))\n in\n let out_schema : ('a option ref, unit) Schema.field =\n Schema.(\n field \"out\" ~typ:(typ deriver)\n ~args:Arg.[]\n ~doc:\"sample query\"\n ~resolve:(fun { ctx; _ } () -> Option.value_exn !ctx))\n in\n Schema.(\n schema [ in_schema; out_schema ] ~mutations:[] ~subscriptions:[])\n in\n let ctx = ref None in\n let open M in\n let run_query q =\n let x = Graphql_parser.parse q in\n match x with\n | Ok res ->\n Schema.execute schema ctx res\n | Error err ->\n failwithf \"Failed to parse query: %s %s\" q err ()\n in\n (* send json in *)\n let* () =\n let json = to_json deriver a in\n let q = arg_query json in\n let* res = run_query q in\n match res with\n | Ok (`Response _) ->\n return @@ ()\n | Error e ->\n failwithf \"Unexpected response in: %s\"\n (e |> Yojson.Basic.to_string)\n ()\n | _ ->\n failwith \"Unexpected stream in\"\n in\n (* get query *)\n let inner_query =\n Option.value_exn\n (Fields_derivers_graphql.Graphql_query.inner_query deriver)\n in\n (* read json out *)\n let* a' =\n let* res = run_query (out_query inner_query) in\n match res with\n | Ok (`Response json) ->\n let unwrap k json =\n match json with\n | `Assoc kv ->\n List.Assoc.find_exn kv ~equal:String.equal k\n | _ ->\n failwithf \"Expected wrapping %s\" k ()\n in\n let inner = json |> unwrap \"data\" |> unwrap \"out\" in\n of_json deriver (json_to_safe inner) |> return\n | Error e ->\n failwithf \"Unexpected response out: %s\"\n (e |> Yojson.Basic.to_string)\n ()\n | _ ->\n failwith \"Unexpected stream out\"\n in\n [%test_eq: string]\n (Yojson.Safe.to_string (to_json deriver a))\n (Yojson.Safe.to_string (to_json deriver a')) ;\n return ()\n end\n end\nend\n\nmodule Derivers = Make (Fields_derivers_graphql.Schema)\ninclude Derivers\nmodule Js_layout = Fields_derivers_js.Js_layout\n\n[%%ifdef consensus_mechanism]\n\nlet proof obj : _ Unified_input.t =\n let of_string s =\n match Pickles.Side_loaded.Proof.of_base64 s with\n | Ok proof ->\n proof\n | Error _err ->\n raise_invalid_scalar `Proof s\n in\n iso_string obj ~name:\"ZkappProof\" ~js_type:String\n ~to_string:Pickles.Side_loaded.Proof.to_base64 ~of_string\n\nlet verification_key_with_hash obj =\n let verification_key obj =\n let of_string s =\n match Pickles.Side_loaded.Verification_key.of_base64 s with\n | Ok vk ->\n vk\n | Error _err ->\n raise_invalid_scalar `Verification_key s\n in\n Pickles.Side_loaded.Verification_key.(\n iso_string obj ~name:\"VerificationKey\" ~js_type:String\n ~to_string:to_base64 ~of_string ~doc:\"Verification key in Base64 format\")\n in\n let ( !. ) =\n ( !. ) ~t_fields_annots:With_hash.Stable.Latest.t_fields_annots\n in\n With_hash.Stable.Latest.Fields.make_creator ~data:!.verification_key\n ~hash:!.field obj\n |> finish \"VerificationKeyWithHash\"\n ~t_toplevel_annots:With_hash.Stable.Latest.t_toplevel_annots\n\nlet%test_unit \"verification key with hash, roundtrip json\" =\n let open Pickles.Side_loaded.Verification_key in\n (* we do this because the dummy doesn't have a wrap_vk on it *)\n let data = dummy |> to_base58_check |> of_base58_check_exn in\n let v = { With_hash.data; hash = Field.one } in\n let o = verification_key_with_hash @@ o () in\n [%test_eq: (t, Field.t) With_hash.t] v (of_json o (to_json o v))\n\n[%%endif]\n\nlet%test_module \"Test\" =\n ( module struct\n module IO = struct\n type +'a t = 'a\n\n let bind t f = f t\n\n let return t = t\n\n module Stream = struct\n type 'a t = 'a Seq.t\n\n let map t f = Seq.map f t\n\n let iter t f = Seq.iter f t\n\n let close _t = ()\n end\n end\n\n module Field_error = struct\n type t = string\n\n let message_of_field_error t = t\n\n let extensions_of_field_error _t = None\n end\n\n module Schema = Graphql_schema.Make (IO) (Field_error)\n module Derivers = Make (Schema)\n include Derivers\n module Public_key = Signature_lib.Public_key.Compressed\n\n module Or_ignore_test = struct\n type 'a t = Check of 'a | Ignore [@@deriving compare, sexp, equal]\n\n let of_option = function None -> Ignore | Some x -> Check x\n\n let to_option = function Ignore -> None | Check x -> Some x\n\n let to_yojson a x = [%to_yojson: 'a option] a (to_option x)\n\n let of_yojson a x = Result.map ~f:of_option ([%of_yojson: 'a option] a x)\n\n let derived inner init =\n iso ~map:of_option ~contramap:to_option\n ((option ~js_type:Flagged_option @@ inner @@ o ()) (o ()))\n init\n end\n\n module V = struct\n type t =\n { foo : int\n ; foo1 : Unsigned_extended.UInt64.t\n ; bar : Unsigned_extended.UInt64.t Or_ignore_test.t\n ; baz : Unsigned_extended.UInt32.t list\n }\n [@@deriving annot, compare, sexp, equal, fields, yojson]\n\n let v =\n { foo = 1\n ; foo1 = Unsigned.UInt64.of_int 10\n ; bar = Or_ignore_test.Check (Unsigned.UInt64.of_int 10)\n ; baz = Unsigned.UInt32.[ of_int 11; of_int 12 ]\n }\n\n let ( !. ) = ( !. ) ~t_fields_annots\n\n let derivers obj =\n Fields.make_creator obj ~foo:!.int ~foo1:!.uint64\n ~bar:!.(Or_ignore_test.derived uint64)\n ~baz:!.(list @@ uint32 @@ o ())\n |> finish \"V\" ~t_toplevel_annots\n end\n\n let v1 = V.derivers @@ o ()\n\n let%test_unit \"full roundtrips\" = Test.Loop.run v1 V.v\n\n module V2 = struct\n type t = { field : Field.t; nothing : unit [@skip] }\n [@@deriving annot, compare, sexp, equal, fields]\n\n let v = { field = Field.of_int 10; nothing = () }\n\n let derivers obj =\n let open Derivers in\n let ( !. ) ?skip_data = ( !. ) ?skip_data ~t_fields_annots in\n Fields.make_creator obj ~field:!.field\n ~nothing:(( !. ) ~skip_data:() skip)\n |> finish \"V2\" ~t_toplevel_annots\n end\n\n let v2 = V2.derivers @@ Derivers.o ()\n\n let%test_unit \"to_json'\" =\n let open Derivers in\n [%test_eq: string]\n (Yojson.Safe.to_string (to_json v2 V2.v))\n {|{\"field\":\"10\"}|}\n\n let%test_unit \"roundtrip json'\" =\n let open Derivers in\n [%test_eq: V2.t] (of_json v2 (to_json v2 V2.v)) V2.v\n\n module V3 = struct\n type t = { public_key : Public_key.t }\n [@@deriving annot, compare, sexp, equal, fields]\n\n let v =\n { public_key =\n Public_key.of_base58_check_exn\n \"B62qoTqMG41DFgkyQmY2Pos1x671Gfzs9k8NKqUdSg7wQasEV6qnXQP\"\n }\n\n let derivers obj =\n let open Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~public_key:!.public_key\n |> finish \"V3\" ~t_toplevel_annots\n end\n\n let v3 = V3.derivers @@ Derivers.o ()\n\n let%test_unit \"to_json'\" =\n let open Derivers in\n [%test_eq: string]\n (Yojson.Safe.to_string (to_json v3 V3.v))\n {|{\"publicKey\":\"B62qoTqMG41DFgkyQmY2Pos1x671Gfzs9k8NKqUdSg7wQasEV6qnXQP\"}|}\n\n let%test_unit \"roundtrip json'\" =\n let open Derivers in\n [%test_eq: V3.t] (of_json v3 (to_json v3 V3.v)) V3.v\n end )\n","(* state_hash.ml -- defines the type for the protocol state hash *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\ninclude Data_hash.Make_full_size (struct\n let version_byte = Base58_check.Version_bytes.state_hash\n\n let description = \"State hash\"\nend)\n\nlet dummy = of_hash Outside_hash_image.t\n\n[%%ifdef consensus_mechanism]\n\nlet zero = dummy\n\n[%%else]\n\n(* in the nonconsensus world, we don't have the Pedersen machinery available,\n so just inline the value for zero\n*)\nlet zero = Field.of_string \"0\"\n\n[%%endif]\n\nlet raw_hash_bytes = to_bytes\n\nlet to_bytes = `Use_to_base58_check_or_raw_hash_bytes\n\nlet to_decimal_string = to_decimal_string\n\nlet of_decimal_string = of_decimal_string\n\n(* Data hash versioned boilerplate below *)\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\nend]\n\nlet (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\nlet deriver obj =\n Fields_derivers_zkapps.(\n iso_string ~name:\"StateHash\" ~js_type:Field ~to_string:to_base58_check\n ~of_string:of_base58_check_exn\n |> needs_custom_js ~name:\"StateHash\" ~js_type:field)\n obj\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nmodule Proof_level = struct\n type t = Full | Check | None [@@deriving bin_io_unversioned, equal]\n\n let to_string = function Full -> \"full\" | Check -> \"check\" | None -> \"none\"\n\n let of_string = function\n | \"full\" ->\n Full\n | \"check\" ->\n Check\n | \"none\" ->\n None\n | s ->\n failwithf \"unrecognised proof level %s\" s ()\n\n [%%inject \"compiled\", proof_level]\n\n let compiled = of_string compiled\n\n let for_unit_tests = Check\nend\n\nmodule Fork_constants = struct\n type t =\n { previous_state_hash : Pickles.Backend.Tick.Field.Stable.Latest.t\n ; previous_length : Mina_numbers.Length.Stable.Latest.t\n ; genesis_slot : Mina_numbers.Global_slot_since_genesis.Stable.Latest.t\n }\n [@@deriving bin_io_unversioned, sexp, equal, compare, yojson]\nend\n\n(** Constants that affect the constraint systems for proofs (and thus also key\n generation).\n\n Care must be taken to ensure that these match against the proving/\n verification keys when [proof_level=Full], otherwise generated proofs will\n be invalid.\n*)\nmodule Constraint_constants = struct\n type t =\n { sub_windows_per_window : int\n ; ledger_depth : int\n ; work_delay : int\n ; block_window_duration_ms : int\n ; transaction_capacity_log_2 : int\n ; pending_coinbase_depth : int\n ; coinbase_amount : Currency.Amount.Stable.Latest.t\n ; supercharged_coinbase_factor : int\n ; account_creation_fee : Currency.Fee.Stable.Latest.t\n ; fork : Fork_constants.t option\n }\n [@@deriving bin_io_unversioned, sexp, equal, compare, yojson]\n\n let to_snark_keys_header (t : t) : Snark_keys_header.Constraint_constants.t =\n { sub_windows_per_window = t.sub_windows_per_window\n ; ledger_depth = t.ledger_depth\n ; work_delay = t.work_delay\n ; block_window_duration_ms = t.block_window_duration_ms\n ; transaction_capacity = Log_2 t.transaction_capacity_log_2\n ; pending_coinbase_depth = t.pending_coinbase_depth\n ; coinbase_amount = Currency.Amount.to_uint64 t.coinbase_amount\n ; supercharged_coinbase_factor = t.supercharged_coinbase_factor\n ; account_creation_fee = Currency.Fee.to_uint64 t.account_creation_fee\n ; fork =\n ( match t.fork with\n | Some { previous_length; previous_state_hash; genesis_slot } ->\n Some\n { previous_length = Unsigned.UInt32.to_int previous_length\n ; previous_state_hash =\n Pickles.Backend.Tick.Field.to_string previous_state_hash\n ; genesis_slot =\n Unsigned.UInt32.to_int\n (Mina_numbers.Global_slot_since_genesis.to_uint32\n genesis_slot )\n }\n | None ->\n None )\n }\n\n (* Generate the compile-time constraint constants, using a signature to hide\n the optcomp constants that we import.\n *)\n include (\n struct\n [%%ifdef consensus_mechanism]\n\n [%%inject \"sub_windows_per_window\", sub_windows_per_window]\n\n [%%else]\n\n (* Invalid value, this should not be used by nonconsensus nodes. *)\n let sub_windows_per_window = -1\n\n [%%endif]\n\n [%%inject \"ledger_depth\", ledger_depth]\n\n [%%inject \"coinbase_amount_string\", coinbase]\n\n [%%inject \"account_creation_fee_string\", account_creation_fee_int]\n\n (** All the proofs before the last [work_delay] blocks must be\n completed to add transactions. [work_delay] is the minimum number\n of blocks and will increase if the throughput is less.\n - If [work_delay = 0], all the work that was added to the scan\n state in the previous block is expected to be completed and\n included in the current block if any transactions/coinbase are to\n be included.\n - [work_delay >= 1] means that there's at least two block times for\n completing the proofs.\n *)\n\n [%%inject \"work_delay\", scan_state_work_delay]\n\n [%%inject \"block_window_duration_ms\", block_window_duration]\n\n [%%if scan_state_with_tps_goal]\n\n [%%inject \"tps_goal_x10\", scan_state_tps_goal_x10]\n\n let max_coinbases = 2\n\n (* block_window_duration is in milliseconds, so divide by 1000 divide\n by 10 again because we have tps * 10\n *)\n let max_user_commands_per_block =\n tps_goal_x10 * block_window_duration_ms / (1000 * 10)\n\n (** Log of the capacity of transactions per transition.\n - 1 will only work if we don't have prover fees.\n - 2 will work with prover fees, but not if we want a transaction\n included in every block.\n - At least 3 ensures a transaction per block and the staged-ledger\n unit tests pass.\n *)\n let transaction_capacity_log_2 =\n 1\n + Core_kernel.Int.ceil_log2 (max_user_commands_per_block + max_coinbases)\n\n [%%else]\n\n [%%inject\n \"transaction_capacity_log_2\", scan_state_transaction_capacity_log_2]\n\n [%%endif]\n\n [%%inject \"supercharged_coinbase_factor\", supercharged_coinbase_factor]\n\n let pending_coinbase_depth =\n Core_kernel.Int.ceil_log2\n (((transaction_capacity_log_2 + 1) * (work_delay + 1)) + 1)\n\n [%%ifndef fork_previous_length]\n\n let fork = None\n\n [%%else]\n\n [%%inject \"fork_previous_length\", fork_previous_length]\n\n [%%inject \"fork_previous_state_hash\", fork_previous_state_hash]\n\n [%%inject \"fork_genesis_slot\", fork_genesis_slot]\n\n let fork =\n Some\n { Fork_constants.previous_state_hash =\n Data_hash_lib.State_hash.of_base58_check_exn\n fork_previous_state_hash\n ; previous_length = Mina_numbers.Length.of_int fork_previous_length\n ; genesis_slot =\n Mina_numbers.Global_slot_since_genesis.of_int fork_genesis_slot\n }\n\n [%%endif]\n\n let compiled =\n { sub_windows_per_window\n ; ledger_depth\n ; work_delay\n ; block_window_duration_ms\n ; transaction_capacity_log_2\n ; pending_coinbase_depth\n ; coinbase_amount =\n Currency.Amount.of_mina_string_exn coinbase_amount_string\n ; supercharged_coinbase_factor\n ; account_creation_fee =\n Currency.Fee.of_mina_string_exn account_creation_fee_string\n ; fork\n }\n end :\n sig\n val compiled : t\n end )\n\n let for_unit_tests = compiled\nend\n\n(*Constants that can be specified for generating the base proof (that are not required for key-generation) in runtime_genesis_ledger.exe and that can be configured at runtime.\n The types are defined such that this module doesn't depend on any of the coda libraries (except blake2 and module_version) to avoid dependency cycles.\n TODO: #4659 move key generation to runtime_genesis_ledger.exe to include scan_state constants, consensus constants (c and block_window_duration) and ledger depth here*)\n\nlet genesis_timestamp_of_string str =\n let default_zone = Time.Zone.of_utc_offset ~hours:(-8) in\n Time.of_string_gen\n ~find_zone:(fun _ -> assert false)\n ~default_zone:(fun () -> default_zone)\n str\n\nlet of_time t = Time.to_span_since_epoch t |> Time.Span.to_ms |> Int64.of_float\n\nlet validate_time time_str =\n match\n Result.try_with (fun () ->\n Option.value_map ~default:(Time.now ()) ~f:genesis_timestamp_of_string\n time_str )\n with\n | Ok time ->\n Ok (of_time time)\n | Error _ ->\n Error\n \"Invalid timestamp. Please specify timestamp in \\\"%Y-%m-%d \\\n %H:%M:%S%z\\\". For example, \\\"2019-01-30 12:00:00-0800\\\" for UTC-08:00 \\\n timezone\"\n\nlet genesis_timestamp_to_string time =\n Int64.to_float time |> Time.Span.of_ms |> Time.of_span_since_epoch\n |> Time.to_string_iso8601_basic ~zone:(Time.Zone.of_utc_offset ~hours:(-8))\n\n(*Protocol constants required for consensus and snarks. Consensus constants is generated using these*)\nmodule Protocol = struct\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('length, 'delta, 'genesis_state_timestamp) t =\n ( 'length\n , 'delta\n , 'genesis_state_timestamp )\n Mina_wire_types.Genesis_constants.Protocol.Poly.V1.t =\n { k : 'length\n ; slots_per_epoch : 'length\n ; slots_per_sub_window : 'length\n ; delta : 'delta\n ; genesis_state_timestamp : 'genesis_state_timestamp\n }\n [@@deriving equal, ord, hash, sexp, yojson, hlist, fields]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = (int, int, (Int64.t[@version_asserted])) Poly.Stable.V1.t\n [@@deriving equal, ord, hash]\n\n let to_latest = Fn.id\n\n let to_yojson (t : t) =\n `Assoc\n [ (\"k\", `Int t.k)\n ; (\"slots_per_epoch\", `Int t.slots_per_epoch)\n ; (\"slots_per_sub_window\", `Int t.slots_per_sub_window)\n ; (\"delta\", `Int t.delta)\n ; ( \"genesis_state_timestamp\"\n , `String\n (Time.to_string_abs\n (Time.of_span_since_epoch\n (Time.Span.of_ms\n (Int64.to_float t.genesis_state_timestamp) ) )\n ~zone:Time.Zone.utc ) )\n ]\n\n let of_yojson = function\n | `Assoc\n [ (\"k\", `Int k)\n ; (\"slots_per_epoch\", `Int slots_per_epoch)\n ; (\"slots_per_sub_window\", `Int slots_per_sub_window)\n ; (\"delta\", `Int delta)\n ; (\"genesis_state_timestamp\", `String time_str)\n ] -> (\n match validate_time time_str with\n | Ok genesis_state_timestamp ->\n Ok\n { Poly.k\n ; slots_per_epoch\n ; slots_per_sub_window\n ; delta\n ; genesis_state_timestamp\n }\n | Error e ->\n Error (sprintf !\"Genesis_constants.Protocol.of_yojson: %s\" e) )\n | _ ->\n Error \"Genesis_constants.Protocol.of_yojson: unexpected JSON\"\n\n let t_of_sexp _ = failwith \"t_of_sexp: not implemented\"\n\n let sexp_of_t (t : t) =\n let module T = struct\n type t = (int, int, string) Poly.Stable.V1.t [@@deriving sexp]\n end in\n let t' : T.t =\n { k = t.k\n ; delta = t.delta\n ; slots_per_epoch = t.slots_per_epoch\n ; slots_per_sub_window = t.slots_per_sub_window\n ; genesis_state_timestamp =\n Time.to_string_abs\n (Time.of_span_since_epoch\n (Time.Span.of_ms (Int64.to_float t.genesis_state_timestamp)) )\n ~zone:Time.Zone.utc\n }\n in\n T.sexp_of_t t'\n end\n end]\n\n [%%define_locally Stable.Latest.(to_yojson)]\nend\n\nmodule T = struct\n (* bin_io is for printing chain id inputs *)\n type t =\n { protocol : Protocol.Stable.Latest.t\n ; txpool_max_size : int\n ; num_accounts : int option\n ; zkapp_proof_update_cost : float\n ; zkapp_signed_single_update_cost : float\n ; zkapp_signed_pair_update_cost : float\n ; zkapp_transaction_cost_limit : float\n ; max_event_elements : int\n ; max_action_elements : int\n }\n [@@deriving to_yojson, sexp_of, bin_io_unversioned]\n\n let hash (t : t) =\n let str =\n ( List.map\n (* TODO: *)\n [ t.protocol.k\n ; t.protocol.slots_per_epoch\n ; t.protocol.slots_per_sub_window\n ; t.protocol.delta\n ; t.txpool_max_size\n ]\n ~f:Int.to_string\n |> String.concat ~sep:\"\" )\n ^ Time.to_string_abs ~zone:Time.Zone.utc\n (Time.of_span_since_epoch\n (Time.Span.of_ms\n (Int64.to_float t.protocol.genesis_state_timestamp) ) )\n in\n Blake2.digest_string str |> Blake2.to_hex\nend\n\ninclude T\n\n[%%inject \"genesis_state_timestamp_string\", genesis_state_timestamp]\n\n[%%inject \"k\", k]\n\n[%%inject \"slots_per_epoch\", slots_per_epoch]\n\n[%%inject \"slots_per_sub_window\", slots_per_sub_window]\n\n[%%inject \"delta\", delta]\n\n[%%inject \"pool_max_size\", pool_max_size]\n\nlet compiled : t =\n { protocol =\n { k\n ; slots_per_epoch\n ; slots_per_sub_window\n ; delta\n ; genesis_state_timestamp =\n genesis_timestamp_of_string genesis_state_timestamp_string |> of_time\n }\n ; txpool_max_size = pool_max_size\n ; num_accounts = None\n ; zkapp_proof_update_cost = Mina_compile_config.zkapp_proof_update_cost\n ; zkapp_signed_single_update_cost =\n Mina_compile_config.zkapp_signed_single_update_cost\n ; zkapp_signed_pair_update_cost =\n Mina_compile_config.zkapp_signed_pair_update_cost\n ; zkapp_transaction_cost_limit =\n Mina_compile_config.zkapp_transaction_cost_limit\n ; max_event_elements = Mina_compile_config.max_event_elements\n ; max_action_elements = Mina_compile_config.max_action_elements\n }\n\nlet for_unit_tests = compiled\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params\nopen Tick\nopen Unsigned_extended\nopen Snark_bits\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Block_time\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Intf.S with type Time.t = A.V1.t\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n module Time = struct\n (* Milliseconds since epoch *)\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = UInt64.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n\n module T = struct\n type typ = t [@@deriving sexp, compare, hash]\n\n type t = typ [@@deriving sexp, compare, hash]\n end\n\n include Hashable.Make (T)\n end\n end]\n\n let max_value = UInt64.max_int\n\n let zero = UInt64.zero\n\n module Controller = struct\n [%%if time_offsets]\n\n type t = unit -> Time.Span.t [@@deriving sexp]\n\n (* NB: All instances are identical by construction (see basic below). *)\n let equal _ _ = true\n\n (* NB: All instances are identical by construction (see basic below). *)\n let compare _ _ = 0\n\n let time_offset = ref None\n\n let setting_enabled = ref None\n\n let disable_setting_offset () = setting_enabled := Some false\n\n let enable_setting_offset () =\n match !setting_enabled with\n | None ->\n setting_enabled := Some true\n | Some true ->\n ()\n | Some false ->\n failwith\n \"Cannot enable time offset mutations; it has been explicitly \\\n disabled\"\n\n let set_time_offset offset =\n match !setting_enabled with\n | Some true ->\n time_offset := Some offset\n | None | Some false ->\n failwith \"Cannot mutate the time offset\"\n\n let create offset = offset\n\n let basic ~logger:_ () =\n match !time_offset with\n | Some offset ->\n offset\n | None ->\n let offset =\n let env = \"MINA_TIME_OFFSET\" in\n let env_offset =\n match Core_kernel.Sys.getenv_opt env with\n | Some tm ->\n Int.of_string tm\n | None ->\n let default = 0 in\n eprintf\n \"Environment variable %s not found, using default of %d\\n\\\n %!\"\n env default ;\n default\n in\n Core_kernel.Time.Span.of_int_sec env_offset\n in\n time_offset := Some offset ;\n offset\n\n let get_time_offset ~logger = basic ~logger ()\n\n [%%else]\n\n type t = unit [@@deriving sexp, equal, compare]\n\n let create () = ()\n\n let basic ~logger:_ = ()\n\n let disable_setting_offset () = ()\n\n let enable_setting_offset () = ()\n\n let set_time_offset _ = failwith \"Cannot mutate the time offset\"\n\n let get_time_offset _ = Core_kernel.Time.Span.of_int_sec 0\n\n [%%endif]\n end\n\n module B = Bits\n module Bits = Bits.UInt64\n include B.Snarkable.UInt64 (Tick)\n module N = Mina_numbers.Nat.Make_checked (UInt64) (Bits)\n\n let to_input (t : t) =\n Random_oracle_input.Chunked.packed\n (Tick.Field.project (Bits.to_bits t), 64)\n\n module Checked = struct\n type t = N.var\n\n module Unsafe = N.Unsafe\n\n let to_input (t : t) = N.to_input t\n\n let to_field = N.to_field\n\n [%%define_locally N.(typ, ( = ), ( <= ), ( >= ), ( < ), ( > ))]\n end\n\n module Span = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = UInt64.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n module Bits = B.UInt64\n include B.Snarkable.UInt64 (Tick)\n\n let of_time_span s = UInt64.of_int64 (Int64.of_float (Time.Span.to_ms s))\n\n let to_time_span s = Time.Span.of_ms (Int64.to_float (UInt64.to_int64 s))\n\n let to_time_ns_span s =\n Time_ns.Span.of_ms (Int64.to_float (UInt64.to_int64 s))\n\n let of_time_ns_span ns : t =\n let int64_ns = ns |> Time_ns.Span.to_int63_ns |> Int63.to_int64 in\n (* convert to milliseconds *)\n Int64.(int64_ns / 1_000_000L) |> UInt64.of_int64\n\n let to_string_hum s = to_time_ns_span s |> Time_ns.Span.to_string_hum\n\n let to_ms = UInt64.to_int64\n\n let of_ms = UInt64.of_int64\n\n [%%define_locally UInt64.Infix.(( + ), ( - ), ( * ))]\n\n [%%define_locally UInt64.(( < ), ( > ), ( = ), ( <= ), ( >= ), min, zero)]\n\n let to_input = to_input\n\n module Checked = Checked\n end\n\n include Comparable.Make (Stable.Latest)\n include Hashable.Make (Stable.Latest)\n\n let of_time t =\n UInt64.of_int64\n (Int64.of_float (Time.Span.to_ms (Time.to_span_since_epoch t)))\n\n (* TODO: Time.t can't hold the full uint64 range, so this can fail for large t *)\n let to_time_exn t =\n let t_int64 = UInt64.to_int64 t in\n if Int64.(t_int64 < zero) then failwith \"converting to negative timestamp\" ;\n Time.of_span_since_epoch (Time.Span.of_ms (Int64.to_float t_int64))\n\n [%%if time_offsets]\n\n let now offset = of_time (Time.sub (Time.now ()) (offset ()))\n\n [%%else]\n\n let now _ = of_time (Time.now ())\n\n [%%endif]\n\n let field_var_to_unpacked (x : Tick.Field.Var.t) =\n Tick.Field.Checked.unpack ~length:64 x\n\n let epoch = of_time Time.epoch\n\n let add x y = UInt64.add x y\n\n let diff x y = UInt64.sub x y\n\n let sub x y = UInt64.sub x y\n\n let to_span_since_epoch t = diff t epoch\n\n let of_span_since_epoch s = UInt64.add s epoch\n\n let diff_checked x y =\n let pack = Tick.Field.Var.project in\n Span.unpack_var Tick.Field.Checked.(pack x - pack y)\n\n let modulus t span = UInt64.rem t span\n\n let unpacked_to_number var =\n let bits = Span.Unpacked.var_to_bits var in\n Number.of_bits (bits :> Boolean.var list)\n\n let to_int64 = Fn.compose Span.to_ms to_span_since_epoch\n\n let of_int64 = Fn.compose of_span_since_epoch Span.of_ms\n\n let of_uint64 : UInt64.t -> t = of_span_since_epoch\n\n let to_uint64 : t -> UInt64.t = to_span_since_epoch\n\n (* TODO: this can fail if the input has more than 63 bits, because it would be serialized to a negative number string *)\n let to_string_exn t =\n let t_int64 = UInt64.to_int64 t in\n if Int64.(t_int64 < zero) then failwith \"converting to negative timestamp\" ;\n Int64.to_string t_int64\n\n let of_time_ns ns : t =\n let int64_ns = ns |> Time_ns.to_int63_ns_since_epoch |> Int63.to_int64 in\n (* convert to milliseconds *)\n Int64.(int64_ns / 1_000_000L) |> UInt64.of_int64\n\n [%%if time_offsets]\n\n let to_system_time (offset : Controller.t) (t : t) =\n of_span_since_epoch\n Span.(to_span_since_epoch t + of_time_span (offset ()))\n\n [%%else]\n\n let to_system_time (_offset : Controller.t) (t : t) = t\n\n [%%endif]\n\n let to_string_system_time_exn (offset : Controller.t) (t : t) : string =\n to_system_time offset t |> to_string_exn\n\n let of_string_exn string =\n Int64.of_string string |> Span.of_ms |> of_span_since_epoch\n\n let gen_incl time_beginning time_end =\n let open Quickcheck.Let_syntax in\n let time_beginning_int64 = to_int64 time_beginning in\n let time_end_int64 = to_int64 time_end in\n let%map int64_time_span =\n Int64.(gen_incl time_beginning_int64 time_end_int64)\n in\n of_span_since_epoch @@ Span.of_ms int64_time_span\n\n let gen =\n let open Quickcheck.Let_syntax in\n let%map int64_time_span = Int64.(gen_incl zero max_value) in\n of_span_since_epoch @@ Span.of_ms int64_time_span\n end\n\n include Time\n module Timeout = Timeout_lib.Make (Time)\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nopen Async_kernel\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type 'a t = [ `One of 'a | `Two of 'a * 'a ]\n [@@deriving equal, compare, hash, sexp, yojson]\n\n let to_latest a_latest = function\n | `One x ->\n `One (a_latest x)\n | `Two (x, y) ->\n `Two (a_latest x, a_latest y)\n\n let of_latest a_latest = function\n | `One x ->\n let open Result.Let_syntax in\n let%map x = a_latest x in\n `One x\n | `Two (x, y) ->\n let open Result.Let_syntax in\n let%map x = a_latest x and y = a_latest y in\n `Two (x, y)\n end\nend]\n\nlet length = function `One _ -> 1 | `Two _ -> 2\n\nlet to_list = function `One a -> [ a ] | `Two (a, b) -> [ a; b ]\n\nlet to_numbered_list = function\n | `One a ->\n [ (0, a) ]\n | `Two (a, b) ->\n [ (0, a); (1, b) ]\n\nlet group_sequence : 'a Sequence.t -> 'a t Sequence.t =\n fun to_group ->\n Sequence.unfold ~init:to_group ~f:(fun acc ->\n match Sequence.next acc with\n | None ->\n None\n | Some (a, rest_1) -> (\n match Sequence.next rest_1 with\n | None ->\n Some (`One a, Sequence.empty)\n | Some (b, rest_2) ->\n Some (`Two (a, b), rest_2) ) )\n\nlet group_list : 'a list -> 'a t list =\n fun xs -> xs |> Sequence.of_list |> group_sequence |> Sequence.to_list\n\nlet zip : 'a t -> 'b t -> ('a * 'b) t Or_error.t =\n fun a b ->\n match (a, b) with\n | `One a1, `One b1 ->\n Ok (`One (a1, b1))\n | `Two (a1, a2), `Two (b1, b2) ->\n Ok (`Two ((a1, b1), (a2, b2)))\n | _ ->\n Or_error.error_string \"One_or_two.zip mismatched\"\n\nlet zip_exn : 'a t -> 'b t -> ('a * 'b) t =\n fun a b -> Or_error.ok_exn @@ zip a b\n\nmodule Monadic2 (M : Monad.S2) :\n Intfs.Monadic2 with type ('a, 'e) m := ('a, 'e) M.t = struct\n let sequence : ('a, 'e) M.t t -> ('a t, 'e) M.t = function\n | `One def ->\n M.map def ~f:(fun x -> `One x)\n | `Two (def1, def2) ->\n let open M.Let_syntax in\n let%bind a = def1 in\n let%map b = def2 in\n `Two (a, b)\n\n let map : 'a t -> f:('a -> ('b, 'e) M.t) -> ('b t, 'e) M.t =\n fun t ~f ->\n (* We could use sequence here, but this approach saves us computation in the\n Result and option monads when the first component of a `Two fails. *)\n match t with\n | `One a ->\n M.map ~f:(fun x -> `One x) (f a)\n | `Two (a, b) ->\n let open M.Let_syntax in\n let%bind a' = f a in\n let%map b' = f b in\n `Two (a', b')\n\n let fold :\n 'a t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'e) M.t)\n -> ('accum, 'e) M.t =\n fun t ~init ~f ->\n match t with\n | `One a ->\n f init a\n | `Two (a, b) ->\n M.bind (f init a) ~f:(fun x -> f x b)\nend\n\nmodule Monadic (M : Monad.S) : Intfs.Monadic with type 'a m := 'a M.t =\n Monadic2 (Base__.Monad_intf.S_to_S2 (M))\n\nmodule Deferred_result = Monadic2 (Deferred.Result)\nmodule Ident = Monadic (Monad.Ident)\nmodule Deferred = Monadic (Deferred)\nmodule Option = Monadic (Option)\nmodule Or_error = Monadic (Or_error)\n\nlet map = Ident.map\n\nlet fold = Ident.fold\n\nlet iter t ~f = match t with `One a -> f a | `Two (a, b) -> f a ; f b\n\nlet fold_until ~init ~f ~finish t =\n Container.fold_until ~fold ~init ~f ~finish t\n\nlet gen inner_gen =\n Quickcheck.Generator.(\n union\n [ map inner_gen ~f:(fun x -> `One x)\n ; map (tuple2 inner_gen inner_gen) ~f:(fun pair -> `Two pair)\n ])\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_import\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Account_id\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Account_id_intf.S\n with type Digest.Stable.V1.t = A.Digest.V1.t\n and type Stable.V2.t = A.V2.t\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n let invalid = (Public_key.Compressed.empty, Pickles.Backend.Tick.Field.zero)\n\n module Digest = struct\n [%%ifdef consensus_mechanism]\n\n let of_bigstring_exn =\n Binable.of_bigstring (module Pickles.Backend.Tick.Field.Stable.Latest)\n\n let to_bigstring =\n Binable.to_bigstring (module Pickles.Backend.Tick.Field.Stable.Latest)\n\n [%%else]\n\n let of_bigstring_exn =\n Binable.of_bigstring (module Snark_params.Tick.Field.Stable.Latest)\n\n let to_bigstring =\n Binable.to_bigstring (module Snark_params.Tick.Field.Stable.Latest)\n\n [%%endif]\n\n module Base58_check = Base58_check.Make (struct\n let description = \"Token ID\"\n\n let version_byte = Base58_check.Version_bytes.token_id_key\n end)\n\n let to_base58_check t : string =\n Base58_check.encode (to_bigstring t |> Bigstring.to_string)\n\n let of_base58_check_exn (s : string) =\n let decoded = Base58_check.decode_exn s in\n decoded |> Bigstring.of_string |> of_bigstring_exn\n\n let to_string = to_base58_check\n\n let of_string = of_base58_check_exn\n\n let of_field = Fn.id\n\n let to_field_unsafe = Fn.id\n\n [%%ifdef consensus_mechanism]\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Pickles.Backend.Tick.Field.Stable.V1.t\n [@@deriving sexp, equal, compare, hash]\n\n let to_yojson (t : t) : Yojson.Safe.t = `String (to_string t)\n\n let of_yojson (j : Yojson.Safe.t) : (t, string) result =\n try Ok (of_string (Yojson.Safe.Util.to_string j))\n with e -> Error (Exn.to_string e)\n\n let to_latest = Fn.id\n end\n end]\n\n [%%else]\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Snark_params.Tick.Field.Stable.V1.t\n [@@deriving sexp, equal, compare, hash]\n\n let to_yojson (t : t) : Yojson.Safe.t = `String (to_string t)\n\n let of_yojson (j : Yojson.Safe.t) : (t, string) result =\n try Ok (of_string (Yojson.Safe.Util.to_string j))\n with e -> Error (Exn.to_string e)\n\n let to_latest = Fn.id\n end\n end]\n\n [%%endif]\n\n [%%define_locally Stable.Latest.(of_yojson, to_yojson)]\n\n module Binables = struct\n include Comparable.Make_binable (Stable.Latest)\n include Hashable.Make_binable (Stable.Latest)\n end\n\n include Binables\n\n let to_input : t -> _ Random_oracle_input.Chunked.t =\n Random_oracle_input.Chunked.field\n\n (* Just matters that this no one can find a preimage to this with poseidon.\n Chose 1 for consistency for the old uint64 based token IDs *)\n let default : t = Snark_params.Tick.Field.one\n\n let gen : t Quickcheck.Generator.t = Snark_params.Tick.Field.gen\n\n let gen_non_default =\n Quickcheck.Generator.filter gen ~f:(fun x -> not (equal x default))\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n open Pickles.Impls.Step\n\n type t = Field.t\n\n let to_input : t -> _ Random_oracle_input.Chunked.t =\n Random_oracle_input.Chunked.field\n\n let constant : Stable.Latest.t -> t = Field.constant\n\n let equal : t -> t -> Boolean.var = Field.equal\n\n let if_ = Field.if_\n\n let of_field = Fn.id\n\n let to_field_unsafe = Fn.id\n\n module Assert = struct\n let equal : t -> t -> unit = Field.Assert.equal\n end\n end\n\n let typ = Snark_params.Tick.Field.typ\n\n [%%endif]\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Public_key.Compressed.Stable.V1.t * Digest.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let create key tid = (key, tid)\n\n let empty : t = (Public_key.Compressed.empty, Digest.default)\n\n let public_key (key, _tid) = key\n\n let of_public_key (pk : Public_key.t) =\n create (Public_key.compress pk) Digest.default\n\n let token_id (_key, id) = id\n\n let to_input ((key, tid) : t) =\n Random_oracle_input.Chunked.(\n append (Public_key.Compressed.to_input key) (field tid))\n\n let derive_token_id ~(owner : t) : Digest.t =\n Random_oracle.hash ~init:Hash_prefix.derive_token_id\n (Random_oracle.pack_input (to_input owner))\n\n let gen =\n let open Quickcheck.Let_syntax in\n let%map key = Public_key.Compressed.gen and tid = Digest.gen in\n (key, tid)\n\n include Comparable.Make_binable (Stable.Latest)\n include Hashable.Make_binable (Stable.Latest)\n\n let to_input ((key, tid) : t) =\n Random_oracle.Input.Chunked.append\n (Public_key.Compressed.to_input key)\n (Digest.to_input tid)\n\n [%%ifdef consensus_mechanism]\n\n type var = Public_key.Compressed.var * Digest.Checked.t\n\n let typ = Snarky_backendless.Typ.(Public_key.Compressed.typ * Digest.typ)\n\n let var_of_t ((key, tid) : t) =\n ( Public_key.Compressed.var_of_t key\n , Snark_params.Tick.Field.Var.constant tid )\n\n module Checked = struct\n open Snark_params\n open Tick\n\n let create key tid = (key, tid)\n\n let public_key (key, _tid) = key\n\n let token_id (_key, tid) = tid\n\n let to_input ((key, tid) : var) =\n let tid = Digest.Checked.to_input tid in\n Random_oracle.Input.Chunked.append\n (Public_key.Compressed.Checked.to_input key)\n tid\n\n let derive_token_id ~(owner : var) : Digest.Checked.t =\n Random_oracle.Checked.hash ~init:Hash_prefix.derive_token_id\n (Random_oracle.Checked.pack_input (to_input owner))\n\n let equal (pk1, tid1) (pk2, tid2) =\n let%bind pk_equal = Public_key.Compressed.Checked.equal pk1 pk2 in\n let%bind tid_equal = Snark_params.Tick.Field.Checked.equal tid1 tid2 in\n Tick.Boolean.(pk_equal && tid_equal)\n\n let if_ b ~then_:(pk_then, tid_then) ~else_:(pk_else, tid_else) =\n let%bind pk =\n Public_key.Compressed.Checked.if_ b ~then_:pk_then ~else_:pk_else\n in\n let%map tid =\n Snark_params.Tick.Field.Checked.if_ b ~then_:tid_then ~else_:tid_else\n in\n (pk, tid)\n end\n\n [%%endif]\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params\nopen Tick\nopen Currency\nopen Mina_numbers\n\n(* A timed account is an account, which releases its balance to be spent\n gradually. The process of releasing frozen funds is defined as follows.\n Until the cliff_time global slot is reached, the initial_minimum_balance\n of mina is frozen and cannot be spent. At the cliff slot, cliff_amount\n is released and initial_minimum_balance is effectively lowered by that\n amount. Next, every vesting_period number of slots, vesting_increment\n is released, further decreasing the current minimum balance. At some\n point minimum balance drops to 0, and after that the account behaves\n like an untimed one. *)\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('slot, 'slot_span, 'balance, 'amount) t =\n | Untimed\n | Timed of\n { initial_minimum_balance : 'balance\n ; cliff_time : 'slot\n ; cliff_amount : 'amount\n ; vesting_period : 'slot_span\n ; vesting_increment : 'amount\n }\n [@@deriving sexp, equal, hash, compare, yojson]\n end\n end]\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n ( Global_slot_since_genesis.Stable.V1.t\n , Global_slot_span.Stable.V1.t\n , Balance.Stable.V1.t\n , Amount.Stable.V1.t )\n Poly.Stable.V2.t\n [@@deriving sexp, equal, hash, compare, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\ntype ('slot, 'slot_span, 'balance, 'amount) tt =\n ('slot, 'slot_span, 'balance, 'amount) Poly.t =\n | Untimed\n | Timed of\n { initial_minimum_balance : 'balance\n ; cliff_time : 'slot\n ; cliff_amount : 'amount\n ; vesting_period : 'slot_span\n ; vesting_increment : 'amount\n }\n[@@deriving sexp, equal, hash, compare, yojson]\n\nmodule As_record = struct\n type ('bool, 'slot, 'slot_span, 'balance, 'amount) t =\n { is_timed : 'bool\n ; initial_minimum_balance : 'balance\n ; cliff_time : 'slot\n ; cliff_amount : 'amount\n ; vesting_period : 'slot_span\n ; vesting_increment : 'amount\n }\n [@@deriving equal, hlist, fields, annot]\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~is_timed:!.bool ~initial_minimum_balance:!.balance\n ~cliff_time:!.global_slot_since_genesis\n ~cliff_amount:!.amount ~vesting_period:!.global_slot_span\n ~vesting_increment:!.amount\n |> finish \"AccountTiming\" ~t_toplevel_annots\nend\n\ntype as_record =\n ( bool\n , Global_slot_since_genesis.Stable.V1.t\n , Global_slot_span.Stable.V1.t\n , Balance.Stable.V1.t\n , Amount.Stable.V1.t )\n As_record.t\n\n(* convert sum type to record format, useful for to_bits and typ *)\nlet to_record t =\n match t with\n | Untimed ->\n let slot_unused = Global_slot_since_genesis.zero in\n let slot_span_one = Global_slot_span.(succ zero) in\n let balance_unused = Balance.zero in\n let amount_unused = Amount.zero in\n { As_record.is_timed = false\n ; initial_minimum_balance = balance_unused\n ; cliff_time = slot_unused\n ; cliff_amount = amount_unused\n ; vesting_period = slot_span_one (* avoid division by zero *)\n ; vesting_increment = amount_unused\n }\n | Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } ->\n { is_timed = true\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n\nlet of_record\n { As_record.is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } : t =\n if is_timed then\n Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n else Untimed\n\nlet of_record (r : as_record) : t =\n if r.is_timed then\n Timed\n { initial_minimum_balance = r.initial_minimum_balance\n ; cliff_time = r.cliff_time\n ; cliff_amount = r.cliff_amount\n ; vesting_period = r.vesting_period\n ; vesting_increment = r.vesting_increment\n }\n else Untimed\n\nlet to_input t =\n let As_record.\n { is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } =\n to_record t\n in\n let open Random_oracle_input.Chunked in\n Array.reduce_exn ~f:append\n [| packed ((if is_timed then Field.one else Field.zero), 1)\n ; Balance.to_input initial_minimum_balance\n ; Global_slot_since_genesis.to_input cliff_time\n ; Amount.to_input cliff_amount\n ; Global_slot_span.to_input vesting_period\n ; Amount.to_input vesting_increment\n |]\n\n[%%ifdef consensus_mechanism]\n\ntype var =\n ( Boolean.var\n , Global_slot_since_genesis.Checked.var\n , Global_slot_span.Checked.var\n , Balance.var\n , Amount.var )\n As_record.t\n\nlet var_to_input\n As_record.\n { is_timed : Boolean.var\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } =\n let open Random_oracle_input.Chunked in\n Array.reduce_exn ~f:append\n [| packed ((is_timed :> Field.Var.t), 1)\n ; Balance.var_to_input initial_minimum_balance\n ; Global_slot_since_genesis.Checked.to_input cliff_time\n ; Amount.var_to_input cliff_amount\n ; Global_slot_span.Checked.to_input vesting_period\n ; Amount.var_to_input vesting_increment\n |]\n\nlet var_of_t (t : t) : var =\n let { As_record.is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } =\n to_record t\n in\n { is_timed = Boolean.var_of_value is_timed\n ; initial_minimum_balance = Balance.var_of_t initial_minimum_balance\n ; cliff_time = Global_slot_since_genesis.Checked.constant cliff_time\n ; cliff_amount = Amount.var_of_t cliff_amount\n ; vesting_period = Global_slot_span.Checked.constant vesting_period\n ; vesting_increment = Amount.var_of_t vesting_increment\n }\n\nlet untimed_var = var_of_t Untimed\n\nlet typ : (var, t) Typ.t =\n (* because we represent the types t (a sum type) and var (a record) differently,\n we can't use the trick, used elsewhere, of polymorphic to_hlist and of_hlist\n functions to handle both types\n *)\n let value_of_hlist :\n ( unit\n , Boolean.value\n -> Balance.t\n -> Global_slot_since_genesis.t\n -> Amount.t\n -> Global_slot_span.t\n -> Amount.t\n -> unit )\n H_list.t\n -> t =\n let open H_list in\n fun [ is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n ] ->\n if is_timed then\n Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n else Untimed\n in\n let value_to_hlist (t : t) =\n let As_record.\n { is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } =\n to_record t\n in\n H_list.\n [ is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n ]\n in\n let var_of_hlist = As_record.of_hlist in\n let var_to_hlist = As_record.to_hlist in\n Typ.of_hlistable\n [ Boolean.typ\n ; Balance.typ\n ; Global_slot_since_genesis.typ\n ; Amount.typ\n ; Global_slot_span.typ\n ; Amount.typ\n ]\n ~var_to_hlist ~var_of_hlist ~value_to_hlist ~value_of_hlist\n\n(* we can't use the generic if_ with the above typ, because Global_slot_since_genesis.typ doesn't work correctly with it\n so we define a custom if_\n*)\nlet if_ b ~(then_ : var) ~(else_ : var) =\n let%bind is_timed =\n Boolean.if_ b ~then_:then_.is_timed ~else_:else_.is_timed\n in\n let%bind initial_minimum_balance =\n Balance.Checked.if_ b ~then_:then_.initial_minimum_balance\n ~else_:else_.initial_minimum_balance\n in\n let%bind cliff_time =\n Global_slot_since_genesis.Checked.if_ b ~then_:then_.cliff_time\n ~else_:else_.cliff_time\n in\n let%bind cliff_amount =\n Amount.Checked.if_ b ~then_:then_.cliff_amount ~else_:else_.cliff_amount\n in\n let%bind vesting_period =\n Global_slot_span.Checked.if_ b ~then_:then_.vesting_period\n ~else_:else_.vesting_period\n in\n let%map vesting_increment =\n Amount.Checked.if_ b ~then_:then_.vesting_increment\n ~else_:else_.vesting_increment\n in\n { As_record.is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n\nlet deriver obj =\n let open Fields_derivers_zkapps in\n iso_record ~to_record ~of_record As_record.deriver obj\n\n[%%endif]\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('field, 'scalar) t = 'field * 'scalar\n [@@deriving sexp, compare, equal, hash]\n end\n end]\nend\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t =\n ( (Field.t[@version_asserted])\n , (Inner_curve.Scalar.t[@version_asserted]) )\n Poly.Stable.V1.t\n [@@deriving sexp, compare, equal, hash]\n\n module Codable_arg = struct\n (* version tag for compatibility with pre-Berkeley hard fork\n Base58Check-serialized signatures\n *)\n type t =\n (Field.t, Inner_curve.Scalar.t) Poly.Stable.V1.With_all_version_tags.t\n [@@deriving bin_io_unversioned]\n\n let description = \"Signature\"\n\n let version_byte = Base58_check.Version_bytes.signature\n end\n\n (* Base58Check encodes t *)\n let (_ : (t, Codable_arg.t) Type_equal.t) = Type_equal.T\n\n include Codable.Make_base58_check (Codable_arg)\n\n let to_latest = Fn.id\n\n let gen = Quickcheck.Generator.tuple2 Field.gen Inner_curve.Scalar.gen\n end\nend]\n\nlet dummy = (Field.one, Inner_curve.Scalar.one)\n\nlet gen = Stable.Latest.gen\n\nmodule Raw = struct\n open Rosetta_coding.Coding\n\n let encode (field, scalar) = of_field field ^ of_scalar scalar\n\n let decode raw =\n let len = String.length raw in\n let field_len = len / 2 in\n let field_enc = String.sub raw ~pos:0 ~len:field_len in\n let scalar_enc = String.sub raw ~pos:field_len ~len:field_len in\n try Some (to_field field_enc, to_scalar scalar_enc) with _ -> None\nend\n\n[%%ifdef consensus_mechanism]\n\ntype var = Field.Var.t * Inner_curve.Scalar.var\n\n[%%endif]\n\n[%%define_locally\nStable.Latest.\n (of_base58_check_exn, of_base58_check, of_yojson, to_yojson, to_base58_check)]\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n(* TODO: temporary hack *)\n[%%ifdef consensus_mechanism]\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Control.V2.t =\n | Proof of Pickles.Side_loaded.Proof.Stable.V2.t\n | Signature of Signature.Stable.V1.t\n | None_given\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\nend]\n\n(* lazy, to prevent spawning Rust threads at startup, which prevents daemonization *)\nlet gen_with_dummies : t Quickcheck.Generator.t =\n let gen =\n lazy\n (Quickcheck.Generator.of_list\n (let dummy_proof =\n let n2 = Pickles_types.Nat.N2.n in\n let proof = Pickles.Proof.dummy n2 n2 n2 ~domain_log2:15 in\n Proof proof\n in\n let dummy_signature = Signature Signature.dummy in\n [ dummy_proof; dummy_signature; None_given ] ) )\n in\n Quickcheck.Generator.create (fun ~size ~random ->\n Quickcheck.Generator.generate (Lazy.force gen) ~size ~random )\n\n[%%else]\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Proof of unit | Signature of Signature.Stable.V1.t | None_given\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n type t =\n | Proof of unit\n | Signature of Signature.Stable.V1.t\n | Both of { signature : Signature.Stable.V1.t; proof : unit }\n | None_given\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest : t -> V2.t = function\n | Proof proof ->\n Proof proof\n | Signature signature ->\n Signature signature\n | None_given ->\n None_given\n | Both _ ->\n failwith\n \"Control.Stable.V1.to_latest: Both variant is no longer supported\"\n end\nend]\n\n[%%endif]\n\nmodule Tag = struct\n type t = Signature | Proof | None_given [@@deriving equal, compare, sexp]\n\n let gen = Quickcheck.Generator.of_list [ Proof; Signature; None_given ]\n\n let to_string = function\n | Signature ->\n \"Signature\"\n | Proof ->\n \"Proof\"\n | None_given ->\n \"None_given\"\n\n let of_string_exn = function\n | \"Signature\" ->\n Signature\n | \"Proof\" ->\n Proof\n | \"None_given\" ->\n None_given\n | s ->\n failwithf \"String %s does not denote a control tag\" s ()\nend\n\nlet tag : t -> Tag.t = function\n | Proof _ ->\n Proof\n | Signature _ ->\n Signature\n | None_given ->\n None_given\n\n[%%ifdef consensus_mechanism]\n\nlet dummy_of_tag : Tag.t -> t = function\n | Proof ->\n let n2 = Pickles_types.Nat.N2.n in\n let proof = Pickles.Proof.dummy n2 n2 n2 ~domain_log2:15 in\n Proof proof\n | Signature ->\n Signature Signature.dummy\n | None_given ->\n None_given\n\nlet signature_deriver obj =\n Fields_derivers_zkapps.Derivers.iso_string obj ~name:\"Signature\"\n ~js_type:String ~to_string:Signature.to_base58_check\n ~of_string:\n (Fields_derivers_zkapps.except ~f:Signature.of_base58_check_exn `Signature)\n\nmodule As_record = struct\n type t =\n { proof : Pickles.Side_loaded.Proof.t option\n ; signature : Signature.t option\n }\n [@@deriving annot, fields]\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj\n ~proof:!.(option ~js_type:Or_undefined @@ proof @@ o ())\n ~signature:!.(option ~js_type:Or_undefined @@ signature_deriver @@ o ())\n |> finish \"Control\" ~t_toplevel_annots\nend\n\nlet to_record = function\n | Proof p ->\n { As_record.proof = Some p; signature = None }\n | Signature s ->\n { proof = None; signature = Some s }\n | None_given ->\n { proof = None; signature = None }\n\nlet of_record = function\n | { As_record.proof = Some p; _ } ->\n Proof p\n | { signature = Some s; _ } ->\n Signature s\n | _ ->\n None_given\n\nlet deriver obj =\n Fields_derivers_zkapps.Derivers.iso_record ~of_record ~to_record\n As_record.deriver obj\n\nlet%test_unit \"json rountrip\" =\n let module Fd = Fields_derivers_zkapps.Derivers in\n let full = deriver (Fd.o ()) in\n let control = dummy_of_tag Proof in\n [%test_eq: t] control (control |> Fd.to_json full |> Fd.of_json full)\n\n[%%endif]\n","(* payment_payload.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Signature_lib\nmodule Amount = Currency.Amount\nmodule Fee = Currency.Fee\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('public_key, 'amount) t =\n ( 'public_key\n , 'amount )\n Mina_wire_types.Mina_base.Payment_payload.Poly.V2.t =\n { receiver_pk : 'public_key; amount : 'amount }\n [@@deriving equal, sexp, hash, yojson, compare, hlist]\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('public_key, 'token_id, 'amount) t =\n { source_pk : 'public_key\n ; receiver_pk : 'public_key\n ; token_id : 'token_id\n ; amount : 'amount\n }\n [@@deriving equal, sexp, hash, yojson, compare, hlist]\n end\n end]\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n (Public_key.Compressed.Stable.V1.t, Amount.Stable.V1.t) Poly.Stable.V2.t\n [@@deriving equal, sexp, hash, compare, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t =\n ( Public_key.Compressed.Stable.V1.t\n , Token_id.Stable.V1.t\n , Amount.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving equal, sexp, hash, compare, yojson]\n\n (* don't need to coerce old payments to new ones *)\n let to_latest _ = failwith \"Not implemented\"\n end\nend]\n\nlet dummy =\n Poly.{ receiver_pk = Public_key.Compressed.empty; amount = Amount.zero }\n\n[%%ifdef consensus_mechanism]\n\ntype var = (Public_key.Compressed.var, Amount.var) Poly.t\n\nlet var_of_t ({ receiver_pk; amount } : t) : var =\n { receiver_pk = Public_key.Compressed.var_of_t receiver_pk\n ; amount = Amount.var_of_t amount\n }\n\n[%%endif]\n\nlet gen_aux max_amount =\n let open Quickcheck.Generator.Let_syntax in\n let%bind receiver_pk = Public_key.Compressed.gen in\n let%map amount = Amount.gen_incl Amount.zero max_amount in\n Poly.{ receiver_pk; amount }\n\nlet gen max_amount = gen_aux max_amount\n\nlet gen_default_token max_amount = gen_aux max_amount\n","open Core_kernel\nopen Snark_params.Tick\n\ninclude Data_hash.Make_full_size (struct\n let description = \"Ledger hash\"\n\n let version_byte = Base58_check.Version_bytes.ledger_hash\nend)\n\n(* Data hash versioned boilerplate below *)\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\nend]\n\nlet (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_util\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nmodule Frozen_ledger_hash = Frozen_ledger_hash0\nmodule Ledger_hash = Ledger_hash0\n\n(* Semantically this type represents a function\n { has_valid_signature: bool; has_valid_proof: bool } -> bool\n\n These are all of them:\n 00 01 10 11 | intuitive definition | Make sense\n 0 0 0 0 | Impossible | yes\n 0 0 0 1 | Both | yes\n 0 0 1 0 | Proof and not signature | no\n 0 0 1 1 | Proof | yes\n 0 1 0 0 | Signature and not proof | no\n 0 1 0 1 | Signature | yes\n 0 1 1 0 | Exactly one | no\n 0 1 1 1 | Either | yes\n 1 0 0 0 | Neither | no\n 1 0 0 1 | Neither or both | no\n 1 0 1 0 | Neither or proof, not both | no\n ...\n 1 1 1 1 | None | yes\n\n The ones marked as \"not making sense\" don't make sense because it is pointless\n to demand a signature failed to verify since you can always make a failing signature\n or proof.\n\n The ones that make sense are\n 0 0 0 0 | Impossible | yes\n 0 0 0 1 | Both | yes\n 0 0 1 1 | Proof | yes\n 0 1 0 1 | Signature | yes\n 0 1 1 1 | Either | yes\n 1 1 1 1 | None | yes\n\n \"Making sense\" can be captured by the idea that these are the *increasing*\n boolean functions on the type { has_valid_signature: bool; has_valid_proof: bool }.\n*)\nmodule Auth_required = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Permissions.Auth_required.V2.t =\n | None\n | Either\n | Proof\n | Signature\n | Impossible (* Both and either can both be subsumed in verification key.\n It is good to have \"Either\" as a separate thing to spare the owner from\n having to make a proof instead of a signature. Both, I'm not sure if there's\n a good justification for. *)\n [@@deriving sexp, equal, compare, hash, yojson, enum]\n\n let to_latest = Fn.id\n end\n end]\n\n let from ~auth_tag : t =\n match auth_tag with\n | Control.Tag.Proof ->\n Proof\n | Signature ->\n Signature\n | None_given ->\n None\n\n (* permissions such that [check permission (Proof _)] is true *)\n let gen_for_proof_authorization : t Quickcheck.Generator.t =\n Quickcheck.Generator.of_list [ None; Either; Proof ]\n\n (* permissions such that [check permission (Signature _)] is true *)\n let gen_for_signature_authorization : t Quickcheck.Generator.t =\n Quickcheck.Generator.of_list [ None; Either; Signature ]\n\n (* permissions such that [check permission None_given] is true *)\n let gen_for_none_given_authorization : t Quickcheck.Generator.t =\n Quickcheck.Generator.return None\n\n let to_string = function\n | None ->\n \"None\"\n | Either ->\n \"Either\"\n | Proof ->\n \"Proof\"\n | Signature ->\n \"Signature\"\n | Impossible ->\n \"Impossible\"\n\n let of_string = function\n | \"None\" ->\n Stable.Latest.None\n | \"Either\" ->\n Either\n | \"Proof\" ->\n Proof\n | \"Signature\" ->\n Signature\n | \"Impossible\" ->\n Impossible\n | _ ->\n failwith \"auth_required_of_string: unknown variant\"\n\n (* The encoding is chosen so that it is easy to write this function\n\n let spec_eval t ~signature_verifies =\n let impossible = (constant t && not (signature_sufficient t)) in\n let result =\n not impossible &&\n ( (signature_verifies && signature_sufficient t)\n || not (signature_necessary t) )\n in\n { result; proof_must_verify= not (signature_sufficient t) } *)\n\n (* Here is the mapping between our type and the bits\n { constant: bool\n ; signature_necessary: bool\n ; signature_sufficient: bool\n }\n\n Not constant\n Signature not necessary\n Signature not sufficient\n Proof\n Signature sufficient\n Either\n Signature necessary\n Signature not sufficient\n Both\n Signature sufficient\n Signature\n\n Constant\n Signature not sufficient\n Impossible\n Signature sufficient\n None\n *)\n module Encoding = struct\n type 'bool t =\n { constant : 'bool\n ; signature_necessary : 'bool\n ; signature_sufficient : 'bool\n }\n [@@deriving hlist, fields]\n\n let to_input ~field_of_bool t =\n let [ x; y; z ] = to_hlist t in\n let bs = [| x; y; z |] in\n Random_oracle.Input.Chunked.packeds\n (Array.map bs ~f:(fun b -> (field_of_bool b, 1)))\n\n let map t ~f =\n { constant = f t.constant\n ; signature_necessary = f t.signature_necessary\n ; signature_sufficient = f t.signature_sufficient\n }\n\n let _ = map\n\n [%%ifdef consensus_mechanism]\n\n let if_ b ~then_:t ~else_:e =\n let open Pickles.Impls.Step in\n { constant = Boolean.if_ b ~then_:t.constant ~else_:e.constant\n ; signature_necessary =\n Boolean.if_ b ~then_:t.signature_necessary\n ~else_:e.signature_necessary\n ; signature_sufficient =\n Boolean.if_ b ~then_:t.signature_sufficient\n ~else_:e.signature_sufficient\n }\n\n [%%endif]\n end\n\n let encode : t -> bool Encoding.t = function\n | Impossible ->\n { constant = true\n ; signature_necessary = true\n ; signature_sufficient = false\n }\n | None ->\n { constant = true\n ; signature_necessary = false\n ; signature_sufficient = true\n }\n | Proof ->\n { constant = false\n ; signature_necessary = false\n ; signature_sufficient = false\n }\n | Signature ->\n { constant = false\n ; signature_necessary = true\n ; signature_sufficient = true\n }\n | Either ->\n { constant = false\n ; signature_necessary = false\n ; signature_sufficient = true\n }\n\n let decode : bool Encoding.t -> t = function\n | { constant = true; signature_necessary = _; signature_sufficient = false }\n ->\n Impossible\n | { constant = true; signature_necessary = _; signature_sufficient = true }\n ->\n None\n | { constant = false\n ; signature_necessary = false\n ; signature_sufficient = false\n } ->\n Proof\n | { constant = false\n ; signature_necessary = true\n ; signature_sufficient = true\n } ->\n Signature\n | { constant = false\n ; signature_necessary = false\n ; signature_sufficient = true\n } ->\n Either\n | { constant = false\n ; signature_necessary = true\n ; signature_sufficient = false\n } ->\n failwith\n \"Permissions.decode: Found encoding of Both, but Both is not an \\\n exposed option\"\n\n let%test_unit \"decode encode\" =\n List.iter [ Impossible; Proof; Signature; Either ] ~f:(fun t ->\n [%test_eq: t] t (decode (encode t)) )\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n type t = Boolean.var Encoding.t\n\n let if_ = Encoding.if_\n\n let to_input : t -> _ =\n Encoding.to_input ~field_of_bool:(fun (b : Boolean.var) ->\n (b :> Field.Var.t) )\n\n let constant t = Encoding.map (encode t) ~f:Boolean.var_of_value\n\n let eval_no_proof\n ({ constant; signature_necessary = _; signature_sufficient } : t)\n ~signature_verifies =\n (* ways authorization can succeed when no proof is present:\n - None\n {constant= true; signature_necessary= _; signature_sufficient= true}\n - Either && signature_verifies\n {constant= false; signature_necessary= false; signature_sufficient= true}\n - Signature && signature_verifies\n {constant= false; signature_necessary= true; signature_sufficient= true}\n *)\n let open Pickles.Impls.Step.Boolean in\n signature_sufficient\n &&& (constant ||| ((not constant) &&& signature_verifies))\n\n let eval_proof ({ constant; signature_necessary; signature_sufficient } : t)\n =\n (* ways authorization can succeed if a proof is present:\n - None\n {constant= true; signature_necessary= _; signature_sufficient= true}\n - Either\n {constant= false; signature_necessary= false; signature_sufficient= true}\n - Proof\n {constant= false; signature_necessary= false; signature_sufficient= false}\n *)\n let open Pickles.Impls.Step.Boolean in\n let impossible = constant &&& not signature_sufficient in\n (not signature_necessary) &&& not impossible\n\n let spec_eval ({ constant; signature_necessary; signature_sufficient } : t)\n ~signature_verifies =\n let open Pickles.Impls.Step.Boolean in\n let impossible = constant &&& not signature_sufficient in\n let result =\n (not impossible)\n &&& ( signature_verifies &&& signature_sufficient\n ||| not signature_necessary )\n in\n let didn't_fail_yet = result in\n (* If the transaction already failed to verify, we don't need to assert\n that the proof should verify. *)\n (result, `proof_must_verify (didn't_fail_yet &&& not signature_sufficient))\n end\n\n let typ =\n let t =\n let open Encoding in\n Typ.of_hlistable\n [ Boolean.typ; Boolean.typ; Boolean.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n in\n Typ.transport t ~there:encode ~back:decode\n\n [%%endif]\n\n let to_input x = Encoding.to_input (encode x) ~field_of_bool\n\n let check (t : t) (c : Control.Tag.t) =\n match (t, c) with\n | Impossible, _ ->\n false\n | None, _ ->\n true\n | Proof, Proof ->\n true\n | Signature, Signature ->\n true\n (* The signatures and proofs have already been checked by this point. *)\n | Either, (Proof | Signature) ->\n true\n | Signature, Proof ->\n false\n | Proof, Signature ->\n false\n | (Proof | Signature | Either), None_given ->\n false\nend\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type 'controller t =\n 'controller Mina_wire_types.Mina_base.Permissions.Poly.V2.t =\n { edit_state : 'controller\n ; access : 'controller\n ; send : 'controller\n ; receive : 'controller\n ; set_delegate : 'controller\n ; set_permissions : 'controller\n ; set_verification_key : 'controller\n ; set_zkapp_uri : 'controller\n ; edit_action_state : 'controller\n ; set_token_symbol : 'controller\n ; increment_nonce : 'controller\n ; set_voting_for : 'controller\n ; set_timing : 'controller\n }\n [@@deriving annot, sexp, equal, compare, hash, yojson, hlist, fields]\n end\n end]\n\n let to_input controller t =\n let f mk acc field = mk (Core_kernel.Field.get field t) :: acc in\n Stable.Latest.Fields.fold ~init:[] ~edit_state:(f controller)\n ~send:(f controller) ~set_delegate:(f controller)\n ~set_permissions:(f controller) ~set_verification_key:(f controller)\n ~receive:(f controller) ~set_zkapp_uri:(f controller)\n ~edit_action_state:(f controller) ~set_token_symbol:(f controller)\n ~increment_nonce:(f controller) ~set_voting_for:(f controller)\n ~set_timing:(f controller) ~access:(f controller)\n |> List.rev\n |> List.reduce_exn ~f:Random_oracle.Input.Chunked.append\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Auth_required.Stable.V2.t Poly.Stable.V2.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\nlet gen ~auth_tag : t Quickcheck.Generator.t =\n let auth_required_gen =\n (* for Auth_required permissions p, choose such that [check p authorization] is true *)\n match auth_tag with\n | Control.Tag.Proof ->\n Auth_required.gen_for_proof_authorization\n | Signature ->\n Auth_required.gen_for_signature_authorization\n | None_given ->\n Auth_required.gen_for_none_given_authorization\n in\n let open Quickcheck.Generator.Let_syntax in\n let%bind edit_state = auth_required_gen in\n let%bind send = auth_required_gen in\n let%bind receive = auth_required_gen in\n let%bind set_delegate = auth_required_gen in\n let%bind set_permissions = auth_required_gen in\n let%bind set_verification_key = auth_required_gen in\n let%bind set_zkapp_uri = auth_required_gen in\n let%bind edit_action_state = auth_required_gen in\n let%bind set_token_symbol = auth_required_gen in\n let%bind increment_nonce = auth_required_gen in\n let%bind set_voting_for = auth_required_gen in\n let%bind set_timing = auth_required_gen in\n let%bind access =\n (* Access permission is significantly more restrictive, do not arbitrarily\n set it when tests may not be intending to exercise it.\n *)\n Auth_required.gen_for_none_given_authorization\n in\n return\n { Poly.edit_state\n ; send\n ; receive\n ; set_delegate\n ; set_permissions\n ; set_verification_key\n ; set_zkapp_uri\n ; edit_action_state\n ; set_token_symbol\n ; increment_nonce\n ; set_voting_for\n ; set_timing\n ; access\n }\n\n[%%ifdef consensus_mechanism]\n\nmodule Checked = struct\n type t = Auth_required.Checked.t Poly.Stable.Latest.t\n\n let to_input (x : t) = Poly.to_input Auth_required.Checked.to_input x\n\n let if_ b ~then_ ~else_ =\n let g cond f =\n cond b\n ~then_:(Core_kernel.Field.get f then_)\n ~else_:(Core_kernel.Field.get f else_)\n in\n let c = g Auth_required.Checked.if_ in\n Poly.Fields.map ~edit_state:c ~send:c ~receive:c ~set_delegate:c\n ~set_permissions:c ~set_verification_key:c ~set_zkapp_uri:c\n ~edit_action_state:c ~set_token_symbol:c ~increment_nonce:c\n ~set_voting_for:c ~set_timing:c ~access:c\n\n let constant (t : Stable.Latest.t) : t =\n let open Core_kernel.Field in\n let a f = Auth_required.Checked.constant (get f t) in\n Poly.Fields.map ~edit_state:a ~send:a ~receive:a ~set_delegate:a\n ~set_permissions:a ~set_verification_key:a ~set_zkapp_uri:a\n ~edit_action_state:a ~set_token_symbol:a ~increment_nonce:a\n ~set_voting_for:a ~set_timing:a ~access:a\nend\n\nlet typ =\n let open Poly.Stable.Latest in\n Typ.of_hlistable\n [ Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n[%%endif]\n\nlet to_input (x : t) = Poly.to_input Auth_required.to_input x\n\nlet user_default : t =\n { edit_state = Signature\n ; send = Signature\n ; receive = None\n ; set_delegate = Signature\n ; set_permissions = Signature\n ; set_verification_key = Signature\n ; set_zkapp_uri = Signature\n ; edit_action_state = Signature\n ; set_token_symbol = Signature\n ; increment_nonce = Signature\n ; set_voting_for = Signature\n ; set_timing = Signature\n ; access = None\n }\n\nlet empty : t =\n { edit_state = None\n ; send = None\n ; receive = None\n ; access = None\n ; set_delegate = None\n ; set_permissions = None\n ; set_verification_key = None\n ; set_zkapp_uri = None\n ; edit_action_state = None\n ; set_token_symbol = None\n ; increment_nonce = None\n ; set_voting_for = None\n ; set_timing = None\n }\n\n(* deriving-fields-related stuff *)\n\nlet auth_required =\n Fields_derivers_zkapps.Derivers.iso_string ~name:\"AuthRequired\"\n ~js_type:(Custom \"AuthRequired\") ~doc:\"Kind of authorization required\"\n ~to_string:Auth_required.to_string ~of_string:Auth_required.of_string\n\nlet deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots:Poly.t_fields_annots in\n Poly.Fields.make_creator obj ~edit_state:!.auth_required ~send:!.auth_required\n ~receive:!.auth_required ~set_delegate:!.auth_required\n ~set_permissions:!.auth_required ~set_verification_key:!.auth_required\n ~set_zkapp_uri:!.auth_required ~edit_action_state:!.auth_required\n ~set_token_symbol:!.auth_required ~increment_nonce:!.auth_required\n ~set_voting_for:!.auth_required ~set_timing:!.auth_required\n ~access:!.auth_required\n |> finish \"Permissions\" ~t_toplevel_annots:Poly.t_toplevel_annots\n\nlet%test_unit \"json roundtrip\" =\n let open Fields_derivers_zkapps.Derivers in\n let full = o () in\n let _a = deriver full in\n [%test_eq: t] user_default (user_default |> to_json full |> of_json full)\n\nlet%test_unit \"json value\" =\n let open Fields_derivers_zkapps.Derivers in\n let full = o () in\n let _a = deriver full in\n [%test_eq: string]\n (user_default |> to_json full |> Yojson.Safe.to_string)\n ( {json|{\n editState: \"Signature\",\n access: \"None\",\n send: \"Signature\",\n receive: \"None\",\n setDelegate: \"Signature\",\n setPermissions: \"Signature\",\n setVerificationKey: \"Signature\",\n setZkappUri: \"Signature\",\n editActionState: \"Signature\",\n setTokenSymbol: \"Signature\",\n incrementNonce: \"Signature\",\n setVotingFor: \"Signature\",\n setTiming: \"Signature\"\n }|json}\n |> Yojson.Safe.from_string |> Yojson.Safe.to_string )\n","(* signed_command_memo.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Signed_command_memo\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Signed_command_memo_intf.S with type t = A.V1.t\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = string [@@deriving sexp, equal, compare, hash]\n\n let to_latest = Fn.id\n\n module Base58_check = Base58_check.Make (struct\n let description = \"User command memo\"\n\n let version_byte = Base58_check.Version_bytes.user_command_memo\n end)\n\n let to_base58_check (memo : t) : string = Base58_check.encode memo\n\n let of_base58_check (s : string) : t Or_error.t = Base58_check.decode s\n\n let of_base58_check_exn (s : string) : t = Base58_check.decode_exn s\n\n module T = struct\n type nonrec t = t\n\n let to_string = to_base58_check\n\n let of_string = of_base58_check_exn\n end\n\n include Codable.Make_of_string (T)\n end\n end]\n\n [%%define_locally\n Stable.Latest.\n (to_yojson, of_yojson, to_base58_check, of_base58_check, of_base58_check_exn)]\n\n exception Too_long_user_memo_input\n\n exception Too_long_digestible_string\n\n let max_digestible_string_length = 1000\n\n (* 0th byte is a tag to distinguish digests from other data\n 1st byte is length, always 32 for digests\n bytes 2 to 33 are data, 0-right-padded if length is less than 32\n *)\n\n let digest_tag = '\\x00'\n\n let bytes_tag = '\\x01'\n\n let tag_index = 0\n\n let length_index = 1\n\n let digest_length = Blake2.digest_size_in_bytes\n\n let digest_length_byte = Char.of_int_exn digest_length\n\n (* +2 for tag and length bytes *)\n let memo_length = digest_length + 2\n\n let max_input_length = digest_length\n\n let tag (memo : t) = memo.[tag_index]\n\n let length memo = Char.to_int memo.[length_index]\n\n let is_bytes memo = Char.equal (tag memo) bytes_tag\n\n let is_digest memo = Char.equal (tag memo) digest_tag\n\n let is_valid memo =\n Int.(String.length memo = memo_length)\n &&\n let length = length memo in\n if is_digest memo then Int.(length = digest_length)\n else\n Char.equal (tag memo) bytes_tag\n && Int.(length <= digest_length)\n &&\n let padded =\n String.sub memo ~pos:(length + 2) ~len:(digest_length - length)\n in\n String.for_all padded ~f:(Char.equal '\\x00')\n\n let create_by_digesting_string_exn s =\n if Int.(String.length s > max_digestible_string_length) then\n raise Too_long_digestible_string ;\n let digest = Blake2.(to_raw_string (digest_string s)) in\n String.init memo_length ~f:(fun ndx ->\n if Int.(ndx = tag_index) then digest_tag\n else if Int.(ndx = length_index) then digest_length_byte\n else digest.[ndx - 2] )\n\n let create_by_digesting_string (s : string) =\n try Ok (create_by_digesting_string_exn s)\n with Too_long_digestible_string ->\n Or_error.error_string \"create_by_digesting_string: string too long\"\n\n module type Memoable = sig\n type t\n\n val length : t -> int\n\n val get : t -> int -> char\n end\n\n let create_from_value_exn (type t) (module M : Memoable with type t = t)\n (value : t) =\n let len = M.length value in\n if Int.(len > max_input_length) then raise Too_long_user_memo_input ;\n String.init memo_length ~f:(fun ndx ->\n if Int.(ndx = tag_index) then bytes_tag\n else if Int.(ndx = length_index) then Char.of_int_exn len\n else if Int.(ndx < len + 2) then M.get value (ndx - 2)\n else '\\x00' )\n\n let create_from_bytes_exn bytes = create_from_value_exn (module Bytes) bytes\n\n let create_from_bytes bytes =\n try Ok (create_from_bytes_exn bytes)\n with Too_long_user_memo_input ->\n Or_error.error_string\n (sprintf \"create_from_bytes: length exceeds %d\" max_input_length)\n\n let create_from_string_exn s = create_from_value_exn (module String) s\n\n let create_from_string s =\n try Ok (create_from_string_exn s)\n with Too_long_user_memo_input ->\n Or_error.error_string\n (sprintf \"create_from_string: length exceeds %d\" max_input_length)\n\n let dummy = (create_by_digesting_string_exn \"\" :> t)\n\n let empty = create_from_string_exn \"\"\n\n type raw = Digest of string | Bytes of string\n\n let to_raw_exn memo =\n let tag = tag memo in\n if Char.equal tag digest_tag then Digest (to_base58_check memo)\n else if Char.equal tag bytes_tag then\n let len = length memo in\n Bytes (String.init len ~f:(fun idx -> memo.[idx - 2]))\n else failwithf \"Unknown memo tag %c\" tag ()\n\n let to_raw_bytes_exn memo =\n match to_raw_exn memo with\n | Digest _ ->\n failwith \"Cannot convert a digest to raw bytes\"\n | Bytes str ->\n str\n\n let of_raw_exn = function\n | Digest base58_check ->\n of_base58_check_exn base58_check\n | Bytes str ->\n of_base58_check_exn str\n\n let fold_bits t =\n { Fold_lib.Fold.fold =\n (fun ~init ~f ->\n let n = 8 * String.length t in\n let rec go acc i =\n if i = n then acc\n else\n let b = (Char.to_int t.[i / 8] lsr (i mod 8)) land 1 = 1 in\n go (f acc b) (i + 1)\n in\n go init 0 )\n }\n\n let to_bits t = Fold_lib.Fold.to_list (fold_bits t)\n\n let gen =\n Quickcheck.Generator.map String.quickcheck_generator\n ~f:create_by_digesting_string_exn\n\n let hash memo =\n Random_oracle.hash ~init:Hash_prefix.zkapp_memo\n (Random_oracle.Legacy.pack_input\n (Random_oracle_input.Legacy.bitstring (to_bits memo)) )\n\n let to_plaintext (memo : t) : string Or_error.t =\n if is_bytes memo then Ok (String.sub memo ~pos:2 ~len:(length memo))\n else Error (Error.of_string \"Memo does not contain text bytes\")\n\n let to_digest (memo : t) : string Or_error.t =\n if is_digest memo then Ok (String.sub memo ~pos:2 ~len:digest_length)\n else Error (Error.of_string \"Memo does not contain a digest\")\n\n let to_string_hum (memo : t) =\n match to_plaintext memo with\n | Ok text ->\n text\n | Error _ -> (\n match to_digest memo with\n | Ok digest ->\n sprintf \"0x%s\" (Hex.encode digest)\n | Error _ ->\n \"(Invalid memo, neither text nor a digest)\" )\n\n [%%ifdef consensus_mechanism]\n\n module Boolean = Tick.Boolean\n module Typ = Tick.Typ\n\n (* the code below is much the same as in Random_oracle.Digest; tag and length bytes\n make it a little different\n *)\n\n module Checked = struct\n type unchecked = t\n\n type t = Boolean.var array\n\n let constant unchecked =\n assert (Int.(String.length (unchecked :> string) = memo_length)) ;\n Array.map\n (Blake2.string_to_bits (unchecked :> string))\n ~f:Boolean.var_of_value\n end\n\n let length_in_bits = 8 * memo_length\n\n let typ : (Checked.t, t) Typ.t =\n Typ.transport\n (Typ.array ~length:length_in_bits Boolean.typ)\n ~there:(fun (t : t) -> Blake2.string_to_bits (t :> string))\n ~back:(fun bs -> (Blake2.bits_to_string bs :> t))\n\n [%%endif]\n\n let deriver obj =\n Fields_derivers_zkapps.iso_string obj ~name:\"Memo\" ~js_type:String\n ~to_string:to_base58_check ~of_string:of_base58_check_exn\n\n let%test_module \"user_command_memo\" =\n ( module struct\n let data memo = String.sub memo ~pos:(length_index + 1) ~len:(length memo)\n\n let%test \"digest string\" =\n let s = \"this is a string\" in\n let memo = create_by_digesting_string_exn s in\n is_valid memo\n\n let%test \"digest too-long string\" =\n let s =\n String.init (max_digestible_string_length + 1) ~f:(fun _ -> '\\xFF')\n in\n try\n let (_ : t) = create_by_digesting_string_exn s in\n false\n with Too_long_digestible_string -> true\n\n let%test \"memo from string\" =\n let s = \"time and tide wait for no one\" in\n let memo = create_from_string_exn s in\n is_valid memo && String.equal s (data memo)\n\n let%test \"memo from too-long string\" =\n let s = String.init (max_input_length + 1) ~f:(fun _ -> '\\xFF') in\n try\n let (_ : t) = create_from_string_exn s in\n false\n with Too_long_user_memo_input -> true\n\n [%%ifdef consensus_mechanism]\n\n let%test_unit \"typ is identity\" =\n let s = \"this is a string\" in\n let memo = create_by_digesting_string_exn s in\n let read_constant = function\n | Snarky_backendless.Cvar.Constant x ->\n x\n | _ ->\n assert false\n in\n let (Typ typ) = typ in\n let memo_var =\n memo |> typ.value_to_fields\n |> (fun (arr, aux) ->\n ( Array.map arr ~f:(fun x -> Snarky_backendless.Cvar.Constant x)\n , aux ) )\n |> typ.var_of_fields\n in\n let memo_read =\n memo_var |> typ.var_to_fields\n |> (fun (arr, aux) ->\n (Array.map arr ~f:(fun x -> read_constant x), aux) )\n |> typ.value_of_fields\n in\n [%test_eq: string] memo memo_read\n\n [%%endif]\n end )\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","(* stake_delegation.ml *)\n\nopen Core_kernel\nopen Signature_lib\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n [@@@with_all_version_tags]\n\n type t = Mina_wire_types.Mina_base.Stake_delegation.V2.t =\n | Set_delegate of { new_delegate : Public_key.Compressed.Stable.V1.t }\n [@@deriving compare, equal, sexp, hash, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Mina_wire_types.Mina_base.Stake_delegation.V1.t =\n | Set_delegate of\n { delegator : Public_key.Compressed.Stable.V1.t\n ; new_delegate : Public_key.Compressed.Stable.V1.t\n }\n [@@deriving compare, equal, sexp, hash, yojson]\n\n let to_latest (Set_delegate { delegator = _; new_delegate }) =\n V2.Set_delegate { new_delegate }\n end\nend]\n\nlet receiver_pk = function Set_delegate { new_delegate } -> new_delegate\n\nlet receiver = function\n | Set_delegate { new_delegate } ->\n Account_id.create new_delegate Token_id.default\n\nlet gen =\n Quickcheck.Generator.map Public_key.Compressed.gen ~f:(fun k ->\n Set_delegate { new_delegate = k } )\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nmodule Failure = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Transaction_status.Failure.V2.t =\n | Predicate [@value 1]\n | Source_not_present\n | Receiver_not_present\n | Amount_insufficient_to_create_account\n | Cannot_pay_creation_fee_in_token\n | Source_insufficient_balance\n | Source_minimum_balance_violation\n | Receiver_already_exists\n | Token_owner_not_caller\n | Overflow\n | Global_excess_overflow\n | Local_excess_overflow\n | Local_supply_increase_overflow\n | Global_supply_increase_overflow\n | Signed_command_on_zkapp_account\n | Zkapp_account_not_present\n | Update_not_permitted_balance\n | Update_not_permitted_access\n | Update_not_permitted_timing\n | Update_not_permitted_delegate\n | Update_not_permitted_app_state\n | Update_not_permitted_verification_key\n | Update_not_permitted_action_state\n | Update_not_permitted_zkapp_uri\n | Update_not_permitted_token_symbol\n | Update_not_permitted_permissions\n | Update_not_permitted_nonce\n | Update_not_permitted_voting_for\n | Zkapp_command_replay_check_failed\n | Fee_payer_nonce_must_increase\n | Fee_payer_must_be_signed\n | Account_balance_precondition_unsatisfied\n | Account_nonce_precondition_unsatisfied\n | Account_receipt_chain_hash_precondition_unsatisfied\n | Account_delegate_precondition_unsatisfied\n | Account_action_state_precondition_unsatisfied\n | Account_app_state_precondition_unsatisfied of int\n | Account_proved_state_precondition_unsatisfied\n | Account_is_new_precondition_unsatisfied\n | Protocol_state_precondition_unsatisfied\n | Unexpected_verification_key_hash\n | Valid_while_precondition_unsatisfied\n | Incorrect_nonce\n | Invalid_fee_excess\n | Cancelled\n [@@deriving sexp, yojson, equal, compare, variants, hash]\n\n let to_latest = Fn.id\n end\n end]\n\n module Collection = struct\n module Display = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = (int * Stable.V2.t list) list\n [@@deriving equal, compare, yojson, sexp, hash]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Stable.V2.t list list\n [@@deriving equal, compare, yojson, sexp, hash]\n\n let to_latest = Fn.id\n end\n end]\n\n let to_display t : Display.t =\n let _, display =\n List.fold_left t ~init:(0, []) ~f:(fun (index, acc) bucket ->\n if List.is_empty bucket then (index + 1, acc)\n else (index + 1, (index, bucket) :: acc) )\n in\n display\n\n let empty = []\n\n let of_single_failure f : t = [ [ f ] ]\n\n let is_empty : t -> bool = Fn.compose List.is_empty List.concat\n end\n\n type failure = t\n\n let failure_min = min\n\n let failure_max = max\n\n let all =\n let add acc var = var.Variantslib.Variant.constructor :: acc in\n Variants.fold ~init:[] ~predicate:add ~source_not_present:add\n ~receiver_not_present:add ~amount_insufficient_to_create_account:add\n ~cannot_pay_creation_fee_in_token:add ~source_insufficient_balance:add\n ~source_minimum_balance_violation:add ~receiver_already_exists:add\n ~token_owner_not_caller:add ~overflow:add ~global_excess_overflow:add\n ~local_excess_overflow:add ~local_supply_increase_overflow:add\n ~global_supply_increase_overflow:add ~signed_command_on_zkapp_account:add\n ~zkapp_account_not_present:add ~update_not_permitted_balance:add\n ~update_not_permitted_timing:add ~update_not_permitted_access:add\n ~update_not_permitted_delegate:add ~update_not_permitted_app_state:add\n ~update_not_permitted_verification_key:add\n ~update_not_permitted_action_state:add ~update_not_permitted_zkapp_uri:add\n ~update_not_permitted_token_symbol:add\n ~update_not_permitted_permissions:add ~update_not_permitted_nonce:add\n ~update_not_permitted_voting_for:add\n ~zkapp_command_replay_check_failed:add ~fee_payer_nonce_must_increase:add\n ~fee_payer_must_be_signed:add\n ~account_balance_precondition_unsatisfied:add\n ~account_nonce_precondition_unsatisfied:add\n ~account_receipt_chain_hash_precondition_unsatisfied:add\n ~account_delegate_precondition_unsatisfied:add\n ~account_action_state_precondition_unsatisfied:add\n ~account_app_state_precondition_unsatisfied:(fun acc var ->\n List.init 8 ~f:var.constructor @ acc )\n ~account_proved_state_precondition_unsatisfied:add\n ~account_is_new_precondition_unsatisfied:add\n ~protocol_state_precondition_unsatisfied:add\n ~valid_while_precondition_unsatisfied:add\n ~unexpected_verification_key_hash:add ~incorrect_nonce:add\n ~invalid_fee_excess:add ~cancelled:add\n\n let gen = Quickcheck.Generator.of_list all\n\n let to_string = function\n | Predicate ->\n \"Predicate\"\n | Source_not_present ->\n \"Source_not_present\"\n | Receiver_not_present ->\n \"Receiver_not_present\"\n | Amount_insufficient_to_create_account ->\n \"Amount_insufficient_to_create_account\"\n | Cannot_pay_creation_fee_in_token ->\n \"Cannot_pay_creation_fee_in_token\"\n | Source_insufficient_balance ->\n \"Source_insufficient_balance\"\n | Source_minimum_balance_violation ->\n \"Source_minimum_balance_violation\"\n | Receiver_already_exists ->\n \"Receiver_already_exists\"\n | Token_owner_not_caller ->\n \"Token_owner_not_caller\"\n | Overflow ->\n \"Overflow\"\n | Global_excess_overflow ->\n \"Global_excess_overflow\"\n | Local_excess_overflow ->\n \"Local_excess_overflow\"\n | Local_supply_increase_overflow ->\n \"Local_supply_increase_overflow\"\n | Global_supply_increase_overflow ->\n \"Global_supply_increase_overflow\"\n | Signed_command_on_zkapp_account ->\n \"Signed_command_on_zkapp_account\"\n | Zkapp_account_not_present ->\n \"Zkapp_account_not_present\"\n | Update_not_permitted_balance ->\n \"Update_not_permitted_balance\"\n | Update_not_permitted_access ->\n \"Update_not_permitted_access\"\n | Update_not_permitted_timing ->\n \"Update_not_permitted_timing\"\n | Update_not_permitted_delegate ->\n \"update_not_permitted_delegate\"\n | Update_not_permitted_app_state ->\n \"Update_not_permitted_app_state\"\n | Update_not_permitted_verification_key ->\n \"Update_not_permitted_verification_key\"\n | Update_not_permitted_action_state ->\n \"Update_not_permitted_action_state\"\n | Update_not_permitted_zkapp_uri ->\n \"Update_not_permitted_zkapp_uri\"\n | Update_not_permitted_token_symbol ->\n \"Update_not_permitted_token_symbol\"\n | Update_not_permitted_permissions ->\n \"Update_not_permitted_permissions\"\n | Update_not_permitted_nonce ->\n \"Update_not_permitted_nonce\"\n | Update_not_permitted_voting_for ->\n \"Update_not_permitted_voting_for\"\n | Zkapp_command_replay_check_failed ->\n \"Zkapp_command_replay_check_failed\"\n | Fee_payer_nonce_must_increase ->\n \"Fee_payer_nonce_must_increase\"\n | Fee_payer_must_be_signed ->\n \"Fee_payer_must_be_signed\"\n | Account_balance_precondition_unsatisfied ->\n \"Account_balance_precondition_unsatisfied\"\n | Account_nonce_precondition_unsatisfied ->\n \"Account_nonce_precondition_unsatisfied\"\n | Account_receipt_chain_hash_precondition_unsatisfied ->\n \"Account_receipt_chain_hash_precondition_unsatisfied\"\n | Account_delegate_precondition_unsatisfied ->\n \"Account_delegate_precondition_unsatisfied\"\n | Account_action_state_precondition_unsatisfied ->\n \"Account_action_state_precondition_unsatisfied\"\n | Account_app_state_precondition_unsatisfied i ->\n sprintf \"Account_app_state_%i_precondition_unsatisfied\" i\n | Account_proved_state_precondition_unsatisfied ->\n \"Account_proved_state_precondition_unsatisfied\"\n | Account_is_new_precondition_unsatisfied ->\n \"Account_is_new_precondition_unsatisfied\"\n | Protocol_state_precondition_unsatisfied ->\n \"Protocol_state_precondition_unsatisfied\"\n | Valid_while_precondition_unsatisfied ->\n \"Valid_while_precondition_unsatisfied\"\n | Unexpected_verification_key_hash ->\n \"Unexpected_verification_key_hash\"\n | Incorrect_nonce ->\n \"Incorrect_nonce\"\n | Invalid_fee_excess ->\n \"Invalid_fee_excess\"\n | Cancelled ->\n \"Cancelled\"\n\n let of_string = function\n | \"Predicate\" ->\n Ok Predicate\n | \"Source_not_present\" ->\n Ok Source_not_present\n | \"Receiver_not_present\" ->\n Ok Receiver_not_present\n | \"Amount_insufficient_to_create_account\" ->\n Ok Amount_insufficient_to_create_account\n | \"Cannot_pay_creation_fee_in_token\" ->\n Ok Cannot_pay_creation_fee_in_token\n | \"Source_insufficient_balance\" ->\n Ok Source_insufficient_balance\n | \"Source_minimum_balance_violation\" ->\n Ok Source_minimum_balance_violation\n | \"Receiver_already_exists\" ->\n Ok Receiver_already_exists\n | \"Token_owner_not_caller\" ->\n Ok Token_owner_not_caller\n | \"Overflow\" ->\n Ok Overflow\n | \"Global_excess_overflow\" ->\n Ok Global_excess_overflow\n | \"Local_excess_overflow\" ->\n Ok Local_excess_overflow\n | \"Local_supply_increase_overflow\" ->\n Ok Local_supply_increase_overflow\n | \"Global_supply_increase_overflow\" ->\n Ok Global_supply_increase_overflow\n | \"Signed_command_on_zkapp_account\" ->\n Ok Signed_command_on_zkapp_account\n | \"Zkapp_account_not_present\" ->\n Ok Zkapp_account_not_present\n | \"Update_not_permitted_balance\" ->\n Ok Update_not_permitted_balance\n | \"Update_not_permitted_access\" ->\n Ok Update_not_permitted_access\n | \"Update_not_permitted_timing\" ->\n Ok Update_not_permitted_timing\n | \"update_not_permitted_delegate\" ->\n Ok Update_not_permitted_delegate\n | \"Update_not_permitted_app_state\" ->\n Ok Update_not_permitted_app_state\n | \"Update_not_permitted_verification_key\" ->\n Ok Update_not_permitted_verification_key\n | \"Update_not_permitted_action_state\" ->\n Ok Update_not_permitted_action_state\n | \"Update_not_permitted_zkapp_uri\" ->\n Ok Update_not_permitted_zkapp_uri\n | \"Update_not_permitted_token_symbol\" ->\n Ok Update_not_permitted_token_symbol\n | \"Update_not_permitted_permissions\" ->\n Ok Update_not_permitted_permissions\n | \"Update_not_permitted_nonce\" ->\n Ok Update_not_permitted_nonce\n | \"Update_not_permitted_voting_for\" ->\n Ok Update_not_permitted_voting_for\n | \"Zkapp_command_replay_check_failed\" ->\n Ok Zkapp_command_replay_check_failed\n | \"Fee_payer_nonce_must_increase\" ->\n Ok Fee_payer_nonce_must_increase\n | \"Fee_payer_must_be_signed\" ->\n Ok Fee_payer_must_be_signed\n | \"Account_balance_precondition_unsatisfied\" ->\n Ok Account_balance_precondition_unsatisfied\n | \"Account_nonce_precondition_unsatisfied\" ->\n Ok Account_nonce_precondition_unsatisfied\n | \"Account_receipt_chain_hash_precondition_unsatisfied\" ->\n Ok Account_receipt_chain_hash_precondition_unsatisfied\n | \"Account_delegate_precondition_unsatisfied\" ->\n Ok Account_delegate_precondition_unsatisfied\n | \"Account_action_state_precondition_unsatisfied\" ->\n Ok Account_action_state_precondition_unsatisfied\n | \"Account_proved_state_precondition_unsatisfied\" ->\n Ok Account_proved_state_precondition_unsatisfied\n | \"Account_is_new_precondition_unsatisfied\" ->\n Ok Account_is_new_precondition_unsatisfied\n | \"Protocol_state_precondition_unsatisfied\" ->\n Ok Protocol_state_precondition_unsatisfied\n | \"Valid_while_precondition_unsatisfied\" ->\n Ok Valid_while_precondition_unsatisfied\n | \"Unexpected_verification_key_hash\" ->\n Ok Unexpected_verification_key_hash\n | \"Incorrect_nonce\" ->\n Ok Incorrect_nonce\n | \"Invalid_fee_excess\" ->\n Ok Invalid_fee_excess\n | \"Cancelled\" ->\n Ok Cancelled\n | str -> (\n let res =\n List.find_map\n ~f:(fun (prefix, suffix, parse) ->\n Option.try_with (fun () ->\n assert (\n String.length str\n >= String.length prefix + String.length suffix ) ;\n for i = 0 to String.length prefix - 1 do\n assert (Char.equal prefix.[i] str.[i])\n done ;\n let offset = String.length str - String.length suffix in\n for i = 0 to String.length suffix - 1 do\n assert (Char.equal suffix.[i] str.[offset + i])\n done ;\n parse\n (String.sub str ~pos:(String.length prefix)\n ~len:(offset - String.length prefix) ) ) )\n [ ( \"Account_app_state_\"\n , \"_precondition_unsatisfied\"\n , fun str ->\n Account_app_state_precondition_unsatisfied (int_of_string str)\n )\n ]\n in\n match res with\n | Some res ->\n Ok res\n | None ->\n Error \"Transaction_status.Failure.of_string: Unknown value\" )\n\n let%test_unit \"of_string(to_string) roundtrip\" =\n List.iter all ~f:(fun failure ->\n [%test_eq: (t, string) Result.t]\n (of_string (to_string failure))\n (Ok failure) )\n\n let describe = function\n | Predicate ->\n \"A predicate failed\"\n | Source_not_present ->\n \"The source account does not exist\"\n | Receiver_not_present ->\n \"The receiver account does not exist\"\n | Amount_insufficient_to_create_account ->\n \"Cannot create account: transaction amount is smaller than the account \\\n creation fee\"\n | Cannot_pay_creation_fee_in_token ->\n \"Cannot create account: account creation fees cannot be paid in \\\n non-default tokens\"\n | Source_insufficient_balance ->\n \"The source account has an insufficient balance\"\n | Source_minimum_balance_violation ->\n \"The source account requires a minimum balance\"\n | Receiver_already_exists ->\n \"Attempted to create an account that already exists\"\n | Token_owner_not_caller ->\n \"An account update used a non-default token but its caller was not the \\\n token owner\"\n | Overflow ->\n \"The resulting balance is too large to store\"\n | Global_excess_overflow ->\n \"The resulting global fee excess is too large to store\"\n | Local_excess_overflow ->\n \"The resulting local fee excess is too large to store\"\n | Local_supply_increase_overflow ->\n \"The resulting local supply increase is too large to store\"\n | Global_supply_increase_overflow ->\n \"The resulting global supply increase is too large to store\"\n | Signed_command_on_zkapp_account ->\n \"The source of a signed command cannot be a snapp account\"\n | Zkapp_account_not_present ->\n \"A zkApp account does not exist\"\n | Update_not_permitted_balance ->\n \"The authentication for an account didn't allow the requested update \\\n to its balance\"\n | Update_not_permitted_access ->\n \"The authentication for an account didn't allow it to be accessed\"\n | Update_not_permitted_timing ->\n \"The authentication for an account didn't allow the requested update \\\n to its timing\"\n | Update_not_permitted_delegate ->\n \"The authentication for an account didn't allow the requested update \\\n to its delegate\"\n | Update_not_permitted_app_state ->\n \"The authentication for an account didn't allow the requested update \\\n to its app state\"\n | Update_not_permitted_verification_key ->\n \"The authentication for an account didn't allow the requested update \\\n to its verification key\"\n | Update_not_permitted_action_state ->\n \"The authentication for an account didn't allow the requested update \\\n to its action state\"\n | Update_not_permitted_zkapp_uri ->\n \"The authentication for an account didn't allow the requested update \\\n to its snapp URI\"\n | Update_not_permitted_token_symbol ->\n \"The authentication for an account didn't allow the requested update \\\n to its token symbol\"\n | Update_not_permitted_permissions ->\n \"The authentication for an account didn't allow the requested update \\\n to its permissions\"\n | Update_not_permitted_nonce ->\n \"The authentication for an account didn't allow the requested update \\\n to its nonce\"\n | Update_not_permitted_voting_for ->\n \"The authentication for an account didn't allow the requested update \\\n to its voted-for state hash\"\n | Zkapp_command_replay_check_failed ->\n \"Check to avoid replays failed. The account update must increment \\\n nonce or use full commitment if the authorization is a signature\"\n | Fee_payer_nonce_must_increase ->\n \"Fee payer account update must increment its nonce\"\n | Fee_payer_must_be_signed ->\n \"Fee payer account update must have a valid signature\"\n | Account_balance_precondition_unsatisfied ->\n \"The account update's account balance precondition was unsatisfied\"\n | Account_nonce_precondition_unsatisfied ->\n \"The account update's account nonce precondition was unsatisfied\"\n | Account_receipt_chain_hash_precondition_unsatisfied ->\n \"The account update's account receipt-chain hash precondition was \\\n unsatisfied\"\n | Account_delegate_precondition_unsatisfied ->\n \"The account update's account delegate precondition was unsatisfied\"\n | Account_action_state_precondition_unsatisfied ->\n \"The account update's account action state precondition was unsatisfied\"\n | Account_app_state_precondition_unsatisfied i ->\n sprintf\n \"The account update's account app state (%i) precondition was \\\n unsatisfied\"\n i\n | Account_proved_state_precondition_unsatisfied ->\n \"The account update's account proved state precondition was unsatisfied\"\n | Account_is_new_precondition_unsatisfied ->\n \"The account update's account is-new state precondition was unsatisfied\"\n | Protocol_state_precondition_unsatisfied ->\n \"The account update's protocol state precondition unsatisfied\"\n | Valid_while_precondition_unsatisfied ->\n \"The account update's valid-until precondition was unsatisfied\"\n | Unexpected_verification_key_hash ->\n \"The account update's verification key hash does not match the \\\n verification key in the ledger account\"\n | Incorrect_nonce ->\n \"Incorrect nonce\"\n | Invalid_fee_excess ->\n \"Fee excess from zkapp_command transaction more than the transaction \\\n fees\"\n | Cancelled ->\n \"The account update is cancelled because there's a failure in the \\\n zkApp transaction\"\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Transaction_status.V2.t =\n | Applied\n | Failed of Failure.Collection.Stable.V1.t\n [@@deriving sexp, yojson, equal, compare]\n\n let to_latest = Fn.id\n end\nend]\n","(* transaction_union_tag.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%else]\n\nopen Mina_base_import\n\n[%%endif]\n\ntype t = Payment | Stake_delegation | Fee_transfer | Coinbase\n[@@deriving enum, equal, sexp]\n\nlet to_string = function\n | Payment ->\n \"payment\"\n | Stake_delegation ->\n \"delegation\"\n | Fee_transfer ->\n \"fee-transfer\"\n | Coinbase ->\n \"coinbase\"\n\nlet gen =\n Quickcheck.Generator.map (Int.gen_incl min max) ~f:(fun i ->\n Option.value_exn (of_enum i) )\n\nmodule Bits = struct\n type t = bool * bool * bool [@@deriving equal]\n\n let of_int i : t =\n let test_mask mask = i land mask = mask in\n (test_mask 0b100, test_mask 0b10, test_mask 0b1)\n\n let of_t x = of_int (to_enum x)\n\n let payment = of_t Payment\n\n let stake_delegation = of_t Stake_delegation\n\n let fee_transfer = of_t Fee_transfer\n\n let coinbase = of_t Coinbase\n\n let to_bits (b1, b2, b3) = [ b1; b2; b3 ]\n\n let to_input_legacy t = Random_oracle.Input.Legacy.bitstring (to_bits t)\n\n [%%ifdef consensus_mechanism]\n\n type var = Boolean.var * Boolean.var * Boolean.var\n\n let typ = Typ.tuple3 Boolean.typ Boolean.typ Boolean.typ\n\n let constant (b1, b2, b3) =\n Boolean.(var_of_value b1, var_of_value b2, var_of_value b3)\n\n [%%endif]\nend\n\nmodule Unpacked = struct\n (* Invariant: exactly one of the tag identifiers must be true. *)\n module Poly = struct\n type 'bool t =\n { is_payment : 'bool\n ; is_stake_delegation : 'bool\n ; is_fee_transfer : 'bool\n ; is_coinbase : 'bool\n ; is_user_command : 'bool\n }\n [@@deriving equal, hlist]\n\n [%%ifdef consensus_mechanism]\n\n let typ (bool : ('bool_var, 'bool) Typ.t) : ('bool_var t, 'bool t) Typ.t =\n Typ.of_hlistable\n [ bool; bool; bool; bool; bool ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n [%%endif]\n end\n\n type t = bool Poly.t [@@deriving equal]\n\n (* An invalid value with all types empty. Do not use directly. *)\n let empty : t =\n { is_payment = false\n ; is_stake_delegation = false\n ; is_fee_transfer = false\n ; is_coinbase = false\n ; is_user_command = false\n }\n\n let payment = { empty with is_payment = true; is_user_command = true }\n\n let stake_delegation =\n { empty with is_stake_delegation = true; is_user_command = true }\n\n let fee_transfer =\n { empty with is_fee_transfer = true; is_user_command = false }\n\n let coinbase = { empty with is_coinbase = true; is_user_command = false }\n\n let of_bits_t (bits : Bits.t) : t =\n match\n List.Assoc.find ~equal:Bits.equal\n [ (Bits.payment, payment)\n ; (Bits.stake_delegation, stake_delegation)\n ; (Bits.fee_transfer, fee_transfer)\n ; (Bits.coinbase, coinbase)\n ]\n bits\n with\n | Some t ->\n t\n | None ->\n raise (Invalid_argument \"Transaction_union_tag.Unpacked.of_bits_t\")\n\n let to_bits_t (t : t) : Bits.t =\n match\n List.Assoc.find ~equal\n [ (payment, Bits.payment)\n ; (stake_delegation, Bits.stake_delegation)\n ; (fee_transfer, Bits.fee_transfer)\n ; (coinbase, Bits.coinbase)\n ]\n t\n with\n | Some bits ->\n bits\n | None ->\n raise (Invalid_argument \"Transaction_union_tag.Unpacked.to_bits_t\")\n\n [%%ifdef consensus_mechanism]\n\n type var = Boolean.var Poly.t\n\n let to_bits_var\n ({ is_payment\n ; is_stake_delegation\n ; is_fee_transfer\n ; is_coinbase\n ; is_user_command = _\n } :\n var ) =\n (* For each bit, compute the sum of all the tags for which that bit is true\n in its bit representation.\n\n Since we have the invariant that exactly one tag identifier is true,\n exactly the bits in that tag's bit representation will be true in the\n resulting bits.\n *)\n let b1, b2, b3 =\n List.fold\n ~init:Field.(Var.(constant zero, constant zero, constant zero))\n [ (Bits.payment, is_payment)\n ; (Bits.stake_delegation, is_stake_delegation)\n ; (Bits.fee_transfer, is_fee_transfer)\n ; (Bits.coinbase, is_coinbase)\n ]\n ~f:(fun (acc1, acc2, acc3) ((bit1, bit2, bit3), bool_var) ->\n let add_if_true bit acc =\n if bit then Field.Var.add acc (bool_var :> Field.Var.t) else acc\n in\n (add_if_true bit1 acc1, add_if_true bit2 acc2, add_if_true bit3 acc3)\n )\n in\n Boolean.Unsafe.(of_cvar b1, of_cvar b2, of_cvar b3)\n\n let typ : (var, t) Typ.t =\n let (Typ base_typ) = Poly.typ Boolean.typ in\n Typ\n { base_typ with\n check =\n (fun ( { is_payment\n ; is_stake_delegation\n ; is_fee_transfer\n ; is_coinbase\n ; is_user_command\n } as t ) ->\n let open Checked.Let_syntax in\n let%bind () = base_typ.check t in\n let%bind () =\n [%with_label_ \"Only one tag is set\"] (fun () ->\n Boolean.Assert.exactly_one\n [ is_payment\n ; is_stake_delegation\n ; is_fee_transfer\n ; is_coinbase\n ] )\n in\n [%with_label_ \"User command flag is correctly set\"] (fun () ->\n Boolean.Assert.exactly_one\n [ is_user_command; is_fee_transfer; is_coinbase ] ) )\n }\n\n let constant\n ({ is_payment\n ; is_stake_delegation\n ; is_fee_transfer\n ; is_coinbase\n ; is_user_command\n } :\n t ) : var =\n { is_payment = Boolean.var_of_value is_payment\n ; is_stake_delegation = Boolean.var_of_value is_stake_delegation\n ; is_fee_transfer = Boolean.var_of_value is_fee_transfer\n ; is_coinbase = Boolean.var_of_value is_coinbase\n ; is_user_command = Boolean.var_of_value is_user_command\n }\n\n let is_payment ({ is_payment; _ } : var) = is_payment\n\n let is_stake_delegation ({ is_stake_delegation; _ } : var) =\n is_stake_delegation\n\n let is_fee_transfer ({ is_fee_transfer; _ } : var) = is_fee_transfer\n\n let is_coinbase ({ is_coinbase; _ } : var) = is_coinbase\n\n let is_user_command ({ is_user_command; _ } : var) = is_user_command\n\n let to_bits t = Bits.to_bits (to_bits_var t)\n\n let to_input_legacy t = Random_oracle.Input.Legacy.bitstring (to_bits t)\n\n [%%endif]\nend\n\nlet unpacked_t_of_t = function\n | Payment ->\n Unpacked.payment\n | Stake_delegation ->\n Unpacked.stake_delegation\n | Fee_transfer ->\n Unpacked.fee_transfer\n | Coinbase ->\n Unpacked.coinbase\n\nlet to_bits tag = Bits.to_bits (Unpacked.to_bits_t (unpacked_t_of_t tag))\n\nlet to_input_legacy tag = Random_oracle.Input.Legacy.bitstring (to_bits tag)\n\n[%%ifdef consensus_mechanism]\n\nlet t_of_unpacked_t (unpacked : Unpacked.t) : t =\n match\n List.Assoc.find ~equal:Unpacked.equal\n [ (Unpacked.payment, Payment)\n ; (Unpacked.stake_delegation, Stake_delegation)\n ; (Unpacked.fee_transfer, Fee_transfer)\n ; (Unpacked.coinbase, Coinbase)\n ]\n unpacked\n with\n | Some t ->\n t\n | None ->\n raise (Invalid_argument \"Transaction_union_tag.t_of_unpacked_t\")\n\nlet bits_t_of_t tag = Unpacked.to_bits_t (unpacked_t_of_t tag)\n\nlet t_of_bits_t tag = t_of_unpacked_t (Unpacked.of_bits_t tag)\n\nlet unpacked_of_t tag = Unpacked.constant (unpacked_t_of_t tag)\n\nlet bits_of_t tag = Bits.constant (bits_t_of_t tag)\n\nlet unpacked_typ =\n Typ.transport Unpacked.typ ~there:unpacked_t_of_t ~back:t_of_unpacked_t\n\nlet bits_typ = Typ.transport Bits.typ ~there:bits_t_of_t ~back:t_of_bits_t\n\nlet%test_module \"predicates\" =\n ( module struct\n let test_predicate checked unchecked =\n let checked x = Checked.return (checked x) in\n for i = min to max do\n Test_util.test_equal unpacked_typ Boolean.typ checked unchecked\n (Option.value_exn (of_enum i))\n done\n\n let one_of xs t = List.mem xs ~equal t\n\n let%test_unit \"is_payment\" =\n test_predicate Unpacked.is_payment (equal Payment)\n\n let%test_unit \"is_stake_delegation\" =\n test_predicate Unpacked.is_stake_delegation (equal Stake_delegation)\n\n let%test_unit \"is_fee_transfer\" =\n test_predicate Unpacked.is_fee_transfer (equal Fee_transfer)\n\n let%test_unit \"is_coinbase\" =\n test_predicate Unpacked.is_coinbase (equal Coinbase)\n\n let%test_unit \"is_user_command\" =\n test_predicate Unpacked.is_user_command\n (one_of [ Payment; Stake_delegation ])\n\n let%test_unit \"not_user_command\" =\n test_predicate\n (fun x -> Boolean.not (Unpacked.is_user_command x))\n (one_of [ Fee_transfer; Coinbase ])\n\n let%test_unit \"bit_representation\" =\n for i = min to max do\n Test_util.test_equal unpacked_typ Bits.typ\n (Fn.compose Checked.return Unpacked.to_bits_var)\n bits_t_of_t\n (Option.value_exn (of_enum i))\n done\n end )\n\n[%%endif]\n","(* user_command_payload.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\nopen Signature_lib\nmodule Memo = Signed_command_memo\nmodule Account_nonce = Mina_numbers.Account_nonce\nmodule Global_slot_since_genesis = Mina_numbers.Global_slot_since_genesis\nmodule Global_slot_legacy = Mina_numbers.Global_slot_legacy\n\n(* This represents the random oracle input corresponding to the old form of the token\n ID, which was a 64-bit integer. The default token id was the number 1.\n\n The corresponding random oracle input is still needed for signing non-snapp\n transactions to maintain compatibility with the old transaction format.\n*)\nmodule Legacy_token_id = struct\n let default : (Field.t, bool) Random_oracle_input.Legacy.t =\n let one = true :: List.init 63 ~f:(fun _ -> false) in\n Random_oracle_input.Legacy.bitstring one\n\n [%%ifdef consensus_mechanism]\n\n let default_checked : (Field.Var.t, Boolean.var) Random_oracle_input.Legacy.t\n =\n { field_elements = Array.map default.field_elements ~f:Field.Var.constant\n ; bitstrings =\n Array.map default.bitstrings ~f:(List.map ~f:Boolean.var_of_value)\n }\n\n [%%endif]\nend\n\nmodule Common = struct\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('fee, 'public_key, 'nonce, 'global_slot, 'memo) t =\n ( 'fee\n , 'public_key\n , 'nonce\n , 'global_slot\n , 'memo )\n Mina_wire_types.Mina_base.Signed_command_payload.Common.Poly.V2.t =\n { fee : 'fee\n ; fee_payer_pk : 'public_key\n ; nonce : 'nonce\n ; valid_until : 'global_slot\n ; memo : 'memo\n }\n [@@deriving compare, equal, sexp, hash, yojson, hlist]\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('fee, 'public_key, 'token_id, 'nonce, 'global_slot, 'memo) t =\n { fee : 'fee\n ; fee_token : 'token_id\n ; fee_payer_pk : 'public_key\n ; nonce : 'nonce\n ; valid_until : 'global_slot\n ; memo : 'memo\n }\n [@@deriving compare, equal, sexp, hash, yojson, hlist]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Currency.Fee.Stable.V1.t\n , Public_key.Compressed.Stable.V1.t\n , Account_nonce.Stable.V1.t\n , Global_slot_since_genesis.Stable.V1.t\n , Memo.Stable.V1.t )\n Poly.Stable.V2.t\n [@@deriving compare, equal, sexp, hash, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t =\n ( Currency.Fee.Stable.V1.t\n , Public_key.Compressed.Stable.V1.t\n , Token_id.Stable.V1.t\n , Account_nonce.Stable.V1.t\n , Global_slot_legacy.Stable.V1.t\n , Memo.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving compare, equal, sexp, hash, yojson]\n\n let to_latest _ = failwith \"Not implemented\"\n end\n end]\n\n let to_input_legacy ({ fee; fee_payer_pk; nonce; valid_until; memo } : t) =\n let bitstring = Random_oracle.Input.Legacy.bitstring in\n Array.reduce_exn ~f:Random_oracle.Input.Legacy.append\n [| Currency.Fee.to_input_legacy fee\n ; Legacy_token_id.default\n ; Public_key.Compressed.to_input_legacy fee_payer_pk\n ; Account_nonce.to_input_legacy nonce\n ; Global_slot_since_genesis.to_input_legacy valid_until\n ; bitstring (Memo.to_bits memo)\n |]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map fee = Currency.Fee.gen\n and fee_payer_pk = Public_key.Compressed.gen\n and nonce = Account_nonce.gen\n and valid_until = Global_slot_since_genesis.gen\n and memo =\n let%bind is_digest = Bool.quickcheck_generator in\n if is_digest then\n String.gen_with_length Memo.max_digestible_string_length\n Char.quickcheck_generator\n >>| Memo.create_by_digesting_string_exn\n else\n String.gen_with_length Memo.max_input_length Char.quickcheck_generator\n >>| Memo.create_from_string_exn\n in\n Poly.{ fee; fee_payer_pk; nonce; valid_until; memo }\n\n [%%ifdef consensus_mechanism]\n\n type var =\n ( Currency.Fee.var\n , Public_key.Compressed.var\n , Account_nonce.Checked.t\n , Global_slot_since_genesis.Checked.t\n , Memo.Checked.t )\n Poly.t\n\n let typ =\n Typ.of_hlistable\n [ Currency.Fee.typ\n ; Public_key.Compressed.typ\n ; Account_nonce.typ\n ; Global_slot_since_genesis.typ\n ; Memo.typ\n ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\n module Checked = struct\n let constant ({ fee; fee_payer_pk; nonce; valid_until; memo } : t) : var =\n { fee = Currency.Fee.var_of_t fee\n ; fee_payer_pk = Public_key.Compressed.var_of_t fee_payer_pk\n ; nonce = Account_nonce.Checked.constant nonce\n ; memo = Memo.Checked.constant memo\n ; valid_until = Global_slot_since_genesis.Checked.constant valid_until\n }\n\n let to_input_legacy ({ fee; fee_payer_pk; nonce; valid_until; memo } : var)\n =\n let%map nonce = Account_nonce.Checked.to_input_legacy nonce\n and valid_until =\n Global_slot_since_genesis.Checked.to_input_legacy valid_until\n and fee = Currency.Fee.var_to_input_legacy fee in\n let fee_token = Legacy_token_id.default_checked in\n Array.reduce_exn ~f:Random_oracle.Input.Legacy.append\n [| fee\n ; fee_token\n ; Public_key.Compressed.Checked.to_input_legacy fee_payer_pk\n ; nonce\n ; valid_until\n ; Random_oracle.Input.Legacy.bitstring\n (Array.to_list (memo :> Boolean.var array))\n |]\n end\n\n [%%endif]\nend\n\nmodule Body = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Signed_command_payload.Body.V2.t =\n | Payment of Payment_payload.Stable.V2.t\n | Stake_delegation of Stake_delegation.Stable.V2.t\n [@@deriving sexp, compare, equal, sexp, hash, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t =\n | Payment of Payment_payload.Stable.V1.t\n | Stake_delegation of Stake_delegation.Stable.V1.t\n (* omitting token commands, none were ever created\n such omission doesn't affect serialization/Base58Check of payments, delegations\n *)\n [@@deriving sexp, compare, equal, sexp, hash, yojson]\n\n let to_latest _ = failwith \"Not implemented\"\n end\n end]\n\n module Tag = Transaction_union_tag\n\n let gen max_amount =\n let open Quickcheck.Generator in\n map\n (variant2 (Payment_payload.gen max_amount) Stake_delegation.gen)\n ~f:(function `A p -> Payment p | `B d -> Stake_delegation d)\n\n let receiver_pk (t : t) =\n match t with\n | Payment payload ->\n payload.receiver_pk\n | Stake_delegation payload ->\n Stake_delegation.receiver_pk payload\n\n let token (_ : t) = Token_id.default\n\n let receiver t =\n match t with\n | Payment payload ->\n Account_id.create payload.receiver_pk Token_id.default\n | Stake_delegation payload ->\n Stake_delegation.receiver payload\n\n let tag = function\n | Payment _ ->\n Transaction_union_tag.Payment\n | Stake_delegation _ ->\n Transaction_union_tag.Stake_delegation\nend\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('common, 'body) t =\n ( 'common\n , 'body )\n Mina_wire_types.Mina_base.Signed_command_payload.Poly.V1.t =\n { common : 'common; body : 'body }\n [@@deriving equal, sexp, hash, yojson, compare, hlist]\n\n let of_latest common_latest body_latest { common; body } =\n let open Result.Let_syntax in\n let%map common = common_latest common and body = body_latest body in\n { common; body }\n end\n end]\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = (Common.Stable.V2.t, Body.Stable.V2.t) Poly.Stable.V1.t\n [@@deriving compare, equal, sexp, hash, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = (Common.Stable.V1.t, Body.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving compare, equal, sexp, hash, yojson]\n\n (* don't need to coerce old transactions to newer version *)\n let to_latest _ = failwith \"Not implemented\"\n end\nend]\n\nlet create ~fee ~fee_payer_pk ~nonce ~valid_until ~memo ~body : t =\n { common =\n { fee\n ; fee_payer_pk\n ; nonce\n ; valid_until =\n Option.value valid_until ~default:Global_slot_since_genesis.max_value\n ; memo\n }\n ; body\n }\n\nlet fee (t : t) = t.common.fee\n\nlet fee_token (_ : t) = Token_id.default\n\nlet fee_payer_pk (t : t) = t.common.fee_payer_pk\n\nlet fee_payer (t : t) = Account_id.create t.common.fee_payer_pk Token_id.default\n\nlet nonce (t : t) = t.common.nonce\n\nlet valid_until (t : t) = t.common.valid_until\n\nlet memo (t : t) = t.common.memo\n\nlet body (t : t) = t.body\n\nlet receiver_pk (t : t) = Body.receiver_pk t.body\n\nlet receiver (t : t) = Body.receiver t.body\n\nlet token (t : t) = Body.token t.body\n\nlet tag (t : t) = Body.tag t.body\n\nlet amount (t : t) =\n match t.body with\n | Payment payload ->\n Some payload.Payment_payload.Poly.amount\n | Stake_delegation _ ->\n None\n\nlet fee_excess (t : t) =\n Fee_excess.of_single (fee_token t, Currency.Fee.Signed.of_unsigned (fee t))\n\nlet account_access_statuses (t : t) (status : Transaction_status.t) =\n match status with\n | Applied ->\n List.map\n [ fee_payer t; receiver t ]\n ~f:(fun acct_id -> (acct_id, `Accessed))\n | Failed _ ->\n (fee_payer t, `Accessed)\n :: List.map [ receiver t ] ~f:(fun acct_id -> (acct_id, `Not_accessed))\n\nlet dummy : t =\n { common =\n { fee = Currency.Fee.zero\n ; fee_payer_pk = Public_key.Compressed.empty\n ; nonce = Account_nonce.zero\n ; valid_until = Global_slot_since_genesis.max_value\n ; memo = Memo.dummy\n }\n ; body = Payment Payment_payload.dummy\n }\n\nlet gen =\n let open Quickcheck.Generator.Let_syntax in\n let%bind common = Common.gen in\n let max_amount =\n Currency.Amount.(sub max_int (of_fee common.fee))\n |> Option.value_exn ?here:None ?error:None ?message:None\n in\n let%map body = Body.gen max_amount in\n Poly.{ common; body }\n\n(** This module defines a weight for each payload component *)\nmodule Weight = struct\n let payment (_payment_payload : Payment_payload.t) : int = 1\n\n let stake_delegation (_stake_delegation : Stake_delegation.t) : int = 1\n\n let of_body : Body.t -> int = function\n | Payment payment_payload ->\n payment payment_payload\n | Stake_delegation stake_delegation_payload ->\n stake_delegation stake_delegation_payload\nend\n\nlet weight (signed_command_payload : t) : int =\n body signed_command_payload |> Weight.of_body\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_import\nopen Mina_numbers\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Signed_command\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Signed_command_intf.Full\n with type With_valid_signature.Stable.Latest.t =\n A.With_valid_signature.V2.t\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n module Fee = Currency.Fee\n module Payload = Signed_command_payload\n\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('payload, 'pk, 'signature) t =\n ( 'payload\n , 'pk\n , 'signature )\n Mina_wire_types.Mina_base.Signed_command.Poly.V1.t =\n { payload : 'payload; signer : 'pk; signature : 'signature }\n [@@deriving compare, sexp, hash, yojson, equal]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n [@@@with_top_version_tag]\n\n (* DO NOT DELETE VERSIONS!\n so we can always get transaction hashes from old transaction ids\n the version linter should be checking this\n\n IF YOU CREATE A NEW VERSION:\n update Transaction_hash.hash_of_transaction_id to handle it\n add hash_signed_command_vn for that version\n *)\n\n module V2 = struct\n type t =\n ( Payload.Stable.V2.t\n , Public_key.Stable.V1.t\n , Signature.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving compare, sexp, hash, yojson]\n\n let to_latest = Fn.id\n\n module T = struct\n (* can't use nonrec + deriving *)\n type typ = t [@@deriving compare, sexp, hash]\n\n type t = typ [@@deriving compare, sexp, hash]\n end\n\n include Comparable.Make (T)\n include Hashable.Make (T)\n\n let account_access_statuses ({ payload; _ } : t) status =\n Payload.account_access_statuses payload status\n\n let accounts_referenced (t : t) =\n List.map (account_access_statuses t Applied)\n ~f:(fun (acct_id, _status) -> acct_id)\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t =\n ( Payload.Stable.V1.t\n , Public_key.Stable.V1.t\n , Signature.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving compare, sexp, hash, yojson]\n\n let to_latest ({ payload; signer; signature } : t) : Latest.t =\n let payload : Signed_command_payload.t =\n let valid_until =\n Global_slot_legacy.to_uint32 payload.common.valid_until\n |> Global_slot_since_genesis.of_uint32\n in\n let common : Signed_command_payload.Common.t =\n { fee = payload.common.fee\n ; fee_payer_pk = payload.common.fee_payer_pk\n ; nonce = payload.common.nonce\n ; valid_until\n ; memo = payload.common.memo\n }\n in\n let body : Signed_command_payload.Body.t =\n match payload.body with\n | Payment payment_payload ->\n let payload' : Payment_payload.t =\n { receiver_pk = payment_payload.receiver_pk\n ; amount = payment_payload.amount\n }\n in\n Payment payload'\n | Stake_delegation stake_delegation_payload ->\n Stake_delegation\n (Stake_delegation.Stable.V1.to_latest stake_delegation_payload)\n in\n { common; body }\n in\n { payload; signer; signature }\n end\n end]\n\n (* type of signed commands, pre-Berkeley hard fork *)\n type t_v1 = Stable.V1.t\n\n let (_ : (t, (Payload.t, Public_key.t, Signature.t) Poly.t) Type_equal.t) =\n Type_equal.T\n\n include (Stable.Latest : module type of Stable.Latest with type t := t)\n\n let signature Poly.{ signature; _ } = signature\n\n let payload Poly.{ payload; _ } = payload\n\n let fee = Fn.compose Payload.fee payload\n\n let nonce = Fn.compose Payload.nonce payload\n\n (* for filtering *)\n let minimum_fee = Currency.Fee.minimum_user_command_fee\n\n let has_insufficient_fee t = Currency.Fee.(fee t < minimum_fee)\n\n let signer { Poly.signer; _ } = signer\n\n let fee_token (_ : t) = Token_id.default\n\n let fee_payer_pk ({ payload; _ } : t) = Payload.fee_payer_pk payload\n\n let fee_payer ({ payload; _ } : t) = Payload.fee_payer payload\n\n let fee_excess ({ payload; _ } : t) = Payload.fee_excess payload\n\n let token ({ payload; _ } : t) = Payload.token payload\n\n let receiver_pk ({ payload; _ } : t) = Payload.receiver_pk payload\n\n let receiver ({ payload; _ } : t) = Payload.receiver payload\n\n let amount = Fn.compose Payload.amount payload\n\n let memo = Fn.compose Payload.memo payload\n\n let valid_until = Fn.compose Payload.valid_until payload\n\n let tag ({ payload; _ } : t) = Payload.tag payload\n\n let tag_string (t : t) =\n match t.payload.body with\n | Payment _ ->\n \"payment\"\n | Stake_delegation _ ->\n \"delegation\"\n\n let to_input_legacy (payload : Payload.t) =\n Transaction_union_payload.(\n to_input_legacy (of_user_command_payload payload))\n\n let sign_payload ?signature_kind (private_key : Signature_lib.Private_key.t)\n (payload : Payload.t) : Signature.t =\n Signature_lib.Schnorr.Legacy.sign ?signature_kind private_key\n (to_input_legacy payload)\n\n let sign ?signature_kind (kp : Signature_keypair.t) (payload : Payload.t) : t\n =\n { payload\n ; signer = kp.public_key\n ; signature = sign_payload ?signature_kind kp.private_key payload\n }\n\n module For_tests = struct\n (* Pretend to sign a command. Much faster than actually signing. *)\n let fake_sign ?signature_kind:_ (kp : Signature_keypair.t)\n (payload : Payload.t) : t =\n { payload; signer = kp.public_key; signature = Signature.dummy }\n end\n\n module Gen = struct\n let gen_inner (sign' : Signature_lib.Keypair.t -> Payload.t -> t) ~key_gen\n ?(nonce = Account_nonce.zero) ~fee_range create_body =\n let open Quickcheck.Generator.Let_syntax in\n let min_fee = Fee.to_nanomina_int Currency.Fee.minimum_user_command_fee in\n let max_fee = min_fee + fee_range in\n let%bind (signer : Signature_keypair.t), (receiver : Signature_keypair.t)\n =\n key_gen\n and fee =\n Int.gen_incl min_fee max_fee >>| Currency.Fee.of_nanomina_int_exn\n and memo = String.quickcheck_generator in\n let%map body = create_body signer receiver in\n let payload : Payload.t =\n Payload.create ~fee\n ~fee_payer_pk:(Public_key.compress signer.public_key)\n ~nonce ~valid_until:None\n ~memo:(Signed_command_memo.create_by_digesting_string_exn memo)\n ~body\n in\n sign' signer payload\n\n let with_random_participants ~keys ~gen =\n let key_gen = Quickcheck_lib.gen_pair @@ Quickcheck_lib.of_array keys in\n gen ~key_gen\n\n module Payment = struct\n let gen_inner (sign' : Signature_lib.Keypair.t -> Payload.t -> t) ~key_gen\n ?nonce ?(min_amount = 1) ~max_amount ~fee_range () =\n gen_inner sign' ~key_gen ?nonce ~fee_range\n @@ fun { public_key = signer; _ } { public_key = receiver; _ } ->\n let open Quickcheck.Generator.Let_syntax in\n let%map amount =\n Int.gen_incl min_amount max_amount\n >>| Currency.Amount.of_nanomina_int_exn\n in\n Signed_command_payload.Body.Payment\n { receiver_pk = Public_key.compress receiver; amount }\n\n let gen ?(sign_type = `Fake) =\n match sign_type with\n | `Fake ->\n gen_inner For_tests.fake_sign\n | `Real ->\n gen_inner sign\n\n let gen_with_random_participants ?sign_type ~keys ?nonce ?min_amount\n ~max_amount ~fee_range =\n with_random_participants ~keys ~gen:(fun ~key_gen ->\n gen ?sign_type ~key_gen ?nonce ?min_amount ~max_amount ~fee_range )\n end\n\n module Stake_delegation = struct\n let gen ~key_gen ?nonce ~fee_range () =\n gen_inner For_tests.fake_sign ~key_gen ?nonce ~fee_range\n (fun { public_key = signer; _ } { public_key = new_delegate; _ } ->\n Quickcheck.Generator.return\n @@ Signed_command_payload.Body.Stake_delegation\n (Set_delegate\n { new_delegate = Public_key.compress new_delegate } ) )\n\n let gen_with_random_participants ~keys ?nonce ~fee_range =\n with_random_participants ~keys ~gen:(gen ?nonce ~fee_range)\n end\n\n let payment = Payment.gen\n\n let payment_with_random_participants = Payment.gen_with_random_participants\n\n let stake_delegation = Stake_delegation.gen\n\n let stake_delegation_with_random_participants =\n Stake_delegation.gen_with_random_participants\n\n let sequence :\n ?length:int\n -> ?sign_type:[ `Fake | `Real ]\n -> ( Signature_lib.Keypair.t\n * Currency.Amount.t\n * Mina_numbers.Account_nonce.t\n * Account_timing.t )\n array\n -> t list Quickcheck.Generator.t =\n fun ?length ?(sign_type = `Fake) account_info ->\n let open Quickcheck.Generator in\n let open Quickcheck.Generator.Let_syntax in\n let%bind n_commands =\n Option.value_map length ~default:small_non_negative_int ~f:return\n in\n if Int.(n_commands = 0) then return []\n else\n let n_accounts = Array.length account_info in\n let%bind command_senders, currency_splits =\n (* How many commands will be issued from each account? *)\n (let%bind command_splits =\n Quickcheck_lib.gen_division n_commands n_accounts\n in\n let command_splits' = Array.of_list command_splits in\n (* List of payment senders in the final order. *)\n let%bind command_senders =\n Quickcheck_lib.shuffle\n @@ List.concat_mapi command_splits ~f:(fun idx cmds ->\n List.init cmds ~f:(Fn.const idx) )\n in\n (* within the accounts, how will the currency be split into separate\n payments? *)\n let%bind currency_splits =\n Quickcheck_lib.init_gen_array\n ~f:(fun i ->\n let%bind spend_all = bool in\n let _, balance, _, _ = account_info.(i) in\n let amount_to_spend =\n if spend_all then balance\n else\n Currency.Amount.of_nanomina_int_exn\n (Currency.Amount.to_nanomina_int balance / 2)\n in\n Quickcheck_lib.gen_division_currency amount_to_spend\n command_splits'.(i) )\n n_accounts\n in\n return (command_senders, currency_splits) )\n |> (* We need to ensure each command has enough currency for a fee of 2\n or more, so it'll be enough to buy the requisite transaction\n snarks. It's important that the backtracking from filter goes and\n redraws command_splits as well as currency_splits, so we don't get\n stuck in a situation where it's very unlikely for the predicate to\n pass. *)\n Quickcheck.Generator.filter ~f:(fun (_, splits) ->\n Array.for_all splits ~f:(fun split ->\n List.for_all split ~f:(fun amt ->\n Currency.Amount.(amt >= of_mina_int_exn 2) ) ) )\n in\n let account_nonces =\n Array.map ~f:(fun (_, _, nonce, _) -> nonce) account_info\n in\n let uncons_exn = function\n | [] ->\n failwith \"uncons_exn\"\n | x :: xs ->\n (x, xs)\n in\n Quickcheck_lib.map_gens command_senders ~f:(fun sender ->\n let this_split, rest_splits = uncons_exn currency_splits.(sender) in\n let sender_pk, _, _, _ = account_info.(sender) in\n currency_splits.(sender) <- rest_splits ;\n let nonce = account_nonces.(sender) in\n account_nonces.(sender) <- Account_nonce.succ nonce ;\n let%bind fee =\n (* use of_string here because json_of_ocaml won't handle\n equivalent integer constants\n *)\n Currency.Fee.(\n gen_incl (of_string \"6000000000\")\n (min (of_string \"10000000000\")\n (Currency.Amount.to_fee this_split) ))\n in\n let amount =\n Option.value_exn Currency.Amount.(this_split - of_fee fee)\n in\n let%bind receiver =\n map ~f:(fun idx ->\n let kp, _, _, _ = account_info.(idx) in\n Public_key.compress kp.public_key )\n @@ Int.gen_uniform_incl 0 (n_accounts - 1)\n in\n let memo = Signed_command_memo.dummy in\n let payload =\n let sender_pk = Public_key.compress sender_pk.public_key in\n Payload.create ~fee ~fee_payer_pk:sender_pk ~valid_until:None\n ~nonce ~memo\n ~body:(Payment { receiver_pk = receiver; amount })\n in\n let sign' =\n match sign_type with\n | `Fake ->\n For_tests.fake_sign\n | `Real ->\n sign\n in\n return @@ sign' sender_pk payload )\n end\n\n module With_valid_signature = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Stable.V2.t [@@deriving sexp, equal, yojson, hash]\n\n let to_latest = Stable.V2.to_latest\n\n let compare = Stable.V2.compare\n\n let equal = Stable.V2.equal\n\n module Gen = Gen\n end\n end]\n\n module Gen = Stable.Latest.Gen\n include Comparable.Make (Stable.Latest)\n end\n\n let to_valid_unsafe t =\n `If_this_is_used_it_should_have_a_comment_justifying_it t\n\n (* so we can deserialize Base58Check transaction ids created before Berkeley hard fork *)\n module V1_all_tagged = struct\n include Stable.V1.With_all_version_tags\n\n let description = \"Signed command\"\n\n let version_byte = Base58_check.Version_bytes.signed_command_v1\n end\n\n let of_base58_check_exn_v1, to_base58_check_v1 =\n let module Base58_check_v1 = Codable.Make_base58_check (V1_all_tagged) in\n Base58_check_v1.(of_base58_check, to_base58_check)\n\n (* give transaction ids have version tag *)\n include Codable.Make_base64 (Stable.Latest.With_top_version_tag)\n\n let check_signature ?signature_kind ({ payload; signer; signature } : t) =\n Signature_lib.Schnorr.Legacy.verify ?signature_kind signature\n (Snark_params.Tick.Inner_curve.of_affine signer)\n (to_input_legacy payload)\n\n let public_keys t =\n let fee_payer = fee_payer_pk t in\n let receiver = receiver_pk t in\n [ fee_payer; receiver ]\n\n let check_valid_keys t =\n List.for_all (public_keys t) ~f:(fun pk ->\n Option.is_some (Public_key.decompress pk) )\n\n let create_with_signature_checked ?signature_kind signature signer payload =\n let open Option.Let_syntax in\n let%bind signer = Public_key.decompress signer in\n let t = Poly.{ payload; signature; signer } in\n Option.some_if (check_signature ?signature_kind t && check_valid_keys t) t\n\n let gen_test =\n let open Quickcheck.Let_syntax in\n let%bind keys =\n Quickcheck.Generator.list_with_length 2 Signature_keypair.gen\n in\n Gen.payment_with_random_participants ~sign_type:`Real\n ~keys:(Array.of_list keys) ~max_amount:10000 ~fee_range:1000 ()\n\n let%test_unit \"completeness\" =\n Quickcheck.test ~trials:20 gen_test ~f:(fun t -> assert (check_signature t))\n\n let%test_unit \"json\" =\n Quickcheck.test ~trials:20 ~sexp_of:sexp_of_t gen_test ~f:(fun t ->\n assert (Codable.For_tests.check_encoding (module Stable.Latest) ~equal t) )\n\n (* return type is `t option` here, interface coerces that to `With_valid_signature.t option` *)\n let check t = Option.some_if (check_signature t && check_valid_keys t) t\n\n (* return type is `t option` here, interface coerces that to `With_valid_signature.t option` *)\n let check_only_for_signature t = Option.some_if (check_signature t) t\n\n let forget_check t = t\n\n let filter_by_participant user_commands public_key =\n List.filter user_commands ~f:(fun user_command ->\n Core_kernel.List.exists\n (accounts_referenced user_command)\n ~f:\n (Fn.compose\n (Public_key.Compressed.equal public_key)\n Account_id.public_key ) )\n\n let%test \"latest signed command version\" =\n (* if this test fails, update `Transaction_hash.hash_of_transaction_id`\n for latest version, then update this test\n *)\n Int.equal Stable.Latest.version 2\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","(* receipt.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nmodule B58_lib = Base58_check\nopen Snark_params.Tick\n\nmodule Signed_command_elt = struct\n type t = Signed_command_payload of Signed_command.Payload.t\nend\n\nmodule Zkapp_command_elt = struct\n type t = Zkapp_command_commitment of Random_oracle.Digest.t\nend\n\nmodule Chain_hash = struct\n include Data_hash.Make_full_size (struct\n let description = \"Receipt chain hash\"\n\n let version_byte = Base58_check.Version_bytes.receipt_chain_hash\n end)\n\n (* Data hash versioned boilerplate below *)\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\n end]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n let equal = Stable.Latest.equal\n\n let empty =\n of_hash (Hash_prefix_create.salt \"CodaReceiptEmpty\" |> Random_oracle.digest)\n\n let cons_signed_command_payload (e : Signed_command_elt.t) (t : t) =\n let open Random_oracle.Legacy in\n let x =\n match e with\n | Signed_command_payload payload ->\n Transaction_union_payload.(\n to_input_legacy (of_user_command_payload payload))\n in\n Input.(append x (field (t :> Field.t)))\n |> pack_input\n |> hash ~init:Hash_prefix.receipt_chain_signed_command\n |> of_hash\n\n (* prepend account_update index computed by Zkapp_command_logic.apply *)\n let cons_zkapp_command_commitment (index : Mina_numbers.Index.t)\n (e : Zkapp_command_elt.t) (t : t) =\n let open Random_oracle in\n let x =\n match e with Zkapp_command_commitment s -> Input.Chunked.field s\n in\n let index_input = Mina_numbers.Index.to_input index in\n Input.Chunked.(append index_input (append x (field (t :> Field.t))))\n |> pack_input\n |> hash ~init:Hash_prefix.receipt_chain_zkapp_command\n |> of_hash\n\n [%%if defined consensus_mechanism]\n\n module Checked = struct\n module Signed_command_elt = struct\n type t = Signed_command_payload of Transaction_union_payload.var\n end\n\n module Zkapp_command_elt = struct\n type t = Zkapp_command_commitment of Random_oracle.Checked.Digest.t\n end\n\n let constant (t : t) =\n var_of_hash_packed (Field.Var.constant (t :> Field.t))\n\n type t = var\n\n let equal t1 t2 = equal_var t1 t2\n\n let if_ = if_\n\n let cons_signed_command_payload (e : Signed_command_elt.t) t =\n let open Random_oracle.Legacy in\n let%bind x =\n match e with\n | Signed_command_payload payload ->\n let%map payload =\n Transaction_union_payload.Checked.to_input_legacy payload\n in\n payload\n in\n make_checked (fun () ->\n Checked.hash ~init:Hash_prefix.receipt_chain_signed_command\n (Checked.pack_input Input.(append x (field (var_to_hash_packed t))))\n |> var_of_hash_packed )\n\n (* prepend account_update index *)\n let cons_zkapp_command_commitment (index : Mina_numbers.Index.Checked.t)\n (e : Zkapp_command_elt.t) (t : t) =\n let open Random_oracle in\n let%bind x =\n match e with\n | Zkapp_command_commitment s ->\n Let_syntax.return (Input.Chunked.field s)\n in\n let index_input = Mina_numbers.Index.Checked.to_input index in\n make_checked (fun () ->\n Checked.hash ~init:Hash_prefix.receipt_chain_zkapp_command\n (Checked.pack_input\n Input.Chunked.(\n append index_input (append x (field (var_to_hash_packed t)))) )\n |> var_of_hash_packed )\n end\n\n [%%endif]\nend\n","open Core_kernel\nopen Snark_params.Tick\n\ninclude Data_hash.Make_full_size (struct\n let description = \"State body hash\"\n\n let version_byte = Base58_check.Version_bytes.state_body_hash\nend)\n\nlet dummy = of_hash Outside_hash_image.t\n\n(* Data hash versioned boilerplate below *)\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\nend]\n\nlet (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nlet field_of_bool = Mina_base_util.field_of_bool\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\nopen Signature_lib\n\n[%%endif]\n\nlet int_to_bits ~length x = List.init length ~f:(fun i -> (x lsr i) land 1 = 1)\n\nlet int_of_bits =\n List.foldi ~init:0 ~f:(fun i acc b -> if b then acc lor (1 lsl i) else acc)\n\nmodule Transition = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = { prev : 'a; next : 'a }\n [@@deriving hlist, sexp, equal, yojson, hash, compare]\n end\n end]\n\n let to_input { prev; next } ~f =\n Random_oracle_input.Chunked.append (f prev) (f next)\n\n [%%ifdef consensus_mechanism]\n\n let typ t =\n Typ.of_hlistable [ t; t ] ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n [%%endif]\nend\n\nmodule Flagged_data = struct\n type ('flag, 'a) t = { flag : 'flag; data : 'a } [@@deriving hlist, fields]\n\n [%%ifdef consensus_mechanism]\n\n let typ flag t =\n Typ.of_hlistable [ flag; t ] ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n [%%endif]\n\n let to_input' { flag; data } ~flag:f ~data:d =\n Random_oracle_input.Chunked.(append (f flag) (d data))\nend\n\nmodule Flagged_option = struct\n type ('bool, 'a) t = { is_some : 'bool; data : 'a } [@@deriving hlist, fields]\n\n let to_input' ~field_of_bool { is_some; data } ~f =\n Random_oracle_input.Chunked.(\n append (packed (field_of_bool is_some, 1)) (f data))\n\n let to_input { is_some; data } ~default ~f =\n let data = if is_some then data else default in\n to_input' { is_some; data } ~f\n\n let of_option t ~default =\n match t with\n | None ->\n { is_some = false; data = default }\n | Some data ->\n { is_some = true; data }\n\n let to_option { is_some; data } = Option.some_if is_some data\n\n let map ~f { is_some; data } = { is_some; data = f data }\n\n [%%ifdef consensus_mechanism]\n\n let if_ ~(if_ : 'b -> then_:'var -> else_:'var -> 'var) b ~then_ ~else_ =\n { is_some =\n Run.run_checked\n (Boolean.if_ b ~then_:then_.is_some ~else_:else_.is_some)\n ; data = if_ b ~then_:then_.data ~else_:else_.data\n }\n\n let typ t =\n Typ.of_hlistable [ Boolean.typ; t ] ~var_to_hlist:to_hlist\n ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let option_typ ~default t =\n Typ.transport (typ t) ~there:(of_option ~default) ~back:to_option\n\n let lazy_option_typ ~default t =\n Typ.transport (typ t)\n ~there:(fun t -> of_option t ~default:(Lazy.force default))\n ~back:to_option\n\n [%%endif]\nend\n\nmodule Set_or_keep = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = 'a Mina_wire_types.Mina_base.Zkapp_basic.Set_or_keep.V1.t =\n | Set of 'a\n | Keep\n [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n let map t ~f = match t with Keep -> Keep | Set x -> Set (f x)\n\n let to_option = function Set x -> Some x | Keep -> None\n\n let of_option = function Some x -> Set x | None -> Keep\n\n let set_or_keep t x = match t with Keep -> x | Set y -> y\n\n let is_set = function Set _ -> true | _ -> false\n\n let is_keep = function Keep -> true | _ -> false\n\n let deriver inner obj =\n let open Fields_derivers_zkapps.Derivers in\n iso ~map:of_option ~contramap:to_option\n ((option ~js_type:Flagged_option @@ inner @@ o ()) (o ()))\n obj\n\n let gen gen_a =\n let open Quickcheck.Let_syntax in\n (* with equal probability, return a Set or a Keep *)\n let%bind b = Quickcheck.Generator.bool in\n if b then\n let%bind a = gen_a in\n return (Set a)\n else return Keep\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n type 'a t\n\n val is_keep : _ t -> Boolean.var\n\n val is_set : _ t -> Boolean.var\n\n val set_or_keep :\n if_:(Boolean.var -> then_:'a -> else_:'a -> 'a) -> 'a t -> 'a -> 'a\n\n val data : 'a t -> 'a\n\n val typ :\n dummy:'a -> ('a_var, 'a) Typ.t -> ('a_var t, 'a Stable.Latest.t) Typ.t\n\n val optional_typ :\n to_option:('new_value -> 'value option)\n -> of_option:('value option -> 'new_value)\n -> ('var, 'new_value) Typ.t\n -> ('var t, 'value Stable.Latest.t) Typ.t\n\n val map : f:('a -> 'b) -> 'a t -> 'b t\n\n val to_input :\n 'a t\n -> f:('a -> Field.Var.t Random_oracle_input.Chunked.t)\n -> Field.Var.t Random_oracle_input.Chunked.t\n\n val set : 'a -> 'a t\n\n val keep : dummy:'a -> 'a t\n\n val make_unsafe : Boolean.var -> 'a -> 'a t\n end = struct\n type 'a t = (Boolean.var, 'a) Flagged_option.t\n\n let set_or_keep ~if_ ({ is_some; data } : _ t) x =\n if_ is_some ~then_:data ~else_:x\n\n let data = Flagged_option.data\n\n let is_set = Flagged_option.is_some\n\n let is_keep x = Boolean.not (Flagged_option.is_some x)\n\n let map = Flagged_option.map\n\n let typ ~dummy t =\n Typ.transport\n (Flagged_option.option_typ ~default:dummy t)\n ~there:to_option ~back:of_option\n\n let optional_typ (type new_value value var) :\n to_option:(new_value -> value option)\n -> of_option:(value option -> new_value)\n -> (var, new_value) Typ.t\n -> (var t, value Stable.Latest.t) Typ.t =\n fun ~to_option ~of_option t ->\n Typ.transport (Flagged_option.typ t)\n ~there:(function\n | Set x ->\n { Flagged_option.is_some = true; data = of_option (Some x) }\n | Keep ->\n { Flagged_option.is_some = false; data = of_option None } )\n ~back:(function\n | { Flagged_option.is_some = true; data = x } ->\n Set (Option.value_exn (to_option x))\n | { Flagged_option.is_some = false; data = _ } ->\n Keep )\n\n let to_input (t : _ t) ~f =\n Flagged_option.to_input' t ~f ~field_of_bool:(fun (b : Boolean.var) ->\n (b :> Field.Var.t) )\n\n let make_unsafe is_keep data = { Flagged_option.is_some = is_keep; data }\n\n let set data = { Flagged_option.is_some = Boolean.true_; data }\n\n let keep ~dummy = { Flagged_option.is_some = Boolean.false_; data = dummy }\n end\n\n let typ = Checked.typ\n\n let optional_typ = Checked.optional_typ\n\n [%%endif]\n\n let to_input t ~dummy:default ~f =\n Flagged_option.to_input ~default ~f ~field_of_bool\n (Flagged_option.of_option ~default (to_option t))\nend\n\nmodule Or_ignore = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = 'a Mina_wire_types.Mina_base.Zkapp_basic.Or_ignore.V1.t =\n | Check of 'a\n | Ignore\n [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n let gen gen_a =\n let open Quickcheck.Let_syntax in\n (* choose constructor *)\n let%bind b = Quickcheck.Generator.bool in\n if b then\n let%map a = gen_a in\n Check a\n else return Ignore\n\n let to_option = function Ignore -> None | Check x -> Some x\n\n let of_option = function None -> Ignore | Some x -> Check x\n\n let deriver_base ~js_type inner obj =\n let open Fields_derivers_zkapps.Derivers in\n iso ~map:of_option ~contramap:to_option\n ((option ~js_type @@ inner @@ o ()) (o ()))\n obj\n\n let deriver inner obj = deriver_base ~js_type:Flagged_option inner obj\n\n let deriver_interval inner obj ~range_max =\n deriver_base ~js_type:(Closed_interval range_max) inner obj\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n type 'a t\n\n val typ :\n ignore:'a -> ('a_var, 'a) Typ.t -> ('a_var t, 'a Stable.Latest.t) Typ.t\n\n val to_input :\n 'a t\n -> f:('a -> Field.Var.t Random_oracle_input.Chunked.t)\n -> Field.Var.t Random_oracle_input.Chunked.t\n\n val check : 'a t -> f:('a -> Boolean.var) -> Boolean.var\n\n val map : f:('a -> 'b) -> 'a t -> 'b t\n\n val data : 'a t -> 'a\n\n val is_check : 'a t -> Boolean.var\n\n val make_unsafe : Boolean.var -> 'a -> 'a t\n end = struct\n type 'a t = (Boolean.var, 'a) Flagged_option.t\n\n let to_input t ~f =\n Flagged_option.to_input' t ~f ~field_of_bool:(fun (b : Boolean.var) ->\n (b :> Field.Var.t) )\n\n let check { Flagged_option.is_some; data } ~f =\n Pickles.Impls.Step.Boolean.(any [ not is_some; f data ])\n\n let map = Flagged_option.map\n\n let data = Flagged_option.data\n\n let is_check = Flagged_option.is_some\n\n let typ (type a_var a) ~ignore (t : (a_var, a) Typ.t) =\n Typ.transport\n (Flagged_option.option_typ ~default:ignore t)\n ~there:to_option ~back:of_option\n\n let make_unsafe is_ignore data =\n { Flagged_option.is_some = is_ignore; data }\n end\n\n let typ = Checked.typ\n\n [%%endif]\nend\n\nmodule Account_state = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Empty | Non_empty | Any\n [@@deriving sexp, equal, yojson, hash, compare, enum]\n\n let to_latest = Fn.id\n end\n end]\n\n module Encoding = struct\n type 'b t = { any : 'b; empty : 'b } [@@deriving hlist]\n\n let to_input ~field_of_bool { any; empty } =\n Random_oracle_input.Chunked.packeds\n [| (field_of_bool any, 1); (field_of_bool empty, 1) |]\n end\n\n let encode : t -> bool Encoding.t = function\n | Empty ->\n { any = false; empty = true }\n | Non_empty ->\n { any = false; empty = false }\n | Any ->\n { any = true; empty = false }\n\n let decode : bool Encoding.t -> t = function\n | { any = false; empty = true } ->\n Empty\n | { any = false; empty = false } ->\n Non_empty\n | { any = true; empty = false } | { any = true; empty = true } ->\n Any\n\n let to_input (x : t) = Encoding.to_input ~field_of_bool (encode x)\n\n let check (t : t) (x : [ `Empty | `Non_empty ]) =\n match (t, x) with\n | Any, _ | Non_empty, `Non_empty | Empty, `Empty ->\n Ok ()\n | _ ->\n Or_error.error_string \"Bad account_type\"\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n open Pickles.Impls.Step\n\n type t = Boolean.var Encoding.t\n\n let to_input (t : t) =\n Encoding.to_input t ~field_of_bool:(fun (b : Boolean.var) ->\n (b :> Field.t) )\n\n let check (t : t) ~is_empty =\n Boolean.(\n any [ t.any; t.empty && is_empty; (not t.empty) && not is_empty ])\n end\n\n let typ : (Checked.t, t) Typ.t =\n let open Encoding in\n Typ.of_hlistable\n [ Boolean.typ; Boolean.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n |> Typ.transport ~there:encode ~back:decode\n\n [%%endif]\nend\n\n[%%ifdef consensus_mechanism]\n\nmodule F = Pickles.Backend.Tick.Field\n\n[%%else]\n\nmodule F = Snark_params.Tick.Field\n\n[%%endif]\n\nmodule F_map = struct\n include Hashable.Make (F)\n include Comparable.Make (F)\nend\n\nlet invalid_public_key : Public_key.Compressed.t =\n { x = F.zero; is_odd = false }\n\nlet%test \"invalid_public_key is invalid\" =\n Option.is_none (Public_key.decompress invalid_public_key)\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\nopen Zkapp_basic\n\nmodule Event = struct\n (* Arbitrary hash input, encoding determined by the zkApp's developer. *)\n type t = Field.t array [@@deriving compare, sexp]\n\n let hash (x : t) = Random_oracle.hash ~init:Hash_prefix_states.zkapp_event x\n\n [%%ifdef consensus_mechanism]\n\n type var = Field.Var.t array\n\n let hash_var (x : Field.Var.t array) =\n Random_oracle.Checked.hash ~init:Hash_prefix_states.zkapp_event x\n\n [%%endif]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck in\n Generator.map ~f:Array.of_list @@ Generator.list Field.gen\nend\n\nmodule Make_events (Inputs : sig\n val salt_phrase : string\n\n val hash_prefix : field Random_oracle.State.t\n\n val deriver_name : string\nend) =\nstruct\n type t = Event.t list [@@deriving compare, sexp]\n\n let empty_hash =\n Hash_prefix_create.salt Inputs.salt_phrase |> Random_oracle.digest\n\n let push_hash acc hash =\n Random_oracle.hash ~init:Inputs.hash_prefix [| acc; hash |]\n\n let push_event acc event = push_hash acc (Event.hash event)\n\n let hash (x : t) =\n (* fold_right so the empty hash is used at the end of the events *)\n List.fold_right ~init:empty_hash ~f:(Fn.flip push_event) x\n\n [%%ifdef consensus_mechanism]\n\n type var = t Data_as_hash.t\n\n let typ = Data_as_hash.typ ~hash\n\n let var_to_input (x : var) = Data_as_hash.to_input x\n\n let to_input (x : t) = Random_oracle_input.Chunked.field (hash x)\n\n let push_to_data_as_hash (events : var) (e : Event.var) : var =\n let open Run in\n let res =\n exists typ ~compute:(fun () ->\n let tl = As_prover.read typ events in\n let hd =\n As_prover.read (Typ.array ~length:(Array.length e) Field.typ) e\n in\n hd :: tl )\n in\n Field.Assert.equal\n (Random_oracle.Checked.hash ~init:Inputs.hash_prefix\n [| Data_as_hash.hash events; Event.hash_var e |] )\n (Data_as_hash.hash res) ;\n res\n\n let empty_stack_msg = \"Attempted to pop an empty stack\"\n\n let pop_from_data_as_hash (events : var) : Event.t Data_as_hash.t * var =\n let open Run in\n let hd, tl =\n exists\n Typ.(Data_as_hash.typ ~hash:Event.hash * typ)\n ~compute:(fun () ->\n match As_prover.read typ events with\n | [] ->\n failwith empty_stack_msg\n | event :: events ->\n (event, events) )\n in\n Field.Assert.equal\n (Random_oracle.Checked.hash ~init:Inputs.hash_prefix\n [| Data_as_hash.hash tl; Data_as_hash.hash hd |] )\n (Data_as_hash.hash events) ;\n (hd, tl)\n\n [%%endif]\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let events = list @@ array field (o ()) in\n needs_custom_js\n ~js_type:(Data_as_hash.deriver events)\n ~name:Inputs.deriver_name events obj\nend\n\nmodule Events = struct\n include Make_events (struct\n let salt_phrase = \"MinaZkappEventsEmpty\"\n\n let hash_prefix = Hash_prefix_states.zkapp_events\n\n let deriver_name = \"Events\"\n end)\nend\n\nmodule Actions = struct\n include Make_events (struct\n let salt_phrase = \"MinaZkappActionsEmpty\"\n\n let hash_prefix = Hash_prefix_states.zkapp_actions\n\n let deriver_name = \"Actions\"\n end)\n\n let is_empty_var (e : var) =\n Snark_params.Tick.Field.(\n Checked.equal (Data_as_hash.hash e) (Var.constant empty_hash))\n\n let empty_state_element =\n let salt_phrase = \"MinaZkappActionStateEmptyElt\" in\n Hash_prefix_create.salt salt_phrase |> Random_oracle.digest\n\n let push_events (acc : Field.t) (events : t) : Field.t =\n push_hash acc (hash events)\n\n [%%ifdef consensus_mechanism]\n\n let push_events_checked (x : Field.Var.t) (e : var) : Field.Var.t =\n Random_oracle.Checked.hash ~init:Hash_prefix_states.zkapp_actions\n [| x; Data_as_hash.hash e |]\n\n [%%endif]\nend\n\nmodule Zkapp_uri = struct\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n module T = struct\n type t = string [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n\n let max_length = 255\n\n let check (x : t) = assert (String.length x <= max_length)\n\n let t_of_sexp sexp =\n let res = t_of_sexp sexp in\n check res ; res\n\n let of_yojson json =\n let res = of_yojson json in\n Result.bind res ~f:(fun res ->\n Result.try_with (fun () -> check res)\n |> Result.map ~f:(Fn.const res)\n |> Result.map_error\n ~f:(Fn.const \"Zkapp_uri.of_yojson: symbol is too long\") )\n end\n\n include T\n\n include\n Binable.Of_binable_without_uuid\n (Core_kernel.String.Stable.V1)\n (struct\n type t = string\n\n let to_binable = Fn.id\n\n let of_binable x = check x ; x\n end)\n end\n end]\n\n [%%define_locally\n Stable.Latest.\n (sexp_of_t, t_of_sexp, equal, to_yojson, of_yojson, max_length, check)]\nend\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('app_state, 'vk, 'zkapp_version, 'field, 'slot, 'bool, 'zkapp_uri) t =\n { app_state : 'app_state\n ; verification_key : 'vk\n ; zkapp_version : 'zkapp_version\n ; action_state : 'field Pickles_types.Vector.Vector_5.Stable.V1.t\n ; last_action_slot : 'slot\n ; proved_state : 'bool\n ; zkapp_uri : 'zkapp_uri\n }\n [@@deriving sexp, equal, compare, hash, yojson, hlist, fields, annot]\n end\n end]\nend\n\ntype ('app_state, 'vk, 'zkapp_version, 'field, 'slot, 'bool, 'zkapp_uri) t_ =\n ('app_state, 'vk, 'zkapp_version, 'field, 'slot, 'bool, 'zkapp_uri) Poly.t =\n { app_state : 'app_state\n ; verification_key : 'vk\n ; zkapp_version : 'zkapp_version\n ; action_state : 'field Pickles_types.Vector.Vector_5.t\n ; last_action_slot : 'slot\n ; proved_state : 'bool\n ; zkapp_uri : 'zkapp_uri\n }\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t =\n ( Zkapp_state.Value.Stable.V1.t\n , Verification_key_wire.Stable.V1.t option\n , Mina_numbers.Zkapp_version.Stable.V1.t\n , F.Stable.V1.t\n , Mina_numbers.Global_slot_since_genesis.Stable.V1.t\n , bool\n , Zkapp_uri.Stable.V1.t )\n Poly.Stable.V2.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\ntype t =\n ( Zkapp_state.Value.t\n , Verification_key_wire.t option\n , Mina_numbers.Zkapp_version.t\n , F.t\n , Mina_numbers.Global_slot_since_genesis.t\n , bool\n , Zkapp_uri.t )\n Poly.t\n[@@deriving sexp, equal, compare, hash, yojson]\n\nlet (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n[%%ifdef consensus_mechanism]\n\nmodule Checked = struct\n type t =\n ( Pickles.Impls.Step.Field.t Zkapp_state.V.t\n , ( Boolean.var\n , (Side_loaded_verification_key.t option, Field.t) With_hash.t\n Data_as_hash.t )\n Flagged_option.t\n , Mina_numbers.Zkapp_version.Checked.t\n , Pickles.Impls.Step.Field.t\n , Mina_numbers.Global_slot_since_genesis.Checked.t\n , Boolean.var\n , string Data_as_hash.t )\n Poly.t\n\n open Pickles_types\n\n let to_input' (t : _ Poly.t) :\n Snark_params.Tick.Field.Var.t Random_oracle.Input.Chunked.t =\n let open Random_oracle.Input.Chunked in\n let f mk acc field = mk (Core_kernel.Field.get field t) :: acc in\n let app_state v =\n Random_oracle.Input.Chunked.field_elements (Vector.to_array v)\n in\n Poly.Fields.fold ~init:[] ~app_state:(f app_state)\n ~verification_key:(f field)\n ~zkapp_version:(f Mina_numbers.Zkapp_version.Checked.to_input)\n ~action_state:(f app_state)\n ~last_action_slot:\n (f Mina_numbers.Global_slot_since_genesis.Checked.to_input)\n ~proved_state:\n (f (fun (b : Boolean.var) ->\n Random_oracle.Input.Chunked.packed ((b :> Field.Var.t), 1) ) )\n ~zkapp_uri:(f field)\n |> List.reduce_exn ~f:append\n\n let to_input (t : t) =\n to_input'\n { t with\n verification_key = Data_as_hash.hash t.verification_key.data\n ; zkapp_uri = Data_as_hash.hash t.zkapp_uri\n }\n\n let digest_vk t =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix_states.side_loaded_vk\n (pack_input (Pickles.Side_loaded.Verification_key.Checked.to_input t)))\n\n let digest t =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix_states.zkapp_account (pack_input (to_input t)))\n\n let digest' t =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix_states.zkapp_account (pack_input (to_input' t)))\nend\n\n[%%define_locally Verification_key_wire.(digest_vk, dummy_vk_hash)]\n\n(* This preimage cannot be attained by any string, due to the trailing [true]\n added below.\n*)\nlet zkapp_uri_non_preimage =\n lazy (Random_oracle_input.Chunked.field_elements [| Field.zero; Field.zero |])\n\nlet hash_zkapp_uri_opt (zkapp_uri_opt : string option) =\n let input =\n match zkapp_uri_opt with\n | Some zkapp_uri ->\n (* We use [length*8 + 1] to pass a final [true] after the end of the\n string, to ensure that trailing null bytes don't alias in the hash\n preimage.\n *)\n let bits = Array.create ~len:((String.length zkapp_uri * 8) + 1) true in\n String.foldi zkapp_uri ~init:() ~f:(fun i () c ->\n let c = Char.to_int c in\n (* Insert the bits into [bits], LSB order. *)\n for j = 0 to 7 do\n (* [Int.test_bit c j] *)\n bits.((i * 8) + j) <- Int.bit_and c (1 lsl j) <> 0\n done ) ;\n Random_oracle_input.Chunked.packeds\n (Array.map ~f:(fun b -> (field_of_bool b, 1)) bits)\n | None ->\n Lazy.force zkapp_uri_non_preimage\n in\n Random_oracle.pack_input input\n |> Random_oracle.hash ~init:Hash_prefix_states.zkapp_uri\n\nlet hash_zkapp_uri (zkapp_uri : string) = hash_zkapp_uri_opt (Some zkapp_uri)\n\nlet typ : (Checked.t, t) Typ.t =\n let open Poly in\n Typ.of_hlistable\n [ Zkapp_state.typ Field.typ\n ; Flagged_option.lazy_option_typ\n ~default:(lazy { With_hash.data = None; hash = dummy_vk_hash () })\n (Data_as_hash.typ ~hash:With_hash.hash)\n |> Typ.transport\n ~there:(Option.map ~f:(With_hash.map ~f:Option.some))\n ~back:\n (Option.map ~f:(With_hash.map ~f:(fun x -> Option.value_exn x)))\n ; Mina_numbers.Zkapp_version.typ\n ; Pickles_types.Vector.typ Field.typ Pickles_types.Nat.N5.n\n ; Mina_numbers.Global_slot_since_genesis.typ\n ; Boolean.typ\n ; Data_as_hash.typ ~hash:hash_zkapp_uri\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n[%%endif]\n\nlet zkapp_uri_to_input zkapp_uri =\n Random_oracle.Input.Chunked.field @@ hash_zkapp_uri zkapp_uri\n\nlet to_input (t : t) : _ Random_oracle.Input.Chunked.t =\n let open Random_oracle.Input.Chunked in\n let f mk acc field = mk (Core_kernel.Field.get field t) :: acc in\n let app_state v =\n Random_oracle.Input.Chunked.field_elements (Pickles_types.Vector.to_array v)\n in\n Poly.Fields.fold ~init:[] ~app_state:(f app_state)\n ~verification_key:\n (f\n (Fn.compose field\n (Option.value_map ~default:(dummy_vk_hash ()) ~f:With_hash.hash) ) )\n ~zkapp_version:(f Mina_numbers.Zkapp_version.to_input)\n ~action_state:(f app_state)\n ~last_action_slot:(f Mina_numbers.Global_slot_since_genesis.to_input)\n ~proved_state:\n (f (fun b -> Random_oracle.Input.Chunked.packed (field_of_bool b, 1)))\n ~zkapp_uri:(f zkapp_uri_to_input)\n |> List.reduce_exn ~f:append\n\nlet default : _ Poly.t =\n (* These are the permissions of a \"user\"/\"non zkapp\" account. *)\n { app_state =\n Pickles_types.Vector.init Zkapp_state.Max_state_size.n ~f:(fun _ ->\n F.zero )\n ; verification_key = None\n ; zkapp_version = Mina_numbers.Zkapp_version.zero\n ; action_state =\n (let empty = Actions.empty_state_element in\n [ empty; empty; empty; empty; empty ] )\n ; last_action_slot = Mina_numbers.Global_slot_since_genesis.zero\n ; proved_state = false\n ; zkapp_uri = \"\"\n }\n\nlet digest (t : t) =\n Random_oracle.(\n hash ~init:Hash_prefix_states.zkapp_account (pack_input (to_input t)))\n\nlet default_digest = lazy (digest default)\n\nlet hash_zkapp_account_opt' = function\n | None ->\n Lazy.force default_digest\n | Some (a : t) ->\n digest a\n\nlet action_state_deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let list_5 = list ~static_length:5 (field @@ o ()) in\n let open Pickles_types.Vector.Vector_5 in\n iso ~map:of_list_exn ~contramap:to_list (list_5 (o ())) obj\n\nlet deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots:Poly.t_fields_annots in\n finish \"ZkappAccount\" ~t_toplevel_annots:Poly.t_toplevel_annots\n @@ Poly.Fields.make_creator\n ~app_state:!.(Zkapp_state.deriver field)\n ~verification_key:\n !.(option ~js_type:Or_undefined (verification_key_with_hash @@ o ()))\n ~zkapp_version:!.uint32 ~action_state:!.action_state_deriver\n ~last_action_slot:!.global_slot_since_genesis\n ~proved_state:!.bool ~zkapp_uri:!.string obj\n\nlet gen_uri =\n let open Quickcheck in\n let open Generator.Let_syntax in\n let%bind parts =\n String.gen_with_length 8 Char.gen_alphanum |> Generator.list_with_length 3\n in\n let%map domain = Generator.of_list [ \"com\"; \"org\"; \"net\"; \"info\" ] in\n Printf.sprintf \"https://%s.%s\" (String.concat ~sep:\".\" parts) domain\n\nlet gen : t Quickcheck.Generator.t =\n let open Quickcheck in\n let open Generator.Let_syntax in\n let app_state =\n Pickles_types.Vector.init Zkapp_state.Max_state_size.n ~f:(fun _ ->\n F.random () )\n in\n let%bind zkapp_version = Mina_numbers.Zkapp_version.gen in\n let%bind seq_state = Generator.list_with_length 5 Field.gen in\n let%bind last_sequence_slot = Mina_numbers.Global_slot_since_genesis.gen in\n let%map zkapp_uri = gen_uri in\n let five = Pickles_types.Nat.(S (S (S (S (S Z))))) in\n { app_state\n ; verification_key = None\n ; zkapp_version\n ; action_state = Pickles_types.(Vector.of_list_and_length_exn seq_state five)\n ; last_action_slot = Mina_numbers.Global_slot_since_genesis.zero\n ; proved_state = false\n ; zkapp_uri\n }\n","(* account.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_util\nopen Snark_params\nopen Tick\nopen Currency\nopen Mina_numbers\nopen Fold_lib\nopen Mina_base_import\n\nmodule Index = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n module T = struct\n type t = int [@@deriving to_yojson, sexp, hash, compare]\n end\n\n include T\n\n let to_latest = Fn.id\n\n include Hashable.Make_binable (T)\n end\n end]\n\n include Hashable.Make_binable (Stable.Latest)\n\n let to_int = Int.to_int\n\n let gen ~ledger_depth = Int.gen_incl 0 ((1 lsl ledger_depth) - 1)\n\n module Vector = struct\n include Int\n\n let empty = zero\n\n let get t i = (t lsr i) land 1 = 1\n\n let set v i b = if b then v lor (one lsl i) else v land lnot (one lsl i)\n end\n\n let to_bits ~ledger_depth t = List.init ledger_depth ~f:(Vector.get t)\n\n let of_bits = List.foldi ~init:Vector.empty ~f:(fun i t b -> Vector.set t i b)\n\n let to_input ~ledger_depth x =\n List.map (to_bits ~ledger_depth x) ~f:(fun b -> (field_of_bool b, 1))\n |> List.to_array |> Random_oracle.Input.Chunked.packeds\n\n let fold_bits ~ledger_depth t =\n { Fold.fold =\n (fun ~init ~f ->\n let rec go acc i =\n if i = ledger_depth then acc else go (f acc (Vector.get t i)) (i + 1)\n in\n go init 0 )\n }\n\n let fold ~ledger_depth t =\n Fold.group3 ~default:false (fold_bits ~ledger_depth t)\n\n [%%ifdef consensus_mechanism]\n\n module Unpacked = struct\n type var = Tick.Boolean.var list\n\n type value = Vector.t\n\n let to_input x =\n List.map x ~f:(fun (b : Boolean.var) -> ((b :> Field.Var.t), 1))\n |> List.to_array |> Random_oracle.Input.Chunked.packeds\n\n let typ ~ledger_depth : (var, value) Tick.Typ.t =\n Typ.transport\n (Typ.list ~length:ledger_depth Boolean.typ)\n ~there:(to_bits ~ledger_depth) ~back:of_bits\n end\n\n [%%endif]\nend\n\nmodule Nonce = Account_nonce\n\nmodule Token_symbol = struct\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n module T = struct\n type t = string [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n\n let max_length = 6\n\n let check (x : t) = assert (String.length x <= max_length)\n\n let t_of_sexp sexp =\n let res = t_of_sexp sexp in\n check res ; res\n\n let of_yojson json =\n let res = of_yojson json in\n Result.bind res ~f:(fun res ->\n Result.try_with (fun () -> check res)\n |> Result.map ~f:(Fn.const res)\n |> Result.map_error\n ~f:(Fn.const \"Token_symbol.of_yojson: symbol is too long\") )\n end\n\n include T\n\n include\n Binable.Of_binable_without_uuid\n (Core_kernel.String.Stable.V1)\n (struct\n type t = string\n\n let to_binable = Fn.id\n\n let of_binable x = check x ; x\n end)\n end\n end]\n\n [%%define_locally\n Stable.Latest.\n (sexp_of_t, t_of_sexp, equal, to_yojson, of_yojson, max_length, check)]\n\n let default = \"\"\n\n (* 48 = max_length * 8 *)\n module Num_bits = Pickles_types.Nat.N48\n\n let num_bits = Pickles_types.Nat.to_int Num_bits.n\n\n let to_bits (x : t) =\n Pickles_types.Vector.init Num_bits.n ~f:(fun i ->\n let byte_index = i / 8 in\n if byte_index < String.length x then\n let c = x.[byte_index] |> Char.to_int in\n c land (1 lsl (i mod 8)) <> 0\n else false )\n\n let of_bits x : t =\n let c, j, chars =\n Pickles_types.Vector.fold x ~init:(0, 0, []) ~f:(fun (c, j, chars) x ->\n let c = c lor ((if x then 1 else 0) lsl j) in\n if j = 7 then (0, 0, Char.of_int_exn c :: chars) else (c, j + 1, chars) )\n in\n assert (c = 0) ;\n assert (j = 0) ;\n let chars = List.drop_while ~f:(fun c -> Char.to_int c = 0) chars in\n String.of_char_list (List.rev chars)\n\n let to_field (x : t) : Field.t =\n Field.project (Pickles_types.Vector.to_list (to_bits x))\n\n let to_input (x : t) =\n Random_oracle_input.Chunked.packed (to_field x, num_bits)\n\n [%%ifdef consensus_mechanism]\n\n type var = Field.Var.t\n\n let range_check (t : var) =\n let%bind actual =\n make_checked (fun () ->\n let _, _, actual_packed =\n Pickles.Scalar_challenge.to_field_checked' ~num_bits m\n (Kimchi_backend_common.Scalar_challenge.create t)\n in\n actual_packed )\n in\n Field.Checked.Assert.equal t actual\n\n let var_of_value x =\n Pickles_types.Vector.map ~f:Boolean.var_of_value (to_bits x)\n\n let of_field (x : Field.t) : t =\n of_bits\n (Pickles_types.Vector.of_list_and_length_exn\n (List.take (Field.unpack x) num_bits)\n Num_bits.n )\n\n let typ : (var, t) Typ.t =\n let (Typ typ) = Field.typ in\n Typ.transport\n (Typ { typ with check = range_check })\n ~there:to_field ~back:of_field\n\n let var_to_input (x : var) = Random_oracle_input.Chunked.packed (x, num_bits)\n\n let if_ = Tick.Run.Field.if_\n\n [%%endif]\nend\n\n(* the `token_symbol` describes a token id owned by the account id\n from this account, not the token id used by this account\n*)\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ( 'pk\n , 'id\n , 'token_symbol\n , 'amount\n , 'nonce\n , 'receipt_chain_hash\n , 'delegate\n , 'state_hash\n , 'timing\n , 'permissions\n , 'zkapp_opt )\n t =\n { public_key : 'pk\n ; token_id : 'id\n ; token_symbol : 'token_symbol\n ; balance : 'amount\n ; nonce : 'nonce\n ; receipt_chain_hash : 'receipt_chain_hash\n ; delegate : 'delegate\n ; voting_for : 'state_hash\n ; timing : 'timing\n ; permissions : 'permissions\n ; zkapp : 'zkapp_opt\n }\n [@@deriving sexp, equal, compare, hash, yojson, fields, hlist, annot]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nlet token = Poly.token_id\n\nmodule Key = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Public_key.Compressed.Stable.V1.t\n [@@deriving sexp, equal, hash, compare, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Identifier = Account_id\n\ntype key = Key.t [@@deriving sexp, equal, hash, compare, yojson]\n\nmodule Timing = Account_timing\n\nmodule Binable_arg = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Public_key.Compressed.Stable.V1.t\n , Token_id.Stable.V2.t\n , Token_symbol.Stable.V1.t\n , Balance.Stable.V1.t\n , Nonce.Stable.V1.t\n , Receipt.Chain_hash.Stable.V1.t\n , Public_key.Compressed.Stable.V1.t option\n , State_hash.Stable.V1.t\n , Timing.Stable.V2.t\n , Permissions.Stable.V2.t\n , Zkapp_account.Stable.V2.t option )\n (* TODO: Cache the digest of this? *)\n Poly.Stable.V2.t\n [@@deriving sexp, equal, hash, compare, yojson]\n\n let to_latest = Fn.id\n\n let public_key (t : t) : key = t.public_key\n end\n end]\nend\n\nlet check = Fn.id\n\n[%%versioned_binable\nmodule Stable = struct\n module V2 = struct\n type t = Binable_arg.Stable.V2.t\n [@@deriving sexp, equal, hash, compare, yojson]\n\n include\n Binable.Of_binable_without_uuid\n (Binable_arg.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable = check\n\n let of_binable = check\n end)\n\n let to_latest = Fn.id\n\n let public_key (t : t) : key = t.public_key\n end\nend]\n\n[%%define_locally Stable.Latest.(public_key)]\n\nlet identifier ({ public_key; token_id; _ } : t) =\n Account_id.create public_key token_id\n\ntype value =\n ( Public_key.Compressed.t\n , Token_id.t\n , Token_symbol.t\n , Balance.t\n , Nonce.t\n , Receipt.Chain_hash.t\n , Public_key.Compressed.t option\n , State_hash.t\n , Timing.t\n , Permissions.t\n , Zkapp_account.t option )\n Poly.t\n[@@deriving sexp]\n\nlet key_gen = Public_key.Compressed.gen\n\nlet initialize account_id : t =\n let public_key = Account_id.public_key account_id in\n let token_id = Account_id.token_id account_id in\n let delegate =\n (* Only allow delegation if this account is for the default token. *)\n if Token_id.(equal default token_id) then Some public_key else None\n in\n { public_key\n ; token_id\n ; token_symbol = \"\"\n ; balance = Balance.zero\n ; nonce = Nonce.zero\n ; receipt_chain_hash = Receipt.Chain_hash.empty\n ; delegate\n ; voting_for = State_hash.dummy\n ; timing = Timing.Untimed\n ; permissions = Permissions.user_default\n ; zkapp = None\n }\n\nlet hash_zkapp_account_opt = function\n | None ->\n Lazy.force Zkapp_account.default_digest\n | Some (a : Zkapp_account.t) ->\n Zkapp_account.digest a\n\nlet delegate_opt = Option.value ~default:Public_key.Compressed.empty\n\nlet to_input (t : t) =\n let open Random_oracle.Input.Chunked in\n let f mk acc field = mk (Core_kernel.Field.get field t) :: acc in\n Poly.Fields.fold ~init:[]\n ~public_key:(f Public_key.Compressed.to_input)\n ~token_id:(f Token_id.to_input) ~balance:(f Balance.to_input)\n ~token_symbol:(f Token_symbol.to_input) ~nonce:(f Nonce.to_input)\n ~receipt_chain_hash:(f Receipt.Chain_hash.to_input)\n ~delegate:(f (Fn.compose Public_key.Compressed.to_input delegate_opt))\n ~voting_for:(f State_hash.to_input) ~timing:(f Timing.to_input)\n ~zkapp:(f (Fn.compose field hash_zkapp_account_opt))\n ~permissions:(f Permissions.to_input)\n |> List.reduce_exn ~f:append\n\nlet crypto_hash_prefix = Hash_prefix.account\n\nlet crypto_hash t =\n Random_oracle.hash ~init:crypto_hash_prefix\n (Random_oracle.pack_input (to_input t))\n\n[%%ifdef consensus_mechanism]\n\ntype var =\n ( Public_key.Compressed.var\n , Token_id.Checked.t\n , Token_symbol.var\n , Balance.var\n , Nonce.Checked.t\n , Receipt.Chain_hash.var\n , Public_key.Compressed.var\n , State_hash.var\n , Timing.var\n , Permissions.Checked.t\n (* TODO: This is a hack that lets us avoid unhashing zkApp accounts when we don't need to *)\n , Field.Var.t * Zkapp_account.t option As_prover.Ref.t )\n Poly.t\n\nlet identifier_of_var ({ public_key; token_id; _ } : var) =\n Account_id.Checked.create public_key token_id\n\nlet typ' zkapp =\n Typ.of_hlistable\n [ Public_key.Compressed.typ\n ; Token_id.typ\n ; Token_symbol.typ\n ; Balance.typ\n ; Nonce.typ\n ; Receipt.Chain_hash.typ\n ; Typ.transport Public_key.Compressed.typ ~there:delegate_opt\n ~back:(fun delegate ->\n if Public_key.Compressed.(equal empty) delegate then None\n else Some delegate )\n ; State_hash.typ\n ; Timing.typ\n ; Permissions.typ\n ; zkapp\n ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\nlet typ : (var, value) Typ.t =\n let zkapp :\n ( Field.Var.t * Zkapp_account.t option As_prover.Ref.t\n , Zkapp_account.t option )\n Typ.t =\n let account :\n (Zkapp_account.t option As_prover.Ref.t, Zkapp_account.t option) Typ.t =\n Typ.Internal.ref ()\n in\n Typ.(Field.typ * account)\n |> Typ.transport ~there:(fun x -> (hash_zkapp_account_opt x, x)) ~back:snd\n in\n typ' zkapp\n\nlet var_of_t\n ({ public_key\n ; token_id\n ; token_symbol\n ; balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; voting_for\n ; timing\n ; permissions\n ; zkapp\n } :\n value ) =\n { Poly.public_key = Public_key.Compressed.var_of_t public_key\n ; token_id = Token_id.Checked.constant token_id\n ; token_symbol = Token_symbol.var_of_value token_symbol\n ; balance = Balance.var_of_t balance\n ; nonce = Nonce.Checked.constant nonce\n ; receipt_chain_hash = Receipt.Chain_hash.var_of_t receipt_chain_hash\n ; delegate = Public_key.Compressed.var_of_t (delegate_opt delegate)\n ; voting_for = State_hash.var_of_t voting_for\n ; timing = Timing.var_of_t timing\n ; permissions = Permissions.Checked.constant permissions\n ; zkapp = Field.Var.constant (hash_zkapp_account_opt zkapp)\n }\n\nmodule Checked = struct\n module Unhashed = struct\n type t =\n ( Public_key.Compressed.var\n , Token_id.Checked.t\n , Token_symbol.var\n , Balance.var\n , Nonce.Checked.t\n , Receipt.Chain_hash.var\n , Public_key.Compressed.var\n , State_hash.var\n , Timing.var\n , Permissions.Checked.t\n , Zkapp_account.Checked.t )\n Poly.t\n\n let typ : (t, Stable.Latest.t) Typ.t =\n typ'\n (Typ.transport Zkapp_account.typ\n ~there:(fun t -> Option.value t ~default:Zkapp_account.default)\n ~back:(fun t -> Some t) )\n end\n\n let to_input (t : var) =\n let f mk acc field = mk (Core_kernel.Field.get field t) :: acc in\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n (Poly.Fields.fold ~init:[]\n ~zkapp:(f (fun (x, _) -> field x))\n ~permissions:(f Permissions.Checked.to_input)\n ~public_key:(f Public_key.Compressed.Checked.to_input)\n ~token_id:(f Token_id.Checked.to_input)\n ~token_symbol:(f Token_symbol.var_to_input)\n ~balance:(f Balance.var_to_input) ~nonce:(f Nonce.Checked.to_input)\n ~receipt_chain_hash:(f Receipt.Chain_hash.var_to_input)\n ~delegate:(f Public_key.Compressed.Checked.to_input)\n ~voting_for:(f State_hash.var_to_input)\n ~timing:(f Timing.var_to_input) )\n\n let digest t =\n make_checked (fun () ->\n Random_oracle.Checked.(\n hash ~init:crypto_hash_prefix (pack_input (to_input t))) )\n\n let balance_upper_bound = Bignum_bigint.(one lsl Balance.length_in_bits)\n\n let amount_upper_bound = Bignum_bigint.(one lsl Amount.length_in_bits)\n\n let min_balance_at_slot ~global_slot ~cliff_time ~cliff_amount\n ~(vesting_period : Mina_numbers.Global_slot_span.Checked.var)\n ~vesting_increment ~initial_minimum_balance =\n let%bind before_cliff =\n Global_slot_since_genesis.Checked.(global_slot < cliff_time)\n in\n let%bind else_branch =\n make_checked (fun () ->\n let _, (slot_diff : Mina_numbers.Global_slot_span.Checked.var) =\n Tick.Run.run_checked\n (Global_slot_since_genesis.Checked.diff_or_zero global_slot\n cliff_time )\n in\n let cliff_decrement = cliff_amount in\n let min_balance_less_cliff_decrement =\n Tick.Run.run_checked\n (Balance.Checked.sub_amount_or_zero initial_minimum_balance\n cliff_decrement )\n in\n let (num_periods : Mina_numbers.Global_slot_span.Checked.var), _ =\n Tick.Run.run_checked\n (Global_slot_span.Checked.div_mod slot_diff vesting_period)\n in\n let vesting_decrement =\n Tick.Run.Field.mul\n (Global_slot_span.Checked.to_field num_periods)\n (Amount.pack_var vesting_increment)\n in\n let min_balance_less_cliff_and_vesting_decrements =\n Tick.Run.run_checked\n (Balance.Checked.sub_amount_or_zero\n min_balance_less_cliff_decrement\n Amount.(Checked.Unsafe.of_field vesting_decrement) )\n in\n min_balance_less_cliff_and_vesting_decrements )\n in\n Balance.Checked.if_ before_cliff ~then_:initial_minimum_balance\n ~else_:else_branch\n\n let has_locked_tokens ~global_slot (t : var) =\n let open Timing.As_record in\n let { is_timed = _\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } =\n t.timing\n in\n let%bind cur_min_balance =\n min_balance_at_slot ~global_slot ~initial_minimum_balance ~cliff_time\n ~cliff_amount ~vesting_period ~vesting_increment\n in\n let%map zero_min_balance =\n Balance.equal_var Balance.(var_of_t zero) cur_min_balance\n in\n (*Note: Untimed accounts will always have zero min balance*)\n Boolean.not zero_min_balance\n\n let has_permission ?signature_verifies ~to_ (account : var) =\n let signature_verifies =\n match signature_verifies with\n | Some signature_verifies ->\n signature_verifies\n | None -> (\n match to_ with\n | `Send ->\n Boolean.true_\n | `Receive ->\n Boolean.false_\n | `Set_delegate ->\n Boolean.true_\n | `Increment_nonce ->\n Boolean.true_\n | `Access ->\n failwith\n \"Account.Checked.has_permission: signature_verifies argument \\\n must be given for access permission\" )\n in\n match to_ with\n | `Send ->\n Permissions.Auth_required.Checked.eval_no_proof account.permissions.send\n ~signature_verifies\n | `Receive ->\n Permissions.Auth_required.Checked.eval_no_proof\n account.permissions.receive ~signature_verifies\n | `Set_delegate ->\n Permissions.Auth_required.Checked.eval_no_proof\n account.permissions.set_delegate ~signature_verifies\n | `Increment_nonce ->\n Permissions.Auth_required.Checked.eval_no_proof\n account.permissions.increment_nonce ~signature_verifies\n | `Access ->\n Permissions.Auth_required.Checked.eval_no_proof\n account.permissions.access ~signature_verifies\nend\n\n[%%endif]\n\nlet digest = crypto_hash\n\nlet empty =\n { Poly.public_key = Public_key.Compressed.empty\n ; token_id = Token_id.default\n ; token_symbol = Token_symbol.default\n ; balance = Balance.zero\n ; nonce = Nonce.zero\n ; receipt_chain_hash = Receipt.Chain_hash.empty\n ; delegate = None\n ; voting_for = State_hash.dummy\n ; timing = Timing.Untimed\n ; permissions =\n Permissions.user_default\n (* TODO: This should maybe be Permissions.empty *)\n ; zkapp = None\n }\n\nlet empty_digest = lazy (digest empty)\n\nlet create account_id balance =\n let public_key = Account_id.public_key account_id in\n let token_id = Account_id.token_id account_id in\n let delegate =\n (* Only allow delegation if this account is for the default token. *)\n if Token_id.(equal default) token_id then Some public_key else None\n in\n { Poly.public_key\n ; token_id\n ; token_symbol = Token_symbol.default\n ; balance\n ; nonce = Nonce.zero\n ; receipt_chain_hash = Receipt.Chain_hash.empty\n ; delegate\n ; voting_for = State_hash.dummy\n ; timing = Timing.Untimed\n ; permissions = Permissions.user_default\n ; zkapp = None\n }\n\nlet create_timed account_id balance ~initial_minimum_balance ~cliff_time\n ~cliff_amount ~vesting_period ~vesting_increment =\n if Global_slot_span.(equal vesting_period zero) then\n Or_error.errorf\n !\"Error creating timed account for account id %{sexp: Account_id.t}: \\\n vesting period must be greater than zero\"\n account_id\n else\n let public_key = Account_id.public_key account_id in\n let token_id = Account_id.token_id account_id in\n let delegate =\n (* Only allow delegation if this account is for the default token. *)\n if Token_id.(equal default) token_id then Some public_key else None\n in\n Or_error.return\n { Poly.public_key\n ; token_id\n ; token_symbol = Token_symbol.default\n ; balance\n ; nonce = Nonce.zero\n ; receipt_chain_hash = Receipt.Chain_hash.empty\n ; delegate\n ; voting_for = State_hash.dummy\n ; zkapp = None\n ; permissions = Permissions.user_default\n ; timing =\n Timing.Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n }\n\n(* no vesting after cliff time + 1 slot *)\nlet create_time_locked public_key balance ~initial_minimum_balance ~cliff_time =\n create_timed public_key balance ~initial_minimum_balance ~cliff_time\n ~vesting_period:Global_slot_span.(succ zero)\n ~vesting_increment:initial_minimum_balance\n\nlet initial_minimum_balance Poly.{ timing; _ } =\n match timing with\n | Timing.Untimed ->\n None\n | Timed t ->\n Some t.initial_minimum_balance\n\nlet cliff_time Poly.{ timing; _ } =\n match timing with Timing.Untimed -> None | Timed t -> Some t.cliff_time\n\nlet cliff_amount Poly.{ timing; _ } =\n match timing with Timing.Untimed -> None | Timed t -> Some t.cliff_amount\n\nlet vesting_increment Poly.{ timing } =\n match timing with\n | Timing.Untimed ->\n None\n | Timed t ->\n Some t.vesting_increment\n\nlet vesting_period Poly.{ timing; _ } =\n match timing with Timing.Untimed -> None | Timed t -> Some t.vesting_period\n\nlet min_balance_at_slot ~global_slot ~cliff_time ~cliff_amount ~vesting_period\n ~vesting_increment ~initial_minimum_balance =\n let open Unsigned in\n if Global_slot_since_genesis.(global_slot < cliff_time) then\n initial_minimum_balance\n (* If vesting period is zero then everything vests immediately at the cliff *)\n else if Global_slot_span.(equal vesting_period zero) then Balance.zero\n else\n match Balance.(initial_minimum_balance - cliff_amount) with\n | None ->\n Balance.zero\n | Some min_balance_past_cliff -> (\n (* take advantage of fact that global slots are uint32's *)\n let num_periods =\n UInt32.(\n let global_slot_u32 =\n Global_slot_since_genesis.to_uint32 global_slot\n in\n let cliff_time_u32 =\n Global_slot_since_genesis.to_uint32 cliff_time\n in\n let vesting_period_u32 =\n Global_slot_span.to_uint32 vesting_period\n in\n Infix.((global_slot_u32 - cliff_time_u32) / vesting_period_u32)\n |> to_int64 |> UInt64.of_int64)\n in\n let vesting_decrement =\n let vesting_increment = Amount.to_uint64 vesting_increment in\n if\n try\n UInt64.(compare Infix.(max_int / num_periods) vesting_increment)\n < 0\n with Division_by_zero -> false\n then\n (* The vesting decrement will overflow, use [max_int] instead. *)\n UInt64.max_int |> Amount.of_uint64\n else\n UInt64.Infix.(num_periods * vesting_increment) |> Amount.of_uint64\n in\n match Balance.(min_balance_past_cliff - vesting_decrement) with\n | None ->\n Balance.zero\n | Some amt ->\n amt )\n\nlet incremental_balance_between_slots ~start_slot ~end_slot ~cliff_time\n ~cliff_amount ~vesting_period ~vesting_increment ~initial_minimum_balance :\n Unsigned.UInt64.t =\n let open Unsigned in\n if Global_slot_since_genesis.(end_slot <= start_slot) then UInt64.zero\n else\n let min_balance_at_start_slot =\n min_balance_at_slot ~global_slot:start_slot ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment ~initial_minimum_balance\n |> Balance.to_amount |> Amount.to_uint64\n in\n let min_balance_at_end_slot =\n min_balance_at_slot ~global_slot:end_slot ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment ~initial_minimum_balance\n |> Balance.to_amount |> Amount.to_uint64\n in\n UInt64.Infix.(min_balance_at_start_slot - min_balance_at_end_slot)\n\nlet has_locked_tokens ~global_slot (account : t) =\n match account.timing with\n | Untimed ->\n false\n | Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } ->\n let curr_min_balance =\n min_balance_at_slot ~global_slot ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment ~initial_minimum_balance\n in\n Balance.(curr_min_balance > zero)\n\nlet final_vesting_slot ~initial_minimum_balance ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment =\n let open Unsigned in\n let to_vest =\n Balance.(initial_minimum_balance - cliff_amount)\n |> Option.value_map ~default:UInt64.zero ~f:Balance.to_uint64\n in\n let vest_incr = Amount.to_uint64 vesting_increment in\n let periods =\n let open UInt64 in\n let open Infix in\n (to_vest / vest_incr)\n + if equal (rem to_vest vest_incr) zero then zero else one\n in\n let open UInt32 in\n let open Infix in\n Global_slot_since_genesis.of_uint32\n @@ Global_slot_since_genesis.to_uint32 cliff_time\n + (UInt64.to_uint32 periods * Global_slot_span.to_uint32 vesting_period)\n\nlet timing_final_vesting_slot = function\n | Timing.Untimed ->\n Global_slot_since_genesis.zero\n | Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } ->\n final_vesting_slot ~initial_minimum_balance ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment\n\nlet has_permission ~control ~to_ (account : t) =\n match to_ with\n | `Access ->\n Permissions.Auth_required.check account.permissions.access control\n | `Send ->\n Permissions.Auth_required.check account.permissions.send control\n | `Receive ->\n Permissions.Auth_required.check account.permissions.receive control\n | `Set_delegate ->\n Permissions.Auth_required.check account.permissions.set_delegate control\n | `Increment_nonce ->\n Permissions.Auth_required.check account.permissions.increment_nonce\n control\n\n(** [true] iff account has permissions set that enable them to transfer Mina (assuming the command is signed) *)\nlet has_permission_to_send account =\n has_permission ~control:Control.Tag.Signature ~to_:`Access account\n && has_permission ~control:Control.Tag.Signature ~to_:`Send account\n\n(** [true] iff account has permissions set that enable them to receive Mina *)\nlet has_permission_to_receive account =\n has_permission ~control:Control.Tag.None_given ~to_:`Access account\n && has_permission ~control:Control.Tag.None_given ~to_:`Receive account\n\n(** [true] iff account has permissions set that enable them to set their delegate (assuming the command is signed) *)\nlet has_permission_to_set_delegate account =\n has_permission ~control:Control.Tag.Signature ~to_:`Access account\n && has_permission ~control:Control.Tag.Signature ~to_:`Set_delegate account\n\n(** [true] iff account has permissions set that enable them to increment their nonce (assuming the command is signed) *)\nlet has_permission_to_increment_nonce account =\n has_permission ~control:Control.Tag.Signature ~to_:`Access account\n && has_permission ~control:Control.Tag.Signature ~to_:`Increment_nonce account\n\nlet liquid_balance_at_slot ~global_slot (account : t) =\n match account.timing with\n | Untimed ->\n account.balance\n | Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } ->\n Balance.sub_amount account.balance\n (Balance.to_amount\n (min_balance_at_slot ~global_slot ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment ~initial_minimum_balance ) )\n |> Option.value_exn\n\nlet gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind public_key = Public_key.Compressed.gen in\n let%bind token_id = Token_id.gen in\n let%map balance = Currency.Balance.gen in\n create (Account_id.create public_key token_id) balance\n\nlet gen_with_constrained_balance ~low ~high : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind public_key = Public_key.Compressed.gen in\n let%bind token_id = Token_id.gen in\n let%map balance = Currency.Balance.gen_incl low high in\n create (Account_id.create public_key token_id) balance\n\nlet gen_any_vesting_range =\n let open Quickcheck.Generator.Let_syntax in\n let open Global_slot_since_genesis in\n (* vesting period must be at least one to avoid division by zero *)\n let%bind vesting_period = Int.gen_incl 1 1000 >>| Global_slot_span.of_int in\n let%bind vesting_end = gen_incl (of_int 1) max_value in\n let%map cliff_time = gen_incl (of_int 1) vesting_end in\n (cliff_time, vesting_end, vesting_period)\n\nlet gen_with_vesting_period vesting_period =\n let open Quickcheck.Generator.Let_syntax in\n let open Global_slot_since_genesis in\n let min_vesting_end =\n Global_slot_span.(succ vesting_period |> to_uint32)\n |> Global_slot_since_genesis.of_uint32\n in\n let%bind vesting_end = gen_incl min_vesting_end max_value in\n let max_cliff_time = Option.value_exn @@ sub vesting_end vesting_period in\n let%map cliff_time = gen_incl (of_int 1) max_cliff_time in\n (cliff_time, vesting_end, vesting_period)\n\nlet gen_vesting_details ~(cliff_time : Global_slot_since_genesis.t)\n ~(vesting_end : Global_slot_since_genesis.t)\n ~(vesting_period : Global_slot_span.t) (initial_minimum_balance : Balance.t)\n : Timing.as_record Quickcheck.Generator.t =\n let open Unsigned in\n let open Quickcheck in\n let open Generator.Let_syntax in\n let vesting_slots =\n let open Global_slot_since_genesis in\n let open UInt32.Infix in\n to_uint32 vesting_end - to_uint32 cliff_time\n in\n (* We need to arrange vesting schedule so that all funds are vested before the\n maximum global slot, which is 2 ^ 32. *)\n let vesting_periods_count =\n Unsigned.UInt32.div vesting_slots\n (Global_slot_span.to_uint32 vesting_period)\n |> UInt64.of_uint32\n in\n let max_cliff_amt =\n Balance.(initial_minimum_balance - Amount.of_uint64 vesting_periods_count)\n |> Option.value_map ~f:Balance.to_amount ~default:Amount.zero\n in\n let%map cliff_amount =\n if UInt64.(compare vesting_periods_count zero) > 0 then\n Amount.(gen_incl zero max_cliff_amt)\n else return @@ Balance.to_amount initial_minimum_balance\n in\n let to_vest =\n Balance.(initial_minimum_balance - cliff_amount)\n |> Option.value_map ~default:Unsigned.UInt64.zero ~f:Balance.to_uint64\n in\n let vesting_increment =\n if Unsigned.UInt64.(equal vesting_periods_count zero) then Amount.one\n (* This value does not matter anyway. *)\n else\n let vi = UInt64.Infix.(to_vest / vesting_periods_count) in\n let rnd = UInt64.Infix.(to_vest mod vesting_periods_count) in\n (if UInt64.(compare rnd zero) > 0 then UInt64.succ vi else vi)\n |> Amount.of_uint64\n in\n { Timing.As_record.is_timed = true\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n\nlet gen_timing (account_balance : Balance.t) =\n let open Quickcheck.Generator.Let_syntax in\n let%bind initial_minimum_balance = Balance.(gen_incl one account_balance)\n and cliff_time, vesting_end, vesting_period = gen_any_vesting_range in\n gen_vesting_details ~vesting_period ~cliff_time ~vesting_end\n initial_minimum_balance\n\nlet gen_timing_at_least_one_vesting_period (account_balance : Balance.t) =\n let open Quickcheck.Generator.Let_syntax in\n let%bind initial_minimum_balance = Balance.(gen_incl one account_balance)\n (* vesting period must be at least one to avoid division by zero *)\n and cliff_time, vesting_end, vesting_period =\n gen_with_vesting_period @@ Global_slot_span.of_int 2\n in\n gen_vesting_details ~vesting_period ~cliff_time ~vesting_end\n initial_minimum_balance\n\nlet gen_timed : t Quickcheck.Generator.t =\n let open Quickcheck in\n let open Generator.Let_syntax in\n let%bind account =\n gen_with_constrained_balance ~low:Balance.one ~high:Balance.max_int\n in\n let%map timing = gen_timing account.balance in\n { account with timing = Timing.of_record timing }\n\nlet deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots:Poly.t_fields_annots in\n let receipt_chain_hash =\n needs_custom_js ~js_type:field ~name:\"ReceiptChainHash\" field\n in\n finish \"Account\" ~t_toplevel_annots:Poly.t_toplevel_annots\n @@ Poly.Fields.make_creator ~public_key:!.public_key\n ~token_id:!.Token_id.deriver ~token_symbol:!.string ~balance:!.balance\n ~nonce:!.uint32 ~receipt_chain_hash:!.receipt_chain_hash\n ~delegate:!.(option ~js_type:Or_undefined (public_key @@ o ()))\n ~voting_for:!.field ~timing:!.Timing.deriver\n ~permissions:!.Permissions.deriver\n ~zkapp:!.(option ~js_type:Or_undefined (Zkapp_account.deriver @@ o ()))\n obj\n","open Core_kernel\nopen Currency\nopen Snark_params.Tick\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('ledger_hash, 'amount) t =\n ( 'ledger_hash\n , 'amount )\n Mina_wire_types.Mina_base.Epoch_ledger.Poly.V1.t =\n { hash : 'ledger_hash; total_currency : 'amount }\n [@@deriving annot, sexp, equal, compare, hash, yojson, hlist, fields]\n end\n end]\nend\n\nmodule Value = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n (Frozen_ledger_hash0.Stable.V1.t, Amount.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nlet to_input ({ hash; total_currency } : Value.t) =\n Random_oracle_input.Chunked.(\n append (field (hash :> Field.t)) (Amount.to_input total_currency))\n\ntype var = (Frozen_ledger_hash0.var, Amount.var) Poly.t\n\nlet typ : (var, Value.t) Typ.t =\n Typ.of_hlistable\n [ Frozen_ledger_hash0.typ; Amount.typ ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\nlet var_to_input ({ Poly.hash; total_currency } : var) =\n let total_currency = Amount.var_to_input total_currency in\n Random_oracle_input.Chunked.(\n append (field (Frozen_ledger_hash0.var_to_hash_packed hash)) total_currency)\n\nlet if_ cond ~(then_ : (Frozen_ledger_hash0.var, Amount.var) Poly.t)\n ~(else_ : (Frozen_ledger_hash0.var, Amount.var) Poly.t) =\n let open Checked.Let_syntax in\n let%map hash =\n Frozen_ledger_hash0.if_ cond ~then_:then_.hash ~else_:else_.hash\n and total_currency =\n Amount.Checked.if_ cond ~then_:then_.total_currency\n ~else_:else_.total_currency\n in\n { Poly.hash; total_currency }\n","open Core_kernel\n\ninclude Data_hash.Make_full_size (struct\n let version_byte = Base58_check.Version_bytes.epoch_seed\n\n let description = \"Epoch Seed\"\nend)\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Snark_params.Tick.Field.t[@version_asserted])\n [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\nend]\n\nlet _f () : (Stable.Latest.t, t) Type_equal.t = Type_equal.T\n","open Core_kernel\nopen Mina_numbers\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'epoch_ledger\n , 'epoch_seed\n , 'start_checkpoint\n , 'lock_checkpoint\n , 'length )\n t =\n ( 'epoch_ledger\n , 'epoch_seed\n , 'start_checkpoint\n , 'lock_checkpoint\n , 'length )\n Mina_wire_types.Mina_base.Epoch_data.Poly.V1.t =\n { ledger : 'epoch_ledger\n ; seed : 'epoch_seed\n ; start_checkpoint : 'start_checkpoint\n (* The lock checkpoint is the hash of the latest state in the seed update range, not including\n the current state. *)\n ; lock_checkpoint : 'lock_checkpoint\n ; epoch_length : 'length\n }\n [@@deriving annot, hlist, sexp, equal, compare, hash, yojson, fields]\n end\n end]\nend\n\ntype var =\n ( Epoch_ledger.var\n , Epoch_seed.var\n , State_hash.var\n , State_hash.var\n , Length.Checked.t )\n Poly.t\n\nlet if_ cond ~(then_ : var) ~(else_ : var) =\n let open Snark_params.Tick.Checked.Let_syntax in\n let%map ledger = Epoch_ledger.if_ cond ~then_:then_.ledger ~else_:else_.ledger\n and seed = Epoch_seed.if_ cond ~then_:then_.seed ~else_:else_.seed\n and start_checkpoint =\n State_hash.if_ cond ~then_:then_.start_checkpoint\n ~else_:else_.start_checkpoint\n and lock_checkpoint =\n State_hash.if_ cond ~then_:then_.lock_checkpoint\n ~else_:else_.lock_checkpoint\n and epoch_length =\n Length.Checked.if_ cond ~then_:then_.epoch_length ~else_:else_.epoch_length\n in\n { Poly.ledger; seed; start_checkpoint; lock_checkpoint; epoch_length }\n\nmodule Value = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( Epoch_ledger.Value.Stable.V1.t\n , Epoch_seed.Stable.V1.t\n , State_hash.Stable.V1.t\n , State_hash.Stable.V1.t\n , Length.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nopen Signature_lib\nmodule A = Account\nopen Mina_numbers\nopen Currency\nopen Zkapp_basic\nopen Pickles_types\nmodule Impl = Pickles.Impls.Step\n\nmodule Closed_interval = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t =\n 'a Mina_wire_types.Mina_base.Zkapp_precondition.Closed_interval.V1.t =\n { lower : 'a; upper : 'a }\n [@@deriving annot, sexp, equal, compare, hash, yojson, hlist, fields]\n end\n end]\n\n let gen gen_a compare_a =\n let open Quickcheck.Let_syntax in\n let%bind a1 = gen_a in\n let%map a2 = gen_a in\n if compare_a a1 a2 <= 0 then { lower = a1; upper = a2 }\n else { lower = a2; upper = a1 }\n\n let to_input { lower; upper } ~f =\n Random_oracle_input.Chunked.append (f lower) (f upper)\n\n let typ x =\n Typ.of_hlistable [ x; x ] ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let deriver ~name inner obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~lower:!.inner ~upper:!.inner\n |> finish (name ^ \"Interval\") ~t_toplevel_annots\n\n let%test_module \"ClosedInterval\" =\n ( module struct\n module IntClosedInterval = struct\n type t_ = int t [@@deriving sexp, equal, compare]\n\n (* Note: nonrec doesn't work with ppx-deriving *)\n type t = t_ [@@deriving sexp, equal, compare]\n\n let v = { lower = 10; upper = 100 }\n end\n\n let%test_unit \"roundtrip json\" =\n let open Fields_derivers_zkapps.Derivers in\n let full = o () in\n let _a : _ Unified_input.t = deriver ~name:\"Int\" int full in\n [%test_eq: IntClosedInterval.t]\n (!(full#of_json) (!(full#to_json) IntClosedInterval.v))\n IntClosedInterval.v\n end )\nend\n\nlet assert_ b e = if b then Ok () else Or_error.error_string e\n\n(* Proofs are produced against a predicate on the protocol state. For the\n transaction to go through, the predicate must be satisfied of the protocol\n state at the time of transaction application. *)\nmodule Numeric = struct\n module Tc = struct\n type ('var, 'a) t =\n { zero : 'a\n ; max_value : 'a\n ; compare : 'a -> 'a -> int\n ; equal : 'a -> 'a -> bool\n ; typ : ('var, 'a) Typ.t\n ; to_input : 'a -> F.t Random_oracle_input.Chunked.t\n ; to_input_checked : 'var -> Field.Var.t Random_oracle_input.Chunked.t\n ; lte_checked : 'var -> 'var -> Boolean.var\n ; eq_checked : 'var -> 'var -> Boolean.var\n }\n\n let run f x y = Impl.run_checked (f x y)\n\n let ( !! ) f = Fn.compose Impl.run_checked f\n\n let length =\n Length.\n { zero\n ; max_value\n ; compare\n ; lte_checked = run Checked.( <= )\n ; eq_checked = run Checked.( = )\n ; equal\n ; typ\n ; to_input\n ; to_input_checked = Checked.to_input\n }\n\n let amount =\n Currency.Amount.\n { zero\n ; max_value = max_int\n ; compare\n ; lte_checked = run Checked.( <= )\n ; eq_checked = run Checked.( = )\n ; equal\n ; typ\n ; to_input\n ; to_input_checked = var_to_input\n }\n\n let balance =\n Currency.Balance.\n { zero\n ; max_value = max_int\n ; compare\n ; lte_checked = run Checked.( <= )\n ; eq_checked = run Checked.( = )\n ; equal\n ; typ\n ; to_input\n ; to_input_checked = var_to_input\n }\n\n let nonce =\n Account_nonce.\n { zero\n ; max_value\n ; compare\n ; lte_checked = run Checked.( <= )\n ; eq_checked = run Checked.( = )\n ; equal\n ; typ\n ; to_input\n ; to_input_checked = Checked.to_input\n }\n\n let global_slot =\n Global_slot_since_genesis.\n { zero\n ; max_value\n ; compare\n ; lte_checked = run Checked.( <= )\n ; eq_checked = run Checked.( = )\n ; equal\n ; typ\n ; to_input\n ; to_input_checked = Checked.to_input\n }\n end\n\n open Tc\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = 'a Closed_interval.Stable.V1.t Or_ignore.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n end\n end]\n\n let deriver name inner range_max obj =\n let closed_interval obj' = Closed_interval.deriver ~name inner obj' in\n Or_ignore.deriver_interval ~range_max closed_interval obj\n\n module Derivers = struct\n open Fields_derivers_zkapps.Derivers\n\n let range_uint32 =\n Unsigned_extended.UInt32.(to_string zero, to_string max_int)\n\n let range_uint64 =\n Unsigned_extended.UInt64.(to_string zero, to_string max_int)\n\n let block_time_inner obj =\n let ( ^^ ) = Fn.compose in\n iso_string ~name:\"BlockTime\" ~js_type:UInt64\n ~of_string:(Block_time.of_uint64 ^^ Unsigned_extended.UInt64.of_string)\n ~to_string:(Unsigned_extended.UInt64.to_string ^^ Block_time.to_uint64)\n obj\n\n let nonce obj = deriver \"Nonce\" uint32 range_uint32 obj\n\n let balance obj = deriver \"Balance\" balance range_uint64 obj\n\n let amount obj = deriver \"CurrencyAmount\" amount range_uint64 obj\n\n let length obj = deriver \"Length\" uint32 range_uint32 obj\n\n let global_slot_since_genesis obj =\n deriver \"GlobalSlotSinceGenesis\" global_slot_since_genesis range_uint32\n obj\n\n let block_time obj = deriver \"BlockTime\" block_time_inner range_uint64 obj\n end\n\n let%test_module \"Numeric\" =\n ( module struct\n module Int_numeric = struct\n type t_ = int t [@@deriving sexp, equal, compare]\n\n (* Note: nonrec doesn't work with ppx-deriving *)\n type t = t_ [@@deriving sexp, equal, compare]\n end\n\n module T = struct\n type t = { foo : Int_numeric.t }\n [@@deriving annot, sexp, equal, compare, fields]\n\n let v : t =\n { foo = Or_ignore.Check { Closed_interval.lower = 10; upper = 100 } }\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~foo:!.(deriver \"Int\" int (\"0\", \"1000\"))\n |> finish \"T\" ~t_toplevel_annots\n end\n\n let%test_unit \"roundtrip json\" =\n let open Fields_derivers_zkapps.Derivers in\n let full = o () in\n let _a : _ Unified_input.t = T.deriver full in\n [%test_eq: T.t] (of_json full (to_json full T.v)) T.v\n end )\n\n let gen gen_a compare_a = Or_ignore.gen (Closed_interval.gen gen_a compare_a)\n\n let to_input { zero; max_value; to_input; _ } (t : 'a t) =\n Flagged_option.to_input'\n ~f:(Closed_interval.to_input ~f:to_input)\n ~field_of_bool\n ( match t with\n | Ignore ->\n { is_some = false\n ; data = { Closed_interval.lower = zero; upper = max_value }\n }\n | Check x ->\n { is_some = true; data = x } )\n\n module Checked = struct\n type 'a t = 'a Closed_interval.t Or_ignore.Checked.t\n\n let to_input { to_input_checked; _ } (t : 'a t) =\n Or_ignore.Checked.to_input t\n ~f:(Closed_interval.to_input ~f:to_input_checked)\n\n open Impl\n\n let check { lte_checked = ( <= ); _ } (t : 'a t) (x : 'a) =\n Or_ignore.Checked.check t ~f:(fun { lower; upper } ->\n Boolean.all [ lower <= x; x <= upper ] )\n\n let is_constant { eq_checked = ( = ); _ } (t : 'a t) =\n let is_constant ({ lower; upper } : _ Closed_interval.t) =\n lower = upper\n in\n Boolean.( &&& )\n (Or_ignore.Checked.is_check t)\n (is_constant (Or_ignore.Checked.data t))\n end\n\n let typ { zero; max_value; typ; _ } =\n Or_ignore.typ (Closed_interval.typ typ)\n ~ignore:{ Closed_interval.lower = zero; upper = max_value }\n\n let check ~label { compare; _ } (t : 'a t) (x : 'a) =\n match t with\n | Ignore ->\n Ok ()\n | Check { lower; upper } ->\n if compare lower x <= 0 && compare x upper <= 0 then Ok ()\n else Or_error.errorf \"Bounds check failed: %s\" label\n\n let is_constant { equal = ( = ); _ } (t : 'a t) =\n match t with Ignore -> false | Check { lower; upper } -> lower = upper\nend\n\nmodule Eq_data = struct\n include Or_ignore\n\n module Tc = struct\n type ('var, 'a) t =\n { equal : 'a -> 'a -> bool\n ; equal_checked : 'var -> 'var -> Boolean.var\n ; default : 'a\n ; typ : ('var, 'a) Typ.t\n ; to_input : 'a -> F.t Random_oracle_input.Chunked.t\n ; to_input_checked : 'var -> Field.Var.t Random_oracle_input.Chunked.t\n }\n\n let run f x y = Impl.run_checked (f x y)\n\n let field =\n let open Random_oracle_input.Chunked in\n Field.\n { typ\n ; equal\n ; equal_checked = run Checked.equal\n ; default = zero\n ; to_input = field\n ; to_input_checked = field\n }\n\n let action_state =\n let open Random_oracle_input.Chunked in\n lazy\n Field.\n { typ\n ; equal\n ; equal_checked = run Checked.equal\n ; default = Zkapp_account.Actions.empty_state_element\n ; to_input = field\n ; to_input_checked = field\n }\n\n let boolean =\n let open Random_oracle_input.Chunked in\n Boolean.\n { typ\n ; equal = Bool.equal\n ; equal_checked = run equal\n ; default = false\n ; to_input = (fun b -> packed (field_of_bool b, 1))\n ; to_input_checked =\n (fun (b : Boolean.var) -> packed ((b :> Field.Var.t), 1))\n }\n\n let receipt_chain_hash =\n Receipt.Chain_hash.\n { field with\n to_input_checked = var_to_input\n ; typ\n ; equal\n ; equal_checked = run equal_var\n }\n\n let ledger_hash =\n Ledger_hash.\n { field with\n to_input_checked = var_to_input\n ; typ\n ; equal\n ; equal_checked = run equal_var\n }\n\n let frozen_ledger_hash =\n Frozen_ledger_hash.\n { field with\n to_input_checked = var_to_input\n ; typ\n ; equal\n ; equal_checked = run equal_var\n }\n\n let state_hash =\n State_hash.\n { field with\n to_input_checked = var_to_input\n ; typ\n ; equal\n ; equal_checked = run equal_var\n }\n\n let token_id =\n Token_id.\n { default\n ; to_input_checked = Checked.to_input\n ; to_input\n ; typ\n ; equal\n ; equal_checked = Checked.equal\n }\n\n let epoch_seed =\n Epoch_seed.\n { field with\n to_input_checked = var_to_input\n ; typ\n ; equal\n ; equal_checked = run equal_var\n }\n\n let public_key () =\n Public_key.Compressed.\n { default = invalid_public_key\n ; to_input\n ; to_input_checked = Checked.to_input\n ; equal_checked = run Checked.equal\n ; typ\n ; equal\n }\n end\n\n let to_input { Tc.default; to_input; _ } (t : _ t) =\n Flagged_option.to_input' ~f:to_input ~field_of_bool\n ( match t with\n | Ignore ->\n { is_some = false; data = default }\n | Check data ->\n { is_some = true; data } )\n\n let to_input_checked { Tc.to_input_checked; _ } (t : _ Checked.t) =\n Checked.to_input t ~f:to_input_checked\n\n let check_checked { Tc.equal_checked; _ } (t : 'a Checked.t) (x : 'a) =\n Checked.check t ~f:(equal_checked x)\n\n let check ?(label = \"\") { Tc.equal; _ } (t : 'a t) (x : 'a) =\n match t with\n | Ignore ->\n Ok ()\n | Check y ->\n if equal x y then Ok ()\n else Or_error.errorf \"Equality check failed: %s\" label\n\n let typ { Tc.default = ignore; typ = t; _ } = typ ~ignore t\nend\n\nmodule Hash = Eq_data\n\nmodule Leaf_typs = struct\n let public_key () =\n Public_key.Compressed.(Or_ignore.typ ~ignore:invalid_public_key typ)\n\n open Eq_data.Tc\n\n let field = Eq_data.typ field\n\n let receipt_chain_hash = Hash.typ receipt_chain_hash\n\n let ledger_hash = Hash.typ ledger_hash\n\n let frozen_ledger_hash = Hash.typ frozen_ledger_hash\n\n let state_hash = Hash.typ state_hash\n\n open Numeric.Tc\n\n let length = Numeric.typ length\n\n let amount = Numeric.typ amount\n\n let balance = Numeric.typ balance\n\n let nonce = Numeric.typ nonce\n\n let global_slot = Numeric.typ global_slot\n\n let token_id = Hash.typ token_id\nend\n\nmodule Account = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Zkapp_precondition.Account.V2.t =\n { balance : Balance.Stable.V1.t Numeric.Stable.V1.t\n ; nonce : Account_nonce.Stable.V1.t Numeric.Stable.V1.t\n ; receipt_chain_hash : Receipt.Chain_hash.Stable.V1.t Hash.Stable.V1.t\n ; delegate : Public_key.Compressed.Stable.V1.t Eq_data.Stable.V1.t\n ; state : F.Stable.V1.t Eq_data.Stable.V1.t Zkapp_state.V.Stable.V1.t\n ; action_state : F.Stable.V1.t Eq_data.Stable.V1.t\n ; proved_state : bool Eq_data.Stable.V1.t\n ; is_new : bool Eq_data.Stable.V1.t\n }\n [@@deriving annot, hlist, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind balance = Numeric.gen Balance.gen Balance.compare in\n let%bind nonce = Numeric.gen Account_nonce.gen Account_nonce.compare in\n let%bind receipt_chain_hash = Or_ignore.gen Receipt.Chain_hash.gen in\n let%bind delegate = Eq_data.gen Public_key.Compressed.gen in\n let%bind state =\n let%bind fields =\n let field_gen = Snark_params.Tick.Field.gen in\n Quickcheck.Generator.list_with_length 8 (Or_ignore.gen field_gen)\n in\n (* won't raise because length is correct *)\n Quickcheck.Generator.return (Zkapp_state.V.of_list_exn fields)\n in\n let%bind action_state =\n let%bind n = Int.gen_uniform_incl Int.min_value Int.max_value in\n let field_gen = Quickcheck.Generator.return (F.of_int n) in\n Or_ignore.gen field_gen\n in\n let%bind proved_state = Or_ignore.gen Quickcheck.Generator.bool in\n let%map is_new = Or_ignore.gen Quickcheck.Generator.bool in\n { balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; state\n ; action_state\n ; proved_state\n ; is_new\n }\n\n let accept : t =\n { balance = Ignore\n ; nonce = Ignore\n ; receipt_chain_hash = Ignore\n ; delegate = Ignore\n ; state =\n Vector.init Zkapp_state.Max_state_size.n ~f:(fun _ -> Or_ignore.Ignore)\n ; action_state = Ignore\n ; proved_state = Ignore\n ; is_new = Ignore\n }\n\n let is_accept : t -> bool = equal accept\n\n let nonce (n : Account.Nonce.t) =\n let nonce : _ Numeric.t = Check { lower = n; upper = n } in\n { accept with nonce }\n\n let is_nonce (t : t) =\n match t.nonce with\n | Ignore ->\n false\n | Check { lower; upper } ->\n (* nonce is exact, all other fields are Ignore *)\n Mina_numbers.Account_nonce.equal lower upper\n && is_accept { t with nonce = Ignore }\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots in\n let action_state =\n needs_custom_js ~js_type:field ~name:\"ActionState\" field\n in\n Fields.make_creator obj ~balance:!.Numeric.Derivers.balance\n ~nonce:!.Numeric.Derivers.nonce\n ~receipt_chain_hash:!.(Or_ignore.deriver field)\n ~delegate:!.(Or_ignore.deriver public_key)\n ~state:!.(Zkapp_state.deriver @@ Or_ignore.deriver field)\n ~action_state:!.(Or_ignore.deriver action_state)\n ~proved_state:!.(Or_ignore.deriver bool)\n ~is_new:!.(Or_ignore.deriver bool)\n |> finish \"AccountPrecondition\" ~t_toplevel_annots\n\n let%test_unit \"json roundtrip\" =\n let b = Balance.of_nanomina_int_exn 1000 in\n let predicate : t =\n { accept with\n balance = Or_ignore.Check { Closed_interval.lower = b; upper = b }\n ; action_state = Or_ignore.Check (Field.of_int 99)\n ; proved_state = Or_ignore.Check true\n }\n in\n let module Fd = Fields_derivers_zkapps.Derivers in\n let full = deriver (Fd.o ()) in\n [%test_eq: t] predicate (predicate |> Fd.to_json full |> Fd.of_json full)\n\n let to_input\n ({ balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; state\n ; action_state\n ; proved_state\n ; is_new\n } :\n t ) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Numeric.(to_input Tc.balance balance)\n ; Numeric.(to_input Tc.nonce nonce)\n ; Hash.(to_input Tc.receipt_chain_hash receipt_chain_hash)\n ; Eq_data.(to_input (Tc.public_key ()) delegate)\n ; Vector.reduce_exn ~f:append\n (Vector.map state ~f:Eq_data.(to_input Tc.field))\n ; Eq_data.(to_input (Lazy.force Tc.action_state)) action_state\n ; Eq_data.(to_input Tc.boolean) proved_state\n ; Eq_data.(to_input Tc.boolean) is_new\n ]\n\n let digest t =\n Random_oracle.(\n hash ~init:Hash_prefix.zkapp_precondition_account\n (pack_input (to_input t)))\n\n module Checked = struct\n type t =\n { balance : Balance.var Numeric.Checked.t\n ; nonce : Account_nonce.Checked.t Numeric.Checked.t\n ; receipt_chain_hash : Receipt.Chain_hash.var Hash.Checked.t\n ; delegate : Public_key.Compressed.var Eq_data.Checked.t\n ; state : Field.Var.t Eq_data.Checked.t Zkapp_state.V.t\n ; action_state : Field.Var.t Eq_data.Checked.t\n ; proved_state : Boolean.var Eq_data.Checked.t\n ; is_new : Boolean.var Eq_data.Checked.t\n }\n [@@deriving hlist]\n\n let to_input\n ({ balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; state\n ; action_state\n ; proved_state\n ; is_new\n } :\n t ) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Numeric.(Checked.to_input Tc.balance balance)\n ; Numeric.(Checked.to_input Tc.nonce nonce)\n ; Hash.(to_input_checked Tc.receipt_chain_hash receipt_chain_hash)\n ; Eq_data.(to_input_checked (Tc.public_key ()) delegate)\n ; Vector.reduce_exn ~f:append\n (Vector.map state ~f:Eq_data.(to_input_checked Tc.field))\n ; Eq_data.(to_input_checked (Lazy.force Tc.action_state)) action_state\n ; Eq_data.(to_input_checked Tc.boolean) proved_state\n ; Eq_data.(to_input_checked Tc.boolean) is_new\n ]\n\n open Impl\n\n let checks ~new_account\n { balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; state\n ; action_state\n ; proved_state\n ; is_new\n } (a : Account.Checked.Unhashed.t) =\n [ ( Transaction_status.Failure.Account_balance_precondition_unsatisfied\n , Numeric.(Checked.check Tc.balance balance a.balance) )\n ; ( Transaction_status.Failure.Account_nonce_precondition_unsatisfied\n , Numeric.(Checked.check Tc.nonce nonce a.nonce) )\n ; ( Transaction_status.Failure\n .Account_receipt_chain_hash_precondition_unsatisfied\n , Eq_data.(\n check_checked Tc.receipt_chain_hash receipt_chain_hash\n a.receipt_chain_hash) )\n ; ( Transaction_status.Failure.Account_delegate_precondition_unsatisfied\n , Eq_data.(check_checked (Tc.public_key ()) delegate a.delegate) )\n ]\n @ [ ( Transaction_status.Failure\n .Account_action_state_precondition_unsatisfied\n , Boolean.any\n Vector.(\n to_list\n (map a.zkapp.action_state\n ~f:\n Eq_data.(\n check_checked (Lazy.force Tc.action_state) action_state) ))\n )\n ]\n @ ( Vector.(\n to_list\n (map2 state a.zkapp.app_state ~f:Eq_data.(check_checked Tc.field)))\n |> List.mapi ~f:(fun i check ->\n let failure =\n Transaction_status.Failure\n .Account_app_state_precondition_unsatisfied\n i\n in\n (failure, check) ) )\n @ [ ( Transaction_status.Failure\n .Account_proved_state_precondition_unsatisfied\n , Eq_data.(check_checked Tc.boolean proved_state a.zkapp.proved_state)\n )\n ]\n @ [ ( Transaction_status.Failure.Account_is_new_precondition_unsatisfied\n , Eq_data.(check_checked Tc.boolean is_new new_account) )\n ]\n\n let check ~new_account ~check t a =\n List.iter\n ~f:(fun (failure, passed) -> check failure passed)\n (checks ~new_account t a)\n\n let digest (t : t) =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix.zkapp_precondition_account\n (pack_input (to_input t)))\n end\n\n let typ () : (Checked.t, t) Typ.t =\n let open Leaf_typs in\n Typ.of_hlistable\n [ balance\n ; nonce\n ; receipt_chain_hash\n ; public_key ()\n ; Zkapp_state.typ (Or_ignore.typ Field.typ ~ignore:Field.zero)\n ; Or_ignore.typ Field.typ\n ~ignore:Zkapp_account.Actions.empty_state_element\n ; Or_ignore.typ Boolean.typ ~ignore:false\n ; Or_ignore.typ Boolean.typ ~ignore:false\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let checks ~new_account\n { balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; state\n ; action_state\n ; proved_state\n ; is_new\n } (a : Account.t) =\n [ ( Transaction_status.Failure.Account_balance_precondition_unsatisfied\n , Numeric.(check ~label:\"balance\" Tc.balance balance a.balance) )\n ; ( Transaction_status.Failure.Account_nonce_precondition_unsatisfied\n , Numeric.(check ~label:\"nonce\" Tc.nonce nonce a.nonce) )\n ; ( Transaction_status.Failure\n .Account_receipt_chain_hash_precondition_unsatisfied\n , Eq_data.(\n check ~label:\"receipt_chain_hash\" Tc.receipt_chain_hash\n receipt_chain_hash a.receipt_chain_hash) )\n ; ( Transaction_status.Failure.Account_delegate_precondition_unsatisfied\n , let tc = Eq_data.Tc.public_key () in\n Eq_data.(\n check ~label:\"delegate\" tc delegate\n (Option.value ~default:tc.default a.delegate)) )\n ]\n @\n let zkapp = Option.value ~default:Zkapp_account.default a.zkapp in\n [ ( Transaction_status.Failure.Account_action_state_precondition_unsatisfied\n , match\n List.find (Vector.to_list zkapp.action_state) ~f:(fun state ->\n Eq_data.(\n check (Lazy.force Tc.action_state) ~label:\"\" action_state state)\n |> Or_error.is_ok )\n with\n | None ->\n Error (Error.createf \"Action state mismatch\")\n | Some _ ->\n Ok () )\n ]\n @ List.mapi\n Vector.(to_list (zip state zkapp.app_state))\n ~f:(fun i (c, v) ->\n let failure =\n Transaction_status.Failure\n .Account_app_state_precondition_unsatisfied\n i\n in\n (failure, Eq_data.(check Tc.field ~label:(sprintf \"state[%d]\" i) c v))\n )\n @ [ ( Transaction_status.Failure\n .Account_proved_state_precondition_unsatisfied\n , Eq_data.(\n check ~label:\"proved_state\" Tc.boolean proved_state\n zkapp.proved_state) )\n ]\n @ [ ( Transaction_status.Failure.Account_is_new_precondition_unsatisfied\n , Eq_data.(check ~label:\"is_new\" Tc.boolean is_new new_account) )\n ]\n\n let check ~new_account ~check t a =\n List.iter\n ~f:(fun (failure, res) -> check failure (Result.is_ok res))\n (checks ~new_account t a)\nend\n\nmodule Protocol_state = struct\n (* On each numeric field, you may assert a range\n On each hash field, you may assert an equality\n *)\n\n module Epoch_data = struct\n module Poly = Epoch_data.Poly\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n (* TODO: Not sure if this should be frozen ledger hash or not *)\n type t =\n ( ( Frozen_ledger_hash.Stable.V1.t Hash.Stable.V1.t\n , Currency.Amount.Stable.V1.t Numeric.Stable.V1.t )\n Epoch_ledger.Poly.Stable.V1.t\n , Epoch_seed.Stable.V1.t Hash.Stable.V1.t\n , State_hash.Stable.V1.t Hash.Stable.V1.t\n , State_hash.Stable.V1.t Hash.Stable.V1.t\n , Length.Stable.V1.t Numeric.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ledger obj' =\n let ( !. ) =\n ( !. ) ~t_fields_annots:Epoch_ledger.Poly.t_fields_annots\n in\n Epoch_ledger.Poly.Fields.make_creator obj'\n ~hash:!.(Or_ignore.deriver field)\n ~total_currency:!.Numeric.Derivers.amount\n |> finish \"EpochLedgerPrecondition\"\n ~t_toplevel_annots:Epoch_ledger.Poly.t_toplevel_annots\n in\n let ( !. ) = ( !. ) ~t_fields_annots:Poly.t_fields_annots in\n Poly.Fields.make_creator obj ~ledger:!.ledger\n ~seed:!.(Or_ignore.deriver field)\n ~start_checkpoint:!.(Or_ignore.deriver field)\n ~lock_checkpoint:!.(Or_ignore.deriver field)\n ~epoch_length:!.Numeric.Derivers.length\n |> finish \"EpochDataPrecondition\"\n ~t_toplevel_annots:Poly.t_toplevel_annots\n\n let%test_unit \"json roundtrip\" =\n let f = Or_ignore.Check Field.one in\n let u = Length.zero in\n let a = Amount.zero in\n let predicate : t =\n { Poly.ledger =\n { Epoch_ledger.Poly.hash = f\n ; total_currency =\n Or_ignore.Check { Closed_interval.lower = a; upper = a }\n }\n ; seed = f\n ; start_checkpoint = f\n ; lock_checkpoint = f\n ; epoch_length =\n Or_ignore.Check { Closed_interval.lower = u; upper = u }\n }\n in\n let module Fd = Fields_derivers_zkapps.Derivers in\n let full = deriver (Fd.o ()) in\n [%test_eq: t] predicate (predicate |> Fd.to_json full |> Fd.of_json full)\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind ledger =\n let%bind hash = Hash.gen Frozen_ledger_hash0.gen in\n let%map total_currency = Numeric.gen Amount.gen Amount.compare in\n { Epoch_ledger.Poly.hash; total_currency }\n in\n let%bind seed = Hash.gen Epoch_seed.gen in\n let%bind start_checkpoint = Hash.gen State_hash.gen in\n let%bind lock_checkpoint = Hash.gen State_hash.gen in\n let min_epoch_length = 8 in\n let max_epoch_length = Genesis_constants.slots_per_epoch in\n let%map epoch_length =\n Numeric.gen\n (Length.gen_incl\n (Length.of_int min_epoch_length)\n (Length.of_int max_epoch_length) )\n Length.compare\n in\n { Poly.ledger; seed; start_checkpoint; lock_checkpoint; epoch_length }\n\n let to_input\n ({ ledger = { hash; total_currency }\n ; seed\n ; start_checkpoint\n ; lock_checkpoint\n ; epoch_length\n } :\n t ) =\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n [ Hash.(to_input Tc.frozen_ledger_hash hash)\n ; Numeric.(to_input Tc.amount total_currency)\n ; Hash.(to_input Tc.epoch_seed seed)\n ; Hash.(to_input Tc.state_hash start_checkpoint)\n ; Hash.(to_input Tc.state_hash lock_checkpoint)\n ; Numeric.(to_input Tc.length epoch_length)\n ]\n\n module Checked = struct\n type t =\n ( ( Frozen_ledger_hash.var Hash.Checked.t\n , Currency.Amount.var Numeric.Checked.t )\n Epoch_ledger.Poly.t\n , Epoch_seed.var Hash.Checked.t\n , State_hash.var Hash.Checked.t\n , State_hash.var Hash.Checked.t\n , Length.Checked.t Numeric.Checked.t )\n Poly.t\n\n let to_input\n ({ ledger = { hash; total_currency }\n ; seed\n ; start_checkpoint\n ; lock_checkpoint\n ; epoch_length\n } :\n t ) =\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n [ Hash.(to_input_checked Tc.frozen_ledger_hash hash)\n ; Numeric.(Checked.to_input Tc.amount total_currency)\n ; Hash.(to_input_checked Tc.epoch_seed seed)\n ; Hash.(to_input_checked Tc.state_hash start_checkpoint)\n ; Hash.(to_input_checked Tc.state_hash lock_checkpoint)\n ; Numeric.(Checked.to_input Tc.length epoch_length)\n ]\n end\n end\n\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'snarked_ledger_hash\n , 'length\n , 'global_slot\n , 'amount\n , 'epoch_data )\n t =\n ( 'snarked_ledger_hash\n , 'length\n , 'global_slot\n , 'amount\n , 'epoch_data )\n Mina_wire_types.Mina_base.Zkapp_precondition.Protocol_state.Poly\n .V1\n .t =\n { (* TODO:\n We should include staged ledger hash again! It only changes once per\n block. *)\n snarked_ledger_hash : 'snarked_ledger_hash\n ; blockchain_length : 'length\n (* TODO: This previously had epoch_count but I removed it as I believe it is redundant\n with global_slot_since_hard_fork.\n\n epoch_count in [a, b]\n\n should be equivalent to\n\n global_slot_since_hard_fork in [slots_per_epoch * a, slots_per_epoch * b]\n\n TODO: Now that we removed global_slot_since_hard_fork, maybe we want to add epoch_count back\n *)\n ; min_window_density : 'length\n ; total_currency : 'amount\n ; global_slot_since_genesis : 'global_slot\n ; staking_epoch_data : 'epoch_data\n ; next_epoch_data : 'epoch_data\n }\n [@@deriving annot, hlist, sexp, equal, yojson, hash, compare, fields]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( Frozen_ledger_hash.Stable.V1.t Hash.Stable.V1.t\n , Length.Stable.V1.t Numeric.Stable.V1.t\n , Global_slot_since_genesis.Stable.V1.t Numeric.Stable.V1.t\n , Currency.Amount.Stable.V1.t Numeric.Stable.V1.t\n , Epoch_data.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) ?skip_data =\n ( !. ) ?skip_data ~t_fields_annots:Poly.t_fields_annots\n in\n Poly.Fields.make_creator obj\n ~snarked_ledger_hash:!.(Or_ignore.deriver field)\n ~blockchain_length:!.Numeric.Derivers.length\n ~min_window_density:!.Numeric.Derivers.length\n ~total_currency:!.Numeric.Derivers.amount\n ~global_slot_since_genesis:!.Numeric.Derivers.global_slot_since_genesis\n ~staking_epoch_data:!.Epoch_data.deriver\n ~next_epoch_data:!.Epoch_data.deriver\n |> finish \"NetworkPrecondition\" ~t_toplevel_annots:Poly.t_toplevel_annots\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n (* TODO: pass in ledger hash, next available token *)\n let snarked_ledger_hash = Zkapp_basic.Or_ignore.Ignore in\n let%bind blockchain_length = Numeric.gen Length.gen Length.compare in\n let max_min_window_density =\n Genesis_constants.for_unit_tests.protocol.slots_per_sub_window\n * Genesis_constants.Constraint_constants.compiled.sub_windows_per_window\n - 1\n |> Length.of_int\n in\n let%bind min_window_density =\n Numeric.gen\n (Length.gen_incl Length.zero max_min_window_density)\n Length.compare\n in\n let%bind total_currency =\n Numeric.gen Currency.Amount.gen Currency.Amount.compare\n in\n let%bind global_slot_since_genesis =\n Numeric.gen Global_slot_since_genesis.gen\n Global_slot_since_genesis.compare\n in\n let%bind staking_epoch_data = Epoch_data.gen in\n let%map next_epoch_data = Epoch_data.gen in\n { Poly.snarked_ledger_hash\n ; blockchain_length\n ; min_window_density\n ; total_currency\n ; global_slot_since_genesis\n ; staking_epoch_data\n ; next_epoch_data\n }\n\n let to_input\n ({ snarked_ledger_hash\n ; blockchain_length\n ; min_window_density\n ; total_currency\n ; global_slot_since_genesis\n ; staking_epoch_data\n ; next_epoch_data\n } :\n t ) =\n let open Random_oracle.Input.Chunked in\n let length = Numeric.(to_input Tc.length) in\n List.reduce_exn ~f:append\n [ Hash.(to_input Tc.field snarked_ledger_hash)\n ; length blockchain_length\n ; length min_window_density\n ; Numeric.(to_input Tc.amount total_currency)\n ; Numeric.(to_input Tc.global_slot global_slot_since_genesis)\n ; Epoch_data.to_input staking_epoch_data\n ; Epoch_data.to_input next_epoch_data\n ]\n\n let digest t =\n Random_oracle.(\n hash ~init:Hash_prefix.zkapp_precondition_protocol_state\n (pack_input (to_input t)))\n\n module View = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( Frozen_ledger_hash.Stable.V1.t\n , Length.Stable.V1.t\n , Global_slot_since_genesis.Stable.V1.t\n , Currency.Amount.Stable.V1.t\n , ( ( Frozen_ledger_hash.Stable.V1.t\n , Currency.Amount.Stable.V1.t )\n Epoch_ledger.Poly.Stable.V1.t\n , Epoch_seed.Stable.V1.t\n , State_hash.Stable.V1.t\n , State_hash.Stable.V1.t\n , Length.Stable.V1.t )\n Epoch_data.Poly.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n module Checked = struct\n type t =\n ( Frozen_ledger_hash.var\n , Length.Checked.t\n , Global_slot_since_genesis.Checked.t\n , Currency.Amount.var\n , ( (Frozen_ledger_hash.var, Currency.Amount.var) Epoch_ledger.Poly.t\n , Epoch_seed.var\n , State_hash.var\n , State_hash.var\n , Length.Checked.t )\n Epoch_data.Poly.t )\n Poly.t\n end\n\n let epoch_data_deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ledger obj' =\n let ( !. ) =\n ( !. ) ~t_fields_annots:Epoch_ledger.Poly.t_fields_annots\n in\n Epoch_ledger.Poly.Fields.make_creator obj' ~hash:!.field\n ~total_currency:!.amount\n |> finish \"EpochLedger\"\n ~t_toplevel_annots:Epoch_ledger.Poly.t_toplevel_annots\n in\n let ( !. ) = ( !. ) ~t_fields_annots:Epoch_data.Poly.t_fields_annots in\n Epoch_data.Poly.Fields.make_creator obj ~ledger:!.ledger ~seed:!.field\n ~start_checkpoint:!.field ~lock_checkpoint:!.field\n ~epoch_length:!.uint32\n |> finish \"EpochData\" ~t_toplevel_annots:Epoch_data.Poly.t_toplevel_annots\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) ?skip_data =\n ( !. ) ?skip_data ~t_fields_annots:Poly.t_fields_annots\n in\n Poly.Fields.make_creator obj ~snarked_ledger_hash:!.field\n ~blockchain_length:!.uint32 ~min_window_density:!.uint32\n ~total_currency:!.amount\n ~global_slot_since_genesis:!.global_slot_since_genesis\n ~staking_epoch_data:!.epoch_data_deriver\n ~next_epoch_data:!.epoch_data_deriver\n |> finish \"NetworkView\" ~t_toplevel_annots:Poly.t_toplevel_annots\n end\n\n module Checked = struct\n type t =\n ( Frozen_ledger_hash.var Hash.Checked.t\n , Length.Checked.t Numeric.Checked.t\n , Global_slot_since_genesis.Checked.t Numeric.Checked.t\n , Currency.Amount.var Numeric.Checked.t\n , Epoch_data.Checked.t )\n Poly.Stable.Latest.t\n\n let to_input\n ({ snarked_ledger_hash\n ; blockchain_length\n ; min_window_density\n ; total_currency\n ; global_slot_since_genesis\n ; staking_epoch_data\n ; next_epoch_data\n } :\n t ) =\n let open Random_oracle.Input.Chunked in\n let length = Numeric.(Checked.to_input Tc.length) in\n List.reduce_exn ~f:append\n [ Hash.(to_input_checked Tc.frozen_ledger_hash snarked_ledger_hash)\n ; length blockchain_length\n ; length min_window_density\n ; Numeric.(Checked.to_input Tc.amount total_currency)\n ; Numeric.(Checked.to_input Tc.global_slot global_slot_since_genesis)\n ; Epoch_data.Checked.to_input staking_epoch_data\n ; Epoch_data.Checked.to_input next_epoch_data\n ]\n\n let digest t =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix.zkapp_precondition_protocol_state\n (pack_input (to_input t)))\n\n let check\n (* Bind all the fields explicity so we make sure they are all used. *)\n ({ snarked_ledger_hash\n ; blockchain_length\n ; min_window_density\n ; total_currency\n ; global_slot_since_genesis\n ; staking_epoch_data\n ; next_epoch_data\n } :\n t ) (s : View.Checked.t) =\n let open Impl in\n let epoch_ledger ({ hash; total_currency } : _ Epoch_ledger.Poly.t)\n (t : Epoch_ledger.var) =\n [ Hash.(check_checked Tc.frozen_ledger_hash) hash t.hash\n ; Numeric.(Checked.check Tc.amount) total_currency t.total_currency\n ]\n in\n let epoch_data\n ({ ledger; seed; start_checkpoint; lock_checkpoint; epoch_length } :\n _ Epoch_data.Poly.t ) (t : _ Epoch_data.Poly.t) =\n ignore seed ;\n epoch_ledger ledger t.ledger\n @ [ Hash.(check_checked Tc.state_hash)\n start_checkpoint t.start_checkpoint\n ; Hash.(check_checked Tc.state_hash) lock_checkpoint t.lock_checkpoint\n ; Numeric.(Checked.check Tc.length) epoch_length t.epoch_length\n ]\n in\n Boolean.all\n ( [ Hash.(check_checked Tc.ledger_hash)\n snarked_ledger_hash s.snarked_ledger_hash\n ; Numeric.(Checked.check Tc.length)\n blockchain_length s.blockchain_length\n ; Numeric.(Checked.check Tc.length)\n min_window_density s.min_window_density\n ; Numeric.(Checked.check Tc.amount) total_currency s.total_currency\n ; Numeric.(Checked.check Tc.global_slot)\n global_slot_since_genesis s.global_slot_since_genesis\n ]\n @ epoch_data staking_epoch_data s.staking_epoch_data\n @ epoch_data next_epoch_data s.next_epoch_data )\n end\n\n let typ : (Checked.t, Stable.Latest.t) Typ.t =\n let open Poly.Stable.Latest in\n let frozen_ledger_hash = Hash.(typ Tc.frozen_ledger_hash) in\n let state_hash = Hash.(typ Tc.state_hash) in\n let epoch_seed = Hash.(typ Tc.epoch_seed) in\n let length = Numeric.(typ Tc.length) in\n let amount = Numeric.(typ Tc.amount) in\n let global_slot = Numeric.(typ Tc.global_slot) in\n let epoch_data =\n let epoch_ledger =\n let open Epoch_ledger.Poly in\n Typ.of_hlistable\n [ frozen_ledger_hash; amount ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n in\n let open Epoch_data.Poly in\n Typ.of_hlistable\n [ epoch_ledger; epoch_seed; state_hash; state_hash; length ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n in\n Typ.of_hlistable\n [ frozen_ledger_hash\n ; length\n ; length\n ; amount\n ; global_slot\n ; epoch_data\n ; epoch_data\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n let epoch_data : Epoch_data.t =\n { ledger = { hash = Ignore; total_currency = Ignore }\n ; seed = Ignore\n ; start_checkpoint = Ignore\n ; lock_checkpoint = Ignore\n ; epoch_length = Ignore\n }\n\n let accept : t =\n { snarked_ledger_hash = Ignore\n ; blockchain_length = Ignore\n ; min_window_density = Ignore\n ; total_currency = Ignore\n ; global_slot_since_genesis = Ignore\n ; staking_epoch_data = epoch_data\n ; next_epoch_data = epoch_data\n }\n\n let valid_until time : t =\n { snarked_ledger_hash = Ignore\n ; blockchain_length = Ignore\n ; min_window_density = Ignore\n ; total_currency = Ignore\n ; global_slot_since_genesis = Check time\n ; staking_epoch_data = epoch_data\n ; next_epoch_data = epoch_data\n }\n\n let%test_unit \"json roundtrip\" =\n let predicate : t = accept in\n let module Fd = Fields_derivers_zkapps.Derivers in\n let full = deriver (Fd.o ()) in\n [%test_eq: t] predicate (predicate |> Fd.to_json full |> Fd.of_json full)\n\n let check\n (* Bind all the fields explicity so we make sure they are all used. *)\n ({ snarked_ledger_hash\n ; blockchain_length\n ; min_window_density\n ; total_currency\n ; global_slot_since_genesis\n ; staking_epoch_data\n ; next_epoch_data\n } :\n t ) (s : View.t) =\n let open Or_error.Let_syntax in\n let epoch_ledger ({ hash; total_currency } : _ Epoch_ledger.Poly.t)\n (t : Epoch_ledger.Value.t) =\n let%bind () =\n Hash.(check ~label:\"epoch_ledger_hash\" Tc.frozen_ledger_hash)\n hash t.hash\n in\n let%map () =\n Numeric.(check ~label:\"epoch_ledger_total_currency\" Tc.amount)\n total_currency t.total_currency\n in\n ()\n in\n let epoch_data label\n ({ ledger; seed; start_checkpoint; lock_checkpoint; epoch_length } :\n _ Epoch_data.Poly.t ) (t : _ Epoch_data.Poly.t) =\n let l s = sprintf \"%s_%s\" label s in\n let%bind () = epoch_ledger ledger t.ledger in\n ignore seed ;\n let%bind () =\n Hash.(check ~label:(l \"start_check_point\") Tc.state_hash)\n start_checkpoint t.start_checkpoint\n in\n let%bind () =\n Hash.(check ~label:(l \"lock_check_point\") Tc.state_hash)\n lock_checkpoint t.lock_checkpoint\n in\n let%map () =\n Numeric.(check ~label:\"epoch_length\" Tc.length)\n epoch_length t.epoch_length\n in\n ()\n in\n let%bind () =\n Hash.(check ~label:\"snarked_ledger_hash\" Tc.ledger_hash)\n snarked_ledger_hash s.snarked_ledger_hash\n in\n let%bind () =\n Numeric.(check ~label:\"blockchain_length\" Tc.length)\n blockchain_length s.blockchain_length\n in\n let%bind () =\n Numeric.(check ~label:\"min_window_density\" Tc.length)\n min_window_density s.min_window_density\n in\n (* TODO: Decide whether to expose this *)\n let%bind () =\n Numeric.(check ~label:\"total_currency\" Tc.amount)\n total_currency s.total_currency\n in\n let%bind () =\n Numeric.(check ~label:\"global_slot_since_genesis\" Tc.global_slot)\n global_slot_since_genesis s.global_slot_since_genesis\n in\n let%bind () =\n epoch_data \"staking_epoch_data\" staking_epoch_data s.staking_epoch_data\n in\n let%map () =\n epoch_data \"next_epoch_data\" next_epoch_data s.next_epoch_data\n in\n ()\nend\n\nmodule Valid_while = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Global_slot_since_genesis.Stable.V1.t Numeric.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver = Numeric.Derivers.global_slot_since_genesis\n\n let gen =\n Numeric.gen Global_slot_since_genesis.gen Global_slot_since_genesis.compare\n\n let typ = Numeric.(typ Tc.global_slot)\n\n let to_input valid_while = Numeric.(to_input Tc.global_slot valid_while)\n\n let check (valid_while : t) global_slot =\n Numeric.(check ~label:\"valid_while_precondition\" Tc.global_slot)\n valid_while global_slot\n\n module Checked = struct\n type t = Global_slot_since_genesis.Checked.t Numeric.Checked.t\n\n let check (valid_while : t) global_slot =\n Numeric.(Checked.check Tc.global_slot) valid_while global_slot\n\n let to_input valid_while =\n Numeric.(Checked.to_input Tc.global_slot valid_while)\n end\nend\n\nmodule Account_type = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = User | Zkapp | None | Any\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let check (t : t) (a : A.t option) =\n match (a, t) with\n | _, Any ->\n Ok ()\n | None, None ->\n Ok ()\n | None, _ ->\n Or_error.error_string \"expected account_type = None\"\n | Some a, User ->\n assert_ (Option.is_none a.zkapp) \"expected account_type = User\"\n | Some a, Zkapp ->\n assert_ (Option.is_some a.zkapp) \"expected account_type = Zkapp\"\n | Some _, None ->\n Or_error.error_string \"no second account allowed\"\n\n let to_bits = function\n | User ->\n [ true; false ]\n | Zkapp ->\n [ false; true ]\n | None ->\n [ false; false ]\n | Any ->\n [ true; true ]\n\n let of_bits = function\n | [ user; zkapp ] -> (\n match (user, zkapp) with\n | true, false ->\n User\n | false, true ->\n Zkapp\n | false, false ->\n None\n | true, true ->\n Any )\n | _ ->\n assert false\n\n let to_input x =\n let open Random_oracle_input.Chunked in\n Array.reduce_exn ~f:append\n (Array.of_list_map (to_bits x) ~f:(fun b -> packed (field_of_bool b, 1)))\n\n module Checked = struct\n type t = { user : Boolean.var; zkapp : Boolean.var } [@@deriving hlist]\n\n let to_input { user; zkapp } =\n let open Random_oracle_input.Chunked in\n Array.reduce_exn ~f:append\n (Array.map [| user; zkapp |] ~f:(fun b ->\n packed ((b :> Field.Var.t), 1) ) )\n\n let constant =\n let open Boolean in\n function\n | User ->\n { user = true_; zkapp = false_ }\n | Zkapp ->\n { user = false_; zkapp = true_ }\n | None ->\n { user = false_; zkapp = false_ }\n | Any ->\n { user = true_; zkapp = true_ }\n\n (* TODO: Write a unit test for these. *)\n let snapp_allowed t = t.zkapp\n\n let user_allowed t = t.user\n end\n\n let typ =\n let open Checked in\n Typ.of_hlistable\n [ Boolean.typ; Boolean.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:(function\n | User ->\n [ true; false ]\n | Zkapp ->\n [ false; true ]\n | None ->\n [ false; false ]\n | Any ->\n [ true; true ] )\n ~value_of_hlist:(fun [ user; zkapp ] ->\n match (user, zkapp) with\n | true, false ->\n User\n | false, true ->\n Zkapp\n | false, false ->\n None\n | true, true ->\n Any )\nend\n\nmodule Other = struct\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('account, 'account_transition, 'vk) t =\n { predicate : 'account\n ; account_transition : 'account_transition\n ; account_vk : 'vk\n }\n [@@deriving hlist, sexp, equal, yojson, hash, compare]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Account.Stable.V2.t\n , Account_state.Stable.V1.t Transition.Stable.V1.t\n , F.Stable.V1.t Hash.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n module Checked = struct\n type t =\n ( Account.Checked.t\n , Account_state.Checked.t Transition.t\n , Field.Var.t Or_ignore.Checked.t )\n Poly.Stable.Latest.t\n\n let to_input ({ predicate; account_transition; account_vk } : t) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Account.Checked.to_input predicate\n ; Transition.to_input ~f:Account_state.Checked.to_input\n account_transition\n ; Hash.(to_input_checked Tc.field) account_vk\n ]\n end\n\n let to_input ({ predicate; account_transition; account_vk } : t) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Account.to_input predicate\n ; Transition.to_input ~f:Account_state.to_input account_transition\n ; Hash.(to_input Tc.field) account_vk\n ]\n\n let typ () =\n let open Poly in\n Typ.of_hlistable\n [ Account.typ (); Transition.typ Account_state.typ; Hash.(typ Tc.field) ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n let accept : t =\n { predicate = Account.accept\n ; account_transition = { prev = Any; next = Any }\n ; account_vk = Ignore\n }\nend\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('account, 'protocol_state, 'other, 'pk) t =\n { self_predicate : 'account\n ; other : 'other\n ; fee_payer : 'pk\n ; protocol_state_predicate : 'protocol_state\n }\n [@@deriving hlist, sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let typ spec =\n let open Stable.Latest in\n Typ.of_hlistable spec ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n ( Account.Stable.V2.t\n , Protocol_state.Stable.V1.t\n , Other.Stable.V2.t\n , Public_key.Compressed.Stable.V1.t Eq_data.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\nend]\n\nmodule Digested = F\n\nlet to_input ({ self_predicate; other; fee_payer; protocol_state_predicate } : t)\n =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Account.to_input self_predicate\n ; Other.to_input other\n ; Eq_data.(to_input (Tc.public_key ())) fee_payer\n ; Protocol_state.to_input protocol_state_predicate\n ]\n\nlet digest t =\n Random_oracle.(\n hash ~init:Hash_prefix.zkapp_precondition (pack_input (to_input t)))\n\nlet accept : t =\n { self_predicate = Account.accept\n ; other = Other.accept\n ; fee_payer = Ignore\n ; protocol_state_predicate = Protocol_state.accept\n }\n\nmodule Checked = struct\n type t =\n ( Account.Checked.t\n , Protocol_state.Checked.t\n , Other.Checked.t\n , Public_key.Compressed.var Or_ignore.Checked.t )\n Poly.Stable.Latest.t\n\n let to_input\n ({ self_predicate; other; fee_payer; protocol_state_predicate } : t) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Account.Checked.to_input self_predicate\n ; Other.Checked.to_input other\n ; Eq_data.(to_input_checked (Tc.public_key ())) fee_payer\n ; Protocol_state.Checked.to_input protocol_state_predicate\n ]\n\n let digest t =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix.zkapp_precondition (pack_input (to_input t)))\nend\n\nlet typ () : (Checked.t, Stable.Latest.t) Typ.t =\n Poly.typ\n [ Account.typ ()\n ; Other.typ ()\n ; Eq_data.(typ (Tc.public_key ()))\n ; Protocol_state.typ\n ]\n","open Snark_params\nopen Tick\n\ntype 'a t = Field.Var.t * 'a As_prover.Ref.t\n\nlet hash (x, _) = x\n\nlet ref (_, x) = x\n\nlet typ ~hash =\n Typ.transport\n Typ.(Field.typ * Internal.ref ())\n ~there:(fun s -> (hash s, s))\n ~back:(fun (_, s) -> s)\n\nlet optional_typ ~hash ~non_preimage ~dummy_value =\n Typ.transport\n Typ.(Field.typ * Internal.ref ())\n ~there:(function\n | None -> (non_preimage, dummy_value) | Some s -> (hash s, s) )\n ~back:(fun (_, s) -> Some s)\n\nlet lazy_optional_typ ~hash ~non_preimage ~dummy_value =\n Typ.transport\n Typ.(Field.typ * Internal.ref ())\n ~there:(function\n | None -> (Lazy.force non_preimage, dummy_value) | Some s -> (hash s, s)\n )\n ~back:(fun (_, s) -> Some s)\n\nlet to_input (x, _) = Random_oracle_input.Chunked.field x\n\nlet if_ b ~then_ ~else_ =\n let open Run in\n let hash = Field.if_ b ~then_:(fst then_) ~else_:(fst else_) in\n let ref =\n As_prover.Ref.create\n As_prover.(\n fun () ->\n let ref = if read Boolean.typ b then snd then_ else snd else_ in\n As_prover.Ref.get ref)\n in\n (hash, ref)\n\nlet make_unsafe hash ref : 'a t = (hash, ref)\n\nmodule As_record = struct\n (* it's OK that hash is a Field.t (not a var), bc this is just annotation for the deriver *)\n type 'a t = { data : 'a; hash : Field.t } [@@deriving annot, fields]\nend\n\nlet deriver inner obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots:As_record.t_fields_annots in\n As_record.Fields.make_creator obj ~data:!.inner ~hash:!.field\n |> finish \"Events\" ~t_toplevel_annots:As_record.t_toplevel_annots\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_util\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nopen Signature_lib\nmodule Impl = Pickles.Impls.Step\nopen Mina_numbers\nopen Currency\nopen Pickles_types\nmodule Digest = Random_oracle.Digest\n\nmodule type Type = sig\n type t\nend\n\nmodule Authorization_kind = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n (* TODO: yojson for Field.t in snarky (#12591) *)\n type t =\n Mina_wire_types.Mina_base.Account_update.Authorization_kind.V1.t =\n | Signature\n | Proof of\n (Field.t\n [@version_asserted]\n [@to_yojson fun t -> `String (Snark_params.Tick.Field.to_string t)]\n [@of_yojson\n function\n | `String s ->\n let field = Snark_params.Tick.Field.of_string s in\n let s' = Snark_params.Tick.Field.to_string field in\n if String.equal s s' then Ok field\n else Error \"Invalid JSON for field\"\n | _ ->\n Error \"expected JSON string\"] )\n | None_given\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n module Structured = struct\n type t =\n { is_signed : bool\n ; is_proved : bool\n ; verification_key_hash : Snark_params.Tick.Field.t\n }\n [@@deriving hlist, annot, fields]\n\n let to_input ({ is_signed; is_proved; verification_key_hash } : t) =\n let f x = if x then Field.one else Field.zero in\n Random_oracle_input.Chunked.append\n (Random_oracle_input.Chunked.packeds\n [| (f is_signed, 1); (f is_proved, 1) |] )\n (Random_oracle_input.Chunked.field verification_key_hash)\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n type t =\n { is_signed : Boolean.var\n ; is_proved : Boolean.var\n ; verification_key_hash : Snark_params.Tick.Field.Var.t\n }\n [@@deriving hlist]\n\n let to_input { is_signed; is_proved; verification_key_hash } =\n let f (x : Boolean.var) = (x :> Field.Var.t) in\n Random_oracle_input.Chunked.append\n (Random_oracle_input.Chunked.packeds\n [| (f is_signed, 1); (f is_proved, 1) |] )\n (Random_oracle_input.Chunked.field verification_key_hash)\n end\n\n let typ =\n Typ.of_hlistable ~var_to_hlist:Checked.to_hlist\n ~var_of_hlist:Checked.of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n [ Boolean.typ; Boolean.typ; Field.typ ]\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let open Fields in\n let ( !. ) = ( !. ) ~t_fields_annots in\n let verification_key_hash =\n needs_custom_js ~js_type:field ~name:\"VerificationKeyHash\" field\n in\n Fields.make_creator obj ~is_signed:!.bool ~is_proved:!.bool\n ~verification_key_hash:!.verification_key_hash\n |> finish \"AuthorizationKindStructured\" ~t_toplevel_annots\n\n [%%endif]\n end\n\n let to_control_tag : t -> Control.Tag.t = function\n | None_given ->\n None_given\n | Signature ->\n Signature\n | Proof _ ->\n Proof\n\n let to_structured : t -> Structured.t = function\n | None_given ->\n { is_signed = false\n ; is_proved = false\n ; verification_key_hash = Zkapp_account.dummy_vk_hash ()\n }\n | Signature ->\n { is_signed = true\n ; is_proved = false\n ; verification_key_hash = Zkapp_account.dummy_vk_hash ()\n }\n | Proof verification_key_hash ->\n { is_signed = false; is_proved = true; verification_key_hash }\n\n let of_structured_exn : Structured.t -> t = function\n | { is_signed = false; is_proved = false; _ } ->\n None_given\n | { is_signed = true; is_proved = false; _ } ->\n Signature\n | { is_signed = false; is_proved = true; verification_key_hash } ->\n Proof verification_key_hash\n | { is_signed = true; is_proved = true; _ } ->\n failwith \"Invalid authorization kind\"\n\n let gen =\n let%bind.Quickcheck vk_hash = Field.gen in\n Quickcheck.Generator.of_list [ None_given; Signature; Proof vk_hash ]\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n iso_record ~to_record:to_structured ~of_record:of_structured_exn\n Structured.deriver obj\n\n let to_input x = Structured.to_input (to_structured x)\n\n [%%ifdef consensus_mechanism]\n\n module Checked = Structured.Checked\n\n let typ =\n Structured.typ |> Typ.transport ~there:to_structured ~back:of_structured_exn\n\n [%%endif]\nend\n\nmodule May_use_token = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Account_update.May_use_token.V1.t =\n | No\n (** No permission to use any token other than the default Mina\n token.\n *)\n | Parents_own_token\n (** Has permission to use the token owned by the direct parent of\n this account update, which may be inherited by child account\n updates.\n *)\n | Inherit_from_parent\n (** Inherit the token permission available to the parent. *)\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen =\n Quickcheck.Generator.of_list [ No; Parents_own_token; Inherit_from_parent ]\n\n let to_string = function\n | No ->\n \"No\"\n | Parents_own_token ->\n \"ParentsOwnToken\"\n | Inherit_from_parent ->\n \"InheritFromParent\"\n\n let of_string = function\n | \"No\" ->\n No\n | \"ParentsOwnToken\" ->\n Parents_own_token\n | \"InheritFromParent\" ->\n Inherit_from_parent\n | s ->\n failwithf \"Invalid call type: %s\" s ()\n\n let parents_own_token = function Parents_own_token -> true | _ -> false\n\n let inherit_from_parent = function Inherit_from_parent -> true | _ -> false\n\n module As_record : sig\n type variant = t\n\n type 'bool t\n\n val parents_own_token : 'bool t -> 'bool\n\n val inherit_from_parent : 'bool t -> 'bool\n\n val map : f:('a -> 'b) -> 'a t -> 'b t\n\n val to_hlist : 'bool t -> (unit, 'bool -> 'bool -> unit) H_list.t\n\n val of_hlist : (unit, 'bool -> 'bool -> unit) H_list.t -> 'bool t\n\n val to_input :\n field_of_bool:('a -> 'b) -> 'a t -> 'b Random_oracle_input.Chunked.t\n\n val typ : (Snark_params.Tick.Boolean.var t, bool t) Snark_params.Tick.Typ.t\n\n val equal :\n and_:('bool -> 'bool -> 'bool)\n -> equal:('a -> 'a -> 'bool)\n -> 'a t\n -> 'a t\n -> 'bool\n\n val to_variant : bool t -> variant\n\n val of_variant : variant -> bool t\n\n (* TODO: Create an alias for this type *)\n val deriver :\n ( bool t\n , ( ( ( bool t\n , ( bool t\n , ( bool t\n , ( ( bool t\n , ( bool t\n , ( bool t\n , ( (< contramap : (bool t -> bool t) Core_kernel.ref\n ; graphql_arg :\n ( unit\n -> bool t\n Fields_derivers_graphql.Schema.Arg\n .arg_typ )\n Core_kernel.ref\n ; graphql_arg_accumulator :\n bool t\n Fields_derivers_zkapps.Derivers.Graphql.Args\n .Acc\n .T\n .t\n Core_kernel.ref\n ; graphql_creator :\n ( ( ( 'a\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers\n .Graphql\n .Args\n .Output\n .t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql\n .Args\n .Input\n .t\n -> bool t )\n Core_kernel.ref\n ; graphql_fields :\n bool t\n Fields_derivers_zkapps.Derivers.Graphql\n .Fields\n .Input\n .T\n .t\n Core_kernel.ref\n ; graphql_fields_accumulator :\n bool t\n Fields_derivers_zkapps.Derivers.Graphql\n .Fields\n .Accumulator\n .T\n .t\n list\n Core_kernel.ref\n ; graphql_query : string option Core_kernel.ref\n ; graphql_query_accumulator :\n (Core_kernel.String.t * string option)\n option\n list\n Core_kernel.ref\n ; js_layout :\n [> `Assoc of (string * Yojson.Safe.t) list ]\n Core_kernel.ref\n ; js_layout_accumulator :\n Fields_derivers_zkapps__.Fields_derivers_js\n .Js_layout\n .Accumulator\n .field\n option\n list\n Core_kernel.ref\n ; map : (bool t -> bool t) Core_kernel.ref\n ; nullable_graphql_arg :\n ( unit\n -> 'b\n Fields_derivers_graphql.Schema.Arg\n .arg_typ )\n Core_kernel.ref\n ; nullable_graphql_fields :\n bool t option\n Fields_derivers_zkapps.Derivers.Graphql\n .Fields\n .Input\n .T\n .t\n Core_kernel.ref\n ; of_json :\n (Yojson.Safe.t -> bool t) Core_kernel.ref\n ; of_json_creator :\n Yojson.Safe.t Core_kernel.String.Map.t\n Core_kernel.ref\n ; skip : bool Core_kernel.ref\n ; to_json :\n (bool t -> Yojson.Safe.t) Core_kernel.ref\n ; to_json_accumulator :\n ( Core_kernel.String.t\n * (bool t -> Yojson.Safe.t) )\n option\n list\n Core_kernel.ref\n ; .. >\n as\n 'a )\n Fields_derivers_zkapps__.Fields_derivers_js\n .Js_layout\n .Input\n .t\n Fields_derivers_graphql.Graphql_query.Input.t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql.Args.Input\n .t\n , bool t\n , bool t option )\n Fields_derivers_zkapps.Derivers.Graphql.Fields.Input\n .t\n , bool t )\n Fields_derivers_json.Of_yojson.Input.t\n , bool t )\n Fields_derivers_json.To_yojson.Input.t\n Fields_derivers_zkapps.Unified_input.t\n Fields_derivers_zkapps__.Fields_derivers_js.Js_layout\n .Input\n .t\n Fields_derivers_graphql.Graphql_query.Input.t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql.Args.Input.t\n , bool t\n , bool t option )\n Fields_derivers_zkapps.Derivers.Graphql.Fields.Input.t\n , bool t )\n Fields_derivers_json.Of_yojson.Input.t\n , bool t )\n Fields_derivers_json.To_yojson.Input.t\n Fields_derivers_zkapps.Unified_input.t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql.Args.Input.t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql.Args.Acc.t\n , bool t\n , bool t option )\n Fields_derivers_zkapps.Derivers.Graphql.Fields.Accumulator.t\n -> ( bool t\n , ( bool t\n , ( bool t\n , ( 'a Fields_derivers_zkapps__.Fields_derivers_js.Js_layout.Input.t\n Fields_derivers_graphql.Graphql_query.Input.t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql.Args.Input.t\n , bool t\n , bool t option )\n Fields_derivers_zkapps.Derivers.Graphql.Fields.Input.t\n , bool t )\n Fields_derivers_json.Of_yojson.Input.t\n , bool t )\n Fields_derivers_json.To_yojson.Input.t\n Fields_derivers_zkapps.Unified_input.t\n end = struct\n type variant = t\n\n type 'bool t =\n { (* NB: call is implicit. *)\n parents_own_token : 'bool\n ; inherit_from_parent : 'bool\n }\n [@@deriving annot, hlist, fields]\n\n let map ~f { parents_own_token; inherit_from_parent } =\n { parents_own_token = f parents_own_token\n ; inherit_from_parent = f inherit_from_parent\n }\n\n let typ : _ Typ.t =\n let open Snark_params.Tick in\n let (Typ typ) =\n Typ.of_hlistable\n [ Boolean.typ; Boolean.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n in\n Typ\n { typ with\n check =\n (fun ({ parents_own_token; inherit_from_parent } as x) ->\n let open Checked in\n let%bind () = typ.check x in\n let sum =\n Field.Var.(\n add (parents_own_token :> t) (inherit_from_parent :> t))\n in\n (* Assert boolean; we should really have a helper for this\n somewhere.\n *)\n let%bind sum_squared = Field.Checked.mul sum sum in\n Field.Checked.Assert.equal sum sum_squared )\n }\n\n let to_input ~field_of_bool { parents_own_token; inherit_from_parent } =\n Array.reduce_exn ~f:Random_oracle_input.Chunked.append\n [| Random_oracle_input.Chunked.packed\n (field_of_bool parents_own_token, 1)\n ; Random_oracle_input.Chunked.packed\n (field_of_bool inherit_from_parent, 1)\n |]\n\n let equal ~and_ ~equal\n { parents_own_token = parents_own_token1\n ; inherit_from_parent = inherit_from_parent1\n }\n { parents_own_token = parents_own_token2\n ; inherit_from_parent = inherit_from_parent2\n } =\n and_\n (equal parents_own_token1 parents_own_token2)\n (equal inherit_from_parent1 inherit_from_parent2)\n\n let to_variant = function\n | { parents_own_token = false; inherit_from_parent = false } ->\n No\n | { parents_own_token = true; inherit_from_parent = false } ->\n Parents_own_token\n | { parents_own_token = false; inherit_from_parent = true } ->\n Inherit_from_parent\n | _ ->\n failwith \"May_use_token.to_variant: More than one boolean flag is set\"\n\n let of_variant = function\n | No ->\n { parents_own_token = false; inherit_from_parent = false }\n | Parents_own_token ->\n { parents_own_token = true; inherit_from_parent = false }\n | Inherit_from_parent ->\n { parents_own_token = false; inherit_from_parent = true }\n\n let deriver obj : _ Fields_derivers_zkapps.Unified_input.t =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~parents_own_token:!.bool\n ~inherit_from_parent:!.bool\n |> finish \"MayUseToken\" ~t_toplevel_annots\n end\n\n let quickcheck_generator = gen\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n iso_record ~of_record:As_record.to_variant ~to_record:As_record.of_variant\n As_record.deriver obj\n\n module Checked = struct\n type t = Boolean.var As_record.t\n\n let parents_own_token = As_record.parents_own_token\n\n let inherit_from_parent = As_record.inherit_from_parent\n\n let constant x =\n As_record.map ~f:Boolean.var_of_value @@ As_record.of_variant x\n\n let to_input (x : t) =\n As_record.to_input\n ~field_of_bool:(fun (x : Boolean.var) -> (x :> Field.Var.t))\n x\n\n let equal x y =\n As_record.equal ~equal:Run.Boolean.equal ~and_:Run.Boolean.( &&& ) x y\n\n let assert_equal x y =\n As_record.equal ~equal:Run.Boolean.Assert.( = ) ~and_:(fun _ _ -> ()) x y\n end\n\n let to_input x = As_record.to_input ~field_of_bool (As_record.of_variant x)\n\n let typ : (Checked.t, t) Typ.t =\n As_record.typ\n |> Typ.transport ~there:As_record.of_variant ~back:As_record.to_variant\nend\n\nmodule Update = struct\n module Timing_info = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n Mina_wire_types.Mina_base.Account_update.Update.Timing_info.V1.t =\n { initial_minimum_balance : Balance.Stable.V1.t\n ; cliff_time : Global_slot_since_genesis.Stable.V1.t\n ; cliff_amount : Amount.Stable.V1.t\n ; vesting_period : Global_slot_span.Stable.V1.t\n ; vesting_increment : Amount.Stable.V1.t\n }\n [@@deriving annot, compare, equal, sexp, hash, yojson, hlist, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n type value = t\n\n let gen =\n let open Quickcheck.Let_syntax in\n let%bind initial_minimum_balance = Balance.gen in\n let%bind cliff_time = Global_slot_since_genesis.gen in\n let%bind cliff_amount =\n Amount.gen_incl Amount.zero (Balance.to_amount initial_minimum_balance)\n in\n let%bind vesting_period =\n Global_slot_span.gen_incl\n Global_slot_span.(succ zero)\n (Global_slot_span.of_int 10)\n in\n let%map vesting_increment =\n Amount.gen_incl Amount.one (Amount.of_nanomina_int_exn 100)\n in\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n\n let to_input (t : t) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Balance.to_input t.initial_minimum_balance\n ; Global_slot_since_genesis.to_input t.cliff_time\n ; Amount.to_input t.cliff_amount\n ; Global_slot_span.to_input t.vesting_period\n ; Amount.to_input t.vesting_increment\n ]\n\n let dummy =\n let slot_unused = Global_slot_since_genesis.zero in\n let slot_span_unused = Global_slot_span.zero in\n let balance_unused = Balance.zero in\n let amount_unused = Amount.zero in\n { initial_minimum_balance = balance_unused\n ; cliff_time = slot_unused\n ; cliff_amount = amount_unused\n ; vesting_period = slot_span_unused\n ; vesting_increment = amount_unused\n }\n\n let to_account_timing (t : t) : Account_timing.t =\n Timed\n { initial_minimum_balance = t.initial_minimum_balance\n ; cliff_time = t.cliff_time\n ; cliff_amount = t.cliff_amount\n ; vesting_period = t.vesting_period\n ; vesting_increment = t.vesting_increment\n }\n\n let of_account_timing (t : Account_timing.t) : t option =\n match t with\n | Untimed ->\n None\n | Timed t ->\n Some\n { initial_minimum_balance = t.initial_minimum_balance\n ; cliff_time = t.cliff_time\n ; cliff_amount = t.cliff_amount\n ; vesting_period = t.vesting_period\n ; vesting_increment = t.vesting_increment\n }\n\n module Checked = struct\n type t =\n { initial_minimum_balance : Balance.Checked.t\n ; cliff_time : Global_slot_since_genesis.Checked.t\n ; cliff_amount : Amount.Checked.t\n ; vesting_period : Global_slot_span.Checked.t\n ; vesting_increment : Amount.Checked.t\n }\n [@@deriving hlist]\n\n let constant (t : value) : t =\n { initial_minimum_balance = Balance.var_of_t t.initial_minimum_balance\n ; cliff_time = Global_slot_since_genesis.Checked.constant t.cliff_time\n ; cliff_amount = Amount.var_of_t t.cliff_amount\n ; vesting_period = Global_slot_span.Checked.constant t.vesting_period\n ; vesting_increment = Amount.var_of_t t.vesting_increment\n }\n\n let to_input\n ({ initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } :\n t ) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Balance.var_to_input initial_minimum_balance\n ; Global_slot_since_genesis.Checked.to_input cliff_time\n ; Amount.var_to_input cliff_amount\n ; Global_slot_span.Checked.to_input vesting_period\n ; Amount.var_to_input vesting_increment\n ]\n\n let to_account_timing (t : t) : Account_timing.var =\n { is_timed = Boolean.true_\n ; initial_minimum_balance = t.initial_minimum_balance\n ; cliff_time = t.cliff_time\n ; cliff_amount = t.cliff_amount\n ; vesting_period = t.vesting_period\n ; vesting_increment = t.vesting_increment\n }\n\n let of_account_timing (t : Account_timing.var) : t =\n { initial_minimum_balance = t.initial_minimum_balance\n ; cliff_time = t.cliff_time\n ; cliff_amount = t.cliff_amount\n ; vesting_period = t.vesting_period\n ; vesting_increment = t.vesting_increment\n }\n end\n\n let typ : (Checked.t, t) Typ.t =\n Typ.of_hlistable\n [ Balance.typ\n ; Global_slot_since_genesis.typ\n ; Amount.typ\n ; Global_slot_span.typ\n ; Amount.typ\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~initial_minimum_balance:!.balance\n ~cliff_time:!.global_slot_since_genesis\n ~cliff_amount:!.amount ~vesting_period:!.global_slot_span\n ~vesting_increment:!.amount\n |> finish \"Timing\" ~t_toplevel_annots\n end\n\n open Zkapp_basic\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n (* TODO: Have to check that the public key is not = Public_key.Compressed.empty here. *)\n type t = Mina_wire_types.Mina_base.Account_update.Update.V1.t =\n { app_state :\n F.Stable.V1.t Set_or_keep.Stable.V1.t Zkapp_state.V.Stable.V1.t\n ; delegate : Public_key.Compressed.Stable.V1.t Set_or_keep.Stable.V1.t\n ; verification_key :\n Verification_key_wire.Stable.V1.t Set_or_keep.Stable.V1.t\n ; permissions : Permissions.Stable.V2.t Set_or_keep.Stable.V1.t\n ; zkapp_uri : string Set_or_keep.Stable.V1.t\n ; token_symbol :\n Account.Token_symbol.Stable.V1.t Set_or_keep.Stable.V1.t\n ; timing : Timing_info.Stable.V1.t Set_or_keep.Stable.V1.t\n ; voting_for : State_hash.Stable.V1.t Set_or_keep.Stable.V1.t\n }\n [@@deriving annot, compare, equal, sexp, hash, yojson, fields, hlist]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen ?(token_account = false) ?(zkapp_account = false) ?vk\n ?permissions_auth () : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind app_state =\n let%bind fields =\n let field_gen = Snark_params.Tick.Field.gen in\n Quickcheck.Generator.list_with_length 8 (Set_or_keep.gen field_gen)\n in\n (* won't raise because length is correct *)\n Quickcheck.Generator.return (Zkapp_state.V.of_list_exn fields)\n in\n let%bind delegate =\n if not token_account then Set_or_keep.gen Public_key.Compressed.gen\n else return Set_or_keep.Keep\n in\n let%bind verification_key =\n if zkapp_account then\n Set_or_keep.gen\n (Quickcheck.Generator.return\n ( match vk with\n | None ->\n let data = Pickles.Side_loaded.Verification_key.dummy in\n let hash = Zkapp_account.digest_vk data in\n { With_hash.data; hash }\n | Some vk ->\n vk ) )\n else return Set_or_keep.Keep\n in\n let%bind permissions =\n match permissions_auth with\n | None ->\n return Set_or_keep.Keep\n | Some auth_tag ->\n let%map permissions = Permissions.gen ~auth_tag in\n Set_or_keep.Set permissions\n in\n let%bind zkapp_uri =\n let uri_gen =\n Quickcheck.Generator.of_list\n [ \"https://www.example.com\"\n ; \"https://www.minaprotocol.com\"\n ; \"https://www.gurgle.com\"\n ; \"https://faceplant.com\"\n ]\n in\n Set_or_keep.gen uri_gen\n in\n let%bind token_symbol =\n let token_gen =\n Quickcheck.Generator.of_list\n [ \"MINA\"; \"TOKEN1\"; \"TOKEN2\"; \"TOKEN3\"; \"TOKEN4\"; \"TOKEN5\" ]\n in\n Set_or_keep.gen token_gen\n in\n let%bind voting_for = Set_or_keep.gen Field.gen in\n (* a new account for the Account_update.t is in the ledger when we use\n this generated update in tests, so the timing must be Keep\n *)\n let timing = Set_or_keep.Keep in\n return\n ( { app_state\n ; delegate\n ; verification_key\n ; permissions\n ; zkapp_uri\n ; token_symbol\n ; timing\n ; voting_for\n }\n : t )\n\n module Checked = struct\n open Pickles.Impls.Step\n\n type t =\n { app_state : Field.t Set_or_keep.Checked.t Zkapp_state.V.t\n ; delegate : Public_key.Compressed.var Set_or_keep.Checked.t\n ; verification_key :\n ( Boolean.var\n , ( Side_loaded_verification_key.t option\n , Field.Constant.t )\n With_hash.t\n Data_as_hash.t )\n Zkapp_basic.Flagged_option.t\n Set_or_keep.Checked.t\n ; permissions : Permissions.Checked.t Set_or_keep.Checked.t\n ; zkapp_uri : string Data_as_hash.t Set_or_keep.Checked.t\n ; token_symbol : Account.Token_symbol.var Set_or_keep.Checked.t\n ; timing : Timing_info.Checked.t Set_or_keep.Checked.t\n ; voting_for : State_hash.var Set_or_keep.Checked.t\n }\n [@@deriving hlist]\n\n let to_input\n ({ app_state\n ; delegate\n ; verification_key\n ; permissions\n ; zkapp_uri\n ; token_symbol\n ; timing\n ; voting_for\n } :\n t ) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Zkapp_state.to_input app_state\n ~f:(Set_or_keep.Checked.to_input ~f:field)\n ; Set_or_keep.Checked.to_input delegate\n ~f:Public_key.Compressed.Checked.to_input\n ; Set_or_keep.Checked.to_input verification_key ~f:(fun x ->\n field (Data_as_hash.hash x.data) )\n ; Set_or_keep.Checked.to_input permissions\n ~f:Permissions.Checked.to_input\n ; Set_or_keep.Checked.to_input zkapp_uri ~f:Data_as_hash.to_input\n ; Set_or_keep.Checked.to_input token_symbol\n ~f:Account.Token_symbol.var_to_input\n ; Set_or_keep.Checked.to_input timing ~f:Timing_info.Checked.to_input\n ; Set_or_keep.Checked.to_input voting_for ~f:State_hash.var_to_input\n ]\n end\n\n let noop : t =\n { app_state =\n Vector.init Zkapp_state.Max_state_size.n ~f:(fun _ -> Set_or_keep.Keep)\n ; delegate = Keep\n ; verification_key = Keep\n ; permissions = Keep\n ; zkapp_uri = Keep\n ; token_symbol = Keep\n ; timing = Keep\n ; voting_for = Keep\n }\n\n let dummy = noop\n\n let to_input\n ({ app_state\n ; delegate\n ; verification_key\n ; permissions\n ; zkapp_uri\n ; token_symbol\n ; timing\n ; voting_for\n } :\n t ) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Zkapp_state.to_input app_state\n ~f:(Set_or_keep.to_input ~dummy:Field.zero ~f:field)\n ; Set_or_keep.to_input delegate\n ~dummy:(Zkapp_precondition.Eq_data.Tc.public_key ()).default\n ~f:Public_key.Compressed.to_input\n ; Set_or_keep.to_input\n (Set_or_keep.map verification_key ~f:With_hash.hash)\n ~dummy:Field.zero ~f:field\n ; Set_or_keep.to_input permissions ~dummy:Permissions.empty\n ~f:Permissions.to_input\n ; Set_or_keep.to_input\n (Set_or_keep.map ~f:Zkapp_account.hash_zkapp_uri zkapp_uri)\n ~dummy:(Zkapp_account.hash_zkapp_uri_opt None)\n ~f:field\n ; Set_or_keep.to_input token_symbol ~dummy:Account.Token_symbol.default\n ~f:Account.Token_symbol.to_input\n ; Set_or_keep.to_input timing ~dummy:Timing_info.dummy\n ~f:Timing_info.to_input\n ; Set_or_keep.to_input voting_for ~dummy:State_hash.dummy\n ~f:State_hash.to_input\n ]\n\n let typ () : (Checked.t, t) Typ.t =\n let open Pickles.Impls.Step in\n Typ.of_hlistable\n [ Zkapp_state.typ (Set_or_keep.typ ~dummy:Field.Constant.zero Field.typ)\n ; Set_or_keep.typ ~dummy:Public_key.Compressed.empty\n Public_key.Compressed.typ\n ; Set_or_keep.optional_typ\n (Data_as_hash.typ ~hash:With_hash.hash)\n ~to_option:(function\n | { With_hash.data = Some data; hash } ->\n Some { With_hash.data; hash }\n | { With_hash.data = None; _ } ->\n None )\n ~of_option:(function\n | Some { With_hash.data; hash } ->\n { With_hash.data = Some data; hash }\n | None ->\n { With_hash.data = None; hash = Field.Constant.zero } )\n |> Typ.transport_var\n ~there:\n (Set_or_keep.Checked.map\n ~f:(fun { Zkapp_basic.Flagged_option.data; _ } -> data) )\n ~back:(fun x ->\n Set_or_keep.Checked.map x ~f:(fun data ->\n { Zkapp_basic.Flagged_option.data\n ; is_some = Set_or_keep.Checked.is_set x\n } ) )\n ; Set_or_keep.typ ~dummy:Permissions.empty Permissions.typ\n ; Set_or_keep.optional_typ\n (Data_as_hash.lazy_optional_typ ~hash:Zkapp_account.hash_zkapp_uri\n ~non_preimage:(lazy (Zkapp_account.hash_zkapp_uri_opt None))\n ~dummy_value:\"\" )\n ~to_option:Fn.id ~of_option:Fn.id\n ; Set_or_keep.typ ~dummy:Account.Token_symbol.default\n Account.Token_symbol.typ\n ; Set_or_keep.typ ~dummy:Timing_info.dummy Timing_info.typ\n ; Set_or_keep.typ ~dummy:State_hash.dummy State_hash.typ\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots in\n let zkapp_uri =\n needs_custom_js\n ~js_type:(Data_as_hash.deriver string)\n ~name:\"ZkappUri\" string\n in\n let token_symbol =\n needs_custom_js\n ~js_type:\n (js_record\n [ (\"symbol\", js_layout string); (\"field\", js_layout field) ] )\n ~name:\"TokenSymbol\" string\n in\n finish \"AccountUpdateModification\" ~t_toplevel_annots\n @@ Fields.make_creator\n ~app_state:!.(Zkapp_state.deriver @@ Set_or_keep.deriver field)\n ~delegate:!.(Set_or_keep.deriver public_key)\n ~verification_key:!.(Set_or_keep.deriver verification_key_with_hash)\n ~permissions:!.(Set_or_keep.deriver Permissions.deriver)\n ~zkapp_uri:!.(Set_or_keep.deriver zkapp_uri)\n ~token_symbol:!.(Set_or_keep.deriver token_symbol)\n ~timing:!.(Set_or_keep.deriver Timing_info.deriver)\n ~voting_for:!.(Set_or_keep.deriver State_hash.deriver)\n obj\nend\n\nmodule Events = Zkapp_account.Events\nmodule Actions = Zkapp_account.Actions\n\nmodule Account_precondition = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Zkapp_precondition.Account.Stable.V2.t\n [@@deriving sexp, yojson, hash]\n\n let (_ :\n ( t\n , Mina_wire_types.Mina_base.Account_update.Account_precondition.V1.t\n )\n Type_equal.t ) =\n Type_equal.T\n\n let to_latest = Fn.id\n\n [%%define_locally Zkapp_precondition.Account.(equal, compare)]\n end\n end]\n\n [%%define_locally Stable.Latest.(equal, compare)]\n\n let gen : t Quickcheck.Generator.t =\n (* we used to have 3 constructors, Full, Nonce, and Accept for the type t\n nowadays, the generator creates these 3 different kinds of values, but all mapped to t\n *)\n let open Zkapp_basic in\n Quickcheck.Generator.variant3 Zkapp_precondition.Account.gen\n Account.Nonce.gen Unit.quickcheck_generator\n |> Quickcheck.Generator.map ~f:(function\n | `A precondition ->\n precondition\n | `B n ->\n Zkapp_precondition.Account.nonce n\n | `C () ->\n Zkapp_precondition.Account.accept )\n\n module Tag = struct\n type t = Full | Nonce | Accept [@@deriving equal, compare, sexp, yojson]\n end\n\n let deriver obj = Zkapp_precondition.Account.deriver obj\n\n let digest (t : t) =\n let digest x =\n Random_oracle.(\n hash ~init:Hash_prefix_states.account_update_account_precondition\n (pack_input x))\n in\n t |> Zkapp_precondition.Account.to_input |> digest\n\n module Checked = struct\n type t = Zkapp_precondition.Account.Checked.t\n\n let digest (t : t) =\n let digest x =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix_states.account_update_account_precondition\n (pack_input x))\n in\n Zkapp_precondition.Account.Checked.to_input t |> digest\n\n let nonce (t : t) = t.nonce\n end\n\n let typ () : (Zkapp_precondition.Account.Checked.t, t) Typ.t =\n Zkapp_precondition.Account.typ ()\n\n let nonce ({ nonce; _ } : t) = nonce\nend\n\nmodule Preconditions = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Account_update.Preconditions.V1.t =\n { network : Zkapp_precondition.Protocol_state.Stable.V1.t\n ; account : Account_precondition.Stable.V1.t\n ; valid_while :\n Mina_numbers.Global_slot_since_genesis.Stable.V1.t\n Zkapp_precondition.Numeric.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, hlist, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj\n ~network:!.Zkapp_precondition.Protocol_state.deriver\n ~account:!.Account_precondition.deriver\n ~valid_while:!.Zkapp_precondition.Valid_while.deriver\n |> finish \"Preconditions\" ~t_toplevel_annots\n\n let to_input ({ network; account; valid_while } : t) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Zkapp_precondition.Protocol_state.to_input network\n ; Zkapp_precondition.Account.to_input account\n ; Zkapp_precondition.Valid_while.to_input valid_while\n ]\n\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%map network = Zkapp_precondition.Protocol_state.gen\n and account = Account_precondition.gen\n and valid_while = Zkapp_precondition.Valid_while.gen in\n { network; account; valid_while }\n\n module Checked = struct\n module Type_of_var (V : sig\n type var\n end) =\n struct\n type t = V.var\n end\n\n module Int_as_prover_ref = struct\n type t = int As_prover.Ref.t\n end\n\n type t =\n { network : Zkapp_precondition.Protocol_state.Checked.t\n ; account : Account_precondition.Checked.t\n ; valid_while : Zkapp_precondition.Valid_while.Checked.t\n }\n [@@deriving annot, hlist, fields]\n\n let to_input ({ network; account; valid_while } : t) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Zkapp_precondition.Protocol_state.Checked.to_input network\n ; Zkapp_precondition.Account.Checked.to_input account\n ; Zkapp_precondition.Valid_while.Checked.to_input valid_while\n ]\n end\n\n let typ () : (Checked.t, t) Typ.t =\n Typ.of_hlistable\n [ Zkapp_precondition.Protocol_state.typ\n ; Account_precondition.typ ()\n ; Zkapp_precondition.Valid_while.typ\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let accept =\n { network = Zkapp_precondition.Protocol_state.accept\n ; account = Zkapp_precondition.Account.accept\n ; valid_while = Ignore\n }\nend\n\nmodule Body = struct\n (* Why isn't this derived automatically? *)\n let hash_fold_array f init x = Array.fold ~init ~f x\n\n module Events' = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Pickles.Backend.Tick.Field.Stable.V1.t array list\n [@@deriving sexp, equal, hash, compare, yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Graphql_repr = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { public_key : Public_key.Compressed.Stable.V1.t\n ; token_id : Token_id.Stable.V2.t\n ; update : Update.Stable.V1.t\n ; balance_change :\n (Amount.Stable.V1.t, Sgn.Stable.V1.t) Signed_poly.Stable.V1.t\n ; increment_nonce : bool\n ; events : Events'.Stable.V1.t\n ; actions : Events'.Stable.V1.t\n ; call_data : Pickles.Backend.Tick.Field.Stable.V1.t\n ; call_depth : int\n ; preconditions : Preconditions.Stable.V1.t\n ; use_full_commitment : bool\n ; implicit_account_creation_fee : bool\n ; may_use_token : May_use_token.Stable.V1.t\n ; authorization_kind : Authorization_kind.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~public_key:!.public_key ~update:!.Update.deriver\n ~token_id:!.Token_id.deriver ~balance_change:!.balance_change\n ~increment_nonce:!.bool ~events:!.Events.deriver\n ~actions:!.Actions.deriver ~call_data:!.field\n ~preconditions:!.Preconditions.deriver ~use_full_commitment:!.bool\n ~implicit_account_creation_fee:!.bool\n ~may_use_token:!.May_use_token.deriver ~call_depth:!.int\n ~authorization_kind:!.Authorization_kind.deriver\n |> finish \"AccountUpdateBody\" ~t_toplevel_annots\n\n let dummy : t =\n { public_key = Public_key.Compressed.empty\n ; update = Update.dummy\n ; token_id = Token_id.default\n ; balance_change = Amount.Signed.zero\n ; increment_nonce = false\n ; events = []\n ; actions = []\n ; call_data = Field.zero\n ; call_depth = 0\n ; preconditions = Preconditions.accept\n ; use_full_commitment = false\n ; implicit_account_creation_fee = false\n ; may_use_token = No\n ; authorization_kind = None_given\n }\n end\n\n module Simple = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { public_key : Public_key.Compressed.Stable.V1.t\n ; token_id : Token_id.Stable.V2.t\n ; update : Update.Stable.V1.t\n ; balance_change :\n (Amount.Stable.V1.t, Sgn.Stable.V1.t) Signed_poly.Stable.V1.t\n ; increment_nonce : bool\n ; events : Events'.Stable.V1.t\n ; actions : Events'.Stable.V1.t\n ; call_data : Pickles.Backend.Tick.Field.Stable.V1.t\n ; call_depth : int\n ; preconditions : Preconditions.Stable.V1.t\n ; use_full_commitment : bool\n ; implicit_account_creation_fee : bool\n ; may_use_token : May_use_token.Stable.V1.t\n ; authorization_kind : Authorization_kind.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Account_update.Body.V1.t =\n { public_key : Public_key.Compressed.Stable.V1.t\n ; token_id : Token_id.Stable.V2.t\n ; update : Update.Stable.V1.t\n ; balance_change :\n (Amount.Stable.V1.t, Sgn.Stable.V1.t) Signed_poly.Stable.V1.t\n ; increment_nonce : bool\n ; events : Events'.Stable.V1.t\n ; actions : Events'.Stable.V1.t\n ; call_data : Pickles.Backend.Tick.Field.Stable.V1.t\n ; preconditions : Preconditions.Stable.V1.t\n ; use_full_commitment : bool\n ; implicit_account_creation_fee : bool\n ; may_use_token : May_use_token.Stable.V1.t\n ; authorization_kind : Authorization_kind.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, hlist, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let of_simple (p : Simple.t) : t =\n { public_key = p.public_key\n ; token_id = p.token_id\n ; update = p.update\n ; balance_change = p.balance_change\n ; increment_nonce = p.increment_nonce\n ; events = p.events\n ; actions = p.actions\n ; call_data = p.call_data\n ; preconditions = p.preconditions\n ; use_full_commitment = p.use_full_commitment\n ; implicit_account_creation_fee = p.implicit_account_creation_fee\n ; may_use_token = p.may_use_token\n ; authorization_kind = p.authorization_kind\n }\n\n let of_graphql_repr\n ({ public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; call_depth = _\n ; authorization_kind\n } :\n Graphql_repr.t ) : t =\n { public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n }\n\n let to_graphql_repr\n ({ public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n } :\n t ) ~call_depth : Graphql_repr.t =\n { Graphql_repr.public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; call_depth\n ; authorization_kind\n }\n\n module Fee_payer = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Account_update.Body.Fee_payer.V1.t =\n { public_key : Public_key.Compressed.Stable.V1.t\n ; fee : Fee.Stable.V1.t\n ; valid_until : Global_slot_since_genesis.Stable.V1.t option\n [@name \"validUntil\"]\n ; nonce : Account_nonce.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, hlist, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map public_key = Public_key.Compressed.gen\n and fee = Currency.Fee.gen\n and valid_until =\n Option.quickcheck_generator Global_slot_since_genesis.gen\n and nonce = Account.Nonce.gen in\n { public_key; fee; valid_until; nonce }\n\n let dummy : t =\n { public_key = Public_key.Compressed.empty\n ; fee = Fee.zero\n ; valid_until = None\n ; nonce = Account_nonce.zero\n }\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let fee obj =\n iso_string obj ~name:\"Fee\" ~js_type:UInt64 ~to_string:Fee.to_string\n ~of_string:Fee.of_string\n in\n let ( !. ) ?skip_data = ( !. ) ?skip_data ~t_fields_annots in\n Fields.make_creator obj ~public_key:!.public_key ~fee:!.fee\n ~valid_until:\n !.Fields_derivers_zkapps.Derivers.(\n option ~js_type:Or_undefined @@ global_slot_since_genesis @@ o ())\n ~nonce:!.uint32\n |> finish \"FeePayerBody\" ~t_toplevel_annots\n end\n\n let of_fee_payer (t : Fee_payer.t) : t =\n { public_key = t.public_key\n ; token_id = Token_id.default\n ; update = Update.noop\n ; balance_change =\n { Signed_poly.sgn = Sgn.Neg; magnitude = Amount.of_fee t.fee }\n ; increment_nonce = true\n ; events = []\n ; actions = []\n ; call_data = Field.zero\n ; preconditions =\n { Preconditions.network =\n (let valid_until =\n Option.value ~default:Global_slot_since_genesis.max_value\n t.valid_until\n in\n { Zkapp_precondition.Protocol_state.accept with\n global_slot_since_genesis =\n Check\n { lower = Global_slot_since_genesis.zero\n ; upper = valid_until\n }\n } )\n ; account = Zkapp_precondition.Account.nonce t.nonce\n ; valid_while = Ignore\n }\n ; use_full_commitment = true\n ; implicit_account_creation_fee = true\n ; may_use_token = No\n ; authorization_kind = Signature\n }\n\n let to_simple_fee_payer (t : Fee_payer.t) : Simple.t =\n { public_key = t.public_key\n ; token_id = Token_id.default\n ; update = Update.noop\n ; balance_change =\n { Signed_poly.sgn = Sgn.Neg; magnitude = Amount.of_fee t.fee }\n ; increment_nonce = true\n ; events = []\n ; actions = []\n ; call_data = Field.zero\n ; preconditions =\n { Preconditions.network =\n (let valid_until =\n Option.value ~default:Global_slot_since_genesis.max_value\n t.valid_until\n in\n { Zkapp_precondition.Protocol_state.accept with\n global_slot_since_genesis =\n Check\n { lower = Global_slot_since_genesis.zero\n ; upper = valid_until\n }\n } )\n ; account = Zkapp_precondition.Account.nonce t.nonce\n ; valid_while = Ignore\n }\n ; use_full_commitment = true\n ; implicit_account_creation_fee = true\n ; may_use_token = No\n ; call_depth = 0\n ; authorization_kind = Signature\n }\n\n let to_fee_payer_exn (t : t) : Fee_payer.t =\n let { public_key\n ; token_id = _\n ; update = _\n ; balance_change\n ; increment_nonce = _\n ; events = _\n ; actions = _\n ; call_data = _\n ; preconditions\n ; use_full_commitment = _\n ; may_use_token = _\n ; authorization_kind = _\n } =\n t\n in\n let fee =\n Currency.Fee.of_uint64\n (balance_change.magnitude |> Currency.Amount.to_uint64)\n in\n let nonce =\n if Zkapp_precondition.Account.is_nonce preconditions.account then\n match preconditions.account.nonce with\n | Check { lower; upper = _ } ->\n lower\n | Ignore ->\n failwith \"Unexpected Ignore for fee payer precondition nonce\"\n else failwith \"Expected a nonce for fee payer account precondition\"\n in\n let valid_until =\n match preconditions.network.global_slot_since_genesis with\n | Ignore ->\n None\n | Check { upper; _ } ->\n Some upper\n in\n { public_key; fee; valid_until; nonce }\n\n module Checked = struct\n module Type_of_var (V : sig\n type var\n end) =\n struct\n type t = V.var\n end\n\n module Int_as_prover_ref = struct\n type t = int As_prover.Ref.t\n end\n\n type t =\n { public_key : Public_key.Compressed.var\n ; token_id : Token_id.Checked.t\n ; update : Update.Checked.t\n ; balance_change : Amount.Signed.var\n ; increment_nonce : Boolean.var\n ; events : Events.var\n ; actions : Actions.var\n ; call_data : Field.Var.t\n ; preconditions : Preconditions.Checked.t\n ; use_full_commitment : Boolean.var\n ; implicit_account_creation_fee : Boolean.var\n ; may_use_token : May_use_token.Checked.t\n ; authorization_kind : Authorization_kind.Checked.t\n }\n [@@deriving annot, hlist, fields]\n\n let to_input\n ({ public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n } :\n t ) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Public_key.Compressed.Checked.to_input public_key\n ; Token_id.Checked.to_input token_id\n ; Update.Checked.to_input update\n ; Snark_params.Tick.Run.run_checked\n (Amount.Signed.Checked.to_input balance_change)\n ; Random_oracle_input.Chunked.packed\n ((increment_nonce :> Field.Var.t), 1)\n ; Events.var_to_input events\n ; Actions.var_to_input actions\n ; Random_oracle_input.Chunked.field call_data\n ; Preconditions.Checked.to_input preconditions\n ; Random_oracle_input.Chunked.packed\n ((use_full_commitment :> Field.Var.t), 1)\n ; Random_oracle_input.Chunked.packed\n ((implicit_account_creation_fee :> Field.Var.t), 1)\n ; May_use_token.Checked.to_input may_use_token\n ; Authorization_kind.Checked.to_input authorization_kind\n ]\n\n let digest ?chain (t : t) =\n Random_oracle.Checked.(\n hash ~init:(Hash_prefix.zkapp_body ?chain) (pack_input (to_input t)))\n end\n\n let typ () : (Checked.t, t) Typ.t =\n Typ.of_hlistable\n [ Public_key.Compressed.typ\n ; Token_id.typ\n ; Update.typ ()\n ; Amount.Signed.typ\n ; Boolean.typ\n ; Events.typ\n ; Actions.typ\n ; Field.typ\n ; Preconditions.typ ()\n ; Impl.Boolean.typ\n ; Impl.Boolean.typ\n ; May_use_token.typ\n ; Authorization_kind.typ\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let dummy : t =\n { public_key = Public_key.Compressed.empty\n ; update = Update.dummy\n ; token_id = Token_id.default\n ; balance_change = Amount.Signed.zero\n ; increment_nonce = false\n ; events = []\n ; actions = []\n ; call_data = Field.zero\n ; preconditions = Preconditions.accept\n ; use_full_commitment = false\n ; implicit_account_creation_fee = true\n ; may_use_token = No\n ; authorization_kind = None_given\n }\n\n let to_input\n ({ public_key\n ; update\n ; token_id\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n } :\n t ) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Public_key.Compressed.to_input public_key\n ; Token_id.to_input token_id\n ; Update.to_input update\n ; Amount.Signed.to_input balance_change\n ; Random_oracle_input.Chunked.packed (field_of_bool increment_nonce, 1)\n ; Events.to_input events\n ; Actions.to_input actions\n ; Random_oracle_input.Chunked.field call_data\n ; Preconditions.to_input preconditions\n ; Random_oracle_input.Chunked.packed (field_of_bool use_full_commitment, 1)\n ; Random_oracle_input.Chunked.packed\n (field_of_bool implicit_account_creation_fee, 1)\n ; May_use_token.to_input may_use_token\n ; Authorization_kind.to_input authorization_kind\n ]\n\n let digest ?chain (t : t) =\n Random_oracle.(\n hash ~init:(Hash_prefix.zkapp_body ?chain) (pack_input (to_input t)))\n\n module Digested = struct\n type t = Random_oracle.Digest.t\n\n module Checked = struct\n type t = Random_oracle.Checked.Digest.t\n end\n end\n\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%map public_key = Public_key.Compressed.gen\n and token_id = Token_id.gen\n and update = Update.gen ()\n and balance_change = Currency.Amount.Signed.gen\n and increment_nonce = Quickcheck.Generator.bool\n and events = return []\n and actions = return []\n and call_data = Field.gen\n and preconditions = Preconditions.gen\n and use_full_commitment = Quickcheck.Generator.bool\n and implicit_account_creation_fee = Quickcheck.Generator.bool\n and may_use_token = May_use_token.gen\n and authorization_kind = Authorization_kind.gen in\n { public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n }\n\n let gen_with_events_and_actions =\n let open Quickcheck.Generator.Let_syntax in\n let%map public_key = Public_key.Compressed.gen\n and token_id = Token_id.gen\n and update = Update.gen ()\n and balance_change = Currency.Amount.Signed.gen\n and increment_nonce = Quickcheck.Generator.bool\n and events = return [ [| Field.zero |]; [| Field.zero |] ]\n and actions = return [ [| Field.zero |]; [| Field.zero |] ]\n and call_data = Field.gen\n and preconditions = Preconditions.gen\n and use_full_commitment = Quickcheck.Generator.bool\n and implicit_account_creation_fee = Quickcheck.Generator.bool\n and may_use_token = May_use_token.gen\n and authorization_kind = Authorization_kind.gen in\n { public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n }\nend\n\nmodule T = struct\n module Graphql_repr = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n (** An account update in a zkApp transaction *)\n type t =\n { body : Body.Graphql_repr.Stable.V1.t\n ; authorization : Control.Stable.V2.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj\n ~body:!.Body.Graphql_repr.deriver\n ~authorization:!.Control.deriver\n |> finish \"ZkappAccountUpdate\" ~t_toplevel_annots\n end\n\n module Simple = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { body : Body.Simple.Stable.V1.t\n ; authorization : Control.Stable.V2.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n (** A account_update to a zkApp transaction *)\n type t = Mina_wire_types.Mina_base.Account_update.V1.t =\n { body : Body.Stable.V1.t; authorization : Control.Stable.V2.t }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let of_graphql_repr ({ body; authorization } : Graphql_repr.t) : t =\n { authorization; body = Body.of_graphql_repr body }\n\n let to_graphql_repr ({ body; authorization } : t) ~call_depth : Graphql_repr.t\n =\n { authorization; body = Body.to_graphql_repr ~call_depth body }\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map body = Body.gen and authorization = Control.gen_with_dummies in\n { body; authorization }\n\n let gen_with_events_and_actions : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map body = Body.gen_with_events_and_actions\n and authorization = Control.gen_with_dummies in\n { body; authorization }\n\n let quickcheck_generator : t Quickcheck.Generator.t = gen\n\n let quickcheck_observer : t Quickcheck.Observer.t =\n Quickcheck.Observer.of_hash (module Stable.Latest)\n\n let quickcheck_shrinker : t Quickcheck.Shrinker.t =\n Quickcheck.Shrinker.empty ()\n\n let of_simple (p : Simple.t) : t =\n { body = Body.of_simple p.body; authorization = p.authorization }\n\n let digest ?chain (t : t) = Body.digest ?chain t.body\n\n module Checked = struct\n type t = Body.Checked.t\n\n let digest ?chain (t : t) = Body.Checked.digest ?chain t\n end\nend\n\nmodule Fee_payer = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Account_update.Fee_payer.V1.t =\n { body : Body.Fee_payer.Stable.V1.t\n ; authorization : Signature.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%map body = Body.Fee_payer.gen in\n let authorization = Signature.dummy in\n { body; authorization }\n\n let quickcheck_generator : t Quickcheck.Generator.t = gen\n\n let quickcheck_observer : t Quickcheck.Observer.t =\n Quickcheck.Observer.of_hash (module Stable.Latest)\n\n let quickcheck_shrinker : t Quickcheck.Shrinker.t =\n Quickcheck.Shrinker.empty ()\n\n let account_id (t : t) : Account_id.t =\n Account_id.create t.body.public_key Token_id.default\n\n let to_account_update (t : t) : T.t =\n { authorization = Control.Signature t.authorization\n ; body = Body.of_fee_payer t.body\n }\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~body:!.Body.Fee_payer.deriver\n ~authorization:!.Control.signature_deriver\n |> finish \"ZkappFeePayer\" ~t_toplevel_annots\nend\n\ninclude T\n\nlet account_id (t : t) : Account_id.t =\n Account_id.create t.body.public_key t.body.token_id\n\nlet verification_key_update_to_option (t : t) :\n Verification_key_wire.t option Zkapp_basic.Set_or_keep.t =\n Zkapp_basic.Set_or_keep.map ~f:Option.some t.body.update.verification_key\n\nlet of_fee_payer ({ body; authorization } : Fee_payer.t) : t =\n { authorization = Signature authorization; body = Body.of_fee_payer body }\n\n(** The change in balance to apply to the target account of this account_update.\n When this is negative, the amount will be withdrawn from the account and\n made available to later zkapp_command in the same transaction.\n When this is positive, the amount will be deposited into the account from\n the funds made available by previous zkapp_command in the same transaction.\n*)\nlet balance_change (t : t) : Amount.Signed.t = t.body.balance_change\n\nlet protocol_state_precondition (t : t) : Zkapp_precondition.Protocol_state.t =\n t.body.preconditions.network\n\nlet valid_while_precondition (t : t) :\n Mina_numbers.Global_slot_since_genesis.t Zkapp_precondition.Numeric.t =\n t.body.preconditions.valid_while\n\nlet public_key (t : t) : Public_key.Compressed.t = t.body.public_key\n\nlet token_id (t : t) : Token_id.t = t.body.token_id\n\nlet use_full_commitment (t : t) : bool = t.body.use_full_commitment\n\nlet implicit_account_creation_fee (t : t) : bool =\n t.body.implicit_account_creation_fee\n\nlet increment_nonce (t : t) : bool = t.body.increment_nonce\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type ('a, 'field) t =\n ('a, 'field) Mina_wire_types.Mina_base.With_stack_hash.V1.t =\n { elt : 'a; stack_hash : 'field }\n [@@deriving sexp, compare, equal, hash, yojson, fields, quickcheck]\n end\nend]\n\nlet map t ~f = { t with elt = f t.elt }\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'a t = 'a Mina_wire_types.Mina_base.With_status.V2.t =\n { data : 'a; status : Transaction_status.Stable.V2.t }\n [@@deriving sexp, yojson, equal, compare, fields]\n\n let to_latest data_latest (t : _ t) =\n { data = data_latest t.data; status = t.status }\n end\nend]\n\nlet map ~f { data; status } = { data = f data; status }\n\nlet map_opt ~f { data; status } =\n Option.map (f data) ~f:(fun data -> { data; status })\n\nlet map_result ~f { data; status } =\n Result.map (f data) ~f:(fun data -> { data; status })\n","open Core_kernel\nopen Signature_lib\n\nmodule Call_forest = struct\n let empty = Outside_hash_image.t\n\n module Tree = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('account_update, 'account_update_digest, 'digest) t =\n ( 'account_update\n , 'account_update_digest\n , 'digest )\n Mina_wire_types.Mina_base.Zkapp_command.Call_forest.Tree.V1.t =\n { account_update : 'account_update\n ; account_update_digest : 'account_update_digest\n ; calls :\n ( ('account_update, 'account_update_digest, 'digest) t\n , 'digest )\n With_stack_hash.Stable.V1.t\n list\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let rec fold_forest (ts : (_ t, _) With_stack_hash.t list) ~f ~init =\n List.fold ts ~init ~f:(fun acc { elt; stack_hash = _ } ->\n fold elt ~init:acc ~f )\n\n and fold { account_update; calls; account_update_digest = _ } ~f ~init =\n fold_forest calls ~f ~init:(f init account_update)\n\n let rec fold_forest2_exn (ts1 : (_ t, _) With_stack_hash.t list)\n (ts2 : (_ t, _) With_stack_hash.t list) ~f ~init =\n List.fold2_exn ts1 ts2 ~init\n ~f:(fun\n acc\n { elt = elt1; stack_hash = _ }\n { elt = elt2; stack_hash = _ }\n -> fold2_exn elt1 elt2 ~init:acc ~f )\n\n and fold2_exn\n { account_update = account_update1\n ; calls = calls1\n ; account_update_digest = _\n }\n { account_update = account_update2\n ; calls = calls2\n ; account_update_digest = _\n } ~f ~init =\n fold_forest2_exn calls1 calls2 ~f\n ~init:(f init account_update1 account_update2)\n\n let iter_forest2_exn ts1 ts2 ~f =\n fold_forest2_exn ts1 ts2 ~init:() ~f:(fun () p1 p2 -> f p1 p2)\n\n let iter2_exn ts1 ts2 ~f =\n fold2_exn ts1 ts2 ~init:() ~f:(fun () p1 p2 -> f p1 p2)\n\n let rec mapi_with_trees' ~i (t : _ t) ~f =\n let account_update = f i t.account_update t in\n let l, calls = mapi_forest_with_trees' ~i:(i + 1) t.calls ~f in\n ( l\n , { calls\n ; account_update\n ; account_update_digest = t.account_update_digest\n } )\n\n and mapi_forest_with_trees' ~i x ~f =\n let rec go i acc = function\n | [] ->\n (i, List.rev acc)\n | t :: ts ->\n let l, elt' = mapi_with_trees' ~i ~f (With_stack_hash.elt t) in\n go l (With_stack_hash.map t ~f:(fun _ -> elt') :: acc) ts\n in\n go i [] x\n\n let mapi_with_trees t ~f = mapi_with_trees' ~i:0 t ~f |> snd\n\n let mapi_forest_with_trees t ~f = mapi_forest_with_trees' ~i:0 t ~f |> snd\n\n let mapi' ~i t ~f =\n mapi_with_trees' ~i t ~f:(fun i account_update _ -> f i account_update)\n\n let mapi_forest' ~i t ~f =\n mapi_forest_with_trees' ~i t ~f:(fun i account_update _ ->\n f i account_update )\n\n let rec deferred_mapi_with_trees' ~i (t : _ t) ~f =\n let open Async_kernel.Deferred.Let_syntax in\n let%bind l, calls =\n deferred_mapi_forest_with_trees' ~i:(i + 1) t.calls ~f\n in\n let%map account_update = f i t.account_update t in\n ( l\n , { calls\n ; account_update\n ; account_update_digest = t.account_update_digest\n } )\n\n and deferred_mapi_forest_with_trees' ~i x ~f =\n let open Async_kernel.Deferred.Let_syntax in\n let rec go i acc = function\n | [] ->\n return (i, List.rev acc)\n | t :: ts ->\n let%bind l, elt' =\n deferred_mapi_with_trees' ~i ~f (With_stack_hash.elt t)\n in\n go l (With_stack_hash.map t ~f:(fun _ -> elt') :: acc) ts\n in\n go i [] x\n\n let map_forest ~f t = mapi_forest' ~i:0 ~f:(fun _ x -> f x) t |> snd\n\n let mapi_forest ~f t = mapi_forest' ~i:0 ~f t |> snd\n\n let deferred_map_forest ~f t =\n let open Async_kernel.Deferred in\n deferred_mapi_forest_with_trees' ~i:0 ~f:(fun _ x -> f x) t >>| snd\n\n let deferred_mapi_forest ~f t =\n let open Async_kernel.Deferred in\n deferred_mapi_forest_with_trees' ~i:0 ~f t >>| snd\n\n let hash { account_update = _; calls; account_update_digest } =\n let stack_hash =\n match calls with [] -> empty | e :: _ -> e.stack_hash\n in\n Random_oracle.hash ~init:Hash_prefix_states.account_update_node\n [| account_update_digest; stack_hash |]\n end\n\n type ('a, 'b, 'c) tree = ('a, 'b, 'c) Tree.t\n\n module type Digest_intf = sig\n module Account_update : sig\n include Digest_intf.S\n\n module Checked : sig\n include Digest_intf.S_checked\n\n val create :\n ?chain:Mina_signature_kind.t -> Account_update.Checked.t -> t\n\n val create_body :\n ?chain:Mina_signature_kind.t -> Account_update.Body.Checked.t -> t\n end\n\n include Digest_intf.S_aux with type t := t and type checked := Checked.t\n\n val create : ?chain:Mina_signature_kind.t -> Account_update.t -> t\n\n val create_body :\n ?chain:Mina_signature_kind.t -> Account_update.Body.t -> t\n end\n\n module rec Forest : sig\n include Digest_intf.S\n\n module Checked : sig\n include Digest_intf.S_checked\n\n val empty : t\n\n val cons : Tree.Checked.t -> t -> t\n end\n\n include Digest_intf.S_aux with type t := t and type checked := Checked.t\n\n val empty : t\n\n val cons : Tree.t -> Forest.t -> Forest.t\n end\n\n and Tree : sig\n include Digest_intf.S\n\n module Checked : sig\n include Digest_intf.S_checked\n\n val create :\n account_update:Account_update.Checked.t\n -> calls:Forest.Checked.t\n -> Tree.Checked.t\n end\n\n include Digest_intf.S_aux with type t := t and type checked := Checked.t\n\n val create : (_, Account_update.t, Forest.t) tree -> Tree.t\n end\n end\n\n module Make_digest_sig\n (T : Mina_wire_types.Mina_base.Zkapp_command.Digest_types.S) =\n struct\n module type S =\n Digest_intf\n with type Account_update.Stable.V1.t = T.Account_update.V1.t\n and type Forest.Stable.V1.t = T.Forest.V1.t\n end\n\n module Make_digest_str\n (T : Mina_wire_types.Mina_base.Zkapp_command.Digest_concrete) :\n Make_digest_sig(T).S = struct\n module M = struct\n open Pickles.Impls.Step.Field\n module Checked = Pickles.Impls.Step.Field\n\n let typ = typ\n\n let constant = constant\n end\n\n module Account_update = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Kimchi_backend.Pasta.Basic.Fp.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include M\n\n module Checked = struct\n include Checked\n\n let create = Account_update.Checked.digest\n\n let create_body = Account_update.Body.Checked.digest\n end\n\n let create : ?chain:Mina_signature_kind.t -> Account_update.t -> t =\n Account_update.digest\n\n let create_body :\n ?chain:Mina_signature_kind.t -> Account_update.Body.t -> t =\n Account_update.Body.digest\n end\n\n module Forest = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Kimchi_backend.Pasta.Basic.Fp.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include M\n\n module Checked = struct\n include Checked\n\n let empty = constant empty\n\n let cons hash h_tl =\n Random_oracle.Checked.hash\n ~init:Hash_prefix_states.account_update_cons [| hash; h_tl |]\n end\n\n let empty = empty\n\n let cons hash h_tl =\n Random_oracle.hash ~init:Hash_prefix_states.account_update_cons\n [| hash; h_tl |]\n end\n\n module Tree = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Kimchi_backend.Pasta.Basic.Fp.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include M\n\n module Checked = struct\n include Checked\n\n let create ~(account_update : Account_update.Checked.t)\n ~(calls : Forest.Checked.t) =\n Random_oracle.Checked.hash\n ~init:Hash_prefix_states.account_update_node\n [| (account_update :> t); (calls :> t) |]\n end\n\n let create ({ account_update = _; calls; account_update_digest } : _ tree)\n =\n let stack_hash =\n match calls with [] -> empty | e :: _ -> e.stack_hash\n in\n Random_oracle.hash ~init:Hash_prefix_states.account_update_node\n [| account_update_digest; stack_hash |]\n end\n end\n\n module Digest =\n Mina_wire_types.Mina_base.Zkapp_command.Digest_make\n (Make_digest_sig)\n (Make_digest_str)\n\n let fold = Tree.fold_forest\n\n let iteri t ~(f : int -> 'a -> unit) : unit =\n let (_ : int) = fold t ~init:0 ~f:(fun acc x -> f acc x ; acc + 1) in\n ()\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('account_update, 'account_update_digest, 'digest) t =\n ( ('account_update, 'account_update_digest, 'digest) Tree.Stable.V1.t\n , 'digest )\n With_stack_hash.Stable.V1.t\n list\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n module Shape = struct\n module I = struct\n type t = int\n\n let quickcheck_shrinker = Quickcheck.Shrinker.empty ()\n\n let quickcheck_generator = [%quickcheck.generator: int]\n\n let quickcheck_observer = [%quickcheck.observer: int]\n end\n\n type t = Node of (I.t * t) list [@@deriving quickcheck]\n end\n\n let rec shape (t : _ t) : Shape.t =\n Node (List.mapi t ~f:(fun i { elt; stack_hash = _ } -> (i, shape elt.calls)))\n\n let match_up (type a b) (xs : a list) (ys : (int * b) list) : (a * b) list =\n let rec go i_curr xs ys =\n match (xs, ys) with\n | [], [] ->\n []\n | x :: xs', (i, y) :: ys' ->\n if i_curr = i then (x, y) :: go (i_curr + 1) xs' ys'\n else if i_curr < i then go (i_curr + 1) xs' ys'\n else assert false\n | [], _ :: _ ->\n assert false\n | _ :: _, [] ->\n []\n in\n go 0 xs ys\n\n let rec mask (t : ('p, 'h1, unit) t) (Node shape : Shape.t) :\n ('p, 'h1, unit) t =\n List.map (match_up t shape)\n ~f:(fun ({ With_stack_hash.elt = t_sub; stack_hash = () }, shape_sub) ->\n { With_stack_hash.elt =\n { t_sub with calls = mask t_sub.calls shape_sub }\n ; stack_hash = ()\n } )\n\n let rec of_account_updates_map ~(f : 'p1 -> 'p2)\n ~(account_update_depth : 'p1 -> int) (account_updates : 'p1 list) :\n ('p2, unit, unit) t =\n match account_updates with\n | [] ->\n []\n | p :: ps ->\n let depth = account_update_depth p in\n let children, siblings =\n List.split_while ps ~f:(fun p' -> account_update_depth p' > depth)\n in\n { With_stack_hash.elt =\n { Tree.account_update = f p\n ; account_update_digest = ()\n ; calls = of_account_updates_map ~f ~account_update_depth children\n }\n ; stack_hash = ()\n }\n :: of_account_updates_map ~f ~account_update_depth siblings\n\n let of_account_updates ~account_update_depth account_updates =\n of_account_updates_map ~f:Fn.id ~account_update_depth account_updates\n\n let to_account_updates_map ~f (xs : _ t) =\n let rec collect depth (xs : _ t) acc =\n match xs with\n | [] ->\n acc\n | { elt = { account_update; calls; account_update_digest = _ }\n ; stack_hash = _\n }\n :: xs ->\n f ~depth account_update :: acc\n |> collect (depth + 1) calls\n |> collect depth xs\n in\n List.rev (collect 0 xs [])\n\n let to_account_updates xs =\n to_account_updates_map ~f:(fun ~depth:_ account_update -> account_update) xs\n\n let hd_account_update (xs : _ t) =\n match xs with\n | [] ->\n None\n | { elt = { account_update; calls = _; account_update_digest = _ }\n ; stack_hash = _\n }\n :: _ ->\n Some account_update\n\n let map = Tree.map_forest\n\n let mapi = Tree.mapi_forest\n\n let mapi_with_trees = Tree.mapi_forest_with_trees\n\n let deferred_mapi = Tree.deferred_mapi_forest\n\n let to_zkapp_command_with_hashes_list (xs : _ t) =\n let rec collect (xs : _ t) acc =\n match xs with\n | [] ->\n acc\n | { elt = { account_update; calls; account_update_digest = _ }\n ; stack_hash\n }\n :: xs ->\n (account_update, stack_hash) :: acc |> collect calls |> collect xs\n in\n List.rev (collect xs [])\n\n let hash_cons hash h_tl =\n Random_oracle.hash ~init:Hash_prefix_states.account_update_cons\n [| hash; h_tl |]\n\n let hash = function\n | [] ->\n Digest.Forest.empty\n | x :: _ ->\n With_stack_hash.stack_hash x\n\n let cons_tree tree (forest : _ t) : _ t =\n { elt = tree\n ; stack_hash = Digest.Forest.cons (Digest.Tree.create tree) (hash forest)\n }\n :: forest\n\n let cons_aux (type p) ~(digest_account_update : p -> _) ?(calls = [])\n (account_update : p) (xs : _ t) : _ t =\n let account_update_digest = digest_account_update account_update in\n let tree : _ Tree.t = { account_update; account_update_digest; calls } in\n cons_tree tree xs\n\n let cons ?calls (account_update : Account_update.t) xs =\n cons_aux ~digest_account_update:Digest.Account_update.create ?calls\n account_update xs\n\n let rec accumulate_hashes ~hash_account_update (xs : _ t) =\n let go = accumulate_hashes ~hash_account_update in\n match xs with\n | [] ->\n []\n | { elt = { account_update; calls; account_update_digest = _ }\n ; stack_hash = _\n }\n :: xs ->\n let calls = go calls in\n let xs = go xs in\n let node =\n { Tree.account_update\n ; calls\n ; account_update_digest = hash_account_update account_update\n }\n in\n let node_hash = Digest.Tree.create node in\n { elt = node; stack_hash = Digest.Forest.cons node_hash (hash xs) }\n :: xs\n\n let accumulate_hashes' (type a b) (xs : (Account_update.t, a, b) t) :\n (Account_update.t, Digest.Account_update.t, Digest.Forest.t) t =\n let hash_account_update (p : Account_update.t) =\n Digest.Account_update.create p\n in\n accumulate_hashes ~hash_account_update xs\n\n let accumulate_hashes_predicated xs =\n accumulate_hashes ~hash_account_update:Digest.Account_update.create xs\n\n module With_hashes_and_data = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'data t =\n ( Account_update.Stable.V1.t * 'data\n , Digest.Account_update.Stable.V1.t\n , Digest.Forest.Stable.V1.t )\n Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let empty = Digest.Forest.empty\n\n let hash_account_update ((p : Account_update.t), _) =\n Digest.Account_update.create p\n\n let accumulate_hashes xs : _ t = accumulate_hashes ~hash_account_update xs\n\n let of_zkapp_command_simple_list (xs : (Account_update.Simple.t * 'a) list)\n : _ t =\n of_account_updates xs\n ~account_update_depth:(fun ((p : Account_update.Simple.t), _) ->\n p.body.call_depth )\n |> map ~f:(fun (p, x) -> (Account_update.of_simple p, x))\n |> accumulate_hashes\n\n let of_account_updates (xs : (Account_update.Graphql_repr.t * 'a) list) :\n _ t =\n of_account_updates_map\n ~account_update_depth:(fun ((p : Account_update.Graphql_repr.t), _) ->\n p.body.call_depth )\n ~f:(fun (p, x) -> (Account_update.of_graphql_repr p, x))\n xs\n |> accumulate_hashes\n\n let to_account_updates (x : _ t) = to_account_updates x\n\n let to_zkapp_command_with_hashes_list (x : _ t) =\n to_zkapp_command_with_hashes_list x\n\n let account_updates_hash' xs = of_account_updates xs |> hash\n\n let account_updates_hash xs =\n List.map ~f:(fun x -> (x, ())) xs |> account_updates_hash'\n end\n\n module With_hashes = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( Account_update.Stable.V1.t\n , Digest.Account_update.Stable.V1.t\n , Digest.Forest.Stable.V1.t )\n Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let empty = Digest.Forest.empty\n\n let hash_account_update (p : Account_update.t) =\n Digest.Account_update.create p\n\n let accumulate_hashes xs : t = accumulate_hashes ~hash_account_update xs\n\n let of_zkapp_command_simple_list (xs : Account_update.Simple.t list) : t =\n of_account_updates xs\n ~account_update_depth:(fun (p : Account_update.Simple.t) ->\n p.body.call_depth )\n |> map ~f:Account_update.of_simple\n |> accumulate_hashes\n\n let of_account_updates (xs : Account_update.Graphql_repr.t list) : t =\n of_account_updates_map\n ~account_update_depth:(fun (p : Account_update.Graphql_repr.t) ->\n p.body.call_depth )\n ~f:(fun p -> Account_update.of_graphql_repr p)\n xs\n |> accumulate_hashes\n\n let to_account_updates (x : t) = to_account_updates x\n\n let to_zkapp_command_with_hashes_list (x : t) =\n to_zkapp_command_with_hashes_list x\n\n let account_updates_hash' xs = of_account_updates xs |> hash\n\n let account_updates_hash xs =\n List.map ~f:(fun x -> x) xs |> account_updates_hash'\n end\n\n let is_empty : _ t -> bool = List.is_empty\n\n let to_list (type p) (t : (p, _, _) t) : p list =\n List.rev @@ fold t ~init:[] ~f:(fun acc p -> p :: acc)\n\n let exists (type p) (t : (p, _, _) t) ~(f : p -> bool) : bool =\n with_return (fun { return } ->\n fold t ~init:() ~f:(fun () p -> if f p then return true else ()) ;\n false )\nend\n\nmodule Graphql_repr = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates : Account_update.Graphql_repr.Stable.V1.t list\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Simple = struct\n (* For easily constructing values *)\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates : Account_update.Simple.Stable.V1.t list\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Digest = Call_forest.Digest\n\nmodule T = struct\n [%%versioned_binable\n module Stable = struct\n [@@@with_top_version_tag]\n\n (* DO NOT DELETE VERSIONS!\n so we can always get transaction hashes from old transaction ids\n the version linter should be checking this\n\n IF YOU CREATE A NEW VERSION:\n update Transaction_hash.hash_of_transaction_id to handle it\n add hash_zkapp_command_vn for that version\n *)\n\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Zkapp_command.V1.t =\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates :\n ( Account_update.Stable.V1.t\n , Digest.Account_update.Stable.V1.t\n , Digest.Forest.Stable.V1.t )\n Call_forest.Stable.V1.t\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving annot, sexp, compare, equal, hash, yojson, fields]\n\n let to_latest = Fn.id\n\n module Wire = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates :\n ( Account_update.Stable.V1.t\n , unit\n , unit )\n Call_forest.Stable.V1.t\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let check (t : t) : unit =\n List.iter t.account_updates ~f:(fun p ->\n assert (\n Account_update.May_use_token.equal\n p.elt.account_update.body.may_use_token No ) )\n\n let of_graphql_repr (t : Graphql_repr.t) : t =\n { fee_payer = t.fee_payer\n ; memo = t.memo\n ; account_updates =\n Call_forest.of_account_updates_map t.account_updates\n ~f:Account_update.of_graphql_repr\n ~account_update_depth:(fun (p : Account_update.Graphql_repr.t)\n -> p.body.call_depth )\n }\n\n let to_graphql_repr (t : t) : Graphql_repr.t =\n { fee_payer = t.fee_payer\n ; memo = t.memo\n ; account_updates =\n t.account_updates\n |> Call_forest.to_account_updates_map\n ~f:(fun ~depth account_update ->\n Account_update.to_graphql_repr account_update\n ~call_depth:depth )\n }\n\n let gen =\n let open Quickcheck.Generator in\n let open Let_syntax in\n let gen_call_forest =\n fixed_point (fun self ->\n let%bind calls_length = small_non_negative_int in\n list_with_length calls_length\n (let%map account_update = Account_update.gen\n and calls = self in\n { With_stack_hash.stack_hash = ()\n ; elt =\n { Call_forest.Tree.account_update\n ; account_update_digest = ()\n ; calls\n }\n } ) )\n in\n let open Quickcheck.Let_syntax in\n let%map fee_payer = Account_update.Fee_payer.gen\n and account_updates = gen_call_forest\n and memo = Signed_command_memo.gen in\n { fee_payer; account_updates; memo }\n\n let shrinker : t Quickcheck.Shrinker.t =\n Quickcheck.Shrinker.create (fun t ->\n let shape = Call_forest.shape t.account_updates in\n Sequence.map\n (Quickcheck.Shrinker.shrink\n Call_forest.Shape.quickcheck_shrinker shape )\n ~f:(fun shape' ->\n { t with\n account_updates = Call_forest.mask t.account_updates shape'\n } ) )\n end\n\n let of_wire (w : Wire.t) : t =\n { fee_payer = w.fee_payer\n ; memo = w.memo\n ; account_updates =\n w.account_updates\n |> Call_forest.accumulate_hashes\n ~hash_account_update:(fun (p : Account_update.t) ->\n Digest.Account_update.create p )\n }\n\n let to_wire (t : t) : Wire.t =\n let rec forget_hashes = List.map ~f:forget_hash\n and forget_hash = function\n | { With_stack_hash.stack_hash = _\n ; elt =\n { Call_forest.Tree.account_update\n ; account_update_digest = _\n ; calls\n }\n } ->\n { With_stack_hash.stack_hash = ()\n ; elt =\n { Call_forest.Tree.account_update\n ; account_update_digest = ()\n ; calls = forget_hashes calls\n }\n }\n in\n { fee_payer = t.fee_payer\n ; memo = t.memo\n ; account_updates = forget_hashes t.account_updates\n }\n\n include\n Binable.Of_binable_without_uuid\n (Wire.Stable.V1)\n (struct\n type nonrec t = t\n\n let of_binable t = Wire.check t ; of_wire t\n\n let to_binable = to_wire\n end)\n end\n end]\nend\n\ninclude T\n\n[%%define_locally Stable.Latest.(of_wire, to_wire)]\n\n[%%define_locally Stable.Latest.Wire.(gen)]\n\nlet of_simple (w : Simple.t) : t =\n { fee_payer = w.fee_payer\n ; memo = w.memo\n ; account_updates =\n Call_forest.of_account_updates w.account_updates\n ~account_update_depth:(fun (p : Account_update.Simple.t) ->\n p.body.call_depth )\n |> Call_forest.map ~f:Account_update.of_simple\n |> Call_forest.accumulate_hashes\n ~hash_account_update:(fun (p : Account_update.t) ->\n Digest.Account_update.create p )\n }\n\nlet to_simple (t : t) : Simple.t =\n { fee_payer = t.fee_payer\n ; memo = t.memo\n ; account_updates =\n t.account_updates\n |> Call_forest.to_account_updates_map\n ~f:(fun ~depth { Account_update.body = b; authorization } ->\n { Account_update.Simple.authorization\n ; body =\n { public_key = b.public_key\n ; token_id = b.token_id\n ; update = b.update\n ; balance_change = b.balance_change\n ; increment_nonce = b.increment_nonce\n ; events = b.events\n ; actions = b.actions\n ; call_data = b.call_data\n ; preconditions = b.preconditions\n ; use_full_commitment = b.use_full_commitment\n ; implicit_account_creation_fee =\n b.implicit_account_creation_fee\n ; may_use_token = b.may_use_token\n ; call_depth = depth\n ; authorization_kind = b.authorization_kind\n }\n } )\n }\n\nlet all_account_updates (t : t) : _ Call_forest.t =\n let p = t.fee_payer in\n let body = Account_update.Body.of_fee_payer p.body in\n let fee_payer : Account_update.t =\n let p = t.fee_payer in\n { authorization = Control.Signature p.authorization; body }\n in\n Call_forest.cons fee_payer t.account_updates\n\nlet fee (t : t) : Currency.Fee.t = t.fee_payer.body.fee\n\nlet fee_payer_account_update ({ fee_payer; _ } : t) = fee_payer\n\nlet applicable_at_nonce (t : t) : Account.Nonce.t =\n (fee_payer_account_update t).body.nonce\n\nlet target_nonce_on_success (t : t) : Account.Nonce.t =\n let base_nonce = Account.Nonce.succ (applicable_at_nonce t) in\n let fee_payer_pubkey = t.fee_payer.body.public_key in\n let fee_payer_account_update_increments =\n List.count (Call_forest.to_list t.account_updates) ~f:(fun p ->\n Public_key.Compressed.equal p.body.public_key fee_payer_pubkey\n && p.body.increment_nonce )\n in\n Account.Nonce.add base_nonce\n (Account.Nonce.of_int fee_payer_account_update_increments)\n\nlet nonce_increments (t : t) : int Public_key.Compressed.Map.t =\n let base_increments =\n Public_key.Compressed.Map.of_alist_exn [ (t.fee_payer.body.public_key, 1) ]\n in\n List.fold_left (Call_forest.to_list t.account_updates) ~init:base_increments\n ~f:(fun incr_map account_update ->\n if account_update.body.increment_nonce then\n Map.update incr_map account_update.body.public_key\n ~f:(Option.value_map ~default:1 ~f:(( + ) 1))\n else incr_map )\n\nlet fee_token (_t : t) = Token_id.default\n\nlet fee_payer (t : t) =\n Account_id.create t.fee_payer.body.public_key (fee_token t)\n\nlet extract_vks (t : t) : Verification_key_wire.t List.t =\n account_updates t\n |> Call_forest.fold ~init:[] ~f:(fun acc (p : Account_update.t) ->\n match Account_update.verification_key_update_to_option p with\n | Zkapp_basic.Set_or_keep.Set (Some vk) ->\n vk :: acc\n | _ ->\n acc )\n\nlet account_updates_list (t : t) : Account_update.t list =\n Call_forest.fold t.account_updates ~init:[] ~f:(Fn.flip List.cons) |> List.rev\n\nlet all_account_updates_list (t : t) : Account_update.t list =\n Call_forest.fold t.account_updates\n ~init:[ Account_update.of_fee_payer (fee_payer_account_update t) ]\n ~f:(Fn.flip List.cons)\n |> List.rev\n\nlet fee_excess (t : t) =\n Fee_excess.of_single (fee_token t, Currency.Fee.Signed.of_unsigned (fee t))\n\n(* always `Accessed` for fee payer *)\nlet account_access_statuses (t : t) (status : Transaction_status.t) =\n let init = [ (fee_payer t, `Accessed) ] in\n let status_sym =\n match status with Applied -> `Accessed | Failed _ -> `Not_accessed\n in\n Call_forest.fold t.account_updates ~init ~f:(fun acc p ->\n (Account_update.account_id p, status_sym) :: acc )\n |> List.rev |> List.stable_dedup\n\nlet accounts_referenced (t : t) =\n List.map (account_access_statuses t Applied) ~f:(fun (acct_id, _status) ->\n acct_id )\n\nlet fee_payer_pk (t : t) = t.fee_payer.body.public_key\n\nlet value_if b ~then_ ~else_ = if b then then_ else else_\n\nmodule Virtual = struct\n module Bool = struct\n type t = bool\n\n let true_ = true\n\n let assert_ _ = ()\n\n let equal = Bool.equal\n\n let not = not\n\n let ( || ) = ( || )\n\n let ( && ) = ( && )\n end\n\n module Unit = struct\n type t = unit\n\n let if_ = value_if\n end\n\n module Ledger = Unit\n module Account = Unit\n\n module Amount = struct\n open Currency.Amount\n\n type nonrec t = t\n\n let if_ = value_if\n\n module Signed = Signed\n\n let zero = zero\n\n let ( - ) (x1 : t) (x2 : t) : Signed.t =\n Option.value_exn Signed.(of_unsigned x1 + negate (of_unsigned x2))\n\n let ( + ) (x1 : t) (x2 : t) : t = Option.value_exn (add x1 x2)\n\n let add_signed (x1 : t) (x2 : Signed.t) : t =\n let y = Option.value_exn Signed.(of_unsigned x1 + x2) in\n match y.sgn with Pos -> y.magnitude | Neg -> failwith \"add_signed\"\n end\n\n module Token_id = struct\n include Token_id\n\n let if_ = value_if\n end\n\n module Zkapp_command = struct\n type t = Account_update.t list\n\n let if_ = value_if\n\n type account_update = Account_update.t\n\n let empty = []\n\n let is_empty = List.is_empty\n\n let pop (t : t) = match t with [] -> failwith \"pop\" | p :: t -> (p, t)\n end\nend\n\nlet check_authorization (p : Account_update.t) : unit Or_error.t =\n match (p.authorization, p.body.authorization_kind) with\n | None_given, None_given | Proof _, Proof _ | Signature _, Signature ->\n Ok ()\n | _ ->\n let err =\n let expected =\n Account_update.Authorization_kind.to_control_tag\n p.body.authorization_kind\n in\n let got = Control.tag p.authorization in\n Error.create \"Authorization kind does not match the authorization\"\n [ (\"expected\", expected); (\"got\", got) ]\n [%sexp_of: (string * Control.Tag.t) list]\n in\n Error err\n\nmodule Verifiable : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t = private\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates :\n ( Side_loaded_verification_key.Stable.V2.t\n , Zkapp_basic.F.Stable.V1.t )\n With_hash.Stable.V1.t\n option\n Call_forest.With_hashes_and_data.Stable.V1.t\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n val to_latest : t -> t\n end\n end]\n\n val find_vk_via_ledger :\n ledger:'a\n -> get:('a -> 'b -> Account.t option)\n -> location_of_account:('a -> Account_id.t -> 'b option)\n -> Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t\n\n val create :\n T.t\n -> status:Transaction_status.t\n -> find_vk:\n ( Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t )\n -> t Or_error.t\n\n module Any : sig\n (** creates verifiables from a list of commands that caches verification\n keys and permits _any_ vks that have been seen earlier in the list. *)\n val create_all :\n T.t With_status.t list\n -> find_vk:\n ( Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t )\n -> t With_status.t list Or_error.t\n end\n\n module Last : sig\n (** creates verifiables from a list of commands that caches verification\n keys and permits only the _last_ vk that has been seen earlier in the\n list. *)\n val create_all :\n T.t With_status.t list\n -> find_vk:\n ( Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t )\n -> t With_status.t list Or_error.t\n end\nend = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates :\n ( Side_loaded_verification_key.Stable.V2.t\n , Zkapp_basic.F.Stable.V1.t )\n With_hash.Stable.V1.t\n option\n Call_forest.With_hashes_and_data.Stable.V1.t\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let ok_if_vk_hash_expected ~got ~expected =\n if not @@ Zkapp_basic.F.equal (With_hash.hash got) expected then\n Error\n (Error.create \"Expected vk hash doesn't match hash in vk we received\"\n [ (\"expected_vk_hash\", expected)\n ; (\"got_vk_hash\", With_hash.hash got)\n ]\n [%sexp_of: (string * Zkapp_basic.F.t) list] )\n else Ok got\n\n let find_vk_via_ledger ~ledger ~get ~location_of_account expected_vk_hash\n account_id =\n match\n let open Option.Let_syntax in\n let%bind location = location_of_account ledger account_id in\n let%bind (account : Account.t) = get ledger location in\n let%bind zkapp = account.zkapp in\n zkapp.verification_key\n with\n | Some vk ->\n ok_if_vk_hash_expected ~got:vk ~expected:expected_vk_hash\n | None ->\n let err =\n Error.create \"No verification key found for proved account update\"\n (\"account_id\", account_id) [%sexp_of: string * Account_id.t]\n in\n Error err\n\n (* Ensures that there's a verification_key available for all account_updates\n * and creates a valid command associating the correct keys with each\n * account_id.\n *\n * If an account_update replaces the verification_key (or deletes it),\n * subsequent account_updates use the replaced key instead of looking in the\n * ledger for the key (ie set by a previous transaction).\n *)\n let create ({ fee_payer; account_updates; memo } : T.t)\n ~(status : Transaction_status.t) ~find_vk : t Or_error.t =\n With_return.with_return (fun { return } ->\n let tbl = Account_id.Table.create () in\n let vks_overridden =\n (* Keep track of the verification keys that have been set so far\n during this transaction.\n *)\n ref Account_id.Map.empty\n in\n let account_updates =\n Call_forest.map account_updates ~f:(fun p ->\n let account_id = Account_update.account_id p in\n let vks_overriden' =\n match Account_update.verification_key_update_to_option p with\n | Zkapp_basic.Set_or_keep.Set vk_next ->\n Account_id.Map.set !vks_overridden ~key:account_id\n ~data:vk_next\n | Zkapp_basic.Set_or_keep.Keep ->\n !vks_overridden\n in\n let () =\n match check_authorization p with\n | Ok () ->\n ()\n | Error _ as err ->\n return err\n in\n match\n ( p.body.authorization_kind\n , phys_equal status Transaction_status.Applied )\n with\n | Proof vk_hash, true -> (\n let prioritized_vk =\n (* only lookup _past_ vk setting, ie exclude the new one we\n * potentially set in this account_update (use the non-'\n * vks_overrided) . *)\n match Account_id.Map.find !vks_overridden account_id with\n | Some (Some vk) -> (\n match\n ok_if_vk_hash_expected ~got:vk ~expected:vk_hash\n with\n | Ok vk ->\n Some vk\n | Error err ->\n return (Error err) )\n | Some None ->\n (* we explicitly have erased the key *)\n let err =\n Error.create\n \"No verification key found for proved account \\\n update: the verification key was removed by a \\\n previous account update\"\n (\"account_id\", account_id)\n [%sexp_of: string * Account_id.t]\n in\n return (Error err)\n | None -> (\n (* we haven't set anything; lookup the vk in the fallback *)\n match find_vk vk_hash account_id with\n | Error e ->\n return (Error e)\n | Ok vk ->\n Some vk )\n in\n match prioritized_vk with\n | Some prioritized_vk ->\n Account_id.Table.update tbl account_id ~f:(fun _ ->\n With_hash.hash prioritized_vk ) ;\n (* return the updated overrides *)\n vks_overridden := vks_overriden' ;\n (p, Some prioritized_vk)\n | None ->\n (* The transaction failed, so we allow the vk to be missing. *)\n (p, None) )\n | _ ->\n vks_overridden := vks_overriden' ;\n (p, None) )\n in\n Ok { fee_payer; account_updates; memo } )\n\n module Map_cache = struct\n type 'a t = 'a Zkapp_basic.F_map.Map.t\n\n let empty = Zkapp_basic.F_map.Map.empty\n\n let find = Zkapp_basic.F_map.Map.find\n\n let set = Zkapp_basic.F_map.Map.set\n end\n\n module Singleton_cache = struct\n type 'a t = (Zkapp_basic.F.t * 'a) option\n\n let empty = None\n\n let find t key =\n match t with\n | None ->\n None\n | Some (k, v) ->\n if Zkapp_basic.F.equal key k then Some v else None\n\n let set _ ~key ~data = Some (key, data)\n end\n\n module Make_create_all (Cache : sig\n type 'a t\n\n val empty : 'a t\n\n val find : 'a t -> Zkapp_basic.F.t -> 'a option\n\n val set : 'a t -> key:Zkapp_basic.F.t -> data:'a -> 'a t\n end) =\n struct\n let create_all (cmds : T.t With_status.t list)\n ~(find_vk :\n Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t ) :\n t With_status.t list Or_error.t =\n Or_error.try_with (fun () ->\n snd (* remove the helper cache we folded with *)\n (List.fold_map cmds ~init:Cache.empty\n ~f:(fun\n (running_cache : Verification_key_wire.t Cache.t)\n { data = cmd; status }\n ->\n let verified_cmd : t =\n create cmd ~status ~find_vk:(fun vk_hash account_id ->\n (* first we check if there's anything in the running\n cache within this chunk so far *)\n match Cache.find running_cache vk_hash with\n | None ->\n (* before falling back to the find_vk *)\n find_vk vk_hash account_id\n | Some vk ->\n Ok vk )\n |> Or_error.ok_exn\n in\n let running_cache' =\n List.fold (extract_vks cmd) ~init:running_cache\n ~f:(fun acc vk ->\n Cache.set acc ~key:(With_hash.hash vk) ~data:vk )\n in\n (running_cache', { With_status.data = verified_cmd; status }) )\n ) )\n end\n\n module Any = struct\n include Make_create_all (Map_cache)\n end\n\n module Last = struct\n include Make_create_all (Singleton_cache)\n end\nend\n\nlet of_verifiable (t : Verifiable.t) : t =\n { fee_payer = t.fee_payer\n ; account_updates = Call_forest.map t.account_updates ~f:fst\n ; memo = t.memo\n }\n\nmodule Transaction_commitment = struct\n module Stable = Kimchi_backend.Pasta.Basic.Fp.Stable\n\n type t = (Stable.Latest.t[@deriving sexp])\n\n let sexp_of_t = Stable.Latest.sexp_of_t\n\n let t_of_sexp = Stable.Latest.t_of_sexp\n\n let empty = Outside_hash_image.t\n\n let typ = Snark_params.Tick.Field.typ\n\n let create ~(account_updates_hash : Digest.Forest.t) : t =\n (account_updates_hash :> t)\n\n let create_complete (t : t) ~memo_hash\n ~(fee_payer_hash : Digest.Account_update.t) =\n Random_oracle.hash ~init:Hash_prefix.account_update_cons\n [| memo_hash; (fee_payer_hash :> t); t |]\n\n module Checked = struct\n type t = Pickles.Impls.Step.Field.t\n\n let create ~(account_updates_hash : Digest.Forest.Checked.t) =\n (account_updates_hash :> t)\n\n let create_complete (t : t) ~memo_hash\n ~(fee_payer_hash : Digest.Account_update.Checked.t) =\n Random_oracle.Checked.hash ~init:Hash_prefix.account_update_cons\n [| memo_hash; (fee_payer_hash :> t); t |]\n end\nend\n\nlet account_updates_hash (t : t) = Call_forest.hash t.account_updates\n\nlet commitment (t : t) : Transaction_commitment.t =\n Transaction_commitment.create ~account_updates_hash:(account_updates_hash t)\n\n(** This module defines weights for each component of a `Zkapp_command.t` element. *)\nmodule Weight = struct\n let account_update : Account_update.t -> int = fun _ -> 1\n\n let fee_payer (_fp : Account_update.Fee_payer.t) : int = 1\n\n let account_updates : (Account_update.t, _, _) Call_forest.t -> int =\n Call_forest.fold ~init:0 ~f:(fun acc p -> acc + account_update p)\n\n let memo : Signed_command_memo.t -> int = fun _ -> 0\nend\n\nlet weight (zkapp_command : t) : int =\n let { fee_payer; account_updates; memo } = zkapp_command in\n List.sum\n (module Int)\n ~f:Fn.id\n [ Weight.fee_payer fee_payer\n ; Weight.account_updates account_updates\n ; Weight.memo memo\n ]\n\nmodule type Valid_intf = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t = private { zkapp_command : T.Stable.V1.t }\n [@@deriving sexp, compare, equal, hash, yojson]\n end\n end]\n\n val to_valid_unsafe :\n T.t -> [> `If_this_is_used_it_should_have_a_comment_justifying_it of t ]\n\n val to_valid :\n T.t\n -> status:Transaction_status.t\n -> find_vk:\n ( Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t )\n -> t Or_error.t\n\n val of_verifiable : Verifiable.t -> t\n\n val forget : t -> T.t\nend\n\nmodule Valid :\n Valid_intf\n with type Stable.V1.t = Mina_wire_types.Mina_base.Zkapp_command.Valid.V1.t =\nstruct\n module S = Stable\n\n module Verification_key_hash = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Zkapp_basic.F.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Zkapp_command.Valid.V1.t =\n { zkapp_command : S.V1.t }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let create zkapp_command : t = { zkapp_command }\n\n let of_verifiable (t : Verifiable.t) : t = { zkapp_command = of_verifiable t }\n\n let to_valid_unsafe (t : T.t) :\n [> `If_this_is_used_it_should_have_a_comment_justifying_it of t ] =\n `If_this_is_used_it_should_have_a_comment_justifying_it (create t)\n\n let forget (t : t) : T.t = t.zkapp_command\n\n let to_valid (t : T.t) ~status ~find_vk : t Or_error.t =\n Verifiable.create t ~status ~find_vk |> Or_error.map ~f:of_verifiable\nend\n\n[%%define_locally Stable.Latest.(of_yojson, to_yojson)]\n\n(* so transaction ids have a version tag *)\ninclude Codable.Make_base64 (Stable.Latest.With_top_version_tag)\n\ntype account_updates =\n (Account_update.t, Digest.Account_update.t, Digest.Forest.t) Call_forest.t\n\nlet account_updates_deriver obj =\n let of_zkapp_command_with_depth (ps : Account_update.Graphql_repr.t list) :\n account_updates =\n Call_forest.of_account_updates ps\n ~account_update_depth:(fun (p : Account_update.Graphql_repr.t) ->\n p.body.call_depth )\n |> Call_forest.map ~f:Account_update.of_graphql_repr\n |> Call_forest.accumulate_hashes'\n and to_zkapp_command_with_depth (ps : account_updates) :\n Account_update.Graphql_repr.t list =\n ps\n |> Call_forest.to_account_updates_map ~f:(fun ~depth p ->\n Account_update.to_graphql_repr ~call_depth:depth p )\n in\n let open Fields_derivers_zkapps.Derivers in\n let inner = (list @@ Account_update.Graphql_repr.deriver @@ o ()) @@ o () in\n iso ~map:of_zkapp_command_with_depth ~contramap:to_zkapp_command_with_depth\n inner obj\n\nlet deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj\n ~fee_payer:!.Account_update.Fee_payer.deriver\n ~account_updates:!.account_updates_deriver\n ~memo:!.Signed_command_memo.deriver\n |> finish \"ZkappCommand\" ~t_toplevel_annots\n\nlet arg_typ () = Fields_derivers_zkapps.(arg_typ (deriver @@ Derivers.o ()))\n\nlet typ () = Fields_derivers_zkapps.(typ (deriver @@ Derivers.o ()))\n\nlet to_json x = Fields_derivers_zkapps.(to_json (deriver @@ Derivers.o ())) x\n\nlet of_json x = Fields_derivers_zkapps.(of_json (deriver @@ Derivers.o ())) x\n\nlet account_updates_of_json x =\n Fields_derivers_zkapps.(\n of_json\n ((list @@ Account_update.Graphql_repr.deriver @@ o ()) @@ derivers ()))\n x\n\nlet zkapp_command_to_json x =\n Fields_derivers_zkapps.(to_json (deriver @@ derivers ())) x\n\nlet arg_query_string x =\n Fields_derivers_zkapps.Test.Loop.json_to_string_gql @@ to_json x\n\nlet dummy =\n lazy\n (let account_update : Account_update.t =\n { body = Account_update.Body.dummy\n ; authorization = Control.dummy_of_tag Signature\n }\n in\n let fee_payer : Account_update.Fee_payer.t =\n { body = Account_update.Body.Fee_payer.dummy\n ; authorization = Signature.dummy\n }\n in\n { fee_payer\n ; account_updates = Call_forest.cons account_update []\n ; memo = Signed_command_memo.empty\n } )\n\nmodule Make_update_group (Input : sig\n type global_state\n\n type local_state\n\n type spec\n\n type connecting_ledger_hash\n\n val zkapp_segment_of_controls : Control.t list -> spec\nend) : sig\n module Zkapp_command_intermediate_state : sig\n type state = { global : Input.global_state; local : Input.local_state }\n\n type t =\n { kind : [ `Same | `New | `Two_new ]\n ; spec : Input.spec\n ; state_before : state\n ; state_after : state\n ; connecting_ledger : Input.connecting_ledger_hash\n }\n end\n\n val group_by_zkapp_command_rev :\n t list\n -> (Input.global_state * Input.local_state * Input.connecting_ledger_hash)\n list\n list\n -> Zkapp_command_intermediate_state.t list\nend = struct\n open Input\n\n module Zkapp_command_intermediate_state = struct\n type state = { global : global_state; local : local_state }\n\n type t =\n { kind : [ `Same | `New | `Two_new ]\n ; spec : spec\n ; state_before : state\n ; state_after : state\n ; connecting_ledger : connecting_ledger_hash\n }\n end\n\n (** [group_by_zkapp_command_rev zkapp_commands stmtss] identifies before/after pairs of\n statements, corresponding to account updates for each zkapp_command in [zkapp_commands] which minimize the\n number of snark proofs needed to prove all of the zkapp_command.\n\n This function is intended to take multiple zkapp transactions as\n its input, which is then converted to a [Account_update.t list list] using\n [List.map ~f:Zkapp_command.zkapp_command]. The [stmtss] argument should\n be a list of the same length, with 1 more state than the number of\n zkapp_command for each transaction.\n\n For example, two transactions made up of zkapp_command [[p1; p2; p3]] and\n [[p4; p5]] should have the statements [[[s0; s1; s2; s3]; [s3; s4; s5]]],\n where each [s_n] is the state after applying [p_n] on top of [s_{n-1}], and\n where [s0] is the initial state before any of the transactions have been\n applied.\n\n Each pair is also identified with one of [`Same], [`New], or [`Two_new],\n indicating that the next one ([`New]) or next two ([`Two_new]) [Zkapp_command.t]s\n will need to be passed as part of the snark witness while applying that\n pair.\n *)\n let group_by_zkapp_command_rev (zkapp_commands : t list)\n (stmtss : (global_state * local_state * connecting_ledger_hash) list list)\n : Zkapp_command_intermediate_state.t list =\n let intermediate_state ~kind ~spec ~before ~after =\n let global_before, local_before, _ = before in\n let global_after, local_after, connecting_ledger = after in\n { Zkapp_command_intermediate_state.kind\n ; spec\n ; state_before = { global = global_before; local = local_before }\n ; state_after = { global = global_after; local = local_after }\n ; connecting_ledger\n }\n in\n let zkapp_account_updatess =\n []\n :: List.map zkapp_commands ~f:(fun (zkapp_command : t) ->\n all_account_updates_list zkapp_command )\n in\n let rec group_by_zkapp_command_rev\n (zkapp_commands : Account_update.t list list) stmtss acc =\n match (zkapp_commands, stmtss) with\n | ([] | [ [] ]), [ _ ] ->\n (* We've associated statements with all given zkapp_command. *)\n acc\n | [ [ { authorization = a1; _ } ] ], [ [ before; after ] ] ->\n (* There are no later zkapp_command to pair this one with. Prove it on its\n own.\n *)\n intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc\n | [ []; [ { authorization = a1; _ } ] ], [ [ _ ]; [ before; after ] ] ->\n (* This account_update is part of a new transaction, and there are no later\n zkapp_command to pair it with. Prove it on its own.\n *)\n intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc\n | ( ({ authorization = Proof _ as a1; _ } :: zkapp_command)\n :: zkapp_commands\n , (before :: (after :: _ as stmts)) :: stmtss ) ->\n (* This account_update contains a proof, don't pair it with other account updates. *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( []\n :: ({ authorization = Proof _ as a1; _ } :: zkapp_command)\n :: zkapp_commands\n , [ _ ] :: (before :: (after :: _ as stmts)) :: stmtss ) ->\n (* This account_update is part of a new transaction, and contains a proof, don't\n pair it with other account updates.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( ({ authorization = a1; _ }\n :: ({ authorization = Proof _; _ } :: _ as zkapp_command) )\n :: zkapp_commands\n , (before :: (after :: _ as stmts)) :: stmtss ) ->\n (* The next account_update contains a proof, don't pair it with this account_update. *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( ({ authorization = a1; _ } :: ([] as zkapp_command))\n :: (({ authorization = Proof _; _ } :: _) :: _ as zkapp_commands)\n , (before :: (after :: _ as stmts)) :: stmtss ) ->\n (* The next account_update is in the next transaction and contains a proof,\n don't pair it with this account_update.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( ({ authorization = (Signature _ | None_given) as a1; _ }\n :: { authorization = (Signature _ | None_given) as a2; _ }\n :: zkapp_command )\n :: zkapp_commands\n , (before :: _ :: (after :: _ as stmts)) :: stmtss ) ->\n (* The next two zkapp_command do not contain proofs, and are within the same\n transaction. Pair them.\n Ok to get \"use_full_commitment\" of [a1] because neither of them\n contain a proof.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1; a2 ])\n ~before ~after\n :: acc )\n | ( []\n :: ({ authorization = a1; _ }\n :: ({ authorization = Proof _; _ } :: _ as zkapp_command) )\n :: zkapp_commands\n , [ _ ] :: (before :: (after :: _ as stmts)) :: stmtss ) ->\n (* This account_update is in the next transaction, and the next account_update contains a\n proof, don't pair it with this account_update.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( []\n :: ({ authorization = (Signature _ | None_given) as a1; _ }\n :: { authorization = (Signature _ | None_given) as a2; _ }\n :: zkapp_command )\n :: zkapp_commands\n , [ _ ] :: (before :: _ :: (after :: _ as stmts)) :: stmtss ) ->\n (* The next two zkapp_command do not contain proofs, and are within the same\n new transaction. Pair them.\n Ok to get \"use_full_commitment\" of [a1] because neither of them\n contain a proof.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1; a2 ])\n ~before ~after\n :: acc )\n | ( [ { authorization = (Signature _ | None_given) as a1; _ } ]\n :: ({ authorization = (Signature _ | None_given) as a2; _ }\n :: zkapp_command )\n :: zkapp_commands\n , (before :: _after1) :: (_before2 :: (after :: _ as stmts)) :: stmtss )\n ->\n (* The next two zkapp_command do not contain proofs, and the second is within\n a new transaction. Pair them.\n Ok to get \"use_full_commitment\" of [a1] because neither of them\n contain a proof.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1; a2 ])\n ~before ~after\n :: acc )\n | ( []\n :: ({ authorization = a1; _ } :: zkapp_command)\n :: (({ authorization = Proof _; _ } :: _) :: _ as zkapp_commands)\n , [ _ ] :: (before :: ([ after ] as stmts)) :: (_ :: _ as stmtss) ) ->\n (* The next transaction contains a proof, and this account_update is in a new\n transaction, don't pair it with the next account_update.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( []\n :: [ { authorization = (Signature _ | None_given) as a1; _ } ]\n :: ({ authorization = (Signature _ | None_given) as a2; _ }\n :: zkapp_command )\n :: zkapp_commands\n , [ _ ]\n :: [ before; _after1 ]\n :: (_before2 :: (after :: _ as stmts)) :: stmtss ) ->\n (* The next two zkapp_command do not contain proofs, the first is within a\n new transaction, and the second is within another new transaction.\n Pair them.\n Ok to get \"use_full_commitment\" of [a1] because neither of them\n contain a proof.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`Two_new\n ~spec:(zkapp_segment_of_controls [ a1; a2 ])\n ~before ~after\n :: acc )\n | [ [ { authorization = a1; _ } ] ], (before :: after :: _) :: _ ->\n (* This account_update is the final account_update given. Prove it on its own. *)\n intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc\n | ( [] :: [ { authorization = a1; _ } ] :: [] :: _\n , [ _ ] :: (before :: after :: _) :: _ ) ->\n (* This account_update is the final account_update given, in a new transaction. Prove it\n on its own.\n *)\n intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc\n | _, [] ->\n failwith \"group_by_zkapp_command_rev: No statements remaining\"\n | ([] | [ [] ]), _ ->\n failwith \"group_by_zkapp_command_rev: Unmatched statements remaining\"\n | [] :: _, [] :: _ ->\n failwith\n \"group_by_zkapp_command_rev: No final statement for current \\\n transaction\"\n | [] :: _, (_ :: _ :: _) :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Unmatched statements for current \\\n transaction\"\n | [] :: [ _ ] :: _, [ _ ] :: (_ :: _ :: _ :: _) :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Unmatched statements for next \\\n transaction\"\n | [ []; [ _ ] ], [ _ ] :: [ _; _ ] :: _ :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Unmatched statements after next \\\n transaction\"\n | (_ :: _) :: _, ([] | [ _ ]) :: _ | (_ :: _ :: _) :: _, [ _; _ ] :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Too few statements remaining for the \\\n current transaction\"\n | ([] | [ _ ]) :: [] :: _, _ ->\n failwith\n \"group_by_zkapp_command_rev: The next transaction has no \\\n zkapp_command\"\n | [] :: (_ :: _) :: _, _ :: ([] | [ _ ]) :: _\n | [] :: (_ :: _ :: _) :: _, _ :: [ _; _ ] :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Too few statements remaining for the \\\n next transaction\"\n | [ _ ] :: (_ :: _) :: _, _ :: ([] | [ _ ]) :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Too few statements remaining for the \\\n next transaction\"\n | [] :: [ _ ] :: (_ :: _) :: _, _ :: _ :: ([] | [ _ ]) :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Too few statements remaining for the \\\n transaction after next\"\n | ([] | [ _ ]) :: (_ :: _) :: _, [ _ ] ->\n failwith\n \"group_by_zkapp_command_rev: No statements given for the next \\\n transaction\"\n | [] :: [ _ ] :: (_ :: _) :: _, [ _; _ :: _ :: _ ] ->\n failwith\n \"group_by_zkapp_command_rev: No statements given for transaction \\\n after next\"\n in\n group_by_zkapp_command_rev zkapp_account_updatess stmtss []\nend\n\n(*Transaction_snark.Zkapp_command_segment.Basic.t*)\ntype possible_segments = Proved | Signed_single | Signed_pair\n\nmodule Update_group = Make_update_group (struct\n type local_state = unit\n\n type global_state = unit\n\n type connecting_ledger_hash = unit\n\n type spec = possible_segments\n\n let zkapp_segment_of_controls controls : spec =\n match controls with\n | [ Control.Proof _ ] ->\n Proved\n | [ (Control.Signature _ | Control.None_given) ] ->\n Signed_single\n | [ Control.(Signature _ | None_given); Control.(Signature _ | None_given) ]\n ->\n Signed_pair\n | _ ->\n failwith \"zkapp_segment_of_controls: Unsupported combination\"\nend)\n\nlet zkapp_cost ~proof_segments ~signed_single_segments ~signed_pair_segments\n ~(genesis_constants : Genesis_constants.t) () =\n (*10.26*np + 10.08*n2 + 9.14*n1 < 69.45*)\n let proof_cost = genesis_constants.zkapp_proof_update_cost in\n let signed_pair_cost = genesis_constants.zkapp_signed_pair_update_cost in\n let signed_single_cost = genesis_constants.zkapp_signed_single_update_cost in\n Float.(\n (proof_cost * of_int proof_segments)\n + (signed_pair_cost * of_int signed_pair_segments)\n + (signed_single_cost * of_int signed_single_segments))\n\n(* Zkapp_command transactions are filtered using this predicate\n - when adding to the transaction pool\n - in incoming blocks\n*)\nlet valid_size ~(genesis_constants : Genesis_constants.t) (t : t) :\n unit Or_error.t =\n let events_elements events =\n List.fold events ~init:0 ~f:(fun acc event -> acc + Array.length event)\n in\n let all_updates, num_event_elements, num_action_elements =\n Call_forest.fold t.account_updates\n ~init:([ Account_update.of_fee_payer (fee_payer_account_update t) ], 0, 0)\n ~f:(fun (acc, num_event_elements, num_action_elements)\n (account_update : Account_update.t) ->\n let account_update_evs_elements =\n events_elements account_update.body.events\n in\n let account_update_seq_evs_elements =\n events_elements account_update.body.actions\n in\n ( account_update :: acc\n , num_event_elements + account_update_evs_elements\n , num_action_elements + account_update_seq_evs_elements ) )\n |> fun (updates, ev, sev) -> (List.rev updates, ev, sev)\n in\n let groups =\n Update_group.group_by_zkapp_command_rev [ t ]\n ( [ ((), (), ()) ]\n :: [ ((), (), ()) :: List.map all_updates ~f:(fun _ -> ((), (), ())) ] )\n in\n let proof_segments, signed_single_segments, signed_pair_segments =\n List.fold ~init:(0, 0, 0) groups\n ~f:(fun (proof_segments, signed_singles, signed_pairs) { spec; _ } ->\n match spec with\n | Proved ->\n (proof_segments + 1, signed_singles, signed_pairs)\n | Signed_single ->\n (proof_segments, signed_singles + 1, signed_pairs)\n | Signed_pair ->\n (proof_segments, signed_singles, signed_pairs + 1) )\n in\n let cost_limit = genesis_constants.zkapp_transaction_cost_limit in\n let max_event_elements = genesis_constants.max_event_elements in\n let max_action_elements = genesis_constants.max_action_elements in\n let zkapp_cost_within_limit =\n Float.(\n zkapp_cost ~proof_segments ~signed_single_segments ~signed_pair_segments\n ~genesis_constants ()\n < cost_limit)\n in\n let valid_event_elements = num_event_elements <= max_event_elements in\n let valid_action_elements = num_action_elements <= max_action_elements in\n if zkapp_cost_within_limit && valid_event_elements && valid_action_elements\n then Ok ()\n else\n let proof_zkapp_command_err =\n if zkapp_cost_within_limit then None\n else Some (sprintf \"zkapp transaction too expensive\")\n in\n let events_err =\n if valid_event_elements then None\n else\n Some\n (sprintf \"too many event elements (%d, max allowed is %d)\"\n num_event_elements max_event_elements )\n in\n let actions_err =\n if valid_action_elements then None\n else\n Some\n (sprintf \"too many sequence event elements (%d, max allowed is %d)\"\n num_action_elements max_action_elements )\n in\n let err_msg =\n List.filter\n [ proof_zkapp_command_err; events_err; actions_err ]\n ~f:Option.is_some\n |> List.map ~f:(fun opt -> Option.value_exn opt)\n |> String.concat ~sep:\"; \"\n in\n Error (Error.of_string err_msg)\n\nlet has_zero_vesting_period t =\n Call_forest.exists t.account_updates ~f:(fun p ->\n match p.body.update.timing with\n | Keep ->\n false\n | Set { vesting_period; _ } ->\n Mina_numbers.Global_slot_span.(equal zero) vesting_period )\n\nlet get_transaction_commitments (zkapp_command : t) =\n let memo_hash = Signed_command_memo.hash zkapp_command.memo in\n let fee_payer_hash =\n Account_update.of_fee_payer zkapp_command.fee_payer\n |> Digest.Account_update.create\n in\n let account_updates_hash = account_updates_hash zkapp_command in\n let txn_commitment = Transaction_commitment.create ~account_updates_hash in\n let full_txn_commitment =\n Transaction_commitment.create_complete txn_commitment ~memo_hash\n ~fee_payer_hash\n in\n (txn_commitment, full_txn_commitment)\n\nlet inner_query =\n lazy\n (Option.value_exn ~message:\"Invariant: All projectable derivers are Some\"\n Fields_derivers_zkapps.(inner_query (deriver @@ Derivers.o ())) )\n\nmodule For_tests = struct\n let replace_vks t vk =\n { t with\n account_updates =\n Call_forest.map t.account_updates ~f:(fun (p : Account_update.t) ->\n { p with\n body =\n { p.body with\n update =\n { p.body.update with\n verification_key =\n (* replace dummy vks in vk Setting *)\n ( match p.body.update.verification_key with\n | Set _vk ->\n Set vk\n | Keep ->\n Keep )\n }\n ; authorization_kind =\n (* replace dummy vk hashes in authorization kind *)\n ( match p.body.authorization_kind with\n | Proof _vk_hash ->\n Proof (With_hash.hash vk)\n | ak ->\n ak )\n }\n } )\n }\nend\n\nlet%test \"latest zkApp version\" =\n (* if this test fails, update `Transaction_hash.hash_of_transaction_id`\n for latest version, then update this test\n *)\n Stable.Latest.version = 1\n","open Core_kernel\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('u, 's) t =\n ('u, 's) Mina_wire_types.Mina_base.User_command.Poly.V2.t =\n | Signed_command of 'u\n | Zkapp_command of 's\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n type ('u, 's) t = Signed_command of 'u | Snapp_command of 's\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest : _ t -> _ V2.t = function\n | Signed_command x ->\n Signed_command x\n | Snapp_command _ ->\n failwith \"Snapp_command\"\n end\n end]\nend\n\ntype ('u, 's) t_ = ('u, 's) Poly.Stable.Latest.t =\n | Signed_command of 'u\n | Zkapp_command of 's\n\nmodule Gen_make (C : Signed_command_intf.Gen_intf) = struct\n let to_signed_command f =\n Quickcheck.Generator.map f ~f:(fun c -> Signed_command c)\n\n open C.Gen\n\n let payment ?sign_type ~key_gen ?nonce ~max_amount ~fee_range () =\n to_signed_command\n (payment ?sign_type ~key_gen ?nonce ~max_amount ~fee_range ())\n\n let payment_with_random_participants ?sign_type ~keys ?nonce ~max_amount\n ~fee_range () =\n to_signed_command\n (payment_with_random_participants ?sign_type ~keys ?nonce ~max_amount\n ~fee_range () )\n\n let stake_delegation ~key_gen ?nonce ~fee_range () =\n to_signed_command (stake_delegation ~key_gen ?nonce ~fee_range ())\n\n let stake_delegation_with_random_participants ~keys ?nonce ~fee_range () =\n to_signed_command\n (stake_delegation_with_random_participants ~keys ?nonce ~fee_range ())\n\n let sequence ?length ?sign_type a =\n Quickcheck.Generator.map\n (sequence ?length ?sign_type a)\n ~f:(List.map ~f:(fun c -> Signed_command c))\nend\n\nmodule Gen = Gen_make (Signed_command)\n\nlet gen_signed =\n let module G = Signed_command.Gen in\n let open Quickcheck.Let_syntax in\n let%bind keys =\n Quickcheck.Generator.list_with_length 2\n Mina_base_import.Signature_keypair.gen\n in\n G.payment_with_random_participants ~sign_type:`Real ~keys:(Array.of_list keys)\n ~max_amount:10000 ~fee_range:1000 ()\n\nlet gen = Gen.to_signed_command gen_signed\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n (Signed_command.Stable.V2.t, Zkapp_command.Stable.V1.t) Poly.Stable.V2.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\nlet to_base64 : t -> string = function\n | Signed_command sc ->\n Signed_command.to_base64 sc\n | Zkapp_command zc ->\n Zkapp_command.to_base64 zc\n\nlet of_base64 s : t Or_error.t =\n match Signed_command.of_base64 s with\n | Ok sc ->\n Ok (Signed_command sc)\n | Error err1 -> (\n match Zkapp_command.of_base64 s with\n | Ok zc ->\n Ok (Zkapp_command zc)\n | Error err2 ->\n Error\n (Error.of_string\n (sprintf\n \"Could decode Base64 neither to signed command (%s), nor to \\\n zkApp (%s)\"\n (Error.to_string_hum err1) (Error.to_string_hum err2) ) ) )\n\n(*\ninclude Allocation_functor.Make.Versioned_v1.Full_compare_eq_hash (struct\n let id = \"user_command\"\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n (Signed_command.Stable.V1.t, Snapp_command.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n\n type 'a creator : Signed_command.t -> Snapp_command.t -> 'a\n\n let create cmd1 cmd2 = (cmd1, cmd2)\n end\n end]\nend)\n*)\n\nmodule Zero_one_or_two = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = [ `Zero | `One of 'a | `Two of 'a * 'a ]\n [@@deriving sexp, compare, equal, hash, yojson]\n end\n end]\nend\n\nmodule Verifiable = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Signed_command.Stable.V2.t\n , Zkapp_command.Verifiable.Stable.V1.t )\n Poly.Stable.V2.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let fee_payer (t : t) =\n match t with\n | Signed_command x ->\n Signed_command.fee_payer x\n | Zkapp_command p ->\n Account_update.Fee_payer.account_id p.fee_payer\nend\n\nlet to_verifiable (t : t) ~status ~find_vk : Verifiable.t Or_error.t =\n match t with\n | Signed_command c ->\n Ok (Signed_command c)\n | Zkapp_command cmd ->\n Zkapp_command.Verifiable.create ~status ~find_vk cmd\n |> Or_error.map ~f:(fun cmd -> Zkapp_command cmd)\n\nmodule Make_to_all_verifiable (Strategy : sig\n val create_all :\n Zkapp_command.t With_status.t list\n -> find_vk:\n ( Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t )\n -> Zkapp_command.Verifiable.t With_status.t list Or_error.t\nend) =\nstruct\n let to_all_verifiable (ts : t With_status.t list) ~find_vk :\n Verifiable.t With_status.t list Or_error.t =\n let open Or_error.Let_syntax in\n (* First we tag everything with its index *)\n let its = List.mapi ts ~f:(fun i x -> (i, x)) in\n (* then we partition out the zkapp commands *)\n let izk_cmds, is_cmds =\n List.partition_map its ~f:(fun (i, cmd) ->\n match cmd.data with\n | Zkapp_command c ->\n First (i, { cmd with data = c })\n | Signed_command c ->\n Second (i, { cmd with data = c }) )\n in\n (* then unzip the indices *)\n let ixs, zk_cmds = List.unzip izk_cmds in\n (* then we verify the zkapp commands *)\n let%map vzk_cmds = Strategy.create_all ~find_vk zk_cmds in\n (* rezip indices *)\n let ivzk_cmds = List.zip_exn ixs vzk_cmds in\n (* Put them back in with a sort by index (un-partition) *)\n let ivs =\n List.map is_cmds ~f:(fun (i, cmd) ->\n (i, { cmd with data = Signed_command cmd.data }) )\n @ List.map ivzk_cmds ~f:(fun (i, cmd) ->\n (i, { cmd with data = Zkapp_command cmd.data }) )\n |> List.sort ~compare:(fun (i, _) (j, _) -> i - j)\n in\n (* Drop the indices *)\n List.unzip ivs |> snd\nend\n\nmodule Any = struct\n include Make_to_all_verifiable (Zkapp_command.Verifiable.Any)\nend\n\nmodule Last = struct\n include Make_to_all_verifiable (Zkapp_command.Verifiable.Last)\nend\n\nlet of_verifiable (t : Verifiable.t) : t =\n match t with\n | Signed_command x ->\n Signed_command x\n | Zkapp_command p ->\n Zkapp_command (Zkapp_command.of_verifiable p)\n\nlet fee : t -> Currency.Fee.t = function\n | Signed_command x ->\n Signed_command.fee x\n | Zkapp_command p ->\n Zkapp_command.fee p\n\n(* for filtering *)\nlet minimum_fee = Currency.Fee.minimum_user_command_fee\n\nlet has_insufficient_fee t = Currency.Fee.(fee t < minimum_fee)\n\n(* always `Accessed` for fee payer *)\nlet accounts_accessed (t : t) (status : Transaction_status.t) :\n (Account_id.t * [ `Accessed | `Not_accessed ]) list =\n match t with\n | Signed_command x ->\n Signed_command.account_access_statuses x status\n | Zkapp_command ps ->\n Zkapp_command.account_access_statuses ps status\n\nlet accounts_referenced (t : t) =\n List.map (accounts_accessed t Applied) ~f:(fun (acct_id, _status) -> acct_id)\n\nlet fee_payer (t : t) =\n match t with\n | Signed_command x ->\n Signed_command.fee_payer x\n | Zkapp_command p ->\n Zkapp_command.fee_payer p\n\n(** The application nonce is the nonce of the fee payer at which a user command can be applied. *)\nlet applicable_at_nonce (t : t) =\n match t with\n | Signed_command x ->\n Signed_command.nonce x\n | Zkapp_command p ->\n Zkapp_command.applicable_at_nonce p\n\nlet expected_target_nonce t = Account.Nonce.succ (applicable_at_nonce t)\n\nlet extract_vks : t -> Verification_key_wire.t List.t = function\n | Signed_command _ ->\n []\n | Zkapp_command cmd ->\n Zkapp_command.extract_vks cmd\n\n(** The target nonce is what the nonce of the fee payer will be after a user command is successfully applied. *)\nlet target_nonce_on_success (t : t) =\n match t with\n | Signed_command x ->\n Account.Nonce.succ (Signed_command.nonce x)\n | Zkapp_command p ->\n Zkapp_command.target_nonce_on_success p\n\nlet fee_token (t : t) =\n match t with\n | Signed_command x ->\n Signed_command.fee_token x\n | Zkapp_command x ->\n Zkapp_command.fee_token x\n\nlet valid_until (t : t) =\n match t with\n | Signed_command x ->\n Signed_command.valid_until x\n | Zkapp_command { fee_payer; _ } -> (\n match fee_payer.Account_update.Fee_payer.body.valid_until with\n | Some valid_until ->\n valid_until\n | None ->\n Mina_numbers.Global_slot_since_genesis.max_value )\n\nmodule Valid = struct\n type t_ = t\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Signed_command.With_valid_signature.Stable.V2.t\n , Zkapp_command.Valid.Stable.V1.t )\n Poly.Stable.V2.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n module Gen = Gen_make (Signed_command.With_valid_signature)\nend\n\nlet check_verifiable (t : Verifiable.t) : Valid.t Or_error.t =\n match t with\n | Signed_command x -> (\n match Signed_command.check x with\n | Some c ->\n Ok (Signed_command c)\n | None ->\n Or_error.error_string \"Invalid signature\" )\n | Zkapp_command p ->\n Ok (Zkapp_command (Zkapp_command.Valid.of_verifiable p))\n\nlet check ~status ~find_vk (t : t) : Valid.t Or_error.t =\n to_verifiable ~status ~find_vk t |> Or_error.bind ~f:check_verifiable\n\nlet forget_check (t : Valid.t) : t =\n match t with\n | Zkapp_command x ->\n Zkapp_command (Zkapp_command.Valid.forget x)\n | Signed_command c ->\n Signed_command (c :> Signed_command.t)\n\nlet to_valid_unsafe (t : t) =\n `If_this_is_used_it_should_have_a_comment_justifying_it\n ( match t with\n | Zkapp_command x ->\n let (`If_this_is_used_it_should_have_a_comment_justifying_it x) =\n Zkapp_command.Valid.to_valid_unsafe x\n in\n Zkapp_command x\n | Signed_command x ->\n (* This is safe due to being immediately wrapped again. *)\n let (`If_this_is_used_it_should_have_a_comment_justifying_it x) =\n Signed_command.to_valid_unsafe x\n in\n Signed_command x )\n\nlet filter_by_participant (commands : t list) public_key =\n List.filter commands ~f:(fun user_command ->\n Core_kernel.List.exists\n (accounts_referenced user_command)\n ~f:\n (Fn.compose\n (Signature_lib.Public_key.Compressed.equal public_key)\n Account_id.public_key ) )\n\n(* A metric on user commands that should correspond roughly to resource costs\n for validation/application *)\nlet weight : t -> int = function\n | Signed_command signed_command ->\n Signed_command.payload signed_command |> Signed_command_payload.weight\n | Zkapp_command zkapp_command ->\n Zkapp_command.weight zkapp_command\n\n(* Fee per weight unit *)\nlet fee_per_wu (user_command : Stable.Latest.t) : Currency.Fee_rate.t =\n (*TODO: return Or_error*)\n Currency.Fee_rate.make_exn (fee user_command) (weight user_command)\n\nlet valid_size ~genesis_constants = function\n | Signed_command _ ->\n Ok ()\n | Zkapp_command zkapp_command ->\n Zkapp_command.valid_size ~genesis_constants zkapp_command\n\nlet has_zero_vesting_period = function\n | Signed_command _ ->\n false\n | Zkapp_command p ->\n Zkapp_command.has_zero_vesting_period p\n\nmodule Well_formedness_error = struct\n (* syntactically-evident errors such that a user command can never succeed *)\n type t =\n | Insufficient_fee\n | Zero_vesting_period\n | Zkapp_too_big of (Error.t[@to_yojson Error_json.error_to_yojson])\n [@@deriving compare, to_yojson]\n\n let to_string = function\n | Insufficient_fee ->\n \"Insufficient fee\"\n | Zero_vesting_period ->\n \"Zero vesting period\"\n | Zkapp_too_big err ->\n sprintf \"Zkapp too big (%s)\" (Error.to_string_hum err)\nend\n\nlet check_well_formedness ~genesis_constants t :\n (unit, Well_formedness_error.t list) result =\n let preds =\n let open Well_formedness_error in\n [ (has_insufficient_fee, Insufficient_fee)\n ; (has_zero_vesting_period, Zero_vesting_period)\n ]\n in\n let errs0 =\n List.fold preds ~init:[] ~f:(fun acc (f, err) ->\n if f t then err :: acc else acc )\n in\n let errs =\n match valid_size ~genesis_constants t with\n | Ok () ->\n errs0\n | Error err ->\n Zkapp_too_big err :: errs0\n in\n if List.is_empty errs then Ok () else Error errs\n\ntype fee_payer_summary_t = Signature.t * Account.key * int\n[@@deriving yojson, hash]\n\nlet fee_payer_summary : t -> fee_payer_summary_t = function\n | Zkapp_command cmd ->\n let fp = Zkapp_command.fee_payer_account_update cmd in\n let open Account_update in\n let body = Fee_payer.body fp in\n ( Fee_payer.authorization fp\n , Body.Fee_payer.public_key body\n , Body.Fee_payer.nonce body |> Unsigned.UInt32.to_int )\n | Signed_command cmd ->\n Signed_command.\n (signature cmd, fee_payer_pk cmd, nonce cmd |> Unsigned.UInt32.to_int)\n\nlet fee_payer_summary_json =\n Fn.compose fee_payer_summary_t_to_yojson fee_payer_summary\n\nlet fee_payer_summary_string =\n let to_string (signature, pk, nonce) =\n sprintf \"%s (%s %d)\"\n (Signature.to_base58_check signature)\n (Signature_lib.Public_key.Compressed.to_base58_check pk)\n nonce\n in\n Fn.compose to_string fee_payer_summary\n","open Core_kernel\nopen Mina_base_import\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Fee_transfer\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Fee_transfer_intf.Full\n with type Single.Stable.V2.t = A.Single.V2.t\n and type Stable.V2.t = A.V2.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n module Single = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = A.Single.V2.t =\n { receiver_pk : Public_key.Compressed.Stable.V1.t\n ; fee : Currency.Fee.Stable.V1.t\n ; fee_token : Token_id.Stable.V2.t\n }\n [@@deriving sexp, compare, equal, yojson, hash]\n\n let to_latest = Fn.id\n\n let description = \"Fee transfer Single\"\n\n let version_byte = Base58_check.Version_bytes.fee_transfer_single\n end\n end]\n\n include Comparable.Make (Stable.Latest)\n module Base58_check = Codable.Make_base58_check (Stable.Latest)\n\n [%%define_locally\n Base58_check.(to_base58_check, of_base58_check, of_base58_check_exn)]\n\n let create ~receiver_pk ~fee ~fee_token = { receiver_pk; fee; fee_token }\n\n let receiver_pk { receiver_pk; _ } = receiver_pk\n\n let receiver { receiver_pk; fee_token; _ } =\n Account_id.create receiver_pk fee_token\n\n let fee { fee; _ } = fee\n\n let fee_token { fee_token; _ } = fee_token\n\n module Gen = struct\n let with_random_receivers ?(min_fee = 0) ~max_fee ~token keys :\n t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map receiver_pk =\n let open Signature_lib in\n Quickcheck_lib.of_array keys\n >>| fun keypair -> Public_key.compress keypair.Keypair.public_key\n and fee =\n Int.gen_incl min_fee max_fee >>| Currency.Fee.of_nanomina_int_exn\n and fee_token = token in\n { receiver_pk; fee; fee_token }\n end\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Single.Stable.V2.t One_or_two.Stable.V1.t\n [@@deriving sexp, compare, equal, yojson, hash]\n\n let to_latest = Fn.id\n end\n end]\n\n type single = Single.t =\n { receiver_pk : Public_key.Compressed.t\n ; fee : Currency.Fee.t\n ; fee_token : Token_id.t\n }\n [@@deriving sexp, compare, yojson, hash]\n\n let to_singles = Fn.id\n\n let of_singles = function\n | `One _ as t ->\n Or_error.return t\n | `Two (one, two) as t ->\n if Token_id.equal one.fee_token two.fee_token then Or_error.return t\n else\n (* Necessary invariant for the transaction snark: we should never have\n fee excesses in multiple tokens simultaneously.\n *)\n Or_error.errorf\n !\"Cannot combine single fee transfers with incompatible tokens: \\\n %{sexp: Token_id.t} <> %{sexp: Token_id.t}\"\n one.fee_token two.fee_token\n\n let create one two =\n let singles =\n match two with None -> `One one | Some two -> `Two (one, two)\n in\n of_singles singles\n\n let create_single ~receiver_pk ~fee ~fee_token =\n `One (Single.create ~receiver_pk ~fee ~fee_token)\n\n include Comparable.Make (Stable.Latest)\n\n let fee_excess ft =\n ft\n |> One_or_two.map ~f:(fun { fee_token; fee; _ } ->\n (fee_token, Currency.Fee.Signed.(negate (of_unsigned fee))) )\n |> Fee_excess.of_one_or_two\n\n let receiver_pks t =\n One_or_two.to_list (One_or_two.map ~f:Single.receiver_pk t)\n\n let receivers t = One_or_two.to_list (One_or_two.map ~f:Single.receiver t)\n\n (* This must match [Transaction_union].\n TODO: enforce this.\n *)\n let fee_payer_pk ft =\n match ft with\n | `One ft ->\n Single.receiver_pk ft\n | `Two (_, ft) ->\n Single.receiver_pk ft\n\n let fee_token = Single.fee_token\n\n let fee_tokens = One_or_two.map ~f:Single.fee_token\n\n let map = One_or_two.map\n\n let fold = One_or_two.fold\n\n let to_list = One_or_two.to_list\n\n let to_numbered_list = One_or_two.to_numbered_list\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nopen Mina_base_import\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Coinbase_fee_transfer\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Coinbase_fee_transfer_intf.Full with type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = A.V1.t =\n { receiver_pk : Public_key.Compressed.Stable.V1.t\n ; fee : Currency.Fee.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, yojson, hash]\n\n let to_latest = Fn.id\n\n let description = \"Coinbase fee transfer\"\n\n let version_byte = Base58_check.Version_bytes.fee_transfer_single\n end\n end]\n\n let create ~receiver_pk ~fee = { receiver_pk; fee }\n\n include Comparable.Make (Stable.Latest)\n module Base58_check = Codable.Make_base58_check (Stable.Latest)\n\n [%%define_locally\n Base58_check.(to_base58_check, of_base58_check, of_base58_check_exn)]\n\n let receiver_pk { receiver_pk; _ } = receiver_pk\n\n let receiver { receiver_pk; _ } =\n Account_id.create receiver_pk Token_id.default\n\n let fee { fee; _ } = fee\n\n let to_fee_transfer { receiver_pk; fee } =\n Fee_transfer.Single.create ~receiver_pk ~fee ~fee_token:Token_id.default\n\n module Gen = struct\n let gen ?(min_fee = Currency.Fee.zero) max_fee : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%bind receiver_pk = Public_key.Compressed.gen in\n let%map fee = Currency.Fee.gen_incl min_fee max_fee in\n { receiver_pk; fee }\n\n let with_random_receivers ~keys ?(min_fee = Currency.Fee.zero)\n coinbase_amount : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let max_fee = Currency.Amount.to_fee coinbase_amount in\n let%map receiver_pk =\n let open Signature_lib in\n Quickcheck_lib.of_array keys\n >>| fun keypair -> Public_key.compress keypair.Keypair.public_key\n and fee = Currency.Fee.gen_incl min_fee max_fee in\n { receiver_pk; fee }\n end\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nopen Mina_base_import\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Coinbase\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Coinbase_intf.Full with type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n module Fee_transfer = Coinbase_fee_transfer\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = A.V1.t =\n { receiver : Public_key.Compressed.Stable.V1.t\n ; amount : Currency.Amount.Stable.V1.t\n ; fee_transfer : Fee_transfer.Stable.V1.t option\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n\n let description = \"Coinbase\"\n\n let version_byte = Base58_check.Version_bytes.coinbase\n end\n end]\n\n module Base58_check = Codable.Make_base58_check (Stable.Latest)\n\n [%%define_locally\n Base58_check.(to_base58_check, of_base58_check, of_base58_check_exn)]\n\n let receiver_pk t = t.receiver\n\n let receiver t = Account_id.create t.receiver Token_id.default\n\n (* This must match [Transaction_union].\n TODO: enforce this.\n *)\n let fee_payer_pk cb =\n match cb.fee_transfer with None -> cb.receiver | Some ft -> ft.receiver_pk\n\n let amount t = t.amount\n\n let fee_transfer t = t.fee_transfer\n\n let account_access_statuses t (status : Transaction_status.t) =\n let access_status =\n match status with Applied -> `Accessed | Failed _ -> `Not_accessed\n in\n let account_ids =\n receiver t\n :: List.map ~f:Fee_transfer.receiver (Option.to_list t.fee_transfer)\n in\n List.map account_ids ~f:(fun acct_id -> (acct_id, access_status))\n\n let accounts_referenced t =\n List.map (account_access_statuses t Transaction_status.Applied)\n ~f:(fun (acct_id, _status) -> acct_id)\n\n let is_valid { amount; fee_transfer; _ } =\n match fee_transfer with\n | None ->\n true\n | Some { fee; _ } ->\n Currency.Amount.(of_fee fee <= amount)\n\n let create ~amount ~receiver ~fee_transfer =\n let t = { receiver; amount; fee_transfer } in\n if is_valid t then\n let adjusted_fee_transfer =\n Option.bind fee_transfer ~f:(fun fee_transfer ->\n Option.some_if\n (not\n (Public_key.Compressed.equal receiver\n (Fee_transfer.receiver_pk fee_transfer) ) )\n fee_transfer )\n in\n Ok { t with fee_transfer = adjusted_fee_transfer }\n else Or_error.error_string \"Coinbase.create: invalid coinbase\"\n\n let expected_supply_increase { receiver = _; amount; fee_transfer } =\n match fee_transfer with\n | None ->\n Ok amount\n | Some { fee; _ } ->\n Currency.Amount.sub amount (Currency.Amount.of_fee fee)\n |> Option.value_map\n ~f:(fun _ -> Ok amount)\n ~default:(Or_error.error_string \"Coinbase underflow\")\n\n let fee_excess t =\n Or_error.map (expected_supply_increase t) ~f:(fun _increase ->\n Fee_excess.empty )\n\n module Gen = struct\n let gen ~(constraint_constants : Genesis_constants.Constraint_constants.t) =\n let open Quickcheck.Let_syntax in\n let%bind receiver = Public_key.Compressed.gen in\n let%bind supercharged_coinbase = Quickcheck.Generator.bool in\n let%bind amount =\n let max_amount = constraint_constants.coinbase_amount in\n (* amount should be at least the account creation fee to pay for the creation of coinbase receiver and the fee transfer receiver below *)\n let min_amount =\n Option.value_exn\n (Currency.Fee.scale constraint_constants.account_creation_fee 2)\n |> Currency.Amount.of_fee\n in\n let%map amount = Currency.Amount.(gen_incl min_amount max_amount) in\n if supercharged_coinbase then\n Option.value_exn\n (Currency.Amount.scale amount\n constraint_constants.supercharged_coinbase_factor )\n else amount\n in\n (* keep account-creation fee for the coinbase-receiver *)\n let max_fee =\n Option.value_exn\n (Currency.Fee.sub\n (Currency.Amount.to_fee amount)\n constraint_constants.account_creation_fee )\n in\n let min_fee = constraint_constants.account_creation_fee in\n let%map fee_transfer =\n Option.quickcheck_generator (Fee_transfer.Gen.gen ~min_fee max_fee)\n in\n let fee_transfer =\n match fee_transfer with\n | Some { Fee_transfer.receiver_pk; _ }\n when Public_key.Compressed.equal receiver receiver_pk ->\n (* Erase fee transfer, to mirror [create]. *)\n None\n | _ ->\n fee_transfer\n in\n ( { receiver; amount; fee_transfer }\n , `Supercharged_coinbase supercharged_coinbase )\n\n let with_random_receivers ~keys ~min_amount ~max_amount ~fee_transfer =\n let open Quickcheck.Let_syntax in\n let%bind receiver =\n let open Signature_lib in\n Quickcheck_lib.of_array keys\n >>| fun keypair -> Public_key.compress keypair.Keypair.public_key\n and amount =\n Int.gen_incl min_amount max_amount\n >>| Currency.Amount.of_nanomina_int_exn\n in\n let%map fee_transfer =\n Option.quickcheck_generator (fee_transfer ~coinbase_amount:amount)\n in\n let fee_transfer =\n match fee_transfer with\n | Some { Fee_transfer.receiver_pk; _ }\n when Public_key.Compressed.equal receiver receiver_pk ->\n (* Erase fee transfer, to mirror [create]. *)\n None\n | _ ->\n fee_transfer\n in\n { receiver; amount; fee_transfer }\n end\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nopen Mina_base_import\nopen Snarky_backendless\nopen Snark_params\nopen Snark_params.Tick\nopen Let_syntax\nopen Currency\n\n(* A pending coinbase is basically a Merkle tree of \"stacks\", each of which contains two hashes. The first hash\n is computed from the components in the coinbase via a \"push\" operation. The second hash, a protocol\n state hash, is computed from the state *body* hash in the coinbase.\n The \"add_coinbase\" operation takes a coinbase, retrieves the latest stack, or creates a new one, and does\n a push.\n\n A pending coinbase also contains a stack id, used to determine the chronology of stacks, so we can know\n which is the oldest, and which is the newest stack.\n\n The name \"stack\" here is a misnomer: see issue #3226\n*)\nmodule Wire_types = Mina_wire_types.Mina_base.Pending_coinbase\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Pending_coinbase_intf.S\n with type State_stack.Stable.V1.t = A.State_stack.V1.t\n and type Stack_versioned.Stable.V1.t = A.Stack_versioned.V1.t\n and type Hash.t = A.Hash_builder.V1.t\n and type Hash_versioned.Stable.V1.t = A.Hash_versioned.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n module Coinbase_data = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Public_key.Compressed.Stable.V1.t * Amount.Stable.V1.t\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let of_coinbase (cb : Coinbase.t) : t = (cb.receiver, cb.amount)\n\n type var = Public_key.Compressed.var * Amount.var\n\n let var_of_t ((public_key, amount) : t) =\n (Public_key.Compressed.var_of_t public_key, Amount.var_of_t amount)\n\n let to_input (pk, amount) =\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n [ Public_key.Compressed.to_input pk; Amount.to_input amount ]\n\n module Checked = struct\n let to_input (public_key, amount) =\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n [ Public_key.Compressed.Checked.to_input public_key\n ; Amount.var_to_input amount\n ]\n end\n\n let typ : (var, t) Typ.t =\n let of_hlist\n : 'public_key 'amount.\n (unit, 'public_key -> 'amount -> unit) H_list.t\n -> 'public_key * 'amount =\n let open H_list in\n fun [ public_key; amount ] -> (public_key, amount)\n in\n let to_hlist (public_key, amount) = H_list.[ public_key; amount ] in\n Typ.of_hlistable\n [ Public_key.Compressed.typ; Amount.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n let empty = (Public_key.Compressed.empty, Amount.zero)\n\n let genesis = empty\n end\n\n module Stack_id : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving sexp, yojson, compare, equal]\n end\n end]\n\n val of_int : int -> t\n\n val to_int : t -> int\n\n val zero : t\n\n val incr_by_one : t -> t Or_error.t\n\n val to_string : t -> string\n\n val ( > ) : t -> t -> bool\n end = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = int [@@deriving sexp, yojson, compare, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n [%%define_locally Int.(( > ), to_string, zero, to_int, of_int, equal)]\n\n let incr_by_one t1 =\n let t2 = t1 + 1 in\n if t2 < t1 then Or_error.error_string \"Stack_id overflow\" else Ok t2\n end\n\n module type Data_hash_intf = sig\n type t = private Field.t [@@deriving sexp, compare, equal, yojson, hash]\n\n type var\n\n val var_of_t : t -> var\n\n val typ : (var, t) Typ.t\n\n val var_to_hash_packed : var -> Field.Var.t\n\n val equal_var : var -> var -> Boolean.var Tick.Checked.t\n\n val to_bytes : t -> string\n\n val to_bits : t -> bool list\n\n val to_base58_check : t -> string\n\n val of_base58_check_exn : string -> t\n\n val gen : t Quickcheck.Generator.t\n end\n\n (* a coinbase stack has two components, data and a state_hash\n we create modules for each component\n *)\n\n module Coinbase_stack = struct\n include Data_hash.Make_full_size (struct\n let description = \"Coinbase stack data\"\n\n let version_byte = Base58_check.Version_bytes.coinbase_stack_data\n end)\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\n end]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n let push (h : t) cb =\n let coinbase = Coinbase_data.of_coinbase cb in\n let open Random_oracle in\n hash ~init:Hash_prefix.coinbase_stack\n (pack_input\n (Input.Chunked.append (Coinbase_data.to_input coinbase) (to_input h)) )\n |> of_hash\n\n let empty = Hash_prefix_create.salt \"CoinbaseStack\" |> Random_oracle.digest\n\n module Checked = struct\n type t = var\n\n let push (h : t) (cb : Coinbase_data.var) =\n let open Random_oracle.Checked in\n make_checked (fun () ->\n hash ~init:Hash_prefix.coinbase_stack\n (pack_input\n (Random_oracle.Input.Chunked.append\n (Coinbase_data.Checked.to_input cb)\n (var_to_input h) ) )\n |> var_of_hash_packed )\n\n let check_merge (_, t1) (s2, _) = equal_var t1 s2\n\n let if_ = if_\n end\n end\n\n module Stack_hash = struct\n include Data_hash.Make_full_size (struct\n let description = \"Coinbase stack hash\"\n\n let version_byte = Base58_check.Version_bytes.coinbase_stack_hash\n end)\n\n (* Data hash versioned boilerplate below *)\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\n end]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n let dummy = of_hash Outside_hash_image.t\n end\n\n (*Stack of protocol state body hashes*)\n module State_stack = struct\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'stack_hash t = 'stack_hash A.State_stack.Poly.V1.t =\n { init : 'stack_hash; curr : 'stack_hash }\n [@@deriving sexp, compare, hash, yojson, equal, hlist]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Stack_hash.Stable.V1.t Poly.Stable.V1.t\n [@@deriving sexp, compare, hash, equal, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n type var = Stack_hash.var Poly.t\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map init, curr =\n Quickcheck.Generator.tuple2 Stack_hash.gen Stack_hash.gen\n in\n { Poly.init; curr }\n\n let to_input (t : t) =\n Random_oracle.Input.Chunked.append\n (Stack_hash.to_input t.init)\n (Stack_hash.to_input t.curr)\n\n let var_to_input (t : var) =\n Random_oracle.Input.Chunked.append\n (Stack_hash.var_to_input t.init)\n (Stack_hash.var_to_input t.curr)\n\n let var_of_t (t : t) =\n { Poly.init = Stack_hash.var_of_t t.init\n ; curr = Stack_hash.var_of_t t.curr\n }\n\n let typ : (var, t) Typ.t =\n Snark_params.Tick.Typ.of_hlistable\n [ Stack_hash.typ; Stack_hash.typ ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\n let to_bits (t : t) = Stack_hash.to_bits t.init @ Stack_hash.to_bits t.curr\n\n let to_bytes (t : t) =\n Stack_hash.to_bytes t.init ^ Stack_hash.to_bytes t.curr\n\n let equal_var (v1 : var) (v2 : var) =\n let open Tick.Checked.Let_syntax in\n let%bind b1 = Stack_hash.equal_var v1.init v2.init in\n let%bind b2 = Stack_hash.equal_var v1.curr v2.curr in\n Boolean.(b1 && b2)\n\n let if_ (cond : Tick0.Boolean.var) ~(then_ : var) ~(else_ : var) :\n var Tick0.Checked.t =\n let%bind init = Stack_hash.if_ cond ~then_:then_.init ~else_:else_.init in\n let%map curr = Stack_hash.if_ cond ~then_:then_.curr ~else_:else_.curr in\n { Poly.init; curr }\n\n let push (t : t) (state_body_hash : State_body_hash.t)\n (global_slot : Mina_numbers.Global_slot_since_genesis.t) : t =\n (* this is the same computation for combining state hashes and state body hashes as\n `Protocol_state.hash_abstract', not available here because it would create\n a module dependency cycle\n *)\n { t with\n curr =\n Random_oracle.hash ~init:Hash_prefix.protocol_state\n [| (t.curr :> Field.t)\n ; (state_body_hash :> Field.t)\n ; Mina_numbers.Global_slot_since_genesis.to_field global_slot\n |]\n |> Stack_hash.of_hash\n }\n\n let empty : t = { Poly.init = Stack_hash.dummy; curr = Stack_hash.dummy }\n\n let create ~init = { Poly.init; curr = init }\n\n module Checked = struct\n type t = var\n\n let push (t : t) (state_body_hash : State_body_hash.var)\n (global_slot : Mina_numbers.Global_slot_since_genesis.Checked.var) =\n make_checked (fun () ->\n let curr =\n Random_oracle.Checked.hash ~init:Hash_prefix.protocol_state\n [| Stack_hash.var_to_hash_packed t.curr\n ; State_body_hash.var_to_hash_packed state_body_hash\n ; Mina_numbers.Global_slot_since_genesis.Checked.to_field\n global_slot\n |]\n |> Stack_hash.var_of_hash_packed\n in\n { t with curr } )\n\n let check_merge (s1, t1) (s2, t2) =\n (*state stacks are updated for every transaction in transaction snark but\n only once for every blockchain snark. Therefore, source stacks (and\n target stacks) will be equal for transactions in the same block*)\n let%bind eq_src = equal_var s1 s2\n and eq_target = equal_var t1 t2\n and correct_transition = equal_var t1 s2 in\n let%bind same_update = Boolean.(eq_src &&& eq_target) in\n Boolean.any [ same_update; correct_transition ]\n end\n end\n\n (* Pending coinbase hash *)\n module Hash_builder = struct\n include Data_hash.Make_full_size (struct\n let description = \"Pending coinbase hash builder\"\n\n let version_byte = Base58_check.Version_bytes.receipt_chain_hash\n end)\n\n (* Data hash versioned boilerplate below *)\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\n end]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n let merge ~height (h1 : t) (h2 : t) =\n Random_oracle.hash\n ~init:(Hash_prefix.coinbase_merkle_tree height)\n [| (h1 :> field); (h2 :> field) |]\n |> of_hash\n\n let empty_hash =\n Hash_prefix_create.salt \"PendingCoinbaseMerkleTree\"\n |> Random_oracle.digest |> of_hash\n\n let of_digest = Fn.compose Fn.id of_hash\n end\n\n module Update = struct\n module Action = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n | Update_none\n | Update_one\n | Update_two_coinbase_in_first\n | Update_two_coinbase_in_second\n [@@deriving equal, sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n type var = Boolean.var * Boolean.var\n\n let to_bits = function\n | Update_none ->\n (false, false)\n | Update_one ->\n (true, false)\n | Update_two_coinbase_in_first ->\n (false, true)\n | Update_two_coinbase_in_second ->\n (true, true)\n\n let of_bits = function\n | false, false ->\n Update_none\n | true, false ->\n Update_one\n | false, true ->\n Update_two_coinbase_in_first\n | true, true ->\n Update_two_coinbase_in_second\n\n let var_of_t t =\n let x, y = to_bits t in\n Boolean.(var_of_value x, var_of_value y)\n\n let typ =\n Typ.transport\n Typ.(Boolean.typ * Boolean.typ)\n ~there:to_bits ~back:of_bits\n\n module Checked = struct\n let no_update (b0, b1) = Boolean.((not b0) &&& not b1)\n\n let update_two_stacks_coinbase_in_first (b0, b1) =\n Boolean.((not b0) &&& b1)\n\n let update_two_stacks_coinbase_in_second (b0, b1) = Boolean.(b0 &&& b1)\n end\n end\n\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('action, 'coinbase_amount) t =\n { action : 'action; coinbase_amount : 'coinbase_amount }\n [@@deriving sexp, to_yojson, hlist]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = (Action.Stable.V1.t, Amount.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n [%%define_locally Poly.(to_hlist, of_hlist)]\n\n type var = (Action.var, Amount.var) Poly.t\n\n let typ =\n let open Snark_params.Tick.Typ in\n of_hlistable ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n [ Action.typ; Amount.typ ]\n\n let genesis : t =\n { coinbase_amount = Currency.Amount.zero; action = Action.Update_none }\n\n let var_of_t (t : t) : var =\n { action = Action.var_of_t t.action\n ; coinbase_amount = Amount.var_of_t t.coinbase_amount\n }\n end\n\n (* Sparse_ledger.Make is applied more than once in the code, so\n it can't make assumptions about the internal structure of its module\n arguments. Therefore, for modules with a bin_io type passed to the functor,\n that type cannot be in a version module hierarchy. We build the required\n modules for Hash and Stack.\n *)\n\n module Stack_versioned = struct\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('data_stack, 'state_stack) t =\n ('data_stack, 'state_stack) A.Stack_versioned.Poly.V1.t =\n { data : 'data_stack; state : 'state_stack }\n [@@deriving yojson, hash, sexp, equal, compare]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n (Coinbase_stack.Stable.V1.t, State_stack.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving equal, yojson, hash, sexp, compare]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Hash_versioned = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Hash_builder.Stable.V1.t\n [@@deriving equal, compare, sexp, yojson, hash]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Merkle_tree_versioned = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Hash_versioned.Stable.V1.t\n , Stack_id.Stable.V1.t\n , Stack_versioned.Stable.V1.t )\n Sparse_ledger_lib.Sparse_ledger.T.Stable.V2.t\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let (_ :\n ( t\n , ( Hash_versioned.t\n , Stack_id.t\n , Stack_versioned.t )\n Sparse_ledger_lib.Sparse_ledger.T.t )\n Type_equal.t ) =\n Type_equal.T\n end\n\n module T = struct\n (* Total number of stacks *)\n let max_coinbase_stack_count ~depth = Int.pow 2 depth\n\n let chain if_ b ~then_ ~else_ =\n let%bind then_ = then_ and else_ = else_ in\n if_ b ~then_ ~else_\n\n (*pair of coinbase and state stacks*)\n module Stack = struct\n module Poly = struct\n type ('data_stack, 'state_stack) t =\n ('data_stack, 'state_stack) Stack_versioned.Poly.t =\n { data : 'data_stack; state : 'state_stack }\n [@@deriving yojson, hash, sexp, compare, hlist]\n end\n\n type t = Stack_versioned.t [@@deriving yojson, equal, compare, sexp, hash]\n\n let (_ : (t, (Coinbase_stack.t, State_stack.t) Poly.t) Type_equal.t) =\n Type_equal.T\n\n type var = (Coinbase_stack.var, State_stack.var) Poly.t\n\n let to_input ({ data; state } : t) =\n Random_oracle.Input.Chunked.append\n (Coinbase_stack.to_input data)\n (State_stack.to_input state)\n\n let data_hash t =\n Random_oracle.(\n hash ~init:Hash_prefix_states.coinbase_stack (pack_input (to_input t)))\n |> Hash_builder.of_digest\n\n let var_to_input ({ data; state } : var) =\n Random_oracle.Input.Chunked.append\n (Coinbase_stack.var_to_input data)\n (State_stack.var_to_input state)\n\n let hash_var (t : var) =\n make_checked (fun () ->\n Random_oracle.Checked.(\n hash ~init:Hash_prefix_states.coinbase_stack\n (pack_input (var_to_input t))) )\n\n let var_of_t t =\n { Poly.data = Coinbase_stack.var_of_t t.Poly.data\n ; state = State_stack.var_of_t t.state\n }\n\n let gen =\n let open Base_quickcheck.Generator.Let_syntax in\n let%bind data = Coinbase_stack.gen in\n let%map state = State_stack.gen in\n { Poly.data; state }\n\n let typ : (var, t) Typ.t =\n Snark_params.Tick.Typ.of_hlistable\n [ Coinbase_stack.typ; State_stack.typ ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\n let num_pad_bits =\n let len = List.length Coinbase_stack.(to_bits empty) in\n (3 - (len mod 3)) mod 3\n\n (* pad to match the triple representation *)\n let pad_bits = List.init num_pad_bits ~f:(fun _ -> false)\n\n let to_bits t =\n Coinbase_stack.to_bits t.Poly.data\n @ pad_bits\n @ State_stack.to_bits t.Poly.state\n\n let to_bytes t =\n Coinbase_stack.to_bytes t.Poly.data ^ State_stack.to_bytes t.Poly.state\n\n let equal_var var1 var2 =\n let open Tick.Checked.Let_syntax in\n let%bind b1 = Coinbase_stack.equal_var var1.Poly.data var2.Poly.data in\n let%bind b2 = State_stack.equal_var var1.Poly.state var2.Poly.state in\n let open Tick0.Boolean in\n b1 &&& b2\n\n let empty =\n { Poly.data = Coinbase_stack.empty; state = State_stack.empty }\n\n let create_with (t : t) =\n { empty with state = State_stack.create ~init:t.state.curr }\n\n let equal_state_hash t1 t2 = State_stack.equal t1.Poly.state t2.Poly.state\n\n let equal_data t1 t2 = Coinbase_stack.equal t1.Poly.data t2.Poly.data\n\n let connected ?(prev : t option = None) ~first ~second () =\n let coinbase_stack_connected =\n (*same as old stack or second could be a new stack with empty data*)\n equal_data first second\n || Coinbase_stack.(equal empty second.Poly.data)\n in\n let state_stack_connected =\n (*1. same as old stack or\n 2. new stack initialized with the stack state of last block. Not possible to know this unless we track all the stack states because they are updated once per block (init=curr)\n 3. [second] could be a new stack initialized with the latest state of [first] or\n 4. [second] starts from the previous state of [first]. This is not available in either [first] or [second] *)\n equal_state_hash first second\n || Stack_hash.equal second.state.init second.state.curr\n || Stack_hash.equal first.state.curr second.state.curr\n || Option.value_map prev ~default:true ~f:(fun prev ->\n Stack_hash.equal prev.state.curr second.state.curr )\n in\n coinbase_stack_connected && state_stack_connected\n\n let push_coinbase (cb : Coinbase.t) t =\n let data = Coinbase_stack.push t.Poly.data cb in\n { t with data }\n\n let push_state (state_body_hash : State_body_hash.t)\n (global_slot : Mina_numbers.Global_slot_since_genesis.t) (t : t) =\n { t with state = State_stack.push t.state state_body_hash global_slot }\n\n let if_ (cond : Tick0.Boolean.var) ~(then_ : var) ~(else_ : var) :\n var Tick0.Checked.t =\n let%bind data =\n Coinbase_stack.Checked.if_ cond ~then_:then_.data ~else_:else_.data\n in\n let%map state =\n State_stack.if_ cond ~then_:then_.state ~else_:else_.state\n in\n { Poly.data; state }\n\n module Checked = struct\n type t = var\n\n let push_coinbase (coinbase : Coinbase_data.var) (t : t) :\n t Tick0.Checked.t =\n let%map data = Coinbase_stack.Checked.push t.data coinbase in\n { t with data }\n\n let push_state (state_body_hash : State_body_hash.var)\n (global_slot : Mina_numbers.Global_slot_since_genesis.Checked.var)\n (t : t) =\n let%map state =\n State_stack.Checked.push t.state state_body_hash global_slot\n in\n { t with state }\n\n let check_merge ~transition1:((s, t) : t * t)\n ~transition2:((s', t') : t * t) : Boolean.var Tick0.Checked.t =\n let%bind valid_coinbase_stacks =\n Coinbase_stack.Checked.check_merge (s.data, t.data)\n (s'.data, t'.data)\n in\n let%bind valid_state_stacks =\n State_stack.Checked.check_merge (s.state, t.state)\n (s'.state, t'.state)\n in\n Boolean.(valid_coinbase_stacks && valid_state_stacks)\n\n let empty = var_of_t empty\n\n let create_with (t : var) =\n { empty with state = State_stack.create ~init:t.state.init }\n\n let if_ = if_\n end\n end\n\n module Hash = struct\n type t = Hash_builder.t constraint t = Hash_versioned.t\n [@@deriving equal, compare, sexp, yojson, hash]\n\n type var = Hash_builder.var\n\n [%%define_locally\n Hash_builder.\n ( of_digest\n , merge\n , empty_hash\n , gen\n , to_bits\n , to_bytes\n , equal_var\n , var_of_t\n , var_of_hash_packed\n , var_to_hash_packed\n , to_base58_check\n , of_base58_check_exn\n , typ )]\n end\n\n module Merkle_tree = struct\n type t = Merkle_tree_versioned.t [@@deriving sexp, to_yojson]\n\n let (_ :\n ( t\n , (Hash.t, Stack_id.t, Stack.t) Sparse_ledger_lib.Sparse_ledger.T.t\n )\n Type_equal.t ) =\n Type_equal.T\n\n module M = Sparse_ledger_lib.Sparse_ledger.Make (Hash) (Stack_id) (Stack)\n\n [%%define_locally\n M.\n ( of_hash\n , get_exn\n , path_exn\n , set_exn\n , find_index_exn\n , add_path\n , merkle_root )]\n end\n\n module Checked = struct\n type var = Hash.var\n\n module Merkle_tree =\n Snarky_backendless.Merkle_tree.Checked\n (Tick)\n (struct\n type value = Field.t\n\n type var = Field.Var.t\n\n let typ = Field.typ\n\n let merge ~height h1 h2 =\n Tick.make_checked (fun () ->\n Random_oracle.Checked.hash\n ~init:(Hash_prefix.coinbase_merkle_tree height)\n [| h1; h2 |] )\n\n let assert_equal h1 h2 = Field.Checked.Assert.equal h1 h2\n\n let if_ = Field.Checked.if_\n end)\n (struct\n include Stack\n\n type value = t [@@deriving sexp]\n\n let hash var = hash_var var\n end)\n\n module Path = Merkle_tree.Path\n\n type path = Path.value\n\n module Address = struct\n include Merkle_tree.Address\n end\n\n type _ Request.t +=\n | Coinbase_stack_path : Address.value -> path Request.t\n | Get_coinbase_stack : Address.value -> (Stack.t * path) Request.t\n | Set_coinbase_stack : Address.value * Stack.t -> unit Request.t\n | Set_oldest_coinbase_stack : Address.value * Stack.t -> unit Request.t\n | Find_index_of_newest_stacks :\n Update.Action.t\n -> (Address.value * Address.value) Request.t\n | Find_index_of_oldest_stack : Address.value Request.t\n | Get_previous_stack : State_stack.t Request.t\n\n let reraise_merkle_requests (With { request; respond }) =\n match request with\n | Merkle_tree.Get_path addr ->\n respond (Delegate (Coinbase_stack_path addr))\n | Merkle_tree.Set (addr, stack) ->\n respond (Delegate (Set_coinbase_stack (addr, stack)))\n | Merkle_tree.Get_element addr ->\n respond (Delegate (Get_coinbase_stack addr))\n | _ ->\n unhandled\n\n let get ~depth t addr =\n handle\n (fun () -> Merkle_tree.get_req ~depth (Hash.var_to_hash_packed t) addr)\n reraise_merkle_requests\n\n let%snarkydef_ add_coinbase\n ~(constraint_constants : Genesis_constants.Constraint_constants.t) t\n ({ action; coinbase_amount = amount } : Update.var) ~coinbase_receiver\n ~supercharge_coinbase state_body_hash global_slot =\n let depth = constraint_constants.pending_coinbase_depth in\n let%bind addr1, addr2 =\n request_witness\n Typ.(Address.typ ~depth * Address.typ ~depth)\n As_prover.(\n map (read Update.Action.typ action) ~f:(fun act ->\n Find_index_of_newest_stacks act ))\n in\n let equal_to_zero x = Amount.(equal_var x (var_of_t zero)) in\n let%bind no_update = Update.Action.Checked.no_update action in\n let update_state_stack (stack : Stack.var) =\n (*get previous stack to carry-forward the stack of state body hashes*)\n let%bind previous_state_stack =\n request_witness State_stack.typ\n As_prover.(map (return ()) ~f:(fun () -> Get_previous_stack))\n in\n let stack_initialized = { stack with state = previous_state_stack } in\n let%bind stack_with_state_hash =\n Stack.Checked.push_state state_body_hash global_slot\n stack_initialized\n in\n (*Always update the state body hash unless there are no transactions in this block*)\n Stack.Checked.if_ no_update ~then_:stack ~else_:stack_with_state_hash\n in\n let update_stack1 stack =\n let%bind stack = update_state_stack stack in\n let%bind total_coinbase_amount =\n let coinbase_amount =\n Currency.Amount.var_of_t constraint_constants.coinbase_amount\n in\n let supercharged_coinbase =\n let amt =\n Option.value_exn\n (Currency.Amount.scale constraint_constants.coinbase_amount\n constraint_constants.supercharged_coinbase_factor )\n in\n Currency.Amount.var_of_t amt\n in\n Currency.Amount.Checked.if_ supercharge_coinbase\n ~then_:supercharged_coinbase ~else_:coinbase_amount\n in\n let%bind rem_amount =\n Currency.Amount.Checked.sub total_coinbase_amount amount\n in\n let%bind no_coinbase_in_this_stack =\n Update.Action.Checked.update_two_stacks_coinbase_in_second action\n in\n let%bind amount1_equal_to_zero = equal_to_zero amount in\n let%bind amount2_equal_to_zero = equal_to_zero rem_amount in\n (*if no update then coinbase amount has to be zero*)\n let%bind () =\n with_label __LOC__ (fun () ->\n let%bind check =\n Boolean.equal no_update amount1_equal_to_zero\n in\n Boolean.Assert.is_true check )\n in\n let%bind no_coinbase =\n Boolean.(no_update ||| no_coinbase_in_this_stack)\n in\n (* TODO: Optimize here since we are pushing twice to the same stack *)\n let%bind stack_with_amount1 =\n Stack.Checked.push_coinbase (coinbase_receiver, amount) stack\n in\n let%bind stack_with_amount2 =\n Stack.Checked.push_coinbase\n (coinbase_receiver, rem_amount)\n stack_with_amount1\n in\n chain Stack.if_ no_coinbase ~then_:(return stack)\n ~else_:\n (Stack.if_ amount2_equal_to_zero ~then_:stack_with_amount1\n ~else_:stack_with_amount2 )\n in\n (*This is for the second stack for when transactions in a block occupy\n two trees of the scan state; the second tree will carry-forward the state\n stack from the previous block, push the new state, and may or may not have a coinbase*)\n let update_stack2 (init_stack : Stack.var) (stack0 : Stack.var) =\n let%bind add_coinbase =\n Update.Action.Checked.update_two_stacks_coinbase_in_second action\n in\n let%bind update_state =\n let%bind update_second_stack =\n Update.Action.Checked.update_two_stacks_coinbase_in_first action\n in\n Boolean.(update_second_stack ||| add_coinbase)\n in\n let%bind stack =\n let%bind stack_with_state =\n Stack.Checked.push_state state_body_hash global_slot\n { stack0 with\n state =\n State_stack.create ~init:init_stack.Stack.Poly.state.curr\n }\n in\n Stack.if_ update_state ~then_:stack_with_state ~else_:stack0\n in\n let%bind stack_with_coinbase =\n Stack.Checked.push_coinbase (coinbase_receiver, amount) stack\n in\n Stack.if_ add_coinbase ~then_:stack_with_coinbase ~else_:stack\n in\n (*update the first stack*)\n let%bind root', `Old prev, `New _updated_stack1 =\n handle\n (fun () ->\n Merkle_tree.fetch_and_update_req ~depth\n (Hash.var_to_hash_packed t)\n addr1 ~f:update_stack1 )\n reraise_merkle_requests\n in\n (*update the second stack*)\n let%map root, _, _ =\n handle\n (fun () ->\n Merkle_tree.fetch_and_update_req ~depth root' addr2\n ~f:(update_stack2 prev) )\n reraise_merkle_requests\n in\n Hash.var_of_hash_packed root\n\n let%snarkydef_ pop_coinbases\n ~(constraint_constants : Genesis_constants.Constraint_constants.t) t\n ~proof_emitted =\n let depth = constraint_constants.pending_coinbase_depth in\n let%bind addr =\n request_witness (Address.typ ~depth)\n As_prover.(map (return ()) ~f:(fun _ -> Find_index_of_oldest_stack))\n in\n let%bind prev, prev_path =\n request_witness\n Typ.(Stack.typ * Path.typ ~depth)\n As_prover.(\n map\n (read (Address.typ ~depth) addr)\n ~f:(fun a -> Get_coinbase_stack a))\n in\n let stack_hash = Stack.hash_var in\n let%bind prev_entry_hash = stack_hash prev in\n let%bind () =\n Merkle_tree.implied_root prev_entry_hash addr prev_path\n >>= Field.Checked.Assert.equal (Hash.var_to_hash_packed t)\n in\n let%bind next =\n Stack.if_ proof_emitted ~then_:Stack.Checked.empty ~else_:prev\n in\n let%bind next_entry_hash = stack_hash next in\n let%bind () =\n perform\n (let open As_prover in\n let open Let_syntax in\n let%map addr = read (Address.typ ~depth) addr\n and next = read Stack.typ next in\n Set_oldest_coinbase_stack (addr, next))\n in\n let%map new_root =\n Merkle_tree.implied_root next_entry_hash addr prev_path\n in\n (Hash.var_of_hash_packed new_root, prev)\n end\n\n module Poly = struct\n type ('tree, 'stack_id) t = ('tree, 'stack_id) A.Poly.t =\n { tree : 'tree; pos_list : 'stack_id list; new_pos : 'stack_id }\n [@@deriving sexp, to_yojson]\n end\n\n type t = (Merkle_tree.t, Stack_id.t) Poly.t [@@deriving sexp, to_yojson]\n\n let hash_at_level =\n let cached = ref [||] in\n fun i ->\n let len = Array.length !cached in\n let len =\n if len = 0 then (\n cached := [| Stack.data_hash Stack.empty |] ;\n 1 )\n else len\n in\n ( if i >= len then\n let cur_hash = ref (Array.last !cached) in\n cached :=\n Array.append !cached\n (Array.init\n (i + 1 - len)\n ~f:(fun i ->\n cur_hash :=\n Hash.merge ~height:(i + len - 1) !cur_hash !cur_hash ;\n !cur_hash ) ) ) ;\n !cached.(i)\n\n let create_exn' ~depth () =\n let rec create_path height path key =\n if height < 0 then path\n else\n let hash = hash_at_level height in\n create_path (height - 1)\n ((if key mod 2 = 0 then `Left hash else `Right hash) :: path)\n (key / 2)\n in\n let rec make_tree t key =\n if Stack_id.( > ) key (Stack_id.of_int @@ (Int.pow 2 depth - 1)) then t\n else\n let path = create_path (depth - 1) [] (Stack_id.to_int key) in\n make_tree\n (Merkle_tree.add_path t path key Stack.empty)\n (Or_error.ok_exn (Stack_id.incr_by_one key))\n in\n let root_hash = hash_at_level depth in\n { Poly.tree =\n make_tree (Merkle_tree.of_hash ~depth root_hash) Stack_id.zero\n ; pos_list = []\n ; new_pos = Stack_id.zero\n }\n\n [%%define_locally Or_error.(try_with)]\n\n let create ~depth () = try_with (fun () -> create_exn' ~depth ())\n\n let merkle_root (t : t) = Merkle_tree.merkle_root t.tree\n\n let get_stack (t : t) index =\n try_with (fun () -> Merkle_tree.get_exn t.tree index)\n\n let path (t : t) index =\n try_with (fun () -> Merkle_tree.path_exn t.tree index)\n\n let find_index (t : t) key =\n try_with (fun () -> Merkle_tree.find_index_exn t.tree key)\n\n let next_index ~depth (t : t) =\n if\n Stack_id.equal t.new_pos\n (Stack_id.of_int (max_coinbase_stack_count ~depth - 1))\n then Ok Stack_id.zero\n else Stack_id.incr_by_one t.new_pos\n\n let next_stack_id ~depth t ~is_new_stack =\n if is_new_stack then next_index ~depth t else Ok t.new_pos\n\n let incr_index ~depth (t : t) ~is_new_stack =\n let open Or_error.Let_syntax in\n if is_new_stack then\n let%map new_pos = next_index ~depth t in\n { t with pos_list = t.new_pos :: t.pos_list; new_pos }\n else Ok t\n\n let set_stack ~depth (t : t) index stack ~is_new_stack =\n let open Or_error.Let_syntax in\n let%bind tree =\n try_with (fun () -> Merkle_tree.set_exn t.tree index stack)\n in\n incr_index ~depth { t with tree } ~is_new_stack\n\n let latest_stack_id (t : t) ~is_new_stack =\n if is_new_stack then t.new_pos\n else match List.hd t.pos_list with Some x -> x | None -> Stack_id.zero\n\n let curr_stack_id (t : t) = List.hd t.pos_list\n\n let current_stack t =\n let prev_stack_id =\n Option.value ~default:Stack_id.zero (curr_stack_id t)\n in\n Or_error.try_with (fun () ->\n let index = Merkle_tree.find_index_exn t.tree prev_stack_id in\n Merkle_tree.get_exn t.tree index )\n\n let latest_stack (t : t) ~is_new_stack =\n let open Or_error.Let_syntax in\n let key = latest_stack_id t ~is_new_stack in\n let%bind res =\n Or_error.try_with (fun () ->\n let index = Merkle_tree.find_index_exn t.tree key in\n Merkle_tree.get_exn t.tree index )\n in\n if is_new_stack then\n let%map prev_stack = current_stack t in\n { res with state = State_stack.create ~init:prev_stack.state.curr }\n else Ok res\n\n let oldest_stack_id (t : t) = List.last t.pos_list\n\n let remove_oldest_stack_id t =\n match List.rev t with\n | [] ->\n Or_error.error_string \"No coinbase stack-with-state-hash to pop\"\n | x :: xs ->\n Ok (x, List.rev xs)\n\n let oldest_stack t =\n let open Or_error.Let_syntax in\n let key = Option.value ~default:Stack_id.zero (oldest_stack_id t) in\n let%bind index = find_index t key in\n get_stack t index\n\n let update_stack' ~depth t ~(f : Stack.t -> Stack.t) ~is_new_stack =\n let open Or_error.Let_syntax in\n let key = latest_stack_id t ~is_new_stack in\n let%bind stack_index = find_index t key in\n let%bind stack_before = get_stack t stack_index in\n let stack_after = f stack_before in\n (* state hash in \"after\" stack becomes previous state hash at top level *)\n set_stack ~depth t stack_index stack_after ~is_new_stack\n\n let add_coinbase ~depth t ~coinbase ~is_new_stack =\n update_stack' ~depth t ~f:(Stack.push_coinbase coinbase) ~is_new_stack\n\n let add_state ~depth t state_body_hash global_slot ~is_new_stack =\n update_stack' ~depth t\n ~f:(Stack.push_state state_body_hash global_slot)\n ~is_new_stack\n\n let update_coinbase_stack ~depth (t : t) stack ~is_new_stack =\n update_stack' ~depth t ~f:(fun _ -> stack) ~is_new_stack\n\n let remove_coinbase_stack ~depth (t : t) =\n let open Or_error.Let_syntax in\n let%bind oldest_stack, remaining = remove_oldest_stack_id t.pos_list in\n let%bind stack_index = find_index t oldest_stack in\n let%bind stack = get_stack t stack_index in\n let%map t' =\n set_stack ~depth t stack_index Stack.empty ~is_new_stack:false\n in\n (stack, { t' with pos_list = remaining })\n\n let hash_extra ({ pos_list; new_pos; _ } : t) =\n let h = Digestif.SHA256.init () in\n let h =\n Digestif.SHA256.feed_string h\n (List.fold pos_list ~init:\"\" ~f:(fun s a -> s ^ Stack_id.to_string a))\n in\n let h = Digestif.SHA256.feed_string h (Stack_id.to_string new_pos) in\n Digestif.SHA256.(get h |> to_raw_string)\n\n let handler ~depth (t : t) ~is_new_stack =\n let pending_coinbase = ref t in\n let coinbase_stack_path_exn idx =\n List.map\n (path !pending_coinbase idx |> Or_error.ok_exn)\n ~f:(function `Left h -> h | `Right h -> h)\n in\n stage (fun (With { request; respond }) ->\n match request with\n | Checked.Coinbase_stack_path idx ->\n let path =\n (coinbase_stack_path_exn idx :> Random_oracle.Digest.t list)\n in\n respond (Provide path)\n | Checked.Find_index_of_oldest_stack ->\n let stack_id =\n Option.value ~default:Stack_id.zero\n (oldest_stack_id !pending_coinbase)\n in\n let index =\n find_index !pending_coinbase stack_id |> Or_error.ok_exn\n in\n respond (Provide index)\n | Checked.Find_index_of_newest_stacks _action ->\n let index1 =\n let stack_id =\n latest_stack_id !pending_coinbase ~is_new_stack\n in\n find_index !pending_coinbase stack_id |> Or_error.ok_exn\n in\n let index2 =\n let stack_id =\n match\n next_stack_id ~depth !pending_coinbase ~is_new_stack\n with\n | Ok id ->\n id\n | _ ->\n Stack_id.zero\n in\n find_index !pending_coinbase stack_id |> Or_error.ok_exn\n in\n respond @@ Provide (index1, index2)\n | Checked.Get_coinbase_stack idx ->\n let elt = get_stack !pending_coinbase idx |> Or_error.ok_exn in\n let path =\n (coinbase_stack_path_exn idx :> Random_oracle.Digest.t list)\n in\n respond (Provide (elt, path))\n | Checked.Set_coinbase_stack (idx, stack) ->\n pending_coinbase :=\n set_stack ~depth !pending_coinbase idx stack ~is_new_stack\n |> Or_error.ok_exn ;\n respond (Provide ())\n | Checked.Set_oldest_coinbase_stack (idx, stack) ->\n pending_coinbase :=\n set_stack ~depth !pending_coinbase idx stack ~is_new_stack:false\n |> Or_error.ok_exn ;\n respond (Provide ())\n | Checked.Get_previous_stack ->\n let prev_state =\n if is_new_stack then\n let stack =\n current_stack !pending_coinbase |> Or_error.ok_exn\n in\n { State_stack.Poly.init = stack.state.curr\n ; curr = stack.state.curr\n }\n else\n let stack =\n latest_stack !pending_coinbase ~is_new_stack\n |> Or_error.ok_exn\n in\n stack.state\n in\n respond (Provide prev_state)\n | _ ->\n unhandled )\n end\n\n include T\n\n module Poly_versioned = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('tree, 'stack_id) t = ('tree, 'stack_id) T.Poly.t =\n { tree : 'tree; pos_list : 'stack_id list; new_pos : 'stack_id }\n [@@deriving sexp, to_yojson]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t =\n ( Merkle_tree_versioned.Stable.V2.t\n , Stack_id.Stable.V1.t )\n Poly_versioned.Stable.V1.t\n [@@deriving sexp, to_yojson]\n\n let (_ : (t, T.t) Type_equal.t) = Type_equal.T\n\n let to_latest = Fn.id\n end\n end]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n let%test_unit \"add stack + remove stack = initial tree \" =\n let constraint_constants =\n Genesis_constants.Constraint_constants.for_unit_tests\n in\n let depth = constraint_constants.pending_coinbase_depth in\n let coinbases_gen =\n Quickcheck.Generator.list_non_empty\n (Coinbase.Gen.gen ~constraint_constants)\n in\n let pending_coinbases = ref (create ~depth () |> Or_error.ok_exn) in\n Quickcheck.test coinbases_gen ~trials:50 ~f:(fun cbs ->\n Run_in_thread.block_on_async_exn (fun () ->\n let is_new_stack = ref true in\n let init = merkle_root !pending_coinbases in\n let after_adding =\n List.fold cbs ~init:!pending_coinbases\n ~f:(fun acc (coinbase, _) ->\n let t =\n add_coinbase ~depth acc ~coinbase\n ~is_new_stack:!is_new_stack\n |> Or_error.ok_exn\n in\n is_new_stack := false ;\n t )\n in\n let _, after_del =\n remove_coinbase_stack ~depth after_adding |> Or_error.ok_exn\n in\n pending_coinbases := after_del ;\n assert (Hash.equal (merkle_root after_del) init) ;\n Async_kernel.Deferred.return () ) )\n\n module type Pending_coinbase_intf = sig\n type t [@@deriving sexp]\n\n val add_coinbase :\n depth:int -> t -> coinbase:Coinbase.t -> is_new_stack:bool -> t Or_error.t\n\n val add_state :\n depth:int\n -> t\n -> State_body_hash.t\n -> Mina_numbers.Global_slot_since_genesis.t\n -> is_new_stack:bool\n -> t Or_error.t\n end\n\n let add_coinbase_with_zero_checks (type t)\n (module T : Pending_coinbase_intf with type t = t) (t : t)\n ~(constraint_constants : Genesis_constants.Constraint_constants.t)\n ~coinbase ~supercharged_coinbase ~state_body_hash ~global_slot\n ~is_new_stack =\n let depth = constraint_constants.pending_coinbase_depth in\n if Amount.equal coinbase.Coinbase.amount Amount.zero then t\n else\n let max_coinbase_amount =\n if supercharged_coinbase then\n Option.value_exn\n (Currency.Amount.scale constraint_constants.coinbase_amount\n constraint_constants.supercharged_coinbase_factor )\n else constraint_constants.coinbase_amount\n in\n let coinbase' =\n Coinbase.create\n ~amount:\n (Option.value_exn (Amount.sub max_coinbase_amount coinbase.amount))\n ~receiver:coinbase.receiver ~fee_transfer:None\n |> Or_error.ok_exn\n in\n let t_with_state =\n T.add_state ~depth t state_body_hash global_slot ~is_new_stack\n |> Or_error.ok_exn\n in\n (*add coinbase to the same stack*)\n let interim_tree =\n T.add_coinbase ~depth t_with_state ~coinbase ~is_new_stack:false\n |> Or_error.ok_exn\n in\n if Amount.equal coinbase'.amount Amount.zero then interim_tree\n else\n T.add_coinbase ~depth interim_tree ~coinbase:coinbase'\n ~is_new_stack:false\n |> Or_error.ok_exn\n\n let%test_unit \"Checked_stack = Unchecked_stack\" =\n let open Quickcheck in\n let constraint_constants =\n Genesis_constants.Constraint_constants.for_unit_tests\n in\n test ~trials:20\n (Generator.tuple2 Stack.gen (Coinbase.Gen.gen ~constraint_constants))\n ~f:(fun (base, (cb, _supercharged_coinbase)) ->\n let coinbase_data = Coinbase_data.of_coinbase cb in\n let unchecked = Stack.push_coinbase cb base in\n let checked =\n let comp =\n let open Snark_params.Tick in\n let cb_var = Coinbase_data.(var_of_t coinbase_data) in\n let%map res =\n Stack.Checked.push_coinbase cb_var (Stack.var_of_t base)\n in\n As_prover.read Stack.typ res\n in\n Or_error.ok_exn (run_and_check comp)\n in\n assert (Stack.equal unchecked checked) )\n\n let%test_unit \"Checked_tree = Unchecked_tree\" =\n let open Quickcheck in\n let constraint_constants =\n Genesis_constants.Constraint_constants.for_unit_tests\n in\n let depth = constraint_constants.pending_coinbase_depth in\n let pending_coinbases = create ~depth () |> Or_error.ok_exn in\n test ~trials:20\n (Generator.tuple3\n (Coinbase.Gen.gen ~constraint_constants)\n State_body_hash.gen Mina_numbers.Global_slot_since_genesis.gen )\n ~f:(fun ( (coinbase, `Supercharged_coinbase supercharged_coinbase)\n , state_body_hash\n , global_slot ) ->\n let amount = coinbase.amount in\n let is_new_stack, action =\n Currency.Amount.(\n if equal coinbase.amount zero then (true, Update.Action.Update_none)\n else (true, Update_one))\n in\n let unchecked =\n add_coinbase_with_zero_checks ~constraint_constants\n (module T)\n pending_coinbases ~coinbase ~is_new_stack ~state_body_hash\n ~global_slot ~supercharged_coinbase\n in\n (* inside the `open' below, Checked means something else, so define this function *)\n let f_add_coinbase = Checked.add_coinbase ~constraint_constants in\n let checked_merkle_root =\n let comp =\n let open Snark_params.Tick in\n let amount_var = Amount.var_of_t amount in\n let action_var = Update.Action.var_of_t action in\n let coinbase_receiver_var =\n Public_key.Compressed.var_of_t coinbase.receiver\n in\n let supercharge_coinbase_var =\n Boolean.var_of_value supercharged_coinbase\n in\n let state_body_hash_var =\n State_body_hash.var_of_t state_body_hash\n in\n let global_slot_var =\n Mina_numbers.Global_slot_since_genesis.Checked.constant\n global_slot\n in\n let%map result =\n handle\n (fun () ->\n f_add_coinbase\n (Hash.var_of_t (merkle_root pending_coinbases))\n { Update.Poly.action = action_var\n ; coinbase_amount = amount_var\n }\n ~coinbase_receiver:coinbase_receiver_var\n ~supercharge_coinbase:supercharge_coinbase_var\n state_body_hash_var global_slot_var )\n (unstage (handler ~depth pending_coinbases ~is_new_stack))\n in\n As_prover.read Hash.typ result\n in\n Or_error.ok_exn (run_and_check comp)\n in\n assert (Hash.equal (merkle_root unchecked) checked_merkle_root) )\n\n let%test_unit \"Checked_tree = Unchecked_tree after pop\" =\n let open Quickcheck in\n let constraint_constants =\n Genesis_constants.Constraint_constants.for_unit_tests\n in\n let depth = constraint_constants.pending_coinbase_depth in\n test ~trials:20\n (Generator.tuple3\n (Coinbase.Gen.gen ~constraint_constants)\n State_body_hash.gen Mina_numbers.Global_slot_since_genesis.gen )\n ~f:(fun ( (coinbase, `Supercharged_coinbase supercharged_coinbase)\n , state_body_hash\n , global_slot ) ->\n let pending_coinbases = create ~depth () |> Or_error.ok_exn in\n let amount = coinbase.amount in\n let action =\n Currency.Amount.(\n if equal coinbase.amount zero then Update.Action.Update_none\n else Update_one)\n in\n let unchecked =\n add_coinbase_with_zero_checks ~constraint_constants\n (module T)\n pending_coinbases ~coinbase ~is_new_stack:true ~state_body_hash\n ~global_slot ~supercharged_coinbase\n in\n (* inside the `open' below, Checked means something else, so define these functions *)\n let f_add_coinbase = Checked.add_coinbase ~constraint_constants in\n let f_pop_coinbase = Checked.pop_coinbases ~constraint_constants in\n let checked_merkle_root =\n let comp =\n let open Snark_params.Tick in\n let amount_var = Amount.var_of_t amount in\n let action_var = Update.Action.(var_of_t action) in\n let coinbase_receiver_var =\n Public_key.Compressed.var_of_t coinbase.receiver\n in\n let supercharge_coinbase_var =\n Boolean.var_of_value supercharged_coinbase\n in\n let state_body_hash_var =\n State_body_hash.var_of_t state_body_hash\n in\n let global_slot_var =\n Mina_numbers.Global_slot_since_genesis.Checked.constant\n global_slot\n in\n let%map result =\n handle\n (fun () ->\n f_add_coinbase\n (Hash.var_of_t (merkle_root pending_coinbases))\n { Update.Poly.action = action_var\n ; coinbase_amount = amount_var\n }\n ~coinbase_receiver:coinbase_receiver_var\n ~supercharge_coinbase:supercharge_coinbase_var\n state_body_hash_var global_slot_var )\n (unstage (handler ~depth pending_coinbases ~is_new_stack:true))\n in\n As_prover.read Hash.typ result\n in\n Or_error.ok_exn (run_and_check comp)\n in\n assert (Hash.equal (merkle_root unchecked) checked_merkle_root) ;\n (*deleting the coinbase stack we just created. therefore if there was no update then don't try to delete*)\n let proof_emitted = not Update.Action.(equal action Update_none) in\n let unchecked_after_pop =\n if proof_emitted then\n remove_coinbase_stack ~depth unchecked |> Or_error.ok_exn |> snd\n else unchecked\n in\n let checked_merkle_root_after_pop =\n let comp =\n let open Snark_params.Tick in\n let%map current, _previous =\n handle\n (fun () ->\n f_pop_coinbase ~proof_emitted:Boolean.true_\n (Hash.var_of_t checked_merkle_root) )\n (unstage (handler ~depth unchecked ~is_new_stack:false))\n in\n As_prover.read Hash.typ current\n in\n Or_error.ok_exn (run_and_check comp)\n in\n assert (\n Hash.equal\n (merkle_root unchecked_after_pop)\n checked_merkle_root_after_pop ) )\n\n let%test_unit \"push and pop multiple stacks\" =\n let open Quickcheck in\n let module Pending_coinbase = T in\n let constraint_constants =\n { Genesis_constants.Constraint_constants.for_unit_tests with\n pending_coinbase_depth = 3\n }\n in\n let depth = constraint_constants.pending_coinbase_depth in\n let t_of_coinbases t = function\n | [] ->\n let t' =\n Pending_coinbase.incr_index ~depth t ~is_new_stack:true\n |> Or_error.ok_exn\n in\n (Pending_coinbase.Stack.empty, t')\n | ( (initial_coinbase, _supercharged_coinbase)\n , state_body_hash\n , global_slot )\n :: coinbases ->\n let t' =\n Pending_coinbase.add_state ~depth t state_body_hash global_slot\n ~is_new_stack:true\n |> Or_error.ok_exn\n |> Pending_coinbase.add_coinbase ~depth ~coinbase:initial_coinbase\n ~is_new_stack:false\n |> Or_error.ok_exn\n in\n let updated =\n List.fold coinbases ~init:t'\n ~f:(fun\n pending_coinbases\n ( (coinbase, `Supercharged_coinbase supercharged_coinbase)\n , state_body_hash\n , global_slot )\n ->\n add_coinbase_with_zero_checks ~constraint_constants\n (module Pending_coinbase)\n pending_coinbases ~coinbase ~is_new_stack:false\n ~state_body_hash ~global_slot ~supercharged_coinbase )\n in\n let new_stack =\n Or_error.ok_exn\n @@ Pending_coinbase.latest_stack updated ~is_new_stack:false\n in\n (new_stack, updated)\n in\n (* Create pending coinbase stacks from coinbase lists and add it to the pending coinbase merkle tree *)\n let add coinbase_lists pending_coinbases =\n List.fold ~init:([], pending_coinbases) coinbase_lists\n ~f:(fun (stacks, pc) coinbases ->\n let new_stack, pc = t_of_coinbases pc coinbases in\n (new_stack :: stacks, pc) )\n in\n (* remove the oldest stack and check if that's the expected one *)\n let remove_check t expected_stack =\n let popped_stack, updated_pending_coinbases =\n Pending_coinbase.remove_coinbase_stack ~depth t |> Or_error.ok_exn\n in\n assert (Pending_coinbase.Stack.equal_data popped_stack expected_stack) ;\n updated_pending_coinbases\n in\n let add_remove_check coinbase_lists =\n let max_coinbase_stack_count =\n Pending_coinbase.max_coinbase_stack_count ~depth\n in\n let pending_coinbases = Pending_coinbase.create_exn' ~depth () in\n let rec go coinbase_lists pc =\n if List.is_empty coinbase_lists then ()\n else\n let coinbase_lists' =\n List.take coinbase_lists max_coinbase_stack_count\n in\n let added_stacks, pending_coinbases_updated =\n add coinbase_lists' pc\n in\n let pending_coinbases' =\n List.fold ~init:pending_coinbases_updated (List.rev added_stacks)\n ~f:(fun pc expected_stack -> remove_check pc expected_stack)\n in\n let remaining_lists =\n List.drop coinbase_lists max_coinbase_stack_count\n in\n go remaining_lists pending_coinbases'\n in\n go coinbase_lists pending_coinbases\n in\n let coinbase_lists_gen =\n Quickcheck.Generator.(\n list\n (list\n (Generator.tuple3\n (Coinbase.Gen.gen ~constraint_constants)\n State_body_hash.gen Mina_numbers.Global_slot_since_genesis.gen ) ))\n in\n test ~trials:100 coinbase_lists_gen ~f:add_remove_check\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_util\nopen Fold_lib\nopen Snark_params.Tick\nmodule Wire_types = Mina_wire_types.Mina_base.Staged_ledger_hash\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Staged_ledger_hash_intf.Full\n with type Aux_hash.t = A.Aux_hash.t\n and type Pending_coinbase_aux.t = A.Pending_coinbase_aux.V1.t\n and type t = A.V1.t\n and type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n module Aux_hash = struct\n let length_in_bits = 256\n\n let length_in_bytes = length_in_bits / 8\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = string [@@deriving sexp, equal, compare, hash]\n\n let to_latest = Fn.id\n\n module Base58_check = Base58_check.Make (struct\n let description = \"Aux hash\"\n\n let version_byte =\n Base58_check.Version_bytes.staged_ledger_hash_aux_hash\n end)\n\n let to_base58_check s = Base58_check.encode s\n\n let of_base58_check_exn s = Base58_check.decode_exn s\n\n let to_yojson s = `String (to_base58_check s)\n\n let of_yojson = function\n | `String s -> (\n match Base58_check.decode s with\n | Error e ->\n Error\n (sprintf \"Aux_hash.of_yojson, bad Base58Check:%s\"\n (Error.to_string_hum e) )\n | Ok x ->\n Ok x )\n | _ ->\n Error \"Aux_hash.of_yojson expected `String\"\n end\n end]\n\n [%%define_locally\n Stable.Latest.\n ( to_yojson\n , of_yojson\n , to_base58_check\n , of_base58_check_exn\n , compare\n , sexp_of_t )]\n\n let of_bytes = Fn.id\n\n let to_bytes = Fn.id\n\n let dummy : t = String.init length_in_bytes ~f:(fun _ -> '\\000')\n\n let of_sha256 : Digestif.SHA256.t -> t =\n Fn.compose of_bytes Digestif.SHA256.to_raw_string\n\n let gen : t Quickcheck.Generator.t =\n let char_generator =\n Base_quickcheck.Generator.of_list\n [ '0'\n ; '1'\n ; '2'\n ; '3'\n ; '4'\n ; '5'\n ; '6'\n ; '7'\n ; '8'\n ; '9'\n ; 'A'\n ; 'B'\n ; 'C'\n ; 'D'\n ; 'E'\n ; 'F'\n ]\n in\n String.gen_with_length (length_in_bytes * 2) char_generator\n |> Quickcheck.Generator.map\n ~f:(Fn.compose of_sha256 Digestif.SHA256.of_hex)\n end\n\n module Pending_coinbase_aux = struct\n let length_in_bits = 256\n\n let length_in_bytes = length_in_bits / 8\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = string [@@deriving sexp, equal, compare, hash]\n\n let to_latest = Fn.id\n\n module Base58_check = Base58_check.Make (struct\n let description = \"Pending coinbase aux\"\n\n let version_byte =\n Base58_check.Version_bytes.staged_ledger_hash_pending_coinbase_aux\n end)\n\n let to_base58_check s = Base58_check.encode s\n\n let of_base58_check_exn s = Base58_check.decode_exn s\n\n let to_yojson s = `String (to_base58_check s)\n\n let of_yojson = function\n | `String s -> (\n match Base58_check.decode s with\n | Ok x ->\n Ok x\n | Error e ->\n Error\n (sprintf\n \"Pending_coinbase_aux.of_yojson, bad Base58Check:%s\"\n (Error.to_string_hum e) ) )\n | _ ->\n Error \"Pending_coinbase_aux.of_yojson expected `String\"\n end\n end]\n\n [%%define_locally\n Stable.Latest.(to_yojson, of_yojson, to_base58_check, of_base58_check_exn)]\n\n let dummy : t = String.init length_in_bytes ~f:(fun _ -> '\\000')\n end\n\n module Non_snark = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = A.Non_snark.V1.t =\n { ledger_hash : Ledger_hash.Stable.V1.t\n ; aux_hash : Aux_hash.Stable.V1.t\n ; pending_coinbase_aux : Pending_coinbase_aux.Stable.V1.t\n }\n [@@deriving sexp, equal, compare, hash, yojson, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n type value = t [@@deriving sexp, compare, hash, yojson]\n\n let dummy : t Lazy.t =\n lazy\n { ledger_hash = Ledger_hash.empty_hash\n ; aux_hash = Aux_hash.dummy\n ; pending_coinbase_aux = Pending_coinbase_aux.dummy\n }\n\n let genesis ~genesis_ledger_hash : t =\n { ledger_hash = genesis_ledger_hash\n ; aux_hash = Aux_hash.dummy\n ; pending_coinbase_aux = Pending_coinbase_aux.dummy\n }\n\n type var = Boolean.var list\n\n let length_in_bits = 256\n\n let digest ({ ledger_hash; aux_hash; pending_coinbase_aux } : t) =\n let h = Digestif.SHA256.init () in\n let h =\n Digestif.SHA256.feed_string h (Ledger_hash.to_bytes ledger_hash)\n in\n let h = Digestif.SHA256.feed_string h aux_hash in\n let h = Digestif.SHA256.feed_string h pending_coinbase_aux in\n Digestif.SHA256.(get h |> to_raw_string)\n\n let fold t = Fold.string_bits (digest t)\n\n let to_input t =\n let open Random_oracle.Input.Chunked in\n Array.reduce_exn ~f:append\n (Array.of_list_map\n (Fold.to_list (fold t))\n ~f:(fun b -> packed (field_of_bool b, 1)) )\n\n let ledger_hash ({ ledger_hash; _ } : t) = ledger_hash\n\n let aux_hash ({ aux_hash; _ } : t) = aux_hash\n\n let of_ledger_aux_coinbase_hash aux_hash ledger_hash pending_coinbase_aux :\n t =\n { aux_hash; ledger_hash; pending_coinbase_aux }\n\n let var_to_input (t : var) =\n let open Random_oracle.Input.Chunked in\n Array.reduce_exn ~f:append\n (Array.of_list_map t ~f:(fun b -> packed ((b :> Field.Var.t), 1)))\n\n let var_of_t t : var =\n List.map (Fold.to_list @@ fold t) ~f:Boolean.var_of_value\n\n [%%if proof_level = \"check\"]\n\n let warn_improper_transport () = ()\n\n [%%else]\n\n let warn_improper_transport () =\n printf \"WARNING: improperly transporting staged-ledger-hash\\n\"\n\n [%%endif]\n\n let typ : (var, value) Typ.t =\n Typ.transport (Typ.list ~length:length_in_bits Boolean.typ)\n ~there:(Fn.compose Fold.to_list fold) ~back:(fun _ ->\n (* If we put a failwith here, we lose the ability to printf-inspect\n * anything that uses staged-ledger-hashes from within Checked\n * computations. It's useful when debugging to dump the protocol state\n * and so we can just lie here instead. *)\n warn_improper_transport () ; Lazy.force dummy )\n end\n\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('non_snark, 'pending_coinbase_hash) t =\n ('non_snark, 'pending_coinbase_hash) A.Poly.V1.t =\n { non_snark : 'non_snark\n ; pending_coinbase_hash : 'pending_coinbase_hash\n }\n [@@deriving sexp, equal, compare, hash, yojson, hlist]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n (** Staged ledger hash has two parts\n 1) merkle root of the pending coinbases\n 2) ledger hash, aux hash, and the FIFO order of the coinbase stacks(Non snark).\n Only part 1 is required for blockchain snark computation and therefore the remaining fields of the staged ledger are grouped together as \"Non_snark\"\n *)\n type t =\n ( Non_snark.Stable.V1.t\n , Pending_coinbase.Hash_versioned.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n type ('a, 'b) t_ = ('a, 'b) Poly.t\n\n type value = t [@@deriving sexp, equal, compare, hash]\n\n type var = (Non_snark.var, Pending_coinbase.Hash.var) t_\n\n include Hashable.Make (Stable.Latest)\n\n let ledger_hash ({ non_snark; _ } : t) = Non_snark.ledger_hash non_snark\n\n let aux_hash ({ non_snark; _ } : t) = Non_snark.aux_hash non_snark\n\n let pending_coinbase_aux ({ non_snark; _ } : t) =\n Non_snark.pending_coinbase_aux non_snark\n\n let pending_coinbase_hash ({ pending_coinbase_hash; _ } : t) =\n pending_coinbase_hash\n\n let pending_coinbase_hash_var ({ pending_coinbase_hash; _ } : var) =\n pending_coinbase_hash\n\n let of_aux_ledger_and_coinbase_hash aux_hash ledger_hash pending_coinbase : t\n =\n { non_snark =\n Non_snark.of_ledger_aux_coinbase_hash aux_hash ledger_hash\n (Pending_coinbase.hash_extra pending_coinbase)\n ; pending_coinbase_hash = Pending_coinbase.merkle_root pending_coinbase\n }\n\n let genesis ~(constraint_constants : Genesis_constants.Constraint_constants.t)\n ~genesis_ledger_hash : t =\n let pending_coinbase =\n Pending_coinbase.create ~depth:constraint_constants.pending_coinbase_depth\n ()\n |> Or_error.ok_exn\n in\n { non_snark = Non_snark.genesis ~genesis_ledger_hash\n ; pending_coinbase_hash = Pending_coinbase.merkle_root pending_coinbase\n }\n\n let var_of_t ({ pending_coinbase_hash; non_snark } : t) : var =\n let non_snark = Non_snark.var_of_t non_snark in\n let pending_coinbase_hash =\n Pending_coinbase.Hash.var_of_t pending_coinbase_hash\n in\n { non_snark; pending_coinbase_hash }\n\n let to_input ({ non_snark; pending_coinbase_hash } : t) =\n Random_oracle.Input.Chunked.(\n append\n (Non_snark.to_input non_snark)\n (field (pending_coinbase_hash :> Field.t)))\n\n let var_to_input ({ non_snark; pending_coinbase_hash } : var) =\n Random_oracle.Input.Chunked.(\n append\n (Non_snark.var_to_input non_snark)\n (field (Pending_coinbase.Hash.var_to_hash_packed pending_coinbase_hash)))\n\n let typ : (var, t) Typ.t =\n Typ.of_hlistable\n [ Non_snark.typ; Pending_coinbase.Hash.typ ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nopen Mina_base_util\nopen Mina_base_import\nmodule Wire_types = Mina_wire_types.Mina_base.Sok_message\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Sok_message_intf.Full with type Digest.t = A.Digest.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { fee : Currency.Fee.Stable.V1.t\n ; prover : Public_key.Compressed.Stable.V1.t\n }\n [@@deriving sexp, yojson, equal, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let create ~fee ~prover = Stable.Latest.{ fee; prover }\n\n module Digest = struct\n let length_in_bytes = Blake2.digest_size_in_bytes\n\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n type t = string [@@deriving sexp, hash, compare, equal, yojson]\n\n let to_latest = Fn.id\n\n include\n Binable.Of_binable_without_uuid\n (Core_kernel.String.Stable.V1)\n (struct\n type nonrec t = t\n\n let to_binable = Fn.id\n\n let of_binable s =\n assert (String.length s = length_in_bytes) ;\n s\n end)\n\n open Snark_params.Tick\n\n let to_input t =\n Random_oracle.Input.Chunked.packeds\n (Array.of_list_map\n Fold_lib.Fold.(to_list (string_bits t))\n ~f:(fun b -> (field_of_bool b, 1)) )\n\n let typ =\n Typ.array ~length:Blake2.digest_size_in_bits Boolean.typ\n |> Typ.transport ~there:Blake2.string_to_bits\n ~back:Blake2.bits_to_string\n end\n end]\n\n module Checked = struct\n open Snark_params.Tick\n\n type t = Boolean.var array\n\n let to_input (t : t) =\n Random_oracle.Input.Chunked.packeds\n (Array.map t ~f:(fun b -> ((b :> Field.Var.t), 1)))\n end\n\n [%%define_locally Stable.Latest.(to_input, typ)]\n\n let default = String.init length_in_bytes ~f:(fun _ -> '\\000')\n end\n\n let digest t =\n Blake2.to_raw_string\n (Blake2.digest_string (Binable.to_string (module Stable.Latest) t))\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\nmodule T = Mina_numbers.Length\n\n(*constants actually required for blockchain snark*)\n(* k\n ,c\n ,slots_per_epoch\n ,slots_per_sub_window\n ,sub_windows_per_window\n ,checkpoint_window_size_in_slots\n ,block_window_duration_ms*)\n\nmodule Poly = Genesis_constants.Protocol.Poly\n\nmodule Value = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n (T.Stable.V1.t, T.Stable.V1.t, Block_time.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving equal, ord, hash, sexp, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind k = Int.gen_incl 1 5000 in\n let%bind delta = Int.gen_incl 0 5000 in\n let%bind slots_per_epoch = Int.gen_incl k (8 * k) >>| ( * ) 3 >>| T.of_int\n and slots_per_sub_window = Int.gen_incl 1 ((k + 9) / 9) in\n (*TODO: Bug -> Block_time.(to_time x |> of_time) != x for certain values.\n Eg: 34702788243129 <--> 34702788243128, 8094 <--> 8093*)\n let%bind ms = Int64.(gen_log_uniform_incl 0L 9999999999999L) in\n let end_time = Block_time.of_int64 999999999999999L in\n let%map genesis_state_timestamp =\n Block_time.(gen_incl (of_int64 ms) end_time)\n in\n { Poly.k = T.of_int k\n ; delta = T.of_int delta\n ; slots_per_epoch\n ; slots_per_sub_window = T.of_int slots_per_sub_window\n ; genesis_state_timestamp\n }\nend\n\ntype value = Value.t\n\nlet value_of_t (t : Genesis_constants.Protocol.t) : value =\n { k = T.of_int t.k\n ; delta = T.of_int t.delta\n ; slots_per_epoch = T.of_int t.slots_per_epoch\n ; slots_per_sub_window = T.of_int t.slots_per_sub_window\n ; genesis_state_timestamp = Block_time.of_int64 t.genesis_state_timestamp\n }\n\nlet t_of_value (v : value) : Genesis_constants.Protocol.t =\n { k = T.to_int v.k\n ; delta = T.to_int v.delta\n ; slots_per_epoch = T.to_int v.slots_per_epoch\n ; slots_per_sub_window = T.to_int v.slots_per_sub_window\n ; genesis_state_timestamp = Block_time.to_int64 v.genesis_state_timestamp\n }\n\nlet to_input (t : value) =\n Array.reduce_exn ~f:Random_oracle.Input.Chunked.append\n [| T.to_input t.k\n ; T.to_input t.delta\n ; T.to_input t.slots_per_epoch\n ; T.to_input t.slots_per_sub_window\n ; Block_time.to_input t.genesis_state_timestamp\n |]\n\n[%%if defined consensus_mechanism]\n\ntype var = (T.Checked.t, T.Checked.t, Block_time.Checked.t) Poly.t\n\nlet typ =\n Typ.of_hlistable\n [ T.Checked.typ\n ; T.Checked.typ\n ; T.Checked.typ\n ; T.Checked.typ\n ; Block_time.Checked.typ\n ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\nlet var_to_input (var : var) =\n let k = T.Checked.to_input var.k\n and delta = T.Checked.to_input var.delta\n and slots_per_epoch = T.Checked.to_input var.slots_per_epoch\n and slots_per_sub_window = T.Checked.to_input var.slots_per_sub_window in\n let genesis_state_timestamp =\n Block_time.Checked.to_input var.genesis_state_timestamp\n in\n Array.reduce_exn ~f:Random_oracle.Input.Chunked.append\n [| k\n ; delta\n ; slots_per_epoch\n ; slots_per_sub_window\n ; genesis_state_timestamp\n |]\n\nlet%test_unit \"value = var\" =\n let compiled = Genesis_constants.for_unit_tests.protocol in\n let test protocol_constants =\n let open Snarky_backendless in\n let p_var =\n let%map p = exists typ ~compute:(As_prover0.return protocol_constants) in\n As_prover0.read typ p\n in\n let res = Or_error.ok_exn (run_and_check p_var) in\n [%test_eq: Value.t] res protocol_constants ;\n [%test_eq: Value.t] protocol_constants\n (t_of_value protocol_constants |> value_of_t)\n in\n Quickcheck.test ~trials:100 Value.gen\n ~examples:[ value_of_t compiled ]\n ~f:test\n\n[%%endif]\n","open Core_kernel\nopen Signature_lib\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Fee_with_prover.V1.t =\n { fee : Currency.Fee.Stable.V1.t\n ; prover : Public_key.Compressed.Stable.V1.t\n }\n [@@deriving sexp, yojson, hash]\n\n let to_latest = Fn.id\n\n module T = struct\n type typ = t [@@deriving sexp]\n\n type t = typ [@@deriving sexp]\n\n (* TODO: Compare in a better way than with public key, like in transaction pool *)\n let compare t1 t2 =\n let r = Currency.Fee.compare t1.fee t2.fee in\n if Int.( <> ) r 0 then r\n else Public_key.Compressed.compare t1.prover t2.prover\n end\n\n include Comparable.Make (T)\n end\nend]\n\ninclude Comparable.Make (Stable.V1.T)\n\nlet gen =\n Quickcheck.Generator.map2 Currency.Fee.gen Public_key.Compressed.gen\n ~f:(fun fee prover -> { fee; prover })\n","open Core_kernel\nopen Mina_base\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type 'command t = 'command Mina_wire_types.Mina_transaction.Poly.V2.t =\n | Command of 'command\n | Fee_transfer of Fee_transfer.Stable.V2.t\n | Coinbase of Coinbase.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n\n let map t ~f =\n match t with\n | Command x ->\n Command (f x)\n | Fee_transfer x ->\n Fee_transfer x\n | Coinbase x ->\n Coinbase x\n end\n end]\nend\n\nmodule Valid = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = User_command.Valid.Stable.V2.t Poly.Stable.V2.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include Hashable.Make (Stable.Latest)\n include Comparable.Make (Stable.Latest)\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = User_command.Stable.V2.t Poly.Stable.V2.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\ninclude Hashable.Make (Stable.Latest)\ninclude Comparable.Make (Stable.Latest)\n\ntype 'command t_ = 'command Poly.t =\n | Command of 'command\n | Fee_transfer of Fee_transfer.t\n | Coinbase of Coinbase.t\n\nlet to_valid_unsafe :\n t -> [ `If_this_is_used_it_should_have_a_comment_justifying_it of Valid.t ]\n = function\n | Command t ->\n let (`If_this_is_used_it_should_have_a_comment_justifying_it t') =\n User_command.to_valid_unsafe t\n in\n `If_this_is_used_it_should_have_a_comment_justifying_it (Command t')\n | Fee_transfer t ->\n `If_this_is_used_it_should_have_a_comment_justifying_it (Fee_transfer t)\n | Coinbase t ->\n `If_this_is_used_it_should_have_a_comment_justifying_it (Coinbase t)\n\nlet forget : Valid.t -> t = function\n | Command t ->\n Command (User_command.forget_check t)\n | Fee_transfer t ->\n Fee_transfer t\n | Coinbase t ->\n Coinbase t\n\nlet fee_excess : t -> Fee_excess.t Or_error.t = function\n | Command (Signed_command t) ->\n Ok (Signed_command.fee_excess t)\n | Command (Zkapp_command ps) ->\n Ok (Zkapp_command.fee_excess ps)\n | Fee_transfer t ->\n Fee_transfer.fee_excess t\n | Coinbase t ->\n Coinbase.fee_excess t\n\nlet expected_supply_increase = function\n | Command _ | Fee_transfer _ ->\n Ok Currency.Amount.zero\n | Coinbase t ->\n Coinbase.expected_supply_increase t\n\nlet public_keys (t : t) =\n let account_ids =\n match t with\n | Command (Signed_command cmd) ->\n Signed_command.accounts_referenced cmd\n | Command (Zkapp_command t) ->\n Zkapp_command.accounts_referenced t\n | Fee_transfer ft ->\n Fee_transfer.receivers ft\n | Coinbase cb ->\n Coinbase.accounts_referenced cb\n in\n List.map account_ids ~f:Account_id.public_key\n\nlet account_access_statuses (t : t) (status : Transaction_status.t) =\n match t with\n | Command (Signed_command cmd) ->\n Signed_command.account_access_statuses cmd status\n | Command (Zkapp_command t) ->\n Zkapp_command.account_access_statuses t status\n | Fee_transfer ft ->\n assert (Transaction_status.equal Applied status) ;\n List.map (Fee_transfer.receivers ft) ~f:(fun acct_id ->\n (acct_id, `Accessed) )\n | Coinbase cb ->\n Coinbase.account_access_statuses cb status\n\nlet accounts_referenced (t : t) =\n List.map (account_access_statuses t Applied) ~f:(fun (acct_id, _status) ->\n acct_id )\n\nlet fee_payer_pk (t : t) =\n match t with\n | Command (Signed_command cmd) ->\n Signed_command.fee_payer_pk cmd\n | Command (Zkapp_command t) ->\n Zkapp_command.fee_payer_pk t\n | Fee_transfer ft ->\n Fee_transfer.fee_payer_pk ft\n | Coinbase cb ->\n Coinbase.fee_payer_pk cb\n\nlet valid_size ~genesis_constants (t : t) =\n match t with\n | Command cmd ->\n User_command.valid_size ~genesis_constants cmd\n | Fee_transfer _ | Coinbase _ ->\n Ok ()\n\nlet check_well_formedness ~genesis_constants (t : t) =\n match t with\n | Command cmd ->\n User_command.check_well_formedness ~genesis_constants cmd\n | Fee_transfer _ | Coinbase _ ->\n Ok ()\n\nlet yojson_summary_of_command =\n let mk_record type_ memo signature =\n `List\n [ `String type_\n ; `String (Signature.to_base58_check signature)\n ; `String (Signed_command_memo.to_string_hum memo)\n ]\n in\n function\n | User_command.Zkapp_command cmd ->\n mk_record \"zkapp\" (Zkapp_command.memo cmd)\n ( Zkapp_command.fee_payer_account_update cmd\n |> Account_update.Fee_payer.authorization )\n | Signed_command cmd ->\n mk_record \"payment\" (Signed_command.memo cmd)\n (Signed_command.signature cmd)\n\nlet yojson_summary = function\n | Command cmd ->\n yojson_summary_of_command cmd\n | Fee_transfer _ ->\n `List [ `String \"fee_transfer\" ]\n | Coinbase cb ->\n let amount = Currency.Amount.to_yojson @@ Coinbase.amount cb in\n `List [ `String \"coinbase\"; amount ]\n\nlet yojson_summary_with_status cmd_with_status =\n let status =\n Transaction_status.to_yojson (With_status.status cmd_with_status)\n in\n match yojson_summary (With_status.data cmd_with_status) with\n | `List lst ->\n `List (lst @ [ status ])\n","open Core_kernel\nopen Mina_base\n\n[%%import \"/src/config.mlh\"]\n\nmodule T = struct\n include Blake2.Make ()\nend\n\ninclude T\n\nmodule Base58_check = Codable.Make_base58_check (struct\n type t = Stable.Latest.t [@@deriving bin_io_unversioned]\n\n let version_byte = Base58_check.Version_bytes.transaction_hash\n\n let description = \"Transaction hash\"\nend)\n\n[%%define_locally\nBase58_check.(of_base58_check, of_base58_check_exn, to_base58_check)]\n\nlet to_yojson t = `String (to_base58_check t)\n\nlet of_yojson = function\n | `String str ->\n Result.map_error (of_base58_check str) ~f:(fun _ ->\n \"Transaction_hash.of_yojson: Error decoding string from base58_check \\\n format\" )\n | _ ->\n Error \"Transaction_hash.of_yojson: Expected a string\"\n\nlet ( hash_signed_command_v1\n , hash_signed_command\n , hash_zkapp_command\n , hash_coinbase\n , hash_fee_transfer ) =\n let mk_hasher (type a) (module M : Bin_prot.Binable.S with type t = a)\n (cmd : a) =\n cmd |> Binable.to_string (module M) |> digest_string\n in\n let signed_cmd_hasher_v1 =\n mk_hasher\n ( module struct\n include Signed_command.Stable.V1\n end )\n in\n let signed_cmd_hasher = mk_hasher (module Signed_command.Stable.Latest) in\n let zkapp_cmd_hasher = mk_hasher (module Zkapp_command.Stable.Latest) in\n (* replace actual signatures, proofs with dummies for hashing, so we can\n reproduce the transaction hashes if signatures, proofs omitted in\n archive db\n *)\n let hash_signed_command_v1 (cmd : Signed_command.Stable.V1.t) =\n let cmd_dummy_signature = { cmd with signature = Signature.dummy } in\n signed_cmd_hasher_v1 cmd_dummy_signature\n in\n let hash_signed_command (cmd : Signed_command.t) =\n let cmd_dummy_signature = { cmd with signature = Signature.dummy } in\n signed_cmd_hasher cmd_dummy_signature\n in\n let hash_zkapp_command (cmd : Zkapp_command.t) =\n let cmd_dummy_signatures_and_proofs =\n { cmd with\n fee_payer = { cmd.fee_payer with authorization = Signature.dummy }\n ; account_updates =\n Zkapp_command.Call_forest.map cmd.account_updates\n ~f:(fun (acct_update : Account_update.t) ->\n let dummy_auth =\n match acct_update.authorization with\n | Control.Proof _ ->\n Control.Proof (Lazy.force Proof.transaction_dummy)\n | Control.Signature _ ->\n Control.Signature Signature.dummy\n | Control.None_given ->\n Control.None_given\n in\n { acct_update with authorization = dummy_auth } )\n }\n in\n zkapp_cmd_hasher cmd_dummy_signatures_and_proofs\n in\n (* no signatures to replace for internal commands *)\n let hash_coinbase = mk_hasher (module Mina_base.Coinbase.Stable.Latest) in\n let hash_fee_transfer =\n mk_hasher (module Fee_transfer.Single.Stable.Latest)\n in\n ( hash_signed_command_v1\n , hash_signed_command\n , hash_zkapp_command\n , hash_coinbase\n , hash_fee_transfer )\n\n[%%ifdef consensus_mechanism]\n\nlet hash_command cmd =\n match cmd with\n | User_command.Signed_command s ->\n hash_signed_command s\n | User_command.Zkapp_command p ->\n hash_zkapp_command p\n\nlet hash_signed_command_v2 = hash_signed_command\n\nlet hash_of_transaction_id (transaction_id : string) : t Or_error.t =\n (* A transaction id might be:\n - original Base58Check transaction ids of signed commands (Signed_command.V1.t), or\n - a Base64 encoding of signed commands and zkApps (Signed_command.Vn.t, for n >= 2,\n or Zkapp_command.Vm.t, for m >= 1)\n\n For the Base64 case, the Bin_prot serialization leads with a version tag\n *)\n match Signed_command.of_base58_check_exn_v1 transaction_id with\n | Ok cmd_v1 ->\n Ok (hash_signed_command_v1 cmd_v1)\n | Error _ -> (\n match Base64.decode transaction_id with\n | Ok s -> (\n let len = String.length s in\n let buf = Bin_prot.Common.create_buf len in\n Bin_prot.Common.blit_string_buf s buf ~len ;\n let pos_ref = ref 0 in\n let version = Bin_prot.Std.bin_read_int ~pos_ref buf in\n match version with\n | 1 -> (\n (* must be a zkApp command *)\n try\n let cmd = Zkapp_command.Stable.Latest.bin_read_t ~pos_ref buf in\n Ok (hash_zkapp_command cmd)\n with _ ->\n Or_error.error_string\n \"Could not decode serialized zkApp command (version 1)\" )\n | 2 -> (\n (* must be a signed command, until there's a V2 for zkApp commands *)\n try\n let cmd = Signed_command.Stable.V2.bin_read_t ~pos_ref buf in\n Ok (hash_signed_command_v2 cmd)\n with _ ->\n Or_error.error_string\n \"Could not decode serialized signed command (version 2)\" )\n | _ ->\n Or_error.error_string\n (sprintf\n \"Transaction hashing not implemented for command with \\\n version %d\"\n version ) )\n | Error _ ->\n Or_error.error_string\n \"Could not decode transaction id as either Base58Check or Base64\" )\n\nmodule User_command_with_valid_signature = struct\n type hash = T.t [@@deriving sexp, compare, hash]\n\n let hash_to_yojson = to_yojson\n\n let hash_of_yojson = of_yojson\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( (User_command.Valid.Stable.V2.t[@hash.ignore])\n , (T.Stable.V1.t[@to_yojson hash_to_yojson]) )\n With_hash.Stable.V1.t\n [@@deriving sexp, hash, to_yojson]\n\n let to_latest = Fn.id\n\n (* Compare only on hashes, comparing on the data too would be slower and\n add no value.\n *)\n let compare (x : t) (y : t) = T.compare x.hash y.hash\n end\n end]\n\n let create (c : User_command.Valid.t) : t =\n { data = c; hash = hash_command (User_command.forget_check c) }\n\n let data ({ data; _ } : t) = data\n\n let command ({ data; _ } : t) = User_command.forget_check data\n\n let hash ({ hash; _ } : t) = hash\n\n let forget_check ({ data; hash } : t) =\n { With_hash.data = User_command.forget_check data; hash }\n\n include Comparable.Make (Stable.Latest)\n\n let make data hash : t = { data; hash }\nend\n\nmodule User_command = struct\n type hash = T.t [@@deriving sexp, compare, hash]\n\n let hash_to_yojson = to_yojson\n\n let hash_of_yojson = of_yojson\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( (User_command.Stable.V2.t[@hash.ignore])\n , (T.Stable.V1.t[@to_yojson hash_to_yojson]) )\n With_hash.Stable.V1.t\n [@@deriving sexp, hash, to_yojson]\n\n let to_latest = Fn.id\n\n (* Compare only on hashes, comparing on the data too would be slower and\n add no value.\n *)\n let compare (x : t) (y : t) = T.compare x.hash y.hash\n end\n end]\n\n let create (c : User_command.t) : t = { data = c; hash = hash_command c }\n\n let data ({ data; _ } : t) = data\n\n let command ({ data; _ } : t) = data\n\n let hash ({ hash; _ } : t) = hash\n\n let of_checked ({ data; hash } : User_command_with_valid_signature.t) : t =\n { With_hash.data = User_command.forget_check data; hash }\n\n include Comparable.Make (Stable.Latest)\nend\n\nlet%test_module \"Transaction hashes\" =\n ( module struct\n let run_test ~transaction_id ~expected_hash =\n let hash =\n match hash_of_transaction_id transaction_id with\n | Ok hash ->\n to_base58_check hash\n | Error err ->\n failwithf \"Error getting hash: %s\" (Error.to_string_hum err) ()\n in\n String.equal hash expected_hash\n\n let%test \"signed command v1 hash from transaction id\" =\n let transaction_id =\n \"BD421DxjdoLimeUh4RA4FEvHdDn6bfxyMVWiWUwbYzQkqhNUv8B5M4gCSREpu9mVueBYoHYWkwB8BMf6iS2jjV8FffvPGkuNeczBfY7YRwLuUGBRCQJ3ktFBrNuu4abqgkYhXmcS2xyzoSGxHbXkJRAokTwjQ9HP6TLSeXz9qa92nJaTeccMnkoZBmEitsZWWnTCMqDc6rhN4Z9UMpg4wzdPMwNJvLRuJBD14Dd5pR84KBoY9rrnv66rHPc4m2hH9QSEt4aEJC76BQ446pHN9ZLmyhrk28f5xZdBmYxp3hV13fJEJ3Gv1XqJMBqFxRhzCVGoKDbLAaNRb5F1u1WxTzJu5n4cMMDEYydGEpNirY2PKQqHkR8gEqjXRTkpZzP8G19qT\"\n in\n let expected_hash =\n \"5JuV53FPXad1QLC46z7wsou9JjjYP87qaUeryscZqLUMmLSg8j2n\"\n in\n run_test ~transaction_id ~expected_hash\n\n let%test \"signed command v2 hash from transaction id\" =\n let transaction_id =\n \"Av0IlDV3VklWpVXVRQr7cidImXn8E9nqCAxPjuyUNZ2pu3pJJxkBAAD//yIAIKTVOZ2q1qG1KT11p6844pWJ3fQug1XGnzv2S3N73azIABXhN3d+nO04Y7YqBul1CY5CEq9o34KWvfcB8IWep3kkAf60JFZJVqVV1UUK+3InSJl5/BPZ6ggMT47slDWdqbt6SScZAQEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=\"\n in\n let expected_hash =\n \"5JvBt4173K3t7gQSpFoMGtbtZuYWPSg29cWad5pnnRd9BnAowoqY\"\n in\n run_test ~transaction_id ~expected_hash\n\n (* To regenerate:\n * Run dune in this library's directory\n dune utop src/lib/transaction\n * Generate a zkapp transaction:\n let txn = let txn = (Lazy.force Mina_base.Zkapp_command.dummy) in {txn with account_updates = Mina_base.Zkapp_command.Call_forest.map txn.account_updates ~f:(fun x -> {x with Mina_base.Account_update.authorization= Proof (Lazy.force Mina_base.Proof.blockchain_dummy)})};;\n * Print the transaction:\n Core_kernel.Out_channel.with_file \"txn_id\" ~f:(fun file -> Out_channel.output_string file (Core_kernel.Binable.to_string (module Mina_base.User_command.Stable.V2) (Zkapp_command txn) |> Base64.encode |> (function Ok x -> x | Error _ -> \"\")));;\n * Get the hash:\n Mina_transaction.Transaction_hash.(hash_command (Zkapp_command txn) |> to_base58_check);;\n *)\n\n let%test \"zkApp v1 hash from transaction id\" =\n let transaction_id =\n \"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\"\n in\n let expected_hash =\n \"5JtWZqwvKEgSMSHbDhYXg6s76GhfBNscQtxLKXnT6YYTsUKQkcpV\"\n in\n run_test ~transaction_id ~expected_hash\n end )\n\n[%%endif]\n","open Core_kernel\nopen Mina_base\nopen Currency\nopen Signature_lib\nopen Mina_transaction\nmodule Zkapp_command_logic = Zkapp_command_logic\nmodule Global_slot_since_genesis = Mina_numbers.Global_slot_since_genesis\n\nmodule Transaction_applied = struct\n module UC = Signed_command\n\n module Signed_command_applied = struct\n module Common = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n { user_command : Signed_command.Stable.V2.t With_status.Stable.V2.t\n }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Body = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n | Payment of { new_accounts : Account_id.Stable.V2.t list }\n | Stake_delegation of\n { previous_delegate : Public_key.Compressed.Stable.V1.t option }\n | Failed\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = { common : Common.Stable.V2.t; body : Body.Stable.V2.t }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let new_accounts (t : t) =\n match t.body with\n | Payment { new_accounts; _ } ->\n new_accounts\n | Stake_delegation _ | Failed ->\n []\n end\n\n module Zkapp_command_applied = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { accounts :\n (Account_id.Stable.V2.t * Account.Stable.V2.t option) list\n ; command : Zkapp_command.Stable.V1.t With_status.Stable.V2.t\n ; new_accounts : Account_id.Stable.V2.t list\n }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Command_applied = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n | Signed_command of Signed_command_applied.Stable.V2.t\n | Zkapp_command of Zkapp_command_applied.Stable.V1.t\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Fee_transfer_applied = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n { fee_transfer : Fee_transfer.Stable.V2.t With_status.Stable.V2.t\n ; new_accounts : Account_id.Stable.V2.t list\n ; burned_tokens : Currency.Amount.Stable.V1.t\n }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Coinbase_applied = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n { coinbase : Coinbase.Stable.V1.t With_status.Stable.V2.t\n ; new_accounts : Account_id.Stable.V2.t list\n ; burned_tokens : Currency.Amount.Stable.V1.t\n }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Varying = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n | Command of Command_applied.Stable.V2.t\n | Fee_transfer of Fee_transfer_applied.Stable.V2.t\n | Coinbase of Coinbase_applied.Stable.V2.t\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n { previous_hash : Ledger_hash.Stable.V1.t\n ; varying : Varying.Stable.V2.t\n }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let burned_tokens : t -> Currency.Amount.t =\n fun { varying; _ } ->\n match varying with\n | Command _ ->\n Currency.Amount.zero\n | Fee_transfer f ->\n f.burned_tokens\n | Coinbase c ->\n c.burned_tokens\n\n let new_accounts : t -> Account_id.t list =\n fun { varying; _ } ->\n match varying with\n | Command c -> (\n match c with\n | Signed_command sc ->\n Signed_command_applied.new_accounts sc\n | Zkapp_command zc ->\n zc.new_accounts )\n | Fee_transfer f ->\n f.new_accounts\n | Coinbase c ->\n c.new_accounts\n\n let supply_increase : t -> Currency.Amount.Signed.t Or_error.t =\n fun t ->\n let open Or_error.Let_syntax in\n let burned_tokens = Currency.Amount.Signed.of_unsigned (burned_tokens t) in\n let account_creation_fees =\n let account_creation_fee_int =\n Genesis_constants.Constraint_constants.compiled.account_creation_fee\n |> Currency.Fee.to_nanomina_int\n in\n let num_accounts_created = List.length @@ new_accounts t in\n (* int type is OK, no danger of overflow *)\n Currency.Amount.(\n Signed.of_unsigned\n @@ of_nanomina_int_exn (account_creation_fee_int * num_accounts_created))\n in\n let txn : Transaction.t =\n match t.varying with\n | Command\n (Signed_command { common = { user_command = { data; _ }; _ }; _ }) ->\n Command (Signed_command data)\n | Command (Zkapp_command c) ->\n Command (Zkapp_command c.command.data)\n | Fee_transfer f ->\n Fee_transfer f.fee_transfer.data\n | Coinbase c ->\n Coinbase c.coinbase.data\n in\n let%bind expected_supply_increase =\n Transaction.expected_supply_increase txn\n in\n let rec process_decreases total = function\n | [] ->\n Some total\n | amt :: amts ->\n let%bind.Option sum =\n Currency.Amount.Signed.(add @@ negate amt) total\n in\n process_decreases sum amts\n in\n let total =\n process_decreases\n (Currency.Amount.Signed.of_unsigned expected_supply_increase)\n [ burned_tokens; account_creation_fees ]\n in\n Option.value_map total ~default:(Or_error.error_string \"overflow\")\n ~f:(fun v -> Ok v)\n\n let transaction_with_status : t -> Transaction.t With_status.t =\n fun { varying; _ } ->\n match varying with\n | Command (Signed_command uc) ->\n With_status.map uc.common.user_command ~f:(fun cmd ->\n Transaction.Command (User_command.Signed_command cmd) )\n | Command (Zkapp_command s) ->\n With_status.map s.command ~f:(fun c ->\n Transaction.Command (User_command.Zkapp_command c) )\n | Fee_transfer f ->\n With_status.map f.fee_transfer ~f:(fun f -> Transaction.Fee_transfer f)\n | Coinbase c ->\n With_status.map c.coinbase ~f:(fun c -> Transaction.Coinbase c)\n\n let transaction_status : t -> Transaction_status.t =\n fun { varying; _ } ->\n match varying with\n | Command\n (Signed_command { common = { user_command = { status; _ }; _ }; _ }) ->\n status\n | Command (Zkapp_command c) ->\n c.command.status\n | Fee_transfer f ->\n f.fee_transfer.status\n | Coinbase c ->\n c.coinbase.status\nend\n\nmodule type S = sig\n type ledger\n\n type location\n\n module Transaction_applied : sig\n module Signed_command_applied : sig\n module Common : sig\n type t = Transaction_applied.Signed_command_applied.Common.t =\n { user_command : Signed_command.t With_status.t }\n [@@deriving sexp]\n end\n\n module Body : sig\n type t = Transaction_applied.Signed_command_applied.Body.t =\n | Payment of { new_accounts : Account_id.t list }\n | Stake_delegation of\n { previous_delegate : Public_key.Compressed.t option }\n | Failed\n [@@deriving sexp]\n end\n\n type t = Transaction_applied.Signed_command_applied.t =\n { common : Common.t; body : Body.t }\n [@@deriving sexp]\n end\n\n module Zkapp_command_applied : sig\n type t = Transaction_applied.Zkapp_command_applied.t =\n { accounts : (Account_id.t * Account.t option) list\n ; command : Zkapp_command.t With_status.t\n ; new_accounts : Account_id.t list\n }\n [@@deriving sexp]\n end\n\n module Command_applied : sig\n type t = Transaction_applied.Command_applied.t =\n | Signed_command of Signed_command_applied.t\n | Zkapp_command of Zkapp_command_applied.t\n [@@deriving sexp]\n end\n\n module Fee_transfer_applied : sig\n type t = Transaction_applied.Fee_transfer_applied.t =\n { fee_transfer : Fee_transfer.t With_status.t\n ; new_accounts : Account_id.t list\n ; burned_tokens : Currency.Amount.t\n }\n [@@deriving sexp]\n end\n\n module Coinbase_applied : sig\n type t = Transaction_applied.Coinbase_applied.t =\n { coinbase : Coinbase.t With_status.t\n ; new_accounts : Account_id.t list\n ; burned_tokens : Currency.Amount.t\n }\n [@@deriving sexp]\n end\n\n module Varying : sig\n type t = Transaction_applied.Varying.t =\n | Command of Command_applied.t\n | Fee_transfer of Fee_transfer_applied.t\n | Coinbase of Coinbase_applied.t\n [@@deriving sexp]\n end\n\n type t = Transaction_applied.t =\n { previous_hash : Ledger_hash.t; varying : Varying.t }\n [@@deriving sexp]\n\n val burned_tokens : t -> Currency.Amount.t\n\n val supply_increase : t -> Currency.Amount.Signed.t Or_error.t\n\n val transaction : t -> Transaction.t With_status.t\n\n val transaction_status : t -> Transaction_status.t\n end\n\n module Global_state : sig\n type t =\n { first_pass_ledger : ledger\n ; second_pass_ledger : ledger\n ; fee_excess : Amount.Signed.t\n ; supply_increase : Amount.Signed.t\n ; protocol_state : Zkapp_precondition.Protocol_state.View.t\n ; block_global_slot : Mina_numbers.Global_slot_since_genesis.t\n (* Slot of block when the transaction is applied. NOTE: This is at least 1 slot after the protocol_state's view, which is for the *previous* slot. *)\n }\n end\n\n module Transaction_partially_applied : sig\n module Zkapp_command_partially_applied : sig\n type t =\n { command : Zkapp_command.t\n ; previous_hash : Ledger_hash.t\n ; original_first_pass_account_states :\n (Account_id.t * (location * Account.t) option) list\n ; constraint_constants : Genesis_constants.Constraint_constants.t\n ; state_view : Zkapp_precondition.Protocol_state.View.t\n ; global_state : Global_state.t\n ; local_state :\n ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , ledger\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n }\n end\n\n type 'applied fully_applied =\n { previous_hash : Ledger_hash.t; applied : 'applied }\n\n type t =\n | Signed_command of\n Transaction_applied.Signed_command_applied.t fully_applied\n | Zkapp_command of Zkapp_command_partially_applied.t\n | Fee_transfer of Transaction_applied.Fee_transfer_applied.t fully_applied\n | Coinbase of Transaction_applied.Coinbase_applied.t fully_applied\n\n val command : t -> Transaction.t\n end\n\n val apply_user_command :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> ledger\n -> Signed_command.With_valid_signature.t\n -> Transaction_applied.Signed_command_applied.t Or_error.t\n\n val apply_user_command_unchecked :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> ledger\n -> Signed_command.t\n -> Transaction_applied.Signed_command_applied.t Or_error.t\n\n val update_action_state :\n Snark_params.Tick.Field.t Pickles_types.Vector.Vector_5.t\n -> Zkapp_account.Actions.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> last_action_slot:Global_slot_since_genesis.t\n -> Snark_params.Tick.Field.t Pickles_types.Vector.Vector_5.t\n * Global_slot_since_genesis.t\n\n val apply_zkapp_command_unchecked :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> global_slot:Mina_numbers.Global_slot_since_genesis.t\n -> state_view:Zkapp_precondition.Protocol_state.View.t\n -> ledger\n -> Zkapp_command.t\n -> ( Transaction_applied.Zkapp_command_applied.t\n * ( ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , ledger\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n * Amount.Signed.t ) )\n Or_error.t\n\n (** Apply all zkapp_command within a zkapp_command transaction. This behaves as\n [apply_zkapp_command_unchecked], except that the [~init] and [~f] arguments\n are provided to allow for the accumulation of the intermediate states.\n\n Invariant: [f] is always applied at least once, so it is valid to use an\n [_ option] as the initial state and call [Option.value_exn] on the\n accumulated result.\n\n This can be used to collect the intermediate states to make them\n available for snark work. In particular, since the transaction snark has\n a cap on the number of zkapp_command of each kind that may be included, we can\n use this to retrieve the (source, target) pairs for each batch of\n zkapp_command to include in the snark work spec / transaction snark witness.\n *)\n val apply_zkapp_command_unchecked_aux :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> global_slot:Mina_numbers.Global_slot_since_genesis.t\n -> state_view:Zkapp_precondition.Protocol_state.View.t\n -> init:'acc\n -> f:\n ( 'acc\n -> Global_state.t\n * ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , ledger\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n -> 'acc )\n -> ?fee_excess:Amount.Signed.t\n -> ?supply_increase:Amount.Signed.t\n -> ledger\n -> Zkapp_command.t\n -> (Transaction_applied.Zkapp_command_applied.t * 'acc) Or_error.t\n\n val apply_zkapp_command_first_pass_aux :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> global_slot:Mina_numbers.Global_slot_since_genesis.t\n -> state_view:Zkapp_precondition.Protocol_state.View.t\n -> init:'acc\n -> f:\n ( 'acc\n -> Global_state.t\n * ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , ledger\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n -> 'acc )\n -> ?fee_excess:Amount.Signed.t\n -> ?supply_increase:Amount.Signed.t\n -> ledger\n -> Zkapp_command.t\n -> (Transaction_partially_applied.Zkapp_command_partially_applied.t * 'acc)\n Or_error.t\n\n val apply_zkapp_command_second_pass_aux :\n init:'acc\n -> f:\n ( 'acc\n -> Global_state.t\n * ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , ledger\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n -> 'acc )\n -> ledger\n -> Transaction_partially_applied.Zkapp_command_partially_applied.t\n -> (Transaction_applied.Zkapp_command_applied.t * 'acc) Or_error.t\n\n val apply_fee_transfer :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> ledger\n -> Fee_transfer.t\n -> Transaction_applied.Fee_transfer_applied.t Or_error.t\n\n val apply_coinbase :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> ledger\n -> Coinbase.t\n -> Transaction_applied.Coinbase_applied.t Or_error.t\n\n val apply_transaction_first_pass :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> global_slot:Global_slot_since_genesis.t\n -> txn_state_view:Zkapp_precondition.Protocol_state.View.t\n -> ledger\n -> Transaction.t\n -> Transaction_partially_applied.t Or_error.t\n\n val apply_transaction_second_pass :\n ledger\n -> Transaction_partially_applied.t\n -> Transaction_applied.t Or_error.t\n\n val apply_transactions :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> global_slot:Mina_numbers.Global_slot_since_genesis.t\n -> txn_state_view:Zkapp_precondition.Protocol_state.View.t\n -> ledger\n -> Transaction.t list\n -> Transaction_applied.t list Or_error.t\n\n val has_locked_tokens :\n global_slot:Global_slot_since_genesis.t\n -> account_id:Account_id.t\n -> ledger\n -> bool Or_error.t\n\n module For_tests : sig\n val validate_timing_with_min_balance :\n account:Account.t\n -> txn_amount:Amount.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> (Account.Timing.t * [> `Min_balance of Balance.t ]) Or_error.t\n\n val validate_timing :\n account:Account.t\n -> txn_amount:Amount.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> Account.Timing.t Or_error.t\n end\nend\n\n(* tags for timing validation errors *)\nlet nsf_tag = \"nsf\"\n\nlet min_balance_tag = \"minbal\"\n\nlet timing_error_to_user_command_status err =\n match Error.Internal_repr.of_info err with\n | Tag_t (tag, _) when String.equal tag nsf_tag ->\n Transaction_status.Failure.Source_insufficient_balance\n | Tag_t (tag, _) when String.equal tag min_balance_tag ->\n Transaction_status.Failure.Source_minimum_balance_violation\n | _ ->\n failwith \"Unexpected timed account validation error\"\n\n(** [validate_timing_with_min_balance' ~account ~txn_amount ~txn_global_slot]\n returns a tuple of 3 values:\n * [[`Insufficient_balance of bool | `Invalid_timing of bool]] encodes\n possible errors, with the invariant that the return value is always\n [`Invalid_timing false] if there was no error.\n - [`Insufficient_balance true] results if [txn_amount] is larger than the\n balance held in [account].\n - [`Invalid_timing true] results if [txn_amount] is larger than the\n balance available in [account] at global slot [txn_global_slot].\n * [Timing.t], the new timing for [account] calculated at [txn_global_slot].\n * [[`Min_balance of Balance.t]] returns the computed available balance at\n [txn_global_slot].\n - NOTE: We skip this calculation if the error is\n [`Insufficient_balance true]. In this scenario, this value MUST NOT be\n used, as it contains an incorrect placeholder value.\n*)\nlet validate_timing_with_min_balance' ~account ~txn_amount ~txn_global_slot =\n let open Account.Poly in\n let open Account.Timing.Poly in\n match account.timing with\n | Untimed -> (\n (* no time restrictions *)\n match Balance.(account.balance - txn_amount) with\n | None ->\n (`Insufficient_balance true, Untimed, `Min_balance Balance.zero)\n | _ ->\n (`Invalid_timing false, Untimed, `Min_balance Balance.zero) )\n | Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } ->\n let invalid_balance, invalid_timing, curr_min_balance =\n let account_balance = account.balance in\n match Balance.(account_balance - txn_amount) with\n | None ->\n (* NB: The [initial_minimum_balance] here is the incorrect value,\n but:\n * we don't use it anywhere in this error case; and\n * we don't want to waste time computing it if it will be unused.\n *)\n (true, false, initial_minimum_balance)\n | Some proposed_new_balance ->\n let curr_min_balance =\n Account.min_balance_at_slot ~global_slot:txn_global_slot\n ~cliff_time ~cliff_amount ~vesting_period ~vesting_increment\n ~initial_minimum_balance\n in\n if Balance.(proposed_new_balance < curr_min_balance) then\n (false, true, curr_min_balance)\n else (false, false, curr_min_balance)\n in\n (* once the calculated minimum balance becomes zero, the account becomes untimed *)\n let possibly_error =\n if invalid_balance then `Insufficient_balance invalid_balance\n else `Invalid_timing invalid_timing\n in\n if Balance.(curr_min_balance > zero) then\n (possibly_error, account.timing, `Min_balance curr_min_balance)\n else (possibly_error, Untimed, `Min_balance Balance.zero)\n\nlet validate_timing_with_min_balance ~account ~txn_amount ~txn_global_slot =\n let open Or_error.Let_syntax in\n let nsf_error kind =\n Or_error.errorf\n !\"For %s account, the requested transaction for amount %{sexp: Amount.t} \\\n at global slot %{sexp: Global_slot_since_genesis.t}, the balance \\\n %{sexp: Balance.t} is insufficient\"\n kind txn_amount txn_global_slot account.Account.Poly.balance\n |> Or_error.tag ~tag:nsf_tag\n in\n let min_balance_error min_balance =\n Or_error.errorf\n !\"For timed account, the requested transaction for amount %{sexp: \\\n Amount.t} at global slot %{sexp: Global_slot_since_genesis.t}, \\\n applying the transaction would put the balance below the calculated \\\n minimum balance of %{sexp: Balance.t}\"\n txn_amount txn_global_slot min_balance\n |> Or_error.tag ~tag:min_balance_tag\n in\n let possibly_error, timing, (`Min_balance curr_min_balance as min_balance) =\n validate_timing_with_min_balance' ~account ~txn_amount ~txn_global_slot\n in\n match possibly_error with\n | `Insufficient_balance true ->\n nsf_error \"timed\"\n | `Invalid_timing true ->\n min_balance_error curr_min_balance\n | `Insufficient_balance false ->\n failwith \"Broken invariant in validate_timing_with_min_balance'\"\n | `Invalid_timing false ->\n return (timing, min_balance)\n\nlet validate_timing ~account ~txn_amount ~txn_global_slot =\n let open Result.Let_syntax in\n let%map timing, `Min_balance _ =\n validate_timing_with_min_balance ~account ~txn_amount ~txn_global_slot\n in\n timing\n\nmodule Make (L : Ledger_intf.S) :\n S with type ledger := L.t and type location := L.location = struct\n open L\n\n let error s = Or_error.errorf \"Ledger.apply_transaction: %s\" s\n\n let error_opt e = Option.value_map ~default:(error e) ~f:Or_error.return\n\n let get_with_location ledger account_id =\n match location_of_account ledger account_id with\n | Some location -> (\n match get ledger location with\n | Some account ->\n Ok (`Existing location, account)\n | None ->\n failwith \"Ledger location with no account\" )\n | None ->\n Ok (`New, Account.create account_id Balance.zero)\n\n let set_with_location ledger location account =\n match location with\n | `Existing location ->\n Ok (set ledger location account)\n | `New ->\n create_new_account ledger (Account.identifier account) account\n\n let add_amount balance amount =\n error_opt \"overflow\" (Balance.add_amount balance amount)\n\n let sub_amount balance amount =\n error_opt \"insufficient funds\" (Balance.sub_amount balance amount)\n\n let sub_account_creation_fee\n ~(constraint_constants : Genesis_constants.Constraint_constants.t) action\n amount =\n let fee = constraint_constants.account_creation_fee in\n if Ledger_intf.equal_account_state action `Added then\n error_opt\n (sprintf\n !\"Error subtracting account creation fee %{sexp: Currency.Fee.t}; \\\n transaction amount %{sexp: Currency.Amount.t} insufficient\"\n fee amount )\n Amount.(sub amount (of_fee fee))\n else Ok amount\n\n let check b = ksprintf (fun s -> if b then Ok () else Or_error.error_string s)\n\n let validate_nonces txn_nonce account_nonce =\n check\n (Account.Nonce.equal account_nonce txn_nonce)\n !\"Nonce in account %{sexp: Account.Nonce.t} different from nonce in \\\n transaction %{sexp: Account.Nonce.t}\"\n account_nonce txn_nonce\n\n let validate_time ~valid_until ~current_global_slot =\n check\n Global_slot_since_genesis.(current_global_slot <= valid_until)\n !\"Current global slot %{sexp: Global_slot_since_genesis.t} greater than \\\n transaction expiry slot %{sexp: Global_slot_since_genesis.t}\"\n current_global_slot valid_until\n\n module Transaction_applied = struct\n include Transaction_applied\n\n let transaction : t -> Transaction.t With_status.t =\n fun { varying; _ } ->\n match varying with\n | Command (Signed_command uc) ->\n With_status.map uc.common.user_command ~f:(fun cmd ->\n Transaction.Command (User_command.Signed_command cmd) )\n | Command (Zkapp_command s) ->\n With_status.map s.command ~f:(fun c ->\n Transaction.Command (User_command.Zkapp_command c) )\n | Fee_transfer f ->\n With_status.map f.fee_transfer ~f:(fun f ->\n Transaction.Fee_transfer f )\n | Coinbase c ->\n With_status.map c.coinbase ~f:(fun c -> Transaction.Coinbase c)\n\n let transaction_status : t -> Transaction_status.t =\n fun { varying; _ } ->\n match varying with\n | Command\n (Signed_command { common = { user_command = { status; _ }; _ }; _ })\n ->\n status\n | Command (Zkapp_command c) ->\n c.command.status\n | Fee_transfer f ->\n f.fee_transfer.status\n | Coinbase c ->\n c.coinbase.status\n end\n\n let get_new_accounts action pk =\n if Ledger_intf.equal_account_state action `Added then [ pk ] else []\n\n let has_locked_tokens ~global_slot ~account_id ledger =\n let open Or_error.Let_syntax in\n let%map _, account = get_with_location ledger account_id in\n Account.has_locked_tokens ~global_slot account\n\n let failure (e : Transaction_status.Failure.t) = e\n\n let incr_balance (acct : Account.t) amt =\n match add_amount acct.balance amt with\n | Ok balance ->\n Ok { acct with balance }\n | Error _ ->\n Result.fail (failure Overflow)\n\n (* Helper function for [apply_user_command_unchecked] *)\n let pay_fee' ~command ~nonce ~fee_payer ~fee ~ledger ~current_global_slot =\n let open Or_error.Let_syntax in\n (* Fee-payer information *)\n let%bind location, account = get_with_location ledger fee_payer in\n let%bind () =\n match location with\n | `Existing _ ->\n return ()\n | `New ->\n Or_error.errorf \"The fee-payer account does not exist\"\n in\n let fee = Amount.of_fee fee in\n let%bind balance = sub_amount account.balance fee in\n let%bind () = validate_nonces nonce account.nonce in\n let%map timing =\n validate_timing ~txn_amount:fee ~txn_global_slot:current_global_slot\n ~account\n in\n ( location\n , { account with\n balance\n ; nonce = Account.Nonce.succ account.nonce\n ; receipt_chain_hash =\n Receipt.Chain_hash.cons_signed_command_payload command\n account.receipt_chain_hash\n ; timing\n } )\n\n (* Helper function for [apply_user_command_unchecked] *)\n let pay_fee ~user_command ~signer_pk ~ledger ~current_global_slot =\n let open Or_error.Let_syntax in\n (* Fee-payer information *)\n let nonce = Signed_command.nonce user_command in\n let fee_payer = Signed_command.fee_payer user_command in\n let%bind () =\n let fee_token = Signed_command.fee_token user_command in\n let%bind () =\n (* TODO: Enable multi-sig. *)\n if\n Public_key.Compressed.equal\n (Account_id.public_key fee_payer)\n signer_pk\n then return ()\n else\n Or_error.errorf\n \"Cannot pay fees from a public key that did not sign the \\\n transaction\"\n in\n let%map () =\n (* TODO: Remove this check and update the transaction snark once we have\n an exchange rate mechanism. See issue #4447.\n *)\n if Token_id.equal fee_token Token_id.default then return ()\n else\n Or_error.errorf\n \"Cannot create transactions with fee_token different from the \\\n default\"\n in\n ()\n in\n let%map loc, account' =\n pay_fee' ~command:(Signed_command_payload user_command.payload) ~nonce\n ~fee_payer\n ~fee:(Signed_command.fee user_command)\n ~ledger ~current_global_slot\n in\n (loc, account')\n\n (* someday: It would probably be better if we didn't modify the receipt chain hash\n in the case that the sender is equal to the receiver, but it complicates the SNARK, so\n we don't for now. *)\n let apply_user_command_unchecked\n ~(constraint_constants : Genesis_constants.Constraint_constants.t)\n ~txn_global_slot ledger\n ({ payload; signer; signature = _ } as user_command : Signed_command.t) =\n let open Or_error.Let_syntax in\n let signer_pk = Public_key.compress signer in\n let current_global_slot = txn_global_slot in\n let%bind () =\n validate_time\n ~valid_until:(Signed_command.valid_until user_command)\n ~current_global_slot\n in\n (* Fee-payer information *)\n let fee_payer = Signed_command.fee_payer user_command in\n let%bind fee_payer_location, fee_payer_account =\n pay_fee ~user_command ~signer_pk ~ledger ~current_global_slot\n in\n let%bind () =\n if Account.has_permission_to_send fee_payer_account then Ok ()\n else\n Or_error.error_string\n Transaction_status.Failure.(describe Update_not_permitted_balance)\n in\n let%bind () =\n if Account.has_permission_to_increment_nonce fee_payer_account then Ok ()\n else\n Or_error.error_string\n Transaction_status.Failure.(describe Update_not_permitted_nonce)\n in\n (* Charge the fee. This must happen, whether or not the command itself\n succeeds, to ensure that the network is compensated for processing this\n command.\n *)\n let%bind () =\n set_with_location ledger fee_payer_location fee_payer_account\n in\n let receiver = Signed_command.receiver user_command in\n let exception Reject of Error.t in\n let ok_or_reject = function Ok x -> x | Error err -> raise (Reject err) in\n let compute_updates () =\n let open Result.Let_syntax in\n (* Compute the necessary changes to apply the command, failing if any of\n the conditions are not met.\n *)\n match payload.body with\n | Stake_delegation _ ->\n let receiver_location, _receiver_account =\n (* Check that receiver account exists. *)\n get_with_location ledger receiver |> ok_or_reject\n in\n let%bind () =\n match receiver_location with\n | `Existing _ ->\n return ()\n | `New ->\n Result.fail Transaction_status.Failure.Receiver_not_present\n in\n let%bind () =\n Result.ok_if_true\n (Account.has_permission_to_set_delegate fee_payer_account)\n ~error:Transaction_status.Failure.Update_not_permitted_delegate\n in\n let previous_delegate = fee_payer_account.delegate in\n (* Timing is always valid, but we need to record any switch from\n timed to untimed here to stay in sync with the snark.\n *)\n let%map fee_payer_account =\n let%map timing =\n validate_timing ~txn_amount:Amount.zero\n ~txn_global_slot:current_global_slot ~account:fee_payer_account\n |> Result.map_error ~f:timing_error_to_user_command_status\n in\n { fee_payer_account with\n delegate = Some (Account_id.public_key receiver)\n ; timing\n }\n in\n ( [ (fee_payer_location, fee_payer_account) ]\n , Transaction_applied.Signed_command_applied.Body.Stake_delegation\n { previous_delegate } )\n | Payment { amount; _ } ->\n let%bind fee_payer_account =\n let ret =\n let%bind balance =\n Result.map_error (sub_amount fee_payer_account.balance amount)\n ~f:(fun _ ->\n Transaction_status.Failure.Source_insufficient_balance )\n in\n let%map timing =\n validate_timing ~txn_amount:amount\n ~txn_global_slot:current_global_slot\n ~account:fee_payer_account\n |> Result.map_error ~f:timing_error_to_user_command_status\n in\n { fee_payer_account with balance; timing }\n in\n (* Don't accept transactions with insufficient balance from the fee-payer.\n TODO: eliminate this condition and accept transaction with failed status\n *)\n match ret with\n | Ok x ->\n Ok x\n | Error failure ->\n raise\n (Reject\n (Error.createf \"%s\"\n (Transaction_status.Failure.describe failure) ) )\n in\n let receiver_location, receiver_account =\n if Account_id.equal fee_payer receiver then\n (fee_payer_location, fee_payer_account)\n else get_with_location ledger receiver |> ok_or_reject\n in\n let%bind () =\n Result.ok_if_true\n (Account.has_permission_to_send fee_payer_account)\n ~error:Transaction_status.Failure.Update_not_permitted_balance\n in\n let%bind () =\n Result.ok_if_true\n (Account.has_permission_to_receive receiver_account)\n ~error:Transaction_status.Failure.Update_not_permitted_balance\n in\n (* Charge the account creation fee. *)\n let%bind receiver_amount =\n match receiver_location with\n | `Existing _ ->\n return amount\n | `New ->\n (* Subtract the creation fee from the transaction amount. *)\n sub_account_creation_fee ~constraint_constants `Added amount\n |> Result.map_error ~f:(fun _ ->\n Transaction_status.Failure\n .Amount_insufficient_to_create_account )\n in\n let%map receiver_account =\n incr_balance receiver_account receiver_amount\n in\n let new_accounts =\n match receiver_location with\n | `Existing _ ->\n []\n | `New ->\n [ receiver ]\n in\n let updated_accounts =\n if Account_id.equal fee_payer receiver then\n (* [receiver_account] at this point has all the updates*)\n [ (receiver_location, receiver_account) ]\n else\n [ (receiver_location, receiver_account)\n ; (fee_payer_location, fee_payer_account)\n ]\n in\n ( updated_accounts\n , Transaction_applied.Signed_command_applied.Body.Payment\n { new_accounts } )\n in\n match compute_updates () with\n | Ok (located_accounts, applied_body) ->\n (* Update the ledger. *)\n let%bind () =\n List.fold located_accounts ~init:(Ok ())\n ~f:(fun acc (location, account) ->\n let%bind () = acc in\n set_with_location ledger location account )\n in\n let applied_common : Transaction_applied.Signed_command_applied.Common.t\n =\n { user_command = { data = user_command; status = Applied } }\n in\n return\n ( { common = applied_common; body = applied_body }\n : Transaction_applied.Signed_command_applied.t )\n | Error failure ->\n (* Do not update the ledger. Except for the fee payer which is already updated *)\n let applied_common : Transaction_applied.Signed_command_applied.Common.t\n =\n { user_command =\n { data = user_command\n ; status =\n Failed\n (Transaction_status.Failure.Collection.of_single_failure\n failure )\n }\n }\n in\n return\n ( { common = applied_common; body = Failed }\n : Transaction_applied.Signed_command_applied.t )\n | exception Reject err ->\n (* TODO: These transactions should never reach this stage, this error\n should be fatal.\n *)\n Error err\n\n let apply_user_command ~constraint_constants ~txn_global_slot ledger\n (user_command : Signed_command.With_valid_signature.t) =\n apply_user_command_unchecked ~constraint_constants ~txn_global_slot ledger\n (Signed_command.forget_check user_command)\n\n module Global_state = struct\n type t =\n { first_pass_ledger : L.t\n ; second_pass_ledger : L.t\n ; fee_excess : Amount.Signed.t\n ; supply_increase : Amount.Signed.t\n ; protocol_state : Zkapp_precondition.Protocol_state.View.t\n ; block_global_slot : Global_slot_since_genesis.t\n }\n\n let first_pass_ledger { first_pass_ledger; _ } =\n L.create_masked first_pass_ledger\n\n let set_first_pass_ledger ~should_update t ledger =\n if should_update then L.apply_mask t.first_pass_ledger ~masked:ledger ;\n t\n\n let second_pass_ledger { second_pass_ledger; _ } =\n L.create_masked second_pass_ledger\n\n let set_second_pass_ledger ~should_update t ledger =\n if should_update then L.apply_mask t.second_pass_ledger ~masked:ledger ;\n t\n\n let fee_excess { fee_excess; _ } = fee_excess\n\n let set_fee_excess t fee_excess = { t with fee_excess }\n\n let supply_increase { supply_increase; _ } = supply_increase\n\n let set_supply_increase t supply_increase = { t with supply_increase }\n\n let block_global_slot { block_global_slot; _ } = block_global_slot\n end\n\n module Transaction_partially_applied = struct\n module Zkapp_command_partially_applied = struct\n type t =\n { command : Zkapp_command.t\n ; previous_hash : Ledger_hash.t\n ; original_first_pass_account_states :\n (Account_id.t * (location * Account.t) option) list\n ; constraint_constants : Genesis_constants.Constraint_constants.t\n ; state_view : Zkapp_precondition.Protocol_state.View.t\n ; global_state : Global_state.t\n ; local_state :\n ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , L.t\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n }\n end\n\n type 'applied fully_applied =\n { previous_hash : Ledger_hash.t; applied : 'applied }\n\n (* TODO: lift previous_hash up in the types *)\n type t =\n | Signed_command of\n Transaction_applied.Signed_command_applied.t fully_applied\n | Zkapp_command of Zkapp_command_partially_applied.t\n | Fee_transfer of Transaction_applied.Fee_transfer_applied.t fully_applied\n | Coinbase of Transaction_applied.Coinbase_applied.t fully_applied\n\n let command (t : t) : Transaction.t =\n match t with\n | Signed_command s ->\n Transaction.Command\n (User_command.Signed_command s.applied.common.user_command.data)\n | Zkapp_command z ->\n Command (User_command.Zkapp_command z.command)\n | Fee_transfer f ->\n Fee_transfer f.applied.fee_transfer.data\n | Coinbase c ->\n Coinbase c.applied.coinbase.data\n end\n\n module Inputs = struct\n let with_label ~label:_ f = f ()\n\n let value_if b ~then_ ~else_ = if b then then_ else else_\n\n module Global_state = Global_state\n\n module Field = struct\n type t = Snark_params.Tick.Field.t\n\n let if_ = value_if\n\n let equal = Snark_params.Tick.Field.equal\n end\n\n module Bool = struct\n type t = bool\n\n module Assert = struct\n let is_true ~pos b =\n try assert b\n with Assert_failure _ ->\n let file, line, col, _ecol = pos in\n raise (Assert_failure (file, line, col))\n\n let any ~pos bs = List.exists ~f:Fn.id bs |> is_true ~pos\n end\n\n let if_ = value_if\n\n let true_ = true\n\n let false_ = false\n\n let equal = Bool.equal\n\n let not = not\n\n let ( ||| ) = ( || )\n\n let ( &&& ) = ( && )\n\n let display b ~label = sprintf \"%s: %b\" label b\n\n let all = List.for_all ~f:Fn.id\n\n type failure_status = Transaction_status.Failure.t option\n\n type failure_status_tbl = Transaction_status.Failure.Collection.t\n\n let is_empty t = List.join t |> List.is_empty\n\n let assert_with_failure_status_tbl ~pos b failure_status_tbl =\n let file, line, col, ecol = pos in\n if (not b) && not (is_empty failure_status_tbl) then\n (* Raise a more useful error message if we have a failure\n description. *)\n let failure_msg =\n Yojson.Safe.to_string\n @@ Transaction_status.Failure.Collection.Display.to_yojson\n @@ Transaction_status.Failure.Collection.to_display\n failure_status_tbl\n in\n Error.raise @@ Error.of_string\n @@ sprintf \"File %S, line %d, characters %d-%d: %s\" file line col ecol\n failure_msg\n else\n try assert b\n with Assert_failure _ -> raise (Assert_failure (file, line, col))\n end\n\n module Account_id = struct\n include Account_id\n\n let if_ = value_if\n end\n\n module Ledger = struct\n type t = L.t\n\n let if_ = value_if\n\n let empty = L.empty\n\n type inclusion_proof = [ `Existing of location | `New ]\n\n let get_account p l =\n let loc, acct =\n Or_error.ok_exn (get_with_location l (Account_update.account_id p))\n in\n (acct, loc)\n\n let set_account l (a, loc) =\n Or_error.ok_exn (set_with_location l loc a) ;\n l\n\n let check_inclusion _ledger (_account, _loc) = ()\n\n let check_account public_key token_id\n ((account, loc) : Account.t * inclusion_proof) =\n assert (Public_key.Compressed.equal public_key account.public_key) ;\n assert (Token_id.equal token_id account.token_id) ;\n match loc with `Existing _ -> `Is_new false | `New -> `Is_new true\n end\n\n module Transaction_commitment = struct\n type t = Field.t\n\n let empty = Zkapp_command.Transaction_commitment.empty\n\n let commitment ~account_updates =\n let account_updates_hash =\n Mina_base.Zkapp_command.Call_forest.hash account_updates\n in\n Zkapp_command.Transaction_commitment.create ~account_updates_hash\n\n let full_commitment ~account_update ~memo_hash ~commitment =\n (* when called from Zkapp_command_logic.apply, the account_update is the fee payer *)\n let fee_payer_hash =\n Zkapp_command.Digest.Account_update.create account_update\n in\n Zkapp_command.Transaction_commitment.create_complete commitment\n ~memo_hash ~fee_payer_hash\n\n let if_ = value_if\n end\n\n module Index = struct\n type t = Mina_numbers.Index.t\n\n let zero, succ = Mina_numbers.Index.(zero, succ)\n\n let if_ = value_if\n end\n\n module Public_key = struct\n type t = Public_key.Compressed.t\n\n let if_ = value_if\n end\n\n module Controller = struct\n type t = Permissions.Auth_required.t\n\n let if_ = value_if\n\n let check ~proof_verifies ~signature_verifies perm =\n (* Invariant: We either have a proof, a signature, or neither. *)\n assert (not (proof_verifies && signature_verifies)) ;\n let tag =\n if proof_verifies then Control.Tag.Proof\n else if signature_verifies then Control.Tag.Signature\n else Control.Tag.None_given\n in\n Permissions.Auth_required.check perm tag\n end\n\n module Global_slot_since_genesis = struct\n include Mina_numbers.Global_slot_since_genesis\n\n let if_ = value_if\n end\n\n module Global_slot_span = struct\n include Mina_numbers.Global_slot_span\n\n let if_ = value_if\n end\n\n module Nonce = struct\n type t = Account.Nonce.t\n\n let if_ = value_if\n\n let succ = Account.Nonce.succ\n end\n\n module Receipt_chain_hash = struct\n type t = Receipt.Chain_hash.t\n\n module Elt = struct\n type t = Receipt.Zkapp_command_elt.t\n\n let of_transaction_commitment tc =\n Receipt.Zkapp_command_elt.Zkapp_command_commitment tc\n end\n\n let cons_zkapp_command_commitment =\n Receipt.Chain_hash.cons_zkapp_command_commitment\n\n let if_ = value_if\n end\n\n module State_hash = struct\n include State_hash\n\n let if_ = value_if\n end\n\n module Timing = struct\n type t = Account_update.Update.Timing_info.t option\n\n let if_ = value_if\n\n let vesting_period (t : t) =\n match t with\n | Some t ->\n t.vesting_period\n | None ->\n (Account_timing.to_record Untimed).vesting_period\n end\n\n module Balance = struct\n include Balance\n\n let if_ = value_if\n end\n\n module Verification_key = struct\n type t = (Side_loaded_verification_key.t, Field.t) With_hash.t option\n\n let if_ = value_if\n end\n\n module Verification_key_hash = struct\n type t = Field.t option\n\n let equal vk1 vk2 = Option.equal Field.equal vk1 vk2\n end\n\n module Actions = struct\n type t = Zkapp_account.Actions.t\n\n let is_empty = List.is_empty\n\n let push_events = Account_update.Actions.push_events\n end\n\n module Zkapp_uri = struct\n type t = string\n\n let if_ = value_if\n end\n\n module Token_symbol = struct\n type t = Account.Token_symbol.t\n\n let if_ = value_if\n end\n\n module Account = struct\n include Account\n\n module Permissions = struct\n let access : t -> Controller.t = fun a -> a.permissions.access\n\n let edit_state : t -> Controller.t = fun a -> a.permissions.edit_state\n\n let send : t -> Controller.t = fun a -> a.permissions.send\n\n let receive : t -> Controller.t = fun a -> a.permissions.receive\n\n let set_delegate : t -> Controller.t =\n fun a -> a.permissions.set_delegate\n\n let set_permissions : t -> Controller.t =\n fun a -> a.permissions.set_permissions\n\n let set_verification_key : t -> Controller.t =\n fun a -> a.permissions.set_verification_key\n\n let set_zkapp_uri : t -> Controller.t =\n fun a -> a.permissions.set_zkapp_uri\n\n let edit_action_state : t -> Controller.t =\n fun a -> a.permissions.edit_action_state\n\n let set_token_symbol : t -> Controller.t =\n fun a -> a.permissions.set_token_symbol\n\n let increment_nonce : t -> Controller.t =\n fun a -> a.permissions.increment_nonce\n\n let set_voting_for : t -> Controller.t =\n fun a -> a.permissions.set_voting_for\n\n let set_timing : t -> Controller.t = fun a -> a.permissions.set_timing\n\n type t = Permissions.t\n\n let if_ = value_if\n end\n\n type timing = Account_update.Update.Timing_info.t option\n\n let timing (a : t) : timing =\n Account_update.Update.Timing_info.of_account_timing a.timing\n\n let set_timing (a : t) (timing : timing) : t =\n { a with\n timing =\n Option.value_map ~default:Account_timing.Untimed\n ~f:Account_update.Update.Timing_info.to_account_timing timing\n }\n\n let is_timed (a : t) =\n match a.timing with Account_timing.Untimed -> false | _ -> true\n\n let set_token_id (a : t) (id : Token_id.t) : t = { a with token_id = id }\n\n let balance (a : t) : Balance.t = a.balance\n\n let set_balance (balance : Balance.t) (a : t) : t = { a with balance }\n\n let check_timing ~txn_global_slot account =\n let invalid_timing, timing, _ =\n validate_timing_with_min_balance' ~txn_amount:Amount.zero\n ~txn_global_slot ~account\n in\n ( invalid_timing\n , Account_update.Update.Timing_info.of_account_timing timing )\n\n let receipt_chain_hash (a : t) : Receipt.Chain_hash.t =\n a.receipt_chain_hash\n\n let set_receipt_chain_hash (a : t) hash =\n { a with receipt_chain_hash = hash }\n\n let make_zkapp (a : t) =\n let zkapp =\n match a.zkapp with\n | None ->\n Some Zkapp_account.default\n | Some _ as zkapp ->\n zkapp\n in\n { a with zkapp }\n\n let unmake_zkapp (a : t) : t =\n let zkapp =\n match a.zkapp with\n | None ->\n None\n | Some zkapp ->\n if Zkapp_account.(equal default zkapp) then None else Some zkapp\n in\n { a with zkapp }\n\n let get_zkapp (a : t) = Option.value_exn a.zkapp\n\n let set_zkapp (a : t) ~f : t = { a with zkapp = Option.map a.zkapp ~f }\n\n let proved_state (a : t) = (get_zkapp a).proved_state\n\n let set_proved_state proved_state (a : t) =\n set_zkapp a ~f:(fun zkapp -> { zkapp with proved_state })\n\n let app_state (a : t) = (get_zkapp a).app_state\n\n let set_app_state app_state (a : t) =\n set_zkapp a ~f:(fun zkapp -> { zkapp with app_state })\n\n let register_verification_key (_ : t) = ()\n\n let verification_key (a : t) = (get_zkapp a).verification_key\n\n let set_verification_key verification_key (a : t) =\n set_zkapp a ~f:(fun zkapp -> { zkapp with verification_key })\n\n let verification_key_hash (a : t) =\n match a.zkapp with\n | None ->\n None\n | Some zkapp ->\n Option.map zkapp.verification_key ~f:With_hash.hash\n\n let last_action_slot (a : t) = (get_zkapp a).last_action_slot\n\n let set_last_action_slot last_action_slot (a : t) =\n set_zkapp a ~f:(fun zkapp -> { zkapp with last_action_slot })\n\n let action_state (a : t) = (get_zkapp a).action_state\n\n let set_action_state action_state (a : t) =\n set_zkapp a ~f:(fun zkapp -> { zkapp with action_state })\n\n let zkapp_uri (a : t) =\n Option.value_map a.zkapp ~default:\"\" ~f:(fun zkapp -> zkapp.zkapp_uri)\n\n let set_zkapp_uri zkapp_uri (a : t) : t =\n { a with\n zkapp = Option.map a.zkapp ~f:(fun zkapp -> { zkapp with zkapp_uri })\n }\n\n let token_symbol (a : t) = a.token_symbol\n\n let set_token_symbol token_symbol (a : t) = { a with token_symbol }\n\n let public_key (a : t) = a.public_key\n\n let set_public_key public_key (a : t) = { a with public_key }\n\n let delegate (a : t) = Account.delegate_opt a.delegate\n\n let set_delegate delegate (a : t) =\n let delegate =\n if Signature_lib.Public_key.Compressed.(equal empty) delegate then\n None\n else Some delegate\n in\n { a with delegate }\n\n let nonce (a : t) = a.nonce\n\n let set_nonce nonce (a : t) = { a with nonce }\n\n let voting_for (a : t) = a.voting_for\n\n let set_voting_for voting_for (a : t) = { a with voting_for }\n\n let permissions (a : t) = a.permissions\n\n let set_permissions permissions (a : t) = { a with permissions }\n end\n\n module Amount = struct\n open Currency.Amount\n\n type unsigned = t\n\n type t = unsigned\n\n let if_ = value_if\n\n module Signed = struct\n include Signed\n\n let if_ = value_if\n\n (* Correctness of these functions hinges on the fact that zero is\n only ever expressed as {sgn = Pos; magnitude = zero}. Sadly, this\n is not guaranteed by the module's signature, as it's internal\n structure is exposed. Create function never produces this unwanted\n value, but the type's internal structure is still exposed, so it's\n possible theoretically to obtain it.\n\n For the moment, however, there is some consolation in the fact that\n addition never produces negative zero, even if it was one of its\n arguments. For that reason the risk of this function misbehaving is\n minimal and can probably be safely ignored. *)\n let is_non_neg (t : t) = Sgn.equal t.sgn Pos\n\n let is_neg (t : t) = Sgn.equal t.sgn Neg\n end\n\n let zero = zero\n\n let equal = equal\n\n let add_flagged = add_flagged\n\n let add_signed_flagged (x1 : t) (x2 : Signed.t) : t * [ `Overflow of bool ]\n =\n let y, `Overflow b = Signed.(add_flagged (of_unsigned x1) x2) in\n match y.sgn with\n | Pos ->\n (y.magnitude, `Overflow b)\n | Neg ->\n (* We want to capture the accurate value so that this will match\n with the values in the snarked logic.\n *)\n let magnitude =\n Amount.to_uint64 y.magnitude\n |> Unsigned.UInt64.(mul (sub zero one))\n |> Amount.of_uint64\n in\n (magnitude, `Overflow true)\n\n let of_constant_fee = of_fee\n end\n\n module Token_id = struct\n include Token_id\n\n let if_ = value_if\n end\n\n module Protocol_state_precondition = struct\n include Zkapp_precondition.Protocol_state\n end\n\n module Valid_while_precondition = struct\n include Zkapp_precondition.Valid_while\n end\n\n module Account_update = struct\n include Account_update\n\n module Account_precondition = struct\n include Account_update.Account_precondition\n\n let nonce (t : Account_update.t) = nonce t.body.preconditions.account\n end\n\n type 'a or_ignore = 'a Zkapp_basic.Or_ignore.t\n\n type call_forest = Zkapp_call_forest.t\n\n type transaction_commitment = Transaction_commitment.t\n\n let may_use_parents_own_token (p : t) =\n May_use_token.parents_own_token p.body.may_use_token\n\n let may_use_token_inherited_from_parent (p : t) =\n May_use_token.inherit_from_parent p.body.may_use_token\n\n let check_authorization ~will_succeed:_ ~commitment:_ ~calls:_\n (account_update : t) =\n (* The transaction's validity should already have been checked before\n this point.\n *)\n match account_update.authorization with\n | Signature _ ->\n (`Proof_verifies false, `Signature_verifies true)\n | Proof _ ->\n (`Proof_verifies true, `Signature_verifies false)\n | None_given ->\n (`Proof_verifies false, `Signature_verifies false)\n\n let is_proved (account_update : t) =\n match account_update.body.authorization_kind with\n | Proof _ ->\n true\n | Signature | None_given ->\n false\n\n let is_signed (account_update : t) =\n match account_update.body.authorization_kind with\n | Signature ->\n true\n | Proof _ | None_given ->\n false\n\n let verification_key_hash (p : t) =\n match p.body.authorization_kind with\n | Proof vk_hash ->\n Some vk_hash\n | _ ->\n None\n\n module Update = struct\n open Zkapp_basic\n\n type 'a set_or_keep = 'a Zkapp_basic.Set_or_keep.t\n\n let timing (account_update : t) : Account.timing set_or_keep =\n Set_or_keep.map ~f:Option.some account_update.body.update.timing\n\n let app_state (account_update : t) =\n account_update.body.update.app_state\n\n let verification_key (account_update : t) =\n Zkapp_basic.Set_or_keep.map ~f:Option.some\n account_update.body.update.verification_key\n\n let actions (account_update : t) = account_update.body.actions\n\n let zkapp_uri (account_update : t) =\n account_update.body.update.zkapp_uri\n\n let token_symbol (account_update : t) =\n account_update.body.update.token_symbol\n\n let delegate (account_update : t) = account_update.body.update.delegate\n\n let voting_for (account_update : t) =\n account_update.body.update.voting_for\n\n let permissions (account_update : t) =\n account_update.body.update.permissions\n end\n end\n\n module Set_or_keep = struct\n include Zkapp_basic.Set_or_keep\n\n let set_or_keep ~if_:_ t x = set_or_keep t x\n end\n\n module Opt = struct\n type 'a t = 'a option\n\n let is_some = Option.is_some\n\n let map = Option.map\n\n let or_default ~if_ x ~default =\n if_ (is_some x) ~then_:(Option.value ~default x) ~else_:default\n\n let or_exn x = Option.value_exn x\n end\n\n module Stack (Elt : sig\n type t\n end) =\n struct\n type t = Elt.t list\n\n let if_ = value_if\n\n let empty () = []\n\n let is_empty = List.is_empty\n\n let pop_exn : t -> Elt.t * t = function\n | [] ->\n failwith \"pop_exn\"\n | x :: xs ->\n (x, xs)\n\n let pop : t -> (Elt.t * t) option = function\n | x :: xs ->\n Some (x, xs)\n | _ ->\n None\n\n let push x ~onto : t = x :: onto\n end\n\n module Call_forest = Zkapp_call_forest\n\n module Stack_frame = struct\n include Stack_frame\n\n type t = value\n\n let if_ = Zkapp_command.value_if\n\n let make = Stack_frame.make\n end\n\n module Call_stack = Stack (Stack_frame)\n\n module Local_state = struct\n type t =\n ( Stack_frame.t\n , Call_stack.t\n , Amount.Signed.t\n , Ledger.t\n , Bool.t\n , Transaction_commitment.t\n , Index.t\n , Bool.failure_status_tbl )\n Zkapp_command_logic.Local_state.t\n\n let add_check (t : t) failure b =\n let failure_status_tbl =\n match t.failure_status_tbl with\n | hd :: tl when not b ->\n (failure :: hd) :: tl\n | old_failure_status_tbl ->\n old_failure_status_tbl\n in\n { t with failure_status_tbl; success = t.success && b }\n\n let update_failure_status_tbl (t : t) failure_status b =\n match failure_status with\n | None ->\n { t with success = t.success && b }\n | Some failure ->\n add_check t failure b\n\n let add_new_failure_status_bucket (t : t) =\n { t with failure_status_tbl = [] :: t.failure_status_tbl }\n end\n\n module Nonce_precondition = struct\n let is_constant =\n Zkapp_precondition.Numeric.is_constant\n Zkapp_precondition.Numeric.Tc.nonce\n end\n end\n\n module Env = struct\n open Inputs\n\n type t =\n < account_update : Account_update.t\n ; zkapp_command : Zkapp_command.t\n ; account : Account.t\n ; ledger : Ledger.t\n ; amount : Amount.t\n ; signed_amount : Amount.Signed.t\n ; bool : Bool.t\n ; token_id : Token_id.t\n ; global_state : Global_state.t\n ; inclusion_proof : [ `Existing of location | `New ]\n ; local_state :\n ( Stack_frame.t\n , Call_stack.t\n , Amount.Signed.t\n , L.t\n , bool\n , Transaction_commitment.t\n , Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n ; protocol_state_precondition : Zkapp_precondition.Protocol_state.t\n ; valid_while_precondition : Zkapp_precondition.Valid_while.t\n ; transaction_commitment : Transaction_commitment.t\n ; full_transaction_commitment : Transaction_commitment.t\n ; field : Snark_params.Tick.Field.t\n ; failure : Transaction_status.Failure.t option >\n\n let perform ~constraint_constants:_ (type r)\n (eff : (r, t) Zkapp_command_logic.Eff.t) : r =\n match eff with\n | Check_valid_while_precondition (valid_while, global_state) ->\n Zkapp_precondition.Valid_while.check valid_while\n global_state.block_global_slot\n |> Or_error.is_ok\n | Check_protocol_state_precondition (pred, global_state) -> (\n Zkapp_precondition.Protocol_state.check pred\n global_state.protocol_state\n |> fun or_err -> match or_err with Ok () -> true | Error _ -> false )\n | Check_account_precondition\n (account_update, account, new_account, local_state) ->\n let local_state = ref local_state in\n let check failure b =\n local_state := Inputs.Local_state.add_check !local_state failure b\n in\n Zkapp_precondition.Account.check ~new_account ~check\n account_update.body.preconditions.account account ;\n !local_state\n | Init_account { account_update = _; account = a } ->\n a\n end\n\n module M = Zkapp_command_logic.Make (Inputs)\n\n let update_action_state action_state actions ~txn_global_slot\n ~last_action_slot =\n let action_state', last_action_slot' =\n M.update_action_state action_state actions ~txn_global_slot\n ~last_action_slot\n in\n (action_state', last_action_slot')\n\n (* apply zkapp command fee payer's while stubbing out the second pass ledger\n CAUTION: If you use the intermediate local states, you MUST update the\n [will_succeed] field to [false] if the [status] is [Failed].*)\n let apply_zkapp_command_first_pass_aux (type user_acc) ~constraint_constants\n ~global_slot ~(state_view : Zkapp_precondition.Protocol_state.View.t)\n ~(init : user_acc) ~f\n ?((* TODO: can this be ripped out from here? *)\n fee_excess = Amount.Signed.zero)\n ?((* TODO: is the right? is it never used for zkapps? *)\n supply_increase = Amount.Signed.zero) (ledger : L.t)\n (command : Zkapp_command.t) :\n ( Transaction_partially_applied.Zkapp_command_partially_applied.t\n * user_acc )\n Or_error.t =\n let open Or_error.Let_syntax in\n let previous_hash = merkle_root ledger in\n let original_first_pass_account_states =\n let id = Zkapp_command.fee_payer command in\n [ ( id\n , Option.Let_syntax.(\n let%bind loc = L.location_of_account ledger id in\n let%map a = L.get ledger loc in\n (loc, a)) )\n ]\n in\n let perform eff = Env.perform ~constraint_constants eff in\n let initial_state :\n Inputs.Global_state.t * _ Zkapp_command_logic.Local_state.t =\n ( { protocol_state = state_view\n ; first_pass_ledger = ledger\n ; second_pass_ledger =\n (* We stub out the second_pass_ledger initially, and then poke the\n correct value in place after the first pass is finished.\n *)\n L.empty ~depth:0 ()\n ; fee_excess\n ; supply_increase\n ; block_global_slot = global_slot\n }\n , { stack_frame =\n ({ calls = []\n ; caller = Token_id.default\n ; caller_caller = Token_id.default\n } : Inputs.Stack_frame.t)\n ; call_stack = []\n ; transaction_commitment = Inputs.Transaction_commitment.empty\n ; full_transaction_commitment = Inputs.Transaction_commitment.empty\n ; excess = Currency.Amount.(Signed.of_unsigned zero)\n ; supply_increase = Currency.Amount.(Signed.of_unsigned zero)\n ; ledger = L.empty ~depth:0 ()\n ; success = true\n ; account_update_index = Inputs.Index.zero\n ; failure_status_tbl = []\n ; will_succeed = true\n } )\n in\n let user_acc = f init initial_state in\n let account_updates = Zkapp_command.all_account_updates command in\n let%map global_state, local_state =\n Or_error.try_with (fun () ->\n M.start ~constraint_constants\n { account_updates\n ; memo_hash = Signed_command_memo.hash command.memo\n ; will_succeed =\n (* It's always valid to set this value to true, and it will\n have no effect outside of the snark.\n *)\n true\n }\n { perform } initial_state )\n in\n ( { Transaction_partially_applied.Zkapp_command_partially_applied.command\n ; previous_hash\n ; original_first_pass_account_states\n ; constraint_constants\n ; state_view\n ; global_state\n ; local_state\n }\n , user_acc )\n\n let apply_zkapp_command_first_pass ~constraint_constants ~global_slot\n ~(state_view : Zkapp_precondition.Protocol_state.View.t)\n ?((* TODO: can this be ripped out from here? *)\n fee_excess = Amount.Signed.zero)\n ?((* TODO: is the right? is it never used for zkapps? *)\n supply_increase = Amount.Signed.zero) (ledger : L.t)\n (command : Zkapp_command.t) :\n Transaction_partially_applied.Zkapp_command_partially_applied.t Or_error.t\n =\n let open Or_error.Let_syntax in\n let%map partial_stmt, _user_acc =\n apply_zkapp_command_first_pass_aux ~constraint_constants ~global_slot\n ~state_view ~fee_excess ~supply_increase ledger command ~init:None\n ~f:(fun _acc state -> Some state)\n in\n partial_stmt\n\n let apply_zkapp_command_second_pass_aux (type user_acc) ~(init : user_acc) ~f\n ledger\n (c : Transaction_partially_applied.Zkapp_command_partially_applied.t) :\n (Transaction_applied.Zkapp_command_applied.t * user_acc) Or_error.t =\n let open Or_error.Let_syntax in\n let perform eff =\n Env.perform ~constraint_constants:c.constraint_constants eff\n in\n let original_account_states =\n (*get the original states of all the accounts in each pass.\n If an account updated in the first pass is referenced in account\n updates, then retain the value before first pass application*)\n (* IMPORTANT: this account list must be sorted by Account_id in increasing order,\n if this ordering changes the scan state hash will be affected and made\n incompatible. *)\n Account_id.Map.to_alist ~key_order:`Increasing\n @@ List.fold ~init:Account_id.Map.empty\n ~f:(fun account_states (id, acc_opt) ->\n Account_id.Map.update account_states id\n ~f:(Option.value ~default:acc_opt) )\n ( c.original_first_pass_account_states\n @ List.map (Zkapp_command.accounts_referenced c.command)\n ~f:(fun id ->\n ( id\n , Option.Let_syntax.(\n let%bind loc = L.location_of_account ledger id in\n let%map a = L.get ledger loc in\n (loc, a)) ) ) )\n in\n let rec step_all (user_acc : user_acc)\n ( (g_state : Inputs.Global_state.t)\n , (l_state : _ Zkapp_command_logic.Local_state.t) ) :\n (user_acc * Transaction_status.Failure.Collection.t) Or_error.t =\n if List.is_empty l_state.stack_frame.Stack_frame.calls then\n Ok (user_acc, l_state.failure_status_tbl)\n else\n let%bind states =\n Or_error.try_with (fun () ->\n M.step ~constraint_constants:c.constraint_constants { perform }\n (g_state, l_state) )\n in\n step_all (f user_acc states) states\n in\n let account_states_after_fee_payer =\n (*To check if the accounts remain unchanged in the event the transaction\n fails. First pass updates will remain even if the transaction fails to\n apply zkapp account updates*)\n List.map (Zkapp_command.accounts_referenced c.command) ~f:(fun id ->\n ( id\n , Option.Let_syntax.(\n let%bind loc = L.location_of_account ledger id in\n let%map a = L.get ledger loc in\n (loc, a)) ) )\n in\n let accounts () =\n List.map original_account_states\n ~f:(Tuple2.map_snd ~f:(Option.map ~f:snd))\n in\n (* Warning: This is an abstraction leak / hack.\n Here, we update global second pass ledger to be the input ledger, and\n then update the local ledger to be the input ledger *IF AND ONLY IF*\n there are more transaction segments to be processed in this pass.\n\n TODO: Remove this, and uplift the logic into the call in staged ledger.\n *)\n let global_state = { c.global_state with second_pass_ledger = ledger } in\n let local_state =\n if List.is_empty c.local_state.stack_frame.Stack_frame.calls then\n (* Don't mess with the local state; we've already finished the\n transaction after the fee payer.\n *)\n c.local_state\n else\n (* Install the ledger that should already be in the local state, but\n may not be in some situations depending on who the caller is.\n *)\n { c.local_state with\n ledger = Global_state.second_pass_ledger global_state\n }\n in\n let start = (global_state, local_state) in\n match step_all (f init start) start with\n | Error e ->\n Error e\n | Ok (user_acc, reversed_failure_status_tbl) ->\n let failure_status_tbl = List.rev reversed_failure_status_tbl in\n let account_ids_originally_not_in_ledger =\n List.filter_map original_account_states\n ~f:(fun (acct_id, loc_and_acct) ->\n if Option.is_none loc_and_acct then Some acct_id else None )\n in\n let successfully_applied =\n Transaction_status.Failure.Collection.is_empty failure_status_tbl\n in\n (* if the zkapp command fails in at least 1 account update,\n then all the account updates would be cancelled except\n the fee payer one\n *)\n let failure_status_tbl =\n if successfully_applied then failure_status_tbl\n else\n List.mapi failure_status_tbl ~f:(fun idx fs ->\n if idx > 0 && List.is_empty fs then\n [ Transaction_status.Failure.Cancelled ]\n else fs )\n in\n (* accounts not originally in ledger, now present in ledger *)\n let new_accounts =\n List.filter account_ids_originally_not_in_ledger ~f:(fun acct_id ->\n Option.is_some @@ L.location_of_account ledger acct_id )\n in\n let valid_result =\n Ok\n ( { Transaction_applied.Zkapp_command_applied.accounts = accounts ()\n ; command =\n { With_status.data = c.command\n ; status =\n ( if successfully_applied then Applied\n else Failed failure_status_tbl )\n }\n ; new_accounts\n }\n , user_acc )\n in\n if successfully_applied then valid_result\n else\n let other_account_update_accounts_unchanged =\n List.fold_until account_states_after_fee_payer ~init:true\n ~f:(fun acc (_, loc_opt) ->\n match\n let open Option.Let_syntax in\n let%bind loc, a = loc_opt in\n let%bind a' = L.get ledger loc in\n Option.some_if (not (Account.equal a a')) ()\n with\n | None ->\n Continue acc\n | Some _ ->\n Stop false )\n ~finish:Fn.id\n in\n (* Other zkapp_command failed, therefore, updates in those should not get applied *)\n if\n List.is_empty new_accounts\n && other_account_update_accounts_unchanged\n then valid_result\n else\n Or_error.error_string\n \"Zkapp_command application failed but new accounts created or \\\n some of the other account_update updates applied\"\n\n let apply_zkapp_command_second_pass ledger c :\n Transaction_applied.Zkapp_command_applied.t Or_error.t =\n let open Or_error.Let_syntax in\n let%map x, () =\n apply_zkapp_command_second_pass_aux ~init:() ~f:Fn.const ledger c\n in\n x\n\n let apply_zkapp_command_unchecked_aux ~constraint_constants ~global_slot\n ~state_view ~init ~f ?fee_excess ?supply_increase ledger command =\n let open Or_error.Let_syntax in\n apply_zkapp_command_first_pass_aux ~constraint_constants ~global_slot\n ~state_view ?fee_excess ?supply_increase ledger command ~init ~f\n >>= fun (partial_stmt, user_acc) ->\n apply_zkapp_command_second_pass_aux ~init:user_acc ~f ledger partial_stmt\n\n let apply_zkapp_command_unchecked ~constraint_constants ~global_slot\n ~state_view ledger command =\n let open Or_error.Let_syntax in\n apply_zkapp_command_first_pass ~constraint_constants ~global_slot\n ~state_view ledger command\n >>= apply_zkapp_command_second_pass_aux ledger ~init:None\n ~f:(fun _acc (global_state, local_state) ->\n Some (local_state, global_state.fee_excess) )\n |> Result.map ~f:(fun (account_update_applied, state_res) ->\n (account_update_applied, Option.value_exn state_res) )\n\n let update_timing_when_no_deduction ~txn_global_slot account =\n validate_timing ~txn_amount:Amount.zero ~txn_global_slot ~account\n\n let has_permission_to_receive ~ledger receiver_account_id :\n Account.t\n * Ledger_intf.account_state\n * [> `Has_permission_to_receive of bool ] =\n let init_account = Account.initialize receiver_account_id in\n match location_of_account ledger receiver_account_id with\n | None ->\n (* new account, check that default permissions allow receiving *)\n ( init_account\n , `Added\n , `Has_permission_to_receive\n (Account.has_permission_to_receive init_account) )\n | Some loc -> (\n match get ledger loc with\n | None ->\n failwith \"Ledger location with no account\"\n | Some receiver_account ->\n ( receiver_account\n , `Existed\n , `Has_permission_to_receive\n (Account.has_permission_to_receive receiver_account) ) )\n\n let no_failure = []\n\n let update_failed =\n [ Transaction_status.Failure.Update_not_permitted_balance ]\n\n let empty = Transaction_status.Failure.Collection.empty\n\n let single_failure =\n Transaction_status.Failure.Collection.of_single_failure\n Update_not_permitted_balance\n\n let append_entry f (s : Transaction_status.Failure.Collection.t) :\n Transaction_status.Failure.Collection.t =\n match s with [] -> [ f ] | h :: t -> h :: f :: t\n\n (*Structure of the failure status:\n I. Only one fee transfer in the transaction (`One) and it fails:\n [[failure]]\n II. Two fee transfers in the transaction (`Two)-\n Both fee transfers fail:\n [[failure-of-first-fee-transfer]; [failure-of-second-fee-transfer]]\n First succeeds and second one fails:\n [[];[failure-of-second-fee-transfer]]\n First fails and second succeeds:\n [[failure-of-first-fee-transfer];[]]\n *)\n let process_fee_transfer t (transfer : Fee_transfer.t) ~modify_balance\n ~modify_timing =\n let open Or_error.Let_syntax in\n (* TODO(#4555): Allow token_id to vary from default. *)\n let%bind () =\n if\n List.for_all\n ~f:Token_id.(equal default)\n (One_or_two.to_list (Fee_transfer.fee_tokens transfer))\n then return ()\n else Or_error.errorf \"Cannot pay fees in non-default tokens.\"\n in\n match Fee_transfer.to_singles transfer with\n | `One ft ->\n let account_id = Fee_transfer.Single.receiver ft in\n let a, action, `Has_permission_to_receive can_receive =\n has_permission_to_receive ~ledger:t account_id\n in\n let%bind timing = modify_timing a in\n let%bind balance = modify_balance action account_id a.balance ft.fee in\n if can_receive then (\n let%map _action, a, loc = get_or_create t account_id in\n let new_accounts = get_new_accounts action account_id in\n set t loc { a with balance; timing } ;\n (new_accounts, empty, Currency.Amount.zero) )\n else Ok ([], single_failure, Currency.Amount.of_fee ft.fee)\n | `Two (ft1, ft2) ->\n let account_id1 = Fee_transfer.Single.receiver ft1 in\n let a1, action1, `Has_permission_to_receive can_receive1 =\n has_permission_to_receive ~ledger:t account_id1\n in\n let account_id2 = Fee_transfer.Single.receiver ft2 in\n if Account_id.equal account_id1 account_id2 then\n let%bind fee = error_opt \"overflow\" (Fee.add ft1.fee ft2.fee) in\n let%bind timing = modify_timing a1 in\n let%bind balance =\n modify_balance action1 account_id1 a1.balance fee\n in\n if can_receive1 then (\n let%map _action1, a1, l1 = get_or_create t account_id1 in\n let new_accounts1 = get_new_accounts action1 account_id1 in\n set t l1 { a1 with balance; timing } ;\n (new_accounts1, empty, Currency.Amount.zero) )\n else\n (*failure for each fee transfer single*)\n Ok\n ( []\n , append_entry update_failed single_failure\n , Currency.Amount.of_fee fee )\n else\n let a2, action2, `Has_permission_to_receive can_receive2 =\n has_permission_to_receive ~ledger:t account_id2\n in\n let%bind balance1 =\n modify_balance action1 account_id1 a1.balance ft1.fee\n in\n (*Note: Not updating the timing field of a1 to avoid additional check in transactions snark (check_timing for \"receiver\"). This is OK because timing rules will not be violated when balance increases and will be checked whenever an amount is deducted from the account. (#5973)*)\n let%bind timing2 = modify_timing a2 in\n let%bind balance2 =\n modify_balance action2 account_id2 a2.balance ft2.fee\n in\n let%bind new_accounts1, failures, burned_tokens1 =\n if can_receive1 then (\n let%map _action1, a1, l1 = get_or_create t account_id1 in\n let new_accounts1 = get_new_accounts action1 account_id1 in\n set t l1 { a1 with balance = balance1 } ;\n ( new_accounts1\n , append_entry no_failure empty\n , Currency.Amount.zero ) )\n else Ok ([], single_failure, Currency.Amount.of_fee ft1.fee)\n in\n let%bind new_accounts2, failures', burned_tokens2 =\n if can_receive2 then (\n let%map _action2, a2, l2 = get_or_create t account_id2 in\n let new_accounts2 = get_new_accounts action2 account_id2 in\n set t l2 { a2 with balance = balance2; timing = timing2 } ;\n ( new_accounts2\n , append_entry no_failure failures\n , Currency.Amount.zero ) )\n else\n Ok\n ( []\n , append_entry update_failed failures\n , Currency.Amount.of_fee ft2.fee )\n in\n let%map burned_tokens =\n error_opt \"burned tokens overflow\"\n (Currency.Amount.add burned_tokens1 burned_tokens2)\n in\n (new_accounts1 @ new_accounts2, failures', burned_tokens)\n\n let apply_fee_transfer ~constraint_constants ~txn_global_slot t transfer =\n let open Or_error.Let_syntax in\n let%map new_accounts, failures, burned_tokens =\n process_fee_transfer t transfer\n ~modify_balance:(fun action _ b f ->\n let%bind amount =\n let amount = Amount.of_fee f in\n sub_account_creation_fee ~constraint_constants action amount\n in\n add_amount b amount )\n ~modify_timing:(fun acc ->\n update_timing_when_no_deduction ~txn_global_slot acc )\n in\n let ft_with_status =\n if Transaction_status.Failure.Collection.is_empty failures then\n { With_status.data = transfer; status = Applied }\n else { data = transfer; status = Failed failures }\n in\n Transaction_applied.Fee_transfer_applied.\n { fee_transfer = ft_with_status; new_accounts; burned_tokens }\n\n (*Structure of the failure status:\n I. No fee transfer and coinbase transfer fails: [[failure]]\n II. With fee transfer-\n Both fee transfer and coinbase fails:\n [[failure-of-fee-transfer]; [failure-of-coinbase]]\n Fee transfer succeeds and coinbase fails:\n [[];[failure-of-coinbase]]\n Fee transfer fails and coinbase succeeds:\n [[failure-of-fee-transfer];[]]\n *)\n let apply_coinbase ~constraint_constants ~txn_global_slot t\n (* TODO: Better system needed for making atomic changes. Could use a monad. *)\n ({ receiver; fee_transfer; amount = coinbase_amount } as cb : Coinbase.t)\n =\n let open Or_error.Let_syntax in\n let%bind ( receiver_reward\n , new_accounts1\n , transferee_update\n , transferee_timing_prev\n , failures1\n , burned_tokens1 ) =\n match fee_transfer with\n | None ->\n return (coinbase_amount, [], None, None, empty, Currency.Amount.zero)\n | Some ({ receiver_pk = transferee; fee } as ft) ->\n assert (not @@ Public_key.Compressed.equal transferee receiver) ;\n let transferee_id = Coinbase.Fee_transfer.receiver ft in\n let fee = Amount.of_fee fee in\n let%bind receiver_reward =\n error_opt \"Coinbase fee transfer too large\"\n (Amount.sub coinbase_amount fee)\n in\n let transferee_account, action, `Has_permission_to_receive can_receive\n =\n has_permission_to_receive ~ledger:t transferee_id\n in\n let new_accounts = get_new_accounts action transferee_id in\n let%bind timing =\n update_timing_when_no_deduction ~txn_global_slot transferee_account\n in\n let%bind balance =\n let%bind amount =\n sub_account_creation_fee ~constraint_constants action fee\n in\n add_amount transferee_account.balance amount\n in\n if can_receive then\n let%map _action, transferee_account, transferee_location =\n get_or_create t transferee_id\n in\n ( receiver_reward\n , new_accounts\n , Some\n ( transferee_location\n , { transferee_account with balance; timing } )\n , Some transferee_account.timing\n , append_entry no_failure empty\n , Currency.Amount.zero )\n else return (receiver_reward, [], None, None, single_failure, fee)\n in\n let receiver_id = Account_id.create receiver Token_id.default in\n let receiver_account, action2, `Has_permission_to_receive can_receive =\n has_permission_to_receive ~ledger:t receiver_id\n in\n let new_accounts2 = get_new_accounts action2 receiver_id in\n (* Note: Updating coinbase receiver timing only if there is no fee transfer.\n This is so as to not add any extra constraints in transaction snark for checking\n \"receiver\" timings. This is OK because timing rules will not be violated when\n balance increases and will be checked whenever an amount is deducted from the\n account (#5973)\n *)\n let%bind coinbase_receiver_timing =\n match transferee_timing_prev with\n | None ->\n let%map new_receiver_timing =\n update_timing_when_no_deduction ~txn_global_slot receiver_account\n in\n new_receiver_timing\n | Some _timing ->\n Ok receiver_account.timing\n in\n let%bind receiver_balance =\n let%bind amount =\n sub_account_creation_fee ~constraint_constants action2 receiver_reward\n in\n add_amount receiver_account.balance amount\n in\n let%bind failures, burned_tokens2 =\n if can_receive then (\n let%map _action2, receiver_account, receiver_location =\n get_or_create t receiver_id\n in\n set t receiver_location\n { receiver_account with\n balance = receiver_balance\n ; timing = coinbase_receiver_timing\n } ;\n (append_entry no_failure failures1, Currency.Amount.zero) )\n else return (append_entry update_failed failures1, receiver_reward)\n in\n Option.iter transferee_update ~f:(fun (l, a) -> set t l a) ;\n let%map burned_tokens =\n error_opt \"burned tokens overflow\"\n (Amount.add burned_tokens1 burned_tokens2)\n in\n let coinbase_with_status =\n if Transaction_status.Failure.Collection.is_empty failures then\n { With_status.data = cb; status = Applied }\n else { With_status.data = cb; status = Failed failures }\n in\n Transaction_applied.Coinbase_applied.\n { coinbase = coinbase_with_status\n ; new_accounts = new_accounts1 @ new_accounts2\n ; burned_tokens\n }\n\n let apply_transaction_first_pass ~constraint_constants ~global_slot\n ~(txn_state_view : Zkapp_precondition.Protocol_state.View.t) ledger\n (t : Transaction.t) : Transaction_partially_applied.t Or_error.t =\n let open Or_error.Let_syntax in\n let previous_hash = merkle_root ledger in\n let txn_global_slot = global_slot in\n match t with\n | Command (Signed_command txn) ->\n let%map applied =\n apply_user_command_unchecked ~constraint_constants ~txn_global_slot\n ledger txn\n in\n Transaction_partially_applied.Signed_command { previous_hash; applied }\n | Command (Zkapp_command txn) ->\n let%map partially_applied =\n apply_zkapp_command_first_pass ~global_slot ~state_view:txn_state_view\n ~constraint_constants ledger txn\n in\n Transaction_partially_applied.Zkapp_command partially_applied\n | Fee_transfer t ->\n let%map applied =\n apply_fee_transfer ~constraint_constants ~txn_global_slot ledger t\n in\n Transaction_partially_applied.Fee_transfer { previous_hash; applied }\n | Coinbase t ->\n let%map applied =\n apply_coinbase ~constraint_constants ~txn_global_slot ledger t\n in\n Transaction_partially_applied.Coinbase { previous_hash; applied }\n\n let apply_transaction_second_pass ledger (t : Transaction_partially_applied.t)\n : Transaction_applied.t Or_error.t =\n let open Or_error.Let_syntax in\n let open Transaction_applied in\n match t with\n | Signed_command { previous_hash; applied } ->\n return\n { previous_hash; varying = Varying.Command (Signed_command applied) }\n | Zkapp_command partially_applied ->\n (* TODO: either here or in second phase of apply, need to update the prior global state statement for the fee payer segment to add the second phase ledger at the end *)\n let%map applied =\n apply_zkapp_command_second_pass ledger partially_applied\n in\n { previous_hash = partially_applied.previous_hash\n ; varying = Varying.Command (Zkapp_command applied)\n }\n | Fee_transfer { previous_hash; applied } ->\n return { previous_hash; varying = Varying.Fee_transfer applied }\n | Coinbase { previous_hash; applied } ->\n return { previous_hash; varying = Varying.Coinbase applied }\n\n let apply_transactions ~constraint_constants ~global_slot ~txn_state_view\n ledger txns =\n let open Or_error in\n Mina_stdlib.Result.List.map txns\n ~f:\n (apply_transaction_first_pass ~constraint_constants ~global_slot\n ~txn_state_view ledger )\n >>= Mina_stdlib.Result.List.map ~f:(apply_transaction_second_pass ledger)\n\n module For_tests = struct\n let validate_timing_with_min_balance = validate_timing_with_min_balance\n\n let validate_timing = validate_timing\n end\nend\n\nmodule For_tests = struct\n open Mina_numbers\n open Currency\n\n module Account_without_receipt_chain_hash = struct\n type t =\n ( Public_key.Compressed.t\n , Token_id.t\n , Account.Token_symbol.t\n , Balance.t\n , Account_nonce.t\n , unit\n , Public_key.Compressed.t option\n , State_hash.t\n , Account_timing.t\n , Permissions.t\n , Zkapp_account.t option )\n Account.Poly.t\n [@@deriving sexp, compare]\n end\n\n let min_init_balance = Int64.of_string \"8000000000\"\n\n let max_init_balance = Int64.of_string \"8000000000000\"\n\n let num_accounts = 10\n\n let num_transactions = 10\n\n let depth = Int.ceil_log2 (num_accounts + num_transactions)\n\n module Init_ledger = struct\n type t = (Keypair.t * int64) array [@@deriving sexp]\n\n let init ?(zkapp = true) (type l) (module L : Ledger_intf.S with type t = l)\n (init_ledger : t) (l : L.t) =\n Array.iter init_ledger ~f:(fun (kp, amount) ->\n let _tag, account, loc =\n L.get_or_create l\n (Account_id.create\n (Public_key.compress kp.public_key)\n Token_id.default )\n |> Or_error.ok_exn\n in\n let permissions : Permissions.t =\n { edit_state = Either\n ; send = Either\n ; receive = None\n ; set_delegate = Either\n ; set_permissions = Either\n ; set_verification_key = Either\n ; set_zkapp_uri = Either\n ; edit_action_state = Either\n ; set_token_symbol = Either\n ; increment_nonce = Either\n ; set_voting_for = Either\n ; access = None\n ; set_timing = Either\n }\n in\n let zkapp =\n if zkapp then\n Some\n { Zkapp_account.default with\n verification_key =\n Some\n { With_hash.hash = Zkapp_basic.F.zero\n ; data = Side_loaded_verification_key.dummy\n }\n }\n else None\n in\n L.set l loc\n { account with\n balance =\n Currency.Balance.of_uint64 (Unsigned.UInt64.of_int64 amount)\n ; permissions\n ; zkapp\n } )\n\n let gen () : t Quickcheck.Generator.t =\n let tbl = Public_key.Compressed.Hash_set.create () in\n let open Quickcheck.Generator in\n let open Let_syntax in\n let rec go acc n =\n if n = 0 then return (Array.of_list acc)\n else\n let%bind kp =\n filter Keypair.gen ~f:(fun kp ->\n not (Hash_set.mem tbl (Public_key.compress kp.public_key)) )\n and amount = Int64.gen_incl min_init_balance max_init_balance in\n Hash_set.add tbl (Public_key.compress kp.public_key) ;\n go ((kp, amount) :: acc) (n - 1)\n in\n go [] num_accounts\n end\n\n module Transaction_spec = struct\n type t =\n { fee : Currency.Fee.t\n ; sender : Keypair.t * Account_nonce.t\n ; receiver : Public_key.Compressed.t\n ; amount : Currency.Amount.t\n }\n [@@deriving sexp]\n\n let gen ~(init_ledger : Init_ledger.t) ~nonces =\n let pk ((kp : Keypair.t), _) = Public_key.compress kp.public_key in\n let open Quickcheck.Let_syntax in\n let%bind receiver_is_new = Bool.quickcheck_generator in\n let gen_index () = Int.gen_incl 0 (Array.length init_ledger - 1) in\n let%bind receiver_index =\n if receiver_is_new then return None else gen_index () >>| Option.return\n in\n let%bind receiver =\n match receiver_index with\n | None ->\n Public_key.Compressed.gen\n | Some i ->\n return (pk init_ledger.(i))\n in\n let%bind sender =\n let%map i =\n match receiver_index with\n | None ->\n gen_index ()\n | Some j ->\n Quickcheck.Generator.filter (gen_index ()) ~f:(( <> ) j)\n in\n fst init_ledger.(i)\n in\n let gen_amount () =\n Currency.Amount.(\n gen_incl\n (of_nanomina_int_exn 1_000_000)\n (of_nanomina_int_exn 100_000_000))\n in\n let gen_fee () =\n Currency.Fee.(\n gen_incl\n (of_nanomina_int_exn 1_000_000)\n (of_nanomina_int_exn 100_000_000))\n in\n let nonce : Account_nonce.t = Map.find_exn nonces sender in\n let%bind fee = gen_fee () in\n let%bind amount = gen_amount () in\n let nonces =\n Map.set nonces ~key:sender ~data:(Account_nonce.succ nonce)\n in\n let spec = { fee; amount; receiver; sender = (sender, nonce) } in\n return (spec, nonces)\n end\n\n module Test_spec = struct\n type t = { init_ledger : Init_ledger.t; specs : Transaction_spec.t list }\n [@@deriving sexp]\n\n let mk_gen ?(num_transactions = num_transactions) () =\n let open Quickcheck.Let_syntax in\n let%bind init_ledger = Init_ledger.gen () in\n let%bind specs =\n let rec go acc n nonces =\n if n = 0 then return (List.rev acc)\n else\n let%bind spec, nonces = Transaction_spec.gen ~init_ledger ~nonces in\n go (spec :: acc) (n - 1) nonces\n in\n go [] num_transactions\n (Keypair.Map.of_alist_exn\n (List.map (Array.to_list init_ledger) ~f:(fun (pk, _) ->\n (pk, Account_nonce.zero) ) ) )\n in\n return { init_ledger; specs }\n\n let gen = mk_gen ~num_transactions ()\n end\n\n let command_send\n { Transaction_spec.fee; sender = sender, sender_nonce; receiver; amount }\n : Signed_command.t =\n let sender_pk = Public_key.compress sender.public_key in\n Signed_command.sign sender\n { common =\n { fee\n ; fee_payer_pk = sender_pk\n ; nonce = sender_nonce\n ; valid_until = Global_slot_since_genesis.max_value\n ; memo = Signed_command_memo.dummy\n }\n ; body = Payment { receiver_pk = receiver; amount }\n }\n |> Signed_command.forget_check\n\n let account_update_send ?(use_full_commitment = true)\n ?(double_sender_nonce = true)\n { Transaction_spec.fee; sender = sender, sender_nonce; receiver; amount }\n : Zkapp_command.t =\n let sender_pk = Public_key.compress sender.public_key in\n let actual_nonce =\n (* Here, we double the spec'd nonce, because we bump the nonce a second\n time for the 'sender' part of the payment.\n *)\n (* TODO: We should make bumping the nonce for signed zkapp_command optional,\n flagged by a field in the account_update (but always true for the fee payer).\n\n This would also allow us to prevent replays of snapp proofs, by\n allowing them to bump their nonce.\n *)\n if double_sender_nonce then\n sender_nonce |> Account.Nonce.to_uint32\n |> Unsigned.UInt32.(mul (of_int 2))\n |> Account.Nonce.to_uint32\n else sender_nonce\n in\n let zkapp_command : Zkapp_command.Simple.t =\n { fee_payer =\n { Account_update.Fee_payer.body =\n { public_key = sender_pk\n ; fee\n ; valid_until = None\n ; nonce = actual_nonce\n }\n (* Real signature added in below *)\n ; authorization = Signature.dummy\n }\n ; account_updates =\n [ { body =\n { public_key = sender_pk\n ; update = Account_update.Update.noop\n ; token_id = Token_id.default\n ; balance_change = Amount.Signed.(negate (of_unsigned amount))\n ; increment_nonce = double_sender_nonce\n ; events = []\n ; actions = []\n ; call_data = Snark_params.Tick.Field.zero\n ; call_depth = 0\n ; preconditions =\n { Account_update.Preconditions.network =\n Zkapp_precondition.Protocol_state.accept\n ; account = Zkapp_precondition.Account.accept\n ; valid_while = Ignore\n }\n ; may_use_token = No\n ; use_full_commitment\n ; implicit_account_creation_fee = true\n ; authorization_kind =\n ( if use_full_commitment then Signature\n else Proof Zkapp_basic.F.zero )\n }\n ; authorization =\n ( if use_full_commitment then Signature Signature.dummy\n else Proof (Lazy.force Mina_base.Proof.transaction_dummy) )\n }\n ; { body =\n { public_key = receiver\n ; update = Account_update.Update.noop\n ; token_id = Token_id.default\n ; balance_change = Amount.Signed.of_unsigned amount\n ; increment_nonce = false\n ; events = []\n ; actions = []\n ; call_data = Snark_params.Tick.Field.zero\n ; call_depth = 0\n ; preconditions =\n { Account_update.Preconditions.network =\n Zkapp_precondition.Protocol_state.accept\n ; account = Zkapp_precondition.Account.accept\n ; valid_while = Ignore\n }\n ; may_use_token = No\n ; use_full_commitment = false\n ; implicit_account_creation_fee = true\n ; authorization_kind = None_given\n }\n ; authorization = None_given\n }\n ]\n ; memo = Signed_command_memo.empty\n }\n in\n let zkapp_command = Zkapp_command.of_simple zkapp_command in\n let commitment = Zkapp_command.commitment zkapp_command in\n let full_commitment =\n Zkapp_command.Transaction_commitment.create_complete commitment\n ~memo_hash:(Signed_command_memo.hash zkapp_command.memo)\n ~fee_payer_hash:\n (Zkapp_command.Digest.Account_update.create\n (Account_update.of_fee_payer zkapp_command.fee_payer) )\n in\n let account_updates_signature =\n let c = if use_full_commitment then full_commitment else commitment in\n Schnorr.Chunked.sign sender.private_key\n (Random_oracle.Input.Chunked.field c)\n in\n let account_updates =\n Zkapp_command.Call_forest.map zkapp_command.account_updates\n ~f:(fun (account_update : Account_update.t) ->\n match account_update.body.authorization_kind with\n | Signature ->\n { account_update with\n authorization = Control.Signature account_updates_signature\n }\n | _ ->\n account_update )\n in\n let signature =\n Schnorr.Chunked.sign sender.private_key\n (Random_oracle.Input.Chunked.field full_commitment)\n in\n { zkapp_command with\n fee_payer = { zkapp_command.fee_payer with authorization = signature }\n ; account_updates\n }\n\n let test_eq (type l) (module L : Ledger_intf.S with type t = l) accounts\n (l1 : L.t) (l2 : L.t) =\n List.map accounts ~f:(fun a ->\n Or_error.try_with (fun () ->\n let mismatch () =\n failwithf\n !\"One ledger had the account %{sexp:Account_id.t} but the \\\n other did not\"\n a ()\n in\n let hide_rc (a : _ Account.Poly.t) =\n { a with receipt_chain_hash = () }\n in\n match L.(location_of_account l1 a, location_of_account l2 a) with\n | None, None ->\n ()\n | Some _, None | None, Some _ ->\n mismatch ()\n | Some x1, Some x2 -> (\n match L.(get l1 x1, get l2 x2) with\n | None, None ->\n ()\n | Some _, None | None, Some _ ->\n mismatch ()\n | Some a1, Some a2 ->\n [%test_eq: Account_without_receipt_chain_hash.t]\n (hide_rc a1) (hide_rc a2) ) ) )\n |> Or_error.combine_errors_unit\n\n let txn_global_slot = Global_slot_since_genesis.zero\n\n let iter_err ts ~f =\n List.fold_until ts\n ~finish:(fun () -> Ok ())\n ~init:()\n ~f:(fun () t ->\n match f t with Error e -> Stop (Error e) | Ok _ -> Continue () )\n\n let view : Zkapp_precondition.Protocol_state.View.t =\n let h = Frozen_ledger_hash.empty_hash in\n let len = Length.zero in\n let a = Currency.Amount.zero in\n let epoch_data =\n { Epoch_data.Poly.ledger =\n { Epoch_ledger.Poly.hash = h; total_currency = a }\n ; seed = h\n ; start_checkpoint = h\n ; lock_checkpoint = h\n ; epoch_length = len\n }\n in\n { snarked_ledger_hash = h\n ; blockchain_length = len\n ; min_window_density = len\n ; total_currency = a\n ; global_slot_since_genesis = txn_global_slot\n ; staking_epoch_data = epoch_data\n ; next_epoch_data = epoch_data\n }\n\n (* Quickcheck generator for Zkapp_command.t, derived from Test_spec generator *)\n let gen_zkapp_command_from_test_spec =\n let open Quickcheck.Let_syntax in\n let%bind use_full_commitment = Bool.quickcheck_generator in\n match%map Test_spec.mk_gen ~num_transactions:1 () with\n | { specs = [ spec ]; _ } ->\n account_update_send ~use_full_commitment spec\n | { specs; _ } ->\n failwithf \"gen_zkapp_command_from_test_spec: expected one spec, got %d\"\n (List.length specs) ()\nend\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\nmodule Impl = Pickles.Impls.Step\nmodule Other_impl = Pickles.Impls.Wrap\nmodule Field = Impl.Field\nmodule Account_update = Mina_base.Account_update\nmodule Zkapp_command = Mina_base.Zkapp_command\n\n(* Test - functions that have a ts implementation, exposed for ts-ml consistency tests *)\n\nmodule Encoding = struct\n (* arbitrary base58_check encoding *)\n let binary_string_to_base58_check bin_string (version_byte : int) :\n Js.js_string Js.t =\n let module T = struct\n let version_byte = Char.of_int_exn version_byte\n\n let description = \"any\"\n end in\n let module B58 = Base58_check.Make (T) in\n bin_string |> B58.encode |> Js.string\n\n let binary_string_of_base58_check (base58 : Js.js_string Js.t)\n (version_byte : int) =\n let module T = struct\n let version_byte = Char.of_int_exn version_byte\n\n let description = \"any\"\n end in\n let module B58 = Base58_check.Make (T) in\n base58 |> Js.to_string |> B58.decode_exn\n\n (* base58 encoding of some transaction types *)\n let public_key_to_base58 (pk : Signature_lib.Public_key.Compressed.t) :\n Js.js_string Js.t =\n pk |> Signature_lib.Public_key.Compressed.to_base58_check |> Js.string\n\n let public_key_of_base58 (pk_base58 : Js.js_string Js.t) :\n Signature_lib.Public_key.Compressed.t =\n pk_base58 |> Js.to_string\n |> Signature_lib.Public_key.Compressed.of_base58_check_exn\n\n let private_key_to_base58 (sk : Other_impl.field) : Js.js_string Js.t =\n sk |> Signature_lib.Private_key.to_base58_check |> Js.string\n\n let private_key_of_base58 (sk_base58 : Js.js_string Js.t) : Other_impl.field =\n sk_base58 |> Js.to_string |> Signature_lib.Private_key.of_base58_check_exn\n\n let token_id_to_base58 (field : Impl.field) : Js.js_string Js.t =\n field |> Mina_base.Account_id.Digest.of_field\n |> Mina_base.Account_id.Digest.to_string |> Js.string\n\n let token_id_of_base58 (field : Js.js_string Js.t) : Impl.field =\n Mina_base.Account_id.Digest.to_field_unsafe\n @@ Mina_base.Account_id.Digest.of_string @@ Js.to_string field\n\n let memo_to_base58 (memo : Js.js_string Js.t) : Js.js_string Js.t =\n Js.string @@ Mina_base.Signed_command_memo.to_base58_check\n @@ Mina_base.Signed_command_memo.create_from_string_exn @@ Js.to_string memo\n\n let memo_hash_base58 (memo_base58 : Js.js_string Js.t) : Impl.field =\n memo_base58 |> Js.to_string\n |> Mina_base.Signed_command_memo.of_base58_check_exn\n |> Mina_base.Signed_command_memo.hash\nend\n\nmodule Token_id = struct\n let derive pk token =\n let account_id =\n Mina_base.Account_id.create pk (Mina_base.Token_id.of_field token)\n in\n Mina_base.Account_id.derive_token_id ~owner:account_id\n |> Mina_base.Token_id.to_field_unsafe\n\n let derive_checked pk token =\n let account_id =\n Mina_base.Account_id.Checked.create pk\n (Mina_base.Token_id.Checked.of_field token)\n in\n Mina_base.Account_id.Checked.derive_token_id ~owner:account_id\n |> Mina_base.Account_id.Digest.Checked.to_field_unsafe\nend\n\n(* deriver *)\nlet account_update_of_json, _account_update_to_json =\n let deriver =\n lazy\n ( Account_update.Graphql_repr.deriver\n @@ Fields_derivers_zkapps.Derivers.o () )\n in\n let account_update_of_json (account_update : Js.js_string Js.t) :\n Account_update.t =\n Fields_derivers_zkapps.of_json (Lazy.force deriver)\n (account_update |> Js.to_string |> Yojson.Safe.from_string)\n |> Account_update.of_graphql_repr\n in\n let account_update_to_json (account_update : Account_update.t) :\n Js.js_string Js.t =\n Fields_derivers_zkapps.to_json (Lazy.force deriver)\n (Account_update.to_graphql_repr account_update ~call_depth:0)\n |> Yojson.Safe.to_string |> Js.string\n in\n (account_update_of_json, account_update_to_json)\n\nlet body_of_json =\n let body_deriver =\n lazy\n ( Mina_base.Account_update.Body.Graphql_repr.deriver\n @@ Fields_derivers_zkapps.o () )\n in\n let body_of_json json =\n json\n |> Fields_derivers_zkapps.of_json (Lazy.force body_deriver)\n |> Account_update.Body.of_graphql_repr\n in\n body_of_json\n\nmodule Poseidon = struct\n let hash_to_group (xs : Impl.field array) =\n let input = Random_oracle.hash xs in\n Snark_params.Group_map.to_group input\nend\n\nmodule Signature = struct\n let sign_field_element (x : Impl.field) (key : Other_impl.field)\n (is_mainnet : bool Js.t) =\n let network_id =\n Mina_signature_kind.(if Js.to_bool is_mainnet then Mainnet else Testnet)\n in\n Signature_lib.Schnorr.Chunked.sign ~signature_kind:network_id key\n (Random_oracle.Input.Chunked.field x)\n |> Mina_base.Signature.to_base58_check |> Js.string\n\n let dummy_signature () =\n Mina_base.Signature.(dummy |> to_base58_check) |> Js.string\nend\n\nmodule To_fields = struct\n (* helper function to check whether the fields we produce from JS are correct *)\n let fields_of_json\n (typ : ('var, 'value, Field.Constant.t, 'tmp) Impl.Internal_Basic.Typ.typ)\n of_json (json : Js.js_string Js.t) : Impl.field array =\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = of_json json in\n let (Typ typ) = typ in\n let fields, _ = typ.value_to_fields value in\n fields\n\n let account_update =\n fields_of_json (Mina_base.Account_update.Body.typ ()) body_of_json\nend\n\nmodule Hash_from_json = struct\n let account_update (p : Js.js_string Js.t) =\n p |> account_update_of_json |> Account_update.digest\n\n let transaction_commitments (tx_json : Js.js_string Js.t) =\n let tx =\n Zkapp_command.of_json @@ Yojson.Safe.from_string @@ Js.to_string tx_json\n in\n let commitment = Zkapp_command.commitment tx in\n let fee_payer = Account_update.of_fee_payer tx.fee_payer in\n let fee_payer_hash = Zkapp_command.Digest.Account_update.create fee_payer in\n let full_commitment =\n Zkapp_command.Transaction_commitment.create_complete commitment\n ~memo_hash:(Mina_base.Signed_command_memo.hash tx.memo)\n ~fee_payer_hash\n in\n object%js\n val commitment = commitment\n\n val fullCommitment = full_commitment\n\n val feePayerHash = (fee_payer_hash :> Impl.field)\n end\n\n let zkapp_public_input (tx_json : Js.js_string Js.t)\n (account_update_index : int) =\n let tx =\n Zkapp_command.of_json @@ Yojson.Safe.from_string @@ Js.to_string tx_json\n in\n let account_update = List.nth_exn tx.account_updates account_update_index in\n object%js\n val accountUpdate =\n (account_update.elt.account_update_digest :> Impl.field)\n\n val calls =\n (Zkapp_command.Call_forest.hash account_update.elt.calls :> Impl.field)\n end\nend\n\nmodule Hash_input = struct\n type random_oracle_input = Impl.field Random_oracle_input.Chunked.t\n\n let pack_input (input : random_oracle_input) : Impl.field array =\n Random_oracle.pack_input input\n\n (* hash inputs for various account_update subtypes *)\n let timing_input (json : Js.js_string Js.t) : random_oracle_input =\n let deriver = Account_update.Update.Timing_info.deriver in\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = Fields_derivers_zkapps.(of_json (deriver @@ o ()) json) in\n let input = Account_update.Update.Timing_info.to_input value in\n input\n\n let permissions_input (json : Js.js_string Js.t) : random_oracle_input =\n let deriver = Mina_base.Permissions.deriver in\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = Fields_derivers_zkapps.(of_json (deriver @@ o ()) json) in\n let input = Mina_base.Permissions.to_input value in\n input\n\n let update_input (json : Js.js_string Js.t) : random_oracle_input =\n let deriver = Account_update.Update.deriver in\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = Fields_derivers_zkapps.(of_json (deriver @@ o ()) json) in\n let input = Account_update.Update.to_input value in\n input\n\n let account_precondition_input (json : Js.js_string Js.t) :\n random_oracle_input =\n let deriver = Mina_base.Zkapp_precondition.Account.deriver in\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = Fields_derivers_zkapps.(of_json (deriver @@ o ()) json) in\n let input = Mina_base.Zkapp_precondition.Account.to_input value in\n input\n\n let network_precondition_input (json : Js.js_string Js.t) :\n random_oracle_input =\n let deriver = Mina_base.Zkapp_precondition.Protocol_state.deriver in\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = Fields_derivers_zkapps.(of_json (deriver @@ o ()) json) in\n let input = Mina_base.Zkapp_precondition.Protocol_state.to_input value in\n input\n\n let body_input (json : Js.js_string Js.t) : random_oracle_input =\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = body_of_json json in\n let input = Account_update.Body.to_input value in\n input\nend\n\nmodule Transaction_hash = struct\n module Signed_command = Mina_base.Signed_command\n module Signed_command_payload = Mina_base.Signed_command_payload\n\n let ok_exn result =\n let open Ppx_deriving_yojson_runtime.Result in\n match result with Ok c -> c | Error e -> failwith (\"not ok: \" ^ e)\n\n let keypair () = Signature_lib.Keypair.create ()\n\n let hash_payment (command : Js.js_string Js.t) =\n let command : Signed_command.t =\n command |> Js.to_string |> Yojson.Safe.from_string\n |> Signed_command.of_yojson |> ok_exn\n in\n Mina_transaction.Transaction_hash.(\n command |> hash_signed_command |> to_base58_check |> Js.string)\n\n let hash_payment_v1 (command : Js.js_string Js.t) =\n let command : Signed_command.t_v1 =\n command |> Js.to_string |> Yojson.Safe.from_string\n |> Signed_command.Stable.V1.of_yojson |> ok_exn\n in\n let b58 = Signed_command.to_base58_check_v1 command in\n Mina_transaction.Transaction_hash.(b58 |> digest_string |> to_base58_check)\n |> Js.string\n\n let serialize_common (command : Js.js_string Js.t) =\n let command : Signed_command_payload.Common.t =\n command |> Js.to_string |> Yojson.Safe.from_string\n |> Signed_command_payload.Common.of_yojson |> ok_exn\n in\n Binable.to_bigstring\n (module Signed_command_payload.Common.Stable.Latest)\n command\n\n let serialize_payment (command : Js.js_string Js.t) =\n let command : Signed_command.t =\n command |> Js.to_string |> Yojson.Safe.from_string\n |> Signed_command.of_yojson |> ok_exn\n in\n Binable.to_bigstring (module Signed_command.Stable.Latest) command\n\n let serialize_payment_v1 (command : Js.js_string Js.t) =\n let command : Signed_command.t_v1 =\n command |> Js.to_string |> Yojson.Safe.from_string\n |> Signed_command.Stable.V1.of_yojson |> ok_exn\n in\n Signed_command.to_base58_check_v1 command |> Js.string\n\n let example_payment () =\n let kp = keypair () in\n let payload : Signed_command_payload.t =\n { Signed_command_payload.dummy with\n common =\n { Signed_command_payload.dummy.common with\n fee_payer_pk = Signature_lib.Public_key.compress kp.public_key\n }\n }\n in\n let payment = Signed_command.sign kp payload in\n (payment :> Signed_command.t)\n |> Signed_command.to_yojson |> Yojson.Safe.to_string |> Js.string\nend\n\nlet test =\n object%js\n val encoding =\n let open Encoding in\n object%js\n val toBase58 = binary_string_to_base58_check\n\n val ofBase58 = binary_string_of_base58_check\n\n method publicKeyToBase58 = public_key_to_base58\n\n method publicKeyOfBase58 = public_key_of_base58\n\n method privateKeyToBase58 = private_key_to_base58\n\n method privateKeyOfBase58 = private_key_of_base58\n\n method tokenIdToBase58 = token_id_to_base58\n\n method tokenIdOfBase58 = token_id_of_base58\n\n method memoToBase58 = memo_to_base58\n\n method memoHashBase58 = memo_hash_base58\n end\n\n val tokenId =\n object%js\n method derive = Token_id.derive\n\n method deriveChecked = Token_id.derive_checked\n end\n\n val poseidon =\n object%js\n val hashToGroup = Poseidon.hash_to_group\n end\n\n val signature =\n object%js\n method signFieldElement = Signature.sign_field_element\n\n val dummySignature = Signature.dummy_signature\n end\n\n val fieldsFromJson =\n object%js\n method accountUpdate = To_fields.account_update\n end\n\n val hashFromJson =\n object%js\n method accountUpdate = Hash_from_json.account_update\n\n method transactionCommitments = Hash_from_json.transaction_commitments\n\n method zkappPublicInput = Hash_from_json.zkapp_public_input\n end\n\n val hashInputFromJson =\n let open Hash_input in\n object%js\n val packInput = pack_input\n\n val timing = timing_input\n\n val permissions = permissions_input\n\n val accountPrecondition = account_precondition_input\n\n val networkPrecondition = network_precondition_input\n\n val update = update_input\n\n val body = body_input\n end\n\n val transactionHash =\n let open Transaction_hash in\n object%js\n method hashPayment = hash_payment\n\n method hashPaymentV1 = hash_payment_v1\n\n method serializeCommon = serialize_common\n\n method serializePayment = serialize_payment\n\n method serializePaymentV1 = serialize_payment_v1\n\n val examplePayment = example_payment\n end\n end\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\nmodule Impl = Pickles.Impls.Step\nmodule Field = Impl.Field\nmodule Boolean = Impl.Boolean\nmodule Typ = Impl.Typ\n\nmodule Public_input = struct\n type t = Field.t array\n\n module Constant = struct\n type t = Field.Constant.t array\n end\nend\n\ntype 'a statement = 'a array * 'a array\n\nmodule Statement = struct\n type t = Field.t statement\n\n module Constant = struct\n type t = Field.Constant.t statement\n end\nend\n\nlet public_input_typ (i : int) = Typ.array ~length:i Field.typ\n\nlet statement_typ (input_size : int) (output_size : int) =\n Typ.(array ~length:input_size Field.typ * array ~length:output_size Field.typ)\n\ntype ('prev_proof, 'proof) js_prover =\n Public_input.Constant.t\n -> 'prev_proof array\n -> (Public_input.Constant.t * 'proof) Promise_js_helpers.js_promise\n\nlet dummy_constraints =\n let module Inner_curve = Kimchi_pasta.Pasta.Pallas in\n let module Step_main_inputs = Pickles.Step_main_inputs in\n let inner_curve_typ : (Field.t * Field.t, Inner_curve.t) Typ.t =\n Typ.transport Step_main_inputs.Inner_curve.typ\n ~there:Inner_curve.to_affine_exn ~back:Inner_curve.of_affine\n in\n fun () ->\n let x =\n Impl.exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3)\n in\n let g = Impl.exists inner_curve_typ ~compute:(fun _ -> Inner_curve.one) in\n ignore\n ( Pickles.Scalar_challenge.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Pickles.Step_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t )\n\ntype pickles_rule_js =\n < identifier : Js.js_string Js.t Js.prop\n ; main :\n ( Public_input.t\n -> < publicOutput : Public_input.t Js.prop\n ; previousStatements : Statement.t array Js.prop\n ; shouldVerify : Boolean.var array Js.prop >\n Js.t )\n Js.prop\n ; proofsToVerify :\n < isSelf : bool Js.t Js.prop ; tag : Js.Unsafe.any Js.t Js.prop > Js.t\n array\n Js.prop >\n Js.t\n\nmodule Choices = struct\n open Pickles_types\n open Hlist\n\n module Prevs = struct\n type ('var, 'value, 'width, 'height) t =\n | Prevs :\n ( self:('var, 'value, 'width, 'height) Pickles.Tag.t\n -> ('prev_var, 'prev_values, 'widths, 'heights) H4.T(Pickles.Tag).t\n )\n -> ('var, 'value, 'width, 'height) t\n\n let of_rule (rule : pickles_rule_js) =\n let js_prevs = rule##.proofsToVerify in\n let rec get_tags (Prevs prevs) index =\n if index < 0 then Prevs prevs\n else\n let js_tag = Array.get js_prevs index in\n (* We introduce new opaque types to make sure that the type in the tag\n doesn't escape into the environment or have other ill effects.\n *)\n let module Types = struct\n type var\n\n type value\n\n type width\n\n type height\n end in\n let open Types in\n let to_tag ~self tag : (var, value, width, height) Pickles.Tag.t =\n (* The magic here isn't ideal, but it's safe enough if we immediately\n hide it behind [Types].\n *)\n if Js.to_bool tag##.isSelf then Obj.magic self\n else Obj.magic tag##.tag\n in\n let tag = to_tag js_tag in\n let prevs ~self : _ H4.T(Pickles.Tag).t = tag ~self :: prevs ~self in\n get_tags (Prevs prevs) (index - 1)\n in\n get_tags (Prevs (fun ~self:_ -> [])) (Array.length js_prevs - 1)\n end\n\n module Inductive_rule = struct\n type ( 'var\n , 'value\n , 'width\n , 'height\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n t =\n | Rule :\n ( self:('var, 'value, 'width, 'height) Pickles.Tag.t\n -> ( 'prev_vars\n , 'prev_values\n , 'widths\n , 'heights\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n Pickles.Inductive_rule.t )\n -> ( 'var\n , 'value\n , 'width\n , 'height\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n t\n\n let rec should_verifys :\n type prev_vars prev_values widths heights.\n int\n -> (prev_vars, prev_values, widths, heights) H4.T(Pickles.Tag).t\n -> Boolean.var array\n -> prev_vars H1.T(E01(Pickles.Inductive_rule.B)).t =\n fun index tags should_verifys_js ->\n match tags with\n | [] ->\n []\n | _ :: tags ->\n let js_bool = Array.get should_verifys_js index in\n let should_verifys =\n should_verifys (index + 1) tags should_verifys_js\n in\n js_bool :: should_verifys\n\n let should_verifys tags should_verifys_js =\n should_verifys 0 tags should_verifys_js\n\n let get_typ ~public_input_size ~public_output_size\n (type a1 a2 a3 a4 width height) (tag : (a1, a2, a3, a4) Pickles.Tag.t)\n (self :\n ( Public_input.t * Public_input.t\n , Public_input.Constant.t * Public_input.Constant.t\n , width\n , height )\n Pickles.Tag.t ) =\n match Type_equal.Id.same_witness tag.id self.id with\n | None ->\n Pickles.Types_map.public_input tag\n | Some T ->\n statement_typ public_input_size public_output_size\n\n let rec prev_statements :\n type prev_vars prev_values widths heights width height.\n public_input_size:int\n -> public_output_size:int\n -> self:\n ( Public_input.t * Public_input.t\n , Public_input.Constant.t * Public_input.Constant.t\n , width\n , height )\n Pickles.Tag.t\n -> int\n -> (prev_vars, prev_values, widths, heights) H4.T(Pickles.Tag).t\n -> Statement.t array\n -> prev_vars H1.T(Id).t =\n fun ~public_input_size ~public_output_size ~self i tags statements ->\n match tags with\n | [] ->\n []\n | tag :: tags ->\n let (Typ typ) =\n get_typ ~public_input_size ~public_output_size tag self\n in\n let input, output = Array.get statements i in\n let fields = Array.concat [ input; output ] in\n let aux = typ.constraint_system_auxiliary () in\n let statement = typ.var_of_fields (fields, aux) in\n statement\n :: prev_statements ~public_input_size ~public_output_size ~self\n (i + 1) tags statements\n\n let prev_statements ~public_input_size ~public_output_size ~self tags\n statements =\n prev_statements ~public_input_size ~public_output_size ~self 0 tags\n statements\n\n type _ Snarky_backendless.Request.t +=\n | Get_prev_proof : int -> _ Pickles.Proof.t Snarky_backendless.Request.t\n\n let create ~public_input_size ~public_output_size (rule : pickles_rule_js) :\n ( _\n , _\n , _\n , _\n , Public_input.t\n , Public_input.Constant.t\n , Public_input.t\n , Public_input.Constant.t\n , unit\n , unit )\n t =\n let (Prevs prevs) = Prevs.of_rule rule in\n Rule\n (fun ~(self :\n ( Field.t array * Field.t array\n , Impl.field array * Impl.field array\n , 'b3\n , 'b4 )\n Pickles.Tag.t ) ->\n let prevs = prevs ~self in\n { Pickles.Inductive_rule.identifier = Js.to_string rule##.identifier\n ; feature_flags = Pickles_types.Plonk_types.Features.none_bool\n ; prevs\n ; main =\n (fun { public_input } ->\n dummy_constraints () ;\n let result = rule##.main public_input in\n let public_output = result##.publicOutput in\n let previous_proofs_should_verify =\n should_verifys prevs result##.shouldVerify\n in\n let previous_public_inputs =\n prev_statements ~public_input_size ~public_output_size ~self\n prevs\n result##.previousStatements\n in\n let previous_proof_statements =\n let rec go :\n type prev_vars prev_values widths heights.\n int\n -> prev_vars H1.T(Id).t\n -> prev_vars H1.T(E01(Pickles.Inductive_rule.B)).t\n -> ( prev_vars\n , prev_values\n , widths\n , heights )\n H4.T(Pickles.Tag).t\n -> ( prev_vars\n , widths )\n H2.T(Pickles.Inductive_rule.Previous_proof_statement).t\n =\n fun i public_inputs should_verifys tags ->\n match (public_inputs, should_verifys, tags) with\n | [], [], [] ->\n []\n | ( public_input :: public_inputs\n , proof_must_verify :: should_verifys\n , _tag :: tags ) ->\n let proof =\n Impl.exists (Impl.Typ.Internal.ref ())\n ~request:(fun () -> Get_prev_proof i)\n in\n { public_input; proof; proof_must_verify }\n :: go (i + 1) public_inputs should_verifys tags\n in\n go 0 previous_public_inputs previous_proofs_should_verify\n prevs\n in\n { previous_proof_statements\n ; public_output\n ; auxiliary_output = ()\n } )\n } )\n end\n\n type ( 'var\n , 'value\n , 'width\n , 'height\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n t =\n | Choices :\n ( self:('var, 'value, 'width, 'height) Pickles.Tag.t\n -> ( 'prev_vars\n , 'prev_values\n , 'widths\n , 'heights\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n H4_6.T(Pickles.Inductive_rule).t )\n -> ( 'var\n , 'value\n , 'width\n , 'height\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n t\n\n let of_js ~public_input_size ~public_output_size js_rules =\n let rec get_rules (Choices rules) index :\n ( _\n , _\n , _\n , _\n , Public_input.t\n , Public_input.Constant.t\n , Public_input.t\n , Public_input.Constant.t\n , unit\n , unit )\n t =\n if index < 0 then Choices rules\n else\n let (Rule rule) =\n Inductive_rule.create ~public_input_size ~public_output_size\n (Array.get js_rules index)\n in\n let rules ~self : _ H4_6.T(Pickles.Inductive_rule).t =\n rule ~self :: rules ~self\n in\n get_rules (Choices rules) (index - 1)\n in\n get_rules (Choices (fun ~self:_ -> [])) (Array.length js_rules - 1)\nend\n\ntype proof = (Pickles_types.Nat.N0.n, Pickles_types.Nat.N0.n) Pickles.Proof.t\n\nmodule Public_inputs_with_proofs =\n Pickles_types.Hlist.H3.T (Pickles.Statement_with_proof)\n\nlet nat_modules_list : (module Pickles_types.Nat.Intf) list =\n let open Pickles_types.Nat in\n [ (module N0)\n ; (module N1)\n ; (module N2)\n ; (module N3)\n ; (module N4)\n ; (module N5)\n ; (module N6)\n ; (module N7)\n ; (module N8)\n ; (module N9)\n ; (module N10)\n ; (module N11)\n ; (module N12)\n ; (module N13)\n ; (module N14)\n ; (module N15)\n ; (module N16)\n ; (module N17)\n ; (module N18)\n ; (module N19)\n ; (module N20)\n ]\n\nlet nat_add_modules_list : (module Pickles_types.Nat.Add.Intf) list =\n let open Pickles_types.Nat in\n [ (module N0)\n ; (module N1)\n ; (module N2)\n ; (module N3)\n ; (module N4)\n ; (module N5)\n ; (module N6)\n ; (module N7)\n ; (module N8)\n ; (module N9)\n ; (module N10)\n ; (module N11)\n ; (module N12)\n ; (module N13)\n ; (module N14)\n ; (module N15)\n ; (module N16)\n ; (module N17)\n ; (module N18)\n ; (module N19)\n ; (module N20)\n ]\n\nlet nat_module (i : int) : (module Pickles_types.Nat.Intf) =\n List.nth_exn nat_modules_list i\n\nlet nat_add_module (i : int) : (module Pickles_types.Nat.Add.Intf) =\n List.nth_exn nat_add_modules_list i\n\nlet name = \"smart-contract\"\n\nlet constraint_constants =\n (* TODO these are dummy values *)\n { Snark_keys_header.Constraint_constants.sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n\nlet pickles_compile (choices : pickles_rule_js array)\n (signature :\n < publicInputSize : int Js.prop\n ; publicOutputSize : int Js.prop\n ; overrideWrapDomain : int Js.optdef_prop >\n Js.t ) =\n (* translate number of branches and recursively verified proofs from JS *)\n let branches = Array.length choices in\n let max_proofs =\n let choices = choices |> Array.to_list in\n List.map choices ~f:(fun c -> c##.proofsToVerify |> Array.length)\n |> List.max_elt ~compare |> Option.value ~default:0\n in\n let (module Branches) = nat_module branches in\n let (module Max_proofs_verified) = nat_add_module max_proofs in\n\n (* translate method circuits from JS *)\n let public_input_size = signature##.publicInputSize in\n let public_output_size = signature##.publicOutputSize in\n let override_wrap_domain =\n Js.Optdef.to_option signature##.overrideWrapDomain\n |> Option.map ~f:Pickles_base.Proofs_verified.of_int\n in\n let (Choices choices) =\n Choices.of_js ~public_input_size ~public_output_size choices\n in\n\n (* call into Pickles *)\n let tag, _cache, p, provers =\n Pickles.compile_promise () ?override_wrap_domain ~choices\n ~public_input:\n (Input_and_output\n ( public_input_typ public_input_size\n , public_input_typ public_output_size ) )\n ~auxiliary_typ:Typ.unit\n ~branches:(module Branches)\n ~max_proofs_verified:(module Max_proofs_verified)\n ~name ~constraint_constants\n in\n\n (* translate returned prover and verify functions to JS *)\n let module Proof = (val p) in\n let to_js_prover prover : ('prev_proof, Proof.t) js_prover =\n let prove (public_input : Public_input.Constant.t)\n (prevs : 'prev_proof array) =\n let handler (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Choices.Inductive_rule.Get_prev_proof i ->\n respond (Provide (Obj.magic (Array.get prevs i)))\n | _ ->\n respond Unhandled\n in\n prover ?handler:(Some handler) public_input\n |> Promise.map ~f:(fun (output, _, proof) -> (output, proof))\n |> Promise_js_helpers.to_js\n in\n prove\n in\n let rec to_js_provers :\n type a b c.\n ( a\n , b\n , c\n , Public_input.Constant.t\n , (Public_input.Constant.t * unit * Proof.t) Promise.t )\n Pickles.Provers.t\n -> ('prev_proof, Proof.t) js_prover list = function\n | [] ->\n []\n | p :: ps ->\n to_js_prover p :: to_js_provers ps\n in\n let provers : (_, Proof.t) js_prover array =\n provers |> to_js_provers |> Array.of_list\n in\n let verify (statement : Statement.Constant.t) (proof : _ Pickles.Proof.t) =\n Proof.verify_promise [ (statement, proof) ]\n |> Promise.map ~f:(fun x -> Js.bool (Or_error.is_ok x))\n |> Promise_js_helpers.to_js\n in\n object%js\n val provers = Obj.magic provers\n\n val verify = Obj.magic verify\n\n val tag = Obj.magic tag\n\n method getVerificationKey =\n let vk = Pickles.Side_loaded.Verification_key.of_compiled tag in\n let data = Pickles.Side_loaded.Verification_key.to_base64 vk in\n let hash = Mina_base.Zkapp_account.digest_vk vk in\n (data |> Js.string, hash)\n end\n\nmodule Proof0 = Pickles.Proof.Make (Pickles_types.Nat.N0) (Pickles_types.Nat.N0)\nmodule Proof1 = Pickles.Proof.Make (Pickles_types.Nat.N1) (Pickles_types.Nat.N1)\nmodule Proof2 = Pickles.Proof.Make (Pickles_types.Nat.N2) (Pickles_types.Nat.N2)\n\ntype some_proof = Proof0 of Proof0.t | Proof1 of Proof1.t | Proof2 of Proof2.t\n\nlet proof_to_base64 = function\n | Proof0 proof ->\n Proof0.to_base64 proof |> Js.string\n | Proof1 proof ->\n Proof1.to_base64 proof |> Js.string\n | Proof2 proof ->\n Proof2.to_base64 proof |> Js.string\n\nlet proof_of_base64 str i : some_proof =\n let str = Js.to_string str in\n match i with\n | 0 ->\n Proof0 (Proof0.of_base64 str |> Result.ok_or_failwith)\n | 1 ->\n Proof1 (Proof1.of_base64 str |> Result.ok_or_failwith)\n | 2 ->\n Proof2 (Proof2.of_base64 str |> Result.ok_or_failwith)\n | _ ->\n failwith \"invalid proof index\"\n\nlet verify (statement : Statement.Constant.t) (proof : proof)\n (vk : Js.js_string Js.t) =\n let i, o = statement in\n let typ = statement_typ (Array.length i) (Array.length o) in\n let proof = Pickles.Side_loaded.Proof.of_proof proof in\n let vk =\n match Pickles.Side_loaded.Verification_key.of_base64 (Js.to_string vk) with\n | Ok vk_ ->\n vk_\n | Error err ->\n failwithf \"Could not decode base64 verification key: %s\"\n (Error.to_string_hum err) ()\n in\n Pickles.Side_loaded.verify_promise ~typ [ (vk, statement, proof) ]\n |> Promise.map ~f:(fun x -> Js.bool (Or_error.is_ok x))\n |> Promise_js_helpers.to_js\n\nlet dummy_base64_proof () =\n let n2 = Pickles_types.Nat.N2.n in\n let proof = Pickles.Proof.dummy n2 n2 n2 ~domain_log2:15 in\n Proof2.to_base64 proof |> Js.string\n\nlet dummy_verification_key () =\n let vk = Pickles.Side_loaded.Verification_key.dummy in\n let data = Pickles.Side_loaded.Verification_key.to_base64 vk in\n let hash = Mina_base.Zkapp_account.digest_vk vk in\n (data |> Js.string, hash)\n\nlet pickles =\n object%js\n val compile = pickles_compile\n\n val verify = verify\n\n val dummyBase64Proof = dummy_base64_proof\n\n val dummyVerificationKey = dummy_verification_key\n\n val proofToBase64 = proof_to_base64\n\n val proofOfBase64 = proof_of_base64\n\n val proofToBase64Transaction =\n fun (proof : proof) ->\n proof |> Pickles.Side_loaded.Proof.of_proof\n |> Pickles.Side_loaded.Proof.to_base64 |> Js.string\n end\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Benoit Vaugon, ENSTA *)\n(* *)\n(* Copyright 2014 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Padding position. *)\ntype padty =\n | Left (* Text is left justified ('-' option). *)\n | Right (* Text is right justified (no '-' option). *)\n | Zeros (* Text is right justified by zeros (see '0' option). *)\n\n(***)\n\n(* Integer conversion. *)\ntype int_conv =\n | Int_d | Int_pd | Int_sd (* %d | %+d | % d *)\n | Int_i | Int_pi | Int_si (* %i | %+i | % i *)\n | Int_x | Int_Cx (* %x | %#x *)\n | Int_X | Int_CX (* %X | %#X *)\n | Int_o | Int_Co (* %o | %#o *)\n | Int_u (* %u *)\n | Int_Cd | Int_Ci | Int_Cu (* %#d | %#i | %#u *)\n\n(* Float conversion. *)\ntype float_flag_conv =\n | Float_flag_ (* %[feEgGFhH] *)\n | Float_flag_p (* %+[feEgGFhH] *)\n | Float_flag_s (* % [feEgGFhH] *)\ntype float_kind_conv =\n | Float_f (* %f | %+f | % f *)\n | Float_e (* %e | %+e | % e *)\n | Float_E (* %E | %+E | % E *)\n | Float_g (* %g | %+g | % g *)\n | Float_G (* %G | %+G | % G *)\n | Float_F (* %F | %+F | % F *)\n | Float_h (* %h | %+h | % h *)\n | Float_H (* %H | %+H | % H *)\n | Float_CF (* %#F| %+#F| % #F *)\ntype float_conv = float_flag_conv * float_kind_conv\n\n(***)\n\n(* Char sets (see %[...]) are bitmaps implemented as 32-char strings. *)\ntype char_set = string\n\n(***)\n\n(* Counter used in Scanf. *)\ntype counter =\n | Line_counter (* %l *)\n | Char_counter (* %n *)\n | Token_counter (* %N, %L *)\n\n(***)\n\n(* Padding of strings and numbers. *)\ntype ('a, 'b) padding =\n (* No padding (ex: \"%d\") *)\n | No_padding : ('a, 'a) padding\n (* Literal padding (ex: \"%8d\") *)\n | Lit_padding : padty * int -> ('a, 'a) padding\n (* Padding as extra argument (ex: \"%*d\") *)\n | Arg_padding : padty -> (int -> 'a, 'a) padding\n\n(* Some formats, such as %_d,\n only accept an optional number as padding option (no extra argument) *)\ntype pad_option = int option\n\n(* Precision of floats and '0'-padding of integers. *)\ntype ('a, 'b) precision =\n (* No precision (ex: \"%f\") *)\n | No_precision : ('a, 'a) precision\n (* Literal precision (ex: \"%.3f\") *)\n | Lit_precision : int -> ('a, 'a) precision\n (* Precision as extra argument (ex: \"%.*f\") *)\n | Arg_precision : (int -> 'a, 'a) precision\n\n(* Some formats, such as %_f,\n only accept an optional number as precision option (no extra argument) *)\ntype prec_option = int option\n\n(* see the Custom format combinator *)\ntype ('a, 'b, 'c) custom_arity =\n | Custom_zero : ('a, string, 'a) custom_arity\n | Custom_succ : ('a, 'b, 'c) custom_arity ->\n ('a, 'x -> 'b, 'x -> 'c) custom_arity\n\n(***)\n\n(* Relational format types\n\nIn the first format+gadts implementation, the type for %(..%) in the\nfmt GADT was as follows:\n\n| Format_subst : (* %(...%) *)\n pad_option * ('d1, 'q1, 'd2, 'q2) reader_nb_unifier *\n ('x, 'b, 'c, 'd1, 'q1, 'u) fmtty *\n ('u, 'b, 'c, 'q1, 'e1, 'f) fmt ->\n (('x, 'b, 'c, 'd2, 'q2, 'u) format6 -> 'x, 'b, 'c, 'd1, 'e1, 'f) fmt\n\nNotice that the 'u parameter in 'f position in the format argument\n(('x, .., 'u) format6 -> ..) is equal to the 'u parameter in 'a\nposition in the format tail (('u, .., 'f) fmt). This means that the\ntype of the expected format parameter depends of where the %(...%)\nare in the format string:\n\n # Printf.printf \"%(%)\"\n - : (unit, out_channel, unit, '_a, '_a, unit)\n CamlinternalFormatBasics.format6 -> unit\n = \n # Printf.printf \"%(%)%d\"\n - : (int -> unit, out_channel, unit, '_a, '_a, int -> unit)\n CamlinternalFormatBasics.format6 -> int -> unit\n = \n\nOn the contrary, the legacy typer gives a clever type that does not\ndepend on the position of %(..%) in the format string. For example,\n%(%) will have the polymorphic type ('a, 'b, 'c, 'd, 'd, 'a): it can\nbe concatenated to any format type, and only enforces the constraint\nthat its 'a and 'f parameters are equal (no format arguments) and 'd\nand 'e are equal (no reader argument).\n\nThe weakening of this parameter type in the GADT version broke user\ncode (in fact it essentially made %(...%) unusable except at the last\nposition of a format). In particular, the following would not work\nanymore:\n\n fun sep ->\n Format.printf \"foo%(%)bar%(%)baz\" sep sep\n\nAs the type-checker would require two *incompatible* types for the %(%)\nin different positions.\n\nThe solution to regain a general type for %(..%) is to generalize this\ntechnique, not only on the 'd, 'e parameters, but on all six\nparameters of a format: we introduce a \"relational\" type\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\nwhose values are proofs that ('a1, .., 'f1) and ('a2, .., 'f2) morally\ncorrespond to the same format type: 'a1 is obtained from 'f1,'b1,'c1\nin the exact same way that 'a2 is obtained from 'f2,'b2,'c2, etc.\n\nFor example, the relation between two format types beginning with a Char\nparameter is as follows:\n\n| Char_ty : (* %c *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (char -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n char -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n\nIn the general case, the term structure of fmtty_rel is (almost[1])\nisomorphic to the fmtty of the previous implementation: every\nconstructor is re-read with a binary, relational type, instead of the\nprevious unary typing. fmtty can then be re-defined as the diagonal of\nfmtty_rel:\n\n type ('a, 'b, 'c, 'd, 'e, 'f) fmtty =\n ('a, 'b, 'c, 'd, 'e, 'f,\n 'a, 'b, 'c, 'd, 'e, 'f) fmtty_rel\n\nOnce we have this fmtty_rel type in place, we can give the more\ngeneral type to %(...%):\n\n| Format_subst : (* %(...%) *)\n pad_option *\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g2, 'b, 'c, 'j2, 'd, 'a) fmtty_rel *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b, 'c, 'j2, 'e, 'f) fmt\n\nWe accept any format (('g, 'h, 'i, 'j, 'k, 'l) format6) (this is\ncompletely unrelated to the type of the current format), but also\nrequire a proof that this format is in relation to another format that\nis concatenable to the format tail. When executing a %(...%) format\n(in camlinternalFormat.ml:make_printf or scanf.ml:make_scanf), we\ntranstype the format along this relation using the 'recast' function\nto transpose between related format types.\n\n val recast :\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1) fmt\n -> ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n -> ('a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmt\n\nNOTE [1]: the typing of Format_subst_ty requires not one format type, but\ntwo, one to establish the link between the format argument and the\nfirst six parameters, and the other for the link between the format\nargument and the last six parameters.\n\n| Format_subst_ty : (* %(...%) *)\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g1, 'b1, 'c1, 'j1, 'd1, 'a1) fmtty_rel *\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g2, 'b2, 'c2, 'j2, 'd2, 'a2) fmtty_rel *\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g1, 'b1, 'c1, 'j1, 'e1, 'f1,\n ('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b2, 'c2, 'j2, 'e2, 'f2) fmtty_rel\n\nWhen we generate a format AST, we generate exactly the same witness\nfor both relations, and the witness-conversion functions in\ncamlinternalFormat do rely on this invariant. For example, the\nfunction that proves that the relation is transitive\n\n val trans :\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n -> ('a2, 'b2, 'c2, 'd2, 'e2, 'f2,\n 'a3, 'b3, 'c3, 'd3, 'e3, 'f3) fmtty_rel\n -> ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a3, 'b3, 'c3, 'd3, 'e3, 'f3) fmtty_rel\n\ndoes assume that the two inputs have exactly the same term structure\n(and is only every used for argument witnesses of the\nFormat_subst_ty constructor).\n*)\n\n(* Type of a block used by the Format pretty-printer. *)\ntype block_type =\n | Pp_hbox (* Horizontal block no line breaking *)\n | Pp_vbox (* Vertical block each break leads to a new line *)\n | Pp_hvbox (* Horizontal-vertical block: same as vbox, except if this block\n is small enough to fit on a single line *)\n | Pp_hovbox (* Horizontal or Vertical block: breaks lead to new line\n only when necessary to print the content of the block *)\n | Pp_box (* Horizontal or Indent block: breaks lead to new line\n only when necessary to print the content of the block, or\n when it leads to a new indentation of the current line *)\n | Pp_fits (* Internal usage: when a block fits on a single line *)\n\n(* Formatting element used by the Format pretty-printer. *)\ntype formatting_lit =\n | Close_box (* @] *)\n | Close_tag (* @} *)\n | Break of string * int * int (* @, | @ | @; | @;<> *)\n | FFlush (* @? *)\n | Force_newline (* @\\n *)\n | Flush_newline (* @. *)\n | Magic_size of string * int (* @ *)\n | Escaped_at (* @@ *)\n | Escaped_percent (* @%% *)\n | Scan_indic of char (* @X *)\n\n(* Formatting element used by the Format pretty-printer. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) formatting_gen =\n | Open_tag : ('a, 'b, 'c, 'd, 'e, 'f) format6 -> (* @{ *)\n ('a, 'b, 'c, 'd, 'e, 'f) formatting_gen\n | Open_box : ('a, 'b, 'c, 'd, 'e, 'f) format6 -> (* @[ *)\n ('a, 'b, 'c, 'd, 'e, 'f) formatting_gen\n\n(***)\n\n(* List of format type elements. *)\n(* In particular used to represent %(...%) and %{...%} contents. *)\nand ('a, 'b, 'c, 'd, 'e, 'f) fmtty =\n ('a, 'b, 'c, 'd, 'e, 'f,\n 'a, 'b, 'c, 'd, 'e, 'f) fmtty_rel\nand ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel =\n | Char_ty : (* %c *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (char -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n char -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | String_ty : (* %s *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (string -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n string -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Int_ty : (* %d *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (int -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n int -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Int32_ty : (* %ld *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (int32 -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n int32 -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Nativeint_ty : (* %nd *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (nativeint -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n nativeint -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Int64_ty : (* %Ld *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (int64 -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n int64 -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Float_ty : (* %f *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (float -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n float -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Bool_ty : (* %B *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (bool -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n bool -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n\n | Format_arg_ty : (* %{...%} *)\n ('g, 'h, 'i, 'j, 'k, 'l) fmtty *\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n ('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2)\n fmtty_rel\n | Format_subst_ty : (* %(...%) *)\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g1, 'b1, 'c1, 'j1, 'd1, 'a1) fmtty_rel *\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g2, 'b2, 'c2, 'j2, 'd2, 'a2) fmtty_rel *\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g1, 'b1, 'c1, 'j1, 'e1, 'f1,\n ('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b2, 'c2, 'j2, 'e2, 'f2)\n fmtty_rel\n\n (* Printf and Format specific constructors. *)\n | Alpha_ty : (* %a *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (('b1 -> 'x -> 'c1) -> 'x -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n ('b2 -> 'x -> 'c2) -> 'x -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Theta_ty : (* %t *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (('b1 -> 'c1) -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n ('b2 -> 'c2) -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Any_ty : (* Used for custom formats *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n ('x -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'x -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n\n (* Scanf specific constructor. *)\n | Reader_ty : (* %r *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n ('x -> 'a1, 'b1, 'c1, ('b1 -> 'x) -> 'd1, 'e1, 'f1,\n 'x -> 'a2, 'b2, 'c2, ('b2 -> 'x) -> 'd2, 'e2, 'f2) fmtty_rel\n | Ignored_reader_ty : (* %_r *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n ('a1, 'b1, 'c1, ('b1 -> 'x) -> 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, ('b2 -> 'x) -> 'd2, 'e2, 'f2) fmtty_rel\n\n | End_of_fmtty :\n ('f1, 'b1, 'c1, 'd1, 'd1, 'f1,\n 'f2, 'b2, 'c2, 'd2, 'd2, 'f2) fmtty_rel\n\n(***)\n\n(* List of format elements. *)\nand ('a, 'b, 'c, 'd, 'e, 'f) fmt =\n | Char : (* %c *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (char -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Caml_char : (* %C *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (char -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | String : (* %s *)\n ('x, string -> 'a) padding * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Caml_string : (* %S *)\n ('x, string -> 'a) padding * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Int : (* %[dixXuo] *)\n int_conv * ('x, 'y) padding * ('y, int -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Int32 : (* %l[dixXuo] *)\n int_conv * ('x, 'y) padding * ('y, int32 -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Nativeint : (* %n[dixXuo] *)\n int_conv * ('x, 'y) padding * ('y, nativeint -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Int64 : (* %L[dixXuo] *)\n int_conv * ('x, 'y) padding * ('y, int64 -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Float : (* %[feEgGFhH] *)\n float_conv * ('x, 'y) padding * ('y, float -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Bool : (* %[bB] *)\n ('x, bool -> 'a) padding * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Flush : (* %! *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt\n\n | String_literal : (* abc *)\n string * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt\n | Char_literal : (* x *)\n char * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt\n\n | Format_arg : (* %{...%} *)\n pad_option * ('g, 'h, 'i, 'j, 'k, 'l) fmtty *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Format_subst : (* %(...%) *)\n pad_option *\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g2, 'b, 'c, 'j2, 'd, 'a) fmtty_rel *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b, 'c, 'j2, 'e, 'f) fmt\n\n (* Printf and Format specific constructor. *)\n | Alpha : (* %a *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (('b -> 'x -> 'c) -> 'x -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Theta : (* %t *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (('b -> 'c) -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n\n (* Format specific constructor: *)\n | Formatting_lit : (* @_ *)\n formatting_lit * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt\n | Formatting_gen : (* @_ *)\n ('a1, 'b, 'c, 'd1, 'e1, 'f1) formatting_gen *\n ('f1, 'b, 'c, 'e1, 'e2, 'f2) fmt -> ('a1, 'b, 'c, 'd1, 'e2, 'f2) fmt\n\n (* Scanf specific constructors: *)\n | Reader : (* %r *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x -> 'a, 'b, 'c, ('b -> 'x) -> 'd, 'e, 'f) fmt\n | Scan_char_set : (* %[...] *)\n pad_option * char_set * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (string -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Scan_get_counter : (* %[nlNL] *)\n counter * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (int -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Scan_next_char : (* %0c *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (char -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Ignored_param : (* %_ *)\n ('a, 'b, 'c, 'd, 'y, 'x) ignored * ('x, 'b, 'c, 'y, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt\n\n (* Custom printing format (PR#6452, GPR#140)\n\n We include a type Custom of \"custom converters\", where an\n arbitrary function can be used to convert one or more\n arguments. There is no syntax for custom converters, it is only\n intended for custom processors that wish to rely on the\n stdlib-defined format GADTs.\n\n For instance a pre-processor could choose to interpret strings\n prefixed with [\"!\"] as format strings where [%{{ ... }}] is\n a special form to pass a to_string function, so that one could\n write:\n\n {[\n type t = { x : int; y : int }\n\n let string_of_t t = Printf.sprintf \"{ x = %d; y = %d }\" t.x t.y\n\n Printf.printf !\"t = %{{string_of_t}}\" { x = 42; y = 42 }\n ]}\n *)\n | Custom :\n ('a, 'x, 'y) custom_arity * (unit -> 'x) * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('y, 'b, 'c, 'd, 'e, 'f) fmt\n\n (* end of a format specification *)\n | End_of_format :\n ('f, 'b, 'c, 'e, 'e, 'f) fmt\n\n(***)\n\n(* Type for ignored parameters (see \"%_\"). *)\nand ('a, 'b, 'c, 'd, 'e, 'f) ignored =\n | Ignored_char : (* %_c *)\n ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_caml_char : (* %_C *)\n ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_string : (* %_s *)\n pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_caml_string : (* %_S *)\n pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_int : (* %_d *)\n int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_int32 : (* %_ld *)\n int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_nativeint : (* %_nd *)\n int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_int64 : (* %_Ld *)\n int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_float : (* %_f *)\n pad_option * prec_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_bool : (* %_B *)\n pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_format_arg : (* %_{...%} *)\n pad_option * ('g, 'h, 'i, 'j, 'k, 'l) fmtty ->\n ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_format_subst : (* %_(...%) *)\n pad_option * ('a, 'b, 'c, 'd, 'e, 'f) fmtty ->\n ('a, 'b, 'c, 'd, 'e, 'f) ignored\n | Ignored_reader : (* %_r *)\n ('a, 'b, 'c, ('b -> 'x) -> 'd, 'd, 'a) ignored\n | Ignored_scan_char_set : (* %_[...] *)\n pad_option * char_set -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_scan_get_counter : (* %_[nlNL] *)\n counter -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_scan_next_char : (* %_0c *)\n ('a, 'b, 'c, 'd, 'd, 'a) ignored\n\nand ('a, 'b, 'c, 'd, 'e, 'f) format6 =\n Format of ('a, 'b, 'c, 'd, 'e, 'f) fmt * string\n\nlet rec erase_rel : type a b c d e f g h i j k l .\n (a, b, c, d, e, f,\n g, h, i, j, k, l) fmtty_rel -> (a, b, c, d, e, f) fmtty\n= function\n | Char_ty rest ->\n Char_ty (erase_rel rest)\n | String_ty rest ->\n String_ty (erase_rel rest)\n | Int_ty rest ->\n Int_ty (erase_rel rest)\n | Int32_ty rest ->\n Int32_ty (erase_rel rest)\n | Int64_ty rest ->\n Int64_ty (erase_rel rest)\n | Nativeint_ty rest ->\n Nativeint_ty (erase_rel rest)\n | Float_ty rest ->\n Float_ty (erase_rel rest)\n | Bool_ty rest ->\n Bool_ty (erase_rel rest)\n | Format_arg_ty (ty, rest) ->\n Format_arg_ty (ty, erase_rel rest)\n | Format_subst_ty (ty1, _ty2, rest) ->\n Format_subst_ty (ty1, ty1, erase_rel rest)\n | Alpha_ty rest ->\n Alpha_ty (erase_rel rest)\n | Theta_ty rest ->\n Theta_ty (erase_rel rest)\n | Any_ty rest ->\n Any_ty (erase_rel rest)\n | Reader_ty rest ->\n Reader_ty (erase_rel rest)\n | Ignored_reader_ty rest ->\n Ignored_reader_ty (erase_rel rest)\n | End_of_fmtty -> End_of_fmtty\n\n(******************************************************************************)\n (* Format type concatenation *)\n\n(* Concatenate two format types. *)\n(* Used by:\n * reader_nb_unifier_of_fmtty to count readers in an fmtty,\n * Scanf.take_fmtty_format_readers to extract readers inside %(...%),\n * CamlinternalFormat.fmtty_of_ignored_format to extract format type. *)\n\n(*\nlet rec concat_fmtty : type a b c d e f g h .\n (a, b, c, d, e, f) fmtty ->\n (f, b, c, e, g, h) fmtty ->\n (a, b, c, d, g, h) fmtty =\n*)\nlet rec concat_fmtty :\n type a1 b1 c1 d1 e1 f1\n a2 b2 c2 d2 e2 f2\n g1 j1 g2 j2\n .\n (g1, b1, c1, j1, d1, a1,\n g2, b2, c2, j2, d2, a2) fmtty_rel ->\n (a1, b1, c1, d1, e1, f1,\n a2, b2, c2, d2, e2, f2) fmtty_rel ->\n (g1, b1, c1, j1, e1, f1,\n g2, b2, c2, j2, e2, f2) fmtty_rel =\nfun fmtty1 fmtty2 -> match fmtty1 with\n | Char_ty rest ->\n Char_ty (concat_fmtty rest fmtty2)\n | String_ty rest ->\n String_ty (concat_fmtty rest fmtty2)\n | Int_ty rest ->\n Int_ty (concat_fmtty rest fmtty2)\n | Int32_ty rest ->\n Int32_ty (concat_fmtty rest fmtty2)\n | Nativeint_ty rest ->\n Nativeint_ty (concat_fmtty rest fmtty2)\n | Int64_ty rest ->\n Int64_ty (concat_fmtty rest fmtty2)\n | Float_ty rest ->\n Float_ty (concat_fmtty rest fmtty2)\n | Bool_ty rest ->\n Bool_ty (concat_fmtty rest fmtty2)\n | Alpha_ty rest ->\n Alpha_ty (concat_fmtty rest fmtty2)\n | Theta_ty rest ->\n Theta_ty (concat_fmtty rest fmtty2)\n | Any_ty rest ->\n Any_ty (concat_fmtty rest fmtty2)\n | Reader_ty rest ->\n Reader_ty (concat_fmtty rest fmtty2)\n | Ignored_reader_ty rest ->\n Ignored_reader_ty (concat_fmtty rest fmtty2)\n | Format_arg_ty (ty, rest) ->\n Format_arg_ty (ty, concat_fmtty rest fmtty2)\n | Format_subst_ty (ty1, ty2, rest) ->\n Format_subst_ty (ty1, ty2, concat_fmtty rest fmtty2)\n | End_of_fmtty -> fmtty2\n\n(******************************************************************************)\n (* Format concatenation *)\n\n(* Concatenate two formats. *)\nlet rec concat_fmt : type a b c d e f g h .\n (a, b, c, d, e, f) fmt ->\n (f, b, c, e, g, h) fmt ->\n (a, b, c, d, g, h) fmt =\nfun fmt1 fmt2 -> match fmt1 with\n | String (pad, rest) ->\n String (pad, concat_fmt rest fmt2)\n | Caml_string (pad, rest) ->\n Caml_string (pad, concat_fmt rest fmt2)\n\n | Int (iconv, pad, prec, rest) ->\n Int (iconv, pad, prec, concat_fmt rest fmt2)\n | Int32 (iconv, pad, prec, rest) ->\n Int32 (iconv, pad, prec, concat_fmt rest fmt2)\n | Nativeint (iconv, pad, prec, rest) ->\n Nativeint (iconv, pad, prec, concat_fmt rest fmt2)\n | Int64 (iconv, pad, prec, rest) ->\n Int64 (iconv, pad, prec, concat_fmt rest fmt2)\n | Float (fconv, pad, prec, rest) ->\n Float (fconv, pad, prec, concat_fmt rest fmt2)\n\n | Char (rest) ->\n Char (concat_fmt rest fmt2)\n | Caml_char rest ->\n Caml_char (concat_fmt rest fmt2)\n | Bool (pad, rest) ->\n Bool (pad, concat_fmt rest fmt2)\n | Alpha rest ->\n Alpha (concat_fmt rest fmt2)\n | Theta rest ->\n Theta (concat_fmt rest fmt2)\n | Custom (arity, f, rest) ->\n Custom (arity, f, concat_fmt rest fmt2)\n | Reader rest ->\n Reader (concat_fmt rest fmt2)\n | Flush rest ->\n Flush (concat_fmt rest fmt2)\n\n | String_literal (str, rest) ->\n String_literal (str, concat_fmt rest fmt2)\n | Char_literal (chr, rest) ->\n Char_literal (chr, concat_fmt rest fmt2)\n\n | Format_arg (pad, fmtty, rest) ->\n Format_arg (pad, fmtty, concat_fmt rest fmt2)\n | Format_subst (pad, fmtty, rest) ->\n Format_subst (pad, fmtty, concat_fmt rest fmt2)\n\n | Scan_char_set (width_opt, char_set, rest) ->\n Scan_char_set (width_opt, char_set, concat_fmt rest fmt2)\n | Scan_get_counter (counter, rest) ->\n Scan_get_counter (counter, concat_fmt rest fmt2)\n | Scan_next_char (rest) ->\n Scan_next_char (concat_fmt rest fmt2)\n | Ignored_param (ign, rest) ->\n Ignored_param (ign, concat_fmt rest fmt2)\n\n | Formatting_lit (fmting_lit, rest) ->\n Formatting_lit (fmting_lit, concat_fmt rest fmt2)\n | Formatting_gen (fmting_gen, rest) ->\n Formatting_gen (fmting_gen, concat_fmt rest fmt2)\n\n | End_of_format ->\n fmt2\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Gabriel Scherer, projet Partout, INRIA Paris-Saclay *)\n(* *)\n(* Copyright 2020 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* CamlinternalAtomic is a dependency of Stdlib, so it is compiled with\n -nopervasives. *)\nexternal ( == ) : 'a -> 'a -> bool = \"%eq\"\nexternal ( + ) : int -> int -> int = \"%addint\"\nexternal ignore : 'a -> unit = \"%ignore\"\n\n(* We are not reusing ('a ref) directly to make it easier to reason\n about atomicity if we wish to: even in a sequential implementation,\n signals and other asynchronous callbacks might break atomicity. *)\ntype 'a t = {mutable v: 'a}\n\nlet make v = {v}\nlet get r = r.v\nlet set r v = r.v <- v\n\n(* The following functions are set to never be inlined: Flambda is\n allowed to move surrounding code inside the critical section,\n including allocations. *)\n\nlet[@inline never] exchange r v =\n (* BEGIN ATOMIC *)\n let cur = r.v in\n r.v <- v;\n (* END ATOMIC *)\n cur\n\nlet[@inline never] compare_and_set r seen v =\n (* BEGIN ATOMIC *)\n let cur = r.v in\n if cur == seen then (\n r.v <- v;\n (* END ATOMIC *)\n true\n ) else\n false\n\nlet[@inline never] fetch_and_add r n =\n (* BEGIN ATOMIC *)\n let cur = r.v in\n r.v <- (cur + n);\n (* END ATOMIC *)\n cur\n\nlet incr r = ignore (fetch_and_add r 1)\nlet decr r = ignore (fetch_and_add r (-1))\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Exceptions *)\n\nexternal register_named_value : string -> 'a -> unit\n = \"caml_register_named_value\"\n\nlet () =\n (* for runtime/fail_nat.c *)\n register_named_value \"Pervasives.array_bound_error\"\n (Invalid_argument \"index out of bounds\")\n\nexternal raise : exn -> 'a = \"%raise\"\nexternal raise_notrace : exn -> 'a = \"%raise_notrace\"\n\nlet failwith s = raise(Failure s)\nlet invalid_arg s = raise(Invalid_argument s)\n\nexception Exit\nexception Match_failure = Match_failure\nexception Assert_failure = Assert_failure\nexception Invalid_argument = Invalid_argument\nexception Failure = Failure\nexception Not_found = Not_found\nexception Out_of_memory = Out_of_memory\nexception Stack_overflow = Stack_overflow\nexception Sys_error = Sys_error\nexception End_of_file = End_of_file\nexception Division_by_zero = Division_by_zero\nexception Sys_blocked_io = Sys_blocked_io\nexception Undefined_recursive_module = Undefined_recursive_module\n\n(* Composition operators *)\n\nexternal ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\nexternal ( @@ ) : ('a -> 'b) -> 'a -> 'b = \"%apply\"\n\n(* Debugging *)\n\nexternal __LOC__ : string = \"%loc_LOC\"\nexternal __FILE__ : string = \"%loc_FILE\"\nexternal __LINE__ : int = \"%loc_LINE\"\nexternal __MODULE__ : string = \"%loc_MODULE\"\nexternal __POS__ : string * int * int * int = \"%loc_POS\"\nexternal __FUNCTION__ : string = \"%loc_FUNCTION\"\n\nexternal __LOC_OF__ : 'a -> string * 'a = \"%loc_LOC\"\nexternal __LINE_OF__ : 'a -> int * 'a = \"%loc_LINE\"\nexternal __POS_OF__ : 'a -> (string * int * int * int) * 'a = \"%loc_POS\"\n\n(* Comparisons *)\n\nexternal ( = ) : 'a -> 'a -> bool = \"%equal\"\nexternal ( <> ) : 'a -> 'a -> bool = \"%notequal\"\nexternal ( < ) : 'a -> 'a -> bool = \"%lessthan\"\nexternal ( > ) : 'a -> 'a -> bool = \"%greaterthan\"\nexternal ( <= ) : 'a -> 'a -> bool = \"%lessequal\"\nexternal ( >= ) : 'a -> 'a -> bool = \"%greaterequal\"\nexternal compare : 'a -> 'a -> int = \"%compare\"\n\nlet min x y = if x <= y then x else y\nlet max x y = if x >= y then x else y\n\nexternal ( == ) : 'a -> 'a -> bool = \"%eq\"\nexternal ( != ) : 'a -> 'a -> bool = \"%noteq\"\n\n(* Boolean operations *)\n\nexternal not : bool -> bool = \"%boolnot\"\nexternal ( & ) : bool -> bool -> bool = \"%sequand\"\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\nexternal ( or ) : bool -> bool -> bool = \"%sequor\"\nexternal ( || ) : bool -> bool -> bool = \"%sequor\"\n\n(* Integer operations *)\n\nexternal ( ~- ) : int -> int = \"%negint\"\nexternal ( ~+ ) : int -> int = \"%identity\"\nexternal succ : int -> int = \"%succint\"\nexternal pred : int -> int = \"%predint\"\nexternal ( + ) : int -> int -> int = \"%addint\"\nexternal ( - ) : int -> int -> int = \"%subint\"\nexternal ( * ) : int -> int -> int = \"%mulint\"\nexternal ( / ) : int -> int -> int = \"%divint\"\nexternal ( mod ) : int -> int -> int = \"%modint\"\n\nlet abs x = if x >= 0 then x else -x\n\nexternal ( land ) : int -> int -> int = \"%andint\"\nexternal ( lor ) : int -> int -> int = \"%orint\"\nexternal ( lxor ) : int -> int -> int = \"%xorint\"\n\nlet lnot x = x lxor (-1)\n\nexternal ( lsl ) : int -> int -> int = \"%lslint\"\nexternal ( lsr ) : int -> int -> int = \"%lsrint\"\nexternal ( asr ) : int -> int -> int = \"%asrint\"\n\nlet max_int = (-1) lsr 1\nlet min_int = max_int + 1\n\n(* Floating-point operations *)\n\nexternal ( ~-. ) : float -> float = \"%negfloat\"\nexternal ( ~+. ) : float -> float = \"%identity\"\nexternal ( +. ) : float -> float -> float = \"%addfloat\"\nexternal ( -. ) : float -> float -> float = \"%subfloat\"\nexternal ( *. ) : float -> float -> float = \"%mulfloat\"\nexternal ( /. ) : float -> float -> float = \"%divfloat\"\nexternal ( ** ) : float -> float -> float = \"caml_power_float\" \"pow\"\n [@@unboxed] [@@noalloc]\nexternal exp : float -> float = \"caml_exp_float\" \"exp\" [@@unboxed] [@@noalloc]\nexternal expm1 : float -> float = \"caml_expm1_float\" \"caml_expm1\"\n [@@unboxed] [@@noalloc]\nexternal acos : float -> float = \"caml_acos_float\" \"acos\"\n [@@unboxed] [@@noalloc]\nexternal asin : float -> float = \"caml_asin_float\" \"asin\"\n [@@unboxed] [@@noalloc]\nexternal atan : float -> float = \"caml_atan_float\" \"atan\"\n [@@unboxed] [@@noalloc]\nexternal atan2 : float -> float -> float = \"caml_atan2_float\" \"atan2\"\n [@@unboxed] [@@noalloc]\nexternal hypot : float -> float -> float\n = \"caml_hypot_float\" \"caml_hypot\" [@@unboxed] [@@noalloc]\nexternal cos : float -> float = \"caml_cos_float\" \"cos\" [@@unboxed] [@@noalloc]\nexternal cosh : float -> float = \"caml_cosh_float\" \"cosh\"\n [@@unboxed] [@@noalloc]\nexternal acosh : float -> float = \"caml_acosh_float\" \"caml_acosh\"\n [@@unboxed] [@@noalloc]\nexternal log : float -> float = \"caml_log_float\" \"log\" [@@unboxed] [@@noalloc]\nexternal log10 : float -> float = \"caml_log10_float\" \"log10\"\n [@@unboxed] [@@noalloc]\nexternal log1p : float -> float = \"caml_log1p_float\" \"caml_log1p\"\n [@@unboxed] [@@noalloc]\nexternal sin : float -> float = \"caml_sin_float\" \"sin\" [@@unboxed] [@@noalloc]\nexternal sinh : float -> float = \"caml_sinh_float\" \"sinh\"\n [@@unboxed] [@@noalloc]\nexternal asinh : float -> float = \"caml_asinh_float\" \"caml_asinh\"\n [@@unboxed] [@@noalloc]\nexternal sqrt : float -> float = \"caml_sqrt_float\" \"sqrt\"\n [@@unboxed] [@@noalloc]\nexternal tan : float -> float = \"caml_tan_float\" \"tan\" [@@unboxed] [@@noalloc]\nexternal tanh : float -> float = \"caml_tanh_float\" \"tanh\"\n [@@unboxed] [@@noalloc]\nexternal atanh : float -> float = \"caml_atanh_float\" \"caml_atanh\"\n [@@unboxed] [@@noalloc]\nexternal ceil : float -> float = \"caml_ceil_float\" \"ceil\"\n [@@unboxed] [@@noalloc]\nexternal floor : float -> float = \"caml_floor_float\" \"floor\"\n [@@unboxed] [@@noalloc]\nexternal abs_float : float -> float = \"%absfloat\"\nexternal copysign : float -> float -> float\n = \"caml_copysign_float\" \"caml_copysign\"\n [@@unboxed] [@@noalloc]\nexternal mod_float : float -> float -> float = \"caml_fmod_float\" \"fmod\"\n [@@unboxed] [@@noalloc]\nexternal frexp : float -> float * int = \"caml_frexp_float\"\nexternal ldexp : (float [@unboxed]) -> (int [@untagged]) -> (float [@unboxed]) =\n \"caml_ldexp_float\" \"caml_ldexp_float_unboxed\" [@@noalloc]\nexternal modf : float -> float * float = \"caml_modf_float\"\nexternal float : int -> float = \"%floatofint\"\nexternal float_of_int : int -> float = \"%floatofint\"\nexternal truncate : float -> int = \"%intoffloat\"\nexternal int_of_float : float -> int = \"%intoffloat\"\nexternal float_of_bits : int64 -> float\n = \"caml_int64_float_of_bits\" \"caml_int64_float_of_bits_unboxed\"\n [@@unboxed] [@@noalloc]\nlet infinity =\n float_of_bits 0x7F_F0_00_00_00_00_00_00L\nlet neg_infinity =\n float_of_bits 0xFF_F0_00_00_00_00_00_00L\nlet nan =\n float_of_bits 0x7F_F0_00_00_00_00_00_01L\nlet max_float =\n float_of_bits 0x7F_EF_FF_FF_FF_FF_FF_FFL\nlet min_float =\n float_of_bits 0x00_10_00_00_00_00_00_00L\nlet epsilon_float =\n float_of_bits 0x3C_B0_00_00_00_00_00_00L\n\ntype fpclass =\n FP_normal\n | FP_subnormal\n | FP_zero\n | FP_infinite\n | FP_nan\nexternal classify_float : (float [@unboxed]) -> fpclass =\n \"caml_classify_float\" \"caml_classify_float_unboxed\" [@@noalloc]\n\n(* String and byte sequence operations -- more in modules String and Bytes *)\n\nexternal string_length : string -> int = \"%string_length\"\nexternal bytes_length : bytes -> int = \"%bytes_length\"\nexternal bytes_create : int -> bytes = \"caml_create_bytes\"\nexternal string_blit : string -> int -> bytes -> int -> int -> unit\n = \"caml_blit_string\" [@@noalloc]\nexternal bytes_blit : bytes -> int -> bytes -> int -> int -> unit\n = \"caml_blit_bytes\" [@@noalloc]\nexternal bytes_unsafe_to_string : bytes -> string = \"%bytes_to_string\"\n\nlet ( ^ ) s1 s2 =\n let l1 = string_length s1 and l2 = string_length s2 in\n let s = bytes_create (l1 + l2) in\n string_blit s1 0 s 0 l1;\n string_blit s2 0 s l1 l2;\n bytes_unsafe_to_string s\n\n(* Character operations -- more in module Char *)\n\nexternal int_of_char : char -> int = \"%identity\"\nexternal unsafe_char_of_int : int -> char = \"%identity\"\nlet char_of_int n =\n if n < 0 || n > 255 then invalid_arg \"char_of_int\" else unsafe_char_of_int n\n\n(* Unit operations *)\n\nexternal ignore : 'a -> unit = \"%ignore\"\n\n(* Pair operations *)\n\nexternal fst : 'a * 'b -> 'a = \"%field0\"\nexternal snd : 'a * 'b -> 'b = \"%field1\"\n\n(* References *)\n\ntype 'a ref = { mutable contents : 'a }\nexternal ref : 'a -> 'a ref = \"%makemutable\"\nexternal ( ! ) : 'a ref -> 'a = \"%field0\"\nexternal ( := ) : 'a ref -> 'a -> unit = \"%setfield0\"\nexternal incr : int ref -> unit = \"%incr\"\nexternal decr : int ref -> unit = \"%decr\"\n\n(* Result type *)\n\ntype ('a,'b) result = Ok of 'a | Error of 'b\n\n(* String conversion functions *)\n\nexternal format_int : string -> int -> string = \"caml_format_int\"\nexternal format_float : string -> float -> string = \"caml_format_float\"\n\nlet string_of_bool b =\n if b then \"true\" else \"false\"\nlet bool_of_string = function\n | \"true\" -> true\n | \"false\" -> false\n | _ -> invalid_arg \"bool_of_string\"\n\nlet bool_of_string_opt = function\n | \"true\" -> Some true\n | \"false\" -> Some false\n | _ -> None\n\nlet string_of_int n =\n format_int \"%d\" n\n\nexternal int_of_string : string -> int = \"caml_int_of_string\"\n\nlet int_of_string_opt s =\n (* TODO: provide this directly as a non-raising primitive. *)\n try Some (int_of_string s)\n with Failure _ -> None\n\nexternal string_get : string -> int -> char = \"%string_safe_get\"\n\nlet valid_float_lexem s =\n let l = string_length s in\n let rec loop i =\n if i >= l then s ^ \".\" else\n match string_get s i with\n | '0' .. '9' | '-' -> loop (i + 1)\n | _ -> s\n in\n loop 0\n\nlet string_of_float f = valid_float_lexem (format_float \"%.12g\" f)\n\nexternal float_of_string : string -> float = \"caml_float_of_string\"\n\nlet float_of_string_opt s =\n (* TODO: provide this directly as a non-raising primitive. *)\n try Some (float_of_string s)\n with Failure _ -> None\n\n(* List operations -- more in module List *)\n\nlet rec ( @ ) l1 l2 =\n match l1 with\n [] -> l2\n | hd :: tl -> hd :: (tl @ l2)\n\n(* I/O operations *)\n\ntype in_channel\ntype out_channel\n\nexternal open_descriptor_out : int -> out_channel\n = \"caml_ml_open_descriptor_out\"\nexternal open_descriptor_in : int -> in_channel = \"caml_ml_open_descriptor_in\"\n\nlet stdin = open_descriptor_in 0\nlet stdout = open_descriptor_out 1\nlet stderr = open_descriptor_out 2\n\n(* General output functions *)\n\ntype open_flag =\n Open_rdonly | Open_wronly | Open_append\n | Open_creat | Open_trunc | Open_excl\n | Open_binary | Open_text | Open_nonblock\n\nexternal open_desc : string -> open_flag list -> int -> int = \"caml_sys_open\"\n\nexternal set_out_channel_name: out_channel -> string -> unit =\n \"caml_ml_set_channel_name\"\n\nlet open_out_gen mode perm name =\n let c = open_descriptor_out(open_desc name mode perm) in\n set_out_channel_name c name;\n c\n\nlet open_out name =\n open_out_gen [Open_wronly; Open_creat; Open_trunc; Open_text] 0o666 name\n\nlet open_out_bin name =\n open_out_gen [Open_wronly; Open_creat; Open_trunc; Open_binary] 0o666 name\n\nexternal flush : out_channel -> unit = \"caml_ml_flush\"\n\nexternal out_channels_list : unit -> out_channel list\n = \"caml_ml_out_channels_list\"\n\nlet flush_all () =\n let rec iter = function\n [] -> ()\n | a::l ->\n begin try\n flush a\n with Sys_error _ ->\n () (* ignore channels closed during a preceding flush. *)\n end;\n iter l\n in iter (out_channels_list ())\n\nexternal unsafe_output : out_channel -> bytes -> int -> int -> unit\n = \"caml_ml_output_bytes\"\nexternal unsafe_output_string : out_channel -> string -> int -> int -> unit\n = \"caml_ml_output\"\n\nexternal output_char : out_channel -> char -> unit = \"caml_ml_output_char\"\n\nlet output_bytes oc s =\n unsafe_output oc s 0 (bytes_length s)\n\nlet output_string oc s =\n unsafe_output_string oc s 0 (string_length s)\n\nlet output oc s ofs len =\n if ofs < 0 || len < 0 || ofs > bytes_length s - len\n then invalid_arg \"output\"\n else unsafe_output oc s ofs len\n\nlet output_substring oc s ofs len =\n if ofs < 0 || len < 0 || ofs > string_length s - len\n then invalid_arg \"output_substring\"\n else unsafe_output_string oc s ofs len\n\nexternal output_byte : out_channel -> int -> unit = \"caml_ml_output_char\"\nexternal output_binary_int : out_channel -> int -> unit = \"caml_ml_output_int\"\n\nexternal marshal_to_channel : out_channel -> 'a -> unit list -> unit\n = \"caml_output_value\"\nlet output_value chan v = marshal_to_channel chan v []\n\nexternal seek_out : out_channel -> int -> unit = \"caml_ml_seek_out\"\nexternal pos_out : out_channel -> int = \"caml_ml_pos_out\"\nexternal out_channel_length : out_channel -> int = \"caml_ml_channel_size\"\nexternal close_out_channel : out_channel -> unit = \"caml_ml_close_channel\"\nlet close_out oc = flush oc; close_out_channel oc\nlet close_out_noerr oc =\n (try flush oc with _ -> ());\n (try close_out_channel oc with _ -> ())\nexternal set_binary_mode_out : out_channel -> bool -> unit\n = \"caml_ml_set_binary_mode\"\n\n(* General input functions *)\n\nexternal set_in_channel_name: in_channel -> string -> unit =\n \"caml_ml_set_channel_name\"\n\nlet open_in_gen mode perm name =\n let c = open_descriptor_in(open_desc name mode perm) in\n set_in_channel_name c name;\n c\n\nlet open_in name =\n open_in_gen [Open_rdonly; Open_text] 0 name\n\nlet open_in_bin name =\n open_in_gen [Open_rdonly; Open_binary] 0 name\n\nexternal input_char : in_channel -> char = \"caml_ml_input_char\"\n\nexternal unsafe_input : in_channel -> bytes -> int -> int -> int\n = \"caml_ml_input\"\n\nlet input ic s ofs len =\n if ofs < 0 || len < 0 || ofs > bytes_length s - len\n then invalid_arg \"input\"\n else unsafe_input ic s ofs len\n\nlet rec unsafe_really_input ic s ofs len =\n if len <= 0 then () else begin\n let r = unsafe_input ic s ofs len in\n if r = 0\n then raise End_of_file\n else unsafe_really_input ic s (ofs + r) (len - r)\n end\n\nlet really_input ic s ofs len =\n if ofs < 0 || len < 0 || ofs > bytes_length s - len\n then invalid_arg \"really_input\"\n else unsafe_really_input ic s ofs len\n\nlet really_input_string ic len =\n let s = bytes_create len in\n really_input ic s 0 len;\n bytes_unsafe_to_string s\n\nexternal input_scan_line : in_channel -> int = \"caml_ml_input_scan_line\"\n\nlet input_line chan =\n let rec build_result buf pos = function\n [] -> buf\n | hd :: tl ->\n let len = bytes_length hd in\n bytes_blit hd 0 buf (pos - len) len;\n build_result buf (pos - len) tl in\n let rec scan accu len =\n let n = input_scan_line chan in\n if n = 0 then begin (* n = 0: we are at EOF *)\n match accu with\n [] -> raise End_of_file\n | _ -> build_result (bytes_create len) len accu\n end else if n > 0 then begin (* n > 0: newline found in buffer *)\n let res = bytes_create (n - 1) in\n ignore (unsafe_input chan res 0 (n - 1));\n ignore (input_char chan); (* skip the newline *)\n match accu with\n [] -> res\n | _ -> let len = len + n - 1 in\n build_result (bytes_create len) len (res :: accu)\n end else begin (* n < 0: newline not found *)\n let beg = bytes_create (-n) in\n ignore(unsafe_input chan beg 0 (-n));\n scan (beg :: accu) (len - n)\n end\n in bytes_unsafe_to_string (scan [] 0)\n\nexternal input_byte : in_channel -> int = \"caml_ml_input_char\"\nexternal input_binary_int : in_channel -> int = \"caml_ml_input_int\"\nexternal input_value : in_channel -> 'a = \"caml_input_value\"\nexternal seek_in : in_channel -> int -> unit = \"caml_ml_seek_in\"\nexternal pos_in : in_channel -> int = \"caml_ml_pos_in\"\nexternal in_channel_length : in_channel -> int = \"caml_ml_channel_size\"\nexternal close_in : in_channel -> unit = \"caml_ml_close_channel\"\nlet close_in_noerr ic = (try close_in ic with _ -> ())\nexternal set_binary_mode_in : in_channel -> bool -> unit\n = \"caml_ml_set_binary_mode\"\n\n(* Output functions on standard output *)\n\nlet print_char c = output_char stdout c\nlet print_string s = output_string stdout s\nlet print_bytes s = output_bytes stdout s\nlet print_int i = output_string stdout (string_of_int i)\nlet print_float f = output_string stdout (string_of_float f)\nlet print_endline s =\n output_string stdout s; output_char stdout '\\n'; flush stdout\nlet print_newline () = output_char stdout '\\n'; flush stdout\n\n(* Output functions on standard error *)\n\nlet prerr_char c = output_char stderr c\nlet prerr_string s = output_string stderr s\nlet prerr_bytes s = output_bytes stderr s\nlet prerr_int i = output_string stderr (string_of_int i)\nlet prerr_float f = output_string stderr (string_of_float f)\nlet prerr_endline s =\n output_string stderr s; output_char stderr '\\n'; flush stderr\nlet prerr_newline () = output_char stderr '\\n'; flush stderr\n\n(* Input functions on standard input *)\n\nlet read_line () = flush stdout; input_line stdin\nlet read_int () = int_of_string(read_line())\nlet read_int_opt () = int_of_string_opt(read_line())\nlet read_float () = float_of_string(read_line())\nlet read_float_opt () = float_of_string_opt(read_line())\n\n(* Operations on large files *)\n\nmodule LargeFile =\n struct\n external seek_out : out_channel -> int64 -> unit = \"caml_ml_seek_out_64\"\n external pos_out : out_channel -> int64 = \"caml_ml_pos_out_64\"\n external out_channel_length : out_channel -> int64\n = \"caml_ml_channel_size_64\"\n external seek_in : in_channel -> int64 -> unit = \"caml_ml_seek_in_64\"\n external pos_in : in_channel -> int64 = \"caml_ml_pos_in_64\"\n external in_channel_length : in_channel -> int64 = \"caml_ml_channel_size_64\"\n end\n\n(* Formats *)\n\ntype ('a, 'b, 'c, 'd, 'e, 'f) format6\n = ('a, 'b, 'c, 'd, 'e, 'f) CamlinternalFormatBasics.format6\n = Format of ('a, 'b, 'c, 'd, 'e, 'f) CamlinternalFormatBasics.fmt\n * string\n\ntype ('a, 'b, 'c, 'd) format4 = ('a, 'b, 'c, 'c, 'c, 'd) format6\n\ntype ('a, 'b, 'c) format = ('a, 'b, 'c, 'c) format4\n\nlet string_of_format (Format (_fmt, str)) = str\n\nexternal format_of_string :\n ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n ('a, 'b, 'c, 'd, 'e, 'f) format6 = \"%identity\"\n\nlet ( ^^ ) (Format (fmt1, str1)) (Format (fmt2, str2)) =\n Format (CamlinternalFormatBasics.concat_fmt fmt1 fmt2,\n str1 ^ \"%,\" ^ str2)\n\n(* Miscellaneous *)\n\nexternal sys_exit : int -> 'a = \"caml_sys_exit\"\n\nlet exit_function = CamlinternalAtomic.make flush_all\n\nlet rec at_exit f =\n let module Atomic = CamlinternalAtomic in\n (* MPR#7253, MPR#7796: make sure \"f\" is executed only once *)\n let f_yet_to_run = Atomic.make true in\n let old_exit = Atomic.get exit_function in\n let new_exit () =\n if Atomic.compare_and_set f_yet_to_run true false then f () ;\n old_exit ()\n in\n let success = Atomic.compare_and_set exit_function old_exit new_exit in\n if not success then at_exit f\n\nlet do_at_exit () = (CamlinternalAtomic.get exit_function) ()\n\nlet exit retcode =\n do_at_exit ();\n sys_exit retcode\n\nlet _ = register_named_value \"Pervasives.do_at_exit\" do_at_exit\n\nexternal major : unit -> unit = \"caml_gc_major\"\nexternal naked_pointers_checked : unit -> bool\n = \"caml_sys_const_naked_pointers_checked\"\nlet () = if naked_pointers_checked () then at_exit major\n\n(*MODULE_ALIASES*)\nmodule Arg = Arg\nmodule Array = Array\nmodule ArrayLabels = ArrayLabels\nmodule Atomic = Atomic\nmodule Bigarray = Bigarray\nmodule Bool = Bool\nmodule Buffer = Buffer\nmodule Bytes = Bytes\nmodule BytesLabels = BytesLabels\nmodule Callback = Callback\nmodule Char = Char\nmodule Complex = Complex\nmodule Digest = Digest\nmodule Either = Either\nmodule Ephemeron = Ephemeron\nmodule Filename = Filename\nmodule Float = Float\nmodule Format = Format\nmodule Fun = Fun\nmodule Gc = Gc\nmodule Genlex = Genlex\nmodule Hashtbl = Hashtbl\nmodule In_channel = In_channel\nmodule Int = Int\nmodule Int32 = Int32\nmodule Int64 = Int64\nmodule Lazy = Lazy\nmodule Lexing = Lexing\nmodule List = List\nmodule ListLabels = ListLabels\nmodule Map = Map\nmodule Marshal = Marshal\nmodule MoreLabels = MoreLabels\nmodule Nativeint = Nativeint\nmodule Obj = Obj\nmodule Oo = Oo\nmodule Option = Option\nmodule Out_channel = Out_channel\nmodule Parsing = Parsing\nmodule Pervasives = Pervasives\nmodule Printexc = Printexc\nmodule Printf = Printf\nmodule Queue = Queue\nmodule Random = Random\nmodule Result = Result\nmodule Scanf = Scanf\nmodule Seq = Seq\nmodule Set = Set\nmodule Stack = Stack\nmodule StdLabels = StdLabels\nmodule Stream = Stream\nmodule String = String\nmodule StringLabels = StringLabels\nmodule Sys = Sys\nmodule Uchar = Uchar\nmodule Unit = Unit\nmodule Weak = Weak\n","(** This module is the toplevel of the Base library; it's what you get when you write\n [open Base].\n\n\n The goal of Base is both to be a more complete standard library, with richer APIs,\n and to be more consistent in its design. For instance, in the standard library\n some things have modules and others don't; in Base, everything is a module.\n\n Base extends some modules and data structures from the standard library, like [Array],\n [Buffer], [Bytes], [Char], [Hashtbl], [Int32], [Int64], [Lazy], [List], [Map],\n [Nativeint], [Printf], [Random], [Set], [String], [Sys], and [Uchar]. One key\n difference is that Base doesn't use exceptions as much as the standard library and\n instead makes heavy use of the [Result] type, as in:\n\n {[ type ('a,'b) result = Ok of 'a | Error of 'b ]}\n\n Base also adds entirely new modules, most notably:\n\n - [Comparable], [Comparator], and [Comparisons] in lieu of polymorphic compare.\n - [Container], which provides a consistent interface across container-like data\n structures (arrays, lists, strings).\n - [Result], [Error], and [Or_error], supporting the or-error pattern.\n\n The recommended way to use Base is to build with [-open Base]. Files compiled this\n way will have the environment described in this file as their initial environment.\n*)\n\n(*_ We hide this from the web docs because the line wrapping is bad, making it\n pretty much inscrutable. *)\n(**/**)\n\n(* The intent is to shadow all of INRIA's standard library. Modules below would cause\n compilation errors without being removed from [Shadow_stdlib] before inclusion. *)\n\ninclude (\n Shadow_stdlib :\n module type of struct\n include Shadow_stdlib\n end\n (* Modules defined in Base *)\n with module Array := Shadow_stdlib.Array\n with module Atomic := Shadow_stdlib.Atomic\n with module Bool := Shadow_stdlib.Bool\n with module Buffer := Shadow_stdlib.Buffer\n with module Bytes := Shadow_stdlib.Bytes\n with module Char := Shadow_stdlib.Char\n with module Either := Shadow_stdlib.Either\n with module Float := Shadow_stdlib.Float\n with module Hashtbl := Shadow_stdlib.Hashtbl\n with module In_channel := Shadow_stdlib.In_channel\n with module Int := Shadow_stdlib.Int\n with module Int32 := Shadow_stdlib.Int32\n with module Int64 := Shadow_stdlib.Int64\n with module Lazy := Shadow_stdlib.Lazy\n with module List := Shadow_stdlib.List\n with module Map := Shadow_stdlib.Map\n with module Nativeint := Shadow_stdlib.Nativeint\n with module Option := Shadow_stdlib.Option\n with module Out_channel := Shadow_stdlib.Out_channel\n with module Printf := Shadow_stdlib.Printf\n with module Queue := Shadow_stdlib.Queue\n with module Random := Shadow_stdlib.Random\n with module Result := Shadow_stdlib.Result\n with module Set := Shadow_stdlib.Set\n with module Stack := Shadow_stdlib.Stack\n with module String := Shadow_stdlib.String\n with module Sys := Shadow_stdlib.Sys\n with module Uchar := Shadow_stdlib.Uchar\n with module Unit := Shadow_stdlib.Unit\n (* Support for generated lexers *)\n with module Lexing := Shadow_stdlib.Lexing\n with type ('a, 'b, 'c) format := ('a, 'b, 'c) format\n with type ('a, 'b, 'c, 'd) format4 := ('a, 'b, 'c, 'd) format4\n with type ('a, 'b, 'c, 'd, 'e, 'f) format6 := ('a, 'b, 'c, 'd, 'e, 'f) format6\n with type 'a ref := 'a ref) [@ocaml.warning \"-3\"]\n\n(**/**)\n\nopen! Import\nmodule Applicative = Applicative\nmodule Array = Array\nmodule Avltree = Avltree\nmodule Backtrace = Backtrace\nmodule Binary_search = Binary_search\nmodule Binary_searchable = Binary_searchable\nmodule Blit = Blit\nmodule Bool = Bool\nmodule Buffer = Buffer\nmodule Bytes = Bytes\nmodule Char = Char\nmodule Comparable = Comparable\nmodule Comparator = Comparator\nmodule Comparisons = Comparisons\nmodule Container = Container\nmodule Either = Either\nmodule Equal = Equal\nmodule Error = Error\nmodule Exn = Exn\nmodule Field = Field\nmodule Float = Float\nmodule Floatable = Floatable\nmodule Fn = Fn\nmodule Formatter = Formatter\nmodule Hash = Hash\nmodule Hash_set = Hash_set\nmodule Hashable = Hashable\nmodule Hasher = Hasher\nmodule Hashtbl = Hashtbl\nmodule Identifiable = Identifiable\nmodule Indexed_container = Indexed_container\nmodule Info = Info\nmodule Int = Int\nmodule Int_conversions = Int_conversions\nmodule Int32 = Int32\nmodule Int63 = Int63\nmodule Int64 = Int64\nmodule Intable = Intable\nmodule Int_math = Int_math\nmodule Invariant = Invariant\nmodule Lazy = Lazy\nmodule List = List\nmodule Map = Map\nmodule Maybe_bound = Maybe_bound\nmodule Monad = Monad\nmodule Nativeint = Nativeint\nmodule Nothing = Nothing\nmodule Option = Option\nmodule Option_array = Option_array\nmodule Or_error = Or_error\nmodule Ordered_collection_common = Ordered_collection_common\nmodule Ordering = Ordering\nmodule Poly = Poly\nmodule Polymorphic_compare = Poly [@@deprecated \"[since 2018-11] use [Poly] instead\"]\n\nmodule Popcount = Popcount\n[@@deprecated \"[since 2018-10] use [popcount] functions in the individual int modules\"]\n\nmodule Pretty_printer = Pretty_printer\nmodule Printf = Printf\nmodule Linked_queue = Linked_queue\nmodule Queue = Queue\nmodule Random = Random\nmodule Ref = Ref\nmodule Result = Result\nmodule Sequence = Sequence\nmodule Set = Set\nmodule Sexpable = Sexpable\nmodule Sign = Sign\nmodule Sign_or_nan = Sign_or_nan\nmodule Source_code_position = Source_code_position\nmodule Stack = Stack\nmodule Staged = Staged\nmodule String = String\nmodule Stringable = Stringable\nmodule Sys = Sys\nmodule T = T\nmodule Type_equal = Type_equal\nmodule Uniform_array = Uniform_array\nmodule Unit = Unit\nmodule Uchar = Uchar\nmodule Validate = Validate\nmodule Variant = Variant\nmodule With_return = With_return\nmodule Word_size = Word_size\n\n(* Avoid a level of indirection for uses of the signatures defined in [T]. *)\ninclude T\n\n(* This is a hack so that odoc creates better documentation. *)\nmodule Sexp = struct\n include Sexp_with_comparable (** @inline *)\nend\n\n(**/**)\n\nmodule Exported_for_specific_uses = struct\n module Fieldslib = Fieldslib\n module Ppx_hash_lib = Ppx_hash_lib\n module Sexplib = Sexplib\n module Variantslib = Variantslib\n module Ppx_compare_lib = Ppx_compare_lib\n module Ppx_sexp_conv_lib = Ppx_sexp_conv_lib\n\n let am_testing = am_testing\nend\n\n(**/**)\n\nmodule Export = struct\n include Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.Builtin\n\n (* [deriving hash] is missing for [array] and [ref] since these types are mutable. *)\n type 'a array = 'a Array.t [@@deriving_inline compare, equal, sexp, sexp_grammar]\n\n let compare_array : 'a. ('a -> 'a -> int) -> 'a array -> 'a array -> int =\n Array.compare\n ;;\n\n let equal_array : 'a. ('a -> 'a -> bool) -> 'a array -> 'a array -> bool = Array.equal\n\n let array_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a array\n =\n Array.t_of_sexp\n ;;\n\n let sexp_of_array :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a array -> Ppx_sexp_conv_lib.Sexp.t\n =\n Array.sexp_of_t\n ;;\n\n let (array_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Array.t\" ]\n ; ggid = \"r\\177A\\255~\\129%\\178\\226\\196g\\165\\t\\232\\204\\001\"\n ; types =\n [ \"array\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ])) ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Array.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (array_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"array\", _the_group)\n in\n array_sexp_grammar\n ;;\n\n [@@@end]\n\n type bool = Bool.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_bool = (Bool.compare : bool -> bool -> int)\n let equal_bool = (Bool.equal : bool -> bool -> bool)\n\n let (hash_fold_bool :\n Ppx_hash_lib.Std.Hash.state -> bool -> Ppx_hash_lib.Std.Hash.state)\n =\n Bool.hash_fold_t\n\n and (hash_bool : bool -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Bool.hash in\n fun x -> func x\n ;;\n\n let bool_of_sexp = (Bool.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> bool)\n let sexp_of_bool = (Bool.sexp_of_t : bool -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (bool_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Bool.t\" ]\n ; ggid = \"{\\171\\239\\166\\219\\128\\005\\201\\192$\\149\\202\\251?\\186\\164\"\n ; types = [ \"bool\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Bool.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (bool_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"bool\", _the_group)\n in\n bool_sexp_grammar\n ;;\n\n [@@@end]\n\n type char = Char.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_char = (Char.compare : char -> char -> int)\n let equal_char = (Char.equal : char -> char -> bool)\n\n let (hash_fold_char :\n Ppx_hash_lib.Std.Hash.state -> char -> Ppx_hash_lib.Std.Hash.state)\n =\n Char.hash_fold_t\n\n and (hash_char : char -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Char.hash in\n fun x -> func x\n ;;\n\n let char_of_sexp = (Char.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> char)\n let sexp_of_char = (Char.sexp_of_t : char -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (char_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Char.t\" ]\n ; ggid = \"H\\140\\243\\204Y\\222\\191d\\000@\\024Md\\028\\147>\"\n ; types = [ \"char\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Char.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (char_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"char\", _the_group)\n in\n char_sexp_grammar\n ;;\n\n [@@@end]\n\n type exn = Exn.t [@@deriving_inline sexp_of]\n\n let sexp_of_exn = (Exn.sexp_of_t : exn -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n\n type float = Float.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_float = (Float.compare : float -> float -> int)\n let equal_float = (Float.equal : float -> float -> bool)\n\n let (hash_fold_float :\n Ppx_hash_lib.Std.Hash.state -> float -> Ppx_hash_lib.Std.Hash.state)\n =\n Float.hash_fold_t\n\n and (hash_float : float -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Float.hash in\n fun x -> func x\n ;;\n\n let float_of_sexp = (Float.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> float)\n let sexp_of_float = (Float.sexp_of_t : float -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (float_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Float.t\" ]\n ; ggid = \"\\190E\\020\\242\\249\\135C\\240+\\214\\226\\143Ip\\217\\223\"\n ; types = [ \"float\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Float.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (float_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"float\", _the_group)\n in\n float_sexp_grammar\n ;;\n\n [@@@end]\n\n type int = Int.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_int = (Int.compare : int -> int -> int)\n let equal_int = (Int.equal : int -> int -> bool)\n\n let (hash_fold_int : Ppx_hash_lib.Std.Hash.state -> int -> Ppx_hash_lib.Std.Hash.state)\n =\n Int.hash_fold_t\n\n and (hash_int : int -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Int.hash in\n fun x -> func x\n ;;\n\n let int_of_sexp = (Int.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> int)\n let sexp_of_int = (Int.sexp_of_t : int -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (int_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Int.t\" ]\n ; ggid = \"\\159\\159\\197^\\165]\\236\\165\\229\\165R8\\169\\225H\\020\"\n ; types = [ \"int\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Int.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (int_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"int\", _the_group)\n in\n int_sexp_grammar\n ;;\n\n [@@@end]\n\n type int32 = Int32.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_int32 = (Int32.compare : int32 -> int32 -> int)\n let equal_int32 = (Int32.equal : int32 -> int32 -> bool)\n\n let (hash_fold_int32 :\n Ppx_hash_lib.Std.Hash.state -> int32 -> Ppx_hash_lib.Std.Hash.state)\n =\n Int32.hash_fold_t\n\n and (hash_int32 : int32 -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Int32.hash in\n fun x -> func x\n ;;\n\n let int32_of_sexp = (Int32.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> int32)\n let sexp_of_int32 = (Int32.sexp_of_t : int32 -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (int32_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Int32.t\" ]\n ; ggid = \"9\\153\\000*L5O+l\\018\\179b\\198\\248\\026\\177\"\n ; types = [ \"int32\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Int32.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (int32_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"int32\", _the_group)\n in\n int32_sexp_grammar\n ;;\n\n [@@@end]\n\n type int64 = Int64.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_int64 = (Int64.compare : int64 -> int64 -> int)\n let equal_int64 = (Int64.equal : int64 -> int64 -> bool)\n\n let (hash_fold_int64 :\n Ppx_hash_lib.Std.Hash.state -> int64 -> Ppx_hash_lib.Std.Hash.state)\n =\n Int64.hash_fold_t\n\n and (hash_int64 : int64 -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Int64.hash in\n fun x -> func x\n ;;\n\n let int64_of_sexp = (Int64.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> int64)\n let sexp_of_int64 = (Int64.sexp_of_t : int64 -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (int64_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Int64.t\" ]\n ; ggid = \"r\\153\\022\\135\\131L\\155\\236\\235CKa\\197o\\248^\"\n ; types = [ \"int64\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Int64.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (int64_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"int64\", _the_group)\n in\n int64_sexp_grammar\n ;;\n\n [@@@end]\n\n type 'a list = 'a List.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_list : 'a. ('a -> 'a -> int) -> 'a list -> 'a list -> int = List.compare\n let equal_list : 'a. ('a -> 'a -> bool) -> 'a list -> 'a list -> bool = List.equal\n\n let hash_fold_list :\n 'a. (Ppx_hash_lib.Std.Hash.state -> 'a -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state -> 'a list -> Ppx_hash_lib.Std.Hash.state\n =\n List.hash_fold_t\n ;;\n\n let list_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a list\n =\n List.t_of_sexp\n ;;\n\n let sexp_of_list :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a list -> Ppx_sexp_conv_lib.Sexp.t\n =\n List.sexp_of_t\n ;;\n\n let (list_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"List.t\" ]\n ; ggid = \"\\144\\022 nativeint -> int)\n let equal_nativeint = (Nativeint.equal : nativeint -> nativeint -> bool)\n\n let (hash_fold_nativeint :\n Ppx_hash_lib.Std.Hash.state -> nativeint -> Ppx_hash_lib.Std.Hash.state)\n =\n Nativeint.hash_fold_t\n\n and (hash_nativeint : nativeint -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Nativeint.hash in\n fun x -> func x\n ;;\n\n let nativeint_of_sexp = (Nativeint.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> nativeint)\n let sexp_of_nativeint = (Nativeint.sexp_of_t : nativeint -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (nativeint_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Nativeint.t\" ]\n ; ggid = \"\\019\\184AE\\023\\\\->1fcm\\002\\254\\196\\129\"\n ; types = [ \"nativeint\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Nativeint.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (nativeint_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"nativeint\", _the_group)\n in\n nativeint_sexp_grammar\n ;;\n\n [@@@end]\n\n type 'a option = 'a Option.t\n [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_option : 'a. ('a -> 'a -> int) -> 'a option -> 'a option -> int =\n Option.compare\n ;;\n\n let equal_option : 'a. ('a -> 'a -> bool) -> 'a option -> 'a option -> bool =\n Option.equal\n ;;\n\n let hash_fold_option :\n 'a. (Ppx_hash_lib.Std.Hash.state -> 'a -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state -> 'a option -> Ppx_hash_lib.Std.Hash.state\n =\n Option.hash_fold_t\n ;;\n\n let option_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a option\n =\n Option.t_of_sexp\n ;;\n\n let sexp_of_option :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a option -> Ppx_sexp_conv_lib.Sexp.t\n =\n Option.sexp_of_t\n ;;\n\n let (option_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Option.t\" ]\n ; ggid = \"\\242@\\255j`*d\\203\\161\\182\\021\\175\\236\\146x\\217\"\n ; types =\n [ \"option\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ]))\n ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Option.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (option_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"option\", _the_group)\n in\n option_sexp_grammar\n ;;\n\n [@@@end]\n\n type 'a ref = 'a Ref.t [@@deriving_inline compare, equal, sexp, sexp_grammar]\n\n let compare_ref : 'a. ('a -> 'a -> int) -> 'a ref -> 'a ref -> int = Ref.compare\n let equal_ref : 'a. ('a -> 'a -> bool) -> 'a ref -> 'a ref -> bool = Ref.equal\n\n let ref_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a ref\n =\n Ref.t_of_sexp\n ;;\n\n let sexp_of_ref :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a ref -> Ppx_sexp_conv_lib.Sexp.t\n =\n Ref.sexp_of_t\n ;;\n\n let (ref_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Ref.t\" ]\n ; ggid = \"\\185\\246\\012[\\001\\197\\230\\192y=\\b\\199\\141\\248\\020\\012\"\n ; types =\n [ \"ref\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ])) ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Ref.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (ref_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"ref\", _the_group)\n in\n ref_sexp_grammar\n ;;\n\n [@@@end]\n\n type string = String.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_string = (String.compare : string -> string -> int)\n let equal_string = (String.equal : string -> string -> bool)\n\n let (hash_fold_string :\n Ppx_hash_lib.Std.Hash.state -> string -> Ppx_hash_lib.Std.Hash.state)\n =\n String.hash_fold_t\n\n and (hash_string : string -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = String.hash in\n fun x -> func x\n ;;\n\n let string_of_sexp = (String.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> string)\n let sexp_of_string = (String.sexp_of_t : string -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (string_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"String.t\" ]\n ; ggid = \"\\141\\195]\\143\\139/M\\t\\159\\t\\152\\214g\\198\\023\\176\"\n ; types = [ \"string\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ String.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (string_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"string\", _the_group)\n in\n string_sexp_grammar\n ;;\n\n [@@@end]\n\n type bytes = Bytes.t [@@deriving_inline compare, equal, sexp, sexp_grammar]\n\n let compare_bytes = (Bytes.compare : bytes -> bytes -> int)\n let equal_bytes = (Bytes.equal : bytes -> bytes -> bool)\n let bytes_of_sexp = (Bytes.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> bytes)\n let sexp_of_bytes = (Bytes.sexp_of_t : bytes -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (bytes_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Bytes.t\" ]\n ; ggid = \"\\015\\153L1\\012\\241\\015\\252\\150\\000\\191\\127Jb#3\"\n ; types = [ \"bytes\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Bytes.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (bytes_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"bytes\", _the_group)\n in\n bytes_sexp_grammar\n ;;\n\n [@@@end]\n\n type unit = Unit.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_unit = (Unit.compare : unit -> unit -> int)\n let equal_unit = (Unit.equal : unit -> unit -> bool)\n\n let (hash_fold_unit :\n Ppx_hash_lib.Std.Hash.state -> unit -> Ppx_hash_lib.Std.Hash.state)\n =\n Unit.hash_fold_t\n\n and (hash_unit : unit -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Unit.hash in\n fun x -> func x\n ;;\n\n let unit_of_sexp = (Unit.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> unit)\n let sexp_of_unit = (Unit.sexp_of_t : unit -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (unit_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Unit.t\" ]\n ; ggid = \"=\\005 \\134\\187\\\"64\\197S\\19256,\\031l\"\n ; types = [ \"unit\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Unit.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (unit_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"unit\", _the_group)\n in\n unit_sexp_grammar\n ;;\n\n [@@@end]\n\n (** Format stuff *)\n\n type nonrec ('a, 'b, 'c) format = ('a, 'b, 'c) format\n type nonrec ('a, 'b, 'c, 'd) format4 = ('a, 'b, 'c, 'd) format4\n type nonrec ('a, 'b, 'c, 'd, 'e, 'f) format6 = ('a, 'b, 'c, 'd, 'e, 'f) format6\n\n (** {2 Sexp}\n\n Exporting the ad-hoc types that are recognized by [ppx_sexp_*] converters.\n [sexp_array], [sexp_list], and [sexp_option] allow a record field to be absent when\n converting from a sexp, and if absent, the field will take a default value of the\n appropriate type:\n\n {v\n sexp_array [||]\n sexp_bool false\n sexp_list []\n sexp_option None\n v}\n\n [sexp_opaque] causes the conversion to sexp to produce the atom [].\n\n For more documentation, see sexplib/README.md. *)\n\n type 'a sexp_array = 'a array\n [@@deprecated \"[since 2019-03] use [@sexp.array] instead\"]\n\n type 'a sexp_list = 'a list [@@deprecated \"[since 2019-03] use [@sexp.list] instead\"]\n type 'a sexp_opaque = 'a [@@deprecated \"[since 2019-03] use [@sexp.opaque] instead\"]\n\n type 'a sexp_option = 'a option\n [@@deprecated \"[since 2019-03] use [@sexp.option] instead\"]\n\n (** List operators *)\n\n include List.Infix\n\n (** Int operators and comparisons *)\n\n include Int.O\n include Int_replace_polymorphic_compare\n\n (** Float operators *)\n\n include Float.O_dot\n\n (* This is declared as an external to be optimized away in more contexts. *)\n\n (** Reverse application operator. [x |> g |> f] is equivalent to [f (g (x))]. *)\n external ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\n\n (** Application operator. [g @@ f @@ x] is equivalent to [g (f (x))]. *)\n external ( @@ ) : ('a -> 'b) -> 'a -> 'b = \"%apply\"\n\n (** Boolean operations *)\n\n (* These need to be declared as an external to get the lazy behavior *)\n external ( && ) : bool -> bool -> bool = \"%sequand\"\n external ( || ) : bool -> bool -> bool = \"%sequor\"\n external not : bool -> bool = \"%boolnot\"\n\n (* This must be declared as an external for the warnings to work properly. *)\n external ignore : _ -> unit = \"%ignore\"\n\n (** Common string operations *)\n let ( ^ ) = String.( ^ )\n\n (** Reference operations *)\n\n (* Declared as an externals so that the compiler skips the caml_modify when possible and\n to keep reference unboxing working *)\n external ( ! ) : 'a ref -> 'a = \"%field0\"\n external ref : 'a -> 'a ref = \"%makemutable\"\n external ( := ) : 'a ref -> 'a -> unit = \"%setfield0\"\n\n (** Pair operations *)\n\n let fst = fst\n let snd = snd\n\n (** Exceptions stuff *)\n\n (* Declared as an external so that the compiler may rewrite '%raise' as '%reraise'. *)\n external raise : exn -> _ = \"%raise\"\n\n let failwith = failwith\n let invalid_arg = invalid_arg\n let raise_s = Error.raise_s\n\n (** Misc *)\n\n let phys_equal = phys_equal\n\n external force : 'a Lazy.t -> 'a = \"%lazy_force\"\nend\n\ninclude Export\n\ninclude Container_intf.Export (** @inline *)\n\nexception Not_found_s = Not_found_s\n\n(* We perform these side effects here because we want them to run for any code that uses\n [Base]. If this were in another module in [Base] that was not used in some program,\n then the side effects might not be run in that program. This will run as long as the\n program refers to at least one value directly in [Base]; referring to values in\n [Base.Bool], for example, is not sufficient. *)\nlet () = Backtrace.initialize_module ()\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(** The OCaml Standard library.\n\n This module is automatically opened at the beginning of each\n compilation. All components of this module can therefore be\n referred by their short name, without prefixing them by [Stdlib].\n\n It particular, it provides the basic operations over the built-in\n types (numbers, booleans, byte sequences, strings, exceptions,\n references, lists, arrays, input-output channels, ...) and the\n {{!modules}standard library modules}.\n*)\n\n(** {1 Exceptions} *)\n\nexternal raise : exn -> 'a = \"%raise\"\n(** Raise the given exception value *)\n\nexternal raise_notrace : exn -> 'a = \"%raise_notrace\"\n(** A faster version [raise] which does not record the backtrace.\n @since 4.02.0\n*)\n\nval invalid_arg : string -> 'a\n(** Raise exception [Invalid_argument] with the given string. *)\n\nval failwith : string -> 'a\n(** Raise exception [Failure] with the given string. *)\n\nexception Exit\n(** The [Exit] exception is not raised by any library function. It is\n provided for use in your programs. *)\n\nexception Match_failure of (string * int * int)\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised when none of the cases of a pattern-matching\n apply. The arguments are the location of the match keyword in the\n source code (file name, line number, column number). *)\n\nexception Assert_failure of (string * int * int)\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised when an assertion fails. The arguments are the\n location of the assert keyword in the source code (file name, line\n number, column number). *)\n\nexception Invalid_argument of string\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised by library functions to signal that the given\n arguments do not make sense. The string gives some information to\n the programmer. As a general rule, this exception should not be\n caught, it denotes a programming error and the code should be\n modified not to trigger it. *)\n\nexception Failure of string\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised by library functions to signal that they are\n undefined on the given arguments. The string is meant to give some\n information to the programmer; you must not pattern match on the\n string literal because it may change in future versions (use\n Failure _ instead). *)\n\nexception Not_found\n(** Exception raised by search functions when the desired object could\n not be found. *)\n\nexception Out_of_memory\n(** Exception raised by the garbage collector when there is\n insufficient memory to complete the computation. (Not reliable for\n allocations on the minor heap.) *)\n\nexception Stack_overflow\n(** Exception raised by the bytecode interpreter when the evaluation\n stack reaches its maximal size. This often indicates infinite or\n excessively deep recursion in the user's program.\n\n Before 4.10, it was not fully implemented by the native-code\n compiler. *)\n\nexception Sys_error of string\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised by the input/output functions to report an\n operating system error. The string is meant to give some\n information to the programmer; you must not pattern match on the\n string literal because it may change in future versions (use\n Sys_error _ instead). *)\n\nexception End_of_file\n(** Exception raised by input functions to signal that the end of file\n has been reached. *)\n\nexception Division_by_zero\n(** Exception raised by integer division and remainder operations when\n their second argument is zero. *)\n\nexception Sys_blocked_io\n(** A special case of Sys_error raised when no I/O is possible on a\n non-blocking I/O channel. *)\n\nexception Undefined_recursive_module of (string * int * int)\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised when an ill-founded recursive module definition\n is evaluated. The arguments are the location of the definition in\n the source code (file name, line number, column number). *)\n\n(** {1 Comparisons} *)\n\nexternal ( = ) : 'a -> 'a -> bool = \"%equal\"\n(** [e1 = e2] tests for structural equality of [e1] and [e2].\n Mutable structures (e.g. references and arrays) are equal\n if and only if their current contents are structurally equal,\n even if the two mutable objects are not the same physical object.\n Equality between functional values raises [Invalid_argument].\n Equality between cyclic data structures may not terminate.\n Left-associative operator, see {!Ocaml_operators} for more information. *)\n\nexternal ( <> ) : 'a -> 'a -> bool = \"%notequal\"\n(** Negation of {!Stdlib.( = )}.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( < ) : 'a -> 'a -> bool = \"%lessthan\"\n(** See {!Stdlib.( >= )}.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( > ) : 'a -> 'a -> bool = \"%greaterthan\"\n(** See {!Stdlib.( >= )}.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( <= ) : 'a -> 'a -> bool = \"%lessequal\"\n(** See {!Stdlib.( >= )}.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( >= ) : 'a -> 'a -> bool = \"%greaterequal\"\n(** Structural ordering functions. These functions coincide with\n the usual orderings over integers, characters, strings, byte sequences\n and floating-point numbers, and extend them to a\n total ordering over all types.\n The ordering is compatible with [( = )]. As in the case\n of [( = )], mutable structures are compared by contents.\n Comparison between functional values raises [Invalid_argument].\n Comparison between cyclic structures may not terminate.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal compare : 'a -> 'a -> int = \"%compare\"\n(** [compare x y] returns [0] if [x] is equal to [y],\n a negative integer if [x] is less than [y], and a positive integer\n if [x] is greater than [y]. The ordering implemented by [compare]\n is compatible with the comparison predicates [=], [<] and [>]\n defined above, with one difference on the treatment of the float value\n {!Stdlib.nan}. Namely, the comparison predicates treat [nan]\n as different from any other float value, including itself;\n while [compare] treats [nan] as equal to itself and less than any\n other float value. This treatment of [nan] ensures that [compare]\n defines a total ordering relation.\n\n [compare] applied to functional values may raise [Invalid_argument].\n [compare] applied to cyclic structures may not terminate.\n\n The [compare] function can be used as the comparison function\n required by the {!Set.Make} and {!Map.Make} functors, as well as\n the {!List.sort} and {!Array.sort} functions. *)\n\nval min : 'a -> 'a -> 'a\n(** Return the smaller of the two arguments.\n The result is unspecified if one of the arguments contains\n the float value [nan]. *)\n\nval max : 'a -> 'a -> 'a\n(** Return the greater of the two arguments.\n The result is unspecified if one of the arguments contains\n the float value [nan]. *)\n\nexternal ( == ) : 'a -> 'a -> bool = \"%eq\"\n(** [e1 == e2] tests for physical equality of [e1] and [e2].\n On mutable types such as references, arrays, byte sequences, records with\n mutable fields and objects with mutable instance variables,\n [e1 == e2] is true if and only if physical modification of [e1]\n also affects [e2].\n On non-mutable types, the behavior of [( == )] is\n implementation-dependent; however, it is guaranteed that\n [e1 == e2] implies [compare e1 e2 = 0].\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( != ) : 'a -> 'a -> bool = \"%noteq\"\n(** Negation of {!Stdlib.( == )}.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\n\n(** {1 Boolean operations} *)\n\nexternal not : bool -> bool = \"%boolnot\"\n(** The boolean negation. *)\n\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\n(** The boolean 'and'. Evaluation is sequential, left-to-right:\n in [e1 && e2], [e1] is evaluated first, and if it returns [false],\n [e2] is not evaluated at all.\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( & ) : bool -> bool -> bool = \"%sequand\"\n [@@ocaml.deprecated \"Use (&&) instead.\"]\n(** @deprecated {!Stdlib.( && )} should be used instead.\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( || ) : bool -> bool -> bool = \"%sequor\"\n(** The boolean 'or'. Evaluation is sequential, left-to-right:\n in [e1 || e2], [e1] is evaluated first, and if it returns [true],\n [e2] is not evaluated at all.\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( or ) : bool -> bool -> bool = \"%sequor\"\n [@@ocaml.deprecated \"Use (||) instead.\"]\n(** @deprecated {!Stdlib.( || )} should be used instead.\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\n(** {1 Debugging} *)\n\nexternal __LOC__ : string = \"%loc_LOC\"\n(** [__LOC__] returns the location at which this expression appears in\n the file currently being parsed by the compiler, with the standard\n error format of OCaml: \"File %S, line %d, characters %d-%d\".\n @since 4.02.0\n*)\n\nexternal __FILE__ : string = \"%loc_FILE\"\n(** [__FILE__] returns the name of the file currently being\n parsed by the compiler.\n @since 4.02.0\n*)\n\nexternal __LINE__ : int = \"%loc_LINE\"\n(** [__LINE__] returns the line number at which this expression\n appears in the file currently being parsed by the compiler.\n @since 4.02.0\n*)\n\nexternal __MODULE__ : string = \"%loc_MODULE\"\n(** [__MODULE__] returns the module name of the file being\n parsed by the compiler.\n @since 4.02.0\n*)\n\nexternal __POS__ : string * int * int * int = \"%loc_POS\"\n(** [__POS__] returns a tuple [(file,lnum,cnum,enum)], corresponding\n to the location at which this expression appears in the file\n currently being parsed by the compiler. [file] is the current\n filename, [lnum] the line number, [cnum] the character position in\n the line and [enum] the last character position in the line.\n @since 4.02.0\n *)\n\nexternal __FUNCTION__ : string = \"%loc_FUNCTION\"\n(** [__FUNCTION__] returns the name of the current function or method, including\n any enclosing modules or classes.\n\n @since 4.12.0 *)\n\nexternal __LOC_OF__ : 'a -> string * 'a = \"%loc_LOC\"\n(** [__LOC_OF__ expr] returns a pair [(loc, expr)] where [loc] is the\n location of [expr] in the file currently being parsed by the\n compiler, with the standard error format of OCaml: \"File %S, line\n %d, characters %d-%d\".\n @since 4.02.0\n*)\n\nexternal __LINE_OF__ : 'a -> int * 'a = \"%loc_LINE\"\n(** [__LINE_OF__ expr] returns a pair [(line, expr)], where [line] is the\n line number at which the expression [expr] appears in the file\n currently being parsed by the compiler.\n @since 4.02.0\n *)\n\nexternal __POS_OF__ : 'a -> (string * int * int * int) * 'a = \"%loc_POS\"\n(** [__POS_OF__ expr] returns a pair [(loc,expr)], where [loc] is a\n tuple [(file,lnum,cnum,enum)] corresponding to the location at\n which the expression [expr] appears in the file currently being\n parsed by the compiler. [file] is the current filename, [lnum] the\n line number, [cnum] the character position in the line and [enum]\n the last character position in the line.\n @since 4.02.0\n *)\n\n(** {1 Composition operators} *)\n\nexternal ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\n(** Reverse-application operator: [x |> f |> g] is exactly equivalent\n to [g (f (x))].\n Left-associative operator, see {!Ocaml_operators} for more information.\n @since 4.01\n*)\n\nexternal ( @@ ) : ('a -> 'b) -> 'a -> 'b = \"%apply\"\n(** Application operator: [g @@ f @@ x] is exactly equivalent to\n [g (f (x))].\n Right-associative operator, see {!Ocaml_operators} for more information.\n @since 4.01\n*)\n\n(** {1 Integer arithmetic} *)\n\n(** Integers are [Sys.int_size] bits wide.\n All operations are taken modulo 2{^[Sys.int_size]}.\n They do not fail on overflow. *)\n\nexternal ( ~- ) : int -> int = \"%negint\"\n(** Unary negation. You can also write [- e] instead of [~- e].\n Unary operator, see {!Ocaml_operators} for more information.\n*)\n\n\nexternal ( ~+ ) : int -> int = \"%identity\"\n(** Unary addition. You can also write [+ e] instead of [~+ e].\n Unary operator, see {!Ocaml_operators} for more information.\n @since 3.12.0\n*)\n\nexternal succ : int -> int = \"%succint\"\n(** [succ x] is [x + 1]. *)\n\nexternal pred : int -> int = \"%predint\"\n(** [pred x] is [x - 1]. *)\n\nexternal ( + ) : int -> int -> int = \"%addint\"\n(** Integer addition.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( - ) : int -> int -> int = \"%subint\"\n(** Integer subtraction.\n Left-associative operator, , see {!Ocaml_operators} for more information.\n*)\n\nexternal ( * ) : int -> int -> int = \"%mulint\"\n(** Integer multiplication.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( / ) : int -> int -> int = \"%divint\"\n(** Integer division.\n Integer division rounds the real quotient of its arguments towards zero.\n More precisely, if [x >= 0] and [y > 0], [x / y] is the greatest integer\n less than or equal to the real quotient of [x] by [y]. Moreover,\n [(- x) / y = x / (- y) = - (x / y)].\n Left-associative operator, see {!Ocaml_operators} for more information.\n\n @raise Division_by_zero if the second argument is 0.\n*)\n\nexternal ( mod ) : int -> int -> int = \"%modint\"\n(** Integer remainder. If [y] is not zero, the result\n of [x mod y] satisfies the following properties:\n [x = (x / y) * y + x mod y] and\n [abs(x mod y) <= abs(y) - 1].\n If [y = 0], [x mod y] raises [Division_by_zero].\n Note that [x mod y] is negative only if [x < 0].\n Left-associative operator, see {!Ocaml_operators} for more information.\n\n @raise Division_by_zero if [y] is zero.\n*)\n\nval abs : int -> int\n(** Return the absolute value of the argument. Note that this may be\n negative if the argument is [min_int]. *)\n\nval max_int : int\n(** The greatest representable integer. *)\n\nval min_int : int\n(** The smallest representable integer. *)\n\n\n(** {2 Bitwise operations} *)\n\nexternal ( land ) : int -> int -> int = \"%andint\"\n(** Bitwise logical and.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( lor ) : int -> int -> int = \"%orint\"\n(** Bitwise logical or.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( lxor ) : int -> int -> int = \"%xorint\"\n(** Bitwise logical exclusive or.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nval lnot : int -> int\n(** Bitwise logical negation. *)\n\nexternal ( lsl ) : int -> int -> int = \"%lslint\"\n(** [n lsl m] shifts [n] to the left by [m] bits.\n The result is unspecified if [m < 0] or [m > Sys.int_size].\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( lsr ) : int -> int -> int = \"%lsrint\"\n(** [n lsr m] shifts [n] to the right by [m] bits.\n This is a logical shift: zeroes are inserted regardless of\n the sign of [n].\n The result is unspecified if [m < 0] or [m > Sys.int_size].\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( asr ) : int -> int -> int = \"%asrint\"\n(** [n asr m] shifts [n] to the right by [m] bits.\n This is an arithmetic shift: the sign bit of [n] is replicated.\n The result is unspecified if [m < 0] or [m > Sys.int_size].\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\n(** {1 Floating-point arithmetic}\n\n OCaml's floating-point numbers follow the\n IEEE 754 standard, using double precision (64 bits) numbers.\n Floating-point operations never raise an exception on overflow,\n underflow, division by zero, etc. Instead, special IEEE numbers\n are returned as appropriate, such as [infinity] for [1.0 /. 0.0],\n [neg_infinity] for [-1.0 /. 0.0], and [nan] ('not a number')\n for [0.0 /. 0.0]. These special numbers then propagate through\n floating-point computations as expected: for instance,\n [1.0 /. infinity] is [0.0], basic arithmetic operations\n ([+.], [-.], [*.], [/.]) with [nan] as an argument return [nan], ...\n*)\n\nexternal ( ~-. ) : float -> float = \"%negfloat\"\n(** Unary negation. You can also write [-. e] instead of [~-. e].\n Unary operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( ~+. ) : float -> float = \"%identity\"\n(** Unary addition. You can also write [+. e] instead of [~+. e].\n Unary operator, see {!Ocaml_operators} for more information.\n @since 3.12.0\n*)\n\nexternal ( +. ) : float -> float -> float = \"%addfloat\"\n(** Floating-point addition.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( -. ) : float -> float -> float = \"%subfloat\"\n(** Floating-point subtraction.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( *. ) : float -> float -> float = \"%mulfloat\"\n(** Floating-point multiplication.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( /. ) : float -> float -> float = \"%divfloat\"\n(** Floating-point division.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( ** ) : float -> float -> float = \"caml_power_float\" \"pow\"\n [@@unboxed] [@@noalloc]\n(** Exponentiation.\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal sqrt : float -> float = \"caml_sqrt_float\" \"sqrt\"\n [@@unboxed] [@@noalloc]\n(** Square root. *)\n\nexternal exp : float -> float = \"caml_exp_float\" \"exp\" [@@unboxed] [@@noalloc]\n(** Exponential. *)\n\nexternal log : float -> float = \"caml_log_float\" \"log\" [@@unboxed] [@@noalloc]\n(** Natural logarithm. *)\n\nexternal log10 : float -> float = \"caml_log10_float\" \"log10\"\n [@@unboxed] [@@noalloc]\n(** Base 10 logarithm. *)\n\nexternal expm1 : float -> float = \"caml_expm1_float\" \"caml_expm1\"\n [@@unboxed] [@@noalloc]\n(** [expm1 x] computes [exp x -. 1.0], giving numerically-accurate results\n even if [x] is close to [0.0].\n @since 3.12.0\n*)\n\nexternal log1p : float -> float = \"caml_log1p_float\" \"caml_log1p\"\n [@@unboxed] [@@noalloc]\n(** [log1p x] computes [log(1.0 +. x)] (natural logarithm),\n giving numerically-accurate results even if [x] is close to [0.0].\n @since 3.12.0\n*)\n\nexternal cos : float -> float = \"caml_cos_float\" \"cos\" [@@unboxed] [@@noalloc]\n(** Cosine. Argument is in radians. *)\n\nexternal sin : float -> float = \"caml_sin_float\" \"sin\" [@@unboxed] [@@noalloc]\n(** Sine. Argument is in radians. *)\n\nexternal tan : float -> float = \"caml_tan_float\" \"tan\" [@@unboxed] [@@noalloc]\n(** Tangent. Argument is in radians. *)\n\nexternal acos : float -> float = \"caml_acos_float\" \"acos\"\n [@@unboxed] [@@noalloc]\n(** Arc cosine. The argument must fall within the range [[-1.0, 1.0]].\n Result is in radians and is between [0.0] and [pi]. *)\n\nexternal asin : float -> float = \"caml_asin_float\" \"asin\"\n [@@unboxed] [@@noalloc]\n(** Arc sine. The argument must fall within the range [[-1.0, 1.0]].\n Result is in radians and is between [-pi/2] and [pi/2]. *)\n\nexternal atan : float -> float = \"caml_atan_float\" \"atan\"\n [@@unboxed] [@@noalloc]\n(** Arc tangent.\n Result is in radians and is between [-pi/2] and [pi/2]. *)\n\nexternal atan2 : float -> float -> float = \"caml_atan2_float\" \"atan2\"\n [@@unboxed] [@@noalloc]\n(** [atan2 y x] returns the arc tangent of [y /. x]. The signs of [x]\n and [y] are used to determine the quadrant of the result.\n Result is in radians and is between [-pi] and [pi]. *)\n\nexternal hypot : float -> float -> float = \"caml_hypot_float\" \"caml_hypot\"\n [@@unboxed] [@@noalloc]\n(** [hypot x y] returns [sqrt(x *. x + y *. y)], that is, the length\n of the hypotenuse of a right-angled triangle with sides of length\n [x] and [y], or, equivalently, the distance of the point [(x,y)]\n to origin. If one of [x] or [y] is infinite, returns [infinity]\n even if the other is [nan].\n @since 4.00.0 *)\n\nexternal cosh : float -> float = \"caml_cosh_float\" \"cosh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic cosine. Argument is in radians. *)\n\nexternal sinh : float -> float = \"caml_sinh_float\" \"sinh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic sine. Argument is in radians. *)\n\nexternal tanh : float -> float = \"caml_tanh_float\" \"tanh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic tangent. Argument is in radians. *)\n\nexternal acosh : float -> float = \"caml_acosh_float\" \"caml_acosh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic arc cosine. The argument must fall within the range\n [[1.0, inf]].\n Result is in radians and is between [0.0] and [inf].\n\n @since 4.13.0\n*)\n\nexternal asinh : float -> float = \"caml_asinh_float\" \"caml_asinh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic arc sine. The argument and result range over the entire\n real line.\n Result is in radians.\n\n @since 4.13.0\n*)\n\nexternal atanh : float -> float = \"caml_atanh_float\" \"caml_atanh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic arc tangent. The argument must fall within the range\n [[-1.0, 1.0]].\n Result is in radians and ranges over the entire real line.\n\n @since 4.13.0\n*)\n\nexternal ceil : float -> float = \"caml_ceil_float\" \"ceil\"\n [@@unboxed] [@@noalloc]\n(** Round above to an integer value.\n [ceil f] returns the least integer value greater than or equal to [f].\n The result is returned as a float. *)\n\nexternal floor : float -> float = \"caml_floor_float\" \"floor\"\n [@@unboxed] [@@noalloc]\n(** Round below to an integer value.\n [floor f] returns the greatest integer value less than or\n equal to [f].\n The result is returned as a float. *)\n\nexternal abs_float : float -> float = \"%absfloat\"\n(** [abs_float f] returns the absolute value of [f]. *)\n\nexternal copysign : float -> float -> float\n = \"caml_copysign_float\" \"caml_copysign\"\n [@@unboxed] [@@noalloc]\n(** [copysign x y] returns a float whose absolute value is that of [x]\n and whose sign is that of [y]. If [x] is [nan], returns [nan].\n If [y] is [nan], returns either [x] or [-. x], but it is not\n specified which.\n @since 4.00.0 *)\n\nexternal mod_float : float -> float -> float = \"caml_fmod_float\" \"fmod\"\n [@@unboxed] [@@noalloc]\n(** [mod_float a b] returns the remainder of [a] with respect to\n [b]. The returned value is [a -. n *. b], where [n]\n is the quotient [a /. b] rounded towards zero to an integer. *)\n\nexternal frexp : float -> float * int = \"caml_frexp_float\"\n(** [frexp f] returns the pair of the significant\n and the exponent of [f]. When [f] is zero, the\n significant [x] and the exponent [n] of [f] are equal to\n zero. When [f] is non-zero, they are defined by\n [f = x *. 2 ** n] and [0.5 <= x < 1.0]. *)\n\n\nexternal ldexp : (float [@unboxed]) -> (int [@untagged]) -> (float [@unboxed]) =\n \"caml_ldexp_float\" \"caml_ldexp_float_unboxed\" [@@noalloc]\n(** [ldexp x n] returns [x *. 2 ** n]. *)\n\nexternal modf : float -> float * float = \"caml_modf_float\"\n(** [modf f] returns the pair of the fractional and integral\n part of [f]. *)\n\nexternal float : int -> float = \"%floatofint\"\n(** Same as {!Stdlib.float_of_int}. *)\n\nexternal float_of_int : int -> float = \"%floatofint\"\n(** Convert an integer to floating-point. *)\n\nexternal truncate : float -> int = \"%intoffloat\"\n(** Same as {!Stdlib.int_of_float}. *)\n\nexternal int_of_float : float -> int = \"%intoffloat\"\n(** Truncate the given floating-point number to an integer.\n The result is unspecified if the argument is [nan] or falls outside the\n range of representable integers. *)\n\nval infinity : float\n(** Positive infinity. *)\n\nval neg_infinity : float\n(** Negative infinity. *)\n\nval nan : float\n(** A special floating-point value denoting the result of an\n undefined operation such as [0.0 /. 0.0]. Stands for\n 'not a number'. Any floating-point operation with [nan] as\n argument returns [nan] as result. As for floating-point comparisons,\n [=], [<], [<=], [>] and [>=] return [false] and [<>] returns [true]\n if one or both of their arguments is [nan]. *)\n\nval max_float : float\n(** The largest positive finite value of type [float]. *)\n\nval min_float : float\n(** The smallest positive, non-zero, non-denormalized value of type [float]. *)\n\nval epsilon_float : float\n(** The difference between [1.0] and the smallest exactly representable\n floating-point number greater than [1.0]. *)\n\ntype fpclass =\n FP_normal (** Normal number, none of the below *)\n | FP_subnormal (** Number very close to 0.0, has reduced precision *)\n | FP_zero (** Number is 0.0 or -0.0 *)\n | FP_infinite (** Number is positive or negative infinity *)\n | FP_nan (** Not a number: result of an undefined operation *)\n(** The five classes of floating-point numbers, as determined by\n the {!Stdlib.classify_float} function. *)\n\nexternal classify_float : (float [@unboxed]) -> fpclass =\n \"caml_classify_float\" \"caml_classify_float_unboxed\" [@@noalloc]\n(** Return the class of the given floating-point number:\n normal, subnormal, zero, infinite, or not a number. *)\n\n\n(** {1 String operations}\n\n More string operations are provided in module {!String}.\n*)\n\nval ( ^ ) : string -> string -> string\n(** String concatenation.\n Right-associative operator, see {!Ocaml_operators} for more information.\n\n @raise Invalid_argument if the result is longer then\n than {!Sys.max_string_length} bytes.\n*)\n\n(** {1 Character operations}\n\n More character operations are provided in module {!Char}.\n*)\n\nexternal int_of_char : char -> int = \"%identity\"\n(** Return the ASCII code of the argument. *)\n\nval char_of_int : int -> char\n(** Return the character with the given ASCII code.\n @raise Invalid_argument if the argument is\n outside the range 0--255. *)\n\n\n(** {1 Unit operations} *)\n\nexternal ignore : 'a -> unit = \"%ignore\"\n(** Discard the value of its argument and return [()].\n For instance, [ignore(f x)] discards the result of\n the side-effecting function [f]. It is equivalent to\n [f x; ()], except that the latter may generate a\n compiler warning; writing [ignore(f x)] instead\n avoids the warning. *)\n\n\n(** {1 String conversion functions} *)\n\nval string_of_bool : bool -> string\n(** Return the string representation of a boolean. As the returned values\n may be shared, the user should not modify them directly.\n*)\n\nval bool_of_string_opt: string -> bool option\n(** Convert the given string to a boolean.\n\n Return [None] if the string is not [\"true\"] or [\"false\"].\n @since 4.05\n*)\n\nval bool_of_string : string -> bool\n(** Same as {!Stdlib.bool_of_string_opt}, but raise\n [Invalid_argument \"bool_of_string\"] instead of returning [None]. *)\n\nval string_of_int : int -> string\n(** Return the string representation of an integer, in decimal. *)\n\nval int_of_string_opt: string -> int option\n(** Convert the given string to an integer.\n The string is read in decimal (by default, or if the string\n begins with [0u]), in hexadecimal (if it begins with [0x] or\n [0X]), in octal (if it begins with [0o] or [0O]), or in binary\n (if it begins with [0b] or [0B]).\n\n The [0u] prefix reads the input as an unsigned integer in the range\n [[0, 2*max_int+1]]. If the input exceeds {!max_int}\n it is converted to the signed integer\n [min_int + input - max_int - 1].\n\n The [_] (underscore) character can appear anywhere in the string\n and is ignored.\n\n Return [None] if the given string is not a valid representation of an\n integer, or if the integer represented exceeds the range of integers\n representable in type [int].\n @since 4.05\n*)\n\nexternal int_of_string : string -> int = \"caml_int_of_string\"\n(** Same as {!Stdlib.int_of_string_opt}, but raise\n [Failure \"int_of_string\"] instead of returning [None]. *)\n\nval string_of_float : float -> string\n(** Return the string representation of a floating-point number. *)\n\nval float_of_string_opt: string -> float option\n(** Convert the given string to a float. The string is read in decimal\n (by default) or in hexadecimal (marked by [0x] or [0X]).\n\n The format of decimal floating-point numbers is\n [ [-] dd.ddd (e|E) [+|-] dd ], where [d] stands for a decimal digit.\n\n The format of hexadecimal floating-point numbers is\n [ [-] 0(x|X) hh.hhh (p|P) [+|-] dd ], where [h] stands for an\n hexadecimal digit and [d] for a decimal digit.\n\n In both cases, at least one of the integer and fractional parts must be\n given; the exponent part is optional.\n\n The [_] (underscore) character can appear anywhere in the string\n and is ignored.\n\n Depending on the execution platforms, other representations of\n floating-point numbers can be accepted, but should not be relied upon.\n\n Return [None] if the given string is not a valid representation of a float.\n @since 4.05\n*)\n\nexternal float_of_string : string -> float = \"caml_float_of_string\"\n(** Same as {!Stdlib.float_of_string_opt}, but raise\n [Failure \"float_of_string\"] instead of returning [None]. *)\n\n(** {1 Pair operations} *)\n\nexternal fst : 'a * 'b -> 'a = \"%field0\"\n(** Return the first component of a pair. *)\n\nexternal snd : 'a * 'b -> 'b = \"%field1\"\n(** Return the second component of a pair. *)\n\n\n(** {1 List operations}\n\n More list operations are provided in module {!List}.\n*)\n\nval ( @ ) : 'a list -> 'a list -> 'a list\n(** List concatenation. Not tail-recursive (length of the first argument).\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\n(** {1 Input/output}\n Note: all input/output functions can raise [Sys_error] when the system\n calls they invoke fail. *)\n\ntype in_channel\n(** The type of input channel. *)\n\ntype out_channel\n(** The type of output channel. *)\n\nval stdin : in_channel\n(** The standard input for the process. *)\n\nval stdout : out_channel\n(** The standard output for the process. *)\n\nval stderr : out_channel\n(** The standard error output for the process. *)\n\n\n(** {2 Output functions on standard output} *)\n\nval print_char : char -> unit\n(** Print a character on standard output. *)\n\nval print_string : string -> unit\n(** Print a string on standard output. *)\n\nval print_bytes : bytes -> unit\n(** Print a byte sequence on standard output.\n @since 4.02.0 *)\n\nval print_int : int -> unit\n(** Print an integer, in decimal, on standard output. *)\n\nval print_float : float -> unit\n(** Print a floating-point number, in decimal, on standard output. *)\n\nval print_endline : string -> unit\n(** Print a string, followed by a newline character, on\n standard output and flush standard output. *)\n\nval print_newline : unit -> unit\n(** Print a newline character on standard output, and flush\n standard output. This can be used to simulate line\n buffering of standard output. *)\n\n\n(** {2 Output functions on standard error} *)\n\nval prerr_char : char -> unit\n(** Print a character on standard error. *)\n\nval prerr_string : string -> unit\n(** Print a string on standard error. *)\n\nval prerr_bytes : bytes -> unit\n(** Print a byte sequence on standard error.\n @since 4.02.0 *)\n\nval prerr_int : int -> unit\n(** Print an integer, in decimal, on standard error. *)\n\nval prerr_float : float -> unit\n(** Print a floating-point number, in decimal, on standard error. *)\n\nval prerr_endline : string -> unit\n(** Print a string, followed by a newline character on standard\n error and flush standard error. *)\n\nval prerr_newline : unit -> unit\n(** Print a newline character on standard error, and flush\n standard error. *)\n\n\n(** {2 Input functions on standard input} *)\n\nval read_line : unit -> string\n(** Flush standard output, then read characters from standard input\n until a newline character is encountered.\n\n Return the string of all characters read, without the newline character\n at the end.\n\n @raise End_of_file if the end of the file is reached at the beginning of\n line.\n*)\n\nval read_int_opt: unit -> int option\n(** Flush standard output, then read one line from standard input\n and convert it to an integer.\n\n Return [None] if the line read is not a valid representation of an integer.\n @since 4.05\n*)\n\nval read_int : unit -> int\n(** Same as {!Stdlib.read_int_opt}, but raise [Failure \"int_of_string\"]\n instead of returning [None]. *)\n\nval read_float_opt: unit -> float option\n(** Flush standard output, then read one line from standard input\n and convert it to a floating-point number.\n\n Return [None] if the line read is not a valid representation of a\n floating-point number.\n @since 4.05.0\n*)\n\nval read_float : unit -> float\n(** Same as {!Stdlib.read_float_opt}, but raise [Failure \"float_of_string\"]\n instead of returning [None]. *)\n\n\n(** {2 General output functions} *)\n\ntype open_flag =\n Open_rdonly (** open for reading. *)\n | Open_wronly (** open for writing. *)\n | Open_append (** open for appending: always write at end of file. *)\n | Open_creat (** create the file if it does not exist. *)\n | Open_trunc (** empty the file if it already exists. *)\n | Open_excl (** fail if Open_creat and the file already exists. *)\n | Open_binary (** open in binary mode (no conversion). *)\n | Open_text (** open in text mode (may perform conversions). *)\n | Open_nonblock (** open in non-blocking mode. *)\n(** Opening modes for {!Stdlib.open_out_gen} and\n {!Stdlib.open_in_gen}. *)\n\nval open_out : string -> out_channel\n(** Open the named file for writing, and return a new output channel\n on that file, positioned at the beginning of the file. The\n file is truncated to zero length if it already exists. It\n is created if it does not already exists. *)\n\nval open_out_bin : string -> out_channel\n(** Same as {!Stdlib.open_out}, but the file is opened in binary mode,\n so that no translation takes place during writes. On operating\n systems that do not distinguish between text mode and binary\n mode, this function behaves like {!Stdlib.open_out}. *)\n\nval open_out_gen : open_flag list -> int -> string -> out_channel\n(** [open_out_gen mode perm filename] opens the named file for writing,\n as described above. The extra argument [mode]\n specifies the opening mode. The extra argument [perm] specifies\n the file permissions, in case the file must be created.\n {!Stdlib.open_out} and {!Stdlib.open_out_bin} are special\n cases of this function. *)\n\nval flush : out_channel -> unit\n(** Flush the buffer associated with the given output channel,\n performing all pending writes on that channel.\n Interactive programs must be careful about flushing standard\n output and standard error at the right time. *)\n\nval flush_all : unit -> unit\n(** Flush all open output channels; ignore errors. *)\n\nval output_char : out_channel -> char -> unit\n(** Write the character on the given output channel. *)\n\nval output_string : out_channel -> string -> unit\n(** Write the string on the given output channel. *)\n\nval output_bytes : out_channel -> bytes -> unit\n(** Write the byte sequence on the given output channel.\n @since 4.02.0 *)\n\nval output : out_channel -> bytes -> int -> int -> unit\n(** [output oc buf pos len] writes [len] characters from byte sequence [buf],\n starting at offset [pos], to the given output channel [oc].\n @raise Invalid_argument if [pos] and [len] do not\n designate a valid range of [buf]. *)\n\nval output_substring : out_channel -> string -> int -> int -> unit\n(** Same as [output] but take a string as argument instead of\n a byte sequence.\n @since 4.02.0 *)\n\nval output_byte : out_channel -> int -> unit\n(** Write one 8-bit integer (as the single character with that code)\n on the given output channel. The given integer is taken modulo\n 256. *)\n\nval output_binary_int : out_channel -> int -> unit\n(** Write one integer in binary format (4 bytes, big-endian)\n on the given output channel.\n The given integer is taken modulo 2{^32}.\n The only reliable way to read it back is through the\n {!Stdlib.input_binary_int} function. The format is compatible across\n all machines for a given version of OCaml. *)\n\nval output_value : out_channel -> 'a -> unit\n(** Write the representation of a structured value of any type\n to a channel. Circularities and sharing inside the value\n are detected and preserved. The object can be read back,\n by the function {!Stdlib.input_value}. See the description of module\n {!Marshal} for more information. {!Stdlib.output_value} is equivalent\n to {!Marshal.to_channel} with an empty list of flags. *)\n\nval seek_out : out_channel -> int -> unit\n(** [seek_out chan pos] sets the current writing position to [pos]\n for channel [chan]. This works only for regular files. On\n files of other kinds (such as terminals, pipes and sockets),\n the behavior is unspecified. *)\n\nval pos_out : out_channel -> int\n(** Return the current writing position for the given channel. Does\n not work on channels opened with the [Open_append] flag (returns\n unspecified results).\n For files opened in text mode under Windows, the returned position\n is approximate (owing to end-of-line conversion); in particular,\n saving the current position with [pos_out], then going back to\n this position using [seek_out] will not work. For this\n programming idiom to work reliably and portably, the file must be\n opened in binary mode. *)\n\nval out_channel_length : out_channel -> int\n(** Return the size (number of characters) of the regular file\n on which the given channel is opened. If the channel is opened\n on a file that is not a regular file, the result is meaningless. *)\n\nval close_out : out_channel -> unit\n(** Close the given channel, flushing all buffered write operations.\n Output functions raise a [Sys_error] exception when they are\n applied to a closed output channel, except [close_out] and [flush],\n which do nothing when applied to an already closed channel.\n Note that [close_out] may raise [Sys_error] if the operating\n system signals an error when flushing or closing. *)\n\nval close_out_noerr : out_channel -> unit\n(** Same as [close_out], but ignore all errors. *)\n\nval set_binary_mode_out : out_channel -> bool -> unit\n(** [set_binary_mode_out oc true] sets the channel [oc] to binary\n mode: no translations take place during output.\n [set_binary_mode_out oc false] sets the channel [oc] to text\n mode: depending on the operating system, some translations\n may take place during output. For instance, under Windows,\n end-of-lines will be translated from [\\n] to [\\r\\n].\n This function has no effect under operating systems that\n do not distinguish between text mode and binary mode. *)\n\n\n(** {2 General input functions} *)\n\nval open_in : string -> in_channel\n(** Open the named file for reading, and return a new input channel\n on that file, positioned at the beginning of the file. *)\n\nval open_in_bin : string -> in_channel\n(** Same as {!Stdlib.open_in}, but the file is opened in binary mode,\n so that no translation takes place during reads. On operating\n systems that do not distinguish between text mode and binary\n mode, this function behaves like {!Stdlib.open_in}. *)\n\nval open_in_gen : open_flag list -> int -> string -> in_channel\n(** [open_in_gen mode perm filename] opens the named file for reading,\n as described above. The extra arguments\n [mode] and [perm] specify the opening mode and file permissions.\n {!Stdlib.open_in} and {!Stdlib.open_in_bin} are special\n cases of this function. *)\n\nval input_char : in_channel -> char\n(** Read one character from the given input channel.\n @raise End_of_file if there are no more characters to read. *)\n\nval input_line : in_channel -> string\n(** Read characters from the given input channel, until a\n newline character is encountered. Return the string of\n all characters read, without the newline character at the end.\n @raise End_of_file if the end of the file is reached\n at the beginning of line. *)\n\nval input : in_channel -> bytes -> int -> int -> int\n(** [input ic buf pos len] reads up to [len] characters from\n the given channel [ic], storing them in byte sequence [buf], starting at\n character number [pos].\n It returns the actual number of characters read, between 0 and\n [len] (inclusive).\n A return value of 0 means that the end of file was reached.\n A return value between 0 and [len] exclusive means that\n not all requested [len] characters were read, either because\n no more characters were available at that time, or because\n the implementation found it convenient to do a partial read;\n [input] must be called again to read the remaining characters,\n if desired. (See also {!Stdlib.really_input} for reading\n exactly [len] characters.)\n Exception [Invalid_argument \"input\"] is raised if [pos] and [len]\n do not designate a valid range of [buf]. *)\n\nval really_input : in_channel -> bytes -> int -> int -> unit\n(** [really_input ic buf pos len] reads [len] characters from channel [ic],\n storing them in byte sequence [buf], starting at character number [pos].\n @raise End_of_file if the end of file is reached before [len]\n characters have been read.\n @raise Invalid_argument if\n [pos] and [len] do not designate a valid range of [buf]. *)\n\nval really_input_string : in_channel -> int -> string\n(** [really_input_string ic len] reads [len] characters from channel [ic]\n and returns them in a new string.\n @raise End_of_file if the end of file is reached before [len]\n characters have been read.\n @since 4.02.0 *)\n\nval input_byte : in_channel -> int\n(** Same as {!Stdlib.input_char}, but return the 8-bit integer representing\n the character.\n @raise End_of_file if the end of file was reached. *)\n\nval input_binary_int : in_channel -> int\n(** Read an integer encoded in binary format (4 bytes, big-endian)\n from the given input channel. See {!Stdlib.output_binary_int}.\n @raise End_of_file if the end of file was reached while reading the\n integer. *)\n\nval input_value : in_channel -> 'a\n(** Read the representation of a structured value, as produced\n by {!Stdlib.output_value}, and return the corresponding value.\n This function is identical to {!Marshal.from_channel};\n see the description of module {!Marshal} for more information,\n in particular concerning the lack of type safety. *)\n\nval seek_in : in_channel -> int -> unit\n(** [seek_in chan pos] sets the current reading position to [pos]\n for channel [chan]. This works only for regular files. On\n files of other kinds, the behavior is unspecified. *)\n\nval pos_in : in_channel -> int\n(** Return the current reading position for the given channel. For\n files opened in text mode under Windows, the returned position is\n approximate (owing to end-of-line conversion); in particular,\n saving the current position with [pos_in], then going back to this\n position using [seek_in] will not work. For this programming\n idiom to work reliably and portably, the file must be opened in\n binary mode. *)\n\nval in_channel_length : in_channel -> int\n(** Return the size (number of characters) of the regular file\n on which the given channel is opened. If the channel is opened\n on a file that is not a regular file, the result is meaningless.\n The returned size does not take into account the end-of-line\n translations that can be performed when reading from a channel\n opened in text mode. *)\n\nval close_in : in_channel -> unit\n(** Close the given channel. Input functions raise a [Sys_error]\n exception when they are applied to a closed input channel,\n except [close_in], which does nothing when applied to an already\n closed channel. *)\n\nval close_in_noerr : in_channel -> unit\n(** Same as [close_in], but ignore all errors. *)\n\nval set_binary_mode_in : in_channel -> bool -> unit\n(** [set_binary_mode_in ic true] sets the channel [ic] to binary\n mode: no translations take place during input.\n [set_binary_mode_out ic false] sets the channel [ic] to text\n mode: depending on the operating system, some translations\n may take place during input. For instance, under Windows,\n end-of-lines will be translated from [\\r\\n] to [\\n].\n This function has no effect under operating systems that\n do not distinguish between text mode and binary mode. *)\n\n\n(** {2 Operations on large files} *)\n\nmodule LargeFile :\n sig\n val seek_out : out_channel -> int64 -> unit\n val pos_out : out_channel -> int64\n val out_channel_length : out_channel -> int64\n val seek_in : in_channel -> int64 -> unit\n val pos_in : in_channel -> int64\n val in_channel_length : in_channel -> int64\n end\n(** Operations on large files.\n This sub-module provides 64-bit variants of the channel functions\n that manipulate file positions and file sizes. By representing\n positions and sizes by 64-bit integers (type [int64]) instead of\n regular integers (type [int]), these alternate functions allow\n operating on files whose sizes are greater than [max_int]. *)\n\n(** {1 References} *)\n\ntype 'a ref = { mutable contents : 'a }\n(** The type of references (mutable indirection cells) containing\n a value of type ['a]. *)\n\nexternal ref : 'a -> 'a ref = \"%makemutable\"\n(** Return a fresh reference containing the given value. *)\n\nexternal ( ! ) : 'a ref -> 'a = \"%field0\"\n(** [!r] returns the current contents of reference [r].\n Equivalent to [fun r -> r.contents].\n Unary operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( := ) : 'a ref -> 'a -> unit = \"%setfield0\"\n(** [r := a] stores the value of [a] in reference [r].\n Equivalent to [fun r v -> r.contents <- v].\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal incr : int ref -> unit = \"%incr\"\n(** Increment the integer contained in the given reference.\n Equivalent to [fun r -> r := succ !r]. *)\n\nexternal decr : int ref -> unit = \"%decr\"\n(** Decrement the integer contained in the given reference.\n Equivalent to [fun r -> r := pred !r]. *)\n\n(** {1 Result type} *)\n\n(** @since 4.03.0 *)\ntype ('a,'b) result = Ok of 'a | Error of 'b\n\n(** {1 Operations on format strings} *)\n\n(** Format strings are character strings with special lexical conventions\n that defines the functionality of formatted input/output functions. Format\n strings are used to read data with formatted input functions from module\n {!Scanf} and to print data with formatted output functions from modules\n {!Printf} and {!Format}.\n\n Format strings are made of three kinds of entities:\n - {e conversions specifications}, introduced by the special character ['%']\n followed by one or more characters specifying what kind of argument to\n read or print,\n - {e formatting indications}, introduced by the special character ['@']\n followed by one or more characters specifying how to read or print the\n argument,\n - {e plain characters} that are regular characters with usual lexical\n conventions. Plain characters specify string literals to be read in the\n input or printed in the output.\n\n There is an additional lexical rule to escape the special characters ['%']\n and ['@'] in format strings: if a special character follows a ['%']\n character, it is treated as a plain character. In other words, [\"%%\"] is\n considered as a plain ['%'] and [\"%@\"] as a plain ['@'].\n\n For more information about conversion specifications and formatting\n indications available, read the documentation of modules {!Scanf},\n {!Printf} and {!Format}.\n*)\n\n(** Format strings have a general and highly polymorphic type\n [('a, 'b, 'c, 'd, 'e, 'f) format6].\n The two simplified types, [format] and [format4] below are\n included for backward compatibility with earlier releases of\n OCaml.\n\n The meaning of format string type parameters is as follows:\n\n - ['a] is the type of the parameters of the format for formatted output\n functions ([printf]-style functions);\n ['a] is the type of the values read by the format for formatted input\n functions ([scanf]-style functions).\n\n - ['b] is the type of input source for formatted input functions and the\n type of output target for formatted output functions.\n For [printf]-style functions from module {!Printf}, ['b] is typically\n [out_channel];\n for [printf]-style functions from module {!Format}, ['b] is typically\n {!type:Format.formatter};\n for [scanf]-style functions from module {!Scanf}, ['b] is typically\n {!Scanf.Scanning.in_channel}.\n\n Type argument ['b] is also the type of the first argument given to\n user's defined printing functions for [%a] and [%t] conversions,\n and user's defined reading functions for [%r] conversion.\n\n - ['c] is the type of the result of the [%a] and [%t] printing\n functions, and also the type of the argument transmitted to the\n first argument of [kprintf]-style functions or to the\n [kscanf]-style functions.\n\n - ['d] is the type of parameters for the [scanf]-style functions.\n\n - ['e] is the type of the receiver function for the [scanf]-style functions.\n\n - ['f] is the final result type of a formatted input/output function\n invocation: for the [printf]-style functions, it is typically [unit];\n for the [scanf]-style functions, it is typically the result type of the\n receiver function.\n*)\n\ntype ('a, 'b, 'c, 'd, 'e, 'f) format6 =\n ('a, 'b, 'c, 'd, 'e, 'f) CamlinternalFormatBasics.format6\n\ntype ('a, 'b, 'c, 'd) format4 = ('a, 'b, 'c, 'c, 'c, 'd) format6\n\ntype ('a, 'b, 'c) format = ('a, 'b, 'c, 'c) format4\n\nval string_of_format : ('a, 'b, 'c, 'd, 'e, 'f) format6 -> string\n(** Converts a format string into a string. *)\n\nexternal format_of_string :\n ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n ('a, 'b, 'c, 'd, 'e, 'f) format6 = \"%identity\"\n(** [format_of_string s] returns a format string read from the string\n literal [s].\n Note: [format_of_string] can not convert a string argument that is not a\n literal. If you need this functionality, use the more general\n {!Scanf.format_from_string} function.\n*)\n\nval ( ^^ ) :\n ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n ('f, 'b, 'c, 'e, 'g, 'h) format6 ->\n ('a, 'b, 'c, 'd, 'g, 'h) format6\n(** [f1 ^^ f2] catenates format strings [f1] and [f2]. The result is a\n format string that behaves as the concatenation of format strings [f1] and\n [f2]: in case of formatted output, it accepts arguments from [f1], then\n arguments from [f2]; in case of formatted input, it returns results from\n [f1], then results from [f2].\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\n(** {1 Program termination} *)\n\nval exit : int -> 'a\n(** Terminate the process, returning the given status code\n to the operating system: usually 0 to indicate no errors,\n and a small positive integer to indicate failure.\n All open output channels are flushed with [flush_all].\n An implicit [exit 0] is performed each time a program\n terminates normally. An implicit [exit 2] is performed if the program\n terminates early because of an uncaught exception. *)\n\nval at_exit : (unit -> unit) -> unit\n(** Register the given function to be called at program termination\n time. The functions registered with [at_exit] will be called when\n the program does any of the following:\n - executes {!Stdlib.exit}\n - terminates, either normally or because of an uncaught\n exception\n - executes the C function [caml_shutdown].\n The functions are called in 'last in, first out' order: the\n function most recently added with [at_exit] is called first. *)\n\n(**/**)\n\n(* The following is for system use only. Do not call directly. *)\n\nval valid_float_lexem : string -> string\n\nval unsafe_really_input : in_channel -> bytes -> int -> int -> unit\n\nval do_at_exit : unit -> unit\n\n(**/**)\n\n(** {1:modules Standard library modules } *)\n\n(*MODULE_ALIASES*)\nmodule Arg = Arg\nmodule Array = Array\nmodule ArrayLabels = ArrayLabels\nmodule Atomic = Atomic\nmodule Bigarray = Bigarray\nmodule Bool = Bool\nmodule Buffer = Buffer\nmodule Bytes = Bytes\nmodule BytesLabels = BytesLabels\nmodule Callback = Callback\nmodule Char = Char\nmodule Complex = Complex\nmodule Digest = Digest\nmodule Either = Either\nmodule Ephemeron = Ephemeron\nmodule Filename = Filename\nmodule Float = Float\nmodule Format = Format\nmodule Fun = Fun\nmodule Gc = Gc\nmodule Genlex = Genlex\n[@@deprecated \"Use the camlp-streams library instead.\"]\nmodule Hashtbl = Hashtbl\nmodule In_channel = In_channel\nmodule Int = Int\nmodule Int32 = Int32\nmodule Int64 = Int64\nmodule Lazy = Lazy\nmodule Lexing = Lexing\nmodule List = List\nmodule ListLabels = ListLabels\nmodule Map = Map\nmodule Marshal = Marshal\nmodule MoreLabels = MoreLabels\nmodule Nativeint = Nativeint\nmodule Obj = Obj\nmodule Oo = Oo\nmodule Option = Option\nmodule Out_channel = Out_channel\nmodule Parsing = Parsing\nmodule Pervasives = Pervasives\n[@@deprecated \"Use Stdlib instead.\\n\\\n\\n\\\nIf you need to stay compatible with OCaml < 4.07, you can use the \\n\\\nstdlib-shims library: https://github.com/ocaml/stdlib-shims\"]\nmodule Printexc = Printexc\nmodule Printf = Printf\nmodule Queue = Queue\nmodule Random = Random\nmodule Result = Result\nmodule Scanf = Scanf\nmodule Seq = Seq\nmodule Set = Set\nmodule Stack = Stack\nmodule StdLabels = StdLabels\nmodule Stream = Stream\n[@@deprecated \"Use the camlp-streams library instead.\"]\nmodule String = String\nmodule StringLabels = StringLabels\nmodule Sys = Sys\nmodule Uchar = Uchar\nmodule Unit = Unit\nmodule Weak = Weak\n","(** An interface to use for int-like types, e.g., {{!Base.Int}[Int]} and\n {{!Base.Int64}[Int64]}. *)\n\nopen! Import\n\nmodule type Round = sig\n type t\n\n (** [round] rounds an int to a multiple of a given [to_multiple_of] argument, according\n to a direction [dir], with default [dir] being [`Nearest]. [round] will raise if\n [to_multiple_of <= 0]. If the result overflows (too far positive or too far\n negative), [round] returns an incorrect result.\n\n {v\n | `Down | rounds toward Int.neg_infinity |\n | `Up | rounds toward Int.infinity |\n | `Nearest | rounds to the nearest multiple, or `Up in case of a tie |\n | `Zero | rounds toward zero |\n v}\n\n Here are some examples for [round ~to_multiple_of:10] for each direction:\n\n {v\n | `Down | {10 .. 19} --> 10 | { 0 ... 9} --> 0 | {-10 ... -1} --> -10 |\n | `Up | { 1 .. 10} --> 10 | {-9 ... 0} --> 0 | {-19 .. -10} --> -10 |\n | `Zero | {10 .. 19} --> 10 | {-9 ... 9} --> 0 | {-19 .. -10} --> -10 |\n | `Nearest | { 5 .. 14} --> 10 | {-5 ... 4} --> 0 | {-15 ... -6} --> -10 |\n v}\n\n For convenience and performance, there are variants of [round] with [dir]\n hard-coded. If you are writing performance-critical code you should use these. *)\n\n val round : ?dir:[ `Zero | `Nearest | `Up | `Down ] -> t -> to_multiple_of:t -> t\n val round_towards_zero : t -> to_multiple_of:t -> t\n val round_down : t -> to_multiple_of:t -> t\n val round_up : t -> to_multiple_of:t -> t\n val round_nearest : t -> to_multiple_of:t -> t\nend\n\nmodule type Hexable = sig\n type t\n\n module Hex : sig\n type nonrec t = t [@@deriving_inline sexp, compare, hash]\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n val compare : t -> t -> int\n val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state\n val hash : t -> Ppx_hash_lib.Std.Hash.hash_value\n\n [@@@end]\n\n include Stringable.S with type t := t\n\n val to_string_hum : ?delimiter:char -> t -> string\n end\nend\n\nmodule type S_common = sig\n type t [@@deriving_inline sexp, sexp_grammar]\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n val t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t\n\n [@@@end]\n\n include Floatable.S with type t := t\n include Intable.S with type t := t\n include Identifiable.S with type t := t\n include Comparable.With_zero with type t := t\n include Invariant.S with type t := t\n include Hexable with type t := t\n\n (** [delimiter] is an underscore by default. *)\n val to_string_hum : ?delimiter:char -> t -> string\n\n (** {2 Infix operators and constants} *)\n\n val zero : t\n val one : t\n val minus_one : t\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val ( * ) : t -> t -> t\n\n (** Integer exponentiation *)\n val ( ** ) : t -> t -> t\n\n (** Negation *)\n\n val neg : t -> t\n val ( ~- ) : t -> t\n\n (** There are two pairs of integer division and remainder functions, [/%] and [%], and\n [/] and [rem]. They both satisfy the same equation relating the quotient and the\n remainder:\n\n {[\n x = (x /% y) * y + (x % y);\n x = (x / y) * y + (rem x y);\n ]}\n\n The functions return the same values if [x] and [y] are positive. They all raise\n if [y = 0].\n\n The functions differ if [x < 0] or [y < 0].\n\n If [y < 0], then [%] and [/%] raise, whereas [/] and [rem] do not.\n\n [x % y] always returns a value between 0 and [y - 1], even when [x < 0]. On the\n other hand, [rem x y] returns a negative value if and only if [x < 0]; that value\n satisfies [abs (rem x y) <= abs y - 1]. *)\n\n val ( /% ) : t -> t -> t\n val ( % ) : t -> t -> t\n val ( / ) : t -> t -> t\n val rem : t -> t -> t\n\n (** Float division of integers. *)\n val ( // ) : t -> t -> float\n\n (** Same as [bit_and]. *)\n val ( land ) : t -> t -> t\n\n (** Same as [bit_or]. *)\n val ( lor ) : t -> t -> t\n\n (** Same as [bit_xor]. *)\n val ( lxor ) : t -> t -> t\n\n (** Same as [bit_not]. *)\n val lnot : t -> t\n\n (** Same as [shift_left]. *)\n val ( lsl ) : t -> int -> t\n\n (** Same as [shift_right]. *)\n val ( asr ) : t -> int -> t\n\n (** {2 Other common functions} *)\n\n include Round with type t := t\n\n (** Returns the absolute value of the argument. May be negative if the input is\n [min_value]. *)\n val abs : t -> t\n\n (** {2 Successor and predecessor functions} *)\n\n val succ : t -> t\n val pred : t -> t\n\n (** {2 Exponentiation} *)\n\n (** [pow base exponent] returns [base] raised to the power of [exponent]. It is OK if\n [base <= 0]. [pow] raises if [exponent < 0], or an integer overflow would occur. *)\n val pow : t -> t -> t\n\n (** {2 Bit-wise logical operations } *)\n\n (** These are identical to [land], [lor], etc. except they're not infix and have\n different names. *)\n val bit_and : t -> t -> t\n\n val bit_or : t -> t -> t\n val bit_xor : t -> t -> t\n val bit_not : t -> t\n\n (** Returns the number of 1 bits in the binary representation of the input. *)\n val popcount : t -> int\n\n (** {2 Bit-shifting operations }\n\n The results are unspecified for negative shifts and shifts [>= num_bits]. *)\n\n (** Shifts left, filling in with zeroes. *)\n val shift_left : t -> int -> t\n\n (** Shifts right, preserving the sign of the input. *)\n val shift_right : t -> int -> t\n\n (** {2 Increment and decrement functions for integer references } *)\n\n val decr : t ref -> unit\n val incr : t ref -> unit\n\n (** {2 Conversion functions to related integer types} *)\n\n val of_int32_exn : int32 -> t\n val to_int32_exn : t -> int32\n val of_int64_exn : int64 -> t\n val to_int64 : t -> int64\n val of_nativeint_exn : nativeint -> t\n val to_nativeint_exn : t -> nativeint\n\n (** [of_float_unchecked] truncates the given floating point number to an integer,\n rounding towards zero.\n The result is unspecified if the argument is nan or falls outside the range\n of representable integers. *)\n val of_float_unchecked : float -> t\nend\n\nmodule type Operators_unbounded = sig\n type t\n\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val ( * ) : t -> t -> t\n val ( / ) : t -> t -> t\n val ( ~- ) : t -> t\n val ( ** ) : t -> t -> t\n\n include Comparisons.Infix with type t := t\n\n val abs : t -> t\n val neg : t -> t\n val zero : t\n val ( % ) : t -> t -> t\n val ( /% ) : t -> t -> t\n val ( // ) : t -> t -> float\n val ( land ) : t -> t -> t\n val ( lor ) : t -> t -> t\n val ( lxor ) : t -> t -> t\n val lnot : t -> t\n val ( lsl ) : t -> int -> t\n val ( asr ) : t -> int -> t\nend\n\nmodule type Operators = sig\n include Operators_unbounded\n\n val ( lsr ) : t -> int -> t\nend\n\n(** [S_unbounded] is a generic interface for unbounded integers, e.g. [Bignum.Bigint].\n [S_unbounded] is a restriction of [S] (below) that omits values that depend on\n fixed-size integers. *)\nmodule type S_unbounded = sig\n include S_common (** @inline *)\n\n (** A sub-module designed to be opened to make working with ints more convenient. *)\n module O : Operators_unbounded with type t := t\nend\n\n(** [S] is a generic interface for fixed-size integers. *)\nmodule type S = sig\n include S_common (** @inline *)\n\n (** The number of bits available in this integer type. Note that the integer\n representations are signed. *)\n val num_bits : int\n\n (** The largest representable integer. *)\n val max_value : t\n\n (** The smallest representable integer. *)\n val min_value : t\n\n (** Same as [shift_right_logical]. *)\n val ( lsr ) : t -> int -> t\n\n (** Shifts right, filling in with zeroes, which will not preserve the sign of the\n input. *)\n val shift_right_logical : t -> int -> t\n\n (** [ceil_pow2 x] returns the smallest power of 2 that is greater than or equal to [x].\n The implementation may only be called for [x > 0]. Example: [ceil_pow2 17 = 32] *)\n val ceil_pow2 : t -> t\n\n (** [floor_pow2 x] returns the largest power of 2 that is less than or equal to [x]. The\n implementation may only be called for [x > 0]. Example: [floor_pow2 17 = 16] *)\n val floor_pow2 : t -> t\n\n (** [ceil_log2 x] returns the ceiling of log-base-2 of [x], and raises if [x <= 0]. *)\n val ceil_log2 : t -> int\n\n (** [floor_log2 x] returns the floor of log-base-2 of [x], and raises if [x <= 0]. *)\n val floor_log2 : t -> int\n\n (** [is_pow2 x] returns true iff [x] is a power of 2. [is_pow2] raises if [x <= 0]. *)\n val is_pow2 : t -> bool\n\n (** Returns the number of leading zeros in the binary representation of the input, as an\n integer between 0 and one less than [num_bits].\n\n The results are unspecified for [t = 0]. *)\n val clz : t -> int\n\n (** Returns the number of trailing zeros in the binary representation of the input, as\n an integer between 0 and one less than [num_bits].\n\n The results are unspecified for [t = 0]. *)\n val ctz : t -> int\n\n (** A sub-module designed to be opened to make working with ints more convenient. *)\n module O : Operators with type t := t\nend\n\ninclude (\nstruct\n (** Various functors whose type-correctness ensures desired relationships between\n interfaces. *)\n\n module Check_O_contained_in_S (M : S) : module type of M.O = M\n module Check_O_contained_in_S_unbounded (M : S_unbounded) : module type of M.O = M\n module Check_S_unbounded_in_S (M : S) : S_unbounded = M\nend :\nsig end)\n\nmodule type Int_without_module_types = sig\n include S with type t = int\n\n (** [max_value_30_bits = 2^30 - 1]. It is useful for writing tests that work on both\n 64-bit and 32-bit platforms. *)\n val max_value_30_bits : t\n\n (** {2 Conversion functions} *)\n\n val of_int : int -> t\n val to_int : t -> int\n val of_int32 : int32 -> t option\n val to_int32 : t -> int32 option\n val of_int64 : int64 -> t option\n val of_nativeint : nativeint -> t option\n val to_nativeint : t -> nativeint\n\n (** {3 Truncating conversions}\n\n These functions return the least-significant bits of the input. In cases\n where optional conversions return [Some x], truncating conversions return [x]. *)\n\n val of_int32_trunc : int32 -> t\n val to_int32_trunc : t -> int32\n val of_int64_trunc : int64 -> t\n val of_nativeint_trunc : nativeint -> t\n\n (** {2 Byte swap operations}\n\n Byte swap operations reverse the order of bytes in an integer. For\n example, {!Int32.bswap32} reorders the bottom 32 bits (or 4 bytes),\n turning [0x1122_3344] to [0x4433_2211]. Byte swap functions exposed by\n Base use OCaml primitives to generate assembly instructions to perform\n the relevant byte swaps.\n\n For a more extensive list of byteswap functions, see {!Int32} and\n {!Int64}.\n *)\n\n (** Byte swaps bottom 16 bits (2 bytes). The values of the remaining bytes\n are undefined. *)\n val bswap16 : t -> t\n\n (**/**)\n\n (*_ See the Jane Street Style Guide for an explanation of [Private] submodules:\n\n https://opensource.janestreet.com/standards/#private-submodules *)\n module Private : sig\n (*_ For ../bench/bench_int.ml *)\n module O_F : sig\n val ( % ) : int -> int -> int\n val ( /% ) : int -> int -> int\n val ( // ) : int -> int -> float\n end\n end\nend\n\n(** OCaml's native integer type.\n\n The number of bits in an integer is platform dependent, being 31-bits on a 32-bit\n platform, and 63-bits on a 64-bit platform. [int] is a signed integer type. [int]s\n are also subject to overflow, meaning that [Int.max_value + 1 = Int.min_value].\n\n [int]s always fit in a machine word. *)\nmodule type Int = sig\n include Int_without_module_types\n\n (** {2 Module types specifying integer operations.} *)\n module type Hexable = Hexable\n\n module type Int_without_module_types = Int_without_module_types\n module type Operators = Operators\n module type Operators_unbounded = Operators_unbounded\n module type Round = Round\n module type S = S\n module type S_common = S_common\n module type S_unbounded = S_unbounded\nend\n","open! Import\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! Float_replace_polymorphic_compare\n\nlet ceil = Caml.ceil\nlet floor = Caml.floor\nlet mod_float = Caml.mod_float\nlet modf = Caml.modf\nlet float_of_string = Caml.float_of_string\nlet nan = Caml.nan\nlet infinity = Caml.infinity\nlet neg_infinity = Caml.neg_infinity\nlet max_finite_value = Caml.max_float\nlet epsilon_float = Caml.epsilon_float\nlet classify_float = Caml.classify_float\nlet abs_float = Caml.abs_float\nlet ( ** ) = Caml.( ** )\n\n(* The bits of INRIA's [Pervasives] that we just want to expose in [Float]. Most are\n already deprecated in [Pervasives], and eventually all of them should be. *)\ninclude (\n Caml :\n sig\n external frexp : float -> float * int = \"caml_frexp_float\"\n\n external ldexp\n : (float[@unboxed])\n -> (int[@untagged])\n -> (float[@unboxed])\n = \"caml_ldexp_float\" \"caml_ldexp_float_unboxed\"\n [@@noalloc]\n\n external log10 : float -> float = \"caml_log10_float\" \"log10\"\n [@@unboxed] [@@noalloc]\n\n external expm1 : float -> float = \"caml_expm1_float\" \"caml_expm1\"\n [@@unboxed] [@@noalloc]\n\n external log1p : float -> float = \"caml_log1p_float\" \"caml_log1p\"\n [@@unboxed] [@@noalloc]\n\n external copysign : float -> float -> float = \"caml_copysign_float\" \"caml_copysign\"\n [@@unboxed] [@@noalloc]\n\n external cos : float -> float = \"caml_cos_float\" \"cos\" [@@unboxed] [@@noalloc]\n external sin : float -> float = \"caml_sin_float\" \"sin\" [@@unboxed] [@@noalloc]\n external tan : float -> float = \"caml_tan_float\" \"tan\" [@@unboxed] [@@noalloc]\n external acos : float -> float = \"caml_acos_float\" \"acos\" [@@unboxed] [@@noalloc]\n external asin : float -> float = \"caml_asin_float\" \"asin\" [@@unboxed] [@@noalloc]\n external atan : float -> float = \"caml_atan_float\" \"atan\" [@@unboxed] [@@noalloc]\n\n external atan2 : float -> float -> float = \"caml_atan2_float\" \"atan2\"\n [@@unboxed] [@@noalloc]\n\n external hypot : float -> float -> float = \"caml_hypot_float\" \"caml_hypot\"\n [@@unboxed] [@@noalloc]\n\n external cosh : float -> float = \"caml_cosh_float\" \"cosh\" [@@unboxed] [@@noalloc]\n external sinh : float -> float = \"caml_sinh_float\" \"sinh\" [@@unboxed] [@@noalloc]\n external tanh : float -> float = \"caml_tanh_float\" \"tanh\" [@@unboxed] [@@noalloc]\n external sqrt : float -> float = \"caml_sqrt_float\" \"sqrt\" [@@unboxed] [@@noalloc]\n external exp : float -> float = \"caml_exp_float\" \"exp\" [@@unboxed] [@@noalloc]\n external log : float -> float = \"caml_log_float\" \"log\" [@@unboxed] [@@noalloc]\n end)\n\n(* We need this indirection because these are exposed as \"val\" instead of \"external\" *)\nlet frexp = frexp\nlet ldexp = ldexp\nlet is_nan x = (x : float) <> x\n\n(* An order-preserving bijection between all floats except for NaNs, and 99.95% of\n int64s.\n\n Note we don't distinguish 0. and -0. as separate values here, they both map to 0L, which\n maps back to 0.\n\n This should work both on little-endian and high-endian CPUs. Wikipedia says: \"on\n modern standard computers (i.e., implementing IEEE 754), one may in practice safely\n assume that the endianness is the same for floating point numbers as for integers\"\n (http://en.wikipedia.org/wiki/Endianness#Floating-point_and_endianness).\n*)\nlet to_int64_preserve_order t =\n if is_nan t\n then None\n else if t = 0.\n then (* also includes -0. *)\n Some 0L\n else if t > 0.\n then Some (Caml.Int64.bits_of_float t)\n else Some (Caml.Int64.neg (Caml.Int64.bits_of_float (-.t)))\n;;\n\nlet to_int64_preserve_order_exn x = Option.value_exn (to_int64_preserve_order x)\n\nlet of_int64_preserve_order x =\n if Int64_replace_polymorphic_compare.( >= ) x 0L\n then Caml.Int64.float_of_bits x\n else ~-.(Caml.Int64.float_of_bits (Caml.Int64.neg x))\n;;\n\nlet one_ulp dir t =\n match to_int64_preserve_order t with\n | None -> Caml.nan\n | Some x ->\n of_int64_preserve_order\n (Caml.Int64.add\n x\n (match dir with\n | `Up -> 1L\n | `Down -> -1L))\n;;\n\n(* [upper_bound_for_int] and [lower_bound_for_int] are for calculating the max/min float\n that fits in a given-size integer when rounded towards 0 (using [int_of_float]).\n\n max_int/min_int depend on [num_bits], e.g. +/- 2^30, +/- 2^62 if 31-bit, 63-bit\n (respectively) while float is IEEE standard for double (52 significant bits).\n\n In all cases, we want to guarantee that\n [lower_bound_for_int <= x <= upper_bound_for_int]\n iff [int_of_float x] fits in an int with [num_bits] bits.\n\n [2 ** (num_bits - 1)] is the first float greater that max_int, we use the preceding\n float as upper bound.\n\n [- (2 ** (num_bits - 1))] is equal to min_int.\n For lower bound we look for the smallest float [f] satisfying [f > min_int - 1] so that\n [f] rounds toward zero to [min_int]\n\n So in particular we will have:\n [lower_bound_for_int x <= - (2 ** (1-x))]\n [upper_bound_for_int x < 2 ** (1-x) ]\n*)\nlet upper_bound_for_int num_bits =\n let exp = Caml.float_of_int (num_bits - 1) in\n one_ulp `Down (2. ** exp)\n;;\n\nlet is_x_minus_one_exact x =\n (* [x = x -. 1.] does not work with x87 floating point arithmetic backend (which is used\n on 32-bit ocaml) because of 80-bit register precision of intermediate computations.\n\n An alternative way of computing this: [x -. one_ulp `Down x <= 1.] is also prone to\n the same precision issues: you need to make sure [x] is 64-bit.\n *)\n let open Int64_replace_polymorphic_compare in\n not (Caml.Int64.bits_of_float x = Caml.Int64.bits_of_float (x -. 1.))\n;;\n\nlet lower_bound_for_int num_bits =\n let exp = Caml.float_of_int (num_bits - 1) in\n let min_int_as_float = ~-.(2. ** exp) in\n let open Int_replace_polymorphic_compare in\n if num_bits - 1 < 53 (* 53 = #bits in the float's mantissa with sign included *)\n then (\n (* The smallest float that rounds towards zero to [min_int] is\n [min_int - 1 + epsilon] *)\n assert (is_x_minus_one_exact min_int_as_float);\n one_ulp `Up (min_int_as_float -. 1.))\n else (\n (* [min_int_as_float] is already the smallest float [f] satisfying [f > min_int - 1]. *)\n assert (not (is_x_minus_one_exact min_int_as_float));\n min_int_as_float)\n;;\n\n(* Float clamping is structured slightly differently than clamping for other types, so\n that we get the behavior of [clamp_unchecked nan ~min ~max = nan] (for any [min] and\n [max]) for free.\n*)\nlet clamp_unchecked (t : float) ~min ~max =\n if t < min then min else if max < t then max else t\n;;\n\nlet box =\n (* Prevent potential constant folding of [+. 0.] in the near ocamlopt future. *)\n let x = Sys0.opaque_identity 0. in\n fun f -> f +. x\n;;\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Float_replace_polymorphic_compare\n","open Core_kernel\nopen Import\nopen Deferred_std\nmodule Stream = Async_stream\n\nlet show_debug_messages = ref false\nlet check_invariant = ref false\n\nmodule Flushed_result = struct\n type t =\n [ `Ok\n | `Reader_closed\n ]\n [@@deriving compare, sexp_of]\n\n let equal = [%compare.equal: t]\n\n let combine (l : t Deferred.t list) =\n let%map l = Deferred.all l in\n match List.mem l `Reader_closed ~equal with\n | true -> `Reader_closed\n | false -> `Ok\n ;;\nend\n\n(* A [Consumer.t] acts as the monitor of some process that reads values from a pipe and\n processes them, allowing that process:\n - to communicate that it has taken responsibility for the values\n - to signal when it has finished with the values to interested parties (via\n [downstream_flushed])\n\n It is used in two steps:\n\n 1. calling [Consumer.start] at the point where the consumer takes values out of the\n Pipe via [read] or [read'].\n\n 2. calling [Consumer.values_sent_downstream].\n\n By calling [values_sent_downstream] one asserts that the [downstream_flushed] function\n supplied to [create] will now wait for this value.\n\n If no [Consumer.t] is supplied when a value is read then the value is defined to be\n flushed at that time. *)\nmodule Consumer : sig\n type t [@@deriving sexp_of]\n\n include Invariant.S with type t := t\n\n val create\n : pipe_id:int\n -> downstream_flushed:(unit -> Flushed_result.t Deferred.t)\n -> t\n\n val pipe_id : t -> int\n val start : t -> unit\n val values_sent_downstream : t -> unit\n val values_sent_downstream_and_flushed : t -> Flushed_result.t Deferred.t\nend = struct\n type t =\n { pipe_id : int\n ; (* [values_read] reflects whether values the consumer has read from the pipe have been\n sent downstream or if not, holds an ivar that is to be filled when they are. *)\n mutable values_read :\n [ `Have_been_sent_downstream | `Have_not_been_sent_downstream of unit Ivar.t ]\n ; (* [downstream_flushed ()] returns when all prior values that the consumer has\n passed downstream have been flushed all the way down the chain of pipes. *)\n downstream_flushed : unit -> Flushed_result.t Deferred.t\n }\n [@@deriving fields, sexp_of]\n\n let invariant t : unit =\n try\n let check f field = f (Field.get field t) in\n Fields.iter\n ~pipe_id:ignore\n ~values_read:\n (check (function\n | `Have_been_sent_downstream -> ()\n | `Have_not_been_sent_downstream ivar -> assert (Ivar.is_empty ivar)))\n ~downstream_flushed:ignore\n with\n | exn ->\n raise_s [%message \"Pipe.Consumer.invariant failed\" (exn : exn) ~pipe:(t : t)]\n ;;\n\n let create ~pipe_id ~downstream_flushed =\n { pipe_id; values_read = `Have_been_sent_downstream; downstream_flushed }\n ;;\n\n let start t =\n match t.values_read with\n | `Have_not_been_sent_downstream _ -> ()\n | `Have_been_sent_downstream ->\n t.values_read <- `Have_not_been_sent_downstream (Ivar.create ())\n ;;\n\n let values_sent_downstream t =\n match t.values_read with\n | `Have_been_sent_downstream -> ()\n | `Have_not_been_sent_downstream ivar ->\n Ivar.fill ivar ();\n t.values_read <- `Have_been_sent_downstream\n ;;\n\n let values_sent_downstream_and_flushed t =\n match t.values_read with\n | `Have_been_sent_downstream -> t.downstream_flushed ()\n | `Have_not_been_sent_downstream when_sent_downstream ->\n let%bind () = Ivar.read when_sent_downstream in\n t.downstream_flushed ()\n ;;\nend\n\nmodule Blocked_read = struct\n (* A [Blocked_read.t] represents a blocked read attempt. If someone reads from an empty\n pipe, they enqueue a [Blocked_read.t] in the queue of [blocked_reads]. Later, when\n values are written to a pipe, that will cause some number of blocked reads to be\n filled, first come first serve. The blocked-read constructor specifies how many\n values a read should consume from the pipe when it gets its turn.\n\n If a pipe is closed, then all blocked reads will be filled with [`Eof]. *)\n type 'a wants =\n | Zero of [ `Eof | `Ok ] Ivar.t\n | One of [ `Eof | `Ok of 'a ] Ivar.t\n | At_most of int * [ `Eof | `Ok of 'a Queue.t ] Ivar.t\n [@@deriving sexp_of]\n\n type 'a t =\n { wants : 'a wants\n ; consumer : Consumer.t option\n }\n [@@deriving fields, sexp_of]\n\n let invariant t : unit =\n try\n let check f field = f (Field.get field t) in\n Fields.iter\n ~wants:\n (check (function\n | Zero _ | One _ -> ()\n | At_most (i, _) -> assert (i > 0)))\n ~consumer:\n (check (function\n | None -> ()\n | Some consumer -> Consumer.invariant consumer))\n with\n | exn ->\n raise_s [%message \"Pipe.Blocked_read.invariant failed\" (exn : exn) ~pipe:(t : _ t)]\n ;;\n\n let create wants consumer = { wants; consumer }\n\n let is_empty t =\n match t.wants with\n | Zero i -> Ivar.is_empty i\n | One i -> Ivar.is_empty i\n | At_most (_, i) -> Ivar.is_empty i\n ;;\n\n let fill_with_eof t =\n match t.wants with\n | Zero i -> Ivar.fill i `Eof\n | One i -> Ivar.fill i `Eof\n | At_most (_, i) -> Ivar.fill i `Eof\n ;;\nend\n\nmodule Blocked_flush = struct\n (* A [Blocked_flush.t] represents a blocked flush operation, which can be enabled by a\n future read. If someone does [flushed p] on a pipe, that blocks until everything\n that's currently in the pipe at that point has drained out of the pipe. When we call\n [flushed], it records the total amount of data that has been written so far in\n [fill_when_num_values_read]. We fill the [Flush.t] with [`Ok] when this amount of\n data has been read from the pipe.\n\n A [Blocked_flush.t] can also be filled with [`Reader_closed], which happens when the\n reader end of the pipe is closed, and we are thus sure that the unread elements\n preceding the flush will never be read. *)\n type t =\n { fill_when_num_values_read : int\n ; ready : [ `Ok | `Reader_closed ] Ivar.t\n }\n [@@deriving fields, sexp_of]\n\n let fill t v = Ivar.fill t.ready v\nend\n\ntype ('a, 'phantom) t =\n { (* [id] is an integer used to distinguish pipes when debugging. *)\n id : int Sexp_hidden_in_test.t\n ; (* [info] is user-provided arbitrary sexp, for debugging purposes. *)\n mutable info : Sexp.t option [@sexp.option]\n ; (* [buffer] holds values written to the pipe that have not yet been read. *)\n mutable buffer : 'a Queue.t\n ; (* [size_budget] governs pushback on writers to the pipe.\n\n There is *no* invariant that [Queue.length buffer <= size_budget]. There is no\n hard upper bound on the number of elements that can be stuffed into the [buffer].\n This is due to the way we handle writes. When we do a write, all of the values\n written are immediately enqueued into [buffer]. After the write, if [Queue.length\n buffer <= t.size_budget], then the writer will be notified to continue writing.\n After the write, if [length t > t.size_budget], then the write will block until the\n pipe is under budget. *)\n mutable size_budget : int\n ; (* [pushback] is used to give feedback to writers about whether they should write to\n the pipe. [pushback] is full iff [length t <= t.size_budget || is_closed t]. *)\n mutable pushback : unit Ivar.t\n ; (* [num_values_read] keeps track of the total number of values that have been read\n from the pipe. We do not have to worry about overflow in [num_values_read]. You'd\n need to write 2^62 elements to the pipe, which would take about 146 years, at a\n flow rate of 1 size-unit/nanosecond. *)\n mutable num_values_read : int\n ; (* [blocked_flushes] holds flushes whose preceding elements have not been completely\n read. For each blocked flush, the number of elements that need to be read from the\n pipe in order to fill the flush is :\n\n fill_when_num_values_read - num_values_read\n\n Keeping the data in this form allows us to change a single field(num_values_read)\n when we consume values instead of having to iterate over the whole queue of\n flushes. *)\n blocked_flushes : Blocked_flush.t Queue.t\n ; (* [blocked_reads] holds reads that are waiting on data to be written to the pipe. *)\n blocked_reads : 'a Blocked_read.t Queue.t\n ; (* [closed] is filled when we close the write end of the pipe. *)\n closed : unit Ivar.t\n ; (* [read_closed] is filled when we close the read end of the pipe. *)\n read_closed : unit Ivar.t\n ; (* [consumers] is a list of all consumers that may be handling values read from the\n pipe. *)\n mutable consumers : Consumer.t list\n ; (* [upstream_flusheds] has a function for each pipe immediately upstream of this one.\n That function walks to the head(s) of the upstream pipe, and calls\n [downstream_flushed] on the head(s). See the definition of [upstream_flushed]\n below. *)\n upstream_flusheds : (unit -> Flushed_result.t Deferred.t) Bag.t\n }\n[@@deriving fields, sexp_of]\n\ntype ('a, 'phantom) pipe = ('a, 'phantom) t [@@deriving sexp_of]\n\nlet hash t = Hashtbl.hash t.id\nlet equal (t1 : (_, _) t) t2 = phys_equal t1 t2\nlet compare t1 t2 = Int.compare t1.id t2.id\nlet is_closed t = Ivar.is_full t.closed\nlet is_read_closed t = Ivar.is_full t.read_closed\nlet closed t = Ivar.read t.closed\nlet pushback t = Ivar.read t.pushback\nlet length t = Queue.length t.buffer\nlet is_empty t = length t = 0\n\nlet invariant t : unit =\n try\n let check f field = f (Field.get field t) in\n Fields.iter\n ~id:ignore\n ~info:ignore\n ~buffer:ignore\n ~size_budget:(check (fun size_budget -> assert (size_budget >= 0)))\n ~pushback:\n (check (fun pushback ->\n assert (\n Bool.equal\n (Ivar.is_full pushback)\n (length t <= t.size_budget || is_closed t))))\n ~num_values_read:ignore\n ~blocked_flushes:\n (check (fun blocked_flushes ->\n Queue.iter blocked_flushes ~f:(fun (f : Blocked_flush.t) ->\n assert (f.fill_when_num_values_read > t.num_values_read));\n assert (\n List.is_sorted\n ~compare:Int.compare\n (List.map\n (Queue.to_list blocked_flushes)\n ~f:Blocked_flush.fill_when_num_values_read));\n if is_empty t then assert (Queue.is_empty blocked_flushes)))\n ~blocked_reads:\n (check (fun blocked_reads ->\n (* If data is available, no one is waiting for it. This would need to change if\n we ever implement [read_exactly] as an atomic operation. *)\n if not (is_empty t) then assert (Queue.is_empty blocked_reads);\n Queue.iter blocked_reads ~f:(fun read ->\n Blocked_read.invariant read;\n assert (Blocked_read.is_empty read));\n (* You never block trying to read a closed pipe. *)\n if is_closed t then assert (Queue.is_empty blocked_reads)))\n ~closed:ignore\n ~read_closed:ignore\n ~consumers:\n (check (fun l ->\n List.iter l ~f:(fun consumer ->\n Consumer.invariant consumer;\n assert (Consumer.pipe_id consumer = t.id))))\n ~upstream_flusheds:ignore\n with\n | exn -> raise_s [%message \"Pipe.invariant failed\" (exn : exn) ~pipe:(t : (_, _) t)]\n;;\n\nmodule Reader = struct\n type phantom [@@deriving sexp_of]\n type 'a t = ('a, phantom) pipe [@@deriving sexp_of]\n\n let invariant = invariant\nend\n\nmodule Writer = struct\n type phantom [@@deriving sexp_of]\n type 'a t = ('a, phantom) pipe [@@deriving sexp_of]\n\n let invariant = invariant\nend\n\nlet id_ref = ref 0\n\nlet create_internal ~info ~initial_buffer =\n incr id_ref;\n let t =\n { id = !id_ref\n ; info\n ; closed = Ivar.create ()\n ; read_closed = Ivar.create ()\n ;\n size_budget = 0\n ; pushback = Ivar.create ()\n ; buffer = initial_buffer\n ; num_values_read = 0\n ; blocked_flushes = Queue.create ()\n ; blocked_reads = Queue.create ()\n ; consumers = []\n ; upstream_flusheds = Bag.create ()\n }\n in\n t\n;;\n\nlet create ?info () =\n let t = create_internal ~info ~initial_buffer:(Queue.create ()) in\n (* initially, the pipe does not pushback *)\n Ivar.fill t.pushback ();\n if !check_invariant then invariant t;\n t, t\n;;\n\nlet update_pushback t =\n if length t <= t.size_budget || is_closed t\n then Ivar.fill_if_empty t.pushback ()\n else if Ivar.is_full t.pushback\n then t.pushback <- Ivar.create ()\n;;\n\nlet close t =\n if !show_debug_messages then eprints \"close\" t [%sexp_of: (_, _) t];\n if !check_invariant then invariant t;\n if not (is_closed t)\n then (\n Ivar.fill t.closed ();\n if is_empty t\n then (\n Queue.iter t.blocked_reads ~f:Blocked_read.fill_with_eof;\n Queue.clear t.blocked_reads);\n update_pushback t)\n;;\n\nlet close_read t =\n if !show_debug_messages then eprints \"close_read\" t [%sexp_of: (_, _) t];\n if !check_invariant then invariant t;\n if not (is_read_closed t)\n then (\n Ivar.fill t.read_closed ();\n Queue.iter t.blocked_flushes ~f:(fun flush ->\n Blocked_flush.fill flush `Reader_closed);\n Queue.clear t.blocked_flushes;\n Queue.clear t.buffer;\n update_pushback t;\n (* we just cleared the buffer, so may need to fill [t.pushback] *)\n close t)\n;;\n\nlet create_reader_not_close_on_exception f =\n let r, w = create () in\n upon (f w) (fun () -> close w);\n r\n;;\n\nlet create_reader ~close_on_exception f =\n if not close_on_exception\n then create_reader_not_close_on_exception f\n else (\n let r, w = create () in\n don't_wait_for\n (Monitor.protect\n (fun () -> f w)\n ~finally:(fun () ->\n close w;\n return ()));\n r)\n;;\n\nlet create_writer f =\n let r, w = create () in\n don't_wait_for\n (Monitor.protect\n (fun () -> f r)\n ~finally:(fun () ->\n close_read r;\n return ()));\n w\n;;\n\nlet values_were_read t consumer =\n Option.iter consumer ~f:Consumer.start;\n let rec loop () =\n match Queue.peek t.blocked_flushes with\n | None -> ()\n | Some flush ->\n if t.num_values_read >= flush.fill_when_num_values_read\n then (\n ignore (Queue.dequeue_exn t.blocked_flushes : Blocked_flush.t);\n (match consumer with\n | None -> Blocked_flush.fill flush `Ok\n | Some consumer ->\n upon\n (Consumer.values_sent_downstream_and_flushed consumer)\n (fun flush_result -> Blocked_flush.fill flush flush_result));\n loop ())\n in\n loop ()\n;;\n\n(* [consume_all t] reads all the elements in [t]. *)\nlet consume_all t consumer =\n let result = t.buffer in\n t.buffer <- Queue.create ();\n t.num_values_read <- t.num_values_read + Queue.length result;\n values_were_read t consumer;\n update_pushback t;\n result\n;;\n\nlet consume_one t consumer =\n assert (length t >= 1);\n let result = Queue.dequeue_exn t.buffer in\n t.num_values_read <- t.num_values_read + 1;\n values_were_read t consumer;\n update_pushback t;\n result\n;;\n\nlet consume t ~max_queue_length consumer =\n assert (max_queue_length >= 0);\n if max_queue_length >= length t\n then consume_all t consumer\n else (\n t.num_values_read <- t.num_values_read + max_queue_length;\n values_were_read t consumer;\n let result = Queue.create ~capacity:max_queue_length () in\n Queue.blit_transfer ~src:t.buffer ~dst:result ~len:max_queue_length ();\n update_pushback t;\n result)\n;;\n\nlet set_size_budget t size_budget =\n if size_budget < 0 then raise_s [%message \"negative size_budget\" (size_budget : int)];\n t.size_budget <- size_budget;\n update_pushback t\n;;\n\nlet fill_blocked_reads t =\n while (not (Queue.is_empty t.blocked_reads)) && not (is_empty t) do\n let blocked_read = Queue.dequeue_exn t.blocked_reads in\n let consumer = blocked_read.consumer in\n match blocked_read.wants with\n | Zero ivar -> Ivar.fill ivar `Ok\n | One ivar -> Ivar.fill ivar (`Ok (consume_one t consumer))\n | At_most (max_queue_length, ivar) ->\n Ivar.fill ivar (`Ok (consume t ~max_queue_length consumer))\n done\n;;\n\n(* checks all invariants, calls a passed in f to handle a write, then updates reads and\n pushback *)\nlet start_write t =\n if !show_debug_messages then eprints \"write\" t [%sexp_of: (_, _) t];\n if !check_invariant then invariant t;\n if is_closed t then raise_s [%message \"write to closed pipe\" ~pipe:(t : (_, _) t)]\n;;\n\nlet finish_write t =\n fill_blocked_reads t;\n update_pushback t\n;;\n\nlet transfer_in_without_pushback t ~from =\n start_write t;\n Queue.blit_transfer ~src:from ~dst:t.buffer ();\n finish_write t\n;;\n\nlet transfer_in t ~from =\n transfer_in_without_pushback t ~from;\n pushback t\n;;\n\nlet copy_in_without_pushback t ~from =\n start_write t;\n Queue.iter from ~f:(fun x -> Queue.enqueue t.buffer x);\n finish_write t\n;;\n\n(* [write'] is used internally *)\nlet write' t q = transfer_in t ~from:q\n\nlet write_without_pushback t value =\n start_write t;\n Queue.enqueue t.buffer value;\n finish_write t\n;;\n\nlet write t value =\n write_without_pushback t value;\n pushback t\n;;\n\nlet write_when_ready t ~f =\n let%map () = pushback t in\n if is_closed t then `Closed else `Ok (f (fun x -> write_without_pushback t x))\n;;\n\nlet write_if_open t x = if not (is_closed t) then write t x else return ()\n\nlet write_without_pushback_if_open t x =\n if not (is_closed t) then write_without_pushback t x\n;;\n\nlet ensure_consumer_matches ?consumer t =\n match consumer with\n | None -> ()\n | Some consumer ->\n if t.id <> Consumer.pipe_id consumer\n then\n raise_s\n [%message\n \"Attempt to use consumer with wrong pipe\"\n (consumer : Consumer.t)\n ~pipe:(t : _ Reader.t)]\n;;\n\nlet start_read ?consumer t label =\n if !show_debug_messages then eprints label t [%sexp_of: (_, _) t];\n if !check_invariant then invariant t;\n ensure_consumer_matches t ?consumer\n;;\n\nlet gen_read_now ?consumer t consume =\n start_read t \"read_now\" ?consumer;\n if is_empty t\n then if is_closed t then `Eof else `Nothing_available\n else (\n assert (Queue.is_empty t.blocked_reads);\n (* from [invariant] and [not (is_empty t)] *)\n `Ok (consume t consumer))\n;;\n\nlet get_max_queue_length ~max_queue_length =\n match max_queue_length with\n | None -> Int.max_value\n | Some max_queue_length ->\n if max_queue_length <= 0\n then raise_s [%message \"max_queue_length <= 0\" (max_queue_length : int)];\n max_queue_length\n;;\n\nlet read_now' ?consumer ?max_queue_length t =\n let max_queue_length = get_max_queue_length ~max_queue_length in\n gen_read_now t ?consumer (fun t consumer -> consume t ~max_queue_length consumer)\n;;\n\nlet read_now ?consumer t = gen_read_now t ?consumer consume_one\nlet peek t = Queue.peek t.buffer\n\nlet clear t =\n match read_now' t with\n | `Eof | `Nothing_available | `Ok _ -> ()\n;;\n\nlet read' ?consumer ?max_queue_length t =\n let max_queue_length = get_max_queue_length ~max_queue_length in\n start_read t \"read'\" ?consumer;\n match read_now' t ?consumer ~max_queue_length with\n | (`Ok _ | `Eof) as r -> return r\n | `Nothing_available ->\n Deferred.create (fun ivar ->\n Queue.enqueue\n t.blocked_reads\n (Blocked_read.create (At_most (max_queue_length, ivar)) consumer))\n;;\n\nlet read ?consumer t =\n start_read t \"read\" ?consumer;\n if is_empty t\n then\n if is_closed t\n then return `Eof\n else\n Deferred.create (fun ivar ->\n Queue.enqueue t.blocked_reads (Blocked_read.(create (One ivar)) consumer))\n else (\n assert (Queue.is_empty t.blocked_reads);\n return (`Ok (consume_one t consumer)))\n;;\n\nlet values_available t =\n start_read t \"values_available\";\n if not (is_empty t)\n then return `Ok\n else if is_closed t\n then return `Eof\n else (\n match Queue.last t.blocked_reads with\n | Some { consumer = None; wants = Zero ivar } ->\n (* This case is an optimization for multiple calls to [values_available] in\n sequence. It causes them to all share the same ivar, rather than allocate\n an ivar per call. *)\n Ivar.read ivar\n | _ ->\n Deferred.create (fun ivar ->\n Queue.enqueue t.blocked_reads (Blocked_read.(create (Zero ivar)) None)))\n;;\n\nlet read_choice t = choice (values_available t) (fun (_ : [ `Ok | `Eof ]) -> read_now t)\n\nlet read_choice_single_consumer_exn t here =\n Deferred.Choice.map (read_choice t) ~f:(function\n | (`Ok _ | `Eof) as x -> x\n | `Nothing_available ->\n raise_s\n [%message\n \"Pipe.read_choice_single_consumer_exn: choice was enabled but pipe is \\\n empty; this is likely due to a race condition with one or more other \\\n consumers\"\n (here : Source_code_position.t)])\n;;\n\n(* [read_exactly t ~num_values] loops, getting you all [num_values] items, up\n to EOF. *)\nlet read_exactly ?consumer t ~num_values =\n start_read t \"read_exactly\" ?consumer;\n if num_values <= 0\n then raise_s [%message \"Pipe.read_exactly got num_values <= 0\" (num_values : int)];\n Deferred.create (fun finish ->\n let result = Queue.create () in\n let rec loop () =\n let already_read = Queue.length result in\n assert (already_read <= num_values);\n if already_read = num_values\n then Ivar.fill finish (`Exactly result)\n else\n read' ?consumer t ~max_queue_length:(num_values - already_read)\n >>> function\n | `Eof -> Ivar.fill finish (if already_read = 0 then `Eof else `Fewer result)\n | `Ok q ->\n Queue.blit_transfer ~src:q ~dst:result ();\n loop ()\n in\n loop ())\n;;\n\nlet downstream_flushed t =\n if is_empty t\n then\n if List.is_empty t.consumers\n then return `Ok\n else\n Flushed_result.combine\n (List.map t.consumers ~f:Consumer.values_sent_downstream_and_flushed)\n else\n (* [t] might be closed. But the read end can't be closed, because if it were, then\n [t] would be empty. If the write end is closed but not the read end, then we want\n to enqueue a blocked flush because the enqueued values may get read. *)\n Deferred.create (fun ready ->\n Queue.enqueue\n t.blocked_flushes\n { fill_when_num_values_read = t.num_values_read + length t; ready })\n;;\n\n(* In practice, along with [Link.create] and [add_upstream_flushed], [upstream_flushed]\n traverses the graph of linked pipes up to the heads and then calls [downstream_flushed]\n on them. *)\nlet upstream_flushed t =\n if Bag.is_empty t.upstream_flusheds\n then downstream_flushed t\n else\n Bag.to_list t.upstream_flusheds\n |> List.map ~f:(fun f -> f ())\n |> Flushed_result.combine\n;;\n\nlet add_upstream_flushed t upstream_flushed =\n Bag.add t.upstream_flusheds upstream_flushed\n;;\n\nlet add_consumer t ~downstream_flushed =\n let consumer = Consumer.create ~pipe_id:t.id ~downstream_flushed in\n t.consumers <- consumer :: t.consumers;\n consumer\n;;\n\n(* A [Link.t] links flushing of two pipes together. *)\nmodule Link : sig\n type t\n\n val create : upstream:(_, _) pipe -> downstream:(_, _) pipe -> t\n val consumer : t -> Consumer.t\n\n (* [unlink_upstream] removes downstream's reference to upstream. *)\n\n val unlink_upstream : t -> unit\nend = struct\n type ('a, 'b) unpacked =\n { downstream : ('a, 'b) t\n ; consumer : Consumer.t\n ; upstream_flusheds_bag_elt : (unit -> Flushed_result.t Deferred.t) Bag.Elt.t\n }\n\n type t = T : (_, _) unpacked -> t\n\n let consumer (T t) = t.consumer\n\n let create ~upstream ~downstream =\n T\n { downstream\n ; consumer =\n add_consumer upstream ~downstream_flushed:(fun () ->\n downstream_flushed downstream)\n ; upstream_flusheds_bag_elt =\n add_upstream_flushed downstream (fun () -> upstream_flushed upstream)\n }\n ;;\n\n let unlink_upstream (T t) =\n Bag.remove t.downstream.upstream_flusheds t.upstream_flusheds_bag_elt\n ;;\nend\n\nmodule Flushed = struct\n type t =\n | Consumer of Consumer.t\n | When_value_processed\n | When_value_read\n [@@deriving sexp_of]\nend\n\nlet fold_gen\n (read_now : ?consumer:Consumer.t -> _ Reader.t -> _)\n ?(flushed = Flushed.When_value_read)\n t\n ~init\n ~f\n =\n let consumer =\n match flushed with\n | When_value_read -> None\n | Consumer consumer -> Some consumer\n | When_value_processed ->\n (* The fact that \"no consumer\" behaves different from \"trivial consumer\" is weird,\n but that's how the consumer machinery works. *)\n Some (add_consumer t ~downstream_flushed:(fun () -> return `Ok))\n in\n if !check_invariant then invariant t;\n ensure_consumer_matches t ?consumer;\n Deferred.create (fun finished ->\n (* We do [return () >>>] to ensure that [f] is only called asynchronously. *)\n return ()\n >>> fun () ->\n let rec loop b =\n match read_now t ?consumer with\n | `Eof -> Ivar.fill finished b\n | `Ok v -> f b v continue\n | `Nothing_available -> values_available t >>> fun _ -> loop b\n and continue b =\n Option.iter consumer ~f:Consumer.values_sent_downstream;\n loop b\n in\n loop init)\n;;\n\nlet fold' ?flushed ?max_queue_length t ~init ~f =\n fold_gen (read_now' ?max_queue_length) ?flushed t ~init ~f:(fun b q loop ->\n f b q >>> loop)\n;;\n\nlet fold ?flushed t ~init ~f =\n fold_gen read_now ?flushed t ~init ~f:(fun b a loop -> f b a >>> loop)\n;;\n\nlet fold_without_pushback ?consumer t ~init ~f =\n fold_gen\n read_now\n t\n ~init\n ~f:(fun b a loop -> loop (f b a))\n ?flushed:\n (match consumer with\n | None -> None\n | Some c -> Some (Consumer c))\n;;\n\nlet with_error_to_current_monitor ?(continue_on_error = false) f a =\n if not continue_on_error\n then f a\n else (\n match%map Monitor.try_with (fun () -> f a) with\n | Ok () -> ()\n | Error exn -> Monitor.send_exn (Monitor.current ()) (Monitor.extract_exn exn))\n;;\n\nlet iter' ?continue_on_error ?flushed ?max_queue_length t ~f =\n fold' ?max_queue_length ?flushed t ~init:() ~f:(fun () q ->\n with_error_to_current_monitor ?continue_on_error f q)\n;;\n\nlet iter ?continue_on_error ?flushed t ~f =\n fold_gen read_now ?flushed t ~init:() ~f:(fun () a loop ->\n with_error_to_current_monitor ?continue_on_error f a >>> fun () -> loop ())\n;;\n\n(* [iter_without_pushback] is a common case, so we implement it in an optimized manner,\n rather than via [iter]. The implementation reads only one element at a time, so that\n if [f] closes [t] or raises, no more elements will be read. *)\nlet iter_without_pushback\n ?consumer\n ?(continue_on_error = false)\n ?max_iterations_per_job\n t\n ~f\n =\n ensure_consumer_matches t ?consumer;\n let max_iterations_per_job =\n match max_iterations_per_job with\n | None -> Int.max_value\n | Some max_iterations_per_job ->\n if max_iterations_per_job <= 0\n then\n raise_s\n [%message\n \"iter_without_pushback got non-positive max_iterations_per_job\"\n (max_iterations_per_job : int)];\n max_iterations_per_job\n in\n let f =\n if not continue_on_error\n then f\n else\n fun a ->\n try f a with\n | exn -> Monitor.send_exn (Monitor.current ()) exn\n in\n Deferred.create (fun finished ->\n (* We do [return () >>>] to ensure that [f] is only called asynchronously. *)\n return ()\n >>> fun () ->\n let rec start () = loop ~remaining:max_iterations_per_job\n and loop ~remaining =\n if remaining = 0\n then return () >>> fun () -> start ()\n else (\n match read_now t ?consumer with\n | `Eof -> Ivar.fill finished ()\n | `Ok a ->\n f a;\n loop ~remaining:(remaining - 1)\n | `Nothing_available -> values_available t >>> fun _ -> start ())\n in\n start ())\n;;\n\nlet drain t = iter' t ~f:(fun _ -> return ())\nlet drain_and_count t = fold' t ~init:0 ~f:(fun sum q -> return (sum + Queue.length q))\n\nlet read_all input =\n let result = Queue.create () in\n let%map () =\n iter' input ~f:(fun q ->\n Queue.blit_transfer ~src:q ~dst:result ();\n return ())\n in\n result\n;;\n\nlet to_list r = read_all r >>| Queue.to_list\n\nlet to_stream_deprecated t =\n Stream.create (fun tail ->\n iter_without_pushback t ~f:(fun x -> Tail.extend tail x)\n >>> fun () -> Tail.close_exn tail)\n;;\n\n(* The implementation of [of_stream_deprecated] does as much batching as possible. It\n grabs as many items as are available into an internal queue. Once it has grabbed\n everything, it writes it to the pipe and then blocks waiting for the next element from\n the stream.\n\n There's no possibility that we'll starve the pipe reading an endless stream, just\n accumulating the elements into our private queue forever without ever writing them\n downstream to the pipe. Why? because while we're running, the stream-producer *isn't*\n running -- there are no Async block points in the queue-accumulator loop. So the\n queue-accumulator loop will eventually catch up to the current stream tail, at which\n point we'll do the pipe-write and then block on the stream... thus giving the\n stream-producer a chance to make more elements.\n\n One can't implement [of_stream] using [Stream.iter] or [Stream.iter'] because you\n need to be able to stop early when the consumer closes the pipe. Also, using either\n of those would entail significantly more deferred overhead, whereas the below\n implementation uses a deferred only when it needs to wait for data from the stream. *)\nlet of_stream_deprecated s =\n let r, w = create () in\n let q = Queue.create () in\n let transfer () =\n if not (Queue.is_empty q)\n then\n (* Can not pushback on the stream, so ignore the pushback on the pipe. *)\n don't_wait_for (write' w q)\n in\n let rec loop s =\n assert (not (is_closed w));\n let next_deferred = Stream.next s in\n match Deferred.peek next_deferred with\n | Some next -> loop_next next\n | None ->\n transfer ();\n upon next_deferred check_closed_loop_next\n and check_closed_loop_next next = if not (is_closed w) then loop_next next\n and loop_next = function\n | Nil ->\n transfer ();\n close w\n | Cons (x, s) ->\n Queue.enqueue q x;\n loop s\n in\n loop s;\n r\n;;\n\nlet transfer_gen\n (read_now : ?consumer:Consumer.t -> _ Reader.t -> _)\n write\n input\n output\n ~f\n =\n if !check_invariant\n then (\n invariant input;\n invariant output);\n let link = Link.create ~upstream:input ~downstream:output in\n let consumer = Link.consumer link in\n (* When we're done with [input], we unlink to remove pointers from\n [output] to [input], which would cause a space leak if we had single long-lived\n output into which we transfer lots of short-lived inputs. *)\n let unlink () = Link.unlink_upstream link in\n Deferred.create (fun result ->\n (* We do [return () >>>] to ensure that [f] is only called asynchronously. *)\n return ()\n >>> fun () ->\n let output_closed () =\n close_read input;\n unlink ();\n Ivar.fill result ()\n in\n let rec loop () =\n if is_closed output\n then output_closed ()\n else (\n match read_now input ~consumer with\n | `Eof ->\n unlink ();\n Ivar.fill result ()\n | `Ok x -> f x continue\n | `Nothing_available ->\n choose\n [ choice (values_available input) ignore; choice (closed output) ignore ]\n >>> fun () -> loop ())\n and continue y =\n if is_closed output\n then output_closed ()\n else (\n let pushback = write output y in\n Consumer.values_sent_downstream consumer;\n pushback >>> fun () -> loop ())\n in\n loop ())\n;;\n\nlet transfer' ?max_queue_length input output ~f =\n transfer_gen (read_now' ?max_queue_length) write' input output ~f:(fun q k ->\n f q >>> k)\n;;\n\nlet transfer input output ~f =\n transfer_gen read_now write input output ~f:(fun a k -> k (f a))\n;;\n\nlet transfer_id ?max_queue_length input output =\n transfer_gen (read_now' ?max_queue_length) write' input output ~f:(fun q k -> k q)\n;;\n\nlet map_gen read write input ~f =\n let info = Option.map input.info ~f:(fun info -> [%sexp Mapped (info : Sexp.t)]) in\n let result, output = create ?info () in\n upon (transfer_gen read write input output ~f) (fun () -> close output);\n result\n;;\n\nlet map' ?max_queue_length input ~f =\n map_gen (read_now' ?max_queue_length) write' input ~f:(fun q k -> f q >>> k)\n;;\n\nlet map input ~f = map_gen read_now write input ~f:(fun a k -> k (f a))\n\nlet filter_map' ?max_queue_length input ~f =\n map' ?max_queue_length input ~f:(fun q -> Deferred.Queue.filter_map q ~f)\n;;\n\nlet filter_map ?max_queue_length input ~f =\n map_gen (read_now' ?max_queue_length) write' input ~f:(fun q k ->\n k (Queue.filter_map q ~f:(fun x -> if is_read_closed input then None else f x)))\n;;\n\nlet folding_filter_map' ?max_queue_length input ~init ~f =\n let accum = ref init in\n filter_map' ?max_queue_length input ~f:(fun x ->\n let%map a, x = f !accum x in\n accum := a;\n x)\n;;\n\nlet folding_filter_map ?max_queue_length input ~init ~f =\n let accum = ref init in\n filter_map ?max_queue_length input ~f:(fun x ->\n let a, x = f !accum x in\n accum := a;\n x)\n;;\n\nlet folding_map ?max_queue_length input ~init ~f =\n folding_filter_map ?max_queue_length input ~init ~f:(fun accum a ->\n let accum, b = f accum a in\n accum, Some b)\n;;\n\nlet filter input ~f = filter_map input ~f:(fun x -> if f x then Some x else None)\n\nlet of_list l =\n let t = create_internal ~info:None ~initial_buffer:(Queue.of_list l) in\n Ivar.fill t.closed ();\n update_pushback t;\n t\n;;\n\nlet empty () = of_list []\n\nlet singleton x =\n let reader, writer = create () in\n write_without_pushback writer x;\n close writer;\n reader\n;;\n\nlet unfold ~init:s ~f =\n (* To get some batching, we run the continuation immediately if the deferred is\n determined. However, we always check for pushback. Because size budget can't be\n infinite, the below loop is guaranteed to eventually yield to the scheduler. *)\n let ( >>=~ ) d f =\n match Deferred.peek d with\n | None -> d >>= f\n | Some x -> f x\n in\n create_reader ~close_on_exception:false (fun writer ->\n let rec loop s =\n f s\n >>=~ function\n | None -> return ()\n | Some (a, s) ->\n if is_closed writer then return () else write writer a >>=~ fun () -> loop s\n in\n loop s)\n;;\n\nlet of_sequence sequence =\n create_reader ~close_on_exception:false (fun writer ->\n let rec enqueue_n sequence i =\n if i <= 0\n then sequence\n else (\n match Sequence.next sequence with\n | None -> sequence\n | Some (a, sequence) ->\n Queue.enqueue writer.buffer a;\n enqueue_n sequence (i - 1))\n in\n let rec loop sequence =\n if is_closed writer || Sequence.is_empty sequence\n then return ()\n else (\n start_write writer;\n let sequence = enqueue_n sequence (1 + writer.size_budget - length writer) in\n finish_write writer;\n let%bind () = pushback writer in\n loop sequence)\n in\n loop sequence)\n;;\n\ntype 'a to_sequence_elt =\n | Value of 'a\n | Wait_for : _ Deferred.t -> _ to_sequence_elt\n\nlet to_sequence t =\n Sequence.unfold ~init:() ~f:(fun () ->\n match read_now t with\n | `Eof -> None\n | `Ok a -> Some (Value a, ())\n | `Nothing_available -> Some (Wait_for (values_available t), ()))\n;;\n\nlet interleave_pipe inputs =\n let output, output_writer = create ~info:[%sexp \"Pipe.interleave\"] () in\n (* We keep a reference count of all the pipes that [interleave_pipe] is managing;\n [inputs] counts as one. When the reference count drops to zero, we know that all\n pipes are closed and we can close [output_writer]. *)\n let num_pipes_remaining = ref 1 in\n let decr_num_pipes_remaining () =\n decr num_pipes_remaining;\n if !num_pipes_remaining = 0 then close output_writer\n in\n don't_wait_for\n (let%map () =\n iter_without_pushback inputs ~f:(fun input ->\n incr num_pipes_remaining;\n don't_wait_for\n (let%map () = transfer_id input output_writer in\n decr_num_pipes_remaining ()))\n in\n decr_num_pipes_remaining ());\n (* for [inputs] *)\n output\n;;\n\nlet interleave inputs =\n if !check_invariant then List.iter inputs ~f:invariant;\n interleave_pipe (of_list inputs)\n;;\n\nlet merge inputs ~compare =\n match inputs with\n | [] -> empty ()\n | [ input ] -> input\n | inputs ->\n let module Heap = Pairing_heap in\n let r, w = create () in\n upon (closed w) (fun () -> List.iter inputs ~f:close_read);\n let heap = Heap.create ~cmp:(fun (a1, _) (a2, _) -> compare a1 a2) () in\n let handle_read input eof_or_ok =\n match eof_or_ok with\n | `Eof -> ()\n | `Ok v -> Heap.add heap (v, input)\n in\n let rec pop_heap_and_loop () =\n (* At this point, all inputs not at Eof occur in [heap] exactly once, so we know\n what the next output element is. [pop_heap_and_loop] repeatedly takes elements\n from the inputs as long as it has one from each input. This is done\n synchronously to avoid the cost of a deferred for each element of the output --\n there's no need to pushback since that is only moving elements from one pipe to\n another. As soon as [pop_heap_and_loop] can't get an element from some input, it\n waits on pushback from the output, since it has to wait on the input anyway.\n This also prevents [merge] from consuming inputs at a rate faster than its output\n is consumed. *)\n match Heap.pop heap with\n | None -> close w\n | Some (v, input) ->\n if not (is_closed w)\n then (\n write_without_pushback w v;\n if Heap.length heap = 0\n then upon (transfer_id input w) (fun () -> close w)\n else (\n match read_now input with\n | (`Eof | `Ok _) as x ->\n handle_read input x;\n pop_heap_and_loop ()\n | `Nothing_available ->\n pushback w\n >>> fun () ->\n read input\n >>> fun x ->\n handle_read input x;\n pop_heap_and_loop ()))\n in\n let initial_push =\n Deferred.List.iter inputs ~f:(fun input ->\n let%map x = read input in\n handle_read input x)\n in\n upon initial_push pop_heap_and_loop;\n r\n;;\n\nlet concat_pipe inputs =\n let r =\n create_reader_not_close_on_exception (fun w ->\n let link = Link.create ~upstream:inputs ~downstream:w in\n let consumer = Link.consumer link in\n iter ~flushed:(Consumer consumer) inputs ~f:(fun input -> transfer_id input w))\n in\n upon (closed r) (fun () -> close inputs);\n r\n;;\n\nlet concat inputs =\n create_reader_not_close_on_exception (fun w ->\n Deferred.List.iter inputs ~f:(fun input -> transfer_id input w))\n;;\n\nlet fork t ~pushback_uses =\n let reader0, writer0 = create () in\n let reader1, writer1 = create () in\n let some_reader_was_closed = ref false in\n let consumer =\n add_consumer t ~downstream_flushed:(fun () ->\n let some_reader_was_closed = !some_reader_was_closed in\n match%map\n Flushed_result.combine\n [ downstream_flushed writer0; downstream_flushed writer1 ]\n with\n | `Reader_closed -> `Reader_closed\n | `Ok ->\n (* In this case, there could have been no pending items in [writer0] nor in\n [writer1], in which case we could have had a closed pipe that missed some\n writes, but [Flushed_result.combine] would still have returned [`Ok] *)\n if some_reader_was_closed then `Reader_closed else `Ok)\n in\n don't_wait_for\n (let still_open = [ writer0; writer1 ] in\n let filter_open still_open =\n (* Only call [filter] and reallocate list if something will get filtered *)\n if not (List.exists still_open ~f:is_closed)\n then still_open\n else (\n some_reader_was_closed := true;\n let still_open = List.filter still_open ~f:(fun w -> not (is_closed w)) in\n if List.is_empty still_open then close t;\n still_open)\n in\n let%bind still_open =\n fold' t ~flushed:(Consumer consumer) ~init:still_open ~f:(fun still_open queue ->\n let still_open = filter_open still_open in\n if List.is_empty still_open\n then return []\n else (\n let%map () =\n match pushback_uses with\n | `Fast_consumer_only -> Deferred.any (List.map still_open ~f:pushback)\n | `Both_consumers -> Deferred.all_unit (List.map still_open ~f:pushback)\n in\n let still_open = filter_open still_open in\n List.iter still_open ~f:(fun w -> copy_in_without_pushback w ~from:queue);\n still_open))\n in\n List.iter still_open ~f:close;\n return ());\n reader0, reader1\n;;\n\nlet set_info t info = set_info t (Some info)\n","open! Import\nmodule Int = Int0\nmodule Sys = Sys0\n\nlet convert_failure x a b to_string =\n Printf.failwithf\n \"conversion from %s to %s failed: %s is out of range\"\n a\n b\n (to_string x)\n ()\n[@@cold] [@@inline never] [@@local never] [@@specialise never]\n;;\n\nlet num_bits_int = Sys.int_size_in_bits\nlet num_bits_int32 = 32\nlet num_bits_int64 = 64\nlet num_bits_nativeint = Word_size.num_bits Word_size.word_size\nlet () = assert (num_bits_int = 63 || num_bits_int = 31 || num_bits_int = 32)\nlet min_int32 = Caml.Int32.min_int\nlet max_int32 = Caml.Int32.max_int\nlet min_int64 = Caml.Int64.min_int\nlet max_int64 = Caml.Int64.max_int\nlet min_nativeint = Caml.Nativeint.min_int\nlet max_nativeint = Caml.Nativeint.max_int\nlet int_to_string = Caml.string_of_int\nlet int32_to_string = Caml.Int32.to_string\nlet int64_to_string = Caml.Int64.to_string\nlet nativeint_to_string = Caml.Nativeint.to_string\n\n(* int <-> int32 *)\n\nlet int_to_int32_failure x = convert_failure x \"int\" \"int32\" int_to_string\nlet int32_to_int_failure x = convert_failure x \"int32\" \"int\" int32_to_string\nlet int32_to_int_trunc = Caml.Int32.to_int\nlet int_to_int32_trunc = Caml.Int32.of_int\n\nlet int_is_representable_as_int32 =\n if num_bits_int <= num_bits_int32\n then fun _ -> true\n else (\n let min = int32_to_int_trunc min_int32 in\n let max = int32_to_int_trunc max_int32 in\n fun x -> compare_int min x <= 0 && compare_int x max <= 0)\n;;\n\nlet int32_is_representable_as_int =\n if num_bits_int32 <= num_bits_int\n then fun _ -> true\n else (\n let min = int_to_int32_trunc Int.min_value in\n let max = int_to_int32_trunc Int.max_value in\n fun x -> compare_int32 min x <= 0 && compare_int32 x max <= 0)\n;;\n\nlet int_to_int32 x =\n if int_is_representable_as_int32 x then Some (int_to_int32_trunc x) else None\n;;\n\nlet int32_to_int x =\n if int32_is_representable_as_int x then Some (int32_to_int_trunc x) else None\n;;\n\nlet int_to_int32_exn x =\n if int_is_representable_as_int32 x\n then int_to_int32_trunc x\n else int_to_int32_failure x\n;;\n\nlet int32_to_int_exn x =\n if int32_is_representable_as_int x\n then int32_to_int_trunc x\n else int32_to_int_failure x\n;;\n\n(* int <-> int64 *)\n\nlet int64_to_int_failure x = convert_failure x \"int64\" \"int\" int64_to_string\nlet () = assert (num_bits_int < num_bits_int64)\nlet int_to_int64 = Caml.Int64.of_int\nlet int64_to_int_trunc = Caml.Int64.to_int\n\nlet int64_is_representable_as_int =\n let min = int_to_int64 Int.min_value in\n let max = int_to_int64 Int.max_value in\n fun x -> compare_int64 min x <= 0 && compare_int64 x max <= 0\n;;\n\nlet int64_to_int x =\n if int64_is_representable_as_int x then Some (int64_to_int_trunc x) else None\n;;\n\nlet int64_to_int_exn x =\n if int64_is_representable_as_int x\n then int64_to_int_trunc x\n else int64_to_int_failure x\n;;\n\n(* int <-> nativeint *)\n\nlet nativeint_to_int_failure x = convert_failure x \"nativeint\" \"int\" nativeint_to_string\nlet () = assert (num_bits_int <= num_bits_nativeint)\nlet int_to_nativeint = Caml.Nativeint.of_int\nlet nativeint_to_int_trunc = Caml.Nativeint.to_int\n\nlet nativeint_is_representable_as_int =\n if num_bits_nativeint <= num_bits_int\n then fun _ -> true\n else (\n let min = int_to_nativeint Int.min_value in\n let max = int_to_nativeint Int.max_value in\n fun x -> compare_nativeint min x <= 0 && compare_nativeint x max <= 0)\n;;\n\nlet nativeint_to_int x =\n if nativeint_is_representable_as_int x then Some (nativeint_to_int_trunc x) else None\n;;\n\nlet nativeint_to_int_exn x =\n if nativeint_is_representable_as_int x\n then nativeint_to_int_trunc x\n else nativeint_to_int_failure x\n;;\n\n(* int32 <-> int64 *)\n\nlet int64_to_int32_failure x = convert_failure x \"int64\" \"int32\" int64_to_string\nlet () = assert (num_bits_int32 < num_bits_int64)\nlet int32_to_int64 = Caml.Int64.of_int32\nlet int64_to_int32_trunc = Caml.Int64.to_int32\n\nlet int64_is_representable_as_int32 =\n let min = int32_to_int64 min_int32 in\n let max = int32_to_int64 max_int32 in\n fun x -> compare_int64 min x <= 0 && compare_int64 x max <= 0\n;;\n\nlet int64_to_int32 x =\n if int64_is_representable_as_int32 x then Some (int64_to_int32_trunc x) else None\n;;\n\nlet int64_to_int32_exn x =\n if int64_is_representable_as_int32 x\n then int64_to_int32_trunc x\n else int64_to_int32_failure x\n;;\n\n(* int32 <-> nativeint *)\n\nlet nativeint_to_int32_failure x =\n convert_failure x \"nativeint\" \"int32\" nativeint_to_string\n;;\n\nlet () = assert (num_bits_int32 <= num_bits_nativeint)\nlet int32_to_nativeint = Caml.Nativeint.of_int32\nlet nativeint_to_int32_trunc = Caml.Nativeint.to_int32\n\nlet nativeint_is_representable_as_int32 =\n if num_bits_nativeint <= num_bits_int32\n then fun _ -> true\n else (\n let min = int32_to_nativeint min_int32 in\n let max = int32_to_nativeint max_int32 in\n fun x -> compare_nativeint min x <= 0 && compare_nativeint x max <= 0)\n;;\n\nlet nativeint_to_int32 x =\n if nativeint_is_representable_as_int32 x\n then Some (nativeint_to_int32_trunc x)\n else None\n;;\n\nlet nativeint_to_int32_exn x =\n if nativeint_is_representable_as_int32 x\n then nativeint_to_int32_trunc x\n else nativeint_to_int32_failure x\n;;\n\n(* int64 <-> nativeint *)\n\nlet int64_to_nativeint_failure x = convert_failure x \"int64\" \"nativeint\" int64_to_string\nlet () = assert (num_bits_int64 >= num_bits_nativeint)\nlet int64_to_nativeint_trunc = Caml.Int64.to_nativeint\nlet nativeint_to_int64 = Caml.Int64.of_nativeint\n\nlet int64_is_representable_as_nativeint =\n if num_bits_int64 <= num_bits_nativeint\n then fun _ -> true\n else (\n let min = nativeint_to_int64 min_nativeint in\n let max = nativeint_to_int64 max_nativeint in\n fun x -> compare_int64 min x <= 0 && compare_int64 x max <= 0)\n;;\n\nlet int64_to_nativeint x =\n if int64_is_representable_as_nativeint x\n then Some (int64_to_nativeint_trunc x)\n else None\n;;\n\nlet int64_to_nativeint_exn x =\n if int64_is_representable_as_nativeint x\n then int64_to_nativeint_trunc x\n else int64_to_nativeint_failure x\n;;\n\n(* int64 <-> int63 *)\n\nlet int64_to_int63_failure x = convert_failure x \"int64\" \"int63\" int64_to_string\n\nlet int64_is_representable_as_int63 =\n let min = Caml.Int64.shift_right min_int64 1 in\n let max = Caml.Int64.shift_right max_int64 1 in\n fun x -> compare_int64 min x <= 0 && compare_int64 x max <= 0\n;;\n\nlet int64_fit_on_int63_exn x =\n if int64_is_representable_as_int63 x then () else int64_to_int63_failure x\n;;\n\n(* string conversions *)\n\nlet insert_delimiter_every input ~delimiter ~chars_per_delimiter =\n let input_length = String.length input in\n if input_length <= chars_per_delimiter\n then input\n else (\n let has_sign =\n match input.[0] with\n | '+' | '-' -> true\n | _ -> false\n in\n let num_digits = if has_sign then input_length - 1 else input_length in\n let num_delimiters = (num_digits - 1) / chars_per_delimiter in\n let output_length = input_length + num_delimiters in\n let output = Bytes.create output_length in\n let input_pos = ref (input_length - 1) in\n let output_pos = ref (output_length - 1) in\n let num_chars_until_delimiter = ref chars_per_delimiter in\n let first_digit_pos = if has_sign then 1 else 0 in\n while !input_pos >= first_digit_pos do\n if !num_chars_until_delimiter = 0\n then (\n Bytes.set output !output_pos delimiter;\n decr output_pos;\n num_chars_until_delimiter := chars_per_delimiter);\n Bytes.set output !output_pos input.[!input_pos];\n decr input_pos;\n decr output_pos;\n decr num_chars_until_delimiter\n done;\n if has_sign then Bytes.set output 0 input.[0];\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:output)\n;;\n\nlet insert_delimiter input ~delimiter =\n insert_delimiter_every input ~delimiter ~chars_per_delimiter:3\n;;\n\nlet insert_underscores input = insert_delimiter input ~delimiter:'_'\nlet sexp_of_int_style = Sexp.of_int_style\n\nmodule Make (I : sig\n type t\n\n val to_string : t -> string\n end) =\nstruct\n open I\n\n let chars_per_delimiter = 3\n\n let to_string_hum ?(delimiter = '_') t =\n insert_delimiter_every (to_string t) ~delimiter ~chars_per_delimiter\n ;;\n\n let sexp_of_t t =\n let s = to_string t in\n Sexp.Atom\n (match !sexp_of_int_style with\n | `Underscores -> insert_delimiter_every s ~chars_per_delimiter ~delimiter:'_'\n | `No_underscores -> s)\n ;;\nend\n\nmodule Make_hex (I : sig\n type t [@@deriving_inline compare, hash]\n\n val compare : t -> t -> int\n val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state\n val hash : t -> Ppx_hash_lib.Std.Hash.hash_value\n\n [@@@end]\n\n val to_string : t -> string\n val of_string : string -> t\n val zero : t\n val ( < ) : t -> t -> bool\n val neg : t -> t\n val module_name : string\n end) =\nstruct\n module T_hex = struct\n type t = I.t [@@deriving_inline compare, hash]\n\n let compare = (I.compare : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n I.hash_fold_t\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = I.hash in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let chars_per_delimiter = 4\n\n let to_string' ?delimiter t =\n let make_suffix =\n match delimiter with\n | None -> I.to_string\n | Some delimiter ->\n fun t -> insert_delimiter_every (I.to_string t) ~delimiter ~chars_per_delimiter\n in\n if I.( < ) t I.zero then \"-0x\" ^ make_suffix (I.neg t) else \"0x\" ^ make_suffix t\n ;;\n\n let to_string t = to_string' t ?delimiter:None\n let to_string_hum ?(delimiter = '_') t = to_string' t ~delimiter\n\n let invalid str =\n Printf.failwithf \"%s.of_string: invalid input %S\" I.module_name str ()\n ;;\n\n let of_string_with_delimiter str =\n I.of_string (String.filter str ~f:(fun c -> Char.( <> ) c '_'))\n ;;\n\n let of_string str =\n let module L = Hex_lexer in\n let lex = Caml.Lexing.from_string str in\n let result = Option.try_with (fun () -> L.parse_hex lex) in\n if lex.lex_curr_pos = lex.lex_buffer_len\n then (\n match result with\n | None -> invalid str\n | Some (Neg body) -> I.neg (of_string_with_delimiter body)\n | Some (Pos body) -> of_string_with_delimiter body)\n else invalid str\n ;;\n end\n\n module Hex = struct\n include T_hex\n include Sexpable.Of_stringable (T_hex)\n end\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* An alias for the type of lists. *)\ntype 'a t = 'a list = [] | (::) of 'a * 'a list\n\n(* List operations *)\n\nlet rec length_aux len = function\n [] -> len\n | _::l -> length_aux (len + 1) l\n\nlet length l = length_aux 0 l\n\nlet cons a l = a::l\n\nlet hd = function\n [] -> failwith \"hd\"\n | a::_ -> a\n\nlet tl = function\n [] -> failwith \"tl\"\n | _::l -> l\n\nlet nth l n =\n if n < 0 then invalid_arg \"List.nth\" else\n let rec nth_aux l n =\n match l with\n | [] -> failwith \"nth\"\n | a::l -> if n = 0 then a else nth_aux l (n-1)\n in nth_aux l n\n\nlet nth_opt l n =\n if n < 0 then invalid_arg \"List.nth\" else\n let rec nth_aux l n =\n match l with\n | [] -> None\n | a::l -> if n = 0 then Some a else nth_aux l (n-1)\n in nth_aux l n\n\nlet append = (@)\n\nlet rec rev_append l1 l2 =\n match l1 with\n [] -> l2\n | a :: l -> rev_append l (a :: l2)\n\nlet rev l = rev_append l []\n\nlet rec init_tailrec_aux acc i n f =\n if i >= n then acc\n else init_tailrec_aux (f i :: acc) (i+1) n f\n\nlet rec init_aux i n f =\n if i >= n then []\n else\n let r = f i in\n r :: init_aux (i+1) n f\n\nlet rev_init_threshold =\n match Sys.backend_type with\n | Sys.Native | Sys.Bytecode -> 10_000\n (* We don't know the size of the stack, better be safe and assume it's\n small. *)\n | Sys.Other _ -> 50\n\nlet init len f =\n if len < 0 then invalid_arg \"List.init\" else\n if len > rev_init_threshold then rev (init_tailrec_aux [] 0 len f)\n else init_aux 0 len f\n\nlet rec flatten = function\n [] -> []\n | l::r -> l @ flatten r\n\nlet concat = flatten\n\nlet rec map f = function\n [] -> []\n | a::l -> let r = f a in r :: map f l\n\nlet rec mapi i f = function\n [] -> []\n | a::l -> let r = f i a in r :: mapi (i + 1) f l\n\nlet mapi f l = mapi 0 f l\n\nlet rev_map f l =\n let rec rmap_f accu = function\n | [] -> accu\n | a::l -> rmap_f (f a :: accu) l\n in\n rmap_f [] l\n\n\nlet rec iter f = function\n [] -> ()\n | a::l -> f a; iter f l\n\nlet rec iteri i f = function\n [] -> ()\n | a::l -> f i a; iteri (i + 1) f l\n\nlet iteri f l = iteri 0 f l\n\nlet rec fold_left f accu l =\n match l with\n [] -> accu\n | a::l -> fold_left f (f accu a) l\n\nlet rec fold_right f l accu =\n match l with\n [] -> accu\n | a::l -> f a (fold_right f l accu)\n\nlet rec map2 f l1 l2 =\n match (l1, l2) with\n ([], []) -> []\n | (a1::l1, a2::l2) -> let r = f a1 a2 in r :: map2 f l1 l2\n | (_, _) -> invalid_arg \"List.map2\"\n\nlet rev_map2 f l1 l2 =\n let rec rmap2_f accu l1 l2 =\n match (l1, l2) with\n | ([], []) -> accu\n | (a1::l1, a2::l2) -> rmap2_f (f a1 a2 :: accu) l1 l2\n | (_, _) -> invalid_arg \"List.rev_map2\"\n in\n rmap2_f [] l1 l2\n\n\nlet rec iter2 f l1 l2 =\n match (l1, l2) with\n ([], []) -> ()\n | (a1::l1, a2::l2) -> f a1 a2; iter2 f l1 l2\n | (_, _) -> invalid_arg \"List.iter2\"\n\nlet rec fold_left2 f accu l1 l2 =\n match (l1, l2) with\n ([], []) -> accu\n | (a1::l1, a2::l2) -> fold_left2 f (f accu a1 a2) l1 l2\n | (_, _) -> invalid_arg \"List.fold_left2\"\n\nlet rec fold_right2 f l1 l2 accu =\n match (l1, l2) with\n ([], []) -> accu\n | (a1::l1, a2::l2) -> f a1 a2 (fold_right2 f l1 l2 accu)\n | (_, _) -> invalid_arg \"List.fold_right2\"\n\nlet rec for_all p = function\n [] -> true\n | a::l -> p a && for_all p l\n\nlet rec exists p = function\n [] -> false\n | a::l -> p a || exists p l\n\nlet rec for_all2 p l1 l2 =\n match (l1, l2) with\n ([], []) -> true\n | (a1::l1, a2::l2) -> p a1 a2 && for_all2 p l1 l2\n | (_, _) -> invalid_arg \"List.for_all2\"\n\nlet rec exists2 p l1 l2 =\n match (l1, l2) with\n ([], []) -> false\n | (a1::l1, a2::l2) -> p a1 a2 || exists2 p l1 l2\n | (_, _) -> invalid_arg \"List.exists2\"\n\nlet rec mem x = function\n [] -> false\n | a::l -> compare a x = 0 || mem x l\n\nlet rec memq x = function\n [] -> false\n | a::l -> a == x || memq x l\n\nlet rec assoc x = function\n [] -> raise Not_found\n | (a,b)::l -> if compare a x = 0 then b else assoc x l\n\nlet rec assoc_opt x = function\n [] -> None\n | (a,b)::l -> if compare a x = 0 then Some b else assoc_opt x l\n\nlet rec assq x = function\n [] -> raise Not_found\n | (a,b)::l -> if a == x then b else assq x l\n\nlet rec assq_opt x = function\n [] -> None\n | (a,b)::l -> if a == x then Some b else assq_opt x l\n\nlet rec mem_assoc x = function\n | [] -> false\n | (a, _) :: l -> compare a x = 0 || mem_assoc x l\n\nlet rec mem_assq x = function\n | [] -> false\n | (a, _) :: l -> a == x || mem_assq x l\n\nlet rec remove_assoc x = function\n | [] -> []\n | (a, _ as pair) :: l ->\n if compare a x = 0 then l else pair :: remove_assoc x l\n\nlet rec remove_assq x = function\n | [] -> []\n | (a, _ as pair) :: l -> if a == x then l else pair :: remove_assq x l\n\nlet rec find p = function\n | [] -> raise Not_found\n | x :: l -> if p x then x else find p l\n\nlet rec find_opt p = function\n | [] -> None\n | x :: l -> if p x then Some x else find_opt p l\n\nlet rec find_map f = function\n | [] -> None\n | x :: l ->\n begin match f x with\n | Some _ as result -> result\n | None -> find_map f l\n end\n\nlet find_all p =\n let rec find accu = function\n | [] -> rev accu\n | x :: l -> if p x then find (x :: accu) l else find accu l in\n find []\n\nlet filter = find_all\n\nlet filteri p l =\n let rec aux i acc = function\n | [] -> rev acc\n | x::l -> aux (i + 1) (if p i x then x::acc else acc) l\n in\n aux 0 [] l\n\nlet filter_map f =\n let rec aux accu = function\n | [] -> rev accu\n | x :: l ->\n match f x with\n | None -> aux accu l\n | Some v -> aux (v :: accu) l\n in\n aux []\n\nlet concat_map f l =\n let rec aux f acc = function\n | [] -> rev acc\n | x :: l ->\n let xs = f x in\n aux f (rev_append xs acc) l\n in aux f [] l\n\nlet fold_left_map f accu l =\n let rec aux accu l_accu = function\n | [] -> accu, rev l_accu\n | x :: l ->\n let accu, x = f accu x in\n aux accu (x :: l_accu) l in\n aux accu [] l\n\nlet partition p l =\n let rec part yes no = function\n | [] -> (rev yes, rev no)\n | x :: l -> if p x then part (x :: yes) no l else part yes (x :: no) l in\n part [] [] l\n\nlet partition_map p l =\n let rec part left right = function\n | [] -> (rev left, rev right)\n | x :: l ->\n begin match p x with\n | Either.Left v -> part (v :: left) right l\n | Either.Right v -> part left (v :: right) l\n end\n in\n part [] [] l\n\nlet rec split = function\n [] -> ([], [])\n | (x,y)::l ->\n let (rx, ry) = split l in (x::rx, y::ry)\n\nlet rec combine l1 l2 =\n match (l1, l2) with\n ([], []) -> []\n | (a1::l1, a2::l2) -> (a1, a2) :: combine l1 l2\n | (_, _) -> invalid_arg \"List.combine\"\n\n(** sorting *)\n\nlet rec merge cmp l1 l2 =\n match l1, l2 with\n | [], l2 -> l2\n | l1, [] -> l1\n | h1 :: t1, h2 :: t2 ->\n if cmp h1 h2 <= 0\n then h1 :: merge cmp t1 l2\n else h2 :: merge cmp l1 t2\n\n\nlet stable_sort cmp l =\n let rec rev_merge l1 l2 accu =\n match l1, l2 with\n | [], l2 -> rev_append l2 accu\n | l1, [] -> rev_append l1 accu\n | h1::t1, h2::t2 ->\n if cmp h1 h2 <= 0\n then rev_merge t1 l2 (h1::accu)\n else rev_merge l1 t2 (h2::accu)\n in\n let rec rev_merge_rev l1 l2 accu =\n match l1, l2 with\n | [], l2 -> rev_append l2 accu\n | l1, [] -> rev_append l1 accu\n | h1::t1, h2::t2 ->\n if cmp h1 h2 > 0\n then rev_merge_rev t1 l2 (h1::accu)\n else rev_merge_rev l1 t2 (h2::accu)\n in\n let rec sort n l =\n match n, l with\n | 2, x1 :: x2 :: tl ->\n let s = if cmp x1 x2 <= 0 then [x1; x2] else [x2; x1] in\n (s, tl)\n | 3, x1 :: x2 :: x3 :: tl ->\n let s =\n if cmp x1 x2 <= 0 then\n if cmp x2 x3 <= 0 then [x1; x2; x3]\n else if cmp x1 x3 <= 0 then [x1; x3; x2]\n else [x3; x1; x2]\n else if cmp x1 x3 <= 0 then [x2; x1; x3]\n else if cmp x2 x3 <= 0 then [x2; x3; x1]\n else [x3; x2; x1]\n in\n (s, tl)\n | n, l ->\n let n1 = n asr 1 in\n let n2 = n - n1 in\n let s1, l2 = rev_sort n1 l in\n let s2, tl = rev_sort n2 l2 in\n (rev_merge_rev s1 s2 [], tl)\n and rev_sort n l =\n match n, l with\n | 2, x1 :: x2 :: tl ->\n let s = if cmp x1 x2 > 0 then [x1; x2] else [x2; x1] in\n (s, tl)\n | 3, x1 :: x2 :: x3 :: tl ->\n let s =\n if cmp x1 x2 > 0 then\n if cmp x2 x3 > 0 then [x1; x2; x3]\n else if cmp x1 x3 > 0 then [x1; x3; x2]\n else [x3; x1; x2]\n else if cmp x1 x3 > 0 then [x2; x1; x3]\n else if cmp x2 x3 > 0 then [x2; x3; x1]\n else [x3; x2; x1]\n in\n (s, tl)\n | n, l ->\n let n1 = n asr 1 in\n let n2 = n - n1 in\n let s1, l2 = sort n1 l in\n let s2, tl = sort n2 l2 in\n (rev_merge s1 s2 [], tl)\n in\n let len = length l in\n if len < 2 then l else fst (sort len l)\n\n\nlet sort = stable_sort\nlet fast_sort = stable_sort\n\n(* Note: on a list of length between about 100000 (depending on the minor\n heap size and the type of the list) and Sys.max_array_size, it is\n actually faster to use the following, but it might also use more memory\n because the argument list cannot be deallocated incrementally.\n\n Also, there seems to be a bug in this code or in the\n implementation of obj_truncate.\n\nexternal obj_truncate : 'a array -> int -> unit = \"caml_obj_truncate\"\n\nlet array_to_list_in_place a =\n let l = Array.length a in\n let rec loop accu n p =\n if p <= 0 then accu else begin\n if p = n then begin\n obj_truncate a p;\n loop (a.(p-1) :: accu) (n-1000) (p-1)\n end else begin\n loop (a.(p-1) :: accu) n (p-1)\n end\n end\n in\n loop [] (l-1000) l\n\n\nlet stable_sort cmp l =\n let a = Array.of_list l in\n Array.stable_sort cmp a;\n array_to_list_in_place a\n\n*)\n\n\n(** sorting + removing duplicates *)\n\nlet sort_uniq cmp l =\n let rec rev_merge l1 l2 accu =\n match l1, l2 with\n | [], l2 -> rev_append l2 accu\n | l1, [] -> rev_append l1 accu\n | h1::t1, h2::t2 ->\n let c = cmp h1 h2 in\n if c = 0 then rev_merge t1 t2 (h1::accu)\n else if c < 0\n then rev_merge t1 l2 (h1::accu)\n else rev_merge l1 t2 (h2::accu)\n in\n let rec rev_merge_rev l1 l2 accu =\n match l1, l2 with\n | [], l2 -> rev_append l2 accu\n | l1, [] -> rev_append l1 accu\n | h1::t1, h2::t2 ->\n let c = cmp h1 h2 in\n if c = 0 then rev_merge_rev t1 t2 (h1::accu)\n else if c > 0\n then rev_merge_rev t1 l2 (h1::accu)\n else rev_merge_rev l1 t2 (h2::accu)\n in\n let rec sort n l =\n match n, l with\n | 2, x1 :: x2 :: tl ->\n let s =\n let c = cmp x1 x2 in\n if c = 0 then [x1] else if c < 0 then [x1; x2] else [x2; x1]\n in\n (s, tl)\n | 3, x1 :: x2 :: x3 :: tl ->\n let s =\n let c = cmp x1 x2 in\n if c = 0 then\n let c = cmp x2 x3 in\n if c = 0 then [x2] else if c < 0 then [x2; x3] else [x3; x2]\n else if c < 0 then\n let c = cmp x2 x3 in\n if c = 0 then [x1; x2]\n else if c < 0 then [x1; x2; x3]\n else\n let c = cmp x1 x3 in\n if c = 0 then [x1; x2]\n else if c < 0 then [x1; x3; x2]\n else [x3; x1; x2]\n else\n let c = cmp x1 x3 in\n if c = 0 then [x2; x1]\n else if c < 0 then [x2; x1; x3]\n else\n let c = cmp x2 x3 in\n if c = 0 then [x2; x1]\n else if c < 0 then [x2; x3; x1]\n else [x3; x2; x1]\n in\n (s, tl)\n | n, l ->\n let n1 = n asr 1 in\n let n2 = n - n1 in\n let s1, l2 = rev_sort n1 l in\n let s2, tl = rev_sort n2 l2 in\n (rev_merge_rev s1 s2 [], tl)\n and rev_sort n l =\n match n, l with\n | 2, x1 :: x2 :: tl ->\n let s =\n let c = cmp x1 x2 in\n if c = 0 then [x1] else if c > 0 then [x1; x2] else [x2; x1]\n in\n (s, tl)\n | 3, x1 :: x2 :: x3 :: tl ->\n let s =\n let c = cmp x1 x2 in\n if c = 0 then\n let c = cmp x2 x3 in\n if c = 0 then [x2] else if c > 0 then [x2; x3] else [x3; x2]\n else if c > 0 then\n let c = cmp x2 x3 in\n if c = 0 then [x1; x2]\n else if c > 0 then [x1; x2; x3]\n else\n let c = cmp x1 x3 in\n if c = 0 then [x1; x2]\n else if c > 0 then [x1; x3; x2]\n else [x3; x1; x2]\n else\n let c = cmp x1 x3 in\n if c = 0 then [x2; x1]\n else if c > 0 then [x2; x1; x3]\n else\n let c = cmp x2 x3 in\n if c = 0 then [x2; x1]\n else if c > 0 then [x2; x3; x1]\n else [x3; x2; x1]\n in\n (s, tl)\n | n, l ->\n let n1 = n asr 1 in\n let n2 = n - n1 in\n let s1, l2 = sort n1 l in\n let s2, tl = sort n2 l2 in\n (rev_merge s1 s2 [], tl)\n in\n let len = length l in\n if len < 2 then l else fst (sort len l)\n\n\nlet rec compare_lengths l1 l2 =\n match l1, l2 with\n | [], [] -> 0\n | [], _ -> -1\n | _, [] -> 1\n | _ :: l1, _ :: l2 -> compare_lengths l1 l2\n;;\n\nlet rec compare_length_with l n =\n match l with\n | [] ->\n if n = 0 then 0 else\n if n > 0 then -1 else 1\n | _ :: l ->\n if n <= 0 then 1 else\n compare_length_with l (n-1)\n;;\n\n(** {1 Comparison} *)\n\n(* Note: we are *not* shortcutting the list by using\n [List.compare_lengths] first; this may be slower on long lists\n immediately start with distinct elements. It is also incorrect for\n [compare] below, and it is better (principle of least surprise) to\n use the same approach for both functions. *)\nlet rec equal eq l1 l2 =\n match l1, l2 with\n | [], [] -> true\n | [], _::_ | _::_, [] -> false\n | a1::l1, a2::l2 -> eq a1 a2 && equal eq l1 l2\n\nlet rec compare cmp l1 l2 =\n match l1, l2 with\n | [], [] -> 0\n | [], _::_ -> -1\n | _::_, [] -> 1\n | a1::l1, a2::l2 ->\n let c = cmp a1 a2 in\n if c <> 0 then c\n else compare cmp l1 l2\n\n(** {1 Iterators} *)\n\nlet to_seq l =\n let rec aux l () = match l with\n | [] -> Seq.Nil\n | x :: tail -> Seq.Cons (x, aux tail)\n in\n aux l\n\nlet of_seq seq =\n let rec direct depth seq : _ list =\n if depth=0\n then\n Seq.fold_left (fun acc x -> x::acc) [] seq\n |> rev (* tailrec *)\n else match seq() with\n | Seq.Nil -> []\n | Seq.Cons (x, next) -> x :: direct (depth-1) next\n in\n direct 500 seq\n","include Base\ninclude Ppxlib\ninclude Ast_builder.Default\n\n(* errors and error messages *)\n\nlet ( ^^ ) = Caml.( ^^ )\nlet error ~loc fmt = Location.raise_errorf ~loc (\"ppx_quickcheck: \" ^^ fmt)\nlet invalid ~loc fmt = error ~loc (\"invalid syntax: \" ^^ fmt)\nlet unsupported ~loc fmt = error ~loc (\"unsupported: \" ^^ fmt)\nlet internal_error ~loc fmt = error ~loc (\"internal error: \" ^^ fmt)\n\nlet short_string_of_core_type core_type =\n match core_type.ptyp_desc with\n | Ptyp_any -> \"wildcard type\"\n | Ptyp_var _ -> \"type variable\"\n | Ptyp_arrow _ -> \"function type\"\n | Ptyp_tuple _ -> \"tuple type\"\n | Ptyp_constr _ -> \"type name\"\n | Ptyp_object _ -> \"object type\"\n | Ptyp_class _ -> \"class type\"\n | Ptyp_alias _ -> \"type variable alias\"\n | Ptyp_variant _ -> \"polymorphic variant\"\n | Ptyp_poly _ -> \"explicit polymorphic type\"\n | Ptyp_package _ -> \"first-class module type\"\n | Ptyp_extension _ -> \"ppx extension type\"\n;;\n\n(* little syntax helpers *)\n\nlet loc_map { loc; txt } ~f = { loc; txt = f txt }\nlet lident_loc = loc_map ~f:lident\n\nlet prefixed_type_name prefix type_name =\n match type_name with\n | \"t\" -> prefix\n | _ -> prefix ^ \"_\" ^ type_name\n;;\n\nlet generator_name type_name = prefixed_type_name \"quickcheck_generator\" type_name\nlet observer_name type_name = prefixed_type_name \"quickcheck_observer\" type_name\nlet shrinker_name type_name = prefixed_type_name \"quickcheck_shrinker\" type_name\nlet pname { loc; txt } ~f = pvar ~loc (f txt)\nlet ename { loc; txt } ~f = evar ~loc (f txt)\nlet pgenerator = pname ~f:generator_name\nlet pobserver = pname ~f:observer_name\nlet pshrinker = pname ~f:shrinker_name\nlet egenerator = ename ~f:generator_name\nlet eobserver = ename ~f:observer_name\nlet eshrinker = ename ~f:shrinker_name\n\nlet ptuple ~loc list =\n match list with\n | [] -> [%pat? ()]\n | [ pat ] -> pat\n | _ -> ppat_tuple ~loc list\n;;\n\n(* creating (probably-)unique symbols for generated code *)\n\nlet gensym prefix loc =\n let loc = { loc with loc_ghost = true } in\n let sym = gen_symbol ~prefix:(\"_\" ^ prefix) () in\n pvar ~loc sym, evar ~loc sym\n;;\n\nlet gensyms prefix loc_list = List.map loc_list ~f:(gensym prefix) |> List.unzip\n\nlet gensymss prefix loc_list_list =\n List.map loc_list_list ~f:(gensyms prefix) |> List.unzip\n;;\n\n(* expression to create a higher order function that maps from function with one kind of\n argument label to another *)\n\nlet fn_map_label ~loc ~from ~to_ =\n let f_pat, f_expr = gensym \"f\" loc in\n let x_pat, x_expr = gensym \"x\" loc in\n pexp_fun\n ~loc\n Nolabel\n None\n f_pat\n (pexp_fun ~loc to_ None x_pat (pexp_apply ~loc f_expr [ from, x_expr ]))\n;;\n","(* [Sys0] defines functions that are primitives or can be simply defined in\n terms of [Caml.Sys]. [Sys0] is intended to completely express the part of\n [Caml.Sys] that [Base] uses -- no other file in Base other than sys.ml\n should use [Caml.Sys]. [Sys0] has few dependencies, and so is available\n early in Base's build order. All Base files that need to use these\n functions and come before [Base.Sys] in build order should do\n [module Sys = Sys0]. Defining [module Sys = Sys0] is also necessary because\n it prevents ocamldep from mistakenly causing a file to depend on [Base.Sys]. *)\n\nopen! Import0\n\ntype backend_type = Caml.Sys.backend_type =\n | Native\n | Bytecode\n | Other of string\n\nlet backend_type = Caml.Sys.backend_type\nlet interactive = Caml.Sys.interactive\nlet os_type = Caml.Sys.os_type\nlet unix = Caml.Sys.unix\nlet win32 = Caml.Sys.win32\nlet cygwin = Caml.Sys.cygwin\nlet word_size_in_bits = Caml.Sys.word_size\nlet int_size_in_bits = Caml.Sys.int_size\nlet big_endian = Caml.Sys.big_endian\nlet max_string_length = Caml.Sys.max_string_length\nlet max_array_length = Caml.Sys.max_array_length\nlet runtime_variant = Caml.Sys.runtime_variant\nlet runtime_parameters = Caml.Sys.runtime_parameters\nlet argv = Caml.Sys.argv\nlet get_argv () = Caml.Sys.argv\nlet ocaml_version = Caml.Sys.ocaml_version\nlet enable_runtime_warnings = Caml.Sys.enable_runtime_warnings\nlet runtime_warnings_enabled = Caml.Sys.runtime_warnings_enabled\n\nlet getenv_exn var =\n try Caml.Sys.getenv var with\n | Caml.Not_found ->\n Printf.failwithf \"Sys.getenv_exn: environment variable %s is not set\" var ()\n;;\n\nlet getenv var =\n match Caml.Sys.getenv var with\n | x -> Some x\n | exception Caml.Not_found -> None\n;;\n\nexternal opaque_identity : 'a -> 'a = \"%opaque\"\n\nexception Break = Caml.Sys.Break\n","(* Write_ml: writing values to the binary protocol using (mostly) OCaml. *)\n\n(* Note: the code is this file is carefully written to avoid unnecessary allocations. When\n touching this code, be sure to run the benchmarks to check for regressions. *)\n\nopen Bigarray\nopen Common\n\ntype 'a writer = buf -> pos:pos -> 'a -> pos\ntype ('a, 'b) writer1 = 'a writer -> 'b writer\ntype ('a, 'b, 'c) writer2 = 'a writer -> ('b, 'c) writer1\ntype ('a, 'b, 'c, 'd) writer3 = 'a writer -> ('b, 'c, 'd) writer2\n\nexternal unsafe_set : buf -> int -> char -> unit = \"%caml_ba_unsafe_set_1\"\nexternal unsafe_set8 : buf -> int -> int -> unit = \"%caml_ba_unsafe_set_1\"\nexternal unsafe_set16 : buf -> int -> int -> unit = \"%caml_bigstring_set16u\"\nexternal unsafe_set32 : buf -> int -> int32 -> unit = \"%caml_bigstring_set32u\"\nexternal unsafe_set64 : buf -> int -> int64 -> unit = \"%caml_bigstring_set64u\"\nexternal bswap16 : int -> int = \"%bswap16\"\nexternal bswap32 : int32 -> int32 = \"%bswap_int32\"\nexternal bswap64 : int64 -> int64 = \"%bswap_int64\"\n\n(*$ open Bin_prot_cinaps $*)\n\nlet code_NEG_INT8 = (*$ Code.char NEG_INT8 *) '\\xff' (*$*)\n\nlet code_INT16 = (*$ Code.char INT16 *) '\\xfe' (*$*)\n\nlet code_INT32 = (*$ Code.char INT32 *) '\\xfd' (*$*)\n\nlet code_INT64 = (*$ Code.char INT64 *) '\\xfc' (*$*)\n\nlet arch_sixtyfour = Sys.word_size = 64\nlet arch_big_endian = Sys.big_endian\n\nlet unsafe_set16be =\n if arch_big_endian\n then unsafe_set16\n else fun buf pos x -> unsafe_set16 buf pos (bswap16 x)\n;;\n\nlet unsafe_set32be =\n if arch_big_endian\n then unsafe_set32\n else fun buf pos x -> unsafe_set32 buf pos (bswap32 x)\n;;\n\nlet unsafe_set64be =\n if arch_big_endian\n then unsafe_set64\n else fun buf pos x -> unsafe_set64 buf pos (bswap64 x)\n;;\n\nlet unsafe_set16le =\n if arch_big_endian\n then fun buf pos x -> unsafe_set16 buf pos (bswap16 x)\n else unsafe_set16\n;;\n\nlet unsafe_set32le =\n if arch_big_endian\n then fun buf pos x -> unsafe_set32 buf pos (bswap32 x)\n else unsafe_set32\n;;\n\nlet unsafe_set64le =\n if arch_big_endian\n then fun buf pos x -> unsafe_set64 buf pos (bswap64 x)\n else unsafe_set64\n;;\n\nlet bin_write_unit buf ~pos () =\n assert_pos pos;\n check_pos buf pos;\n unsafe_set buf pos '\\000';\n pos + 1\n;;\n\nlet bin_write_bool buf ~pos b =\n assert_pos pos;\n check_pos buf pos;\n unsafe_set buf pos (if b then '\\001' else '\\000');\n pos + 1\n;;\n\nlet all_bin_write_small_int buf pos n =\n check_pos buf pos;\n unsafe_set8 buf pos n;\n pos + 1\n;;\n\nlet all_bin_write_neg_int8 buf pos n =\n let next = pos + 2 in\n check_next buf next;\n unsafe_set buf pos code_NEG_INT8;\n unsafe_set8 buf (pos + 1) n;\n next\n;;\n\nlet all_bin_write_int16 buf pos n =\n let next = pos + 3 in\n check_next buf next;\n unsafe_set buf pos code_INT16;\n unsafe_set16le buf (pos + 1) n;\n next\n;;\n\nlet all_bin_write_int32 buf pos n =\n let next = pos + 5 in\n check_next buf next;\n unsafe_set buf pos code_INT32;\n unsafe_set32le buf (pos + 1) n;\n next\n[@@inline]\n;;\n\nlet all_bin_write_int64 buf pos n =\n let next = pos + 9 in\n check_next buf next;\n unsafe_set buf pos code_INT64;\n unsafe_set64le buf (pos + 1) n;\n next\n[@@inline]\n;;\n\nlet bin_write_char buf ~pos c =\n assert_pos pos;\n check_pos buf pos;\n unsafe_set buf pos c;\n pos + 1\n;;\n\nlet bin_write_int buf ~pos n =\n assert_pos pos;\n if n >= 0\n then\n if n < 0x00000080\n then all_bin_write_small_int buf pos n\n else if n < 0x00008000\n then all_bin_write_int16 buf pos n\n else if arch_sixtyfour && n >= 1 lsl 31\n then all_bin_write_int64 buf pos (Int64.of_int n)\n else all_bin_write_int32 buf pos (Int32.of_int n)\n else if n >= -0x00000080\n then all_bin_write_neg_int8 buf pos n\n else if n >= -0x00008000\n then all_bin_write_int16 buf pos n\n else if arch_sixtyfour && n < -(1 lsl 31)\n then all_bin_write_int64 buf pos (Int64.of_int n)\n else all_bin_write_int32 buf pos (Int32.of_int n)\n;;\n\nlet bin_write_nat0 buf ~pos nat0 =\n assert_pos pos;\n let n = (nat0 : Nat0.t :> int) in\n if n < 0x00000080\n then all_bin_write_small_int buf pos n\n else if n < 0x00010000\n then all_bin_write_int16 buf pos n\n else if arch_sixtyfour && n >= 1 lsl 32\n then all_bin_write_int64 buf pos (Int64.of_int n)\n else all_bin_write_int32 buf pos (Int32.of_int n)\n;;\n\nlet bin_write_string buf ~pos str =\n let len = String.length str in\n let plen = Nat0.unsafe_of_int len in\n let new_pos = bin_write_nat0 buf ~pos plen in\n let next = new_pos + len in\n check_next buf next;\n (* TODO: optimize for small strings *)\n unsafe_blit_string_buf ~src_pos:0 str ~dst_pos:new_pos buf ~len;\n next\n;;\n\nlet bin_write_bytes buf ~pos str =\n let len = Bytes.length str in\n let plen = Nat0.unsafe_of_int len in\n let new_pos = bin_write_nat0 buf ~pos plen in\n let next = new_pos + len in\n check_next buf next;\n (* TODO: optimize for small bytes *)\n unsafe_blit_bytes_buf ~src_pos:0 str ~dst_pos:new_pos buf ~len;\n next\n;;\n\nlet bin_write_float buf ~pos x =\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n unsafe_set64le buf pos (Int64.bits_of_float x);\n next\n[@@inline]\n;;\n\nlet bin_write_int32 =\n if arch_sixtyfour\n then fun [@inline] buf ~pos n -> bin_write_int buf ~pos (Int32.to_int n)\n else\n fun [@inline] buf ~pos n ->\n if n >= 0x00008000l || n < -0x00008000l\n then (\n assert_pos pos;\n all_bin_write_int32 buf pos n)\n else bin_write_int buf ~pos (Int32.to_int n)\n;;\n\nlet bin_write_int64 buf ~pos n =\n if n >= 0x80000000L || n < -0x80000000L\n then (\n assert_pos pos;\n all_bin_write_int64 buf pos n)\n else if arch_sixtyfour\n then bin_write_int buf ~pos (Int64.to_int n)\n else if n >= 0x00008000L || n < -0x00008000L\n then (\n assert_pos pos;\n all_bin_write_int32 buf pos (Int64.to_int32 n))\n else bin_write_int buf ~pos (Int64.to_int n)\n[@@inline]\n;;\n\nlet bin_write_nativeint buf ~pos n =\n if arch_sixtyfour\n && (n >= (* 0x80000000n *) Nativeint.shift_left 1n 31\n || n < (* -0x80000000n *) Nativeint.neg (Nativeint.shift_left 1n 31))\n then (\n assert_pos pos;\n all_bin_write_int64 buf pos (Int64.of_nativeint n))\n else if ((not arch_sixtyfour) && n >= 0x8000n) || n < -0x8000n\n then (\n assert_pos pos;\n all_bin_write_int32 buf pos (Nativeint.to_int32 n))\n else bin_write_int buf ~pos (Nativeint.to_int n)\n[@@inline]\n;;\n\nlet bin_write_ref bin_write_el buf ~pos r = bin_write_el buf ~pos !r\n\nlet bin_write_lazy bin_write_el buf ~pos lv =\n let v = Lazy.force lv in\n bin_write_el buf ~pos v\n;;\n\nlet bin_write_option bin_write_el buf ~pos = function\n | None -> bin_write_bool buf ~pos false\n | Some v ->\n let next = bin_write_bool buf ~pos true in\n bin_write_el buf ~pos:next v\n;;\n\nlet bin_write_pair bin_write_a bin_write_b buf ~pos (a, b) =\n let next = bin_write_a buf ~pos a in\n bin_write_b buf ~pos:next b\n;;\n\nlet bin_write_triple bin_write_a bin_write_b bin_write_c buf ~pos (a, b, c) =\n let next1 = bin_write_a buf ~pos a in\n let next2 = bin_write_b buf ~pos:next1 b in\n bin_write_c buf ~pos:next2 c\n;;\n\nlet bin_write_list bin_write_el buf ~pos lst =\n let rec loop els_pos = function\n | [] -> els_pos\n | h :: t ->\n let new_els_pos = bin_write_el buf ~pos:els_pos h in\n loop new_els_pos t\n in\n let len = Nat0.unsafe_of_int (List.length lst) in\n let els_pos = bin_write_nat0 buf ~pos len in\n loop els_pos lst\n;;\n\nlet bin_write_float_array buf ~pos a =\n let len = Array.length a in\n let plen = Nat0.unsafe_of_int len in\n let pos = bin_write_nat0 buf ~pos plen in\n let size = len * 8 in\n let next = pos + size in\n check_next buf next;\n unsafe_blit_float_array_buf a buf ~src_pos:0 ~dst_pos:pos ~len;\n next\n;;\n\nlet bin_write_array_loop bin_write_el buf ~els_pos ~n ar =\n let els_pos_ref = ref els_pos in\n for i = 0 to n - 1 do\n els_pos_ref := bin_write_el buf ~pos:!els_pos_ref (Array.unsafe_get ar i)\n done;\n !els_pos_ref\n;;\n\nlet bin_write_array (type a) bin_write_el buf ~pos ar =\n if (Obj.magic (bin_write_el : a writer) : float writer) == bin_write_float\n then bin_write_float_array buf ~pos (Obj.magic (ar : a array) : float array)\n else (\n let n = Array.length ar in\n let pn = Nat0.unsafe_of_int n in\n let els_pos = bin_write_nat0 buf ~pos pn in\n bin_write_array_loop bin_write_el buf ~els_pos ~n ar)\n;;\n\nlet bin_write_hashtbl bin_write_key bin_write_val buf ~pos htbl =\n let len = Hashtbl.length htbl in\n let plen = Nat0.unsafe_of_int len in\n let els_pos = bin_write_nat0 buf ~pos plen in\n let cnt_ref = ref 0 in\n let coll_htbl k v els_pos =\n incr cnt_ref;\n let new_els_pos = bin_write_key buf ~pos:els_pos k in\n bin_write_val buf ~pos:new_els_pos v\n in\n let res_pos = Hashtbl.fold coll_htbl htbl els_pos in\n if !cnt_ref <> len then raise_concurrent_modification \"bin_write_hashtbl\";\n res_pos\n;;\n\nexternal buf_of_vec32 : vec32 -> buf = \"%identity\"\nexternal buf_of_vec64 : vec64 -> buf = \"%identity\"\nexternal buf_of_mat32 : mat32 -> buf = \"%identity\"\nexternal buf_of_mat64 : mat64 -> buf = \"%identity\"\n\nlet bin_write_float32_vec buf ~pos v =\n let len = Array1.dim v in\n let plen = Nat0.unsafe_of_int len in\n let pos = bin_write_nat0 buf ~pos plen in\n let size = len * 4 in\n let next = pos + size in\n check_next buf next;\n unsafe_blit_buf ~src:(buf_of_vec32 v) ~src_pos:0 ~dst:buf ~dst_pos:pos ~len:size;\n next\n;;\n\nlet bin_write_float64_vec buf ~pos v =\n let len = Array1.dim v in\n let plen = Nat0.unsafe_of_int len in\n let pos = bin_write_nat0 buf ~pos plen in\n let size = len * 8 in\n let next = pos + size in\n check_next buf next;\n unsafe_blit_buf ~src:(buf_of_vec64 v) ~src_pos:0 ~dst:buf ~dst_pos:pos ~len:size;\n next\n;;\n\nlet bin_write_vec = bin_write_float64_vec\n\nlet bin_write_float32_mat buf ~pos m =\n let len1 = Array2.dim1 m in\n let len2 = Array2.dim2 m in\n let pos = bin_write_nat0 buf ~pos (Nat0.unsafe_of_int len1) in\n let pos = bin_write_nat0 buf ~pos (Nat0.unsafe_of_int len2) in\n let size = len1 * len2 * 4 in\n let next = pos + size in\n check_next buf next;\n unsafe_blit_buf ~src:(buf_of_mat32 m) ~src_pos:0 ~dst:buf ~dst_pos:pos ~len:size;\n next\n;;\n\nlet bin_write_float64_mat buf ~pos m =\n let len1 = Array2.dim1 m in\n let len2 = Array2.dim2 m in\n let pos = bin_write_nat0 buf ~pos (Nat0.unsafe_of_int len1) in\n let pos = bin_write_nat0 buf ~pos (Nat0.unsafe_of_int len2) in\n let size = len1 * len2 * 8 in\n let next = pos + size in\n check_next buf next;\n unsafe_blit_buf ~src:(buf_of_mat64 m) ~src_pos:0 ~dst:buf ~dst_pos:pos ~len:size;\n next\n;;\n\nlet bin_write_mat = bin_write_float64_mat\n\nlet bin_write_bigstring buf ~pos s =\n let len = Array1.dim s in\n let plen = Nat0.unsafe_of_int len in\n let pos = bin_write_nat0 buf ~pos plen in\n let next = pos + len in\n check_next buf next;\n unsafe_blit_buf ~src:s ~src_pos:0 ~dst:buf ~dst_pos:pos ~len;\n next\n;;\n\nlet bin_write_variant_int buf ~pos x =\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n unsafe_set32le buf pos (Int32.logor (Int32.shift_left (Int32.of_int x) 1) 1l);\n next\n;;\n\nlet bin_write_int_8bit buf ~pos n =\n assert_pos pos;\n check_pos buf pos;\n unsafe_set8 buf pos n;\n pos + 1\n;;\n\nlet bin_write_int_16bit buf ~pos n =\n assert_pos pos;\n let next = pos + 2 in\n check_next buf next;\n unsafe_set16le buf pos n;\n next\n;;\n\nlet bin_write_int_32bit buf ~pos n =\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n unsafe_set32le buf pos (Int32.of_int n);\n next\n;;\n\nlet bin_write_int_64bit buf ~pos n =\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n unsafe_set64le buf pos (Int64.of_int n);\n next\n;;\n\nlet bin_write_int64_bits buf ~pos n =\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n unsafe_set64le buf pos n;\n next\n;;\n\nlet bin_write_network16_int buf ~pos n =\n assert_pos pos;\n let next = pos + 2 in\n check_next buf next;\n unsafe_set16be buf pos n;\n next\n;;\n\nlet bin_write_network32_int buf ~pos n =\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n unsafe_set32be buf pos (Int32.of_int n);\n next\n;;\n\nlet bin_write_network32_int32 buf ~pos n =\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n unsafe_set32be buf pos n;\n next\n;;\n\nlet bin_write_network64_int buf ~pos n =\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n unsafe_set64be buf pos (Int64.of_int n);\n next\n;;\n\nlet bin_write_network64_int64 buf ~pos n =\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n unsafe_set64be buf pos n;\n next\n;;\n\nlet bin_write_array_no_length bin_write_el buf ~pos ar =\n bin_write_array_loop bin_write_el buf ~els_pos:pos ~n:(Array.length ar) ar\n;;\n\nexternal unsafe_string_get32 : string -> int -> int32 = \"%caml_string_get32u\"\nexternal unsafe_string_get64 : string -> int -> int64 = \"%caml_string_get64u\"\n\nlet bin_write_md5 buf ~pos x =\n let x = Md5_lib.to_binary x in\n assert (String.length x = 16);\n assert_pos pos;\n let next = pos + 16 in\n check_next buf next;\n if arch_sixtyfour\n then (\n let a = unsafe_string_get64 x 0 in\n let b = unsafe_string_get64 x 8 in\n unsafe_set64 buf pos a;\n unsafe_set64 buf (pos + 8) b)\n else (\n let a = unsafe_string_get32 x 0 in\n let b = unsafe_string_get32 x 4 in\n let c = unsafe_string_get32 x 8 in\n let d = unsafe_string_get32 x 12 in\n unsafe_set32 buf pos a;\n unsafe_set32 buf (pos + 4) b;\n unsafe_set32 buf (pos + 8) c;\n unsafe_set32 buf (pos + 12) d);\n next\n;;\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Para, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1997 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Internals of forcing lazy values. *)\n\ntype 'a t = 'a lazy_t\n\nexception Undefined\n\nlet raise_undefined = Obj.repr (fun () -> raise Undefined)\n\nexternal make_forward : Obj.t -> Obj.t -> unit = \"caml_obj_make_forward\"\n\n(* Assume [blk] is a block with tag lazy *)\nlet force_lazy_block (blk : 'arg lazy_t) =\n let closure = (Obj.obj (Obj.field (Obj.repr blk) 0) : unit -> 'arg) in\n Obj.set_field (Obj.repr blk) 0 raise_undefined;\n try\n let result = closure () in\n make_forward (Obj.repr blk) (Obj.repr result);\n result\n with e ->\n Obj.set_field (Obj.repr blk) 0 (Obj.repr (fun () -> raise e));\n raise e\n\n\n(* Assume [blk] is a block with tag lazy *)\nlet force_val_lazy_block (blk : 'arg lazy_t) =\n let closure = (Obj.obj (Obj.field (Obj.repr blk) 0) : unit -> 'arg) in\n Obj.set_field (Obj.repr blk) 0 raise_undefined;\n let result = closure () in\n make_forward (Obj.repr blk) (Obj.repr result);\n result\n\n\n(* [force] is not used, since [Lazy.force] is declared as a primitive\n whose code inlines the tag tests of its argument, except when afl\n instrumentation is turned on. *)\n\nlet force (lzv : 'arg lazy_t) =\n (* Using [Sys.opaque_identity] prevents two potential problems:\n - If the value is known to have Forward_tag, then its tag could have\n changed during GC, so that information must be forgotten (see GPR#713\n and issue #7301)\n - If the value is known to be immutable, then if the compiler\n cannot prove that the last branch is not taken it will issue a\n warning 59 (modification of an immutable value) *)\n let lzv = Sys.opaque_identity lzv in\n let x = Obj.repr lzv in\n let t = Obj.tag x in\n if t = Obj.forward_tag then (Obj.obj (Obj.field x 0) : 'arg) else\n if t <> Obj.lazy_tag then (Obj.obj x : 'arg)\n else force_lazy_block lzv\n\n\nlet force_val (lzv : 'arg lazy_t) =\n let x = Obj.repr lzv in\n let t = Obj.tag x in\n if t = Obj.forward_tag then (Obj.obj (Obj.field x 0) : 'arg) else\n if t <> Obj.lazy_tag then (Obj.obj x : 'arg)\n else force_val_lazy_block lzv\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Para, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1997 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Lazy]: deferred computations *)\n\n\n(*\n WARNING: some purple magic is going on here. Do not take this file\n as an example of how to program in OCaml.\n*)\n\n\n(* We make use of two special tags provided by the runtime:\n [lazy_tag] and [forward_tag].\n\n A value of type ['a Lazy.t] can be one of three things:\n 1. A block of size 1 with tag [lazy_tag]. Its field is a closure of\n type [unit -> 'a] that computes the value.\n 2. A block of size 1 with tag [forward_tag]. Its field is the value\n of type ['a] that was computed.\n 3. Anything else except a float. This has type ['a] and is the value\n that was computed.\n Exceptions are stored in format (1).\n The GC will magically change things from (2) to (3) according to its\n fancy.\n\n If OCaml was configured with the -flat-float-array option (which is\n currently the default), the following is also true:\n We cannot use representation (3) for a [float Lazy.t] because\n [caml_make_array] assumes that only a [float] value can have tag\n [Double_tag].\n\n We have to use the built-in type constructor [lazy_t] to\n let the compiler implement the special typing and compilation\n rules for the [lazy] keyword.\n*)\n\ntype 'a t = 'a CamlinternalLazy.t\n\nexception Undefined = CamlinternalLazy.Undefined\n\nexternal make_forward : 'a -> 'a lazy_t = \"caml_lazy_make_forward\"\n\nexternal force : 'a t -> 'a = \"%lazy_force\"\n\n\nlet force_val = CamlinternalLazy.force_val\n\nlet from_fun (f : unit -> 'arg) =\n let x = Obj.new_block Obj.lazy_tag 1 in\n Obj.set_field x 0 (Obj.repr f);\n (Obj.obj x : 'arg t)\n\nlet from_val (v : 'arg) =\n let t = Obj.tag (Obj.repr v) in\n if t = Obj.forward_tag || t = Obj.lazy_tag || t = Obj.double_tag then begin\n make_forward v\n end else begin\n (Obj.magic v : 'arg t)\n end\n\n\nlet is_val (l : 'arg t) = Obj.tag (Obj.repr l) <> Obj.lazy_tag\n\nlet lazy_from_fun = from_fun\n\nlet lazy_from_val = from_val\n\nlet lazy_is_val = is_val\n\n\nlet map f x =\n lazy (f (force x))\n\nlet map_val f x =\n if is_val x\n then lazy_from_val (f (force x))\n else lazy (f (force x))\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Simon Cruanes *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Seq]: functional iterators *)\n\ntype +'a node =\n | Nil\n | Cons of 'a * 'a t\n\nand 'a t = unit -> 'a node\n\nlet empty () = Nil\n\nlet return x () = Cons (x, empty)\n\nlet cons x next () = Cons (x, next)\n\nlet rec append seq1 seq2 () =\n match seq1() with\n | Nil -> seq2()\n | Cons (x, next) -> Cons (x, append next seq2)\n\nlet rec map f seq () = match seq() with\n | Nil -> Nil\n | Cons (x, next) -> Cons (f x, map f next)\n\nlet rec filter_map f seq () = match seq() with\n | Nil -> Nil\n | Cons (x, next) ->\n match f x with\n | None -> filter_map f next ()\n | Some y -> Cons (y, filter_map f next)\n\nlet rec filter f seq () = match seq() with\n | Nil -> Nil\n | Cons (x, next) ->\n if f x\n then Cons (x, filter f next)\n else filter f next ()\n\nlet rec concat seq () = match seq () with\n | Nil -> Nil\n | Cons (x, next) ->\n append x (concat next) ()\n\nlet rec flat_map f seq () = match seq () with\n | Nil -> Nil\n | Cons (x, next) ->\n append (f x) (flat_map f next) ()\n\nlet concat_map = flat_map\n\nlet rec fold_left f acc seq =\n match seq () with\n | Nil -> acc\n | Cons (x, next) ->\n let acc = f acc x in\n fold_left f acc next\n\nlet rec iter f seq =\n match seq () with\n | Nil -> ()\n | Cons (x, next) ->\n f x;\n iter f next\n\nlet rec unfold f u () =\n match f u with\n | None -> Nil\n | Some (x, u') -> Cons (x, unfold f u')\n\nlet is_empty xs =\n match xs() with\n | Nil ->\n true\n | Cons (_, _) ->\n false\n\nlet uncons xs =\n match xs() with\n | Cons (x, xs) ->\n Some (x, xs)\n | Nil ->\n None\n\n\n\nlet rec length_aux accu xs =\n match xs() with\n | Nil ->\n accu\n | Cons (_, xs) ->\n length_aux (accu + 1) xs\n\nlet[@inline] length xs =\n length_aux 0 xs\n\nlet rec iteri_aux f i xs =\n match xs() with\n | Nil ->\n ()\n | Cons (x, xs) ->\n f i x;\n iteri_aux f (i+1) xs\n\nlet[@inline] iteri f xs =\n iteri_aux f 0 xs\n\nlet rec fold_lefti_aux f accu i xs =\n match xs() with\n | Nil ->\n accu\n | Cons (x, xs) ->\n let accu = f accu i x in\n fold_lefti_aux f accu (i+1) xs\n\nlet[@inline] fold_lefti f accu xs =\n fold_lefti_aux f accu 0 xs\n\nlet rec for_all p xs =\n match xs() with\n | Nil ->\n true\n | Cons (x, xs) ->\n p x && for_all p xs\n\nlet rec exists p xs =\n match xs() with\n | Nil ->\n false\n | Cons (x, xs) ->\n p x || exists p xs\n\nlet rec find p xs =\n match xs() with\n | Nil ->\n None\n | Cons (x, xs) ->\n if p x then Some x else find p xs\n\nlet rec find_map f xs =\n match xs() with\n | Nil ->\n None\n | Cons (x, xs) ->\n match f x with\n | None ->\n find_map f xs\n | Some _ as result ->\n result\n\n(* [iter2], [fold_left2], [for_all2], [exists2], [map2], [zip] work also in\n the case where the two sequences have different lengths. They stop as soon\n as one sequence is exhausted. Their behavior is slightly asymmetric: when\n [xs] is empty, they do not force [ys]; however, when [ys] is empty, [xs] is\n forced, even though the result of the function application [xs()] turns out\n to be useless. *)\n\nlet rec iter2 f xs ys =\n match xs() with\n | Nil ->\n ()\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n ()\n | Cons (y, ys) ->\n f x y;\n iter2 f xs ys\n\nlet rec fold_left2 f accu xs ys =\n match xs() with\n | Nil ->\n accu\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n accu\n | Cons (y, ys) ->\n let accu = f accu x y in\n fold_left2 f accu xs ys\n\nlet rec for_all2 f xs ys =\n match xs() with\n | Nil ->\n true\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n true\n | Cons (y, ys) ->\n f x y && for_all2 f xs ys\n\nlet rec exists2 f xs ys =\n match xs() with\n | Nil ->\n false\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n false\n | Cons (y, ys) ->\n f x y || exists2 f xs ys\n\nlet rec equal eq xs ys =\n match xs(), ys() with\n | Nil, Nil ->\n true\n | Cons (x, xs), Cons (y, ys) ->\n eq x y && equal eq xs ys\n | Nil, Cons (_, _)\n | Cons (_, _), Nil ->\n false\n\nlet rec compare cmp xs ys =\n match xs(), ys() with\n | Nil, Nil ->\n 0\n | Cons (x, xs), Cons (y, ys) ->\n let c = cmp x y in\n if c <> 0 then c else compare cmp xs ys\n | Nil, Cons (_, _) ->\n -1\n | Cons (_, _), Nil ->\n +1\n\n\n\n(* [init_aux f i j] is the sequence [f i, ..., f (j-1)]. *)\n\nlet rec init_aux f i j () =\n if i < j then begin\n Cons (f i, init_aux f (i + 1) j)\n end\n else\n Nil\n\nlet init n f =\n if n < 0 then\n invalid_arg \"Seq.init\"\n else\n init_aux f 0 n\n\nlet rec repeat x () =\n Cons (x, repeat x)\n\nlet rec forever f () =\n Cons (f(), forever f)\n\n(* This preliminary definition of [cycle] requires the sequence [xs]\n to be nonempty. Applying it to an empty sequence would produce a\n sequence that diverges when it is forced. *)\n\nlet rec cycle_nonempty xs () =\n append xs (cycle_nonempty xs) ()\n\n(* [cycle xs] checks whether [xs] is empty and, if so, returns an empty\n sequence. Otherwise, [cycle xs] produces one copy of [xs] followed\n with the infinite sequence [cycle_nonempty xs]. Thus, the nonemptiness\n check is performed just once. *)\n\nlet cycle xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs') ->\n Cons (x, append xs' (cycle_nonempty xs))\n\n(* [iterate1 f x] is the sequence [f x, f (f x), ...].\n It is equivalent to [tail (iterate f x)].\n [iterate1] is used as a building block in the definition of [iterate]. *)\n\nlet rec iterate1 f x () =\n let y = f x in\n Cons (y, iterate1 f y)\n\n(* [iterate f x] is the sequence [x, f x, ...]. *)\n\n(* The reason why we give this slightly indirect definition of [iterate],\n as opposed to the more naive definition that may come to mind, is that\n we are careful to avoid evaluating [f x] until this function call is\n actually necessary. The naive definition (not shown here) computes the\n second argument of the sequence, [f x], when the first argument is\n requested by the user. *)\n\nlet iterate f x =\n cons x (iterate1 f x)\n\n\n\nlet rec mapi_aux f i xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n Cons (f i x, mapi_aux f (i+1) xs)\n\nlet[@inline] mapi f xs =\n mapi_aux f 0 xs\n\n(* [tail_scan f s xs] is equivalent to [tail (scan f s xs)].\n [tail_scan] is used as a building block in the definition of [scan]. *)\n\n(* This slightly indirect definition of [scan] is meant to avoid computing\n elements too early; see the above comment about [iterate1] and [iterate]. *)\n\nlet rec tail_scan f s xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n let s = f s x in\n Cons (s, tail_scan f s xs)\n\nlet scan f s xs =\n cons s (tail_scan f s xs)\n\n(* [take] is defined in such a way that [take 0 xs] returns [empty]\n immediately, without allocating any memory. *)\n\nlet rec take_aux n xs =\n if n = 0 then\n empty\n else\n fun () ->\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n Cons (x, take_aux (n-1) xs)\n\nlet take n xs =\n if n < 0 then invalid_arg \"Seq.take\";\n take_aux n xs\n\n(* [force_drop n xs] is equivalent to [drop n xs ()].\n [force_drop n xs] requires [n > 0].\n [force_drop] is used as a building block in the definition of [drop]. *)\n\nlet rec force_drop n xs =\n match xs() with\n | Nil ->\n Nil\n | Cons (_, xs) ->\n let n = n - 1 in\n if n = 0 then\n xs()\n else\n force_drop n xs\n\n(* [drop] is defined in such a way that [drop 0 xs] returns [xs] immediately,\n without allocating any memory. *)\n\nlet drop n xs =\n if n < 0 then invalid_arg \"Seq.drop\"\n else if n = 0 then\n xs\n else\n fun () ->\n force_drop n xs\n\nlet rec take_while p xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n if p x then Cons (x, take_while p xs) else Nil\n\nlet rec drop_while p xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) as node ->\n if p x then drop_while p xs () else node\n\nlet rec group eq xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n Cons (cons x (take_while (eq x) xs), group eq (drop_while (eq x) xs))\n\nexception Forced_twice\n\nmodule Suspension = struct\n\n type 'a suspension =\n unit -> 'a\n\n (* Conversions. *)\n\n let to_lazy : 'a suspension -> 'a Lazy.t =\n Lazy.from_fun\n (* fun s -> lazy (s()) *)\n\n let from_lazy (s : 'a Lazy.t) : 'a suspension =\n fun () -> Lazy.force s\n\n (* [memoize] turns an arbitrary suspension into a persistent suspension. *)\n\n let memoize (s : 'a suspension) : 'a suspension =\n from_lazy (to_lazy s)\n\n (* [failure] is a suspension that fails when forced. *)\n\n let failure : _ suspension =\n fun () ->\n (* A suspension created by [once] has been forced twice. *)\n raise Forced_twice\n\n (* If [f] is a suspension, then [once f] is a suspension that can be forced\n at most once. If it is forced more than once, then [Forced_twice] is\n raised. *)\n\n let once (f : 'a suspension) : 'a suspension =\n let action = CamlinternalAtomic.make f in\n fun () ->\n (* Get the function currently stored in [action], and write the\n function [failure] in its place, so the next access will result\n in a call to [failure()]. *)\n let f = CamlinternalAtomic.exchange action failure in\n f()\n\nend (* Suspension *)\n\nlet rec memoize xs =\n Suspension.memoize (fun () ->\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n Cons (x, memoize xs)\n )\n\nlet rec once xs =\n Suspension.once (fun () ->\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n Cons (x, once xs)\n )\n\n\nlet rec zip xs ys () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n Nil\n | Cons (y, ys) ->\n Cons ((x, y), zip xs ys)\n\nlet rec map2 f xs ys () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n Nil\n | Cons (y, ys) ->\n Cons (f x y, map2 f xs ys)\n\nlet rec interleave xs ys () =\n match xs() with\n | Nil ->\n ys()\n | Cons (x, xs) ->\n Cons (x, interleave ys xs)\n\n(* [sorted_merge1l cmp x xs ys] is equivalent to\n [sorted_merge cmp (cons x xs) ys].\n\n [sorted_merge1r cmp xs y ys] is equivalent to\n [sorted_merge cmp xs (cons y ys)].\n\n [sorted_merge1 cmp x xs y ys] is equivalent to\n [sorted_merge cmp (cons x xs) (cons y ys)].\n\n These three functions are used as building blocks in the definition\n of [sorted_merge]. *)\n\nlet rec sorted_merge1l cmp x xs ys () =\n match ys() with\n | Nil ->\n Cons (x, xs)\n | Cons (y, ys) ->\n sorted_merge1 cmp x xs y ys\n\nand sorted_merge1r cmp xs y ys () =\n match xs() with\n | Nil ->\n Cons (y, ys)\n | Cons (x, xs) ->\n sorted_merge1 cmp x xs y ys\n\nand sorted_merge1 cmp x xs y ys =\n if cmp x y <= 0 then\n Cons (x, sorted_merge1r cmp xs y ys)\n else\n Cons (y, sorted_merge1l cmp x xs ys)\n\nlet sorted_merge cmp xs ys () =\n match xs(), ys() with\n | Nil, Nil ->\n Nil\n | Nil, c\n | c, Nil ->\n c\n | Cons (x, xs), Cons (y, ys) ->\n sorted_merge1 cmp x xs y ys\n\n\nlet rec map_fst xys () =\n match xys() with\n | Nil ->\n Nil\n | Cons ((x, _), xys) ->\n Cons (x, map_fst xys)\n\nlet rec map_snd xys () =\n match xys() with\n | Nil ->\n Nil\n | Cons ((_, y), xys) ->\n Cons (y, map_snd xys)\n\nlet unzip xys =\n map_fst xys, map_snd xys\n\nlet split =\n unzip\n\n(* [filter_map_find_left_map f xs] is equivalent to\n [filter_map Either.find_left (map f xs)]. *)\n\nlet rec filter_map_find_left_map f xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n match f x with\n | Either.Left y ->\n Cons (y, filter_map_find_left_map f xs)\n | Either.Right _ ->\n filter_map_find_left_map f xs ()\n\nlet rec filter_map_find_right_map f xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n match f x with\n | Either.Left _ ->\n filter_map_find_right_map f xs ()\n | Either.Right z ->\n Cons (z, filter_map_find_right_map f xs)\n\nlet partition_map f xs =\n filter_map_find_left_map f xs,\n filter_map_find_right_map f xs\n\nlet partition p xs =\n filter p xs, filter (fun x -> not (p x)) xs\n\n(* If [xss] is a matrix (a sequence of rows), then [peel xss] is a pair of\n the first column (a sequence of elements) and of the remainder of the\n matrix (a sequence of shorter rows). These two sequences have the same\n length. The rows of the matrix [xss] are not required to have the same\n length. An empty row is ignored. *)\n\n(* Because [peel] uses [unzip], its argument must be persistent. The same\n remark applies to [transpose], [diagonals], [product], etc. *)\n\nlet peel xss =\n unzip (filter_map uncons xss)\n\nlet rec transpose xss () =\n let heads, tails = peel xss in\n if is_empty heads then begin\n assert (is_empty tails);\n Nil\n end\n else\n Cons (heads, transpose tails)\n\n(* The internal function [diagonals] takes an extra argument, [remainders],\n which contains the remainders of the rows that have already been\n discovered. *)\n\nlet rec diagonals remainders xss () =\n match xss() with\n | Cons (xs, xss) ->\n begin match xs() with\n | Cons (x, xs) ->\n (* We discover a new nonempty row [x :: xs]. Thus, the next diagonal\n is [x :: heads]: this diagonal begins with [x] and continues with\n the first element of every row in [remainders]. In the recursive\n call, the argument [remainders] is instantiated with [xs ::\n tails], which means that we have one more remaining row, [xs],\n and that we keep the tails of the pre-existing remaining rows. *)\n let heads, tails = peel remainders in\n Cons (cons x heads, diagonals (cons xs tails) xss)\n | Nil ->\n (* We discover a new empty row. In this case, the new diagonal is\n just [heads], and [remainders] is instantiated with just [tails],\n as we do not have one more remaining row. *)\n let heads, tails = peel remainders in\n Cons (heads, diagonals tails xss)\n end\n | Nil ->\n (* There are no more rows to be discovered. There remains to exhaust\n the remaining rows. *)\n transpose remainders ()\n\n(* If [xss] is a matrix (a sequence of rows), then [diagonals xss] is\n the sequence of its diagonals.\n\n The first diagonal contains just the first element of the\n first row. The second diagonal contains the first element of the\n second row and the second element of the first row; and so on.\n This kind of diagonal is in fact sometimes known as an antidiagonal.\n\n - Every diagonal is a finite sequence.\n - The rows of the matrix [xss] are not required to have the same length.\n - The matrix [xss] is not required to be finite (in either direction).\n - The matrix [xss] must be persistent. *)\n\nlet diagonals xss =\n diagonals empty xss\n\nlet map_product f xs ys =\n concat (diagonals (\n map (fun x ->\n map (fun y ->\n f x y\n ) ys\n ) xs\n ))\n\nlet product xs ys =\n map_product (fun x y -> (x, y)) xs ys\n\nlet of_dispenser it =\n let rec c () =\n match it() with\n | None ->\n Nil\n | Some x ->\n Cons (x, c)\n in\n c\n\nlet to_dispenser xs =\n let s = ref xs in\n fun () ->\n match (!s)() with\n | Nil ->\n None\n | Cons (x, xs) ->\n s := xs;\n Some x\n\n\n\nlet rec ints i () =\n Cons (i, ints (i + 1))\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* The OCaml programmers *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype 'a t = 'a option = None | Some of 'a\n\nlet none = None\nlet some v = Some v\nlet value o ~default = match o with Some v -> v | None -> default\nlet get = function Some v -> v | None -> invalid_arg \"option is None\"\nlet bind o f = match o with None -> None | Some v -> f v\nlet join = function Some o -> o | None -> None\nlet map f o = match o with None -> None | Some v -> Some (f v)\nlet fold ~none ~some = function Some v -> some v | None -> none\nlet iter f = function Some v -> f v | None -> ()\nlet is_none = function None -> true | Some _ -> false\nlet is_some = function None -> false | Some _ -> true\n\nlet equal eq o0 o1 = match o0, o1 with\n| Some v0, Some v1 -> eq v0 v1\n| None, None -> true\n| _ -> false\n\nlet compare cmp o0 o1 = match o0, o1 with\n| Some v0, Some v1 -> cmp v0 v1\n| None, None -> 0\n| None, Some _ -> -1\n| Some _, None -> 1\n\nlet to_result ~none = function None -> Error none | Some v -> Ok v\nlet to_list = function None -> [] | Some v -> [v]\nlet to_seq = function None -> Seq.empty | Some v -> Seq.return v\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* The OCaml programmers *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype ('a, 'e) t = ('a, 'e) result = Ok of 'a | Error of 'e\n\nlet ok v = Ok v\nlet error e = Error e\nlet value r ~default = match r with Ok v -> v | Error _ -> default\nlet get_ok = function Ok v -> v | Error _ -> invalid_arg \"result is Error _\"\nlet get_error = function Error e -> e | Ok _ -> invalid_arg \"result is Ok _\"\nlet bind r f = match r with Ok v -> f v | Error _ as e -> e\nlet join = function Ok r -> r | Error _ as e -> e\nlet map f = function Ok v -> Ok (f v) | Error _ as e -> e\nlet map_error f = function Error e -> Error (f e) | Ok _ as v -> v\nlet fold ~ok ~error = function Ok v -> ok v | Error e -> error e\nlet iter f = function Ok v -> f v | Error _ -> ()\nlet iter_error f = function Error e -> f e | Ok _ -> ()\nlet is_ok = function Ok _ -> true | Error _ -> false\nlet is_error = function Error _ -> true | Ok _ -> false\n\nlet equal ~ok ~error r0 r1 = match r0, r1 with\n| Ok v0, Ok v1 -> ok v0 v1\n| Error e0, Error e1 -> error e0 e1\n| _, _ -> false\n\nlet compare ~ok ~error r0 r1 = match r0, r1 with\n| Ok v0, Ok v1 -> ok v0 v1\n| Error e0, Error e1 -> error e0 e1\n| Ok _, Error _ -> -1\n| Error _, Ok _ -> 1\n\nlet to_option = function Ok v -> Some v | Error _ -> None\nlet to_list = function Ok v -> [v] | Error _ -> []\nlet to_seq = function Ok v -> Seq.return v | Error _ -> Seq.empty\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Character operations *)\n\nexternal code: char -> int = \"%identity\"\nexternal unsafe_chr: int -> char = \"%identity\"\n\nlet chr n =\n if n < 0 || n > 255 then invalid_arg \"Char.chr\" else unsafe_chr n\n\nexternal bytes_create: int -> bytes = \"caml_create_bytes\"\nexternal bytes_unsafe_set : bytes -> int -> char -> unit\n = \"%bytes_unsafe_set\"\nexternal unsafe_to_string : bytes -> string = \"%bytes_to_string\"\n\nlet escaped = function\n | '\\'' -> \"\\\\'\"\n | '\\\\' -> \"\\\\\\\\\"\n | '\\n' -> \"\\\\n\"\n | '\\t' -> \"\\\\t\"\n | '\\r' -> \"\\\\r\"\n | '\\b' -> \"\\\\b\"\n | ' ' .. '~' as c ->\n let s = bytes_create 1 in\n bytes_unsafe_set s 0 c;\n unsafe_to_string s\n | c ->\n let n = code c in\n let s = bytes_create 4 in\n bytes_unsafe_set s 0 '\\\\';\n bytes_unsafe_set s 1 (unsafe_chr (48 + n / 100));\n bytes_unsafe_set s 2 (unsafe_chr (48 + (n / 10) mod 10));\n bytes_unsafe_set s 3 (unsafe_chr (48 + n mod 10));\n unsafe_to_string s\n\nlet lowercase = function\n | 'A' .. 'Z'\n | '\\192' .. '\\214'\n | '\\216' .. '\\222' as c ->\n unsafe_chr(code c + 32)\n | c -> c\n\nlet uppercase = function\n | 'a' .. 'z'\n | '\\224' .. '\\246'\n | '\\248' .. '\\254' as c ->\n unsafe_chr(code c - 32)\n | c -> c\n\nlet lowercase_ascii = function\n | 'A' .. 'Z' as c -> unsafe_chr(code c + 32)\n | c -> c\n\nlet uppercase_ascii = function\n | 'a' .. 'z' as c -> unsafe_chr(code c - 32)\n | c -> c\n\ntype t = char\n\nlet compare c1 c2 = code c1 - code c2\nlet equal (c1: t) (c2: t) = compare c1 c2 = 0\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* The OCaml programmers *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype t = int\n\nlet zero = 0\nlet one = 1\nlet minus_one = -1\nexternal neg : int -> int = \"%negint\"\nexternal add : int -> int -> int = \"%addint\"\nexternal sub : int -> int -> int = \"%subint\"\nexternal mul : int -> int -> int = \"%mulint\"\nexternal div : int -> int -> int = \"%divint\"\nexternal rem : int -> int -> int = \"%modint\"\nexternal succ : int -> int = \"%succint\"\nexternal pred : int -> int = \"%predint\"\nlet abs x = if x >= 0 then x else -x\nlet max_int = (-1) lsr 1\nlet min_int = max_int + 1\nexternal logand : int -> int -> int = \"%andint\"\nexternal logor : int -> int -> int = \"%orint\"\nexternal logxor : int -> int -> int = \"%xorint\"\nlet lognot x = logxor x (-1)\nexternal shift_left : int -> int -> int = \"%lslint\"\nexternal shift_right : int -> int -> int = \"%asrint\"\nexternal shift_right_logical : int -> int -> int = \"%lsrint\"\nlet equal : int -> int -> bool = ( = )\nlet compare : int -> int -> int = Stdlib.compare\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\nexternal to_float : int -> float = \"%floatofint\"\nexternal of_float : float -> int = \"%intoffloat\"\n\n(*\nexternal int_of_string : string -> int = \"caml_int_of_string\"\nlet of_string s = try Some (int_of_string s) with Failure _ -> None\n*)\n\nexternal format_int : string -> int -> string = \"caml_format_int\"\nlet to_string x = format_int \"%d\" x\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Byte sequence operations *)\n\n(* WARNING: Some functions in this file are duplicated in string.ml for\n efficiency reasons. When you modify the one in this file you need to\n modify its duplicate in string.ml.\n These functions have a \"duplicated\" comment above their definition.\n*)\n\nexternal length : bytes -> int = \"%bytes_length\"\nexternal string_length : string -> int = \"%string_length\"\nexternal get : bytes -> int -> char = \"%bytes_safe_get\"\nexternal set : bytes -> int -> char -> unit = \"%bytes_safe_set\"\nexternal create : int -> bytes = \"caml_create_bytes\"\nexternal unsafe_get : bytes -> int -> char = \"%bytes_unsafe_get\"\nexternal unsafe_set : bytes -> int -> char -> unit = \"%bytes_unsafe_set\"\nexternal unsafe_fill : bytes -> int -> int -> char -> unit\n = \"caml_fill_bytes\" [@@noalloc]\nexternal unsafe_to_string : bytes -> string = \"%bytes_to_string\"\nexternal unsafe_of_string : string -> bytes = \"%bytes_of_string\"\n\nexternal unsafe_blit : bytes -> int -> bytes -> int -> int -> unit\n = \"caml_blit_bytes\" [@@noalloc]\nexternal unsafe_blit_string : string -> int -> bytes -> int -> int -> unit\n = \"caml_blit_string\" [@@noalloc]\n\nlet make n c =\n let s = create n in\n unsafe_fill s 0 n c;\n s\n\nlet init n f =\n let s = create n in\n for i = 0 to n - 1 do\n unsafe_set s i (f i)\n done;\n s\n\nlet empty = create 0\n\nlet copy s =\n let len = length s in\n let r = create len in\n unsafe_blit s 0 r 0 len;\n r\n\nlet to_string b = unsafe_to_string (copy b)\nlet of_string s = copy (unsafe_of_string s)\n\nlet sub s ofs len =\n if ofs < 0 || len < 0 || ofs > length s - len\n then invalid_arg \"String.sub / Bytes.sub\"\n else begin\n let r = create len in\n unsafe_blit s ofs r 0 len;\n r\n end\n\nlet sub_string b ofs len = unsafe_to_string (sub b ofs len)\n\n(* addition with an overflow check *)\nlet (++) a b =\n let c = a + b in\n match a < 0, b < 0, c < 0 with\n | true , true , false\n | false, false, true -> invalid_arg \"Bytes.extend\" (* overflow *)\n | _ -> c\n\nlet extend s left right =\n let len = length s ++ left ++ right in\n let r = create len in\n let (srcoff, dstoff) = if left < 0 then -left, 0 else 0, left in\n let cpylen = Int.min (length s - srcoff) (len - dstoff) in\n if cpylen > 0 then unsafe_blit s srcoff r dstoff cpylen;\n r\n\nlet fill s ofs len c =\n if ofs < 0 || len < 0 || ofs > length s - len\n then invalid_arg \"String.fill / Bytes.fill\"\n else unsafe_fill s ofs len c\n\nlet blit s1 ofs1 s2 ofs2 len =\n if len < 0 || ofs1 < 0 || ofs1 > length s1 - len\n || ofs2 < 0 || ofs2 > length s2 - len\n then invalid_arg \"Bytes.blit\"\n else unsafe_blit s1 ofs1 s2 ofs2 len\n\nlet blit_string s1 ofs1 s2 ofs2 len =\n if len < 0 || ofs1 < 0 || ofs1 > string_length s1 - len\n || ofs2 < 0 || ofs2 > length s2 - len\n then invalid_arg \"String.blit / Bytes.blit_string\"\n else unsafe_blit_string s1 ofs1 s2 ofs2 len\n\n(* duplicated in string.ml *)\nlet iter f a =\n for i = 0 to length a - 1 do f(unsafe_get a i) done\n\n(* duplicated in string.ml *)\nlet iteri f a =\n for i = 0 to length a - 1 do f i (unsafe_get a i) done\n\nlet ensure_ge (x:int) y = if x >= y then x else invalid_arg \"Bytes.concat\"\n\nlet rec sum_lengths acc seplen = function\n | [] -> acc\n | hd :: [] -> length hd + acc\n | hd :: tl -> sum_lengths (ensure_ge (length hd + seplen + acc) acc) seplen tl\n\nlet rec unsafe_blits dst pos sep seplen = function\n [] -> dst\n | hd :: [] ->\n unsafe_blit hd 0 dst pos (length hd); dst\n | hd :: tl ->\n unsafe_blit hd 0 dst pos (length hd);\n unsafe_blit sep 0 dst (pos + length hd) seplen;\n unsafe_blits dst (pos + length hd + seplen) sep seplen tl\n\nlet concat sep = function\n [] -> empty\n | l -> let seplen = length sep in\n unsafe_blits\n (create (sum_lengths 0 seplen l))\n 0 sep seplen l\n\nlet cat s1 s2 =\n let l1 = length s1 in\n let l2 = length s2 in\n let r = create (l1 + l2) in\n unsafe_blit s1 0 r 0 l1;\n unsafe_blit s2 0 r l1 l2;\n r\n\n\nexternal char_code: char -> int = \"%identity\"\nexternal char_chr: int -> char = \"%identity\"\n\nlet is_space = function\n | ' ' | '\\012' | '\\n' | '\\r' | '\\t' -> true\n | _ -> false\n\nlet trim s =\n let len = length s in\n let i = ref 0 in\n while !i < len && is_space (unsafe_get s !i) do\n incr i\n done;\n let j = ref (len - 1) in\n while !j >= !i && is_space (unsafe_get s !j) do\n decr j\n done;\n if !j >= !i then\n sub s !i (!j - !i + 1)\n else\n empty\n\nlet escaped s =\n let n = ref 0 in\n for i = 0 to length s - 1 do\n n := !n +\n (match unsafe_get s i with\n | '\\\"' | '\\\\' | '\\n' | '\\t' | '\\r' | '\\b' -> 2\n | ' ' .. '~' -> 1\n | _ -> 4)\n done;\n if !n = length s then copy s else begin\n let s' = create !n in\n n := 0;\n for i = 0 to length s - 1 do\n begin match unsafe_get s i with\n | ('\\\"' | '\\\\') as c ->\n unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n c\n | '\\n' ->\n unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 'n'\n | '\\t' ->\n unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 't'\n | '\\r' ->\n unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 'r'\n | '\\b' ->\n unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 'b'\n | (' ' .. '~') as c -> unsafe_set s' !n c\n | c ->\n let a = char_code c in\n unsafe_set s' !n '\\\\';\n incr n;\n unsafe_set s' !n (char_chr (48 + a / 100));\n incr n;\n unsafe_set s' !n (char_chr (48 + (a / 10) mod 10));\n incr n;\n unsafe_set s' !n (char_chr (48 + a mod 10));\n end;\n incr n\n done;\n s'\n end\n\nlet map f s =\n let l = length s in\n if l = 0 then s else begin\n let r = create l in\n for i = 0 to l - 1 do unsafe_set r i (f (unsafe_get s i)) done;\n r\n end\n\nlet mapi f s =\n let l = length s in\n if l = 0 then s else begin\n let r = create l in\n for i = 0 to l - 1 do unsafe_set r i (f i (unsafe_get s i)) done;\n r\n end\n\nlet fold_left f x a =\n let r = ref x in\n for i = 0 to length a - 1 do\n r := f !r (unsafe_get a i)\n done;\n !r\n\nlet fold_right f a x =\n let r = ref x in\n for i = length a - 1 downto 0 do\n r := f (unsafe_get a i) !r\n done;\n !r\n\nlet exists p s =\n let n = length s in\n let rec loop i =\n if i = n then false\n else if p (unsafe_get s i) then true\n else loop (succ i) in\n loop 0\n\nlet for_all p s =\n let n = length s in\n let rec loop i =\n if i = n then true\n else if p (unsafe_get s i) then loop (succ i)\n else false in\n loop 0\n\nlet uppercase_ascii s = map Char.uppercase_ascii s\nlet lowercase_ascii s = map Char.lowercase_ascii s\n\nlet apply1 f s =\n if length s = 0 then s else begin\n let r = copy s in\n unsafe_set r 0 (f(unsafe_get s 0));\n r\n end\n\nlet capitalize_ascii s = apply1 Char.uppercase_ascii s\nlet uncapitalize_ascii s = apply1 Char.lowercase_ascii s\n\n(* duplicated in string.ml *)\nlet starts_with ~prefix s =\n let len_s = length s\n and len_pre = length prefix in\n let rec aux i =\n if i = len_pre then true\n else if unsafe_get s i <> unsafe_get prefix i then false\n else aux (i + 1)\n in len_s >= len_pre && aux 0\n\n(* duplicated in string.ml *)\nlet ends_with ~suffix s =\n let len_s = length s\n and len_suf = length suffix in\n let diff = len_s - len_suf in\n let rec aux i =\n if i = len_suf then true\n else if unsafe_get s (diff + i) <> unsafe_get suffix i then false\n else aux (i + 1)\n in diff >= 0 && aux 0\n\n(* duplicated in string.ml *)\nlet rec index_rec s lim i c =\n if i >= lim then raise Not_found else\n if unsafe_get s i = c then i else index_rec s lim (i + 1) c\n\n(* duplicated in string.ml *)\nlet index s c = index_rec s (length s) 0 c\n\n(* duplicated in string.ml *)\nlet rec index_rec_opt s lim i c =\n if i >= lim then None else\n if unsafe_get s i = c then Some i else index_rec_opt s lim (i + 1) c\n\n(* duplicated in string.ml *)\nlet index_opt s c = index_rec_opt s (length s) 0 c\n\n(* duplicated in string.ml *)\nlet index_from s i c =\n let l = length s in\n if i < 0 || i > l then invalid_arg \"String.index_from / Bytes.index_from\" else\n index_rec s l i c\n\n(* duplicated in string.ml *)\nlet index_from_opt s i c =\n let l = length s in\n if i < 0 || i > l then\n invalid_arg \"String.index_from_opt / Bytes.index_from_opt\"\n else\n index_rec_opt s l i c\n\n(* duplicated in string.ml *)\nlet rec rindex_rec s i c =\n if i < 0 then raise Not_found else\n if unsafe_get s i = c then i else rindex_rec s (i - 1) c\n\n(* duplicated in string.ml *)\nlet rindex s c = rindex_rec s (length s - 1) c\n\n(* duplicated in string.ml *)\nlet rindex_from s i c =\n if i < -1 || i >= length s then\n invalid_arg \"String.rindex_from / Bytes.rindex_from\"\n else\n rindex_rec s i c\n\n(* duplicated in string.ml *)\nlet rec rindex_rec_opt s i c =\n if i < 0 then None else\n if unsafe_get s i = c then Some i else rindex_rec_opt s (i - 1) c\n\n(* duplicated in string.ml *)\nlet rindex_opt s c = rindex_rec_opt s (length s - 1) c\n\n(* duplicated in string.ml *)\nlet rindex_from_opt s i c =\n if i < -1 || i >= length s then\n invalid_arg \"String.rindex_from_opt / Bytes.rindex_from_opt\"\n else\n rindex_rec_opt s i c\n\n\n(* duplicated in string.ml *)\nlet contains_from s i c =\n let l = length s in\n if i < 0 || i > l then\n invalid_arg \"String.contains_from / Bytes.contains_from\"\n else\n try ignore (index_rec s l i c); true with Not_found -> false\n\n\n(* duplicated in string.ml *)\nlet contains s c = contains_from s 0 c\n\n(* duplicated in string.ml *)\nlet rcontains_from s i c =\n if i < 0 || i >= length s then\n invalid_arg \"String.rcontains_from / Bytes.rcontains_from\"\n else\n try ignore (rindex_rec s i c); true with Not_found -> false\n\n\ntype t = bytes\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nexternal equal : t -> t -> bool = \"caml_bytes_equal\" [@@noalloc]\n\n(* duplicated in string.ml *)\nlet split_on_char sep s =\n let r = ref [] in\n let j = ref (length s) in\n for i = length s - 1 downto 0 do\n if unsafe_get s i = sep then begin\n r := sub s (i + 1) (!j - i - 1) :: !r;\n j := i\n end\n done;\n sub s 0 !j :: !r\n\n(* Deprecated functions implemented via other deprecated functions *)\n[@@@ocaml.warning \"-3\"]\nlet uppercase s = map Char.uppercase s\nlet lowercase s = map Char.lowercase s\n\nlet capitalize s = apply1 Char.uppercase s\nlet uncapitalize s = apply1 Char.lowercase s\n\n(** {1 Iterators} *)\n\nlet to_seq s =\n let rec aux i () =\n if i = length s then Seq.Nil\n else\n let x = get s i in\n Seq.Cons (x, aux (i+1))\n in\n aux 0\n\nlet to_seqi s =\n let rec aux i () =\n if i = length s then Seq.Nil\n else\n let x = get s i in\n Seq.Cons ((i,x), aux (i+1))\n in\n aux 0\n\nlet of_seq i =\n let n = ref 0 in\n let buf = ref (make 256 '\\000') in\n let resize () =\n (* resize *)\n let new_len = Int.min (2 * length !buf) Sys.max_string_length in\n if length !buf = new_len then failwith \"Bytes.of_seq: cannot grow bytes\";\n let new_buf = make new_len '\\000' in\n blit !buf 0 new_buf 0 !n;\n buf := new_buf\n in\n Seq.iter\n (fun c ->\n if !n = length !buf then resize();\n set !buf !n c;\n incr n)\n i;\n sub !buf 0 !n\n\n(** {6 Binary encoding/decoding of integers} *)\n\n(* The get_ functions are all duplicated in string.ml *)\n\nexternal unsafe_get_uint8 : bytes -> int -> int = \"%bytes_unsafe_get\"\nexternal unsafe_get_uint16_ne : bytes -> int -> int = \"%caml_bytes_get16u\"\nexternal get_uint8 : bytes -> int -> int = \"%bytes_safe_get\"\nexternal get_uint16_ne : bytes -> int -> int = \"%caml_bytes_get16\"\nexternal get_int32_ne : bytes -> int -> int32 = \"%caml_bytes_get32\"\nexternal get_int64_ne : bytes -> int -> int64 = \"%caml_bytes_get64\"\n\nexternal unsafe_set_uint8 : bytes -> int -> int -> unit = \"%bytes_unsafe_set\"\nexternal unsafe_set_uint16_ne : bytes -> int -> int -> unit\n = \"%caml_bytes_set16u\"\nexternal set_int8 : bytes -> int -> int -> unit = \"%bytes_safe_set\"\nexternal set_int16_ne : bytes -> int -> int -> unit = \"%caml_bytes_set16\"\nexternal set_int32_ne : bytes -> int -> int32 -> unit = \"%caml_bytes_set32\"\nexternal set_int64_ne : bytes -> int -> int64 -> unit = \"%caml_bytes_set64\"\nexternal swap16 : int -> int = \"%bswap16\"\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\n\nlet unsafe_get_uint16_le b i =\n if Sys.big_endian\n then swap16 (unsafe_get_uint16_ne b i)\n else unsafe_get_uint16_ne b i\n\nlet unsafe_get_uint16_be b i =\n if Sys.big_endian\n then unsafe_get_uint16_ne b i\n else swap16 (unsafe_get_uint16_ne b i)\n\nlet get_int8 b i =\n ((get_uint8 b i) lsl (Sys.int_size - 8)) asr (Sys.int_size - 8)\n\nlet get_uint16_le b i =\n if Sys.big_endian then swap16 (get_uint16_ne b i)\n else get_uint16_ne b i\n\nlet get_uint16_be b i =\n if not Sys.big_endian then swap16 (get_uint16_ne b i)\n else get_uint16_ne b i\n\nlet get_int16_ne b i =\n ((get_uint16_ne b i) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int16_le b i =\n ((get_uint16_le b i) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int16_be b i =\n ((get_uint16_be b i) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int32_le b i =\n if Sys.big_endian then swap32 (get_int32_ne b i)\n else get_int32_ne b i\n\nlet get_int32_be b i =\n if not Sys.big_endian then swap32 (get_int32_ne b i)\n else get_int32_ne b i\n\nlet get_int64_le b i =\n if Sys.big_endian then swap64 (get_int64_ne b i)\n else get_int64_ne b i\n\nlet get_int64_be b i =\n if not Sys.big_endian then swap64 (get_int64_ne b i)\n else get_int64_ne b i\n\nlet unsafe_set_uint16_le b i x =\n if Sys.big_endian\n then unsafe_set_uint16_ne b i (swap16 x)\n else unsafe_set_uint16_ne b i x\n\nlet unsafe_set_uint16_be b i x =\n if Sys.big_endian\n then unsafe_set_uint16_ne b i x else\n unsafe_set_uint16_ne b i (swap16 x)\n\nlet set_int16_le b i x =\n if Sys.big_endian then set_int16_ne b i (swap16 x)\n else set_int16_ne b i x\n\nlet set_int16_be b i x =\n if not Sys.big_endian then set_int16_ne b i (swap16 x)\n else set_int16_ne b i x\n\nlet set_int32_le b i x =\n if Sys.big_endian then set_int32_ne b i (swap32 x)\n else set_int32_ne b i x\n\nlet set_int32_be b i x =\n if not Sys.big_endian then set_int32_ne b i (swap32 x)\n else set_int32_ne b i x\n\nlet set_int64_le b i x =\n if Sys.big_endian then set_int64_ne b i (swap64 x)\n else set_int64_ne b i x\n\nlet set_int64_be b i x =\n if not Sys.big_endian then set_int64_ne b i (swap64 x)\n else set_int64_ne b i x\n\nlet set_uint8 = set_int8\nlet set_uint16_ne = set_int16_ne\nlet set_uint16_be = set_int16_be\nlet set_uint16_le = set_int16_le\n\n(* UTF codecs and validations *)\n\nlet dec_invalid = Uchar.utf_decode_invalid\nlet[@inline] dec_ret n u = Uchar.utf_decode n (Uchar.unsafe_of_int u)\n\n(* In case of decoding error, if we error on the first byte, we\n consume the byte, otherwise we consume the [n] bytes preceeding\n the erroring byte.\n\n This means that if a client uses decodes without caring about\n validity it naturally replace bogus data with Uchar.rep according\n to the WHATWG Encoding standard. Other schemes are possible by\n consulting the number of used bytes on invalid decodes. For more\n details see https://hsivonen.fi/broken-utf-8/\n\n For this reason in [get_utf_8_uchar] we gradually check the next\n byte is available rather than doing it immediately after the\n first byte. Contrast with [is_valid_utf_8]. *)\n\n(* UTF-8 *)\n\nlet[@inline] not_in_x80_to_xBF b = b lsr 6 <> 0b10\nlet[@inline] not_in_xA0_to_xBF b = b lsr 5 <> 0b101\nlet[@inline] not_in_x80_to_x9F b = b lsr 5 <> 0b100\nlet[@inline] not_in_x90_to_xBF b = b < 0x90 || 0xBF < b\nlet[@inline] not_in_x80_to_x8F b = b lsr 4 <> 0x8\n\nlet[@inline] utf_8_uchar_2 b0 b1 =\n ((b0 land 0x1F) lsl 6) lor\n ((b1 land 0x3F))\n\nlet[@inline] utf_8_uchar_3 b0 b1 b2 =\n ((b0 land 0x0F) lsl 12) lor\n ((b1 land 0x3F) lsl 6) lor\n ((b2 land 0x3F))\n\nlet[@inline] utf_8_uchar_4 b0 b1 b2 b3 =\n ((b0 land 0x07) lsl 18) lor\n ((b1 land 0x3F) lsl 12) lor\n ((b2 land 0x3F) lsl 6) lor\n ((b3 land 0x3F))\n\nlet get_utf_8_uchar b i =\n let b0 = get_uint8 b i in (* raises if [i] is not a valid index. *)\n let get = unsafe_get_uint8 in\n let max = length b - 1 in\n match Char.unsafe_chr b0 with (* See The Unicode Standard, Table 3.7 *)\n | '\\x00' .. '\\x7F' -> dec_ret 1 b0\n | '\\xC2' .. '\\xDF' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x80_to_xBF b1 then dec_invalid 1 else\n dec_ret 2 (utf_8_uchar_2 b0 b1)\n | '\\xE0' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_xA0_to_xBF b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n dec_ret 3 (utf_8_uchar_3 b0 b1 b2)\n | '\\xE1' .. '\\xEC' | '\\xEE' .. '\\xEF' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x80_to_xBF b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n dec_ret 3 (utf_8_uchar_3 b0 b1 b2)\n | '\\xED' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x80_to_x9F b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n dec_ret 3 (utf_8_uchar_3 b0 b1 b2)\n | '\\xF0' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x90_to_xBF b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n let i = i + 1 in if i > max then dec_invalid 3 else\n let b3 = get b i in if not_in_x80_to_xBF b3 then dec_invalid 3 else\n dec_ret 4 (utf_8_uchar_4 b0 b1 b2 b3)\n | '\\xF1' .. '\\xF3' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x80_to_xBF b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n let i = i + 1 in if i > max then dec_invalid 3 else\n let b3 = get b i in if not_in_x80_to_xBF b3 then dec_invalid 3 else\n dec_ret 4 (utf_8_uchar_4 b0 b1 b2 b3)\n | '\\xF4' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x80_to_x8F b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n let i = i + 1 in if i > max then dec_invalid 3 else\n let b3 = get b i in if not_in_x80_to_xBF b3 then dec_invalid 3 else\n dec_ret 4 (utf_8_uchar_4 b0 b1 b2 b3)\n | _ -> dec_invalid 1\n\nlet set_utf_8_uchar b i u =\n let set = unsafe_set_uint8 in\n let max = length b - 1 in\n match Uchar.to_int u with\n | u when u < 0 -> assert false\n | u when u <= 0x007F ->\n set_uint8 b i u;\n 1\n | u when u <= 0x07FF ->\n let last = i + 1 in\n if last > max then 0 else\n (set_uint8 b i (0xC0 lor (u lsr 6));\n set b last (0x80 lor (u land 0x3F));\n 2)\n | u when u <= 0xFFFF ->\n let last = i + 2 in\n if last > max then 0 else\n (set_uint8 b i (0xE0 lor (u lsr 12));\n set b (i + 1) (0x80 lor ((u lsr 6) land 0x3F));\n set b last (0x80 lor (u land 0x3F));\n 3)\n | u when u <= 0x10FFFF ->\n let last = i + 3 in\n if last > max then 0 else\n (set_uint8 b i (0xF0 lor (u lsr 18));\n set b (i + 1) (0x80 lor ((u lsr 12) land 0x3F));\n set b (i + 2) (0x80 lor ((u lsr 6) land 0x3F));\n set b last (0x80 lor (u land 0x3F));\n 4)\n | _ -> assert false\n\nlet is_valid_utf_8 b =\n let rec loop max b i =\n if i > max then true else\n let get = unsafe_get_uint8 in\n match Char.unsafe_chr (get b i) with\n | '\\x00' .. '\\x7F' -> loop max b (i + 1)\n | '\\xC2' .. '\\xDF' ->\n let last = i + 1 in\n if last > max\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xE0' ->\n let last = i + 2 in\n if last > max\n || not_in_xA0_to_xBF (get b (i + 1))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xE1' .. '\\xEC' | '\\xEE' .. '\\xEF' ->\n let last = i + 2 in\n if last > max\n || not_in_x80_to_xBF (get b (i + 1))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xED' ->\n let last = i + 2 in\n if last > max\n || not_in_x80_to_x9F (get b (i + 1))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xF0' ->\n let last = i + 3 in\n if last > max\n || not_in_x90_to_xBF (get b (i + 1))\n || not_in_x80_to_xBF (get b (i + 2))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xF1' .. '\\xF3' ->\n let last = i + 3 in\n if last > max\n || not_in_x80_to_xBF (get b (i + 1))\n || not_in_x80_to_xBF (get b (i + 2))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xF4' ->\n let last = i + 3 in\n if last > max\n || not_in_x80_to_x8F (get b (i + 1))\n || not_in_x80_to_xBF (get b (i + 2))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | _ -> false\n in\n loop (length b - 1) b 0\n\n(* UTF-16BE *)\n\nlet get_utf_16be_uchar b i =\n let get = unsafe_get_uint16_be in\n let max = length b - 1 in\n if i < 0 || i > max then invalid_arg \"index out of bounds\" else\n if i = max then dec_invalid 1 else\n match get b i with\n | u when u < 0xD800 || u > 0xDFFF -> dec_ret 2 u\n | u when u > 0xDBFF -> dec_invalid 2\n | hi -> (* combine [hi] with a low surrogate *)\n let last = i + 3 in\n if last > max then dec_invalid (max - i + 1) else\n match get b (i + 2) with\n | u when u < 0xDC00 || u > 0xDFFF -> dec_invalid 2 (* retry here *)\n | lo ->\n let u = (((hi land 0x3FF) lsl 10) lor (lo land 0x3FF)) + 0x10000 in\n dec_ret 4 u\n\nlet set_utf_16be_uchar b i u =\n let set = unsafe_set_uint16_be in\n let max = length b - 1 in\n if i < 0 || i > max then invalid_arg \"index out of bounds\" else\n match Uchar.to_int u with\n | u when u < 0 -> assert false\n | u when u <= 0xFFFF ->\n let last = i + 1 in\n if last > max then 0 else (set b i u; 2)\n | u when u <= 0x10FFFF ->\n let last = i + 3 in\n if last > max then 0 else\n let u' = u - 0x10000 in\n let hi = (0xD800 lor (u' lsr 10)) in\n let lo = (0xDC00 lor (u' land 0x3FF)) in\n set b i hi; set b (i + 2) lo; 4\n | _ -> assert false\n\nlet is_valid_utf_16be b =\n let rec loop max b i =\n let get = unsafe_get_uint16_be in\n if i > max then true else\n if i = max then false else\n match get b i with\n | u when u < 0xD800 || u > 0xDFFF -> loop max b (i + 2)\n | u when u > 0xDBFF -> false\n | _hi ->\n let last = i + 3 in\n if last > max then false else\n match get b (i + 2) with\n | u when u < 0xDC00 || u > 0xDFFF -> false\n | _lo -> loop max b (i + 4)\n in\n loop (length b - 1) b 0\n\n(* UTF-16LE *)\n\nlet get_utf_16le_uchar b i =\n let get = unsafe_get_uint16_le in\n let max = length b - 1 in\n if i < 0 || i > max then invalid_arg \"index out of bounds\" else\n if i = max then dec_invalid 1 else\n match get b i with\n | u when u < 0xD800 || u > 0xDFFF -> dec_ret 2 u\n | u when u > 0xDBFF -> dec_invalid 2\n | hi -> (* combine [hi] with a low surrogate *)\n let last = i + 3 in\n if last > max then dec_invalid (max - i + 1) else\n match get b (i + 2) with\n | u when u < 0xDC00 || u > 0xDFFF -> dec_invalid 2 (* retry here *)\n | lo ->\n let u = (((hi land 0x3FF) lsl 10) lor (lo land 0x3FF)) + 0x10000 in\n dec_ret 4 u\n\nlet set_utf_16le_uchar b i u =\n let set = unsafe_set_uint16_le in\n let max = length b - 1 in\n if i < 0 || i > max then invalid_arg \"index out of bounds\" else\n match Uchar.to_int u with\n | u when u < 0 -> assert false\n | u when u <= 0xFFFF ->\n let last = i + 1 in\n if last > max then 0 else (set b i u; 2)\n | u when u <= 0x10FFFF ->\n let last = i + 3 in\n if last > max then 0 else\n let u' = u - 0x10000 in\n let hi = (0xD800 lor (u' lsr 10)) in\n let lo = (0xDC00 lor (u' land 0x3FF)) in\n set b i hi; set b (i + 2) lo; 4\n | _ -> assert false\n\nlet is_valid_utf_16le b =\n let rec loop max b i =\n let get = unsafe_get_uint16_le in\n if i > max then true else\n if i = max then false else\n match get b i with\n | u when u < 0xD800 || u > 0xDFFF -> loop max b (i + 2)\n | u when u > 0xDBFF -> false\n | _hi ->\n let last = i + 3 in\n if last > max then false else\n match get b (i + 2) with\n | u when u < 0xDC00 || u > 0xDFFF -> false\n | _lo -> loop max b (i + 4)\n in\n loop (length b - 1) b 0\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Gallium, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2014 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* String operations, based on byte sequence operations *)\n\n(* WARNING: Some functions in this file are duplicated in bytes.ml for\n efficiency reasons. When you modify the one in this file you need to\n modify its duplicate in bytes.ml.\n These functions have a \"duplicated\" comment above their definition.\n*)\n\nexternal length : string -> int = \"%string_length\"\nexternal get : string -> int -> char = \"%string_safe_get\"\nexternal set : bytes -> int -> char -> unit = \"%string_safe_set\"\nexternal create : int -> bytes = \"caml_create_string\"\nexternal unsafe_get : string -> int -> char = \"%string_unsafe_get\"\nexternal unsafe_set : bytes -> int -> char -> unit = \"%string_unsafe_set\"\nexternal unsafe_blit : string -> int -> bytes -> int -> int -> unit\n = \"caml_blit_string\" [@@noalloc]\nexternal unsafe_fill : bytes -> int -> int -> char -> unit\n = \"caml_fill_string\" [@@noalloc]\n\nmodule B = Bytes\n\nlet bts = B.unsafe_to_string\nlet bos = B.unsafe_of_string\n\nlet make n c =\n B.make n c |> bts\nlet init n f =\n B.init n f |> bts\nlet empty = \"\"\nlet copy s =\n B.copy (bos s) |> bts\nlet of_bytes = B.to_string\nlet to_bytes = B.of_string\nlet sub s ofs len =\n B.sub (bos s) ofs len |> bts\nlet fill =\n B.fill\nlet blit =\n B.blit_string\n\nlet ensure_ge (x:int) y = if x >= y then x else invalid_arg \"String.concat\"\n\nlet rec sum_lengths acc seplen = function\n | [] -> acc\n | hd :: [] -> length hd + acc\n | hd :: tl -> sum_lengths (ensure_ge (length hd + seplen + acc) acc) seplen tl\n\nlet rec unsafe_blits dst pos sep seplen = function\n [] -> dst\n | hd :: [] ->\n unsafe_blit hd 0 dst pos (length hd); dst\n | hd :: tl ->\n unsafe_blit hd 0 dst pos (length hd);\n unsafe_blit sep 0 dst (pos + length hd) seplen;\n unsafe_blits dst (pos + length hd + seplen) sep seplen tl\n\nlet concat sep = function\n [] -> \"\"\n | l -> let seplen = length sep in bts @@\n unsafe_blits\n (B.create (sum_lengths 0 seplen l))\n 0 sep seplen l\n\nlet cat = ( ^ )\n\n(* duplicated in bytes.ml *)\nlet iter f s =\n for i = 0 to length s - 1 do f (unsafe_get s i) done\n\n(* duplicated in bytes.ml *)\nlet iteri f s =\n for i = 0 to length s - 1 do f i (unsafe_get s i) done\n\nlet map f s =\n B.map f (bos s) |> bts\nlet mapi f s =\n B.mapi f (bos s) |> bts\nlet fold_right f x a =\n B.fold_right f (bos x) a\nlet fold_left f a x =\n B.fold_left f a (bos x)\nlet exists f s =\n B.exists f (bos s)\nlet for_all f s =\n B.for_all f (bos s)\n\n(* Beware: we cannot use B.trim or B.escape because they always make a\n copy, but String.mli spells out some cases where we are not allowed\n to make a copy. *)\n\nlet is_space = function\n | ' ' | '\\012' | '\\n' | '\\r' | '\\t' -> true\n | _ -> false\n\nlet trim s =\n if s = \"\" then s\n else if is_space (unsafe_get s 0) || is_space (unsafe_get s (length s - 1))\n then bts (B.trim (bos s))\n else s\n\nlet escaped s =\n let rec escape_if_needed s n i =\n if i >= n then s else\n match unsafe_get s i with\n | '\\\"' | '\\\\' | '\\000'..'\\031' | '\\127'.. '\\255' ->\n bts (B.escaped (bos s))\n | _ -> escape_if_needed s n (i+1)\n in\n escape_if_needed s (length s) 0\n\n(* duplicated in bytes.ml *)\nlet rec index_rec s lim i c =\n if i >= lim then raise Not_found else\n if unsafe_get s i = c then i else index_rec s lim (i + 1) c\n\n(* duplicated in bytes.ml *)\nlet index s c = index_rec s (length s) 0 c\n\n(* duplicated in bytes.ml *)\nlet rec index_rec_opt s lim i c =\n if i >= lim then None else\n if unsafe_get s i = c then Some i else index_rec_opt s lim (i + 1) c\n\n(* duplicated in bytes.ml *)\nlet index_opt s c = index_rec_opt s (length s) 0 c\n\n(* duplicated in bytes.ml *)\nlet index_from s i c =\n let l = length s in\n if i < 0 || i > l then invalid_arg \"String.index_from / Bytes.index_from\" else\n index_rec s l i c\n\n(* duplicated in bytes.ml *)\nlet index_from_opt s i c =\n let l = length s in\n if i < 0 || i > l then\n invalid_arg \"String.index_from_opt / Bytes.index_from_opt\"\n else\n index_rec_opt s l i c\n\n(* duplicated in bytes.ml *)\nlet rec rindex_rec s i c =\n if i < 0 then raise Not_found else\n if unsafe_get s i = c then i else rindex_rec s (i - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex s c = rindex_rec s (length s - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex_from s i c =\n if i < -1 || i >= length s then\n invalid_arg \"String.rindex_from / Bytes.rindex_from\"\n else\n rindex_rec s i c\n\n(* duplicated in bytes.ml *)\nlet rec rindex_rec_opt s i c =\n if i < 0 then None else\n if unsafe_get s i = c then Some i else rindex_rec_opt s (i - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex_opt s c = rindex_rec_opt s (length s - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex_from_opt s i c =\n if i < -1 || i >= length s then\n invalid_arg \"String.rindex_from_opt / Bytes.rindex_from_opt\"\n else\n rindex_rec_opt s i c\n\n(* duplicated in bytes.ml *)\nlet contains_from s i c =\n let l = length s in\n if i < 0 || i > l then\n invalid_arg \"String.contains_from / Bytes.contains_from\"\n else\n try ignore (index_rec s l i c); true with Not_found -> false\n\n(* duplicated in bytes.ml *)\nlet contains s c = contains_from s 0 c\n\n(* duplicated in bytes.ml *)\nlet rcontains_from s i c =\n if i < 0 || i >= length s then\n invalid_arg \"String.rcontains_from / Bytes.rcontains_from\"\n else\n try ignore (rindex_rec s i c); true with Not_found -> false\n\nlet uppercase_ascii s =\n B.uppercase_ascii (bos s) |> bts\nlet lowercase_ascii s =\n B.lowercase_ascii (bos s) |> bts\nlet capitalize_ascii s =\n B.capitalize_ascii (bos s) |> bts\nlet uncapitalize_ascii s =\n B.uncapitalize_ascii (bos s) |> bts\n\n(* duplicated in bytes.ml *)\nlet starts_with ~prefix s =\n let len_s = length s\n and len_pre = length prefix in\n let rec aux i =\n if i = len_pre then true\n else if unsafe_get s i <> unsafe_get prefix i then false\n else aux (i + 1)\n in len_s >= len_pre && aux 0\n\n(* duplicated in bytes.ml *)\nlet ends_with ~suffix s =\n let len_s = length s\n and len_suf = length suffix in\n let diff = len_s - len_suf in\n let rec aux i =\n if i = len_suf then true\n else if unsafe_get s (diff + i) <> unsafe_get suffix i then false\n else aux (i + 1)\n in diff >= 0 && aux 0\n\n(* duplicated in bytes.ml *)\nlet split_on_char sep s =\n let r = ref [] in\n let j = ref (length s) in\n for i = length s - 1 downto 0 do\n if unsafe_get s i = sep then begin\n r := sub s (i + 1) (!j - i - 1) :: !r;\n j := i\n end\n done;\n sub s 0 !j :: !r\n\n(* Deprecated functions implemented via other deprecated functions *)\n[@@@ocaml.warning \"-3\"]\nlet uppercase s =\n B.uppercase (bos s) |> bts\nlet lowercase s =\n B.lowercase (bos s) |> bts\nlet capitalize s =\n B.capitalize (bos s) |> bts\nlet uncapitalize s =\n B.uncapitalize (bos s) |> bts\n\ntype t = string\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nexternal equal : string -> string -> bool = \"caml_string_equal\" [@@noalloc]\n\n(** {1 Iterators} *)\n\nlet to_seq s = bos s |> B.to_seq\n\nlet to_seqi s = bos s |> B.to_seqi\n\nlet of_seq g = B.of_seq g |> bts\n\n(* UTF decoders and validators *)\n\nlet get_utf_8_uchar s i = B.get_utf_8_uchar (bos s) i\nlet is_valid_utf_8 s = B.is_valid_utf_8 (bos s)\n\nlet get_utf_16be_uchar s i = B.get_utf_16be_uchar (bos s) i\nlet is_valid_utf_16be s = B.is_valid_utf_16be (bos s)\n\nlet get_utf_16le_uchar s i = B.get_utf_16le_uchar (bos s) i\nlet is_valid_utf_16le s = B.is_valid_utf_16le (bos s)\n\n(** {6 Binary encoding/decoding of integers} *)\n\nexternal get_uint8 : string -> int -> int = \"%string_safe_get\"\nexternal get_uint16_ne : string -> int -> int = \"%caml_string_get16\"\nexternal get_int32_ne : string -> int -> int32 = \"%caml_string_get32\"\nexternal get_int64_ne : string -> int -> int64 = \"%caml_string_get64\"\n\nlet get_int8 s i = B.get_int8 (bos s) i\nlet get_uint16_le s i = B.get_uint16_le (bos s) i\nlet get_uint16_be s i = B.get_uint16_be (bos s) i\nlet get_int16_ne s i = B.get_int16_ne (bos s) i\nlet get_int16_le s i = B.get_int16_le (bos s) i\nlet get_int16_be s i = B.get_int16_be (bos s) i\nlet get_int32_le s i = B.get_int32_le (bos s) i\nlet get_int32_be s i = B.get_int32_be (bos s) i\nlet get_int64_le s i = B.get_int64_le (bos s) i\nlet get_int64_be s i = B.get_int64_be (bos s) i\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1997 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype extern_flags =\n No_sharing\n | Closures\n | Compat_32\n(* note: this type definition is used in 'runtime/debugger.c' *)\n\nexternal to_channel: out_channel -> 'a -> extern_flags list -> unit\n = \"caml_output_value\"\nexternal to_bytes: 'a -> extern_flags list -> bytes\n = \"caml_output_value_to_bytes\"\nexternal to_string: 'a -> extern_flags list -> string\n = \"caml_output_value_to_string\"\nexternal to_buffer_unsafe:\n bytes -> int -> int -> 'a -> extern_flags list -> int\n = \"caml_output_value_to_buffer\"\n\nlet to_buffer buff ofs len v flags =\n if ofs < 0 || len < 0 || ofs > Bytes.length buff - len\n then invalid_arg \"Marshal.to_buffer: substring out of bounds\"\n else to_buffer_unsafe buff ofs len v flags\n\n(* The functions below use byte sequences as input, never using any\n mutation. It makes sense to use non-mutated [bytes] rather than\n [string], because we really work with sequences of bytes, not\n a text representation.\n*)\n\nexternal from_channel: in_channel -> 'a = \"caml_input_value\"\nexternal from_bytes_unsafe: bytes -> int -> 'a = \"caml_input_value_from_bytes\"\nexternal data_size_unsafe: bytes -> int -> int = \"caml_marshal_data_size\"\n\nlet header_size = 20\nlet data_size buff ofs =\n if ofs < 0 || ofs > Bytes.length buff - header_size\n then invalid_arg \"Marshal.data_size\"\n else data_size_unsafe buff ofs\nlet total_size buff ofs = header_size + data_size buff ofs\n\nlet from_bytes buff ofs =\n if ofs < 0 || ofs > Bytes.length buff - header_size\n then invalid_arg \"Marshal.from_bytes\"\n else begin\n let len = data_size_unsafe buff ofs in\n if ofs > Bytes.length buff - (header_size + len)\n then invalid_arg \"Marshal.from_bytes\"\n else from_bytes_unsafe buff ofs\n end\n\nlet from_string buff ofs =\n (* Bytes.unsafe_of_string is safe here, as the produced byte\n sequence is never mutated *)\n from_bytes (Bytes.unsafe_of_string buff) ofs\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* An alias for the type of arrays. *)\ntype 'a t = 'a array\n\n(* Array operations *)\n\nexternal length : 'a array -> int = \"%array_length\"\nexternal get: 'a array -> int -> 'a = \"%array_safe_get\"\nexternal set: 'a array -> int -> 'a -> unit = \"%array_safe_set\"\nexternal unsafe_get: 'a array -> int -> 'a = \"%array_unsafe_get\"\nexternal unsafe_set: 'a array -> int -> 'a -> unit = \"%array_unsafe_set\"\nexternal make: int -> 'a -> 'a array = \"caml_make_vect\"\nexternal create: int -> 'a -> 'a array = \"caml_make_vect\"\nexternal unsafe_sub : 'a array -> int -> int -> 'a array = \"caml_array_sub\"\nexternal append_prim : 'a array -> 'a array -> 'a array = \"caml_array_append\"\nexternal concat : 'a array list -> 'a array = \"caml_array_concat\"\nexternal unsafe_blit :\n 'a array -> int -> 'a array -> int -> int -> unit = \"caml_array_blit\"\nexternal unsafe_fill :\n 'a array -> int -> int -> 'a -> unit = \"caml_array_fill\"\nexternal create_float: int -> float array = \"caml_make_float_vect\"\nlet make_float = create_float\n\nmodule Floatarray = struct\n external create : int -> floatarray = \"caml_floatarray_create\"\n external length : floatarray -> int = \"%floatarray_length\"\n external get : floatarray -> int -> float = \"%floatarray_safe_get\"\n external set : floatarray -> int -> float -> unit = \"%floatarray_safe_set\"\n external unsafe_get : floatarray -> int -> float = \"%floatarray_unsafe_get\"\n external unsafe_set : floatarray -> int -> float -> unit\n = \"%floatarray_unsafe_set\"\nend\n\nlet init l f =\n if l = 0 then [||] else\n if l < 0 then invalid_arg \"Array.init\"\n (* See #6575. We could also check for maximum array size, but this depends\n on whether we create a float array or a regular one... *)\n else\n let res = create l (f 0) in\n for i = 1 to pred l do\n unsafe_set res i (f i)\n done;\n res\n\nlet make_matrix sx sy init =\n let res = create sx [||] in\n for x = 0 to pred sx do\n unsafe_set res x (create sy init)\n done;\n res\n\nlet create_matrix = make_matrix\n\nlet copy a =\n let l = length a in if l = 0 then [||] else unsafe_sub a 0 l\n\nlet append a1 a2 =\n let l1 = length a1 in\n if l1 = 0 then copy a2\n else if length a2 = 0 then unsafe_sub a1 0 l1\n else append_prim a1 a2\n\nlet sub a ofs len =\n if ofs < 0 || len < 0 || ofs > length a - len\n then invalid_arg \"Array.sub\"\n else unsafe_sub a ofs len\n\nlet fill a ofs len v =\n if ofs < 0 || len < 0 || ofs > length a - len\n then invalid_arg \"Array.fill\"\n else unsafe_fill a ofs len v\n\nlet blit a1 ofs1 a2 ofs2 len =\n if len < 0 || ofs1 < 0 || ofs1 > length a1 - len\n || ofs2 < 0 || ofs2 > length a2 - len\n then invalid_arg \"Array.blit\"\n else unsafe_blit a1 ofs1 a2 ofs2 len\n\nlet iter f a =\n for i = 0 to length a - 1 do f(unsafe_get a i) done\n\nlet iter2 f a b =\n if length a <> length b then\n invalid_arg \"Array.iter2: arrays must have the same length\"\n else\n for i = 0 to length a - 1 do f (unsafe_get a i) (unsafe_get b i) done\n\nlet map f a =\n let l = length a in\n if l = 0 then [||] else begin\n let r = create l (f(unsafe_get a 0)) in\n for i = 1 to l - 1 do\n unsafe_set r i (f(unsafe_get a i))\n done;\n r\n end\n\nlet map2 f a b =\n let la = length a in\n let lb = length b in\n if la <> lb then\n invalid_arg \"Array.map2: arrays must have the same length\"\n else begin\n if la = 0 then [||] else begin\n let r = create la (f (unsafe_get a 0) (unsafe_get b 0)) in\n for i = 1 to la - 1 do\n unsafe_set r i (f (unsafe_get a i) (unsafe_get b i))\n done;\n r\n end\n end\n\nlet iteri f a =\n for i = 0 to length a - 1 do f i (unsafe_get a i) done\n\nlet mapi f a =\n let l = length a in\n if l = 0 then [||] else begin\n let r = create l (f 0 (unsafe_get a 0)) in\n for i = 1 to l - 1 do\n unsafe_set r i (f i (unsafe_get a i))\n done;\n r\n end\n\nlet to_list a =\n let rec tolist i res =\n if i < 0 then res else tolist (i - 1) (unsafe_get a i :: res) in\n tolist (length a - 1) []\n\n(* Cannot use List.length here because the List module depends on Array. *)\nlet rec list_length accu = function\n | [] -> accu\n | _::t -> list_length (succ accu) t\n\nlet of_list = function\n [] -> [||]\n | hd::tl as l ->\n let a = create (list_length 0 l) hd in\n let rec fill i = function\n [] -> a\n | hd::tl -> unsafe_set a i hd; fill (i+1) tl in\n fill 1 tl\n\nlet fold_left f x a =\n let r = ref x in\n for i = 0 to length a - 1 do\n r := f !r (unsafe_get a i)\n done;\n !r\n\nlet fold_left_map f acc input_array =\n let len = length input_array in\n if len = 0 then (acc, [||]) else begin\n let acc, elt = f acc (unsafe_get input_array 0) in\n let output_array = create len elt in\n let acc = ref acc in\n for i = 1 to len - 1 do\n let acc', elt = f !acc (unsafe_get input_array i) in\n acc := acc';\n unsafe_set output_array i elt;\n done;\n !acc, output_array\n end\n\nlet fold_right f a x =\n let r = ref x in\n for i = length a - 1 downto 0 do\n r := f (unsafe_get a i) !r\n done;\n !r\n\nlet exists p a =\n let n = length a in\n let rec loop i =\n if i = n then false\n else if p (unsafe_get a i) then true\n else loop (succ i) in\n loop 0\n\nlet for_all p a =\n let n = length a in\n let rec loop i =\n if i = n then true\n else if p (unsafe_get a i) then loop (succ i)\n else false in\n loop 0\n\nlet for_all2 p l1 l2 =\n let n1 = length l1\n and n2 = length l2 in\n if n1 <> n2 then invalid_arg \"Array.for_all2\"\n else let rec loop i =\n if i = n1 then true\n else if p (unsafe_get l1 i) (unsafe_get l2 i) then loop (succ i)\n else false in\n loop 0\n\nlet exists2 p l1 l2 =\n let n1 = length l1\n and n2 = length l2 in\n if n1 <> n2 then invalid_arg \"Array.exists2\"\n else let rec loop i =\n if i = n1 then false\n else if p (unsafe_get l1 i) (unsafe_get l2 i) then true\n else loop (succ i) in\n loop 0\n\nlet mem x a =\n let n = length a in\n let rec loop i =\n if i = n then false\n else if compare (unsafe_get a i) x = 0 then true\n else loop (succ i) in\n loop 0\n\nlet memq x a =\n let n = length a in\n let rec loop i =\n if i = n then false\n else if x == (unsafe_get a i) then true\n else loop (succ i) in\n loop 0\n\nlet find_opt p a =\n let n = length a in\n let rec loop i =\n if i = n then None\n else\n let x = unsafe_get a i in\n if p x then Some x\n else loop (succ i)\n in\n loop 0\n\nlet find_map f a =\n let n = length a in\n let rec loop i =\n if i = n then None\n else\n match f (unsafe_get a i) with\n | None -> loop (succ i)\n | Some _ as r -> r\n in\n loop 0\n\nlet split x =\n if x = [||] then [||], [||]\n else begin\n let a0, b0 = unsafe_get x 0 in\n let n = length x in\n let a = create n a0 in\n let b = create n b0 in\n for i = 1 to n - 1 do\n let ai, bi = unsafe_get x i in\n unsafe_set a i ai;\n unsafe_set b i bi\n done;\n a, b\n end\n\nlet combine a b =\n let na = length a in\n let nb = length b in\n if na <> nb then invalid_arg \"Array.combine\";\n if na = 0 then [||]\n else begin\n let x = create na (unsafe_get a 0, unsafe_get b 0) in\n for i = 1 to na - 1 do\n unsafe_set x i (unsafe_get a i, unsafe_get b i)\n done;\n x\n end\n\nexception Bottom of int\nlet sort cmp a =\n let maxson l i =\n let i31 = i+i+i+1 in\n let x = ref i31 in\n if i31+2 < l then begin\n if cmp (get a i31) (get a (i31+1)) < 0 then x := i31+1;\n if cmp (get a !x) (get a (i31+2)) < 0 then x := i31+2;\n !x\n end else\n if i31+1 < l && cmp (get a i31) (get a (i31+1)) < 0\n then i31+1\n else if i31 < l then i31 else raise (Bottom i)\n in\n let rec trickledown l i e =\n let j = maxson l i in\n if cmp (get a j) e > 0 then begin\n set a i (get a j);\n trickledown l j e;\n end else begin\n set a i e;\n end;\n in\n let trickle l i e = try trickledown l i e with Bottom i -> set a i e in\n let rec bubbledown l i =\n let j = maxson l i in\n set a i (get a j);\n bubbledown l j\n in\n let bubble l i = try bubbledown l i with Bottom i -> i in\n let rec trickleup i e =\n let father = (i - 1) / 3 in\n assert (i <> father);\n if cmp (get a father) e < 0 then begin\n set a i (get a father);\n if father > 0 then trickleup father e else set a 0 e;\n end else begin\n set a i e;\n end;\n in\n let l = length a in\n for i = (l + 1) / 3 - 1 downto 0 do trickle l i (get a i); done;\n for i = l - 1 downto 2 do\n let e = (get a i) in\n set a i (get a 0);\n trickleup (bubble i 0) e;\n done;\n if l > 1 then (let e = (get a 1) in set a 1 (get a 0); set a 0 e)\n\n\nlet cutoff = 5\nlet stable_sort cmp a =\n let merge src1ofs src1len src2 src2ofs src2len dst dstofs =\n let src1r = src1ofs + src1len and src2r = src2ofs + src2len in\n let rec loop i1 s1 i2 s2 d =\n if cmp s1 s2 <= 0 then begin\n set dst d s1;\n let i1 = i1 + 1 in\n if i1 < src1r then\n loop i1 (get a i1) i2 s2 (d + 1)\n else\n blit src2 i2 dst (d + 1) (src2r - i2)\n end else begin\n set dst d s2;\n let i2 = i2 + 1 in\n if i2 < src2r then\n loop i1 s1 i2 (get src2 i2) (d + 1)\n else\n blit a i1 dst (d + 1) (src1r - i1)\n end\n in loop src1ofs (get a src1ofs) src2ofs (get src2 src2ofs) dstofs;\n in\n let isortto srcofs dst dstofs len =\n for i = 0 to len - 1 do\n let e = (get a (srcofs + i)) in\n let j = ref (dstofs + i - 1) in\n while (!j >= dstofs && cmp (get dst !j) e > 0) do\n set dst (!j + 1) (get dst !j);\n decr j;\n done;\n set dst (!j + 1) e;\n done;\n in\n let rec sortto srcofs dst dstofs len =\n if len <= cutoff then isortto srcofs dst dstofs len else begin\n let l1 = len / 2 in\n let l2 = len - l1 in\n sortto (srcofs + l1) dst (dstofs + l1) l2;\n sortto srcofs a (srcofs + l2) l1;\n merge (srcofs + l2) l1 dst (dstofs + l1) l2 dst dstofs;\n end;\n in\n let l = length a in\n if l <= cutoff then isortto 0 a 0 l else begin\n let l1 = l / 2 in\n let l2 = l - l1 in\n let t = make l2 (get a 0) in\n sortto l1 t 0 l2;\n sortto 0 a l2 l1;\n merge l2 l1 t 0 l2 a 0;\n end\n\n\nlet fast_sort = stable_sort\n\n(** {1 Iterators} *)\n\nlet to_seq a =\n let rec aux i () =\n if i < length a\n then\n let x = unsafe_get a i in\n Seq.Cons (x, aux (i+1))\n else Seq.Nil\n in\n aux 0\n\nlet to_seqi a =\n let rec aux i () =\n if i < length a\n then\n let x = unsafe_get a i in\n Seq.Cons ((i,x), aux (i+1))\n else Seq.Nil\n in\n aux 0\n\nlet of_rev_list = function\n [] -> [||]\n | hd::tl as l ->\n let len = list_length 0 l in\n let a = create len hd in\n let rec fill i = function\n [] -> a\n | hd::tl -> unsafe_set a i hd; fill (i-1) tl\n in\n fill (len-2) tl\n\nlet of_seq i =\n let l = Seq.fold_left (fun acc x -> x::acc) [] i in\n of_rev_list l\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Int32]: 32-bit integers *)\n\nexternal neg : int32 -> int32 = \"%int32_neg\"\nexternal add : int32 -> int32 -> int32 = \"%int32_add\"\nexternal sub : int32 -> int32 -> int32 = \"%int32_sub\"\nexternal mul : int32 -> int32 -> int32 = \"%int32_mul\"\nexternal div : int32 -> int32 -> int32 = \"%int32_div\"\nexternal rem : int32 -> int32 -> int32 = \"%int32_mod\"\nexternal logand : int32 -> int32 -> int32 = \"%int32_and\"\nexternal logor : int32 -> int32 -> int32 = \"%int32_or\"\nexternal logxor : int32 -> int32 -> int32 = \"%int32_xor\"\nexternal shift_left : int32 -> int -> int32 = \"%int32_lsl\"\nexternal shift_right : int32 -> int -> int32 = \"%int32_asr\"\nexternal shift_right_logical : int32 -> int -> int32 = \"%int32_lsr\"\nexternal of_int : int -> int32 = \"%int32_of_int\"\nexternal to_int : int32 -> int = \"%int32_to_int\"\nexternal of_float : float -> int32\n = \"caml_int32_of_float\" \"caml_int32_of_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal to_float : int32 -> float\n = \"caml_int32_to_float\" \"caml_int32_to_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal bits_of_float : float -> int32\n = \"caml_int32_bits_of_float\" \"caml_int32_bits_of_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal float_of_bits : int32 -> float\n = \"caml_int32_float_of_bits\" \"caml_int32_float_of_bits_unboxed\"\n [@@unboxed] [@@noalloc]\n\nlet zero = 0l\nlet one = 1l\nlet minus_one = -1l\nlet succ n = add n 1l\nlet pred n = sub n 1l\nlet abs n = if n >= 0l then n else neg n\nlet min_int = 0x80000000l\nlet max_int = 0x7FFFFFFFl\nlet lognot n = logxor n (-1l)\n\nlet unsigned_to_int =\n match Sys.word_size with\n | 32 ->\n let max_int = of_int Stdlib.max_int in\n fun n ->\n if compare zero n <= 0 && compare n max_int <= 0 then\n Some (to_int n)\n else\n None\n | 64 ->\n (* So that it compiles in 32-bit *)\n let mask = 0xFFFF lsl 16 lor 0xFFFF in\n fun n -> Some (to_int n land mask)\n | _ ->\n assert false\n\nexternal format : string -> int32 -> string = \"caml_int32_format\"\nlet to_string n = format \"%d\" n\n\nexternal of_string : string -> int32 = \"caml_int32_of_string\"\n\nlet of_string_opt s =\n (* TODO: expose a non-raising primitive directly. *)\n try Some (of_string s)\n with Failure _ -> None\n\ntype t = int32\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nlet equal (x: t) (y: t) = compare x y = 0\n\nlet unsigned_compare n m =\n compare (sub n min_int) (sub m min_int)\n\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\n\n(* Unsigned division from signed division of the same\n bitness. See Warren Jr., Henry S. (2013). Hacker's Delight (2 ed.), Sec 9-3.\n*)\nlet unsigned_div n d =\n if d < zero then\n if unsigned_compare n d < 0 then zero else one\n else\n let q = shift_left (div (shift_right_logical n 1) d) 1 in\n let r = sub n (mul q d) in\n if unsigned_compare r d >= 0 then succ q else q\n\nlet unsigned_rem n d =\n sub n (mul (unsigned_div n d) d)\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Nativeint]: processor-native integers *)\n\nexternal neg: nativeint -> nativeint = \"%nativeint_neg\"\nexternal add: nativeint -> nativeint -> nativeint = \"%nativeint_add\"\nexternal sub: nativeint -> nativeint -> nativeint = \"%nativeint_sub\"\nexternal mul: nativeint -> nativeint -> nativeint = \"%nativeint_mul\"\nexternal div: nativeint -> nativeint -> nativeint = \"%nativeint_div\"\nexternal rem: nativeint -> nativeint -> nativeint = \"%nativeint_mod\"\nexternal logand: nativeint -> nativeint -> nativeint = \"%nativeint_and\"\nexternal logor: nativeint -> nativeint -> nativeint = \"%nativeint_or\"\nexternal logxor: nativeint -> nativeint -> nativeint = \"%nativeint_xor\"\nexternal shift_left: nativeint -> int -> nativeint = \"%nativeint_lsl\"\nexternal shift_right: nativeint -> int -> nativeint = \"%nativeint_asr\"\nexternal shift_right_logical: nativeint -> int -> nativeint = \"%nativeint_lsr\"\nexternal of_int: int -> nativeint = \"%nativeint_of_int\"\nexternal to_int: nativeint -> int = \"%nativeint_to_int\"\nexternal of_float : float -> nativeint\n = \"caml_nativeint_of_float\" \"caml_nativeint_of_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal to_float : nativeint -> float\n = \"caml_nativeint_to_float\" \"caml_nativeint_to_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal of_int32: int32 -> nativeint = \"%nativeint_of_int32\"\nexternal to_int32: nativeint -> int32 = \"%nativeint_to_int32\"\n\nlet zero = 0n\nlet one = 1n\nlet minus_one = -1n\nlet succ n = add n 1n\nlet pred n = sub n 1n\nlet abs n = if n >= 0n then n else neg n\nlet size = Sys.word_size\nlet min_int = shift_left 1n (size - 1)\nlet max_int = sub min_int 1n\nlet lognot n = logxor n (-1n)\n\nlet unsigned_to_int =\n let max_int = of_int Stdlib.max_int in\n fun n ->\n if compare zero n <= 0 && compare n max_int <= 0 then\n Some (to_int n)\n else\n None\n\nexternal format : string -> nativeint -> string = \"caml_nativeint_format\"\nlet to_string n = format \"%d\" n\n\nexternal of_string: string -> nativeint = \"caml_nativeint_of_string\"\n\nlet of_string_opt s =\n (* TODO: expose a non-raising primitive directly. *)\n try Some (of_string s)\n with Failure _ -> None\n\ntype t = nativeint\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nlet equal (x: t) (y: t) = compare x y = 0\n\nlet unsigned_compare n m =\n compare (sub n min_int) (sub m min_int)\n\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\n\n(* Unsigned division from signed division of the same\n bitness. See Warren Jr., Henry S. (2013). Hacker's Delight (2 ed.), Sec 9-3.\n*)\nlet unsigned_div n d =\n if d < zero then\n if unsigned_compare n d < 0 then zero else one\n else\n let q = shift_left (div (shift_right_logical n 1) d) 1 in\n let r = sub n (mul q d) in\n if unsigned_compare r d >= 0 then succ q else q\n\nlet unsigned_rem n d =\n sub n (mul (unsigned_div n d) d)\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* The parsing engine *)\n\nopen Lexing\n\n(* Internal interface to the parsing engine *)\n\ntype parser_env =\n { mutable s_stack : int array; (* States *)\n mutable v_stack : Obj.t array; (* Semantic attributes *)\n mutable symb_start_stack : position array; (* Start positions *)\n mutable symb_end_stack : position array; (* End positions *)\n mutable stacksize : int; (* Size of the stacks *)\n mutable stackbase : int; (* Base sp for current parse *)\n mutable curr_char : int; (* Last token read *)\n mutable lval : Obj.t; (* Its semantic attribute *)\n mutable symb_start : position; (* Start pos. of the current symbol*)\n mutable symb_end : position; (* End pos. of the current symbol *)\n mutable asp : int; (* The stack pointer for attributes *)\n mutable rule_len : int; (* Number of rhs items in the rule *)\n mutable rule_number : int; (* Rule number to reduce by *)\n mutable sp : int; (* Saved sp for parse_engine *)\n mutable state : int; (* Saved state for parse_engine *)\n mutable errflag : int } (* Saved error flag for parse_engine *)\n[@@warning \"-unused-field\"]\n\ntype parse_tables =\n { actions : (parser_env -> Obj.t) array;\n transl_const : int array;\n transl_block : int array;\n lhs : string;\n len : string;\n defred : string;\n dgoto : string;\n sindex : string;\n rindex : string;\n gindex : string;\n tablesize : int;\n table : string;\n check : string;\n error_function : string -> unit;\n names_const : string;\n names_block : string }\n\nexception YYexit of Obj.t\nexception Parse_error\n\ntype parser_input =\n Start\n | Token_read\n | Stacks_grown_1\n | Stacks_grown_2\n | Semantic_action_computed\n | Error_detected\n\ntype parser_output =\n Read_token\n | Raise_parse_error\n | Grow_stacks_1\n | Grow_stacks_2\n | Compute_semantic_action\n | Call_error_function\n\n(* to avoid warnings *)\nlet _ = [Read_token; Raise_parse_error; Grow_stacks_1; Grow_stacks_2;\n Compute_semantic_action; Call_error_function]\n\nexternal parse_engine :\n parse_tables -> parser_env -> parser_input -> Obj.t -> parser_output\n = \"caml_parse_engine\"\n\nexternal set_trace: bool -> bool\n = \"caml_set_parser_trace\"\n\nlet env =\n { s_stack = Array.make 100 0;\n v_stack = Array.make 100 (Obj.repr ());\n symb_start_stack = Array.make 100 dummy_pos;\n symb_end_stack = Array.make 100 dummy_pos;\n stacksize = 100;\n stackbase = 0;\n curr_char = 0;\n lval = Obj.repr ();\n symb_start = dummy_pos;\n symb_end = dummy_pos;\n asp = 0;\n rule_len = 0;\n rule_number = 0;\n sp = 0;\n state = 0;\n errflag = 0 }\n\nlet grow_stacks() =\n let oldsize = env.stacksize in\n let newsize = oldsize * 2 in\n let new_s = Array.make newsize 0\n and new_v = Array.make newsize (Obj.repr ())\n and new_start = Array.make newsize dummy_pos\n and new_end = Array.make newsize dummy_pos in\n Array.blit env.s_stack 0 new_s 0 oldsize;\n env.s_stack <- new_s;\n Array.blit env.v_stack 0 new_v 0 oldsize;\n env.v_stack <- new_v;\n Array.blit env.symb_start_stack 0 new_start 0 oldsize;\n env.symb_start_stack <- new_start;\n Array.blit env.symb_end_stack 0 new_end 0 oldsize;\n env.symb_end_stack <- new_end;\n env.stacksize <- newsize\n\nlet clear_parser() =\n Array.fill env.v_stack 0 env.stacksize (Obj.repr ());\n env.lval <- Obj.repr ()\n\nlet current_lookahead_fun = ref (fun (_ : Obj.t) -> false)\n\nlet yyparse tables start lexer lexbuf =\n let rec loop cmd arg =\n match parse_engine tables env cmd arg with\n Read_token ->\n let t = Obj.repr(lexer lexbuf) in\n env.symb_start <- lexbuf.lex_start_p;\n env.symb_end <- lexbuf.lex_curr_p;\n loop Token_read t\n | Raise_parse_error ->\n raise Parse_error\n | Compute_semantic_action ->\n let (action, value) =\n try\n (Semantic_action_computed, tables.actions.(env.rule_number) env)\n with Parse_error ->\n (Error_detected, Obj.repr ()) in\n loop action value\n | Grow_stacks_1 ->\n grow_stacks(); loop Stacks_grown_1 (Obj.repr ())\n | Grow_stacks_2 ->\n grow_stacks(); loop Stacks_grown_2 (Obj.repr ())\n | Call_error_function ->\n tables.error_function \"syntax error\";\n loop Error_detected (Obj.repr ()) in\n let init_asp = env.asp\n and init_sp = env.sp\n and init_stackbase = env.stackbase\n and init_state = env.state\n and init_curr_char = env.curr_char\n and init_lval = env.lval\n and init_errflag = env.errflag in\n env.stackbase <- env.sp + 1;\n env.curr_char <- start;\n env.symb_end <- lexbuf.lex_curr_p;\n try\n loop Start (Obj.repr ())\n with exn ->\n let curr_char = env.curr_char in\n env.asp <- init_asp;\n env.sp <- init_sp;\n env.stackbase <- init_stackbase;\n env.state <- init_state;\n env.curr_char <- init_curr_char;\n env.lval <- init_lval;\n env.errflag <- init_errflag;\n match exn with\n YYexit v ->\n Obj.magic v\n | _ ->\n current_lookahead_fun :=\n (fun tok ->\n if Obj.is_block tok\n then tables.transl_block.(Obj.tag tok) = curr_char\n else tables.transl_const.(Obj.magic tok) = curr_char);\n raise exn\n\nlet peek_val env n =\n Obj.magic env.v_stack.(env.asp - n)\n\nlet symbol_start_pos () =\n let rec loop i =\n if i <= 0 then env.symb_end_stack.(env.asp)\n else begin\n let st = env.symb_start_stack.(env.asp - i + 1) in\n let en = env.symb_end_stack.(env.asp - i + 1) in\n if st <> en then st else loop (i - 1)\n end\n in\n loop env.rule_len\n\nlet symbol_end_pos () = env.symb_end_stack.(env.asp)\nlet rhs_start_pos n = env.symb_start_stack.(env.asp - (env.rule_len - n))\nlet rhs_end_pos n = env.symb_end_stack.(env.asp - (env.rule_len - n))\n\nlet symbol_start () = (symbol_start_pos ()).pos_cnum\nlet symbol_end () = (symbol_end_pos ()).pos_cnum\nlet rhs_start n = (rhs_start_pos n).pos_cnum\nlet rhs_end n = (rhs_end_pos n).pos_cnum\n\nlet is_current_lookahead tok =\n (!current_lookahead_fun)(Obj.repr tok)\n\nlet parse_error (_ : string) = ()\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Sets over ordered types *)\n\nmodule type OrderedType =\n sig\n type t\n val compare: t -> t -> int\n end\n\nmodule type S =\n sig\n type elt\n type t\n val empty: t\n val is_empty: t -> bool\n val mem: elt -> t -> bool\n val add: elt -> t -> t\n val singleton: elt -> t\n val remove: elt -> t -> t\n val union: t -> t -> t\n val inter: t -> t -> t\n val disjoint: t -> t -> bool\n val diff: t -> t -> t\n val compare: t -> t -> int\n val equal: t -> t -> bool\n val subset: t -> t -> bool\n val iter: (elt -> unit) -> t -> unit\n val map: (elt -> elt) -> t -> t\n val fold: (elt -> 'a -> 'a) -> t -> 'a -> 'a\n val for_all: (elt -> bool) -> t -> bool\n val exists: (elt -> bool) -> t -> bool\n val filter: (elt -> bool) -> t -> t\n val filter_map: (elt -> elt option) -> t -> t\n val partition: (elt -> bool) -> t -> t * t\n val cardinal: t -> int\n val elements: t -> elt list\n val min_elt: t -> elt\n val min_elt_opt: t -> elt option\n val max_elt: t -> elt\n val max_elt_opt: t -> elt option\n val choose: t -> elt\n val choose_opt: t -> elt option\n val split: elt -> t -> t * bool * t\n val find: elt -> t -> elt\n val find_opt: elt -> t -> elt option\n val find_first: (elt -> bool) -> t -> elt\n val find_first_opt: (elt -> bool) -> t -> elt option\n val find_last: (elt -> bool) -> t -> elt\n val find_last_opt: (elt -> bool) -> t -> elt option\n val of_list: elt list -> t\n val to_seq_from : elt -> t -> elt Seq.t\n val to_seq : t -> elt Seq.t\n val to_rev_seq : t -> elt Seq.t\n val add_seq : elt Seq.t -> t -> t\n val of_seq : elt Seq.t -> t\n end\n\nmodule Make(Ord: OrderedType) =\n struct\n type elt = Ord.t\n type t = Empty | Node of {l:t; v:elt; r:t; h:int}\n\n (* Sets are represented by balanced binary trees (the heights of the\n children differ by at most 2 *)\n\n let height = function\n Empty -> 0\n | Node {h} -> h\n\n (* Creates a new node with left son l, value v and right son r.\n We must have all elements of l < v < all elements of r.\n l and r must be balanced and | height l - height r | <= 2.\n Inline expansion of height for better speed. *)\n\n let create l v r =\n let hl = match l with Empty -> 0 | Node {h} -> h in\n let hr = match r with Empty -> 0 | Node {h} -> h in\n Node{l; v; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n (* Same as create, but performs one step of rebalancing if necessary.\n Assumes l and r balanced and | height l - height r | <= 3.\n Inline expansion of create for better speed in the most frequent case\n where no rebalancing is required. *)\n\n let bal l v r =\n let hl = match l with Empty -> 0 | Node {h} -> h in\n let hr = match r with Empty -> 0 | Node {h} -> h in\n if hl > hr + 2 then begin\n match l with\n Empty -> invalid_arg \"Set.bal\"\n | Node{l=ll; v=lv; r=lr} ->\n if height ll >= height lr then\n create ll lv (create lr v r)\n else begin\n match lr with\n Empty -> invalid_arg \"Set.bal\"\n | Node{l=lrl; v=lrv; r=lrr}->\n create (create ll lv lrl) lrv (create lrr v r)\n end\n end else if hr > hl + 2 then begin\n match r with\n Empty -> invalid_arg \"Set.bal\"\n | Node{l=rl; v=rv; r=rr} ->\n if height rr >= height rl then\n create (create l v rl) rv rr\n else begin\n match rl with\n Empty -> invalid_arg \"Set.bal\"\n | Node{l=rll; v=rlv; r=rlr} ->\n create (create l v rll) rlv (create rlr rv rr)\n end\n end else\n Node{l; v; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n (* Insertion of one element *)\n\n let rec add x = function\n Empty -> Node{l=Empty; v=x; r=Empty; h=1}\n | Node{l; v; r} as t ->\n let c = Ord.compare x v in\n if c = 0 then t else\n if c < 0 then\n let ll = add x l in\n if l == ll then t else bal ll v r\n else\n let rr = add x r in\n if r == rr then t else bal l v rr\n\n let singleton x = Node{l=Empty; v=x; r=Empty; h=1}\n\n (* Beware: those two functions assume that the added v is *strictly*\n smaller (or bigger) than all the present elements in the tree; it\n does not test for equality with the current min (or max) element.\n Indeed, they are only used during the \"join\" operation which\n respects this precondition.\n *)\n\n let rec add_min_element x = function\n | Empty -> singleton x\n | Node {l; v; r} ->\n bal (add_min_element x l) v r\n\n let rec add_max_element x = function\n | Empty -> singleton x\n | Node {l; v; r} ->\n bal l v (add_max_element x r)\n\n (* Same as create and bal, but no assumptions are made on the\n relative heights of l and r. *)\n\n let rec join l v r =\n match (l, r) with\n (Empty, _) -> add_min_element v r\n | (_, Empty) -> add_max_element v l\n | (Node{l=ll; v=lv; r=lr; h=lh}, Node{l=rl; v=rv; r=rr; h=rh}) ->\n if lh > rh + 2 then bal ll lv (join lr v r) else\n if rh > lh + 2 then bal (join l v rl) rv rr else\n create l v r\n\n (* Smallest and greatest element of a set *)\n\n let rec min_elt = function\n Empty -> raise Not_found\n | Node{l=Empty; v} -> v\n | Node{l} -> min_elt l\n\n let rec min_elt_opt = function\n Empty -> None\n | Node{l=Empty; v} -> Some v\n | Node{l} -> min_elt_opt l\n\n let rec max_elt = function\n Empty -> raise Not_found\n | Node{v; r=Empty} -> v\n | Node{r} -> max_elt r\n\n let rec max_elt_opt = function\n Empty -> None\n | Node{v; r=Empty} -> Some v\n | Node{r} -> max_elt_opt r\n\n (* Remove the smallest element of the given set *)\n\n let rec remove_min_elt = function\n Empty -> invalid_arg \"Set.remove_min_elt\"\n | Node{l=Empty; r} -> r\n | Node{l; v; r} -> bal (remove_min_elt l) v r\n\n (* Merge two trees l and r into one.\n All elements of l must precede the elements of r.\n Assume | height l - height r | <= 2. *)\n\n let merge t1 t2 =\n match (t1, t2) with\n (Empty, t) -> t\n | (t, Empty) -> t\n | (_, _) -> bal t1 (min_elt t2) (remove_min_elt t2)\n\n (* Merge two trees l and r into one.\n All elements of l must precede the elements of r.\n No assumption on the heights of l and r. *)\n\n let concat t1 t2 =\n match (t1, t2) with\n (Empty, t) -> t\n | (t, Empty) -> t\n | (_, _) -> join t1 (min_elt t2) (remove_min_elt t2)\n\n (* Splitting. split x s returns a triple (l, present, r) where\n - l is the set of elements of s that are < x\n - r is the set of elements of s that are > x\n - present is false if s contains no element equal to x,\n or true if s contains an element equal to x. *)\n\n let rec split x = function\n Empty ->\n (Empty, false, Empty)\n | Node{l; v; r} ->\n let c = Ord.compare x v in\n if c = 0 then (l, true, r)\n else if c < 0 then\n let (ll, pres, rl) = split x l in (ll, pres, join rl v r)\n else\n let (lr, pres, rr) = split x r in (join l v lr, pres, rr)\n\n (* Implementation of the set operations *)\n\n let empty = Empty\n\n let is_empty = function Empty -> true | _ -> false\n\n let rec mem x = function\n Empty -> false\n | Node{l; v; r} ->\n let c = Ord.compare x v in\n c = 0 || mem x (if c < 0 then l else r)\n\n let rec remove x = function\n Empty -> Empty\n | (Node{l; v; r} as t) ->\n let c = Ord.compare x v in\n if c = 0 then merge l r\n else\n if c < 0 then\n let ll = remove x l in\n if l == ll then t\n else bal ll v r\n else\n let rr = remove x r in\n if r == rr then t\n else bal l v rr\n\n let rec union s1 s2 =\n match (s1, s2) with\n (Empty, t2) -> t2\n | (t1, Empty) -> t1\n | (Node{l=l1; v=v1; r=r1; h=h1}, Node{l=l2; v=v2; r=r2; h=h2}) ->\n if h1 >= h2 then\n if h2 = 1 then add v2 s1 else begin\n let (l2, _, r2) = split v1 s2 in\n join (union l1 l2) v1 (union r1 r2)\n end\n else\n if h1 = 1 then add v1 s2 else begin\n let (l1, _, r1) = split v2 s1 in\n join (union l1 l2) v2 (union r1 r2)\n end\n\n let rec inter s1 s2 =\n match (s1, s2) with\n (Empty, _) -> Empty\n | (_, Empty) -> Empty\n | (Node{l=l1; v=v1; r=r1}, t2) ->\n match split v1 t2 with\n (l2, false, r2) ->\n concat (inter l1 l2) (inter r1 r2)\n | (l2, true, r2) ->\n join (inter l1 l2) v1 (inter r1 r2)\n\n (* Same as split, but compute the left and right subtrees\n only if the pivot element is not in the set. The right subtree\n is computed on demand. *)\n\n type split_bis =\n | Found\n | NotFound of t * (unit -> t)\n\n let rec split_bis x = function\n Empty ->\n NotFound (Empty, (fun () -> Empty))\n | Node{l; v; r; _} ->\n let c = Ord.compare x v in\n if c = 0 then Found\n else if c < 0 then\n match split_bis x l with\n | Found -> Found\n | NotFound (ll, rl) -> NotFound (ll, (fun () -> join (rl ()) v r))\n else\n match split_bis x r with\n | Found -> Found\n | NotFound (lr, rr) -> NotFound (join l v lr, rr)\n\n let rec disjoint s1 s2 =\n match (s1, s2) with\n (Empty, _) | (_, Empty) -> true\n | (Node{l=l1; v=v1; r=r1}, t2) ->\n if s1 == s2 then false\n else match split_bis v1 t2 with\n NotFound(l2, r2) -> disjoint l1 l2 && disjoint r1 (r2 ())\n | Found -> false\n\n let rec diff s1 s2 =\n match (s1, s2) with\n (Empty, _) -> Empty\n | (t1, Empty) -> t1\n | (Node{l=l1; v=v1; r=r1}, t2) ->\n match split v1 t2 with\n (l2, false, r2) ->\n join (diff l1 l2) v1 (diff r1 r2)\n | (l2, true, r2) ->\n concat (diff l1 l2) (diff r1 r2)\n\n type enumeration = End | More of elt * t * enumeration\n\n let rec cons_enum s e =\n match s with\n Empty -> e\n | Node{l; v; r} -> cons_enum l (More(v, r, e))\n\n let rec compare_aux e1 e2 =\n match (e1, e2) with\n (End, End) -> 0\n | (End, _) -> -1\n | (_, End) -> 1\n | (More(v1, r1, e1), More(v2, r2, e2)) ->\n let c = Ord.compare v1 v2 in\n if c <> 0\n then c\n else compare_aux (cons_enum r1 e1) (cons_enum r2 e2)\n\n let compare s1 s2 =\n compare_aux (cons_enum s1 End) (cons_enum s2 End)\n\n let equal s1 s2 =\n compare s1 s2 = 0\n\n let rec subset s1 s2 =\n match (s1, s2) with\n Empty, _ ->\n true\n | _, Empty ->\n false\n | Node {l=l1; v=v1; r=r1}, (Node {l=l2; v=v2; r=r2} as t2) ->\n let c = Ord.compare v1 v2 in\n if c = 0 then\n subset l1 l2 && subset r1 r2\n else if c < 0 then\n subset (Node {l=l1; v=v1; r=Empty; h=0}) l2 && subset r1 t2\n else\n subset (Node {l=Empty; v=v1; r=r1; h=0}) r2 && subset l1 t2\n\n let rec iter f = function\n Empty -> ()\n | Node{l; v; r} -> iter f l; f v; iter f r\n\n let rec fold f s accu =\n match s with\n Empty -> accu\n | Node{l; v; r} -> fold f r (f v (fold f l accu))\n\n let rec for_all p = function\n Empty -> true\n | Node{l; v; r} -> p v && for_all p l && for_all p r\n\n let rec exists p = function\n Empty -> false\n | Node{l; v; r} -> p v || exists p l || exists p r\n\n let rec filter p = function\n Empty -> Empty\n | (Node{l; v; r}) as t ->\n (* call [p] in the expected left-to-right order *)\n let l' = filter p l in\n let pv = p v in\n let r' = filter p r in\n if pv then\n if l==l' && r==r' then t else join l' v r'\n else concat l' r'\n\n let rec partition p = function\n Empty -> (Empty, Empty)\n | Node{l; v; r} ->\n (* call [p] in the expected left-to-right order *)\n let (lt, lf) = partition p l in\n let pv = p v in\n let (rt, rf) = partition p r in\n if pv\n then (join lt v rt, concat lf rf)\n else (concat lt rt, join lf v rf)\n\n let rec cardinal = function\n Empty -> 0\n | Node{l; r} -> cardinal l + 1 + cardinal r\n\n let rec elements_aux accu = function\n Empty -> accu\n | Node{l; v; r} -> elements_aux (v :: elements_aux accu r) l\n\n let elements s =\n elements_aux [] s\n\n let choose = min_elt\n\n let choose_opt = min_elt_opt\n\n let rec find x = function\n Empty -> raise Not_found\n | Node{l; v; r} ->\n let c = Ord.compare x v in\n if c = 0 then v\n else find x (if c < 0 then l else r)\n\n let rec find_first_aux v0 f = function\n Empty ->\n v0\n | Node{l; v; r} ->\n if f v then\n find_first_aux v f l\n else\n find_first_aux v0 f r\n\n let rec find_first f = function\n Empty ->\n raise Not_found\n | Node{l; v; r} ->\n if f v then\n find_first_aux v f l\n else\n find_first f r\n\n let rec find_first_opt_aux v0 f = function\n Empty ->\n Some v0\n | Node{l; v; r} ->\n if f v then\n find_first_opt_aux v f l\n else\n find_first_opt_aux v0 f r\n\n let rec find_first_opt f = function\n Empty ->\n None\n | Node{l; v; r} ->\n if f v then\n find_first_opt_aux v f l\n else\n find_first_opt f r\n\n let rec find_last_aux v0 f = function\n Empty ->\n v0\n | Node{l; v; r} ->\n if f v then\n find_last_aux v f r\n else\n find_last_aux v0 f l\n\n let rec find_last f = function\n Empty ->\n raise Not_found\n | Node{l; v; r} ->\n if f v then\n find_last_aux v f r\n else\n find_last f l\n\n let rec find_last_opt_aux v0 f = function\n Empty ->\n Some v0\n | Node{l; v; r} ->\n if f v then\n find_last_opt_aux v f r\n else\n find_last_opt_aux v0 f l\n\n let rec find_last_opt f = function\n Empty ->\n None\n | Node{l; v; r} ->\n if f v then\n find_last_opt_aux v f r\n else\n find_last_opt f l\n\n let rec find_opt x = function\n Empty -> None\n | Node{l; v; r} ->\n let c = Ord.compare x v in\n if c = 0 then Some v\n else find_opt x (if c < 0 then l else r)\n\n let try_join l v r =\n (* [join l v r] can only be called when (elements of l < v <\n elements of r); use [try_join l v r] when this property may\n not hold, but you hope it does hold in the common case *)\n if (l = Empty || Ord.compare (max_elt l) v < 0)\n && (r = Empty || Ord.compare v (min_elt r) < 0)\n then join l v r\n else union l (add v r)\n\n let rec map f = function\n | Empty -> Empty\n | Node{l; v; r} as t ->\n (* enforce left-to-right evaluation order *)\n let l' = map f l in\n let v' = f v in\n let r' = map f r in\n if l == l' && v == v' && r == r' then t\n else try_join l' v' r'\n\n let try_concat t1 t2 =\n match (t1, t2) with\n (Empty, t) -> t\n | (t, Empty) -> t\n | (_, _) -> try_join t1 (min_elt t2) (remove_min_elt t2)\n\n let rec filter_map f = function\n | Empty -> Empty\n | Node{l; v; r} as t ->\n (* enforce left-to-right evaluation order *)\n let l' = filter_map f l in\n let v' = f v in\n let r' = filter_map f r in\n begin match v' with\n | Some v' ->\n if l == l' && v == v' && r == r' then t\n else try_join l' v' r'\n | None ->\n try_concat l' r'\n end\n\n let of_sorted_list l =\n let rec sub n l =\n match n, l with\n | 0, l -> Empty, l\n | 1, x0 :: l -> Node {l=Empty; v=x0; r=Empty; h=1}, l\n | 2, x0 :: x1 :: l ->\n Node{l=Node{l=Empty; v=x0; r=Empty; h=1}; v=x1; r=Empty; h=2}, l\n | 3, x0 :: x1 :: x2 :: l ->\n Node{l=Node{l=Empty; v=x0; r=Empty; h=1}; v=x1;\n r=Node{l=Empty; v=x2; r=Empty; h=1}; h=2}, l\n | n, l ->\n let nl = n / 2 in\n let left, l = sub nl l in\n match l with\n | [] -> assert false\n | mid :: l ->\n let right, l = sub (n - nl - 1) l in\n create left mid right, l\n in\n fst (sub (List.length l) l)\n\n let of_list l =\n match l with\n | [] -> empty\n | [x0] -> singleton x0\n | [x0; x1] -> add x1 (singleton x0)\n | [x0; x1; x2] -> add x2 (add x1 (singleton x0))\n | [x0; x1; x2; x3] -> add x3 (add x2 (add x1 (singleton x0)))\n | [x0; x1; x2; x3; x4] -> add x4 (add x3 (add x2 (add x1 (singleton x0))))\n | _ -> of_sorted_list (List.sort_uniq Ord.compare l)\n\n let add_seq i m =\n Seq.fold_left (fun s x -> add x s) m i\n\n let of_seq i = add_seq i empty\n\n let rec seq_of_enum_ c () = match c with\n | End -> Seq.Nil\n | More (x, t, rest) -> Seq.Cons (x, seq_of_enum_ (cons_enum t rest))\n\n let to_seq c = seq_of_enum_ (cons_enum c End)\n\n let rec snoc_enum s e =\n match s with\n Empty -> e\n | Node{l; v; r} -> snoc_enum r (More(v, l, e))\n\n let rec rev_seq_of_enum_ c () = match c with\n | End -> Seq.Nil\n | More (x, t, rest) -> Seq.Cons (x, rev_seq_of_enum_ (snoc_enum t rest))\n\n let to_rev_seq c = rev_seq_of_enum_ (snoc_enum c End)\n\n let to_seq_from low s =\n let rec aux low s c = match s with\n | Empty -> c\n | Node {l; r; v; _} ->\n begin match Ord.compare v low with\n | 0 -> More (v, r, c)\n | n when n<0 -> aux low r c\n | _ -> aux low l (More (v, r, c))\n end\n in\n seq_of_enum_ (aux low s End)\n end\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule type OrderedType =\n sig\n type t\n val compare: t -> t -> int\n end\n\nmodule type S =\n sig\n type key\n type !+'a t\n val empty: 'a t\n val is_empty: 'a t -> bool\n val mem: key -> 'a t -> bool\n val add: key -> 'a -> 'a t -> 'a t\n val update: key -> ('a option -> 'a option) -> 'a t -> 'a t\n val singleton: key -> 'a -> 'a t\n val remove: key -> 'a t -> 'a t\n val merge:\n (key -> 'a option -> 'b option -> 'c option) -> 'a t -> 'b t -> 'c t\n val union: (key -> 'a -> 'a -> 'a option) -> 'a t -> 'a t -> 'a t\n val compare: ('a -> 'a -> int) -> 'a t -> 'a t -> int\n val equal: ('a -> 'a -> bool) -> 'a t -> 'a t -> bool\n val iter: (key -> 'a -> unit) -> 'a t -> unit\n val fold: (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n val for_all: (key -> 'a -> bool) -> 'a t -> bool\n val exists: (key -> 'a -> bool) -> 'a t -> bool\n val filter: (key -> 'a -> bool) -> 'a t -> 'a t\n val filter_map: (key -> 'a -> 'b option) -> 'a t -> 'b t\n val partition: (key -> 'a -> bool) -> 'a t -> 'a t * 'a t\n val cardinal: 'a t -> int\n val bindings: 'a t -> (key * 'a) list\n val min_binding: 'a t -> (key * 'a)\n val min_binding_opt: 'a t -> (key * 'a) option\n val max_binding: 'a t -> (key * 'a)\n val max_binding_opt: 'a t -> (key * 'a) option\n val choose: 'a t -> (key * 'a)\n val choose_opt: 'a t -> (key * 'a) option\n val split: key -> 'a t -> 'a t * 'a option * 'a t\n val find: key -> 'a t -> 'a\n val find_opt: key -> 'a t -> 'a option\n val find_first: (key -> bool) -> 'a t -> key * 'a\n val find_first_opt: (key -> bool) -> 'a t -> (key * 'a) option\n val find_last: (key -> bool) -> 'a t -> key * 'a\n val find_last_opt: (key -> bool) -> 'a t -> (key * 'a) option\n val map: ('a -> 'b) -> 'a t -> 'b t\n val mapi: (key -> 'a -> 'b) -> 'a t -> 'b t\n val to_seq : 'a t -> (key * 'a) Seq.t\n val to_rev_seq : 'a t -> (key * 'a) Seq.t\n val to_seq_from : key -> 'a t -> (key * 'a) Seq.t\n val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t\n val of_seq : (key * 'a) Seq.t -> 'a t\n end\n\nmodule Make(Ord: OrderedType) = struct\n\n type key = Ord.t\n\n type 'a t =\n Empty\n | Node of {l:'a t; v:key; d:'a; r:'a t; h:int}\n\n let height = function\n Empty -> 0\n | Node {h} -> h\n\n let create l x d r =\n let hl = height l and hr = height r in\n Node{l; v=x; d; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n let singleton x d = Node{l=Empty; v=x; d; r=Empty; h=1}\n\n let bal l x d r =\n let hl = match l with Empty -> 0 | Node {h} -> h in\n let hr = match r with Empty -> 0 | Node {h} -> h in\n if hl > hr + 2 then begin\n match l with\n Empty -> invalid_arg \"Map.bal\"\n | Node{l=ll; v=lv; d=ld; r=lr} ->\n if height ll >= height lr then\n create ll lv ld (create lr x d r)\n else begin\n match lr with\n Empty -> invalid_arg \"Map.bal\"\n | Node{l=lrl; v=lrv; d=lrd; r=lrr}->\n create (create ll lv ld lrl) lrv lrd (create lrr x d r)\n end\n end else if hr > hl + 2 then begin\n match r with\n Empty -> invalid_arg \"Map.bal\"\n | Node{l=rl; v=rv; d=rd; r=rr} ->\n if height rr >= height rl then\n create (create l x d rl) rv rd rr\n else begin\n match rl with\n Empty -> invalid_arg \"Map.bal\"\n | Node{l=rll; v=rlv; d=rld; r=rlr} ->\n create (create l x d rll) rlv rld (create rlr rv rd rr)\n end\n end else\n Node{l; v=x; d; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n let empty = Empty\n\n let is_empty = function Empty -> true | _ -> false\n\n let rec add x data = function\n Empty ->\n Node{l=Empty; v=x; d=data; r=Empty; h=1}\n | Node {l; v; d; r; h} as m ->\n let c = Ord.compare x v in\n if c = 0 then\n if d == data then m else Node{l; v=x; d=data; r; h}\n else if c < 0 then\n let ll = add x data l in\n if l == ll then m else bal ll v d r\n else\n let rr = add x data r in\n if r == rr then m else bal l v d rr\n\n let rec find x = function\n Empty ->\n raise Not_found\n | Node {l; v; d; r} ->\n let c = Ord.compare x v in\n if c = 0 then d\n else find x (if c < 0 then l else r)\n\n let rec find_first_aux v0 d0 f = function\n Empty ->\n (v0, d0)\n | Node {l; v; d; r} ->\n if f v then\n find_first_aux v d f l\n else\n find_first_aux v0 d0 f r\n\n let rec find_first f = function\n Empty ->\n raise Not_found\n | Node {l; v; d; r} ->\n if f v then\n find_first_aux v d f l\n else\n find_first f r\n\n let rec find_first_opt_aux v0 d0 f = function\n Empty ->\n Some (v0, d0)\n | Node {l; v; d; r} ->\n if f v then\n find_first_opt_aux v d f l\n else\n find_first_opt_aux v0 d0 f r\n\n let rec find_first_opt f = function\n Empty ->\n None\n | Node {l; v; d; r} ->\n if f v then\n find_first_opt_aux v d f l\n else\n find_first_opt f r\n\n let rec find_last_aux v0 d0 f = function\n Empty ->\n (v0, d0)\n | Node {l; v; d; r} ->\n if f v then\n find_last_aux v d f r\n else\n find_last_aux v0 d0 f l\n\n let rec find_last f = function\n Empty ->\n raise Not_found\n | Node {l; v; d; r} ->\n if f v then\n find_last_aux v d f r\n else\n find_last f l\n\n let rec find_last_opt_aux v0 d0 f = function\n Empty ->\n Some (v0, d0)\n | Node {l; v; d; r} ->\n if f v then\n find_last_opt_aux v d f r\n else\n find_last_opt_aux v0 d0 f l\n\n let rec find_last_opt f = function\n Empty ->\n None\n | Node {l; v; d; r} ->\n if f v then\n find_last_opt_aux v d f r\n else\n find_last_opt f l\n\n let rec find_opt x = function\n Empty ->\n None\n | Node {l; v; d; r} ->\n let c = Ord.compare x v in\n if c = 0 then Some d\n else find_opt x (if c < 0 then l else r)\n\n let rec mem x = function\n Empty ->\n false\n | Node {l; v; r} ->\n let c = Ord.compare x v in\n c = 0 || mem x (if c < 0 then l else r)\n\n let rec min_binding = function\n Empty -> raise Not_found\n | Node {l=Empty; v; d} -> (v, d)\n | Node {l} -> min_binding l\n\n let rec min_binding_opt = function\n Empty -> None\n | Node {l=Empty; v; d} -> Some (v, d)\n | Node {l}-> min_binding_opt l\n\n let rec max_binding = function\n Empty -> raise Not_found\n | Node {v; d; r=Empty} -> (v, d)\n | Node {r} -> max_binding r\n\n let rec max_binding_opt = function\n Empty -> None\n | Node {v; d; r=Empty} -> Some (v, d)\n | Node {r} -> max_binding_opt r\n\n let rec remove_min_binding = function\n Empty -> invalid_arg \"Map.remove_min_elt\"\n | Node {l=Empty; r} -> r\n | Node {l; v; d; r} -> bal (remove_min_binding l) v d r\n\n let merge t1 t2 =\n match (t1, t2) with\n (Empty, t) -> t\n | (t, Empty) -> t\n | (_, _) ->\n let (x, d) = min_binding t2 in\n bal t1 x d (remove_min_binding t2)\n\n let rec remove x = function\n Empty ->\n Empty\n | (Node {l; v; d; r} as m) ->\n let c = Ord.compare x v in\n if c = 0 then merge l r\n else if c < 0 then\n let ll = remove x l in if l == ll then m else bal ll v d r\n else\n let rr = remove x r in if r == rr then m else bal l v d rr\n\n let rec update x f = function\n Empty ->\n begin match f None with\n | None -> Empty\n | Some data -> Node{l=Empty; v=x; d=data; r=Empty; h=1}\n end\n | Node {l; v; d; r; h} as m ->\n let c = Ord.compare x v in\n if c = 0 then begin\n match f (Some d) with\n | None -> merge l r\n | Some data ->\n if d == data then m else Node{l; v=x; d=data; r; h}\n end else if c < 0 then\n let ll = update x f l in\n if l == ll then m else bal ll v d r\n else\n let rr = update x f r in\n if r == rr then m else bal l v d rr\n\n let rec iter f = function\n Empty -> ()\n | Node {l; v; d; r} ->\n iter f l; f v d; iter f r\n\n let rec map f = function\n Empty ->\n Empty\n | Node {l; v; d; r; h} ->\n let l' = map f l in\n let d' = f d in\n let r' = map f r in\n Node{l=l'; v; d=d'; r=r'; h}\n\n let rec mapi f = function\n Empty ->\n Empty\n | Node {l; v; d; r; h} ->\n let l' = mapi f l in\n let d' = f v d in\n let r' = mapi f r in\n Node{l=l'; v; d=d'; r=r'; h}\n\n let rec fold f m accu =\n match m with\n Empty -> accu\n | Node {l; v; d; r} ->\n fold f r (f v d (fold f l accu))\n\n let rec for_all p = function\n Empty -> true\n | Node {l; v; d; r} -> p v d && for_all p l && for_all p r\n\n let rec exists p = function\n Empty -> false\n | Node {l; v; d; r} -> p v d || exists p l || exists p r\n\n (* Beware: those two functions assume that the added k is *strictly*\n smaller (or bigger) than all the present keys in the tree; it\n does not test for equality with the current min (or max) key.\n\n Indeed, they are only used during the \"join\" operation which\n respects this precondition.\n *)\n\n let rec add_min_binding k x = function\n | Empty -> singleton k x\n | Node {l; v; d; r} ->\n bal (add_min_binding k x l) v d r\n\n let rec add_max_binding k x = function\n | Empty -> singleton k x\n | Node {l; v; d; r} ->\n bal l v d (add_max_binding k x r)\n\n (* Same as create and bal, but no assumptions are made on the\n relative heights of l and r. *)\n\n let rec join l v d r =\n match (l, r) with\n (Empty, _) -> add_min_binding v d r\n | (_, Empty) -> add_max_binding v d l\n | (Node{l=ll; v=lv; d=ld; r=lr; h=lh},\n Node{l=rl; v=rv; d=rd; r=rr; h=rh}) ->\n if lh > rh + 2 then bal ll lv ld (join lr v d r) else\n if rh > lh + 2 then bal (join l v d rl) rv rd rr else\n create l v d r\n\n (* Merge two trees l and r into one.\n All elements of l must precede the elements of r.\n No assumption on the heights of l and r. *)\n\n let concat t1 t2 =\n match (t1, t2) with\n (Empty, t) -> t\n | (t, Empty) -> t\n | (_, _) ->\n let (x, d) = min_binding t2 in\n join t1 x d (remove_min_binding t2)\n\n let concat_or_join t1 v d t2 =\n match d with\n | Some d -> join t1 v d t2\n | None -> concat t1 t2\n\n let rec split x = function\n Empty ->\n (Empty, None, Empty)\n | Node {l; v; d; r} ->\n let c = Ord.compare x v in\n if c = 0 then (l, Some d, r)\n else if c < 0 then\n let (ll, pres, rl) = split x l in (ll, pres, join rl v d r)\n else\n let (lr, pres, rr) = split x r in (join l v d lr, pres, rr)\n\n let rec merge f s1 s2 =\n match (s1, s2) with\n (Empty, Empty) -> Empty\n | (Node {l=l1; v=v1; d=d1; r=r1; h=h1}, _) when h1 >= height s2 ->\n let (l2, d2, r2) = split v1 s2 in\n concat_or_join (merge f l1 l2) v1 (f v1 (Some d1) d2) (merge f r1 r2)\n | (_, Node {l=l2; v=v2; d=d2; r=r2}) ->\n let (l1, d1, r1) = split v2 s1 in\n concat_or_join (merge f l1 l2) v2 (f v2 d1 (Some d2)) (merge f r1 r2)\n | _ ->\n assert false\n\n let rec union f s1 s2 =\n match (s1, s2) with\n | (Empty, s) | (s, Empty) -> s\n | (Node {l=l1; v=v1; d=d1; r=r1; h=h1},\n Node {l=l2; v=v2; d=d2; r=r2; h=h2}) ->\n if h1 >= h2 then\n let (l2, d2, r2) = split v1 s2 in\n let l = union f l1 l2 and r = union f r1 r2 in\n match d2 with\n | None -> join l v1 d1 r\n | Some d2 -> concat_or_join l v1 (f v1 d1 d2) r\n else\n let (l1, d1, r1) = split v2 s1 in\n let l = union f l1 l2 and r = union f r1 r2 in\n match d1 with\n | None -> join l v2 d2 r\n | Some d1 -> concat_or_join l v2 (f v2 d1 d2) r\n\n let rec filter p = function\n Empty -> Empty\n | Node {l; v; d; r} as m ->\n (* call [p] in the expected left-to-right order *)\n let l' = filter p l in\n let pvd = p v d in\n let r' = filter p r in\n if pvd then if l==l' && r==r' then m else join l' v d r'\n else concat l' r'\n\n let rec filter_map f = function\n Empty -> Empty\n | Node {l; v; d; r} ->\n (* call [f] in the expected left-to-right order *)\n let l' = filter_map f l in\n let fvd = f v d in\n let r' = filter_map f r in\n begin match fvd with\n | Some d' -> join l' v d' r'\n | None -> concat l' r'\n end\n\n let rec partition p = function\n Empty -> (Empty, Empty)\n | Node {l; v; d; r} ->\n (* call [p] in the expected left-to-right order *)\n let (lt, lf) = partition p l in\n let pvd = p v d in\n let (rt, rf) = partition p r in\n if pvd\n then (join lt v d rt, concat lf rf)\n else (concat lt rt, join lf v d rf)\n\n type 'a enumeration = End | More of key * 'a * 'a t * 'a enumeration\n\n let rec cons_enum m e =\n match m with\n Empty -> e\n | Node {l; v; d; r} -> cons_enum l (More(v, d, r, e))\n\n let compare cmp m1 m2 =\n let rec compare_aux e1 e2 =\n match (e1, e2) with\n (End, End) -> 0\n | (End, _) -> -1\n | (_, End) -> 1\n | (More(v1, d1, r1, e1), More(v2, d2, r2, e2)) ->\n let c = Ord.compare v1 v2 in\n if c <> 0 then c else\n let c = cmp d1 d2 in\n if c <> 0 then c else\n compare_aux (cons_enum r1 e1) (cons_enum r2 e2)\n in compare_aux (cons_enum m1 End) (cons_enum m2 End)\n\n let equal cmp m1 m2 =\n let rec equal_aux e1 e2 =\n match (e1, e2) with\n (End, End) -> true\n | (End, _) -> false\n | (_, End) -> false\n | (More(v1, d1, r1, e1), More(v2, d2, r2, e2)) ->\n Ord.compare v1 v2 = 0 && cmp d1 d2 &&\n equal_aux (cons_enum r1 e1) (cons_enum r2 e2)\n in equal_aux (cons_enum m1 End) (cons_enum m2 End)\n\n let rec cardinal = function\n Empty -> 0\n | Node {l; r} -> cardinal l + 1 + cardinal r\n\n let rec bindings_aux accu = function\n Empty -> accu\n | Node {l; v; d; r} -> bindings_aux ((v, d) :: bindings_aux accu r) l\n\n let bindings s =\n bindings_aux [] s\n\n let choose = min_binding\n\n let choose_opt = min_binding_opt\n\n let add_seq i m =\n Seq.fold_left (fun m (k,v) -> add k v m) m i\n\n let of_seq i = add_seq i empty\n\n let rec seq_of_enum_ c () = match c with\n | End -> Seq.Nil\n | More (k,v,t,rest) -> Seq.Cons ((k,v), seq_of_enum_ (cons_enum t rest))\n\n let to_seq m =\n seq_of_enum_ (cons_enum m End)\n\n let rec snoc_enum s e =\n match s with\n Empty -> e\n | Node{l; v; d; r} -> snoc_enum r (More(v, d, l, e))\n\n let rec rev_seq_of_enum_ c () = match c with\n | End -> Seq.Nil\n | More (k,v,t,rest) ->\n Seq.Cons ((k,v), rev_seq_of_enum_ (snoc_enum t rest))\n\n let to_rev_seq c =\n rev_seq_of_enum_ (snoc_enum c End)\n\n let to_seq_from low m =\n let rec aux low m c = match m with\n | Empty -> c\n | Node {l; v; d; r; _} ->\n begin match Ord.compare v low with\n | 0 -> More (v, d, r, c)\n | n when n<0 -> aux low r c\n | _ -> aux low l (More (v, d, r, c))\n end\n in\n seq_of_enum_ (aux low m End)\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype 'a t = { mutable c : 'a list; mutable len : int; }\n\nexception Empty\n\nlet create () = { c = []; len = 0; }\n\nlet clear s = s.c <- []; s.len <- 0\n\nlet copy s = { c = s.c; len = s.len; }\n\nlet push x s = s.c <- x :: s.c; s.len <- s.len + 1\n\nlet pop s =\n match s.c with\n | hd::tl -> s.c <- tl; s.len <- s.len - 1; hd\n | [] -> raise Empty\n\nlet pop_opt s =\n match s.c with\n | hd::tl -> s.c <- tl; s.len <- s.len - 1; Some hd\n | [] -> None\n\nlet top s =\n match s.c with\n | hd::_ -> hd\n | [] -> raise Empty\n\nlet top_opt s =\n match s.c with\n | hd::_ -> Some hd\n | [] -> None\n\nlet is_empty s = (s.c = [])\n\nlet length s = s.len\n\nlet iter f s = List.iter f s.c\n\nlet fold f acc s = List.fold_left f acc s.c\n\n(** {1 Iterators} *)\n\nlet to_seq s = List.to_seq s.c\n\nlet add_seq q i = Seq.iter (fun x -> push x q) i\n\nlet of_seq g =\n let s = create() in\n add_seq s g;\n s\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Francois Pottier, projet Cristal, INRIA Rocquencourt *)\n(* Jeremie Dimino, Jane Street Europe *)\n(* *)\n(* Copyright 2002 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nexception Empty\n\ntype 'a cell =\n | Nil\n | Cons of { content: 'a; mutable next: 'a cell }\n\ntype 'a t = {\n mutable length: int;\n mutable first: 'a cell;\n mutable last: 'a cell\n}\n\nlet create () = {\n length = 0;\n first = Nil;\n last = Nil\n}\n\nlet clear q =\n q.length <- 0;\n q.first <- Nil;\n q.last <- Nil\n\nlet add x q =\n let cell = Cons {\n content = x;\n next = Nil\n } in\n match q.last with\n | Nil ->\n q.length <- 1;\n q.first <- cell;\n q.last <- cell\n | Cons last ->\n q.length <- q.length + 1;\n last.next <- cell;\n q.last <- cell\n\nlet push =\n add\n\nlet peek q =\n match q.first with\n | Nil -> raise Empty\n | Cons { content } -> content\n\nlet peek_opt q =\n match q.first with\n | Nil -> None\n | Cons { content } -> Some content\n\nlet top =\n peek\n\nlet take q =\n match q.first with\n | Nil -> raise Empty\n | Cons { content; next = Nil } ->\n clear q;\n content\n | Cons { content; next } ->\n q.length <- q.length - 1;\n q.first <- next;\n content\n\nlet take_opt q =\n match q.first with\n | Nil -> None\n | Cons { content; next = Nil } ->\n clear q;\n Some content\n | Cons { content; next } ->\n q.length <- q.length - 1;\n q.first <- next;\n Some content\n\nlet pop =\n take\n\nlet copy =\n let rec copy q_res prev cell =\n match cell with\n | Nil -> q_res.last <- prev; q_res\n | Cons { content; next } ->\n let res = Cons { content; next = Nil } in\n begin match prev with\n | Nil -> q_res.first <- res\n | Cons p -> p.next <- res\n end;\n copy q_res res next\n in\n fun q -> copy { length = q.length; first = Nil; last = Nil } Nil q.first\n\nlet is_empty q =\n q.length = 0\n\nlet length q =\n q.length\n\nlet iter =\n let rec iter f cell =\n match cell with\n | Nil -> ()\n | Cons { content; next } ->\n f content;\n iter f next\n in\n fun f q -> iter f q.first\n\nlet fold =\n let rec fold f accu cell =\n match cell with\n | Nil -> accu\n | Cons { content; next } ->\n let accu = f accu content in\n fold f accu next\n in\n fun f accu q -> fold f accu q.first\n\nlet transfer q1 q2 =\n if q1.length > 0 then\n match q2.last with\n | Nil ->\n q2.length <- q1.length;\n q2.first <- q1.first;\n q2.last <- q1.last;\n clear q1\n | Cons last ->\n q2.length <- q2.length + q1.length;\n last.next <- q1.first;\n q2.last <- q1.last;\n clear q1\n\n(** {1 Iterators} *)\n\nlet to_seq q =\n let rec aux c () = match c with\n | Nil -> Seq.Nil\n | Cons { content=x; next; } -> Seq.Cons (x, aux next)\n in\n aux q.first\n\nlet add_seq q i = Seq.iter (fun x -> push x q) i\n\nlet of_seq g =\n let q = create() in\n add_seq q g;\n q\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Pierre Weis and Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1999 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Extensible buffers *)\n\ntype t =\n {mutable buffer : bytes;\n mutable position : int;\n mutable length : int;\n initial_buffer : bytes}\n(* Invariants: all parts of the code preserve the invariants that:\n - [0 <= b.position <= b.length]\n - [b.length = Bytes.length b.buffer]\n\n Note in particular that [b.position = b.length] is legal,\n it means that the buffer is full and will have to be extended\n before any further addition. *)\n\nlet create n =\n let n = if n < 1 then 1 else n in\n let n = if n > Sys.max_string_length then Sys.max_string_length else n in\n let s = Bytes.create n in\n {buffer = s; position = 0; length = n; initial_buffer = s}\n\nlet contents b = Bytes.sub_string b.buffer 0 b.position\nlet to_bytes b = Bytes.sub b.buffer 0 b.position\n\nlet sub b ofs len =\n if ofs < 0 || len < 0 || ofs > b.position - len\n then invalid_arg \"Buffer.sub\"\n else Bytes.sub_string b.buffer ofs len\n\n\nlet blit src srcoff dst dstoff len =\n if len < 0 || srcoff < 0 || srcoff > src.position - len\n || dstoff < 0 || dstoff > (Bytes.length dst) - len\n then invalid_arg \"Buffer.blit\"\n else\n Bytes.unsafe_blit src.buffer srcoff dst dstoff len\n\n\nlet nth b ofs =\n if ofs < 0 || ofs >= b.position then\n invalid_arg \"Buffer.nth\"\n else Bytes.unsafe_get b.buffer ofs\n\n\nlet length b = b.position\n\nlet clear b = b.position <- 0\n\nlet reset b =\n b.position <- 0;\n b.buffer <- b.initial_buffer;\n b.length <- Bytes.length b.buffer\n\n(* [resize b more] ensures that [b.position + more <= b.length] holds\n by dynamically extending [b.buffer] if necessary -- and thus\n increasing [b.length].\n\n In particular, after [resize b more] is called, a direct access of\n size [more] at [b.position] will always be in-bounds, so that\n (unsafe_{get,set}) may be used for performance.\n*)\nlet resize b more =\n let old_pos = b.position in\n let old_len = b.length in\n let new_len = ref old_len in\n while old_pos + more > !new_len do new_len := 2 * !new_len done;\n if !new_len > Sys.max_string_length then begin\n if old_pos + more <= Sys.max_string_length\n then new_len := Sys.max_string_length\n else failwith \"Buffer.add: cannot grow buffer\"\n end;\n let new_buffer = Bytes.create !new_len in\n (* PR#6148: let's keep using [blit] rather than [unsafe_blit] in\n this tricky function that is slow anyway. *)\n Bytes.blit b.buffer 0 new_buffer 0 b.position;\n b.buffer <- new_buffer;\n b.length <- !new_len;\n assert (b.position + more <= b.length);\n assert (old_pos + more <= b.length);\n ()\n (* Note: there are various situations (preemptive threads, signals and\n gc finalizers) where OCaml code may be run asynchronously; in\n particular, there may be a race with another user of [b], changing\n its mutable fields in the middle of the [resize] call. The Buffer\n module does not provide any correctness guarantee if that happens,\n but we must still ensure that the datastructure invariants hold for\n memory-safety -- as we plan to use [unsafe_{get,set}].\n\n There are two potential allocation points in this function,\n [ref] and [Bytes.create], but all reads and writes to the fields\n of [b] happen before both of them or after both of them.\n\n We therefore assume that [b.position] may change at these allocations,\n and check that the [b.position + more <= b.length] postcondition\n holds for both values of [b.position], before or after the function\n is called. More precisely, the following invariants must hold if the\n function returns correctly, in addition to the usual buffer invariants:\n - [old(b.position) + more <= new(b.length)]\n - [new(b.position) + more <= new(b.length)]\n - [old(b.length) <= new(b.length)]\n\n Note: [b.position + more <= old(b.length)] does *not*\n hold in general, as it is precisely the case where you need\n to call [resize] to increase [b.length].\n\n Note: [assert] above does not mean that we know the conditions\n always hold, but that the function may return correctly\n only if they hold.\n\n Note: the other functions in this module does not need\n to be checked with this level of scrutiny, given that they\n read/write the buffer immediately after checking that\n [b.position + more <= b.length] hold or calling [resize].\n *)\n\nlet add_char b c =\n let pos = b.position in\n if pos >= b.length then resize b 1;\n Bytes.unsafe_set b.buffer pos c;\n b.position <- pos + 1\n\nlet uchar_utf_8_byte_length_max = 4\nlet uchar_utf_16_byte_length_max = 4\n\nlet rec add_utf_8_uchar b u =\n let pos = b.position in\n if pos >= b.length then resize b uchar_utf_8_byte_length_max;\n let n = Bytes.set_utf_8_uchar b.buffer pos u in\n if n = 0\n then (resize b uchar_utf_8_byte_length_max; add_utf_8_uchar b u)\n else (b.position <- pos + n)\n\nlet rec add_utf_16be_uchar b u =\n let pos = b.position in\n if pos >= b.length then resize b uchar_utf_16_byte_length_max;\n let n = Bytes.set_utf_16be_uchar b.buffer pos u in\n if n = 0\n then (resize b uchar_utf_16_byte_length_max; add_utf_16be_uchar b u)\n else (b.position <- pos + n)\n\nlet rec add_utf_16le_uchar b u =\n let pos = b.position in\n if pos >= b.length then resize b uchar_utf_16_byte_length_max;\n let n = Bytes.set_utf_16le_uchar b.buffer pos u in\n if n = 0\n then (resize b uchar_utf_16_byte_length_max; add_utf_16le_uchar b u)\n else (b.position <- pos + n)\n\nlet add_substring b s offset len =\n if offset < 0 || len < 0 || offset > String.length s - len\n then invalid_arg \"Buffer.add_substring/add_subbytes\";\n let new_position = b.position + len in\n if new_position > b.length then resize b len;\n Bytes.unsafe_blit_string s offset b.buffer b.position len;\n b.position <- new_position\n\nlet add_subbytes b s offset len =\n add_substring b (Bytes.unsafe_to_string s) offset len\n\nlet add_string b s =\n let len = String.length s in\n let new_position = b.position + len in\n if new_position > b.length then resize b len;\n Bytes.unsafe_blit_string s 0 b.buffer b.position len;\n b.position <- new_position\n\nlet add_bytes b s = add_string b (Bytes.unsafe_to_string s)\n\nlet add_buffer b bs =\n add_subbytes b bs.buffer 0 bs.position\n\n(* this (private) function could move into the standard library *)\nlet really_input_up_to ic buf ofs len =\n let rec loop ic buf ~already_read ~ofs ~to_read =\n if to_read = 0 then already_read\n else begin\n let r = input ic buf ofs to_read in\n if r = 0 then already_read\n else begin\n let already_read = already_read + r in\n let ofs = ofs + r in\n let to_read = to_read - r in\n loop ic buf ~already_read ~ofs ~to_read\n end\n end\n in loop ic buf ~already_read:0 ~ofs ~to_read:len\n\n\nlet unsafe_add_channel_up_to b ic len =\n if b.position + len > b.length then resize b len;\n let n = really_input_up_to ic b.buffer b.position len in\n (* The assertion below may fail in weird scenario where\n threaded/finalizer code, run asynchronously during the\n [really_input_up_to] call, races on the buffer; we don't ensure\n correctness in this case, but need to preserve the invariants for\n memory-safety (see discussion of [resize]). *)\n assert (b.position + n <= b.length);\n b.position <- b.position + n;\n n\n\nlet add_channel b ic len =\n if len < 0 || len > Sys.max_string_length then (* PR#5004 *)\n invalid_arg \"Buffer.add_channel\";\n let n = unsafe_add_channel_up_to b ic len in\n (* It is intentional that a consumer catching End_of_file\n will see the data written (see #6719, #7136). *)\n if n < len then raise End_of_file;\n ()\n\nlet output_buffer oc b =\n output oc b.buffer 0 b.position\n\nlet closing = function\n | '(' -> ')'\n | '{' -> '}'\n | _ -> assert false\n\n(* opening and closing: open and close characters, typically ( and )\n k: balance of opening and closing chars\n s: the string where we are searching\n start: the index where we start the search. *)\nlet advance_to_closing opening closing k s start =\n let rec advance k i lim =\n if i >= lim then raise Not_found else\n if s.[i] = opening then advance (k + 1) (i + 1) lim else\n if s.[i] = closing then\n if k = 0 then i else advance (k - 1) (i + 1) lim\n else advance k (i + 1) lim in\n advance k start (String.length s)\n\nlet advance_to_non_alpha s start =\n let rec advance i lim =\n if i >= lim then lim else\n match s.[i] with\n | 'a' .. 'z' | 'A' .. 'Z' | '0' .. '9' | '_' -> advance (i + 1) lim\n | _ -> i in\n advance start (String.length s)\n\n(* We are just at the beginning of an ident in s, starting at start. *)\nlet find_ident s start lim =\n if start >= lim then raise Not_found else\n match s.[start] with\n (* Parenthesized ident ? *)\n | '(' | '{' as c ->\n let new_start = start + 1 in\n let stop = advance_to_closing c (closing c) 0 s new_start in\n String.sub s new_start (stop - start - 1), stop + 1\n (* Regular ident *)\n | _ ->\n let stop = advance_to_non_alpha s (start + 1) in\n String.sub s start (stop - start), stop\n\n(* Substitute $ident, $(ident), or ${ident} in s,\n according to the function mapping f. *)\nlet add_substitute b f s =\n let lim = String.length s in\n let rec subst previous i =\n if i < lim then begin\n match s.[i] with\n | '$' as current when previous = '\\\\' ->\n add_char b current;\n subst ' ' (i + 1)\n | '$' ->\n let j = i + 1 in\n let ident, next_i = find_ident s j lim in\n add_string b (f ident);\n subst ' ' next_i\n | current when previous == '\\\\' ->\n add_char b '\\\\';\n add_char b current;\n subst ' ' (i + 1)\n | '\\\\' as current ->\n subst current (i + 1)\n | current ->\n add_char b current;\n subst current (i + 1)\n end else\n if previous = '\\\\' then add_char b previous in\n subst ' ' 0\n\nlet truncate b len =\n if len < 0 || len > length b then\n invalid_arg \"Buffer.truncate\"\n else\n b.position <- len\n\n(** {1 Iterators} *)\n\nlet to_seq b =\n let rec aux i () =\n (* Note that b.position is not a constant and cannot be lifted out of aux *)\n if i >= b.position then Seq.Nil\n else\n let x = Bytes.unsafe_get b.buffer i in\n Seq.Cons (x, aux (i+1))\n in\n aux 0\n\nlet to_seqi b =\n let rec aux i () =\n (* Note that b.position is not a constant and cannot be lifted out of aux *)\n if i >= b.position then Seq.Nil\n else\n let x = Bytes.unsafe_get b.buffer i in\n Seq.Cons ((i,x), aux (i+1))\n in\n aux 0\n\nlet add_seq b seq = Seq.iter (add_char b) seq\n\nlet of_seq i =\n let b = create 32 in\n add_seq b i;\n b\n\n(** {6 Binary encoding of integers} *)\n\nexternal unsafe_set_int8 : bytes -> int -> int -> unit = \"%bytes_unsafe_set\"\nexternal unsafe_set_int16 : bytes -> int -> int -> unit = \"%caml_bytes_set16u\"\nexternal unsafe_set_int32 : bytes -> int -> int32 -> unit = \"%caml_bytes_set32u\"\nexternal unsafe_set_int64 : bytes -> int -> int64 -> unit = \"%caml_bytes_set64u\"\nexternal swap16 : int -> int = \"%bswap16\"\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\n\n\nlet add_int8 b x =\n let new_position = b.position + 1 in\n if new_position > b.length then resize b 1;\n unsafe_set_int8 b.buffer b.position x;\n b.position <- new_position\n\nlet add_int16_ne b x =\n let new_position = b.position + 2 in\n if new_position > b.length then resize b 2;\n unsafe_set_int16 b.buffer b.position x;\n b.position <- new_position\n\nlet add_int32_ne b x =\n let new_position = b.position + 4 in\n if new_position > b.length then resize b 4;\n unsafe_set_int32 b.buffer b.position x;\n b.position <- new_position\n\nlet add_int64_ne b x =\n let new_position = b.position + 8 in\n if new_position > b.length then resize b 8;\n unsafe_set_int64 b.buffer b.position x;\n b.position <- new_position\n\nlet add_int16_le b x =\n add_int16_ne b (if Sys.big_endian then swap16 x else x)\n\nlet add_int16_be b x =\n add_int16_ne b (if Sys.big_endian then x else swap16 x)\n\nlet add_int32_le b x =\n add_int32_ne b (if Sys.big_endian then swap32 x else x)\n\nlet add_int32_be b x =\n add_int32_ne b (if Sys.big_endian then x else swap32 x)\n\nlet add_int64_le b x =\n add_int64_ne b (if Sys.big_endian then swap64 x else x)\n\nlet add_int64_be b x =\n add_int64_ne b (if Sys.big_endian then x else swap64 x)\n\nlet add_uint8 = add_int8\nlet add_uint16_ne = add_int16_ne\nlet add_uint16_le = add_int16_le\nlet add_uint16_be = add_int16_be\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy and Pierre Weis, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nopen CamlinternalFormatBasics\nopen CamlinternalFormat\n\nlet kfprintf k o (Format (fmt, _)) =\n make_printf (fun acc -> output_acc o acc; k o) End_of_acc fmt\nlet kbprintf k b (Format (fmt, _)) =\n make_printf (fun acc -> bufput_acc b acc; k b) End_of_acc fmt\nlet ikfprintf k oc (Format (fmt, _)) =\n make_iprintf k oc fmt\nlet ikbprintf = ikfprintf\n\nlet fprintf oc fmt = kfprintf ignore oc fmt\nlet bprintf b fmt = kbprintf ignore b fmt\nlet ifprintf oc fmt = ikfprintf ignore oc fmt\nlet ibprintf b fmt = ikbprintf ignore b fmt\nlet printf fmt = fprintf stdout fmt\nlet eprintf fmt = fprintf stderr fmt\n\nlet ksprintf k (Format (fmt, _)) =\n let k' acc =\n let buf = Buffer.create 64 in\n strput_acc buf acc;\n k (Buffer.contents buf) in\n make_printf k' End_of_acc fmt\n\nlet sprintf fmt = ksprintf (fun s -> s) fmt\n\nlet kprintf = ksprintf\n","open! Base\n\nmodule Bigstring0 = struct\n type t =\n ( char\n , Stdlib.Bigarray.int8_unsigned_elt\n , Stdlib.Bigarray.c_layout )\n Stdlib.Bigarray.Array1.t\nend\n\nmodule Array1 = struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) Stdlib.Bigarray.Array1.t\n\n external get : ('a, 'b, 'c) t -> int -> 'a = \"%caml_ba_ref_1\"\n external set : ('a, 'b, 'c) t -> int -> 'a -> unit = \"%caml_ba_set_1\"\n external unsafe_get : ('a, 'b, 'c) t -> int -> 'a = \"%caml_ba_unsafe_ref_1\"\n external unsafe_set : ('a, 'b, 'c) t -> int -> 'a -> unit = \"%caml_ba_unsafe_set_1\"\n external dim : ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\nend\n\ninclude Bigstring0\n\nexternal aux_create\n : max_mem_waiting_gc_in_bytes:int\n -> size:int\n -> t\n = \"bigstring_alloc\"\n\nlet sprintf = Printf.sprintf\n\n(* One needs to use [Caml.Sys.word_size] so that its value is known at compile-time. *)\nlet arch_sixtyfour = Caml.Sys.word_size = 64\nlet arch_big_endian = Caml.Sys.big_endian\nlet not_on_32bit = Caml.Sys.word_size > 32\n\nlet create ?max_mem_waiting_gc_in_bytes size =\n let max_mem_waiting_gc_in_bytes =\n Option.value max_mem_waiting_gc_in_bytes ~default:(-1)\n in\n (* This check is important because [aux_create ~size:(-1)] raises [Out_of_memory], which\n could be confusing during debugging. *)\n if size < 0 then invalid_arg (sprintf \"create: size = %d < 0\" size);\n aux_create ~max_mem_waiting_gc_in_bytes ~size\n;;\n\nlet length = Array1.dim\n\nexternal is_mmapped : t -> bool = \"bigstring_is_mmapped_stub\" [@@noalloc]\n\nlet init n ~f =\n let t = create n in\n for i = 0 to n - 1 do\n t.{i} <- f i\n done;\n t\n;;\n\nlet check_args ~loc ~pos ~len (bstr : t) =\n if pos < 0 then invalid_arg (loc ^ \": pos < 0\");\n if len < 0 then invalid_arg (loc ^ \": len < 0\");\n let bstr_len = length bstr in\n (* Be careful with overflow! We could have bogons like [pos = Int.max_value] or [len =\n Int.max_value] passed by the user. *)\n if bstr_len - pos < len\n then invalid_arg (sprintf \"Bigstring.%s: length(bstr) < pos + len\" loc)\n;;\n\nlet get_opt_len bstr ~pos = function\n | Some len -> len\n | None -> length bstr - pos\n;;\n\n(* Blitting *)\n\nexternal unsafe_blit\n : src:t\n -> src_pos:int\n -> dst:t\n -> dst_pos:int\n -> len:int\n -> unit\n = \"bigstring_blit_stub\"\n[@@noalloc]\n\n(* Exposing the external version of get/set supports better inlining. *)\nexternal get : t -> int -> char = \"%caml_ba_ref_1\"\nexternal set : t -> int -> char -> unit = \"%caml_ba_set_1\"\n\nmodule Bigstring_sequence = struct\n type nonrec t = t\n\n let create ~len = create len\n let length = length\nend\n\nmodule Bytes_sequence = struct\n type t = bytes\n\n let create ~len = Bytes.create len\n let length = Bytes.length\nend\n\ninclude Blit.Make (struct\n include Bigstring_sequence\n\n let unsafe_blit = unsafe_blit\n end)\n\nmodule From_bytes =\n Blit.Make_distinct\n (Bytes_sequence)\n (struct\n external unsafe_blit\n : src:bytes\n -> src_pos:int\n -> dst:t\n -> dst_pos:int\n -> len:int\n -> unit\n = \"bigstring_blit_bytes_bigstring_stub\"\n [@@noalloc]\n\n include Bigstring_sequence\n end)\n\nmodule To_bytes =\n Blit.Make_distinct\n (Bigstring_sequence)\n (struct\n external unsafe_blit\n : src:t\n -> src_pos:int\n -> dst:bytes\n -> dst_pos:int\n -> len:int\n -> unit\n = \"bigstring_blit_bigstring_bytes_stub\"\n [@@noalloc]\n\n include Bytes_sequence\n end)\n\nmodule From_string =\n Blit.Make_distinct\n (struct\n type t = string\n\n let length = String.length\n end)\n (struct\n external unsafe_blit\n : src:string\n -> src_pos:int\n -> dst:t\n -> dst_pos:int\n -> len:int\n -> unit\n = \"bigstring_blit_string_bigstring_stub\"\n [@@noalloc]\n\n include Bigstring_sequence\n end)\n\nmodule To_string = struct\n include To_bytes\n include Blit.Make_to_string (Bigstring0) (To_bytes)\nend\n\nlet of_string = From_string.subo\nlet of_bytes = From_bytes.subo\nlet to_string = To_string.subo\nlet to_bytes = To_bytes.subo\nlet sexp_of_t t = Sexp.Atom (to_string t)\n\nlet t_of_sexp : Sexp.t -> t = function\n | Atom str -> of_string str\n | List _ as sexp ->\n Sexplib0.Sexp_conv.of_sexp_error \"bigstring_of_sexp: atom needed\" sexp\n;;\n\nlet copy t : t = sub t ~pos:0 ~len:(length t)\n\nlet concat =\n let append ~src ~dst ~dst_pos_ref =\n let len = length src in\n let src_pos = 0 in\n let dst_pos = !dst_pos_ref in\n blit ~dst ~dst_pos ~src ~src_pos ~len;\n dst_pos_ref := dst_pos + len\n in\n fun ?sep list ->\n match list with\n | [] -> create 0\n | head :: tail ->\n let head_len = length head in\n let sep_len = Option.value_map sep ~f:length ~default:0 in\n let tail_count = List.length tail in\n let len =\n head_len + (sep_len * tail_count) + List.sum (module Int) tail ~f:length\n in\n let dst = create len in\n let dst_pos_ref = ref 0 in\n append ~src:head ~dst ~dst_pos_ref;\n List.iter tail ~f:(fun src ->\n (match sep with\n | None -> ()\n | Some sep -> append ~src:sep ~dst ~dst_pos_ref);\n append ~src ~dst ~dst_pos_ref);\n assert (!dst_pos_ref = len);\n dst\n;;\n\nexternal unsafe_memset\n : t\n -> pos:int\n -> len:int\n -> char\n -> unit\n = \"bigstring_memset_stub\"\n[@@noalloc]\n\nlet memset t ~pos ~len c =\n Ordered_collection_common.check_pos_len_exn ~pos ~len ~total_length:(length t);\n unsafe_memset t ~pos ~len c\n;;\n\n(* Comparison *)\n\nexternal unsafe_memcmp\n : t\n -> pos1:int\n -> t\n -> pos2:int\n -> len:int\n -> int\n = \"bigstring_memcmp_stub\"\n[@@noalloc]\n\nlet memcmp t1 ~pos1 t2 ~pos2 ~len =\n Ordered_collection_common.check_pos_len_exn ~pos:pos1 ~len ~total_length:(length t1);\n Ordered_collection_common.check_pos_len_exn ~pos:pos2 ~len ~total_length:(length t2);\n unsafe_memcmp t1 ~pos1 t2 ~pos2 ~len\n;;\n\nlet compare t1 t2 =\n if phys_equal t1 t2\n then 0\n else (\n let len1 = length t1 in\n let len2 = length t2 in\n let len = Int.min len1 len2 in\n match unsafe_memcmp t1 ~pos1:0 t2 ~pos2:0 ~len with\n | 0 -> if len1 < len2 then -1 else if len1 > len2 then 1 else 0\n | n -> n)\n;;\n\nexternal internalhash_fold_bigstring\n : Hash.state\n -> t\n -> Hash.state\n = \"internalhash_fold_bigstring\"\n[@@noalloc]\n\nlet _making_sure_the_C_binding_takes_an_int (x : Hash.state) = (x :> int)\nlet hash_fold_t = internalhash_fold_bigstring\nlet hash = Ppx_hash_lib.Std.Hash.of_fold hash_fold_t\n\ntype t_frozen = t [@@deriving compare, hash, sexp]\n\nlet equal t1 t2 =\n if phys_equal t1 t2\n then true\n else (\n let len1 = length t1 in\n let len2 = length t2 in\n Int.equal len1 len2 && Int.equal (unsafe_memcmp t1 ~pos1:0 t2 ~pos2:0 ~len:len1) 0)\n;;\n\n(* Search *)\n\nexternal unsafe_find : t -> char -> pos:int -> len:int -> int = \"bigstring_find\"\n[@@noalloc]\n\nlet find ?(pos = 0) ?len chr bstr =\n let len = get_opt_len bstr ~pos len in\n check_args ~loc:\"find\" ~pos ~len bstr;\n let res = unsafe_find bstr chr ~pos ~len in\n if res < 0 then None else Some res\n;;\n\n(* vim: set filetype=ocaml : *)\n\n(* Binary-packing like accessors *)\n\nexternal int32_of_int : int -> int32 = \"%int32_of_int\"\nexternal int32_to_int : int32 -> int = \"%int32_to_int\"\nexternal int64_of_int : int -> int64 = \"%int64_of_int\"\nexternal int64_to_int : int64 -> int = \"%int64_to_int\"\nexternal swap16 : int -> int = \"%bswap16\"\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\nexternal unsafe_get_16 : t -> int -> int = \"%caml_bigstring_get16u\"\nexternal unsafe_get_32 : t -> int -> int32 = \"%caml_bigstring_get32u\"\nexternal unsafe_get_64 : t -> int -> int64 = \"%caml_bigstring_get64u\"\nexternal unsafe_set_16 : t -> int -> int -> unit = \"%caml_bigstring_set16u\"\nexternal unsafe_set_32 : t -> int -> int32 -> unit = \"%caml_bigstring_set32u\"\nexternal unsafe_set_64 : t -> int -> int64 -> unit = \"%caml_bigstring_set64u\"\n\nlet get_16 (t : t) (pos : int) : int =\n check_args ~loc:\"get_16\" ~pos ~len:2 t;\n unsafe_get_16 t pos\n;;\n\nlet get_32 (t : t) (pos : int) : int32 =\n check_args ~loc:\"get_32\" ~pos ~len:4 t;\n unsafe_get_32 t pos\n;;\n\nlet get_64 (t : t) (pos : int) : int64 =\n check_args ~loc:\"get_64\" ~pos ~len:8 t;\n unsafe_get_64 t pos\n;;\n\nlet set_16_trunc (t : t) (pos : int) (v : int) : unit =\n check_args ~loc:\"set_16\" ~pos ~len:2 t;\n unsafe_set_16 t pos v\n;;\n\nlet set_32 (t : t) (pos : int) (v : int32) : unit =\n check_args ~loc:\"set_32\" ~pos ~len:4 t;\n unsafe_set_32 t pos v\n;;\n\nlet set_64 (t : t) (pos : int) (v : int64) : unit =\n check_args ~loc:\"set_64\" ~pos ~len:8 t;\n unsafe_set_64 t pos v\n;;\n\nlet sign_extend_16 u = (u lsl (Int.num_bits - 16)) asr (Int.num_bits - 16)\n\nlet check_valid_uint16 x ~loc =\n if x < 0 || x > 0xFFFF\n then invalid_arg (sprintf \"%s: %d is not a valid unsigned 16-bit integer\" loc x)\n;;\n\nlet check_valid_int16 x ~loc =\n if x < -0x8000 || x > 0x7FFF\n then invalid_arg (sprintf \"%s: %d is not a valid (signed) 16-bit integer\" loc x)\n;;\n\nlet check_valid_uint8 x ~loc =\n if x < 0 || x > 0xFF\n then invalid_arg (sprintf \"%s: %d is not a valid unsigned 8-bit integer\" loc x)\n;;\n\nlet check_valid_int8 x ~loc =\n if x < -0x80 || x > 0x7F\n then invalid_arg (sprintf \"%s: %d is not a valid (signed) 8-bit integer\" loc x)\n;;\n\nlet check_valid_int32 =\n if not arch_sixtyfour\n then fun _ ~loc:_ -> ()\n else\n fun x ~loc ->\n if x >= -1 lsl 31 && x < 1 lsl 31\n then ()\n else invalid_arg (sprintf \"%s: %d is not a valid (signed) 32-bit integer\" loc x)\n;;\n\nlet check_valid_uint32 =\n if not arch_sixtyfour\n then\n fun x ~loc ->\n if x >= 0\n then ()\n else invalid_arg (sprintf \"%s: %d is not a valid unsigned 32-bit integer\" loc x)\n else\n fun x ~loc ->\n if x >= 0 && x < 1 lsl 32\n then ()\n else invalid_arg (sprintf \"%s: %d is not a valid unsigned 32-bit integer\" loc x)\n;;\n\nlet check_valid_uint64 x ~loc =\n if x >= 0\n then ()\n else invalid_arg (sprintf \"%s: %d is not a valid unsigned 64-bit integer\" loc x)\n;;\n\nlet unsafe_read_int16 t ~pos = sign_extend_16 (unsafe_get_16 t pos)\nlet unsafe_read_int16_swap t ~pos = sign_extend_16 (swap16 (unsafe_get_16 t pos))\nlet unsafe_write_int16 t ~pos x = unsafe_set_16 t pos x\nlet unsafe_write_int16_swap t ~pos x = unsafe_set_16 t pos (swap16 x)\nlet read_int16 t ~pos = sign_extend_16 (get_16 t pos)\nlet read_int16_swap t ~pos = sign_extend_16 (swap16 (get_16 t pos))\n\nlet write_int16_exn t ~pos x =\n check_valid_int16 x ~loc:\"Bigstring.write_int16\";\n set_16_trunc t pos x\n;;\n\nlet write_int16_swap_exn t ~pos x =\n (* Omit \"_swap\" from the error message it's bi-endian. *)\n check_valid_int16 x ~loc:\"Bigstring.write_int16\";\n set_16_trunc t pos (swap16 x)\n;;\n\nlet unsafe_read_uint16 t ~pos = unsafe_get_16 t pos\nlet unsafe_read_uint16_swap t ~pos = swap16 (unsafe_get_16 t pos)\nlet unsafe_write_uint16 t ~pos x = unsafe_set_16 t pos x\nlet unsafe_write_uint16_swap t ~pos x = unsafe_set_16 t pos (swap16 x)\nlet read_uint16 t ~pos = get_16 t pos\nlet read_uint16_swap t ~pos = swap16 (get_16 t pos)\n\nlet write_uint16_exn t ~pos x =\n check_valid_uint16 x ~loc:\"Bigstring.write_uint16\";\n set_16_trunc t pos x\n;;\n\nlet write_uint16_swap_exn t ~pos x =\n (* Omit \"_swap\" from the error message it's bi-endian. *)\n check_valid_uint16 x ~loc:\"Bigstring.write_uint16\";\n set_16_trunc t pos (swap16 x)\n;;\n\nlet unsafe_read_int32_int t ~pos = int32_to_int (unsafe_get_32 t pos)\nlet unsafe_read_int32_int_swap t ~pos = int32_to_int (swap32 (unsafe_get_32 t pos))\nlet unsafe_read_int32 t ~pos = unsafe_get_32 t pos\nlet unsafe_read_int32_swap t ~pos = swap32 (unsafe_get_32 t pos)\nlet unsafe_write_int32 t ~pos x = unsafe_set_32 t pos x\nlet unsafe_write_int32_swap t ~pos x = unsafe_set_32 t pos (swap32 x)\nlet unsafe_write_int32_int t ~pos x = unsafe_set_32 t pos (int32_of_int x)\nlet unsafe_write_int32_int_swap t ~pos x = unsafe_set_32 t pos (swap32 (int32_of_int x))\nlet read_int32_int t ~pos = int32_to_int (get_32 t pos)\nlet read_int32_int_swap t ~pos = int32_to_int (swap32 (get_32 t pos))\nlet read_int32 t ~pos = get_32 t pos\nlet read_int32_swap t ~pos = swap32 (get_32 t pos)\nlet write_int32 t ~pos x = set_32 t pos x\nlet write_int32_swap t ~pos x = set_32 t pos (swap32 x)\n\nlet write_int32_int_exn t ~pos x =\n check_valid_int32 x ~loc:\"Bigstring.write_int32_int\";\n set_32 t pos (int32_of_int x)\n;;\n\nlet write_int32_int_swap_exn t ~pos x =\n (* Omit \"_swap\" from the error message it's bi-endian. *)\n check_valid_int32 x ~loc:\"Bigstring.write_int32_int\";\n set_32 t pos (swap32 (int32_of_int x))\n;;\n\nlet unsafe_read_int64_int t ~pos = int64_to_int (unsafe_get_64 t pos)\nlet unsafe_read_int64_int_swap t ~pos = int64_to_int (swap64 (unsafe_get_64 t pos))\nlet unsafe_read_int64 t ~pos = unsafe_get_64 t pos\nlet unsafe_read_int64_swap t ~pos = swap64 (unsafe_get_64 t pos)\nlet unsafe_write_int64 t ~pos x = unsafe_set_64 t pos x\nlet unsafe_write_int64_swap t ~pos x = unsafe_set_64 t pos (swap64 x)\nlet unsafe_write_int64_int t ~pos x = unsafe_set_64 t pos (int64_of_int x)\nlet unsafe_write_int64_int_swap t ~pos x = unsafe_set_64 t pos (swap64 (int64_of_int x))\nlet read_int64_int t ~pos = int64_to_int (get_64 t pos)\nlet read_int64_int_swap t ~pos = int64_to_int (swap64 (get_64 t pos))\nlet read_int64 t ~pos = get_64 t pos\nlet read_int64_swap t ~pos = swap64 (get_64 t pos)\nlet write_int64 t ~pos x = set_64 t pos x\nlet write_int64_swap t ~pos x = set_64 t pos (swap64 x)\nlet write_int64_int t ~pos x = set_64 t pos (int64_of_int x)\nlet write_int64_int_swap t ~pos x = set_64 t pos (swap64 (int64_of_int x))\n\nlet unsafe_get_int16_be =\n if arch_big_endian then unsafe_read_int16 else unsafe_read_int16_swap\n;;\n\nlet unsafe_get_int16_le =\n if arch_big_endian then unsafe_read_int16_swap else unsafe_read_int16\n;;\n\nlet unsafe_get_uint16_be =\n if arch_big_endian then unsafe_read_uint16 else unsafe_read_uint16_swap\n;;\n\nlet unsafe_get_uint16_le =\n if arch_big_endian then unsafe_read_uint16_swap else unsafe_read_uint16\n;;\n\nlet get_int16_be = if arch_big_endian then read_int16 else read_int16_swap\nlet get_int16_le = if arch_big_endian then read_int16_swap else read_int16\nlet get_uint16_be = if arch_big_endian then read_uint16 else read_uint16_swap\nlet get_uint16_le = if arch_big_endian then read_uint16_swap else read_uint16\n\nlet unsafe_set_int16_be =\n if arch_big_endian then unsafe_write_int16 else unsafe_write_int16_swap\n;;\n\nlet unsafe_set_int16_le =\n if arch_big_endian then unsafe_write_int16_swap else unsafe_write_int16\n;;\n\nlet unsafe_set_uint16_be =\n if arch_big_endian then unsafe_write_uint16 else unsafe_write_uint16_swap\n;;\n\nlet unsafe_set_uint16_le =\n if arch_big_endian then unsafe_write_uint16_swap else unsafe_write_uint16\n;;\n\nlet set_int16_be_exn = if arch_big_endian then write_int16_exn else write_int16_swap_exn\nlet set_int16_le_exn = if arch_big_endian then write_int16_swap_exn else write_int16_exn\n\nlet set_uint16_be_exn =\n if arch_big_endian then write_uint16_exn else write_uint16_swap_exn\n;;\n\nlet set_uint16_le_exn =\n if arch_big_endian then write_uint16_swap_exn else write_uint16_exn\n;;\n\nlet unsafe_get_int32_t_be =\n if arch_big_endian then unsafe_read_int32 else unsafe_read_int32_swap\n;;\n\nlet unsafe_get_int32_t_le =\n if arch_big_endian then unsafe_read_int32_swap else unsafe_read_int32\n;;\n\nlet unsafe_set_int32_t_be =\n if arch_big_endian then unsafe_write_int32 else unsafe_write_int32_swap\n;;\n\nlet unsafe_set_int32_t_le =\n if arch_big_endian then unsafe_write_int32_swap else unsafe_write_int32\n;;\n\nlet get_int32_t_be = if arch_big_endian then read_int32 else read_int32_swap\nlet get_int32_t_le = if arch_big_endian then read_int32_swap else read_int32\nlet set_int32_t_be = if arch_big_endian then write_int32 else write_int32_swap\nlet set_int32_t_le = if arch_big_endian then write_int32_swap else write_int32\n\nlet unsafe_get_int32_be =\n if arch_big_endian then unsafe_read_int32_int else unsafe_read_int32_int_swap\n;;\n\nlet unsafe_get_int32_le =\n if arch_big_endian then unsafe_read_int32_int_swap else unsafe_read_int32_int\n;;\n\nlet unsafe_set_int32_be =\n if arch_big_endian then unsafe_write_int32_int else unsafe_write_int32_int_swap\n;;\n\nlet unsafe_set_int32_le =\n if arch_big_endian then unsafe_write_int32_int_swap else unsafe_write_int32_int\n;;\n\nlet get_int32_be = if arch_big_endian then read_int32_int else read_int32_int_swap\nlet get_int32_le = if arch_big_endian then read_int32_int_swap else read_int32_int\n\nlet set_int32_be_exn =\n if arch_big_endian then write_int32_int_exn else write_int32_int_swap_exn\n;;\n\nlet set_int32_le_exn =\n if arch_big_endian then write_int32_int_swap_exn else write_int32_int_exn\n;;\n\nlet unsafe_get_int64_be_trunc =\n if arch_big_endian then unsafe_read_int64_int else unsafe_read_int64_int_swap\n;;\n\nlet unsafe_get_int64_le_trunc =\n if arch_big_endian then unsafe_read_int64_int_swap else unsafe_read_int64_int\n;;\n\nlet unsafe_set_int64_be =\n if arch_big_endian then unsafe_write_int64_int else unsafe_write_int64_int_swap\n;;\n\nlet unsafe_set_int64_le =\n if arch_big_endian then unsafe_write_int64_int_swap else unsafe_write_int64_int\n;;\n\nlet get_int64_be_trunc = if arch_big_endian then read_int64_int else read_int64_int_swap\nlet get_int64_le_trunc = if arch_big_endian then read_int64_int_swap else read_int64_int\nlet set_int64_be = if arch_big_endian then write_int64_int else write_int64_int_swap\nlet set_int64_le = if arch_big_endian then write_int64_int_swap else write_int64_int\n\nlet unsafe_get_int64_t_be =\n if arch_big_endian then unsafe_read_int64 else unsafe_read_int64_swap\n;;\n\nlet unsafe_get_int64_t_le =\n if arch_big_endian then unsafe_read_int64_swap else unsafe_read_int64\n;;\n\nlet unsafe_set_int64_t_be =\n if arch_big_endian then unsafe_write_int64 else unsafe_write_int64_swap\n;;\n\nlet unsafe_set_int64_t_le =\n if arch_big_endian then unsafe_write_int64_swap else unsafe_write_int64\n;;\n\nlet get_int64_t_be = if arch_big_endian then read_int64 else read_int64_swap\nlet get_int64_t_le = if arch_big_endian then read_int64_swap else read_int64\nlet set_int64_t_be = if arch_big_endian then write_int64 else write_int64_swap\nlet set_int64_t_le = if arch_big_endian then write_int64_swap else write_int64\n\nlet int64_conv_error () =\n failwith \"unsafe_read_int64: value cannot be represented unboxed!\"\n;;\n\nlet uint64_conv_error () =\n failwith \"unsafe_read_uint64: value cannot be represented unboxed!\"\n;;\n\n(* [Poly] is required so that we can compare unboxed [int64]. *)\nlet int64_to_int_exn n =\n if arch_sixtyfour\n then\n if Poly.(n >= -0x4000_0000_0000_0000L && n < 0x4000_0000_0000_0000L)\n then int64_to_int n\n else int64_conv_error ()\n else if Poly.(n >= -0x0000_0000_4000_0000L && n < 0x0000_0000_4000_0000L)\n then int64_to_int n\n else int64_conv_error ()\n;;\n\nlet uint64_to_int_exn n =\n if arch_sixtyfour\n then\n if Poly.(n >= 0L && n < 0x4000_0000_0000_0000L)\n then int64_to_int n\n else uint64_conv_error ()\n else if Poly.(n >= 0L && n < 0x0000_0000_4000_0000L)\n then int64_to_int n\n else uint64_conv_error ()\n;;\n\nlet unsafe_get_int64_be_exn t ~pos = int64_to_int_exn (unsafe_get_int64_t_be t ~pos)\nlet unsafe_get_int64_le_exn t ~pos = int64_to_int_exn (unsafe_get_int64_t_le t ~pos)\nlet get_int64_be_exn t ~pos = int64_to_int_exn (get_int64_t_be t ~pos)\nlet get_int64_le_exn t ~pos = int64_to_int_exn (get_int64_t_le t ~pos)\nlet unsafe_get_uint64_be_exn t ~pos = uint64_to_int_exn (unsafe_get_int64_t_be t ~pos)\nlet unsafe_get_uint64_le_exn t ~pos = uint64_to_int_exn (unsafe_get_int64_t_le t ~pos)\nlet get_uint64_be_exn t ~pos = uint64_to_int_exn (get_int64_t_be t ~pos)\nlet get_uint64_le_exn t ~pos = uint64_to_int_exn (get_int64_t_le t ~pos)\nlet unsafe_set_uint64_be = unsafe_set_int64_be\nlet unsafe_set_uint64_le = unsafe_set_int64_le\n\nlet set_uint64_be_exn t ~pos n =\n check_valid_uint64 ~loc:\"Bigstring.set_uint64_be_exn\" n;\n set_int64_be t ~pos n\n;;\n\nlet set_uint64_le_exn t ~pos n =\n check_valid_uint64 ~loc:\"Bigstring.set_uint64_le_exn\" n;\n set_int64_le t ~pos n\n;;\n\n(* Type annotations on the [t]s are important here: in order for the compiler to generate\n optimized code, it needs to know the fully instantiated type of the bigarray. This is\n because the type of the bigarray encodes the element kind and the layout of the\n bigarray. Without the annotation the compiler generates a C call to the generic access\n functions. *)\nlet unsafe_set_uint8 (t : t) ~pos n = Array1.unsafe_set t pos (Char.unsafe_of_int n)\n\nlet unsafe_set_int8 (t : t) ~pos n =\n (* In all the set functions where there are these tests, it looks like the test could be\n removed, since they are only changing the values of the bytes that are not\n written. *)\n let n = if n < 0 then n + 256 else n in\n Array1.unsafe_set t pos (Char.unsafe_of_int n)\n;;\n\nlet unsafe_get_uint8 (t : t) ~pos = Char.to_int (Array1.unsafe_get t pos)\n\nlet unsafe_get_int8 (t : t) ~pos =\n let n = Char.to_int (Array1.unsafe_get t pos) in\n if n >= 128 then n - 256 else n\n;;\n\nlet set_uint8_exn (t : t) ~pos n =\n check_valid_uint8 ~loc:\"Bigstring.set_uint8_exn\" n;\n Array1.set t pos (Char.unsafe_of_int n)\n;;\n\nlet set_int8_exn (t : t) ~pos n =\n check_valid_int8 ~loc:\"Bigstring.set_int8_exn\" n;\n let n = if n < 0 then n + 256 else n in\n Array1.set t pos (Char.unsafe_of_int n)\n;;\n\nlet get_uint8 (t : t) ~pos = Char.to_int (Array1.get t pos)\n\nlet get_int8 (t : t) ~pos =\n let n = Char.to_int (Array1.get t pos) in\n if n >= 128 then n - 256 else n\n;;\n\nlet unsafe_set_uint32_le t ~pos n =\n let n = if not_on_32bit && n >= 1 lsl 31 then n - (1 lsl 32) else n in\n unsafe_set_int32_le t ~pos n\n;;\n\nlet unsafe_set_uint32_be t ~pos n =\n let n = if not_on_32bit && n >= 1 lsl 31 then n - (1 lsl 32) else n in\n unsafe_set_int32_be t ~pos n\n;;\n\nlet unsafe_get_uint32_le t ~pos =\n let n = unsafe_get_int32_le t ~pos in\n if not_on_32bit && n < 0 then n + (1 lsl 32) else n\n;;\n\nlet unsafe_get_uint32_be t ~pos =\n let n = unsafe_get_int32_be t ~pos in\n if not_on_32bit && n < 0 then n + (1 lsl 32) else n\n;;\n\nlet set_uint32_le_exn t ~pos n =\n check_valid_uint32 ~loc:\"Bigstring.set_uint32_le_exn\" n;\n let n = if not_on_32bit && n >= 1 lsl 31 then n - (1 lsl 32) else n in\n set_int32_le_exn t ~pos n\n;;\n\nlet set_uint32_be_exn t ~pos n =\n check_valid_uint32 ~loc:\"Bigstring.set_uint32_be_exn\" n;\n let n = if not_on_32bit && n >= 1 lsl 31 then n - (1 lsl 32) else n in\n set_int32_be_exn t ~pos n\n;;\n\nlet get_uint32_le t ~pos =\n let n = get_int32_le t ~pos in\n if not_on_32bit && n < 0 then n + (1 lsl 32) else n\n;;\n\nlet get_uint32_be t ~pos =\n let n = get_int32_be t ~pos in\n if not_on_32bit && n < 0 then n + (1 lsl 32) else n\n;;\n\nmodule Private = struct\n let sign_extend_16 = sign_extend_16\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Para, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype key = string\ntype doc = string\ntype usage_msg = string\ntype anon_fun = (string -> unit)\n\ntype spec =\n | Unit of (unit -> unit) (* Call the function with unit argument *)\n | Bool of (bool -> unit) (* Call the function with a bool argument *)\n | Set of bool ref (* Set the reference to true *)\n | Clear of bool ref (* Set the reference to false *)\n | String of (string -> unit) (* Call the function with a string argument *)\n | Set_string of string ref (* Set the reference to the string argument *)\n | Int of (int -> unit) (* Call the function with an int argument *)\n | Set_int of int ref (* Set the reference to the int argument *)\n | Float of (float -> unit) (* Call the function with a float argument *)\n | Set_float of float ref (* Set the reference to the float argument *)\n | Tuple of spec list (* Take several arguments according to the\n spec list *)\n | Symbol of string list * (string -> unit)\n (* Take one of the symbols as argument and\n call the function with the symbol. *)\n | Rest of (string -> unit) (* Stop interpreting keywords and call the\n function with each remaining argument *)\n | Rest_all of (string list -> unit)\n (* Stop interpreting keywords and call the\n function with all remaining arguments. *)\n | Expand of (string -> string array) (* If the remaining arguments to process\n are of the form\n [[\"-foo\"; \"arg\"] @ rest] where \"foo\"\n is registered as [Expand f], then the\n arguments [f \"arg\" @ rest] are\n processed. Only allowed in\n [parse_and_expand_argv_dynamic]. *)\n\nexception Bad of string\nexception Help of string\n\ntype error =\n | Unknown of string\n | Wrong of string * string * string (* option, actual, expected *)\n | Missing of string\n | Message of string\n\nexception Stop of error (* used internally *)\n\nopen Printf\n\nlet rec assoc3 x l =\n match l with\n | [] -> raise Not_found\n | (y1, y2, _) :: _ when y1 = x -> y2\n | _ :: t -> assoc3 x t\n\n\nlet split s =\n let i = String.index s '=' in\n let len = String.length s in\n String.sub s 0 i, String.sub s (i+1) (len-(i+1))\n\n\nlet make_symlist prefix sep suffix l =\n match l with\n | [] -> \"\"\n | h::t -> (List.fold_left (fun x y -> x ^ sep ^ y) (prefix ^ h) t) ^ suffix\n\n\nlet print_spec buf (key, spec, doc) =\n if String.length doc > 0 then\n match spec with\n | Symbol (l, _) ->\n bprintf buf \" %s %s%s\\n\" key (make_symlist \"{\" \"|\" \"}\" l) doc\n | _ ->\n bprintf buf \" %s %s\\n\" key doc\n\n\nlet help_action () = raise (Stop (Unknown \"-help\"))\n\nlet add_help speclist =\n let add1 =\n try ignore (assoc3 \"-help\" speclist); []\n with Not_found ->\n [\"-help\", Unit help_action, \" Display this list of options\"]\n and add2 =\n try ignore (assoc3 \"--help\" speclist); []\n with Not_found ->\n [\"--help\", Unit help_action, \" Display this list of options\"]\n in\n speclist @ (add1 @ add2)\n\n\nlet usage_b buf speclist errmsg =\n bprintf buf \"%s\\n\" errmsg;\n List.iter (print_spec buf) (add_help speclist)\n\n\nlet usage_string speclist errmsg =\n let b = Buffer.create 200 in\n usage_b b speclist errmsg;\n Buffer.contents b\n\n\nlet usage speclist errmsg =\n eprintf \"%s\" (usage_string speclist errmsg)\n\n\nlet current = ref 0\n\nlet bool_of_string_opt x =\n try Some (bool_of_string x)\n with Invalid_argument _ -> None\n\nlet int_of_string_opt x =\n try Some (int_of_string x)\n with Failure _ -> None\n\nlet float_of_string_opt x =\n try Some (float_of_string x)\n with Failure _ -> None\n\nlet parse_and_expand_argv_dynamic_aux allow_expand current argv speclist anonfun\n errmsg =\n let initpos = !current in\n let convert_error error =\n (* convert an internal error to a Bad/Help exception\n *or* add the program name as a prefix and the usage message as a suffix\n to an user-raised Bad exception.\n *)\n let b = Buffer.create 200 in\n let progname =\n if initpos < (Array.length !argv) then !argv.(initpos) else \"(?)\" in\n begin match error with\n | Unknown \"-help\" -> ()\n | Unknown \"--help\" -> ()\n | Unknown s ->\n bprintf b \"%s: unknown option '%s'.\\n\" progname s\n | Missing s ->\n bprintf b \"%s: option '%s' needs an argument.\\n\" progname s\n | Wrong (opt, arg, expected) ->\n bprintf b \"%s: wrong argument '%s'; option '%s' expects %s.\\n\"\n progname arg opt expected\n | Message s -> (* user error message *)\n bprintf b \"%s: %s.\\n\" progname s\n end;\n usage_b b !speclist errmsg;\n if error = Unknown \"-help\" || error = Unknown \"--help\"\n then Help (Buffer.contents b)\n else Bad (Buffer.contents b)\n in\n incr current;\n while !current < (Array.length !argv) do\n begin try\n let s = !argv.(!current) in\n if String.length s >= 1 && s.[0] = '-' then begin\n let action, follow =\n try assoc3 s !speclist, None\n with Not_found ->\n try\n let keyword, arg = split s in\n assoc3 keyword !speclist, Some arg\n with Not_found -> raise (Stop (Unknown s))\n in\n let no_arg () =\n match follow with\n | None -> ()\n | Some arg -> raise (Stop (Wrong (s, arg, \"no argument\"))) in\n let get_arg () =\n match follow with\n | None ->\n if !current + 1 < (Array.length !argv) then !argv.(!current + 1)\n else raise (Stop (Missing s))\n | Some arg -> arg\n in\n let consume_arg () =\n match follow with\n | None -> incr current\n | Some _ -> ()\n in\n let rec treat_action = function\n | Unit f -> no_arg (); f ();\n | Bool f ->\n let arg = get_arg () in\n begin match bool_of_string_opt arg with\n | None -> raise (Stop (Wrong (s, arg, \"a boolean\")))\n | Some s -> f s\n end;\n consume_arg ();\n | Set r -> no_arg (); r := true;\n | Clear r -> no_arg (); r := false;\n | String f ->\n let arg = get_arg () in\n f arg;\n consume_arg ();\n | Symbol (symb, f) ->\n let arg = get_arg () in\n if List.mem arg symb then begin\n f arg;\n consume_arg ();\n end else begin\n raise (Stop (Wrong (s, arg, \"one of: \"\n ^ (make_symlist \"\" \" \" \"\" symb))))\n end\n | Set_string r ->\n r := get_arg ();\n consume_arg ();\n | Int f ->\n let arg = get_arg () in\n begin match int_of_string_opt arg with\n | None -> raise (Stop (Wrong (s, arg, \"an integer\")))\n | Some x -> f x\n end;\n consume_arg ();\n | Set_int r ->\n let arg = get_arg () in\n begin match int_of_string_opt arg with\n | None -> raise (Stop (Wrong (s, arg, \"an integer\")))\n | Some x -> r := x\n end;\n consume_arg ();\n | Float f ->\n let arg = get_arg () in\n begin match float_of_string_opt arg with\n | None -> raise (Stop (Wrong (s, arg, \"a float\")))\n | Some x -> f x\n end;\n consume_arg ();\n | Set_float r ->\n let arg = get_arg () in\n begin match float_of_string_opt arg with\n | None -> raise (Stop (Wrong (s, arg, \"a float\")))\n | Some x -> r := x\n end;\n consume_arg ();\n | Tuple specs ->\n no_arg ();\n List.iter treat_action specs;\n | Rest f ->\n no_arg ();\n while !current < (Array.length !argv) - 1 do\n f !argv.(!current + 1);\n consume_arg ();\n done;\n | Rest_all f ->\n no_arg ();\n let acc = ref [] in\n while !current < Array.length !argv - 1 do\n acc := !argv.(!current + 1) :: !acc;\n consume_arg ();\n done;\n f (List.rev !acc)\n | Expand f ->\n if not allow_expand then\n raise (Invalid_argument \"Arg.Expand is is only allowed with \\\n Arg.parse_and_expand_argv_dynamic\");\n let arg = get_arg () in\n let newarg = f arg in\n consume_arg ();\n let before = Array.sub !argv 0 (!current + 1)\n and after =\n Array.sub !argv (!current + 1)\n ((Array.length !argv) - !current - 1) in\n argv:= Array.concat [before;newarg;after];\n in\n treat_action action end\n else anonfun s\n with | Bad m -> raise (convert_error (Message m));\n | Stop e -> raise (convert_error e);\n end;\n incr current\n done\n\nlet parse_and_expand_argv_dynamic current argv speclist anonfun errmsg =\n parse_and_expand_argv_dynamic_aux true current argv speclist anonfun errmsg\n\nlet parse_argv_dynamic ?(current=current) argv speclist anonfun errmsg =\n parse_and_expand_argv_dynamic_aux false current (ref argv) speclist anonfun\n errmsg\n\n\nlet parse_argv ?(current=current) argv speclist anonfun errmsg =\n parse_argv_dynamic ~current:current argv (ref speclist) anonfun errmsg\n\n\nlet parse l f msg =\n try\n parse_argv Sys.argv l f msg\n with\n | Bad msg -> eprintf \"%s\" msg; exit 2\n | Help msg -> printf \"%s\" msg; exit 0\n\n\nlet parse_dynamic l f msg =\n try\n parse_argv_dynamic Sys.argv l f msg\n with\n | Bad msg -> eprintf \"%s\" msg; exit 2\n | Help msg -> printf \"%s\" msg; exit 0\n\nlet parse_expand l f msg =\n try\n let argv = ref Sys.argv in\n let spec = ref l in\n let current = ref (!current) in\n parse_and_expand_argv_dynamic current argv spec f msg\n with\n | Bad msg -> eprintf \"%s\" msg; exit 2\n | Help msg -> printf \"%s\" msg; exit 0\n\n\nlet second_word s =\n let len = String.length s in\n let rec loop n =\n if n >= len then len\n else if s.[n] = ' ' then loop (n+1)\n else n\n in\n match String.index s '\\t' with\n | n -> loop (n+1)\n | exception Not_found ->\n begin match String.index s ' ' with\n | n -> loop (n+1)\n | exception Not_found -> len\n end\n\n\nlet max_arg_len cur (kwd, spec, doc) =\n match spec with\n | Symbol _ -> Int.max cur (String.length kwd)\n | _ -> Int.max cur (String.length kwd + second_word doc)\n\n\nlet replace_leading_tab s =\n let seen = ref false in\n String.map (function '\\t' when not !seen -> seen := true; ' ' | c -> c) s\n\nlet add_padding len ksd =\n match ksd with\n | (_, _, \"\") ->\n (* Do not pad undocumented options, so that they still don't show up when\n * run through [usage] or [parse]. *)\n ksd\n | (kwd, (Symbol _ as spec), msg) ->\n let cutcol = second_word msg in\n let spaces = String.make ((Int.max 0 (len - cutcol)) + 3) ' ' in\n (kwd, spec, \"\\n\" ^ spaces ^ replace_leading_tab msg)\n | (kwd, spec, msg) ->\n let cutcol = second_word msg in\n let kwd_len = String.length kwd in\n let diff = len - kwd_len - cutcol in\n if diff <= 0 then\n (kwd, spec, replace_leading_tab msg)\n else\n let spaces = String.make diff ' ' in\n let prefix = String.sub (replace_leading_tab msg) 0 cutcol in\n let suffix = String.sub msg cutcol (String.length msg - cutcol) in\n (kwd, spec, prefix ^ spaces ^ suffix)\n\n\nlet align ?(limit=max_int) speclist =\n let completed = add_help speclist in\n let len = List.fold_left max_arg_len 0 completed in\n let len = Int.min len limit in\n List.map (add_padding len) completed\n\nlet trim_cr s =\n let len = String.length s in\n if len > 0 && String.get s (len - 1) = '\\r' then\n String.sub s 0 (len - 1)\n else\n s\n\nlet read_aux trim sep file =\n let ic = open_in_bin file in\n let buf = Buffer.create 200 in\n let words = ref [] in\n let stash () =\n let word = Buffer.contents buf in\n let word = if trim then trim_cr word else word in\n words := word :: !words;\n Buffer.clear buf\n in\n begin\n try while true do\n let c = input_char ic in\n if c = sep then stash () else Buffer.add_char buf c\n done\n with End_of_file -> ()\n end;\n if Buffer.length buf > 0 then stash ();\n close_in ic;\n Array.of_list (List.rev !words)\n\nlet read_arg = read_aux true '\\n'\n\nlet read_arg0 = read_aux false '\\x00'\n\nlet write_aux sep file args =\n let oc = open_out_bin file in\n Array.iter (fun s -> fprintf oc \"%s%c\" s sep) args;\n close_out oc\n\nlet write_arg = write_aux '\\n'\n\nlet write_arg0 = write_aux '\\x00'\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* The OCaml programmers *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nexternal id : 'a -> 'a = \"%identity\"\nlet const c _ = c\nlet flip f x y = f y x\nlet negate p v = not (p v)\n\nexception Finally_raised of exn\n\nlet () = Printexc.register_printer @@ function\n| Finally_raised exn -> Some (\"Fun.Finally_raised: \" ^ Printexc.to_string exn)\n| _ -> None\n\nlet protect ~(finally : unit -> unit) work =\n let finally_no_exn () =\n try finally () with e ->\n let bt = Printexc.get_raw_backtrace () in\n Printexc.raise_with_backtrace (Finally_raised e) bt\n in\n match work () with\n | result -> finally_no_exn () ; result\n | exception work_exn ->\n let work_bt = Printexc.get_raw_backtrace () in\n finally_no_exn () ;\n Printexc.raise_with_backtrace work_exn work_bt\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Message digest (MD5) *)\n\ntype t = string\n\nlet compare = String.compare\nlet equal = String.equal\n\nexternal unsafe_string: string -> int -> int -> t = \"caml_md5_string\"\nexternal channel: in_channel -> int -> t = \"caml_md5_chan\"\n\nlet string str =\n unsafe_string str 0 (String.length str)\n\nlet bytes b = string (Bytes.unsafe_to_string b)\n\nlet substring str ofs len =\n if ofs < 0 || len < 0 || ofs > String.length str - len\n then invalid_arg \"Digest.substring\"\n else unsafe_string str ofs len\n\nlet subbytes b ofs len = substring (Bytes.unsafe_to_string b) ofs len\n\nlet file filename =\n let ic = open_in_bin filename in\n match channel ic (-1) with\n | d -> close_in ic; d\n | exception e -> close_in ic; raise e\n\nlet output chan digest =\n output_string chan digest\n\nlet input chan = really_input_string chan 16\n\nlet char_hex n =\n Char.unsafe_chr (n + if n < 10 then Char.code '0' else (Char.code 'a' - 10))\n\nlet to_hex d =\n if String.length d <> 16 then invalid_arg \"Digest.to_hex\";\n let result = Bytes.create 32 in\n for i = 0 to 15 do\n let x = Char.code d.[i] in\n Bytes.unsafe_set result (i*2) (char_hex (x lsr 4));\n Bytes.unsafe_set result (i*2+1) (char_hex (x land 0x0f));\n done;\n Bytes.unsafe_to_string result\n\nlet from_hex s =\n if String.length s <> 32 then invalid_arg \"Digest.from_hex\";\n let digit c =\n match c with\n | '0'..'9' -> Char.code c - Char.code '0'\n | 'A'..'F' -> Char.code c - Char.code 'A' + 10\n | 'a'..'f' -> Char.code c - Char.code 'a' + 10\n | _ -> raise (Invalid_argument \"Digest.from_hex\")\n in\n let byte i = digit s.[i] lsl 4 + digit s.[i+1] in\n let result = Bytes.create 16 in\n for i = 0 to 15 do\n Bytes.set result i (Char.chr (byte (2 * i)));\n done;\n Bytes.unsafe_to_string result\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Para, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Pseudo-random number generator\n This is a lagged-Fibonacci F(55, 24, +) with a modified addition\n function to enhance the mixing of bits.\n If we use normal addition, the low-order bit fails tests 1 and 7\n of the Diehard test suite, and bits 1 and 2 also fail test 7.\n If we use multiplication as suggested by Marsaglia, it doesn't fare\n much better.\n By mixing the bits of one of the numbers before addition (XOR the\n 5 high-order bits into the low-order bits), we get a generator that\n passes all the Diehard tests.\n*)\n\nexternal random_seed: unit -> int array = \"caml_sys_random_seed\"\n\nmodule State = struct\n\n type t = { st : int array; mutable idx : int }\n\n let new_state () = { st = Array.make 55 0; idx = 0 }\n let assign st1 st2 =\n Array.blit st2.st 0 st1.st 0 55;\n st1.idx <- st2.idx\n\n\n let full_init s seed =\n let combine accu x = Digest.string (accu ^ Int.to_string x) in\n let extract d =\n Char.code d.[0] + (Char.code d.[1] lsl 8) + (Char.code d.[2] lsl 16)\n + (Char.code d.[3] lsl 24)\n in\n let seed = if Array.length seed = 0 then [| 0 |] else seed in\n let l = Array.length seed in\n for i = 0 to 54 do\n s.st.(i) <- i;\n done;\n let accu = ref \"x\" in\n for i = 0 to 54 + Int.max 55 l do\n let j = i mod 55 in\n let k = i mod l in\n accu := combine !accu seed.(k);\n s.st.(j) <- (s.st.(j) lxor extract !accu) land 0x3FFFFFFF; (* PR#5575 *)\n done;\n s.idx <- 0\n\n\n let make seed =\n let result = new_state () in\n full_init result seed;\n result\n\n\n let make_self_init () = make (random_seed ())\n\n let copy s =\n let result = new_state () in\n assign result s;\n result\n\n\n (* Returns 30 random bits as an integer 0 <= x < 1073741824 *)\n let bits s =\n s.idx <- (s.idx + 1) mod 55;\n let curval = s.st.(s.idx) in\n let newval = s.st.((s.idx + 24) mod 55)\n + (curval lxor ((curval lsr 25) land 0x1F)) in\n let newval30 = newval land 0x3FFFFFFF in (* PR#5575 *)\n s.st.(s.idx) <- newval30;\n newval30\n\n\n let rec intaux s n =\n let r = bits s in\n let v = r mod n in\n if r - v > 0x3FFFFFFF - n + 1 then intaux s n else v\n\n let int s bound =\n if bound > 0x3FFFFFFF || bound <= 0\n then invalid_arg \"Random.int\"\n else intaux s bound\n\n let rec int63aux s n =\n let max_int_32 = (1 lsl 30) + 0x3FFFFFFF in (* 0x7FFFFFFF *)\n let b1 = bits s in\n let b2 = bits s in\n let (r, max_int) =\n if n <= max_int_32 then\n (* 31 random bits on both 64-bit OCaml and JavaScript.\n Use upper 15 bits of b1 and 16 bits of b2. *)\n let bpos =\n (((b2 land 0x3FFFC000) lsl 1) lor (b1 lsr 15))\n in\n (bpos, max_int_32)\n else\n let b3 = bits s in\n (* 62 random bits on 64-bit OCaml; unreachable on JavaScript.\n Use upper 20 bits of b1 and 21 bits of b2 and b3. *)\n let bpos =\n ((((b3 land 0x3FFFFE00) lsl 12) lor (b2 lsr 9)) lsl 20)\n lor (b1 lsr 10)\n in\n (bpos, max_int)\n in\n let v = r mod n in\n if r - v > max_int - n + 1 then int63aux s n else v\n\n let full_int s bound =\n if bound <= 0 then\n invalid_arg \"Random.full_int\"\n else if bound > 0x3FFFFFFF then\n int63aux s bound\n else\n intaux s bound\n\n\n let rec int32aux s n =\n let b1 = Int32.of_int (bits s) in\n let b2 = Int32.shift_left (Int32.of_int (bits s land 1)) 30 in\n let r = Int32.logor b1 b2 in\n let v = Int32.rem r n in\n if Int32.sub r v > Int32.add (Int32.sub Int32.max_int n) 1l\n then int32aux s n\n else v\n\n let int32 s bound =\n if bound <= 0l\n then invalid_arg \"Random.int32\"\n else int32aux s bound\n\n\n let rec int64aux s n =\n let b1 = Int64.of_int (bits s) in\n let b2 = Int64.shift_left (Int64.of_int (bits s)) 30 in\n let b3 = Int64.shift_left (Int64.of_int (bits s land 7)) 60 in\n let r = Int64.logor b1 (Int64.logor b2 b3) in\n let v = Int64.rem r n in\n if Int64.sub r v > Int64.add (Int64.sub Int64.max_int n) 1L\n then int64aux s n\n else v\n\n let int64 s bound =\n if bound <= 0L\n then invalid_arg \"Random.int64\"\n else int64aux s bound\n\n\n let nativeint =\n if Nativeint.size = 32\n then fun s bound -> Nativeint.of_int32 (int32 s (Nativeint.to_int32 bound))\n else fun s bound -> Int64.to_nativeint (int64 s (Int64.of_nativeint bound))\n\n\n (* Returns a float 0 <= x <= 1 with at most 60 bits of precision. *)\n let rawfloat s =\n let scale = 1073741824.0 (* 2^30 *)\n and r1 = Stdlib.float (bits s)\n and r2 = Stdlib.float (bits s)\n in (r1 /. scale +. r2) /. scale\n\n\n let float s bound = rawfloat s *. bound\n\n let bool s = (bits s land 1 = 0)\n\n let bits32 s =\n let b1 = Int32.(shift_right_logical (of_int (bits s)) 14) in (* 16 bits *)\n let b2 = Int32.(shift_right_logical (of_int (bits s)) 14) in (* 16 bits *)\n Int32.(logor b1 (shift_left b2 16))\n\n let bits64 s =\n let b1 = Int64.(shift_right_logical (of_int (bits s)) 9) in (* 21 bits *)\n let b2 = Int64.(shift_right_logical (of_int (bits s)) 9) in (* 21 bits *)\n let b3 = Int64.(shift_right_logical (of_int (bits s)) 8) in (* 22 bits *)\n Int64.(logor b1 (logor (shift_left b2 21) (shift_left b3 42)))\n\n let nativebits =\n if Nativeint.size = 32\n then fun s -> Nativeint.of_int32 (bits32 s)\n else fun s -> Int64.to_nativeint (bits64 s)\n\nend\n\n(* This is the state you get with [init 27182818] and then applying\n the \"land 0x3FFFFFFF\" filter to them. See #5575, #5793, #5977. *)\nlet default = {\n State.st = [|\n 0x3ae2522b; 0x1d8d4634; 0x15b4fad0; 0x18b14ace; 0x12f8a3c4; 0x3b086c47;\n 0x16d467d6; 0x101d91c7; 0x321df177; 0x0176c193; 0x1ff72bf1; 0x1e889109;\n 0x0b464b18; 0x2b86b97c; 0x0891da48; 0x03137463; 0x085ac5a1; 0x15d61f2f;\n 0x3bced359; 0x29c1c132; 0x3a86766e; 0x366d8c86; 0x1f5b6222; 0x3ce1b59f;\n 0x2ebf78e1; 0x27cd1b86; 0x258f3dc3; 0x389a8194; 0x02e4c44c; 0x18c43f7d;\n 0x0f6e534f; 0x1e7df359; 0x055d0b7e; 0x10e84e7e; 0x126198e4; 0x0e7722cb;\n 0x1cbede28; 0x3391b964; 0x3d40e92a; 0x0c59933d; 0x0b8cd0b7; 0x24efff1c;\n 0x2803fdaa; 0x08ebc72e; 0x0f522e32; 0x05398edc; 0x2144a04c; 0x0aef3cbd;\n 0x01ad4719; 0x35b93cd6; 0x2a559d4f; 0x1e6fd768; 0x26e27f36; 0x186f18c3;\n 0x2fbf967a;\n |];\n State.idx = 0;\n}\n\nlet bits () = State.bits default\nlet int bound = State.int default bound\nlet full_int bound = State.full_int default bound\nlet int32 bound = State.int32 default bound\nlet nativeint bound = State.nativeint default bound\nlet int64 bound = State.int64 default bound\nlet float scale = State.float default scale\nlet bool () = State.bool default\nlet bits32 () = State.bits32 default\nlet bits64 () = State.bits64 default\nlet nativebits () = State.nativebits default\n\nlet full_init seed = State.full_init default seed\nlet init seed = State.full_init default [| seed |]\nlet self_init () = full_init (random_seed())\n\n(* Manipulating the current state. *)\n\nlet get_state () = State.copy default\nlet set_state s = State.assign default s\n\n(********************\n\n(* Test functions. Not included in the library.\n The [chisquare] function should be called with n > 10r.\n It returns a triple (low, actual, high).\n If low <= actual <= high, the [g] function passed the test,\n otherwise it failed.\n\n Some results:\n\ninit 27182818; chisquare int 100000 1000\ninit 27182818; chisquare int 100000 100\ninit 27182818; chisquare int 100000 5000\ninit 27182818; chisquare int 1000000 1000\ninit 27182818; chisquare int 100000 1024\ninit 299792643; chisquare int 100000 1024\ninit 14142136; chisquare int 100000 1024\ninit 27182818; init_diff 1024; chisquare diff 100000 1024\ninit 27182818; init_diff 100; chisquare diff 100000 100\ninit 27182818; init_diff2 1024; chisquare diff2 100000 1024\ninit 27182818; init_diff2 100; chisquare diff2 100000 100\ninit 14142136; init_diff2 100; chisquare diff2 100000 100\ninit 299792643; init_diff2 100; chisquare diff2 100000 100\n- : float * float * float = (936.754446796632465, 997.5, 1063.24555320336754)\n# - : float * float * float = (80., 89.7400000000052387, 120.)\n# - : float * float * float = (4858.57864376269, 5045.5, 5141.42135623731)\n# - : float * float * float =\n(936.754446796632465, 944.805999999982305, 1063.24555320336754)\n# - : float * float * float = (960., 1019.19744000000355, 1088.)\n# - : float * float * float = (960., 1059.31776000000536, 1088.)\n# - : float * float * float = (960., 1039.98463999999512, 1088.)\n# - : float * float * float = (960., 1054.38207999999577, 1088.)\n# - : float * float * float = (80., 90.096000000005, 120.)\n# - : float * float * float = (960., 1076.78720000000612, 1088.)\n# - : float * float * float = (80., 85.1760000000067521, 120.)\n# - : float * float * float = (80., 85.2160000000003492, 120.)\n# - : float * float * float = (80., 80.6220000000030268, 120.)\n\n*)\n\n(* Return the sum of the squares of v[i0,i1[ *)\nlet rec sumsq v i0 i1 =\n if i0 >= i1 then 0.0\n else if i1 = i0 + 1 then Stdlib.float v.(i0) *. Stdlib.float v.(i0)\n else sumsq v i0 ((i0+i1)/2) +. sumsq v ((i0+i1)/2) i1\n\n\nlet chisquare g n r =\n if n <= 10 * r then invalid_arg \"chisquare\";\n let f = Array.make r 0 in\n for i = 1 to n do\n let t = g r in\n f.(t) <- f.(t) + 1\n done;\n let t = sumsq f 0 r\n and r = Stdlib.float r\n and n = Stdlib.float n in\n let sr = 2.0 *. sqrt r in\n (r -. sr, (r *. t /. n) -. n, r +. sr)\n\n\n(* This is to test for linear dependencies between successive random numbers.\n*)\nlet st = ref 0\nlet init_diff r = st := int r\nlet diff r =\n let x1 = !st\n and x2 = int r\n in\n st := x2;\n if x1 >= x2 then\n x1 - x2\n else\n r + x1 - x2\n\n\nlet st1 = ref 0\nand st2 = ref 0\n\n\n(* This is to test for quadratic dependencies between successive random\n numbers.\n*)\nlet init_diff2 r = st1 := int r; st2 := int r\nlet diff2 r =\n let x1 = !st1\n and x2 = !st2\n and x3 = int r\n in\n st1 := x2;\n st2 := x3;\n (x3 - x2 - x2 + x1 + 2*r) mod r\n\n\n********************)\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Hash tables *)\n\n(* We do dynamic hashing, and resize the table and rehash the elements\n when buckets become too long. *)\n\ntype ('a, 'b) t =\n { mutable size: int; (* number of entries *)\n mutable data: ('a, 'b) bucketlist array; (* the buckets *)\n seed: int; (* for randomization *)\n mutable initial_size: int; (* initial array size *)\n }\n\nand ('a, 'b) bucketlist =\n Empty\n | Cons of { mutable key: 'a;\n mutable data: 'b;\n mutable next: ('a, 'b) bucketlist }\n\n(* The sign of initial_size encodes the fact that a traversal is\n ongoing or not.\n\n This disables the efficient in place implementation of resizing.\n*)\n\nlet ongoing_traversal h =\n Obj.size (Obj.repr h) < 4 (* compatibility with old hash tables *)\n || h.initial_size < 0\n\nlet flip_ongoing_traversal h =\n h.initial_size <- - h.initial_size\n\n(* To pick random seeds if requested *)\n\nlet randomized_default =\n let params =\n try Sys.getenv \"OCAMLRUNPARAM\" with Not_found ->\n try Sys.getenv \"CAMLRUNPARAM\" with Not_found -> \"\" in\n String.contains params 'R'\n\nlet randomized = ref randomized_default\n\nlet randomize () = randomized := true\nlet is_randomized () = !randomized\n\nlet prng = lazy (Random.State.make_self_init())\n\n(* Functions which appear before the functorial interface must either be\n independent of the hash function or take it as a parameter (see #2202 and\n code below the functor definitions. *)\n\n(* Creating a fresh, empty table *)\n\nlet rec power_2_above x n =\n if x >= n then x\n else if x * 2 > Sys.max_array_length then x\n else power_2_above (x * 2) n\n\nlet create ?(random = !randomized) initial_size =\n let s = power_2_above 16 initial_size in\n let seed = if random then Random.State.bits (Lazy.force prng) else 0 in\n { initial_size = s; size = 0; seed = seed; data = Array.make s Empty }\n\nlet clear h =\n if h.size > 0 then begin\n h.size <- 0;\n Array.fill h.data 0 (Array.length h.data) Empty\n end\n\nlet reset h =\n let len = Array.length h.data in\n if Obj.size (Obj.repr h) < 4 (* compatibility with old hash tables *)\n || len = abs h.initial_size then\n clear h\n else begin\n h.size <- 0;\n h.data <- Array.make (abs h.initial_size) Empty\n end\n\nlet copy_bucketlist = function\n | Empty -> Empty\n | Cons {key; data; next} ->\n let rec loop prec = function\n | Empty -> ()\n | Cons {key; data; next} ->\n let r = Cons {key; data; next} in\n begin match prec with\n | Empty -> assert false\n | Cons prec -> prec.next <- r\n end;\n loop r next\n in\n let r = Cons {key; data; next} in\n loop r next;\n r\n\nlet copy h = { h with data = Array.map copy_bucketlist h.data }\n\nlet length h = h.size\n\nlet insert_all_buckets indexfun inplace odata ndata =\n let nsize = Array.length ndata in\n let ndata_tail = Array.make nsize Empty in\n let rec insert_bucket = function\n | Empty -> ()\n | Cons {key; data; next} as cell ->\n let cell =\n if inplace then cell\n else Cons {key; data; next = Empty}\n in\n let nidx = indexfun key in\n begin match ndata_tail.(nidx) with\n | Empty -> ndata.(nidx) <- cell;\n | Cons tail -> tail.next <- cell;\n end;\n ndata_tail.(nidx) <- cell;\n insert_bucket next\n in\n for i = 0 to Array.length odata - 1 do\n insert_bucket odata.(i)\n done;\n if inplace then\n for i = 0 to nsize - 1 do\n match ndata_tail.(i) with\n | Empty -> ()\n | Cons tail -> tail.next <- Empty\n done\n\nlet resize indexfun h =\n let odata = h.data in\n let osize = Array.length odata in\n let nsize = osize * 2 in\n if nsize < Sys.max_array_length then begin\n let ndata = Array.make nsize Empty in\n let inplace = not (ongoing_traversal h) in\n h.data <- ndata; (* so that indexfun sees the new bucket count *)\n insert_all_buckets (indexfun h) inplace odata ndata\n end\n\nlet iter f h =\n let rec do_bucket = function\n | Empty ->\n ()\n | Cons{key; data; next} ->\n f key data; do_bucket next in\n let old_trav = ongoing_traversal h in\n if not old_trav then flip_ongoing_traversal h;\n try\n let d = h.data in\n for i = 0 to Array.length d - 1 do\n do_bucket d.(i)\n done;\n if not old_trav then flip_ongoing_traversal h;\n with exn when not old_trav ->\n flip_ongoing_traversal h;\n raise exn\n\nlet rec filter_map_inplace_bucket f h i prec = function\n | Empty ->\n begin match prec with\n | Empty -> h.data.(i) <- Empty\n | Cons c -> c.next <- Empty\n end\n | (Cons ({key; data; next} as c)) as slot ->\n begin match f key data with\n | None ->\n h.size <- h.size - 1;\n filter_map_inplace_bucket f h i prec next\n | Some data ->\n begin match prec with\n | Empty -> h.data.(i) <- slot\n | Cons c -> c.next <- slot\n end;\n c.data <- data;\n filter_map_inplace_bucket f h i slot next\n end\n\nlet filter_map_inplace f h =\n let d = h.data in\n let old_trav = ongoing_traversal h in\n if not old_trav then flip_ongoing_traversal h;\n try\n for i = 0 to Array.length d - 1 do\n filter_map_inplace_bucket f h i Empty h.data.(i)\n done;\n if not old_trav then flip_ongoing_traversal h\n with exn when not old_trav ->\n flip_ongoing_traversal h;\n raise exn\n\nlet fold f h init =\n let rec do_bucket b accu =\n match b with\n Empty ->\n accu\n | Cons{key; data; next} ->\n do_bucket next (f key data accu) in\n let old_trav = ongoing_traversal h in\n if not old_trav then flip_ongoing_traversal h;\n try\n let d = h.data in\n let accu = ref init in\n for i = 0 to Array.length d - 1 do\n accu := do_bucket d.(i) !accu\n done;\n if not old_trav then flip_ongoing_traversal h;\n !accu\n with exn when not old_trav ->\n flip_ongoing_traversal h;\n raise exn\n\ntype statistics = {\n num_bindings: int;\n num_buckets: int;\n max_bucket_length: int;\n bucket_histogram: int array\n}\n\nlet rec bucket_length accu = function\n | Empty -> accu\n | Cons{next} -> bucket_length (accu + 1) next\n\nlet stats h =\n let mbl =\n Array.fold_left (fun m b -> Int.max m (bucket_length 0 b)) 0 h.data in\n let histo = Array.make (mbl + 1) 0 in\n Array.iter\n (fun b ->\n let l = bucket_length 0 b in\n histo.(l) <- histo.(l) + 1)\n h.data;\n { num_bindings = h.size;\n num_buckets = Array.length h.data;\n max_bucket_length = mbl;\n bucket_histogram = histo }\n\n(** {1 Iterators} *)\n\nlet to_seq tbl =\n (* capture current array, so that even if the table is resized we\n keep iterating on the same array *)\n let tbl_data = tbl.data in\n (* state: index * next bucket to traverse *)\n let rec aux i buck () = match buck with\n | Empty ->\n if i = Array.length tbl_data\n then Seq.Nil\n else aux(i+1) tbl_data.(i) ()\n | Cons {key; data; next} ->\n Seq.Cons ((key, data), aux i next)\n in\n aux 0 Empty\n\nlet to_seq_keys m = Seq.map fst (to_seq m)\n\nlet to_seq_values m = Seq.map snd (to_seq m)\n\n(* Functorial interface *)\n\nmodule type HashedType =\n sig\n type t\n val equal: t -> t -> bool\n val hash: t -> int\n end\n\nmodule type SeededHashedType =\n sig\n type t\n val equal: t -> t -> bool\n val hash: int -> t -> int\n end\n\nmodule type S =\n sig\n type key\n type !'a t\n val create: int -> 'a t\n val clear : 'a t -> unit\n val reset : 'a t -> unit\n val copy: 'a t -> 'a t\n val add: 'a t -> key -> 'a -> unit\n val remove: 'a t -> key -> unit\n val find: 'a t -> key -> 'a\n val find_opt: 'a t -> key -> 'a option\n val find_all: 'a t -> key -> 'a list\n val replace : 'a t -> key -> 'a -> unit\n val mem : 'a t -> key -> bool\n val iter: (key -> 'a -> unit) -> 'a t -> unit\n val filter_map_inplace: (key -> 'a -> 'a option) -> 'a t -> unit\n val fold: (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n val length: 'a t -> int\n val stats: 'a t -> statistics\n val to_seq : 'a t -> (key * 'a) Seq.t\n val to_seq_keys : _ t -> key Seq.t\n val to_seq_values : 'a t -> 'a Seq.t\n val add_seq : 'a t -> (key * 'a) Seq.t -> unit\n val replace_seq : 'a t -> (key * 'a) Seq.t -> unit\n val of_seq : (key * 'a) Seq.t -> 'a t\n end\n\nmodule type SeededS =\n sig\n type key\n type !'a t\n val create : ?random:bool -> int -> 'a t\n val clear : 'a t -> unit\n val reset : 'a t -> unit\n val copy : 'a t -> 'a t\n val add : 'a t -> key -> 'a -> unit\n val remove : 'a t -> key -> unit\n val find : 'a t -> key -> 'a\n val find_opt: 'a t -> key -> 'a option\n val find_all : 'a t -> key -> 'a list\n val replace : 'a t -> key -> 'a -> unit\n val mem : 'a t -> key -> bool\n val iter : (key -> 'a -> unit) -> 'a t -> unit\n val filter_map_inplace: (key -> 'a -> 'a option) -> 'a t -> unit\n val fold : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n val length : 'a t -> int\n val stats: 'a t -> statistics\n val to_seq : 'a t -> (key * 'a) Seq.t\n val to_seq_keys : _ t -> key Seq.t\n val to_seq_values : 'a t -> 'a Seq.t\n val add_seq : 'a t -> (key * 'a) Seq.t -> unit\n val replace_seq : 'a t -> (key * 'a) Seq.t -> unit\n val of_seq : (key * 'a) Seq.t -> 'a t\n end\n\nmodule MakeSeeded(H: SeededHashedType): (SeededS with type key = H.t) =\n struct\n type key = H.t\n type 'a hashtbl = (key, 'a) t\n type 'a t = 'a hashtbl\n let create = create\n let clear = clear\n let reset = reset\n let copy = copy\n\n let key_index h key =\n (H.hash h.seed key) land (Array.length h.data - 1)\n\n let add h key data =\n let i = key_index h key in\n let bucket = Cons{key; data; next=h.data.(i)} in\n h.data.(i) <- bucket;\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize key_index h\n\n let rec remove_bucket h i key prec = function\n | Empty ->\n ()\n | (Cons {key=k; next}) as c ->\n if H.equal k key\n then begin\n h.size <- h.size - 1;\n match prec with\n | Empty -> h.data.(i) <- next\n | Cons c -> c.next <- next\n end\n else remove_bucket h i key c next\n\n let remove h key =\n let i = key_index h key in\n remove_bucket h i key Empty h.data.(i)\n\n let rec find_rec key = function\n | Empty ->\n raise Not_found\n | Cons{key=k; data; next} ->\n if H.equal key k then data else find_rec key next\n\n let find h key =\n match h.data.(key_index h key) with\n | Empty -> raise Not_found\n | Cons{key=k1; data=d1; next=next1} ->\n if H.equal key k1 then d1 else\n match next1 with\n | Empty -> raise Not_found\n | Cons{key=k2; data=d2; next=next2} ->\n if H.equal key k2 then d2 else\n match next2 with\n | Empty -> raise Not_found\n | Cons{key=k3; data=d3; next=next3} ->\n if H.equal key k3 then d3 else find_rec key next3\n\n let rec find_rec_opt key = function\n | Empty ->\n None\n | Cons{key=k; data; next} ->\n if H.equal key k then Some data else find_rec_opt key next\n\n let find_opt h key =\n match h.data.(key_index h key) with\n | Empty -> None\n | Cons{key=k1; data=d1; next=next1} ->\n if H.equal key k1 then Some d1 else\n match next1 with\n | Empty -> None\n | Cons{key=k2; data=d2; next=next2} ->\n if H.equal key k2 then Some d2 else\n match next2 with\n | Empty -> None\n | Cons{key=k3; data=d3; next=next3} ->\n if H.equal key k3 then Some d3 else find_rec_opt key next3\n\n let find_all h key =\n let rec find_in_bucket = function\n | Empty ->\n []\n | Cons{key=k; data=d; next} ->\n if H.equal k key\n then d :: find_in_bucket next\n else find_in_bucket next in\n find_in_bucket h.data.(key_index h key)\n\n let rec replace_bucket key data = function\n | Empty ->\n true\n | Cons ({key=k; next} as slot) ->\n if H.equal k key\n then (slot.key <- key; slot.data <- data; false)\n else replace_bucket key data next\n\n let replace h key data =\n let i = key_index h key in\n let l = h.data.(i) in\n if replace_bucket key data l then begin\n h.data.(i) <- Cons{key; data; next=l};\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize key_index h\n end\n\n let mem h key =\n let rec mem_in_bucket = function\n | Empty ->\n false\n | Cons{key=k; next} ->\n H.equal k key || mem_in_bucket next in\n mem_in_bucket h.data.(key_index h key)\n\n let add_seq tbl i =\n Seq.iter (fun (k,v) -> add tbl k v) i\n\n let replace_seq tbl i =\n Seq.iter (fun (k,v) -> replace tbl k v) i\n\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n\n let iter = iter\n let filter_map_inplace = filter_map_inplace\n let fold = fold\n let length = length\n let stats = stats\n let to_seq = to_seq\n let to_seq_keys = to_seq_keys\n let to_seq_values = to_seq_values\n end\n\nmodule Make(H: HashedType): (S with type key = H.t) =\n struct\n include MakeSeeded(struct\n type t = H.t\n let equal = H.equal\n let hash (_seed: int) x = H.hash x\n end)\n let create sz = create ~random:false sz\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n end\n\n(* Polymorphic hash function-based tables *)\n(* Code included below the functorial interface to guard against accidental\n use - see #2202 *)\n\nexternal seeded_hash_param :\n int -> int -> int -> 'a -> int = \"caml_hash\" [@@noalloc]\n\nlet hash x = seeded_hash_param 10 100 0 x\nlet hash_param n1 n2 x = seeded_hash_param n1 n2 0 x\nlet seeded_hash seed x = seeded_hash_param 10 100 seed x\n\nlet key_index h key =\n if Obj.size (Obj.repr h) >= 4\n then (seeded_hash_param 10 100 h.seed key) land (Array.length h.data - 1)\n else invalid_arg \"Hashtbl: unsupported hash table format\"\n\nlet add h key data =\n let i = key_index h key in\n let bucket = Cons{key; data; next=h.data.(i)} in\n h.data.(i) <- bucket;\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize key_index h\n\nlet rec remove_bucket h i key prec = function\n | Empty ->\n ()\n | (Cons {key=k; next}) as c ->\n if compare k key = 0\n then begin\n h.size <- h.size - 1;\n match prec with\n | Empty -> h.data.(i) <- next\n | Cons c -> c.next <- next\n end\n else remove_bucket h i key c next\n\nlet remove h key =\n let i = key_index h key in\n remove_bucket h i key Empty h.data.(i)\n\nlet rec find_rec key = function\n | Empty ->\n raise Not_found\n | Cons{key=k; data; next} ->\n if compare key k = 0 then data else find_rec key next\n\nlet find h key =\n match h.data.(key_index h key) with\n | Empty -> raise Not_found\n | Cons{key=k1; data=d1; next=next1} ->\n if compare key k1 = 0 then d1 else\n match next1 with\n | Empty -> raise Not_found\n | Cons{key=k2; data=d2; next=next2} ->\n if compare key k2 = 0 then d2 else\n match next2 with\n | Empty -> raise Not_found\n | Cons{key=k3; data=d3; next=next3} ->\n if compare key k3 = 0 then d3 else find_rec key next3\n\nlet rec find_rec_opt key = function\n | Empty ->\n None\n | Cons{key=k; data; next} ->\n if compare key k = 0 then Some data else find_rec_opt key next\n\nlet find_opt h key =\n match h.data.(key_index h key) with\n | Empty -> None\n | Cons{key=k1; data=d1; next=next1} ->\n if compare key k1 = 0 then Some d1 else\n match next1 with\n | Empty -> None\n | Cons{key=k2; data=d2; next=next2} ->\n if compare key k2 = 0 then Some d2 else\n match next2 with\n | Empty -> None\n | Cons{key=k3; data=d3; next=next3} ->\n if compare key k3 = 0 then Some d3 else find_rec_opt key next3\n\nlet find_all h key =\n let rec find_in_bucket = function\n | Empty ->\n []\n | Cons{key=k; data; next} ->\n if compare k key = 0\n then data :: find_in_bucket next\n else find_in_bucket next in\n find_in_bucket h.data.(key_index h key)\n\nlet rec replace_bucket key data = function\n | Empty ->\n true\n | Cons ({key=k; next} as slot) ->\n if compare k key = 0\n then (slot.key <- key; slot.data <- data; false)\n else replace_bucket key data next\n\nlet replace h key data =\n let i = key_index h key in\n let l = h.data.(i) in\n if replace_bucket key data l then begin\n h.data.(i) <- Cons{key; data; next=l};\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize key_index h\n end\n\nlet mem h key =\n let rec mem_in_bucket = function\n | Empty ->\n false\n | Cons{key=k; next} ->\n compare k key = 0 || mem_in_bucket next in\n mem_in_bucket h.data.(key_index h key)\n\nlet add_seq tbl i =\n Seq.iter (fun (k,v) -> add tbl k v) i\n\nlet replace_seq tbl i =\n Seq.iter (fun (k,v) -> replace tbl k v) i\n\nlet of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n\nlet rebuild ?(random = !randomized) h =\n let s = power_2_above 16 (Array.length h.data) in\n let seed =\n if random then Random.State.bits (Lazy.force prng)\n else if Obj.size (Obj.repr h) >= 4 then h.seed\n else 0 in\n let h' = {\n size = h.size;\n data = Array.make s Empty;\n seed = seed;\n initial_size = if Obj.size (Obj.repr h) >= 4 then h.initial_size else s\n } in\n insert_all_buckets (key_index h') false h.data h'.data;\n h'\n","open! Import\n\nlet poly_equal a b =\n let module Poly = struct\n type t = T : _ -> t\n end in\n Stdppx.Poly.equal (Poly.T a) (Poly.T b)\n\nmodule Context = struct\n type 'a t =\n | Label_declaration : label_declaration t\n | Constructor_declaration : constructor_declaration t\n | Type_declaration : type_declaration t\n | Type_exception : type_exception t\n | Type_extension : type_extension t\n | Extension_constructor : extension_constructor t\n | Pattern : pattern t\n | Core_type : core_type t\n | Expression : expression t\n | Value_description : value_description t\n | Class_type : class_type t\n | Class_type_field : class_type_field t\n | Class_infos : _ class_infos t\n | Class_expr : class_expr t\n | Class_field : class_field t\n | Module_type : module_type t\n | Module_declaration : module_declaration t\n | Module_type_declaration : module_type_declaration t\n | Module_substitution : module_substitution t\n | Open_description : open_description t\n | Open_declaration : open_declaration t\n | Include_infos : _ include_infos t\n | Module_expr : module_expr t\n | Value_binding : value_binding t\n | Module_binding : module_binding t\n | Pstr_eval : structure_item t\n | Pstr_extension : structure_item t\n | Psig_extension : signature_item t\n | Rtag : row_field t\n | Object_type_field : object_field t\n\n let label_declaration = Label_declaration\n let constructor_declaration = Constructor_declaration\n let type_declaration = Type_declaration\n let type_extension = Type_extension\n let type_exception = Type_exception\n let extension_constructor = Extension_constructor\n let pattern = Pattern\n let core_type = Core_type\n let expression = Expression\n let value_description = Value_description\n let class_type = Class_type\n let class_type_field = Class_type_field\n let class_infos = Class_infos\n let class_expr = Class_expr\n let class_field = Class_field\n let module_type = Module_type\n let module_declaration = Module_declaration\n let module_type_declaration = Module_type_declaration\n let open_description = Open_description\n let include_infos = Include_infos\n let module_expr = Module_expr\n let value_binding = Value_binding\n let module_binding = Module_binding\n let pstr_eval = Pstr_eval\n let pstr_extension = Pstr_extension\n let psig_extension = Psig_extension\n let rtag = Rtag\n let object_type_field = Object_type_field\n\n let get_pstr_eval st =\n match st.pstr_desc with\n | Pstr_eval (e, l) -> (e, l)\n | _ -> failwith \"Attribute.Context.get_pstr_eval\"\n\n let get_pstr_extension st =\n match st.pstr_desc with\n | Pstr_extension (e, l) -> (e, l)\n | _ -> failwith \"Attribute.Context.get_pstr_extension\"\n\n let get_psig_extension st =\n match st.psig_desc with\n | Psig_extension (e, l) -> (e, l)\n | _ -> failwith \"Attribute.Context.get_psig_extension\"\n\n let get_attributes : type a. a t -> a -> attributes =\n fun t x ->\n match t with\n | Label_declaration -> x.pld_attributes\n | Constructor_declaration -> x.pcd_attributes\n | Type_declaration -> x.ptype_attributes\n | Type_extension -> x.ptyext_attributes\n | Type_exception -> x.ptyexn_attributes\n | Extension_constructor -> x.pext_attributes\n | Pattern -> x.ppat_attributes\n | Core_type -> x.ptyp_attributes\n | Expression -> x.pexp_attributes\n | Value_description -> x.pval_attributes\n | Class_type -> x.pcty_attributes\n | Class_type_field -> x.pctf_attributes\n | Class_infos -> x.pci_attributes\n | Class_expr -> x.pcl_attributes\n | Class_field -> x.pcf_attributes\n | Module_type -> x.pmty_attributes\n | Module_declaration -> x.pmd_attributes\n | Module_type_declaration -> x.pmtd_attributes\n | Module_substitution -> x.pms_attributes\n | Open_description -> x.popen_attributes\n | Open_declaration -> x.popen_attributes\n | Include_infos -> x.pincl_attributes\n | Module_expr -> x.pmod_attributes\n | Value_binding -> x.pvb_attributes\n | Module_binding -> x.pmb_attributes\n | Pstr_eval -> snd (get_pstr_eval x)\n | Pstr_extension -> snd (get_pstr_extension x)\n | Psig_extension -> snd (get_psig_extension x)\n | Rtag -> x.prf_attributes\n | Object_type_field -> x.pof_attributes\n\n let set_attributes : type a. a t -> a -> attributes -> a =\n fun t x attrs ->\n match t with\n | Label_declaration -> { x with pld_attributes = attrs }\n | Constructor_declaration -> { x with pcd_attributes = attrs }\n | Type_declaration -> { x with ptype_attributes = attrs }\n | Type_extension -> { x with ptyext_attributes = attrs }\n | Type_exception -> { x with ptyexn_attributes = attrs }\n | Extension_constructor -> { x with pext_attributes = attrs }\n | Pattern -> { x with ppat_attributes = attrs }\n | Core_type -> { x with ptyp_attributes = attrs }\n | Expression -> { x with pexp_attributes = attrs }\n | Value_description -> { x with pval_attributes = attrs }\n | Class_type -> { x with pcty_attributes = attrs }\n | Class_type_field -> { x with pctf_attributes = attrs }\n | Class_infos -> { x with pci_attributes = attrs }\n | Class_expr -> { x with pcl_attributes = attrs }\n | Class_field -> { x with pcf_attributes = attrs }\n | Module_type -> { x with pmty_attributes = attrs }\n | Module_declaration -> { x with pmd_attributes = attrs }\n | Module_type_declaration -> { x with pmtd_attributes = attrs }\n | Module_substitution -> { x with pms_attributes = attrs }\n | Open_description -> { x with popen_attributes = attrs }\n | Open_declaration -> { x with popen_attributes = attrs }\n | Include_infos -> { x with pincl_attributes = attrs }\n | Module_expr -> { x with pmod_attributes = attrs }\n | Value_binding -> { x with pvb_attributes = attrs }\n | Module_binding -> { x with pmb_attributes = attrs }\n | Pstr_eval ->\n { x with pstr_desc = Pstr_eval (get_pstr_eval x |> fst, attrs) }\n | Pstr_extension ->\n {\n x with\n pstr_desc = Pstr_extension (get_pstr_extension x |> fst, attrs);\n }\n | Psig_extension ->\n {\n x with\n psig_desc = Psig_extension (get_psig_extension x |> fst, attrs);\n }\n | Rtag -> { x with prf_attributes = attrs }\n | Object_type_field -> { x with pof_attributes = attrs }\n\n let desc : type a. a t -> string = function\n | Label_declaration -> \"label declaration\"\n | Constructor_declaration -> \"constructor declaration\"\n | Type_declaration -> \"type declaration\"\n | Type_extension -> \"type extension\"\n | Type_exception -> \"type exception\"\n | Extension_constructor -> \"extension constructor\"\n | Pattern -> \"pattern\"\n | Core_type -> \"core type\"\n | Expression -> \"expression\"\n | Value_description -> \"value\"\n | Class_type -> \"class type\"\n | Class_type_field -> \"class type field\"\n | Class_infos -> \"class declaration\"\n | Class_expr -> \"class expression\"\n | Class_field -> \"class field\"\n | Module_type -> \"module type\"\n | Module_declaration -> \"module declaration\"\n | Module_type_declaration -> \"module type declaration\"\n | Module_substitution -> \"module substitution\"\n | Open_description -> \"open\"\n | Open_declaration -> \"open\"\n | Include_infos -> \"include\"\n | Module_expr -> \"module expression\"\n | Value_binding -> \"value binding\"\n | Module_binding -> \"module binding\"\n | Pstr_eval -> \"toplevel expression\"\n | Pstr_extension -> \"toplevel extension\"\n | Psig_extension -> \"toplevel signature extension\"\n | Rtag -> \"polymorphic variant tag\"\n | Object_type_field -> \"object type field\"\n\n (*\n let pattern : type a b c d. a t\n -> (attributes, b, c) Ast_pattern.t\n -> (a, c, d) Ast_pattern.t\n -> (a, b, d) Ast_pattern.t = function\n | Label_declaration -> Ast_pattern.pld_attributes\n | Constructor_declaration -> Ast_pattern.pcd_attributes\n | Type_declaration -> Ast_pattern.ptype_attributes\n | Type_extension -> Ast_pattern.ptyext_attributes\n | Extension_constructor -> Ast_pattern.pext_attributes\n*)\n\n let equal : _ t -> _ t -> bool = poly_equal\nend\n\nmodule Floating_context = struct\n type 'a t =\n | Structure_item : structure_item t\n | Signature_item : signature_item t\n | Class_field : class_field t\n | Class_type_field : class_type_field t\n\n let structure_item = Structure_item\n let signature_item = Signature_item\n let class_field = Class_field\n let class_type_field = Class_type_field\n\n let get_attribute_if_is_floating_node : type a. a t -> a -> attribute option =\n fun t x ->\n match (t, x) with\n | Structure_item, { pstr_desc = Pstr_attribute a; _ } -> Some a\n | Signature_item, { psig_desc = Psig_attribute a; _ } -> Some a\n | Class_field, { pcf_desc = Pcf_attribute a; _ } -> Some a\n | Class_type_field, { pctf_desc = Pctf_attribute a; _ } -> Some a\n | _ -> None\n\n let get_attribute t x =\n match get_attribute_if_is_floating_node t x with\n | Some a -> a\n | None -> failwith \"Attribute.Floating.Context.get_attribute\"\n\n let replace_by_dummy : type a. a t -> a -> a =\n let dummy_ext = ({ txt = \"\"; loc = Location.none }, PStr []) in\n fun t x ->\n match t with\n | Structure_item -> { x with pstr_desc = Pstr_extension (dummy_ext, []) }\n | Signature_item -> { x with psig_desc = Psig_extension (dummy_ext, []) }\n | Class_field -> { x with pcf_desc = Pcf_extension dummy_ext }\n | Class_type_field -> { x with pctf_desc = Pctf_extension dummy_ext }\n\n let desc : type a. a t -> string = function\n | Structure_item -> \"structure item\"\n | Signature_item -> \"signature item\"\n | Class_field -> \"class field\"\n | Class_type_field -> \"class type field\"\n\n let equal : _ t -> _ t -> bool = poly_equal\nend\n\ntype packed_context =\n | On_item : _ Context.t -> packed_context\n | Floating : _ Floating_context.t -> packed_context\n\ntype _ payload_parser =\n | Payload_parser :\n (payload, 'a, 'b) Ast_pattern.t * (name_loc:Location.t -> 'a)\n -> 'b payload_parser\n\ntype ('a, 'b) t = {\n name : Name.Pattern.t;\n context : 'a Context.t;\n payload : 'b payload_parser;\n}\n\ntype packed = T : (_, _) t -> packed\n\nlet name t = Name.Pattern.name t.name\nlet context t = t.context\n\nlet registrar =\n Name.Registrar.create ~kind:\"attribute\" ~current_file:__FILE__\n ~string_of_context:(function\n | On_item t -> Some (Context.desc t)\n | Floating t -> Some (Floating_context.desc t ^ \" (floating)\"))\n\nlet declare_with_name_loc name context pattern k =\n Name.Registrar.register ~kind:`Attribute registrar (On_item context) name;\n {\n name = Name.Pattern.make name;\n context;\n payload = Payload_parser (pattern, k);\n }\n\nlet declare name context pattern k =\n declare_with_name_loc name context pattern (fun ~name_loc:_ -> k)\n\nmodule Attribute_table = Caml.Hashtbl.Make (struct\n type t = string loc\n\n let hash : t -> int = Hashtbl.hash\n let equal : t -> t -> bool = Poly.equal\nend)\n\nlet not_seen = Attribute_table.create 128\nlet mark_as_seen { attr_name; _ } = Attribute_table.remove not_seen attr_name\nlet mark_as_handled_manually = mark_as_seen\n\nlet explicitly_drop =\n object\n inherit Ast_traverse.iter\n method! attribute = mark_as_seen\n end\n\nlet get_internal =\n let rec find_best_match t attributes longest_match =\n match attributes with\n | [] -> longest_match\n | ({ attr_name = name; _ } as attr) :: rest ->\n if Name.Pattern.matches t.name name.txt then\n match longest_match with\n | None -> find_best_match t rest (Some attr)\n | Some { attr_name = name'; _ } ->\n let len = String.length name.txt in\n let len' = String.length name'.txt in\n if len > len' then find_best_match t rest (Some attr)\n else if len < len' then find_best_match t rest longest_match\n else Location.raise_errorf ~loc:name.loc \"Duplicated attribute\"\n else find_best_match t rest longest_match\n in\n fun t attributes -> find_best_match t attributes None\n\nlet convert ?(do_mark_as_seen = true) pattern attr =\n if do_mark_as_seen then mark_as_seen attr;\n let (Payload_parser (pattern, k)) = pattern in\n Ast_pattern.parse pattern\n (Common.loc_of_payload attr)\n attr.attr_payload\n (k ~name_loc:attr.attr_name.loc)\n\nlet get t ?mark_as_seen:do_mark_as_seen x =\n let attrs = Context.get_attributes t.context x in\n match get_internal t attrs with\n | None -> None\n | Some attr -> Some (convert t.payload attr ?do_mark_as_seen)\n\nlet consume t x =\n let attrs = Context.get_attributes t.context x in\n match get_internal t attrs with\n | None -> None\n | Some attr ->\n let attrs = List.filter attrs ~f:(fun attr' -> not (attr == attr')) in\n let x = Context.set_attributes t.context x attrs in\n Some (x, convert t.payload attr)\n\nlet remove_seen (type a) (context : a Context.t) packeds (x : a) =\n let attrs = Context.get_attributes context x in\n let matched =\n let rec loop acc = function\n | [] -> acc\n | T t :: rest ->\n if Context.equal t.context context then\n match get_internal t attrs with\n | None -> loop acc rest\n | Some attr ->\n let name = attr.attr_name in\n if Attribute_table.mem not_seen name then loop acc rest\n else loop (attr :: acc) rest\n else loop acc rest\n in\n loop [] packeds\n in\n let attrs =\n List.filter attrs ~f:(fun attr' -> not (List.memq ~set:matched attr'))\n in\n Context.set_attributes context x attrs\n\nlet pattern t p =\n let f = Ast_pattern.to_func p in\n Ast_pattern.of_func (fun ctx loc x k ->\n match consume t x with\n | None -> f ctx loc x (k None)\n | Some (x, v) -> f ctx loc x (k (Some v)))\n\nmodule Floating = struct\n module Context = Floating_context\n\n type ('a, 'b) t = {\n name : Name.Pattern.t;\n context : 'a Context.t;\n payload : 'b payload_parser;\n }\n\n let name t = Name.Pattern.name t.name\n\n let declare name context pattern k =\n Name.Registrar.register ~kind:`Attribute registrar (Floating context) name;\n {\n name = Name.Pattern.make name;\n context;\n payload = Payload_parser (pattern, fun ~name_loc:_ -> k);\n }\n\n let convert ts x =\n match ts with\n | [] -> None\n | { context; _ } :: _ -> (\n assert (List.for_all ts ~f:(fun t -> Context.equal t.context context));\n let attr = Context.get_attribute context x in\n let name = attr.attr_name in\n match\n List.filter ts ~f:(fun t -> Name.Pattern.matches t.name name.txt)\n with\n | [] -> None\n | [ t ] -> Some (convert t.payload attr)\n | l ->\n Location.raise_errorf ~loc:name.loc\n \"Multiple match for floating attributes: %s\"\n (String.concat ~sep:\", \"\n (List.map l ~f:(fun t -> Name.Pattern.name t.name))))\nend\n\nlet check_attribute registrar context name =\n if\n (not\n (Name.Whitelisted.is_whitelisted ~kind:`Attribute name.txt\n || Name.ignore_checks name.txt))\n && Attribute_table.mem not_seen name\n then\n let white_list = Name.Whitelisted.get_attribute_list () in\n Name.Registrar.raise_errorf registrar context ~white_list\n \"Attribute `%s' was not used\" name\n\nlet check_unused =\n object (self)\n inherit Ast_traverse.iter as super\n\n method! attribute { attr_name = name; _ } =\n Location.raise_errorf ~loc:name.loc\n \"attribute not expected here, Ppxlib.Attribute needs updating!\"\n\n method private check_node : type a. a Context.t -> a -> a =\n fun context node ->\n let attrs = Context.get_attributes context node in\n match attrs with\n | [] -> node\n | _ ->\n List.iter attrs\n ~f:(fun ({ attr_name = name; attr_payload = payload; _ } as attr)\n ->\n self#payload payload;\n check_attribute registrar (On_item context) name;\n (* If we allow the attribute to pass through, mark it as seen *)\n mark_as_seen attr);\n Context.set_attributes context node []\n\n method private check_floating : type a. a Floating.Context.t -> a -> a =\n fun context node ->\n match\n Floating.Context.get_attribute_if_is_floating_node context node\n with\n | None -> node\n | Some ({ attr_name = name; attr_payload = payload; _ } as attr) ->\n self#payload payload;\n check_attribute registrar (Floating context) name;\n mark_as_seen attr;\n Floating.Context.replace_by_dummy context node\n\n method! label_declaration x =\n super#label_declaration (self#check_node Label_declaration x)\n\n method! constructor_declaration x =\n super#constructor_declaration (self#check_node Constructor_declaration x)\n\n method! type_declaration x =\n super#type_declaration (self#check_node Type_declaration x)\n\n method! type_extension x =\n super#type_extension (self#check_node Type_extension x)\n\n method! type_exception x =\n super#type_exception (self#check_node Type_exception x)\n\n method! extension_constructor x =\n super#extension_constructor (self#check_node Extension_constructor x)\n\n method! pattern x = super#pattern (self#check_node Pattern x)\n method! core_type x = super#core_type (self#check_node Core_type x)\n method! expression x = super#expression (self#check_node Expression x)\n\n method! value_description x =\n super#value_description (self#check_node Value_description x)\n\n method! class_type x = super#class_type (self#check_node Class_type x)\n\n method! class_infos f x =\n super#class_infos f (self#check_node Class_infos x)\n\n method! class_expr x = super#class_expr (self#check_node Class_expr x)\n method! module_type x = super#module_type (self#check_node Module_type x)\n\n method! module_declaration x =\n super#module_declaration (self#check_node Module_declaration x)\n\n method! module_type_declaration x =\n super#module_type_declaration (self#check_node Module_type_declaration x)\n\n method! open_description x =\n super#open_description (self#check_node Open_description x)\n\n method! open_declaration x =\n super#open_declaration (self#check_node Open_declaration x)\n\n method! include_infos f x =\n super#include_infos f (self#check_node Include_infos x)\n\n method! module_expr x = super#module_expr (self#check_node Module_expr x)\n\n method! value_binding x =\n super#value_binding (self#check_node Value_binding x)\n\n method! module_binding x =\n super#module_binding (self#check_node Module_binding x)\n\n method! class_field x =\n let x = self#check_node Class_field x in\n let x = self#check_floating Class_field x in\n super#class_field x\n\n method! class_type_field x =\n let x = self#check_node Class_type_field x in\n let x = self#check_floating Class_type_field x in\n super#class_type_field x\n\n method! row_field x =\n let x =\n match x.prf_desc with Rtag _ -> self#check_node Rtag x | _ -> x\n in\n super#row_field x\n\n method! core_type_desc x =\n let x =\n match x with\n | Ptyp_object (fields, closed_flag) ->\n let fields =\n List.map fields ~f:(self#check_node Object_type_field)\n in\n Ptyp_object (fields, closed_flag)\n | _ -> x\n in\n super#core_type_desc x\n\n method! structure_item item =\n let item = self#check_floating Structure_item item in\n let item =\n match item.pstr_desc with\n | Pstr_eval _ -> self#check_node Pstr_eval item\n | Pstr_extension _ -> self#check_node Pstr_extension item\n | _ -> item\n in\n super#structure_item item\n\n method! signature_item item =\n let item = self#check_floating Signature_item item in\n let item =\n match item.psig_desc with\n | Psig_extension _ -> self#check_node Psig_extension item\n | _ -> item\n in\n super#signature_item item\n end\n\nlet reset_checks () = Attribute_table.clear not_seen\n\nlet collect =\n object\n inherit Ast_traverse.iter as super\n\n method! attribute ({ attr_name = name; attr_payload = payload; _ } as attr)\n =\n let loc = Common.loc_of_attribute attr in\n super#payload payload;\n Attribute_table.add not_seen name loc\n end\n\nlet check_all_seen () =\n let fail name loc =\n let txt = name.txt in\n if not (Name.ignore_checks txt) then\n Location.raise_errorf ~loc \"Attribute `%s' was silently dropped\" txt\n in\n Attribute_table.iter fail not_seen\n\nlet remove_attributes_present_in table =\n object\n inherit Ast_traverse.iter as super\n\n method! attribute { attr_name = name; attr_payload = payload; _ } =\n super#payload payload;\n Attribute_table.remove table name\n end\n\nlet copy_of_not_seen () =\n let copy = Attribute_table.create (Attribute_table.length not_seen) in\n Attribute_table.iter (Attribute_table.add copy) not_seen;\n copy\n\nlet dropped_so_far_structure st =\n let table = copy_of_not_seen () in\n (remove_attributes_present_in table)#structure st;\n Attribute_table.fold\n (fun name loc acc -> { txt = name.txt; loc } :: acc)\n table []\n\nlet dropped_so_far_signature sg =\n let table = copy_of_not_seen () in\n (remove_attributes_present_in table)#signature sg;\n Attribute_table.fold\n (fun name loc acc -> { txt = name.txt; loc } :: acc)\n table []\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Pierre Weis, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* A pretty-printing facility and definition of formatters for 'parallel'\n (i.e. unrelated or independent) pretty-printing on multiple out channels. *)\n\n(*\n The pretty-printing engine internal data structures.\n*)\n\nlet id x = x\n\n(* A devoted type for sizes to avoid confusion\n between sizes and mere integers. *)\nmodule Size : sig\n type t\n\n val to_int : t -> int\n val of_int : int -> t\n val zero : t\n val unknown : t\n val is_known : t -> bool\nend = struct\n type t = int\n\n let to_int = id\n let of_int = id\n let zero = 0\n let unknown = -1\n let is_known n = n >= 0\nend\n\n\n\n(* The pretty-printing boxes definition:\n a pretty-printing box is either\n - hbox: horizontal box (no line splitting)\n - vbox: vertical box (every break hint splits the line)\n - hvbox: horizontal/vertical box\n (the box behaves as an horizontal box if it fits on\n the current line, otherwise the box behaves as a vertical box)\n - hovbox: horizontal or vertical compacting box\n (the box is compacting material, printing as much material as possible\n on every lines)\n - box: horizontal or vertical compacting box with enhanced box structure\n (the box behaves as an horizontal or vertical box but break hints split\n the line if splitting would move to the left)\n*)\ntype box_type = CamlinternalFormatBasics.block_type =\n | Pp_hbox | Pp_vbox | Pp_hvbox | Pp_hovbox | Pp_box | Pp_fits\n\n\n(* The pretty-printing tokens definition:\n are either text to print or pretty printing\n elements that drive indentation and line splitting. *)\ntype pp_token =\n | Pp_text of string (* normal text *)\n | Pp_break of { (* complete break *)\n fits: string * int * string; (* line is not split *)\n breaks: string * int * string; (* line is split *)\n }\n | Pp_tbreak of int * int (* go to next tabulation *)\n | Pp_stab (* set a tabulation *)\n | Pp_begin of int * box_type (* beginning of a box *)\n | Pp_end (* end of a box *)\n | Pp_tbegin of tbox (* beginning of a tabulation box *)\n | Pp_tend (* end of a tabulation box *)\n | Pp_newline (* to force a newline inside a box *)\n | Pp_if_newline (* to do something only if this very\n line has been broken *)\n | Pp_open_tag of stag (* opening a tag name *)\n | Pp_close_tag (* closing the most recently open tag *)\n\nand stag = ..\n\nand tbox = Pp_tbox of int list ref (* Tabulation box *)\n\ntype tag = string\ntype stag += String_tag of tag\n\n\n(* The pretty-printer queue:\n pretty-printing material is not written in the output as soon as emitted;\n instead, the material is simply recorded in the pretty-printer queue,\n until the enclosing box has a known computed size and proper splitting\n decisions can be made.\n\n The pretty-printer queue contains formatting elements to be printed.\n Each formatting element is a tuple (size, token, length), where\n - length is the declared length of the token,\n - size is effective size of the token when it is printed\n (size is set when the size of the box is known, so that size of break\n hints are definitive). *)\ntype pp_queue_elem = {\n mutable size : Size.t;\n token : pp_token;\n length : int;\n}\n\n\n(* The pretty-printer queue definition. *)\ntype pp_queue = pp_queue_elem Queue.t\n\n(* The pretty-printer scanning stack. *)\n\n(* The pretty-printer scanning stack: scanning element definition. *)\ntype pp_scan_elem = {\n left_total : int; (* Value of pp_left_total when the element was enqueued. *)\n queue_elem : pp_queue_elem\n}\n\n(* The pretty-printer formatting stack:\n the formatting stack contains the description of all the currently active\n boxes; the pretty-printer formatting stack is used to split the lines\n while printing tokens. *)\n\n(* The pretty-printer formatting stack: formatting stack element definition.\n Each stack element describes a pretty-printing box. *)\ntype pp_format_elem = { box_type : box_type; width : int }\n\n(* The formatter definition.\n Each formatter value is a pretty-printer instance with all its\n machinery. *)\ntype formatter = {\n (* The pretty-printer scanning stack. *)\n pp_scan_stack : pp_scan_elem Stack.t;\n (* The pretty-printer formatting stack. *)\n pp_format_stack : pp_format_elem Stack.t;\n pp_tbox_stack : tbox Stack.t;\n (* The pretty-printer semantics tag stack. *)\n pp_tag_stack : stag Stack.t;\n pp_mark_stack : stag Stack.t;\n (* Value of right margin. *)\n mutable pp_margin : int;\n (* Minimal space left before margin, when opening a box. *)\n mutable pp_min_space_left : int;\n (* Maximum value of indentation:\n no box can be opened further. *)\n mutable pp_max_indent : int;\n (* Space remaining on the current line. *)\n mutable pp_space_left : int;\n (* Current value of indentation. *)\n mutable pp_current_indent : int;\n (* True when the line has been broken by the pretty-printer. *)\n mutable pp_is_new_line : bool;\n (* Total width of tokens already printed. *)\n mutable pp_left_total : int;\n (* Total width of tokens ever put in queue. *)\n mutable pp_right_total : int;\n (* Current number of open boxes. *)\n mutable pp_curr_depth : int;\n (* Maximum number of boxes which can be simultaneously open. *)\n mutable pp_max_boxes : int;\n (* Ellipsis string. *)\n mutable pp_ellipsis : string;\n (* Output function. *)\n mutable pp_out_string : string -> int -> int -> unit;\n (* Flushing function. *)\n mutable pp_out_flush : unit -> unit;\n (* Output of new lines. *)\n mutable pp_out_newline : unit -> unit;\n (* Output of break hints spaces. *)\n mutable pp_out_spaces : int -> unit;\n (* Output of indentation of new lines. *)\n mutable pp_out_indent : int -> unit;\n (* Are tags printed ? *)\n mutable pp_print_tags : bool;\n (* Are tags marked ? *)\n mutable pp_mark_tags : bool;\n (* Find opening and closing markers of tags. *)\n mutable pp_mark_open_tag : stag -> string;\n mutable pp_mark_close_tag : stag -> string;\n mutable pp_print_open_tag : stag -> unit;\n mutable pp_print_close_tag : stag -> unit;\n (* The pretty-printer queue. *)\n pp_queue : pp_queue;\n}\n\n\n(* The formatter specific tag handling functions. *)\ntype formatter_stag_functions = {\n mark_open_stag : stag -> string;\n mark_close_stag : stag -> string;\n print_open_stag : stag -> unit;\n print_close_stag : stag -> unit;\n}\n\n\n(* The formatter functions to output material. *)\ntype formatter_out_functions = {\n out_string : string -> int -> int -> unit;\n out_flush : unit -> unit;\n out_newline : unit -> unit;\n out_spaces : int -> unit;\n out_indent : int -> unit;\n}\n\n\n(*\n\n Auxiliaries and basic functions.\n\n*)\n\n(* Enter a token in the pretty-printer queue. *)\nlet pp_enqueue state token =\n state.pp_right_total <- state.pp_right_total + token.length;\n Queue.add token state.pp_queue\n\n\nlet pp_clear_queue state =\n state.pp_left_total <- 1; state.pp_right_total <- 1;\n Queue.clear state.pp_queue\n\n\n(* Pp_infinity: large value for default tokens size.\n\n Pp_infinity is documented as being greater than 1e10; to avoid\n confusion about the word 'greater', we choose pp_infinity greater\n than 1e10 + 1; for correct handling of tests in the algorithm,\n pp_infinity must be even one more than 1e10 + 1; let's stand on the\n safe side by choosing 1.e10+10.\n\n Pp_infinity could probably be 1073741823 that is 2^30 - 1, that is\n the minimal upper bound for integers; now that max_int is defined,\n this limit could also be defined as max_int - 1.\n\n However, before setting pp_infinity to something around max_int, we\n must carefully double-check all the integer arithmetic operations\n that involve pp_infinity, since any overflow would wreck havoc the\n pretty-printing algorithm's invariants. Given that this arithmetic\n correctness check is difficult and error prone and given that 1e10\n + 1 is in practice large enough, there is no need to attempt to set\n pp_infinity to the theoretically maximum limit. It is not worth the\n burden ! *)\nlet pp_infinity = 1000000010\n\n(* Output functions for the formatter. *)\nlet pp_output_string state s = state.pp_out_string s 0 (String.length s)\nand pp_output_newline state = state.pp_out_newline ()\nand pp_output_spaces state n = state.pp_out_spaces n\nand pp_output_indent state n = state.pp_out_indent n\n\n(* Format a textual token *)\nlet format_pp_text state size text =\n state.pp_space_left <- state.pp_space_left - size;\n pp_output_string state text;\n state.pp_is_new_line <- false\n\n(* Format a string by its length, if not empty *)\nlet format_string state s =\n if s <> \"\" then format_pp_text state (String.length s) s\n\n(* To format a break, indenting a new line. *)\nlet break_new_line state (before, offset, after) width =\n format_string state before;\n pp_output_newline state;\n state.pp_is_new_line <- true;\n let indent = state.pp_margin - width + offset in\n (* Don't indent more than pp_max_indent. *)\n let real_indent = Int.min state.pp_max_indent indent in\n state.pp_current_indent <- real_indent;\n state.pp_space_left <- state.pp_margin - state.pp_current_indent;\n pp_output_indent state state.pp_current_indent;\n format_string state after\n\n\n(* To force a line break inside a box: no offset is added. *)\nlet break_line state width = break_new_line state (\"\", 0, \"\") width\n\n(* To format a break that fits on the current line. *)\nlet break_same_line state (before, width, after) =\n format_string state before;\n state.pp_space_left <- state.pp_space_left - width;\n pp_output_spaces state width;\n format_string state after\n\n\n(* To indent no more than pp_max_indent, if one tries to open a box\n beyond pp_max_indent, then the box is rejected on the left\n by simulating a break. *)\nlet pp_force_break_line state =\n match Stack.top_opt state.pp_format_stack with\n | None -> pp_output_newline state\n | Some { box_type; width } ->\n if width > state.pp_space_left then\n match box_type with\n | Pp_fits | Pp_hbox -> ()\n | Pp_vbox | Pp_hvbox | Pp_hovbox | Pp_box -> break_line state width\n\n\n(* To skip a token, if the previous line has been broken. *)\nlet pp_skip_token state =\n match Queue.take_opt state.pp_queue with\n | None -> () (* print_if_newline must have been the last printing command *)\n | Some { size; length; _ } ->\n state.pp_left_total <- state.pp_left_total - length;\n state.pp_space_left <- state.pp_space_left + Size.to_int size\n\n\n(*\n\n The main pretty printing functions.\n\n*)\n\n(* Formatting a token with a given size. *)\nlet format_pp_token state size = function\n\n | Pp_text s ->\n format_pp_text state size s\n\n | Pp_begin (off, ty) ->\n let insertion_point = state.pp_margin - state.pp_space_left in\n if insertion_point > state.pp_max_indent then\n (* can not open a box right there. *)\n begin pp_force_break_line state end;\n let width = state.pp_space_left - off in\n let box_type =\n match ty with\n | Pp_vbox -> Pp_vbox\n | Pp_hbox | Pp_hvbox | Pp_hovbox | Pp_box | Pp_fits ->\n if size > state.pp_space_left then ty else Pp_fits in\n Stack.push { box_type; width } state.pp_format_stack\n\n | Pp_end ->\n Stack.pop_opt state.pp_format_stack |> ignore\n\n | Pp_tbegin (Pp_tbox _ as tbox) ->\n Stack.push tbox state.pp_tbox_stack\n\n | Pp_tend ->\n Stack.pop_opt state.pp_tbox_stack |> ignore\n\n | Pp_stab ->\n begin match Stack.top_opt state.pp_tbox_stack with\n | None -> () (* No open tabulation box. *)\n | Some (Pp_tbox tabs) ->\n let rec add_tab n = function\n | [] -> [n]\n | x :: l as ls -> if n < x then n :: ls else x :: add_tab n l in\n tabs := add_tab (state.pp_margin - state.pp_space_left) !tabs\n end\n\n | Pp_tbreak (n, off) ->\n let insertion_point = state.pp_margin - state.pp_space_left in\n begin match Stack.top_opt state.pp_tbox_stack with\n | None -> () (* No open tabulation box. *)\n | Some (Pp_tbox tabs) ->\n let tab =\n match !tabs with\n | [] -> insertion_point\n | first :: _ ->\n let rec find = function\n | head :: tail ->\n if head >= insertion_point then head else find tail\n | [] -> first in\n find !tabs in\n let offset = tab - insertion_point in\n if offset >= 0\n then break_same_line state (\"\", offset + n, \"\")\n else break_new_line state (\"\", tab + off, \"\") state.pp_margin\n end\n\n | Pp_newline ->\n begin match Stack.top_opt state.pp_format_stack with\n | None -> pp_output_newline state (* No open box. *)\n | Some { width; _} -> break_line state width\n end\n\n | Pp_if_newline ->\n if state.pp_current_indent != state.pp_margin - state.pp_space_left\n then pp_skip_token state\n\n | Pp_break { fits; breaks } ->\n let before, off, _ = breaks in\n begin match Stack.top_opt state.pp_format_stack with\n | None -> () (* No open box. *)\n | Some { box_type; width } ->\n begin match box_type with\n | Pp_hovbox ->\n if size + String.length before > state.pp_space_left\n then break_new_line state breaks width\n else break_same_line state fits\n | Pp_box ->\n (* Have the line just been broken here ? *)\n if state.pp_is_new_line then break_same_line state fits else\n if size + String.length before > state.pp_space_left\n then break_new_line state breaks width else\n (* break the line here leads to new indentation ? *)\n if state.pp_current_indent > state.pp_margin - width + off\n then break_new_line state breaks width\n else break_same_line state fits\n | Pp_hvbox -> break_new_line state breaks width\n | Pp_fits -> break_same_line state fits\n | Pp_vbox -> break_new_line state breaks width\n | Pp_hbox -> break_same_line state fits\n end\n end\n\n | Pp_open_tag tag_name ->\n let marker = state.pp_mark_open_tag tag_name in\n pp_output_string state marker;\n Stack.push tag_name state.pp_mark_stack\n\n | Pp_close_tag ->\n begin match Stack.pop_opt state.pp_mark_stack with\n | None -> () (* No more tag to close. *)\n | Some tag_name ->\n let marker = state.pp_mark_close_tag tag_name in\n pp_output_string state marker\n end\n\n\n(* Print if token size is known else printing is delayed.\n Printing is delayed when the text waiting in the queue requires\n more room to format than exists on the current line. *)\nlet rec advance_left state =\n match Queue.peek_opt state.pp_queue with\n | None -> () (* No tokens to print *)\n | Some { size; token; length } ->\n let pending_count = state.pp_right_total - state.pp_left_total in\n if Size.is_known size || pending_count >= state.pp_space_left then begin\n Queue.take state.pp_queue |> ignore; (* Not empty: we peek into it *)\n let size = if Size.is_known size then Size.to_int size else pp_infinity in\n format_pp_token state size token;\n state.pp_left_total <- length + state.pp_left_total;\n (advance_left [@tailcall]) state\n end\n\n\n(* To enqueue a token : try to advance. *)\nlet enqueue_advance state tok = pp_enqueue state tok; advance_left state\n\n\n(* To enqueue strings. *)\nlet enqueue_string_as state size s =\n enqueue_advance state { size; token = Pp_text s; length = Size.to_int size }\n\n\nlet enqueue_string state s =\n enqueue_string_as state (Size.of_int (String.length s)) s\n\n\n(* Routines for scan stack\n determine size of boxes. *)\n\n(* The scan_stack is never empty. *)\nlet initialize_scan_stack stack =\n Stack.clear stack;\n let queue_elem = { size = Size.unknown; token = Pp_text \"\"; length = 0 } in\n Stack.push { left_total = -1; queue_elem } stack\n\n(* Setting the size of boxes on scan stack:\n if ty = true then size of break is set else size of box is set;\n in each case pp_scan_stack is popped.\n\n Note:\n Pattern matching on scan stack is exhaustive, since scan_stack is never\n empty.\n Pattern matching on token in scan stack is also exhaustive,\n since scan_push is used on breaks and opening of boxes. *)\nlet set_size state ty =\n match Stack.top_opt state.pp_scan_stack with\n | None -> () (* scan_stack is never empty. *)\n | Some { left_total; queue_elem } ->\n let size = Size.to_int queue_elem.size in\n (* test if scan stack contains any data that is not obsolete. *)\n if left_total < state.pp_left_total then\n initialize_scan_stack state.pp_scan_stack\n else\n match queue_elem.token with\n | Pp_break _ | Pp_tbreak (_, _) ->\n if ty then begin\n queue_elem.size <- Size.of_int (state.pp_right_total + size);\n Stack.pop_opt state.pp_scan_stack |> ignore\n end\n | Pp_begin (_, _) ->\n if not ty then begin\n queue_elem.size <- Size.of_int (state.pp_right_total + size);\n Stack.pop_opt state.pp_scan_stack |> ignore\n end\n | Pp_text _ | Pp_stab | Pp_tbegin _ | Pp_tend | Pp_end\n | Pp_newline | Pp_if_newline | Pp_open_tag _ | Pp_close_tag ->\n () (* scan_push is only used for breaks and boxes. *)\n\n\n(* Push a token on pretty-printer scanning stack.\n If b is true set_size is called. *)\nlet scan_push state b token =\n pp_enqueue state token;\n if b then set_size state true;\n let elem = { left_total = state.pp_right_total; queue_elem = token } in\n Stack.push elem state.pp_scan_stack\n\n\n(* To open a new box :\n the user may set the depth bound pp_max_boxes\n any text nested deeper is printed as the ellipsis string. *)\nlet pp_open_box_gen state indent br_ty =\n state.pp_curr_depth <- state.pp_curr_depth + 1;\n if state.pp_curr_depth < state.pp_max_boxes then\n let size = Size.of_int (- state.pp_right_total) in\n let elem = { size; token = Pp_begin (indent, br_ty); length = 0 } in\n scan_push state false elem else\n if state.pp_curr_depth = state.pp_max_boxes\n then enqueue_string state state.pp_ellipsis\n\n\n(* The box which is always open. *)\nlet pp_open_sys_box state = pp_open_box_gen state 0 Pp_hovbox\n\n(* Close a box, setting sizes of its sub boxes. *)\nlet pp_close_box state () =\n if state.pp_curr_depth > 1 then\n begin\n if state.pp_curr_depth < state.pp_max_boxes then\n begin\n pp_enqueue state { size = Size.zero; token = Pp_end; length = 0 };\n set_size state true; set_size state false\n end;\n state.pp_curr_depth <- state.pp_curr_depth - 1;\n end\n\n\n(* Open a tag, pushing it on the tag stack. *)\nlet pp_open_stag state tag_name =\n if state.pp_print_tags then\n begin\n Stack.push tag_name state.pp_tag_stack;\n state.pp_print_open_tag tag_name\n end;\n if state.pp_mark_tags then\n let token = Pp_open_tag tag_name in\n pp_enqueue state { size = Size.zero; token; length = 0 }\n\n\n(* Close a tag, popping it from the tag stack. *)\nlet pp_close_stag state () =\n if state.pp_mark_tags then\n pp_enqueue state { size = Size.zero; token = Pp_close_tag; length = 0 };\n if state.pp_print_tags then\n match Stack.pop_opt state.pp_tag_stack with\n | None -> () (* No more tag to close. *)\n | Some tag_name ->\n state.pp_print_close_tag tag_name\n\nlet pp_open_tag state s = pp_open_stag state (String_tag s)\nlet pp_close_tag state () = pp_close_stag state ()\n\nlet pp_set_print_tags state b = state.pp_print_tags <- b\nlet pp_set_mark_tags state b = state.pp_mark_tags <- b\nlet pp_get_print_tags state () = state.pp_print_tags\nlet pp_get_mark_tags state () = state.pp_mark_tags\nlet pp_set_tags state b =\n pp_set_print_tags state b; pp_set_mark_tags state b\n\n\n(* Handling tag handling functions: get/set functions. *)\nlet pp_get_formatter_stag_functions state () = {\n mark_open_stag = state.pp_mark_open_tag;\n mark_close_stag = state.pp_mark_close_tag;\n print_open_stag = state.pp_print_open_tag;\n print_close_stag = state.pp_print_close_tag;\n}\n\n\nlet pp_set_formatter_stag_functions state {\n mark_open_stag = mot;\n mark_close_stag = mct;\n print_open_stag = pot;\n print_close_stag = pct;\n } =\n state.pp_mark_open_tag <- mot;\n state.pp_mark_close_tag <- mct;\n state.pp_print_open_tag <- pot;\n state.pp_print_close_tag <- pct\n\n\n(* Initialize pretty-printer. *)\nlet pp_rinit state =\n pp_clear_queue state;\n initialize_scan_stack state.pp_scan_stack;\n Stack.clear state.pp_format_stack;\n Stack.clear state.pp_tbox_stack;\n Stack.clear state.pp_tag_stack;\n Stack.clear state.pp_mark_stack;\n state.pp_current_indent <- 0;\n state.pp_curr_depth <- 0;\n state.pp_space_left <- state.pp_margin;\n pp_open_sys_box state\n\nlet clear_tag_stack state =\n Stack.iter (fun _ -> pp_close_tag state ()) state.pp_tag_stack\n\n\n(* Flushing pretty-printer queue. *)\nlet pp_flush_queue state b =\n clear_tag_stack state;\n while state.pp_curr_depth > 1 do\n pp_close_box state ()\n done;\n state.pp_right_total <- pp_infinity;\n advance_left state;\n if b then pp_output_newline state;\n pp_rinit state\n\n(*\n\n Procedures to format values and use boxes.\n\n*)\n\n(* To format a string. *)\nlet pp_print_as_size state size s =\n if state.pp_curr_depth < state.pp_max_boxes\n then enqueue_string_as state size s\n\n\nlet pp_print_as state isize s =\n pp_print_as_size state (Size.of_int isize) s\n\n\nlet pp_print_string state s =\n pp_print_as state (String.length s) s\n\nlet pp_print_bytes state s =\n pp_print_as state (Bytes.length s) (Bytes.to_string s)\n\n(* To format an integer. *)\nlet pp_print_int state i = pp_print_string state (Int.to_string i)\n\n(* To format a float. *)\nlet pp_print_float state f = pp_print_string state (string_of_float f)\n\n(* To format a boolean. *)\nlet pp_print_bool state b = pp_print_string state (string_of_bool b)\n\n(* To format a char. *)\nlet pp_print_char state c =\n pp_print_as state 1 (String.make 1 c)\n\n\n(* Opening boxes. *)\nlet pp_open_hbox state () = pp_open_box_gen state 0 Pp_hbox\nand pp_open_vbox state indent = pp_open_box_gen state indent Pp_vbox\n\nand pp_open_hvbox state indent = pp_open_box_gen state indent Pp_hvbox\nand pp_open_hovbox state indent = pp_open_box_gen state indent Pp_hovbox\nand pp_open_box state indent = pp_open_box_gen state indent Pp_box\n\n\n(* Printing queued text.\n\n [pp_print_flush] prints all pending items in the pretty-printer queue and\n then flushes the low level output device of the formatter to actually\n display printing material.\n\n [pp_print_newline] behaves as [pp_print_flush] after printing an additional\n new line. *)\nlet pp_print_newline state () =\n pp_flush_queue state true; state.pp_out_flush ()\nand pp_print_flush state () =\n pp_flush_queue state false; state.pp_out_flush ()\n\n\n(* To get a newline when one does not want to close the current box. *)\nlet pp_force_newline state () =\n if state.pp_curr_depth < state.pp_max_boxes then\n enqueue_advance state { size = Size.zero; token = Pp_newline; length = 0 }\n\n\n(* To format something, only in case the line has just been broken. *)\nlet pp_print_if_newline state () =\n if state.pp_curr_depth < state.pp_max_boxes then\n enqueue_advance state\n { size = Size.zero; token = Pp_if_newline; length = 0 }\n\n\n(* Generalized break hint that allows printing strings before/after\n same-line offset (width) or new-line offset *)\nlet pp_print_custom_break state ~fits ~breaks =\n let before, width, after = fits in\n if state.pp_curr_depth < state.pp_max_boxes then\n let size = Size.of_int (- state.pp_right_total) in\n let token = Pp_break { fits; breaks } in\n let length = String.length before + width + String.length after in\n let elem = { size; token; length } in\n scan_push state true elem\n\n(* Printing break hints:\n A break hint indicates where a box may be broken.\n If line is broken then offset is added to the indentation of the current\n box else (the value of) width blanks are printed. *)\nlet pp_print_break state width offset =\n pp_print_custom_break state\n ~fits:(\"\", width, \"\") ~breaks:(\"\", offset, \"\")\n\n\n(* Print a space :\n a space is a break hint that prints a single space if the break does not\n split the line;\n a cut is a break hint that prints nothing if the break does not split the\n line. *)\nlet pp_print_space state () = pp_print_break state 1 0\nand pp_print_cut state () = pp_print_break state 0 0\n\n\n(* Tabulation boxes. *)\nlet pp_open_tbox state () =\n state.pp_curr_depth <- state.pp_curr_depth + 1;\n if state.pp_curr_depth < state.pp_max_boxes then\n let size = Size.zero in\n let elem = { size; token = Pp_tbegin (Pp_tbox (ref [])); length = 0 } in\n enqueue_advance state elem\n\n\n(* Close a tabulation box. *)\nlet pp_close_tbox state () =\n if state.pp_curr_depth > 1 then\n begin\n if state.pp_curr_depth < state.pp_max_boxes then\n let elem = { size = Size.zero; token = Pp_tend; length = 0 } in\n enqueue_advance state elem;\n state.pp_curr_depth <- state.pp_curr_depth - 1\n end\n\n\n(* Print a tabulation break. *)\nlet pp_print_tbreak state width offset =\n if state.pp_curr_depth < state.pp_max_boxes then\n let size = Size.of_int (- state.pp_right_total) in\n let elem = { size; token = Pp_tbreak (width, offset); length = width } in\n scan_push state true elem\n\n\nlet pp_print_tab state () = pp_print_tbreak state 0 0\n\nlet pp_set_tab state () =\n if state.pp_curr_depth < state.pp_max_boxes then\n let elem = { size = Size.zero; token = Pp_stab; length = 0 } in\n enqueue_advance state elem\n\n\n(*\n\n Procedures to control the pretty-printers\n\n*)\n\n(* Set_max_boxes. *)\nlet pp_set_max_boxes state n = if n > 1 then state.pp_max_boxes <- n\n\n(* To know the current maximum number of boxes allowed. *)\nlet pp_get_max_boxes state () = state.pp_max_boxes\n\nlet pp_over_max_boxes state () = state.pp_curr_depth = state.pp_max_boxes\n\n(* Ellipsis. *)\nlet pp_set_ellipsis_text state s = state.pp_ellipsis <- s\nand pp_get_ellipsis_text state () = state.pp_ellipsis\n\n\n(* To set the margin of pretty-printer. *)\nlet pp_limit n =\n if n < pp_infinity then n else pred pp_infinity\n\n\n(* Internal pretty-printer functions. *)\nlet pp_set_min_space_left state n =\n if n >= 1 then\n let n = pp_limit n in\n state.pp_min_space_left <- n;\n state.pp_max_indent <- state.pp_margin - state.pp_min_space_left;\n pp_rinit state\n\n\n(* Initially, we have :\n pp_max_indent = pp_margin - pp_min_space_left, and\n pp_space_left = pp_margin. *)\nlet pp_set_max_indent state n =\n if n > 1 then\n pp_set_min_space_left state (state.pp_margin - n)\n\n\nlet pp_get_max_indent state () = state.pp_max_indent\n\nlet pp_set_margin state n =\n if n >= 1 then\n let n = pp_limit n in\n state.pp_margin <- n;\n let new_max_indent =\n (* Try to maintain max_indent to its actual value. *)\n if state.pp_max_indent <= state.pp_margin\n then state.pp_max_indent else\n (* If possible maintain pp_min_space_left to its actual value,\n if this leads to a too small max_indent, take half of the\n new margin, if it is greater than 1. *)\n Int.max (Int.max (state.pp_margin - state.pp_min_space_left)\n (state.pp_margin / 2)) 1 in\n (* Rebuild invariants. *)\n pp_set_max_indent state new_max_indent\n\n\n(** Geometry functions and types *)\ntype geometry = { max_indent:int; margin: int}\n\nlet validate_geometry {margin; max_indent} =\n if max_indent < 2 then\n Error \"max_indent < 2\"\n else if margin <= max_indent then\n Error \"margin <= max_indent\"\n else Ok ()\n\nlet check_geometry geometry =\n match validate_geometry geometry with\n | Ok () -> true\n | Error _ -> false\n\nlet pp_get_margin state () = state.pp_margin\n\nlet pp_set_full_geometry state {margin; max_indent} =\n pp_set_margin state margin;\n pp_set_max_indent state max_indent;\n ()\n\nlet pp_set_geometry state ~max_indent ~margin =\n let geometry = { max_indent; margin } in\n match validate_geometry geometry with\n | Error msg ->\n raise (Invalid_argument (\"Format.pp_set_geometry: \" ^ msg))\n | Ok () ->\n pp_set_full_geometry state geometry\n\nlet pp_safe_set_geometry state ~max_indent ~margin =\n let geometry = { max_indent; margin } in\n match validate_geometry geometry with\n | Error _msg ->\n ()\n | Ok () ->\n pp_set_full_geometry state geometry\n\nlet pp_get_geometry state () =\n { margin = pp_get_margin state (); max_indent = pp_get_max_indent state () }\n\nlet pp_update_geometry state update =\n let geometry = pp_get_geometry state () in\n pp_set_full_geometry state (update geometry)\n\n(* Setting a formatter basic output functions. *)\nlet pp_set_formatter_out_functions state {\n out_string = f;\n out_flush = g;\n out_newline = h;\n out_spaces = i;\n out_indent = j;\n } =\n state.pp_out_string <- f;\n state.pp_out_flush <- g;\n state.pp_out_newline <- h;\n state.pp_out_spaces <- i;\n state.pp_out_indent <- j\n\nlet pp_get_formatter_out_functions state () = {\n out_string = state.pp_out_string;\n out_flush = state.pp_out_flush;\n out_newline = state.pp_out_newline;\n out_spaces = state.pp_out_spaces;\n out_indent = state.pp_out_indent;\n}\n\n\n(* Setting a formatter basic string output and flush functions. *)\nlet pp_set_formatter_output_functions state f g =\n state.pp_out_string <- f; state.pp_out_flush <- g\n\nlet pp_get_formatter_output_functions state () =\n (state.pp_out_string, state.pp_out_flush)\n\n\n(* The default function to output new lines. *)\nlet display_newline state () = state.pp_out_string \"\\n\" 0 1\n\n(* The default function to output spaces. *)\nlet blank_line = String.make 80 ' '\nlet rec display_blanks state n =\n if n > 0 then\n if n <= 80 then state.pp_out_string blank_line 0 n else\n begin\n state.pp_out_string blank_line 0 80;\n display_blanks state (n - 80)\n end\n\n\n(* The default function to output indentation of new lines. *)\nlet display_indent = display_blanks\n\n(* Setting a formatter basic output functions as printing to a given\n [Pervasive.out_channel] value. *)\nlet pp_set_formatter_out_channel state oc =\n state.pp_out_string <- output_substring oc;\n state.pp_out_flush <- (fun () -> flush oc);\n state.pp_out_newline <- display_newline state;\n state.pp_out_spaces <- display_blanks state;\n state.pp_out_indent <- display_indent state\n\n(*\n\n Defining specific formatters\n\n*)\n\nlet default_pp_mark_open_tag = function\n | String_tag s -> \"<\" ^ s ^ \">\"\n | _ -> \"\"\nlet default_pp_mark_close_tag = function\n | String_tag s -> \"\"\n | _ -> \"\"\n\nlet default_pp_print_open_tag = ignore\nlet default_pp_print_close_tag = ignore\n\n(* Building a formatter given its basic output functions.\n Other fields get reasonable default values. *)\nlet pp_make_formatter f g h i j =\n (* The initial state of the formatter contains a dummy box. *)\n let pp_queue = Queue.create () in\n let sys_tok =\n { size = Size.unknown; token = Pp_begin (0, Pp_hovbox); length = 0 } in\n Queue.add sys_tok pp_queue;\n let scan_stack = Stack.create () in\n initialize_scan_stack scan_stack;\n Stack.push { left_total = 1; queue_elem = sys_tok } scan_stack;\n let pp_margin = 78\n and pp_min_space_left = 10 in\n {\n pp_scan_stack = scan_stack;\n pp_format_stack = Stack.create ();\n pp_tbox_stack = Stack.create ();\n pp_tag_stack = Stack.create ();\n pp_mark_stack = Stack.create ();\n pp_margin = pp_margin;\n pp_min_space_left = pp_min_space_left;\n pp_max_indent = pp_margin - pp_min_space_left;\n pp_space_left = pp_margin;\n pp_current_indent = 0;\n pp_is_new_line = true;\n pp_left_total = 1;\n pp_right_total = 1;\n pp_curr_depth = 1;\n pp_max_boxes = max_int;\n pp_ellipsis = \".\";\n pp_out_string = f;\n pp_out_flush = g;\n pp_out_newline = h;\n pp_out_spaces = i;\n pp_out_indent = j;\n pp_print_tags = false;\n pp_mark_tags = false;\n pp_mark_open_tag = default_pp_mark_open_tag;\n pp_mark_close_tag = default_pp_mark_close_tag;\n pp_print_open_tag = default_pp_print_open_tag;\n pp_print_close_tag = default_pp_print_close_tag;\n pp_queue = pp_queue;\n }\n\n\n(* Build a formatter out of its out functions. *)\nlet formatter_of_out_functions out_funs =\n pp_make_formatter\n out_funs.out_string\n out_funs.out_flush\n out_funs.out_newline\n out_funs.out_spaces\n out_funs.out_indent\n\n\n(* Make a formatter with default functions to output spaces,\n indentation, and new lines. *)\nlet make_formatter output flush =\n let ppf = pp_make_formatter output flush ignore ignore ignore in\n ppf.pp_out_newline <- display_newline ppf;\n ppf.pp_out_spaces <- display_blanks ppf;\n ppf.pp_out_indent <- display_indent ppf;\n ppf\n\n\n(* Make a formatter writing to a given [Pervasive.out_channel] value. *)\nlet formatter_of_out_channel oc =\n make_formatter (output_substring oc) (fun () -> flush oc)\n\n\n(* Make a formatter writing to a given [Buffer.t] value. *)\nlet formatter_of_buffer b =\n make_formatter (Buffer.add_substring b) ignore\n\n\n(* Allocating buffer for pretty-printing purposes.\n Default buffer size is pp_buffer_size or 512.\n*)\nlet pp_buffer_size = 512\nlet pp_make_buffer () = Buffer.create pp_buffer_size\n\n(* The standard (shared) buffer. *)\nlet stdbuf = pp_make_buffer ()\n\n(* Predefined formatters standard formatter to print\n to [Stdlib.stdout], [Stdlib.stderr], and {!stdbuf}. *)\nlet std_formatter = formatter_of_out_channel Stdlib.stdout\nand err_formatter = formatter_of_out_channel Stdlib.stderr\nand str_formatter = formatter_of_buffer stdbuf\n\n\n(* [flush_buffer_formatter buf ppf] flushes formatter [ppf],\n then returns the contents of buffer [buf] that is reset.\n Formatter [ppf] is supposed to print to buffer [buf], otherwise this\n function is not really useful. *)\nlet flush_buffer_formatter buf ppf =\n pp_flush_queue ppf false;\n let s = Buffer.contents buf in\n Buffer.reset buf;\n s\n\n\n(* Flush [str_formatter] and get the contents of [stdbuf]. *)\nlet flush_str_formatter () = flush_buffer_formatter stdbuf str_formatter\n\n(*\n Symbolic pretty-printing\n*)\n\n(*\n Symbolic pretty-printing is pretty-printing with no low level output.\n\n When using a symbolic formatter, all regular pretty-printing activities\n occur but output material is symbolic and stored in a buffer of output\n items. At the end of pretty-printing, flushing the output buffer allows\n post-processing of symbolic output before low level output operations.\n*)\n\ntype symbolic_output_item =\n | Output_flush\n | Output_newline\n | Output_string of string\n | Output_spaces of int\n | Output_indent of int\n\ntype symbolic_output_buffer = {\n mutable symbolic_output_contents : symbolic_output_item list;\n}\n\nlet make_symbolic_output_buffer () =\n { symbolic_output_contents = [] }\n\nlet clear_symbolic_output_buffer sob =\n sob.symbolic_output_contents <- []\n\nlet get_symbolic_output_buffer sob =\n List.rev sob.symbolic_output_contents\n\nlet flush_symbolic_output_buffer sob =\n let items = get_symbolic_output_buffer sob in\n clear_symbolic_output_buffer sob;\n items\n\nlet add_symbolic_output_item sob item =\n sob.symbolic_output_contents <- item :: sob.symbolic_output_contents\n\nlet formatter_of_symbolic_output_buffer sob =\n let symbolic_flush sob () =\n add_symbolic_output_item sob Output_flush\n and symbolic_newline sob () =\n add_symbolic_output_item sob Output_newline\n and symbolic_string sob s i n =\n add_symbolic_output_item sob (Output_string (String.sub s i n))\n and symbolic_spaces sob n =\n add_symbolic_output_item sob (Output_spaces n)\n and symbolic_indent sob n =\n add_symbolic_output_item sob (Output_indent n) in\n\n let f = symbolic_string sob\n and g = symbolic_flush sob\n and h = symbolic_newline sob\n and i = symbolic_spaces sob\n and j = symbolic_indent sob in\n pp_make_formatter f g h i j\n\n(*\n\n Basic functions on the 'standard' formatter\n (the formatter that prints to [Stdlib.stdout]).\n\n*)\n\nlet open_hbox = pp_open_hbox std_formatter\nand open_vbox = pp_open_vbox std_formatter\nand open_hvbox = pp_open_hvbox std_formatter\nand open_hovbox = pp_open_hovbox std_formatter\nand open_box = pp_open_box std_formatter\nand close_box = pp_close_box std_formatter\nand open_tag = pp_open_tag std_formatter\nand close_tag = pp_close_tag std_formatter\nand open_stag = pp_open_stag std_formatter\nand close_stag = pp_close_stag std_formatter\nand print_as = pp_print_as std_formatter\nand print_string = pp_print_string std_formatter\nand print_bytes = pp_print_bytes std_formatter\nand print_int = pp_print_int std_formatter\nand print_float = pp_print_float std_formatter\nand print_char = pp_print_char std_formatter\nand print_bool = pp_print_bool std_formatter\nand print_break = pp_print_break std_formatter\nand print_cut = pp_print_cut std_formatter\nand print_space = pp_print_space std_formatter\nand force_newline = pp_force_newline std_formatter\nand print_flush = pp_print_flush std_formatter\nand print_newline = pp_print_newline std_formatter\nand print_if_newline = pp_print_if_newline std_formatter\n\nand open_tbox = pp_open_tbox std_formatter\nand close_tbox = pp_close_tbox std_formatter\nand print_tbreak = pp_print_tbreak std_formatter\n\nand set_tab = pp_set_tab std_formatter\nand print_tab = pp_print_tab std_formatter\n\nand set_margin = pp_set_margin std_formatter\nand get_margin = pp_get_margin std_formatter\n\nand set_max_indent = pp_set_max_indent std_formatter\nand get_max_indent = pp_get_max_indent std_formatter\n\nand set_geometry = pp_set_geometry std_formatter\nand safe_set_geometry = pp_safe_set_geometry std_formatter\nand get_geometry = pp_get_geometry std_formatter\nand update_geometry = pp_update_geometry std_formatter\n\nand set_max_boxes = pp_set_max_boxes std_formatter\nand get_max_boxes = pp_get_max_boxes std_formatter\nand over_max_boxes = pp_over_max_boxes std_formatter\n\nand set_ellipsis_text = pp_set_ellipsis_text std_formatter\nand get_ellipsis_text = pp_get_ellipsis_text std_formatter\n\nand set_formatter_out_channel =\n pp_set_formatter_out_channel std_formatter\n\nand set_formatter_out_functions =\n pp_set_formatter_out_functions std_formatter\nand get_formatter_out_functions =\n pp_get_formatter_out_functions std_formatter\n\nand set_formatter_output_functions =\n pp_set_formatter_output_functions std_formatter\nand get_formatter_output_functions =\n pp_get_formatter_output_functions std_formatter\n\nand set_formatter_stag_functions =\n pp_set_formatter_stag_functions std_formatter\nand get_formatter_stag_functions =\n pp_get_formatter_stag_functions std_formatter\nand set_print_tags =\n pp_set_print_tags std_formatter\nand get_print_tags =\n pp_get_print_tags std_formatter\nand set_mark_tags =\n pp_set_mark_tags std_formatter\nand get_mark_tags =\n pp_get_mark_tags std_formatter\nand set_tags =\n pp_set_tags std_formatter\n\n\n(* Convenience functions *)\n\n(* To format a list *)\nlet rec pp_print_list ?(pp_sep = pp_print_cut) pp_v ppf = function\n | [] -> ()\n | [v] -> pp_v ppf v\n | v :: vs ->\n pp_v ppf v;\n pp_sep ppf ();\n pp_print_list ~pp_sep pp_v ppf vs\n\n(* To format a sequence *)\nlet rec pp_print_seq_in ~pp_sep pp_v ppf seq =\n match seq () with\n | Seq.Nil -> ()\n | Seq.Cons (v, seq) ->\n pp_sep ppf ();\n pp_v ppf v;\n pp_print_seq_in ~pp_sep pp_v ppf seq\n\nlet pp_print_seq ?(pp_sep = pp_print_cut) pp_v ppf seq =\n match seq () with\n | Seq.Nil -> ()\n | Seq.Cons (v, seq) ->\n pp_v ppf v;\n pp_print_seq_in ~pp_sep pp_v ppf seq\n\n(* To format free-flowing text *)\nlet pp_print_text ppf s =\n let len = String.length s in\n let left = ref 0 in\n let right = ref 0 in\n let flush () =\n pp_print_string ppf (String.sub s !left (!right - !left));\n incr right; left := !right;\n in\n while (!right <> len) do\n match s.[!right] with\n | '\\n' ->\n flush ();\n pp_force_newline ppf ()\n | ' ' ->\n flush (); pp_print_space ppf ()\n (* there is no specific support for '\\t'\n as it is unclear what a right semantics would be *)\n | _ -> incr right\n done;\n if !left <> len then flush ()\n\nlet pp_print_option ?(none = fun _ () -> ()) pp_v ppf = function\n| None -> none ppf ()\n| Some v -> pp_v ppf v\n\nlet pp_print_result ~ok ~error ppf = function\n| Ok v -> ok ppf v\n| Error e -> error ppf e\n\nlet pp_print_either ~left ~right ppf = function\n| Either.Left l -> left ppf l\n| Either.Right r -> right ppf r\n\n (**************************************************************)\n\nlet compute_tag output tag_acc =\n let buf = Buffer.create 16 in\n let ppf = formatter_of_buffer buf in\n output ppf tag_acc;\n pp_print_flush ppf ();\n let len = Buffer.length buf in\n if len < 2 then Buffer.contents buf\n else Buffer.sub buf 1 (len - 2)\n\n (**************************************************************\n\n Defining continuations to be passed as arguments of\n CamlinternalFormat.make_printf.\n\n **************************************************************)\n\nopen CamlinternalFormatBasics\nopen CamlinternalFormat\n\n(* Interpret a formatting entity on a formatter. *)\nlet output_formatting_lit ppf fmting_lit = match fmting_lit with\n | Close_box -> pp_close_box ppf ()\n | Close_tag -> pp_close_tag ppf ()\n | Break (_, width, offset) -> pp_print_break ppf width offset\n | FFlush -> pp_print_flush ppf ()\n | Force_newline -> pp_force_newline ppf ()\n | Flush_newline -> pp_print_newline ppf ()\n | Magic_size (_, _) -> ()\n | Escaped_at -> pp_print_char ppf '@'\n | Escaped_percent -> pp_print_char ppf '%'\n | Scan_indic c -> pp_print_char ppf '@'; pp_print_char ppf c\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n printing entities (string, char, flus, ...) in an output_stream. *)\n(* Differ from Printf.output_acc by the interpretation of formatting. *)\n(* Used as a continuation of CamlinternalFormat.make_printf. *)\nlet rec output_acc ppf acc = match acc with\n | Acc_string_literal (Acc_formatting_lit (p, Magic_size (_, size)), s)\n | Acc_data_string (Acc_formatting_lit (p, Magic_size (_, size)), s) ->\n output_acc ppf p;\n pp_print_as_size ppf (Size.of_int size) s;\n | Acc_char_literal (Acc_formatting_lit (p, Magic_size (_, size)), c)\n | Acc_data_char (Acc_formatting_lit (p, Magic_size (_, size)), c) ->\n output_acc ppf p;\n pp_print_as_size ppf (Size.of_int size) (String.make 1 c);\n | Acc_formatting_lit (p, f) ->\n output_acc ppf p;\n output_formatting_lit ppf f;\n | Acc_formatting_gen (p, Acc_open_tag acc') ->\n output_acc ppf p;\n pp_open_stag ppf (String_tag (compute_tag output_acc acc'))\n | Acc_formatting_gen (p, Acc_open_box acc') ->\n output_acc ppf p;\n let (indent, bty) = open_box_of_string (compute_tag output_acc acc') in\n pp_open_box_gen ppf indent bty\n | Acc_string_literal (p, s)\n | Acc_data_string (p, s) -> output_acc ppf p; pp_print_string ppf s;\n | Acc_char_literal (p, c)\n | Acc_data_char (p, c) -> output_acc ppf p; pp_print_char ppf c;\n | Acc_delay (p, f) -> output_acc ppf p; f ppf;\n | Acc_flush p -> output_acc ppf p; pp_print_flush ppf ();\n | Acc_invalid_arg (p, msg) -> output_acc ppf p; invalid_arg msg;\n | End_of_acc -> ()\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n printing entities (string, char, flus, ...) in a buffer. *)\n(* Differ from Printf.bufput_acc by the interpretation of formatting. *)\n(* Used as a continuation of CamlinternalFormat.make_printf. *)\nlet rec strput_acc ppf acc = match acc with\n | Acc_string_literal (Acc_formatting_lit (p, Magic_size (_, size)), s)\n | Acc_data_string (Acc_formatting_lit (p, Magic_size (_, size)), s) ->\n strput_acc ppf p;\n pp_print_as_size ppf (Size.of_int size) s;\n | Acc_char_literal (Acc_formatting_lit (p, Magic_size (_, size)), c)\n | Acc_data_char (Acc_formatting_lit (p, Magic_size (_, size)), c) ->\n strput_acc ppf p;\n pp_print_as_size ppf (Size.of_int size) (String.make 1 c);\n | Acc_delay (Acc_formatting_lit (p, Magic_size (_, size)), f) ->\n strput_acc ppf p;\n pp_print_as_size ppf (Size.of_int size) (f ());\n | Acc_formatting_lit (p, f) ->\n strput_acc ppf p;\n output_formatting_lit ppf f;\n | Acc_formatting_gen (p, Acc_open_tag acc') ->\n strput_acc ppf p;\n pp_open_stag ppf (String_tag (compute_tag strput_acc acc'))\n | Acc_formatting_gen (p, Acc_open_box acc') ->\n strput_acc ppf p;\n let (indent, bty) = open_box_of_string (compute_tag strput_acc acc') in\n pp_open_box_gen ppf indent bty\n | Acc_string_literal (p, s)\n | Acc_data_string (p, s) -> strput_acc ppf p; pp_print_string ppf s;\n | Acc_char_literal (p, c)\n | Acc_data_char (p, c) -> strput_acc ppf p; pp_print_char ppf c;\n | Acc_delay (p, f) -> strput_acc ppf p; pp_print_string ppf (f ());\n | Acc_flush p -> strput_acc ppf p; pp_print_flush ppf ();\n | Acc_invalid_arg (p, msg) -> strput_acc ppf p; invalid_arg msg;\n | End_of_acc -> ()\n\n(*\n\n Defining [fprintf] and various flavors of [fprintf].\n\n*)\n\nlet kfprintf k ppf (Format (fmt, _)) =\n make_printf\n (fun acc -> output_acc ppf acc; k ppf)\n End_of_acc fmt\n\nand ikfprintf k ppf (Format (fmt, _)) =\n make_iprintf k ppf fmt\n\nlet ifprintf _ppf (Format (fmt, _)) =\n make_iprintf ignore () fmt\n\nlet fprintf ppf = kfprintf ignore ppf\nlet printf fmt = fprintf std_formatter fmt\nlet eprintf fmt = fprintf err_formatter fmt\n\nlet kdprintf k (Format (fmt, _)) =\n make_printf\n (fun acc -> k (fun ppf -> output_acc ppf acc))\n End_of_acc fmt\n\nlet dprintf fmt = kdprintf (fun i -> i) fmt\n\nlet ksprintf k (Format (fmt, _)) =\n let b = pp_make_buffer () in\n let ppf = formatter_of_buffer b in\n let k acc =\n strput_acc ppf acc;\n k (flush_buffer_formatter b ppf) in\n make_printf k End_of_acc fmt\n\n\nlet sprintf fmt = ksprintf id fmt\n\nlet kasprintf k (Format (fmt, _)) =\n let b = pp_make_buffer () in\n let ppf = formatter_of_buffer b in\n let k acc =\n output_acc ppf acc;\n k (flush_buffer_formatter b ppf) in\n make_printf k End_of_acc fmt\n\n\nlet asprintf fmt = kasprintf id fmt\n\n(* Flushing standard formatters at end of execution. *)\n\nlet flush_standard_formatters () =\n pp_print_flush std_formatter ();\n pp_print_flush err_formatter ()\n\nlet () = at_exit flush_standard_formatters\n\n(*\n\n Deprecated stuff.\n\n*)\n\n(* Deprecated : subsumed by pp_set_formatter_out_functions *)\nlet pp_set_all_formatter_output_functions state\n ~out:f ~flush:g ~newline:h ~spaces:i =\n pp_set_formatter_output_functions state f g;\n state.pp_out_newline <- h;\n state.pp_out_spaces <- i\n\n(* Deprecated : subsumed by pp_get_formatter_out_functions *)\nlet pp_get_all_formatter_output_functions state () =\n (state.pp_out_string, state.pp_out_flush,\n state.pp_out_newline, state.pp_out_spaces)\n\n\n(* Deprecated : subsumed by set_formatter_out_functions *)\nlet set_all_formatter_output_functions =\n pp_set_all_formatter_output_functions std_formatter\n\n\n(* Deprecated : subsumed by get_formatter_out_functions *)\nlet get_all_formatter_output_functions =\n pp_get_all_formatter_output_functions std_formatter\n\n\n(* Deprecated : error prone function, do not use it.\n This function is neither compositional nor incremental, since it flushes\n the pretty-printer queue at each call.\n To get the same functionality, define a formatter of your own writing to\n the buffer argument, as in\n let ppf = formatter_of_buffer b\n then use {!fprintf ppf} as usual. *)\nlet bprintf b (Format (fmt, _) : ('a, formatter, unit) format) =\n let ppf = formatter_of_buffer b in\n let k acc = output_acc ppf acc; pp_flush_queue ppf false in\n make_printf k End_of_acc fmt\n\n\n(* Deprecated : alias for ksprintf. *)\nlet kprintf = ksprintf\n\n\n\n(* Deprecated tag functions *)\n\ntype formatter_tag_functions = {\n mark_open_tag : tag -> string;\n mark_close_tag : tag -> string;\n print_open_tag : tag -> unit;\n print_close_tag : tag -> unit;\n}\n\n\nlet pp_set_formatter_tag_functions state {\n mark_open_tag = mot;\n mark_close_tag = mct;\n print_open_tag = pot;\n print_close_tag = pct;\n } =\n let stringify f e = function String_tag s -> f s | _ -> e in\n state.pp_mark_open_tag <- stringify mot \"\";\n state.pp_mark_close_tag <- stringify mct \"\";\n state.pp_print_open_tag <- stringify pot ();\n state.pp_print_close_tag <- stringify pct ()\n\nlet pp_get_formatter_tag_functions fmt () =\n let funs = pp_get_formatter_stag_functions fmt () in\n let mark_open_tag s = funs.mark_open_stag (String_tag s) in\n let mark_close_tag s = funs.mark_close_stag (String_tag s) in\n let print_open_tag s = funs.print_open_stag (String_tag s) in\n let print_close_tag s = funs.print_close_stag (String_tag s) in\n {mark_open_tag; mark_close_tag; print_open_tag; print_close_tag}\n\nlet set_formatter_tag_functions =\n pp_set_formatter_tag_functions std_formatter\nand get_formatter_tag_functions =\n pp_get_formatter_tag_functions std_formatter\n","(** Very small tooling for format printers. *)\n\ninclude Format\n\ntype 'a t = Format.formatter -> 'a -> unit\n\n(* Only in the stdlib since 4.02, so we copy. *)\nlet rec list ?(pp_sep = pp_print_cut) pp ppf = function\n | [] -> ()\n | [v] -> pp ppf v\n | v :: vs ->\n pp ppf v;\n pp_sep ppf ();\n list ~pp_sep pp ppf vs\n\n(* want this name to make sure we don't use pp_print_list from stdlib\n accidentally *)\nlet pp_print_list = list\n\nlet str = pp_print_string\nlet sexp fmt s pp x = fprintf fmt \"@[<3>(%s@ %a)@]\" s pp x\nlet pair pp1 pp2 fmt (v1,v2) =\n pp1 fmt v1; pp_print_space fmt () ; pp2 fmt v2\nlet triple pp1 pp2 pp3 fmt (v1, v2, v3) =\n pp1 fmt v1; pp_print_space fmt () ;\n pp2 fmt v2; pp_print_space fmt () ;\n pp3 fmt v3\nlet int = pp_print_int\nlet optint fmt = function\n | None -> ()\n | Some i -> fprintf fmt \"@ %d\" i\n\nlet quote fmt s = Format.fprintf fmt \"\\\"%s\\\"\" s\n\nlet pp_olist pp_elem fmt =\n Format.fprintf fmt \"@[<3>[@ %a@ ]@]\"\n (pp_print_list\n ~pp_sep:(fun fmt () -> fprintf fmt \";@ \")\n pp_elem)\n\nlet pp_str_list = pp_olist quote\n\nlet to_to_string pp x =\n let b = Buffer.create 16 in\n let fmt = Format.formatter_of_buffer b in\n pp fmt x;\n Buffer.contents b\n","\nmodule Pmark = struct\n type t = int\n let equal (x : int) (y : int) = x = y\n let compare (x : int) (y : int) = compare x y\n let r = ref 0\n let gen () = incr r ; !r\n\n let pp = Format.pp_print_int\nend\n\ninclude Pmark\nmodule Set = Set.Make(Pmark)\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Pierre Weis, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2002 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nopen CamlinternalFormatBasics\nopen CamlinternalFormat\n\n(* alias to avoid warning for ambiguity between\n Stdlib.format6\n and CamlinternalFormatBasics.format6\n\n (the former is in fact an alias for the latter,\n but the ambiguity warning doesn't care)\n*)\ntype ('a, 'b, 'c, 'd, 'e, 'f) format6 =\n ('a, 'b, 'c, 'd, 'e, 'f) Stdlib.format6\n\n\n(* The run-time library for scanners. *)\n\n(* Scanning buffers. *)\nmodule type SCANNING = sig\n\n type in_channel\n\n type scanbuf = in_channel\n\n type file_name = string\n\n val stdin : in_channel\n (* The scanning buffer reading from [Stdlib.stdin].\n [stdib] is equivalent to [Scanning.from_channel Stdlib.stdin]. *)\n\n val stdib : in_channel\n (* An alias for [Scanf.stdin], the scanning buffer reading from\n [Stdlib.stdin]. *)\n\n val next_char : scanbuf -> char\n (* [Scanning.next_char ib] advance the scanning buffer for\n one character.\n If no more character can be read, sets a end of file condition and\n returns '\\000'. *)\n\n val invalidate_current_char : scanbuf -> unit\n (* [Scanning.invalidate_current_char ib] mark the current_char as already\n scanned. *)\n\n val peek_char : scanbuf -> char\n (* [Scanning.peek_char ib] returns the current char available in\n the buffer or reads one if necessary (when the current character is\n already scanned).\n If no character can be read, sets an end of file condition and\n returns '\\000'. *)\n\n val checked_peek_char : scanbuf -> char\n (* Same as [Scanning.peek_char] above but always returns a valid char or\n fails: instead of returning a null char when the reading method of the\n input buffer has reached an end of file, the function raises exception\n [End_of_file]. *)\n\n val store_char : int -> scanbuf -> char -> int\n (* [Scanning.store_char lim ib c] adds [c] to the token buffer\n of the scanning buffer [ib]. It also advances the scanning buffer for\n one character and returns [lim - 1], indicating the new limit for the\n length of the current token. *)\n\n val skip_char : int -> scanbuf -> int\n (* [Scanning.skip_char lim ib] ignores the current character. *)\n\n val ignore_char : int -> scanbuf -> int\n (* [Scanning.ignore_char ib lim] ignores the current character and\n decrements the limit. *)\n\n val token : scanbuf -> string\n (* [Scanning.token ib] returns the string stored into the token\n buffer of the scanning buffer: it returns the token matched by the\n format. *)\n\n val reset_token : scanbuf -> unit\n (* [Scanning.reset_token ib] resets the token buffer of\n the given scanning buffer. *)\n\n val char_count : scanbuf -> int\n (* [Scanning.char_count ib] returns the number of characters\n read so far from the given buffer. *)\n\n val line_count : scanbuf -> int\n (* [Scanning.line_count ib] returns the number of new line\n characters read so far from the given buffer. *)\n\n val token_count : scanbuf -> int\n (* [Scanning.token_count ib] returns the number of tokens read\n so far from [ib]. *)\n\n val eof : scanbuf -> bool\n (* [Scanning.eof ib] returns the end of input condition\n of the given buffer. *)\n\n val end_of_input : scanbuf -> bool\n (* [Scanning.end_of_input ib] tests the end of input condition\n of the given buffer (if no char has ever been read, an attempt to\n read one is performed). *)\n\n val beginning_of_input : scanbuf -> bool\n (* [Scanning.beginning_of_input ib] tests the beginning of input\n condition of the given buffer. *)\n\n val name_of_input : scanbuf -> string\n (* [Scanning.name_of_input ib] returns the name of the character\n source for input buffer [ib]. *)\n\n val open_in : file_name -> in_channel\n val open_in_bin : file_name -> in_channel\n val from_file : file_name -> in_channel\n val from_file_bin : file_name -> in_channel\n val from_string : string -> in_channel\n val from_function : (unit -> char) -> in_channel\n val from_channel : Stdlib.in_channel -> in_channel\n\n val close_in : in_channel -> unit\n\n val memo_from_channel : Stdlib.in_channel -> in_channel\n (* Obsolete. *)\n\nend\n\n\nmodule Scanning : SCANNING = struct\n\n (* The run-time library for scanf. *)\n\n type file_name = string\n\n type in_channel_name =\n | From_channel of Stdlib.in_channel\n | From_file of file_name * Stdlib.in_channel\n | From_function\n | From_string\n\n\n type in_channel = {\n mutable ic_eof : bool;\n mutable ic_current_char : char;\n mutable ic_current_char_is_valid : bool;\n mutable ic_char_count : int;\n mutable ic_line_count : int;\n mutable ic_token_count : int;\n ic_get_next_char : unit -> char;\n ic_token_buffer : Buffer.t;\n ic_input_name : in_channel_name;\n }\n\n\n type scanbuf = in_channel\n\n let null_char = '\\000'\n\n (* Reads a new character from input buffer.\n Next_char never fails, even in case of end of input:\n it then simply sets the end of file condition. *)\n let next_char ib =\n try\n let c = ib.ic_get_next_char () in\n ib.ic_current_char <- c;\n ib.ic_current_char_is_valid <- true;\n ib.ic_char_count <- succ ib.ic_char_count;\n if c = '\\n' then ib.ic_line_count <- succ ib.ic_line_count;\n c with\n | End_of_file ->\n let c = null_char in\n ib.ic_current_char <- c;\n ib.ic_current_char_is_valid <- false;\n ib.ic_eof <- true;\n c\n\n\n let peek_char ib =\n if ib.ic_current_char_is_valid\n then ib.ic_current_char\n else next_char ib\n\n\n (* Returns a valid current char for the input buffer. In particular\n no irrelevant null character (as set by [next_char] in case of end\n of input) is returned, since [End_of_file] is raised when\n [next_char] sets the end of file condition while trying to read a\n new character. *)\n let checked_peek_char ib =\n let c = peek_char ib in\n if ib.ic_eof then raise End_of_file;\n c\n\n\n let end_of_input ib =\n ignore (peek_char ib);\n ib.ic_eof\n\n\n let eof ib = ib.ic_eof\n\n let beginning_of_input ib = ib.ic_char_count = 0\n\n let name_of_input ib =\n match ib.ic_input_name with\n | From_channel _ic -> \"unnamed Stdlib input channel\"\n | From_file (fname, _ic) -> fname\n | From_function -> \"unnamed function\"\n | From_string -> \"unnamed character string\"\n\n\n let char_count ib =\n if ib.ic_current_char_is_valid\n then ib.ic_char_count - 1\n else ib.ic_char_count\n\n\n let line_count ib = ib.ic_line_count\n\n let reset_token ib = Buffer.reset ib.ic_token_buffer\n\n let invalidate_current_char ib = ib.ic_current_char_is_valid <- false\n\n let token ib =\n let token_buffer = ib.ic_token_buffer in\n let tok = Buffer.contents token_buffer in\n Buffer.clear token_buffer;\n ib.ic_token_count <- succ ib.ic_token_count;\n tok\n\n\n let token_count ib = ib.ic_token_count\n\n let skip_char width ib =\n invalidate_current_char ib;\n width\n\n\n let ignore_char width ib = skip_char (width - 1) ib\n\n let store_char width ib c =\n Buffer.add_char ib.ic_token_buffer c;\n ignore_char width ib\n\n\n let default_token_buffer_size = 1024\n\n let create iname next = {\n ic_eof = false;\n ic_current_char = null_char;\n ic_current_char_is_valid = false;\n ic_char_count = 0;\n ic_line_count = 0;\n ic_token_count = 0;\n ic_get_next_char = next;\n ic_token_buffer = Buffer.create default_token_buffer_size;\n ic_input_name = iname;\n }\n\n\n let from_string s =\n let i = ref 0 in\n let len = String.length s in\n let next () =\n if !i >= len then raise End_of_file else\n let c = s.[!i] in\n incr i;\n c in\n create From_string next\n\n\n let from_function = create From_function\n\n (* Scanning from an input channel. *)\n\n (* Position of the problem:\n\n We cannot prevent the scanning mechanism to use one lookahead character,\n if needed by the semantics of the format string specifications (e.g. a\n trailing 'skip space' specification in the format string); in this case,\n the mandatory lookahead character is indeed read from the input and not\n used to return the token read. It is thus mandatory to be able to store\n an unused lookahead character somewhere to get it as the first character\n of the next scan.\n\n To circumvent this problem, all the scanning functions get a low level\n input buffer argument where they store the lookahead character when\n needed; additionally, the input buffer is the only source of character of\n a scanner. The [scanbuf] input buffers are defined in module {!Scanning}.\n\n Now we understand that it is extremely important that related and\n successive calls to scanners indeed read from the same input buffer.\n In effect, if a scanner [scan1] is reading from [ib1] and stores an\n unused lookahead character [c1] into its input buffer [ib1], then\n another scanner [scan2] not reading from the same buffer [ib1] will miss\n the character [c1], seemingly vanished in the air from the point of view\n of [scan2].\n\n This mechanism works perfectly to read from strings, from files, and from\n functions, since in those cases, allocating two buffers reading from the\n same source is unnatural.\n\n Still, there is a difficulty in the case of scanning from an input\n channel. In effect, when scanning from an input channel [ic], this channel\n may not have been allocated from within this library. Hence, it may be\n shared (two functions of the user's program may successively read from\n [ic]). This is highly error prone since, one of the function may seek the\n input channel, while the other function has still an unused lookahead\n character in its input buffer. In conclusion, you should never mix direct\n low level reading and high level scanning from the same input channel.\n\n *)\n\n (* Perform bufferized input to improve efficiency. *)\n let file_buffer_size = ref 1024\n\n (* The scanner closes the input channel at end of input. *)\n let scan_close_at_end ic = Stdlib.close_in ic; raise End_of_file\n\n (* The scanner does not close the input channel at end of input:\n it just raises [End_of_file]. *)\n let scan_raise_at_end _ic = raise End_of_file\n\n let from_ic scan_close_ic iname ic =\n let len = !file_buffer_size in\n let buf = Bytes.create len in\n let i = ref 0 in\n let lim = ref 0 in\n let eof = ref false in\n let next () =\n if !i < !lim then begin let c = Bytes.get buf !i in incr i; c end else\n if !eof then raise End_of_file else begin\n lim := input ic buf 0 len;\n if !lim = 0 then begin eof := true; scan_close_ic ic end else begin\n i := 1;\n Bytes.get buf 0\n end\n end in\n create iname next\n\n\n let from_ic_close_at_end = from_ic scan_close_at_end\n let from_ic_raise_at_end = from_ic scan_raise_at_end\n\n (* The scanning buffer reading from [Stdlib.stdin].\n One could try to define [stdib] as a scanning buffer reading a character\n at a time (no bufferization at all), but unfortunately the top-level\n interaction would be wrong. This is due to some kind of\n 'race condition' when reading from [Stdlib.stdin],\n since the interactive compiler and [Scanf.scanf] will simultaneously\n read the material they need from [Stdlib.stdin]; then, confusion\n will result from what should be read by the top-level and what should be\n read by [Scanf.scanf].\n This is even more complicated by the one character lookahead that\n [Scanf.scanf] is sometimes obliged to maintain: the lookahead character\n will be available for the next [Scanf.scanf] entry, seemingly coming from\n nowhere.\n Also no [End_of_file] is raised when reading from stdin: if not enough\n characters have been read, we simply ask to read more. *)\n let stdin =\n from_ic scan_raise_at_end\n (From_file (\"-\", Stdlib.stdin)) Stdlib.stdin\n\n\n let stdib = stdin\n\n let open_in_file open_in fname =\n match fname with\n | \"-\" -> stdin\n | fname ->\n let ic = open_in fname in\n from_ic_close_at_end (From_file (fname, ic)) ic\n\n\n let open_in = open_in_file Stdlib.open_in\n let open_in_bin = open_in_file Stdlib.open_in_bin\n\n let from_file = open_in\n let from_file_bin = open_in_bin\n\n let from_channel ic =\n from_ic_raise_at_end (From_channel ic) ic\n\n\n let close_in ib =\n match ib.ic_input_name with\n | From_channel ic ->\n Stdlib.close_in ic\n | From_file (_fname, ic) -> Stdlib.close_in ic\n | From_function | From_string -> ()\n\n\n (*\n Obsolete: a memo [from_channel] version to build a [Scanning.in_channel]\n scanning buffer out of a [Stdlib.in_channel].\n This function was used to try to preserve the scanning\n semantics for the (now obsolete) function [fscanf].\n Given that all scanner must read from a [Scanning.in_channel] scanning\n buffer, [fscanf] must read from one!\n More precisely, given [ic], all successive calls [fscanf ic] must read\n from the same scanning buffer.\n This obliged this library to allocated scanning buffers that were\n not properly garbage collectable, hence leading to memory leaks.\n If you need to read from a [Stdlib.in_channel] input channel\n [ic], simply define a [Scanning.in_channel] formatted input channel as in\n [let ib = Scanning.from_channel ic], then use [Scanf.bscanf ib] as usual.\n *)\n let memo_from_ic =\n let memo = ref [] in\n (fun scan_close_ic ic ->\n try List.assq ic !memo with\n | Not_found ->\n let ib =\n from_ic scan_close_ic (From_channel ic) ic in\n memo := (ic, ib) :: !memo;\n ib)\n\n\n (* Obsolete: see {!memo_from_ic} above. *)\n let memo_from_channel = memo_from_ic scan_raise_at_end\n\nend\n\n\n(* Formatted input functions. *)\n\ntype ('a, 'b, 'c, 'd) scanner =\n ('a, Scanning.in_channel, 'b, 'c, 'a -> 'd, 'd) format6 -> 'c\n\n\n(* Reporting errors. *)\nexception Scan_failure of string\n\nlet bad_input s = raise (Scan_failure s)\n\nlet bad_input_escape c =\n bad_input (Printf.sprintf \"illegal escape character %C\" c)\n\n\nlet bad_token_length message =\n bad_input\n (Printf.sprintf\n \"scanning of %s failed: \\\n the specified length was too short for token\"\n message)\n\n\nlet bad_end_of_input message =\n bad_input\n (Printf.sprintf\n \"scanning of %s failed: \\\n premature end of file occurred before end of token\"\n message)\n\n\nlet bad_float () =\n bad_input \"no dot or exponent part found in float token\"\n\n\nlet bad_hex_float () =\n bad_input \"not a valid float in hexadecimal notation\"\n\n\nlet character_mismatch_err c ci =\n Printf.sprintf \"looking for %C, found %C\" c ci\n\n\nlet character_mismatch c ci =\n bad_input (character_mismatch_err c ci)\n\n\nlet rec skip_whites ib =\n let c = Scanning.peek_char ib in\n if not (Scanning.eof ib) then begin\n match c with\n | ' ' | '\\t' | '\\n' | '\\r' ->\n Scanning.invalidate_current_char ib; skip_whites ib\n | _ -> ()\n end\n\n\n(* Checking that [c] is indeed in the input, then skips it.\n In this case, the character [c] has been explicitly specified in the\n format as being mandatory in the input; hence we should fail with\n [End_of_file] in case of end_of_input.\n (Remember that [Scan_failure] is raised only when (we can prove by\n evidence) that the input does not match the format string given. We must\n thus differentiate [End_of_file] as an error due to lack of input, and\n [Scan_failure] which is due to provably wrong input. I am not sure this is\n worth the burden: it is complex and somehow subliminal; should be clearer\n to fail with Scan_failure \"Not enough input to complete scanning\"!)\n\n That's why, waiting for a better solution, we use checked_peek_char here.\n We are also careful to treat \"\\r\\n\" in the input as an end of line marker:\n it always matches a '\\n' specification in the input format string. *)\nlet rec check_char ib c =\n match c with\n | ' ' -> skip_whites ib\n | '\\n' -> check_newline ib\n | c -> check_this_char ib c\n\nand check_this_char ib c =\n let ci = Scanning.checked_peek_char ib in\n if ci = c then Scanning.invalidate_current_char ib else\n character_mismatch c ci\n\nand check_newline ib =\n let ci = Scanning.checked_peek_char ib in\n match ci with\n | '\\n' -> Scanning.invalidate_current_char ib\n | '\\r' -> Scanning.invalidate_current_char ib; check_this_char ib '\\n'\n | _ -> character_mismatch '\\n' ci\n\n\n(* Extracting tokens from the output token buffer. *)\n\nlet token_char ib = (Scanning.token ib).[0]\n\nlet token_string = Scanning.token\n\nlet token_bool ib =\n match Scanning.token ib with\n | \"true\" -> true\n | \"false\" -> false\n | s -> bad_input (Printf.sprintf \"invalid boolean '%s'\" s)\n\n\n(* The type of integer conversions. *)\ntype integer_conversion =\n | B_conversion (* Unsigned binary conversion *)\n | D_conversion (* Signed decimal conversion *)\n | I_conversion (* Signed integer conversion *)\n | O_conversion (* Unsigned octal conversion *)\n | U_conversion (* Unsigned decimal conversion *)\n | X_conversion (* Unsigned hexadecimal conversion *)\n\n\nlet integer_conversion_of_char = function\n | 'b' -> B_conversion\n | 'd' -> D_conversion\n | 'i' -> I_conversion\n | 'o' -> O_conversion\n | 'u' -> U_conversion\n | 'x' | 'X' -> X_conversion\n | _ -> assert false\n\n\n(* Extract an integer literal token.\n Since the functions Stdlib.*int*_of_string do not accept a leading +,\n we skip it if necessary. *)\nlet token_int_literal conv ib =\n let tok =\n match conv with\n | D_conversion | I_conversion -> Scanning.token ib\n | U_conversion -> \"0u\" ^ Scanning.token ib\n | O_conversion -> \"0o\" ^ Scanning.token ib\n | X_conversion -> \"0x\" ^ Scanning.token ib\n | B_conversion -> \"0b\" ^ Scanning.token ib in\n let l = String.length tok in\n if l = 0 || tok.[0] <> '+' then tok else String.sub tok 1 (l - 1)\n\n\n(* All the functions that convert a string to a number raise the exception\n Failure when the conversion is not possible.\n This exception is then trapped in [kscanf]. *)\nlet token_int conv ib = int_of_string (token_int_literal conv ib)\n\nlet token_float ib = float_of_string (Scanning.token ib)\n\n(* To scan native ints, int32 and int64 integers.\n We cannot access to conversions to/from strings for those types,\n Nativeint.of_string, Int32.of_string, and Int64.of_string,\n since those modules are not available to [Scanf].\n However, we can bind and use the corresponding primitives that are\n available in the runtime. *)\nexternal nativeint_of_string : string -> nativeint\n = \"caml_nativeint_of_string\"\n\nexternal int32_of_string : string -> int32\n = \"caml_int32_of_string\"\n\nexternal int64_of_string : string -> int64\n = \"caml_int64_of_string\"\n\n\nlet token_nativeint conv ib = nativeint_of_string (token_int_literal conv ib)\nlet token_int32 conv ib = int32_of_string (token_int_literal conv ib)\nlet token_int64 conv ib = int64_of_string (token_int_literal conv ib)\n\n(* Scanning numbers. *)\n\n(* Digits scanning functions suppose that one character has been checked and\n is available, since they return at end of file with the currently found\n token selected.\n\n Put it in another way, the digits scanning functions scan for a possibly\n empty sequence of digits, (hence, a successful scanning from one of those\n functions does not imply that the token is a well-formed number: to get a\n true number, it is mandatory to check that at least one valid digit is\n available before calling one of the digit scanning functions). *)\n\n(* The decimal case is treated especially for optimization purposes. *)\nlet rec scan_decimal_digit_star width ib =\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n match c with\n | '0' .. '9' as c ->\n let width = Scanning.store_char width ib c in\n scan_decimal_digit_star width ib\n | '_' ->\n let width = Scanning.ignore_char width ib in\n scan_decimal_digit_star width ib\n | _ -> width\n\n\nlet scan_decimal_digit_plus width ib =\n if width = 0 then bad_token_length \"decimal digits\" else\n let c = Scanning.checked_peek_char ib in\n match c with\n | '0' .. '9' ->\n let width = Scanning.store_char width ib c in\n scan_decimal_digit_star width ib\n | c ->\n bad_input (Printf.sprintf \"character %C is not a decimal digit\" c)\n\n\n(* To scan numbers from other bases, we use a predicate argument to\n scan digits. *)\nlet scan_digit_star digitp width ib =\n let rec scan_digits width ib =\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n match c with\n | c when digitp c ->\n let width = Scanning.store_char width ib c in\n scan_digits width ib\n | '_' ->\n let width = Scanning.ignore_char width ib in\n scan_digits width ib\n | _ -> width in\n scan_digits width ib\n\n\nlet scan_digit_plus basis digitp width ib =\n (* Ensure we have got enough width left,\n and read at least one digit. *)\n if width = 0 then bad_token_length \"digits\" else\n let c = Scanning.checked_peek_char ib in\n if digitp c then\n let width = Scanning.store_char width ib c in\n scan_digit_star digitp width ib\n else\n bad_input (Printf.sprintf \"character %C is not a valid %s digit\" c basis)\n\n\nlet is_binary_digit = function\n | '0' .. '1' -> true\n | _ -> false\n\n\nlet scan_binary_int = scan_digit_plus \"binary\" is_binary_digit\n\nlet is_octal_digit = function\n | '0' .. '7' -> true\n | _ -> false\n\n\nlet scan_octal_int = scan_digit_plus \"octal\" is_octal_digit\n\nlet is_hexa_digit = function\n | '0' .. '9' | 'a' .. 'f' | 'A' .. 'F' -> true\n | _ -> false\n\n\nlet scan_hexadecimal_int = scan_digit_plus \"hexadecimal\" is_hexa_digit\n\n(* Scan a decimal integer. *)\nlet scan_unsigned_decimal_int = scan_decimal_digit_plus\n\nlet scan_sign width ib =\n let c = Scanning.checked_peek_char ib in\n match c with\n | '+' -> Scanning.store_char width ib c\n | '-' -> Scanning.store_char width ib c\n | _ -> width\n\n\nlet scan_optionally_signed_decimal_int width ib =\n let width = scan_sign width ib in\n scan_unsigned_decimal_int width ib\n\n\n(* Scan an unsigned integer that could be given in any (common) basis.\n If digits are prefixed by one of 0x, 0X, 0o, or 0b, the number is\n assumed to be written respectively in hexadecimal, hexadecimal,\n octal, or binary. *)\nlet scan_unsigned_int width ib =\n match Scanning.checked_peek_char ib with\n | '0' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n begin match c with\n | 'x' | 'X' -> scan_hexadecimal_int (Scanning.store_char width ib c) ib\n | 'o' -> scan_octal_int (Scanning.store_char width ib c) ib\n | 'b' -> scan_binary_int (Scanning.store_char width ib c) ib\n | _ -> scan_decimal_digit_star width ib end\n | _ -> scan_unsigned_decimal_int width ib\n\n\nlet scan_optionally_signed_int width ib =\n let width = scan_sign width ib in\n scan_unsigned_int width ib\n\n\nlet scan_int_conversion conv width ib =\n match conv with\n | B_conversion -> scan_binary_int width ib\n | D_conversion -> scan_optionally_signed_decimal_int width ib\n | I_conversion -> scan_optionally_signed_int width ib\n | O_conversion -> scan_octal_int width ib\n | U_conversion -> scan_unsigned_decimal_int width ib\n | X_conversion -> scan_hexadecimal_int width ib\n\n\n(* Scanning floating point numbers. *)\n\n(* Fractional part is optional and can be reduced to 0 digits. *)\nlet scan_fractional_part width ib =\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n match c with\n | '0' .. '9' as c ->\n scan_decimal_digit_star (Scanning.store_char width ib c) ib\n | _ -> width\n\n\n(* Exp part is optional and can be reduced to 0 digits. *)\nlet scan_exponent_part width ib =\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n match c with\n | 'e' | 'E' as c ->\n scan_optionally_signed_decimal_int (Scanning.store_char width ib c) ib\n | _ -> width\n\n\n(* Scan the integer part of a floating point number, (not using the\n OCaml lexical convention since the integer part can be empty):\n an optional sign, followed by a possibly empty sequence of decimal\n digits (e.g. -.1). *)\nlet scan_integer_part width ib =\n let width = scan_sign width ib in\n scan_decimal_digit_star width ib\n\n\n(*\n For the time being we have (as found in scanf.mli):\n the field width is composed of an optional integer literal\n indicating the maximal width of the token to read.\n Unfortunately, the type-checker let the user write an optional precision,\n since this is valid for printf format strings.\n\n Thus, the next step for Scanf is to support a full width and precision\n indication, more or less similar to the one for printf, possibly extended\n to the specification of a [max, min] range for the width of the token read\n for strings. Something like the following spec for scanf.mli:\n\n The optional [width] is an integer indicating the maximal\n width of the token read. For instance, [%6d] reads an integer,\n having at most 6 characters.\n\n The optional [precision] is a dot [.] followed by an integer:\n\n - in the floating point number conversions ([%f], [%e], [%g], [%F], [%E],\n and [%F] conversions, the [precision] indicates the maximum number of\n digits that may follow the decimal point. For instance, [%.4f] reads a\n [float] with at most 4 fractional digits,\n\n - in the string conversions ([%s], [%S], [%\\[ range \\]]), and in the\n integer number conversions ([%i], [%d], [%u], [%x], [%o], and their\n [int32], [int64], and [native_int] correspondent), the [precision]\n indicates the required minimum width of the token read,\n\n - on all other conversions, the width and precision specify the [max, min]\n range for the width of the token read.\n*)\nlet scan_float width precision ib =\n let width = scan_integer_part width ib in\n if width = 0 then width, precision else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width, precision else\n match c with\n | '.' ->\n let width = Scanning.store_char width ib c in\n let precision = Int.min width precision in\n let width = width - (precision - scan_fractional_part precision ib) in\n scan_exponent_part width ib, precision\n | _ ->\n scan_exponent_part width ib, precision\n\n\nlet check_case_insensitive_string width ib error str =\n let lowercase c =\n match c with\n | 'A' .. 'Z' ->\n char_of_int (int_of_char c - int_of_char 'A' + int_of_char 'a')\n | _ -> c in\n let len = String.length str in\n let width = ref width in\n for i = 0 to len - 1 do\n let c = Scanning.peek_char ib in\n if lowercase c <> lowercase str.[i] then error ();\n if !width = 0 then error ();\n width := Scanning.store_char !width ib c;\n done;\n !width\n\n\nlet scan_hex_float width precision ib =\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n let width = scan_sign width ib in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n match Scanning.peek_char ib with\n | '0' as c -> (\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n let width = check_case_insensitive_string width ib bad_hex_float \"x\" in\n if width = 0 || Scanning.end_of_input ib then width else\n let width = match Scanning.peek_char ib with\n | '.' | 'p' | 'P' -> width\n | _ -> scan_hexadecimal_int width ib in\n if width = 0 || Scanning.end_of_input ib then width else\n let width = match Scanning.peek_char ib with\n | '.' as c -> (\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then width else\n match Scanning.peek_char ib with\n | 'p' | 'P' -> width\n | _ ->\n let precision = Int.min width precision in\n width - (precision - scan_hexadecimal_int precision ib)\n )\n | _ -> width in\n if width = 0 || Scanning.end_of_input ib then width else\n match Scanning.peek_char ib with\n | 'p' | 'P' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n scan_optionally_signed_decimal_int width ib\n | _ -> width\n )\n | 'n' | 'N' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n check_case_insensitive_string width ib bad_hex_float \"an\"\n | 'i' | 'I' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n check_case_insensitive_string width ib bad_hex_float \"nfinity\"\n | _ -> bad_hex_float ()\n\n\nlet scan_caml_float_rest width precision ib =\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n let width = scan_decimal_digit_star width ib in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n let c = Scanning.peek_char ib in\n match c with\n | '.' ->\n let width = Scanning.store_char width ib c in\n (* The effective width available for scanning the fractional part is\n the minimum of declared precision and width left. *)\n let precision = Int.min width precision in\n (* After scanning the fractional part with [precision] provisional width,\n [width_precision] is left. *)\n let width_precision = scan_fractional_part precision ib in\n (* Hence, scanning the fractional part took exactly\n [precision - width_precision] chars. *)\n let frac_width = precision - width_precision in\n (* And new provisional width is [width - width_precision. *)\n let width = width - frac_width in\n scan_exponent_part width ib\n | 'e' | 'E' ->\n scan_exponent_part width ib\n | _ -> bad_float ()\n\n\nlet scan_caml_float width precision ib =\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n let width = scan_sign width ib in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n match Scanning.peek_char ib with\n | '0' as c -> (\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n match Scanning.peek_char ib with\n | 'x' | 'X' as c -> (\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n let width = scan_hexadecimal_int width ib in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n let width = match Scanning.peek_char ib with\n | '.' as c -> (\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then width else\n match Scanning.peek_char ib with\n | 'p' | 'P' -> width\n | _ ->\n let precision = Int.min width precision in\n width - (precision - scan_hexadecimal_int precision ib)\n )\n | 'p' | 'P' -> width\n | _ -> bad_float () in\n if width = 0 || Scanning.end_of_input ib then width else\n match Scanning.peek_char ib with\n | 'p' | 'P' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n scan_optionally_signed_decimal_int width ib\n | _ -> width\n )\n | _ ->\n scan_caml_float_rest width precision ib\n )\n | '1' .. '9' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n scan_caml_float_rest width precision ib\n(* Special case of nan and infinity:\n | 'i' ->\n | 'n' ->\n*)\n | _ -> bad_float ()\n\n\n(* Scan a regular string:\n stops when encountering a space, if no scanning indication has been given;\n otherwise, stops when encountering the characters in the scanning\n indication [stp].\n It also stops at end of file or when the maximum number of characters has\n been read. *)\nlet scan_string stp width ib =\n let rec loop width =\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n match stp with\n | Some c' when c = c' -> Scanning.skip_char width ib\n | Some _ -> loop (Scanning.store_char width ib c)\n | None ->\n match c with\n | ' ' | '\\t' | '\\n' | '\\r' -> width\n | _ -> loop (Scanning.store_char width ib c) in\n loop width\n\n\n(* Scan a char: peek strictly one character in the input, whatsoever. *)\nlet scan_char width ib =\n (* The case width = 0 could not happen here, since it is tested before\n calling scan_char, in the main scanning function.\n if width = 0 then bad_token_length \"a character\" else *)\n Scanning.store_char width ib (Scanning.checked_peek_char ib)\n\n\nlet char_for_backslash = function\n | 'n' -> '\\010'\n | 'r' -> '\\013'\n | 'b' -> '\\008'\n | 't' -> '\\009'\n | c -> c\n\n\n(* The integer value corresponding to the facial value of a valid\n decimal digit character. *)\nlet decimal_value_of_char c = int_of_char c - int_of_char '0'\n\nlet char_for_decimal_code c0 c1 c2 =\n let c =\n 100 * decimal_value_of_char c0 +\n 10 * decimal_value_of_char c1 +\n decimal_value_of_char c2 in\n if c < 0 || c > 255 then\n bad_input\n (Printf.sprintf\n \"bad character decimal encoding \\\\%c%c%c\" c0 c1 c2) else\n char_of_int c\n\n\n(* The integer value corresponding to the facial value of a valid\n hexadecimal digit character. *)\nlet hexadecimal_value_of_char c =\n let d = int_of_char c in\n (* Could also be:\n if d <= int_of_char '9' then d - int_of_char '0' else\n if d <= int_of_char 'F' then 10 + d - int_of_char 'A' else\n if d <= int_of_char 'f' then 10 + d - int_of_char 'a' else assert false\n *)\n if d >= int_of_char 'a' then\n d - 87 (* 10 + int_of_char c - int_of_char 'a' *) else\n if d >= int_of_char 'A' then\n d - 55 (* 10 + int_of_char c - int_of_char 'A' *) else\n d - int_of_char '0'\n\n\nlet char_for_hexadecimal_code c1 c2 =\n let c =\n 16 * hexadecimal_value_of_char c1 +\n hexadecimal_value_of_char c2 in\n if c < 0 || c > 255 then\n bad_input\n (Printf.sprintf \"bad character hexadecimal encoding \\\\%c%c\" c1 c2) else\n char_of_int c\n\n\n(* Called in particular when encountering '\\\\' as starter of a char.\n Stops before the corresponding '\\''. *)\nlet check_next_char message width ib =\n if width = 0 then bad_token_length message else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then bad_end_of_input message else\n c\n\n\nlet check_next_char_for_char = check_next_char \"a Char\"\nlet check_next_char_for_string = check_next_char \"a String\"\n\nlet scan_backslash_char width ib =\n match check_next_char_for_char width ib with\n | '\\\\' | '\\'' | '\\\"' | 'n' | 't' | 'b' | 'r' as c ->\n Scanning.store_char width ib (char_for_backslash c)\n | '0' .. '9' as c ->\n let get_digit () =\n let c = Scanning.next_char ib in\n match c with\n | '0' .. '9' as c -> c\n | c -> bad_input_escape c in\n let c0 = c in\n let c1 = get_digit () in\n let c2 = get_digit () in\n Scanning.store_char (width - 2) ib (char_for_decimal_code c0 c1 c2)\n | 'x' ->\n let get_digit () =\n let c = Scanning.next_char ib in\n match c with\n | '0' .. '9' | 'A' .. 'F' | 'a' .. 'f' as c -> c\n | c -> bad_input_escape c in\n let c1 = get_digit () in\n let c2 = get_digit () in\n Scanning.store_char (width - 2) ib (char_for_hexadecimal_code c1 c2)\n | c ->\n bad_input_escape c\n\n\n(* Scan a character (an OCaml token). *)\nlet scan_caml_char width ib =\n\n let rec find_start width =\n match Scanning.checked_peek_char ib with\n | '\\'' -> find_char (Scanning.ignore_char width ib)\n | c -> character_mismatch '\\'' c\n\n and find_char width =\n match check_next_char_for_char width ib with\n | '\\\\' ->\n find_stop (scan_backslash_char (Scanning.ignore_char width ib) ib)\n | c ->\n find_stop (Scanning.store_char width ib c)\n\n and find_stop width =\n match check_next_char_for_char width ib with\n | '\\'' -> Scanning.ignore_char width ib\n | c -> character_mismatch '\\'' c in\n\n find_start width\n\n\n(* Scan a delimited string (an OCaml token). *)\nlet scan_caml_string width ib =\n\n let rec find_start width =\n match Scanning.checked_peek_char ib with\n | '\\\"' -> find_stop (Scanning.ignore_char width ib)\n | c -> character_mismatch '\\\"' c\n\n and find_stop width =\n match check_next_char_for_string width ib with\n | '\\\"' -> Scanning.ignore_char width ib\n | '\\\\' -> scan_backslash (Scanning.ignore_char width ib)\n | c -> find_stop (Scanning.store_char width ib c)\n\n and scan_backslash width =\n match check_next_char_for_string width ib with\n | '\\r' -> skip_newline (Scanning.ignore_char width ib)\n | '\\n' -> skip_spaces (Scanning.ignore_char width ib)\n | _ -> find_stop (scan_backslash_char width ib)\n\n and skip_newline width =\n match check_next_char_for_string width ib with\n | '\\n' -> skip_spaces (Scanning.ignore_char width ib)\n | _ -> find_stop (Scanning.store_char width ib '\\r')\n\n and skip_spaces width =\n match check_next_char_for_string width ib with\n | ' ' -> skip_spaces (Scanning.ignore_char width ib)\n | _ -> find_stop width in\n\n find_start width\n\n\n(* Scan a boolean (an OCaml token). *)\nlet scan_bool ib =\n let c = Scanning.checked_peek_char ib in\n let m =\n match c with\n | 't' -> 4\n | 'f' -> 5\n | c ->\n bad_input\n (Printf.sprintf \"the character %C cannot start a boolean\" c) in\n scan_string None m ib\n\n\n(* Scan a string containing elements in char_set and terminated by scan_indic\n if provided. *)\nlet scan_chars_in_char_set char_set scan_indic width ib =\n let rec scan_chars i stp =\n let c = Scanning.peek_char ib in\n if i > 0 && not (Scanning.eof ib) &&\n is_in_char_set char_set c &&\n int_of_char c <> stp then\n let _ = Scanning.store_char max_int ib c in\n scan_chars (i - 1) stp in\n match scan_indic with\n | None -> scan_chars width (-1);\n | Some c ->\n scan_chars width (int_of_char c);\n if not (Scanning.eof ib) then\n let ci = Scanning.peek_char ib in\n if c = ci\n then Scanning.invalidate_current_char ib\n else character_mismatch c ci\n\n\n(* The global error report function for [Scanf]. *)\nlet scanf_bad_input ib = function\n | Scan_failure s | Failure s ->\n let i = Scanning.char_count ib in\n bad_input (Printf.sprintf \"scanf: bad input at char number %i: %s\" i s)\n | x -> raise x\n\n\n(* Get the content of a counter from an input buffer. *)\nlet get_counter ib counter =\n match counter with\n | Line_counter -> Scanning.line_count ib\n | Char_counter -> Scanning.char_count ib\n | Token_counter -> Scanning.token_count ib\n\n\n(* Compute the width of a padding option (see \"%42{\" and \"%123(\"). *)\nlet width_of_pad_opt pad_opt = match pad_opt with\n | None -> max_int\n | Some width -> width\n\n\nlet stopper_of_formatting_lit fmting =\n if fmting = Escaped_percent then '%', \"\" else\n let str = string_of_formatting_lit fmting in\n let stp = str.[1] in\n let sub_str = String.sub str 2 (String.length str - 2) in\n stp, sub_str\n\n\n(******************************************************************************)\n (* Reader management *)\n\n(* A call to take_format_readers on a format is evaluated into functions\n taking readers as arguments and aggregate them into an heterogeneous list *)\n(* When all readers are taken, finally pass the list of the readers to the\n continuation k. *)\nlet rec take_format_readers : type a c d e f .\n ((d, e) heter_list -> e) -> (a, Scanning.in_channel, c, d, e, f) fmt ->\n d =\nfun k fmt -> match fmt with\n | Reader fmt_rest ->\n fun reader ->\n let new_k readers_rest = k (Cons (reader, readers_rest)) in\n take_format_readers new_k fmt_rest\n | Char rest -> take_format_readers k rest\n | Caml_char rest -> take_format_readers k rest\n | String (_, rest) -> take_format_readers k rest\n | Caml_string (_, rest) -> take_format_readers k rest\n | Int (_, _, _, rest) -> take_format_readers k rest\n | Int32 (_, _, _, rest) -> take_format_readers k rest\n | Nativeint (_, _, _, rest) -> take_format_readers k rest\n | Int64 (_, _, _, rest) -> take_format_readers k rest\n | Float (_, _, _, rest) -> take_format_readers k rest\n | Bool (_, rest) -> take_format_readers k rest\n | Alpha rest -> take_format_readers k rest\n | Theta rest -> take_format_readers k rest\n | Flush rest -> take_format_readers k rest\n | String_literal (_, rest) -> take_format_readers k rest\n | Char_literal (_, rest) -> take_format_readers k rest\n | Custom (_, _, rest) -> take_format_readers k rest\n\n | Scan_char_set (_, _, rest) -> take_format_readers k rest\n | Scan_get_counter (_, rest) -> take_format_readers k rest\n | Scan_next_char rest -> take_format_readers k rest\n\n | Formatting_lit (_, rest) -> take_format_readers k rest\n | Formatting_gen (Open_tag (Format (fmt, _)), rest) ->\n take_format_readers k (concat_fmt fmt rest)\n | Formatting_gen (Open_box (Format (fmt, _)), rest) ->\n take_format_readers k (concat_fmt fmt rest)\n\n | Format_arg (_, _, rest) -> take_format_readers k rest\n | Format_subst (_, fmtty, rest) ->\n take_fmtty_format_readers k (erase_rel (symm fmtty)) rest\n | Ignored_param (ign, rest) -> take_ignored_format_readers k ign rest\n\n | End_of_format -> k Nil\n\n(* Take readers associated to an fmtty coming from a Format_subst \"%(...%)\". *)\nand take_fmtty_format_readers : type x y a c d e f .\n ((d, e) heter_list -> e) -> (a, Scanning.in_channel, c, d, x, y) fmtty ->\n (y, Scanning.in_channel, c, x, e, f) fmt -> d =\nfun k fmtty fmt -> match fmtty with\n | Reader_ty fmt_rest ->\n fun reader ->\n let new_k readers_rest = k (Cons (reader, readers_rest)) in\n take_fmtty_format_readers new_k fmt_rest fmt\n | Ignored_reader_ty fmt_rest ->\n fun reader ->\n let new_k readers_rest = k (Cons (reader, readers_rest)) in\n take_fmtty_format_readers new_k fmt_rest fmt\n | Char_ty rest -> take_fmtty_format_readers k rest fmt\n | String_ty rest -> take_fmtty_format_readers k rest fmt\n | Int_ty rest -> take_fmtty_format_readers k rest fmt\n | Int32_ty rest -> take_fmtty_format_readers k rest fmt\n | Nativeint_ty rest -> take_fmtty_format_readers k rest fmt\n | Int64_ty rest -> take_fmtty_format_readers k rest fmt\n | Float_ty rest -> take_fmtty_format_readers k rest fmt\n | Bool_ty rest -> take_fmtty_format_readers k rest fmt\n | Alpha_ty rest -> take_fmtty_format_readers k rest fmt\n | Theta_ty rest -> take_fmtty_format_readers k rest fmt\n | Any_ty rest -> take_fmtty_format_readers k rest fmt\n | Format_arg_ty (_, rest) -> take_fmtty_format_readers k rest fmt\n | End_of_fmtty -> take_format_readers k fmt\n | Format_subst_ty (ty1, ty2, rest) ->\n let ty = trans (symm ty1) ty2 in\n take_fmtty_format_readers k (concat_fmtty ty rest) fmt\n\n(* Take readers associated to an ignored parameter. *)\nand take_ignored_format_readers : type x y a c d e f .\n ((d, e) heter_list -> e) -> (a, Scanning.in_channel, c, d, x, y) ignored ->\n (y, Scanning.in_channel, c, x, e, f) fmt -> d =\nfun k ign fmt -> match ign with\n | Ignored_reader ->\n fun reader ->\n let new_k readers_rest = k (Cons (reader, readers_rest)) in\n take_format_readers new_k fmt\n | Ignored_char -> take_format_readers k fmt\n | Ignored_caml_char -> take_format_readers k fmt\n | Ignored_string _ -> take_format_readers k fmt\n | Ignored_caml_string _ -> take_format_readers k fmt\n | Ignored_int (_, _) -> take_format_readers k fmt\n | Ignored_int32 (_, _) -> take_format_readers k fmt\n | Ignored_nativeint (_, _) -> take_format_readers k fmt\n | Ignored_int64 (_, _) -> take_format_readers k fmt\n | Ignored_float (_, _) -> take_format_readers k fmt\n | Ignored_bool _ -> take_format_readers k fmt\n | Ignored_format_arg _ -> take_format_readers k fmt\n | Ignored_format_subst (_, fmtty) -> take_fmtty_format_readers k fmtty fmt\n | Ignored_scan_char_set _ -> take_format_readers k fmt\n | Ignored_scan_get_counter _ -> take_format_readers k fmt\n | Ignored_scan_next_char -> take_format_readers k fmt\n\n(******************************************************************************)\n (* Generic scanning *)\n\n(* Make a generic scanning function. *)\n(* Scan a stream according to a format and readers obtained by\n take_format_readers, and aggregate scanned values into an\n heterogeneous list. *)\n(* Return the heterogeneous list of scanned values. *)\nlet rec make_scanf : type a c d e f.\n Scanning.in_channel -> (a, Scanning.in_channel, c, d, e, f) fmt ->\n (d, e) heter_list -> (a, f) heter_list =\nfun ib fmt readers -> match fmt with\n | Char rest ->\n let _ = scan_char 0 ib in\n let c = token_char ib in\n Cons (c, make_scanf ib rest readers)\n | Caml_char rest ->\n let _ = scan_caml_char 0 ib in\n let c = token_char ib in\n Cons (c, make_scanf ib rest readers)\n\n | String (pad, Formatting_lit (fmting_lit, rest)) ->\n let stp, str = stopper_of_formatting_lit fmting_lit in\n let scan width _ ib = scan_string (Some stp) width ib in\n let str_rest = String_literal (str, rest) in\n pad_prec_scanf ib str_rest readers pad No_precision scan token_string\n | String (pad, Formatting_gen (Open_tag (Format (fmt', _)), rest)) ->\n let scan width _ ib = scan_string (Some '{') width ib in\n pad_prec_scanf ib (concat_fmt fmt' rest) readers pad No_precision scan\n token_string\n | String (pad, Formatting_gen (Open_box (Format (fmt', _)), rest)) ->\n let scan width _ ib = scan_string (Some '[') width ib in\n pad_prec_scanf ib (concat_fmt fmt' rest) readers pad No_precision scan\n token_string\n | String (pad, rest) ->\n let scan width _ ib = scan_string None width ib in\n pad_prec_scanf ib rest readers pad No_precision scan token_string\n\n | Caml_string (pad, rest) ->\n let scan width _ ib = scan_caml_string width ib in\n pad_prec_scanf ib rest readers pad No_precision scan token_string\n | Int (iconv, pad, prec, rest) ->\n let c = integer_conversion_of_char (char_of_iconv iconv) in\n let scan width _ ib = scan_int_conversion c width ib in\n pad_prec_scanf ib rest readers pad prec scan (token_int c)\n | Int32 (iconv, pad, prec, rest) ->\n let c = integer_conversion_of_char (char_of_iconv iconv) in\n let scan width _ ib = scan_int_conversion c width ib in\n pad_prec_scanf ib rest readers pad prec scan (token_int32 c)\n | Nativeint (iconv, pad, prec, rest) ->\n let c = integer_conversion_of_char (char_of_iconv iconv) in\n let scan width _ ib = scan_int_conversion c width ib in\n pad_prec_scanf ib rest readers pad prec scan (token_nativeint c)\n | Int64 (iconv, pad, prec, rest) ->\n let c = integer_conversion_of_char (char_of_iconv iconv) in\n let scan width _ ib = scan_int_conversion c width ib in\n pad_prec_scanf ib rest readers pad prec scan (token_int64 c)\n | Float ((_, (Float_F | Float_CF)), pad, prec, rest) ->\n pad_prec_scanf ib rest readers pad prec scan_caml_float token_float\n | Float ((_, (Float_f | Float_e | Float_E | Float_g | Float_G)),\n pad, prec, rest) ->\n pad_prec_scanf ib rest readers pad prec scan_float token_float\n | Float ((_, (Float_h | Float_H)), pad, prec, rest) ->\n pad_prec_scanf ib rest readers pad prec scan_hex_float token_float\n | Bool (pad, rest) ->\n let scan _ _ ib = scan_bool ib in\n pad_prec_scanf ib rest readers pad No_precision scan token_bool\n | Alpha _ ->\n invalid_arg \"scanf: bad conversion \\\"%a\\\"\"\n | Theta _ ->\n invalid_arg \"scanf: bad conversion \\\"%t\\\"\"\n | Custom _ ->\n invalid_arg \"scanf: bad conversion \\\"%?\\\" (custom converter)\"\n | Reader fmt_rest ->\n begin match readers with\n | Cons (reader, readers_rest) ->\n let x = reader ib in\n Cons (x, make_scanf ib fmt_rest readers_rest)\n | Nil ->\n invalid_arg \"scanf: missing reader\"\n end\n | Flush rest ->\n if Scanning.end_of_input ib then make_scanf ib rest readers\n else bad_input \"end of input not found\"\n\n | String_literal (str, rest) ->\n String.iter (check_char ib) str;\n make_scanf ib rest readers\n | Char_literal (chr, rest) ->\n check_char ib chr;\n make_scanf ib rest readers\n\n | Format_arg (pad_opt, fmtty, rest) ->\n let _ = scan_caml_string (width_of_pad_opt pad_opt) ib in\n let s = token_string ib in\n let fmt =\n try format_of_string_fmtty s fmtty\n with Failure msg -> bad_input msg\n in\n Cons (fmt, make_scanf ib rest readers)\n | Format_subst (pad_opt, fmtty, rest) ->\n let _ = scan_caml_string (width_of_pad_opt pad_opt) ib in\n let s = token_string ib in\n let fmt, fmt' =\n try\n let Fmt_EBB fmt = fmt_ebb_of_string s in\n let Fmt_EBB fmt' = fmt_ebb_of_string s in\n (* TODO: find a way to avoid reparsing twice *)\n\n (* TODO: these type-checks below *can* fail because of type\n ambiguity in presence of ignored-readers: \"%_r%d\" and \"%d%_r\"\n are typed in the same way.\n\n # Scanf.sscanf \"\\\"%_r%d\\\"3\" \"%(%d%_r%)\" ignore\n (fun fmt n -> string_of_format fmt, n)\n Exception: CamlinternalFormat.Type_mismatch.\n\n We should properly catch this exception.\n *)\n type_format fmt (erase_rel fmtty),\n type_format fmt' (erase_rel (symm fmtty))\n with Failure msg -> bad_input msg\n in\n Cons (Format (fmt, s),\n make_scanf ib (concat_fmt fmt' rest) readers)\n\n | Scan_char_set (width_opt, char_set, Formatting_lit (fmting_lit, rest)) ->\n let stp, str = stopper_of_formatting_lit fmting_lit in\n let width = width_of_pad_opt width_opt in\n scan_chars_in_char_set char_set (Some stp) width ib;\n let s = token_string ib in\n let str_rest = String_literal (str, rest) in\n Cons (s, make_scanf ib str_rest readers)\n | Scan_char_set (width_opt, char_set, rest) ->\n let width = width_of_pad_opt width_opt in\n scan_chars_in_char_set char_set None width ib;\n let s = token_string ib in\n Cons (s, make_scanf ib rest readers)\n | Scan_get_counter (counter, rest) ->\n let count = get_counter ib counter in\n Cons (count, make_scanf ib rest readers)\n | Scan_next_char rest ->\n let c = Scanning.checked_peek_char ib in\n Cons (c, make_scanf ib rest readers)\n\n | Formatting_lit (formatting_lit, rest) ->\n String.iter (check_char ib) (string_of_formatting_lit formatting_lit);\n make_scanf ib rest readers\n | Formatting_gen (Open_tag (Format (fmt', _)), rest) ->\n check_char ib '@'; check_char ib '{';\n make_scanf ib (concat_fmt fmt' rest) readers\n | Formatting_gen (Open_box (Format (fmt', _)), rest) ->\n check_char ib '@'; check_char ib '[';\n make_scanf ib (concat_fmt fmt' rest) readers\n\n | Ignored_param (ign, rest) ->\n let Param_format_EBB fmt' = param_format_of_ignored_format ign rest in\n begin match make_scanf ib fmt' readers with\n | Cons (_, arg_rest) -> arg_rest\n | Nil -> assert false\n end\n\n | End_of_format ->\n Nil\n\n(* Case analysis on padding and precision. *)\n(* Reject formats containing \"%*\" or \"%.*\". *)\n(* Pass padding and precision to the generic scanner `scan'. *)\nand pad_prec_scanf : type a c d e f x y z t .\n Scanning.in_channel -> (a, Scanning.in_channel, c, d, e, f) fmt ->\n (d, e) heter_list -> (x, y) padding -> (y, z -> a) precision ->\n (int -> int -> Scanning.in_channel -> t) ->\n (Scanning.in_channel -> z) ->\n (x, f) heter_list =\nfun ib fmt readers pad prec scan token -> match pad, prec with\n | No_padding, No_precision ->\n let _ = scan max_int max_int ib in\n let x = token ib in\n Cons (x, make_scanf ib fmt readers)\n | No_padding, Lit_precision p ->\n let _ = scan max_int p ib in\n let x = token ib in\n Cons (x, make_scanf ib fmt readers)\n | Lit_padding ((Right | Zeros), w), No_precision ->\n let _ = scan w max_int ib in\n let x = token ib in\n Cons (x, make_scanf ib fmt readers)\n | Lit_padding ((Right | Zeros), w), Lit_precision p ->\n let _ = scan w p ib in\n let x = token ib in\n Cons (x, make_scanf ib fmt readers)\n | Lit_padding (Left, _), _ ->\n invalid_arg \"scanf: bad conversion \\\"%-\\\"\"\n | Lit_padding ((Right | Zeros), _), Arg_precision ->\n invalid_arg \"scanf: bad conversion \\\"%*\\\"\"\n | Arg_padding _, _ ->\n invalid_arg \"scanf: bad conversion \\\"%*\\\"\"\n | No_padding, Arg_precision ->\n invalid_arg \"scanf: bad conversion \\\"%*\\\"\"\n\n(******************************************************************************)\n (* Defining [scanf] and various flavors of [scanf] *)\n\ntype 'a kscanf_result = Args of 'a | Exc of exn\n\nlet kscanf ib ef (Format (fmt, str)) =\n let rec apply : type a b . a -> (a, b) heter_list -> b =\n fun f args -> match args with\n | Cons (x, r) -> apply (f x) r\n | Nil -> f\n in\n let k readers f =\n Scanning.reset_token ib;\n match try Args (make_scanf ib fmt readers) with\n | (Scan_failure _ | Failure _ | End_of_file) as exc -> Exc exc\n | Invalid_argument msg ->\n invalid_arg (msg ^ \" in format \\\"\" ^ String.escaped str ^ \"\\\"\")\n with\n | Args args -> apply f args\n | Exc exc -> ef ib exc\n in\n take_format_readers k fmt\n\n(***)\n\nlet kbscanf = kscanf\nlet bscanf ib fmt = kbscanf ib scanf_bad_input fmt\n\nlet ksscanf s ef fmt = kbscanf (Scanning.from_string s) ef fmt\nlet sscanf s fmt = kbscanf (Scanning.from_string s) scanf_bad_input fmt\n\nlet scanf fmt = kscanf Scanning.stdib scanf_bad_input fmt\n\n(***)\n\n(* Scanning format strings. *)\nlet bscanf_format :\n Scanning.in_channel -> ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n (('a, 'b, 'c, 'd, 'e, 'f) format6 -> 'g) -> 'g =\n fun ib format f ->\n let _ = scan_caml_string max_int ib in\n let str = token_string ib in\n let fmt' =\n try format_of_string_format str format\n with Failure msg -> bad_input msg in\n f fmt'\n\n\nlet sscanf_format :\n string -> ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n (('a, 'b, 'c, 'd, 'e, 'f) format6 -> 'g) -> 'g =\n fun s format f -> bscanf_format (Scanning.from_string s) format f\n\n\nlet format_from_string s fmt =\n sscanf_format (\"\\\"\" ^ String.escaped s ^ \"\\\"\") fmt (fun x -> x)\n\n\nlet unescaped s =\n sscanf (\"\\\"\" ^ s ^ \"\\\"\") \"%S%!\" (fun x -> x)\n\n\n(* Deprecated *)\nlet kfscanf ic ef fmt = kbscanf (Scanning.memo_from_channel ic) ef fmt\nlet fscanf ic fmt = kscanf (Scanning.memo_from_channel ic) scanf_bad_input fmt\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Registering OCaml values with the C runtime for later callbacks *)\n\nexternal register_named_value : string -> Obj.t -> unit\n = \"caml_register_named_value\"\n\nlet register name v =\n register_named_value name (Obj.repr v)\n\nlet register_exception name (exn : exn) =\n let exn = Obj.repr exn in\n let slot = if Obj.tag exn = Obj.object_tag then exn else Obj.field exn 0 in\n register_named_value name slot\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2004 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype shape =\n | Function\n | Lazy\n | Class\n | Module of shape array\n | Value of Obj.t\n\nlet rec init_mod_field modu i loc shape =\n let init =\n match shape with\n | Function ->\n let rec fn (x : 'a) =\n let fn' : 'a -> 'b = Obj.obj (Obj.field modu i) in\n if fn == fn' then\n raise (Undefined_recursive_module loc)\n else\n fn' x in\n Obj.repr fn\n | Lazy ->\n let rec l =\n lazy (\n let l' = Obj.obj (Obj.field modu i) in\n if l == l' then\n raise (Undefined_recursive_module loc)\n else\n Lazy.force l') in\n Obj.repr l\n | Class ->\n Obj.repr (CamlinternalOO.dummy_class loc)\n | Module comps ->\n Obj.repr (init_mod_block loc comps)\n | Value v -> v\n in\n Obj.set_field modu i init\n\nand init_mod_block loc comps =\n let length = Array.length comps in\n let modu = Obj.new_block 0 length in\n for i = 0 to length - 1 do\n init_mod_field modu i loc comps.(i)\n done;\n modu\n\nlet init_mod loc shape =\n match shape with\n | Module comps ->\n Obj.repr (init_mod_block loc comps)\n | _ -> failwith \"CamlinternalMod.init_mod: not a module\"\n\nlet rec update_mod_field modu i shape n =\n match shape with\n | Function | Lazy ->\n Obj.set_field modu i n\n | Value _ ->\n () (* the value is already there *)\n | Class ->\n assert (Obj.tag n = 0 && Obj.size n = 4);\n let cl = Obj.field modu i in\n for j = 0 to 3 do\n Obj.set_field cl j (Obj.field n j)\n done\n | Module comps ->\n update_mod_block comps (Obj.field modu i) n\n\nand update_mod_block comps o n =\n assert (Obj.tag n = 0 && Obj.size n >= Array.length comps);\n for i = 0 to Array.length comps - 1 do\n update_mod_field o i comps.(i) (Obj.field n i)\n done\n\nlet update_mod shape o n =\n match shape with\n | Module comps ->\n update_mod_block comps o n\n | _ -> failwith \"CamlinternalMod.update_mod: not a module\"\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Manuel Serrano et Xavier Leroy, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2000 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Bigarray]: large, multi-dimensional, numerical arrays *)\n\n(* These types in must be kept in sync with the tables in\n ../typing/typeopt.ml *)\n\ntype float32_elt = Float32_elt\ntype float64_elt = Float64_elt\ntype int8_signed_elt = Int8_signed_elt\ntype int8_unsigned_elt = Int8_unsigned_elt\ntype int16_signed_elt = Int16_signed_elt\ntype int16_unsigned_elt = Int16_unsigned_elt\ntype int32_elt = Int32_elt\ntype int64_elt = Int64_elt\ntype int_elt = Int_elt\ntype nativeint_elt = Nativeint_elt\ntype complex32_elt = Complex32_elt\ntype complex64_elt = Complex64_elt\n\ntype ('a, 'b) kind =\n Float32 : (float, float32_elt) kind\n | Float64 : (float, float64_elt) kind\n | Int8_signed : (int, int8_signed_elt) kind\n | Int8_unsigned : (int, int8_unsigned_elt) kind\n | Int16_signed : (int, int16_signed_elt) kind\n | Int16_unsigned : (int, int16_unsigned_elt) kind\n | Int32 : (int32, int32_elt) kind\n | Int64 : (int64, int64_elt) kind\n | Int : (int, int_elt) kind\n | Nativeint : (nativeint, nativeint_elt) kind\n | Complex32 : (Complex.t, complex32_elt) kind\n | Complex64 : (Complex.t, complex64_elt) kind\n | Char : (char, int8_unsigned_elt) kind\n\ntype c_layout = C_layout_typ\ntype fortran_layout = Fortran_layout_typ (**)\n\ntype 'a layout =\n C_layout: c_layout layout\n | Fortran_layout: fortran_layout layout\n\n(* Keep those constants in sync with the caml_ba_kind enumeration\n in bigarray.h *)\n\nlet float32 = Float32\nlet float64 = Float64\nlet int8_signed = Int8_signed\nlet int8_unsigned = Int8_unsigned\nlet int16_signed = Int16_signed\nlet int16_unsigned = Int16_unsigned\nlet int32 = Int32\nlet int64 = Int64\nlet int = Int\nlet nativeint = Nativeint\nlet complex32 = Complex32\nlet complex64 = Complex64\nlet char = Char\n\nlet kind_size_in_bytes : type a b. (a, b) kind -> int = function\n | Float32 -> 4\n | Float64 -> 8\n | Int8_signed -> 1\n | Int8_unsigned -> 1\n | Int16_signed -> 2\n | Int16_unsigned -> 2\n | Int32 -> 4\n | Int64 -> 8\n | Int -> Sys.word_size / 8\n | Nativeint -> Sys.word_size / 8\n | Complex32 -> 8\n | Complex64 -> 16\n | Char -> 1\n\n(* Keep those constants in sync with the caml_ba_layout enumeration\n in bigarray.h *)\n\nlet c_layout = C_layout\nlet fortran_layout = Fortran_layout\n\nmodule Genarray = struct\n type (!'a, !'b, !'c) t\n external create: ('a, 'b) kind -> 'c layout -> int array -> ('a, 'b, 'c) t\n = \"caml_ba_create\"\n external get: ('a, 'b, 'c) t -> int array -> 'a\n = \"caml_ba_get_generic\"\n external set: ('a, 'b, 'c) t -> int array -> 'a -> unit\n = \"caml_ba_set_generic\"\n\n let rec cloop arr idx f col max =\n if col = Array.length idx then set arr idx (f idx)\n else for j = 0 to pred max.(col) do\n idx.(col) <- j;\n cloop arr idx f (succ col) max\n done\n let rec floop arr idx f col max =\n if col < 0 then set arr idx (f idx)\n else for j = 1 to max.(col) do\n idx.(col) <- j;\n floop arr idx f (pred col) max\n done\n let init (type t) kind (layout : t layout) dims f =\n let arr = create kind layout dims in\n match Array.length dims, layout with\n | 0, _ -> arr\n | dlen, C_layout -> cloop arr (Array.make dlen 0) f 0 dims; arr\n | dlen, Fortran_layout -> floop arr (Array.make dlen 1) f (pred dlen) dims;\n arr\n\n external num_dims: ('a, 'b, 'c) t -> int = \"caml_ba_num_dims\"\n external nth_dim: ('a, 'b, 'c) t -> int -> int = \"caml_ba_dim\"\n let dims a =\n let n = num_dims a in\n let d = Array.make n 0 in\n for i = 0 to n-1 do d.(i) <- nth_dim a i done;\n d\n\n external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n = \"caml_ba_change_layout\"\n\n let size_in_bytes arr =\n (kind_size_in_bytes (kind arr)) * (Array.fold_left ( * ) 1 (dims arr))\n\n external sub_left: ('a, 'b, c_layout) t -> int -> int -> ('a, 'b, c_layout) t\n = \"caml_ba_sub\"\n external sub_right: ('a, 'b, fortran_layout) t -> int -> int ->\n ('a, 'b, fortran_layout) t\n = \"caml_ba_sub\"\n external slice_left: ('a, 'b, c_layout) t -> int array ->\n ('a, 'b, c_layout) t\n = \"caml_ba_slice\"\n external slice_right: ('a, 'b, fortran_layout) t -> int array ->\n ('a, 'b, fortran_layout) t\n = \"caml_ba_slice\"\n external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit\n = \"caml_ba_blit\"\n external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\nend\n\nmodule Array0 = struct\n type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n let create kind layout =\n Genarray.create kind layout [||]\n let get arr = Genarray.get arr [||]\n let set arr = Genarray.set arr [||]\n external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n = \"caml_ba_change_layout\"\n\n let size_in_bytes arr = kind_size_in_bytes (kind arr)\n\n external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n\n let of_value kind layout v =\n let a = create kind layout in\n set a v;\n a\n let init = of_value\nend\n\nmodule Array1 = struct\n type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n let create kind layout dim =\n Genarray.create kind layout [|dim|]\n external get: ('a, 'b, 'c) t -> int -> 'a = \"%caml_ba_ref_1\"\n external set: ('a, 'b, 'c) t -> int -> 'a -> unit = \"%caml_ba_set_1\"\n external unsafe_get: ('a, 'b, 'c) t -> int -> 'a = \"%caml_ba_unsafe_ref_1\"\n external unsafe_set: ('a, 'b, 'c) t -> int -> 'a -> unit\n = \"%caml_ba_unsafe_set_1\"\n external dim: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\n external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n = \"caml_ba_change_layout\"\n\n let size_in_bytes arr =\n (kind_size_in_bytes (kind arr)) * (dim arr)\n\n external sub: ('a, 'b, 'c) t -> int -> int -> ('a, 'b, 'c) t = \"caml_ba_sub\"\n let slice (type t) (a : (_, _, t) Genarray.t) n =\n match layout a with\n | C_layout -> (Genarray.slice_left a [|n|] : (_, _, t) Genarray.t)\n | Fortran_layout -> (Genarray.slice_right a [|n|]: (_, _, t) Genarray.t)\n external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n let c_init arr dim f =\n for i = 0 to pred dim do unsafe_set arr i (f i) done\n let fortran_init arr dim f =\n for i = 1 to dim do unsafe_set arr i (f i) done\n let init (type t) kind (layout : t layout) dim f =\n let arr = create kind layout dim in\n match layout with\n | C_layout -> c_init arr dim f; arr\n | Fortran_layout -> fortran_init arr dim f; arr\n let of_array (type t) kind (layout: t layout) data =\n let ba = create kind layout (Array.length data) in\n let ofs =\n match layout with\n C_layout -> 0\n | Fortran_layout -> 1\n in\n for i = 0 to Array.length data - 1 do unsafe_set ba (i + ofs) data.(i) done;\n ba\nend\n\nmodule Array2 = struct\n type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n let create kind layout dim1 dim2 =\n Genarray.create kind layout [|dim1; dim2|]\n external get: ('a, 'b, 'c) t -> int -> int -> 'a = \"%caml_ba_ref_2\"\n external set: ('a, 'b, 'c) t -> int -> int -> 'a -> unit = \"%caml_ba_set_2\"\n external unsafe_get: ('a, 'b, 'c) t -> int -> int -> 'a\n = \"%caml_ba_unsafe_ref_2\"\n external unsafe_set: ('a, 'b, 'c) t -> int -> int -> 'a -> unit\n = \"%caml_ba_unsafe_set_2\"\n external dim1: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\n external dim2: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_2\"\n external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n = \"caml_ba_change_layout\"\n\n let size_in_bytes arr =\n (kind_size_in_bytes (kind arr)) * (dim1 arr) * (dim2 arr)\n\n external sub_left: ('a, 'b, c_layout) t -> int -> int -> ('a, 'b, c_layout) t\n = \"caml_ba_sub\"\n external sub_right:\n ('a, 'b, fortran_layout) t -> int -> int -> ('a, 'b, fortran_layout) t\n = \"caml_ba_sub\"\n let slice_left a n = Genarray.slice_left a [|n|]\n let slice_right a n = Genarray.slice_right a [|n|]\n external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n let c_init arr dim1 dim2 f =\n for i = 0 to pred dim1 do\n for j = 0 to pred dim2 do\n unsafe_set arr i j (f i j)\n done\n done\n let fortran_init arr dim1 dim2 f =\n for j = 1 to dim2 do\n for i = 1 to dim1 do\n unsafe_set arr i j (f i j)\n done\n done\n let init (type t) kind (layout : t layout) dim1 dim2 f =\n let arr = create kind layout dim1 dim2 in\n match layout with\n | C_layout -> c_init arr dim1 dim2 f; arr\n | Fortran_layout -> fortran_init arr dim1 dim2 f; arr\n let of_array (type t) kind (layout: t layout) data =\n let dim1 = Array.length data in\n let dim2 = if dim1 = 0 then 0 else Array.length data.(0) in\n let ba = create kind layout dim1 dim2 in\n let ofs =\n match layout with\n C_layout -> 0\n | Fortran_layout -> 1\n in\n for i = 0 to dim1 - 1 do\n let row = data.(i) in\n if Array.length row <> dim2 then\n invalid_arg(\"Bigarray.Array2.of_array: non-rectangular data\");\n for j = 0 to dim2 - 1 do\n unsafe_set ba (i + ofs) (j + ofs) row.(j)\n done\n done;\n ba\nend\n\nmodule Array3 = struct\n type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n let create kind layout dim1 dim2 dim3 =\n Genarray.create kind layout [|dim1; dim2; dim3|]\n external get: ('a, 'b, 'c) t -> int -> int -> int -> 'a = \"%caml_ba_ref_3\"\n external set: ('a, 'b, 'c) t -> int -> int -> int -> 'a -> unit\n = \"%caml_ba_set_3\"\n external unsafe_get: ('a, 'b, 'c) t -> int -> int -> int -> 'a\n = \"%caml_ba_unsafe_ref_3\"\n external unsafe_set: ('a, 'b, 'c) t -> int -> int -> int -> 'a -> unit\n = \"%caml_ba_unsafe_set_3\"\n external dim1: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\n external dim2: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_2\"\n external dim3: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_3\"\n external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n = \"caml_ba_change_layout\"\n\n let size_in_bytes arr =\n (kind_size_in_bytes (kind arr)) * (dim1 arr) * (dim2 arr) * (dim3 arr)\n\n external sub_left: ('a, 'b, c_layout) t -> int -> int -> ('a, 'b, c_layout) t\n = \"caml_ba_sub\"\n external sub_right:\n ('a, 'b, fortran_layout) t -> int -> int -> ('a, 'b, fortran_layout) t\n = \"caml_ba_sub\"\n let slice_left_1 a n m = Genarray.slice_left a [|n; m|]\n let slice_right_1 a n m = Genarray.slice_right a [|n; m|]\n let slice_left_2 a n = Genarray.slice_left a [|n|]\n let slice_right_2 a n = Genarray.slice_right a [|n|]\n external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n let c_init arr dim1 dim2 dim3 f =\n for i = 0 to pred dim1 do\n for j = 0 to pred dim2 do\n for k = 0 to pred dim3 do\n unsafe_set arr i j k (f i j k)\n done\n done\n done\n let fortran_init arr dim1 dim2 dim3 f =\n for k = 1 to dim3 do\n for j = 1 to dim2 do\n for i = 1 to dim1 do\n unsafe_set arr i j k (f i j k)\n done\n done\n done\n let init (type t) kind (layout : t layout) dim1 dim2 dim3 f =\n let arr = create kind layout dim1 dim2 dim3 in\n match layout with\n | C_layout -> c_init arr dim1 dim2 dim3 f; arr\n | Fortran_layout -> fortran_init arr dim1 dim2 dim3 f; arr\n let of_array (type t) kind (layout: t layout) data =\n let dim1 = Array.length data in\n let dim2 = if dim1 = 0 then 0 else Array.length data.(0) in\n let dim3 = if dim2 = 0 then 0 else Array.length data.(0).(0) in\n let ba = create kind layout dim1 dim2 dim3 in\n let ofs =\n match layout with\n C_layout -> 0\n | Fortran_layout -> 1\n in\n for i = 0 to dim1 - 1 do\n let row = data.(i) in\n if Array.length row <> dim2 then\n invalid_arg(\"Bigarray.Array3.of_array: non-cubic data\");\n for j = 0 to dim2 - 1 do\n let col = row.(j) in\n if Array.length col <> dim3 then\n invalid_arg(\"Bigarray.Array3.of_array: non-cubic data\");\n for k = 0 to dim3 - 1 do\n unsafe_set ba (i + ofs) (j + ofs) (k + ofs) col.(k)\n done\n done\n done;\n ba\nend\n\nexternal genarray_of_array0: ('a, 'b, 'c) Array0.t -> ('a, 'b, 'c) Genarray.t\n = \"%identity\"\nexternal genarray_of_array1: ('a, 'b, 'c) Array1.t -> ('a, 'b, 'c) Genarray.t\n = \"%identity\"\nexternal genarray_of_array2: ('a, 'b, 'c) Array2.t -> ('a, 'b, 'c) Genarray.t\n = \"%identity\"\nexternal genarray_of_array3: ('a, 'b, 'c) Array3.t -> ('a, 'b, 'c) Genarray.t\n = \"%identity\"\nlet array0_of_genarray a =\n if Genarray.num_dims a = 0 then a\n else invalid_arg \"Bigarray.array0_of_genarray\"\nlet array1_of_genarray a =\n if Genarray.num_dims a = 1 then a\n else invalid_arg \"Bigarray.array1_of_genarray\"\nlet array2_of_genarray a =\n if Genarray.num_dims a = 2 then a\n else invalid_arg \"Bigarray.array2_of_genarray\"\nlet array3_of_genarray a =\n if Genarray.num_dims a = 3 then a\n else invalid_arg \"Bigarray.array3_of_genarray\"\n\nexternal reshape:\n ('a, 'b, 'c) Genarray.t -> int array -> ('a, 'b, 'c) Genarray.t\n = \"caml_ba_reshape\"\nlet reshape_0 a = reshape a [||]\nlet reshape_1 a dim1 = reshape a [|dim1|]\nlet reshape_2 a dim1 dim2 = reshape a [|dim1;dim2|]\nlet reshape_3 a dim1 dim2 dim3 = reshape a [|dim1;dim2;dim3|]\n\n(* Force caml_ba_get_{1,2,3,N} to be linked in, since we don't refer\n to those primitives directly in this file *)\n\nlet _ =\n let _ = Genarray.get in\n let _ = Array1.get in\n let _ = Array2.get in\n let _ = Array3.get in\n ()\n\n[@@@ocaml.warning \"-32\"]\nexternal get1: unit -> unit = \"caml_ba_get_1\"\nexternal get2: unit -> unit = \"caml_ba_get_2\"\nexternal get3: unit -> unit = \"caml_ba_get_3\"\nexternal set1: unit -> unit = \"caml_ba_set_1\"\nexternal set2: unit -> unit = \"caml_ba_set_2\"\nexternal set3: unit -> unit = \"caml_ba_set_3\"\n","(** Why allocate a ref instead of storing the int directly?\n\n We generate many more sexp grammars than actually get used, so we prefer to defer the\n id until we need it. The compiler can optimize away allocations that nobody touches.\n*)\n\ntype t = int Lazy.t\n\nlet create =\n let next = ref 0 in\n fun () -> lazy (\n (* As long as we don't give up the global Ocaml runtime lock by allocating, we can\n treat the read and write as atomic. See \"20.12.2 Parallel execution of long-running\n C code\" in the 4.09 manual. *)\n let id = !next in\n next := id + 1;\n id)\n\nlet force (t : t) = Lazy.force t\n\nlet compare a b = compare (force a) (force b)\n","[@@@ocaml.warning \"-3\"]\n\n(* blit_string doesn't exist in [StdLabels.Bytes]... *)\nlet bytes_blit_string ~src ~src_pos ~dst ~dst_pos ~len =\n Bytes.blit_string src src_pos dst dst_pos len\n\nopen StdLabels\nopen Format\n\n(** Type of S-expressions *)\ntype t = Atom of string | List of t list\n\nlet sexp_of_t t = t\nlet t_of_sexp t = t\nlet t_sexp_grammar = Raw_grammar.Inline Any\n\nlet rec compare_list a b =\n match a, b with\n | [] , [] -> 0\n | [] , _ -> -1\n | _ , [] -> 1\n | x::xs, y::ys ->\n let res = compare x y in\n if res <> 0 then res\n else compare_list xs ys\n\nand compare a b =\n if a == b then\n 0\n else\n match a, b with\n | Atom a, Atom b -> String.compare a b\n | Atom _, _ -> -1\n | _, Atom _ -> 1\n | List a, List b -> compare_list a b\n\nlet equal a b = compare a b = 0\n\nexception Not_found_s of t\n\nexception Of_sexp_error of exn * t\n\nmodule Printing = struct\n (* Default indentation level for human-readable conversions *)\n\n let default_indent = ref 1\n\n (* Escaping of strings used as atoms in S-expressions *)\n\n let must_escape str =\n let len = String.length str in\n len = 0 ||\n let rec loop str ix =\n match str.[ix] with\n | '\"' | '(' | ')' | ';' | '\\\\' -> true\n | '|' -> ix > 0 && let next = ix - 1 in Char.equal str.[next] '#' || loop str next\n | '#' -> ix > 0 && let next = ix - 1 in Char.equal str.[next] '|' || loop str next\n | '\\000' .. '\\032' | '\\127' .. '\\255' -> true\n | _ -> ix > 0 && loop str (ix - 1)\n in\n loop str (len - 1)\n\n let escaped s =\n let n = ref 0 in\n for i = 0 to String.length s - 1 do\n n := !n +\n (match String.unsafe_get s i with\n | '\\\"' | '\\\\' | '\\n' | '\\t' | '\\r' | '\\b' -> 2\n | ' ' .. '~' -> 1\n | _ -> 4)\n done;\n if !n = String.length s then s else begin\n let s' = Bytes.create !n in\n n := 0;\n for i = 0 to String.length s - 1 do\n begin match String.unsafe_get s i with\n | ('\\\"' | '\\\\') as c ->\n Bytes.unsafe_set s' !n '\\\\'; incr n; Bytes.unsafe_set s' !n c\n | '\\n' ->\n Bytes.unsafe_set s' !n '\\\\'; incr n; Bytes.unsafe_set s' !n 'n'\n | '\\t' ->\n Bytes.unsafe_set s' !n '\\\\'; incr n; Bytes.unsafe_set s' !n 't'\n | '\\r' ->\n Bytes.unsafe_set s' !n '\\\\'; incr n; Bytes.unsafe_set s' !n 'r'\n | '\\b' ->\n Bytes.unsafe_set s' !n '\\\\'; incr n; Bytes.unsafe_set s' !n 'b'\n | (' ' .. '~') as c -> Bytes.unsafe_set s' !n c\n | c ->\n let a = Char.code c in\n Bytes.unsafe_set s' !n '\\\\';\n incr n;\n Bytes.unsafe_set s' !n (Char.chr (48 + a / 100));\n incr n;\n Bytes.unsafe_set s' !n (Char.chr (48 + (a / 10) mod 10));\n incr n;\n Bytes.unsafe_set s' !n (Char.chr (48 + a mod 10));\n end;\n incr n\n done;\n Bytes.unsafe_to_string s'\n end\n\n let esc_str str =\n let estr = escaped str in\n let elen = String.length estr in\n let res = Bytes.create (elen + 2) in\n bytes_blit_string ~src:estr ~src_pos:0 ~dst:res ~dst_pos:1 ~len:elen;\n Bytes.unsafe_set res 0 '\"';\n Bytes.unsafe_set res (elen + 1) '\"';\n Bytes.unsafe_to_string res\n\n let index_of_newline str start =\n try Some (String.index_from str start '\\n')\n with Not_found -> None\n\n let get_substring str index end_pos_opt =\n let end_pos =\n match end_pos_opt with\n | None -> String.length str\n | Some end_pos -> end_pos\n in\n String.sub str ~pos:index ~len:(end_pos - index)\n\n let is_one_line str =\n match index_of_newline str 0 with\n | None -> true\n | Some index -> index + 1 = String.length str\n\n let pp_hum_maybe_esc_str ppf str =\n if not (must_escape str) then\n pp_print_string ppf str\n else if is_one_line str then\n pp_print_string ppf (esc_str str)\n else begin\n let rec loop index =\n let next_newline = index_of_newline str index in\n let next_line = get_substring str index next_newline in\n pp_print_string ppf (escaped next_line);\n match next_newline with\n | None -> ()\n | Some newline_index ->\n pp_print_string ppf \"\\\\\";\n pp_force_newline ppf ();\n pp_print_string ppf \"\\\\n\";\n loop (newline_index + 1)\n in\n pp_open_box ppf 0;\n (* the leading space is to line up the lines *)\n pp_print_string ppf \" \\\"\";\n loop 0;\n pp_print_string ppf \"\\\"\";\n pp_close_box ppf ();\n end\n\n let mach_maybe_esc_str str =\n if must_escape str then esc_str str else str\n\n (* Output of S-expressions to formatters *)\n\n let rec pp_hum_indent indent ppf = function\n | Atom str -> pp_hum_maybe_esc_str ppf str\n | List (h :: t) ->\n pp_open_box ppf indent;\n pp_print_string ppf \"(\";\n pp_hum_indent indent ppf h;\n pp_hum_rest indent ppf t\n | List [] -> pp_print_string ppf \"()\"\n\n and pp_hum_rest indent ppf = function\n | h :: t ->\n pp_print_space ppf ();\n pp_hum_indent indent ppf h;\n pp_hum_rest indent ppf t\n | [] ->\n pp_print_string ppf \")\";\n pp_close_box ppf ()\n\n let rec pp_mach_internal may_need_space ppf = function\n | Atom str ->\n let str' = mach_maybe_esc_str str in\n let new_may_need_space = str' == str in\n if may_need_space && new_may_need_space then pp_print_string ppf \" \";\n pp_print_string ppf str';\n new_may_need_space\n | List (h :: t) ->\n pp_print_string ppf \"(\";\n let may_need_space = pp_mach_internal false ppf h in\n pp_mach_rest may_need_space ppf t;\n false\n | List [] -> pp_print_string ppf \"()\"; false\n\n and pp_mach_rest may_need_space ppf = function\n | h :: t ->\n let may_need_space = pp_mach_internal may_need_space ppf h in\n pp_mach_rest may_need_space ppf t\n | [] -> pp_print_string ppf \")\"\n\n let pp_hum ppf sexp = pp_hum_indent !default_indent ppf sexp\n\n let pp_mach ppf sexp = ignore (pp_mach_internal false ppf sexp)\n let pp = pp_mach\n\n (* Sexp size *)\n\n let rec size_loop (v, c as acc) = function\n | Atom str -> v + 1, c + String.length str\n | List lst -> List.fold_left lst ~init:acc ~f:size_loop\n\n let size sexp = size_loop (0, 0) sexp\n\n (* Buffer conversions *)\n\n let to_buffer_hum ~buf ?(indent = !default_indent) sexp =\n let ppf = Format.formatter_of_buffer buf in\n Format.fprintf ppf \"%a@?\" (pp_hum_indent indent) sexp\n\n let to_buffer_mach ~buf sexp =\n let rec loop may_need_space = function\n | Atom str ->\n let str' = mach_maybe_esc_str str in\n let new_may_need_space = str' == str in\n if may_need_space && new_may_need_space then Buffer.add_char buf ' ';\n Buffer.add_string buf str';\n new_may_need_space\n | List (h :: t) ->\n Buffer.add_char buf '(';\n let may_need_space = loop false h in\n loop_rest may_need_space t;\n false\n | List [] -> Buffer.add_string buf \"()\"; false\n and loop_rest may_need_space = function\n | h :: t ->\n let may_need_space = loop may_need_space h in\n loop_rest may_need_space t\n | [] -> Buffer.add_char buf ')' in\n ignore (loop false sexp)\n\n let to_buffer = to_buffer_mach\n\n let to_buffer_gen ~buf ~add_char ~add_string sexp =\n let rec loop may_need_space = function\n | Atom str ->\n let str' = mach_maybe_esc_str str in\n let new_may_need_space = str' == str in\n if may_need_space && new_may_need_space then add_char buf ' ';\n add_string buf str';\n new_may_need_space\n | List (h :: t) ->\n add_char buf '(';\n let may_need_space = loop false h in\n loop_rest may_need_space t;\n false\n | List [] -> add_string buf \"()\"; false\n and loop_rest may_need_space = function\n | h :: t ->\n let may_need_space = loop may_need_space h in\n loop_rest may_need_space t\n | [] -> add_char buf ')' in\n ignore (loop false sexp)\n\n (* The maximum size of a thing on the minor heap is 256 words.\n Previously, this size of the returned buffer here was 4096 bytes, which\n caused the Buffer to be allocated on the *major* heap every time.\n\n According to a simple benchmark by Ron, we can improve performance for\n small s-expressions by a factor of ~4 if we only allocate 1024 bytes\n (128 words + some small overhead) worth of buffer initially. And one\n can argue that if it's free to allocate strings smaller than 256 words,\n large s-expressions requiring larger expensive buffers won't notice\n the extra two doublings from 1024 bytes to 2048 and 4096. And especially\n performance-sensitive applications to always pass in a larger buffer to\n use. *)\n let buffer () = Buffer.create 1024\n\n (* String conversions *)\n\n let to_string_hum ?indent = function\n | Atom str when (match index_of_newline str 0 with None -> true | Some _ -> false) ->\n mach_maybe_esc_str str\n | sexp ->\n let buf = buffer () in\n to_buffer_hum ?indent sexp ~buf;\n Buffer.contents buf\n\n let to_string_mach = function\n | Atom str -> mach_maybe_esc_str str\n | sexp ->\n let buf = buffer () in\n to_buffer_mach sexp ~buf;\n Buffer.contents buf\n\n let to_string = to_string_mach\nend\ninclude Printing\n\nlet of_float_style : [ `Underscores | `No_underscores ] ref = ref `No_underscores\nlet of_int_style : [ `Underscores | `No_underscores ] ref = ref `No_underscores\n\nmodule Private = struct\n include Printing\n\n module Raw_grammar = struct\n include Raw_grammar\n\n module Builtin = struct\n let unit_sexp_grammar = Inline (List [])\n let bool_sexp_grammar = Inline (Atom Bool)\n let string_sexp_grammar = Inline (Atom String)\n let bytes_sexp_grammar = string_sexp_grammar\n let char_sexp_grammar = Inline (Atom Char)\n let int_sexp_grammar = Inline (Atom Int)\n let float_sexp_grammar = Inline (Atom Float)\n let int32_sexp_grammar = Inline (Atom Int)\n let int64_sexp_grammar = Inline (Atom Int)\n let nativeint_sexp_grammar = Inline (Atom Int)\n let ref_sexp_grammar = Inline (Explicit_bind ([ \"'a\" ], Explicit_var 0))\n let lazy_t_sexp_grammar = Inline (Explicit_bind ([ \"'a\" ], Explicit_var 0))\n let option_sexp_grammar = Inline (Explicit_bind ([ \"'a\" ], Option (Explicit_var 0)))\n\n let list_sexp_grammar =\n Inline (Explicit_bind ([ \"'a\" ], List [ Many (Explicit_var 0) ]))\n ;;\n\n let array_sexp_grammar = list_sexp_grammar\n end\n\n let empty_sexp_grammar = Inline (Union [])\n let opaque_sexp_grammar = empty_sexp_grammar\n let fun_sexp_grammar = empty_sexp_grammar\n let tuple2_sexp_grammar =\n Inline\n (Explicit_bind\n ([ \"'a\"; \"'b\" ], List [ One (Explicit_var 0); One (Explicit_var 1) ]))\n ;;\n end\nend\n\nlet message name fields =\n let rec conv_fields = function\n | [] -> []\n | (fname, fsexp) :: rest ->\n match fname with\n | \"\" -> fsexp :: conv_fields rest\n | _ -> List [ Atom fname; fsexp ] :: conv_fields rest\n in\n List (Atom name :: conv_fields fields)\n","(* Utility Module for S-expression Conversions *)\nlet polymorphic_compare = compare\nopen StdLabels\nopen MoreLabels\nopen Printf\nopen Sexp\n\ntype sexp_bool = bool\ntype 'a sexp_option = 'a option\ntype 'a sexp_list = 'a list\ntype 'a sexp_array = 'a array\ntype 'a sexp_opaque = 'a\n\n(* Conversion of OCaml-values to S-expressions *)\nexternal format_float : string -> float -> string = \"caml_format_float\"\n\n(* '%.17g' is guaranteed to be round-trippable.\n\n '%.15g' will be round-trippable and not have noise at the last digit or two for a float\n which was converted from a decimal (string) with <= 15 significant digits. So it's\n worth trying first to avoid things like \"3.1400000000000001\".\n\n See comment above [to_string_round_trippable] in {!Core_kernel.Float} for\n detailed explanation and examples. *)\nlet default_string_of_float =\n ref (fun x ->\n let y = format_float \"%.15G\" x in\n if (float_of_string y) = x then\n y\n else\n format_float \"%.17G\" x)\n;;\n\nlet read_old_option_format = ref true\nlet write_old_option_format = ref true\n\nlet list_map f l = List.rev (List.rev_map l ~f)\n\nlet sexp_of_unit () = List []\nlet sexp_of_bool b = Atom (string_of_bool b)\nlet sexp_of_string str = Atom str\nlet sexp_of_bytes bytes = Atom (Bytes.to_string bytes)\nlet sexp_of_char c = Atom (String.make 1 c)\nlet sexp_of_int n = Atom (string_of_int n)\nlet sexp_of_float n = Atom (!default_string_of_float n)\nlet sexp_of_int32 n = Atom (Int32.to_string n)\nlet sexp_of_int64 n = Atom (Int64.to_string n)\nlet sexp_of_nativeint n = Atom (Nativeint.to_string n)\nlet sexp_of_ref sexp_of__a rf = sexp_of__a !rf\nlet sexp_of_lazy_t sexp_of__a lv = sexp_of__a (Lazy.force lv)\n\nlet sexp_of_option sexp_of__a = function\n | Some x when !write_old_option_format -> List [sexp_of__a x]\n | Some x -> List [Atom \"some\"; sexp_of__a x]\n | None when !write_old_option_format -> List []\n | None -> Atom \"none\"\n\nlet sexp_of_pair sexp_of__a sexp_of__b (a, b) =\n List [sexp_of__a a; sexp_of__b b]\n\nlet sexp_of_triple sexp_of__a sexp_of__b sexp_of__c (a, b, c) =\n List [sexp_of__a a; sexp_of__b b; sexp_of__c c]\n\n(* List.rev (List.rev_map ...) is tail recursive, the OCaml standard\n library List.map is NOT. *)\nlet sexp_of_list sexp_of__a lst = List (List.rev (List.rev_map lst ~f:sexp_of__a))\n\nlet sexp_of_array sexp_of__a ar =\n let lst_ref = ref [] in\n for i = Array.length ar - 1 downto 0 do\n lst_ref := sexp_of__a ar.(i) :: !lst_ref\n done;\n List !lst_ref\n\nlet sexp_of_hashtbl sexp_of_key sexp_of_val htbl =\n let coll ~key:k ~data:v acc = List [sexp_of_key k; sexp_of_val v] :: acc in\n List (Hashtbl.fold htbl ~init:[] ~f:coll)\n\nlet sexp_of_opaque _ = Atom \"\"\nlet sexp_of_fun _ = Atom \"\"\n\n\n(* Exception converter registration and lookup *)\n\nmodule Exn_converter = struct\n (* These exception registration functions assume that context-switches\n cannot happen unless there is an allocation. It is reasonable to expect\n that this will remain true for the foreseeable future. That way we\n avoid using mutexes and thus a dependency on the threads library. *)\n\n (* Fast and automatic exception registration *)\n\n module Int = struct\n type t = int\n\n let compare t1 t2 = polymorphic_compare (t1 : int) t2\n end\n\n module Exn_ids = Map.Make (Int)\n\n module Obj = struct\n module Extension_constructor = struct\n [@@@ocaml.warning \"-3\"]\n type t = extension_constructor\n let id = Obj.extension_id\n let of_val = Obj.extension_constructor\n end\n end\n\n let exn_id_map\n : (Obj.Extension_constructor.t, exn -> Sexp.t) Ephemeron.K1.t Exn_ids.t ref =\n ref Exn_ids.empty\n\n (* [Obj.extension_id] works on both the exception itself, and the extension slot of the\n exception. *)\n let rec clean_up_handler (slot : Obj.Extension_constructor.t) =\n let id = Obj.Extension_constructor.id slot in\n let old_exn_id_map = !exn_id_map in\n let new_exn_id_map = Exn_ids.remove id old_exn_id_map in\n (* This trick avoids mutexes and should be fairly efficient *)\n if !exn_id_map != old_exn_id_map then\n clean_up_handler slot\n else\n exn_id_map := new_exn_id_map\n\n (* Ephemerons are used so that [sexp_of_exn] closure don't keep the\n extension_constructor live. *)\n let add ?(finalise = true) extension_constructor sexp_of_exn =\n let id = Obj.Extension_constructor.id extension_constructor in\n let rec loop () =\n let old_exn_id_map = !exn_id_map in\n let ephe = Ephemeron.K1.create () in\n Ephemeron.K1.set_data ephe sexp_of_exn;\n Ephemeron.K1.set_key ephe extension_constructor;\n let new_exn_id_map = Exn_ids.add old_exn_id_map ~key:id ~data:ephe in\n (* This trick avoids mutexes and should be fairly efficient *)\n if !exn_id_map != old_exn_id_map then\n loop ()\n else begin\n exn_id_map := new_exn_id_map;\n if finalise then\n try\n Gc.finalise clean_up_handler extension_constructor\n with Invalid_argument _ ->\n (* Pre-allocated extension constructors cannot be finalised *)\n ()\n end\n in\n loop ()\n\n let add_auto ?finalise exn sexp_of_exn =\n add ?finalise (Obj.Extension_constructor.of_val exn) sexp_of_exn\n\n let find_auto exn =\n let id = Obj.Extension_constructor.id (Obj.Extension_constructor.of_val exn) in\n match Exn_ids.find id !exn_id_map with\n | exception Not_found -> None\n | ephe ->\n match Ephemeron.K1.get_data ephe with\n | None -> None\n | Some sexp_of_exn -> Some (sexp_of_exn exn)\n\n\n module For_unit_tests_only = struct\n let size () = Exn_ids.fold !exn_id_map ~init:0 ~f:(fun ~key:_ ~data:ephe acc ->\n match Ephemeron.K1.get_data ephe with\n | None -> acc\n | Some _ -> acc + 1\n )\n end\n\nend\n\nlet sexp_of_exn_opt exn = Exn_converter.find_auto exn\n\n\nlet sexp_of_exn exn =\n match sexp_of_exn_opt exn with\n | None -> List [Atom (Printexc.to_string exn)]\n | Some sexp -> sexp\n\nlet exn_to_string e = Sexp.to_string_hum (sexp_of_exn e)\n\n(* {[exception Blah [@@deriving sexp]]} generates a call to the function\n [Exn_converter.add] defined in this file. So we are guaranted that as soon as we\n mark an exception as sexpable, this module will be linked in and this printer will be\n registered, which is what we want. *)\nlet () =\n Printexc.register_printer (fun exn ->\n match sexp_of_exn_opt exn with\n | None -> None\n | Some sexp ->\n Some (Sexp.to_string_hum ~indent:2 sexp))\n\n(* Conversion of S-expressions to OCaml-values *)\n\nexception Of_sexp_error = Sexp.Of_sexp_error\n\nlet record_check_extra_fields = ref true\n\nlet of_sexp_error_exn exc sexp = raise (Of_sexp_error (exc, sexp))\n\nlet of_sexp_error what sexp = raise (Of_sexp_error (Failure what, sexp))\n\nlet unit_of_sexp sexp = match sexp with\n | List [] -> ()\n | Atom _ | List _ -> of_sexp_error \"unit_of_sexp: empty list needed\" sexp\n\nlet bool_of_sexp sexp = match sexp with\n | Atom (\"true\" | \"True\") -> true\n | Atom (\"false\" | \"False\") -> false\n | Atom _ -> of_sexp_error \"bool_of_sexp: unknown string\" sexp\n | List _ -> of_sexp_error \"bool_of_sexp: atom needed\" sexp\n\nlet string_of_sexp sexp = match sexp with\n | Atom str -> str\n | List _ -> of_sexp_error \"string_of_sexp: atom needed\" sexp\n\nlet bytes_of_sexp sexp = match sexp with\n | Atom str -> Bytes.of_string str\n | List _ -> of_sexp_error \"bytes_of_sexp: atom needed\" sexp\n\n\nlet char_of_sexp sexp = match sexp with\n | Atom str ->\n if String.length str <> 1 then\n of_sexp_error\n \"char_of_sexp: atom string must contain one character only\" sexp;\n str.[0]\n | List _ -> of_sexp_error \"char_of_sexp: atom needed\" sexp\n\nlet int_of_sexp sexp = match sexp with\n | Atom str ->\n (try int_of_string str\n with exc -> of_sexp_error (\"int_of_sexp: \" ^ exn_to_string exc) sexp)\n | List _ -> of_sexp_error \"int_of_sexp: atom needed\" sexp\n\nlet float_of_sexp sexp = match sexp with\n | Atom str ->\n (try float_of_string str\n with exc ->\n of_sexp_error (\"float_of_sexp: \" ^ exn_to_string exc) sexp)\n | List _ -> of_sexp_error \"float_of_sexp: atom needed\" sexp\n\nlet int32_of_sexp sexp = match sexp with\n | Atom str ->\n (try Int32.of_string str\n with exc ->\n of_sexp_error (\"int32_of_sexp: \" ^ exn_to_string exc) sexp)\n | List _ -> of_sexp_error \"int32_of_sexp: atom needed\" sexp\n\nlet int64_of_sexp sexp = match sexp with\n | Atom str ->\n (try Int64.of_string str\n with exc ->\n of_sexp_error (\"int64_of_sexp: \" ^ exn_to_string exc) sexp)\n | List _ -> of_sexp_error \"int64_of_sexp: atom needed\" sexp\n\nlet nativeint_of_sexp sexp = match sexp with\n | Atom str ->\n (try Nativeint.of_string str\n with exc ->\n of_sexp_error (\"nativeint_of_sexp: \" ^ exn_to_string exc) sexp)\n | List _ -> of_sexp_error \"nativeint_of_sexp: atom needed\" sexp\n\nlet ref_of_sexp a__of_sexp sexp = ref (a__of_sexp sexp)\nlet lazy_t_of_sexp a__of_sexp sexp = Lazy.from_val (a__of_sexp sexp)\n\nlet option_of_sexp a__of_sexp sexp =\n if !read_old_option_format then\n match sexp with\n | List [] | Atom (\"none\" | \"None\") -> None\n | List [el] | List [Atom (\"some\" | \"Some\"); el] -> Some (a__of_sexp el)\n | List _ ->\n of_sexp_error \"option_of_sexp: list must represent optional value\" sexp\n | Atom _ -> of_sexp_error \"option_of_sexp: only none can be atom\" sexp\n else\n match sexp with\n | Atom (\"none\" | \"None\") -> None\n | List [Atom (\"some\" | \"Some\"); el] -> Some (a__of_sexp el)\n | Atom _ -> of_sexp_error \"option_of_sexp: only none can be atom\" sexp\n | List _ -> of_sexp_error \"option_of_sexp: list must be (some el)\" sexp\n\nlet pair_of_sexp a__of_sexp b__of_sexp sexp = match sexp with\n | List [a_sexp; b_sexp] ->\n let a = a__of_sexp a_sexp in\n let b = b__of_sexp b_sexp in\n a, b\n | List _ ->\n of_sexp_error\n \"pair_of_sexp: list must contain exactly two elements only\" sexp\n | Atom _ -> of_sexp_error \"pair_of_sexp: list needed\" sexp\n\nlet triple_of_sexp a__of_sexp b__of_sexp c__of_sexp sexp = match sexp with\n | List [a_sexp; b_sexp; c_sexp] ->\n let a = a__of_sexp a_sexp in\n let b = b__of_sexp b_sexp in\n let c = c__of_sexp c_sexp in\n a, b, c\n | List _ ->\n of_sexp_error\n \"triple_of_sexp: list must contain exactly three elements only\" sexp\n | Atom _ -> of_sexp_error \"triple_of_sexp: list needed\" sexp\n\nlet list_of_sexp a__of_sexp sexp = match sexp with\n | List lst ->\n let rev_lst = List.rev_map lst ~f:a__of_sexp in\n List.rev rev_lst\n | Atom _ -> of_sexp_error \"list_of_sexp: list needed\" sexp\n\nlet array_of_sexp a__of_sexp sexp = match sexp with\n | List [] -> [||]\n | List (h :: t) ->\n let len = List.length t + 1 in\n let res = Array.make len (a__of_sexp h) in\n let rec loop i = function\n | [] -> res\n | h :: t -> res.(i) <- a__of_sexp h; loop (i + 1) t in\n loop 1 t\n | Atom _ -> of_sexp_error \"array_of_sexp: list needed\" sexp\n\nlet hashtbl_of_sexp key_of_sexp val_of_sexp sexp = match sexp with\n | List lst ->\n let htbl = Hashtbl.create 0 in\n let act = function\n | List [k_sexp; v_sexp] ->\n Hashtbl.add htbl ~key:(key_of_sexp k_sexp) ~data:(val_of_sexp v_sexp)\n | List _ | Atom _ ->\n of_sexp_error \"hashtbl_of_sexp: tuple list needed\" sexp\n in\n List.iter lst ~f:act;\n htbl\n | Atom _ -> of_sexp_error \"hashtbl_of_sexp: list needed\" sexp\n\nlet opaque_of_sexp sexp =\n of_sexp_error \"opaque_of_sexp: cannot convert opaque values\" sexp\n\nlet fun_of_sexp sexp =\n of_sexp_error \"fun_of_sexp: cannot convert function values\" sexp\n\n(* Registering default exception printers *)\n\nlet get_flc_error name (file, line, chr) =\n Atom (sprintf \"%s %s:%d:%d\" name file line chr)\n\nlet () =\n List.iter\n ~f:(fun (extension_constructor, handler) -> Exn_converter.add ~finalise:false extension_constructor handler)\n [\n (\n [%extension_constructor Assert_failure],\n (function\n | Assert_failure arg -> get_flc_error \"Assert_failure\" arg\n | _ -> assert false)\n );(\n [%extension_constructor Exit],\n (function\n | Exit -> Atom \"Exit\"\n | _ -> assert false)\n );(\n [%extension_constructor End_of_file],\n (function\n | End_of_file -> Atom \"End_of_file\"\n | _ -> assert false)\n );(\n [%extension_constructor Failure],\n (function\n | Failure arg -> List [Atom \"Failure\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Not_found],\n (function\n | Not_found -> Atom \"Not_found\"\n | _ -> assert false)\n );(\n [%extension_constructor Invalid_argument],\n (function\n | Invalid_argument arg -> List [Atom \"Invalid_argument\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Match_failure],\n (function\n | Match_failure arg -> get_flc_error \"Match_failure\" arg\n | _ -> assert false)\n );(\n [%extension_constructor Not_found_s],\n (function\n | Not_found_s arg -> List [Atom \"Not_found_s\"; arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Sys_error],\n (function\n | Sys_error arg -> List [Atom \"Sys_error\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Arg.Help],\n (function\n | Arg.Help arg -> List [Atom \"Arg.Help\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Arg.Bad],\n (function\n | Arg.Bad arg -> List [Atom \"Arg.Bad\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Lazy.Undefined],\n (function\n | Lazy.Undefined -> Atom \"Lazy.Undefined\"\n | _ -> assert false)\n );(\n [%extension_constructor Parsing.Parse_error],\n (function\n | Parsing.Parse_error -> Atom \"Parsing.Parse_error\"\n | _ -> assert false)\n );(\n [%extension_constructor Queue.Empty],\n (function\n | Queue.Empty -> Atom \"Queue.Empty\"\n | _ -> assert false)\n );(\n [%extension_constructor Scanf.Scan_failure],\n (function\n | Scanf.Scan_failure arg -> List [Atom \"Scanf.Scan_failure\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Stack.Empty],\n (function\n | Stack.Empty -> Atom \"Stack.Empty\"\n | _ -> assert false)\n );(\n [%extension_constructor Stream.Failure],\n (function\n | Stream.Failure -> Atom \"Stream.Failure\"\n | _ -> assert false)\n );(\n [%extension_constructor Stream.Error],\n (function\n | Stream.Error arg -> List [Atom \"Stream.Error\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Sys.Break],\n (function\n | Sys.Break -> Atom \"Sys.Break\"\n | _ -> assert false)\n );(\n [%extension_constructor Of_sexp_error],\n (function\n | Of_sexp_error (exc, sexp) ->\n List [Atom \"Sexplib.Conv.Of_sexp_error\"; sexp_of_exn exc; sexp]\n | _ -> assert false)\n );\n ]\n\nexternal ignore : _ -> unit = \"%ignore\"\nexternal ( = ) : 'a -> 'a -> bool = \"%equal\"\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Para, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1997 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n[@@@ocaml.warning \"-32\"]\n\nmodule type SeededS = sig\n\n type key\n type !'a t\n val create : ?random (*thwart tools/sync_stdlib_docs*) : bool -> int -> 'a t\n val clear : 'a t -> unit\n val reset : 'a t -> unit\n val copy : 'a t -> 'a t\n val add : 'a t -> key -> 'a -> unit\n val remove : 'a t -> key -> unit\n val find : 'a t -> key -> 'a\n val find_opt : 'a t -> key -> 'a option\n val find_all : 'a t -> key -> 'a list\n val replace : 'a t -> key -> 'a -> unit\n val mem : 'a t -> key -> bool\n val iter : (key -> 'a -> unit) -> 'a t -> unit\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val filter_map_inplace : (key -> 'a -> 'a option) -> 'a t -> unit\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val fold : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val length : 'a t -> int\n val stats : 'a t -> Hashtbl.statistics\n val to_seq : 'a t -> (key * 'a) Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val to_seq_keys : _ t -> key Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val to_seq_values : 'a t -> 'a Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val add_seq : 'a t -> (key * 'a) Seq.t -> unit\n val replace_seq : 'a t -> (key * 'a) Seq.t -> unit\n val of_seq : (key * 'a) Seq.t -> 'a t\n val clean: 'a t -> unit\n val stats_alive: 'a t -> Hashtbl.statistics\n (** same as {!stats} but only count the alive bindings *)\nend\n\nmodule type S = sig\n\n type key\n type !'a t\n val create : int -> 'a t\n val clear : 'a t -> unit\n val reset : 'a t -> unit\n val copy : 'a t -> 'a t\n val add : 'a t -> key -> 'a -> unit\n val remove : 'a t -> key -> unit\n val find : 'a t -> key -> 'a\n val find_opt : 'a t -> key -> 'a option\n val find_all : 'a t -> key -> 'a list\n val replace : 'a t -> key -> 'a -> unit\n val mem : 'a t -> key -> bool\n val iter : (key -> 'a -> unit) -> 'a t -> unit\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val filter_map_inplace : (key -> 'a -> 'a option) -> 'a t -> unit\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val fold : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val length : 'a t -> int\n val stats : 'a t -> Hashtbl.statistics\n val to_seq : 'a t -> (key * 'a) Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val to_seq_keys : _ t -> key Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val to_seq_values : 'a t -> 'a Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val add_seq : 'a t -> (key * 'a) Seq.t -> unit\n val replace_seq : 'a t -> (key * 'a) Seq.t -> unit\n val of_seq : (key * 'a) Seq.t -> 'a t\n val clean: 'a t -> unit\n val stats_alive: 'a t -> Hashtbl.statistics\n (** same as {!stats} but only count the alive bindings *)\nend\n\nmodule GenHashTable = struct\n\n type equal =\n | ETrue | EFalse\n | EDead (** the garbage collector reclaimed the data *)\n\n module MakeSeeded(H: sig\n type t\n type 'a container\n val create: t -> 'a -> 'a container\n val hash: int -> t -> int\n val equal: 'a container -> t -> equal\n val get_data: 'a container -> 'a option\n val get_key: 'a container -> t option\n val set_key_data: 'a container -> t -> 'a -> unit\n val check_key: 'a container -> bool\n end) : SeededS with type key = H.t\n = struct\n\n type 'a t =\n { mutable size: int; (* number of entries *)\n mutable data: 'a bucketlist array; (* the buckets *)\n seed: int; (* for randomization *)\n initial_size: int; (* initial array size *)\n }\n\n and 'a bucketlist =\n | Empty\n | Cons of int (* hash of the key *) * 'a H.container * 'a bucketlist\n\n (** the hash of the key is kept in order to test the equality of the hash\n before the key. Same reason as for Weak.Make *)\n\n type key = H.t\n\n let rec power_2_above x n =\n if x >= n then x\n else if x * 2 > Sys.max_array_length then x\n else power_2_above (x * 2) n\n\n let prng = lazy (Random.State.make_self_init())\n\n let create ?(random = (Hashtbl.is_randomized ())) initial_size =\n let s = power_2_above 16 initial_size in\n let seed = if random then Random.State.bits (Lazy.force prng) else 0 in\n { initial_size = s; size = 0; seed = seed; data = Array.make s Empty }\n\n let clear h =\n h.size <- 0;\n let len = Array.length h.data in\n for i = 0 to len - 1 do\n h.data.(i) <- Empty\n done\n\n let reset h =\n let len = Array.length h.data in\n if len = h.initial_size then\n clear h\n else begin\n h.size <- 0;\n h.data <- Array.make h.initial_size Empty\n end\n\n let copy h = { h with data = Array.copy h.data }\n\n let key_index h hkey =\n hkey land (Array.length h.data - 1)\n\n let clean h =\n let rec do_bucket = function\n | Empty ->\n Empty\n | Cons(_, c, rest) when not (H.check_key c) ->\n h.size <- h.size - 1;\n do_bucket rest\n | Cons(hkey, c, rest) ->\n Cons(hkey, c, do_bucket rest)\n in\n let d = h.data in\n for i = 0 to Array.length d - 1 do\n d.(i) <- do_bucket d.(i)\n done\n\n (** resize is the only function to do the actual cleaning of dead keys\n (remove does it just because it could).\n\n The goal is to:\n\n - not resize infinitely when the actual number of alive keys is\n bounded but keys are continuously added. That would happen if\n this function always resize.\n - not call this function after each addition, that would happen if this\n function don't resize even when only one key is dead.\n\n So the algorithm:\n - clean the keys before resizing\n - if the number of remaining keys is less than half the size of the\n array, don't resize.\n - if it is more, resize.\n\n The second problem remains if the table reaches {!Sys.max_array_length}.\n\n *)\n let resize h =\n let odata = h.data in\n let osize = Array.length odata in\n let nsize = osize * 2 in\n clean h;\n if nsize < Sys.max_array_length && h.size >= osize lsr 1 then begin\n let ndata = Array.make nsize Empty in\n h.data <- ndata; (* so that key_index sees the new bucket count *)\n let rec insert_bucket = function\n Empty -> ()\n | Cons(hkey, data, rest) ->\n insert_bucket rest; (* preserve original order of elements *)\n let nidx = key_index h hkey in\n ndata.(nidx) <- Cons(hkey, data, ndata.(nidx)) in\n for i = 0 to osize - 1 do\n insert_bucket odata.(i)\n done\n end\n\n let add h key info =\n let hkey = H.hash h.seed key in\n let i = key_index h hkey in\n let container = H.create key info in\n let bucket = Cons(hkey, container, h.data.(i)) in\n h.data.(i) <- bucket;\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize h\n\n let remove h key =\n let hkey = H.hash h.seed key in\n let rec remove_bucket = function\n | Empty -> Empty\n | Cons(hk, c, next) when hkey = hk ->\n begin match H.equal c key with\n | ETrue -> h.size <- h.size - 1; next\n | EFalse -> Cons(hk, c, remove_bucket next)\n | EDead ->\n (* The dead key is automatically removed. It is acceptable\n for this function since it already removes a binding *)\n h.size <- h.size - 1;\n remove_bucket next\n end\n | Cons(hk,c,next) -> Cons(hk, c, remove_bucket next) in\n let i = key_index h hkey in\n h.data.(i) <- remove_bucket h.data.(i)\n\n (** {!find} don't remove dead keys because it would be surprising for\n the user that a read-only function mutates the state (eg. concurrent\n access). Same for {!iter}, {!fold}, {!mem}.\n *)\n let rec find_rec key hkey = function\n | Empty ->\n raise Not_found\n | Cons(hk, c, rest) when hkey = hk ->\n begin match H.equal c key with\n | ETrue ->\n begin match H.get_data c with\n | None ->\n (* This case is not impossible because the gc can run between\n H.equal and H.get_data *)\n find_rec key hkey rest\n | Some d -> d\n end\n | EFalse -> find_rec key hkey rest\n | EDead ->\n find_rec key hkey rest\n end\n | Cons(_, _, rest) ->\n find_rec key hkey rest\n\n let find h key =\n let hkey = H.hash h.seed key in\n (* TODO inline 3 iterations *)\n find_rec key hkey (h.data.(key_index h hkey))\n\n let rec find_rec_opt key hkey = function\n | Empty ->\n None\n | Cons(hk, c, rest) when hkey = hk ->\n begin match H.equal c key with\n | ETrue ->\n begin match H.get_data c with\n | None ->\n (* This case is not impossible because the gc can run between\n H.equal and H.get_data *)\n find_rec_opt key hkey rest\n | Some _ as d -> d\n end\n | EFalse -> find_rec_opt key hkey rest\n | EDead ->\n find_rec_opt key hkey rest\n end\n | Cons(_, _, rest) ->\n find_rec_opt key hkey rest\n\n let find_opt h key =\n let hkey = H.hash h.seed key in\n (* TODO inline 3 iterations *)\n find_rec_opt key hkey (h.data.(key_index h hkey))\n\n let find_all h key =\n let hkey = H.hash h.seed key in\n let rec find_in_bucket = function\n | Empty -> []\n | Cons(hk, c, rest) when hkey = hk ->\n begin match H.equal c key with\n | ETrue -> begin match H.get_data c with\n | None ->\n find_in_bucket rest\n | Some d -> d::find_in_bucket rest\n end\n | EFalse -> find_in_bucket rest\n | EDead ->\n find_in_bucket rest\n end\n | Cons(_, _, rest) ->\n find_in_bucket rest in\n find_in_bucket h.data.(key_index h hkey)\n\n\n let replace h key info =\n let hkey = H.hash h.seed key in\n let rec replace_bucket = function\n | Empty -> raise Not_found\n | Cons(hk, c, next) when hkey = hk ->\n begin match H.equal c key with\n | ETrue -> H.set_key_data c key info\n | EFalse | EDead -> replace_bucket next\n end\n | Cons(_,_,next) -> replace_bucket next\n in\n let i = key_index h hkey in\n let l = h.data.(i) in\n try\n replace_bucket l\n with Not_found ->\n let container = H.create key info in\n h.data.(i) <- Cons(hkey, container, l);\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize h\n\n let mem h key =\n let hkey = H.hash h.seed key in\n let rec mem_in_bucket = function\n | Empty ->\n false\n | Cons(hk, c, rest) when hk = hkey ->\n begin match H.equal c key with\n | ETrue -> true\n | EFalse | EDead -> mem_in_bucket rest\n end\n | Cons(_hk, _c, rest) -> mem_in_bucket rest in\n mem_in_bucket h.data.(key_index h hkey)\n\n let iter f h =\n let rec do_bucket = function\n | Empty ->\n ()\n | Cons(_, c, rest) ->\n begin match H.get_key c, H.get_data c with\n | None, _ | _, None -> ()\n | Some k, Some d -> f k d\n end; do_bucket rest in\n let d = h.data in\n for i = 0 to Array.length d - 1 do\n do_bucket d.(i)\n done\n\n let fold f h init =\n let rec do_bucket b accu =\n match b with\n Empty ->\n accu\n | Cons(_, c, rest) ->\n let accu = begin match H.get_key c, H.get_data c with\n | None, _ | _, None -> accu\n | Some k, Some d -> f k d accu\n end in\n do_bucket rest accu in\n let d = h.data in\n let accu = ref init in\n for i = 0 to Array.length d - 1 do\n accu := do_bucket d.(i) !accu\n done;\n !accu\n\n let filter_map_inplace f h =\n let rec do_bucket = function\n | Empty ->\n Empty\n | Cons(hk, c, rest) ->\n match H.get_key c, H.get_data c with\n | None, _ | _, None ->\n do_bucket rest\n | Some k, Some d ->\n match f k d with\n | None ->\n do_bucket rest\n | Some new_d ->\n H.set_key_data c k new_d;\n Cons(hk, c, do_bucket rest)\n in\n let d = h.data in\n for i = 0 to Array.length d - 1 do\n d.(i) <- do_bucket d.(i)\n done\n\n let length h = h.size\n\n let rec bucket_length accu = function\n | Empty -> accu\n | Cons(_, _, rest) -> bucket_length (accu + 1) rest\n\n let stats h =\n let mbl =\n Array.fold_left (fun m b -> Int.max m (bucket_length 0 b)) 0 h.data in\n let histo = Array.make (mbl + 1) 0 in\n Array.iter\n (fun b ->\n let l = bucket_length 0 b in\n histo.(l) <- histo.(l) + 1)\n h.data;\n { Hashtbl.num_bindings = h.size;\n num_buckets = Array.length h.data;\n max_bucket_length = mbl;\n bucket_histogram = histo }\n\n let rec bucket_length_alive accu = function\n | Empty -> accu\n | Cons(_, c, rest) when H.check_key c ->\n bucket_length_alive (accu + 1) rest\n | Cons(_, _, rest) -> bucket_length_alive accu rest\n\n let stats_alive h =\n let size = ref 0 in\n let mbl =\n Array.fold_left\n (fun m b -> Int.max m (bucket_length_alive 0 b)) 0 h.data\n in\n let histo = Array.make (mbl + 1) 0 in\n Array.iter\n (fun b ->\n let l = bucket_length_alive 0 b in\n size := !size + l;\n histo.(l) <- histo.(l) + 1)\n h.data;\n { Hashtbl.num_bindings = !size;\n num_buckets = Array.length h.data;\n max_bucket_length = mbl;\n bucket_histogram = histo }\n\n let to_seq tbl =\n (* capture current array, so that even if the table is resized we\n keep iterating on the same array *)\n let tbl_data = tbl.data in\n (* state: index * next bucket to traverse *)\n let rec aux i buck () = match buck with\n | Empty ->\n if i = Array.length tbl_data\n then Seq.Nil\n else aux(i+1) tbl_data.(i) ()\n | Cons (_, c, next) ->\n begin match H.get_key c, H.get_data c with\n | None, _ | _, None -> aux i next ()\n | Some key, Some data ->\n Seq.Cons ((key, data), aux i next)\n end\n in\n aux 0 Empty\n\n let to_seq_keys m = Seq.map fst (to_seq m)\n\n let to_seq_values m = Seq.map snd (to_seq m)\n\n let add_seq tbl i =\n Seq.iter (fun (k,v) -> add tbl k v) i\n\n let replace_seq tbl i =\n Seq.iter (fun (k,v) -> replace tbl k v) i\n\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n\n end\nend\n\nmodule ObjEph = Obj.Ephemeron\n\nlet _obj_opt : Obj.t option -> 'a option = fun x ->\n match x with\n | None -> x\n | Some v -> Some (Obj.obj v)\n\n(** The previous function is typed so this one is also correct *)\nlet obj_opt : Obj.t option -> 'a option = fun x -> Obj.magic x\n\n\nmodule K1 = struct\n type ('k,'d) t = ObjEph.t\n\n let create () : ('k,'d) t = ObjEph.create 1\n\n let get_key (t:('k,'d) t) : 'k option = obj_opt (ObjEph.get_key t 0)\n let get_key_copy (t:('k,'d) t) : 'k option = obj_opt (ObjEph.get_key_copy t 0)\n let set_key (t:('k,'d) t) (k:'k) : unit = ObjEph.set_key t 0 (Obj.repr k)\n let unset_key (t:('k,'d) t) : unit = ObjEph.unset_key t 0\n let check_key (t:('k,'d) t) : bool = ObjEph.check_key t 0\n\n let blit_key (t1:('k,'d) t) (t2:('k,'d) t): unit =\n ObjEph.blit_key t1 0 t2 0 1\n\n let get_data (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data t)\n let get_data_copy (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data_copy t)\n let set_data (t:('k,'d) t) (d:'d) : unit = ObjEph.set_data t (Obj.repr d)\n let unset_data (t:('k,'d) t) : unit = ObjEph.unset_data t\n let check_data (t:('k,'d) t) : bool = ObjEph.check_data t\n let blit_data (t1:(_,'d) t) (t2:(_,'d) t) : unit = ObjEph.blit_data t1 t2\n\n let make key data =\n let eph = create () in\n set_data eph data;\n set_key eph key;\n eph\n\n let query eph key =\n match get_key eph with\n | None -> None\n | Some k when k == key -> get_data eph\n | Some _ -> None\n\n module MakeSeeded (H:Hashtbl.SeededHashedType) =\n GenHashTable.MakeSeeded(struct\n type 'a container = (H.t,'a) t\n type t = H.t\n let create k d =\n let c = create () in\n set_data c d;\n set_key c k;\n c\n let hash = H.hash\n let equal c k =\n (* {!get_key_copy} is not used because the equality of the user can be\n the physical equality *)\n match get_key c with\n | None -> GenHashTable.EDead\n | Some k' ->\n if H.equal k k' then GenHashTable.ETrue else GenHashTable.EFalse\n let get_data = get_data\n let get_key = get_key\n let set_key_data c k d =\n unset_data c;\n set_key c k;\n set_data c d\n let check_key = check_key\n end)\n\n module Make(H: Hashtbl.HashedType): (S with type key = H.t) =\n struct\n include MakeSeeded(struct\n type t = H.t\n let equal = H.equal\n let hash (_seed: int) x = H.hash x\n end)\n let create sz = create ~random:false sz\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n end\n\n module Bucket = struct\n\n type nonrec ('k, 'd) t = ('k, 'd) t list ref\n let k1_make = make\n let make () = ref []\n let add b k d = b := k1_make k d :: !b\n\n let test_key k e =\n match get_key e with\n | Some x when x == k -> true\n | _ -> false\n\n let remove b k =\n let rec loop l acc =\n match l with\n | [] -> ()\n | h :: t when test_key k h -> b := List.rev_append acc t\n | h :: t -> loop t (h :: acc)\n in\n loop !b []\n\n let find b k =\n match List.find_opt (test_key k) !b with\n | Some e -> get_data e\n | None -> None\n\n let length b = List.length !b\n let clear b = b := []\n\n end\n\nend\n\nmodule K2 = struct\n type ('k1, 'k2, 'd) t = ObjEph.t\n\n let create () : ('k1,'k2,'d) t = ObjEph.create 2\n\n let get_key1 (t:('k1,'k2,'d) t) : 'k1 option = obj_opt (ObjEph.get_key t 0)\n let get_key1_copy (t:('k1,'k2,'d) t) : 'k1 option =\n obj_opt (ObjEph.get_key_copy t 0)\n let set_key1 (t:('k1,'k2,'d) t) (k:'k1) : unit =\n ObjEph.set_key t 0 (Obj.repr k)\n let unset_key1 (t:('k1,'k2,'d) t) : unit = ObjEph.unset_key t 0\n let check_key1 (t:('k1,'k2,'d) t) : bool = ObjEph.check_key t 0\n\n let get_key2 (t:('k1,'k2,'d) t) : 'k2 option = obj_opt (ObjEph.get_key t 1)\n let get_key2_copy (t:('k1,'k2,'d) t) : 'k2 option =\n obj_opt (ObjEph.get_key_copy t 1)\n let set_key2 (t:('k1,'k2,'d) t) (k:'k2) : unit =\n ObjEph.set_key t 1 (Obj.repr k)\n let unset_key2 (t:('k1,'k2,'d) t) : unit = ObjEph.unset_key t 1\n let check_key2 (t:('k1,'k2,'d) t) : bool = ObjEph.check_key t 1\n\n\n let blit_key1 (t1:('k1,_,_) t) (t2:('k1,_,_) t) : unit =\n ObjEph.blit_key t1 0 t2 0 1\n let blit_key2 (t1:(_,'k2,_) t) (t2:(_,'k2,_) t) : unit =\n ObjEph.blit_key t1 1 t2 1 1\n let blit_key12 (t1:('k1,'k2,_) t) (t2:('k1,'k2,_) t) : unit =\n ObjEph.blit_key t1 0 t2 0 2\n\n let get_data (t:('k1,'k2,'d) t) : 'd option = obj_opt (ObjEph.get_data t)\n let get_data_copy (t:('k1,'k2,'d) t) : 'd option =\n obj_opt (ObjEph.get_data_copy t)\n let set_data (t:('k1,'k2,'d) t) (d:'d) : unit =\n ObjEph.set_data t (Obj.repr d)\n let unset_data (t:('k1,'k2,'d) t) : unit = ObjEph.unset_data t\n let check_data (t:('k1,'k2,'d) t) : bool = ObjEph.check_data t\n let blit_data (t1:(_,_,'d) t) (t2:(_,_,'d) t) : unit = ObjEph.blit_data t1 t2\n\n let make key1 key2 data =\n let eph = create () in\n set_data eph data;\n set_key1 eph key1;\n set_key2 eph key2;\n ignore (Sys.opaque_identity key1);\n eph\n\n let query eph key1 key2 =\n match get_key1 eph with\n | None -> None\n | Some k when k == key1 ->\n begin match get_key2 eph with\n | None -> None\n | Some k when k == key2 -> get_data eph\n | Some _ -> None\n end\n | Some _ -> None\n\n module MakeSeeded\n (H1:Hashtbl.SeededHashedType)\n (H2:Hashtbl.SeededHashedType) =\n GenHashTable.MakeSeeded(struct\n type 'a container = (H1.t,H2.t,'a) t\n type t = H1.t * H2.t\n let create (k1,k2) d =\n let c = create () in\n set_data c d;\n set_key1 c k1; set_key2 c k2;\n c\n let hash seed (k1,k2) =\n H1.hash seed k1 + H2.hash seed k2 * 65599\n let equal c (k1,k2) =\n match get_key1 c, get_key2 c with\n | None, _ | _ , None -> GenHashTable.EDead\n | Some k1', Some k2' ->\n if H1.equal k1 k1' && H2.equal k2 k2'\n then GenHashTable.ETrue else GenHashTable.EFalse\n let get_data = get_data\n let get_key c =\n match get_key1 c, get_key2 c with\n | None, _ | _ , None -> None\n | Some k1', Some k2' -> Some (k1', k2')\n let set_key_data c (k1,k2) d =\n unset_data c;\n set_key1 c k1; set_key2 c k2;\n set_data c d\n let check_key c = check_key1 c && check_key2 c\n end)\n\n module Make(H1: Hashtbl.HashedType)(H2: Hashtbl.HashedType):\n (S with type key = H1.t * H2.t) =\n struct\n include MakeSeeded\n (struct\n type t = H1.t\n let equal = H1.equal\n let hash (_seed: int) x = H1.hash x\n end)\n (struct\n type t = H2.t\n let equal = H2.equal\n let hash (_seed: int) x = H2.hash x\n end)\n let create sz = create ~random:false sz\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n end\n\n module Bucket = struct\n\n type nonrec ('k1, 'k2, 'd) t = ('k1, 'k2, 'd) t list ref\n let k2_make = make\n let make () = ref []\n let add b k1 k2 d = b := k2_make k1 k2 d :: !b\n\n let test_keys k1 k2 e =\n match get_key1 e, get_key2 e with\n | Some x1, Some x2 when x1 == k1 && x2 == k2 -> true\n | _ -> false\n\n let remove b k1 k2 =\n let rec loop l acc =\n match l with\n | [] -> ()\n | h :: t when test_keys k1 k2 h -> b := List.rev_append acc t\n | h :: t -> loop t (h :: acc)\n in\n loop !b []\n\n let find b k1 k2 =\n match List.find_opt (test_keys k1 k2) !b with\n | Some e -> get_data e\n | None -> None\n\n let length b = List.length !b\n let clear b = b := []\n\n end\n\nend\n\nmodule Kn = struct\n type ('k,'d) t = ObjEph.t\n\n let create n : ('k,'d) t = ObjEph.create n\n let length (k:('k,'d) t) : int = ObjEph.length k\n\n let get_key (t:('k,'d) t) (n:int) : 'k option = obj_opt (ObjEph.get_key t n)\n let get_key_copy (t:('k,'d) t) (n:int) : 'k option =\n obj_opt (ObjEph.get_key_copy t n)\n let set_key (t:('k,'d) t) (n:int) (k:'k) : unit =\n ObjEph.set_key t n (Obj.repr k)\n let unset_key (t:('k,'d) t) (n:int) : unit = ObjEph.unset_key t n\n let check_key (t:('k,'d) t) (n:int) : bool = ObjEph.check_key t n\n\n let blit_key (t1:('k,'d) t) (o1:int) (t2:('k,'d) t) (o2:int) (l:int) : unit =\n ObjEph.blit_key t1 o1 t2 o2 l\n\n let get_data (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data t)\n let get_data_copy (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data_copy t)\n let set_data (t:('k,'d) t) (d:'d) : unit = ObjEph.set_data t (Obj.repr d)\n let unset_data (t:('k,'d) t) : unit = ObjEph.unset_data t\n let check_data (t:('k,'d) t) : bool = ObjEph.check_data t\n let blit_data (t1:(_,'d) t) (t2:(_,'d) t) : unit = ObjEph.blit_data t1 t2\n\n let make keys data =\n let l = Array.length keys in\n let eph = create l in\n set_data eph data;\n for i = 0 to l - 1 do set_key eph i keys.(i) done;\n eph\n\n let query eph keys =\n let l = length eph in\n try\n if l <> Array.length keys then raise Exit;\n for i = 0 to l - 1 do\n match get_key eph i with\n | None -> raise Exit\n | Some k when k == keys.(i) -> ()\n | Some _ -> raise Exit\n done;\n get_data eph\n with Exit -> None\n\n module MakeSeeded (H:Hashtbl.SeededHashedType) =\n GenHashTable.MakeSeeded(struct\n type 'a container = (H.t,'a) t\n type t = H.t array\n let create k d =\n let c = create (Array.length k) in\n set_data c d;\n for i=0 to Array.length k -1 do\n set_key c i k.(i);\n done;\n c\n let hash seed k =\n let h = ref 0 in\n for i=0 to Array.length k -1 do\n h := H.hash seed k.(i) * 65599 + !h;\n done;\n !h\n let equal c k =\n let len = Array.length k in\n let len' = length c in\n if len != len' then GenHashTable.EFalse\n else\n let rec equal_array k c i =\n if i < 0 then GenHashTable.ETrue\n else\n match get_key c i with\n | None -> GenHashTable.EDead\n | Some ki ->\n if H.equal k.(i) ki\n then equal_array k c (i-1)\n else GenHashTable.EFalse\n in\n equal_array k c (len-1)\n let get_data = get_data\n let get_key c =\n let len = length c in\n if len = 0 then Some [||]\n else\n match get_key c 0 with\n | None -> None\n | Some k0 ->\n let rec fill a i =\n if i < 1 then Some a\n else\n match get_key c i with\n | None -> None\n | Some ki ->\n a.(i) <- ki;\n fill a (i-1)\n in\n let a = Array.make len k0 in\n fill a (len-1)\n let set_key_data c k d =\n unset_data c;\n for i=0 to Array.length k -1 do\n set_key c i k.(i);\n done;\n set_data c d\n let check_key c =\n let rec check c i =\n i < 0 || (check_key c i && check c (i-1)) in\n check c (length c - 1)\n end)\n\n module Make(H: Hashtbl.HashedType): (S with type key = H.t array) =\n struct\n include MakeSeeded(struct\n type t = H.t\n let equal = H.equal\n let hash (_seed: int) x = H.hash x\n end)\n let create sz = create ~random:false sz\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n end\n\n module Bucket = struct\n\n type nonrec ('k, 'd) t = ('k, 'd) t list ref\n let kn_make = make\n let make () = ref []\n let add b k d = b := kn_make k d :: !b\n\n let test_keys k e =\n try\n if length e <> Array.length k then raise Exit;\n for i = 0 to Array.length k - 1 do\n match get_key e i with\n | Some x when x == k.(i) -> ()\n | _ -> raise Exit\n done;\n true\n with Exit -> false\n\n let remove b k =\n let rec loop l acc =\n match l with\n | [] -> ()\n | h :: t when test_keys k h -> b := List.rev_append acc t\n | h :: t -> loop t (h :: acc)\n in\n loop !b []\n\n let find b k =\n match List.find_opt (test_keys k) !b with\n | Some e -> get_data e\n | None -> None\n\n let length b = List.length !b\n let clear b = b := []\n\n end\n\nend\n","(* Conv_error: Module for Handling Errors during Automated S-expression\n Conversions *)\n\nopen StdLabels\nopen Printf\nopen Sexp_conv\n\nexception Of_sexp_error = Of_sexp_error\n\n(* Errors concerning tuples *)\n\nlet tuple_of_size_n_expected loc n sexp =\n of_sexp_error (sprintf \"%s_of_sexp: tuple of size %d expected\" loc n) sexp\n\n\n(* Errors concerning sum types *)\n\nlet stag_no_args loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: sum tag does not take arguments\") sexp\n\nlet stag_incorrect_n_args loc tag sexp =\n let msg =\n sprintf \"%s_of_sexp: sum tag %S has incorrect number of arguments\" loc tag\n in\n of_sexp_error msg sexp\n\nlet stag_takes_args loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: sum tag must be a structured value\") sexp\n\nlet nested_list_invalid_sum loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: a nested list is an invalid sum\") sexp\n\nlet empty_list_invalid_sum loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: the empty list is an invalid sum\") sexp\n\nlet unexpected_stag loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: unexpected sum tag\") sexp\n\n\n(* Errors concerning records *)\n\nlet record_sexp_bool_with_payload loc sexp =\n let msg =\n loc ^\n \"_of_sexp: record conversion: a [sexp.bool] field was given a payload.\" in\n of_sexp_error msg sexp\n\nlet record_only_pairs_expected loc sexp =\n let msg =\n loc ^\n \"_of_sexp: record conversion: only pairs expected, \\\n their first element must be an atom\" in\n of_sexp_error msg sexp\n\nlet record_superfluous_fields ~what ~loc rev_fld_names sexp =\n let fld_names_str = String.concat (List.rev rev_fld_names) ~sep:\" \" in\n let msg = sprintf \"%s_of_sexp: %s: %s\" loc what fld_names_str in\n of_sexp_error msg sexp\n\nlet record_duplicate_fields loc rev_fld_names sexp =\n record_superfluous_fields ~what:\"duplicate fields\" ~loc rev_fld_names sexp\n\nlet record_extra_fields loc rev_fld_names sexp =\n record_superfluous_fields ~what:\"extra fields\" ~loc rev_fld_names sexp\n\nlet rec record_get_undefined_loop fields = function\n | [] -> String.concat (List.rev fields) ~sep:\" \"\n | (true, field) :: rest -> record_get_undefined_loop (field :: fields) rest\n | _ :: rest -> record_get_undefined_loop fields rest\n\nlet record_undefined_elements loc sexp lst =\n let undefined = record_get_undefined_loop [] lst in\n let msg =\n sprintf \"%s_of_sexp: the following record elements were undefined: %s\"\n loc undefined\n in\n of_sexp_error msg sexp\n\nlet record_list_instead_atom loc sexp =\n let msg = loc ^ \"_of_sexp: list instead of atom for record expected\" in\n of_sexp_error msg sexp\n\nlet record_poly_field_value loc sexp =\n let msg =\n loc ^\n \"_of_sexp: cannot convert values of types resulting from polymorphic \\\n record fields\"\n in\n of_sexp_error msg sexp\n\n\n(* Errors concerning polymorphic variants *)\n\nexception No_variant_match\n\nlet no_variant_match () =\n raise No_variant_match\n\nlet no_matching_variant_found loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: no matching variant found\") sexp\n\nlet ptag_no_args loc sexp =\n of_sexp_error (\n loc ^ \"_of_sexp: polymorphic variant does not take arguments\") sexp\n\nlet ptag_incorrect_n_args loc cnstr sexp =\n let msg =\n sprintf\n \"%s_of_sexp: polymorphic variant tag %S has incorrect number of arguments\"\n loc cnstr\n in\n of_sexp_error msg sexp\n\nlet ptag_takes_args loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: polymorphic variant tag takes an argument\")\n sexp\n\nlet nested_list_invalid_poly_var loc sexp =\n of_sexp_error (\n loc ^ \"_of_sexp: a nested list is an invalid polymorphic variant\") sexp\n\nlet empty_list_invalid_poly_var loc sexp =\n of_sexp_error (\n loc ^ \"_of_sexp: the empty list is an invalid polymorphic variant\") sexp\n\nlet empty_type loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: trying to convert an empty type\") sexp\n","open! Import\nopen Std_internal\n\nlet randomize span ~percent ~scale =\n let mult = Percent.to_mult percent in\n if Float.( < ) mult 0. || Float.( > ) mult 1.\n then\n raise_s\n [%message \"Span.randomize: percent is out of range [0x, 1x]\" (percent : Percent.t)];\n let factor = Random.float_range (1. -. mult) (Float.one_ulp `Up (1. +. mult)) in\n scale span factor\n;;\n\nlet format_decimal n tenths units =\n assert (tenths >= 0 && tenths < 10);\n if n < 10 && tenths <> 0\n then sprintf \"%d.%d%s\" n tenths units\n else sprintf \"%d%s\" n units\n;;\n\nlet short_string ~sign ~hr ~min ~sec ~ms ~us ~ns =\n let s =\n if hr >= 24\n then format_decimal (hr / 24) (Int.of_float (Float.of_int (hr % 24) /. 2.4)) \"d\"\n else if hr > 0\n then format_decimal hr (min / 6) \"h\"\n else if min > 0\n then format_decimal min (sec / 6) \"m\"\n else if sec > 0\n then format_decimal sec (ms / 100) \"s\"\n else if ms > 0\n then format_decimal ms (us / 100) \"ms\"\n else if us > 0\n then format_decimal us (ns / 100) \"us\"\n else sprintf \"%ins\" ns\n in\n match (sign : Sign.t) with\n | Neg -> \"-\" ^ s\n | Zero | Pos -> s\n;;\n","(* This module is included in [Import]. It is aimed at modules that define the standard\n combinators for [sexp_of], [of_sexp], [compare] and [hash] and are included in\n [Import]. *)\n\ninclude (\n Shadow_stdlib :\n module type of struct\n include Shadow_stdlib\n end\n with type 'a ref := 'a ref\n with type ('a, 'b, 'c) format := ('a, 'b, 'c) format\n with type ('a, 'b, 'c, 'd) format4 := ('a, 'b, 'c, 'd) format4\n with type ('a, 'b, 'c, 'd, 'e, 'f) format6 := ('a, 'b, 'c, 'd, 'e, 'f) format6\n (* These modules are redefined in Base *)\n with module Array := Shadow_stdlib.Array\n with module Atomic := Shadow_stdlib.Atomic\n with module Bool := Shadow_stdlib.Bool\n with module Buffer := Shadow_stdlib.Buffer\n with module Bytes := Shadow_stdlib.Bytes\n with module Char := Shadow_stdlib.Char\n with module Either := Shadow_stdlib.Either\n with module Float := Shadow_stdlib.Float\n with module Hashtbl := Shadow_stdlib.Hashtbl\n with module Int := Shadow_stdlib.Int\n with module Int32 := Shadow_stdlib.Int32\n with module Int64 := Shadow_stdlib.Int64\n with module Lazy := Shadow_stdlib.Lazy\n with module List := Shadow_stdlib.List\n with module Map := Shadow_stdlib.Map\n with module Nativeint := Shadow_stdlib.Nativeint\n with module Option := Shadow_stdlib.Option\n with module Printf := Shadow_stdlib.Printf\n with module Queue := Shadow_stdlib.Queue\n with module Random := Shadow_stdlib.Random\n with module Result := Shadow_stdlib.Result\n with module Set := Shadow_stdlib.Set\n with module Stack := Shadow_stdlib.Stack\n with module String := Shadow_stdlib.String\n with module Sys := Shadow_stdlib.Sys\n with module Uchar := Shadow_stdlib.Uchar\n with module Unit := Shadow_stdlib.Unit) [@ocaml.warning \"-3\"]\n\ntype 'a ref = 'a Caml.ref = { mutable contents : 'a }\n\n(* Reshuffle [Caml] so that we choose the modules using labels when available. *)\nmodule Caml = struct\n\n module Arg = Caml.Arg (** @canonical Caml.Arg *)\n\n module Array = Caml.StdLabels.Array (** @canonical Caml.StdLabels.Array *)\n\n module Bool = Caml.Bool (** @canonical Caml.Bool *)\n\n module Buffer = Caml.Buffer (** @canonical Caml.Buffer *)\n\n module Bytes = Caml.StdLabels.Bytes (** @canonical Caml.StdLabels.Bytes *)\n\n module Char = Caml.Char (** @canonical Caml.Char *)\n\n module Ephemeron = Caml.Ephemeron (** @canonical Caml.Ephemeron *)\n\n module Float = Caml.Float (** @canonical Caml.Float *)\n\n module Format = Caml.Format (** @canonical Caml.Format *)\n\n module Fun = Caml.Fun (** @canonical Caml.Fun *)\n\n module Gc = Caml.Gc (** @canonical Caml.Gc *)\n\n module Hashtbl = Caml.MoreLabels.Hashtbl (** @canonical Caml.MoreLabels.Hashtbl *)\n\n module Int32 = Caml.Int32 (** @canonical Caml.Int32 *)\n\n module Int = Caml.Int (** @canonical Caml.Int *)\n\n module Int64 = Caml.Int64 (** @canonical Caml.Int64 *)\n\n module Lazy = Caml.Lazy (** @canonical Caml.Lazy *)\n\n module Lexing = Caml.Lexing (** @canonical Caml.Lexing *)\n\n module List = Caml.StdLabels.List (** @canonical Caml.StdLabels.List *)\n\n module Map = Caml.MoreLabels.Map (** @canonical Caml.MoreLabels.Map *)\n\n module Nativeint = Caml.Nativeint (** @canonical Caml.Nativeint *)\n\n module Obj = Caml.Obj (** @canonical Caml.Obj *)\n\n module Option = Caml.Option (** @canonical Caml.Option *)\n\n module Parsing = Caml.Parsing (** @canonical Caml.Parsing *)\n\n module Printexc = Caml.Printexc (** @canonical Caml.Printexc *)\n\n module Printf = Caml.Printf (** @canonical Caml.Printf *)\n\n module Queue = Caml.Queue (** @canonical Caml.Queue *)\n\n module Random = Caml.Random (** @canonical Caml.Random *)\n\n module Result = Caml.Result (** @canonical Caml.Result *)\n\n module Scanf = Caml.Scanf (** @canonical Caml.Scanf *)\n\n module Seq = Caml.Seq (** @canonical Caml.Seq *)\n\n module Set = Caml.MoreLabels.Set (** @canonical Caml.MoreLabels.Set *)\n\n module Stack = Caml.Stack (** @canonical Caml.Stack *)\n\n module Stream = Caml.Stream [@ocaml.warning \"-3\"] (** @canonical Caml.Stream *)\n\n module String = Caml.StdLabels.String (** @canonical Caml.StdLabels.String *)\n\n module Sys = Caml.Sys (** @canonical Caml.Sys *)\n\n module Uchar = Caml.Uchar (** @canonical Caml.Uchar *)\n\n module Unit = Caml.Unit (** @canonical Caml.Unit *)\n\n include Pervasives [@ocaml.warning \"-3\"]\n\n exception Not_found = Caml.Not_found\nend\n\nexternal ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\n\n(* These need to be declared as an external to get the lazy behavior *)\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\nexternal ( || ) : bool -> bool -> bool = \"%sequor\"\nexternal not : bool -> bool = \"%boolnot\"\n\n(* We use [Obj.magic] here as other implementations generate a conditional jump and the\n performance difference is noticeable. *)\nlet bool_to_int (x : bool) : int = Caml.Obj.magic x\n\n(* This need to be declared as an external for the warnings to work properly *)\nexternal ignore : _ -> unit = \"%ignore\"\n\nlet ( != ) = Caml.( != )\nlet ( * ) = Caml.( * )\nlet ( ** ) = Caml.( ** )\nlet ( *. ) = Caml.( *. )\nlet ( + ) = Caml.( + )\nlet ( +. ) = Caml.( +. )\nlet ( - ) = Caml.( - )\nlet ( -. ) = Caml.( -. )\nlet ( / ) = Caml.( / )\nlet ( /. ) = Caml.( /. )\n\nmodule Poly = Poly0 (** @canonical Base.Poly *)\n\nmodule Int_replace_polymorphic_compare = struct\n let ( < ) (x : int) y = Poly.( < ) x y\n let ( <= ) (x : int) y = Poly.( <= ) x y\n let ( <> ) (x : int) y = Poly.( <> ) x y\n let ( = ) (x : int) y = Poly.( = ) x y\n let ( > ) (x : int) y = Poly.( > ) x y\n let ( >= ) (x : int) y = Poly.( >= ) x y\n let compare (x : int) y = bool_to_int (x > y) - bool_to_int (x < y)\n let ascending (x : int) y = compare x y\n let descending (x : int) y = compare y x\n let equal (x : int) y = Poly.equal x y\n let max (x : int) y = if x >= y then x else y\n let min (x : int) y = if x <= y then x else y\nend\n\ninclude Int_replace_polymorphic_compare\n\nmodule Int32_replace_polymorphic_compare = struct\n let ( < ) (x : Caml.Int32.t) y = Poly.( < ) x y\n let ( <= ) (x : Caml.Int32.t) y = Poly.( <= ) x y\n let ( <> ) (x : Caml.Int32.t) y = Poly.( <> ) x y\n let ( = ) (x : Caml.Int32.t) y = Poly.( = ) x y\n let ( > ) (x : Caml.Int32.t) y = Poly.( > ) x y\n let ( >= ) (x : Caml.Int32.t) y = Poly.( >= ) x y\n let ascending (x : Caml.Int32.t) y = Poly.ascending x y\n let descending (x : Caml.Int32.t) y = Poly.descending x y\n let compare (x : Caml.Int32.t) y = Poly.compare x y\n let equal (x : Caml.Int32.t) y = Poly.equal x y\n let max (x : Caml.Int32.t) y = if x >= y then x else y\n let min (x : Caml.Int32.t) y = if x <= y then x else y\nend\n\nmodule Int64_replace_polymorphic_compare = struct\n let ( < ) (x : Caml.Int64.t) y = Poly.( < ) x y\n let ( <= ) (x : Caml.Int64.t) y = Poly.( <= ) x y\n let ( <> ) (x : Caml.Int64.t) y = Poly.( <> ) x y\n let ( = ) (x : Caml.Int64.t) y = Poly.( = ) x y\n let ( > ) (x : Caml.Int64.t) y = Poly.( > ) x y\n let ( >= ) (x : Caml.Int64.t) y = Poly.( >= ) x y\n let ascending (x : Caml.Int64.t) y = Poly.ascending x y\n let descending (x : Caml.Int64.t) y = Poly.descending x y\n let compare (x : Caml.Int64.t) y = Poly.compare x y\n let equal (x : Caml.Int64.t) y = Poly.equal x y\n let max (x : Caml.Int64.t) y = if x >= y then x else y\n let min (x : Caml.Int64.t) y = if x <= y then x else y\nend\n\nmodule Nativeint_replace_polymorphic_compare = struct\n let ( < ) (x : Caml.Nativeint.t) y = Poly.( < ) x y\n let ( <= ) (x : Caml.Nativeint.t) y = Poly.( <= ) x y\n let ( <> ) (x : Caml.Nativeint.t) y = Poly.( <> ) x y\n let ( = ) (x : Caml.Nativeint.t) y = Poly.( = ) x y\n let ( > ) (x : Caml.Nativeint.t) y = Poly.( > ) x y\n let ( >= ) (x : Caml.Nativeint.t) y = Poly.( >= ) x y\n let ascending (x : Caml.Nativeint.t) y = Poly.ascending x y\n let descending (x : Caml.Nativeint.t) y = Poly.descending x y\n let compare (x : Caml.Nativeint.t) y = Poly.compare x y\n let equal (x : Caml.Nativeint.t) y = Poly.equal x y\n let max (x : Caml.Nativeint.t) y = if x >= y then x else y\n let min (x : Caml.Nativeint.t) y = if x <= y then x else y\nend\n\nmodule Bool_replace_polymorphic_compare = struct\n let ( < ) (x : bool) y = Poly.( < ) x y\n let ( <= ) (x : bool) y = Poly.( <= ) x y\n let ( <> ) (x : bool) y = Poly.( <> ) x y\n let ( = ) (x : bool) y = Poly.( = ) x y\n let ( > ) (x : bool) y = Poly.( > ) x y\n let ( >= ) (x : bool) y = Poly.( >= ) x y\n let ascending (x : bool) y = Poly.ascending x y\n let descending (x : bool) y = Poly.descending x y\n let compare (x : bool) y = Poly.compare x y\n let equal (x : bool) y = Poly.equal x y\n let max (x : bool) y = if x >= y then x else y\n let min (x : bool) y = if x <= y then x else y\nend\n\nmodule Char_replace_polymorphic_compare = struct\n let ( < ) (x : char) y = Poly.( < ) x y\n let ( <= ) (x : char) y = Poly.( <= ) x y\n let ( <> ) (x : char) y = Poly.( <> ) x y\n let ( = ) (x : char) y = Poly.( = ) x y\n let ( > ) (x : char) y = Poly.( > ) x y\n let ( >= ) (x : char) y = Poly.( >= ) x y\n let ascending (x : char) y = Poly.ascending x y\n let descending (x : char) y = Poly.descending x y\n let compare (x : char) y = Poly.compare x y\n let equal (x : char) y = Poly.equal x y\n let max (x : char) y = if x >= y then x else y\n let min (x : char) y = if x <= y then x else y\nend\n\nmodule Uchar_replace_polymorphic_compare = struct\n let i x = Caml.Uchar.to_int x\n let ( < ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( < ) (i x) (i y)\n let ( <= ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( <= ) (i x) (i y)\n let ( <> ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( <> ) (i x) (i y)\n let ( = ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( = ) (i x) (i y)\n let ( > ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( > ) (i x) (i y)\n let ( >= ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( >= ) (i x) (i y)\n\n let ascending (x : Caml.Uchar.t) y =\n Int_replace_polymorphic_compare.ascending (i x) (i y)\n ;;\n\n let descending (x : Caml.Uchar.t) y =\n Int_replace_polymorphic_compare.descending (i x) (i y)\n ;;\n\n let compare (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.compare (i x) (i y)\n let equal (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.equal (i x) (i y)\n let max (x : Caml.Uchar.t) y = if x >= y then x else y\n let min (x : Caml.Uchar.t) y = if x <= y then x else y\nend\n\nmodule Float_replace_polymorphic_compare = struct\n let ( < ) (x : float) y = Poly.( < ) x y\n let ( <= ) (x : float) y = Poly.( <= ) x y\n let ( <> ) (x : float) y = Poly.( <> ) x y\n let ( = ) (x : float) y = Poly.( = ) x y\n let ( > ) (x : float) y = Poly.( > ) x y\n let ( >= ) (x : float) y = Poly.( >= ) x y\n let ascending (x : float) y = Poly.ascending x y\n let descending (x : float) y = Poly.descending x y\n let compare (x : float) y = Poly.compare x y\n let equal (x : float) y = Poly.equal x y\n let max (x : float) y = if x >= y then x else y\n let min (x : float) y = if x <= y then x else y\nend\n\nmodule String_replace_polymorphic_compare = struct\n let ( < ) (x : string) y = Poly.( < ) x y\n let ( <= ) (x : string) y = Poly.( <= ) x y\n let ( <> ) (x : string) y = Poly.( <> ) x y\n let ( = ) (x : string) y = Poly.( = ) x y\n let ( > ) (x : string) y = Poly.( > ) x y\n let ( >= ) (x : string) y = Poly.( >= ) x y\n let ascending (x : string) y = Poly.ascending x y\n let descending (x : string) y = Poly.descending x y\n let compare (x : string) y = Poly.compare x y\n let equal (x : string) y = Poly.equal x y\n let max (x : string) y = if x >= y then x else y\n let min (x : string) y = if x <= y then x else y\nend\n\nmodule Bytes_replace_polymorphic_compare = struct\n let ( < ) (x : bytes) y = Poly.( < ) x y\n let ( <= ) (x : bytes) y = Poly.( <= ) x y\n let ( <> ) (x : bytes) y = Poly.( <> ) x y\n let ( = ) (x : bytes) y = Poly.( = ) x y\n let ( > ) (x : bytes) y = Poly.( > ) x y\n let ( >= ) (x : bytes) y = Poly.( >= ) x y\n let ascending (x : bytes) y = Poly.ascending x y\n let descending (x : bytes) y = Poly.descending x y\n let compare (x : bytes) y = Poly.compare x y\n let equal (x : bytes) y = Poly.equal x y\n let max (x : bytes) y = if x >= y then x else y\n let min (x : bytes) y = if x <= y then x else y\nend\n\n(* This needs to be defined as an external so that the compiler can specialize it as a\n direct set or caml_modify *)\nexternal ( := ) : 'a ref -> 'a -> unit = \"%setfield0\"\n\n(* These need to be defined as an external otherwise the compiler won't unbox\n references *)\nexternal ( ! ) : 'a ref -> 'a = \"%field0\"\nexternal ref : 'a -> 'a ref = \"%makemutable\"\n\nlet ( @ ) = Caml.( @ )\nlet ( ^ ) = Caml.( ^ )\nlet ( ~- ) = Caml.( ~- )\nlet ( ~-. ) = Caml.( ~-. )\nlet ( asr ) = Caml.( asr )\nlet ( land ) = Caml.( land )\nlet lnot = Caml.lnot\nlet ( lor ) = Caml.( lor )\nlet ( lsl ) = Caml.( lsl )\nlet ( lsr ) = Caml.( lsr )\nlet ( lxor ) = Caml.( lxor )\nlet ( mod ) = Caml.( mod )\nlet abs = Caml.abs\nlet failwith = Caml.failwith\nlet fst = Caml.fst\nlet invalid_arg = Caml.invalid_arg\nlet snd = Caml.snd\n\n(* [raise] needs to be defined as an external as the compiler automatically replaces\n '%raise' by '%reraise' when appropriate. *)\nexternal raise : exn -> _ = \"%raise\"\n\nlet phys_equal = Caml.( == )\nlet decr = Caml.decr\nlet incr = Caml.incr\n\n(* used by sexp_conv, which float0 depends on through option *)\nlet float_of_string = Caml.float_of_string\n\n(* [am_testing] is used in a few places to behave differently when in testing mode, such\n as in [random.ml]. [am_testing] is implemented using [Base_am_testing], a weak C/js\n primitive that returns [false], but when linking an inline-test-runner executable, is\n overridden by another primitive that returns [true]. *)\nexternal am_testing : unit -> bool = \"Base_am_testing\"\n\nlet am_testing = am_testing ()\n","open! Import0\ninclude Caml.Printf\n\n(** failwith, invalid_arg, and exit accepting printf's format. *)\n\nlet failwithf fmt = ksprintf (fun s () -> failwith s) fmt\nlet invalid_argf fmt = ksprintf (fun s () -> invalid_arg s) fmt\n","(* [Array0] defines array functions that are primitives or can be simply defined in terms\n of [Caml.Array]. [Array0] is intended to completely express the part of [Caml.Array]\n that [Base] uses -- no other file in Base other than array0.ml should use [Caml.Array].\n [Array0] has few dependencies, and so is available early in Base's build order. All\n Base files that need to use arrays and come before [Base.Array] in build order should\n do [module Array = Array0]. This includes uses of subscript syntax ([x.(i)], [x.(i) <-\n e]), which the OCaml parser desugars into calls to [Array.get] and [Array.set].\n Defining [module Array = Array0] is also necessary because it prevents ocamldep from\n mistakenly causing a file to depend on [Base.Array]. *)\n\nopen! Import0\nmodule Sys = Sys0\n\nlet invalid_argf = Printf.invalid_argf\n\nmodule Array = struct\n external create : int -> 'a -> 'a array = \"caml_make_vect\"\n external get : 'a array -> int -> 'a = \"%array_safe_get\"\n external length : 'a array -> int = \"%array_length\"\n external set : 'a array -> int -> 'a -> unit = \"%array_safe_set\"\n external unsafe_get : 'a array -> int -> 'a = \"%array_unsafe_get\"\n external unsafe_set : 'a array -> int -> 'a -> unit = \"%array_unsafe_set\"\nend\n\ninclude Array\n\nlet max_length = Sys.max_array_length\n\nlet create ~len x =\n try create len x with\n | Invalid_argument _ -> invalid_argf \"Array.create ~len:%d: invalid length\" len ()\n;;\n\nlet append = Caml.Array.append\nlet blit = Caml.Array.blit\nlet concat = Caml.Array.concat\nlet copy = Caml.Array.copy\nlet fill = Caml.Array.fill\nlet init = Caml.Array.init\nlet make_matrix = Caml.Array.make_matrix\nlet of_list = Caml.Array.of_list\nlet sub = Caml.Array.sub\nlet to_list = Caml.Array.to_list\n\n(* These are eta expanded in order to permute parameter order to follow Base\n conventions. *)\nlet fold t ~init ~f = Caml.Array.fold_left t ~init ~f\nlet fold_right t ~f ~init = Caml.Array.fold_right t ~f ~init\nlet iter t ~f = Caml.Array.iter t ~f\nlet iteri t ~f = Caml.Array.iteri t ~f\nlet map t ~f = Caml.Array.map t ~f\nlet mapi t ~f = Caml.Array.mapi t ~f\nlet stable_sort t ~compare = Caml.Array.stable_sort t ~cmp:compare\n\nlet swap t i j =\n let tmp = t.(i) in\n t.(i) <- t.(j);\n t.(j) <- tmp\n;;\n","(* [Char0] defines char functions that are primitives or can be simply defined in terms of\n [Caml.Char]. [Char0] is intended to completely express the part of [Caml.Char] that\n [Base] uses -- no other file in Base other than char0.ml should use [Caml.Char].\n [Char0] has few dependencies, and so is available early in Base's build order. All\n Base files that need to use chars and come before [Base.Char] in build order should do\n [module Char = Char0]. Defining [module Char = Char0] is also necessary because it\n prevents ocamldep from mistakenly causing a file to depend on [Base.Char]. *)\n\nopen! Import0\n\nlet failwithf = Printf.failwithf\nlet escaped = Caml.Char.escaped\nlet lowercase = Caml.Char.lowercase_ascii\nlet to_int = Caml.Char.code\nlet unsafe_of_int = Caml.Char.unsafe_chr\nlet uppercase = Caml.Char.uppercase_ascii\n\n(* We use our own range test when converting integers to chars rather than\n calling [Caml.Char.chr] because it's simple and it saves us a function call\n and the try-with (exceptions cost, especially in the world with backtraces). *)\nlet int_is_ok i = 0 <= i && i <= 255\nlet min_value = unsafe_of_int 0\nlet max_value = unsafe_of_int 255\nlet of_int i = if int_is_ok i then Some (unsafe_of_int i) else None\n\nlet of_int_exn i =\n if int_is_ok i\n then unsafe_of_int i\n else failwithf \"Char.of_int_exn got integer out of range: %d\" i ()\n;;\n\nlet equal (t1 : char) t2 = Poly.equal t1 t2\n","(* [List0] defines list functions that are primitives or can be simply defined in terms of\n [Caml.List]. [List0] is intended to completely express the part of [Caml.List] that\n [Base] uses -- no other file in Base other than list0.ml should use [Caml.List].\n [List0] has few dependencies, and so is available early in Base's build order. All\n Base files that need to use lists and come before [Base.List] in build order should do\n [module List = List0]. Defining [module List = List0] is also necessary because it\n prevents ocamldep from mistakenly causing a file to depend on [Base.List]. *)\n\nopen! Import0\n\nlet hd_exn = Caml.List.hd\nlet length = Caml.List.length\nlet rev_append = Caml.List.rev_append\nlet tl_exn = Caml.List.tl\nlet unzip = Caml.List.split\n\n(* These are eta expanded in order to permute parameter order to follow Base\n conventions. *)\nlet exists t ~f = Caml.List.exists t ~f\nlet exists2_ok l1 l2 ~f = Caml.List.exists2 l1 l2 ~f\nlet fold t ~init ~f = Caml.List.fold_left t ~f ~init\nlet fold2_ok l1 l2 ~init ~f = Caml.List.fold_left2 l1 l2 ~init ~f\nlet for_all t ~f = Caml.List.for_all t ~f\nlet for_all2_ok l1 l2 ~f = Caml.List.for_all2 l1 l2 ~f\nlet iter t ~f = Caml.List.iter t ~f\nlet iter2_ok l1 l2 ~f = Caml.List.iter2 l1 l2 ~f\nlet nontail_map t ~f = Caml.List.map t ~f\nlet nontail_mapi t ~f = Caml.List.mapi t ~f\nlet partition t ~f = Caml.List.partition t ~f\nlet rev_map t ~f = Caml.List.rev_map t ~f\nlet rev_map2_ok l1 l2 ~f = Caml.List.rev_map2 l1 l2 ~f\nlet sort l ~compare = Caml.List.sort l ~cmp:compare\nlet stable_sort l ~compare = Caml.List.stable_sort l ~cmp:compare\n\nlet rev = function\n | ([] | [ _ ]) as res -> res\n | x :: y :: rest -> rev_append rest [ y; x ]\n;;\n","open Core_kernel\n\nmodule type S = sig\n type 'a t = private 'a list\n\n include Container.S1 with type 'a t := 'a t\n\n val of_list : 'a list -> 'a t\n\n val init : int -> f:(int -> 'a) -> 'a t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val pad : padding_length:int -> zero:'a -> 'a t -> 'a t\nend\n\nmodule T = struct\n include List\n\n let of_list = Fn.id\nend\n\nmodule Msb_first = struct\n include T\n\n let of_lsb_first = List.rev\n\n let pad ~padding_length ~zero xs =\n List.init padding_length ~f:(fun _ -> zero) @ xs\nend\n\nmodule Lsb_first = struct\n include T\n\n let of_msb_first = List.rev\n\n let pad ~padding_length ~zero xs =\n xs @ List.init padding_length ~f:(fun _ -> zero)\nend\n\nlet pad_to_triple_list ~default xs =\n let rec go acc = function\n | [] ->\n List.rev acc\n | [ x1 ] ->\n List.rev ((x1, default, default) :: acc)\n | [ x1; x2 ] ->\n List.rev ((x1, x2, default) :: acc)\n | x1 :: x2 :: x3 :: xs ->\n go ((x1, x2, x3) :: acc) xs\n in\n go [] xs\n","(*\n This is the interface to the runtime support for [ppx_hash].\n\n The [ppx_hash] syntax extension supports: [@@deriving hash] and [%hash_fold: TYPE] and\n [%hash: TYPE]\n\n For type [t] a function [hash_fold_t] of type [Hash.state -> t -> Hash.state] is\n generated.\n\n The generated [hash_fold_] function is compositional, following the structure of the\n type; allowing user overrides at every level. This is in contrast to ocaml's builtin\n polymorphic hashing [Hashtbl.hash] which ignores user overrides.\n\n The generator also provides a direct hash-function [hash] (named [hash_] when !=\n \"t\") of type: [t -> Hash.hash_value].\n\n The folding hash function can be accessed as [%hash_fold: TYPE]\n The direct hash function can be accessed as [%hash: TYPE]\n*)\n\nopen! Import0\nmodule Array = Array0\nmodule Char = Char0\nmodule Int = Int0\nmodule List = List0\ninclude Hash_intf\n\n(** Builtin folding-style hash functions, abstracted over [Hash_intf.S] *)\nmodule Folding (Hash : Hash_intf.S) :\n Hash_intf.Builtin_intf\n with type state = Hash.state\n and type hash_value = Hash.hash_value = struct\n type state = Hash.state\n type hash_value = Hash.hash_value\n type 'a folder = state -> 'a -> state\n\n let hash_fold_unit s () = s\n let hash_fold_int = Hash.fold_int\n let hash_fold_int64 = Hash.fold_int64\n let hash_fold_float = Hash.fold_float\n let hash_fold_string = Hash.fold_string\n let as_int f s x = hash_fold_int s (f x)\n\n (* This ignores the sign bit on 32-bit architectures, but it's unlikely to lead to\n frequent collisions (min_value colliding with 0 is the most likely one). *)\n let hash_fold_int32 = as_int Caml.Int32.to_int\n let hash_fold_char = as_int Char.to_int\n\n let hash_fold_bool =\n as_int (function\n | true -> 1\n | false -> 0)\n ;;\n\n let hash_fold_nativeint s x = hash_fold_int64 s (Caml.Int64.of_nativeint x)\n\n let hash_fold_option hash_fold_elem s = function\n | None -> hash_fold_int s 0\n | Some x -> hash_fold_elem (hash_fold_int s 1) x\n ;;\n\n let rec hash_fold_list_body hash_fold_elem s list =\n match list with\n | [] -> s\n | x :: xs -> hash_fold_list_body hash_fold_elem (hash_fold_elem s x) xs\n ;;\n\n let hash_fold_list hash_fold_elem s list =\n (* The [length] of the list must be incorporated into the hash-state so values of\n types such as [unit list] - ([], [()], [();()],..) are hashed differently. *)\n (* The [length] must come before the elements to avoid a violation of the rule\n enforced by Perfect_hash. *)\n let s = hash_fold_int s (List.length list) in\n let s = hash_fold_list_body hash_fold_elem s list in\n s\n ;;\n\n let hash_fold_lazy_t hash_fold_elem s x = hash_fold_elem s (Caml.Lazy.force x)\n let hash_fold_ref_frozen hash_fold_elem s x = hash_fold_elem s !x\n\n let rec hash_fold_array_frozen_i hash_fold_elem s array i =\n if i = Array.length array\n then s\n else (\n let e = Array.unsafe_get array i in\n hash_fold_array_frozen_i hash_fold_elem (hash_fold_elem s e) array (i + 1))\n ;;\n\n let hash_fold_array_frozen hash_fold_elem s array =\n hash_fold_array_frozen_i\n (* [length] must be incorporated for arrays, as it is for lists. See comment above *)\n hash_fold_elem\n (hash_fold_int s (Array.length array))\n array\n 0\n ;;\n\n (* the duplication here is because we think\n ocaml can't eliminate indirect function calls otherwise. *)\n let hash_nativeint x =\n Hash.get_hash_value (hash_fold_nativeint (Hash.reset (Hash.alloc ())) x)\n ;;\n\n let hash_int64 x = Hash.get_hash_value (hash_fold_int64 (Hash.reset (Hash.alloc ())) x)\n let hash_int32 x = Hash.get_hash_value (hash_fold_int32 (Hash.reset (Hash.alloc ())) x)\n let hash_char x = Hash.get_hash_value (hash_fold_char (Hash.reset (Hash.alloc ())) x)\n let hash_int x = Hash.get_hash_value (hash_fold_int (Hash.reset (Hash.alloc ())) x)\n let hash_bool x = Hash.get_hash_value (hash_fold_bool (Hash.reset (Hash.alloc ())) x)\n\n let hash_string x =\n Hash.get_hash_value (hash_fold_string (Hash.reset (Hash.alloc ())) x)\n ;;\n\n let hash_float x = Hash.get_hash_value (hash_fold_float (Hash.reset (Hash.alloc ())) x)\n let hash_unit x = Hash.get_hash_value (hash_fold_unit (Hash.reset (Hash.alloc ())) x)\nend\n\nmodule F (Hash : Hash_intf.S) :\n Hash_intf.Full\n with type hash_value = Hash.hash_value\n and type state = Hash.state\n and type seed = Hash.seed = struct\n include Hash\n\n type 'a folder = state -> 'a -> state\n\n let create ?seed () = reset ?seed (alloc ())\n let of_fold hash_fold_t t = get_hash_value (hash_fold_t (create ()) t)\n\n module Builtin = Folding (Hash)\n\n let run ?seed folder x =\n Hash.get_hash_value (folder (Hash.reset ?seed (Hash.alloc ())) x)\n ;;\nend\n\nmodule Internalhash : sig\n include\n Hash_intf.S\n with type state = Base_internalhash_types.state\n (* We give a concrete type for [state], albeit only partially exposed (see\n Base_internalhash_types), so that it unifies with the same type in [Base_boot],\n and to allow optimizations for the immediate type. *)\n and type seed = Base_internalhash_types.seed\n and type hash_value = Base_internalhash_types.hash_value\n\n external fold_int64 : state -> int64 -> state = \"Base_internalhash_fold_int64\"\n [@@noalloc]\n\n external fold_int : state -> int -> state = \"Base_internalhash_fold_int\" [@@noalloc]\n\n external fold_float : state -> float -> state = \"Base_internalhash_fold_float\"\n [@@noalloc]\n\n external fold_string : state -> string -> state = \"Base_internalhash_fold_string\"\n [@@noalloc]\n\n external get_hash_value : state -> hash_value = \"Base_internalhash_get_hash_value\"\n [@@noalloc]\nend = struct\n let description = \"internalhash\"\n\n include Base_internalhash_types\n\n let alloc () = create_seeded 0\n let reset ?(seed = 0) _t = create_seeded seed\n\n module For_tests = struct\n let compare_state (a : state) (b : state) = compare (a :> int) (b :> int)\n let state_to_string (state : state) = Int.to_string (state :> int)\n end\nend\n\nmodule T = struct\n include Internalhash\n\n type 'a folder = state -> 'a -> state\n\n let create ?seed () = reset ?seed (alloc ())\n let run ?seed folder x = get_hash_value (folder (reset ?seed (alloc ())) x)\n let of_fold hash_fold_t t = get_hash_value (hash_fold_t (create ()) t)\n\n module Builtin = struct\n module Folding = Folding (Internalhash)\n\n include (\n Folding :\n Hash_intf.Builtin_hash_fold_intf\n with type state := state\n and type 'a folder := 'a folder)\n\n let hash_nativeint = Folding.hash_nativeint\n let hash_int64 = Folding.hash_int64\n let hash_int32 = Folding.hash_int32\n let hash_string = Folding.hash_string\n\n (* [Folding] provides some default implementations for the [hash_*] functions below,\n but they are inefficient for some use-cases because of the use of the [hash_fold]\n functions. At this point, the [hash_value] type has been fixed to [int], so this\n module can provide specialized implementations. *)\n\n let hash_char = Char0.to_int\n\n (* This hash was chosen from here: https://gist.github.com/badboy/6267743\n\n It attempts to fulfill the primary goals of a non-cryptographic hash function:\n\n - a bit change in the input should change ~1/2 of the output bits\n - the output should be uniformly distributed across the output range\n - inputs that are close to each other shouldn't lead to outputs that are close to\n each other.\n - all bits of the input are used in generating the output\n\n In our case we also want it to be fast, non-allocating, and inlinable. *)\n let[@inline always] hash_int (t : int) =\n let t = lnot t + (t lsl 21) in\n let t = t lxor (t lsr 24) in\n let t = t + (t lsl 3) + (t lsl 8) in\n let t = t lxor (t lsr 14) in\n let t = t + (t lsl 2) + (t lsl 4) in\n let t = t lxor (t lsr 28) in\n t + (t lsl 31)\n ;;\n\n let hash_bool x = if x then 1 else 0\n\n external hash_float : float -> int = \"Base_hash_double\" [@@noalloc]\n\n let hash_unit () = 0\n end\nend\n\ninclude T\n","open Import0\n\nlet phys_equal = phys_equal\n\nexternal polymorphic_compare : 'a -> 'a -> int = \"%compare\"\nexternal polymorphic_equal : 'a -> 'a -> bool = \"%equal\"\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\n\nlet compare_abstract ~type_name _ _ =\n Printf.ksprintf\n failwith\n \"Compare called on the type %s, which is abstract in an implementation.\"\n type_name\n;;\n\nlet equal_abstract ~type_name _ _ =\n Printf.ksprintf\n failwith\n \"Equal called on the type %s, which is abstract in an implementation.\"\n type_name\n;;\n\ntype 'a compare = 'a -> 'a -> int\ntype 'a equal = 'a -> 'a -> bool\n\nmodule Builtin = struct\n let compare_bool : bool compare = Poly.compare\n let compare_char : char compare = Poly.compare\n let compare_float : float compare = Poly.compare\n let compare_int : int compare = Poly.compare\n let compare_int32 : int32 compare = Poly.compare\n let compare_int64 : int64 compare = Poly.compare\n let compare_nativeint : nativeint compare = Poly.compare\n let compare_string : string compare = Poly.compare\n let compare_unit : unit compare = Poly.compare\n\n let compare_array compare_elt a b =\n if phys_equal a b\n then 0\n else (\n let len_a = Array0.length a in\n let len_b = Array0.length b in\n let ret = compare len_a len_b in\n if ret <> 0\n then ret\n else (\n let rec loop i =\n if i = len_a\n then 0\n else (\n let l = Array0.unsafe_get a i\n and r = Array0.unsafe_get b i in\n let res = compare_elt l r in\n if res <> 0 then res else loop (i + 1))\n in\n loop 0))\n ;;\n\n let rec compare_list compare_elt a b =\n match a, b with\n | [], [] -> 0\n | [], _ -> -1\n | _, [] -> 1\n | x :: xs, y :: ys ->\n let res = compare_elt x y in\n if res <> 0 then res else compare_list compare_elt xs ys\n ;;\n\n let compare_option compare_elt a b =\n match a, b with\n | None, None -> 0\n | None, Some _ -> -1\n | Some _, None -> 1\n | Some a, Some b -> compare_elt a b\n ;;\n\n let compare_ref compare_elt a b = compare_elt !a !b\n let equal_bool : bool equal = Poly.equal\n let equal_char : char equal = Poly.equal\n let equal_int : int equal = Poly.equal\n let equal_int32 : int32 equal = Poly.equal\n let equal_int64 : int64 equal = Poly.equal\n let equal_nativeint : nativeint equal = Poly.equal\n let equal_string : string equal = Poly.equal\n let equal_unit : unit equal = Poly.equal\n\n (* [Poly.equal] is IEEE compliant, which is not what we want here. *)\n let equal_float x y = equal_int (compare_float x y) 0\n\n let equal_array equal_elt a b =\n phys_equal a b\n ||\n let len_a = Array0.length a in\n let len_b = Array0.length b in\n equal len_a len_b\n &&\n let rec loop i =\n i = len_a\n ||\n let l = Array0.unsafe_get a i\n and r = Array0.unsafe_get b i in\n equal_elt l r && loop (i + 1)\n in\n loop 0\n ;;\n\n let rec equal_list equal_elt a b =\n match a, b with\n | [], [] -> true\n | [], _ | _, [] -> false\n | x :: xs, y :: ys -> equal_elt x y && equal_list equal_elt xs ys\n ;;\n\n let equal_option equal_elt a b =\n match a, b with\n | None, None -> true\n | None, Some _ | Some _, None -> false\n | Some a, Some b -> equal_elt a b\n ;;\n\n let equal_ref equal_elt a b = equal_elt !a !b\nend\n","(* [String0] defines string functions that are primitives or can be simply defined in\n terms of [Caml.String]. [String0] is intended to completely express the part of\n [Caml.String] that [Base] uses -- no other file in Base other than string0.ml should\n use [Caml.String]. [String0] has few dependencies, and so is available early in Base's\n build order.\n\n All Base files that need to use strings, including the subscript syntax\n [x.(i)] or [x.(i) <- e] which the OCaml parser desugars into calls to\n [String], and come before [Base.String] in build order should do\n\n {[\n module String = String0\n ]}\n\n Defining [module String = String0] is also necessary because it prevents\n ocamldep from mistakenly causing a file to depend on [Base.String]. *)\n\nopen! Import0\nmodule Sys = Sys0\n\nmodule String = struct\n external get : string -> int -> char = \"%string_safe_get\"\n external length : string -> int = \"%string_length\"\n external unsafe_get : string -> int -> char = \"%string_unsafe_get\"\n\n include Bytes_set_primitives\nend\n\ninclude String\n\nlet max_length = Sys.max_string_length\nlet ( ^ ) = ( ^ )\nlet capitalize = Caml.String.capitalize_ascii\nlet compare = Caml.String.compare\nlet[@warning \"-3\"] copy = Caml.String.copy\nlet escaped = Caml.String.escaped\nlet lowercase = Caml.String.lowercase_ascii\nlet make = Caml.String.make\nlet sub = Caml.String.sub\nlet uncapitalize = Caml.String.uncapitalize_ascii\nlet unsafe_blit = Caml.String.unsafe_blit\nlet uppercase = Caml.String.uppercase_ascii\n\nlet concat ?(sep = \"\") l =\n match l with\n | [] -> \"\"\n (* The stdlib does not specialize this case because it could break existing projects. *)\n | [ x ] -> x\n | l -> Caml.String.concat ~sep l\n;;\n\n(* These are eta expanded in order to permute parameter order to follow Base\n conventions. *)\nlet iter t ~f = Caml.String.iter t ~f\n","open Hash.Builtin\nopen Ppx_compare_lib.Builtin\nmodule List = List0\nmodule String = String0\ninclude (Sexplib0.Sexp : module type of Sexplib0.Sexp with type t := Sexplib0.Sexp.t)\n\n(** Type of S-expressions *)\ntype t = Sexplib0.Sexp.t =\n | Atom of string\n | List of t list\n[@@deriving_inline compare, hash]\n\nlet rec compare =\n (fun a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match a__001_, b__002_ with\n | Atom _a__003_, Atom _b__004_ -> compare_string _a__003_ _b__004_\n | Atom _, _ -> -1\n | _, Atom _ -> 1\n | List _a__005_, List _b__006_ -> compare_list compare _a__005_ _b__006_)\n : t -> t -> int)\n;;\n\nlet rec (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n (fun hsv arg ->\n match arg with\n | Atom _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 0 in\n let hsv = hsv in\n hash_fold_string hsv _a0\n | List _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 1 in\n let hsv = hsv in\n hash_fold_list hash_fold_t hsv _a0\n : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state)\n\nand (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func arg =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (let hsv = Ppx_hash_lib.Std.Hash.create () in\n hash_fold_t hsv arg)\n in\n fun x -> func x\n;;\n\n[@@@end]\n\nlet of_string = ()\nlet invariant (_ : t) = ()\n","open! Import\ninclude Sexplib0.Sexpable\n\nmodule Of_sexpable\n (Sexpable : S) (M : sig\n type t\n\n val to_sexpable : t -> Sexpable.t\n val of_sexpable : Sexpable.t -> t\n end) : S with type t := M.t = struct\n let t_of_sexp sexp =\n let s = Sexpable.t_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t t = Sexpable.sexp_of_t (M.to_sexpable t)\nend\n\nmodule Of_sexpable1\n (Sexpable : S1) (M : sig\n type 'a t\n\n val to_sexpable : 'a t -> 'a Sexpable.t\n val of_sexpable : 'a Sexpable.t -> 'a t\n end) : S1 with type 'a t := 'a M.t = struct\n let t_of_sexp a_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a t = Sexpable.sexp_of_t sexp_of_a (M.to_sexpable t)\nend\n\nmodule Of_sexpable2\n (Sexpable : S2) (M : sig\n type ('a, 'b) t\n\n val to_sexpable : ('a, 'b) t -> ('a, 'b) Sexpable.t\n val of_sexpable : ('a, 'b) Sexpable.t -> ('a, 'b) t\n end) : S2 with type ('a, 'b) t := ('a, 'b) M.t = struct\n let t_of_sexp a_of_sexp b_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp b_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a sexp_of_b t =\n Sexpable.sexp_of_t sexp_of_a sexp_of_b (M.to_sexpable t)\n ;;\nend\n\nmodule Of_sexpable3\n (Sexpable : S3) (M : sig\n type ('a, 'b, 'c) t\n\n val to_sexpable : ('a, 'b, 'c) t -> ('a, 'b, 'c) Sexpable.t\n val of_sexpable : ('a, 'b, 'c) Sexpable.t -> ('a, 'b, 'c) t\n end) : S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t = struct\n let t_of_sexp a_of_sexp b_of_sexp c_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp b_of_sexp c_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a sexp_of_b sexp_of_c t =\n Sexpable.sexp_of_t sexp_of_a sexp_of_b sexp_of_c (M.to_sexpable t)\n ;;\nend\n\nmodule Of_stringable (M : Stringable.S) : S with type t := M.t = struct\n let t_of_sexp sexp =\n match sexp with\n | Sexp.Atom s ->\n (try M.of_string s with\n | exn -> of_sexp_error_exn exn sexp)\n | Sexp.List _ ->\n of_sexp_error\n \"Sexpable.Of_stringable.t_of_sexp expected an atom, but got a list\"\n sexp\n ;;\n\n let sexp_of_t t = Sexp.Atom (M.to_string t)\nend\n","open! Import\nmodule Sys = Sys0\n\ntype t =\n | W32\n | W64\n[@@deriving_inline sexp_of]\n\nlet sexp_of_t =\n (function\n | W32 -> Ppx_sexp_conv_lib.Sexp.Atom \"W32\"\n | W64 -> Ppx_sexp_conv_lib.Sexp.Atom \"W64\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet num_bits = function\n | W32 -> 32\n | W64 -> 64\n;;\n\nlet word_size =\n match Sys.word_size_in_bits with\n | 32 -> W32\n | 64 -> W64\n | _ -> failwith \"unknown word size\"\n;;\n","open! Import\n\nlet r = ref [ \"Base.Sexp.pp_hum\" ]\nlet all () = !r\nlet register p = r := p :: !r\n\nmodule type S = sig\n type t\n\n val pp : Formatter.t -> t -> unit\nend\n\nmodule Register_pp (M : sig\n include S\n\n val module_name : string\n end) =\nstruct\n include M\n\n let () = register (M.module_name ^ \".pp\")\nend\n\nmodule Register (M : sig\n type t\n\n val module_name : string\n val to_string : t -> string\n end) =\n Register_pp (struct\n include M\n\n let pp formatter t = Caml.Format.pp_print_string formatter (M.to_string t)\n end)\n","(** [Core_kernel] greatly expands the functionality available in Base while still\n remaining platform-agnostic. Core_kernel changes more frequently (i.e., is less\n stable) than Base.\n\n Some modules are mere extensions of their counterparts in Base, usually adding generic\n functionality by including functors that make them binable, comparable, sexpable,\n blitable, etc. The bulk of Core_kernel, though, is modules providing entirely new\n functionality. *)\n\nopen! Import\n\n\nmodule Applicative = Applicative\nmodule Arg = Arg\nmodule Array = Array\nmodule Avltree = Avltree\nmodule Backtrace = Backtrace\nmodule Bag = Bag\nmodule Bigbuffer = Bigbuffer\nmodule Bigstring = Bigstring\nmodule Bigsubstring = Bigsubstring\nmodule Bin_prot = Core_bin_prot\nmodule Binable = Binable\nmodule Binary_search = Binary_search\nmodule Binary_searchable = Binary_searchable\nmodule Blang = Blang\nmodule Blit = Blit\nmodule Bool = Bool\nmodule Bounded_index = Bounded_index\nmodule Buffer = Base.Buffer\nmodule Byte_units = Byte_units\nmodule Bytes = Bytes\nmodule Caml = Caml\nmodule Char = Char\nmodule Command = Command\nmodule Comparable = Comparable\nmodule Comparator = Comparator\nmodule Comparisons = Comparisons\nmodule Container = Container\nmodule Container_intf = Container_intf\nmodule Continue_or_stop = Continue_or_stop\nmodule Core_kernel_stable = Stable\nmodule Date = Date\nmodule Day_of_week = Day_of_week\nmodule Debug = Debug\nmodule Deque = Deque\nmodule Deriving_hash = Deriving_hash\nmodule Digest = Md5 [@@ocaml.deprecated \"[since 2017-05] Use Md5 instead.\"]\nmodule Doubly_linked = Doubly_linked\nmodule Either = Either\nmodule Ephemeron = Ephemeron\nmodule Equal = Equal\nmodule Error = Error\nmodule Exn = Base.Exn\nmodule Expect_test_config = Expect_test_config\nmodule Fdeque = Fdeque\nmodule Field = Field\nmodule Filename = Filename\nmodule Float = Float\nmodule Float_with_finite_only_serialization = Float_with_finite_only_serialization\nmodule Floatable = Floatable\nmodule Fn = Fn\nmodule Formatter = Formatter\nmodule Fqueue = Fqueue\nmodule Gc = Gc\nmodule Hash = Hash\nmodule Hash_queue = Hash_queue\nmodule Hash_set = Hash_set\nmodule Hashable = Hashable\nmodule Hashtbl = Hashtbl\nmodule Hashtbl_intf = Hashtbl_intf\nmodule Heap_block = Heap_block\nmodule Hexdump = Hexdump\nmodule Hexdump_intf = Hexdump_intf\nmodule Host_and_port = Host_and_port\nmodule Identifiable = Identifiable\nmodule Immediate_option = Immediate_option\nmodule Immediate_option_intf = Immediate_option_intf\nmodule In_channel = In_channel\nmodule Info = Info\nmodule Int = Int\nmodule Int32 = Int32\nmodule Int63 = Int63\nmodule Int64 = Int64\nmodule Int_conversions = Int_conversions\nmodule Int_intf = Int_intf\nmodule Int_math = Int_math\nmodule Intable = Intable\nmodule Interfaces = Interfaces\nmodule Invariant = Invariant\nmodule Lazy = Lazy\nmodule Linked_queue = Linked_queue\nmodule List = List\nmodule Map = Map\nmodule Map_intf = Map_intf\nmodule Maybe_bound = Maybe_bound\nmodule Md5 = Md5\nmodule Memo = Memo\nmodule Monad = Monad\nmodule Month = Month\nmodule Nativeint = Nativeint\nmodule No_polymorphic_compare = No_polymorphic_compare\nmodule Nothing = Nothing\nmodule Only_in_test = Only_in_test\nmodule Option = Option\nmodule Option_array = Option_array\nmodule Optional_syntax = Optional_syntax\nmodule Optional_syntax_intf = Optional_syntax_intf\nmodule Or_error = Or_error\nmodule Ordered_collection_common = Ordered_collection_common\nmodule Ordering = Ordering\nmodule Out_channel = Out_channel\nmodule Percent = Percent\nmodule Perms = Perms\nmodule Pid = Pid\nmodule Poly = Poly\nmodule Polymorphic_compare = Poly [@@deprecated \"[since 2018-11] use [Poly] instead\"]\n\nmodule Popcount = Base.Popcount\n[@@warning \"-3\"]\n[@@deprecated \"[since 2018-10] use [popcount] functions in individual int modules\"]\n\nmodule Pretty_printer = Pretty_printer\nmodule Printexc = Printexc\nmodule Printf = Printf\nmodule Queue = Queue\nmodule Quickcheck = Quickcheck\nmodule Quickcheck_intf = Quickcheck_intf\nmodule Quickcheckable = Quickcheckable\nmodule Random = Base.Random\nmodule Ref = Ref\nmodule Result = Result\nmodule Robustly_comparable = Robustly_comparable\nmodule Sequence = Sequence\nmodule Set = Set\nmodule Set_intf = Set_intf\nmodule Set_once = Set_once\nmodule Sexp_maybe = Sexp.Sexp_maybe\n\nmodule Sexp = Sexp\nmodule Sexpable = Sexpable\nmodule Sign = Sign\nmodule Sign_or_nan = Sign_or_nan\nmodule Source_code_position = Source_code_position\nmodule Splittable_random = Splittable_random\nmodule Stable_comparable = Stable_comparable\nmodule Stable_unit_test = Stable_unit_test\nmodule Stack = Stack\nmodule Staged = Base.Staged\nmodule String = String\nmodule String_id = String_id\nmodule Stringable = Stringable\nmodule Substring = Substring\nmodule Substring_intf = Substring_intf\nmodule Sys = Sys\nmodule Time = Time_float\nmodule Time_ns = Time_ns\nmodule Tuple = Tuple\nmodule Tuple2 = Tuple.T2\nmodule Tuple3 = Tuple.T3\nmodule Type_equal = Type_equal\nmodule Type_immediacy = Type_immediacy\nmodule Uchar = Uchar\nmodule Uniform_array = Uniform_array\nmodule Union_find = Union_find\nmodule Unique_id = Unique_id\nmodule Unit = Unit\nmodule Unit_of_time = Unit_of_time\nmodule Univ_map = Univ_map\n\nmodule Unix = struct end\n[@@deprecated\n \"[since 2020-03] Core_kernel shadows Unix. Use Core.Unix, which overrides some of \\\n Unix's behavior. If necessary, Unix is available and unshadowed as Caml_unix.\"]\n\nmodule Validate = Validate\nmodule Validated = Validated\nmodule Variant = Variant\nmodule Weak = Weak\nmodule With_return = With_return\nmodule Word_size = Word_size\n\nmodule type Unique_id = Unique_id.Id\n\ninclude T (** @open *)\n\ninclude Std_internal\ninclude Not_found\n\n(** {2 Top-level values} *)\n\ntype 'a _maybe_bound = 'a Maybe_bound.t =\n | Incl of 'a\n | Excl of 'a\n | Unbounded\n\nlet am_running_inline_test = am_running_inline_test\nlet am_running_test = am_running_test\nlet does_raise = Exn.does_raise\nlet sec = Time_float.Span.of_sec\n\n(** We perform these side effects here because we want them to run for any code that uses\n [Core_kernel]. If this were in another module in [Core_kernel] that was not used in\n some program, then the side effects might not be run in that program. This will run\n as long as the program refers to at least one value directly in [Std_kernel];\n referring to values in [Std_kernel.Bool], for example, is not sufficient. *)\nlet () = Exn.initialize_module ()\n\n(** To be used in implementing Core, but not by end users. *)\nmodule Core_kernel_private = struct\n module Digit_string_helpers = Digit_string_helpers\n module Time_zone = Zone\n module Ofday_helpers = Ofday_helpers\n module Span_float = Span_float\n\n module Bigbuffer_internal = Bigbuffer_internal\n module Stable_internal = Stable_internal\n module Std_internal = Std_internal\n\n module Time_ns_alternate_sexp = Time_ns_alternate_sexp\nend\n","(* belongs in Common, but moved here to avoid circular dependencies *)\n\nopen! Import\n\ntype 'a return = { return : 'b. 'a -> 'b } [@@unboxed]\n\nlet with_return (type a) f =\n let module M = struct\n (* Raised to indicate ~return was called. Local so that the exception is tied to a\n particular call of [with_return]. *)\n exception Return of a\n end\n in\n let is_alive = ref true in\n let return a =\n if not !is_alive\n then failwith \"use of [return] from a [with_return] that already returned\";\n Exn.raise_without_backtrace (M.Return a)\n in\n try\n let a = f { return } in\n is_alive := false;\n a\n with\n | exn ->\n is_alive := false;\n (match exn with\n | M.Return a -> a\n | _ -> raise exn)\n;;\n\nlet with_return_option f =\n with_return (fun return ->\n f { return = (fun a -> return.return (Some a)) };\n None)\n;;\n\nlet prepend { return } ~f = { return = (fun x -> return (f x)) }\n","open! Import\nmodule List = List0\ninclude Monad_intf\n\nmodule type Basic_general = sig\n type ('a, 'i, 'j, 'd, 'e) t\n\n val bind\n : ('a, 'i, 'j, 'd, 'e) t\n -> f:('a -> ('b, 'j, 'k, 'd, 'e) t)\n -> ('b, 'i, 'k, 'd, 'e) t\n\n val map\n : [ `Define_using_bind\n | `Custom of ('a, 'i, 'j, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'i, 'j, 'd, 'e) t\n ]\n\n val return : 'a -> ('a, 'i, 'i, 'd, 'e) t\nend\n\nmodule Make_general (M : Basic_general) = struct\n let bind = M.bind\n let return = M.return\n let map_via_bind ma ~f = M.bind ma ~f:(fun a -> M.return (f a))\n\n let map =\n match M.map with\n | `Define_using_bind -> map_via_bind\n | `Custom x -> x\n ;;\n\n module Monad_infix = struct\n let ( >>= ) t f = bind t ~f\n let ( >>| ) t f = map t ~f\n end\n\n include Monad_infix\n\n module Let_syntax = struct\n let return = return\n\n include Monad_infix\n\n module Let_syntax = struct\n let return = return\n let bind = bind\n let map = map\n let both a b = a >>= fun a -> b >>| fun b -> a, b\n\n module Open_on_rhs = struct end\n end\n end\n\n let join t = t >>= fun t' -> t'\n let ignore_m t = map t ~f:(fun _ -> ())\n\n let all =\n let rec loop vs = function\n | [] -> return (List.rev vs)\n | t :: ts -> t >>= fun v -> loop (v :: vs) ts\n in\n fun ts -> loop [] ts\n ;;\n\n let rec all_unit = function\n | [] -> return ()\n | t :: ts -> t >>= fun () -> all_unit ts\n ;;\nend\n\nmodule Make_indexed (M : Basic_indexed) :\n S_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) M.t = Make_general (struct\n type ('a, 'i, 'j, 'd, 'e) t = ('a, 'i, 'j) M.t\n\n include (M : Basic_indexed with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t)\n end)\n\nmodule Make3 (M : Basic3) : S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) M.t =\n Make_general (struct\n type ('a, 'i, 'j, 'd, 'e) t = ('a, 'd, 'e) M.t\n\n include (M : Basic3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t)\n end)\n\nmodule Make2 (M : Basic2) : S2 with type ('a, 'd) t := ('a, 'd) M.t =\n Make_general (struct\n type ('a, 'i, 'j, 'd, 'e) t = ('a, 'd) M.t\n\n include (M : Basic2 with type ('a, 'b) t := ('a, 'b) M.t)\n end)\n\nmodule Make (M : Basic) : S with type 'a t := 'a M.t = Make_general (struct\n type ('a, 'i, 'j, 'd, 'e) t = 'a M.t\n\n include (M : Basic with type 'a t := 'a M.t)\n end)\n\nmodule Ident = struct\n type 'a t = 'a\n\n include Make (struct\n type nonrec 'a t = 'a t\n\n let bind a ~f = f a\n let return a = a\n let map = `Custom (fun a ~f -> f a)\n end)\nend\n","open! Import\n\ntype ('a, 'witness) t =\n { compare : 'a -> 'a -> int\n ; sexp_of_t : 'a -> Sexp.t\n }\n\ntype ('a, 'b) comparator = ('a, 'b) t\n\nmodule type S = sig\n type t\n type comparator_witness\n\n val comparator : (t, comparator_witness) comparator\nend\n\nmodule type S1 = sig\n type 'a t\n type comparator_witness\n\n val comparator : ('a t, comparator_witness) comparator\nend\n\nmodule type S_fc = sig\n type comparable_t\n\n include S with type t := comparable_t\nend\n\nlet make (type t) ~compare ~sexp_of_t =\n (module struct\n type comparable_t = t\n type comparator_witness\n\n let comparator = { compare; sexp_of_t }\n end : S_fc\n with type comparable_t = t)\n;;\n\nmodule S_to_S1 (S : S) = struct\n type 'a t = S.t\n type comparator_witness = S.comparator_witness\n\n open S\n\n let comparator = comparator\nend\n\nmodule Make (M : sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) =\nstruct\n include M\n\n type comparator_witness\n\n let comparator = M.{ compare; sexp_of_t }\nend\n\nmodule Make1 (M : sig\n type 'a t\n\n val compare : 'a t -> 'a t -> int\n val sexp_of_t : 'a t -> Sexp.t\n end) =\nstruct\n type comparator_witness\n\n let comparator = M.{ compare; sexp_of_t }\nend\n\nmodule Poly = struct\n type 'a t = 'a\n\n include Make1 (struct\n type 'a t = 'a\n\n let compare = Poly.compare\n let sexp_of_t _ = Sexp.Atom \"_\"\n end)\nend\n\nmodule type Derived = sig\n type 'a t\n type 'cmp comparator_witness\n\n val comparator : ('a, 'cmp) comparator -> ('a t, 'cmp comparator_witness) comparator\nend\n\nmodule Derived (M : sig\n type 'a t [@@deriving_inline compare, sexp_of]\n\n val compare : ('a -> 'a -> int) -> 'a t -> 'a t -> int\n val sexp_of_t : ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) =\nstruct\n type 'cmp comparator_witness\n\n let comparator a =\n { compare = M.compare a.compare; sexp_of_t = M.sexp_of_t a.sexp_of_t }\n ;;\nend\n\nmodule type Derived2 = sig\n type ('a, 'b) t\n type ('cmp_a, 'cmp_b) comparator_witness\n\n val comparator\n : ('a, 'cmp_a) comparator\n -> ('b, 'cmp_b) comparator\n -> (('a, 'b) t, ('cmp_a, 'cmp_b) comparator_witness) comparator\nend\n\nmodule Derived2 (M : sig\n type ('a, 'b) t [@@deriving_inline compare, sexp_of]\n\n val compare : ('a -> 'a -> int) -> ('b -> 'b -> int) -> ('a, 'b) t -> ('a, 'b) t -> int\n\n val sexp_of_t\n : ('a -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('b -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('a, 'b) t\n -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) =\nstruct\n type ('cmp_a, 'cmp_b) comparator_witness\n\n let comparator a b =\n { compare = M.compare a.compare b.compare\n ; sexp_of_t = M.sexp_of_t a.sexp_of_t b.sexp_of_t\n }\n ;;\nend\n\nmodule type Derived_phantom = sig\n type ('a, 'b) t\n type 'cmp comparator_witness\n\n val comparator\n : ('a, 'cmp) comparator\n -> (('a, _) t, 'cmp comparator_witness) comparator\nend\n\nmodule Derived_phantom (M : sig\n type ('a, 'b) t\n\n val compare : ('a -> 'a -> int) -> ('a, 'b) t -> ('a, 'b) t -> int\n val sexp_of_t : ('a -> Sexp.t) -> ('a, _) t -> Sexp.t\n end) =\nstruct\n type 'cmp_a comparator_witness\n\n let comparator a =\n { compare = M.compare a.compare; sexp_of_t = M.sexp_of_t a.sexp_of_t }\n ;;\nend\n","(* The type [t] should be abstract to make the fset and set functions unavailable\n for private types at the level of types (and not by putting None in the field).\n Unfortunately, making the type abstract means that when creating fields (through\n a [create] function) value restriction kicks in. This is worked around by instead\n not making the type abstract, but forcing anyone breaking the abstraction to use\n the [For_generated_code] module, making it obvious to any reader that something ugly\n is going on.\n t_with_perm (and derivatives) is the type that users really use. It is a constructor\n because:\n 1. it makes type errors more readable (less aliasing)\n 2. the typer in ocaml 4.01 allows this:\n\n {[\n module A = struct\n type t = {a : int}\n end\n type t = A.t\n let f (x : t) = x.a\n ]}\n\n (although with Warning 40: a is used out of scope)\n which means that if [t_with_perm] was really an alias on [For_generated_code.t],\n people could say [t.setter] and break the abstraction with no indication that\n something ugly is going on in the source code.\n The warning is (I think) for people who want to make their code compatible with\n previous versions of ocaml, so we may very well turn it off.\n\n The type t_with_perm could also have been a [unit -> For_generated_code.t] to work\n around value restriction and then [For_generated_code.t] would have been a proper\n abstract type, but it looks like it could impact performance (for example, a fold on a\n record type with 40 fields would actually allocate the 40 [For_generated_code.t]'s at\n every single fold.) *)\n\nmodule For_generated_code = struct\n type ('perm, 'record, 'field) t =\n { force_variance : 'perm -> unit\n ; (* force [t] to be contravariant in ['perm], because phantom type variables on\n concrete types don't work that well otherwise (using :> can remove them easily) *)\n name : string\n ; setter : ('record -> 'field -> unit) option\n ; getter : 'record -> 'field\n ; fset : 'record -> 'field -> 'record\n }\n\n let opaque_identity = Sys0.opaque_identity\nend\n\ntype ('perm, 'record, 'field) t_with_perm =\n | Field of ('perm, 'record, 'field) For_generated_code.t\n[@@unboxed]\n\ntype ('record, 'field) t = ([ `Read | `Set_and_create ], 'record, 'field) t_with_perm\ntype ('record, 'field) readonly_t = ([ `Read ], 'record, 'field) t_with_perm\n\nlet name (Field field) = field.name\nlet get (Field field) r = field.getter r\nlet fset (Field field) r v = field.fset r v\nlet setter (Field field) = field.setter\n\ntype ('perm, 'record, 'result) user =\n { f : 'field. ('perm, 'record, 'field) t_with_perm -> 'result }\n\nlet map (Field field) r ~f = field.fset r (f (field.getter r))\n\nlet updater (Field field) =\n match field.setter with\n | None -> None\n | Some setter -> Some (fun r ~f -> setter r (f (field.getter r)))\n;;\n","open! Import\nmodule Int = Int0\nmodule String = String0\n\nmodule T = struct\n type t = Caml.Lexing.position =\n { pos_fname : string\n ; pos_lnum : int\n ; pos_bol : int\n ; pos_cnum : int\n }\n [@@deriving_inline compare, hash, sexp]\n\n let compare =\n (fun a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match compare_string a__001_.pos_fname b__002_.pos_fname with\n | 0 ->\n (match compare_int a__001_.pos_lnum b__002_.pos_lnum with\n | 0 ->\n (match compare_int a__001_.pos_bol b__002_.pos_bol with\n | 0 -> compare_int a__001_.pos_cnum b__002_.pos_cnum\n | n -> n)\n | n -> n)\n | n -> n)\n : t -> t -> int)\n ;;\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n fun hsv arg ->\n let hsv =\n let hsv =\n let hsv =\n let hsv = hsv in\n hash_fold_string hsv arg.pos_fname\n in\n hash_fold_int hsv arg.pos_lnum\n in\n hash_fold_int hsv arg.pos_bol\n in\n hash_fold_int hsv arg.pos_cnum\n ;;\n\n let (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func arg =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (let hsv = Ppx_hash_lib.Std.Hash.create () in\n hash_fold_t hsv arg)\n in\n fun x -> func x\n ;;\n\n let t_of_sexp =\n (let _tp_loc = \"source_code_position0.ml.T.t\" in\n function\n | Ppx_sexp_conv_lib.Sexp.List field_sexps as sexp ->\n let pos_fname_field = ref Ppx_sexp_conv_lib.Option.None\n and pos_lnum_field = ref Ppx_sexp_conv_lib.Option.None\n and pos_bol_field = ref Ppx_sexp_conv_lib.Option.None\n and pos_cnum_field = ref Ppx_sexp_conv_lib.Option.None\n and duplicates = ref []\n and extra = ref [] in\n let rec iter = function\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom field_name :: (([] | [ _ ]) as _field_sexps))\n :: tail ->\n let _field_sexp () =\n match _field_sexps with\n | [ x ] -> x\n | [] -> Ppx_sexp_conv_lib.Conv_error.record_only_pairs_expected _tp_loc sexp\n | _ -> assert false\n in\n (match field_name with\n | \"pos_fname\" ->\n (match !pos_fname_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = string_of_sexp _field_sexp in\n pos_fname_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ -> duplicates := field_name :: !duplicates)\n | \"pos_lnum\" ->\n (match !pos_lnum_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n pos_lnum_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ -> duplicates := field_name :: !duplicates)\n | \"pos_bol\" ->\n (match !pos_bol_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n pos_bol_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ -> duplicates := field_name :: !duplicates)\n | \"pos_cnum\" ->\n (match !pos_cnum_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n pos_cnum_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ -> duplicates := field_name :: !duplicates)\n | _ ->\n if !Ppx_sexp_conv_lib.Conv.record_check_extra_fields\n then extra := field_name :: !extra\n else ());\n iter tail\n | ((Ppx_sexp_conv_lib.Sexp.Atom _ | Ppx_sexp_conv_lib.Sexp.List _) as sexp) :: _\n -> Ppx_sexp_conv_lib.Conv_error.record_only_pairs_expected _tp_loc sexp\n | [] -> ()\n in\n iter field_sexps;\n (match !duplicates with\n | _ :: _ ->\n Ppx_sexp_conv_lib.Conv_error.record_duplicate_fields _tp_loc !duplicates sexp\n | [] ->\n (match !extra with\n | _ :: _ -> Ppx_sexp_conv_lib.Conv_error.record_extra_fields _tp_loc !extra sexp\n | [] ->\n (match !pos_fname_field, !pos_lnum_field, !pos_bol_field, !pos_cnum_field with\n | ( Ppx_sexp_conv_lib.Option.Some pos_fname_value\n , Ppx_sexp_conv_lib.Option.Some pos_lnum_value\n , Ppx_sexp_conv_lib.Option.Some pos_bol_value\n , Ppx_sexp_conv_lib.Option.Some pos_cnum_value ) ->\n { pos_fname = pos_fname_value\n ; pos_lnum = pos_lnum_value\n ; pos_bol = pos_bol_value\n ; pos_cnum = pos_cnum_value\n }\n | _ ->\n Ppx_sexp_conv_lib.Conv_error.record_undefined_elements\n _tp_loc\n sexp\n [ ( Ppx_sexp_conv_lib.Conv.( = )\n !pos_fname_field\n Ppx_sexp_conv_lib.Option.None\n , \"pos_fname\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !pos_lnum_field\n Ppx_sexp_conv_lib.Option.None\n , \"pos_lnum\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !pos_bol_field\n Ppx_sexp_conv_lib.Option.None\n , \"pos_bol\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !pos_cnum_field\n Ppx_sexp_conv_lib.Option.None\n , \"pos_cnum\" )\n ])))\n | Ppx_sexp_conv_lib.Sexp.Atom _ as sexp ->\n Ppx_sexp_conv_lib.Conv_error.record_list_instead_atom _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> t)\n ;;\n\n let sexp_of_t =\n (function\n | { pos_fname = v_pos_fname\n ; pos_lnum = v_pos_lnum\n ; pos_bol = v_pos_bol\n ; pos_cnum = v_pos_cnum\n } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_int v_pos_cnum in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"pos_cnum\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_pos_bol in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"pos_bol\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_pos_lnum in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"pos_lnum\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_string v_pos_fname in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"pos_fname\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\nend\n\ninclude T\ninclude Comparator.Make (T)\n\n(* This is the same function as Ppx_here.lift_position_as_string. *)\nlet make_location_string ~pos_fname ~pos_lnum ~pos_cnum ~pos_bol =\n String.concat\n [ pos_fname; \":\"; Int.to_string pos_lnum; \":\"; Int.to_string (pos_cnum - pos_bol) ]\n;;\n\nlet to_string { Caml.Lexing.pos_fname; pos_lnum; pos_cnum; pos_bol } =\n make_location_string ~pos_fname ~pos_lnum ~pos_cnum ~pos_bol\n;;\n\nlet sexp_of_t t = Sexp.Atom (to_string t)\n","open! Import\ninclude List0\n\nlet is_empty = function\n | [] -> true\n | _ -> false\n;;\n\nlet partition_map t ~f =\n let rec loop t fst snd =\n match t with\n | [] -> rev fst, rev snd\n | x :: t ->\n (match (f x : _ Either0.t) with\n | First y -> loop t (y :: fst) snd\n | Second y -> loop t fst (y :: snd))\n in\n loop t [] []\n;;\n","open! Import\nmodule Either = Either0\n\ntype ('a, 'b) t = ('a, 'b) Caml.result =\n | Ok of 'a\n | Error of 'b\n[@@deriving_inline sexp, compare, equal, hash]\n\nlet t_of_sexp\n : type a b.\n (Ppx_sexp_conv_lib.Sexp.t -> a)\n -> (Ppx_sexp_conv_lib.Sexp.t -> b)\n -> Ppx_sexp_conv_lib.Sexp.t\n -> (a, b) t\n =\n let _tp_loc = \"result.ml.t\" in\n fun _of_a _of_b -> function\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"ok\" | \"Ok\") as _tag) :: sexp_args) as _sexp ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_a v0 in\n Ok v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"error\" | \"Error\") as _tag) :: sexp_args) as _sexp\n ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_b v0 in\n Error v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.Atom (\"ok\" | \"Ok\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.Atom (\"error\" | \"Error\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n;;\n\nlet sexp_of_t\n : type a b.\n (a -> Ppx_sexp_conv_lib.Sexp.t)\n -> (b -> Ppx_sexp_conv_lib.Sexp.t)\n -> (a, b) t\n -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a _of_b -> function\n | Ok v0 ->\n let v0 = _of_a v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Ok\"; v0 ]\n | Error v0 ->\n let v0 = _of_b v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Error\"; v0 ]\n;;\n\nlet compare :\n 'a 'b. ('a -> 'a -> int) -> ('b -> 'b -> int) -> ('a, 'b) t -> ('a, 'b) t -> int\n =\n fun _cmp__a _cmp__b a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match a__001_, b__002_ with\n | Ok _a__003_, Ok _b__004_ -> _cmp__a _a__003_ _b__004_\n | Ok _, _ -> -1\n | _, Ok _ -> 1\n | Error _a__005_, Error _b__006_ -> _cmp__b _a__005_ _b__006_)\n;;\n\nlet equal :\n 'a 'b. ('a -> 'a -> bool) -> ('b -> 'b -> bool) -> ('a, 'b) t -> ('a, 'b) t -> bool\n =\n fun _cmp__a _cmp__b a__007_ b__008_ ->\n if Ppx_compare_lib.phys_equal a__007_ b__008_\n then true\n else (\n match a__007_, b__008_ with\n | Ok _a__009_, Ok _b__010_ -> _cmp__a _a__009_ _b__010_\n | Ok _, _ -> false\n | _, Ok _ -> false\n | Error _a__011_, Error _b__012_ -> _cmp__b _a__011_ _b__012_)\n;;\n\nlet hash_fold_t\n : type a b.\n (Ppx_hash_lib.Std.Hash.state -> a -> Ppx_hash_lib.Std.Hash.state)\n -> (Ppx_hash_lib.Std.Hash.state -> b -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state\n -> (a, b) t\n -> Ppx_hash_lib.Std.Hash.state\n =\n fun _hash_fold_a _hash_fold_b hsv arg ->\n match arg with\n | Ok _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 0 in\n let hsv = hsv in\n _hash_fold_a hsv _a0\n | Error _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 1 in\n let hsv = hsv in\n _hash_fold_b hsv _a0\n;;\n\n[@@@end]\n\ninclude Monad.Make2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n\n let bind x ~f =\n match x with\n | Error _ as x -> x\n | Ok x -> f x\n ;;\n\n let map x ~f =\n match x with\n | Error _ as x -> x\n | Ok x -> Ok (f x)\n ;;\n\n let map = `Custom map\n let return x = Ok x\n end)\n\nlet invariant check_ok check_error t =\n match t with\n | Ok ok -> check_ok ok\n | Error error -> check_error error\n;;\n\nlet fail x = Error x\nlet failf format = Printf.ksprintf fail format\n\nlet map_error t ~f =\n match t with\n | Ok _ as x -> x\n | Error x -> Error (f x)\n;;\n\nlet is_ok = function\n | Ok _ -> true\n | Error _ -> false\n;;\n\nlet is_error = function\n | Ok _ -> false\n | Error _ -> true\n;;\n\nlet ok = function\n | Ok x -> Some x\n | Error _ -> None\n;;\n\nlet error = function\n | Ok _ -> None\n | Error x -> Some x\n;;\n\nlet of_option opt ~error =\n match opt with\n | Some x -> Ok x\n | None -> Error error\n;;\n\nlet iter v ~f =\n match v with\n | Ok x -> f x\n | Error _ -> ()\n;;\n\nlet iter_error v ~f =\n match v with\n | Ok _ -> ()\n | Error x -> f x\n;;\n\nlet to_either : _ t -> _ Either.t = function\n | Ok x -> First x\n | Error x -> Second x\n;;\n\nlet of_either : _ Either.t -> _ t = function\n | First x -> Ok x\n | Second x -> Error x\n;;\n\nlet ok_if_true bool ~error = if bool then Ok () else Error error\n\nlet try_with f =\n try Ok (f ()) with\n | exn -> Error exn\n;;\n\nlet ok_exn = function\n | Ok x -> x\n | Error exn -> raise exn\n;;\n\nlet ok_or_failwith = function\n | Ok x -> x\n | Error str -> failwith str\n;;\n\nmodule Export = struct\n type ('ok, 'err) _result = ('ok, 'err) t =\n | Ok of 'ok\n | Error of 'err\n\n let is_error = is_error\n let is_ok = is_ok\nend\n\nlet combine t1 t2 ~ok ~err =\n match t1, t2 with\n | Ok _, Error e | Error e, Ok _ -> Error e\n | Ok ok1, Ok ok2 -> Ok (ok ok1 ok2)\n | Error err1, Error err2 -> Error (err err1 err2)\n;;\n\nlet combine_errors l =\n let ok, errs = List1.partition_map l ~f:to_either in\n match errs with\n | [] -> Ok ok\n | _ :: _ -> Error errs\n;;\n\nlet combine_errors_unit l = map (combine_errors l) ~f:(fun (_ : unit list) -> ())\n\n(* deprecated binding for export only *)\nlet ok_fst = to_either\n","(** Provides generic signatures for container data structures.\n\n These signatures include functions ([iter], [fold], [exists], [for_all], ...) that\n you would expect to find in any container. Used by including [Container.S0] or\n [Container.S1] in the signature for every container-like data structure ([Array],\n [List], [String], ...) to ensure a consistent interface. *)\n\nopen! Import\n\nmodule Export = struct\n (** [Continue_or_stop.t] is used by the [f] argument to [fold_until] in order to\n indicate whether folding should continue, or stop early. *)\n module Continue_or_stop = struct\n type ('a, 'b) t =\n | Continue of 'a\n | Stop of 'b\n end\nend\n\ninclude Export\n\nmodule type Summable = sig\n type t\n\n (** The result of summing no values. *)\n val zero : t\n\n (** An operation that combines two [t]'s and handles [zero + x] by just returning [x],\n as well as in the symmetric case. *)\n val ( + ) : t -> t -> t\nend\n\n(** Signature for monomorphic container, e.g., string. *)\nmodule type S0 = sig\n type t\n type elt\n\n (** Checks whether the provided element is there, using equality on [elt]s. *)\n val mem : t -> elt -> bool\n\n val length : t -> int\n val is_empty : t -> bool\n\n (** [iter] must allow exceptions raised in [f] to escape, terminating the iteration\n cleanly. The same holds for all functions below taking an [f]. *)\n val iter : t -> f:(elt -> unit) -> unit\n\n (** [fold t ~init ~f] returns [f (... f (f (f init e1) e2) e3 ...) en], where [e1..en]\n are the elements of [t]. *)\n val fold : t -> init:'accum -> f:('accum -> elt -> 'accum) -> 'accum\n\n (** [fold_result t ~init ~f] is a short-circuiting version of [fold] that runs in the\n [Result] monad. If [f] returns an [Error _], that value is returned without any\n additional invocations of [f]. *)\n val fold_result\n : t\n -> init:'accum\n -> f:('accum -> elt -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n (** [fold_until t ~init ~f ~finish] is a short-circuiting version of [fold]. If [f]\n returns [Stop _] the computation ceases and results in that value. If [f] returns\n [Continue _], the fold will proceed. If [f] never returns [Stop _], the final result\n is computed by [finish].\n\n Example:\n\n {[\n type maybe_negative =\n | Found_negative of int\n | All_nonnegative of { sum : int }\n\n (** [first_neg_or_sum list] returns the first negative number in [list], if any,\n otherwise returns the sum of the list. *)\n let first_neg_or_sum =\n List.fold_until ~init:0\n ~f:(fun sum x ->\n if x < 0\n then Stop (Found_negative x)\n else Continue (sum + x))\n ~finish:(fun sum -> All_nonnegative { sum })\n ;;\n\n let x = first_neg_or_sum [1; 2; 3; 4; 5]\n val x : maybe_negative = All_nonnegative {sum = 15}\n\n let y = first_neg_or_sum [1; 2; -3; 4; 5]\n val y : maybe_negative = Found_negative -3\n ]} *)\n val fold_until\n : t\n -> init:'accum\n -> f:('accum -> elt -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n (** Returns [true] if and only if there exists an element for which the provided\n function evaluates to [true]. This is a short-circuiting operation. *)\n val exists : t -> f:(elt -> bool) -> bool\n\n (** Returns [true] if and only if the provided function evaluates to [true] for all\n elements. This is a short-circuiting operation. *)\n val for_all : t -> f:(elt -> bool) -> bool\n\n (** Returns the number of elements for which the provided function evaluates to true. *)\n val count : t -> f:(elt -> bool) -> int\n\n (** Returns the sum of [f i] for all [i] in the container. *)\n val sum : (module Summable with type t = 'sum) -> t -> f:(elt -> 'sum) -> 'sum\n\n (** Returns as an [option] the first element for which [f] evaluates to true. *)\n val find : t -> f:(elt -> bool) -> elt option\n\n (** Returns the first evaluation of [f] that returns [Some], and returns [None] if there\n is no such element. *)\n val find_map : t -> f:(elt -> 'a option) -> 'a option\n\n val to_list : t -> elt list\n val to_array : t -> elt array\n\n (** Returns a min (resp. max) element from the collection using the provided [compare]\n function. In case of a tie, the first element encountered while traversing the\n collection is returned. The implementation uses [fold] so it has the same\n complexity as [fold]. Returns [None] iff the collection is empty. *)\n val min_elt : t -> compare:(elt -> elt -> int) -> elt option\n\n val max_elt : t -> compare:(elt -> elt -> int) -> elt option\nend\n\nmodule type S0_phantom = sig\n type elt\n type 'a t\n\n (** Checks whether the provided element is there, using equality on [elt]s. *)\n val mem : _ t -> elt -> bool\n\n val length : _ t -> int\n val is_empty : _ t -> bool\n val iter : _ t -> f:(elt -> unit) -> unit\n\n (** [fold t ~init ~f] returns [f (... f (f (f init e1) e2) e3 ...) en], where [e1..en]\n are the elements of [t]. *)\n val fold : _ t -> init:'accum -> f:('accum -> elt -> 'accum) -> 'accum\n\n (** [fold_result t ~init ~f] is a short-circuiting version of [fold] that runs in the\n [Result] monad. If [f] returns an [Error _], that value is returned without any\n additional invocations of [f]. *)\n val fold_result\n : _ t\n -> init:'accum\n -> f:('accum -> elt -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n (** [fold_until t ~init ~f ~finish] is a short-circuiting version of [fold]. If [f]\n returns [Stop _] the computation ceases and results in that value. If [f] returns\n [Continue _], the fold will proceed. If [f] never returns [Stop _], the final result\n is computed by [finish].\n\n Example:\n\n {[\n type maybe_negative =\n | Found_negative of int\n | All_nonnegative of { sum : int }\n\n (** [first_neg_or_sum list] returns the first negative number in [list], if any,\n otherwise returns the sum of the list. *)\n let first_neg_or_sum =\n List.fold_until ~init:0\n ~f:(fun sum x ->\n if x < 0\n then Stop (Found_negative x)\n else Continue (sum + x))\n ~finish:(fun sum -> All_nonnegative { sum })\n ;;\n\n let x = first_neg_or_sum [1; 2; 3; 4; 5]\n val x : maybe_negative = All_nonnegative {sum = 15}\n\n let y = first_neg_or_sum [1; 2; -3; 4; 5]\n val y : maybe_negative = Found_negative -3\n ]} *)\n val fold_until\n : _ t\n -> init:'accum\n -> f:('accum -> elt -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n (** Returns [true] if and only if there exists an element for which the provided\n function evaluates to [true]. This is a short-circuiting operation. *)\n val exists : _ t -> f:(elt -> bool) -> bool\n\n (** Returns [true] if and only if the provided function evaluates to [true] for all\n elements. This is a short-circuiting operation. *)\n val for_all : _ t -> f:(elt -> bool) -> bool\n\n (** Returns the number of elements for which the provided function evaluates to true. *)\n val count : _ t -> f:(elt -> bool) -> int\n\n (** Returns the sum of [f i] for all [i] in the container. The order in which the\n elements will be summed is unspecified. *)\n val sum : (module Summable with type t = 'sum) -> _ t -> f:(elt -> 'sum) -> 'sum\n\n (** Returns as an [option] the first element for which [f] evaluates to true. *)\n val find : _ t -> f:(elt -> bool) -> elt option\n\n (** Returns the first evaluation of [f] that returns [Some], and returns [None] if there\n is no such element. *)\n val find_map : _ t -> f:(elt -> 'a option) -> 'a option\n\n val to_list : _ t -> elt list\n val to_array : _ t -> elt array\n\n (** Returns a min (resp max) element from the collection using the provided [compare]\n function, or [None] if the collection is empty. In case of a tie, the first element\n encountered while traversing the collection is returned. *)\n val min_elt : _ t -> compare:(elt -> elt -> int) -> elt option\n\n val max_elt : _ t -> compare:(elt -> elt -> int) -> elt option\nend\n\n(** Signature for polymorphic container, e.g., ['a list] or ['a array]. *)\nmodule type S1 = sig\n type 'a t\n\n (** Checks whether the provided element is there, using [equal]. *)\n val mem : 'a t -> 'a -> equal:('a -> 'a -> bool) -> bool\n\n val length : 'a t -> int\n val is_empty : 'a t -> bool\n val iter : 'a t -> f:('a -> unit) -> unit\n\n (** [fold t ~init ~f] returns [f (... f (f (f init e1) e2) e3 ...) en], where [e1..en]\n are the elements of [t] *)\n val fold : 'a t -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum\n\n (** [fold_result t ~init ~f] is a short-circuiting version of [fold] that runs in the\n [Result] monad. If [f] returns an [Error _], that value is returned without any\n additional invocations of [f]. *)\n val fold_result\n : 'a t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n (** [fold_until t ~init ~f ~finish] is a short-circuiting version of [fold]. If [f]\n returns [Stop _] the computation ceases and results in that value. If [f] returns\n [Continue _], the fold will proceed. If [f] never returns [Stop _], the final result\n is computed by [finish].\n\n Example:\n\n {[\n type maybe_negative =\n | Found_negative of int\n | All_nonnegative of { sum : int }\n\n (** [first_neg_or_sum list] returns the first negative number in [list], if any,\n otherwise returns the sum of the list. *)\n let first_neg_or_sum =\n List.fold_until ~init:0\n ~f:(fun sum x ->\n if x < 0\n then Stop (Found_negative x)\n else Continue (sum + x))\n ~finish:(fun sum -> All_nonnegative { sum })\n ;;\n\n let x = first_neg_or_sum [1; 2; 3; 4; 5]\n val x : maybe_negative = All_nonnegative {sum = 15}\n\n let y = first_neg_or_sum [1; 2; -3; 4; 5]\n val y : maybe_negative = Found_negative -3\n ]} *)\n val fold_until\n : 'a t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n (** Returns [true] if and only if there exists an element for which the provided\n function evaluates to [true]. This is a short-circuiting operation. *)\n val exists : 'a t -> f:('a -> bool) -> bool\n\n (** Returns [true] if and only if the provided function evaluates to [true] for all\n elements. This is a short-circuiting operation. *)\n val for_all : 'a t -> f:('a -> bool) -> bool\n\n (** Returns the number of elements for which the provided function evaluates to true. *)\n val count : 'a t -> f:('a -> bool) -> int\n\n (** Returns the sum of [f i] for all [i] in the container. *)\n val sum : (module Summable with type t = 'sum) -> 'a t -> f:('a -> 'sum) -> 'sum\n\n (** Returns as an [option] the first element for which [f] evaluates to true. *)\n val find : 'a t -> f:('a -> bool) -> 'a option\n\n (** Returns the first evaluation of [f] that returns [Some], and returns [None] if there\n is no such element. *)\n val find_map : 'a t -> f:('a -> 'b option) -> 'b option\n\n val to_list : 'a t -> 'a list\n val to_array : 'a t -> 'a array\n\n (** Returns a minimum (resp maximum) element from the collection using the provided\n [compare] function, or [None] if the collection is empty. In case of a tie, the first\n element encountered while traversing the collection is returned. The implementation\n uses [fold] so it has the same complexity as [fold]. *)\n val min_elt : 'a t -> compare:('a -> 'a -> int) -> 'a option\n\n val max_elt : 'a t -> compare:('a -> 'a -> int) -> 'a option\nend\n\nmodule type S1_phantom_invariant = sig\n type ('a, 'phantom) t\n\n (** Checks whether the provided element is there, using [equal]. *)\n val mem : ('a, _) t -> 'a -> equal:('a -> 'a -> bool) -> bool\n\n val length : (_, _) t -> int\n val is_empty : (_, _) t -> bool\n val iter : ('a, _) t -> f:('a -> unit) -> unit\n\n (** [fold t ~init ~f] returns [f (... f (f (f init e1) e2) e3 ...) en], where [e1..en]\n are the elements of [t]. *)\n val fold : ('a, _) t -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum\n\n (** [fold_result t ~init ~f] is a short-circuiting version of [fold] that runs in the\n [Result] monad. If [f] returns an [Error _], that value is returned without any\n additional invocations of [f]. *)\n val fold_result\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n (** [fold_until t ~init ~f ~finish] is a short-circuiting version of [fold]. If [f]\n returns [Stop _] the computation ceases and results in that value. If [f] returns\n [Continue _], the fold will proceed. If [f] never returns [Stop _], the final result\n is computed by [finish].\n\n Example:\n\n {[\n type maybe_negative =\n | Found_negative of int\n | All_nonnegative of { sum : int }\n\n (** [first_neg_or_sum list] returns the first negative number in [list], if any,\n otherwise returns the sum of the list. *)\n let first_neg_or_sum =\n List.fold_until ~init:0\n ~f:(fun sum x ->\n if x < 0\n then Stop (Found_negative x)\n else Continue (sum + x))\n ~finish:(fun sum -> All_nonnegative { sum })\n ;;\n\n let x = first_neg_or_sum [1; 2; 3; 4; 5]\n val x : maybe_negative = All_nonnegative {sum = 15}\n\n let y = first_neg_or_sum [1; 2; -3; 4; 5]\n val y : maybe_negative = Found_negative -3\n ]} *)\n val fold_until\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n (** Returns [true] if and only if there exists an element for which the provided\n function evaluates to [true]. This is a short-circuiting operation. *)\n val exists : ('a, _) t -> f:('a -> bool) -> bool\n\n (** Returns [true] if and only if the provided function evaluates to [true] for all\n elements. This is a short-circuiting operation. *)\n val for_all : ('a, _) t -> f:('a -> bool) -> bool\n\n (** Returns the number of elements for which the provided function evaluates to true. *)\n val count : ('a, _) t -> f:('a -> bool) -> int\n\n (** Returns the sum of [f i] for all [i] in the container. *)\n val sum : (module Summable with type t = 'sum) -> ('a, _) t -> f:('a -> 'sum) -> 'sum\n\n (** Returns as an [option] the first element for which [f] evaluates to true. *)\n val find : ('a, _) t -> f:('a -> bool) -> 'a option\n\n (** Returns the first evaluation of [f] that returns [Some], and returns [None] if there\n is no such element. *)\n val find_map : ('a, _) t -> f:('a -> 'b option) -> 'b option\n\n val to_list : ('a, _) t -> 'a list\n val to_array : ('a, _) t -> 'a array\n\n (** Returns a min (resp max) element from the collection using the provided [compare]\n function. In case of a tie, the first element encountered while traversing the\n collection is returned. The implementation uses [fold] so it has the same complexity\n as [fold]. Returns [None] iff the collection is empty. *)\n val min_elt : ('a, _) t -> compare:('a -> 'a -> int) -> 'a option\n\n val max_elt : ('a, _) t -> compare:('a -> 'a -> int) -> 'a option\nend\n\nmodule type S1_phantom = sig\n type ('a, +'phantom) t\n\n include S1_phantom_invariant with type ('a, 'phantom) t := ('a, 'phantom) t\nend\n\nmodule type Generic = sig\n type 'a t\n type 'a elt\n\n val length : _ t -> int\n val is_empty : _ t -> bool\n val iter : 'a t -> f:('a elt -> unit) -> unit\n val fold : 'a t -> init:'accum -> f:('accum -> 'a elt -> 'accum) -> 'accum\n\n val fold_result\n : 'a t\n -> init:'accum\n -> f:('accum -> 'a elt -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n val fold_until\n : 'a t\n -> init:'accum\n -> f:('accum -> 'a elt -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n val exists : 'a t -> f:('a elt -> bool) -> bool\n val for_all : 'a t -> f:('a elt -> bool) -> bool\n val count : 'a t -> f:('a elt -> bool) -> int\n val sum : (module Summable with type t = 'sum) -> 'a t -> f:('a elt -> 'sum) -> 'sum\n val find : 'a t -> f:('a elt -> bool) -> 'a elt option\n val find_map : 'a t -> f:('a elt -> 'b option) -> 'b option\n val to_list : 'a t -> 'a elt list\n val to_array : 'a t -> 'a elt array\n val min_elt : 'a t -> compare:('a elt -> 'a elt -> int) -> 'a elt option\n val max_elt : 'a t -> compare:('a elt -> 'a elt -> int) -> 'a elt option\nend\n\nmodule type Generic_phantom = sig\n type ('a, 'phantom) t\n type 'a elt\n\n val length : (_, _) t -> int\n val is_empty : (_, _) t -> bool\n val iter : ('a, _) t -> f:('a elt -> unit) -> unit\n val fold : ('a, _) t -> init:'accum -> f:('accum -> 'a elt -> 'accum) -> 'accum\n\n val fold_result\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a elt -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n val fold_until\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a elt -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n val exists : ('a, _) t -> f:('a elt -> bool) -> bool\n val for_all : ('a, _) t -> f:('a elt -> bool) -> bool\n val count : ('a, _) t -> f:('a elt -> bool) -> int\n\n val sum\n : (module Summable with type t = 'sum)\n -> ('a, _) t\n -> f:('a elt -> 'sum)\n -> 'sum\n\n val find : ('a, _) t -> f:('a elt -> bool) -> 'a elt option\n val find_map : ('a, _) t -> f:('a elt -> 'b option) -> 'b option\n val to_list : ('a, _) t -> 'a elt list\n val to_array : ('a, _) t -> 'a elt array\n val min_elt : ('a, _) t -> compare:('a elt -> 'a elt -> int) -> 'a elt option\n val max_elt : ('a, _) t -> compare:('a elt -> 'a elt -> int) -> 'a elt option\nend\n\nmodule type Make_gen_arg = sig\n type 'a t\n type 'a elt\n\n val fold : 'a t -> init:'accum -> f:('accum -> 'a elt -> 'accum) -> 'accum\n\n (** The [iter] argument to [Container.Make] specifies how to implement the\n container's [iter] function. [`Define_using_fold] means to define [iter]\n via:\n\n {[\n iter t ~f = Container.iter ~fold t ~f\n ]}\n\n [`Custom] overrides the default implementation, presumably with something more\n efficient. Several other functions returned by [Container.Make] are defined in\n terms of [iter], so passing in a more efficient [iter] will improve their efficiency\n as well. *)\n val iter : [ `Define_using_fold | `Custom of 'a t -> f:('a elt -> unit) -> unit ]\n\n (** The [length] argument to [Container.Make] specifies how to implement the\n container's [length] function. [`Define_using_fold] means to define\n [length] via:\n\n {[\n length t ~f = Container.length ~fold t ~f\n ]}\n\n [`Custom] overrides the default implementation, presumably with something more\n efficient. Several other functions returned by [Container.Make] are defined in\n terms of [length], so passing in a more efficient [length] will improve their\n efficiency as well. *)\n val length : [ `Define_using_fold | `Custom of 'a t -> int ]\nend\n\nmodule type Make_arg = Make_gen_arg with type 'a elt := 'a Monad.Ident.t\n\nmodule type Make0_arg = sig\n module Elt : sig\n type t\n\n val equal : t -> t -> bool\n end\n\n type t\n\n val fold : t -> init:'accum -> f:('accum -> Elt.t -> 'accum) -> 'accum\n val iter : [ `Define_using_fold | `Custom of t -> f:(Elt.t -> unit) -> unit ]\n val length : [ `Define_using_fold | `Custom of t -> int ]\nend\n\nmodule type Container = sig\n include module type of struct\n include Export\n end\n\n module type S0 = S0\n module type S0_phantom = S0_phantom\n module type S1 = S1\n module type S1_phantom_invariant = S1_phantom_invariant\n module type S1_phantom = S1_phantom\n module type Generic = Generic\n module type Generic_phantom = Generic_phantom\n module type Summable = Summable\n\n (** Generic definitions of container operations in terms of [fold].\n\n E.g.: [iter ~fold t ~f = fold t ~init:() ~f:(fun () a -> f a)]. *)\n\n type ('t, 'a, 'accum) fold = 't -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum\n type ('t, 'a) iter = 't -> f:('a -> unit) -> unit\n type 't length = 't -> int\n\n val iter : fold:('t, 'a, unit) fold -> ('t, 'a) iter\n val count : fold:('t, 'a, int) fold -> 't -> f:('a -> bool) -> int\n\n val min_elt\n : fold:('t, 'a, 'a option) fold\n -> 't\n -> compare:('a -> 'a -> int)\n -> 'a option\n\n val max_elt\n : fold:('t, 'a, 'a option) fold\n -> 't\n -> compare:('a -> 'a -> int)\n -> 'a option\n\n val length : fold:('t, _, int) fold -> 't -> int\n val to_list : fold:('t, 'a, 'a list) fold -> 't -> 'a list\n\n val sum\n : fold:('t, 'a, 'sum) fold\n -> (module Summable with type t = 'sum)\n -> 't\n -> f:('a -> 'sum)\n -> 'sum\n\n val fold_result\n : fold:('t, 'a, 'b) fold\n -> init:'b\n -> f:('b -> 'a -> ('b, 'e) Result.t)\n -> 't\n -> ('b, 'e) Result.t\n\n val fold_until\n : fold:('t, 'a, 'b) fold\n -> init:'b\n -> f:('b -> 'a -> ('b, 'final) Continue_or_stop.t)\n -> finish:('b -> 'final)\n -> 't\n -> 'final\n\n (** Generic definitions of container operations in terms of [iter] and [length]. *)\n val is_empty : iter:('t, 'a) iter -> 't -> bool\n\n val exists : iter:('t, 'a) iter -> 't -> f:('a -> bool) -> bool\n val for_all : iter:('t, 'a) iter -> 't -> f:('a -> bool) -> bool\n val find : iter:('t, 'a) iter -> 't -> f:('a -> bool) -> 'a option\n val find_map : iter:('t, 'a) iter -> 't -> f:('a -> 'b option) -> 'b option\n val to_array : length:'t length -> iter:('t, 'a) iter -> 't -> 'a array\n\n (** The idiom for using [Container.Make] is to bind the resulting module and to\n explicitly import each of the functions that one wants:\n\n {[\n module C = Container.Make (struct ... end)\n let count = C.count\n let exists = C.exists\n let find = C.find\n (* ... *)\n ]}\n\n This is preferable to:\n\n {[\n include Container.Make (struct ... end)\n ]}\n\n because the [include] makes it too easy to shadow specialized implementations of\n container functions ([length] being a common one).\n\n [Container.Make0] is like [Container.Make], but for monomorphic containers like\n [string]. *)\n module Make (T : Make_arg) : S1 with type 'a t := 'a T.t\n\n module Make0 (T : Make0_arg) : S0 with type t := T.t and type elt := T.Elt.t\nend\n","open! Import\nmodule Array = Array0\nmodule List = List0\ninclude Container_intf\n\nlet with_return = With_return.with_return\n\ntype ('t, 'a, 'accum) fold = 't -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum\ntype ('t, 'a) iter = 't -> f:('a -> unit) -> unit\ntype 't length = 't -> int\n\nlet iter ~fold t ~f = fold t ~init:() ~f:(fun () a -> f a)\nlet count ~fold t ~f = fold t ~init:0 ~f:(fun n a -> if f a then n + 1 else n)\n\nlet sum (type a) ~fold (module M : Summable with type t = a) t ~f =\n fold t ~init:M.zero ~f:(fun n a -> M.( + ) n (f a))\n;;\n\nlet fold_result ~fold ~init ~f t =\n with_return (fun { return } ->\n Result.Ok\n (fold t ~init ~f:(fun acc item ->\n match f acc item with\n | Result.Ok x -> x\n | Error _ as e -> return e)))\n;;\n\nlet fold_until ~fold ~init ~f ~finish t =\n with_return (fun { return } ->\n finish\n (fold t ~init ~f:(fun acc item ->\n match f acc item with\n | Continue_or_stop.Continue x -> x\n | Stop x -> return x)))\n;;\n\nlet min_elt ~fold t ~compare =\n fold t ~init:None ~f:(fun acc elt ->\n match acc with\n | None -> Some elt\n | Some min -> if compare min elt > 0 then Some elt else acc)\n;;\n\nlet max_elt ~fold t ~compare =\n fold t ~init:None ~f:(fun acc elt ->\n match acc with\n | None -> Some elt\n | Some max -> if compare max elt < 0 then Some elt else acc)\n;;\n\nlet length ~fold c = fold c ~init:0 ~f:(fun acc _ -> acc + 1)\n\nlet is_empty ~iter c =\n with_return (fun r ->\n iter c ~f:(fun _ -> r.return false);\n true)\n;;\n\nlet exists ~iter c ~f =\n with_return (fun r ->\n iter c ~f:(fun x -> if f x then r.return true);\n false)\n;;\n\nlet for_all ~iter c ~f =\n with_return (fun r ->\n iter c ~f:(fun x -> if not (f x) then r.return false);\n true)\n;;\n\nlet find_map ~iter t ~f =\n with_return (fun r ->\n iter t ~f:(fun x ->\n match f x with\n | None -> ()\n | Some _ as res -> r.return res);\n None)\n;;\n\nlet find ~iter c ~f =\n with_return (fun r ->\n iter c ~f:(fun x -> if f x then r.return (Some x));\n None)\n;;\n\nlet to_list ~fold c = List.rev (fold c ~init:[] ~f:(fun acc x -> x :: acc))\n\nlet to_array ~length ~iter c =\n let array = ref [||] in\n let i = ref 0 in\n iter c ~f:(fun x ->\n if !i = 0 then array := Array.create ~len:(length c) x;\n !array.(!i) <- x;\n incr i);\n !array\n;;\n\nmodule Make_gen (T : Make_gen_arg) : sig\n include Generic with type 'a t := 'a T.t with type 'a elt := 'a T.elt\nend = struct\n let fold = T.fold\n\n let iter =\n match T.iter with\n | `Custom iter -> iter\n | `Define_using_fold -> fun t ~f -> iter ~fold t ~f\n ;;\n\n let length =\n match T.length with\n | `Custom length -> length\n | `Define_using_fold -> fun t -> length ~fold t\n ;;\n\n let is_empty t = is_empty ~iter t\n let sum m t = sum ~fold m t\n let count t ~f = count ~fold t ~f\n let exists t ~f = exists ~iter t ~f\n let for_all t ~f = for_all ~iter t ~f\n let find_map t ~f = find_map ~iter t ~f\n let find t ~f = find ~iter t ~f\n let to_list t = to_list ~fold t\n let to_array t = to_array ~length ~iter t\n let min_elt t ~compare = min_elt ~fold t ~compare\n let max_elt t ~compare = max_elt ~fold t ~compare\n let fold_result t ~init ~f = fold_result t ~fold ~init ~f\n let fold_until t ~init ~f ~finish = fold_until t ~fold ~init ~f ~finish\nend\n\nmodule Make (T : Make_arg) = struct\n include Make_gen (struct\n include T\n\n type 'a elt = 'a\n end)\n\n let mem t a ~equal = exists t ~f:(equal a)\nend\n\nmodule Make0 (T : Make0_arg) = struct\n include Make_gen (struct\n include (T : Make0_arg with type t := T.t with module Elt := T.Elt)\n\n type 'a t = T.t\n type 'a elt = T.Elt.t\n end)\n\n let mem t elt = exists t ~f:(T.Elt.equal elt)\nend\n\nopen T\n\n\n(* The following functors exist as a consistency check among all the various [S?]\n interfaces. They ensure that each particular [S?] is an instance of a more generic\n signature. *)\nmodule Check\n (T : T1)\n (Elt : T1)\n (M : Generic with type 'a t := 'a T.t with type 'a elt := 'a Elt.t) =\nstruct end\n\nmodule Check_S0 (M : S0) =\n Check\n (struct\n type 'a t = M.t\n end)\n (struct\n type 'a t = M.elt\n end)\n (M)\n\nmodule Check_S0_phantom (M : S0_phantom) =\n Check\n (struct\n type 'a t = 'a M.t\n end)\n (struct\n type 'a t = M.elt\n end)\n (M)\n\nmodule Check_S1 (M : S1) =\n Check\n (struct\n type 'a t = 'a M.t\n end)\n (struct\n type 'a t = 'a\n end)\n (M)\n\ntype phantom\n\nmodule Check_S1_phantom (M : S1_phantom) =\n Check\n (struct\n type 'a t = ('a, phantom) M.t\n end)\n (struct\n type 'a t = 'a\n end)\n (M)\n\nmodule Check_S1_phantom_invariant (M : S1_phantom_invariant) =\n Check\n (struct\n type 'a t = ('a, phantom) M.t\n end)\n (struct\n type 'a t = 'a\n end)\n (M)\n","open! Import\n\ntype 'a t = 'a lazy_t [@@deriving_inline sexp]\n\nlet t_of_sexp : 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t =\n lazy_t_of_sexp\n;;\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n sexp_of_lazy_t\n;;\n\n[@@@end]\n\ninclude (Caml.Lazy : module type of Caml.Lazy with type 'a t := 'a t)\n\nlet map t ~f = lazy (f (force t))\n\nlet compare compare_a t1 t2 =\n if phys_equal t1 t2 then 0 else compare_a (force t1) (force t2)\n;;\n\nlet hash_fold_t = Hash.Builtin.hash_fold_lazy_t\n\ninclude Monad.Make (struct\n type nonrec 'a t = 'a t\n\n let return x = from_val x\n let bind t ~f = lazy (force (f (force t)))\n let map = map\n let map = `Custom map\n end)\n\nmodule T_unforcing = struct\n type nonrec 'a t = 'a t\n\n let sexp_of_t sexp_of_a t =\n if is_val t then sexp_of_a (force t) else sexp_of_string \"\"\n ;;\nend\n","open! Import\n\nmodule type Basic = sig\n type 'a t\n\n val bind : 'a t -> f:('a -> 'b t) -> 'b t\n val return : 'a -> 'a t\n\n (** The following identities ought to hold (for some value of =):\n\n - [return x >>= f = f x]\n - [t >>= fun x -> return x = t]\n - [(t >>= f) >>= g = t >>= fun x -> (f x >>= g)]\n\n Note: [>>=] is the infix notation for [bind]) *)\n\n (** The [map] argument to [Monad.Make] says how to implement the monad's [map] function.\n [`Define_using_bind] means to define [map t ~f = bind t ~f:(fun a -> return (f a))].\n [`Custom] overrides the default implementation, presumably with something more\n efficient.\n\n Some other functions returned by [Monad.Make] are defined in terms of [map], so\n passing in a more efficient [map] will improve their efficiency as well. *)\n val map : [ `Define_using_bind | `Custom of 'a t -> f:('a -> 'b) -> 'b t ]\nend\n\nmodule type Infix = sig\n type 'a t\n\n (** [t >>= f] returns a computation that sequences the computations represented by two\n monad elements. The resulting computation first does [t] to yield a value [v], and\n then runs the computation returned by [f v]. *)\n val ( >>= ) : 'a t -> ('a -> 'b t) -> 'b t\n\n (** [t >>| f] is [t >>= (fun a -> return (f a))]. *)\n val ( >>| ) : 'a t -> ('a -> 'b) -> 'b t\nend\n\n(** Opening a module of this type allows one to use the [%bind] and [%map] syntax\n extensions defined by ppx_let, and brings [return] into scope. *)\nmodule type Syntax = sig\n type 'a t\n\n module Let_syntax : sig\n (** These are convenient to have in scope when programming with a monad: *)\n\n val return : 'a -> 'a t\n\n include Infix with type 'a t := 'a t\n\n module Let_syntax : sig\n val return : 'a -> 'a t\n val bind : 'a t -> f:('a -> 'b t) -> 'b t\n val map : 'a t -> f:('a -> 'b) -> 'b t\n val both : 'a t -> 'b t -> ('a * 'b) t\n\n module Open_on_rhs : sig end\n end\n end\nend\n\nmodule type S_without_syntax = sig\n type 'a t\n\n include Infix with type 'a t := 'a t\n module Monad_infix : Infix with type 'a t := 'a t\n\n (** [bind t ~f] = [t >>= f] *)\n val bind : 'a t -> f:('a -> 'b t) -> 'b t\n\n (** [return v] returns the (trivial) computation that returns v. *)\n val return : 'a -> 'a t\n\n (** [map t ~f] is t >>| f. *)\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n (** [join t] is [t >>= (fun t' -> t')]. *)\n val join : 'a t t -> 'a t\n\n (** [ignore_m t] is [map t ~f:(fun _ -> ())]. [ignore_m] used to be called [ignore],\n but we decided that was a bad name, because it shadowed the widely used\n [Caml.ignore]. Some monads still do [let ignore = ignore_m] for historical\n reasons. *)\n val ignore_m : 'a t -> unit t\n\n val all : 'a t list -> 'a list t\n\n (** Like [all], but ensures that every monadic value in the list produces a unit value,\n all of which are discarded rather than being collected into a list. *)\n val all_unit : unit t list -> unit t\nend\n\nmodule type S = sig\n type 'a t\n\n include S_without_syntax with type 'a t := 'a t\n include Syntax with type 'a t := 'a t\nend\n\n(** Multi parameter monad. The second parameter gets unified across all the computation.\n This is used to encode monads working on a multi parameter data structure like\n ([('a,'b) result]). *)\nmodule type Basic2 = sig\n type ('a, 'e) t\n\n val bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t\n val map : [ `Define_using_bind | `Custom of ('a, 'e) t -> f:('a -> 'b) -> ('b, 'e) t ]\n val return : 'a -> ('a, _) t\nend\n\n(** Same as Infix, except the monad type has two arguments. The second is always just\n passed through. *)\nmodule type Infix2 = sig\n type ('a, 'e) t\n\n val ( >>= ) : ('a, 'e) t -> ('a -> ('b, 'e) t) -> ('b, 'e) t\n val ( >>| ) : ('a, 'e) t -> ('a -> 'b) -> ('b, 'e) t\nend\n\nmodule type Syntax2 = sig\n type ('a, 'e) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, _) t\n\n include Infix2 with type ('a, 'e) t := ('a, 'e) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, _) t\n val bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t\n val map : ('a, 'e) t -> f:('a -> 'b) -> ('b, 'e) t\n val both : ('a, 'e) t -> ('b, 'e) t -> ('a * 'b, 'e) t\n\n module Open_on_rhs : sig end\n end\n end\nend\n\n(** The same as S except the monad type has two arguments. The second is always just\n passed through. *)\nmodule type S2 = sig\n type ('a, 'e) t\n\n include Infix2 with type ('a, 'e) t := ('a, 'e) t\n include Syntax2 with type ('a, 'e) t := ('a, 'e) t\n module Monad_infix : Infix2 with type ('a, 'e) t := ('a, 'e) t\n\n val bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t\n val return : 'a -> ('a, _) t\n val map : ('a, 'e) t -> f:('a -> 'b) -> ('b, 'e) t\n val join : (('a, 'e) t, 'e) t -> ('a, 'e) t\n val ignore_m : (_, 'e) t -> (unit, 'e) t\n val all : ('a, 'e) t list -> ('a list, 'e) t\n val all_unit : (unit, 'e) t list -> (unit, 'e) t\nend\n\n(** Multi parameter monad. The second and third parameters get unified across all the\n computation. *)\nmodule type Basic3 = sig\n type ('a, 'd, 'e) t\n\n val bind : ('a, 'd, 'e) t -> f:('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n\n val map\n : [ `Define_using_bind | `Custom of ('a, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'd, 'e) t ]\n\n val return : 'a -> ('a, _, _) t\nend\n\n(** Same as Infix, except the monad type has three arguments. The second and third are\n always just passed through. *)\nmodule type Infix3 = sig\n type ('a, 'd, 'e) t\n\n val ( >>= ) : ('a, 'd, 'e) t -> ('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n val ( >>| ) : ('a, 'd, 'e) t -> ('a -> 'b) -> ('b, 'd, 'e) t\nend\n\nmodule type Syntax3 = sig\n type ('a, 'd, 'e) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, _, _) t\n\n include Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, _, _) t\n val bind : ('a, 'd, 'e) t -> f:('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n val map : ('a, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'd, 'e) t\n val both : ('a, 'd, 'e) t -> ('b, 'd, 'e) t -> ('a * 'b, 'd, 'e) t\n\n module Open_on_rhs : sig end\n end\n end\nend\n\n(** The same as S except the monad type has three arguments. The second and third are\n always just passed through. *)\nmodule type S3 = sig\n type ('a, 'd, 'e) t\n\n include Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n include Syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n module Monad_infix : Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n val bind : ('a, 'd, 'e) t -> f:('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n val return : 'a -> ('a, _, _) t\n val map : ('a, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'd, 'e) t\n val join : (('a, 'd, 'e) t, 'd, 'e) t -> ('a, 'd, 'e) t\n val ignore_m : (_, 'd, 'e) t -> (unit, 'd, 'e) t\n val all : ('a, 'd, 'e) t list -> ('a list, 'd, 'e) t\n val all_unit : (unit, 'd, 'e) t list -> (unit, 'd, 'e) t\nend\n\n(** Indexed monad, in the style of Atkey. The second and third parameters are composed\n across all computation. To see this more clearly, you can look at the type of bind:\n\n {[\n val bind : ('a, 'i, 'j) t -> f:('a -> ('b, 'j, 'k) t) -> ('b, 'i, 'k) t\n ]}\n\n and isolate some of the type variables to see their individual behaviors:\n\n {[\n val bind : 'a -> f:('a -> 'b ) -> 'b\n val bind : 'i, 'j -> 'j, 'k -> 'i, 'k\n ]}\n\n For more information on Atkey-style indexed monads, see:\n\n {v\n Parameterised Notions of Computation\n Robert Atkey\n http://bentnib.org/paramnotions-jfp.pdf\n v} *)\nmodule type Basic_indexed = sig\n type ('a, 'i, 'j) t\n\n val bind : ('a, 'i, 'j) t -> f:('a -> ('b, 'j, 'k) t) -> ('b, 'i, 'k) t\n\n val map\n : [ `Define_using_bind | `Custom of ('a, 'i, 'j) t -> f:('a -> 'b) -> ('b, 'i, 'j) t ]\n\n val return : 'a -> ('a, 'i, 'i) t\nend\n\n(** Same as Infix, except the monad type has three arguments. The second and third are\n compose across all computation. *)\nmodule type Infix_indexed = sig\n type ('a, 'i, 'j) t\n\n val ( >>= ) : ('a, 'i, 'j) t -> ('a -> ('b, 'j, 'k) t) -> ('b, 'i, 'k) t\n val ( >>| ) : ('a, 'i, 'j) t -> ('a -> 'b) -> ('b, 'i, 'j) t\nend\n\nmodule type Syntax_indexed = sig\n type ('a, 'i, 'j) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, 'i, 'i) t\n\n include Infix_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, 'i, 'i) t\n val bind : ('a, 'i, 'j) t -> f:('a -> ('b, 'j, 'k) t) -> ('b, 'i, 'k) t\n val map : ('a, 'i, 'j) t -> f:('a -> 'b) -> ('b, 'i, 'j) t\n val both : ('a, 'i, 'j) t -> ('b, 'j, 'k) t -> ('a * 'b, 'i, 'k) t\n\n module Open_on_rhs : sig end\n end\n end\nend\n\n(** The same as S except the monad type has three arguments. The second and third are\n composed across all computation. *)\nmodule type S_indexed = sig\n type ('a, 'i, 'j) t\n\n include Infix_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) t\n include Syntax_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) t\n module Monad_infix : Infix_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) t\n\n val bind : ('a, 'i, 'j) t -> f:('a -> ('b, 'j, 'k) t) -> ('b, 'i, 'k) t\n val return : 'a -> ('a, 'i, 'i) t\n val map : ('a, 'i, 'j) t -> f:('a -> 'b) -> ('b, 'i, 'j) t\n val join : (('a, 'j, 'k) t, 'i, 'j) t -> ('a, 'i, 'k) t\n val ignore_m : (_, 'i, 'j) t -> (unit, 'i, 'j) t\n val all : ('a, 'i, 'i) t list -> ('a list, 'i, 'i) t\n val all_unit : (unit, 'i, 'i) t list -> (unit, 'i, 'i) t\nend\n\nmodule S_to_S2 (X : S) : S2 with type ('a, 'e) t = 'a X.t = struct\n type ('a, 'e) t = 'a X.t\n\n include (X : S with type 'a t := 'a X.t)\nend\n\nmodule S2_to_S3 (X : S2) : S3 with type ('a, 'd, 'e) t = ('a, 'd) X.t = struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : S2 with type ('a, 'd) t := ('a, 'd) X.t)\nend\n\nmodule S_to_S_indexed (X : S) : S_indexed with type ('a, 'i, 'j) t = 'a X.t = struct\n type ('a, 'i, 'j) t = 'a X.t\n\n include (X : S with type 'a t := 'a X.t)\nend\n\nmodule S2_to_S (X : S2) : S with type 'a t = ('a, unit) X.t = struct\n type 'a t = ('a, unit) X.t\n\n include (X : S2 with type ('a, 'e) t := ('a, 'e) X.t)\nend\n\nmodule S3_to_S2 (X : S3) : S2 with type ('a, 'e) t = ('a, 'e, unit) X.t = struct\n type ('a, 'e) t = ('a, 'e, unit) X.t\n\n include (X : S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t)\nend\n\nmodule S_indexed_to_S2 (X : S_indexed) : S2 with type ('a, 'e) t = ('a, 'e, 'e) X.t =\nstruct\n type ('a, 'e) t = ('a, 'e, 'e) X.t\n\n include (X : S_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) X.t)\nend\n\nmodule type Monad = sig\n (** A monad is an abstraction of the concept of sequencing of computations. A value of\n type ['a monad] represents a computation that returns a value of type ['a]. *)\n\n module type Basic = Basic\n module type Basic2 = Basic2\n module type Basic3 = Basic3\n module type Basic_indexed = Basic_indexed\n module type Infix = Infix\n module type Infix2 = Infix2\n module type Infix3 = Infix3\n module type Infix_indexed = Infix_indexed\n module type Syntax = Syntax\n module type Syntax2 = Syntax2\n module type Syntax3 = Syntax3\n module type Syntax_indexed = Syntax_indexed\n module type S_without_syntax = S_without_syntax\n module type S = S\n module type S2 = S2\n module type S3 = S3\n module type S_indexed = S_indexed\n\n module Make (X : Basic) : S with type 'a t := 'a X.t\n module Make2 (X : Basic2) : S2 with type ('a, 'e) t := ('a, 'e) X.t\n module Make3 (X : Basic3) : S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t\n\n module Make_indexed (X : Basic_indexed) :\n S_indexed with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t\n\n module Ident : S with type 'a t = 'a\nend\n","open! Import\n\nlet const c _ = c\n\nexternal ignore : _ -> unit = \"%ignore\"\n\n(* this has the same behavior as [Caml.ignore] *)\n\nlet non f x = not (f x)\n\nlet forever f =\n let rec forever () =\n f ();\n forever ()\n in\n try forever () with\n | e -> e\n;;\n\nexternal id : 'a -> 'a = \"%identity\"\nexternal ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\n\n(* The typical use case for these functions is to pass in functional arguments and get\n functions as a result. *)\nlet compose f g x = f (g x)\nlet flip f x y = f y x\nlet rec apply_n_times ~n f x = if n <= 0 then x else apply_n_times ~n:(n - 1) f (f x)\n","open! Import\nmodule Array = Array0\nmodule Either = Either0\n\n\ninclude List1\n\n(* This itself includes [List0]. *)\n\nlet invalid_argf = Printf.invalid_argf\n\nmodule T = struct\n type 'a t = 'a list [@@deriving_inline sexp, sexp_grammar]\n\n let t_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t\n =\n list_of_sexp\n ;;\n\n let sexp_of_t :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t\n =\n sexp_of_list\n ;;\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"list\" ]\n ; ggid = \"j\\132);\\135qH\\158\\135\\222H\\001\\007\\004\\158\\218\"\n ; types =\n [ \"t\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ])) ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ list_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"list.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\nend\n\nmodule Or_unequal_lengths = struct\n type 'a t =\n | Ok of 'a\n | Unequal_lengths\n [@@deriving_inline compare, sexp_of]\n\n let compare : 'a. ('a -> 'a -> int) -> 'a t -> 'a t -> int =\n fun _cmp__a a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match a__001_, b__002_ with\n | Ok _a__003_, Ok _b__004_ -> _cmp__a _a__003_ _b__004_\n | Ok _, _ -> -1\n | _, Ok _ -> 1\n | Unequal_lengths, Unequal_lengths -> 0)\n ;;\n\n let sexp_of_t\n : type a. (a -> Ppx_sexp_conv_lib.Sexp.t) -> a t -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a -> function\n | Ok v0 ->\n let v0 = _of_a v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Ok\"; v0 ]\n | Unequal_lengths -> Ppx_sexp_conv_lib.Sexp.Atom \"Unequal_lengths\"\n ;;\n\n [@@@end]\nend\n\ninclude T\n\nlet invariant f t = iter t ~f\nlet of_list t = t\n\nlet range' ~compare ~stride ?(start = `inclusive) ?(stop = `exclusive) start_i stop_i =\n let next_i = stride start_i in\n let order x y = Ordering.of_int (compare x y) in\n let raise_stride_cannot_return_same_value () =\n invalid_arg \"List.range': stride function cannot return the same value\"\n in\n let initial_stride_order =\n match order start_i next_i with\n | Equal -> raise_stride_cannot_return_same_value ()\n | Less -> `Less\n | Greater -> `Greater\n in\n let rec loop i accum =\n let i_to_stop_order = order i stop_i in\n match i_to_stop_order, initial_stride_order with\n | Less, `Less | Greater, `Greater ->\n (* haven't yet reached [stop_i]. Continue. *)\n let next_i = stride i in\n (match order i next_i, initial_stride_order with\n | Equal, _ -> raise_stride_cannot_return_same_value ()\n | Less, `Greater | Greater, `Less ->\n invalid_arg \"List.range': stride function cannot change direction\"\n | Less, `Less | Greater, `Greater -> loop next_i (i :: accum))\n | Less, `Greater | Greater, `Less ->\n (* stepped past [stop_i]. Finished. *)\n accum\n | Equal, _ ->\n (* reached [stop_i]. Finished. *)\n (match stop with\n | `inclusive -> i :: accum\n | `exclusive -> accum)\n in\n let start_i =\n match start with\n | `inclusive -> start_i\n | `exclusive -> next_i\n in\n rev (loop start_i [])\n;;\n\nlet range ?(stride = 1) ?(start = `inclusive) ?(stop = `exclusive) start_i stop_i =\n if stride = 0 then invalid_arg \"List.range: stride must be non-zero\";\n range' ~compare ~stride:(fun x -> x + stride) ~start ~stop start_i stop_i\n;;\n\nlet hd t =\n match t with\n | [] -> None\n | x :: _ -> Some x\n;;\n\nlet tl t =\n match t with\n | [] -> None\n | _ :: t' -> Some t'\n;;\n\nlet nth t n =\n if n < 0\n then None\n else (\n let rec nth_aux t n =\n match t with\n | [] -> None\n | a :: t -> if n = 0 then Some a else nth_aux t (n - 1)\n in\n nth_aux t n)\n;;\n\nlet nth_exn t n =\n match nth t n with\n | None -> invalid_argf \"List.nth_exn %d called on list of length %d\" n (length t) ()\n | Some a -> a\n;;\n\nlet unordered_append l1 l2 =\n match l1, l2 with\n | [], l | l, [] -> l\n | _ -> rev_append l1 l2\n;;\n\nlet check_length2_exn name l1 l2 =\n let n1 = length l1 in\n let n2 = length l2 in\n if n1 <> n2 then invalid_argf \"length mismatch in %s: %d <> %d\" name n1 n2 ()\n;;\n\nlet check_length3_exn name l1 l2 l3 =\n let n1 = length l1 in\n let n2 = length l2 in\n let n3 = length l3 in\n if n1 <> n2 || n2 <> n3\n then invalid_argf \"length mismatch in %s: %d <> %d || %d <> %d\" name n1 n2 n2 n3 ()\n;;\n\nlet check_length2 l1 l2 ~f =\n if length l1 <> length l2 then Or_unequal_lengths.Unequal_lengths else Ok (f l1 l2)\n;;\n\nlet check_length3 l1 l2 l3 ~f =\n let n1 = length l1 in\n let n2 = length l2 in\n let n3 = length l3 in\n if n1 <> n2 || n2 <> n3 then Or_unequal_lengths.Unequal_lengths else Ok (f l1 l2 l3)\n;;\n\nlet iter2 l1 l2 ~f = check_length2 l1 l2 ~f:(iter2_ok ~f)\n\nlet iter2_exn l1 l2 ~f =\n check_length2_exn \"iter2_exn\" l1 l2;\n iter2_ok l1 l2 ~f\n;;\n\nlet rev_map2 l1 l2 ~f = check_length2 l1 l2 ~f:(rev_map2_ok ~f)\n\nlet rev_map2_exn l1 l2 ~f =\n check_length2_exn \"rev_map2_exn\" l1 l2;\n rev_map2_ok l1 l2 ~f\n;;\n\nlet fold2 l1 l2 ~init ~f = check_length2 l1 l2 ~f:(fold2_ok ~init ~f)\n\nlet fold2_exn l1 l2 ~init ~f =\n check_length2_exn \"fold2_exn\" l1 l2;\n fold2_ok l1 l2 ~init ~f\n;;\n\nlet for_all2 l1 l2 ~f = check_length2 l1 l2 ~f:(for_all2_ok ~f)\n\nlet for_all2_exn l1 l2 ~f =\n check_length2_exn \"for_all2_exn\" l1 l2;\n for_all2_ok l1 l2 ~f\n;;\n\nlet exists2 l1 l2 ~f = check_length2 l1 l2 ~f:(exists2_ok ~f)\n\nlet exists2_exn l1 l2 ~f =\n check_length2_exn \"exists2_exn\" l1 l2;\n exists2_ok l1 l2 ~f\n;;\n\nlet mem t a ~equal =\n let rec loop equal a = function\n | [] -> false\n | b :: bs -> equal a b || loop equal a bs\n in\n loop equal a t\n;;\n\n(* This is a copy of the code from the standard library, with an extra eta-expansion to\n avoid creating partial closures (showed up for [filter]) in profiling). *)\nlet rev_filter t ~f =\n let rec find ~f accu = function\n | [] -> accu\n | x :: l -> if f x then find ~f (x :: accu) l else find ~f accu l\n in\n find ~f [] t\n;;\n\nlet filter t ~f = rev (rev_filter t ~f)\n\nlet find_map t ~f =\n let rec loop = function\n | [] -> None\n | x :: l ->\n (match f x with\n | None -> loop l\n | Some _ as r -> r)\n in\n loop t\n;;\n\nlet find_map_exn =\n let not_found = Not_found_s (Atom \"List.find_map_exn: not found\") in\n let find_map_exn t ~f =\n match find_map t ~f with\n | None -> raise not_found\n | Some x -> x\n in\n (* named to preserve symbol in compiled binary *)\n find_map_exn\n;;\n\nlet find t ~f =\n let rec loop = function\n | [] -> None\n | x :: l -> if f x then Some x else loop l\n in\n loop t\n;;\n\nlet find_exn =\n let not_found = Not_found_s (Atom \"List.find_exn: not found\") in\n let rec find_exn t ~f =\n match t with\n | [] -> raise not_found\n | x :: t -> if f x then x else find_exn t ~f\n in\n (* named to preserve symbol in compiled binary *)\n find_exn\n;;\n\nlet findi t ~f =\n let rec loop i t =\n match t with\n | [] -> None\n | x :: l -> if f i x then Some (i, x) else loop (i + 1) l\n in\n loop 0 t\n;;\n\nlet find_mapi t ~f =\n let rec loop i t =\n match t with\n | [] -> None\n | x :: l ->\n (match f i x with\n | Some _ as result -> result\n | None -> loop (i + 1) l)\n in\n loop 0 t\n;;\n\nlet find_mapi_exn =\n let not_found = Not_found_s (Atom \"List.find_mapi_exn: not found\") in\n let find_mapi_exn t ~f =\n match find_mapi t ~f with\n | None -> raise not_found\n | Some x -> x\n in\n (* named to preserve symbol in compiled binary *)\n find_mapi_exn\n;;\n\nlet for_alli t ~f =\n let rec loop i t =\n match t with\n | [] -> true\n | hd :: tl -> f i hd && loop (i + 1) tl\n in\n loop 0 t\n;;\n\nlet existsi t ~f =\n let rec loop i t =\n match t with\n | [] -> false\n | hd :: tl -> f i hd || loop (i + 1) tl\n in\n loop 0 t\n;;\n\n(** For the container interface. *)\nlet fold_left = fold\n\nlet to_array = Array.of_list\nlet to_list t = t\n\n(** Tail recursive versions of standard [List] module *)\n\nlet slow_append l1 l2 = rev_append (rev l1) l2\n\n(* There are a few optimized list operations here, including append and map. There are\n basically two optimizations in play: loop unrolling, and dynamic switching between\n stack and heap allocation.\n\n The loop-unrolling is straightforward, we just unroll 5 levels of the loop. This makes\n each iteration faster, and also reduces the number of stack frames consumed per list\n element.\n\n The dynamic switching is done by counting the number of stack frames, and then\n switching to the \"slow\" implementation when we exceed a given limit. This means that\n short lists use the fast stack-allocation method, and long lists use a slower one that\n doesn't require stack space. *)\nlet rec count_append l1 l2 count =\n match l2 with\n | [] -> l1\n | _ ->\n (match l1 with\n | [] -> l2\n | [ x1 ] -> x1 :: l2\n | [ x1; x2 ] -> x1 :: x2 :: l2\n | [ x1; x2; x3 ] -> x1 :: x2 :: x3 :: l2\n | [ x1; x2; x3; x4 ] -> x1 :: x2 :: x3 :: x4 :: l2\n | x1 :: x2 :: x3 :: x4 :: x5 :: tl ->\n x1\n :: x2\n :: x3\n :: x4\n :: x5\n :: (if count > 1000 then slow_append tl l2 else count_append tl l2 (count + 1)))\n;;\n\nlet append l1 l2 = count_append l1 l2 0\nlet slow_map l ~f = rev (rev_map l ~f)\n\nlet rec count_map ~f l ctr =\n match l with\n | [] -> []\n | [ x1 ] ->\n let f1 = f x1 in\n [ f1 ]\n | [ x1; x2 ] ->\n let f1 = f x1 in\n let f2 = f x2 in\n [ f1; f2 ]\n | [ x1; x2; x3 ] ->\n let f1 = f x1 in\n let f2 = f x2 in\n let f3 = f x3 in\n [ f1; f2; f3 ]\n | [ x1; x2; x3; x4 ] ->\n let f1 = f x1 in\n let f2 = f x2 in\n let f3 = f x3 in\n let f4 = f x4 in\n [ f1; f2; f3; f4 ]\n | x1 :: x2 :: x3 :: x4 :: x5 :: tl ->\n let f1 = f x1 in\n let f2 = f x2 in\n let f3 = f x3 in\n let f4 = f x4 in\n let f5 = f x5 in\n f1\n :: f2\n :: f3\n :: f4\n :: f5\n :: (if ctr > 1000 then slow_map ~f tl else count_map ~f tl (ctr + 1))\n;;\n\nlet map l ~f = count_map ~f l 0\n\nlet folding_map t ~init ~f =\n let acc = ref init in\n map t ~f:(fun x ->\n let new_acc, y = f !acc x in\n acc := new_acc;\n y)\n;;\n\nlet fold_map t ~init ~f =\n let acc = ref init in\n let result =\n map t ~f:(fun x ->\n let new_acc, y = f !acc x in\n acc := new_acc;\n y)\n in\n !acc, result\n;;\n\nlet ( >>| ) l f = map l ~f\nlet map2_ok l1 l2 ~f = rev (rev_map2_ok l1 l2 ~f)\nlet map2 l1 l2 ~f = check_length2 l1 l2 ~f:(map2_ok ~f)\n\nlet map2_exn l1 l2 ~f =\n check_length2_exn \"map2_exn\" l1 l2;\n map2_ok l1 l2 ~f\n;;\n\nlet rev_map3_ok l1 l2 l3 ~f =\n let rec loop l1 l2 l3 ac =\n match l1, l2, l3 with\n | [], [], [] -> ac\n | x1 :: l1, x2 :: l2, x3 :: l3 -> loop l1 l2 l3 (f x1 x2 x3 :: ac)\n | _ -> assert false\n in\n loop l1 l2 l3 []\n;;\n\nlet rev_map3 l1 l2 l3 ~f = check_length3 l1 l2 l3 ~f:(rev_map3_ok ~f)\n\nlet rev_map3_exn l1 l2 l3 ~f =\n check_length3_exn \"rev_map3_exn\" l1 l2 l3;\n rev_map3_ok l1 l2 l3 ~f\n;;\n\nlet map3_ok l1 l2 l3 ~f = rev (rev_map3_ok l1 l2 l3 ~f)\nlet map3 l1 l2 l3 ~f = check_length3 l1 l2 l3 ~f:(map3_ok ~f)\n\nlet map3_exn l1 l2 l3 ~f =\n check_length3_exn \"map3_exn\" l1 l2 l3;\n map3_ok l1 l2 l3 ~f\n;;\n\nlet rec rev_map_append l1 l2 ~f =\n match l1 with\n | [] -> l2\n | h :: t -> rev_map_append ~f t (f h :: l2)\n;;\n\nlet fold_right l ~f ~init =\n match l with\n | [] -> init (* avoid the allocation of [~f] below *)\n | _ -> fold ~f:(fun a b -> f b a) ~init (rev l)\n;;\n\nlet unzip list =\n let rec loop list l1 l2 =\n match list with\n | [] -> rev l1, rev l2\n | (x, y) :: tl -> loop tl (x :: l1) (y :: l2)\n in\n loop list [] []\n;;\n\nlet unzip3 list =\n let rec loop list l1 l2 l3 =\n match list with\n | [] -> rev l1, rev l2, rev l3\n | (x, y, z) :: tl -> loop tl (x :: l1) (y :: l2) (z :: l3)\n in\n loop list [] [] []\n;;\n\nlet zip_exn l1 l2 =\n check_length2_exn \"zip_exn\" l1 l2;\n map2_ok ~f:(fun a b -> a, b) l1 l2\n;;\n\nlet zip l1 l2 = map2 ~f:(fun a b -> a, b) l1 l2\n\n(** Additional list operations *)\n\nlet rev_mapi l ~f =\n let rec loop i acc = function\n | [] -> acc\n | h :: t -> loop (i + 1) (f i h :: acc) t\n in\n loop 0 [] l\n;;\n\nlet mapi l ~f = rev (rev_mapi l ~f)\n\nlet folding_mapi t ~init ~f =\n let acc = ref init in\n mapi t ~f:(fun i x ->\n let new_acc, y = f i !acc x in\n acc := new_acc;\n y)\n;;\n\nlet fold_mapi t ~init ~f =\n let acc = ref init in\n let result =\n mapi t ~f:(fun i x ->\n let new_acc, y = f i !acc x in\n acc := new_acc;\n y)\n in\n !acc, result\n;;\n\nlet iteri l ~f =\n ignore\n (fold l ~init:0 ~f:(fun i x ->\n f i x;\n i + 1)\n : int)\n;;\n\nlet foldi t ~init ~f =\n snd (fold t ~init:(0, init) ~f:(fun (i, acc) v -> i + 1, f i acc v))\n;;\n\nlet filteri l ~f =\n rev (foldi l ~f:(fun pos acc x -> if f pos x then x :: acc else acc) ~init:[])\n;;\n\nlet reduce l ~f =\n match l with\n | [] -> None\n | hd :: tl -> Some (fold ~init:hd ~f tl)\n;;\n\nlet reduce_exn l ~f =\n match reduce l ~f with\n | None -> invalid_arg \"List.reduce_exn\"\n | Some v -> v\n;;\n\nlet reduce_balanced l ~f =\n (* Call the \"size\" of a value the number of list elements that have been combined into\n it via calls to [f]. We proceed by using [f] to combine elements in the accumulator\n of the same size until we can't combine any more, then getting a new element from the\n input list and repeating.\n\n With this strategy, in the accumulator:\n - we only ever have elements of sizes a power of two\n - we never have more than one element of each size\n - the sum of all the element sizes is equal to the number of elements consumed\n\n These conditions enforce that list of elements of each size is precisely the binary\n expansion of the number of elements consumed: if you've consumed 13 = 0b1101\n elements, you have one element of size 8, one of size 4, and one of size 1. Hence\n when a new element comes along, the number of combinings you need to do is the number\n of trailing 1s in the binary expansion of [num], the number of elements that have\n already gone into the accumulator. The accumulator is in ascending order of size, so\n the next element to combine with is always the head of the list. *)\n let rec step_accum num acc x =\n if num land 1 = 0\n then x :: acc\n else (\n match acc with\n | [] -> assert false\n (* New elements from later in the input list go on the front of the accumulator, so\n the accumulator is in reverse order wrt the original list order, hence [f y x]\n instead of [f x y]. *)\n | y :: ys -> step_accum (num asr 1) ys (f y x))\n in\n (* Experimentally, inlining [foldi] and unrolling this loop a few times can reduce\n runtime down to a third and allocation to 1/16th or so in the microbenchmarks below.\n However, in most use cases [f] is likely to be expensive (otherwise why do you care\n about the order of reduction?) so the overhead of this function itself doesn't really\n matter. If you come up with a use-case where it does, then that's something you might\n want to try: see hg log -pr 49ef065f429d. *)\n match foldi l ~init:[] ~f:step_accum with\n | [] -> None\n | x :: xs -> Some (fold xs ~init:x ~f:(fun x y -> f y x))\n;;\n\nlet reduce_balanced_exn l ~f =\n match reduce_balanced l ~f with\n | None -> invalid_arg \"List.reduce_balanced_exn\"\n | Some v -> v\n;;\n\nlet groupi l ~break =\n let groups =\n foldi l ~init:[] ~f:(fun i acc x ->\n match acc with\n | [] -> [ [ x ] ]\n | current_group :: tl ->\n if break i (hd_exn current_group) x\n then [ x ] :: current_group :: tl (* start new group *)\n else (x :: current_group) :: tl)\n (* extend current group *)\n in\n match groups with\n | [] -> []\n | l -> rev_map l ~f:rev\n;;\n\nlet group l ~break = groupi l ~break:(fun _ x y -> break x y)\n\nlet concat_map l ~f =\n let rec aux acc = function\n | [] -> rev acc\n | hd :: tl -> aux (rev_append (f hd) acc) tl\n in\n aux [] l\n;;\n\nlet concat_mapi l ~f =\n let rec aux cont acc = function\n | [] -> rev acc\n | hd :: tl -> aux (cont + 1) (rev_append (f cont hd) acc) tl\n in\n aux 0 [] l\n;;\n\nlet merge l1 l2 ~compare =\n let rec loop acc l1 l2 =\n match l1, l2 with\n | [], l2 -> rev_append acc l2\n | l1, [] -> rev_append acc l1\n | h1 :: t1, h2 :: t2 ->\n if compare h1 h2 <= 0 then loop (h1 :: acc) t1 l2 else loop (h2 :: acc) l1 t2\n in\n loop [] l1 l2\n;;\n\ninclude struct\n (* We are explicit about what we import from the general Monad functor so that we don't\n accidentally rebind more efficient list-specific functions. *)\n module Monad = Monad.Make (struct\n type 'a t = 'a list\n\n let bind x ~f = concat_map x ~f\n let map = `Custom map\n let return x = [ x ]\n end)\n\n open Monad\n module Monad_infix = Monad_infix\n module Let_syntax = Let_syntax\n\n let ignore_m = ignore_m\n let join = join\n let bind = bind\n let ( >>= ) t f = bind t ~f\n let return = return\n let all = all\n let all_unit = all_unit\nend\n\n(** returns final element of list *)\nlet rec last_exn list =\n match list with\n | [ x ] -> x\n | _ :: tl -> last_exn tl\n | [] -> invalid_arg \"List.last\"\n;;\n\n(** optionally returns final element of list *)\nlet rec last list =\n match list with\n | [ x ] -> Some x\n | _ :: tl -> last tl\n | [] -> None\n;;\n\nlet rec is_prefix list ~prefix ~equal =\n match prefix with\n | [] -> true\n | hd :: tl ->\n (match list with\n | [] -> false\n | hd' :: tl' -> equal hd hd' && is_prefix tl' ~prefix:tl ~equal)\n;;\n\nlet find_consecutive_duplicate t ~equal =\n match t with\n | [] -> None\n | a1 :: t ->\n let rec loop a1 t =\n match t with\n | [] -> None\n | a2 :: t -> if equal a1 a2 then Some (a1, a2) else loop a2 t\n in\n loop a1 t\n;;\n\n(* returns list without adjacent duplicates *)\nlet remove_consecutive_duplicates ?(which_to_keep = `Last) list ~equal =\n let rec loop to_keep accum = function\n | [] -> to_keep :: accum\n | hd :: tl ->\n if equal hd to_keep\n then (\n let to_keep =\n match which_to_keep with\n | `First -> to_keep\n | `Last -> hd\n in\n loop to_keep accum tl)\n else loop hd (to_keep :: accum) tl\n in\n match list with\n | [] -> []\n | hd :: tl -> rev (loop hd [] tl)\n;;\n\n(** returns sorted version of list with duplicates removed *)\nlet dedup_and_sort ~compare list =\n match list with\n | [] | [ _ ] -> list (* performance hack *)\n | _ ->\n let equal x x' = compare x x' = 0 in\n let sorted = sort ~compare list in\n remove_consecutive_duplicates ~equal sorted\n;;\n\nlet find_a_dup ~compare l =\n let sorted = sort ~compare l in\n let rec loop l =\n match l with\n | [] | [ _ ] -> None\n | hd1 :: (hd2 :: _ as tl) -> if compare hd1 hd2 = 0 then Some hd1 else loop tl\n in\n loop sorted\n;;\n\nlet contains_dup ~compare lst =\n match find_a_dup ~compare lst with\n | Some _ -> true\n | None -> false\n;;\n\nlet find_all_dups ~compare l =\n (* We add this reversal, so we can skip a [rev] at the end. We could skip\n [rev] anyway since we don not give any ordering guarantees, but it is\n nice to get results in natural order. *)\n let compare a b = -1 * compare a b in\n let sorted = sort ~compare l in\n (* Walk the list and record the first of each consecutive run of identical elements *)\n let rec loop sorted prev ~already_recorded acc =\n match sorted with\n | [] -> acc\n | hd :: tl ->\n if compare prev hd <> 0\n then loop tl hd ~already_recorded:false acc\n else if already_recorded\n then loop tl hd ~already_recorded:true acc\n else loop tl hd ~already_recorded:true (hd :: acc)\n in\n match sorted with\n | [] -> []\n | hd :: tl -> loop tl hd ~already_recorded:false []\n;;\n\nlet count t ~f = Container.count ~fold t ~f\nlet sum m t ~f = Container.sum ~fold m t ~f\nlet min_elt t ~compare = Container.min_elt ~fold t ~compare\nlet max_elt t ~compare = Container.max_elt ~fold t ~compare\n\nlet counti t ~f =\n foldi t ~init:0 ~f:(fun idx count a -> if f idx a then count + 1 else count)\n;;\n\nlet init n ~f =\n if n < 0 then invalid_argf \"List.init %d\" n ();\n let rec loop i accum =\n assert (i >= 0);\n if i = 0 then accum else loop (i - 1) (f (i - 1) :: accum)\n in\n loop n []\n;;\n\nlet rev_filter_map l ~f =\n let rec loop l accum =\n match l with\n | [] -> accum\n | hd :: tl ->\n (match f hd with\n | Some x -> loop tl (x :: accum)\n | None -> loop tl accum)\n in\n loop l []\n;;\n\nlet filter_map l ~f = rev (rev_filter_map l ~f)\n\nlet rev_filter_mapi l ~f =\n let rec loop i l accum =\n match l with\n | [] -> accum\n | hd :: tl ->\n (match f i hd with\n | Some x -> loop (i + 1) tl (x :: accum)\n | None -> loop (i + 1) tl accum)\n in\n loop 0 l []\n;;\n\nlet filter_mapi l ~f = rev (rev_filter_mapi l ~f)\nlet filter_opt l = filter_map l ~f:Fn.id\n\nlet partition3_map t ~f =\n let rec loop t fst snd trd =\n match t with\n | [] -> rev fst, rev snd, rev trd\n | x :: t ->\n (match f x with\n | `Fst y -> loop t (y :: fst) snd trd\n | `Snd y -> loop t fst (y :: snd) trd\n | `Trd y -> loop t fst snd (y :: trd))\n in\n loop t [] [] []\n;;\n\nlet partition_tf t ~f =\n let f x : _ Either.t = if f x then First x else Second x in\n partition_map t ~f\n;;\n\nlet partition_result t = partition_map t ~f:Result.to_either\n\nmodule Assoc = struct\n type ('a, 'b) t = ('a * 'b) list [@@deriving_inline sexp]\n\n let t_of_sexp :\n 'a 'b. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> (Ppx_sexp_conv_lib.Sexp.t -> 'b)\n -> Ppx_sexp_conv_lib.Sexp.t -> ('a, 'b) t\n =\n let _tp_loc = \"list.ml.Assoc.t\" in\n fun _of_a _of_b t ->\n list_of_sexp\n (function\n | Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ] ->\n let v0 = _of_a v0\n and v1 = _of_b v1 in\n v0, v1\n | sexp -> Ppx_sexp_conv_lib.Conv_error.tuple_of_size_n_expected _tp_loc 2 sexp)\n t\n ;;\n\n let sexp_of_t :\n 'a 'b. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> ('b -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('a, 'b) t -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a _of_b v ->\n sexp_of_list\n (function\n | v0, v1 ->\n let v0 = _of_a v0\n and v1 = _of_b v1 in\n Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ])\n v\n ;;\n\n [@@@end]\n\n let find t ~equal key =\n match find t ~f:(fun (key', _) -> equal key key') with\n | None -> None\n | Some x -> Some (snd x)\n ;;\n\n let find_exn =\n let not_found = Not_found_s (Atom \"List.Assoc.find_exn: not found\") in\n let find_exn t ~equal key =\n match find t key ~equal with\n | None -> raise not_found\n | Some value -> value\n in\n (* named to preserve symbol in compiled binary *)\n find_exn\n ;;\n\n let mem t ~equal key =\n match find t ~equal key with\n | None -> false\n | Some _ -> true\n ;;\n\n let remove t ~equal key = filter t ~f:(fun (key', _) -> not (equal key key'))\n\n let add t ~equal key value =\n (* the remove doesn't change the map semantics, but keeps the list small *)\n (key, value) :: remove t ~equal key\n ;;\n\n let inverse t = map t ~f:(fun (x, y) -> y, x)\n let map t ~f = map t ~f:(fun (key, value) -> key, f value)\nend\n\nlet sub l ~pos ~len =\n (* We use [pos > length l - len] rather than [pos + len > length l] to avoid the\n possibility of overflow. *)\n if pos < 0 || len < 0 || pos > length l - len then invalid_arg \"List.sub\";\n rev\n (foldi l ~init:[] ~f:(fun i acc el ->\n if i >= pos && i < pos + len then el :: acc else acc))\n;;\n\nlet split_n t_orig n =\n if n <= 0\n then [], t_orig\n else (\n let rec loop n t accum =\n if n = 0\n then rev accum, t\n else (\n match t with\n | [] -> t_orig, [] (* in this case, t_orig = rev accum *)\n | hd :: tl -> loop (n - 1) tl (hd :: accum))\n in\n loop n t_orig [])\n;;\n\n(* copied from [split_n] to avoid allocating a tuple *)\nlet take t_orig n =\n if n <= 0\n then []\n else (\n let rec loop n t accum =\n if n = 0\n then rev accum\n else (\n match t with\n | [] -> t_orig\n | hd :: tl -> loop (n - 1) tl (hd :: accum))\n in\n loop n t_orig [])\n;;\n\nlet rec drop t n =\n match t with\n | _ :: tl when n > 0 -> drop tl (n - 1)\n | t -> t\n;;\n\nlet chunks_of l ~length =\n if length <= 0\n then invalid_argf \"List.chunks_of: Expected length > 0, got %d\" length ();\n let rec aux of_length acc l =\n match l with\n | [] -> rev acc\n | _ :: _ ->\n let sublist, l = split_n l length in\n aux of_length (sublist :: acc) l\n in\n aux length [] l\n;;\n\nlet split_while xs ~f =\n let rec loop acc = function\n | hd :: tl when f hd -> loop (hd :: acc) tl\n | t -> rev acc, t\n in\n loop [] xs\n;;\n\n(* copied from [split_while] to avoid allocating a tuple *)\nlet take_while xs ~f =\n let rec loop acc = function\n | hd :: tl when f hd -> loop (hd :: acc) tl\n | _ -> rev acc\n in\n loop [] xs\n;;\n\nlet rec drop_while t ~f =\n match t with\n | hd :: tl when f hd -> drop_while tl ~f\n | t -> t\n;;\n\nlet drop_last t =\n match rev t with\n | [] -> None\n | _ :: lst -> Some (rev lst)\n;;\n\nlet drop_last_exn t =\n match drop_last t with\n | None -> failwith \"List.drop_last_exn: empty list\"\n | Some lst -> lst\n;;\n\nlet cartesian_product list1 list2 =\n if is_empty list2\n then []\n else (\n let rec loop l1 l2 accum =\n match l1 with\n | [] -> accum\n | hd :: tl -> loop tl l2 (rev_append (map ~f:(fun x -> hd, x) l2) accum)\n in\n rev (loop list1 list2 []))\n;;\n\nlet concat l = fold_right l ~init:[] ~f:append\nlet concat_no_order l = fold l ~init:[] ~f:(fun acc l -> rev_append l acc)\nlet cons x l = x :: l\n\nlet is_sorted l ~compare =\n let rec loop l =\n match l with\n | [] | [ _ ] -> true\n | x1 :: (x2 :: _ as rest) -> compare x1 x2 <= 0 && loop rest\n in\n loop l\n;;\n\nlet is_sorted_strictly l ~compare =\n let rec loop l =\n match l with\n | [] | [ _ ] -> true\n | x1 :: (x2 :: _ as rest) -> compare x1 x2 < 0 && loop rest\n in\n loop l\n;;\n\nmodule Infix = struct\n let ( @ ) = append\nend\n\nlet permute ?(random_state = Random.State.default) list =\n match list with\n (* special cases to speed things up in trivial cases *)\n | [] | [ _ ] -> list\n | [ x; y ] -> if Random.State.bool random_state then [ y; x ] else list\n | _ ->\n let arr = Array.of_list list in\n Array_permute.permute arr ~random_state;\n Array.to_list arr\n;;\n\nlet random_element_exn ?(random_state = Random.State.default) list =\n if is_empty list\n then failwith \"List.random_element_exn: empty list\"\n else nth_exn list (Random.State.int random_state (length list))\n;;\n\nlet random_element ?(random_state = Random.State.default) list =\n try Some (random_element_exn ~random_state list) with\n | _ -> None\n;;\n\nlet rec compare cmp a b =\n match a, b with\n | [], [] -> 0\n | [], _ -> -1\n | _, [] -> 1\n | x :: xs, y :: ys ->\n let n = cmp x y in\n if n = 0 then compare cmp xs ys else n\n;;\n\nlet hash_fold_t = hash_fold_list\n\nlet equal equal t1 t2 =\n let rec loop ~equal t1 t2 =\n match t1, t2 with\n | [], [] -> true\n | x1 :: t1, x2 :: t2 -> equal x1 x2 && loop ~equal t1 t2\n | _ -> false\n in\n loop ~equal t1 t2\n;;\n\nlet transpose =\n let rec transpose_aux t rev_columns =\n match\n partition_map t ~f:(function\n | [] -> Second ()\n | x :: xs -> First (x, xs))\n with\n | _ :: _, _ :: _ -> None\n | [], _ -> Some (rev_append rev_columns [])\n | heads_and_tails, [] ->\n let column, trimmed_rows = unzip heads_and_tails in\n transpose_aux trimmed_rows (column :: rev_columns)\n in\n fun t -> transpose_aux t []\n;;\n\nexception Transpose_got_lists_of_different_lengths of int list [@@deriving_inline sexp]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Transpose_got_lists_of_different_lengths]\n (function\n | Transpose_got_lists_of_different_lengths v0 ->\n let v0 = sexp_of_list sexp_of_int v0 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom\n \"list.ml.Transpose_got_lists_of_different_lengths\"\n ; v0\n ]\n | _ -> assert false)\n;;\n\n[@@@end]\n\nlet transpose_exn l =\n match transpose l with\n | Some l -> l\n | None -> raise (Transpose_got_lists_of_different_lengths (map l ~f:length))\n;;\n\nlet intersperse t ~sep =\n match t with\n | [] -> []\n | x :: xs -> x :: fold_right xs ~init:[] ~f:(fun y acc -> sep :: y :: acc)\n;;\n\nlet fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\nlet fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\n\nlet is_suffix list ~suffix ~equal:equal_elt =\n let list_len = length list in\n let suffix_len = length suffix in\n list_len >= suffix_len && equal equal_elt (drop list (list_len - suffix_len)) suffix\n;;\n","open! Import\n\ntype t =\n | Less\n | Equal\n | Greater\n[@@deriving_inline compare, hash, enumerate, sexp]\n\nlet compare = (Ppx_compare_lib.polymorphic_compare : t -> t -> int)\n\nlet (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n (fun hsv arg ->\n match arg with\n | Less -> Ppx_hash_lib.Std.Hash.fold_int hsv 0\n | Equal -> Ppx_hash_lib.Std.Hash.fold_int hsv 1\n | Greater -> Ppx_hash_lib.Std.Hash.fold_int hsv 2\n : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state)\n;;\n\nlet (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func arg =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (let hsv = Ppx_hash_lib.Std.Hash.create () in\n hash_fold_t hsv arg)\n in\n fun x -> func x\n;;\n\nlet all = ([ Less; Equal; Greater ] : t list)\n\nlet t_of_sexp =\n (let _tp_loc = \"ordering.ml.t\" in\n function\n | Ppx_sexp_conv_lib.Sexp.Atom (\"less\" | \"Less\") -> Less\n | Ppx_sexp_conv_lib.Sexp.Atom (\"equal\" | \"Equal\") -> Equal\n | Ppx_sexp_conv_lib.Sexp.Atom (\"greater\" | \"Greater\") -> Greater\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"less\" | \"Less\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"equal\" | \"Equal\") :: _)\n as sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"greater\" | \"Greater\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> t)\n;;\n\nlet sexp_of_t =\n (function\n | Less -> Ppx_sexp_conv_lib.Sexp.Atom \"Less\"\n | Equal -> Ppx_sexp_conv_lib.Sexp.Atom \"Equal\"\n | Greater -> Ppx_sexp_conv_lib.Sexp.Atom \"Greater\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet equal a b = compare a b = 0\n\nmodule Export = struct\n type _ordering = t =\n | Less\n | Equal\n | Greater\nend\n\nlet of_int n = if n < 0 then Less else if n = 0 then Equal else Greater\n\nlet to_int = function\n | Less -> -1\n | Equal -> 0\n | Greater -> 1\n;;\n","open! Import\ninclude Applicative_intf\n\n(** This module serves mostly as a partial check that [S2] and [S] are in sync, but\n actually calling it is occasionally useful. *)\nmodule S_to_S2 (X : S) : S2 with type ('a, 'e) t = 'a X.t = struct\n type ('a, 'e) t = 'a X.t\n\n include (X : S with type 'a t := 'a X.t)\nend\n\nmodule S2_to_S (X : S2) : S with type 'a t = ('a, unit) X.t = struct\n type 'a t = ('a, unit) X.t\n\n include (X : S2 with type ('a, 'e) t := ('a, 'e) X.t)\nend\n\nmodule S2_to_S3 (X : S2) : S3 with type ('a, 'd, 'e) t = ('a, 'd) X.t = struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : S2 with type ('a, 'd) t := ('a, 'd) X.t)\nend\n\nmodule S3_to_S2 (X : S3) : S2 with type ('a, 'd) t = ('a, 'd, unit) X.t = struct\n type ('a, 'd) t = ('a, 'd, unit) X.t\n\n include (X : S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t)\nend\n\n(* These functors serve only to check that the signatures for various Foo and Foo2 module\n types don't drift apart over time.\n*)\nmodule Check_compatibility = struct\n module Applicative_infix_to_Applicative_infix2 (X : Applicative_infix) :\n Applicative_infix2 with type ('a, 'e) t = 'a X.t = struct\n type ('a, 'e) t = 'a X.t\n\n include (X : Applicative_infix with type 'a t := 'a X.t)\n end\n\n module Applicative_infix2_to_Applicative_infix (X : Applicative_infix2) :\n Applicative_infix with type 'a t = ('a, unit) X.t = struct\n type 'a t = ('a, unit) X.t\n\n include (X : Applicative_infix2 with type ('a, 'e) t := ('a, 'e) X.t)\n end\n\n module Applicative_infix2_to_Applicative_infix3 (X : Applicative_infix2) :\n Applicative_infix3 with type ('a, 'd, 'e) t = ('a, 'd) X.t = struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : Applicative_infix2 with type ('a, 'd) t := ('a, 'd) X.t)\n end\n\n module Applicative_infix3_to_Applicative_infix2 (X : Applicative_infix3) :\n Applicative_infix2 with type ('a, 'd) t = ('a, 'd, unit) X.t = struct\n type ('a, 'd) t = ('a, 'd, unit) X.t\n\n include (X : Applicative_infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t)\n end\n\n module Let_syntax_to_Let_syntax2 (X : Let_syntax) :\n Let_syntax2 with type ('a, 'e) t = 'a X.t = struct\n type ('a, 'e) t = 'a X.t\n\n include (X : Let_syntax with type 'a t := 'a X.t)\n end\n\n module Let_syntax2_to_Let_syntax (X : Let_syntax2) :\n Let_syntax with type 'a t = ('a, unit) X.t = struct\n type 'a t = ('a, unit) X.t\n\n include (X : Let_syntax2 with type ('a, 'e) t := ('a, 'e) X.t)\n end\n\n module Let_syntax2_to_Let_syntax3 (X : Let_syntax2) :\n Let_syntax3 with type ('a, 'd, 'e) t = ('a, 'd) X.t = struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : Let_syntax2 with type ('a, 'd) t := ('a, 'd) X.t)\n end\n\n module Let_syntax3_to_Let_syntax2 (X : Let_syntax3) :\n Let_syntax2 with type ('a, 'd) t = ('a, 'd, unit) X.t = struct\n type ('a, 'd) t = ('a, 'd, unit) X.t\n\n include (X : Let_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t)\n end\nend\n\nmodule Make3 (X : Basic3) : S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t = struct\n include X\n\n let ( <*> ) = apply\n let derived_map t ~f = return f <*> t\n\n let map =\n match X.map with\n | `Define_using_apply -> derived_map\n | `Custom x -> x\n ;;\n\n let ( >>| ) t f = map t ~f\n let map2 ta tb ~f = map ~f ta <*> tb\n let map3 ta tb tc ~f = map ~f ta <*> tb <*> tc\n let all ts = List.fold_right ts ~init:(return []) ~f:(map2 ~f:(fun x xs -> x :: xs))\n let both ta tb = map2 ta tb ~f:(fun a b -> a, b)\n let ( *> ) u v = return (fun () y -> y) <*> u <*> v\n let ( <* ) u v = return (fun x () -> x) <*> u <*> v\n let all_unit ts = List.fold ts ~init:(return ()) ~f:( *> )\n\n module Applicative_infix = struct\n let ( <*> ) = ( <*> )\n let ( *> ) = ( *> )\n let ( <* ) = ( <* )\n let ( >>| ) = ( >>| )\n end\nend\n\nmodule Make2 (X : Basic2) : S2 with type ('a, 'e) t := ('a, 'e) X.t = Make3 (struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : Basic2 with type ('a, 'e) t := ('a, 'e) X.t)\n end)\n\nmodule Make (X : Basic) : S with type 'a t := 'a X.t = Make2 (struct\n type ('a, 'e) t = 'a X.t\n\n include (X : Basic with type 'a t := 'a X.t)\n end)\n\nmodule Make_let_syntax3\n (X : For_let_syntax3) (Intf : sig\n module type S\n end)\n (Impl : Intf.S) =\nstruct\n module Let_syntax = struct\n include X\n\n module Let_syntax = struct\n include X\n module Open_on_rhs = Impl\n end\n end\nend\n\nmodule Make_let_syntax2\n (X : For_let_syntax2) (Intf : sig\n module type S\n end)\n (Impl : Intf.S) =\n Make_let_syntax3\n (struct\n type ('a, 'd, _) t = ('a, 'd) X.t\n\n include (X : For_let_syntax2 with type ('a, 'e) t := ('a, 'e) X.t)\n end)\n (Intf)\n (Impl)\n\nmodule Make_let_syntax\n (X : For_let_syntax) (Intf : sig\n module type S\n end)\n (Impl : Intf.S) =\n Make_let_syntax2\n (struct\n type ('a, _) t = 'a X.t\n\n include (X : For_let_syntax with type 'a t := 'a X.t)\n end)\n (Intf)\n (Impl)\n\nmodule Make3_using_map2 (X : Basic3_using_map2) = Make3 (struct\n include X\n\n let apply tf tx = map2 tf tx ~f:(fun f x -> f x)\n\n let map =\n match map with\n | `Custom map -> `Custom map\n | `Define_using_map2 -> `Define_using_apply\n ;;\n end)\n\nmodule Make2_using_map2 (X : Basic2_using_map2) :\n S2 with type ('a, 'e) t := ('a, 'e) X.t = Make3_using_map2 (struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : Basic2_using_map2 with type ('a, 'e) t := ('a, 'e) X.t)\n end)\n\nmodule Make_using_map2 (X : Basic_using_map2) : S with type 'a t := 'a X.t =\n Make2_using_map2 (struct\n type ('a, 'e) t = 'a X.t\n\n include (X : Basic_using_map2 with type 'a t := 'a X.t)\n end)\n\nmodule Of_monad2 (M : Monad.S2) : S2 with type ('a, 'e) t := ('a, 'e) M.t = Make2 (struct\n type ('a, 'e) t = ('a, 'e) M.t\n\n let return = M.return\n let apply mf mx = M.bind mf ~f:(fun f -> M.map mx ~f)\n let map = `Custom M.map\n end)\n\nmodule Of_monad (M : Monad.S) : S with type 'a t := 'a M.t = Of_monad2 (struct\n type ('a, _) t = 'a M.t\n\n include (M : Monad.S with type 'a t := 'a M.t)\n end)\n\nmodule Compose (F : S) (G : S) : S with type 'a t = 'a F.t G.t = struct\n type 'a t = 'a F.t G.t\n\n include Make (struct\n type nonrec 'a t = 'a t\n\n let return a = G.return (F.return a)\n let apply tf tx = G.apply (G.map ~f:F.apply tf) tx\n let custom_map t ~f = G.map ~f:(F.map ~f) t\n let map = `Custom custom_map\n end)\nend\n\nmodule Pair (F : S) (G : S) : S with type 'a t = 'a F.t * 'a G.t = struct\n type 'a t = 'a F.t * 'a G.t\n\n include Make (struct\n type nonrec 'a t = 'a t\n\n let return a = F.return a, G.return a\n let apply tf tx = F.apply (fst tf) (fst tx), G.apply (snd tf) (snd tx)\n let custom_map t ~f = F.map ~f (fst t), G.map ~f (snd t)\n let map = `Custom custom_map\n end)\nend\n","(* This module is trying to minimize dependencies on modules in Core, so as to allow\n [Info], [Error], and [Or_error] to be used in as many places as possible. Please avoid\n adding new dependencies. *)\n\nopen! Import\ninclude Info_intf\nmodule String = String0\n\nmodule Message = struct\n type t =\n | Could_not_construct of Sexp.t\n | String of string\n | Exn of exn\n | Sexp of Sexp.t\n | Tag_sexp of string * Sexp.t * Source_code_position0.t option\n | Tag_t of string * t\n | Tag_arg of string * Sexp.t * t\n | Of_list of int option * t list\n | With_backtrace of t * string (* backtrace *)\n [@@deriving_inline sexp_of]\n\n let rec sexp_of_t =\n (function\n | Could_not_construct v0 ->\n let v0 = Sexp.sexp_of_t v0 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"Could_not_construct\"; v0 ]\n | String v0 ->\n let v0 = sexp_of_string v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"String\"; v0 ]\n | Exn v0 ->\n let v0 = sexp_of_exn v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Exn\"; v0 ]\n | Sexp v0 ->\n let v0 = Sexp.sexp_of_t v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Sexp\"; v0 ]\n | Tag_sexp (v0, v1, v2) ->\n let v0 = sexp_of_string v0\n and v1 = Sexp.sexp_of_t v1\n and v2 = sexp_of_option Source_code_position0.sexp_of_t v2 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Tag_sexp\"; v0; v1; v2 ]\n | Tag_t (v0, v1) ->\n let v0 = sexp_of_string v0\n and v1 = sexp_of_t v1 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Tag_t\"; v0; v1 ]\n | Tag_arg (v0, v1, v2) ->\n let v0 = sexp_of_string v0\n and v1 = Sexp.sexp_of_t v1\n and v2 = sexp_of_t v2 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Tag_arg\"; v0; v1; v2 ]\n | Of_list (v0, v1) ->\n let v0 = sexp_of_option sexp_of_int v0\n and v1 = sexp_of_list sexp_of_t v1 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Of_list\"; v0; v1 ]\n | With_backtrace (v0, v1) ->\n let v0 = sexp_of_t v0\n and v1 = sexp_of_string v1 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"With_backtrace\"; v0; v1 ]\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\n\n let rec to_strings_hum t ac =\n (* We use [Sexp.to_string_mach], despite the fact that we are implementing\n [to_strings_hum], because we want the info to fit on a single line, and once we've\n had to resort to sexps, the message is going to start not looking so pretty\n anyway. *)\n match t with\n | Could_not_construct sexp ->\n \"could not construct info: \" :: Sexp.to_string_mach sexp :: ac\n | String string -> string :: ac\n | Exn exn -> Sexp.to_string_mach (Exn.sexp_of_t exn) :: ac\n | Sexp sexp -> Sexp.to_string_mach sexp :: ac\n | Tag_sexp (tag, sexp, _) -> tag :: \": \" :: Sexp.to_string_mach sexp :: ac\n | Tag_t (tag, t) -> tag :: \": \" :: to_strings_hum t ac\n | Tag_arg (tag, sexp, t) ->\n let body = Sexp.to_string_mach sexp :: \": \" :: to_strings_hum t ac in\n if String.length tag = 0 then body else tag :: \": \" :: body\n | With_backtrace (t, backtrace) ->\n to_strings_hum t (\"\\nBacktrace:\\n\" :: backtrace :: ac)\n | Of_list (trunc_after, ts) ->\n let ts =\n match trunc_after with\n | None -> ts\n | Some max ->\n let n = List.length ts in\n if n <= max\n then ts\n else List.take ts max @ [ String (Printf.sprintf \"and %d more info\" (n - max)) ]\n in\n List.fold (List.rev ts) ~init:ac ~f:(fun ac t ->\n to_strings_hum t (if List.is_empty ac then ac else \"; \" :: ac))\n ;;\n\n let to_string_hum_deprecated t = String.concat (to_strings_hum t [])\n\n let rec to_sexps_hum t ac =\n match t with\n | Could_not_construct _ as t -> sexp_of_t t :: ac\n | String string -> Atom string :: ac\n | Exn exn -> Exn.sexp_of_t exn :: ac\n | Sexp sexp -> sexp :: ac\n | Tag_sexp (tag, sexp, here) ->\n List\n (Atom tag\n :: sexp\n ::\n (match here with\n | None -> []\n | Some here -> [ Source_code_position0.sexp_of_t here ]))\n :: ac\n | Tag_t (tag, t) -> List (Atom tag :: to_sexps_hum t []) :: ac\n | Tag_arg (tag, sexp, t) ->\n let body = sexp :: to_sexps_hum t [] in\n if String.length tag = 0 then List body :: ac else List (Atom tag :: body) :: ac\n | With_backtrace (t, backtrace) ->\n Sexp.List [ to_sexp_hum t; Sexp.Atom backtrace ] :: ac\n | Of_list (_, ts) ->\n List.fold (List.rev ts) ~init:ac ~f:(fun ac t -> to_sexps_hum t ac)\n\n and to_sexp_hum t =\n match to_sexps_hum t [] with\n | [ sexp ] -> sexp\n | sexps -> Sexp.List sexps\n ;;\n\n (* We use [protect] to guard against exceptions raised by user-supplied functions, so\n that failure to produce one part of an info doesn't interfere with other parts. *)\n let protect f =\n try f () with\n | exn -> Could_not_construct (Exn.sexp_of_t exn)\n ;;\n\n let of_info info = protect (fun () -> Lazy.force info)\n let to_info t = lazy t\nend\n\nopen Message\n\ntype t = Message.t Lazy.t\n\nlet invariant _ = ()\nlet to_message = Message.of_info\nlet of_message = Message.to_info\n\n(* It is OK to use [Message.to_sexp_hum], which is not stable, because [t_of_sexp] below\n can handle any sexp. *)\nlet sexp_of_t t = Message.to_sexp_hum (to_message t)\nlet t_of_sexp sexp = lazy (Message.Sexp sexp)\nlet compare t1 t2 = Sexp.compare (sexp_of_t t1) (sexp_of_t t2)\nlet equal t1 t2 = Sexp.equal (sexp_of_t t1) (sexp_of_t t2)\nlet hash_fold_t state t = Sexp.hash_fold_t state (sexp_of_t t)\nlet hash t = Hash.run hash_fold_t t\n\nlet to_string_hum t =\n match to_message t with\n | String s -> s\n | message -> Sexp.to_string_hum (Message.to_sexp_hum message)\n;;\n\nlet to_string_hum_deprecated t = Message.to_string_hum_deprecated (to_message t)\nlet to_string_mach t = Sexp.to_string_mach (sexp_of_t t)\nlet of_lazy l = lazy (protect (fun () -> String (Lazy.force l)))\nlet of_lazy_t lazy_t = Lazy.join lazy_t\nlet of_string message = Lazy.from_val (String message)\nlet createf format = Printf.ksprintf of_string format\nlet of_thunk f = lazy (protect (fun () -> String (f ())))\n\nlet create ?here ?strict tag x sexp_of_x =\n match strict with\n | None -> lazy (protect (fun () -> Tag_sexp (tag, sexp_of_x x, here)))\n | Some () -> of_message (Tag_sexp (tag, sexp_of_x x, here))\n;;\n\nlet create_s sexp = Lazy.from_val (Sexp sexp)\nlet tag t ~tag = lazy (Tag_t (tag, to_message t))\nlet tag_s t ~tag = lazy (protect (fun () -> Tag_arg (\"\", tag, to_message t)))\n\nlet tag_arg t tag x sexp_of_x =\n lazy (protect (fun () -> Tag_arg (tag, sexp_of_x x, to_message t)))\n;;\n\nlet of_list ?trunc_after ts = lazy (Of_list (trunc_after, List.map ts ~f:to_message))\n\nexception Exn of t\n\nlet () =\n (* We install a custom exn-converter rather than use\n [exception Exn of t [@@deriving_inline sexp] ... [@@@end]] to eliminate the extra\n wrapping of \"(Exn ...)\". *)\n Sexplib.Conv.Exn_converter.add [%extension_constructor Exn] (function\n | Exn t -> sexp_of_t t\n | _ ->\n (* Reaching this branch indicates a bug in sexplib. *)\n assert false)\n;;\n\nlet to_exn t =\n if not (Lazy.is_val t)\n then Exn t\n else (\n match Lazy.force t with\n | Message.Exn exn -> exn\n | _ -> Exn t)\n;;\n\nlet of_exn ?backtrace exn =\n let backtrace =\n match backtrace with\n | None -> None\n | Some `Get -> Some (Caml.Printexc.get_backtrace ())\n | Some (`This s) -> Some s\n in\n match exn, backtrace with\n | Exn t, None -> t\n | Exn t, Some backtrace -> lazy (With_backtrace (to_message t, backtrace))\n | _, None -> Lazy.from_val (Message.Exn exn)\n | _, Some backtrace -> lazy (With_backtrace (Sexp (Exn.sexp_of_t exn), backtrace))\n;;\n\ninclude Pretty_printer.Register_pp (struct\n type nonrec t = t\n\n let module_name = \"Base.Info\"\n let pp ppf t = Caml.Format.pp_print_string ppf (to_string_hum t)\n end)\n\nmodule Internal_repr = Message\n\n","(* This module is trying to minimize dependencies on modules in Core, so as to allow\n [Error] and [Or_error] to be used in various places. Please avoid adding new\n dependencies. *)\n\nopen! Import\ninclude Info\n\nlet raise t = raise (to_exn t)\nlet raise_s sexp = raise (create_s sexp)\nlet to_info t = t\nlet of_info t = t\n\ninclude Pretty_printer.Register_pp (struct\n type nonrec t = t\n\n let module_name = \"Base.Error\"\n let pp = pp\n end)\n","open! Import\ninclude Invariant_intf\n\nlet raise_s = Error.raise_s\n\nlet invariant here t sexp_of_t f : unit =\n try f () with\n | exn ->\n raise_s\n (Sexp.message\n \"invariant failed\"\n [ \"\", Source_code_position0.sexp_of_t here\n ; \"exn\", sexp_of_exn exn\n ; \"\", sexp_of_t t\n ])\n;;\n\nlet check_field t f field =\n try f (Field.get field t) with\n | exn ->\n raise_s\n (Sexp.message\n \"problem with field\"\n [ \"field\", sexp_of_string (Field.name field); \"exn\", sexp_of_exn exn ])\n;;\n","open! Import\n\ntype 'a t =\n | Incl of 'a\n | Excl of 'a\n | Unbounded\n[@@deriving_inline enumerate, sexp]\n\nlet all : 'a. 'a list -> 'a t list =\n fun _all_of_a ->\n Ppx_enumerate_lib.List.append\n (let rec map l acc =\n match l with\n | [] -> Ppx_enumerate_lib.List.rev acc\n | enumerate__001_ :: l -> map l (Incl enumerate__001_ :: acc)\n in\n map _all_of_a [])\n (Ppx_enumerate_lib.List.append\n (let rec map l acc =\n match l with\n | [] -> Ppx_enumerate_lib.List.rev acc\n | enumerate__002_ :: l -> map l (Excl enumerate__002_ :: acc)\n in\n map _all_of_a [])\n [ Unbounded ])\n;;\n\nlet t_of_sexp\n : type a. (Ppx_sexp_conv_lib.Sexp.t -> a) -> Ppx_sexp_conv_lib.Sexp.t -> a t\n =\n let _tp_loc = \"maybe_bound.ml.t\" in\n fun _of_a -> function\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"incl\" | \"Incl\") as _tag) :: sexp_args) as _sexp\n ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_a v0 in\n Incl v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"excl\" | \"Excl\") as _tag) :: sexp_args) as _sexp\n ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_a v0 in\n Excl v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.Atom (\"unbounded\" | \"Unbounded\") -> Unbounded\n | Ppx_sexp_conv_lib.Sexp.Atom (\"incl\" | \"Incl\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.Atom (\"excl\" | \"Excl\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"unbounded\" | \"Unbounded\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n;;\n\nlet sexp_of_t\n : type a. (a -> Ppx_sexp_conv_lib.Sexp.t) -> a t -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a -> function\n | Incl v0 ->\n let v0 = _of_a v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Incl\"; v0 ]\n | Excl v0 ->\n let v0 = _of_a v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Excl\"; v0 ]\n | Unbounded -> Ppx_sexp_conv_lib.Sexp.Atom \"Unbounded\"\n;;\n\n[@@@end]\n\ntype interval_comparison =\n | Below_lower_bound\n | In_range\n | Above_upper_bound\n[@@deriving_inline sexp, compare, hash]\n\nlet interval_comparison_of_sexp =\n (let _tp_loc = \"maybe_bound.ml.interval_comparison\" in\n function\n | Ppx_sexp_conv_lib.Sexp.Atom (\"below_lower_bound\" | \"Below_lower_bound\") ->\n Below_lower_bound\n | Ppx_sexp_conv_lib.Sexp.Atom (\"in_range\" | \"In_range\") -> In_range\n | Ppx_sexp_conv_lib.Sexp.Atom (\"above_upper_bound\" | \"Above_upper_bound\") ->\n Above_upper_bound\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"below_lower_bound\" | \"Below_lower_bound\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"in_range\" | \"In_range\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"above_upper_bound\" | \"Above_upper_bound\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> interval_comparison)\n;;\n\nlet sexp_of_interval_comparison =\n (function\n | Below_lower_bound -> Ppx_sexp_conv_lib.Sexp.Atom \"Below_lower_bound\"\n | In_range -> Ppx_sexp_conv_lib.Sexp.Atom \"In_range\"\n | Above_upper_bound -> Ppx_sexp_conv_lib.Sexp.Atom \"Above_upper_bound\"\n : interval_comparison -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\nlet compare_interval_comparison =\n (Ppx_compare_lib.polymorphic_compare\n : interval_comparison -> interval_comparison -> int)\n;;\n\nlet (hash_fold_interval_comparison :\n Ppx_hash_lib.Std.Hash.state -> interval_comparison -> Ppx_hash_lib.Std.Hash.state)\n =\n (fun hsv arg ->\n match arg with\n | Below_lower_bound -> Ppx_hash_lib.Std.Hash.fold_int hsv 0\n | In_range -> Ppx_hash_lib.Std.Hash.fold_int hsv 1\n | Above_upper_bound -> Ppx_hash_lib.Std.Hash.fold_int hsv 2\n : Ppx_hash_lib.Std.Hash.state -> interval_comparison -> Ppx_hash_lib.Std.Hash.state)\n;;\n\nlet (hash_interval_comparison : interval_comparison -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func arg =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (let hsv = Ppx_hash_lib.Std.Hash.create () in\n hash_fold_interval_comparison hsv arg)\n in\n fun x -> func x\n;;\n\n[@@@end]\n\nlet map t ~f =\n match t with\n | Incl incl -> Incl (f incl)\n | Excl excl -> Excl (f excl)\n | Unbounded -> Unbounded\n;;\n\nlet is_lower_bound t ~of_:a ~compare =\n match t with\n | Incl incl -> compare incl a <= 0\n | Excl excl -> compare excl a < 0\n | Unbounded -> true\n;;\n\nlet is_upper_bound t ~of_:a ~compare =\n match t with\n | Incl incl -> compare a incl <= 0\n | Excl excl -> compare a excl < 0\n | Unbounded -> true\n;;\n\nlet bounds_crossed ~lower ~upper ~compare =\n match lower with\n | Unbounded -> false\n | Incl lower | Excl lower ->\n (match upper with\n | Unbounded -> false\n | Incl upper | Excl upper -> compare lower upper > 0)\n;;\n\nlet check_interval_exn ~lower ~upper ~compare =\n if bounds_crossed ~lower ~upper ~compare\n then failwith \"Maybe_bound.compare_to_interval_exn: lower bound > upper bound\"\n;;\n\nlet compare_to_interval_exn ~lower ~upper a ~compare =\n check_interval_exn ~lower ~upper ~compare;\n if not (is_lower_bound lower ~of_:a ~compare)\n then Below_lower_bound\n else if not (is_upper_bound upper ~of_:a ~compare)\n then Above_upper_bound\n else In_range\n;;\n\nlet interval_contains_exn ~lower ~upper a ~compare =\n match compare_to_interval_exn ~lower ~upper a ~compare with\n | In_range -> true\n | Below_lower_bound | Above_upper_bound -> false\n;;\n","open! Import\n\ntype 'a t = ('a, Error.t) Result.t [@@deriving_inline compare, equal, hash, sexp]\n\nlet compare : 'a. ('a -> 'a -> int) -> 'a t -> 'a t -> int =\n fun _cmp__a a__001_ b__002_ -> Result.compare _cmp__a Error.compare a__001_ b__002_\n;;\n\nlet equal : 'a. ('a -> 'a -> bool) -> 'a t -> 'a t -> bool =\n fun _cmp__a a__007_ b__008_ -> Result.equal _cmp__a Error.equal a__007_ b__008_\n;;\n\nlet hash_fold_t :\n 'a. (Ppx_hash_lib.Std.Hash.state -> 'a -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state -> 'a t -> Ppx_hash_lib.Std.Hash.state\n =\n fun _hash_fold_a hsv arg -> Result.hash_fold_t _hash_fold_a Error.hash_fold_t hsv arg\n;;\n\nlet t_of_sexp : 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t =\n let _tp_loc = \"or_error.ml.t\" in\n fun _of_a t -> Result.t_of_sexp _of_a Error.t_of_sexp t\n;;\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n fun _of_a v -> Result.sexp_of_t _of_a Error.sexp_of_t v\n;;\n\n[@@@end]\n\nlet invariant invariant_a t =\n match t with\n | Ok a -> invariant_a a\n | Error error -> Error.invariant error\n;;\n\ninclude (\n Result :\n Monad.S2\n with type ('a, 'b) t := ('a, 'b) Result.t\n with module Let_syntax := Result.Let_syntax)\n\ninclude Applicative.Make (struct\n type nonrec 'a t = 'a t\n\n let return = return\n\n let apply f x =\n Result.combine f x ~ok:(fun f x -> f x) ~err:(fun e1 e2 -> Error.of_list [ e1; e2 ])\n ;;\n\n let map = `Custom map\n end)\n\nmodule Let_syntax = struct\n let return = return\n\n include Monad_infix\n\n module Let_syntax = struct\n let return = return\n let map = map\n let bind = bind\n let both = both\n\n (* from Applicative.Make *)\n module Open_on_rhs = struct end\n end\nend\n\nlet ok = Result.ok\nlet is_ok = Result.is_ok\nlet is_error = Result.is_error\n\nlet try_with ?(backtrace = false) f =\n try Ok (f ()) with\n | exn -> Error (Error.of_exn exn ?backtrace:(if backtrace then Some `Get else None))\n;;\n\nlet try_with_join ?backtrace f = join (try_with ?backtrace f)\n\nlet ok_exn = function\n | Ok x -> x\n | Error err -> Error.raise err\n;;\n\nlet of_exn ?backtrace exn = Error (Error.of_exn ?backtrace exn)\n\nlet of_exn_result ?backtrace = function\n | Ok _ as z -> z\n | Error exn -> of_exn ?backtrace exn\n;;\n\nlet error ?strict message a sexp_of_a = Error (Error.create ?strict message a sexp_of_a)\nlet error_s sexp = Error (Error.create_s sexp)\nlet error_string message = Error (Error.of_string message)\nlet errorf format = Printf.ksprintf error_string format\nlet tag t ~tag = Result.map_error t ~f:(Error.tag ~tag)\nlet tag_s t ~tag = Result.map_error t ~f:(Error.tag_s ~tag)\n\nlet tag_arg t message a sexp_of_a =\n Result.map_error t ~f:(fun e -> Error.tag_arg e message a sexp_of_a)\n;;\n\nlet unimplemented s = error \"unimplemented\" s sexp_of_string\nlet combine_errors l = Result.map_error (Result.combine_errors l) ~f:Error.of_list\nlet combine_errors_unit l = Result.map (combine_errors l) ~f:(fun (_ : unit list) -> ())\n\nlet filter_ok_at_least_one l =\n let ok, errs = List.partition_map l ~f:Result.to_either in\n match ok with\n | [] -> Error (Error.of_list errs)\n | _ -> Ok ok\n;;\n\nlet find_ok l =\n match List.find_map l ~f:Result.ok with\n | Some x -> Ok x\n | None ->\n Error\n (Error.of_list\n (List.map l ~f:(function\n | Ok _ -> assert false\n | Error err -> err)))\n;;\n\nlet find_map_ok l ~f =\n With_return.with_return (fun { return } ->\n Error\n (Error.of_list\n (List.map l ~f:(fun elt ->\n match f elt with\n | Ok _ as x -> return x\n | Error err -> err))))\n;;\n\nlet map = Result.map\nlet iter = Result.iter\nlet iter_error = Result.iter_error\n","open! Import\ninclude Comparable_intf\n\nmodule Validate (T : sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) : Validate with type t := T.t = struct\n module V = Validate\n open Maybe_bound\n\n let to_string t = Sexp.to_string (T.sexp_of_t t)\n\n let validate_bound ~min ~max t =\n V.bounded ~name:to_string ~lower:min ~upper:max ~compare:T.compare t\n ;;\n\n let validate_lbound ~min t = validate_bound ~min ~max:Unbounded t\n let validate_ubound ~max t = validate_bound ~max ~min:Unbounded t\nend\n\nmodule With_zero (T : sig\n type t [@@deriving_inline compare]\n\n val compare : t -> t -> int\n\n [@@@end]\n\n val zero : t\n\n include Validate with type t := t\n end) =\nstruct\n open T\n\n (* Preallocate the interesting bounds to minimize allocation in the implementations of\n [validate_*]. *)\n let excl_zero = Maybe_bound.Excl zero\n let incl_zero = Maybe_bound.Incl zero\n let validate_positive t = validate_lbound ~min:excl_zero t\n let validate_non_negative t = validate_lbound ~min:incl_zero t\n let validate_negative t = validate_ubound ~max:excl_zero t\n let validate_non_positive t = validate_ubound ~max:incl_zero t\n let is_positive t = compare t zero > 0\n let is_non_negative t = compare t zero >= 0\n let is_negative t = compare t zero < 0\n let is_non_positive t = compare t zero <= 0\n let sign t = Sign0.of_int (compare t zero)\nend\n\nmodule Validate_with_zero (T : sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val zero : t\n end) =\nstruct\n module V = Validate (T)\n include V\n\n include With_zero (struct\n include T\n include V\n end)\nend\n\nmodule Poly (T : sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) =\nstruct\n module Replace_polymorphic_compare = struct\n type t = T.t [@@deriving_inline sexp_of]\n\n let sexp_of_t = (T.sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n\n include Poly\n end\n\n include Poly\n\n let between t ~low ~high = low <= t && t <= high\n let clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\n let clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n ;;\n\n let clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n ;;\n\n module C = struct\n include T\n include Comparator.Make (Replace_polymorphic_compare)\n end\n\n include C\n\n include Validate (struct\n type nonrec t = t [@@deriving_inline compare, sexp_of]\n\n let compare = (compare : t -> t -> int)\n let sexp_of_t = (sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n end)\nend\n\nlet gt cmp a b = cmp a b > 0\nlet lt cmp a b = cmp a b < 0\nlet geq cmp a b = cmp a b >= 0\nlet leq cmp a b = cmp a b <= 0\nlet equal cmp a b = cmp a b = 0\nlet not_equal cmp a b = cmp a b <> 0\nlet min cmp t t' = if leq cmp t t' then t else t'\nlet max cmp t t' = if geq cmp t t' then t else t'\n\nmodule Infix (T : sig\n type t [@@deriving_inline compare]\n\n val compare : t -> t -> int\n\n [@@@end]\n end) : Infix with type t := T.t = struct\n let ( > ) a b = gt T.compare a b\n let ( < ) a b = lt T.compare a b\n let ( >= ) a b = geq T.compare a b\n let ( <= ) a b = leq T.compare a b\n let ( = ) a b = equal T.compare a b\n let ( <> ) a b = not_equal T.compare a b\nend\n\nmodule Polymorphic_compare (T : sig\n type t [@@deriving_inline compare]\n\n val compare : t -> t -> int\n\n [@@@end]\n end) : Polymorphic_compare with type t := T.t = struct\n include Infix (T)\n\n let compare = T.compare\n let equal = ( = )\n let min t t' = min compare t t'\n let max t t' = max compare t t'\nend\n\nmodule Make_using_comparator (T : sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n include Comparator.S with type t := t\n end) : S with type t := T.t and type comparator_witness = T.comparator_witness = struct\n module T = struct\n include T\n\n let compare = comparator.compare\n end\n\n include T\n module Replace_polymorphic_compare = Polymorphic_compare (T)\n include Replace_polymorphic_compare\n\n let ascending = compare\n let descending t t' = compare t' t\n let between t ~low ~high = low <= t && t <= high\n let clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\n let clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n ;;\n\n let clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n ;;\n\n include Validate (T)\nend\n\nmodule Make (T : sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) =\n Make_using_comparator (struct\n include T\n include Comparator.Make (T)\n end)\n\nmodule Inherit (C : sig\n type t [@@deriving_inline compare]\n\n val compare : t -> t -> int\n\n [@@@end]\n end) (T : sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val component : t -> C.t\n end) =\n Make (struct\n type t = T.t [@@deriving_inline sexp_of]\n\n let sexp_of_t = (T.sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n\n let compare t t' = C.compare (T.component t) (T.component t')\n end)\n\n(* compare [x] and [y] lexicographically using functions in the list [cmps] *)\nlet lexicographic cmps x y =\n let rec loop = function\n | cmp :: cmps ->\n let res = cmp x y in\n if res = 0 then loop cmps else res\n | [] -> 0\n in\n loop cmps\n;;\n\nlet lift cmp ~f x y = cmp (f x) (f y)\nlet reverse cmp x y = cmp y x\n","open! Import\n\nmodule type S = sig\n type t [@@deriving_inline hash, sexp]\n\n val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state\n val hash : t -> Ppx_hash_lib.Std.Hash.hash_value\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n [@@@end]\n\n include Stringable.S with type t := t\n include Comparable.S with type t := t\n include Pretty_printer.S with type t := t\nend\n\nmodule Make (T : sig\n type t [@@deriving_inline compare, hash, sexp]\n\n val compare : t -> t -> int\n val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state\n val hash : t -> Ppx_hash_lib.Std.Hash.hash_value\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n [@@@end]\n\n include Stringable.S with type t := t\n\n val module_name : string\n end) =\nstruct\n include T\n include Comparable.Make (T)\n include Pretty_printer.Register (T)\nend\n\nmodule Make_using_comparator (T : sig\n type t [@@deriving_inline hash, sexp]\n\n val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state\n val hash : t -> Ppx_hash_lib.Std.Hash.hash_value\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n [@@@end]\n\n include Comparator.S with type t := t\n include Stringable.S with type t := t\n\n val module_name : string\n end) =\nstruct\n include T\n include Comparable.Make_using_comparator (T)\n include Pretty_printer.Register (T)\nend\n","open! Import\n\nmodule type Infix = Base.Comparable.Infix\nmodule type Polymorphic_compare = Base.Comparable.Polymorphic_compare\nmodule type Validate = Base.Comparable.Validate\nmodule type With_zero = Base.Comparable.With_zero\n\nmodule type S_common = sig\n include Base.Comparable.S\n module Replace_polymorphic_compare : Polymorphic_compare with type t := t\nend\n\n(** Usage example:\n\n {[\n module Foo : sig\n type t = ...\n include Comparable.S with type t := t\n end\n ]}\n\n Then use [Comparable.Make] in the struct (see comparable.mli for an example). *)\n\nmodule type S_plain = sig\n include S_common\n\n module Map :\n Map.S_plain with type Key.t = t with type Key.comparator_witness = comparator_witness\n\n module Set :\n Set.S_plain with type Elt.t = t with type Elt.comparator_witness = comparator_witness\nend\n\nmodule type S = sig\n include S_common\n\n module Map :\n Map.S with type Key.t = t with type Key.comparator_witness = comparator_witness\n\n module Set :\n Set.S with type Elt.t = t with type Elt.comparator_witness = comparator_witness\nend\n\nmodule type Map_and_set_binable = sig\n type t\n\n include Comparator.S with type t := t\n\n module Map :\n Map.S_binable\n with type Key.t = t\n with type Key.comparator_witness = comparator_witness\n\n module Set :\n Set.S_binable\n with type Elt.t = t\n with type Elt.comparator_witness = comparator_witness\nend\n\nmodule type S_binable = sig\n include S_common\n\n include\n Map_and_set_binable\n with type t := t\n with type comparator_witness := comparator_witness\nend\n\n","open! Import\n\nmodule T = struct\n type t = unit [@@deriving_inline enumerate, hash, sexp, sexp_grammar]\n\n let all = ([ () ] : t list)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_unit\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_unit in\n fun x -> func x\n ;;\n\n let t_of_sexp = (unit_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_unit : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"unit\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ unit_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"unit.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare _ _ = 0\n\n let of_string = function\n | \"()\" -> ()\n | _ -> failwith \"Base.Unit.of_string: () expected\"\n ;;\n\n let to_string () = \"()\"\n let module_name = \"Base.Unit\"\nend\n\ninclude T\ninclude Identifiable.Make (T)\n\nlet invariant () = ()\n","open! Import\n\nlet invalid_argf = Printf.invalid_argf\n\nlet slow_check_pos_len_exn ~pos ~len ~total_length =\n if pos < 0 then invalid_argf \"Negative position: %d\" pos ();\n if len < 0 then invalid_argf \"Negative length: %d\" len ();\n (* We use [pos > total_length - len] rather than [pos + len > total_length] to avoid the\n possibility of overflow. *)\n if pos > total_length - len\n then invalid_argf \"pos + len past end: %d + %d > %d\" pos len total_length ()\n[@@cold] [@@inline never] [@@local never] [@@specialise never]\n;;\n\nlet check_pos_len_exn ~pos ~len ~total_length =\n (* This is better than [slow_check_pos_len_exn] for two reasons:\n\n - much less inlined code\n - only one conditional jump\n\n The reason it works is that checking [< 0] is testing the highest order bit, so\n [a < 0 || b < 0] is the same as [a lor b < 0].\n\n [pos + len] can overflow, so [pos > total_length - len] is not equivalent to\n [total_length - len - pos < 0], we need to test for [pos + len] overflow as\n well. *)\n let stop = pos + len in\n if pos lor len lor stop lor (total_length - stop) < 0\n then slow_check_pos_len_exn ~pos ~len ~total_length\n;;\n\nlet get_pos_len_exn ?(pos = 0) ?len () ~total_length =\n let len =\n match len with\n | Some i -> i\n | None -> total_length - pos\n in\n check_pos_len_exn ~pos ~len ~total_length;\n pos, len\n;;\n\nlet get_pos_len ?pos ?len () ~total_length =\n try Result.Ok (get_pos_len_exn () ?pos ?len ~total_length) with\n | Invalid_argument s -> Or_error.error_string s\n;;\n\nmodule Private = struct\n let slow_check_pos_len_exn = slow_check_pos_len_exn\nend\n","open! Import\n\n(* These functions implement a search for the first (resp. last) element\n satisfying a predicate, assuming that the predicate is increasing on\n the container, meaning that, if the container is [u1...un], there exists a\n k such that p(u1)=....=p(uk) = false and p(uk+1)=....=p(un)= true.\n If this k = 1 (resp n), find_last_not_satisfying (resp find_first_satisfying)\n will return None. *)\n\nlet rec linear_search_first_satisfying t ~get ~lo ~hi ~pred =\n if lo > hi\n then None\n else if pred (get t lo)\n then Some lo\n else linear_search_first_satisfying t ~get ~lo:(lo + 1) ~hi ~pred\n;;\n\n(* Takes a container [t], a predicate [pred] and two indices [lo < hi], such that\n [pred] is increasing on [t] between [lo] and [hi].\n\n return a range (lo, hi) where:\n - lo and hi are close enough together for a linear search\n - If [pred] is not constantly [false] on [t] between [lo] and [hi], the first element\n on which [pred] is [true] is between [lo] and [hi]. *)\n(* Invariant: the first element satisfying [pred], if it exists is between [lo] and [hi] *)\nlet rec find_range_near_first_satisfying t ~get ~lo ~hi ~pred =\n (* Warning: this function will not terminate if the constant (currently 8) is\n set <= 1 *)\n if hi - lo <= 8\n then lo, hi\n else (\n let mid = lo + ((hi - lo) / 2) in\n if pred (get t mid)\n (* INVARIANT check: it means the first satisfying element is between [lo] and [mid] *)\n then\n find_range_near_first_satisfying t ~get ~lo ~hi:mid ~pred\n (* INVARIANT check: it means the first satisfying element, if it exists,\n is between [mid+1] and [hi] *)\n else find_range_near_first_satisfying t ~get ~lo:(mid + 1) ~hi ~pred)\n;;\n\nlet find_first_satisfying ?pos ?len t ~get ~length ~pred =\n let pos, len =\n Ordered_collection_common.get_pos_len_exn () ?pos ?len ~total_length:(length t)\n in\n let lo = pos in\n let hi = pos + len - 1 in\n let lo, hi = find_range_near_first_satisfying t ~get ~lo ~hi ~pred in\n linear_search_first_satisfying t ~get ~lo ~hi ~pred\n;;\n\n(* Takes an array with shape [true,...true,false,...false] (i.e., the _reverse_ of what\n is described above) and returns the index of the last true or None if there are no\n true*)\nlet find_last_satisfying ?pos ?len t ~pred ~get ~length =\n let pos, len =\n Ordered_collection_common.get_pos_len_exn () ?pos ?len ~total_length:(length t)\n in\n if len = 0\n then None\n else (\n (* The last satisfying is the one just before the first not satisfying *)\n match find_first_satisfying ~pos ~len t ~get ~length ~pred:(Fn.non pred) with\n | None -> Some (pos + len - 1)\n (* This means that all elements satisfy pred.\n There is at least an element as (len > 0) *)\n | Some i when i = pos -> None (* no element satisfies pred *)\n | Some i -> Some (i - 1))\n;;\n\nlet binary_search ?pos ?len t ~length ~get ~compare how v =\n match how with\n | `Last_strictly_less_than ->\n find_last_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v < 0)\n | `Last_less_than_or_equal_to ->\n find_last_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v <= 0)\n | `First_equal_to ->\n (match\n find_first_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v >= 0)\n with\n | Some x when compare (get t x) v = 0 -> Some x\n | None | Some _ -> None)\n | `Last_equal_to ->\n (match\n find_last_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v <= 0)\n with\n | Some x when compare (get t x) v = 0 -> Some x\n | None | Some _ -> None)\n | `First_greater_than_or_equal_to ->\n find_first_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v >= 0)\n | `First_strictly_greater_than ->\n find_first_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v > 0)\n;;\n\nlet binary_search_segmented ?pos ?len t ~length ~get ~segment_of how =\n let is_left x =\n match segment_of x with\n | `Left -> true\n | `Right -> false\n in\n let is_right x = not (is_left x) in\n match how with\n | `Last_on_left -> find_last_satisfying ?pos ?len t ~length ~get ~pred:is_left\n | `First_on_right -> find_first_satisfying ?pos ?len t ~length ~get ~pred:is_right\n;;\n","open! Import\ninclude Binary_searchable_intf\n\nmodule type Arg = sig\n type 'a elt\n type 'a t\n\n val get : 'a t -> int -> 'a elt\n val length : _ t -> int\nend\n\nmodule Make_gen (T : Arg) = struct\n let get = T.get\n let length = T.length\n\n let binary_search ?pos ?len t ~compare how v =\n Binary_search.binary_search ?pos ?len t ~get ~length ~compare how v\n ;;\n\n let binary_search_segmented ?pos ?len t ~segment_of how =\n Binary_search.binary_search_segmented ?pos ?len t ~get ~length ~segment_of how\n ;;\nend\n\nmodule Make (T : Indexable) = Make_gen (struct\n type 'a elt = T.elt\n type 'a t = T.t\n\n include (T : Indexable with type elt := T.elt with type t := T.t)\n end)\n\nmodule Make1 (T : Indexable1) = Make_gen (struct\n type 'a elt = 'a\n type 'a t = 'a T.t\n\n let get = T.get\n let length = T.length\n end)\n","(* [Bytes0] defines string functions that are primitives or can be simply\n defined in terms of [Caml.Bytes]. [Bytes0] is intended to completely express\n the part of [Caml.Bytes] that [Base] uses -- no other file in Base other\n than bytes0.ml should use [Caml.Bytes]. [Bytes0] has few dependencies, and\n so is available early in Base's build order.\n\n All Base files that need to use strings and come before [Base.Bytes] in\n build order should do:\n\n {[\n module Bytes = Bytes0\n ]}\n\n Defining [module Bytes = Bytes0] is also necessary because it prevents\n ocamldep from mistakenly causing a file to depend on [Base.Bytes]. *)\n\nopen! Import0\nmodule Sys = Sys0\n\nmodule Primitives = struct\n external get : bytes -> int -> char = \"%bytes_safe_get\"\n external length : bytes -> int = \"%bytes_length\"\n external unsafe_get : bytes -> int -> char = \"%bytes_unsafe_get\"\n\n include Bytes_set_primitives\n\n (* [unsafe_blit_string] is not exported in the [stdlib] so we export it here *)\n external unsafe_blit_string\n : src:string\n -> src_pos:int\n -> dst:bytes\n -> dst_pos:int\n -> len:int\n -> unit\n = \"caml_blit_string\"\n [@@noalloc]\nend\n\ninclude Primitives\n\nlet max_length = Sys.max_string_length\nlet blit = Caml.Bytes.blit\nlet blit_string = Caml.Bytes.blit_string\nlet compare = Caml.Bytes.compare\nlet copy = Caml.Bytes.copy\nlet create = Caml.Bytes.create\nlet fill = Caml.Bytes.fill\nlet make = Caml.Bytes.make\nlet map = Caml.Bytes.map\nlet mapi = Caml.Bytes.mapi\nlet sub = Caml.Bytes.sub\nlet unsafe_blit = Caml.Bytes.unsafe_blit\nlet to_string = Caml.Bytes.to_string\nlet of_string = Caml.Bytes.of_string\n\nlet unsafe_to_string ~no_mutation_while_string_reachable:s =\n Caml.Bytes.unsafe_to_string s\n;;\n\nlet unsafe_of_string_promise_no_mutation = Caml.Bytes.unsafe_of_string\n","open! Import\ninclude Blit_intf\n\nmodule type Sequence_gen = sig\n type 'a t\n\n val length : _ t -> int\nend\n\nmodule Make_gen\n (Src : Sequence_gen) (Dst : sig\n include Sequence_gen\n\n val create_like : len:int -> 'a Src.t -> 'a t\n val unsafe_blit : ('a Src.t, 'a t) blit\n end) =\nstruct\n let unsafe_blit = Dst.unsafe_blit\n\n let blit ~src ~src_pos ~dst ~dst_pos ~len =\n Ordered_collection_common.check_pos_len_exn\n ~pos:src_pos\n ~len\n ~total_length:(Src.length src);\n Ordered_collection_common.check_pos_len_exn\n ~pos:dst_pos\n ~len\n ~total_length:(Dst.length dst);\n if len > 0 then unsafe_blit ~src ~src_pos ~dst ~dst_pos ~len\n ;;\n\n let blito\n ~src\n ?(src_pos = 0)\n ?(src_len = Src.length src - src_pos)\n ~dst\n ?(dst_pos = 0)\n ()\n =\n blit ~src ~src_pos ~len:src_len ~dst ~dst_pos\n ;;\n\n (* [sub] and [subo] ensure that every position of the created sequence is populated by\n an element of the source array. Thus every element of [dst] below is well\n defined. *)\n let sub src ~pos ~len =\n Ordered_collection_common.check_pos_len_exn ~pos ~len ~total_length:(Src.length src);\n let dst = Dst.create_like ~len src in\n if len > 0 then unsafe_blit ~src ~src_pos:pos ~dst ~dst_pos:0 ~len;\n dst\n ;;\n\n let subo ?(pos = 0) ?len src =\n sub\n src\n ~pos\n ~len:\n (match len with\n | Some i -> i\n | None -> Src.length src - pos)\n ;;\nend\n\nmodule Make1 (Sequence : sig\n include Sequence_gen\n\n val create_like : len:int -> 'a t -> 'a t\n val unsafe_blit : ('a t, 'a t) blit\n end) =\n Make_gen (Sequence) (Sequence)\n\nmodule Make1_generic (Sequence : Sequence1) = Make_gen (Sequence) (Sequence)\n\nmodule Make (Sequence : sig\n include Sequence\n\n val create : len:int -> t\n val unsafe_blit : (t, t) blit\n end) =\nstruct\n module Sequence = struct\n type 'a t = Sequence.t\n\n open Sequence\n\n let create_like ~len _ = create ~len\n let length = length\n let unsafe_blit = unsafe_blit\n end\n\n include Make_gen (Sequence) (Sequence)\nend\n\nmodule Make_distinct\n (Src : Sequence) (Dst : sig\n include Sequence\n\n val create : len:int -> t\n val unsafe_blit : (Src.t, t) blit\n end) =\n Make_gen\n (struct\n type 'a t = Src.t\n\n open Src\n\n let length = length\n end)\n (struct\n type 'a t = Dst.t\n\n open Dst\n\n let length = length\n let create_like ~len _ = create ~len\n let unsafe_blit = unsafe_blit\n end)\n\nmodule Make_to_string (T : sig\n type t\n end)\n (To_bytes : S_distinct with type src := T.t with type dst := bytes) =\nstruct\n open To_bytes\n\n let sub src ~pos ~len =\n Bytes0.unsafe_to_string ~no_mutation_while_string_reachable:(sub src ~pos ~len)\n ;;\n\n let subo ?pos ?len src =\n Bytes0.unsafe_to_string ~no_mutation_while_string_reachable:(subo ?pos ?len src)\n ;;\nend\n","open! Import\n\ntype 'a t = 'a option =\n | None\n | Some of 'a\n\ninclude (\nstruct\n type 'a t = 'a option [@@deriving_inline compare, hash, sexp, sexp_grammar]\n\n let compare : 'a. ('a -> 'a -> int) -> 'a t -> 'a t -> int = compare_option\n\n let hash_fold_t :\n 'a. (Ppx_hash_lib.Std.Hash.state -> 'a -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state -> 'a t -> Ppx_hash_lib.Std.Hash.state\n =\n hash_fold_option\n ;;\n\n let t_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t\n =\n option_of_sexp\n ;;\n\n let sexp_of_t :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t\n =\n sexp_of_option\n ;;\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group)\n =\n { implicit_vars = [ \"option\" ]\n ; ggid = \"j\\132);\\135qH\\158\\135\\222H\\001\\007\\004\\158\\218\"\n ; types =\n [ \"t\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ])) ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ option_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"option.ml\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\nend :\nsig\n type 'a t = 'a option [@@deriving_inline compare, hash, sexp, sexp_grammar]\n\n val compare : ('a -> 'a -> int) -> 'a t -> 'a t -> int\n\n val hash_fold_t\n : (Ppx_hash_lib.Std.Hash.state -> 'a -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state\n -> 'a t\n -> Ppx_hash_lib.Std.Hash.state\n\n include Ppx_sexp_conv_lib.Sexpable.S1 with type 'a t := 'a t\n\n val t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t\n\n [@@@end]\nend\nwith type 'a t := 'a t)\n\nlet is_none = function\n | None -> true\n | _ -> false\n;;\n\nlet is_some = function\n | Some _ -> true\n | _ -> false\n;;\n\nlet value_map o ~default ~f =\n match o with\n | Some x -> f x\n | None -> default\n;;\n\nlet iter o ~f =\n match o with\n | None -> ()\n | Some a -> f a\n;;\n\nlet invariant f t = iter t ~f\n\nlet map2 o1 o2 ~f =\n match o1, o2 with\n | Some a1, Some a2 -> Some (f a1 a2)\n | _ -> None\n;;\n\nlet call x ~f =\n match f with\n | None -> ()\n | Some f -> f x\n;;\n\nlet value t ~default =\n match t with\n | None -> default\n | Some x -> x\n;;\n\nlet value_exn ?here ?error ?message t =\n match t with\n | Some x -> x\n | None ->\n let error =\n match here, error, message with\n | None, None, None -> Error.of_string \"Option.value_exn None\"\n | None, None, Some m -> Error.of_string m\n | None, Some e, None -> e\n | None, Some e, Some m -> Error.tag e ~tag:m\n | Some p, None, None ->\n Error.create \"Option.value_exn\" p Source_code_position0.sexp_of_t\n | Some p, None, Some m -> Error.create m p Source_code_position0.sexp_of_t\n | Some p, Some e, _ ->\n Error.create\n (value message ~default:\"\")\n (e, p)\n (sexp_of_pair Error.sexp_of_t Source_code_position0.sexp_of_t)\n in\n Error.raise error\n;;\n\nlet to_array t =\n match t with\n | None -> [||]\n | Some x -> [| x |]\n;;\n\nlet to_list t =\n match t with\n | None -> []\n | Some x -> [ x ]\n;;\n\nlet min_elt t ~compare:_ = t\nlet max_elt t ~compare:_ = t\n\nlet sum (type a) (module M : Container.Summable with type t = a) t ~f =\n match t with\n | None -> M.zero\n | Some x -> f x\n;;\n\nlet for_all t ~f =\n match t with\n | None -> true\n | Some x -> f x\n;;\n\nlet exists t ~f =\n match t with\n | None -> false\n | Some x -> f x\n;;\n\nlet mem t a ~equal =\n match t with\n | None -> false\n | Some a' -> equal a a'\n;;\n\nlet length t =\n match t with\n | None -> 0\n | Some _ -> 1\n;;\n\nlet is_empty = is_none\n\nlet fold t ~init ~f =\n match t with\n | None -> init\n | Some x -> f init x\n;;\n\nlet count t ~f =\n match t with\n | None -> 0\n | Some a -> if f a then 1 else 0\n;;\n\nlet find t ~f =\n match t with\n | None -> None\n | Some x -> if f x then Some x else None\n;;\n\nlet find_map t ~f =\n match t with\n | None -> None\n | Some a -> f a\n;;\n\nlet equal f t t' =\n match t, t' with\n | None, None -> true\n | Some x, Some x' -> f x x'\n | _ -> false\n;;\n\nlet some x = Some x\n\nlet both x y =\n match x, y with\n | Some a, Some b -> Some (a, b)\n | _ -> None\n;;\n\nlet first_some x y =\n match x with\n | Some _ -> x\n | None -> y\n;;\n\nlet some_if cond x = if cond then Some x else None\n\nlet merge a b ~f =\n match a, b with\n | None, x | x, None -> x\n | Some a, Some b -> Some (f a b)\n;;\n\nlet filter t ~f =\n match t with\n | Some v as o when f v -> o\n | _ -> None\n;;\n\nlet try_with f =\n match f () with\n | x -> Some x\n | exception _ -> None\n;;\n\nlet try_with_join f =\n match f () with\n | x -> x\n | exception _ -> None\n;;\n\ninclude Monad.Make (struct\n type 'a t = 'a option\n\n let return x = Some x\n\n let map t ~f =\n match t with\n | None -> None\n | Some a -> Some (f a)\n ;;\n\n let map = `Custom map\n\n let bind o ~f =\n match o with\n | None -> None\n | Some x -> f x\n ;;\n end)\n\nlet fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\nlet fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\n\nlet validate ~none ~some t =\n let module V = Validate in\n match t with\n | None -> V.name \"none\" (V.protect none ())\n | Some x -> V.name \"some\" (V.protect some x)\n;;\n","open! Import\ninclude Either_intf\nmodule Array = Array0\nmodule List = List0\ninclude Either0\n\nlet swap = function\n | First x -> Second x\n | Second x -> First x\n;;\n\nlet is_first = function\n | First _ -> true\n | Second _ -> false\n;;\n\nlet is_second = function\n | First _ -> false\n | Second _ -> true\n;;\n\nlet value (First x | Second x) = x\n\nlet value_map t ~first ~second =\n match t with\n | First x -> first x\n | Second x -> second x\n;;\n\nlet iter = value_map\n\nlet map t ~first ~second =\n match t with\n | First x -> First (first x)\n | Second x -> Second (second x)\n;;\n\nlet first x = First x\nlet second x = Second x\n\nlet equal eq1 eq2 t1 t2 =\n match t1, t2 with\n | First x, First y -> eq1 x y\n | Second x, Second y -> eq2 x y\n | First _, Second _ | Second _, First _ -> false\n;;\n\nlet invariant f s = function\n | First x -> f x\n | Second y -> s y\n;;\n\nmodule Make_focused (M : sig\n type (+'a, +'b) t\n\n val return : 'a -> ('a, _) t\n val other : 'b -> (_, 'b) t\n val either : ('a, 'b) t -> return:('a -> 'c) -> other:('b -> 'c) -> 'c\n\n val combine\n : ('a, 'd) t\n -> ('b, 'd) t\n -> f:('a -> 'b -> 'c)\n -> other:('d -> 'd -> 'd)\n -> ('c, 'd) t\n\n val bind : ('a, 'b) t -> f:('a -> ('c, 'b) t) -> ('c, 'b) t\n end) =\nstruct\n include M\n open With_return\n\n let map t ~f = bind t ~f:(fun x -> return (f x))\n\n include Monad.Make2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n\n let return = return\n let bind = bind\n let map = `Custom map\n end)\n\n module App = Applicative.Make2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n\n let return = return\n let apply t1 t2 = bind t1 ~f:(fun f -> bind t2 ~f:(fun x -> return (f x)))\n let map = `Custom map\n end)\n\n include App\n\n let combine_all =\n let rec other_loop f acc = function\n | [] -> other acc\n | t :: ts ->\n either\n t\n ~return:(fun _ -> other_loop f acc ts)\n ~other:(fun o -> other_loop f (f acc o) ts)\n in\n let rec return_loop f acc = function\n | [] -> return (List.rev acc)\n | t :: ts ->\n either\n t\n ~return:(fun x -> return_loop f (x :: acc) ts)\n ~other:(fun o -> other_loop f o ts)\n in\n fun ts ~f -> return_loop f [] ts\n ;;\n\n let combine_all_unit =\n let rec other_loop f acc = function\n | [] -> other acc\n | t :: ts ->\n either\n t\n ~return:(fun () -> other_loop f acc ts)\n ~other:(fun o -> other_loop f (f acc o) ts)\n in\n let rec return_loop f = function\n | [] -> return ()\n | t :: ts ->\n either t ~return:(fun () -> return_loop f ts) ~other:(fun o -> other_loop f o ts)\n in\n fun ts ~f -> return_loop f ts\n ;;\n\n let to_option t = either t ~return:Option.some ~other:(fun _ -> None)\n let value t ~default = either t ~return:Fn.id ~other:(fun _ -> default)\n\n let with_return f =\n with_return (fun ret -> other (f (With_return.prepend ret ~f:return)))\n ;;\nend\n\nmodule First = Make_focused (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n\n let return = first\n let other = second\n\n let either t ~return ~other =\n match t with\n | First x -> return x\n | Second y -> other y\n ;;\n\n let combine t1 t2 ~f ~other =\n match t1, t2 with\n | First x, First y -> First (f x y)\n | Second x, Second y -> Second (other x y)\n | Second x, _ | _, Second x -> Second x\n ;;\n\n let bind t ~f =\n match t with\n | First x -> f x\n (* Reuse the value in order to avoid allocation. *)\n | Second _ as y -> y\n ;;\n end)\n\nmodule Second = Make_focused (struct\n type nonrec ('a, 'b) t = ('b, 'a) t\n\n let return = second\n let other = first\n\n let either t ~return ~other =\n match t with\n | Second y -> return y\n | First x -> other x\n ;;\n\n let combine t1 t2 ~f ~other =\n match t1, t2 with\n | Second x, Second y -> Second (f x y)\n | First x, First y -> First (other x y)\n | First x, _ | _, First x -> First x\n ;;\n\n let bind t ~f =\n match t with\n | Second x -> f x\n (* Reuse the value in order to avoid allocation, like [First.bind] above. *)\n | First _ as y -> y\n ;;\n end)\n\nmodule Export = struct\n type ('f, 's) _either = ('f, 's) t =\n | First of 'f\n | Second of 's\nend\n","include Indexed_container_intf\n\nlet with_return = With_return.with_return\n\nlet iteri ~fold t ~f =\n ignore\n (fold t ~init:0 ~f:(fun i x ->\n f i x;\n i + 1)\n : int)\n;;\n\nlet foldi ~fold t ~init ~f =\n let i = ref 0 in\n fold t ~init ~f:(fun acc v ->\n let acc = f !i acc v in\n i := !i + 1;\n acc)\n;;\n\nlet counti ~foldi t ~f = foldi t ~init:0 ~f:(fun i n a -> if f i a then n + 1 else n)\n\nlet existsi ~iteri c ~f =\n with_return (fun r ->\n iteri c ~f:(fun i x -> if f i x then r.return true);\n false)\n;;\n\nlet for_alli ~iteri c ~f =\n with_return (fun r ->\n iteri c ~f:(fun i x -> if not (f i x) then r.return false);\n true)\n;;\n\nlet find_mapi ~iteri t ~f =\n with_return (fun r ->\n iteri t ~f:(fun i x ->\n match f i x with\n | None -> ()\n | Some _ as res -> r.return res);\n None)\n;;\n\nlet findi ~iteri c ~f =\n with_return (fun r ->\n iteri c ~f:(fun i x -> if f i x then r.return (Some (i, x)));\n None)\n;;\n\nmodule Make (T : Make_arg) : S1 with type 'a t := 'a T.t = struct\n include Container.Make (T)\n\n let iteri =\n match T.iteri with\n | `Custom iteri -> iteri\n | `Define_using_fold -> fun t ~f -> iteri ~fold t ~f\n ;;\n\n let foldi =\n match T.foldi with\n | `Custom foldi -> foldi\n | `Define_using_fold -> fun t ~init ~f -> foldi ~fold t ~init ~f\n ;;\n\n let counti t ~f = counti ~foldi t ~f\n let existsi t ~f = existsi ~iteri t ~f\n let for_alli t ~f = for_alli ~iteri t ~f\n let find_mapi t ~f = find_mapi ~iteri t ~f\n let findi t ~f = findi ~iteri t ~f\nend\n","open! Import\nopen Container_intf.Export\nmodule Array = Array0\nmodule List = List1\n\nmodule Step = struct\n (* 'a is an item in the sequence, 's is the state that will produce the remainder of\n the sequence *)\n type ('a, 's) t =\n | Done\n | Skip of 's\n | Yield of 'a * 's\n [@@deriving_inline sexp_of]\n\n let sexp_of_t\n : type a s.\n (a -> Ppx_sexp_conv_lib.Sexp.t)\n -> (s -> Ppx_sexp_conv_lib.Sexp.t)\n -> (a, s) t\n -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a _of_s -> function\n | Done -> Ppx_sexp_conv_lib.Sexp.Atom \"Done\"\n | Skip v0 ->\n let v0 = _of_s v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Skip\"; v0 ]\n | Yield (v0, v1) ->\n let v0 = _of_a v0\n and v1 = _of_s v1 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Yield\"; v0; v1 ]\n ;;\n\n [@@@end]\nend\n\nopen Step\n\n(* 'a is an item in the sequence, 's is the state that will produce the remainder of the\n sequence *)\ntype +_ t = Sequence : 's * ('s -> ('a, 's) Step.t) -> 'a t\ntype 'a sequence = 'a t\n\nmodule Expert = struct\n let next_step (Sequence (s, f)) =\n match f s with\n | Done -> Done\n | Skip s -> Skip (Sequence (s, f))\n | Yield (a, s) -> Yield (a, Sequence (s, f))\n ;;\n\n let delayed_fold_step s ~init ~f ~finish =\n let rec loop s next finish f acc =\n match next s with\n | Done -> finish acc\n | Skip s -> f acc None ~k:(loop s next finish f)\n | Yield (a, s) -> f acc (Some a) ~k:(loop s next finish f)\n in\n match s with\n | Sequence (s, next) -> loop s next finish f init\n ;;\nend\n\nlet unfold_step ~init ~f = Sequence (init, f)\n\nlet unfold ~init ~f =\n unfold_step ~init ~f:(fun s ->\n match f s with\n | None -> Step.Done\n | Some (a, s) -> Step.Yield (a, s))\n;;\n\nlet unfold_with s ~init ~f =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( (init, s)\n , fun (seed, s) ->\n match next s with\n | Done -> Done\n | Skip s -> Skip (seed, s)\n | Yield (a, s) ->\n (match f seed a with\n | Done -> Done\n | Skip seed -> Skip (seed, s)\n | Yield (a, seed) -> Yield (a, (seed, s))) )\n;;\n\nlet unfold_with_and_finish s ~init ~running_step ~inner_finished ~finishing_step =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( `Inner_running (init, s)\n , fun state ->\n match state with\n | `Inner_running (state, inner_state) ->\n (match next inner_state with\n | Done -> Skip (`Inner_finished (inner_finished state))\n | Skip inner_state -> Skip (`Inner_running (state, inner_state))\n | Yield (x, inner_state) ->\n (match running_step state x with\n | Done -> Done\n | Skip state -> Skip (`Inner_running (state, inner_state))\n | Yield (y, state) -> Yield (y, `Inner_running (state, inner_state))))\n | `Inner_finished state ->\n (match finishing_step state with\n | Done -> Done\n | Skip state -> Skip (`Inner_finished state)\n | Yield (y, state) -> Yield (y, `Inner_finished state)) )\n;;\n\nlet of_list l =\n unfold_step ~init:l ~f:(function\n | [] -> Done\n | x :: l -> Yield (x, l))\n;;\n\n\nlet fold t ~init ~f =\n let rec loop seed v next f =\n match next seed with\n | Done -> v\n | Skip s -> loop s v next f\n | Yield (a, s) -> loop s (f v a) next f\n in\n match t with\n | Sequence (seed, next) -> loop seed init next f\n;;\n\nlet to_list_rev t = fold t ~init:[] ~f:(fun l x -> x :: l)\n\n\nlet to_list (Sequence (s, next)) =\n let safe_to_list t = List.rev (to_list_rev t) in\n let rec to_list s next i =\n if i = 0\n then safe_to_list (Sequence (s, next))\n else (\n match next s with\n | Done -> []\n | Skip s -> to_list s next i\n | Yield (a, s) -> a :: to_list s next (i - 1))\n in\n to_list s next 500\n;;\n\nlet sexp_of_t sexp_of_a t = sexp_of_list sexp_of_a (to_list t)\n\nlet range ?(stride = 1) ?(start = `inclusive) ?(stop = `exclusive) start_v stop_v =\n let step =\n match stop with\n | `inclusive when stride >= 0 ->\n fun i -> if i > stop_v then Done else Yield (i, i + stride)\n | `inclusive -> fun i -> if i < stop_v then Done else Yield (i, i + stride)\n | `exclusive when stride >= 0 ->\n fun i -> if i >= stop_v then Done else Yield (i, i + stride)\n | `exclusive -> fun i -> if i <= stop_v then Done else Yield (i, i + stride)\n in\n let init =\n match start with\n | `inclusive -> start_v\n | `exclusive -> start_v + stride\n in\n unfold_step ~init ~f:step\n;;\n\nlet of_lazy t_lazy =\n unfold_step ~init:t_lazy ~f:(fun t_lazy ->\n let (Sequence (s, next)) = Lazy.force t_lazy in\n match next s with\n | Done -> Done\n | Skip s ->\n Skip\n (let v = Sequence (s, next) in\n lazy v)\n | Yield (x, s) ->\n Yield\n ( x\n , let v = Sequence (s, next) in\n lazy v ))\n;;\n\nlet map t ~f =\n match t with\n | Sequence (seed, next) ->\n Sequence\n ( seed\n , fun seed ->\n match next seed with\n | Done -> Done\n | Skip s -> Skip s\n | Yield (a, s) -> Yield (f a, s) )\n;;\n\nlet mapi t ~f =\n match t with\n | Sequence (s, next) ->\n Sequence\n ( (0, s)\n , fun (i, s) ->\n match next s with\n | Done -> Done\n | Skip s -> Skip (i, s)\n | Yield (a, s) -> Yield (f i a, (i + 1, s)) )\n;;\n\nlet folding_map t ~init ~f =\n unfold_with t ~init ~f:(fun acc x ->\n let acc, x = f acc x in\n Yield (x, acc))\n;;\n\nlet folding_mapi t ~init ~f =\n unfold_with t ~init:(0, init) ~f:(fun (i, acc) x ->\n let acc, x = f i acc x in\n Yield (x, (i + 1, acc)))\n;;\n\nlet filter t ~f =\n match t with\n | Sequence (seed, next) ->\n Sequence\n ( seed\n , fun seed ->\n match next seed with\n | Done -> Done\n | Skip s -> Skip s\n | Yield (a, s) when f a -> Yield (a, s)\n | Yield (_, s) -> Skip s )\n;;\n\nlet filteri t ~f =\n map ~f:snd (filter (mapi t ~f:(fun i s -> i, s)) ~f:(fun (i, s) -> f i s))\n;;\n\nlet length t =\n let rec loop i s next =\n match next s with\n | Done -> i\n | Skip s -> loop i s next\n | Yield (_, s) -> loop (i + 1) s next\n in\n match t with\n | Sequence (seed, next) -> loop 0 seed next\n;;\n\nlet to_list_rev_with_length t = fold t ~init:([], 0) ~f:(fun (l, i) x -> x :: l, i + 1)\n\nlet to_array t =\n let l, len = to_list_rev_with_length t in\n match l with\n | [] -> [||]\n | x :: l ->\n let a = Array.create ~len x in\n let rec loop i l =\n match l with\n | [] -> assert (i = -1)\n | x :: l ->\n a.(i) <- x;\n loop (i - 1) l\n in\n loop (len - 2) l;\n a\n;;\n\nlet find t ~f =\n let rec loop s next f =\n match next s with\n | Done -> None\n | Yield (a, _) when f a -> Some a\n | Yield (_, s) | Skip s -> loop s next f\n in\n match t with\n | Sequence (seed, next) -> loop seed next f\n;;\n\nlet find_map t ~f =\n let rec loop s next f =\n match next s with\n | Done -> None\n | Yield (a, s) ->\n (match f a with\n | None -> loop s next f\n | some_b -> some_b)\n | Skip s -> loop s next f\n in\n match t with\n | Sequence (seed, next) -> loop seed next f\n;;\n\n\nlet find_mapi t ~f =\n let rec loop s next f i =\n match next s with\n | Done -> None\n | Yield (a, s) ->\n (match f i a with\n | None -> loop s next f (i + 1)\n | some_b -> some_b)\n | Skip s -> loop s next f i\n in\n match t with\n | Sequence (seed, next) -> loop seed next f 0\n;;\n\nlet for_all t ~f =\n let rec loop s next f =\n match next s with\n | Done -> true\n | Yield (a, _) when not (f a) -> false\n | Yield (_, s) | Skip s -> loop s next f\n in\n match t with\n | Sequence (seed, next) -> loop seed next f\n;;\n\nlet for_alli t ~f =\n let rec loop s next f i =\n match next s with\n | Done -> true\n | Yield (a, _) when not (f i a) -> false\n | Yield (_, s) -> loop s next f (i + 1)\n | Skip s -> loop s next f i\n in\n match t with\n | Sequence (seed, next) -> loop seed next f 0\n;;\n\nlet exists t ~f =\n let rec loop s next f =\n match next s with\n | Done -> false\n | Yield (a, _) when f a -> true\n | Yield (_, s) | Skip s -> loop s next f\n in\n match t with\n | Sequence (seed, next) -> loop seed next f\n;;\n\nlet existsi t ~f =\n let rec loop s next f i =\n match next s with\n | Done -> false\n | Yield (a, _) when f i a -> true\n | Yield (_, s) -> loop s next f (i + 1)\n | Skip s -> loop s next f i\n in\n match t with\n | Sequence (seed, next) -> loop seed next f 0\n;;\n\nlet iter t ~f =\n let rec loop seed next f =\n match next seed with\n | Done -> ()\n | Skip s -> loop s next f\n | Yield (a, s) ->\n f a;\n loop s next f\n in\n match t with\n | Sequence (seed, next) -> loop seed next f\n;;\n\nlet is_empty t =\n let rec loop s next =\n match next s with\n | Done -> true\n | Skip s -> loop s next\n | Yield _ -> false\n in\n match t with\n | Sequence (seed, next) -> loop seed next\n;;\n\nlet mem t a ~equal =\n let rec loop s next a =\n match next s with\n | Done -> false\n | Yield (b, _) when equal a b -> true\n | Yield (_, s) | Skip s -> loop s next a\n in\n match t with\n | Sequence (seed, next) -> loop seed next a\n;;\n\nlet empty = Sequence ((), fun () -> Done)\n\nlet bind t ~f =\n unfold_step\n ~f:(function\n | Sequence (seed, next), rest ->\n (match next seed with\n | Done ->\n (match rest with\n | Sequence (seed, next) ->\n (match next seed with\n | Done -> Done\n | Skip s -> Skip (empty, Sequence (s, next))\n | Yield (a, s) -> Skip (f a, Sequence (s, next))))\n | Skip s -> Skip (Sequence (s, next), rest)\n | Yield (a, s) -> Yield (a, (Sequence (s, next), rest))))\n ~init:(empty, t)\n;;\n\nlet return x =\n unfold_step ~init:(Some x) ~f:(function\n | None -> Done\n | Some x -> Yield (x, None))\n;;\n\ninclude Monad.Make (struct\n type nonrec 'a t = 'a t\n\n let map = `Custom map\n let bind = bind\n let return = return\n end)\n\nlet nth s n =\n if n < 0\n then None\n else (\n let rec loop i s next =\n match next s with\n | Done -> None\n | Skip s -> loop i s next\n | Yield (a, s) -> if phys_equal i 0 then Some a else loop (i - 1) s next\n in\n match s with\n | Sequence (s, next) -> loop n s next)\n;;\n\nlet nth_exn s n =\n if n < 0\n then invalid_arg \"Sequence.nth\"\n else (\n match nth s n with\n | None -> failwith \"Sequence.nth\"\n | Some x -> x)\n;;\n\nmodule Merge_with_duplicates_element = struct\n type ('a, 'b) t =\n | Left of 'a\n | Right of 'b\n | Both of 'a * 'b\n [@@deriving_inline compare, hash, sexp]\n\n let compare :\n 'a 'b. ('a -> 'a -> int) -> ('b -> 'b -> int) -> ('a, 'b) t -> ('a, 'b) t -> int\n =\n fun _cmp__a _cmp__b a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match a__001_, b__002_ with\n | Left _a__003_, Left _b__004_ -> _cmp__a _a__003_ _b__004_\n | Left _, _ -> -1\n | _, Left _ -> 1\n | Right _a__005_, Right _b__006_ -> _cmp__b _a__005_ _b__006_\n | Right _, _ -> -1\n | _, Right _ -> 1\n | Both (_a__007_, _a__009_), Both (_b__008_, _b__010_) ->\n (match _cmp__a _a__007_ _b__008_ with\n | 0 -> _cmp__b _a__009_ _b__010_\n | n -> n))\n ;;\n\n let hash_fold_t\n : type a b.\n (Ppx_hash_lib.Std.Hash.state -> a -> Ppx_hash_lib.Std.Hash.state)\n -> (Ppx_hash_lib.Std.Hash.state -> b -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state\n -> (a, b) t\n -> Ppx_hash_lib.Std.Hash.state\n =\n fun _hash_fold_a _hash_fold_b hsv arg ->\n match arg with\n | Left _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 0 in\n let hsv = hsv in\n _hash_fold_a hsv _a0\n | Right _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 1 in\n let hsv = hsv in\n _hash_fold_b hsv _a0\n | Both (_a0, _a1) ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 2 in\n let hsv =\n let hsv = hsv in\n _hash_fold_a hsv _a0\n in\n _hash_fold_b hsv _a1\n ;;\n\n let t_of_sexp\n : type a b.\n (Ppx_sexp_conv_lib.Sexp.t -> a)\n -> (Ppx_sexp_conv_lib.Sexp.t -> b)\n -> Ppx_sexp_conv_lib.Sexp.t\n -> (a, b) t\n =\n let _tp_loc = \"sequence.ml.Merge_with_duplicates_element.t\" in\n fun _of_a _of_b -> function\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"left\" | \"Left\") as _tag) :: sexp_args) as _sexp\n ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_a v0 in\n Left v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"right\" | \"Right\") as _tag) :: sexp_args) as\n _sexp ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_b v0 in\n Right v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"both\" | \"Both\") as _tag) :: sexp_args) as _sexp\n ->\n (match sexp_args with\n | [ v0; v1 ] ->\n let v0 = _of_a v0\n and v1 = _of_b v1 in\n Both (v0, v1)\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.Atom (\"left\" | \"Left\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.Atom (\"right\" | \"Right\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.Atom (\"both\" | \"Both\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n ;;\n\n let sexp_of_t\n : type a b.\n (a -> Ppx_sexp_conv_lib.Sexp.t)\n -> (b -> Ppx_sexp_conv_lib.Sexp.t)\n -> (a, b) t\n -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a _of_b -> function\n | Left v0 ->\n let v0 = _of_a v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Left\"; v0 ]\n | Right v0 ->\n let v0 = _of_b v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Right\"; v0 ]\n | Both (v0, v1) ->\n let v0 = _of_a v0\n and v1 = _of_b v1 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Both\"; v0; v1 ]\n ;;\n\n [@@@end]\nend\n\nlet merge_with_duplicates (Sequence (s1, next1)) (Sequence (s2, next2)) ~compare =\n let unshadowed_compare = compare in\n let open Merge_with_duplicates_element in\n let next = function\n | Skip s1, s2 -> Skip (next1 s1, s2)\n | s1, Skip s2 -> Skip (s1, next2 s2)\n | (Yield (a, s1') as s1), (Yield (b, s2') as s2) ->\n let comparison = unshadowed_compare a b in\n if comparison < 0\n then Yield (Left a, (Skip s1', s2))\n else if comparison = 0\n then Yield (Both (a, b), (Skip s1', Skip s2'))\n else Yield (Right b, (s1, Skip s2'))\n | Done, Done -> Done\n | Yield (a, s1), Done -> Yield (Left a, (Skip s1, Done))\n | Done, Yield (b, s2) -> Yield (Right b, (Done, Skip s2))\n in\n Sequence ((Skip s1, Skip s2), next)\n;;\n\nlet merge s1 s2 ~compare =\n map (merge_with_duplicates s1 s2 ~compare) ~f:(function\n | Left x | Right x | Both (x, _) -> x)\n;;\n\nlet hd s =\n let rec loop s next =\n match next s with\n | Done -> None\n | Skip s -> loop s next\n | Yield (a, _) -> Some a\n in\n match s with\n | Sequence (s, next) -> loop s next\n;;\n\nlet hd_exn s =\n match hd s with\n | None -> failwith \"hd_exn\"\n | Some a -> a\n;;\n\nlet tl s =\n let rec loop s next =\n match next s with\n | Done -> None\n | Skip s -> loop s next\n | Yield (_, a) -> Some a\n in\n match s with\n | Sequence (s, next) ->\n (match loop s next with\n | None -> None\n | Some s -> Some (Sequence (s, next)))\n;;\n\nlet tl_eagerly_exn s =\n match tl s with\n | None -> failwith \"Sequence.tl_exn\"\n | Some s -> s\n;;\n\nlet lift_identity next s =\n match next s with\n | Done -> Done\n | Skip s -> Skip (`Identity s)\n | Yield (a, s) -> Yield (a, `Identity s)\n;;\n\nlet next s =\n let rec loop s next =\n match next s with\n | Done -> None\n | Skip s -> loop s next\n | Yield (a, s) -> Some (a, Sequence (s, next))\n in\n match s with\n | Sequence (s, next) -> loop s next\n;;\n\nlet filter_opt s =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( s\n , fun s ->\n match next s with\n | Done -> Done\n | Skip s -> Skip s\n | Yield (None, s) -> Skip s\n | Yield (Some a, s) -> Yield (a, s) )\n;;\n\nlet filter_map s ~f = filter_opt (map s ~f)\nlet filter_mapi s ~f = filter_map (mapi s ~f:(fun i s -> i, s)) ~f:(fun (i, s) -> f i s)\n\nlet split_n s n =\n let rec loop s i accum next =\n if i <= 0\n then List.rev accum, Sequence (s, next)\n else (\n match next s with\n | Done -> List.rev accum, empty\n | Skip s -> loop s i accum next\n | Yield (a, s) -> loop s (i - 1) (a :: accum) next)\n in\n match s with\n | Sequence (s, next) -> loop s n [] next\n;;\n\nlet chunks_exn t n =\n if n <= 0\n then invalid_arg \"Sequence.chunks_exn\"\n else\n unfold_step ~init:t ~f:(fun t ->\n match split_n t n with\n | [], _empty -> Done\n | (_ :: _ as xs), t -> Yield (xs, t))\n;;\n\nlet findi s ~f = find (mapi s ~f:(fun i s -> i, s)) ~f:(fun (i, s) -> f i s)\n\nlet find_exn s ~f =\n match find s ~f with\n | None -> failwith \"Sequence.find_exn\"\n | Some x -> x\n;;\n\nlet append s1 s2 =\n match s1, s2 with\n | Sequence (s1, next1), Sequence (s2, next2) ->\n Sequence\n ( `First_list s1\n , function\n | `First_list s1 ->\n (match next1 s1 with\n | Done -> Skip (`Second_list s2)\n | Skip s1 -> Skip (`First_list s1)\n | Yield (a, s1) -> Yield (a, `First_list s1))\n | `Second_list s2 ->\n (match next2 s2 with\n | Done -> Done\n | Skip s2 -> Skip (`Second_list s2)\n | Yield (a, s2) -> Yield (a, `Second_list s2)) )\n;;\n\nlet concat_map s ~f = bind s ~f\nlet concat s = concat_map s ~f:Fn.id\nlet concat_mapi s ~f = concat_map (mapi s ~f:(fun i s -> i, s)) ~f:(fun (i, s) -> f i s)\n\nlet zip (Sequence (s1, next1)) (Sequence (s2, next2)) =\n let next = function\n | Yield (a, s1), Yield (b, s2) -> Yield ((a, b), (Skip s1, Skip s2))\n | Done, _ | _, Done -> Done\n | Skip s1, s2 -> Skip (next1 s1, s2)\n | s1, Skip s2 -> Skip (s1, next2 s2)\n in\n Sequence ((Skip s1, Skip s2), next)\n;;\n\nlet zip_full (Sequence (s1, next1)) (Sequence (s2, next2)) =\n let next = function\n | Yield (a, s1), Yield (b, s2) -> Yield (`Both (a, b), (Skip s1, Skip s2))\n | Done, Done -> Done\n | Skip s1, s2 -> Skip (next1 s1, s2)\n | s1, Skip s2 -> Skip (s1, next2 s2)\n | Done, Yield (b, s2) -> Yield (`Right b, (Done, next2 s2))\n | Yield (a, s1), Done -> Yield (`Left a, (next1 s1, Done))\n in\n Sequence ((Skip s1, Skip s2), next)\n;;\n\nlet bounded_length (Sequence (seed, next)) ~at_most =\n let rec loop i seed next =\n if i > at_most\n then `Greater\n else (\n match next seed with\n | Done -> `Is i\n | Skip seed -> loop i seed next\n | Yield (_, seed) -> loop (i + 1) seed next)\n in\n loop 0 seed next\n;;\n\nlet length_is_bounded_by ?(min = -1) ?max t =\n let length_is_at_least (Sequence (s, next)) =\n let rec loop s acc =\n if acc >= min\n then true\n else (\n match next s with\n | Done -> false\n | Skip s -> loop s acc\n | Yield (_, s) -> loop s (acc + 1))\n in\n loop s 0\n in\n match max with\n | None -> length_is_at_least t\n | Some max ->\n (match bounded_length t ~at_most:max with\n | `Is len when len >= min -> true\n | _ -> false)\n;;\n\nlet iteri s ~f = iter (mapi s ~f:(fun i s -> i, s)) ~f:(fun (i, s) -> f i s)\n\nlet foldi s ~init ~f =\n fold ~init (mapi s ~f:(fun i s -> i, s)) ~f:(fun acc (i, s) -> f i acc s)\n;;\n\nlet reduce s ~f =\n match next s with\n | None -> None\n | Some (a, s) -> Some (fold s ~init:a ~f)\n;;\n\nlet reduce_exn s ~f =\n match reduce s ~f with\n | None -> failwith \"Sequence.reduce_exn\"\n | Some res -> res\n;;\n\nlet group (Sequence (s, next)) ~break =\n unfold_step\n ~init:(Some ([], s))\n ~f:(function\n | None -> Done\n | Some (acc, s) ->\n (match acc, next s with\n | _, Skip s -> Skip (Some (acc, s))\n | [], Done -> Done\n | acc, Done -> Yield (List.rev acc, None)\n | [], Yield (cur, s) -> Skip (Some ([ cur ], s))\n | (prev :: _ as acc), Yield (cur, s) ->\n if break prev cur\n then Yield (List.rev acc, Some ([ cur ], s))\n else Skip (Some (cur :: acc, s))))\n;;\n\nlet find_consecutive_duplicate (Sequence (s, next)) ~equal =\n let rec loop last_elt s =\n match next s with\n | Done -> None\n | Skip s -> loop last_elt s\n | Yield (a, s) ->\n (match last_elt with\n | Some b when equal a b -> Some (b, a)\n | None | Some _ -> loop (Some a) s)\n in\n loop None s\n;;\n\nlet remove_consecutive_duplicates s ~equal =\n unfold_with s ~init:None ~f:(fun prev a ->\n match prev with\n | Some b when equal a b -> Skip (Some a)\n | None | Some _ -> Yield (a, Some a))\n;;\n\nlet count s ~f = length (filter s ~f)\nlet counti t ~f = length (filteri t ~f)\nlet sum m t ~f = Container.sum ~fold m t ~f\nlet min_elt t ~compare = Container.min_elt ~fold t ~compare\nlet max_elt t ~compare = Container.max_elt ~fold t ~compare\n\nlet init n ~f =\n unfold_step ~init:0 ~f:(fun i -> if i >= n then Done else Yield (f i, i + 1))\n;;\n\nlet sub s ~pos ~len =\n if pos < 0 || len < 0 then failwith \"Sequence.sub\";\n match s with\n | Sequence (s, next) ->\n Sequence\n ( (0, s)\n , fun (i, s) ->\n if i - pos >= len\n then Done\n else (\n match next s with\n | Done -> Done\n | Skip s -> Skip (i, s)\n | Yield (a, s) when i >= pos -> Yield (a, (i + 1, s))\n | Yield (_, s) -> Skip (i + 1, s)) )\n;;\n\nlet take s len =\n if len < 0 then failwith \"Sequence.take\";\n match s with\n | Sequence (s, next) ->\n Sequence\n ( (0, s)\n , fun (i, s) ->\n if i >= len\n then Done\n else (\n match next s with\n | Done -> Done\n | Skip s -> Skip (i, s)\n | Yield (a, s) -> Yield (a, (i + 1, s))) )\n;;\n\nlet drop s len =\n if len < 0 then failwith \"Sequence.drop\";\n match s with\n | Sequence (s, next) ->\n Sequence\n ( (0, s)\n , fun (i, s) ->\n match next s with\n | Done -> Done\n | Skip s -> Skip (i, s)\n | Yield (a, s) when i >= len -> Yield (a, (i + 1, s))\n | Yield (_, s) -> Skip (i + 1, s) )\n;;\n\nlet take_while s ~f =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( s\n , fun s ->\n match next s with\n | Done -> Done\n | Skip s -> Skip s\n | Yield (a, s) when f a -> Yield (a, s)\n | Yield (_, _) -> Done )\n;;\n\nlet drop_while s ~f =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( `Dropping s\n , function\n | `Dropping s ->\n (match next s with\n | Done -> Done\n | Skip s -> Skip (`Dropping s)\n | Yield (a, s) when f a -> Skip (`Dropping s)\n | Yield (a, s) -> Yield (a, `Identity s))\n | `Identity s -> lift_identity next s )\n;;\n\nlet shift_right s x =\n match s with\n | Sequence (seed, next) ->\n Sequence\n ( `Consing (seed, x)\n , function\n | `Consing (seed, x) -> Yield (x, `Identity seed)\n | `Identity s -> lift_identity next s )\n;;\n\nlet shift_right_with_list s l = append (of_list l) s\nlet shift_left = drop\n\nmodule Infix = struct\n let ( @ ) = append\nend\n\nlet intersperse s ~sep =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( `Init s\n , function\n | `Init s ->\n (match next s with\n | Done -> Done\n | Skip s -> Skip (`Init s)\n | Yield (a, s) -> Yield (a, `Running s))\n | `Running s ->\n (match next s with\n | Done -> Done\n | Skip s -> Skip (`Running s)\n | Yield (a, s) -> Yield (sep, `Putting (a, s)))\n | `Putting (a, s) -> Yield (a, `Running s) )\n;;\n\nlet repeat x = unfold_step ~init:x ~f:(fun x -> Yield (x, x))\n\nlet cycle_list_exn xs =\n if List.is_empty xs then invalid_arg \"Sequence.cycle_list_exn\";\n let s = of_list xs in\n concat_map ~f:(fun () -> s) (repeat ())\n;;\n\nlet cartesian_product sa sb = concat_map sa ~f:(fun a -> zip (repeat a) sb)\nlet singleton x = return x\n\nlet delayed_fold s ~init ~f ~finish =\n Expert.delayed_fold_step s ~init ~finish ~f:(fun acc option ~k ->\n match option with\n | None -> k acc\n | Some a -> f acc a ~k)\n;;\n\nlet fold_m ~bind ~return t ~init ~f =\n Expert.delayed_fold_step\n t\n ~init\n ~f:(fun acc option ~k ->\n match option with\n | None -> bind (return acc) ~f:k\n | Some a -> bind (f acc a) ~f:k)\n ~finish:return\n;;\n\nlet iter_m ~bind ~return t ~f =\n Expert.delayed_fold_step\n t\n ~init:()\n ~f:(fun () option ~k ->\n match option with\n | None -> bind (return ()) ~f:k\n | Some a -> bind (f a) ~f:k)\n ~finish:return\n;;\n\nlet fold_until s ~init ~f ~finish =\n let rec loop s next f acc =\n match next s with\n | Done -> finish acc\n | Skip s -> loop s next f acc\n | Yield (a, s) ->\n (match (f acc a : ('a, 'b) Continue_or_stop.t) with\n | Stop x -> x\n | Continue acc -> loop s next f acc)\n in\n match s with\n | Sequence (s, next) -> loop s next f init\n;;\n\nlet fold_result s ~init ~f =\n let rec loop s next f acc =\n match next s with\n | Done -> Result.return acc\n | Skip s -> loop s next f acc\n | Yield (a, s) ->\n (match (f acc a : (_, _) Result.t) with\n | Error _ as e -> e\n | Ok acc -> loop s next f acc)\n in\n match s with\n | Sequence (s, next) -> loop s next f init\n;;\n\nlet force_eagerly t = of_list (to_list t)\n\nlet memoize (type a) (Sequence (s, next)) =\n let module M = struct\n type t = T of (a, t) Step.t Lazy.t\n end\n in\n let rec memoize s = M.T (lazy (find_step s))\n and find_step s =\n match next s with\n | Done -> Done\n | Skip s -> find_step s\n | Yield (a, s) -> Yield (a, memoize s)\n in\n Sequence (memoize s, fun (M.T l) -> Lazy.force l)\n;;\n\nlet drop_eagerly s len =\n let rec loop i ~len s next =\n if i >= len\n then Sequence (s, next)\n else (\n match next s with\n | Done -> empty\n | Skip s -> loop i ~len s next\n | Yield (_, s) -> loop (i + 1) ~len s next)\n in\n match s with\n | Sequence (s, next) -> loop 0 ~len s next\n;;\n\nlet drop_while_option (Sequence (s, next)) ~f =\n let rec loop s =\n match next s with\n | Done -> None\n | Skip s -> loop s\n | Yield (x, s) -> if f x then loop s else Some (x, Sequence (s, next))\n in\n loop s\n;;\n\nlet compare compare_a t1 t2 =\n With_return.with_return (fun r ->\n iter (zip_full t1 t2) ~f:(function\n | `Left _ -> r.return 1\n | `Right _ -> r.return (-1)\n | `Both (v1, v2) ->\n let c = compare_a v1 v2 in\n if c <> 0 then r.return c);\n 0)\n;;\n\nlet equal equal_a t1 t2 =\n for_all (zip_full t1 t2) ~f:(function\n | `Both (a1, a2) -> equal_a a1 a2\n | `Left _ | `Right _ -> false)\n;;\n\nlet round_robin list =\n let next (todo_stack, done_stack) =\n match todo_stack with\n | Sequence (s, f) :: todo_stack ->\n (match f s with\n | Yield (x, s) -> Yield (x, (todo_stack, Sequence (s, f) :: done_stack))\n | Skip s -> Skip (Sequence (s, f) :: todo_stack, done_stack)\n | Done -> Skip (todo_stack, done_stack))\n | [] -> if List.is_empty done_stack then Done else Skip (List.rev done_stack, [])\n in\n let state = list, [] in\n Sequence (state, next)\n;;\n\nlet interleave (Sequence (s1, f1)) =\n let next (todo_stack, done_stack, s1) =\n match todo_stack with\n | Sequence (s2, f2) :: todo_stack ->\n (match f2 s2 with\n | Yield (x, s2) -> Yield (x, (todo_stack, Sequence (s2, f2) :: done_stack, s1))\n | Skip s2 -> Skip (todo_stack, Sequence (s2, f2) :: done_stack, s1)\n | Done -> Skip (todo_stack, done_stack, s1))\n | [] ->\n (match f1 s1, done_stack with\n | Yield (t, s1), _ -> Skip (List.rev (t :: done_stack), [], s1)\n | Skip s1, _ -> Skip (List.rev done_stack, [], s1)\n | Done, _ :: _ -> Skip (List.rev done_stack, [], s1)\n | Done, [] -> Done)\n in\n let state = [], [], s1 in\n Sequence (state, next)\n;;\n\nlet interleaved_cartesian_product s1 s2 =\n map s1 ~f:(fun x1 -> map s2 ~f:(fun x2 -> x1, x2)) |> interleave\n;;\n\nlet of_seq (seq : _ Caml.Seq.t) =\n unfold_step ~init:seq ~f:(fun seq ->\n match seq () with\n | Nil -> Done\n | Cons (hd, tl) -> Yield (hd, tl))\n;;\n\nlet to_seq (Sequence (state, next)) =\n let rec loop state =\n match next state with\n | Done -> Caml.Seq.Nil\n | Skip state -> loop state\n | Yield (hd, state) -> Caml.Seq.Cons (hd, fun () -> loop state)\n in\n fun () -> loop state\n;;\n\nmodule Generator = struct\n type 'elt steps = Wrap of ('elt, unit -> 'elt steps) Step.t\n\n let unwrap (Wrap step) = step\n\n module T = struct\n type ('a, 'elt) t = ('a -> 'elt steps) -> 'elt steps\n\n let return x k = k x\n\n let bind m ~f k =\n m (fun a ->\n let m' = f a in\n m' k)\n ;;\n\n let map m ~f k = m (fun a -> k (f a))\n let map = `Custom map\n end\n\n include T\n include Monad.Make2 (T)\n\n let yield e k = Wrap (Yield (e, k))\n let to_steps t = t (fun () -> Wrap Done)\n\n let of_sequence sequence =\n delayed_fold\n sequence\n ~init:()\n ~f:(fun () x ~k f -> Wrap (Yield (x, fun () -> k () f)))\n ~finish:return\n ;;\n\n let run t =\n let init () = to_steps t in\n let f thunk = unwrap (thunk ()) in\n unfold_step ~init ~f\n ;;\nend\n","open! Import\ninclude Array0\nmodule Int = Int0\n\ntype 'a t = 'a array [@@deriving_inline compare, sexp, sexp_grammar]\n\nlet compare : 'a. ('a -> 'a -> int) -> 'a t -> 'a t -> int = compare_array\n\nlet t_of_sexp : 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t =\n array_of_sexp\n;;\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n sexp_of_array\n;;\n\nlet (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"array\" ]\n ; ggid = \"j\\132);\\135qH\\158\\135\\222H\\001\\007\\004\\158\\218\"\n ; types = [ \"t\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ])) ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ array_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"array.ml\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n;;\n\n[@@@end]\n\n(* This module implements a new in-place, constant heap sorting algorithm to replace the\n one used by the standard libraries. Its only purpose is to be faster (hopefully\n strictly faster) than the base sort and stable_sort.\n\n At a high level the algorithm is:\n - pick two pivot points by:\n - pick 5 arbitrary elements from the array\n - sort them within the array\n - take the elements on either side of the middle element of the sort as the pivots\n - sort the array with:\n - all elements less than pivot1 to the left (range 1)\n - all elements >= pivot1 and <= pivot2 in the middle (range 2)\n - all elements > pivot2 to the right (range 3)\n - if pivot1 and pivot2 are equal, then the middle range is sorted, so ignore it\n - recurse into range 1, 2 (if pivot1 and pivot2 are unequal), and 3\n - during recursion there are two inflection points:\n - if the size of the current range is small, use insertion sort to sort it\n - if the stack depth is large, sort the range with heap-sort to avoid n^2 worst-case\n behavior\n\n See the following for more information:\n - \"Dual-Pivot Quicksort\" by Vladimir Yaroslavskiy.\n Available at\n http://www.kriche.com.ar/root/programming/spaceTimeComplexity/DualPivotQuicksort.pdf\n - \"Quicksort is Optimal\" by Sedgewick and Bentley.\n Slides at http://www.cs.princeton.edu/~rs/talks/QuicksortIsOptimal.pdf\n - http://www.sorting-algorithms.com/quick-sort-3-way *)\n\nmodule Sort = struct\n (* For the sake of speed we could use unsafe get/set throughout, but speed tests don't\n show a significant improvement. *)\n let get = get\n let set = set\n\n let swap arr i j =\n let tmp = get arr i in\n set arr i (get arr j);\n set arr j tmp\n ;;\n\n module type Sort = sig\n val sort\n : 'a t\n -> compare:('a -> 'a -> int)\n -> left:int (* leftmost index of sub-array to sort *)\n -> right:int (* rightmost index of sub-array to sort *)\n -> unit\n end\n\n (* http://en.wikipedia.org/wiki/Insertion_sort *)\n module Insertion_sort : Sort = struct\n let sort arr ~compare ~left ~right =\n (* loop invariant:\n [arr] is sorted from [left] to [pos - 1], inclusive *)\n for pos = left + 1 to right do\n (* loop invariants:\n 1. the subarray arr[left .. i-1] is sorted\n 2. the subarray arr[i+1 .. pos] is sorted and contains only elements > v\n 3. arr[i] may be thought of as containing v\n\n Note that this does not allocate a closure, but is left in the for\n loop for the readability of the documentation. *)\n let rec loop arr ~left ~compare i v =\n let i_next = i - 1 in\n if i_next >= left && compare (get arr i_next) v > 0\n then (\n set arr i (get arr i_next);\n loop arr ~left ~compare i_next v)\n else i\n in\n let v = get arr pos in\n let final_pos = loop arr ~left ~compare pos v in\n set arr final_pos v\n done\n ;;\n end\n\n (* http://en.wikipedia.org/wiki/Heapsort *)\n module Heap_sort : Sort = struct\n (* loop invariant:\n root's children are both either roots of max-heaps or > right *)\n let rec heapify arr ~compare root ~left ~right =\n let relative_root = root - left in\n let left_child = (2 * relative_root) + left + 1 in\n let right_child = (2 * relative_root) + left + 2 in\n let largest =\n if left_child <= right && compare (get arr left_child) (get arr root) > 0\n then left_child\n else root\n in\n let largest =\n if right_child <= right && compare (get arr right_child) (get arr largest) > 0\n then right_child\n else largest\n in\n if largest <> root\n then (\n swap arr root largest;\n heapify arr ~compare largest ~left ~right)\n ;;\n\n let build_heap arr ~compare ~left ~right =\n (* Elements in the second half of the array are already heaps of size 1. We move\n through the first half of the array from back to front examining the element at\n hand, and the left and right children, fixing the heap property as we go. *)\n for i = (left + right) / 2 downto left do\n heapify arr ~compare i ~left ~right\n done\n ;;\n\n let sort arr ~compare ~left ~right =\n build_heap arr ~compare ~left ~right;\n (* loop invariants:\n 1. the subarray arr[left ... i] is a max-heap H\n 2. the subarray arr[i+1 ... right] is sorted (call it S)\n 3. every element of H is less than every element of S *)\n for i = right downto left + 1 do\n swap arr left i;\n heapify arr ~compare left ~left ~right:(i - 1)\n done\n ;;\n end\n\n (* http://en.wikipedia.org/wiki/Introsort *)\n module Intro_sort : sig\n include Sort\n\n val five_element_sort\n : 'a t\n -> compare:('a -> 'a -> int)\n -> int\n -> int\n -> int\n -> int\n -> int\n -> unit\n end = struct\n let five_element_sort arr ~compare m1 m2 m3 m4 m5 =\n let compare_and_swap i j =\n if compare (get arr i) (get arr j) > 0 then swap arr i j\n in\n (* Optimal 5-element sorting network:\n\n {v\n 1--o-----o-----o--------------1\n | | |\n 2--o-----|--o--|-----o--o-----2\n | | | | |\n 3--------o--o--|--o--|--o-----3\n | | |\n 4-----o--------o--o--|-----o--4\n | | |\n 5-----o--------------o-----o--5\n v} *)\n compare_and_swap m1 m2;\n compare_and_swap m4 m5;\n compare_and_swap m1 m3;\n compare_and_swap m2 m3;\n compare_and_swap m1 m4;\n compare_and_swap m3 m4;\n compare_and_swap m2 m5;\n compare_and_swap m2 m3;\n compare_and_swap m4 m5\n ;;\n\n (* choose pivots for the array by sorting 5 elements and examining the center three\n elements. The goal is to choose two pivots that will either:\n - break the range up into 3 even partitions\n or\n - eliminate a commonly appearing element by sorting it into the center partition\n by itself\n To this end we look at the center 3 elements of the 5 and return pairs of equal\n elements or the widest range *)\n let choose_pivots arr ~compare ~left ~right =\n let sixth = (right - left) / 6 in\n let m1 = left + sixth in\n let m2 = m1 + sixth in\n let m3 = m2 + sixth in\n let m4 = m3 + sixth in\n let m5 = m4 + sixth in\n five_element_sort arr ~compare m1 m2 m3 m4 m5;\n let m2_val = get arr m2 in\n let m3_val = get arr m3 in\n let m4_val = get arr m4 in\n if compare m2_val m3_val = 0\n then m2_val, m3_val, true\n else if compare m3_val m4_val = 0\n then m3_val, m4_val, true\n else m2_val, m4_val, false\n ;;\n\n let dual_pivot_partition arr ~compare ~left ~right =\n let pivot1, pivot2, pivots_equal = choose_pivots arr ~compare ~left ~right in\n (* loop invariants:\n 1. left <= l < r <= right\n 2. l <= p <= r\n 3. l <= x < p implies arr[x] >= pivot1\n and arr[x] <= pivot2\n 4. left <= x < l implies arr[x] < pivot1\n 5. r < x <= right implies arr[x] > pivot2 *)\n let rec loop l p r =\n let pv = get arr p in\n if compare pv pivot1 < 0\n then (\n swap arr p l;\n cont (l + 1) (p + 1) r)\n else if compare pv pivot2 > 0\n then (\n (* loop invariants: same as those of the outer loop *)\n let rec scan_backwards r =\n if r > p && compare (get arr r) pivot2 > 0 then scan_backwards (r - 1) else r\n in\n let r = scan_backwards r in\n swap arr r p;\n cont l p (r - 1))\n else cont l (p + 1) r\n and cont l p r = if p > r then l, r else loop l p r in\n let l, r = cont left left right in\n l, r, pivots_equal\n ;;\n\n let rec intro_sort arr ~max_depth ~compare ~left ~right =\n let len = right - left + 1 in\n (* This takes care of some edge cases, such as left > right or very short arrays,\n since Insertion_sort.sort handles these cases properly. Thus we don't need to\n make sure that left and right are valid in recursive calls. *)\n if len <= 32\n then Insertion_sort.sort arr ~compare ~left ~right\n else if max_depth < 0\n then Heap_sort.sort arr ~compare ~left ~right\n else (\n let max_depth = max_depth - 1 in\n let l, r, middle_sorted = dual_pivot_partition arr ~compare ~left ~right in\n intro_sort arr ~max_depth ~compare ~left ~right:(l - 1);\n if not middle_sorted then intro_sort arr ~max_depth ~compare ~left:l ~right:r;\n intro_sort arr ~max_depth ~compare ~left:(r + 1) ~right)\n ;;\n\n let log10_of_3 = Caml.log10 3.\n let log3 x = Caml.log10 x /. log10_of_3\n\n let sort arr ~compare ~left ~right =\n let len = right - left + 1 in\n let heap_sort_switch_depth =\n (* with perfect 3-way partitioning, this is the recursion depth *)\n Int.of_float (log3 (Int.to_float len))\n in\n intro_sort arr ~max_depth:heap_sort_switch_depth ~compare ~left ~right\n ;;\n end\nend\n\nlet sort ?pos ?len arr ~compare =\n let pos, len =\n Ordered_collection_common.get_pos_len_exn () ?pos ?len ~total_length:(length arr)\n in\n Sort.Intro_sort.sort arr ~compare ~left:pos ~right:(pos + len - 1)\n;;\n\nlet to_array t = t\nlet is_empty t = length t = 0\n\nlet is_sorted t ~compare =\n let rec is_sorted_loop t ~compare i =\n if i < 1\n then true\n else compare t.(i - 1) t.(i) <= 0 && is_sorted_loop t ~compare (i - 1)\n in\n is_sorted_loop t ~compare (length t - 1)\n;;\n\nlet is_sorted_strictly t ~compare =\n let rec is_sorted_strictly_loop t ~compare i =\n if i < 1\n then true\n else compare t.(i - 1) t.(i) < 0 && is_sorted_strictly_loop t ~compare (i - 1)\n in\n is_sorted_strictly_loop t ~compare (length t - 1)\n;;\n\nlet folding_map t ~init ~f =\n let acc = ref init in\n map t ~f:(fun x ->\n let new_acc, y = f !acc x in\n acc := new_acc;\n y)\n;;\n\nlet fold_map t ~init ~f =\n let acc = ref init in\n let result =\n map t ~f:(fun x ->\n let new_acc, y = f !acc x in\n acc := new_acc;\n y)\n in\n !acc, result\n;;\n\nlet fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\nlet fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\nlet count t ~f = Container.count ~fold t ~f\nlet sum m t ~f = Container.sum ~fold m t ~f\nlet min_elt t ~compare = Container.min_elt ~fold t ~compare\nlet max_elt t ~compare = Container.max_elt ~fold t ~compare\n\nlet foldi t ~init ~f =\n let rec foldi_loop t i ac ~f =\n if i = length t then ac else foldi_loop t (i + 1) (f i ac t.(i)) ~f\n in\n foldi_loop t 0 init ~f\n;;\n\nlet folding_mapi t ~init ~f =\n let acc = ref init in\n mapi t ~f:(fun i x ->\n let new_acc, y = f i !acc x in\n acc := new_acc;\n y)\n;;\n\nlet fold_mapi t ~init ~f =\n let acc = ref init in\n let result =\n mapi t ~f:(fun i x ->\n let new_acc, y = f i !acc x in\n acc := new_acc;\n y)\n in\n !acc, result\n;;\n\nlet counti t ~f =\n foldi t ~init:0 ~f:(fun idx count a -> if f idx a then count + 1 else count)\n;;\n\nlet concat_map t ~f = concat (to_list (map ~f t))\nlet concat_mapi t ~f = concat (to_list (mapi ~f t))\n\nlet rev_inplace t =\n let i = ref 0 in\n let j = ref (length t - 1) in\n while !i < !j do\n swap t !i !j;\n incr i;\n decr j\n done\n;;\n\nlet of_list_rev l =\n match l with\n | [] -> [||]\n | a :: l ->\n let len = 1 + List.length l in\n let t = create ~len a in\n let r = ref l in\n (* We start at [len - 2] because we already put [a] at [t.(len - 1)]. *)\n for i = len - 2 downto 0 do\n match !r with\n | [] -> assert false\n | a :: l ->\n t.(i) <- a;\n r := l\n done;\n t\n;;\n\n(* [of_list_map] and [of_list_rev_map] are based on functions from the OCaml\n distribution. *)\n\nlet of_list_map xs ~f =\n match xs with\n | [] -> [||]\n | hd :: tl ->\n let a = create ~len:(1 + List.length tl) (f hd) in\n let rec fill i = function\n | [] -> a\n | hd :: tl ->\n unsafe_set a i (f hd);\n fill (i + 1) tl\n in\n fill 1 tl\n;;\n\nlet of_list_mapi xs ~f =\n match xs with\n | [] -> [||]\n | hd :: tl ->\n let a = create ~len:(1 + List.length tl) (f 0 hd) in\n let rec fill a i = function\n | [] -> a\n | hd :: tl ->\n unsafe_set a i (f i hd);\n fill a (i + 1) tl\n in\n fill a 1 tl\n;;\n\nlet of_list_rev_map xs ~f =\n let t = of_list_map xs ~f in\n rev_inplace t;\n t\n;;\n\nlet of_list_rev_mapi xs ~f =\n let t = of_list_mapi xs ~f in\n rev_inplace t;\n t\n;;\n\nlet filter_mapi t ~f =\n let r = ref [||] in\n let k = ref 0 in\n for i = 0 to length t - 1 do\n match f i (unsafe_get t i) with\n | None -> ()\n | Some a ->\n if !k = 0 then r := create ~len:(length t) a;\n unsafe_set !r !k a;\n incr k\n done;\n if !k = length t then !r else if !k > 0 then sub ~pos:0 ~len:!k !r else [||]\n;;\n\nlet filter_map t ~f = filter_mapi t ~f:(fun _i a -> f a)\nlet filter_opt t = filter_map t ~f:Fn.id\n\nlet raise_length_mismatch name n1 n2 =\n invalid_argf \"length mismatch in %s: %d <> %d\" name n1 n2 ()\n[@@cold] [@@inline never] [@@local never] [@@specialise never]\n;;\n\nlet check_length2_exn name t1 t2 =\n let n1 = length t1 in\n let n2 = length t2 in\n if n1 <> n2 then raise_length_mismatch name n1 n2\n;;\n\nlet iter2_exn t1 t2 ~f =\n check_length2_exn \"Array.iter2_exn\" t1 t2;\n iteri t1 ~f:(fun i x1 -> f x1 t2.(i))\n;;\n\nlet map2_exn t1 t2 ~f =\n check_length2_exn \"Array.map2_exn\" t1 t2;\n init (length t1) ~f:(fun i -> f t1.(i) t2.(i))\n;;\n\nlet fold2_exn t1 t2 ~init ~f =\n check_length2_exn \"Array.fold2_exn\" t1 t2;\n foldi t1 ~init ~f:(fun i ac x -> f ac x t2.(i))\n;;\n\nlet filter t ~f = filter_map t ~f:(fun x -> if f x then Some x else None)\nlet filteri t ~f = filter_mapi t ~f:(fun i x -> if f i x then Some x else None)\n\nlet exists t ~f =\n let rec exists_loop t ~f i =\n if i < 0 then false else f t.(i) || exists_loop t ~f (i - 1)\n in\n exists_loop t ~f (length t - 1)\n;;\n\nlet existsi t ~f =\n let rec existsi_loop t ~f i =\n if i < 0 then false else f i t.(i) || existsi_loop t ~f (i - 1)\n in\n existsi_loop t ~f (length t - 1)\n;;\n\nlet mem t a ~equal = exists t ~f:(equal a)\n\nlet for_all t ~f =\n let rec for_all_loop t ~f i =\n if i < 0 then true else f t.(i) && for_all_loop t ~f (i - 1)\n in\n for_all_loop t ~f (length t - 1)\n;;\n\nlet for_alli t ~f =\n let rec for_alli_loop t ~f i =\n if i < 0 then true else f i t.(i) && for_alli_loop t ~f (i - 1)\n in\n for_alli_loop t ~f (length t - 1)\n;;\n\nlet exists2_exn t1 t2 ~f =\n let rec exists2_exn_loop t1 t2 ~f i =\n if i < 0 then false else f t1.(i) t2.(i) || exists2_exn_loop t1 t2 ~f (i - 1)\n in\n check_length2_exn \"Array.exists2_exn\" t1 t2;\n exists2_exn_loop t1 t2 ~f (length t1 - 1)\n;;\n\nlet for_all2_exn t1 t2 ~f =\n let rec for_all2_loop t1 t2 ~f i =\n if i < 0 then true else f t1.(i) t2.(i) && for_all2_loop t1 t2 ~f (i - 1)\n in\n check_length2_exn \"Array.for_all2_exn\" t1 t2;\n for_all2_loop t1 t2 ~f (length t1 - 1)\n;;\n\nlet equal equal t1 t2 = length t1 = length t2 && for_all2_exn t1 t2 ~f:equal\n\n\nlet map_inplace t ~f =\n for i = 0 to length t - 1 do\n t.(i) <- f t.(i)\n done\n;;\n\nlet findi t ~f =\n let rec findi_loop t ~f ~length i =\n if i >= length\n then None\n else if f i t.(i)\n then Some (i, t.(i))\n else findi_loop t ~f ~length (i + 1)\n in\n let length = length t in\n findi_loop t ~f ~length 0\n;;\n\nlet findi_exn =\n let not_found = Not_found_s (Atom \"Array.findi_exn: not found\") in\n let findi_exn t ~f =\n match findi t ~f with\n | None -> raise not_found\n | Some x -> x\n in\n (* named to preserve symbol in compiled binary *)\n findi_exn\n;;\n\nlet find_exn =\n let not_found = Not_found_s (Atom \"Array.find_exn: not found\") in\n let find_exn t ~f =\n match findi t ~f:(fun _i x -> f x) with\n | None -> raise not_found\n | Some (_i, x) -> x\n in\n (* named to preserve symbol in compiled binary *)\n find_exn\n;;\n\nlet find t ~f = Option.map (findi t ~f:(fun _i x -> f x)) ~f:(fun (_i, x) -> x)\n\nlet find_map t ~f =\n let rec find_map_loop t ~f ~length i =\n if i >= length\n then None\n else (\n match f t.(i) with\n | None -> find_map_loop t ~f ~length (i + 1)\n | Some _ as res -> res)\n in\n let length = length t in\n find_map_loop t ~f ~length 0\n;;\n\nlet find_map_exn =\n let not_found = Not_found_s (Atom \"Array.find_map_exn: not found\") in\n let find_map_exn t ~f =\n match find_map t ~f with\n | None -> raise not_found\n | Some x -> x\n in\n (* named to preserve symbol in compiled binary *)\n find_map_exn\n;;\n\nlet find_mapi t ~f =\n let rec find_mapi_loop t ~f ~length i =\n if i >= length\n then None\n else (\n match f i t.(i) with\n | None -> find_mapi_loop t ~f ~length (i + 1)\n | Some _ as res -> res)\n in\n let length = length t in\n find_mapi_loop t ~f ~length 0\n;;\n\nlet find_mapi_exn =\n let not_found = Not_found_s (Atom \"Array.find_mapi_exn: not found\") in\n let find_mapi_exn t ~f =\n match find_mapi t ~f with\n | None -> raise not_found\n | Some x -> x\n in\n (* named to preserve symbol in compiled binary *)\n find_mapi_exn\n;;\n\nlet find_consecutive_duplicate t ~equal =\n let n = length t in\n if n <= 1\n then None\n else (\n let result = ref None in\n let i = ref 1 in\n let prev = ref t.(0) in\n while !i < n do\n let cur = t.(!i) in\n if equal cur !prev\n then (\n result := Some (!prev, cur);\n i := n)\n else (\n prev := cur;\n incr i)\n done;\n !result)\n;;\n\nlet reduce t ~f =\n if length t = 0\n then None\n else (\n let r = ref t.(0) in\n for i = 1 to length t - 1 do\n r := f !r t.(i)\n done;\n Some !r)\n;;\n\nlet reduce_exn t ~f =\n match reduce t ~f with\n | None -> invalid_arg \"Array.reduce_exn\"\n | Some v -> v\n;;\n\nlet permute = Array_permute.permute\n\nlet random_element_exn ?(random_state = Random.State.default) t =\n if is_empty t\n then failwith \"Array.random_element_exn: empty array\"\n else t.(Random.State.int random_state (length t))\n;;\n\nlet random_element ?(random_state = Random.State.default) t =\n try Some (random_element_exn ~random_state t) with\n | _ -> None\n;;\n\nlet zip t1 t2 =\n if length t1 <> length t2 then None else Some (map2_exn t1 t2 ~f:(fun x1 x2 -> x1, x2))\n;;\n\nlet zip_exn t1 t2 =\n if length t1 <> length t2\n then failwith \"Array.zip_exn\"\n else map2_exn t1 t2 ~f:(fun x1 x2 -> x1, x2)\n;;\n\nlet unzip t =\n let n = length t in\n if n = 0\n then [||], [||]\n else (\n let x, y = t.(0) in\n let res1 = create ~len:n x in\n let res2 = create ~len:n y in\n for i = 1 to n - 1 do\n let x, y = t.(i) in\n res1.(i) <- x;\n res2.(i) <- y\n done;\n res1, res2)\n;;\n\nlet sorted_copy t ~compare =\n let t1 = copy t in\n sort t1 ~compare;\n t1\n;;\n\nlet partitioni_tf t ~f =\n let both = mapi t ~f:(fun i x -> if f i x then Either.First x else Either.Second x) in\n let trues =\n filter_map both ~f:(function\n | First x -> Some x\n | Second _ -> None)\n in\n let falses =\n filter_map both ~f:(function\n | First _ -> None\n | Second x -> Some x)\n in\n trues, falses\n;;\n\nlet partition_tf t ~f = partitioni_tf t ~f:(fun _i x -> f x)\nlet last t = t.(length t - 1)\n\n(* Convert to a sequence but does not attempt to protect against modification\n in the array. *)\nlet to_sequence_mutable t =\n Sequence.unfold_step ~init:0 ~f:(fun i ->\n if i >= length t then Sequence.Step.Done else Sequence.Step.Yield (t.(i), i + 1))\n;;\n\nlet to_sequence t = to_sequence_mutable (copy t)\n\nlet cartesian_product t1 t2 =\n if is_empty t1 || is_empty t2\n then [||]\n else (\n let n1 = length t1 in\n let n2 = length t2 in\n let t = create ~len:(n1 * n2) (t1.(0), t2.(0)) in\n let r = ref 0 in\n for i1 = 0 to n1 - 1 do\n for i2 = 0 to n2 - 1 do\n t.(!r) <- (t1.(i1), t2.(i2));\n incr r\n done\n done;\n t)\n;;\n\nlet transpose tt =\n if length tt = 0\n then Some [||]\n else (\n let width = length tt in\n let depth = length tt.(0) in\n if exists tt ~f:(fun t -> length t <> depth)\n then None\n else Some (init depth ~f:(fun d -> init width ~f:(fun w -> tt.(w).(d)))))\n;;\n\nlet transpose_exn tt =\n match transpose tt with\n | None -> invalid_arg \"Array.transpose_exn\"\n | Some tt' -> tt'\n;;\n\ninclude Binary_searchable.Make1 (struct\n type nonrec 'a t = 'a t\n\n let get = get\n let length = length\n end)\n\ninclude Blit.Make1 (struct\n type nonrec 'a t = 'a t\n\n let length = length\n\n let create_like ~len t =\n if len = 0\n then [||]\n else (\n assert (length t > 0);\n create ~len t.(0))\n ;;\n\n let unsafe_blit = blit\n end)\n\nlet invariant invariant_a t = iter t ~f:invariant_a\n\nmodule Private = struct\n module Sort = Sort\nend\n","open! Import\nmodule Int = Int0\nmodule String = String0\nmodule Array = Array0\n\n(* We maintain the property that all values of type [t] do not have the tag\n [double_array_tag]. Some functions below assume this in order to avoid testing the\n tag, and will segfault if this property doesn't hold. *)\ntype t = Caml.Obj.t array\n\nlet invariant t = assert (Caml.Obj.tag (Caml.Obj.repr t) <> Caml.Obj.double_array_tag)\nlet length = Array.length\nlet swap t i j = Array.swap t i j\n\nlet sexp_of_t t =\n Sexp.Atom\n (String.concat ~sep:\"\" [ \"\" ])\n;;\n\nlet zero_obj = Caml.Obj.repr (0 : int)\n\n(* We call [Array.create] with a value that is not a float so that the array doesn't get\n tagged with [Double_array_tag]. *)\nlet create_zero ~len = Array.create ~len zero_obj\n\nlet create ~len x =\n (* If we can, use [Array.create] directly. *)\n if Caml.Obj.tag x <> Caml.Obj.double_tag\n then Array.create ~len x\n else (\n (* Otherwise use [create_zero] and set the contents *)\n let t = create_zero ~len in\n let x = Sys.opaque_identity x in\n for i = 0 to len - 1 do\n Array.unsafe_set t i x\n done;\n t)\n;;\n\nlet empty = [||]\n\ntype not_a_float =\n | Not_a_float_0\n | Not_a_float_1 of int\n\nlet _not_a_float_0 = Not_a_float_0\nlet _not_a_float_1 = Not_a_float_1 42\n\nlet get t i =\n (* Make the compiler believe [t] is an array not containing floats so it does not check\n if [t] is tagged with [Double_array_tag]. It is NOT ok to use [int array] since (if\n this function is inlined and the array contains in-heap boxed values) wrong register\n typing may result, leading to a failure to register necessary GC roots. *)\n Caml.Obj.repr ((Caml.Obj.magic (t : t) : not_a_float array).(i) : not_a_float)\n;;\n\nlet[@inline always] unsafe_get t i =\n (* Make the compiler believe [t] is an array not containing floats so it does not check\n if [t] is tagged with [Double_array_tag]. *)\n Caml.Obj.repr\n (Array.unsafe_get (Caml.Obj.magic (t : t) : not_a_float array) i : not_a_float)\n;;\n\nlet[@inline always] unsafe_set_with_caml_modify t i obj =\n (* Same comment as [unsafe_get]. Sys.opaque_identity prevents the compiler from\n potentially wrongly guessing the type of the array based on the type of element, that\n is prevent the implication: (Obj.tag obj = Obj.double_tag) => (Obj.tag t =\n Obj.double_array_tag) which flambda has tried in the past (at least that's assuming\n the compiler respects Sys.opaque_identity, which is not always the case). *)\n Array.unsafe_set\n (Caml.Obj.magic (t : t) : not_a_float array)\n i\n (Caml.Obj.obj (Sys.opaque_identity obj) : not_a_float)\n;;\n\nlet[@inline always] unsafe_set_int_assuming_currently_int t i int =\n (* This skips [caml_modify], which is OK if both the old and new values are integers. *)\n Array.unsafe_set (Caml.Obj.magic (t : t) : int array) i (Sys.opaque_identity int)\n;;\n\n(* For [set] and [unsafe_set], if a pointer is involved, we first do a physical-equality\n test to see if the pointer is changing. If not, we don't need to do the [set], which\n saves a call to [caml_modify]. We think this physical-equality test is worth it\n because it is very cheap (both values are already available from the [is_int] test)\n and because [caml_modify] is expensive. *)\n\nlet set t i obj =\n (* We use [get] first but then we use [Array.unsafe_set] since we know that [i] is\n valid. *)\n let old_obj = get t i in\n if Caml.Obj.is_int old_obj && Caml.Obj.is_int obj\n then unsafe_set_int_assuming_currently_int t i (Caml.Obj.obj obj : int)\n else if not (phys_equal old_obj obj)\n then unsafe_set_with_caml_modify t i obj\n;;\n\nlet[@inline always] unsafe_set t i obj =\n let old_obj = unsafe_get t i in\n if Caml.Obj.is_int old_obj && Caml.Obj.is_int obj\n then unsafe_set_int_assuming_currently_int t i (Caml.Obj.obj obj : int)\n else if not (phys_equal old_obj obj)\n then unsafe_set_with_caml_modify t i obj\n;;\n\nlet[@inline always] unsafe_set_omit_phys_equal_check t i obj =\n let old_obj = unsafe_get t i in\n if Caml.Obj.is_int old_obj && Caml.Obj.is_int obj\n then unsafe_set_int_assuming_currently_int t i (Caml.Obj.obj obj : int)\n else unsafe_set_with_caml_modify t i obj\n;;\n\nlet singleton obj = create ~len:1 obj\n\n(* Pre-condition: t.(i) is an integer. *)\nlet unsafe_set_assuming_currently_int t i obj =\n if Caml.Obj.is_int obj\n then unsafe_set_int_assuming_currently_int t i (Caml.Obj.obj obj : int)\n else\n (* [t.(i)] is an integer and [obj] is not, so we do not need to check if they are\n equal. *)\n unsafe_set_with_caml_modify t i obj\n;;\n\nlet unsafe_set_int t i int =\n let old_obj = unsafe_get t i in\n if Caml.Obj.is_int old_obj\n then unsafe_set_int_assuming_currently_int t i int\n else unsafe_set_with_caml_modify t i (Caml.Obj.repr int)\n;;\n\nlet unsafe_clear_if_pointer t i =\n let old_obj = unsafe_get t i in\n if not (Caml.Obj.is_int old_obj) then unsafe_set_with_caml_modify t i (Caml.Obj.repr 0)\n;;\n\n(** [unsafe_blit] is like [Array.blit], except it uses our own for-loop to avoid\n caml_modify when possible. Its performance is still not comparable to a memcpy. *)\nlet unsafe_blit ~src ~src_pos ~dst ~dst_pos ~len =\n (* When [phys_equal src dst], we need to check whether [dst_pos < src_pos] and have the\n for loop go in the right direction so that we don't overwrite data that we still need\n to read. When [not (phys_equal src dst)], doing this is harmless. From a\n memory-performance perspective, it doesn't matter whether one loops up or down.\n Constant-stride access, forward or backward, should be indistinguishable (at least on\n an intel i7). So, we don't do a check for [phys_equal src dst] and always loop up in\n that case. *)\n if dst_pos < src_pos\n then\n for i = 0 to len - 1 do\n unsafe_set dst (dst_pos + i) (unsafe_get src (src_pos + i))\n done\n else\n for i = len - 1 downto 0 do\n unsafe_set dst (dst_pos + i) (unsafe_get src (src_pos + i))\n done\n;;\n\ninclude Blit.Make (struct\n type nonrec t = t\n\n let create = create_zero\n let length = length\n let unsafe_blit = unsafe_blit\n end)\n\nlet copy src =\n let dst = create_zero ~len:(length src) in\n blito ~src ~dst ();\n dst\n;;\n","open! Import\n\n(* WARNING:\n We use non-memory-safe things throughout the [Trusted] module.\n Most of it is only safe in combination with the type signature (e.g. exposing\n [val copy : 'a t -> 'b t] would be a big mistake). *)\nmodule Trusted : sig\n type 'a t\n\n val empty : 'a t\n val unsafe_create_uninitialized : len:int -> 'a t\n val create_obj_array : len:int -> 'a t\n val create : len:int -> 'a -> 'a t\n val singleton : 'a -> 'a t\n val get : 'a t -> int -> 'a\n val set : 'a t -> int -> 'a -> unit\n val swap : _ t -> int -> int -> unit\n val unsafe_get : 'a t -> int -> 'a\n val unsafe_set : 'a t -> int -> 'a -> unit\n val unsafe_set_omit_phys_equal_check : 'a t -> int -> 'a -> unit\n val unsafe_set_int : 'a t -> int -> int -> unit\n val unsafe_set_int_assuming_currently_int : 'a t -> int -> int -> unit\n val unsafe_set_assuming_currently_int : 'a t -> int -> 'a -> unit\n val length : 'a t -> int\n val unsafe_blit : ('a t, 'a t) Blit.blit\n val copy : 'a t -> 'a t\n val unsafe_clear_if_pointer : _ t -> int -> unit\nend = struct\n type 'a t = Obj_array.t\n\n let empty = Obj_array.empty\n let unsafe_create_uninitialized ~len = Obj_array.create_zero ~len\n let create_obj_array ~len = Obj_array.create_zero ~len\n let create ~len x = Obj_array.create ~len (Caml.Obj.repr x)\n let singleton x = Obj_array.singleton (Caml.Obj.repr x)\n let swap t i j = Obj_array.swap t i j\n let get arr i = Caml.Obj.obj (Obj_array.get arr i)\n let set arr i x = Obj_array.set arr i (Caml.Obj.repr x)\n let unsafe_get arr i = Caml.Obj.obj (Obj_array.unsafe_get arr i)\n let unsafe_set arr i x = Obj_array.unsafe_set arr i (Caml.Obj.repr x)\n let unsafe_set_int arr i x = Obj_array.unsafe_set_int arr i x\n\n let unsafe_set_int_assuming_currently_int arr i x =\n Obj_array.unsafe_set_int_assuming_currently_int arr i x\n ;;\n\n let unsafe_set_assuming_currently_int arr i x =\n Obj_array.unsafe_set_assuming_currently_int arr i (Caml.Obj.repr x)\n ;;\n\n let length = Obj_array.length\n let unsafe_blit = Obj_array.unsafe_blit\n let copy = Obj_array.copy\n\n let unsafe_set_omit_phys_equal_check t i x =\n Obj_array.unsafe_set_omit_phys_equal_check t i (Caml.Obj.repr x)\n ;;\n\n let unsafe_clear_if_pointer = Obj_array.unsafe_clear_if_pointer\nend\n\ninclude Trusted\n\nlet invariant t = assert (Caml.Obj.tag (Caml.Obj.repr t) <> Caml.Obj.double_array_tag)\n\nlet init l ~f =\n if l < 0\n then invalid_arg \"Uniform_array.init\"\n else (\n let res = unsafe_create_uninitialized ~len:l in\n for i = 0 to l - 1 do\n unsafe_set res i (f i)\n done;\n res)\n;;\n\nlet of_array arr = init ~f:(Array.unsafe_get arr) (Array.length arr)\nlet map a ~f = init ~f:(fun i -> f (unsafe_get a i)) (length a)\n\nlet iter a ~f =\n for i = 0 to length a - 1 do\n f (unsafe_get a i)\n done\n;;\n\nlet iteri a ~f =\n for i = 0 to length a - 1 do\n f i (unsafe_get a i)\n done\n;;\n\nlet to_list t = List.init ~f:(get t) (length t)\n\nlet of_list l =\n let len = List.length l in\n let res = unsafe_create_uninitialized ~len in\n List.iteri l ~f:(fun i x -> set res i x);\n res\n;;\n\n(* It is not safe for [to_array] to be the identity function because we have code that\n relies on [float array]s being unboxed, for example in [bin_write_array]. *)\nlet to_array t = Array.init (length t) ~f:(fun i -> unsafe_get t i)\n\nlet exists t ~f =\n let rec loop t ~f i =\n if i < 0 then false else f (unsafe_get t i) || loop t ~f (i - 1)\n in\n loop t ~f (length t - 1)\n;;\n\nlet map2_exn t1 t2 ~f =\n let len = length t1 in\n if length t2 <> len then invalid_arg \"Array.map2_exn\";\n init len ~f:(fun i -> f (unsafe_get t1 i) (unsafe_get t2 i))\n;;\n\ninclude Sexpable.Of_sexpable1\n (Array)\n (struct\n type nonrec 'a t = 'a t\n\n let to_sexpable = to_array\n let of_sexpable = of_array\n end)\n\ninclude Blit.Make1 (struct\n type nonrec 'a t = 'a t\n\n let length = length\n\n let create_like ~len t =\n if len = 0\n then empty\n else (\n assert (length t > 0);\n create ~len (get t 0))\n ;;\n\n let unsafe_blit = unsafe_blit\n end)\n\nlet fold t ~init ~f =\n let r = ref init in\n for i = 0 to length t - 1 do\n r := f !r (unsafe_get t i)\n done;\n !r\n;;\n\nlet min_elt t ~compare = Container.min_elt ~fold t ~compare\nlet max_elt t ~compare = Container.max_elt ~fold t ~compare\n","open! Import\nmodule Array = Array0\nmodule String = String0\ninclude Char0\n\nmodule T = struct\n type t = char [@@deriving_inline compare, hash, sexp, sexp_grammar]\n\n let compare = (compare_char : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_char\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_char in\n fun x -> func x\n ;;\n\n let t_of_sexp = (char_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_char : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"char\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ char_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"char.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let to_string t = String.make 1 t\n\n let of_string s =\n match String.length s with\n | 1 -> s.[0]\n | _ -> failwithf \"Char.of_string: %S\" s ()\n ;;\nend\n\ninclude T\n\ninclude Identifiable.Make (struct\n include T\n\n let module_name = \"Base.Char\"\n end)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! Char_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet all = Array.init 256 ~f:unsafe_of_int |> Array.to_list\n\nlet is_lowercase = function\n | 'a' .. 'z' -> true\n | _ -> false\n;;\n\nlet is_uppercase = function\n | 'A' .. 'Z' -> true\n | _ -> false\n;;\n\nlet is_print = function\n | ' ' .. '~' -> true\n | _ -> false\n;;\n\nlet is_whitespace = function\n | '\\t' | '\\n' | '\\011' (* vertical tab *) | '\\012' (* form feed *) | '\\r' | ' ' -> true\n | _ -> false\n;;\n\nlet is_digit = function\n | '0' .. '9' -> true\n | _ -> false\n;;\n\nlet is_alpha = function\n | 'a' .. 'z' | 'A' .. 'Z' -> true\n | _ -> false\n;;\n\n(* Writing these out, instead of calling [is_alpha] and [is_digit], reduces\n runtime by approx. 30% *)\nlet is_alphanum = function\n | 'a' .. 'z' | 'A' .. 'Z' | '0' .. '9' -> true\n | _ -> false\n;;\n\nlet get_digit_unsafe t = to_int t - to_int '0'\n\nlet get_digit_exn t =\n if is_digit t\n then get_digit_unsafe t\n else failwithf \"Char.get_digit_exn %C: not a digit\" t ()\n;;\n\nlet get_digit t = if is_digit t then Some (get_digit_unsafe t) else None\n\nmodule O = struct\n let ( >= ) = ( >= )\n let ( <= ) = ( <= )\n let ( = ) = ( = )\n let ( > ) = ( > )\n let ( < ) = ( < )\n let ( <> ) = ( <> )\nend\n\nmodule Caseless = struct\n module T = struct\n type t = char [@@deriving_inline sexp]\n\n let t_of_sexp = (char_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_char : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n\n let compare c1 c2 = compare (lowercase c1) (lowercase c2)\n let hash_fold_t state t = hash_fold_char state (lowercase t)\n let hash t = Hash.run hash_fold_t t\n end\n\n include T\n include Comparable.Make (T)\nend\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Char_replace_polymorphic_compare\n","open! Import\nmodule Array = Array0\nmodule Bytes = Bytes0\ninclude String0\n\nlet invalid_argf = Printf.invalid_argf\nlet raise_s = Error.raise_s\nlet stage = Staged.stage\n\nmodule T = struct\n type t = string [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_string\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_string in\n fun x -> func x\n ;;\n\n let t_of_sexp = (string_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_string : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"string\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ string_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"string.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare = compare\nend\n\ninclude T\ninclude Comparator.Make (T)\n\ntype elt = char\n\nlet invariant (_ : t) = ()\n\n(* This is copied/adapted from 'blit.ml'.\n [sub], [subo] could be implemented using [Blit.Make(Bytes)] plus unsafe casts to/from\n string but were inlined here to avoid using [Bytes.unsafe_of_string] as much as possible.\n*)\nlet sub src ~pos ~len =\n if pos = 0 && len = String.length src\n then src\n else (\n Ordered_collection_common.check_pos_len_exn ~pos ~len ~total_length:(length src);\n let dst = Bytes.create len in\n if len > 0 then Bytes.unsafe_blit_string ~src ~src_pos:pos ~dst ~dst_pos:0 ~len;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:dst)\n;;\n\nlet subo ?(pos = 0) ?len src =\n sub\n src\n ~pos\n ~len:\n (match len with\n | Some i -> i\n | None -> length src - pos)\n;;\n\nlet rec contains_unsafe t ~pos ~end_ char =\n pos < end_\n && (Char.equal (unsafe_get t pos) char || contains_unsafe t ~pos:(pos + 1) ~end_ char)\n;;\n\nlet contains ?(pos = 0) ?len t char =\n let total_length = String.length t in\n let len = Option.value len ~default:(total_length - pos) in\n Ordered_collection_common.check_pos_len_exn ~pos ~len ~total_length;\n contains_unsafe t ~pos ~end_:(pos + len) char\n;;\n\nlet is_empty t = length t = 0\n\nlet rec index_from_exn_internal string ~pos ~len ~not_found char =\n if pos >= len\n then raise not_found\n else if Char.equal (unsafe_get string pos) char\n then pos\n else index_from_exn_internal string ~pos:(pos + 1) ~len ~not_found char\n;;\n\nlet index_exn_internal t ~not_found char =\n index_from_exn_internal t ~pos:0 ~len:(length t) ~not_found char\n;;\n\nlet index_exn =\n let not_found = Not_found_s (Atom \"String.index_exn: not found\") in\n let index_exn t char = index_exn_internal t ~not_found char in\n (* named to preserve symbol in compiled binary *)\n index_exn\n;;\n\nlet index_from_exn =\n let not_found = Not_found_s (Atom \"String.index_from_exn: not found\") in\n let index_from_exn t pos char =\n let len = length t in\n if pos < 0 || pos > len\n then invalid_arg \"String.index_from_exn\"\n else index_from_exn_internal t ~pos ~len ~not_found char\n in\n (* named to preserve symbol in compiled binary *)\n index_from_exn\n;;\n\nlet rec rindex_from_exn_internal string ~pos ~len ~not_found char =\n if pos < 0\n then raise not_found\n else if Char.equal (unsafe_get string pos) char\n then pos\n else rindex_from_exn_internal string ~pos:(pos - 1) ~len ~not_found char\n;;\n\nlet rindex_exn_internal t ~not_found char =\n let len = length t in\n rindex_from_exn_internal t ~pos:(len - 1) ~len ~not_found char\n;;\n\nlet rindex_exn =\n let not_found = Not_found_s (Atom \"String.rindex_exn: not found\") in\n let rindex_exn t char = rindex_exn_internal t ~not_found char in\n (* named to preserve symbol in compiled binary *)\n rindex_exn\n;;\n\nlet rindex_from_exn =\n let not_found = Not_found_s (Atom \"String.rindex_from_exn: not found\") in\n let rindex_from_exn t pos char =\n let len = length t in\n if pos < -1 || pos >= len\n then invalid_arg \"String.rindex_from_exn\"\n else rindex_from_exn_internal t ~pos ~len ~not_found char\n in\n (* named to preserve symbol in compiled binary *)\n rindex_from_exn\n;;\n\nlet index t char =\n try Some (index_exn t char) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nlet rindex t char =\n try Some (rindex_exn t char) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nlet index_from t pos char =\n try Some (index_from_exn t pos char) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nlet rindex_from t pos char =\n try Some (rindex_from_exn t pos char) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nmodule Search_pattern0 = struct\n type t =\n { pattern : string\n ; case_sensitive : bool\n ; kmp_array : int array\n }\n\n let sexp_of_t { pattern; case_sensitive; kmp_array = _ } : Sexp.t =\n List\n [ List [ Atom \"pattern\"; sexp_of_string pattern ]\n ; List [ Atom \"case_sensitive\"; sexp_of_bool case_sensitive ]\n ]\n ;;\n\n let pattern t = t.pattern\n let case_sensitive t = t.case_sensitive\n\n (* Find max number of matched characters at [next_text_char], given the current\n [matched_chars]. Try to extend the current match, if chars don't match, try to match\n fewer chars. If chars match then extend the match. *)\n let kmp_internal_loop ~matched_chars ~next_text_char ~pattern ~kmp_array ~char_equal =\n let matched_chars = ref matched_chars in\n while\n !matched_chars > 0\n && not (char_equal next_text_char (unsafe_get pattern !matched_chars))\n do\n matched_chars := Array.unsafe_get kmp_array (!matched_chars - 1)\n done;\n if char_equal next_text_char (unsafe_get pattern !matched_chars)\n then matched_chars := !matched_chars + 1;\n !matched_chars\n ;;\n\n let get_char_equal ~case_sensitive =\n match case_sensitive with\n | true -> Char.equal\n | false -> Char.Caseless.equal\n ;;\n\n (* Classic KMP pre-processing of the pattern: build the int array, which, for each i,\n contains the length of the longest non-trivial prefix of s which is equal to a suffix\n ending at s.[i] *)\n let create pattern ~case_sensitive =\n let n = length pattern in\n let kmp_array = Array.create ~len:n (-1) in\n if n > 0\n then (\n let char_equal = get_char_equal ~case_sensitive in\n Array.unsafe_set kmp_array 0 0;\n let matched_chars = ref 0 in\n for i = 1 to n - 1 do\n matched_chars\n := kmp_internal_loop\n ~matched_chars:!matched_chars\n ~next_text_char:(unsafe_get pattern i)\n ~pattern\n ~kmp_array\n ~char_equal;\n Array.unsafe_set kmp_array i !matched_chars\n done);\n { pattern; case_sensitive; kmp_array }\n ;;\n\n (* Classic KMP: use the pre-processed pattern to optimize look-behinds on non-matches.\n We return int to avoid allocation in [index_exn]. -1 means no match. *)\n let index_internal ?(pos = 0) { pattern; case_sensitive; kmp_array } ~in_:text =\n if pos < 0 || pos > length text - length pattern\n then -1\n else (\n let char_equal = get_char_equal ~case_sensitive in\n let j = ref pos in\n let matched_chars = ref 0 in\n let k = length pattern in\n let n = length text in\n while !j < n && !matched_chars < k do\n let next_text_char = unsafe_get text !j in\n matched_chars\n := kmp_internal_loop\n ~matched_chars:!matched_chars\n ~next_text_char\n ~pattern\n ~kmp_array\n ~char_equal;\n j := !j + 1\n done;\n if !matched_chars = k then !j - k else -1)\n ;;\n\n let matches t str = index_internal t ~in_:str >= 0\n\n let index ?pos t ~in_ =\n let p = index_internal ?pos t ~in_ in\n if p < 0 then None else Some p\n ;;\n\n let index_exn ?pos t ~in_ =\n let p = index_internal ?pos t ~in_ in\n if p >= 0\n then p\n else\n raise_s\n (Sexp.message \"Substring not found\" [ \"substring\", sexp_of_string t.pattern ])\n ;;\n\n let index_all { pattern; case_sensitive; kmp_array } ~may_overlap ~in_:text =\n if length pattern = 0\n then List.init (1 + length text) ~f:Fn.id\n else (\n let char_equal = get_char_equal ~case_sensitive in\n let matched_chars = ref 0 in\n let k = length pattern in\n let n = length text in\n let found = ref [] in\n for j = 0 to n do\n if !matched_chars = k\n then (\n found := (j - k) :: !found;\n (* we just found a match in the previous iteration *)\n match may_overlap with\n | true -> matched_chars := Array.unsafe_get kmp_array (k - 1)\n | false -> matched_chars := 0);\n if j < n\n then (\n let next_text_char = unsafe_get text j in\n matched_chars\n := kmp_internal_loop\n ~matched_chars:!matched_chars\n ~next_text_char\n ~pattern\n ~kmp_array\n ~char_equal)\n done;\n List.rev !found)\n ;;\n\n let replace_first ?pos t ~in_:s ~with_ =\n match index ?pos t ~in_:s with\n | None -> s\n | Some i ->\n let len_s = length s in\n let len_t = length t.pattern in\n let len_with = length with_ in\n let dst = Bytes.create (len_s + len_with - len_t) in\n Bytes.blit_string ~src:s ~src_pos:0 ~dst ~dst_pos:0 ~len:i;\n Bytes.blit_string ~src:with_ ~src_pos:0 ~dst ~dst_pos:i ~len:len_with;\n Bytes.blit_string\n ~src:s\n ~src_pos:(i + len_t)\n ~dst\n ~dst_pos:(i + len_with)\n ~len:(len_s - i - len_t);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:dst\n ;;\n\n\n let replace_all t ~in_:s ~with_ =\n let matches = index_all t ~may_overlap:false ~in_:s in\n match matches with\n | [] -> s\n | _ :: _ ->\n let len_s = length s in\n let len_t = length t.pattern in\n let len_with = length with_ in\n let num_matches = List.length matches in\n let dst = Bytes.create (len_s + ((len_with - len_t) * num_matches)) in\n let next_dst_pos = ref 0 in\n let next_src_pos = ref 0 in\n List.iter matches ~f:(fun i ->\n let len = i - !next_src_pos in\n Bytes.blit_string\n ~src:s\n ~src_pos:!next_src_pos\n ~dst\n ~dst_pos:!next_dst_pos\n ~len;\n Bytes.blit_string\n ~src:with_\n ~src_pos:0\n ~dst\n ~dst_pos:(!next_dst_pos + len)\n ~len:len_with;\n next_dst_pos := !next_dst_pos + len + len_with;\n next_src_pos := !next_src_pos + len + len_t);\n Bytes.blit_string\n ~src:s\n ~src_pos:!next_src_pos\n ~dst\n ~dst_pos:!next_dst_pos\n ~len:(len_s - !next_src_pos);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:dst\n ;;\n\n module Private = struct\n type public = t\n\n type nonrec t = t =\n { pattern : string\n ; case_sensitive : bool\n ; kmp_array : int array\n }\n [@@deriving_inline equal, sexp_of]\n\n let equal =\n (fun a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then true\n else\n Ppx_compare_lib.( && )\n (equal_string a__001_.pattern b__002_.pattern)\n (Ppx_compare_lib.( && )\n (equal_bool a__001_.case_sensitive b__002_.case_sensitive)\n (equal_array equal_int a__001_.kmp_array b__002_.kmp_array))\n : t -> t -> bool)\n ;;\n\n let sexp_of_t =\n (function\n | { pattern = v_pattern\n ; case_sensitive = v_case_sensitive\n ; kmp_array = v_kmp_array\n } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_array sexp_of_int v_kmp_array in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"kmp_array\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_bool v_case_sensitive in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"case_sensitive\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_string v_pattern in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"pattern\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\n\n let representation = Fn.id\n end\nend\n\nmodule Search_pattern_helper = struct\n module Search_pattern = Search_pattern0\nend\n\nopen Search_pattern_helper\n\nlet substr_index_gen ~case_sensitive ?pos t ~pattern =\n Search_pattern.index ?pos (Search_pattern.create ~case_sensitive pattern) ~in_:t\n;;\n\nlet substr_index_exn_gen ~case_sensitive ?pos t ~pattern =\n Search_pattern.index_exn ?pos (Search_pattern.create ~case_sensitive pattern) ~in_:t\n;;\n\nlet substr_index_all_gen ~case_sensitive t ~may_overlap ~pattern =\n Search_pattern.index_all\n (Search_pattern.create ~case_sensitive pattern)\n ~may_overlap\n ~in_:t\n;;\n\nlet substr_replace_first_gen ~case_sensitive ?pos t ~pattern =\n Search_pattern.replace_first\n ?pos\n (Search_pattern.create ~case_sensitive pattern)\n ~in_:t\n;;\n\nlet substr_replace_all_gen ~case_sensitive t ~pattern =\n Search_pattern.replace_all (Search_pattern.create ~case_sensitive pattern) ~in_:t\n;;\n\nlet is_substring_gen ~case_sensitive t ~substring =\n Option.is_some (substr_index_gen t ~pattern:substring ~case_sensitive)\n;;\n\nlet substr_index = substr_index_gen ~case_sensitive:true\nlet substr_index_exn = substr_index_exn_gen ~case_sensitive:true\nlet substr_index_all = substr_index_all_gen ~case_sensitive:true\nlet substr_replace_first = substr_replace_first_gen ~case_sensitive:true\nlet substr_replace_all = substr_replace_all_gen ~case_sensitive:true\nlet is_substring = is_substring_gen ~case_sensitive:true\n\nlet is_substring_at_gen =\n let rec loop ~str ~str_pos ~sub ~sub_pos ~sub_len ~char_equal =\n if sub_pos = sub_len\n then true\n else if char_equal (unsafe_get str str_pos) (unsafe_get sub sub_pos)\n then\n loop ~str ~str_pos:(str_pos + 1) ~sub ~sub_pos:(sub_pos + 1) ~sub_len ~char_equal\n else false\n in\n fun str ~pos:str_pos ~substring:sub ~char_equal ->\n let str_len = length str in\n let sub_len = length sub in\n if str_pos < 0 || str_pos > str_len\n then\n invalid_argf\n \"String.is_substring_at: invalid index %d for string of length %d\"\n str_pos\n str_len\n ();\n str_pos + sub_len <= str_len\n && loop ~str ~str_pos ~sub ~sub_pos:0 ~sub_len ~char_equal\n;;\n\nlet is_suffix_gen string ~suffix ~char_equal =\n let string_len = length string in\n let suffix_len = length suffix in\n string_len >= suffix_len\n && is_substring_at_gen\n string\n ~pos:(string_len - suffix_len)\n ~substring:suffix\n ~char_equal\n;;\n\nlet is_prefix_gen string ~prefix ~char_equal =\n let string_len = length string in\n let prefix_len = length prefix in\n string_len >= prefix_len\n && is_substring_at_gen string ~pos:0 ~substring:prefix ~char_equal\n;;\n\nmodule Caseless = struct\n module T = struct\n type t = string [@@deriving_inline sexp]\n\n let t_of_sexp = (string_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_string : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n\n let char_compare_caseless c1 c2 =\n Char.compare (Char.lowercase c1) (Char.lowercase c2)\n ;;\n\n let rec compare_loop ~pos ~string1 ~len1 ~string2 ~len2 =\n if pos = len1\n then if pos = len2 then 0 else -1\n else if pos = len2\n then 1\n else (\n let c =\n char_compare_caseless (unsafe_get string1 pos) (unsafe_get string2 pos)\n in\n match c with\n | 0 -> compare_loop ~pos:(pos + 1) ~string1 ~len1 ~string2 ~len2\n | _ -> c)\n ;;\n\n let compare string1 string2 =\n if phys_equal string1 string2\n then 0\n else\n compare_loop\n ~pos:0\n ~string1\n ~len1:(String.length string1)\n ~string2\n ~len2:(String.length string2)\n ;;\n\n let hash_fold_t state t =\n let len = length t in\n let state = ref (hash_fold_int state len) in\n for pos = 0 to len - 1 do\n state := hash_fold_char !state (Char.lowercase (unsafe_get t pos))\n done;\n !state\n ;;\n\n let hash t = Hash.run hash_fold_t t\n let is_suffix s ~suffix = is_suffix_gen s ~suffix ~char_equal:Char.Caseless.equal\n let is_prefix s ~prefix = is_prefix_gen s ~prefix ~char_equal:Char.Caseless.equal\n let substr_index = substr_index_gen ~case_sensitive:false\n let substr_index_exn = substr_index_exn_gen ~case_sensitive:false\n let substr_index_all = substr_index_all_gen ~case_sensitive:false\n let substr_replace_first = substr_replace_first_gen ~case_sensitive:false\n let substr_replace_all = substr_replace_all_gen ~case_sensitive:false\n let is_substring = is_substring_gen ~case_sensitive:false\n let is_substring_at = is_substring_at_gen ~char_equal:Char.Caseless.equal\n end\n\n include T\n include Comparable.Make (T)\nend\n\nlet of_string = Fn.id\nlet to_string = Fn.id\n\nlet init n ~f =\n if n < 0 then invalid_argf \"String.init %d\" n ();\n let t = Bytes.create n in\n for i = 0 to n - 1 do\n Bytes.set t i (f i)\n done;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:t\n;;\n\nlet to_list s =\n let rec loop acc i = if i < 0 then acc else loop (s.[i] :: acc) (i - 1) in\n loop [] (length s - 1)\n;;\n\nlet to_list_rev s =\n let len = length s in\n let rec loop acc i = if i = len then acc else loop (s.[i] :: acc) (i + 1) in\n loop [] 0\n;;\n\nlet rev t =\n let len = length t in\n let res = Bytes.create len in\n for i = 0 to len - 1 do\n unsafe_set res i (unsafe_get t (len - 1 - i))\n done;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:res\n;;\n\n(** Efficient string splitting *)\n\nlet lsplit2_exn =\n let not_found = Not_found_s (Atom \"String.lsplit2_exn: not found\") in\n let lsplit2_exn line ~on:delim =\n let pos = index_exn_internal line ~not_found delim in\n sub line ~pos:0 ~len:pos, sub line ~pos:(pos + 1) ~len:(length line - pos - 1)\n in\n (* named to preserve symbol in compiled binary *)\n lsplit2_exn\n;;\n\nlet rsplit2_exn =\n let not_found = Not_found_s (Atom \"String.rsplit2_exn: not found\") in\n let rsplit2_exn line ~on:delim =\n let pos = rindex_exn_internal line ~not_found delim in\n sub line ~pos:0 ~len:pos, sub line ~pos:(pos + 1) ~len:(length line - pos - 1)\n in\n (* named to preserve symbol in compiled binary *)\n rsplit2_exn\n;;\n\nlet lsplit2 line ~on =\n try Some (lsplit2_exn line ~on) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nlet rsplit2 line ~on =\n try Some (rsplit2_exn line ~on) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nlet rec char_list_mem l (c : char) =\n match l with\n | [] -> false\n | hd :: tl -> Char.equal hd c || char_list_mem tl c\n;;\n\nlet split_gen str ~on =\n let is_delim =\n match on with\n | `char c' -> fun c -> Char.equal c c'\n | `char_list l -> fun c -> char_list_mem l c\n in\n let len = length str in\n let rec loop acc last_pos pos =\n if pos = -1\n then sub str ~pos:0 ~len:last_pos :: acc\n else if is_delim str.[pos]\n then (\n let pos1 = pos + 1 in\n let sub_str = sub str ~pos:pos1 ~len:(last_pos - pos1) in\n loop (sub_str :: acc) pos (pos - 1))\n else loop acc last_pos (pos - 1)\n in\n loop [] len (len - 1)\n;;\n\nlet split str ~on = split_gen str ~on:(`char on)\nlet split_on_chars str ~on:chars = split_gen str ~on:(`char_list chars)\n\nlet split_lines =\n let back_up_at_newline ~t ~pos ~eol =\n pos := !pos - if !pos > 0 && Char.equal t.[!pos - 1] '\\r' then 2 else 1;\n eol := !pos + 1\n in\n fun t ->\n let n = length t in\n if n = 0\n then []\n else (\n (* Invariant: [-1 <= pos < eol]. *)\n let pos = ref (n - 1) in\n let eol = ref n in\n let ac = ref [] in\n (* We treat the end of the string specially, because if the string ends with a\n newline, we don't want an extra empty string at the end of the output. *)\n if Char.equal t.[!pos] '\\n' then back_up_at_newline ~t ~pos ~eol;\n while !pos >= 0 do\n if Char.( <> ) t.[!pos] '\\n'\n then decr pos\n else (\n (* Because [pos < eol], we know that [start <= eol]. *)\n let start = !pos + 1 in\n ac := sub t ~pos:start ~len:(!eol - start) :: !ac;\n back_up_at_newline ~t ~pos ~eol)\n done;\n sub t ~pos:0 ~len:!eol :: !ac)\n;;\n\nlet is_suffix s ~suffix = is_suffix_gen s ~suffix ~char_equal:Char.equal\nlet is_prefix s ~prefix = is_prefix_gen s ~prefix ~char_equal:Char.equal\n\nlet is_substring_at s ~pos ~substring =\n is_substring_at_gen s ~pos ~substring ~char_equal:Char.equal\n;;\n\nlet wrap_sub_n t n ~name ~pos ~len ~on_error =\n if n < 0\n then invalid_arg (name ^ \" expecting nonnegative argument\")\n else (\n try sub t ~pos ~len with\n | _ -> on_error)\n;;\n\nlet drop_prefix t n =\n wrap_sub_n ~name:\"drop_prefix\" t n ~pos:n ~len:(length t - n) ~on_error:\"\"\n;;\n\nlet drop_suffix t n =\n wrap_sub_n ~name:\"drop_suffix\" t n ~pos:0 ~len:(length t - n) ~on_error:\"\"\n;;\n\nlet prefix t n = wrap_sub_n ~name:\"prefix\" t n ~pos:0 ~len:n ~on_error:t\nlet suffix t n = wrap_sub_n ~name:\"suffix\" t n ~pos:(length t - n) ~len:n ~on_error:t\n\nlet lfindi ?(pos = 0) t ~f =\n let n = length t in\n let rec loop i = if i = n then None else if f i t.[i] then Some i else loop (i + 1) in\n loop pos\n;;\n\nlet find t ~f =\n match lfindi t ~f:(fun _ c -> f c) with\n | None -> None\n | Some i -> Some t.[i]\n;;\n\nlet find_map t ~f =\n let n = length t in\n let rec loop i =\n if i = n\n then None\n else (\n match f t.[i] with\n | None -> loop (i + 1)\n | Some _ as res -> res)\n in\n loop 0\n;;\n\nlet rfindi ?pos t ~f =\n let rec loop i = if i < 0 then None else if f i t.[i] then Some i else loop (i - 1) in\n let pos =\n match pos with\n | Some pos -> pos\n | None -> length t - 1\n in\n loop pos\n;;\n\nlet last_non_drop ~drop t = rfindi t ~f:(fun _ c -> not (drop c))\n\nlet rstrip ?(drop = Char.is_whitespace) t =\n match last_non_drop t ~drop with\n | None -> \"\"\n | Some i -> if i = length t - 1 then t else prefix t (i + 1)\n;;\n\nlet first_non_drop ~drop t = lfindi t ~f:(fun _ c -> not (drop c))\n\nlet lstrip ?(drop = Char.is_whitespace) t =\n match first_non_drop t ~drop with\n | None -> \"\"\n | Some 0 -> t\n | Some n -> drop_prefix t n\n;;\n\n(* [strip t] could be implemented as [lstrip (rstrip t)]. The implementation\n below saves (at least) a factor of two allocation, by only allocating the\n final result. This also saves some amount of time. *)\nlet strip ?(drop = Char.is_whitespace) t =\n let length = length t in\n if length = 0 || not (drop t.[0] || drop t.[length - 1])\n then t\n else (\n match first_non_drop t ~drop with\n | None -> \"\"\n | Some first ->\n (match last_non_drop t ~drop with\n | None -> assert false\n | Some last -> sub t ~pos:first ~len:(last - first + 1)))\n;;\n\nlet mapi t ~f =\n let l = length t in\n let t' = Bytes.create l in\n for i = 0 to l - 1 do\n Bytes.unsafe_set t' i (f i t.[i])\n done;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:t'\n;;\n\n(* repeated code to avoid requiring an extra allocation for a closure on each call. *)\nlet map t ~f =\n let l = length t in\n let t' = Bytes.create l in\n for i = 0 to l - 1 do\n Bytes.unsafe_set t' i (f t.[i])\n done;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:t'\n;;\n\nlet to_array s = Array.init (length s) ~f:(fun i -> s.[i])\n\nlet exists =\n let rec loop s i ~len ~f = i < len && (f s.[i] || loop s (i + 1) ~len ~f) in\n fun s ~f -> loop s 0 ~len:(length s) ~f\n;;\n\nlet for_all =\n let rec loop s i ~len ~f = i = len || (f s.[i] && loop s (i + 1) ~len ~f) in\n fun s ~f -> loop s 0 ~len:(length s) ~f\n;;\n\nlet fold t ~init ~f =\n let n = length t in\n let rec loop i ac = if i = n then ac else loop (i + 1) (f ac t.[i]) in\n loop 0 init\n;;\n\nlet foldi t ~init ~f =\n let n = length t in\n let rec loop i ac = if i = n then ac else loop (i + 1) (f i ac t.[i]) in\n loop 0 init\n;;\n\nlet count t ~f = Container.count ~fold t ~f\nlet sum m t ~f = Container.sum ~fold m t ~f\nlet min_elt t = Container.min_elt ~fold t\nlet max_elt t = Container.max_elt ~fold t\nlet fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\nlet fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\n\nlet mem =\n let rec loop t c ~pos:i ~len =\n i < len && (Char.equal c (unsafe_get t i) || loop t c ~pos:(i + 1) ~len)\n in\n fun t c -> loop t c ~pos:0 ~len:(length t)\n;;\n\nlet tr ~target ~replacement s =\n if Char.equal target replacement\n then s\n else if mem s target\n then map s ~f:(fun c -> if Char.equal c target then replacement else c)\n else s\n;;\n\nlet tr_multi ~target ~replacement =\n if is_empty target\n then stage Fn.id\n else if is_empty replacement\n then invalid_arg \"tr_multi replacement is empty string\"\n else (\n match Bytes_tr.tr_create_map ~target ~replacement with\n | None -> stage Fn.id\n | Some tr_map ->\n stage (fun s ->\n if exists s ~f:(fun c -> Char.( <> ) c (unsafe_get tr_map (Char.to_int c)))\n then map s ~f:(fun c -> unsafe_get tr_map (Char.to_int c))\n else s))\n;;\n\n(* fast version, if we ever need it:\n {[\n let concat_array ~sep ar =\n let ar_len = Array.length ar in\n if ar_len = 0 then \"\"\n else\n let sep_len = length sep in\n let res_len_ref = ref (sep_len * (ar_len - 1)) in\n for i = 0 to ar_len - 1 do\n res_len_ref := !res_len_ref + length ar.(i)\n done;\n let res = create !res_len_ref in\n let str_0 = ar.(0) in\n let len_0 = length str_0 in\n blit ~src:str_0 ~src_pos:0 ~dst:res ~dst_pos:0 ~len:len_0;\n let pos_ref = ref len_0 in\n for i = 1 to ar_len - 1 do\n let pos = !pos_ref in\n blit ~src:sep ~src_pos:0 ~dst:res ~dst_pos:pos ~len:sep_len;\n let new_pos = pos + sep_len in\n let str_i = ar.(i) in\n let len_i = length str_i in\n blit ~src:str_i ~src_pos:0 ~dst:res ~dst_pos:new_pos ~len:len_i;\n pos_ref := new_pos + len_i\n done;\n res\n ]} *)\n\nlet concat_array ?sep ar = concat ?sep (Array.to_list ar)\nlet concat_map ?sep s ~f = concat_array ?sep (Array.map (to_array s) ~f)\n\n(* [filter t f] is implemented by the following algorithm.\n\n Let [n = length t].\n\n 1. Find the lowest [i] such that [not (f t.[i])].\n\n 2. If there is no such [i], then return [t].\n\n 3. If there is such an [i], allocate a string, [out], to hold the result. [out] has\n length [n - 1], which is the maximum possible output size given that there is at least\n one character not satisfying [f].\n\n 4. Copy characters at indices 0 ... [i - 1] from [t] to [out].\n\n 5. Walk through characters at indices [i+1] ... [n-1] of [t], copying those that\n satisfy [f] from [t] to [out].\n\n 6. If we completely filled [out], then return it. If not, return the prefix of [out]\n that we did fill in.\n\n This algorithm has the property that it doesn't allocate a new string if there's\n nothing to filter, which is a common case. *)\nlet filter t ~f =\n let n = length t in\n let i = ref 0 in\n while !i < n && f t.[!i] do\n incr i\n done;\n if !i = n\n then t\n else (\n let out = Bytes.create (n - 1) in\n Bytes.blit_string ~src:t ~src_pos:0 ~dst:out ~dst_pos:0 ~len:!i;\n let out_pos = ref !i in\n incr i;\n while !i < n do\n let c = t.[!i] in\n if f c\n then (\n Bytes.set out !out_pos c;\n incr out_pos);\n incr i\n done;\n let out = Bytes.unsafe_to_string ~no_mutation_while_string_reachable:out in\n if !out_pos = n - 1 then out else sub out ~pos:0 ~len:!out_pos)\n;;\n\nlet chop_prefix s ~prefix =\n if is_prefix s ~prefix then Some (drop_prefix s (length prefix)) else None\n;;\n\nlet chop_prefix_if_exists s ~prefix =\n if is_prefix s ~prefix then drop_prefix s (length prefix) else s\n;;\n\nlet chop_prefix_exn s ~prefix =\n match chop_prefix s ~prefix with\n | Some str -> str\n | None -> invalid_argf \"String.chop_prefix_exn %S %S\" s prefix ()\n;;\n\nlet chop_suffix s ~suffix =\n if is_suffix s ~suffix then Some (drop_suffix s (length suffix)) else None\n;;\n\nlet chop_suffix_if_exists s ~suffix =\n if is_suffix s ~suffix then drop_suffix s (length suffix) else s\n;;\n\nlet chop_suffix_exn s ~suffix =\n match chop_suffix s ~suffix with\n | Some str -> str\n | None -> invalid_argf \"String.chop_suffix_exn %S %S\" s suffix ()\n;;\n\n(* There used to be a custom implementation that was faster for very short strings\n (peaking at 40% faster for 4-6 char long strings).\n This new function is around 20% faster than the default hash function, but slower\n than the previous custom implementation. However, the new OCaml function is well\n behaved, and this implementation is less likely to diverge from the default OCaml\n implementation does, which is a desirable property. (The only way to avoid the\n divergence is to expose the macro redefined in hash_stubs.c in the hash.h header of\n the OCaml compiler.) *)\nmodule Hash = struct\n external hash : string -> int = \"Base_hash_string\" [@@noalloc]\nend\n\n(* [include Hash] to make the [external] version override the [hash] from\n [Hashable.Make_binable], so that we get a little bit of a speedup by exposing it as\n external in the mli. *)\nlet _ = hash\n\ninclude Hash\ninclude Comparable.Validate (T)\n\n(* for interactive top-levels -- modules deriving from String should have String's pretty\n printer. *)\nlet pp = Caml.Format.pp_print_string\nlet of_char c = make 1 c\n\nlet of_char_list l =\n let t = Bytes.create (List.length l) in\n List.iteri l ~f:(fun i c -> Bytes.set t i c);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:t\n;;\n\nmodule Escaping = struct\n (* If this is changed, make sure to update [escape], which attempts to ensure all the\n invariants checked here. *)\n let build_and_validate_escapeworthy_map escapeworthy_map escape_char func =\n let escapeworthy_map =\n if List.Assoc.mem escapeworthy_map ~equal:Char.equal escape_char\n then escapeworthy_map\n else (escape_char, escape_char) :: escapeworthy_map\n in\n let arr = Array.create ~len:256 (-1) in\n let vals = Array.create ~len:256 false in\n let rec loop = function\n | [] -> Ok arr\n | (c_from, c_to) :: l ->\n let k, v =\n match func with\n | `Escape -> Char.to_int c_from, c_to\n | `Unescape -> Char.to_int c_to, c_from\n in\n if arr.(k) <> -1 || vals.(Char.to_int v)\n then\n Or_error.error_s\n (Sexp.message\n \"escapeworthy_map not one-to-one\"\n [ \"c_from\", sexp_of_char c_from\n ; \"c_to\", sexp_of_char c_to\n ; ( \"escapeworthy_map\"\n , sexp_of_list (sexp_of_pair sexp_of_char sexp_of_char) escapeworthy_map\n )\n ])\n else (\n arr.(k) <- Char.to_int v;\n vals.(Char.to_int v) <- true;\n loop l)\n in\n loop escapeworthy_map\n ;;\n\n let escape_gen ~escapeworthy_map ~escape_char =\n match build_and_validate_escapeworthy_map escapeworthy_map escape_char `Escape with\n | Error _ as x -> x\n | Ok escapeworthy ->\n Ok\n (fun src ->\n (* calculate a list of (index of char to escape * escaped char) first, the order\n is from tail to head *)\n let to_escape_len = ref 0 in\n let to_escape =\n foldi src ~init:[] ~f:(fun i acc c ->\n match escapeworthy.(Char.to_int c) with\n | -1 -> acc\n | n ->\n (* (index of char to escape * escaped char) *)\n incr to_escape_len;\n (i, Char.unsafe_of_int n) :: acc)\n in\n match to_escape with\n | [] -> src\n | _ ->\n (* [to_escape] divide [src] to [List.length to_escape + 1] pieces separated by\n the chars to escape.\n\n Lets take\n {[\n escape_gen_exn\n ~escapeworthy_map:[('a', 'A'); ('b', 'B'); ('c', 'C')]\n ~escape_char:'_'\n ]}\n for example, and assume the string to escape is\n\n \"000a111b222c333\"\n\n then [to_escape] is [(11, 'C'); (7, 'B'); (3, 'A')].\n\n Then we create a [dst] of length [length src + 3] to store the\n result, copy piece \"333\" to [dst] directly, then copy '_' and 'C' to [dst];\n then move on to next; after 3 iterations, copy piece \"000\" and we are done.\n\n Finally the result will be\n\n \"000_A111_B222_C333\" *)\n let src_len = length src in\n let dst_len = src_len + !to_escape_len in\n let dst = Bytes.create dst_len in\n let rec loop last_idx last_dst_pos = function\n | [] ->\n (* copy \"000\" at last *)\n Bytes.blit_string ~src ~src_pos:0 ~dst ~dst_pos:0 ~len:last_idx\n | (idx, escaped_char) :: to_escape ->\n (*[idx] = the char to escape*)\n (* take first iteration for example *)\n (* calculate length of \"333\", minus 1 because we don't copy 'c' *)\n let len = last_idx - idx - 1 in\n (* set the dst_pos to copy to *)\n let dst_pos = last_dst_pos - len in\n (* copy \"333\", set [src_pos] to [idx + 1] to skip 'c' *)\n Bytes.blit_string ~src ~src_pos:(idx + 1) ~dst ~dst_pos ~len;\n (* backoff [dst_pos] by 2 to copy '_' and 'C' *)\n let dst_pos = dst_pos - 2 in\n Bytes.set dst dst_pos escape_char;\n Bytes.set dst (dst_pos + 1) escaped_char;\n loop idx dst_pos to_escape\n in\n (* set [last_dst_pos] and [last_idx] to length of [dst] and [src] first *)\n loop src_len dst_len to_escape;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:dst)\n ;;\n\n let escape_gen_exn ~escapeworthy_map ~escape_char =\n Or_error.ok_exn (escape_gen ~escapeworthy_map ~escape_char) |> stage\n ;;\n\n let escape ~escapeworthy ~escape_char =\n (* For [escape_gen_exn], we don't know how to fix invalid escapeworthy_map so we have\n to raise exception; but in this case, we know how to fix duplicated elements in\n escapeworthy list, so we just fix it instead of raising exception to make this\n function easier to use. *)\n let escapeworthy_map =\n escapeworthy\n |> List.dedup_and_sort ~compare:Char.compare\n |> List.map ~f:(fun c -> c, c)\n in\n escape_gen_exn ~escapeworthy_map ~escape_char\n ;;\n\n (* In an escaped string, any char is either `Escaping, `Escaped or `Literal. For\n example, the escape statuses of chars in string \"a_a__\" with escape_char = '_' are\n\n a : `Literal\n _ : `Escaping\n a : `Escaped\n _ : `Escaping\n _ : `Escaped\n\n [update_escape_status str ~escape_char i previous_status] gets escape status of\n str.[i] basing on escape status of str.[i - 1] *)\n let update_escape_status str ~escape_char i = function\n | `Escaping -> `Escaped\n | `Literal | `Escaped ->\n if Char.equal str.[i] escape_char then `Escaping else `Literal\n ;;\n\n let unescape_gen ~escapeworthy_map ~escape_char =\n match build_and_validate_escapeworthy_map escapeworthy_map escape_char `Unescape with\n | Error _ as x -> x\n | Ok escapeworthy ->\n Ok\n (fun src ->\n (* Continue the example in [escape_gen_exn], now we unescape\n\n \"000_A111_B222_C333\"\n\n back to\n\n \"000a111b222c333\"\n\n Then [to_unescape] is [14; 9; 4], which is indexes of '_'s.\n\n Then we create a string [dst] to store the result, copy \"333\" to it, then copy\n 'c', then move on to next iteration. After 3 iterations copy \"000\" and we are\n done. *)\n (* indexes of escape chars *)\n let to_unescape =\n let rec loop i status acc =\n if i >= length src\n then acc\n else (\n let status = update_escape_status src ~escape_char i status in\n loop\n (i + 1)\n status\n (match status with\n | `Escaping -> i :: acc\n | `Escaped | `Literal -> acc))\n in\n loop 0 `Literal []\n in\n match to_unescape with\n | [] -> src\n | idx :: to_unescape' ->\n let dst = Bytes.create (length src - List.length to_unescape) in\n let rec loop last_idx last_dst_pos = function\n | [] ->\n (* copy \"000\" at last *)\n Bytes.blit_string ~src ~src_pos:0 ~dst ~dst_pos:0 ~len:last_idx\n | idx :: to_unescape ->\n (* [idx] = index of escaping char *)\n (* take 1st iteration as example, calculate the length of \"333\", minus 2 to\n skip '_C' *)\n let len = last_idx - idx - 2 in\n (* point [dst_pos] to the position to copy \"333\" to *)\n let dst_pos = last_dst_pos - len in\n (* copy \"333\" *)\n Bytes.blit_string ~src ~src_pos:(idx + 2) ~dst ~dst_pos ~len;\n (* backoff [dst_pos] by 1 to copy 'c' *)\n let dst_pos = dst_pos - 1 in\n Bytes.set\n dst\n dst_pos\n (match escapeworthy.(Char.to_int src.[idx + 1]) with\n | -1 -> src.[idx + 1]\n | n -> Char.unsafe_of_int n);\n (* update [last_dst_pos] and [last_idx] *)\n loop idx dst_pos to_unescape\n in\n if idx < length src - 1\n then\n (* set [last_dst_pos] and [last_idx] to length of [dst] and [src] *)\n loop (length src) (Bytes.length dst) to_unescape\n else\n (* for escaped string ending with an escaping char like \"000_\", just ignore\n the last escaping char *)\n loop (length src - 1) (Bytes.length dst) to_unescape';\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:dst)\n ;;\n\n let unescape_gen_exn ~escapeworthy_map ~escape_char =\n Or_error.ok_exn (unescape_gen ~escapeworthy_map ~escape_char) |> stage\n ;;\n\n let unescape ~escape_char = unescape_gen_exn ~escapeworthy_map:[] ~escape_char\n\n let preceding_escape_chars str ~escape_char pos =\n let rec loop p cnt =\n if p < 0 || Char.( <> ) str.[p] escape_char then cnt else loop (p - 1) (cnt + 1)\n in\n loop (pos - 1) 0\n ;;\n\n (* In an escaped string, any char is either `Escaping, `Escaped or `Literal. For\n example, the escape statuses of chars in string \"a_a__\" with escape_char = '_' are\n\n a : `Literal\n _ : `Escaping\n a : `Escaped\n _ : `Escaping\n _ : `Escaped\n\n [update_escape_status str ~escape_char i previous_status] gets escape status of\n str.[i] basing on escape status of str.[i - 1] *)\n let update_escape_status str ~escape_char i = function\n | `Escaping -> `Escaped\n | `Literal | `Escaped ->\n if Char.equal str.[i] escape_char then `Escaping else `Literal\n ;;\n\n let escape_status str ~escape_char pos =\n let odd = preceding_escape_chars str ~escape_char pos mod 2 = 1 in\n match odd, Char.equal str.[pos] escape_char with\n | true, (true | false) -> `Escaped\n | false, true -> `Escaping\n | false, false -> `Literal\n ;;\n\n let check_bound str pos function_name =\n if pos >= length str || pos < 0\n then invalid_argf \"%s: out of bounds\" function_name ()\n ;;\n\n let is_char_escaping str ~escape_char pos =\n check_bound str pos \"is_char_escaping\";\n match escape_status str ~escape_char pos with\n | `Escaping -> true\n | `Escaped | `Literal -> false\n ;;\n\n let is_char_escaped str ~escape_char pos =\n check_bound str pos \"is_char_escaped\";\n match escape_status str ~escape_char pos with\n | `Escaped -> true\n | `Escaping | `Literal -> false\n ;;\n\n let is_char_literal str ~escape_char pos =\n check_bound str pos \"is_char_literal\";\n match escape_status str ~escape_char pos with\n | `Literal -> true\n | `Escaped | `Escaping -> false\n ;;\n\n let index_from str ~escape_char pos char =\n check_bound str pos \"index_from\";\n let rec loop i status =\n if i >= pos\n && (match status with\n | `Literal -> true\n | `Escaped | `Escaping -> false)\n && Char.equal str.[i] char\n then Some i\n else (\n let i = i + 1 in\n if i >= length str\n then None\n else loop i (update_escape_status str ~escape_char i status))\n in\n loop pos (escape_status str ~escape_char pos)\n ;;\n\n let index_from_exn str ~escape_char pos char =\n match index_from str ~escape_char pos char with\n | None ->\n raise_s\n (Sexp.message\n \"index_from_exn: not found\"\n [ \"str\", sexp_of_t str\n ; \"escape_char\", sexp_of_char escape_char\n ; \"pos\", sexp_of_int pos\n ; \"char\", sexp_of_char char\n ])\n | Some pos -> pos\n ;;\n\n let index str ~escape_char char = index_from str ~escape_char 0 char\n let index_exn str ~escape_char char = index_from_exn str ~escape_char 0 char\n\n let rindex_from str ~escape_char pos char =\n check_bound str pos \"rindex_from\";\n (* if the target char is the same as [escape_char], we have no way to determine which\n escape_char is literal, so just return None *)\n if Char.equal char escape_char\n then None\n else (\n let rec loop pos =\n if pos < 0\n then None\n else (\n let escape_chars = preceding_escape_chars str ~escape_char pos in\n if escape_chars mod 2 = 0 && Char.equal str.[pos] char\n then Some pos\n else loop (pos - escape_chars - 1))\n in\n loop pos)\n ;;\n\n let rindex_from_exn str ~escape_char pos char =\n match rindex_from str ~escape_char pos char with\n | None ->\n raise_s\n (Sexp.message\n \"rindex_from_exn: not found\"\n [ \"str\", sexp_of_t str\n ; \"escape_char\", sexp_of_char escape_char\n ; \"pos\", sexp_of_int pos\n ; \"char\", sexp_of_char char\n ])\n | Some pos -> pos\n ;;\n\n let rindex str ~escape_char char =\n if is_empty str then None else rindex_from str ~escape_char (length str - 1) char\n ;;\n\n let rindex_exn str ~escape_char char =\n rindex_from_exn str ~escape_char (length str - 1) char\n ;;\n\n (* [split_gen str ~escape_char ~on] works similarly to [String.split_gen], with an\n additional requirement: only split on literal chars, not escaping or escaped *)\n let split_gen str ~escape_char ~on =\n let is_delim =\n match on with\n | `char c' -> fun c -> Char.equal c c'\n | `char_list l -> fun c -> char_list_mem l c\n in\n let len = length str in\n let rec loop acc status last_pos pos =\n if pos = len\n then List.rev (sub str ~pos:last_pos ~len:(len - last_pos) :: acc)\n else (\n let status = update_escape_status str ~escape_char pos status in\n if (match status with\n | `Literal -> true\n | `Escaped | `Escaping -> false)\n && is_delim str.[pos]\n then (\n let sub_str = sub str ~pos:last_pos ~len:(pos - last_pos) in\n loop (sub_str :: acc) status (pos + 1) (pos + 1))\n else loop acc status last_pos (pos + 1))\n in\n loop [] `Literal 0 0\n ;;\n\n let split str ~on = split_gen str ~on:(`char on)\n let split_on_chars str ~on:chars = split_gen str ~on:(`char_list chars)\n\n let split_at str pos =\n sub str ~pos:0 ~len:pos, sub str ~pos:(pos + 1) ~len:(length str - pos - 1)\n ;;\n\n let lsplit2 str ~on ~escape_char =\n Option.map (index str ~escape_char on) ~f:(fun x -> split_at str x)\n ;;\n\n let rsplit2 str ~on ~escape_char =\n Option.map (rindex str ~escape_char on) ~f:(fun x -> split_at str x)\n ;;\n\n let lsplit2_exn str ~on ~escape_char = split_at str (index_exn str ~escape_char on)\n let rsplit2_exn str ~on ~escape_char = split_at str (rindex_exn str ~escape_char on)\n\n (* [last_non_drop_literal] and [first_non_drop_literal] are either both [None] or both\n [Some]. If [Some], then the former is >= the latter. *)\n let last_non_drop_literal ~drop ~escape_char t =\n rfindi t ~f:(fun i c ->\n (not (drop c))\n || is_char_escaping t ~escape_char i\n || is_char_escaped t ~escape_char i)\n ;;\n\n let first_non_drop_literal ~drop ~escape_char t =\n lfindi t ~f:(fun i c ->\n (not (drop c))\n || is_char_escaping t ~escape_char i\n || is_char_escaped t ~escape_char i)\n ;;\n\n let rstrip_literal ?(drop = Char.is_whitespace) t ~escape_char =\n match last_non_drop_literal t ~drop ~escape_char with\n | None -> \"\"\n | Some i -> if i = length t - 1 then t else prefix t (i + 1)\n ;;\n\n let lstrip_literal ?(drop = Char.is_whitespace) t ~escape_char =\n match first_non_drop_literal t ~drop ~escape_char with\n | None -> \"\"\n | Some 0 -> t\n | Some n -> drop_prefix t n\n ;;\n\n (* [strip t] could be implemented as [lstrip (rstrip t)]. The implementation\n below saves (at least) a factor of two allocation, by only allocating the\n final result. This also saves some amount of time. *)\n let strip_literal ?(drop = Char.is_whitespace) t ~escape_char =\n let length = length t in\n (* performance hack: avoid copying [t] in common cases *)\n if length = 0 || not (drop t.[0] || drop t.[length - 1])\n then t\n else (\n match first_non_drop_literal t ~drop ~escape_char with\n | None -> \"\"\n | Some first ->\n (match last_non_drop_literal t ~drop ~escape_char with\n | None -> assert false\n | Some last -> sub t ~pos:first ~len:(last - first + 1)))\n ;;\nend\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! String_replace_polymorphic_compare\n\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\n(* Override [Search_pattern] with default case-sensitivity argument at the end of the\n file, so that call sites above are forced to supply case-sensitivity explicitly. *)\nmodule Search_pattern = struct\n include Search_pattern0\n\n let create ?(case_sensitive = true) pattern = create pattern ~case_sensitive\nend\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude String_replace_polymorphic_compare\n","open! Import\nmodule Array = Array0\n\nlet stage = Staged.stage\n\nmodule T = struct\n type t = bytes [@@deriving_inline sexp, sexp_grammar]\n\n let t_of_sexp = (bytes_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_bytes : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"bytes\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ bytes_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"bytes.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n include Bytes0\n\n let module_name = \"Base.Bytes\"\n let pp fmt t = Caml.Format.fprintf fmt \"%S\" (to_string t)\nend\n\ninclude T\n\nmodule To_bytes = Blit.Make (struct\n include T\n\n let create ~len = create len\n end)\n\ninclude To_bytes\ninclude Comparator.Make (T)\ninclude Comparable.Validate (T)\ninclude Pretty_printer.Register_pp (T)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! Bytes_replace_polymorphic_compare\nmodule To_string = Blit.Make_to_string (T) (To_bytes)\n\nmodule From_string =\n Blit.Make_distinct\n (struct\n type t = string\n\n let length = String.length\n end)\n (struct\n type nonrec t = t\n\n let create ~len = create len\n let length = length\n let unsafe_blit = unsafe_blit_string\n end)\n\nlet invariant (_ : t) = ()\n\nlet init n ~f =\n if Int_replace_polymorphic_compare.( < ) n 0\n then Printf.invalid_argf \"Bytes.init %d\" n ();\n let t = create n in\n for i = 0 to n - 1 do\n unsafe_set t i (f i)\n done;\n t\n;;\n\nlet of_char_list l =\n let t = create (List.length l) in\n List.iteri l ~f:(fun i c -> set t i c);\n t\n;;\n\nlet to_list t =\n let rec loop t i acc =\n if Int_replace_polymorphic_compare.( < ) i 0\n then acc\n else loop t (i - 1) (unsafe_get t i :: acc)\n in\n loop t (length t - 1) []\n;;\n\nlet to_array t = Array.init (length t) ~f:(fun i -> unsafe_get t i)\nlet map t ~f = map t ~f\nlet mapi t ~f = mapi t ~f\n\nlet fold =\n let rec loop t ~f ~len ~pos acc =\n if Int_replace_polymorphic_compare.equal pos len\n then acc\n else loop t ~f ~len ~pos:(pos + 1) (f acc (unsafe_get t pos))\n in\n fun t ~init ~f -> loop t ~f ~len:(length t) ~pos:0 init\n;;\n\nlet foldi =\n let rec loop t ~f ~len ~pos acc =\n if Int_replace_polymorphic_compare.equal pos len\n then acc\n else loop t ~f ~len ~pos:(pos + 1) (f pos acc (unsafe_get t pos))\n in\n fun t ~init ~f -> loop t ~f ~len:(length t) ~pos:0 init\n;;\n\nlet tr ~target ~replacement s =\n for i = 0 to length s - 1 do\n if Char.equal (unsafe_get s i) target then unsafe_set s i replacement\n done\n;;\n\nlet tr_multi ~target ~replacement =\n if Int_replace_polymorphic_compare.( = ) (String.length target) 0\n then stage ignore\n else if Int_replace_polymorphic_compare.( = ) (String.length replacement) 0\n then invalid_arg \"tr_multi: replacement is the empty string\"\n else (\n match Bytes_tr.tr_create_map ~target ~replacement with\n | None -> stage ignore\n | Some tr_map ->\n stage (fun s ->\n for i = 0 to length s - 1 do\n unsafe_set s i (String.unsafe_get tr_map (Char.to_int (unsafe_get s i)))\n done))\n;;\n\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet contains ?pos ?len t char =\n let pos, len =\n Ordered_collection_common.get_pos_len_exn () ?pos ?len ~total_length:(length t)\n in\n let last = pos + len in\n let rec loop i =\n Int_replace_polymorphic_compare.( < ) i last\n && (Char.equal (get t i) char || loop (i + 1))\n in\n loop pos\n;;\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Bytes_replace_polymorphic_compare\n","(* This file was autogenerated by ../generate/generate_pow_overflow_bounds.exe *)\n\nopen! Import\n\nmodule Array = Array0\n\n(* We have to use Int64.to_int_exn instead of int constants to make\n sure that file can be preprocessed on 32-bit machines. *)\n\nlet overflow_bound_max_int32_value : int32 =\n 2147483647l\n\nlet int32_positive_overflow_bounds : int32 array =\n [| 2147483647l\n ; 2147483647l\n ; 46340l\n ; 1290l\n ; 215l\n ; 73l\n ; 35l\n ; 21l\n ; 14l\n ; 10l\n ; 8l\n ; 7l\n ; 5l\n ; 5l\n ; 4l\n ; 4l\n ; 3l\n ; 3l\n ; 3l\n ; 3l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n |]\n\nlet overflow_bound_max_int_value : int =\n (-1) lsr 1\n\nlet int_positive_overflow_bounds : int array =\n match Int_conversions.num_bits_int with\n | 32 -> Array.map int32_positive_overflow_bounds ~f:Caml.Int32.to_int\n | 63 ->\n [| Caml.Int64.to_int 4611686018427387903L\n ; Caml.Int64.to_int 4611686018427387903L\n ; Caml.Int64.to_int 2147483647L\n ; 1664510\n ; 46340\n ; 5404\n ; 1290\n ; 463\n ; 215\n ; 118\n ; 73\n ; 49\n ; 35\n ; 27\n ; 21\n ; 17\n ; 14\n ; 12\n ; 10\n ; 9\n ; 8\n ; 7\n ; 7\n ; 6\n ; 5\n ; 5\n ; 5\n ; 4\n ; 4\n ; 4\n ; 4\n ; 3\n ; 3\n ; 3\n ; 3\n ; 3\n ; 3\n ; 3\n ; 3\n ; 3\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 1\n ; 1\n |]\n | 31 ->\n [| 1073741823\n ; 1073741823\n ; 32767\n ; 1023\n ; 181\n ; 63\n ; 31\n ; 19\n ; 13\n ; 10\n ; 7\n ; 6\n ; 5\n ; 4\n ; 4\n ; 3\n ; 3\n ; 3\n ; 3\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n |]\n | _ -> assert false\n\nlet overflow_bound_max_int63_on_int64_value : int64 =\n 4611686018427387903L\n\nlet int63_on_int64_positive_overflow_bounds : int64 array =\n [| 4611686018427387903L\n ; 4611686018427387903L\n ; 2147483647L\n ; 1664510L\n ; 46340L\n ; 5404L\n ; 1290L\n ; 463L\n ; 215L\n ; 118L\n ; 73L\n ; 49L\n ; 35L\n ; 27L\n ; 21L\n ; 17L\n ; 14L\n ; 12L\n ; 10L\n ; 9L\n ; 8L\n ; 7L\n ; 7L\n ; 6L\n ; 5L\n ; 5L\n ; 5L\n ; 4L\n ; 4L\n ; 4L\n ; 4L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 1L\n ; 1L\n |]\n\nlet overflow_bound_max_int64_value : int64 =\n 9223372036854775807L\n\nlet int64_positive_overflow_bounds : int64 array =\n [| 9223372036854775807L\n ; 9223372036854775807L\n ; 3037000499L\n ; 2097151L\n ; 55108L\n ; 6208L\n ; 1448L\n ; 511L\n ; 234L\n ; 127L\n ; 78L\n ; 52L\n ; 38L\n ; 28L\n ; 22L\n ; 18L\n ; 15L\n ; 13L\n ; 11L\n ; 9L\n ; 8L\n ; 7L\n ; 7L\n ; 6L\n ; 6L\n ; 5L\n ; 5L\n ; 5L\n ; 4L\n ; 4L\n ; 4L\n ; 4L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 1L\n |]\n\nlet int64_negative_overflow_bounds : int64 array =\n [| -9223372036854775807L\n ; -9223372036854775807L\n ; -3037000499L\n ; -2097151L\n ; -55108L\n ; -6208L\n ; -1448L\n ; -511L\n ; -234L\n ; -127L\n ; -78L\n ; -52L\n ; -38L\n ; -28L\n ; -22L\n ; -18L\n ; -15L\n ; -13L\n ; -11L\n ; -9L\n ; -8L\n ; -7L\n ; -7L\n ; -6L\n ; -6L\n ; -5L\n ; -5L\n ; -5L\n ; -4L\n ; -4L\n ; -4L\n ; -4L\n ; -3L\n ; -3L\n ; -3L\n ; -3L\n ; -3L\n ; -3L\n ; -3L\n ; -3L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -1L\n |]\n","open! Import\n\nlet invalid_argf = Printf.invalid_argf\nlet negative_exponent () = Printf.invalid_argf \"exponent can not be negative\" ()\nlet overflow () = Printf.invalid_argf \"integer overflow in pow\" ()\n\n(* To implement [int64_pow], we use C code rather than OCaml to eliminate allocation. *)\nexternal int_math_int_pow : int -> int -> int = \"Base_int_math_int_pow_stub\" [@@noalloc]\nexternal int_math_int64_pow : int64 -> int64 -> int64 = \"Base_int_math_int64_pow_stub\"\n\nlet int_pow base exponent =\n if exponent < 0 then negative_exponent ();\n if abs base > 1\n && (exponent > 63\n || abs base > Pow_overflow_bounds.int_positive_overflow_bounds.(exponent))\n then overflow ();\n int_math_int_pow base exponent\n;;\n\nmodule Int64_with_comparisons = struct\n include Caml.Int64\n\n external ( < ) : int64 -> int64 -> bool = \"%lessthan\"\n external ( > ) : int64 -> int64 -> bool = \"%greaterthan\"\n external ( >= ) : int64 -> int64 -> bool = \"%greaterequal\"\nend\n\n(* we don't do [abs] in int64 case to avoid allocation *)\nlet int64_pow base exponent =\n let open Int64_with_comparisons in\n if exponent < 0L then negative_exponent ();\n if (base > 1L || base < -1L)\n && (exponent > 63L\n || (base >= 0L\n && base > Pow_overflow_bounds.int64_positive_overflow_bounds.(to_int exponent)\n )\n || (base < 0L\n && base < Pow_overflow_bounds.int64_negative_overflow_bounds.(to_int exponent)\n ))\n then overflow ();\n int_math_int64_pow base exponent\n;;\n\nlet int63_pow_on_int64 base exponent =\n let open Int64_with_comparisons in\n if exponent < 0L then negative_exponent ();\n if abs base > 1L\n && (exponent > 63L\n || abs base\n > Pow_overflow_bounds.int63_on_int64_positive_overflow_bounds.(to_int exponent)\n )\n then overflow ();\n int_math_int64_pow base exponent\n;;\n\nmodule type Make_arg = sig\n type t\n\n include Floatable.S with type t := t\n include Stringable.S with type t := t\n\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val ( * ) : t -> t -> t\n val ( / ) : t -> t -> t\n val ( ~- ) : t -> t\n\n include Comparisons.Infix with type t := t\n\n val abs : t -> t\n val neg : t -> t\n val zero : t\n val of_int_exn : int -> t\n val rem : t -> t -> t\nend\n\nmodule Make (X : Make_arg) = struct\n open X\n\n let ( % ) x y =\n if y <= zero\n then\n invalid_argf\n \"%s %% %s in core_int.ml: modulus should be positive\"\n (to_string x)\n (to_string y)\n ();\n let rval = X.rem x y in\n if rval < zero then rval + y else rval\n ;;\n\n let one = of_int_exn 1\n\n let ( /% ) x y =\n if y <= zero\n then\n invalid_argf\n \"%s /%% %s in core_int.ml: divisor should be positive\"\n (to_string x)\n (to_string y)\n ();\n if x < zero then ((x + one) / y) - one else x / y\n ;;\n\n (** float division of integers *)\n let ( // ) x y = to_float x /. to_float y\n\n let round_down i ~to_multiple_of:modulus = i - (i % modulus)\n\n let round_up i ~to_multiple_of:modulus =\n let remainder = i % modulus in\n if remainder = zero then i else i + modulus - remainder\n ;;\n\n let round_towards_zero i ~to_multiple_of =\n if i = zero\n then zero\n else if i > zero\n then round_down i ~to_multiple_of\n else round_up i ~to_multiple_of\n ;;\n\n let round_nearest i ~to_multiple_of:modulus =\n let remainder = i % modulus in\n let modulus_minus_remainder = modulus - remainder in\n if modulus_minus_remainder <= remainder\n then i + modulus_minus_remainder\n else i - remainder\n ;;\n\n let round ?(dir = `Nearest) i ~to_multiple_of =\n match dir with\n | `Nearest -> round_nearest i ~to_multiple_of\n | `Down -> round_down i ~to_multiple_of\n | `Up -> round_up i ~to_multiple_of\n | `Zero -> round_towards_zero i ~to_multiple_of\n ;;\nend\n\nmodule Private = struct\n let int_pow = int_pow\n let int64_pow = int64_pow\n let int63_pow_on_int64 = int63_pow_on_int64\n\n module Pow_overflow_bounds = Pow_overflow_bounds\nend\n","open! Import\ninclude Int_intf\ninclude Int0\n\nmodule T = struct\n type t = int [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int in\n fun x -> func x\n ;;\n\n let t_of_sexp = (int_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_int : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"int\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ int_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"int.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare x y = Int_replace_polymorphic_compare.compare x y\n\n let of_string s =\n try of_string s with\n | _ -> Printf.failwithf \"Int.of_string: %S\" s ()\n ;;\n\n let to_string = to_string\nend\n\nlet num_bits = Int_conversions.num_bits_int\nlet float_lower_bound = Float0.lower_bound_for_int num_bits\nlet float_upper_bound = Float0.upper_bound_for_int num_bits\nlet to_float = Caml.float_of_int\nlet of_float_unchecked = Caml.int_of_float\n\nlet of_float f =\n if Float_replace_polymorphic_compare.( >= ) f float_lower_bound\n && Float_replace_polymorphic_compare.( <= ) f float_upper_bound\n then Caml.int_of_float f\n else\n Printf.invalid_argf\n \"Int.of_float: argument (%f) is out of range or NaN\"\n (Float0.box f)\n ()\n;;\n\nlet zero = 0\nlet one = 1\nlet minus_one = -1\n\ninclude T\ninclude Comparator.Make (T)\n\ninclude Comparable.Validate_with_zero (struct\n include T\n\n let zero = zero\n end)\n\nmodule Conv = Int_conversions\ninclude Conv.Make (T)\n\ninclude Conv.Make_hex (struct\n open Int_replace_polymorphic_compare\n\n type t = int [@@deriving_inline compare, hash]\n\n let compare = (compare_int : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let zero = zero\n let neg = ( ~- )\n let ( < ) = ( < )\n let to_string i = Printf.sprintf \"%x\" i\n let of_string s = Caml.Scanf.sscanf s \"%x\" Fn.id\n let module_name = \"Base.Int.Hex\"\n end)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Base.Int\"\n end)\n\n(* Open replace_polymorphic_compare after including functor instantiations so\n they do not shadow its definitions. This is here so that efficient versions\n of the comparison functions are available within this module. *)\nopen! Int_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet pred i = i - 1\nlet succ i = i + 1\nlet to_int i = i\nlet to_int_exn = to_int\nlet of_int i = i\nlet of_int_exn = of_int\nlet max_value = Caml.max_int\nlet min_value = Caml.min_int\nlet max_value_30_bits = 0x3FFF_FFFF\nlet of_int32 = Conv.int32_to_int\nlet of_int32_exn = Conv.int32_to_int_exn\nlet of_int32_trunc = Conv.int32_to_int_trunc\nlet to_int32 = Conv.int_to_int32\nlet to_int32_exn = Conv.int_to_int32_exn\nlet to_int32_trunc = Conv.int_to_int32_trunc\nlet of_int64 = Conv.int64_to_int\nlet of_int64_exn = Conv.int64_to_int_exn\nlet of_int64_trunc = Conv.int64_to_int_trunc\nlet to_int64 = Conv.int_to_int64\nlet of_nativeint = Conv.nativeint_to_int\nlet of_nativeint_exn = Conv.nativeint_to_int_exn\nlet of_nativeint_trunc = Conv.nativeint_to_int_trunc\nlet to_nativeint = Conv.int_to_nativeint\nlet to_nativeint_exn = to_nativeint\nlet abs x = abs x\nlet ( + ) x y = x + y\nlet ( - ) x y = x - y\nlet ( * ) x y = x * y\nlet ( / ) x y = x / y\nlet neg x = -x\nlet ( ~- ) = neg\n\n(* note that rem is not same as % *)\nlet rem a b = a mod b\nlet incr = Caml.incr\nlet decr = Caml.decr\nlet shift_right a b = a asr b\nlet shift_right_logical a b = a lsr b\nlet shift_left a b = a lsl b\nlet bit_not a = lnot a\nlet bit_or a b = a lor b\nlet bit_and a b = a land b\nlet bit_xor a b = a lxor b\nlet pow = Int_math.Private.int_pow\nlet ( ** ) b e = pow b e\n\nmodule Pow2 = struct\n open! Import\n module Sys = Sys0\n\n let raise_s = Error.raise_s\n\n let non_positive_argument () =\n Printf.invalid_argf \"argument must be strictly positive\" ()\n ;;\n\n\n (** \"ceiling power of 2\" - Least power of 2 greater than or equal to x. *)\n let ceil_pow2 x =\n if x <= 0 then non_positive_argument ();\n let x = x - 1 in\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n (* The next line is superfluous on 32-bit architectures, but it's faster to do it\n anyway than to branch *)\n let x = x lor (x lsr 32) in\n x + 1\n ;;\n\n (** \"floor power of 2\" - Largest power of 2 less than or equal to x. *)\n let floor_pow2 x =\n if x <= 0 then non_positive_argument ();\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n (* The next line is superfluous on 32-bit architectures, but it's faster to do it\n anyway than to branch *)\n let x = x lor (x lsr 32) in\n x - (x lsr 1)\n ;;\n\n let is_pow2 x =\n if x <= 0 then non_positive_argument ();\n x land (x - 1) = 0\n ;;\n\n (* C stubs for int clz and ctz to use the CLZ/BSR/CTZ/BSF instruction where possible *)\n external clz\n : (* Note that we pass the tagged int here. See int_math_stubs.c for details on why\n this is correct. *)\n int\n -> (int[@untagged])\n = \"Base_int_math_int_clz\" \"Base_int_math_int_clz_untagged\"\n [@@noalloc]\n\n external ctz\n : (int[@untagged])\n -> (int[@untagged])\n = \"Base_int_math_int_ctz\" \"Base_int_math_int_ctz_untagged\"\n [@@noalloc]\n\n (** Hacker's Delight Second Edition p106 *)\n let floor_log2 i =\n if i <= 0\n then\n raise_s (Sexp.message \"[Int.floor_log2] got invalid input\" [ \"\", sexp_of_int i ]);\n num_bits - 1 - clz i\n ;;\n\n let ceil_log2 i =\n if i <= 0\n then raise_s (Sexp.message \"[Int.ceil_log2] got invalid input\" [ \"\", sexp_of_int i ]);\n if i = 1 then 0 else num_bits - clz (i - 1)\n ;;\nend\n\ninclude Pow2\n\n(* This is already defined by Comparable.Validate_with_zero, but Sign.of_int is\n more direct. *)\nlet sign = Sign.of_int\nlet popcount = Popcount.int_popcount\n\nmodule Pre_O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Int_replace_polymorphic_compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int_exn = of_int_exn\nend\n\nmodule O = struct\n include Pre_O\n\n module F = Int_math.Make (struct\n type nonrec t = t\n\n include Pre_O\n\n let rem = rem\n let to_float = to_float\n let of_float = of_float\n let of_string = T.of_string\n let to_string = T.to_string\n end)\n\n include F\n\n external bswap16 : int -> int = \"%bswap16\"\n\n (* These inlined versions of (%), (/%), and (//) perform better than their functorized\n counterparts in [F] (see benchmarks below).\n\n The reason these functions are inlined in [Int] but not in any of the other integer\n modules is that they existed in [Int] and [Int] alone prior to the introduction of\n the [Int_math.Make] functor, and we didn't want to degrade their performance.\n\n We won't pre-emptively do the same for new functions, unless someone cares, on a case\n by case fashion. *)\n\n let ( % ) x y =\n if y <= zero\n then\n Printf.invalid_argf\n \"%s %% %s in core_int.ml: modulus should be positive\"\n (to_string x)\n (to_string y)\n ();\n let rval = rem x y in\n if rval < zero then rval + y else rval\n ;;\n\n let ( /% ) x y =\n if y <= zero\n then\n Printf.invalid_argf\n \"%s /%% %s in core_int.ml: divisor should be positive\"\n (to_string x)\n (to_string y)\n ();\n if x < zero then ((x + one) / y) - one else x / y\n ;;\n\n let ( // ) x y = to_float x /. to_float y\n let ( land ) = ( land )\n let ( lor ) = ( lor )\n let ( lxor ) = ( lxor )\n let lnot = lnot\n let ( lsl ) = ( lsl )\n let ( asr ) = ( asr )\n let ( lsr ) = ( lsr )\nend\n\ninclude O\n\n(* [Int] and [Int.O] agree value-wise *)\n\nmodule Private = struct\n module O_F = O.F\nend\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after including functor\n application that could shadow its definitions. This is here so that efficient versions\n of the comparison functions are exported by this module. *)\ninclude Int_replace_polymorphic_compare\n","open! Import\n\ntype ('a, 'b) t = T : ('a, 'a) t [@@deriving_inline sexp_of]\n\nlet sexp_of_t\n : type a b.\n (a -> Ppx_sexp_conv_lib.Sexp.t)\n -> (b -> Ppx_sexp_conv_lib.Sexp.t)\n -> (a, b) t\n -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a _of_b -> function\n | T -> Ppx_sexp_conv_lib.Sexp.Atom \"T\"\n;;\n\n[@@@end]\n\ntype ('a, 'b) equal = ('a, 'b) t\n\nlet refl = T\nlet sym (type a b) (T : (a, b) t) : (b, a) t = T\nlet trans (type a b c) (T : (a, b) t) (T : (b, c) t) : (a, c) t = T\nlet conv (type a b) (T : (a, b) t) (a : a) : b = a\n\nmodule Lift (X : sig\n type 'a t\n end) =\nstruct\n let lift (type a b) (T : (a, b) t) : (a X.t, b X.t) t = T\nend\n\nmodule Lift2 (X : sig\n type ('a1, 'a2) t\n end) =\nstruct\n let lift (type a1 b1 a2 b2) (T : (a1, b1) t) (T : (a2, b2) t)\n : ((a1, a2) X.t, (b1, b2) X.t) t\n =\n T\n ;;\nend\n\nmodule Lift3 (X : sig\n type ('a1, 'a2, 'a3) t\n end) =\nstruct\n let lift (type a1 b1 a2 b2 a3 b3) (T : (a1, b1) t) (T : (a2, b2) t) (T : (a3, b3) t)\n : ((a1, a2, a3) X.t, (b1, b2, b3) X.t) t\n =\n T\n ;;\nend\n\nlet detuple2 (type a1 a2 b1 b2) (T : (a1 * a2, b1 * b2) t) : (a1, b1) t * (a2, b2) t =\n T, T\n;;\n\nlet tuple2 (type a1 a2 b1 b2) (T : (a1, b1) t) (T : (a2, b2) t) : (a1 * a2, b1 * b2) t =\n T\n;;\n\nmodule type Injective = sig\n type 'a t\n\n val strip : ('a t, 'b t) equal -> ('a, 'b) equal\nend\n\nmodule type Injective2 = sig\n type ('a1, 'a2) t\n\n val strip : (('a1, 'a2) t, ('b1, 'b2) t) equal -> ('a1, 'b1) equal * ('a2, 'b2) equal\nend\n\nmodule Composition_preserves_injectivity (M1 : Injective) (M2 : Injective) = struct\n type 'a t = 'a M1.t M2.t\n\n let strip e = M1.strip (M2.strip e)\nend\n\nmodule Obj = struct\n module Extension_constructor = struct\n [@@@ocaml.warning \"-3\"]\n\n let id = Caml.Obj.extension_id\n let of_val = Caml.Obj.extension_constructor\n end\nend\n\nmodule Id = struct\n module Uid = Int\n\n module Witness = struct\n module Key = struct\n type _ t = ..\n type type_witness_int = [ `type_witness of int ] [@@deriving_inline sexp_of]\n\n let sexp_of_type_witness_int =\n (function\n | `type_witness v0 ->\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"type_witness\"; sexp_of_int v0 ]\n : type_witness_int -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\n\n let sexp_of_t _sexp_of_a t =\n `type_witness (Obj.Extension_constructor.id (Obj.Extension_constructor.of_val t))\n |> sexp_of_type_witness_int\n ;;\n end\n\n module type S = sig\n type t\n type _ Key.t += Key : t Key.t\n end\n\n type 'a t = (module S with type t = 'a)\n\n let sexp_of_t (type a) sexp_of_a (module M : S with type t = a) =\n M.Key |> Key.sexp_of_t sexp_of_a\n ;;\n\n let create (type t) () =\n let module M = struct\n type nonrec t = t\n type _ Key.t += Key : t Key.t\n end\n in\n (module M : S with type t = t)\n ;;\n\n let uid (type a) (module M : S with type t = a) =\n Obj.Extension_constructor.id (Obj.Extension_constructor.of_val M.Key)\n ;;\n\n (* We want a constant allocated once that [same] can return whenever it gets the same\n witnesses. If we write the constant inside the body of [same], the native-code\n compiler will do the right thing and lift it out. But for clarity and robustness,\n we do it ourselves. *)\n let some_t = Some T\n\n let same (type a b) (a : a t) (b : b t) : (a, b) equal option =\n let module A = (val a : S with type t = a) in\n let module B = (val b : S with type t = b) in\n match A.Key with\n | B.Key -> some_t\n | _ -> None\n ;;\n end\n\n\n type 'a t =\n { witness : 'a Witness.t\n ; name : string\n ; to_sexp : 'a -> Sexp.t\n }\n\n let sexp_of_t _ { witness; name; to_sexp } : Sexp.t =\n if am_testing\n then Atom name\n else\n List\n [ List [ Atom \"name\"; Atom name ]\n ; List [ Atom \"witness\"; witness |> Witness.sexp_of_t to_sexp ]\n ]\n ;;\n\n let to_sexp t = t.to_sexp\n let name t = t.name\n let create ~name to_sexp = { witness = Witness.create (); name; to_sexp }\n let uid t = Witness.uid t.witness\n let hash t = uid t\n let hash_fold_t s t = hash_fold_int s (uid t)\n let same_witness t1 t2 = Witness.same t1.witness t2.witness\n let same t1 t2 = Option.is_some (same_witness t1 t2)\n\n let same_witness_exn t1 t2 =\n match same_witness t1 t2 with\n | Some w -> w\n | None ->\n Error.raise_s\n (Sexp.message\n \"Type_equal.Id.same_witness_exn got different ids\"\n [ ( \"\"\n , sexp_of_pair (sexp_of_t sexp_of_opaque) (sexp_of_t sexp_of_opaque) (t1, t2)\n )\n ])\n ;;\nend\n","open! Import\nopen Std_internal\ninclude Univ_map_intf\nmodule Uid = Type_equal.Id.Uid\n\nmodule Make1\n (Key : Key) (Data : sig\n type ('s, 'a) t [@@deriving sexp_of]\n end) =\nstruct\n (* A wrapper for the [Key] module that adds a dynamic check to [Key.to_type_id].\n\n It's a bug if the user-provided [Key.to_type_id] gives different type ids on\n different calls. Because this check should be fairly cheap, we do it dynamically to\n avoid subtler problems later.\n\n Of course, we're not checking truly pathological things like the provided\n [Key.to_type_id] only changes the value it returns on every third call...\n *)\n module Key = struct\n type 'a t = 'a Key.t [@@deriving sexp_of]\n\n (* test-friendly sexp conversion *)\n let sexp_of_type_id type_id =\n [%sexp\n { name = (Type_equal.Id.name type_id : string)\n ; uid =\n ((if am_running_inline_test\n then Sexp.Atom \"\"\n else Type_equal.Id.Uid.sexp_of_t (Type_equal.Id.uid type_id)) : Sexp.t)\n }]\n ;;\n\n let to_type_id key =\n let type_id1 = Key.to_type_id key in\n let type_id2 = Key.to_type_id key in\n if Type_equal.Id.same type_id1 type_id2\n then type_id1\n else\n raise_s\n [%message\n \"[Key.to_type_id] must not provide different type ids when called on the \\\n same input\"\n (key : _ Key.t)\n (type_id1 : type_id)\n (type_id2 : type_id)]\n ;;\n end\n\n type ('s, 'a) data = ('s, 'a) Data.t\n\n let name_of_key key = Type_equal.Id.name (Key.to_type_id key)\n let uid_of_key key = Type_equal.Id.uid (Key.to_type_id key)\n\n module Packed = struct\n type 's t = T : 'a Key.t * ('s, 'a) Data.t -> 's t\n\n let sexp_of_t sexp_of_a (T (key, data)) =\n Data.sexp_of_t sexp_of_a (Type_equal.Id.to_sexp (Key.to_type_id key)) data\n ;;\n\n let type_id_name (T (key, _)) = name_of_key key\n let type_id_uid (T (key, _)) = uid_of_key key\n end\n\n type 's t = 's Packed.t Uid.Map.t\n\n let sexp_of_t sexp_of_a t =\n Map.data t\n |> List.map ~f:(fun u -> Packed.type_id_name u, u)\n |> List.sort ~compare:(fun (a, _) (b, _) -> String.compare a b)\n |> [%sexp_of: (string * a Packed.t) list]\n ;;\n\n let invariant (t : _ t) =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n Map.iteri t ~f:(fun ~key ~data ->\n assert (Uid.equal key (Packed.type_id_uid data))))\n ;;\n\n let set t key data = Map.set t ~key:(uid_of_key key) ~data:(Packed.T (key, data))\n let mem_by_id t id = Map.mem t id\n let mem t key = mem_by_id t (uid_of_key key)\n let remove_by_id t id = Map.remove t id\n let remove t key = remove_by_id t (uid_of_key key)\n let empty = Uid.Map.empty\n let is_empty = Map.is_empty\n\n let find (type b) t (key : b Key.t) =\n match Map.find t (uid_of_key key) with\n | None -> None\n | Some (Packed.T (key', value)) ->\n (* cannot raise -- see [invariant] *)\n let Type_equal.T =\n Type_equal.Id.same_witness_exn (Key.to_type_id key) (Key.to_type_id key')\n in\n Some (value : (_, b) Data.t)\n ;;\n\n let find_exn t key =\n match find t key with\n | Some data -> data\n | None -> failwithf \"Univ_map.find_exn on unknown key %s\" (name_of_key key) ()\n ;;\n\n let add t key data = if mem t key then `Duplicate else `Ok (set t key data)\n\n let add_exn t key data =\n match add t key data with\n | `Ok t -> t\n | `Duplicate -> failwithf \"Univ_map.add_exn on existing key %s\" (name_of_key key) ()\n ;;\n\n let change_exn t key ~f:update =\n match find t key with\n | Some data -> set t key (update data)\n | None -> failwithf \"Univ_map.change_exn on unknown key %s\" (name_of_key key) ()\n ;;\n\n let change t key ~f:update =\n let orig = find t key in\n let next = update orig in\n match next with\n | Some data -> set t key data\n | None -> if Option.is_none orig then t else remove t key\n ;;\n\n let update t key ~f = change t key ~f:(fun data -> Some (f data))\n let to_alist t = Map.data t\n\n let of_alist_exn t =\n Uid.Map.of_alist_exn (List.map t ~f:(fun p -> Packed.type_id_uid p, p))\n ;;\nend\n\nmodule Make\n (Key : Key) (Data : sig\n type 'a t [@@deriving sexp_of]\n end) =\nstruct\n module M =\n Make1\n (Key)\n (struct\n type (_, 'a) t = 'a Data.t [@@deriving sexp_of]\n end)\n\n type t = unit M.t [@@deriving sexp_of]\n\n module Key = Key\n\n type 'a data = 'a Data.t\n\n let invariant = M.invariant\n let empty = M.empty\n let is_empty = M.is_empty\n let set = M.set\n let mem = M.mem\n let mem_by_id = M.mem_by_id\n let find = M.find\n let find_exn = M.find_exn\n let add = M.add\n let add_exn = M.add_exn\n let change = M.change\n let change_exn = M.change_exn\n let update = M.update\n let remove = M.remove\n let remove_by_id = M.remove_by_id\n\n module Packed = struct\n type t = T : 'a Key.t * 'a Data.t -> t\n end\n\n let to_alist t =\n List.map (M.to_alist t) ~f:(function M.Packed.T (key, data) -> Packed.T (key, data))\n ;;\n\n let of_alist_exn t =\n M.of_alist_exn\n (List.map t ~f:(function Packed.T (key, data) -> M.Packed.T (key, data)))\n ;;\nend\n\nmodule Merge\n (Key : Key)\n (Input1_data : Data1)\n (Input2_data : Data1)\n (Output_data : Data1) =\nstruct\n type 's f =\n { f :\n 'a. key:'a Key.t\n -> [ `Left of ('s, 'a) Input1_data.t\n | `Right of ('s, 'a) Input2_data.t\n | `Both of ('s, 'a) Input1_data.t * ('s, 'a) Input2_data.t\n ] -> ('s, 'a) Output_data.t option\n }\n\n module Output = Make1 (Key) (Output_data)\n\n let merge\n (type s)\n (t1 : s Make1(Key)(Input1_data).t)\n (t2 : s Make1(Key)(Input2_data).t)\n ~f:{ f }\n =\n let f ~key merge_result =\n Option.map (f ~key merge_result) ~f:(fun data -> Output.Packed.T (key, data))\n in\n Map.merge t1 t2 ~f:(fun ~key:_ ->\n function\n | `Left (T (key, data)) -> f ~key (`Left data)\n | `Right (T (key, data)) -> f ~key (`Right data)\n | `Both (T (left_key, left_data), T (right_key, right_data)) ->\n (* Can't raise due to the invariant *)\n let Type_equal.T =\n Type_equal.Id.same_witness_exn\n (Key.to_type_id left_key)\n (Key.to_type_id right_key)\n in\n f ~key:left_key (`Both (left_data, right_data)))\n ;;\nend\n\nmodule Type_id_key = struct\n type 'a t = 'a Type_equal.Id.t [@@deriving sexp_of]\n\n let to_type_id = Fn.id\nend\n\ninclude (\n Make\n (Type_id_key)\n (struct\n type 'a t = 'a [@@deriving sexp_of]\n end) :\n S with type 'a data = 'a and module Key := Type_id_key)\n\nmodule Key = Type_equal.Id\n\nmodule With_default = struct\n module Key = struct\n type 'a t =\n { key : 'a Type_equal.Id.t\n ; default : 'a\n }\n\n let create ~default ~name sexp_of =\n { default; key = Type_equal.Id.create ~name sexp_of }\n ;;\n\n let id t = t.key\n end\n\n let find t { Key.key; default } = Option.value ~default (find t key)\n let set t { Key.key; default = _ } v = set t key v\n let change t k ~f:update = set t k (update (find t k))\nend\n\nmodule With_fold = struct\n module Key = struct\n type ('a, 'b) t =\n { key : 'b With_default.Key.t\n ; f : 'b -> 'a -> 'b\n }\n\n let create ~init ~f ~name sexp_of =\n { f; key = With_default.Key.create ~default:init ~name sexp_of }\n ;;\n\n let id t = With_default.Key.id t.key\n end\n\n let find t { Key.key; f = _ } = With_default.find t key\n let set t { Key.key; f = _ } v = With_default.set t key v\n let change t { Key.key; f = _ } ~f:update = With_default.change t key ~f:update\n let add t { Key.key; f } v = With_default.change t key ~f:(fun acc -> f acc v)\nend\n\nmodule Multi = struct\n open With_fold\n\n module Key = struct\n type 'a t = ('a, 'a list) Key.t\n\n let create ~name sexp_of =\n Key.create ~init:[] ~f:(fun xs x -> x :: xs) ~name (List.sexp_of_t sexp_of)\n ;;\n\n let id = With_fold.Key.id\n end\n\n let set = set\n let find = find\n let add = add\n let change = change\nend\n","open! Import\n\n(** ['a Cheap_option.t] is like ['a option], but it doesn't box [some _] values.\n\n There are several things that are unsafe about it:\n\n - [float t array] (or any array-backed container) is not memory-safe\n because float array optimization is incompatible with unboxed option\n optimization. You have to use [Uniform_array.t] instead of [array].\n\n - Nested options (['a t t]) don't work. They are believed to be\n memory-safe, but not parametric.\n\n - A record with [float t]s in it should be safe, but it's only [t] being\n abstract that gives you safety. If the compiler was smart enough to peek\n through the module signature then it could decide to construct a float\n array instead. *)\nmodule Cheap_option = struct\n (* This is taken from core_kernel. Rather than expose it in the public\n interface of base, just keep a copy around here. *)\n let phys_same (type a b) (a : a) (b : b) = phys_equal a (Caml.Obj.magic b : a)\n\n module T0 : sig\n type 'a t\n\n val none : _ t\n val some : 'a -> 'a t\n val is_none : _ t -> bool\n val is_some : _ t -> bool\n val value_exn : 'a t -> 'a\n val value_unsafe : 'a t -> 'a\n end = struct\n type +'a t\n\n (* Being a pointer, no one outside this module can construct a value that is\n [phys_same] as this one.\n\n It would be simpler to use this value as [none], but we use an immediate instead\n because it lets us avoid caml_modify when setting to [none], making certain\n benchmarks significantly faster (e.g. ../bench/array_queue.exe).\n\n this code is duplicated in Moption, and if we find yet another place where we want\n it we should reconsider making it shared. *)\n let none_substitute : _ t = Caml.Obj.obj (Caml.Obj.new_block Caml.Obj.abstract_tag 1)\n\n let none : _ t =\n (* The number was produced by\n [< /dev/urandom tr -c -d '1234567890abcdef' | head -c 16].\n\n The idea is that a random number will have lower probability to collide with\n anything than any number we can choose ourselves.\n\n We are using a polymorphic variant instead of an integer constant because there\n is a compiler bug where it wrongly assumes that the result of [if _ then c else\n y] is not a pointer if [c] is an integer compile-time constant. This is being\n fixed in https://github.com/ocaml/ocaml/pull/555. The \"memory corruption\" test\n below demonstrates the issue. *)\n Caml.Obj.magic `x6e8ee3478e1d7449\n ;;\n\n let is_none x = phys_equal x none\n let is_some x = not (phys_equal x none)\n\n let some (type a) (x : a) : a t =\n if phys_same x none then none_substitute else Caml.Obj.magic x\n ;;\n\n let value_unsafe (type a) (x : a t) : a =\n if phys_equal x none_substitute then Caml.Obj.magic none else Caml.Obj.magic x\n ;;\n\n let value_exn x =\n if is_some x\n then value_unsafe x\n else failwith \"Option_array.get_some_exn: the element is [None]\"\n ;;\n end\n\n module T1 = struct\n include T0\n\n let of_option = function\n | None -> none\n | Some x -> some x\n ;;\n\n let to_option x = if is_some x then Some (value_unsafe x) else None\n let to_sexpable = to_option\n let of_sexpable = of_option\n end\n\n include T1\n include Sexpable.Of_sexpable1 (Option) (T1)\nend\n\ntype 'a t = 'a Cheap_option.t Uniform_array.t [@@deriving_inline sexp]\n\nlet t_of_sexp : 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t =\n let _tp_loc = \"option_array.ml.t\" in\n fun _of_a t -> Uniform_array.t_of_sexp (Cheap_option.t_of_sexp _of_a) t\n;;\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n fun _of_a v -> Uniform_array.sexp_of_t (Cheap_option.sexp_of_t _of_a) v\n;;\n\n[@@@end]\n\nlet empty = Uniform_array.empty\nlet create ~len = Uniform_array.create ~len Cheap_option.none\nlet init n ~f = Uniform_array.init n ~f:(fun i -> Cheap_option.of_option (f i))\nlet init_some n ~f = Uniform_array.init n ~f:(fun i -> Cheap_option.some (f i))\nlet length = Uniform_array.length\nlet get t i = Cheap_option.to_option (Uniform_array.get t i)\nlet get_some_exn t i = Cheap_option.value_exn (Uniform_array.get t i)\nlet is_none t i = Cheap_option.is_none (Uniform_array.get t i)\nlet is_some t i = Cheap_option.is_some (Uniform_array.get t i)\nlet set t i x = Uniform_array.set t i (Cheap_option.of_option x)\nlet set_some t i x = Uniform_array.set t i (Cheap_option.some x)\nlet set_none t i = Uniform_array.set t i Cheap_option.none\nlet swap t i j = Uniform_array.swap t i j\nlet unsafe_get t i = Cheap_option.to_option (Uniform_array.unsafe_get t i)\nlet unsafe_get_some_exn t i = Cheap_option.value_exn (Uniform_array.unsafe_get t i)\n\nlet unsafe_get_some_assuming_some t i =\n Cheap_option.value_unsafe (Uniform_array.unsafe_get t i)\n;;\n\nlet unsafe_is_some t i = Cheap_option.is_some (Uniform_array.unsafe_get t i)\nlet unsafe_set t i x = Uniform_array.unsafe_set t i (Cheap_option.of_option x)\nlet unsafe_set_some t i x = Uniform_array.unsafe_set t i (Cheap_option.some x)\nlet unsafe_set_none t i = Uniform_array.unsafe_set t i Cheap_option.none\n\nlet clear t =\n for i = 0 to length t - 1 do\n unsafe_set_none t i\n done\n;;\n\ninclude Blit.Make1_generic (struct\n type nonrec 'a t = 'a t\n\n let length = length\n let create_like ~len _ = create ~len\n let unsafe_blit = Uniform_array.unsafe_blit\n end)\n\nlet copy = Uniform_array.copy\n\nmodule For_testing = struct\n module Unsafe_cheap_option = Cheap_option\nend\n","open! Import\ninclude Stack_intf\n\nlet raise_s = Error.raise_s\n\n(* This implementation is similar to [Deque] in that it uses an array of ['a] and\n a mutable [int] to indicate what in the array is used. We choose to implement [Stack]\n directly rather than on top of [Deque] for performance reasons. E.g. a simple\n microbenchmark shows that push/pop is about 20% faster. *)\ntype 'a t =\n { mutable length : int\n ; mutable elts : 'a Option_array.t\n }\n[@@deriving_inline sexp_of]\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n fun _of_a -> function\n | { length = v_length; elts = v_elts } ->\n let bnds = [] in\n let bnds =\n let arg = Option_array.sexp_of_t _of_a v_elts in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"elts\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_length in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"length\"; arg ] :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n;;\n\n[@@@end]\n\nlet sexp_of_t_internal = sexp_of_t\nlet sexp_of_t = `Rebound_later\nlet _ = sexp_of_t\nlet capacity t = Option_array.length t.elts\n\nlet invariant invariant_a ({ length; elts } as t) : unit =\n try\n assert (0 <= length && length <= Option_array.length elts);\n for i = 0 to length - 1 do\n invariant_a (Option_array.get_some_exn elts i)\n done;\n (* We maintain the invariant that unused elements are unset to avoid a space\n leak. *)\n for i = length to Option_array.length elts - 1 do\n assert (not (Option_array.is_some elts i))\n done\n with\n | exn ->\n raise_s\n (Sexp.message\n \"Stack.invariant failed\"\n [ \"exn\", exn |> Exn.sexp_of_t; \"stack\", t |> sexp_of_t_internal sexp_of_opaque ])\n;;\n\nlet create (type a) () : a t = { length = 0; elts = Option_array.empty }\nlet length t = t.length\nlet is_empty t = length t = 0\n\n(* The order in which elements are visited has been chosen so as to be backwards\n compatible with both [Linked_stack] and [Caml.Stack] *)\nlet fold t ~init ~f =\n let r = ref init in\n for i = t.length - 1 downto 0 do\n r := f !r (Option_array.get_some_exn t.elts i)\n done;\n !r\n;;\n\nlet iter t ~f =\n for i = t.length - 1 downto 0 do\n f (Option_array.get_some_exn t.elts i)\n done\n;;\n\nmodule C = Container.Make (struct\n type nonrec 'a t = 'a t\n\n let fold = fold\n let iter = `Custom iter\n let length = `Custom length\n end)\n\nlet mem = C.mem\nlet exists = C.exists\nlet for_all = C.for_all\nlet count = C.count\nlet sum = C.sum\nlet find = C.find\nlet find_map = C.find_map\nlet to_list = C.to_list\nlet to_array = C.to_array\nlet min_elt = C.min_elt\nlet max_elt = C.max_elt\nlet fold_result = C.fold_result\nlet fold_until = C.fold_until\n\nlet of_list (type a) (l : a list) =\n if List.is_empty l\n then create ()\n else (\n let length = List.length l in\n let elts = Option_array.create ~len:(2 * length) in\n let r = ref l in\n for i = length - 1 downto 0 do\n match !r with\n | [] -> assert false\n | a :: l ->\n Option_array.set_some elts i a;\n r := l\n done;\n { length; elts })\n;;\n\nlet sexp_of_t sexp_of_a t = List.sexp_of_t sexp_of_a (to_list t)\nlet t_of_sexp a_of_sexp sexp = of_list (List.t_of_sexp a_of_sexp sexp)\n\nlet resize t size =\n let arr = Option_array.create ~len:size in\n Option_array.blit ~src:t.elts ~dst:arr ~src_pos:0 ~dst_pos:0 ~len:t.length;\n t.elts <- arr\n;;\n\nlet set_capacity t new_capacity =\n let new_capacity = max new_capacity (length t) in\n if new_capacity <> capacity t then resize t new_capacity\n;;\n\nlet push t a =\n if t.length = Option_array.length t.elts then resize t (2 * (t.length + 1));\n Option_array.set_some t.elts t.length a;\n t.length <- t.length + 1\n;;\n\nlet pop_nonempty t =\n let i = t.length - 1 in\n let result = Option_array.get_some_exn t.elts i in\n Option_array.set_none t.elts i;\n t.length <- i;\n result\n;;\n\nlet pop_error = Error.of_string \"Stack.pop of empty stack\"\nlet pop t = if is_empty t then None else Some (pop_nonempty t)\nlet pop_exn t = if is_empty t then Error.raise pop_error else pop_nonempty t\nlet top_nonempty t = Option_array.get_some_exn t.elts (t.length - 1)\nlet top_error = Error.of_string \"Stack.top of empty stack\"\nlet top t = if is_empty t then None else Some (top_nonempty t)\nlet top_exn t = if is_empty t then Error.raise top_error else top_nonempty t\nlet copy { length; elts } = { length; elts = Option_array.copy elts }\n\nlet clear t =\n if t.length > 0\n then (\n for i = 0 to t.length - 1 do\n Option_array.set_none t.elts i\n done;\n t.length <- 0)\n;;\n\nlet until_empty t f =\n let rec loop () =\n if t.length > 0\n then (\n f (pop_nonempty t);\n loop ())\n in\n loop ()\n;;\n\nlet singleton x =\n let t = create () in\n push t x;\n t\n;;\n","(***********************************************************************)\n(* *)\n(* Objective Caml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. All rights reserved. This file is distributed *)\n(* under the terms of the Apache 2.0 license. See ../THIRD-PARTY.txt *)\n(* for details. *)\n(* *)\n(***********************************************************************)\n\n(* Sets over ordered types *)\n\nopen! Import\ninclude Set_intf\n\nlet with_return = With_return.with_return\n\n\nmodule Tree0 = struct\n type 'a t =\n | Empty\n (* (Leaf x) is the same as (Node (Empty, x, Empty, 1, 1)) but uses less space. *)\n | Leaf of 'a\n (* first int is height, second is sub-tree size *)\n | Node of 'a t * 'a * 'a t * int * int\n\n type 'a tree = 'a t\n\n (* Sets are represented by balanced binary trees (the heights of the children differ by\n at most 2. *)\n let height = function\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, h, _) -> h\n ;;\n\n let length = function\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, s) -> s\n ;;\n\n let invariants =\n let in_range lower upper compare_elt v =\n (match lower with\n | None -> true\n | Some lower -> compare_elt lower v < 0)\n &&\n match upper with\n | None -> true\n | Some upper -> compare_elt v upper < 0\n in\n let rec loop lower upper compare_elt t =\n match t with\n | Empty -> true\n | Leaf v -> in_range lower upper compare_elt v\n | Node (l, v, r, h, n) ->\n let hl = height l\n and hr = height r in\n abs (hl - hr) <= 2\n && h = max hl hr + 1\n && n = length l + length r + 1\n && in_range lower upper compare_elt v\n && loop lower (Some v) compare_elt l\n && loop (Some v) upper compare_elt r\n in\n fun t ~compare_elt -> loop None None compare_elt t\n ;;\n\n let is_empty = function\n | Empty -> true\n | Leaf _ | Node _ -> false\n ;;\n\n (* Creates a new node with left son l, value v and right son r.\n We must have all elements of l < v < all elements of r.\n l and r must be balanced and | height l - height r | <= 2.\n Inline expansion of height for better speed. *)\n\n let create l v r =\n let hl =\n match l with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, h, _) -> h\n in\n let hr =\n match r with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, h, _) -> h\n in\n let h = if hl >= hr then hl + 1 else hr + 1 in\n if h = 1\n then Leaf v\n else (\n let sl =\n match l with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, s) -> s\n in\n let sr =\n match r with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, s) -> s\n in\n Node (l, v, r, h, sl + sr + 1))\n ;;\n\n (* We must call [f] with increasing indexes, because the bin_prot reader in\n Core_kernel.Set needs it. *)\n let of_increasing_iterator_unchecked ~len ~f =\n let rec loop n ~f i =\n match n with\n | 0 -> Empty\n | 1 ->\n let k = f i in\n Leaf k\n | 2 ->\n let kl = f i in\n let k = f (i + 1) in\n create (Leaf kl) k Empty\n | 3 ->\n let kl = f i in\n let k = f (i + 1) in\n let kr = f (i + 2) in\n create (Leaf kl) k (Leaf kr)\n | n ->\n let left_length = n lsr 1 in\n let right_length = n - left_length - 1 in\n let left = loop left_length ~f i in\n let k = f (i + left_length) in\n let right = loop right_length ~f (i + left_length + 1) in\n create left k right\n in\n loop len ~f 0\n ;;\n\n let of_sorted_array_unchecked array ~compare_elt =\n let array_length = Array.length array in\n let next =\n (* We don't check if the array is sorted or keys are duplicated, because that\n checking is slower than the whole [of_sorted_array] function *)\n if array_length < 2 || compare_elt array.(0) array.(1) < 0\n then fun i -> array.(i)\n else fun i -> array.(array_length - 1 - i)\n in\n of_increasing_iterator_unchecked ~len:array_length ~f:next\n ;;\n\n let of_sorted_array array ~compare_elt =\n match array with\n | [||] | [| _ |] -> Result.Ok (of_sorted_array_unchecked array ~compare_elt)\n | _ ->\n with_return (fun r ->\n let increasing =\n match compare_elt array.(0) array.(1) with\n | 0 ->\n r.return (Or_error.error_string \"of_sorted_array: duplicated elements\")\n | i -> i < 0\n in\n for i = 1 to Array.length array - 2 do\n match compare_elt array.(i) array.(i + 1) with\n | 0 ->\n r.return (Or_error.error_string \"of_sorted_array: duplicated elements\")\n | i ->\n if Poly.( <> ) (i < 0) increasing\n then\n r.return\n (Or_error.error_string \"of_sorted_array: elements are not ordered\")\n done;\n Result.Ok (of_sorted_array_unchecked array ~compare_elt))\n ;;\n\n (* Same as create, but performs one step of rebalancing if necessary.\n Assumes l and r balanced and | height l - height r | <= 3.\n Inline expansion of create for better speed in the most frequent case\n where no rebalancing is required. *)\n\n let bal l v r =\n let hl =\n match l with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, h, _) -> h\n in\n let hr =\n match r with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, h, _) -> h\n in\n if hl > hr + 2\n then (\n match l with\n | Empty -> assert false\n | Leaf _ -> assert false (* because h(l)>h(r)+2 and h(leaf)=1 *)\n | Node (ll, lv, lr, _, _) ->\n if height ll >= height lr\n then create ll lv (create lr v r)\n else (\n match lr with\n | Empty -> assert false\n | Leaf lrv ->\n assert (is_empty ll);\n create (create ll lv Empty) lrv (create Empty v r)\n | Node (lrl, lrv, lrr, _, _) -> create (create ll lv lrl) lrv (create lrr v r)))\n else if hr > hl + 2\n then (\n match r with\n | Empty -> assert false\n | Leaf rv -> create (create l v Empty) rv Empty\n | Node (rl, rv, rr, _, _) ->\n if height rr >= height rl\n then create (create l v rl) rv rr\n else (\n match rl with\n | Empty -> assert false\n | Leaf rlv ->\n assert (is_empty rr);\n create (create l v Empty) rlv (create Empty rv rr)\n | Node (rll, rlv, rlr, _, _) -> create (create l v rll) rlv (create rlr rv rr)))\n else (\n let h = if hl >= hr then hl + 1 else hr + 1 in\n let sl =\n match l with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, s) -> s\n in\n let sr =\n match r with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, s) -> s\n in\n if h = 1 then Leaf v else Node (l, v, r, h, sl + sr + 1))\n ;;\n\n (* Insertion of one element *)\n\n exception Same\n\n let add t x ~compare_elt =\n let rec aux = function\n | Empty -> Leaf x\n | Leaf v ->\n let c = compare_elt x v in\n if c = 0\n then raise Same\n else if c < 0\n then bal (Leaf x) v Empty\n else bal Empty v (Leaf x)\n | Node (l, v, r, _, _) ->\n let c = compare_elt x v in\n if c = 0 then raise Same else if c < 0 then bal (aux l) v r else bal l v (aux r)\n in\n try aux t with\n | Same -> t\n ;;\n\n (* Same as create and bal, but no assumptions are made on the relative heights of l and\n r. *)\n let rec join l v r ~compare_elt =\n match l, r with\n | Empty, _ -> add r v ~compare_elt\n | _, Empty -> add l v ~compare_elt\n | Leaf lv, _ -> add (add r v ~compare_elt) lv ~compare_elt\n | _, Leaf rv -> add (add l v ~compare_elt) rv ~compare_elt\n | Node (ll, lv, lr, lh, _), Node (rl, rv, rr, rh, _) ->\n if lh > rh + 2\n then bal ll lv (join lr v r ~compare_elt)\n else if rh > lh + 2\n then bal (join l v rl ~compare_elt) rv rr\n else create l v r\n ;;\n\n (* Smallest and greatest element of a set *)\n let rec min_elt = function\n | Empty -> None\n | Leaf v | Node (Empty, v, _, _, _) -> Some v\n | Node (l, _, _, _, _) -> min_elt l\n ;;\n\n exception Set_min_elt_exn_of_empty_set [@@deriving_inline sexp]\n\n let () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Set_min_elt_exn_of_empty_set]\n (function\n | Set_min_elt_exn_of_empty_set ->\n Ppx_sexp_conv_lib.Sexp.Atom \"set.ml.Tree0.Set_min_elt_exn_of_empty_set\"\n | _ -> assert false)\n ;;\n\n [@@@end]\n\n exception Set_max_elt_exn_of_empty_set [@@deriving_inline sexp]\n\n let () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Set_max_elt_exn_of_empty_set]\n (function\n | Set_max_elt_exn_of_empty_set ->\n Ppx_sexp_conv_lib.Sexp.Atom \"set.ml.Tree0.Set_max_elt_exn_of_empty_set\"\n | _ -> assert false)\n ;;\n\n [@@@end]\n\n let min_elt_exn t =\n match min_elt t with\n | None -> raise Set_min_elt_exn_of_empty_set\n | Some v -> v\n ;;\n\n let fold_until t ~init ~f ~finish =\n let rec fold_until_helper ~f t acc =\n match t with\n | Empty -> Continue_or_stop.Continue acc\n | Leaf value -> f acc value\n | Node (left, value, right, _, _) ->\n (match fold_until_helper ~f left acc with\n | Stop _a as x -> x\n | Continue acc ->\n (match f acc value with\n | Stop _a as x -> x\n | Continue a -> fold_until_helper ~f right a))\n in\n match fold_until_helper ~f t init with\n | Continue x -> finish x\n | Stop x -> x\n ;;\n\n let rec max_elt = function\n | Empty -> None\n | Leaf v | Node (_, v, Empty, _, _) -> Some v\n | Node (_, _, r, _, _) -> max_elt r\n ;;\n\n let max_elt_exn t =\n match max_elt t with\n | None -> raise Set_max_elt_exn_of_empty_set\n | Some v -> v\n ;;\n\n (* Remove the smallest element of the given set *)\n\n let rec remove_min_elt = function\n | Empty -> invalid_arg \"Set.remove_min_elt\"\n | Leaf _ -> Empty\n | Node (Empty, _, r, _, _) -> r\n | Node (l, v, r, _, _) -> bal (remove_min_elt l) v r\n ;;\n\n (* Merge two trees l and r into one. All elements of l must precede the elements of r.\n Assume | height l - height r | <= 2. *)\n let merge t1 t2 =\n match t1, t2 with\n | Empty, t -> t\n | t, Empty -> t\n | _, _ -> bal t1 (min_elt_exn t2) (remove_min_elt t2)\n ;;\n\n (* Merge two trees l and r into one. All elements of l must precede the elements of r.\n No assumption on the heights of l and r. *)\n let concat t1 t2 ~compare_elt =\n match t1, t2 with\n | Empty, t | t, Empty -> t\n | _, _ -> join t1 (min_elt_exn t2) (remove_min_elt t2) ~compare_elt\n ;;\n\n let split t x ~compare_elt =\n let rec split t =\n match t with\n | Empty -> Empty, None, Empty\n | Leaf v ->\n let c = compare_elt x v in\n if c = 0\n then Empty, Some v, Empty\n else if c < 0\n then Empty, None, Leaf v\n else Leaf v, None, Empty\n | Node (l, v, r, _, _) ->\n let c = compare_elt x v in\n if c = 0\n then l, Some v, r\n else if c < 0\n then (\n let ll, maybe_elt, rl = split l in\n ll, maybe_elt, join rl v r ~compare_elt)\n else (\n let lr, maybe_elt, rr = split r in\n join l v lr ~compare_elt, maybe_elt, rr)\n in\n split t\n ;;\n\n (* Implementation of the set operations *)\n\n let empty = Empty\n\n let rec mem t x ~compare_elt =\n match t with\n | Empty -> false\n | Leaf v ->\n let c = compare_elt x v in\n c = 0\n | Node (l, v, r, _, _) ->\n let c = compare_elt x v in\n c = 0 || mem (if c < 0 then l else r) x ~compare_elt\n ;;\n\n let singleton x = Leaf x\n\n let remove t x ~compare_elt =\n let rec aux t =\n match t with\n | Empty -> raise Same\n | Leaf v -> if compare_elt x v = 0 then Empty else raise Same\n | Node (l, v, r, _, _) ->\n let c = compare_elt x v in\n if c = 0 then merge l r else if c < 0 then bal (aux l) v r else bal l v (aux r)\n in\n try aux t with\n | Same -> t\n ;;\n\n let remove_index t i ~compare_elt:_ =\n let rec aux t i =\n match t with\n | Empty -> raise Same\n | Leaf _ -> if i = 0 then Empty else raise Same\n | Node (l, v, r, _, _) ->\n let l_size = length l in\n let c = Poly.compare i l_size in\n if c = 0\n then merge l r\n else if c < 0\n then bal (aux l i) v r\n else bal l v (aux r (i - l_size - 1))\n in\n try aux t i with\n | Same -> t\n ;;\n\n let union s1 s2 ~compare_elt =\n let rec union s1 s2 =\n if phys_equal s1 s2\n then s1\n else (\n match s1, s2 with\n | Empty, t | t, Empty -> t\n | Leaf v1, _ -> union (Node (Empty, v1, Empty, 1, 1)) s2\n | _, Leaf v2 -> union s1 (Node (Empty, v2, Empty, 1, 1))\n | Node (l1, v1, r1, h1, _), Node (l2, v2, r2, h2, _) ->\n if h1 >= h2\n then\n if h2 = 1\n then add s1 v2 ~compare_elt\n else (\n let l2, _, r2 = split s2 v1 ~compare_elt in\n join (union l1 l2) v1 (union r1 r2) ~compare_elt)\n else if h1 = 1\n then add s2 v1 ~compare_elt\n else (\n let l1, _, r1 = split s1 v2 ~compare_elt in\n join (union l1 l2) v2 (union r1 r2) ~compare_elt))\n in\n union s1 s2\n ;;\n\n let union_list ~comparator ~to_tree xs =\n let compare_elt = comparator.Comparator.compare in\n List.fold xs ~init:empty ~f:(fun ac x -> union ac (to_tree x) ~compare_elt)\n ;;\n\n let inter s1 s2 ~compare_elt =\n let rec inter s1 s2 =\n if phys_equal s1 s2\n then s1\n else (\n match s1, s2 with\n | Empty, _ | _, Empty -> Empty\n | (Leaf elt as singleton), other_set | other_set, (Leaf elt as singleton) ->\n if mem other_set elt ~compare_elt then singleton else Empty\n | Node (l1, v1, r1, _, _), t2 ->\n (match split t2 v1 ~compare_elt with\n | l2, None, r2 -> concat (inter l1 l2) (inter r1 r2) ~compare_elt\n | l2, Some v1, r2 -> join (inter l1 l2) v1 (inter r1 r2) ~compare_elt))\n in\n inter s1 s2\n ;;\n\n let diff s1 s2 ~compare_elt =\n let rec diff s1 s2 =\n if phys_equal s1 s2\n then Empty\n else (\n match s1, s2 with\n | Empty, _ -> Empty\n | t1, Empty -> t1\n | Leaf v1, t2 -> diff (Node (Empty, v1, Empty, 1, 1)) t2\n | Node (l1, v1, r1, _, _), t2 ->\n (match split t2 v1 ~compare_elt with\n | l2, None, r2 -> join (diff l1 l2) v1 (diff r1 r2) ~compare_elt\n | l2, Some _, r2 -> concat (diff l1 l2) (diff r1 r2) ~compare_elt))\n in\n diff s1 s2\n ;;\n\n module Enum = struct\n type increasing\n type decreasing\n\n type ('a, 'direction) t =\n | End\n | More of 'a * 'a tree * ('a, 'direction) t\n\n let rec cons s (e : (_, increasing) t) : (_, increasing) t =\n match s with\n | Empty -> e\n | Leaf v -> More (v, Empty, e)\n | Node (l, v, r, _, _) -> cons l (More (v, r, e))\n ;;\n\n let rec cons_right s (e : (_, decreasing) t) : (_, decreasing) t =\n match s with\n | Empty -> e\n | Leaf v -> More (v, Empty, e)\n | Node (l, v, r, _, _) -> cons_right r (More (v, l, e))\n ;;\n\n let of_set s : (_, increasing) t = cons s End\n let of_set_right s : (_, decreasing) t = cons_right s End\n\n let starting_at_increasing t key compare : (_, increasing) t =\n let rec loop t e =\n match t with\n | Empty -> e\n | Leaf v -> loop (Node (Empty, v, Empty, 1, 1)) e\n | Node (_, v, r, _, _) when compare v key < 0 -> loop r e\n | Node (l, v, r, _, _) -> loop l (More (v, r, e))\n in\n loop t End\n ;;\n\n let starting_at_decreasing t key compare : (_, decreasing) t =\n let rec loop t e =\n match t with\n | Empty -> e\n | Leaf v -> loop (Node (Empty, v, Empty, 1, 1)) e\n | Node (l, v, _, _, _) when compare v key > 0 -> loop l e\n | Node (l, v, r, _, _) -> loop r (More (v, l, e))\n in\n loop t End\n ;;\n\n let compare compare_elt e1 e2 =\n let rec loop e1 e2 =\n match e1, e2 with\n | End, End -> 0\n | End, _ -> -1\n | _, End -> 1\n | More (v1, r1, e1), More (v2, r2, e2) ->\n let c = compare_elt v1 v2 in\n if c <> 0\n then c\n else if phys_equal r1 r2\n then loop e1 e2\n else loop (cons r1 e1) (cons r2 e2)\n in\n loop e1 e2\n ;;\n\n let rec iter ~f = function\n | End -> ()\n | More (a, tree, enum) ->\n f a;\n iter (cons tree enum) ~f\n ;;\n\n let iter2 compare_elt t1 t2 ~f =\n let rec loop t1 t2 =\n match t1, t2 with\n | End, End -> ()\n | End, _ -> iter t2 ~f:(fun a -> f (`Right a))\n | _, End -> iter t1 ~f:(fun a -> f (`Left a))\n | More (a1, tree1, enum1), More (a2, tree2, enum2) ->\n let compare_result = compare_elt a1 a2 in\n if compare_result = 0\n then (\n f (`Both (a1, a2));\n loop (cons tree1 enum1) (cons tree2 enum2))\n else if compare_result < 0\n then (\n f (`Left a1);\n loop (cons tree1 enum1) t2)\n else (\n f (`Right a2);\n loop t1 (cons tree2 enum2))\n in\n loop t1 t2\n ;;\n\n let symmetric_diff t1 t2 ~compare_elt =\n let step state : ((_, _) Either.t, _) Sequence.Step.t =\n match state with\n | End, End -> Done\n | End, More (elt, tree, enum) -> Yield (Second elt, (End, cons tree enum))\n | More (elt, tree, enum), End -> Yield (First elt, (cons tree enum, End))\n | (More (a1, tree1, enum1) as left), (More (a2, tree2, enum2) as right) ->\n let compare_result = compare_elt a1 a2 in\n if compare_result = 0\n then (\n let next_state =\n if phys_equal tree1 tree2\n then enum1, enum2\n else cons tree1 enum1, cons tree2 enum2\n in\n Skip next_state)\n else if compare_result < 0\n then Yield (First a1, (cons tree1 enum1, right))\n else Yield (Second a2, (left, cons tree2 enum2))\n in\n Sequence.unfold_step ~init:(of_set t1, of_set t2) ~f:step\n ;;\n end\n\n let to_sequence_increasing comparator ~from_elt t =\n let next enum =\n match enum with\n | Enum.End -> Sequence.Step.Done\n | Enum.More (k, t, e) -> Sequence.Step.Yield (k, Enum.cons t e)\n in\n let init =\n match from_elt with\n | None -> Enum.of_set t\n | Some key -> Enum.starting_at_increasing t key comparator.Comparator.compare\n in\n Sequence.unfold_step ~init ~f:next\n ;;\n\n let to_sequence_decreasing comparator ~from_elt t =\n let next enum =\n match enum with\n | Enum.End -> Sequence.Step.Done\n | Enum.More (k, t, e) -> Sequence.Step.Yield (k, Enum.cons_right t e)\n in\n let init =\n match from_elt with\n | None -> Enum.of_set_right t\n | Some key -> Enum.starting_at_decreasing t key comparator.Comparator.compare\n in\n Sequence.unfold_step ~init ~f:next\n ;;\n\n let to_sequence\n comparator\n ?(order = `Increasing)\n ?greater_or_equal_to\n ?less_or_equal_to\n t\n =\n let inclusive_bound side t bound =\n let compare_elt = comparator.Comparator.compare in\n let l, maybe, r = split t bound ~compare_elt in\n let t = side (l, r) in\n match maybe with\n | None -> t\n | Some elt -> add t elt ~compare_elt\n in\n match order with\n | `Increasing ->\n let t = Option.fold less_or_equal_to ~init:t ~f:(inclusive_bound fst) in\n to_sequence_increasing comparator ~from_elt:greater_or_equal_to t\n | `Decreasing ->\n let t = Option.fold greater_or_equal_to ~init:t ~f:(inclusive_bound snd) in\n to_sequence_decreasing comparator ~from_elt:less_or_equal_to t\n ;;\n\n\n let rec find_first_satisfying t ~f =\n match t with\n | Empty -> None\n | Leaf v -> if f v then Some v else None\n | Node (l, v, r, _, _) ->\n if f v\n then (\n match find_first_satisfying l ~f with\n | None -> Some v\n | Some _ as x -> x)\n else find_first_satisfying r ~f\n ;;\n\n let rec find_last_satisfying t ~f =\n match t with\n | Empty -> None\n | Leaf v -> if f v then Some v else None\n | Node (l, v, r, _, _) ->\n if f v\n then (\n match find_last_satisfying r ~f with\n | None -> Some v\n | Some _ as x -> x)\n else find_last_satisfying l ~f\n ;;\n\n let binary_search t ~compare how v =\n match how with\n | `Last_strictly_less_than -> find_last_satisfying t ~f:(fun x -> compare x v < 0)\n | `Last_less_than_or_equal_to ->\n find_last_satisfying t ~f:(fun x -> compare x v <= 0)\n | `First_equal_to ->\n (match find_first_satisfying t ~f:(fun x -> compare x v >= 0) with\n | Some x as elt when compare x v = 0 -> elt\n | None | Some _ -> None)\n | `Last_equal_to ->\n (match find_last_satisfying t ~f:(fun x -> compare x v <= 0) with\n | Some x as elt when compare x v = 0 -> elt\n | None | Some _ -> None)\n | `First_greater_than_or_equal_to ->\n find_first_satisfying t ~f:(fun x -> compare x v >= 0)\n | `First_strictly_greater_than ->\n find_first_satisfying t ~f:(fun x -> compare x v > 0)\n ;;\n\n let binary_search_segmented t ~segment_of how =\n let is_left x =\n match segment_of x with\n | `Left -> true\n | `Right -> false\n in\n let is_right x = not (is_left x) in\n match how with\n | `Last_on_left -> find_last_satisfying t ~f:is_left\n | `First_on_right -> find_first_satisfying t ~f:is_right\n ;;\n\n let merge_to_sequence\n comparator\n ?(order = `Increasing)\n ?greater_or_equal_to\n ?less_or_equal_to\n t\n t'\n =\n Sequence.merge_with_duplicates\n (to_sequence comparator ~order ?greater_or_equal_to ?less_or_equal_to t)\n (to_sequence comparator ~order ?greater_or_equal_to ?less_or_equal_to t')\n ~compare:\n (match order with\n | `Increasing -> comparator.compare\n | `Decreasing -> Fn.flip comparator.compare)\n ;;\n\n let compare compare_elt s1 s2 =\n Enum.compare compare_elt (Enum.of_set s1) (Enum.of_set s2)\n ;;\n\n let iter2 s1 s2 ~compare_elt = Enum.iter2 compare_elt (Enum.of_set s1) (Enum.of_set s2)\n let equal s1 s2 ~compare_elt = compare compare_elt s1 s2 = 0\n\n let is_subset s1 ~of_:s2 ~compare_elt =\n let rec is_subset s1 ~of_:s2 =\n match s1, s2 with\n | Empty, _ -> true\n | _, Empty -> false\n | Leaf v1, t2 -> mem t2 v1 ~compare_elt\n | Node (l1, v1, r1, _, _), Leaf v2 ->\n (match l1, r1 with\n | Empty, Empty ->\n (* This case shouldn't occur in practice because we should have constructed\n a Leaf rather than a Node with two Empty subtrees *)\n compare_elt v1 v2 = 0\n | _, _ -> false)\n | Node (l1, v1, r1, _, _), (Node (l2, v2, r2, _, _) as t2) ->\n let c = compare_elt v1 v2 in\n if c = 0\n then\n phys_equal s1 s2 || (is_subset l1 ~of_:l2 && is_subset r1 ~of_:r2)\n (* Note that height and size don't matter here. *)\n else if c < 0\n then is_subset (Node (l1, v1, Empty, 0, 0)) ~of_:l2 && is_subset r1 ~of_:t2\n else is_subset (Node (Empty, v1, r1, 0, 0)) ~of_:r2 && is_subset l1 ~of_:t2\n in\n is_subset s1 ~of_:s2\n ;;\n\n let rec are_disjoint s1 s2 ~compare_elt =\n match s1, s2 with\n | Empty, _ | _, Empty -> true\n | Leaf elt, other_set | other_set, Leaf elt -> not (mem other_set elt ~compare_elt)\n | Node (l1, v1, r1, _, _), t2 ->\n if phys_equal s1 s2\n then false\n else (\n match split t2 v1 ~compare_elt with\n | l2, None, r2 ->\n are_disjoint l1 l2 ~compare_elt && are_disjoint r1 r2 ~compare_elt\n | _, Some _, _ -> false)\n ;;\n\n let iter t ~f =\n let rec iter = function\n | Empty -> ()\n | Leaf v -> f v\n | Node (l, v, r, _, _) ->\n iter l;\n f v;\n iter r\n in\n iter t\n ;;\n\n let symmetric_diff = Enum.symmetric_diff\n\n let rec fold s ~init:accu ~f =\n match s with\n | Empty -> accu\n | Leaf v -> f accu v\n | Node (l, v, r, _, _) -> fold ~f r ~init:(f (fold ~f l ~init:accu) v)\n ;;\n\n let hash_fold_t_ignoring_structure hash_fold_elem state t =\n fold t ~init:(hash_fold_int state (length t)) ~f:hash_fold_elem\n ;;\n\n let count t ~f = Container.count ~fold t ~f\n let sum m t ~f = Container.sum ~fold m t ~f\n\n let rec fold_right s ~init:accu ~f =\n match s with\n | Empty -> accu\n | Leaf v -> f v accu\n | Node (l, v, r, _, _) -> fold_right ~f l ~init:(f v (fold_right ~f r ~init:accu))\n ;;\n\n let rec for_all t ~f:p =\n match t with\n | Empty -> true\n | Leaf v -> p v\n | Node (l, v, r, _, _) -> p v && for_all ~f:p l && for_all ~f:p r\n ;;\n\n let rec exists t ~f:p =\n match t with\n | Empty -> false\n | Leaf v -> p v\n | Node (l, v, r, _, _) -> p v || exists ~f:p l || exists ~f:p r\n ;;\n\n let filter s ~f:p ~compare_elt =\n let rec filt accu = function\n | Empty -> accu\n | Leaf v -> if p v then add accu v ~compare_elt else accu\n | Node (l, v, r, _, _) ->\n filt (filt (if p v then add accu v ~compare_elt else accu) l) r\n in\n filt Empty s\n ;;\n\n let filter_map s ~f:p ~compare_elt =\n let rec filt accu = function\n | Empty -> accu\n | Leaf v ->\n (match p v with\n | None -> accu\n | Some v -> add accu v ~compare_elt)\n | Node (l, v, r, _, _) ->\n filt\n (filt\n (match p v with\n | None -> accu\n | Some v -> add accu v ~compare_elt)\n l)\n r\n in\n filt Empty s\n ;;\n\n let partition_tf s ~f:p ~compare_elt =\n let rec part ((t, f) as accu) = function\n | Empty -> accu\n | Leaf v -> if p v then add t v ~compare_elt, f else t, add f v ~compare_elt\n | Node (l, v, r, _, _) ->\n part\n (part (if p v then add t v ~compare_elt, f else t, add f v ~compare_elt) l)\n r\n in\n part (Empty, Empty) s\n ;;\n\n let rec elements_aux accu = function\n | Empty -> accu\n | Leaf v -> v :: accu\n | Node (l, v, r, _, _) -> elements_aux (v :: elements_aux accu r) l\n ;;\n\n let elements s = elements_aux [] s\n\n let choose t =\n match t with\n | Empty -> None\n | Leaf v -> Some v\n | Node (_, v, _, _, _) -> Some v\n ;;\n\n let choose_exn =\n let not_found = Not_found_s (Atom \"Set.choose_exn: empty set\") in\n let choose_exn t =\n match choose t with\n | None -> raise not_found\n | Some v -> v\n in\n (* named to preserve symbol in compiled binary *)\n choose_exn\n ;;\n\n let of_list lst ~compare_elt =\n List.fold lst ~init:empty ~f:(fun t x -> add t x ~compare_elt)\n ;;\n\n let to_list s = elements s\n\n let of_array a ~compare_elt =\n Array.fold a ~init:empty ~f:(fun t x -> add t x ~compare_elt)\n ;;\n\n (* faster but equivalent to [Array.of_list (to_list t)] *)\n let to_array = function\n | Empty -> [||]\n | Leaf v -> [| v |]\n | Node (l, v, r, _, s) ->\n let res = Array.create ~len:s v in\n let pos_ref = ref 0 in\n let rec loop = function\n (* Invariant: on entry and on exit to [loop], !pos_ref is the next\n available cell in the array. *)\n | Empty -> ()\n | Leaf v ->\n res.(!pos_ref) <- v;\n incr pos_ref\n | Node (l, v, r, _, _) ->\n loop l;\n res.(!pos_ref) <- v;\n incr pos_ref;\n loop r\n in\n loop l;\n (* res.(!pos_ref) is already initialized (by Array.create ~len:above). *)\n incr pos_ref;\n loop r;\n res\n ;;\n\n let map t ~f ~compare_elt = fold t ~init:empty ~f:(fun t x -> add t (f x) ~compare_elt)\n\n let group_by set ~equiv ~compare_elt =\n let rec loop set equiv_classes =\n if is_empty set\n then equiv_classes\n else (\n let x = choose_exn set in\n let equiv_x, not_equiv_x =\n partition_tf set ~f:(fun elt -> phys_equal x elt || equiv x elt) ~compare_elt\n in\n loop not_equiv_x (equiv_x :: equiv_classes))\n in\n loop set []\n ;;\n\n let rec find t ~f =\n match t with\n | Empty -> None\n | Leaf v -> if f v then Some v else None\n | Node (l, v, r, _, _) ->\n if f v\n then Some v\n else (\n match find l ~f with\n | None -> find r ~f\n | Some _ as r -> r)\n ;;\n\n let rec find_map t ~f =\n match t with\n | Empty -> None\n | Leaf v -> f v\n | Node (l, v, r, _, _) ->\n (match f v with\n | Some _ as r -> r\n | None ->\n (match find_map l ~f with\n | None -> find_map r ~f\n | Some _ as r -> r))\n ;;\n\n let find_exn t ~f =\n match find t ~f with\n | None -> failwith \"Set.find_exn failed to find a matching element\"\n | Some e -> e\n ;;\n\n let rec nth t i =\n match t with\n | Empty -> None\n | Leaf v -> if i = 0 then Some v else None\n | Node (l, v, r, _, s) ->\n if i >= s\n then None\n else (\n let l_size = length l in\n let c = Poly.compare i l_size in\n if c < 0 then nth l i else if c = 0 then Some v else nth r (i - l_size - 1))\n ;;\n\n let stable_dedup_list xs ~compare_elt =\n let rec loop xs leftovers already_seen =\n match xs with\n | [] -> List.rev leftovers\n | hd :: tl ->\n if mem already_seen hd ~compare_elt\n then loop tl leftovers already_seen\n else loop tl (hd :: leftovers) (add already_seen hd ~compare_elt)\n in\n loop xs [] empty\n ;;\n\n let t_of_sexp_direct a_of_sexp sexp ~compare_elt =\n match sexp with\n | Sexp.List lst ->\n let elt_lst = List.map lst ~f:a_of_sexp in\n let set = of_list elt_lst ~compare_elt in\n if length set = List.length lst\n then set\n else (\n let set = ref empty in\n List.iter2_exn lst elt_lst ~f:(fun el_sexp el ->\n if mem !set el ~compare_elt\n then of_sexp_error \"Set.t_of_sexp: duplicate element in set\" el_sexp\n else set := add !set el ~compare_elt);\n assert false)\n | sexp -> of_sexp_error \"Set.t_of_sexp: list needed\" sexp\n ;;\n\n let sexp_of_t sexp_of_a t =\n Sexp.List (fold_right t ~init:[] ~f:(fun el acc -> sexp_of_a el :: acc))\n ;;\n\n module Named = struct\n type nonrec ('a, 'cmp) t =\n { tree : 'a t\n ; name : string\n }\n\n let is_subset (subset : _ t) ~of_:(superset : _ t) ~sexp_of_elt ~compare_elt =\n let invalid_elements = diff subset.tree superset.tree ~compare_elt in\n if is_empty invalid_elements\n then Ok ()\n else (\n let invalid_elements_sexp = sexp_of_t sexp_of_elt invalid_elements in\n Or_error.error_s\n (Sexp.message\n (subset.name ^ \" is not a subset of \" ^ superset.name)\n [ \"invalid_elements\", invalid_elements_sexp ]))\n ;;\n\n let equal s1 s2 ~sexp_of_elt ~compare_elt =\n Or_error.combine_errors_unit\n [ is_subset s1 ~of_:s2 ~sexp_of_elt ~compare_elt\n ; is_subset s2 ~of_:s1 ~sexp_of_elt ~compare_elt\n ]\n ;;\n end\nend\n\ntype ('a, 'comparator) t =\n { (* [comparator] is the first field so that polymorphic equality fails on a map due\n to the functional value in the comparator.\n Note that this does not affect polymorphic [compare]: that still produces\n nonsense. *)\n comparator : ('a, 'comparator) Comparator.t\n ; tree : 'a Tree0.t\n }\n\ntype ('a, 'comparator) tree = 'a Tree0.t\n\nlet like { tree = _; comparator } tree = { tree; comparator }\nlet compare_elt t = t.comparator.Comparator.compare\n\nmodule Accessors = struct\n let comparator t = t.comparator\n let invariants t = Tree0.invariants t.tree ~compare_elt:(compare_elt t)\n let length t = Tree0.length t.tree\n let is_empty t = Tree0.is_empty t.tree\n let elements t = Tree0.elements t.tree\n let min_elt t = Tree0.min_elt t.tree\n let min_elt_exn t = Tree0.min_elt_exn t.tree\n let max_elt t = Tree0.max_elt t.tree\n let max_elt_exn t = Tree0.max_elt_exn t.tree\n let choose t = Tree0.choose t.tree\n let choose_exn t = Tree0.choose_exn t.tree\n let to_list t = Tree0.to_list t.tree\n let to_array t = Tree0.to_array t.tree\n let fold t ~init ~f = Tree0.fold t.tree ~init ~f\n let fold_until t ~init ~f = Tree0.fold_until t.tree ~init ~f\n let fold_right t ~init ~f = Tree0.fold_right t.tree ~init ~f\n let fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\n let iter t ~f = Tree0.iter t.tree ~f\n let iter2 a b ~f = Tree0.iter2 a.tree b.tree ~f ~compare_elt:(compare_elt a)\n let exists t ~f = Tree0.exists t.tree ~f\n let for_all t ~f = Tree0.for_all t.tree ~f\n let count t ~f = Tree0.count t.tree ~f\n let sum m t ~f = Tree0.sum m t.tree ~f\n let find t ~f = Tree0.find t.tree ~f\n let find_exn t ~f = Tree0.find_exn t.tree ~f\n let find_map t ~f = Tree0.find_map t.tree ~f\n let mem t a = Tree0.mem t.tree a ~compare_elt:(compare_elt t)\n let filter t ~f = like t (Tree0.filter t.tree ~f ~compare_elt:(compare_elt t))\n let add t a = like t (Tree0.add t.tree a ~compare_elt:(compare_elt t))\n let remove t a = like t (Tree0.remove t.tree a ~compare_elt:(compare_elt t))\n let union t1 t2 = like t1 (Tree0.union t1.tree t2.tree ~compare_elt:(compare_elt t1))\n let inter t1 t2 = like t1 (Tree0.inter t1.tree t2.tree ~compare_elt:(compare_elt t1))\n let diff t1 t2 = like t1 (Tree0.diff t1.tree t2.tree ~compare_elt:(compare_elt t1))\n\n let symmetric_diff t1 t2 =\n Tree0.symmetric_diff t1.tree t2.tree ~compare_elt:(compare_elt t1)\n ;;\n\n let compare_direct t1 t2 = Tree0.compare (compare_elt t1) t1.tree t2.tree\n let equal t1 t2 = Tree0.equal t1.tree t2.tree ~compare_elt:(compare_elt t1)\n\n let is_subset t ~of_ =\n Tree0.is_subset t.tree ~of_:of_.tree ~compare_elt:(compare_elt t)\n ;;\n\n let are_disjoint t1 t2 =\n Tree0.are_disjoint t1.tree t2.tree ~compare_elt:(compare_elt t1)\n ;;\n\n module Named = struct\n type nonrec ('a, 'cmp) t =\n { set : ('a, 'cmp) t\n ; name : string\n }\n\n let to_named_tree { set; name } = { Tree0.Named.tree = set.tree; name }\n\n let is_subset (subset : (_, _) t) ~of_:(superset : (_, _) t) =\n Tree0.Named.is_subset\n (to_named_tree subset)\n ~of_:(to_named_tree superset)\n ~compare_elt:(compare_elt subset.set)\n ~sexp_of_elt:subset.set.comparator.sexp_of_t\n ;;\n\n let equal t1 t2 =\n Or_error.combine_errors_unit [ is_subset t1 ~of_:t2; is_subset t2 ~of_:t1 ]\n ;;\n end\n\n let partition_tf t ~f =\n let tree_t, tree_f = Tree0.partition_tf t.tree ~f ~compare_elt:(compare_elt t) in\n like t tree_t, like t tree_f\n ;;\n\n let split t a =\n let tree1, b, tree2 = Tree0.split t.tree a ~compare_elt:(compare_elt t) in\n like t tree1, b, like t tree2\n ;;\n\n let group_by t ~equiv =\n List.map (Tree0.group_by t.tree ~equiv ~compare_elt:(compare_elt t)) ~f:(like t)\n ;;\n\n let nth t i = Tree0.nth t.tree i\n\n let remove_index t i =\n like t (Tree0.remove_index t.tree i ~compare_elt:(compare_elt t))\n ;;\n\n let sexp_of_t sexp_of_a _ t = Tree0.sexp_of_t sexp_of_a t.tree\n\n let to_sequence ?order ?greater_or_equal_to ?less_or_equal_to t =\n Tree0.to_sequence t.comparator ?order ?greater_or_equal_to ?less_or_equal_to t.tree\n ;;\n\n let binary_search t ~compare how v = Tree0.binary_search t.tree ~compare how v\n\n let binary_search_segmented t ~segment_of how =\n Tree0.binary_search_segmented t.tree ~segment_of how\n ;;\n\n let merge_to_sequence ?order ?greater_or_equal_to ?less_or_equal_to t t' =\n Tree0.merge_to_sequence\n t.comparator\n ?order\n ?greater_or_equal_to\n ?less_or_equal_to\n t.tree\n t'.tree\n ;;\n\n let hash_fold_direct hash_fold_key state t =\n Tree0.hash_fold_t_ignoring_structure hash_fold_key state t.tree\n ;;\nend\n\ninclude Accessors\n\nlet compare _ _ t1 t2 = compare_direct t1 t2\n\nmodule Tree = struct\n type ('a, 'comparator) t = ('a, 'comparator) tree\n\n let ce comparator = comparator.Comparator.compare\n\n let t_of_sexp_direct ~comparator a_of_sexp sexp =\n Tree0.t_of_sexp_direct ~compare_elt:(ce comparator) a_of_sexp sexp\n ;;\n\n let empty_without_value_restriction = Tree0.empty\n let empty ~comparator:_ = empty_without_value_restriction\n let singleton ~comparator:_ e = Tree0.singleton e\n let length t = Tree0.length t\n let invariants ~comparator t = Tree0.invariants t ~compare_elt:(ce comparator)\n let is_empty t = Tree0.is_empty t\n let elements t = Tree0.elements t\n let min_elt t = Tree0.min_elt t\n let min_elt_exn t = Tree0.min_elt_exn t\n let max_elt t = Tree0.max_elt t\n let max_elt_exn t = Tree0.max_elt_exn t\n let choose t = Tree0.choose t\n let choose_exn t = Tree0.choose_exn t\n let to_list t = Tree0.to_list t\n let to_array t = Tree0.to_array t\n let iter t ~f = Tree0.iter t ~f\n let exists t ~f = Tree0.exists t ~f\n let for_all t ~f = Tree0.for_all t ~f\n let count t ~f = Tree0.count t ~f\n let sum m t ~f = Tree0.sum m t ~f\n let find t ~f = Tree0.find t ~f\n let find_exn t ~f = Tree0.find_exn t ~f\n let find_map t ~f = Tree0.find_map t ~f\n let fold t ~init ~f = Tree0.fold t ~init ~f\n let fold_until t ~init ~f = Tree0.fold_until t ~init ~f\n let fold_right t ~init ~f = Tree0.fold_right t ~init ~f\n let map ~comparator t ~f = Tree0.map t ~f ~compare_elt:(ce comparator)\n let filter ~comparator t ~f = Tree0.filter t ~f ~compare_elt:(ce comparator)\n let filter_map ~comparator t ~f = Tree0.filter_map t ~f ~compare_elt:(ce comparator)\n\n let partition_tf ~comparator t ~f =\n Tree0.partition_tf t ~f ~compare_elt:(ce comparator)\n ;;\n\n let iter2 ~comparator a b ~f = Tree0.iter2 a b ~f ~compare_elt:(ce comparator)\n let mem ~comparator t a = Tree0.mem t a ~compare_elt:(ce comparator)\n let add ~comparator t a = Tree0.add t a ~compare_elt:(ce comparator)\n let remove ~comparator t a = Tree0.remove t a ~compare_elt:(ce comparator)\n let union ~comparator t1 t2 = Tree0.union t1 t2 ~compare_elt:(ce comparator)\n let inter ~comparator t1 t2 = Tree0.inter t1 t2 ~compare_elt:(ce comparator)\n let diff ~comparator t1 t2 = Tree0.diff t1 t2 ~compare_elt:(ce comparator)\n\n let symmetric_diff ~comparator t1 t2 =\n Tree0.symmetric_diff t1 t2 ~compare_elt:(ce comparator)\n ;;\n\n let compare_direct ~comparator t1 t2 = Tree0.compare (ce comparator) t1 t2\n let equal ~comparator t1 t2 = Tree0.equal t1 t2 ~compare_elt:(ce comparator)\n let is_subset ~comparator t ~of_ = Tree0.is_subset t ~of_ ~compare_elt:(ce comparator)\n\n let are_disjoint ~comparator t1 t2 =\n Tree0.are_disjoint t1 t2 ~compare_elt:(ce comparator)\n ;;\n\n let of_list ~comparator l = Tree0.of_list l ~compare_elt:(ce comparator)\n let of_array ~comparator a = Tree0.of_array a ~compare_elt:(ce comparator)\n\n let of_sorted_array_unchecked ~comparator a =\n Tree0.of_sorted_array_unchecked a ~compare_elt:(ce comparator)\n ;;\n\n let of_increasing_iterator_unchecked ~comparator:_ ~len ~f =\n Tree0.of_increasing_iterator_unchecked ~len ~f\n ;;\n\n let of_sorted_array ~comparator a =\n Tree0.of_sorted_array a ~compare_elt:(ce comparator)\n ;;\n\n let union_list ~comparator l = Tree0.union_list l ~to_tree:Fn.id ~comparator\n\n let stable_dedup_list ~comparator xs =\n Tree0.stable_dedup_list xs ~compare_elt:(ce comparator)\n ;;\n\n let group_by ~comparator t ~equiv =\n Tree0.group_by t ~equiv ~compare_elt:(ce comparator)\n ;;\n\n let split ~comparator t a = Tree0.split t a ~compare_elt:(ce comparator)\n let nth t i = Tree0.nth t i\n let remove_index ~comparator t i = Tree0.remove_index t i ~compare_elt:(ce comparator)\n let sexp_of_t sexp_of_a _ t = Tree0.sexp_of_t sexp_of_a t\n let to_tree t = t\n let of_tree ~comparator:_ t = t\n\n let to_sequence ~comparator ?order ?greater_or_equal_to ?less_or_equal_to t =\n Tree0.to_sequence comparator ?order ?greater_or_equal_to ?less_or_equal_to t\n ;;\n\n let binary_search ~comparator:_ t ~compare how v = Tree0.binary_search t ~compare how v\n\n let binary_search_segmented ~comparator:_ t ~segment_of how =\n Tree0.binary_search_segmented t ~segment_of how\n ;;\n\n let merge_to_sequence ~comparator ?order ?greater_or_equal_to ?less_or_equal_to t t' =\n Tree0.merge_to_sequence comparator ?order ?greater_or_equal_to ?less_or_equal_to t t'\n ;;\n\n let fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\n\n module Named = struct\n include Tree0.Named\n\n let is_subset ~comparator t1 ~of_:t2 =\n Tree0.Named.is_subset\n t1\n ~of_:t2\n ~compare_elt:(ce comparator)\n ~sexp_of_elt:comparator.Comparator.sexp_of_t\n ;;\n\n let equal ~comparator t1 t2 =\n Tree0.Named.equal\n t1\n t2\n ~compare_elt:(ce comparator)\n ~sexp_of_elt:comparator.Comparator.sexp_of_t\n ;;\n end\nend\n\nmodule Using_comparator = struct\n type nonrec ('elt, 'cmp) t = ('elt, 'cmp) t\n\n include Accessors\n\n let to_tree t = t.tree\n let of_tree ~comparator tree = { comparator; tree }\n\n let t_of_sexp_direct ~comparator a_of_sexp sexp =\n of_tree\n ~comparator\n (Tree0.t_of_sexp_direct ~compare_elt:comparator.compare a_of_sexp sexp)\n ;;\n\n let empty ~comparator = { comparator; tree = Tree0.empty }\n\n module Empty_without_value_restriction (Elt : Comparator.S1) = struct\n let empty = { comparator = Elt.comparator; tree = Tree0.empty }\n end\n\n let singleton ~comparator e = { comparator; tree = Tree0.singleton e }\n\n let union_list ~comparator l =\n of_tree ~comparator (Tree0.union_list ~comparator ~to_tree l)\n ;;\n\n let of_sorted_array_unchecked ~comparator array =\n let tree =\n Tree0.of_sorted_array_unchecked array ~compare_elt:comparator.Comparator.compare\n in\n { comparator; tree }\n ;;\n\n let of_increasing_iterator_unchecked ~comparator ~len ~f =\n of_tree ~comparator (Tree0.of_increasing_iterator_unchecked ~len ~f)\n ;;\n\n let of_sorted_array ~comparator array =\n Or_error.Monad_infix.(\n Tree0.of_sorted_array array ~compare_elt:comparator.Comparator.compare\n >>| fun tree -> { comparator; tree })\n ;;\n\n let of_list ~comparator l =\n { comparator; tree = Tree0.of_list l ~compare_elt:comparator.Comparator.compare }\n ;;\n\n let of_array ~comparator a =\n { comparator; tree = Tree0.of_array a ~compare_elt:comparator.Comparator.compare }\n ;;\n\n let stable_dedup_list ~comparator xs =\n Tree0.stable_dedup_list xs ~compare_elt:comparator.Comparator.compare\n ;;\n\n let map ~comparator t ~f =\n { comparator; tree = Tree0.map t.tree ~f ~compare_elt:comparator.Comparator.compare }\n ;;\n\n let filter_map ~comparator t ~f =\n { comparator\n ; tree = Tree0.filter_map t.tree ~f ~compare_elt:comparator.Comparator.compare\n }\n ;;\n\n module Tree = Tree\nend\n\ntype ('elt, 'cmp) comparator =\n (module Comparator.S with type t = 'elt and type comparator_witness = 'cmp)\n\nlet comparator_s (type k cmp) t : (k, cmp) comparator =\n (module struct\n type t = k\n type comparator_witness = cmp\n\n let comparator = t.comparator\n end)\n;;\n\nlet to_comparator (type elt cmp) ((module M) : (elt, cmp) comparator) = M.comparator\nlet empty m = Using_comparator.empty ~comparator:(to_comparator m)\nlet singleton m a = Using_comparator.singleton ~comparator:(to_comparator m) a\nlet union_list m a = Using_comparator.union_list ~comparator:(to_comparator m) a\n\nlet of_sorted_array_unchecked m a =\n Using_comparator.of_sorted_array_unchecked ~comparator:(to_comparator m) a\n;;\n\nlet of_increasing_iterator_unchecked m ~len ~f =\n Using_comparator.of_increasing_iterator_unchecked ~comparator:(to_comparator m) ~len ~f\n;;\n\nlet of_sorted_array m a =\n Using_comparator.of_sorted_array ~comparator:(to_comparator m) a\n;;\n\nlet of_list m a = Using_comparator.of_list ~comparator:(to_comparator m) a\nlet of_array m a = Using_comparator.of_array ~comparator:(to_comparator m) a\n\nlet stable_dedup_list m a =\n Using_comparator.stable_dedup_list ~comparator:(to_comparator m) a\n;;\n\nlet map m a ~f = Using_comparator.map ~comparator:(to_comparator m) a ~f\nlet filter_map m a ~f = Using_comparator.filter_map ~comparator:(to_comparator m) a ~f\n\nmodule M (Elt : sig\n type t\n type comparator_witness\n end) =\nstruct\n type nonrec t = (Elt.t, Elt.comparator_witness) t\nend\n\nmodule type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\nend\n\nmodule type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Comparator.S with type t := t\nend\n\nmodule type Compare_m = sig end\nmodule type Equal_m = sig end\nmodule type Hash_fold_m = Hasher.S\n\nlet sexp_of_m__t (type elt) (module Elt : Sexp_of_m with type t = elt) t =\n sexp_of_t Elt.sexp_of_t (fun _ -> Sexp.Atom \"_\") t\n;;\n\nlet m__t_of_sexp\n (type elt cmp)\n (module Elt : M_of_sexp with type t = elt and type comparator_witness = cmp)\n sexp\n =\n Using_comparator.t_of_sexp_direct ~comparator:Elt.comparator Elt.t_of_sexp sexp\n;;\n\nlet compare_m__t (module Elt : Compare_m) t1 t2 = compare_direct t1 t2\nlet equal_m__t (module Elt : Equal_m) t1 t2 = equal t1 t2\n\nlet hash_fold_m__t (type elt) (module Elt : Hash_fold_m with type t = elt) state =\n hash_fold_direct Elt.hash_fold_t state\n;;\n\nlet hash_m__t folder t =\n let state = hash_fold_m__t folder (Hash.create ()) t in\n Hash.get_hash_value state\n;;\n\nmodule Poly = struct\n type comparator_witness = Comparator.Poly.comparator_witness\n type nonrec ('elt, 'cmp) set = ('elt, comparator_witness) t\n type nonrec 'elt t = ('elt, comparator_witness) t\n type nonrec 'elt tree = ('elt, comparator_witness) tree\n type nonrec 'elt named = ('elt, comparator_witness) Named.t\n\n include Accessors\n\n let comparator = Comparator.Poly.comparator\n\n include Using_comparator.Empty_without_value_restriction (Comparator.Poly)\n\n let singleton a = Using_comparator.singleton ~comparator a\n let union_list a = Using_comparator.union_list ~comparator a\n\n let of_sorted_array_unchecked a =\n Using_comparator.of_sorted_array_unchecked ~comparator a\n ;;\n\n let of_increasing_iterator_unchecked ~len ~f =\n Using_comparator.of_increasing_iterator_unchecked ~comparator ~len ~f\n ;;\n\n let of_sorted_array a = Using_comparator.of_sorted_array ~comparator a\n let of_list a = Using_comparator.of_list ~comparator a\n let of_array a = Using_comparator.of_array ~comparator a\n let stable_dedup_list a = Using_comparator.stable_dedup_list ~comparator a\n let map a ~f = Using_comparator.map ~comparator a ~f\n let filter_map a ~f = Using_comparator.filter_map ~comparator a ~f\n let of_tree tree = { comparator; tree }\n let to_tree t = t.tree\nend\n","open! Import\nopen! T\n\nmodule type Elt_plain = sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\nend\n\nmodule Without_comparator = Map_intf.Without_comparator\nmodule With_comparator = Map_intf.With_comparator\nmodule With_first_class_module = Map_intf.With_first_class_module\ninclude Container_intf.Export\nmodule Merge_to_sequence_element = Sequence.Merge_with_duplicates_element\n\nmodule type Accessors_generic = sig\n include Container.Generic_phantom\n\n type ('a, 'cmp) tree\n\n (** The [options] type is used to make [Accessors_generic] flexible as to whether a\n comparator is required to be passed to certain functions. *)\n type ('a, 'cmp, 'z) options\n\n type 'cmp cmp\n\n val invariants : ('a, 'cmp, ('a, 'cmp) t -> bool) options\n\n (** override [Container]'s [mem] *)\n val mem : ('a, 'cmp, ('a, 'cmp) t -> 'a elt -> bool) options\n\n val add : ('a, 'cmp, ('a, 'cmp) t -> 'a elt -> ('a, 'cmp) t) options\n val remove : ('a, 'cmp, ('a, 'cmp) t -> 'a elt -> ('a, 'cmp) t) options\n val union : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t) options\n val inter : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t) options\n val diff : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t) options\n\n val symmetric_diff\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t -> ('a, 'cmp) t -> ('a elt, 'a elt) Either.t Sequence.t )\n options\n\n val compare_direct : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> int) options\n val equal : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> bool) options\n val is_subset : ('a, 'cmp, ('a, 'cmp) t -> of_:('a, 'cmp) t -> bool) options\n val are_disjoint : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> bool) options\n\n type ('a, 'cmp) named\n\n module Named : sig\n val is_subset\n : ('a, 'cmp, ('a, 'cmp) named -> of_:('a, 'cmp) named -> unit Or_error.t) options\n\n val equal\n : ('a, 'cmp, ('a, 'cmp) named -> ('a, 'cmp) named -> unit Or_error.t) options\n end\n\n val fold_until\n : ('a, _) t\n -> init:'b\n -> f:('b -> 'a elt -> ('b, 'final) Continue_or_stop.t)\n -> finish:('b -> 'final)\n -> 'final\n\n val fold_right : ('a, _) t -> init:'b -> f:('a elt -> 'b -> 'b) -> 'b\n\n val iter2\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> f:([ `Left of 'a elt | `Right of 'a elt | `Both of 'a elt * 'a elt ] -> unit)\n -> unit )\n options\n\n val filter : ('a, 'cmp, ('a, 'cmp) t -> f:('a elt -> bool) -> ('a, 'cmp) t) options\n\n val partition_tf\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t -> f:('a elt -> bool) -> ('a, 'cmp) t * ('a, 'cmp) t )\n options\n\n val elements : ('a, _) t -> 'a elt list\n val min_elt : ('a, _) t -> 'a elt option\n val min_elt_exn : ('a, _) t -> 'a elt\n val max_elt : ('a, _) t -> 'a elt option\n val max_elt_exn : ('a, _) t -> 'a elt\n val choose : ('a, _) t -> 'a elt option\n val choose_exn : ('a, _) t -> 'a elt\n\n val split\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t -> 'a elt -> ('a, 'cmp) t * 'a elt option * ('a, 'cmp) t )\n options\n\n val group_by\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t -> equiv:('a elt -> 'a elt -> bool) -> ('a, 'cmp) t list )\n options\n\n val find_exn : ('a, _) t -> f:('a elt -> bool) -> 'a elt\n val nth : ('a, _) t -> int -> 'a elt option\n val remove_index : ('a, 'cmp, ('a, 'cmp) t -> int -> ('a, 'cmp) t) options\n val to_tree : ('a, 'cmp) t -> ('a elt, 'cmp) tree\n\n val to_sequence\n : ( 'a\n , 'cmp\n , ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a elt\n -> ?less_or_equal_to:'a elt\n -> ('a, 'cmp) t\n -> 'a elt Sequence.t )\n options\n\n val binary_search\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t\n -> compare:('a elt -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> 'a elt option )\n options\n\n val binary_search_segmented\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t\n -> segment_of:('a elt -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> 'a elt option )\n options\n\n val merge_to_sequence\n : ( 'a\n , 'cmp\n , ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a elt\n -> ?less_or_equal_to:'a elt\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a elt, 'a elt) Merge_to_sequence_element.t Sequence.t )\n options\nend\n\nmodule type Accessors0 = sig\n include Container.S0\n\n type tree\n type comparator_witness\n\n val invariants : t -> bool\n val mem : t -> elt -> bool\n val add : t -> elt -> t\n val remove : t -> elt -> t\n val union : t -> t -> t\n val inter : t -> t -> t\n val diff : t -> t -> t\n val symmetric_diff : t -> t -> (elt, elt) Either.t Sequence.t\n val compare_direct : t -> t -> int\n val equal : t -> t -> bool\n val is_subset : t -> of_:t -> bool\n val are_disjoint : t -> t -> bool\n\n type named\n\n module Named : sig\n val is_subset : named -> of_:named -> unit Or_error.t\n val equal : named -> named -> unit Or_error.t\n end\n\n val fold_until\n : t\n -> init:'b\n -> f:('b -> elt -> ('b, 'final) Continue_or_stop.t)\n -> finish:('b -> 'final)\n -> 'final\n\n val fold_right : t -> init:'b -> f:(elt -> 'b -> 'b) -> 'b\n\n val iter2\n : t\n -> t\n -> f:([ `Left of elt | `Right of elt | `Both of elt * elt ] -> unit)\n -> unit\n\n val filter : t -> f:(elt -> bool) -> t\n val partition_tf : t -> f:(elt -> bool) -> t * t\n val elements : t -> elt list\n val min_elt : t -> elt option\n val min_elt_exn : t -> elt\n val max_elt : t -> elt option\n val max_elt_exn : t -> elt\n val choose : t -> elt option\n val choose_exn : t -> elt\n val split : t -> elt -> t * elt option * t\n val group_by : t -> equiv:(elt -> elt -> bool) -> t list\n val find_exn : t -> f:(elt -> bool) -> elt\n val nth : t -> int -> elt option\n val remove_index : t -> int -> t\n val to_tree : t -> tree\n\n val to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:elt\n -> ?less_or_equal_to:elt\n -> t\n -> elt Sequence.t\n\n val binary_search\n : t\n -> compare:(elt -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> elt option\n\n val binary_search_segmented\n : t\n -> segment_of:(elt -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> elt option\n\n val merge_to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:elt\n -> ?less_or_equal_to:elt\n -> t\n -> t\n -> (elt, elt) Merge_to_sequence_element.t Sequence.t\nend\n\nmodule type Accessors1 = sig\n include Container.S1\n\n type 'a tree\n type comparator_witness\n\n val invariants : _ t -> bool\n val mem : 'a t -> 'a -> bool\n val add : 'a t -> 'a -> 'a t\n val remove : 'a t -> 'a -> 'a t\n val union : 'a t -> 'a t -> 'a t\n val inter : 'a t -> 'a t -> 'a t\n val diff : 'a t -> 'a t -> 'a t\n val symmetric_diff : 'a t -> 'a t -> ('a, 'a) Either.t Sequence.t\n val compare_direct : 'a t -> 'a t -> int\n val equal : 'a t -> 'a t -> bool\n val is_subset : 'a t -> of_:'a t -> bool\n val are_disjoint : 'a t -> 'a t -> bool\n\n type 'a named\n\n module Named : sig\n val is_subset : 'a named -> of_:'a named -> unit Or_error.t\n val equal : 'a named -> 'a named -> unit Or_error.t\n end\n\n val fold_until\n : 'a t\n -> init:'b\n -> f:('b -> 'a -> ('b, 'final) Continue_or_stop.t)\n -> finish:('b -> 'final)\n -> 'final\n\n val fold_right : 'a t -> init:'b -> f:('a -> 'b -> 'b) -> 'b\n\n val iter2\n : 'a t\n -> 'a t\n -> f:([ `Left of 'a | `Right of 'a | `Both of 'a * 'a ] -> unit)\n -> unit\n\n val filter : 'a t -> f:('a -> bool) -> 'a t\n val partition_tf : 'a t -> f:('a -> bool) -> 'a t * 'a t\n val elements : 'a t -> 'a list\n val min_elt : 'a t -> 'a option\n val min_elt_exn : 'a t -> 'a\n val max_elt : 'a t -> 'a option\n val max_elt_exn : 'a t -> 'a\n val choose : 'a t -> 'a option\n val choose_exn : 'a t -> 'a\n val split : 'a t -> 'a -> 'a t * 'a option * 'a t\n val group_by : 'a t -> equiv:('a -> 'a -> bool) -> 'a t list\n val find_exn : 'a t -> f:('a -> bool) -> 'a\n val nth : 'a t -> int -> 'a option\n val remove_index : 'a t -> int -> 'a t\n val to_tree : 'a t -> 'a tree\n\n val to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> 'a t\n -> 'a Sequence.t\n\n val binary_search\n : 'a t\n -> compare:('a -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> 'a option\n\n val binary_search_segmented\n : 'a t\n -> segment_of:('a -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> 'a option\n\n val merge_to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> 'a t\n -> 'a t\n -> ('a, 'a) Merge_to_sequence_element.t Sequence.t\nend\n\nmodule type Accessors2 = sig\n include Container.S1_phantom_invariant\n\n type ('a, 'cmp) tree\n\n val invariants : (_, _) t -> bool\n val mem : ('a, _) t -> 'a -> bool\n val add : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n val remove : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n val union : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n val inter : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n val diff : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n val symmetric_diff : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'a) Either.t Sequence.t\n val compare_direct : ('a, 'cmp) t -> ('a, 'cmp) t -> int\n val equal : ('a, 'cmp) t -> ('a, 'cmp) t -> bool\n val is_subset : ('a, 'cmp) t -> of_:('a, 'cmp) t -> bool\n val are_disjoint : ('a, 'cmp) t -> ('a, 'cmp) t -> bool\n\n type ('a, 'cmp) named\n\n module Named : sig\n val is_subset : ('a, 'cmp) named -> of_:('a, 'cmp) named -> unit Or_error.t\n val equal : ('a, 'cmp) named -> ('a, 'cmp) named -> unit Or_error.t\n end\n\n val fold_until\n : ('a, _) t\n -> init:'b\n -> f:('b -> 'a -> ('b, 'final) Continue_or_stop.t)\n -> finish:('b -> 'final)\n -> 'final\n\n val fold_right : ('a, _) t -> init:'b -> f:('a -> 'b -> 'b) -> 'b\n\n val iter2\n : ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> f:([ `Left of 'a | `Right of 'a | `Both of 'a * 'a ] -> unit)\n -> unit\n\n val filter : ('a, 'cmp) t -> f:('a -> bool) -> ('a, 'cmp) t\n val partition_tf : ('a, 'cmp) t -> f:('a -> bool) -> ('a, 'cmp) t * ('a, 'cmp) t\n val elements : ('a, _) t -> 'a list\n val min_elt : ('a, _) t -> 'a option\n val min_elt_exn : ('a, _) t -> 'a\n val max_elt : ('a, _) t -> 'a option\n val max_elt_exn : ('a, _) t -> 'a\n val choose : ('a, _) t -> 'a option\n val choose_exn : ('a, _) t -> 'a\n val split : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t * 'a option * ('a, 'cmp) t\n val group_by : ('a, 'cmp) t -> equiv:('a -> 'a -> bool) -> ('a, 'cmp) t list\n val find_exn : ('a, _) t -> f:('a -> bool) -> 'a\n val nth : ('a, _) t -> int -> 'a option\n val remove_index : ('a, 'cmp) t -> int -> ('a, 'cmp) t\n val to_tree : ('a, 'cmp) t -> ('a, 'cmp) tree\n\n val to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> 'a Sequence.t\n\n val binary_search\n : ('a, 'cmp) t\n -> compare:('a -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> 'a option\n\n val binary_search_segmented\n : ('a, 'cmp) t\n -> segment_of:('a -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> 'a option\n\n val merge_to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'a) Merge_to_sequence_element.t Sequence.t\nend\n\nmodule type Accessors2_with_comparator = sig\n include Container.S1_phantom_invariant\n\n type ('a, 'cmp) tree\n\n val invariants : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t -> bool\n val mem : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t -> 'a -> bool\n val add : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n val remove : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n\n val union\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n\n val inter\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n\n val diff\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n\n val symmetric_diff\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'a) Either.t Sequence.t\n\n val compare_direct\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> int\n\n val equal : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t -> ('a, 'cmp) t -> bool\n\n val is_subset\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> of_:('a, 'cmp) t\n -> bool\n\n val are_disjoint\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> bool\n\n type ('a, 'cmp) named\n\n module Named : sig\n val is_subset\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) named\n -> of_:('a, 'cmp) named\n -> unit Or_error.t\n\n val equal\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) named\n -> ('a, 'cmp) named\n -> unit Or_error.t\n end\n\n val fold_until\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n val fold_right : ('a, _) t -> init:'accum -> f:('a -> 'accum -> 'accum) -> 'accum\n\n val iter2\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> f:([ `Left of 'a | `Right of 'a | `Both of 'a * 'a ] -> unit)\n -> unit\n\n val filter\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> f:('a -> bool)\n -> ('a, 'cmp) t\n\n val partition_tf\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> f:('a -> bool)\n -> ('a, 'cmp) t * ('a, 'cmp) t\n\n val elements : ('a, _) t -> 'a list\n val min_elt : ('a, _) t -> 'a option\n val min_elt_exn : ('a, _) t -> 'a\n val max_elt : ('a, _) t -> 'a option\n val max_elt_exn : ('a, _) t -> 'a\n val choose : ('a, _) t -> 'a option\n val choose_exn : ('a, _) t -> 'a\n\n val split\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> 'a\n -> ('a, 'cmp) t * 'a option * ('a, 'cmp) t\n\n val group_by\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> equiv:('a -> 'a -> bool)\n -> ('a, 'cmp) t list\n\n val find_exn : ('a, _) t -> f:('a -> bool) -> 'a\n val nth : ('a, _) t -> int -> 'a option\n\n val remove_index\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> int\n -> ('a, 'cmp) t\n\n val to_tree : ('a, 'cmp) t -> ('a, 'cmp) tree\n\n val to_sequence\n : comparator:('a, 'cmp) Comparator.t\n -> ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> 'a Sequence.t\n\n val binary_search\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> compare:('a -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> 'a option\n\n val binary_search_segmented\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> segment_of:('a -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> 'a option\n\n val merge_to_sequence\n : comparator:('a, 'cmp) Comparator.t\n -> ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'a) Merge_to_sequence_element.t Sequence.t\nend\n\n(** Consistency checks (same as in [Container]). *)\nmodule Check_accessors\n (T : T2)\n (Tree : T2)\n (Elt : T1)\n (Named : T2)\n (Cmp : T1)\n (Options : T3)\n (M : Accessors_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Options.t\n with type ('a, 'b) t := ('a, 'b) T.t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type 'a elt := 'a Elt.t\n with type 'cmp cmp := 'cmp Cmp.t\n with type ('a, 'b) named := ('a, 'b) Named.t) =\nstruct end\n\nmodule Check_accessors0 (M : Accessors0) =\n Check_accessors\n (struct\n type ('a, 'b) t = M.t\n end)\n (struct\n type ('a, 'b) t = M.tree\n end)\n (struct\n type 'a t = M.elt\n end)\n (struct\n type ('a, 'b) t = M.named\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors1 (M : Accessors1) =\n Check_accessors\n (struct\n type ('a, 'b) t = 'a M.t\n end)\n (struct\n type ('a, 'b) t = 'a M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type ('a, 'b) t = 'a M.named\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors2 (M : Accessors2) =\n Check_accessors\n (struct\n type ('a, 'b) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.named\n end)\n (struct\n type 'a t = 'a\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors2_with_comparator (M : Accessors2_with_comparator) =\n Check_accessors\n (struct\n type ('a, 'b) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.named\n end)\n (struct\n type 'a t = 'a\n end)\n (With_comparator)\n (M)\n\nmodule type Creators_generic = sig\n type ('a, 'cmp) t\n type ('a, 'cmp) set\n type ('a, 'cmp) tree\n type 'a elt\n type ('a, 'cmp, 'z) options\n type 'cmp cmp\n\n val empty : ('a, 'cmp, ('a, 'cmp) t) options\n val singleton : ('a, 'cmp, 'a elt -> ('a, 'cmp) t) options\n val union_list : ('a, 'cmp, ('a, 'cmp) t list -> ('a, 'cmp) t) options\n val of_list : ('a, 'cmp, 'a elt list -> ('a, 'cmp) t) options\n val of_array : ('a, 'cmp, 'a elt array -> ('a, 'cmp) t) options\n val of_sorted_array : ('a, 'cmp, 'a elt array -> ('a, 'cmp) t Or_error.t) options\n val of_sorted_array_unchecked : ('a, 'cmp, 'a elt array -> ('a, 'cmp) t) options\n\n val of_increasing_iterator_unchecked\n : ('a, 'cmp, len:int -> f:(int -> 'a elt) -> ('a, 'cmp) t) options\n\n val stable_dedup_list : ('a, _, 'a elt list -> 'a elt list) options\n\n (** The types of [map] and [filter_map] are subtle. The input set, [('a, _) set],\n reflects the fact that these functions take a set of *any* type, with any\n comparator, while the output set, [('b, 'cmp) t], reflects that the output set has\n the particular ['cmp] of the creation function. The comparator can come in one of\n three ways, depending on which set module is used\n\n - [Set.map] -- comparator comes as an argument\n - [Set.Poly.map] -- comparator is polymorphic comparison\n - [Foo.Set.map] -- comparator is [Foo.comparator] *)\n val map : ('b, 'cmp, ('a, _) set -> f:('a -> 'b elt) -> ('b, 'cmp) t) options\n\n val filter_map\n : ('b, 'cmp, ('a, _) set -> f:('a -> 'b elt option) -> ('b, 'cmp) t) options\n\n val of_tree : ('a, 'cmp, ('a elt, 'cmp) tree -> ('a, 'cmp) t) options\nend\n\nmodule type Creators0 = sig\n type ('a, 'cmp) set\n type t\n type tree\n type elt\n type comparator_witness\n\n val empty : t\n val singleton : elt -> t\n val union_list : t list -> t\n val of_list : elt list -> t\n val of_array : elt array -> t\n val of_sorted_array : elt array -> t Or_error.t\n val of_sorted_array_unchecked : elt array -> t\n val of_increasing_iterator_unchecked : len:int -> f:(int -> elt) -> t\n val stable_dedup_list : elt list -> elt list\n val map : ('a, _) set -> f:('a -> elt) -> t\n val filter_map : ('a, _) set -> f:('a -> elt option) -> t\n val of_tree : tree -> t\nend\n\nmodule type Creators1 = sig\n type ('a, 'cmp) set\n type 'a t\n type 'a tree\n type comparator_witness\n\n val empty : 'a t\n val singleton : 'a -> 'a t\n val union_list : 'a t list -> 'a t\n val of_list : 'a list -> 'a t\n val of_array : 'a array -> 'a t\n val of_sorted_array : 'a array -> 'a t Or_error.t\n val of_sorted_array_unchecked : 'a array -> 'a t\n val of_increasing_iterator_unchecked : len:int -> f:(int -> 'a) -> 'a t\n val stable_dedup_list : 'a list -> 'a list\n val map : ('a, _) set -> f:('a -> 'b) -> 'b t\n val filter_map : ('a, _) set -> f:('a -> 'b option) -> 'b t\n val of_tree : 'a tree -> 'a t\nend\n\nmodule type Creators2 = sig\n type ('a, 'cmp) set\n type ('a, 'cmp) t\n type ('a, 'cmp) tree\n\n val empty : ('a, 'cmp) t\n val singleton : 'a -> ('a, 'cmp) t\n val union_list : ('a, 'cmp) t list -> ('a, 'cmp) t\n val of_list : 'a list -> ('a, 'cmp) t\n val of_array : 'a array -> ('a, 'cmp) t\n val of_sorted_array : 'a array -> ('a, 'cmp) t Or_error.t\n val of_sorted_array_unchecked : 'a array -> ('a, 'cmp) t\n val of_increasing_iterator_unchecked : len:int -> f:(int -> 'a) -> ('a, 'cmp) t\n val stable_dedup_list : 'a list -> 'a list\n val map : ('a, _) set -> f:('a -> 'b) -> ('b, 'cmp) t\n val filter_map : ('a, _) set -> f:('a -> 'b option) -> ('b, 'cmp) t\n val of_tree : ('a, 'cmp) tree -> ('a, 'cmp) t\nend\n\nmodule type Creators2_with_comparator = sig\n type ('a, 'cmp) set\n type ('a, 'cmp) t\n type ('a, 'cmp) tree\n\n val empty : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t\n val singleton : comparator:('a, 'cmp) Comparator.t -> 'a -> ('a, 'cmp) t\n\n val union_list\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t list\n -> ('a, 'cmp) t\n\n val of_list : comparator:('a, 'cmp) Comparator.t -> 'a list -> ('a, 'cmp) t\n val of_array : comparator:('a, 'cmp) Comparator.t -> 'a array -> ('a, 'cmp) t\n\n val of_sorted_array\n : comparator:('a, 'cmp) Comparator.t\n -> 'a array\n -> ('a, 'cmp) t Or_error.t\n\n val of_sorted_array_unchecked\n : comparator:('a, 'cmp) Comparator.t\n -> 'a array\n -> ('a, 'cmp) t\n\n val of_increasing_iterator_unchecked\n : comparator:('a, 'cmp) Comparator.t\n -> len:int\n -> f:(int -> 'a)\n -> ('a, 'cmp) t\n\n val stable_dedup_list : comparator:('a, 'cmp) Comparator.t -> 'a list -> 'a list\n\n val map\n : comparator:('b, 'cmp) Comparator.t\n -> ('a, _) set\n -> f:('a -> 'b)\n -> ('b, 'cmp) t\n\n val filter_map\n : comparator:('b, 'cmp) Comparator.t\n -> ('a, _) set\n -> f:('a -> 'b option)\n -> ('b, 'cmp) t\n\n val of_tree : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) tree -> ('a, 'cmp) t\nend\n\nmodule Check_creators\n (T : T2)\n (Tree : T2)\n (Elt : T1)\n (Cmp : T1)\n (Options : T3)\n (M : Creators_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Options.t\n with type ('a, 'b) t := ('a, 'b) T.t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type 'a elt := 'a Elt.t\n with type 'cmp cmp := 'cmp Cmp.t) =\nstruct end\n\nmodule Check_creators0 (M : Creators0) =\n Check_creators\n (struct\n type ('a, 'b) t = M.t\n end)\n (struct\n type ('a, 'b) t = M.tree\n end)\n (struct\n type 'a t = M.elt\n end)\n (struct\n type 'cmp t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_creators1 (M : Creators1) =\n Check_creators\n (struct\n type ('a, 'b) t = 'a M.t\n end)\n (struct\n type ('a, 'b) t = 'a M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'cmp t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_creators2 (M : Creators2) =\n Check_creators\n (struct\n type ('a, 'b) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'cmp t = 'cmp\n end)\n (Without_comparator)\n (M)\n\nmodule Check_creators2_with_comparator (M : Creators2_with_comparator) =\n Check_creators\n (struct\n type ('a, 'b) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'cmp t = 'cmp\n end)\n (With_comparator)\n (M)\n\nmodule type Creators_and_accessors_generic = sig\n include Accessors_generic\n\n include\n Creators_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) options\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) tree\n with type 'a elt := 'a elt\n with type 'cmp cmp := 'cmp cmp\nend\n\nmodule type Creators_and_accessors0 = sig\n include Accessors0\n\n include\n Creators0\n with type t := t\n with type tree := tree\n with type elt := elt\n with type comparator_witness := comparator_witness\nend\n\nmodule type Creators_and_accessors1 = sig\n include Accessors1\n\n include\n Creators1\n with type 'a t := 'a t\n with type 'a tree := 'a tree\n with type comparator_witness := comparator_witness\nend\n\nmodule type Creators_and_accessors2 = sig\n include Accessors2\n\n include\n Creators2 with type ('a, 'b) t := ('a, 'b) t with type ('a, 'b) tree := ('a, 'b) tree\nend\n\nmodule type Creators_and_accessors2_with_comparator = sig\n include Accessors2_with_comparator\n\n include\n Creators2_with_comparator\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) tree\nend\n\nmodule type S_poly = Creators_and_accessors1\n\nmodule type For_deriving = sig\n type ('a, 'b) t\n\n module type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end\n\n module type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Comparator.S with type t := t\n end\n\n module type Compare_m = sig end\n module type Equal_m = sig end\n module type Hash_fold_m = Hasher.S\n\n val sexp_of_m__t : (module Sexp_of_m with type t = 'elt) -> ('elt, 'cmp) t -> Sexp.t\n\n val m__t_of_sexp\n : (module M_of_sexp with type t = 'elt and type comparator_witness = 'cmp)\n -> Sexp.t\n -> ('elt, 'cmp) t\n\n val compare_m__t : (module Compare_m) -> ('elt, 'cmp) t -> ('elt, 'cmp) t -> int\n val equal_m__t : (module Equal_m) -> ('elt, 'cmp) t -> ('elt, 'cmp) t -> bool\n\n val hash_fold_m__t\n : (module Hash_fold_m with type t = 'elt)\n -> Hash.state\n -> ('elt, _) t\n -> Hash.state\n\n val hash_m__t : (module Hash_fold_m with type t = 'elt) -> ('elt, _) t -> int\nend\n\nmodule type Set = sig\n (** This module defines the [Set] module for [Base]. Functions that construct a set take\n as an argument the comparator for the element type. *)\n\n (** The type of a set. The first type parameter identifies the type of the element, and\n the second identifies the comparator, which determines the comparison function that\n is used for ordering elements in this set. Many operations (e.g., {!union}),\n require that they be passed sets with the same element type and the same comparator\n type. *)\n type ('elt, 'cmp) t [@@deriving_inline compare]\n\n val compare\n : ('elt -> 'elt -> int)\n -> ('cmp -> 'cmp -> int)\n -> ('elt, 'cmp) t\n -> ('elt, 'cmp) t\n -> int\n\n [@@@end]\n\n type ('k, 'cmp) comparator =\n (module Comparator.S with type t = 'k and type comparator_witness = 'cmp)\n\n (** Tests internal invariants of the set data structure. Returns true on success. *)\n val invariants : (_, _) t -> bool\n\n (** Returns a first-class module that can be used to build other map/set/etc\n with the same notion of comparison. *)\n val comparator_s : ('a, 'cmp) t -> ('a, 'cmp) comparator\n\n val comparator : ('a, 'cmp) t -> ('a, 'cmp) Comparator.t\n\n (** Creates an empty set based on the provided comparator. *)\n val empty : ('a, 'cmp) comparator -> ('a, 'cmp) t\n\n (** Creates a set based on the provided comparator that contains only the provided\n element. *)\n val singleton : ('a, 'cmp) comparator -> 'a -> ('a, 'cmp) t\n\n (** Returns the cardinality of the set. [O(1)]. *)\n val length : (_, _) t -> int\n\n (** [is_empty t] is [true] iff [t] is empty. [O(1)]. *)\n val is_empty : (_, _) t -> bool\n\n (** [mem t a] returns [true] iff [a] is in [t]. [O(log n)]. *)\n val mem : ('a, _) t -> 'a -> bool\n\n (** [add t a] returns a new set with [a] added to [t], or returns [t] if [mem t a].\n [O(log n)]. *)\n val add : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n\n (** [remove t a] returns a new set with [a] removed from [t] if [mem t a], or returns [t]\n otherwise. [O(log n)]. *)\n val remove : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n\n (** [union t1 t2] returns the union of the two sets. [O(length t1 + length t2)]. *)\n val union : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n\n (** [union c list] returns the union of all the sets in [list]. The\n [comparator] argument is required for the case where [list] is empty.\n [O(max(List.length list, n log n))], where [n] is the sum of sizes of the input sets. *)\n val union_list : ('a, 'cmp) comparator -> ('a, 'cmp) t list -> ('a, 'cmp) t\n\n (** [inter t1 t2] computes the intersection of sets [t1] and [t2]. [O(length t1 +\n length t2)]. *)\n val inter : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n\n (** [diff t1 t2] computes the set difference [t1 - t2], i.e., the set containing all\n elements in [t1] that are not in [t2]. [O(length t1 + length t2)]. *)\n val diff : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n\n (** [symmetric_diff t1 t2] returns a sequence of changes between [t1] and [t2]. It is\n intended to be efficient in the case where [t1] and [t2] share a large amount of\n structure. *)\n val symmetric_diff : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'a) Either.t Sequence.t\n\n (** [compare_direct t1 t2] compares the sets [t1] and [t2]. It returns the same result\n as [compare], but unlike compare, doesn't require arguments to be passed in for the\n type parameters of the set. [O(length t1 + length t2)]. *)\n val compare_direct : ('a, 'cmp) t -> ('a, 'cmp) t -> int\n\n (** Hash function: a building block to use when hashing data structures containing sets in\n them. [hash_fold_direct hash_fold_key] is compatible with [compare_direct] iff\n [hash_fold_key] is compatible with [(comparator s).compare] of the set [s] being\n hashed. *)\n val hash_fold_direct : 'a Hash.folder -> ('a, 'cmp) t Hash.folder\n\n (** [equal t1 t2] returns [true] iff the two sets have the same elements. [O(length t1 +\n length t2)] *)\n val equal : ('a, 'cmp) t -> ('a, 'cmp) t -> bool\n\n (** [exists t ~f] returns [true] iff there exists an [a] in [t] for which [f a]. [O(n)],\n but returns as soon as it finds an [a] for which [f a]. *)\n val exists : ('a, _) t -> f:('a -> bool) -> bool\n\n (** [for_all t ~f] returns [true] iff for all [a] in [t], [f a]. [O(n)], but returns as\n soon as it finds an [a] for which [not (f a)]. *)\n val for_all : ('a, _) t -> f:('a -> bool) -> bool\n\n (** [count t] returns the number of elements of [t] for which [f] returns [true].\n [O(n)]. *)\n val count : ('a, _) t -> f:('a -> bool) -> int\n\n (** [sum t] returns the sum of [f t] for each [t] in the set.\n [O(n)]. *)\n val sum\n : (module Container.Summable with type t = 'sum)\n -> ('a, _) t\n -> f:('a -> 'sum)\n -> 'sum\n\n (** [find t f] returns an element of [t] for which [f] returns true, with no guarantee as\n to which element is returned. [O(n)], but returns as soon as a suitable element is\n found. *)\n val find : ('a, _) t -> f:('a -> bool) -> 'a option\n\n (** [find_map t f] returns [b] for some [a] in [t] for which [f a = Some b]. If no such\n [a] exists, then [find] returns [None]. [O(n)], but returns as soon as a suitable\n element is found. *)\n val find_map : ('a, _) t -> f:('a -> 'b option) -> 'b option\n\n (** Like [find], but throws an exception on failure. *)\n val find_exn : ('a, _) t -> f:('a -> bool) -> 'a\n\n (** [nth t i] returns the [i]th smallest element of [t], in [O(log n)] time. The\n smallest element has [i = 0]. Returns [None] if [i < 0] or [i >= length t]. *)\n val nth : ('a, _) t -> int -> 'a option\n\n (** [remove_index t i] returns a version of [t] with the [i]th smallest element removed,\n in [O(log n)] time. The smallest element has [i = 0]. Returns [t] if [i < 0] or\n [i >= length t]. *)\n val remove_index : ('a, 'cmp) t -> int -> ('a, 'cmp) t\n\n (** [is_subset t1 ~of_:t2] returns true iff [t1] is a subset of [t2]. *)\n val is_subset : ('a, 'cmp) t -> of_:('a, 'cmp) t -> bool\n\n (** [are_disjoint t1 t2] returns [true] iff [is_empty (inter t1 t2)], but is more\n efficient. *)\n val are_disjoint : ('a, 'cmp) t -> ('a, 'cmp) t -> bool\n\n (** [Named] allows the validation of subset and equality relationships between sets. A\n [Named.t] is a record of a set and a name, where the name is used in error messages,\n and [Named.is_subset] and [Named.equal] validate subset and equality relationships\n respectively.\n\n The error message for, e.g.,\n {[\n Named.is_subset { set = set1; name = \"set1\" } ~of_:{set = set2; name = \"set2\" }\n ]}\n\n looks like\n {v\n (\"set1 is not a subset of set2\" (invalid_elements (...elements of set1 - set2...)))\n v}\n\n so [name] should be a noun phrase that doesn't sound awkward in the above error\n message. Even though it adds verbosity, choosing [name]s that start with the phrase\n \"the set of\" often makes the error message sound more natural.\n *)\n module Named : sig\n type nonrec ('a, 'cmp) t =\n { set : ('a, 'cmp) t\n ; name : string\n }\n\n (** [is_subset t1 ~of_:t2] returns [Ok ()] if [t1] is a subset of [t2] and a\n human-readable error otherwise. *)\n val is_subset : ('a, 'cmp) t -> of_:('a, 'cmp) t -> unit Or_error.t\n\n (** [equal t1 t2] returns [Ok ()] if [t1] is equal to [t2] and a human-readable\n error otherwise. *)\n val equal : ('a, 'cmp) t -> ('a, 'cmp) t -> unit Or_error.t\n end\n\n (** The list or array given to [of_list] and [of_array] need not be sorted. *)\n val of_list : ('a, 'cmp) comparator -> 'a list -> ('a, 'cmp) t\n\n val of_array : ('a, 'cmp) comparator -> 'a array -> ('a, 'cmp) t\n\n (** [to_list] and [to_array] produce sequences sorted in ascending order according to the\n comparator. *)\n val to_list : ('a, _) t -> 'a list\n\n val to_array : ('a, _) t -> 'a array\n\n (** Create set from sorted array. The input must be sorted (either in ascending or\n descending order as given by the comparator) and contain no duplicates, otherwise the\n result is an error. The complexity of this function is [O(n)]. *)\n val of_sorted_array : ('a, 'cmp) comparator -> 'a array -> ('a, 'cmp) t Or_error.t\n\n (** Similar to [of_sorted_array], but without checking the input array. *)\n val of_sorted_array_unchecked : ('a, 'cmp) comparator -> 'a array -> ('a, 'cmp) t\n\n (** [of_increasing_iterator_unchecked c ~len ~f] behaves like [of_sorted_array_unchecked c\n (Array.init len ~f)], with the additional restriction that a decreasing order is not\n supported. The advantage is not requiring you to allocate an intermediate array. [f]\n will be called with 0, 1, ... [len - 1], in order. *)\n val of_increasing_iterator_unchecked\n : ('a, 'cmp) comparator\n -> len:int\n -> f:(int -> 'a)\n -> ('a, 'cmp) t\n\n (** [stable_dedup_list] is here rather than in the [List] module because the\n implementation relies crucially on sets, and because doing so allows one to avoid uses\n of polymorphic comparison by instantiating the functor at a different implementation\n of [Comparator] and using the resulting [stable_dedup_list]. *)\n val stable_dedup_list : ('a, _) comparator -> 'a list -> 'a list\n\n (** [map c t ~f] returns a new set created by applying [f] to every element in\n [t]. The returned set is based on the provided [comparator]. [O(n log n)]. *)\n val map : ('b, 'cmp) comparator -> ('a, _) t -> f:('a -> 'b) -> ('b, 'cmp) t\n\n (** Like {!map}, except elements for which [f] returns [None] will be dropped. *)\n val filter_map\n : ('b, 'cmp) comparator\n -> ('a, _) t\n -> f:('a -> 'b option)\n -> ('b, 'cmp) t\n\n (** [filter t ~f] returns the subset of [t] for which [f] evaluates to true. [O(n log\n n)]. *)\n val filter : ('a, 'cmp) t -> f:('a -> bool) -> ('a, 'cmp) t\n\n (** [fold t ~init ~f] folds over the elements of the set from smallest to largest. *)\n val fold : ('a, _) t -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum\n\n (** [fold_result ~init ~f] folds over the elements of the set from smallest to\n largest, short circuiting the fold if [f accum x] is an [Error _] *)\n val fold_result\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n (** [fold_until t ~init ~f] is a short-circuiting version of [fold]. If [f]\n returns [Stop _] the computation ceases and results in that value. If [f] returns\n [Continue _], the fold will proceed. *)\n val fold_until\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n\n (** Like {!fold}, except that it goes from the largest to the smallest element. *)\n val fold_right : ('a, _) t -> init:'accum -> f:('a -> 'accum -> 'accum) -> 'accum\n\n (** [iter t ~f] calls [f] on every element of [t], going in order from the smallest to\n largest. *)\n val iter : ('a, _) t -> f:('a -> unit) -> unit\n\n (** Iterate two sets side by side. Complexity is [O(m+n)] where [m] and [n] are the sizes\n of the two input sets. As an example, with the inputs [0; 1] and [1; 2], [f] will be\n called with [`Left 0]; [`Both (1, 1)]; and [`Right 2]. *)\n val iter2\n : ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> f:([ `Left of 'a | `Right of 'a | `Both of 'a * 'a ] -> unit)\n -> unit\n\n (** if [a, b = partition_tf set ~f] then [a] is the elements on which [f] produced [true],\n and [b] is the elements on which [f] produces [false]. *)\n val partition_tf : ('a, 'cmp) t -> f:('a -> bool) -> ('a, 'cmp) t * ('a, 'cmp) t\n\n (** Same as {!to_list}. *)\n val elements : ('a, _) t -> 'a list\n\n (** Returns the smallest element of the set. [O(log n)]. *)\n val min_elt : ('a, _) t -> 'a option\n\n (** Like {!min_elt}, but throws an exception when given an empty set. *)\n val min_elt_exn : ('a, _) t -> 'a\n\n (** Returns the largest element of the set. [O(log n)]. *)\n val max_elt : ('a, _) t -> 'a option\n\n (** Like {!max_elt}, but throws an exception when given an empty set. *)\n val max_elt_exn : ('a, _) t -> 'a\n\n (** returns an arbitrary element, or [None] if the set is empty. *)\n val choose : ('a, _) t -> 'a option\n\n (** Like {!choose}, but throws an exception on an empty set. *)\n val choose_exn : ('a, _) t -> 'a\n\n (** [split t x] produces a triple [(t1, maybe_x, t2)] where [t1] is the set of elements\n strictly less than [x], [maybe_x] is the member (if any) of [t] which compares equal\n to [x], and [t2] is the set of elements strictly larger than [x]. *)\n val split : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t * 'a option * ('a, 'cmp) t\n\n (** if [equiv] is an equivalence predicate, then [group_by set ~equiv] produces a list\n of equivalence classes (i.e., a set-theoretic quotient). E.g.,\n\n {[\n let chars = Set.of_list ['A'; 'a'; 'b'; 'c'] in\n let equiv c c' = Char.equal (Char.uppercase c) (Char.uppercase c') in\n group_by chars ~equiv\n ]}\n\n produces:\n\n {[\n [Set.of_list ['A';'a']; Set.singleton 'b'; Set.singleton 'c']\n ]}\n\n [group_by] runs in O(n^2) time, so if you have a comparison function, it's usually\n much faster to use [Set.of_list]. *)\n val group_by : ('a, 'cmp) t -> equiv:('a -> 'a -> bool) -> ('a, 'cmp) t list\n\n (** [to_sequence t] converts the set [t] to a sequence of the elements between\n [greater_or_equal_to] and [less_or_equal_to] inclusive in the order indicated by\n [order]. If [greater_or_equal_to > less_or_equal_to] the sequence is empty. Cost is\n O(log n) up front and amortized O(1) for each element produced. *)\n val to_sequence\n : ?order:[ `Increasing (** default *) | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> 'a Sequence.t\n\n (** [binary_search t ~compare which elt] returns the element in [t] specified by\n [compare] and [which], if one exists.\n\n [t] must be sorted in increasing order according to [compare], where [compare] and\n [elt] divide [t] into three (possibly empty) segments:\n\n {v\n | < elt | = elt | > elt |\n v}\n\n [binary_search] returns an element on the boundary of segments as specified by\n [which]. See the diagram below next to the [which] variants.\n\n [binary_search] does not check that [compare] orders [t], and behavior is\n unspecified if [compare] doesn't order [t]. Behavior is also unspecified if\n [compare] mutates [t]. *)\n val binary_search\n : ('a, 'cmp) t\n -> compare:('a -> 'key -> int)\n -> [ `Last_strictly_less_than (** {v | < elt X | v} *)\n | `Last_less_than_or_equal_to (** {v | <= elt X | v} *)\n | `Last_equal_to (** {v | = elt X | v} *)\n | `First_equal_to (** {v | X = elt | v} *)\n | `First_greater_than_or_equal_to (** {v | X >= elt | v} *)\n | `First_strictly_greater_than (** {v | X > elt | v} *)\n ]\n -> 'key\n -> 'a option\n\n (** [binary_search_segmented t ~segment_of which] takes a [segment_of] function that\n divides [t] into two (possibly empty) segments:\n\n {v\n | segment_of elt = `Left | segment_of elt = `Right |\n v}\n\n [binary_search_segmented] returns the element on the boundary of the segments as\n specified by [which]: [`Last_on_left] yields the last element of the left segment,\n while [`First_on_right] yields the first element of the right segment. It returns\n [None] if the segment is empty.\n\n [binary_search_segmented] does not check that [segment_of] segments [t] as in the\n diagram, and behavior is unspecified if [segment_of] doesn't segment [t]. Behavior\n is also unspecified if [segment_of] mutates [t]. *)\n val binary_search_segmented\n : ('a, 'cmp) t\n -> segment_of:('a -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> 'a option\n\n (** Produces the elements of the two sets between [greater_or_equal_to] and\n [less_or_equal_to] in [order], noting whether each element appears in the left set,\n the right set, or both. In the both case, both elements are returned, in case the\n caller can distinguish between elements that are equal to the sets' comparator. Runs\n in O(length t + length t'). *)\n module Merge_to_sequence_element : sig\n type ('a, 'b) t = ('a, 'b) Sequence.Merge_with_duplicates_element.t =\n | Left of 'a\n | Right of 'b\n | Both of 'a * 'b\n [@@deriving_inline compare, sexp]\n\n val compare\n : ('a -> 'a -> int)\n -> ('b -> 'b -> int)\n -> ('a, 'b) t\n -> ('a, 'b) t\n -> int\n\n include Ppx_sexp_conv_lib.Sexpable.S2 with type ('a, 'b) t := ('a, 'b) t\n\n [@@@end]\n end\n\n val merge_to_sequence\n : ?order:[ `Increasing (** default *) | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'a) Merge_to_sequence_element.t Sequence.t\n\n (** [M] is meant to be used in combination with OCaml applicative functor types:\n\n {[\n type string_set = Set.M(String).t\n ]}\n\n which stands for:\n\n {[\n type string_set = (String.t, String.comparator_witness) Set.t\n ]}\n\n The point is that [Set.M(String).t] supports deriving, whereas the second syntax\n doesn't (because there is no such thing as, say, String.sexp_of_comparator_witness,\n instead you would want to pass the comparator directly). *)\n module M (Elt : sig\n type t\n type comparator_witness\n end) : sig\n type nonrec t = (Elt.t, Elt.comparator_witness) t\n end\n\n include For_deriving with type ('a, 'b) t := ('a, 'b) t\n\n (** A polymorphic Set. *)\n module Poly : S_poly with type 'elt t = ('elt, Comparator.Poly.comparator_witness) t\n\n (** Using comparator is a similar interface as the toplevel of [Set], except the functions\n take a [~comparator:('elt, 'cmp) Comparator.t] where the functions at the toplevel of\n [Set] takes a [('elt, 'cmp) comparator]. *)\n module Using_comparator : sig\n type nonrec ('elt, 'cmp) t = ('elt, 'cmp) t [@@deriving_inline sexp_of]\n\n val sexp_of_t\n : ('elt -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('cmp -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('elt, 'cmp) t\n -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val t_of_sexp_direct\n : comparator:('elt, 'cmp) Comparator.t\n -> (Sexp.t -> 'elt)\n -> Sexp.t\n -> ('elt, 'cmp) t\n\n module Tree : sig\n (** A [Tree.t] contains just the tree data structure that a set is based on, without\n including the comparator. Accordingly, any operation on a [Tree.t] must also take\n as an argument the corresponding comparator. *)\n type ('a, 'cmp) t [@@deriving_inline sexp_of]\n\n val sexp_of_t\n : ('a -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('cmp -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('a, 'cmp) t\n -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val t_of_sexp_direct\n : comparator:('elt, 'cmp) Comparator.t\n -> (Sexp.t -> 'elt)\n -> Sexp.t\n -> ('elt, 'cmp) t\n\n module Named : sig\n type nonrec ('a, 'cmp) t =\n { tree : ('a, 'cmp) t\n ; name : string\n }\n\n val is_subset\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> of_:('a, 'cmp) t\n -> unit Or_error.t\n\n val equal\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> unit Or_error.t\n end\n\n include\n Creators_and_accessors2_with_comparator\n with type ('a, 'b) set := ('a, 'b) t\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) t\n with type ('a, 'b) named := ('a, 'b) Named.t\n with module Named := Named\n\n val empty_without_value_restriction : (_, _) t\n end\n\n include\n Accessors2\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type ('a, 'b) named := ('a, 'b) Named.t\n\n include\n Creators2_with_comparator\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type ('a, 'b) set := ('a, 'b) t\n\n val comparator : ('a, 'cmp) t -> ('a, 'cmp) Comparator.t\n val hash_fold_direct : 'elt Hash.folder -> ('elt, 'cmp) t Hash.folder\n\n module Empty_without_value_restriction (Elt : Comparator.S1) : sig\n val empty : ('a Elt.t, Elt.comparator_witness) t\n end\n end\n\n (** {2 Modules and module types for extending [Set]}\n\n For use in extensions of Base, like [Core_kernel]. *)\n\n module With_comparator = With_comparator\n module With_first_class_module = With_first_class_module\n module Without_comparator = Without_comparator\n\n module type For_deriving = For_deriving\n module type S_poly = S_poly\n module type Accessors0 = Accessors0\n module type Accessors1 = Accessors1\n module type Accessors2 = Accessors2\n module type Accessors2_with_comparator = Accessors2_with_comparator\n module type Accessors_generic = Accessors_generic\n module type Creators0 = Creators0\n module type Creators1 = Creators1\n module type Creators2 = Creators2\n module type Creators2_with_comparator = Creators2_with_comparator\n module type Creators_and_accessors0 = Creators_and_accessors0\n module type Creators_and_accessors1 = Creators_and_accessors1\n module type Creators_and_accessors2 = Creators_and_accessors2\n\n module type Creators_and_accessors2_with_comparator =\n Creators_and_accessors2_with_comparator\n\n module type Creators_generic = Creators_generic\n module type Elt_plain = Elt_plain\nend\n","open! Import\n\n\n(* [t] stores the [t.length] queue elements at consecutive increasing indices of [t.elts],\n mod the capacity of [t], which is [Option_array.length t.elts]. The capacity is\n required to be a power of two (user-requested capacities are rounded up to the nearest\n power), so that mod can quickly be computed using [land t.mask], where [t.mask =\n capacity t - 1]. So, queue element [i] is at [t.elts.( (t.front + i) land t.mask )].\n\n [num_mutations] is used to detect modification during iteration. *)\ntype 'a t =\n { mutable num_mutations : int\n ; mutable front : int\n ; mutable mask : int\n ; mutable length : int\n ; mutable elts : 'a Option_array.t\n }\n[@@deriving_inline sexp_of]\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n fun _of_a -> function\n | { num_mutations = v_num_mutations\n ; front = v_front\n ; mask = v_mask\n ; length = v_length\n ; elts = v_elts\n } ->\n let bnds = [] in\n let bnds =\n let arg = Option_array.sexp_of_t _of_a v_elts in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"elts\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_length in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"length\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_mask in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"mask\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_front in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"front\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_num_mutations in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"num_mutations\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n;;\n\n[@@@end]\n\nmodule type S = Queue_intf.S\n\nlet inc_num_mutations t = t.num_mutations <- t.num_mutations + 1\nlet capacity t = t.mask + 1\nlet elts_index t i = (t.front + i) land t.mask\nlet unsafe_get t i = Option_array.unsafe_get_some_exn t.elts (elts_index t i)\nlet unsafe_is_set t i = Option_array.unsafe_is_some t.elts (elts_index t i)\nlet unsafe_set t i a = Option_array.unsafe_set_some t.elts (elts_index t i) a\nlet unsafe_unset t i = Option_array.unsafe_set_none t.elts (elts_index t i)\n\nlet check_index_exn t i =\n if i < 0 || i >= t.length\n then\n Error.raise_s\n (Sexp.message\n \"Queue index out of bounds\"\n [ \"index\", i |> Int.sexp_of_t; \"length\", t.length |> Int.sexp_of_t ])\n;;\n\nlet get t i =\n check_index_exn t i;\n unsafe_get t i\n;;\n\nlet set t i a =\n check_index_exn t i;\n inc_num_mutations t;\n unsafe_set t i a\n;;\n\nlet is_empty t = t.length = 0\nlet length { length; _ } = length\n\nlet ensure_no_mutation t num_mutations =\n if t.num_mutations <> num_mutations\n then\n Error.raise_s\n (Sexp.message\n \"mutation of queue during iteration\"\n [ \"\", t |> sexp_of_t (fun _ -> Sexp.Atom \"_\") ])\n;;\n\nlet compare =\n let rec unsafe_compare_from compare_elt pos ~t1 ~t2 ~len1 ~len2 ~mut1 ~mut2 =\n match pos = len1, pos = len2 with\n | true, true -> 0\n | true, false -> -1\n | false, true -> 1\n | false, false ->\n let x = compare_elt (unsafe_get t1 pos) (unsafe_get t2 pos) in\n ensure_no_mutation t1 mut1;\n ensure_no_mutation t2 mut2;\n (match x with\n | 0 -> unsafe_compare_from compare_elt (pos + 1) ~t1 ~t2 ~len1 ~len2 ~mut1 ~mut2\n | n -> n)\n in\n fun compare_elt t1 t2 ->\n if phys_equal t1 t2\n then 0\n else\n unsafe_compare_from\n compare_elt\n 0\n ~t1\n ~t2\n ~len1:t1.length\n ~len2:t2.length\n ~mut1:t1.num_mutations\n ~mut2:t2.num_mutations\n;;\n\nlet equal =\n let rec unsafe_equal_from equal_elt pos ~t1 ~t2 ~mut1 ~mut2 ~len =\n pos = len\n ||\n let b = equal_elt (unsafe_get t1 pos) (unsafe_get t2 pos) in\n ensure_no_mutation t1 mut1;\n ensure_no_mutation t2 mut2;\n b && unsafe_equal_from equal_elt (pos + 1) ~t1 ~t2 ~mut1 ~mut2 ~len\n in\n fun equal_elt t1 t2 ->\n phys_equal t1 t2\n ||\n let len1 = t1.length in\n let len2 = t2.length in\n len1 = len2\n && unsafe_equal_from\n equal_elt\n 0\n ~t1\n ~t2\n ~len:len1\n ~mut1:t1.num_mutations\n ~mut2:t2.num_mutations\n;;\n\nlet invariant invariant_a t =\n let { num_mutations; mask = _; elts; front; length } = t in\n assert (front >= 0);\n assert (front < capacity t);\n let capacity = capacity t in\n assert (capacity = Option_array.length elts);\n assert (capacity >= 1);\n assert (Int.is_pow2 capacity);\n assert (length >= 0);\n assert (length <= capacity);\n for i = 0 to capacity - 1 do\n if i < t.length\n then (\n invariant_a (unsafe_get t i);\n ensure_no_mutation t num_mutations)\n else assert (not (unsafe_is_set t i))\n done\n;;\n\nlet create (type a) ?capacity () : a t =\n let capacity =\n match capacity with\n | None -> 1\n | Some capacity ->\n if capacity < 0\n then\n Error.raise_s\n (Sexp.message\n \"cannot have queue with negative capacity\"\n [ \"capacity\", capacity |> Int.sexp_of_t ])\n else if capacity = 0\n then 1\n else Int.ceil_pow2 capacity\n in\n { num_mutations = 0\n ; front = 0\n ; mask = capacity - 1\n ; length = 0\n ; elts = Option_array.create ~len:capacity\n }\n;;\n\nlet blit_to_array ~src dst =\n assert (src.length <= Option_array.length dst);\n let front_len = Int.min src.length (capacity src - src.front) in\n let rest_len = src.length - front_len in\n Option_array.blit ~len:front_len ~src:src.elts ~src_pos:src.front ~dst ~dst_pos:0;\n Option_array.blit ~len:rest_len ~src:src.elts ~src_pos:0 ~dst ~dst_pos:front_len\n;;\n\nlet set_capacity t desired_capacity =\n (* We allow arguments less than 1 to [set_capacity], but translate them to 1 to simplify\n the code that relies on the array length being a power of 2. *)\n inc_num_mutations t;\n let new_capacity = Int.ceil_pow2 (max 1 (max desired_capacity t.length)) in\n if new_capacity <> capacity t\n then (\n let dst = Option_array.create ~len:new_capacity in\n blit_to_array ~src:t dst;\n t.front <- 0;\n t.mask <- new_capacity - 1;\n t.elts <- dst)\n;;\n\nlet enqueue t a =\n inc_num_mutations t;\n if t.length = capacity t then set_capacity t (2 * t.length);\n unsafe_set t t.length a;\n t.length <- t.length + 1\n;;\n\nlet dequeue_nonempty t =\n inc_num_mutations t;\n let elts = t.elts in\n let front = t.front in\n let res = Option_array.get_some_exn elts front in\n Option_array.set_none elts front;\n t.front <- elts_index t 1;\n t.length <- t.length - 1;\n res\n;;\n\nlet dequeue_exn t = if is_empty t then raise Caml.Queue.Empty else dequeue_nonempty t\nlet dequeue t = if is_empty t then None else Some (dequeue_nonempty t)\nlet front_nonempty t = Option_array.unsafe_get_some_exn t.elts t.front\nlet last_nonempty t = unsafe_get t (t.length - 1)\nlet peek t = if is_empty t then None else Some (front_nonempty t)\nlet peek_exn t = if is_empty t then raise Caml.Queue.Empty else front_nonempty t\nlet last t = if is_empty t then None else Some (last_nonempty t)\nlet last_exn t = if is_empty t then raise Caml.Queue.Empty else last_nonempty t\n\nlet clear t =\n inc_num_mutations t;\n if t.length > 0\n then (\n for i = 0 to t.length - 1 do\n unsafe_unset t i\n done;\n t.length <- 0;\n t.front <- 0)\n;;\n\nlet blit_transfer ~src ~dst ?len () =\n inc_num_mutations src;\n inc_num_mutations dst;\n let len =\n match len with\n | None -> src.length\n | Some len ->\n if len < 0\n then\n Error.raise_s\n (Sexp.message\n \"Queue.blit_transfer: negative length\"\n [ \"length\", len |> Int.sexp_of_t ]);\n min len src.length\n in\n if len > 0\n then (\n set_capacity dst (max (capacity dst) (dst.length + len));\n let dst_start = dst.front + dst.length in\n for i = 0 to len - 1 do\n (* This is significantly faster than simply [enqueue dst (dequeue_nonempty src)] *)\n let src_i = (src.front + i) land src.mask in\n let dst_i = (dst_start + i) land dst.mask in\n Option_array.unsafe_set_some\n dst.elts\n dst_i\n (Option_array.unsafe_get_some_exn src.elts src_i);\n Option_array.unsafe_set_none src.elts src_i\n done;\n dst.length <- dst.length + len;\n src.front <- (src.front + len) land src.mask;\n src.length <- src.length - len)\n;;\n\nlet enqueue_all t l =\n (* Traversing the list up front to compute its length is probably (but not definitely)\n better than doubling the underlying array size several times for large queues. *)\n set_capacity t (Int.max (capacity t) (t.length + List.length l));\n List.iter l ~f:(fun x -> enqueue t x)\n;;\n\nlet fold t ~init ~f =\n if t.length = 0\n then init\n else (\n let num_mutations = t.num_mutations in\n let r = ref init in\n for i = 0 to t.length - 1 do\n r := f !r (unsafe_get t i);\n ensure_no_mutation t num_mutations\n done;\n !r)\n;;\n\nlet foldi t ~init ~f =\n let i = ref 0 in\n fold t ~init ~f:(fun acc a ->\n let acc = f !i acc a in\n i := !i + 1;\n acc)\n;;\n\n\n(* [iter] is implemented directly because implementing it in terms of [fold] is\n slower. *)\nlet iter t ~f =\n let num_mutations = t.num_mutations in\n for i = 0 to t.length - 1 do\n f (unsafe_get t i);\n ensure_no_mutation t num_mutations\n done\n;;\n\nlet iteri t ~f =\n let num_mutations = t.num_mutations in\n for i = 0 to t.length - 1 do\n f i (unsafe_get t i);\n ensure_no_mutation t num_mutations\n done\n;;\n\nmodule C = Indexed_container.Make (struct\n type nonrec 'a t = 'a t\n\n let fold = fold\n let iter = `Custom iter\n let length = `Custom length\n let foldi = `Custom foldi\n let iteri = `Custom iteri\n end)\n\nlet count = C.count\nlet exists = C.exists\nlet find = C.find\nlet find_map = C.find_map\nlet fold_result = C.fold_result\nlet fold_until = C.fold_until\nlet for_all = C.for_all\nlet max_elt = C.max_elt\nlet mem = C.mem\nlet min_elt = C.min_elt\nlet sum = C.sum\nlet to_list = C.to_list\nlet counti = C.counti\nlet existsi = C.existsi\nlet find_mapi = C.find_mapi\nlet findi = C.findi\nlet for_alli = C.for_alli\n\n\n(* For [concat_map], [filter_map], and [filter], we don't create [t_result] with [t]'s\n capacity because we have no idea how many elements [t_result] will ultimately hold. *)\nlet concat_map t ~f =\n let t_result = create () in\n iter t ~f:(fun a -> List.iter (f a) ~f:(fun b -> enqueue t_result b));\n t_result\n;;\n\nlet concat_mapi t ~f =\n let t_result = create () in\n iteri t ~f:(fun i a -> List.iter (f i a) ~f:(fun b -> enqueue t_result b));\n t_result\n;;\n\nlet filter_map t ~f =\n let t_result = create () in\n iter t ~f:(fun a ->\n match f a with\n | None -> ()\n | Some b -> enqueue t_result b);\n t_result\n;;\n\nlet filter_mapi t ~f =\n let t_result = create () in\n iteri t ~f:(fun i a ->\n match f i a with\n | None -> ()\n | Some b -> enqueue t_result b);\n t_result\n;;\n\nlet filter t ~f =\n let t_result = create () in\n iter t ~f:(fun a -> if f a then enqueue t_result a);\n t_result\n;;\n\nlet filteri t ~f =\n let t_result = create () in\n iteri t ~f:(fun i a -> if f i a then enqueue t_result a);\n t_result\n;;\n\nlet filter_inplace t ~f =\n let t2 = filter t ~f in\n clear t;\n blit_transfer ~src:t2 ~dst:t ()\n;;\n\nlet filteri_inplace t ~f =\n let t2 = filteri t ~f in\n clear t;\n blit_transfer ~src:t2 ~dst:t ()\n;;\n\nlet copy src =\n let dst = create ~capacity:src.length () in\n blit_to_array ~src dst.elts;\n dst.length <- src.length;\n dst\n;;\n\nlet of_list l =\n (* Traversing the list up front to compute its length is probably (but not definitely)\n better than doubling the underlying array size several times for large queues. *)\n let t = create ~capacity:(List.length l) () in\n List.iter l ~f:(fun x -> enqueue t x);\n t\n;;\n\n(* The queue [t] returned by [create] will have [t.length = 0], [t.front = 0], and\n [capacity t = Int.ceil_pow2 len]. So, we only have to set [t.length] to [len] after\n the blit to maintain all the invariants: [t.length] is equal to the number of elements\n in the queue, [t.front] is the array index of the first element in the queue, and\n [capacity t = Option_array.length t.elts]. *)\nlet init len ~f =\n if len < 0\n then\n Error.raise_s\n (Sexp.message \"Queue.init: negative length\" [ \"length\", len |> Int.sexp_of_t ]);\n let t = create ~capacity:len () in\n assert (Option_array.length t.elts >= len);\n for i = 0 to len - 1 do\n Option_array.unsafe_set_some t.elts i (f i)\n done;\n t.length <- len;\n t\n;;\n\nlet of_array a = init (Array.length a) ~f:(Array.unsafe_get a)\nlet to_array t = Array.init t.length ~f:(fun i -> unsafe_get t i)\n\nlet map ta ~f =\n let num_mutations = ta.num_mutations in\n let tb = create ~capacity:ta.length () in\n tb.length <- ta.length;\n for i = 0 to ta.length - 1 do\n let b = f (unsafe_get ta i) in\n ensure_no_mutation ta num_mutations;\n Option_array.unsafe_set_some tb.elts i b\n done;\n tb\n;;\n\nlet mapi t ~f =\n let i = ref 0 in\n map t ~f:(fun a ->\n let result = f !i a in\n i := !i + 1;\n result)\n;;\n\nlet singleton x =\n let t = create () in\n enqueue t x;\n t\n;;\n\nlet sexp_of_t sexp_of_a t = to_list t |> List.sexp_of_t sexp_of_a\nlet t_of_sexp a_of_sexp sexp = List.t_of_sexp a_of_sexp sexp |> of_list\n","open! Import\n\nmodule T = struct\n type t = |\n\n let unreachable_code = function\n | (_ : t) -> .\n ;;\n\n let all = []\n let hash_fold_t _ t = unreachable_code t\n let hash = unreachable_code\n let compare a _ = unreachable_code a\n let sexp_of_t = unreachable_code\n let t_of_sexp sexp = Sexplib.Conv_error.empty_type \"Base.Nothing.t\" sexp\n let to_string = unreachable_code\n let of_string (_ : string) = failwith \"Base.Nothing.of_string: not supported\"\nend\n\ninclude T\n\ninclude Identifiable.Make (struct\n include T\n\n let module_name = \"Base.Nothing\"\n end)\n","(** [never_returns] should be used as the return type of functions that don't return and\n might block forever, rather than ['a] or [_]. This forces callers of such functions\n to have a call to [never_returns] at the call site, which makes it clear to readers\n what's going on. We do not intend to use this type for functions such as [failwithf]\n that always raise an exception. *)\n\nopen! Import\n\ntype never_returns = Nothing.t [@@deriving sexp_of]\n\nlet never_returns = Nothing.unreachable_code\n","open! Import\nopen! Caml.Nativeint\ninclude Nativeint_replace_polymorphic_compare\n\nmodule T = struct\n type t = nativeint [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_nativeint\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_nativeint in\n fun x -> func x\n ;;\n\n let t_of_sexp = (nativeint_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_nativeint : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"nativeint\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ nativeint_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"nativeint.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare = Nativeint_replace_polymorphic_compare.compare\n let to_string = to_string\n let of_string = of_string\nend\n\ninclude T\ninclude Comparator.Make (T)\n\ninclude Comparable.Validate_with_zero (struct\n include T\n\n let zero = zero\n end)\n\nmodule Conv = Int_conversions\ninclude Conv.Make (T)\n\ninclude Conv.Make_hex (struct\n open Nativeint_replace_polymorphic_compare\n\n type t = nativeint [@@deriving_inline compare, hash]\n\n let compare = (compare_nativeint : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_nativeint\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_nativeint in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let zero = zero\n let neg = neg\n let ( < ) = ( < )\n let to_string i = Printf.sprintf \"%nx\" i\n let of_string s = Caml.Scanf.sscanf s \"%nx\" Fn.id\n let module_name = \"Base.Nativeint.Hex\"\n end)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Base.Nativeint\"\n end)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! Nativeint_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet num_bits = Word_size.num_bits Word_size.word_size\nlet float_lower_bound = Float0.lower_bound_for_int num_bits\nlet float_upper_bound = Float0.upper_bound_for_int num_bits\nlet shift_right_logical = shift_right_logical\nlet shift_right = shift_right\nlet shift_left = shift_left\nlet bit_not = lognot\nlet bit_xor = logxor\nlet bit_or = logor\nlet bit_and = logand\nlet min_value = min_int\nlet max_value = max_int\nlet abs = abs\nlet pred = pred\nlet succ = succ\nlet rem = rem\nlet neg = neg\nlet minus_one = minus_one\nlet one = one\nlet zero = zero\nlet to_float = to_float\nlet of_float_unchecked = of_float\n\nlet of_float f =\n if Float_replace_polymorphic_compare.( >= ) f float_lower_bound\n && Float_replace_polymorphic_compare.( <= ) f float_upper_bound\n then of_float f\n else\n Printf.invalid_argf\n \"Nativeint.of_float: argument (%f) is out of range or NaN\"\n (Float0.box f)\n ()\n;;\n\nmodule Pow2 = struct\n open! Import\n open Nativeint_replace_polymorphic_compare\n module Sys = Sys0\n\n let raise_s = Error.raise_s\n\n let non_positive_argument () =\n Printf.invalid_argf \"argument must be strictly positive\" ()\n ;;\n\n let ( lor ) = Caml.Nativeint.logor\n let ( lsr ) = Caml.Nativeint.shift_right_logical\n let ( land ) = Caml.Nativeint.logand\n\n (** \"ceiling power of 2\" - Least power of 2 greater than or equal to x. *)\n let ceil_pow2 (x : nativeint) =\n if x <= 0n then non_positive_argument ();\n let x = Caml.Nativeint.pred x in\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n (* The next line is superfluous on 32-bit architectures, but it's faster to do it\n anyway than to branch *)\n let x = x lor (x lsr 32) in\n Caml.Nativeint.succ x\n ;;\n\n (** \"floor power of 2\" - Largest power of 2 less than or equal to x. *)\n let floor_pow2 x =\n if x <= 0n then non_positive_argument ();\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n let x = x lor (x lsr 32) in\n Caml.Nativeint.sub x (x lsr 1)\n ;;\n\n let is_pow2 x =\n if x <= 0n then non_positive_argument ();\n x land Caml.Nativeint.pred x = 0n\n ;;\n\n (* C stubs for nativeint clz and ctz to use the CLZ/BSR/CTZ/BSF instruction where possible *)\n external clz\n : (nativeint[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_nativeint_clz\" \"Base_int_math_nativeint_clz_unboxed\"\n [@@noalloc]\n\n external ctz\n : (nativeint[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_nativeint_ctz\" \"Base_int_math_nativeint_ctz_unboxed\"\n [@@noalloc]\n\n (** Hacker's Delight Second Edition p106 *)\n let floor_log2 i =\n if Poly.( <= ) i Caml.Nativeint.zero\n then\n raise_s\n (Sexp.message\n \"[Nativeint.floor_log2] got invalid input\"\n [ \"\", sexp_of_nativeint i ]);\n num_bits - 1 - clz i\n ;;\n\n (** Hacker's Delight Second Edition p106 *)\n let ceil_log2 i =\n if Poly.( <= ) i Caml.Nativeint.zero\n then\n raise_s\n (Sexp.message\n \"[Nativeint.ceil_log2] got invalid input\"\n [ \"\", sexp_of_nativeint i ]);\n if Caml.Nativeint.equal i Caml.Nativeint.one\n then 0\n else num_bits - clz (Caml.Nativeint.pred i)\n ;;\nend\n\ninclude Pow2\n\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet ( / ) = div\nlet ( * ) = mul\nlet ( - ) = sub\nlet ( + ) = add\nlet ( ~- ) = neg\nlet incr r = r := !r + one\nlet decr r = r := !r - one\nlet of_nativeint t = t\nlet of_nativeint_exn = of_nativeint\nlet to_nativeint t = t\nlet to_nativeint_exn = to_nativeint\nlet popcount = Popcount.nativeint_popcount\nlet of_int = Conv.int_to_nativeint\nlet of_int_exn = of_int\nlet to_int = Conv.nativeint_to_int\nlet to_int_exn = Conv.nativeint_to_int_exn\nlet to_int_trunc = Conv.nativeint_to_int_trunc\nlet of_int32 = Conv.int32_to_nativeint\nlet of_int32_exn = of_int32\nlet to_int32 = Conv.nativeint_to_int32\nlet to_int32_exn = Conv.nativeint_to_int32_exn\nlet to_int32_trunc = Conv.nativeint_to_int32_trunc\nlet of_int64 = Conv.int64_to_nativeint\nlet of_int64_exn = Conv.int64_to_nativeint_exn\nlet of_int64_trunc = Conv.int64_to_nativeint_trunc\nlet to_int64 = Conv.nativeint_to_int64\nlet pow b e = of_int_exn (Int_math.Private.int_pow (to_int_exn b) (to_int_exn e))\nlet ( ** ) b e = pow b e\n\nmodule Pre_O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Nativeint_replace_polymorphic_compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int_exn = of_int_exn\nend\n\nmodule O = struct\n include Pre_O\n\n include Int_math.Make (struct\n type nonrec t = t\n\n include Pre_O\n\n let rem = rem\n let to_float = to_float\n let of_float = of_float\n let of_string = T.of_string\n let to_string = T.to_string\n end)\n\n let ( land ) = bit_and\n let ( lor ) = bit_or\n let ( lxor ) = bit_xor\n let lnot = bit_not\n let ( lsl ) = shift_left\n let ( asr ) = shift_right\n let ( lsr ) = shift_right_logical\nend\n\ninclude O\n\n(* [Nativeint] and [Nativeint.O] agree value-wise *)\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Nativeint_replace_polymorphic_compare\n\nexternal bswap : t -> t = \"%bswap_native\"\n","(***********************************************************************)\n(* *)\n(* Objective Caml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. All rights reserved. This file is distributed *)\n(* under the terms of the Apache 2.0 license. See ../THIRD-PARTY.txt *)\n(* for details. *)\n(* *)\n(***********************************************************************)\n\nopen! Import\nmodule List = List0\n\ninclude (\n Map_intf :\n sig\n module Or_duplicate = Map_intf.Or_duplicate\n module Continue_or_stop = Map_intf.Continue_or_stop\n module With_comparator = Map_intf.With_comparator\n module With_first_class_module = Map_intf.With_first_class_module\n module Without_comparator = Map_intf.Without_comparator\n\n (* The module susbstitutions below are needed for older versions of OCaml\n (before 4.07), because back then [module type of] did not keep module\n aliases. *)\n\n include module type of struct\n include Map_intf\n end\n with module Finished_or_unfinished := Map_intf.Finished_or_unfinished\n and module Or_duplicate := Or_duplicate\n and module Continue_or_stop := Continue_or_stop\n and module With_comparator := With_comparator\n and module With_first_class_module := With_first_class_module\n and module Without_comparator := Without_comparator\n end)\n\nmodule Finished_or_unfinished = struct\n include Map_intf.Finished_or_unfinished\n\n (* These two functions are tested in [test_map.ml] to make sure our use of\n [Caml.Obj.magic] is correct and safe. *)\n let of_continue_or_stop : Continue_or_stop.t -> t = Caml.Obj.magic\n let to_continue_or_stop : t -> Continue_or_stop.t = Caml.Obj.magic\nend\n\nlet with_return = With_return.with_return\n\nexception Duplicate [@@deriving_inline sexp]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add [%extension_constructor Duplicate] (function\n | Duplicate -> Ppx_sexp_conv_lib.Sexp.Atom \"map.ml.Duplicate\"\n | _ -> assert false)\n;;\n\n[@@@end]\n\nmodule Tree0 = struct\n type ('k, 'v) t =\n | Empty\n | Leaf of 'k * 'v\n | Node of ('k, 'v) t * 'k * 'v * ('k, 'v) t * int\n\n type ('k, 'v) tree = ('k, 'v) t\n\n let height = function\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, h) -> h\n ;;\n\n let invariants =\n let in_range lower upper compare_key k =\n (match lower with\n | None -> true\n | Some lower -> compare_key lower k < 0)\n &&\n match upper with\n | None -> true\n | Some upper -> compare_key k upper < 0\n in\n let rec loop lower upper compare_key t =\n match t with\n | Empty -> true\n | Leaf (k, _) -> in_range lower upper compare_key k\n | Node (l, k, _, r, h) ->\n let hl = height l\n and hr = height r in\n abs (hl - hr) <= 2\n && h = max hl hr + 1\n && in_range lower upper compare_key k\n && loop lower (Some k) compare_key l\n && loop (Some k) upper compare_key r\n in\n fun t ~compare_key -> loop None None compare_key t\n ;;\n\n (* precondition: |height(l) - height(r)| <= 2 *)\n let create l x d r =\n let hl = height l\n and hr = height r in\n if hl = 0 && hr = 0\n then Leaf (x, d)\n else Node (l, x, d, r, if hl >= hr then hl + 1 else hr + 1)\n ;;\n\n let singleton key data = Leaf (key, data)\n\n (* We must call [f] with increasing indexes, because the bin_prot reader in\n Core_kernel.Map needs it. *)\n let of_increasing_iterator_unchecked ~len ~f =\n let rec loop n ~f i : (_, _) t =\n match n with\n | 0 -> Empty\n | 1 ->\n let k, v = f i in\n Leaf (k, v)\n | 2 ->\n let kl, vl = f i in\n let k, v = f (i + 1) in\n Node (Leaf (kl, vl), k, v, Empty, 2)\n | 3 ->\n let kl, vl = f i in\n let k, v = f (i + 1) in\n let kr, vr = f (i + 2) in\n Node (Leaf (kl, vl), k, v, Leaf (kr, vr), 2)\n | n ->\n let left_length = n lsr 1 in\n let right_length = n - left_length - 1 in\n let left = loop left_length ~f i in\n let k, v = f (i + left_length) in\n let right = loop right_length ~f (i + left_length + 1) in\n create left k v right\n in\n loop len ~f 0\n ;;\n\n let of_sorted_array_unchecked array ~compare_key =\n let array_length = Array.length array in\n let next =\n if array_length < 2\n ||\n let k0, _ = array.(0) in\n let k1, _ = array.(1) in\n compare_key k0 k1 < 0\n then fun i -> array.(i)\n else fun i -> array.(array_length - 1 - i)\n in\n of_increasing_iterator_unchecked ~len:array_length ~f:next, array_length\n ;;\n\n let of_sorted_array array ~compare_key =\n match array with\n | [||] | [| _ |] -> Result.Ok (of_sorted_array_unchecked array ~compare_key)\n | _ ->\n with_return (fun r ->\n let increasing =\n match compare_key (fst array.(0)) (fst array.(1)) with\n | 0 ->\n r.return (Or_error.error_string \"of_sorted_array: duplicated elements\")\n | i -> i < 0\n in\n for i = 1 to Array.length array - 2 do\n match compare_key (fst array.(i)) (fst array.(i + 1)) with\n | 0 ->\n r.return (Or_error.error_string \"of_sorted_array: duplicated elements\")\n | i ->\n if Poly.( <> ) (i < 0) increasing\n then\n r.return\n (Or_error.error_string \"of_sorted_array: elements are not ordered\")\n done;\n Result.Ok (of_sorted_array_unchecked array ~compare_key))\n ;;\n\n (* precondition: |height(l) - height(r)| <= 3 *)\n let bal l x d r =\n let hl = height l in\n let hr = height r in\n if hl > hr + 2\n then (\n match l with\n | Empty -> invalid_arg \"Map.bal\"\n | Leaf _ -> assert false (* height(Leaf) = 1 && 1 is not larger than hr + 2 *)\n | Node (ll, lv, ld, lr, _) ->\n if height ll >= height lr\n then create ll lv ld (create lr x d r)\n else (\n match lr with\n | Empty -> invalid_arg \"Map.bal\"\n | Leaf (lrv, lrd) ->\n create (create ll lv ld Empty) lrv lrd (create Empty x d r)\n | Node (lrl, lrv, lrd, lrr, _) ->\n create (create ll lv ld lrl) lrv lrd (create lrr x d r)))\n else if hr > hl + 2\n then (\n match r with\n | Empty -> invalid_arg \"Map.bal\"\n | Leaf _ -> assert false (* height(Leaf) = 1 && 1 is not larger than hl + 2 *)\n | Node (rl, rv, rd, rr, _) ->\n if height rr >= height rl\n then create (create l x d rl) rv rd rr\n else (\n match rl with\n | Empty -> invalid_arg \"Map.bal\"\n | Leaf (rlv, rld) ->\n create (create l x d Empty) rlv rld (create Empty rv rd rr)\n | Node (rll, rlv, rld, rlr, _) ->\n create (create l x d rll) rlv rld (create rlr rv rd rr)))\n else create l x d r\n ;;\n\n let empty = Empty\n\n let is_empty = function\n | Empty -> true\n | _ -> false\n ;;\n\n let raise_key_already_present ~key ~sexp_of_key =\n Error.raise_s\n (Sexp.message \"[Map.add_exn] got key already present\" [ \"key\", key |> sexp_of_key ])\n ;;\n\n module Add_or_set = struct\n type t =\n | Add_exn_internal\n | Add_exn\n | Set\n end\n\n\n let rec find_and_add_or_set\n t\n ~length\n ~key:x\n ~data\n ~compare_key\n ~sexp_of_key\n ~(add_or_set : Add_or_set.t)\n =\n match t with\n | Empty -> Leaf (x, data), length + 1\n | Leaf (v, d) ->\n let c = compare_key x v in\n if c = 0\n then (\n match add_or_set with\n | Add_exn_internal -> Exn.raise_without_backtrace Duplicate\n | Add_exn -> raise_key_already_present ~key:x ~sexp_of_key\n | Set -> Leaf (x, data), length)\n else if c < 0\n then Node (Leaf (x, data), v, d, Empty, 2), length + 1\n else Node (Empty, v, d, Leaf (x, data), 2), length + 1\n | Node (l, v, d, r, h) ->\n let c = compare_key x v in\n if c = 0\n then (\n match add_or_set with\n | Add_exn_internal -> Exn.raise_without_backtrace Duplicate\n | Add_exn -> raise_key_already_present ~key:x ~sexp_of_key\n | Set -> Node (l, x, data, r, h), length)\n else if c < 0\n then (\n let l, length =\n find_and_add_or_set\n ~length\n ~key:x\n ~data\n l\n ~compare_key\n ~sexp_of_key\n ~add_or_set\n in\n bal l v d r, length)\n else (\n let r, length =\n find_and_add_or_set\n ~length\n ~key:x\n ~data\n r\n ~compare_key\n ~sexp_of_key\n ~add_or_set\n in\n bal l v d r, length)\n ;;\n\n let add_exn t ~length ~key ~data ~compare_key ~sexp_of_key =\n find_and_add_or_set\n t\n ~length\n ~key\n ~data\n ~compare_key\n ~sexp_of_key\n ~add_or_set:Add_exn\n ;;\n\n let add_exn_internal t ~length ~key ~data ~compare_key ~sexp_of_key =\n find_and_add_or_set\n t\n ~length\n ~key\n ~data\n ~compare_key\n ~sexp_of_key\n ~add_or_set:Add_exn_internal\n ;;\n\n let set t ~length ~key ~data ~compare_key =\n find_and_add_or_set\n t\n ~length\n ~key\n ~data\n ~compare_key\n ~sexp_of_key:(fun _ -> List [])\n ~add_or_set:Set\n ;;\n\n let set' t key data ~compare_key = fst (set t ~length:0 ~key ~data ~compare_key)\n\n module Build_increasing = struct\n module Fragment = struct\n type nonrec ('k, 'v) t =\n { left_subtree : ('k, 'v) t\n ; key : 'k\n ; data : 'v\n }\n\n let singleton_to_tree_exn = function\n | { left_subtree = Empty; key; data } -> singleton key data\n | _ -> failwith \"Map.singleton_to_tree_exn: not a singleton\"\n ;;\n\n let singleton ~key ~data = { left_subtree = Empty; key; data }\n\n (* precondition: |height(l.left_subtree) - height(r)| <= 2,\n max_key(l) < min_key(r)\n *)\n let collapse l r = create l.left_subtree l.key l.data r\n\n (* precondition: |height(l.left_subtree) - height(r.left_subtree)| <= 2,\n max_key(l) < min_key(r)\n *)\n let join l r = { r with left_subtree = collapse l r.left_subtree }\n let max_key t = t.key\n end\n\n (** Build trees from singletons in a balanced way by using skew binary encoding.\n Each level contains trees of the same height, consecutive levels have consecutive\n heights. There are no gaps. The first level are single keys.\n *)\n type ('k, 'v) t =\n | Zero of unit\n (* [unit] to make pattern matching faster *)\n | One of ('k, 'v) t * ('k, 'v) Fragment.t\n | Two of ('k, 'v) t * ('k, 'v) Fragment.t * ('k, 'v) Fragment.t\n\n let empty = Zero ()\n\n let add_unchecked =\n let rec go t x =\n match t with\n | Zero () -> One (t, x)\n | One (t, y) -> Two (t, y, x)\n | Two (t, z, y) -> One (go t (Fragment.join z y), x)\n in\n fun t ~key ~data -> go t (Fragment.singleton ~key ~data)\n ;;\n\n let to_tree =\n let rec go t r =\n match t with\n | Zero () -> r\n | One (t, l) -> go t (Fragment.collapse l r)\n | Two (t, ll, l) -> go t (Fragment.collapse (Fragment.join ll l) r)\n in\n function\n | Zero () -> Empty\n | One (t, r) -> go t (Fragment.singleton_to_tree_exn r)\n | Two (t, l, r) -> go (One (t, l)) (Fragment.singleton_to_tree_exn r)\n ;;\n\n let max_key = function\n | Zero () -> None\n | One (_, r) | Two (_, _, r) -> Some (Fragment.max_key r)\n ;;\n end\n\n let of_increasing_sequence seq ~compare_key =\n with_return (fun { return } ->\n let builder, length =\n Sequence.fold\n seq\n ~init:(Build_increasing.empty, 0)\n ~f:(fun (builder, length) (key, data) ->\n match Build_increasing.max_key builder with\n | Some prev_key when compare_key prev_key key >= 0 ->\n return\n (Or_error.error_string \"of_increasing_sequence: non-increasing key\")\n | _ -> Build_increasing.add_unchecked builder ~key ~data, length + 1)\n in\n Ok (Build_increasing.to_tree builder, length))\n ;;\n\n (* Like [bal] but allows any difference in height between [l] and [r].\n\n O(|height l - height r|) *)\n let rec join l k d r ~compare_key =\n match l, r with\n | Empty, _ -> set' r k d ~compare_key\n | _, Empty -> set' l k d ~compare_key\n | Leaf (lk, ld), _ -> set' (set' r k d ~compare_key) lk ld ~compare_key\n | _, Leaf (rk, rd) -> set' (set' l k d ~compare_key) rk rd ~compare_key\n | Node (ll, lk, ld, lr, lh), Node (rl, rk, rd, rr, rh) ->\n (* [bal] requires height difference <= 3. *)\n if lh > rh + 3\n (* [height lr >= height r],\n therefore [height (join lr k d r ...)] is [height rl + 1] or [height rl]\n therefore the height difference with [ll] will be <= 3 *)\n then bal ll lk ld (join lr k d r ~compare_key)\n else if rh > lh + 3\n then bal (join l k d rl ~compare_key) rk rd rr\n else bal l k d r\n ;;\n\n let rec split t x ~compare_key =\n match t with\n | Empty -> Empty, None, Empty\n | Leaf (k, d) ->\n let cmp = compare_key x k in\n if cmp = 0\n then Empty, Some (k, d), Empty\n else if cmp < 0\n then Empty, None, t\n else t, None, Empty\n | Node (l, k, d, r, _) ->\n let cmp = compare_key x k in\n if cmp = 0\n then l, Some (k, d), r\n else if cmp < 0\n then (\n let ll, maybe, lr = split l x ~compare_key in\n ll, maybe, join lr k d r ~compare_key)\n else (\n let rl, maybe, rr = split r x ~compare_key in\n join l k d rl ~compare_key, maybe, rr)\n ;;\n\n let split_and_reinsert_boundary t ~into x ~compare_key =\n let left, boundary_opt, right = split t x ~compare_key in\n match boundary_opt with\n | None -> left, right\n | Some (key, data) ->\n let insert_into tree = fst (set tree ~key ~data ~length:0 ~compare_key) in\n (match into with\n | `Left -> insert_into left, right\n | `Right -> left, insert_into right)\n ;;\n\n let split_range\n t\n ~(lower_bound : 'a Maybe_bound.t)\n ~(upper_bound : 'a Maybe_bound.t)\n ~compare_key\n =\n if Maybe_bound.bounds_crossed\n ~compare:compare_key\n ~lower:lower_bound\n ~upper:upper_bound\n then empty, empty, empty\n else (\n let left, mid_and_right =\n match lower_bound with\n | Unbounded -> empty, t\n | Incl lb -> split_and_reinsert_boundary ~into:`Right t lb ~compare_key\n | Excl lb -> split_and_reinsert_boundary ~into:`Left t lb ~compare_key\n in\n let mid, right =\n match upper_bound with\n | Unbounded -> mid_and_right, empty\n | Incl lb ->\n split_and_reinsert_boundary ~into:`Left mid_and_right lb ~compare_key\n | Excl lb ->\n split_and_reinsert_boundary ~into:`Right mid_and_right lb ~compare_key\n in\n left, mid, right)\n ;;\n\n let rec find t x ~compare_key =\n match t with\n | Empty -> None\n | Leaf (v, d) -> if compare_key x v = 0 then Some d else None\n | Node (l, v, d, r, _) ->\n let c = compare_key x v in\n if c = 0 then Some d else find (if c < 0 then l else r) x ~compare_key\n ;;\n\n let add_multi t ~length ~key ~data ~compare_key =\n let data = data :: Option.value (find t key ~compare_key) ~default:[] in\n set ~length ~key ~data t ~compare_key\n ;;\n\n let find_multi t x ~compare_key =\n match find t x ~compare_key with\n | None -> []\n | Some l -> l\n ;;\n\n let find_exn =\n let if_not_found key ~sexp_of_key =\n raise (Not_found_s (List [ Atom \"Map.find_exn: not found\"; sexp_of_key key ]))\n in\n let rec find_exn t x ~compare_key ~sexp_of_key =\n match t with\n | Empty -> if_not_found x ~sexp_of_key\n | Leaf (v, d) -> if compare_key x v = 0 then d else if_not_found x ~sexp_of_key\n | Node (l, v, d, r, _) ->\n let c = compare_key x v in\n if c = 0\n then d\n else find_exn (if c < 0 then l else r) x ~compare_key ~sexp_of_key\n in\n (* named to preserve symbol in compiled binary *)\n find_exn\n ;;\n\n let mem t x ~compare_key = Option.is_some (find t x ~compare_key)\n\n let rec min_elt = function\n | Empty -> None\n | Leaf (k, d) -> Some (k, d)\n | Node (Empty, k, d, _, _) -> Some (k, d)\n | Node (l, _, _, _, _) -> min_elt l\n ;;\n\n exception Map_min_elt_exn_of_empty_map [@@deriving_inline sexp]\n\n let () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Map_min_elt_exn_of_empty_map]\n (function\n | Map_min_elt_exn_of_empty_map ->\n Ppx_sexp_conv_lib.Sexp.Atom \"map.ml.Tree0.Map_min_elt_exn_of_empty_map\"\n | _ -> assert false)\n ;;\n\n [@@@end]\n\n exception Map_max_elt_exn_of_empty_map [@@deriving_inline sexp]\n\n let () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Map_max_elt_exn_of_empty_map]\n (function\n | Map_max_elt_exn_of_empty_map ->\n Ppx_sexp_conv_lib.Sexp.Atom \"map.ml.Tree0.Map_max_elt_exn_of_empty_map\"\n | _ -> assert false)\n ;;\n\n [@@@end]\n\n let min_elt_exn t =\n match min_elt t with\n | None -> raise Map_min_elt_exn_of_empty_map\n | Some v -> v\n ;;\n\n let rec max_elt = function\n | Empty -> None\n | Leaf (k, d) -> Some (k, d)\n | Node (_, k, d, Empty, _) -> Some (k, d)\n | Node (_, _, _, r, _) -> max_elt r\n ;;\n\n let max_elt_exn t =\n match max_elt t with\n | None -> raise Map_max_elt_exn_of_empty_map\n | Some v -> v\n ;;\n\n let rec remove_min_elt t =\n match t with\n | Empty -> invalid_arg \"Map.remove_min_elt\"\n | Leaf _ -> Empty\n | Node (Empty, _, _, r, _) -> r\n | Node (l, x, d, r, _) -> bal (remove_min_elt l) x d r\n ;;\n\n let append ~lower_part ~upper_part ~compare_key =\n match max_elt lower_part, min_elt upper_part with\n | None, _ -> `Ok upper_part\n | _, None -> `Ok lower_part\n | Some (max_lower, _), Some (min_upper, v) when compare_key max_lower min_upper < 0\n ->\n let upper_part_without_min = remove_min_elt upper_part in\n `Ok (join ~compare_key lower_part min_upper v upper_part_without_min)\n | _ -> `Overlapping_key_ranges\n ;;\n\n let fold_range_inclusive =\n (* This assumes that min <= max, which is checked by the outer function. *)\n let rec go t ~min ~max ~init ~f ~compare_key =\n match t with\n | Empty -> init\n | Leaf (k, d) ->\n if compare_key k min < 0 || compare_key k max > 0\n then (* k < min || k > max *)\n init\n else f ~key:k ~data:d init\n | Node (l, k, d, r, _) ->\n let c_min = compare_key k min in\n if c_min < 0\n then\n (* if k < min, then this node and its left branch are outside our range *)\n go r ~min ~max ~init ~f ~compare_key\n else if c_min = 0\n then\n (* if k = min, then this node's left branch is outside our range *)\n go r ~min ~max ~init:(f ~key:k ~data:d init) ~f ~compare_key\n else (\n (* k > min *)\n let z = go l ~min ~max ~init ~f ~compare_key in\n let c_max = compare_key k max in\n (* if k > max, we're done *)\n if c_max > 0\n then z\n else (\n let z = f ~key:k ~data:d z in\n (* if k = max, then we fold in this one last value and we're done *)\n if c_max = 0 then z else go r ~min ~max ~init:z ~f ~compare_key))\n in\n fun t ~min ~max ~init ~f ~compare_key ->\n if compare_key min max <= 0 then go t ~min ~max ~init ~f ~compare_key else init\n ;;\n\n let range_to_alist t ~min ~max ~compare_key =\n List.rev\n (fold_range_inclusive\n t\n ~min\n ~max\n ~init:[]\n ~f:(fun ~key ~data l -> (key, data) :: l)\n ~compare_key)\n ;;\n\n let concat_unchecked t1 t2 =\n match t1, t2 with\n | Empty, t -> t\n | t, Empty -> t\n | _, _ ->\n let x, d = min_elt_exn t2 in\n bal t1 x d (remove_min_elt t2)\n ;;\n\n let rec remove t x ~length ~compare_key =\n match t with\n | Empty -> Empty, length\n | Leaf (v, _) -> if compare_key x v = 0 then Empty, length - 1 else t, length\n | Node (l, v, d, r, _) ->\n let c = compare_key x v in\n if c = 0\n then concat_unchecked l r, length - 1\n else if c < 0\n then (\n let l, length = remove l x ~length ~compare_key in\n bal l v d r, length)\n else (\n let r, length = remove r x ~length ~compare_key in\n bal l v d r, length)\n ;;\n\n (* Use exception to avoid tree-rebuild in no-op case *)\n exception Change_no_op\n\n let change t key ~f ~length ~compare_key =\n let rec change_core t key f =\n match t with\n | Empty ->\n (match f None with\n | None -> raise Change_no_op (* equivalent to returning: Empty *)\n | Some data -> Leaf (key, data), length + 1)\n | Leaf (v, d) ->\n let c = compare_key key v in\n if c = 0\n then (\n match f (Some d) with\n | None -> Empty, length - 1\n | Some d' -> Leaf (v, d'), length)\n else if c < 0\n then (\n let l, length = change_core Empty key f in\n bal l v d Empty, length)\n else (\n let r, length = change_core Empty key f in\n bal Empty v d r, length)\n | Node (l, v, d, r, h) ->\n let c = compare_key key v in\n if c = 0\n then (\n match f (Some d) with\n | None -> concat_unchecked l r, length - 1\n | Some data -> Node (l, key, data, r, h), length)\n else if c < 0\n then (\n let l, length = change_core l key f in\n bal l v d r, length)\n else (\n let r, length = change_core r key f in\n bal l v d r, length)\n in\n try change_core t key f with\n | Change_no_op -> t, length\n ;;\n\n let update t key ~f ~length ~compare_key =\n let rec update_core t key f =\n match t with\n | Empty ->\n let data = f None in\n Leaf (key, data), length + 1\n | Leaf (v, d) ->\n let c = compare_key key v in\n if c = 0\n then (\n let d' = f (Some d) in\n Leaf (v, d'), length)\n else if c < 0\n then (\n let l, length = update_core Empty key f in\n bal l v d Empty, length)\n else (\n let r, length = update_core Empty key f in\n bal Empty v d r, length)\n | Node (l, v, d, r, h) ->\n let c = compare_key key v in\n if c = 0\n then (\n let data = f (Some d) in\n Node (l, key, data, r, h), length)\n else if c < 0\n then (\n let l, length = update_core l key f in\n bal l v d r, length)\n else (\n let r, length = update_core r key f in\n bal l v d r, length)\n in\n update_core t key f\n ;;\n\n let remove_multi t key ~length ~compare_key =\n change t key ~length ~compare_key ~f:(function\n | None | Some ([] | [ _ ]) -> None\n | Some (_ :: (_ :: _ as non_empty_tail)) -> Some non_empty_tail)\n ;;\n\n let rec iter_keys t ~f =\n match t with\n | Empty -> ()\n | Leaf (v, _) -> f v\n | Node (l, v, _, r, _) ->\n iter_keys ~f l;\n f v;\n iter_keys ~f r\n ;;\n\n let rec iter t ~f =\n match t with\n | Empty -> ()\n | Leaf (_, d) -> f d\n | Node (l, _, d, r, _) ->\n iter ~f l;\n f d;\n iter ~f r\n ;;\n\n let rec iteri t ~f =\n match t with\n | Empty -> ()\n | Leaf (v, d) -> f ~key:v ~data:d\n | Node (l, v, d, r, _) ->\n iteri ~f l;\n f ~key:v ~data:d;\n iteri ~f r\n ;;\n\n let iteri_until =\n let rec iteri_until_loop t ~f : Continue_or_stop.t =\n match t with\n | Empty -> Continue\n | Leaf (v, d) -> f ~key:v ~data:d\n | Node (l, v, d, r, _) ->\n (match iteri_until_loop ~f l with\n | Stop -> Stop\n | Continue ->\n (match f ~key:v ~data:d with\n | Stop -> Stop\n | Continue -> iteri_until_loop ~f r))\n in\n fun t ~f -> Finished_or_unfinished.of_continue_or_stop (iteri_until_loop t ~f)\n ;;\n\n let rec map t ~f =\n match t with\n | Empty -> Empty\n | Leaf (v, d) -> Leaf (v, f d)\n | Node (l, v, d, r, h) ->\n let l' = map ~f l in\n let d' = f d in\n let r' = map ~f r in\n Node (l', v, d', r', h)\n ;;\n\n let rec mapi t ~f =\n match t with\n | Empty -> Empty\n | Leaf (v, d) -> Leaf (v, f ~key:v ~data:d)\n | Node (l, v, d, r, h) ->\n let l' = mapi ~f l in\n let d' = f ~key:v ~data:d in\n let r' = mapi ~f r in\n Node (l', v, d', r', h)\n ;;\n\n let rec fold t ~init:accu ~f =\n match t with\n | Empty -> accu\n | Leaf (v, d) -> f ~key:v ~data:d accu\n | Node (l, v, d, r, _) -> fold ~f r ~init:(f ~key:v ~data:d (fold ~f l ~init:accu))\n ;;\n\n let rec fold_right t ~init:accu ~f =\n match t with\n | Empty -> accu\n | Leaf (v, d) -> f ~key:v ~data:d accu\n | Node (l, v, d, r, _) ->\n fold_right ~f l ~init:(f ~key:v ~data:d (fold_right ~f r ~init:accu))\n ;;\n\n let filter_keys t ~f ~compare_key =\n fold ~init:(Empty, 0) t ~f:(fun ~key ~data (accu, length) ->\n if f key then set ~length ~key ~data accu ~compare_key else accu, length)\n ;;\n\n\n let filter t ~f ~compare_key =\n fold ~init:(Empty, 0) t ~f:(fun ~key ~data (accu, length) ->\n if f data then set ~length ~key ~data accu ~compare_key else accu, length)\n ;;\n\n let filteri t ~f ~compare_key =\n fold ~init:(Empty, 0) t ~f:(fun ~key ~data (accu, length) ->\n if f ~key ~data then set ~length ~key ~data accu ~compare_key else accu, length)\n ;;\n\n let filter_map t ~f ~compare_key =\n fold ~init:(Empty, 0) t ~f:(fun ~key ~data (accu, length) ->\n match f data with\n | None -> accu, length\n | Some b -> set ~length ~key ~data:b accu ~compare_key)\n ;;\n\n let filter_mapi t ~f ~compare_key =\n fold ~init:(Empty, 0) t ~f:(fun ~key ~data (accu, length) ->\n match f ~key ~data with\n | None -> accu, length\n | Some b -> set ~length ~key ~data:b accu ~compare_key)\n ;;\n\n let partition_mapi t ~f ~compare_key =\n fold\n t\n ~init:((Empty, 0), (Empty, 0))\n ~f:(fun ~key ~data (pair1, pair2) ->\n match (f ~key ~data : _ Either.t) with\n | First x ->\n let t, length = pair1 in\n set t ~key ~data:x ~compare_key ~length, pair2\n | Second y ->\n let t, length = pair2 in\n pair1, set t ~key ~data:y ~compare_key ~length)\n ;;\n\n let partition_map t ~f ~compare_key =\n partition_mapi t ~compare_key ~f:(fun ~key:_ ~data -> f data)\n ;;\n\n let partitioni_tf t ~f ~compare_key =\n partition_mapi t ~compare_key ~f:(fun ~key ~data ->\n if f ~key ~data then First data else Second data)\n ;;\n\n let partition_tf t ~f ~compare_key =\n partition_mapi t ~compare_key ~f:(fun ~key:_ ~data ->\n if f data then First data else Second data)\n ;;\n\n module Enum = struct\n type increasing\n type decreasing\n\n type ('k, 'v, 'direction) t =\n | End\n | More of 'k * 'v * ('k, 'v) tree * ('k, 'v, 'direction) t\n\n let rec cons t (e : (_, _, increasing) t) : (_, _, increasing) t =\n match t with\n | Empty -> e\n | Leaf (v, d) -> More (v, d, Empty, e)\n | Node (l, v, d, r, _) -> cons l (More (v, d, r, e))\n ;;\n\n let rec cons_right t (e : (_, _, decreasing) t) : (_, _, decreasing) t =\n match t with\n | Empty -> e\n | Leaf (v, d) -> More (v, d, Empty, e)\n | Node (l, v, d, r, _) -> cons_right r (More (v, d, l, e))\n ;;\n\n let of_tree tree : (_, _, increasing) t = cons tree End\n let of_tree_right tree : (_, _, decreasing) t = cons_right tree End\n\n let starting_at_increasing t key compare : (_, _, increasing) t =\n let rec loop t e =\n match t with\n | Empty -> e\n | Leaf (v, d) -> loop (Node (Empty, v, d, Empty, 1)) e\n | Node (_, v, _, r, _) when compare v key < 0 -> loop r e\n | Node (l, v, d, r, _) -> loop l (More (v, d, r, e))\n in\n loop t End\n ;;\n\n let starting_at_decreasing t key compare : (_, _, decreasing) t =\n let rec loop t e =\n match t with\n | Empty -> e\n | Leaf (v, d) -> loop (Node (Empty, v, d, Empty, 1)) e\n | Node (l, v, _, _, _) when compare v key > 0 -> loop l e\n | Node (l, v, d, r, _) -> loop r (More (v, d, l, e))\n in\n loop t End\n ;;\n\n let compare compare_key compare_data t1 t2 =\n let rec loop t1 t2 =\n match t1, t2 with\n | End, End -> 0\n | End, _ -> -1\n | _, End -> 1\n | More (v1, d1, r1, e1), More (v2, d2, r2, e2) ->\n let c = compare_key v1 v2 in\n if c <> 0\n then c\n else (\n let c = compare_data d1 d2 in\n if c <> 0\n then c\n else if phys_equal r1 r2\n then loop e1 e2\n else loop (cons r1 e1) (cons r2 e2))\n in\n loop t1 t2\n ;;\n\n let equal compare_key data_equal t1 t2 =\n let rec loop t1 t2 =\n match t1, t2 with\n | End, End -> true\n | End, _ | _, End -> false\n | More (v1, d1, r1, e1), More (v2, d2, r2, e2) ->\n compare_key v1 v2 = 0\n && data_equal d1 d2\n && if phys_equal r1 r2 then loop e1 e2 else loop (cons r1 e1) (cons r2 e2)\n in\n loop t1 t2\n ;;\n\n let rec fold ~init ~f = function\n | End -> init\n | More (key, data, tree, enum) ->\n let next = f ~key ~data init in\n fold (cons tree enum) ~init:next ~f\n ;;\n\n let fold2 compare_key t1 t2 ~init ~f =\n let rec loop t1 t2 curr =\n match t1, t2 with\n | End, End -> curr\n | End, _ ->\n fold t2 ~init:curr ~f:(fun ~key ~data acc -> f ~key ~data:(`Right data) acc)\n | _, End ->\n fold t1 ~init:curr ~f:(fun ~key ~data acc -> f ~key ~data:(`Left data) acc)\n | More (k1, v1, tree1, enum1), More (k2, v2, tree2, enum2) ->\n let compare_result = compare_key k1 k2 in\n if compare_result = 0\n then (\n let next = f ~key:k1 ~data:(`Both (v1, v2)) curr in\n loop (cons tree1 enum1) (cons tree2 enum2) next)\n else if compare_result < 0\n then (\n let next = f ~key:k1 ~data:(`Left v1) curr in\n loop (cons tree1 enum1) t2 next)\n else (\n let next = f ~key:k2 ~data:(`Right v2) curr in\n loop t1 (cons tree2 enum2) next)\n in\n loop t1 t2 init\n ;;\n\n let symmetric_diff t1 t2 ~compare_key ~data_equal =\n let step state =\n match state with\n | End, End -> Sequence.Step.Done\n | End, More (key, data, tree, enum) ->\n Sequence.Step.Yield ((key, `Right data), (End, cons tree enum))\n | More (key, data, tree, enum), End ->\n Sequence.Step.Yield ((key, `Left data), (cons tree enum, End))\n | (More (k1, v1, tree1, enum1) as left), (More (k2, v2, tree2, enum2) as right)\n ->\n let compare_result = compare_key k1 k2 in\n if compare_result = 0\n then (\n let next_state =\n if phys_equal tree1 tree2\n then enum1, enum2\n else cons tree1 enum1, cons tree2 enum2\n in\n if data_equal v1 v2\n then Sequence.Step.Skip next_state\n else Sequence.Step.Yield ((k1, `Unequal (v1, v2)), next_state))\n else if compare_result < 0\n then Sequence.Step.Yield ((k1, `Left v1), (cons tree1 enum1, right))\n else Sequence.Step.Yield ((k2, `Right v2), (left, cons tree2 enum2))\n in\n Sequence.unfold_step ~init:(of_tree t1, of_tree t2) ~f:step\n ;;\n\n let fold_symmetric_diff t1 t2 ~compare_key ~data_equal ~init ~f =\n let add acc k v = f acc (k, `Right v) in\n let remove acc k v = f acc (k, `Left v) in\n let rec loop left right acc =\n match left, right with\n | End, enum -> fold enum ~init:acc ~f:(fun ~key ~data acc -> add acc key data)\n | enum, End -> fold enum ~init:acc ~f:(fun ~key ~data acc -> remove acc key data)\n | (More (k1, v1, tree1, enum1) as left), (More (k2, v2, tree2, enum2) as right)\n ->\n let compare_result = compare_key k1 k2 in\n if compare_result = 0\n then (\n let acc = if data_equal v1 v2 then acc else f acc (k1, `Unequal (v1, v2)) in\n if phys_equal tree1 tree2\n then loop enum1 enum2 acc\n else loop (cons tree1 enum1) (cons tree2 enum2) acc)\n else if compare_result < 0\n then (\n let acc = remove acc k1 v1 in\n loop (cons tree1 enum1) right acc)\n else (\n let acc = add acc k2 v2 in\n loop left (cons tree2 enum2) acc)\n in\n loop (of_tree t1) (of_tree t2) init\n ;;\n end\n\n let to_sequence_increasing comparator ~from_key t =\n let next enum =\n match enum with\n | Enum.End -> Sequence.Step.Done\n | Enum.More (k, v, t, e) -> Sequence.Step.Yield ((k, v), Enum.cons t e)\n in\n let init =\n match from_key with\n | None -> Enum.of_tree t\n | Some key -> Enum.starting_at_increasing t key comparator.Comparator.compare\n in\n Sequence.unfold_step ~init ~f:next\n ;;\n\n let to_sequence_decreasing comparator ~from_key t =\n let next enum =\n match enum with\n | Enum.End -> Sequence.Step.Done\n | Enum.More (k, v, t, e) -> Sequence.Step.Yield ((k, v), Enum.cons_right t e)\n in\n let init =\n match from_key with\n | None -> Enum.of_tree_right t\n | Some key -> Enum.starting_at_decreasing t key comparator.Comparator.compare\n in\n Sequence.unfold_step ~init ~f:next\n ;;\n\n let to_sequence\n comparator\n ?(order = `Increasing_key)\n ?keys_greater_or_equal_to\n ?keys_less_or_equal_to\n t\n =\n let inclusive_bound side t bound =\n let compare_key = comparator.Comparator.compare in\n let l, maybe, r = split t bound ~compare_key in\n let t = side (l, r) in\n match maybe with\n | None -> t\n | Some (key, data) -> set' t key data ~compare_key\n in\n match order with\n | `Increasing_key ->\n let t = Option.fold keys_less_or_equal_to ~init:t ~f:(inclusive_bound fst) in\n to_sequence_increasing comparator ~from_key:keys_greater_or_equal_to t\n | `Decreasing_key ->\n let t = Option.fold keys_greater_or_equal_to ~init:t ~f:(inclusive_bound snd) in\n to_sequence_decreasing comparator ~from_key:keys_less_or_equal_to t\n ;;\n\n let compare compare_key compare_data t1 t2 =\n Enum.compare compare_key compare_data (Enum.of_tree t1) (Enum.of_tree t2)\n ;;\n\n let equal compare_key compare_data t1 t2 =\n Enum.equal compare_key compare_data (Enum.of_tree t1) (Enum.of_tree t2)\n ;;\n\n let iter2 t1 t2 ~f ~compare_key =\n Enum.fold2\n compare_key\n (Enum.of_tree t1)\n (Enum.of_tree t2)\n ~init:()\n ~f:(fun ~key ~data () -> f ~key ~data)\n ;;\n\n let fold2 t1 t2 ~init ~f ~compare_key =\n Enum.fold2 compare_key (Enum.of_tree t1) (Enum.of_tree t2) ~f ~init\n ;;\n\n let symmetric_diff = Enum.symmetric_diff\n\n let fold_symmetric_diff t1 t2 ~compare_key ~data_equal ~init ~f =\n (* [Enum.fold_diffs] is a correct implementation of this function, but is considerably\n slower, as we have to allocate quite a lot of state to track enumeration of a tree.\n Avoid if we can.\n *)\n let slow x y ~init =\n Enum.fold_symmetric_diff x y ~compare_key ~data_equal ~f ~init\n in\n let add acc k v = f acc (k, `Right v) in\n let remove acc k v = f acc (k, `Left v) in\n let delta acc k v v' =\n if data_equal v v' then acc else f acc (k, `Unequal (v, v'))\n in\n (* If two trees have the same structure at the root (and the same key, if they're\n [Node]s) we can trivially diff each subpart in obvious ways. *)\n let rec loop t t' acc =\n if phys_equal t t'\n then acc\n else (\n match t, t' with\n | Empty, new_vals ->\n fold new_vals ~init:acc ~f:(fun ~key ~data acc -> add acc key data)\n | old_vals, Empty ->\n fold old_vals ~init:acc ~f:(fun ~key ~data acc -> remove acc key data)\n | Leaf (k, v), Leaf (k', v') ->\n (match compare_key k k' with\n | x when x = 0 -> delta acc k v v'\n | x when x < 0 ->\n let acc = remove acc k v in\n add acc k' v'\n | _ (* when x > 0 *) ->\n let acc = add acc k' v' in\n remove acc k v)\n | Node (l, k, v, r, _), Node (l', k', v', r', _) when compare_key k k' = 0 ->\n let acc = loop l l' acc in\n let acc = delta acc k v v' in\n loop r r' acc\n (* Our roots aren't the same key. Fallback to the slow mode. Trees with small\n diffs will only do this on very small parts of the tree (hopefully - if the\n overall root is rebalanced, we'll eat the whole cost, unfortunately.) *)\n | Node _, Node _ | Node _, Leaf _ | Leaf _, Node _ -> slow t t' ~init:acc)\n in\n loop t1 t2 init\n ;;\n\n let rec length = function\n | Empty -> 0\n | Leaf _ -> 1\n | Node (l, _, _, r, _) -> length l + length r + 1\n ;;\n\n let hash_fold_t_ignoring_structure hash_fold_key hash_fold_data state t =\n fold\n t\n ~init:(hash_fold_int state (length t))\n ~f:(fun ~key ~data state -> hash_fold_data (hash_fold_key state key) data)\n ;;\n\n let keys t = fold_right ~f:(fun ~key ~data:_ list -> key :: list) t ~init:[]\n let data t = fold_right ~f:(fun ~key:_ ~data list -> data :: list) t ~init:[]\n\n module type Foldable = sig\n val name : string\n\n type 'a t\n\n val fold : 'a t -> init:'b -> f:('b -> 'a -> 'b) -> 'b\n end\n\n module Of_foldable (M : Foldable) = struct\n let of_foldable_fold foldable ~init ~f ~compare_key =\n M.fold foldable ~init:(empty, 0) ~f:(fun (accum, length) (key, data) ->\n let prev_data =\n match find accum key ~compare_key with\n | None -> init\n | Some prev -> prev\n in\n let data = f prev_data data in\n set accum ~length ~key ~data ~compare_key)\n ;;\n\n let of_foldable_reduce foldable ~f ~compare_key =\n M.fold foldable ~init:(empty, 0) ~f:(fun (accum, length) (key, data) ->\n let new_data =\n match find accum key ~compare_key with\n | None -> data\n | Some prev -> f prev data\n in\n set accum ~length ~key ~data:new_data ~compare_key)\n ;;\n\n let of_foldable foldable ~compare_key =\n with_return (fun r ->\n let map =\n M.fold foldable ~init:(empty, 0) ~f:(fun (t, length) (key, data) ->\n let ((_, length') as acc) = set ~length ~key ~data t ~compare_key in\n if length = length' then r.return (`Duplicate_key key) else acc)\n in\n `Ok map)\n ;;\n\n let of_foldable_or_error foldable ~comparator =\n match of_foldable foldable ~compare_key:comparator.Comparator.compare with\n | `Ok x -> Result.Ok x\n | `Duplicate_key key ->\n Or_error.error\n (\"Map.of_\" ^ M.name ^ \"_or_error: duplicate key\")\n key\n comparator.sexp_of_t\n ;;\n\n let of_foldable_exn foldable ~comparator =\n match of_foldable foldable ~compare_key:comparator.Comparator.compare with\n | `Ok x -> x\n | `Duplicate_key key ->\n Error.create\n (\"Map.of_\" ^ M.name ^ \"_exn: duplicate key\")\n key\n comparator.sexp_of_t\n |> Error.raise\n ;;\n end\n\n module Of_alist = Of_foldable (struct\n let name = \"alist\"\n\n type 'a t = 'a list\n\n let fold = List.fold\n end)\n\n let of_alist_fold = Of_alist.of_foldable_fold\n let of_alist_reduce = Of_alist.of_foldable_reduce\n let of_alist = Of_alist.of_foldable\n let of_alist_or_error = Of_alist.of_foldable_or_error\n let of_alist_exn = Of_alist.of_foldable_exn\n\n (* Reverse the input, then fold from left to right. The resulting map uses the first\n instance of each key from the input list. The relative ordering of elements in each\n output list is the same as in the input list. *)\n let of_foldable_multi foldable ~fold ~compare_key =\n let alist = fold foldable ~init:[] ~f:(fun l x -> x :: l) in\n of_alist_fold alist ~init:[] ~f:(fun l x -> x :: l) ~compare_key\n ;;\n\n let of_alist_multi alist ~compare_key =\n of_foldable_multi alist ~fold:List.fold ~compare_key\n ;;\n\n module Of_sequence = Of_foldable (struct\n let name = \"sequence\"\n\n type 'a t = 'a Sequence.t\n\n let fold = Sequence.fold\n end)\n\n let of_sequence_fold = Of_sequence.of_foldable_fold\n let of_sequence_reduce = Of_sequence.of_foldable_reduce\n let of_sequence = Of_sequence.of_foldable\n let of_sequence_or_error = Of_sequence.of_foldable_or_error\n let of_sequence_exn = Of_sequence.of_foldable_exn\n\n let of_sequence_multi sequence ~compare_key =\n of_foldable_multi sequence ~fold:Sequence.fold ~compare_key\n ;;\n\n let for_all t ~f =\n with_return (fun r ->\n iter t ~f:(fun data -> if not (f data) then r.return false);\n true)\n ;;\n\n let for_alli t ~f =\n with_return (fun r ->\n iteri t ~f:(fun ~key ~data -> if not (f ~key ~data) then r.return false);\n true)\n ;;\n\n let exists t ~f =\n with_return (fun r ->\n iter t ~f:(fun data -> if f data then r.return true);\n false)\n ;;\n\n let existsi t ~f =\n with_return (fun r ->\n iteri t ~f:(fun ~key ~data -> if f ~key ~data then r.return true);\n false)\n ;;\n\n let count t ~f =\n fold t ~init:0 ~f:(fun ~key:_ ~data acc -> if f data then acc + 1 else acc)\n ;;\n\n let counti t ~f =\n fold t ~init:0 ~f:(fun ~key ~data acc -> if f ~key ~data then acc + 1 else acc)\n ;;\n\n let to_alist ?(key_order = `Increasing) t =\n match key_order with\n | `Increasing -> fold_right t ~init:[] ~f:(fun ~key ~data x -> (key, data) :: x)\n | `Decreasing -> fold t ~init:[] ~f:(fun ~key ~data x -> (key, data) :: x)\n ;;\n\n let merge t1 t2 ~f ~compare_key =\n let elts = Uniform_array.unsafe_create_uninitialized ~len:(length t1 + length t2) in\n let i = ref 0 in\n iter2 t1 t2 ~compare_key ~f:(fun ~key ~data:values ->\n match f ~key values with\n | Some value ->\n Uniform_array.set elts !i (key, value);\n incr i\n | None -> ());\n let len = !i in\n let get i = Uniform_array.get elts i in\n let tree = of_increasing_iterator_unchecked ~len ~f:get in\n tree, len\n ;;\n\n module Closest_key_impl = struct\n (* [marker] and [repackage] allow us to create \"logical\" options without actually\n allocating any options. Passing [Found key value] to a function is equivalent to\n passing [Some (key, value)]; passing [Missing () ()] is equivalent to passing\n [None]. *)\n type ('k, 'v, 'k_opt, 'v_opt) marker =\n | Missing : ('k, 'v, unit, unit) marker\n | Found : ('k, 'v, 'k, 'v) marker\n\n let repackage\n (type k v k_opt v_opt)\n (marker : (k, v, k_opt, v_opt) marker)\n (k : k_opt)\n (v : v_opt)\n : (k * v) option\n =\n match marker with\n | Missing -> None\n | Found -> Some (k, v)\n ;;\n\n (* The type signature is explicit here to allow polymorphic recursion. *)\n let rec loop :\n 'k 'v 'k_opt 'v_opt. ('k, 'v) tree\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'k -> compare_key:('k -> 'k -> int) -> ('k, 'v, 'k_opt, 'v_opt) marker\n -> 'k_opt -> 'v_opt -> ('k * 'v) option\n =\n fun t dir k ~compare_key found_marker found_key found_value ->\n match t with\n | Empty -> repackage found_marker found_key found_value\n | Leaf (k', v') ->\n let c = compare_key k' k in\n if match dir with\n | `Greater_or_equal_to -> c >= 0\n | `Greater_than -> c > 0\n | `Less_or_equal_to -> c <= 0\n | `Less_than -> c < 0\n then Some (k', v')\n else repackage found_marker found_key found_value\n | Node (l, k', v', r, _) ->\n let c = compare_key k' k in\n if c = 0\n then (\n (* This is a base case (no recursive call). *)\n match dir with\n | `Greater_or_equal_to | `Less_or_equal_to -> Some (k', v')\n | `Greater_than ->\n if is_empty r\n then repackage found_marker found_key found_value\n else min_elt r\n | `Less_than ->\n if is_empty l\n then repackage found_marker found_key found_value\n else max_elt l)\n else (\n (* We are guaranteed here that k' <> k. *)\n (* This is the only recursive case. *)\n match dir with\n | `Greater_or_equal_to | `Greater_than ->\n if c > 0\n then loop l dir k ~compare_key Found k' v'\n else loop r dir k ~compare_key found_marker found_key found_value\n | `Less_or_equal_to | `Less_than ->\n if c < 0\n then loop r dir k ~compare_key Found k' v'\n else loop l dir k ~compare_key found_marker found_key found_value)\n ;;\n\n let closest_key t dir k ~compare_key = loop t dir k ~compare_key Missing () ()\n end\n\n let closest_key = Closest_key_impl.closest_key\n\n let rec rank t k ~compare_key =\n match t with\n | Empty -> None\n | Leaf (k', _) -> if compare_key k' k = 0 then Some 0 else None\n | Node (l, k', _, r, _) ->\n let c = compare_key k' k in\n if c = 0\n then Some (length l)\n else if c > 0\n then rank l k ~compare_key\n else Option.map (rank r k ~compare_key) ~f:(fun rank -> rank + 1 + length l)\n ;;\n\n (* this could be implemented using [Sequence] interface but the following implementation\n allocates only 2 words and doesn't require write-barrier *)\n let rec nth' num_to_search = function\n | Empty -> None\n | Leaf (k, v) ->\n if !num_to_search = 0\n then Some (k, v)\n else (\n decr num_to_search;\n None)\n | Node (l, k, v, r, _) ->\n (match nth' num_to_search l with\n | Some _ as some -> some\n | None ->\n if !num_to_search = 0\n then Some (k, v)\n else (\n decr num_to_search;\n nth' num_to_search r))\n ;;\n\n let nth t n = nth' (ref n) t\n\n\n let rec find_first_satisfying t ~f =\n match t with\n | Empty -> None\n | Leaf (k, v) -> if f ~key:k ~data:v then Some (k, v) else None\n | Node (l, k, v, r, _) ->\n if f ~key:k ~data:v\n then (\n match find_first_satisfying l ~f with\n | None -> Some (k, v)\n | Some _ as x -> x)\n else find_first_satisfying r ~f\n ;;\n\n let rec find_last_satisfying t ~f =\n match t with\n | Empty -> None\n | Leaf (k, v) -> if f ~key:k ~data:v then Some (k, v) else None\n | Node (l, k, v, r, _) ->\n if f ~key:k ~data:v\n then (\n match find_last_satisfying r ~f with\n | None -> Some (k, v)\n | Some _ as x -> x)\n else find_last_satisfying l ~f\n ;;\n\n let binary_search t ~compare how v =\n match how with\n | `Last_strictly_less_than ->\n find_last_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v < 0)\n | `Last_less_than_or_equal_to ->\n find_last_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v <= 0)\n | `First_equal_to ->\n (match\n find_first_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v >= 0)\n with\n | Some (key, data) as pair when compare ~key ~data v = 0 -> pair\n | None | Some _ -> None)\n | `Last_equal_to ->\n (match find_last_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v <= 0) with\n | Some (key, data) as pair when compare ~key ~data v = 0 -> pair\n | None | Some _ -> None)\n | `First_greater_than_or_equal_to ->\n find_first_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v >= 0)\n | `First_strictly_greater_than ->\n find_first_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v > 0)\n ;;\n\n let binary_search_segmented t ~segment_of how =\n let is_left ~key ~data =\n match segment_of ~key ~data with\n | `Left -> true\n | `Right -> false\n in\n let is_right ~key ~data = not (is_left ~key ~data) in\n match how with\n | `Last_on_left -> find_last_satisfying t ~f:is_left\n | `First_on_right -> find_first_satisfying t ~f:is_right\n ;;\n\n type ('k, 'v) acc =\n { mutable bad_key : 'k option\n ; mutable map_length : ('k, 'v) t * int\n }\n\n let of_iteri ~iteri ~compare_key =\n let acc = { bad_key = None; map_length = empty, 0 } in\n iteri ~f:(fun ~key ~data ->\n let map, length = acc.map_length in\n let ((_, length') as pair) = set ~length ~key ~data map ~compare_key in\n if length = length' && Option.is_none acc.bad_key\n then acc.bad_key <- Some key\n else acc.map_length <- pair);\n match acc.bad_key with\n | None -> `Ok acc.map_length\n | Some key -> `Duplicate_key key\n ;;\n\n let t_of_sexp_direct key_of_sexp value_of_sexp sexp ~(comparator : _ Comparator.t) =\n let alist = list_of_sexp (pair_of_sexp key_of_sexp value_of_sexp) sexp in\n let compare_key = comparator.compare in\n match of_alist alist ~compare_key with\n | `Ok v -> v\n | `Duplicate_key k ->\n (* find the sexp of a duplicate key, so the error is narrowed to a key and not\n the whole map *)\n let alist_sexps = list_of_sexp (pair_of_sexp Fn.id Fn.id) sexp in\n let found_first_k = ref false in\n List.iter2_ok alist alist_sexps ~f:(fun (k2, _) (k2_sexp, _) ->\n if compare_key k k2 = 0\n then\n if !found_first_k\n then of_sexp_error \"Map.t_of_sexp_direct: duplicate key\" k2_sexp\n else found_first_k := true);\n assert false\n ;;\n\n let sexp_of_t sexp_of_key sexp_of_value t =\n let f ~key ~data acc = Sexp.List [ sexp_of_key key; sexp_of_value data ] :: acc in\n Sexp.List (fold_right ~f t ~init:[])\n ;;\n\n let combine_errors t ~compare_key ~sexp_of_key =\n let oks, (error_tree, _) = partition_map t ~compare_key ~f:Result.to_either in\n if is_empty error_tree\n then Ok oks\n else Or_error.error_s (sexp_of_t sexp_of_key Error.sexp_of_t error_tree)\n ;;\nend\n\ntype ('k, 'v, 'comparator) t =\n { (* [comparator] is the first field so that polymorphic equality fails on a map due\n to the functional value in the comparator.\n Note that this does not affect polymorphic [compare]: that still produces\n nonsense. *)\n comparator : ('k, 'comparator) Comparator.t\n ; tree : ('k, 'v) Tree0.t\n ; length : int\n }\n\ntype ('k, 'v, 'comparator) tree = ('k, 'v) Tree0.t\n\nlet compare_key t = t.comparator.Comparator.compare\n\n\nlet like { tree = _; length = _; comparator } (tree, length) =\n { tree; length; comparator }\n;;\n\nlet like2 x (y, z) = like x y, like x z\nlet with_same_length { tree = _; comparator; length } tree = { tree; comparator; length }\nlet of_tree ~comparator tree = { tree; comparator; length = Tree0.length tree }\n\n(* Exposing this function would make it very easy for the invariants\n of this module to be broken. *)\nlet of_tree_unsafe ~comparator ~length tree = { tree; comparator; length }\n\nmodule Accessors = struct\n let comparator t = t.comparator\n let to_tree t = t.tree\n let invariants t = Tree0.invariants t.tree ~compare_key:(compare_key t)\n let is_empty t = Tree0.is_empty t.tree\n let length t = t.length\n\n let set t ~key ~data =\n like t (Tree0.set t.tree ~length:t.length ~key ~data ~compare_key:(compare_key t))\n ;;\n\n let add_exn t ~key ~data =\n like\n t\n (Tree0.add_exn\n t.tree\n ~length:t.length\n ~key\n ~data\n ~compare_key:(compare_key t)\n ~sexp_of_key:t.comparator.sexp_of_t)\n ;;\n\n let add_exn_internal t ~key ~data =\n like\n t\n (Tree0.add_exn_internal\n t.tree\n ~length:t.length\n ~key\n ~data\n ~compare_key:(compare_key t)\n ~sexp_of_key:t.comparator.sexp_of_t)\n ;;\n\n let add t ~key ~data =\n match add_exn_internal t ~key ~data with\n | result -> `Ok result\n | exception Duplicate -> `Duplicate\n ;;\n\n let add_multi t ~key ~data =\n like\n t\n (Tree0.add_multi t.tree ~length:t.length ~key ~data ~compare_key:(compare_key t))\n ;;\n\n let remove_multi t key =\n like t (Tree0.remove_multi t.tree ~length:t.length key ~compare_key:(compare_key t))\n ;;\n\n let find_multi t key = Tree0.find_multi t.tree key ~compare_key:(compare_key t)\n\n let change t key ~f =\n like t (Tree0.change t.tree key ~f ~length:t.length ~compare_key:(compare_key t))\n ;;\n\n let update t key ~f =\n like t (Tree0.update t.tree key ~f ~length:t.length ~compare_key:(compare_key t))\n ;;\n\n let find_exn t key =\n Tree0.find_exn\n t.tree\n key\n ~compare_key:(compare_key t)\n ~sexp_of_key:t.comparator.sexp_of_t\n ;;\n\n let find t key = Tree0.find t.tree key ~compare_key:(compare_key t)\n\n let remove t key =\n like t (Tree0.remove t.tree key ~length:t.length ~compare_key:(compare_key t))\n ;;\n\n let mem t key = Tree0.mem t.tree key ~compare_key:(compare_key t)\n let iter_keys t ~f = Tree0.iter_keys t.tree ~f\n let iter t ~f = Tree0.iter t.tree ~f\n let iteri t ~f = Tree0.iteri t.tree ~f\n let iteri_until t ~f = Tree0.iteri_until t.tree ~f\n let iter2 t1 t2 ~f = Tree0.iter2 t1.tree t2.tree ~f ~compare_key:(compare_key t1)\n let map t ~f = with_same_length t (Tree0.map t.tree ~f)\n let mapi t ~f = with_same_length t (Tree0.mapi t.tree ~f)\n let fold t ~init ~f = Tree0.fold t.tree ~f ~init\n let fold_right t ~init ~f = Tree0.fold_right t.tree ~f ~init\n\n let fold2 t1 t2 ~init ~f =\n Tree0.fold2 t1.tree t2.tree ~init ~f ~compare_key:(compare_key t1)\n ;;\n\n let filter_keys t ~f =\n like t (Tree0.filter_keys t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let filter t ~f = like t (Tree0.filter t.tree ~f ~compare_key:(compare_key t))\n let filteri t ~f = like t (Tree0.filteri t.tree ~f ~compare_key:(compare_key t))\n let filter_map t ~f = like t (Tree0.filter_map t.tree ~f ~compare_key:(compare_key t))\n\n let filter_mapi t ~f =\n like t (Tree0.filter_mapi t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let partition_mapi t ~f =\n like2 t (Tree0.partition_mapi t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let partition_map t ~f =\n like2 t (Tree0.partition_map t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let partitioni_tf t ~f =\n like2 t (Tree0.partitioni_tf t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let partition_tf t ~f =\n like2 t (Tree0.partition_tf t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let combine_errors t =\n Or_error.map\n ~f:(like t)\n (Tree0.combine_errors\n t.tree\n ~compare_key:(compare_key t)\n ~sexp_of_key:t.comparator.sexp_of_t)\n ;;\n\n let compare_direct compare_data t1 t2 =\n Tree0.compare (compare_key t1) compare_data t1.tree t2.tree\n ;;\n\n let equal compare_data t1 t2 =\n Tree0.equal (compare_key t1) compare_data t1.tree t2.tree\n ;;\n\n let keys t = Tree0.keys t.tree\n let data t = Tree0.data t.tree\n let to_alist ?key_order t = Tree0.to_alist ?key_order t.tree\n let validate ~name f t = Validate.alist ~name f (to_alist t)\n let validatei ~name f t = Validate.list ~name:(Fn.compose name fst) f (to_alist t)\n\n let symmetric_diff t1 t2 ~data_equal =\n Tree0.symmetric_diff t1.tree t2.tree ~compare_key:(compare_key t1) ~data_equal\n ;;\n\n let fold_symmetric_diff t1 t2 ~data_equal ~init ~f =\n Tree0.fold_symmetric_diff\n t1.tree\n t2.tree\n ~compare_key:(compare_key t1)\n ~data_equal\n ~init\n ~f\n ;;\n\n let merge t1 t2 ~f =\n like t1 (Tree0.merge t1.tree t2.tree ~f ~compare_key:(compare_key t1))\n ;;\n\n let min_elt t = Tree0.min_elt t.tree\n let min_elt_exn t = Tree0.min_elt_exn t.tree\n let max_elt t = Tree0.max_elt t.tree\n let max_elt_exn t = Tree0.max_elt_exn t.tree\n let for_all t ~f = Tree0.for_all t.tree ~f\n let for_alli t ~f = Tree0.for_alli t.tree ~f\n let exists t ~f = Tree0.exists t.tree ~f\n let existsi t ~f = Tree0.existsi t.tree ~f\n let count t ~f = Tree0.count t.tree ~f\n let counti t ~f = Tree0.counti t.tree ~f\n\n let split t k =\n let l, maybe, r = Tree0.split t.tree k ~compare_key:(compare_key t) in\n let comparator = comparator t in\n (* Try to traverse the least amount possible to calculate the length,\n using height as a heuristic. *)\n let both_len = if Option.is_some maybe then t.length - 1 else t.length in\n if Tree0.height l < Tree0.height r\n then (\n let l = of_tree l ~comparator in\n l, maybe, of_tree_unsafe r ~comparator ~length:(both_len - length l))\n else (\n let r = of_tree r ~comparator in\n of_tree_unsafe l ~comparator ~length:(both_len - length r), maybe, r)\n ;;\n\n let subrange t ~lower_bound ~upper_bound =\n let left, mid, right =\n Tree0.split_range t.tree ~lower_bound ~upper_bound ~compare_key:(compare_key t)\n in\n (* Try to traverse the least amount possible to calculate the length,\n using height as a heuristic. *)\n let outer_joined_height =\n let h_l = Tree0.height left\n and h_r = Tree0.height right in\n if h_l = h_r then h_l + 1 else max h_l h_r\n in\n if outer_joined_height < Tree0.height mid\n then (\n let mid_length = t.length - (Tree0.length left + Tree0.length right) in\n of_tree_unsafe mid ~comparator:(comparator t) ~length:mid_length)\n else of_tree mid ~comparator:(comparator t)\n ;;\n\n let append ~lower_part ~upper_part =\n match\n Tree0.append\n ~compare_key:(compare_key lower_part)\n ~lower_part:lower_part.tree\n ~upper_part:upper_part.tree\n with\n | `Ok tree ->\n `Ok\n (of_tree_unsafe\n tree\n ~comparator:(comparator lower_part)\n ~length:(lower_part.length + upper_part.length))\n | `Overlapping_key_ranges -> `Overlapping_key_ranges\n ;;\n\n let fold_range_inclusive t ~min ~max ~init ~f =\n Tree0.fold_range_inclusive t.tree ~min ~max ~init ~f ~compare_key:(compare_key t)\n ;;\n\n let range_to_alist t ~min ~max =\n Tree0.range_to_alist t.tree ~min ~max ~compare_key:(compare_key t)\n ;;\n\n let closest_key t dir key =\n Tree0.closest_key t.tree dir key ~compare_key:(compare_key t)\n ;;\n\n let nth t n = Tree0.nth t.tree n\n let nth_exn t n = Option.value_exn (nth t n)\n let rank t key = Tree0.rank t.tree key ~compare_key:(compare_key t)\n let sexp_of_t sexp_of_k sexp_of_v _ t = Tree0.sexp_of_t sexp_of_k sexp_of_v t.tree\n\n let to_sequence ?order ?keys_greater_or_equal_to ?keys_less_or_equal_to t =\n Tree0.to_sequence\n t.comparator\n ?order\n ?keys_greater_or_equal_to\n ?keys_less_or_equal_to\n t.tree\n ;;\n\n let binary_search t ~compare how v = Tree0.binary_search t.tree ~compare how v\n\n let binary_search_segmented t ~segment_of how =\n Tree0.binary_search_segmented t.tree ~segment_of how\n ;;\n\n let hash_fold_direct hash_fold_key hash_fold_data state t =\n Tree0.hash_fold_t_ignoring_structure hash_fold_key hash_fold_data state t.tree\n ;;\nend\n\n(* [0] is used as the [length] argument everywhere in this module, since trees do not\n have their lengths stored at the root, unlike maps. The values are discarded always. *)\nmodule Tree = struct\n type ('k, 'v, 'comparator) t = ('k, 'v, 'comparator) tree\n\n let empty_without_value_restriction = Tree0.empty\n let empty ~comparator:_ = empty_without_value_restriction\n let of_tree ~comparator:_ tree = tree\n let singleton ~comparator:_ k v = Tree0.singleton k v\n\n let of_sorted_array_unchecked ~comparator array =\n fst\n (Tree0.of_sorted_array_unchecked array ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sorted_array ~comparator array =\n Tree0.of_sorted_array array ~compare_key:comparator.Comparator.compare\n |> Or_error.map ~f:fst\n ;;\n\n let of_alist ~comparator alist =\n match Tree0.of_alist alist ~compare_key:comparator.Comparator.compare with\n | `Duplicate_key _ as d -> d\n | `Ok (tree, _size) -> `Ok tree\n ;;\n\n let of_alist_or_error ~comparator alist =\n Tree0.of_alist_or_error alist ~comparator |> Or_error.map ~f:fst\n ;;\n\n let of_alist_exn ~comparator alist = fst (Tree0.of_alist_exn alist ~comparator)\n\n let of_alist_multi ~comparator alist =\n fst (Tree0.of_alist_multi alist ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_alist_fold ~comparator alist ~init ~f =\n fst (Tree0.of_alist_fold alist ~init ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_alist_reduce ~comparator alist ~f =\n fst (Tree0.of_alist_reduce alist ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_iteri ~comparator ~iteri =\n match Tree0.of_iteri ~iteri ~compare_key:comparator.Comparator.compare with\n | `Ok (tree, _size) -> `Ok tree\n | `Duplicate_key _ as d -> d\n ;;\n\n let of_increasing_iterator_unchecked ~comparator:_required_by_intf ~len ~f =\n Tree0.of_increasing_iterator_unchecked ~len ~f\n ;;\n\n let of_increasing_sequence ~comparator seq =\n Or_error.map\n ~f:fst\n (Tree0.of_increasing_sequence seq ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence ~comparator seq =\n match Tree0.of_sequence seq ~compare_key:comparator.Comparator.compare with\n | `Duplicate_key _ as d -> d\n | `Ok (tree, _size) -> `Ok tree\n ;;\n\n let of_sequence_or_error ~comparator seq =\n Tree0.of_sequence_or_error seq ~comparator |> Or_error.map ~f:fst\n ;;\n\n let of_sequence_exn ~comparator seq = fst (Tree0.of_sequence_exn seq ~comparator)\n\n let of_sequence_multi ~comparator seq =\n fst (Tree0.of_sequence_multi seq ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence_fold ~comparator seq ~init ~f =\n fst (Tree0.of_sequence_fold seq ~init ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence_reduce ~comparator seq ~f =\n fst (Tree0.of_sequence_reduce seq ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let to_tree t = t\n\n let invariants ~comparator t =\n Tree0.invariants t ~compare_key:comparator.Comparator.compare\n ;;\n\n let is_empty t = Tree0.is_empty t\n let length t = Tree0.length t\n\n let set ~comparator t ~key ~data =\n fst (Tree0.set t ~key ~data ~length:0 ~compare_key:comparator.Comparator.compare)\n ;;\n\n let add_exn ~comparator t ~key ~data =\n fst\n (Tree0.add_exn\n t\n ~key\n ~data\n ~length:0\n ~compare_key:comparator.Comparator.compare\n ~sexp_of_key:comparator.sexp_of_t)\n ;;\n\n let add ~comparator t ~key ~data =\n try `Ok (add_exn t ~comparator ~key ~data) with\n | _ -> `Duplicate\n ;;\n\n let add_multi ~comparator t ~key ~data =\n Tree0.add_multi t ~key ~data ~length:0 ~compare_key:comparator.Comparator.compare\n |> fst\n ;;\n\n let remove_multi ~comparator t key =\n Tree0.remove_multi t key ~length:0 ~compare_key:comparator.Comparator.compare |> fst\n ;;\n\n let find_multi ~comparator t key =\n Tree0.find_multi t key ~compare_key:comparator.Comparator.compare\n ;;\n\n let change ~comparator t key ~f =\n fst (Tree0.change t key ~f ~length:0 ~compare_key:comparator.Comparator.compare)\n ;;\n\n let update ~comparator t key ~f =\n change ~comparator t key ~f:(fun data -> Some (f data))\n ;;\n\n let find_exn ~comparator t key =\n Tree0.find_exn\n t\n key\n ~compare_key:comparator.Comparator.compare\n ~sexp_of_key:comparator.Comparator.sexp_of_t\n ;;\n\n let find ~comparator t key =\n Tree0.find t key ~compare_key:comparator.Comparator.compare\n ;;\n\n let remove ~comparator t key =\n fst (Tree0.remove t key ~length:0 ~compare_key:comparator.Comparator.compare)\n ;;\n\n let mem ~comparator t key = Tree0.mem t key ~compare_key:comparator.Comparator.compare\n let iter_keys t ~f = Tree0.iter_keys t ~f\n let iter t ~f = Tree0.iter t ~f\n let iteri t ~f = Tree0.iteri t ~f\n let iteri_until t ~f = Tree0.iteri_until t ~f\n\n let iter2 ~comparator t1 t2 ~f =\n Tree0.iter2 t1 t2 ~f ~compare_key:comparator.Comparator.compare\n ;;\n\n let map t ~f = Tree0.map t ~f\n let mapi t ~f = Tree0.mapi t ~f\n let fold t ~init ~f = Tree0.fold t ~f ~init\n let fold_right t ~init ~f = Tree0.fold_right t ~f ~init\n\n let fold2 ~comparator t1 t2 ~init ~f =\n Tree0.fold2 t1 t2 ~init ~f ~compare_key:comparator.Comparator.compare\n ;;\n\n let filter_keys ~comparator t ~f =\n fst (Tree0.filter_keys t ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let filter ~comparator t ~f =\n fst (Tree0.filter t ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let filteri ~comparator t ~f =\n fst (Tree0.filteri t ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let filter_map ~comparator t ~f =\n fst (Tree0.filter_map t ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let filter_mapi ~comparator t ~f =\n fst (Tree0.filter_mapi t ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let partition_mapi ~comparator t ~f =\n let (a, _), (b, _) =\n Tree0.partition_mapi t ~f ~compare_key:comparator.Comparator.compare\n in\n a, b\n ;;\n\n let partition_map ~comparator t ~f =\n let (a, _), (b, _) =\n Tree0.partition_map t ~f ~compare_key:comparator.Comparator.compare\n in\n a, b\n ;;\n\n let partitioni_tf ~comparator t ~f =\n let (a, _), (b, _) =\n Tree0.partitioni_tf t ~f ~compare_key:comparator.Comparator.compare\n in\n a, b\n ;;\n\n let partition_tf ~comparator t ~f =\n let (a, _), (b, _) =\n Tree0.partition_tf t ~f ~compare_key:comparator.Comparator.compare\n in\n a, b\n ;;\n\n let combine_errors ~comparator t =\n Or_error.map\n ~f:fst\n (Tree0.combine_errors\n t\n ~compare_key:comparator.Comparator.compare\n ~sexp_of_key:comparator.Comparator.sexp_of_t)\n ;;\n\n let compare_direct ~comparator compare_data t1 t2 =\n Tree0.compare comparator.Comparator.compare compare_data t1 t2\n ;;\n\n let equal ~comparator compare_data t1 t2 =\n Tree0.equal comparator.Comparator.compare compare_data t1 t2\n ;;\n\n let keys t = Tree0.keys t\n let data t = Tree0.data t\n let to_alist ?key_order t = Tree0.to_alist ?key_order t\n let validate ~name f t = Validate.alist ~name f (to_alist t)\n let validatei ~name f t = Validate.list ~name:(Fn.compose name fst) f (to_alist t)\n\n let symmetric_diff ~comparator t1 t2 ~data_equal =\n Tree0.symmetric_diff t1 t2 ~compare_key:comparator.Comparator.compare ~data_equal\n ;;\n\n let fold_symmetric_diff ~comparator t1 t2 ~data_equal ~init ~f =\n Tree0.fold_symmetric_diff\n t1\n t2\n ~compare_key:comparator.Comparator.compare\n ~data_equal\n ~init\n ~f\n ;;\n\n let merge ~comparator t1 t2 ~f =\n fst (Tree0.merge t1 t2 ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let min_elt t = Tree0.min_elt t\n let min_elt_exn t = Tree0.min_elt_exn t\n let max_elt t = Tree0.max_elt t\n let max_elt_exn t = Tree0.max_elt_exn t\n let for_all t ~f = Tree0.for_all t ~f\n let for_alli t ~f = Tree0.for_alli t ~f\n let exists t ~f = Tree0.exists t ~f\n let existsi t ~f = Tree0.existsi t ~f\n let count t ~f = Tree0.count t ~f\n let counti t ~f = Tree0.counti t ~f\n let split ~comparator t k = Tree0.split t k ~compare_key:comparator.Comparator.compare\n\n let append ~comparator ~lower_part ~upper_part =\n Tree0.append ~lower_part ~upper_part ~compare_key:comparator.Comparator.compare\n ;;\n\n let subrange ~comparator t ~lower_bound ~upper_bound =\n let _, ret, _ =\n Tree0.split_range\n t\n ~lower_bound\n ~upper_bound\n ~compare_key:comparator.Comparator.compare\n in\n ret\n ;;\n\n let fold_range_inclusive ~comparator t ~min ~max ~init ~f =\n Tree0.fold_range_inclusive\n t\n ~min\n ~max\n ~init\n ~f\n ~compare_key:comparator.Comparator.compare\n ;;\n\n let range_to_alist ~comparator t ~min ~max =\n Tree0.range_to_alist t ~min ~max ~compare_key:comparator.Comparator.compare\n ;;\n\n let closest_key ~comparator t dir key =\n Tree0.closest_key t dir key ~compare_key:comparator.Comparator.compare\n ;;\n\n let nth ~comparator:_ t n = Tree0.nth t n\n let nth_exn ~comparator t n = Option.value_exn (nth ~comparator t n)\n\n let rank ~comparator t key =\n Tree0.rank t key ~compare_key:comparator.Comparator.compare\n ;;\n\n let sexp_of_t sexp_of_k sexp_of_v _ t = Tree0.sexp_of_t sexp_of_k sexp_of_v t\n\n let t_of_sexp_direct ~comparator k_of_sexp v_of_sexp sexp =\n fst (Tree0.t_of_sexp_direct k_of_sexp v_of_sexp sexp ~comparator)\n ;;\n\n let to_sequence ~comparator ?order ?keys_greater_or_equal_to ?keys_less_or_equal_to t =\n Tree0.to_sequence\n comparator\n ?order\n ?keys_greater_or_equal_to\n ?keys_less_or_equal_to\n t\n ;;\n\n let binary_search ~comparator:_ t ~compare how v = Tree0.binary_search t ~compare how v\n\n let binary_search_segmented ~comparator:_ t ~segment_of how =\n Tree0.binary_search_segmented t ~segment_of how\n ;;\nend\n\nmodule Using_comparator = struct\n type nonrec ('k, 'v, 'cmp) t = ('k, 'v, 'cmp) t\n\n include Accessors\n\n let empty ~comparator = { tree = Tree0.empty; comparator; length = 0 }\n let singleton ~comparator k v = { comparator; tree = Tree0.singleton k v; length = 1 }\n let of_tree0 ~comparator (tree, length) = { comparator; tree; length }\n let of_tree ~comparator tree = of_tree0 ~comparator (tree, Tree0.length tree)\n let to_tree = to_tree\n\n let of_sorted_array_unchecked ~comparator array =\n of_tree0\n ~comparator\n (Tree0.of_sorted_array_unchecked array ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sorted_array ~comparator array =\n Or_error.map\n (Tree0.of_sorted_array array ~compare_key:comparator.Comparator.compare)\n ~f:(fun tree -> of_tree0 ~comparator tree)\n ;;\n\n let of_alist ~comparator alist =\n match Tree0.of_alist alist ~compare_key:comparator.Comparator.compare with\n | `Ok (tree, length) -> `Ok { comparator; tree; length }\n | `Duplicate_key _ as z -> z\n ;;\n\n let of_alist_or_error ~comparator alist =\n Result.map (Tree0.of_alist_or_error alist ~comparator) ~f:(fun tree ->\n of_tree0 ~comparator tree)\n ;;\n\n let of_alist_exn ~comparator alist =\n of_tree0 ~comparator (Tree0.of_alist_exn alist ~comparator)\n ;;\n\n let of_alist_multi ~comparator alist =\n of_tree0\n ~comparator\n (Tree0.of_alist_multi alist ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_alist_fold ~comparator alist ~init ~f =\n of_tree0\n ~comparator\n (Tree0.of_alist_fold alist ~init ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_alist_reduce ~comparator alist ~f =\n of_tree0\n ~comparator\n (Tree0.of_alist_reduce alist ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_iteri ~comparator ~iteri =\n match Tree0.of_iteri ~compare_key:comparator.Comparator.compare ~iteri with\n | `Ok tree_length -> `Ok (of_tree0 ~comparator tree_length)\n | `Duplicate_key _ as z -> z\n ;;\n\n let of_increasing_iterator_unchecked ~comparator ~len ~f =\n of_tree0 ~comparator (Tree0.of_increasing_iterator_unchecked ~len ~f, len)\n ;;\n\n let of_increasing_sequence ~comparator seq =\n Or_error.map\n ~f:(of_tree0 ~comparator)\n (Tree0.of_increasing_sequence seq ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence ~comparator seq =\n match Tree0.of_sequence seq ~compare_key:comparator.Comparator.compare with\n | `Ok (tree, length) -> `Ok { comparator; tree; length }\n | `Duplicate_key _ as z -> z\n ;;\n\n let of_sequence_or_error ~comparator seq =\n Result.map (Tree0.of_sequence_or_error seq ~comparator) ~f:(fun tree ->\n of_tree0 ~comparator tree)\n ;;\n\n let of_sequence_exn ~comparator seq =\n of_tree0 ~comparator (Tree0.of_sequence_exn seq ~comparator)\n ;;\n\n let of_sequence_multi ~comparator seq =\n of_tree0\n ~comparator\n (Tree0.of_sequence_multi seq ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence_fold ~comparator seq ~init ~f =\n of_tree0\n ~comparator\n (Tree0.of_sequence_fold seq ~init ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence_reduce ~comparator seq ~f =\n of_tree0\n ~comparator\n (Tree0.of_sequence_reduce seq ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let t_of_sexp_direct ~comparator k_of_sexp v_of_sexp sexp =\n of_tree0 ~comparator (Tree0.t_of_sexp_direct k_of_sexp v_of_sexp sexp ~comparator)\n ;;\n\n module Empty_without_value_restriction (K : Comparator.S1) = struct\n let empty = { tree = Tree0.empty; comparator = K.comparator; length = 0 }\n end\n\n module Tree = Tree\nend\n\ninclude Accessors\n\ntype ('k, 'cmp) comparator =\n (module Comparator.S with type t = 'k and type comparator_witness = 'cmp)\n\nlet comparator_s (type k cmp) t : (k, cmp) comparator =\n (module struct\n type t = k\n type comparator_witness = cmp\n\n let comparator = t.comparator\n end)\n;;\n\nlet to_comparator (type k cmp) ((module M) : (k, cmp) comparator) = M.comparator\nlet empty m = Using_comparator.empty ~comparator:(to_comparator m)\nlet singleton m a = Using_comparator.singleton ~comparator:(to_comparator m) a\nlet of_alist m a = Using_comparator.of_alist ~comparator:(to_comparator m) a\n\nlet of_alist_or_error m a =\n Using_comparator.of_alist_or_error ~comparator:(to_comparator m) a\n;;\n\nlet of_alist_exn m a = Using_comparator.of_alist_exn ~comparator:(to_comparator m) a\nlet of_alist_multi m a = Using_comparator.of_alist_multi ~comparator:(to_comparator m) a\n\nlet of_alist_fold m a ~init ~f =\n Using_comparator.of_alist_fold ~comparator:(to_comparator m) a ~init ~f\n;;\n\nlet of_alist_reduce m a ~f =\n Using_comparator.of_alist_reduce ~comparator:(to_comparator m) a ~f\n;;\n\nlet of_sorted_array_unchecked m a =\n Using_comparator.of_sorted_array_unchecked ~comparator:(to_comparator m) a\n;;\n\nlet of_sorted_array m a =\n Using_comparator.of_sorted_array ~comparator:(to_comparator m) a\n;;\n\nlet of_iteri m ~iteri = Using_comparator.of_iteri ~iteri ~comparator:(to_comparator m)\n\nlet of_increasing_iterator_unchecked m ~len ~f =\n Using_comparator.of_increasing_iterator_unchecked ~len ~f ~comparator:(to_comparator m)\n;;\n\nlet of_increasing_sequence m seq =\n Using_comparator.of_increasing_sequence ~comparator:(to_comparator m) seq\n;;\n\nlet of_sequence m s = Using_comparator.of_sequence ~comparator:(to_comparator m) s\n\nlet of_sequence_or_error m s =\n Using_comparator.of_sequence_or_error ~comparator:(to_comparator m) s\n;;\n\nlet of_sequence_exn m s =\n Using_comparator.of_sequence_exn ~comparator:(to_comparator m) s\n;;\n\nlet of_sequence_multi m s =\n Using_comparator.of_sequence_multi ~comparator:(to_comparator m) s\n;;\n\nlet of_sequence_fold m s ~init ~f =\n Using_comparator.of_sequence_fold ~comparator:(to_comparator m) s ~init ~f\n;;\n\nlet of_sequence_reduce m s ~f =\n Using_comparator.of_sequence_reduce ~comparator:(to_comparator m) s ~f\n;;\n\nmodule M (K : sig\n type t\n type comparator_witness\n end) =\nstruct\n type nonrec 'v t = (K.t, 'v, K.comparator_witness) t\nend\n\nmodule type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\nend\n\nmodule type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Comparator.S with type t := t\nend\n\nmodule type Compare_m = sig end\nmodule type Equal_m = sig end\nmodule type Hash_fold_m = Hasher.S\n\nlet sexp_of_m__t (type k) (module K : Sexp_of_m with type t = k) sexp_of_v t =\n sexp_of_t K.sexp_of_t sexp_of_v (fun _ -> Sexp.Atom \"_\") t\n;;\n\nlet m__t_of_sexp\n (type k cmp)\n (module K : M_of_sexp with type t = k and type comparator_witness = cmp)\n v_of_sexp\n sexp\n =\n Using_comparator.t_of_sexp_direct ~comparator:K.comparator K.t_of_sexp v_of_sexp sexp\n;;\n\nlet m__t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t =\n Inline\n (Explicit_bind\n ( [ \"'k\"; \"'v\" ]\n , Apply\n ( Grammar list_sexp_grammar\n , [ Apply\n ( Grammar Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.tuple2_sexp_grammar\n , [ Explicit_var 0; Explicit_var 1 ] )\n ] ) ))\n;;\n\nlet compare_m__t (module K : Compare_m) compare_v t1 t2 = compare_direct compare_v t1 t2\nlet equal_m__t (module K : Equal_m) equal_v t1 t2 = equal equal_v t1 t2\n\nlet hash_fold_m__t (type k) (module K : Hash_fold_m with type t = k) hash_fold_v state =\n hash_fold_direct K.hash_fold_t hash_fold_v state\n;;\n\nlet merge_skewed t1 t2 ~combine =\n let t1, t2, combine =\n if length t2 <= length t1\n then t1, t2, combine\n else t2, t1, fun ~key v1 v2 -> combine ~key v2 v1\n in\n fold t2 ~init:t1 ~f:(fun ~key ~data:v2 t1 ->\n change t1 key ~f:(function\n | None -> Some v2\n | Some v1 -> Some (combine ~key v1 v2)))\n;;\n\nmodule Poly = struct\n type nonrec ('k, 'v) t = ('k, 'v, Comparator.Poly.comparator_witness) t\n type nonrec ('k, 'v) tree = ('k, 'v) Tree0.t\n type comparator_witness = Comparator.Poly.comparator_witness\n\n include Accessors\n\n let comparator = Comparator.Poly.comparator\n let of_tree tree = { tree; comparator; length = Tree0.length tree }\n\n include Using_comparator.Empty_without_value_restriction (Comparator.Poly)\n\n let singleton a = Using_comparator.singleton ~comparator a\n let of_alist a = Using_comparator.of_alist ~comparator a\n let of_alist_or_error a = Using_comparator.of_alist_or_error ~comparator a\n let of_alist_exn a = Using_comparator.of_alist_exn ~comparator a\n let of_alist_multi a = Using_comparator.of_alist_multi ~comparator a\n let of_alist_fold a ~init ~f = Using_comparator.of_alist_fold ~comparator a ~init ~f\n let of_alist_reduce a ~f = Using_comparator.of_alist_reduce ~comparator a ~f\n\n let of_sorted_array_unchecked a =\n Using_comparator.of_sorted_array_unchecked ~comparator a\n ;;\n\n let of_sorted_array a = Using_comparator.of_sorted_array ~comparator a\n let of_iteri ~iteri = Using_comparator.of_iteri ~iteri ~comparator\n\n let of_increasing_iterator_unchecked ~len ~f =\n Using_comparator.of_increasing_iterator_unchecked ~len ~f ~comparator\n ;;\n\n let of_increasing_sequence seq =\n Using_comparator.of_increasing_sequence ~comparator seq\n ;;\n\n let of_sequence s = Using_comparator.of_sequence ~comparator s\n let of_sequence_or_error s = Using_comparator.of_sequence_or_error ~comparator s\n let of_sequence_exn s = Using_comparator.of_sequence_exn ~comparator s\n let of_sequence_multi s = Using_comparator.of_sequence_multi ~comparator s\n\n let of_sequence_fold s ~init ~f =\n Using_comparator.of_sequence_fold ~comparator s ~init ~f\n ;;\n\n let of_sequence_reduce s ~f = Using_comparator.of_sequence_reduce ~comparator s ~f\nend\n","open! Import\nopen! T\n\nmodule Or_duplicate = struct\n type 'a t =\n [ `Ok of 'a\n | `Duplicate\n ]\n [@@deriving_inline sexp_of]\n\n let sexp_of_t :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a -> function\n | `Ok v0 -> Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Ok\"; _of_a v0 ]\n | `Duplicate -> Ppx_sexp_conv_lib.Sexp.Atom \"Duplicate\"\n ;;\n\n [@@@end]\nend\n\nmodule Without_comparator = struct\n type ('key, 'cmp, 'z) t = 'z\nend\n\nmodule With_comparator = struct\n type ('key, 'cmp, 'z) t = comparator:('key, 'cmp) Comparator.t -> 'z\nend\n\nmodule With_first_class_module = struct\n type ('key, 'cmp, 'z) t =\n (module Comparator.S with type t = 'key and type comparator_witness = 'cmp) -> 'z\nend\n\nmodule Symmetric_diff_element = struct\n type ('k, 'v) t = 'k * [ `Left of 'v | `Right of 'v | `Unequal of 'v * 'v ]\n [@@deriving_inline compare, sexp]\n\n let compare :\n 'k 'v. ('k -> 'k -> int) -> ('v -> 'v -> int) -> ('k, 'v) t -> ('k, 'v) t -> int\n =\n fun _cmp__k _cmp__v a__001_ b__002_ ->\n let t__003_, t__004_ = a__001_ in\n let t__005_, t__006_ = b__002_ in\n match _cmp__k t__003_ t__005_ with\n | 0 ->\n if Ppx_compare_lib.phys_equal t__004_ t__006_\n then 0\n else (\n match t__004_, t__006_ with\n | `Left _left__007_, `Left _right__008_ -> _cmp__v _left__007_ _right__008_\n | `Right _left__009_, `Right _right__010_ -> _cmp__v _left__009_ _right__010_\n | `Unequal _left__011_, `Unequal _right__012_ ->\n let t__013_, t__014_ = _left__011_ in\n let t__015_, t__016_ = _right__012_ in\n (match _cmp__v t__013_ t__015_ with\n | 0 -> _cmp__v t__014_ t__016_\n | n -> n)\n | x, y -> Ppx_compare_lib.polymorphic_compare x y)\n | n -> n\n ;;\n\n let t_of_sexp :\n 'k 'v. (Ppx_sexp_conv_lib.Sexp.t -> 'k) -> (Ppx_sexp_conv_lib.Sexp.t -> 'v)\n -> Ppx_sexp_conv_lib.Sexp.t -> ('k, 'v) t\n =\n let _tp_loc = \"map_intf.ml.Symmetric_diff_element.t\" in\n fun _of_k _of_v -> function\n | Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ] ->\n let v0 = _of_k v0\n and v1 =\n (fun sexp ->\n try\n match sexp with\n | Ppx_sexp_conv_lib.Sexp.Atom atom as _sexp ->\n (match atom with\n | \"Left\" -> Ppx_sexp_conv_lib.Conv_error.ptag_takes_args _tp_loc _sexp\n | \"Right\" -> Ppx_sexp_conv_lib.Conv_error.ptag_takes_args _tp_loc _sexp\n | \"Unequal\" -> Ppx_sexp_conv_lib.Conv_error.ptag_takes_args _tp_loc _sexp\n | _ -> Ppx_sexp_conv_lib.Conv_error.no_variant_match ())\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom atom :: sexp_args) as _sexp ->\n (match atom with\n | \"Left\" as _tag ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_v v0 in\n `Left v0\n | _ ->\n Ppx_sexp_conv_lib.Conv_error.ptag_incorrect_n_args _tp_loc _tag _sexp)\n | \"Right\" as _tag ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_v v0 in\n `Right v0\n | _ ->\n Ppx_sexp_conv_lib.Conv_error.ptag_incorrect_n_args _tp_loc _tag _sexp)\n | \"Unequal\" as _tag ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 =\n match v0 with\n | Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ] ->\n let v0 = _of_v v0\n and v1 = _of_v v1 in\n v0, v1\n | sexp ->\n Ppx_sexp_conv_lib.Conv_error.tuple_of_size_n_expected\n _tp_loc\n 2\n sexp\n in\n `Unequal v0\n | _ ->\n Ppx_sexp_conv_lib.Conv_error.ptag_incorrect_n_args _tp_loc _tag _sexp)\n | _ -> Ppx_sexp_conv_lib.Conv_error.no_variant_match ())\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp\n -> Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_poly_var _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_poly_var _tp_loc sexp\n with\n | Ppx_sexp_conv_lib.Conv_error.No_variant_match ->\n Ppx_sexp_conv_lib.Conv_error.no_matching_variant_found _tp_loc sexp)\n v1\n in\n v0, v1\n | sexp -> Ppx_sexp_conv_lib.Conv_error.tuple_of_size_n_expected _tp_loc 2 sexp\n ;;\n\n let sexp_of_t :\n 'k 'v. ('k -> Ppx_sexp_conv_lib.Sexp.t) -> ('v -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('k, 'v) t -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_k _of_v -> function\n | v0, v1 ->\n let v0 = _of_k v0\n and v1 =\n match v1 with\n | `Left v0 ->\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Left\"; _of_v v0 ]\n | `Right v0 ->\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Right\"; _of_v v0 ]\n | `Unequal v0 ->\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"Unequal\"\n ; (let v0, v1 = v0 in\n let v0 = _of_v v0\n and v1 = _of_v v1 in\n Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ])\n ]\n in\n Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ]\n ;;\n\n [@@@end]\nend\n\nmodule Continue_or_stop = struct\n type t =\n | Continue\n | Stop\n [@@deriving_inline compare, enumerate, equal, sexp_of]\n\n let compare = (Ppx_compare_lib.polymorphic_compare : t -> t -> int)\n let all = ([ Continue; Stop ] : t list)\n let equal = (Ppx_compare_lib.polymorphic_equal : t -> t -> bool)\n\n let sexp_of_t =\n (function\n | Continue -> Ppx_sexp_conv_lib.Sexp.Atom \"Continue\"\n | Stop -> Ppx_sexp_conv_lib.Sexp.Atom \"Stop\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\nend\n\nmodule Finished_or_unfinished = struct\n type t =\n | Finished\n | Unfinished\n [@@deriving_inline compare, enumerate, equal, sexp_of]\n\n let compare = (Ppx_compare_lib.polymorphic_compare : t -> t -> int)\n let all = ([ Finished; Unfinished ] : t list)\n let equal = (Ppx_compare_lib.polymorphic_equal : t -> t -> bool)\n\n let sexp_of_t =\n (function\n | Finished -> Ppx_sexp_conv_lib.Sexp.Atom \"Finished\"\n | Unfinished -> Ppx_sexp_conv_lib.Sexp.Atom \"Unfinished\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\nend\n\nmodule type Accessors_generic = sig\n type ('a, 'b, 'cmp) t\n type ('a, 'b, 'cmp) tree\n type 'a key\n type 'cmp cmp\n type ('a, 'cmp, 'z) options\n\n val invariants : ('k, 'cmp, ('k, 'v, 'cmp) t -> bool) options\n val is_empty : (_, _, _) t -> bool\n val length : (_, _, _) t -> int\n\n val add\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> key:'k key -> data:'v -> ('k, 'v, 'cmp) t Or_duplicate.t )\n options\n\n val add_exn\n : ('k, 'cmp, ('k, 'v, 'cmp) t -> key:'k key -> data:'v -> ('k, 'v, 'cmp) t) options\n\n val set\n : ('k, 'cmp, ('k, 'v, 'cmp) t -> key:'k key -> data:'v -> ('k, 'v, 'cmp) t) options\n\n val add_multi\n : ( 'k\n , 'cmp\n , ('k, 'v list, 'cmp) t -> key:'k key -> data:'v -> ('k, 'v list, 'cmp) t )\n options\n\n val remove_multi\n : ('k, 'cmp, ('k, 'v list, 'cmp) t -> 'k key -> ('k, 'v list, 'cmp) t) options\n\n val find_multi : ('k, 'cmp, ('k, 'v list, 'cmp) t -> 'k key -> 'v list) options\n\n val change\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> 'k key -> f:('v option -> 'v option) -> ('k, 'v, 'cmp) t )\n options\n\n val update\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> 'k key -> f:('v option -> 'v) -> ('k, 'v, 'cmp) t )\n options\n\n val find : ('k, 'cmp, ('k, 'v, 'cmp) t -> 'k key -> 'v option) options\n val find_exn : ('k, 'cmp, ('k, 'v, 'cmp) t -> 'k key -> 'v) options\n val remove : ('k, 'cmp, ('k, 'v, 'cmp) t -> 'k key -> ('k, 'v, 'cmp) t) options\n val mem : ('k, 'cmp, ('k, _, 'cmp) t -> 'k key -> bool) options\n val iter_keys : ('k, _, _) t -> f:('k key -> unit) -> unit\n val iter : (_, 'v, _) t -> f:('v -> unit) -> unit\n val iteri : ('k, 'v, _) t -> f:(key:'k key -> data:'v -> unit) -> unit\n\n val iteri_until\n : ('k, 'v, _) t\n -> f:(key:'k key -> data:'v -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n val iter2\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> f:(key:'k key\n -> data:[ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ]\n -> unit)\n -> unit )\n options\n\n val map : ('k, 'v1, 'cmp) t -> f:('v1 -> 'v2) -> ('k, 'v2, 'cmp) t\n val mapi : ('k, 'v1, 'cmp) t -> f:(key:'k key -> data:'v1 -> 'v2) -> ('k, 'v2, 'cmp) t\n val fold : ('k, 'v, _) t -> init:'a -> f:(key:'k key -> data:'v -> 'a -> 'a) -> 'a\n\n val fold_right\n : ('k, 'v, _) t\n -> init:'a\n -> f:(key:'k key -> data:'v -> 'a -> 'a)\n -> 'a\n\n val fold2\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> init:'a\n -> f:(key:'k key\n -> data:[ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ]\n -> 'a\n -> 'a)\n -> 'a )\n options\n\n val filter_keys\n : ('k, 'cmp, ('k, 'v, 'cmp) t -> f:('k key -> bool) -> ('k, 'v, 'cmp) t) options\n\n val filter : ('k, 'cmp, ('k, 'v, 'cmp) t -> f:('v -> bool) -> ('k, 'v, 'cmp) t) options\n\n val filteri\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> f:(key:'k key -> data:'v -> bool) -> ('k, 'v, 'cmp) t )\n options\n\n val filter_map\n : ('k, 'cmp, ('k, 'v1, 'cmp) t -> f:('v1 -> 'v2 option) -> ('k, 'v2, 'cmp) t) options\n\n val filter_mapi\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> f:(key:'k key -> data:'v1 -> 'v2 option)\n -> ('k, 'v2, 'cmp) t )\n options\n\n val partition_mapi\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> f:(key:'k key -> data:'v1 -> ('v2, 'v3) Either.t)\n -> ('k, 'v2, 'cmp) t * ('k, 'v3, 'cmp) t )\n options\n\n val partition_map\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> f:('v1 -> ('v2, 'v3) Either.t)\n -> ('k, 'v2, 'cmp) t * ('k, 'v3, 'cmp) t )\n options\n\n val partitioni_tf\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> f:(key:'k key -> data:'v -> bool)\n -> ('k, 'v, 'cmp) t * ('k, 'v, 'cmp) t )\n options\n\n val partition_tf\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> f:('v -> bool) -> ('k, 'v, 'cmp) t * ('k, 'v, 'cmp) t )\n options\n\n val combine_errors\n : ('k, 'cmp, ('k, 'v Or_error.t, 'cmp) t -> ('k, 'v, 'cmp) t Or_error.t) options\n\n val compare_direct\n : ( 'k\n , 'cmp\n , ('v -> 'v -> int) -> ('k, 'v, 'cmp) t -> ('k, 'v, 'cmp) t -> int )\n options\n\n val equal\n : ( 'k\n , 'cmp\n , ('v -> 'v -> bool) -> ('k, 'v, 'cmp) t -> ('k, 'v, 'cmp) t -> bool )\n options\n\n val keys : ('k, _, _) t -> 'k key list\n val data : (_, 'v, _) t -> 'v list\n\n val to_alist\n : ?key_order:[ `Increasing | `Decreasing ]\n -> ('k, 'v, _) t\n -> ('k key * 'v) list\n\n val validate\n : name:('k key -> string)\n -> 'v Validate.check\n -> ('k, 'v, _) t Validate.check\n\n val validatei\n : name:('k key -> string)\n -> ('k key * 'v) Validate.check\n -> ('k, 'v, _) t Validate.check\n\n val merge\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> f:(key:'k key\n -> [ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ]\n -> 'v3 option)\n -> ('k, 'v3, 'cmp) t )\n options\n\n val symmetric_diff\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> data_equal:('v -> 'v -> bool)\n -> ('k key, 'v) Symmetric_diff_element.t Sequence.t )\n options\n\n val fold_symmetric_diff\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> data_equal:('v -> 'v -> bool)\n -> init:'a\n -> f:('a -> ('k key, 'v) Symmetric_diff_element.t -> 'a)\n -> 'a )\n options\n\n val min_elt : ('k, 'v, _) t -> ('k key * 'v) option\n val min_elt_exn : ('k, 'v, _) t -> 'k key * 'v\n val max_elt : ('k, 'v, _) t -> ('k key * 'v) option\n val max_elt_exn : ('k, 'v, _) t -> 'k key * 'v\n val for_all : ('k, 'v, _) t -> f:('v -> bool) -> bool\n val for_alli : ('k, 'v, _) t -> f:(key:'k key -> data:'v -> bool) -> bool\n val exists : ('k, 'v, _) t -> f:('v -> bool) -> bool\n val existsi : ('k, 'v, _) t -> f:(key:'k key -> data:'v -> bool) -> bool\n val count : ('k, 'v, _) t -> f:('v -> bool) -> int\n val counti : ('k, 'v, _) t -> f:(key:'k key -> data:'v -> bool) -> int\n\n val split\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> 'k key\n -> ('k, 'v, 'cmp) t * ('k key * 'v) option * ('k, 'v, 'cmp) t )\n options\n\n val append\n : ( 'k\n , 'cmp\n , lower_part:('k, 'v, 'cmp) t\n -> upper_part:('k, 'v, 'cmp) t\n -> [ `Ok of ('k, 'v, 'cmp) t | `Overlapping_key_ranges ] )\n options\n\n val subrange\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> lower_bound:'k key Maybe_bound.t\n -> upper_bound:'k key Maybe_bound.t\n -> ('k, 'v, 'cmp) t )\n options\n\n val fold_range_inclusive\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> min:'k key\n -> max:'k key\n -> init:'a\n -> f:(key:'k key -> data:'v -> 'a -> 'a)\n -> 'a )\n options\n\n val range_to_alist\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> min:'k key -> max:'k key -> ('k key * 'v) list )\n options\n\n val closest_key\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'k key\n -> ('k key * 'v) option )\n options\n\n val nth : ('k, 'cmp, ('k, 'v, 'cmp) t -> int -> ('k key * 'v) option) options\n val nth_exn : ('k, 'cmp, ('k, 'v, 'cmp) t -> int -> 'k key * 'v) options\n val rank : ('k, 'cmp, ('k, _, 'cmp) t -> 'k key -> int option) options\n val to_tree : ('k, 'v, 'cmp) t -> ('k key, 'v, 'cmp) tree\n\n val to_sequence\n : ( 'k\n , 'cmp\n , ?order:[ `Increasing_key | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:'k key\n -> ?keys_less_or_equal_to:'k key\n -> ('k, 'v, 'cmp) t\n -> ('k key * 'v) Sequence.t )\n options\n\n val binary_search\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> compare:(key:'k key -> data:'v -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> ('k key * 'v) option )\n options\n\n val binary_search_segmented\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> segment_of:(key:'k key -> data:'v -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> ('k key * 'v) option )\n options\nend\n\nmodule type Accessors1 = sig\n type 'a t\n type 'a tree\n type key\n type comparator_witness\n\n val invariants : _ t -> bool\n val is_empty : _ t -> bool\n val length : _ t -> int\n val add : 'a t -> key:key -> data:'a -> 'a t Or_duplicate.t\n val add_exn : 'a t -> key:key -> data:'a -> 'a t\n val set : 'a t -> key:key -> data:'a -> 'a t\n val add_multi : 'a list t -> key:key -> data:'a -> 'a list t\n val remove_multi : 'a list t -> key -> 'a list t\n val find_multi : 'a list t -> key -> 'a list\n val change : 'a t -> key -> f:('a option -> 'a option) -> 'a t\n val update : 'a t -> key -> f:('a option -> 'a) -> 'a t\n val find : 'a t -> key -> 'a option\n val find_exn : 'a t -> key -> 'a\n val remove : 'a t -> key -> 'a t\n val mem : _ t -> key -> bool\n val iter_keys : _ t -> f:(key -> unit) -> unit\n val iter : 'a t -> f:('a -> unit) -> unit\n val iteri : 'a t -> f:(key:key -> data:'a -> unit) -> unit\n\n val iteri_until\n : 'a t\n -> f:(key:key -> data:'a -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n val iter2\n : 'a t\n -> 'b t\n -> f:(key:key -> data:[ `Left of 'a | `Right of 'b | `Both of 'a * 'b ] -> unit)\n -> unit\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n val mapi : 'a t -> f:(key:key -> data:'a -> 'b) -> 'b t\n val fold : 'a t -> init:'b -> f:(key:key -> data:'a -> 'b -> 'b) -> 'b\n val fold_right : 'a t -> init:'b -> f:(key:key -> data:'a -> 'b -> 'b) -> 'b\n\n val fold2\n : 'a t\n -> 'b t\n -> init:'c\n -> f:(key:key -> data:[ `Left of 'a | `Right of 'b | `Both of 'a * 'b ] -> 'c -> 'c)\n -> 'c\n\n val filter_keys : 'a t -> f:(key -> bool) -> 'a t\n val filter : 'a t -> f:('a -> bool) -> 'a t\n val filteri : 'a t -> f:(key:key -> data:'a -> bool) -> 'a t\n val filter_map : 'a t -> f:('a -> 'b option) -> 'b t\n val filter_mapi : 'a t -> f:(key:key -> data:'a -> 'b option) -> 'b t\n val partition_mapi : 'a t -> f:(key:key -> data:'a -> ('b, 'c) Either.t) -> 'b t * 'c t\n val partition_map : 'a t -> f:('a -> ('b, 'c) Either.t) -> 'b t * 'c t\n val partitioni_tf : 'a t -> f:(key:key -> data:'a -> bool) -> 'a t * 'a t\n val partition_tf : 'a t -> f:('a -> bool) -> 'a t * 'a t\n val combine_errors : 'a Or_error.t t -> 'a t Or_error.t\n val compare_direct : ('a -> 'a -> int) -> 'a t -> 'a t -> int\n val equal : ('a -> 'a -> bool) -> 'a t -> 'a t -> bool\n val keys : _ t -> key list\n val data : 'a t -> 'a list\n val to_alist : ?key_order:[ `Increasing | `Decreasing ] -> 'a t -> (key * 'a) list\n val validate : name:(key -> string) -> 'a Validate.check -> 'a t Validate.check\n\n val validatei\n : name:(key -> string)\n -> (key * 'a) Validate.check\n -> 'a t Validate.check\n\n val merge\n : 'a t\n -> 'b t\n -> f:(key:key -> [ `Left of 'a | `Right of 'b | `Both of 'a * 'b ] -> 'c option)\n -> 'c t\n\n val symmetric_diff\n : 'a t\n -> 'a t\n -> data_equal:('a -> 'a -> bool)\n -> (key, 'a) Symmetric_diff_element.t Sequence.t\n\n val fold_symmetric_diff\n : 'a t\n -> 'a t\n -> data_equal:('a -> 'a -> bool)\n -> init:'c\n -> f:('c -> (key, 'a) Symmetric_diff_element.t -> 'c)\n -> 'c\n\n val min_elt : 'a t -> (key * 'a) option\n val min_elt_exn : 'a t -> key * 'a\n val max_elt : 'a t -> (key * 'a) option\n val max_elt_exn : 'a t -> key * 'a\n val for_all : 'a t -> f:('a -> bool) -> bool\n val for_alli : 'a t -> f:(key:key -> data:'a -> bool) -> bool\n val exists : 'a t -> f:('a -> bool) -> bool\n val existsi : 'a t -> f:(key:key -> data:'a -> bool) -> bool\n val count : 'a t -> f:('a -> bool) -> int\n val counti : 'a t -> f:(key:key -> data:'a -> bool) -> int\n val split : 'a t -> key -> 'a t * (key * 'a) option * 'a t\n\n val append\n : lower_part:'a t\n -> upper_part:'a t\n -> [ `Ok of 'a t | `Overlapping_key_ranges ]\n\n val subrange\n : 'a t\n -> lower_bound:key Maybe_bound.t\n -> upper_bound:key Maybe_bound.t\n -> 'a t\n\n val fold_range_inclusive\n : 'a t\n -> min:key\n -> max:key\n -> init:'b\n -> f:(key:key -> data:'a -> 'b -> 'b)\n -> 'b\n\n val range_to_alist : 'a t -> min:key -> max:key -> (key * 'a) list\n\n val closest_key\n : 'a t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> key\n -> (key * 'a) option\n\n val nth : 'a t -> int -> (key * 'a) option\n val nth_exn : 'a t -> int -> key * 'a\n val rank : _ t -> key -> int option\n val to_tree : 'a t -> 'a tree\n\n val to_sequence\n : ?order:[ `Increasing_key | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:key\n -> ?keys_less_or_equal_to:key\n -> 'a t\n -> (key * 'a) Sequence.t\n\n val binary_search\n : 'a t\n -> compare:(key:key -> data:'a -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> (key * 'a) option\n\n val binary_search_segmented\n : 'a t\n -> segment_of:(key:key -> data:'a -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> (key * 'a) option\nend\n\nmodule type Accessors2 = sig\n type ('a, 'b) t\n type ('a, 'b) tree\n type comparator_witness\n\n val invariants : (_, _) t -> bool\n val is_empty : (_, _) t -> bool\n val length : (_, _) t -> int\n val add : ('a, 'b) t -> key:'a -> data:'b -> ('a, 'b) t Or_duplicate.t\n val add_exn : ('a, 'b) t -> key:'a -> data:'b -> ('a, 'b) t\n val set : ('a, 'b) t -> key:'a -> data:'b -> ('a, 'b) t\n val add_multi : ('a, 'b list) t -> key:'a -> data:'b -> ('a, 'b list) t\n val remove_multi : ('a, 'b list) t -> 'a -> ('a, 'b list) t\n val find_multi : ('a, 'b list) t -> 'a -> 'b list\n val change : ('a, 'b) t -> 'a -> f:('b option -> 'b option) -> ('a, 'b) t\n val update : ('a, 'b) t -> 'a -> f:('b option -> 'b) -> ('a, 'b) t\n val find : ('a, 'b) t -> 'a -> 'b option\n val find_exn : ('a, 'b) t -> 'a -> 'b\n val remove : ('a, 'b) t -> 'a -> ('a, 'b) t\n val mem : ('a, 'b) t -> 'a -> bool\n val iter_keys : ('a, _) t -> f:('a -> unit) -> unit\n val iter : (_, 'b) t -> f:('b -> unit) -> unit\n val iteri : ('a, 'b) t -> f:(key:'a -> data:'b -> unit) -> unit\n\n val iteri_until\n : ('a, 'b) t\n -> f:(key:'a -> data:'b -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n val iter2\n : ('a, 'b) t\n -> ('a, 'c) t\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> unit)\n -> unit\n\n val map : ('a, 'b) t -> f:('b -> 'c) -> ('a, 'c) t\n val mapi : ('a, 'b) t -> f:(key:'a -> data:'b -> 'c) -> ('a, 'c) t\n val fold : ('a, 'b) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n val fold_right : ('a, 'b) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n\n val fold2\n : ('a, 'b) t\n -> ('a, 'c) t\n -> init:'d\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd -> 'd)\n -> 'd\n\n val filter_keys : ('a, 'b) t -> f:('a -> bool) -> ('a, 'b) t\n val filter : ('a, 'b) t -> f:('b -> bool) -> ('a, 'b) t\n val filteri : ('a, 'b) t -> f:(key:'a -> data:'b -> bool) -> ('a, 'b) t\n val filter_map : ('a, 'b) t -> f:('b -> 'c option) -> ('a, 'c) t\n val filter_mapi : ('a, 'b) t -> f:(key:'a -> data:'b -> 'c option) -> ('a, 'c) t\n\n val partition_mapi\n : ('a, 'b) t\n -> f:(key:'a -> data:'b -> ('c, 'd) Either.t)\n -> ('a, 'c) t * ('a, 'd) t\n\n val partition_map\n : ('a, 'b) t\n -> f:('b -> ('c, 'd) Either.t)\n -> ('a, 'c) t * ('a, 'd) t\n\n val partitioni_tf\n : ('a, 'b) t\n -> f:(key:'a -> data:'b -> bool)\n -> ('a, 'b) t * ('a, 'b) t\n\n val partition_tf : ('a, 'b) t -> f:('b -> bool) -> ('a, 'b) t * ('a, 'b) t\n val combine_errors : ('a, 'b Or_error.t) t -> ('a, 'b) t Or_error.t\n val compare_direct : ('b -> 'b -> int) -> ('a, 'b) t -> ('a, 'b) t -> int\n val equal : ('b -> 'b -> bool) -> ('a, 'b) t -> ('a, 'b) t -> bool\n val keys : ('a, _) t -> 'a list\n val data : (_, 'b) t -> 'b list\n val to_alist : ?key_order:[ `Increasing | `Decreasing ] -> ('a, 'b) t -> ('a * 'b) list\n val validate : name:('a -> string) -> 'b Validate.check -> ('a, 'b) t Validate.check\n\n val validatei\n : name:('a -> string)\n -> ('a * 'b) Validate.check\n -> ('a, 'b) t Validate.check\n\n val merge\n : ('a, 'b) t\n -> ('a, 'c) t\n -> f:(key:'a -> [ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd option)\n -> ('a, 'd) t\n\n val symmetric_diff\n : ('a, 'b) t\n -> ('a, 'b) t\n -> data_equal:('b -> 'b -> bool)\n -> ('a, 'b) Symmetric_diff_element.t Sequence.t\n\n val fold_symmetric_diff\n : ('a, 'b) t\n -> ('a, 'b) t\n -> data_equal:('b -> 'b -> bool)\n -> init:'c\n -> f:('c -> ('a, 'b) Symmetric_diff_element.t -> 'c)\n -> 'c\n\n val min_elt : ('a, 'b) t -> ('a * 'b) option\n val min_elt_exn : ('a, 'b) t -> 'a * 'b\n val max_elt : ('a, 'b) t -> ('a * 'b) option\n val max_elt_exn : ('a, 'b) t -> 'a * 'b\n val for_all : (_, 'b) t -> f:('b -> bool) -> bool\n val for_alli : ('a, 'b) t -> f:(key:'a -> data:'b -> bool) -> bool\n val exists : (_, 'b) t -> f:('b -> bool) -> bool\n val existsi : ('a, 'b) t -> f:(key:'a -> data:'b -> bool) -> bool\n val count : (_, 'b) t -> f:('b -> bool) -> int\n val counti : ('a, 'b) t -> f:(key:'a -> data:'b -> bool) -> int\n val split : ('a, 'b) t -> 'a -> ('a, 'b) t * ('a * 'b) option * ('a, 'b) t\n\n val append\n : lower_part:('a, 'b) t\n -> upper_part:('a, 'b) t\n -> [ `Ok of ('a, 'b) t | `Overlapping_key_ranges ]\n\n val subrange\n : ('a, 'b) t\n -> lower_bound:'a Maybe_bound.t\n -> upper_bound:'a Maybe_bound.t\n -> ('a, 'b) t\n\n val fold_range_inclusive\n : ('a, 'b) t\n -> min:'a\n -> max:'a\n -> init:'c\n -> f:(key:'a -> data:'b -> 'c -> 'c)\n -> 'c\n\n val range_to_alist : ('a, 'b) t -> min:'a -> max:'a -> ('a * 'b) list\n\n val closest_key\n : ('a, 'b) t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'a\n -> ('a * 'b) option\n\n val nth : ('a, 'b) t -> int -> ('a * 'b) option\n val nth_exn : ('a, 'b) t -> int -> 'a * 'b\n val rank : ('a, _) t -> 'a -> int option\n val to_tree : ('a, 'b) t -> ('a, 'b) tree\n\n val to_sequence\n : ?order:[ `Increasing_key | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:'a\n -> ?keys_less_or_equal_to:'a\n -> ('a, 'b) t\n -> ('a * 'b) Sequence.t\n\n val binary_search\n : ('k, 'v) t\n -> compare:(key:'k -> data:'v -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> ('k * 'v) option\n\n val binary_search_segmented\n : ('k, 'v) t\n -> segment_of:(key:'k -> data:'v -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> ('k * 'v) option\nend\n\nmodule type Accessors3 = sig\n type ('a, 'b, 'cmp) t\n type ('a, 'b, 'cmp) tree\n\n val invariants : (_, _, _) t -> bool\n val is_empty : (_, _, _) t -> bool\n val length : (_, _, _) t -> int\n val add : ('a, 'b, 'cmp) t -> key:'a -> data:'b -> ('a, 'b, 'cmp) t Or_duplicate.t\n val add_exn : ('a, 'b, 'cmp) t -> key:'a -> data:'b -> ('a, 'b, 'cmp) t\n val set : ('a, 'b, 'cmp) t -> key:'a -> data:'b -> ('a, 'b, 'cmp) t\n val add_multi : ('a, 'b list, 'cmp) t -> key:'a -> data:'b -> ('a, 'b list, 'cmp) t\n val remove_multi : ('a, 'b list, 'cmp) t -> 'a -> ('a, 'b list, 'cmp) t\n val find_multi : ('a, 'b list, 'cmp) t -> 'a -> 'b list\n val change : ('a, 'b, 'cmp) t -> 'a -> f:('b option -> 'b option) -> ('a, 'b, 'cmp) t\n val update : ('a, 'b, 'cmp) t -> 'a -> f:('b option -> 'b) -> ('a, 'b, 'cmp) t\n val find : ('a, 'b, 'cmp) t -> 'a -> 'b option\n val find_exn : ('a, 'b, 'cmp) t -> 'a -> 'b\n val remove : ('a, 'b, 'cmp) t -> 'a -> ('a, 'b, 'cmp) t\n val mem : ('a, 'b, 'cmp) t -> 'a -> bool\n val iter_keys : ('a, _, 'cmp) t -> f:('a -> unit) -> unit\n val iter : (_, 'b, 'cmp) t -> f:('b -> unit) -> unit\n val iteri : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> unit) -> unit\n\n val iteri_until\n : ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n val iter2\n : ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> unit)\n -> unit\n\n val map : ('a, 'b, 'cmp) t -> f:('b -> 'c) -> ('a, 'c, 'cmp) t\n val mapi : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> 'c) -> ('a, 'c, 'cmp) t\n val fold : ('a, 'b, _) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n val fold_right : ('a, 'b, _) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n\n val fold2\n : ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> init:'d\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd -> 'd)\n -> 'd\n\n val filter_keys : ('a, 'b, 'cmp) t -> f:('a -> bool) -> ('a, 'b, 'cmp) t\n val filter : ('a, 'b, 'cmp) t -> f:('b -> bool) -> ('a, 'b, 'cmp) t\n val filteri : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> bool) -> ('a, 'b, 'cmp) t\n val filter_map : ('a, 'b, 'cmp) t -> f:('b -> 'c option) -> ('a, 'c, 'cmp) t\n\n val filter_mapi\n : ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> 'c option)\n -> ('a, 'c, 'cmp) t\n\n val partition_mapi\n : ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> ('c, 'd) Either.t)\n -> ('a, 'c, 'cmp) t * ('a, 'd, 'cmp) t\n\n val partition_map\n : ('a, 'b, 'cmp) t\n -> f:('b -> ('c, 'd) Either.t)\n -> ('a, 'c, 'cmp) t * ('a, 'd, 'cmp) t\n\n val partitioni_tf\n : ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> bool)\n -> ('a, 'b, 'cmp) t * ('a, 'b, 'cmp) t\n\n val partition_tf\n : ('a, 'b, 'cmp) t\n -> f:('b -> bool)\n -> ('a, 'b, 'cmp) t * ('a, 'b, 'cmp) t\n\n val combine_errors : ('a, 'b Or_error.t, 'cmp) t -> ('a, 'b, 'cmp) t Or_error.t\n val compare_direct : ('b -> 'b -> int) -> ('a, 'b, 'cmp) t -> ('a, 'b, 'cmp) t -> int\n val equal : ('b -> 'b -> bool) -> ('a, 'b, 'cmp) t -> ('a, 'b, 'cmp) t -> bool\n val keys : ('a, _, _) t -> 'a list\n val data : (_, 'b, _) t -> 'b list\n\n val to_alist\n : ?key_order:[ `Increasing | `Decreasing ]\n -> ('a, 'b, _) t\n -> ('a * 'b) list\n\n val validate : name:('a -> string) -> 'b Validate.check -> ('a, 'b, _) t Validate.check\n\n val validatei\n : name:('a -> string)\n -> ('a * 'b) Validate.check\n -> ('a, 'b, _) t Validate.check\n\n val merge\n : ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> f:(key:'a -> [ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd option)\n -> ('a, 'd, 'cmp) t\n\n val symmetric_diff\n : ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> data_equal:('b -> 'b -> bool)\n -> ('a, 'b) Symmetric_diff_element.t Sequence.t\n\n val fold_symmetric_diff\n : ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> data_equal:('b -> 'b -> bool)\n -> init:'c\n -> f:('c -> ('a, 'b) Symmetric_diff_element.t -> 'c)\n -> 'c\n\n val min_elt : ('a, 'b, 'cmp) t -> ('a * 'b) option\n val min_elt_exn : ('a, 'b, 'cmp) t -> 'a * 'b\n val max_elt : ('a, 'b, 'cmp) t -> ('a * 'b) option\n val max_elt_exn : ('a, 'b, 'cmp) t -> 'a * 'b\n val for_all : (_, 'b, _) t -> f:('b -> bool) -> bool\n val for_alli : ('a, 'b, _) t -> f:(key:'a -> data:'b -> bool) -> bool\n val exists : (_, 'b, _) t -> f:('b -> bool) -> bool\n val existsi : ('a, 'b, _) t -> f:(key:'a -> data:'b -> bool) -> bool\n val count : (_, 'b, _) t -> f:('b -> bool) -> int\n val counti : ('a, 'b, _) t -> f:(key:'a -> data:'b -> bool) -> int\n\n val split\n : ('k, 'v, 'cmp) t\n -> 'k\n -> ('k, 'v, 'cmp) t * ('k * 'v) option * ('k, 'v, 'cmp) t\n\n val append\n : lower_part:('k, 'v, 'cmp) t\n -> upper_part:('k, 'v, 'cmp) t\n -> [ `Ok of ('k, 'v, 'cmp) t | `Overlapping_key_ranges ]\n\n val subrange\n : ('k, 'v, 'cmp) t\n -> lower_bound:'k Maybe_bound.t\n -> upper_bound:'k Maybe_bound.t\n -> ('k, 'v, 'cmp) t\n\n val fold_range_inclusive\n : ('a, 'b, _) t\n -> min:'a\n -> max:'a\n -> init:'c\n -> f:(key:'a -> data:'b -> 'c -> 'c)\n -> 'c\n\n val range_to_alist : ('a, 'b, _) t -> min:'a -> max:'a -> ('a * 'b) list\n\n val closest_key\n : ('a, 'b, _) t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'a\n -> ('a * 'b) option\n\n val nth : ('a, 'b, _) t -> int -> ('a * 'b) option\n val nth_exn : ('a, 'b, _) t -> int -> 'a * 'b\n val rank : ('a, _, _) t -> 'a -> int option\n val to_tree : ('a, 'b, 'cmp) t -> ('a, 'b, 'cmp) tree\n\n val to_sequence\n : ?order:[ `Increasing_key | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:'a\n -> ?keys_less_or_equal_to:'a\n -> ('a, 'b, _) t\n -> ('a * 'b) Sequence.t\n\n val binary_search\n : ('k, 'v, _) t\n -> compare:(key:'k -> data:'v -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> ('k * 'v) option\n\n val binary_search_segmented\n : ('k, 'v, _) t\n -> segment_of:(key:'k -> data:'v -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> ('k * 'v) option\nend\n\nmodule type Accessors3_with_comparator = sig\n type ('a, 'b, 'cmp) t\n type ('a, 'b, 'cmp) tree\n\n val invariants : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> bool\n val is_empty : ('a, 'b, 'cmp) t -> bool\n val length : ('a, 'b, 'cmp) t -> int\n\n val add\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> key:'a\n -> data:'b\n -> ('a, 'b, 'cmp) t Or_duplicate.t\n\n val add_exn\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> key:'a\n -> data:'b\n -> ('a, 'b, 'cmp) t\n\n val set\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> key:'a\n -> data:'b\n -> ('a, 'b, 'cmp) t\n\n val add_multi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b list, 'cmp) t\n -> key:'a\n -> data:'b\n -> ('a, 'b list, 'cmp) t\n\n val remove_multi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b list, 'cmp) t\n -> 'a\n -> ('a, 'b list, 'cmp) t\n\n val find_multi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b list, 'cmp) t\n -> 'a\n -> 'b list\n\n val change\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> 'a\n -> f:('b option -> 'b option)\n -> ('a, 'b, 'cmp) t\n\n val update\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> 'a\n -> f:('b option -> 'b)\n -> ('a, 'b, 'cmp) t\n\n val find : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> 'a -> 'b option\n val find_exn : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> 'a -> 'b\n\n val remove\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> 'a\n -> ('a, 'b, 'cmp) t\n\n val mem : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> 'a -> bool\n val iter_keys : ('a, _, 'cmp) t -> f:('a -> unit) -> unit\n val iter : (_, 'b, 'cmp) t -> f:('b -> unit) -> unit\n val iteri : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> unit) -> unit\n\n val iteri_until\n : ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n val iter2\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> unit)\n -> unit\n\n val map : ('a, 'b, 'cmp) t -> f:('b -> 'c) -> ('a, 'c, 'cmp) t\n val mapi : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> 'c) -> ('a, 'c, 'cmp) t\n val fold : ('a, 'b, _) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n val fold_right : ('a, 'b, _) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n\n val fold2\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> init:'d\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd -> 'd)\n -> 'd\n\n val filter_keys\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:('a -> bool)\n -> ('a, 'b, 'cmp) t\n\n val filter\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:('b -> bool)\n -> ('a, 'b, 'cmp) t\n\n val filteri\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> bool)\n -> ('a, 'b, 'cmp) t\n\n val filter_map\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:('b -> 'c option)\n -> ('a, 'c, 'cmp) t\n\n val filter_mapi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> 'c option)\n -> ('a, 'c, 'cmp) t\n\n val partition_mapi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> ('c, 'd) Either.t)\n -> ('a, 'c, 'cmp) t * ('a, 'd, 'cmp) t\n\n val partition_map\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:('b -> ('c, 'd) Either.t)\n -> ('a, 'c, 'cmp) t * ('a, 'd, 'cmp) t\n\n val partitioni_tf\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> bool)\n -> ('a, 'b, 'cmp) t * ('a, 'b, 'cmp) t\n\n val partition_tf\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:('b -> bool)\n -> ('a, 'b, 'cmp) t * ('a, 'b, 'cmp) t\n\n val combine_errors\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b Or_error.t, 'cmp) t\n -> ('a, 'b, 'cmp) t Or_error.t\n\n val compare_direct\n : comparator:('a, 'cmp) Comparator.t\n -> ('b -> 'b -> int)\n -> ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> int\n\n val equal\n : comparator:('a, 'cmp) Comparator.t\n -> ('b -> 'b -> bool)\n -> ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> bool\n\n val keys : ('a, _, _) t -> 'a list\n val data : (_, 'b, _) t -> 'b list\n\n val to_alist\n : ?key_order:[ `Increasing | `Decreasing ]\n -> ('a, 'b, _) t\n -> ('a * 'b) list\n\n val validate : name:('a -> string) -> 'b Validate.check -> ('a, 'b, _) t Validate.check\n\n val validatei\n : name:('a -> string)\n -> ('a * 'b) Validate.check\n -> ('a, 'b, _) t Validate.check\n\n val merge\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> f:(key:'a -> [ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd option)\n -> ('a, 'd, 'cmp) t\n\n val symmetric_diff\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> data_equal:('b -> 'b -> bool)\n -> ('a, 'b) Symmetric_diff_element.t Sequence.t\n\n val fold_symmetric_diff\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> data_equal:('b -> 'b -> bool)\n -> init:'c\n -> f:('c -> ('a, 'b) Symmetric_diff_element.t -> 'c)\n -> 'c\n\n val min_elt : ('a, 'b, 'cmp) t -> ('a * 'b) option\n val min_elt_exn : ('a, 'b, 'cmp) t -> 'a * 'b\n val max_elt : ('a, 'b, 'cmp) t -> ('a * 'b) option\n val max_elt_exn : ('a, 'b, 'cmp) t -> 'a * 'b\n val for_all : ('a, 'b, 'cmp) t -> f:('b -> bool) -> bool\n val for_alli : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> bool) -> bool\n val exists : ('a, 'b, 'cmp) t -> f:('b -> bool) -> bool\n val existsi : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> bool) -> bool\n val count : ('a, 'b, 'cmp) t -> f:('b -> bool) -> int\n val counti : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> bool) -> int\n\n val split\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> 'a\n -> ('a, 'b, 'cmp) t * ('a * 'b) option * ('a, 'b, 'cmp) t\n\n val append\n : comparator:('a, 'cmp) Comparator.t\n -> lower_part:('a, 'b, 'cmp) t\n -> upper_part:('a, 'b, 'cmp) t\n -> [ `Ok of ('a, 'b, 'cmp) t | `Overlapping_key_ranges ]\n\n val subrange\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> lower_bound:'a Maybe_bound.t\n -> upper_bound:'a Maybe_bound.t\n -> ('a, 'b, 'cmp) t\n\n val fold_range_inclusive\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> min:'a\n -> max:'a\n -> init:'c\n -> f:(key:'a -> data:'b -> 'c -> 'c)\n -> 'c\n\n val range_to_alist\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> min:'a\n -> max:'a\n -> ('a * 'b) list\n\n val closest_key\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'a\n -> ('a * 'b) option\n\n val nth\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> int\n -> ('a * 'b) option\n\n val nth_exn : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> int -> 'a * 'b\n val rank : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> 'a -> int option\n val to_tree : ('a, 'b, 'cmp) t -> ('a, 'b, 'cmp) tree\n\n val to_sequence\n : comparator:('a, 'cmp) Comparator.t\n -> ?order:[ `Increasing_key | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:'a\n -> ?keys_less_or_equal_to:'a\n -> ('a, 'b, 'cmp) t\n -> ('a * 'b) Sequence.t\n\n val binary_search\n : comparator:('k, 'cmp) Comparator.t\n -> ('k, 'v, 'cmp) t\n -> compare:(key:'k -> data:'v -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> ('k * 'v) option\n\n val binary_search_segmented\n : comparator:('k, 'cmp) Comparator.t\n -> ('k, 'v, 'cmp) t\n -> segment_of:(key:'k -> data:'v -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> ('k * 'v) option\nend\n\n(** Consistency checks (same as in [Container]). *)\nmodule Check_accessors\n (T : T3)\n (Tree : T3)\n (Key : T1)\n (Cmp : T1)\n (Options : T3)\n (M : Accessors_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Options.t\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) T.t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n with type 'a key := 'a Key.t\n with type 'cmp cmp := 'cmp Cmp.t) =\nstruct end\n\nmodule Check_accessors1 (M : Accessors1) =\n Check_accessors\n (struct\n type ('a, 'b, 'c) t = 'b M.t\n end)\n (struct\n type ('a, 'b, 'c) t = 'b M.tree\n end)\n (struct\n type 'a t = M.key\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors2 (M : Accessors2) =\n Check_accessors\n (struct\n type ('a, 'b, 'c) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b, 'c) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors3 (M : Accessors3) =\n Check_accessors\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.t\n end)\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'a t = 'a\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors3_with_comparator (M : Accessors3_with_comparator) =\n Check_accessors\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.t\n end)\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'a t = 'a\n end)\n (With_comparator)\n (M)\n\nmodule type Creators_generic = sig\n type ('k, 'v, 'cmp) t\n type ('k, 'v, 'cmp) tree\n type 'k key\n type ('a, 'cmp, 'z) options\n type 'cmp cmp\n\n val empty : ('k, 'cmp, ('k, _, 'cmp) t) options\n val singleton : ('k, 'cmp, 'k key -> 'v -> ('k, 'v, 'cmp) t) options\n\n val of_sorted_array\n : ('k, 'cmp, ('k key * 'v) array -> ('k, 'v, 'cmp) t Or_error.t) options\n\n val of_sorted_array_unchecked\n : ('k, 'cmp, ('k key * 'v) array -> ('k, 'v, 'cmp) t) options\n\n val of_increasing_iterator_unchecked\n : ('k, 'cmp, len:int -> f:(int -> 'k key * 'v) -> ('k, 'v, 'cmp) t) options\n\n val of_alist\n : ( 'k\n , 'cmp\n , ('k key * 'v) list -> [ `Ok of ('k, 'v, 'cmp) t | `Duplicate_key of 'k key ] )\n options\n\n val of_alist_or_error\n : ('k, 'cmp, ('k key * 'v) list -> ('k, 'v, 'cmp) t Or_error.t) options\n\n val of_alist_exn : ('k, 'cmp, ('k key * 'v) list -> ('k, 'v, 'cmp) t) options\n val of_alist_multi : ('k, 'cmp, ('k key * 'v) list -> ('k, 'v list, 'cmp) t) options\n\n val of_alist_fold\n : ( 'k\n , 'cmp\n , ('k key * 'v1) list -> init:'v2 -> f:('v2 -> 'v1 -> 'v2) -> ('k, 'v2, 'cmp) t )\n options\n\n val of_alist_reduce\n : ('k, 'cmp, ('k key * 'v) list -> f:('v -> 'v -> 'v) -> ('k, 'v, 'cmp) t) options\n\n val of_increasing_sequence\n : ('k, 'cmp, ('k key * 'v) Sequence.t -> ('k, 'v, 'cmp) t Or_error.t) options\n\n val of_sequence\n : ( 'k\n , 'cmp\n , ('k key * 'v) Sequence.t -> [ `Ok of ('k, 'v, 'cmp) t | `Duplicate_key of 'k key ]\n )\n options\n\n val of_sequence_or_error\n : ('k, 'cmp, ('k key * 'v) Sequence.t -> ('k, 'v, 'cmp) t Or_error.t) options\n\n val of_sequence_exn : ('k, 'cmp, ('k key * 'v) Sequence.t -> ('k, 'v, 'cmp) t) options\n\n val of_sequence_multi\n : ('k, 'cmp, ('k key * 'v) Sequence.t -> ('k, 'v list, 'cmp) t) options\n\n val of_sequence_fold\n : ( 'k\n , 'cmp\n , ('k key * 'v1) Sequence.t\n -> init:'v2\n -> f:('v2 -> 'v1 -> 'v2)\n -> ('k, 'v2, 'cmp) t )\n options\n\n val of_sequence_reduce\n : ( 'k\n , 'cmp\n , ('k key * 'v) Sequence.t -> f:('v -> 'v -> 'v) -> ('k, 'v, 'cmp) t )\n options\n\n val of_iteri\n : ( 'k\n , 'cmp\n , iteri:(f:(key:'k key -> data:'v -> unit) -> unit)\n -> [ `Ok of ('k, 'v, 'cmp) t | `Duplicate_key of 'k key ] )\n options\n\n val of_tree : ('k, 'cmp, ('k key, 'v, 'cmp) tree -> ('k, 'v, 'cmp) t) options\nend\n\nmodule type Creators1 = sig\n type 'a t\n type 'a tree\n type key\n type comparator_witness\n\n val empty : _ t\n val singleton : key -> 'a -> 'a t\n val of_alist : (key * 'a) list -> [ `Ok of 'a t | `Duplicate_key of key ]\n val of_alist_or_error : (key * 'a) list -> 'a t Or_error.t\n val of_alist_exn : (key * 'a) list -> 'a t\n val of_alist_multi : (key * 'a) list -> 'a list t\n val of_alist_fold : (key * 'a) list -> init:'b -> f:('b -> 'a -> 'b) -> 'b t\n val of_alist_reduce : (key * 'a) list -> f:('a -> 'a -> 'a) -> 'a t\n val of_sorted_array : (key * 'a) array -> 'a t Or_error.t\n val of_sorted_array_unchecked : (key * 'a) array -> 'a t\n val of_increasing_iterator_unchecked : len:int -> f:(int -> key * 'a) -> 'a t\n val of_increasing_sequence : (key * 'a) Sequence.t -> 'a t Or_error.t\n val of_sequence : (key * 'a) Sequence.t -> [ `Ok of 'a t | `Duplicate_key of key ]\n val of_sequence_or_error : (key * 'a) Sequence.t -> 'a t Or_error.t\n val of_sequence_exn : (key * 'a) Sequence.t -> 'a t\n val of_sequence_multi : (key * 'a) Sequence.t -> 'a list t\n val of_sequence_fold : (key * 'a) Sequence.t -> init:'b -> f:('b -> 'a -> 'b) -> 'b t\n val of_sequence_reduce : (key * 'a) Sequence.t -> f:('a -> 'a -> 'a) -> 'a t\n\n val of_iteri\n : iteri:(f:(key:key -> data:'v -> unit) -> unit)\n -> [ `Ok of 'v t | `Duplicate_key of key ]\n\n val of_tree : 'a tree -> 'a t\nend\n\nmodule type Creators2 = sig\n type ('a, 'b) t\n type ('a, 'b) tree\n type comparator_witness\n\n val empty : (_, _) t\n val singleton : 'a -> 'b -> ('a, 'b) t\n val of_alist : ('a * 'b) list -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a ]\n val of_alist_or_error : ('a * 'b) list -> ('a, 'b) t Or_error.t\n val of_alist_exn : ('a * 'b) list -> ('a, 'b) t\n val of_alist_multi : ('a * 'b) list -> ('a, 'b list) t\n val of_alist_fold : ('a * 'b) list -> init:'c -> f:('c -> 'b -> 'c) -> ('a, 'c) t\n val of_alist_reduce : ('a * 'b) list -> f:('b -> 'b -> 'b) -> ('a, 'b) t\n val of_sorted_array : ('a * 'b) array -> ('a, 'b) t Or_error.t\n val of_sorted_array_unchecked : ('a * 'b) array -> ('a, 'b) t\n val of_increasing_iterator_unchecked : len:int -> f:(int -> 'a * 'b) -> ('a, 'b) t\n val of_increasing_sequence : ('a * 'b) Sequence.t -> ('a, 'b) t Or_error.t\n val of_sequence : ('a * 'b) Sequence.t -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a ]\n val of_sequence_or_error : ('a * 'b) Sequence.t -> ('a, 'b) t Or_error.t\n val of_sequence_exn : ('a * 'b) Sequence.t -> ('a, 'b) t\n val of_sequence_multi : ('a * 'b) Sequence.t -> ('a, 'b list) t\n\n val of_sequence_fold\n : ('a * 'b) Sequence.t\n -> init:'c\n -> f:('c -> 'b -> 'c)\n -> ('a, 'c) t\n\n val of_sequence_reduce : ('a * 'b) Sequence.t -> f:('b -> 'b -> 'b) -> ('a, 'b) t\n\n val of_iteri\n : iteri:(f:(key:'a -> data:'b -> unit) -> unit)\n -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a ]\n\n val of_tree : ('a, 'b) tree -> ('a, 'b) t\nend\n\nmodule type Creators3_with_comparator = sig\n type ('a, 'b, 'cmp) t\n type ('a, 'b, 'cmp) tree\n\n val empty : comparator:('a, 'cmp) Comparator.t -> ('a, _, 'cmp) t\n val singleton : comparator:('a, 'cmp) Comparator.t -> 'a -> 'b -> ('a, 'b, 'cmp) t\n\n val of_alist\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> [ `Ok of ('a, 'b, 'cmp) t | `Duplicate_key of 'a ]\n\n val of_alist_or_error\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> ('a, 'b, 'cmp) t Or_error.t\n\n val of_alist_exn\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> ('a, 'b, 'cmp) t\n\n val of_alist_multi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> ('a, 'b list, 'cmp) t\n\n val of_alist_fold\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> init:'c\n -> f:('c -> 'b -> 'c)\n -> ('a, 'c, 'cmp) t\n\n val of_alist_reduce\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> f:('b -> 'b -> 'b)\n -> ('a, 'b, 'cmp) t\n\n val of_sorted_array\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) array\n -> ('a, 'b, 'cmp) t Or_error.t\n\n val of_sorted_array_unchecked\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) array\n -> ('a, 'b, 'cmp) t\n\n val of_increasing_iterator_unchecked\n : comparator:('a, 'cmp) Comparator.t\n -> len:int\n -> f:(int -> 'a * 'b)\n -> ('a, 'b, 'cmp) t\n\n val of_increasing_sequence\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> ('a, 'b, 'cmp) t Or_error.t\n\n val of_sequence\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> [ `Ok of ('a, 'b, 'cmp) t | `Duplicate_key of 'a ]\n\n val of_sequence_or_error\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> ('a, 'b, 'cmp) t Or_error.t\n\n val of_sequence_exn\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> ('a, 'b, 'cmp) t\n\n val of_sequence_multi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> ('a, 'b list, 'cmp) t\n\n val of_sequence_fold\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> init:'c\n -> f:('c -> 'b -> 'c)\n -> ('a, 'c, 'cmp) t\n\n val of_sequence_reduce\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> f:('b -> 'b -> 'b)\n -> ('a, 'b, 'cmp) t\n\n val of_iteri\n : comparator:('a, 'cmp) Comparator.t\n -> iteri:(f:(key:'a -> data:'b -> unit) -> unit)\n -> [ `Ok of ('a, 'b, 'cmp) t | `Duplicate_key of 'a ]\n\n val of_tree\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) tree\n -> ('a, 'b, 'cmp) t\nend\n\nmodule Check_creators\n (T : T3)\n (Tree : T3)\n (Key : T1)\n (Cmp : T1)\n (Options : T3)\n (M : Creators_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Options.t\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) T.t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n with type 'a key := 'a Key.t\n with type 'a cmp := 'a Cmp.t) =\nstruct end\n\nmodule Check_creators1 (M : Creators1) =\n Check_creators\n (struct\n type ('a, 'b, 'c) t = 'b M.t\n end)\n (struct\n type ('a, 'b, 'c) t = 'b M.tree\n end)\n (struct\n type 'a t = M.key\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_creators2 (M : Creators2) =\n Check_creators\n (struct\n type ('a, 'b, 'c) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b, 'c) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_creators3_with_comparator (M : Creators3_with_comparator) =\n Check_creators\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.t\n end)\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'a t = 'a\n end)\n (With_comparator)\n (M)\n\nmodule type Creators_and_accessors_generic = sig\n include Creators_generic\n\n include\n Accessors_generic\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) tree\n with type 'a key := 'a key\n with type 'a cmp := 'a cmp\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) options\nend\n\nmodule type Creators_and_accessors1 = sig\n include Creators1\n\n include\n Accessors1\n with type 'a t := 'a t\n with type 'a tree := 'a tree\n with type key := key\n with type comparator_witness := comparator_witness\nend\n\nmodule type Creators_and_accessors2 = sig\n include Creators2\n\n include\n Accessors2\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) tree\n with type comparator_witness := comparator_witness\nend\n\nmodule type Creators_and_accessors3_with_comparator = sig\n include Creators3_with_comparator\n\n include\n Accessors3_with_comparator\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) tree\nend\n\nmodule type S_poly = Creators_and_accessors2\n\nmodule type For_deriving = sig\n type ('a, 'b, 'c) t\n\n module type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end\n\n module type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Comparator.S with type t := t\n end\n\n module type Compare_m = sig end\n module type Equal_m = sig end\n module type Hash_fold_m = Hasher.S\n\n val sexp_of_m__t\n : (module Sexp_of_m with type t = 'k)\n -> ('v -> Sexp.t)\n -> ('k, 'v, 'cmp) t\n -> Sexp.t\n\n val m__t_of_sexp\n : (module M_of_sexp with type t = 'k and type comparator_witness = 'cmp)\n -> (Sexp.t -> 'v)\n -> Sexp.t\n -> ('k, 'v, 'cmp) t\n\n val m__t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t\n\n val compare_m__t\n : (module Compare_m)\n -> ('v -> 'v -> int)\n -> ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> int\n\n val equal_m__t\n : (module Equal_m)\n -> ('v -> 'v -> bool)\n -> ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> bool\n\n val hash_fold_m__t\n : (module Hash_fold_m with type t = 'k)\n -> (Hash.state -> 'v -> Hash.state)\n -> Hash.state\n -> ('k, 'v, _) t\n -> Hash.state\nend\n\nmodule type Map = sig\n (** [Map] is a functional data structure (balanced binary tree) implementing finite maps\n over a totally-ordered domain, called a \"key\". *)\n\n type ('key, +'value, 'cmp) t\n\n module Or_duplicate = Or_duplicate\n module Continue_or_stop = Continue_or_stop\n\n module Finished_or_unfinished : sig\n type t = Finished_or_unfinished.t =\n | Finished\n | Unfinished\n [@@deriving_inline compare, enumerate, equal, sexp_of]\n\n val compare : t -> t -> int\n val all : t list\n val equal : t -> t -> bool\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n (** Maps [Continue] to [Finished] and [Stop] to [Unfinished]. *)\n val of_continue_or_stop : Continue_or_stop.t -> t\n\n (** Maps [Finished] to [Continue] and [Unfinished] to [Stop]. *)\n val to_continue_or_stop : t -> Continue_or_stop.t\n end\n\n type ('k, 'cmp) comparator =\n (module Comparator.S with type t = 'k and type comparator_witness = 'cmp)\n\n (** Test if the invariants of the internal AVL search tree hold. *)\n val invariants : (_, _, _) t -> bool\n\n (** Returns a first-class module that can be used to build other map/set/etc.\n with the same notion of comparison. *)\n val comparator_s : ('a, _, 'cmp) t -> ('a, 'cmp) comparator\n\n val comparator : ('a, _, 'cmp) t -> ('a, 'cmp) Comparator.t\n\n (** The empty map. *)\n val empty : ('a, 'cmp) comparator -> ('a, 'b, 'cmp) t\n\n (** A map with one (key, data) pair. *)\n val singleton : ('a, 'cmp) comparator -> 'a -> 'b -> ('a, 'b, 'cmp) t\n\n (** Creates a map from an association list with unique keys. *)\n val of_alist\n : ('a, 'cmp) comparator\n -> ('a * 'b) list\n -> [ `Ok of ('a, 'b, 'cmp) t | `Duplicate_key of 'a ]\n\n (** Creates a map from an association list with unique keys, returning an error if\n duplicate ['a] keys are found. *)\n val of_alist_or_error\n : ('a, 'cmp) comparator\n -> ('a * 'b) list\n -> ('a, 'b, 'cmp) t Or_error.t\n\n (** Creates a map from an association list with unique keys, raising an exception if\n duplicate ['a] keys are found. *)\n val of_alist_exn : ('a, 'cmp) comparator -> ('a * 'b) list -> ('a, 'b, 'cmp) t\n\n (** Creates a map from an association list with possibly repeated keys. The values in\n the map for a given key appear in the same order as they did in the association\n list. *)\n val of_alist_multi : ('a, 'cmp) comparator -> ('a * 'b) list -> ('a, 'b list, 'cmp) t\n\n (** Combines an association list into a map, folding together bound values with common\n keys. *)\n val of_alist_fold\n : ('a, 'cmp) comparator\n -> ('a * 'b) list\n -> init:'c\n -> f:('c -> 'b -> 'c)\n -> ('a, 'c, 'cmp) t\n\n (** Combines an association list into a map, reducing together bound values with common\n keys. *)\n val of_alist_reduce\n : ('a, 'cmp) comparator\n -> ('a * 'b) list\n -> f:('b -> 'b -> 'b)\n -> ('a, 'b, 'cmp) t\n\n (** [of_iteri ~iteri] behaves like [of_alist], except that instead of taking a concrete\n data structure, it takes an iteration function. For instance, to convert a string table\n into a map: [of_iteri (module String) ~f:(Hashtbl.iteri table)]. It is faster than\n adding the elements one by one. *)\n val of_iteri\n : ('a, 'cmp) comparator\n -> iteri:(f:(key:'a -> data:'b -> unit) -> unit)\n -> [ `Ok of ('a, 'b, 'cmp) t | `Duplicate_key of 'a ]\n\n (** Creates a map from a sorted array of key-data pairs. The input array must be sorted\n (either in ascending or descending order), as given by the relevant comparator, and\n must not contain duplicate keys. If either of these conditions does not hold,\n an error is returned. *)\n val of_sorted_array\n : ('a, 'cmp) comparator\n -> ('a * 'b) array\n -> ('a, 'b, 'cmp) t Or_error.t\n\n (** Like [of_sorted_array] except that it returns a map with broken invariants when an\n [Error] would have been returned. *)\n val of_sorted_array_unchecked\n : ('a, 'cmp) comparator\n -> ('a * 'b) array\n -> ('a, 'b, 'cmp) t\n\n (** [of_increasing_iterator_unchecked c ~len ~f] behaves like [of_sorted_array_unchecked c\n (Array.init len ~f)], with the additional restriction that a decreasing order is not\n supported. The advantage is not requiring you to allocate an intermediate array. [f]\n will be called with 0, 1, ... [len - 1], in order. *)\n val of_increasing_iterator_unchecked\n : ('a, 'cmp) comparator\n -> len:int\n -> f:(int -> 'a * 'b)\n -> ('a, 'b, 'cmp) t\n\n (** [of_increasing_sequence c seq] behaves like [of_sorted_array c (Sequence.to_array\n seq)], but does not allocate the intermediate array.\n\n The sequence will be folded over once, and the additional time complexity is {e O(n)}.\n *)\n val of_increasing_sequence\n : ('k, 'cmp) comparator\n -> ('k * 'v) Sequence.t\n -> ('k, 'v, 'cmp) t Or_error.t\n\n (** Creates a map from an association sequence with unique keys.\n\n [of_sequence c seq] behaves like [of_alist c (Sequence.to_list seq)] but\n does not allocate the intermediate list.\n\n If your sequence is increasing, use [of_increasing_sequence].\n *)\n val of_sequence\n : ('k, 'cmp) comparator\n -> ('k * 'v) Sequence.t\n -> [ `Ok of ('k, 'v, 'cmp) t | `Duplicate_key of 'k ]\n\n (** Creates a map from an association sequence with unique keys, returning an error if\n duplicate ['a] keys are found.\n\n [of_sequence_or_error c seq] behaves like [of_alist_or_error c (Sequence.to_list seq)]\n but does not allocate the intermediate list.\n *)\n val of_sequence_or_error\n : ('a, 'cmp) comparator\n -> ('a * 'b) Sequence.t\n -> ('a, 'b, 'cmp) t Or_error.t\n\n (** Creates a map from an association sequence with unique keys, raising an exception if\n duplicate ['a] keys are found.\n\n [of_sequence_exn c seq] behaves like [of_alist_exn c (Sequence.to_list seq)] but\n does not allocate the intermediate list.\n *)\n val of_sequence_exn : ('a, 'cmp) comparator -> ('a * 'b) Sequence.t -> ('a, 'b, 'cmp) t\n\n (** Creates a map from an association sequence with possibly repeated keys. The values in\n the map for a given key appear in the same order as they did in the association\n list.\n\n [of_sequence_multi c seq] behaves like [of_alist_exn c (Sequence.to_list seq)] but\n does not allocate the intermediate list.\n *)\n val of_sequence_multi\n : ('a, 'cmp) comparator\n -> ('a * 'b) Sequence.t\n -> ('a, 'b list, 'cmp) t\n\n (** Combines an association sequence into a map, folding together bound values with common\n keys.\n\n [of_sequence_fold c seq ~init ~f] behaves like [of_alist_fold c (Sequence.to_list seq) ~init ~f]\n but does not allocate the intermediate list.\n *)\n val of_sequence_fold\n : ('a, 'cmp) comparator\n -> ('a * 'b) Sequence.t\n -> init:'c\n -> f:('c -> 'b -> 'c)\n -> ('a, 'c, 'cmp) t\n\n (** Combines an association sequence into a map, reducing together bound values with common\n keys.\n\n [of_sequence_reduce c seq ~f] behaves like [of_alist_reduce c (Sequence.to_list seq) ~f]\n but does not allocate the intermediate list. *)\n val of_sequence_reduce\n : ('a, 'cmp) comparator\n -> ('a * 'b) Sequence.t\n -> f:('b -> 'b -> 'b)\n -> ('a, 'b, 'cmp) t\n\n (** Tests whether a map is empty. *)\n val is_empty : (_, _, _) t -> bool\n\n (** [length map] returns the number of elements in [map]. O(1), but [Tree.length] is\n O(n). *)\n val length : (_, _, _) t -> int\n\n (** Returns a new map with the specified new binding; if the key was already bound, its\n previous binding disappears. *)\n val set : ('k, 'v, 'cmp) t -> key:'k -> data:'v -> ('k, 'v, 'cmp) t\n\n (** [add t ~key ~data] adds a new entry to [t] mapping [key] to [data] and returns [`Ok]\n with the new map, or if [key] is already present in [t], returns [`Duplicate]. *)\n val add : ('k, 'v, 'cmp) t -> key:'k -> data:'v -> ('k, 'v, 'cmp) t Or_duplicate.t\n\n val add_exn : ('k, 'v, 'cmp) t -> key:'k -> data:'v -> ('k, 'v, 'cmp) t\n\n (** If [key] is not present then add a singleton list, otherwise, cons data onto the\n head of the existing list. *)\n val add_multi : ('k, 'v list, 'cmp) t -> key:'k -> data:'v -> ('k, 'v list, 'cmp) t\n\n (** If the key is present, then remove its head element; if the result is empty, remove\n the key. *)\n val remove_multi : ('k, 'v list, 'cmp) t -> 'k -> ('k, 'v list, 'cmp) t\n\n (** Returns the value bound to the given key, or the empty list if there is none. *)\n val find_multi : ('k, 'v list, 'cmp) t -> 'k -> 'v list\n\n (** [change t key ~f] returns a new map [m] that is the same as [t] on all keys except\n for [key], and whose value for [key] is defined by [f], i.e., [find m key = f (find\n t key)]. *)\n val change : ('k, 'v, 'cmp) t -> 'k -> f:('v option -> 'v option) -> ('k, 'v, 'cmp) t\n\n (** [update t key ~f] is [change t key ~f:(fun o -> Some (f o))]. *)\n val update : ('k, 'v, 'cmp) t -> 'k -> f:('v option -> 'v) -> ('k, 'v, 'cmp) t\n\n\n (** Returns [Some value] bound to the given key, or [None] if none exists. *)\n val find : ('k, 'v, 'cmp) t -> 'k -> 'v option\n\n (** Returns the value bound to the given key, raising [Caml.Not_found] or [Not_found_s]\n if none exists. *)\n val find_exn : ('k, 'v, 'cmp) t -> 'k -> 'v\n\n (** Returns a new map with any binding for the key in question removed. *)\n val remove : ('k, 'v, 'cmp) t -> 'k -> ('k, 'v, 'cmp) t\n\n (** [mem map key] tests whether [map] contains a binding for [key]. *)\n val mem : ('k, _, 'cmp) t -> 'k -> bool\n\n val iter_keys : ('k, _, _) t -> f:('k -> unit) -> unit\n val iter : (_, 'v, _) t -> f:('v -> unit) -> unit\n val iteri : ('k, 'v, _) t -> f:(key:'k -> data:'v -> unit) -> unit\n\n (** Iterates until the first time [f] returns [Stop]. If [f] returns [Stop], the final\n result is [Unfinished]. Otherwise, the final result is [Finished]. *)\n val iteri_until\n : ('k, 'v, _) t\n -> f:(key:'k -> data:'v -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n (** Iterates two maps side by side. The complexity of this function is O(M + N). If two\n inputs are [[(0, a); (1, a)]] and [[(1, b); (2, b)]], [f] will be called with [[(0,\n `Left a); (1, `Both (a, b)); (2, `Right b)]]. *)\n val iter2\n : ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> f:(key:'k -> data:[ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ] -> unit)\n -> unit\n\n (** Returns a new map with bound values replaced by [f] applied to the bound values.*)\n val map : ('k, 'v1, 'cmp) t -> f:('v1 -> 'v2) -> ('k, 'v2, 'cmp) t\n\n (** Like [map], but the passed function takes both [key] and [data] as arguments. *)\n val mapi : ('k, 'v1, 'cmp) t -> f:(key:'k -> data:'v1 -> 'v2) -> ('k, 'v2, 'cmp) t\n\n (** Folds over keys and data in the map in increasing order of [key]. *)\n val fold : ('k, 'v, _) t -> init:'a -> f:(key:'k -> data:'v -> 'a -> 'a) -> 'a\n\n (** Folds over keys and data in the map in decreasing order of [key]. *)\n val fold_right : ('k, 'v, _) t -> init:'a -> f:(key:'k -> data:'v -> 'a -> 'a) -> 'a\n\n (** Folds over two maps side by side, like [iter2]. *)\n val fold2\n : ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> init:'a\n -> f:(key:'k\n -> data:[ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ]\n -> 'a\n -> 'a)\n -> 'a\n\n (** [filter], [filteri], [filter_keys], [filter_map], and [filter_mapi] run in O(n * lg\n n) time; they simply accumulate each key & data pair retained by [f] into a new map\n using [add]. *)\n val filter_keys : ('k, 'v, 'cmp) t -> f:('k -> bool) -> ('k, 'v, 'cmp) t\n\n val filter : ('k, 'v, 'cmp) t -> f:('v -> bool) -> ('k, 'v, 'cmp) t\n val filteri : ('k, 'v, 'cmp) t -> f:(key:'k -> data:'v -> bool) -> ('k, 'v, 'cmp) t\n\n (** Returns a new map with bound values filtered by [f] applied to the bound values. *)\n val filter_map : ('k, 'v1, 'cmp) t -> f:('v1 -> 'v2 option) -> ('k, 'v2, 'cmp) t\n\n (** Like [filter_map], but the passed function takes both [key] and [data] as\n arguments. *)\n val filter_mapi\n : ('k, 'v1, 'cmp) t\n -> f:(key:'k -> data:'v1 -> 'v2 option)\n -> ('k, 'v2, 'cmp) t\n\n (** [partition_mapi t ~f] returns two new [t]s, with each key in [t] appearing in\n exactly one of the resulting maps depending on its mapping in [f]. *)\n val partition_mapi\n : ('k, 'v1, 'cmp) t\n -> f:(key:'k -> data:'v1 -> ('v2, 'v3) Either.t)\n -> ('k, 'v2, 'cmp) t * ('k, 'v3, 'cmp) t\n\n (** [partition_map t ~f = partition_mapi t ~f:(fun ~key:_ ~data -> f data)] *)\n val partition_map\n : ('k, 'v1, 'cmp) t\n -> f:('v1 -> ('v2, 'v3) Either.t)\n -> ('k, 'v2, 'cmp) t * ('k, 'v3, 'cmp) t\n\n (**\n {[\n partitioni_tf t ~f\n =\n partition_mapi t ~f:(fun ~key ~data ->\n if f ~key ~data\n then First data\n else Second data)\n ]} *)\n val partitioni_tf\n : ('k, 'v, 'cmp) t\n -> f:(key:'k -> data:'v -> bool)\n -> ('k, 'v, 'cmp) t * ('k, 'v, 'cmp) t\n\n (** [partition_tf t ~f = partitioni_tf t ~f:(fun ~key:_ ~data -> f data)] *)\n val partition_tf\n : ('k, 'v, 'cmp) t\n -> f:('v -> bool)\n -> ('k, 'v, 'cmp) t * ('k, 'v, 'cmp) t\n\n (** Produces [Ok] of a map including all keys if all data is [Ok], or an [Error]\n including all errors otherwise. *)\n val combine_errors : ('k, 'v Or_error.t, 'cmp) t -> ('k, 'v, 'cmp) t Or_error.t\n\n (** Returns a total ordering between maps. The first argument is a total ordering used\n to compare data associated with equal keys in the two maps. *)\n val compare_direct : ('v -> 'v -> int) -> ('k, 'v, 'cmp) t -> ('k, 'v, 'cmp) t -> int\n\n (** Hash function: a building block to use when hashing data structures containing maps in\n them. [hash_fold_direct hash_fold_key] is compatible with [compare_direct] iff\n [hash_fold_key] is compatible with [(comparator m).compare] of the map [m] being\n hashed. *)\n val hash_fold_direct : 'k Hash.folder -> 'v Hash.folder -> ('k, 'v, 'cmp) t Hash.folder\n\n (** [equal cmp m1 m2] tests whether the maps [m1] and [m2] are equal, that is, contain\n the same keys and associate each key with the same value. [cmp] is the equality\n predicate used to compare the values associated with the keys. *)\n val equal : ('v -> 'v -> bool) -> ('k, 'v, 'cmp) t -> ('k, 'v, 'cmp) t -> bool\n\n (** Returns a list of the keys in the given map. *)\n val keys : ('k, _, _) t -> 'k list\n\n (** Returns a list of the data in the given map. *)\n val data : (_, 'v, _) t -> 'v list\n\n (** Creates an association list from the given map. *)\n val to_alist\n : ?key_order:[ `Increasing | `Decreasing ] (** default is [`Increasing] *)\n -> ('k, 'v, _) t\n -> ('k * 'v) list\n\n val validate : name:('k -> string) -> 'v Validate.check -> ('k, 'v, _) t Validate.check\n\n val validatei\n : name:('k -> string)\n -> ('k * 'v) Validate.check\n -> ('k, 'v, _) t Validate.check\n\n (** {2 Additional operations on maps} *)\n\n (** Merges two maps. The runtime is O(length(t1) + length(t2)). You shouldn't use this\n function to merge a list of maps; consider using [merge_skewed] instead. *)\n val merge\n : ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> f:(key:'k -> [ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ] -> 'v3 option)\n -> ('k, 'v3, 'cmp) t\n\n (** A special case of [merge], [merge_skewed t1 t2] is a map containing all the\n bindings of [t1] and [t2]. Bindings that appear in both [t1] and [t2] are\n combined into a single value using the [combine] function. In a call\n [combine ~key v1 v2], the value [v1] comes from [t1] and [v2] from [t2].\n\n The runtime of [merge_skewed] is [O(l1 * log(l2))], where [l1] is the length\n of the smaller map and [l2] the length of the larger map. This is likely to\n be faster than [merge] when one of the maps is a lot smaller, or when you\n merge a list of maps. *)\n val merge_skewed\n : ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> combine:(key:'k -> 'v -> 'v -> 'v)\n -> ('k, 'v, 'cmp) t\n\n module Symmetric_diff_element : sig\n type ('k, 'v) t = 'k * [ `Left of 'v | `Right of 'v | `Unequal of 'v * 'v ]\n [@@deriving_inline compare, sexp]\n\n val compare\n : ('k -> 'k -> int)\n -> ('v -> 'v -> int)\n -> ('k, 'v) t\n -> ('k, 'v) t\n -> int\n\n include Ppx_sexp_conv_lib.Sexpable.S2 with type ('k, 'v) t := ('k, 'v) t\n\n [@@@end]\n end\n\n (** [symmetric_diff t1 t2 ~data_equal] returns a list of changes between [t1] and [t2].\n It is intended to be efficient in the case where [t1] and [t2] share a large amount\n of structure. The keys in the output sequence will be in sorted order.\n\n It is assumed that [data_equal] is at least as equating as physical equality: that\n [phys_equal x y] implies [data_equal x y]. Otherwise, [symmetric_diff] may behave in\n unexpected ways. For example, with [~data_equal:(fun _ _ -> false)] it is NOT\n necessarily the case the resulting change sequence will contain an element\n [(k, `Unequal _)] for every key [k] shared by both maps.\n\n Warning: Float equality violates this property! [phys_equal Float.nan Float.nan] is\n true, but [Float.(=) Float.nan Float.nan] is false. *)\n val symmetric_diff\n : ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> data_equal:('v -> 'v -> bool)\n -> ('k, 'v) Symmetric_diff_element.t Sequence.t\n\n (** [fold_symmetric_diff t1 t2 ~data_equal] folds across an implicit sequence of changes\n between [t1] and [t2], in sorted order by keys. Equivalent to\n [Sequence.fold (symmetric_diff t1 t2 ~data_equal)], and more efficient. *)\n val fold_symmetric_diff\n : ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> data_equal:('v -> 'v -> bool)\n -> init:'a\n -> f:('a -> ('k, 'v) Symmetric_diff_element.t -> 'a)\n -> 'a\n\n (** [min_elt map] returns [Some (key, data)] pair corresponding to the minimum key in\n [map], or [None] if empty. *)\n val min_elt : ('k, 'v, _) t -> ('k * 'v) option\n\n val min_elt_exn : ('k, 'v, _) t -> 'k * 'v\n\n (** [max_elt map] returns [Some (key, data)] pair corresponding to the maximum key in\n [map], or [None] if [map] is empty. *)\n val max_elt : ('k, 'v, _) t -> ('k * 'v) option\n\n val max_elt_exn : ('k, 'v, _) t -> 'k * 'v\n\n (** These functions have the same semantics as similar functions in [List]. *)\n\n val for_all : ('k, 'v, _) t -> f:('v -> bool) -> bool\n val for_alli : ('k, 'v, _) t -> f:(key:'k -> data:'v -> bool) -> bool\n val exists : ('k, 'v, _) t -> f:('v -> bool) -> bool\n val existsi : ('k, 'v, _) t -> f:(key:'k -> data:'v -> bool) -> bool\n val count : ('k, 'v, _) t -> f:('v -> bool) -> int\n val counti : ('k, 'v, _) t -> f:(key:'k -> data:'v -> bool) -> int\n\n\n (** [split t key] returns a map of keys strictly less than [key], the mapping of [key] if\n any, and a map of keys strictly greater than [key].\n\n Runtime is O(m + log n), where n is the size of the input map and m is the size of\n the smaller of the two output maps. The O(m) term is due to the need to calculate\n the length of the output maps. *)\n val split\n : ('k, 'v, 'cmp) t\n -> 'k\n -> ('k, 'v, 'cmp) t * ('k * 'v) option * ('k, 'v, 'cmp) t\n\n (** [append ~lower_part ~upper_part] returns [`Ok map] where [map] contains all the\n [(key, value)] pairs from the two input maps if all the keys from [lower_part] are\n less than all the keys from [upper_part]. Otherwise it returns\n [`Overlapping_key_ranges].\n\n Runtime is O(log n) where n is the size of the larger input map. This can be\n significantly faster than [Map.merge] or repeated [Map.add].\n\n {[\n assert (match Map.append ~lower_part ~upper_part with\n | `Ok whole_map ->\n Map.to_alist whole_map\n = List.append (to_alist lower_part) (to_alist upper_part)\n | `Overlapping_key_ranges -> true);\n ]} *)\n val append\n : lower_part:('k, 'v, 'cmp) t\n -> upper_part:('k, 'v, 'cmp) t\n -> [ `Ok of ('k, 'v, 'cmp) t | `Overlapping_key_ranges ]\n\n (** [subrange t ~lower_bound ~upper_bound] returns a map containing all the entries from\n [t] whose keys lie inside the interval indicated by [~lower_bound] and\n [~upper_bound]. If this interval is empty, an empty map is returned.\n\n Runtime is O(m + log n), where n is the size of the input map and m is the size of\n the output map. The O(m) term is due to the need to calculate the length of the\n output map. *)\n val subrange\n : ('k, 'v, 'cmp) t\n -> lower_bound:'k Maybe_bound.t\n -> upper_bound:'k Maybe_bound.t\n -> ('k, 'v, 'cmp) t\n\n (** [fold_range_inclusive t ~min ~max ~init ~f] folds [f] (with initial value [~init])\n over all keys (and their associated values) that are in the range [[min, max]]\n (inclusive). *)\n val fold_range_inclusive\n : ('k, 'v, 'cmp) t\n -> min:'k\n -> max:'k\n -> init:'a\n -> f:(key:'k -> data:'v -> 'a -> 'a)\n -> 'a\n\n (** [range_to_alist t ~min ~max] returns an associative list of the elements whose keys\n lie in [[min, max]] (inclusive), with the smallest key being at the head of the\n list. *)\n val range_to_alist : ('k, 'v, 'cmp) t -> min:'k -> max:'k -> ('k * 'v) list\n\n (** [closest_key t dir k] returns the [(key, value)] pair in [t] with [key] closest to\n [k] that satisfies the given inequality bound.\n\n For example, [closest_key t `Less_than k] would be the pair with the closest key to\n [k] where [key < k].\n\n [to_sequence] can be used to get the same results as [closest_key]. It is less\n efficient for individual lookups but more efficient for finding many elements starting\n at some value. *)\n val closest_key\n : ('k, 'v, 'cmp) t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'k\n -> ('k * 'v) option\n\n (** [nth t n] finds the (key, value) pair of rank n (i.e., such that there are exactly n\n keys strictly less than the found key), if one exists. O(log(length t) + n) time. *)\n val nth : ('k, 'v, _) t -> int -> ('k * 'v) option\n\n val nth_exn : ('k, 'v, _) t -> int -> 'k * 'v\n\n (** [rank t k] If [k] is in [t], returns the number of keys strictly less than [k] in\n [t], and [None] otherwise. *)\n val rank : ('k, 'v, 'cmp) t -> 'k -> int option\n\n\n\n (** [to_sequence ?order ?keys_greater_or_equal_to ?keys_less_or_equal_to t]\n gives a sequence of key-value pairs between [keys_less_or_equal_to] and\n [keys_greater_or_equal_to] inclusive, presented in [order]. If\n [keys_greater_or_equal_to > keys_less_or_equal_to], the sequence is\n empty.\n\n When neither [keys_greater_or_equal_to] nor [keys_less_or_equal_to] are\n provided, the cost is O(log n) up front and amortized O(1) to produce\n each element. If either is provided (and is used by the order parameter\n provided), then the the cost is O(n) up front, and amortized O(1) to\n produce each element. *)\n val to_sequence\n : ?order:[ `Increasing_key (** default *) | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:'k\n -> ?keys_less_or_equal_to:'k\n -> ('k, 'v, 'cmp) t\n -> ('k * 'v) Sequence.t\n\n (** [binary_search t ~compare which elt] returns the [(key, value)] pair in [t]\n specified by [compare] and [which], if one exists.\n\n [t] must be sorted in increasing order according to [compare], where [compare] and\n [elt] divide [t] into three (possibly empty) segments:\n\n {v\n | < elt | = elt | > elt |\n v}\n\n [binary_search] returns an element on the boundary of segments as specified by\n [which]. See the diagram below next to the [which] variants.\n\n [binary_search] does not check that [compare] orders [t], and behavior is\n unspecified if [compare] doesn't order [t]. Behavior is also unspecified if\n [compare] mutates [t]. *)\n val binary_search\n : ('k, 'v, 'cmp) t\n -> compare:(key:'k -> data:'v -> 'key -> int)\n -> [ `Last_strictly_less_than (** {v | < elt X | v} *)\n | `Last_less_than_or_equal_to (** {v | <= elt X | v} *)\n | `Last_equal_to (** {v | = elt X | v} *)\n | `First_equal_to (** {v | X = elt | v} *)\n | `First_greater_than_or_equal_to (** {v | X >= elt | v} *)\n | `First_strictly_greater_than (** {v | X > elt | v} *)\n ]\n -> 'key\n -> ('k * 'v) option\n\n (** [binary_search_segmented t ~segment_of which] takes a [segment_of] function that\n divides [t] into two (possibly empty) segments:\n\n {v\n | segment_of elt = `Left | segment_of elt = `Right |\n v}\n\n [binary_search_segmented] returns the [(key, value)] pair on the boundary of the\n segments as specified by [which]: [`Last_on_left] yields the last element of the\n left segment, while [`First_on_right] yields the first element of the right segment.\n It returns [None] if the segment is empty.\n\n [binary_search_segmented] does not check that [segment_of] segments [t] as in the\n diagram, and behavior is unspecified if [segment_of] doesn't segment [t]. Behavior\n is also unspecified if [segment_of] mutates [t]. *)\n val binary_search_segmented\n : ('k, 'v, 'cmp) t\n -> segment_of:(key:'k -> data:'v -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> ('k * 'v) option\n\n (** [M] is meant to be used in combination with OCaml applicative functor types:\n\n {[\n type string_to_int_map = int Map.M(String).t\n ]}\n\n which stands for:\n\n {[\n type string_to_int_map = (String.t, int, String.comparator_witness) Map.t\n ]}\n\n The point is that [int Map.M(String).t] supports deriving, whereas the second syntax\n doesn't (because there is no such thing as, say, [String.sexp_of_comparator_witness]\n -- instead you would want to pass the comparator directly).\n\n In addition, when using [@@deriving], the requirements on the key module are only\n those needed to satisfy what you are trying to derive on the map itself. Say you\n write:\n\n {[\n type t = int Map.M(X).t [@@deriving hash]\n ]}\n\n then this will be well typed exactly if [X] contains at least:\n - a type [t] with no parameters\n - a comparator witness\n - a [hash_fold_t] function with the right type *)\n module M (K : sig\n type t\n type comparator_witness\n end) : sig\n type nonrec 'v t = (K.t, 'v, K.comparator_witness) t\n end\n\n include For_deriving with type ('key, 'value, 'cmp) t := ('key, 'value, 'cmp) t\n\n (** A polymorphic Map. *)\n module Poly :\n S_poly\n with type ('key, +'value) t = ('key, 'value, Comparator.Poly.comparator_witness) t\n\n (** [Using_comparator] is a similar interface as the toplevel of [Map], except the\n functions take a [~comparator:('k, 'cmp) Comparator.t], whereas the functions at the\n toplevel of [Map] take a [('k, 'cmp) comparator]. *)\n module Using_comparator : sig\n type nonrec ('k, +'v, 'cmp) t = ('k, 'v, 'cmp) t [@@deriving_inline sexp_of]\n\n val sexp_of_t\n : ('k -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('v -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('cmp -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('k, 'v, 'cmp) t\n -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val t_of_sexp_direct\n : comparator:('k, 'cmp) Comparator.t\n -> (Sexp.t -> 'k)\n -> (Sexp.t -> 'v)\n -> Sexp.t\n -> ('k, 'v, 'cmp) t\n\n module Tree : sig\n type ('k, +'v, 'cmp) t [@@deriving_inline sexp_of]\n\n val sexp_of_t\n : ('k -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('v -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('cmp -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('k, 'v, 'cmp) t\n -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val t_of_sexp_direct\n : comparator:('k, 'cmp) Comparator.t\n -> (Sexp.t -> 'k)\n -> (Sexp.t -> 'v)\n -> Sexp.t\n -> ('k, 'v, 'cmp) t\n\n include\n Creators_and_accessors3_with_comparator\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) t\n\n val empty_without_value_restriction : (_, _, _) t\n end\n\n include\n Accessors3\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n\n include\n Creators3_with_comparator\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n\n val comparator : ('a, _, 'cmp) t -> ('a, 'cmp) Comparator.t\n\n val hash_fold_direct\n : 'k Hash.folder\n -> 'v Hash.folder\n -> ('k, 'v, 'cmp) t Hash.folder\n\n (** To get around the value restriction, apply the functor and include it. You\n can see an example of this in the [Poly] submodule below. *)\n module Empty_without_value_restriction (K : Comparator.S1) : sig\n val empty : ('a K.t, 'v, K.comparator_witness) t\n end\n end\n\n\n (** {2 Modules and module types for extending [Map]}\n\n For use in extensions of Base, like [Core_kernel]. *)\n\n module With_comparator = With_comparator\n module With_first_class_module = With_first_class_module\n module Without_comparator = Without_comparator\n\n module type For_deriving = For_deriving\n module type S_poly = S_poly\n module type Accessors1 = Accessors1\n module type Accessors2 = Accessors2\n module type Accessors3 = Accessors3\n module type Accessors3_with_comparator = Accessors3_with_comparator\n module type Accessors_generic = Accessors_generic\n module type Creators1 = Creators1\n module type Creators2 = Creators2\n module type Creators3_with_comparator = Creators3_with_comparator\n module type Creators_and_accessors1 = Creators_and_accessors1\n module type Creators_and_accessors2 = Creators_and_accessors2\n\n module type Creators_and_accessors3_with_comparator =\n Creators_and_accessors3_with_comparator\n\n module type Creators_and_accessors_generic = Creators_and_accessors_generic\n module type Creators_generic = Creators_generic\nend\n","open! Import\nopen! Caml.Int64\n\nmodule T = struct\n type t = int64 [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int64\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int64 in\n fun x -> func x\n ;;\n\n let t_of_sexp = (int64_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_int64 : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"int64\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ int64_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"int64.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare = Int64_replace_polymorphic_compare.compare\n let to_string = to_string\n let of_string = of_string\nend\n\ninclude T\ninclude Comparator.Make (T)\n\nlet num_bits = 64\nlet float_lower_bound = Float0.lower_bound_for_int num_bits\nlet float_upper_bound = Float0.upper_bound_for_int num_bits\nlet float_of_bits = float_of_bits\nlet bits_of_float = bits_of_float\nlet shift_right_logical = shift_right_logical\nlet shift_right = shift_right\nlet shift_left = shift_left\nlet bit_not = lognot\nlet bit_xor = logxor\nlet bit_or = logor\nlet bit_and = logand\nlet min_value = min_int\nlet max_value = max_int\nlet abs = abs\nlet pred = pred\nlet succ = succ\nlet pow = Int_math.Private.int64_pow\nlet rem = rem\nlet neg = neg\nlet minus_one = minus_one\nlet one = one\nlet zero = zero\nlet to_float = to_float\nlet of_float_unchecked = Caml.Int64.of_float\n\nlet of_float f =\n if Float_replace_polymorphic_compare.( >= ) f float_lower_bound\n && Float_replace_polymorphic_compare.( <= ) f float_upper_bound\n then Caml.Int64.of_float f\n else\n Printf.invalid_argf\n \"Int64.of_float: argument (%f) is out of range or NaN\"\n (Float0.box f)\n ()\n;;\n\nlet ( ** ) b e = pow b e\n\nexternal bswap64 : t -> t = \"%bswap_int64\"\n\nlet[@inline always] bswap16 x = Caml.Int64.shift_right_logical (bswap64 x) 48\n\nlet[@inline always] bswap32 x =\n (* This is strictly better than coercing to an int32 to perform byteswap. Coercing\n from an int32 will add unnecessary shift operations to sign extend the number\n appropriately.\n *)\n Caml.Int64.shift_right_logical (bswap64 x) 32\n;;\n\nlet[@inline always] bswap48 x = Caml.Int64.shift_right_logical (bswap64 x) 16\n\ninclude Comparable.Validate_with_zero (struct\n include T\n\n let zero = zero\n end)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen Int64_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet ( / ) = div\nlet ( * ) = mul\nlet ( - ) = sub\nlet ( + ) = add\nlet ( ~- ) = neg\nlet incr r = r := !r + one\nlet decr r = r := !r - one\nlet of_int64 t = t\nlet of_int64_exn = of_int64\nlet to_int64 t = t\nlet popcount = Popcount.int64_popcount\n\nmodule Conv = Int_conversions\n\nlet of_int = Conv.int_to_int64\nlet of_int_exn = of_int\nlet to_int = Conv.int64_to_int\nlet to_int_exn = Conv.int64_to_int_exn\nlet to_int_trunc = Conv.int64_to_int_trunc\nlet of_int32 = Conv.int32_to_int64\nlet of_int32_exn = of_int32\nlet to_int32 = Conv.int64_to_int32\nlet to_int32_exn = Conv.int64_to_int32_exn\nlet to_int32_trunc = Conv.int64_to_int32_trunc\nlet of_nativeint = Conv.nativeint_to_int64\nlet of_nativeint_exn = of_nativeint\nlet to_nativeint = Conv.int64_to_nativeint\nlet to_nativeint_exn = Conv.int64_to_nativeint_exn\nlet to_nativeint_trunc = Conv.int64_to_nativeint_trunc\n\nmodule Pow2 = struct\n open! Import\n open Int64_replace_polymorphic_compare\n module Sys = Sys0\n\n let raise_s = Error.raise_s\n\n let non_positive_argument () =\n Printf.invalid_argf \"argument must be strictly positive\" ()\n ;;\n\n let ( lor ) = Caml.Int64.logor\n let ( lsr ) = Caml.Int64.shift_right_logical\n let ( land ) = Caml.Int64.logand\n\n (** \"ceiling power of 2\" - Least power of 2 greater than or equal to x. *)\n let ceil_pow2 x =\n if x <= Caml.Int64.zero then non_positive_argument ();\n let x = Caml.Int64.pred x in\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n let x = x lor (x lsr 32) in\n Caml.Int64.succ x\n ;;\n\n (** \"floor power of 2\" - Largest power of 2 less than or equal to x. *)\n let floor_pow2 x =\n if x <= Caml.Int64.zero then non_positive_argument ();\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n let x = x lor (x lsr 32) in\n Caml.Int64.sub x (x lsr 1)\n ;;\n\n let is_pow2 x =\n if x <= Caml.Int64.zero then non_positive_argument ();\n x land Caml.Int64.pred x = Caml.Int64.zero\n ;;\n\n (* C stubs for int clz and ctz to use the CLZ/BSR/CTZ/BSF instruction where possible *)\n external clz\n : (int64[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_int64_clz\" \"Base_int_math_int64_clz_unboxed\"\n [@@noalloc]\n\n external ctz\n : (int64[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_int64_ctz\" \"Base_int_math_int64_ctz_unboxed\"\n [@@noalloc]\n\n (** Hacker's Delight Second Edition p106 *)\n let floor_log2 i =\n if i <= Caml.Int64.zero\n then\n raise_s\n (Sexp.message \"[Int64.floor_log2] got invalid input\" [ \"\", sexp_of_int64 i ]);\n num_bits - 1 - clz i\n ;;\n\n (** Hacker's Delight Second Edition p106 *)\n let ceil_log2 i =\n if Poly.( <= ) i Caml.Int64.zero\n then\n raise_s\n (Sexp.message \"[Int64.ceil_log2] got invalid input\" [ \"\", sexp_of_int64 i ]);\n if Caml.Int64.equal i Caml.Int64.one then 0 else num_bits - clz (Caml.Int64.pred i)\n ;;\nend\n\ninclude Pow2\ninclude Conv.Make (T)\n\ninclude Conv.Make_hex (struct\n type t = int64 [@@deriving_inline compare, hash]\n\n let compare = (compare_int64 : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int64\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int64 in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let zero = zero\n let neg = ( ~- )\n let ( < ) = ( < )\n let to_string i = Printf.sprintf \"%Lx\" i\n let of_string s = Caml.Scanf.sscanf s \"%Lx\" Fn.id\n let module_name = \"Base.Int64.Hex\"\n end)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Base.Int64\"\n end)\n\nmodule Pre_O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Int64_replace_polymorphic_compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int_exn = of_int_exn\nend\n\nmodule O = struct\n include Pre_O\n\n include Int_math.Make (struct\n type nonrec t = t\n\n include Pre_O\n\n let rem = rem\n let to_float = to_float\n let of_float = of_float\n let of_string = T.of_string\n let to_string = T.to_string\n end)\n\n let ( land ) = bit_and\n let ( lor ) = bit_or\n let ( lxor ) = bit_xor\n let lnot = bit_not\n let ( lsl ) = shift_left\n let ( asr ) = shift_right\n let ( lsr ) = shift_right_logical\nend\n\ninclude O\n\n(* [Int64] and [Int64.O] agree value-wise *)\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Int64_replace_polymorphic_compare\n","open! Import\n\nlet invalid_argf = Printf.invalid_argf\n\nmodule T = struct\n type t = bool [@@deriving_inline compare, enumerate, hash, sexp, sexp_grammar]\n\n let compare = (compare_bool : t -> t -> int)\n let all = ([ false; true ] : t list)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_bool\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_bool in\n fun x -> func x\n ;;\n\n let t_of_sexp = (bool_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_bool : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"bool\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ bool_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"bool.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let of_string = function\n | \"true\" -> true\n | \"false\" -> false\n | s -> invalid_argf \"Bool.of_string: expected true or false but got %s\" s ()\n ;;\n\n let to_string = Caml.string_of_bool\nend\n\ninclude T\ninclude Comparator.Make (T)\ninclude Comparable.Validate (T)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Base.Bool\"\n end)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! Bool_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet to_int x = bool_to_int x\n\nmodule Non_short_circuiting = struct\n (* We don't expose this, since we don't want to break the invariant mentioned below of\n (to_int true = 1) and (to_int false = 0). *)\n let unsafe_of_int (x : int) : bool = Caml.Obj.magic x\n let ( || ) a b = unsafe_of_int (to_int a lor to_int b)\n let ( && ) a b = unsafe_of_int (to_int a land to_int b)\nend\n\n(* We do this as a direct assert on the theory that it's a cheap thing to test and a\n really core invariant that we never expect to break, and we should be happy for a\n program to fail immediately if this is violated. *)\nlet () = assert (Poly.( = ) (to_int true) 1 && Poly.( = ) (to_int false) 0)\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Bool_replace_polymorphic_compare\n","open! Import\nopen! Caml.Int32\n\nmodule T = struct\n type t = int32 [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int32\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int32 in\n fun x -> func x\n ;;\n\n let t_of_sexp = (int32_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_int32 : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"int32\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ int32_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"int32.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare (x : t) y = compare x y\n let to_string = to_string\n let of_string = of_string\nend\n\ninclude T\ninclude Comparator.Make (T)\n\nlet num_bits = 32\nlet float_lower_bound = Float0.lower_bound_for_int num_bits\nlet float_upper_bound = Float0.upper_bound_for_int num_bits\nlet float_of_bits = float_of_bits\nlet bits_of_float = bits_of_float\nlet shift_right_logical = shift_right_logical\nlet shift_right = shift_right\nlet shift_left = shift_left\nlet bit_not = lognot\nlet bit_xor = logxor\nlet bit_or = logor\nlet bit_and = logand\nlet min_value = min_int\nlet max_value = max_int\nlet abs = abs\nlet pred = pred\nlet succ = succ\nlet rem = rem\nlet neg = neg\nlet minus_one = minus_one\nlet one = one\nlet zero = zero\nlet compare = compare\nlet to_float = to_float\nlet of_float_unchecked = of_float\n\nlet of_float f =\n if Float_replace_polymorphic_compare.( >= ) f float_lower_bound\n && Float_replace_polymorphic_compare.( <= ) f float_upper_bound\n then of_float f\n else\n Printf.invalid_argf\n \"Int32.of_float: argument (%f) is out of range or NaN\"\n (Float0.box f)\n ()\n;;\n\ninclude Comparable.Validate_with_zero (struct\n include T\n\n let zero = zero\n end)\n\nmodule Infix_compare = struct\n open Poly\n\n let ( >= ) (x : t) y = x >= y\n let ( <= ) (x : t) y = x <= y\n let ( = ) (x : t) y = x = y\n let ( > ) (x : t) y = x > y\n let ( < ) (x : t) y = x < y\n let ( <> ) (x : t) y = x <> y\nend\n\nmodule Compare = struct\n include Infix_compare\n\n let compare = compare\n let ascending = compare\n let descending x y = compare y x\n let min (x : t) y = if x < y then x else y\n let max (x : t) y = if x > y then x else y\n let equal (x : t) y = x = y\n let between t ~low ~high = low <= t && t <= high\n let clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\n let clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n ;;\n\n let clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n ;;\nend\n\ninclude Compare\n\nlet invariant (_ : t) = ()\nlet ( / ) = div\nlet ( * ) = mul\nlet ( - ) = sub\nlet ( + ) = add\nlet ( ~- ) = neg\nlet incr r = r := !r + one\nlet decr r = r := !r - one\nlet of_int32 t = t\nlet of_int32_exn = of_int32\nlet to_int32 t = t\nlet to_int32_exn = to_int32\nlet popcount = Popcount.int32_popcount\n\nmodule Conv = Int_conversions\n\nlet of_int = Conv.int_to_int32\nlet of_int_exn = Conv.int_to_int32_exn\nlet of_int_trunc = Conv.int_to_int32_trunc\nlet to_int = Conv.int32_to_int\nlet to_int_exn = Conv.int32_to_int_exn\nlet to_int_trunc = Conv.int32_to_int_trunc\nlet of_int64 = Conv.int64_to_int32\nlet of_int64_exn = Conv.int64_to_int32_exn\nlet of_int64_trunc = Conv.int64_to_int32_trunc\nlet to_int64 = Conv.int32_to_int64\nlet of_nativeint = Conv.nativeint_to_int32\nlet of_nativeint_exn = Conv.nativeint_to_int32_exn\nlet of_nativeint_trunc = Conv.nativeint_to_int32_trunc\nlet to_nativeint = Conv.int32_to_nativeint\nlet to_nativeint_exn = to_nativeint\nlet pow b e = of_int_exn (Int_math.Private.int_pow (to_int_exn b) (to_int_exn e))\nlet ( ** ) b e = pow b e\n\nexternal bswap32 : t -> t = \"%bswap_int32\"\n\nlet bswap16 x = Caml.Int32.shift_right_logical (bswap32 x) 16\n\nmodule Pow2 = struct\n open! Import\n open Int32_replace_polymorphic_compare\n module Sys = Sys0\n\n let raise_s = Error.raise_s\n\n let non_positive_argument () =\n Printf.invalid_argf \"argument must be strictly positive\" ()\n ;;\n\n let ( lor ) = Caml.Int32.logor\n let ( lsr ) = Caml.Int32.shift_right_logical\n let ( land ) = Caml.Int32.logand\n\n (** \"ceiling power of 2\" - Least power of 2 greater than or equal to x. *)\n let ceil_pow2 x =\n if x <= Caml.Int32.zero then non_positive_argument ();\n let x = Caml.Int32.pred x in\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n Caml.Int32.succ x\n ;;\n\n (** \"floor power of 2\" - Largest power of 2 less than or equal to x. *)\n let floor_pow2 x =\n if x <= Caml.Int32.zero then non_positive_argument ();\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n Caml.Int32.sub x (x lsr 1)\n ;;\n\n let is_pow2 x =\n if x <= Caml.Int32.zero then non_positive_argument ();\n x land Caml.Int32.pred x = Caml.Int32.zero\n ;;\n\n (* C stubs for int32 clz and ctz to use the CLZ/BSR/CTZ/BSF instruction where possible *)\n external clz\n : (int32[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_int32_clz\" \"Base_int_math_int32_clz_unboxed\"\n [@@noalloc]\n\n external ctz\n : (int32[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_int32_ctz\" \"Base_int_math_int32_ctz_unboxed\"\n [@@noalloc]\n\n (** Hacker's Delight Second Edition p106 *)\n let floor_log2 i =\n if i <= Caml.Int32.zero\n then\n raise_s\n (Sexp.message \"[Int32.floor_log2] got invalid input\" [ \"\", sexp_of_int32 i ]);\n num_bits - 1 - clz i\n ;;\n\n (** Hacker's Delight Second Edition p106 *)\n let ceil_log2 i =\n if i <= Caml.Int32.zero\n then\n raise_s\n (Sexp.message \"[Int32.ceil_log2] got invalid input\" [ \"\", sexp_of_int32 i ]);\n (* The [i = 1] check is needed because clz(0) is undefined *)\n if Caml.Int32.equal i Caml.Int32.one then 0 else num_bits - clz (Caml.Int32.pred i)\n ;;\nend\n\ninclude Pow2\ninclude Conv.Make (T)\n\ninclude Conv.Make_hex (struct\n type t = int32 [@@deriving_inline compare, hash]\n\n let compare = (compare_int32 : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int32\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int32 in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let zero = zero\n let neg = ( ~- )\n let ( < ) = ( < )\n let to_string i = Printf.sprintf \"%lx\" i\n let of_string s = Caml.Scanf.sscanf s \"%lx\" Fn.id\n let module_name = \"Base.Int32.Hex\"\n end)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Base.Int32\"\n end)\n\nmodule Pre_O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int_exn = of_int_exn\nend\n\nmodule O = struct\n include Pre_O\n\n include Int_math.Make (struct\n type nonrec t = t\n\n include Pre_O\n\n let rem = rem\n let to_float = to_float\n let of_float = of_float\n let of_string = T.of_string\n let to_string = T.to_string\n end)\n\n let ( land ) = bit_and\n let ( lor ) = bit_or\n let ( lxor ) = bit_xor\n let lnot = bit_not\n let ( lsl ) = shift_left\n let ( asr ) = shift_right\n let ( lsr ) = shift_right_logical\nend\n\ninclude O\n\n(* [Int32] and [Int32.O] agree value-wise *)\n","open! Import\n\nlet raise_s = Error.raise_s\n\nmodule Repr = Int63_emul.Repr\n\n(* In a world where the compiler would understand [@@immediate64] attributes on type\n declarations, this module is how one would produce a [type t] with this attribute. *)\nmodule Immediate64 : sig\n module type Non_immediate = sig\n type t\n end\n\n module type Immediate = sig\n type t [@@immediate]\n end\n\n module Make (Immediate : Immediate) (Non_immediate : Non_immediate) : sig\n type t [@@immediate64]\n\n type 'a repr =\n | Immediate : Immediate.t repr\n | Non_immediate : Non_immediate.t repr\n\n val repr : t repr\n end\nend = struct\n module type Non_immediate = sig\n type t\n end\n\n module type Immediate = sig\n type t [@@immediate]\n end\n\n module Make (Immediate : Immediate) (Non_immediate : Non_immediate) = struct\n type t [@@immediate64]\n\n type 'a repr =\n | Immediate : Immediate.t repr\n | Non_immediate : Non_immediate.t repr\n\n let repr =\n match Word_size.word_size with\n | W64 -> (Caml.Obj.magic Immediate : t repr)\n | W32 -> (Caml.Obj.magic Non_immediate : t repr)\n ;;\n end\nend\n\ninclude Immediate64.Make (Int) (Int63_emul)\n\nmodule Backend = struct\n module type S = sig\n type t\n\n include Int_intf.S with type t := t\n\n val of_int : int -> t\n val to_int : t -> int option\n val to_int_trunc : t -> int\n val of_int32 : int32 -> t\n val to_int32 : t -> Int32.t option\n val to_int32_trunc : t -> Int32.t\n val of_int64 : Int64.t -> t option\n val of_int64_trunc : Int64.t -> t\n val of_nativeint : nativeint -> t option\n val to_nativeint : t -> nativeint option\n val of_nativeint_trunc : nativeint -> t\n val to_nativeint_trunc : t -> nativeint\n val of_float_unchecked : float -> t\n val repr : (t, t) Int63_emul.Repr.t\n val bswap16 : t -> t\n val bswap32 : t -> t\n val bswap48 : t -> t\n end\n with type t := t\n\n module Native = struct\n include Int\n\n let to_int x = Some x\n let to_int_trunc x = x\n\n (* [of_int32_exn] is a safe operation on platforms with 64-bit word sizes. *)\n let of_int32 = of_int32_exn\n let to_nativeint_trunc x = to_nativeint x\n let to_nativeint x = Some (to_nativeint x)\n let repr = Int63_emul.Repr.Int\n let bswap32 t = Int64.to_int_trunc (Int64.bswap32 (Int64.of_int t))\n let bswap48 t = Int64.to_int_trunc (Int64.bswap48 (Int64.of_int t))\n end\n\n let impl : (module S) =\n match repr with\n | Immediate -> (module Native : S)\n | Non_immediate -> (module Int63_emul : S)\n ;;\nend\n\ninclude (val Backend.impl : Backend.S)\n\nmodule Overflow_exn = struct\n let ( + ) t u =\n let sum = t + u in\n if bit_or (bit_xor t u) (bit_xor t (bit_not sum)) < zero\n then sum\n else\n raise_s\n (Sexp.message\n \"( + ) overflow\"\n [ \"t\", sexp_of_t t; \"u\", sexp_of_t u; \"sum\", sexp_of_t sum ])\n ;;\n\n let ( - ) t u =\n let diff = t - u in\n let pos_diff = t > u in\n if t <> u && Bool.( <> ) pos_diff (is_positive diff)\n then\n raise_s\n (Sexp.message\n \"( - ) overflow\"\n [ \"t\", sexp_of_t t; \"u\", sexp_of_t u; \"diff\", sexp_of_t diff ])\n else diff\n ;;\n\n let abs t = if t = min_value then failwith \"abs overflow\" else abs t\n let neg t = if t = min_value then failwith \"neg overflow\" else neg t\nend\n\nlet () = assert (Int.( = ) num_bits 63)\n\nlet random_of_int ?(state = Random.State.default) bound =\n of_int (Random.State.int state (to_int_exn bound))\n;;\n\nlet random_of_int64 ?(state = Random.State.default) bound =\n of_int64_exn (Random.State.int64 state (to_int64 bound))\n;;\n\nlet random =\n match Word_size.word_size with\n | W64 -> random_of_int\n | W32 -> random_of_int64\n;;\n\nlet random_incl_of_int ?(state = Random.State.default) lo hi =\n of_int (Random.State.int_incl state (to_int_exn lo) (to_int_exn hi))\n;;\n\nlet random_incl_of_int64 ?(state = Random.State.default) lo hi =\n of_int64_exn (Random.State.int64_incl state (to_int64 lo) (to_int64 hi))\n;;\n\nlet random_incl =\n match Word_size.word_size with\n | W64 -> random_incl_of_int\n | W32 -> random_incl_of_int64\n;;\n\nlet floor_log2 t =\n match Word_size.word_size with\n | W64 -> t |> to_int_exn |> Int.floor_log2\n | W32 ->\n if t <= zero\n then raise_s (Sexp.message \"[Int.floor_log2] got invalid input\" [ \"\", sexp_of_t t ]);\n let floor_log2 = ref (Int.( - ) num_bits 2) in\n while equal zero (bit_and t (shift_left one !floor_log2)) do\n floor_log2 := Int.( - ) !floor_log2 1\n done;\n !floor_log2\n;;\n\nmodule Private = struct\n module Repr = Repr\n\n let repr = repr\n\n module Emul = Int63_emul\nend\n","open! Import\ninclude Hashtbl_intf\n\nmodule type Key = Key.S\n\nlet with_return = With_return.with_return\nlet hash_param = Hashable.hash_param\nlet hash = Hashable.hash\nlet raise_s = Error.raise_s\n\ntype ('k, 'v) t =\n { mutable table : ('k, 'v) Avltree.t array\n ; mutable length : int\n (* [recently_added] is the reference passed to [Avltree.add]. We put it in the hash\n table to avoid allocating it at every [set]. *)\n ; recently_added : bool ref\n ; growth_allowed : bool\n ; hashable : 'k Hashable.t\n ; mutable mutation_allowed : bool (* Set during all iteration operations *)\n }\n\ntype 'a key = 'a\n\nlet sexp_of_key t = t.hashable.Hashable.sexp_of_t\nlet compare_key t = t.hashable.Hashable.compare\n\nlet ensure_mutation_allowed t =\n if not t.mutation_allowed\n then failwith \"Hashtbl: mutation not allowed during iteration\"\n;;\n\nlet without_mutating t f =\n if t.mutation_allowed\n then (\n t.mutation_allowed <- false;\n match f () with\n | x ->\n t.mutation_allowed <- true;\n x\n | exception exn ->\n t.mutation_allowed <- true;\n raise exn)\n else f ()\n;;\n\n(** Internally use a maximum size that is a power of 2. Reverses the above to find the\n floor power of 2 below the system max array length *)\nlet max_table_length = Int.floor_pow2 Array.max_length\n\n(* The default size is chosen to be 0 (as opposed to 128 as it was before) because:\n - 128 can create substantial memory overhead (x10) when creating many tables, most\n of which are not big (say, if you have a hashtbl of hashtbl). And memory overhead is\n not that easy to profile.\n - if a hashtbl is going to grow, it's not clear why 128 is markedly better than other\n sizes (if you going to stick 1000 elements, you're going to grow the hashtable once\n or twice anyway)\n - in other languages (like rust, python, and apparently go), the default is also a\n small size. *)\nlet create ?(growth_allowed = true) ?(size = 0) ~hashable () =\n let size = Int.min (Int.max 1 size) max_table_length in\n let size = Int.ceil_pow2 size in\n { table = Array.create ~len:size Avltree.empty\n ; length = 0\n ; growth_allowed\n ; recently_added = ref false\n ; hashable\n ; mutation_allowed = true\n }\n;;\n\n(** Supplemental hash. This may not be necessary, it is intended as a defense against poor\n hash functions, for which the power of 2 sized table will be especially sensitive.\n With some testing we may choose to add it, but this table is designed to be robust to\n collisions, and in most of my testing this degrades performance. *)\nlet _supplemental_hash h =\n let h = h lxor ((h lsr 20) lxor (h lsr 12)) in\n h lxor (h lsr 7) lxor (h lsr 4)\n;;\n\nlet slot t key =\n let hash = t.hashable.Hashable.hash key in\n (* this is always non-negative because we do [land] with non-negative number *)\n hash land (Array.length t.table - 1)\n;;\n\nlet add_worker t ~replace ~key ~data =\n let i = slot t key in\n let root = t.table.(i) in\n let added = t.recently_added in\n added := false;\n let new_root =\n (* The avl tree might replace the value [replace=true] or do nothing [replace=false]\n to the entry, in that case the table did not get bigger, so we should not\n increment length, we pass in the bool ref t.added so that it can tell us whether\n it added or replaced. We do it this way to avoid extra allocation. Since the bool\n is an immediate it does not go through the write barrier. *)\n Avltree.add ~replace root ~compare:(compare_key t) ~added ~key ~data\n in\n if !added then t.length <- t.length + 1;\n (* This little optimization saves a caml_modify when the tree\n hasn't been rebalanced. *)\n if not (phys_equal new_root root) then t.table.(i) <- new_root\n;;\n\nlet maybe_resize_table t =\n let len = Array.length t.table in\n let should_grow = t.length > len in\n if should_grow && t.growth_allowed\n then (\n let new_array_length = Int.min (len * 2) max_table_length in\n if new_array_length > len\n then (\n let new_table = Array.create ~len:new_array_length Avltree.empty in\n let old_table = t.table in\n t.table <- new_table;\n t.length <- 0;\n let f ~key ~data = add_worker ~replace:true t ~key ~data in\n for i = 0 to Array.length old_table - 1 do\n Avltree.iter old_table.(i) ~f\n done))\n;;\n\nlet set t ~key ~data =\n ensure_mutation_allowed t;\n add_worker ~replace:true t ~key ~data;\n maybe_resize_table t\n;;\n\nlet add t ~key ~data =\n ensure_mutation_allowed t;\n add_worker ~replace:false t ~key ~data;\n if !(t.recently_added)\n then (\n maybe_resize_table t;\n `Ok)\n else `Duplicate\n;;\n\nlet add_exn t ~key ~data =\n match add t ~key ~data with\n | `Ok -> ()\n | `Duplicate ->\n let sexp_of_key = sexp_of_key t in\n let error = Error.create \"Hashtbl.add_exn got key already present\" key sexp_of_key in\n Error.raise error\n;;\n\nlet clear t =\n ensure_mutation_allowed t;\n for i = 0 to Array.length t.table - 1 do\n t.table.(i) <- Avltree.empty\n done;\n t.length <- 0\n;;\n\nlet find_and_call t key ~if_found ~if_not_found =\n (* with a good hash function these first two cases will be the overwhelming majority,\n and Avltree.find is recursive, so it can't be inlined, so doing this avoids a\n function call in most cases. *)\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found v else if_not_found key\n | tree ->\n Avltree.find_and_call tree ~compare:(compare_key t) key ~if_found ~if_not_found\n;;\n\nlet find_and_call1 t key ~a ~if_found ~if_not_found =\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key a\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found v a else if_not_found key a\n | tree ->\n Avltree.find_and_call1 tree ~compare:(compare_key t) key ~a ~if_found ~if_not_found\n;;\n\nlet find_and_call2 t key ~a ~b ~if_found ~if_not_found =\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key a b\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found v a b else if_not_found key a b\n | tree ->\n Avltree.find_and_call2\n tree\n ~compare:(compare_key t)\n key\n ~a\n ~b\n ~if_found\n ~if_not_found\n;;\n\nlet findi_and_call t key ~if_found ~if_not_found =\n (* with a good hash function these first two cases will be the overwhelming majority,\n and Avltree.find is recursive, so it can't be inlined, so doing this avoids a\n function call in most cases. *)\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found ~key:k ~data:v else if_not_found key\n | tree ->\n Avltree.findi_and_call tree ~compare:(compare_key t) key ~if_found ~if_not_found\n;;\n\nlet findi_and_call1 t key ~a ~if_found ~if_not_found =\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key a\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found ~key:k ~data:v a else if_not_found key a\n | tree ->\n Avltree.findi_and_call1 tree ~compare:(compare_key t) key ~a ~if_found ~if_not_found\n;;\n\nlet findi_and_call2 t key ~a ~b ~if_found ~if_not_found =\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key a b\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found ~key:k ~data:v a b else if_not_found key a b\n | tree ->\n Avltree.findi_and_call2\n tree\n ~compare:(compare_key t)\n key\n ~a\n ~b\n ~if_found\n ~if_not_found\n;;\n\nlet find =\n let if_found v = Some v in\n let if_not_found _ = None in\n fun t key -> find_and_call t key ~if_found ~if_not_found\n;;\n\nlet mem t key =\n match t.table.(slot t key) with\n | Avltree.Empty -> false\n | Avltree.Leaf { key = k; value = _ } -> compare_key t k key = 0\n | tree -> Avltree.mem tree ~compare:(compare_key t) key\n;;\n\nlet remove t key =\n ensure_mutation_allowed t;\n let i = slot t key in\n let root = t.table.(i) in\n let added_or_removed = t.recently_added in\n added_or_removed := false;\n let new_root =\n Avltree.remove root ~removed:added_or_removed ~compare:(compare_key t) key\n in\n if not (phys_equal root new_root) then t.table.(i) <- new_root;\n if !added_or_removed then t.length <- t.length - 1\n;;\n\nlet length t = t.length\nlet is_empty t = length t = 0\n\nlet fold t ~init ~f =\n if length t = 0\n then init\n else (\n let n = Array.length t.table in\n let acc = ref init in\n let m = t.mutation_allowed in\n match\n t.mutation_allowed <- false;\n for i = 0 to n - 1 do\n match Array.unsafe_get t.table i with\n | Avltree.Empty -> ()\n | Avltree.Leaf { key; value = data } -> acc := f ~key ~data !acc\n | bucket -> acc := Avltree.fold bucket ~init:!acc ~f\n done\n with\n | () ->\n t.mutation_allowed <- m;\n !acc\n | exception exn ->\n t.mutation_allowed <- m;\n raise exn)\n;;\n\nlet iteri t ~f =\n if t.length = 0\n then ()\n else (\n let n = Array.length t.table in\n let m = t.mutation_allowed in\n match\n t.mutation_allowed <- false;\n for i = 0 to n - 1 do\n match Array.unsafe_get t.table i with\n | Avltree.Empty -> ()\n | Avltree.Leaf { key; value = data } -> f ~key ~data\n | bucket -> Avltree.iter bucket ~f\n done\n with\n | () -> t.mutation_allowed <- m\n | exception exn ->\n t.mutation_allowed <- m;\n raise exn)\n;;\n\nlet iter t ~f = iteri t ~f:(fun ~key:_ ~data -> f data)\nlet iter_keys t ~f = iteri t ~f:(fun ~key ~data:_ -> f key)\n\nlet rec choose_nonempty table i =\n let avltree = table.(i) in\n if Avltree.is_empty avltree\n then choose_nonempty table (i + 1)\n else Avltree.choose_exn avltree\n;;\n\nlet choose_exn t =\n if t.length = 0 then raise_s (Sexp.message \"[Hashtbl.choose_exn] of empty hashtbl\" []);\n choose_nonempty t.table 0\n;;\n\nlet choose t = if is_empty t then None else Some (choose_nonempty t.table 0)\n\nlet invariant invariant_key invariant_data t =\n for i = 0 to Array.length t.table - 1 do\n Avltree.invariant t.table.(i) ~compare:(compare_key t)\n done;\n let real_len =\n fold t ~init:0 ~f:(fun ~key ~data i ->\n invariant_key key;\n invariant_data data;\n i + 1)\n in\n assert (real_len = t.length)\n;;\n\nlet find_exn =\n let if_found v _ = v in\n let if_not_found k t =\n raise\n (Not_found_s (List [ Atom \"Hashtbl.find_exn: not found\"; t.hashable.sexp_of_t k ]))\n in\n let find_exn t key = find_and_call1 t key ~a:t ~if_found ~if_not_found in\n (* named to preserve symbol in compiled binary *)\n find_exn\n;;\n\nlet existsi t ~f =\n with_return (fun r ->\n iteri t ~f:(fun ~key ~data -> if f ~key ~data then r.return true);\n false)\n;;\n\nlet exists t ~f = existsi t ~f:(fun ~key:_ ~data -> f data)\nlet for_alli t ~f = not (existsi t ~f:(fun ~key ~data -> not (f ~key ~data)))\nlet for_all t ~f = not (existsi t ~f:(fun ~key:_ ~data -> not (f data)))\n\nlet counti t ~f =\n fold t ~init:0 ~f:(fun ~key ~data acc -> if f ~key ~data then acc + 1 else acc)\n;;\n\nlet count t ~f =\n fold t ~init:0 ~f:(fun ~key:_ ~data acc -> if f data then acc + 1 else acc)\n;;\n\nlet mapi t ~f =\n let new_t =\n create ~growth_allowed:t.growth_allowed ~hashable:t.hashable ~size:t.length ()\n in\n iteri t ~f:(fun ~key ~data -> set new_t ~key ~data:(f ~key ~data));\n new_t\n;;\n\nlet map t ~f = mapi t ~f:(fun ~key:_ ~data -> f data)\nlet copy t = map t ~f:Fn.id\n\nlet filter_mapi t ~f =\n let new_t =\n create ~growth_allowed:t.growth_allowed ~hashable:t.hashable ~size:t.length ()\n in\n iteri t ~f:(fun ~key ~data ->\n match f ~key ~data with\n | Some new_data -> set new_t ~key ~data:new_data\n | None -> ());\n new_t\n;;\n\nlet filter_map t ~f = filter_mapi t ~f:(fun ~key:_ ~data -> f data)\n\nlet filteri t ~f =\n filter_mapi t ~f:(fun ~key ~data -> if f ~key ~data then Some data else None)\n;;\n\nlet filter t ~f = filteri t ~f:(fun ~key:_ ~data -> f data)\nlet filter_keys t ~f = filteri t ~f:(fun ~key ~data:_ -> f key)\n\nlet partition_mapi t ~f =\n let t0 =\n create ~growth_allowed:t.growth_allowed ~hashable:t.hashable ~size:t.length ()\n in\n let t1 =\n create ~growth_allowed:t.growth_allowed ~hashable:t.hashable ~size:t.length ()\n in\n iteri t ~f:(fun ~key ~data ->\n match (f ~key ~data : _ Either.t) with\n | First new_data -> set t0 ~key ~data:new_data\n | Second new_data -> set t1 ~key ~data:new_data);\n t0, t1\n;;\n\nlet partition_map t ~f = partition_mapi t ~f:(fun ~key:_ ~data -> f data)\n\nlet partitioni_tf t ~f =\n partition_mapi t ~f:(fun ~key ~data ->\n if f ~key ~data then First data else Second data)\n;;\n\nlet partition_tf t ~f = partitioni_tf t ~f:(fun ~key:_ ~data -> f data)\n\nlet find_or_add t id ~default =\n match find t id with\n | Some x -> x\n | None ->\n let default = default () in\n set t ~key:id ~data:default;\n default\n;;\n\nlet findi_or_add t id ~default =\n match find t id with\n | Some x -> x\n | None ->\n let default = default id in\n set t ~key:id ~data:default;\n default\n;;\n\n(* Some hashtbl implementations may be able to perform this more efficiently than two\n separate lookups *)\nlet find_and_remove t id =\n let result = find t id in\n if Option.is_some result then remove t id;\n result\n;;\n\n\nlet change t id ~f =\n match f (find t id) with\n | None -> remove t id\n | Some data -> set t ~key:id ~data\n;;\n\nlet update t id ~f = set t ~key:id ~data:(f (find t id))\n\nlet incr_by ~remove_if_zero t key by =\n if remove_if_zero\n then\n change t key ~f:(fun opt ->\n match by + Option.value opt ~default:0 with\n | 0 -> None\n | n -> Some n)\n else\n update t key ~f:(function\n | None -> by\n | Some i -> by + i)\n;;\n\nlet incr ?(by = 1) ?(remove_if_zero = false) t key = incr_by ~remove_if_zero t key by\nlet decr ?(by = 1) ?(remove_if_zero = false) t key = incr_by ~remove_if_zero t key (-by)\n\nlet add_multi t ~key ~data =\n update t key ~f:(function\n | None -> [ data ]\n | Some l -> data :: l)\n;;\n\nlet remove_multi t key =\n match find t key with\n | None -> ()\n | Some [] | Some [ _ ] -> remove t key\n | Some (_ :: tl) -> set t ~key ~data:tl\n;;\n\nlet find_multi t key =\n match find t key with\n | None -> []\n | Some l -> l\n;;\n\nlet create_mapped ?growth_allowed ?size ~hashable ~get_key ~get_data rows =\n let size =\n match size with\n | Some s -> s\n | None -> List.length rows\n in\n let res = create ?growth_allowed ~hashable ~size () in\n let dupes = ref [] in\n List.iter rows ~f:(fun r ->\n let key = get_key r in\n let data = get_data r in\n if mem res key then dupes := key :: !dupes else set res ~key ~data);\n match !dupes with\n | [] -> `Ok res\n | keys -> `Duplicate_keys (List.dedup_and_sort ~compare:hashable.Hashable.compare keys)\n;;\n\nlet create_mapped_multi ?growth_allowed ?size ~hashable ~get_key ~get_data rows =\n let size =\n match size with\n | Some s -> s\n | None -> List.length rows\n in\n let res = create ?growth_allowed ~size ~hashable () in\n List.iter rows ~f:(fun r ->\n let key = get_key r in\n let data = get_data r in\n add_multi res ~key ~data);\n res\n;;\n\nlet of_alist ?growth_allowed ?size ~hashable lst =\n match create_mapped ?growth_allowed ?size ~hashable ~get_key:fst ~get_data:snd lst with\n | `Ok t -> `Ok t\n | `Duplicate_keys k -> `Duplicate_key (List.hd_exn k)\n;;\n\nlet of_alist_report_all_dups ?growth_allowed ?size ~hashable lst =\n create_mapped ?growth_allowed ?size ~hashable ~get_key:fst ~get_data:snd lst\n;;\n\nlet of_alist_or_error ?growth_allowed ?size ~hashable lst =\n match of_alist ?growth_allowed ?size ~hashable lst with\n | `Ok v -> Result.Ok v\n | `Duplicate_key key ->\n let sexp_of_key = hashable.Hashable.sexp_of_t in\n Or_error.error \"Hashtbl.of_alist_exn: duplicate key\" key sexp_of_key\n;;\n\nlet of_alist_exn ?growth_allowed ?size ~hashable lst =\n match of_alist_or_error ?growth_allowed ?size ~hashable lst with\n | Result.Ok v -> v\n | Result.Error e -> Error.raise e\n;;\n\nlet of_alist_multi ?growth_allowed ?size ~hashable lst =\n create_mapped_multi ?growth_allowed ?size ~hashable ~get_key:fst ~get_data:snd lst\n;;\n\nlet to_alist t = fold ~f:(fun ~key ~data list -> (key, data) :: list) ~init:[] t\n\nlet sexp_of_t sexp_of_key sexp_of_data t =\n t\n |> to_alist\n |> List.sort ~compare:(fun (k1, _) (k2, _) -> t.hashable.compare k1 k2)\n |> sexp_of_list (sexp_of_pair sexp_of_key sexp_of_data)\n;;\n\nlet t_of_sexp ~hashable k_of_sexp d_of_sexp sexp =\n let alist = list_of_sexp (pair_of_sexp k_of_sexp d_of_sexp) sexp in\n match of_alist ~hashable alist ~size:(List.length alist) with\n | `Ok v -> v\n | `Duplicate_key k ->\n (* find the sexp of a duplicate key, so the error is narrowed to a key and not\n the whole map *)\n let alist_sexps = list_of_sexp (pair_of_sexp Fn.id Fn.id) sexp in\n let found_first_k = ref false in\n List.iter2_exn alist alist_sexps ~f:(fun (k2, _) (k2_sexp, _) ->\n if hashable.compare k k2 = 0\n then\n if !found_first_k\n then of_sexp_error \"Hashtbl.t_of_sexp: duplicate key\" k2_sexp\n else found_first_k := true);\n assert false\n;;\n\nlet validate ~name f t = Validate.alist ~name f (to_alist t)\nlet keys t = fold t ~init:[] ~f:(fun ~key ~data:_ acc -> key :: acc)\nlet data t = fold ~f:(fun ~key:_ ~data list -> data :: list) ~init:[] t\n\nlet add_to_groups groups ~get_key ~get_data ~combine ~rows =\n List.iter rows ~f:(fun row ->\n let key = get_key row in\n let data = get_data row in\n let data =\n match find groups key with\n | None -> data\n | Some old -> combine old data\n in\n set groups ~key ~data)\n;;\n\nlet group ?growth_allowed ?size ~hashable ~get_key ~get_data ~combine rows =\n let res = create ?growth_allowed ?size ~hashable () in\n add_to_groups res ~get_key ~get_data ~combine ~rows;\n res\n;;\n\nlet create_with_key ?growth_allowed ?size ~hashable ~get_key rows =\n create_mapped ?growth_allowed ?size ~hashable ~get_key ~get_data:Fn.id rows\n;;\n\nlet create_with_key_or_error ?growth_allowed ?size ~hashable ~get_key rows =\n match create_with_key ?growth_allowed ?size ~hashable ~get_key rows with\n | `Ok t -> Result.Ok t\n | `Duplicate_keys keys ->\n let sexp_of_key = hashable.Hashable.sexp_of_t in\n Or_error.error_s\n (Sexp.message\n \"Hashtbl.create_with_key: duplicate keys\"\n [ \"keys\", sexp_of_list sexp_of_key keys ])\n;;\n\nlet create_with_key_exn ?growth_allowed ?size ~hashable ~get_key rows =\n Or_error.ok_exn\n (create_with_key_or_error ?growth_allowed ?size ~hashable ~get_key rows)\n;;\n\nlet merge =\n let maybe_set t ~key ~f d =\n match f ~key d with\n | None -> ()\n | Some v -> set t ~key ~data:v\n in\n fun t_left t_right ~f ->\n if not (Hashable.equal t_left.hashable t_right.hashable)\n then invalid_arg \"Hashtbl.merge: different 'hashable' values\";\n let new_t =\n create\n ~growth_allowed:t_left.growth_allowed\n ~hashable:t_left.hashable\n ~size:t_left.length\n ()\n in\n without_mutating t_left (fun () ->\n without_mutating t_right (fun () ->\n iteri t_left ~f:(fun ~key ~data:left ->\n match find t_right key with\n | None -> maybe_set new_t ~key ~f (`Left left)\n | Some right -> maybe_set new_t ~key ~f (`Both (left, right)));\n iteri t_right ~f:(fun ~key ~data:right ->\n match find t_left key with\n | None -> maybe_set new_t ~key ~f (`Right right)\n | Some _ -> ()\n (* already done above *))));\n new_t\n;;\n\nlet merge_into ~src ~dst ~f =\n iteri src ~f:(fun ~key ~data ->\n let dst_data = find dst key in\n let action = without_mutating dst (fun () -> f ~key data dst_data) in\n match (action : _ Merge_into_action.t) with\n | Remove -> remove dst key\n | Set_to data ->\n (match dst_data with\n | None -> set dst ~key ~data\n | Some dst_data -> if not (phys_equal dst_data data) then set dst ~key ~data))\n;;\n\nlet filteri_inplace t ~f =\n let to_remove =\n fold t ~init:[] ~f:(fun ~key ~data ac -> if f ~key ~data then ac else key :: ac)\n in\n List.iter to_remove ~f:(fun key -> remove t key)\n;;\n\nlet filter_inplace t ~f = filteri_inplace t ~f:(fun ~key:_ ~data -> f data)\nlet filter_keys_inplace t ~f = filteri_inplace t ~f:(fun ~key ~data:_ -> f key)\n\nlet filter_mapi_inplace t ~f =\n let map_results =\n fold t ~init:[] ~f:(fun ~key ~data ac -> (key, f ~key ~data) :: ac)\n in\n List.iter map_results ~f:(fun (key, result) ->\n match result with\n | None -> remove t key\n | Some data -> set t ~key ~data)\n;;\n\nlet filter_map_inplace t ~f = filter_mapi_inplace t ~f:(fun ~key:_ ~data -> f data)\n\nlet mapi_inplace t ~f =\n ensure_mutation_allowed t;\n without_mutating t (fun () -> Array.iter t.table ~f:(Avltree.mapi_inplace ~f))\n;;\n\nlet map_inplace t ~f = mapi_inplace t ~f:(fun ~key:_ ~data -> f data)\n\nlet equal equal t t' =\n length t = length t'\n && with_return (fun r ->\n without_mutating t' (fun () ->\n iteri t ~f:(fun ~key ~data ->\n match find t' key with\n | None -> r.return false\n | Some data' -> if not (equal data data') then r.return false));\n true)\n;;\n\nlet similar = equal\n\nmodule Accessors = struct\n let invariant = invariant\n let choose = choose\n let choose_exn = choose_exn\n let clear = clear\n let copy = copy\n let remove = remove\n let set = set\n let add = add\n let add_exn = add_exn\n let change = change\n let update = update\n let add_multi = add_multi\n let remove_multi = remove_multi\n let find_multi = find_multi\n let mem = mem\n let iter_keys = iter_keys\n let iter = iter\n let iteri = iteri\n let exists = exists\n let existsi = existsi\n let for_all = for_all\n let for_alli = for_alli\n let count = count\n let counti = counti\n let fold = fold\n let length = length\n let is_empty = is_empty\n let map = map\n let mapi = mapi\n let filter_map = filter_map\n let filter_mapi = filter_mapi\n let filter_keys = filter_keys\n let filter = filter\n let filteri = filteri\n let partition_map = partition_map\n let partition_mapi = partition_mapi\n let partition_tf = partition_tf\n let partitioni_tf = partitioni_tf\n let find_or_add = find_or_add\n let findi_or_add = findi_or_add\n let find = find\n let find_exn = find_exn\n let find_and_call = find_and_call\n let find_and_call1 = find_and_call1\n let find_and_call2 = find_and_call2\n let findi_and_call = findi_and_call\n let findi_and_call1 = findi_and_call1\n let findi_and_call2 = findi_and_call2\n let find_and_remove = find_and_remove\n let to_alist = to_alist\n let validate = validate\n let merge = merge\n let merge_into = merge_into\n let keys = keys\n let data = data\n let filter_keys_inplace = filter_keys_inplace\n let filter_inplace = filter_inplace\n let filteri_inplace = filteri_inplace\n let map_inplace = map_inplace\n let mapi_inplace = mapi_inplace\n let filter_map_inplace = filter_map_inplace\n let filter_mapi_inplace = filter_mapi_inplace\n let equal = equal\n let similar = similar\n let incr = incr\n let decr = decr\n let sexp_of_key = sexp_of_key\nend\n\nmodule Creators (Key : sig\n type 'a t\n\n val hashable : 'a t Hashable.t\n end) : sig\n type ('a, 'b) t_ = ('a Key.t, 'b) t\n\n val t_of_sexp : (Sexp.t -> 'a Key.t) -> (Sexp.t -> 'b) -> Sexp.t -> ('a, 'b) t_\n\n include\n Creators_generic\n with type ('a, 'b) t := ('a, 'b) t_\n with type 'a key := 'a Key.t\n with type ('key, 'data, 'a) create_options :=\n ('key, 'data, 'a) create_options_without_first_class_module\nend = struct\n let hashable = Key.hashable\n\n type ('a, 'b) t_ = ('a Key.t, 'b) t\n\n let create ?growth_allowed ?size () = create ?growth_allowed ?size ~hashable ()\n let of_alist ?growth_allowed ?size l = of_alist ?growth_allowed ~hashable ?size l\n\n let of_alist_report_all_dups ?growth_allowed ?size l =\n of_alist_report_all_dups ?growth_allowed ~hashable ?size l\n ;;\n\n let of_alist_or_error ?growth_allowed ?size l =\n of_alist_or_error ?growth_allowed ~hashable ?size l\n ;;\n\n let of_alist_exn ?growth_allowed ?size l =\n of_alist_exn ?growth_allowed ~hashable ?size l\n ;;\n\n let t_of_sexp k_of_sexp d_of_sexp sexp = t_of_sexp ~hashable k_of_sexp d_of_sexp sexp\n\n let of_alist_multi ?growth_allowed ?size l =\n of_alist_multi ?growth_allowed ~hashable ?size l\n ;;\n\n let create_mapped ?growth_allowed ?size ~get_key ~get_data l =\n create_mapped ?growth_allowed ~hashable ?size ~get_key ~get_data l\n ;;\n\n let create_with_key ?growth_allowed ?size ~get_key l =\n create_with_key ?growth_allowed ~hashable ?size ~get_key l\n ;;\n\n let create_with_key_or_error ?growth_allowed ?size ~get_key l =\n create_with_key_or_error ?growth_allowed ~hashable ?size ~get_key l\n ;;\n\n let create_with_key_exn ?growth_allowed ?size ~get_key l =\n create_with_key_exn ?growth_allowed ~hashable ?size ~get_key l\n ;;\n\n let group ?growth_allowed ?size ~get_key ~get_data ~combine l =\n group ?growth_allowed ~hashable ?size ~get_key ~get_data ~combine l\n ;;\nend\n\nmodule Poly = struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n type 'a key = 'a\n\n let hashable = Hashable.poly\n\n include Creators (struct\n type 'a t = 'a\n\n let hashable = hashable\n end)\n\n include Accessors\n\n let sexp_of_t = sexp_of_t\nend\n\nmodule Private = struct\n module type Creators_generic = Creators_generic\n module type Hashable = Hashable.Hashable\n\n type nonrec ('key, 'data, 'z) create_options_without_first_class_module =\n ('key, 'data, 'z) create_options_without_first_class_module\n\n let hashable t = t.hashable\nend\n\nlet create ?growth_allowed ?size m =\n create ~hashable:(Hashable.of_key m) ?growth_allowed ?size ()\n;;\n\nlet of_alist ?growth_allowed ?size m l =\n of_alist ~hashable:(Hashable.of_key m) ?growth_allowed ?size l\n;;\n\nlet of_alist_report_all_dups ?growth_allowed ?size m l =\n of_alist_report_all_dups ~hashable:(Hashable.of_key m) ?growth_allowed ?size l\n;;\n\nlet of_alist_or_error ?growth_allowed ?size m l =\n of_alist_or_error ~hashable:(Hashable.of_key m) ?growth_allowed ?size l\n;;\n\nlet of_alist_exn ?growth_allowed ?size m l =\n of_alist_exn ~hashable:(Hashable.of_key m) ?growth_allowed ?size l\n;;\n\nlet of_alist_multi ?growth_allowed ?size m l =\n of_alist_multi ~hashable:(Hashable.of_key m) ?growth_allowed ?size l\n;;\n\nlet create_mapped ?growth_allowed ?size m ~get_key ~get_data l =\n create_mapped ~hashable:(Hashable.of_key m) ?growth_allowed ?size ~get_key ~get_data l\n;;\n\nlet create_with_key ?growth_allowed ?size m ~get_key l =\n create_with_key ~hashable:(Hashable.of_key m) ?growth_allowed ?size ~get_key l\n;;\n\nlet create_with_key_or_error ?growth_allowed ?size m ~get_key l =\n create_with_key_or_error ~hashable:(Hashable.of_key m) ?growth_allowed ?size ~get_key l\n;;\n\nlet create_with_key_exn ?growth_allowed ?size m ~get_key l =\n create_with_key_exn ~hashable:(Hashable.of_key m) ?growth_allowed ?size ~get_key l\n;;\n\nlet group ?growth_allowed ?size m ~get_key ~get_data ~combine l =\n group ~hashable:(Hashable.of_key m) ?growth_allowed ?size ~get_key ~get_data ~combine l\n;;\n\nlet hashable_s t = Hashable.to_key t.hashable\n\nmodule M (K : T.T) = struct\n type nonrec 'v t = (K.t, 'v) t\nend\n\nmodule type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\nend\n\nmodule type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Key.S with type t := t\nend\n\nlet sexp_of_m__t (type k) (module K : Sexp_of_m with type t = k) sexp_of_v t =\n sexp_of_t K.sexp_of_t sexp_of_v t\n;;\n\nlet m__t_of_sexp (type k) (module K : M_of_sexp with type t = k) v_of_sexp sexp =\n t_of_sexp ~hashable:(Hashable.of_key (module K)) K.t_of_sexp v_of_sexp sexp\n;;\n\n(* typechecking this code is a compile-time test that [Creators] is a specialization of\n [Creators_generic]. *)\nmodule Check : sig end = struct\n module Make_creators_check\n (Type : T.T2)\n (Key : T.T1)\n (Options : T.T3)\n (M : Creators_generic\n with type ('a, 'b) t := ('a, 'b) Type.t\n with type 'a key := 'a Key.t\n with type ('a, 'b, 'z) create_options := ('a, 'b, 'z) Options.t) =\n struct end\n\n module Check_creators_is_specialization_of_creators_generic (M : Creators) =\n Make_creators_check\n (struct\n type ('a, 'b) t = ('a, 'b) M.t\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type ('a, 'b, 'z) t = ('a, 'b, 'z) create_options\n end)\n (struct\n include M\n\n let create ?growth_allowed ?size m () = create ?growth_allowed ?size m\n end)\nend\n","open! Import\n\nmodule Key = struct\n module type S = sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n (** Two [t]s that [compare] equal must have equal hashes for the hashtable\n to behave properly. *)\n val hash : t -> int\n end\n\n type 'a t = (module S with type t = 'a)\nend\n\nmodule Merge_into_action = struct\n type 'a t =\n | Remove\n | Set_to of 'a\nend\n\nmodule type Accessors = sig\n (** {2 Accessors} *)\n\n type ('a, 'b) t\n type 'a key\n\n val sexp_of_key : ('a, _) t -> 'a key -> Sexp.t\n val clear : (_, _) t -> unit\n val copy : ('a, 'b) t -> ('a, 'b) t\n\n (** Attempting to modify ([set], [remove], etc.) the hashtable during iteration ([fold],\n [iter], [iter_keys], [iteri]) will raise an exception. *)\n val fold : ('a, 'b) t -> init:'c -> f:(key:'a key -> data:'b -> 'c -> 'c) -> 'c\n\n val iter_keys : ('a, _) t -> f:('a key -> unit) -> unit\n val iter : (_, 'b) t -> f:('b -> unit) -> unit\n\n (** Iterates over both keys and values.\n\n Example:\n\n {v\n let h = Hashtbl.of_alist_exn (module Int) [(1, 4); (5, 6)] in\n Hashtbl.iteri h ~f:(fun ~key ~data ->\n print_endline (Printf.sprintf \"%d-%d\" key data));;\n 1-4\n 5-6\n - : unit = ()\n v} *)\n val iteri : ('a, 'b) t -> f:(key:'a key -> data:'b -> unit) -> unit\n\n val existsi : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> bool\n val exists : (_, 'b) t -> f:('b -> bool) -> bool\n val for_alli : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> bool\n val for_all : (_, 'b) t -> f:('b -> bool) -> bool\n val counti : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> int\n val count : (_, 'b) t -> f:('b -> bool) -> int\n val length : (_, _) t -> int\n val is_empty : (_, _) t -> bool\n val mem : ('a, _) t -> 'a key -> bool\n val remove : ('a, _) t -> 'a key -> unit\n val choose : ('a, 'b) t -> ('a key * 'b) option\n val choose_exn : ('a, 'b) t -> 'a key * 'b\n\n (** Sets the given [key] to [data]. *)\n val set : ('a, 'b) t -> key:'a key -> data:'b -> unit\n\n (** [add] and [add_exn] leave the table unchanged if the key was already present. *)\n val add : ('a, 'b) t -> key:'a key -> data:'b -> [ `Ok | `Duplicate ]\n\n val add_exn : ('a, 'b) t -> key:'a key -> data:'b -> unit\n\n (** [change t key ~f] changes [t]'s value for [key] to be [f (find t key)]. *)\n val change : ('a, 'b) t -> 'a key -> f:('b option -> 'b option) -> unit\n\n (** [update t key ~f] is [change t key ~f:(fun o -> Some (f o))]. *)\n val update : ('a, 'b) t -> 'a key -> f:('b option -> 'b) -> unit\n\n (** [map t f] returns a new table with values replaced by the result of applying [f]\n to the current values.\n\n Example:\n\n {v\n let h = Hashtbl.of_alist_exn (module Int) [(1, 4); (5, 6)] in\n let h' = Hashtbl.map h ~f:(fun x -> x * 2) in\n Hashtbl.to_alist h';;\n - : (int * int) list = [(5, 12); (1, 8)]\n v} *)\n val map : ('a, 'b) t -> f:('b -> 'c) -> ('a, 'c) t\n\n (** Like [map], but the function [f] takes both key and data as arguments. *)\n val mapi : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'c) -> ('a, 'c) t\n\n (** Returns a new table by filtering the given table's values by [f]: the keys for which\n [f] applied to the current value returns [Some] are kept, and those for which it\n returns [None] are discarded.\n\n Example:\n\n {v\n let h = Hashtbl.of_alist_exn (module Int) [(1, 4); (5, 6)] in\n Hashtbl.filter_map h ~f:(fun x -> if x > 5 then Some x else None)\n |> Hashtbl.to_alist;;\n - : (int * int) list = [(5, 6)]\n v} *)\n val filter_map : ('a, 'b) t -> f:('b -> 'c option) -> ('a, 'c) t\n\n (** Like [filter_map], but the function [f] takes both key and data as arguments. *)\n val filter_mapi : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'c option) -> ('a, 'c) t\n\n val filter_keys : ('a, 'b) t -> f:('a key -> bool) -> ('a, 'b) t\n val filter : ('a, 'b) t -> f:('b -> bool) -> ('a, 'b) t\n val filteri : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> ('a, 'b) t\n\n (** Returns new tables with bound values partitioned by [f] applied to the bound\n values. *)\n val partition_map\n : ('a, 'b) t\n -> f:('b -> ('c, 'd) Either.t)\n -> ('a, 'c) t * ('a, 'd) t\n\n (** Like [partition_map], but the function [f] takes both key and data as arguments. *)\n val partition_mapi\n : ('a, 'b) t\n -> f:(key:'a key -> data:'b -> ('c, 'd) Either.t)\n -> ('a, 'c) t * ('a, 'd) t\n\n (** Returns a pair of tables [(t1, t2)], where [t1] contains all the elements of the\n initial table which satisfy the predicate [f], and [t2] contains the rest. *)\n val partition_tf : ('a, 'b) t -> f:('b -> bool) -> ('a, 'b) t * ('a, 'b) t\n\n (** Like [partition_tf], but the function [f] takes both key and data as arguments. *)\n val partitioni_tf\n : ('a, 'b) t\n -> f:(key:'a key -> data:'b -> bool)\n -> ('a, 'b) t * ('a, 'b) t\n\n (** [find_or_add t k ~default] returns the data associated with key [k] if it is in the\n table [t], and otherwise assigns [k] the value returned by [default ()]. *)\n val find_or_add : ('a, 'b) t -> 'a key -> default:(unit -> 'b) -> 'b\n\n (** Like [find_or_add] but [default] takes the key as an argument. *)\n val findi_or_add : ('a, 'b) t -> 'a key -> default:('a key -> 'b) -> 'b\n\n (** [find t k] returns [Some] (the current binding) of [k] in [t], or [None] if no such\n binding exists. *)\n val find : ('a, 'b) t -> 'a key -> 'b option\n\n (** [find_exn t k] returns the current binding of [k] in [t], or raises [Caml.Not_found]\n or [Not_found_s] if no such binding exists. *)\n val find_exn : ('a, 'b) t -> 'a key -> 'b\n\n (** [find_and_call t k ~if_found ~if_not_found]\n\n is equivalent to:\n\n [match find t k with Some v -> if_found v | None -> if_not_found k]\n\n except that it doesn't allocate the option. *)\n val find_and_call\n : ('a, 'b) t\n -> 'a key\n -> if_found:('b -> 'c)\n -> if_not_found:('a key -> 'c)\n -> 'c\n\n (** Just like [find_and_call], but takes an extra argument which is passed to [if_found]\n and [if_not_found], so that the client code can avoid allocating closures or using\n refs to pass this additional information. This function is only useful in code\n which tries to minimize heap allocation. *)\n val find_and_call1\n : ('a, 'b) t\n -> 'a key\n -> a:'d\n -> if_found:('b -> 'd -> 'c)\n -> if_not_found:('a key -> 'd -> 'c)\n -> 'c\n\n val find_and_call2\n : ('a, 'b) t\n -> 'a key\n -> a:'d\n -> b:'e\n -> if_found:('b -> 'd -> 'e -> 'c)\n -> if_not_found:('a key -> 'd -> 'e -> 'c)\n -> 'c\n\n val findi_and_call\n : ('a, 'b) t\n -> 'a key\n -> if_found:(key:'a key -> data:'b -> 'c)\n -> if_not_found:('a key -> 'c)\n -> 'c\n\n val findi_and_call1\n : ('a, 'b) t\n -> 'a key\n -> a:'d\n -> if_found:(key:'a key -> data:'b -> 'd -> 'c)\n -> if_not_found:('a key -> 'd -> 'c)\n -> 'c\n\n val findi_and_call2\n : ('a, 'b) t\n -> 'a key\n -> a:'d\n -> b:'e\n -> if_found:(key:'a key -> data:'b -> 'd -> 'e -> 'c)\n -> if_not_found:('a key -> 'd -> 'e -> 'c)\n -> 'c\n\n (** [find_and_remove t k] returns Some (the current binding) of k in t and removes it,\n or None is no such binding exists. *)\n val find_and_remove : ('a, 'b) t -> 'a key -> 'b option\n\n (** Merges two hashtables.\n\n The result of [merge f h1 h2] has as keys the set of all [k] in the union of the\n sets of keys of [h1] and [h2] for which [d(k)] is not None, where:\n\n d(k) =\n - [f ~key:k (`Left d1)]\n if [k] in [h1] maps to d1, and [h2] does not have data for [k];\n\n - [f ~key:k (`Right d2)]\n if [k] in [h2] maps to d2, and [h1] does not have data for [k];\n\n - [f ~key:k (`Both (d1, d2))]\n otherwise, where [k] in [h1] maps to [d1] and [k] in [h2] maps to [d2].\n\n Each key [k] is mapped to a single piece of data [x], where [d(k) = Some x].\n\n Example:\n\n {v\n let h1 = Hashtbl.of_alist_exn (module Int) [(1, 5); (2, 3232)] in\n let h2 = Hashtbl.of_alist_exn (module Int) [(1, 3)] in\n Hashtbl.merge h1 h2 ~f:(fun ~key:_ -> function\n | `Left x -> Some (`Left x)\n | `Right x -> Some (`Right x)\n | `Both (x, y) -> if x=y then None else Some (`Both (x,y))\n ) |> Hashtbl.to_alist;;\n - : (int * [> `Both of int * int | `Left of int | `Right of int ]) list =\n [(2, `Left 3232); (1, `Both (5, 3))]\n v} *)\n val merge\n : ('k, 'a) t\n -> ('k, 'b) t\n -> f:(key:'k key -> [ `Left of 'a | `Right of 'b | `Both of 'a * 'b ] -> 'c option)\n -> ('k, 'c) t\n\n\n (** Every [key] in [src] will be removed or set in [dst] according to the return value\n of [f]. *)\n val merge_into\n : src:('k, 'a) t\n -> dst:('k, 'b) t\n -> f:(key:'k key -> 'a -> 'b option -> 'b Merge_into_action.t)\n -> unit\n\n (** Returns the list of all keys for given hashtable. *)\n val keys : ('a, _) t -> 'a key list\n\n (** Returns the list of all data for given hashtable. *)\n val data : (_, 'b) t -> 'b list\n\n (** [filter_inplace t ~f] removes all the elements from [t] that don't satisfy [f]. *)\n val filter_keys_inplace : ('a, _) t -> f:('a key -> bool) -> unit\n\n val filter_inplace : (_, 'b) t -> f:('b -> bool) -> unit\n val filteri_inplace : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> unit\n\n (** [map_inplace t ~f] applies [f] to all elements in [t], transforming them in\n place. *)\n val map_inplace : (_, 'b) t -> f:('b -> 'b) -> unit\n\n val mapi_inplace : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'b) -> unit\n\n (** [filter_map_inplace] combines the effects of [map_inplace] and [filter_inplace]. *)\n val filter_map_inplace : (_, 'b) t -> f:('b -> 'b option) -> unit\n\n val filter_mapi_inplace : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'b option) -> unit\n\n (** [equal f t1 t2] and [similar f t1 t2] both return true iff [t1] and [t2] have the\n same keys and for all keys [k], [f (find_exn t1 k) (find_exn t2 k)]. [equal] and\n [similar] only differ in their types. *)\n val equal : ('b -> 'b -> bool) -> ('a, 'b) t -> ('a, 'b) t -> bool\n\n val similar : ('b1 -> 'b2 -> bool) -> ('a, 'b1) t -> ('a, 'b2) t -> bool\n\n (** Returns the list of all (key, data) pairs for given hashtable. *)\n val to_alist : ('a, 'b) t -> ('a key * 'b) list\n\n val validate\n : name:('a key -> string)\n -> 'b Validate.check\n -> ('a, 'b) t Validate.check\n\n\n (** [remove_if_zero]'s default is [false]. *)\n val incr : ?by:int -> ?remove_if_zero:bool -> ('a, int) t -> 'a key -> unit\n\n val decr : ?by:int -> ?remove_if_zero:bool -> ('a, int) t -> 'a key -> unit\nend\n\nmodule type Multi = sig\n type ('a, 'b) t\n type 'a key\n\n (** [add_multi t ~key ~data] if [key] is present in the table then cons\n [data] on the list, otherwise add [key] with a single element list. *)\n val add_multi : ('a, 'b list) t -> key:'a key -> data:'b -> unit\n\n (** [remove_multi t key] updates the table, removing the head of the list bound to\n [key]. If the list has only one element (or is empty) then the binding is\n removed. *)\n val remove_multi : ('a, _ list) t -> 'a key -> unit\n\n (** [find_multi t key] returns the empty list if [key] is not present in the table,\n returns [t]'s values for [key] otherwise. *)\n val find_multi : ('a, 'b list) t -> 'a key -> 'b list\nend\n\ntype ('key, 'data, 'z) create_options =\n ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'key Key.t\n -> 'z\n\ntype ('key, 'data, 'z) create_options_without_first_class_module =\n ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'z\n\nmodule type Creators_generic = sig\n type ('a, 'b) t\n type 'a key\n type ('key, 'data, 'z) create_options\n\n val create : ('a key, 'b, unit -> ('a, 'b) t) create_options\n\n\n val of_alist\n : ( 'a key\n , 'b\n , ('a key * 'b) list -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a key ] )\n create_options\n\n val of_alist_report_all_dups\n : ( 'a key\n , 'b\n , ('a key * 'b) list -> [ `Ok of ('a, 'b) t | `Duplicate_keys of 'a key list ] )\n create_options\n\n val of_alist_or_error\n : ('a key, 'b, ('a key * 'b) list -> ('a, 'b) t Or_error.t) create_options\n\n val of_alist_exn : ('a key, 'b, ('a key * 'b) list -> ('a, 'b) t) create_options\n\n val of_alist_multi\n : ('a key, 'b list, ('a key * 'b) list -> ('a, 'b list) t) create_options\n\n\n (** {[ create_mapped get_key get_data [x1,...,xn]\n = of_alist [get_key x1, get_data x1; ...; get_key xn, get_data xn] ]} *)\n val create_mapped\n : ( 'a key\n , 'b\n , get_key:('r -> 'a key)\n -> get_data:('r -> 'b)\n -> 'r list\n -> [ `Ok of ('a, 'b) t | `Duplicate_keys of 'a key list ] )\n create_options\n\n\n (** {[ create_with_key ~get_key [x1,...,xn]\n = of_alist [get_key x1, x1; ...; get_key xn, xn] ]} *)\n val create_with_key\n : ( 'a key\n , 'r\n , get_key:('r -> 'a key)\n -> 'r list\n -> [ `Ok of ('a, 'r) t | `Duplicate_keys of 'a key list ] )\n create_options\n\n val create_with_key_or_error\n : ( 'a key\n , 'r\n , get_key:('r -> 'a key) -> 'r list -> ('a, 'r) t Or_error.t )\n create_options\n\n val create_with_key_exn\n : ('a key, 'r, get_key:('r -> 'a key) -> 'r list -> ('a, 'r) t) create_options\n\n\n val group\n : ( 'a key\n , 'b\n , get_key:('r -> 'a key)\n -> get_data:('r -> 'b)\n -> combine:('b -> 'b -> 'b)\n -> 'r list\n -> ('a, 'b) t )\n create_options\nend\n\nmodule type Creators = sig\n type ('a, 'b) t\n\n (** {2 Creators} *)\n\n (** The module you pass to [create] must have a type that is hashable, sexpable, and\n comparable.\n\n Example:\n\n {v\n Hashtbl.create (module Int);;\n - : (int, '_a) Hashtbl.t = ;;\n v} *)\n val create\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a, 'b) t\n\n (** Example:\n\n {v\n Hashtbl.of_alist (module Int) [(3, \"something\"); (2, \"whatever\")]\n - : [ `Duplicate_key of int | `Ok of (int, string) Hashtbl.t ] = `Ok \n v} *)\n val of_alist\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a * 'b) list\n -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a ]\n\n (** Whereas [of_alist] will report [Duplicate_key] no matter how many dups there are in\n your list, [of_alist_report_all_dups] will report each and every duplicate entry.\n\n For example:\n\n {v\n Hashtbl.of_alist (module Int) [(1, \"foo\"); (1, \"bar\"); (2, \"foo\"); (2, \"bar\")];;\n - : [ `Duplicate_key of int | `Ok of (int, string) Hashtbl.t ] = `Duplicate_key 1\n\n Hashtbl.of_alist_report_all_dups (module Int) [(1, \"foo\"); (1, \"bar\"); (2, \"foo\"); (2, \"bar\")];;\n - : [ `Duplicate_keys of int list | `Ok of (int, string) Hashtbl.t ] = `Duplicate_keys [1; 2]\n v} *)\n val of_alist_report_all_dups\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a * 'b) list\n -> [ `Ok of ('a, 'b) t | `Duplicate_keys of 'a list ]\n\n val of_alist_or_error\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a * 'b) list\n -> ('a, 'b) t Or_error.t\n\n val of_alist_exn\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a * 'b) list\n -> ('a, 'b) t\n\n (** Creates a {{!Multi} \"multi\"} hashtable, i.e., a hashtable where each key points to a\n list potentially containing multiple values. So instead of short-circuiting with a\n [`Duplicate_key] variant on duplicates, as in [of_alist], [of_alist_multi] folds\n those values into a list for the given key:\n\n {v\n let h = Hashtbl.of_alist_multi (module Int) [(1, \"a\"); (1, \"b\"); (2, \"c\"); (2, \"d\")];;\n val h : (int, string list) Hashtbl.t = \n\n Hashtbl.find_exn h 1;;\n - : string list = [\"b\"; \"a\"]\n v} *)\n val of_alist_multi\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a * 'b) list\n -> ('a, 'b list) t\n\n (** Applies the [get_key] and [get_data] functions to the ['r list] to create the\n initial keys and values, respectively, for the new hashtable.\n\n {[ create_mapped get_key get_data [x1;...;xn]\n = of_alist [get_key x1, get_data x1; ...; get_key xn, get_data xn]\n ]}\n\n Example:\n\n {v\n let h =\n Hashtbl.create_mapped (module Int)\n ~get_key:(fun x -> x)\n ~get_data:(fun x -> x + 1)\n [1; 2; 3];;\n val h : [ `Duplicate_keys of int list | `Ok of (int, int) Hashtbl.t ] = `Ok \n\n let h =\n match h with\n | `Ok x -> x\n | `Duplicate_keys _ -> failwith \"\"\n in\n Hashtbl.find_exn h 1;;\n - : int = 2\n v} *)\n val create_mapped\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> get_key:('r -> 'a)\n -> get_data:('r -> 'b)\n -> 'r list\n -> [ `Ok of ('a, 'b) t | `Duplicate_keys of 'a list ]\n\n (** {[ create_with_key ~get_key [x1;...;xn]\n = of_alist [get_key x1, x1; ...; get_key xn, xn] ]} *)\n val create_with_key\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> get_key:('r -> 'a)\n -> 'r list\n -> [ `Ok of ('a, 'r) t | `Duplicate_keys of 'a list ]\n\n val create_with_key_or_error\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> get_key:('r -> 'a)\n -> 'r list\n -> ('a, 'r) t Or_error.t\n\n val create_with_key_exn\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> get_key:('r -> 'a)\n -> 'r list\n -> ('a, 'r) t\n\n (** Like [create_mapped], applies the [get_key] and [get_data] functions to the ['r\n list] to create the initial keys and values, respectively, for the new hashtable --\n and then, like [add_multi], folds together values belonging to the same keys. Here,\n though, the function used for the folding is given by [combine] (instead of just\n being a [cons]).\n\n Example:\n\n {v\n Hashtbl.group (module Int)\n ~get_key:(fun x -> x / 2)\n ~get_data:(fun x -> x)\n ~combine:(fun x y -> x * y)\n [ 1; 2; 3; 4]\n |> Hashtbl.to_alist;;\n - : (int * int) list = [(2, 4); (1, 6); (0, 1)]\n v} *)\n val group\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> get_key:('r -> 'a)\n -> get_data:('r -> 'b)\n -> combine:('b -> 'b -> 'b)\n -> 'r list\n -> ('a, 'b) t\nend\n\nmodule type S_without_submodules = sig\n val hash : 'a -> int\n val hash_param : int -> int -> 'a -> int\n\n type ('a, 'b) t\n\n (** We provide a [sexp_of_t] but not a [t_of_sexp] for this type because one needs to be\n explicit about the hash and comparison functions used when creating a hashtable.\n Note that [Hashtbl.Poly.t] does have [[@@deriving sexp]], and uses OCaml's built-in\n polymorphic comparison and and polymorphic hashing. *)\n val sexp_of_t : ('a -> Sexp.t) -> ('b -> Sexp.t) -> ('a, 'b) t -> Sexp.t\n\n include Creators with type ('a, 'b) t := ('a, 'b) t (** @inline *)\n\n include\n Accessors with type ('a, 'b) t := ('a, 'b) t with type 'a key = 'a\n (** @inline *)\n\n\n include\n Multi with type ('a, 'b) t := ('a, 'b) t with type 'a key := 'a key\n (** @inline *)\n\n val hashable_s : ('key, _) t -> 'key Key.t\n\n include Invariant.S2 with type ('a, 'b) t := ('a, 'b) t\nend\n\nmodule type S_poly = sig\n type ('a, 'b) t [@@deriving_inline sexp]\n\n include Ppx_sexp_conv_lib.Sexpable.S2 with type ('a, 'b) t := ('a, 'b) t\n\n [@@@end]\n\n val hashable : 'a Hashable.t\n\n include Invariant.S2 with type ('a, 'b) t := ('a, 'b) t\n\n include\n Creators_generic\n with type ('a, 'b) t := ('a, 'b) t\n with type 'a key = 'a\n with type ('key, 'data, 'z) create_options :=\n ('key, 'data, 'z) create_options_without_first_class_module\n\n include Accessors with type ('a, 'b) t := ('a, 'b) t with type 'a key := 'a key\n include Multi with type ('a, 'b) t := ('a, 'b) t with type 'a key := 'a key\nend\n\nmodule type For_deriving = sig\n type ('k, 'v) t\n\n module type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end\n\n module type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Key.S with type t := t\n end\n\n val sexp_of_m__t\n : (module Sexp_of_m with type t = 'k)\n -> ('v -> Sexp.t)\n -> ('k, 'v) t\n -> Sexp.t\n\n val m__t_of_sexp\n : (module M_of_sexp with type t = 'k)\n -> (Sexp.t -> 'v)\n -> Sexp.t\n -> ('k, 'v) t\nend\n\nmodule type Hashtbl = sig\n (** A hash table is a mutable data structure implementing a map between keys and values.\n It supports constant-time lookup and in-place modification.\n\n {1 Usage}\n\n As a simple example, we'll create a hash table with string keys using the\n {{!create}[create]} constructor, which expects a module defining the key's type:\n\n {[\n let h = Hashtbl.create (module String);;\n val h : (string, '_a) Hashtbl.t = \n ]}\n\n We can set the values of individual keys with {{!set}[set]}. If the key already has\n a value, it will be overwritten.\n\n {v\n Hashtbl.set h ~key:\"foo\" ~data:5;;\n - : unit = ()\n\n Hashtbl.set h ~key:\"foo\" ~data:6;;\n - : unit = ()\n\n Hashtbl.set h ~key:\"bar\" ~data:6;;\n - : unit = ()\n v}\n\n We can access values by key, or dump all of the hash table's data:\n\n {v\n Hashtbl.find h \"foo\";;\n - : int option = Some 6\n\n Hashtbl.find_exn h \"foo\";;\n - : int = 6\n\n Hashtbl.to_alist h;;\n - : (string * int) list = [(\"foo\", 6); (\"bar\", 6)]\n v}\n\n {{!change}[change]} lets us change a key's value by applying the given function:\n\n {v\n Hashtbl.change h \"foo\" (fun x ->\n match x with\n | Some x -> Some (x * 2)\n | None -> None\n );;\n - : unit = ()\n\n Hashtbl.to_alist h;;\n - : (string * int) list = [(\"foo\", 12); (\"bar\", 6)]\n v}\n\n\n We can use {{!merge}[merge]} to merge two hashtables with fine-grained control over\n how we choose values when a key is present in the first (\"left\") hashtable, the\n second (\"right\"), or both. Here, we'll cons the values when both hashtables have a\n key:\n\n {v\n let h1 = Hashtbl.of_alist_exn (module Int) [(1, 5); (2, 3232)] in\n let h2 = Hashtbl.of_alist_exn (module Int) [(1, 3)] in\n Hashtbl.merge h1 h2 ~f:(fun ~key:_ -> function\n | `Left x -> Some (`Left x)\n | `Right x -> Some (`Right x)\n | `Both (x, y) -> if x=y then None else Some (`Both (x,y))\n ) |> Hashtbl.to_alist;;\n - : (int * [> `Both of int * int | `Left of int | `Right of int ]) list =\n [(2, `Left 3232); (1, `Both (5, 3))]\n v}\n\n {1 Interface} *)\n\n include S_without_submodules (** @inline *)\n\n module type Accessors = Accessors\n module type Creators = Creators\n module type Key = Key.S [@@deprecated \"[since 2019-03] Use [Hashtbl.Key.S]\"]\n module type Multi = Multi\n module type S_poly = S_poly\n module type S_without_submodules = S_without_submodules\n module type For_deriving = For_deriving\n\n module Key = Key\n module Merge_into_action = Merge_into_action\n\n type nonrec ('key, 'data, 'z) create_options = ('key, 'data, 'z) create_options\n\n module Creators (Key : sig\n type 'a t\n\n val hashable : 'a t Hashable.t\n end) : sig\n type ('a, 'b) t_ = ('a Key.t, 'b) t\n\n val t_of_sexp : (Sexp.t -> 'a Key.t) -> (Sexp.t -> 'b) -> Sexp.t -> ('a, 'b) t_\n\n include\n Creators_generic\n with type ('a, 'b) t := ('a, 'b) t_\n with type 'a key := 'a Key.t\n with type ('key, 'data, 'a) create_options :=\n ('key, 'data, 'a) create_options_without_first_class_module\n end\n\n module Poly : S_poly with type ('a, 'b) t = ('a, 'b) t\n\n (** [M] is meant to be used in combination with OCaml applicative functor types:\n\n {[\n type string_to_int_table = int Hashtbl.M(String).t\n ]}\n\n which stands for:\n\n {[\n type string_to_int_table = (String.t, int) Hashtbl.t\n ]}\n\n The point is that [int Hashtbl.M(String).t] supports deriving, whereas the second\n syntax doesn't (because [t_of_sexp] doesn't know what comparison/hash function to\n use). *)\n module M (K : T.T) : sig\n type nonrec 'v t = (K.t, 'v) t\n end\n\n include For_deriving with type ('a, 'b) t := ('a, 'b) t\n\n (**/**)\n\n (*_ See the Jane Street Style Guide for an explanation of [Private] submodules:\n\n https://opensource.janestreet.com/standards/#private-submodules *)\n module Private : sig\n module type Creators_generic = Creators_generic\n\n type nonrec ('key, 'data, 'z) create_options_without_first_class_module =\n ('key, 'data, 'z) create_options_without_first_class_module\n\n val hashable : ('key, _) t -> 'key Hashable.t\n end\nend\n","open! Import\n\nmodule type Key = sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n (** Values returned by [hash] must be non-negative. An exception will be raised in the\n case that [hash] returns a negative value. *)\n val hash : t -> int\nend\n\nmodule Hashable = struct\n type 'a t =\n { hash : 'a -> int\n ; compare : 'a -> 'a -> int\n ; sexp_of_t : 'a -> Sexp.t\n }\n\n (** This function is sound but not complete, meaning that if it returns [true] then it's\n safe to use the two interchangeably. If it's [false], you have no guarantees. For\n example:\n\n {[\n > utop\n open Core;;\n let equal (a : 'a Hashtbl_intf.Hashable.t) b =\n phys_equal a b\n || (phys_equal a.hash b.hash\n && phys_equal a.compare b.compare\n && phys_equal a.sexp_of_t b.sexp_of_t)\n ;;\n let a = Hashtbl_intf.Hashable.{ hash; compare; sexp_of_t = Int.sexp_of_t };;\n let b = Hashtbl_intf.Hashable.{ hash; compare; sexp_of_t = Int.sexp_of_t };;\n equal a b;; (* false?! *)\n ]}\n *)\n let equal a b =\n phys_equal a b\n || (phys_equal a.hash b.hash\n && phys_equal a.compare b.compare\n && phys_equal a.sexp_of_t b.sexp_of_t)\n ;;\n\n let hash_param = Caml.Hashtbl.hash_param\n let hash = Caml.Hashtbl.hash\n let poly = { hash; compare = Poly.compare; sexp_of_t = (fun _ -> Sexp.Atom \"_\") }\n\n let of_key (type a) (module Key : Key with type t = a) =\n { hash = Key.hash; compare = Key.compare; sexp_of_t = Key.sexp_of_t }\n ;;\n\n let to_key (type a) { hash; compare; sexp_of_t } =\n (module struct\n type t = a\n\n let hash = hash\n let compare = compare\n let sexp_of_t = sexp_of_t\n end : Key\n with type t = a)\n ;;\nend\n\ninclude Hashable\n\nmodule type Hashable = sig\n type 'a t = 'a Hashable.t =\n { hash : 'a -> int\n ; compare : 'a -> 'a -> int\n ; sexp_of_t : 'a -> Sexp.t\n }\n\n val equal : 'a t -> 'a t -> bool\n val poly : 'a t\n val of_key : (module Key with type t = 'a) -> 'a t\n val to_key : 'a t -> (module Key with type t = 'a)\n val hash_param : int -> int -> 'a -> int\n val hash : 'a -> int\nend\n","(* A few small things copied from other parts of Base because they depend on us, so we\n can't use them. *)\n\nopen! Import\n\nlet raise_s = Error.raise_s\n\nmodule Int = struct\n type t = int\n\n let max (x : t) y = if x > y then x else y\nend\n\n(* Its important that Empty have no args. It's tempting to make this type a record\n (e.g. to hold the compare function), but a lot of memory is saved by Empty being an\n immediate, since all unused buckets in the hashtbl don't use any memory (besides the\n array cell) *)\ntype ('k, 'v) t =\n | Empty\n | Node of\n { mutable left : ('k, 'v) t\n ; key : 'k\n ; mutable value : 'v\n ; mutable height : int\n ; mutable right : ('k, 'v) t\n }\n | Leaf of\n { key : 'k\n ; mutable value : 'v\n }\n\nlet empty = Empty\n\nlet is_empty = function\n | Empty -> true\n | Leaf _ | Node _ -> false\n;;\n\nlet height = function\n | Empty -> 0\n | Leaf _ -> 1\n | Node { left = _; key = _; value = _; height; right = _ } -> height\n;;\n\nlet invariant compare =\n let legal_left_key key = function\n | Empty -> ()\n | Leaf { key = left_key; value = _ }\n | Node { left = _; key = left_key; value = _; height = _; right = _ } ->\n assert (compare left_key key < 0)\n in\n let legal_right_key key = function\n | Empty -> ()\n | Leaf { key = right_key; value = _ }\n | Node { left = _; key = right_key; value = _; height = _; right = _ } ->\n assert (compare right_key key > 0)\n in\n let rec inv = function\n | Empty | Leaf _ -> ()\n | Node { left; key = k; value = _; height = h; right } ->\n let hl, hr = height left, height right in\n inv left;\n inv right;\n legal_left_key k left;\n legal_right_key k right;\n assert (h = Int.max hl hr + 1);\n assert (abs (hl - hr) <= 2)\n in\n inv\n;;\n\nlet invariant t ~compare = invariant compare t\n\n(* In the following comments,\n 't is balanced' means that 'invariant t' does not\n raise an exception. This implies of course that each node's height field is\n correct.\n 't is balanceable' means that height of the left and right subtrees of t\n differ by at most 3. *)\n\n(* @pre: left and right subtrees have correct heights\n @post: output has the correct height *)\nlet update_height = function\n | Node ({ left; key = _; value = _; height = old_height; right } as x) ->\n let new_height = Int.max (height left) (height right) + 1 in\n if new_height <> old_height then x.height <- new_height\n | Empty | Leaf _ -> assert false\n;;\n\n(* @pre: left and right subtrees are balanced\n @pre: tree is balanceable\n @post: output is balanced (in particular, height is correct) *)\nlet balance tree =\n match tree with\n | Empty | Leaf _ -> tree\n | Node ({ left; key = _; value = _; height = _; right } as root_node) ->\n let hl = height left\n and hr = height right in\n (* + 2 is critically important, lowering it to 1 will break the Leaf\n assumptions in the code below, and will force us to promote leaf nodes in\n the balance routine. It's also faster, since it will balance less often.\n Note that the following code is delicate. The update_height calls must\n occur in the correct order, since update_height assumes its children have\n the correct heights. *)\n if hl > hr + 2\n then (\n match left with\n (* It cannot be a leaf, because even if right is empty, a leaf\n is only height 1 *)\n | Empty | Leaf _ -> assert false\n | Node\n ({ left = left_node_left\n ; key = _\n ; value = _\n ; height = _\n ; right = left_node_right\n } as left_node) ->\n if height left_node_left >= height left_node_right\n then (\n root_node.left <- left_node_right;\n left_node.right <- tree;\n update_height tree;\n update_height left;\n left)\n else (\n (* if right is a leaf, then left must be empty. That means\n height is 2. Even if hr is empty we still can't get here. *)\n match left_node_right with\n | Empty | Leaf _ -> assert false\n | Node\n ({ left = lr_left; key = _; value = _; height = _; right = lr_right } as\n lr_node) ->\n left_node.right <- lr_left;\n root_node.left <- lr_right;\n lr_node.right <- tree;\n lr_node.left <- left;\n update_height left;\n update_height tree;\n update_height left_node_right;\n left_node_right))\n else if hr > hl + 2\n then (\n (* see above for an explanation of why right cannot be a leaf *)\n match right with\n | Empty | Leaf _ -> assert false\n | Node\n ({ left = right_node_left\n ; key = _\n ; value = _\n ; height = _\n ; right = right_node_right\n } as right_node) ->\n if height right_node_right >= height right_node_left\n then (\n root_node.right <- right_node_left;\n right_node.left <- tree;\n update_height tree;\n update_height right;\n right)\n else (\n (* see above for an explanation of why this cannot be a leaf *)\n match right_node_left with\n | Empty | Leaf _ -> assert false\n | Node\n ({ left = rl_left; key = _; value = _; height = _; right = rl_right } as\n rl_node) ->\n right_node.left <- rl_right;\n root_node.right <- rl_left;\n rl_node.left <- tree;\n rl_node.right <- right;\n update_height right;\n update_height tree;\n update_height right_node_left;\n right_node_left))\n else (\n update_height tree;\n tree)\n;;\n\n(* @pre: tree is balanceable\n @pre: abs (height (right node) - height (balance tree)) <= 3\n @post: result is balanceable *)\n\n(* @pre: tree is balanceable\n @pre: abs (height (right node) - height (balance tree)) <= 3\n @post: result is balanceable *)\nlet set_left node tree =\n let tree = balance tree in\n match node with\n | Node ({ left; key = _; value = _; height = _; right = _ } as r) ->\n if phys_equal left tree then () else r.left <- tree;\n update_height node\n | _ -> assert false\n;;\n\n(* @pre: tree is balanceable\n @pre: abs (height (left node) - height (balance tree)) <= 3\n @post: result is balanceable *)\nlet set_right node tree =\n let tree = balance tree in\n match node with\n | Node ({ left = _; key = _; value = _; height = _; right } as r) ->\n if phys_equal right tree then () else r.right <- tree;\n update_height node\n | _ -> assert false\n;;\n\n(* @pre: t is balanced.\n @post: result is balanced, with new node inserted\n @post: !added = true iff the shape of the input tree changed. *)\nlet add =\n let rec add t replace added compare k v =\n match t with\n | Empty ->\n added := true;\n Leaf { key = k; value = v }\n | Leaf ({ key = k'; value = _ } as r) ->\n let c = compare k' k in\n (* This compare is reversed on purpose, we are pretending\n that the leaf was just inserted instead of the other way\n round, that way we only allocate one node. *)\n if c = 0\n then (\n added := false;\n if replace then r.value <- v;\n t)\n else (\n added := true;\n if c < 0\n then Node { left = t; key = k; value = v; height = 2; right = Empty }\n else Node { left = Empty; key = k; value = v; height = 2; right = t })\n | Node ({ left; key = k'; value = _; height = _; right } as r) ->\n let c = compare k k' in\n if c = 0\n then (\n added := false;\n if replace then r.value <- v)\n else if c < 0\n then set_left t (add left replace added compare k v)\n else set_right t (add right replace added compare k v);\n t\n in\n fun t ~replace ~compare ~added ~key ~data ->\n let t = add t replace added compare key data in\n if !added then balance t else t\n;;\n\nlet rec first t =\n match t with\n | Empty -> None\n | Leaf { key = k; value = v }\n | Node { left = Empty; key = k; value = v; height = _; right = _ } -> Some (k, v)\n | Node { left = l; key = _; value = _; height = _; right = _ } -> first l\n;;\n\nlet rec last t =\n match t with\n | Empty -> None\n | Leaf { key = k; value = v }\n | Node { left = _; key = k; value = v; height = _; right = Empty } -> Some (k, v)\n | Node { left = _; key = _; value = _; height = _; right = r } -> last r\n;;\n\n\nlet[@inline always] rec findi_and_call_impl\n t\n ~compare\n k\n arg1\n arg2\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n =\n match t with\n | Empty -> call_if_not_found ~if_not_found k arg1 arg2\n | Leaf { key = k'; value = v } ->\n if compare k k' = 0\n then call_if_found ~if_found ~key:k' ~data:v arg1 arg2\n else call_if_not_found ~if_not_found k arg1 arg2\n | Node { left; key = k'; value = v; height = _; right } ->\n let c = compare k k' in\n if c = 0\n then call_if_found ~if_found ~key:k' ~data:v arg1 arg2\n else\n findi_and_call_impl\n (if c < 0 then left else right)\n ~compare\n k\n arg1\n arg2\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet find_and_call =\n let call_if_found ~if_found ~key:_ ~data () () = if_found data in\n let call_if_not_found ~if_not_found key () () = if_not_found key in\n fun t ~compare k ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n ()\n ()\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet findi_and_call =\n let call_if_found ~if_found ~key ~data () () = if_found ~key ~data in\n let call_if_not_found ~if_not_found key () () = if_not_found key in\n fun t ~compare k ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n ()\n ()\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet find_and_call1 =\n let call_if_found ~if_found ~key:_ ~data arg () = if_found data arg in\n let call_if_not_found ~if_not_found key arg () = if_not_found key arg in\n fun t ~compare k ~a ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n a\n ()\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet findi_and_call1 =\n let call_if_found ~if_found ~key ~data arg () = if_found ~key ~data arg in\n let call_if_not_found ~if_not_found key arg () = if_not_found key arg in\n fun t ~compare k ~a ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n a\n ()\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet find_and_call2 =\n let call_if_found ~if_found ~key:_ ~data arg1 arg2 = if_found data arg1 arg2 in\n let call_if_not_found ~if_not_found key arg1 arg2 = if_not_found key arg1 arg2 in\n fun t ~compare k ~a ~b ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n a\n b\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet findi_and_call2 =\n let call_if_found ~if_found ~key ~data arg1 arg2 = if_found ~key ~data arg1 arg2 in\n let call_if_not_found ~if_not_found key arg1 arg2 = if_not_found key arg1 arg2 in\n fun t ~compare k ~a ~b ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n a\n b\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet find =\n let if_found v = Some v in\n let if_not_found _ = None in\n fun t ~compare k -> find_and_call t ~compare k ~if_found ~if_not_found\n;;\n\nlet mem =\n let if_found _ = true in\n let if_not_found _ = false in\n fun t ~compare k -> find_and_call t ~compare k ~if_found ~if_not_found\n;;\n\nlet remove =\n let rec min_elt tree =\n match tree with\n | Empty -> Empty\n | Leaf _ -> tree\n | Node { left = Empty; key = _; value = _; height = _; right = _ } -> tree\n | Node { left; key = _; value = _; height = _; right = _ } -> min_elt left\n in\n let rec remove_min_elt tree =\n match tree with\n | Empty -> assert false\n | Leaf _ -> Empty (* This must be the root *)\n | Node { left = Empty; key = _; value = _; height = _; right } -> right\n | Node { left = Leaf _; key = k; value = v; height = _; right = Empty } ->\n Leaf { key = k; value = v }\n | Node { left = Leaf _; key = _; value = _; height = _; right = _ } as node ->\n set_left node Empty;\n tree\n | Node { left; key = _; value = _; height = _; right = _ } as node ->\n set_left node (remove_min_elt left);\n tree\n in\n let merge t1 t2 =\n match t1, t2 with\n | Empty, t -> t\n | t, Empty -> t\n | _, _ ->\n let tree = min_elt t2 in\n (match tree with\n | Empty -> assert false\n | Leaf { key = k; value = v } ->\n let t2 = balance (remove_min_elt t2) in\n Node\n { left = t1\n ; key = k\n ; value = v\n ; height = Int.max (height t1) (height t2) + 1\n ; right = t2\n }\n | Node _ as node ->\n set_right node (remove_min_elt t2);\n set_left node t1;\n node)\n in\n let rec remove t removed compare k =\n match t with\n | Empty ->\n removed := false;\n Empty\n | Leaf { key = k'; value = _ } ->\n if compare k k' = 0\n then (\n removed := true;\n Empty)\n else (\n removed := false;\n t)\n | Node { left; key = k'; value = _; height = _; right } ->\n let c = compare k k' in\n if c = 0\n then (\n removed := true;\n merge left right)\n else if c < 0\n then (\n set_left t (remove left removed compare k);\n t)\n else (\n set_right t (remove right removed compare k);\n t)\n in\n fun t ~removed ~compare k -> balance (remove t removed compare k)\n;;\n\nlet rec fold t ~init ~f =\n match t with\n | Empty -> init\n | Leaf { key; value = data } -> f ~key ~data init\n | Node\n { left = Leaf { key = lkey; value = ldata }\n ; key\n ; value = data\n ; height = _\n ; right = Leaf { key = rkey; value = rdata }\n } -> f ~key:rkey ~data:rdata (f ~key ~data (f ~key:lkey ~data:ldata init))\n | Node\n { left = Leaf { key = lkey; value = ldata }\n ; key\n ; value = data\n ; height = _\n ; right = Empty\n } -> f ~key ~data (f ~key:lkey ~data:ldata init)\n | Node\n { left = Empty\n ; key\n ; value = data\n ; height = _\n ; right = Leaf { key = rkey; value = rdata }\n } -> f ~key:rkey ~data:rdata (f ~key ~data init)\n | Node\n { left; key; value = data; height = _; right = Leaf { key = rkey; value = rdata } }\n -> f ~key:rkey ~data:rdata (f ~key ~data (fold left ~init ~f))\n | Node\n { left = Leaf { key = lkey; value = ldata }; key; value = data; height = _; right }\n -> fold right ~init:(f ~key ~data (f ~key:lkey ~data:ldata init)) ~f\n | Node { left; key; value = data; height = _; right } ->\n fold right ~init:(f ~key ~data (fold left ~init ~f)) ~f\n;;\n\nlet rec iter t ~f =\n match t with\n | Empty -> ()\n | Leaf { key; value = data } -> f ~key ~data\n | Node { left; key; value = data; height = _; right } ->\n iter left ~f;\n f ~key ~data;\n iter right ~f\n;;\n\nlet rec mapi_inplace t ~f =\n match t with\n | Empty -> ()\n | Leaf ({ key; value } as t) -> t.value <- f ~key ~data:value\n | Node ({ left; key; value; height = _; right } as t) ->\n mapi_inplace ~f left;\n t.value <- f ~key ~data:value;\n mapi_inplace ~f right\n;;\n\nlet choose_exn = function\n | Empty -> raise_s (Sexp.message \"[Avltree.choose_exn] of empty hashtbl\" [])\n | Leaf { key; value; _ } | Node { key; value; _ } -> key, value\n;;\n","open! Import\nmodule Key = Hashtbl_intf.Key\n\nmodule type Accessors = sig\n include Container.Generic\n\n (** override [Container.Generic.mem] *)\n val mem : 'a t -> 'a -> bool\n\n (** preserves the equality function *)\n val copy : 'a t -> 'a t\n\n val add : 'a t -> 'a -> unit\n\n (** [strict_add t x] returns [Ok ()] if the [x] was not in [t], or an [Error] if it\n was. *)\n val strict_add : 'a t -> 'a -> unit Or_error.t\n\n val strict_add_exn : 'a t -> 'a -> unit\n val remove : 'a t -> 'a -> unit\n\n (** [strict_remove t x] returns [Ok ()] if the [x] was in [t], or an [Error] if it\n was not. *)\n val strict_remove : 'a t -> 'a -> unit Or_error.t\n\n val strict_remove_exn : 'a t -> 'a -> unit\n val clear : 'a t -> unit\n val equal : 'a t -> 'a t -> bool\n val filter : 'a t -> f:('a -> bool) -> 'a t\n val filter_inplace : 'a t -> f:('a -> bool) -> unit\n\n (** [inter t1 t2] computes the set intersection of [t1] and [t2]. Runs in O(min(length\n t1, length t2)). Behavior is undefined if [t1] and [t2] don't have the same\n equality function. *)\n val inter : 'key t -> 'key t -> 'key t\n\n val union : 'a t -> 'a t -> 'a t\n val diff : 'a t -> 'a t -> 'a t\n val of_hashtbl_keys : ('a, _) Hashtbl.t -> 'a t\n val to_hashtbl : 'key t -> f:('key -> 'data) -> ('key, 'data) Hashtbl.t\nend\n\ntype ('key, 'z) create_options = ('key, unit, 'z) Hashtbl_intf.create_options\n\ntype ('key, 'z) create_options_without_first_class_module =\n ('key, unit, 'z) Hashtbl_intf.create_options_without_first_class_module\n\nmodule type Creators = sig\n type 'a t\n\n val create\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> 'a t\n\n val of_list\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> 'a list\n -> 'a t\nend\n\nmodule type Creators_generic = sig\n type 'a t\n type 'a elt\n type ('a, 'z) create_options\n\n val create : ('a, unit -> 'a t) create_options\n val of_list : ('a, 'a elt list -> 'a t) create_options\nend\n\nmodule Check = struct\n module Make_creators_check\n (Type : T.T1)\n (Elt : T.T1)\n (Options : T.T2)\n (M : Creators_generic\n with type 'a t := 'a Type.t\n with type 'a elt := 'a Elt.t\n with type ('a, 'z) create_options := ('a, 'z) Options.t) =\n struct end\n\n module Check_creators_is_specialization_of_creators_generic (M : Creators) =\n Make_creators_check\n (struct\n type 'a t = 'a M.t\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type ('a, 'z) t = ('a, 'z) create_options\n end)\n (struct\n include M\n\n let create ?growth_allowed ?size m () = create ?growth_allowed ?size m\n end)\nend\n\nmodule type Hash_set = sig\n type 'a t [@@deriving_inline sexp_of]\n\n val sexp_of_t : ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n (** We use [[@@deriving sexp_of]] but not [[@@deriving sexp]] because we want people to be\n explicit about the hash and comparison functions used when creating hashtables. One\n can use [Hash_set.Poly.t], which does have [[@@deriving sexp]], to use polymorphic\n comparison and hashing. *)\n\n module Key = Key\n\n module type Creators = Creators\n module type Creators_generic = Creators_generic\n\n type nonrec ('key, 'z) create_options = ('key, 'z) create_options\n\n include Creators with type 'a t := 'a t (** @open *)\n\n module type Accessors = Accessors\n\n include Accessors with type 'a t := 'a t with type 'a elt = 'a (** @open *)\n\n val hashable_s : 'key t -> 'key Key.t\n\n type nonrec ('key, 'z) create_options_without_first_class_module =\n ('key, 'z) create_options_without_first_class_module\n\n (** A hash set that uses polymorphic comparison *)\n module Poly : sig\n type nonrec 'a t = 'a t [@@deriving_inline sexp]\n\n include Ppx_sexp_conv_lib.Sexpable.S1 with type 'a t := 'a t\n\n [@@@end]\n\n include\n Creators_generic\n with type 'a t := 'a t\n with type 'a elt = 'a\n with type ('key, 'z) create_options :=\n ('key, 'z) create_options_without_first_class_module\n\n include Accessors with type 'a t := 'a t with type 'a elt := 'a elt\n end\n\n (** [M] is meant to be used in combination with OCaml applicative functor types:\n\n {[\n type string_hash_set = Hash_set.M(String).t\n ]}\n\n which stands for:\n\n {[\n type string_hash_set = (String.t, int) Hash_set.t\n ]}\n\n The point is that [Hash_set.M(String).t] supports deriving, whereas the second\n syntax doesn't (because [t_of_sexp] doesn't know what comparison/hash function to\n use). *)\n module M (Elt : T.T) : sig\n type nonrec t = Elt.t t\n end\n\n module type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end\n\n module type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Hashtbl_intf.Key.S with type t := t\n end\n\n val sexp_of_m__t : (module Sexp_of_m with type t = 'elt) -> 'elt t -> Sexp.t\n val m__t_of_sexp : (module M_of_sexp with type t = 'elt) -> Sexp.t -> 'elt t\n\n module Creators (Elt : sig\n type 'a t\n\n val hashable : 'a t Hashable.t\n end) : sig\n type 'a t_ = 'a Elt.t t\n\n val t_of_sexp : (Sexp.t -> 'a Elt.t) -> Sexp.t -> 'a t_\n\n include\n Creators_generic\n with type 'a t := 'a t_\n with type 'a elt := 'a Elt.t\n with type ('elt, 'z) create_options :=\n ('elt, 'z) create_options_without_first_class_module\n end\n\n (**/**)\n\n (*_ See the Jane Street Style Guide for an explanation of [Private] submodules:\n\n https://opensource.janestreet.com/standards/#private-submodules *)\n module Private : sig\n val hashable : 'a t -> 'a Hashable.t\n end\nend\n","open! Import\ninclude Hash_set_intf\n\nlet hashable_s = Hashtbl.hashable_s\nlet hashable = Hashtbl.Private.hashable\nlet poly_hashable = Hashtbl.Poly.hashable\nlet with_return = With_return.with_return\n\ntype 'a t = ('a, unit) Hashtbl.t\ntype 'a hash_set = 'a t\ntype 'a elt = 'a\n\nmodule Accessors = struct\n let hashable = hashable\n let clear = Hashtbl.clear\n let length = Hashtbl.length\n let mem = Hashtbl.mem\n let is_empty t = Hashtbl.is_empty t\n\n let find_map t ~f =\n with_return (fun r ->\n Hashtbl.iter_keys t ~f:(fun elt ->\n match f elt with\n | None -> ()\n | Some _ as o -> r.return o);\n None)\n ;;\n\n let find t ~f = find_map t ~f:(fun a -> if f a then Some a else None)\n let add t k = Hashtbl.set t ~key:k ~data:()\n\n let strict_add t k =\n if mem t k\n then Or_error.error_string \"element already exists\"\n else (\n Hashtbl.set t ~key:k ~data:();\n Result.Ok ())\n ;;\n\n let strict_add_exn t k = Or_error.ok_exn (strict_add t k)\n let remove = Hashtbl.remove\n\n let strict_remove t k =\n if mem t k\n then (\n remove t k;\n Result.Ok ())\n else Or_error.error \"element not in set\" k (Hashtbl.sexp_of_key t)\n ;;\n\n let strict_remove_exn t k = Or_error.ok_exn (strict_remove t k)\n let fold t ~init ~f = Hashtbl.fold t ~init ~f:(fun ~key ~data:() acc -> f acc key)\n let iter t ~f = Hashtbl.iter_keys t ~f\n let count t ~f = Container.count ~fold t ~f\n let sum m t ~f = Container.sum ~fold m t ~f\n let min_elt t ~compare = Container.min_elt ~fold t ~compare\n let max_elt t ~compare = Container.max_elt ~fold t ~compare\n let fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\n let fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\n let to_list = Hashtbl.keys\n\n let sexp_of_t sexp_of_e t =\n sexp_of_list sexp_of_e (to_list t |> List.sort ~compare:(hashable t).compare)\n ;;\n\n let to_array t =\n let len = length t in\n let index = ref (len - 1) in\n fold t ~init:[||] ~f:(fun acc key ->\n if Array.length acc = 0\n then Array.create ~len key\n else (\n index := !index - 1;\n acc.(!index) <- key;\n acc))\n ;;\n\n let exists t ~f = Hashtbl.existsi t ~f:(fun ~key ~data:() -> f key)\n let for_all t ~f = not (Hashtbl.existsi t ~f:(fun ~key ~data:() -> not (f key)))\n let equal t1 t2 = Hashtbl.equal (fun () () -> true) t1 t2\n let copy t = Hashtbl.copy t\n let filter t ~f = Hashtbl.filteri t ~f:(fun ~key ~data:() -> f key)\n let union t1 t2 = Hashtbl.merge t1 t2 ~f:(fun ~key:_ _ -> Some ())\n let diff t1 t2 = filter t1 ~f:(fun key -> not (Hashtbl.mem t2 key))\n\n let inter t1 t2 =\n let smaller, larger = if length t1 > length t2 then t2, t1 else t1, t2 in\n Hashtbl.filteri smaller ~f:(fun ~key ~data:() -> Hashtbl.mem larger key)\n ;;\n\n let filter_inplace t ~f =\n let to_remove = fold t ~init:[] ~f:(fun ac x -> if f x then ac else x :: ac) in\n List.iter to_remove ~f:(fun x -> remove t x)\n ;;\n\n let of_hashtbl_keys hashtbl = Hashtbl.map hashtbl ~f:ignore\n let to_hashtbl t ~f = Hashtbl.mapi t ~f:(fun ~key ~data:() -> f key)\nend\n\ninclude Accessors\n\nlet create ?growth_allowed ?size m = Hashtbl.create ?growth_allowed ?size m\n\nlet of_list ?growth_allowed ?size m l =\n let size =\n match size with\n | Some x -> x\n | None -> List.length l\n in\n let t = Hashtbl.create ?growth_allowed ~size m in\n List.iter l ~f:(fun k -> add t k);\n t\n;;\n\nlet t_of_sexp m e_of_sexp sexp =\n match sexp with\n | Sexp.Atom _ -> of_sexp_error \"Hash_set.t_of_sexp requires a list\" sexp\n | Sexp.List list ->\n let t = create m ~size:(List.length list) in\n List.iter list ~f:(fun sexp ->\n let e = e_of_sexp sexp in\n match strict_add t e with\n | Ok () -> ()\n | Error _ -> of_sexp_error \"Hash_set.t_of_sexp got a duplicate element\" sexp);\n t\n;;\n\nmodule Creators (Elt : sig\n type 'a t\n\n val hashable : 'a t Hashable.t\n end) : sig\n type 'a t_ = 'a Elt.t t\n\n val t_of_sexp : (Sexp.t -> 'a Elt.t) -> Sexp.t -> 'a t_\n\n include\n Creators_generic\n with type 'a t := 'a t_\n with type 'a elt := 'a Elt.t\n with type ('elt, 'z) create_options :=\n ('elt, 'z) create_options_without_first_class_module\nend = struct\n type 'a t_ = 'a Elt.t t\n\n let create ?growth_allowed ?size () =\n create ?growth_allowed ?size (Hashable.to_key Elt.hashable)\n ;;\n\n let of_list ?growth_allowed ?size l =\n of_list ?growth_allowed ?size (Hashable.to_key Elt.hashable) l\n ;;\n\n let t_of_sexp e_of_sexp sexp = t_of_sexp (Hashable.to_key Elt.hashable) e_of_sexp sexp\nend\n\nmodule Poly = struct\n type 'a t = 'a hash_set\n type 'a elt = 'a\n\n let hashable = poly_hashable\n\n include Creators (struct\n type 'a t = 'a\n\n let hashable = hashable\n end)\n\n include Accessors\n\n let sexp_of_t = sexp_of_t\nend\n\nmodule M (Elt : T.T) = struct\n type nonrec t = Elt.t t\nend\n\nmodule type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\nend\n\nmodule type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Hashtbl_intf.Key.S with type t := t\nend\n\nlet sexp_of_m__t (type elt) (module Elt : Sexp_of_m with type t = elt) t =\n sexp_of_t Elt.sexp_of_t t\n;;\n\nlet m__t_of_sexp (type elt) (module Elt : M_of_sexp with type t = elt) sexp =\n t_of_sexp (module Elt) Elt.t_of_sexp sexp\n;;\n\nmodule Private = struct\n let hashable = Hashtbl.Private.hashable\nend\n","open! Import\nopen! Printf\nmodule Bytes = Bytes0\ninclude Float0\n\nlet raise_s = Error.raise_s\n\nmodule T = struct\n type t = float [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_float\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_float in\n fun x -> func x\n ;;\n\n let t_of_sexp = (float_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_float : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"float\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ float_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"float.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare = Float_replace_polymorphic_compare.compare\nend\n\ninclude T\ninclude Comparator.Make (T)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen Float_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet to_float x = x\nlet of_float x = x\n\nlet of_string s =\n try float_of_string s with\n | _ -> invalid_argf \"Float.of_string %s\" s ()\n;;\n\nexternal format_float : string -> float -> string = \"caml_format_float\"\n\n(* Stolen from [pervasives.ml]. Adds a \".\" at the end if needed. It is in\n [pervasives.mli], but it also says not to use it directly, so we copy and paste the\n code. It makes the assumption on the string passed in argument that it was returned by\n [format_float]. *)\nlet valid_float_lexem s =\n let l = String.length s in\n let rec loop i =\n if Int_replace_polymorphic_compare.( >= ) i l\n then s ^ \".\"\n else (\n match s.[i] with\n | '0' .. '9' | '-' -> loop (i + 1)\n | _ -> s)\n in\n loop 0\n;;\n\n(* Let [y] be a power of 2. Then the next representable float is:\n [z = y * (1 + 2 ** -52)]\n and the previous one is\n [x = y * (1 - 2 ** -53)]\n\n In general, every two adjacent floats are within a factor of between [1 + 2**-53]\n and [1 + 2**-52] from each other, that is within [1 + 1.1e-16] and [1 + 2.3e-16].\n\n So if the decimal representation of a float starts with \"1\", then its adjacent floats\n will usually differ from it by 1, and sometimes by 2, at the 17th significant digit\n (counting from 1).\n\n On the other hand, if the decimal representation starts with \"9\", then the adjacent\n floats will be off by no more than 23 at the 16th and 17th significant digits.\n\n E.g.:\n\n {v\n # sprintf \"%.17g\" (1024. *. (1. -. 2.** (-53.)));;\n 11111111\n 1234 5678901234567\n - : string = \"1023.9999999999999\"\n v}\n Printing a couple of extra digits reveals that the difference indeed is roughly 11 at\n digits 17th and 18th (that is, 13th and 14th after \".\"):\n\n {v\n # sprintf \"%.19g\" (1024. *. (1. -. 2.** (-53.)));;\n 1111111111\n 1234 567890123456789\n - : string = \"1023.999999999999886\"\n v}\n\n The ulp (the difference between adjacent floats) is twice as big on the other side of\n 1024.:\n\n {v\n # sprintf \"%.19g\" (1024. *. (1. +. 2.** (-52.)));;\n 1111111111\n 1234 567890123456789\n - : string = \"1024.000000000000227\"\n v}\n\n Now take a power of 2 which starts with 99:\n\n {v\n # 2.**93. ;;\n 1111111111\n 1 23456789012345678\n - : float = 9.9035203142830422e+27\n\n # 2.**93. *. (1. +. 2.** (-52.));;\n - : float = 9.9035203142830444e+27\n\n # 2.**93. *. (1. -. 2.** (-53.));;\n - : float = 9.9035203142830411e+27\n v}\n\n The difference between 2**93 and its two neighbors is slightly more than, respectively,\n 1 and 2 at significant digit 16.\n\n Those examples show that:\n - 17 significant digits is always sufficient to represent a float without ambiguity\n - 15th significant digit can always be represented accurately\n - converting a decimal number with 16 significant digits to its nearest float and back\n can change the last decimal digit by no more than 1\n\n To make sure that floats obtained by conversion from decimal fractions (e.g. \"3.14\")\n are printed without trailing non-zero digits, one should choose the first among the\n '%.15g', '%.16g', and '%.17g' representations which does round-trip:\n\n {v\n # sprintf \"%.15g\" 3.14;;\n - : string = \"3.14\" (* pick this one *)\n # sprintf \"%.16g\" 3.14;;\n - : string = \"3.14\"\n # sprintf \"%.17g\" 3.14;;\n - : string = \"3.1400000000000001\" (* do not pick this one *)\n\n # sprintf \"%.15g\" 8.000000000000002;;\n - : string = \"8\" (* do not pick this one--does not round-trip *)\n # sprintf \"%.16g\" 8.000000000000002;;\n - : string = \"8.000000000000002\" (* prefer this one *)\n # sprintf \"%.17g\" 8.000000000000002;;\n - : string = \"8.0000000000000018\" (* this one has one digit of junk at the end *)\n v}\n\n Skipping the '%.16g' in the above procedure saves us some time, but it means that, as\n seen in the second example above, occasionally numbers with exactly 16 significant\n digits will have an error introduced at the 17th digit. That is probably OK for\n typical use, because a number with 16 significant digits is \"ugly\" already. Adding one\n more doesn't make it much worse for a human reader.\n\n On the other hand, we cannot skip '%.15g' and only look at '%.16g' and '%.17g', since\n the inaccuracy at the 16th digit might introduce the noise we want to avoid:\n\n {v\n # sprintf \"%.15g\" 9.992;;\n - : string = \"9.992\" (* pick this one *)\n # sprintf \"%.16g\" 9.992;;\n - : string = \"9.992000000000001\" (* do not pick this one--junk at the end *)\n # sprintf \"%.17g\" 9.992;;\n - : string = \"9.9920000000000009\"\n v}\n*)\nlet to_string x =\n valid_float_lexem\n (let y = format_float \"%.15g\" x in\n if float_of_string y = x then y else format_float \"%.17g\" x)\n;;\n\nlet max_value = infinity\nlet min_value = neg_infinity\nlet min_positive_subnormal_value = 2. ** -1074.\nlet min_positive_normal_value = 2. ** -1022.\nlet zero = 0.\nlet one = 1.\nlet minus_one = -1.\nlet pi = 0x3.243F6A8885A308D313198A2E037073\nlet sqrt_pi = 0x1.C5BF891B4EF6AA79C3B0520D5DB938\nlet sqrt_2pi = 0x2.81B263FEC4E0B2CAF9483F5CE459DC\nlet euler = 0x0.93C467E37DB0C7A4D1BE3F810152CB\nlet of_int = Int.to_float\nlet to_int = Int.of_float\nlet of_int63 i = Int63.to_float i\nlet of_int64 i = Caml.Int64.to_float i\nlet to_int64 = Caml.Int64.of_float\nlet iround_lbound = lower_bound_for_int Int.num_bits\nlet iround_ubound = upper_bound_for_int Int.num_bits\n\n(* The performance of the \"exn\" rounding functions is important, so they are written\n out separately, and tuned individually. (We could have the option versions call\n the \"exn\" versions, but that imposes arguably gratuitous overhead---especially\n in the case where the capture of backtraces is enabled upon \"with\"---and that seems\n not worth it when compared to the relatively small amount of code duplication.) *)\n\n(* Error reporting below is very carefully arranged so that, e.g., [iround_nearest_exn]\n itself can be inlined into callers such that they don't need to allocate a box for the\n [float] argument. This is done with a box [box] function carefully chosen to allow the\n compiler to create a separate box for the float only in error cases. See, e.g.,\n [../../zero/test/price_test.ml] for a mechanical test of this property when building\n with [X_LIBRARY_INLINING=true]. *)\n\nlet iround_up t =\n if t > 0.0\n then (\n let t' = ceil t in\n if t' <= iround_ubound then Some (Int.of_float_unchecked t') else None)\n else if t >= iround_lbound\n then Some (Int.of_float_unchecked t)\n else None\n;;\n\nlet[@ocaml.inline always] iround_up_exn t =\n if t > 0.0\n then (\n let t' = ceil t in\n if t' <= iround_ubound\n then Int.of_float_unchecked t'\n else invalid_argf \"Float.iround_up_exn: argument (%f) is too large\" (box t) ())\n else if t >= iround_lbound\n then Int.of_float_unchecked t\n else invalid_argf \"Float.iround_up_exn: argument (%f) is too small or NaN\" (box t) ()\n;;\n\nlet iround_down t =\n if t >= 0.0\n then if t <= iround_ubound then Some (Int.of_float_unchecked t) else None\n else (\n let t' = floor t in\n if t' >= iround_lbound then Some (Int.of_float_unchecked t') else None)\n;;\n\nlet[@ocaml.inline always] iround_down_exn t =\n if t >= 0.0\n then\n if t <= iround_ubound\n then Int.of_float_unchecked t\n else invalid_argf \"Float.iround_down_exn: argument (%f) is too large\" (box t) ()\n else (\n let t' = floor t in\n if t' >= iround_lbound\n then Int.of_float_unchecked t'\n else\n invalid_argf \"Float.iround_down_exn: argument (%f) is too small or NaN\" (box t) ())\n;;\n\nlet iround_towards_zero t =\n if t >= iround_lbound && t <= iround_ubound\n then Some (Int.of_float_unchecked t)\n else None\n;;\n\nlet[@ocaml.inline always] iround_towards_zero_exn t =\n if t >= iround_lbound && t <= iround_ubound\n then Int.of_float_unchecked t\n else\n invalid_argf\n \"Float.iround_towards_zero_exn: argument (%f) is out of range or NaN\"\n (box t)\n ()\n;;\n\n(* Outside of the range (round_nearest_lb..round_nearest_ub), all representable doubles\n are integers in the mathematical sense, and [round_nearest] should be identity.\n\n However, for odd numbers with the absolute value between 2**52 and 2**53, the formula\n [round_nearest x = floor (x + 0.5)] does not hold:\n\n {v\n # let naive_round_nearest x = floor (x +. 0.5);;\n # let x = 2. ** 52. +. 1.;;\n val x : float = 4503599627370497.\n # naive_round_nearest x;;\n - : float = 4503599627370498.\n v}\n*)\n\nlet round_nearest_lb = -.(2. ** 52.)\nlet round_nearest_ub = 2. ** 52.\n\n(* For [x = one_ulp `Down 0.5], the formula [floor (x +. 0.5)] for rounding to nearest\n does not work, because the exact result is halfway between [one_ulp `Down 1.] and [1.],\n and it gets rounded up to [1.] due to the round-ties-to-even rule. *)\nlet one_ulp_less_than_half = one_ulp `Down 0.5\n\nlet add_half_for_round_nearest t =\n t\n +.\n if t = one_ulp_less_than_half\n then one_ulp_less_than_half (* since t < 0.5, make sure the result is < 1.0 *)\n else 0.5\n;;\n\nlet iround_nearest_32 t =\n if t >= 0.\n then (\n let t' = add_half_for_round_nearest t in\n if t' <= iround_ubound then Some (Int.of_float_unchecked t') else None)\n else (\n let t' = floor (t +. 0.5) in\n if t' >= iround_lbound then Some (Int.of_float_unchecked t') else None)\n;;\n\nlet iround_nearest_64 t =\n if t >= 0.\n then\n if t < round_nearest_ub\n then Some (Int.of_float_unchecked (add_half_for_round_nearest t))\n else if t <= iround_ubound\n then Some (Int.of_float_unchecked t)\n else None\n else if t > round_nearest_lb\n then Some (Int.of_float_unchecked (floor (t +. 0.5)))\n else if t >= iround_lbound\n then Some (Int.of_float_unchecked t)\n else None\n;;\n\nlet iround_nearest =\n match Word_size.word_size with\n | W64 -> iround_nearest_64\n | W32 -> iround_nearest_32\n;;\n\nlet iround_nearest_exn_32 t =\n if t >= 0.\n then (\n let t' = add_half_for_round_nearest t in\n if t' <= iround_ubound\n then Int.of_float_unchecked t'\n else invalid_argf \"Float.iround_nearest_exn: argument (%f) is too large\" (box t) ())\n else (\n let t' = floor (t +. 0.5) in\n if t' >= iround_lbound\n then Int.of_float_unchecked t'\n else invalid_argf \"Float.iround_nearest_exn: argument (%f) is too small\" (box t) ())\n;;\n\nlet[@ocaml.inline always] iround_nearest_exn_64 t =\n if t >= 0.\n then\n if t < round_nearest_ub\n then Int.of_float_unchecked (add_half_for_round_nearest t)\n else if t <= iround_ubound\n then Int.of_float_unchecked t\n else invalid_argf \"Float.iround_nearest_exn: argument (%f) is too large\" (box t) ()\n else if t > round_nearest_lb\n then Int.of_float_unchecked (floor (t +. 0.5))\n else if t >= iround_lbound\n then Int.of_float_unchecked t\n else\n invalid_argf \"Float.iround_nearest_exn: argument (%f) is too small or NaN\" (box t) ()\n;;\n\nlet iround_nearest_exn =\n match Word_size.word_size with\n | W64 -> iround_nearest_exn_64\n | W32 -> iround_nearest_exn_32\n;;\n\n(* The following [iround_exn] and [iround] functions are slower than the ones above.\n Their equivalence to those functions is tested in the unit tests below. *)\n\nlet[@inline] iround_exn ?(dir = `Nearest) t =\n match dir with\n | `Zero -> iround_towards_zero_exn t\n | `Nearest -> iround_nearest_exn t\n | `Up -> iround_up_exn t\n | `Down -> iround_down_exn t\n;;\n\nlet iround ?(dir = `Nearest) t =\n try Some (iround_exn ~dir t) with\n | _ -> None\n;;\n\nlet is_inf x =\n match classify_float x with\n | FP_infinite -> true\n | _ -> false\n;;\n\nlet min_inan (x : t) y =\n if is_nan y then x else if is_nan x then y else if x < y then x else y\n;;\n\nlet max_inan (x : t) y =\n if is_nan y then x else if is_nan x then y else if x > y then x else y\n;;\n\nlet add = ( +. )\nlet sub = ( -. )\nlet neg = ( ~-. )\nlet abs = abs_float\nlet scale = ( *. )\nlet square x = x *. x\n\nmodule Parts : sig\n type t\n\n val fractional : t -> float\n val integral : t -> float\n val modf : float -> t\nend = struct\n type t = float * float\n\n let fractional t = fst t\n let integral t = snd t\n let modf = modf\nend\n\nlet modf = Parts.modf\nlet round_down = floor\nlet round_up = ceil\nlet round_towards_zero t = if t >= 0. then round_down t else round_up t\n\n(* see the comment above [round_nearest_lb] and [round_nearest_ub] for an explanation *)\nlet round_nearest t =\n if t > round_nearest_lb && t < round_nearest_ub\n then floor (add_half_for_round_nearest t)\n else t +. 0.\n;;\n\nlet round_nearest_half_to_even t =\n if t <= round_nearest_lb || t >= round_nearest_ub\n then t +. 0.\n else (\n let floor = floor t in\n (* [ceil_or_succ = if t is an integer then t +. 1. else ceil t]. Faster than [ceil]. *)\n let ceil_or_succ = floor +. 1. in\n let diff_floor = t -. floor in\n let diff_ceil = ceil_or_succ -. t in\n if diff_floor < diff_ceil\n then floor\n else if diff_floor > diff_ceil\n then ceil_or_succ\n else if (* exact tie, pick the even *)\n mod_float floor 2. = 0.\n then floor\n else ceil_or_succ)\n;;\n\nlet int63_round_lbound = lower_bound_for_int Int63.num_bits\nlet int63_round_ubound = upper_bound_for_int Int63.num_bits\n\nlet int63_round_up_exn t =\n if t > 0.0\n then (\n let t' = ceil t in\n if t' <= int63_round_ubound\n then Int63.of_float_unchecked t'\n else\n invalid_argf\n \"Float.int63_round_up_exn: argument (%f) is too large\"\n (Float0.box t)\n ())\n else if t >= int63_round_lbound\n then Int63.of_float_unchecked t\n else\n invalid_argf\n \"Float.int63_round_up_exn: argument (%f) is too small or NaN\"\n (Float0.box t)\n ()\n;;\n\nlet int63_round_down_exn t =\n if t >= 0.0\n then\n if t <= int63_round_ubound\n then Int63.of_float_unchecked t\n else\n invalid_argf\n \"Float.int63_round_down_exn: argument (%f) is too large\"\n (Float0.box t)\n ()\n else (\n let t' = floor t in\n if t' >= int63_round_lbound\n then Int63.of_float_unchecked t'\n else\n invalid_argf\n \"Float.int63_round_down_exn: argument (%f) is too small or NaN\"\n (Float0.box t)\n ())\n;;\n\nlet int63_round_nearest_portable_alloc_exn t0 =\n let t = round_nearest t0 in\n if t > 0.\n then\n if t <= int63_round_ubound\n then Int63.of_float_unchecked t\n else\n invalid_argf\n \"Float.int63_round_nearest_portable_alloc_exn: argument (%f) is too large\"\n (box t0)\n ()\n else if t >= int63_round_lbound\n then Int63.of_float_unchecked t\n else\n invalid_argf\n \"Float.int63_round_nearest_portable_alloc_exn: argument (%f) is too small or NaN\"\n (box t0)\n ()\n;;\n\nlet int63_round_nearest_arch64_noalloc_exn f = Int63.of_int (iround_nearest_exn f)\n\nlet int63_round_nearest_exn =\n match Word_size.word_size with\n | W64 -> int63_round_nearest_arch64_noalloc_exn\n | W32 -> int63_round_nearest_portable_alloc_exn\n;;\n\nlet round ?(dir = `Nearest) t =\n match dir with\n | `Nearest -> round_nearest t\n | `Down -> round_down t\n | `Up -> round_up t\n | `Zero -> round_towards_zero t\n;;\n\nmodule Class = struct\n type t =\n | Infinite\n | Nan\n | Normal\n | Subnormal\n | Zero\n [@@deriving_inline compare, enumerate, sexp]\n\n let compare = (Ppx_compare_lib.polymorphic_compare : t -> t -> int)\n let all = ([ Infinite; Nan; Normal; Subnormal; Zero ] : t list)\n\n let t_of_sexp =\n (let _tp_loc = \"float.ml.Class.t\" in\n function\n | Ppx_sexp_conv_lib.Sexp.Atom (\"infinite\" | \"Infinite\") -> Infinite\n | Ppx_sexp_conv_lib.Sexp.Atom (\"nan\" | \"Nan\") -> Nan\n | Ppx_sexp_conv_lib.Sexp.Atom (\"normal\" | \"Normal\") -> Normal\n | Ppx_sexp_conv_lib.Sexp.Atom (\"subnormal\" | \"Subnormal\") -> Subnormal\n | Ppx_sexp_conv_lib.Sexp.Atom (\"zero\" | \"Zero\") -> Zero\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"infinite\" | \"Infinite\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"nan\" | \"Nan\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"normal\" | \"Normal\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"subnormal\" | \"Subnormal\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"zero\" | \"Zero\") :: _)\n as sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> t)\n ;;\n\n let sexp_of_t =\n (function\n | Infinite -> Ppx_sexp_conv_lib.Sexp.Atom \"Infinite\"\n | Nan -> Ppx_sexp_conv_lib.Sexp.Atom \"Nan\"\n | Normal -> Ppx_sexp_conv_lib.Sexp.Atom \"Normal\"\n | Subnormal -> Ppx_sexp_conv_lib.Sexp.Atom \"Subnormal\"\n | Zero -> Ppx_sexp_conv_lib.Sexp.Atom \"Zero\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\n\n let to_string t = string_of_sexp (sexp_of_t t)\n let of_string s = t_of_sexp (sexp_of_string s)\nend\n\nlet classify t =\n let module C = Class in\n match classify_float t with\n | FP_normal -> C.Normal\n | FP_subnormal -> C.Subnormal\n | FP_zero -> C.Zero\n | FP_infinite -> C.Infinite\n | FP_nan -> C.Nan\n;;\n\nlet is_finite t = not (t = infinity || t = neg_infinity || is_nan t)\n\nlet insert_underscores ?(delimiter = '_') ?(strip_zero = false) string =\n match String.lsplit2 string ~on:'.' with\n | None -> Int_conversions.insert_delimiter string ~delimiter\n | Some (left, right) ->\n let left = Int_conversions.insert_delimiter left ~delimiter in\n let right =\n if strip_zero then String.rstrip right ~drop:(fun c -> Char.( = ) c '0') else right\n in\n (match right with\n | \"\" -> left\n | _ -> left ^ \".\" ^ right)\n;;\n\nlet to_string_hum ?delimiter ?(decimals = 3) ?strip_zero f =\n if Int_replace_polymorphic_compare.( < ) decimals 0\n then invalid_argf \"to_string_hum: invalid argument ~decimals=%d\" decimals ();\n match classify f with\n | Class.Infinite -> if f > 0. then \"inf\" else \"-inf\"\n | Class.Nan -> \"nan\"\n | Class.Normal | Class.Subnormal | Class.Zero ->\n insert_underscores (sprintf \"%.*f\" decimals f) ?delimiter ?strip_zero\n;;\n\nlet sexp_of_t t =\n let sexp = sexp_of_t t in\n match !Sexp.of_float_style with\n | `No_underscores -> sexp\n | `Underscores ->\n (match sexp with\n | List _ ->\n raise_s\n (Sexp.message\n \"[sexp_of_float] produced strange sexp\"\n [ \"sexp\", Sexp.sexp_of_t sexp ])\n | Atom string ->\n if String.contains string 'E' then sexp else Atom (insert_underscores string))\n;;\n\nlet to_padded_compact_string_custom t ?(prefix = \"\") ~kilo ~mega ~giga ~tera ?peta () =\n (* Round a ratio toward the nearest integer, resolving ties toward the nearest even\n number. For sane inputs (in particular, when [denominator] is an integer and\n [abs numerator < 2e52]) this should be accurate. Otherwise, the result might be a\n little bit off, but we don't really use that case. *)\n let iround_ratio_exn ~numerator ~denominator =\n let k = floor (numerator /. denominator) in\n (* if [abs k < 2e53], then both [k] and [k +. 1.] are accurately represented, and in\n particular [k +. 1. > k]. If [denominator] is also an integer, and\n [abs (denominator *. (k +. 1)) < 2e53] (and in some other cases, too), then [lower]\n and [higher] are actually both accurate. Since (roughly)\n [numerator = denominator *. k] then for [abs numerator < 2e52] we should be\n fine. *)\n let lower = denominator *. k in\n let higher = denominator *. (k +. 1.) in\n (* Subtracting numbers within a factor of two from each other is accurate.\n So either the two subtractions below are accurate, or k = 0, or k = -1.\n In case of a tie, round to even. *)\n let diff_right = higher -. numerator in\n let diff_left = numerator -. lower in\n let k = iround_nearest_exn k in\n if diff_right < diff_left\n then k + 1\n else if diff_right > diff_left\n then k\n else if (* a tie *)\n Int_replace_polymorphic_compare.( = ) (k mod 2) 0\n then k\n else k + 1\n in\n match classify t with\n | Class.Infinite -> if t < 0.0 then \"-inf \" else \"inf \"\n | Class.Nan -> \"nan \"\n | Class.Subnormal | Class.Normal | Class.Zero ->\n let go t =\n let conv_one t =\n assert (0. <= t && t < 999.95);\n let x = prefix ^ format_float \"%.1f\" t in\n (* Fix the \".0\" suffix *)\n if String.is_suffix x ~suffix:\".0\"\n then (\n let x = Bytes.of_string x in\n let n = Bytes.length x in\n Bytes.set x (n - 1) ' ';\n Bytes.set x (n - 2) ' ';\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:x)\n else x\n in\n let conv mag t denominator =\n assert (\n (denominator = 100. && t >= 999.95)\n || (denominator >= 100_000. && t >= round_nearest (denominator *. 9.999_5)));\n assert (t < round_nearest (denominator *. 9_999.5));\n let i, d =\n let k = iround_ratio_exn ~numerator:t ~denominator in\n (* [mod] is okay here because we know i >= 0. *)\n k / 10, k mod 10\n in\n let open Int_replace_polymorphic_compare in\n assert (0 <= i && i < 1000);\n assert (0 <= d && d < 10);\n if d = 0\n then sprintf \"%s%d%s \" prefix i mag\n else sprintf \"%s%d%s%d\" prefix i mag d\n in\n (* While the standard metric prefixes (e.g. capital \"M\" rather than \"m\", [1]) are\n nominally more correct, this hinders readability in our case. E.g., 10G6 and\n 1066 look too similar. That's an extreme example, but in general k,m,g,t,p\n probably stand out better than K,M,G,T,P when interspersed with digits.\n\n [1] http://en.wikipedia.org/wiki/Metric_prefix *)\n (* The trick here is that:\n - the first boundary (999.95) as a float is slightly over-represented (so it is\n better approximated as \"1k\" than as \"999.9\"),\n - the other boundaries are accurately represented, because they are integers.\n That's why the strict equalities below do exactly what we want. *)\n if t < 999.95E0\n then conv_one t\n else if t < 999.95E3\n then conv kilo t 100.\n else if t < 999.95E6\n then conv mega t 100_000.\n else if t < 999.95E9\n then conv giga t 100_000_000.\n else if t < 999.95E12\n then conv tera t 100_000_000_000.\n else (\n match peta with\n | None -> sprintf \"%s%.1e\" prefix t\n | Some peta ->\n if t < 999.95E15\n then conv peta t 100_000_000_000_000.\n else sprintf \"%s%.1e\" prefix t)\n in\n if t >= 0. then go t else \"-\" ^ go ~-.t\n;;\n\nlet to_padded_compact_string t =\n to_padded_compact_string_custom t ~kilo:\"k\" ~mega:\"m\" ~giga:\"g\" ~tera:\"t\" ~peta:\"p\" ()\n;;\n\n(* Performance note: Initializing the accumulator to 1 results in one extra\n multiply; e.g., to compute x ** 4, we in principle only need 2 multiplies,\n but this function will have 3 multiplies. However, attempts to avoid this\n (like decrementing n and initializing accum to be x, or handling small\n exponents as a special case) have not yielded anything that is a net\n improvement.\n*)\nlet int_pow x n =\n let open Int_replace_polymorphic_compare in\n if n = 0\n then 1.\n else (\n (* Using [x +. (-0.)] on the following line convinces the compiler to avoid a certain\n boxing (that would result in allocation in each iteration). Soon, the compiler\n shouldn't need this \"hint\" to avoid the boxing. The reason we add -0 rather than 0\n is that [x +. (-0.)] is apparently always the same as [x], whereas [x +. 0.] is\n not, in that it sends [-0.] to [0.]. This makes a difference because we want\n [int_pow (-0.) (-1)] to return neg_infinity just like [-0. ** -1.] would. *)\n let x = ref (x +. -0.) in\n let n = ref n in\n let accum = ref 1. in\n if !n < 0\n then (\n (* x ** n = (1/x) ** -n *)\n x := 1. /. !x;\n n := ~- (!n);\n if !n < 0\n then (\n (* n must have been min_int, so it is now so big that it has wrapped around.\n We decrement it so that it looks positive again, but accordingly have\n to put an extra factor of x in the accumulator.\n *)\n accum := !x;\n decr n));\n (* Letting [a] denote (the original value of) [x ** n], we maintain\n the invariant that [(x ** n) *. accum = a]. *)\n while !n > 1 do\n if !n land 1 <> 0 then accum := !x *. !accum;\n x := !x *. !x;\n n := !n lsr 1\n done;\n (* n is necessarily 1 at this point, so there is one additional\n multiplication by x. *)\n !x *. !accum)\n;;\n\nlet round_gen x ~how =\n if x = 0.\n then 0.\n else if not (is_finite x)\n then x\n else (\n (* Significant digits and decimal digits. *)\n let sd, dd =\n match how with\n | `significant_digits sd ->\n let dd = sd - to_int (round_up (log10 (abs x))) in\n sd, dd\n | `decimal_digits dd ->\n let sd = dd + to_int (round_up (log10 (abs x))) in\n sd, dd\n in\n let open Int_replace_polymorphic_compare in\n if sd < 0\n then 0.\n else if sd >= 17\n then x\n else (\n (* Choose the order that is exactly representable as a float. Small positive\n integers are, but their inverses in most cases are not. *)\n let abs_dd = Int.abs dd in\n if abs_dd > 22 || sd >= 16\n (* 10**22 is exactly representable as a float, but 10**23 is not, so use the slow\n path. Similarly, if we need 16 significant digits in the result, then the integer\n [round_nearest (x order)] might not be exactly representable as a float, since\n for some ranges we only have 15 digits of precision guaranteed.\n\n That said, we are still rounding twice here:\n\n 1) first time when rounding [x *. order] or [x /. order] to the nearest float\n (just the normal way floating-point multiplication or division works),\n\n 2) second time when applying [round_nearest_half_to_even] to the result of the\n above operation\n\n So for arguments within an ulp from a tie we might still produce an off-by-one\n result. *)\n then of_string (sprintf \"%.*g\" sd x)\n else (\n let order = int_pow 10. abs_dd in\n if dd >= 0\n then round_nearest_half_to_even (x *. order) /. order\n else round_nearest_half_to_even (x /. order) *. order)))\n;;\n\nlet round_significant x ~significant_digits =\n if Int_replace_polymorphic_compare.( <= ) significant_digits 0\n then\n invalid_argf\n \"Float.round_significant: invalid argument significant_digits:%d\"\n significant_digits\n ()\n else round_gen x ~how:(`significant_digits significant_digits)\n;;\n\nlet round_decimal x ~decimal_digits = round_gen x ~how:(`decimal_digits decimal_digits)\nlet between t ~low ~high = low <= t && t <= high\n\nlet clamp_exn t ~min ~max =\n (* Also fails if [min] or [max] is nan *)\n assert (min <= max);\n (* clamp_unchecked is in float0.ml *)\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n (* Also fails if [min] or [max] is nan *)\n if min <= max\n then Ok (clamp_unchecked t ~min ~max)\n else\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n;;\n\nlet ( + ) = ( +. )\nlet ( - ) = ( -. )\nlet ( * ) = ( *. )\nlet ( ** ) = ( ** )\nlet ( / ) = ( /. )\nlet ( ~- ) = ( ~-. )\n\nlet sign_exn t : Sign.t =\n if t > 0.\n then Pos\n else if t < 0.\n then Neg\n else if t = 0.\n then Zero\n else Error.raise_s (Sexp.message \"Float.sign_exn of NAN\" [ \"\", sexp_of_t t ])\n;;\n\nlet sign_or_nan t : Sign_or_nan.t =\n if t > 0. then Pos else if t < 0. then Neg else if t = 0. then Zero else Nan\n;;\n\nlet ieee_negative t =\n let bits = Caml.Int64.bits_of_float t in\n Poly.(bits < Caml.Int64.zero)\n;;\n\nlet exponent_bits = 11\nlet mantissa_bits = 52\nlet exponent_mask64 = Int64.(shift_left one exponent_bits - one)\nlet exponent_mask = Int64.to_int_exn exponent_mask64\nlet mantissa_mask = Int63.(shift_left one mantissa_bits - one)\nlet mantissa_mask64 = Int63.to_int64 mantissa_mask\n\nlet ieee_exponent t =\n let bits = Caml.Int64.bits_of_float t in\n Int64.(bit_and (shift_right_logical bits mantissa_bits) exponent_mask64)\n |> Caml.Int64.to_int\n;;\n\nlet ieee_mantissa t =\n let bits = Caml.Int64.bits_of_float t in\n Int63.of_int64_exn Caml.Int64.(logand bits mantissa_mask64)\n;;\n\nlet create_ieee_exn ~negative ~exponent ~mantissa =\n if Int.(bit_and exponent exponent_mask <> exponent)\n then failwithf \"exponent %d out of range [0, %d]\" exponent exponent_mask ()\n else if Int63.(bit_and mantissa mantissa_mask <> mantissa)\n then\n failwithf\n \"mantissa %s out of range [0, %s]\"\n (Int63.to_string mantissa)\n (Int63.to_string mantissa_mask)\n ()\n else (\n let sign_bits = if negative then Caml.Int64.min_int else Caml.Int64.zero in\n let expt_bits = Caml.Int64.shift_left (Caml.Int64.of_int exponent) mantissa_bits in\n let mant_bits = Int63.to_int64 mantissa in\n let bits = Caml.Int64.(logor sign_bits (logor expt_bits mant_bits)) in\n Caml.Int64.float_of_bits bits)\n;;\n\nlet create_ieee ~negative ~exponent ~mantissa =\n Or_error.try_with (fun () -> create_ieee_exn ~negative ~exponent ~mantissa)\n;;\n\nmodule Terse = struct\n type nonrec t = t\n\n let t_of_sexp = t_of_sexp\n let to_string x = Printf.sprintf \"%.8G\" x\n let sexp_of_t x = Sexp.Atom (to_string x)\n let of_string x = of_string x\nend\n\nlet validate_ordinary t =\n Validate.of_error_opt\n (let module C = Class in\n match classify t with\n | C.Normal | C.Subnormal | C.Zero -> None\n | C.Infinite -> Some \"value is infinite\"\n | C.Nan -> Some \"value is NaN\")\n;;\n\nmodule V = struct\n module ZZ = Comparable.Validate (T)\n\n let validate_bound ~min ~max t =\n Validate.first_failure (validate_ordinary t) (ZZ.validate_bound t ~min ~max)\n ;;\n\n let validate_lbound ~min t =\n Validate.first_failure (validate_ordinary t) (ZZ.validate_lbound t ~min)\n ;;\n\n let validate_ubound ~max t =\n Validate.first_failure (validate_ordinary t) (ZZ.validate_ubound t ~max)\n ;;\nend\n\ninclude V\n\ninclude Comparable.With_zero (struct\n include T\n\n let zero = zero\n\n include V\n end)\n\n(* These are partly here as a performance hack to avoid some boxing we're getting with\n the versions we get from [With_zero]. They also make [Float.is_negative nan] and\n [Float.is_non_positive nan] return [false]; the versions we get from [With_zero] return\n [true]. *)\nlet is_positive t = t > 0.\nlet is_non_negative t = t >= 0.\nlet is_negative t = t < 0.\nlet is_non_positive t = t <= 0.\n\ninclude Pretty_printer.Register (struct\n include T\n\n let module_name = \"Base.Float\"\n let to_string = to_string\n end)\n\nmodule O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Float_replace_polymorphic_compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int = of_int\n let of_float x = x\nend\n\nmodule O_dot = struct\n let ( *. ) = ( * )\n let ( +. ) = ( + )\n let ( -. ) = ( - )\n let ( /. ) = ( / )\n let ( ~-. ) = ( ~- )\n let ( **. ) = ( ** )\nend\n\nmodule Private = struct\n let box = box\n let clamp_unchecked = clamp_unchecked\n let lower_bound_for_int = lower_bound_for_int\n let upper_bound_for_int = upper_bound_for_int\n let specialized_hash = hash_float\n let one_ulp_less_than_half = one_ulp_less_than_half\n let int63_round_nearest_portable_alloc_exn = int63_round_nearest_portable_alloc_exn\n let int63_round_nearest_arch64_noalloc_exn = int63_round_nearest_arch64_noalloc_exn\n let iround_nearest_exn_64 = iround_nearest_exn_64\nend\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Float_replace_polymorphic_compare\n\n(* These functions specifically replace defaults in replace_polymorphic_compare.\n\n The desired behavior here is to propagate a nan if either argument is nan. Because the\n first comparison will always return false if either argument is nan, it suffices to\n check if x is nan. Then, when x is nan or both x and y are nan, we return x = nan; and\n when y is nan but not x, we return y = nan.\n\n There are various ways to implement these functions. The benchmark below shows a few\n different versions. This benchmark was run over an array of random floats (none of\n which are nan).\n\n ┌────────────────────────────────────────────────┬──────────┐\n │ Name │ Time/Run │\n ├────────────────────────────────────────────────┼──────────┤\n │ if is_nan x then x else if x < y then x else y │ 2.42us │\n │ if is_nan x || x < y then x else y │ 2.02us │\n │ if x < y || is_nan x then x else y │ 1.88us │\n └────────────────────────────────────────────────┴──────────┘\n\n The benchmark below was run when x > y is always true (again, no nan values).\n\n ┌────────────────────────────────────────────────┬──────────┐\n │ Name │ Time/Run │\n ├────────────────────────────────────────────────┼──────────┤\n │ if is_nan x then x else if x < y then x else y │ 2.83us │\n │ if is_nan x || x < y then x else y │ 1.97us │\n │ if x < y || is_nan x then x else y │ 1.56us │\n └────────────────────────────────────────────────┴──────────┘\n*)\nlet min (x : t) y = if x < y || is_nan x then x else y\nlet max (x : t) y = if x > y || is_nan x then x else y\n","open! Import\ninclude Buffer_intf\ninclude Caml.Buffer\n\nlet contents_bytes = to_bytes\nlet add_substring t s ~pos ~len = add_substring t s pos len\nlet add_subbytes t s ~pos ~len = add_subbytes t s pos len\nlet sexp_of_t t = sexp_of_string (contents t)\n\nmodule To_bytes =\n Blit.Make_distinct\n (struct\n type nonrec t = t\n\n let length = length\n end)\n (struct\n type t = Bytes.t\n\n let create ~len = Bytes.create len\n let length = Bytes.length\n\n let unsafe_blit ~src ~src_pos ~dst ~dst_pos ~len =\n Caml.Buffer.blit src src_pos dst dst_pos len\n ;;\n end)\n\ninclude To_bytes\nmodule To_string = Blit.Make_to_string (Caml.Buffer) (To_bytes)\n","open Base\n\ntype 'a test_pred\n = ?here:Lexing.position list\n -> ?message:string\n -> ('a -> bool)\n -> 'a\n -> unit\n\ntype 'a test_eq\n = ?here:Lexing.position list\n -> ?message:string\n -> ?equal:('a -> 'a -> bool)\n -> 'a\n -> 'a\n -> unit\n\ntype 'a test_result\n = ?here:Lexing.position list\n -> ?message:string\n -> ?equal:('a -> 'a -> bool)\n -> expect:'a\n -> 'a\n -> unit\n\nexception E of string * Sexp.t [@@deriving sexp]\n\nlet failwith message sexp = raise (E (message, sexp))\n\nlet fail_in_sexp_style ~message ~pos ~here ~tag body =\n let message =\n match message with\n | None -> tag\n | Some s -> s ^ \": \" ^ tag\n in\n let sexp =\n Sexp.List (\n body\n @ [ Sexp.List [ Sexp.Atom \"Loc\"; Sexp.Atom pos ] ]\n @ begin match here with\n | [] -> []\n | _ -> [ Sexp.List [ Sexp.Atom \"Stack\"\n ; [%sexp_of: Source_code_position.t list] here\n ] ]\n end\n )\n in\n failwith message sexp\n\nlet [@cold] test_pred_failed ~message ~pos ~here ~sexpifier t =\n fail_in_sexp_style ~message ~pos ~here ~tag:\"predicate failed\" [\n Sexp.List [Sexp.Atom \"Value\"; sexpifier t]\n ]\n\nlet test_pred ~pos ~sexpifier ~here ?message predicate t =\n if not (predicate t) then\n test_pred_failed ~message ~pos ~here ~sexpifier t\n\nlet r_diff : (from_:string -> to_:string -> unit) option ref = ref None\nlet set_diff_function f = r_diff := f\n\nlet [@cold] test_result_or_eq_failed ~sexpifier ~expect ~got =\n let got = sexpifier got in\n let expect = sexpifier expect in\n begin match !r_diff with\n | None -> ()\n | Some diff ->\n let from_ = Sexp.to_string_hum expect in\n let to_ = Sexp.to_string_hum got in\n diff ~from_ ~to_\n end;\n `Fail (expect, got)\n\nlet test_result_or_eq ~sexpifier ~comparator ?equal ~expect ~got =\n let pass =\n match equal with\n | None -> comparator got expect = 0\n | Some f -> f got expect\n in\n if pass\n then `Pass\n else test_result_or_eq_failed ~sexpifier ~expect ~got\n\nlet [@cold] test_eq_failed ~message ~pos ~here ~t1 ~t2 =\n fail_in_sexp_style ~message ~pos ~here ~tag:\"comparison failed\" [\n t1;\n Sexp.Atom \"vs\";\n t2;\n ]\n\nlet test_eq ~pos ~sexpifier ~comparator ~here ?message ?equal t1 t2 =\n match test_result_or_eq ~sexpifier ~comparator ?equal ~expect:t1 ~got:t2 with\n | `Pass -> ()\n | `Fail (t1, t2) -> test_eq_failed ~message ~pos ~here ~t1 ~t2\n\nlet [@cold] test_result_failed ~message ~pos ~here ~expect ~got =\n fail_in_sexp_style ~message ~pos ~here ~tag:\"got unexpected result\" [\n Sexp.List [Sexp.Atom \"expected\"; expect];\n Sexp.List [Sexp.Atom \"got\"; got];\n ]\n\nlet test_result ~pos ~sexpifier ~comparator ~here ?message ?equal ~expect ~got =\n match test_result_or_eq ~sexpifier ~comparator ?equal ~expect ~got with\n | `Pass -> ()\n | `Fail (expect, got) -> test_result_failed ~message ~pos ~here ~expect ~got\n","type t = string\n\n(* Share the digest of the empty string *)\nlet empty = Digest.string \"\"\nlet make s =\n if s = empty then\n empty\n else\n s\n\nlet compare = compare\n\nlet length = 16\n\nlet to_binary s = s\nlet of_binary_exn s = assert (String.length s = length); make s\nlet unsafe_of_binary = make\n\nlet to_hex = Digest.to_hex\nlet of_hex_exn s = make (Digest.from_hex s)\n\nlet string s = make (Digest.string s)\n\nlet bytes s = make (Digest.bytes s)\n\nlet subbytes bytes ~pos ~len = make (Digest.subbytes bytes pos len)\n","(* Common: common definitions used by binary protocol converters *)\n\nopen Base\nopen Printf\nopen Bigarray\n\ntype pos = int [@@deriving sexp_of]\n\n(* Errors and exceptions *)\n\nexception Buffer_short\nexception No_variant_match\n\nmodule ReadError = struct\n type t =\n | Neg_int8\n | Int_code\n | Int_overflow\n | Nat0_code\n | Nat0_overflow\n | Int32_code\n | Int64_code\n | Nativeint_code\n | Unit_code\n | Bool_code\n | Option_code\n | String_too_long\n | Variant_tag\n | Array_too_long\n | List_too_long of\n { len : int\n ; max_len : int\n }\n | Hashtbl_too_long\n | Sum_tag of string\n | Variant of string\n | Poly_rec_bound of string\n | Variant_wrong_type of string\n | Silly_type of string\n | Empty_type of string\n\n let to_string = function\n | Neg_int8 -> \"Neg_int8\"\n | Int_code -> \"Int_code\"\n | Int_overflow -> \"Int_overflow\"\n | Nat0_code -> \"Nat0_code\"\n | Nat0_overflow -> \"Nat0_overflow\"\n | Int32_code -> \"Int32_code\"\n | Int64_code -> \"Int64_code\"\n | Nativeint_code -> \"Nativeint_code\"\n | Unit_code -> \"Unit_code\"\n | Bool_code -> \"Bool_code\"\n | Option_code -> \"Option_code\"\n | String_too_long -> \"String_too_long\"\n | Variant_tag -> \"Variant_tag\"\n | Array_too_long -> \"Array_too_long\"\n | List_too_long { len; max_len } -> sprintf \"List_too_long / %d (max %d)\" len max_len\n | Hashtbl_too_long -> \"Hashtbl_too_long\"\n | Sum_tag loc -> \"Sum_tag / \" ^ loc\n | Variant loc -> \"Variant / \" ^ loc\n | Poly_rec_bound loc -> \"Poly_rec_bound / \" ^ loc\n | Variant_wrong_type loc -> \"Variant_wrong_type / \" ^ loc\n | Silly_type loc -> \"Silly_type / \" ^ loc\n | Empty_type loc -> \"Empty_type / \" ^ loc\n ;;\n\n let sexp_of_t t = Sexp.Atom (to_string t)\nend\n\nexception Read_error of ReadError.t * pos [@@deriving sexp_of]\nexception Poly_rec_write of string\nexception Empty_type of string\n\nlet raise_read_error err pos = raise (Read_error (err, pos))\n\nlet raise_variant_wrong_type name pos =\n raise (Read_error (ReadError.Variant_wrong_type name, pos))\n;;\n\nlet raise_concurrent_modification loc = failwith (loc ^ \": concurrent modification\")\nlet array_bound_error () = invalid_arg \"index out of bounds\"\n\n(* Buffers *)\n\ntype pos_ref = pos ref\ntype buf = (char, int8_unsigned_elt, c_layout) Array1.t\n\nlet create_buf n = Array1.create Bigarray.char c_layout n\nlet buf_len buf = Array1.dim buf\nlet assert_pos pos = if pos < 0 then array_bound_error ()\nlet check_pos (buf : buf) pos = if pos >= Array1.dim buf then raise Buffer_short\n\nlet safe_get_pos buf pos_ref =\n let pos = !pos_ref in\n check_pos buf pos;\n pos\n;;\n\nlet check_next (buf : buf) next = if next > Array1.dim buf then raise Buffer_short\n\nlet get_opt_pos ~loc ~var = function\n | Some pos ->\n if pos < 0 then invalid_arg (sprintf \"Bin_prot.Common.%s: %s < 0\" loc var);\n pos\n | None -> 0\n;;\n\nexternal unsafe_blit_buf\n : src_pos:int\n -> src:buf\n -> dst_pos:int\n -> dst:buf\n -> len:int\n -> unit\n = \"bin_prot_blit_buf_stub\"\n\nlet blit_buf ?src_pos ~src ?dst_pos ~dst len =\n let loc = \"blit_buf\" in\n let src_pos = get_opt_pos ~loc ~var:\"src_pos\" src_pos in\n let dst_pos = get_opt_pos ~loc ~var:\"dst_pos\" dst_pos in\n if len < 0\n then invalid_arg \"Bin_prot.Common.blit_buf: len < 0\"\n else if len = 0\n then (\n if src_pos > Array1.dim src\n then invalid_arg \"Bin_prot.Common.blit_buf: src_pos > src_len\";\n if dst_pos > Array1.dim dst\n then invalid_arg \"Bin_prot.Common.blit_buf: dst_pos > dst_len\")\n else if src_pos + len > Array1.dim src\n then invalid_arg \"Bin_prot.Common.blit_buf: src_pos + len > src_len\"\n else if dst_pos + len > Array1.dim dst\n then invalid_arg \"Bin_prot.Common.blit_buf: dst_pos + len > dst_len\"\n else unsafe_blit_buf ~src_pos ~src ~dst_pos ~dst ~len\n;;\n\nexternal unsafe_blit_string_buf\n : src_pos:int\n -> string\n -> dst_pos:int\n -> buf\n -> len:int\n -> unit\n = \"bin_prot_blit_string_buf_stub\"\n[@@noalloc]\n\nexternal unsafe_blit_bytes_buf\n : src_pos:int\n -> bytes\n -> dst_pos:int\n -> buf\n -> len:int\n -> unit\n = \"bin_prot_blit_bytes_buf_stub\"\n[@@noalloc]\n\nlet blit_string_buf ?src_pos str ?dst_pos buf ~len =\n let loc = \"blit_string_buf\" in\n let src_pos = get_opt_pos ~loc ~var:\"src_pos\" src_pos in\n let dst_pos = get_opt_pos ~loc ~var:\"dst_pos\" dst_pos in\n if len < 0\n then invalid_arg \"Bin_prot.Common.blit_string_buf: len < 0\"\n else if len = 0\n then (\n if src_pos > String.length str\n then invalid_arg \"Bin_prot.Common.blit_string_buf: src_pos > str_len\";\n if dst_pos > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_string_buf: src_pos > buf\")\n else if src_pos + len > String.length str\n then invalid_arg \"Bin_prot.Common.blit_string_buf: src_pos + len > str_len\"\n else if dst_pos + len > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_string_buf: src_pos + len > buf\"\n else unsafe_blit_string_buf ~src_pos str ~dst_pos buf ~len\n;;\n\nlet blit_bytes_buf ?src_pos str ?dst_pos buf ~len =\n let loc = \"blit_bytes_buf\" in\n let src_pos = get_opt_pos ~loc ~var:\"src_pos\" src_pos in\n let dst_pos = get_opt_pos ~loc ~var:\"dst_pos\" dst_pos in\n if len < 0\n then invalid_arg \"Bin_prot.Common.blit_bytes_buf: len < 0\"\n else if len = 0\n then (\n if src_pos > Bytes.length str\n then invalid_arg \"Bin_prot.Common.blit_bytes_buf: src_pos > str_len\";\n if dst_pos > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_bytes_buf: src_pos > buf\")\n else if src_pos + len > Bytes.length str\n then invalid_arg \"Bin_prot.Common.blit_bytes_buf: src_pos + len > str_len\"\n else if dst_pos + len > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_bytes_buf: src_pos + len > buf\"\n else unsafe_blit_bytes_buf ~src_pos str ~dst_pos buf ~len\n;;\n\nexternal unsafe_blit_buf_string\n : src_pos:int\n -> buf\n -> dst_pos:int\n -> bytes\n -> len:int\n -> unit\n = \"bin_prot_blit_buf_bytes_stub\"\n[@@noalloc]\n\nexternal unsafe_blit_buf_bytes\n : src_pos:int\n -> buf\n -> dst_pos:int\n -> bytes\n -> len:int\n -> unit\n = \"bin_prot_blit_buf_bytes_stub\"\n[@@noalloc]\n\nlet blit_buf_bytes ?src_pos buf ?dst_pos str ~len =\n let loc = \"blit_buf_string\" in\n let src_pos = get_opt_pos ~loc ~var:\"src_pos\" src_pos in\n let dst_pos = get_opt_pos ~loc ~var:\"dst_pos\" dst_pos in\n if len < 0\n then invalid_arg \"Bin_prot.Common.blit_buf_string: len < 0\"\n else if len = 0\n then (\n if src_pos > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_buf_string: src_pos > buf_len\";\n if dst_pos > Bytes.length str\n then invalid_arg \"Bin_prot.Common.blit_buf_string: src_pos > str_len\")\n else if src_pos + len > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_buf_string: src_pos + len > buf_len\"\n else if dst_pos + len > Bytes.length str\n then invalid_arg \"Bin_prot.Common.blit_buf_string: src_pos + len > str_len\"\n else unsafe_blit_buf_bytes ~src_pos buf ~dst_pos str ~len\n;;\n\nlet blit_buf_string = blit_buf_bytes\n\n(* Miscellaneous *)\n\nlet rec copy_htbl_list htbl = function\n | [] -> htbl\n | (k, v) :: rest ->\n Caml.Hashtbl.add htbl k v;\n copy_htbl_list htbl rest\n;;\n\n(* Bigarrays *)\n\ntype vec32 = (float, float32_elt, fortran_layout) Array1.t\ntype vec64 = (float, float64_elt, fortran_layout) Array1.t\ntype vec = vec64\ntype mat32 = (float, float32_elt, fortran_layout) Array2.t\ntype mat64 = (float, float64_elt, fortran_layout) Array2.t\ntype mat = mat64\n\n(* Float arrays *)\n\nexternal unsafe_blit_float_array_buf\n : src_pos:int\n -> float array\n -> dst_pos:int\n -> buf\n -> len:int\n -> unit\n = \"bin_prot_blit_float_array_buf_stub\"\n[@@noalloc]\n\nexternal unsafe_blit_buf_float_array\n : src_pos:int\n -> buf\n -> dst_pos:int\n -> float array\n -> len:int\n -> unit\n = \"bin_prot_blit_buf_float_array_stub\"\n[@@noalloc]\n\n(***)\n\nlet ( + ) = ( + )\n","open Core_kernel\n\nmodule type Nat_intf = Nat.Intf\n\ntype z = Nat.z\n\ntype 'a s = 'a Nat.s\n\nmodule T = struct\n type ('a, _) t = [] : ('a, z) t | ( :: ) : 'a * ('a, 'n) t -> ('a, 'n s) t\nend\n\ninclude T\n\nlet singleton a = [ a ]\n\nlet unsingleton (type a) ([ x ] : (a, z s) t) : a = x\n\nlet rec iter : type a n. (a, n) t -> f:(a -> unit) -> unit =\n fun t ~f -> match t with [] -> () | x :: xs -> f x ; iter xs ~f\n\nlet iteri (type a n) (t : (a, n) t) ~(f : int -> a -> unit) : unit =\n let rec go : type n. int -> (a, n) t -> unit =\n fun acc t ->\n match t with\n | [] ->\n ()\n | x :: xs ->\n f acc x ;\n go (acc + 1) xs\n in\n go 0 t\n\nlet rec length : type a n. (a, n) t -> n Nat.t = function\n | [] ->\n Z\n | _ :: xs ->\n S (length xs)\n\nlet nth v i =\n let rec loop : type a n. int -> (a, n) t -> a option =\n fun j -> function\n | [] ->\n None\n | x :: xs ->\n if Int.equal i j then Some x else loop (j + 1) xs\n in\n loop 0 v\n\nlet nth_exn v i =\n match nth v i with\n | None ->\n invalid_argf \"Vector.nth_exn %d called on a vector of length %d\" i\n (length v |> Nat.to_int)\n ()\n | Some e ->\n e\n\nlet rec iter2 : type a b n. (a, n) t -> (b, n) t -> f:(a -> b -> unit) -> unit =\n fun t1 t2 ~f ->\n match (t1, t2) with\n | [], [] ->\n ()\n | x :: xs, y :: ys ->\n f x y ; iter2 xs ys ~f\n\nlet rec map2 : type a b c n. (a, n) t -> (b, n) t -> f:(a -> b -> c) -> (c, n) t\n =\n fun t1 t2 ~f ->\n match (t1, t2) with\n | [], [] ->\n []\n | x :: xs, y :: ys ->\n f x y :: map2 xs ys ~f\n\nlet rec hhead_off :\n type xs n.\n (xs, n s) Hlist0.H1_1(T).t -> xs Hlist0.HlistId.t * (xs, n) Hlist0.H1_1(T).t\n =\n fun xss ->\n match xss with\n | [] ->\n ([], [])\n | (x :: xs) :: xss ->\n let hds, tls = hhead_off xss in\n (x :: hds, xs :: tls)\n\nlet rec mapn :\n type xs y n.\n (xs, n) Hlist0.H1_1(T).t -> f:(xs Hlist0.HlistId.t -> y) -> (y, n) t =\n fun xss ~f ->\n match xss with\n | [] :: _xss ->\n []\n | (_ :: _) :: _ ->\n let hds, tls = hhead_off xss in\n let y = f hds in\n let ys = mapn tls ~f in\n y :: ys\n | [] ->\n failwith \"mapn: Empty args\"\n\nlet rec nth : type a n. (a, n) t -> int -> a option =\n fun t idx ->\n match t with\n | [] ->\n None\n | x :: _ when idx = 0 ->\n Some x\n | _ :: t ->\n nth t (idx - 1)\n\nlet zip xs ys = map2 xs ys ~f:(fun x y -> (x, y))\n\nlet rec to_list : type a n. (a, n) t -> a list =\n fun t -> match t with [] -> [] | x :: xs -> x :: to_list xs\n\nlet sexp_of_t a _ v = List.sexp_of_t a (to_list v)\n\nlet to_array t = Array.of_list (to_list t)\n\nlet rec init : type a n. int -> n Nat.t -> f:(int -> a) -> (a, n) t =\n fun i n ~f -> match n with Z -> [] | S n -> f i :: init (i + 1) n ~f\n\nlet init n ~f = init 0 n ~f\n\nlet rec _fold_map :\n type acc a b n.\n (a, n) t -> f:(acc -> a -> acc * b) -> init:acc -> acc * (b, n) t =\n fun t ~f ~init ->\n match t with\n | [] ->\n (init, [])\n | x :: xs ->\n let acc, y = f init x in\n let res, ys = _fold_map xs ~f ~init:acc in\n (res, y :: ys)\n\nlet rec map : type a b n. (a, n) t -> f:(a -> b) -> (b, n) t =\n fun t ~f -> match t with [] -> [] | x :: xs -> f x :: map xs ~f\n\nlet mapi (type a b m) (t : (a, m) t) ~(f : int -> a -> b) =\n let rec go : type n. int -> (a, n) t -> (b, n) t =\n fun i t -> match t with [] -> [] | x :: xs -> f i x :: go (i + 1) xs\n in\n go 0 t\n\nlet unzip ts = (map ts ~f:fst, map ts ~f:snd)\n\ntype _ e = T : ('a, 'n) t -> 'a e\n\nlet rec of_list : type a. a list -> a e = function\n | [] ->\n T []\n | x :: xs ->\n let (T xs) = of_list xs in\n T (x :: xs)\n\nlet rec of_list_and_length_exn : type a n. a list -> n Nat.t -> (a, n) t =\n fun xs n ->\n match (xs, n) with\n | [], Z ->\n []\n | x :: xs, S n ->\n x :: of_list_and_length_exn xs n\n | [], S _ | _ :: _, Z ->\n failwith \"Vector: Length mismatch\"\n\nlet of_array_and_length_exn : type a n. a array -> n Nat.t -> (a, n) t =\n fun xs n ->\n if Array.length xs <> Nat.to_int n then\n failwithf \"of_array_and_length_exn: got %d (expected %d)\" (Array.length xs)\n (Nat.to_int n) () ;\n init n ~f:(Array.get xs)\n\nlet rec _take_from_list : type a n. a list -> n Nat.t -> (a, n) t =\n fun xs n ->\n match (xs, n) with\n | _, Z ->\n []\n | x :: xs, S n ->\n x :: _take_from_list xs n\n | [], S _ ->\n failwith \"take_from_list: Not enough to take\"\n\nlet rec fold : type acc a n. (a, n) t -> f:(acc -> a -> acc) -> init:acc -> acc\n =\n fun t ~f ~init ->\n match t with\n | [] ->\n init\n | x :: xs ->\n let acc = f init x in\n fold xs ~f ~init:acc\n\nlet for_all : type a n. (a, n) t -> f:(a -> bool) -> bool =\n fun v ~f ->\n with_return (fun { return } ->\n iter v ~f:(fun x -> if not (f x) then return false) ;\n true )\n\nlet foldi t ~f ~init =\n snd (fold t ~f:(fun (i, acc) x -> (i + 1, f i acc x)) ~init:(0, init))\n\nlet reduce_exn (type n) (t : (_, n) t) ~f =\n match t with\n | [] ->\n failwith \"reduce_exn: empty list\"\n | init :: xs ->\n fold xs ~f ~init\n\nmodule L = struct\n type 'a t = 'a list [@@deriving yojson]\nend\n\nmodule Make = struct\n module Cata (F : sig\n type _ t\n\n val pair : 'a t -> 'b t -> ('a * 'b) t\n\n val cnv : ('a -> 'b) -> ('b -> 'a) -> 'b t -> 'a t\n\n val unit : unit t\n end) =\n struct\n let rec f : type n a. n Nat.t -> a F.t -> (a, n) t F.t =\n fun n tc ->\n match n with\n | Z ->\n F.cnv (function [] -> ()) (fun () -> []) F.unit\n | S n ->\n let tl = f n tc in\n F.cnv\n (function x :: xs -> (x, xs))\n (fun (x, xs) -> x :: xs)\n (F.pair tc tl)\n end\n\n module Sexpable (N : Nat_intf) : Sexpable.S1 with type 'a t := ('a, N.n) t =\n struct\n let sexp_of_t f t = List.sexp_of_t f (to_list t)\n\n let t_of_sexp f s = of_list_and_length_exn (List.t_of_sexp f s) N.n\n end\n\n module Yojson (N : Nat_intf) :\n Sigs.Jsonable.S1 with type 'a t := ('a, N.n) t = struct\n let to_yojson f t = L.to_yojson f (to_list t)\n\n let of_yojson f s =\n Result.map (L.of_yojson f s) ~f:(Fn.flip of_list_and_length_exn N.n)\n end\n\n module Binable (N : Nat_intf) : Binable.S1 with type 'a t := ('a, N.n) t =\n struct\n open Bin_prot\n\n module Tc = Cata (struct\n type 'a t = 'a Type_class.t\n\n let pair = Type_class.bin_pair\n\n let cnv t = Type_class.cnv Fn.id t\n\n let unit = Type_class.bin_unit\n end)\n\n module Shape = Cata (struct\n type _ t = Shape.t\n\n let pair = Shape.bin_shape_pair\n\n let cnv _ _ = Fn.id\n\n let unit = Shape.bin_shape_unit\n end)\n\n module Size = Cata (struct\n type 'a t = 'a Size.sizer\n\n let pair = Size.bin_size_pair\n\n let cnv a_to_b _b_to_a b_sizer a = b_sizer (a_to_b a)\n\n let unit = Size.bin_size_unit\n end)\n\n module Write = Cata (struct\n type 'a t = 'a Write.writer\n\n let pair = Write.bin_write_pair\n\n let cnv a_to_b _b_to_a b_writer buf ~pos a = b_writer buf ~pos (a_to_b a)\n\n let unit = Write.bin_write_unit\n end)\n\n module Writer = Cata (struct\n type 'a t = 'a Type_class.writer\n\n let pair = Type_class.bin_writer_pair\n\n let cnv a_to_b _b_to_a b_writer = Type_class.cnv_writer a_to_b b_writer\n\n let unit = Type_class.bin_writer_unit\n end)\n\n module Reader = Cata (struct\n type 'a t = 'a Type_class.reader\n\n let pair = Type_class.bin_reader_pair\n\n let cnv _a_to_b b_to_a b_reader = Type_class.cnv_reader b_to_a b_reader\n\n let unit = Type_class.bin_reader_unit\n end)\n\n module Read = Cata (struct\n type 'a t = 'a Read.reader\n\n let pair = Read.bin_read_pair\n\n let cnv _a_to_b b_to_a b_reader buf ~pos_ref =\n b_to_a (b_reader buf ~pos_ref)\n\n let unit = Read.bin_read_unit\n end)\n\n let bin_shape_t sh = Shape.f N.n sh\n\n let bin_size_t sz = Size.f N.n sz\n\n let bin_write_t wr = Write.f N.n wr\n\n let bin_writer_t wr = Writer.f N.n wr\n\n let bin_t tc = Tc.f N.n tc\n\n let bin_reader_t re = Reader.f N.n re\n\n let bin_read_t re = Read.f N.n re\n\n let __bin_read_t__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"vector\" !pos_ref\n end\nend\n\ntype ('a, 'n) vec = ('a, 'n) t\n\nmodule With_length (N : Nat.Intf) = struct\n type 'a t = ('a, N.n) vec\n\n let compare c t1 t2 = Base.List.compare c (to_list t1) (to_list t2)\n\n let hash_fold_t f s v = List.hash_fold_t f s (to_list v)\n\n let equal f t1 t2 = List.equal f (to_list t1) (to_list t2)\n\n include Make.Yojson (N)\n include Make.Sexpable (N)\n\n let map (t : 'a t) = map t\n\n let of_list_exn : 'a list -> 'a t = fun ls -> of_list_and_length_exn ls N.n\n\n let to_list : 'a t -> 'a list = to_list\nend\n\nlet rec typ' :\n type f var value n.\n ((var, value, f) Snarky_backendless.Typ.t, n) t\n -> ((var, n) t, (value, n) t, f) Snarky_backendless.Typ.t =\n let open Snarky_backendless.Typ in\n fun elts ->\n match elts with\n | elt :: elts ->\n let tl = typ' elts in\n let there = function x :: xs -> (x, xs) in\n let back (x, xs) = x :: xs in\n transport (elt * tl) ~there ~back |> transport_var ~there ~back\n | [] ->\n let there [] = () in\n let back () = [] in\n transport (unit ()) ~there ~back |> transport_var ~there ~back\n\nlet typ elt n = typ' (init n ~f:(fun _ -> elt))\n\nlet rec append :\n type n m n_m a. (a, n) t -> (a, m) t -> (n, m, n_m) Nat.Adds.t -> (a, n_m) t\n =\n fun t1 t2 adds ->\n match (t1, adds) with\n | [], Z ->\n t2\n | x :: t1, S adds ->\n x :: append t1 t2 adds\n\n(* TODO: Make more efficient *)\nlet rev (type a n) (xs : (a, n) t) : (a, n) t =\n of_list_and_length_exn\n (fold ~init:[] ~f:(fun acc x -> List.cons x acc) xs)\n (length xs)\n\nlet rec _last : type a n. (a, n s) t -> a = function\n | [ x ] ->\n x\n | _ :: (_ :: _ as xs) ->\n _last xs\n\nlet rec split :\n type n m n_m a. (a, n_m) t -> (n, m, n_m) Nat.Adds.t -> (a, n) t * (a, m) t\n =\n fun t adds ->\n match (t, adds) with\n | [], Z ->\n ([], [])\n | _ :: _, Z ->\n ([], t)\n | x :: t1, S adds ->\n let xs, ys = split t1 adds in\n (x :: xs, ys)\n\nlet rec transpose : type a n m. ((a, n) t, m) t -> ((a, m) t, n) t =\n fun xss ->\n match xss with\n | [] ->\n failwith \"transpose: empty list\"\n | [] :: _ ->\n []\n | (_ :: _) :: _ ->\n let heads, tails = unzip (map xss ~f:(fun (x :: xs) -> (x, xs))) in\n heads :: transpose tails\n\nlet rec trim : type a n m. (a, m) t -> (n, m) Nat.Lte.t -> (a, n) t =\n fun v p -> match (v, p) with _, Z -> [] | x :: xs, S p -> x :: trim xs p\n\nlet trim_front (type a n m) (v : (a, m) t) (p : (n, m) Nat.Lte.t) : (a, n) t =\n rev (trim (rev v) p)\n\nlet extend_front_exn : type n m a. (a, n) t -> m Nat.t -> a -> (a, m) t =\n fun v m dummy ->\n let v = to_array v in\n let n = Array.length v in\n let m' = Nat.to_int m in\n assert (n <= m') ;\n let padding = m' - n in\n init m ~f:(fun i -> if i < padding then dummy else v.(i - padding))\n\nlet rec extend_exn : type n m a. (a, n) t -> m Nat.t -> a -> (a, m) t =\n fun v m default ->\n match (v, m) with\n | [], Z ->\n []\n | [], S n ->\n default :: extend_exn [] n default\n | _x :: _xs, Z ->\n failwith \"extend_exn: list too long\"\n | x :: xs, S m ->\n let extended = extend_exn xs m default in\n x :: extended\n\nlet rec extend :\n type a n m. (a, n) t -> (n, m) Nat.Lte.t -> m Nat.t -> a -> (a, m) t =\n fun v p m default ->\n match (v, p, m) with\n | _, Z, Z ->\n []\n | _, Z, S m ->\n default :: extend [] Z m default\n | x :: xs, S p, S m ->\n x :: extend xs p m default\n\nlet extend_front :\n type a n m. (a, n) t -> (n, m) Nat.Lte.t -> m Nat.t -> a -> (a, m) t =\n fun v _p m default -> extend_front_exn v m default\n\nmodule type S = sig\n type 'a t [@@deriving compare, yojson, sexp, hash, equal]\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val of_list_exn : 'a list -> 'a t\n\n val to_list : 'a t -> 'a list\nend\n\nmodule type VECTOR = sig\n type 'a t\n\n include S with type 'a t := 'a t\n\n module Stable : sig\n module V1 : sig\n include S with type 'a t = 'a t\n\n include Sigs.Binable.S1 with type 'a t = 'a t\n\n include Sigs.VERSIONED\n end\n end\nend\n\nmodule With_version (N : Nat.Intf) = struct\n module type S = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type 'a t = ('a, N.n) vec\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val of_list_exn : 'a list -> 'a t\n\n val to_list : 'a t -> 'a list\n end\nend\n\nmodule Vector_2 = struct\n module T = With_length (Nat.N2)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N2.n) vec\n\n include Make.Binable (Nat.N2)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_4 = struct\n module T = With_length (Nat.N4)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N4.n) vec\n\n include Make.Binable (Nat.N4)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_5 = struct\n module T = With_length (Nat.N5)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N5.n) vec\n\n include Make.Binable (Nat.N5)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_6 = struct\n module T = With_length (Nat.N6)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N6.n) vec\n\n include Make.Binable (Nat.N6)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_7 = struct\n module T = With_length (Nat.N7)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N7.n) vec\n\n include Make.Binable (Nat.N7)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_8 = struct\n module T = With_length (Nat.N8)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N8.n) vec\n\n include Make.Binable (Nat.N8)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_15 = struct\n module T = With_length (Nat.N15)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N15.n) vec\n\n include Make.Binable (Nat.N15)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_16 = struct\n module T = With_length (Nat.N16)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N16.n) vec\n\n include Make.Binable (Nat.N16)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n","(* Read_ml: reading values from the binary protocol using (mostly) OCaml. *)\n\n(* Note: the code is this file is carefully written to avoid unnecessary allocations. When\n touching this code, be sure to run the benchmarks to check for regressions. *)\n\nopen Bigarray\nopen Common\n\ntype 'a reader = buf -> pos_ref:pos_ref -> 'a\ntype ('a, 'b) reader1 = 'a reader -> 'b reader\ntype ('a, 'b, 'c) reader2 = 'a reader -> ('b, 'c) reader1\ntype ('a, 'b, 'c, 'd) reader3 = 'a reader -> ('b, 'c, 'd) reader2\n\nexternal unsafe_get : buf -> int -> char = \"%caml_ba_unsafe_ref_1\"\nexternal unsafe_get8 : buf -> int -> int = \"%caml_ba_unsafe_ref_1\"\n\nlet unsafe_get8_signed buf pos =\n let c = unsafe_get8 buf pos in\n if c >= 128 then c - 256 else c\n;;\n\n(*$ open Bin_prot_cinaps $*)\n\nlet arch_sixtyfour = Sys.word_size = 64\nlet arch_big_endian = Sys.big_endian\nlet max_int_int32 = if arch_sixtyfour then Int32.max_int else Int32.of_int max_int\nlet min_int_int32 = if arch_sixtyfour then Int32.max_int else Int32.of_int min_int\nlet max_int_int64 = Int64.of_int max_int\nlet min_int_int64 = Int64.of_int min_int\n\nlet safe_int_of_int32 pos x =\n if arch_sixtyfour\n then Int32.to_int x\n else if x >= min_int_int32 && x <= max_int_int32\n then Int32.to_int x\n else raise_read_error ReadError.Int_overflow pos\n;;\n\nlet safe_int_of_int64 pos x =\n if x >= min_int_int64 && x <= max_int_int64\n then Int64.to_int x\n else raise_read_error ReadError.Int_overflow pos\n;;\n\nlet safe_nativeint_of_int64 =\n if arch_sixtyfour\n then fun _pos x -> Int64.to_nativeint x\n else\n fun pos x ->\n if x >= Int64.of_nativeint Nativeint.min_int\n && x <= Int64.of_nativeint Nativeint.max_int\n then Int64.to_nativeint x\n else raise_read_error ReadError.Int_overflow pos\n;;\n\nexternal unsafe_get16 : buf -> int -> int = \"%caml_bigstring_get16u\"\nexternal unsafe_get32 : buf -> int -> int32 = \"%caml_bigstring_get32u\"\nexternal unsafe_get64 : buf -> int -> int64 = \"%caml_bigstring_get64u\"\nexternal bswap16 : int -> int = \"%bswap16\"\nexternal bswap32 : int32 -> int32 = \"%bswap_int32\"\nexternal bswap64 : int64 -> int64 = \"%bswap_int64\"\n\nlet unsafe_get16be_unsigned =\n if arch_big_endian\n then unsafe_get16\n else fun buf pos -> unsafe_get16 buf pos |> bswap16\n;;\n\nlet unsafe_get32be =\n if arch_big_endian\n then unsafe_get32\n else fun buf pos -> unsafe_get32 buf pos |> bswap32\n;;\n\nlet unsafe_get64be =\n if arch_big_endian\n then unsafe_get64\n else fun buf pos -> unsafe_get64 buf pos |> bswap64\n;;\n\nlet unsafe_get16le_unsigned =\n if arch_big_endian\n then fun buf pos -> unsafe_get16 buf pos |> bswap16\n else unsafe_get16\n;;\n\nlet unsafe_get32le =\n if arch_big_endian\n then fun buf pos -> unsafe_get32 buf pos |> bswap32\n else unsafe_get32\n;;\n\nlet unsafe_get64le =\n if arch_big_endian\n then fun buf pos -> unsafe_get64 buf pos |> bswap64\n else unsafe_get64\n;;\n\nlet unsafe_get16le_signed buf pos =\n let x = unsafe_get16le_unsigned buf pos in\n if x > 32767 then x - 65536 else x\n;;\n\nlet bin_read_unit buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n if unsafe_get buf pos = '\\000'\n then pos_ref := pos + 1\n else raise_read_error ReadError.Unit_code pos\n;;\n\nlet bin_read_bool buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\000' ->\n pos_ref := pos + 1;\n false\n | '\\001' ->\n pos_ref := pos + 1;\n true\n | _ -> raise_read_error ReadError.Bool_code pos\n;;\n\nlet safe_bin_read_neg_int8 buf ~pos_ref ~pos =\n let next = pos + 1 in\n check_next buf next;\n let n = unsafe_get8_signed buf pos in\n if n >= 0 then raise_read_error ReadError.Neg_int8 !pos_ref;\n pos_ref := next;\n n\n;;\n\nlet safe_bin_read_int16 buf ~pos_ref ~pos =\n let next = pos + 2 in\n check_next buf next;\n pos_ref := next;\n (* Can be above next line (no errors possible with 16bit).\n This should improve the generated code. *)\n unsafe_get16le_signed buf pos\n;;\n\nlet safe_bin_read_int32 buf ~pos_ref ~pos =\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n (* No error possible either. *)\n unsafe_get32le buf pos\n;;\n\nlet safe_bin_read_int64 buf ~pos_ref ~pos =\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n (* No error possible either. *)\n unsafe_get64le buf pos\n;;\n\nlet safe_bin_read_int32_as_int buf ~pos_ref ~pos =\n let next = pos + 4 in\n check_next buf next;\n let n = unsafe_get32le buf pos in\n let n = safe_int_of_int32 !pos_ref n in\n pos_ref := next;\n n\n;;\n\nlet safe_bin_read_int64_as_int buf ~pos_ref ~pos =\n let next = pos + 8 in\n check_next buf next;\n let n = unsafe_get64le buf pos in\n let n = safe_int_of_int64 !pos_ref n in\n pos_ref := next;\n n\n;;\n\nlet safe_bin_read_int32_as_int64 buf ~pos_ref ~pos =\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get32le buf pos in\n Int64.of_int32 n\n;;\n\nlet safe_bin_read_int32_as_nativeint buf ~pos_ref ~pos =\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get32le buf pos in\n Nativeint.of_int32 n\n;;\n\nlet safe_bin_read_int64_as_nativeint buf ~pos_ref ~pos =\n let next = pos + 8 in\n check_next buf next;\n let n = unsafe_get64le buf pos in\n let n = safe_nativeint_of_int64 pos n in\n pos_ref := next;\n n\n;;\n\nlet safe_bin_read_nat0_16 buf ~pos_ref ~pos =\n let next = pos + 2 in\n check_next buf next;\n pos_ref := next;\n Nat0.unsafe_of_int (unsafe_get16le_unsigned buf pos)\n;;\n\nlet safe_bin_read_nat0_32 =\n if arch_sixtyfour\n then (\n let mask_32bit = Int64.to_int 0xffff_ffffL in\n fun buf ~pos_ref ~pos ->\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n let n = Int32.to_int (unsafe_get32le buf pos) in\n if n >= 0\n then Nat0.unsafe_of_int n\n else\n (* Erase the upper bits that were set to 1 during the int32 -> int conversion. *)\n Nat0.unsafe_of_int (n land mask_32bit))\n else\n fun buf ~pos_ref ~pos ->\n let next = pos + 4 in\n check_next buf next;\n let n = unsafe_get32le buf pos in\n if n >= 0l && n <= max_int_int32\n then (\n let n = Nat0.unsafe_of_int (Int32.to_int n) in\n pos_ref := next;\n n)\n else raise_read_error ReadError.Nat0_overflow !pos_ref\n;;\n\nlet safe_bin_read_nat0_64 buf ~pos_ref ~pos =\n let next = pos + 8 in\n check_next buf next;\n let n = unsafe_get64le buf pos in\n if n >= 0L && n <= max_int_int64\n then (\n let n = Nat0.unsafe_of_int (Int64.to_int n) in\n pos_ref := next;\n n)\n else raise_read_error ReadError.Nat0_overflow !pos_ref\n;;\n\nlet bin_read_nat0 buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\x00'..'\\x7f' as ch ->\n pos_ref := pos + 1;\n Nat0.unsafe_of_int (Char.code ch)\n | (*$ Code.char INT16 *)'\\xfe'(*$*) ->\n safe_bin_read_nat0_16 buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT32 *)'\\xfd'(*$*) ->\n safe_bin_read_nat0_32 buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT64 *)'\\xfc'(*$*) ->\n if arch_sixtyfour then\n safe_bin_read_nat0_64 buf ~pos_ref ~pos:(pos + 1)\n else\n raise_read_error ReadError.Nat0_overflow pos\n | _ ->\n raise_read_error ReadError.Nat0_code pos\n[@@ocamlformat \"disable\"]\n\nlet bin_read_bytes buf ~pos_ref =\n let start_pos = !pos_ref in\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n if len > Sys.max_string_length\n then raise_read_error ReadError.String_too_long start_pos;\n let pos = !pos_ref in\n let next = pos + len in\n check_next buf next;\n pos_ref := next;\n let str = Bytes.create len in\n unsafe_blit_buf_bytes ~src_pos:pos buf ~dst_pos:0 str ~len;\n str\n;;\n\nlet bin_read_string buf ~pos_ref =\n let str = bin_read_bytes buf ~pos_ref in\n Bytes.unsafe_to_string str\n;;\n\nlet bin_read_char buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n pos_ref := pos + 1;\n unsafe_get buf pos\n;;\n\nlet bin_read_int buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\x00'..'\\x7f' as ch ->\n pos_ref := pos + 1;\n Char.code ch\n | (*$ Code.char NEG_INT8 *)'\\xff'(*$*) ->\n safe_bin_read_neg_int8 buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT16 *)'\\xfe'(*$*) ->\n safe_bin_read_int16 buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT32 *)'\\xfd'(*$*) ->\n safe_bin_read_int32_as_int buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT64 *)'\\xfc'(*$*) ->\n if arch_sixtyfour then\n safe_bin_read_int64_as_int buf ~pos_ref ~pos:(pos + 1)\n else\n raise_read_error ReadError.Int_overflow pos\n | _ ->\n raise_read_error ReadError.Int_code pos\n[@@ocamlformat \"disable\"]\n\nlet bin_read_float buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n (* No error possible either. *)\n Int64.float_of_bits (unsafe_get64le buf pos)\n;;\n\nlet bin_read_int32 buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\x00'..'\\x7f' as ch ->\n pos_ref := pos + 1;\n Int32.of_int (Char.code ch)\n | (*$ Code.char NEG_INT8 *)'\\xff'(*$*) ->\n Int32.of_int (safe_bin_read_neg_int8 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT16 *)'\\xfe'(*$*) ->\n Int32.of_int (safe_bin_read_int16 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT32 *)'\\xfd'(*$*) ->\n safe_bin_read_int32 buf ~pos_ref ~pos:(pos + 1)\n | _ ->\n raise_read_error ReadError.Int32_code pos\n[@@ocamlformat \"disable\"]\n\nlet bin_read_int64 buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\x00'..'\\x7f' as ch ->\n pos_ref := pos + 1;\n Int64.of_int (Char.code ch)\n | (*$ Code.char NEG_INT8 *)'\\xff'(*$*) ->\n Int64.of_int (safe_bin_read_neg_int8 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT16 *)'\\xfe'(*$*) ->\n Int64.of_int (safe_bin_read_int16 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT32 *)'\\xfd'(*$*) ->\n safe_bin_read_int32_as_int64 buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT64 *)'\\xfc'(*$*) ->\n safe_bin_read_int64 buf ~pos_ref ~pos:(pos + 1)\n | _ ->\n raise_read_error ReadError.Int64_code pos\n[@@ocamlformat \"disable\"]\n\nlet bin_read_nativeint buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\x00'..'\\x7f' as ch ->\n pos_ref := pos + 1;\n Nativeint.of_int (Char.code ch)\n | (*$ Code.char NEG_INT8 *)'\\xff'(*$*) ->\n Nativeint.of_int (safe_bin_read_neg_int8 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT16 *)'\\xfe'(*$*) ->\n Nativeint.of_int (safe_bin_read_int16 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT32 *)'\\xfd'(*$*) ->\n safe_bin_read_int32_as_nativeint buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT64 *)'\\xfc'(*$*) when arch_sixtyfour ->\n safe_bin_read_int64_as_nativeint buf ~pos_ref ~pos:(pos + 1)\n | _ ->\n raise_read_error ReadError.Nativeint_code pos\n[@@ocamlformat \"disable\"]\n\nlet bin_read_ref bin_read_el buf ~pos_ref =\n let el = bin_read_el buf ~pos_ref in\n ref el\n;;\n\nlet bin_read_lazy bin_read_el buf ~pos_ref =\n let el = bin_read_el buf ~pos_ref in\n Lazy.from_val el\n;;\n\nlet bin_read_option bin_read_el buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\000' ->\n pos_ref := pos + 1;\n None\n | '\\001' ->\n pos_ref := pos + 1;\n let el = bin_read_el buf ~pos_ref in\n Some el\n | _ -> raise_read_error ReadError.Option_code pos\n;;\n\nlet bin_read_pair bin_read_a bin_read_b buf ~pos_ref =\n let a = bin_read_a buf ~pos_ref in\n let b = bin_read_b buf ~pos_ref in\n a, b\n;;\n\nlet bin_read_triple bin_read_a bin_read_b bin_read_c buf ~pos_ref =\n let a = bin_read_a buf ~pos_ref in\n let b = bin_read_b buf ~pos_ref in\n let c = bin_read_c buf ~pos_ref in\n a, b, c\n;;\n\nlet bin_read_n_rev_list bin_read_el buf ~pos_ref len =\n let rec loop n acc =\n if n = 0 then acc else loop (n - 1) (bin_read_el buf ~pos_ref :: acc)\n in\n loop len []\n;;\n\nlet bin_read_list_with_max_len ~max_len bin_read_el buf ~pos_ref =\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n if len > max_len then raise_read_error (List_too_long { len; max_len }) !pos_ref;\n let rev_lst = bin_read_n_rev_list bin_read_el buf ~pos_ref len in\n List.rev rev_lst\n;;\n\nlet bin_read_list bin_read_el buf ~pos_ref =\n bin_read_list_with_max_len ~max_len:max_int bin_read_el buf ~pos_ref\n;;\n\nlet dummy_float_buf = create_buf 8\nlet () = ignore (Write.bin_write_float dummy_float_buf ~pos:0 3.1)\n\nlet max_float_array_length =\n if arch_sixtyfour then Sys.max_array_length else Sys.max_array_length / 2\n;;\n\nlet bin_read_float_array buf ~pos_ref =\n let pos = !pos_ref in\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n if len > max_float_array_length then raise_read_error ReadError.Array_too_long pos;\n let size = len * 8 in\n let pos = !pos_ref in\n let next = pos + size in\n check_next buf next;\n let arr = Array.create_float len in\n unsafe_blit_buf_float_array buf arr ~src_pos:pos ~dst_pos:0 ~len;\n pos_ref := next;\n arr\n;;\n\nlet bin_read_array (type a) bin_read_el buf ~pos_ref =\n if (Obj.magic (bin_read_el : a reader) : float reader) == bin_read_float\n then (Obj.magic (bin_read_float_array buf ~pos_ref : float array) : a array)\n else (\n let start_pos = !pos_ref in\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n if len = 0\n then [||]\n else (\n if arch_sixtyfour\n then (\n if len > Sys.max_array_length\n then raise_read_error ReadError.Array_too_long start_pos)\n else if len > Sys.max_array_length / 2\n then (\n let maybe_float =\n try\n let el = bin_read_el dummy_float_buf ~pos_ref:(ref 0) in\n Some el\n with\n | _ -> None\n in\n match maybe_float with\n | None ->\n if len > Sys.max_array_length\n then raise_read_error ReadError.Array_too_long start_pos\n | Some el ->\n if Obj.tag (Obj.repr el) = Obj.double_tag || len > Sys.max_array_length\n then raise_read_error ReadError.Array_too_long start_pos);\n let first = bin_read_el buf ~pos_ref in\n let res = Array.make len first in\n for i = 1 to len - 1 do\n let el = bin_read_el buf ~pos_ref in\n Array.unsafe_set res i el\n done;\n res))\n;;\n\nlet bin_read_hashtbl bin_read_key bin_read_val buf ~pos_ref =\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n let htbl = Hashtbl.create len in\n let read_kv_pair = bin_read_pair bin_read_key bin_read_val in\n let els = bin_read_n_rev_list read_kv_pair buf ~pos_ref len in\n copy_htbl_list htbl els\n;;\n\nexternal buf_of_vec32 : vec32 -> buf = \"%identity\"\nexternal buf_of_vec64 : vec64 -> buf = \"%identity\"\nexternal buf_of_mat32 : mat32 -> buf = \"%identity\"\nexternal buf_of_mat64 : mat64 -> buf = \"%identity\"\n\nlet bin_read_float32_vec buf ~pos_ref =\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n let size = len * 4 in\n let pos = !pos_ref in\n let next = pos + size in\n check_next buf next;\n let vec = Array1.create float32 fortran_layout len in\n unsafe_blit_buf ~src:buf ~src_pos:pos ~dst:(buf_of_vec32 vec) ~dst_pos:0 ~len:size;\n pos_ref := next;\n vec\n;;\n\nlet bin_read_float64_vec buf ~pos_ref =\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n let size = len * 8 in\n let pos = !pos_ref in\n let next = pos + size in\n check_next buf next;\n let vec = Array1.create float64 fortran_layout len in\n unsafe_blit_buf ~src:buf ~src_pos:pos ~dst:(buf_of_vec64 vec) ~dst_pos:0 ~len:size;\n pos_ref := next;\n vec\n;;\n\nlet bin_read_vec = bin_read_float64_vec\n\nlet bin_read_float32_mat buf ~pos_ref =\n let len1 = (bin_read_nat0 buf ~pos_ref :> int) in\n let len2 = (bin_read_nat0 buf ~pos_ref :> int) in\n let size = len1 * len2 * 4 in\n let pos = !pos_ref in\n let next = pos + size in\n check_next buf next;\n let mat = Array2.create float32 fortran_layout len1 len2 in\n unsafe_blit_buf ~src:buf ~src_pos:pos ~dst:(buf_of_mat32 mat) ~dst_pos:0 ~len:size;\n pos_ref := next;\n mat\n;;\n\nlet bin_read_float64_mat buf ~pos_ref =\n let len1 = (bin_read_nat0 buf ~pos_ref :> int) in\n let len2 = (bin_read_nat0 buf ~pos_ref :> int) in\n let size = len1 * len2 * 8 in\n let pos = !pos_ref in\n let next = pos + size in\n check_next buf next;\n let mat = Array2.create float64 fortran_layout len1 len2 in\n unsafe_blit_buf ~src:buf ~src_pos:pos ~dst:(buf_of_mat64 mat) ~dst_pos:0 ~len:size;\n pos_ref := next;\n mat\n;;\n\nlet bin_read_mat = bin_read_float64_mat\n\nlet bin_read_bigstring buf ~pos_ref =\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n let pos = !pos_ref in\n let next = pos + len in\n check_next buf next;\n let str = create_buf len in\n unsafe_blit_buf ~src:buf ~src_pos:pos ~dst:str ~dst_pos:0 ~len;\n pos_ref := next;\n str\n;;\n\nlet bin_read_variant_int buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n let n = unsafe_get32le buf pos in\n (* [n] must contain an integer already encoded, i.e. [n = 2 * k + 1]. *)\n if Int32.logand n 1l = 0l\n then raise (Read_error (ReadError.Variant_tag, pos))\n else (\n (* We shift it by one bit to the right se we get back [2 * k + 1] in the end. *)\n pos_ref := next;\n Int32.to_int (Int32.shift_right n 1))\n;;\n\nlet bin_read_int_8bit buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n pos_ref := pos + 1;\n unsafe_get8 buf pos\n;;\n\nlet bin_read_int_16bit buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 2 in\n check_next buf next;\n pos_ref := next;\n unsafe_get16le_unsigned buf pos\n;;\n\nlet bin_read_int_32bit buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get32le buf pos in\n safe_int_of_int32 pos n\n;;\n\nlet bin_read_int_64bit buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get64le buf pos in\n safe_int_of_int64 pos n\n;;\n\nlet bin_read_int64_bits buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n unsafe_get64le buf pos\n;;\n\nlet bin_read_network16_int buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 2 in\n check_next buf next;\n pos_ref := next;\n unsafe_get16be_unsigned buf pos\n;;\n\nlet bin_read_network32_int buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get32be buf pos in\n safe_int_of_int32 pos n\n;;\n\nlet bin_read_network32_int32 buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n unsafe_get32be buf pos\n;;\n\nlet bin_read_network64_int buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get64be buf pos in\n safe_int_of_int64 pos n\n;;\n\nlet bin_read_network64_int64 buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n unsafe_get64be buf pos\n;;\n\n[%%if\n ocaml_version < (4, 07, 0)]\n\nexternal unsafe_bytes_set32 : bytes -> int -> int32 -> unit = \"%caml_string_set32u\"\nexternal unsafe_bytes_set64 : bytes -> int -> int64 -> unit = \"%caml_string_set64u\"\n\n[%%else]\n\nexternal unsafe_bytes_set32 : bytes -> int -> int32 -> unit = \"%caml_bytes_set32u\"\nexternal unsafe_bytes_set64 : bytes -> int -> int64 -> unit = \"%caml_bytes_set64u\"\n\n[%%endif]\n\nlet bin_read_md5 buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 16 in\n check_next buf next;\n pos_ref := next;\n let res = Bytes.create 16 in\n if arch_sixtyfour\n then (\n let a = unsafe_get64 buf pos in\n let b = unsafe_get64 buf (pos + 8) in\n unsafe_bytes_set64 res 0 a;\n unsafe_bytes_set64 res 8 b)\n else (\n let a = unsafe_get32 buf pos in\n let b = unsafe_get32 buf (pos + 4) in\n let c = unsafe_get32 buf (pos + 8) in\n let d = unsafe_get32 buf (pos + 12) in\n unsafe_bytes_set32 res 0 a;\n unsafe_bytes_set32 res 4 b;\n unsafe_bytes_set32 res 8 c;\n unsafe_bytes_set32 res 12 d);\n Md5_lib.unsafe_of_binary (Bytes.unsafe_to_string res)\n;;\n","include Bin_shape_lib.Std.Shape\n\n(* new base shapes *)\nlet bin_shape_unit = basetype (Uuid.of_string \"unit\") []\nlet bin_shape_bool = basetype (Uuid.of_string \"bool\") []\nlet bin_shape_string = basetype (Uuid.of_string \"string\") []\nlet bin_shape_bytes = basetype (Uuid.of_string \"bytes\") []\nlet bin_shape_char = basetype (Uuid.of_string \"char\") []\nlet bin_shape_float = basetype (Uuid.of_string \"float\") []\nlet bin_shape_int = basetype (Uuid.of_string \"int\") []\nlet bin_shape_int32 = basetype (Uuid.of_string \"int32\") []\nlet bin_shape_int63 = basetype (Uuid.of_string \"int63\") []\nlet bin_shape_int64 = basetype (Uuid.of_string \"int64\") []\nlet bin_shape_nativeint = basetype (Uuid.of_string \"nativeint\") []\nlet bin_shape_nat0 = basetype (Uuid.of_string \"nat0\") []\nlet bin_shape_digest = basetype (Uuid.of_string \"digest\") []\nlet bin_shape_float32_vec = basetype (Uuid.of_string \"float32_vec\") []\nlet bin_shape_float64_vec = basetype (Uuid.of_string \"float64_vec\") []\nlet bin_shape_vec = basetype (Uuid.of_string \"vec\") []\nlet bin_shape_float32_mat = basetype (Uuid.of_string \"float32_mat\") []\nlet bin_shape_float64_mat = basetype (Uuid.of_string \"float64_mat\") []\nlet bin_shape_mat = basetype (Uuid.of_string \"mat\") []\nlet bin_shape_bigstring = basetype (Uuid.of_string \"bigstring\") []\nlet bin_shape_variant_int = basetype (Uuid.of_string \"variant_int\") []\nlet bin_shape_int_8bit = basetype (Uuid.of_string \"int_8bit\") []\nlet bin_shape_int_16bit = basetype (Uuid.of_string \"int_16bit\") []\nlet bin_shape_int_32bit = basetype (Uuid.of_string \"int_32bit\") []\nlet bin_shape_int_64bit = basetype (Uuid.of_string \"int_64bit\") []\nlet bin_shape_int64_bits = basetype (Uuid.of_string \"int64_bits\") []\nlet bin_shape_network16_int = basetype (Uuid.of_string \"network16_int\") []\nlet bin_shape_network32_int = basetype (Uuid.of_string \"network32_int\") []\nlet bin_shape_network32_int32 = basetype (Uuid.of_string \"network32_int32\") []\nlet bin_shape_network64_int = basetype (Uuid.of_string \"network64_int\") []\nlet bin_shape_network64_int64 = basetype (Uuid.of_string \"network64_int64\") []\n\n(* new shape constructors *)\nlet bin_shape_ref x = basetype (Uuid.of_string \"ref\") [ x ]\nlet bin_shape_option x = basetype (Uuid.of_string \"option\") [ x ]\nlet bin_shape_list x = basetype (Uuid.of_string \"list\") [ x ]\nlet bin_shape_array x = basetype (Uuid.of_string \"array\") [ x ]\nlet bin_shape_hashtbl x y = basetype (Uuid.of_string \"hashtbl\") [ x; y ]\n\n(* shape alias *)\nlet bin_shape_float_array = bin_shape_array bin_shape_float\n\n(* shape-constructor aliases *)\nlet bin_shape_lazy x = x\nlet bin_shape_pair x y = tuple [ x; y ]\nlet bin_shape_triple x y z = tuple [ x; y; z ]\n","(* Size: compute size of values in the binary protocol. *)\n\nopen Bigarray\n\nlet arch_sixtyfour = Sys.word_size = 64\n\nopen Common\n\nmodule Maximum = struct\n let bin_size_unit = 1\n let bin_size_bool = 1\n let bin_size_char = 1\n let bin_size_md5 = 16\n let bin_size_int_nat0 = if arch_sixtyfour then 9 else 5\n let bin_size_int_negative = if arch_sixtyfour then 9 else 5\n let bin_size_int = max bin_size_int_nat0 bin_size_int_negative\n let bin_size_float = 8\n let bin_size_int32 = 5\n let bin_size_int64 = 9\n let bin_size_nativeint = bin_size_int\n let bin_size_nat0 = bin_size_int_nat0\n let bin_size_variant_int = 4\n let bin_size_int_8bit = 1\n let bin_size_int_16bit = 2\n let bin_size_int_32bit = 4\n let bin_size_int_64bit = 8\n let bin_size_int64_bits = 8\n let bin_size_network16_int = 2\n let bin_size_network32_int = 4\n let bin_size_network32_int32 = 4\n let bin_size_network64_int = 8\n let bin_size_network64_int64 = 8\nend\n\nmodule Minimum = struct\n let bin_size_unit = Maximum.bin_size_unit\n let bin_size_bool = Maximum.bin_size_bool\n let bin_size_char = Maximum.bin_size_char\n let bin_size_md5 = 16\n let bin_size_int_nat0 = 1\n let bin_size_int_negative = 2\n let bin_size_int = min bin_size_int_nat0 bin_size_int_negative\n let bin_size_float = Maximum.bin_size_float\n let bin_size_int32 = bin_size_int\n let bin_size_int64 = bin_size_int\n let bin_size_nativeint = bin_size_int\n let bin_size_nat0 = 1\n let bin_size_ref = 1\n let bin_size_lazy_t = 1\n let bin_size_option = 1\n let bin_size_pair = 1 + 1\n let bin_size_triple = 1 + 1 + 1\n let bin_size_len = bin_size_nat0\n let bin_size_list = bin_size_len\n let bin_size_array = bin_size_len\n let bin_size_hashtbl = bin_size_len\n let bin_size_string = bin_size_len\n let bin_size_bytes = bin_size_len\n let bin_size_vec = bin_size_len\n let bin_size_float32_vec = bin_size_vec\n let bin_size_float64_vec = bin_size_vec\n let bin_size_mat = bin_size_len + bin_size_len\n let bin_size_float32_mat = bin_size_mat\n let bin_size_float64_mat = bin_size_mat\n let bin_size_bigstring = bin_size_len\n let bin_size_float_array = bin_size_len\n let bin_size_variant_int = Maximum.bin_size_variant_int\n let bin_size_int_8bit = Maximum.bin_size_int_8bit\n let bin_size_int_16bit = Maximum.bin_size_int_16bit\n let bin_size_int_32bit = Maximum.bin_size_int_32bit\n let bin_size_int_64bit = Maximum.bin_size_int_64bit\n let bin_size_int64_bits = Maximum.bin_size_int64_bits\n let bin_size_network16_int = Maximum.bin_size_network16_int\n let bin_size_network32_int = Maximum.bin_size_network32_int\n let bin_size_network32_int32 = Maximum.bin_size_network32_int32\n let bin_size_network64_int = Maximum.bin_size_network64_int\n let bin_size_network64_int64 = Maximum.bin_size_network64_int64\nend\n\ntype 'a sizer = 'a -> int\ntype ('a, 'b) sizer1 = 'a sizer -> 'b sizer\ntype ('a, 'b, 'c) sizer2 = 'a sizer -> ('b, 'c) sizer1\ntype ('a, 'b, 'c, 'd) sizer3 = 'a sizer -> ('b, 'c, 'd) sizer2\n\nlet bin_size_unit () = 1\nlet bin_size_bool _ = 1\n\nlet bin_size_int_nat0 n =\n if n < 0x00000080\n then 1\n else if n < 0x00008000\n then 3\n else if arch_sixtyfour && n >= (* 0x80000000 *) 1 lsl 31\n then 9\n else 5\n;;\n\nlet bin_size_int_negative n =\n if n >= -0x00000080\n then 2\n else if n >= -0x00008000\n then 3\n else if arch_sixtyfour && n < (* -0x80000000 *) -(1 lsl 31)\n then 9\n else 5\n;;\n\nlet bin_size_char _ = 1\nlet bin_size_int n = if n >= 0 then bin_size_int_nat0 n else bin_size_int_negative n\n\nlet bin_size_nat0 nat0 =\n let n = (nat0 : Nat0.t :> int) in\n if n < 0x00000080\n then 1\n else if n < 0x00010000\n then 3\n else if arch_sixtyfour && n >= (* 0x100000000 *) 1 lsl 32\n then 9\n else 5\n;;\n\nlet bin_size_string_or_bytes len =\n let plen = Nat0.unsafe_of_int len in\n let size_len = bin_size_nat0 plen in\n size_len + len\n;;\n\nlet bin_size_string str = bin_size_string_or_bytes (String.length str)\nlet bin_size_bytes str = bin_size_string_or_bytes (Bytes.length str)\nlet bin_size_md5 _ = 16\n\nlet bin_size_float f =\n (* If we just ignore the argument the compiler will still require it to exist and be\n boxed. This means that if for instance we call this for a field of a float record,\n the compiler will allocate the float for nothing.\n\n With this line the compiler really ignores the float. *)\n ignore (truncate f);\n 8\n;;\n\nlet bin_size_int32 =\n if arch_sixtyfour\n then fun n -> bin_size_int (Int32.to_int n)\n else\n fun n ->\n if n >= 0x00008000l || n < -0x00008000l then 5 else bin_size_int (Int32.to_int n)\n;;\n\nlet bin_size_int64 =\n if arch_sixtyfour\n then\n fun n ->\n if n >= 0x80000000L || n < -0x80000000L then 9 else bin_size_int (Int64.to_int n)\n else\n fun n ->\n if n >= 0x80000000L || n < -0x80000000L then 9 else bin_size_int32 (Int64.to_int32 n)\n;;\n\nlet bin_size_nativeint =\n if arch_sixtyfour\n then fun n -> bin_size_int64 (Int64.of_nativeint n)\n else fun n -> bin_size_int32 (Nativeint.to_int32 n)\n;;\n\nlet bin_size_ref bin_size_el r = bin_size_el !r\nlet bin_size_lazy_t bin_size_el lv = bin_size_el (Lazy.force lv)\nlet bin_size_lazy = bin_size_lazy_t\n\nlet bin_size_option bin_size_el = function\n | None -> 1\n | Some v -> 1 + bin_size_el v\n;;\n\nlet bin_size_pair bin_size_a bin_size_b (a, b) = bin_size_a a + bin_size_b b\n\nlet bin_size_triple bin_size_a bin_size_b bin_size_c (a, b, c) =\n bin_size_a a + bin_size_b b + bin_size_c c\n;;\n\nlet bin_size_list bin_size_el lst =\n let rec loop len = function\n | [] -> len\n | h :: t -> loop (len + bin_size_el h) t\n in\n let len = Nat0.unsafe_of_int (List.length lst) in\n let size_len = bin_size_nat0 len in\n loop size_len lst\n;;\n\nlet bin_size_len len =\n let plen = Nat0.unsafe_of_int len in\n bin_size_nat0 plen\n;;\n\nlet bin_size_float_array ar =\n let len = Array.length ar in\n bin_size_len len + (8 * len)\n;;\n\nlet bin_size_array_loop bin_size_el ar ~total_len ~n =\n let total_len_ref = ref total_len in\n for i = 0 to n - 1 do\n let el = Array.unsafe_get ar i in\n total_len_ref := !total_len_ref + bin_size_el el\n done;\n !total_len_ref\n;;\n\nlet bin_size_array (type a) bin_size_el ar =\n if (Obj.magic (bin_size_el : a sizer) : float sizer) == bin_size_float\n then bin_size_float_array (Obj.magic (ar : a array) : float array)\n else (\n let n = Array.length ar in\n let total_len = bin_size_len n in\n bin_size_array_loop bin_size_el ar ~total_len ~n)\n;;\n\nlet bin_size_hashtbl bin_size_key bin_size_val htbl =\n let cnt_ref = ref 0 in\n let coll_htbl k v total_len =\n incr cnt_ref;\n total_len + bin_size_key k + bin_size_val v\n in\n let len = Hashtbl.length htbl in\n let total_len = Hashtbl.fold coll_htbl htbl (bin_size_len len) in\n if !cnt_ref <> len then raise_concurrent_modification \"bin_size_hashtbl\";\n total_len\n;;\n\nlet bin_size_gen_vec vec multiplier =\n let len = Array1.dim vec in\n bin_size_len len + (multiplier * len)\n;;\n\nlet bin_size_float32_vec vec = bin_size_gen_vec vec 4\nlet bin_size_float64_vec vec = bin_size_gen_vec vec 8\nlet bin_size_vec = bin_size_float64_vec\n\nlet bin_size_gen_mat mat multiplier =\n let dim1 = Array2.dim1 mat in\n let dim2 = Array2.dim2 mat in\n let size = dim1 * dim2 in\n bin_size_len dim1 + bin_size_len dim2 + (multiplier * size)\n;;\n\nlet bin_size_float32_mat mat = bin_size_gen_mat mat 4\nlet bin_size_float64_mat mat = bin_size_gen_mat mat 8\nlet bin_size_mat = bin_size_float64_mat\nlet bin_size_bigstring buf = bin_size_gen_vec buf 1\nlet bin_size_variant_int _ = 4\nlet bin_size_int_8bit _ = 1\nlet bin_size_int_16bit _ = 2\nlet bin_size_int_32bit _ = 4\nlet bin_size_int_64bit _ = 8\nlet bin_size_int64_bits _ = 8\nlet bin_size_network16_int _ = 2\nlet bin_size_network32_int _ = 4\nlet bin_size_network32_int32 _ = 4\nlet bin_size_network64_int _ = 8\nlet bin_size_network64_int64 _ = 8\n\nlet bin_size_array_no_length bin_size_el ar =\n bin_size_array_loop bin_size_el ar ~total_len:0 ~n:(Array.length ar)\n;;\n","(* Tp_class: sizers, writers, and readers in records *)\n\ntype 'a writer =\n { size : 'a Size.sizer\n ; write : 'a Write.writer\n }\n\ntype 'a reader =\n { read : 'a Read.reader\n ; vtag_read : (int -> 'a) Read.reader\n }\n\ntype 'a t =\n { shape : Shape.t\n ; writer : 'a writer\n ; reader : 'a reader\n }\n\ntype 'a writer0 = 'a writer\ntype 'a reader0 = 'a reader\ntype 'a t0 = 'a t\n\nmodule S1 = struct\n type ('a, 'b) writer = 'a writer0 -> 'b writer0\n type ('a, 'b) reader = 'a reader0 -> 'b reader0\n type ('a, 'b) t = 'a t0 -> 'b t0\nend\n\nmodule S2 = struct\n type ('a, 'b, 'c) writer = 'a writer0 -> ('b, 'c) S1.writer\n type ('a, 'b, 'c) reader = 'a reader0 -> ('b, 'c) S1.reader\n type ('a, 'b, 'c) t = 'a t0 -> ('b, 'c) S1.t\nend\n\nmodule S3 = struct\n type ('a, 'b, 'c, 'd) writer = 'a writer0 -> ('b, 'c, 'd) S2.writer\n type ('a, 'b, 'c, 'd) reader = 'a reader0 -> ('b, 'c, 'd) S2.reader\n type ('a, 'b, 'c, 'd) t = 'a t0 -> ('b, 'c, 'd) S2.t\nend\n\nlet variant_wrong_type name _buf ~pos_ref _x =\n Common.raise_variant_wrong_type name !pos_ref\n;;\n\n(*$ open Bin_prot_cinaps.Str *)\n(*$ mk_base \"unit\" *)\nlet bin_writer_unit = { size = Size.bin_size_unit; write = Write.bin_write_unit }\n\nlet bin_reader_unit =\n { read = Read.bin_read_unit; vtag_read = variant_wrong_type \"unit\" }\n;;\n\nlet bin_shape_unit = Shape.bin_shape_unit\n\nlet bin_unit =\n { shape = bin_shape_unit; writer = bin_writer_unit; reader = bin_reader_unit }\n;;\n\n(*$ mk_base \"bool\" *)\nlet bin_writer_bool = { size = Size.bin_size_bool; write = Write.bin_write_bool }\n\nlet bin_reader_bool =\n { read = Read.bin_read_bool; vtag_read = variant_wrong_type \"bool\" }\n;;\n\nlet bin_shape_bool = Shape.bin_shape_bool\n\nlet bin_bool =\n { shape = bin_shape_bool; writer = bin_writer_bool; reader = bin_reader_bool }\n;;\n\n(*$ mk_base \"string\" *)\nlet bin_writer_string = { size = Size.bin_size_string; write = Write.bin_write_string }\n\nlet bin_reader_string =\n { read = Read.bin_read_string; vtag_read = variant_wrong_type \"string\" }\n;;\n\nlet bin_shape_string = Shape.bin_shape_string\n\nlet bin_string =\n { shape = bin_shape_string; writer = bin_writer_string; reader = bin_reader_string }\n;;\n\n(*$ mk_base \"bytes\" *)\nlet bin_writer_bytes = { size = Size.bin_size_bytes; write = Write.bin_write_bytes }\n\nlet bin_reader_bytes =\n { read = Read.bin_read_bytes; vtag_read = variant_wrong_type \"bytes\" }\n;;\n\nlet bin_shape_bytes = Shape.bin_shape_bytes\n\nlet bin_bytes =\n { shape = bin_shape_bytes; writer = bin_writer_bytes; reader = bin_reader_bytes }\n;;\n\n(*$ mk_base \"char\" *)\nlet bin_writer_char = { size = Size.bin_size_char; write = Write.bin_write_char }\n\nlet bin_reader_char =\n { read = Read.bin_read_char; vtag_read = variant_wrong_type \"char\" }\n;;\n\nlet bin_shape_char = Shape.bin_shape_char\n\nlet bin_char =\n { shape = bin_shape_char; writer = bin_writer_char; reader = bin_reader_char }\n;;\n\n(*$ mk_base \"int\" *)\nlet bin_writer_int = { size = Size.bin_size_int; write = Write.bin_write_int }\nlet bin_reader_int = { read = Read.bin_read_int; vtag_read = variant_wrong_type \"int\" }\nlet bin_shape_int = Shape.bin_shape_int\nlet bin_int = { shape = bin_shape_int; writer = bin_writer_int; reader = bin_reader_int }\n\n(*$ mk_base \"float\" *)\nlet bin_writer_float = { size = Size.bin_size_float; write = Write.bin_write_float }\n\nlet bin_reader_float =\n { read = Read.bin_read_float; vtag_read = variant_wrong_type \"float\" }\n;;\n\nlet bin_shape_float = Shape.bin_shape_float\n\nlet bin_float =\n { shape = bin_shape_float; writer = bin_writer_float; reader = bin_reader_float }\n;;\n\n(*$ mk_base \"int32\" *)\nlet bin_writer_int32 = { size = Size.bin_size_int32; write = Write.bin_write_int32 }\n\nlet bin_reader_int32 =\n { read = Read.bin_read_int32; vtag_read = variant_wrong_type \"int32\" }\n;;\n\nlet bin_shape_int32 = Shape.bin_shape_int32\n\nlet bin_int32 =\n { shape = bin_shape_int32; writer = bin_writer_int32; reader = bin_reader_int32 }\n;;\n\n(*$ mk_base \"int64\" *)\nlet bin_writer_int64 = { size = Size.bin_size_int64; write = Write.bin_write_int64 }\n\nlet bin_reader_int64 =\n { read = Read.bin_read_int64; vtag_read = variant_wrong_type \"int64\" }\n;;\n\nlet bin_shape_int64 = Shape.bin_shape_int64\n\nlet bin_int64 =\n { shape = bin_shape_int64; writer = bin_writer_int64; reader = bin_reader_int64 }\n;;\n\n(*$ mk_base \"nativeint\" *)\nlet bin_writer_nativeint =\n { size = Size.bin_size_nativeint; write = Write.bin_write_nativeint }\n;;\n\nlet bin_reader_nativeint =\n { read = Read.bin_read_nativeint; vtag_read = variant_wrong_type \"nativeint\" }\n;;\n\nlet bin_shape_nativeint = Shape.bin_shape_nativeint\n\nlet bin_nativeint =\n { shape = bin_shape_nativeint\n ; writer = bin_writer_nativeint\n ; reader = bin_reader_nativeint\n }\n;;\n\n(*$ mk_base \"nat0\" *)\nlet bin_writer_nat0 = { size = Size.bin_size_nat0; write = Write.bin_write_nat0 }\n\nlet bin_reader_nat0 =\n { read = Read.bin_read_nat0; vtag_read = variant_wrong_type \"nat0\" }\n;;\n\nlet bin_shape_nat0 = Shape.bin_shape_nat0\n\nlet bin_nat0 =\n { shape = bin_shape_nat0; writer = bin_writer_nat0; reader = bin_reader_nat0 }\n;;\n\n(*$ mk_base1 \"ref\" *)\nlet bin_writer_ref bin_writer_el =\n { size = (fun v -> Size.bin_size_ref bin_writer_el.size v)\n ; write = (fun buf ~pos v -> Write.bin_write_ref bin_writer_el.write buf ~pos v)\n }\n;;\n\nlet bin_reader_ref bin_reader_el =\n { read = (fun buf ~pos_ref -> Read.bin_read_ref bin_reader_el.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"ref\"\n }\n;;\n\nlet bin_shape_ref x1 = Shape.bin_shape_ref x1\n\nlet bin_ref bin_el =\n { shape = bin_shape_ref bin_el.shape\n ; writer = bin_writer_ref bin_el.writer\n ; reader = bin_reader_ref bin_el.reader\n }\n;;\n\n(*$ mk_base1 \"lazy\" *)\nlet bin_writer_lazy bin_writer_el =\n { size = (fun v -> Size.bin_size_lazy bin_writer_el.size v)\n ; write = (fun buf ~pos v -> Write.bin_write_lazy bin_writer_el.write buf ~pos v)\n }\n;;\n\nlet bin_reader_lazy bin_reader_el =\n { read = (fun buf ~pos_ref -> Read.bin_read_lazy bin_reader_el.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"lazy\"\n }\n;;\n\nlet bin_shape_lazy x1 = Shape.bin_shape_lazy x1\n\nlet bin_lazy bin_el =\n { shape = bin_shape_lazy bin_el.shape\n ; writer = bin_writer_lazy bin_el.writer\n ; reader = bin_reader_lazy bin_el.reader\n }\n;;\n\n(*$ mk_base1 \"option\" *)\nlet bin_writer_option bin_writer_el =\n { size = (fun v -> Size.bin_size_option bin_writer_el.size v)\n ; write = (fun buf ~pos v -> Write.bin_write_option bin_writer_el.write buf ~pos v)\n }\n;;\n\nlet bin_reader_option bin_reader_el =\n { read = (fun buf ~pos_ref -> Read.bin_read_option bin_reader_el.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"option\"\n }\n;;\n\nlet bin_shape_option x1 = Shape.bin_shape_option x1\n\nlet bin_option bin_el =\n { shape = bin_shape_option bin_el.shape\n ; writer = bin_writer_option bin_el.writer\n ; reader = bin_reader_option bin_el.reader\n }\n;;\n\n(*$ mk_base2 \"pair\" *)\nlet bin_writer_pair bin_writer_el1 bin_writer_el2 =\n { size = (fun v -> Size.bin_size_pair bin_writer_el1.size bin_writer_el2.size v)\n ; write =\n (fun buf ~pos v ->\n Write.bin_write_pair bin_writer_el1.write bin_writer_el2.write buf ~pos v)\n }\n;;\n\nlet bin_reader_pair bin_reader_el1 bin_reader_el2 =\n { read =\n (fun buf ~pos_ref ->\n Read.bin_read_pair bin_reader_el1.read bin_reader_el2.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"pair\"\n }\n;;\n\nlet bin_shape_pair x1 x2 = Shape.bin_shape_pair x1 x2\n\nlet bin_pair bin_el1 bin_el2 =\n { shape = bin_shape_pair bin_el1.shape bin_el2.shape\n ; writer = bin_writer_pair bin_el1.writer bin_el2.writer\n ; reader = bin_reader_pair bin_el1.reader bin_el2.reader\n }\n;;\n\n(*$ mk_base3 \"triple\" *)\nlet bin_writer_triple bin_writer_el1 bin_writer_el2 bin_writer_el3 =\n { size =\n (fun v ->\n Size.bin_size_triple\n bin_writer_el1.size\n bin_writer_el2.size\n bin_writer_el3.size\n v)\n ; write =\n (fun buf ~pos v ->\n Write.bin_write_triple\n bin_writer_el1.write\n bin_writer_el2.write\n bin_writer_el3.write\n buf\n ~pos\n v)\n }\n;;\n\nlet bin_reader_triple bin_reader_el1 bin_reader_el2 bin_reader_el3 =\n { read =\n (fun buf ~pos_ref ->\n Read.bin_read_triple\n bin_reader_el1.read\n bin_reader_el2.read\n bin_reader_el3.read\n buf\n ~pos_ref)\n ; vtag_read = variant_wrong_type \"triple\"\n }\n;;\n\nlet bin_shape_triple x1 x2 x3 = Shape.bin_shape_triple x1 x2 x3\n\nlet bin_triple bin_el1 bin_el2 bin_el3 =\n { shape = bin_shape_triple bin_el1.shape bin_el2.shape bin_el3.shape\n ; writer = bin_writer_triple bin_el1.writer bin_el2.writer bin_el3.writer\n ; reader = bin_reader_triple bin_el1.reader bin_el2.reader bin_el3.reader\n }\n;;\n\n(*$ mk_base1 \"list\" *)\nlet bin_writer_list bin_writer_el =\n { size = (fun v -> Size.bin_size_list bin_writer_el.size v)\n ; write = (fun buf ~pos v -> Write.bin_write_list bin_writer_el.write buf ~pos v)\n }\n;;\n\nlet bin_reader_list bin_reader_el =\n { read = (fun buf ~pos_ref -> Read.bin_read_list bin_reader_el.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"list\"\n }\n;;\n\nlet bin_shape_list x1 = Shape.bin_shape_list x1\n\nlet bin_list bin_el =\n { shape = bin_shape_list bin_el.shape\n ; writer = bin_writer_list bin_el.writer\n ; reader = bin_reader_list bin_el.reader\n }\n;;\n\n(*$ mk_base1 \"array\" *)\nlet bin_writer_array bin_writer_el =\n { size = (fun v -> Size.bin_size_array bin_writer_el.size v)\n ; write = (fun buf ~pos v -> Write.bin_write_array bin_writer_el.write buf ~pos v)\n }\n;;\n\nlet bin_reader_array bin_reader_el =\n { read = (fun buf ~pos_ref -> Read.bin_read_array bin_reader_el.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"array\"\n }\n;;\n\nlet bin_shape_array x1 = Shape.bin_shape_array x1\n\nlet bin_array bin_el =\n { shape = bin_shape_array bin_el.shape\n ; writer = bin_writer_array bin_el.writer\n ; reader = bin_reader_array bin_el.reader\n }\n;;\n\n(*$ mk_base2 \"hashtbl\" *)\nlet bin_writer_hashtbl bin_writer_el1 bin_writer_el2 =\n { size = (fun v -> Size.bin_size_hashtbl bin_writer_el1.size bin_writer_el2.size v)\n ; write =\n (fun buf ~pos v ->\n Write.bin_write_hashtbl bin_writer_el1.write bin_writer_el2.write buf ~pos v)\n }\n;;\n\nlet bin_reader_hashtbl bin_reader_el1 bin_reader_el2 =\n { read =\n (fun buf ~pos_ref ->\n Read.bin_read_hashtbl bin_reader_el1.read bin_reader_el2.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"hashtbl\"\n }\n;;\n\nlet bin_shape_hashtbl x1 x2 = Shape.bin_shape_hashtbl x1 x2\n\nlet bin_hashtbl bin_el1 bin_el2 =\n { shape = bin_shape_hashtbl bin_el1.shape bin_el2.shape\n ; writer = bin_writer_hashtbl bin_el1.writer bin_el2.writer\n ; reader = bin_reader_hashtbl bin_el1.reader bin_el2.reader\n }\n;;\n\n(*$ mk_base \"float32_vec\" *)\nlet bin_writer_float32_vec =\n { size = Size.bin_size_float32_vec; write = Write.bin_write_float32_vec }\n;;\n\nlet bin_reader_float32_vec =\n { read = Read.bin_read_float32_vec; vtag_read = variant_wrong_type \"float32_vec\" }\n;;\n\nlet bin_shape_float32_vec = Shape.bin_shape_float32_vec\n\nlet bin_float32_vec =\n { shape = bin_shape_float32_vec\n ; writer = bin_writer_float32_vec\n ; reader = bin_reader_float32_vec\n }\n;;\n\n(*$ mk_base \"float64_vec\" *)\nlet bin_writer_float64_vec =\n { size = Size.bin_size_float64_vec; write = Write.bin_write_float64_vec }\n;;\n\nlet bin_reader_float64_vec =\n { read = Read.bin_read_float64_vec; vtag_read = variant_wrong_type \"float64_vec\" }\n;;\n\nlet bin_shape_float64_vec = Shape.bin_shape_float64_vec\n\nlet bin_float64_vec =\n { shape = bin_shape_float64_vec\n ; writer = bin_writer_float64_vec\n ; reader = bin_reader_float64_vec\n }\n;;\n\n(*$ mk_base \"vec\" *)\nlet bin_writer_vec = { size = Size.bin_size_vec; write = Write.bin_write_vec }\nlet bin_reader_vec = { read = Read.bin_read_vec; vtag_read = variant_wrong_type \"vec\" }\nlet bin_shape_vec = Shape.bin_shape_vec\nlet bin_vec = { shape = bin_shape_vec; writer = bin_writer_vec; reader = bin_reader_vec }\n\n(*$ mk_base \"float32_mat\" *)\nlet bin_writer_float32_mat =\n { size = Size.bin_size_float32_mat; write = Write.bin_write_float32_mat }\n;;\n\nlet bin_reader_float32_mat =\n { read = Read.bin_read_float32_mat; vtag_read = variant_wrong_type \"float32_mat\" }\n;;\n\nlet bin_shape_float32_mat = Shape.bin_shape_float32_mat\n\nlet bin_float32_mat =\n { shape = bin_shape_float32_mat\n ; writer = bin_writer_float32_mat\n ; reader = bin_reader_float32_mat\n }\n;;\n\n(*$ mk_base \"float64_mat\" *)\nlet bin_writer_float64_mat =\n { size = Size.bin_size_float64_mat; write = Write.bin_write_float64_mat }\n;;\n\nlet bin_reader_float64_mat =\n { read = Read.bin_read_float64_mat; vtag_read = variant_wrong_type \"float64_mat\" }\n;;\n\nlet bin_shape_float64_mat = Shape.bin_shape_float64_mat\n\nlet bin_float64_mat =\n { shape = bin_shape_float64_mat\n ; writer = bin_writer_float64_mat\n ; reader = bin_reader_float64_mat\n }\n;;\n\n(*$ mk_base \"mat\" *)\nlet bin_writer_mat = { size = Size.bin_size_mat; write = Write.bin_write_mat }\nlet bin_reader_mat = { read = Read.bin_read_mat; vtag_read = variant_wrong_type \"mat\" }\nlet bin_shape_mat = Shape.bin_shape_mat\nlet bin_mat = { shape = bin_shape_mat; writer = bin_writer_mat; reader = bin_reader_mat }\n\n(*$ mk_base \"bigstring\" *)\nlet bin_writer_bigstring =\n { size = Size.bin_size_bigstring; write = Write.bin_write_bigstring }\n;;\n\nlet bin_reader_bigstring =\n { read = Read.bin_read_bigstring; vtag_read = variant_wrong_type \"bigstring\" }\n;;\n\nlet bin_shape_bigstring = Shape.bin_shape_bigstring\n\nlet bin_bigstring =\n { shape = bin_shape_bigstring\n ; writer = bin_writer_bigstring\n ; reader = bin_reader_bigstring\n }\n;;\n\n(*$*)\ntype float_array = float array\n\n(*$ mk_base \"float_array\" *)\nlet bin_writer_float_array =\n { size = Size.bin_size_float_array; write = Write.bin_write_float_array }\n;;\n\nlet bin_reader_float_array =\n { read = Read.bin_read_float_array; vtag_read = variant_wrong_type \"float_array\" }\n;;\n\nlet bin_shape_float_array = Shape.bin_shape_float_array\n\nlet bin_float_array =\n { shape = bin_shape_float_array\n ; writer = bin_writer_float_array\n ; reader = bin_reader_float_array\n }\n;;\n\n(*$ mk_base \"variant_int\" *)\nlet bin_writer_variant_int =\n { size = Size.bin_size_variant_int; write = Write.bin_write_variant_int }\n;;\n\nlet bin_reader_variant_int =\n { read = Read.bin_read_variant_int; vtag_read = variant_wrong_type \"variant_int\" }\n;;\n\nlet bin_shape_variant_int = Shape.bin_shape_variant_int\n\nlet bin_variant_int =\n { shape = bin_shape_variant_int\n ; writer = bin_writer_variant_int\n ; reader = bin_reader_variant_int\n }\n;;\n\n(*$ mk_base \"int_8bit\" *)\nlet bin_writer_int_8bit =\n { size = Size.bin_size_int_8bit; write = Write.bin_write_int_8bit }\n;;\n\nlet bin_reader_int_8bit =\n { read = Read.bin_read_int_8bit; vtag_read = variant_wrong_type \"int_8bit\" }\n;;\n\nlet bin_shape_int_8bit = Shape.bin_shape_int_8bit\n\nlet bin_int_8bit =\n { shape = bin_shape_int_8bit\n ; writer = bin_writer_int_8bit\n ; reader = bin_reader_int_8bit\n }\n;;\n\n(*$ mk_base \"int_16bit\" *)\nlet bin_writer_int_16bit =\n { size = Size.bin_size_int_16bit; write = Write.bin_write_int_16bit }\n;;\n\nlet bin_reader_int_16bit =\n { read = Read.bin_read_int_16bit; vtag_read = variant_wrong_type \"int_16bit\" }\n;;\n\nlet bin_shape_int_16bit = Shape.bin_shape_int_16bit\n\nlet bin_int_16bit =\n { shape = bin_shape_int_16bit\n ; writer = bin_writer_int_16bit\n ; reader = bin_reader_int_16bit\n }\n;;\n\n(*$ mk_base \"int_32bit\" *)\nlet bin_writer_int_32bit =\n { size = Size.bin_size_int_32bit; write = Write.bin_write_int_32bit }\n;;\n\nlet bin_reader_int_32bit =\n { read = Read.bin_read_int_32bit; vtag_read = variant_wrong_type \"int_32bit\" }\n;;\n\nlet bin_shape_int_32bit = Shape.bin_shape_int_32bit\n\nlet bin_int_32bit =\n { shape = bin_shape_int_32bit\n ; writer = bin_writer_int_32bit\n ; reader = bin_reader_int_32bit\n }\n;;\n\n(*$ mk_base \"int_64bit\" *)\nlet bin_writer_int_64bit =\n { size = Size.bin_size_int_64bit; write = Write.bin_write_int_64bit }\n;;\n\nlet bin_reader_int_64bit =\n { read = Read.bin_read_int_64bit; vtag_read = variant_wrong_type \"int_64bit\" }\n;;\n\nlet bin_shape_int_64bit = Shape.bin_shape_int_64bit\n\nlet bin_int_64bit =\n { shape = bin_shape_int_64bit\n ; writer = bin_writer_int_64bit\n ; reader = bin_reader_int_64bit\n }\n;;\n\n(*$ mk_base \"int64_bits\" *)\nlet bin_writer_int64_bits =\n { size = Size.bin_size_int64_bits; write = Write.bin_write_int64_bits }\n;;\n\nlet bin_reader_int64_bits =\n { read = Read.bin_read_int64_bits; vtag_read = variant_wrong_type \"int64_bits\" }\n;;\n\nlet bin_shape_int64_bits = Shape.bin_shape_int64_bits\n\nlet bin_int64_bits =\n { shape = bin_shape_int64_bits\n ; writer = bin_writer_int64_bits\n ; reader = bin_reader_int64_bits\n }\n;;\n\n(*$ mk_base \"network16_int\" *)\nlet bin_writer_network16_int =\n { size = Size.bin_size_network16_int; write = Write.bin_write_network16_int }\n;;\n\nlet bin_reader_network16_int =\n { read = Read.bin_read_network16_int; vtag_read = variant_wrong_type \"network16_int\" }\n;;\n\nlet bin_shape_network16_int = Shape.bin_shape_network16_int\n\nlet bin_network16_int =\n { shape = bin_shape_network16_int\n ; writer = bin_writer_network16_int\n ; reader = bin_reader_network16_int\n }\n;;\n\n(*$ mk_base \"network32_int\" *)\nlet bin_writer_network32_int =\n { size = Size.bin_size_network32_int; write = Write.bin_write_network32_int }\n;;\n\nlet bin_reader_network32_int =\n { read = Read.bin_read_network32_int; vtag_read = variant_wrong_type \"network32_int\" }\n;;\n\nlet bin_shape_network32_int = Shape.bin_shape_network32_int\n\nlet bin_network32_int =\n { shape = bin_shape_network32_int\n ; writer = bin_writer_network32_int\n ; reader = bin_reader_network32_int\n }\n;;\n\n(*$ mk_base \"network32_int32\" *)\nlet bin_writer_network32_int32 =\n { size = Size.bin_size_network32_int32; write = Write.bin_write_network32_int32 }\n;;\n\nlet bin_reader_network32_int32 =\n { read = Read.bin_read_network32_int32\n ; vtag_read = variant_wrong_type \"network32_int32\"\n }\n;;\n\nlet bin_shape_network32_int32 = Shape.bin_shape_network32_int32\n\nlet bin_network32_int32 =\n { shape = bin_shape_network32_int32\n ; writer = bin_writer_network32_int32\n ; reader = bin_reader_network32_int32\n }\n;;\n\n(*$ mk_base \"network64_int\" *)\nlet bin_writer_network64_int =\n { size = Size.bin_size_network64_int; write = Write.bin_write_network64_int }\n;;\n\nlet bin_reader_network64_int =\n { read = Read.bin_read_network64_int; vtag_read = variant_wrong_type \"network64_int\" }\n;;\n\nlet bin_shape_network64_int = Shape.bin_shape_network64_int\n\nlet bin_network64_int =\n { shape = bin_shape_network64_int\n ; writer = bin_writer_network64_int\n ; reader = bin_reader_network64_int\n }\n;;\n\n(*$ mk_base \"network64_int64\" *)\nlet bin_writer_network64_int64 =\n { size = Size.bin_size_network64_int64; write = Write.bin_write_network64_int64 }\n;;\n\nlet bin_reader_network64_int64 =\n { read = Read.bin_read_network64_int64\n ; vtag_read = variant_wrong_type \"network64_int64\"\n }\n;;\n\nlet bin_shape_network64_int64 = Shape.bin_shape_network64_int64\n\nlet bin_network64_int64 =\n { shape = bin_shape_network64_int64\n ; writer = bin_writer_network64_int64\n ; reader = bin_reader_network64_int64\n }\n;;\n\n(*$*)\nlet bin_writer_array_no_length bin_writer_el =\n { size =\n (fun v -> (Size.bin_size_array_no_length [@warning \"-3\"]) bin_writer_el.size v)\n ; write =\n (fun buf ~pos v ->\n (Write.bin_write_array_no_length [@warning \"-3\"]) bin_writer_el.write buf ~pos v)\n }\n;;\n\n(* Conversion of binable types *)\n\nlet cnv_writer cnv tp_class =\n { size = (fun v -> tp_class.size (cnv v))\n ; write = (fun buf ~pos v -> tp_class.write buf ~pos (cnv v))\n }\n;;\n\nlet cnv_reader cnv tp_class =\n { read = (fun buf ~pos_ref -> cnv (tp_class.read buf ~pos_ref))\n ; vtag_read = (fun buf ~pos_ref vtag -> cnv (tp_class.vtag_read buf ~pos_ref vtag))\n }\n;;\n\nlet cnv for_shape for_writer for_reader tp_class =\n { shape = for_shape tp_class.shape\n ; writer = cnv_writer for_writer tp_class.writer\n ; reader = cnv_reader for_reader tp_class.reader\n }\n;;\n","(* Utils: utility functions for user convenience *)\n\nopen Common\nopen Size\nopen Type_class\ninclude Utils_intf\n\nlet size_header_length = 8\nlet bin_write_size_header = Write.bin_write_int_64bit\nlet bin_read_size_header = Read.bin_read_int_64bit\n\nlet bin_dump ?(header = false) writer v =\n let buf, pos, pos_len =\n let v_len = writer.size v in\n if header\n then (\n let tot_len = v_len + size_header_length in\n let buf = create_buf tot_len in\n let pos = bin_write_size_header buf ~pos:0 v_len in\n buf, pos, pos + v_len)\n else (\n let buf = create_buf v_len in\n buf, 0, v_len)\n in\n let pos = writer.write buf ~pos v in\n if pos = pos_len\n then buf\n else failwith \"Bin_prot.Utils.bin_dump: size changed during writing\"\n;;\n\n(* Reading from streams *)\n\nlet bin_read_stream ?max_size ~read reader =\n let buf = create_buf size_header_length in\n read buf ~pos:0 ~len:size_header_length;\n let pos_ref = ref 0 in\n let len = bin_read_size_header buf ~pos_ref in\n match max_size with\n | Some max_size when len > max_size ->\n failwith\n (Printf.sprintf\n \"Bin_prot.Utils.bin_read_stream: size exceeds max_size: %d > %d\"\n len\n max_size)\n | _ ->\n let buf = if len > size_header_length then create_buf len else buf in\n read buf ~pos:0 ~len;\n pos_ref := 0;\n let res = reader.read buf ~pos_ref in\n if !pos_ref = len\n then res\n else (\n let msg =\n Printf.sprintf\n \"Bin_prot.Utils.bin_read_stream: protocol lied about length of value: \\\n expected %d, received %d\"\n len\n !pos_ref\n in\n failwith msg)\n;;\n\n(* Conversion of binable types *)\n\nmodule Of_minimal (S : Binable.Minimal.S) : Binable.S with type t := S.t = struct\n include S\n\n let bin_writer_t = { size = bin_size_t; write = bin_write_t }\n let bin_reader_t = { read = bin_read_t; vtag_read = __bin_read_t__ }\n let bin_t = { shape = bin_shape_t; writer = bin_writer_t; reader = bin_reader_t }\nend\n\nlet maybe_annotate_shape maybe_uuid shape =\n match maybe_uuid with\n | None -> shape\n | Some uuid -> Shape.annotate uuid shape\n;;\n\nmodule Make_binable_gen (S : sig\n include Make_binable_without_uuid_spec\n\n val maybe_caller_identity : Shape.Uuid.t option\n end) =\nstruct\n include Of_minimal (struct\n module B = S.Binable\n\n type t = S.t\n\n let bin_shape_t = maybe_annotate_shape S.maybe_caller_identity B.bin_shape_t\n let bin_size_t t = B.bin_size_t (S.to_binable t)\n let bin_write_t buf ~pos t = B.bin_write_t buf ~pos (S.to_binable t)\n let bin_read_t buf ~pos_ref = S.of_binable (B.bin_read_t buf ~pos_ref)\n let __bin_read_t__ buf ~pos_ref n = S.of_binable (B.__bin_read_t__ buf ~pos_ref n)\n end)\nend\n\nmodule Make_binable1_gen (S : sig\n include Make_binable1_without_uuid_spec\n\n val maybe_caller_identity : Shape.Uuid.t option\n end) =\nstruct\n module B = S.Binable\n\n let bin_shape_t bin_shape_el =\n maybe_annotate_shape S.maybe_caller_identity (B.bin_shape_t bin_shape_el)\n ;;\n\n let bin_size_t bin_size_el t = B.bin_size_t bin_size_el (S.to_binable t)\n\n let bin_write_t bin_write_el buf ~pos t =\n B.bin_write_t bin_write_el buf ~pos (S.to_binable t)\n ;;\n\n let bin_read_t bin_read_el buf ~pos_ref =\n S.of_binable (B.bin_read_t bin_read_el buf ~pos_ref)\n ;;\n\n let __bin_read_t__ bin_read_el buf ~pos_ref n =\n S.of_binable (B.__bin_read_t__ bin_read_el buf ~pos_ref n)\n ;;\n\n let bin_writer_t bin_writer =\n { size = (fun v -> bin_size_t bin_writer.size v)\n ; write = (fun buf ~pos v -> bin_write_t bin_writer.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader =\n { read = (fun buf ~pos_ref -> bin_read_t bin_reader.read buf ~pos_ref)\n ; vtag_read =\n (fun _buf ~pos_ref _n ->\n raise_variant_wrong_type \"Bin_prot.Utils.Make_binable1.bin_reader_t\" !pos_ref)\n }\n ;;\n\n let bin_t type_class =\n { shape = bin_shape_t type_class.shape\n ; writer = bin_writer_t type_class.writer\n ; reader = bin_reader_t type_class.reader\n }\n ;;\nend\n\nmodule Make_binable2_gen (S : sig\n include Make_binable2_without_uuid_spec\n\n val maybe_caller_identity : Shape.Uuid.t option\n end) =\nstruct\n module B = S.Binable\n\n let bin_shape_t bin_shape_el1 bin_shape_el2 =\n maybe_annotate_shape\n S.maybe_caller_identity\n (B.bin_shape_t bin_shape_el1 bin_shape_el2)\n ;;\n\n let bin_size_t bin_size_el1 bin_size_el2 t =\n B.bin_size_t bin_size_el1 bin_size_el2 (S.to_binable t)\n ;;\n\n let bin_write_t bin_write_el1 bin_write_el2 buf ~pos t =\n B.bin_write_t bin_write_el1 bin_write_el2 buf ~pos (S.to_binable t)\n ;;\n\n let bin_read_t bin_read_el1 bin_read_el2 buf ~pos_ref =\n S.of_binable (B.bin_read_t bin_read_el1 bin_read_el2 buf ~pos_ref)\n ;;\n\n let __bin_read_t__ bin_read_el1 bin_read_el2 buf ~pos_ref n =\n S.of_binable (B.__bin_read_t__ bin_read_el1 bin_read_el2 buf ~pos_ref n)\n ;;\n\n let bin_writer_t bin_writer1 bin_writer2 =\n { size = (fun v -> bin_size_t bin_writer1.size bin_writer2.size v)\n ; write =\n (fun buf ~pos v -> bin_write_t bin_writer1.write bin_writer2.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader1 bin_reader2 =\n { read =\n (fun buf ~pos_ref -> bin_read_t bin_reader1.read bin_reader2.read buf ~pos_ref)\n ; vtag_read =\n (fun _buf ~pos_ref _n ->\n raise_variant_wrong_type \"Bin_prot.Utils.Make_binable2.bin_reader_t\" !pos_ref)\n }\n ;;\n\n let bin_t type_class1 type_class2 =\n { shape = bin_shape_t type_class1.shape type_class2.shape\n ; writer = bin_writer_t type_class1.writer type_class2.writer\n ; reader = bin_reader_t type_class1.reader type_class2.reader\n }\n ;;\nend\n\nmodule Make_binable3_gen (S : sig\n include Make_binable3_without_uuid_spec\n\n val maybe_caller_identity : Shape.Uuid.t option\n end) =\nstruct\n module B = S.Binable\n\n let bin_shape_t bin_shape_el1 bin_shape_el2 bin_shape_el3 =\n maybe_annotate_shape\n S.maybe_caller_identity\n (B.bin_shape_t bin_shape_el1 bin_shape_el2 bin_shape_el3)\n ;;\n\n let bin_size_t bin_size_el1 bin_size_el2 bin_size_el3 t =\n B.bin_size_t bin_size_el1 bin_size_el2 bin_size_el3 (S.to_binable t)\n ;;\n\n let bin_write_t bin_write_el1 bin_write_el2 bin_write_el3 buf ~pos t =\n B.bin_write_t bin_write_el1 bin_write_el2 bin_write_el3 buf ~pos (S.to_binable t)\n ;;\n\n let bin_read_t bin_read_el1 bin_read_el2 bin_read_el3 buf ~pos_ref =\n S.of_binable (B.bin_read_t bin_read_el1 bin_read_el2 bin_read_el3 buf ~pos_ref)\n ;;\n\n let __bin_read_t__ bin_read_el1 bin_read_el2 bin_read_el3 buf ~pos_ref n =\n S.of_binable (B.__bin_read_t__ bin_read_el1 bin_read_el2 bin_read_el3 buf ~pos_ref n)\n ;;\n\n let bin_writer_t bin_writer1 bin_writer2 bin_writer3 =\n { size = (fun v -> bin_size_t bin_writer1.size bin_writer2.size bin_writer3.size v)\n ; write =\n (fun buf ~pos v ->\n bin_write_t bin_writer1.write bin_writer2.write bin_writer3.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader1 bin_reader2 bin_reader3 =\n { read =\n (fun buf ~pos_ref ->\n bin_read_t bin_reader1.read bin_reader2.read bin_reader3.read buf ~pos_ref)\n ; vtag_read =\n (fun _buf ~pos_ref _n ->\n raise_variant_wrong_type \"Bin_prot.Utils.Make_binable3.bin_reader_t\" !pos_ref)\n }\n ;;\n\n let bin_t type_class1 type_class2 type_class3 =\n { shape = bin_shape_t type_class1.shape type_class2.shape type_class3.shape\n ; writer = bin_writer_t type_class1.writer type_class2.writer type_class3.writer\n ; reader = bin_reader_t type_class1.reader type_class2.reader type_class3.reader\n }\n ;;\nend\n\nmodule Make_binable_with_uuid (S : Make_binable_with_uuid_spec) =\n Make_binable_gen (struct\n include S\n\n let maybe_caller_identity = Some S.caller_identity\n end)\n\nmodule Make_binable1_with_uuid (S : Make_binable1_with_uuid_spec) =\n Make_binable1_gen (struct\n include S\n\n let maybe_caller_identity = Some S.caller_identity\n end)\n\nmodule Make_binable2_with_uuid (S : Make_binable2_with_uuid_spec) =\n Make_binable2_gen (struct\n include S\n\n let maybe_caller_identity = Some S.caller_identity\n end)\n\nmodule Make_binable3_with_uuid (S : Make_binable3_with_uuid_spec) =\n Make_binable3_gen (struct\n include S\n\n let maybe_caller_identity = Some S.caller_identity\n end)\n\nmodule Make_binable_without_uuid (S : Make_binable_without_uuid_spec) =\n Make_binable_gen (struct\n include S\n\n let maybe_caller_identity = None\n end)\n\nmodule Make_binable1_without_uuid (S : Make_binable1_without_uuid_spec) =\n Make_binable1_gen (struct\n include S\n\n let maybe_caller_identity = None\n end)\n\nmodule Make_binable2_without_uuid (S : Make_binable2_without_uuid_spec) =\n Make_binable2_gen (struct\n include S\n\n let maybe_caller_identity = None\n end)\n\nmodule Make_binable3_without_uuid (S : Make_binable3_without_uuid_spec) =\n Make_binable3_gen (struct\n include S\n\n let maybe_caller_identity = None\n end)\n\nmodule Make_binable = Make_binable_without_uuid\nmodule Make_binable1 = Make_binable1_without_uuid\nmodule Make_binable2 = Make_binable2_without_uuid\nmodule Make_binable3 = Make_binable3_without_uuid\n\nlet with_module_name f ~module_name function_name =\n match module_name with\n | None -> f function_name\n | Some module_name -> Printf.ksprintf f \"%s.%s\" module_name function_name\n;;\n\nlet raise_concurrent_modification = with_module_name raise_concurrent_modification\n\nlet raise_read_too_much =\n with_module_name\n (Printf.ksprintf failwith \"%s: tried to read more elements than available\")\n;;\n\nlet raise_read_not_enough =\n with_module_name (Printf.ksprintf failwith \"%s: didn't read all elements\")\n;;\n\nmodule Make_iterable_binable (S : Make_iterable_binable_spec) = struct\n open S\n\n let bin_shape_t =\n Shape.(\n basetype\n caller_identity\n [ basetype\n (Uuid.of_string \"6592371a-4994-11e6-923a-7748e4182764\")\n [ S.bin_shape_el ]\n ])\n ;;\n\n let bin_size_t t =\n let size_ref = ref 0 in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n size_ref := !size_ref + bin_size_el el;\n incr cnt_ref);\n let len = length t in\n if !cnt_ref = len\n then bin_size_nat0 (Nat0.unsafe_of_int len) + !size_ref\n else raise_concurrent_modification ~module_name \"bin_size_t\"\n ;;\n\n let bin_write_t buf ~pos t =\n let len = length t in\n let plen = Nat0.unsafe_of_int len in\n let pos_ref = ref (Write.bin_write_nat0 buf ~pos plen) in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n pos_ref := bin_write_el buf ~pos:!pos_ref el;\n incr cnt_ref);\n if !cnt_ref = len\n then !pos_ref\n else raise_concurrent_modification ~module_name \"bin_write_t\"\n ;;\n\n let bin_read_t buf ~pos_ref =\n let len = (Read.bin_read_nat0 buf ~pos_ref :> int) in\n let idx = ref 0 in\n let next () =\n if !idx >= len then raise_read_too_much ~module_name \"bin_read_t\";\n incr idx;\n bin_read_el buf ~pos_ref\n in\n let result = init ~len ~next in\n if !idx < len then raise_read_not_enough ~module_name \"bin_read_t\";\n result\n ;;\n\n let __bin_read_t__ _buf ~pos_ref _n = raise_variant_wrong_type \"t\" !pos_ref\n let bin_writer_t = { size = bin_size_t; write = bin_write_t }\n let bin_reader_t = { read = bin_read_t; vtag_read = __bin_read_t__ }\n let bin_t = { shape = bin_shape_t; writer = bin_writer_t; reader = bin_reader_t }\nend\n\nmodule Make_iterable_binable1 (S : Make_iterable_binable1_spec) = struct\n open S\n\n let bin_shape_t t =\n Shape.(\n basetype\n caller_identity\n [ basetype\n (Uuid.of_string \"ac8a9ff4-4994-11e6-9a1b-9fb4e933bd9d\")\n [ S.bin_shape_el t ]\n ])\n ;;\n\n let bin_size_t bin_size_a t =\n let size_ref = ref 0 in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n size_ref := !size_ref + bin_size_el bin_size_a el;\n incr cnt_ref);\n let len = length t in\n if !cnt_ref = len\n then bin_size_nat0 (Nat0.unsafe_of_int len) + !size_ref\n else raise_concurrent_modification ~module_name \"bin_size_t\"\n ;;\n\n let bin_write_t bin_write_a buf ~pos t =\n let len = length t in\n let plen = Nat0.unsafe_of_int len in\n let pos_ref = ref (Write.bin_write_nat0 buf ~pos plen) in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n pos_ref := bin_write_el bin_write_a buf ~pos:!pos_ref el;\n incr cnt_ref);\n if !cnt_ref = len\n then !pos_ref\n else raise_concurrent_modification ~module_name \"bin_write_t\"\n ;;\n\n let bin_read_t bin_read_a buf ~pos_ref =\n let len = (Read.bin_read_nat0 buf ~pos_ref :> int) in\n let idx = ref 0 in\n let next () =\n if !idx >= len then raise_read_too_much ~module_name \"bin_read_t\";\n incr idx;\n bin_read_el bin_read_a buf ~pos_ref\n in\n let result = init ~len ~next in\n if !idx < len then raise_read_not_enough ~module_name \"bin_read_t\";\n result\n ;;\n\n let __bin_read_t__ _bin_read_a _buf ~pos_ref _n = raise_variant_wrong_type \"t\" !pos_ref\n\n let bin_writer_t bin_writer =\n { size = (fun v -> bin_size_t bin_writer.size v)\n ; write = (fun buf ~pos v -> bin_write_t bin_writer.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader =\n { read = (fun buf ~pos_ref -> bin_read_t bin_reader.read buf ~pos_ref)\n ; vtag_read = (fun buf ~pos_ref _n -> __bin_read_t__ bin_reader.read buf ~pos_ref _n)\n }\n ;;\n\n let bin_t type_class =\n { shape = bin_shape_t type_class.shape\n ; writer = bin_writer_t type_class.writer\n ; reader = bin_reader_t type_class.reader\n }\n ;;\nend\n\nmodule Make_iterable_binable2 (S : Make_iterable_binable2_spec) = struct\n open S\n\n let bin_shape_t t1 t2 =\n Shape.(\n basetype\n caller_identity\n [ basetype\n (Uuid.of_string \"b4e54ad2-4994-11e6-b8df-87c2997f9f52\")\n [ S.bin_shape_el t1 t2 ]\n ])\n ;;\n\n let bin_size_t bin_size_a bin_size_b t =\n let size_ref = ref 0 in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n size_ref := !size_ref + bin_size_el bin_size_a bin_size_b el;\n incr cnt_ref);\n let len = length t in\n if !cnt_ref = len\n then bin_size_nat0 (Nat0.unsafe_of_int len) + !size_ref\n else raise_concurrent_modification ~module_name \"bin_size_t\"\n ;;\n\n let bin_write_t bin_write_a bin_write_b buf ~pos t =\n let len = length t in\n let plen = Nat0.unsafe_of_int len in\n let pos_ref = ref (Write.bin_write_nat0 buf ~pos plen) in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n pos_ref := bin_write_el bin_write_a bin_write_b buf ~pos:!pos_ref el;\n incr cnt_ref);\n if !cnt_ref = len\n then !pos_ref\n else raise_concurrent_modification ~module_name \"bin_write_t\"\n ;;\n\n let bin_read_t bin_read_a bin_read_b buf ~pos_ref =\n let len = (Read.bin_read_nat0 buf ~pos_ref :> int) in\n let idx = ref 0 in\n let next () =\n if !idx >= len then raise_read_too_much ~module_name \"bin_read_t\";\n incr idx;\n bin_read_el bin_read_a bin_read_b buf ~pos_ref\n in\n let result = init ~len ~next in\n if !idx < len then raise_read_not_enough ~module_name \"bin_read_t\";\n result\n ;;\n\n let __bin_read_t__ _bin_read_a _bin_read_b _buf ~pos_ref _n =\n raise_variant_wrong_type \"t\" !pos_ref\n ;;\n\n let bin_writer_t bin_writer1 bin_writer2 =\n { size = (fun v -> bin_size_t bin_writer1.size bin_writer2.size v)\n ; write =\n (fun buf ~pos v -> bin_write_t bin_writer1.write bin_writer2.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader1 bin_reader2 =\n { read =\n (fun buf ~pos_ref -> bin_read_t bin_reader1.read bin_reader2.read buf ~pos_ref)\n ; vtag_read =\n (fun buf ~pos_ref n ->\n __bin_read_t__ bin_reader1.read bin_reader2.read buf ~pos_ref n)\n }\n ;;\n\n let bin_t type_class1 type_class2 =\n { shape = bin_shape_t type_class1.shape type_class2.shape\n ; writer = bin_writer_t type_class1.writer type_class2.writer\n ; reader = bin_reader_t type_class1.reader type_class2.reader\n }\n ;;\nend\n\nmodule Make_iterable_binable3 (S : Make_iterable_binable3_spec) = struct\n open S\n\n let bin_shape_t t1 t2 t3 =\n Shape.(\n basetype\n caller_identity\n [ basetype\n (Uuid.of_string \"f2112eda-e7d7-11e6-bb36-072e9ce159db\")\n [ S.bin_shape_el t1 t2 t3 ]\n ])\n ;;\n\n let bin_size_t bin_size_a bin_size_b bin_size_c t =\n let size_ref = ref 0 in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n size_ref := !size_ref + bin_size_el bin_size_a bin_size_b bin_size_c el;\n incr cnt_ref);\n let len = length t in\n if !cnt_ref = len\n then bin_size_nat0 (Nat0.unsafe_of_int len) + !size_ref\n else raise_concurrent_modification ~module_name \"bin_size_t\"\n ;;\n\n let bin_write_t bin_write_a bin_write_b bin_write_c buf ~pos t =\n let len = length t in\n let plen = Nat0.unsafe_of_int len in\n let pos_ref = ref (Write.bin_write_nat0 buf ~pos plen) in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n pos_ref := bin_write_el bin_write_a bin_write_b bin_write_c buf ~pos:!pos_ref el;\n incr cnt_ref);\n if !cnt_ref = len\n then !pos_ref\n else raise_concurrent_modification ~module_name \"bin_write_t\"\n ;;\n\n let bin_read_t bin_read_a bin_read_b bin_read_c buf ~pos_ref =\n let len = (Read.bin_read_nat0 buf ~pos_ref :> int) in\n let idx = ref 0 in\n let next () =\n if !idx >= len then raise_read_too_much ~module_name \"bin_read_t\";\n incr idx;\n bin_read_el bin_read_a bin_read_b bin_read_c buf ~pos_ref\n in\n let result = init ~len ~next in\n if !idx < len then raise_read_not_enough ~module_name \"bin_read_t\";\n result\n ;;\n\n let __bin_read_t__ _bin_read_a _bin_read_b _bin_read_c _buf ~pos_ref _n =\n raise_variant_wrong_type \"t\" !pos_ref\n ;;\n\n let bin_writer_t bin_writer1 bin_writer2 bin_writer3 =\n { size = (fun v -> bin_size_t bin_writer1.size bin_writer2.size bin_writer3.size v)\n ; write =\n (fun buf ~pos v ->\n bin_write_t bin_writer1.write bin_writer2.write bin_writer3.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader1 bin_reader2 bin_reader3 =\n { read =\n (fun buf ~pos_ref ->\n bin_read_t bin_reader1.read bin_reader2.read bin_reader3.read buf ~pos_ref)\n ; vtag_read =\n (fun buf ~pos_ref n ->\n __bin_read_t__\n bin_reader1.read\n bin_reader2.read\n bin_reader3.read\n buf\n ~pos_ref\n n)\n }\n ;;\n\n let bin_t type_class1 type_class2 type_class3 =\n { shape = bin_shape_t type_class1.shape type_class2.shape type_class3.shape\n ; writer = bin_writer_t type_class1.writer type_class2.writer type_class3.writer\n ; reader = bin_reader_t type_class1.reader type_class2.reader type_class3.reader\n }\n ;;\nend\n","(**\n This module defines default converters for the types defined in the OCaml\n standard library.\n*)\n\ninclude Size\n\nlet bin_unit = Type_class.bin_unit\nlet bin_shape_unit = Type_class.bin_shape_unit\nlet bin_writer_unit = Type_class.bin_writer_unit\nlet bin_write_unit = Write.bin_write_unit\nlet bin_reader_unit = Type_class.bin_reader_unit\nlet bin_read_unit = Read.bin_read_unit\n\nlet __bin_read_unit__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"unit\" !pos_ref\n;;\n\nlet bin_bool = Type_class.bin_bool\nlet bin_shape_bool = Type_class.bin_shape_bool\nlet bin_writer_bool = Type_class.bin_writer_bool\nlet bin_write_bool = Write.bin_write_bool\nlet bin_reader_bool = Type_class.bin_reader_bool\nlet bin_read_bool = Read.bin_read_bool\n\nlet __bin_read_bool__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"bool\" !pos_ref\n;;\n\nlet bin_string = Type_class.bin_string\nlet bin_shape_string = Type_class.bin_shape_string\nlet bin_writer_string = Type_class.bin_writer_string\nlet bin_write_string = Write.bin_write_string\nlet bin_reader_string = Type_class.bin_reader_string\nlet bin_read_string = Read.bin_read_string\n\nlet __bin_read_string__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"string\" !pos_ref\n;;\n\nlet bin_bytes = Type_class.bin_bytes\nlet bin_shape_bytes = Type_class.bin_shape_bytes\nlet bin_writer_bytes = Type_class.bin_writer_bytes\nlet bin_write_bytes = Write.bin_write_bytes\nlet bin_reader_bytes = Type_class.bin_reader_bytes\nlet bin_read_bytes = Read.bin_read_bytes\n\nlet __bin_read_bytes__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"bytes\" !pos_ref\n;;\n\nlet bin_char = Type_class.bin_char\nlet bin_shape_char = Type_class.bin_shape_char\nlet bin_writer_char = Type_class.bin_writer_char\nlet bin_write_char = Write.bin_write_char\nlet bin_reader_char = Type_class.bin_reader_char\nlet bin_read_char = Read.bin_read_char\n\nlet __bin_read_char__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"char\" !pos_ref\n;;\n\nlet bin_int = Type_class.bin_int\nlet bin_shape_int = Type_class.bin_shape_int\nlet bin_writer_int = Type_class.bin_writer_int\nlet bin_write_int = Write.bin_write_int\nlet bin_reader_int = Type_class.bin_reader_int\nlet bin_read_int = Read.bin_read_int\nlet __bin_read_int__ _buf ~pos_ref _vint = Common.raise_variant_wrong_type \"int\" !pos_ref\nlet bin_float = Type_class.bin_float\nlet bin_shape_float = Type_class.bin_shape_float\nlet bin_writer_float = Type_class.bin_writer_float\nlet bin_write_float = Write.bin_write_float\nlet bin_reader_float = Type_class.bin_reader_float\nlet bin_read_float = Read.bin_read_float\n\nlet __bin_read_float__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float\" !pos_ref\n;;\n\ntype float_array = float array\n\nlet bin_float_array = Type_class.bin_float_array\nlet bin_shape_float_array = Type_class.bin_shape_float_array\nlet bin_writer_float_array = Type_class.bin_writer_float_array\nlet bin_write_float_array = Write.bin_write_float_array\nlet bin_reader_float_array = Type_class.bin_reader_float_array\nlet bin_read_float_array = Read.bin_read_float_array\n\nlet __bin_read_float_array__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float_array\" !pos_ref\n;;\n\nlet bin_int32 = Type_class.bin_int32\nlet bin_shape_int32 = Type_class.bin_shape_int32\nlet bin_writer_int32 = Type_class.bin_writer_int32\nlet bin_write_int32 = Write.bin_write_int32\nlet bin_reader_int32 = Type_class.bin_reader_int32\nlet bin_read_int32 = Read.bin_read_int32\n\nlet __bin_read_int32__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"int32\" !pos_ref\n;;\n\nlet bin_int64 = Type_class.bin_int64\nlet bin_shape_int64 = Type_class.bin_shape_int64\nlet bin_writer_int64 = Type_class.bin_writer_int64\nlet bin_write_int64 = Write.bin_write_int64\nlet bin_reader_int64 = Type_class.bin_reader_int64\nlet bin_read_int64 = Read.bin_read_int64\n\nlet __bin_read_int64__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"int64\" !pos_ref\n;;\n\nlet bin_nativeint = Type_class.bin_nativeint\nlet bin_shape_nativeint = Type_class.bin_shape_nativeint\nlet bin_writer_nativeint = Type_class.bin_writer_nativeint\nlet bin_write_nativeint = Write.bin_write_nativeint\nlet bin_reader_nativeint = Type_class.bin_reader_nativeint\nlet bin_read_nativeint = Read.bin_read_nativeint\n\nlet __bin_read_nativeint__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"nativeint\" !pos_ref\n;;\n\nlet bin_ref = Type_class.bin_ref\nlet bin_shape_ref = Type_class.bin_shape_ref\nlet bin_writer_ref = Type_class.bin_writer_ref\nlet bin_write_ref = Write.bin_write_ref\nlet bin_reader_ref = Type_class.bin_reader_ref\nlet bin_read_ref = Read.bin_read_ref\n\nlet __bin_read_ref__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"ref\" !pos_ref\n;;\n\nlet bin_lazy_t = Type_class.bin_lazy\nlet bin_shape_lazy_t = Type_class.bin_shape_lazy\nlet bin_writer_lazy_t = Type_class.bin_writer_lazy\nlet bin_write_lazy_t = Write.bin_write_lazy\nlet bin_reader_lazy_t = Type_class.bin_reader_lazy\nlet bin_read_lazy_t = Read.bin_read_lazy\n\nlet __bin_read_lazy_t__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"lazy\" !pos_ref\n;;\n\nlet bin_lazy = Type_class.bin_lazy\nlet bin_shape_lazy = Type_class.bin_shape_lazy\nlet bin_writer_lazy = Type_class.bin_writer_lazy\nlet bin_write_lazy = Write.bin_write_lazy\nlet bin_reader_lazy = Type_class.bin_reader_lazy\nlet bin_read_lazy = Read.bin_read_lazy\n\nlet __bin_read_lazy__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"lazy\" !pos_ref\n;;\n\nlet bin_option = Type_class.bin_option\nlet bin_shape_option = Type_class.bin_shape_option\nlet bin_writer_option = Type_class.bin_writer_option\nlet bin_write_option = Write.bin_write_option\nlet bin_reader_option = Type_class.bin_reader_option\nlet bin_read_option = Read.bin_read_option\n\nlet __bin_read_option__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"option\" !pos_ref\n;;\n\nlet bin_list = Type_class.bin_list\nlet bin_shape_list = Type_class.bin_shape_list\nlet bin_writer_list = Type_class.bin_writer_list\nlet bin_write_list = Write.bin_write_list\nlet bin_reader_list = Type_class.bin_reader_list\nlet bin_read_list = Read.bin_read_list\n\nlet __bin_read_list__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"list\" !pos_ref\n;;\n\nlet bin_array = Type_class.bin_array\nlet bin_shape_array = Type_class.bin_shape_array\nlet bin_writer_array = Type_class.bin_writer_array\nlet bin_write_array = Write.bin_write_array\nlet bin_reader_array = Type_class.bin_reader_array\nlet bin_read_array = Read.bin_read_array\n\nlet __bin_read_array__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"array\" !pos_ref\n;;\n\nlet bin_hashtbl = Type_class.bin_hashtbl\nlet bin_shape_hashtbl = Type_class.bin_shape_hashtbl\nlet bin_writer_hashtbl = Type_class.bin_writer_hashtbl\nlet bin_write_hashtbl = Write.bin_write_hashtbl\nlet bin_reader_hashtbl = Type_class.bin_reader_hashtbl\nlet bin_read_hashtbl = Read.bin_read_hashtbl\n\nlet __bin_read_hashtbl__ _f _g _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"hashtbl\" !pos_ref\n;;\n\nlet bin_bigstring = Type_class.bin_bigstring\nlet bin_shape_bigstring = Type_class.bin_shape_bigstring\nlet bin_writer_bigstring = Type_class.bin_writer_bigstring\nlet bin_write_bigstring = Write.bin_write_bigstring\nlet bin_reader_bigstring = Type_class.bin_reader_bigstring\nlet bin_read_bigstring = Read.bin_read_bigstring\n\nlet __bin_read_bigstring__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"bigstring\" !pos_ref\n;;\n\nlet bin_mat = Type_class.bin_mat\nlet bin_shape_mat = Type_class.bin_shape_mat\nlet bin_writer_mat = Type_class.bin_writer_mat\nlet bin_write_mat = Write.bin_write_mat\nlet bin_reader_mat = Type_class.bin_reader_mat\nlet bin_read_mat = Read.bin_read_mat\nlet __bin_read_mat__ _buf ~pos_ref _vint = Common.raise_variant_wrong_type \"mat\" !pos_ref\nlet bin_float32_mat = Type_class.bin_float32_mat\nlet bin_shape_float32_mat = Type_class.bin_shape_float32_mat\nlet bin_writer_float32_mat = Type_class.bin_writer_float32_mat\nlet bin_write_float32_mat = Write.bin_write_float32_mat\nlet bin_reader_float32_mat = Type_class.bin_reader_float32_mat\nlet bin_read_float32_mat = Read.bin_read_float32_mat\n\nlet __bin_read_float32_mat__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float32_mat\" !pos_ref\n;;\n\nlet bin_float64_mat = Type_class.bin_float64_mat\nlet bin_shape_float64_mat = Type_class.bin_shape_float64_mat\nlet bin_writer_float64_mat = Type_class.bin_writer_float64_mat\nlet bin_write_float64_mat = Write.bin_write_float64_mat\nlet bin_reader_float64_mat = Type_class.bin_reader_float64_mat\nlet bin_read_float64_mat = Read.bin_read_float64_mat\n\nlet __bin_read_float64_mat__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float64_mat\" !pos_ref\n;;\n\nlet bin_vec = Type_class.bin_vec\nlet bin_shape_vec = Type_class.bin_shape_vec\nlet bin_writer_vec = Type_class.bin_writer_vec\nlet bin_write_vec = Write.bin_write_vec\nlet bin_reader_vec = Type_class.bin_reader_vec\nlet bin_read_vec = Read.bin_read_vec\nlet __bin_read_vec__ _buf ~pos_ref _vint = Common.raise_variant_wrong_type \"vec\" !pos_ref\nlet bin_float32_vec = Type_class.bin_float32_vec\nlet bin_shape_float32_vec = Type_class.bin_shape_float32_vec\nlet bin_writer_float32_vec = Type_class.bin_writer_float32_vec\nlet bin_write_float32_vec = Write.bin_write_float32_vec\nlet bin_reader_float32_vec = Type_class.bin_reader_float32_vec\nlet bin_read_float32_vec = Read.bin_read_float32_vec\n\nlet __bin_read_float32_vec__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float32_vec\" !pos_ref\n;;\n\nlet bin_float64_vec = Type_class.bin_float64_vec\nlet bin_shape_float64_vec = Type_class.bin_shape_float64_vec\nlet bin_writer_float64_vec = Type_class.bin_writer_float64_vec\nlet bin_write_float64_vec = Write.bin_write_float64_vec\nlet bin_reader_float64_vec = Type_class.bin_reader_float64_vec\nlet bin_read_float64_vec = Read.bin_read_float64_vec\n\nlet __bin_read_float64_vec__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float64_vec\" !pos_ref\n;;\n","module type S = sig\n val pre_test_hook : unit -> unit\nend\n\nlet pre_test_hook = ignore\n","[%%import\n \"config.h\"]\n\nopen! Base\n\n[%%ifdef\n JSC_ARCH_SIXTYFOUR]\n\nexternal nanoseconds_since_unix_epoch_or_zero\n : unit\n -> Int63.t\n = \"time_now_nanoseconds_since_unix_epoch_or_zero\"\n[@@noalloc]\n\n[%%else]\n\nexternal nanoseconds_since_unix_epoch_or_zero\n : unit\n -> Int63.t\n = \"time_now_nanoseconds_since_unix_epoch_or_zero\"\n\n[%%endif]\n\n[%%ifdef\n JSC_POSIX_TIMERS]\n\nlet[@cold] gettime_failed () = failwith \"clock_gettime(CLOCK_REALTIME) failed\"\n\n[%%else]\n\nlet[@cold] gettime_failed () = failwith \"gettimeofday failed\"\n\n[%%endif]\n\nlet nanoseconds_since_unix_epoch () =\n let t = nanoseconds_since_unix_epoch_or_zero () in\n if Int63.( <> ) t Int63.zero then t else gettime_failed ()\n;;\n","module Test_result = struct\n type t = Success | Failure | Error\n\n let to_exit_code = function\n | Success -> 0\n | Failure -> 2\n | Error -> 1\n ;;\n\n let to_string = function\n | Success -> \"success\"\n | Failure -> \"failure\"\n | Error -> \"error\"\n ;;\n\n let combine t1 t2 =\n match t1, t2 with\n | Success, Success -> Success\n | Error , _ | _, Error -> Error\n | Failure, _ | _, Failure -> Failure\n ;;\n\n let combine_all ts = List.fold_left combine Success ts\nend\n\nlet parse_argv argv l f msg =\n try\n Arg.parse_argv argv l f msg\n with\n | Arg.Bad msg -> Printf.eprintf \"%s\" msg; exit 1\n | Arg.Help msg -> Printf.printf \"%s\" msg; exit 0\n;;\n\ntype descr = string\nlet test_modules_ran = ref 0\nlet test_modules_failed = ref 0\nlet tests_ran = ref 0\nlet tests_failed = ref 0\nlet dynamic_lib : string option ref = ref None\ntype filename = string\ntype line_number = int\ntype start_pos = int\ntype end_pos = int\ntype config = (module Inline_test_config.S)\ntype 'a test_function_args\n = config:config\n -> descr:descr\n -> tags:string list\n -> filename:filename\n -> line_number:line_number\n -> start_pos:start_pos\n -> end_pos:end_pos\n -> 'a\n\nmodule Tag_predicate = struct\n type t =\n { required_tags : string list\n ; dropped_tags : string list\n }\n\n let enable_everything = { required_tags = []; dropped_tags = [] }\n\n let drop t tag =\n { dropped_tags = tag :: t.dropped_tags\n ; required_tags = List.filter ((<>) tag) t.required_tags\n }\n\n let require t tag =\n { dropped_tags = List.filter ((<>) tag) t.dropped_tags\n ; required_tags = tag :: t.required_tags\n }\n\n let entire_module_disabled t ~partial_tags:tags =\n List.exists (fun dropped -> List.mem dropped tags) t.dropped_tags\n\n let disabled t ~complete_tags:tags =\n List.exists (fun req -> not (List.mem req tags)) t.required_tags\n || List.exists (fun dropped -> List.mem dropped tags) t.dropped_tags\nend\n\n\ntype which_tests =\n { libname : string\n ; only_test_location : (filename * line_number option * bool ref) list\n ; which_tags : Tag_predicate.t\n }\ntype test_mode =\n { which_tests : which_tests\n ; what_to_do :\n [ `Run_partition of string option\n | `List_partitions\n ]\n }\n\nmodule Action : sig\n type t = [\n | `Ignore\n | `Test_mode of test_mode\n ]\n val get : unit -> t\n val set : t -> unit\nend = struct\n type t = [\n | `Ignore\n | `Test_mode of test_mode\n ]\n let action : t ref = ref `Ignore\n let force_drop =\n try ignore (Sys.getenv \"FORCE_DROP_INLINE_TEST\" : string); true\n with Not_found -> false\n let get () =\n (* This is useful when compiling to javascript.\n Js_of_ocaml can statically evaluate [Sys.getenv \"FORCE_DROP_INLINE_TEST\"]\n and inline the result ([`Ignore]) whenever [get ()] is called.\n Unit tests can then be treated as deadcode since the argument [f] of the [test]\n function below is never used. *)\n if force_drop\n then `Ignore\n else !action\n\n let set v = action := v\nend\n\nmodule Partition : sig\n val found_test : unit -> unit\n val set_current : string -> unit\n val is_current : string option -> bool\n val all : unit -> string list\nend = struct\n let all = Hashtbl.create 23\n let current = ref \"\" let set_current x = current := x\n let found_test () =\n if !current <> \"\" && not (Hashtbl.mem all !current) then\n Hashtbl.add all !current ()\n ;;\n let is_current = function\n | None -> true\n | Some p -> p = !current\n ;;\n let all () =\n List.sort String.compare\n (Hashtbl.fold (fun k () acc -> k :: acc) all [])\n ;;\nend\n\nmodule Module_context = struct\n module T = struct\n type one_module =\n { descr : string\n ; tags : string list\n }\n\n type t = one_module list\n\n let descr t = List.map (fun m -> m.descr) t\n let tags t = List.concat (List.map (fun m -> m.tags) t)\n end\n\n let current : T.t ref = ref []\n\n let with_ ~descr ~tags f =\n let prev = !current in\n current := { T. descr; tags } :: prev;\n try\n f ();\n current := prev;\n with e ->\n current := prev;\n raise e\n\n let current_descr () = T.descr !current\n let current_tags () = T.tags !current\nend\n\nlet verbose = ref false\nlet strict = ref false\nlet show_counts = ref false\nlet list_test_names = ref false\nlet delayed_errors = ref []\nlet stop_on_error = ref false\n\nlet log = ref None\n\nlet time_sec = ref 0.\n\nlet use_color = ref true\nlet in_place = ref false\nlet diff_command = ref None\nlet source_tree_root = ref None\nlet allow_output_patterns = ref false\n\nlet displayed_descr descr filename line start_pos end_pos =\n Printf.sprintf \"File %S, line %d, characters %d-%d%s\"\n filename line start_pos end_pos descr\nlet parse_descr str =\n try Some (Scanf.sscanf str \" File %S , line %d , characters %d - %d %!\"\n (fun file line _start_pos _end_pos -> file, Some line))\n with _ ->\n try Some (Scanf.sscanf str \" File %S , line %d %!\" (fun file line -> file, Some line))\n with _ ->\n try Some (Scanf.sscanf str \" File %S %!\" (fun file -> file, None))\n with _ -> None\n\nlet indent ~by = function\n | \"\" -> \"\"\n | str ->\n let len = String.length str in\n let buf = Buffer.create (len * 2) in\n let indentation = String.make by ' ' in\n Buffer.add_string buf indentation;\n for i = 0 to len - 1; do\n Buffer.add_char buf str.[i];\n if str.[i] = '\\n' && i <> len - 1 then Buffer.add_string buf indentation\n done;\n Buffer.contents buf\n\nlet backtrace_indented ~by =\n let str = Printexc.get_backtrace () in\n indent str ~by\n\nlet () =\n match Array.to_list Sys.argv with\n | name :: \"inline-test-runner\" :: lib :: rest\n when Base.Exported_for_specific_uses.am_testing -> begin\n (* when we see this argument, we switch to test mode *)\n let tests = ref [] in\n let list_partitions = ref false in\n let partition = ref None in\n let tag_predicate = ref Tag_predicate.enable_everything in\n parse_argv (Array.of_list (name :: rest)) (Arg.align [\n \"-list-test-names\", Arg.Unit (fun () -> list_test_names := true; verbose := true),\n \" Do not run tests but show what would have been run\";\n \"-list-partitions\", Arg.Unit (fun () -> list_partitions := true),\n \" Lists all the partitions that contain at least one test or test_module\";\n \"-partition\", Arg.String (fun i -> partition := Some i),\n \" Only run the tests in the given partition\";\n \"-verbose\", Arg.Set verbose, \" Show the tests as they run\";\n \"-stop-on-error\", Arg.Set stop_on_error, \" Run tests only up to the first error \\\n (doesn't work for expect tests)\";\n \"-strict\", Arg.Set strict, \" End with an error if no tests were run\";\n \"-show-counts\", Arg.Set show_counts, \" Show the number of tests ran\";\n \"-log\", Arg.Unit (fun () ->\n (try Sys.remove \"inline_tests.log\" with _ -> ());\n log := Some (open_out \"inline_tests.log\")\n ), \" Log the tests run in inline_tests.log\";\n \"-drop-tag\", Arg.String (fun s ->\n tag_predicate := Tag_predicate.drop !tag_predicate s\n ), \"tag Only run tests not tagged with [tag] (overrides previous -require-tag)\";\n \"-require-tag\", Arg.String (fun s ->\n tag_predicate := Tag_predicate.require !tag_predicate s\n ), \"tag Only run tests tagged with [tag] (overrides previous -drop-tag)\";\n \"-only-test\", Arg.String (fun s ->\n let filename, index =\n match parse_descr s with\n | Some (file, index) -> file, index\n | None ->\n if String.contains s ':' then\n let i = String.index s ':' in\n let filename = String.sub s 0 i in\n let index_string = String.sub s (i + 1) (String.length s - i - 1) in\n let index =\n try int_of_string index_string\n with Failure _ ->\n Printf.eprintf\n \"Argument %s doesn't fit the format filename[:line_number]\\n%!\" s;\n exit 1\n in\n filename, Some index\n else\n s, None\n in\n tests := (filename, index, ref false) :: !tests\n ), \"location Run only the tests specified by all the -only-test options.\n Locations can be one of these forms:\n - file.ml\n - file.ml:line_number\n - File \\\"file.ml\\\"\n - File \\\"file.ml\\\", line 23\n - File \\\"file.ml\\\", line 23, characters 2-3\";\n \"-no-color\", Arg.Clear use_color, \" Summarize tests without using color\";\n \"-in-place\", Arg.Set in_place, \" Update expect tests in place\";\n \"-diff-cmd\", Arg.String (fun s -> diff_command := Some s),\n \" Diff command for tests that require diffing (use - to disable diffing)\";\n \"-allow-output-patterns\", Arg.Set allow_output_patterns,\n \" Allow output patterns in tests expectations\";\n \"-source-tree-root\", Arg.String (fun s -> source_tree_root := Some s),\n \" Path to the root of the source tree\"\n ]) (fun anon ->\n Printf.eprintf \"%s: unexpected anonymous argument %s\\n%!\" name anon;\n exit 1\n ) (Printf.sprintf \"%s %s %s [args]\" name \"inline-test-runner\" lib);\n Action.set (\n `Test_mode\n { which_tests =\n { libname = lib\n ; only_test_location = !tests;\n which_tags = !tag_predicate;\n }\n ; what_to_do =\n if !list_partitions\n then `List_partitions\n else `Run_partition !partition\n })\n end\n | _ ->\n ()\n\nlet am_test_runner =\n match Action.get () with\n | `Test_mode _ -> true\n | `Ignore -> false\n\nlet am_running_inline_test_env_var =\n (* for approximate compatibility, given that the variable is not exactly equivalent\n to what PPX_INLINE_TEST_LIB_AM_RUNNING_INLINE_TEST used to be *)\n \"TESTING_FRAMEWORK\"\n\n(* This value is deprecated in principle, in favor of Core_kernel.am_running_test, so\n we're going to live with the ugly pattern match. *)\nlet am_running_inline_test =\n match Sys.getenv \"PPX_INLINE_TEST_LIB_AM_RUNNING_INLINE_TEST\" with\n | (_ : string) -> true (* for compatibility with people setting this variable directly *)\n | exception Not_found ->\n match Sys.getenv am_running_inline_test_env_var with\n | \"inline-test\" -> true\n | exception Not_found -> false\n | _ -> false\n\nlet testing =\n if am_test_runner\n then `Testing `Am_test_runner\n else\n (if am_running_inline_test\n then `Testing `Am_child_of_test_runner\n else `Not_testing)\n\nlet wall_time_clock_ns () =\n Time_now.nanoseconds_since_unix_epoch ()\n\n\nlet time_without_resetting_random_seeds f =\n let before_ns = wall_time_clock_ns () in\n Base.Exn.protect ~finally:(fun[@inline] () ->\n time_sec := Base.Int63.(wall_time_clock_ns () - before_ns |> to_float) /. 1e9)\n ~f\n\n\nlet saved_caml_random_state = lazy (Caml.Random.State.make [| 100; 200; 300 |])\nlet saved_base_random_state = lazy (Base.Random.State.make [| 111; 222; 333 |])\n\nlet time_and_reset_random_seeds f =\n let caml_random_state = Caml.Random.get_state () in\n let base_random_state = Base.Random.State.copy Base.Random.State.default in\n Caml.Random.set_state (Lazy.force saved_caml_random_state);\n Base.Random.set_state (Lazy.force saved_base_random_state);\n let result = time_without_resetting_random_seeds f in\n Caml.Random.set_state caml_random_state;\n Base.Random.set_state base_random_state;\n result\n\nlet string_of_module_descr () =\n String.concat \"\" (\n List.map (fun s -> \" in TES\" ^ \"T_MODULE at \" ^ String.uncapitalize_ascii s ^ \"\\n\")\n (Module_context.current_descr ())\n )\n\nlet position_match def_filename def_line_number l =\n List.exists (fun (filename, line_number_opt, used) ->\n let position_start =\n String.length def_filename - String.length filename in\n let found =\n position_start >= 0 &&\n let end_of_def_filename =\n String.sub def_filename\n position_start\n (String.length filename) in\n end_of_def_filename = filename\n && (position_start = 0 || def_filename.[position_start - 1] = '/')\n && (match line_number_opt with\n | None -> true\n | Some line_number -> def_line_number = line_number)\n in\n if found then used := true;\n found\n ) l\n\nlet print_delayed_errors () =\n match List.rev !delayed_errors with\n | [] -> ()\n | _ :: _ as delayed_errors ->\n Printf.eprintf \"\\n%s\\n%!\" (String.make 70 '=');\n List.iter (fun message ->\n Printf.eprintf \"%s%!\" message\n ) delayed_errors\n\nlet eprintf_or_delay fmt =\n Printf.ksprintf (fun s ->\n if !verbose then delayed_errors := s :: !delayed_errors\n else Printf.eprintf \"%s%!\" s;\n if !stop_on_error then begin\n print_delayed_errors ();\n exit 2\n end\n ) fmt\n\nlet add_hooks ((module C) : config) f =\n fun () -> C.pre_test_hook (); f ()\n\nlet[@inline never] test ~config ~descr ~tags ~filename:def_filename ~line_number:def_line_number\n ~start_pos ~end_pos f =\n match Action.get () with\n | `Ignore -> ()\n | `Test_mode { which_tests = { libname; only_test_location; which_tags }; what_to_do } ->\n let f = add_hooks config f in\n let descr () = displayed_descr descr def_filename def_line_number start_pos end_pos in\n let complete_tags = tags @ Module_context.current_tags () in\n let should_run =\n Some libname = !dynamic_lib\n && begin match only_test_location with\n | [] -> true\n | _ :: _ -> position_match def_filename def_line_number only_test_location\n end\n && not (Tag_predicate.disabled which_tags ~complete_tags)\n in\n if should_run then begin\n match what_to_do with\n | `List_partitions -> Partition.found_test ()\n | `Run_partition partition ->\n if Partition.is_current partition then begin\n let descr = descr () in\n incr tests_ran;\n begin match !log with\n | None -> ()\n | Some ch -> Printf.fprintf ch \"%s\\n%s\" descr (string_of_module_descr ())\n end;\n if !verbose then begin\n Printf.printf \"%s%!\" descr\n end;\n let print_time_taken () =\n (* If !list_test_names, this is is a harmless zero. *)\n if !verbose then Printf.printf \" (%.3f sec)\\n%!\" !time_sec;\n in\n try\n let failed = not !list_test_names && not (time_and_reset_random_seeds f) in\n print_time_taken ();\n if failed then begin\n incr tests_failed;\n eprintf_or_delay \"%s is false.\\n%s\\n%!\" descr\n (string_of_module_descr ())\n end\n with exn ->\n print_time_taken ();\n let backtrace = backtrace_indented ~by:2 in\n incr tests_failed;\n let exn_str = Printexc.to_string exn in\n let sep = if String.contains exn_str '\\n' then \"\\n\" else \" \" in\n eprintf_or_delay \"%s threw%s%s.\\n%s%s\\n%!\" descr sep exn_str\n backtrace (string_of_module_descr ())\n end\n end\n\nlet set_lib_and_partition static_lib partition =\n match !dynamic_lib with\n | Some _ ->\n (* possible if the interface is used explicitly or if we happen to dynlink something\n that contain tests *)\n ()\n | None ->\n dynamic_lib := Some static_lib;\n match Action.get () with\n | `Ignore -> ()\n | `Test_mode { which_tests; what_to_do } ->\n if which_tests.libname = static_lib then begin\n let requires_partition =\n match what_to_do with\n | `List_partitions | `Run_partition (Some _) -> true\n | `Run_partition None -> false\n in\n if partition = \"\" && requires_partition\n then failwith \"ppx_inline_test: cannot use -list-partition or -partition \\\n without specifying a partition at preprocessing time\"\n else Partition.set_current partition\n end\n\nlet unset_lib static_lib =\n match !dynamic_lib with\n | None ->\n (* not giving an error, because when some annoying people put pa_ounit in their list\n of preprocessors, pa_ounit is set up twice and we have two calls to unset_lib at\n the end of the file, and the second one comes in this branch *)\n ()\n | Some lib ->\n if lib = static_lib then dynamic_lib := None\n\nlet test_unit ~config ~descr ~tags ~filename ~line_number ~start_pos ~end_pos f =\n test ~config ~descr ~tags ~filename ~line_number ~start_pos ~end_pos\n (fun () -> f (); true)\n\nlet[@inline never] test_module ~config ~descr ~tags ~filename:def_filename ~line_number:def_line_number\n ~start_pos ~end_pos f =\n match Action.get () with\n | `Ignore -> ()\n | `Test_mode { which_tests = { libname; only_test_location = _; which_tags }; what_to_do } ->\n let f = add_hooks config f in\n let descr () = displayed_descr descr def_filename def_line_number start_pos end_pos in\n let partial_tags = tags @ Module_context.current_tags () in\n let should_run =\n Some libname = !dynamic_lib\n (* If, no matter what tags a test defines, we certainly will drop all tests within\n this module, then don't run the module at all. This means people can write\n things like the following without breaking the 32-bit build:\n let%test_module [@tags \"64-bits-only\"] = (module struct\n let i = Int64.to_int_exn ....\n end)\n We don't shortcut based on position, as we can't tell what positions the\n inner tests will have. *)\n && not (Tag_predicate.entire_module_disabled which_tags ~partial_tags)\n in\n if should_run then begin\n match what_to_do with\n | `List_partitions -> Partition.found_test ()\n | `Run_partition partition ->\n if Partition.is_current partition then begin\n incr test_modules_ran;\n let descr = descr () in\n try\n Module_context.with_ ~descr ~tags (fun () ->\n (* We do not reset random states upon entering [let%test_module].\n\n Con: Code in test modules can accidentally depend on top-level random\n state effects.\n\n Pros: (1) We don't reset to the same seed on entering a [let%test_module]\n and then a [let%test] inside that module, which could lead to\n accidentally randomly generating the same values in some test. (2) Moving\n code into and out of [let%test_module] does not change its random seed.\n *)\n time_without_resetting_random_seeds f)\n with exn ->\n let backtrace = backtrace_indented ~by:2 in\n incr test_modules_failed;\n let exn_str = Printexc.to_string exn in\n let sep = if String.contains exn_str '\\n' then \"\\n\" else \" \" in\n eprintf_or_delay (\"TES\" ^^ \"T_MODULE at %s threw%s%s.\\n%s%s\\n%!\")\n (String.uncapitalize_ascii descr) sep exn_str backtrace (string_of_module_descr ())\n end\n end\n\nlet summarize () =\n match Action.get () with\n | `Ignore ->\n if Sys.argv <> [||] && Filename.basename Sys.argv.(0) = \"inline_tests_runner.exe\" then\n Printf.eprintf \"inline_tests_runner.exe is not supposed to be run by hand, you \\n\\\n should run the inline_tests_runner script instead.\\n%!\"\n else\n Printf.eprintf \"You are doing something unexpected with the tests. No tests have \\n\\\n been run. You should use the inline_tests_runner script to run \\n\\\n tests.\\n%!\";\n Test_result.Error\n | `Test_mode { which_tests = _; what_to_do = `List_partitions } ->\n List.iter (Printf.printf \"%s\\n\") (Partition.all ());\n Test_result.Success\n | `Test_mode { what_to_do = `Run_partition _; which_tests } -> begin\n begin match !log with\n | None -> ()\n | Some ch -> close_out ch\n end;\n print_delayed_errors ();\n match !tests_failed, !test_modules_failed with\n | 0, 0 -> begin\n if !show_counts then begin\n Printf.eprintf \"%d tests ran, %d test_modules ran\\n%!\" !tests_ran !test_modules_ran\n end;\n let errors =\n let unused_tests =\n List.filter (fun (_, _, used) -> not !used) which_tests.only_test_location\n in\n match unused_tests with\n | [] -> None\n | _ :: _ -> Some unused_tests\n in\n match errors with\n | Some tests ->\n Printf.eprintf \"ppx_inline_test error: the following -only-test flags matched nothing:\";\n List.iter (fun (filename, line_number_opt, _) ->\n match line_number_opt with\n | None -> Printf.eprintf \" %s\" filename\n | Some line_number -> Printf.eprintf \" %s:%d\" filename line_number\n ) tests;\n Printf.eprintf \".\\n%!\";\n Test_result.Error\n | None ->\n if !tests_ran = 0 && !strict then begin\n Printf.eprintf \"ppx_inline_test error: no tests have been run.\\n%!\";\n Test_result.Error\n end else begin\n Test_result.Success\n end\n end\n | count, count_test_modules ->\n Printf.eprintf \"FAILED %d / %d tests%s\\n%!\" count !tests_ran\n (if count_test_modules = 0 then \"\" else Printf.sprintf (\", %d TES\" ^^ \"T_MODULES\") count_test_modules);\n Test_result.Failure\n end\n\nlet use_color = !use_color\nlet in_place = !in_place\nlet diff_command = !diff_command\nlet source_tree_root = !source_tree_root\nlet allow_output_patterns = !allow_output_patterns\n\nlet evaluators = ref [summarize]\nlet add_evaluator ~f = evaluators := f :: !evaluators\nlet exit () =\n List.map (fun f -> f ()) (List.rev !evaluators)\n |> Test_result.combine_all\n |> Test_result.to_exit_code\n |> exit\n","(* this lib should not depend on core *)\nmodule List = struct\n include List\n let compare cmp a b =\n let rec loop a b =\n match a, b with\n | [], [] -> 0\n | [], _ -> -1\n | _ , [] -> 1\n | x :: xs, y :: ys ->\n let n = cmp x y in\n if n = 0 then loop xs ys\n else n\n in\n loop a b\nend\n\nmodule Uid : sig\n type t\n val compare : t -> t -> int\n val equal : t -> t -> bool\n val next : string -> t\n val hash : t -> int\n val name : t -> string\n val static : t\nend = struct\n type t = {\n code : int;\n name : string;\n }\n let compare a b = compare (a.code : int) b.code\n let equal a b = (a.code : int) = b.code\n let uid = ref 0\n let next name = let code = !uid in incr uid; {code; name}\n let hash a = Hashtbl.hash a.code\n let name a = a.name\n let static = next \"static\"\nend\n\nmodule Key = struct\n type t = {\n uid : Uid.t;\n params : t list;\n }\n let rec compare k1 k2 =\n if k1 == k2 then 0 else\n let cmp = Uid.compare k1.uid k2.uid in\n if cmp <> 0 then cmp else\n List.compare compare k1.params k2.params\n let equal a b = compare a b = 0\n let hash = (Hashtbl.hash : t -> int)\n let static = { uid = Uid.static ; params = [] }\nend\n\ntype 'a t = Key.t\ntype 'a typename = 'a t\n\nlet key t = t\nlet uid t = t.Key.uid\nlet name t = Uid.name t.Key.uid\nlet static = Key.static\n\nlet create ?(name=\"Typename.create\") () = { Key.uid = Uid.next name ; params = [] }\n\ninclude struct\n (* The argument for Obj.magic here is the same as the one in core/type_equal *)\n\n let same (type a) (type b) (nm1 : a t) (nm2 : b t) = Key.compare nm1 nm2 = 0\n\n let same_witness (type a) (type b) (nm1 : a t) (nm2 : b t) =\n if Key.compare nm1 nm2 = 0\n then Some (Obj.magic Type_equal.refl : (a, b) Type_equal.t)\n else None\n\n let same_witness_exn (type a) (type b) (nm1 : a t) (nm2 : b t) =\n if Key.compare nm1 nm2 = 0\n then (Obj.magic Type_equal.refl : (a, b) Type_equal.t)\n else failwith \"Typename.same_witness_exn\"\n\nend\n\nmodule type S0 = sig\n type t\n val typename_of_t : t typename\nend\n\nmodule type S1 = sig\n type 'a t\n val typename_of_t : 'a typename -> 'a t typename\nend\n\nmodule type S2 = sig\n type ('a, 'b) t\n val typename_of_t :\n 'a typename\n -> 'b typename\n -> ('a, 'b) t typename\nend\n\nmodule type S3 = sig\n type ('a, 'b, 'c) t\n val typename_of_t :\n 'a typename\n -> 'b typename\n -> 'c typename\n -> ('a, 'b, 'c) t typename\nend\n\nmodule type S4 = sig\n type ('a, 'b, 'c, 'd) t\n val typename_of_t :\n 'a typename\n -> 'b typename\n -> 'c typename\n -> 'd typename\n -> ('a, 'b, 'c, 'd) t typename\nend\n\nmodule type S5 = sig\n type ('a, 'b, 'c, 'd, 'e) t\n val typename_of_t :\n 'a typename\n -> 'b typename\n -> 'c typename\n -> 'd typename\n -> 'e typename\n -> ('a, 'b, 'c, 'd, 'e) t typename\nend\n\nmodule Make0 (X : Named_intf.S0) = struct\n let uid = Uid.next X.name\n let typename_of_t = { Key.uid ; params = [] }\nend\n\nmodule Make1 (X : Named_intf.S1) = struct\n let uid = Uid.next X.name\n let typename_of_t a = { Key.uid ; params = [ a ] }\nend\n\nmodule Make2 (X : Named_intf.S2) = struct\n let uid = Uid.next X.name\n let typename_of_t a b = { Key.uid ; params = [ a ; b ] }\nend\n\nmodule Make3 (X : Named_intf.S3) = struct\n let uid = Uid.next X.name\n let typename_of_t a b c = { Key.uid ; params = [ a ; b ; c ] }\nend\n\nmodule Make4 (X : Named_intf.S4) = struct\n let uid = Uid.next X.name\n let typename_of_t a b c d = { Key.uid ; params = [ a ; b ; c ; d ] }\nend\n\nmodule Make5 (X : Named_intf.S5) = struct\n let uid = Uid.next X.name\n let typename_of_t a b c d e = { Key.uid ; params = [ a ; b ; c ; d ; e ] }\nend\n\nmodule Key_table = Hashtbl.Make (Key)\n\nmodule Table (X : sig\n type 'a t\nend) = struct\n\n type data = Data : 'a t * 'a X.t -> data\n type t = data Key_table.t\n\n let create int = Key_table.create int\n\n let mem table name = Key_table.mem table (key name)\n\n let set table name data =\n Key_table.replace table (key name) (Data (name, data))\n\n let find (type a) table (name : a typename) =\n let data =\n try Some (Key_table.find table (key name))\n with Base.Not_found_s _ | Caml.Not_found -> None\n in\n match data with\n | None -> None\n | Some (Data (name', data)) ->\n (fun (type b) (name' : b typename) (data : b X.t) ->\n let Type_equal.T = (same_witness_exn name' name : (b, a) Type_equal.t) in\n Some (data : a X.t)\n ) name' data\nend\n\nlet fail uid_a uid_b =\n let msg =\n Printf.sprintf \"Typename.Same_witness_exn %S %S\" (Uid.name uid_a) (Uid.name uid_b)\n in\n failwith msg\n\nmodule Same_witness_exn_1 (A : S1) (B : S1) = struct\n type t = { eq : 'a. ('a A.t, 'a B.t) Type_equal.t }\n\n let witness =\n let uid_a = uid (A.typename_of_t static) in\n let uid_b = uid (B.typename_of_t static) in\n if Uid.equal uid_a uid_b\n then { eq = Obj.magic Type_equal.refl }\n else fail uid_a uid_b\nend\n\nmodule Same_witness_exn_2 (A : S2) (B : S2) = struct\n type t = {\n eq : 'a 'b. ( ('a, 'b) A.t,\n ('a, 'b) B.t ) Type_equal.t\n }\n\n let witness =\n let uid_a = uid (A.typename_of_t static static) in\n let uid_b = uid (B.typename_of_t static static) in\n if Uid.equal uid_a uid_b\n then { eq = Obj.magic Type_equal.refl }\n else fail uid_a uid_b\nend\n\nmodule Same_witness_exn_3 (A : S3) (B : S3) = struct\n type t = {\n eq : 'a 'b 'c. ( ('a, 'b, 'c) A.t,\n ('a, 'b, 'c) B.t ) Type_equal.t\n }\n\n let witness =\n let uid_a = uid (A.typename_of_t static static static) in\n let uid_b = uid (B.typename_of_t static static static) in\n if Uid.equal uid_a uid_b\n then { eq = Obj.magic Type_equal.refl }\n else fail uid_a uid_b\nend\n\nmodule Same_witness_exn_4 (A : S4) (B : S4) = struct\n type t = {\n eq : 'a 'b 'c 'd. ( ('a, 'b, 'c, 'd) A.t,\n ('a, 'b, 'c, 'd) B.t ) Type_equal.t\n }\n\n let witness =\n let uid_a = uid (A.typename_of_t static static static static) in\n let uid_b = uid (B.typename_of_t static static static static) in\n if Uid.equal uid_a uid_b\n then { eq = Obj.magic Type_equal.refl }\n else fail uid_a uid_b\nend\n\nmodule Same_witness_exn_5 (A : S5) (B : S5) = struct\n type t = {\n eq : 'a 'b 'c 'd 'e. ( ('a, 'b, 'c, 'd, 'e) A.t,\n ('a, 'b, 'c, 'd, 'e) B.t ) Type_equal.t\n }\n\n let witness =\n let uid_a = uid (A.typename_of_t static static static static static) in\n let uid_b = uid (B.typename_of_t static static static static static) in\n if Uid.equal uid_a uid_b\n then { eq = Obj.magic Type_equal.refl }\n else fail uid_a uid_b\nend\n","open Std_internal\n\nmodule Make0 (X : Named_intf.S0) = struct\n module Name_of_x = Typename.Make0 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named =\n Typerep.Named.T0 (module struct\n type named = X.t\n type t = X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T0 with type t = X.t)\nend\n\nmodule Make1 (X : Named_intf.S1) = struct\n module Name_of_x = Typename.Make1 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named (type p1) of_p1 =\n let typename_of_t = Name_of_x.typename_of_t\n (Typerep.typename_of_t of_p1)\n in\n Typerep.Named.T1 (module struct\n type 'a named = 'a X.t\n type a = p1 let a = of_p1\n type t = p1 X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T1 with type t = p1 X.t)\nend\n\nmodule Make2 (X : Named_intf.S2) = struct\n module Name_of_x = Typename.Make2 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named (type p1) (type p2) of_p1 of_p2 =\n let typename_of_t = Name_of_x.typename_of_t\n (Typerep.typename_of_t of_p1)\n (Typerep.typename_of_t of_p2)\n in\n Typerep.Named.T2 (module struct\n type ('a, 'b) named = ('a, 'b) X.t\n type a = p1 let a = of_p1\n type b = p2 let b = of_p2\n type t = (p1, p2) X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T2 with type t = (p1, p2) X.t)\nend\n\nmodule Make3 (X : Named_intf.S3) = struct\n module Name_of_x = Typename.Make3 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named (type p1) (type p2) (type p3) of_p1 of_p2 of_p3 =\n let typename_of_t = Name_of_x.typename_of_t\n (Typerep.typename_of_t of_p1)\n (Typerep.typename_of_t of_p2)\n (Typerep.typename_of_t of_p3)\n in\n Typerep.Named.T3 (module struct\n type ('a, 'b, 'c) named = ('a, 'b, 'c) X.t\n type a = p1 let a = of_p1\n type b = p2 let b = of_p2\n type c = p3 let c = of_p3\n type t = (p1, p2, p3) X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T3 with type t = (p1, p2, p3) X.t)\nend\n\nmodule Make4 (X : Named_intf.S4) = struct\n module Name_of_x = Typename.Make4 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named (type p1) (type p2) (type p3) (type p4) of_p1 of_p2 of_p3 of_p4 =\n let typename_of_t = Name_of_x.typename_of_t\n (Typerep.typename_of_t of_p1)\n (Typerep.typename_of_t of_p2)\n (Typerep.typename_of_t of_p3)\n (Typerep.typename_of_t of_p4)\n in\n Typerep.Named.T4 (module struct\n type ('a, 'b, 'c, 'd) named = ('a, 'b, 'c, 'd) X.t\n type a = p1 let a = of_p1\n type b = p2 let b = of_p2\n type c = p3 let c = of_p3\n type d = p4 let d = of_p4\n type t = (p1, p2, p3, p4) X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T4 with type t = (p1, p2, p3, p4) X.t)\nend\n\nmodule Make5 (X : Named_intf.S5) = struct\n module Name_of_x = Typename.Make5 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named\n (type p1) (type p2) (type p3) (type p4) (type p5)\n of_p1 of_p2 of_p3 of_p4 of_p5 =\n let typename_of_t = Name_of_x.typename_of_t\n (Typerep.typename_of_t of_p1)\n (Typerep.typename_of_t of_p2)\n (Typerep.typename_of_t of_p3)\n (Typerep.typename_of_t of_p4)\n (Typerep.typename_of_t of_p5)\n in\n Typerep.Named.T5 (module struct\n type ('a, 'b, 'c, 'd, 'e) named = ('a, 'b, 'c, 'd, 'e) X.t\n type a = p1 let a = of_p1\n type b = p2 let b = of_p2\n type c = p3 let c = of_p3\n type d = p4 let d = of_p4\n type e = p5 let e = of_p5\n type t = (p1, p2, p3, p4, p5) X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T5 with type t = (p1, p2, p3, p4, p5) X.t)\nend\n","(**\n Place holder for common Variants and Fields interface\n*)\n\nmodule M (X : sig\n\n (**\n This functor is essentially there because we use this same interface in different\n contexts, with different types for ['a t].\n\n 1) One use case for it is where ['a X.t = 'a Typerep.t]. These interfaces are then\n part of the type witness built for a type containing a record or a variant in its\n structure. [traverse] will give a way of accessing the type representation for the\n arguments of a variant or record type.\n\n 2) Another use case is for building \"staged generic computations\". In that case, the\n type ['a X.t] is the type of the computation that is being built. [traverse]\n returns the computation built for the argument. The interface no longer exports\n the typerep of the arguments in hopes of enforcing that no typerep traversal\n happens at runtime if the computation happen to be a function.\n *)\n type 'a t\nend) = struct\n\n (* The functions prefixed by [internal] as well as the module suffixed by [_internal]\n are used by the code generated by the camlp4 extension [with typerep] as well as some\n internals of the typerep library. Do not consider using these somewhere else. They\n should ideally not be exported outside the typerep library, but the generated code\n needs somehow to access this, even outside. *)\n\n module Tag_internal = struct\n type ('variant, 'args) create = Args of ('args -> 'variant) | Const of 'variant\n type ('variant, 'args) t =\n { label : string\n ; rep : 'args X.t\n ; arity : int\n ; args_labels: string list\n ; index : int\n ; ocaml_repr : int\n ; tyid : 'args Typename.t\n ; create : ('variant, 'args) create\n }\n end\n\n (**\n Witness of a tag, that is an item in a variant type, also called an \"applied\n variant Constructor\"\n\n The first parameter is the variant type, the second is the type of the tag\n parameters. Example:\n\n {[\n type t =\n | A of (int * string)\n | B of string\n | C of { x : int; y : string }\n ]}\n\n this type has three constructors. For each of them we'll have a corresponding\n [Tag.t]:\n\n {[\n val tag_A : (t, (int * string)) Tag.t\n val tag_B : (t, string ) Tag.t\n val tag_C : (t, (int * string)) Tag.t\n ]}\n\n Note, inline record in variant are typed as if their definition was using tuples,\n without the parenthesis. This is consistent with their runtime representation. But\n the distinction is carried and available for introspection as part of the [Tag.t].\n See [args_labels]. *)\n module Tag : sig\n type ('variant, 'args) create = Args of ('args -> 'variant) | Const of 'variant\n type ('variant, 'args) t\n\n (**\n The name of the constructor as it is given in the concrete syntax\n Examples:\n\n {v\n Constructor | label\n -------------------------\n | A of int | \"A\"\n | `a of int | \"a\"\n | `A of int | \"A\"\n | A of { x : int } | \"A\"\n v}\n\n for standard variant, the ocaml syntax implies that this label will always starts\n with a capital letter. For polymorphic variants, this might be a lowercase char.\n For polymorphic variant, this label does not include the [`] character.\n *)\n val label : (_, _) t -> string\n\n (**\n The size of the ocaml heap block containing the arguments\n\n Examples:\n {v\n 0: | A | 'A\n 1: | A of int | `A of int | A of (int * int) | `A of (int * int)\n | `A of int * int\n | A of { x : int}\n 2: | A of int * float\n | A of { x : int; y : string }\n etc.\n v}\n *)\n val arity : (_, _) t -> int\n\n (** The label of the fields for inline records. For other forms of tags, this is the\n empty list. When this returns a non empty list, the length of the returned list\n is equal to the arity.\n\n Example:\n\n {v\n (1) Empty:\n\n | A | 'A\n | A of int | `A of int | A of (int * int) | `A of (int * int)\n | `A of int * int\n | A of int * float\n\n (2) Non empty:\n\n | A of { x : int } -> [ \"x\" ]\n | A of { x : int; y : string } -> [ \"x\" ; \"y\" ]\n v}\n *)\n val args_labels : (_, _) t -> string list\n\n (**\n The index of the constructor in the list of all the variant type's constructors\n Examples:\n {[\n type t =\n | A of int (* 0 *)\n | B (* 1 *)\n | C of int (* 2 *)\n | D of char (* 3 *)\n | E of { x : int } (* 4 *)\n ]}\n *)\n val index : (_, _) t -> int\n\n (**\n ocaml_repr is related to the runtime of objects. this is essentially a way of\n giving one the ability to rebuild dynamically an [Obj.t] representing a tag.\n\n Polymorphic variants:\n ---------------------\n\n [ocaml_repr] is the hash of the label, as done by the compiler.\n Example:\n print_int (Obj.magic `bar) (* 4895187 *)\n print_int (Obj.magic 'foo) (* 5097222 *)\n\n Standards variants:\n -------------------\n\n [ocaml_repr] is the tag corresponding to the constructor within the type.\n the way it works in the ocaml runtime is by partitioning the constructors regarding\n if they have some arguments or not, preserving the order, then assign increasing\n index withing each partition.\n Example:\n\n {[\n type t = (* no arg *) (* args *)\n | A (* 0 *)\n | B of int (* 0 *)\n | C (* 1 *)\n | D of (float * string) (* 1 *)\n | E (* 2 *)\n | F (* 3 *)\n | G of string (* 2 *)\n | H of { x : int } (* 3 *)\n ]}\n *)\n val ocaml_repr : (_, _) t -> int\n\n (**\n Give back a way of constructing a value of that constructor from its arguments.\n\n Examples:\n\n {[\n type t =\n | A of (int * string)\n | B of int * float\n | C\n | D of { x : int; y : string }\n ]}\n\n [create] will return something equivalent to:\n tag_A : [Args (fun (d : (int * string) -> A d)]\n tag_B : [Args (fun (i, f) -> B (i, f))]\n tag_C : [Const C]\n tag_D : [Args (fun (x, y) -> D { x; y })]\n *)\n val create : ('variant, 'args) t -> ('variant, 'args) create\n\n (** return the type_name of the arguments. might be used to perform some lookup based\n on it while building a computation for example *)\n val tyid : (_, 'args) t -> 'args Typename.t\n\n (** get the representation/computation of the arguments *)\n val traverse : (_, 'args) t -> 'args X.t\n\n (* used by the camlp4 extension to build type witnesses, or by some internal parts of\n typerep. you should feel bad if you need to use it in some user code *)\n val internal_use_only : ('a, 'b) Tag_internal.t -> ('a, 'b) t\n end = struct\n include Tag_internal\n let label t = t.label\n let arity t = t.arity\n let args_labels t = t.args_labels\n let index t = t.index\n let ocaml_repr t = t.ocaml_repr\n let create t = t.create\n let tyid t = t.tyid\n let traverse t = t.rep\n\n let internal_use_only t = t\n end\n\n module Variant_internal = struct\n type _ tag = Tag : ('variant, 'a) Tag.t -> 'variant tag\n type _ value = Value : ('variant, 'a) Tag.t * 'a -> 'variant value\n type 'a t = {\n typename : 'a Typename.t;\n tags : 'a tag array;\n polymorphic : bool;\n value : 'a -> 'a value;\n }\n end\n\n module Variant : sig\n\n (**\n An existential type used to gather all the tags constituing a variant\n type. the ['variant] parameter is the variant type, it is the same for all the\n constructors of that variant type. The type of the parameters might be different\n for each constructor and is thus existential\n *)\n type _ tag = Tag : ('variant, 'args) Tag.t -> 'variant tag\n\n (**\n A similar existential constructor to [_ tag] but this one holds a value whose type\n is the arguments of the tag constructor. A value of type ['a value] is a pair of\n (1) a value of variant type ['a] along with (2) some information about the\n constructor within the type ['a]\n *)\n type _ value = Value : ('variant, 'args) Tag.t * 'args -> 'variant value\n\n (**\n Witness of a variant type. The parameter is the type of the variant type witnessed.\n *)\n type 'a t\n\n val typename_of_t : 'a t -> 'a Typename.t\n\n (**\n Returns the number of tags of this variant type definition.\n *)\n val length : 'a t -> int\n\n (**\n Get the nth tag of this variant type, indexed from 0.\n *)\n val tag : 'a t -> int -> 'a tag\n\n (**\n Distinguish polymorphic variants and standard variants. Typically, polymorphic\n variants tags starts with the [`] character.\n Example\n polymorphic variant: type t = [ `A | `B ]\n standard variant: type t = A | B\n *)\n val is_polymorphic : _ t -> bool\n\n (**\n Pattern matching on a value of this variant type.\n *)\n val value : 'a t -> 'a -> 'a value\n\n (**\n folding along the tags of the variant type\n *)\n val fold : 'a t -> init:'acc -> f:('acc -> 'a tag -> 'acc) -> 'acc\n\n (* used by the camlp4 extension to build type witnesses, or by some internal parts of\n typerep. you should feel bad if you need to use it in some user code *)\n val internal_use_only : 'a Variant_internal.t -> 'a t\n end = struct\n include Variant_internal\n let typename_of_t t = t.typename\n let length t = Array.length t.tags\n let tag t index = t.tags.(index)\n let is_polymorphic t = t.polymorphic\n let value t = t.value\n\n let fold t ~init ~f = Array.fold_left f init t.tags\n\n let internal_use_only t = t\n end\n\n module Field_internal = struct\n type ('record, 'field) t = {\n label : string;\n rep : 'field X.t;\n index : int;\n tyid : 'field Typename.t;\n get : ('record -> 'field);\n (* set : ('record -> 'field -> unit) option; (\\* mutable field *\\) *)\n is_mutable : bool;\n }\n end\n\n (**\n Witness of a field, that is an item in a record type.\n The first parameter is the record type, the second is the type of the field.\n Example:\n {[\n type t = { x : int ; y : string }\n ]}\n This type has two fields. for each of them we'll have a corresponding [Field.t]\n\n val field_x : (t, int) Field.t\n val field_y : (t, string) Field.t\n *)\n module Field : sig\n type ('record, 'field) t\n\n (**\n The name of the field as it is given in the concrete syntax\n Examples:\n {[\n { x : int; (* \"x\" *)\n foo : string; (* \"foo\" *)\n bar : float; (* \"bar\" *)\n }\n ]}\n *)\n val label : (_, _) t -> string\n\n (**\n The 0-based index of the field in the list of all fields for this record type.\n Example:\n {[\n type t = {\n x : int; (* 0 *)\n foo : string; (* 1 *)\n bar : string; (* 2 *)\n }\n ]}\n *)\n val index : (_, _) t -> int\n\n (**\n Field accessors. This corresponds to the dot operation.\n [Field.get bar_field t] returns the field [bar] of the record value [t], just the\n same as [t.bar]\n *)\n val get : ('record, 'field) t -> 'record -> 'field\n\n (** return whether the field is mutable, i.e. whether its declaration is prefixed with\n the keyword [mutable] *)\n val is_mutable : (_, _) t -> bool\n\n (** return the type_name of the arguments. Might be used to perform some lookup based\n on it *)\n val tyid : (_, 'field) t -> 'field Typename.t\n\n (** get the computation of the arguments *)\n val traverse : (_, 'field) t -> 'field X.t\n\n (* used by the camlp4 extension to build type witnesses, or by some internal parts of\n typerep. you should feel bad if you need to use it in some user code *)\n val internal_use_only : ('a, 'b) Field_internal.t -> ('a, 'b) t\n end = struct\n include Field_internal\n let label t = t.label\n let index t = t.index\n let get t = t.get\n let is_mutable t = t.is_mutable\n let tyid t = t.tyid\n let traverse t = t.rep\n\n let internal_use_only t = t\n end\n\n module Record_internal = struct\n type _ field = Field : ('record, 'a) Field.t -> 'record field\n type 'record fields = { get : 'field. ('record, 'field) Field.t -> 'field }\n type 'a t = {\n typename : 'a Typename.t;\n fields : 'a field array;\n has_double_array_tag : bool;\n create : 'a fields -> 'a;\n }\n end\n\n module Record : sig\n\n (**\n An existential type used to gather all the fields constituing a record type. the\n ['record] parameter is the record type, it is the same for all the field of that\n record type. The type of the fields might be different for each field and is thus\n existential.\n *)\n type _ field = Field : ('record, 'a) Field.t -> 'record field\n\n (**\n ['record fields] is a type isomorphic to ['record]. This gives a way to get the\n field value for each field of the record. The advantage of this representation is\n that it is convenient for writing generic computations.\n *)\n type 'record fields = { get : 'field. ('record, 'field) Field.t -> 'field }\n\n (**\n Witness of a record type. The parameter is the type of the record type witnessed.\n *)\n type 'a t\n\n val typename_of_t : 'a t -> 'a Typename.t\n\n (**\n Returns the number of fields of this record type definition.\n *)\n val length : 'a t -> int\n\n (**\n Get the nth field of this record type, indexed from 0.\n *)\n val field : 'a t -> int -> 'a field\n\n (**\n This is a low level metadata regarding the way the ocaml compiler represent the\n array underneath that is the runtime value of a record of type ['a] given a witness\n of type ['a t]. [has_double_array_tag w] returns [true] if the array that\n represents runtime values of this type is an optimized ocaml float array.\n Typically, this will be true for record where all fields are statically known as to\n be [floats].\n\n Note that you can't get this information dynamically by inspecting the typerep once\n it is applied, because there is at this point no way to tell whether one of the\n field is polymorphic in the type definition.\n *)\n val has_double_array_tag : _ t -> bool\n\n (**\n Expose one direction of the isomorphism between a value of type ['a] and a value of\n type ['a fields]. Basically, given an encoding way of accessing the value of all\n the fields of a record, create that record and return it.\n *)\n val create : 'a t -> 'a fields -> 'a\n\n (**\n folding along the tags of the variant type\n *)\n val fold : 'a t -> init:'acc -> f:('acc -> 'a field -> 'acc) -> 'acc\n\n (* used by the camlp4 extension to build type witnesses, or by some internal parts of\n typerep. you should feel bad if you need to use it in some user code *)\n val internal_use_only : 'a Record_internal.t -> 'a t\n end = struct\n include Record_internal\n let typename_of_t t = t.typename\n let length t = Array.length t.fields\n let field t index = t.fields.(index)\n let has_double_array_tag t = t.has_double_array_tag\n let create t = t.create\n let fold t ~init ~f = Array.fold_left f init t.fields\n\n let internal_use_only t = t\n end\nend\n\nmodule type S = sig\n type 'a t\n include (module type of M (struct type 'a rep = 'a t type 'a t = 'a rep end))\nend\n","(* using the hash_variant of pa_type_conv at compile time *)\nlet repr_of_poly_variant : [> ] -> int = fun variant ->\n let obj = Obj.repr variant in\n if Obj.is_int obj then Obj.obj obj\n else\n let size = Obj.size obj in\n assert (size = 2);\n let repr = Obj.field obj 0 in\n (assert (Obj.is_int repr));\n Obj.obj repr\n\nlet hash_variant s =\n let accu = ref 0 in\n for i = 0 to String.length s - 1 do\n accu := 223 * !accu + Char.code s.[i]\n done;\n (* reduce to 31 bits *)\n accu := !accu land (1 lsl 31 - 1);\n (* make it signed for 64 bits architectures *)\n if !accu > 0x3FFFFFFF then !accu - (1 lsl 31) else !accu\n\n(* a few unit tests of cases that have triggered diffs in the past of this\n lib *)\nlet () = assert (repr_of_poly_variant `Latency_stats = hash_variant \"Latency_stats\")\nlet () = assert (repr_of_poly_variant `zero = hash_variant \"zero\")\n\nlet double_array_value = Obj.magic 0.\nlet has_double_array_tag a = Obj.double_array_tag = (Obj.tag (Obj.repr a))\nlet () =\n let module M = struct\n type double = { a : float ; b : float }\n type simple = { c : float ; d : int }\n let double = { a = double_array_value; b = double_array_value; }\n let simple = { c = double_array_value; d = double_array_value; }\n end in\n assert (has_double_array_tag M.double);\n assert (not (has_double_array_tag M.simple));\n;;\n","open Std_internal\n\nmodule Make0 (X : Named_intf.S0) : Typerepable.S\n with type t := X.t\n= struct\n module M = Make_typename.Make0(X)\n let typerep_of_t =\n Typerep.Named (M.named, None)\n let typename_of_t = M.typename_of_t\nend\n\nmodule Make1 (X : Named_intf.S1) : Typerepable.S1\n with type 'a t := 'a X.t\n= struct\n module M = Make_typename.Make1(X)\n let typerep_of_t of_p1 =\n Typerep.Named (M.named of_p1, None)\n let typename_of_t = M.typename_of_t\nend\n\nmodule Make2 (X : Named_intf.S2) : Typerepable.S2\n with type ('a, 'b) t := ('a, 'b) X.t\n= struct\n module M = Make_typename.Make2(X)\n let typerep_of_t of_p1 of_p2 =\n Typerep.Named (M.named of_p1 of_p2, None)\n let typename_of_t = M.typename_of_t\nend\n\nmodule Make3 (X : Named_intf.S3) : Typerepable.S3\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) X.t\n= struct\n module M = Make_typename.Make3(X)\n let typerep_of_t of_p1 of_p2 of_p3 =\n Typerep.Named (M.named of_p1 of_p2 of_p3, None)\n let typename_of_t = M.typename_of_t\nend\n\nmodule Make4 (X : Named_intf.S4) : Typerepable.S4\n with type ('a, 'b, 'c, 'd) t := ('a, 'b, 'c, 'd) X.t\n= struct\n module M = Make_typename.Make4(X)\n let typerep_of_t of_p1 of_p2 of_p3 of_p4 =\n Typerep.Named (M.named of_p1 of_p2 of_p3 of_p4, None)\n let typename_of_t = M.typename_of_t\nend\n\nmodule Make5 (X : Named_intf.S5) : Typerepable.S5\n with type ('a, 'b, 'c, 'd, 'e) t := ('a, 'b, 'c, 'd, 'e) X.t\n= struct\n module M = Make_typename.Make5(X)\n let typerep_of_t of_p1 of_p2 of_p3 of_p4 of_p5 =\n Typerep.Named (M.named of_p1 of_p2 of_p3 of_p4 of_p5, None)\n let typename_of_t = M.typename_of_t\nend\n","open! Base\nopen Import\n\nmodule Name : sig\n type t [@@deriving_inline sexp, compare]\n\n include sig\n [@@@ocaml.warning \"-32\"]\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n val compare : t -> t -> int\n end\n [@@ocaml.doc \"@inline\"]\n\n [@@@end]\n\n val relative_to : dir:string -> t -> string\n\n include Identifiable.S with type t := t\nend = struct\n include String\n\n let relative_to ~dir t =\n if not (Caml.Filename.is_relative t) then t else Caml.Filename.concat dir t\n ;;\nend\n\nlet initial_dir =\n let dir_or_error =\n match Caml.Sys.getcwd () with\n | v -> `Ok v\n | exception exn -> `Exn exn\n in\n fun () ->\n match dir_or_error with\n | `Ok v -> v\n | `Exn exn -> raise exn\n;;\n\nmodule Location = struct\n module T = struct\n type t =\n { filename : Name.t\n ; line_number : int\n ; line_start : int\n ; start_pos : int\n ; end_pos : int\n }\n [@@deriving_inline sexp, compare]\n\n let _ = fun (_ : t) -> ()\n\n let t_of_sexp =\n (let _tp_loc = \"file.ml.Location.T.t\" in\n function\n | Ppx_sexp_conv_lib.Sexp.List field_sexps as sexp ->\n let filename_field = ref Ppx_sexp_conv_lib.Option.None\n and line_number_field = ref Ppx_sexp_conv_lib.Option.None\n and line_start_field = ref Ppx_sexp_conv_lib.Option.None\n and start_pos_field = ref Ppx_sexp_conv_lib.Option.None\n and end_pos_field = ref Ppx_sexp_conv_lib.Option.None\n and duplicates = ref []\n and extra = ref [] in\n let rec iter = function\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom field_name :: (([] | [ _ ]) as _field_sexps))\n :: tail ->\n let _field_sexp () =\n match _field_sexps with\n | [ x ] -> x\n | [] ->\n Ppx_sexp_conv_lib.Conv_error.record_only_pairs_expected _tp_loc sexp\n | _ -> assert false\n in\n (match field_name with\n | \"filename\" ->\n (match !filename_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = Name.t_of_sexp _field_sexp in\n filename_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ ->\n duplicates := field_name :: !duplicates)\n | \"line_number\" ->\n (match !line_number_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n line_number_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ ->\n duplicates := field_name :: !duplicates)\n | \"line_start\" ->\n (match !line_start_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n line_start_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ ->\n duplicates := field_name :: !duplicates)\n | \"start_pos\" ->\n (match !start_pos_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n start_pos_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ ->\n duplicates := field_name :: !duplicates)\n | \"end_pos\" ->\n (match !end_pos_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n end_pos_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ ->\n duplicates := field_name :: !duplicates)\n | _ ->\n if !Ppx_sexp_conv_lib.Conv.record_check_extra_fields\n then extra := field_name :: !extra\n else ());\n iter tail\n | ((Ppx_sexp_conv_lib.Sexp.Atom _ | Ppx_sexp_conv_lib.Sexp.List _) as sexp)\n :: _ -> Ppx_sexp_conv_lib.Conv_error.record_only_pairs_expected _tp_loc sexp\n | [] -> ()\n in\n iter field_sexps;\n (match !duplicates with\n | _ :: _ ->\n Ppx_sexp_conv_lib.Conv_error.record_duplicate_fields _tp_loc !duplicates sexp\n | [] ->\n (match !extra with\n | _ :: _ ->\n Ppx_sexp_conv_lib.Conv_error.record_extra_fields _tp_loc !extra sexp\n | [] ->\n (match\n ( !filename_field\n , !line_number_field\n , !line_start_field\n , !start_pos_field\n , !end_pos_field )\n with\n | ( Ppx_sexp_conv_lib.Option.Some filename_value\n , Ppx_sexp_conv_lib.Option.Some line_number_value\n , Ppx_sexp_conv_lib.Option.Some line_start_value\n , Ppx_sexp_conv_lib.Option.Some start_pos_value\n , Ppx_sexp_conv_lib.Option.Some end_pos_value ) ->\n { filename = filename_value\n ; line_number = line_number_value\n ; line_start = line_start_value\n ; start_pos = start_pos_value\n ; end_pos = end_pos_value\n }\n | _ ->\n Ppx_sexp_conv_lib.Conv_error.record_undefined_elements\n _tp_loc\n sexp\n [ ( Ppx_sexp_conv_lib.Conv.( = )\n !filename_field\n Ppx_sexp_conv_lib.Option.None\n , \"filename\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !line_number_field\n Ppx_sexp_conv_lib.Option.None\n , \"line_number\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !line_start_field\n Ppx_sexp_conv_lib.Option.None\n , \"line_start\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !start_pos_field\n Ppx_sexp_conv_lib.Option.None\n , \"start_pos\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !end_pos_field\n Ppx_sexp_conv_lib.Option.None\n , \"end_pos\" )\n ])))\n | Ppx_sexp_conv_lib.Sexp.Atom _ as sexp ->\n Ppx_sexp_conv_lib.Conv_error.record_list_instead_atom _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> t)\n ;;\n\n let _ = t_of_sexp\n\n let sexp_of_t =\n (function\n | { filename = v_filename\n ; line_number = v_line_number\n ; line_start = v_line_start\n ; start_pos = v_start_pos\n ; end_pos = v_end_pos\n } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_int v_end_pos in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"end_pos\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_start_pos in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"start_pos\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_line_start in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"line_start\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_line_number in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"line_number\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = Name.sexp_of_t v_filename in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"filename\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n let _ = sexp_of_t\n\n let compare =\n (fun a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match Name.compare a__001_.filename b__002_.filename with\n | 0 ->\n (match compare_int a__001_.line_number b__002_.line_number with\n | 0 ->\n (match compare_int a__001_.line_start b__002_.line_start with\n | 0 ->\n (match compare_int a__001_.start_pos b__002_.start_pos with\n | 0 -> compare_int a__001_.end_pos b__002_.end_pos\n | n -> n)\n | n -> n)\n | n -> n)\n | n -> n)\n : t -> t -> int)\n ;;\n\n let _ = compare\n\n [@@@end]\n\n let compare a b =\n if not (Name.equal a.filename b.filename)\n then invalid_arg \"Expect_test_collector.File.Location.compare\"\n else compare a b\n ;;\n end\n\n include T\n include Comparable.Make (T)\n\n let beginning_of_file filename =\n { filename; line_number = 1; line_start = 0; start_pos = 0; end_pos = 0 }\n ;;\nend\n\nmodule Digest : sig\n type t [@@deriving_inline sexp_of, compare]\n\n include sig\n [@@@ocaml.warning \"-32\"]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n val compare : t -> t -> int\n end\n [@@ocaml.doc \"@inline\"]\n\n [@@@end]\n\n val to_string : t -> string\n val of_string : string -> t\nend = struct\n type t = string [@@deriving_inline sexp_of, compare]\n\n let _ = fun (_ : t) -> ()\n let sexp_of_t = (sexp_of_string : t -> Ppx_sexp_conv_lib.Sexp.t)\n let _ = sexp_of_t\n let compare = (compare_string : t -> t -> int)\n let _ = compare\n\n [@@@end]\n\n let to_string t = t\n\n let of_string s =\n let expected_length = 32 in\n if String.length s <> expected_length\n then invalid_arg \"Expect_test_collector.File.Digest.of_string, unexpected length\";\n for i = 0 to expected_length - 1 do\n match s.[i] with\n | '0' .. '9' | 'a' .. 'f' -> ()\n | _ -> invalid_arg \"Expect_test_collector.File.Digest.of_string\"\n done;\n s\n ;;\nend\n","open Expect_test_common\nmodule List = ListLabels\n\nmodule Test_outcome = struct\n type t =\n { file_digest : File.Digest.t\n ; location : File.Location.t\n ; expectations : Expectation.Raw.t list\n ; uncaught_exn_expectation : Expectation.Raw.t option\n ; saved_output : (File.Location.t * string) list\n ; trailing_output : string\n ; upon_unreleasable_issue : Expect_test_config_types.Upon_unreleasable_issue.t\n ; uncaught_exn : (exn * Printexc.raw_backtrace) option\n }\nend\n\nlet tests_run : Test_outcome.t list ref = ref []\n\nlet protect ~finally ~f =\n match f () with\n | x ->\n finally ();\n x\n | exception e ->\n finally ();\n raise e\n;;\n\nmodule Current_file = struct\n let current = ref None\n\n let set ~absolute_filename =\n match !current with\n | None -> current := Some absolute_filename\n | Some _ -> failwith \"Expect_test_collector.set: already set\"\n ;;\n\n let unset () =\n match !current with\n | Some _ -> current := None\n | None -> failwith \"Expect_test_collector.unset: not set\"\n ;;\n\n let get () =\n match !current with\n | Some fn -> fn\n | None -> failwith \"Expect_test_collector.get: not set\"\n ;;\nend\n\nmodule Make (C : Expect_test_config_types.S) = struct\n let ( >>= ) t f = C.IO_flush.bind t ~f\n let return = C.IO_flush.return\n\n module C = struct\n include C\n\n let flush () =\n Format.pp_print_flush Format.std_formatter ();\n Format.pp_print_flush Format.err_formatter ();\n Caml.flush Caml.stdout;\n Caml.flush Caml.stderr;\n C.flush ()\n ;;\n end\n\n module Instance : sig\n val save_output : File.Location.t -> unit C.IO_flush.t\n val save_and_return_output : File.Location.t -> string C.IO_flush.t\n\n val exec\n : file_digest:File.Digest.t\n -> location:File.Location.t\n -> expectations:Expectation.Raw.t list\n -> uncaught_exn_expectation:Expectation.Raw.t option\n -> f:(unit -> unit C.IO_run.t)\n -> unit\n end = struct\n type t =\n { mutable saved : (File.Location.t * int) list\n ; chan : out_channel\n ; filename : File.Name.t\n }\n\n external before_test\n : output:out_channel\n -> stdout:out_channel\n -> stderr:out_channel\n -> unit\n = \"expect_test_collector_before_test\"\n\n external after_test\n : stdout:out_channel\n -> stderr:out_channel\n -> unit\n = \"expect_test_collector_after_test\"\n\n external pos_out : out_channel -> int = \"caml_out_channel_pos_fd\"\n\n let get_position () = pos_out stdout\n\n let create () =\n let filename = Filename.temp_file \"expect-test\" \"output\" in\n let chan = open_out_bin filename in\n before_test ~output:chan ~stdout ~stderr;\n { chan; filename = File.Name.of_string filename; saved = [] }\n ;;\n\n let extract_output ic len =\n let s = really_input_string ic len in\n if not (Check_backtraces.contains_backtraces s)\n then s\n else\n Expect_test_config_types.Upon_unreleasable_issue\n .message_when_expectation_contains_backtrace\n C.upon_unreleasable_issue\n ^ s\n ;;\n\n let relative_filename t = File.Name.relative_to ~dir:(File.initial_dir ()) t.filename\n\n let with_ic fname ~f =\n let ic = open_in_bin fname in\n protect ~finally:(fun () -> close_in ic) ~f:(fun () -> f ic)\n ;;\n\n let get_outputs_and_cleanup t =\n let last_ofs = get_position () in\n after_test ~stdout ~stderr;\n close_out t.chan;\n let fname = relative_filename t in\n protect\n ~finally:(fun () -> Sys.remove fname)\n ~f:(fun () ->\n with_ic fname ~f:(fun ic ->\n let ofs, outputs =\n List.fold_left\n (List.rev t.saved)\n ~init:(0, [])\n ~f:(fun (ofs, acc) (loc, next_ofs) ->\n let s = extract_output ic (next_ofs - ofs) in\n next_ofs, (loc, s) :: acc)\n in\n let trailing_output = extract_output ic (last_ofs - ofs) in\n List.rev outputs, trailing_output))\n ;;\n\n let current_test : (File.Location.t * t) option ref = ref None\n\n let get_current () =\n match !current_test with\n | Some (_, t) -> t\n | None ->\n failwith \"Expect_test_collector.Instance.get_current called outside a test.\"\n ;;\n\n let save_output location =\n let t = get_current () in\n C.flush ()\n >>= fun () ->\n let pos = get_position () in\n t.saved <- (location, pos) :: t.saved;\n return ()\n ;;\n\n let save_and_return_output location =\n let t = get_current () in\n C.flush ()\n >>= fun () ->\n let pos = get_position () in\n let prev_pos =\n match t.saved with\n | [] -> 0\n | (_, prev_pos) :: _ -> prev_pos\n in\n t.saved <- (location, pos) :: t.saved;\n flush t.chan;\n let len = pos - prev_pos in\n return\n (with_ic (relative_filename t) ~f:(fun ic ->\n seek_in ic prev_pos;\n really_input_string ic len))\n ;;\n\n let () =\n Caml.at_exit (fun () ->\n match !current_test with\n | None -> ()\n | Some (loc, t) ->\n let blocks, trailing = get_outputs_and_cleanup t in\n Printf.eprintf\n \"File %S, line %d, characters %d-%d:\\n\\\n Error: program exited while expect test was running!\\n\\\n Output captured so far:\\n\\\n %!\"\n (File.Name.to_string loc.filename)\n loc.line_number\n (loc.start_pos - loc.line_start)\n (loc.end_pos - loc.line_start);\n List.iter blocks ~f:(fun (_, s) -> Printf.eprintf \"%s%!\" s);\n Printf.eprintf \"%s%!\" trailing)\n ;;\n\n let rec final_flush ?(count = 0) k =\n let max_attempts = 10 in\n C.flush ()\n >>= fun () ->\n if C.flushed ()\n then k ~append:\"\"\n else if count = max_attempts\n then\n k\n ~append:\n (Printf.sprintf\n \"\\n\\\n STOPPED COLLECTING OUTPUT AFTER %d FLUSHING ATTEMPS\\n\\\n THERE MUST BE A BACKGROUND JOB PRINTING TO STDOUT\\n\"\n max_attempts)\n else final_flush ~count:(count + 1) k\n ;;\n\n let exec ~file_digest ~location ~expectations ~uncaught_exn_expectation ~f =\n let t = create () in\n current_test := Some (location, t);\n let finally uncaught_exn =\n C.run (fun () ->\n C.IO_flush.to_run\n (final_flush (fun ~append ->\n current_test := None;\n let saved_output, trailing_output = get_outputs_and_cleanup t in\n tests_run\n := { file_digest\n ; location\n ; expectations\n ; uncaught_exn_expectation\n ; saved_output\n ; trailing_output = trailing_output ^ append\n ; upon_unreleasable_issue = C.upon_unreleasable_issue\n ; uncaught_exn\n }\n :: !tests_run;\n return ())))\n in\n match C.run f with\n | () -> finally None\n | exception exn ->\n let bt = Printexc.get_raw_backtrace () in\n finally (Some (exn, bt))\n ;;\n end\n\n let save_output = Instance.save_output\n let save_and_return_output = Instance.save_and_return_output\n\n let run\n ~file_digest\n ~(location : File.Location.t)\n ~absolute_filename:defined_in\n ~description\n ~tags\n ~expectations\n ~uncaught_exn_expectation\n ~inline_test_config\n f\n =\n Ppx_inline_test_lib.Runtime.test\n ~config:inline_test_config\n ~descr:\n (match description with\n | None -> \"\"\n | Some s -> \": \" ^ s)\n ~tags\n ~filename:(File.Name.to_string location.filename)\n ~line_number:location.line_number\n ~start_pos:(location.start_pos - location.line_start)\n ~end_pos:(location.end_pos - location.line_start)\n (fun () ->\n let registering_tests_for = Current_file.get () in\n if defined_in <> registering_tests_for\n then\n Printf.ksprintf\n failwith\n \"Trying to run an expect test from the wrong file.\\n\\\n - test declared at %s:%d\\n\\\n - trying to run it from %s\\n\"\n defined_in\n location.line_number\n registering_tests_for\n else (\n (* To avoid capturing not-yet flushed data of the stdout buffer *)\n C.run (fun () -> C.IO_flush.to_run (C.flush ()));\n Instance.exec ~file_digest ~location ~expectations ~uncaught_exn_expectation ~f;\n true))\n ;;\nend\n[@@inline never]\n\nlet tests_run () =\n (* We prepend tests when we encounter them, so reverse the list to reinstate order *)\n List.rev !tests_run\n;;\n","module Upon_unreleasable_issue = struct\n type t =\n [ `CR (** Leaves a CR, so that features cannot be released. *)\n | `Warning_for_collector_testing (** Only for ppx_expect testing; do not use. *)\n ]\nend\n\nmodule type S = sig\n module IO_run : sig\n type 'a t\n end\n\n module IO_flush : sig\n type 'a t\n\n val return : 'a -> 'a t\n val bind : 'a t -> f:('a -> 'b t) -> 'b t\n val to_run : 'a t -> 'a IO_run.t\n end\n\n (** Flush whatever need to be to get pending output out on file descriptor 0. *)\n val flush : unit -> unit IO_flush.t\n\n (** Run an IO operation until completion *)\n val run : (unit -> unit IO_run.t) -> unit\n\n (** Synchronous check that there is no pending output on file description 0. With async,\n there is no guarantee that on the rhs of a [IO.bind (flush ()) ...] the output is\n completely flushed, that's why we need this. *)\n val flushed : unit -> bool\n\n\n (** [upon_unreleasable_issue] specifies how to deal with output that should not be\n released even if it is accepted (e.g. backtraces). The default is [`CR]. *)\n val upon_unreleasable_issue : Upon_unreleasable_issue.t\nend\n\n(** Configuration for running expect tests *)\nmodule type Expect_test_config_types = sig\n (** To configure expect_test, add the following at the top of your .ml file, or in some\n import.ml:\n\n {[\n module Expect_test_config = struct\n include Expect_test_config\n let pre_redirect_hook () = ...\n end\n ]}\n\n Note that since all expect test are also inline tests, the inline test configuration\n also applies to all expect test.\n *)\n\n module Upon_unreleasable_issue : sig\n include module type of Upon_unreleasable_issue\n\n val equal : t -> t -> bool\n val comment_prefix : t -> string\n\n (** Message to print when an expectation contains a backtrace *)\n val message_when_expectation_contains_backtrace : t -> string\n end\n\n module type S = S\nend\n","module type S = Expect_test_config_types_intf.S\n\nmodule type Expect_test_config_types =\n Expect_test_config_types_intf.Expect_test_config_types\n\nmodule Upon_unreleasable_issue = struct\n include Expect_test_config_types_intf.Upon_unreleasable_issue\n\n let equal t1 t2 = t1 = t2\n\n let comment_prefix = function\n | `CR -> \"CR \"\n | `Warning_for_collector_testing -> \"\"\n ;;\n\n let message_when_expectation_contains_backtrace t =\n Printf.sprintf\n {|\n(* %sexpect_test_collector: This test expectation appears to contain a backtrace.\n This is strongly discouraged as backtraces are fragile.\n Please change this test to not include a backtrace. *)\n\n|}\n (comment_prefix t)\n ;;\nend\n","module IO_run = struct\n type 'a t = 'a\n\n let return x = x\n let bind t ~f = f t\nend\n\nmodule IO_flush = struct\n include IO_run\n\n let to_run t = t\nend\n\nlet flush () = () (* the runtime already flushes [stdout] *)\n\nlet run f = f ()\nlet flushed () = true (* the runtime flushed [stdout] before calling this function *)\n\nlet upon_unreleasable_issue = `CR\n","open! Base\n\nmodule T : sig\n type +'a t\n\n val create : (size:int -> random:Splittable_random.State.t -> 'a) -> 'a t\n val generate : 'a t -> size:int -> random:Splittable_random.State.t -> 'a\nend = struct\n type 'a t = (size:int -> random:Splittable_random.State.t -> 'a) Staged.t\n\n let create f : _ t = Staged.stage f\n\n let generate (t : _ t) ~size ~random =\n if size < 0\n then raise_s [%message \"Base_quickcheck.Generator.generate: size < 0\" (size : int)]\n else Staged.unstage t ~size ~random\n ;;\nend\n\ninclude T\n\nlet size = create (fun ~size ~random:_ -> size)\n\nlet fn dom rng =\n create (fun ~size ~random ->\n let random = Splittable_random.State.split random in\n fun x ->\n let hash = Observer0.observe dom x ~size ~hash:(Hash.alloc ()) in\n let random = Splittable_random.State.copy random in\n Splittable_random.State.perturb random (Hash.get_hash_value hash);\n generate rng ~size ~random)\n;;\n\nlet with_size t ~size = create (fun ~size:_ ~random -> generate t ~size ~random)\n\nlet perturb t salt =\n create (fun ~size ~random ->\n Splittable_random.State.perturb random salt;\n generate t ~size ~random)\n;;\n\nlet filter_map t ~f =\n let rec loop ~size ~random =\n let x = generate t ~size ~random in\n match f x with\n | Some y -> y\n | None -> loop ~size:(size + 1) ~random\n in\n create loop\n;;\n\nlet filter t ~f = filter_map t ~f:(fun x -> if f x then Some x else None)\nlet return x = create (fun ~size:_ ~random:_ -> x)\nlet map t ~f = create (fun ~size ~random -> f (generate t ~size ~random))\n\nlet apply tf tx =\n create (fun ~size ~random ->\n let f = generate tf ~size ~random in\n let x = generate tx ~size ~random in\n f x)\n;;\n\nlet bind t ~f =\n create (fun ~size ~random ->\n let x = generate t ~size ~random in\n generate (f x) ~size ~random)\n;;\n\nlet all list = create (fun ~size ~random -> List.map list ~f:(generate ~size ~random))\n\nlet all_unit list =\n create (fun ~size ~random -> List.iter list ~f:(generate ~size ~random))\n;;\n\nmodule For_applicative = Applicative.Make (struct\n type nonrec 'a t = 'a t\n\n let return = return\n let apply = apply\n let map = `Custom map\n end)\n\nlet both = For_applicative.both\nlet map2 = For_applicative.map2\nlet map3 = For_applicative.map3\n\nmodule Applicative_infix = For_applicative.Applicative_infix\ninclude Applicative_infix\n\nmodule For_monad = Monad.Make (struct\n type nonrec 'a t = 'a t\n\n let return = return\n let bind = bind\n let map = `Custom map\n end)\n\nlet ignore_m = For_monad.ignore_m\nlet join = For_monad.join\n\nmodule Monad_infix = For_monad.Monad_infix\ninclude Monad_infix\nmodule Let_syntax = For_monad.Let_syntax\nopen Let_syntax\n\nlet of_list list =\n if List.is_empty list\n then Error.raise_s [%message \"Base_quickcheck.Generator.of_list: empty list\"];\n let array = Array.of_list list in\n let lo = 0 in\n let hi = Array.length array - 1 in\n create (fun ~size:_ ~random ->\n let index = Splittable_random.int random ~lo ~hi in\n array.(index))\n;;\n\nlet union list = join (of_list list)\n\nlet of_weighted_list alist =\n if List.is_empty alist\n then Error.raise_s [%message \"Base_quickcheck.Generator.of_weighted_list: empty list\"];\n let weights, values = List.unzip alist in\n let value_array = Array.of_list values in\n let total_weight, cumulative_weight_array =\n let array = Array.init (Array.length value_array) ~f:(fun _ -> 0.) in\n let sum =\n List.foldi weights ~init:0. ~f:(fun index acc weight ->\n if not (Float.is_finite weight)\n then\n Error.raise_s\n [%message\n \"Base_quickcheck.Generator.of_weighted_list: weight is not finite\"\n (weight : float)];\n if Float.( < ) weight 0.\n then\n Error.raise_s\n [%message\n \"Base_quickcheck.Generator.of_weighted_list: weight is negative\"\n (weight : float)];\n let cumulative = acc +. weight in\n array.(index) <- cumulative;\n cumulative)\n in\n if Float.( <= ) sum 0.\n then\n Error.raise_s\n [%message \"Base_quickcheck.Generator.of_weighted_list: total weight is zero\"];\n sum, array\n in\n create (fun ~size:_ ~random ->\n let choice = Splittable_random.float random ~lo:0. ~hi:total_weight in\n match\n Array.binary_search\n cumulative_weight_array\n ~compare:Float.compare\n `First_greater_than_or_equal_to\n choice\n with\n | Some index -> value_array.(index)\n | None -> assert false)\n;;\n\nlet weighted_union alist = join (of_weighted_list alist)\nlet of_lazy lazy_t = create (fun ~size ~random -> generate (force lazy_t) ~size ~random)\n\nlet fixed_point of_generator =\n let rec lazy_t = lazy (of_generator (of_lazy lazy_t)) in\n force lazy_t\n;;\n\nlet weighted_recursive_union nonrec_list ~f =\n fixed_point (fun self ->\n let rec_list =\n List.map (f self) ~f:(fun (w, t) ->\n ( w\n , let%bind n = size in\n with_size ~size:(n - 1) t ))\n in\n if List.is_empty nonrec_list || List.is_empty rec_list\n then\n raise_s\n [%message\n \"Base_quickcheck.Generator.weighted_recursive_union: lists must be non-empty\"];\n let nonrec_gen = weighted_union nonrec_list in\n let rec_gen = weighted_union (nonrec_list @ rec_list) in\n match%bind size with\n | 0 -> nonrec_gen\n | _ -> rec_gen)\n;;\n\nlet recursive_union nonrec_list ~f =\n let weighted list = List.map list ~f:(fun t -> 1., t) in\n weighted_recursive_union (weighted nonrec_list) ~f:(fun self -> weighted (f self))\n;;\n\nlet sizes ?(min_length = 0) ?(max_length = Int.max_value) () =\n create (fun ~size ~random ->\n assert (min_length <= max_length);\n let upper_bound = min_length + size in\n let max_length =\n if upper_bound >= min_length (* guard against overflow *)\n then min max_length upper_bound\n else max_length\n in\n (* pick a length, weighted low so that most of the size is spent on elements *)\n let len = Splittable_random.Log_uniform.int random ~lo:min_length ~hi:max_length in\n (* if there are no elements return an empty array, otherwise return a non-empty array\n with the size distributed among the elements *)\n if len = 0\n then []\n else (\n let sizes = Array.init len ~f:(fun _ -> 0) in\n let remaining = size - (len - min_length) in\n let max_index = len - 1 in\n for _ = 1 to remaining do\n (* pick an index, weighted low so that we see unbalanced distributions often *)\n let index = Splittable_random.Log_uniform.int random ~lo:0 ~hi:max_index in\n sizes.(index) <- sizes.(index) + 1\n done;\n (* permute the array so that no index is favored over another *)\n for i = 0 to max_index - 1 do\n let j = Splittable_random.int random ~lo:i ~hi:max_index in\n Array.swap sizes i j\n done;\n assert (Array.sum (module Int) sizes ~f:Fn.id + (len - min_length) = size);\n Array.to_list sizes))\n;;\n\nlet unit = return ()\nlet bool = create (fun ~size:_ ~random -> Splittable_random.bool random)\nlet option value_t = union [ return None; map value_t ~f:Option.return ]\nlet either fst_t snd_t = union [ map fst_t ~f:Either.first; map snd_t ~f:Either.second ]\n\nlet result ok_t err_t =\n map (either ok_t err_t) ~f:(function\n | First ok -> Ok ok\n | Second err -> Error err)\n;;\n\nlet list_generic ?min_length ?max_length elt_gen =\n let%bind sizes = sizes ?min_length ?max_length () in\n List.map sizes ~f:(fun size -> with_size ~size elt_gen) |> all\n;;\n\nlet list elt_gen = list_generic elt_gen\nlet list_non_empty elt_gen = list_generic ~min_length:1 elt_gen\n\nlet list_with_length elt_gen ~length =\n list_generic ~min_length:length ~max_length:length elt_gen\n;;\n\nlet list_filtered elts =\n let elts = Array.of_list elts in\n let length_of_input = Array.length elts in\n create (fun ~size:_ ~random ->\n let length_of_output = Splittable_random.int random ~lo:0 ~hi:length_of_input in\n let indices = Array.init length_of_input ~f:Fn.id in\n (* Choose [length_of_output] random values in the prefix of [indices]. *)\n for i = 0 to length_of_output - 1 do\n let j = Splittable_random.int random ~lo:i ~hi:(length_of_input - 1) in\n Array.swap indices i j\n done;\n (* Sort the chosen indices because we don't want to reorder them. *)\n Array.sort indices ~pos:0 ~len:length_of_output ~compare:Int.compare;\n (* Return the chosen elements. *)\n List.init length_of_output ~f:(fun i -> elts.(indices.(i))))\n;;\n\nlet list_permutations list =\n create (fun ~size:_ ~random ->\n let array = Array.of_list list in\n for i = 1 to Array.length array - 1 do\n let j = Splittable_random.int random ~lo:0 ~hi:i in\n Array.swap array i j\n done;\n Array.to_list array)\n;;\n\nlet char_uniform_inclusive lo hi =\n create (fun ~size:_ ~random ->\n Splittable_random.int random ~lo:(Char.to_int lo) ~hi:(Char.to_int hi)\n |> Char.unsafe_of_int)\n;;\n\nlet char_uppercase = char_uniform_inclusive 'A' 'Z'\nlet char_lowercase = char_uniform_inclusive 'a' 'z'\nlet char_digit = char_uniform_inclusive '0' '9'\nlet char_print_uniform = char_uniform_inclusive ' ' '~'\nlet char_uniform = char_uniform_inclusive Char.min_value Char.max_value\nlet char_alpha = union [ char_lowercase; char_uppercase ]\n\nlet char_alphanum =\n weighted_union\n (* Most people probably expect this to be a uniform distribution, not weighted\n toward digits like we would get with [union] (since there are fewer digits than\n letters). *)\n [ 52., char_alpha; 10., char_digit ]\n;;\n\nlet char_whitespace = of_list (List.filter Char.all ~f:Char.is_whitespace)\nlet char_print = weighted_union [ 10., char_alphanum; 1., char_print_uniform ]\n\nlet char =\n weighted_union\n [ 100., char_print\n ; 10., char_uniform\n ; 1., return Char.min_value\n ; 1., return Char.max_value\n ]\n;;\n\n(* Produces a number from 0 or 1 to size + 1, weighted high. We have found this\n distribution empirically useful for string lengths. *)\nlet small_int ~allow_zero =\n create (fun ~size ~random ->\n let lower_bound = if allow_zero then 0 else 1 in\n let upper_bound = size + 1 in\n let weighted_low =\n Splittable_random.Log_uniform.int random ~lo:0 ~hi:(upper_bound - lower_bound)\n in\n let weighted_high = upper_bound - weighted_low in\n weighted_high)\n;;\n\nlet small_positive_or_zero_int = small_int ~allow_zero:true\nlet small_strictly_positive_int = small_int ~allow_zero:false\n\nmodule type Int_with_random = sig\n include Int.S\n\n val uniform : Splittable_random.State.t -> lo:t -> hi:t -> t\n val log_uniform : Splittable_random.State.t -> lo:t -> hi:t -> t\nend\n\nmodule For_integer (Integer : Int_with_random) = struct\n let uniform_inclusive lo hi =\n create (fun ~size:_ ~random -> Integer.uniform random ~lo ~hi)\n ;;\n\n let log_uniform_inclusive lo hi =\n create (fun ~size:_ ~random -> Integer.log_uniform random ~lo ~hi)\n ;;\n\n let non_uniform f lo hi =\n weighted_union [ 0.05, return lo; 0.05, return hi; 0.9, f lo hi ]\n ;;\n\n let inclusive = non_uniform uniform_inclusive\n let log_inclusive = non_uniform log_uniform_inclusive\n let uniform_all = uniform_inclusive Integer.min_value Integer.max_value\n\n let all =\n [%map\n let negative = bool\n and magnitude = log_inclusive Integer.zero Integer.max_value in\n if negative then Integer.bit_not magnitude else magnitude]\n ;;\nend\n\nmodule For_int = For_integer (struct\n include Int\n\n let uniform = Splittable_random.int\n let log_uniform = Splittable_random.Log_uniform.int\n end)\n\nlet int = For_int.all\nlet int_uniform = For_int.uniform_all\nlet int_inclusive = For_int.inclusive\nlet int_uniform_inclusive = For_int.uniform_inclusive\nlet int_log_inclusive = For_int.log_inclusive\nlet int_log_uniform_inclusive = For_int.log_uniform_inclusive\n\nmodule For_int32 = For_integer (struct\n include Int32\n\n let uniform = Splittable_random.int32\n let log_uniform = Splittable_random.Log_uniform.int32\n end)\n\nlet int32 = For_int32.all\nlet int32_uniform = For_int32.uniform_all\nlet int32_inclusive = For_int32.inclusive\nlet int32_uniform_inclusive = For_int32.uniform_inclusive\nlet int32_log_inclusive = For_int32.log_inclusive\nlet int32_log_uniform_inclusive = For_int32.log_uniform_inclusive\n\nmodule For_int63 = For_integer (struct\n include Int63\n\n let uniform = Splittable_random.int63\n let log_uniform = Splittable_random.Log_uniform.int63\n end)\n\nlet int63 = For_int63.all\nlet int63_uniform = For_int63.uniform_all\nlet int63_inclusive = For_int63.inclusive\nlet int63_uniform_inclusive = For_int63.uniform_inclusive\nlet int63_log_inclusive = For_int63.log_inclusive\nlet int63_log_uniform_inclusive = For_int63.log_uniform_inclusive\n\nmodule For_int64 = For_integer (struct\n include Int64\n\n let uniform = Splittable_random.int64\n let log_uniform = Splittable_random.Log_uniform.int64\n end)\n\nlet int64 = For_int64.all\nlet int64_uniform = For_int64.uniform_all\nlet int64_inclusive = For_int64.inclusive\nlet int64_uniform_inclusive = For_int64.uniform_inclusive\nlet int64_log_inclusive = For_int64.log_inclusive\nlet int64_log_uniform_inclusive = For_int64.log_uniform_inclusive\n\nmodule For_nativeint = For_integer (struct\n include Nativeint\n\n let uniform = Splittable_random.nativeint\n let log_uniform = Splittable_random.Log_uniform.nativeint\n end)\n\nlet nativeint = For_nativeint.all\nlet nativeint_uniform = For_nativeint.uniform_all\nlet nativeint_inclusive = For_nativeint.inclusive\nlet nativeint_uniform_inclusive = For_nativeint.uniform_inclusive\nlet nativeint_log_inclusive = For_nativeint.log_inclusive\nlet nativeint_log_uniform_inclusive = For_nativeint.log_uniform_inclusive\nlet float_zero_exponent = Float.ieee_exponent 0.\nlet float_zero_mantissa = Float.ieee_mantissa 0.\n\nlet float_max_positive_subnormal_value =\n Float.one_ulp `Down Float.min_positive_normal_value\n;;\n\nlet float_subnormal_exponent = Float.ieee_exponent Float.min_positive_subnormal_value\nlet float_min_subnormal_mantissa = Float.ieee_mantissa Float.min_positive_subnormal_value\nlet float_max_subnormal_mantissa = Float.ieee_mantissa float_max_positive_subnormal_value\nlet float_max_positive_normal_value = Float.max_finite_value\nlet float_min_normal_exponent = Float.ieee_exponent Float.min_positive_normal_value\nlet float_max_normal_exponent = Float.ieee_exponent float_max_positive_normal_value\nlet float_max_normal_mantissa = Float.ieee_mantissa float_max_positive_normal_value\nlet float_inf_exponent = Float.ieee_exponent Float.infinity\nlet float_inf_mantissa = Float.ieee_mantissa Float.infinity\nlet float_nan_exponent = Float.ieee_exponent Float.nan\nlet float_min_nan_mantissa = Int63.succ float_inf_mantissa\nlet float_max_nan_mantissa = float_max_normal_mantissa\nlet float_num_mantissa_bits = 52\n\n(* We weight mantissas so that \"integer-like\" values, and values with only a few digits\n past the decimal, are reasonably common. *)\nlet float_normal_mantissa =\n let%bind num_bits = For_int.uniform_inclusive 0 float_num_mantissa_bits in\n let%map bits =\n For_int63.inclusive Int63.zero (Int63.pred (Int63.shift_left Int63.one num_bits))\n in\n Int63.shift_left bits (Int.( - ) float_num_mantissa_bits num_bits)\n;;\n\nlet float_exponent_weighted_low lower_bound upper_bound =\n let%map offset = For_int.log_inclusive 0 (Int.( - ) upper_bound lower_bound) in\n Int.( + ) lower_bound offset\n;;\n\nlet float_exponent_weighted_high lower_bound upper_bound =\n let%map offset = For_int.log_inclusive 0 (Int.( - ) upper_bound lower_bound) in\n Int.( - ) upper_bound offset\n;;\n\n(* We weight exponents such that values near 1 are more likely. *)\nlet float_exponent =\n let midpoint = Float.ieee_exponent 1. in\n union\n [ float_exponent_weighted_high float_min_normal_exponent midpoint\n ; float_exponent_weighted_low midpoint float_max_normal_exponent\n ]\n;;\n\nlet float_zero =\n let%map negative = bool in\n Float.create_ieee_exn\n ~negative\n ~exponent:float_zero_exponent\n ~mantissa:float_zero_mantissa\n;;\n\nlet float_subnormal =\n let%map negative = bool\n and exponent = return float_subnormal_exponent\n and mantissa =\n For_int63.log_inclusive float_min_subnormal_mantissa float_max_subnormal_mantissa\n in\n Float.create_ieee_exn ~negative ~exponent ~mantissa\n;;\n\nlet float_normal =\n let%map negative = bool\n and exponent = float_exponent\n and mantissa = float_normal_mantissa in\n Float.create_ieee_exn ~negative ~exponent ~mantissa\n;;\n\nlet float_infinite =\n let%map negative = bool in\n Float.create_ieee_exn\n ~negative\n ~exponent:float_inf_exponent\n ~mantissa:float_inf_mantissa\n;;\n\nlet float_nan =\n let%map negative = bool\n and exponent = return float_nan_exponent\n and mantissa = For_int63.inclusive float_min_nan_mantissa float_max_nan_mantissa in\n Float.create_ieee_exn ~negative ~exponent ~mantissa\n;;\n\nlet float_of_class c =\n match (c : Float.Class.t) with\n | Zero -> float_zero\n | Subnormal -> float_subnormal\n | Normal -> float_normal\n | Infinite -> float_infinite\n | Nan -> float_nan\n;;\n\nlet float_weight_of_class c =\n match (c : Float.Class.t) with\n | Zero -> 1.\n | Subnormal -> 10.\n | Normal -> 100.\n | Infinite -> 1.\n | Nan -> 1.\n;;\n\nlet float_matching_classes filter =\n List.filter_map Float.Class.all ~f:(fun c ->\n if filter c then Some (float_weight_of_class c, float_of_class c) else None)\n |> weighted_union\n;;\n\nlet float_finite =\n float_matching_classes (function\n | Zero | Subnormal | Normal -> true\n | Infinite | Nan -> false)\n;;\n\nlet float_without_nan =\n float_matching_classes (function\n | Zero | Subnormal | Normal | Infinite -> true\n | Nan -> false)\n;;\n\nlet float = float_matching_classes (fun _ -> true)\n\nlet float_finite_non_zero =\n float_matching_classes (function\n | Subnormal | Normal -> true\n | Zero | Infinite | Nan -> false)\n;;\n\nlet float_strictly_positive =\n let%map t = float_finite_non_zero in\n Float.abs t\n;;\n\nlet float_strictly_negative =\n let%map t = float_finite_non_zero in\n ~-.(Float.abs t)\n;;\n\nlet float_positive_or_zero =\n let%map t = float_finite in\n Float.abs t\n;;\n\nlet float_negative_or_zero =\n let%map t = float_finite in\n ~-.(Float.abs t)\n;;\n\nlet float_uniform_exclusive lower_bound upper_bound =\n let open Float.O in\n if (not (Float.is_finite lower_bound)) || not (Float.is_finite upper_bound)\n then\n raise_s\n [%message\n \"Float.uniform_exclusive: bounds are not finite\"\n (lower_bound : float)\n (upper_bound : float)];\n let lower_inclusive = Float.one_ulp `Up lower_bound in\n let upper_inclusive = Float.one_ulp `Down upper_bound in\n if lower_inclusive > upper_inclusive\n then\n raise_s\n [%message\n \"Float.uniform_exclusive: requested range is empty\"\n (lower_bound : float)\n (upper_bound : float)];\n create (fun ~size:_ ~random ->\n Splittable_random.float random ~lo:lower_inclusive ~hi:upper_inclusive)\n;;\n\nlet float_inclusive lower_bound upper_bound =\n weighted_union\n [ 0.05, return lower_bound\n ; 0.05, return upper_bound\n ; 0.9, float_uniform_exclusive lower_bound upper_bound\n ]\n;;\n\nlet string_with_length_of char_gen ~length =\n list_with_length char_gen ~length |> map ~f:String.of_char_list\n;;\n\nlet string_of char_gen =\n bind small_positive_or_zero_int ~f:(fun length ->\n string_with_length_of char_gen ~length)\n;;\n\nlet string_non_empty_of char_gen =\n bind small_strictly_positive_int ~f:(fun length ->\n string_with_length_of char_gen ~length)\n;;\n\nlet string = string_of char\nlet string_non_empty = string_non_empty_of char\nlet string_with_length ~length = string_with_length_of char ~length\n\nlet sexp_of atom =\n fixed_point (fun self ->\n let%bind size = size in\n (* choose a number weighted low so we have a decreasing, but not vanishing, chance\n to generate atoms as size grows *)\n match%bind For_int.log_uniform_inclusive 0 (size + 1) with\n (* generate an atom using the given size *)\n | 0 ->\n let%map atom = atom in\n Sexp.Atom atom\n (* relying on [List.gen] to distribute [size] over sub-sexps *)\n | _ ->\n let%map list = list self in\n Sexp.List list)\n;;\n\nlet sexp = sexp_of string\n\nlet map_tree_using_comparator ~comparator key_gen data_gen =\n let%bind keys = list key_gen in\n let keys = List.dedup_and_sort keys ~compare:comparator.Comparator.compare in\n let%bind data = list_with_length data_gen ~length:(List.length keys) in\n return (Map.Using_comparator.Tree.of_alist_exn ~comparator (List.zip_exn keys data))\n;;\n\nlet set_tree_using_comparator ~comparator elt_gen =\n map (list elt_gen) ~f:(Set.Using_comparator.Tree.of_list ~comparator)\n;;\n\nlet comparator_of_m\n (type a c)\n (module M : Comparator.S with type t = a and type comparator_witness = c)\n =\n M.comparator\n;;\n\nlet map_t_m m key_gen data_gen =\n let comparator = comparator_of_m m in\n map_tree_using_comparator ~comparator key_gen data_gen\n |> map ~f:(Map.Using_comparator.of_tree ~comparator)\n;;\n\nlet set_t_m m elt_gen =\n let comparator = comparator_of_m m in\n set_tree_using_comparator ~comparator elt_gen\n |> map ~f:(Set.Using_comparator.of_tree ~comparator)\n;;\n\nlet bigarray1 t kind layout =\n let%map elts = list t in\n let elts = Array.of_list elts in\n let dim = Array.length elts in\n let offset = Bigarray_helpers.Layout.offset layout in\n Bigarray_helpers.Array1.init kind layout dim ~f:(fun i -> elts.(i - offset))\n;;\n\nlet bigstring = bigarray1 char Char C_layout\nlet float32_vec = bigarray1 float Float32 Fortran_layout\nlet float64_vec = bigarray1 float Float64 Fortran_layout\n\nlet bigarray2_dim =\n match%bind size with\n | 0 -> return (0, 0)\n | max_total_size ->\n let%bind a =\n (* choose a dimension up to [max_total_size], weighted low to give the other\n dimension a good chance of being comparatively high *)\n int_log_uniform_inclusive 1 max_total_size\n in\n let%bind b =\n (* choose a dimension up to [max_total_size / a], weighted high to reach close to\n [max_total_size] most of the time *)\n let max_b = max_total_size / a in\n let%map b_weighted_low = int_log_uniform_inclusive 0 max_b in\n max_b - b_weighted_low\n in\n (* avoid any skew of a vs b by randomly swapping *)\n if%map bool then a, b else b, a\n;;\n\nlet bigarray2 t kind layout =\n let%bind dim1, dim2 = bigarray2_dim in\n let%map elts = list_with_length ~length:dim1 (list_with_length ~length:dim2 t) in\n let elts = Array.of_list_map ~f:Array.of_list elts in\n let offset = Bigarray_helpers.Layout.offset layout in\n Bigarray_helpers.Array2.init kind layout dim1 dim2 ~f:(fun i j ->\n elts.(i - offset).(j - offset))\n;;\n\nlet float32_mat = bigarray2 float Float32 Fortran_layout\nlet float64_mat = bigarray2 float Float64 Fortran_layout\n","open! Base\n\nmodule Layout = struct\n type 'a t = 'a Bigarray.layout\n\n let offset : type a. a t -> int = function\n | Bigarray.Fortran_layout -> 1\n | Bigarray.C_layout -> 0\n ;;\nend\n\nmodule Array1 = struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) Bigarray.Array1.t\n\n let iteri t ~f =\n let offset = Layout.offset (Bigarray.Array1.layout t) in\n for i = 0 to Bigarray.Array1.dim t - 1 do\n f (i + offset) t.{i + offset}\n done\n ;;\n\n let init (type elt) (kind : (elt, _) Bigarray.kind) layout dim ~f =\n let t = Bigarray.Array1.create kind layout dim in\n iteri t ~f:(fun i (_ : elt) -> t.{i} <- f i);\n t\n ;;\n\n let fold (type elt) (t : (elt, _, _) t) ~init ~f =\n let init = ref init in\n iteri t ~f:(fun i (_ : elt) -> init := f !init t.{i});\n !init\n ;;\n\n let to_array t =\n let offset = Layout.offset (Bigarray.Array1.layout t) in\n Array.init (Bigarray.Array1.dim t) ~f:(fun i -> t.{i + offset})\n ;;\n\n let sexp_of_t sexp_of_elt _sexp_of_pack _sexp_of_layout t =\n [%sexp (to_array t : elt array)]\n ;;\n\n let hash_fold hash_fold_elt state t =\n let state = hash_fold_int state (Bigarray.Array1.dim t) in\n fold t ~init:state ~f:hash_fold_elt\n ;;\nend\n\nmodule Array2 = struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) Bigarray.Array2.t\n\n let iteri t ~f =\n let offset = Layout.offset (Bigarray.Array2.layout t) in\n for i = 0 to Bigarray.Array2.dim1 t - 1 do\n for j = 0 to Bigarray.Array2.dim2 t - 1 do\n f (i + offset) (j + offset) t.{i + offset, j + offset}\n done\n done\n ;;\n\n let init (type elt) (kind : (elt, _) Bigarray.kind) layout dim1 dim2 ~f =\n let t = Bigarray.Array2.create kind layout dim1 dim2 in\n iteri t ~f:(fun i j (_ : elt) -> t.{i, j} <- f i j);\n t\n ;;\n\n let fold (type elt) (t : (elt, _, _) t) ~init ~f =\n let init = ref init in\n iteri t ~f:(fun (_ : int) (_ : int) elt -> init := f !init elt);\n !init\n ;;\n\n let to_array t =\n let offset = Layout.offset (Bigarray.Array2.layout t) in\n Array.init (Bigarray.Array2.dim1 t) ~f:(fun i ->\n Array.init (Bigarray.Array2.dim2 t) ~f:(fun j -> t.{i + offset, j + offset}))\n ;;\n\n let sexp_of_t sexp_of_elt _sexp_of_pack _sexp_of_layout t =\n [%sexp (to_array t : elt array array)]\n ;;\n\n let hash_fold hash_fold_elt state t =\n let state = hash_fold_int state (Bigarray.Array2.dim1 t) in\n let state = hash_fold_int state (Bigarray.Array2.dim2 t) in\n fold t ~init:state ~f:hash_fold_elt\n ;;\nend\n","open! Base\n\ntype 'a t = 'a -> size:int -> hash:Hash.state -> Hash.state\n\nlet create f : _ t = f\n\nlet observe (t : _ t) x ~size ~hash =\n if size < 0\n then raise_s [%message \"Base_quickcheck.Observer.observe: size < 0\" (size : int)]\n else t x ~size ~hash\n;;\n\nlet opaque _ ~size:_ ~hash = hash\n","open Core_kernel\n\n(* This module implements snarky functions for a sponge that can *conditionally* absorb input,\n while branching minimally. Specifically, if absorbing N field elements, this sponge can absorb\n a variable subset of N field elements, while performing N + 1 invocations of the sponge's\n underlying permutation. *)\n\nlet m = 3\n\nlet capacity = 1\n\nlet rate = m - capacity\n\ntype 'f sponge_state =\n | Absorbing of\n { next_index : 'f Snarky_backendless.Boolean.t\n ; xs : ('f Snarky_backendless.Boolean.t * 'f) list\n }\n | Squeezed of int\n\ntype 'f t =\n { mutable state : 'f array\n ; params : 'f Sponge.Params.t\n ; mutable needs_final_permute_if_empty : bool\n ; mutable sponge_state : 'f sponge_state\n }\n\nmodule Make\n (Impl : Snarky_backendless.Snark_intf.Run)\n (P : Sponge.Intf.Permutation with type Field.t = Impl.Field.t) =\nstruct\n open P\n open Impl\n\n type nonrec t = Field.t t\n\n let _state { state; _ } = Array.copy state\n\n let copy { state; params; sponge_state; needs_final_permute_if_empty } =\n { state = Array.copy state\n ; params\n ; sponge_state\n ; needs_final_permute_if_empty\n }\n\n let initial_state = Array.init m ~f:(fun _ -> Field.zero)\n\n let of_sponge { Sponge.state; params; sponge_state; id = _ } =\n match sponge_state with\n | Sponge.Squeezed n ->\n { sponge_state = Squeezed n\n ; state = Array.copy state\n ; needs_final_permute_if_empty = true\n ; params\n }\n | Sponge.Absorbed n -> (\n let abs i =\n { sponge_state = Absorbing { next_index = i; xs = [] }\n ; state = Array.copy state\n ; params\n ; needs_final_permute_if_empty = true\n }\n in\n match n with\n | 0 ->\n abs Boolean.false_\n | 1 ->\n abs Boolean.true_\n | 2 ->\n { sponge_state = Absorbing { next_index = Boolean.false_; xs = [] }\n ; state = P.block_cipher params state\n ; needs_final_permute_if_empty = false\n ; params\n }\n | _ ->\n assert false )\n\n let create ?(init = initial_state) params =\n { params\n ; state = Array.copy init\n ; needs_final_permute_if_empty = true\n ; sponge_state = Absorbing { next_index = Boolean.false_; xs = [] }\n }\n\n let () = assert (rate = 2)\n\n let add_in a i x =\n let i_equals_0 = Boolean.not i in\n let i_equals_1 = i in\n (*\n a.(0) <- a.(0) + i_equals_0 * x\n a.(1) <- a.(1) + i_equals_1 * x *)\n List.iteri [ i_equals_0; i_equals_1 ] ~f:(fun j i_equals_j ->\n let a_j' =\n exists Field.typ\n ~compute:\n As_prover.(\n fun () ->\n let a_j = read Field.typ a.(j) in\n if read Boolean.typ i_equals_j then\n Field.Constant.(a_j + read Field.typ x)\n else a_j)\n in\n assert_r1cs x (i_equals_j :> Field.t) Field.(a_j' - a.(j)) ;\n a.(j) <- a_j' )\n\n let cond_permute ~params ~permute state =\n let permuted = P.block_cipher params (Array.copy state) in\n for i = 0 to m - 1 do\n state.(i) <- Field.if_ permute ~then_:permuted.(i) ~else_:state.(i)\n done\n\n let consume_pairs ~params ~state ~pos:start_pos pairs =\n Array.fold ~init:start_pos pairs ~f:(fun p ((b, x), (b', y)) ->\n (* Semantically, we want to do this.\n match b, b' with\n | 1, 1 ->\n if p = 0\n then state := perm {state with .0 += x, .1 += y }\n else state := {perm {state with .1 += x} with .0 += y}\n | 1, 0 ->\n if p = 0\n then state := {state with .0 += x}\n else state := perm {state with .1 += x}\n | 0, 1 ->\n if p = 0\n then state := {state with .0 += y }\n else state := perm {state with .1 += y}\n | 0, 0 ->\n state\n *)\n let p' = Boolean.( lxor ) p b in\n let pos_after = Boolean.( lxor ) p' b' in\n let y = Field.(y * (b' :> t)) in\n let add_in_y_after_perm =\n (* post\n add in\n (1, 1, 1)\n\n do not add in\n (1, 1, 0)\n (0, 1, 0)\n (0, 1, 1)\n\n (1, 0, 0)\n (1, 0, 1)\n (0, 0, 0)\n (0, 0, 1)\n *)\n (* Only one case where we add in y after the permutation is applied *)\n Boolean.all [ b; b'; p ]\n in\n let add_in_y_before_perm = Boolean.not add_in_y_after_perm in\n add_in state p Field.(x * (b :> t)) ;\n add_in state p' Field.(y * (add_in_y_before_perm :> t)) ;\n let permute =\n (* (b, b', p)\n true:\n (0, 1, 1)\n (1, 0, 1)\n (1, 1, 0)\n (1, 1, 1)\n\n false:\n (0, 0, 0)\n (0, 0, 1)\n (0, 1, 0)\n (1, 0, 0)\n *)\n (* (b && b') || (p && (b || b')) *)\n Boolean.(any [ all [ b; b' ]; all [ p; b ||| b' ] ])\n in\n cond_permute ~params ~permute state ;\n add_in state p' Field.(y * (add_in_y_after_perm :> t)) ;\n pos_after )\n\n let consume ~needs_final_permute_if_empty ~params ~start_pos input state =\n assert (Array.length state = m) ;\n let n = Array.length input in\n let num_pairs = n / 2 in\n let remaining = n - (2 * num_pairs) in\n let pairs =\n Array.init num_pairs ~f:(fun i -> (input.(2 * i), input.((2 * i) + 1)))\n in\n let pos = consume_pairs ~params ~state ~pos:start_pos pairs in\n let empty_imput =\n Boolean.not (Boolean.Array.any (Array.map input ~f:fst))\n in\n let should_permute =\n match remaining with\n | 0 ->\n if needs_final_permute_if_empty then Boolean.(empty_imput ||| pos)\n else pos\n | 1 ->\n let b, x = input.(n - 1) in\n let p = pos in\n let pos_after = Boolean.( lxor ) p b in\n ignore (pos_after : Boolean.var) ;\n add_in state p Field.(x * (b :> t)) ;\n if needs_final_permute_if_empty then Boolean.any [ p; b; empty_imput ]\n else Boolean.any [ p; b ]\n | _ ->\n assert false\n in\n cond_permute ~params ~permute:should_permute state\n\n let absorb (t : t) x =\n match t.sponge_state with\n | Absorbing { next_index; xs } ->\n t.sponge_state <- Absorbing { next_index; xs = x :: xs }\n | Squeezed _ ->\n t.sponge_state <- Absorbing { next_index = Boolean.false_; xs = [ x ] }\n\n let squeeze (t : t) =\n match t.sponge_state with\n | Squeezed n ->\n if n = rate then (\n t.state <- block_cipher t.params t.state ;\n t.sponge_state <- Squeezed 1 ;\n t.state.(0) )\n else (\n t.sponge_state <- Squeezed (n + 1) ;\n t.state.(n) )\n | Absorbing { next_index; xs } ->\n consume ~needs_final_permute_if_empty:t.needs_final_permute_if_empty\n ~start_pos:next_index ~params:t.params (Array.of_list_rev xs) t.state ;\n t.needs_final_permute_if_empty <- true ;\n t.sponge_state <- Squeezed 1 ;\n t.state.(0)\n\n let consume_all_pending (t : t) =\n match t.sponge_state with\n | Squeezed _ ->\n failwith \"Nothing pending\"\n | Absorbing { next_index; xs } ->\n let input = Array.of_list_rev xs in\n assert (Array.length t.state = m) ;\n let n = Array.length input in\n let num_pairs = n / 2 in\n let remaining = n - (2 * num_pairs) in\n let pairs =\n Array.init num_pairs ~f:(fun i ->\n (input.(2 * i), input.((2 * i) + 1)) )\n in\n let pos =\n consume_pairs ~params:t.params ~state:t.state ~pos:next_index pairs\n in\n let pos_after =\n if remaining = 1 then (\n let b, x = input.(n - 1) in\n let p = pos in\n let pos_after = Boolean.( lxor ) p b in\n add_in t.state p Field.(x * (b :> t)) ;\n pos_after )\n else pos\n in\n (* TODO: We should propagate the emptiness state of the pairs,\n otherwise this will break in some edge cases.\n *)\n t.sponge_state <- Absorbing { next_index = pos_after; xs = [] }\n\n let recombine ~original_sponge b (t : t) =\n match[@warning \"-4\"] (original_sponge.sponge_state, t.sponge_state) with\n | Squeezed orig_i, Squeezed curr_i ->\n if orig_i <> curr_i then failwithf \"Squeezed %i vs %i\" orig_i curr_i () ;\n Array.iteri original_sponge.state ~f:(fun i x ->\n t.state.(i) <- Field.if_ b ~then_:t.state.(i) ~else_:x )\n | ( Absorbing { next_index = next_index_orig; xs = xs_orig }\n , Absorbing { next_index = next_index_curr; xs = xs_curr } ) ->\n (* TODO: Should test for full equality here, if we want to catch all\n sponge misuses.\n OTOH, if you're using this sponge then you'd better know what it's\n doing..\n *)\n if List.length xs_orig <> List.length xs_curr then\n failwithf \"Pending absorptions %i vs %i\" (List.length xs_orig)\n (List.length xs_curr) () ;\n Array.iteri original_sponge.state ~f:(fun i x ->\n t.state.(i) <- Field.if_ b ~then_:t.state.(i) ~else_:x ) ;\n t.sponge_state <-\n Absorbing\n { next_index =\n Boolean.if_ b ~then_:next_index_curr ~else_:next_index_orig\n ; xs = xs_curr\n }\n | _, _ ->\n failwith \"Incompatible states\"\n\n let%test_module \"opt_sponge\" =\n ( module struct\n module S = Sponge.Make_sponge (P)\n\n let%test_unit \"correctness\" =\n let params : _ Sponge.Params.t =\n let a () =\n Array.init 3 ~f:(fun _ -> Field.(constant (Constant.random ())))\n in\n { mds = Array.init 3 ~f:(fun _ -> a ())\n ; round_constants = Array.init 40 ~f:(fun _ -> a ())\n }\n in\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%bind n = Quickcheck.Generator.small_positive_int\n and n_pre = Quickcheck.Generator.small_positive_int in\n let%map xs = List.gen_with_length n Field.Constant.gen\n and bs = List.gen_with_length n Bool.quickcheck_generator\n and pre = List.gen_with_length n_pre Field.Constant.gen in\n (pre, List.zip_exn bs xs)\n in\n Quickcheck.test gen ~trials:10 ~f:(fun (pre, ps) ->\n let filtered =\n List.filter_map ps ~f:(fun (b, x) -> if b then Some x else None)\n in\n let init () =\n let pre =\n exists\n (Typ.list ~length:(List.length pre) Field.typ)\n ~compute:(fun () -> pre)\n in\n let s = S.create params in\n List.iter pre ~f:(S.absorb s) ;\n s\n in\n let filtered_res =\n let n = List.length filtered in\n Impl.Internal_Basic.Test.checked_to_unchecked\n (Typ.list ~length:n Field.typ)\n Field.typ\n (fun xs ->\n make_checked (fun () ->\n let s = init () in\n List.iter xs ~f:(S.absorb s) ;\n S.squeeze s ) )\n filtered\n in\n let opt_res =\n let n = List.length ps in\n Impl.Internal_Basic.Test.checked_to_unchecked\n (Typ.list ~length:n (Typ.tuple2 Boolean.typ Field.typ))\n Field.typ\n (fun xs ->\n make_checked (fun () ->\n let s =\n if List.length pre = 0 then create params\n else of_sponge (init ())\n in\n List.iter xs ~f:(absorb s) ;\n squeeze s ) )\n ps\n in\n if not (Field.Constant.equal filtered_res opt_res) then\n failwithf\n !\"hash(%{sexp:Field.Constant.t list}) = %{sexp:Field.Constant.t}\\n\\\n hash(%{sexp:(bool * Field.Constant.t) list}) = \\\n %{sexp:Field.Constant.t}\"\n filtered filtered_res ps opt_res () )\n end )\nend\n","open! Base\n\nmodule T : sig\n type 'a t\n\n val atomic : _ t\n val create : ('a -> 'a Sequence.t) -> 'a t\n val shrink : 'a t -> 'a -> 'a Sequence.t\nend = struct\n type 'a t = 'a -> 'a Sequence.t\n\n let atomic _ = Sequence.empty\n let create = Fn.id\n let shrink = Fn.id\nend\n\ninclude T\n\nlet map t ~f ~f_inverse = create (fun x -> Sequence.map ~f (shrink t (f_inverse x)))\nlet filter t ~f = create (fun x -> Sequence.filter ~f (shrink t x))\n\nlet filter_map t ~f ~f_inverse =\n create (fun x -> Sequence.filter_map ~f (shrink t (f_inverse x)))\n;;\n\nlet of_lazy lazy_t = create (fun x -> Sequence.of_lazy (lazy (shrink (force lazy_t) x)))\n\nlet fixed_point of_shrinker =\n let rec lazy_t = lazy (of_shrinker (of_lazy lazy_t)) in\n of_lazy lazy_t\n;;\n\nlet both fst_t snd_t =\n create (fun (fst, snd) ->\n Sequence.round_robin\n [ Sequence.map (shrink fst_t fst) ~f:(fun fst -> fst, snd)\n ; Sequence.map (shrink snd_t snd) ~f:(fun snd -> fst, snd)\n ])\n;;\n\nlet unit = atomic\nlet bool = atomic\nlet char = atomic\nlet int = atomic\nlet int32 = atomic\nlet int63 = atomic\nlet int64 = atomic\nlet nativeint = atomic\nlet float = atomic\n\nlet bigarray1 src =\n let dim = Bigarray.Array1.dim src in\n match dim with\n | 0 -> Sequence.empty\n | _ ->\n let kind = Bigarray.Array1.kind src in\n let layout = Bigarray.Array1.layout src in\n let offset = Bigarray_helpers.Layout.offset layout in\n Sequence.init dim ~f:(fun to_skip ->\n let to_skip = to_skip + offset in\n Bigarray_helpers.Array1.init kind layout (dim - 1) ~f:(fun i ->\n src.{(if i < to_skip then i else i + 1)}))\n;;\n\nlet bigstring = create bigarray1\nlet float32_vec = create bigarray1\nlet float64_vec = create bigarray1\n\nlet bigarray2 =\n let module Dims = struct\n type t =\n { dim1 : int\n ; dim2 : int\n }\n [@@deriving fields]\n\n let create a = Bigarray.Array2.{ dim1 = dim1 a; dim2 = dim2 a }\n end\n in\n let shrink field src =\n let dims = Dims.create src in\n match Field.get field dims with\n | 0 -> Sequence.empty\n | _ ->\n let kind = Bigarray.Array2.kind src in\n let layout = Bigarray.Array2.layout src in\n let offset = Bigarray_helpers.Layout.offset layout in\n let ({ dim1; dim2 } : Dims.t) = Field.map field dims ~f:Int.pred in\n Sequence.init (Field.get field dims) ~f:(fun to_skip ->\n let to_skip = to_skip + offset in\n let skip i = if i < to_skip then i else i + 1 in\n Bigarray_helpers.Array2.init kind layout dim1 dim2 ~f:(fun dim1 dim2 ->\n let ({ dim1; dim2 } : Dims.t) = Field.map field { dim1; dim2 } ~f:skip in\n src.{dim1, dim2}))\n in\n fun src ->\n Sequence.round_robin [ shrink Dims.Fields.dim1 src; shrink Dims.Fields.dim2 src ]\n;;\n\nlet float32_mat = create bigarray2\nlet float64_mat = create bigarray2\n\nlet option value_t =\n create (function\n | None -> Sequence.empty\n | Some value ->\n Sequence.append\n (Sequence.singleton None)\n (Sequence.map ~f:Option.return (shrink value_t value)))\n;;\n\nlet list elt_t =\n fixed_point (fun list_t ->\n create (function\n | [] -> Sequence.empty\n | head :: tail ->\n Sequence.round_robin\n [ Sequence.singleton tail\n ; Sequence.map (shrink elt_t head) ~f:(fun head -> head :: tail)\n ; Sequence.map (shrink list_t tail) ~f:(fun tail -> head :: tail)\n ]))\n;;\n\nlet string = map (list char) ~f:String.of_char_list ~f_inverse:String.to_list\n\nlet sexp =\n fixed_point (fun shrinker ->\n create (function\n | Sexp.Atom _ -> Sequence.empty\n | Sexp.List l ->\n let shrink_list =\n shrink (list shrinker) l |> Sequence.map ~f:(fun l -> Sexp.List l)\n in\n let shrink_tree = Sequence.of_list l in\n Sequence.round_robin [ shrink_list; shrink_tree ]))\n;;\n\nlet either fst_t snd_t =\n create (fun either ->\n match (either : _ Either.t) with\n | First fst -> Sequence.map (shrink fst_t fst) ~f:Either.first\n | Second snd -> Sequence.map (shrink snd_t snd) ~f:Either.second)\n;;\n\nlet result ok_t err_t =\n map\n (either ok_t err_t)\n ~f:(function\n | First ok -> Ok ok\n | Second err -> Error err)\n ~f_inverse:(function\n | Ok ok -> First ok\n | Error err -> Second err)\n;;\n\nlet map_tree_using_comparator ~comparator key_t data_t =\n create (fun tree ->\n let alist = Map.Using_comparator.Tree.to_alist tree in\n let drop_keys =\n Sequence.map (Sequence.of_list alist) ~f:(fun (k, _) ->\n Map.Using_comparator.Tree.remove ~comparator tree k)\n in\n let shrink_keys =\n Sequence.round_robin\n (List.map alist ~f:(fun (key, data) ->\n let tree = Map.Using_comparator.Tree.remove ~comparator tree key in\n Sequence.filter_map (shrink key_t key) ~f:(fun smaller_key ->\n match\n Map.Using_comparator.Tree.add\n ~comparator\n tree\n ~key:smaller_key\n ~data\n with\n | `Ok tree -> Some tree\n | `Duplicate -> None)))\n in\n let shrink_data =\n Sequence.round_robin\n (List.map alist ~f:(fun (key, data) ->\n Sequence.map (shrink data_t data) ~f:(fun smaller_data ->\n Map.Using_comparator.Tree.set ~comparator tree ~key ~data:smaller_data)))\n in\n Sequence.round_robin [ drop_keys; shrink_keys; shrink_data ])\n;;\n\nlet set_tree_using_comparator ~comparator elt_t =\n create (fun tree ->\n let list = Set.Using_comparator.Tree.to_list tree in\n let drop_elts =\n Sequence.map (Sequence.of_list list) ~f:(fun elt ->\n Set.Using_comparator.Tree.remove ~comparator tree elt)\n in\n let shrink_elts =\n Sequence.round_robin\n (List.map list ~f:(fun elt ->\n let tree = Set.Using_comparator.Tree.remove ~comparator tree elt in\n Sequence.filter_map (shrink elt_t elt) ~f:(fun smaller_elt ->\n match Set.Using_comparator.Tree.mem ~comparator tree smaller_elt with\n | true -> None\n | false ->\n Some (Set.Using_comparator.Tree.add tree ~comparator smaller_elt))))\n in\n Sequence.round_robin [ drop_elts; shrink_elts ])\n;;\n\nlet map_t key_t data_t =\n create (fun map_t ->\n let comparator = Map.comparator map_t in\n let t =\n map\n (map_tree_using_comparator ~comparator key_t data_t)\n ~f:(Map.Using_comparator.of_tree ~comparator)\n ~f_inverse:Map.Using_comparator.to_tree\n in\n shrink t map_t)\n;;\n\nlet set_t elt_t =\n create (fun set_t ->\n let comparator = Set.comparator set_t in\n let t =\n map\n (set_tree_using_comparator ~comparator elt_t)\n ~f:(Set.Using_comparator.of_tree ~comparator)\n ~f_inverse:Set.Using_comparator.to_tree\n in\n shrink t set_t)\n;;\n","open! Base\ninclude Test_intf\n\nmodule Config = struct\n module Seed = struct\n type t =\n | Nondeterministic\n | Deterministic of string\n [@@deriving sexp_of]\n end\n\n module Potentially_infinite_sequence = struct\n type 'a t = 'a Sequence.t\n\n let sexp_of_t sexp_of_elt sequence =\n let prefix, suffix = Sequence.split_n sequence 100 in\n let prefix = List.map prefix ~f:sexp_of_elt in\n let suffix =\n match Sequence.is_empty suffix with\n | true -> []\n | false -> [ [%message \"...\"] ]\n in\n Sexp.List (prefix @ suffix)\n ;;\n end\n\n type t =\n { seed : Seed.t\n ; test_count : int\n ; shrink_count : int\n ; sizes : int Potentially_infinite_sequence.t\n }\n [@@deriving fields, sexp_of]\nend\n\nlet default_config : Config.t =\n { seed = Deterministic \"an arbitrary but deterministic string\"\n ; test_count = 10_000\n ; shrink_count = 10_000\n ; sizes = Sequence.cycle_list_exn (List.range 0 ~start:`inclusive 30 ~stop:`inclusive)\n }\n;;\n\nlet lazy_nondeterministic_state = lazy (Random.State.make_self_init ())\n\nlet initial_random_state ~config =\n match Config.seed config with\n | Nondeterministic ->\n Splittable_random.State.create (force lazy_nondeterministic_state)\n | Deterministic string -> Splittable_random.State.of_int (String.hash string)\n;;\n\nlet one_size_per_test ~(config : Config.t) =\n Sequence.unfold ~init:(config.sizes, 0) ~f:(fun (sizes, number_of_size_values) ->\n match number_of_size_values >= config.test_count with\n | true -> None\n | false ->\n (match Sequence.next sizes with\n | Some (size, remaining_sizes) ->\n Some (size, (remaining_sizes, number_of_size_values + 1))\n | None ->\n raise_s\n [%message\n \"Base_quickcheck.Test.run: insufficient size values for test count\"\n ~test_count:(config.test_count : int)\n (number_of_size_values : int)]))\n;;\n\nlet shrink_error ~shrinker ~config ~f input error =\n let rec loop ~shrink_count ~alternates input error =\n match shrink_count with\n | 0 -> input, error\n | _ ->\n let shrink_count = shrink_count - 1 in\n (match Sequence.next alternates with\n | None -> input, error\n | Some (alternate, alternates) ->\n (match f alternate with\n | Ok () -> loop ~shrink_count ~alternates input error\n | Error error ->\n let alternates = Shrinker.shrink shrinker alternate in\n loop ~shrink_count ~alternates alternate error))\n in\n let shrink_count = Config.shrink_count config in\n let alternates = Shrinker.shrink shrinker input in\n loop ~shrink_count ~alternates input error\n;;\n\nlet input_sequence ~config ~examples ~generator =\n let random = initial_random_state ~config in\n Sequence.append\n (Sequence.of_list examples)\n (one_size_per_test ~config\n |> Sequence.map ~f:(fun size -> Generator.generate generator ~size ~random))\n;;\n\nlet with_sample ~f ?(config = default_config) ?(examples = []) generator =\n let sequence = input_sequence ~config ~examples ~generator in\n f sequence\n;;\n\nlet result (type a) ~f ?(config = default_config) ?(examples = []) m =\n let (module M : S with type t = a) = m in\n with_sample M.quickcheck_generator ~config ~examples ~f:(fun sequence ->\n match\n Sequence.fold_result sequence ~init:() ~f:(fun () input ->\n match f input with\n | Ok () -> Ok ()\n | Error error -> Error (input, error))\n with\n | Ok () -> Ok ()\n | Error (input, error) ->\n let shrinker = M.quickcheck_shrinker in\n let input, error = shrink_error ~shrinker ~config ~f input error in\n Error (input, error))\n;;\n\nlet run (type a) ~f ?config ?examples (module M : S with type t = a) =\n let f x =\n Or_error.try_with_join ~backtrace:(Backtrace.Exn.am_recording ()) (fun () -> f x)\n in\n match result ~f ?config ?examples (module M) with\n | Ok () -> Ok ()\n | Error (input, error) ->\n Or_error.error_s\n [%message \"Base_quickcheck.Test.run: test failed\" (input : M.t) (error : Error.t)]\n;;\n\nlet with_sample_exn ~f ?config ?examples generator =\n let f x = Or_error.try_with (fun () -> f x) in\n with_sample ~f ?config ?examples generator |> Or_error.ok_exn\n;;\n\nlet run_exn ~f ?config ?examples testable =\n let f x =\n Or_error.try_with ~backtrace:(Backtrace.Exn.am_recording ()) (fun () -> f x)\n in\n run ~f ?config ?examples testable |> Or_error.ok_exn\n;;\n","open! Base\ninclude Observer0\n\nlet unmap t ~f = create (fun x ~size ~hash -> observe t (f x) ~size ~hash)\nlet of_hash_fold f = create (fun x ~size:_ ~hash -> f hash x)\nlet of_lazy lazy_t = create (fun x ~size ~hash -> observe (force lazy_t) x ~size ~hash)\n\nlet fixed_point wrap =\n let rec lazy_t = lazy (wrap (of_lazy lazy_t)) in\n of_lazy lazy_t\n;;\n\nlet unit = opaque\nlet bool = of_hash_fold Bool.hash_fold_t\nlet char = of_hash_fold Char.hash_fold_t\nlet int = of_hash_fold Int.hash_fold_t\nlet int32 = of_hash_fold Int32.hash_fold_t\nlet int63 = of_hash_fold Int63.hash_fold_t\nlet int64 = of_hash_fold Int64.hash_fold_t\nlet nativeint = of_hash_fold Nativeint.hash_fold_t\nlet float = of_hash_fold Float.hash_fold_t\nlet string = of_hash_fold String.hash_fold_t\nlet sexp = of_hash_fold Sexp.hash_fold_t\nlet bigstring = of_hash_fold (Bigarray_helpers.Array1.hash_fold hash_fold_char)\nlet float32_vec = of_hash_fold (Bigarray_helpers.Array1.hash_fold hash_fold_float)\nlet float64_vec = of_hash_fold (Bigarray_helpers.Array1.hash_fold hash_fold_float)\nlet float32_mat = of_hash_fold (Bigarray_helpers.Array2.hash_fold hash_fold_float)\nlet float64_mat = of_hash_fold (Bigarray_helpers.Array2.hash_fold hash_fold_float)\n\nlet either fst_t snd_t =\n create (fun either ~size ~hash ->\n match (either : _ Either.t) with\n | First fst -> observe fst_t fst ~size ~hash:(hash_fold_int hash 1)\n | Second snd -> observe snd_t snd ~size ~hash:(hash_fold_int hash 2))\n;;\n\nlet result ok_t err_t =\n unmap (either ok_t err_t) ~f:(function\n | Ok ok -> First ok\n | Error err -> Second err)\n;;\n\nlet both fst_t snd_t =\n create (fun (fst, snd) ~size ~hash ->\n let hash = observe fst_t fst ~size ~hash in\n let hash = observe snd_t snd ~size ~hash in\n hash)\n;;\n\nlet option value_t =\n unmap (either opaque value_t) ~f:(function\n | None -> First ()\n | Some value -> Second value)\n;;\n\nlet list elt_t =\n create (fun list ~size ~hash ->\n let random = Splittable_random.State.of_int (Hash.get_hash_value hash) in\n let length = List.length list in\n let sizes =\n Generator.sizes ~min_length:length ~max_length:length ()\n |> Generator.generate ~size ~random\n in\n List.fold2_exn list sizes ~init:(hash_fold_int hash 0) ~f:(fun hash elt size ->\n observe elt_t elt ~size ~hash:(hash_fold_int hash 1)))\n;;\n\nlet fn dom rng =\n create (fun f ~size ~hash ->\n let random = Splittable_random.State.of_int (Hash.get_hash_value hash) in\n let sizes =\n (* Empirically, doubling the size when generating the list of inputs gives us much\n better coverage of the space of functions. *)\n Generator.generate (Generator.sizes ()) ~size:(size * 2) ~random\n in\n List.fold sizes ~init:hash ~f:(fun hash size ->\n let x = Generator.generate dom ~size ~random in\n observe rng (f x) ~size ~hash))\n;;\n\nlet map_tree key_obs data_obs =\n unmap (list (both key_obs data_obs)) ~f:Map.Using_comparator.Tree.to_alist\n;;\n\nlet set_tree elt_obs = unmap (list elt_obs) ~f:Set.Using_comparator.Tree.to_list\n\nlet map_t key_obs data_obs =\n unmap (map_tree key_obs data_obs) ~f:Map.Using_comparator.to_tree\n;;\n\nlet set_t elt_obs = unmap (set_tree elt_obs) ~f:Set.Using_comparator.to_tree\n","open! Base\nopen! Blit\n\ninclude Test_blit_intf\n\nmodule type S_gen = sig\n open Blit\n type 'a src\n type 'a dst\n (* val blit : ('a src, 'a dst) blit*)\n val blito : ('a src, 'a dst) blito\n (* val unsafe_blit : ('a src, 'a dst) blit*)\n val sub : ('a src, 'a dst) sub\n (*val subo : ('a src, 'a dst) subo*)\nend\n\nmodule type For_tests_gen = sig\n module Elt : sig\n type 'a t\n val equal : bool t -> bool t -> bool\n val of_bool : bool -> bool t\n end\n\n type 'a z\n\n module Src : sig\n type 'a t\n val length : _ t -> int\n val create_bool : len:int -> bool z t\n val get : 'a z t -> int -> 'a Elt.t\n val set : 'a z t -> int -> 'a Elt.t -> unit\n end\n\n module Dst : sig\n type 'a t\n val length : _ t -> int\n val create_bool : len:int -> bool z t\n val get : 'a z t -> int -> 'a Elt.t\n val set : 'a z t -> int -> 'a Elt.t -> unit\n val overlapping_src_dst\n : [ `Do_not_check\n | `Check of ('a Src.t -> 'a t)\n ]\n end\nend\n\nmodule Test_gen\n (For_tests : For_tests_gen)\n (Tested : S_gen\n with type 'a src := 'a For_tests.Src.t\n with type 'a dst := 'a For_tests.Dst.t)\n= struct\n open Tested\n open For_tests\n\n let init ~len ~create ~set ~f =\n let t = create ~len in\n for i = 0 to len - 1 do\n set t i (f i);\n done;\n t\n ;;\n\n (* Test [blit]. *)\n let%test_unit _ =\n let elt1 = Elt.of_bool true in\n let elt2 = Elt.of_bool false in\n assert (not (Elt.equal elt1 elt2));\n let src_bit i = if i land 0x1 = 0 then elt1 else elt2 in\n let dst_bit i = if i land 0x1 = 0 then elt2 else elt1 in\n let n = 4 in\n for src_length = 0 to n do\n for dst_length = 0 to n do\n for src_pos = 0 to src_length do\n for dst_pos = 0 to dst_length do\n for src_len = 0 to min (src_length - src_pos) (dst_length - dst_pos) do\n try\n let is_in_range i = i >= dst_pos && i < dst_pos + src_len in\n let check length get =\n fun name sequence ~expect ->\n for i = 0 to length sequence - 1 do\n if not (Elt.equal (get sequence i) (expect i)) then\n raise_s [%message \"bug\" (name : string) (i : int)]\n done;\n in\n let check_src = check Src.length Src.get in\n let check_dst = check Dst.length Dst.get in\n let src =\n init ~len:src_length ~create:Src.create_bool ~set:Src.set ~f:src_bit\n in\n assert (Src.length src = src_length);\n let dst =\n init ~len:dst_length ~create:Dst.create_bool ~set:Dst.set ~f:dst_bit\n in\n assert (Dst.length dst = dst_length);\n let init_src () =\n for i = 0 to src_length - 1 do\n Src.set src i (src_bit i);\n done\n in\n blito ~src ~src_pos ~src_len ~dst ~dst_pos ();\n check_src \"blit src\" src ~expect:src_bit;\n check_dst \"blit dst\" dst ~expect:(fun i ->\n if is_in_range i\n then src_bit (src_pos + i - dst_pos)\n else dst_bit i);\n begin match Dst.overlapping_src_dst with\n | `Do_not_check -> ()\n | `Check src_to_dst ->\n if dst_pos + src_len <= src_length then begin\n init_src ();\n let dst = src_to_dst src in\n if false then begin\n blito ~src ~src_pos ~src_len ~dst ~dst_pos ();\n check_dst \"blit dst overlapping\" dst ~expect:(fun i ->\n src_bit (if is_in_range i then (src_pos + i - dst_pos) else i));\n end;\n end;\n end;\n (* Check [sub]. *)\n init_src ();\n let dst = sub src ~pos:src_pos ~len:src_len in\n check_src \"sub src\" src ~expect:src_bit;\n check_dst \"sub dst\" dst ~expect:(fun i -> src_bit (src_pos + i));\n with exn ->\n raise_s [%message\n \"bug\"\n (exn : exn)\n (src_length : int) (src_pos : int)\n (dst_length : int) (dst_pos : int)]\n done;\n done;\n done;\n done;\n done\n ;;\nend\n\nmodule Test1\n (Sequence : Sequence1 with type 'a elt := 'a poly)\n (Tested : S1 with type 'a t := 'a Sequence.t)\n = Test_gen\n (struct\n module Elt = struct\n type 'a t = 'a\n let equal = Poly.equal\n let of_bool = Fn.id\n end\n type 'a z = 'a Sequence.z\n module Src = Sequence\n module Dst = struct\n include Sequence\n let overlapping_src_dst = `Check Fn.id\n end\n end)\n (Tested)\n\nmodule Test1_generic\n (Elt : Elt1)\n (Sequence : Sequence1 with type 'a elt := 'a Elt.t)\n (Tested : S1 with type 'a t := 'a Sequence.t)\n = Test_gen\n (struct\n module Elt = Elt\n type 'a z = 'a Sequence.z\n module Src = Sequence\n module Dst = struct\n include Sequence\n let overlapping_src_dst = `Check Fn.id\n end\n end)\n (Tested)\n\nmodule Elt_to_elt1 (Elt : Elt) = struct\n type 'a t = Elt.t\n let equal = Elt.equal\n let of_bool = Elt.of_bool\nend\n\nmodule Test\n (Elt : Elt)\n (Sequence : Sequence with type elt := Elt.t)\n (Tested : S with type t := Sequence.t)\n = Test_gen\n (struct\n module Elt = Elt_to_elt1(Elt)\n type 'a z = unit\n module Src = struct\n open Sequence\n type nonrec 'a t = t\n let length = length\n let get = get\n let set = set\n let create_bool = create\n end\n module Dst = struct\n include Src\n let overlapping_src_dst = `Check Fn.id\n end\n end)\n (Tested)\n\nmodule Test_distinct\n (Elt : Elt)\n (Src : Sequence with type elt := Elt.t)\n (Dst : Sequence with type elt := Elt.t)\n (Tested : S_distinct\n with type src := Src.t\n with type dst := Dst.t)\n = Test_gen\n (struct\n module Elt = Elt_to_elt1 (Elt)\n type 'a z = unit\n module Src = struct\n open Src\n type nonrec 'a t = t\n let length = length\n let get = get\n let set = set\n let create_bool = create\n end\n module Dst = struct\n open Dst\n type nonrec 'a t = t\n let length = length\n let get = get\n let set = set\n let create_bool = create\n let overlapping_src_dst = `Do_not_check\n end\n end)\n (Tested)\n\nmodule Make_and_test\n (Elt : Elt)\n (Sequence : sig\n include Sequence with type elt := Elt.t\n val unsafe_blit : (t, t) blit\n end) = struct\n module B = Make (Sequence)\n include Test (Elt) (Sequence) (B)\n include B\nend\n\nmodule Make_distinct_and_test\n (Elt : Elt)\n (Src : Sequence with type elt := Elt.t)\n (Dst : sig\n include Sequence with type elt := Elt.t\n val unsafe_blit : (Src.t, t) blit\n end) = struct\n module B = Make_distinct (Src) (Dst)\n include Test_distinct (Elt) (Src) (Dst) (B)\n include B\nend\n\nmodule Make1_and_test\n (Sequence : sig\n include Blit.Sequence1\n include Sequence1\n with type 'a t := 'a t\n with type 'a elt := 'a poly\n end) = struct\n module B = Make1 (Sequence)\n include Test1 (Sequence) (B)\n include B\nend\n\nmodule Make1_generic_and_test\n (Elt : Elt1)\n (Sequence : sig\n include Blit.Sequence1\n include Sequence1\n with type 'a t := 'a t\n with type 'a elt := 'a Elt.t\n end) = struct\n module B = Make1_generic (Sequence)\n include Test1_generic (Elt) (Sequence) (B)\n include B\nend\n","open! Base\nopen! Binary_searchable\n\ninclude Test_binary_searchable_intf\n\nmodule type S_gen = sig\n open Binary_searchable\n\n type 'a t\n type 'a elt\n\n val binary_search : ('a t, 'a elt, 'a elt) binary_search\n val binary_search_segmented : ('a t, 'a elt) binary_search_segmented\nend\n\nmodule type Indexable_gen_and_for_test = sig\n include S_gen\n\n module For_test : sig\n val compare : bool elt -> bool elt -> int\n val small : bool elt\n val big : bool elt\n val of_array : bool elt array -> bool t\n end\nend\n\nmodule Test_gen (M : Indexable_gen_and_for_test) = struct\n open M\n\n let%test_module \"test_binary_searchable\" =\n (module struct\n let compare = For_test.compare\n let elt_compare = For_test.compare\n\n let s = For_test.small\n let b = For_test.big\n\n let binary_search ?pos ?len ~compare t how v =\n binary_search ?pos ?len ~compare (For_test.of_array t) how v\n\n let (=) = Poly.equal\n\n let%test _ = binary_search ~compare [| |] `First_equal_to s = None\n let%test _ = binary_search ~compare [| s |] `First_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s |] `First_equal_to b = None\n let%test _ = binary_search ~compare [| s ; b |] `First_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s ; b |] `First_equal_to b = Some 1\n let%test _ = binary_search ~compare [| b ; b |] `First_equal_to s = None\n let%test _ = binary_search ~compare [| s ; s |] `First_equal_to b = None\n let%test _ = binary_search ~compare [| s ; b ; b |] `First_equal_to b = Some 1\n let%test _ = binary_search ~compare [| s ; s ; b |] `First_equal_to s = Some 0\n let%test _ = binary_search ~compare [| b ; b ; b |] `First_equal_to s = None\n\n let%test _ = binary_search ~compare [| |] `Last_equal_to s = None\n let%test _ = binary_search ~compare [| s |] `Last_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s |] `Last_equal_to b = None\n let%test _ = binary_search ~compare [| s ; b |] `Last_equal_to b = Some 1\n let%test _ = binary_search ~compare [| s ; b |] `Last_equal_to s = Some 0\n let%test _ = binary_search ~compare [| b ; b |] `Last_equal_to s = None\n let%test _ = binary_search ~compare [| s ; s |] `Last_equal_to b = None\n let%test _ = binary_search ~compare [| s ; b ; b |] `Last_equal_to b = Some 2\n let%test _ = binary_search ~compare [| s ; s ; b |] `Last_equal_to s = Some 1\n let%test _ = binary_search ~compare [| b ; b; b |] `Last_equal_to s = None\n\n let%test _ = binary_search ~compare [||] `First_greater_than_or_equal_to s = None\n let%test _ = binary_search ~compare [| b |] `First_greater_than_or_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s |] `First_greater_than_or_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s |] `First_strictly_greater_than s = None\n\n let%test _ = binary_search ~compare [||] `Last_less_than_or_equal_to s = None\n let%test _ = binary_search ~compare [| b |] `Last_less_than_or_equal_to s = None\n let%test _ = binary_search ~compare [| s |] `Last_less_than_or_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s |] `Last_strictly_less_than s = None\n\n let create_test_case (num_s, num_b) =\n let arr = Array.create b ~len:(num_s + num_b) in\n for i = 0 to num_s -1 do\n arr.(i) <- s\n done;\n arr\n ;;\n\n let only_small = (10_000, 0)\n let only_big = (0, 10_000)\n\n let both = (2531, 4717)\n\n let%test _ =\n match binary_search (create_test_case only_small) ~compare `First_equal_to s with\n | None -> false\n | Some _ -> true\n\n let%test _ =\n let arr = create_test_case both in\n match binary_search arr ~compare `First_equal_to b with\n | None -> false\n | Some v -> v = 2531\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `First_equal_to b = None\n\n let create_deterministic_test () =\n Array.init 100_000 ~f:(fun i -> if i > 50_000 then b else s)\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_equal_to s = Some 0\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_equal_to s = Some 50_000\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_greater_than_or_equal_to s = Some 0\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_less_than_or_equal_to s = Some 50_000\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_strictly_greater_than s = Some 50_001\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_strictly_less_than b = Some 50_000\n\n (* tests around a gap*)\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_equal_to b = Some 50_001\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_equal_to b = Some 99_999\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_greater_than_or_equal_to b = Some 50_001\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_less_than_or_equal_to b = Some 99_999\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_strictly_greater_than b = None\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_strictly_less_than b = Some 50_000\n\n (* test beginning of array *)\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `First_equal_to s = None\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `Last_equal_to s = None\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `First_greater_than_or_equal_to s = Some 0\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `Last_less_than_or_equal_to s = None\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `First_strictly_greater_than s = Some 0\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `Last_strictly_less_than b = None\n\n\n (* test end of array *)\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `First_equal_to b = None\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `Last_equal_to b = None\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `First_greater_than_or_equal_to b = None\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `Last_less_than_or_equal_to b = Some 9_999\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `First_strictly_greater_than s = None\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `Last_strictly_less_than b = Some 9_999\n\n let%test_unit _ =\n for length = 0 to 5 do\n for num_s = 0 to length do\n let arr = Array.init length ~f:(fun i -> if i < num_s then s else b) in\n for pos = -1 to length do\n for len = -1 to length + 1 do\n (*try*)\n let should_raise =\n Exn.does_raise (fun () ->\n Ordered_collection_common.check_pos_len_exn ~pos ~len\n ~total_length:length)\n in\n let result =\n Result.try_with (fun () ->\n binary_search arr ~pos ~len ~compare:elt_compare `Last_equal_to s)\n in\n match should_raise, result with\n | true , Error _ -> ()\n | true , Ok _ -> failwith \"expected it to raise but it didn't\"\n | false, Error _ -> failwith \"expected it to not raise, but it raised\"\n | false, Ok result ->\n let searched = num_s - 1 in\n let correct_result =\n if searched < pos then None\n else if len = 0 then None\n else if searched >= pos + len then Some(pos + len - 1)\n else Some searched\n in\n if not (correct_result = result) then failwith \"Wrong result\"\n (*with exn ->\n failwiths \"binary_search bug\"\n (exn, `length length, `search_key search_key, `pos pos, `len len)\n <:sexp_of< exn * [ `length of int ] * [ `search_key of int ]\n * [ `pos of int ] * [ `len of int ] >>*)\n done;\n done;\n done;\n done\n ;;\n\n let binary_search_segmented a = binary_search_segmented (For_test.of_array a)\n\n (*test for binary_search_segmented*)\n let%test _ =\n let arr = create_deterministic_test () in\n let segment_of x = if x = b then `Right else `Left in\n binary_search_segmented arr ~segment_of `Last_on_left = Some 50_000 &&\n binary_search_segmented arr ~segment_of `First_on_right = Some 50_001\n\n let%test _ =\n let arr = create_deterministic_test () in\n let segment_of _ = `Right in\n binary_search_segmented arr ~segment_of `Last_on_left = None &&\n binary_search_segmented arr ~segment_of `First_on_right = Some 0\n\n let%test _ =\n let arr = create_deterministic_test () in\n let segment_of _ = `Left in\n binary_search_segmented arr ~segment_of `Last_on_left = Some 99_999 &&\n binary_search_segmented arr ~segment_of `First_on_right = None\n\n end)\nend\n\nmodule Test (M : Binary_searchable_and_for_test) =\n Test_gen\n (struct\n type 'a t = M.t\n type 'a elt = M.elt\n let binary_search = M.binary_search\n let binary_search_segmented = M.binary_search_segmented\n module For_test = M.For_test\n end)\n\nmodule Test1 (M : Binary_searchable1_and_for_test) =\n Test_gen\n (struct\n type 'a t = 'a M.t\n type 'a elt = 'a\n let binary_search = M.binary_search\n let binary_search_segmented = M.binary_search_segmented\n module For_test = struct\n let of_array = M.For_test.of_array\n let compare = Bool.compare\n let small = false\n let big = true\n end\n end)\n\nmodule Make_and_test (M : Indexable_and_for_test) = struct\n module B = Binary_searchable.Make (M)\n include B\n include Test (struct\n type t = M.t\n type elt = M.elt\n include B\n module For_test = M.For_test\n end)\nend\n\nmodule Make1_and_test (M : Indexable1_and_for_test) = struct\n module B = Binary_searchable.Make1 (M)\n include B\n include Test1 (struct\n type 'a t = 'a M.t\n include B\n module For_test = M.For_test\n end)\nend\n","open! Import\n\nmodule type Conv = Conv.S\nmodule type Parser = Parser.S\nmodule type Eager_parser = Parser.S_eager\n\nmodule Conv_error = Conv_error\nmodule Of_sexp_error = Of_sexp_error\nmodule Old_parser_cont_state = Old_parser_cont_state\nmodule Parse_error = Parse_error\nmodule Positions = Positions\nmodule Cst = Cst\nmodule A = Parser_automaton\n\nexception Parse_error = Parse_error.Parse_error\nexception Of_sexp_error = Of_sexp_error.Of_sexp_error\n\nmodule Single =\n Parser.Make\n (Kind.Sexp)\n (struct\n type parsed_value = Sexp.t\n\n let mode = A.Single\n let make_value _ stack = Automaton_stack.get_single stack\n end)\n\nmodule Many =\n Parser.Make\n (Kind.Sexp)\n (struct\n type parsed_value = Sexp.t list\n\n let mode = A.Many\n let make_value _ stack = Automaton_stack.get_many stack\n end)\n\nmodule Eager =\n Parser.Make_eager\n (Kind.Sexp)\n (struct\n type parsed_value = Sexp.t\n\n let make_value _ stack = Automaton_stack.get_single stack\n end)\n\nmodule Single_and_positions =\n Parser.Make\n (Kind.Sexp_with_positions)\n (struct\n type parsed_value = Sexp.t * Positions.t\n\n let mode = A.Single\n let make_value state stack = Automaton_stack.get_single stack, A.positions state\n end)\n\nmodule Many_and_positions =\n Parser.Make\n (Kind.Sexp_with_positions)\n (struct\n type parsed_value = Sexp.t list * Positions.t\n\n let mode = A.Many\n let make_value state stack = Automaton_stack.get_many stack, A.positions state\n end)\n\nmodule Eager_and_positions =\n Parser.Make_eager\n (Kind.Sexp_with_positions)\n (struct\n type parsed_value = Sexp.t * Positions.t\n\n let make_value state stack = Automaton_stack.get_single stack, A.positions state\n end)\n\nmodule Single_just_positions =\n Parser.Make\n (Kind.Positions)\n (struct\n type parsed_value = Positions.t\n\n let mode = A.Single\n let make_value state () = A.positions state\n end)\n\nmodule Many_just_positions =\n Parser.Make\n (Kind.Positions)\n (struct\n type parsed_value = Positions.t\n\n let mode = A.Many\n let make_value state () = A.positions state\n end)\n\nmodule Eager_just_positions =\n Parser.Make_eager\n (Kind.Positions)\n (struct\n type parsed_value = Positions.t\n\n let make_value state () = A.positions state\n end)\n\nmodule Many_cst =\n Parser.Make\n (Kind.Cst)\n (struct\n type parsed_value = Cst.t_or_comment list\n\n let mode = A.Many\n let make_value _ stack = Automaton_stack.For_cst.get_many stack\n end)\n\nmodule Eager_cst =\n Parser.Make_eager\n (Kind.Cst)\n (struct\n type parsed_value = Cst.t_or_comment\n\n let make_value _ stack =\n match Automaton_stack.For_cst.get_many stack with\n | [ sexp ] -> sexp\n | _ -> assert false\n ;;\n end)\n\ntype 'a id = 'a\ntype sexp_list = Sexp.t list\n\nmodule Conv_single =\n Conv.Make\n (struct\n type 'a res = 'a\n type parsed_sexp = Sexp.t\n type chunk_to_conv = Sexp.t\n\n let apply_f x ~f = f x\n let find = Positions.find_sub_sexp_phys\n end)\n (Single)\n (Single_just_positions)\n\nmodule Conv_many =\n Conv.Make\n (struct\n type 'a res = 'a list\n type parsed_sexp = Sexp.t list\n type chunk_to_conv = Sexp.t\n\n let apply_f x ~f = List.rev (List.rev_map x ~f)\n let find = Positions.find_sub_sexp_in_list_phys\n end)\n (Many)\n (Many_just_positions)\n\nmodule Conv_many_at_once =\n Conv.Make\n (struct\n type 'a res = 'a\n type parsed_sexp = Sexp.t list\n type chunk_to_conv = Sexp.t list\n\n let apply_f x ~f = f x\n let find = Positions.find_sub_sexp_in_list_phys\n end)\n (Many)\n (Many_just_positions)\n\nmodule Private = struct\n module Automaton_stack = Automaton_stack\n module Parser_automaton = Parser_automaton\nend\n","open! Import\ninclude Automaton_stack_intf\n\nmodule For_cst = struct\n type t =\n | Empty\n | T_or_comment of Cst.t_or_comment * t\n | Open of Positions.pos * t\n | In_sexp_comment of\n { hash_semi_pos : Positions.pos\n ; rev_comments : Cst.comment list\n ; stack : t\n }\n\n let empty = Empty\n\n let get_many =\n let rec loop acc = function\n | Empty -> acc\n | T_or_comment (t, stack) -> loop (t :: acc) stack\n | Open _ | In_sexp_comment _ -> failwith \"Automaton_stack.For_cst.get_many\"\n in\n fun stack -> loop [] stack\n ;;\nend\n\nmodule Just_positions = struct\n type t = unit\n\n let empty = ()\nend\n\ntype t =\n | Empty\n | Open of t\n | Sexp of Sexp.t * t\n\nlet empty = Empty\n\nlet get_single = function\n | Sexp (sexp, Empty) -> sexp\n | _ -> failwith \"Automaton_stack.get_single\"\n;;\n\nlet get_many =\n let rec loop acc = function\n | Empty -> acc\n | Open _ -> failwith \"Automaton_stack.get_many\"\n | Sexp (sexp, stack) -> loop (sexp :: acc) stack\n in\n fun stack -> loop [] stack\n;;\n","open! Import\n\ntype t =\n { user_exn : exn\n ; sub_sexp : Sexp.t\n ; location : Positions.range option\n }\n[@@deriving_inline sexp_of]\n\nlet sexp_of_t =\n (function\n | { user_exn = v_user_exn; sub_sexp = v_sub_sexp; location = v_location } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_option Positions.sexp_of_range v_location in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"location\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = Sexp.sexp_of_t v_sub_sexp in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"sub_sexp\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_exn v_user_exn in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"user_exn\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet user_exn t = t.user_exn\nlet sub_sexp t = t.sub_sexp\nlet location t = t.location\n\nlet report ppf ~filename t =\n let line, start, stop =\n match t.location with\n | None -> 1, 0, 0\n | Some { start_pos; end_pos } ->\n start_pos.line, start_pos.col, start_pos.col + end_pos.offset - start_pos.offset\n in\n Format.fprintf\n ppf\n \"File \\\"%s\\\", line %d, characters %d-%d:\\n\\\n Error: s-expression conversion error;\\n\\\n exception %s\\n\"\n filename\n line\n start\n stop\n (Printexc.to_string t.user_exn)\n;;\n\nexception Of_sexp_error of t [@@deriving_inline sexp_of]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Of_sexp_error]\n (function\n | Of_sexp_error v0 ->\n let v0 = sexp_of_t v0 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"of_sexp_error.ml.Of_sexp_error\"; v0 ]\n | _ -> assert false)\n;;\n\n[@@@end]\n\nlet raise ~user_exn ~sub_sexp ~location =\n raise (Of_sexp_error { user_exn; sub_sexp; location })\n;;\n","open! Import\ninclude Parse_error_intf\n\ntype t =\n { position : Positions.pos\n ; message : string\n ; old_parser_exn : [ `Parse_error | `Failure ]\n }\n\nlet sexp_of_t { position; message; old_parser_exn = _ } : Sexp.t =\n List\n [ List [ Atom \"position\"; Positions.sexp_of_pos position ]\n ; List [ Atom \"message\"; sexp_of_string message ]\n ]\n;;\n\nlet position t = t.position\nlet message t = t.message\nlet old_parser_exn t = t.old_parser_exn\n\nlet report ppf ~filename t =\n let pos = position t in\n let msg = message t in\n Format.fprintf\n ppf\n \"File \\\"%s\\\", line %d, character %d:\\nError: s-expression parsing error;\\n%s\\n\"\n filename\n pos.line\n pos.col\n msg\n;;\n\nexception Parse_error of t [@@deriving_inline sexp]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add [%extension_constructor Parse_error] (function\n | Parse_error v0 ->\n let v0 = sexp_of_t v0 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"parse_error.ml.Parse_error\"; v0 ]\n | _ -> assert false)\n;;\n\n[@@@end]\n\nlet raise (reason : Reason.t) position ~at_eof ~atom_buffer =\n let message =\n (* These messages where choosen such that we can build the various Sexplib parsing\n functions on top of Parsexp and keep the same exceptions.\n\n At the time of writing this, a simple layer on top of parsexp to implement the\n sexplib API is passing all the sexplib tests.\n\n Note that parsexp matches the semantic of Sexp.parse which is slightly\n different from the ocamllex/ocamlyacc based parser of Sexplib. The latter one\n is less tested and assumed to be less used. *)\n match reason with\n | Unexpected_char_parsing_hex_escape -> \"unterminated hexadecimal escape sequence\"\n | Unexpected_char_parsing_dec_escape -> \"unterminated decimal escape sequence\"\n | Unterminated_quoted_string -> \"unterminated quoted string\"\n | Unterminated_block_comment -> \"unterminated block comment\"\n | Escape_sequence_out_of_range -> \"escape sequence in quoted string out of range\"\n | Unclosed_paren -> \"unclosed parentheses at end of input\"\n | Too_many_sexps -> \"s-expression followed by data\"\n | Closed_paren_without_opened -> \"unexpected character: ')'\"\n | Comment_token_in_unquoted_atom ->\n if String.equal (Buffer.contents atom_buffer) \"|\"\n then \"illegal end of comment\"\n else \"comment tokens in unquoted atom\"\n | Sexp_comment_without_sexp -> \"unterminated sexp comment\"\n | Unexpected_character_after_cr ->\n if at_eof\n then \"unexpected end of input after carriage return\"\n else \"unexpected character after carriage return\"\n | No_sexp_found_in_input -> \"no s-expression found in input\"\n | Automaton_in_error_state -> failwith \"Parsexp.Parser_automaton: parser is dead\"\n in\n let old_parser_exn =\n match reason, at_eof with\n | Too_many_sexps, _ | _, true -> `Failure\n | Comment_token_in_unquoted_atom, _\n when String.equal (Buffer.contents atom_buffer) \"|\" -> `Failure\n | _ -> `Parse_error\n in\n raise (Parse_error { position; message; old_parser_exn })\n;;\n\nmodule Private = struct\n module Reason = Reason\n\n let old_parser_exn = old_parser_exn\n let raise = raise\nend\n","open! Import\n\nmodule Public = struct\n type state_cst =\n { token_buffer : Buffer.t\n ; (* Starting positions of the current token *)\n mutable token_start_pos : Positions.pos\n }\n\n type ('u, 's) kind =\n | Positions : (Positions.Builder.t, unit) kind\n | Sexp : (unit, Automaton_stack.t) kind\n | Sexp_with_positions : (Positions.Builder.t, Automaton_stack.t) kind\n | Cst : (state_cst, Automaton_stack.For_cst.t) kind\n\n type ('u, 's) state =\n { mutable automaton_state : int\n ; kind : ('u, 's) kind\n ; mutable depth : int\n ; (* Number of opened #| when parsing a block comment *)\n mutable block_comment_depth : int\n ; (* Stack of ignoring depths; the current depth is pushed\n each time a #; comment is entered. *)\n mutable ignoring_stack : int list\n ; (* When parsing an escape sequence of the form \"\\\\NNN\" or \"\\\\XX\", this accumulates\n the computed number *)\n mutable escaped_value : int\n ; (* Buffer for accumulating atoms *)\n atom_buffer : Buffer.t\n ; user_state : 'u\n ; mode : ('u, 's) mode\n ; mutable full_sexps : int\n ; mutable offset : int (* global offset *)\n ; mutable line_number : int\n ; mutable bol_offset : int (* offset of beginning of line *)\n }\n\n and ('u, 's) mode =\n | Single\n | Many\n | Eager of\n { got_sexp : ('u, 's) state -> 's -> 's\n ; mutable no_sexp_is_error : bool\n }\n\n let initial_user_state : type u s. (u, s) kind -> Positions.pos -> u =\n fun kind initial_pos ->\n match kind with\n | Positions -> Positions.Builder.create ~initial_pos ()\n | Sexp -> ()\n | Sexp_with_positions -> Positions.Builder.create ~initial_pos ()\n | Cst ->\n (* [token_start_pos] is set to a dummy location here. It is properly set when we\n start to capture a token from the input *)\n { token_buffer = Buffer.create 128; token_start_pos = Positions.beginning_of_file }\n ;;\n\n (* these magic numbers are checked in gen_parser_automaton.ml:\n let () = assert (initial = 0)\n let () = assert (to_int Error = 1) *)\n let initial_state = 0\n let error_state = 1\n\n let new_state ?(initial_pos = Positions.beginning_of_file) mode kind =\n { kind\n ; depth = 0\n ; automaton_state = initial_state\n ; block_comment_depth = 0\n ; ignoring_stack = []\n ; escaped_value = 0\n ; atom_buffer = Buffer.create 128\n ; user_state = initial_user_state kind initial_pos\n ; mode\n ; full_sexps = 0\n ; offset = initial_pos.offset\n ; line_number = initial_pos.line\n ; bol_offset = initial_pos.offset - initial_pos.col\n }\n ;;\n\n let mode t = t.mode\n let positions t = Positions.Builder.contents t.user_state\n let atom_buffer t = t.atom_buffer\n let offset state = state.offset\n let line state = state.line_number\n let column state = state.offset - state.bol_offset\n let position t = { Positions.col = column t; line = line t; offset = offset t }\n\n let reset_user_state : type u s. (u, s) state -> unit =\n fun t ->\n match t.kind with\n | Positions -> Positions.Builder.reset t.user_state (position t)\n | Sexp -> ()\n | Sexp_with_positions -> Positions.Builder.reset t.user_state (position t)\n | Cst -> Buffer.clear t.user_state.token_buffer\n ;;\n\n let reset ?(pos = Positions.beginning_of_file) t =\n t.depth <- 0;\n t.automaton_state <- initial_state;\n t.block_comment_depth <- 0;\n t.ignoring_stack <- [];\n t.escaped_value <- 0;\n t.full_sexps <- 0;\n t.offset <- pos.offset;\n t.line_number <- pos.line;\n t.bol_offset <- pos.offset - pos.col;\n reset_user_state t;\n Buffer.clear t.atom_buffer\n ;;\n\n type context =\n | Sexp_comment\n | Sexp\n\n let is_ignoring state =\n match state.ignoring_stack with\n | _ :: _ -> true\n | [] -> false\n ;;\n\n let is_not_ignoring state = not (is_ignoring state)\n let context state = if is_not_ignoring state then Sexp else Sexp_comment\n let has_unclosed_paren state = state.depth > 0\n let set_error_state state = state.automaton_state <- error_state\n\n module Error = Parse_error\n\n let automaton_state state = state.automaton_state\nend\n\nopen Public\n\nlet raise_error : type a b. (a, b) state -> _ =\n fun state ~at_eof reason ->\n set_error_state state;\n Parse_error.Private.raise\n reason\n { line = state.line_number\n ; col = state.offset - state.bol_offset\n ; offset = state.offset\n }\n ~at_eof\n ~atom_buffer:state.atom_buffer\n;;\n\ntype nonrec context = context =\n | Sexp_comment\n | Sexp\n\nlet context = context\n\ntype ('u, 's) action = ('u, 's) state -> char -> 's -> 's\ntype ('u, 's) epsilon_action = ('u, 's) state -> 's -> 's\n\nlet current_pos ?(delta = 0) state : Positions.pos =\n let offset = state.offset + delta in\n { line = state.line_number; col = offset - state.bol_offset; offset }\n;;\n\nlet set_automaton_state state x = state.automaton_state <- x\nlet advance state = state.offset <- state.offset + 1\n\nlet advance_eol : type u s. (u, s) state -> unit =\n fun state ->\n let newline_offset = state.offset in\n state.offset <- newline_offset + 1;\n state.bol_offset <- state.offset;\n state.line_number <- state.line_number + 1;\n match state.kind with\n | Positions -> Positions.Builder.add_newline state.user_state ~offset:newline_offset\n | Sexp_with_positions ->\n Positions.Builder.add_newline state.user_state ~offset:newline_offset\n | _ -> ()\n;;\n\nlet block_comment_depth state = state.block_comment_depth\n\nlet add_token_char : type u s. (u, s) action =\n fun state char stack ->\n match state.kind with\n | Cst ->\n Buffer.add_char state.user_state.token_buffer char;\n stack\n | _ -> stack\n;;\n\nlet add_atom_char state c stack =\n Buffer.add_char state.atom_buffer c;\n stack\n;;\n\nlet add_quoted_atom_char state c stack =\n Buffer.add_char state.atom_buffer c;\n add_token_char state c stack\n;;\n\nlet check_new_sexp_allowed state =\n let is_single =\n match state.mode with\n | Single -> true\n | _ -> false\n in\n if is_single && state.full_sexps > 0 && is_not_ignoring state\n then raise_error state ~at_eof:false Too_many_sexps\n;;\n\nlet add_pos state ~delta =\n Positions.Builder.add state.user_state ~offset:(state.offset + delta)\n;;\n\nlet add_first_char : type u s. (u, s) action =\n fun state char stack ->\n check_new_sexp_allowed state;\n Buffer.add_char state.atom_buffer char;\n (* For non-quoted atoms, we save both positions at the end. We can always determine the\n start position from the end position and the atom length for non-quoted atoms.\n\n Doing it this way allows us to detect single characater atoms for which we need to\n save the position twice. *)\n stack\n;;\n\nlet eps_add_first_char_hash : type u s. (u, s) epsilon_action =\n fun state stack ->\n check_new_sexp_allowed state;\n Buffer.add_char state.atom_buffer '#';\n stack\n;;\n\nlet start_quoted_string : type u s. (u, s) action =\n fun state _char stack ->\n check_new_sexp_allowed state;\n match state.kind with\n | Positions ->\n if is_not_ignoring state then add_pos state ~delta:0;\n stack\n | Sexp_with_positions ->\n if is_not_ignoring state then add_pos state ~delta:0;\n stack\n | Cst ->\n state.user_state.token_start_pos <- current_pos state;\n Buffer.add_char state.user_state.token_buffer '\"';\n stack\n | Sexp -> stack\n;;\n\nlet add_escaped state c stack =\n let c' =\n match c with\n | 'n' -> '\\n'\n | 'r' -> '\\r'\n | 'b' -> '\\b'\n | 't' -> '\\t'\n | '\\\\' | '\\'' | '\"' -> c\n | _ ->\n Buffer.add_char state.atom_buffer '\\\\';\n c\n in\n Buffer.add_char state.atom_buffer c';\n add_token_char state c stack\n;;\n\nlet eps_add_escaped_cr state stack =\n Buffer.add_char state.atom_buffer '\\r';\n stack\n;;\n\nlet dec_val c = Char.code c - Char.code '0'\n\nlet hex_val c =\n match c with\n | '0' .. '9' -> Char.code c - Char.code '0'\n | 'a' .. 'f' -> Char.code c - Char.code 'a' + 10\n | _ -> Char.code c - Char.code 'A' + 10\n;;\n\nlet add_dec_escape_char state c stack =\n state.escaped_value <- (state.escaped_value * 10) + dec_val c;\n add_token_char state c stack\n;;\n\nlet add_last_dec_escape_char state c stack =\n let value = (state.escaped_value * 10) + dec_val c in\n state.escaped_value <- 0;\n if value > 255 then raise_error state ~at_eof:false Escape_sequence_out_of_range;\n Buffer.add_char state.atom_buffer (Char.chr value);\n add_token_char state c stack\n;;\n\nlet comment_add_last_dec_escape_char state c stack =\n let value = (state.escaped_value * 10) + dec_val c in\n state.escaped_value <- 0;\n if value > 255 then raise_error state ~at_eof:false Escape_sequence_out_of_range;\n add_token_char state c stack\n;;\n\nlet add_hex_escape_char state c stack =\n state.escaped_value <- (state.escaped_value lsl 4) lor hex_val c;\n add_token_char state c stack\n;;\n\nlet add_last_hex_escape_char state c stack =\n let value = (state.escaped_value lsl 4) lor hex_val c in\n state.escaped_value <- 0;\n Buffer.add_char state.atom_buffer (Char.chr value);\n add_token_char state c stack\n;;\n\nlet opening : type u s. (u, s) state -> char -> s -> s =\n fun state _char stack ->\n check_new_sexp_allowed state;\n state.depth <- state.depth + 1;\n match state.kind with\n | Positions ->\n if is_not_ignoring state then add_pos state ~delta:0;\n stack\n | Sexp -> if is_not_ignoring state then Open stack else stack\n | Sexp_with_positions ->\n if is_not_ignoring state\n then (\n add_pos state ~delta:0;\n Open stack)\n else stack\n | Cst -> Open (current_pos state, stack)\n;;\n\nlet do_reset_positions state =\n Positions.Builder.reset\n state.user_state\n { line = state.line_number\n ; col = state.offset - state.bol_offset\n ; offset = state.offset\n }\n;;\n\nlet reset_positions : type u s. (u, s) state -> unit =\n fun state ->\n match state.kind with\n | Positions -> do_reset_positions state\n | Sexp_with_positions -> do_reset_positions state\n | Sexp -> ()\n | Cst -> ()\n;;\n\nlet toplevel_sexp_or_comment_added state stack ~delta =\n match state.mode with\n | Single | Many -> stack\n | Eager { got_sexp = f; _ } ->\n (* Modify the offset so that [f] get a state pointing to the end of the current\n s-expression *)\n let saved_offset = state.offset in\n state.offset <- state.offset + delta;\n let saved_full_sexps = state.full_sexps in\n (match f state stack with\n | exception e ->\n set_error_state state;\n raise e\n | stack ->\n (* This assert is not a full protection against the user mutating the state but\n it should catch most cases. *)\n assert (state.offset = saved_offset + delta && state.full_sexps = saved_full_sexps);\n state.offset <- saved_offset;\n reset_positions state;\n stack)\n;;\n\nlet is_top_level state = is_not_ignoring state && state.depth = 0\n\nlet comment_added_assuming_cst state stack ~delta =\n if is_top_level state then toplevel_sexp_or_comment_added state stack ~delta else stack\n;;\n\nlet maybe_pop_ignoring_stack state =\n match state.ignoring_stack with\n | inner_comment_depth :: _tl when inner_comment_depth > state.depth ->\n raise_error state ~at_eof:false Sexp_comment_without_sexp\n | inner_comment_depth :: tl when inner_comment_depth = state.depth ->\n state.ignoring_stack <- tl;\n true\n | _ -> false\n;;\n\nlet sexp_added : type u s. (u, s) state -> s -> delta:int -> s =\n fun state stack ~delta ->\n let is_comment = maybe_pop_ignoring_stack state in\n if is_top_level state\n then (\n if not is_comment then state.full_sexps <- state.full_sexps + 1;\n if (not is_comment)\n ||\n match state.kind with\n | Cst -> true\n | _ -> false\n then toplevel_sexp_or_comment_added state stack ~delta\n else stack)\n else stack\n;;\n\nlet rec make_list acc : Automaton_stack.t -> Automaton_stack.t = function\n | Empty -> assert false\n | Open stack -> Sexp (List acc, stack)\n | Sexp (sexp, stack) -> make_list (sexp :: acc) stack\n;;\n\nlet add_comment_to_stack_cst comment (stack : Automaton_stack.For_cst.t)\n : Automaton_stack.For_cst.t\n =\n match stack with\n | In_sexp_comment r ->\n In_sexp_comment { r with rev_comments = comment :: r.rev_comments }\n | _ -> T_or_comment (Comment comment, stack)\n;;\n\nlet add_sexp_to_stack_cst sexp : Automaton_stack.For_cst.t -> Automaton_stack.For_cst.t\n = function\n | In_sexp_comment { hash_semi_pos; rev_comments; stack } ->\n let comment : Cst.comment =\n Sexp_comment { hash_semi_pos; comments = List.rev rev_comments; sexp }\n in\n add_comment_to_stack_cst comment stack\n | stack -> T_or_comment (Sexp sexp, stack)\n;;\n\nlet rec make_list_cst end_pos acc\n : Automaton_stack.For_cst.t -> Automaton_stack.For_cst.t\n = function\n | T_or_comment (t, stack) -> make_list_cst end_pos (t :: acc) stack\n | Open (start_pos, stack) ->\n let sexp : Cst.t = List { loc = { start_pos; end_pos }; elements = acc } in\n add_sexp_to_stack_cst sexp stack\n | Empty | In_sexp_comment _ -> assert false\n;;\n\nlet closing : type u s. (u, s) state -> char -> s -> s =\n fun state _char stack ->\n if state.depth > 0\n then (\n let stack : s =\n match state.kind with\n | Positions ->\n (* Note we store end positions as inclusive in [Positions.t], so we use [delta:0],\n while in the [Cst] case we save directly the final ranges, so we use\n [delta:1]. *)\n if is_not_ignoring state then add_pos state ~delta:0;\n stack\n | Sexp -> if is_not_ignoring state then make_list [] stack else stack\n | Sexp_with_positions ->\n if is_not_ignoring state\n then (\n add_pos state ~delta:0;\n make_list [] stack)\n else stack\n | Cst -> make_list_cst (current_pos state ~delta:1) [] stack\n in\n state.depth <- state.depth - 1;\n sexp_added state stack ~delta:1)\n else raise_error state ~at_eof:false Closed_paren_without_opened\n;;\n\nlet make_loc ?(delta = 0) state : Positions.range =\n { start_pos = state.user_state.token_start_pos; end_pos = current_pos state ~delta }\n;;\n\n(* This is always called on the position exactly following the last character of a\n non-quoted atom *)\nlet add_non_quoted_atom_pos state ~atom =\n let len = String.length atom in\n if len = 1\n then Positions.Builder.add_twice state.user_state ~offset:(state.offset - 1)\n else (\n add_pos state ~delta:(-len);\n add_pos state ~delta:(-1))\n;;\n\nlet eps_push_atom : type u s. (u, s) epsilon_action =\n fun state stack ->\n let str = Buffer.contents state.atom_buffer in\n Buffer.clear state.atom_buffer;\n let stack : s =\n match state.kind with\n | Positions ->\n if is_not_ignoring state then add_non_quoted_atom_pos state ~atom:str;\n stack\n | Sexp -> if is_not_ignoring state then Sexp (Atom str, stack) else stack\n | Sexp_with_positions ->\n if is_not_ignoring state\n then (\n add_non_quoted_atom_pos state ~atom:str;\n Sexp (Atom str, stack))\n else stack\n | Cst ->\n let loc : Positions.range =\n { start_pos = current_pos state ~delta:(-String.length str)\n ; end_pos = current_pos state ~delta:0\n }\n in\n let sexp : Cst.t = Atom { loc; atom = str; unescaped = Some str } in\n add_sexp_to_stack_cst sexp stack\n in\n sexp_added state stack ~delta:0\n;;\n\nlet push_quoted_atom : type u s. (u, s) action =\n fun state _char stack ->\n let str = Buffer.contents state.atom_buffer in\n Buffer.clear state.atom_buffer;\n let stack : s =\n match state.kind with\n | Positions ->\n if is_not_ignoring state then add_pos state ~delta:0;\n stack\n | Sexp -> if is_not_ignoring state then Sexp (Atom str, stack) else stack\n | Sexp_with_positions ->\n if is_not_ignoring state\n then (\n add_pos state ~delta:0;\n Sexp (Atom str, stack))\n else stack\n | Cst ->\n let buf = state.user_state.token_buffer in\n Buffer.add_char buf '\"';\n let s = Buffer.contents buf in\n Buffer.clear buf;\n let sexp : Cst.t =\n Atom { loc = make_loc state ~delta:1; atom = str; unescaped = Some s }\n in\n add_sexp_to_stack_cst sexp stack\n in\n sexp_added state stack ~delta:1\n;;\n\nlet start_sexp_comment : type u s. (u, s) action =\n fun state _char stack ->\n state.ignoring_stack <- state.depth :: state.ignoring_stack;\n match state.kind with\n | Cst ->\n In_sexp_comment\n { hash_semi_pos = current_pos state ~delta:(-1); rev_comments = []; stack }\n | _ -> stack\n;;\n\nlet start_block_comment : type u s. (u, s) state -> char -> s -> s =\n fun state char stack ->\n state.block_comment_depth <- state.block_comment_depth + 1;\n match state.kind with\n | Positions -> stack\n | Sexp -> stack\n | Sexp_with_positions -> stack\n | Cst ->\n if state.block_comment_depth = 1\n then (\n state.user_state.token_start_pos <- current_pos state ~delta:(-1);\n Buffer.add_char state.user_state.token_buffer '#');\n Buffer.add_char state.user_state.token_buffer char;\n stack\n;;\n\nlet end_block_comment : type u s. (u, s) state -> char -> s -> s =\n fun state char stack ->\n state.block_comment_depth <- state.block_comment_depth - 1;\n match state.kind with\n | Positions -> stack\n | Sexp -> stack\n | Sexp_with_positions -> stack\n | Cst ->\n let buf = state.user_state.token_buffer in\n Buffer.add_char buf char;\n if state.block_comment_depth = 0\n then (\n let s = Buffer.contents buf in\n Buffer.clear buf;\n let comment : Cst.comment =\n Plain_comment { loc = make_loc state ~delta:1; comment = s }\n in\n let stack = add_comment_to_stack_cst comment stack in\n comment_added_assuming_cst state stack ~delta:1)\n else stack\n;;\n\nlet start_line_comment : type u s. (u, s) action =\n fun state char stack ->\n match state.kind with\n | Cst ->\n state.user_state.token_start_pos <- current_pos state;\n Buffer.add_char state.user_state.token_buffer char;\n stack\n | _ -> stack\n;;\n\nlet end_line_comment : type u s. (u, s) epsilon_action =\n fun state stack ->\n match state.kind with\n | Positions -> stack\n | Sexp -> stack\n | Sexp_with_positions -> stack\n | Cst ->\n let buf = state.user_state.token_buffer in\n let s = Buffer.contents buf in\n Buffer.clear buf;\n let comment : Cst.comment = Plain_comment { loc = make_loc state; comment = s } in\n let stack = add_comment_to_stack_cst comment stack in\n comment_added_assuming_cst state stack ~delta:0\n;;\n\nlet eps_eoi_check : type u s. (u, s) epsilon_action =\n fun state stack ->\n if state.depth > 0 then raise_error state ~at_eof:true Unclosed_paren;\n if is_ignoring state then raise_error state ~at_eof:true Sexp_comment_without_sexp;\n if state.full_sexps = 0\n then (\n match state.mode with\n | Many | Eager { no_sexp_is_error = false; _ } -> ()\n | Single | Eager { no_sexp_is_error = true; _ } ->\n raise_error state ~at_eof:true No_sexp_found_in_input);\n stack\n;;\n","open Parser_automaton_internal\ninclude Public\n\nlet raise = Parser_automaton_internal.raise_error\n\ntype u'\ntype s'\n\n(*$ open Parsexp_cinaps_helpers.Gen_parser_automaton ;; *)\n(*$ print_code () ;; *)\n\nlet tr_00 state char stack =\n let stack = add_first_char state char stack in\n set_automaton_state state 3;\n advance state;\n stack\n;;\n\nlet tr_01 state _char stack =\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_02 state _char stack =\n set_automaton_state state 0;\n advance_eol state;\n stack\n;;\n\nlet tr_03 state _char stack =\n set_automaton_state state 2;\n advance state;\n stack\n;;\n\nlet tr_04 state char stack =\n let stack = start_quoted_string state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_05 state _char stack =\n set_automaton_state state 7;\n advance state;\n stack\n;;\n\nlet tr_06 state char stack =\n let stack = opening state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_07 state char stack =\n let stack = closing state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_08 state char stack =\n let stack = start_line_comment state char stack in\n set_automaton_state state 6;\n advance state;\n stack\n;;\n\nlet tr_09 state char stack =\n let stack = add_first_char state char stack in\n set_automaton_state state 5;\n advance state;\n stack\n;;\n\nlet tr_10 _state _char _stack = raise _state ~at_eof:false Automaton_in_error_state\nlet tr_11 _state _char _stack = raise _state ~at_eof:false Unexpected_character_after_cr\n\nlet tr_12 state char stack =\n let stack = add_atom_char state char stack in\n set_automaton_state state 3;\n advance state;\n stack\n;;\n\nlet tr_13 state _char stack =\n let stack = eps_push_atom state stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_14 state _char stack =\n let stack = eps_push_atom state stack in\n set_automaton_state state 0;\n advance_eol state;\n stack\n;;\n\nlet tr_15 state _char stack =\n let stack = eps_push_atom state stack in\n set_automaton_state state 2;\n advance state;\n stack\n;;\n\nlet tr_16 state char stack =\n let stack = eps_push_atom state stack in\n let stack = start_quoted_string state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_17 state char stack =\n let stack = add_atom_char state char stack in\n set_automaton_state state 4;\n advance state;\n stack\n;;\n\nlet tr_18 state char stack =\n let stack = eps_push_atom state stack in\n let stack = opening state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_19 state char stack =\n let stack = eps_push_atom state stack in\n let stack = closing state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_20 state char stack =\n let stack = eps_push_atom state stack in\n let stack = start_line_comment state char stack in\n set_automaton_state state 6;\n advance state;\n stack\n;;\n\nlet tr_21 state char stack =\n let stack = add_atom_char state char stack in\n set_automaton_state state 5;\n advance state;\n stack\n;;\n\nlet tr_22 _state _char _stack = raise _state ~at_eof:false Comment_token_in_unquoted_atom\n\nlet tr_23 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 6;\n advance state;\n stack\n;;\n\nlet tr_24 state _char stack =\n let stack = end_line_comment state stack in\n set_automaton_state state 0;\n advance_eol state;\n stack\n;;\n\nlet tr_25 state _char stack =\n let stack = end_line_comment state stack in\n set_automaton_state state 2;\n advance state;\n stack\n;;\n\nlet tr_26 state char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = add_atom_char state char stack in\n set_automaton_state state 3;\n advance state;\n stack\n;;\n\nlet tr_27 state _char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_28 state _char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n set_automaton_state state 0;\n advance_eol state;\n stack\n;;\n\nlet tr_29 state _char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n set_automaton_state state 2;\n advance state;\n stack\n;;\n\nlet tr_30 state char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n let stack = start_quoted_string state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_31 state char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = add_atom_char state char stack in\n set_automaton_state state 4;\n advance state;\n stack\n;;\n\nlet tr_32 state char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n let stack = opening state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_33 state char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n let stack = closing state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_34 state char stack =\n let stack = start_sexp_comment state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_35 state char stack =\n let stack = start_block_comment state char stack in\n set_automaton_state state 16;\n advance state;\n stack\n;;\n\nlet tr_36 state char stack =\n let stack = add_quoted_atom_char state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_37 state char stack =\n let stack = add_quoted_atom_char state char stack in\n set_automaton_state state 8;\n advance_eol state;\n stack\n;;\n\nlet tr_38 state char stack =\n let stack = push_quoted_atom state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_39 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 9;\n advance state;\n stack\n;;\n\nlet tr_40 state char stack =\n let stack = add_escaped state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_41 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 15;\n advance_eol state;\n stack\n;;\n\nlet tr_42 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 10;\n advance state;\n stack\n;;\n\nlet tr_43 state char stack =\n let stack = add_dec_escape_char state char stack in\n set_automaton_state state 11;\n advance state;\n stack\n;;\n\nlet tr_44 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 13;\n advance state;\n stack\n;;\n\nlet tr_45 state char stack =\n let stack = eps_add_escaped_cr state stack in\n let stack = add_quoted_atom_char state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_46 state char stack =\n let stack = eps_add_escaped_cr state stack in\n let stack = push_quoted_atom state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_47 state char stack =\n let stack = eps_add_escaped_cr state stack in\n let stack = add_token_char state char stack in\n set_automaton_state state 9;\n advance state;\n stack\n;;\n\nlet tr_48 _state _char _stack =\n raise _state ~at_eof:false Unexpected_char_parsing_dec_escape\n;;\n\nlet tr_49 state char stack =\n let stack = add_dec_escape_char state char stack in\n set_automaton_state state 12;\n advance state;\n stack\n;;\n\nlet tr_50 state char stack =\n let stack = add_last_dec_escape_char state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_51 _state _char _stack =\n raise _state ~at_eof:false Unexpected_char_parsing_hex_escape\n;;\n\nlet tr_52 state char stack =\n let stack = add_hex_escape_char state char stack in\n set_automaton_state state 14;\n advance state;\n stack\n;;\n\nlet tr_53 state char stack =\n let stack = add_last_hex_escape_char state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_54 state char stack =\n let stack = add_quoted_atom_char state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_55 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 15;\n advance state;\n stack\n;;\n\nlet tr_56 state char stack =\n let stack = add_quoted_atom_char state char stack in\n set_automaton_state state 8;\n advance_eol state;\n stack\n;;\n\nlet tr_57 state char stack =\n let stack = push_quoted_atom state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_58 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 9;\n advance state;\n stack\n;;\n\nlet tr_59 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 16;\n advance state;\n stack\n;;\n\nlet tr_60 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 16;\n advance_eol state;\n stack\n;;\n\nlet tr_61 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 19;\n advance state;\n stack\n;;\n\nlet tr_62 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 18;\n advance state;\n stack\n;;\n\nlet tr_63 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 17;\n advance state;\n stack\n;;\n\nlet tr_64 state char stack =\n let stack = end_block_comment state char stack in\n set_automaton_state state (if block_comment_depth state <> 0 then 16 else 0);\n advance state;\n stack\n;;\n\nlet tr_65 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 19;\n advance_eol state;\n stack\n;;\n\nlet tr_66 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 20;\n advance state;\n stack\n;;\n\nlet tr_67 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 26;\n advance_eol state;\n stack\n;;\n\nlet tr_68 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 21;\n advance state;\n stack\n;;\n\nlet tr_69 state char stack =\n let stack = add_dec_escape_char state char stack in\n set_automaton_state state 22;\n advance state;\n stack\n;;\n\nlet tr_70 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 24;\n advance state;\n stack\n;;\n\nlet tr_71 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 19;\n advance state;\n stack\n;;\n\nlet tr_72 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 16;\n advance state;\n stack\n;;\n\nlet tr_73 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 20;\n advance state;\n stack\n;;\n\nlet tr_74 state char stack =\n let stack = add_dec_escape_char state char stack in\n set_automaton_state state 23;\n advance state;\n stack\n;;\n\nlet tr_75 state char stack =\n let stack = comment_add_last_dec_escape_char state char stack in\n set_automaton_state state 19;\n advance state;\n stack\n;;\n\nlet tr_76 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 25;\n advance state;\n stack\n;;\n\nlet tr_77 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 26;\n advance state;\n stack\n;;\n\nlet tr_78 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 19;\n advance_eol state;\n stack\n;;\n\nlet tr_eoi_00 state stack = eps_eoi_check state stack\nlet tr_eoi_01 state _stack = raise state ~at_eof:true Automaton_in_error_state\nlet tr_eoi_02 state _stack = raise state ~at_eof:true Unexpected_character_after_cr\n\nlet tr_eoi_03 state stack =\n let stack = eps_push_atom state stack in\n eps_eoi_check state stack\n;;\n\nlet tr_eoi_04 state stack =\n let stack = end_line_comment state stack in\n eps_eoi_check state stack\n;;\n\nlet tr_eoi_05 state stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n eps_eoi_check state stack\n;;\n\nlet tr_eoi_06 state _stack = raise state ~at_eof:true Unterminated_quoted_string\nlet tr_eoi_07 state _stack = raise state ~at_eof:true Unterminated_block_comment\n\nlet transitions =\n [| tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_01\n ; tr_02\n ; tr_00\n ; tr_01\n ; tr_03\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_01\n ; tr_00\n ; tr_04\n ; tr_05\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_06\n ; tr_07\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_08\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_09\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_02\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_14\n ; tr_12\n ; tr_13\n ; tr_15\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_12\n ; tr_16\n ; tr_17\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_18\n ; tr_19\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_20\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_21\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_14\n ; tr_12\n ; tr_13\n ; tr_15\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_12\n ; tr_16\n ; tr_17\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_18\n ; tr_19\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_20\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_22\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_14\n ; tr_12\n ; tr_13\n ; tr_15\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_12\n ; tr_16\n ; tr_22\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_18\n ; tr_19\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_20\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_21\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_24\n ; tr_23\n ; tr_23\n ; tr_25\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_27\n ; tr_28\n ; tr_26\n ; tr_27\n ; tr_29\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_27\n ; tr_26\n ; tr_30\n ; tr_31\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_32\n ; tr_33\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_34\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_35\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_37\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_38\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_39\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_41\n ; tr_40\n ; tr_40\n ; tr_42\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_44\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_41\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_46\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_47\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_55\n ; tr_56\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_55\n ; tr_54\n ; tr_57\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_58\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_60\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_61\n ; tr_62\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_63\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_60\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_61\n ; tr_64\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_63\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_60\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_61\n ; tr_62\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_35\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_65\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_59\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_66\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_67\n ; tr_61\n ; tr_61\n ; tr_68\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_70\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_67\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_72\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_73\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_77\n ; tr_78\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_77\n ; tr_71\n ; tr_72\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_73\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n |]\n;;\n\nlet transitions_eoi =\n [| tr_eoi_00\n ; tr_eoi_01\n ; tr_eoi_02\n ; tr_eoi_03\n ; tr_eoi_03\n ; tr_eoi_03\n ; tr_eoi_04\n ; tr_eoi_05\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n |]\n;;\n\nlet old_parser_approx_cont_states : Old_parser_cont_state.t array =\n [| Parsing_toplevel_whitespace\n ; Parsing_toplevel_whitespace\n ; Parsing_nested_whitespace\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_toplevel_whitespace\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n |]\n;;\n\n(*$*)\n\nlet feed (type u s) (state : (u, s) state) char (stack : s) : s =\n let idx = (automaton_state state lsl 8) lor Char.code char in\n (* We need an Obj.magic as the type of the array can't be generalized.\n This problem will go away when we get immutable arrays. *)\n let magic\n : ((u', s') state -> char -> s' -> s') array\n -> ((u, s) state -> char -> s -> s) array\n =\n Obj.magic\n in\n (magic transitions).(idx) state char stack\n[@@inline always]\n;;\n\nlet feed_eoi (type u s) (state : (u, s) state) (stack : s) : s =\n let magic : ((u', s') state -> s' -> s') array -> ((u, s) state -> s -> s) array =\n Obj.magic\n in\n let stack = (magic transitions_eoi).(automaton_state state) state stack in\n set_error_state state;\n stack\n;;\n\nlet old_parser_cont_state state : Old_parser_cont_state.t =\n match context state with\n | Sexp_comment -> Parsing_sexp_comment\n | Sexp ->\n (match\n old_parser_approx_cont_states.(automaton_state state), has_unclosed_paren state\n with\n | Parsing_toplevel_whitespace, true -> Parsing_list\n | s, _ -> s)\n;;\n","open! Import\ninclude Kind_intf\n\nlet create (type stack state) (module Stack : Stack with type t = stack) kind\n : (module S with type Stack.t = stack and type state = state)\n =\n (module struct\n module Stack = Stack\n\n type nonrec state = state\n\n let kind = kind\n end)\n;;\n\nmodule Sexp = (val create (module Automaton_stack) Sexp)\nmodule Sexp_with_positions = (val create (module Automaton_stack) Sexp_with_positions)\nmodule Positions = (val create (module Automaton_stack.Just_positions) Positions)\nmodule Cst = (val create (module Automaton_stack.For_cst) Cst)\n","open! Import\n\nlet rec feed_substring_unsafe str state stack i stop =\n if i < stop\n then (\n let c = String.unsafe_get str i in\n let stack = Parser_automaton.feed state c stack in\n feed_substring_unsafe str state stack (i + 1) stop)\n else stack\n;;\n\nlet rec feed_subbytes_unsafe str state stack i stop =\n if i < stop\n then (\n let c = Bytes.unsafe_get str i in\n let stack = Parser_automaton.feed state c stack in\n feed_subbytes_unsafe str state stack (i + 1) stop)\n else stack\n;;\n\nlet feed_substring state str ~pos ~len stack =\n let str_len = String.length str in\n if pos < 0 || len < 0 || pos > str_len - len then invalid_arg \"Parsexp.feed_substring\";\n feed_substring_unsafe str state stack pos (pos + len)\n;;\n\nlet feed_subbytes state str ~pos ~len stack =\n let str_len = Bytes.length str in\n if pos < 0 || len < 0 || pos > str_len - len then invalid_arg \"Parsexp.feed_subbytes\";\n feed_subbytes_unsafe str state stack pos (pos + len)\n;;\n\nlet feed_string state str stack =\n feed_substring_unsafe str state stack 0 (String.length str)\n;;\n\nlet feed_bytes state str stack =\n feed_subbytes_unsafe str state stack 0 (Bytes.length str)\n;;\n","open! Import\ninclude Parser_intf\n\n\nmodule Make (Kind : Kind.S) (Mode : Mode(Kind).S) :\n S\n with type parsed_value = Mode.parsed_value\n with type State.t = (Kind.state, Kind.Stack.t) A.state\n with module Stack = Kind.Stack = struct\n type parsed_value = Mode.parsed_value\n\n module Stack = Kind.Stack\n\n module State = struct\n type t = (Kind.state, Kind.Stack.t) A.state\n\n let create ?pos () = A.new_state ?initial_pos:pos Mode.mode Kind.kind\n let reset = A.reset\n let offset = A.offset\n let line = A.line\n let column = A.column\n let position t : Positions.pos = { offset = offset t; line = line t; col = column t }\n let stop state = A.set_error_state state\n end\n\n let feed = A.feed\n let feed_eoi state stack = Mode.make_value state (A.feed_eoi state stack)\n let feed_substring = Automaton_helpers.feed_substring\n let feed_string = Automaton_helpers.feed_string\n let feed_subbytes = Automaton_helpers.feed_subbytes\n let feed_bytes = Automaton_helpers.feed_bytes\n\n let parse_string_exn str =\n let state = State.create () in\n feed_eoi state (feed_string state str Kind.Stack.empty)\n ;;\n\n let parse_string str =\n match parse_string_exn str with\n | x -> Ok x\n | exception Parse_error.Parse_error e -> Error e\n ;;\nend\n\nmodule Make_eager (Kind : Kind.S) (Mode : Mode_eager(Kind).S) :\n S_eager\n with type parsed_value = Mode.parsed_value\n with type State.t = (Kind.state, Kind.Stack.t) A.state\n with module Stack = Kind.Stack = struct\n type parsed_value = Mode.parsed_value\n\n module Stack = Kind.Stack\n\n module State = struct\n module Read_only = struct\n type t = (Kind.state, Kind.Stack.t) A.state\n\n let offset = A.offset\n let line = A.line\n let column = A.column\n\n let position t : Positions.pos =\n { offset = offset t; line = line t; col = column t }\n ;;\n end\n\n include Read_only\n\n let create ?pos ?(no_sexp_is_error = false) f =\n let got_sexp state stack =\n let parsed_value = Mode.make_value state stack in\n f state parsed_value;\n Stack.empty\n in\n A.new_state ?initial_pos:pos (Eager { got_sexp; no_sexp_is_error }) Kind.kind\n ;;\n\n let reset = A.reset\n let stop t = A.set_error_state t\n let old_parser_cont_state t = Parser_automaton.old_parser_cont_state t\n end\n\n let feed = A.feed\n let feed_eoi state stack = ignore (A.feed_eoi state stack : Stack.t)\n let feed_substring = Automaton_helpers.feed_substring\n let feed_string = Automaton_helpers.feed_string\n let feed_subbytes = Automaton_helpers.feed_subbytes\n let feed_bytes = Automaton_helpers.feed_bytes\n\n module Lexbuf_consumer = struct\n type t = State.t\n\n exception Got_sexp of parsed_value * Positions.pos\n\n let got_sexp state parsed_value =\n raise_notrace (Got_sexp (parsed_value, State.position state))\n ;;\n\n let create () = State.create got_sexp\n\n let pos_of_lexbuf lexbuf =\n let p = lexbuf.Lexing.lex_curr_p in\n { Positions.line = p.pos_lnum; col = p.pos_cnum - p.pos_bol; offset = p.pos_cnum }\n ;;\n\n let update_lexbuf (lexbuf : Lexing.lexbuf) (pos : Positions.pos) =\n let p = pos.offset - lexbuf.lex_abs_pos in\n lexbuf.lex_curr_pos <- p;\n lexbuf.lex_start_pos <- p;\n lexbuf.lex_curr_p\n <- { lexbuf.lex_curr_p with\n pos_lnum = pos.line\n ; pos_cnum = pos.offset\n ; pos_bol = pos.offset - pos.col\n }\n ;;\n\n let rec feed_lexbuf t (lexbuf : Lexing.lexbuf) stack =\n let stack =\n feed_subbytes\n t\n lexbuf.lex_buffer\n stack\n ~pos:lexbuf.lex_curr_pos\n ~len:(lexbuf.lex_buffer_len - lexbuf.lex_curr_pos)\n in\n lexbuf.lex_curr_pos <- lexbuf.lex_buffer_len;\n lexbuf.lex_start_pos <- lexbuf.lex_buffer_len;\n if not lexbuf.lex_eof_reached\n then (\n lexbuf.refill_buff lexbuf;\n feed_lexbuf t lexbuf stack)\n else feed_eoi t stack\n ;;\n\n let parse_gen t (lexbuf : Lexing.lexbuf) =\n A.reset t ~pos:(pos_of_lexbuf lexbuf);\n match feed_lexbuf t lexbuf Stack.empty with\n | () ->\n update_lexbuf lexbuf (State.position t);\n None\n | exception Got_sexp (parsed_value, pos) ->\n update_lexbuf lexbuf pos;\n Some parsed_value\n | exception exn ->\n update_lexbuf lexbuf (State.position t);\n raise exn\n ;;\n\n let set_no_sexp_is_error t x =\n match A.mode t with\n | Eager e -> e.no_sexp_is_error <- x\n | _ -> assert false\n ;;\n\n let parse t lexbuf =\n set_no_sexp_is_error t true;\n match parse_gen t lexbuf with\n | Some x -> x\n | None -> failwith \"Parsexp.parse_gen: None\"\n ;;\n\n let parse_opt t lexbuf =\n set_no_sexp_is_error t false;\n parse_gen t lexbuf\n ;;\n end\nend\n","open! Import\ninclude Conv_intf\n\nmodule Make\n (Mode : Mode)\n (Sexp_parser : Parser.S with type parsed_value = Mode.parsed_sexp)\n (Positions_parser : Parser.S with type parsed_value = Positions.t) =\nstruct\n let reraise positions parsed_value ~sub user_exn =\n let location = Mode.find positions parsed_value ~sub in\n Of_sexp_error.raise ~user_exn ~sub_sexp:sub ~location\n ;;\n\n let parse_string_exn str f =\n let parsed_value = Sexp_parser.parse_string_exn str in\n match Mode.apply_f parsed_value ~f with\n | x -> x\n | exception Sexp.Of_sexp_error (exn, sub) ->\n let positions = Positions_parser.parse_string_exn str in\n reraise positions parsed_value exn ~sub\n ;;\n\n let parse_string str f : (_, Conv_error.t) result =\n match parse_string_exn str f with\n | x -> Ok x\n | exception Parse_error.Parse_error e -> Error (Parse_error e)\n | exception Of_sexp_error.Of_sexp_error e -> Error (Of_sexp_error e)\n ;;\n\n let conv_exn (parsed_value, positions) f =\n match Mode.apply_f parsed_value ~f with\n | x -> x\n | exception Sexp.Of_sexp_error (exn, sub) -> reraise positions parsed_value exn ~sub\n ;;\n\n let conv x f =\n match conv_exn x f with\n | x -> Ok x\n | exception Of_sexp_error.Of_sexp_error e -> Error e\n ;;\n\n let conv_combine result f : (_, Conv_error.t) result =\n match result with\n | Error e -> Error (Parse_error e)\n | Ok x ->\n (match conv x f with\n | Ok _ as r -> r\n | Error e -> Error (Of_sexp_error e))\n ;;\nend\n","(* Sexp: Module for handling S-expressions (I/O, etc.) *)\n\nopen Format\nopen Bigarray\nmodule Sexplib = Sexplib0\nmodule Conv = Sexplib.Sexp_conv\n\n(* conv.ml depends on us so we can only use this module *)\n\ninclude Type\n\ntype bigstring = (char, int8_unsigned_elt, c_layout) Array1.t\n\ninclude (\n Sexplib.Sexp :\n module type of struct\n include Sexplib.Sexp\n end\n with type t := t)\n\ninclude Private\n\n(* Output of S-expressions to I/O-channels *)\n\nlet with_new_buffer oc f =\n let buf = buffer () in\n f buf;\n Buffer.output_buffer oc buf\n;;\n\nlet output_hum oc sexp = with_new_buffer oc (fun buf -> to_buffer_hum sexp ~buf)\n\nlet output_hum_indent indent oc sexp =\n with_new_buffer oc (fun buf -> to_buffer_hum ~indent sexp ~buf)\n;;\n\nlet output_mach oc sexp = with_new_buffer oc (fun buf -> to_buffer_mach sexp ~buf)\nlet output = output_mach\n\n(* Output of S-expressions to file *)\n\n(* The temp file functions in the OCaml Filename module do not support\n permissions. But opening a file with given permissions is different\n from opening it and chmoding it to these permissions, because the umask\n is taken in account. Under Unix there's no easy way to get the umask in\n a thread-safe way. *)\nmodule Tmp_file = struct\n let prng = ref None\n\n let temp_file_name prefix suffix =\n let rand_state =\n match !prng with\n | Some v -> v\n | None ->\n let ret = Random.State.make_self_init () in\n prng := Some ret;\n ret\n in\n let rnd = Random.State.bits rand_state land 0xFFFFFF in\n Printf.sprintf \"%s%06x%s\" prefix rnd suffix\n ;;\n\n (* Keep the permissions loose. Sexps are usually shared and rarely private*)\n let open_temp_file ?(perm = 0o666) prefix suffix =\n let rec try_name counter =\n let name = temp_file_name prefix suffix in\n try\n let oc =\n open_out_gen [ Open_wronly; Open_creat; Open_excl; Open_text ] perm name\n in\n name, oc\n with\n | Sys_error _ as e -> if counter >= 1000 then raise e else try_name (counter + 1)\n in\n try_name 0\n ;;\nend\n\nlet save_of_output ?perm output_function file sexp =\n let tmp_name, oc = Tmp_file.open_temp_file ?perm file \"tmp\" in\n (try\n output_function oc sexp;\n close_out oc\n with\n | e ->\n close_out_noerr oc;\n (try Sys.remove tmp_name with\n | _ -> ());\n raise e);\n Sys.rename tmp_name file\n;;\n\nlet output_sexp_nl do_output oc sexp =\n do_output oc sexp;\n output_string oc \"\\n\"\n;;\n\nlet save_hum ?perm file sexp = save_of_output ?perm (output_sexp_nl output_hum) file sexp\nlet save_mach ?perm file sexp = save_of_output ?perm output_mach file sexp\nlet save = save_mach\nlet output_sexps_nl do_output oc sexps = List.iter (output_sexp_nl do_output oc) sexps\n\nlet save_sexps_hum ?perm file sexps =\n save_of_output ?perm (output_sexps_nl output_hum) file sexps\n;;\n\nlet save_sexps_mach ?perm file sexps =\n save_of_output ?perm (output_sexps_nl output_mach) file sexps\n;;\n\nlet save_sexps = save_sexps_mach\n\n(* Scan functions *)\n\nlet scan_sexp ?buf lexbuf = Parser.sexp (Lexer.main ?buf) lexbuf\nlet scan_sexp_opt ?buf lexbuf = Parser.sexp_opt (Lexer.main ?buf) lexbuf\nlet scan_sexps ?buf lexbuf = Parser.sexps (Lexer.main ?buf) lexbuf\nlet scan_rev_sexps ?buf lexbuf = Parser.rev_sexps (Lexer.main ?buf) lexbuf\n\nlet get_main_buf buf =\n let buf =\n match buf with\n | None -> Buffer.create 128\n | Some buf -> buf\n in\n Lexer.main ~buf\n;;\n\nlet scan_fold_sexps ?buf ~f ~init lexbuf =\n let main = get_main_buf buf in\n let rec loop acc =\n match Parser.sexp_opt main lexbuf with\n | None -> acc\n | Some sexp -> loop (f acc sexp)\n in\n loop init\n;;\n\nlet scan_iter_sexps ?buf ~f lexbuf =\n scan_fold_sexps ?buf lexbuf ~init:() ~f:(fun () sexp -> f sexp)\n;;\n\nlet scan_sexps_conv ?buf ~f lexbuf =\n let coll acc sexp = f sexp :: acc in\n List.rev (scan_fold_sexps ?buf ~f:coll ~init:[] lexbuf)\n;;\n\nlet sexp_conversion_error_message ?containing_sexp ?location ?invalid_sexp () ~exn : t =\n List\n (List.concat\n [ [ Atom \"Of_sexp_error\" ]\n ; (match location with\n | None -> []\n | Some x -> [ Atom x ])\n ; [ (match exn with\n | Failure x -> Atom x\n | _ -> Conv.sexp_of_exn exn)\n ]\n ; (match invalid_sexp with\n | None -> []\n | Some x -> [ List [ Atom \"invalid_sexp\"; x ] ])\n ; (match containing_sexp with\n | None -> []\n | Some x -> [ List [ Atom \"containing_sexp\"; x ] ])\n ])\n;;\n\n(* Partial parsing *)\n\nmodule Annot = struct\n type pos = Parsexp.Positions.pos =\n { line : int\n ; col : int\n ; offset : int\n }\n\n type range = Parsexp.Positions.range =\n { start_pos : pos\n ; end_pos : pos\n }\n\n type t =\n | Atom of range * Type.t\n | List of range * t list * Type.t\n\n type 'a conv =\n [ `Result of 'a\n | `Error of exn * t\n ]\n\n exception Conv_exn of string * exn\n\n let () =\n Conv.Exn_converter.add ~finalise:false [%extension_constructor Conv_exn] (function\n | Conv_exn (location, exn) -> sexp_conversion_error_message () ~location ~exn\n | _ -> assert false)\n ;;\n\n type stack =\n { mutable positions : pos list\n ; mutable stack : t list list\n }\n\n let get_sexp = function\n | Atom (_, sexp) | List (_, _, sexp) -> sexp\n ;;\n\n let get_range = function\n | Atom (range, _) | List (range, _, _) -> range\n ;;\n\n let sexp_of_conv sexp_of_a = function\n | `Result a -> Type.List [ Atom \"Result\"; a |> sexp_of_a ]\n | `Error (exn, t) ->\n List [ Atom \"Error\"; List [ exn |> Conv.sexp_of_exn; t |> get_sexp ] ]\n ;;\n\n exception Annot_sexp of t\n\n let find_sexp annot_sexp sexp =\n let rec loop annot_sexp =\n match annot_sexp with\n | (Atom (_, sub_sexp) | List (_, _, sub_sexp)) when sexp == sub_sexp ->\n raise (Annot_sexp annot_sexp)\n | List (_, annots, _) -> List.iter loop annots\n | Atom _ -> ()\n in\n try\n loop annot_sexp;\n None\n with\n | Annot_sexp res -> Some res\n ;;\nend\n\nlet () =\n Conv.Exn_converter.add ~finalise:false [%extension_constructor Of_sexp_error] (function\n | Of_sexp_error (Annot.Conv_exn (location, exn), invalid_sexp) ->\n sexp_conversion_error_message () ~location ~invalid_sexp ~exn\n | Of_sexp_error (exn, invalid_sexp) ->\n sexp_conversion_error_message () ~invalid_sexp ~exn\n | _ ->\n (* Reaching this branch indicates a bug in sexplib. *)\n assert false)\n;;\n\nmodule Parse_pos = struct\n type t =\n { mutable text_line : int\n ; mutable text_char : int\n ; mutable global_offset : int\n ; mutable buf_pos : int\n }\n\n let create ?(text_line = 1) ?(text_char = 0) ?(buf_pos = 0) ?(global_offset = 0) () =\n let fail msg = failwith (\"Sexplib.Sexp.Parse_pos.create: \" ^ msg) in\n if text_line < 1\n then fail \"text_line < 1\"\n else if text_char < 0\n then fail \"text_char < 0\"\n else if global_offset < 0\n then fail \"global_offset < 0\"\n else if buf_pos < 0\n then fail \"buf_pos < 0\"\n else { text_line; text_char; global_offset; buf_pos }\n ;;\n\n let with_buf_pos t buf_pos = { t with buf_pos }\nend\n\nmodule Cont_state = Parsexp.Old_parser_cont_state\n\ntype ('a, 't) parse_result =\n | Done of 't * Parse_pos.t\n | Cont of Cont_state.t * ('a, 't) parse_fun\n\nand ('a, 't) parse_fun = pos:int -> len:int -> 'a -> ('a, 't) parse_result\n\ntype 't parse_state = { parse_pos : Parse_pos.t }\n\ntype parse_error =\n { err_msg : string\n ; parse_state : [ `Sexp of t list list parse_state | `Annot of Annot.stack parse_state ]\n }\n\nexception Parse_error of parse_error\n\nlet () =\n Conv.Exn_converter.add ~finalise:false [%extension_constructor Parse_error] (function\n | Parse_error pe ->\n let ppos =\n match pe.parse_state with\n | `Sexp { parse_pos } | `Annot { parse_pos } -> parse_pos\n in\n List\n [ Atom \"Sexplib.Sexp.Parse_error\"\n ; List\n [ List [ Atom \"err_msg\"; Atom pe.err_msg ]\n ; List [ Atom \"text_line\"; Conv.sexp_of_int ppos.Parse_pos.text_line ]\n ; List [ Atom \"text_char\"; Conv.sexp_of_int ppos.Parse_pos.text_char ]\n ; List\n [ Atom \"global_offset\"; Conv.sexp_of_int ppos.Parse_pos.global_offset ]\n ; List [ Atom \"buf_pos\"; Conv.sexp_of_int ppos.Parse_pos.buf_pos ]\n ]\n ]\n | _ -> assert false)\n;;\n\nmodule Parser_output : sig\n module type T = sig\n module Impl : Parsexp.Eager_parser\n\n type output\n\n exception Found of output\n\n val raise_found : Impl.State.Read_only.t -> Impl.parsed_value -> unit\n end\n\n module Bare_sexp : T with type output = Type.t\n module Annotated_sexp : T with type output = Annot.t\nend = struct\n module type T = sig\n module Impl : Parsexp.Eager_parser\n\n type output\n\n exception Found of output\n\n val raise_found : Impl.State.Read_only.t -> Impl.parsed_value -> unit\n end\n\n module I = Parsexp.Positions.Iterator\n\n let rec annotate_sexp sexp iter =\n match sexp with\n | Type.Atom _ ->\n let start_pos = I.advance_exn iter ~skip:0 in\n let end_pos = I.advance_exn iter ~skip:0 in\n Annot.Atom ({ start_pos; end_pos }, sexp)\n | Type.List l ->\n let start_pos = I.advance_exn iter ~skip:0 in\n let annot = annotate_sexp_list l iter in\n let end_pos = I.advance_exn iter ~skip:0 in\n Annot.List ({ start_pos; end_pos }, annot, sexp)\n\n and annotate_sexp_list sexps iter =\n List.rev (List.rev_map (fun sexp -> annotate_sexp sexp iter) sexps)\n ;;\n\n module Bare_sexp = struct\n module Impl = Parsexp.Eager\n\n type output = Type.t\n\n exception Found of output\n\n let raise_found _state sexp = raise_notrace (Found sexp)\n end\n\n module Annotated_sexp = struct\n module Impl = Parsexp.Eager_and_positions\n\n type output = Annot.t\n\n exception Found of output\n\n let raise_found _state (sexp, positions) =\n let annot = annotate_sexp sexp (I.create positions) in\n raise_notrace (Found annot)\n ;;\n end\nend\n\nmodule Make_parser (T : sig\n include Parser_output.T\n\n type input\n\n val length : input -> int\n\n val unsafe_feed_loop\n : Impl.State.t\n -> Impl.Stack.t\n -> input\n -> max_pos:int\n -> pos:int\n -> Impl.Stack.t\n end) : sig\n val parse\n : ?parse_pos:Parse_pos.t\n -> ?len:int\n -> T.input\n -> (T.input, T.output) parse_result\nend = struct\n let parse_pos_of_state state buf_pos =\n { Parse_pos.text_line = T.Impl.State.line state\n ; Parse_pos.text_char = T.Impl.State.column state\n ; Parse_pos.global_offset = T.Impl.State.offset state\n ; Parse_pos.buf_pos\n }\n ;;\n\n let check_str_bounds ~pos ~len str =\n if pos < 0 then invalid_arg \"parse: pos < 0\";\n if len < 0 then invalid_arg \"parse: len < 0\";\n let str_len = T.length str in\n let pos_len = pos + len in\n if pos_len > str_len then invalid_arg \"parse: pos + len > str_len\";\n pos_len - 1\n ;;\n\n let raise_parse_error state pos msg =\n let parse_state = { parse_pos = parse_pos_of_state state pos } in\n let parse_error = { err_msg = msg; parse_state = `Sexp parse_state } in\n raise (Parse_error parse_error)\n ;;\n\n let handle_parsexp_error state pos e =\n let msg = Parsexp.Parse_error.message e in\n match Parsexp.Parse_error.Private.old_parser_exn e with\n | `Parse_error -> raise_parse_error state pos msg\n | `Failure -> failwith msg\n ;;\n\n let rec run_feed_loop state stack ~pos ~len str =\n let max_pos = check_str_bounds ~pos ~len str in\n let previous_offset = T.Impl.State.offset state in\n match T.unsafe_feed_loop state stack str ~max_pos ~pos with\n | stack -> mk_cont_state state stack\n | exception T.Found result ->\n let offset = T.Impl.State.offset state in\n let next_pos = pos + (offset - previous_offset) in\n Done (result, parse_pos_of_state state next_pos)\n | exception Parsexp.Parse_error.Parse_error err ->\n handle_parsexp_error\n state\n (pos + (T.Impl.State.offset state - previous_offset))\n err\n\n and mk_cont_state state stack =\n let parse_fun =\n let used_ref = ref false in\n fun ~pos ~len str ->\n if !used_ref\n then failwith \"Sexplib.Sexp: parser continuation called twice\"\n else (\n used_ref := true;\n run_feed_loop state stack ~pos ~len str)\n in\n let cont_state = T.Impl.State.old_parser_cont_state state in\n Cont (cont_state, parse_fun)\n ;;\n\n let parse ?(parse_pos = Parse_pos.create ()) ?len str =\n let pos, buf_pos =\n let { Parse_pos.text_line; text_char; global_offset; buf_pos } = parse_pos in\n ( { Parsexp.Positions.line = text_line; col = text_char; offset = global_offset }\n , buf_pos )\n in\n let state = T.Impl.State.create ~pos ~no_sexp_is_error:false T.raise_found in\n let stack = T.Impl.Stack.empty in\n let len =\n match len with\n | Some x -> x\n | None -> T.length str - buf_pos\n in\n run_feed_loop state stack str ~pos:buf_pos ~len\n ;;\nend\n[@@inline always]\n\nmodule String_single_sexp = Make_parser (struct\n include Parser_output.Bare_sexp\n\n type input = string\n\n let length = String.length\n\n let rec unsafe_feed_loop state stack str ~max_pos ~pos =\n if pos <= max_pos\n then (\n let stack = Impl.feed state (String.unsafe_get str pos) stack in\n unsafe_feed_loop state stack str ~max_pos ~pos:(pos + 1))\n else stack\n ;;\n end)\n\nlet parse_str = String_single_sexp.parse\nlet parse = String_single_sexp.parse\n\nmodule String_single_annot = Make_parser (struct\n include Parser_output.Annotated_sexp\n\n type input = string\n\n let length = String.length\n\n let rec unsafe_feed_loop state stack str ~max_pos ~pos =\n if pos <= max_pos\n then (\n let stack = Impl.feed state (String.unsafe_get str pos) stack in\n unsafe_feed_loop state stack str ~max_pos ~pos:(pos + 1))\n else stack\n ;;\n end)\n\nlet parse_str_annot = String_single_annot.parse\n\nmodule Bigstring_single_sexp = Make_parser (struct\n include Parser_output.Bare_sexp\n\n type input = bigstring\n\n let length = Array1.dim\n\n let rec unsafe_feed_loop state stack (str : input) ~max_pos ~pos =\n if pos <= max_pos\n then (\n let stack = Impl.feed state (Array1.unsafe_get str pos) stack in\n unsafe_feed_loop state stack str ~max_pos ~pos:(pos + 1))\n else stack\n ;;\n end)\n\nlet parse_bigstring = Bigstring_single_sexp.parse\n\nmodule Bigstring_single_annot = Make_parser (struct\n include Parser_output.Annotated_sexp\n\n type input = bigstring\n\n let length = Array1.dim\n\n let rec unsafe_feed_loop state stack (str : input) ~max_pos ~pos =\n if pos <= max_pos\n then (\n let stack = Impl.feed state (Array1.unsafe_get str pos) stack in\n unsafe_feed_loop state stack str ~max_pos ~pos:(pos + 1))\n else stack\n ;;\n end)\n\nlet parse_bigstring_annot = Bigstring_single_annot.parse\n\n(* Input functions *)\n\nlet mk_this_parse ?parse_pos my_parse =\n ();\n fun ~pos ~len str ->\n let parse_pos =\n match parse_pos with\n | None -> Parse_pos.create ~buf_pos:pos ()\n | Some parse_pos ->\n parse_pos.Parse_pos.buf_pos <- pos;\n parse_pos\n in\n my_parse ?parse_pos:(Some parse_pos) ?len:(Some len) str\n;;\n\n(* [ws_buf] must contain a single space character *)\nlet feed_end_of_input ~this_parse ~ws_buf =\n (* When parsing atoms, the incremental parser cannot tell whether\n it is at the end until it hits whitespace. We therefore feed it\n one space to determine whether it is finished. *)\n match this_parse ~pos:0 ~len:1 ws_buf with\n | Done (sexp, _) -> Ok sexp\n | Cont (cont_state, _) -> Error cont_state\n;;\n\nlet gen_input_sexp my_parse ?parse_pos ic =\n let buf = Bytes.create 1 in\n let rec loop this_parse =\n match input_char ic with\n | exception End_of_file ->\n (match feed_end_of_input ~this_parse ~ws_buf:\" \" with\n | Ok sexp -> sexp\n | Error _ -> raise End_of_file)\n | c ->\n Bytes.set buf 0 c;\n (match this_parse ~pos:0 ~len:1 (Bytes.unsafe_to_string buf) with\n | Done (sexp, _) -> sexp\n | Cont (_, this_parse) -> loop this_parse)\n in\n loop (mk_this_parse ?parse_pos my_parse)\n;;\n\nlet input_sexp ?parse_pos ic = gen_input_sexp parse ?parse_pos ic\n\nlet gen_input_rev_sexps my_parse ~ws_buf ?parse_pos ?(buf = Bytes.create 8192) ic =\n let rev_sexps_ref = ref [] in\n let buf_len = Bytes.length buf in\n let rec loop this_parse ~pos ~len =\n if len > 0\n then (\n match this_parse ~pos ~len (Bytes.unsafe_to_string buf) with\n | Done (sexp, ({ Parse_pos.buf_pos; _ } as parse_pos)) ->\n rev_sexps_ref := sexp :: !rev_sexps_ref;\n let n_parsed = buf_pos - pos in\n let this_parse = mk_this_parse ~parse_pos my_parse in\n if n_parsed = len\n then (\n let new_len = input ic buf 0 buf_len in\n loop this_parse ~pos:0 ~len:new_len)\n else loop this_parse ~pos:buf_pos ~len:(len - n_parsed)\n | Cont (_, this_parse) -> loop this_parse ~pos:0 ~len:(input ic buf 0 buf_len))\n else (\n match feed_end_of_input ~this_parse ~ws_buf with\n | Ok sexp -> sexp :: !rev_sexps_ref\n | Error Parsing_toplevel_whitespace -> !rev_sexps_ref\n | Error cont_state ->\n failwith\n (\"Sexplib.Sexp.input_rev_sexps: reached EOF while in state \"\n ^ Cont_state.to_string cont_state))\n in\n let len = input ic buf 0 buf_len in\n let this_parse = mk_this_parse ?parse_pos my_parse in\n loop this_parse ~pos:0 ~len\n;;\n\nlet input_rev_sexps ?parse_pos ?buf ic =\n gen_input_rev_sexps parse ~ws_buf:\" \" ?parse_pos ?buf ic\n;;\n\nlet input_sexps ?parse_pos ?buf ic = List.rev (input_rev_sexps ?parse_pos ?buf ic)\n\n(* of_string and of_bigstring *)\n\nlet of_string_bigstring loc my_parse ws_buf get_len get_sub str =\n match my_parse ?parse_pos:None ?len:None str with\n | Done (sexp, parse_pos) ->\n (match my_parse ?parse_pos:(Some parse_pos) ?len:None str with\n | Done (_sexp2, _) ->\n failwith\n (sprintf\n \"Sexplib.Sexp.%s: got multiple S-expressions where only one was expected.\"\n loc)\n | Cont (Cont_state.Parsing_toplevel_whitespace, _) -> sexp\n | Cont (_, _) ->\n (* not using [feed_end_of_input] here means \"a b\" will end up here and not in\n \"multiple S-expressions\" branch, but it doesn't matter that much *)\n failwith\n (sprintf\n \"Sexplib.Sexp.%s: S-expression followed by data at position %d...\"\n loc\n parse_pos.buf_pos))\n | Cont (_, this_parse) ->\n (match feed_end_of_input ~this_parse ~ws_buf with\n | Ok sexp -> sexp\n | Error cont_state ->\n let cont_state_str = Cont_state.to_string cont_state in\n failwith\n (sprintf\n \"Sexplib.Sexp.%s: incomplete S-expression while in state %s: %s\"\n loc\n cont_state_str\n (get_sub str 0 (get_len str))))\n;;\n\nlet of_string str =\n of_string_bigstring \"of_string\" parse \" \" String.length String.sub str\n;;\n\nlet get_bstr_sub_str bstr pos len =\n let str = Bytes.create len in\n for i = 0 to len - 1 do\n Bytes.set str i bstr.{pos + i}\n done;\n Bytes.unsafe_to_string str\n;;\n\nlet bstr_ws_buf = Array1.create char c_layout 1\nlet () = bstr_ws_buf.{0} <- ' '\n\nlet of_bigstring bstr =\n of_string_bigstring\n \"of_bigstring\"\n parse_bigstring\n bstr_ws_buf\n Array1.dim\n get_bstr_sub_str\n bstr\n;;\n\n(* Loading *)\n\nlet gen_load_rev_sexps input_rev_sexps ?buf file =\n let ic = open_in file in\n try\n let sexps = input_rev_sexps ?parse_pos:None ?buf ic in\n close_in ic;\n sexps\n with\n | exc ->\n close_in_noerr ic;\n raise exc\n;;\n\nlet load_rev_sexps ?buf file = gen_load_rev_sexps input_rev_sexps ?buf file\nlet load_sexps ?buf file = List.rev (load_rev_sexps ?buf file)\nlet gen_load_sexp_loc = \"Sexplib.Sexp.gen_load_sexp\"\n\nlet gen_load_sexp my_parse ?(strict = true) ?(buf = Bytes.create 8192) file =\n let buf_len = Bytes.length buf in\n let ic = open_in file in\n let rec loop this_parse =\n let len = input ic buf 0 buf_len in\n if len = 0\n then (\n match feed_end_of_input ~this_parse ~ws_buf:\" \" with\n | Ok sexp -> sexp\n | Error cont_state ->\n failwith\n (sprintf\n \"%s: EOF in %s while in state %s\"\n gen_load_sexp_loc\n file\n (Cont_state.to_string cont_state)))\n else (\n match this_parse ~pos:0 ~len (Bytes.unsafe_to_string buf) with\n | Done (sexp, ({ Parse_pos.buf_pos; _ } as parse_pos)) when strict ->\n let rec strict_loop this_parse ~pos ~len =\n match this_parse ~pos ~len (Bytes.unsafe_to_string buf) with\n | Done _ ->\n failwith\n (sprintf \"%s: more than one S-expression in file %s\" gen_load_sexp_loc file)\n | Cont (cont_state, this_parse) ->\n let len = input ic buf 0 buf_len in\n if len > 0\n then strict_loop this_parse ~pos:0 ~len\n else if cont_state = Cont_state.Parsing_toplevel_whitespace\n then sexp\n else\n failwith\n (sprintf\n \"%s: %s in state %s loading file %s\"\n gen_load_sexp_loc\n \"additional incomplete data\"\n (Cont_state.to_string cont_state)\n file)\n in\n let this_parse = mk_this_parse ~parse_pos my_parse in\n strict_loop this_parse ~pos:buf_pos ~len:(len - buf_pos)\n | Done (sexp, _) -> sexp\n | Cont (_, this_parse) -> loop this_parse)\n in\n try\n let sexp = loop (mk_this_parse my_parse) in\n close_in ic;\n sexp\n with\n | exc ->\n close_in_noerr ic;\n raise exc\n;;\n\nlet load_sexp ?strict ?buf file = gen_load_sexp parse ?strict ?buf file\n\nmodule Annotated = struct\n include Annot\n\n let parse = parse_str_annot\n let parse_bigstring = parse_bigstring_annot\n\n let input_rev_sexps ?parse_pos ?buf ic =\n gen_input_rev_sexps parse ~ws_buf:\" \" ?parse_pos ?buf ic\n ;;\n\n let input_sexp ?parse_pos ic = gen_input_sexp parse ?parse_pos ic\n let input_sexps ?parse_pos ?buf ic = List.rev (input_rev_sexps ?parse_pos ?buf ic)\n\n let of_string str =\n of_string_bigstring \"Annotated.of_string\" parse \" \" String.length String.sub str\n ;;\n\n let of_bigstring bstr =\n of_string_bigstring\n \"Annotated.of_bigstring\"\n parse_bigstring\n bstr_ws_buf\n Array1.dim\n get_bstr_sub_str\n bstr\n ;;\n\n let load_rev_sexps ?buf file = gen_load_rev_sexps input_rev_sexps ?buf file\n let load_sexps ?buf file = List.rev (load_rev_sexps ?buf file)\n let load_sexp ?strict ?buf file = gen_load_sexp parse ?strict ?buf file\n\n let conv f annot_sexp =\n let sexp = get_sexp annot_sexp in\n try `Result (f sexp) with\n | Of_sexp_error (exc, bad_sexp) as e ->\n (match find_sexp annot_sexp bad_sexp with\n | None -> raise e\n | Some bad_annot_sexp -> `Error (exc, bad_annot_sexp))\n ;;\n\n let get_conv_exn ~file ~exc annot_sexp =\n let range = get_range annot_sexp in\n let { start_pos = { line; col; offset = _ }; end_pos = _ } = range in\n let loc = sprintf \"%s:%d:%d\" file line col in\n Of_sexp_error (Annot.Conv_exn (loc, exc), get_sexp annot_sexp)\n ;;\nend\n\nlet load_sexp_conv ?(strict = true) ?(buf = Bytes.create 8192) file f =\n let sexp = load_sexp ~strict ~buf file in\n try `Result (f sexp) with\n | Of_sexp_error _ -> Annotated.conv f (Annotated.load_sexp ~strict ~buf file)\n;;\n\nlet raise_conv_exn ~file = function\n | `Result res -> res\n | `Error (exc, annot_sexp) -> raise (Annotated.get_conv_exn ~file ~exc annot_sexp)\n;;\n\nlet load_sexp_conv_exn ?strict ?buf file f =\n raise_conv_exn ~file (load_sexp_conv ?strict ?buf file f)\n;;\n\nlet load_sexps_conv ?(buf = Bytes.create 8192) file f =\n let rev_sexps = load_rev_sexps ~buf file in\n try List.rev_map (fun sexp -> `Result (f sexp)) rev_sexps with\n | Of_sexp_error _ as e ->\n (match Annotated.load_rev_sexps ~buf file with\n | [] ->\n (* File is now empty - perhaps it was a temporary file handle? *)\n raise e\n | rev_annot_sexps ->\n List.rev_map (fun annot_sexp -> Annotated.conv f annot_sexp) rev_annot_sexps)\n;;\n\nlet load_sexps_conv_exn ?(buf = Bytes.create 8192) file f =\n let rev_sexps = load_rev_sexps ~buf file in\n try List.rev_map f rev_sexps with\n | Of_sexp_error _ as e ->\n (match Annotated.load_rev_sexps ~buf file with\n | [] ->\n (* File is now empty - perhaps it was a temporary file handle? *)\n raise e\n | rev_annot_sexps ->\n List.rev_map\n (fun annot_sexp -> raise_conv_exn ~file (Annotated.conv f annot_sexp))\n rev_annot_sexps)\n;;\n\nlet gen_of_string_conv of_string annot_of_string str f =\n let sexp = of_string str in\n try `Result (f sexp) with\n | Of_sexp_error _ -> Annotated.conv f (annot_of_string str)\n;;\n\nlet of_string_conv str f = gen_of_string_conv of_string Annotated.of_string str f\n\nlet of_bigstring_conv bstr f =\n gen_of_string_conv of_bigstring Annotated.of_bigstring bstr f\n;;\n\nmodule Of_string_conv_exn = struct\n type t =\n { exc : exn\n ; sexp : Type.t\n ; sub_sexp : Type.t\n }\n\n exception E of t\n\n let () =\n Conv.Exn_converter.add ~finalise:false [%extension_constructor E] (function\n | E osce ->\n sexp_conversion_error_message\n ()\n ~invalid_sexp:osce.sub_sexp\n ~exn:osce.exc\n ~containing_sexp:osce.sexp\n | _ -> assert false)\n ;;\nend\n\nlet gen_of_string_conv_exn of_string str f =\n let sexp = of_string str in\n try f sexp with\n | Of_sexp_error (exc, sub_sexp) ->\n raise (Of_string_conv_exn.E { Of_string_conv_exn.exc; sexp; sub_sexp })\n;;\n\nlet of_string_conv_exn str f = gen_of_string_conv_exn of_string str f\nlet of_bigstring_conv_exn bstr f = gen_of_string_conv_exn of_bigstring bstr f\n\n(* Utilities for automated type conversions *)\n\nlet unit = List []\n\nlet is_unit = function\n | List [] -> true\n | _ -> false\n;;\n\nexternal sexp_of_t : t -> t = \"%identity\"\nexternal t_of_sexp : t -> t = \"%identity\"\n\n(* Utilities for conversion error handling *)\n\ntype found =\n [ `Found\n | `Pos of int * found\n ]\n\ntype search_result =\n [ `Not_found\n | found\n ]\n\nlet rec search_physical sexp ~contained =\n if sexp == contained\n then `Found\n else (\n match sexp with\n | Atom _ -> `Not_found\n | List lst ->\n let rec loop i = function\n | [] -> `Not_found\n | h :: t ->\n let res = search_physical h ~contained in\n (match res with\n | `Not_found -> loop (i + 1) t\n | #found as found -> `Pos (i, found))\n in\n loop 0 lst)\n;;\n\nlet rec subst_found sexp ~subst = function\n | `Found -> subst\n | `Pos (pos, found) ->\n (match sexp with\n | Atom _ -> failwith \"Sexplib.Sexp.subst_found: atom when position requested\"\n | List lst ->\n let rec loop acc pos = function\n | [] -> failwith \"Sexplib.Sexp.subst_found: short list when position requested\"\n | h :: t when pos <> 0 -> loop (h :: acc) (pos - 1) t\n | h :: t -> List (List.rev_append acc (subst_found h ~subst found :: t))\n in\n loop [] pos lst)\n;;\n","open! Import\n\ntype t =\n | Parsing_toplevel_whitespace\n | Parsing_nested_whitespace\n | Parsing_atom\n | Parsing_list\n | Parsing_sexp_comment\n | Parsing_block_comment\n[@@deriving_inline sexp_of]\n\nlet sexp_of_t =\n (function\n | Parsing_toplevel_whitespace ->\n Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_toplevel_whitespace\"\n | Parsing_nested_whitespace -> Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_nested_whitespace\"\n | Parsing_atom -> Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_atom\"\n | Parsing_list -> Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_list\"\n | Parsing_sexp_comment -> Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_sexp_comment\"\n | Parsing_block_comment -> Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_block_comment\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet to_string t =\n match sexp_of_t t with\n | Atom s -> s\n | List _ -> failwith \"BUG: [sexp_of_t] returned a [List _]\"\n;;\n","open Printf\nopen Bigarray\ninclude Sexplib0.Sexp_conv\nopen Sexp\n\ntype bigstring = (char, int8_unsigned_elt, c_layout) Array1.t\ntype float32_vec = (float, float32_elt, fortran_layout) Array1.t\ntype float64_vec = (float, float64_elt, fortran_layout) Array1.t\ntype vec = float64_vec\ntype float32_mat = (float, float32_elt, fortran_layout) Array2.t\ntype float64_mat = (float, float64_elt, fortran_layout) Array2.t\ntype mat = float64_mat\n\nlet sexp_of_float_vec vec =\n let lst_ref = ref [] in\n for i = Array1.dim vec downto 1 do\n lst_ref := sexp_of_float vec.{i} :: !lst_ref\n done;\n List !lst_ref\n;;\n\nlet sexp_of_bigstring (bstr : bigstring) =\n let n = Array1.dim bstr in\n let str = Bytes.create n in\n for i = 0 to n - 1 do\n Bytes.set str i bstr.{i}\n done;\n Atom (Bytes.unsafe_to_string str)\n;;\n\nlet sexp_of_float32_vec (vec : float32_vec) = sexp_of_float_vec vec\nlet sexp_of_float64_vec (vec : float64_vec) = sexp_of_float_vec vec\nlet sexp_of_vec (vec : vec) = sexp_of_float_vec vec\n\nlet sexp_of_float_mat mat =\n let m = Array2.dim1 mat in\n let n = Array2.dim2 mat in\n let lst_ref = ref [] in\n (* It's surprising that we serialize [Fortran_layout] matrices in row-major order. I can\n only speculate that it was chosen for readability. The cache performance is\n irrelevant because people who care won't serialize to sexp. *)\n for row = n downto 1 do\n for col = m downto 1 do\n lst_ref := sexp_of_float mat.{col, row} :: !lst_ref\n done\n done;\n List (sexp_of_int m :: sexp_of_int n :: !lst_ref)\n;;\n\nlet sexp_of_float32_mat (mat : float32_mat) = sexp_of_float_mat mat\nlet sexp_of_float64_mat (mat : float64_mat) = sexp_of_float_mat mat\nlet sexp_of_mat (mat : mat) = sexp_of_float_mat mat\nlet bigstring_sexp_grammar : Sexplib0.Sexp.Private.Raw_grammar.t = Inline (Atom String)\n\nlet bigstring_of_sexp sexp =\n match sexp with\n | Atom str ->\n let len = String.length str in\n let bstr = Array1.create char c_layout len in\n for i = 0 to len - 1 do\n bstr.{i} <- str.[i]\n done;\n bstr\n | List _ -> of_sexp_error \"bigstring_of_sexp: atom needed\" sexp\n;;\n\nlet float_vec_of_sexp empty_float_vec create_float_vec sexp =\n match sexp with\n | List [] -> empty_float_vec\n | List lst ->\n let len = List.length lst in\n let res = create_float_vec len in\n let rec loop i = function\n | [] -> res\n | h :: t ->\n res.{i} <- float_of_sexp h;\n loop (i + 1) t\n in\n loop 1 lst\n | Atom _ -> of_sexp_error \"float_vec_of_sexp: list needed\" sexp\n;;\n\nlet create_float32_vec = Array1.create float32 fortran_layout\nlet create_float64_vec = Array1.create float64 fortran_layout\nlet empty_float32_vec = create_float32_vec 0\nlet empty_float64_vec = create_float64_vec 0\nlet float32_vec_of_sexp = float_vec_of_sexp empty_float32_vec create_float32_vec\nlet float64_vec_of_sexp = float_vec_of_sexp empty_float64_vec create_float64_vec\nlet vec_of_sexp = float_vec_of_sexp empty_float64_vec create_float64_vec\n\nlet vec_sexp_grammar : Sexplib0.Sexp.Private.Raw_grammar.t =\n Inline (List [ Many (Atom Float) ])\n;;\n\nlet float32_vec_sexp_grammar = vec_sexp_grammar\nlet float64_vec_sexp_grammar = vec_sexp_grammar\n\nlet check_too_much_data sexp data res =\n if data = [] then res else of_sexp_error \"float_mat_of_sexp: too much data\" sexp\n;;\n\nlet float_mat_of_sexp create_float_mat sexp =\n match sexp with\n | List (sm :: sn :: data) ->\n let m = int_of_sexp sm in\n let n = int_of_sexp sn in\n let res = create_float_mat m n in\n if m = 0 || n = 0\n then check_too_much_data sexp data res\n else (\n let rec loop_cols col data =\n let vec = Array2.slice_right res col in\n let rec loop_rows row = function\n | [] -> of_sexp_error \"float_mat_of_sexp: not enough data\" sexp\n | h :: t ->\n vec.{row} <- float_of_sexp h;\n if row = m\n then\n if col = n then check_too_much_data sexp t res else loop_cols (col + 1) t\n else loop_rows (row + 1) t\n in\n loop_rows 1 data\n in\n loop_cols 1 data)\n | List _ -> of_sexp_error \"float_mat_of_sexp: list too short\" sexp\n | Atom _ -> of_sexp_error \"float_mat_of_sexp: list needed\" sexp\n;;\n\nlet create_float32_mat = Array2.create float32 fortran_layout\nlet create_float64_mat = Array2.create float64 fortran_layout\nlet float32_mat_of_sexp = float_mat_of_sexp create_float32_mat\nlet float64_mat_of_sexp = float_mat_of_sexp create_float64_mat\nlet mat_of_sexp = float_mat_of_sexp create_float64_mat\n\nlet mat_sexp_grammar : Sexplib0.Sexp.Private.Raw_grammar.t =\n Inline (List [ One (Atom Int); One (Atom Int); Many (Atom Float) ])\n;;\n\nlet float32_mat_sexp_grammar = mat_sexp_grammar\nlet float64_mat_sexp_grammar = mat_sexp_grammar\nlet string_of__of__sexp_of to_sexp x = Sexp.to_string (to_sexp x)\n\nlet of_string__of__of_sexp of_sexp s =\n try\n let sexp = Sexp.of_string s in\n of_sexp sexp\n with\n | e ->\n failwith\n (sprintf \"of_string failed on %s with %s\" s (Sexp.to_string_hum (sexp_of_exn e)))\n;;\n","\n(* We do not [include Base] here, and instead import modules that [Core_kernel] doesn't\n extend, because we want code in [Core_kernel] to be clear when it references a [Base]\n module that [Core_kernel] is overriding. *)\nmodule Applicative = Base.Applicative\nmodule Avltree = Base.Avltree\nmodule Backtrace = Base.Backtrace\nmodule Binary_search = Base.Binary_search\nmodule Comparisons = Base.Comparisons\nmodule Continue_or_stop = Base.Continue_or_stop\nmodule Equal = Base.Equal\nmodule Exn = Base.Exn\nmodule Floatable = Base.Floatable\nmodule Formatter = Base.Formatter\nmodule Hash = Base.Hash\nmodule Hasher = Base.Hasher\nmodule Indexed_container = Base.Indexed_container\nmodule Intable = Base.Intable\nmodule Int_conversions = Base.Int_conversions\nmodule Int_math = Base.Int_math\nmodule Invariant = Base.Invariant\nmodule Monad = Base.Monad\nmodule Poly = Base.Poly\n\nmodule Popcount = Base.Popcount\n[@@warning \"-3\"]\n[@@deprecated \"[since 2018-10] use [popcount] functions in individual int modules\"]\n\nmodule Pretty_printer = Base.Pretty_printer\nmodule Random = Base.Random\nmodule Staged = Base.Staged\nmodule Stringable = Base.Stringable\nmodule Uchar = Base.Uchar\nmodule Validate = Base.Validate\nmodule With_return = Base.With_return\nmodule Word_size = Base.Word_size\n\n(* We do include [Base]'s top-level value and type bindings, because they don't cause\n any confusion, and duplicating them would be error prone. *)\ninclude Base.Export\ninclude Stdio\ninclude Base_for_tests\ninclude Bin_prot.Std\nmodule Field = Fieldslib.Field\n\nmodule From_sexplib : sig\n type bigstring = Sexplib.Conv.bigstring [@@deriving sexp]\n type mat = Sexplib.Conv.mat [@@deriving sexp]\n type vec = Sexplib.Conv.vec [@@deriving sexp]\n\n (* [sexp_of_opaque] and [opaque_of_sexp] are used by the code generated from\n [[@@deriving sexp]], [[%sexp_of: ]], and [[%of_sexp: ]]. The type [_ sexp_opaque]\n expands to uses of [sexp_of_opaque] and [opaque_of_sexp]. *)\n\n val sexp_of_opaque : _ -> Base.Sexp.t\n val opaque_of_sexp : Base.Sexp.t -> _\n val sexp_of_pair : ('a -> Base.Sexp.t) -> ('b -> Base.Sexp.t) -> 'a * 'b -> Base.Sexp.t\n val pair_of_sexp : (Base.Sexp.t -> 'a) -> (Base.Sexp.t -> 'b) -> Base.Sexp.t -> 'a * 'b\n\n exception Of_sexp_error of exn * Base.Sexp.t\n\n val of_sexp_error : string -> Base.Sexp.t -> _\n val of_sexp_error_exn : exn -> Base.Sexp.t -> _\nend =\n Sexplib.Conv\n\ninclude From_sexplib\n\n(* [sexp_opaque] indicates to [ppx_sexp_conv] that a value should be rendered as [_], i.e.\n [Sexp.Atom \"_\"]. Here we expose the [@@deriving] aspects of [sexp_opaque] so that\n other ppx's treat [sexp_opaque] correctly, by ignoring it and processing the underlying\n type. *)\ninclude (\nstruct\n type 'a sexp_opaque = 'a [@@deriving bin_io, compare, hash, typerep]\nend :\nsig\n type 'a sexp_opaque [@@deriving bin_io, compare, hash, typerep]\nend\nwith type 'a sexp_opaque := 'a)\n\ninclude (\n Typerep_lib.Std :\n module type of struct\n include Typerep_lib.Std\n end\n with module Type_equal := Typerep_lib.Std.Type_equal)\n\nmodule Variant = Variantslib.Variant\n\nlet with_return = With_return.with_return\nlet am_running_inline_test = Ppx_inline_test_lib.Runtime.am_running_inline_test\n\nlet am_running_test =\n try\n ignore (Caml.Sys.getenv \"TESTING_FRAMEWORK\" : string);\n true\n with\n (* [Caml.*] never raises [Not_found_s] *)\n | Caml.Not_found -> false\n;;\n\ntype 'a identity = 'a\n\nmodule Not_found = struct\n exception\n Not_found = Not_found\n [@deprecated\n {|[since 2018-02] Instead of raising [Not_found], consider using [raise_s] with an\ninformative error message. If code needs to distinguish [Not_found] from other\nexceptions, please change it to handle both [Not_found] and [Not_found_s]. Then, instead\nof raising [Not_found], raise [Not_found_s] with an informative error message.|}]\n\n exception Not_found_s = Base.Not_found_s\nend\n\ninclude Not_found\n","open! Import\ninclude Base.Sexpable\n\nmodule Stable = struct\n module Of_sexpable = struct\n module V1\n (Sexpable : S) (M : sig\n type t\n\n val to_sexpable : t -> Sexpable.t\n val of_sexpable : Sexpable.t -> t\n end) : S with type t := M.t = struct\n let t_of_sexp sexp =\n let s = Sexpable.t_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t t = Sexpable.sexp_of_t (M.to_sexpable t)\n end\n end\n\n module Of_sexpable1 = struct\n module V1\n (Sexpable : S1) (M : sig\n type 'a t\n\n val to_sexpable : 'a t -> 'a Sexpable.t\n val of_sexpable : 'a Sexpable.t -> 'a t\n end) : S1 with type 'a t := 'a M.t = struct\n let t_of_sexp a_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a t = Sexpable.sexp_of_t sexp_of_a (M.to_sexpable t)\n end\n end\n\n module Of_sexpable2 = struct\n module V1\n (Sexpable : S2) (M : sig\n type ('a, 'b) t\n\n val to_sexpable : ('a, 'b) t -> ('a, 'b) Sexpable.t\n val of_sexpable : ('a, 'b) Sexpable.t -> ('a, 'b) t\n end) : S2 with type ('a, 'b) t := ('a, 'b) M.t = struct\n let t_of_sexp a_of_sexp b_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp b_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a sexp_of_b t =\n Sexpable.sexp_of_t sexp_of_a sexp_of_b (M.to_sexpable t)\n ;;\n end\n end\n\n module Of_sexpable3 = struct\n module V1\n (Sexpable : S3) (M : sig\n type ('a, 'b, 'c) t\n\n val to_sexpable : ('a, 'b, 'c) t -> ('a, 'b, 'c) Sexpable.t\n val of_sexpable : ('a, 'b, 'c) Sexpable.t -> ('a, 'b, 'c) t\n end) : S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t = struct\n let t_of_sexp a_of_sexp b_of_sexp c_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp b_of_sexp c_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a sexp_of_b sexp_of_c t =\n Sexpable.sexp_of_t sexp_of_a sexp_of_b sexp_of_c (M.to_sexpable t)\n ;;\n end\n end\n\n module Of_stringable = struct\n module V1 (M : Stringable.S) : S with type t := M.t = struct\n let t_of_sexp sexp =\n match sexp with\n | Sexplib.Sexp.Atom s ->\n (try M.of_string s with\n | exn -> of_sexp_error_exn exn sexp)\n | Sexplib.Sexp.List _ ->\n of_sexp_error\n \"Sexpable.Of_stringable.t_of_sexp expected an atom, but got a list\"\n sexp\n ;;\n\n let sexp_of_t t = Sexplib.Sexp.Atom (M.to_string t)\n end\n end\n\n module To_stringable = struct\n module V1 (M : S) : Stringable.S with type t := M.t = struct\n let of_string x = Sexplib.Conv.of_string__of__of_sexp M.t_of_sexp x\n let to_string x = Sexplib.Conv.string_of__of__sexp_of M.sexp_of_t x\n end\n end\nend\n\nmodule To_stringable = Stable.To_stringable.V1\n","open! Import\nopen Bin_prot.Binable\nopen Bigarray\n\nmodule type Conv_without_uuid = sig\n type binable\n type t\n\n val to_binable : t -> binable\n val of_binable : binable -> t\nend\n\nmodule type Conv1_without_uuid = sig\n type 'a binable\n type 'a t\n\n val to_binable : 'a t -> 'a binable\n val of_binable : 'a binable -> 'a t\nend\n\nmodule type Conv2_without_uuid = sig\n type ('a, 'b) binable\n type ('a, 'b) t\n\n val to_binable : ('a, 'b) t -> ('a, 'b) binable\n val of_binable : ('a, 'b) binable -> ('a, 'b) t\nend\n\nmodule type Conv3_without_uuid = sig\n type ('a, 'b, 'c) binable\n type ('a, 'b, 'c) t\n\n val to_binable : ('a, 'b, 'c) t -> ('a, 'b, 'c) binable\n val of_binable : ('a, 'b, 'c) binable -> ('a, 'b, 'c) t\nend\n\nmodule type Conv = sig\n include Conv_without_uuid\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\nmodule type Conv1 = sig\n include Conv1_without_uuid\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\nmodule type Conv2 = sig\n include Conv2_without_uuid\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\nmodule type Conv3 = sig\n include Conv3_without_uuid\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\nmodule type Conv_sexpable = sig\n include Sexpable.S\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\nmodule type Conv_stringable = sig\n include Stringable.S\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\n(** Module types and utilities for dealing with types that support the bin-io binary\n encoding. *)\nmodule type Binable = sig\n (** We copy the definition of the bigstring type here, because we cannot depend on\n bigstring.ml *)\n type bigstring = (char, int8_unsigned_elt, c_layout) Array1.t\n\n (** New code should use [@@deriving bin_io]. These module types ([S], [S1], and [S2])\n are exported only for backwards compatibility. *)\n module type S = S\n\n module type S_only_functions = S_only_functions\n module type S1 = S1\n module type S2 = S2\n module type S3 = S3\n\n module Minimal : sig\n module type S = Minimal.S\n module type S1 = Minimal.S1\n module type S2 = Minimal.S2\n module type S3 = Minimal.S3\n end\n\n module type Conv = Conv\n module type Conv1 = Conv1\n module type Conv2 = Conv2\n module type Conv3 = Conv3\n module type Conv_sexpable = Conv_sexpable\n module type Conv_stringable = Conv_stringable\n module type Conv_without_uuid = Conv_without_uuid\n module type Conv1_without_uuid = Conv1_without_uuid\n module type Conv2_without_uuid = Conv2_without_uuid\n module type Conv3_without_uuid = Conv3_without_uuid\n\n (** [Of_binable*] functors are for when you want the binary representation of one type\n to be the same as that for some other isomorphic type. *)\n\n module Of_binable_with_uuid\n (Binable : Minimal.S)\n (M : Conv with type binable := Binable.t) : S with type t := M.t\n\n module Of_binable1_with_uuid\n (Binable : Minimal.S1)\n (M : Conv1 with type 'a binable := 'a Binable.t) : S1 with type 'a t := 'a M.t\n\n module Of_binable2_with_uuid\n (Binable : Minimal.S2)\n (M : Conv2 with type ('a, 'b) binable := ('a, 'b) Binable.t) :\n S2 with type ('a, 'b) t := ('a, 'b) M.t\n\n module Of_binable3_with_uuid\n (Binable : Minimal.S3)\n (M : Conv3 with type ('a, 'b, 'c) binable := ('a, 'b, 'c) Binable.t) :\n S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t\n\n module Of_binable_without_uuid\n (Binable : Minimal.S)\n (M : Conv_without_uuid with type binable := Binable.t) : S with type t := M.t\n [@@alert legacy \"Use [Of_binable_with_uuid] if possible.\"]\n\n module Of_binable1_without_uuid\n (Binable : Minimal.S1)\n (M : Conv1_without_uuid with type 'a binable := 'a Binable.t) :\n S1 with type 'a t := 'a M.t\n [@@alert legacy \"Use [Of_binable1_with_uuid] if possible.\"]\n\n module Of_binable2_without_uuid\n (Binable : Minimal.S2)\n (M : Conv2_without_uuid with type ('a, 'b) binable := ('a, 'b) Binable.t) :\n S2 with type ('a, 'b) t := ('a, 'b) M.t\n [@@alert legacy \"Use [Of_binable2_with_uuid] if possible.\"]\n\n module Of_binable3_without_uuid\n (Binable : Minimal.S3)\n (M : Conv3_without_uuid with type ('a, 'b, 'c) binable := ('a, 'b, 'c) Binable.t) :\n S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t\n [@@alert legacy \"Use [Of_binable3_with_uuid] if possible.\"]\n\n module Of_binable = Of_binable_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_binable_with_uuid] if possible, otherwise use \\\n [Of_binable_without_uuid].\"]\n\n module Of_binable1 = Of_binable1_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_binable1_with_uuid] if possible, otherwise use \\\n [Of_binable1_without_uuid].\"]\n\n module Of_binable2 = Of_binable2_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_binable2_with_uuid] if possible, otherwise use \\\n [Of_binable2_without_uuid].\"]\n\n module Of_binable3 = Of_binable3_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_binable3_with_uuid] if possible, otherwise use \\\n [Of_binable3_without_uuid].\"]\n\n (** [Of_sexpable_with_uuid] serializes a value using the bin-io of the sexp\n serialization of the value. This is not as efficient as using [@@deriving bin_io].\n However, it is useful when performance isn't important and there are obstacles to\n using [@@deriving bin_io], e.g., some type missing [@@deriving bin_io].\n [Of_sexpable_with_uuid] is also useful when one wants to be forgiving about format\n changes, due to the sexp serialization being more robust to changes like adding or\n removing a constructor. *)\n\n module Of_sexpable_with_uuid (M : Conv_sexpable) : S with type t := M.t\n module Of_stringable_with_uuid (M : Conv_stringable) : S with type t := M.t\n\n module Of_sexpable_without_uuid (M : Sexpable.S) : S with type t := M.t\n [@@alert legacy \"Use [Of_sexpable_with_uuid] if possible.\"]\n\n module Of_stringable_without_uuid (M : Stringable.S) : S with type t := M.t\n [@@alert legacy \"Use [Of_stringable_with_uuid] if possible.\"]\n\n module Of_sexpable = Of_sexpable_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_sexpable_with_uuid] if possible, otherwise use \\\n [Of_sexpable_without_uuid].\"]\n\n module Of_stringable = Of_stringable_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_stringable_with_uuid] if possible, otherwise use \\\n [Of_stringable_without_uuid].\"]\n\n type 'a m = (module S with type t = 'a)\n\n val of_bigstring : 'a m -> bigstring -> 'a\n\n val to_bigstring\n : ?prefix_with_length:bool (** defaults to false *)\n -> 'a m\n -> 'a\n -> bigstring\n\n val of_string : 'a m -> string -> 'a\n val to_string : 'a m -> 'a -> string\n\n (** The following functors preserve stability: if applied to stable types with stable\n (de)serializations, they will produce stable types with stable (de)serializations.\n\n Note: In all cases, stability of the input (and therefore the output) depends on the\n semantics of all conversion functions (e.g. [to_string], [to_sexpable]) not changing\n in the future.\n *)\n\n module Stable : sig\n module Of_binable : sig\n module V1 : (module type of Of_binable_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_binable_with_uuid\n end\n\n module Of_binable1 : sig\n module V1 : (module type of Of_binable1_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_binable1_with_uuid\n end\n\n module Of_binable2 : sig\n module V1 : (module type of Of_binable2_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_binable2_with_uuid\n end\n\n module Of_binable3 : sig\n module V1 : (module type of Of_binable3_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_binable3_with_uuid\n end\n\n module Of_sexpable : sig\n module V1 : (module type of Of_sexpable_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_sexpable_with_uuid\n end\n\n module Of_stringable : sig\n module V1 : (module type of Of_stringable_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_stringable_with_uuid\n end\n end\nend\n","open! Import\nopen Binable_intf\ninclude Bin_prot.Binable\nmodule Shape = Bin_prot.Shape\nmodule List = Base.List\n\nmodule Stable = struct\n module Of_binable = struct\n module V1\n (Binable : Minimal.S)\n (M : Conv_without_uuid with type binable := Binable.t) : S with type t := M.t =\n Bin_prot.Utils.Make_binable_without_uuid (struct\n module Binable = Binable\n include M\n end)\n [@@alert \"-legacy\"]\n\n module V2 (Binable : Minimal.S) (M : Conv with type binable := Binable.t) :\n S with type t := M.t = Bin_prot.Utils.Make_binable_with_uuid (struct\n module Binable = Binable\n include M\n end)\n end\n\n module Of_binable1 = struct\n module V1\n (Binable : Minimal.S1)\n (M : Conv1_without_uuid with type 'a binable := 'a Binable.t) :\n S1 with type 'a t := 'a M.t = Bin_prot.Utils.Make_binable1_without_uuid (struct\n module Binable = Binable\n include M\n end)\n [@@alert \"-legacy\"]\n\n module V2 (Binable : Minimal.S1) (M : Conv1 with type 'a binable := 'a Binable.t) :\n S1 with type 'a t := 'a M.t = Bin_prot.Utils.Make_binable1_with_uuid (struct\n module Binable = Binable\n include M\n end)\n end\n\n module Of_binable2 = struct\n module V1\n (Binable : Minimal.S2)\n (M : Conv2_without_uuid with type ('a, 'b) binable := ('a, 'b) Binable.t) :\n S2 with type ('a, 'b) t := ('a, 'b) M.t =\n Bin_prot.Utils.Make_binable2_without_uuid (struct\n module Binable = Binable\n include M\n end)\n [@@alert \"-legacy\"]\n\n module V2\n (Binable : Minimal.S2)\n (M : Conv2 with type ('a, 'b) binable := ('a, 'b) Binable.t) :\n S2 with type ('a, 'b) t := ('a, 'b) M.t =\n Bin_prot.Utils.Make_binable2_with_uuid (struct\n module Binable = Binable\n include M\n end)\n end\n\n module Of_binable3 = struct\n module V1\n (Binable : Minimal.S3)\n (M : Conv3_without_uuid with type ('a, 'b, 'c) binable := ('a, 'b, 'c) Binable.t) :\n S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t =\n Bin_prot.Utils.Make_binable3_without_uuid (struct\n module Binable = Binable\n include M\n end)\n [@@alert \"-legacy\"]\n\n module V2\n (Binable : Minimal.S3)\n (M : Conv3 with type ('a, 'b, 'c) binable := ('a, 'b, 'c) Binable.t) :\n S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t =\n Bin_prot.Utils.Make_binable3_with_uuid (struct\n module Binable = Binable\n include M\n end)\n end\n\n module Of_sexpable = struct\n module V1 (M : Sexpable.S) =\n Of_binable.V1\n (struct\n type t = Base.Sexp.t =\n | Atom of string\n | List of t list\n [@@deriving bin_io]\n end)\n (struct\n type t = M.t\n\n let to_binable = M.sexp_of_t\n let of_binable = M.t_of_sexp\n end)\n\n module V2 (M : Conv_sexpable) =\n Of_binable.V2\n (struct\n type t = Base.Sexp.t =\n | Atom of string\n | List of t list\n [@@deriving bin_io]\n end)\n (struct\n type t = M.t\n\n let to_binable = M.sexp_of_t\n let of_binable = M.t_of_sexp\n let caller_identity = M.caller_identity\n end)\n end\n\n module Of_stringable = struct\n module V1 (M : Stringable.S) = Bin_prot.Utils.Make_binable_without_uuid (struct\n module Binable = struct\n type t = string [@@deriving bin_io]\n end\n\n type t = M.t\n\n let to_binable = M.to_string\n\n (* Wrap exception for improved diagnostics. *)\n exception Of_binable of string * exn [@@deriving sexp]\n\n let of_binable s =\n try M.of_string s with\n | x -> raise (Of_binable (s, x))\n ;;\n end)\n [@@alert \"-legacy\"]\n\n module V2 (M : Conv_stringable) = Bin_prot.Utils.Make_binable_with_uuid (struct\n module Binable = struct\n type t = string [@@deriving bin_io]\n end\n\n type t = M.t\n\n let to_binable = M.to_string\n\n (* Wrap exception for improved diagnostics. *)\n exception Of_binable of string * exn [@@deriving sexp]\n\n let of_binable s =\n try M.of_string s with\n | x -> raise (Of_binable (s, x))\n ;;\n\n let caller_identity = M.caller_identity\n end)\n end\nend\n\nopen Bigarray\n\ntype bigstring = (char, int8_unsigned_elt, c_layout) Array1.t\n\n\ntype 'a m = (module S with type t = 'a)\n\nlet of_bigstring (type a) m bigstring =\n let module M = (val m : S with type t = a) in\n let pos_ref = ref 0 in\n let t = M.bin_read_t bigstring ~pos_ref in\n assert (!pos_ref = Array1.dim bigstring);\n t\n;;\n\n(* Using the [Bigstring] module would introduce a cyclic dependency. *)\nlet create_bigstring size = Array1.create Bigarray.char Bigarray.c_layout size\n\nlet to_bigstring ?(prefix_with_length = false) (type a) m t =\n let module M = (val m : S with type t = a) in\n let t_length = M.bin_size_t t in\n let bigstring_length =\n if prefix_with_length then t_length + 8 (* the size of a 64-bit int *) else t_length\n in\n let bigstring = create_bigstring bigstring_length in\n let pos =\n if prefix_with_length\n then Bin_prot.Write.bin_write_int_64bit bigstring ~pos:0 t_length\n else 0\n in\n let pos = M.bin_write_t bigstring ~pos t in\n assert (pos = bigstring_length);\n bigstring\n;;\n\nmodule Of_binable_with_uuid = Stable.Of_binable.V2\nmodule Of_binable1_with_uuid = Stable.Of_binable1.V2\nmodule Of_binable2_with_uuid = Stable.Of_binable2.V2\nmodule Of_binable3_with_uuid = Stable.Of_binable3.V2\nmodule Of_sexpable_with_uuid = Stable.Of_sexpable.V2\nmodule Of_stringable_with_uuid = Stable.Of_stringable.V2\n\nmodule Of_binable_without_uuid = Stable.Of_binable.V1\n[@@alert legacy \"Use [Of_binable_with_uuid] if possible.\"]\n\nmodule Of_binable1_without_uuid = Stable.Of_binable1.V1\n[@@alert legacy \"Use [Of_binable1_with_uuid] if possible.\"]\n\nmodule Of_binable2_without_uuid = Stable.Of_binable2.V1\n[@@alert legacy \"Use [Of_binable2_with_uuid] if possible.\"]\n\nmodule Of_binable3_without_uuid = Stable.Of_binable3.V1\n[@@alert legacy \"Use [Of_binable3_with_uuid] if possible.\"]\n\nmodule Of_sexpable_without_uuid = Stable.Of_sexpable.V1\n[@@alert legacy \"Use [Of_sexpable_with_uuid] if possible.\"]\n\nmodule Of_stringable_without_uuid = Stable.Of_stringable.V1\n[@@alert legacy \"Use [Of_stringable_with_uuid] if possible.\"]\n\nmodule type S_only_functions_and_shape = sig\n include S_only_functions\n\n val bin_shape_t : Shape.t\nend\n\n(* check that only the functions & shape are sufficient for [@@deriving bin_io] *)\nmodule Of_only_functions_and_shape (X : S_only_functions_and_shape) : S = struct\n type t = X.t [@@deriving bin_io]\nend\n","(** This module extends {{!Base.Printf}[Base.Printf]}. *)\n\nopen! Import\n\ninclude Base.Printf (** @open *)\n\nlet eprintf = Stdio.Out_channel.eprintf\nlet fprintf = Stdio.Out_channel.fprintf\nlet kfprintf = Stdio.Out_channel.kfprintf\nlet printf = Stdio.Out_channel.printf\n\n\n(** print to stderr; exit 1 *)\nlet exitf fmt =\n ksprintf\n (fun s () ->\n eprintf \"%s\\n%!\" s;\n exit 1)\n fmt\n;;\n","open! Import\nmodule Comparator = Base.Comparator\n\ntype ('a, 'witness) t = ('a, 'witness) Comparator.t = private\n { compare : 'a -> 'a -> int\n ; sexp_of_t : 'a -> Base.Sexp.t\n }\n\nmodule type Base_mask = module type of Comparator with type ('a, 'b) t := ('a, 'b) t\n\ninclude (Comparator : Base_mask)\n\nmodule Stable = struct\n module V1 = struct\n type nonrec ('a, 'witness) t = ('a, 'witness) t = private\n { compare : 'a -> 'a -> int\n ; sexp_of_t : 'a -> Base.Sexp.t\n }\n\n type ('a, 'b) comparator = ('a, 'b) t\n\n module type S = S\n module type S1 = S1\n\n let make = make\n\n module Make = Make\n module Make1 = Make1\n end\nend\n","open! Import\nmodule Result = Base.Result\n\nmodule Stable = struct\n module V1 = struct\n type ('a, 'b) t = ('a, 'b) Result.t =\n | Ok of 'a\n | Error of 'b\n [@@deriving bin_io, compare, hash, sexp]\n\n let map x ~f1 ~f2 =\n match x with\n | Error err -> Error (f2 err)\n | Ok x -> Ok (f1 x)\n ;;\n end\n\n module V1_stable_unit_test = struct\n type t = (string, int) V1.t [@@deriving bin_io, compare, hash, sexp]\n\n let equal = [%compare.equal: t]\n\n let tests =\n [ V1.Ok \"foo\", \"(Ok foo)\", \"\\000\\003foo\"; V1.Error 7, \"(Error 7)\", \"\\001\\007\" ]\n ;;\n end\nend\n\ninclude Stable.V1\ninclude Result\n","include Base.Container\n\nmodule type S1_permissions = Container_intf.S1_permissions\n","let ( |! ) x y = x |> y\n","(** Extends {{!Base.Fn}[Base.Fn]}. *)\n\ninclude Base.Fn (** @open *)\n\ninclude Deprecate_pipe_bang\n","include Base.Ordered_collection_common\n\nlet normalize ~length_fun t i = if i < 0 then i + length_fun t else i\n\nlet slice ~length_fun ~sub_fun t start stop =\n let stop = if stop = 0 then length_fun t else stop in\n let pos = normalize ~length_fun t start in\n let len = normalize ~length_fun t stop - pos in\n sub_fun t ~pos ~len\n;;\n","open! Import\ninclude Base.Sequence\n\ninclude Bin_prot.Utils.Make_binable1_without_uuid [@alert \"-legacy\"] (struct\n module Binable = struct\n type 'a t = 'a list [@@deriving bin_io]\n end\n\n type 'a t = 'a Base.Sequence.t\n\n let of_binable = Base.Sequence.of_list\n let to_binable = Base.Sequence.to_list\n end)\n\nmodule Step = struct\n include Step\n\n type ('a, 's) t = ('a, 's) Step.t =\n | Done\n | Skip of 's\n | Yield of 'a * 's\n [@@deriving bin_io]\nend\n\nmodule Merge_with_duplicates_element = struct\n include Merge_with_duplicates_element\n\n type ('a, 'b) t = ('a, 'b) Merge_with_duplicates_element.t =\n | Left of 'a\n | Right of 'b\n | Both of 'a * 'b\n [@@deriving bin_io]\nend\n\nmodule type Heap = sig\n type 'a t\n\n val create : compare:('a -> 'a -> int) -> 'a t\n val add : 'a t -> 'a -> 'a t\n val remove_min : 'a t -> ('a * 'a t) option\nend\n\nlet merge_all (module Heap : Heap) seqs ~compare =\n let module Merge_all_state = struct\n type 'a t =\n { heap : ('a * 'a Base.Sequence.t) Heap.t\n ; not_yet_in_heap : 'a Base.Sequence.t list\n }\n [@@deriving fields]\n\n let create = Fields.create\n end\n in\n unfold_step\n ~init:\n (Merge_all_state.create\n ~heap:(Heap.create ~compare:(Base.Comparable.lift compare ~f:fst))\n ~not_yet_in_heap:seqs)\n ~f:(fun { heap; not_yet_in_heap } ->\n match not_yet_in_heap with\n | seq :: not_yet_in_heap ->\n (match Expert.next_step seq with\n | Done -> Skip { not_yet_in_heap; heap }\n | Skip seq -> Skip { not_yet_in_heap = seq :: not_yet_in_heap; heap }\n | Yield (elt, seq) -> Skip { not_yet_in_heap; heap = Heap.add heap (elt, seq) })\n | [] ->\n (match Heap.remove_min heap with\n | None -> Done\n | Some ((elt, seq), heap) -> Yield (elt, { heap; not_yet_in_heap = [ seq ] })))\n;;\n","open! Import\nopen Perms.Export\nmodule Array = Base.Array\nmodule Core_sequence = Sequence\n\ninclude (\n Base.Array :\n sig\n type 'a t = 'a array [@@deriving sexp, compare, sexp_grammar]\n end)\n\ntype 'a t = 'a array [@@deriving bin_io, typerep]\n\nmodule Private = Base.Array.Private\n\nmodule T = struct\n include Base.Array\n\n let normalize t i = Ordered_collection_common.normalize ~length_fun:length t i\n\n let slice t start stop =\n Ordered_collection_common.slice ~length_fun:length ~sub_fun:sub t start stop\n ;;\n\n let nget t i = t.(normalize t i)\n let nset t i v = t.(normalize t i) <- v\n\n module Sequence = struct\n open Base.Array\n\n let length = length\n let get = get\n let set = set\n end\n\n (* See OCaml perf notes for why these array blits are special cased -- in particular,\n the section entitled \"Fast, Slow and Incorrect Array blits\" of\n https://janestreet.github.io/ocaml-perf-notes.html *)\n module Int = struct\n type t_ = int array [@@deriving bin_io, compare, sexp]\n\n module Unsafe_blit = struct\n external unsafe_blit\n : src:t_\n -> src_pos:int\n -> dst:t_\n -> dst_pos:int\n -> len:int\n -> unit\n = \"core_array_unsafe_int_blit\"\n [@@noalloc]\n end\n\n include Test_blit.Make_and_test\n (struct\n type t = int\n\n let equal = ( = )\n let of_bool b = if b then 1 else 0\n end)\n (struct\n type t = t_ [@@deriving sexp_of]\n\n include Sequence\n\n let create ~len = create ~len 0\n\n include Unsafe_blit\n end)\n\n include Unsafe_blit\n end\n\n module Float = struct\n type t_ = float array [@@deriving bin_io, compare, sexp]\n\n module Unsafe_blit = struct\n external unsafe_blit\n : src:t_\n -> src_pos:int\n -> dst:t_\n -> dst_pos:int\n -> len:int\n -> unit\n = \"core_array_unsafe_float_blit\"\n [@@noalloc]\n end\n\n include Test_blit.Make_and_test\n (struct\n type t = float\n\n let equal = Base.Float.equal\n let of_bool b = if b then 1. else 0.\n end)\n (struct\n type t = t_ [@@deriving sexp_of]\n\n include Sequence\n\n let create ~len = create ~len 0.\n\n include Unsafe_blit\n end)\n\n include Unsafe_blit\n end\nend\n\nmodule type Permissioned = sig\n type ('a, -'perms) t\n\n include Container.S1_permissions with type ('a, 'perms) t := ('a, 'perms) t\n include Blit.S1_permissions with type ('a, 'perms) t := ('a, 'perms) t\n include Binary_searchable.S1_permissions with type ('a, 'perms) t := ('a, 'perms) t\n\n val length : (_, _) t -> int\n val is_empty : (_, _) t -> bool\n external get : ('a, [> read ]) t -> int -> 'a = \"%array_safe_get\"\n external set : ('a, [> write ]) t -> int -> 'a -> unit = \"%array_safe_set\"\n external unsafe_get : ('a, [> read ]) t -> int -> 'a = \"%array_unsafe_get\"\n external unsafe_set : ('a, [> write ]) t -> int -> 'a -> unit = \"%array_unsafe_set\"\n val create : len:int -> 'a -> ('a, [< _ perms ]) t\n val init : int -> f:(int -> 'a) -> ('a, [< _ perms ]) t\n val make_matrix : dimx:int -> dimy:int -> 'a -> (('a, [< _ perms ]) t, [< _ perms ]) t\n val append : ('a, [> read ]) t -> ('a, [> read ]) t -> ('a, [< _ perms ]) t\n val concat : ('a, [> read ]) t list -> ('a, [< _ perms ]) t\n val copy : ('a, [> read ]) t -> ('a, [< _ perms ]) t\n val fill : ('a, [> write ]) t -> pos:int -> len:int -> 'a -> unit\n val of_list : 'a list -> ('a, [< _ perms ]) t\n val map : ('a, [> read ]) t -> f:('a -> 'b) -> ('b, [< _ perms ]) t\n\n val folding_map\n : ('a, [> read ]) t\n -> init:'b\n -> f:('b -> 'a -> 'b * 'c)\n -> ('c, [< _ perms ]) t\n\n val fold_map\n : ('a, [> read ]) t\n -> init:'b\n -> f:('b -> 'a -> 'b * 'c)\n -> 'b * ('c, [< _ perms ]) t\n\n val mapi : ('a, [> read ]) t -> f:(int -> 'a -> 'b) -> ('b, [< _ perms ]) t\n val iteri : ('a, [> read ]) t -> f:(int -> 'a -> unit) -> unit\n val foldi : ('a, [> read ]) t -> init:'b -> f:(int -> 'b -> 'a -> 'b) -> 'b\n\n val folding_mapi\n : ('a, [> read ]) t\n -> init:'b\n -> f:(int -> 'b -> 'a -> 'b * 'c)\n -> ('c, [< _ perms ]) t\n\n val fold_mapi\n : ('a, [> read ]) t\n -> init:'b\n -> f:(int -> 'b -> 'a -> 'b * 'c)\n -> 'b * ('c, [< _ perms ]) t\n\n val fold_right : ('a, [> read ]) t -> f:('a -> 'b -> 'b) -> init:'b -> 'b\n\n val sort\n : ?pos:int\n -> ?len:int\n -> ('a, [> read_write ]) t\n -> compare:('a -> 'a -> int)\n -> unit\n\n val stable_sort : ('a, [> read_write ]) t -> compare:('a -> 'a -> int) -> unit\n val is_sorted : ('a, [> read ]) t -> compare:('a -> 'a -> int) -> bool\n val is_sorted_strictly : ('a, [> read ]) t -> compare:('a -> 'a -> int) -> bool\n\n val concat_map\n : ('a, [> read ]) t\n -> f:('a -> ('b, [> read ]) t)\n -> ('b, [< _ perms ]) t\n\n val concat_mapi\n : ('a, [> read ]) t\n -> f:(int -> 'a -> ('b, [> read ]) t)\n -> ('b, [< _ perms ]) t\n\n val partition_tf\n : ('a, [> read ]) t\n -> f:('a -> bool)\n -> ('a, [< _ perms ]) t * ('a, [< _ perms ]) t\n\n val partitioni_tf\n : ('a, [> read ]) t\n -> f:(int -> 'a -> bool)\n -> ('a, [< _ perms ]) t * ('a, [< _ perms ]) t\n\n val cartesian_product\n : ('a, [> read ]) t\n -> ('b, [> read ]) t\n -> ('a * 'b, [< _ perms ]) t\n\n val transpose\n : (('a, [> read ]) t, [> read ]) t\n -> (('a, [< _ perms ]) t, [< _ perms ]) t option\n\n val transpose_exn\n : (('a, [> read ]) t, [> read ]) t\n -> (('a, [< _ perms ]) t, [< _ perms ]) t\n\n val normalize : ('a, _) t -> int -> int\n val slice : ('a, [> read ]) t -> int -> int -> ('a, [< _ perms ]) t\n val nget : ('a, [> read ]) t -> int -> 'a\n val nset : ('a, [> write ]) t -> int -> 'a -> unit\n val filter_opt : ('a option, [> read ]) t -> ('a, [< _ perms ]) t\n val filter_map : ('a, [> read ]) t -> f:('a -> 'b option) -> ('b, [< _ perms ]) t\n\n val filter_mapi\n : ('a, [> read ]) t\n -> f:(int -> 'a -> 'b option)\n -> ('b, [< _ perms ]) t\n\n val for_alli : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> bool\n val existsi : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> bool\n val counti : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> int\n val iter2_exn : ('a, [> read ]) t -> ('b, [> read ]) t -> f:('a -> 'b -> unit) -> unit\n\n val map2_exn\n : ('a, [> read ]) t\n -> ('b, [> read ]) t\n -> f:('a -> 'b -> 'c)\n -> ('c, [< _ perms ]) t\n\n val fold2_exn\n : ('a, [> read ]) t\n -> ('b, [> read ]) t\n -> init:'c\n -> f:('c -> 'a -> 'b -> 'c)\n -> 'c\n\n val for_all2_exn\n : ('a, [> read ]) t\n -> ('b, [> read ]) t\n -> f:('a -> 'b -> bool)\n -> bool\n\n val exists2_exn\n : ('a, [> read ]) t\n -> ('b, [> read ]) t\n -> f:('a -> 'b -> bool)\n -> bool\n\n val filter : ('a, [> read ]) t -> f:('a -> bool) -> ('a, [< _ perms ]) t\n val filteri : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> ('a, [< _ perms ]) t\n val swap : ('a, [> read_write ]) t -> int -> int -> unit\n val rev_inplace : ('a, [> read_write ]) t -> unit\n val of_list_rev : 'a list -> ('a, [< _ perms ]) t\n val of_list_map : 'a list -> f:('a -> 'b) -> ('b, [< _ perms ]) t\n val of_list_mapi : 'a list -> f:(int -> 'a -> 'b) -> ('b, [< _ perms ]) t\n val of_list_rev_map : 'a list -> f:('a -> 'b) -> ('b, [< _ perms ]) t\n val of_list_rev_mapi : 'a list -> f:(int -> 'a -> 'b) -> ('b, [< _ perms ]) t\n val map_inplace : ('a, [> read_write ]) t -> f:('a -> 'a) -> unit\n val find_exn : ('a, [> read ]) t -> f:('a -> bool) -> 'a\n val find_map_exn : ('a, [> read ]) t -> f:('a -> 'b option) -> 'b\n val findi : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> (int * 'a) option\n val findi_exn : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> int * 'a\n val find_mapi : ('a, [> read ]) t -> f:(int -> 'a -> 'b option) -> 'b option\n val find_mapi_exn : ('a, [> read ]) t -> f:(int -> 'a -> 'b option) -> 'b\n\n val find_consecutive_duplicate\n : ('a, [> read ]) t\n -> equal:('a -> 'a -> bool)\n -> ('a * 'a) option\n\n val reduce : ('a, [> read ]) t -> f:('a -> 'a -> 'a) -> 'a option\n val reduce_exn : ('a, [> read ]) t -> f:('a -> 'a -> 'a) -> 'a\n val permute : ?random_state:Random.State.t -> ('a, [> read_write ]) t -> unit\n val random_element : ?random_state:Random.State.t -> ('a, [> read ]) t -> 'a option\n val random_element_exn : ?random_state:Random.State.t -> ('a, [> read ]) t -> 'a\n val zip : ('a, [> read ]) t -> ('b, [> read ]) t -> ('a * 'b, [< _ perms ]) t option\n val zip_exn : ('a, [> read ]) t -> ('b, [> read ]) t -> ('a * 'b, [< _ perms ]) t\n val unzip : ('a * 'b, [> read ]) t -> ('a, [< _ perms ]) t * ('b, [< _ perms ]) t\n\n val sorted_copy\n : ('a, [> read ]) t\n -> compare:('a -> 'a -> int)\n -> ('a, [< _ perms ]) t\n\n val last : ('a, [> read ]) t -> 'a\n val equal : ('a -> 'a -> bool) -> ('a, [> read ]) t -> ('a, [> read ]) t -> bool\n val to_sequence : ('a, [> read ]) t -> 'a Sequence.t\n val to_sequence_mutable : ('a, [> read ]) t -> 'a Sequence.t\nend\n\nmodule Permissioned : sig\n type ('a, -'perms) t [@@deriving bin_io, compare, sexp]\n\n module Int : sig\n type nonrec -'perms t = (int, 'perms) t [@@deriving bin_io, compare, sexp]\n\n include Blit.S_permissions with type 'perms t := 'perms t\n\n external unsafe_blit\n : src:[> read ] t\n -> src_pos:int\n -> dst:[> write ] t\n -> dst_pos:int\n -> len:int\n -> unit\n = \"core_array_unsafe_int_blit\"\n [@@noalloc]\n end\n\n module Float : sig\n type nonrec -'perms t = (float, 'perms) t [@@deriving bin_io, compare, sexp]\n\n include Blit.S_permissions with type 'perms t := 'perms t\n\n external unsafe_blit\n : src:[> read ] t\n -> src_pos:int\n -> dst:[> write ] t\n -> dst_pos:int\n -> len:int\n -> unit\n = \"core_array_unsafe_float_blit\"\n [@@noalloc]\n end\n\n val of_array_id : 'a array -> ('a, [< read_write ]) t\n val to_array_id : ('a, [> read_write ]) t -> 'a array\n val to_sequence_immutable : ('a, [> immutable ]) t -> 'a Sequence.t\n\n include Permissioned with type ('a, 'perms) t := ('a, 'perms) t\nend = struct\n type ('a, -'perms) t = 'a array [@@deriving bin_io, compare, sexp, typerep]\n\n module Int = struct\n include T.Int\n\n type -'perms t = t_ [@@deriving bin_io, compare, sexp]\n end\n\n module Float = struct\n include T.Float\n\n type -'perms t = t_ [@@deriving bin_io, compare, sexp]\n end\n\n let to_array_id = Fn.id\n let of_array_id = Fn.id\n\n include (T : Permissioned with type ('a, 'b) t := ('a, 'b) t) [@ocaml.warning \"-3\"]\n\n let to_array = copy\n let to_sequence_immutable = to_sequence_mutable\nend\n\nmodule type S = sig\n type 'a t\n\n include Binary_searchable.S1 with type 'a t := 'a t\n include Container.S1 with type 'a t := 'a t\n\n external get : 'a t -> int -> 'a = \"%array_safe_get\"\n external set : 'a t -> int -> 'a -> unit = \"%array_safe_set\"\n external unsafe_get : 'a t -> int -> 'a = \"%array_unsafe_get\"\n external unsafe_set : 'a t -> int -> 'a -> unit = \"%array_unsafe_set\"\n val create : len:int -> 'a -> 'a t\n val init : int -> f:(int -> 'a) -> 'a t\n val make_matrix : dimx:int -> dimy:int -> 'a -> 'a t t\n val append : 'a t -> 'a t -> 'a t\n val concat : 'a t list -> 'a t\n val copy : 'a t -> 'a t\n val fill : 'a t -> pos:int -> len:int -> 'a -> unit\n\n include Blit.S1 with type 'a t := 'a t\n\n val of_list : 'a list -> 'a t\n val map : 'a t -> f:('a -> 'b) -> 'b t\n val folding_map : 'a t -> init:'b -> f:('b -> 'a -> 'b * 'c) -> 'c t\n val fold_map : 'a t -> init:'b -> f:('b -> 'a -> 'b * 'c) -> 'b * 'c t\n val mapi : 'a t -> f:(int -> 'a -> 'b) -> 'b t\n val iteri : 'a t -> f:(int -> 'a -> unit) -> unit\n val foldi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b) -> 'b\n val folding_mapi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b * 'c) -> 'c t\n val fold_mapi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b * 'c) -> 'b * 'c t\n val fold_right : 'a t -> f:('a -> 'b -> 'b) -> init:'b -> 'b\n val sort : ?pos:int -> ?len:int -> 'a t -> compare:('a -> 'a -> int) -> unit\n val stable_sort : 'a t -> compare:('a -> 'a -> int) -> unit\n val is_sorted : 'a t -> compare:('a -> 'a -> int) -> bool\n val is_sorted_strictly : 'a t -> compare:('a -> 'a -> int) -> bool\n val concat_map : 'a t -> f:('a -> 'b t) -> 'b t\n val concat_mapi : 'a t -> f:(int -> 'a -> 'b t) -> 'b t\n val partition_tf : 'a t -> f:('a -> bool) -> 'a t * 'a t\n val partitioni_tf : 'a t -> f:(int -> 'a -> bool) -> 'a t * 'a t\n val cartesian_product : 'a t -> 'b t -> ('a * 'b) t\n val transpose : 'a t t -> 'a t t option\n val transpose_exn : 'a t t -> 'a t t\n val normalize : 'a t -> int -> int\n val slice : 'a t -> int -> int -> 'a t\n val nget : 'a t -> int -> 'a\n val nset : 'a t -> int -> 'a -> unit\n val filter_opt : 'a option t -> 'a t\n val filter_map : 'a t -> f:('a -> 'b option) -> 'b t\n val filter_mapi : 'a t -> f:(int -> 'a -> 'b option) -> 'b t\n val for_alli : 'a t -> f:(int -> 'a -> bool) -> bool\n val existsi : 'a t -> f:(int -> 'a -> bool) -> bool\n val counti : 'a t -> f:(int -> 'a -> bool) -> int\n val iter2_exn : 'a t -> 'b t -> f:('a -> 'b -> unit) -> unit\n val map2_exn : 'a t -> 'b t -> f:('a -> 'b -> 'c) -> 'c t\n val fold2_exn : 'a t -> 'b t -> init:'c -> f:('c -> 'a -> 'b -> 'c) -> 'c\n val for_all2_exn : 'a t -> 'b t -> f:('a -> 'b -> bool) -> bool\n val exists2_exn : 'a t -> 'b t -> f:('a -> 'b -> bool) -> bool\n val filter : 'a t -> f:('a -> bool) -> 'a t\n val filteri : 'a t -> f:(int -> 'a -> bool) -> 'a t\n val swap : 'a t -> int -> int -> unit\n val rev_inplace : 'a t -> unit\n val of_list_rev : 'a list -> 'a t\n val of_list_map : 'a list -> f:('a -> 'b) -> 'b t\n val of_list_mapi : 'a list -> f:(int -> 'a -> 'b) -> 'b t\n val of_list_rev_map : 'a list -> f:('a -> 'b) -> 'b t\n val of_list_rev_mapi : 'a list -> f:(int -> 'a -> 'b) -> 'b t\n val map_inplace : 'a t -> f:('a -> 'a) -> unit\n val find_exn : 'a t -> f:('a -> bool) -> 'a\n val find_map_exn : 'a t -> f:('a -> 'b option) -> 'b\n val findi : 'a t -> f:(int -> 'a -> bool) -> (int * 'a) option\n val findi_exn : 'a t -> f:(int -> 'a -> bool) -> int * 'a\n val find_mapi : 'a t -> f:(int -> 'a -> 'b option) -> 'b option\n val find_mapi_exn : 'a t -> f:(int -> 'a -> 'b option) -> 'b\n val find_consecutive_duplicate : 'a t -> equal:('a -> 'a -> bool) -> ('a * 'a) option\n val reduce : 'a t -> f:('a -> 'a -> 'a) -> 'a option\n val reduce_exn : 'a t -> f:('a -> 'a -> 'a) -> 'a\n val permute : ?random_state:Random.State.t -> 'a t -> unit\n val random_element : ?random_state:Random.State.t -> 'a t -> 'a option\n val random_element_exn : ?random_state:Random.State.t -> 'a t -> 'a\n val zip : 'a t -> 'b t -> ('a * 'b) t option\n val zip_exn : 'a t -> 'b t -> ('a * 'b) t\n val unzip : ('a * 'b) t -> 'a t * 'b t\n val sorted_copy : 'a t -> compare:('a -> 'a -> int) -> 'a t\n val last : 'a t -> 'a\n val equal : ('a -> 'a -> bool) -> 'a t -> 'a t -> bool\n val to_sequence : 'a t -> 'a Core_sequence.t\n val to_sequence_mutable : 'a t -> 'a Core_sequence.t\nend\n\ninclude (T : S with type 'a t := 'a array) [@ocaml.warning \"-3\"]\n\nlet invariant invariant_a t = iter t ~f:invariant_a\nlet max_length = Sys.max_array_length\n\nmodule Int = struct\n include T.Int\n\n type t = t_ [@@deriving bin_io, compare, sexp]\nend\n\nmodule Float = struct\n include T.Float\n\n type t = t_ [@@deriving bin_io, compare, sexp]\nend\n\nmodule Check1 (M : S) : sig\n type ('a, -'perm) t_\n\n include Permissioned with type ('a, 'perm) t := ('a, 'perm) t_\nend = struct\n include M\n\n type ('a, -'perm) t_ = 'a t\nend\n\nmodule Check2 (M : Permissioned) : sig\n type 'a t_\n\n include S with type 'a t := 'a t_\nend = struct\n include M\n\n type 'a t_ = ('a, read_write) t\nend\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n include Base.Source_code_position\n\n type t = Base.Source_code_position.t =\n { pos_fname : string\n ; pos_lnum : int\n ; pos_bol : int\n ; pos_cnum : int\n }\n [@@deriving bin_io, compare, hash, sexp]\n end\nend\n\ninclude Stable.V1\n\nlet to_string = Base.Source_code_position.to_string\nlet sexp_of_t = Base.Source_code_position.sexp_of_t\n","(* This module is trying to minimize dependencies on modules in Core, so as to allow\n [Info], [Error], and [Or_error] to be used in is many places places as possible.\n Please avoid adding new dependencies. *)\n\nopen! Import\nopen! Info_intf\n\nmodule type S = Base.Info.S\n\nmodule Source_code_position = Source_code_position0\nmodule Binable = Binable0\n\nmodule Sexp = struct\n include Sexplib.Sexp\n\n include (\n struct\n type t = Base.Sexp.t =\n | Atom of string\n | List of t list\n [@@deriving bin_io, compare, hash]\n end :\n sig\n type t [@@deriving bin_io, compare, hash]\n end\n with type t := t)\nend\n\nmodule Binable_exn = struct\n module Stable = struct\n module V1 = struct\n module T = struct\n type t = exn [@@deriving sexp_of]\n end\n\n include T\n\n include Binable.Stable.Of_binable.V1 [@alert \"-legacy\"]\n (Sexp)\n (struct\n include T\n\n let to_binable t = t |> [%sexp_of: t]\n let of_binable = Exn.create_s\n end)\n end\n end\nend\n\nmodule Extend (Info : Base.Info.S) = struct\n include Info\n\n module Internal_repr = struct\n module Stable = struct\n module Binable_exn = Binable_exn.Stable\n\n module Source_code_position = struct\n module V1 = struct\n type t = Source_code_position.Stable.V1.t [@@deriving bin_io]\n\n (* [sexp_of_t] as defined here is unstable; this is OK because there is no\n [t_of_sexp]. [sexp_of_t] is only used to produce a sexp that is never\n deserialized as a [Source_code_position]. *)\n let sexp_of_t = Source_code_position.sexp_of_t\n end\n end\n\n module V2 = struct\n type t = Info.Internal_repr.t =\n | Could_not_construct of Sexp.t\n | String of string\n | Exn of Binable_exn.V1.t\n | Sexp of Sexp.t\n | Tag_sexp of string * Sexp.t * Source_code_position.V1.t option\n | Tag_t of string * t\n | Tag_arg of string * Sexp.t * t\n | Of_list of int option * t list\n | With_backtrace of t * string (* backtrace *)\n [@@deriving bin_io, sexp_of]\n end\n end\n\n include Stable.V2\n\n let to_info = Info.Internal_repr.to_info\n let of_info = Info.Internal_repr.of_info\n end\n\n module Stable = struct\n module V2 = struct\n module T = struct\n type t = Info.t [@@deriving sexp, compare, hash]\n end\n\n include T\n include Comparator.Stable.V1.Make (T)\n\n include Binable.Stable.Of_binable.V1 [@alert \"-legacy\"]\n (Internal_repr.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable = Info.Internal_repr.of_info\n let of_binable = Info.Internal_repr.to_info\n end)\n end\n\n module V1 = struct\n module T = struct\n type t = Info.t [@@deriving compare]\n\n include Sexpable.Stable.Of_sexpable.V1\n (Sexp)\n (struct\n type nonrec t = t\n\n let to_sexpable = Info.sexp_of_t\n let of_sexpable = Info.t_of_sexp\n end)\n\n let compare = compare\n end\n\n include T\n include Comparator.Stable.V1.Make (T)\n\n include Binable.Stable.Of_binable.V1 [@alert \"-legacy\"]\n (Sexp)\n (struct\n type nonrec t = t\n\n let to_binable = sexp_of_t\n let of_binable = t_of_sexp\n end)\n end\n end\n\n type t = Stable.V2.t [@@deriving bin_io]\nend\n\ninclude Extend (Base.Info)\n\n","include Base.Error\ninclude Info.Extend (Base.Error)\n\nlet failwiths ?strict ~here message a sexp_of_a =\n raise (create ?strict ~here message a sexp_of_a)\n;;\n\nlet failwithp ?strict here message a sexp_of_a =\n raise (create ?strict ~here message a sexp_of_a)\n;;\n","(** Derived from [Base.T]. Used for matching bare signatures with just a type. *)\n\nopen! Import\ninclude Base.T\n\nmodule type T_bin = sig\n type t [@@deriving bin_io]\nend\n","open! Import\nopen! Typerep_lib.Std\nmodule Array = Base.Array\ninclude Base.List\n\ntype 'a t = 'a list [@@deriving bin_io, typerep]\n\nmodule Assoc = struct\n include Assoc\n\n type ('a, 'b) t = ('a * 'b) list [@@deriving bin_io]\n\n let[@deprecated\n \"[since 2016-06] This does not respect the equivalence class promised by \\\n List.Assoc. Use List.compare directly if that's what you want.\"] compare\n (type a b)\n compare_a\n compare_b\n =\n [%compare: (a * b) list]\n ;;\nend\n\nlet to_string ~f t =\n Sexplib.Sexp.to_string (sexp_of_t (fun x -> Sexplib.Sexp.Atom x) (map t ~f))\n;;\n\ninclude Comparator.Derived (struct\n type nonrec 'a t = 'a t [@@deriving sexp_of, compare]\n end)\n\nlet quickcheck_generator = Base_quickcheck.Generator.list\nlet gen_non_empty = Base_quickcheck.Generator.list_non_empty\n\nlet gen_with_length length quickcheck_generator =\n Base_quickcheck.Generator.list_with_length quickcheck_generator ~length\n;;\n\nlet gen_filtered = Base_quickcheck.Generator.list_filtered\nlet gen_permutations = Base_quickcheck.Generator.list_permutations\nlet quickcheck_observer = Base_quickcheck.Observer.list\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.list\n","open! Import\nopen Hashtbl_intf\nmodule Avltree = Avltree\nmodule Binable = Binable0\nmodule Hashable = Hashtbl_intf.Hashable\nmodule Merge_into_action = Hashtbl_intf.Merge_into_action\nmodule List = List0\n\nlet failwiths = Error.failwiths\n\nmodule Creators = Hashtbl.Creators\n\ninclude (\n Hashtbl :\n sig\n type ('a, 'b) t = ('a, 'b) Hashtbl.t [@@deriving sexp_of]\n\n include Base.Hashtbl.S_without_submodules with type ('a, 'b) t := ('a, 'b) t\n end)\n\nmodule Using_hashable = struct\n type nonrec ('a, 'b) t = ('a, 'b) t [@@deriving sexp_of]\n\n let create ?growth_allowed ?size ~hashable () =\n create ?growth_allowed ?size (Base.Hashable.to_key hashable)\n ;;\n\n let of_alist ?growth_allowed ?size ~hashable l =\n of_alist ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\n\n let of_alist_report_all_dups ?growth_allowed ?size ~hashable l =\n of_alist_report_all_dups ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\n\n let of_alist_or_error ?growth_allowed ?size ~hashable l =\n of_alist_or_error ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\n\n let of_alist_exn ?growth_allowed ?size ~hashable l =\n of_alist_exn ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\n\n let of_alist_multi ?growth_allowed ?size ~hashable l =\n of_alist_multi ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\n\n let create_mapped ?growth_allowed ?size ~hashable ~get_key ~get_data l =\n create_mapped\n ?growth_allowed\n ?size\n (Base.Hashable.to_key hashable)\n ~get_key\n ~get_data\n l\n ;;\n\n let create_with_key ?growth_allowed ?size ~hashable ~get_key l =\n create_with_key ?growth_allowed ?size (Base.Hashable.to_key hashable) ~get_key l\n ;;\n\n let create_with_key_or_error ?growth_allowed ?size ~hashable ~get_key l =\n create_with_key_or_error\n ?growth_allowed\n ?size\n (Base.Hashable.to_key hashable)\n ~get_key\n l\n ;;\n\n let create_with_key_exn ?growth_allowed ?size ~hashable ~get_key l =\n create_with_key_exn ?growth_allowed ?size (Base.Hashable.to_key hashable) ~get_key l\n ;;\n\n let group ?growth_allowed ?size ~hashable ~get_key ~get_data ~combine l =\n group\n ?growth_allowed\n ?size\n (Base.Hashable.to_key hashable)\n ~get_key\n ~get_data\n ~combine\n l\n ;;\nend\n\nmodule type S_plain = S_plain with type ('a, 'b) hashtbl = ('a, 'b) t\nmodule type S = S with type ('a, 'b) hashtbl = ('a, 'b) t\nmodule type S_binable = S_binable with type ('a, 'b) hashtbl = ('a, 'b) t\nmodule type Key_plain = Key_plain\nmodule type Key = Key\nmodule type Key_binable = Key_binable\n\nmodule Poly = struct\n include Hashtbl.Poly\n\n include Bin_prot.Utils.Make_iterable_binable2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n type ('a, 'b) el = 'a * 'b [@@deriving bin_io]\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"8f3e445c-4992-11e6-a279-3703be311e7b\"\n ;;\n\n let module_name = Some \"Core_kernel.Hashtbl\"\n let length = length\n let iter t ~f = iteri t ~f:(fun ~key ~data -> f (key, data))\n\n let init ~len ~next =\n let t = create ~size:len () in\n for _i = 0 to len - 1 do\n let key, data = next () in\n match find t key with\n | None -> set t ~key ~data\n | Some _ -> failwith \"Core_hashtbl.bin_read_t_: duplicate key\"\n done;\n t\n ;;\n end)\nend\n\nmodule Make_plain (Key : Key_plain) = struct\n let hashable =\n { Hashable.hash = Key.hash; compare = Key.compare; sexp_of_t = Key.sexp_of_t }\n ;;\n\n type key = Key.t\n type ('a, 'b) hashtbl = ('a, 'b) t\n type 'a t = (Key.t, 'a) hashtbl\n type ('a, 'b) t__ = (Key.t, 'b) hashtbl\n type 'a key_ = Key.t\n\n include Creators (struct\n type 'a t = Key.t\n\n let hashable = hashable\n end)\n\n include (\n Hashtbl :\n sig\n include\n Hashtbl.Accessors\n with type ('a, 'b) t := ('a, 'b) t__\n with type 'a key := 'a key_\n\n include\n Hashtbl.Multi with type ('a, 'b) t := ('a, 'b) t__ with type 'a key := 'a key_\n\n include Invariant.S2 with type ('a, 'b) t := ('a, 'b) hashtbl\n end)\n\n let invariant invariant_key t = invariant ignore invariant_key t\n let sexp_of_t sexp_of_v t = Poly.sexp_of_t Key.sexp_of_t sexp_of_v t\n\n module Provide_of_sexp\n (Key : sig\n type t [@@deriving of_sexp]\n end\n with type t := key) =\n struct\n let t_of_sexp v_of_sexp sexp = t_of_sexp Key.t_of_sexp v_of_sexp sexp\n end\n\n module Provide_bin_io\n (Key' : sig\n type t [@@deriving bin_io]\n end\n with type t := key) =\n Bin_prot.Utils.Make_iterable_binable1 (struct\n module Key = struct\n include Key\n include Key'\n end\n\n type nonrec 'a t = 'a t\n type 'a el = Key.t * 'a [@@deriving bin_io]\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"8fabab0a-4992-11e6-8cca-9ba2c4686d9e\"\n ;;\n\n let module_name = Some \"Core_kernel.Hashtbl\"\n let length = length\n let iter t ~f = iteri t ~f:(fun ~key ~data -> f (key, data))\n\n let init ~len ~next =\n let t = create ~size:len () in\n for _i = 0 to len - 1 do\n let key, data = next () in\n match find t key with\n | None -> set t ~key ~data\n | Some _ ->\n failwiths\n ~here:[%here]\n \"Hashtbl.bin_read_t: duplicate key\"\n key\n [%sexp_of: Key.t]\n done;\n t\n ;;\n end)\nend\n\nmodule Make (Key : Key) = struct\n include Make_plain (Key)\n include Provide_of_sexp (Key)\nend\n\nmodule Make_binable (Key : Key_binable) = struct\n include Make (Key)\n include Provide_bin_io (Key)\nend\n\nmodule M = Hashtbl.M\n\nmodule type For_deriving = For_deriving\n\ninclude (Hashtbl : For_deriving with type ('a, 'b) t := ('a, 'b) t)\n\nlet hashable = Hashtbl.Private.hashable\n","open! Import\nopen Hash_set_intf\ninclude Base.Hash_set\n\nmodule type S_plain = S_plain with type 'a hash_set := 'a t\nmodule type S = S with type 'a hash_set := 'a t\nmodule type S_binable = S_binable with type 'a hash_set := 'a t\nmodule type Elt_plain = Hashtbl.Key_plain\nmodule type Elt = Hashtbl.Key\nmodule type Elt_binable = Hashtbl.Key_binable\n\nmodule Make_plain (Elt : Elt_plain) = struct\n type elt = Elt.t\n type nonrec t = elt t\n type 'a elt_ = elt\n\n include Creators (struct\n type 'a t = Elt.t\n\n let hashable = Hashtbl.Hashable.of_key (module Elt)\n end)\n\n let sexp_of_t t = Poly.sexp_of_t Elt.sexp_of_t t\n\n module Provide_of_sexp\n (X : sig\n type t [@@deriving of_sexp]\n end\n with type t := elt) =\n struct\n let t_of_sexp sexp = t_of_sexp X.t_of_sexp sexp\n end\n\n module Provide_bin_io\n (X : sig\n type t [@@deriving bin_io]\n end\n with type t := elt) =\n Bin_prot.Utils.Make_iterable_binable (struct\n module Elt = struct\n include Elt\n include X\n end\n\n type nonrec t = t\n type el = Elt.t [@@deriving bin_io]\n\n let _ = bin_el\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"ad381672-4992-11e6-9e36-b76dc8cd466f\"\n ;;\n\n let module_name = Some \"Core_kernel.Hash_set\"\n let length = length\n let iter = iter\n\n let init ~len ~next =\n let t = create ~size:len () in\n for _i = 0 to len - 1 do\n let v = next () in\n add t v\n done;\n t\n ;;\n end)\nend\n\nmodule Make (Elt : Elt) = struct\n include Make_plain (Elt)\n include Provide_of_sexp (Elt)\nend\n\nmodule Make_binable (Elt : Elt_binable) = struct\n include Make (Elt)\n include Provide_bin_io (Elt)\nend\n\nmodule Using_hashable = struct\n type 'a elt = 'a\n\n let create ?growth_allowed ?size ~hashable () =\n create ?growth_allowed ?size (Base.Hashable.to_key hashable)\n ;;\n\n let of_list ?growth_allowed ?size ~hashable l =\n of_list ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\nend\n\nlet hashable = Private.hashable\nlet create ?growth_allowed ?size m = create ?growth_allowed ?size m\n","open! Import\ninclude Base.Or_error\n\ntype 'a t = ('a, Error.t) Result.t [@@deriving bin_io]\n\nmodule Expect_test_config = struct\n module IO = Base.Or_error\n module IO_run = IO\n\n module IO_flush = struct\n include IO\n\n let to_run t = t\n end\n\n let flush () = return ()\n let run f = ok_exn (f ())\n let flushed () = true\n let upon_unreleasable_issue = Expect_test_config.upon_unreleasable_issue\nend\n\nmodule Stable = struct\n module V1 = struct\n type 'a t = ('a, Error.Stable.V1.t) Result.Stable.V1.t\n [@@deriving bin_io, compare, sexp]\n\n let map x ~f = Result.Stable.V1.map x ~f1:f ~f2:Fn.id\n end\n\n module V2 = struct\n type 'a t = ('a, Error.Stable.V2.t) Result.Stable.V1.t\n [@@deriving bin_io, compare, sexp]\n\n let map x ~f = Result.Stable.V1.map x ~f1:f ~f2:Fn.id\n end\nend\n","open! Import\nopen Map_intf\nmodule List = List0\n\nmodule Symmetric_diff_element = struct\n module Stable = struct\n module V1 = struct\n type ('k, 'v) t = 'k * [ `Left of 'v | `Right of 'v | `Unequal of 'v * 'v ]\n [@@deriving bin_io, compare, sexp]\n\n let%expect_test _ =\n print_endline [%bin_digest: (int, string) t];\n [%expect {| 00674be9fe8dfe9e9ad476067d7d8101 |}]\n ;;\n\n let map (k, diff) ~f1 ~f2 =\n let k = f1 k in\n let diff =\n match diff with\n | `Left v -> `Left (f2 v)\n | `Right v -> `Right (f2 v)\n | `Unequal (v1, v2) -> `Unequal (f2 v1, f2 v2)\n in\n k, diff\n ;;\n\n let map_data t ~f = map t ~f1:Fn.id ~f2:f\n\n let left (_key, diff) =\n match diff with\n | `Left x | `Unequal (x, _) -> Some x\n | `Right _ -> None\n ;;\n\n let right (_key, diff) =\n match diff with\n | `Right x | `Unequal (_, x) -> Some x\n | `Left _ -> None\n ;;\n end\n end\n\n include Stable.V1\nend\n\nmodule Continue_or_stop = Base.Map.Continue_or_stop\nmodule Finished_or_unfinished = Base.Map.Finished_or_unfinished\n\ntype ('k, 'cmp) comparator =\n (module Comparator.S with type t = 'k and type comparator_witness = 'cmp)\n\nlet to_comparator (type k cmp) ((module M) : (k, cmp) Map.comparator) = M.comparator\n\nlet of_comparator (type k cmp) comparator : (k, cmp) Map.comparator =\n (module struct\n type t = k\n type comparator_witness = cmp\n\n let comparator = comparator\n end)\n;;\n\nmodule For_quickcheck = struct\n let gen_tree ~comparator k_gen v_gen =\n Base_quickcheck.Generator.map_tree_using_comparator ~comparator k_gen v_gen\n ;;\n\n let quickcheck_generator ~comparator k_gen v_gen =\n Base_quickcheck.Generator.map_t_m (of_comparator comparator) k_gen v_gen\n ;;\n\n let obs_tree k_obs v_obs = Base_quickcheck.Observer.map_tree k_obs v_obs\n\n let shr_tree ~comparator k_shr v_shr =\n Base_quickcheck.Shrinker.map_tree_using_comparator ~comparator k_shr v_shr\n ;;\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.map_t_m\nlet quickcheck_observer = Base_quickcheck.Observer.map_t\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.map_t\n\nmodule Using_comparator = struct\n include Map.Using_comparator\n include For_quickcheck\n\n let of_hashtbl_exn ~comparator hashtbl =\n match of_iteri ~comparator ~iteri:(Hashtbl.iteri hashtbl) with\n | `Ok map -> map\n | `Duplicate_key key ->\n Error.failwiths\n ~here:[%here]\n \"Map.of_hashtbl_exn: duplicate key\"\n key\n comparator.sexp_of_t\n ;;\n\n let tree_of_hashtbl_exn ~comparator hashtbl =\n to_tree (of_hashtbl_exn ~comparator hashtbl)\n ;;\n\n let key_set ~comparator t =\n Base.Set.Using_comparator.of_sorted_array_unchecked\n ~comparator\n (List.to_array (keys t))\n ;;\n\n let key_set_of_tree ~comparator t = key_set ~comparator (of_tree ~comparator t)\n\n let of_key_set key_set ~f =\n of_sorted_array_unchecked\n ~comparator:(Base.Set.comparator key_set)\n (Array.map (Base.Set.to_array key_set) ~f:(fun key -> key, f key))\n ;;\n\n let tree_of_key_set key_set ~f = to_tree (of_key_set key_set ~f)\nend\n\nmodule Accessors = struct\n include (\n Map.Using_comparator :\n Map.Accessors3\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) Map.t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t)\n\n let quickcheck_observer k v = quickcheck_observer k v\n let quickcheck_shrinker k v = quickcheck_shrinker k v\n let key_set t = Using_comparator.key_set t ~comparator:(Using_comparator.comparator t)\nend\n\nlet key_set t = Using_comparator.key_set ~comparator:(Using_comparator.comparator t) t\nlet of_key_set = Using_comparator.of_key_set\nlet hash_fold_direct = Using_comparator.hash_fold_direct\nlet comparator = Using_comparator.comparator\nlet comparator_s = Base.Map.comparator_s\n\ntype 'k key = 'k\ntype 'c cmp = 'c\n\ninclude (\nstruct\n include Map\n\n let of_tree m = Map.Using_comparator.of_tree ~comparator:(to_comparator m)\n let to_tree = Map.Using_comparator.to_tree\nend :\nsig\n type ('a, 'b, 'c) t = ('a, 'b, 'c) Map.t\n\n include\n Map.Creators_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Map.With_first_class_module.t\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n with type 'k key := 'k key\n with type 'c cmp := 'c cmp\n\n include\n Map.Accessors3\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\nend)\n\nmodule Empty_without_value_restriction = Using_comparator.Empty_without_value_restriction\n\nlet find_or_error t key =\n let comparator = comparator t in\n match find t key with\n | Some data -> Ok data\n | None ->\n let sexp_of_key = comparator.sexp_of_t in\n Or_error.error_s [%message \"key not found\" ~_:(key : key)]\n;;\n\nlet merge_skewed = Map.merge_skewed\nlet of_hashtbl_exn m t = Using_comparator.of_hashtbl_exn ~comparator:(to_comparator m) t\n\nmodule Creators (Key : Comparator.S1) : sig\n type ('a, 'b, 'c) t_ = ('a Key.t, 'b, Key.comparator_witness) t\n type ('a, 'b, 'c) tree = ('a, 'b, Key.comparator_witness) Tree.t\n type ('a, 'b, 'c) options = ('a, 'b, 'c) Without_comparator.t\n\n val t_of_sexp\n : (Base.Sexp.t -> 'a Key.t)\n -> (Base.Sexp.t -> 'b)\n -> Base.Sexp.t\n -> ('a, 'b, _) t_\n\n include\n Creators_generic\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t_\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) tree\n with type 'a key := 'a Key.t\n with type 'a cmp := Key.comparator_witness\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) options\nend = struct\n type ('a, 'b, 'c) options = ('a, 'b, 'c) Without_comparator.t\n\n let comparator = Key.comparator\n\n type ('a, 'b, 'c) t_ = ('a Key.t, 'b, Key.comparator_witness) t\n type ('a, 'b, 'c) tree = ('a, 'b, Key.comparator_witness) Tree.t\n\n module M_empty = Empty_without_value_restriction (Key)\n\n let empty = M_empty.empty\n let of_tree tree = Using_comparator.of_tree ~comparator tree\n let singleton k v = Using_comparator.singleton ~comparator k v\n\n let of_sorted_array_unchecked array =\n Using_comparator.of_sorted_array_unchecked ~comparator array\n ;;\n\n let of_sorted_array array = Using_comparator.of_sorted_array ~comparator array\n\n let of_increasing_iterator_unchecked ~len ~f =\n Using_comparator.of_increasing_iterator_unchecked ~comparator ~len ~f\n ;;\n\n let of_increasing_sequence seq =\n Using_comparator.of_increasing_sequence ~comparator seq\n ;;\n\n let of_sequence seq = Using_comparator.of_sequence ~comparator seq\n let of_sequence_or_error seq = Using_comparator.of_sequence_or_error ~comparator seq\n let of_sequence_exn seq = Using_comparator.of_sequence_exn ~comparator seq\n let of_sequence_multi seq = Using_comparator.of_sequence_multi ~comparator seq\n\n let of_sequence_fold seq ~init ~f =\n Using_comparator.of_sequence_fold ~comparator seq ~init ~f\n ;;\n\n let of_sequence_reduce seq ~f = Using_comparator.of_sequence_reduce ~comparator seq ~f\n let of_alist alist = Using_comparator.of_alist ~comparator alist\n let of_alist_or_error alist = Using_comparator.of_alist_or_error ~comparator alist\n let of_alist_exn alist = Using_comparator.of_alist_exn ~comparator alist\n let of_hashtbl_exn hashtbl = Using_comparator.of_hashtbl_exn ~comparator hashtbl\n let of_alist_multi alist = Using_comparator.of_alist_multi ~comparator alist\n\n let of_alist_fold alist ~init ~f =\n Using_comparator.of_alist_fold ~comparator alist ~init ~f\n ;;\n\n let of_alist_reduce alist ~f = Using_comparator.of_alist_reduce ~comparator alist ~f\n let of_iteri ~iteri = Using_comparator.of_iteri ~comparator ~iteri\n\n let t_of_sexp k_of_sexp v_of_sexp sexp =\n Using_comparator.t_of_sexp_direct ~comparator k_of_sexp v_of_sexp sexp\n ;;\n\n let of_key_set key_set ~f = Using_comparator.of_key_set key_set ~f\n\n let quickcheck_generator gen_k gen_v =\n Using_comparator.quickcheck_generator ~comparator gen_k gen_v\n ;;\nend\n\nmodule Make_tree (Key : Comparator.S1) = struct\n open Tree\n\n let comparator = Key.comparator\n let sexp_of_t = sexp_of_t\n let t_of_sexp a b c = t_of_sexp_direct a b c ~comparator\n let empty = empty_without_value_restriction\n let of_tree tree = tree\n let singleton a = singleton a ~comparator\n let of_sorted_array_unchecked a = of_sorted_array_unchecked a ~comparator\n let of_sorted_array a = of_sorted_array a ~comparator\n\n let of_increasing_iterator_unchecked ~len ~f =\n of_increasing_iterator_unchecked ~len ~f ~comparator\n ;;\n\n let of_increasing_sequence seq = of_increasing_sequence ~comparator seq\n let of_sequence s = of_sequence s ~comparator\n let of_sequence_or_error s = of_sequence_or_error s ~comparator\n let of_sequence_exn s = of_sequence_exn s ~comparator\n let of_sequence_multi s = of_sequence_multi s ~comparator\n let of_sequence_fold s ~init ~f = of_sequence_fold s ~init ~f ~comparator\n let of_sequence_reduce s ~f = of_sequence_reduce s ~f ~comparator\n let of_alist a = of_alist a ~comparator\n let of_alist_or_error a = of_alist_or_error a ~comparator\n let of_alist_exn a = of_alist_exn a ~comparator\n let of_hashtbl_exn a = Using_comparator.tree_of_hashtbl_exn a ~comparator\n let of_alist_multi a = of_alist_multi a ~comparator\n let of_alist_fold a ~init ~f = of_alist_fold a ~init ~f ~comparator\n let of_alist_reduce a ~f = of_alist_reduce a ~f ~comparator\n let of_iteri ~iteri = of_iteri ~iteri ~comparator\n let of_key_set = Using_comparator.tree_of_key_set\n let to_tree t = t\n let invariants a = invariants a ~comparator\n let is_empty a = is_empty a\n let length a = length a\n let set a ~key ~data = set a ~key ~data ~comparator\n let add a ~key ~data = add a ~key ~data ~comparator\n let add_exn a ~key ~data = add_exn a ~key ~data ~comparator\n let add_multi a ~key ~data = add_multi a ~key ~data ~comparator\n let remove_multi a b = remove_multi a b ~comparator\n let find_multi a b = find_multi a b ~comparator\n let change a b ~f = change a b ~f ~comparator\n let update a b ~f = update a b ~f ~comparator\n let find_exn a b = find_exn a b ~comparator\n let find a b = find a b ~comparator\n let remove a b = remove a b ~comparator\n let mem a b = mem a b ~comparator\n let iter_keys = iter_keys\n let iter = iter\n let iteri = iteri\n let iteri_until = iteri_until\n let iter2 a b ~f = iter2 a b ~f ~comparator\n let map = map\n let mapi = mapi\n let fold = fold\n let fold_right = fold_right\n let fold2 a b ~init ~f = fold2 a b ~init ~f ~comparator\n let filter_keys a ~f = filter_keys a ~f ~comparator\n let filter a ~f = filter a ~f ~comparator\n let filteri a ~f = filteri a ~f ~comparator\n let filter_map a ~f = filter_map a ~f ~comparator\n let filter_mapi a ~f = filter_mapi a ~f ~comparator\n let partition_mapi t ~f = partition_mapi t ~f ~comparator\n let partition_map t ~f = partition_map t ~f ~comparator\n let partitioni_tf t ~f = partitioni_tf t ~f ~comparator\n let partition_tf t ~f = partition_tf t ~f ~comparator\n let combine_errors t = combine_errors t ~comparator\n let compare_direct a b c = compare_direct a b c ~comparator\n let equal a b c = equal a b c ~comparator\n let keys = keys\n let data = data\n let to_alist = to_alist\n let validate = validate\n let validatei = validatei\n let symmetric_diff a b ~data_equal = symmetric_diff a b ~data_equal ~comparator\n\n let fold_symmetric_diff a b ~data_equal ~init ~f =\n fold_symmetric_diff a b ~data_equal ~f ~init ~comparator\n ;;\n\n let merge a b ~f = merge a b ~f ~comparator\n let min_elt = min_elt\n let min_elt_exn = min_elt_exn\n let max_elt = max_elt\n let max_elt_exn = max_elt_exn\n let for_all = for_all\n let for_alli = for_alli\n let exists = exists\n let existsi = existsi\n let count = count\n let counti = counti\n let split a b = split a b ~comparator\n let append ~lower_part ~upper_part = append ~lower_part ~upper_part ~comparator\n\n let subrange t ~lower_bound ~upper_bound =\n subrange t ~lower_bound ~upper_bound ~comparator\n ;;\n\n let fold_range_inclusive t ~min ~max ~init ~f =\n fold_range_inclusive t ~min ~max ~init ~f ~comparator\n ;;\n\n let range_to_alist t ~min ~max = range_to_alist t ~min ~max ~comparator\n let closest_key a b c = closest_key a b c ~comparator\n let nth a = nth a ~comparator\n let nth_exn a = nth_exn a ~comparator\n let rank a b = rank a b ~comparator\n\n let to_sequence ?order ?keys_greater_or_equal_to ?keys_less_or_equal_to t =\n to_sequence ~comparator ?order ?keys_greater_or_equal_to ?keys_less_or_equal_to t\n ;;\n\n let binary_search t ~compare how v = binary_search ~comparator t ~compare how v\n\n let binary_search_segmented t ~segment_of how =\n binary_search_segmented ~comparator t ~segment_of how\n ;;\n\n let key_set t = Using_comparator.key_set_of_tree ~comparator t\n let quickcheck_generator k v = For_quickcheck.gen_tree ~comparator k v\n let quickcheck_observer k v = For_quickcheck.obs_tree k v\n let quickcheck_shrinker k v = For_quickcheck.shr_tree ~comparator k v\nend\n\n(* Don't use [of_sorted_array] to avoid the allocation of an intermediate array *)\nlet init_for_bin_prot ~len ~f ~comparator =\n let map = Using_comparator.of_increasing_iterator_unchecked ~len ~f ~comparator in\n if invariants map\n then map\n else (\n (* The invariants are broken, but we can still traverse the structure. *)\n match Using_comparator.of_iteri ~iteri:(iteri map) ~comparator with\n | `Ok map -> map\n | `Duplicate_key _key -> failwith \"Map.bin_read_t: duplicate element in map\")\n;;\n\nmodule Poly = struct\n include Creators (Comparator.Poly)\n\n type ('a, 'b, 'c) map = ('a, 'b, 'c) t\n type ('k, 'v) t = ('k, 'v, Comparator.Poly.comparator_witness) map\n type comparator_witness = Comparator.Poly.comparator_witness\n\n include Accessors\n\n let compare _ cmpv t1 t2 = compare_direct cmpv t1 t2\n\n let sexp_of_t sexp_of_k sexp_of_v t =\n Using_comparator.sexp_of_t sexp_of_k sexp_of_v [%sexp_of: _] t\n ;;\n\n include Bin_prot.Utils.Make_iterable_binable2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n type ('a, 'b) el = 'a * 'b [@@deriving bin_io]\n\n let _ = bin_el\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"b7d7b1a0-4992-11e6-8a32-bbb221fa025c\"\n ;;\n\n let module_name = Some \"Core_kernel.Map\"\n let length = length\n let iter t ~f = iteri t ~f:(fun ~key ~data -> f (key, data))\n\n let init ~len ~next =\n init_for_bin_prot ~len ~f:(fun _ -> next ()) ~comparator:Comparator.Poly.comparator\n ;;\n end)\n\n module Tree = struct\n include Make_tree (Comparator.Poly)\n\n type ('k, +'v) t = ('k, 'v, Comparator.Poly.comparator_witness) tree\n type comparator_witness = Comparator.Poly.comparator_witness\n\n let sexp_of_t sexp_of_k sexp_of_v t = sexp_of_t sexp_of_k sexp_of_v [%sexp_of: _] t\n end\nend\n\nmodule type Key_plain = Key_plain\nmodule type Key = Key\nmodule type Key_binable = Key_binable\nmodule type Key_hashable = Key_hashable\nmodule type Key_binable_hashable = Key_binable_hashable\nmodule type S_plain = S_plain\nmodule type S = S\nmodule type S_binable = S_binable\n\nmodule Key_bin_io = Key_bin_io\n\nmodule Provide_bin_io (Key : Key_bin_io.S) =\n Bin_prot.Utils.Make_iterable_binable1 (struct\n module Key = Key\n\n type nonrec 'v t = (Key.t, 'v, Key.comparator_witness) t\n type 'v el = Key.t * 'v [@@deriving bin_io]\n\n let _ = bin_el\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"dfb300f8-4992-11e6-9c15-73a2ac6b815c\"\n ;;\n\n let module_name = Some \"Core_kernel.Map\"\n let length = length\n let iter t ~f = iteri t ~f:(fun ~key ~data -> f (key, data))\n\n let init ~len ~next =\n init_for_bin_prot ~len ~f:(fun _ -> next ()) ~comparator:Key.comparator\n ;;\n end)\n\nmodule Make_plain_using_comparator (Key : sig\n type t [@@deriving sexp_of]\n\n include Comparator.S with type t := t\n end) =\nstruct\n module Key = Key\n module Key_S1 = Comparator.S_to_S1 (Key)\n include Creators (Key_S1)\n\n type key = Key.t\n type ('a, 'b, 'c) map = ('a, 'b, 'c) t\n type 'v t = (key, 'v, Key.comparator_witness) map\n\n include Accessors\n\n let compare cmpv t1 t2 = compare_direct cmpv t1 t2\n\n let sexp_of_t sexp_of_v t =\n Using_comparator.sexp_of_t Key.sexp_of_t sexp_of_v [%sexp_of: _] t\n ;;\n\n module Provide_of_sexp\n (Key : sig\n type t [@@deriving of_sexp]\n end\n with type t := Key.t) =\n struct\n let t_of_sexp v_of_sexp sexp = t_of_sexp Key.t_of_sexp v_of_sexp sexp\n end\n\n module Provide_hash (Key' : Hasher.S with type t := Key.t) = struct\n let hash_fold_t (type a) hash_fold_data state (t : a t) =\n Using_comparator.hash_fold_direct Key'.hash_fold_t hash_fold_data state t\n ;;\n end\n\n module Provide_bin_io\n (Key' : sig\n type t [@@deriving bin_io]\n end\n with type t := Key.t) =\n Provide_bin_io (struct\n include Key\n include Key'\n end)\n\n module Tree = struct\n include Make_tree (Key_S1)\n\n type +'v t = (Key.t, 'v, Key.comparator_witness) tree\n\n let sexp_of_t sexp_of_v t = sexp_of_t Key.sexp_of_t sexp_of_v [%sexp_of: _] t\n\n module Provide_of_sexp\n (X : sig\n type t [@@deriving of_sexp]\n end\n with type t := Key.t) =\n struct\n let t_of_sexp v_of_sexp sexp = t_of_sexp X.t_of_sexp v_of_sexp sexp\n end\n end\nend\n\nmodule Make_plain (Key : Key_plain) = Make_plain_using_comparator (struct\n include Key\n include Comparator.Make (Key)\n end)\n\nmodule Make_using_comparator (Key_sexp : sig\n type t [@@deriving sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include Make_plain_using_comparator (Key_sexp)\n module Key = Key_sexp\n include Provide_of_sexp (Key)\n\n module Tree = struct\n include Tree\n include Provide_of_sexp (Key)\n end\nend\n\nmodule Make (Key : Key) = Make_using_comparator (struct\n include Key\n include Comparator.Make (Key)\n end)\n\nmodule Make_binable_using_comparator (Key_bin_sexp : sig\n type t [@@deriving bin_io, sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include Make_using_comparator (Key_bin_sexp)\n module Key = Key_bin_sexp\n include Provide_bin_io (Key)\nend\n\nmodule Make_binable (Key : Key_binable) = Make_binable_using_comparator (struct\n include Key\n include Comparator.Make (Key)\n end)\n\nmodule For_deriving = struct\n module M = Map.M\n\n let bin_shape_m__t (type t c) (m : (t, c) Key_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_shape_t\n ;;\n\n let bin_size_m__t (type t c) (m : (t, c) Key_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_size_t\n ;;\n\n let bin_write_m__t (type t c) (m : (t, c) Key_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_write_t\n ;;\n\n let bin_read_m__t (type t c) (m : (t, c) Key_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_read_t\n ;;\n\n let __bin_read_m__t__ (type t c) (m : (t, c) Key_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.__bin_read_t__\n ;;\n\n module type Quickcheck_generator_m = sig\n include Comparator.S\n\n val quickcheck_generator : t Quickcheck.Generator.t\n end\n\n module type Quickcheck_observer_m = sig\n include Comparator.S\n\n val quickcheck_observer : t Quickcheck.Observer.t\n end\n\n module type Quickcheck_shrinker_m = sig\n include Comparator.S\n\n val quickcheck_shrinker : t Quickcheck.Shrinker.t\n end\n\n let quickcheck_generator_m__t\n (type k cmp)\n (module Key : Quickcheck_generator_m\n with type t = k\n and type comparator_witness = cmp)\n v_generator\n =\n quickcheck_generator (module Key) Key.quickcheck_generator v_generator\n ;;\n\n let quickcheck_observer_m__t\n (type k cmp)\n (module Key : Quickcheck_observer_m\n with type t = k\n and type comparator_witness = cmp)\n v_observer\n =\n quickcheck_observer Key.quickcheck_observer v_observer\n ;;\n\n let quickcheck_shrinker_m__t\n (type k cmp)\n (module Key : Quickcheck_shrinker_m\n with type t = k\n and type comparator_witness = cmp)\n v_shrinker\n =\n quickcheck_shrinker Key.quickcheck_shrinker v_shrinker\n ;;\n\n module type For_deriving = Map.For_deriving\n\n include (Map : For_deriving with type ('a, 'b, 'c) t := ('a, 'b, 'c) t)\nend\n\ninclude For_deriving\n\nmodule Tree = struct\n include Tree\n\n let of_hashtbl_exn = Using_comparator.tree_of_hashtbl_exn\n let key_set = Using_comparator.key_set_of_tree\n let of_key_set = Using_comparator.tree_of_key_set\n let quickcheck_generator ~comparator k v = For_quickcheck.gen_tree ~comparator k v\n let quickcheck_observer k v = For_quickcheck.obs_tree k v\n let quickcheck_shrinker ~comparator k v = For_quickcheck.shr_tree ~comparator k v\nend\n\nmodule Stable = struct\n module V1 = struct\n type nonrec ('k, 'v, 'cmp) t = ('k, 'v, 'cmp) t\n\n module type S = sig\n type key\n type comparator_witness\n type nonrec 'a t = (key, 'a, comparator_witness) t\n\n include Stable_module_types.S1 with type 'a t := 'a t\n end\n\n module Make (Key : Stable_module_types.S0) = Make_binable_using_comparator (Key)\n end\n\n module Symmetric_diff_element = Symmetric_diff_element.Stable\nend\n","open! Import\nmodule List = List0\nopen Set_intf\nmodule Merge_to_sequence_element = Merge_to_sequence_element\nmodule Named = Named\n\nmodule type Elt_plain = Elt_plain\nmodule type Elt = Elt\nmodule type Elt_binable = Elt_binable\n\nlet to_comparator (type k cmp) ((module M) : (k, cmp) Set.comparator) = M.comparator\n\nlet of_comparator (type k cmp) comparator : (k, cmp) Set.comparator =\n (module struct\n type t = k\n type comparator_witness = cmp\n\n let comparator = comparator\n end)\n;;\n\nmodule For_quickcheck = struct\n let quickcheck_generator ~comparator elt_gen =\n Base_quickcheck.Generator.set_t_m (of_comparator comparator) elt_gen\n ;;\n\n let gen_tree ~comparator elt_gen =\n Base_quickcheck.Generator.set_tree_using_comparator ~comparator elt_gen\n ;;\n\n let quickcheck_observer elt_obs = Base_quickcheck.Observer.set_t elt_obs\n let obs_tree elt_obs = Base_quickcheck.Observer.set_tree elt_obs\n let quickcheck_shrinker elt_shr = Base_quickcheck.Shrinker.set_t elt_shr\n\n let shr_tree ~comparator elt_shr =\n Base_quickcheck.Shrinker.set_tree_using_comparator ~comparator elt_shr\n ;;\nend\n\nlet quickcheck_generator m elt_gen =\n For_quickcheck.quickcheck_generator ~comparator:(to_comparator m) elt_gen\n;;\n\nlet quickcheck_observer = For_quickcheck.quickcheck_observer\nlet quickcheck_shrinker = For_quickcheck.quickcheck_shrinker\n\nmodule Tree = struct\n include Tree\n\n let to_map ~comparator t = Map.of_key_set (Set.Using_comparator.of_tree t ~comparator)\n let of_map_keys m = Set.Using_comparator.to_tree (Map.key_set m)\n\n let of_hash_set ~comparator hset =\n Hash_set.fold hset ~init:(empty ~comparator) ~f:(fun t x -> add t x ~comparator)\n ;;\n\n let of_hashtbl_keys ~comparator hashtbl =\n Hashtbl.fold hashtbl ~init:(empty ~comparator) ~f:(fun ~key:x ~data:_ t ->\n add t x ~comparator)\n ;;\n\n let quickcheck_generator = For_quickcheck.gen_tree\n let quickcheck_observer = For_quickcheck.obs_tree\n let quickcheck_shrinker = For_quickcheck.shr_tree\nend\n\nmodule Accessors = struct\n include (\n Set.Using_comparator :\n Set.Accessors2\n with type ('a, 'b) t := ('a, 'b) Set.t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type ('a, 'b) named := ('a, 'b) Set.Named.t)\n\n let to_map = Map.of_key_set\n let quickcheck_observer = quickcheck_observer\n let quickcheck_shrinker = quickcheck_shrinker\nend\n\ntype 'a cmp = 'a\ntype 'a elt = 'a\n\ninclude (\nstruct\n include Set\n\n let of_tree m = Set.Using_comparator.of_tree ~comparator:(to_comparator m)\n let to_tree = Set.Using_comparator.to_tree\n let sexp_of_t = Set.Using_comparator.sexp_of_t\n\n module Empty_without_value_restriction =\n Set.Using_comparator.Empty_without_value_restriction\nend :\nsig\n type ('a, 'b) t = ('a, 'b) Set.t [@@deriving sexp_of]\n\n include\n Set.Creators_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Set.With_first_class_module.t\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) set := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type 'a cmp := 'a cmp\n with type 'a elt := 'a elt\n\n include\n Set.Accessors2\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type ('a, 'b) named := ('a, 'b) Set.Named.t\n with module Named := Named\nend)\n\ntype ('k, 'cmp) comparator =\n (module Comparator.S with type t = 'k and type comparator_witness = 'cmp)\n\nlet compare _ _ t1 t2 = compare_direct t1 t2\n\nmodule Using_comparator = struct\n include (\n Set.Using_comparator :\n module type of struct\n include Set.Using_comparator\n end\n with module Tree := Set.Using_comparator.Tree)\n\n include For_quickcheck\n\n let of_map_keys = Map.key_set\n\n let of_hash_set ~comparator hset =\n of_tree ~comparator (Tree.of_hash_set hset ~comparator)\n ;;\n\n let of_hashtbl_keys ~comparator hashtbl =\n of_tree ~comparator (Tree.of_hashtbl_keys hashtbl ~comparator)\n ;;\nend\n\nlet to_map = Map.of_key_set\nlet of_map_keys = Map.key_set\nlet hash_fold_direct = Using_comparator.hash_fold_direct\nlet comparator = Using_comparator.comparator\nlet of_hash_set m hset = Using_comparator.of_hash_set ~comparator:(to_comparator m) hset\n\nlet of_hashtbl_keys m hashtbl =\n Using_comparator.of_hashtbl_keys ~comparator:(to_comparator m) hashtbl\n;;\n\nmodule Creators (Elt : Comparator.S1) : sig\n type nonrec ('a, 'comparator) t_ = ('a Elt.t, Elt.comparator_witness) t\n type ('a, 'b) tree = ('a, Elt.comparator_witness) Tree.t\n type 'a elt_ = 'a Elt.t\n type 'a cmp_ = Elt.comparator_witness\n\n val t_of_sexp : (Base.Sexp.t -> 'a Elt.t) -> Base.Sexp.t -> ('a, 'comparator) t_\n\n include\n Creators_generic\n with type ('a, 'b) t := ('a, 'b) t_\n with type ('a, 'b) set := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) tree\n with type 'a elt := 'a elt_\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Without_comparator.t\n with type 'a cmp := 'a cmp_\nend = struct\n open Using_comparator\n\n type nonrec ('a, 'comparator) t_ = ('a Elt.t, Elt.comparator_witness) t\n type ('a, 'b) tree = ('a, Elt.comparator_witness) Tree.t\n type 'a elt_ = 'a Elt.t\n type 'cmp cmp_ = Elt.comparator_witness\n\n let comparator = Elt.comparator\n let of_tree tree = of_tree ~comparator tree\n let of_sorted_array_unchecked array = of_sorted_array_unchecked ~comparator array\n\n let of_increasing_iterator_unchecked ~len ~f =\n of_increasing_iterator_unchecked ~comparator ~len ~f\n ;;\n\n let of_sorted_array array = of_sorted_array ~comparator array\n\n module M_empty = Empty_without_value_restriction (Elt)\n\n let empty = M_empty.empty\n let singleton e = singleton ~comparator e\n let union_list l = union_list ~comparator l\n let of_list l = of_list ~comparator l\n let of_hash_set h = of_hash_set ~comparator h\n let of_hashtbl_keys h = of_hashtbl_keys ~comparator h\n let of_array a = of_array ~comparator a\n let stable_dedup_list xs = stable_dedup_list ~comparator xs\n let map t ~f = map ~comparator t ~f\n let filter_map t ~f = filter_map ~comparator t ~f\n\n let t_of_sexp a_of_sexp sexp =\n of_tree (Tree.t_of_sexp_direct a_of_sexp sexp ~comparator)\n ;;\n\n let of_map_keys = Map.key_set\n let quickcheck_generator elt = quickcheck_generator ~comparator elt\nend\n\nmodule Make_tree (Elt : Comparator.S1) = struct\n let comparator = Elt.comparator\n let empty = Tree.empty_without_value_restriction\n let singleton e = Tree.singleton ~comparator e\n let invariants t = Tree.invariants t ~comparator\n let length t = Tree.length t\n let is_empty t = Tree.is_empty t\n let elements t = Tree.elements t\n let min_elt t = Tree.min_elt t\n let min_elt_exn t = Tree.min_elt_exn t\n let max_elt t = Tree.max_elt t\n let max_elt_exn t = Tree.max_elt_exn t\n let choose t = Tree.choose t\n let choose_exn t = Tree.choose_exn t\n let to_list t = Tree.to_list t\n let to_array t = Tree.to_array t\n let iter t ~f = Tree.iter t ~f\n let iter2 a b ~f = Tree.iter2 a b ~f ~comparator\n let exists t ~f = Tree.exists t ~f\n let for_all t ~f = Tree.for_all t ~f\n let count t ~f = Tree.count t ~f\n let sum m t ~f = Tree.sum m t ~f\n let find t ~f = Tree.find t ~f\n let find_exn t ~f = Tree.find_exn t ~f\n let find_map t ~f = Tree.find_map t ~f\n let fold t ~init ~f = Tree.fold t ~init ~f\n let fold_until t ~init ~f = Tree.fold_until t ~init ~f\n let fold_right t ~init ~f = Tree.fold_right t ~init ~f\n let fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\n let map t ~f = Tree.map t ~f ~comparator\n let filter t ~f = Tree.filter t ~f ~comparator\n let filter_map t ~f = Tree.filter_map t ~f ~comparator\n let partition_tf t ~f = Tree.partition_tf t ~f ~comparator\n let mem t a = Tree.mem t a ~comparator\n let add t a = Tree.add t a ~comparator\n let remove t a = Tree.remove t a ~comparator\n let union t1 t2 = Tree.union t1 t2 ~comparator\n let inter t1 t2 = Tree.inter t1 t2 ~comparator\n let diff t1 t2 = Tree.diff t1 t2 ~comparator\n let symmetric_diff t1 t2 = Tree.symmetric_diff t1 t2 ~comparator\n let compare_direct t1 t2 = Tree.compare_direct ~comparator t1 t2\n let equal t1 t2 = Tree.equal t1 t2 ~comparator\n let is_subset t ~of_ = Tree.is_subset t ~of_ ~comparator\n let are_disjoint t1 t2 = Tree.are_disjoint t1 t2 ~comparator\n let of_list l = Tree.of_list l ~comparator\n let of_hash_set h = Tree.of_hash_set h ~comparator\n let of_hashtbl_keys h = Tree.of_hashtbl_keys h ~comparator\n let of_array a = Tree.of_array a ~comparator\n let of_sorted_array_unchecked a = Tree.of_sorted_array_unchecked a ~comparator\n\n let of_increasing_iterator_unchecked ~len ~f =\n Tree.of_increasing_iterator_unchecked ~len ~f ~comparator\n ;;\n\n let of_sorted_array a = Tree.of_sorted_array a ~comparator\n let union_list l = Tree.union_list l ~comparator\n let stable_dedup_list xs = Tree.stable_dedup_list xs ~comparator\n let group_by t ~equiv = Tree.group_by t ~equiv ~comparator\n let split t a = Tree.split t a ~comparator\n let nth t i = Tree.nth t i\n let remove_index t i = Tree.remove_index t i ~comparator\n let to_tree t = t\n let of_tree t = t\n\n let to_sequence ?order ?greater_or_equal_to ?less_or_equal_to t =\n Tree.to_sequence ~comparator ?order ?greater_or_equal_to ?less_or_equal_to t\n ;;\n\n let binary_search t ~compare how v = Tree.binary_search ~comparator t ~compare how v\n\n let binary_search_segmented t ~segment_of how =\n Tree.binary_search_segmented ~comparator t ~segment_of how\n ;;\n\n let merge_to_sequence ?order ?greater_or_equal_to ?less_or_equal_to t t' =\n Tree.merge_to_sequence ~comparator ?order ?greater_or_equal_to ?less_or_equal_to t t'\n ;;\n\n let of_map_keys = Tree.of_map_keys\n let to_map t ~f = Tree.to_map ~comparator t ~f\n\n module Named = struct\n let is_subset t ~of_ = Tree.Named.is_subset t ~of_ ~comparator\n let equal t1 t2 = Tree.Named.equal t1 t2 ~comparator\n end\n\n let quickcheck_generator elt = For_quickcheck.gen_tree elt ~comparator\n let quickcheck_observer elt = For_quickcheck.obs_tree elt\n let quickcheck_shrinker elt = For_quickcheck.shr_tree elt ~comparator\nend\n\n(* Don't use [of_sorted_array] to avoid the allocation of an intermediate array *)\nlet init_for_bin_prot ~len ~f ~comparator =\n let set = Using_comparator.of_increasing_iterator_unchecked ~comparator ~len ~f in\n if invariants set\n then set\n else\n Using_comparator.of_tree\n ~comparator\n (fold set ~init:(Tree.empty ~comparator) ~f:(fun acc elt ->\n if Tree.mem acc elt ~comparator\n then failwith \"Set.bin_read_t: duplicate element in map\"\n else Tree.add acc elt ~comparator))\n;;\n\nmodule Poly = struct\n module Elt = Comparator.Poly\n include Creators (Elt)\n\n type nonrec 'a t = ('a, Elt.comparator_witness) t\n type 'a named = ('a, Elt.comparator_witness) Named.t\n\n include Accessors\n\n let compare _ t1 t2 = compare_direct t1 t2\n let sexp_of_t sexp_of_k t = sexp_of_t sexp_of_k [%sexp_of: _] t\n\n include Bin_prot.Utils.Make_iterable_binable1 (struct\n type nonrec 'a t = 'a t\n type 'a el = 'a [@@deriving bin_io]\n\n let _ = bin_el\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"88bcc478-4992-11e6-a95d-ff4831acf410\"\n ;;\n\n let module_name = Some \"Core_kernel.Set\"\n let length = length\n let iter t ~f = iter ~f:(fun key -> f key) t\n\n let init ~len ~next =\n init_for_bin_prot ~len ~f:(fun _ -> next ()) ~comparator:Comparator.Poly.comparator\n ;;\n end)\n\n module Tree = struct\n include Make_tree (Comparator.Poly)\n\n type 'elt t = ('elt, Comparator.Poly.comparator_witness) tree\n type 'a named = ('a, Elt.comparator_witness) Tree.Named.t\n\n let sexp_of_t sexp_of_elt t = Tree.sexp_of_t sexp_of_elt [%sexp_of: _] t\n\n let t_of_sexp elt_of_sexp sexp =\n Tree.t_of_sexp_direct elt_of_sexp sexp ~comparator:Comparator.Poly.comparator\n ;;\n end\nend\n\nmodule type S_plain = S_plain\nmodule type S = S\nmodule type S_binable = S_binable\n\nmodule Elt_bin_io = Elt_bin_io\n\nmodule Provide_bin_io (Elt : Elt_bin_io.S) = Bin_prot.Utils.Make_iterable_binable (struct\n type nonrec t = (Elt.t, Elt.comparator_witness) t\n type el = Elt.t [@@deriving bin_io]\n\n let _ = bin_el\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"8989278e-4992-11e6-8f4a-6b89776b1e53\"\n ;;\n\n let module_name = Some \"Core_kernel.Set\"\n let length = length\n let iter t ~f = iter ~f:(fun key -> f key) t\n\n let init ~len ~next =\n init_for_bin_prot ~len ~f:(fun _ -> next ()) ~comparator:Elt.comparator\n ;;\n end)\n\nmodule Make_plain_using_comparator (Elt : sig\n type t [@@deriving sexp_of]\n\n include Comparator.S with type t := t\n end) =\nstruct\n module Elt = Elt\n module Elt_S1 = Comparator.S_to_S1 (Elt)\n include Creators (Elt_S1)\n\n type ('a, 'b) set = ('a, 'b) t\n type t = (Elt.t, Elt.comparator_witness) set\n type named = (Elt.t, Elt.comparator_witness) Named.t\n\n include Accessors\n\n let compare t1 t2 = compare_direct t1 t2\n let sexp_of_t t = sexp_of_t Elt.sexp_of_t [%sexp_of: _] t\n\n module Provide_of_sexp\n (Elt : sig\n type t [@@deriving of_sexp]\n end\n with type t := Elt.t) =\n struct\n let t_of_sexp sexp = t_of_sexp Elt.t_of_sexp sexp\n end\n\n module Provide_hash (Elt : Hasher.S with type t := Elt.t) = struct\n let hash_fold_t state t = Using_comparator.hash_fold_direct Elt.hash_fold_t state t\n\n let hash t =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (hash_fold_t (Ppx_hash_lib.Std.Hash.create ()) t)\n ;;\n end\n\n module Provide_bin_io\n (Elt' : sig\n type t [@@deriving bin_io]\n end\n with type t := Elt.t) =\n Provide_bin_io (struct\n include Elt\n include Elt'\n end)\n\n module Tree = struct\n include Make_tree (Elt_S1)\n\n type t = (Elt.t, Elt.comparator_witness) tree\n type named = (Elt.t, Elt.comparator_witness) Tree.Named.t\n\n let compare t1 t2 = compare_direct t1 t2\n let sexp_of_t t = Tree.sexp_of_t Elt.sexp_of_t [%sexp_of: _] t\n\n module Provide_of_sexp\n (X : sig\n type t [@@deriving of_sexp]\n end\n with type t := Elt.t) =\n struct\n let t_of_sexp sexp =\n Tree.t_of_sexp_direct X.t_of_sexp sexp ~comparator:Elt_S1.comparator\n ;;\n end\n end\nend\n\nmodule Make_plain (Elt : Elt_plain) = Make_plain_using_comparator (struct\n include Elt\n include Comparator.Make (Elt)\n end)\n\nmodule Make_using_comparator (Elt_sexp : sig\n type t [@@deriving sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include Make_plain_using_comparator (Elt_sexp)\n module Elt = Elt_sexp\n include Provide_of_sexp (Elt)\n\n module Tree = struct\n include Tree\n include Provide_of_sexp (Elt)\n end\nend\n\nmodule Make (Elt : Elt) = Make_using_comparator (struct\n include Elt\n include Comparator.Make (Elt)\n end)\n\nmodule Make_binable_using_comparator (Elt_bin_sexp : sig\n type t [@@deriving bin_io, sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include Make_using_comparator (Elt_bin_sexp)\n module Elt = Elt_bin_sexp\n include Provide_bin_io (Elt)\nend\n\nmodule Make_binable (Elt : Elt_binable) = Make_binable_using_comparator (struct\n include Elt\n include Comparator.Make (Elt)\n end)\n\nmodule For_deriving = struct\n module M = Set.M\n\n let bin_shape_m__t (type t c) (m : (t, c) Elt_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_shape_t\n ;;\n\n let bin_size_m__t (type t c) (m : (t, c) Elt_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_size_t\n ;;\n\n let bin_write_m__t (type t c) (m : (t, c) Elt_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_write_t\n ;;\n\n let bin_read_m__t (type t c) (m : (t, c) Elt_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_read_t\n ;;\n\n let __bin_read_m__t__ (type t c) (m : (t, c) Elt_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.__bin_read_t__\n ;;\n\n module type Quickcheck_generator_m = sig\n include Comparator.S\n\n val quickcheck_generator : t Quickcheck.Generator.t\n end\n\n module type Quickcheck_observer_m = sig\n include Comparator.S\n\n val quickcheck_observer : t Quickcheck.Observer.t\n end\n\n module type Quickcheck_shrinker_m = sig\n include Comparator.S\n\n val quickcheck_shrinker : t Quickcheck.Shrinker.t\n end\n\n let quickcheck_generator_m__t\n (type t cmp)\n (module Elt : Quickcheck_generator_m\n with type t = t\n and type comparator_witness = cmp)\n =\n quickcheck_generator (module Elt) Elt.quickcheck_generator\n ;;\n\n let quickcheck_observer_m__t\n (type t cmp)\n (module Elt : Quickcheck_observer_m\n with type t = t\n and type comparator_witness = cmp)\n =\n quickcheck_observer Elt.quickcheck_observer\n ;;\n\n let quickcheck_shrinker_m__t\n (type t cmp)\n (module Elt : Quickcheck_shrinker_m\n with type t = t\n and type comparator_witness = cmp)\n =\n quickcheck_shrinker Elt.quickcheck_shrinker\n ;;\n\n module type For_deriving = Set.For_deriving\n\n include (Set : For_deriving with type ('a, 'b) t := ('a, 'b) t)\nend\n\ninclude For_deriving\n\nmodule Stable = struct\n module V1 = struct\n type nonrec ('a, 'cmp) t = ('a, 'cmp) t\n\n module type S = sig\n type elt\n type elt_comparator_witness\n type nonrec t = (elt, elt_comparator_witness) t\n\n include Stable_module_types.S0_without_comparator with type t := t\n end\n\n include For_deriving\n module Make (Elt : Stable_module_types.S0) = Make_binable_using_comparator (Elt)\n end\nend\n","open! Import\nmodule List = Base.List\ninclude Comparable_intf\nmodule Infix = Base.Comparable.Infix\nmodule Polymorphic_compare = Base.Comparable.Polymorphic_compare\nmodule Validate = Base.Comparable.Validate\n\nmodule With_zero (T : sig\n type t [@@deriving compare, sexp]\n\n val zero : t\n\n include Validate with type t := t\n end) =\n Base.Comparable.With_zero (T)\n\nmodule Validate_with_zero (T : sig\n type t [@@deriving compare, sexp]\n\n val zero : t\n end) =\n Base.Comparable.Validate_with_zero (T)\n\nmodule Map_and_set_binable_using_comparator (T : sig\n type t [@@deriving bin_io, compare, sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include T\n module Map = Map.Make_binable_using_comparator (T)\n module Set = Set.Make_binable_using_comparator (T)\nend\n\nmodule Map_and_set_binable (T : sig\n type t [@@deriving bin_io, compare, sexp]\n end) =\n Map_and_set_binable_using_comparator (struct\n include T\n include Comparator.Make (T)\n end)\n\nmodule Poly (T : sig\n type t [@@deriving sexp]\n end) =\nstruct\n module C = struct\n include T\n include Base.Comparable.Poly (T)\n end\n\n include C\n module Replace_polymorphic_compare : Polymorphic_compare with type t := t = C\n module Map = Map.Make_using_comparator (C)\n module Set = Set.Make_using_comparator (C)\nend\n\nmodule Make_plain_using_comparator (T : sig\n type t [@@deriving sexp_of]\n\n include Comparator.S with type t := t\n end) : S_plain with type t := T.t and type comparator_witness = T.comparator_witness =\nstruct\n include T\n module M = Base.Comparable.Make_using_comparator (T)\n include M\n module Replace_polymorphic_compare : Polymorphic_compare with type t := t = M\n module Map = Map.Make_plain_using_comparator (T)\n module Set = Set.Make_plain_using_comparator (T)\nend\n\nmodule Make_plain (T : sig\n type t [@@deriving compare, sexp_of]\n end) =\n Make_plain_using_comparator (struct\n include T\n include Comparator.Make (T)\n end)\n\nmodule Make_using_comparator (T : sig\n type t [@@deriving sexp]\n\n include Comparator.S with type t := t\n end) : S with type t := T.t and type comparator_witness = T.comparator_witness = struct\n include T\n module M = Base.Comparable.Make_using_comparator (T)\n include M\n module Replace_polymorphic_compare : Polymorphic_compare with type t := t = M\n module Map = Map.Make_using_comparator (T)\n module Set = Set.Make_using_comparator (T)\nend\n\nmodule Make (T : sig\n type t [@@deriving compare, sexp]\n end) : S with type t := T.t = Make_using_comparator (struct\n include T\n include Comparator.Make (T)\n end)\n\nmodule Make_binable_using_comparator (T : sig\n type t [@@deriving bin_io, sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include T\n module M = Base.Comparable.Make_using_comparator (T)\n include M\n module Replace_polymorphic_compare : Polymorphic_compare with type t := t = M\n module Map = Map.Make_binable_using_comparator (T)\n module Set = Set.Make_binable_using_comparator (T)\nend\n\nmodule Make_binable (T : sig\n type t [@@deriving bin_io, compare, sexp]\n end) =\n Make_binable_using_comparator (struct\n include T\n include Comparator.Make (T)\n end)\n\nmodule Extend\n (M : Base.Comparable.S) (X : sig\n type t = M.t [@@deriving sexp]\n end) =\nstruct\n module T = struct\n include M\n\n include (\n X :\n sig\n type t = M.t [@@deriving sexp]\n end\n with type t := t)\n end\n\n include T\n module Replace_polymorphic_compare : Comparisons.S with type t := t = M\n module Map = Map.Make_using_comparator (T)\n module Set = Set.Make_using_comparator (T)\nend\n\nmodule Extend_binable\n (M : Base.Comparable.S) (X : sig\n type t = M.t [@@deriving bin_io, sexp]\n end) =\nstruct\n module T = struct\n include M\n\n include (\n X :\n sig\n type t = M.t [@@deriving bin_io, sexp]\n end\n with type t := t)\n end\n\n include T\n module Replace_polymorphic_compare : Comparisons.S with type t := t = M\n module Map = Map.Make_binable_using_comparator (T)\n module Set = Set.Make_binable_using_comparator (T)\nend\n\nmodule Inherit (C : sig\n type t [@@deriving compare]\n end) (T : sig\n type t [@@deriving sexp]\n\n val component : t -> C.t\n end) =\n Make (struct\n type t = T.t [@@deriving sexp]\n\n let compare t t' = C.compare (T.component t) (T.component t')\n end)\n\nlet lexicographic = Base.Comparable.lexicographic\nlet lift = Base.Comparable.lift\nlet reverse = Base.Comparable.reverse\n\nmodule Stable = struct\n module V1 = struct\n module type S = sig\n type comparable\n type comparator_witness\n\n module Map :\n Map.Stable.V1.S\n with type key := comparable\n with type comparator_witness := comparator_witness\n\n module Set :\n Set.Stable.V1.S\n with type elt := comparable\n with type elt_comparator_witness := comparator_witness\n end\n\n module Make (X : Stable_module_types.S0) = struct\n module Map = Map.Stable.V1.Make (X)\n module Set = Set.Stable.V1.Make (X)\n end\n end\nend\n","(** Doubly-linked lists.\n\n Compared to other doubly-linked lists, in this one:\n\n 1. Calls to modification functions ([insert*], [move*], ...) detect if the list is\n being iterated over ([iter], [fold], ...), and if so raise an exception. For example,\n a use like the following would raise:\n\n {[\n iter t ~f:(fun _ -> ... remove t e ...)\n ]}\n\n 2. There is a designated \"front\" and \"back\" of each list, rather than viewing each\n element as an equal in a ring.\n\n 3. Elements know which list they're in. Each operation that takes an [Elt.t] also\n takes a [t], first checks that the [Elt] belongs to the [t], and if not, raises.\n\n 4. Related to (3), lists cannot be split, though a sort of splicing is available as\n [transfer]. In other words, no operation will cause one list to become two. This\n makes this module unsuitable for maintaining the faces of a planar graph under edge\n insertion and deletion, for example.\n\n 5. Another property permitted by (3) and (4) is that [length] is O(1).\n*)\n\nopen! Import\n\nmodule type S = sig\n module Elt : sig\n type 'a t\n\n val value : 'a t -> 'a\n\n (** pointer equality *)\n val equal : 'a t -> 'a t -> bool\n\n val set : 'a t -> 'a -> unit\n val sexp_of_t : ('a -> Base.Sexp.t) -> 'a t -> Base.Sexp.t\n end\n\n type 'a t [@@deriving compare, sexp]\n\n include Container.S1 with type 'a t := 'a t\n include Invariant.S1 with type 'a t := 'a t\n\n (** {2 Creating doubly-linked lists} *)\n\n val create : unit -> 'a t\n\n (** [of_list l] returns a doubly-linked list [t] with the same elements as [l] and in the\n same order (i.e., the first element of [l] is the first element of [t]). It is always\n the case that [l = to_list (of_list l)]. *)\n val of_list : 'a list -> 'a t\n\n val of_array : 'a array -> 'a t\n\n (** {2 Predicates} *)\n\n (** pointer equality *)\n val equal : 'a t -> 'a t -> bool\n\n val is_first : 'a t -> 'a Elt.t -> bool\n val is_last : 'a t -> 'a Elt.t -> bool\n val mem_elt : 'a t -> 'a Elt.t -> bool\n\n (** {2 Constant-time extraction of first and last elements} *)\n\n val first_elt : 'a t -> 'a Elt.t option\n val last_elt : 'a t -> 'a Elt.t option\n val first : 'a t -> 'a option\n val last : 'a t -> 'a option\n\n (** {2 Constant-time retrieval of next or previous element} *)\n\n val next : 'a t -> 'a Elt.t -> 'a Elt.t option\n val prev : 'a t -> 'a Elt.t -> 'a Elt.t option\n\n (** {2 Constant-time insertion of a new element} *)\n\n val insert_before : 'a t -> 'a Elt.t -> 'a -> 'a Elt.t\n val insert_after : 'a t -> 'a Elt.t -> 'a -> 'a Elt.t\n val insert_first : 'a t -> 'a -> 'a Elt.t\n val insert_last : 'a t -> 'a -> 'a Elt.t\n\n (** {2 Constant-time move of an element from and to positions in the same list}\n\n An exception is raised if [elt] is equal to [anchor]. *)\n\n val move_to_front : 'a t -> 'a Elt.t -> unit\n val move_to_back : 'a t -> 'a Elt.t -> unit\n val move_after : 'a t -> 'a Elt.t -> anchor:'a Elt.t -> unit\n val move_before : 'a t -> 'a Elt.t -> anchor:'a Elt.t -> unit\n\n (** {2 Constant-time removal of an element} *)\n\n val remove : 'a t -> 'a Elt.t -> unit\n val remove_first : 'a t -> 'a option\n val remove_last : 'a t -> 'a option\n val iteri : 'a t -> f:(int -> 'a -> unit) -> unit\n val foldi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b) -> 'b\n\n (** [fold_elt t ~init ~f] is the same as fold, except [f] is called with the ['a Elt.t]'s\n from the list instead of the contained ['a] values.\n\n Note that like other iteration functions, it is an error to mutate [t] inside the\n fold. If you'd like to call [remove] on any of the ['a Elt.t]'s, use\n [filter_inplace]. *)\n val fold_elt : 'a t -> init:'b -> f:('b -> 'a Elt.t -> 'b) -> 'b\n\n val foldi_elt : 'a t -> init:'b -> f:(int -> 'b -> 'a Elt.t -> 'b) -> 'b\n val iter_elt : 'a t -> f:('a Elt.t -> unit) -> unit\n val iteri_elt : 'a t -> f:(int -> 'a Elt.t -> unit) -> unit\n\n\n val fold_right : 'a t -> init:'b -> f:('a -> 'b -> 'b) -> 'b\n val fold_right_elt : 'a t -> init:'b -> f:('a Elt.t -> 'b -> 'b) -> 'b\n\n (** [find_elt t ~f] finds the first element in [t] that satisfies [f], by testing each of\n element of [t] in turn until [f] succeeds. *)\n val find_elt : 'a t -> f:('a -> bool) -> 'a Elt.t option\n\n val findi_elt : 'a t -> f:(int -> 'a -> bool) -> (int * 'a Elt.t) option\n\n (** [clear t] removes all elements from the list in constant time. *)\n val clear : 'a t -> unit\n\n val copy : 'a t -> 'a t\n\n (** [transfer ~src ~dst] has the same behavior as\n [iter src ~f:(insert_last dst); clear src] except that it runs in constant time.\n\n If [s = to_list src] and [d = to_list dst], then after [transfer ~src ~dst]:\n\n [to_list src = []]\n\n [to_list dst = d @ s] *)\n val transfer : src:'a t -> dst:'a t -> unit\n\n (** {2 Linear-time mapping of lists (creates a new list)} *)\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n val mapi : 'a t -> f:(int -> 'a -> 'b) -> 'b t\n val filter : 'a t -> f:('a -> bool) -> 'a t\n val filteri : 'a t -> f:(int -> 'a -> bool) -> 'a t\n val filter_map : 'a t -> f:('a -> 'b option) -> 'b t\n val filter_mapi : 'a t -> f:(int -> 'a -> 'b option) -> 'b t\n\n (** {2 Linear-time partition of lists (creates two new lists)} *)\n\n val partition_tf : 'a t -> f:('a -> bool) -> 'a t * 'a t\n val partitioni_tf : 'a t -> f:(int -> 'a -> bool) -> 'a t * 'a t\n val partition_map : 'a t -> f:('a -> ('b, 'c) Either.t) -> 'b t * 'c t\n val partition_mapi : 'a t -> f:(int -> 'a -> ('b, 'c) Either.t) -> 'b t * 'c t\n\n (** {2 Linear-time in-place mapping of lists} *)\n\n (** [map_inplace t ~f] replaces all values [v] with [f v] *)\n val map_inplace : 'a t -> f:('a -> 'a) -> unit\n\n val mapi_inplace : 'a t -> f:(int -> 'a -> 'a) -> unit\n\n (** [filter_inplace t ~f] removes all elements of [t] that don't satisfy [f]. *)\n val filter_inplace : 'a t -> f:('a -> bool) -> unit\n\n val filteri_inplace : 'a t -> f:(int -> 'a -> bool) -> unit\n\n (** If [f] returns [None], the element is removed, else the value is replaced with the\n contents of the [Some] *)\n val filter_map_inplace : 'a t -> f:('a -> 'a option) -> unit\n\n val filter_mapi_inplace : 'a t -> f:(int -> 'a -> 'a option) -> unit\n\n (** [unchecked_iter t ~f] behaves like [iter t ~f] except that [f] is allowed to modify\n [t]. Adding or removing elements before the element currently being visited has no\n effect on the traversal. Elements added after the element currently being visited\n will be traversed. Elements deleted after the element currently being visited will\n not be traversed. Deleting the element currently being visited is an error that is not\n detected (presumably leading to an infinite loop). *)\n val unchecked_iter : 'a t -> f:('a -> unit) -> unit\n\n\n (** A sequence of values from the doubly-linked list. It makes an intermediate copy of the\n list so that the returned sequence is immune to any subsequent mutation of the\n original list. *)\n val to_sequence : 'a t -> 'a Sequence.t\nend\n\nmodule type Doubly_linked = sig\n module type S = S\n\n include S\nend\n","include List0 (** @inline *)\n\n(** [stable_dedup] Same as [dedup] but maintains the order of the list and doesn't allow\n compare function to be specified (otherwise, the implementation in terms of Set.t\n would hide a heavyweight functor instantiation at each call). *)\nlet stable_dedup = Set.Poly.stable_dedup_list\n\n(* This function is staged to indicate that real work (the functor application) takes\n place after a partial application. *)\nlet stable_dedup_staged (type a) ~(compare : a -> a -> int)\n : (a list -> a list) Base.Staged.t\n =\n let module Set =\n Set.Make (struct\n type t = a\n\n let compare = compare\n\n (* [stable_dedup_list] never calls these *)\n let t_of_sexp _ = assert false\n let sexp_of_t _ = assert false\n end)\n in\n Base.Staged.stage Set.stable_dedup_list\n;;\n\nlet zip_with_remainder =\n let rec zip_with_acc_and_remainder acc xs ys =\n match xs, ys with\n | [], [] -> rev acc, None\n | fst, [] -> rev acc, Some (Either.First fst)\n | [], snd -> rev acc, Some (Either.Second snd)\n | x :: xs, y :: ys -> zip_with_acc_and_remainder ((x, y) :: acc) xs ys\n in\n fun xs ys -> zip_with_acc_and_remainder [] xs ys\n;;\n\ntype sexp_thunk = unit -> Base.Sexp.t\n\nlet sexp_of_sexp_thunk x = x ()\n\nexception Duplicate_found of sexp_thunk * Base.String.t [@@deriving sexp]\n\nlet exn_if_dup ~compare ?(context = \"exn_if_dup\") t ~to_sexp =\n match find_a_dup ~compare t with\n | None -> ()\n | Some dup -> raise (Duplicate_found ((fun () -> to_sexp dup), context))\n;;\n\nlet slice a start stop =\n Ordered_collection_common.slice ~length_fun:length ~sub_fun:sub a start stop\n;;\n\nmodule Stable = struct\n module V1 = struct\n type nonrec 'a t = 'a t [@@deriving sexp, bin_io, compare]\n end\nend\n","open! Import\ninclude Base.Option\n\ntype 'a t = 'a option [@@deriving bin_io, typerep]\n\ninclude Comparator.Derived (struct\n type nonrec 'a t = 'a t [@@deriving sexp_of, compare]\n end)\n\nlet quickcheck_generator = Base_quickcheck.Generator.option\nlet quickcheck_observer = Base_quickcheck.Observer.option\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.option\n\nmodule Stable = struct\n module V1 = struct\n type nonrec 'a t = 'a t [@@deriving bin_io, compare, equal, sexp]\n end\nend\n\nmodule Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n\n (* [unsafe_value] is only safe to call when [is_none] returns [false]. To avoid\n repeating the [is_none] check, we declare [Unchecked_some]. [Unchecked_some x]\n has the same representation as [Some x], but the type has no [None] clause.\n\n We make sure all this works with tests of [unsafe_value] in test_option.ml.\n\n We tried using [Obj.field] instead. It generates much worse native code due to\n float array representations. *)\n\n module Unchecked_some = struct\n (* Warning 37 tells us [Unchecked_some] is never used as a constructor. This is\n intentional, so we disable the warning. *)\n type 'a t = Unchecked_some of 'a [@@ocaml.boxed] [@@ocaml.warning \"-37\"]\n end\n\n let unsafe_value (type a) (t : a t) : a =\n let (Unchecked_some value) = (Obj.magic t : a Unchecked_some.t) in\n value\n ;;\n end\nend\n","(* This code is based on the MLton library set/disjoint.fun, which has the\n following copyright notice.\n*)\n(* Copyright (C) 1999-2005 Henry Cejtin, Matthew Fluet, Suresh\n * Jagannathan, and Stephen Weeks.\n *\n * MLton is released under a BSD-style license.\n * See the file MLton-LICENSE for details.\n*)\n\nopen! Import\n\n(*\n {v\n Root\n |\n Inner\n / .. | .. \\\n Inner Inner Inner\n /|\\ /|\\ /|\\\n ... ... ...\n v}\n\n We construct the `inverted' tree in the ML representation.\n The direction of the edges is UPWARDS.\n Starting with any ['a t] we can step directly to its parent.\n But we can't (and don't need to) start from the root and step to its children.\n*)\n\n(*\n [rank] is an upper bound on the depth of any node in the up-tree.\n\n Imagine an unlucky sequence of operations in which you create N\n individual [t]-values and then union them together in such a way\n that you always pick the root of each tree to union together, so that\n no path compression takes place. If you don't take care to somehow\n balance the resulting up-tree, it is possible that you end up with one\n big long chain of N links, and then calling [representative] on the\n deepest node takes Theta(N) time. With the balancing scheme of never\n increasing the rank of a node unnecessarily, it would take O(log N).\n*)\ntype 'a root =\n { mutable value : 'a\n ; mutable rank : int\n }\n\ntype 'a t = { mutable node : 'a node }\n\nand 'a node =\n | Inner of 'a t\n (* [Inner x] is a node whose parent is [x]. *)\n | Root of 'a root\n\nlet invariant _ t =\n let rec loop t depth =\n match t.node with\n | Inner t -> loop t (depth + 1)\n | Root r -> assert (depth <= r.rank)\n in\n loop t 0\n;;\n\nlet create v = { node = Root { value = v; rank = 0 } }\n\n(* invariants:\n [inner.node] = [inner_node] = [Inner t].\n [descendants] are the proper descendants of [inner] we've visited.\n*)\nlet rec compress t ~inner_node ~inner ~descendants =\n match t.node with\n | Root r ->\n (* t is the root of the tree.\n Re-point all descendants directly to it by setting them to [Inner t].\n Note: we don't re-point [inner] as it already points there. *)\n List.iter descendants ~f:(fun t -> t.node <- inner_node);\n t, r\n | Inner t' as node ->\n compress t' ~inner_node:node ~inner:t ~descendants:(inner :: descendants)\n;;\n\nlet representative t =\n match t.node with\n | Root r -> t, r\n | Inner t' as node -> compress t' ~inner_node:node ~inner:t ~descendants:[]\n;;\n\nlet root t =\n match t.node with\n | Root r ->\n (* avoid tuple allocation in the fast path *)\n r\n | _ -> snd (representative t)\n;;\n\nlet rank t = (root t).rank\nlet get t = (root t).value\nlet set t v = (root t).value <- v\nlet same_class t1 t2 = phys_equal (root t1) (root t2)\n\nlet union t1 t2 =\n let t1, r1 = representative t1 in\n let t2, r2 = representative t2 in\n if phys_equal r1 r2\n then ()\n else (\n let n1 = r1.rank in\n let n2 = r2.rank in\n if n1 < n2\n then t1.node <- Inner t2\n else (\n t2.node <- Inner t1;\n if n1 = n2 then r1.rank <- r1.rank + 1))\n;;\n\nlet is_compressed t =\n invariant ignore t;\n match t.node with\n | Root _ -> true\n | Inner t ->\n (match t.node with\n | Root _ -> true\n | Inner _ -> false)\n;;\n\nmodule Private = struct\n let is_compressed = is_compressed\n let rank = rank\nend\n","open! Import\ninclude Doubly_linked_intf\n\n(* INVARIANT: This exception is raised if a list is mutated during a pending iteration.\n\n This invariant is guaranteed by the Header and Elt modules in conjunction. All\n downstream code in this module need not be concerned with this invariant.\n*)\nexception Attempt_to_mutate_list_during_iteration\n\nlet phys_equal = ( == )\n\nmodule Header : sig\n type t\n\n val create : unit -> t\n val length : t -> int\n val equal : t -> t -> bool\n val incr_length : by:int -> t -> unit\n val check_no_pending_iterations : t -> unit\n\n (* Unfortunate, but by specializing [with_iteration] for different arities, a large\n amount of allocation during folds and iterations is avoided.\n\n The original type of [with_iteration] was\n [val with_iteration : t -> (unit -> 'a) -> 'a]\n\n The difference between\n {[\n let x = e in\n let f () = g x in\n f ()\n ]}\n and\n {[\n let x = e in\n let f x = g x in\n f x\n ]}\n is that in the first case the closure for [f] contains a pointer to [x],\n and in the second case it doesn't. A closure without pointers to enclosing\n environment is implemented as a naked function pointer, so we don't\n allocate at all.\n\n For the same reason we make sure not to call [Result.try_with (fun () -> ...)]\n inside [with_iteration] and do an explicit match statement instead. *)\n\n val with_iteration_2 : t -> 'a -> 'b -> ('a -> 'b -> 'c) -> 'c\n val with_iteration_3 : t -> 'a -> 'b -> 'c -> ('a -> 'b -> 'c -> 'd) -> 'd\n val with_iteration_4 : t -> 'a -> 'b -> 'c -> 'd -> ('a -> 'b -> 'c -> 'd -> 'e) -> 'e\n val merge : t -> t -> [ `Same_already | `Merged ]\nend = struct\n type s =\n { mutable length : int\n ;\n mutable pending_iterations : int\n }\n\n type t = s Union_find.t\n\n let create () = Union_find.create { length = 1; pending_iterations = 0 }\n let equal (t1 : t) t2 = Union_find.same_class t1 t2\n let length t = (Union_find.get t).length\n\n let union_find_get__check_no_pending_iterations t =\n let s = Union_find.get t in\n if s.pending_iterations > 0 then raise Attempt_to_mutate_list_during_iteration else s\n ;;\n\n let check_no_pending_iterations t =\n ignore (union_find_get__check_no_pending_iterations t : s)\n ;;\n\n let incr_length ~by:n t =\n let s = union_find_get__check_no_pending_iterations t in\n s.length <- s.length + n\n ;;\n\n (* Care is taken not to allocate in [with_iteration_*], since it is called every second\n by [every_second] in [writer0.ml] *)\n\n let incr_pending_iters s = s.pending_iterations <- s.pending_iterations + 1\n let decr_pending_iters s = s.pending_iterations <- s.pending_iterations - 1\n\n let with_iteration_2 t a b f =\n let s = Union_find.get t in\n incr_pending_iters s;\n match f a b with\n | exception exn ->\n decr_pending_iters s;\n raise exn\n | r ->\n decr_pending_iters s;\n r\n ;;\n\n let with_iteration_3 t a b c f =\n let s = Union_find.get t in\n incr_pending_iters s;\n match f a b c with\n | exception exn ->\n decr_pending_iters s;\n raise exn\n | r ->\n decr_pending_iters s;\n r\n ;;\n\n let with_iteration_4 t a b c d f =\n let s = Union_find.get t in\n incr_pending_iters s;\n match f a b c d with\n | exception exn ->\n decr_pending_iters s;\n raise exn\n | r ->\n decr_pending_iters s;\n r\n ;;\n\n let merge (t1 : t) t2 =\n if Union_find.same_class t1 t2\n then `Same_already\n else (\n let n1 = (union_find_get__check_no_pending_iterations t1).length in\n let n2 = (union_find_get__check_no_pending_iterations t2).length in\n with_iteration_4 t1 t1 t2 n1 n2 (fun t1 t2 n1 n2 ->\n with_iteration_4 t2 t1 t2 n1 n2 (fun t1 t2 n1 n2 ->\n Union_find.union t1 t2;\n Union_find.set t1 { length = n1 + n2; pending_iterations = 0 }));\n `Merged)\n ;;\nend\n\nmodule Elt : sig\n type 'a t [@@deriving sexp_of]\n\n val header : 'a t -> Header.t\n val equal : 'a t -> 'a t -> bool\n val create : 'a -> 'a t\n val value : 'a t -> 'a\n val set : 'a t -> 'a -> unit\n val unlink : 'a t -> unit\n val split_or_splice_before : 'a t -> 'a t -> unit\n val split_or_splice_after : 'a t -> 'a t -> unit\n val insert_after : 'a t -> 'a -> 'a t\n val insert_before : 'a t -> 'a -> 'a t\n val unlink_before : 'a t -> 'a t\n val next : 'a t -> 'a t\n val prev : 'a t -> 'a t\nend = struct\n type 'a t =\n { mutable value : 'a\n ; mutable prev : 'a t\n ; mutable next : 'a t\n ; mutable header : Header.t\n }\n\n let equal = phys_equal\n let next t = t.next\n let prev t = t.prev\n let header t = t.header\n\n let create_aux v header =\n let rec t = { value = v; prev = t; next = t; header } in\n t\n ;;\n\n let is_singleton t = equal t t.prev\n let sexp_of_t sexp_of_a t = sexp_of_a t.value\n let create v = create_aux v (Header.create ())\n let value t = t.value\n let set t v = t.value <- v\n\n (*\n [split_or_splice] is sufficient as the lone primitive for\n accomplishing all pointer updates on cyclic loops of list nodes.\n It takes two \"gaps\" between adjacent linked list nodes. If the gaps\n point into the same list, the result is that it will be split into\n two lists afterwards. If the gaps point into different lists, the\n result is that they will be spliced together into one list afterwards.\n\n {v\n Before After\n -----+ +----- -----+ +-----\n A | <--> | B A | <--- ---> | B\n -----+ +----- -----+ \\ / +-----\n X\n -----+ +----- -----+ / \\ +-----\n C | <--> | D C | <--- ---> | D\n -----+ +----- -----+ +-----\n v} *)\n\n let unsafe_split_or_splice ~prev1:a ~next1:b ~prev2:c ~next2:d =\n a.next <- d;\n d.prev <- a;\n c.next <- b;\n b.prev <- c\n ;;\n\n let unsafe_split_or_splice_after t1 t2 =\n unsafe_split_or_splice\n ~next1:t1.next\n ~prev1:t1.next.prev\n ~next2:t2.next\n ~prev2:t2.next.prev\n ;;\n\n let unsafe_split_or_splice_before t1 t2 =\n unsafe_split_or_splice\n ~prev1:t1.prev\n ~next1:t1.prev.next\n ~prev2:t2.prev\n ~next2:t2.prev.next\n ;;\n\n let check_two_nodes_no_pending_iterations t1 t2 =\n Header.check_no_pending_iterations t1.header;\n if not (Header.equal t1.header t2.header)\n then Header.check_no_pending_iterations t2.header\n ;;\n\n (* We redefine safe versions for export *)\n let split_or_splice_after t1 t2 =\n check_two_nodes_no_pending_iterations t1 t2;\n unsafe_split_or_splice_after t1 t2\n ;;\n\n let split_or_splice_before t1 t2 =\n check_two_nodes_no_pending_iterations t1 t2;\n unsafe_split_or_splice_before t1 t2\n ;;\n\n let insert_before t v =\n Header.incr_length t.header ~by:1;\n let node = create_aux v t.header in\n unsafe_split_or_splice_before t node;\n node\n ;;\n\n let insert_after t v =\n Header.incr_length t.header ~by:1;\n let node = create_aux v t.header in\n unsafe_split_or_splice_after t node;\n node\n ;;\n\n let dummy_header = Header.create ()\n\n let unlink_before t =\n let node = t.prev in\n if is_singleton node\n then node\n else (\n Header.incr_length t.header ~by:(-1);\n unsafe_split_or_splice_before t node;\n node.header <- dummy_header;\n node)\n ;;\n\n let unlink_after t =\n let node = t.next in\n if is_singleton node\n then node\n else (\n Header.incr_length t.header ~by:(-1);\n unsafe_split_or_splice_after t node;\n node.header <- dummy_header;\n node)\n ;;\n\n let unlink t = ignore (unlink_after t.prev : _ t)\nend\n\ntype 'a t = 'a Elt.t option ref\n\nlet invariant invariant_a t =\n match !t with\n | None -> ()\n | Some head ->\n let header = Elt.header head in\n let rec loop n elt =\n let next_elt = Elt.next elt in\n let prev_elt = Elt.prev elt in\n assert (Elt.equal elt (Elt.prev next_elt));\n assert (Elt.equal elt (Elt.next prev_elt));\n assert (Header.equal (Elt.header elt) header);\n invariant_a (Elt.value elt);\n if Elt.equal next_elt head then n else loop (n + 1) next_elt\n in\n let len = loop 1 head in\n assert (len = Header.length header)\n;;\n\nlet create (type a) () : a t = ref None\nlet equal (t : _ t) t' = phys_equal t t'\n\nlet of_list = function\n | [] -> create ()\n | x :: xs ->\n let first = Elt.create x in\n let _last = List.fold xs ~init:first ~f:Elt.insert_after in\n ref (Some first)\n;;\n\nlet of_array = function\n | [||] -> create ()\n | arr ->\n let first = Elt.create arr.(0) in\n let rec loop arr elt i =\n if i < Array.length arr then loop arr (Elt.insert_after elt arr.(i)) (i + 1)\n in\n loop arr first 1;\n ref (Some first)\n;;\n\nlet map t ~f =\n match !t with\n | None -> create ()\n | Some first ->\n let new_first = Elt.create (f (Elt.value first)) in\n Header.with_iteration_3\n (Elt.header first)\n f\n new_first\n first\n (fun f new_first first ->\n let rec loop f acc first elt =\n let acc = Elt.insert_after acc (f (Elt.value elt)) in\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f acc first next\n in\n (* unroll and skip first elt *)\n let next = Elt.next first in\n if not (phys_equal next first) then loop f new_first first next);\n ref (Some new_first)\n;;\n\nlet mapi t ~f =\n match !t with\n | None -> create ()\n | Some first ->\n let new_first = Elt.create (f 0 (Elt.value first)) in\n Header.with_iteration_3\n (Elt.header first)\n f\n new_first\n first\n (fun f new_first first ->\n let rec loop f i acc first elt =\n let acc = Elt.insert_after acc (f i (Elt.value elt)) in\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f (i + 1) acc first next\n in\n (* unroll and skip first elt *)\n let next = Elt.next first in\n if not (phys_equal next first) then loop f 1 new_first first next);\n ref (Some new_first)\n;;\n\nlet fold_elt t ~init ~f =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f init first (fun f init first ->\n let rec loop f acc first elt =\n let acc = f acc elt in\n let next = Elt.next elt in\n if phys_equal next first then acc else loop f acc first next\n in\n loop f init first first)\n;;\n\nlet foldi_elt t ~init ~f =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f init first (fun f init first ->\n let rec loop f i acc first elt =\n let acc = f i acc elt in\n let next = Elt.next elt in\n if phys_equal next first then acc else loop f (i + 1) acc first next\n in\n loop f 0 init first first)\n;;\n\nlet fold_elt_1 t ~init ~f a =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f a init first (fun f a init first ->\n let rec loop f a acc first elt =\n let acc = f a acc elt in\n let next = Elt.next elt in\n if phys_equal next first then acc else loop f a acc first next\n in\n loop f a init first first)\n;;\n\nlet foldi_elt_1 t ~init ~f a =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f a init first (fun f a init first ->\n let rec loop f i a acc first elt =\n let acc = f i a acc elt in\n let next = Elt.next elt in\n if phys_equal next first then acc else loop f (i + 1) a acc first next\n in\n loop f 0 a init first first)\n;;\n\nlet iter_elt t ~f = fold_elt_1 t ~init:() ~f:(fun f () elt -> f elt) f\nlet iteri_elt t ~f = foldi_elt t ~init:() ~f:(fun i () elt -> f i elt)\n\nopen With_return\n\nlet find_elt t ~f =\n with_return (fun r ->\n fold_elt_1 t f ~init:() ~f:(fun f () elt ->\n if f (Elt.value elt) then r.return (Some elt));\n None)\n;;\n\nlet findi_elt t ~f =\n with_return (fun r ->\n foldi_elt_1 t f ~init:() ~f:(fun i f () elt ->\n if f i (Elt.value elt) then r.return (Some (i, elt)));\n None)\n;;\n\n(* this function is lambda lifted for performance, to make direct recursive calls instead\n of calls through its closure. It also avoids the initial closure allocation. *)\nlet rec iter_loop first f elt =\n f (Elt.value elt);\n let next = Elt.next elt in\n if not (phys_equal next first) then iter_loop first f next\n;;\n\nlet iter t ~f =\n match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_2 (Elt.header first) first f (fun first f ->\n iter_loop first f first)\n;;\n\nlet length t =\n match !t with\n | None -> 0\n | Some first -> Header.length (Elt.header first)\n;;\n\nlet rec iteri_loop first f i elt =\n f i (Elt.value elt);\n let next = Elt.next elt in\n if not (phys_equal next first) then iteri_loop first f (i + 1) next\n;;\n\nlet iteri t ~f =\n match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_2 (Elt.header first) first f (fun first f ->\n iteri_loop first f 0 first)\n;;\n\nlet foldi t ~init ~f =\n foldi_elt_1 t ~init f ~f:(fun i f acc elt -> f i acc (Elt.value elt))\n;;\n\nmodule C = Container.Make (struct\n type nonrec 'a t = 'a t\n\n let fold t ~init ~f = fold_elt_1 t ~init f ~f:(fun f acc elt -> f acc (Elt.value elt))\n let iter = `Custom iter\n let length = `Custom length\n end)\n\nlet count = C.count\nlet sum = C.sum\nlet exists = C.exists\nlet find = C.find\nlet find_map = C.find_map\nlet fold = C.fold\nlet for_all = C.for_all\nlet mem = C.mem\nlet to_array = C.to_array\nlet min_elt = C.min_elt\nlet max_elt = C.max_elt\nlet fold_result = C.fold_result\nlet fold_until = C.fold_until\n\nlet unchecked_iter t ~f =\n match !t with\n | None -> ()\n | Some first ->\n let rec loop t f elt =\n f (Elt.value elt);\n let next = Elt.next elt in\n match !t with\n (* the first element of the bag may have been changed by [f] *)\n | None -> ()\n | Some first -> if not (phys_equal first next) then loop t f next\n in\n loop t f first\n;;\n\nlet is_empty t = Option.is_none !t\n\n(* more efficient than what Container.Make returns *)\n\nlet fold_right t ~init ~f =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f init first (fun f init first ->\n let rec loop f acc elt =\n let prev = Elt.prev elt in\n let acc = f (Elt.value prev) acc in\n if phys_equal prev first then acc else loop f acc prev\n in\n loop f init first)\n;;\n\nlet fold_right_elt t ~init ~f =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f init first (fun f init first ->\n let rec loop f acc elt =\n let prev = Elt.prev elt in\n let acc = f prev acc in\n if phys_equal prev first then acc else loop f acc prev\n in\n loop f init first)\n;;\n\nlet to_list t = fold_right t ~init:[] ~f:(fun x tl -> x :: tl)\nlet sexp_of_t sexp_of_a t = List.sexp_of_t sexp_of_a (to_list t)\nlet t_of_sexp a_of_sexp s = of_list (List.t_of_sexp a_of_sexp s)\nlet copy t = of_list (to_list t)\nlet clear t = t := None\n\nlet compare compare_elt t1 t2 =\n match !t1, !t2 with\n | None, None -> 0\n | None, _ -> -1\n | _, None -> 1\n | Some f1, Some f2 ->\n Header.with_iteration_3 (Elt.header f1) compare_elt f1 f2 (fun compare_elt f1 f2 ->\n Header.with_iteration_3\n (Elt.header f2)\n compare_elt\n f1\n f2\n (fun compare_elt f1 f2 ->\n let rec loop compare_elt elt1 f1 elt2 f2 =\n let compare_result = compare_elt (Elt.value elt1) (Elt.value elt2) in\n if compare_result <> 0\n then compare_result\n else (\n let next1 = Elt.next elt1 in\n let next2 = Elt.next elt2 in\n match phys_equal next1 f1, phys_equal next2 f2 with\n | true, true -> 0\n | true, false -> -1\n | false, true -> 1\n | false, false -> loop compare_elt next1 f1 next2 f2)\n in\n loop compare_elt f1 f1 f2 f2))\n;;\n\nexception Transfer_src_and_dst_are_same_list\n\nlet transfer ~src ~dst =\n if phys_equal src dst then raise Transfer_src_and_dst_are_same_list;\n match !src with\n | None -> ()\n | Some src_head ->\n (match !dst with\n | None ->\n dst := Some src_head;\n clear src\n | Some dst_head ->\n (match Header.merge (Elt.header src_head) (Elt.header dst_head) with\n | `Same_already -> raise Transfer_src_and_dst_are_same_list\n | `Merged ->\n Elt.split_or_splice_before dst_head src_head;\n clear src))\n;;\n\nlet map_inplace t ~f = iter_elt t ~f:(fun elt -> Elt.set elt (f (Elt.value elt)))\nlet mapi_inplace t ~f = iteri_elt t ~f:(fun i elt -> Elt.set elt (f i (Elt.value elt)))\n\nlet remove_list t to_remove =\n List.iter to_remove ~f:(fun elt ->\n (match !t with\n | None -> ()\n | Some head ->\n if Elt.equal head elt\n then (\n let next_elt = Elt.next elt in\n t := if Elt.equal head next_elt then None else Some next_elt));\n Elt.unlink elt)\n;;\n\nlet filter_inplace t ~f =\n let to_remove =\n List.rev\n (fold_elt t ~init:[] ~f:(fun elts elt ->\n if f (Elt.value elt) then elts else elt :: elts))\n in\n remove_list t to_remove\n;;\n\nlet filteri_inplace t ~f =\n let to_remove =\n List.rev\n (foldi_elt t ~init:[] ~f:(fun i elts elt ->\n if f i (Elt.value elt) then elts else elt :: elts))\n in\n remove_list t to_remove\n;;\n\nlet filter_map_inplace t ~f =\n let to_remove =\n List.rev\n (fold_elt t ~init:[] ~f:(fun elts elt ->\n match f (Elt.value elt) with\n | None -> elt :: elts\n | Some value ->\n Elt.set elt value;\n elts))\n in\n remove_list t to_remove\n;;\n\nlet filter_mapi_inplace t ~f =\n let to_remove =\n List.rev\n (foldi_elt t ~init:[] ~f:(fun i elts elt ->\n match f i (Elt.value elt) with\n | None -> elt :: elts\n | Some value ->\n Elt.set elt value;\n elts))\n in\n remove_list t to_remove\n;;\n\nexception Elt_does_not_belong_to_list\n\nlet first_elt t = !t\nlet last_elt t = Option.map ~f:Elt.prev !t\nlet first t = Option.map ~f:Elt.value (first_elt t)\nlet last t = Option.map ~f:Elt.value (last_elt t)\n\nlet is_first t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Header.equal (Elt.header first) (Elt.header elt)\n then Elt.equal elt first\n else raise Elt_does_not_belong_to_list\n;;\n\nlet is_last t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Header.equal (Elt.header first) (Elt.header elt)\n then (\n let last = Elt.prev first in\n Elt.equal elt last)\n else raise Elt_does_not_belong_to_list\n;;\n\nlet mem_elt t elt =\n match !t with\n | None -> false\n | Some first -> Header.equal (Elt.header first) (Elt.header elt)\n;;\n\nlet prev t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Elt.equal elt first\n then None\n else if Header.equal (Elt.header first) (Elt.header elt)\n then Some (Elt.prev elt)\n else raise Elt_does_not_belong_to_list\n;;\n\nlet next t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n let last = Elt.prev first in\n if Elt.equal elt last\n then None\n else if Header.equal (Elt.header first) (Elt.header elt)\n then Some (Elt.next elt)\n else raise Elt_does_not_belong_to_list\n;;\n\nlet insert_after t elt v =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Header.equal (Elt.header first) (Elt.header elt)\n then Elt.insert_after elt v\n else raise Elt_does_not_belong_to_list\n;;\n\nlet insert_before t elt v =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Elt.equal elt first\n then (\n let new_elt = Elt.insert_before first v in\n t := Some new_elt;\n new_elt)\n else if Header.equal (Elt.header first) (Elt.header elt)\n then Elt.insert_before elt v\n else raise Elt_does_not_belong_to_list\n;;\n\nlet insert_empty t v =\n let new_elt = Elt.create v in\n t := Some new_elt;\n new_elt\n;;\n\nlet insert_last t v =\n match !t with\n | None -> insert_empty t v\n | Some first -> Elt.insert_before first v\n;;\n\nlet insert_first t v =\n match !t with\n | None -> insert_empty t v\n | Some first ->\n let new_elt = Elt.insert_before first v in\n t := Some new_elt;\n new_elt\n;;\n\nlet remove_last t =\n match !t with\n | None -> None\n | Some first ->\n let last = Elt.unlink_before first in\n if Elt.equal first last then t := None;\n Some (Elt.value last)\n;;\n\nlet remove_first t =\n match !t with\n | None -> None\n | Some first ->\n let second = Elt.next first in\n Elt.unlink first;\n t := if Elt.equal first second then None else Some second;\n Some (Elt.value first)\n;;\n\nlet remove t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Elt.equal elt first\n then ignore (remove_first t : _ option)\n else if Header.equal (Elt.header first) (Elt.header elt)\n then Elt.unlink elt\n else raise Elt_does_not_belong_to_list\n;;\n\nlet filter t ~f =\n let new_t = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f new_t first (fun f new_t first ->\n let rec loop f new_t first elt =\n if f (Elt.value elt)\n then insert_last new_t (Elt.value elt) |> (ignore : _ Elt.t -> unit);\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f new_t first next\n in\n loop f new_t first first));\n new_t\n;;\n\nlet filteri t ~f =\n let new_t = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f new_t first (fun f new_t first ->\n let rec loop f i new_t first elt =\n if f i (Elt.value elt)\n then insert_last new_t (Elt.value elt) |> (ignore : _ Elt.t -> unit);\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f (i + 1) new_t first next\n in\n loop f 0 new_t first first));\n new_t\n;;\n\nlet filter_map t ~f =\n let new_t = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f new_t first (fun f new_t first ->\n let rec loop f new_t first elt =\n (match f (Elt.value elt) with\n | None -> ()\n | Some value -> insert_last new_t value |> (ignore : _ Elt.t -> unit));\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f new_t first next\n in\n loop f new_t first first));\n new_t\n;;\n\nlet filter_mapi t ~f =\n let new_t = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f new_t first (fun f new_t first ->\n let rec loop f i new_t first elt =\n (match f i (Elt.value elt) with\n | None -> ()\n | Some value -> insert_last new_t value |> (ignore : _ Elt.t -> unit));\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f (i + 1) new_t first next\n in\n loop f 0 new_t first first));\n new_t\n;;\n\nlet partition_tf t ~f =\n let t1 = create () in\n let t2 = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f t1 t2 first (fun f t1 t2 first ->\n let rec loop f t1 t2 first elt =\n insert_last (if f (Elt.value elt) then t1 else t2) (Elt.value elt)\n |> (ignore : _ Elt.t -> unit);\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f t1 t2 first next\n in\n loop f t1 t2 first first));\n t1, t2\n;;\n\nlet partitioni_tf t ~f =\n let t1 = create () in\n let t2 = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f t1 t2 first (fun f t1 t2 first ->\n let rec loop f i t1 t2 first elt =\n insert_last (if f i (Elt.value elt) then t1 else t2) (Elt.value elt)\n |> (ignore : _ Elt.t -> unit);\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f (i + 1) t1 t2 first next\n in\n loop f 0 t1 t2 first first));\n t1, t2\n;;\n\nlet partition_map t ~f =\n let t1 = create () in\n let t2 = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f t1 t2 first (fun f t1 t2 first ->\n let rec loop f t1 t2 first elt =\n (match (f (Elt.value elt) : (_, _) Either.t) with\n | First value -> insert_last t1 value |> (ignore : _ Elt.t -> unit)\n | Second value -> insert_last t2 value |> (ignore : _ Elt.t -> unit));\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f t1 t2 first next\n in\n loop f t1 t2 first first));\n t1, t2\n;;\n\nlet partition_mapi t ~f =\n let t1 = create () in\n let t2 = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f t1 t2 first (fun f t1 t2 first ->\n let rec loop f i t1 t2 first elt =\n (match (f i (Elt.value elt) : (_, _) Either.t) with\n | First value -> insert_last t1 value |> (ignore : _ Elt.t -> unit)\n | Second value -> insert_last t2 value |> (ignore : _ Elt.t -> unit));\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f (i + 1) t1 t2 first next\n in\n loop f 0 t1 t2 first first));\n t1, t2\n;;\n\nexception Invalid_move__elt_equals_anchor\n\nlet move_before t elt ~anchor =\n if Elt.equal anchor elt then raise Invalid_move__elt_equals_anchor;\n if Header.equal (Elt.header anchor) (Elt.header elt)\n then (\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Header.equal (Elt.header first) (Elt.header elt)\n then (\n (* unlink [elt] *)\n let after_elt = Elt.next elt in\n Elt.split_or_splice_before elt after_elt;\n let first =\n if Elt.equal first elt\n then (\n t := Some after_elt;\n after_elt)\n else first\n in\n (* splice [elt] in before [anchor] *)\n Elt.split_or_splice_before anchor elt;\n if Elt.equal first anchor then t := Some elt)\n else raise Elt_does_not_belong_to_list)\n else raise Elt_does_not_belong_to_list\n;;\n\nlet move_to_front t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first -> if not (Elt.equal elt first) then move_before t elt ~anchor:first\n;;\n\nlet move_after t elt ~anchor =\n if Elt.equal anchor elt then raise Invalid_move__elt_equals_anchor;\n if Header.equal (Elt.header anchor) (Elt.header elt)\n then (\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Header.equal (Elt.header first) (Elt.header elt)\n then (\n (* unlink [elt] *)\n let after_elt = Elt.next elt in\n Elt.split_or_splice_before elt after_elt;\n if Elt.equal first elt then t := Some after_elt;\n (* splice [elt] in after [anchor] *)\n Elt.split_or_splice_after anchor elt)\n else raise Elt_does_not_belong_to_list)\n else raise Elt_does_not_belong_to_list\n;;\n\nlet move_to_back t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n let last = Elt.prev first in\n if not (Elt.equal elt last) then move_after t elt ~anchor:last\n;;\n\nlet to_sequence t = to_list t |> Sequence.of_list\n","open! Import\ninclude Bag_intf\ninclude (Doubly_linked : Doubly_linked.S)\n\nlet add = insert_first\nlet add_unit t v = add t v |> (ignore : _ Elt.t -> unit)\nlet elts t = fold_elt t ~init:[] ~f:(fun acc elt -> elt :: acc)\nlet remove_one = remove_first\nlet choose = first_elt\n\nlet until_empty t f =\n let rec loop () =\n Option.iter (remove_one t) ~f:(fun v ->\n f v;\n loop ())\n in\n loop ()\n;;\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n type t = Base.Sexp.t =\n | Atom of string\n | List of t list\n [@@deriving bin_io, compare, hash]\n\n let t_of_sexp = Sexplib.Sexp.t_of_sexp\n let sexp_of_t = Sexplib.Sexp.sexp_of_t\n end\nend\n\ninclude Stable.V1\n\ninclude (\n Base.Sexp :\n module type of struct\n include Base.Sexp\n end\n with type t := t)\n\ninclude (\n Sexplib.Sexp :\n module type of struct\n include Sexplib.Sexp\n end\n with type t := t)\n\nmodule O = struct\n type sexp = Base.Sexp.t =\n | Atom of string\n | List of t list\nend\n\nmodule Sexp_maybe = struct\n type nonrec 'a t = ('a, t * Error.t) Result.t [@@deriving bin_io, compare, hash]\n\n let sexp_of_t sexp_of_a t =\n match t with\n | Result.Ok a -> sexp_of_a a\n | Result.Error (sexp, err) ->\n List [ Atom \"sexp_parse_error\"; sexp; Error.sexp_of_t err ]\n ;;\n\n let t_of_sexp a_of_sexp sexp =\n match sexp with\n | List [ Atom \"sexp_parse_error\"; sexp; _ ] | sexp ->\n (try Result.Ok (a_of_sexp sexp) with\n | exn -> Result.Error (sexp, Error.of_exn exn))\n ;;\nend\n\nmodule With_text = struct\n open Result.Export\n\n type 'a t =\n { value : 'a\n ; text : string\n }\n [@@deriving bin_io]\n\n let sexp_of_t _ t = Atom t.text\n\n let of_text value_of_sexp ?(filename = \"\") text =\n match Or_error.try_with (fun () -> of_string_conv text value_of_sexp) with\n | Ok (`Result value) -> Ok { value; text }\n | Error _ as err -> err\n | Ok (`Error (exn, annotated)) ->\n Error (Error.of_exn (Annotated.get_conv_exn annotated ~file:filename ~exc:exn))\n ;;\n\n let t_of_sexp a_of_sexp sexp =\n match sexp with\n | List _ ->\n of_sexp_error\n \"With_text.t should be stored as an atom, but instead a list was found.\"\n sexp\n | Atom text -> of_text a_of_sexp text |> Or_error.ok_exn\n ;;\n\n let text t = t.text\n let value t = t.value\n\n let of_value sexp_of_value value =\n let text = sexp_of_value value |> to_string_hum in\n { value; text }\n ;;\nend\n\ntype 'a no_raise = 'a [@@deriving bin_io, sexp]\n\nlet sexp_of_no_raise sexp_of_a a =\n try sexp_of_a a with\n | exn ->\n (try List [ Atom \"failure building sexp\"; sexp_of_exn exn ] with\n | _ -> Atom \"could not build sexp for exn raised when building sexp for value\")\n;;\n\ninclude Comparable.Extend (Base.Sexp) (Base.Sexp)\n\nlet of_sexp_allow_extra_fields_recursively of_sexp sexp =\n let r = Sexplib.Conv.record_check_extra_fields in\n let prev = !r in\n Exn.protect\n ~finally:(fun () -> r := prev)\n ~f:(fun () ->\n r := false;\n of_sexp sexp)\n;;\n\nlet quickcheck_generator = Base_quickcheck.Generator.sexp\nlet quickcheck_observer = Base_quickcheck.Observer.sexp\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.sexp\n","open! Import\nopen Hash_queue_intf\n\nmodule type Key = Key\nmodule type S_backend = S_backend\n\nmodule Make_backend (Table : Hashtbl_intf.Hashtbl) : S_backend = struct\n module type Backend =\n S1\n with type 'key create_arg := 'key Hashtbl.Hashable.t\n with type 'key create_key := 'key\n\n module Backend : Backend = struct\n module Key_value = struct\n module T = struct\n type ('key, 'value) t =\n { key : 'key\n ; mutable value : 'value\n }\n end\n\n include T\n\n let key t = t.key\n let value t = t.value\n\n let sexp_of_t sexp_of_key sexp_of_data { key; value } =\n [%sexp_of: key * data] (key, value)\n ;;\n end\n\n open Key_value.T\n module Elt = Doubly_linked.Elt\n\n type ('key, 'data) t =\n { mutable num_readers : int\n ; queue : ('key, 'data) Key_value.t Doubly_linked.t\n ; table : ('key, ('key, 'data) Key_value.t Elt.t) Table.t\n }\n\n let sexp_of_t sexp_of_key sexp_of_data t =\n [%sexp_of: (key, data) Key_value.t Doubly_linked.t] t.queue\n ;;\n\n let invariant t =\n assert (Doubly_linked.length t.queue = Table.length t.table);\n (* Look at each element in the queue, checking:\n * - every element in the queue is in the hash table\n * - there are no duplicate keys\n *)\n let keys = Table.create ~size:(Table.length t.table) (Table.hashable_s t.table) in\n Doubly_linked.iter t.queue ~f:(fun kv ->\n let key = kv.key in\n match Table.find t.table key with\n | None -> assert false\n | Some _ ->\n assert (not (Table.mem keys key));\n Table.set keys ~key ~data:())\n ;;\n\n let create ?(growth_allowed = true) ?(size = 16) hashable =\n { num_readers = 0\n ; queue = Doubly_linked.create ()\n ; table = Table.create ~growth_allowed ~size (Table.Hashable.to_key hashable)\n }\n ;;\n\n let read t f =\n t.num_readers <- t.num_readers + 1;\n Exn.protect ~f ~finally:(fun () -> t.num_readers <- t.num_readers - 1)\n ;;\n\n let ensure_can_modify t =\n if t.num_readers > 0\n then failwith \"It is an error to modify a Hash_queue.t while iterating over it.\"\n ;;\n\n let clear t =\n ensure_can_modify t;\n Doubly_linked.clear t.queue;\n Table.clear t.table\n ;;\n\n let length t = Table.length t.table\n let is_empty t = length t = 0\n\n let lookup t k =\n match Table.find t.table k with\n | None -> None\n | Some elt -> Some (Elt.value elt).value\n ;;\n\n let lookup_exn t k = (Elt.value (Table.find_exn t.table k)).value\n let mem t k = Table.mem t.table k\n\n (* Note that this is the tail-recursive Core_list.map *)\n let to_list t = List.map (Doubly_linked.to_list t.queue) ~f:Key_value.value\n let to_array t = Array.map (Doubly_linked.to_array t.queue) ~f:Key_value.value\n\n let for_all t ~f =\n read t (fun () -> Doubly_linked.for_all t.queue ~f:(fun kv -> f kv.value))\n ;;\n\n let exists t ~f =\n read t (fun () -> Doubly_linked.exists t.queue ~f:(fun kv -> f kv.value))\n ;;\n\n let find_map t ~f =\n read t (fun () -> Doubly_linked.find_map t.queue ~f:(fun kv -> f kv.value))\n ;;\n\n let find t ~f =\n read t (fun () ->\n Option.map\n (Doubly_linked.find t.queue ~f:(fun kv -> f kv.value))\n ~f:Key_value.value)\n ;;\n\n let enqueue t back_or_front key value =\n ensure_can_modify t;\n if Table.mem t.table key\n then `Key_already_present\n else (\n let contents = { Key_value.key; value } in\n let elt =\n match back_or_front with\n | `back -> Doubly_linked.insert_last t.queue contents\n | `front -> Doubly_linked.insert_first t.queue contents\n in\n Table.set t.table ~key ~data:elt;\n `Ok)\n ;;\n\n let enqueue_back t = enqueue t `back\n let enqueue_front t = enqueue t `front\n\n let raise_enqueue_duplicate_key t key =\n raise_s\n [%message\n \"Hash_queue.enqueue_exn: duplicate key\"\n ~_:(Table.sexp_of_key t.table key : Sexp.t)]\n ;;\n\n let enqueue_exn t back_or_front key value =\n match enqueue t back_or_front key value with\n | `Key_already_present -> raise_enqueue_duplicate_key t key\n | `Ok -> ()\n ;;\n\n let enqueue_back_exn t = enqueue_exn t `back\n let enqueue_front_exn t = enqueue_exn t `front\n\n (* Performance hack: we implement this version separately to avoid allocation from the\n option. *)\n let lookup_and_move_to_back_exn t key =\n ensure_can_modify t;\n let elt = Table.find_exn t.table key in\n Doubly_linked.move_to_back t.queue elt;\n Key_value.value (Elt.value elt)\n ;;\n\n let lookup_and_move_to_back t key =\n let open Option.Let_syntax in\n ensure_can_modify t;\n let%map elt = Table.find t.table key in\n Doubly_linked.move_to_back t.queue elt;\n Key_value.value (Elt.value elt)\n ;;\n\n let lookup_and_move_to_front_exn t key =\n ensure_can_modify t;\n let elt = Table.find_exn t.table key in\n Doubly_linked.move_to_front t.queue elt;\n Key_value.value (Elt.value elt)\n ;;\n\n let lookup_and_move_to_front t key =\n let open Option.Let_syntax in\n ensure_can_modify t;\n let%map elt = Table.find t.table key in\n Doubly_linked.move_to_front t.queue elt;\n Key_value.value (Elt.value elt)\n ;;\n\n let dequeue_with_key t back_or_front =\n ensure_can_modify t;\n let maybe_kv =\n match back_or_front with\n | `back -> Doubly_linked.remove_last t.queue\n | `front -> Doubly_linked.remove_first t.queue\n in\n match maybe_kv with\n | None -> None\n | Some kv ->\n Table.remove t.table kv.key;\n Some (kv.key, kv.value)\n ;;\n\n let raise_dequeue_with_key_empty () =\n raise_s [%message \"Hash_queue.dequeue_with_key: empty queue\"]\n ;;\n\n let dequeue_with_key_exn t back_or_front =\n match dequeue_with_key t back_or_front with\n | None -> raise_dequeue_with_key_empty ()\n | Some (k, v) -> k, v\n ;;\n\n let dequeue_back_with_key t = dequeue_with_key t `back\n let dequeue_back_with_key_exn t = dequeue_with_key_exn t `back\n let dequeue_front_with_key t = dequeue_with_key t `front\n let dequeue_front_with_key_exn t = dequeue_with_key_exn t `front\n\n let dequeue t back_or_front =\n match dequeue_with_key t back_or_front with\n | None -> None\n | Some (_, v) -> Some v\n ;;\n\n let dequeue_back t = dequeue t `back\n let dequeue_front t = dequeue t `front\n\n let first_with_key t =\n match Doubly_linked.first t.queue with\n | None -> None\n | Some { key; value } -> Some (key, value)\n ;;\n\n let first t =\n match Doubly_linked.first t.queue with\n | None -> None\n | Some kv -> Some kv.value\n ;;\n\n let raise_dequeue_empty () = raise_s [%message \"Hash_queue.dequeue_exn: empty queue\"]\n\n let dequeue_exn t back_or_front =\n match dequeue t back_or_front with\n | None -> raise_dequeue_empty ()\n | Some v -> v\n ;;\n\n let dequeue_back_exn t = dequeue_exn t `back\n let dequeue_front_exn t = dequeue_exn t `front\n\n let keys t =\n (* Return the keys in the order of the queue. *)\n List.map (Doubly_linked.to_list t.queue) ~f:Key_value.key\n ;;\n\n let iteri t ~f =\n read t (fun () ->\n Doubly_linked.iter t.queue ~f:(fun kv -> f ~key:kv.key ~data:kv.value))\n ;;\n\n let iter t ~f = iteri t ~f:(fun ~key:_ ~data -> f data)\n\n let foldi t ~init ~f =\n read t (fun () ->\n Doubly_linked.fold t.queue ~init ~f:(fun ac kv ->\n f ac ~key:kv.key ~data:kv.value))\n ;;\n\n let fold t ~init ~f = foldi t ~init ~f:(fun ac ~key:_ ~data -> f ac data)\n let count t ~f = Container.count ~fold t ~f\n let sum m t ~f = Container.sum m ~fold t ~f\n let min_elt t ~compare = Container.min_elt ~fold t ~compare\n let max_elt t ~compare = Container.max_elt ~fold t ~compare\n let fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\n let fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\n\n let dequeue_all t ~f =\n let rec loop () =\n match dequeue_front t with\n | None -> ()\n | Some v ->\n f v;\n loop ()\n in\n loop ()\n ;;\n\n let remove t k =\n ensure_can_modify t;\n match Table.find_and_remove t.table k with\n | None -> `No_such_key\n | Some elt ->\n Doubly_linked.remove t.queue elt;\n `Ok\n ;;\n\n let raise_remove_unknown_key t key =\n raise_s\n [%message\n \"Hash_queue.remove_exn: unknown key\"\n ~_:(Table.sexp_of_key t.table key : Sexp.t)]\n ;;\n\n let remove_exn t k =\n ensure_can_modify t;\n match remove t k with\n | `No_such_key -> raise_remove_unknown_key t k\n | `Ok -> ()\n ;;\n\n let lookup_and_remove t k =\n ensure_can_modify t;\n match Table.find_and_remove t.table k with\n | None -> None\n | Some elt ->\n Doubly_linked.remove t.queue elt;\n Some (Elt.value elt).value\n ;;\n\n let replace t k v =\n ensure_can_modify t;\n match Table.find t.table k with\n | None -> `No_such_key\n | Some elt ->\n (Elt.value elt).value <- v;\n `Ok\n ;;\n\n let raise_replace_unknown_key t key =\n raise_s\n [%message\n \"Hash_queue.replace_exn: unknown key\"\n ~_:(Table.sexp_of_key t.table key : Sexp.t)]\n ;;\n\n let replace_exn t k v =\n ensure_can_modify t;\n match replace t k v with\n | `No_such_key -> raise_replace_unknown_key t k\n | `Ok -> ()\n ;;\n\n let drop ?(n = 1) t back_or_front =\n if n >= length t\n then clear t\n else\n for _ = 1 to n do\n ignore (dequeue_with_key t back_or_front : _ option)\n done\n ;;\n\n let drop_back ?n t = drop ?n t `back\n let drop_front ?n t = drop ?n t `front\n end\n\n module type S = S0 with type ('key, 'data) hash_queue := ('key, 'data) Backend.t\n\n module Make (Key : Key) : S with type key = Key.t = struct\n include (Backend : Backend with type ('k, 'd) t := ('k, 'd) Backend.t)\n\n type key = Key.t\n type 'data t = (Key.t, 'data) Backend.t [@@deriving sexp_of]\n\n let hashable = Table.Hashable.of_key (module Key)\n let create ?growth_allowed ?size () = create ?growth_allowed ?size hashable\n end\n\n include Backend\nend\n\ninclude Make_backend (Hashtbl)\n","(** Functors and interfaces used to make modules hashable. *)\n\nopen! Import\nmodule Binable = Binable0\n\nmodule type Common = sig\n type t [@@deriving compare, hash]\n\n val hashable : t Hashtbl.Hashable.t\nend\n\nmodule type S_plain = sig\n include Common\n module Table : Hashtbl.S_plain with type key = t\n module Hash_set : Hash_set.S_plain with type elt = t\n module Hash_queue : Hash_queue.S with type key = t\nend\n\nmodule type S = sig\n include Common\n module Table : Hashtbl.S with type key = t\n module Hash_set : Hash_set.S with type elt = t\n module Hash_queue : Hash_queue.S with type key = t\nend\n\nmodule Make_plain (T : sig\n type t [@@deriving hash]\n\n include Hashtbl.Key_plain with type t := t\n end) : S_plain with type t := T.t = struct\n include T\n module Table = Hashtbl.Make_plain (T)\n module Hash_set = Hash_set.Make_plain (T)\n module Hash_queue = Hash_queue.Make (T)\n\n let hashable = Table.hashable\nend\n\nmodule Make_plain_and_derive_hash_fold_t (T : Hashtbl.Key_plain) :\n S_plain with type t := T.t = Make_plain (struct\n include T\n\n let hash_fold_t state t = hash_fold_int state (hash t)\n end)\n\nmodule Make (T : sig\n type t [@@deriving hash]\n\n include Hashtbl.Key with type t := t\n end) : S with type t := T.t = struct\n include T\n module Table = Hashtbl.Make (T)\n module Hash_set = Hash_set.Make (T)\n module Hash_queue = Hash_queue.Make (T)\n\n let hashable = Table.hashable\nend\n\nmodule Make_and_derive_hash_fold_t (T : Hashtbl.Key) : S with type t := T.t =\n Make (struct\n include T\n\n let hash_fold_t state t = hash_fold_int state (hash t)\n end)\n\nmodule type S_binable = sig\n type t [@@deriving hash]\n\n val hashable : t Hashtbl.Hashable.t\n\n module Table : Hashtbl.S_binable with type key = t\n module Hash_set : Hash_set.S_binable with type elt = t\n module Hash_queue : Hash_queue.S with type key = t\nend\n\nmodule Make_binable (T : sig\n type t [@@deriving hash]\n\n include Hashtbl.Key_binable with type t := t\n end) : S_binable with type t := T.t = struct\n module Table = Hashtbl.Make_binable (T)\n module Hash_set = Hash_set.Make_binable (T)\n module Hash_queue = Hash_queue.Make (T)\n include T\n\n let hashable = Table.hashable\nend\n\nmodule Make_binable_and_derive_hash_fold_t (T : Hashtbl.Key_binable) :\n S_binable with type t := T.t = Make_binable (struct\n include T\n\n let hash_fold_t state t = hash_fold_int state (hash t)\n end)\n\nmodule Stable : sig\n module V1 : sig\n module type S = sig\n type key\n\n module Table : sig\n type 'a t = (key, 'a) Hashtbl.t [@@deriving sexp, bin_io]\n end\n\n module Hash_set : sig\n type t = key Hash_set.t [@@deriving sexp, bin_io]\n end\n end\n\n module Make (Key : Hashtbl.Key_binable) : S with type key := Key.t\n end\nend = struct\n module V1 = struct\n module type S = sig\n type key\n\n module Table : sig\n type 'a t = (key, 'a) Hashtbl.t [@@deriving sexp, bin_io]\n end\n\n module Hash_set : sig\n type t = key Hash_set.t [@@deriving sexp, bin_io]\n end\n end\n\n module Make (Key : Hashtbl.Key_binable) : S with type key := Key.t = struct\n module Table = Hashtbl.Make_binable (Key)\n module Hash_set = Hash_set.Make_binable (Key)\n end\n end\nend\n","open! Import\nmodule Binable = Binable0\n\nmodule type S_common = sig\n type t [@@deriving compare, hash, sexp_of]\n\n include Stringable.S with type t := t\n include Pretty_printer.S with type t := t\nend\n\nmodule type S_plain = sig\n include S_common\n include Comparable.S_plain with type t := t\n include Hashable.S_plain with type t := t\nend\n\nmodule type S_not_binable = sig\n type t [@@deriving hash, sexp]\n\n include S_common with type t := t\n include Comparable.S with type t := t\n include Hashable.S with type t := t\nend\n\nmodule type S = sig\n type t [@@deriving bin_io, hash, sexp]\n\n include S_common with type t := t\n include Comparable.S_binable with type t := t\n include Hashable.S_binable with type t := t\nend\n\nmodule Make_plain (T : sig\n type t [@@deriving compare, hash, sexp_of]\n\n include Stringable.S with type t := t\n\n val module_name : string\n end) =\nstruct\n include T\n include Comparable.Make_plain (T)\n include Hashable.Make_plain (T)\n include Pretty_printer.Register (T)\nend\n\nmodule Make (T : sig\n type t [@@deriving bin_io, compare, hash, sexp]\n\n include Stringable.S with type t := t\n\n val module_name : string\n end) =\nstruct\n include T\n include Comparable.Make_binable (T)\n include Hashable.Make_binable (T)\n include Pretty_printer.Register (T)\nend\n\nmodule Make_and_derive_hash_fold_t (T : sig\n type t [@@deriving bin_io, compare, sexp]\n\n include Stringable.S with type t := t\n\n val hash : t -> int\n val module_name : string\n end) =\n Make (struct\n include T\n\n let hash_fold_t state t = hash_fold_int state (hash t)\n end)\n\nmodule Make_using_comparator (T : sig\n type t [@@deriving bin_io, compare, hash, sexp]\n\n include Comparator.S with type t := t\n include Stringable.S with type t := t\n\n val module_name : string\n end) =\nstruct\n include T\n include Comparable.Make_binable_using_comparator (T)\n include Hashable.Make_binable (T)\n include Pretty_printer.Register (T)\nend\n\nmodule Make_using_comparator_and_derive_hash_fold_t (T : sig\n type t [@@deriving bin_io, compare, sexp]\n\n include Comparator.S with type t := t\n include Stringable.S with type t := t\n\n val hash : t -> int\n val module_name : string\n end) =\n Make_using_comparator (struct\n include T\n\n let hash_fold_t state t = hash_fold_int state (hash t)\n end)\n\nmodule Extend (M : Base.Identifiable.S) (B : Binable0.S with type t = M.t) = struct\n module T = struct\n include M\n include (B : Binable.S with type t := t)\n end\n\n include T\n include Comparable.Extend_binable (M) (T)\n include Hashable.Make_binable (T)\nend\n","open! Import\n\ntype t = bool [@@deriving bin_io, typerep]\n\ninclude Identifiable.Extend\n (Base.Bool)\n (struct\n type nonrec t = t [@@deriving bin_io]\n end)\n\nmodule Replace_polymorphic_compare = Base.Bool\n\ninclude (\n Base.Bool :\n module type of struct\n include Base.Bool\n end\n with type t := t)\n\nlet quickcheck_generator = Base_quickcheck.Generator.bool\nlet quickcheck_observer = Base_quickcheck.Observer.bool\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.bool\n\nmodule Stable = struct\n module V1 = struct\n type nonrec t = t [@@deriving compare, sexp, bin_io]\n end\nend\n","(** A functor for displaying a type as a sequence of ASCII characters printed in\n hexadecimal.\n\n [sexp_of_t] and [to_string_hum] print [t] in a similar format to 'hexdump' on Unix\n systems. For example, the string \"Back off, man, I'm a scientist.\" renders as:\n\n {v\n00000000 42 61 63 6b 20 6f 66 66 2c 20 6d 61 6e 2c 20 49 |Back off, man, I|\n00000010 27 6d 20 61 20 73 63 69 65 6e 74 69 73 74 2e |'m a scientist.|\n v}\n\n [to_sequence] produces a sequence of strings representing lines in the hex dump. It\n can be used to process a hex dump incrementally, for example with potentially infinite\n values, or to avoid keeping the entire output in memory at once. *)\n\nopen! Import\n\nmodule type S = sig\n type t\n\n module Hexdump : sig\n type nonrec t = t [@@deriving sexp_of]\n\n (** [to_string_hum] renders [t] as a multi-line ASCII string in hexdump format. [pos]\n and [len] select a subrange of [t] to render. [max_lines] determines the maximum\n number of lines of hex dump to produce. If the full hex dump exceeds this number,\n lines in the middle are replaced by a single \"...\"; the beginning and end of the\n hex dump are left intact. In order to produce at least some readable hex dump, at\n least 3 lines are always produced. *)\n val to_string_hum\n : ?max_lines:int (** default: [!default_max_lines] *)\n -> ?pos:int\n -> ?len:int\n -> t\n -> string\n\n (** [to_sequence] produces the lines of [to_string_hum] as a sequence of strings.\n This may be useful for incrementally rendering a large hex dump without producing\n the whole thing in memory. Optional arguments function as in [to_string_hum]. *)\n val to_sequence\n : ?max_lines:int (** default: [!default_max_lines] *)\n -> ?pos:int\n -> ?len:int\n -> t\n -> string Sequence.t\n\n (** [[%sexp_of: Hexdump.Pretty.t]] is the same as [[%sexp_of: Hexdump.t]], unless the\n underlying sequence of characters is entirely printable. In that case, it is\n rendered directly as a string. This allows e.g. test output to be much more\n compact in the common (printable) case while still being interpretable for any\n byte sequence. *)\n module Pretty : sig\n type nonrec t = t [@@deriving sexp_of]\n end\n end\nend\n\nmodule type S1 = sig\n type _ t\n\n module Hexdump : sig\n type nonrec 'a t = 'a t [@@deriving sexp_of]\n\n val to_string_hum : ?max_lines:int -> ?pos:int -> ?len:int -> _ t -> string\n\n\n val to_sequence : ?max_lines:int -> ?pos:int -> ?len:int -> _ t -> string Sequence.t\n\n module Pretty : sig\n type nonrec 'a t = 'a t [@@deriving sexp_of]\n end\n end\nend\n\nmodule type S2 = sig\n type (_, _) t\n\n module Hexdump : sig\n type nonrec ('a, 'b) t = ('a, 'b) t [@@deriving sexp_of]\n\n val to_string_hum : ?max_lines:int -> ?pos:int -> ?len:int -> (_, _) t -> string\n\n val to_sequence\n : ?max_lines:int\n -> ?pos:int\n -> ?len:int\n -> (_, _) t\n -> string Sequence.t\n\n module Pretty : sig\n type nonrec ('a, 'b) t = ('a, 'b) t [@@deriving sexp_of]\n end\n end\nend\n\n(** The functor [Hexdump.Of_indexable] uses [length] and [get] to iterate over the\n characters in a value and produce a hex dump. *)\nmodule type Indexable = sig\n type t\n\n val length : t -> int\n val get : t -> int -> char\nend\n\nmodule type Indexable1 = sig\n type _ t\n\n val length : _ t -> int\n val get : _ t -> int -> char\nend\n\nmodule type Indexable2 = sig\n type (_, _) t\n\n val length : (_, _) t -> int\n val get : (_, _) t -> int -> char\nend\n\nmodule type Hexdump = sig\n module type Indexable = Indexable\n module type Indexable1 = Indexable1\n module type Indexable2 = Indexable2\n module type S = S\n module type S1 = S1\n module type S2 = S2\n\n (** Can be used to override the default [~lines] argument for [to_string_hum] and\n [to_sequence] in [S]. *)\n val default_max_lines : int ref\n\n module Of_indexable (T : Indexable) : S with type t := T.t\n module Of_indexable1 (T : Indexable1) : S1 with type 'a t := 'a T.t\n module Of_indexable2 (T : Indexable2) : S2 with type ('a, 'b) t := ('a, 'b) T.t\nend\n","open! Import\nmodule Char = Base.Char\nmodule Int = Base.Int\nmodule String = Base.String\ninclude Hexdump_intf\n\nlet bytes_per_line = 16\n\n(* Initialize to enough lines to display 4096 bytes -- large enough that, for example, a\n complete Ethernet packet can always be displayed -- including the line containing the\n final index. *)\nlet default_max_lines = ref ((4096 / bytes_per_line) + 1)\n\nmodule Of_indexable2 (T : Indexable2) = struct\n module Hexdump = struct\n include T\n\n let hex_of_pos pos = Printf.sprintf \"%08x\" pos\n\n let hex_of_char t ~start ~until offset =\n let pos = start + offset in\n if pos >= until then \" \" else Printf.sprintf \"%02x\" (Char.to_int (get t pos))\n ;;\n\n let hex_of_line t ~start ~until =\n Printf.sprintf\n \"%s %s %s %s %s %s %s %s %s %s %s %s %s %s %s %s\"\n (hex_of_char t ~start ~until 0)\n (hex_of_char t ~start ~until 1)\n (hex_of_char t ~start ~until 2)\n (hex_of_char t ~start ~until 3)\n (hex_of_char t ~start ~until 4)\n (hex_of_char t ~start ~until 5)\n (hex_of_char t ~start ~until 6)\n (hex_of_char t ~start ~until 7)\n (hex_of_char t ~start ~until 8)\n (hex_of_char t ~start ~until 9)\n (hex_of_char t ~start ~until 10)\n (hex_of_char t ~start ~until 11)\n (hex_of_char t ~start ~until 12)\n (hex_of_char t ~start ~until 13)\n (hex_of_char t ~start ~until 14)\n (hex_of_char t ~start ~until 15)\n ;;\n\n let printable_string t ~start ~until =\n String.init (until - start) ~f:(fun i ->\n let char = get t (start + i) in\n if Char.is_print char then char else '.')\n ;;\n\n let line t ~pos ~len ~line_index =\n let start = pos + (line_index * bytes_per_line) in\n let until = min (start + bytes_per_line) (pos + len) in\n Printf.sprintf\n \"%s %s |%s|\"\n (hex_of_pos start)\n (hex_of_line t ~start ~until)\n (printable_string t ~start ~until)\n ;;\n\n let to_sequence ?max_lines ?pos ?len t =\n let pos, len =\n Ordered_collection_common.get_pos_len_exn () ?pos ?len ~total_length:(length t)\n in\n let max_lines =\n match max_lines with\n | Some max_lines -> max_lines\n | None -> !default_max_lines\n in\n (* always produce at least 3 lines: first line of hex, ellipsis, last line of hex *)\n let max_lines = max max_lines 3 in\n (* unabridged lines = lines of hex + line with final index *)\n let unabridged_lines =\n Int.round_up len ~to_multiple_of:bytes_per_line / bytes_per_line\n in\n (* Figure out where we need to skip from and to if [max_lines < unabridged_lines].\n Skip after half the actual hex lines (subtracting one line for the ellipsis).\n Skip to near the end, less the number of lines remaining to produce, plus the\n ellipsis line. *)\n let skip_from = (max_lines - 1) / 2 in\n let skip_to = unabridged_lines - (max_lines - skip_from) + 1 in\n Sequence.unfold_step ~init:0 ~f:(fun line_index ->\n if line_index >= unabridged_lines\n then Done\n else if line_index = skip_from && max_lines < unabridged_lines\n then Yield (\"...\", skip_to)\n else Yield (line t ~pos ~len ~line_index, line_index + 1))\n ;;\n\n let to_string_hum ?max_lines ?pos ?len t =\n to_sequence ?max_lines ?pos ?len t |> Sequence.to_list |> String.concat ~sep:\"\\n\"\n ;;\n\n let sexp_of_t _ _ t = to_sequence t |> Sequence.to_list |> [%sexp_of: string list]\n\n module Pretty = struct\n include T\n\n let printable =\n let rec printable_from t ~pos ~length =\n pos >= length\n || (Char.is_print (get t pos) && printable_from t ~pos:(pos + 1) ~length)\n in\n fun t -> printable_from t ~pos:0 ~length:(length t)\n ;;\n\n let to_string t = String.init (length t) ~f:(fun pos -> get t pos)\n\n let sexp_of_t sexp_of_a sexp_of_b t =\n if printable t then [%sexp (to_string t : string)] else [%sexp (t : (a, b) t)]\n ;;\n end\n end\nend\n\nmodule Of_indexable1 (T : Indexable1) = struct\n module M = Of_indexable2 (struct\n type ('a, _) t = 'a T.t\n\n let length = T.length\n let get = T.get\n end)\n\n module Hexdump = struct\n include T\n\n let sexp_of_t x t = M.Hexdump.sexp_of_t x [%sexp_of: _] t\n let to_sequence = M.Hexdump.to_sequence\n let to_string_hum = M.Hexdump.to_string_hum\n\n module Pretty = struct\n include T\n\n let sexp_of_t sexp_of_a t = [%sexp (t : (a, _) M.Hexdump.Pretty.t)]\n end\n end\nend\n\nmodule Of_indexable (T : Indexable) = struct\n module M = Of_indexable1 (struct\n type _ t = T.t\n\n let length = T.length\n let get = T.get\n end)\n\n module Hexdump = struct\n include T\n\n let sexp_of_t t = M.Hexdump.sexp_of_t [%sexp_of: _] t\n let to_sequence = M.Hexdump.to_sequence\n let to_string_hum = M.Hexdump.to_string_hum\n\n module Pretty = struct\n include T\n\n let sexp_of_t t = [%sexp (t : _ M.Hexdump.Pretty.t)]\n end\n end\nend\n","open! Import\ninclude Base.String\n\n(* These two are needed because [include Identifiable.Extend] (present later in the file)\n binds new [Map] and [Set] modules. *)\nmodule Core_map = Map\nmodule Core_set = Set\n\nmodule Stable = struct\n module V1 = struct\n module T = struct\n include Base.String\n\n type t = string [@@deriving bin_io]\n end\n\n include T\n\n let to_string = Fn.id\n let of_string = Fn.id\n\n include Comparable.Stable.V1.Make (T)\n include Hashable.Stable.V1.Make (T)\n end\nend\n\nmodule Caseless = struct\n module T = struct\n include Caseless\n\n type t = string [@@deriving bin_io]\n end\n\n include T\n include Comparable.Make_binable_using_comparator (T)\n include Hashable.Make_binable (T)\nend\n\ntype t = string [@@deriving typerep]\n\ninclude Identifiable.Extend\n (Base.String)\n (struct\n type t = string [@@deriving bin_io]\n end)\n\ninclude Hexdump.Of_indexable (struct\n type t = string\n\n let length = length\n let get = get\n end)\n\nlet quickcheck_generator = Base_quickcheck.Generator.string\nlet quickcheck_observer = Base_quickcheck.Observer.string\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.string\nlet gen_nonempty = Base_quickcheck.Generator.string_non_empty\nlet gen' = Base_quickcheck.Generator.string_of\nlet gen_nonempty' = Base_quickcheck.Generator.string_non_empty_of\n\nlet gen_with_length length chars =\n Base_quickcheck.Generator.string_with_length_of chars ~length\n;;\n\nlet take_while t ~f =\n match lfindi t ~f:(fun _ elt -> not (f elt)) with\n | None -> t\n | Some i -> sub t ~pos:0 ~len:i\n;;\n\nlet rtake_while t ~f =\n match rfindi t ~f:(fun _ elt -> not (f elt)) with\n | None -> t\n | Some i -> sub t ~pos:(i + 1) ~len:(length t - i - 1)\n;;\n\n(** See {!Array.normalize} for the following 4 functions. *)\nlet normalize t i = Ordered_collection_common.normalize ~length_fun:length t i\n\nlet slice t start stop =\n Ordered_collection_common.slice ~length_fun:length ~sub_fun:sub t start stop\n;;\n\nlet nget x i =\n let module String = Base.String in\n x.[normalize x i]\n;;\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n include Base.Bytes\n\n type t = bytes [@@deriving bin_io, typerep]\n end\nend\n\ninclude Stable.V1\n\ninclude Hexdump.Of_indexable (struct\n type t = bytes\n\n let length = length\n let get = get\n end)\n\nlet quickcheck_generator =\n String.quickcheck_generator |> Quickcheck.Generator.map ~f:of_string\n;;\n\nlet quickcheck_observer =\n String.quickcheck_observer |> Quickcheck.Observer.unmap ~f:to_string\n;;\n\nlet quickcheck_shrinker =\n String.quickcheck_shrinker |> Quickcheck.Shrinker.map ~f:of_string ~f_inverse:to_string\n;;\n\nlet gen' char_gen = String.gen' char_gen |> Quickcheck.Generator.map ~f:of_string\n\nlet gen_with_length len char_gen =\n String.gen_with_length len char_gen |> Quickcheck.Generator.map ~f:of_string\n;;\n","open! Import\n\ntype t = char [@@deriving typerep]\n\ninclude Identifiable.Extend\n (Base.Char)\n (struct\n type t = char [@@deriving bin_io]\n end)\n\n(* include [Base.Char] after the application of [Identifiable.Extend] to replace the\n [Comparable] functions with the pervasive versions *)\ninclude (\n Base.Char :\n module type of struct\n include Base.Char\n end\n with type t := t)\n\nmodule Caseless = struct\n module T = struct\n include Caseless\n\n type t = char [@@deriving bin_io]\n end\n\n include T\n include Comparable.Make_binable_using_comparator (T)\n include Hashable.Make_binable (T)\nend\n\nmodule Replace_polymorphic_compare = Base.Char\n\nlet quickcheck_generator = Base_quickcheck.Generator.char\nlet quickcheck_observer = Base_quickcheck.Observer.char\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.char\nlet gen_digit = Base_quickcheck.Generator.char_digit\nlet gen_lowercase = Base_quickcheck.Generator.char_lowercase\nlet gen_uppercase = Base_quickcheck.Generator.char_uppercase\nlet gen_alpha = Base_quickcheck.Generator.char_alpha\nlet gen_alphanum = Base_quickcheck.Generator.char_alphanum\nlet gen_print = Base_quickcheck.Generator.char_print\nlet gen_whitespace = Base_quickcheck.Generator.char_whitespace\nlet gen_uniform_inclusive = Base_quickcheck.Generator.char_uniform_inclusive\n","include Caml\n\n(* At Jane Street, the OCaml stdlib is patched to define [Pervasives.raise] as the\n [\"%reraise\"] primitive. We do this as the compiler is currently not good enough at\n automatically detecting reraise [1]. We patch the stdlib so that everything is\n affected, including libraries defined before base such as sexplib or non Jane Street\n libraries.\n\n We need this definition so that this implementation can match its interface with the\n patched stdlib and with the original one.\n\n [[1] http://caml.inria.fr/mantis/view.php?id=6556\n*)\nexternal raise : exn -> 'a = \"%reraise\"\n","open! Import\nmodule Sign = Base.Sign\n\nmodule Stable = struct\n module V1 = struct\n type t = Sign.t =\n | Neg\n | Zero\n | Pos\n [@@deriving sexp, bin_io, compare, hash, typerep, enumerate]\n end\nend\n\ninclude Stable.V1\ninclude Sign\ninclude Identifiable.Extend (Sign) (Stable.V1)\n","external format_float : string -> float -> string = \"caml_format_float\"\n\n(* Stolen from [pervasives.ml]. Adds a \".\" at the end if needed. It is in\n [pervasives.mli], but it also says not to use it directly, so we copy and paste the\n code. It makes the assumption on the string passed in argument that it was returned by\n [format_float] *)\nlet valid_float_lexem s =\n let l = String.length s in\n let rec loop i =\n if i >= l\n then s ^ \".\"\n else (\n match s.[i] with\n | '0' .. '9' | '-' -> loop (i + 1)\n | _ -> s)\n in\n loop 0\n;;\n\nopen! Import\nmodule List = Base.List\n\nmodule T = struct\n include Base.Float\n\n type t = float [@@deriving bin_io, typerep]\nend\n\ninclude T\ninclude Hashable.Make_binable (T)\ninclude Comparable.Map_and_set_binable_using_comparator (T)\nmodule Replace_polymorphic_compare : Comparisons.S with type t := t = T\n\nmodule Robust_compare = struct\n module type S = sig\n (* intended to be a tolerance on human-entered floats *)\n\n val robust_comparison_tolerance : float\n\n include Robustly_comparable.S with type t := float\n end\n\n module Make (T : sig\n val robust_comparison_tolerance : float\n end) : S = struct\n (* We have test in the tree that rely on these functions not allocating, even without\n X_LIBRARY_INLING. The only way to ensure that these don't create temporary boxed\n floats without X_LIBRARY_INLING is for this code to see the float operations as\n externals, as defined in [Pervasives]. That's why we use [Poly] and float\n arithmetic from [Caml]. *)\n open Poly\n\n let robust_comparison_tolerance = T.robust_comparison_tolerance\n let ( >=. ) x y = x >= Caml.( -. ) y robust_comparison_tolerance\n let ( <=. ) x y = y >=. x\n let ( =. ) x y = x >=. y && y >=. x\n let ( >. ) x y = x > Caml.( +. ) y robust_comparison_tolerance\n let ( <. ) x y = y >. x\n let ( <>. ) x y = not (x =. y)\n\n let robustly_compare x y =\n let d = Caml.( -. ) x y in\n if d < Caml.( ~-. ) robust_comparison_tolerance\n then -1\n else if d > robust_comparison_tolerance\n then 1\n else 0\n ;;\n end\nend\n\nmodule Robustly_comparable = Robust_compare.Make (struct\n let robust_comparison_tolerance = 1E-7\n end)\n\ninclude Robustly_comparable\n\nmodule O = struct\n include Base.Float.O\n include Robustly_comparable\nend\n\nmodule Terse = struct\n type nonrec t = t [@@deriving bin_io]\n\n include (\n Base.Float.Terse :\n module type of struct\n include Base.Float.Terse\n end\n with type t := t)\nend\n\nlet robust_sign t : Sign.t = if t >. 0. then Pos else if t <. 0. then Neg else Zero\n\n(* There are two issues:\n - Float.sign used to use robust comparison, and users of [Core] might have come to\n depend on this.\n - Robustness aside, what we get from Comparable.With_zero would map nan to Neg.\n*)\nlet sign = robust_sign\n\n(* Standard 12 significant digits, exponential notation used as necessary, guaranteed to\n be a valid OCaml float lexem, not to look like an int. *)\nlet to_string_12 x = valid_float_lexem (format_float \"%.12g\" x)\nlet quickcheck_generator = Base_quickcheck.Generator.float\nlet quickcheck_observer = Base_quickcheck.Observer.float\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.float\nlet gen_uniform_excl = Base_quickcheck.Generator.float_uniform_exclusive\nlet gen_incl = Base_quickcheck.Generator.float_inclusive\nlet gen_without_nan = Base_quickcheck.Generator.float_without_nan\nlet gen_finite = Base_quickcheck.Generator.float_finite\nlet gen_positive = Base_quickcheck.Generator.float_strictly_positive\nlet gen_negative = Base_quickcheck.Generator.float_strictly_negative\nlet gen_zero = Base_quickcheck.Generator.float_of_class Zero\nlet gen_nan = Base_quickcheck.Generator.float_of_class Nan\nlet gen_subnormal = Base_quickcheck.Generator.float_of_class Subnormal\nlet gen_normal = Base_quickcheck.Generator.float_of_class Normal\nlet gen_infinite = Base_quickcheck.Generator.float_of_class Infinite\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n module T = struct\n include Base.Int\n\n type t = int [@@deriving hash, bin_io, sexp]\n end\n\n include T\n include Comparable.Stable.V1.Make (T)\n end\nend\n\ninclude Identifiable.Extend\n (Base.Int)\n (struct\n type t = int [@@deriving bin_io]\n end)\n\nmodule Replace_polymorphic_compare = Base.Int\ninclude Base.Int\n\ntype t = int [@@deriving typerep]\n\nmodule Hex = struct\n include Hex\n\n type nonrec t = t [@@deriving typerep, bin_io]\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.int\nlet quickcheck_observer = Base_quickcheck.Observer.int\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.int\nlet gen_incl = Base_quickcheck.Generator.int_inclusive\nlet gen_uniform_incl = Base_quickcheck.Generator.int_uniform_inclusive\nlet gen_log_incl = Base_quickcheck.Generator.int_log_inclusive\nlet gen_log_uniform_incl = Base_quickcheck.Generator.int_log_uniform_inclusive\n","open! Import\n\ninclude Identifiable.Extend\n (Base.Int32)\n (struct\n type t = int32 [@@deriving bin_io]\n end)\n\ninclude Base.Int32\n\ntype t = int32 [@@deriving typerep]\n\nmodule Hex = struct\n include Hex\n\n type nonrec t = t [@@deriving typerep, bin_io]\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.int32\nlet quickcheck_observer = Base_quickcheck.Observer.int32\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.int32\nlet gen_incl = Base_quickcheck.Generator.int32_inclusive\nlet gen_uniform_incl = Base_quickcheck.Generator.int32_uniform_inclusive\nlet gen_log_incl = Base_quickcheck.Generator.int32_log_inclusive\nlet gen_log_uniform_incl = Base_quickcheck.Generator.int32_log_uniform_inclusive\n","(* unsigned_extended.ml *)\n\nopen Core_kernel\ninclude Intf\nopen Snark_params\nopen Tick\n\nmodule type Unsigned_intf = Unsigned.S\n\nmodule Extend\n (Unsigned : Unsigned.S) (M : sig\n val length : int\n end) : S with type t = Unsigned.t = struct\n assert (M.length < Field.size_in_bits - 3)\n\n let length_in_bits = M.length\n\n module T = struct\n include Sexpable.Of_stringable (Unsigned)\n\n type t = Unsigned.t\n\n let compare = Unsigned.compare\n\n let hash_fold_t s t = Int64.hash_fold_t s (Unsigned.to_int64 t)\n\n let hash t = Int64.hash (Unsigned.to_int64 t)\n\n let to_bigint t =\n let i64 = Unsigned.to_int64 t in\n if Int64.(i64 >= 0L) then Bignum_bigint.of_int64 i64\n else\n Bignum_bigint.(\n of_int64 i64 - of_int64 Int64.min_value + of_int64 Int64.max_value\n + one)\n end\n\n include T\n include Hashable.Make (T)\n\n include (Unsigned : Unsigned_intf with type t := t)\n\n (* serializes to and from json as strings since bit lengths > 32 cannot be represented in json *)\n let to_yojson n = `String (to_string n)\n\n let of_yojson = function\n | `String s ->\n Ok (of_string s)\n | _ ->\n Error \"expected string\"\n\n let ( < ) x y = compare x y < 0\n\n let ( > ) x y = compare x y > 0\n\n let ( = ) x y = compare x y = 0\n\n let ( <= ) x y = compare x y <= 0\n\n let ( >= ) x y = compare x y >= 0\nend\n\nmodule UInt64 = struct\n module M =\n Extend\n (Unsigned.UInt64)\n (struct\n let length = 64\n end)\n\n (* this module allows use to generate With_all_version_tags from the\n Binable.Of_binable functor below, needed to decode transaction ids\n for V1 signed commands; it does not add any tags\n *)\n module Int64_for_version_tags = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t = (Int64.t[@version_asserted])\n\n let to_latest = Fn.id\n\n module With_all_version_tags = struct\n type typ = t [@@deriving bin_io_unversioned]\n\n type t = typ [@@deriving bin_io_unversioned]\n end\n end\n end]\n end\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Unsigned.UInt64.t\n\n let to_latest = Fn.id\n\n (* these are defined in the Extend functor, rather than derived, so import them *)\n [%%define_locally\n M.\n ( equal\n , compare\n , hash\n , hash_fold_t\n , sexp_of_t\n , t_of_sexp\n , to_yojson\n , of_yojson )]\n\n module M = struct\n type t = Unsigned.UInt64.t\n\n let to_binable = Unsigned.UInt64.to_int64\n\n let of_binable = Unsigned.UInt64.of_int64\n end\n\n include Binable.Of_binable (Int64_for_version_tags.Stable.V1) (M)\n end\n end]\n\n include M\n\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n\n let to_uint64 : t -> uint64 = Fn.id\n\n let of_uint64 : uint64 -> t = Fn.id\nend\n\nmodule UInt32 = struct\n module M =\n Extend\n (Unsigned.UInt32)\n (struct\n let length = 32\n end)\n\n (* this module allows use to generate With_all_version_tags from the\n Binable.Of_binable functor below, needed to decode transaction ids\n for V1 signed commands; it does not add any tags\n *)\n module Int32_for_version_tags = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t = (Int32.t[@version_asserted])\n\n let to_latest = Fn.id\n\n module With_all_version_tags = struct\n type typ = t [@@deriving bin_io_unversioned]\n\n type t = typ [@@deriving bin_io_unversioned]\n end\n end\n end]\n end\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Unsigned.UInt32.t\n\n let to_latest = Fn.id\n\n (* these are defined in the Extend functor, rather than derived, so import them *)\n [%%define_locally\n M.\n ( equal\n , compare\n , hash\n , hash_fold_t\n , sexp_of_t\n , t_of_sexp\n , to_yojson\n , of_yojson )]\n\n module M = struct\n type t = Unsigned.UInt32.t\n\n let to_binable = Unsigned.UInt32.to_int32\n\n let of_binable = Unsigned.UInt32.of_int32\n end\n\n include Binable.Of_binable (Int32_for_version_tags.Stable.V1) (M)\n end\n end]\n\n include M\n\n let to_uint32 : t -> uint32 = Fn.id\n\n let of_uint32 : uint32 -> t = Fn.id\nend\n","open! Import\n\ninclude Identifiable.Extend\n (Base.Int64)\n (struct\n type t = int64 [@@deriving bin_io]\n end)\n\ninclude Base.Int64\n\ntype t = int64 [@@deriving typerep]\n\nmodule Hex = struct\n include Hex\n\n type nonrec t = t [@@deriving typerep, bin_io]\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.int64\nlet quickcheck_observer = Base_quickcheck.Observer.int64\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.int64\nlet gen_incl = Base_quickcheck.Generator.int64_inclusive\nlet gen_uniform_incl = Base_quickcheck.Generator.int64_uniform_inclusive\nlet gen_log_incl = Base_quickcheck.Generator.int64_log_inclusive\nlet gen_log_uniform_incl = Base_quickcheck.Generator.int64_log_uniform_inclusive\n","open! Import\n\nmodule Bin : Binable0.S with type t := Base.Int63.t = struct\n module Bin_emulated = struct\n type t = Base.Int63.Private.Emul.t\n\n include Binable0.Of_binable_without_uuid [@alert \"-legacy\"]\n (Int64)\n (struct\n type nonrec t = t\n\n let of_binable = Base.Int63.Private.Emul.W.wrap_exn\n let to_binable = Base.Int63.Private.Emul.W.unwrap\n end)\n end\n\n type 'a binable = (module Binable0.S with type t = 'a)\n\n let binable_of_repr : type a b. (a, b) Base.Int63.Private.Repr.t -> b binable\n = function\n | Base.Int63.Private.Repr.Int -> (module Int)\n | Base.Int63.Private.Repr.Int64 -> (module Bin_emulated)\n ;;\n\n let binable : Base.Int63.t binable = binable_of_repr Base.Int63.Private.repr\n\n include (val binable)\n\n let bin_shape_t = Bin_prot.Shape.bin_shape_int63\nend\n\nmodule Stable = struct\n module V1 = struct\n module T = struct\n type t = Base.Int63.t [@@deriving hash, sexp]\n\n include Bin\n\n include (\n Base.Int63 :\n Base.Comparable.S\n with type t := t\n with type comparator_witness = Base.Int63.comparator_witness)\n end\n\n include T\n include Comparable.Stable.V1.Make (T)\n end\nend\n\n(* This [include struct] is required because it lets us shadow [t] when we include\n [Base.Int63] later on. *)\ninclude struct\n type t = Base.Int63.t\nend\n\nlet typerep_of_t = typerep_of_int63\nlet typename_of_t = typename_of_int63\n\ninclude Identifiable.Extend\n (Base.Int63)\n (struct\n type nonrec t = t\n\n include Bin\n end)\n\nmodule Replace_polymorphic_compare : Comparable.Polymorphic_compare with type t := t =\n Base.Int63\n\ninclude Base.Int63\n\nmodule Hex = struct\n include Hex\n\n type nonrec t = t [@@deriving typerep, bin_io]\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.int63\nlet quickcheck_observer = Base_quickcheck.Observer.int63\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.int63\nlet gen_incl = Base_quickcheck.Generator.int63_inclusive\nlet gen_uniform_incl = Base_quickcheck.Generator.int63_uniform_inclusive\nlet gen_log_incl = Base_quickcheck.Generator.int63_log_inclusive\nlet gen_log_uniform_incl = Base_quickcheck.Generator.int63_log_uniform_inclusive\n","module Stable = struct\n open Base.Export\n open Bin_prot.Std\n\n module V1 = struct\n module T = struct\n type t = unit [@@deriving bin_io, compare, sexp]\n end\n\n include T\n include Comparator.Stable.V1.Make (T)\n\n let%expect_test _ =\n print_endline [%bin_digest: t];\n [%expect {| 86ba5df747eec837f0b391dd49f33f9e |}]\n ;;\n end\nend\n\nopen! Import\n\ninclude Identifiable.Extend\n (Base.Unit)\n (struct\n type t = unit [@@deriving bin_io]\n end)\n\ninclude Base.Unit\n\ntype t = unit [@@deriving typerep]\n\nlet quickcheck_generator = Base_quickcheck.Generator.unit\nlet quickcheck_observer = Base_quickcheck.Observer.unit\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.unit\n\nmodule type S = sig end\n\ntype m = (module S)\n","(** Various interface exports. *)\n\nopen! Import\n\nmodule type Applicative = Applicative.S\nmodule type Binable = Binable0.S\nmodule type Comparable = Comparable.S\nmodule type Comparable_binable = Comparable.S_binable\nmodule type Floatable = Floatable.S\nmodule type Hashable = Hashable.S\nmodule type Hashable_binable = Hashable.S_binable\nmodule type Identifiable = Identifiable.S\nmodule type Infix_comparators = Comparable.Infix\nmodule type Intable = Intable.S\nmodule type Monad = Monad.S\nmodule type Quickcheckable = Quickcheckable.S\nmodule type Robustly_comparable = Robustly_comparable.S\nmodule type Sexpable = Sexpable.S\nmodule type Stable = Stable_module_types.S0\nmodule type Stable_int63able = Stable_int63able.S\nmodule type Stable_without_comparator = Stable_module_types.S0_without_comparator\nmodule type Stable1 = Stable_module_types.S1\nmodule type Stable2 = Stable_module_types.S2\nmodule type Stable3 = Stable_module_types.S3\nmodule type Stable4 = Stable_module_types.S4\nmodule type Stringable = Stringable.S\nmodule type Unit = Unit.S\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n open Sexplib.Std\n\n type 'a t = 'a lazy_t [@@deriving bin_io, sexp, typerep]\n\n let map = Base.Lazy.map\n let compare = Base.Lazy.compare\n let t_sexp_grammar = lazy_t_sexp_grammar\n end\nend\n\nmodule type Base_mask = module type of Base.Lazy with type 'a t := 'a Stable.V1.t\n\ninclude Stable.V1\ninclude (Base.Lazy : Base_mask)\n","open! Import\n\ninclude Identifiable.Extend\n (Base.Nativeint)\n (struct\n type t = nativeint [@@deriving bin_io]\n end)\n\ninclude Base.Nativeint\n\ntype t = nativeint [@@deriving typerep]\n\nmodule Hex = struct\n include Hex\n\n type nonrec t = t [@@deriving typerep, bin_io]\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.nativeint\nlet quickcheck_observer = Base_quickcheck.Observer.nativeint\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.nativeint\nlet gen_incl = Base_quickcheck.Generator.nativeint_inclusive\nlet gen_uniform_incl = Base_quickcheck.Generator.nativeint_uniform_inclusive\nlet gen_log_incl = Base_quickcheck.Generator.nativeint_log_inclusive\nlet gen_log_uniform_incl = Base_quickcheck.Generator.nativeint_log_uniform_inclusive\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n type t = Base.Nothing.t = |\n\n module Shape = struct\n type t [@@deriving bin_shape]\n end\n\n let unreachable_code = Base.Nothing.unreachable_code\n let bin_shape_t = Shape.bin_shape_t\n let tp_loc = [%here].pos_fname ^ \".Stable.V1.t\"\n let all = []\n let hash_fold_t _ t = unreachable_code t\n let hash = unreachable_code\n let compare a _ = unreachable_code a\n let bin_size_t = unreachable_code\n let bin_write_t _buf ~pos:_ t = unreachable_code t\n let bin_writer_t = { Bin_prot.Type_class.size = bin_size_t; write = bin_write_t }\n\n let __bin_read_t__ _buf ~pos_ref _ =\n Bin_prot.Common.raise_variant_wrong_type tp_loc !pos_ref\n ;;\n\n let bin_read_t _buf ~pos_ref =\n Bin_prot.Common.raise_read_error (Empty_type tp_loc) !pos_ref\n ;;\n\n let bin_reader_t =\n { Bin_prot.Type_class.read = bin_read_t; vtag_read = __bin_read_t__ }\n ;;\n\n let bin_t =\n { Bin_prot.Type_class.writer = bin_writer_t\n ; reader = bin_reader_t\n ; shape = bin_shape_t\n }\n ;;\n\n let sexp_of_t = unreachable_code\n let t_of_sexp sexp = Sexplib.Conv_error.empty_type tp_loc sexp\n end\nend\n\ninclude Stable.V1\ninclude Base.Nothing\ninclude Identifiable.Extend (Base.Nothing) (Stable.V1)\n","open! Import\n\ntype t = Base.Ordering.t =\n | Less\n | Equal\n | Greater\n[@@deriving bin_io, compare, hash, sexp]\n\nmodule type Base_mask = module type of Base.Ordering with type t := t\n\ninclude (Base.Ordering : Base_mask)\n","open! Import\n\nmodule T = struct\n include Base.Ref\n\n include (\n struct\n type 'a t = 'a ref [@@deriving bin_io, typerep]\n end :\n sig\n type 'a t = 'a ref [@@deriving bin_io, typerep]\n end\n with type 'a t := 'a t)\nend\n\ninclude T\n\nmodule Permissioned = struct\n include T\n\n type ('a, -'perms) t = 'a T.t [@@deriving bin_io, sexp]\n\n let read_only = Fn.id\n let of_ref = Fn.id\n let to_ref = Fn.id\n let set = ( := )\n let get = ( ! )\nend\n","(* zkapp_command_logic.ml *)\n\nopen Core_kernel\nopen Mina_base\n\nmodule type Iffable = sig\n type bool\n\n type t\n\n val if_ : bool -> then_:t -> else_:t -> t\nend\n\nmodule type Bool_intf = sig\n type t\n\n include Iffable with type t := t and type bool := t\n\n val true_ : t\n\n val false_ : t\n\n val equal : t -> t -> t\n\n val not : t -> t\n\n val ( ||| ) : t -> t -> t\n\n val ( &&& ) : t -> t -> t\n\n module Assert : sig\n (* [pos] is file,line,col,endcol from __POS__ *)\n val is_true : pos:string * int * int * int -> t -> unit\n\n (* [pos] is file,line,col,endcol from __POS__ *)\n val any : pos:string * int * int * int -> t list -> unit\n end\n\n val display : t -> label:string -> string\n\n val all : t list -> t\n\n type failure_status\n\n type failure_status_tbl\n\n (* [pos] is file,line,col,endcol from __POS__ *)\n val assert_with_failure_status_tbl :\n pos:string * int * int * int -> t -> failure_status_tbl -> unit\nend\n\nmodule type Balance_intf = sig\n include Iffable\n\n type amount\n\n type signed_amount\n\n val sub_amount_flagged : t -> amount -> t * [ `Underflow of bool ]\n\n val add_signed_amount_flagged : t -> signed_amount -> t * [ `Overflow of bool ]\nend\n\nmodule type Receipt_chain_hash_intf = sig\n include Iffable\n\n type transaction_commitment\n\n type index\n\n module Elt : sig\n type t\n\n val of_transaction_commitment : transaction_commitment -> t\n end\n\n val cons_zkapp_command_commitment : index -> Elt.t -> t -> t\nend\n\nmodule type Amount_intf = sig\n include Iffable\n\n type unsigned = t\n\n module Signed : sig\n include Iffable with type bool := bool\n\n val equal : t -> t -> bool\n\n val is_neg : t -> bool\n\n val is_non_neg : t -> bool\n\n val negate : t -> t\n\n val add_flagged : t -> t -> t * [ `Overflow of bool ]\n\n val of_unsigned : unsigned -> t\n end\n\n val zero : t\n\n val equal : t -> t -> bool\n\n val add_flagged : t -> t -> t * [ `Overflow of bool ]\n\n val add_signed_flagged : t -> Signed.t -> t * [ `Overflow of bool ]\n\n val of_constant_fee : Currency.Fee.t -> t\nend\n\nmodule type Account_id_intf = sig\n include Iffable\n\n type public_key\n\n type token_id\n\n val invalid : t\n\n val equal : t -> t -> bool\n\n val create : public_key -> token_id -> t\n\n val derive_token_id : owner:t -> token_id\nend\n\nmodule type Global_slot_since_genesis_intf = sig\n include Iffable\n\n val zero : t\n\n val ( > ) : t -> t -> bool\n\n val equal : t -> t -> bool\nend\n\nmodule type Global_slot_span_intf = sig\n include Iffable\n\n val zero : t\n\n val ( > ) : t -> t -> bool\nend\n\nmodule type Verification_key_hash_intf = sig\n type t\n\n type bool\n\n val equal : t -> t -> bool\nend\n\nmodule type Timing_intf = sig\n include Iffable\n\n type global_slot_span\n\n val vesting_period : t -> global_slot_span\nend\n\nmodule type Token_id_intf = sig\n include Iffable\n\n val equal : t -> t -> bool\n\n val default : t\nend\n\nmodule type Actions_intf = sig\n type t\n\n type bool\n\n type field\n\n val is_empty : t -> bool\n\n val push_events : field -> t -> field\nend\n\nmodule type Protocol_state_precondition_intf = sig\n type t\nend\n\nmodule type Valid_while_precondition_intf = sig\n type t\nend\n\nmodule Local_state = struct\n open Core_kernel\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'stack_frame\n , 'call_stack\n , 'signed_amount\n , 'ledger\n , 'bool\n , 'comm\n , 'length\n , 'failure_status_tbl )\n t =\n ( 'stack_frame\n , 'call_stack\n , 'signed_amount\n , 'ledger\n , 'bool\n , 'comm\n , 'length\n , 'failure_status_tbl )\n Mina_wire_types.Mina_transaction_logic.Zkapp_command_logic\n .Local_state\n .V1\n .t =\n { stack_frame : 'stack_frame\n ; call_stack : 'call_stack\n ; transaction_commitment : 'comm\n ; full_transaction_commitment : 'comm\n ; excess : 'signed_amount\n ; supply_increase : 'signed_amount\n ; ledger : 'ledger\n ; success : 'bool\n ; account_update_index : 'length\n ; failure_status_tbl : 'failure_status_tbl\n ; will_succeed : 'bool\n }\n [@@deriving compare, equal, hash, sexp, yojson, fields, hlist]\n end\n end]\n\n let typ stack_frame call_stack excess supply_increase ledger bool comm length\n failure_status_tbl =\n Pickles.Impls.Step.Typ.of_hlistable\n [ stack_frame\n ; call_stack\n ; comm\n ; comm\n ; excess\n ; supply_increase\n ; ledger\n ; bool\n ; length\n ; failure_status_tbl\n ; bool\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n module Value = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( Mina_base.Stack_frame.Digest.Stable.V1.t\n , Mina_base.Call_stack_digest.Stable.V1.t\n , ( Currency.Amount.Stable.V1.t\n , Sgn.Stable.V1.t )\n Currency.Signed_poly.Stable.V1.t\n , Ledger_hash.Stable.V1.t\n , bool\n , Zkapp_command.Transaction_commitment.Stable.V1.t\n , Mina_numbers.Index.Stable.V1.t\n , Transaction_status.Failure.Collection.Stable.V1.t )\n Stable.V1.t\n [@@deriving equal, compare, hash, yojson, sexp]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Checked = struct\n open Pickles.Impls.Step\n\n type t =\n ( Stack_frame.Digest.Checked.t\n , Call_stack_digest.Checked.t\n , Currency.Amount.Signed.Checked.t\n , Ledger_hash.var\n , Boolean.var\n , Zkapp_command.Transaction_commitment.Checked.t\n , Mina_numbers.Index.Checked.t\n , unit )\n Stable.Latest.t\n end\nend\n\nmodule type Set_or_keep_intf = sig\n type _ t\n\n type bool\n\n val is_set : _ t -> bool\n\n val is_keep : _ t -> bool\n\n val set_or_keep : if_:(bool -> then_:'a -> else_:'a -> 'a) -> 'a t -> 'a -> 'a\nend\n\nmodule type Account_update_intf = sig\n type t\n\n type bool\n\n type call_forest\n\n type signed_amount\n\n type transaction_commitment\n\n type protocol_state_precondition\n\n type valid_while_precondition\n\n type public_key\n\n type token_id\n\n type account_id\n\n type account\n\n type nonce\n\n type verification_key_hash\n\n type _ or_ignore\n\n val balance_change : t -> signed_amount\n\n val protocol_state_precondition : t -> protocol_state_precondition\n\n val valid_while_precondition : t -> valid_while_precondition\n\n val public_key : t -> public_key\n\n val token_id : t -> token_id\n\n val account_id : t -> account_id\n\n val may_use_parents_own_token : t -> bool\n\n val may_use_token_inherited_from_parent : t -> bool\n\n val use_full_commitment : t -> bool\n\n val increment_nonce : t -> bool\n\n val implicit_account_creation_fee : t -> bool\n\n val check_authorization :\n will_succeed:bool\n -> commitment:transaction_commitment\n -> calls:call_forest\n -> t\n -> [ `Proof_verifies of bool ] * [ `Signature_verifies of bool ]\n\n val is_signed : t -> bool\n\n val is_proved : t -> bool\n\n val verification_key_hash : t -> verification_key_hash\n\n module Update : sig\n type _ set_or_keep\n\n type timing\n\n val timing : t -> timing set_or_keep\n\n type field\n\n val app_state : t -> field set_or_keep Zkapp_state.V.t\n\n type verification_key\n\n val verification_key : t -> verification_key set_or_keep\n\n type actions\n\n val actions : t -> actions\n\n type zkapp_uri\n\n val zkapp_uri : t -> zkapp_uri set_or_keep\n\n type token_symbol\n\n val token_symbol : t -> token_symbol set_or_keep\n\n val delegate : t -> public_key set_or_keep\n\n type state_hash\n\n val voting_for : t -> state_hash set_or_keep\n\n type permissions\n\n val permissions : t -> permissions set_or_keep\n end\n\n module Account_precondition : sig\n val nonce : t -> nonce Zkapp_precondition.Closed_interval.t or_ignore\n end\nend\n\nmodule type Opt_intf = sig\n type bool\n\n type 'a t\n\n val is_some : 'a t -> bool\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val or_default :\n if_:(bool -> then_:'a -> else_:'a -> 'a) -> 'a t -> default:'a -> 'a\n\n val or_exn : 'a t -> 'a\nend\n\nmodule type Stack_intf = sig\n include Iffable\n\n module Opt : Opt_intf with type bool := bool\n\n type elt\n\n val empty : unit -> t\n\n val is_empty : t -> bool\n\n val pop_exn : t -> elt * t\n\n val pop : t -> (elt * t) Opt.t\n\n val push : elt -> onto:t -> t\nend\n\nmodule type Call_forest_intf = sig\n include Iffable\n\n type account_update\n\n module Opt : Opt_intf with type bool := bool\n\n val empty : unit -> t\n\n val is_empty : t -> bool\n\n val pop_exn : t -> (account_update * t) * t\nend\n\nmodule type Stack_frame_intf = sig\n type caller\n\n type call_forest\n\n include Iffable\n\n val caller : t -> caller\n\n val caller_caller : t -> caller\n\n val calls : t -> call_forest\n\n val make : caller:caller -> caller_caller:caller -> calls:call_forest -> t\nend\n\nmodule type Call_stack_intf = sig\n type stack_frame\n\n include Stack_intf with type elt := stack_frame\nend\n\nmodule type Ledger_intf = sig\n include Iffable\n\n type public_key\n\n type token_id\n\n type account_update\n\n type account\n\n type inclusion_proof\n\n val empty : depth:int -> unit -> t\n\n val get_account : account_update -> t -> account * inclusion_proof\n\n val set_account : t -> account * inclusion_proof -> t\n\n val check_inclusion : t -> account * inclusion_proof -> unit\n\n val check_account :\n public_key -> token_id -> account * inclusion_proof -> [ `Is_new of bool ]\nend\n\nmodule type Controller_intf = sig\n include Iffable\n\n val check : proof_verifies:bool -> signature_verifies:bool -> t -> bool\nend\n\nmodule type Account_intf = sig\n type t\n\n type bool\n\n type public_key\n\n type account_id\n\n module Permissions : sig\n type controller\n\n val access : t -> controller\n\n val edit_state : t -> controller\n\n val send : t -> controller\n\n val receive : t -> controller\n\n val set_delegate : t -> controller\n\n val set_permissions : t -> controller\n\n val set_verification_key : t -> controller\n\n val set_zkapp_uri : t -> controller\n\n val edit_action_state : t -> controller\n\n val set_token_symbol : t -> controller\n\n val increment_nonce : t -> controller\n\n val set_voting_for : t -> controller\n\n val set_timing : t -> controller\n\n include Iffable with type bool := bool\n end\n\n type timing\n\n type token_id\n\n type receipt_chain_hash\n\n val timing : t -> timing\n\n val set_timing : t -> timing -> t\n\n val is_timed : t -> bool\n\n val set_token_id : t -> token_id -> t\n\n type balance\n\n val balance : t -> balance\n\n val set_balance : balance -> t -> t\n\n type global_slot\n\n val check_timing :\n txn_global_slot:global_slot\n -> t\n -> [ `Invalid_timing of bool | `Insufficient_balance of bool ] * timing\n\n val receipt_chain_hash : t -> receipt_chain_hash\n\n val set_receipt_chain_hash : t -> receipt_chain_hash -> t\n\n (** Fill the zkapp field of the account if it's currently [None] *)\n val make_zkapp : t -> t\n\n (** If the current account has no zkApp fields set, reset its zkapp field to\n [None].\n *)\n val unmake_zkapp : t -> t\n\n val proved_state : t -> bool\n\n val set_proved_state : bool -> t -> t\n\n type field\n\n val app_state : t -> field Zkapp_state.V.t\n\n val set_app_state : field Zkapp_state.V.t -> t -> t\n\n val register_verification_key : t -> unit\n\n type verification_key\n\n val verification_key : t -> verification_key\n\n val set_verification_key : verification_key -> t -> t\n\n type verification_key_hash\n\n val verification_key_hash : t -> verification_key_hash\n\n val last_action_slot : t -> global_slot\n\n val set_last_action_slot : global_slot -> t -> t\n\n val action_state : t -> field Pickles_types.Vector.Vector_5.t\n\n val set_action_state : field Pickles_types.Vector.Vector_5.t -> t -> t\n\n type zkapp_uri\n\n val zkapp_uri : t -> zkapp_uri\n\n val set_zkapp_uri : zkapp_uri -> t -> t\n\n type token_symbol\n\n val token_symbol : t -> token_symbol\n\n val set_token_symbol : token_symbol -> t -> t\n\n val public_key : t -> public_key\n\n val set_public_key : public_key -> t -> t\n\n val delegate : t -> public_key\n\n val set_delegate : public_key -> t -> t\n\n type nonce\n\n val nonce : t -> nonce\n\n val set_nonce : nonce -> t -> t\n\n type state_hash\n\n val voting_for : t -> state_hash\n\n val set_voting_for : state_hash -> t -> t\n\n val permissions : t -> Permissions.t\n\n val set_permissions : Permissions.t -> t -> t\nend\n\nmodule Eff = struct\n type (_, _) t =\n | Check_valid_while_precondition :\n 'valid_while_precondition * 'global_state\n -> ( 'bool\n , < bool : 'bool\n ; valid_while_precondition : 'valid_while_precondition\n ; global_state : 'global_state\n ; .. > )\n t\n | Check_account_precondition :\n (* the bool input is a new_account flag *)\n 'account_update\n * 'account\n * 'bool\n * 'local_state\n -> ( 'local_state\n , < bool : 'bool\n ; account_update : 'account_update\n ; account : 'account\n ; local_state : 'local_state\n ; .. > )\n t\n | Check_protocol_state_precondition :\n 'protocol_state_pred * 'global_state\n -> ( 'bool\n , < bool : 'bool\n ; global_state : 'global_state\n ; protocol_state_precondition : 'protocol_state_pred\n ; .. > )\n t\n | Init_account :\n { account_update : 'account_update; account : 'account }\n -> ( 'account\n , < account_update : 'account_update ; account : 'account ; .. > )\n t\nend\n\ntype 'e handler = { perform : 'r. ('r, 'e) Eff.t -> 'r }\n\nmodule type Inputs_intf = sig\n val with_label : label:string -> (unit -> 'a) -> 'a\n\n module Bool : Bool_intf\n\n module Field : Iffable with type bool := Bool.t\n\n module Amount : Amount_intf with type bool := Bool.t\n\n module Balance :\n Balance_intf\n with type bool := Bool.t\n and type amount := Amount.t\n and type signed_amount := Amount.Signed.t\n\n module Public_key : Iffable with type bool := Bool.t\n\n module Token_id : Token_id_intf with type bool := Bool.t\n\n module Account_id :\n Account_id_intf\n with type bool := Bool.t\n and type public_key := Public_key.t\n and type token_id := Token_id.t\n\n module Set_or_keep : Set_or_keep_intf with type bool := Bool.t\n\n module Protocol_state_precondition : Protocol_state_precondition_intf\n\n module Valid_while_precondition : Valid_while_precondition_intf\n\n module Controller : Controller_intf with type bool := Bool.t\n\n module Global_slot_since_genesis :\n Global_slot_since_genesis_intf with type bool := Bool.t\n\n module Global_slot_span : Global_slot_span_intf with type bool := Bool.t\n\n module Nonce : sig\n include Iffable with type bool := Bool.t\n\n val succ : t -> t\n end\n\n module State_hash : Iffable with type bool := Bool.t\n\n module Timing :\n Timing_intf\n with type bool := Bool.t\n and type global_slot_span := Global_slot_span.t\n\n module Zkapp_uri : Iffable with type bool := Bool.t\n\n module Token_symbol : Iffable with type bool := Bool.t\n\n module Opt : Opt_intf with type bool := Bool.t\n\n module rec Receipt_chain_hash :\n (Receipt_chain_hash_intf\n with type bool := Bool.t\n and type transaction_commitment := Transaction_commitment.t\n and type index := Index.t)\n\n and Verification_key : (Iffable with type bool := Bool.t)\n and Verification_key_hash :\n (Verification_key_hash_intf with type bool := Bool.t)\n\n and Account :\n (Account_intf\n with type Permissions.controller := Controller.t\n and type timing := Timing.t\n and type balance := Balance.t\n and type receipt_chain_hash := Receipt_chain_hash.t\n and type bool := Bool.t\n and type global_slot := Global_slot_since_genesis.t\n and type field := Field.t\n and type verification_key := Verification_key.t\n and type verification_key_hash := Verification_key_hash.t\n and type zkapp_uri := Zkapp_uri.t\n and type token_symbol := Token_symbol.t\n and type public_key := Public_key.t\n and type nonce := Nonce.t\n and type state_hash := State_hash.t\n and type token_id := Token_id.t\n and type account_id := Account_id.t)\n\n and Actions :\n (Actions_intf with type bool := Bool.t and type field := Field.t)\n\n and Account_update :\n (Account_update_intf\n with type signed_amount := Amount.Signed.t\n and type protocol_state_precondition := Protocol_state_precondition.t\n and type valid_while_precondition := Valid_while_precondition.t\n and type token_id := Token_id.t\n and type bool := Bool.t\n and type account := Account.t\n and type public_key := Public_key.t\n and type nonce := Nonce.t\n and type account_id := Account_id.t\n and type verification_key_hash := Verification_key_hash.t\n and type Update.timing := Timing.t\n and type 'a Update.set_or_keep := 'a Set_or_keep.t\n and type Update.field := Field.t\n and type Update.verification_key := Verification_key.t\n and type Update.actions := Actions.t\n and type Update.zkapp_uri := Zkapp_uri.t\n and type Update.token_symbol := Token_symbol.t\n and type Update.state_hash := State_hash.t\n and type Update.permissions := Account.Permissions.t)\n\n and Nonce_precondition : sig\n val is_constant :\n Nonce.t Zkapp_precondition.Closed_interval.t Account_update.or_ignore\n -> Bool.t\n end\n\n and Ledger :\n (Ledger_intf\n with type bool := Bool.t\n and type account := Account.t\n and type account_update := Account_update.t\n and type token_id := Token_id.t\n and type public_key := Public_key.t)\n\n and Call_forest :\n (Call_forest_intf\n with type t = Account_update.call_forest\n and type bool := Bool.t\n and type account_update := Account_update.t\n and module Opt := Opt)\n\n and Stack_frame :\n (Stack_frame_intf\n with type bool := Bool.t\n and type call_forest := Call_forest.t\n and type caller := Token_id.t)\n\n and Call_stack :\n (Call_stack_intf\n with type stack_frame := Stack_frame.t\n and type bool := Bool.t\n and module Opt := Opt)\n\n and Transaction_commitment : sig\n include\n Iffable\n with type bool := Bool.t\n and type t = Account_update.transaction_commitment\n\n val empty : t\n\n val commitment : account_updates:Call_forest.t -> t\n\n val full_commitment :\n account_update:Account_update.t -> memo_hash:Field.t -> commitment:t -> t\n end\n\n and Index : sig\n include Iffable with type bool := Bool.t\n\n val zero : t\n\n val succ : t -> t\n end\n\n module Local_state : sig\n type t =\n ( Stack_frame.t\n , Call_stack.t\n , Amount.Signed.t\n , Ledger.t\n , Bool.t\n , Transaction_commitment.t\n , Index.t\n , Bool.failure_status_tbl )\n Local_state.t\n\n val add_check : t -> Transaction_status.Failure.t -> Bool.t -> t\n\n val update_failure_status_tbl : t -> Bool.failure_status -> Bool.t -> t\n\n val add_new_failure_status_bucket : t -> t\n end\n\n module Global_state : sig\n type t\n\n val first_pass_ledger : t -> Ledger.t\n\n val set_first_pass_ledger : should_update:Bool.t -> t -> Ledger.t -> t\n\n val second_pass_ledger : t -> Ledger.t\n\n val set_second_pass_ledger : should_update:Bool.t -> t -> Ledger.t -> t\n\n val fee_excess : t -> Amount.Signed.t\n\n val set_fee_excess : t -> Amount.Signed.t -> t\n\n val supply_increase : t -> Amount.Signed.t\n\n val set_supply_increase : t -> Amount.Signed.t -> t\n\n val block_global_slot : t -> Global_slot_since_genesis.t\n end\nend\n\nmodule Start_data = struct\n open Core_kernel\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('account_updates, 'field, 'bool) t =\n { account_updates : 'account_updates\n ; memo_hash : 'field\n ; will_succeed : 'bool\n }\n [@@deriving sexp, yojson]\n end\n end]\nend\n\nmodule Make (Inputs : Inputs_intf) = struct\n open Inputs\n\n let default_caller = Token_id.default\n\n let stack_frame_default () =\n Stack_frame.make ~caller:default_caller ~caller_caller:default_caller\n ~calls:(Call_forest.empty ())\n\n let assert_ ~pos b = Bool.Assert.is_true ~pos b\n\n (* Pop from the call stack, returning dummy values if the stack is empty. *)\n let pop_call_stack (s : Call_stack.t) : Stack_frame.t * Call_stack.t =\n let res = Call_stack.pop s in\n (* Split out the option returned by Call_stack.pop into two options *)\n let next_frame, next_call_stack =\n (Opt.map ~f:fst res, Opt.map ~f:snd res)\n in\n (* Handle the None cases *)\n ( Opt.or_default ~if_:Stack_frame.if_ ~default:(stack_frame_default ())\n next_frame\n , Opt.or_default ~if_:Call_stack.if_ ~default:(Call_stack.empty ())\n next_call_stack )\n\n type get_next_account_update_result =\n { account_update : Account_update.t\n ; caller_id : Token_id.t\n ; account_update_forest : Call_forest.t\n ; new_call_stack : Call_stack.t\n ; new_frame : Stack_frame.t\n }\n\n let get_next_account_update (current_forest : Stack_frame.t)\n (* The stack for the most recent zkApp *)\n (call_stack : Call_stack.t) (* The partially-completed parent stacks *)\n : get_next_account_update_result =\n (* If the current stack is complete, 'return' to the previous\n partially-completed one.\n *)\n let current_forest, call_stack =\n let next_forest, next_call_stack =\n (* Invariant: call_stack contains only non-empty forests. *)\n pop_call_stack call_stack\n in\n (* TODO: I believe current should only be empty for the first account_update in\n a transaction. *)\n let current_is_empty =\n Call_forest.is_empty (Stack_frame.calls current_forest)\n in\n ( Stack_frame.if_ current_is_empty ~then_:next_forest ~else_:current_forest\n , Call_stack.if_ current_is_empty ~then_:next_call_stack ~else_:call_stack\n )\n in\n let (account_update, account_update_forest), remainder_of_current_forest =\n Call_forest.pop_exn (Stack_frame.calls current_forest)\n in\n let may_use_parents_own_token =\n Account_update.may_use_parents_own_token account_update\n in\n let may_use_token_inherited_from_parent =\n Account_update.may_use_token_inherited_from_parent account_update\n in\n let caller_id =\n Token_id.if_ may_use_token_inherited_from_parent\n ~then_:(Stack_frame.caller_caller current_forest)\n ~else_:\n (Token_id.if_ may_use_parents_own_token\n ~then_:(Stack_frame.caller current_forest)\n ~else_:Token_id.default )\n in\n (* Cases:\n - [account_update_forest] is empty, [remainder_of_current_forest] is empty.\n Pop from the call stack to get another forest, which is guaranteed to be non-empty.\n The result of popping becomes the \"current forest\".\n - [account_update_forest] is empty, [remainder_of_current_forest] is non-empty.\n Push nothing to the stack. [remainder_of_current_forest] becomes new \"current forest\"\n - [account_update_forest] is non-empty, [remainder_of_current_forest] is empty.\n Push nothing to the stack. [account_update_forest] becomes new \"current forest\"\n - [account_update_forest] is non-empty, [remainder_of_current_forest] is non-empty:\n Push [remainder_of_current_forest] to the stack. [account_update_forest] becomes new \"current forest\".\n *)\n let account_update_forest_empty =\n Call_forest.is_empty account_update_forest\n in\n let remainder_of_current_forest_empty =\n Call_forest.is_empty remainder_of_current_forest\n in\n let newly_popped_frame, popped_call_stack = pop_call_stack call_stack in\n let remainder_of_current_forest_frame : Stack_frame.t =\n Stack_frame.make\n ~caller:(Stack_frame.caller current_forest)\n ~caller_caller:(Stack_frame.caller_caller current_forest)\n ~calls:remainder_of_current_forest\n in\n let new_call_stack =\n Call_stack.if_ account_update_forest_empty\n ~then_:\n (Call_stack.if_ remainder_of_current_forest_empty\n ~then_:\n (* Don't actually need the or_default used in this case. *)\n popped_call_stack ~else_:call_stack )\n ~else_:\n (Call_stack.if_ remainder_of_current_forest_empty ~then_:call_stack\n ~else_:\n (Call_stack.push remainder_of_current_forest_frame\n ~onto:call_stack ) )\n in\n let new_frame =\n Stack_frame.if_ account_update_forest_empty\n ~then_:\n (Stack_frame.if_ remainder_of_current_forest_empty\n ~then_:newly_popped_frame ~else_:remainder_of_current_forest_frame )\n ~else_:\n (let caller =\n Account_id.derive_token_id\n ~owner:(Account_update.account_id account_update)\n and caller_caller = caller_id in\n Stack_frame.make ~calls:account_update_forest ~caller ~caller_caller\n )\n in\n { account_update\n ; caller_id\n ; account_update_forest\n ; new_frame\n ; new_call_stack\n }\n\n let update_action_state (action_state : _ Pickles_types.Vector.t) actions\n ~txn_global_slot ~last_action_slot =\n (* Push events to s1. *)\n let [ s1'; s2'; s3'; s4'; s5' ] = action_state in\n let is_empty = Actions.is_empty actions in\n let s1_updated = Actions.push_events s1' actions in\n let s1 = Field.if_ is_empty ~then_:s1' ~else_:s1_updated in\n (* Shift along if not empty and last update wasn't this slot *)\n let is_this_slot =\n Global_slot_since_genesis.equal txn_global_slot last_action_slot\n in\n let is_empty_or_this_slot = Bool.(is_empty ||| is_this_slot) in\n let s5 = Field.if_ is_empty_or_this_slot ~then_:s5' ~else_:s4' in\n let s4 = Field.if_ is_empty_or_this_slot ~then_:s4' ~else_:s3' in\n let s3 = Field.if_ is_empty_or_this_slot ~then_:s3' ~else_:s2' in\n let s2 = Field.if_ is_empty_or_this_slot ~then_:s2' ~else_:s1' in\n let last_action_slot =\n Global_slot_since_genesis.if_ is_empty ~then_:last_action_slot\n ~else_:txn_global_slot\n in\n (([ s1; s2; s3; s4; s5 ] : _ Pickles_types.Vector.t), last_action_slot)\n\n let apply ~(constraint_constants : Genesis_constants.Constraint_constants.t)\n ~(is_start : [ `Yes of _ Start_data.t | `No | `Compute of _ Start_data.t ])\n (h :\n (< global_state : Global_state.t\n ; transaction_commitment : Transaction_commitment.t\n ; full_transaction_commitment : Transaction_commitment.t\n ; amount : Amount.t\n ; bool : Bool.t\n ; failure : Bool.failure_status\n ; .. >\n as\n 'env )\n handler )\n ((global_state : Global_state.t), (local_state : Local_state.t)) =\n let open Inputs in\n let is_start' =\n let is_empty_call_forest =\n Call_forest.is_empty (Stack_frame.calls local_state.stack_frame)\n in\n ( match is_start with\n | `Compute _ ->\n ()\n | `Yes _ ->\n assert_ ~pos:__POS__ is_empty_call_forest\n | `No ->\n assert_ ~pos:__POS__ (Bool.not is_empty_call_forest) ) ;\n match is_start with\n | `Yes _ ->\n Bool.true_\n | `No ->\n Bool.false_\n | `Compute _ ->\n is_empty_call_forest\n in\n let will_succeed =\n match is_start with\n | `Compute start_data ->\n Bool.if_ is_start' ~then_:start_data.will_succeed\n ~else_:local_state.will_succeed\n | `Yes start_data ->\n start_data.will_succeed\n | `No ->\n local_state.will_succeed\n in\n let local_state =\n { local_state with\n ledger =\n Inputs.Ledger.if_ is_start'\n ~then_:(Inputs.Global_state.first_pass_ledger global_state)\n ~else_:local_state.ledger\n ; will_succeed\n }\n in\n let ( (account_update, remaining, call_stack)\n , account_update_forest\n , local_state\n , (a, inclusion_proof) ) =\n let to_pop, call_stack =\n match is_start with\n | `Compute start_data ->\n ( Stack_frame.if_ is_start'\n ~then_:\n (Stack_frame.make ~calls:start_data.account_updates\n ~caller:default_caller ~caller_caller:default_caller )\n ~else_:local_state.stack_frame\n , Call_stack.if_ is_start' ~then_:(Call_stack.empty ())\n ~else_:local_state.call_stack )\n | `Yes start_data ->\n ( Stack_frame.make ~calls:start_data.account_updates\n ~caller:default_caller ~caller_caller:default_caller\n , Call_stack.empty () )\n | `No ->\n (local_state.stack_frame, local_state.call_stack)\n in\n let { account_update\n ; caller_id\n ; account_update_forest\n ; new_frame = remaining\n ; new_call_stack = call_stack\n } =\n with_label ~label:\"get next account update\" (fun () ->\n (* TODO: Make the stack frame hashed inside of the local state *)\n get_next_account_update to_pop call_stack )\n in\n let local_state =\n with_label ~label:\"token owner not caller\" (fun () ->\n let default_token_or_token_owner_was_caller =\n (* Check that the token owner was consulted if using a non-default\n token *)\n let account_update_token_id =\n Account_update.token_id account_update\n in\n Bool.( ||| )\n (Token_id.equal account_update_token_id Token_id.default)\n (Token_id.equal account_update_token_id caller_id)\n in\n Local_state.add_check local_state Token_owner_not_caller\n default_token_or_token_owner_was_caller )\n in\n let ((a, inclusion_proof) as acct) =\n with_label ~label:\"get account\" (fun () ->\n Inputs.Ledger.get_account account_update local_state.ledger )\n in\n Inputs.Ledger.check_inclusion local_state.ledger (a, inclusion_proof) ;\n let transaction_commitment, full_transaction_commitment =\n match is_start with\n | `No ->\n ( local_state.transaction_commitment\n , local_state.full_transaction_commitment )\n | `Yes start_data | `Compute start_data ->\n let tx_commitment_on_start =\n Transaction_commitment.commitment\n ~account_updates:(Stack_frame.calls remaining)\n in\n let full_tx_commitment_on_start =\n Transaction_commitment.full_commitment ~account_update\n ~memo_hash:start_data.memo_hash\n ~commitment:tx_commitment_on_start\n in\n let tx_commitment =\n Transaction_commitment.if_ is_start' ~then_:tx_commitment_on_start\n ~else_:local_state.transaction_commitment\n in\n let full_tx_commitment =\n Transaction_commitment.if_ is_start'\n ~then_:full_tx_commitment_on_start\n ~else_:local_state.full_transaction_commitment\n in\n (tx_commitment, full_tx_commitment)\n in\n let local_state =\n { local_state with transaction_commitment; full_transaction_commitment }\n in\n ( (account_update, remaining, call_stack)\n , account_update_forest\n , local_state\n , acct )\n in\n let local_state =\n { local_state with stack_frame = remaining; call_stack }\n in\n let local_state = Local_state.add_new_failure_status_bucket local_state in\n (* Register verification key, in case it needs to be 'side-loaded' to\n verify a zkapp proof.\n *)\n Account.register_verification_key a ;\n let (`Is_new account_is_new) =\n Inputs.Ledger.check_account\n (Account_update.public_key account_update)\n (Account_update.token_id account_update)\n (a, inclusion_proof)\n in\n (* delegate to public key if new account using default token *)\n let a =\n let self_delegate =\n let account_update_token_id = Account_update.token_id account_update in\n Bool.(\n account_is_new\n &&& Token_id.equal account_update_token_id Token_id.default)\n in\n (* in-SNARK, a new account has the empty public key here\n in that case, use the public key from the account update, not the account\n *)\n Account.set_delegate\n (Public_key.if_ self_delegate\n ~then_:(Account_update.public_key account_update)\n ~else_:(Account.delegate a) )\n a\n in\n let matching_verification_key_hashes =\n Inputs.Bool.(\n (not (Account_update.is_proved account_update))\n ||| Verification_key_hash.equal\n (Account.verification_key_hash a)\n (Account_update.verification_key_hash account_update))\n in\n let local_state =\n Local_state.add_check local_state Unexpected_verification_key_hash\n matching_verification_key_hashes\n in\n let local_state =\n h.perform\n (Check_account_precondition\n (account_update, a, account_is_new, local_state) )\n in\n let protocol_state_predicate_satisfied =\n h.perform\n (Check_protocol_state_precondition\n ( Account_update.protocol_state_precondition account_update\n , global_state ) )\n in\n let local_state =\n Local_state.add_check local_state Protocol_state_precondition_unsatisfied\n protocol_state_predicate_satisfied\n in\n let local_state =\n let valid_while_satisfied =\n h.perform\n (Check_valid_while_precondition\n ( Account_update.valid_while_precondition account_update\n , global_state ) )\n in\n Local_state.add_check local_state Valid_while_precondition_unsatisfied\n valid_while_satisfied\n in\n let `Proof_verifies proof_verifies, `Signature_verifies signature_verifies =\n let commitment =\n Inputs.Transaction_commitment.if_\n (Inputs.Account_update.use_full_commitment account_update)\n ~then_:local_state.full_transaction_commitment\n ~else_:local_state.transaction_commitment\n in\n Inputs.Account_update.check_authorization\n ~will_succeed:local_state.will_succeed ~commitment\n ~calls:account_update_forest account_update\n in\n assert_ ~pos:__POS__\n (Bool.equal proof_verifies (Account_update.is_proved account_update)) ;\n assert_ ~pos:__POS__\n (Bool.equal signature_verifies (Account_update.is_signed account_update)) ;\n (* The fee-payer must increment their nonce. *)\n let local_state =\n Local_state.add_check local_state Fee_payer_nonce_must_increase\n Inputs.Bool.(\n Inputs.Account_update.increment_nonce account_update ||| not is_start')\n in\n let local_state =\n Local_state.add_check local_state Fee_payer_must_be_signed\n Inputs.Bool.(signature_verifies ||| not is_start')\n in\n let local_state =\n let precondition_has_constant_nonce =\n Inputs.Account_update.Account_precondition.nonce account_update\n |> Inputs.Nonce_precondition.is_constant\n in\n let increments_nonce_and_constrains_its_old_value =\n Inputs.Bool.(\n Inputs.Account_update.increment_nonce account_update\n &&& precondition_has_constant_nonce)\n in\n let depends_on_the_fee_payers_nonce_and_isnt_the_fee_payer =\n Inputs.Bool.(\n Inputs.Account_update.use_full_commitment account_update\n &&& not is_start')\n in\n let does_not_use_a_signature = Inputs.Bool.not signature_verifies in\n Local_state.add_check local_state Zkapp_command_replay_check_failed\n Inputs.Bool.(\n increments_nonce_and_constrains_its_old_value\n ||| depends_on_the_fee_payers_nonce_and_isnt_the_fee_payer\n ||| does_not_use_a_signature)\n in\n let a = Account.set_token_id a (Account_update.token_id account_update) in\n let account_update_token = Account_update.token_id account_update in\n let account_update_token_is_default =\n Token_id.(equal default) account_update_token\n in\n let account_is_untimed = Bool.not (Account.is_timed a) in\n (* Set account timing. *)\n let a, local_state =\n let timing = Account_update.Update.timing account_update in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_timing a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_timing\n Bool.(\n Set_or_keep.is_keep timing\n ||| (account_is_untimed &&& has_permission))\n in\n let timing =\n Set_or_keep.set_or_keep ~if_:Timing.if_ timing (Account.timing a)\n in\n let vesting_period = Timing.vesting_period timing in\n (* Assert that timing is valid, otherwise we may have a division by 0. *)\n assert_ ~pos:__POS__ Global_slot_span.(vesting_period > zero) ;\n let a = Account.set_timing a timing in\n (a, local_state)\n in\n let account_creation_fee =\n Amount.of_constant_fee constraint_constants.account_creation_fee\n in\n let implicit_account_creation_fee =\n Account_update.implicit_account_creation_fee account_update\n in\n (* Check the token for implicit account creation fee payment. *)\n let local_state =\n Local_state.add_check local_state Cannot_pay_creation_fee_in_token\n Bool.(\n (not implicit_account_creation_fee)\n ||| account_update_token_is_default)\n in\n (* Compute the change to the account balance. *)\n let local_state, actual_balance_change =\n let balance_change = Account_update.balance_change account_update in\n let neg_creation_fee =\n let open Amount.Signed in\n negate (of_unsigned account_creation_fee)\n in\n let balance_change_for_creation, `Overflow creation_overflow =\n let open Amount.Signed in\n add_flagged balance_change neg_creation_fee\n in\n let pay_creation_fee =\n Bool.(account_is_new &&& implicit_account_creation_fee)\n in\n let creation_overflow = Bool.(pay_creation_fee &&& creation_overflow) in\n let balance_change =\n Amount.Signed.if_ pay_creation_fee ~then_:balance_change_for_creation\n ~else_:balance_change\n in\n let local_state =\n Local_state.add_check local_state Amount_insufficient_to_create_account\n Bool.(\n not\n ( pay_creation_fee\n &&& (creation_overflow ||| Amount.Signed.is_neg balance_change) ))\n in\n (local_state, balance_change)\n in\n (* Apply balance change. *)\n let a, local_state =\n let pay_creation_fee_from_excess =\n Bool.(account_is_new &&& not implicit_account_creation_fee)\n in\n let balance, `Overflow failed1 =\n Balance.add_signed_amount_flagged (Account.balance a)\n actual_balance_change\n in\n (* TODO: Should this report 'insufficient balance'? *)\n let local_state =\n Local_state.add_check local_state Overflow (Bool.not failed1)\n in\n let account_creation_fee =\n Amount.of_constant_fee constraint_constants.account_creation_fee\n in\n let local_state =\n (* Conditionally subtract account creation fee from fee excess *)\n let excess_minus_creation_fee, `Overflow excess_update_failed =\n Amount.Signed.add_flagged local_state.excess\n Amount.Signed.(negate (of_unsigned account_creation_fee))\n in\n let local_state =\n Local_state.add_check local_state Local_excess_overflow\n Bool.(not (pay_creation_fee_from_excess &&& excess_update_failed))\n in\n { local_state with\n excess =\n Amount.Signed.if_ pay_creation_fee_from_excess\n ~then_:excess_minus_creation_fee ~else_:local_state.excess\n }\n in\n let local_state =\n (* Conditionally subtract account creation fee from supply increase *)\n let ( supply_increase_minus_creation_fee\n , `Overflow supply_increase_update_failed ) =\n Amount.Signed.add_flagged local_state.supply_increase\n Amount.Signed.(negate (of_unsigned account_creation_fee))\n in\n let local_state =\n Local_state.add_check local_state Local_supply_increase_overflow\n Bool.(not (account_is_new &&& supply_increase_update_failed))\n in\n { local_state with\n supply_increase =\n Amount.Signed.if_ account_is_new\n ~then_:supply_increase_minus_creation_fee\n ~else_:local_state.supply_increase\n }\n in\n let is_receiver = Amount.Signed.is_non_neg actual_balance_change in\n let local_state =\n let controller =\n Controller.if_ is_receiver\n ~then_:(Account.Permissions.receive a)\n ~else_:(Account.Permissions.send a)\n in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies controller\n in\n Local_state.add_check local_state Update_not_permitted_balance\n Bool.(\n has_permission\n ||| Amount.Signed.(\n equal (of_unsigned Amount.zero) actual_balance_change))\n in\n let a = Account.set_balance balance a in\n (a, local_state)\n in\n let txn_global_slot = Global_state.block_global_slot global_state in\n (* Check timing with current balance *)\n let a, local_state =\n let `Invalid_timing invalid_timing, timing =\n match Account.check_timing ~txn_global_slot a with\n | `Insufficient_balance _, _ ->\n failwith \"Did not propose a balance change at this timing check!\"\n | `Invalid_timing invalid_timing, timing ->\n (* NB: Have to destructure to remove the possibility of\n [`Insufficient_balance _] in the type.\n *)\n (`Invalid_timing invalid_timing, timing)\n in\n let local_state =\n Local_state.add_check local_state Source_minimum_balance_violation\n (Bool.not invalid_timing)\n in\n let a = Account.set_timing a timing in\n (a, local_state)\n in\n (* Transform into a zkApp account.\n This must be done before updating zkApp fields!\n *)\n let a = Account.make_zkapp a in\n (* Check that the account can be accessed with the given authorization. *)\n let local_state =\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.access a)\n in\n Local_state.add_check local_state Update_not_permitted_access\n has_permission\n in\n (* Update app state. *)\n let a, local_state =\n let app_state = Account_update.Update.app_state account_update in\n let keeping_app_state =\n Bool.all\n (List.map ~f:Set_or_keep.is_keep\n (Pickles_types.Vector.to_list app_state) )\n in\n let changing_entire_app_state =\n Bool.all\n (List.map ~f:Set_or_keep.is_set\n (Pickles_types.Vector.to_list app_state) )\n in\n let proved_state =\n (* The [proved_state] tracks whether the app state has been entirely\n determined by proofs ([true] if so), to allow zkApp authors to be\n confident that their initialization logic has been run, rather than\n some malicious deployer instantiating the zkApp in an account with\n some fake non-initial state.\n The logic here is:\n * if the state is unchanged, keep the previous value;\n * if the state has been entirely replaced, and the authentication\n was a proof, the state has been 'proved' and [proved_state] is set\n to [true];\n * if the state has been partially updated by a proof, the\n [proved_state] is unchanged;\n * if the state has been changed by some authentication other than a\n proof, the state is considered to have been tampered with, and\n [proved_state] is reset to [false].\n *)\n Bool.if_ keeping_app_state ~then_:(Account.proved_state a)\n ~else_:\n (Bool.if_ proof_verifies\n ~then_:\n (Bool.if_ changing_entire_app_state ~then_:Bool.true_\n ~else_:(Account.proved_state a) )\n ~else_:Bool.false_ )\n in\n let a = Account.set_proved_state proved_state a in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.edit_state a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_app_state\n Bool.(keeping_app_state ||| has_permission)\n in\n let app_state =\n Pickles_types.Vector.map2 app_state (Account.app_state a)\n ~f:(Set_or_keep.set_or_keep ~if_:Field.if_)\n in\n let a = Account.set_app_state app_state a in\n (a, local_state)\n in\n (* Set verification key. *)\n let a, local_state =\n let verification_key =\n Account_update.Update.verification_key account_update\n in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_verification_key a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_verification_key\n Bool.(Set_or_keep.is_keep verification_key ||| has_permission)\n in\n let verification_key =\n Set_or_keep.set_or_keep ~if_:Verification_key.if_ verification_key\n (Account.verification_key a)\n in\n let a = Account.set_verification_key verification_key a in\n (a, local_state)\n in\n (* Update action state. *)\n let a, local_state =\n let actions = Account_update.Update.actions account_update in\n let last_action_slot = Account.last_action_slot a in\n let action_state, last_action_slot =\n update_action_state (Account.action_state a) actions ~txn_global_slot\n ~last_action_slot\n in\n let is_empty =\n (* also computed in update_action_state, but messy to return it *)\n Actions.is_empty actions\n in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.edit_action_state a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_action_state\n Bool.(is_empty ||| has_permission)\n in\n let a =\n a\n |> Account.set_action_state action_state\n |> Account.set_last_action_slot last_action_slot\n in\n (a, local_state)\n in\n (* Update zkApp URI. *)\n let a, local_state =\n let zkapp_uri = Account_update.Update.zkapp_uri account_update in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_zkapp_uri a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_zkapp_uri\n Bool.(Set_or_keep.is_keep zkapp_uri ||| has_permission)\n in\n let zkapp_uri =\n Set_or_keep.set_or_keep ~if_:Zkapp_uri.if_ zkapp_uri\n (Account.zkapp_uri a)\n in\n let a = Account.set_zkapp_uri zkapp_uri a in\n (a, local_state)\n in\n (* At this point, all possible changes have been made to the zkapp\n part of an account. Reset zkApp state to [None] if that part\n is unmodified.\n *)\n let a = Account.unmake_zkapp a in\n (* Update token symbol. *)\n let a, local_state =\n let token_symbol = Account_update.Update.token_symbol account_update in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_token_symbol a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_token_symbol\n Bool.(Set_or_keep.is_keep token_symbol ||| has_permission)\n in\n let token_symbol =\n Set_or_keep.set_or_keep ~if_:Token_symbol.if_ token_symbol\n (Account.token_symbol a)\n in\n let a = Account.set_token_symbol token_symbol a in\n (a, local_state)\n in\n (* Update delegate. *)\n let a, local_state =\n let delegate = Account_update.Update.delegate account_update in\n (* for new accounts using the default token, we've already\n set the delegate to the public key\n *)\n let base_delegate = Account.delegate a in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_delegate a)\n in\n let local_state =\n (* Note: only accounts for the default token can delegate. *)\n Local_state.add_check local_state Update_not_permitted_delegate\n Bool.(\n Set_or_keep.is_keep delegate\n ||| (has_permission &&& account_update_token_is_default))\n in\n let delegate =\n Set_or_keep.set_or_keep ~if_:Public_key.if_ delegate base_delegate\n in\n let a = Account.set_delegate delegate a in\n (a, local_state)\n in\n (* Update nonce. *)\n let a, local_state =\n let nonce = Account.nonce a in\n let increment_nonce = Account_update.increment_nonce account_update in\n let nonce =\n Nonce.if_ increment_nonce ~then_:(Nonce.succ nonce) ~else_:nonce\n in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.increment_nonce a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_nonce\n Bool.((not increment_nonce) ||| has_permission)\n in\n let a = Account.set_nonce nonce a in\n (a, local_state)\n in\n (* Update voting-for. *)\n let a, local_state =\n let voting_for = Account_update.Update.voting_for account_update in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_voting_for a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_voting_for\n Bool.(Set_or_keep.is_keep voting_for ||| has_permission)\n in\n let voting_for =\n Set_or_keep.set_or_keep ~if_:State_hash.if_ voting_for\n (Account.voting_for a)\n in\n let a = Account.set_voting_for voting_for a in\n (a, local_state)\n in\n (* Update receipt chain hash *)\n let a =\n let new_hash =\n let old_hash = Account.receipt_chain_hash a in\n Receipt_chain_hash.if_\n (let open Inputs.Bool in\n signature_verifies ||| proof_verifies)\n ~then_:\n (let elt =\n local_state.full_transaction_commitment\n |> Receipt_chain_hash.Elt.of_transaction_commitment\n in\n Receipt_chain_hash.cons_zkapp_command_commitment\n local_state.account_update_index elt old_hash )\n ~else_:old_hash\n in\n Account.set_receipt_chain_hash a new_hash\n in\n (* Finally, update permissions.\n This should be the last update applied, to ensure that any earlier\n updates use the account's existing permissions, and not permissions that\n are specified by the account_update!\n *)\n let a, local_state =\n let permissions = Account_update.Update.permissions account_update in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_permissions a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_permissions\n Bool.(Set_or_keep.is_keep permissions ||| has_permission)\n in\n let permissions =\n Set_or_keep.set_or_keep ~if_:Account.Permissions.if_ permissions\n (Account.permissions a)\n in\n let a = Account.set_permissions permissions a in\n (a, local_state)\n in\n (* Initialize account's pk, in case it is new. *)\n let a = h.perform (Init_account { account_update; account = a }) in\n (* DO NOT ADD ANY UPDATES HERE. They must be earlier in the code.\n See comment above.\n *)\n let local_delta =\n (* NOTE: It is *not* correct to use the actual change in balance here.\n Indeed, if the account creation fee is paid, using that amount would\n be equivalent to paying it out to the block producer.\n In the case of a failure that prevents any updates from being applied,\n every other account_update in this transaction will also fail, and the\n excess will never be promoted to the global excess, so this amount is\n irrelevant.\n *)\n Amount.Signed.negate (Account_update.balance_change account_update)\n in\n let new_local_fee_excess, `Overflow overflowed =\n (* We only allow the default token for fees. *)\n Bool.(\n assert_ ~pos:__POS__\n ( (not is_start')\n ||| ( account_update_token_is_default\n &&& Amount.Signed.is_non_neg local_delta ) )) ;\n let new_local_fee_excess, `Overflow overflow =\n Amount.Signed.add_flagged local_state.excess local_delta\n in\n ( Amount.Signed.if_ account_update_token_is_default\n ~then_:new_local_fee_excess ~else_:local_state.excess\n , (* No overflow if we aren't using the result of the addition (which we don't in the case that account_update token is not default). *)\n `Overflow (Bool.( &&& ) account_update_token_is_default overflow) )\n in\n let local_state = { local_state with excess = new_local_fee_excess } in\n let local_state =\n Local_state.add_check local_state Local_excess_overflow\n (Bool.not overflowed)\n in\n (* If a's token ID differs from that in the local state, then\n the local state excess gets moved into the execution state's fee excess.\n\n If there are more zkapp_command to execute after this one, then the local delta gets\n accumulated in the local state.\n\n If there are no more zkapp_command to execute, then we do the same as if we switch tokens.\n The local state excess (plus the local delta) gets moved to the fee excess if it is default token.\n *)\n let new_ledger =\n Inputs.Ledger.set_account local_state.ledger (a, inclusion_proof)\n in\n let is_last_account_update =\n Call_forest.is_empty (Stack_frame.calls remaining)\n in\n let local_state =\n { local_state with\n ledger = new_ledger\n ; transaction_commitment =\n Transaction_commitment.if_ is_last_account_update\n ~then_:Transaction_commitment.empty\n ~else_:local_state.transaction_commitment\n ; full_transaction_commitment =\n Transaction_commitment.if_ is_last_account_update\n ~then_:Transaction_commitment.empty\n ~else_:local_state.full_transaction_commitment\n }\n in\n let valid_fee_excess =\n let delta_settled =\n Amount.Signed.equal local_state.excess Amount.(Signed.of_unsigned zero)\n in\n (* 1) ignore local excess if it is_start because it will be promoted to global\n excess and then set to zero later in the code\n 2) ignore everything but last account update since the excess wouldn't have\n been settled\n 3) Excess should be settled after the last account update has been applied.\n *)\n Bool.(is_start' ||| not is_last_account_update ||| delta_settled)\n in\n let local_state =\n Local_state.add_check local_state Invalid_fee_excess valid_fee_excess\n in\n let is_start_or_last = Bool.(is_start' ||| is_last_account_update) in\n let update_global_state_fee_excess =\n Bool.(is_start_or_last &&& local_state.success)\n in\n let global_state, global_excess_update_failed =\n let amt = Global_state.fee_excess global_state in\n let res, `Overflow overflow =\n Amount.Signed.add_flagged amt local_state.excess\n in\n let global_excess_update_failed =\n Bool.(update_global_state_fee_excess &&& overflow)\n in\n let new_amt =\n Amount.Signed.if_ update_global_state_fee_excess ~then_:res ~else_:amt\n in\n ( Global_state.set_fee_excess global_state new_amt\n , global_excess_update_failed )\n in\n let local_state =\n { local_state with\n excess =\n Amount.Signed.if_ is_start_or_last\n ~then_:Amount.(Signed.of_unsigned zero)\n ~else_:local_state.excess\n }\n in\n let local_state =\n Local_state.add_check local_state Global_excess_overflow\n Bool.(not global_excess_update_failed)\n in\n (* add local supply increase in global state *)\n let new_global_supply_increase, global_supply_increase_update_failed =\n let res, `Overflow overflow =\n Amount.Signed.add_flagged\n (Global_state.supply_increase global_state)\n local_state.supply_increase\n in\n (res, overflow)\n in\n let local_state =\n Local_state.add_check local_state Global_supply_increase_overflow\n Bool.(not global_supply_increase_update_failed)\n in\n (* The first account_update must succeed. *)\n Bool.(\n assert_with_failure_status_tbl ~pos:__POS__\n ((not is_start') ||| local_state.success)\n local_state.failure_status_tbl) ;\n (* If we are the fee payer (is_start' = true), push the first pass ledger\n and set the local ledger to be the second pass ledger in preparation for\n the children.\n *)\n let local_state, global_state =\n let is_fee_payer = is_start' in\n let global_state =\n Global_state.set_first_pass_ledger ~should_update:is_fee_payer\n global_state local_state.ledger\n in\n let local_state =\n { local_state with\n ledger =\n Inputs.Ledger.if_ is_fee_payer\n ~then_:(Global_state.second_pass_ledger global_state)\n ~else_:local_state.ledger\n }\n in\n (local_state, global_state)\n in\n (* If this is the last account update, and [will_succeed] is false, then\n [success] must also be false.\n *)\n Bool.(\n Assert.any ~pos:__POS__\n [ not is_last_account_update\n ; local_state.will_succeed\n ; not local_state.success\n ]) ;\n (* If this is the last party and there were no failures, update the second\n pass ledger and the supply increase.\n *)\n let global_state =\n let is_successful_last_party =\n Bool.(is_last_account_update &&& local_state.success)\n in\n let global_state =\n Global_state.set_supply_increase global_state\n (Amount.Signed.if_ is_successful_last_party\n ~then_:new_global_supply_increase\n ~else_:(Global_state.supply_increase global_state) )\n in\n Global_state.set_second_pass_ledger\n ~should_update:is_successful_last_party global_state local_state.ledger\n in\n let local_state =\n (* Make sure to reset the local_state at the end of a transaction.\n The following fields are already reset\n - zkapp_command\n - transaction_commitment\n - full_transaction_commitment\n - excess\n so we need to reset\n - token_id = Token_id.default\n - ledger = Frozen_ledger_hash.empty_hash\n - success = true\n - account_update_index = Index.zero\n - supply_increase = Amount.Signed.zero\n *)\n { local_state with\n ledger =\n Inputs.Ledger.if_ is_last_account_update\n ~then_:(Inputs.Ledger.empty ~depth:0 ())\n ~else_:local_state.ledger\n ; success =\n Bool.if_ is_last_account_update ~then_:Bool.true_\n ~else_:local_state.success\n ; account_update_index =\n Inputs.Index.if_ is_last_account_update ~then_:Inputs.Index.zero\n ~else_:(Inputs.Index.succ local_state.account_update_index)\n ; supply_increase =\n Amount.Signed.if_ is_last_account_update\n ~then_:Amount.(Signed.of_unsigned zero)\n ~else_:local_state.supply_increase\n ; will_succeed =\n Bool.if_ is_last_account_update ~then_:Bool.true_\n ~else_:local_state.will_succeed\n }\n in\n (global_state, local_state)\n\n let step h state = apply ~is_start:`No h state\n\n let start start_data h state = apply ~is_start:(`Yes start_data) h state\nend\n","open! Import\nopen Std_internal\nmodule Repr = Int63\n\nmodule T : sig\n type t [@@deriving compare, hash, sexp_of]\n\n val to_string : t -> string\n val of_repr : Repr.t -> t\n val to_repr : t -> Repr.t\nend = struct\n type t = Repr.t [@@deriving compare, hash]\n\n let of_repr = Fn.id\n let to_repr = Fn.id\n\n let to_string n =\n let open Repr in\n let kib = of_int 1024 in\n let mib = kib * kib in\n let gib = kib * mib in\n let n_abs = abs n in\n if n_abs < kib\n then sprintf \"%dB\" (to_int_exn n)\n else if n_abs < mib\n then sprintf \"%gK\" (to_float n /. to_float kib)\n else if n_abs < gib\n then sprintf \"%gM\" (to_float n /. to_float mib)\n else sprintf \"%gG\" (to_float n /. to_float gib)\n ;;\n\n let sexp_of_t n = Sexp.Atom (to_string n)\nend\n\ninclude T\n\nlet bytes_int_exn t = Repr.to_int_exn (to_repr t)\n","open! Import\nopen Std_internal\nopen Bigarray\nmodule Binable = Binable0\n\nmodule Stable = struct\n module V1 = struct\n include Base_bigstring\n\n module Z : sig\n type t = (char, int8_unsigned_elt, c_layout) Array1.t [@@deriving bin_io]\n end = struct\n type t = bigstring [@@deriving bin_io]\n end\n\n include Z\n\n type t_frozen = t [@@deriving bin_io]\n end\nend\n\nmodule T = Stable.V1\ninclude T\nmodule Unstable = T\n\nlet create ?max_mem_waiting_gc size =\n let max_mem_waiting_gc_in_bytes =\n Option.map max_mem_waiting_gc ~f:Byte_units0.bytes_int_exn\n in\n create ?max_mem_waiting_gc_in_bytes size\n;;\n\nlet sub_shared ?(pos = 0) ?len (bstr : t) =\n let len = get_opt_len bstr ~pos len in\n Array1.sub bstr pos len\n;;\n\n(* Destruction *)\n\nexternal unsafe_destroy : t -> unit = \"bigstring_destroy_stub\"\n\nexternal unsafe_destroy_and_resize : t -> len:int -> t = \"bigstring_realloc\"\n\n(* Reading / writing bin-prot *)\n\nlet read_bin_prot_verbose_errors t ?(pos = 0) ?len reader =\n let len = get_opt_len t len ~pos in\n let limit = pos + len in\n check_args ~loc:\"read_bin_prot_verbose_errors\" t ~pos ~len;\n let invalid_data message a sexp_of_a =\n `Invalid_data (Error.create message a sexp_of_a)\n in\n let read bin_reader ~pos ~len =\n if len > limit - pos\n then `Not_enough_data\n else (\n let pos_ref = ref pos in\n match\n try `Ok (bin_reader t ~pos_ref) with\n | exn -> `Invalid_data (Error.of_exn exn)\n with\n | `Invalid_data _ as x -> x\n | `Ok result ->\n let expected_pos = pos + len in\n if !pos_ref = expected_pos\n then `Ok (result, expected_pos)\n else\n invalid_data\n \"pos_ref <> expected_pos\"\n (!pos_ref, expected_pos)\n [%sexp_of: int * int])\n in\n match\n read Bin_prot.Utils.bin_read_size_header ~pos ~len:Bin_prot.Utils.size_header_length\n with\n | (`Not_enough_data | `Invalid_data _) as x -> x\n | `Ok (element_length, pos) ->\n if element_length < 0\n then invalid_data \"negative element length %d\" element_length [%sexp_of: int]\n else read reader.Bin_prot.Type_class.read ~pos ~len:element_length\n;;\n\nlet read_bin_prot t ?pos ?len reader =\n match read_bin_prot_verbose_errors t ?pos ?len reader with\n | `Ok x -> Ok x\n | `Invalid_data e -> Error (Error.tag e ~tag:\"Invalid data\")\n | `Not_enough_data -> Or_error.error_string \"not enough data\"\n;;\n\nlet write_bin_prot t ?(pos = 0) writer v =\n let data_len = writer.Bin_prot.Type_class.size v in\n let total_len = data_len + Bin_prot.Utils.size_header_length in\n if pos < 0\n then\n failwiths ~here:[%here] \"Bigstring.write_bin_prot: negative pos\" pos [%sexp_of: int];\n if pos + total_len > length t\n then\n failwiths\n ~here:[%here]\n \"Bigstring.write_bin_prot: not enough room\"\n (`pos pos, `pos_after_writing (pos + total_len), `bigstring_length (length t))\n [%sexp_of:\n [ `pos of int ] * [ `pos_after_writing of int ] * [ `bigstring_length of int ]];\n let pos_after_size_header = Bin_prot.Utils.bin_write_size_header t ~pos data_len in\n let pos_after_data = writer.Bin_prot.Type_class.write t ~pos:pos_after_size_header v in\n if pos_after_data - pos <> total_len\n then\n failwiths\n ~here:[%here]\n \"Bigstring.write_bin_prot bug!\"\n ( `pos_after_data pos_after_data\n , `start_pos pos\n , `bin_prot_size_header_length Bin_prot.Utils.size_header_length\n , `data_len data_len\n , `total_len total_len )\n [%sexp_of:\n [ `pos_after_data of int ]\n * [ `start_pos of int ]\n * [ `bin_prot_size_header_length of int ]\n * [ `data_len of int ]\n * [ `total_len of int ]];\n pos_after_data\n;;\n\n(* Hex dump *)\n\ninclude Hexdump.Of_indexable (struct\n type nonrec t = t\n\n let length = length\n let get = get\n end)\n\nlet rec last_nonmatch_plus_one ~buf ~min_pos ~pos ~char =\n let pos' = pos - 1 in\n if pos' >= min_pos && Char.( = ) (get buf pos') char\n then last_nonmatch_plus_one ~buf ~min_pos ~pos:pos' ~char\n else pos\n;;\n\nlet get_tail_padded_fixed_string ~padding t ~pos ~len () =\n let data_end =\n last_nonmatch_plus_one ~buf:t ~min_pos:pos ~pos:(pos + len) ~char:padding\n in\n to_string t ~pos ~len:(data_end - pos)\n;;\n\nlet set_tail_padded_fixed_string ~padding t ~pos ~len value =\n let slen = String.length value in\n if slen > len\n then\n Printf.failwithf\n \"Bigstring.set_tail_padded_fixed_string: %S is longer than %d\"\n value\n len\n ();\n From_string.blit ~src:value ~dst:t ~src_pos:0 ~dst_pos:pos ~len:slen;\n for i = pos + slen to pos + len - 1 do\n set t i padding\n done\n;;\n\nlet rec first_nonmatch ~buf ~pos ~max_pos ~char =\n if pos <= max_pos && Char.( = ) (get buf pos) char\n then first_nonmatch ~buf ~pos:(Int.succ pos) ~max_pos ~char\n else pos\n;;\n\nlet set_head_padded_fixed_string ~padding t ~pos ~len value =\n let slen = String.length value in\n if slen > len\n then\n Printf.failwithf\n \"Bigstring.set_head_padded_fixed_string: %S is longer than %d\"\n value\n len\n ();\n From_string.blit ~src:value ~dst:t ~src_pos:0 ~dst_pos:(pos + len - slen) ~len:slen;\n for i = pos to pos + len - slen - 1 do\n set t i padding\n done\n;;\n\nlet get_head_padded_fixed_string ~padding t ~pos ~len () =\n let data_begin = first_nonmatch ~buf:t ~pos ~max_pos:(pos + len - 1) ~char:padding in\n to_string t ~pos:data_begin ~len:(len - (data_begin - pos))\n;;\n","open! Import\ninclude Bin_prot\n\nmodule Writer = struct\n type 'a t = 'a Bin_prot.Type_class.writer =\n { size : 'a Size.sizer\n ; write : 'a Write.writer\n }\n\n let to_string t v =\n let len = t.size v in\n let buf = Bigstring.create len in\n let pos = t.write buf ~pos:0 v in\n assert (pos = Bigstring.length buf);\n let str = Bigstring.to_string buf in\n Bigstring.unsafe_destroy buf;\n str\n ;;\n\n let to_bytes t v =\n let len = t.size v in\n let buf = Bigstring.create len in\n let pos = t.write buf ~pos:0 v in\n assert (pos = Bigstring.length buf);\n let str = Bigstring.to_bytes buf in\n Bigstring.unsafe_destroy buf;\n str\n ;;\nend\n\nmodule Reader = struct\n type 'a t = 'a Bin_prot.Type_class.reader =\n { read : 'a Read.reader\n ; vtag_read : (int -> 'a) Read.reader\n }\n\n let of_string t string =\n let buf = Bigstring.of_string string in\n let pos_ref = ref 0 in\n let v = t.read buf ~pos_ref in\n assert (!pos_ref = Bigstring.length buf);\n Bigstring.unsafe_destroy buf;\n v\n ;;\n\n let of_bytes t bytes =\n let buf = Bigstring.of_bytes bytes in\n let pos_ref = ref 0 in\n let v = t.read buf ~pos_ref in\n assert (!pos_ref = Bigstring.length buf);\n Bigstring.unsafe_destroy buf;\n v\n ;;\nend\n","module T = struct\n include Bin_prot.Md5\n\n let sexp_of_t t = t |> to_hex |> String.sexp_of_t\n let t_of_sexp s = s |> String.t_of_sexp |> of_hex_exn\nend\n\nlet hash_fold_t accum t = String.hash_fold_t accum (T.to_binary t)\nlet hash t = String.hash (T.to_binary t)\n\nmodule As_binary_string = struct\n module Stable = struct\n module V1 = struct\n type t = T.t [@@deriving compare]\n\n let hash_fold_t = hash_fold_t\n let hash = hash\n let sexp_of_t x = String.sexp_of_t (T.to_binary x)\n let t_of_sexp x = T.of_binary_exn (String.t_of_sexp x)\n\n include Bin_prot.Utils.Make_binable_without_uuid [@alert \"-legacy\"] (struct\n module Binable = String\n\n type t = Bin_prot.Md5.t\n\n let to_binable = T.to_binary\n let of_binable = T.of_binary_exn\n end)\n end\n end\n\n include Stable.V1\n include Comparable.Make (Stable.V1)\n include Hashable.Make (Stable.V1)\nend\n\nmodule Stable = struct\n module V1 = struct\n type t = T.t [@@deriving compare, sexp]\n\n let hash_fold_t = hash_fold_t\n let hash = hash\n\n include Bin_prot.Utils.Make_binable_without_uuid [@alert \"-legacy\"] (struct\n module Binable = Bin_prot.Md5\n\n type t = Bin_prot.Md5.t\n\n let to_binable = Fn.id\n let of_binable = Fn.id\n end)\n end\n\n let digest_string s = Md5_lib.string s\nend\n\ninclude Stable.V1\ninclude Comparable.Make (Stable.V1)\ninclude Hashable.Make (Stable.V1)\n\nlet digest_num_bytes = 16\nlet to_hex = T.to_hex\nlet from_hex = T.of_hex_exn\nlet of_hex_exn = T.of_hex_exn\nlet of_binary_exn = T.of_binary_exn\nlet to_binary = T.to_binary\nlet digest_string = Stable.digest_string\nlet digest_bytes = Md5_lib.bytes\n\nexternal caml_sys_open\n : string\n -> Caml.open_flag list\n -> perm:int\n -> int\n = \"caml_sys_open\"\n\nexternal caml_sys_close : int -> unit = \"caml_sys_close\"\nexternal digest_fd_blocking : int -> string = \"core_md5_fd\"\n\nlet digest_file_blocking path =\n of_binary_exn\n (Base.Exn.protectx\n (caml_sys_open path [ Open_rdonly; Open_binary ] ~perm:0o000)\n ~f:digest_fd_blocking\n ~finally:caml_sys_close)\n;;\n\nlet file = digest_file_blocking\n\nlet digest_channel_blocking_without_releasing_runtime_lock channel ~len =\n of_binary_exn (Caml.Digest.channel channel len)\n;;\n\nlet channel channel len =\n digest_channel_blocking_without_releasing_runtime_lock channel ~len\n;;\n\nlet output_blocking t oc = Caml.Digest.output oc (to_binary t)\nlet output oc t = output_blocking t oc\nlet input_blocking ic = of_binary_exn (Caml.Digest.input ic)\nlet input = input_blocking\nlet digest_subbytes = Md5_lib.subbytes\nlet string = digest_string\nlet bytes = digest_bytes\nlet subbytes s pos len = digest_subbytes s ~pos ~len\n\nlet digest_bin_prot writer value =\n digest_string (Core_bin_prot.Writer.to_string writer value)\n;;\n\nexternal c_digest_subbigstring\n : Bigstring.t\n -> pos:int\n -> len:int\n -> res:Bytes.t\n -> unit\n = \"core_md5_digest_subbigstring\"\n\nlet unsafe_digest_subbigstring buf ~pos ~len =\n (* It's more efficient to allocate the result on the OCaml side and declare the C\n function as noalloc than to let the C function allocate. *)\n let res = Bytes.create 16 in\n c_digest_subbigstring buf ~pos ~len ~res;\n Md5_lib.unsafe_of_binary\n (Bytes.unsafe_to_string ~no_mutation_while_string_reachable:res)\n;;\n\nlet digest_subbigstring buf ~pos ~len =\n Ordered_collection_common.check_pos_len_exn\n ~pos\n ~len\n ~total_length:(Bigstring.length buf);\n unsafe_digest_subbigstring buf ~pos ~len\n;;\n\nlet digest_bigstring buf =\n unsafe_digest_subbigstring buf ~pos:0 ~len:(Bigstring.length buf)\n;;\n","(** Time-zone handling. *)\n\nopen! Import\n\n(** The internal time representation of [Zone.t]. This is a tiny subset of [Time0_intf.S],\n see that interface for details such as the meaning of [Span] and [Date_and_ofday].\n\n The name of the interface reflects the fact that the interface only gives you access\n to the seconds of the [t]. But you can use this interface with types that have higher\n precision than that, hence the rounding implied in the name of\n [to_int63_seconds_round_down_exn].\n*)\nmodule type Time_in_seconds = sig\n module Span : sig\n type t\n\n val of_int63_seconds : Int63.t -> t\n val to_int63_seconds_round_down_exn : t -> Int63.t\n end\n\n module Date_and_ofday : sig\n type t\n\n val of_synthetic_span_since_epoch : Span.t -> t\n val to_synthetic_span_since_epoch : t -> Span.t\n end\n\n type t\n\n val of_span_since_epoch : Span.t -> t\n val to_span_since_epoch : t -> Span.t\nend\n\n(** This is the interface of [Zone], but not the interface of [Time.Zone] or\n [Time_ns.Zone]. For those, look at [Time_intf.Zone] *)\nmodule type S = sig\n (** {1 User-friendly interface} *)\n\n (** The type of a time-zone.\n\n bin_io and sexp representations of Zone.t are the name of the zone, and\n not the full data that is read from disk when Zone.find is called. The\n full Zone.t is reconstructed on the receiving/reading side by reloading\n the zone file from disk. Any zone name that is accepted by [find] is\n acceptable in the bin_io and sexp representations. *)\n type t [@@deriving sexp_of, compare]\n\n (** [input_tz_file ~zonename ~filename] read in [filename] and return [t]\n with [name t] = [zonename] *)\n val input_tz_file : zonename:string -> filename:string -> t\n\n (** [likely_machine_zones] is a list of zone names that will be searched\n first when trying to determine the machine zone of a box. Setting this\n to a likely set of zones for your application will speed the very first\n use of the local timezone. *)\n val likely_machine_zones : string list ref\n\n (** [of_utc_offset offset] returns a timezone with a static UTC offset (given in\n hours). *)\n val of_utc_offset : hours:int -> t\n\n (** [utc] the UTC time zone. Included for convenience *)\n val utc : t\n\n val name : t -> string\n\n (** [original_filename t] return the filename [t] was loaded from (if any) *)\n val original_filename : t -> string option\n\n (** [digest t] return the MD5 digest of the file the t was created from (if any) *)\n val digest : t -> Md5.t option\n\n module Time_in_seconds : Time_in_seconds\n\n (** For performance testing only; [reset_transition_cache t] resets an internal cache in\n [t] used to speed up repeated lookups of the same clock shift transition. *)\n val reset_transition_cache : t -> unit\n\n (** A time zone index refers to a range of times delimited by DST transitions at one or\n both ends. Every time belongs to exactly one such range. The times of DST\n transitions themselves belong to the range for which they are the lower bound. *)\n module Index : sig\n type t [@@immediate]\n\n val next : t -> t\n val prev : t -> t\n end\n\n (** Gets the index of a time. *)\n val index : t -> Time_in_seconds.t -> Index.t\n\n val index_of_date_and_ofday : t -> Time_in_seconds.Date_and_ofday.t -> Index.t\n\n (** Gets the UTC offset of times in a specific range.\n\n This can raise if you use an [Index.t] that is out of bounds for this [t]. *)\n val index_offset_from_utc_exn : t -> Index.t -> Time_in_seconds.Span.t\n\n (** [index_abbreviation_exn t index] returns the abbreviation name (such as EDT, EST,\n JST) of given zone [t] for the range of [index]. This string conversion is one-way\n only, and cannot reliably be turned back into a [t]. This function reads and writes\n the zone's cached index. Raises if [index] is out of bounds for [t]. *)\n val index_abbreviation_exn : t -> Index.t -> string\n\n (** Accessors for the DST transitions delimiting the start and end of a range, if any.\n The [_exn] accessors raise if there is no such transition. These accessors are split\n up to increase performance and improve allocation; they are intended as a low-level\n back-end for commonly-used time conversion functions. See [Time.Zone] and\n [Time_ns.Zone] for higher-level accessors that return an optional tuple for clock\n shifts in either direction. *)\n val index_has_prev_clock_shift : t -> Index.t -> bool\n\n val index_prev_clock_shift_time_exn : t -> Index.t -> Time_in_seconds.t\n val index_prev_clock_shift_amount_exn : t -> Index.t -> Time_in_seconds.Span.t\n val index_has_next_clock_shift : t -> Index.t -> bool\n val index_next_clock_shift_time_exn : t -> Index.t -> Time_in_seconds.t\n val index_next_clock_shift_amount_exn : t -> Index.t -> Time_in_seconds.Span.t\nend\n\nmodule type S_stable = sig\n type t\n\n module Full_data : sig\n module V1 : Stable_module_types.S0_without_comparator with type t = t\n end\nend\n\nmodule type Zone = sig\n module type S = S\n module type S_stable = S_stable\n\n include S\n module Stable : S_stable with type t := t\nend\n","open! Import\ninclude Binable_intf\ninclude Binable0\n\n(* [of_string] and [to_string] can't go in binable0.ml due to a cyclic dependency. *)\nlet of_string m string = of_bigstring m (Bigstring.of_string string)\nlet to_string m t = Bigstring.to_string (to_bigstring m t)\n\nmodule Of_binable = Of_binable_without_uuid [@@alert \"-legacy\"]\nmodule Of_binable1 = Of_binable1_without_uuid [@@alert \"-legacy\"]\nmodule Of_binable2 = Of_binable2_without_uuid [@@alert \"-legacy\"]\nmodule Of_binable3 = Of_binable3_without_uuid [@@alert \"-legacy\"]\nmodule Of_sexpable = Of_sexpable_without_uuid [@@alert \"-legacy\"]\nmodule Of_stringable = Of_stringable_without_uuid [@@alert \"-legacy\"]\n","(* Functions for parsing time zone database files (zic files).\n\n A time zone file consists (conceptually - the representation is more\n compact) of an ordered list of (Time.t * [local_time_type]) that mark\n the boundaries (marked from the epoch) at which various time adjustment\n regimes are in effect. This can also be thought of as breaking down all\n time past the epoch into ranges with a [local_time_type] that describes the\n offset from GMT to apply to each range to get local time.\n*)\n\nopen Import\nopen Std_internal\nopen! Int.Replace_polymorphic_compare\ninclude Zone_intf\n\nexception Invalid_file_format of string [@@deriving sexp]\n\nmodule Stable = struct\n module Full_data = struct\n module V1 = struct\n module Index = struct\n type t = int\n\n let next = Int.succ\n let prev = Int.pred\n let before_first_transition = -1\n\n (* Some existing clients expect [index >= 0], so we never serialize a negative\n index. This conversion can be removed if new stable versions are minted. *)\n let to_external t = max 0 t\n\n (* When the index of a time zone with no transitions is converted via to_external,\n its value becomes 0 even though its transition array is empty (and it should\n have been -1). When the converted value is changed back to a Zone.t through\n of_external, returning this value for its index could result in unsafe array\n accesses to the transition array of the zone (since there is no transition at\n index 0). Also, it does not make sense to keep the converted index because it\n is intended to be a mutable value used for caching. So of_external always sets\n the index to -1, which is a safe value. *)\n let of_external (_ : t) = -1\n\n include Binable.Of_binable_without_uuid [@alert \"-legacy\"]\n (Int)\n (struct\n type t = int\n\n let to_binable = to_external\n let of_binable = of_external\n end)\n\n include Sexpable.Of_sexpable\n (Int)\n (struct\n type t = int\n\n let to_sexpable = to_external\n let of_sexpable = of_external\n end)\n end\n\n module Regime = struct\n type t =\n { utc_offset_in_seconds : Int63.Stable.V1.t\n ; is_dst : bool\n ; abbrv : string\n }\n [@@deriving bin_io, sexp]\n end\n\n (* holds information about when leap seconds should be applied - unused\n because we are translating based on a epoch system clock (see the Core_zone\n documentation). *)\n module Leap_second = struct\n type t =\n { time_in_seconds_since_epoch : Int63.Stable.V1.t\n ; seconds : int\n }\n [@@deriving bin_io, sexp]\n end\n\n module Transition = struct\n type t =\n { start_time_in_seconds_since_epoch : Int63.Stable.V1.t\n ; new_regime : Regime.t\n }\n [@@deriving bin_io, sexp]\n end\n\n type t =\n { name : string\n ; original_filename : string option\n ;\n digest : Md5.As_binary_string.t option\n ; transitions : Transition.t array\n ; (* caches the index of the last transition we used to make lookups faster *)\n mutable last_regime_index : Index.t\n ; default_local_time_type : Regime.t\n ; leap_seconds : Leap_second.t list\n }\n [@@deriving bin_io, sexp]\n\n (* this relies on zones with the same name having the same transitions *)\n let compare t1 t2 = String.compare t1.name t2.name\n let original_filename zone = zone.original_filename\n let digest zone = zone.digest\n\n module Zone_file : sig\n val input_tz_file : zonename:string -> filename:string -> t\n end = struct\n let bool_of_int i = i <> 0\n\n let input_long_as_int32 =\n let long = Bytes.create 4 in\n let int32_of_char chr = Int32.of_int_exn (int_of_char chr) in\n fun ic ->\n In_channel.really_input_exn ic ~buf:long ~pos:0 ~len:4;\n let sb1 = Int32.shift_left (int32_of_char (Bytes.get long 0)) 24 in\n let sb2 = Int32.shift_left (int32_of_char (Bytes.get long 1)) 16 in\n let sb3 = Int32.shift_left (int32_of_char (Bytes.get long 2)) 8 in\n let sb4 = int32_of_char (Bytes.get long 3) in\n Int32.bit_or (Int32.bit_or sb1 sb2) (Int32.bit_or sb3 sb4)\n ;;\n\n (* Note that this is only safe to use on numbers that will fit into a 31-bit\n int. UNIX timestamps won't, for example. In our case this is only used\n to hold small numbers that are never interpreted as timestamps. *)\n let input_long_as_int ic = Int32.to_int_exn (input_long_as_int32 ic)\n let input_long_as_int63 ic = Int63.of_int32 (input_long_as_int32 ic)\n\n let input_long_long_as_int63 ic =\n let int63_of_char chr = Int63.of_int_exn (int_of_char chr) in\n let shift c bits = Int63.shift_left (int63_of_char c) bits in\n let long_long = Bytes.create 8 in\n In_channel.really_input_exn ic ~buf:long_long ~pos:0 ~len:8;\n let result = shift (Bytes.get long_long 0) 56 in\n let result = Int63.bit_or result (shift (Bytes.get long_long 1) 48) in\n let result = Int63.bit_or result (shift (Bytes.get long_long 2) 40) in\n let result = Int63.bit_or result (shift (Bytes.get long_long 3) 32) in\n let result = Int63.bit_or result (shift (Bytes.get long_long 4) 24) in\n let result = Int63.bit_or result (shift (Bytes.get long_long 5) 16) in\n let result = Int63.bit_or result (shift (Bytes.get long_long 6) 8) in\n let result = Int63.bit_or result (int63_of_char (Bytes.get long_long 7)) in\n result\n ;;\n\n let input_list ic ~len ~f =\n let rec loop c lst =\n if c > 0 then loop (c - 1) (f ic :: lst) else List.rev lst\n in\n loop len []\n ;;\n\n let input_array ic ~len ~f = Array.of_list (input_list ic ~len ~f)\n\n let input_regime ic =\n let utc_offset_in_seconds = input_long_as_int63 ic in\n let is_dst = bool_of_int (Option.value_exn (In_channel.input_byte ic)) in\n let abbrv_index = Option.value_exn (In_channel.input_byte ic) in\n let lt abbrv = { Regime.utc_offset_in_seconds; is_dst; abbrv } in\n lt, abbrv_index\n ;;\n\n let input_abbreviations ic ~len =\n let raw_abbrvs =\n input_list ic ~len ~f:(fun ic -> Option.value_exn (In_channel.input_char ic))\n in\n let buf = Buffer.create len in\n let _, indexed_abbrvs =\n List.fold raw_abbrvs ~init:(0, Map.Poly.empty) ~f:(fun (index, abbrvs) c ->\n match c with\n | '\\000' ->\n let data = Buffer.contents buf in\n let next_index = index + String.length data + 1 in\n let abbrvs = Map.set abbrvs ~key:index ~data in\n Buffer.clear buf;\n next_index, abbrvs\n | c ->\n Buffer.add_char buf c;\n index, abbrvs)\n in\n if Buffer.length buf <> 0\n then\n raise\n (Invalid_file_format\n \"missing \\000 terminating character in input_abbreviations\");\n indexed_abbrvs\n ;;\n\n let input_tz_file_gen ~input_transition ~input_leap_second ic =\n let utc_local_count = input_long_as_int ic in\n let std_wall_count = input_long_as_int ic in\n let leap_count = input_long_as_int ic in\n let transition_count = input_long_as_int ic in\n let type_count = input_long_as_int ic in\n let abbrv_char_count = input_long_as_int ic in\n let transition_times =\n input_list ic ~f:input_transition ~len:transition_count\n in\n let transition_indices =\n input_list\n ic\n ~f:(fun ic -> Option.value_exn (In_channel.input_byte ic))\n ~len:transition_count\n in\n let regimes = input_list ic ~f:input_regime ~len:type_count in\n let abbreviations = input_abbreviations ic ~len:abbrv_char_count in\n let leap_seconds = input_list ic ~f:input_leap_second ~len:leap_count in\n (* The following two arrays indicate two boolean values per regime that\n represent a three-value type that would translate to:\n\n type transition_type = UTC | Standard | Wall_clock\n\n However, these are only used by the system library when handling the case where the\n TZ variable is set, not to a time zone name, but instead is of the form:\n\n TZ = \"std offset dst offset, rule\"\n\n Which is deeply obscure, and almost certainly a mistake to use. This library makes\n no pretense about handling this case. We continue to read them in for\n completeness, and because it's possible that we will later discover a case where\n they are used. *)\n let _std_wall_indicators =\n input_array ic ~len:std_wall_count ~f:(fun ic ->\n bool_of_int (Option.value_exn (In_channel.input_byte ic)))\n in\n let _utc_local_indicators =\n input_array ic ~len:utc_local_count ~f:(fun ic ->\n bool_of_int (Option.value_exn (In_channel.input_byte ic)))\n in\n let regimes =\n Array.of_list\n (List.map regimes ~f:(fun (lt, abbrv_index) ->\n let abbrv = Map.find_exn abbreviations abbrv_index in\n lt abbrv))\n in\n let raw_transitions =\n List.map2_exn transition_times transition_indices ~f:(fun time index ->\n let regime = regimes.(index) in\n time, regime)\n in\n let transitions =\n let rec make_transitions acc l =\n match l with\n | [] -> Array.of_list (List.rev acc)\n | (start_time_in_seconds_since_epoch, new_regime) :: rest ->\n make_transitions\n ({ Transition.start_time_in_seconds_since_epoch; new_regime } :: acc)\n rest\n in\n make_transitions [] raw_transitions\n in\n let default_local_time_type =\n match Array.find regimes ~f:(fun r -> not r.Regime.is_dst) with\n | None -> regimes.(0)\n | Some ltt -> ltt\n in\n fun name ~original_filename ~digest ->\n { name\n ; original_filename = Some original_filename\n ; digest = Some digest\n ; transitions\n ; last_regime_index = Index.before_first_transition\n ; default_local_time_type\n ; leap_seconds\n }\n ;;\n\n let input_leap_second_gen ~input_leap_second ic =\n let time_in_seconds_since_epoch = input_leap_second ic in\n let seconds = input_long_as_int ic in\n { Leap_second.time_in_seconds_since_epoch; seconds }\n ;;\n\n let read_header ic =\n let magic =\n let buf = Bytes.create 4 in\n In_channel.really_input_exn ic ~buf ~pos:0 ~len:4;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf\n in\n if not (String.equal magic \"TZif\")\n then raise (Invalid_file_format \"magic characters TZif not present\");\n let version =\n match In_channel.input_char ic with\n | Some '\\000' -> `V1\n | Some '2' -> `V2\n | Some '3' -> `V3\n | None -> raise (Invalid_file_format \"expected version, found nothing\")\n | Some bad_version ->\n raise (Invalid_file_format (sprintf \"version (%c) is invalid\" bad_version))\n in\n (* space reserved for future use in the format *)\n In_channel.really_input_exn ic ~buf:(Bytes.create 15) ~pos:0 ~len:15;\n version\n ;;\n\n let input_tz_file_v1 ic =\n let input_leap_second =\n input_leap_second_gen ~input_leap_second:input_long_as_int63\n in\n input_tz_file_gen ~input_transition:input_long_as_int63 ~input_leap_second ic\n ;;\n\n (*\n version 2 timezone files have the format:\n\n part 1 - exactly the same as v1\n\n part 2 - same format as v1, except that 8 bytes are used to store\n transition times and leap seconds\n\n part 3 - a newline-encloded, POSIX-TZ-environment-variable-style\n string for use in handling instants after the last transition time\n stored in the file (with nothing between the newlines if there is no\n POSIX representation for such instants)\n\n We handle files in this format by parsing the first part exactly as a v1\n timezone file and then continuing to parse with 64bit reading functions in the\n right places.\n\n Version 3 timezone files are the same as version 2, except the\n POSIX-TZ-environment-variable-style string in part 3 may use two minor\n extensions to the POSIX TZ format (the hours part of its transition\n times may be signed and range from -167 through 167 instead of the\n POSIX-required unsigned values from 0 through 24; and DST is in effect all\n year if it starts January 1 at 00:00 and ends December 31 at 24:00 plus the\n difference between daylight saving and standard time).\n\n As we don't actually do anything with part 3 anyway, we can just read v3\n files as v2.\n *)\n let input_tz_file_v2_or_v3 ~version ic =\n let (_ : string -> original_filename:string -> digest:Md5_lib.t -> t) =\n input_tz_file_v1 ic\n in\n (* the header is fully repeated *)\n assert ([%compare.equal: [ `V1 | `V2 | `V3 ]] (read_header ic) version);\n let input_leap_second =\n input_leap_second_gen ~input_leap_second:input_long_long_as_int63\n in\n input_tz_file_gen\n ~input_transition:input_long_long_as_int63\n ~input_leap_second\n ic\n ;;\n\n let input_tz_file ~zonename ~filename =\n try\n protectx (In_channel.create filename) ~finally:In_channel.close ~f:(fun ic ->\n let make_zone =\n match read_header ic with\n | `V1 -> input_tz_file_v1 ic\n | (`V2 | `V3) as version -> input_tz_file_v2_or_v3 ~version ic\n in\n let digest = Md5.digest_file_blocking filename in\n let r = make_zone zonename ~original_filename:filename ~digest in\n r)\n with\n | Invalid_file_format reason ->\n raise (Invalid_file_format (sprintf \"%s - %s\" filename reason))\n ;;\n end\n\n let of_utc_offset ~hours:offset =\n assert (offset >= -24 && offset <= 24);\n let name =\n if offset = 0\n then \"UTC\"\n else sprintf \"UTC%s%d\" (if offset < 0 then \"-\" else \"+\") (abs offset)\n in\n let utc_offset_in_seconds = Int63.of_int (offset * 60 * 60) in\n { name\n ; original_filename = None\n ; digest = None\n ; transitions = [||]\n ; last_regime_index = Index.before_first_transition\n ; default_local_time_type =\n { Regime.utc_offset_in_seconds; is_dst = false; abbrv = name }\n ; leap_seconds = []\n }\n ;;\n end\n end\nend\n\ninclude Stable.Full_data.V1\n\nlet sexp_of_t t = Sexp.Atom t.name\n\nlet likely_machine_zones =\n ref [ \"America/New_York\"; \"Europe/London\"; \"Asia/Hong_Kong\"; \"America/Chicago\" ]\n;;\n\nlet input_tz_file = Zone_file.input_tz_file\nlet utc = of_utc_offset ~hours:0\nlet name zone = zone.name\nlet reset_transition_cache t = t.last_regime_index <- Index.before_first_transition\n\n(* Raises if [index >= Array.length t.transitions] *)\nlet get_regime_exn t index =\n if index < 0 then t.default_local_time_type else t.transitions.(index).new_regime\n;;\n\n(* In \"absolute mode\", a number of seconds is interpreted as an offset of that many\n seconds from the UNIX epoch, ignoring leap seconds.\n\n In \"date and ofday mode\", you interpret the number of seconds as a number of days in\n combination with a number of seconds since midnight, which gives you a calendar day and\n a clock face time. Then you take the time that those represent in some relevant\n timezone.\n\n Of course, if the timezone in question has DST shifts, the date and ofday might\n represent two or zero times. These times will be interpreted according to either the\n previous UTC offset or the next one, in a way whose precise details you probably\n shouldn't depend on.\n\n (For the curious, what we do is: compute the \"relative time\" of the shift according to\n the new regime, and assign relative times to the old regime or new regime depending on\n which side of the shift time they occur. Since this amounts to using the old regime\n when the clocks move forward and the new regime when the clocks move back, it's\n equivalent to calculating the corresponding Time.t's relative to both the old and the\n new regime and picking the one that occurs later. Yes, later. I had to draw a diagram\n to persuade myself that it's that way round, but it is.)\n*)\nmodule Mode = struct\n type t =\n | Absolute\n | Date_and_ofday\nend\n\nlet effective_start_time ~mode (x : Transition.t) =\n let open Int63.O in\n match (mode : Mode.t) with\n | Absolute -> x.start_time_in_seconds_since_epoch\n | Date_and_ofday ->\n x.start_time_in_seconds_since_epoch + x.new_regime.utc_offset_in_seconds\n;;\n\nlet index_lower_bound_contains_seconds_since_epoch t index ~mode seconds =\n index < 0 || Int63.( >= ) seconds (effective_start_time ~mode t.transitions.(index))\n;;\n\nlet index_upper_bound_contains_seconds_since_epoch t index ~mode seconds =\n index + 1 >= Array.length t.transitions\n || Int63.( < ) seconds (effective_start_time ~mode t.transitions.(index + 1))\n;;\n\nlet binary_search_index_of_seconds_since_epoch t ~mode seconds : Index.t =\n Array.binary_search_segmented\n t.transitions\n `Last_on_left\n ~segment_of:(fun transition ->\n if Int63.( <= ) (effective_start_time transition ~mode) seconds\n then `Left\n else `Right)\n |> Option.value ~default:Index.before_first_transition\n;;\n\nlet index_of_seconds_since_epoch t ~mode seconds =\n let index =\n let index = t.last_regime_index in\n if not (index_lower_bound_contains_seconds_since_epoch t index ~mode seconds)\n (* time is before cached index; try previous index *)\n then (\n let index = index - 1 in\n if not (index_lower_bound_contains_seconds_since_epoch t index ~mode seconds)\n (* time is before previous index; fall back on binary search *)\n then\n binary_search_index_of_seconds_since_epoch t ~mode seconds\n (* time is before cached index and not before previous, so within previous *)\n else index)\n else if not (index_upper_bound_contains_seconds_since_epoch t index ~mode seconds)\n (* time is after cached index; try next index *)\n then (\n let index = index + 1 in\n if not (index_upper_bound_contains_seconds_since_epoch t index ~mode seconds)\n (* time is after next index; fall back on binary search *)\n then\n binary_search_index_of_seconds_since_epoch t ~mode seconds\n (* time is after cached index and not after next, so within next *)\n else index (* time is within cached index *))\n else index\n in\n t.last_regime_index <- index;\n index\n;;\n\nmodule Time_in_seconds : sig\n include Zone_intf.Time_in_seconds\nend = struct\n module Span = struct\n type t = Int63.t\n\n let of_int63_seconds = ident\n let to_int63_seconds_round_down_exn = ident\n end\n\n module Absolute = struct\n type t = Int63.t\n\n let of_span_since_epoch = ident\n let to_span_since_epoch = ident\n end\n\n module Date_and_ofday = struct\n type t = Int63.t\n\n let of_synthetic_span_since_epoch = ident\n let to_synthetic_span_since_epoch = ident\n end\n\n include Absolute\nend\n\nlet index t time =\n Time_in_seconds.to_span_since_epoch time\n |> Time_in_seconds.Span.to_int63_seconds_round_down_exn\n |> index_of_seconds_since_epoch t ~mode:Absolute\n;;\n\nlet index_of_date_and_ofday t time =\n Time_in_seconds.Date_and_ofday.to_synthetic_span_since_epoch time\n |> Time_in_seconds.Span.to_int63_seconds_round_down_exn\n |> index_of_seconds_since_epoch t ~mode:Date_and_ofday\n;;\n\nlet index_has_prev_clock_shift t index = index >= 0 && index < Array.length t.transitions\nlet index_has_next_clock_shift t index = index_has_prev_clock_shift t (index + 1)\n\nlet index_prev_clock_shift_time_exn t index =\n let transition = t.transitions.(index) in\n transition.start_time_in_seconds_since_epoch\n |> Time_in_seconds.Span.of_int63_seconds\n |> Time_in_seconds.of_span_since_epoch\n;;\n\nlet index_next_clock_shift_time_exn t index =\n index_prev_clock_shift_time_exn t (index + 1)\n;;\n\nlet index_prev_clock_shift_amount_exn t index =\n let transition = t.transitions.(index) in\n let after = transition.new_regime in\n let before =\n if index = 0 then t.default_local_time_type else t.transitions.(index - 1).new_regime\n in\n Int63.( - ) after.utc_offset_in_seconds before.utc_offset_in_seconds\n |> Time_in_seconds.Span.of_int63_seconds\n;;\n\nlet index_next_clock_shift_amount_exn t index =\n index_prev_clock_shift_amount_exn t (index + 1)\n;;\n\nlet index_abbreviation_exn t index =\n let regime = get_regime_exn t index in\n regime.abbrv\n;;\n\nlet index_offset_from_utc_exn t index =\n let regime = get_regime_exn t index in\n Time_in_seconds.Span.of_int63_seconds regime.utc_offset_in_seconds\n;;\n","open! Import\ninclude Base.Source_code_position\ninclude Source_code_position0\ninclude Comparable.Extend (Base.Source_code_position) (Source_code_position0)\ninclude Hashable.Make (Source_code_position0)\n","open! Import\nopen Std_internal\nopen Validated_intf\n\nmodule type Raw = Raw\n\ntype ('raw, 'witness) t = 'raw\n\nmodule type S = S with type ('a, 'b) validated := ('a, 'b) t\nmodule type S_bin_io = S_bin_io with type ('a, 'b) validated := ('a, 'b) t\n\nmodule type S_bin_io_compare_hash_sexp =\n S_bin_io_compare_hash_sexp with type ('a, 'b) validated := ('a, 'b) t\n\nlet raw t = t\n\nmodule Make (Raw : Raw) = struct\n type witness\n type t = Raw.t [@@deriving sexp_of]\n\n let validation_failed t error =\n Error.create\n \"validation failed\"\n (t, error, Raw.here)\n [%sexp_of: Raw.t * Error.t * Source_code_position.t]\n ;;\n\n let create_exn t =\n match Validate.result (Raw.validate t) with\n | Ok () -> t\n | Error error -> Error.raise (validation_failed t error)\n ;;\n\n let create t =\n match Validate.result (Raw.validate t) with\n | Ok () -> Ok t\n | Error error -> Error (validation_failed t error)\n ;;\n\n let t_of_sexp sexp = create_exn (Raw.t_of_sexp sexp)\n let raw t = t\nend\n\nmodule Add_bin_io (Raw : sig\n type t [@@deriving bin_io]\n\n include Raw_bin_io with type t := t\n end)\n (Validated : S with type raw := Raw.t) =\nstruct\n include Binable.Of_binable_without_uuid [@alert \"-legacy\"]\n (Raw)\n (struct\n type t = Raw.t\n\n let of_binable raw =\n if Raw.validate_binio_deserialization\n then Validated.create_exn raw\n else raw\n ;;\n\n let to_binable = Fn.id\n end)\nend\n\nmodule Add_compare (Raw : sig\n type t [@@deriving compare]\n\n include Raw with type t := t\n end)\n (Validated : S with type raw := Raw.t) =\nstruct\n let compare t1 t2 = [%compare: Raw.t] (raw t1) (raw t2)\nend\n\nmodule Add_hash (Raw : sig\n type t [@@deriving hash]\n\n include Raw with type t := t\n end)\n (Validated : S with type raw := Raw.t) =\nstruct\n let hash_fold_t state t = Raw.hash_fold_t state (Validated.raw t)\n let hash t = Raw.hash (Validated.raw t)\nend\n\nmodule Add_typerep (Raw : sig\n type t [@@deriving typerep]\n\n include Raw with type t := t\n end)\n (Validated : S with type raw := Raw.t) =\nstruct\n type t = Raw.t [@@deriving typerep]\nend\n\nmodule Make_binable (Raw : Raw_bin_io) = struct\n module T0 = Make (Raw)\n include T0\n include Add_bin_io (Raw) (T0)\nend\n\nmodule Make_bin_io_compare_hash_sexp (Raw : sig\n type t [@@deriving compare, hash]\n\n include Raw_bin_io with type t := t\n end) =\nstruct\n module T = Make_binable (Raw)\n include T\n include Add_compare (Raw) (T)\n\n include (\n Add_hash (Raw) (T) :\n sig\n type t [@@deriving hash]\n end\n with type t := t)\nend\n","include Base.Type_equal\n\nmodule Id = struct\n include Id\n\n module Uid = struct\n module Upstream = Base.Type_equal.Id.Uid\n include Base.Type_equal.Id.Uid\n\n include Comparable.Extend\n (Upstream)\n (struct\n type t = Base.Type_equal.Id.Uid.t [@@deriving sexp]\n end)\n\n include Hashable.Make (Upstream)\n end\nend\n","(** Universal/heterogeneous maps, useful for storing values of arbitrary type in a single\n map.\n\n In order to recover a value, it must be looked up with exactly the [Key.t] it was\n stored in. In other words, given different [Key.t]s from the same [string], one will\n not be able to recover the key stored in the other one.\n\n This is similar to [Univ] in spirit.\n*)\n\nopen! Import\n\nmodule type Key = sig\n type 'a t [@@deriving sexp_of]\n\n (** For correct behavior of the map, [to_type_id] must return the same\n [Type_equal.Id] on different calls on the same input.\n *)\n val to_type_id : 'a t -> 'a Type_equal.Id.t\nend\n\nmodule type Data = sig\n type 'a t [@@deriving sexp_of]\nend\n\nmodule type Data1 = sig\n type ('s, 'a) t [@@deriving sexp_of]\nend\n\nmodule type S = sig\n type t [@@deriving sexp_of]\n\n module Key : Key\n\n type 'a data\n\n include Invariant.S with type t := t\n\n val empty : t\n val is_empty : t -> bool\n val set : t -> 'a Key.t -> 'a data -> t\n val mem : t -> 'a Key.t -> bool\n val mem_by_id : t -> Type_equal.Id.Uid.t -> bool\n val find : t -> 'a Key.t -> 'a data option\n val find_exn : t -> 'a Key.t -> 'a data\n val add : t -> 'a Key.t -> 'a data -> [ `Ok of t | `Duplicate ]\n val add_exn : t -> 'a Key.t -> 'a data -> t\n val change : t -> 'a Key.t -> f:('a data option -> 'a data option) -> t\n val change_exn : t -> 'a Key.t -> f:('a data -> 'a data) -> t\n val update : t -> 'a Key.t -> f:('a data option -> 'a data) -> t\n val remove : t -> 'a Key.t -> t\n val remove_by_id : t -> Type_equal.Id.Uid.t -> t\n\n module Packed : sig\n type t = T : 'a Key.t * 'a data -> t\n end\n\n val to_alist : t -> Packed.t list\n val of_alist_exn : Packed.t list -> t\nend\n\nmodule type S1 = sig\n (** The ['s] parameter is shared across all values stored in the map. *)\n type 's t [@@deriving sexp_of]\n\n module Key : Key\n\n type ('s, 'a) data\n\n val invariant : _ t -> unit\n val empty : _ t\n val is_empty : _ t -> bool\n val set : 's t -> 'a Key.t -> ('s, 'a) data -> 's t\n val mem : _ t -> _ Key.t -> bool\n val mem_by_id : _ t -> Type_equal.Id.Uid.t -> bool\n val find : 's t -> 'a Key.t -> ('s, 'a) data option\n val find_exn : 's t -> 'a Key.t -> ('s, 'a) data\n val add : 's t -> 'a Key.t -> ('s, 'a) data -> [ `Ok of 's t | `Duplicate ]\n val add_exn : 's t -> 'a Key.t -> ('s, 'a) data -> 's t\n\n val change\n : 's t\n -> 'a Key.t\n -> f:(('s, 'a) data option -> ('s, 'a) data option)\n -> 's t\n\n val change_exn : 's t -> 'a Key.t -> f:(('s, 'a) data -> ('s, 'a) data) -> 's t\n val update : 's t -> 'a Key.t -> f:(('s, 'a) data option -> ('s, 'a) data) -> 's t\n val remove : 's t -> 'a Key.t -> 's t\n val remove_by_id : 's t -> Type_equal.Id.Uid.t -> 's t\n\n module Packed : sig\n type 's t = T : 'a Key.t * ('s, 'a) data -> 's t\n end\n\n val to_alist : 's t -> 's Packed.t list\n val of_alist_exn : 's Packed.t list -> 's t\nend\n\nmodule type Univ_map = sig\n module type S = S\n module type S1 = S1\n module type Key = Key\n module type Data = Data\n\n module Type_id_key : Key with type 'a t = 'a Type_equal.Id.t\n include S with type 'a data = 'a and module Key := Type_id_key\n\n (** This binding is convenient because existing call sites often refer to\n [Univ_map.Key.create].\n *)\n module Key = Type_equal.Id\n\n module Make (Key : Key) (Data : Data) :\n S with type 'a data = 'a Data.t and module Key = Key\n\n module Make1 (Key : Key) (Data : Data1) :\n S1 with type ('s, 'a) data = ('s, 'a) Data.t and module Key = Key\n\n module Merge\n (Key : Key)\n (Input1_data : Data1)\n (Input2_data : Data1)\n (Output_data : Data1) : sig\n type 's f =\n { f :\n 'a. key:'a Key.t\n -> [ `Left of ('s, 'a) Input1_data.t\n | `Right of ('s, 'a) Input2_data.t\n | `Both of ('s, 'a) Input1_data.t * ('s, 'a) Input2_data.t\n ] -> ('s, 'a) Output_data.t option\n }\n\n (** The analogue of the normal [Map.merge] function. *)\n val merge\n : 's Make1(Key)(Input1_data).t\n -> 's Make1(Key)(Input2_data).t\n -> f:'s f\n -> 's Make1(Key)(Output_data).t\n end\n\n (** keys with associated default values, so that [find] is no longer partial *)\n module With_default : sig\n module Key : sig\n type 'a t\n\n val create : default:'a -> name:string -> ('a -> Sexp.t) -> 'a t\n val id : 'a t -> 'a Type_equal.Id.t\n end\n\n val set : t -> 'a Key.t -> 'a -> t\n val find : t -> 'a Key.t -> 'a\n val change : t -> 'a Key.t -> f:('a -> 'a) -> t\n end\n\n (** keys that map to an accumulator value with an associated fold operation *)\n module With_fold : sig\n module Key : sig\n type ('a, 'b) t\n\n val create\n : init:'b\n -> f:('b -> 'a -> 'b)\n -> name:string\n -> ('b -> Sexp.t)\n -> ('a, 'b) t\n\n val id : ('a, 'b) t -> 'b Type_equal.Id.t\n end\n\n (** reset the accumulator *)\n val set : t -> ('a, 'b) Key.t -> 'b -> t\n\n (** the current accumulator *)\n val find : t -> ('a, 'b) Key.t -> 'b\n\n (** fold value into accumulator *)\n val add : t -> ('a, 'b) Key.t -> 'a -> t\n\n (** accumulator update *)\n val change : t -> ('a, 'b) Key.t -> f:('b -> 'b) -> t\n end\n\n (** list-accumulating keys with a default value of the empty list *)\n module Multi : sig\n module Key : sig\n type 'a t\n\n val create : name:string -> ('a -> Sexp.t) -> 'a t\n val id : 'a t -> 'a list Type_equal.Id.t\n end\n\n val set : t -> 'a Key.t -> 'a list -> t\n val find : t -> 'a Key.t -> 'a list\n val add : t -> 'a Key.t -> 'a -> t\n val change : t -> 'a Key.t -> f:('a list -> 'a list) -> t\n end\nend\n","open! Import\n\ntype t =\n | Nanosecond\n | Microsecond\n | Millisecond\n | Second\n | Minute\n | Hour\n | Day\n[@@deriving sexp, compare, enumerate, hash]\n","open! Import\nopen Std_internal\nopen Unique_id_intf\n\nmodule type Id = Id\n\n(* Only \"make\" can cause a context-switch that might lead to a race.\n Thus we have to check whether the contents of the cell remained\n unchanged across this call. The subsequent comparison, dereferencing\n and assignment cannot cause context switches. If the contents of the\n cell had changed, we will have to try again to obtain a unique id.\n This is essentially like a spin-lock and is virtually guaranteed to\n succeed quickly. *)\nlet rec race_free_create_loop cell make =\n let x = !cell in\n let new_x = make x in\n if phys_equal !cell x\n then (\n cell := new_x;\n x)\n else race_free_create_loop cell make\n;;\n\nmodule Int () = struct\n include Int\n\n let current = ref zero\n let create () = race_free_create_loop current succ\nend\n\nmodule Int63 () = struct\n include Int63\n\n let current = ref zero\n let create () = race_free_create_loop current succ\nend\n","open! Import\ninclude Base.Uniform_array\n\ninclude Binable.Of_binable1_without_uuid [@alert \"-legacy\"]\n (Array)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable = to_array\n let of_binable = of_array\n end)\n","open! Import\n\nlet failwithf = Printf.failwithf\n\nmodule Stable = struct\n module V1 = struct\n module T = struct\n type t =\n | Sun\n | Mon\n | Tue\n | Wed\n | Thu\n | Fri\n | Sat\n [@@deriving bin_io, compare, hash, quickcheck]\n\n let to_string t =\n match t with\n | Sun -> \"SUN\"\n | Mon -> \"MON\"\n | Tue -> \"TUE\"\n | Wed -> \"WED\"\n | Thu -> \"THU\"\n | Fri -> \"FRI\"\n | Sat -> \"SAT\"\n ;;\n\n let to_string_long t =\n match t with\n | Sun -> \"Sunday\"\n | Mon -> \"Monday\"\n | Tue -> \"Tuesday\"\n | Wed -> \"Wednesday\"\n | Thu -> \"Thursday\"\n | Fri -> \"Friday\"\n | Sat -> \"Saturday\"\n ;;\n\n let of_string_internal s =\n match String.uppercase s with\n | \"SUN\" | \"SUNDAY\" -> Sun\n | \"MON\" | \"MONDAY\" -> Mon\n | \"TUE\" | \"TUESDAY\" -> Tue\n | \"WED\" | \"WEDNESDAY\" -> Wed\n | \"THU\" | \"THURSDAY\" -> Thu\n | \"FRI\" | \"FRIDAY\" -> Fri\n | \"SAT\" | \"SATURDAY\" -> Sat\n | _ -> failwithf \"Day_of_week.of_string: %S\" s ()\n ;;\n\n let of_int_exn i =\n match i with\n | 0 -> Sun\n | 1 -> Mon\n | 2 -> Tue\n | 3 -> Wed\n | 4 -> Thu\n | 5 -> Fri\n | 6 -> Sat\n | _ -> failwithf \"Day_of_week.of_int_exn: %d\" i ()\n ;;\n\n (* Be very generous with of_string. We accept all possible capitalizations and the\n integer representations as well. *)\n let of_string s =\n try of_string_internal s with\n | _ ->\n (try of_int_exn (Int.of_string s) with\n | _ -> failwithf \"Day_of_week.of_string: %S\" s ())\n ;;\n\n (* this is in T rather than outside so that the later functor application to build maps\n uses this sexp representation *)\n include Sexpable.Stable.Of_stringable.V1 (struct\n type nonrec t = t\n\n let of_string = of_string\n let to_string = to_string\n end)\n end\n\n include T\n\n module Unstable = struct\n include T\n include (Comparable.Make_binable (T) : Comparable.S_binable with type t := t)\n include Hashable.Make_binable (T)\n end\n\n include Comparable.Stable.V1.Make (Unstable)\n include Hashable.Stable.V1.Make (Unstable)\n end\nend\n\ninclude Stable.V1.Unstable\n\nlet weekdays = [ Mon; Tue; Wed; Thu; Fri ]\nlet weekends = [ Sat; Sun ]\n\n(* written out to save overhead when loading modules. The members of the set and the\n ordering should never change, so speed wins over something more complex that proves\n the order = the order in t at runtime *)\nlet all = [ Sun; Mon; Tue; Wed; Thu; Fri; Sat ]\n\nlet of_int i =\n try Some (of_int_exn i) with\n | _ -> None\n;;\n\nlet to_int t =\n match t with\n | Sun -> 0\n | Mon -> 1\n | Tue -> 2\n | Wed -> 3\n | Thu -> 4\n | Fri -> 5\n | Sat -> 6\n;;\n\nlet iso_8601_weekday_number t =\n match t with\n | Mon -> 1\n | Tue -> 2\n | Wed -> 3\n | Thu -> 4\n | Fri -> 5\n | Sat -> 6\n | Sun -> 7\n;;\n\nlet num_days_in_week = 7\nlet shift t i = of_int_exn (Int.( % ) (to_int t + i) num_days_in_week)\n\nlet num_days ~from ~to_ =\n let d = to_int to_ - to_int from in\n if Int.(d < 0) then d + num_days_in_week else d\n;;\n\nlet is_sun_or_sat t = t = Sun || t = Sat\n","open! Import\nopen Std_internal\nopen Digit_string_helpers\n\nlet suffixes char =\n let sprintf = Printf.sprintf in\n [ sprintf \"%c\" char; sprintf \"%cM\" char; sprintf \"%c.M\" char; sprintf \"%c.M.\" char ]\n |> List.concat_map ~f:(fun suffix ->\n [ String.lowercase suffix; String.uppercase suffix ])\n;;\n\nlet am_suffixes = lazy (suffixes 'A')\nlet pm_suffixes = lazy (suffixes 'P')\n\n(* Avoids the allocation that [List.find] would entail in both both the closure input and\n the option output. *)\nlet rec find_suffix string suffixes =\n match suffixes with\n | suffix :: suffixes ->\n if String.is_suffix string ~suffix then suffix else find_suffix string suffixes\n | [] -> \"\"\n;;\n\nlet has_colon string pos ~until = pos < until && Char.equal ':' string.[pos]\n\n(* This function defines what we meant by \"decimal point\", because in some string formats\n it means '.' and in some it can be '.' or ','. There's no particular demand for support\n for ',', and using just '.' lets us use [Float.of_string] for the decimal substring\n without any substitutions. *)\nlet char_is_decimal_point string pos = Char.equal '.' string.[pos]\n\nlet decrement_length_if_ends_in_space string len =\n if len > 0 && Char.equal ' ' string.[len - 1] then len - 1 else len\n;;\n\nlet[@cold] invalid_string string ~reason =\n raise_s [%message \"Time.Ofday: invalid string\" string reason]\n;;\n\nlet check_digits_with_underscore_and_return_if_nonzero string pos ~until =\n let nonzero = ref false in\n for pos = pos to until - 1 do\n match string.[pos] with\n | '0' | '_' -> ()\n | '1' .. '9' -> nonzero := true\n | _ ->\n invalid_string\n string\n ~reason:\"expected digits and/or underscores after decimal point\"\n done;\n !nonzero\n;;\n\nlet check_digits_without_underscore_and_return_if_nonzero string pos ~until =\n let nonzero = ref false in\n for pos = pos to until - 1 do\n match string.[pos] with\n | '0' -> ()\n | '1' .. '9' -> nonzero := true\n | _ -> invalid_string string ~reason:\"expected digits after decimal point\"\n done;\n !nonzero\n;;\n\nlet parse string ~f =\n let len = String.length string in\n let am_or_pm, until =\n (* discriminate among AM (1:30am), PM (12:30:00 P.M.), or 24-hr (13:00). *)\n match\n ( find_suffix string (Lazy.force am_suffixes)\n , find_suffix string (Lazy.force pm_suffixes) )\n with\n | \"\", \"\" -> `hr_24, len\n | am, \"\" -> `hr_AM, decrement_length_if_ends_in_space string (len - String.length am)\n | \"\", pm -> `hr_PM, decrement_length_if_ends_in_space string (len - String.length pm)\n | _, _ -> `hr_24, assert false\n (* Immediately above, it may seem nonsensical to write [`hr_24, assert false] when the\n [`hr_24] can never be returned. We do this to help the compiler figure out never to\n allocate a tuple in this code: the [let] pattern is syntactically a tuple and every\n match clause is syntactically a tuple. *)\n in\n let pos = 0 in\n let pos, hr, expect_minutes_and_seconds =\n (* e.g. \"1:00\" or \"1:00:00\" *)\n if has_colon string (pos + 1) ~until\n then\n pos + 2, read_1_digit_int string ~pos, `Minutes_and_maybe_seconds\n (* e.g. \"12:00\" or \"12:00:00\" *)\n else if has_colon string (pos + 2) ~until\n then\n pos + 3, read_2_digit_int string ~pos, `Minutes_and_maybe_seconds\n (* e.g. \"1am\"; must have AM or PM (checked below) *)\n else if pos + 1 = until\n then\n pos + 1, read_1_digit_int string ~pos, `Neither_minutes_nor_seconds\n (* e.g. \"12am\"; must have AM or PM (checked below) *)\n else if pos + 2 = until\n then\n pos + 2, read_2_digit_int string ~pos, `Neither_minutes_nor_seconds\n (* e.g. \"0930\"; must not have seconds *)\n else pos + 2, read_2_digit_int string ~pos, `Minutes_but_not_seconds\n in\n let pos, min, expect_seconds =\n match expect_minutes_and_seconds with\n | `Neither_minutes_nor_seconds ->\n (* e.g. \"12am\" *)\n pos, 0, false\n | (`Minutes_and_maybe_seconds | `Minutes_but_not_seconds) as maybe_seconds ->\n (* e.g. \"12:00:00\" *)\n if has_colon string (pos + 2) ~until\n then\n ( pos + 3\n , read_2_digit_int string ~pos\n , match maybe_seconds with\n | `Minutes_and_maybe_seconds -> true\n | `Minutes_but_not_seconds ->\n invalid_string string ~reason:\"expected end of string after minutes\" )\n (* e.g. \"12:00\" *)\n else if pos + 2 = until\n then pos + 2, read_2_digit_int string ~pos, false\n else\n invalid_string\n string\n ~reason:\"expected colon or am/pm suffix with optional space after minutes\"\n in\n let sec, subsec_pos, subsec_len, subsec_nonzero =\n match expect_seconds with\n | false ->\n (* e.g. \"12am\" or \"12:00\" *)\n if pos = until\n then 0, pos, 0, false\n else\n (* This case is actually unreachable, based on the various ways that\n [expect_seconds] can end up false. *)\n invalid_string string ~reason:\"BUG: did not expect seconds, but found them\"\n | true ->\n (* e.g. \"12:00:00\" *)\n if pos + 2 > until\n then\n (* e.g. \"12:00:0\" *)\n invalid_string string ~reason:\"expected two digits of seconds\"\n else (\n let sec = read_2_digit_int string ~pos in\n let pos = pos + 2 in\n (* e.g. \"12:00:00\" *)\n if pos = until\n then sec, pos, 0, false (* e.g. \"12:00:00.123\" *)\n else if pos < until && char_is_decimal_point string pos\n then\n ( sec\n , pos\n , until - pos\n , check_digits_with_underscore_and_return_if_nonzero string (pos + 1) ~until )\n else\n invalid_string\n string\n ~reason:\"expected decimal point or am/pm suffix after seconds\")\n in\n let hr =\n (* NB. We already know [hr] is non-negative, because it's the result of\n [read_2_digit_int]. *)\n match am_or_pm with\n | `hr_AM ->\n (* e.g. \"12:00am\" *)\n if hr < 1 || hr > 12\n then invalid_string string ~reason:\"hours out of bounds\"\n else if hr = 12\n then 0\n else hr\n | `hr_PM ->\n (* e.g. \"12:00pm\" *)\n if hr < 1 || hr > 12\n then invalid_string string ~reason:\"hours out of bounds\"\n else if hr = 12\n then 12\n else hr + 12\n | `hr_24 ->\n (match expect_minutes_and_seconds with\n | `Neither_minutes_nor_seconds ->\n invalid_string string ~reason:\"hours without minutes or AM/PM\"\n | `Minutes_but_not_seconds | `Minutes_and_maybe_seconds ->\n if hr > 24\n then invalid_string string ~reason:\"hours out of bounds\"\n else if hr = 24 && (min > 0 || sec > 0 || subsec_nonzero)\n then invalid_string string ~reason:\"time is past 24:00:00\" (* e.g. \"13:00:00\" *)\n else hr)\n in\n let min =\n if min > 59 then invalid_string string ~reason:\"minutes out of bounds\" else min\n in\n let sec =\n if sec > 60 then invalid_string string ~reason:\"seconds out of bounds\" else sec\n in\n let subsec_len = if sec = 60 || not subsec_nonzero then 0 else subsec_len in\n f string ~hr ~min ~sec ~subsec_pos ~subsec_len\n;;\n\nlet parse_iso8601_extended ?pos ?len str ~f =\n let pos, len =\n match\n Ordered_collection_common.get_pos_len\n ()\n ?pos\n ?len\n ~total_length:(String.length str)\n with\n | Result.Ok z -> z\n | Result.Error s ->\n failwithf \"Ofday.of_string_iso8601_extended: %s\" (Error.to_string_mach s) ()\n in\n if len < 2\n then failwith \"len < 2\"\n else (\n let hr = read_2_digit_int str ~pos in\n if hr > 24 then failwith \"hour > 24\";\n if len = 2\n then f str ~hr ~min:0 ~sec:0 ~subsec_pos:(pos + len) ~subsec_len:0\n else if len < 5\n then failwith \"2 < len < 5\"\n else if not (Char.equal str.[pos + 2] ':')\n then failwith \"first colon missing\"\n else (\n let min = read_2_digit_int str ~pos:(pos + 3) in\n if min >= 60 then failwith \"minute > 60\";\n if hr = 24 && min <> 0 then failwith \"24 hours and non-zero minute\";\n if len = 5\n then f str ~hr ~min ~sec:0 ~subsec_pos:(pos + len) ~subsec_len:0\n else if len < 8\n then failwith \"5 < len < 8\"\n else if not (Char.equal str.[pos + 5] ':')\n then failwith \"second colon missing\"\n else (\n let sec = read_2_digit_int str ~pos:(pos + 6) in\n (* second can be 60 in the case of a leap second. Unfortunately, what with\n non-hour-multiple timezone offsets, we can't say anything about what\n the hour or minute must be in that case *)\n if sec > 60 then failwithf \"invalid second: %i\" sec ();\n if hr = 24 && sec <> 0 then failwith \"24 hours and non-zero seconds\";\n if len = 8\n then f str ~hr ~min ~sec ~subsec_pos:(pos + len) ~subsec_len:0\n else if len = 9\n then failwith \"length = 9\"\n else (\n match str.[pos + 8] with\n | '.' | ',' ->\n let subsec_pos = pos + 8 in\n let subsec_len =\n match\n check_digits_without_underscore_and_return_if_nonzero\n str\n (subsec_pos + 1)\n ~until:(pos + len)\n with\n | true when sec = 60 -> 0\n | true when hr = 24 -> failwith \"24 hours and non-zero subseconds\"\n | _ -> len - 8\n in\n f str ~hr ~min ~sec ~subsec_pos ~subsec_len\n | _ -> failwith \"missing subsecond separator\"))))\n;;\n","open! Import\ninclude Bin_prot.Std\ninclude Hash.Builtin\n\ninclude (\n Base :\n sig\n type nonrec 'a array = 'a array [@@deriving sexp, sexp_grammar]\n type nonrec bool = bool [@@deriving sexp, sexp_grammar]\n type nonrec char = char [@@deriving sexp, sexp_grammar]\n type nonrec exn = exn [@@deriving sexp_of]\n type nonrec float = float [@@deriving sexp, sexp_grammar]\n type nonrec int = int [@@deriving sexp, sexp_grammar]\n type nonrec int32 = int32 [@@deriving sexp, sexp_grammar]\n type nonrec int64 = int64 [@@deriving sexp, sexp_grammar]\n type nonrec 'a list = 'a list [@@deriving sexp, sexp_grammar]\n type nonrec nativeint = nativeint [@@deriving sexp, sexp_grammar]\n type nonrec 'a option = 'a option [@@deriving sexp, sexp_grammar]\n type nonrec 'a ref = 'a ref [@@deriving sexp, sexp_grammar]\n type nonrec string = string [@@deriving sexp, sexp_grammar]\n type nonrec bytes = bytes [@@deriving sexp, sexp_grammar]\n type nonrec unit = unit [@@deriving sexp, sexp_grammar]\n end\n with type 'a array := 'a array\n with type bool := bool\n with type char := char\n with type exn := exn\n with type float := float\n with type int := int\n with type int32 := int32\n with type int64 := int64\n with type 'a list := 'a list\n with type nativeint := nativeint\n with type 'a option := 'a option\n with type 'a ref := 'a ref\n with type string := string\n with type bytes := bytes\n with type unit := unit)\n\ninclude (\nstruct\n type 'a sexp_option = ('a Std_internal.sexp_option[@ocaml.warning \"-3\"])\n [@@deriving bin_io, compare, hash]\n\n type 'a sexp_list = ('a Std_internal.sexp_list[@ocaml.warning \"-3\"])\n [@@deriving bin_io, compare, hash]\nend :\nsig\n type 'a sexp_option = ('a Std_internal.sexp_option[@ocaml.warning \"-3\"])\n [@@deriving bin_io, compare, hash]\n\n type 'a sexp_list = ('a Std_internal.sexp_list[@ocaml.warning \"-3\"])\n [@@deriving bin_io, compare, hash]\nend\nwith type 'a sexp_option := ('a Std_internal.sexp_option[@ocaml.warning \"-3\"])\nwith type 'a sexp_list := ('a Std_internal.sexp_list[@ocaml.warning \"-3\"]))\n\ntype 'a sexp_option = ('a Std_internal.sexp_option[@ocaml.warning \"-3\"])\n[@@deprecated \"[since 2019-03] use [@sexp.option] instead\"]\n\ntype 'a sexp_list = ('a Std_internal.sexp_list[@ocaml.warning \"-3\"])\n[@@deprecated \"[since 2019-03] use [@sexp.list] instead\"]\n","open Ppx_compare_lib.Builtin\n\nmodule Stable = struct\n open Stable_internal\n module Binable = Binable.Stable\n\n module V1 = struct\n exception Nan_or_inf [@@deriving sexp]\n\n type t = float [@@deriving compare, hash]\n\n let verify t =\n match Caml.classify_float t with\n | FP_normal | FP_subnormal | FP_zero -> ()\n | FP_infinite | FP_nan -> raise Nan_or_inf\n ;;\n\n include Binable.Of_binable.V1 [@alert \"-legacy\"]\n (Float)\n (struct\n type nonrec t = t\n\n let of_binable t =\n verify t;\n t\n ;;\n\n let to_binable t =\n verify t;\n t\n ;;\n end)\n\n let sexp_of_t = Float.sexp_of_t\n\n let t_of_sexp = function\n | Sexp.Atom _ as sexp ->\n let t = Float.t_of_sexp sexp in\n (try verify t with\n | e -> Import.of_sexp_error (Import.Exn.to_string e) sexp);\n t\n | s -> Import.of_sexp_error \"Decimal.t_of_sexp: Expected Atom, found List\" s\n ;;\n end\nend\n\ninclude Stable.V1\n","open Async_kernel\nopen Core_kernel\n\nmodule type Time_intf = sig\n type t\n\n module Span : sig\n type t\n\n val to_time_ns_span : t -> Time_ns.Span.t\n\n val ( - ) : t -> t -> t\n end\n\n module Controller : sig\n type t\n end\n\n val now : Controller.t -> t\n\n val diff : t -> t -> Span.t\nend\n\nmodule Timeout_intf (Time : Time_intf) = struct\n module type S = sig\n type 'a t\n\n val create : Time.Controller.t -> Time.Span.t -> f:(Time.t -> 'a) -> 'a t\n\n val to_deferred : 'a t -> 'a Async_kernel.Deferred.t\n\n val peek : 'a t -> 'a option\n\n val cancel : Time.Controller.t -> 'a t -> 'a -> unit\n\n val remaining_time : 'a t -> Time.Span.t\n\n val await :\n timeout_duration:Time.Span.t\n -> Time.Controller.t\n -> 'a Deferred.t\n -> [ `Ok of 'a | `Timeout ] Deferred.t\n\n val await_exn :\n timeout_duration:Time.Span.t\n -> Time.Controller.t\n -> 'a Deferred.t\n -> 'a Deferred.t\n end\nend\n\nmodule Make (Time : Time_intf) : Timeout_intf(Time).S = struct\n type 'a t =\n { deferred : 'a Deferred.t\n ; cancel : 'a -> unit\n ; start_time : Time.t\n ; span : Time.Span.t\n ; ctrl : Time.Controller.t\n }\n\n let create ctrl span ~f:action =\n let open Deferred.Let_syntax in\n let cancel_ivar = Ivar.create () in\n let timeout = after (Time.Span.to_time_ns_span span) >>| fun () -> None in\n let deferred =\n Deferred.any [ Ivar.read cancel_ivar; timeout ]\n >>| function None -> action (Time.now ctrl) | Some x -> x\n in\n let cancel value = Ivar.fill_if_empty cancel_ivar (Some value) in\n { ctrl; deferred; cancel; start_time = Time.now ctrl; span }\n\n let to_deferred { deferred; _ } = deferred\n\n let peek { deferred; _ } = Deferred.peek deferred\n\n let cancel _ { cancel; _ } value = cancel value\n\n let remaining_time { ctrl : _; start_time; span; _ } =\n let current_time = Time.now ctrl in\n let time_elapsed = Time.diff current_time start_time in\n Time.Span.(span - time_elapsed)\n\n let await ~timeout_duration time_controller deferred =\n let timeout =\n Deferred.create (fun ivar ->\n ignore\n ( create time_controller timeout_duration ~f:(fun x ->\n if Ivar.is_full ivar then\n [%log' error (Logger.create ())] \"Ivar.fill bug is here!\" ;\n Ivar.fill_if_empty ivar x )\n : unit t ) )\n in\n Deferred.(\n choose\n [ choice deferred (fun x -> `Ok x); choice timeout (Fn.const `Timeout) ])\n\n let await_exn ~timeout_duration time_controller deferred =\n match%map await ~timeout_duration time_controller deferred with\n | `Timeout ->\n failwith \"timeout\"\n | `Ok x ->\n x\nend\n\nmodule Core_time = Make (struct\n include (\n Core_kernel.Time :\n module type of Core_kernel.Time\n with module Span := Core_kernel.Time.Span\n and type underlying = float )\n\n module Controller = struct\n type t = unit\n end\n\n module Span = struct\n include Core_kernel.Time.Span\n\n let to_time_ns_span = Fn.compose Core_kernel.Time_ns.Span.of_ns to_ns\n end\n\n let diff x y =\n let x_ns = Span.to_ns @@ to_span_since_epoch x in\n let y_ns = Span.to_ms @@ to_span_since_epoch y in\n Span.of_ns (x_ns -. y_ns)\nend)\n\nmodule Core_time_ns = Make (struct\n include (\n Core_kernel.Time_ns :\n module type of Core_kernel.Time_ns\n with module Span := Core_kernel.Time_ns.Span )\n\n module Controller = struct\n type t = unit\n end\n\n module Span = struct\n include Core_kernel.Time_ns.Span\n\n let to_time_ns_span = Fn.id\n end\n\n let diff x y =\n let x_ns = Span.to_ns @@ to_span_since_epoch x in\n let y_ns = Span.to_ms @@ to_span_since_epoch y in\n Span.of_ns (x_ns -. y_ns)\nend)\n","open! Import\nopen! Std_internal\nmodule Date = Date0\n\nmodule type Zone = sig\n module Time : Time0_intf.S\n include Zone.S with type t = Zone.t and module Time_in_seconds := Time\n\n (** [abbreviation t time] returns the abbreviation name (such as EDT, EST, JST) of given\n zone [t] at [time]. This string conversion is one-way only, and cannot reliably be\n turned back into a [t]. This function reads and writes the zone's cached index. *)\n val abbreviation : t -> Time.t -> string\n\n (** [absolute_time_of_date_and_ofday] and [date_and_ofday_of_absolute_time] convert\n between absolute times and date + ofday forms. These are low level functions not\n intended for most clients. These functions read and write the zone's cached index.\n *)\n val absolute_time_of_date_and_ofday : t -> Time.Date_and_ofday.t -> Time.t\n\n val date_and_ofday_of_absolute_time : t -> Time.t -> Time.Date_and_ofday.t\n\n (** Takes a [Time.t] and returns the next [Time.t] strictly after it, if any, that the\n time zone UTC offset changes, and by how much it does so. *)\n val next_clock_shift : t -> strictly_after:Time.t -> (Time.t * Time.Span.t) option\n\n (** As [next_clock_shift], but *at or before* the given time. *)\n val prev_clock_shift : t -> at_or_before:Time.t -> (Time.t * Time.Span.t) option\nend\n\nmodule type Basic = sig\n module Time : Time0_intf.S\n\n (*_ necessary to preserve type equality with the Time functor argument *)\n\n include module type of struct\n include Time\n end\n [@ocaml.remove_aliases]\n\n (** [now ()] returns a [t] representing the current time *)\n val now : unit -> t\n\n module Zone : Zone with module Time := Time\n\n (** {6 Basic operations on times} *)\n\n (** [add t s] adds the span [s] to time [t] and returns the resulting time.\n\n NOTE: adding spans as a means of adding days is not accurate, and may run into trouble\n due to shifts in daylight savings time, float arithmetic issues, and leap seconds.\n See the comment at the top of Zone.mli for a more complete discussion of some of\n the issues of time-keeping. For spans that cross date boundaries, use date functions\n instead.\n *)\n val add : t -> Span.t -> t\n\n (** [sub t s] subtracts the span [s] from time [t] and returns the\n resulting time. See important note for [add]. *)\n val sub : t -> Span.t -> t\n\n (** [diff t1 t2] returns time [t1] minus time [t2]. *)\n val diff : t -> t -> Span.t\n\n (** [abs_diff t1 t2] returns the absolute span of time [t1] minus time [t2]. *)\n val abs_diff : t -> t -> Span.t\nend\n\nmodule type Shared = sig\n type t\n\n include Quickcheck.S_range with type t := t\n\n module Span : sig\n type t\n end\n\n module Ofday : sig\n type t\n end\n\n (** {6 Comparisons} *)\n\n val is_earlier : t -> than:t -> bool\n val is_later : t -> than:t -> bool\n\n (** {6 Conversions} *)\n\n val of_date_ofday : zone:Zone.t -> Date.t -> Ofday.t -> t\n\n (** Because timezone offsets change throughout the year (clocks go forward or back) some\n local times can occur twice or not at all. In the case that they occur twice, this\n function gives [`Twice] with both occurrences in order; if they do not occur at all,\n this function gives [`Never] with the time at which the local clock skips over the\n desired time of day.\n\n Note that this is really only intended to work with DST transitions and not unusual or\n dramatic changes, like the calendar change in 1752 (run \"cal 9 1752\" in a shell to\n see). In particular it makes the assumption that midnight of each day is unambiguous.\n\n Most callers should use {!of_date_ofday} rather than this function. In the [`Twice]\n and [`Never] cases, {!of_date_ofday} will return reasonable times for most uses. *)\n val of_date_ofday_precise\n : Date.t\n -> Ofday.t\n -> zone:Zone.t\n -> [ `Once of t | `Twice of t * t | `Never of t ]\n\n val to_date_ofday : t -> zone:Zone.t -> Date.t * Ofday.t\n\n (** Always returns the [Date.t * Ofday.t] that [to_date_ofday] would have returned, and in\n addition returns a variant indicating whether the time is associated with a time zone\n transition.\n\n {v\n - `Only -> there is a one-to-one mapping between [t]'s and\n [Date.t * Ofday.t] pairs\n - `Also_at -> there is another [t] that maps to the same [Date.t * Ofday.t]\n (this date/time pair happened twice because the clock fell back)\n - `Also_skipped -> there is another [Date.t * Ofday.t] pair that never happened (due\n to a jump forward) that [of_date_ofday] would map to the same\n [t].\n v}\n *)\n val to_date_ofday_precise\n : t\n -> zone:Zone.t\n -> Date.t * Ofday.t * [ `Only | `Also_at of t | `Also_skipped of Date.t * Ofday.t ]\n\n val to_date : t -> zone:Zone.t -> Date.t\n val to_ofday : t -> zone:Zone.t -> Ofday.t\n\n (** For performance testing only; [reset_date_cache ()] resets an internal cache used to\n speed up [to_date] and related functions when called repeatedly on times that fall\n within the same day. *)\n val reset_date_cache : unit -> unit\n\n (** Unlike [Time_ns], this module purposely omits [max_value] and [min_value]:\n 1. They produce unintuitive corner cases because most people's mental models of time\n do not include +/- infinity as concrete values\n 2. In practice, when people ask for these values, it is for questionable uses, e.g.,\n as null values to use in place of explicit options. *)\n\n (** midnight, Jan 1, 1970 in UTC *)\n val epoch : t\n\n (** It's unspecified what happens if the given date/ofday/zone correspond to more than\n one date/ofday pair in the other zone. *)\n val convert : from_tz:Zone.t -> to_tz:Zone.t -> Date.t -> Ofday.t -> Date.t * Ofday.t\n\n val utc_offset : t -> zone:Zone.t -> Span.t\n\n (** {6 Other string conversions} *)\n\n (** The [{to,of}_string] functions in [Time] convert to UTC time, because a local time\n zone is not necessarily available. They are generous in what they will read in. *)\n include\n Stringable with type t := t\n\n (** [to_filename_string t ~zone] converts [t] to string with format\n YYYY-MM-DD_HH-MM-SS.mmm which is suitable for using in filenames. *)\n val to_filename_string : t -> zone:Zone.t -> string\n\n (** [of_filename_string s ~zone] converts [s] that has format YYYY-MM-DD_HH-MM-SS.mmm into\n time. *)\n val of_filename_string : string -> zone:Zone.t -> t\n\n (** [to_string_abs ~zone t] is the same as [to_string t] except that it uses the given\n time zone. *)\n val to_string_abs : t -> zone:Zone.t -> string\n\n (** [to_string_abs_trimmed] is the same as [to_string_abs], but drops trailing seconds\n and milliseconds if they are 0. *)\n val to_string_abs_trimmed : t -> zone:Zone.t -> string\n\n val to_string_abs_parts : t -> zone:Zone.t -> string list\n\n (** Same as [to_string_abs_trimmed], except it leaves off the timezone, so won't\n reliably round trip. *)\n val to_string_trimmed : t -> zone:Zone.t -> string\n\n (** Same as [to_string_abs], but without milliseconds *)\n val to_sec_string : t -> zone:Zone.t -> string\n\n (** [of_localized_string ~zone str] read in the given string assuming that it represents\n a time in zone and return the appropriate Time.t *)\n val of_localized_string : zone:Zone.t -> string -> t\n\n (** [of_string_gen ~default_zone ~find_zone s] attempts to parse [s] as a [t], calling\n out to [default_zone] and [find_zone] as needed. *)\n val of_string_gen\n : default_zone:(unit -> Zone.t)\n -> find_zone:(string -> Zone.t)\n -> string\n -> t\n\n (** [to_string_iso8601_basic] return a string representation of the following form:\n %Y-%m-%dT%H:%M:%S.%s%Z\n e.g.\n [ to_string_iso8601_basic ~zone:Time.Zone.utc epoch = \"1970-01-01T00:00:00.000000Z\" ]\n *)\n val to_string_iso8601_basic : t -> zone:Zone.t -> string\n\n (** [occurrence side time ~ofday ~zone] returns a [Time.t] that is the occurrence of\n ofday (in the given [zone]) that is the latest occurrence (<=) [time] or the\n earliest occurrence (>=) [time], according to [side].\n\n NOTE: If the given time converted to wall clock time in the given zone is equal to\n ofday then the t returned will be equal to the t given.\n *)\n val occurrence\n : [ `First_after_or_at | `Last_before_or_at ]\n -> t\n -> ofday:Ofday.t\n -> zone:Zone.t\n -> t\nend\n\nmodule type S = sig\n include Basic\n include Shared with type t := t with module Span := Span with module Ofday := Ofday\nend\n\nmodule type Time = sig\n module type S = S\n\n module Make (Time : Time0_intf.S) : S with module Time := Time\nend\n","(* See Time_float.ml for the primary instantiation of this functor that is visible outside\n of Core_kernel as Time (see core_kernel.ml and std.ml). *)\nopen! Import\nopen Std_internal\nopen! Int.Replace_polymorphic_compare\ninclude Time_intf\nmodule Zone0 = Zone\n\nmodule Make (Time0 : Time0_intf.S) = struct\n module Time0 = Time0\n include Time0\n\n let epoch = of_span_since_epoch Span.zero\n let is_earlier t1 ~than:t2 = t1 <. t2\n let is_later t1 ~than:t2 = t1 >. t2\n\n module Zone : sig\n include Time_intf.Zone with module Time := Time0\n end = struct\n include Zone\n\n let of_span_in_seconds span_in_seconds =\n (* NB. no actual rounding or exns can occur here *)\n Time_in_seconds.Span.to_int63_seconds_round_down_exn span_in_seconds\n |> Time0.Span.of_int63_seconds\n ;;\n\n let of_time_in_seconds time_in_seconds =\n Time_in_seconds.to_span_since_epoch time_in_seconds\n (* NB. no actual rounding or exns can occur here *)\n |> Time_in_seconds.Span.to_int63_seconds_round_down_exn\n |> Time0.Span.of_int63_seconds\n |> Time0.of_span_since_epoch\n ;;\n\n let to_time_in_seconds_round_down_exn time =\n Time0.to_span_since_epoch time\n |> Time0.Span.to_int63_seconds_round_down_exn\n |> Time_in_seconds.Span.of_int63_seconds\n |> Time_in_seconds.of_span_since_epoch\n ;;\n\n let to_date_and_ofday_in_seconds_round_down_exn relative =\n Time0.Date_and_ofday.to_synthetic_span_since_epoch relative\n |> Time0.Span.to_int63_seconds_round_down_exn\n |> Time_in_seconds.Span.of_int63_seconds\n |> Time_in_seconds.Date_and_ofday.of_synthetic_span_since_epoch\n ;;\n\n let index t time = index t (to_time_in_seconds_round_down_exn time)\n\n let index_of_date_and_ofday t relative =\n index_of_date_and_ofday t (to_date_and_ofday_in_seconds_round_down_exn relative)\n ;;\n\n let index_offset_from_utc_exn t index =\n of_span_in_seconds (index_offset_from_utc_exn t index)\n ;;\n\n let index_prev_clock_shift_time_exn t index =\n of_time_in_seconds (index_prev_clock_shift_time_exn t index)\n ;;\n\n let index_next_clock_shift_time_exn t index =\n of_time_in_seconds (index_next_clock_shift_time_exn t index)\n ;;\n\n let index_prev_clock_shift_amount_exn t index =\n of_span_in_seconds (index_prev_clock_shift_amount_exn t index)\n ;;\n\n let index_next_clock_shift_amount_exn t index =\n of_span_in_seconds (index_next_clock_shift_amount_exn t index)\n ;;\n\n let abbreviation t time =\n (* no exn because [index] always returns a valid index *)\n index_abbreviation_exn t (index t time)\n ;;\n\n let index_prev_clock_shift t index =\n match index_has_prev_clock_shift t index with\n | false -> None\n | true ->\n Some\n ( index_prev_clock_shift_time_exn t index\n , index_prev_clock_shift_amount_exn t index )\n ;;\n\n let index_next_clock_shift t index = index_prev_clock_shift t (Index.next index)\n let prev_clock_shift t ~at_or_before:time = index_prev_clock_shift t (index t time)\n let next_clock_shift t ~strictly_after:time = index_next_clock_shift t (index t time)\n\n let date_and_ofday_of_absolute_time t time =\n let index = index t time in\n (* no exn because [index] always returns a valid index *)\n let offset_from_utc = index_offset_from_utc_exn t index in\n Time0.Date_and_ofday.of_absolute time ~offset_from_utc\n ;;\n\n let absolute_time_of_date_and_ofday t relative =\n let index = index_of_date_and_ofday t relative in\n (* no exn because [index_of_date_and_ofday] always returns a valid index *)\n let offset_from_utc = index_offset_from_utc_exn t index in\n Time0.Date_and_ofday.to_absolute relative ~offset_from_utc\n ;;\n end\n\n let abs_diff t1 t2 = Span.abs (diff t1 t2)\n\n let of_date_ofday ~zone date ofday =\n let relative = Date_and_ofday.of_date_ofday date ofday in\n Zone.absolute_time_of_date_and_ofday zone relative\n ;;\n\n let of_date_ofday_precise date ofday ~zone =\n (* We assume that there will be only one zone shift within a given local day. *)\n let start_of_day = of_date_ofday ~zone date Ofday.start_of_day in\n let proposed_time = add start_of_day (Ofday.to_span_since_start_of_day ofday) in\n match Zone.next_clock_shift zone ~strictly_after:start_of_day with\n | None -> `Once proposed_time\n | Some (shift_start, shift_amount) ->\n let shift_backwards = Span.(shift_amount < zero) in\n (* start and end of the \"problematic region\" *)\n let s, e =\n if shift_backwards\n then add shift_start shift_amount, shift_start\n else shift_start, add shift_start shift_amount\n in\n if proposed_time < s\n then `Once proposed_time\n else if s <= proposed_time && proposed_time < e\n then\n if shift_backwards\n then `Twice (proposed_time, sub proposed_time shift_amount)\n else `Never shift_start\n else `Once (sub proposed_time shift_amount)\n ;;\n\n module Date_cache = struct\n type t =\n { mutable zone : Zone.t\n ; mutable cache_start_incl : Time0.t\n ; mutable cache_until_excl : Time0.t\n ; mutable effective_day_start : Time0.t\n ; mutable date : Date0.t\n }\n end\n\n let date_cache : Date_cache.t =\n { zone = Zone.utc\n ; cache_start_incl = epoch\n ; cache_until_excl = epoch\n ; effective_day_start = epoch\n ; date = Date0.unix_epoch\n }\n ;;\n\n let reset_date_cache () =\n date_cache.zone <- Zone.utc;\n date_cache.cache_start_incl <- epoch;\n date_cache.cache_until_excl <- epoch;\n date_cache.effective_day_start <- epoch;\n date_cache.date <- Date0.unix_epoch\n ;;\n\n let is_in_cache time ~zone =\n phys_equal zone date_cache.zone\n && Time0.( >= ) time date_cache.cache_start_incl\n && Time0.( < ) time date_cache.cache_until_excl\n ;;\n\n let set_date_cache time ~zone =\n match is_in_cache time ~zone with\n | true -> ()\n | false ->\n let index = Zone.index zone time in\n (* no exn because [Zone.index] always returns a valid index *)\n let offset_from_utc = Zone.index_offset_from_utc_exn zone index in\n let rel = Date_and_ofday.of_absolute time ~offset_from_utc in\n let date = Date_and_ofday.to_date rel in\n let span = Date_and_ofday.to_ofday rel |> Ofday.to_span_since_start_of_day in\n let effective_day_start =\n Time0.sub (Date_and_ofday.to_absolute rel ~offset_from_utc) span\n in\n let effective_day_until = Time0.add effective_day_start Span.day in\n let cache_start_incl =\n match Zone.index_has_prev_clock_shift zone index with\n | false -> effective_day_start\n | true ->\n effective_day_start\n |> Time0.max (Zone.index_prev_clock_shift_time_exn zone index)\n in\n let cache_until_excl =\n match Zone.index_has_next_clock_shift zone index with\n | false -> effective_day_until\n | true ->\n effective_day_until\n |> Time0.min (Zone.index_next_clock_shift_time_exn zone index)\n in\n date_cache.zone <- zone;\n date_cache.cache_start_incl <- cache_start_incl;\n date_cache.cache_until_excl <- cache_until_excl;\n date_cache.effective_day_start <- effective_day_start;\n date_cache.date <- date\n ;;\n\n let to_date time ~zone =\n set_date_cache time ~zone;\n date_cache.date\n ;;\n\n let to_ofday time ~zone =\n set_date_cache time ~zone;\n Time0.diff time date_cache.effective_day_start\n |> Ofday.of_span_since_start_of_day_exn\n ;;\n\n let to_date_ofday time ~zone = to_date time ~zone, to_ofday time ~zone\n\n (* The correctness of this algorithm (interface, even) depends on the fact that\n timezone shifts aren't too close together (as in, it can't simultaneously be the\n case that a timezone shift of X hours occurred less than X hours ago, *and*\n a timezone shift of Y hours will occur in less than Y hours' time) *)\n let to_date_ofday_precise time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let clock_shift_after = Zone.next_clock_shift zone ~strictly_after:time in\n let clock_shift_before_or_at = Zone.prev_clock_shift zone ~at_or_before:time in\n let also_skipped_earlier amount =\n (* Using [date] and raising on [None] here is OK on the assumption that clock\n shifts can't cross date boundaries. This is true in all cases I've ever heard\n of (and [of_date_ofday_precise] would need revisiting if it turned out to be\n false) *)\n match Ofday.sub ofday amount with\n | Some ofday -> `Also_skipped (date, ofday)\n | None ->\n raise_s\n [%message\n \"Time.to_date_ofday_precise\"\n ~span_since_epoch:(to_span_since_epoch time : Span.t)\n (zone : Zone.t)]\n in\n let ambiguity =\n (* Edge cases: the instant of transition belongs to the new zone regime. So if the\n clock moved by an hour exactly one hour ago, there's no ambiguity, because the\n hour-ago time belongs to the same regime as you, and conversely, if the clock\n will move by an hour in an hours' time, there *is* ambiguity. Hence [>.] for\n the first case and [<=.] for the second. *)\n match clock_shift_before_or_at, clock_shift_after with\n | Some (start, amount), _ when add start (Span.abs amount) >. time ->\n (* clock shifted recently *)\n if Span.(amount > zero)\n then\n (* clock shifted forward recently: we skipped a time *)\n also_skipped_earlier amount\n else (\n (* clock shifted back recently: this date/ofday already happened *)\n assert (Span.(amount < zero));\n `Also_at (sub time (Span.abs amount)))\n | _, Some (start, amount) when sub start (Span.abs amount) <=. time ->\n (* clock is about to shift *)\n if Span.(amount > zero)\n then (* clock about to shift forward: no effect *)\n `Only\n else (\n (* clock about to shift back: this date/ofday will be repeated *)\n assert (Span.(amount < zero));\n `Also_at (add time (Span.abs amount)))\n | _ -> `Only\n in\n date, ofday, ambiguity\n ;;\n\n let convert ~from_tz ~to_tz date ofday =\n let start_time = of_date_ofday ~zone:from_tz date ofday in\n to_date_ofday ~zone:to_tz start_time\n ;;\n\n let utc_offset t ~zone =\n let utc_epoch = Zone.date_and_ofday_of_absolute_time zone t in\n Span.( - )\n (Date_and_ofday.to_synthetic_span_since_epoch utc_epoch)\n (to_span_since_epoch t)\n ;;\n\n let offset_string time ~zone =\n let utc_offset = utc_offset time ~zone in\n let is_utc = Span.( = ) utc_offset Span.zero in\n if is_utc\n then \"Z\"\n else\n String.concat\n [ (if Span.( < ) utc_offset Span.zero then \"-\" else \"+\")\n ; Ofday.to_string_trimmed\n (Ofday.of_span_since_start_of_day_exn (Span.abs utc_offset))\n ]\n ;;\n\n let to_string_abs_parts time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let offset_string = offset_string time ~zone in\n [ Date0.to_string date\n ; String.concat ~sep:\"\" [ Ofday.to_string ofday; offset_string ]\n ]\n ;;\n\n let to_string_abs_trimmed time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let offset_string = offset_string time ~zone in\n String.concat\n ~sep:\" \"\n [ Date0.to_string date; Ofday.to_string_trimmed ofday ^ offset_string ]\n ;;\n\n let to_string_abs time ~zone = String.concat ~sep:\" \" (to_string_abs_parts ~zone time)\n let to_string t = to_string_abs t ~zone:Zone.utc\n\n let to_string_iso8601_basic time ~zone =\n String.concat ~sep:\"T\" (to_string_abs_parts ~zone time)\n ;;\n\n let to_string_trimmed t ~zone =\n let date, sec = to_date_ofday ~zone t in\n Date0.to_string date ^ \" \" ^ Ofday.to_string_trimmed sec\n ;;\n\n let to_sec_string t ~zone =\n let date, sec = to_date_ofday ~zone t in\n Date0.to_string date ^ \" \" ^ Ofday.to_sec_string sec\n ;;\n\n let to_filename_string t ~zone =\n let date, ofday = to_date_ofday ~zone t in\n Date0.to_string date\n ^ \"_\"\n ^ String.tr ~target:':' ~replacement:'-' (Ofday.to_string ofday)\n ;;\n\n let of_filename_string s ~zone =\n try\n match String.lsplit2 s ~on:'_' with\n | None -> failwith \"no space in filename string\"\n | Some (date, ofday) ->\n let date = Date0.of_string date in\n let ofday = String.tr ~target:'-' ~replacement:':' ofday in\n let ofday = Ofday.of_string ofday in\n of_date_ofday date ofday ~zone\n with\n | exn -> invalid_argf \"Time.of_filename_string (%s): %s\" s (Exn.to_string exn) ()\n ;;\n\n let of_localized_string ~zone str =\n try\n match String.lsplit2 str ~on:' ' with\n | None -> invalid_arg (sprintf \"no space in date_ofday string: %s\" str)\n | Some (date, time) ->\n let date = Date0.of_string date in\n let ofday = Ofday.of_string time in\n of_date_ofday ~zone date ofday\n with\n | e -> Exn.reraise e \"Time.of_localized_string\"\n ;;\n\n let occurrence before_or_after t ~ofday ~zone =\n let first_guess_date = to_date t ~zone in\n let first_guess = of_date_ofday ~zone first_guess_date ofday in\n let cmp, increment =\n match before_or_after with\n | `Last_before_or_at -> ( <= ), -1\n | `First_after_or_at -> ( >= ), 1\n in\n if cmp first_guess t\n then first_guess\n else of_date_ofday ~zone (Date0.add_days first_guess_date increment) ofday\n ;;\n\n let ensure_colon_in_offset offset =\n let offset_length = String.length offset in\n if Int.( <= ) offset_length 2\n && Char.is_digit offset.[0]\n && Char.is_digit offset.[offset_length - 1]\n then offset ^ \":00\"\n else if Char.( = ) offset.[1] ':' || Char.( = ) offset.[2] ':'\n then offset\n else if Int.( < ) offset_length 3 || Int.( > ) offset_length 4\n then failwithf \"invalid offset %s\" offset ()\n else\n String.concat\n [ String.slice offset 0 (offset_length - 2)\n ; \":\"\n ; String.slice offset (offset_length - 2) offset_length\n ]\n ;;\n\n exception Time_of_string of string * Exn.t [@@deriving sexp]\n\n let of_string_gen ~default_zone ~find_zone s =\n try\n let date, ofday, tz =\n match String.split s ~on:' ' with\n | [ day; month; year; ofday ] ->\n String.concat [ day; \" \"; month; \" \"; year ], ofday, None\n | [ date; ofday; tz ] -> date, ofday, Some tz\n | [ date; ofday ] -> date, ofday, None\n | [ s ] ->\n (match String.rsplit2 ~on:'T' s with\n | Some (date, ofday) -> date, ofday, None\n | None -> failwith \"no spaces or T found\")\n | _ -> failwith \"too many spaces\"\n in\n let ofday_to_sec od = Span.to_sec (Ofday.to_span_since_start_of_day od) in\n let ofday, utc_offset =\n match tz with\n | Some _ -> ofday, None\n | None ->\n if Char.( = ) ofday.[String.length ofday - 1] 'Z'\n then String.sub ofday ~pos:0 ~len:(String.length ofday - 1), Some 0.\n else (\n match String.lsplit2 ~on:'+' ofday with\n | Some (l, r) ->\n l, Some (ofday_to_sec (Ofday.of_string (ensure_colon_in_offset r)))\n | None ->\n (match String.lsplit2 ~on:'-' ofday with\n | Some (l, r) ->\n l, Some (-1. *. ofday_to_sec (Ofday.of_string (ensure_colon_in_offset r)))\n | None -> ofday, None))\n in\n let date = Date0.of_string date in\n let ofday = Ofday.of_string ofday in\n match tz with\n | Some tz -> of_date_ofday ~zone:(find_zone tz) date ofday\n | None ->\n (match utc_offset with\n | None ->\n let zone = default_zone () in\n of_date_ofday ~zone date ofday\n | Some utc_offset ->\n let utc_t = of_date_ofday ~zone:Zone.utc date ofday in\n sub utc_t (Span.of_sec utc_offset))\n with\n | e -> raise (Time_of_string (s, e))\n ;;\n\n let of_string s =\n let default_zone () = raise_s [%message \"time has no time zone or UTC offset\" s] in\n let find_zone zone_name =\n failwithf \"unable to lookup Zone %s. Try using Core.Time.of_string\" zone_name ()\n in\n of_string_gen ~default_zone ~find_zone s\n ;;\n\n let quickcheck_shrinker =\n Quickcheck.Shrinker.map\n Span.quickcheck_shrinker\n ~f:of_span_since_epoch\n ~f_inverse:to_span_since_epoch\n ;;\n\n let quickcheck_observer =\n Quickcheck.Observer.unmap Span.quickcheck_observer ~f:to_span_since_epoch\n ;;\n\n let quickcheck_generator =\n Quickcheck.Generator.map Span.quickcheck_generator ~f:of_span_since_epoch\n ;;\n\n let gen_incl lo hi =\n Span.gen_incl (to_span_since_epoch lo) (to_span_since_epoch hi)\n |> Quickcheck.Generator.map ~f:of_span_since_epoch\n ;;\n\n let gen_uniform_incl lo hi =\n Span.gen_uniform_incl (to_span_since_epoch lo) (to_span_since_epoch hi)\n |> Quickcheck.Generator.map ~f:of_span_since_epoch\n ;;\nend\n","open! Import\nopen Std_internal\nopen! Int.Replace_polymorphic_compare\nmodule Span = Span_float\nmodule Ofday = Ofday_float\n\nmodule Absolute = struct\n type underlying = Float.t\n\n include (\n Float :\n sig\n type t = float [@@deriving bin_io, hash, typerep]\n\n include Comparable.S_common with type t := t\n\n include module type of struct\n include Float.O\n end\n end)\n\n (* due to precision limitations in float we can't expect better than microsecond\n precision *)\n include Float.Robust_compare.Make (struct\n let robust_comparison_tolerance = 1E-6\n end)\n\n let diff t1 t2 = Span.of_sec (t1 - t2)\n let add t span = t +. Span.to_sec span\n let sub t span = t -. Span.to_sec span\n let prev t = Float.one_ulp `Down t\n let next t = Float.one_ulp `Up t\n let to_span_since_epoch = Span.of_sec\n let of_span_since_epoch = Span.to_sec\nend\n\ninclude Absolute\n\nmodule Date_and_ofday = struct\n type t = float\n\n let of_synthetic_span_since_epoch span = Span.to_sec span\n let to_synthetic_span_since_epoch t = Span.of_sec t\n\n let of_date_ofday date ofday =\n let days =\n Float.of_int (Date0.Days.diff (Date0.Days.of_date date) Date0.Days.unix_epoch)\n in\n (days *. 86400.) +. Span.to_sec (Ofday.to_span_since_start_of_day ofday)\n ;;\n\n let to_absolute relative ~offset_from_utc = sub relative offset_from_utc\n let of_absolute absolute ~offset_from_utc = add absolute offset_from_utc\n\n (* Years out of range for [Date.create_exn]. *)\n let[@cold] assert_in_bounds ~sec_since_epoch =\n (* $ TZ=UTC date --date=@-62167219200\n Sat Jan 1 00:00:00 UTC 0000 *)\n let gmtime_lower_bound = -62_167_219_200. in\n (* $ TZ=UTC date --date=@253402300799\n Fri Dec 31 23:59:59 UTC 9999 *)\n let gmtime_upper_bound = 253_402_300_799. in\n if Float.( >= ) sec_since_epoch (gmtime_upper_bound +. 1.)\n || Float.( < ) sec_since_epoch gmtime_lower_bound\n then failwithf \"Time.gmtime: out of range (%f)\" sec_since_epoch ()\n ;;\n\n let sec_per_day = Int63.of_int 86_400\n\n let to_days_from_epoch t =\n assert_in_bounds ~sec_since_epoch:t;\n let open Int63.O in\n let days_from_epoch_approx = Int63.of_float t / sec_per_day in\n (* when [t] is negative the integer division that calculated days_from_epoch_approx\n will leave us one day short because it truncates (e.g. -100 / 86_400 = 0 and we\n want -1) -- adjust for that here. *)\n if Float.( < ) t (Int63.to_float (days_from_epoch_approx * sec_per_day))\n then Int63.pred days_from_epoch_approx\n else days_from_epoch_approx\n ;;\n\n let ofday_of_days_from_epoch t ~days_from_epoch =\n let open Int63.O in\n let days_from_epoch_in_sec = Int63.to_float (days_from_epoch * sec_per_day) in\n let remainder = t -. days_from_epoch_in_sec in\n Span.of_sec remainder |> Ofday.of_span_since_start_of_day_exn\n ;;\n\n let date_of_days_from_epoch ~days_from_epoch =\n Int63.to_int_exn days_from_epoch\n |> Date0.Days.add_days Date0.Days.unix_epoch\n |> Date0.Days.to_date\n ;;\n\n let to_date t =\n let days_from_epoch = to_days_from_epoch t in\n date_of_days_from_epoch ~days_from_epoch\n ;;\n\n let to_ofday t =\n let days_from_epoch = to_days_from_epoch t in\n ofday_of_days_from_epoch t ~days_from_epoch\n ;;\n\n let to_date_ofday t =\n let days_from_epoch = to_days_from_epoch t in\n let date = date_of_days_from_epoch ~days_from_epoch in\n let ofday = ofday_of_days_from_epoch t ~days_from_epoch in\n date, ofday\n ;;\nend\n\nlet next_multiple_internal ~can_equal_after ~base ~after ~interval =\n if Span.( <= ) interval Span.zero\n then\n failwiths\n ~here:[%here]\n \"Time.next_multiple got nonpositive interval\"\n interval\n [%sexp_of: Span.t];\n let base_to_after = diff after base in\n if Span.( < ) base_to_after Span.zero\n then base (* [after < base], choose [k = 0]. *)\n else (\n let next =\n add\n base\n (Span.scale\n interval\n (Float.round ~dir:`Down (Span.( // ) base_to_after interval)))\n in\n if next > after || (can_equal_after && next = after) then next else add next interval)\n;;\n\nlet next_multiple ?(can_equal_after = false) ~base ~after ~interval () =\n next_multiple_internal ~can_equal_after ~base ~after ~interval\n;;\n\nlet prev_multiple ?(can_equal_before = false) ~base ~before ~interval () =\n next_multiple_internal\n ~can_equal_after:(not can_equal_before)\n ~base\n ~after:(sub before interval)\n ~interval\n;;\n\nlet now () =\n let float_ns = Time_now.nanoseconds_since_unix_epoch () |> Int63.to_float in\n of_span_since_epoch (Span.of_sec (float_ns *. 1E-9))\n;;\n\nmodule Stable = struct\n module Span = Span.Stable\n module Ofday = Ofday.Stable\nend\n","open! Import\nopen! Std_internal\n\nmodule type S_kernel_without_zone = Time0_intf.S\nmodule type S_kernel = Time_intf.S\n\nmodule Zone_stable = Zone.Stable\ninclude Time.Make (Time_float0)\ninclude Time_float0\n\nmodule Stable = struct\n include Time_float0.Stable\n\n module With_utc_sexp = struct\n (* V2 is actually the first version of this in Core_kernel, but a V1 stable module\n with generous parsing, unix-dependent [t_of_sexp] already existed in Core *)\n module V2 = struct\n type nonrec t = t [@@deriving bin_io, compare, hash]\n\n let sexp_of_t t = [%sexp (to_string_abs_parts t ~zone:Zone.utc : string list)]\n\n let t_of_sexp sexp =\n try\n match sexp with\n | Sexp.List [ Sexp.Atom date; Sexp.Atom ofday_and_possibly_zone ] ->\n of_string_gen\n ~default_zone:(fun () -> Zone.utc)\n ~find_zone:(fun _ ->\n of_sexp_error \"Time.Stable.With_utc.V2.t_of_sexp: unknown time zone\" sexp)\n (date ^ \" \" ^ ofday_and_possibly_zone)\n | _ -> of_sexp_error \"Time.Stable.With_utc.V2.t_of_sexp\" sexp\n with\n | Of_sexp_error _ as e -> raise e\n | e ->\n of_sexp_error\n (sprintf \"Time.Stable.With_utc.V2.t_of_sexp: %s\" (Exn.to_string e))\n sexp\n ;;\n end\n end\n\n module Zone = Zone_stable\nend\n","open! Import\nopen Std_internal\n\nlet arch_sixtyfour = Sys.word_size = 64\n\nmodule Span = Span_ns\nmodule Ofday = Ofday_ns\n\ntype t = Span.t (* since the Unix epoch (1970-01-01 00:00:00 UTC) *)\n[@@deriving bin_io, compare, hash, typerep]\n\ninclude (Span : Comparable.Infix with type t := t)\ninclude (Span : Quickcheck.S_range with type t := t)\n\nlet now = Span.since_unix_epoch\nlet equal = Span.equal\nlet min_value_for_1us_rounding = Span.min_value_for_1us_rounding\nlet max_value_for_1us_rounding = Span.max_value_for_1us_rounding\nlet epoch = Span.zero\nlet add = Span.( + )\nlet sub = Span.( - )\nlet diff = Span.( - )\nlet abs_diff t u = Span.abs (diff t u)\nlet max = Span.max\nlet min = Span.min\nlet next = Span.next\nlet prev = Span.prev\nlet to_span_since_epoch t = t\nlet of_span_since_epoch s = s\nlet to_int63_ns_since_epoch t : Int63.t = Span.to_int63_ns (to_span_since_epoch t)\nlet of_int63_ns_since_epoch i = of_span_since_epoch (Span.of_int63_ns i)\nlet[@cold] overflow () = raise_s [%message \"Time_ns: overflow\"]\nlet is_earlier t1 ~than:t2 = t1 < t2\nlet is_later t1 ~than:t2 = t1 > t2\n\nlet add_overflowed x y ~sum =\n if Span.( > ) y Span.zero then Span.( < ) sum x else Span.( > ) sum x\n;;\n\nlet sub_overflowed x y ~diff =\n if Span.( > ) y Span.zero then Span.( > ) diff x else Span.( < ) diff x\n;;\n\nlet add_exn x y =\n let sum = add x y in\n if add_overflowed x y ~sum then overflow () else sum\n;;\n\nlet sub_exn x y =\n let diff = sub x y in\n if sub_overflowed x y ~diff then overflow () else diff\n;;\n\nlet add_saturating x y =\n let sum = add x y in\n if add_overflowed x y ~sum\n then\n if Span.(y > zero)\n then Span.max_value_representable\n else Span.min_value_representable\n else sum\n;;\n\nlet sub_saturating x y =\n let diff = sub x y in\n if sub_overflowed x y ~diff\n then\n if Span.(y > zero)\n then Span.min_value_representable\n else Span.max_value_representable\n else diff\n;;\n\nlet to_int_ns_since_epoch =\n if arch_sixtyfour\n then fun t -> Int63.to_int_exn (to_int63_ns_since_epoch t)\n else fun _ -> failwith \"Time_ns.to_int_ns_since_epoch: unsupported on 32bit machines\"\n;;\n\nlet of_int_ns_since_epoch i = of_int63_ns_since_epoch (Int63.of_int i)\n\nlet to_time_float_round_nearest t =\n Time_float.of_span_since_epoch\n (Span.to_span_float_round_nearest (to_span_since_epoch t))\n;;\n\nlet to_time_float_round_nearest_microsecond t =\n Time_float.of_span_since_epoch\n (Span.to_span_float_round_nearest_microsecond (to_span_since_epoch t))\n;;\n\nlet min_time_value_for_1us_rounding =\n to_time_float_round_nearest min_value_for_1us_rounding\n;;\n\nlet max_time_value_for_1us_rounding =\n to_time_float_round_nearest max_value_for_1us_rounding\n;;\n\nlet check_before_conversion_for_1us_rounding time =\n if Time_float.( < ) time min_time_value_for_1us_rounding\n || Time_float.( > ) time max_time_value_for_1us_rounding\n then\n failwiths\n ~here:[%here]\n \"Time_ns does not support this time\"\n time\n [%sexp_of: Time_float.Stable.With_utc_sexp.V2.t]\n;;\n\nlet of_time_float_round_nearest time =\n of_span_since_epoch\n (Span.of_span_float_round_nearest (Time_float.to_span_since_epoch time))\n;;\n\nlet of_time_float_round_nearest_microsecond time =\n check_before_conversion_for_1us_rounding time;\n of_span_since_epoch\n (Span.of_span_float_round_nearest_microsecond (Time_float.to_span_since_epoch time))\n;;\n\nlet[@cold] raise_next_multiple_got_nonpositive_interval interval =\n failwiths\n ~here:[%here]\n \"Time_ns.next_multiple got nonpositive interval\"\n interval\n [%sexp_of: Span.t]\n;;\n\nlet next_multiple_internal ~can_equal_after ~base ~after ~interval =\n if Span.( <= ) interval Span.zero\n then raise_next_multiple_got_nonpositive_interval interval;\n let base_to_after = diff after base in\n if Span.( < ) base_to_after Span.zero\n then base (* [after < base], choose [k = 0]. *)\n else (\n let next = add base (Span.scale_int63 interval (Span.div base_to_after interval)) in\n if next > after || (can_equal_after && next = after) then next else add next interval)\n;;\n\nlet next_multiple ?(can_equal_after = false) ~base ~after ~interval () =\n next_multiple_internal ~can_equal_after ~base ~after ~interval\n;;\n\nlet prev_multiple ?(can_equal_before = false) ~base ~before ~interval () =\n next_multiple_internal\n ~can_equal_after:(not can_equal_before)\n ~base\n ~after:(sub before interval)\n ~interval\n;;\n\nlet random ?state () = Span.random ?state ()\n\nmodule Utc : sig\n val to_date_and_span_since_start_of_day : t -> Date0.t * Span.t\n val of_date_and_span_since_start_of_day : Date0.t -> Span.t -> t\nend = struct\n (* a recreation of the system call gmtime specialized to the fields we need that also\n doesn't rely on Unix. *)\n let to_date_and_span_since_start_of_day t =\n let open Int63.O in\n let ( !< ) i = Int63.of_int_exn i in\n let ( !> ) t = Int63.to_int_exn t in\n let ns_since_epoch = to_int63_ns_since_epoch t in\n let ns_per_day = !<86_400 * !<1_000_000_000 in\n let approx_days_from_epoch = ns_since_epoch / ns_per_day in\n let days_from_epoch =\n if ns_since_epoch < !<0 && approx_days_from_epoch * ns_per_day <> ns_since_epoch\n then approx_days_from_epoch - !<1\n else approx_days_from_epoch\n in\n let ns_since_start_of_day = ns_since_epoch - (ns_per_day * days_from_epoch) in\n let date =\n Date0.Days.add_days Date0.Days.unix_epoch !>days_from_epoch |> Date0.Days.to_date\n in\n let span_since_start_of_day = Span.of_int63_ns ns_since_start_of_day in\n date, span_since_start_of_day\n ;;\n\n let of_date_and_span_since_start_of_day date span_since_start_of_day =\n assert (\n Span.( >= ) span_since_start_of_day Span.zero\n && Span.( < ) span_since_start_of_day Span.day);\n let days_from_epoch =\n Date0.Days.diff (Date0.Days.of_date date) Date0.Days.unix_epoch\n in\n let span_in_days_since_epoch = Span.scale_int Span.day days_from_epoch in\n let span_since_epoch = Span.( + ) span_in_days_since_epoch span_since_start_of_day in\n of_span_since_epoch span_since_epoch\n ;;\nend\n\nmodule Alternate_sexp = struct\n type nonrec t = t\n\n module Ofday_as_span = struct\n open Int.O\n\n let seconds_to_string seconds_span =\n let seconds = Span.to_int_sec seconds_span in\n let h = seconds / 3600 in\n let m = seconds / 60 % 60 in\n let s = seconds % 60 in\n sprintf \"%02d:%02d:%02d\" h m s\n ;;\n\n let two_digit_of_string string =\n assert (String.length string = 2 && String.for_all string ~f:Char.is_digit);\n Int.of_string string\n ;;\n\n let seconds_of_string seconds_string =\n match String.split seconds_string ~on:':' with\n | [ h_string; m_string; s_string ] ->\n let h = two_digit_of_string h_string in\n let m = two_digit_of_string m_string in\n let s = two_digit_of_string s_string in\n Span.of_int_sec ((((h * 60) + m) * 60) + s)\n | _ -> assert false\n ;;\n\n let ns_of_100_ms = 100_000_000\n let ns_of_10_ms = 10_000_000\n let ns_of_1_ms = 1_000_000\n let ns_of_100_us = 100_000\n let ns_of_10_us = 10_000\n let ns_of_1_us = 1_000\n let ns_of_100_ns = 100\n let ns_of_10_ns = 10\n let ns_of_1_ns = 1\n\n let sub_second_to_string sub_second_span =\n let open Int.O in\n let ns = Span.to_int63_ns sub_second_span |> Int63.to_int_exn in\n if ns = 0\n then \"\"\n else if ns % ns_of_100_ms = 0\n then sprintf \".%01d\" (ns / ns_of_100_ms)\n else if ns % ns_of_10_ms = 0\n then sprintf \".%02d\" (ns / ns_of_10_ms)\n else if ns % ns_of_1_ms = 0\n then sprintf \".%03d\" (ns / ns_of_1_ms)\n else if ns % ns_of_100_us = 0\n then sprintf \".%04d\" (ns / ns_of_100_us)\n else if ns % ns_of_10_us = 0\n then sprintf \".%05d\" (ns / ns_of_10_us)\n else if ns % ns_of_1_us = 0\n then sprintf \".%06d\" (ns / ns_of_1_us)\n else if ns % ns_of_100_ns = 0\n then sprintf \".%07d\" (ns / ns_of_100_ns)\n else if ns % ns_of_10_ns = 0\n then sprintf \".%08d\" (ns / ns_of_10_ns)\n else sprintf \".%09d\" ns\n ;;\n\n let sub_second_of_string string =\n if String.is_empty string\n then Span.zero\n else (\n let digits = String.chop_prefix_exn string ~prefix:\".\" in\n assert (String.for_all digits ~f:Char.is_digit);\n let multiplier =\n match String.length digits with\n | 1 -> ns_of_100_ms\n | 2 -> ns_of_10_ms\n | 3 -> ns_of_1_ms\n | 4 -> ns_of_100_us\n | 5 -> ns_of_10_us\n | 6 -> ns_of_1_us\n | 7 -> ns_of_100_ns\n | 8 -> ns_of_10_ns\n | 9 -> ns_of_1_ns\n | _ -> assert false\n in\n Span.of_int63_ns (Int63.of_int (Int.of_string digits * multiplier)))\n ;;\n\n let to_string span =\n assert (Span.( >= ) span Span.zero && Span.( < ) span Span.day);\n let seconds_span = span |> Span.to_int_sec |> Span.of_int_sec in\n let sub_second_span = Span.( - ) span seconds_span in\n seconds_to_string seconds_span ^ sub_second_to_string sub_second_span\n ;;\n\n let of_string string =\n let len = String.length string in\n let prefix_len = 8 in\n (* \"HH:MM:DD\" *)\n let suffix_len = len - prefix_len in\n let seconds_string = String.sub string ~pos:0 ~len:prefix_len in\n let sub_second_string = String.sub string ~pos:prefix_len ~len:suffix_len in\n let seconds_span = seconds_of_string seconds_string in\n let sub_second_span = sub_second_of_string sub_second_string in\n Span.( + ) seconds_span sub_second_span\n ;;\n end\n\n let to_string t =\n let date, span_since_start_of_day = Utc.to_date_and_span_since_start_of_day t in\n Date0.to_string date ^ \" \" ^ Ofday_as_span.to_string span_since_start_of_day ^ \"Z\"\n ;;\n\n let of_string string =\n let date_string, ofday_string_with_zone = String.lsplit2_exn string ~on:' ' in\n let ofday_string = String.chop_suffix_exn ofday_string_with_zone ~suffix:\"Z\" in\n let date = Date0.of_string date_string in\n let ofday = Ofday_as_span.of_string ofday_string in\n Utc.of_date_and_span_since_start_of_day date ofday\n ;;\n\n include Sexpable.Of_stringable (struct\n type nonrec t = t\n\n let to_string = to_string\n let of_string = of_string\n end)\n\n module Stable = struct\n module V1 = struct\n (* see tests in lib/core_kernel/test/test_time_ns that ensure stability of this\n representation *)\n type nonrec t = t [@@deriving bin_io, compare, sexp]\n end\n end\nend\n\nmodule Stable = struct\n module Alternate_sexp = Alternate_sexp.Stable\n module Span = Span.Stable\n module Ofday = Ofday.Stable\nend\n\n(* this code is directly duplicated from Time.ml functor, converted enough to get Time_ns\n to/of_string working *)\nmodule To_and_of_string : sig\n val of_date_ofday : zone:Zone.t -> Date.t -> Ofday.t -> t\n\n val of_date_ofday_precise\n : Date.t\n -> Ofday.t\n -> zone:Zone.t\n -> [ `Once of t | `Twice of t * t | `Never of t ]\n\n val to_date_ofday : t -> zone:Zone.t -> Date.t * Ofday.t\n\n val to_date_ofday_precise\n : t\n -> zone:Zone.t\n -> Date.t * Ofday.t * [ `Only | `Also_at of t | `Also_skipped of Date.t * Ofday.t ]\n\n val to_date : t -> zone:Zone.t -> Date.t\n val to_ofday : t -> zone:Zone.t -> Ofday.t\n val convert : from_tz:Zone.t -> to_tz:Zone.t -> Date.t -> Ofday.t -> Date.t * Ofday.t\n val reset_date_cache : unit -> unit\n val utc_offset : t -> zone:Zone.t -> Span.t\n\n include Stringable with type t := t\n\n val to_filename_string : t -> zone:Zone.t -> string\n val of_filename_string : string -> zone:Zone.t -> t\n val to_string_trimmed : t -> zone:Zone.t -> string\n val to_sec_string : t -> zone:Zone.t -> string\n val of_localized_string : zone:Zone.t -> string -> t\n\n val of_string_gen\n : default_zone:(unit -> Zone.t)\n -> find_zone:(string -> Zone.t)\n -> string\n -> t\n\n val to_string_abs : t -> zone:Zone.t -> string\n val to_string_abs_trimmed : t -> zone:Zone.t -> string\n val to_string_abs_parts : t -> zone:Zone.t -> string list\n val to_string_iso8601_basic : t -> zone:Zone.t -> string\n\n val occurrence\n : [ `First_after_or_at | `Last_before_or_at ]\n -> t\n -> ofday:Ofday.t\n -> zone:Zone.t\n -> t\nend = struct\n (* this code is directly duplicated from Time_float0.ml, converted enough to get\n Time_ns to/of_string working *)\n module Date_and_ofday = struct\n type t = Int63.t\n\n let to_synthetic_span_since_epoch t = Span.of_int63_ns t\n\n let of_date_ofday date ofday =\n let days =\n Date0.Days.diff (Date0.Days.of_date date) Date0.Days.unix_epoch |> Int63.of_int\n in\n let open Int63.O in\n (days * Span.to_int63_ns Span.day)\n + Span.to_int63_ns (Ofday.to_span_since_start_of_day ofday)\n ;;\n\n let to_absolute relative ~offset_from_utc =\n sub_exn (Span.of_int63_ns relative) offset_from_utc\n ;;\n\n let of_absolute absolute ~offset_from_utc =\n Span.to_int63_ns (add_exn absolute offset_from_utc)\n ;;\n\n let ns_per_day = Span.to_int63_ns Span.day\n\n let to_days_from_epoch t =\n (* note Time_ns represents about 146 years, not enough for [Date.create_exn] to ever\n raise *)\n let open Int63.O in\n let days_from_epoch_approx = t / ns_per_day in\n (* when [t] is negative the integer division that calculated days_from_epoch_approx\n will leave us one day short because it truncates (e.g. -100 / 86_400 = 0 and we\n want -1) -- adjust for that here. *)\n if t < days_from_epoch_approx * ns_per_day\n then Int63.pred days_from_epoch_approx\n else days_from_epoch_approx\n ;;\n\n let ofday_of_days_from_epoch t ~days_from_epoch =\n let open Int63.O in\n let days_from_epoch_in_ns = days_from_epoch * ns_per_day in\n let remainder = t - days_from_epoch_in_ns in\n Span.of_int63_ns remainder |> Ofday.of_span_since_start_of_day_exn\n ;;\n\n let date_of_days_from_epoch ~days_from_epoch =\n Int63.to_int_exn days_from_epoch\n |> Date0.Days.add_days Date0.Days.unix_epoch\n |> Date0.Days.to_date\n ;;\n\n let to_date t =\n let days_from_epoch = to_days_from_epoch t in\n date_of_days_from_epoch ~days_from_epoch\n ;;\n\n let to_ofday t =\n let days_from_epoch = to_days_from_epoch t in\n ofday_of_days_from_epoch t ~days_from_epoch\n ;;\n end\n\n module Zone0 = Zone\n\n module Zone : sig\n (* This interface is directly duplicated from Time_intf.Zone, converted enough to get\n this to work.\n\n The problem is has references to Time0_intf.S, which is the functor input interface\n that Time_ns currently does not satisfy. *)\n\n type time = t\n type t = Zone.t [@@deriving sexp_of]\n\n module Index = Zone.Index\n\n (* copied functions reexported from Zone *)\n\n val utc : t\n val index_has_prev_clock_shift : t -> Index.t -> bool\n val index_has_next_clock_shift : t -> Index.t -> bool\n\n (* new functions defined below *)\n\n val index : t -> time -> Index.t\n val index_offset_from_utc_exn : t -> Index.t -> time\n val index_prev_clock_shift_time_exn : t -> Index.t -> time\n val index_next_clock_shift_time_exn : t -> Index.t -> time\n val absolute_time_of_date_and_ofday : t -> Date_and_ofday.t -> time\n val date_and_ofday_of_absolute_time : t -> time -> Date_and_ofday.t\n val next_clock_shift : t -> strictly_after:time -> (time * Span.t) option\n val prev_clock_shift : t -> at_or_before:time -> (time * Span.t) option\n end = struct\n type time = t\n\n include Zone\n\n let of_span_in_seconds span_in_seconds =\n (* NB. no actual rounding or exns can occur here *)\n Time_in_seconds.Span.to_int63_seconds_round_down_exn span_in_seconds\n |> Span.of_int63_seconds\n ;;\n\n let of_time_in_seconds time_in_seconds =\n Time_in_seconds.to_span_since_epoch time_in_seconds\n (* NB. no actual rounding or exns can occur here *)\n |> Time_in_seconds.Span.to_int63_seconds_round_down_exn\n |> Span.of_int63_seconds\n |> of_span_since_epoch\n ;;\n\n let to_time_in_seconds_round_down_exn time =\n to_span_since_epoch time\n |> Span.to_int63_seconds_round_down_exn\n |> Time_in_seconds.Span.of_int63_seconds\n |> Time_in_seconds.of_span_since_epoch\n ;;\n\n let to_date_and_ofday_in_seconds_round_down_exn relative =\n Date_and_ofday.to_synthetic_span_since_epoch relative\n |> Span.to_int63_seconds_round_down_exn\n |> Time_in_seconds.Span.of_int63_seconds\n |> Time_in_seconds.Date_and_ofday.of_synthetic_span_since_epoch\n ;;\n\n let index t time = index t (to_time_in_seconds_round_down_exn time)\n\n let index_of_date_and_ofday t relative =\n index_of_date_and_ofday t (to_date_and_ofday_in_seconds_round_down_exn relative)\n ;;\n\n let index_offset_from_utc_exn t index =\n of_span_in_seconds (index_offset_from_utc_exn t index)\n ;;\n\n let index_prev_clock_shift_time_exn t index =\n of_time_in_seconds (index_prev_clock_shift_time_exn t index)\n ;;\n\n let index_next_clock_shift_time_exn t index =\n of_time_in_seconds (index_next_clock_shift_time_exn t index)\n ;;\n\n let index_prev_clock_shift_amount_exn t index =\n of_span_in_seconds (index_prev_clock_shift_amount_exn t index)\n ;;\n\n let index_prev_clock_shift t index =\n match index_has_prev_clock_shift t index with\n | false -> None\n | true ->\n Some\n ( index_prev_clock_shift_time_exn t index\n , index_prev_clock_shift_amount_exn t index )\n ;;\n\n let index_next_clock_shift t index = index_prev_clock_shift t (Index.next index)\n let prev_clock_shift t ~at_or_before:time = index_prev_clock_shift t (index t time)\n let next_clock_shift t ~strictly_after:time = index_next_clock_shift t (index t time)\n\n let date_and_ofday_of_absolute_time t time =\n let index = index t time in\n (* no exn because [index] always returns a valid index *)\n let offset_from_utc = index_offset_from_utc_exn t index in\n Date_and_ofday.of_absolute time ~offset_from_utc\n ;;\n\n let absolute_time_of_date_and_ofday t relative =\n let index = index_of_date_and_ofday t relative in\n (* no exn because [index_of_date_and_ofday] always returns a valid index *)\n let offset_from_utc = index_offset_from_utc_exn t index in\n Date_and_ofday.to_absolute relative ~offset_from_utc\n ;;\n end\n\n let of_date_ofday ~zone date ofday =\n let relative = Date_and_ofday.of_date_ofday date ofday in\n Zone.absolute_time_of_date_and_ofday zone relative\n ;;\n\n let of_date_ofday_precise date ofday ~zone =\n (* We assume that there will be only one zone shift within a given local day. *)\n let start_of_day = of_date_ofday ~zone date Ofday.start_of_day in\n let proposed_time = add start_of_day (Ofday.to_span_since_start_of_day ofday) in\n match Zone.next_clock_shift zone ~strictly_after:start_of_day with\n | None -> `Once proposed_time\n | Some (shift_start, shift_amount) ->\n let shift_backwards = Span.(shift_amount < zero) in\n (* start and end of the \"problematic region\" *)\n let s, e =\n if shift_backwards\n then add shift_start shift_amount, shift_start\n else shift_start, add shift_start shift_amount\n in\n if proposed_time < s\n then `Once proposed_time\n else if s <= proposed_time && proposed_time < e\n then\n if shift_backwards\n then `Twice (proposed_time, sub proposed_time shift_amount)\n else `Never shift_start\n else `Once (sub proposed_time shift_amount)\n ;;\n\n module Date_cache = struct\n type nonrec t =\n { mutable zone : Zone.t\n ; mutable cache_start_incl : t\n ; mutable cache_until_excl : t\n ; mutable effective_day_start : t\n ; mutable date : Date0.t\n }\n end\n\n let date_cache : Date_cache.t =\n { zone = Zone.utc\n ; cache_start_incl = epoch\n ; cache_until_excl = epoch\n ; effective_day_start = epoch\n ; date = Date0.unix_epoch\n }\n ;;\n\n let reset_date_cache () =\n date_cache.zone <- Zone.utc;\n date_cache.cache_start_incl <- epoch;\n date_cache.cache_until_excl <- epoch;\n date_cache.effective_day_start <- epoch;\n date_cache.date <- Date0.unix_epoch\n ;;\n\n let is_in_cache time ~zone =\n phys_equal zone date_cache.zone\n && time >= date_cache.cache_start_incl\n && time < date_cache.cache_until_excl\n ;;\n\n let set_date_cache time ~zone =\n match is_in_cache time ~zone with\n | true -> ()\n | false ->\n let index = Zone.index zone time in\n (* no exn because [Zone.index] always returns a valid index *)\n let offset_from_utc = Zone.index_offset_from_utc_exn zone index in\n let rel = Date_and_ofday.of_absolute time ~offset_from_utc in\n let date = Date_and_ofday.to_date rel in\n let span = Date_and_ofday.to_ofday rel |> Ofday.to_span_since_start_of_day in\n let effective_day_start =\n sub (Date_and_ofday.to_absolute rel ~offset_from_utc) span\n in\n let effective_day_until = add effective_day_start Span.day in\n let cache_start_incl =\n match Zone.index_has_prev_clock_shift zone index with\n | false -> effective_day_start\n | true ->\n effective_day_start |> max (Zone.index_prev_clock_shift_time_exn zone index)\n in\n let cache_until_excl =\n match Zone.index_has_next_clock_shift zone index with\n | false -> effective_day_until\n | true ->\n effective_day_until |> min (Zone.index_next_clock_shift_time_exn zone index)\n in\n date_cache.zone <- zone;\n date_cache.cache_start_incl <- cache_start_incl;\n date_cache.cache_until_excl <- cache_until_excl;\n date_cache.effective_day_start <- effective_day_start;\n date_cache.date <- date\n ;;\n\n let to_date time ~zone =\n set_date_cache time ~zone;\n date_cache.date\n ;;\n\n let to_ofday time ~zone =\n set_date_cache time ~zone;\n diff time date_cache.effective_day_start |> Ofday.of_span_since_start_of_day_exn\n ;;\n\n let to_date_ofday time ~zone = to_date time ~zone, to_ofday time ~zone\n\n (* The correctness of this algorithm (interface, even) depends on the fact that\n timezone shifts aren't too close together (as in, it can't simultaneously be the\n case that a timezone shift of X hours occurred less than X hours ago, *and*\n a timezone shift of Y hours will occur in less than Y hours' time) *)\n let to_date_ofday_precise time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let clock_shift_after = Zone.next_clock_shift zone ~strictly_after:time in\n let clock_shift_before_or_at = Zone.prev_clock_shift zone ~at_or_before:time in\n let also_skipped_earlier amount =\n (* Using [date] and raising on [None] here is OK on the assumption that clock\n shifts can't cross date boundaries. This is true in all cases I've ever heard\n of (and [of_date_ofday_precise] would need revisiting if it turned out to be\n false) *)\n match Ofday.sub ofday amount with\n | Some ofday -> `Also_skipped (date, ofday)\n | None ->\n raise_s\n [%message\n \"Time.to_date_ofday_precise\"\n ~span_since_epoch:(to_span_since_epoch time : Span.t)\n (zone : Zone.t)]\n in\n let ambiguity =\n (* Edge cases: the instant of transition belongs to the new zone regime. So if the\n clock moved by an hour exactly one hour ago, there's no ambiguity, because the\n hour-ago time belongs to the same regime as you, and conversely, if the clock\n will move by an hour in an hours' time, there *is* ambiguity. Hence [>.] for\n the first case and [<=.] for the second. *)\n match clock_shift_before_or_at, clock_shift_after with\n | Some (start, amount), _ when add start (Span.abs amount) > time ->\n (* clock shifted recently *)\n if Span.(amount > zero)\n then\n (* clock shifted forward recently: we skipped a time *)\n also_skipped_earlier amount\n else (\n (* clock shifted back recently: this date/ofday already happened *)\n assert (Span.(amount < zero));\n `Also_at (sub time (Span.abs amount)))\n | _, Some (start, amount) when sub start (Span.abs amount) <= time ->\n (* clock is about to shift *)\n if Span.(amount > zero)\n then (* clock about to shift forward: no effect *)\n `Only\n else (\n (* clock about to shift back: this date/ofday will be repeated *)\n assert (Span.(amount < zero));\n `Also_at (add time (Span.abs amount)))\n | _ -> `Only\n in\n date, ofday, ambiguity\n ;;\n\n let convert ~from_tz ~to_tz date ofday =\n let start_time = of_date_ofday ~zone:from_tz date ofday in\n to_date_ofday ~zone:to_tz start_time\n ;;\n\n let utc_offset t ~zone =\n let utc_epoch = Zone.date_and_ofday_of_absolute_time zone t in\n Span.( - )\n (Date_and_ofday.to_synthetic_span_since_epoch utc_epoch)\n (to_span_since_epoch t)\n ;;\n\n let offset_string time ~zone =\n let utc_offset = utc_offset time ~zone in\n let is_utc = Span.( = ) utc_offset Span.zero in\n if is_utc\n then \"Z\"\n else\n String.concat\n [ (if Span.( < ) utc_offset Span.zero then \"-\" else \"+\")\n ; Ofday.to_string_trimmed\n (Ofday.of_span_since_start_of_day_exn (Span.abs utc_offset))\n ]\n ;;\n\n let to_string_abs_parts =\n let attempt time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let offset_string = offset_string time ~zone in\n [ Date0.to_string date\n ; String.concat ~sep:\"\" [ Ofday.to_string ofday; offset_string ]\n ]\n in\n fun time ~zone ->\n try attempt time ~zone with\n | (_ : exn) ->\n (* If we overflow applying the UTC offset, try again with UTC time. *)\n attempt time ~zone:Zone.utc\n ;;\n\n let to_string_abs_trimmed time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let offset_string = offset_string time ~zone in\n String.concat\n ~sep:\" \"\n [ Date0.to_string date; Ofday.to_string_trimmed ofday ^ offset_string ]\n ;;\n\n let to_string_abs time ~zone = String.concat ~sep:\" \" (to_string_abs_parts ~zone time)\n let to_string t = to_string_abs t ~zone:Zone.utc\n\n let to_string_iso8601_basic time ~zone =\n String.concat ~sep:\"T\" (to_string_abs_parts ~zone time)\n ;;\n\n let to_string_trimmed t ~zone =\n let date, sec = to_date_ofday ~zone t in\n Date0.to_string date ^ \" \" ^ Ofday.to_string_trimmed sec\n ;;\n\n let to_sec_string t ~zone =\n let date, sec = to_date_ofday ~zone t in\n Date0.to_string date ^ \" \" ^ Ofday.to_sec_string sec\n ;;\n\n let to_filename_string t ~zone =\n let date, ofday = to_date_ofday ~zone t in\n Date0.to_string date\n ^ \"_\"\n ^ String.tr\n ~target:':'\n ~replacement:'-'\n (String.drop_suffix (Ofday.to_string ofday) 3)\n ;;\n\n let of_filename_string s ~zone =\n try\n match String.lsplit2 s ~on:'_' with\n | None -> failwith \"no space in filename string\"\n | Some (date, ofday) ->\n let date = Date0.of_string date in\n let ofday = String.tr ~target:'-' ~replacement:':' ofday in\n let ofday = Ofday.of_string ofday in\n of_date_ofday date ofday ~zone\n with\n | exn -> invalid_argf \"Time.of_filename_string (%s): %s\" s (Exn.to_string exn) ()\n ;;\n\n let of_localized_string ~zone str =\n try\n match String.lsplit2 str ~on:' ' with\n | None -> invalid_arg (sprintf \"no space in date_ofday string: %s\" str)\n | Some (date, time) ->\n let date = Date0.of_string date in\n let ofday = Ofday.of_string time in\n of_date_ofday ~zone date ofday\n with\n | e -> Exn.reraise e \"Time.of_localized_string\"\n ;;\n\n let occurrence before_or_after t ~ofday ~zone =\n let first_guess_date = to_date t ~zone in\n let first_guess = of_date_ofday ~zone first_guess_date ofday in\n let cmp, increment =\n match before_or_after with\n | `Last_before_or_at -> ( <= ), -1\n | `First_after_or_at -> ( >= ), 1\n in\n if cmp first_guess t\n then first_guess\n else of_date_ofday ~zone (Date0.add_days first_guess_date increment) ofday\n ;;\n\n let ensure_colon_in_offset offset =\n let offset_length = String.length offset in\n if Int.( <= ) offset_length 2\n && Char.is_digit offset.[0]\n && Char.is_digit offset.[offset_length - 1]\n then offset ^ \":00\"\n else if Char.( = ) offset.[1] ':' || Char.( = ) offset.[2] ':'\n then offset\n else if Int.( < ) offset_length 3 || Int.( > ) offset_length 4\n then failwithf \"invalid offset %s\" offset ()\n else\n String.concat\n [ String.slice offset 0 (offset_length - 2)\n ; \":\"\n ; String.slice offset (offset_length - 2) offset_length\n ]\n ;;\n\n exception Time_ns_of_string of string * Exn.t [@@deriving sexp]\n\n let of_string_gen ~default_zone ~find_zone s =\n try\n let date, ofday, tz =\n match String.split s ~on:' ' with\n | [ day; month; year; ofday ] ->\n String.concat [ day; \" \"; month; \" \"; year ], ofday, None\n | [ date; ofday; tz ] -> date, ofday, Some tz\n | [ date; ofday ] -> date, ofday, None\n | [ s ] ->\n (match String.rsplit2 ~on:'T' s with\n | Some (date, ofday) -> date, ofday, None\n | None -> failwith \"no spaces or T found\")\n | _ -> failwith \"too many spaces\"\n in\n let ofday_to_sec od = Span.to_sec (Ofday.to_span_since_start_of_day od) in\n let ofday, utc_offset =\n match tz with\n | Some _ -> ofday, None\n | None ->\n if Char.( = ) ofday.[String.length ofday - 1] 'Z'\n then String.sub ofday ~pos:0 ~len:(String.length ofday - 1), Some 0.\n else (\n match String.lsplit2 ~on:'+' ofday with\n | Some (l, r) ->\n l, Some (ofday_to_sec (Ofday.of_string (ensure_colon_in_offset r)))\n | None ->\n (match String.lsplit2 ~on:'-' ofday with\n | Some (l, r) ->\n l, Some (-1. *. ofday_to_sec (Ofday.of_string (ensure_colon_in_offset r)))\n | None -> ofday, None))\n in\n let date = Date0.of_string date in\n let ofday = Ofday.of_string ofday in\n match tz with\n | Some tz -> of_date_ofday ~zone:(find_zone tz) date ofday\n | None ->\n (match utc_offset with\n | None ->\n let zone = default_zone () in\n of_date_ofday ~zone date ofday\n | Some utc_offset ->\n let utc_t = of_date_ofday ~zone:Zone.utc date ofday in\n sub utc_t (Span.of_sec utc_offset))\n with\n | e -> raise (Time_ns_of_string (s, e))\n ;;\n\n let of_string s =\n let default_zone () = raise_s [%message \"time has no time zone or UTC offset\" s] in\n let find_zone zone_name =\n failwithf \"unable to lookup Zone %s. Try using Core.Time.of_string\" zone_name ()\n in\n of_string_gen ~default_zone ~find_zone s\n ;;\nend\n\ninclude To_and_of_string\n\nlet min_value_representable = of_span_since_epoch Span.min_value_representable\nlet max_value_representable = of_span_since_epoch Span.max_value_representable\n\n(* Legacy definitions based on rounding to the nearest microsecond. *)\nlet min_value = min_value_for_1us_rounding\nlet max_value = max_value_for_1us_rounding\nlet to_time = to_time_float_round_nearest_microsecond\nlet of_time = of_time_float_round_nearest_microsecond\n\nmodule For_ppx_module_timer = struct\n open Ppx_module_timer_runtime\n\n let () =\n Duration.format\n := (module struct\n let duration_of_span s = s |> Span.to_int63_ns |> Duration.of_nanoseconds\n let span_of_duration d = d |> Duration.to_nanoseconds |> Span.of_int63_ns\n let of_string string = string |> Span.of_string |> duration_of_span\n\n let to_string_with_same_unit durations =\n let spans = durations |> List.map ~f:span_of_duration in\n let unit_of_time =\n spans\n |> List.max_elt ~compare:Span.compare\n |> Option.value_map\n ~f:Span.to_unit_of_time\n ~default:Unit_of_time.Nanosecond\n in\n spans |> List.map ~f:(Span.to_string_hum ~unit_of_time ~align_decimal:true)\n ;;\n end)\n ;;\nend\n","open! Import\n\n(* A [Time_ns] that uses its alternate sexp representation. *)\ninclude Time_ns\ninclude Alternate_sexp\n","module Stable = struct\n open Stable_internal\n\n module T = struct\n type 'a t =\n { mutable value : 'a option\n ; mutable set_at : Source_code_position.Stable.V1.t\n }\n [@@deriving fields]\n end\n\n module V1 = struct\n module Format = struct\n type 'a t = 'a option ref [@@deriving bin_io, sexp]\n end\n\n module T = struct\n type 'a t = 'a T.t\n\n let of_format (v1 : 'a Format.t) : 'a t = { value = !v1; set_at = [%here] }\n let to_format (t : 'a t) : 'a Format.t = ref t.value\n end\n\n include T\n\n include Binable.Of_binable1_without_uuid [@alert \"-legacy\"]\n (Format)\n (struct\n include T\n\n let of_binable = of_format\n let to_binable = to_format\n end)\n\n include Sexpable.Of_sexpable1\n (Format)\n (struct\n include T\n\n let of_sexpable = of_format\n let to_sexpable = to_format\n end)\n end\nend\n\nopen! Import\nmodule Unstable = Stable.V1\nopen Stable.T\n\ntype 'a t = 'a Stable.T.t\n\nlet sexp_of_t sexp_of_a { value; set_at } =\n match value with\n | None -> [%message \"unset\"]\n | Some value ->\n [%message \"\" (value : a) ~set_at:(set_at |> Source_code_position.to_string)]\n;;\n\nlet invariant invariant_a t =\n match t.value with\n | None -> ()\n | Some a -> invariant_a a\n;;\n\nlet create () = { value = None; set_at = [%here] }\n\nlet set_internal t here value =\n t.value <- Some value;\n t.set_at <- here\n;;\n\nlet set_if_none t here value = if Option.is_none t.value then set_internal t here value\n\nlet set t here value =\n if Option.is_none t.value\n then (\n set_internal t here value;\n Ok ())\n else\n Or_error.error_s\n [%message\n \"[Set_once.set_exn] already set\"\n ~setting_at:(here : Source_code_position.t)\n ~previously_set_at:(t.set_at : Source_code_position.t)]\n;;\n\nlet set_exn t here value = Or_error.ok_exn (set t here value)\nlet get t = t.value\n\nlet get_exn (t : _ t) here =\n match t.value with\n | Some a -> a\n | None ->\n raise_s [%message \"[Set_once.get_exn] unset\" ~at:(here : Source_code_position.t)]\n;;\n\nlet is_none t = Option.is_none t.value\nlet is_some t = Option.is_some t.value\nlet iter t ~f = Option.iter t.value ~f\n\nmodule Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n let unsafe_value t = get_exn t [%here]\n end\nend\n","open! Import\n\ntype 'a t = 'a [@@deriving sexp_of]\n\nexternal is_heap_block : Caml.Obj.t -> bool = \"Core_kernel_heap_block_is_heap_block\"\n[@@noalloc]\n\nlet is_ok v = is_heap_block (Caml.Obj.repr v)\nlet create v = if is_ok v then Some v else None\n\nlet create_exn v =\n if is_ok v then v else failwith \"Heap_block.create_exn called with non heap block\"\n;;\n\nlet value t = t\nlet bytes_per_word = Word_size.(num_bits word_size) / 8\n\nlet bytes (type a) (t : a t) =\n (Caml.Obj.size (Caml.Obj.repr (t : a t)) + 1) * bytes_per_word\n;;\n","open! Import\ninclude Base.Queue\n\ninclude Test_binary_searchable.Make1_and_test (struct\n type nonrec 'a t = 'a t\n\n let get = get\n let length = length\n\n module For_test = struct\n let of_array a =\n let r = create () in\n (* We enqueue everything twice, and dequeue it once to ensure:\n - that the queue has the same content as the array.\n - that it has, in most cases, an interesting internal structure*)\n for i = 0 to Array.length a - 1 do\n enqueue r a.(i)\n done;\n for i = 0 to Array.length a - 1 do\n ignore (dequeue_exn r : bool);\n enqueue r a.(i)\n done;\n r\n ;;\n end\n end)\n\nmodule Serialization_v1 = struct\n let sexp_of_t = sexp_of_t\n let t_of_sexp = t_of_sexp\n\n include Bin_prot.Utils.Make_iterable_binable1 (struct\n type nonrec 'a t = 'a t\n type 'a el = 'a [@@deriving bin_io]\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"b4c84254-4992-11e6-9ba7-734e154027bd\"\n ;;\n\n let module_name = Some \"Core_kernel.Queue\"\n let length = length\n let iter = iter\n let init ~len ~next = init len ~f:(fun _ -> next ())\n end)\nend\n\ninclude Serialization_v1\n\nmodule Stable = struct\n module V1 = struct\n type nonrec 'a t = 'a t [@@deriving compare]\n\n include Serialization_v1\n\n (* We don't have a [%bin_digest] expect test here because the bin_io is mostly hand\n written, and [core_queue_unit_tests.ml] has unit tests for specific values. *)\n\n let map = map\n end\nend\n","open! Import\ninclude Base.Option_array\n\nlet to_array t = Array.init (length t) ~f:(fun i -> unsafe_get t i)\nlet of_array a = init (Array.length a) ~f:(fun i -> Array.unsafe_get a i)\n\ninclude Binable.Of_binable1_without_uuid [@alert \"-legacy\"]\n (struct\n type 'a t = 'a option array [@@deriving sexp, bin_io]\n end)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable = to_array\n let of_binable = of_array\n end)\n","open! Import\nopen Std_internal\n\ntype ('a, 'b) fn = 'a -> 'b\n\nmodule Result = struct\n type 'a t =\n | Rval of 'a\n | Expt of exn\n\n let return = function\n | Rval v -> v\n | Expt e -> raise e\n ;;\n\n let capture f x =\n try Rval (f x) with\n | Sys.Break as e -> raise e\n | e -> Expt e\n ;;\nend\n\nlet unit f =\n let l = Lazy.from_fun f in\n fun () -> Lazy.force l\n;;\n\nlet unbounded (type a) ?(hashable = Hashtbl.Hashable.poly) f =\n let cache =\n let module A =\n Hashable.Make_plain_and_derive_hash_fold_t (struct\n type t = a\n\n let { Hashtbl.Hashable.hash; compare; sexp_of_t } = hashable\n end)\n in\n A.Table.create () ~size:0\n in\n (* Allocate this closure at the call to [unbounded], not at each call to the memoized\n function. *)\n let really_call_f arg = Result.capture f arg in\n fun arg -> Result.return (Hashtbl.findi_or_add cache arg ~default:really_call_f)\n;;\n\n(* the same but with a bound on cache size *)\nlet lru (type a) ?(hashable = Hashtbl.Hashable.poly) ~max_cache_size f =\n if max_cache_size <= 0\n then failwithf \"Memo.lru: max_cache_size of %i <= 0\" max_cache_size ();\n let module Cache =\n Hash_queue.Make (struct\n type t = a\n\n let { Hashtbl.Hashable.hash; compare; sexp_of_t } = hashable\n end)\n in\n let cache = Cache.create () in\n fun arg ->\n Result.return\n (match Cache.lookup_and_move_to_back cache arg with\n | Some result -> result\n | None ->\n let result = Result.capture f arg in\n Cache.enqueue_back_exn cache arg result;\n (* eject least recently used cache entry *)\n if Cache.length cache > max_cache_size\n then ignore (Cache.dequeue_front_exn cache : _ Result.t);\n result)\n;;\n\nlet general ?hashable ?cache_size_bound f =\n match cache_size_bound with\n | None -> unbounded ?hashable f\n | Some n -> lru ?hashable ~max_cache_size:n f\n;;\n\nlet of_comparable (type index) (module M : Comparable.S_plain with type t = index) f =\n let m = ref M.Map.empty in\n fun (x : M.t) ->\n let v =\n match Map.find !m x with\n | Some v -> v\n | None ->\n let v = Result.capture f x in\n m := Map.set !m ~key:x ~data:v;\n v\n in\n Result.return v\n;;\n","open! Import\nopen Std_internal\n\ntype 'a t =\n { (* [arr] is a cyclic buffer *)\n mutable arr : 'a Option_array.t\n ; (* [front_index] and [back_index] are the positions in which new elements may be\n enqueued. This makes the active part of [arr] the range from [front_index+1] to\n [back_index-1] (modulo the length of [arr] and wrapping around if necessary). Note\n that this means the active range is maximized when [front_index = back_index], which\n occurs when there are [Array.length arr - 1] active elements. *)\n mutable front_index : int\n ; mutable back_index : int\n ; (* apparent_front_index is what is exposed as the front index externally. It has no\n real relation to the array -- every enqueue to the front decrements it and every\n dequeue from the front increments it. *)\n mutable apparent_front_index : int\n ; mutable length : int\n ; (* We keep arr_length here as a speed hack. Calling Array.length on arr is actually\n meaningfully slower. *)\n mutable arr_length : int\n ; never_shrink : bool\n }\n\nlet create ?initial_length ?never_shrink () =\n let never_shrink =\n match never_shrink with\n | None -> Option.is_some initial_length\n | Some b -> b\n in\n let initial_length = Option.value ~default:7 initial_length in\n if initial_length < 0\n then\n invalid_argf \"passed negative initial_length to Deque.create: %i\" initial_length ();\n (* Make the initial array length be [initial_length + 1] so we can fit [initial_length]\n elements without growing. We never quite use the whole array. *)\n let arr_length = initial_length + 1 in\n { arr = Option_array.create ~len:arr_length\n ; front_index = 0\n ; back_index = 1\n ; apparent_front_index = 0\n ; length = 0\n ; arr_length\n ; never_shrink\n }\n;;\n\nlet length t = t.length\nlet is_empty t = length t = 0\n\n(* We keep track of the length in a mutable field for speed, but this calculation should\n be correct by construction, and can be used for testing. *)\nlet _invariant_length t =\n let constructed_length =\n if t.front_index < t.back_index\n then t.back_index - t.front_index - 1\n else t.back_index - t.front_index - 1 + t.arr_length\n in\n assert (length t = constructed_length)\n;;\n\n(* The various \"when_not_empty\" functions return misleading numbers when the dequeue is\n empty. They are safe to call if it is known that the dequeue is non-empty. *)\nlet apparent_front_index_when_not_empty t = t.apparent_front_index\nlet apparent_back_index_when_not_empty t = t.apparent_front_index + length t - 1\n\nlet actual_front_index_when_not_empty t =\n if t.front_index = t.arr_length - 1 then 0 else t.front_index + 1\n;;\n\nlet actual_back_index_when_not_empty t =\n if t.back_index = 0 then t.arr_length - 1 else t.back_index - 1\n;;\n\nlet checked t f = if is_empty t then None else Some (f t)\nlet apparent_front_index t = checked t apparent_front_index_when_not_empty\nlet apparent_back_index t = checked t apparent_back_index_when_not_empty\n\nlet foldi' t dir ~init ~f =\n if is_empty t\n then init\n else (\n let apparent_front = apparent_front_index_when_not_empty t in\n let apparent_back = apparent_back_index_when_not_empty t in\n let actual_front = actual_front_index_when_not_empty t in\n let actual_back = actual_back_index_when_not_empty t in\n let rec loop acc ~apparent_i ~real_i ~stop_pos ~step =\n if real_i = stop_pos\n then acc, apparent_i\n else\n loop\n (f apparent_i acc (Option_array.get_some_exn t.arr real_i))\n ~apparent_i:(apparent_i + step)\n ~real_i:(real_i + step)\n ~stop_pos\n ~step\n in\n (* We want to iterate from actual_front to actual_back (or vice versa), but we may\n need to wrap around the array to do so. Thus we do the following:\n 1. If the active range is contiguous (i.e. actual_front <= actual_back), then loop\n starting at the appropriate end of the active range until we reach the first\n element outside of it.\n 2. If it is not contiguous (actual_front > actual_back), then first loop from the\n appropriate end of the active range to the end of the array. Then, loop from\n the opposite end of the array to the opposite end of the active range.\n *)\n match dir with\n | `front_to_back ->\n if actual_front <= actual_back\n then (\n let acc, _ =\n loop\n init\n ~apparent_i:apparent_front\n ~real_i:actual_front\n ~stop_pos:(actual_back + 1)\n ~step:1\n in\n acc)\n else (\n let acc, apparent_i =\n loop\n init\n ~apparent_i:apparent_front\n ~real_i:actual_front\n ~stop_pos:t.arr_length\n ~step:1\n in\n let acc, _ =\n loop acc ~apparent_i ~real_i:0 ~stop_pos:(actual_back + 1) ~step:1\n in\n acc)\n | `back_to_front ->\n if actual_front <= actual_back\n then (\n let acc, _ =\n loop\n init\n ~apparent_i:apparent_back\n ~real_i:actual_back\n ~stop_pos:(actual_front - 1)\n ~step:(-1)\n in\n acc)\n else (\n let acc, apparent_i =\n loop\n init\n ~apparent_i:apparent_back\n ~real_i:actual_back\n ~stop_pos:(-1)\n ~step:(-1)\n in\n let acc, _ =\n loop\n acc\n ~apparent_i\n ~real_i:(t.arr_length - 1)\n ~stop_pos:(actual_front - 1)\n ~step:(-1)\n in\n acc))\n;;\n\nlet fold' t dir ~init ~f = foldi' t dir ~init ~f:(fun _ acc v -> f acc v)\nlet iteri' t dir ~f = foldi' t dir ~init:() ~f:(fun i () v -> f i v)\nlet iter' t dir ~f = foldi' t dir ~init:() ~f:(fun _ () v -> f v)\nlet fold t ~init ~f = fold' t `front_to_back ~init ~f\nlet foldi t ~init ~f = foldi' t `front_to_back ~init ~f\nlet iteri t ~f = iteri' t `front_to_back ~f\n\nlet iteri_internal t ~f =\n if not (is_empty t)\n then (\n let actual_front = actual_front_index_when_not_empty t in\n let actual_back = actual_back_index_when_not_empty t in\n let rec loop ~real_i ~stop_pos =\n if real_i < stop_pos\n then (\n f t.arr real_i;\n loop ~real_i:(real_i + 1) ~stop_pos)\n in\n if actual_front <= actual_back\n then loop ~real_i:actual_front ~stop_pos:(actual_back + 1)\n else (\n loop ~real_i:actual_front ~stop_pos:t.arr_length;\n loop ~real_i:0 ~stop_pos:(actual_back + 1)))\n;;\n\nlet iter t ~f = iteri_internal t ~f:(fun arr i -> Option_array.get_some_exn arr i |> f)\n\nlet clear t =\n if t.never_shrink\n then\n (* clear the array to allow elements to be garbage collected *)\n iteri_internal t ~f:Option_array.unsafe_set_none\n else t.arr <- Option_array.create ~len:8;\n t.front_index <- 0;\n t.back_index <- 1;\n t.length <- 0;\n t.arr_length <- Option_array.length t.arr\n;;\n\n(* We have to be careful here, importing all of Container.Make would change the runtime of\n some functions ([length] minimally) silently without changing the semantics. We get\n around that by importing things explicitly. *)\nmodule C = Container.Make (struct\n type nonrec 'a t = 'a t\n\n let fold = fold\n let iter = `Custom iter\n let length = `Custom length\n end)\n\nlet count = C.count\nlet sum = C.sum\nlet exists = C.exists\nlet mem = C.mem\nlet for_all = C.for_all\nlet find_map = C.find_map\nlet find = C.find\nlet to_list = C.to_list\nlet min_elt = C.min_elt\nlet max_elt = C.max_elt\nlet fold_result = C.fold_result\nlet fold_until = C.fold_until\n\nlet blit new_arr t =\n assert (not (is_empty t));\n let actual_front = actual_front_index_when_not_empty t in\n let actual_back = actual_back_index_when_not_empty t in\n let old_arr = t.arr in\n if actual_front <= actual_back\n then\n Option_array.blit\n ~src:old_arr\n ~dst:new_arr\n ~src_pos:actual_front\n ~dst_pos:0\n ~len:(length t)\n else (\n let break_pos = Option_array.length old_arr - actual_front in\n Option_array.blit\n ~src:old_arr\n ~dst:new_arr\n ~src_pos:actual_front\n ~dst_pos:0\n ~len:break_pos;\n Option_array.blit\n ~src:old_arr\n ~dst:new_arr\n ~src_pos:0\n ~dst_pos:break_pos\n ~len:(actual_back + 1));\n (* length depends on t.arr and t.front_index, so this needs to be first *)\n t.back_index <- length t;\n t.arr <- new_arr;\n t.arr_length <- Option_array.length new_arr;\n t.front_index <- Option_array.length new_arr - 1;\n (* Since t.front_index = Option_array.length new_arr - 1, this is asserting that t.back_index\n is a valid index in the array and that the array can support at least one more\n element -- recall, if t.front_index = t.back_index then the array is full.\n\n Note that this is true if and only if Option_array.length new_arr > length t + 1.\n *)\n assert (t.front_index > t.back_index)\n;;\n\nlet maybe_shrink_underlying t =\n if (not t.never_shrink) && t.arr_length > 10 && t.arr_length / 3 > length t\n then (\n let new_arr = Option_array.create ~len:(t.arr_length / 2) in\n blit new_arr t)\n;;\n\nlet grow_underlying t =\n let new_arr = Option_array.create ~len:(t.arr_length * 2) in\n blit new_arr t\n;;\n\nlet enqueue_back t v =\n if t.front_index = t.back_index then grow_underlying t;\n Option_array.set_some t.arr t.back_index v;\n t.back_index <- (if t.back_index = t.arr_length - 1 then 0 else t.back_index + 1);\n t.length <- t.length + 1\n;;\n\nlet enqueue_front t v =\n if t.front_index = t.back_index then grow_underlying t;\n Option_array.set_some t.arr t.front_index v;\n t.front_index <- (if t.front_index = 0 then t.arr_length - 1 else t.front_index - 1);\n t.apparent_front_index <- t.apparent_front_index - 1;\n t.length <- t.length + 1\n;;\n\nlet enqueue t back_or_front v =\n match back_or_front with\n | `back -> enqueue_back t v\n | `front -> enqueue_front t v\n;;\n\nlet peek_front_nonempty t =\n Option_array.get_some_exn t.arr (actual_front_index_when_not_empty t)\n;;\n\nlet peek_front_exn t =\n if is_empty t\n then failwith \"Deque.peek_front_exn passed an empty queue\"\n else peek_front_nonempty t\n;;\n\nlet peek_front t = if is_empty t then None else Some (peek_front_nonempty t)\n\nlet peek_back_nonempty t =\n Option_array.get_some_exn t.arr (actual_back_index_when_not_empty t)\n;;\n\nlet peek_back_exn t =\n if is_empty t\n then failwith \"Deque.peek_back_exn passed an empty queue\"\n else peek_back_nonempty t\n;;\n\nlet peek_back t = if is_empty t then None else Some (peek_back_nonempty t)\n\nlet peek t back_or_front =\n match back_or_front with\n | `back -> peek_back t\n | `front -> peek_front t\n;;\n\nlet dequeue_front_nonempty t =\n let i = actual_front_index_when_not_empty t in\n let res = Option_array.get_some_exn t.arr i in\n Option_array.set_none t.arr i;\n t.front_index <- i;\n t.apparent_front_index <- t.apparent_front_index + 1;\n t.length <- t.length - 1;\n maybe_shrink_underlying t;\n res\n;;\n\nlet dequeue_front_exn t =\n if is_empty t\n then failwith \"Deque.dequeue_front_exn passed an empty queue\"\n else dequeue_front_nonempty t\n;;\n\nlet dequeue_front t = if is_empty t then None else Some (dequeue_front_nonempty t)\n\nlet dequeue_back_nonempty t =\n let i = actual_back_index_when_not_empty t in\n let res = Option_array.get_some_exn t.arr i in\n Option_array.set_none t.arr i;\n t.back_index <- i;\n t.length <- t.length - 1;\n maybe_shrink_underlying t;\n res\n;;\n\nlet dequeue_back_exn t =\n if is_empty t\n then failwith \"Deque.dequeue_back_exn passed an empty queue\"\n else dequeue_back_nonempty t\n;;\n\nlet dequeue_back t = if is_empty t then None else Some (dequeue_back_nonempty t)\n\nlet dequeue_exn t back_or_front =\n match back_or_front with\n | `front -> dequeue_front_exn t\n | `back -> dequeue_back_exn t\n;;\n\nlet dequeue t back_or_front =\n match back_or_front with\n | `front -> dequeue_front t\n | `back -> dequeue_back t\n;;\n\nlet drop_gen ?(n = 1) ~dequeue t =\n if n < 0 then invalid_argf \"Deque.drop: negative input (%d)\" n ();\n let rec loop n =\n if n > 0\n then (\n match dequeue t with\n | None -> ()\n | Some _ -> loop (n - 1))\n in\n loop n\n;;\n\nlet drop_front ?n t = drop_gen ?n ~dequeue:dequeue_front t\nlet drop_back ?n t = drop_gen ?n ~dequeue:dequeue_back t\n\nlet drop ?n t back_or_front =\n match back_or_front with\n | `back -> drop_back ?n t\n | `front -> drop_front ?n t\n;;\n\nlet assert_not_empty t name = if is_empty t then failwithf \"%s: Deque.t is empty\" name ()\n\nlet true_index_exn t i =\n let i_from_zero = i - t.apparent_front_index in\n if i_from_zero < 0 || length t <= i_from_zero\n then (\n assert_not_empty t \"Deque.true_index_exn\";\n let apparent_front = apparent_front_index_when_not_empty t in\n let apparent_back = apparent_back_index_when_not_empty t in\n invalid_argf\n \"invalid index: %i for array with indices (%i,%i)\"\n i\n apparent_front\n apparent_back\n ());\n let true_i = t.front_index + 1 + i_from_zero in\n if true_i >= t.arr_length then true_i - t.arr_length else true_i\n;;\n\nlet get t i = Option_array.get_some_exn t.arr (true_index_exn t i)\n\nlet get_opt t i =\n try Some (get t i) with\n | _ -> None\n;;\n\nlet set_exn t i v = Option_array.set_some t.arr (true_index_exn t i) v\n\nlet to_array t =\n match peek_front t with\n | None -> [||]\n | Some front ->\n let arr = Array.create ~len:(length t) front in\n ignore\n (fold t ~init:0 ~f:(fun i v ->\n arr.(i) <- v;\n i + 1)\n : int);\n arr\n;;\n\nlet of_array arr =\n let t = create ~initial_length:(Array.length arr + 1) () in\n Array.iter arr ~f:(fun v -> enqueue_back t v);\n t\n;;\n\ninclude Bin_prot.Utils.Make_iterable_binable1 (struct\n type nonrec 'a t = 'a t\n type 'a el = 'a [@@deriving bin_io]\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"34c1e9ca-4992-11e6-a686-8b4bd4f87796\"\n ;;\n\n let module_name = Some \"Core_kernel.Deque\"\n let length = length\n let iter t ~f = iter t ~f\n\n let init ~len ~next =\n let t = create ~initial_length:len () in\n for _i = 0 to len - 1 do\n let x = next () in\n enqueue_back t x\n done;\n t\n ;;\n end)\n\nlet t_of_sexp f sexp = of_array (Array.t_of_sexp f sexp)\nlet sexp_of_t f t = Array.sexp_of_t f (to_array t)\n\n(* re-expose these here under a different name to avoid internal confusion *)\nlet back_index = apparent_back_index\nlet front_index = apparent_front_index\n\nlet back_index_exn t =\n assert_not_empty t \"Deque.back_index_exn\";\n apparent_back_index_when_not_empty t\n;;\n\nlet front_index_exn t =\n assert_not_empty t \"Deque.front_index_exn\";\n apparent_front_index_when_not_empty t\n;;\n\nmodule Binary_searchable = Test_binary_searchable.Make1_and_test (struct\n type nonrec 'a t = 'a t\n\n let get t i = get t (front_index_exn t + i)\n let length = length\n\n module For_test = struct\n let of_array = of_array\n end\n end)\n\n(* The \"stable\" indices used in this module make the application of the\n [Binary_searchable] functor awkward. We need to be sure to translate incoming\n positions from stable space to the expected 0 -> length - 1 space and then we need to\n translate them back on return. *)\nlet binary_search ?pos ?len t ~compare how v =\n let pos =\n match pos with\n | None -> None\n | Some pos -> Some (pos - t.apparent_front_index)\n in\n match Binary_searchable.binary_search ?pos ?len t ~compare how v with\n | None -> None\n | Some untranslated_i -> Some (t.apparent_front_index + untranslated_i)\n;;\n\nlet binary_search_segmented ?pos ?len t ~segment_of how =\n let pos =\n match pos with\n | None -> None\n | Some pos -> Some (pos - t.apparent_front_index)\n in\n match Binary_searchable.binary_search_segmented ?pos ?len t ~segment_of how with\n | None -> None\n | Some untranslated_i -> Some (t.apparent_front_index + untranslated_i)\n;;\n","open! Import\nmodule List = Base.List\nmodule String = Base.String\n\nlet eprint message = Printf.eprintf \"%s\\n%!\" message\nlet eprint_s sexp = eprint (Sexp.to_string_hum sexp)\nlet eprints message a sexp_of_a = eprint_s ([%sexp_of: string * a] (message, a))\nlet eprintf format = Printf.ksprintf eprint format\nlet failwiths = Error.failwiths\n\nmodule Make () = struct\n let check_invariant = ref true\n let show_messages = ref true\n\n let debug invariant ~module_name name ts arg sexp_of_arg sexp_of_result f =\n if !show_messages\n then eprints (String.concat ~sep:\"\" [ module_name; \".\"; name ]) arg sexp_of_arg;\n if !check_invariant\n then (\n try List.iter ts ~f:invariant with\n | exn ->\n failwiths\n ~here:[%here]\n \"invariant pre-condition failed\"\n (name, exn)\n [%sexp_of: string * exn]);\n let result_or_exn = Result.try_with f in\n if !check_invariant\n then (\n try List.iter ts ~f:invariant with\n | exn ->\n failwiths\n ~here:[%here]\n \"invariant post-condition failed\"\n (name, exn)\n [%sexp_of: string * exn]);\n if !show_messages\n then\n eprints\n (String.concat ~sep:\"\" [ module_name; \".\"; name; \"-result\" ])\n result_or_exn\n [%sexp_of: (result, exn) Result.t];\n Result.ok_exn result_or_exn\n ;;\nend\n\nlet should_print_backtrace = ref false\n\nlet am_internal here message =\n (* In this function we use [Printf.eprintf] rather than [Debug.eprintf], because the\n former doesn't flush, while the latter does. We'd rather flush once at the end,\n rather than three times. *)\n Printf.eprintf \"%s:\\n\" (Source_code_position.to_string here);\n if !should_print_backtrace\n then\n Printf.eprintf\n \"%s\\n\"\n (Backtrace.get () |> [%sexp_of: Backtrace.t] |> Sexp.to_string_hum);\n (match message with\n | None -> ()\n | Some message -> Printf.eprintf \"%s\\n\" message);\n Printf.eprintf \"%!\"\n;;\n\nlet am here = am_internal here None\nlet amf here fmt = Printf.ksprintf (fun string -> am_internal here (Some string)) fmt\n\nlet ams here message a sexp_of_a =\n am_internal here (Some ((message, a) |> [%sexp_of: string * a] |> Sexp.to_string_hum))\n;;\n","(** Imperative set-like data structure.\n\n There are a few differences from simple sets:\n\n - Duplicates are allowed.\n - It doesn't require anything (hashable, comparable) of elements in the bag.\n - Addition and removal are constant time operations.\n\n It is an error to modify a bag ([add], [remove], [remove_one], ...) during iteration\n ([fold], [iter], ...). *)\n\nopen! Import\n\nmodule type S = sig\n module Elt : sig\n type 'a t\n\n val equal : 'a t -> 'a t -> bool\n val sexp_of_t : ('a -> Sexp.t) -> 'a t -> Sexp.t\n val value : 'a t -> 'a\n end\n\n type 'a t [@@deriving sexp]\n\n (** Much of a bag's interface comes from the generic {!Base.Container} module. *)\n include\n Container.S1 with type 'a t := 'a t\n\n include Invariant.S1 with type 'a t := 'a t\n\n (** [create ()] returns an empty bag. *)\n val create : unit -> 'a t\n\n (** [add t v] adds [v] to the bag [t], returning an element that can\n later be removed from the bag. [add] runs in constant time. *)\n val add : 'a t -> 'a -> 'a Elt.t\n\n val add_unit : 'a t -> 'a -> unit\n\n (** [mem_elt t elt] returns whether or not [elt] is in [t]. It is like [mem] (included\n from [Container]), but it takes an ['a Elt.t] instead of an ['a] and runs in constant\n time instead of linear time. *)\n val mem_elt : 'a t -> 'a Elt.t -> bool\n\n (** [remove t elt] removes [elt] from the bag [t], raising an exception if [elt]\n is not in the bag. [remove] runs in constant time. *)\n val remove : 'a t -> 'a Elt.t -> unit\n\n (** [choose t] returns some element in the bag. *)\n val choose : 'a t -> 'a Elt.t option\n\n (** [remove_one t] removes some element from the bag, and returns its value.\n [remove_one] runs in constant time. *)\n val remove_one : 'a t -> 'a option\n\n (** [clear t] removes all elements from the bag. [clear] runs in constant time. *)\n val clear : 'a t -> unit\n\n (** [filter_inplace t ~f] removes all the elements from [t] that don't satisfy [f]. *)\n val filter_inplace : 'a t -> f:('a -> bool) -> unit\n\n val iter_elt : 'a t -> f:('a Elt.t -> unit) -> unit\n\n (** [find_elt t ~f] returns the first element in the bag satisfying [f], returning [None]\n if none is found. *)\n val find_elt : 'a t -> f:('a -> bool) -> 'a Elt.t option\n\n (** [until_empty t f] repeatedly removes values [v] from [t], running [f v] on each one,\n until [t] is empty. Running [f] may add elements to [t] if it wants. *)\n val until_empty : 'a t -> ('a -> unit) -> unit\n\n (** [transfer ~src ~dst] moves all of the elements from [src] to [dst] in constant\n time. *)\n val transfer : src:'a t -> dst:'a t -> unit\n\n val of_list : 'a list -> 'a t\n val elts : 'a t -> 'a Elt.t list\n\n (** [unchecked_iter t ~f] behaves like [iter t ~f] except that [f] is allowed to modify\n [t]. Elements added by [f] may or may not be visited; elements removed by [f] that\n have not been visited will not be visited. It is an (undetected) error to delete the\n current element. *)\n val unchecked_iter : 'a t -> f:('a -> unit) -> unit\nend\n\nmodule type Bag = sig\n (** The module type of the Bag module.\n\n Example usage:\n {[\n module My_bag : Bag.S = Bag\n ]}\n\n Now [My_bag.Elt.t] can't be used with any other [Bag.t] type.\n *)\n module type S = S\n\n include S\nend\n","(*\n * Copyright (c) 2013 Jeremy Yallop.\n *\n * This file is distributed under the terms of the MIT License.\n * See the file LICENSE for details.\n *)\n\nmodule Pervasives = Pervasives [@@ocaml.warning \"-3\"]\n\nexternal init : unit -> unit = \"integers_unsigned_init\"\nlet () = init ()\n\n(* Boxed unsigned types *)\nmodule type Basics = sig\n type t\n\n val add : t -> t -> t\n val sub : t -> t -> t\n val mul : t -> t -> t\n val div : t -> t -> t\n val rem : t -> t -> t\n val max_int : t\n val logand : t -> t -> t\n val logor : t -> t -> t\n val logxor : t -> t -> t\n val shift_left : t -> int -> t\n val shift_right : t -> int -> t\n val of_int : int -> t\n val to_int : t -> int\n val of_int64 : int64 -> t\n val to_int64 : t -> int64\n val of_string : string -> t\n val to_string : t -> string\nend\n\n\nmodule type Extras = sig\n type t\n\n val zero : t\n val one : t\n val lognot : t -> t\n val succ : t -> t\n val pred : t -> t\n val compare : t -> t -> int\n val equal : t -> t -> bool\n val max : t -> t -> t\n val min : t -> t -> t\n val pp : Format.formatter -> t -> unit\nend\n\n\nmodule type Infix = sig\n type t\n val (+) : t -> t -> t\n val (-) : t -> t -> t\n val ( * ) : t -> t -> t\n val (/) : t -> t -> t\n val (mod) : t -> t -> t\n val (land) : t -> t -> t\n val (lor) : t -> t -> t\n val (lxor) : t -> t -> t\n val (lsl) : t -> int -> t\n val (lsr) : t -> int -> t\nend\n\n\nmodule type S = sig\n include Basics\n include Extras with type t := t\n\n module Infix : Infix with type t := t\nend\n\n\nmodule MakeInfix (B : Basics) =\nstruct\n open B\n let (+) = add\n let (-) = sub\n let ( * ) = mul\n let (/) = div\n let (mod) = rem\n let (land) = logand\n let (lor) = logor\n let (lxor) = logxor\n let (lsl) = shift_left\n let (lsr) = shift_right\nend\n\n\nmodule Extras(Basics : Basics) : Extras with type t := Basics.t =\nstruct\n open Basics\n let zero = of_int 0\n let one = of_int 1\n let succ n = add n one\n let pred n = sub n one\n let lognot n = logxor n max_int\n let compare (x : t) (y : t) = Pervasives.compare x y\n let equal (x : t) (y : t) = Pervasives.(=) x y\n let max (x : t) (y : t) = Pervasives.max x y\n let min (x : t) (y : t) = Pervasives.min x y\n let pp fmt x = Format.fprintf fmt \"%s\" (to_string x)\nend\n\n\nmodule UInt8 : S with type t = private int =\nstruct\n module B =\n struct\n type t = int\n let max_int = 255\n let add : t -> t -> t = fun x y -> (x + y) land max_int\n let sub : t -> t -> t = fun x y -> (x - y) land max_int\n let mul : t -> t -> t = fun x y -> (x * y) land max_int\n let div : t -> t -> t = (/)\n let rem : t -> t -> t = (mod)\n let logand: t -> t -> t = (land)\n let logor: t -> t -> t = (lor)\n let logxor : t -> t -> t = (lxor)\n let shift_left : t -> int -> t = fun x y -> (x lsl y) land max_int\n let shift_right : t -> int -> t = (lsr)\n let of_int (x: int): t =\n (* For backwards compatibility, this wraps *)\n x land max_int\n external to_int : t -> int = \"%identity\"\n let of_int64 : int64 -> t = fun x -> of_int (Int64.to_int x)\n let to_int64 : t -> int64 = fun x -> Int64.of_int (to_int x)\n external of_string : string -> t = \"integers_uint8_of_string\"\n let to_string : t -> string = string_of_int\n end\n include B\n include Extras(B)\n module Infix = MakeInfix(B)\nend\n\n\nmodule UInt16 : S with type t = private int =\nstruct\n module B =\n struct\n type t = int\n let max_int = 65535\n let add : t -> t -> t = fun x y -> (x + y) land max_int\n let sub : t -> t -> t = fun x y -> (x - y) land max_int\n let mul : t -> t -> t = fun x y -> (x * y) land max_int\n let div : t -> t -> t = (/)\n let rem : t -> t -> t = (mod)\n let logand: t -> t -> t = (land)\n let logor: t -> t -> t = (lor)\n let logxor : t -> t -> t = (lxor)\n let shift_left : t -> int -> t = fun x y -> (x lsl y) land max_int\n let shift_right : t -> int -> t = (lsr)\n let of_int (x: int): t =\n (* For backwards compatibility, this wraps *)\n x land max_int\n external to_int : t -> int = \"%identity\"\n let of_int64 : int64 -> t = fun x -> Int64.to_int x |> of_int\n let to_int64 : t -> int64 = fun x -> to_int x |> Int64.of_int\n external of_string : string -> t = \"integers_uint16_of_string\"\n let to_string : t -> string = string_of_int\n end\n include B\n include Extras(B)\n module Infix = MakeInfix(B)\nend\n\n\nmodule UInt32 : sig\n include S\n external of_int32 : int32 -> t = \"integers_uint32_of_int32\"\n external to_int32 : t -> int32 = \"integers_int32_of_uint32\"\nend = \nstruct\n module B =\n struct\n type t\n external add : t -> t -> t = \"integers_uint32_add\"\n external sub : t -> t -> t = \"integers_uint32_sub\"\n external mul : t -> t -> t = \"integers_uint32_mul\"\n external div : t -> t -> t = \"integers_uint32_div\"\n external rem : t -> t -> t = \"integers_uint32_rem\"\n external logand : t -> t -> t = \"integers_uint32_logand\"\n external logor : t -> t -> t = \"integers_uint32_logor\"\n external logxor : t -> t -> t = \"integers_uint32_logxor\"\n external shift_left : t -> int -> t = \"integers_uint32_shift_left\"\n external shift_right : t -> int -> t = \"integers_uint32_shift_right\"\n external of_int : int -> t = \"integers_uint32_of_int\"\n external to_int : t -> int = \"integers_uint32_to_int\"\n external of_int64 : int64 -> t = \"integers_uint32_of_int64\"\n external to_int64 : t -> int64 = \"integers_uint32_to_int64\"\n external of_string : string -> t = \"integers_uint32_of_string\"\n external to_string : t -> string = \"integers_uint32_to_string\"\n external _max_int : unit -> t = \"integers_uint32_max\"\n let max_int = _max_int ()\n end\n include B\n include Extras(B)\n module Infix = MakeInfix(B)\n external of_int32 : int32 -> t = \"integers_uint32_of_int32\"\n external to_int32 : t -> int32 = \"integers_int32_of_uint32\"\nend\n\n\nmodule UInt64 : sig\n include S\n external of_int64 : int64 -> t = \"integers_uint64_of_int64\"\n external to_int64 : t -> int64 = \"integers_uint64_to_int64\"\n external of_uint32 : UInt32.t -> t = \"integers_uint64_of_uint32\"\n external to_uint32 : t -> UInt32.t = \"integers_uint32_of_uint64\"\nend = \nstruct\n module B =\n struct\n type t\n external add : t -> t -> t = \"integers_uint64_add\"\n external sub : t -> t -> t = \"integers_uint64_sub\"\n external mul : t -> t -> t = \"integers_uint64_mul\"\n external div : t -> t -> t = \"integers_uint64_div\"\n external rem : t -> t -> t = \"integers_uint64_rem\"\n external logand : t -> t -> t = \"integers_uint64_logand\"\n external logor : t -> t -> t = \"integers_uint64_logor\"\n external logxor : t -> t -> t = \"integers_uint64_logxor\"\n external shift_left : t -> int -> t = \"integers_uint64_shift_left\"\n external shift_right : t -> int -> t = \"integers_uint64_shift_right\"\n external of_int : int -> t = \"integers_uint64_of_int\"\n external to_int : t -> int = \"integers_uint64_to_int\"\n external of_int64 : int64 -> t = \"integers_uint64_of_int64\"\n external to_int64 : t -> int64 = \"integers_uint64_to_int64\"\n external of_uint32 : UInt32.t -> t = \"integers_uint64_of_uint32\"\n external to_uint32 : t -> UInt32.t = \"integers_uint32_of_uint64\"\n external of_string : string -> t = \"integers_uint64_of_string\"\n external to_string : t -> string = \"integers_uint64_to_string\"\n external _max_int : unit -> t = \"integers_uint64_max\"\n let max_int = _max_int ()\n end\n include B\n include Extras(B)\n module Infix = MakeInfix(B)\nend\n\n\nlet of_byte_size : int -> (module S) = function\n | 1 -> (module UInt8)\n | 2 -> (module UInt16)\n | 4 -> (module UInt32)\n | 8 -> (module UInt64)\n | _ -> invalid_arg \"Unsigned.of_byte_size\"\n\n \nexternal size_t_size : unit -> int = \"integers_size_t_size\"\nexternal ushort_size : unit -> int = \"integers_ushort_size\"\nexternal uint_size : unit -> int = \"integers_uint_size\"\nexternal ulong_size : unit -> int = \"integers_ulong_size\"\nexternal ulonglong_size : unit -> int = \"integers_ulonglong_size\"\n\nmodule Size_t : S = (val of_byte_size (size_t_size ()))\nmodule UChar = UInt8\nmodule UShort : S = (val of_byte_size (ushort_size ()))\nmodule UInt : S = (val of_byte_size (uint_size ()))\nmodule ULong : S = (val of_byte_size (ulong_size ()))\nmodule ULLong : S = (val of_byte_size (ulonglong_size ()))\n\ntype uchar = UChar.t\ntype uint8 = UInt8.t\ntype uint16 = UInt16.t\ntype uint32 = UInt32.t\ntype uint64 = UInt64.t\ntype size_t = Size_t.t\ntype ushort = UShort.t\ntype uint = UInt.t\ntype ulong = ULong.t\ntype ullong = ULLong.t\n","exception Error of string\n\nlet error s = raise (Error s)\n\n\n(*\n Debugging utilities.\n*)\n\nlet string8_of_int x =\n let s = Bytes.create 8 in\n for i = 0 to 7 do\n Bytes.set s (7-i) (Char.chr (0xff land (x lsr (8 * i))))\n done;\n Bytes.to_string s\n\nlet string4_of_int x =\n let s = Bytes.create 4 in\n for i = 0 to 3 do\n Bytes.set s (3-i) (Char.chr (0xff land (x lsr (8 * i))))\n done;\n Bytes.to_string s\n\nlet print_bits ?(pos = 0) ?len s =\n let slen = String.length s in\n if pos < 0 || (pos > 0 && pos >= slen) then\n invalid_arg \"Bi_util.print_bits\";\n let len =\n match len with\n None -> slen - pos\n | Some len ->\n if len > slen - pos then invalid_arg \"Bi_util.print_bits\"\n else len\n in\n\n let r = Bytes.create (len * 9) in\n for i = 0 to len - 1 do\n let k = i * 9 in\n let x = Char.code s.[pos+i] in\n for j = 0 to 7 do\n Bytes.set r (k+j) (if (x lsr (7 - j)) land 1 = 0 then '0' else '1')\n done;\n Bytes.set r (k+8) (if (i + 1) mod 8 = 0 then '\\n' else ' ')\n done;\n Bytes.to_string r\n\n(* int size in bits *)\nlet int_size =\n let c = ref 0 in\n let r = ref (-1) in\n while !r <> 0 do\n r := !r lsr 1;\n incr c\n done;\n !c\n","type t = {\n mutable o_s : bytes;\n mutable o_max_len : int;\n mutable o_len : int;\n mutable o_offs : int;\n o_init_len : int;\n o_make_room : (t -> int -> unit);\n mutable o_shared : Bi_share.Wr.tbl;\n o_shared_init_len : int;\n}\n\nlet really_extend b n =\n let slen0 = b.o_max_len in\n let reqlen = b.o_len + n in\n let slen =\n let x = max reqlen (2 * slen0) in\n if x <= Sys.max_string_length then x\n else\n if Sys.max_string_length < reqlen then\n\tinvalid_arg \"Buf.extend: reached Sys.max_string_length\"\n else\n\tSys.max_string_length\n in\n let s = Bytes.create slen in\n Bytes.blit b.o_s 0 s 0 b.o_len;\n b.o_s <- s;\n b.o_max_len <- slen\n\nlet flush_to_output abstract_output b n =\n abstract_output (Bytes.to_string b.o_s) 0 b.o_len;\n b.o_offs <- b.o_offs + b.o_len;\n b.o_len <- 0;\n if n > b.o_max_len then\n really_extend b n\n\nlet flush_to_channel oc = flush_to_output (output_substring oc)\n\n\nlet create ?(make_room = really_extend) ?(shrlen = 16) n = {\n o_s = Bytes.create n;\n o_max_len = n;\n o_len = 0;\n o_offs = 0;\n o_init_len = n;\n o_make_room = make_room;\n o_shared = Bi_share.Wr.create shrlen;\n o_shared_init_len = shrlen;\n}\n\nlet create_channel_writer ?(len = 4096) ?shrlen oc =\n create ~make_room:(flush_to_channel oc) ?shrlen len\n\nlet flush_channel_writer b =\n b.o_make_room b 0\n\nlet create_output_writer ?(len = 4096) ?shrlen out =\n create ~make_room:(flush_to_output out#output) ?shrlen len\n\nlet flush_output_writer = flush_channel_writer\n\n\n(*\n Guarantee that the buffer string has enough room for n additional bytes.\n*)\nlet extend b n =\n if b.o_len + n > b.o_max_len then\n b.o_make_room b n\n\nlet alloc b n =\n extend b n;\n let pos = b.o_len in\n b.o_len <- pos + n;\n pos\n\nlet add_sub blit b s pos len =\n extend b len;\n blit s pos b.o_s b.o_len len;\n b.o_len <- b.o_len + len\n\nlet add_substring = add_sub String.blit\nlet add_subbytes = add_sub Bytes.blit\n\nlet add_string b s =\n add_substring b s 0 (String.length s)\n\nlet add_bytes b s =\n add_subbytes b s 0 (Bytes.length s)\n\n\nlet add_char b c =\n let pos = alloc b 1 in\n Bytes.set b.o_s pos c\n\nlet unsafe_add_char b c =\n let len = b.o_len in\n Bytes.set b.o_s len c;\n b.o_len <- len + 1\n\nlet add_char2 b c1 c2 =\n let pos = alloc b 2 in\n let s = b.o_s in\n Bytes.unsafe_set s pos c1;\n Bytes.unsafe_set s (pos+1) c2\n\nlet add_char4 b c1 c2 c3 c4 =\n let pos = alloc b 4 in\n let s = b.o_s in\n Bytes.unsafe_set s pos c1;\n Bytes.unsafe_set s (pos+1) c2;\n Bytes.unsafe_set s (pos+2) c3;\n Bytes.unsafe_set s (pos+3) c4\n\n\n\nlet clear b =\n b.o_offs <- 0;\n b.o_len <- 0;\n Bi_share.Wr.clear b.o_shared\n\nlet reset b =\n if Bytes.length b.o_s <> b.o_init_len then\n b.o_s <- Bytes.create b.o_init_len;\n b.o_offs <- 0;\n b.o_len <- 0;\n b.o_shared <- Bi_share.Wr.create b.o_shared_init_len\n\nlet contents b = Bytes.sub_string b.o_s 0 b.o_len\n","type type_id = int\n\nlet dummy_type_id = 0\n\nlet create_type_id =\n let n = ref dummy_type_id in\n fun () ->\n incr n;\n if !n < 0 then\n failwith \"Bi_share.Rd_poly.create_type_id: \\\n exhausted available type_id's\"\n else\n !n\n\nmodule Wr =\nstruct\n module H = Hashtbl.Make (\n struct\n type t = Obj.t * type_id\n let equal (x1, t1) (x2, t2) = x1 == x2 && t1 == t2\n let hash = Hashtbl.hash\n end\n )\n\n type tbl = int H.t\n\n let create = H.create\n let clear tbl =\n if H.length tbl > 0 then\n H.clear tbl\n\n let put tbl k pos =\n try\n let pos0 = H.find tbl (Obj.magic k) in\n pos - pos0\n with Not_found ->\n H.add tbl (Obj.magic k) pos;\n 0\nend\n\nmodule Rd =\nstruct\n type tbl = ((int * type_id), Obj.t) Hashtbl.t\n\n let create n = Hashtbl.create n\n let clear = Hashtbl.clear\n\n let put tbl pos x =\n Hashtbl.add tbl pos x\n\n let get tbl pos =\n try Hashtbl.find tbl pos\n with Not_found ->\n Bi_util.error \"Corrupted data (invalid reference)\"\nend\n","include Ppx_deriving_runtime\n\nlet (>>=) x f =\n match x with Result.Ok x -> f x | (Result.Error _) as x -> x\n\nlet (>|=) x f =\n x >>= fun x -> Result.Ok (f x)\n\nlet rec map_bind f acc xs =\n match xs with\n | x :: xs -> f x >>= fun x -> map_bind f (x :: acc) xs\n | [] -> Result.Ok (List.rev acc)\n\ntype 'a error_or = ('a, string) Result.result\n\n(** [safe_map f l] returns the same value as [List.map f l], but\n computes it tail-recursively so that large list lengths don't\n cause a stack overflow *)\nlet safe_map f l = List.rev (List.rev_map f l)\n","(* This file is generated automatically with ocaml_gen. *)\n\nmodule BigInt256 = struct\n type nonrec t\n\n external of_numeral : string -> int -> int -> t = \"caml_bigint_256_of_numeral\"\n\n external of_decimal_string : string -> t = \"caml_bigint_256_of_decimal_string\"\n\n external num_limbs : unit -> int = \"caml_bigint_256_num_limbs\"\n\n external bytes_per_limb : unit -> int = \"caml_bigint_256_bytes_per_limb\"\n\n external div : t -> t -> t = \"caml_bigint_256_div\"\n\n external compare : t -> t -> int = \"caml_bigint_256_compare\"\n\n external print : t -> unit = \"caml_bigint_256_print\"\n\n external to_string : t -> string = \"caml_bigint_256_to_string\"\n\n external test_bit : t -> int -> bool = \"caml_bigint_256_test_bit\"\n\n external to_bytes : t -> bytes = \"caml_bigint_256_to_bytes\"\n\n external of_bytes : bytes -> t = \"caml_bigint_256_of_bytes\"\n\n external deep_copy : t -> t = \"caml_bigint_256_deep_copy\"\nend\n\nmodule Fp = struct\n type nonrec t\n\n external size_in_bits : unit -> int = \"caml_pasta_fp_size_in_bits\"\n\n external size : unit -> BigInt256.t = \"caml_pasta_fp_size\"\n\n external add : t -> t -> t = \"caml_pasta_fp_add\"\n\n external sub : t -> t -> t = \"caml_pasta_fp_sub\"\n\n external negate : t -> t = \"caml_pasta_fp_negate\"\n\n external mul : t -> t -> t = \"caml_pasta_fp_mul\"\n\n external div : t -> t -> t = \"caml_pasta_fp_div\"\n\n external inv : t -> t option = \"caml_pasta_fp_inv\"\n\n external square : t -> t = \"caml_pasta_fp_square\"\n\n external is_square : t -> bool = \"caml_pasta_fp_is_square\"\n\n external sqrt : t -> t option = \"caml_pasta_fp_sqrt\"\n\n external of_int : int -> t = \"caml_pasta_fp_of_int\"\n\n external to_string : t -> string = \"caml_pasta_fp_to_string\"\n\n external of_string : string -> t = \"caml_pasta_fp_of_string\"\n\n external print : t -> unit = \"caml_pasta_fp_print\"\n\n external copy : t -> t -> unit = \"caml_pasta_fp_copy\"\n\n external mut_add : t -> t -> unit = \"caml_pasta_fp_mut_add\"\n\n external mut_sub : t -> t -> unit = \"caml_pasta_fp_mut_sub\"\n\n external mut_mul : t -> t -> unit = \"caml_pasta_fp_mut_mul\"\n\n external mut_square : t -> unit = \"caml_pasta_fp_mut_square\"\n\n external compare : t -> t -> int = \"caml_pasta_fp_compare\"\n\n external equal : t -> t -> bool = \"caml_pasta_fp_equal\"\n\n external random : unit -> t = \"caml_pasta_fp_random\"\n\n external rng : int -> t = \"caml_pasta_fp_rng\"\n\n external to_bigint : t -> BigInt256.t = \"caml_pasta_fp_to_bigint\"\n\n external of_bigint : BigInt256.t -> t = \"caml_pasta_fp_of_bigint\"\n\n external two_adic_root_of_unity : unit -> t\n = \"caml_pasta_fp_two_adic_root_of_unity\"\n\n external domain_generator : int -> t = \"caml_pasta_fp_domain_generator\"\n\n external to_bytes : t -> bytes = \"caml_pasta_fp_to_bytes\"\n\n external of_bytes : bytes -> t = \"caml_pasta_fp_of_bytes\"\n\n external deep_copy : t -> t = \"caml_pasta_fp_deep_copy\"\nend\n\nmodule Fq = struct\n type nonrec t\n\n external size_in_bits : unit -> int = \"caml_pasta_fq_size_in_bits\"\n\n external size : unit -> BigInt256.t = \"caml_pasta_fq_size\"\n\n external add : t -> t -> t = \"caml_pasta_fq_add\"\n\n external sub : t -> t -> t = \"caml_pasta_fq_sub\"\n\n external negate : t -> t = \"caml_pasta_fq_negate\"\n\n external mul : t -> t -> t = \"caml_pasta_fq_mul\"\n\n external div : t -> t -> t = \"caml_pasta_fq_div\"\n\n external inv : t -> t option = \"caml_pasta_fq_inv\"\n\n external square : t -> t = \"caml_pasta_fq_square\"\n\n external is_square : t -> bool = \"caml_pasta_fq_is_square\"\n\n external sqrt : t -> t option = \"caml_pasta_fq_sqrt\"\n\n external of_int : int -> t = \"caml_pasta_fq_of_int\"\n\n external to_string : t -> string = \"caml_pasta_fq_to_string\"\n\n external of_string : string -> t = \"caml_pasta_fq_of_string\"\n\n external print : t -> unit = \"caml_pasta_fq_print\"\n\n external copy : t -> t -> unit = \"caml_pasta_fq_copy\"\n\n external mut_add : t -> t -> unit = \"caml_pasta_fq_mut_add\"\n\n external mut_sub : t -> t -> unit = \"caml_pasta_fq_mut_sub\"\n\n external mut_mul : t -> t -> unit = \"caml_pasta_fq_mut_mul\"\n\n external mut_square : t -> unit = \"caml_pasta_fq_mut_square\"\n\n external compare : t -> t -> int = \"caml_pasta_fq_compare\"\n\n external equal : t -> t -> bool = \"caml_pasta_fq_equal\"\n\n external random : unit -> t = \"caml_pasta_fq_random\"\n\n external rng : int -> t = \"caml_pasta_fq_rng\"\n\n external to_bigint : t -> BigInt256.t = \"caml_pasta_fq_to_bigint\"\n\n external of_bigint : BigInt256.t -> t = \"caml_pasta_fq_of_bigint\"\n\n external two_adic_root_of_unity : unit -> t\n = \"caml_pasta_fq_two_adic_root_of_unity\"\n\n external domain_generator : int -> t = \"caml_pasta_fq_domain_generator\"\n\n external to_bytes : t -> bytes = \"caml_pasta_fq_to_bytes\"\n\n external of_bytes : bytes -> t = \"caml_pasta_fq_of_bytes\"\n\n external deep_copy : t -> t = \"caml_pasta_fq_deep_copy\"\nend\n\nmodule Vesta = struct\n module BaseField = struct\n type nonrec t = Fq.t\n end\n\n module ScalarField = struct\n type nonrec t = Fp.t\n end\n\n module Affine = struct\n type nonrec t = Fq.t Kimchi_types.or_infinity\n end\n\n type nonrec t\n\n external one : unit -> t = \"caml_vesta_one\"\n\n external add : t -> t -> t = \"caml_vesta_add\"\n\n external sub : t -> t -> t = \"caml_vesta_sub\"\n\n external negate : t -> t = \"caml_vesta_negate\"\n\n external double : t -> t = \"caml_vesta_double\"\n\n external scale : t -> Fp.t -> t = \"caml_vesta_scale\"\n\n external random : unit -> t = \"caml_vesta_random\"\n\n external rng : int -> t = \"caml_vesta_rng\"\n\n external endo_base : unit -> Fq.t = \"caml_vesta_endo_base\"\n\n external endo_scalar : unit -> Fp.t = \"caml_vesta_endo_scalar\"\n\n external to_affine : t -> Fq.t Kimchi_types.or_infinity\n = \"caml_vesta_to_affine\"\n\n external of_affine : Fq.t Kimchi_types.or_infinity -> t\n = \"caml_vesta_of_affine\"\n\n external of_affine_coordinates : Fq.t -> Fq.t -> t\n = \"caml_vesta_of_affine_coordinates\"\n\n external deep_copy :\n Fq.t Kimchi_types.or_infinity -> Fq.t Kimchi_types.or_infinity\n = \"caml_vesta_affine_deep_copy\"\nend\n\nmodule Pallas = struct\n module BaseField = struct\n type nonrec t = Fp.t\n end\n\n module ScalarField = struct\n type nonrec t = Fq.t\n end\n\n module Affine = struct\n type nonrec t = Fp.t Kimchi_types.or_infinity\n end\n\n type nonrec t\n\n external one : unit -> t = \"caml_pallas_one\"\n\n external add : t -> t -> t = \"caml_pallas_add\"\n\n external sub : t -> t -> t = \"caml_pallas_sub\"\n\n external negate : t -> t = \"caml_pallas_negate\"\n\n external double : t -> t = \"caml_pallas_double\"\n\n external scale : t -> Fq.t -> t = \"caml_pallas_scale\"\n\n external random : unit -> t = \"caml_pallas_random\"\n\n external rng : int -> t = \"caml_pallas_rng\"\n\n external endo_base : unit -> Fp.t = \"caml_pallas_endo_base\"\n\n external endo_scalar : unit -> Fq.t = \"caml_pallas_endo_scalar\"\n\n external to_affine : t -> Fp.t Kimchi_types.or_infinity\n = \"caml_pallas_to_affine\"\n\n external of_affine : Fp.t Kimchi_types.or_infinity -> t\n = \"caml_pallas_of_affine\"\n\n external of_affine_coordinates : Fp.t -> Fp.t -> t\n = \"caml_pallas_of_affine_coordinates\"\n\n external deep_copy :\n Fp.t Kimchi_types.or_infinity -> Fp.t Kimchi_types.or_infinity\n = \"caml_pallas_affine_deep_copy\"\nend\n","open Core_kernel\n\ntype 'a t = 'a * 'a [@@deriving bin_io, sexp, eq, compare]\n\nlet map (x1, x2) ~f = (f x1, f x2)\n\nlet map2 (x1, x2) (y1, y2) ~f = (f x1 y1, f x2 y2)\n\nlet iter (x1, x2) ~f = f x1 ; f x2\n","open Core_kernel\n\nmodule type S = sig\n type 'a t [@@deriving bin_io, sexp, eq, compare]\n\n val iter : 'a t -> f:('a -> unit) -> unit\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val map2 : 'a t -> 'b t -> f:('a -> 'b -> 'c) -> 'c t\nend\n","open Core_kernel\n\ntype t = Zero | One | Two | Three [@@deriving sexp, eq, bin_io, hash]\n\nlet of_bits_lsb : bool Double.t -> t = function\n | false, false ->\n Zero\n | true, false ->\n One\n | false, true ->\n Two\n | true, true ->\n Three\n","open Core_kernel\n\ntype 'a t = 'a * 'a * 'a * 'a [@@deriving bin_io, sexp, eq, compare]\n\nlet get ((x0, x1, x2, x3) : 'a t) (i : Four.t) =\n match i with Zero -> x0 | One -> x1 | Two -> x2 | Three -> x3\n\nlet map (x1, x2, x3, x4) ~f = (f x1, f x2, f x3, f x4)\n\nlet map2 (x1, x2, x3, x4) (y1, y2, y3, y4) ~f =\n (f x1 y1, f x2 y2, f x3 y3, f x4 y4)\n\nlet iter (x1, x2, x3, x4) ~f = f x1 ; f x2 ; f x3 ; f x4\n","open Core_kernel\n\ntype 'a t = 'a * 'a * 'a [@@deriving bin_io, sexp, eq, compare]\n\nlet map (x1, x2, x3) ~f = (f x1, f x2, f x3)\n\nlet map2 (x1, x2, x3) (y1, y2, y3) ~f = (f x1 y1, f x2 y2, f x3 y3)\n\nlet iter (x1, x2, x3) ~f = f x1 ; f x2 ; f x3\n","module Double = Double\nmodule Triple = Triple\nmodule Quadruple = Quadruple\nmodule Four = Four\n","(* bits.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Fold_lib\nopen Bitstring_lib\n\n(* Someday: Make more efficient by giving Field.unpack a length argument in\n camlsnark *)\nlet unpack_field unpack ~bit_length x = List.take (unpack x) bit_length\n\nlet bits_per_char = 8\n\nlet pad (type a) ~length ~default (bs : a Bitstring.Lsb_first.t) =\n let bs = (bs :> a list) in\n let padding = length - List.length bs in\n assert (padding >= 0) ;\n bs @ List.init padding ~f:(fun _ -> default)\n\nmodule Vector = struct\n module type Basic = sig\n type t\n\n val length : int\n\n val get : t -> int -> bool\n\n val set : t -> int -> bool -> t\n end\n\n module type S = sig\n include Basic\n\n val empty : t\n\n val set : t -> int -> bool -> t\n end\n\n module UInt64 : S with type t = Unsigned.UInt64.t = struct\n open Unsigned.UInt64.Infix\n include Unsigned.UInt64\n\n let length = 64\n\n let empty = zero\n\n let get t i = equal ((t lsr i) land one) one\n\n let set t i b = if b then t lor (one lsl i) else t land lognot (one lsl i)\n end\n\n module UInt32 : S with type t = Unsigned.UInt32.t = struct\n open Unsigned.UInt32.Infix\n include Unsigned.UInt32\n\n let length = 32\n\n let empty = zero\n\n let get t i = equal ((t lsr i) land one) one\n\n let set t i b = if b then t lor (one lsl i) else t land lognot (one lsl i)\n end\n\n module Make (V : S) : Bits_intf.Convertible_bits with type t = V.t = struct\n type t = V.t\n\n let fold t =\n { Fold.fold =\n (fun ~init ~f ->\n let rec go acc i =\n if i = V.length then acc else go (f acc (V.get t i)) (i + 1)\n in\n go init 0 )\n }\n\n let iter t ~f =\n for i = 0 to V.length - 1 do\n f (V.get t i)\n done\n\n let to_bits t = List.init V.length ~f:(V.get t)\n\n let of_bits bools =\n List.foldi bools ~init:V.empty ~f:(fun i t bool -> V.set t i bool)\n\n let size_in_bits = V.length\n end\nend\n\nmodule UInt64 : Bits_intf.Convertible_bits with type t := Unsigned.UInt64.t =\n Vector.Make (Vector.UInt64)\n\nmodule UInt32 : Bits_intf.Convertible_bits with type t := Unsigned.UInt32.t =\n Vector.Make (Vector.UInt32)\n\n[%%ifdef consensus_mechanism]\n\nmodule type Big_int_intf = sig\n include Snarky_backendless.Bigint_intf.S\n\n val to_field : t -> field\nend\n\nmodule Make_field0\n (Field : Snarky_backendless.Field_intf.S)\n (Bigint : Big_int_intf with type field := Field.t) (M : sig\n val bit_length : int\n end) : Bits_intf.S with type t = Field.t = struct\n open M\n\n type t = Field.t\n\n let fold t =\n { Fold.fold =\n (fun ~init ~f ->\n let n = Bigint.of_field t in\n let rec go acc i =\n if i = bit_length then acc\n else go (f acc (Bigint.test_bit n i)) (i + 1)\n in\n go init 0 )\n }\n\n let iter t ~f =\n let n = Bigint.of_field t in\n for i = 0 to bit_length - 1 do\n f (Bigint.test_bit n i)\n done\n\n let to_bits t =\n let n = Bigint.of_field t in\n let rec go acc i =\n if i < 0 then acc else go (Bigint.test_bit n i :: acc) (i - 1)\n in\n go [] (bit_length - 1)\n\n let size_in_bits = bit_length\nend\n\nmodule Make_field\n (Field : Snarky_backendless.Field_intf.S)\n (Bigint : Big_int_intf with type field := Field.t) :\n Bits_intf.S with type t = Field.t =\n Make_field0 (Field) (Bigint)\n (struct\n let bit_length = Field.size_in_bits\n end)\n\nmodule Small\n (Field : Snarky_backendless.Field_intf.S)\n (Bigint : Big_int_intf with type field := Field.t) (M : sig\n val bit_length : int\n end) : Bits_intf.S with type t = Field.t = struct\n let () = assert (M.bit_length < Field.size_in_bits)\n\n include Make_field0 (Field) (Bigint) (M)\nend\n\nmodule Snarkable = struct\n module Small_bit_vector\n (Impl : Snarky_backendless.Snark_intf.S) (V : sig\n type t\n\n val empty : t\n\n val length : int\n\n val get : t -> int -> bool\n\n val set : t -> int -> bool -> t\n end) :\n Bits_intf.Snarkable.Small\n with type ('a, 'b) typ := ('a, 'b) Impl.Typ.t\n and type 'a checked := 'a Impl.Checked.t\n and type boolean_var := Impl.Boolean.var\n and type field_var := Impl.Field.Var.t\n and type Packed.var = Impl.Field.Var.t\n and type Packed.value = V.t\n and type Unpacked.var = Impl.Boolean.var list\n and type Unpacked.value = V.t\n and type comparison_result := Impl.Field.Checked.comparison_result =\n struct\n open Impl\n\n let bit_length = V.length\n\n let () = assert (bit_length < Field.size_in_bits)\n\n let size_in_bits = bit_length\n\n let init ~f =\n let rec go acc i =\n if i = V.length then acc else go (V.set acc i (f i)) (i + 1)\n in\n go V.empty 0\n\n module Packed = struct\n type var = Field.Var.t\n\n type value = V.t\n\n let typ : (var, value) Typ.t =\n Field.typ\n |> Typ.transport\n ~there:(fun t ->\n let rec go two_to_the_i i acc =\n if i = V.length then acc\n else\n let acc =\n if V.get t i then Field.add two_to_the_i acc else acc\n in\n go (Field.add two_to_the_i two_to_the_i) (i + 1) acc\n in\n go Field.one 0 Field.zero )\n ~back:(fun t ->\n let n = Bigint.of_field t in\n init ~f:(fun i -> Bigint.test_bit n i) )\n\n let size_in_bits = size_in_bits\n end\n\n let v_to_list n v =\n List.init n ~f:(fun i -> if i < V.length then V.get v i else false)\n\n let v_of_list vs =\n List.foldi vs ~init:V.empty ~f:(fun i acc b ->\n if i < V.length then V.set acc i b else acc )\n\n let pack_var = Field.Var.project\n\n let pack_value = Fn.id\n\n module Unpacked = struct\n type var = Boolean.var list\n\n type value = V.t\n\n let typ : (var, value) Typ.t =\n Typ.transport\n (Typ.list ~length:V.length Boolean.typ)\n ~there:(v_to_list V.length) ~back:v_of_list\n\n let var_to_bits = Bitstring.Lsb_first.of_list\n\n let var_of_bits = pad ~length:V.length ~default:Boolean.false_\n\n let var_to_triples (bs : var) =\n Bitstring_lib.Bitstring.pad_to_triple_list ~default:Boolean.false_ bs\n\n let var_of_value v =\n List.init V.length ~f:(fun i -> Boolean.var_of_value (V.get v i))\n\n let size_in_bits = size_in_bits\n end\n\n let unpack_var x = Impl.Field.Checked.unpack x ~length:bit_length\n\n let var_of_field = unpack_var\n\n let var_of_field_unsafe = Fn.id\n\n let unpack_value (x : Packed.value) : Unpacked.value = x\n\n let compare_var x y =\n Impl.Field.Checked.compare ~bit_length:V.length (pack_var x) (pack_var y)\n\n let%snarkydef_ increment_if_var bs (b : Boolean.var) =\n let open Impl in\n let v = Field.Var.pack bs in\n let v' = Field.Var.add v (b :> Field.Var.t) in\n Field.Checked.unpack v' ~length:V.length\n\n let%snarkydef_ increment_var bs =\n let open Impl in\n let v = Field.Var.pack bs in\n let v' = Field.Var.add v (Field.Var.constant Field.one) in\n Field.Checked.unpack v' ~length:V.length\n\n let%snarkydef_ equal_var (n : Unpacked.var) (n' : Unpacked.var) =\n Field.Checked.equal (pack_var n) (pack_var n')\n\n let%snarkydef_ assert_equal_var (n : Unpacked.var) (n' : Unpacked.var) =\n Field.Checked.Assert.equal (pack_var n) (pack_var n')\n\n let if_ (cond : Boolean.var) ~(then_ : Unpacked.var) ~(else_ : Unpacked.var)\n : Unpacked.var Checked.t =\n match\n List.map2 then_ else_ ~f:(fun then_ else_ ->\n Boolean.if_ cond ~then_ ~else_ )\n with\n | Ok result ->\n Checked.List.all result\n | Unequal_lengths ->\n failwith \"Bits.if_: unpacked bit lengths were unequal\"\n end\n\n module UInt64 (Impl : Snarky_backendless.Snark_intf.S) =\n Small_bit_vector (Impl) (Vector.UInt64)\n module UInt32 (Impl : Snarky_backendless.Snark_intf.S) =\n Small_bit_vector (Impl) (Vector.UInt32)\n\n module Field_backed\n (Impl : Snarky_backendless.Snark_intf.S) (M : sig\n val bit_length : int\n end) =\n struct\n open Impl\n include M\n\n let size_in_bits = bit_length\n\n module Packed = struct\n type var = Field.Var.t\n\n type value = Field.t\n\n let typ = Typ.field\n\n let assert_equal = Field.Checked.Assert.equal\n\n let size_in_bits = size_in_bits\n end\n\n module Unpacked = struct\n type var = Boolean.var list\n\n type value = Field.t\n\n let typ : (var, value) Typ.t =\n Typ.transport\n (Typ.list ~length:bit_length Boolean.typ)\n ~there:(unpack_field Field.unpack ~bit_length)\n ~back:Field.project\n\n let var_to_bits = Bitstring_lib.Bitstring.Lsb_first.of_list\n\n let var_of_bits = pad ~length:bit_length ~default:Boolean.false_\n\n let var_to_triples (bs : var) =\n Bitstring_lib.Bitstring.pad_to_triple_list ~default:Boolean.false_ bs\n\n let var_of_value v =\n unpack_field Field.unpack ~bit_length v\n |> List.map ~f:Boolean.var_of_value\n\n let size_in_bits = size_in_bits\n end\n\n let project_value = Fn.id\n\n let project_var = Field.Var.project\n\n let choose_preimage_var : Packed.var -> Unpacked.var Checked.t =\n Field.Checked.choose_preimage_var ~length:bit_length\n\n let unpack_value = Fn.id\n end\n\n module Field (Impl : Snarky_backendless.Snark_intf.S) :\n Bits_intf.Snarkable.Lossy\n with type ('a, 'b) typ := ('a, 'b) Impl.Typ.t\n and type 'a checked := 'a Impl.Checked.t\n and type boolean_var := Impl.Boolean.var\n and type Packed.var = Impl.Field.Var.t\n and type Packed.value = Impl.Field.t\n and type Unpacked.var = Impl.Boolean.var list\n and type Unpacked.value = Impl.Field.t =\n Field_backed\n (Impl)\n (struct\n let bit_length = Impl.Field.size_in_bits\n end)\n\n module Small\n (Impl : Snarky_backendless.Snark_intf.S) (M : sig\n val bit_length : int\n end) :\n Bits_intf.Snarkable.Faithful\n with type ('a, 'b) typ := ('a, 'b) Impl.Typ.t\n and type 'a checked := 'a Impl.Checked.t\n and type boolean_var := Impl.Boolean.var\n and type Packed.var = Impl.Field.Var.t\n and type Packed.value = Impl.Field.t\n and type Unpacked.var = Impl.Boolean.var list\n and type Unpacked.value = Impl.Field.t = struct\n let () = assert (M.bit_length < Impl.Field.size_in_bits)\n\n include Field_backed (Impl) (M)\n\n let pack_var bs =\n assert (Mina_stdlib.List.Length.Compare.(bs = M.bit_length)) ;\n project_var bs\n\n let pack_value = Fn.id\n\n let unpack_var = Impl.Field.Checked.unpack ~length:M.bit_length\n end\nend\n\nmodule Make_unpacked\n (Impl : Snarky_backendless.Snark_intf.S) (M : sig\n val bit_length : int\n end) =\nstruct\n open Impl\n\n module T = struct\n type var = Boolean.var list\n\n type value = Boolean.value list\n end\n\n include T\n\n let typ : (var, value) Typ.t = Typ.list ~length:M.bit_length Boolean.typ\nend\n\n[%%endif]\n","open Core_kernel\n\nmodule Interval = struct\n (* Semantically (a, b) : t is the closed interval [a, b] *)\n type t = int * int [@@deriving eq, sexp]\n\n let before (_, b1) (a2, _) = b1 <= a2\n\n let gen_from start =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = Int.gen_incl start Int.max_value_30_bits in\n let%map y = Int.gen_incl x Int.max_value_30_bits in\n (x, y)\n\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = Int.gen_incl Int.min_value Int.max_value_30_bits in\n let%map y = Int.gen_incl x Int.max_value_30_bits in\n (x, y)\n\n let%test_unit \"gen is correct\" =\n Quickcheck.test gen ~f:(fun (x, y) -> assert (x <= y))\nend\n\n(* Simplest possible implementation. Should be an increasing list of\n disjoint intervals.\n Semantically is the set of ints corresponding to the union of these\n ntervals. *)\ntype t = Interval.t list [@@deriving eq, sexp]\n\nlet empty : t = []\n\nlet union_intervals_exn (a1, b1) (a2, b2) =\n let ( = ) = Int.( = ) in\n if b1 = a2 then `Combine (a1, b2)\n else if b2 = a1 then `Combine (a2, b1)\n else if b1 < a2 then `Disjoint_ordered\n else if b2 < a1 then `Disjoint_inverted\n else failwithf \"Intervals not disjoint: (%d, %d) and (%d, %d)\" a1 b1 a2 b2 ()\n\nlet of_interval i = [ i ]\n\nlet rec canonicalize = function\n | [] ->\n []\n | [ i1 ] ->\n [ i1 ]\n | (a1, a2) :: (a3, a4) :: t ->\n if a2 = a3 then canonicalize ((a1, a4) :: t)\n else (a1, a2) :: canonicalize ((a3, a4) :: t)\n\nlet rec disjoint_union_exn t1 t2 =\n match (t1, t2) with\n | t, [] | [], t ->\n t\n | i1 :: t1', i2 :: t2' -> (\n match union_intervals_exn i1 i2 with\n | `Combine (a, b) ->\n (a, b) :: disjoint_union_exn t1' t2'\n | `Disjoint_ordered ->\n i1 :: disjoint_union_exn t1' t2\n | `Disjoint_inverted ->\n i2 :: disjoint_union_exn t1 t2' )\n\nlet disjoint_union_exn t1 t2 = canonicalize (disjoint_union_exn t1 t2)\n\nlet rec disjoint t1 t2 =\n match (t1, t2) with\n | _, [] | [], _ ->\n true\n | i1 :: t1', i2 :: t2' ->\n if Interval.before i1 i2 then disjoint t1' t2\n else if Interval.before i2 i1 then disjoint t1 t2'\n else false\n\n(* Someday: inefficient *)\nlet of_intervals_exn is =\n match is with\n | [] ->\n []\n | i :: is ->\n List.fold is ~init:(of_interval i) ~f:(fun acc x ->\n disjoint_union_exn (of_interval x) acc )\n\nlet to_interval = function\n | [ i ] ->\n Ok i\n | [] ->\n Or_error.error_string \"Interval_union.to_interval: the union is empty\\n\"\n | _ :: _ :: _ as xs ->\n Or_error.error_string\n (Printf.sprintf\n !\"Interval_union.to_interval: expected a single interval in the \\\n union, got multiple disjoint intervals %{sexp: Interval.t list}\\n\"\n xs )\n\nlet right_endpoint t = Option.map ~f:snd (List.last t)\n\nlet left_endpoint t = Option.map ~f:fst (List.hd t)\n\nlet invariant t =\n let rec go = function\n | [ (a, b) ] ->\n assert (a <= b)\n | [] ->\n ()\n | (a1, b1) :: ((a2, _) :: _ as t) ->\n assert (a1 <= b1) ;\n assert (b1 < a2) ;\n go t\n in\n go t\n\nlet gen_from ?(min_size = 0) start =\n let open Quickcheck.Generator.Let_syntax in\n let rec go acc size start =\n if size = 0 then return (of_intervals_exn (List.rev acc))\n else\n let%bind ((_, y) as i) = Interval.gen_from start in\n go (i :: acc) (size - 1) y\n in\n let%bind size = Quickcheck.Generator.small_positive_int in\n go [] (min_size + size) start\n\nlet gen = gen_from Int.min_value\n\nlet%test_unit \"check invariant\" = Quickcheck.test gen ~f:invariant\n\nlet gen_disjoint_pair =\n let open Quickcheck.Generator.Let_syntax in\n let%bind t1 = gen in\n let y = List.last_exn t1 |> snd in\n let%map t2 = gen_from y in\n (t1, t2)\n\nlet%test_unit \"canonicalize\" =\n assert (equal (canonicalize [ (1, 2); (2, 3) ]) [ (1, 3) ])\n\nlet%test_unit \"disjoint union doesn't care about order\" =\n Quickcheck.test gen_disjoint_pair ~f:(fun (a, b) ->\n assert (equal (disjoint_union_exn a b) (disjoint_union_exn b a)) )\n\nlet%test_unit \"check invariant on disjoint union\" =\n Quickcheck.test gen_disjoint_pair ~f:(fun (a, b) ->\n invariant (disjoint_union_exn a b) )\n\nlet%test_unit \"disjoint_union works with holes\" =\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let s = 1000000 in\n let%bind y0 = Int.gen_incl 0 s in\n let%bind y1 = Int.gen_incl (y0 + 1) (y0 + s) in\n let%bind y2 = Int.gen_incl (y1 + 1) (y1 + s) in\n let%bind y3 = Int.gen_incl (y2 + 1) (y2 + s) in\n return (of_interval (y1, y2), of_intervals_exn [ (y0, y1); (y2, y3) ])\n in\n Quickcheck.test gen ~f:(fun (x, y) -> invariant (disjoint_union_exn x y))\n","open Core_kernel\n\ntype t = Big_int.big_int\n\nlet equal = Big_int.eq_big_int\n\nlet num_bits = Big_int.num_bits_big_int\n\nlet shift_right = Big_int.shift_right_big_int\n\nlet shift_left = Big_int.shift_left_big_int\n\nlet log_and = Big_int.and_big_int\n\nlet log_or = Big_int.or_big_int\n\nlet of_int = Big_int.big_int_of_int\n\nlet test_bit t i =\n equal (log_and Big_int.unit_big_int (shift_right t i)) Big_int.unit_big_int\n\nlet to_bytes x =\n let n = num_bits x in\n let num_bytes = (n + 7) / 8 in\n String.init num_bytes ~f:(fun byte ->\n let c i =\n let bit = (8 * byte) + i in\n if test_bit x bit then 1 lsl i else 0\n in\n Char.of_int_exn\n (c 0 lor c 1 lor c 2 lor c 3 lor c 4 lor c 5 lor c 6 lor c 7) )\n\nlet of_bytes x =\n String.foldi x ~init:Big_int.zero_big_int ~f:(fun i acc c ->\n log_or acc (shift_left (of_int (Char.to_int c)) (8 * i)) )\n\nlet ( + ) = Big_int.add_big_int\n\nlet ( - ) = Big_int.sub_big_int\n\nlet ( * ) = Big_int.mult_big_int\n\nlet ( % ) = Big_int.mod_big_int\n\nlet ( // ) = Big_int.div_big_int\n\nlet ( < ) = Big_int.lt_big_int\n\nlet to_int_exn = Big_int.int_of_big_int\n\nlet compare = Big_int.compare_big_int\n\nmodule String_hum = struct\n type nonrec t = t\n\n let of_string = Big_int.big_int_of_string\n\n let to_string = Big_int.string_of_big_int\nend\n\ninclude Sexpable.Of_stringable (String_hum)\n\ninclude (String_hum : Stringable.S with type t := t)\n\nlet hash t = Stdlib.Hashtbl.hash t\n\nlet hash_fold_t h t = hash_fold_int h (hash t)\n\nlet to_yojson t = `String (to_string t)\n\nlet of_yojson = function\n | `String s ->\n Ok (of_string s)\n | _ ->\n Error \"Nat.of_yojson: Expected string\"\n\n[@@@alert \"-legacy\"]\n\n(** this serialization is not used for fields *)\ninclude Binable.Of_stringable_without_uuid (struct\n type nonrec t = t\n\n let of_string = of_bytes\n\n let to_string = to_bytes\nend)\n","type ('var, 'value) t = { var : 'var; mutable value : 'value option }\n\nlet var { var; _ } = var\n","(** The usual Janestreet [Monad] interfaces, with [Let_syntax] included in the\n monad module. *)\nopen Core_kernel\n\nopen Monad\n\nmodule type Let_syntax = sig\n type 'a t\n\n val return : 'a -> 'a t\n\n val bind : 'a t -> f:('a -> 'b t) -> 'b t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val both : 'a t -> 'b t -> ('a * 'b) t\n\n module Open_on_rhs : sig end\nend\n\nmodule type Base_syntax = sig\n type 'a t\n\n val return : 'a -> 'a t\n\n include Infix with type 'a t := 'a t\nend\n\nmodule type Syntax = sig\n include Base_syntax\n\n include Let_syntax with type 'a t := 'a t\nend\n\nmodule type S = sig\n type 'a t\n\n include S_without_syntax with type 'a t := 'a t\n\n module Let_syntax : sig\n include Base_syntax with type 'a t := 'a t\n\n include Let_syntax with type 'a t := 'a t\n\n module Let_syntax : Let_syntax with type 'a t := 'a t\n end\nend\n\nmodule type Let_syntax2 = sig\n type ('a, 'e) t\n\n val return : 'a -> ('a, 'e) t\n\n val bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t\n\n val map : ('a, 'e) t -> f:('a -> 'b) -> ('b, 'e) t\n\n val both : ('a, 'e) t -> ('b, 'e) t -> ('a * 'b, 'e) t\n\n module Open_on_rhs : sig end\nend\n\nmodule type Base_syntax2 = sig\n type ('a, 'e) t\n\n val return : 'a -> ('a, 'e) t\n\n include Infix2 with type ('a, 'e) t := ('a, 'e) t\nend\n\nmodule type Syntax2 = sig\n include Base_syntax2\n\n include Let_syntax2 with type ('a, 'e) t := ('a, 'e) t\nend\n\nmodule type S_without_syntax2 = sig\n type ('a, 'e) t\n\n include Infix2 with type ('a, 'e) t := ('a, 'e) t\n\n module Monad_infix : Infix2 with type ('a, 'e) t := ('a, 'e) t\n\n val bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t\n\n val return : 'a -> ('a, _) t\n\n val map : ('a, 'e) t -> f:('a -> 'b) -> ('b, 'e) t\n\n val join : (('a, 'e) t, 'e) t -> ('a, 'e) t\n\n val ignore_m : (_, 'e) t -> (unit, 'e) t\n\n val all : ('a, 'e) t list -> ('a list, 'e) t\n\n val all_unit : (unit, 'e) t list -> (unit, 'e) t\nend\n\nmodule type S2 = sig\n type ('a, 'e) t\n\n include S_without_syntax2 with type ('a, 'e) t := ('a, 'e) t\n\n module Let_syntax : sig\n include Base_syntax2 with type ('a, 'e) t := ('a, 'e) t\n\n include Let_syntax2 with type ('a, 'e) t := ('a, 'e) t\n\n module Let_syntax : Let_syntax2 with type ('a, 'e) t := ('a, 'e) t\n end\nend\n\nmodule type Let_syntax3 = sig\n type ('a, 'd, 'e) t\n\n val return : 'a -> ('a, 'd, 'e) t\n\n val bind : ('a, 'd, 'e) t -> f:('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n\n val map : ('a, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'd, 'e) t\n\n val both : ('a, 'd, 'e) t -> ('b, 'd, 'e) t -> ('a * 'b, 'd, 'e) t\n\n module Open_on_rhs : sig end\nend\n\nmodule type Base_syntax3 = sig\n type ('a, 'd, 'e) t\n\n val return : 'a -> ('a, 'd, 'e) t\n\n include Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\nend\n\nmodule type Syntax3 = sig\n include Base_syntax3\n\n include Let_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\nend\n\nmodule type S_without_syntax3 = sig\n type ('a, 'd, 'e) t\n\n include Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n module Monad_infix : Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n val bind : ('a, 'd, 'e) t -> f:('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n\n val return : 'a -> ('a, _, _) t\n\n val map : ('a, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'd, 'e) t\n\n val join : (('a, 'd, 'e) t, 'd, 'e) t -> ('a, 'd, 'e) t\n\n val ignore_m : (_, 'd, 'e) t -> (unit, 'd, 'e) t\n\n val all : ('a, 'd, 'e) t list -> ('a list, 'd, 'e) t\n\n val all_unit : (unit, 'd, 'e) t list -> (unit, 'd, 'e) t\nend\n\nmodule type S3 = sig\n type ('a, 'd, 'e) t\n\n include S_without_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n module Let_syntax : sig\n include Base_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n include Let_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n module Let_syntax : Let_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n end\nend\n\nmodule Make3 (X : Monad.Basic3) :\n S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t = struct\n include X\n module M = Monad.Make3 (X)\n module Let = M.Let_syntax.Let_syntax\n\n [@@@warning \"-3\"]\n\n include (M : S_without_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t)\n\n module Let_syntax = struct\n include (\n M.Let_syntax : Base_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t )\n\n include (Let : Let_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t)\n\n module Let_syntax = Let\n end\nend\n\nmodule Make2 (X : Monad.Basic2) : S2 with type ('a, 'e) t := ('a, 'e) X.t =\nMake3 (struct\n type ('a, 'd, 'e) t = ('a, 'e) X.t\n\n include (X : Monad.Basic3 with type ('a, 'd, 'e) t := ('a, 'e) X.t)\nend)\n\nmodule Make (X : Monad.Basic) : S with type 'a t := 'a X.t = Make2 (struct\n type ('a, 'e) t = 'a X.t\n\n include (X : Monad.Basic2 with type ('a, 'e) t := 'a X.t)\nend)\n","type _ t = ..\n\ntype _ t += Fail : 'a t\n\ntype 'a req = 'a t\n\ntype response = ..\n\ntype response += Unhandled\n\nlet unhandled = Unhandled\n\nmodule Response = struct\n type 'a t = Provide of 'a | Delegate of 'a req | Unhandled\nend\n\ntype request =\n | With : { request : 'a t; respond : 'a Response.t -> response } -> request\n\nmodule Handler = struct\n type single = { handle : 'a. 'a t -> 'a Response.t }\n\n type t = single list\n\n let fail = []\n\n let run : t -> string list -> 'a req -> 'a =\n fun stack0 label_stack req0 ->\n let rec go req = function\n | [] ->\n failwith\n ( \"Unhandled request: \"\n ^ Core_kernel.String.concat ~sep:\"\\n\" label_stack )\n | { handle } :: hs -> (\n match handle req with\n | Provide x ->\n x\n | Delegate req' ->\n go req' hs\n | Unhandled ->\n go req hs )\n in\n go req0 stack0\n\n let create_single (handler : request -> response) : single =\n let handle : type a. a req -> a Response.t =\n fun request ->\n let module T = struct\n type response += T of a Response.t\n end in\n match handler (With { request; respond = (fun x -> T.T x) }) with\n | T.T x ->\n x\n | _ ->\n Response.Unhandled\n in\n { handle }\n\n let push (t : t) (single : single) : t = single :: t\nend\n","open Core_kernel\n\nmodule Make (Field : sig\n type t [@@deriving sexp]\n\n val equal : t -> t -> bool\nend)\n(Basic : Checked_intf.Basic with type 'f field = Field.t)\n(As_prover : As_prover_intf.Basic with type 'f field := 'f Basic.field) :\n Checked_intf.S\n with module Types = Basic.Types\n with type 'f field = 'f Basic.field = struct\n include Basic\n\n let request_witness (typ : ('var, 'value, 'f field) Types.Typ.t)\n (r : ('value Request.t, 'f field) As_prover.t) =\n let%map h = exists typ (Request r) in\n Handle.var h\n\n let request ?such_that typ r =\n match such_that with\n | None ->\n request_witness typ (As_prover.return r)\n | Some such_that ->\n let open Let_syntax in\n let%bind x = request_witness typ (As_prover.return r) in\n let%map () = such_that x in\n x\n\n let exists_handle ?request ?compute typ =\n let provider =\n let request =\n Option.value request ~default:(As_prover.return Request.Fail)\n in\n match compute with\n | None ->\n Types.Provider.Request request\n | Some c ->\n Types.Provider.Both (request, c)\n in\n exists typ provider\n\n let exists ?request ?compute typ =\n let%map h = exists_handle ?request ?compute typ in\n Handle.var h\n\n type response = Request.response\n\n let unhandled = Request.unhandled\n\n type request = Request.request =\n | With :\n { request : 'a Request.t; respond : 'a Request.Response.t -> response }\n -> request\n\n let handle t k = with_handler (Request.Handler.create_single k) t\n\n let handle_as_prover t k =\n let handler = ref None in\n let%bind () =\n as_prover\n As_prover.(\n let%map h = k in\n handler := Some h)\n in\n handle t (fun request -> (Option.value_exn !handler) request)\n\n let assert_ ?label c = add_constraint (Constraint.override_label c label)\n\n let assert_r1cs ?label a b c = assert_ (Constraint.r1cs ?label a b c)\n\n let assert_square ?label a c = assert_ (Constraint.square ?label a c)\n\n let assert_all ?label cs =\n List.fold_right cs ~init:(return ()) ~f:(fun c (acc : _ t) ->\n bind acc ~f:(fun () ->\n add_constraint (Constraint.override_label c label) ) )\n\n let assert_equal ?label x y =\n match (x, y) with\n | Cvar.Constant x, Cvar.Constant y ->\n if Field.equal x y then return ()\n else\n failwithf !\"assert_equal: %{sexp: Field.t} != %{sexp: Field.t}\" x y ()\n | _ ->\n assert_ (Constraint.equal ?label x y)\nend\n","module As_prover = struct\n type ('a, 'f) t = ('f Cvar.t -> 'f) -> 'a\nend\n\nmodule Provider = struct\n module T = struct\n (** The different ways to generate a value for the circuit witness.\n\n If [Both], this attempts the request first, and falls back on compute\n if the request is unhandled or raises an exception.\n *)\n type ('request, 'compute) provider =\n | Request of 'request\n | Compute of 'compute\n | Both of 'request * 'compute\n end\n\n include T\n\n type ('request, 'compute) t = ('request, 'compute) provider\nend\n\nmodule Typ = struct\n module T = struct\n (** The type [('var, 'value, 'field, 'checked) t] describes a mapping from\n OCaml types to the variables and constraints they represent:\n - ['value] is the OCaml type\n - ['field] is the type of the field elements\n - ['var] is some other type that contains some R1CS variables\n - ['checked] is the type of checked computation that verifies the stored\n contents as R1CS variables.\n\n For convenience and readability, it is usually best to have the ['var]\n type mirror the ['value] type in structure, for example:\n{[\n type t = {b1 : bool; b2 : bool} (* 'value *)\n\n let or (x : t) = x.b1 || x.b2\n\n module Checked = struct\n type t = {b1 : Snark.Boolean.var; b2 : Snark.Boolean.var} (* 'var *)\n\n let or (x : t) = Snark.Boolean.(x.b1 || x.b2)\n end\n]}*)\n type ('var, 'value, 'aux, 'field, 'checked) typ' =\n { var_to_fields : 'var -> 'field Cvar.t array * 'aux\n ; var_of_fields : 'field Cvar.t array * 'aux -> 'var\n ; value_to_fields : 'value -> 'field array * 'aux\n ; value_of_fields : 'field array * 'aux -> 'value\n ; size_in_field_elements : int\n ; constraint_system_auxiliary : unit -> 'aux\n ; check : 'var -> 'checked\n }\n\n type ('var, 'value, 'field, 'checked) typ =\n | Typ :\n ('var, 'value, 'aux, 'field, 'checked) typ'\n -> ('var, 'value, 'field, 'checked) typ\n end\n\n include T\n\n type ('var, 'value, 'field, 'checked) t = ('var, 'value, 'field, 'checked) typ\nend\n\nmodule type Types = sig\n module Checked : sig\n type ('a, 'f) t\n end\n\n module Typ : sig\n include module type of Typ.T\n\n type ('var, 'value, 'f) t = ('var, 'value, 'f, (unit, 'f) Checked.t) Typ.t\n end\n\n module Provider : sig\n include module type of Provider.T\n\n type ('a, 'f) t =\n (('a Request.t, 'f) As_prover.t, ('a, 'f) As_prover.t) provider\n end\nend\n","open Core_kernel\n\ntype ('a, 'f) t = ('a, 'f) Types.As_prover.t\n\nlet map t ~f tbl =\n let x = t tbl in\n f x\n\nlet bind t ~f tbl =\n let x = t tbl in\n f x tbl\n\nlet return x _ = x\n\nlet run t tbl = t tbl\n\nlet get_state _tbl s = (s, s)\n\nlet set_state s _tbl _ = (s, ())\n\nlet modify_state f _tbl s = (f s, ())\n\nlet map2 x y ~f tbl =\n let x = x tbl in\n let y = y tbl in\n f x y\n\nlet read_var (v : 'var) : ('field, 'field) t = fun tbl -> tbl v\n\nlet read\n (Typ { var_to_fields; value_of_fields; _ } :\n ('var, 'value, 'field, _) Types.Typ.t ) (var : 'var) : ('value, 'field) t\n =\n fun tbl ->\n let field_vars, aux = var_to_fields var in\n let fields = Array.map ~f:tbl field_vars in\n value_of_fields (fields, aux)\n\ninclude Monad_let.Make2 (struct\n type nonrec ('a, 'e) t = ('a, 'e) t\n\n let map = `Custom map\n\n let bind = bind\n\n let return = return\nend)\n\nmodule Provider = struct\n (** The different ways to generate a value of type ['a] for a circuit\n witness over field ['f].\n\n This is one of:\n * a [Request], dispatching an ['a Request.t];\n * [Compute], running a computation to generate the value;\n * [Both], attempting to dispatch an ['a Request.t], and falling back to\n the computation if the request is unhandled or raises an exception.\n *)\n type nonrec ('a, 'f) t = (('a Request.t, 'f) t, ('a, 'f) t) Types.Provider.t\n\n open Types.Provider\n\n let run t stack tbl (handler : Request.Handler.t) =\n match t with\n | Request rc ->\n let r = run rc tbl in\n Request.Handler.run handler stack r\n | Compute c ->\n run c tbl\n | Both (rc, c) -> (\n let r = run rc tbl in\n match Request.Handler.run handler stack r with\n | exception _ ->\n run c tbl\n | x ->\n x )\nend\n\nmodule Handle = struct\n let value (t : ('var, 'value) Handle.t) : ('value, 'field) t =\n fun _ -> Option.value_exn t.value\nend\n\nmodule type Extended = sig\n type field\n\n include As_prover_intf.Basic with type 'f field := field\n\n type nonrec 'a t = ('a, field) t\nend\n\nmodule Make_extended (Env : sig\n type field\nend)\n(As_prover : As_prover_intf.Basic with type 'f field := Env.field) =\nstruct\n include Env\n include As_prover\n\n type nonrec 'a t = ('a, field) t\nend\n","module Vector = struct\n open Core_kernel\n\n type 'elt t =\n | T :\n (module Snarky_intf.Vector.S with type elt = 'elt and type t = 't)\n * 't Type_equal.Id.t\n * 't\n -> 'elt t\n\n let unit = Type_equal.Id.create ~name:\"unit\" Unit.sexp_of_t\n\n let null : type a. a t =\n let module T = struct\n type elt = a\n\n type t = unit\n\n let create () = ()\n\n let get _ _ = failwith \"Vector.null: get\"\n\n let emplace_back _ _ = failwith \"Vector.null: emplace_back\"\n\n let length () = 0\n end in\n T ((module T), unit, ())\n\n let get (type x) (T ((module T), _, t) : x t) i = T.get t i\n\n let emplace_back (type x) (T ((module T), _, t) : x t) x = T.emplace_back t x\nend\n\n(** The internal state used to run a checked computation. *)\ntype 'field t =\n { system : 'field Constraint_system.t option\n ; input : 'field Vector.t\n ; aux : 'field Vector.t\n ; eval_constraints : bool\n ; num_inputs : int\n ; next_auxiliary : int ref\n ; has_witness : bool\n ; stack : string list\n ; handler : Request.Handler.t\n ; is_running : bool\n ; as_prover : bool ref\n ; log_constraint :\n ( ?at_label_boundary:[ `Start | `End ] * string\n -> ('field Cvar.t, 'field) Constraint.t option\n -> unit )\n option\n }\n\nlet make ~num_inputs ~input ~next_auxiliary ~aux ?system ~eval_constraints\n ?log_constraint ?handler ~with_witness ?(stack = []) ?(is_running = true) ()\n =\n next_auxiliary := num_inputs ;\n (* We can't evaluate the constraints if we are not computing over a value. *)\n let eval_constraints = eval_constraints && with_witness in\n { system\n ; input\n ; aux\n ; eval_constraints\n ; num_inputs\n ; next_auxiliary\n ; has_witness = with_witness\n ; stack\n ; handler = Option.value handler ~default:Request.Handler.fail\n ; is_running\n ; as_prover = ref false\n ; log_constraint\n }\n\nlet dump (t : _ t) =\n Format.sprintf\n \"state { is_running: %B; as_prover: %B; has_witness: %B; eval_constraints: \\\n %B; num_inputs: %d; next_auxiliary: %d }\\n\"\n t.is_running !(t.as_prover) t.has_witness t.eval_constraints t.num_inputs\n !(t.next_auxiliary)\n\nlet get_variable_value { num_inputs; input; aux; _ } : int -> 'field =\n fun i ->\n if i < num_inputs then Vector.get input i else Vector.get aux (i - num_inputs)\n\nlet store_field_elt { next_auxiliary; aux; _ } x =\n let v = !next_auxiliary in\n incr next_auxiliary ; Vector.emplace_back aux x ; Cvar.Unsafe.of_index v\n\nlet alloc_var { next_auxiliary; _ } () =\n let v = !next_auxiliary in\n incr next_auxiliary ; Cvar.Unsafe.of_index v\n\nlet has_witness { has_witness; _ } = has_witness\n\nlet as_prover { as_prover; _ } = !as_prover\n\nlet set_as_prover t as_prover = t.as_prover := as_prover\n\nlet stack { stack; _ } = stack\n\nlet set_stack t stack = { t with stack }\n\nlet log_constraint { log_constraint; _ } = log_constraint\n\nlet eval_constraints { eval_constraints; _ } = eval_constraints\n\nlet system { system; _ } = system\n\nlet handler { handler; _ } = handler\n\nlet set_handler t handler = { t with handler }\n\nlet is_running { is_running; _ } = is_running\n\nlet set_is_running t is_running = { t with is_running }\n\nlet next_auxiliary { next_auxiliary; _ } = !next_auxiliary\n","module type Basic = sig\n module Types : Types.Types\n\n type ('a, 'f) t = ('a, 'f) Types.Checked.t\n\n type 'f field\n\n include Monad_let.S2 with type ('a, 'f) t := ('a, 'f) t\n\n val add_constraint :\n ('f field Cvar.t, 'f field) Constraint.t -> (unit, 'f field) t\n\n val as_prover : (unit, 'f field) As_prover0.t -> (unit, 'f field) t\n\n val mk_lazy : (unit -> ('a, 'f) t) -> ('a Lazy.t, 'f) t\n\n val with_label : string -> (unit -> ('a, 'f field) t) -> ('a, 'f field) t\n\n val with_handler :\n Request.Handler.single -> (unit -> ('a, 'f field) t) -> ('a, 'f field) t\n\n val exists :\n ('var, 'value, 'f field) Types.Typ.t\n -> ('value, 'f field) Types.Provider.t\n -> (('var, 'value) Handle.t, 'f field) t\n\n val next_auxiliary : unit -> (int, 'f field) t\n\n val direct :\n ('f field Run_state.t -> 'f field Run_state.t * 'a) -> ('a, 'f field) t\n\n val constraint_count :\n ?weight:(('f field Cvar.t, 'f field) Constraint.t -> int)\n -> ?log:(?start:bool -> string -> int -> unit)\n -> (unit -> ('a, 'f field) t)\n -> int\nend\n\nmodule type S = sig\n module Types : Types.Types\n\n type ('a, 'f) t = ('a, 'f) Types.Checked.t\n\n type 'f field\n\n include Monad_let.S2 with type ('a, 'f) t := ('a, 'f) t\n\n val as_prover : (unit, 'f field) As_prover0.t -> (unit, 'f field) t\n\n val mk_lazy : (unit -> ('a, 'f) t) -> ('a Lazy.t, 'f) t\n\n val request_witness :\n ('var, 'value, 'f field) Types.Typ.t\n -> ('value Request.t, 'f field) As_prover0.t\n -> ('var, 'f field) t\n\n val request :\n ?such_that:('var -> (unit, 'f field) t)\n -> ('var, 'value, 'f field) Types.Typ.t\n -> 'value Request.t\n -> ('var, 'f field) t\n\n val exists_handle :\n ?request:('value Request.t, 'f field) As_prover0.t\n -> ?compute:('value, 'f field) As_prover0.t\n -> ('var, 'value, 'f field) Types.Typ.t\n -> (('var, 'value) Handle.t, 'f field) t\n\n val exists :\n ?request:('value Request.t, 'f field) As_prover0.t\n -> ?compute:('value, 'f field) As_prover0.t\n -> ('var, 'value, 'f field) Types.Typ.t\n -> ('var, 'f field) t\n\n type response = Request.response\n\n val unhandled : response\n\n type request = Request.request =\n | With :\n { request : 'a Request.t; respond : 'a Request.Response.t -> response }\n -> request\n\n val handle :\n (unit -> ('a, 'f field) t) -> (request -> response) -> ('a, 'f field) t\n\n val handle_as_prover :\n (unit -> ('a, 'f field) t)\n -> (request -> response, 'f field) As_prover0.t\n -> ('a, 'f field) t\n\n val next_auxiliary : unit -> (int, 'f field) t\n\n val with_label : string -> (unit -> ('a, 'f field) t) -> ('a, 'f field) t\n\n val assert_ :\n ?label:Base.string\n -> ('f field Cvar.t, 'f field) Constraint.t\n -> (unit, 'f field) t\n\n val assert_r1cs :\n ?label:Base.string\n -> 'f field Cvar.t\n -> 'f field Cvar.t\n -> 'f field Cvar.t\n -> (unit, 'f field) t\n\n val assert_square :\n ?label:Base.string\n -> 'f field Cvar.t\n -> 'f field Cvar.t\n -> (unit, 'f field) t\n\n val assert_all :\n ?label:Base.string\n -> ('f field Cvar.t, 'f field) Constraint.t list\n -> (unit, 'f field) t\n\n val assert_equal :\n ?label:Base.string\n -> 'f field Cvar.t\n -> 'f field Cvar.t\n -> (unit, 'f field) t\n\n val direct :\n ('f field Run_state.t -> 'f field Run_state.t * 'a) -> ('a, 'f field) t\n\n val constraint_count :\n ?weight:(('f field Cvar.t, 'f field) Constraint.t -> int)\n -> ?log:(?start:bool -> string -> int -> unit)\n -> (unit -> ('a, 'f field) t)\n -> int\nend\n\nmodule type Extended = sig\n type field\n\n module Types : Types.Types\n\n type 'a t = ('a, field) Types.Checked.t\n\n include\n S\n with module Types := Types\n with type 'f field := field\n and type ('a, 'f) t := ('a, 'f) Types.Checked.t\n\n val run : 'a t -> field Run_state.t -> field Run_state.t * 'a\nend\n\nmodule Unextend (Checked : Extended) :\n S with module Types = Checked.Types with type 'f field = Checked.field =\nstruct\n include (\n Checked :\n S\n with module Types = Checked.Types\n with type 'f field := Checked.field\n and type ('a, 'f) t := ('a, 'f) Checked.Types.Checked.t )\n\n type 'f field = Checked.field\n\n type ('a, 'f) t = ('a, 'f) Types.Checked.t\nend\n","open Core_kernel\n\ntype 'a t = 'a option ref\n\nmodule Make_ref_typ (Checked : Monad_let.S2) = struct\n let typ : ('a t, 'a, _, _) Types.Typ.t =\n Typ\n { var_to_fields = (fun x -> ([||], !x))\n ; var_of_fields = (fun (_, x) -> ref x)\n ; value_to_fields = (fun x -> ([||], Some x))\n ; value_of_fields = (fun (_, x) -> Option.value_exn x)\n ; size_in_field_elements = 0\n ; constraint_system_auxiliary = (fun () -> None)\n ; check = (fun _ -> Checked.return ())\n }\nend\n\nmodule type S = sig\n module Types : Types.Types\n\n type ('a, 'f) checked\n\n type 'f field\n\n type nonrec 'a t = 'a t\n\n val create : ('a, 'f field) As_prover0.t -> ('a t, 'f field) checked\n\n val get : 'a t -> ('a, 'f field) As_prover0.t\n\n val set : 'a t -> 'a -> (unit, 'f field) As_prover0.t\nend\n\nmodule Make\n (Checked : Checked_intf.S)\n (As_prover : As_prover_intf.Basic\n with type 'f field := 'f Checked.field\n and type ('a, 'f) Provider.t =\n ('a, 'f) Checked.Types.Provider.t) :\n S\n with module Types = Checked.Types\n and type ('a, 'f) checked := ('a, 'f) Checked.t\n and type 'f field = 'f Checked.field = struct\n module Types = Checked.Types\n\n type 'f field = 'f Checked.field\n\n type nonrec 'a t = 'a t\n\n let create (x : ('a, 'f Checked.field) As_prover.t) :\n ('a t, 'f Checked.field) Checked.t =\n let r = ref None in\n let open Checked in\n let%map () =\n Checked.as_prover (As_prover.map x ~f:(fun x -> r := Some x))\n in\n r\n\n open As_prover.Let_syntax\n\n let get (r : 'a t) =\n let%map () = As_prover.return () in\n Option.value_exn !r\n\n let set (r : 'a t) x =\n let%map () = As_prover.return () in\n r := Some x\nend\n","type 'v t = 'v\n\nmodule Unsafe = struct\n let create x = x\nend\n","open Core_kernel\nmodule Types0 = Types\n\nmodule Make\n (Backend : Backend_extended.S)\n (Checked : Checked_intf.Extended with type field = Backend.Field.t)\n (As_prover : As_prover0.Extended with type field := Backend.Field.t)\n (Runner : Checked_runner.S\n with module Types := Checked.Types\n with type field := Backend.Field.t\n and type cvar := Backend.Cvar.t\n and type constr := Backend.Constraint.t option\n and type r1cs := Backend.R1CS_constraint_system.t) =\nstruct\n open Backend\n\n let set_constraint_logger = Runner.set_constraint_logger\n\n let clear_constraint_logger = Runner.clear_constraint_logger\n\n type field = Field.t\n\n let field_vec_id : Field.Vector.t Type_equal.Id.t =\n Type_equal.Id.create ~name:\"field-vector\" sexp_of_opaque\n\n let pack_field_vec v =\n Run_state.Vector.T ((module Field.Vector), field_vec_id, v)\n\n let field_vec () = pack_field_vec (Field.Vector.create ())\n\n module Proof_inputs = struct\n type t =\n { public_inputs : Field.Vector.t; auxiliary_inputs : Field.Vector.t }\n end\n\n module Bigint = Bigint\n module Field0 = Field\n module Cvar = Cvar\n module Constraint = Constraint\n\n module Handler = struct\n type t = Request.request -> Request.response\n end\n\n module Runner = Runner\n\n (* TODO-someday: Add pass to unify variables which have an Equal constraint *)\n let constraint_system ~run ~num_inputs ~return_typ:(Types.Typ.Typ return_typ)\n output t : R1CS_constraint_system.t =\n let input = field_vec () in\n let next_auxiliary = ref num_inputs in\n let aux = field_vec () in\n let system = R1CS_constraint_system.create () in\n let state =\n Runner.State.make ~num_inputs ~input ~next_auxiliary ~aux ~system\n ~with_witness:false ()\n in\n let state, res = run t state in\n let res, _ = return_typ.var_to_fields res in\n let output, _ = return_typ.var_to_fields output in\n let _state =\n Array.fold2_exn ~init:state res output ~f:(fun state res output ->\n fst @@ Checked.run (Checked.assert_equal res output) state )\n in\n let auxiliary_input_size = !next_auxiliary - num_inputs in\n R1CS_constraint_system.set_auxiliary_input_size system auxiliary_input_size ;\n system\n\n let auxiliary_input ?system ~run ~num_inputs\n ?(handlers = ([] : Handler.t list)) t0 (input : Field.Vector.t)\n ~return_typ:(Types.Typ.Typ return_typ) ~output : Field.Vector.t * _ =\n let next_auxiliary = ref num_inputs in\n let aux = Field.Vector.create () in\n let handler =\n List.fold ~init:Request.Handler.fail handlers ~f:(fun handler h ->\n Request.Handler.(push handler (create_single h)) )\n in\n let state =\n Runner.State.make ?system ~num_inputs ~input:(pack_field_vec input)\n ~next_auxiliary ~aux:(pack_field_vec aux) ~handler ~with_witness:true ()\n in\n let state, res = run t0 state in\n let res, auxiliary_output_data = return_typ.var_to_fields res in\n let output, _ = return_typ.var_to_fields output in\n let _state =\n Array.fold2_exn ~init:state res output ~f:(fun state res output ->\n Field.Vector.emplace_back input (Runner.get_value state res) ;\n fst @@ Checked.run (Checked.assert_equal res output) state )\n in\n let true_output =\n return_typ.var_of_fields (output, auxiliary_output_data)\n in\n Option.iter system ~f:(fun system ->\n let auxiliary_input_size = !next_auxiliary - num_inputs in\n R1CS_constraint_system.set_auxiliary_input_size system\n auxiliary_input_size ;\n R1CS_constraint_system.finalize system ) ;\n (aux, true_output)\n\n let run_and_check_exn' ~run t0 =\n let num_inputs = 0 in\n let input = field_vec () in\n let next_auxiliary = ref 0 in\n let aux = Field.Vector.create () in\n let system = R1CS_constraint_system.create () in\n let get_value : Cvar.t -> Field.t =\n let get_one v = Field.Vector.get aux v in\n Cvar.eval (`Return_values_will_be_mutated get_one)\n in\n let state =\n Runner.State.make ~num_inputs ~input ~next_auxiliary\n ~aux:(pack_field_vec aux) ~system ~eval_constraints:true\n ~with_witness:true ()\n in\n let _, x = run t0 state in\n (x, get_value)\n\n let run_and_check' ~run t0 =\n match run_and_check_exn' ~run t0 with\n | exception e ->\n Or_error.of_exn ~backtrace:`Get e\n | res ->\n Ok res\n\n let run_and_check_deferred_exn' ~map ~run t0 =\n let num_inputs = 0 in\n let input = field_vec () in\n let next_auxiliary = ref 0 in\n let aux = Field.Vector.create () in\n let system = R1CS_constraint_system.create () in\n let get_value : Cvar.t -> Field.t =\n let get_one v = Field.Vector.get aux v in\n Cvar.eval (`Return_values_will_be_mutated get_one)\n in\n let state =\n Runner.State.make ~num_inputs ~input ~next_auxiliary\n ~aux:(pack_field_vec aux) ~system ~eval_constraints:true\n ~with_witness:true ()\n in\n let res = run t0 state in\n map res ~f:(function _, x -> (x, get_value))\n\n let run_and_check_deferred' ~map ~return ~run t0 =\n match\n run_and_check_deferred_exn'\n ~map:(fun x ~f -> map x ~f:(fun x -> Ok (f x)))\n ~run t0\n with\n | exception e ->\n return (Or_error.of_exn ~backtrace:`Get e)\n | res ->\n res\n\n let run_unchecked ~run t0 =\n let num_inputs = 0 in\n let input = field_vec () in\n let next_auxiliary = ref 0 in\n let aux = field_vec () in\n let state =\n Runner.State.make ~num_inputs ~input ~next_auxiliary ~aux\n ~with_witness:true ()\n in\n match run t0 state with _, x -> x\n\n let run_and_check_exn ~run t =\n let x, get_value = run_and_check_exn' ~run t in\n let x = As_prover.run x get_value in\n x\n\n let run_and_check ~run t =\n Or_error.map (run_and_check' ~run t) ~f:(fun (x, get_value) ->\n let x = As_prover.run x get_value in\n x )\n\n let check_exn ~run t = run_and_check_exn' ~run t |> Fn.const ()\n\n let check ~run t = run_and_check' ~run t |> Result.map ~f:(Fn.const ())\n\n module Run = struct\n let alloc_var next_input () =\n let v = !next_input in\n incr next_input ; Cvar.Unsafe.of_index v\n\n let store_field_elt primary_input next_input x =\n let v = alloc_var next_input () in\n Field.Vector.emplace_back primary_input x ;\n v\n\n let collect_input_constraints :\n type checked input_var input_value.\n int ref\n -> input_typ:\n ( input_var\n , input_value\n , field\n , (unit, field) Checked.Types.Checked.t )\n Types.Typ.typ\n -> return_typ:_ Types.Typ.t\n -> (unit -> input_var -> checked)\n -> _ * (unit -> checked) Checked.t =\n fun next_input ~input_typ:(Typ input_typ) ~return_typ:(Typ return_typ) k ->\n (* allocate variables for the public input and the public output *)\n let open Checked in\n let alloc_input\n { Types0.Typ.var_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; _\n } =\n var_of_fields\n ( Core_kernel.Array.init size_in_field_elements ~f:(fun _ ->\n alloc_var next_input () )\n , constraint_system_auxiliary () )\n in\n let var = alloc_input input_typ in\n let retval = alloc_input return_typ in\n\n (* create constraints to validate the input (using the input [Typ]'s [check]) *)\n let circuit =\n let%bind () = input_typ.check var in\n Checked.return (fun () -> k () var)\n in\n (retval, circuit)\n\n let r1cs_h :\n type a checked input_var input_value retval.\n run:(a, checked) Runner.run\n -> int ref\n -> input_typ:\n ( input_var\n , input_value\n , field\n , (unit, field) Checked.Types.Checked.t )\n Types.Typ.typ\n -> return_typ:(a, retval, _, _) Types.Typ.t\n -> (input_var -> checked)\n -> R1CS_constraint_system.t =\n fun ~run next_input ~input_typ ~return_typ k ->\n (* allocate variables for the public input and the public output *)\n let retval, checked =\n collect_input_constraints next_input ~input_typ ~return_typ (fun () ->\n k )\n in\n\n (* ? *)\n let run_in_run checked state =\n let state, x = Checked.run checked state in\n run x state\n in\n\n (* ? *)\n constraint_system ~run:run_in_run ~num_inputs:!next_input ~return_typ\n retval\n (Checked.map ~f:(fun r -> r ()) checked)\n\n let constraint_system (type a checked input_var) :\n run:(a, checked) Runner.run\n -> input_typ:(input_var, _, _, _) Types.Typ.typ\n -> return_typ:_\n -> (input_var -> checked)\n -> R1CS_constraint_system.t =\n fun ~run ~input_typ ~return_typ k ->\n r1cs_h ~run (ref 0) ~input_typ ~return_typ k\n\n let generate_public_input :\n ('input_var, 'input_value, _, _) Types.Typ.typ\n -> 'input_value\n -> Field.Vector.t =\n fun (Typ { value_to_fields; _ }) value ->\n let primary_input = Field.Vector.create () in\n let next_input = ref 0 in\n let store_field_elt = store_field_elt primary_input next_input in\n let fields, _aux = value_to_fields value in\n let _fields = Array.map ~f:store_field_elt fields in\n primary_input\n\n let conv :\n type r_var r_value.\n (int -> _ -> r_var -> Field.Vector.t -> r_value)\n -> ('input_var, 'input_value, _, _) Types.Typ.t\n -> _ Types.Typ.t\n -> (unit -> 'input_var -> r_var)\n -> 'input_value\n -> r_value =\n fun cont0 input_typ (Typ return_typ) k0 ->\n let primary_input = Field.Vector.create () in\n let next_input = ref 0 in\n let store_field_elt x =\n let v = !next_input in\n incr next_input ;\n Field.Vector.emplace_back primary_input x ;\n Cvar.Unsafe.of_index v\n in\n let (Typ { var_of_fields; value_to_fields; _ }) = input_typ in\n fun value ->\n let fields, aux = value_to_fields value in\n let fields = Array.map ~f:store_field_elt fields in\n let var = var_of_fields (fields, aux) in\n let retval =\n return_typ.var_of_fields\n ( Core_kernel.Array.init return_typ.size_in_field_elements\n ~f:(fun _ -> alloc_var next_input ())\n , return_typ.constraint_system_auxiliary () )\n in\n cont0 !next_input retval (k0 () var) primary_input\n\n let generate_auxiliary_input :\n run:('a, 'checked) Runner.run\n -> input_typ:_ Types.Typ.t\n -> return_typ:(_, _, _, _) Types.Typ.t\n -> ?handlers:Handler.t list\n -> 'k_var\n -> 'k_value =\n fun ~run ~input_typ ~return_typ ?handlers k ->\n conv\n (fun num_inputs output c primary ->\n let auxiliary =\n auxiliary_input ~run ?handlers ~return_typ ~output ~num_inputs c\n primary\n in\n ignore auxiliary )\n input_typ return_typ\n (fun () -> k)\n\n let generate_witness_conv :\n run:('a, 'checked) Runner.run\n -> f:(Proof_inputs.t -> _ -> 'out)\n -> input_typ:_ Types.Typ.t\n -> return_typ:_ Types.Typ.t\n -> ?handlers:Handler.t list\n -> 'k_var\n -> 'k_value =\n fun ~run ~f ~input_typ ~return_typ ?handlers k ->\n conv\n (fun num_inputs output c primary ->\n let auxiliary, output =\n auxiliary_input ~run ?handlers ~return_typ ~output ~num_inputs c\n primary\n in\n let output =\n let (Typ return_typ) = return_typ in\n let fields, aux = return_typ.var_to_fields output in\n let read_cvar =\n let get_one i =\n if i < num_inputs then Field.Vector.get primary i\n else Field.Vector.get auxiliary (i - num_inputs)\n in\n Cvar.eval (`Return_values_will_be_mutated get_one)\n in\n let fields = Array.map ~f:read_cvar fields in\n return_typ.value_of_fields (fields, aux)\n in\n f\n { Proof_inputs.public_inputs = primary\n ; auxiliary_inputs = auxiliary\n }\n output )\n input_typ return_typ\n (fun () -> k)\n\n let generate_witness =\n generate_witness_conv ~f:(fun inputs _output -> inputs)\n end\n\n module Perform = struct\n let generate_witness ~run t ~return_typ k =\n Run.generate_witness ~run t ~return_typ k\n\n let generate_witness_conv ~run ~f t ~return_typ k =\n Run.generate_witness_conv ~run ~f t ~return_typ k\n\n let constraint_system = Run.constraint_system\n\n let run_unchecked = run_unchecked\n\n let run_and_check_exn = run_and_check_exn\n\n let run_and_check = run_and_check\n\n let check_exn = check_exn\n\n let check = check\n end\n\n let conv f spec return_typ k =\n Run.conv (fun _ _ x _ -> f x) spec return_typ (fun () -> k)\n\n let generate_auxiliary_input ~input_typ ~return_typ k =\n Run.generate_auxiliary_input ~run:Checked.run ~input_typ ~return_typ k\n\n let generate_public_input = Run.generate_public_input\n\n let generate_witness ~input_typ ~return_typ k =\n Run.generate_witness ~run:Checked.run ~input_typ ~return_typ k\n\n let generate_witness_conv ~f ~input_typ ~return_typ k =\n Run.generate_witness_conv ~run:Checked.run ~f ~input_typ ~return_typ k\n\n let constraint_system ~input_typ ~return_typ k =\n Run.constraint_system ~run:Checked.run ~input_typ ~return_typ k\n\n let run_unchecked t = run_unchecked ~run:Checked.run t\n\n let run_and_check t = run_and_check ~run:Checked.run t\n\n let run_and_check_exn t = run_and_check_exn ~run:Checked.run t\n\n let check t = check ~run:Checked.run t\n\n let check_exn t = check_exn ~run:Checked.run t\nend\n","open Core_kernel\nopen Types.Typ\n\nmodule Data_spec0 = struct\n (** A list of {!type:Type.Typ.t} values, describing the inputs to a checked\n computation. The type [('r_var, 'r_value, 'k_var, 'k_value, 'field) t]\n represents\n - ['k_value] is the OCaml type of the computation\n - ['r_value] is the OCaml type of the result\n - ['k_var] is the type of the computation within the R1CS\n - ['k_value] is the type of the result within the R1CS\n - ['field] is the field over which the R1CS operates\n - ['checked] is the type of checked computation that verifies the stored\n contents as R1CS variables.\n\n This functions the same as OCaml's default list type:\n{[\n Data_spec.[typ1; typ2; typ3]\n\n Data_spec.(typ1 :: typs)\n\n let open Data_spec in\n [typ1; typ2; typ3; typ4; typ5]\n\n let open Data_spec in\n typ1 :: typ2 :: typs\n\n]}\n all function as you would expect.\n *)\n type ('r_var, 'r_value, 'k_var, 'k_value, 'f, 'checked) data_spec =\n | ( :: ) :\n ('var, 'value, 'f, 'checked) Types.Typ.t\n * ('r_var, 'r_value, 'k_var, 'k_value, 'f, 'checked) data_spec\n -> ( 'r_var\n , 'r_value\n , 'var -> 'k_var\n , 'value -> 'k_value\n , 'f\n , 'checked )\n data_spec\n | [] : ('r_var, 'r_value, 'r_var, 'r_value, 'f, 'checked) data_spec\nend\n\nmodule Intf = struct\n module type S = sig\n type field\n\n type field_var\n\n type 'field checked\n\n module Var : sig\n type t\n\n val size_in_field_elements : int\n\n val to_field_elements : t -> field_var array\n\n val of_field_elements : field_var array -> t\n\n val check : t -> field checked\n end\n\n module Value : sig\n type t\n\n val size_in_field_elements : int\n\n val to_field_elements : t -> field array\n\n val of_field_elements : field array -> t\n end\n end\nend\n\nmodule type Checked_monad = sig\n type ('a, 'f) t\n\n type 'f field\n\n include Monad_let.S2 with type ('a, 'e) t := ('a, 'e) t\n\n module Types : Types.Types\nend\n\nmodule Make (Checked : Checked_monad) = struct\n type ('var, 'value, 'field) t =\n ('var, 'value, 'field, (unit, 'field) Checked.t) Types.Typ.t\n\n type ('var, 'value, 'field) typ = ('var, 'value, 'field) t\n\n module type S = sig\n type field\n\n include\n Intf.S\n with type 'field checked := (unit, 'field) Checked.t\n and type field := field\n and type field_var := field Cvar.t\n end\n\n module Data_spec = struct\n include Data_spec0\n\n type ('r_var, 'r_value, 'k_var, 'k_value, 'f) t =\n ('r_var, 'r_value, 'k_var, 'k_value, 'f, (unit, 'f) Checked.t) data_spec\n\n let size t =\n let rec go :\n type r_var r_value k_var k_value.\n int -> (r_var, r_value, k_var, k_value, 'f) t -> int =\n fun acc t ->\n match t with\n | [] ->\n acc\n | Typ { size_in_field_elements; _ } :: t' ->\n go (acc + size_in_field_elements) t'\n in\n go 0 t\n end\n\n module T = struct\n let unit () : (unit, unit, 'field) t =\n Typ\n { var_to_fields = (fun () -> ([||], ()))\n ; var_of_fields = (fun _ -> ())\n ; value_to_fields = (fun () -> ([||], ()))\n ; value_of_fields = (fun _ -> ())\n ; size_in_field_elements = 0\n ; constraint_system_auxiliary = (fun () -> ())\n ; check = (fun () -> Checked.return ())\n }\n\n let field () : ('field Cvar.t, 'field, 'field) t =\n Typ\n { var_to_fields = (fun f -> ([| f |], ()))\n ; var_of_fields = (fun (fields, _) -> fields.(0))\n ; value_to_fields = (fun f -> ([| f |], ()))\n ; value_of_fields = (fun (fields, _) -> fields.(0))\n ; size_in_field_elements = 1\n ; constraint_system_auxiliary = (fun () -> ())\n ; check = (fun _ -> Checked.return ())\n }\n\n module Internal = struct\n let snarkless value : _ t =\n Typ\n { var_to_fields = (fun _ -> ([||], ()))\n ; var_of_fields = (fun _ -> value)\n ; value_to_fields =\n (fun value' ->\n assert (phys_equal value value') ;\n ([||], ()) )\n ; value_of_fields = (fun _ -> value)\n ; size_in_field_elements = 0\n ; constraint_system_auxiliary = (fun () -> ())\n ; check = (fun _ -> Checked.return ())\n }\n\n module Ref_typ = As_prover_ref.Make_ref_typ (Checked)\n\n let ref () = Ref_typ.typ\n end\n\n let transport (type var value1 value2 field)\n (Typ\n { var_to_fields\n ; var_of_fields\n ; value_to_fields\n ; value_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check\n } :\n (var, value1, field) t ) ~(there : value2 -> value1)\n ~(back : value1 -> value2) : (var, value2, field) t =\n Typ\n { var_to_fields\n ; var_of_fields\n ; value_to_fields = (fun x -> value_to_fields (there x))\n ; value_of_fields = (fun x -> back (value_of_fields x))\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check\n }\n\n let transport_var (type var1 var2 value field)\n (Typ\n { var_to_fields\n ; var_of_fields\n ; value_to_fields\n ; value_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check\n } :\n (var1, value, field) t ) ~(there : var2 -> var1) ~(back : var1 -> var2)\n : (var2, value, field) t =\n Typ\n { var_to_fields = (fun x -> var_to_fields (there x))\n ; var_of_fields = (fun x -> back (var_of_fields x))\n ; value_to_fields\n ; value_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check = (fun x -> check (there x))\n }\n\n let list ~length\n (Typ\n { var_to_fields\n ; var_of_fields\n ; value_to_fields\n ; value_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check\n } :\n ('elt_var, 'elt_value, 'field) t ) :\n ('elt_var list, 'elt_value list, 'field) t =\n (* NB: We store the size_in_field_elements of each in the auxiliary\n data, to allow for 'reads' of e.g. list of lists of different\n lengths.\n *)\n Typ\n { var_to_fields =\n (fun ts ->\n let rec go ts ((fieldss, auxes) as acc) =\n match ts with\n | [] ->\n acc\n | t :: tl ->\n let fields, aux = var_to_fields t in\n let acc =\n ( Array.append fieldss fields\n , (aux, Array.length fields) :: auxes )\n in\n go tl acc\n in\n go ts ([||], []) )\n ; var_of_fields =\n (fun (fields, auxes) ->\n let vars, _ =\n List.fold\n ~init:([], Array.length fields)\n auxes\n ~f:(fun (vars, end_pos) (aux, num_fields) ->\n let end_pos = end_pos - num_fields in\n let var =\n var_of_fields\n (Array.sub ~pos:end_pos ~len:num_fields fields, aux)\n in\n (var :: vars, end_pos) )\n in\n vars )\n ; value_to_fields =\n (fun ts ->\n let rec go ts ((fieldss, auxes) as acc) =\n match ts with\n | [] ->\n acc\n | t :: tl ->\n let fields, aux = value_to_fields t in\n let acc =\n ( Array.append fieldss fields\n , (aux, Array.length fields) :: auxes )\n in\n go tl acc\n in\n go ts ([||], []) )\n ; value_of_fields =\n (fun (fields, auxes) ->\n let vars, _ =\n List.fold\n ~init:([], Array.length fields)\n auxes\n ~f:(fun (vars, end_pos) (aux, num_fields) ->\n let end_pos = end_pos - num_fields in\n let var =\n value_of_fields\n (Array.sub ~pos:end_pos ~len:num_fields fields, aux)\n in\n (var :: vars, end_pos) )\n in\n vars )\n ; size_in_field_elements = length * size_in_field_elements\n ; constraint_system_auxiliary =\n (fun () ->\n List.init length ~f:(fun _ ->\n (constraint_system_auxiliary (), size_in_field_elements) ) )\n ; check = (fun ts -> Checked.all_unit (List.map ts ~f:check))\n }\n\n let array ~length typ =\n list ~length typ\n |> transport ~there:Array.to_list ~back:Array.of_list\n |> transport_var ~there:Array.to_list ~back:Array.of_list\n\n let hlist (type k_var k_value)\n (spec0 : (unit, unit, k_var, k_value, 'f) Data_spec.t) :\n ((unit, k_var) H_list.t, (unit, k_value) H_list.t, 'f) t =\n let rec go :\n type k_var k_value.\n (unit, unit, k_var, k_value, 'f) Data_spec.t\n -> ((unit, k_var) H_list.t, (unit, k_value) H_list.t, 'f) t =\n fun spec0 ->\n let open H_list in\n match spec0 with\n | [] ->\n Typ\n { var_to_fields = (fun [] -> ([||], ()))\n ; var_of_fields = (fun _ -> [])\n ; value_to_fields = (fun [] -> ([||], ()))\n ; value_of_fields = (fun _ -> [])\n ; size_in_field_elements = 0\n ; constraint_system_auxiliary = (fun () -> ())\n ; check = (fun [] -> Checked.return ())\n }\n | Typ\n { var_to_fields\n ; var_of_fields\n ; value_to_fields\n ; value_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check\n }\n :: spec0 ->\n let (Typ typ) = go spec0 in\n let open H_list in\n Typ\n { var_to_fields =\n (fun (x :: tl) ->\n let fields, aux = var_to_fields x in\n let fieldss, auxes = typ.var_to_fields tl in\n ( Array.append fields fieldss\n , (aux, Array.length fields, auxes) ) )\n ; var_of_fields =\n (fun (fields, (hd, len, tl)) ->\n let var =\n var_of_fields (Array.sub ~pos:0 ~len fields, hd)\n in\n let tl =\n typ.var_of_fields\n ( Array.sub ~pos:len\n ~len:(Array.length fields - len)\n fields\n , tl )\n in\n var :: tl )\n ; value_to_fields =\n (fun (x :: tl) ->\n let fields, aux = value_to_fields x in\n let fieldss, auxes = typ.value_to_fields tl in\n ( Array.append fields fieldss\n , (aux, Array.length fields, auxes) ) )\n ; value_of_fields =\n (fun (fields, (hd, len, tl)) ->\n let value =\n value_of_fields (Array.sub ~pos:0 ~len fields, hd)\n in\n let tl =\n typ.value_of_fields\n ( Array.sub ~pos:len\n ~len:(Array.length fields - len)\n fields\n , tl )\n in\n value :: tl )\n ; size_in_field_elements =\n size_in_field_elements + typ.size_in_field_elements\n ; constraint_system_auxiliary =\n (fun () ->\n let hd = constraint_system_auxiliary () in\n let auxes = typ.constraint_system_auxiliary () in\n (hd, size_in_field_elements, auxes) )\n ; check =\n (fun (x :: tl) ->\n Checked.bind (check x) ~f:(fun () -> typ.check tl) )\n }\n in\n go spec0\n\n let tuple2 typ1 typ2 =\n let open H_list in\n hlist [ typ1; typ2 ]\n |> transport\n ~there:(fun (a, b) -> [ a; b ])\n ~back:(fun ([ a; b ] : (unit, _ -> _ -> unit) H_list.t) -> (a, b))\n |> transport_var\n ~there:(fun (a, b) -> [ a; b ])\n ~back:(fun ([ a; b ] : (unit, _ -> _ -> unit) H_list.t) -> (a, b))\n\n let ( * ) = tuple2\n\n let tuple3 typ1 typ2 typ3 =\n let open H_list in\n hlist [ typ1; typ2; typ3 ]\n |> transport\n ~there:(fun (a, b, c) -> [ a; b; c ])\n ~back:(fun ([ a; b; c ] : (unit, _ -> _ -> _ -> unit) H_list.t) ->\n (a, b, c) )\n |> transport_var\n ~there:(fun (a, b, c) -> [ a; b; c ])\n ~back:(fun ([ a; b; c ] : (unit, _ -> _ -> _ -> unit) H_list.t) ->\n (a, b, c) )\n\n let tuple4 typ1 typ2 typ3 typ4 =\n let open H_list in\n hlist [ typ1; typ2; typ3; typ4 ]\n |> transport\n ~there:(fun (a, b, c, d) -> [ a; b; c; d ])\n ~back:(fun ([ a; b; c; d ] :\n (unit, _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d) )\n |> transport_var\n ~there:(fun (a, b, c, d) -> [ a; b; c; d ])\n ~back:(fun ([ a; b; c; d ] :\n (unit, _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d) )\n\n let tuple5 typ1 typ2 typ3 typ4 typ5 =\n let open H_list in\n hlist [ typ1; typ2; typ3; typ4; typ5 ]\n |> transport\n ~there:(fun (a, b, c, d, e) -> [ a; b; c; d; e ])\n ~back:(fun ([ a; b; c; d; e ] :\n (unit, _ -> _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d, e) )\n |> transport_var\n ~there:(fun (a, b, c, d, e) -> [ a; b; c; d; e ])\n ~back:(fun ([ a; b; c; d; e ] :\n (unit, _ -> _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d, e) )\n\n let tuple6 typ1 typ2 typ3 typ4 typ5 typ6 =\n let open H_list in\n hlist [ typ1; typ2; typ3; typ4; typ5; typ6 ]\n |> transport\n ~there:(fun (a, b, c, d, e, f) -> [ a; b; c; d; e; f ])\n ~back:(fun ([ a; b; c; d; e; f ] :\n (unit, _ -> _ -> _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d, e, f) )\n |> transport_var\n ~there:(fun (a, b, c, d, e, f) -> [ a; b; c; d; e; f ])\n ~back:(fun ([ a; b; c; d; e; f ] :\n (unit, _ -> _ -> _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d, e, f) )\n\n let of_hlistable (spec : (unit, unit, 'k_var, 'k_value, 'f) Data_spec.t)\n ~(var_to_hlist : 'var -> (unit, 'k_var) H_list.t)\n ~(var_of_hlist : (unit, 'k_var) H_list.t -> 'var)\n ~(value_to_hlist : 'value -> (unit, 'k_value) H_list.t)\n ~(value_of_hlist : (unit, 'k_value) H_list.t -> 'value) :\n ('var, 'value, 'f) t =\n hlist spec\n |> transport ~there:value_to_hlist ~back:value_of_hlist\n |> transport_var ~there:var_to_hlist ~back:var_of_hlist\n end\n\n include T\nend\n\ninclude Make (Checked_runner.Simple)\n","open Core_kernel\n\n(** Helpers for operating over a sequence of data (currently, either an array\n or a list) inside of a monad.\n*)\nmodule type S = sig\n type 'a monad\n\n type 'a t\n\n type boolean\n\n val foldi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b monad) -> 'b monad\n\n val fold : 'a t -> init:'b -> f:('b -> 'a -> 'b monad) -> 'b monad\n\n val fold_map :\n 'a t -> init:'b -> f:('b -> 'a -> ('b * 'c) monad) -> ('b * 'c t) monad\n\n val exists : 'a t -> f:('a -> boolean monad) -> boolean monad\n\n val existsi : 'a t -> f:(int -> 'a -> boolean monad) -> boolean monad\n\n val for_all : 'a t -> f:('a -> boolean monad) -> boolean monad\n\n val for_alli : 'a t -> f:(int -> 'a -> boolean monad) -> boolean monad\n\n val all : 'a monad t -> 'a t monad\n\n val all_unit : unit monad t -> unit monad\n\n val init : int -> f:(int -> 'a monad) -> 'a t monad\n\n val iter : 'a t -> f:('a -> unit monad) -> unit monad\n\n val iteri : 'a t -> f:(int -> 'a -> unit monad) -> unit monad\n\n val map : 'a t -> f:('a -> 'b monad) -> 'b t monad\n\n val mapi : 'a t -> f:(int -> 'a -> 'b monad) -> 'b t monad\nend\n\nmodule List\n (M : Monad_let.S) (Bool : sig\n type t\n\n val any : t list -> t M.t\n\n val all : t list -> t M.t\n end) :\n S\n with type 'a t = 'a list\n and type 'a monad := 'a M.t\n and type boolean := Bool.t = struct\n type 'a t = 'a list\n\n open M.Let_syntax\n\n let foldi t ~init ~f =\n let rec go i acc = function\n | [] ->\n return acc\n | x :: xs ->\n let%bind acc = f i acc x in\n go (i + 1) acc xs\n in\n go 0 init t\n\n let fold t ~init ~f = foldi t ~init ~f:(fun _ acc x -> f acc x)\n\n let fold_map xs ~init ~f =\n let%map res, ys =\n fold xs ~init:(init, []) ~f:(fun (acc, ys) x ->\n let%map acc, y = f acc x in\n (acc, y :: ys) )\n in\n (res, List.rev ys)\n\n let all = M.all\n\n let all_unit = M.all_unit\n\n let init n ~f =\n let rec go acc i =\n if i < 0 then return acc\n else\n let%bind x = f i in\n go (x :: acc) (i - 1)\n in\n go [] (n - 1)\n\n let iteri t ~f =\n let rec go i = function\n | [] ->\n return ()\n | x :: xs ->\n let%bind () = f i x in\n go (i + 1) xs\n in\n go 0 t\n\n let iter t ~f = iteri t ~f:(fun _i x -> f x)\n\n let mapi t ~f =\n let rec go i acc = function\n | [] ->\n return (List.rev acc)\n | x :: xs ->\n let%bind y = f i x in\n go (i + 1) (y :: acc) xs\n in\n go 0 [] t\n\n let map t ~f = mapi t ~f:(fun _i x -> f x)\n\n (* The following functions use [map] to evaluate [f] on every element, since\n * we can't shortcut in the snark -- every constraint is either always\n present or always absent -- so we need to apply [f] to all of them\n * [Bool.any]/[Bool.all] operate by calculating the sum of the array,\n which requires an R1CS variable representing each element to be\n available.\n *)\n\n let existsi t ~f = mapi t ~f >>= Bool.any\n\n let exists t ~f = map t ~f >>= Bool.any\n\n let for_alli t ~f = mapi t ~f >>= Bool.all\n\n let for_all t ~f = map t ~f >>= Bool.all\nend\n\nmodule Array\n (M : Monad_let.S) (Bool : sig\n type t\n\n val any : t array -> t M.t\n\n val all : t array -> t M.t\n end) :\n S\n with type 'a t = 'a array\n and type 'a monad := 'a M.t\n and type boolean := Bool.t = struct\n type 'a t = 'a array\n\n open M.Let_syntax\n\n let foldi t ~init ~f =\n Array.foldi t ~init:(M.return init) ~f:(fun i acc x ->\n let%bind acc = acc in\n f i acc x )\n\n let fold t ~init ~f =\n Array.fold t ~init:(M.return init) ~f:(fun acc x ->\n let%bind acc = acc in\n f acc x )\n\n let iteri t ~f = foldi t ~init:() ~f:(fun i () x -> f i x)\n\n let iter t ~f = fold t ~init:() ~f:(fun () x -> f x)\n\n let init n ~f =\n let rec go arr i =\n if i < 0 then M.return arr\n else\n let%bind x = f i in\n Array.unsafe_set arr i x ;\n go arr (i - 1)\n in\n if n < 0 then invalid_arg \"Monad_sequence.Array.init\"\n else if n = 0 then M.return [||]\n else\n let%bind last = f (n - 1) in\n let arr = Array.create ~len:n last in\n go arr (n - 2)\n\n let mapi t ~f = init (Array.length t) ~f:(fun i -> f i (Array.unsafe_get t i))\n\n let map t ~f = mapi t ~f:(fun _i x -> f x)\n\n let fold_map t ~init ~f =\n let res = ref init in\n let%map t =\n map t ~f:(fun x ->\n let%map acc, y = f !res x in\n res := acc ;\n y )\n in\n (!res, t)\n\n let all = map ~f:(fun x -> x)\n\n let all_unit = iter ~f:(fun x -> x)\n\n (* The following functions use [map] to evaluate [f] on every element, since\n * we can't shortcut in the snark -- every constraint is either always\n present or always absent -- so we need to apply [f] to all of them\n * [Bool.any]/[Bool.all] operate by calculating the sum of the array,\n which requires an R1CS variable representing each element to be\n available.\n *)\n\n let existsi t ~f = mapi t ~f >>= Bool.any\n\n let exists t ~f = map t ~f >>= Bool.any\n\n let for_alli t ~f = mapi t ~f >>= Bool.all\n\n let for_all t ~f = map t ~f >>= Bool.all\nend\n","open Core_kernel\n\nlet int_to_bits ~length n =\n let ith_bit i = (n lsr i) land 1 = 1 in\n List.init length ~f:ith_bit\n\nlet int_of_bits bs =\n List.foldi bs ~init:0 ~f:(fun i acc b -> if b then acc + (1 lsl i) else acc)\n\nmodule Make\n (Impl : Snark_intf.Basic) (M : sig\n type t [@@deriving enum]\n end) =\nstruct\n open Impl\n\n (* TODO: Make this throw when the elt is too big *)\n let field_to_int x = int_of_bits (List.take (Field.unpack x) 62)\n\n open M\n\n let _unused = M.min (* generate unused variable error *)\n\n let bit_length =\n let n = Int.ceil_log2 (M.max + 1) in\n assert (n < Field.size_in_bits) ;\n n\n\n type var = Field.Var.t\n\n let to_field t = Field.of_int (to_enum t)\n\n let of_field x = Option.value_exn (of_enum (field_to_int x))\n\n let assert_equal x y = Field.Checked.Assert.equal x y\n\n let typ : (var, t) Typ.t =\n let check =\n if M.max = 1 then fun x -> assert_ (Constraint.boolean x)\n else fun x ->\n Field.Checked.Assert.lte ~bit_length x\n (constant Field.typ (Field.of_int M.max))\n in\n let (Typ typ) = Typ.transport Field.typ ~there:to_field ~back:of_field in\n Typ { typ with check }\n\n let var_to_bits : var -> Boolean.var list Checked.t =\n Field.Checked.unpack ~length:bit_length\n\n let to_bits t = int_to_bits ~length:bit_length (to_enum t)\n\n let if_ b ~(then_ : var) ~(else_ : var) = Field.Checked.if_ b ~then_ ~else_\n\n let var t : var = constant Field.typ (to_field t)\n\n let ( = ) = Field.Checked.equal\nend\n\nmodule Run = struct\n module Make\n (Impl : Snark_intf.Run_basic) (M : sig\n type t [@@deriving enum]\n end) =\n struct\n open Impl\n include Make (Impl.Internal_Basic) (M)\n\n let assert_equal x y = run_checked (assert_equal x y)\n\n let var_to_bits x = run_checked (var_to_bits x)\n\n let if_ x ~then_ ~else_ = run_checked (if_ x ~then_ ~else_)\n\n let ( = ) x y = run_checked (x = y)\n end\nend\n","module Bignum_bigint = Bigint\nopen Core_kernel\n\nlet pow2 n = Bignum_bigint.(pow (of_int 2) (of_int n))\n\nlet bigint_num_bits =\n let rec go acc i =\n if Bignum_bigint.(acc = zero) then i\n else go (Bignum_bigint.shift_right acc 1) (i + 1)\n in\n fun n -> go n 0\n\nmodule Make (Impl : Snark_intf.Basic) = struct\n open Impl\n open Let_syntax\n\n type t =\n { upper_bound : Bignum_bigint.t\n ; lower_bound : Bignum_bigint.t\n ; var : Field.Var.t\n ; bits : Boolean.var list option\n }\n\n let two_to_the n =\n let rec go acc i = if i <= 0 then acc else go (Field.add acc acc) (i - 1) in\n go Field.one n\n\n let to_bits { var; bits; upper_bound; lower_bound = _ } =\n let length = bigint_num_bits upper_bound in\n with_label \"Number.to_bits\" (fun () ->\n match bits with\n | Some bs ->\n return (List.take bs length)\n | None ->\n Field.Checked.unpack var ~length )\n\n let of_bits bs =\n let n = List.length bs in\n assert (n < Field.size_in_bits) ;\n { upper_bound = Bignum_bigint.(pow2 n - one)\n ; lower_bound = Bignum_bigint.zero\n ; var = Field.Var.pack bs\n ; bits = Some bs\n }\n\n let mul_pow_2 n (`Two_to_the k) =\n let%map bits = to_bits n in\n let multiplied = List.init k ~f:(fun _ -> Boolean.false_) @ bits in\n let upper_bound =\n Bignum_bigint.(n.upper_bound * pow (of_int 2) (of_int k))\n in\n assert (Bignum_bigint.(upper_bound < Field.size)) ;\n { upper_bound\n ; lower_bound = Bignum_bigint.(n.lower_bound * pow (of_int 2) (of_int k))\n ; var = Field.Var.pack multiplied\n ; bits = Some multiplied\n }\n\n let div_pow_2 n (`Two_to_the k) =\n let%map bits = to_bits n in\n let divided = List.drop bits k in\n let divided_of_bits = of_bits divided in\n { upper_bound =\n Bignum_bigint.(divided_of_bits.upper_bound / pow (of_int 2) (of_int k))\n ; lower_bound =\n Bignum_bigint.(divided_of_bits.lower_bound / pow (of_int 2) (of_int k))\n ; var = divided_of_bits.var\n ; bits = divided_of_bits.bits\n }\n\n let clamp_to_n_bits t n =\n assert (n < Field.size_in_bits) ;\n with_label \"Number.clamp_to_n_bits\" (fun () ->\n let k = pow2 n in\n if Bignum_bigint.(t.upper_bound < k) then return t\n else\n let%bind bs = to_bits t in\n let bs' = List.take bs n in\n let g = Field.Var.project bs' in\n let%bind fits = Field.Checked.equal t.var g in\n let%map r =\n Field.Checked.if_ fits ~then_:g\n ~else_:(constant Field.typ Field.(sub (two_to_the n) one))\n in\n { upper_bound = Bignum_bigint.(k - one)\n ; lower_bound = t.lower_bound\n ; var = r\n ; bits = None\n } )\n\n let ( < ) x y =\n let open Bignum_bigint in\n (*\n x [ ]\n y [ ]\n\n x [ ]\n y [ ]\n *)\n with_label \"Number.(<)\" (fun () ->\n if x.upper_bound < y.lower_bound then return Boolean.true_\n else if x.lower_bound >= y.upper_bound then return Boolean.false_\n else\n let bit_length =\n Int.max\n (bigint_num_bits x.upper_bound)\n (bigint_num_bits y.upper_bound)\n in\n let%map { less; _ } = Field.Checked.compare ~bit_length x.var y.var in\n less )\n\n let ( <= ) x y =\n let open Bignum_bigint in\n (*\n x [ ]\n y [ ]\n\n x [ ]\n y [ ]\n *)\n with_label \"Number.(<=)\" (fun () ->\n if x.upper_bound <= y.lower_bound then return Boolean.true_\n else if x.lower_bound > y.upper_bound then return Boolean.false_\n else\n let bit_length =\n Int.max\n (bigint_num_bits x.upper_bound)\n (bigint_num_bits y.upper_bound)\n in\n let%map { less_or_equal; _ } =\n Field.Checked.compare ~bit_length x.var y.var\n in\n less_or_equal )\n\n let ( > ) x y = y < x\n\n let ( >= ) x y = y <= x\n\n let ( = ) x y =\n (* TODO: Have \"short circuiting\" for efficiency as above. *)\n Field.Checked.equal x.var y.var\n\n let to_var { var; _ } = var\n\n let constant x =\n let tick_n = Bigint.of_field x in\n let n = Bigint.to_bignum_bigint tick_n in\n { upper_bound = n\n ; lower_bound = n\n ; var = constant Field.typ x\n ; bits =\n Some\n (List.init (bigint_num_bits n) ~f:(fun i ->\n constant Boolean.typ (Bigint.test_bit tick_n i) ) )\n }\n\n let one = constant Field.one\n\n let zero = constant Field.zero\n\n let of_pow_2 (`Two_to_the k) = constant (Field.of_int (Int.pow 2 k))\n\n let if_ b ~then_ ~else_ =\n let%map var = Field.Checked.if_ b ~then_:then_.var ~else_:else_.var in\n let open Bignum_bigint in\n { upper_bound = max then_.upper_bound else_.upper_bound\n ; lower_bound = min then_.lower_bound else_.lower_bound\n ; var\n ; bits = None\n }\n\n let ( + ) x y =\n let open Bignum_bigint in\n let upper_bound = x.upper_bound + y.upper_bound in\n if upper_bound < Field.size then\n { upper_bound\n ; lower_bound = x.lower_bound + y.lower_bound\n ; var = Field.Var.add x.var y.var\n ; bits = None\n }\n else\n failwithf \"Number.+: Potential overflow: (%s + %s > Field.size)\"\n (to_string x.upper_bound) (to_string y.upper_bound) ()\n\n (* Compute (n, k) -> ceil(n / 2^k) using the identity\n\n ceil(n / m)\n =\n if n % m = 0\n then floor(n / m)\n else floor(n / m) + 1\n =\n if m * floor(n / m) = n\n then floor(n / m)\n else floor(n / m) + 1\n *)\n let ceil_div_pow_2 n m =\n let%bind floor_div = div_pow_2 n m in\n let%bind m_divides_n = mul_pow_2 floor_div m >>= ( = ) n in\n if_ m_divides_n ~then_:floor_div ~else_:(floor_div + one)\n\n let ( - ) x y =\n let open Bignum_bigint in\n (* x_upper_bound >= x >= x_lower_bound >= y_upper_bound >= y >= y_lower_bound *)\n if x.lower_bound >= y.upper_bound then\n { upper_bound = x.upper_bound - y.lower_bound\n ; lower_bound = x.lower_bound - y.upper_bound\n ; var = Field.Var.sub x.var y.var\n ; bits = None\n }\n else\n failwithf \"Number.-: Potential underflow (%s < %s)\"\n (to_string x.lower_bound) (to_string y.upper_bound) ()\n\n let ( * ) x y =\n let open Bignum_bigint in\n with_label \"Number.(*)\" (fun () ->\n let upper_bound = x.upper_bound * y.upper_bound in\n if upper_bound < Field.size then\n let%map var = Field.Checked.mul x.var y.var in\n { upper_bound\n ; lower_bound = x.lower_bound * y.lower_bound\n ; var\n ; bits = None\n }\n else\n failwithf \"Number.*: Potential overflow: (%s * %s > Field.size)\"\n (to_string x.upper_bound) (to_string y.upper_bound) () )\n\n (* x mod n = x - n * floor(x / n) *)\n let mod_pow_2 x n =\n let%bind x_div_n = div_pow_2 x n in\n let%map n_x_div_n = mul_pow_2 x_div_n n in\n let res = x - n_x_div_n in\n { res with\n lower_bound = Bignum_bigint.zero\n ; upper_bound =\n (let (`Two_to_the k) = n in\n Bignum_bigint.(pow (of_int 2) (of_int k)) )\n }\n\n let min x y =\n let%bind less = x < y in\n if_ less ~then_:x ~else_:y\n\n let max x y =\n let%bind less = x < y in\n if_ less ~then_:y ~else_:x\nend\n\nmodule Run = struct\n module Make (Impl : Snark_intf.Run_basic) = struct\n open Impl\n include Make (Impl.Internal_Basic)\n\n let ( * ) x y = run_checked (x * y)\n\n let if_ x ~then_ ~else_ = run_checked (if_ x ~then_ ~else_)\n\n let ( < ) x y = run_checked (x < y)\n\n let ( > ) x y = run_checked (x > y)\n\n let ( <= ) x y = run_checked (x <= y)\n\n let ( >= ) x y = run_checked (x >= y)\n\n let ( = ) x y = run_checked (x = y)\n\n let min x y = run_checked (min x y)\n\n let max x y = run_checked (max x y)\n\n let to_bits x = run_checked (to_bits x)\n\n let div_pow_2 x y = run_checked (div_pow_2 x y)\n\n let ceil_div_pow_2 x y = run_checked (ceil_div_pow_2 x y)\n\n let mul_pow_2 x y = run_checked (mul_pow_2 x y)\n\n let mod_pow_2 x y = run_checked (mod_pow_2 x y)\n\n let clamp_to_n_bits x y = run_checked (clamp_to_n_bits x y)\n end\nend\n","include Snark0\nmodule Backend_intf = Backend_intf\nmodule Merkle_tree = Merkle_tree\n","(* shapes.ml -- registry of Bin_prot shapes *)\n\nopen Core_kernel\nmodule Shape_tbl = Hashtbl.Make (Base.String)\n\nlet shape_tbl : (Bin_prot.Shape.t * string) Shape_tbl.t = Shape_tbl.create ()\n\nlet find path_to_type = Shape_tbl.find shape_tbl path_to_type\n\nlet iteri ~f = Shape_tbl.iteri shape_tbl ~f\n\nlet equal_shapes shape1 shape2 =\n let canonical1 = Bin_prot.Shape.eval shape1 in\n let canonical2 = Bin_prot.Shape.eval shape2 in\n Bin_prot.Shape.Canonical.compare canonical1 canonical2 = 0\n\nlet register path_to_type (shape : Bin_prot.Shape.t) (ty_decl : string) =\n match Shape_tbl.add shape_tbl ~key:path_to_type ~data:(shape, ty_decl) with\n | `Ok ->\n ()\n | `Duplicate -> (\n (* versioned types inside functors that are called more than\n once will yield duplicates; OK if the shapes are the same\n *)\n match find path_to_type with\n | Some (shape', _ty_decl) ->\n if not (equal_shapes shape shape') then\n failwithf \"Different type shapes at path %s\" path_to_type ()\n else ()\n | None ->\n failwithf \"Expected to find registered shape at path %s\" path_to_type\n () )\n","(*----------------------------------------------------------------------------\n Copyright (c) 2017 Inhabited Type LLC.\n\n All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions\n are met:\n\n 1. Redistributions of source code must retain the above copyright\n notice, this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in the\n documentation and/or other materials provided with the distribution.\n\n 3. Neither the name of the author nor the names of his contributors\n may be used to endorse or promote products derived from this software\n without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS ``AS IS'' AND ANY EXPRESS\n OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR\n ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\n STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN\n ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n POSSIBILITY OF SUCH DAMAGE.\n ----------------------------------------------------------------------------*)\n\ntype t =\n { mutable parser_committed_bytes : int\n ; client_committed_bytes : int\n ; off : int\n ; len : int\n ; buffer : Bigstringaf.t\n }\n\nlet create buffer ~off ~len ~committed_bytes =\n { parser_committed_bytes = committed_bytes\n ; client_committed_bytes = committed_bytes\n ; off\n ; len\n ; buffer }\n\nlet length t = t.client_committed_bytes + t.len\nlet client_committed_bytes t = t.client_committed_bytes\nlet parser_committed_bytes t = t.parser_committed_bytes\n\nlet committed_bytes_discrepancy t = t.parser_committed_bytes - t.client_committed_bytes\nlet bytes_for_client_to_commit t = committed_bytes_discrepancy t\n\nlet parser_uncommitted_bytes t = t.len - bytes_for_client_to_commit t\n\nlet invariant t =\n assert (parser_committed_bytes t + parser_uncommitted_bytes t = length t);\n assert (parser_committed_bytes t - client_committed_bytes t = bytes_for_client_to_commit t);\n;;\n\nlet offset_in_buffer t pos =\n t.off + pos - t.client_committed_bytes\n\nlet apply t pos len ~f =\n let off = offset_in_buffer t pos in\n f t.buffer ~off ~len\n\nlet unsafe_get_char t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get t.buffer off\n\nlet unsafe_get_int16_le t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int16_le t.buffer off\n\nlet unsafe_get_int32_le t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int32_le t.buffer off\n\nlet unsafe_get_int64_le t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int64_le t.buffer off\n\nlet unsafe_get_int16_be t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int16_be t.buffer off\n\nlet unsafe_get_int32_be t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int32_be t.buffer off\n\nlet unsafe_get_int64_be t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int64_be t.buffer off\n\nlet count_while t pos ~f =\n let buffer = t.buffer in\n let off = offset_in_buffer t pos in\n let i = ref off in\n let limit = t.off + t.len in\n while !i < limit && f (Bigstringaf.unsafe_get buffer !i) do\n incr i\n done;\n !i - off\n;;\n\nlet commit t pos =\n t.parser_committed_bytes <- pos\n;;\n","module State = struct\n type 'a t =\n | Partial of 'a partial\n | Lazy of 'a t Lazy.t\n | Done of int * 'a\n | Fail of int * string list * string\n\n and 'a partial =\n { committed : int\n ; continue : Bigstringaf.t -> off:int -> len:int -> More.t -> 'a t }\n\nend\ntype 'a with_state = Input.t -> int -> More.t -> 'a\n\ntype 'a failure = (string list -> string -> 'a State.t) with_state\ntype ('a, 'r) success = ('a -> 'r State.t) with_state\n\ntype 'a t =\n { run : 'r. ('r failure -> ('a, 'r) success -> 'r State.t) with_state }\n\nlet fail_k input pos _ marks msg =\n State.Fail(pos - Input.client_committed_bytes input, marks, msg)\nlet succeed_k input pos _ v =\n State.Done(pos - Input.client_committed_bytes input, v)\n\nlet rec to_exported_state = function\n | State.Partial {committed;continue} ->\n Exported_state.Partial\n { committed\n ; continue =\n fun bs ~off ~len more ->\n to_exported_state (continue bs ~off ~len more)}\n | State.Done (i,x) -> Exported_state.Done (i,x)\n | State.Fail (i, sl, s) -> Exported_state.Fail (i, sl, s)\n | State.Lazy x -> to_exported_state (Lazy.force x)\n\nlet parse p =\n let input = Input.create Bigstringaf.empty ~committed_bytes:0 ~off:0 ~len:0 in\n to_exported_state (p.run input 0 Incomplete fail_k succeed_k)\n\nlet parse_bigstring p input =\n let input = Input.create input ~committed_bytes:0 ~off:0 ~len:(Bigstringaf.length input) in\n Exported_state.state_to_result (to_exported_state (p.run input 0 Complete fail_k succeed_k))\n\nmodule Monad = struct\n let return v =\n { run = fun input pos more _fail succ ->\n succ input pos more v\n }\n\n let fail msg =\n { run = fun input pos more fail _succ ->\n fail input pos more [] msg\n }\n\n let (>>=) p f =\n { run = fun input pos more fail succ ->\n let succ' input' pos' more' v = (f v).run input' pos' more' fail succ in\n p.run input pos more fail succ'\n }\n\n let (>>|) p f =\n { run = fun input pos more fail succ ->\n let succ' input' pos' more' v = succ input' pos' more' (f v) in\n p.run input pos more fail succ'\n }\n\n let (<$>) f m =\n m >>| f\n\n let (<*>) f m =\n (* f >>= fun f -> m >>| f *)\n { run = fun input pos more fail succ ->\n let succ0 input0 pos0 more0 f =\n let succ1 input1 pos1 more1 m = succ input1 pos1 more1 (f m) in\n m.run input0 pos0 more0 fail succ1\n in\n f.run input pos more fail succ0 }\n\n let lift f m =\n f <$> m\n\n let lift2 f m1 m2 =\n { run = fun input pos more fail succ ->\n let succ1 input1 pos1 more1 m1 =\n let succ2 input2 pos2 more2 m2 = succ input2 pos2 more2 (f m1 m2) in\n m2.run input1 pos1 more1 fail succ2\n in\n m1.run input pos more fail succ1 }\n\n let lift3 f m1 m2 m3 =\n { run = fun input pos more fail succ ->\n let succ1 input1 pos1 more1 m1 =\n let succ2 input2 pos2 more2 m2 =\n let succ3 input3 pos3 more3 m3 =\n succ input3 pos3 more3 (f m1 m2 m3) in\n m3.run input2 pos2 more2 fail succ3 in\n m2.run input1 pos1 more1 fail succ2\n in\n m1.run input pos more fail succ1 }\n\n let lift4 f m1 m2 m3 m4 =\n { run = fun input pos more fail succ ->\n let succ1 input1 pos1 more1 m1 =\n let succ2 input2 pos2 more2 m2 =\n let succ3 input3 pos3 more3 m3 =\n let succ4 input4 pos4 more4 m4 =\n succ input4 pos4 more4 (f m1 m2 m3 m4) in\n m4.run input3 pos3 more3 fail succ4 in\n m3.run input2 pos2 more2 fail succ3 in\n m2.run input1 pos1 more1 fail succ2\n in\n m1.run input pos more fail succ1 }\n\n let ( *>) a b =\n (* a >>= fun _ -> b *)\n { run = fun input pos more fail succ ->\n let succ' input' pos' more' _ = b.run input' pos' more' fail succ in\n a.run input pos more fail succ'\n }\n\n let (<* ) a b =\n (* a >>= fun x -> b >>| fun _ -> x *)\n { run = fun input pos more fail succ ->\n let succ0 input0 pos0 more0 x =\n let succ1 input1 pos1 more1 _ = succ input1 pos1 more1 x in\n b.run input0 pos0 more0 fail succ1\n in\n a.run input pos more fail succ0 }\nend\n\nmodule Choice = struct\n let () p mark =\n { run = fun input pos more fail succ ->\n let fail' input' pos' more' marks msg =\n fail input' pos' more' (mark::marks) msg in\n p.run input pos more fail' succ\n }\n\n let (<|>) p q =\n { run = fun input pos more fail succ ->\n let fail' input' pos' more' marks msg =\n (* The only two constructors that introduce new failure continuations are\n * [] and [<|>]. If the initial input position is less than the length\n * of the committed input, then calling the failure continuation will\n * have the effect of unwinding all choices and collecting marks along\n * the way. *)\n if pos < Input.parser_committed_bytes input' then\n fail input' pos' more marks msg\n else\n q.run input' pos more' fail succ in\n p.run input pos more fail' succ\n }\nend\n\nmodule Monad_use_for_debugging = struct\n let return = Monad.return\n let fail = Monad.fail\n let (>>=) = Monad.(>>=)\n\n let (>>|) m f = m >>= fun x -> return (f x)\n\n let (<$>) f m = m >>| f\n let (<*>) f m = f >>= fun f -> m >>| f\n\n let lift = (>>|)\n let lift2 f m1 m2 = f <$> m1 <*> m2\n let lift3 f m1 m2 m3 = f <$> m1 <*> m2 <*> m3\n let lift4 f m1 m2 m3 m4 = f <$> m1 <*> m2 <*> m3 <*> m4\n\n let ( *>) a b = a >>= fun _ -> b\n let (<* ) a b = a >>= fun x -> b >>| fun _ -> x\nend\n","(*----------------------------------------------------------------------------\n Copyright (c) 2016 Inhabited Type LLC.\n\n All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions\n are met:\n\n 1. Redistributions of source code must retain the above copyright\n notice, this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in the\n documentation and/or other materials provided with the distribution.\n\n 3. Neither the name of the author nor the names of his contributors\n may be used to endorse or promote products derived from this software\n without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS ``AS IS'' AND ANY EXPRESS\n OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR\n ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\n STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN\n ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n POSSIBILITY OF SUCH DAMAGE.\n ----------------------------------------------------------------------------*)\n\nmodule Bigarray = struct\n (* Do not access Bigarray operations directly. If anything's needed, refer to\n * the internal Bigstring module. *)\nend\n\ntype bigstring = Bigstringaf.t\n\n\nmodule Unbuffered = struct\n include Parser\n\n include Exported_state\n\n type more = More.t =\n | Complete\n | Incomplete\nend\n\ninclude Unbuffered\ninclude Parser.Monad\ninclude Parser.Choice\n\nmodule Buffered = struct\n type unconsumed = Buffering.unconsumed =\n { buf : bigstring\n ; off : int\n ; len : int }\n\n type input =\n [ `Bigstring of bigstring\n | `String of string ]\n\n type 'a state =\n | Partial of ([ input | `Eof ] -> 'a state)\n | Done of unconsumed * 'a\n | Fail of unconsumed * string list * string\n\n let from_unbuffered_state ~f buffering = function\n | Unbuffered.Partial p -> Partial (f p)\n | Unbuffered.Done(consumed, v) ->\n let unconsumed = Buffering.unconsumed ~shift:consumed buffering in\n Done(unconsumed, v)\n | Unbuffered.Fail(consumed, marks, msg) ->\n let unconsumed = Buffering.unconsumed ~shift:consumed buffering in\n Fail(unconsumed, marks, msg)\n\n let parse ?(initial_buffer_size=0x1000) p =\n if initial_buffer_size < 1 then\n failwith \"parse: invalid argument, initial_buffer_size < 1\";\n let buffering = Buffering.create initial_buffer_size in\n let rec f p input =\n Buffering.shift buffering p.committed;\n let more : More.t =\n match input with\n | `Eof -> Complete\n | #input as input ->\n Buffering.feed_input buffering input;\n Incomplete\n in\n let for_reading = Buffering.for_reading buffering in\n p.continue for_reading ~off:0 ~len:(Bigstringaf.length for_reading) more\n |> from_unbuffered_state buffering ~f\n in\n Unbuffered.parse p\n |> from_unbuffered_state buffering ~f\n\n let feed state input =\n match state with\n | Partial k -> k input\n | Fail(unconsumed, marks, msg) ->\n begin match input with\n | `Eof -> state\n | #input as input ->\n let buffering = Buffering.of_unconsumed unconsumed in\n Buffering.feed_input buffering input;\n Fail(Buffering.unconsumed buffering, marks, msg)\n end\n | Done(unconsumed, v) ->\n begin match input with\n | `Eof -> state\n | #input as input ->\n let buffering = Buffering.of_unconsumed unconsumed in\n Buffering.feed_input buffering input;\n Done(Buffering.unconsumed buffering, v)\n end\n\n let state_to_option = function\n | Done(_, v) -> Some v\n | Partial _ -> None\n | Fail _ -> None\n\n let state_to_result = function\n | Partial _ -> Error \"incomplete input\"\n | Done(_, v) -> Ok v\n | Fail(_, marks, msg) -> Error (Unbuffered.fail_to_string marks msg)\n\n let state_to_unconsumed = function\n | Done(unconsumed, _)\n | Fail(unconsumed, _, _) -> Some unconsumed\n | Partial _ -> None\n\nend\n\n(** BEGIN: getting input *)\n\nlet rec prompt input pos fail succ =\n (* [prompt] should only call [succ] if it has received more input. If there\n * is no chance that the input will grow, i.e., [more = Complete], then\n * [prompt] should call [fail]. Otherwise (in the case where the input\n * hasn't grown but [more = Incomplete] just prompt again. *)\n let parser_uncommitted_bytes = Input.parser_uncommitted_bytes input in\n let parser_committed_bytes = Input.parser_committed_bytes input in\n (* The continuation should not hold any references to input above. *)\n let continue input ~off ~len more =\n if len < parser_uncommitted_bytes then\n failwith \"prompt: input shrunk!\";\n let input = Input.create input ~off ~len ~committed_bytes:parser_committed_bytes in\n if len = parser_uncommitted_bytes then\n match (more : More.t) with\n | Complete -> fail input pos More.Complete\n | Incomplete -> prompt input pos fail succ\n else\n succ input pos more\n in\n State.Partial { committed = Input.bytes_for_client_to_commit input; continue }\n\nlet demand_input =\n { run = fun input pos more fail succ ->\n match (more : More.t) with\n | Complete -> fail input pos more [] \"not enough input\"\n | Incomplete ->\n let succ' input' pos' more' = succ input' pos' more' ()\n and fail' input' pos' more' = fail input' pos' more' [] \"not enough input\" in\n prompt input pos fail' succ'\n }\n\nlet ensure_suspended n input pos more fail succ =\n let rec go =\n { run = fun input' pos' more' fail' succ' ->\n if pos' + n <= Input.length input' then\n succ' input' pos' more' ()\n else\n (demand_input *> go).run input' pos' more' fail' succ'\n }\n in\n (demand_input *> go).run input pos more fail succ\n\nlet unsafe_apply len ~f =\n { run = fun input pos more _fail succ ->\n succ input (pos + len) more (Input.apply input pos len ~f)\n }\n\nlet unsafe_apply_opt len ~f =\n { run = fun input pos more fail succ ->\n match Input.apply input pos len ~f with\n | Error e -> fail input pos more [] e\n | Ok x -> succ input (pos + len) more x\n }\n\nlet ensure n p =\n { run = fun input pos more fail succ ->\n if pos + n <= Input.length input\n then p.run input pos more fail succ\n else\n let succ' input' pos' more' () = p.run input' pos' more' fail succ in\n ensure_suspended n input pos more fail succ' }\n\n(** END: getting input *)\n\nlet at_end_of_input =\n { run = fun input pos more _ succ ->\n if pos < Input.length input then\n succ input pos more false\n else match more with\n | Complete -> succ input pos more true\n | Incomplete ->\n let succ' input' pos' more' = succ input' pos' more' false\n and fail' input' pos' more' = succ input' pos' more' true in\n prompt input pos fail' succ'\n }\n\nlet end_of_input =\n at_end_of_input\n >>= function\n | true -> return ()\n | false -> fail \"end_of_input\"\n\nlet advance n =\n if n < 0\n then fail \"advance\"\n else\n let p =\n { run = fun input pos more _fail succ -> succ input (pos + n) more () }\n in\n ensure n p\n\nlet pos =\n { run = fun input pos more _fail succ -> succ input pos more pos }\n\nlet available =\n { run = fun input pos more _fail succ ->\n succ input pos more (Input.length input - pos)\n }\n\nlet commit =\n { run = fun input pos more _fail succ ->\n Input.commit input pos;\n succ input pos more () }\n\n(* Do not use this if [p] contains a [commit]. *)\nlet unsafe_lookahead p =\n { run = fun input pos more fail succ ->\n let succ' input' _ more' v = succ input' pos more' v in\n p.run input pos more fail succ' }\n\nlet peek_char =\n { run = fun input pos more _fail succ ->\n if pos < Input.length input then\n succ input pos more (Some (Input.unsafe_get_char input pos))\n else if more = Complete then\n succ input pos more None\n else\n let succ' input' pos' more' =\n succ input' pos' more' (Some (Input.unsafe_get_char input' pos'))\n and fail' input' pos' more' =\n succ input' pos' more' None in\n prompt input pos fail' succ'\n }\n\n(* This parser is too important to not be optimized. Do a custom job. *)\nlet rec peek_char_fail =\n { run = fun input pos more fail succ ->\n if pos < Input.length input\n then succ input pos more (Input.unsafe_get_char input pos)\n else\n let succ' input' pos' more' () =\n peek_char_fail.run input' pos' more' fail succ in\n ensure_suspended 1 input pos more fail succ' }\n\nlet satisfy f =\n { run = fun input pos more fail succ ->\n if pos < Input.length input then\n let c = Input.unsafe_get_char input pos in\n if f c\n then succ input (pos + 1) more c\n else Printf.ksprintf (fail input pos more []) \"satisfy: %C\" c\n else\n let succ' input' pos' more' () =\n let c = Input.unsafe_get_char input' pos' in\n if f c\n then succ input' (pos' + 1) more' c\n else Printf.ksprintf (fail input' pos' more' []) \"satisfy: %C\" c\n in\n ensure_suspended 1 input pos more fail succ' }\n\nlet char c =\n let p =\n { run = fun input pos more fail succ ->\n if Input.unsafe_get_char input pos = c\n then succ input (pos + 1) more c\n else fail input pos more [] (Printf.sprintf \"char %C\" c) }\n in\n ensure 1 p\n\nlet not_char c =\n let p =\n { run = fun input pos more fail succ ->\n let c' = Input.unsafe_get_char input pos in\n if c <> c'\n then succ input (pos + 1) more c'\n else fail input pos more [] (Printf.sprintf \"not char %C\" c) }\n in\n ensure 1 p\n\nlet any_char =\n let p =\n { run = fun input pos more _fail succ ->\n succ input (pos + 1) more (Input.unsafe_get_char input pos) }\n in\n ensure 1 p\n\nlet int8 i =\n let p =\n { run = fun input pos more fail succ ->\n let c = Char.code (Input.unsafe_get_char input pos) in\n if c = i land 0xff\n then succ input (pos + 1) more c\n else fail input pos more [] (Printf.sprintf \"int8 %d\" i) }\n in\n ensure 1 p\n\nlet any_uint8 =\n let p =\n { run = fun input pos more _fail succ ->\n let c = Input.unsafe_get_char input pos in\n succ input (pos + 1) more (Char.code c) }\n in\n ensure 1 p\n\nlet any_int8 =\n (* https://graphics.stanford.edu/~seander/bithacks.html#VariableSignExtendRisky *)\n let s = Sys.int_size - 8 in\n let p =\n { run = fun input pos more _fail succ ->\n let c = Input.unsafe_get_char input pos in\n succ input (pos + 1) more ((Char.code c lsl s) asr s) }\n in\n ensure 1 p\n\nlet skip f =\n let p =\n { run = fun input pos more fail succ ->\n if f (Input.unsafe_get_char input pos)\n then succ input (pos + 1) more ()\n else fail input pos more [] \"skip\" }\n in\n ensure 1 p\n\nlet rec count_while ~init ~f ~with_buffer =\n { run = fun input pos more fail succ ->\n let len = Input.count_while input (pos + init) ~f in\n let input_len = Input.length input in\n let init' = init + len in\n (* Check if the loop terminated because it reached the end of the input\n * buffer. If so, then prompt for additional input and continue. *)\n if pos + init' < input_len || more = Complete\n then succ input (pos + init') more (Input.apply input pos init' ~f:with_buffer)\n else\n let succ' input' pos' more' =\n (count_while ~init:init' ~f ~with_buffer).run input' pos' more' fail succ\n and fail' input' pos' more' =\n succ input' (pos' + init') more' (Input.apply input' pos' init' ~f:with_buffer)\n in\n prompt input pos fail' succ'\n }\n\nlet rec count_while1 ~f ~with_buffer =\n { run = fun input pos more fail succ ->\n let len = Input.count_while input pos ~f in\n let input_len = Input.length input in\n (* Check if the loop terminated because it reached the end of the input\n * buffer. If so, then prompt for additional input and continue. *)\n if len < 1\n then\n if pos < input_len || more = Complete\n then fail input pos more [] \"count_while1\"\n else\n let succ' input' pos' more' =\n (count_while1 ~f ~with_buffer).run input' pos' more' fail succ\n and fail' input' pos' more' =\n fail input' pos' more' [] \"count_while1\"\n in\n prompt input pos fail' succ'\n else if pos + len < input_len || more = Complete\n then succ input (pos + len) more (Input.apply input pos len ~f:with_buffer)\n else\n let succ' input' pos' more' =\n (count_while ~init:len ~f ~with_buffer).run input' pos' more' fail succ\n and fail' input' pos' more' =\n succ input' (pos' + len) more' (Input.apply input' pos' len ~f:with_buffer)\n in\n prompt input pos fail' succ'\n }\n\nlet string_ f s =\n (* XXX(seliopou): Inefficient. Could check prefix equality to short-circuit\n * the io. *)\n let len = String.length s in\n ensure len (unsafe_apply_opt len ~f:(fun buffer ~off ~len ->\n let i = ref 0 in\n while !i < len && Char.equal (f (Bigstringaf.unsafe_get buffer (off + !i)))\n (f (String.unsafe_get s !i))\n do\n incr i\n done;\n if len = !i\n then Ok (Bigstringaf.substring buffer ~off ~len)\n else Error \"string\"))\n\nlet string s = string_ (fun x -> x) s\nlet string_ci s = string_ Char.lowercase_ascii s\n\nlet skip_while f =\n count_while ~init:0 ~f ~with_buffer:(fun _ ~off:_ ~len:_ -> ())\n\nlet take n =\n if n < 0\n then fail \"take: n < 0\"\n else\n let n = max n 0 in\n ensure n (unsafe_apply n ~f:Bigstringaf.substring)\n\nlet take_bigstring n =\n if n < 0\n then fail \"take_bigstring: n < 0\"\n else\n let n = max n 0 in\n ensure n (unsafe_apply n ~f:Bigstringaf.copy)\n\nlet take_bigstring_while f =\n count_while ~init:0 ~f ~with_buffer:Bigstringaf.copy\n\nlet take_bigstring_while1 f =\n count_while1 ~f ~with_buffer:Bigstringaf.copy\n\nlet take_bigstring_till f =\n take_bigstring_while (fun c -> not (f c))\n\nlet peek_string n =\n unsafe_lookahead (take n)\n\nlet take_while f =\n count_while ~init:0 ~f ~with_buffer:Bigstringaf.substring\n\nlet take_while1 f =\n count_while1 ~f ~with_buffer:Bigstringaf.substring\n\nlet take_till f =\n take_while (fun c -> not (f c))\n\nlet choice ?(failure_msg=\"no more choices\") ps =\n List.fold_right (<|>) ps (fail failure_msg)\n\nlet fix_direct f =\n let rec p = lazy (f r)\n and r = { run = fun buf pos more fail succ ->\n (Lazy.force p).run buf pos more fail succ }\n in\n r\n\nlet fix_lazy f =\n let max_steps = 20 in\n let steps = ref max_steps in\n let rec p = lazy (f r)\n and r = { run = fun buf pos more fail succ ->\n decr steps;\n if !steps < 0\n then (\n steps := max_steps;\n State.Lazy (lazy ((Lazy.force p).run buf pos more fail succ)))\n else\n (Lazy.force p).run buf pos more fail succ\n }\n in\n r\n\nlet fix = match Sys.backend_type with\n | Native -> fix_direct\n | Bytecode -> fix_direct\n | Other _ -> fix_lazy\n\nlet option x p =\n p <|> return x\n\nlet cons x xs = x :: xs\n\nlet rec list ps =\n match ps with\n | [] -> return []\n | p::ps -> lift2 cons p (list ps)\n\nlet count n p =\n if n < 0 \n then fail \"count: n < 0\"\n else \n let rec loop = function\n | 0 -> return []\n | n -> lift2 cons p (loop (n - 1))\n in\n loop n\n\nlet many p =\n fix (fun m ->\n (lift2 cons p m) <|> return [])\n\nlet many1 p =\n lift2 cons p (many p)\n\nlet many_till p t =\n fix (fun m ->\n (t *> return []) <|> (lift2 cons p m))\n\nlet sep_by1 s p =\n fix (fun m ->\n lift2 cons p ((s *> m) <|> return []))\n\nlet sep_by s p =\n (lift2 cons p ((s *> sep_by1 s p) <|> return [])) <|> return []\n\nlet skip_many p =\n fix (fun m ->\n (p *> m) <|> return ())\n\nlet skip_many1 p =\n p *> skip_many p\n\nlet end_of_line =\n (char '\\n' *> return ()) <|> (string \"\\r\\n\" *> return ()) \"end_of_line\"\n\nlet scan_ state f ~with_buffer =\n { run = fun input pos more fail succ ->\n let state = ref state in\n let parser =\n count_while ~init:0 ~f:(fun c ->\n match f !state c with\n | None -> false\n | Some state' -> state := state'; true)\n ~with_buffer\n >>| fun x -> x, !state\n in\n parser.run input pos more fail succ }\n\nlet scan state f =\n scan_ state f ~with_buffer:Bigstringaf.substring\n\nlet scan_state state f =\n scan_ state f ~with_buffer:(fun _ ~off:_ ~len:_ -> ())\n >>| fun ((), state) -> state\n\nlet scan_string state f =\n scan state f >>| fst\n\nlet consume_with p f =\n { run = fun input pos more fail succ ->\n let start = pos in\n let parser_committed_bytes = Input.parser_committed_bytes input in\n let succ' input' pos' more' _ =\n if parser_committed_bytes <> Input.parser_committed_bytes input'\n then fail input' pos' more' [] \"consumed: parser committed\"\n else (\n let len = pos' - start in\n let consumed = Input.apply input' start len ~f in\n succ input' pos' more' consumed)\n in\n p.run input pos more fail succ'\n }\n\nlet consumed p = consume_with p Bigstringaf.substring\nlet consumed_bigstring p = consume_with p Bigstringaf.copy\n\nlet both a b = lift2 (fun a b -> a, b) a b\nlet map t ~f = t >>| f\nlet bind t ~f = t >>= f\nlet map2 a b ~f = lift2 f a b\nlet map3 a b c ~f = lift3 f a b c\nlet map4 a b c d ~f = lift4 f a b c d\n\nmodule Let_syntax = struct\n let return = return\n let ( >>| ) = ( >>| )\n let ( >>= ) = ( >>= )\n\n module Let_syntax = struct\n let return = return\n let map = map\n let bind = bind\n let both = both\n let map2 = map2\n let map3 = map3\n let map4 = map4\n end\nend\n\nlet ( let+ ) = ( >>| )\nlet ( let* ) = ( >>= )\nlet ( and+ ) = both\n\nmodule BE = struct\n (* XXX(seliopou): The pattern in both this module and [LE] are a compromise\n * between efficiency and code reuse. By inlining [ensure] you can recover\n * about 2 nanoseconds on average. That may add up in certain applications.\n *\n * This pattern does not allocate in the fast (success) path.\n * *)\n let int16 n =\n let bytes = 2 in\n let p =\n { run = fun input pos more fail succ ->\n if Input.unsafe_get_int16_be input pos = (n land 0xffff)\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"BE.int16\" }\n in\n ensure bytes p\n\n let int32 n =\n let bytes = 4 in\n let p =\n { run = fun input pos more fail succ ->\n if Int32.equal (Input.unsafe_get_int32_be input pos) n\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"BE.int32\" }\n in\n ensure bytes p\n\n let int64 n =\n let bytes = 8 in\n let p =\n { run = fun input pos more fail succ ->\n if Int64.equal (Input.unsafe_get_int64_be input pos) n\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"BE.int64\" }\n in\n ensure bytes p\n\n let any_uint16 =\n ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_be bs off))\n\n let any_int16 =\n ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_sign_extended_be bs off))\n\n let any_int32 =\n ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int32_be bs off))\n\n let any_int64 =\n ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int64_be bs off))\n\n let any_float =\n ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Int32.float_of_bits (Bigstringaf.unsafe_get_int32_be bs off)))\n\n let any_double =\n ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Int64.float_of_bits (Bigstringaf.unsafe_get_int64_be bs off)))\nend\n\nmodule LE = struct\n let int16 n =\n let bytes = 2 in\n let p =\n { run = fun input pos more fail succ ->\n if Input.unsafe_get_int16_le input pos = (n land 0xffff)\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"LE.int16\" }\n in\n ensure bytes p\n\n let int32 n =\n let bytes = 4 in\n let p =\n { run = fun input pos more fail succ ->\n if Int32.equal (Input.unsafe_get_int32_le input pos) n\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"LE.int32\" }\n in\n ensure bytes p\n\n let int64 n =\n let bytes = 8 in\n let p =\n { run = fun input pos more fail succ ->\n if Int64.equal (Input.unsafe_get_int64_le input pos) n\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"LE.int64\" }\n in\n ensure bytes p\n\n\n let any_uint16 =\n ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_le bs off))\n\n let any_int16 =\n ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_sign_extended_le bs off))\n\n let any_int32 =\n ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int32_le bs off))\n\n let any_int64 =\n ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int64_le bs off))\n\n let any_float =\n ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Int32.float_of_bits (Bigstringaf.unsafe_get_int32_le bs off)))\n\n let any_double =\n ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Int64.float_of_bits (Bigstringaf.unsafe_get_int64_le bs off)))\nend\n\nmodule Unsafe = struct\n let take n f =\n let n = max n 0 in\n ensure n (unsafe_apply n ~f)\n\n let peek n f =\n unsafe_lookahead (take n f)\n\n let take_while check f =\n count_while ~init:0 ~f:check ~with_buffer:f\n\n let take_while1 check f =\n count_while1 ~f:check ~with_buffer:f\n\n let take_till check f =\n take_while (fun c -> not (check c)) f\nend\n\nmodule Consume = struct\n type t =\n | Prefix\n | All\nend\n\nlet parse_bigstring ~consume p bs =\n let p =\n match (consume : Consume.t) with\n | Prefix -> p\n | All -> p <* end_of_input\n in\n Unbuffered.parse_bigstring p bs\n\nlet parse_string ~consume p s =\n let len = String.length s in\n let bs = Bigstringaf.create len in\n Bigstringaf.unsafe_blit_from_string s ~src_off:0 bs ~dst_off:0 ~len;\n parse_bigstring ~consume p bs\n","open Core_kernel\n\ntype mode = Hidden | Inline | After\n\ntype config =\n { mode : mode; max_interpolation_length : int; pretty_print : bool }\n\nlet rec result_fold_left ls ~init ~f =\n match ls with\n | [] ->\n Ok init\n | h :: t -> (\n match f init h with\n | Ok init' ->\n result_fold_left t ~init:init' ~f\n | Error err ->\n Error err )\n\nlet parser =\n let open Angstrom in\n let not_f f x = not (f x) in\n let or_f f g x = f x || g x in\n let is_alpha = function\n | 'a' .. 'z' | 'A' .. 'Z' | '_' ->\n true\n | _ ->\n false\n in\n let is_numeric = function '0' .. '9' -> true | _ -> false in\n let interpolation =\n lift2\n (fun c s -> String.of_char c ^ s)\n (char '$' *> commit *> satisfy is_alpha)\n (take_while (or_f is_alpha is_numeric))\n in\n let message =\n many1\n (choice\n [ (take_while1 (not_f (Char.equal '$')) >>| fun x -> `Raw x)\n ; (interpolation >>| fun x -> `Interpolate x)\n ] )\n in\n message <* end_of_input\n\nlet parse = Angstrom.parse_string ~consume:All parser\n\n(* map and concat vs. fold: which is better for strings? *)\nlet render ~max_interpolation_length ~format_json metadata items =\n let open Result.Let_syntax in\n let%map msg, extra =\n result_fold_left items ~init:(\"\", []) ~f:(fun (msg_acc, extra_acc) el ->\n match el with\n | `Raw str ->\n Ok (msg_acc ^ str, extra_acc)\n | `Interpolate id ->\n let%map json =\n String.Map.find metadata id\n |> Result.of_option ~error:(sprintf \"bad interpolation for %s\" id)\n in\n let str = format_json json in\n if String.length str > max_interpolation_length then\n (msg_acc ^ \"$\" ^ id, (id, str) :: extra_acc)\n else (msg_acc ^ str, extra_acc) )\n in\n (msg, List.rev extra)\n\nlet interpolate { mode; max_interpolation_length; pretty_print } msg metadata =\n let open Result.Let_syntax in\n let format_json =\n if pretty_print then Yojson.Safe.pretty_to_string\n else Yojson.Safe.to_string ?buf:None ?len:None\n in\n match mode with\n | Hidden ->\n Ok (msg, [])\n | Inline ->\n let%bind items = parse msg in\n render ~max_interpolation_length ~format_json metadata items\n | After ->\n Ok\n ( msg\n , List.map (String.Map.to_alist metadata) ~f:(fun (k, v) ->\n (k, format_json v) ) )\n","open Core_kernel\n\ntype t = ..\n\ntype id = string [@@deriving equal, yojson, sexp]\n\nmodule Set = String.Set\n\nlet id_of_string s = s\n\nlet string_of_id s = s\n\ntype repr =\n { id : id\n ; event_name : string\n ; arguments : String.Set.t\n ; log : t -> (string * (string * Yojson.Safe.t) list) option\n ; parse : (string * Yojson.Safe.t) list -> t option\n }\n\nmodule Registry = struct\n let reprs : repr list ref = ref []\n\n let register_constructor repr = reprs := repr :: !reprs\nend\n\nlet parse_exn id json_pairs =\n let result =\n List.find_map !Registry.reprs ~f:(fun repr ->\n if equal_id id repr.id then\n let json_pairs =\n (* Remove additional metadata that may have been added to the log\n message.\n *)\n List.filter json_pairs ~f:(fun (field_name, _) ->\n Set.mem repr.arguments field_name )\n in\n match repr.parse json_pairs with\n | Some t ->\n Some t\n | None ->\n failwithf\n \"parse_exn: parser for id %s found, but failed when applied to \\\n arguments: %s\"\n id\n ( List.map json_pairs ~f:(fun (name, json) ->\n sprintf \"%s = %s\" name (Yojson.Safe.to_string json) )\n |> String.concat ~sep:\",\" )\n ()\n else None )\n in\n match result with\n | Some data ->\n data\n | None ->\n failwithf \"parse_exn: did not find matching parser for id %s\" id ()\n\nlet log t =\n let result =\n List.find_map !Registry.reprs ~f:(fun repr ->\n Option.map (repr.log t) ~f:(fun (msg, fields) -> (msg, repr.id, fields)) )\n in\n match result with\n | Some data ->\n data\n | None ->\n let[@warning \"-3\"] name =\n Obj.extension_name (Obj.extension_constructor t)\n in\n failwithf \"log: did not find matching logger for %s\" name ()\n\nlet register_constructor = Registry.register_constructor\n\nlet dump_registered_events () =\n List.map !Registry.reprs ~f:(fun { event_name; id; arguments; _ } ->\n (event_name, id, Set.to_list arguments) )\n\nlet check_interpolations_exn ~msg_loc msg label_names =\n (* don't use Logproc_lib, which depends on C++ code\n using Interpolator_lib allows use in js_of_ocaml\n the `parse` code is the same\n *)\n match Interpolator_lib.Interpolator.parse msg with\n | Error err ->\n failwithf\n \"%s\\nEncountered an error while parsing the structured log message: %s\"\n msg_loc err ()\n | Ok items ->\n List.iter items ~f:(function\n | `Interpolate interp\n when not (List.mem ~equal:String.equal label_names interp) ->\n failwithf\n \"%s\\n\\\n The structured log message contains interpolation point \\\"$%s\\\" \\\n which is not a field in the record\"\n msg_loc interp ()\n | _ ->\n () )\n","type z = Z of z\n\ntype 'a s = Z | S of 'a\n\ntype _ t = Z : z t | S : 'n t -> 'n s t\n\ntype 'a nat = 'a t\n\ntype e = T : 'n nat -> e\n\nlet to_int : type n. n t -> int =\n let rec go : type n. int -> n t -> int =\n fun acc n -> match n with Z -> acc | S n -> go (acc + 1) n\n in\n fun x -> go 0 x\n\nlet rec of_int : int -> e =\n fun n ->\n if n < 0 then failwith \"of_int: negative\"\n else if n = 0 then T Z\n else\n let (T n) = of_int (n - 1) in\n T (S n)\n\nmodule type Intf = sig\n type n\n\n val n : n t\nend\n\nmodule Adds = struct\n type ('a, 'b, 'c) t =\n | Z : (z, 'n, 'n) t\n | S : ('a, 'b, 'c) t -> ('a s, 'b, 'c s) t\n\n let rec add_zr : type n. n nat -> (n, z, n) t = function\n | Z ->\n Z\n | S n ->\n let pi = add_zr n in\n S pi\nend\n\nmodule Lte = struct\n type (_, _) t = Z : (z, _) t | S : ('n, 'm) t -> ('n s, 'm s) t\n\n let rec refl : type n. n nat -> (n, n) t = function\n | Z ->\n Z\n | S n ->\n S (refl n)\n\n let rec trans : type a b c. (a, b) t -> (b, c) t -> (a, c) t =\n fun t1 t2 -> match (t1, t2) with Z, _ -> Z | S t1, S t2 -> S (trans t1 t2)\nend\n\nmodule N0 = struct\n type 'a plus_n = 'a\n\n type n = z\n\n let n = Z\n\n let add m = (m, Adds.Z)\n\n let eq = Core_kernel.Type_equal.T\nend\n\nmodule Add = struct\n module type Intf = sig\n type _ plus_n\n\n type n\n\n val eq : (n, z plus_n) Core_kernel.Type_equal.t\n\n val n : z plus_n t\n\n val add : 'm nat -> 'm plus_n nat * (z plus_n, 'm, 'm plus_n) Adds.t\n end\n\n let rec create : type n. n nat -> (module Intf with type n = n) = function\n | Z ->\n (module N0)\n | S n ->\n let (module N) = create n in\n let T = N.eq in\n let module Sn = struct\n type 'a plus_n = 'a N.plus_n s\n\n type n = N.n s\n\n let n = S N.n\n\n let eq = Core_kernel.Type_equal.T\n\n let add t =\n let t_plus_n, pi = N.add t in\n (S t_plus_n, Adds.S pi)\n end in\n (module Sn)\n\n let n : type n. (module Intf with type n = n) -> n nat =\n fun (module N) ->\n let T = N.eq in\n N.n\n\n module type Intf_transparent = sig\n type _ plus_n\n\n type n = z plus_n\n\n val eq : (n, z plus_n) Core_kernel.Type_equal.t\n\n val n : z plus_n t\n\n val add : 'm nat -> 'm plus_n nat * (z plus_n, 'm, 'm plus_n) Adds.t\n end\nend\n\nmodule S (N : Add.Intf) = struct\n type 'a plus_n = 'a N.plus_n s\n\n type n = z plus_n\n\n let n = S N.n\n\n let add m =\n let k, pi = N.add m in\n (S k, Adds.S pi)\n\n let eq = match N.eq with T -> Core_kernel.Type_equal.T\nend\n\nmodule N1 = S (N0)\nmodule N2 = S (N1)\nmodule N3 = S (N2)\nmodule N4 = S (N3)\nmodule N5 = S (N4)\nmodule N6 = S (N5)\nmodule N7 = S (N6)\nmodule N8 = S (N7)\nmodule N9 = S (N8)\nmodule N10 = S (N9)\nmodule N11 = S (N10)\nmodule N12 = S (N11)\nmodule N13 = S (N12)\nmodule N14 = S (N13)\nmodule N15 = S (N14)\nmodule N16 = S (N15)\nmodule N17 = S (N16)\nmodule N18 = S (N17)\nmodule N19 = S (N18)\nmodule N20 = S (N19)\nmodule N21 = S (N20)\nmodule N22 = S (N21)\nmodule N23 = S (N22)\nmodule N24 = S (N23)\nmodule N25 = S (N24)\nmodule N26 = S (N25)\nmodule N27 = S (N26)\nmodule N28 = S (N27)\nmodule N29 = S (N28)\nmodule N30 = S (N29)\nmodule N31 = S (N30)\nmodule N32 = S (N31)\nmodule N33 = S (N32)\nmodule N34 = S (N33)\nmodule N35 = S (N34)\nmodule N36 = S (N35)\nmodule N37 = S (N36)\nmodule N38 = S (N37)\nmodule N39 = S (N38)\nmodule N40 = S (N39)\nmodule N41 = S (N40)\nmodule N42 = S (N41)\nmodule N43 = S (N42)\nmodule N44 = S (N43)\nmodule N45 = S (N44)\nmodule N46 = S (N45)\nmodule N47 = S (N46)\nmodule N48 = S (N47)\n\nmodule Empty = struct\n type t = T of t\n\n let rec elim : type a. t -> a = function T t -> elim t\nend\n\nmodule Not = struct\n type 'a t = 'a -> Empty.t\nend\n\nopen Core_kernel\n\nlet rec compare :\n type n m. n t -> m t -> [ `Lte of (n, m) Lte.t | `Gt of (n, m) Lte.t Not.t ]\n =\n fun n m ->\n match (n, m) with\n | Z, _ ->\n `Lte Lte.Z\n | S _, Z ->\n `Gt (function _ -> .)\n | S n, S m -> (\n match compare n m with\n | `Lte pi ->\n `Lte (S pi)\n | `Gt gt ->\n `Gt (function S pi -> gt pi) )\n\nlet lte_exn n m =\n match compare n m with `Lte pi -> pi | `Gt _gt -> failwith \"lte_exn\"\n\nlet rec gt_implies_gte :\n type n m. n nat -> m nat -> (n, m) Lte.t Not.t -> (m, n) Lte.t =\n fun n m not_lte ->\n match (n, m) with\n | Z, _ ->\n Empty.elim (not_lte Z)\n | S _, Z ->\n Z\n | S n, S m ->\n S (gt_implies_gte n m (fun pi -> not_lte (S pi)))\n\nlet rec eq :\n type n m.\n n nat\n -> m nat\n -> [ `Equal of (n, m) Type_equal.t\n | `Not_equal of (n, m) Type_equal.t Not.t ] =\n fun n m ->\n match (n, m) with\n | Z, Z ->\n `Equal T\n | S _, Z ->\n `Not_equal (function _ -> .)\n | Z, S _ ->\n `Not_equal (function _ -> .)\n | S n, S m -> (\n match eq n m with\n | `Equal T ->\n `Equal T\n | `Not_equal f ->\n `Not_equal (function T -> f T) )\n\nlet eq_exn : type n m. n nat -> m nat -> (n, m) Type_equal.t =\n fun n m ->\n match eq n m with\n | `Equal t ->\n t\n | `Not_equal _ ->\n failwithf \"eq_exn: %d vs %d\" (to_int n) (to_int m) ()\n\nmodule type I = Add.Intf_transparent\n","module Length = struct\n type (_, _) t =\n | Z : (unit, Nat.z) t\n | S : ('tail, 'n) t -> ('a * 'tail, 'n Nat.s) t\n\n let rec to_nat : type xs n. (xs, n) t -> n Nat.t = function\n | Z ->\n Z\n | S n ->\n S (to_nat n)\n\n type 'xs n = T : 'n Nat.t * ('xs, 'n) t -> 'xs n\n\n let rec contr :\n type xs n m. (xs, n) t -> (xs, m) t -> (n, m) Core_kernel.Type_equal.t =\n fun t1 t2 ->\n match (t1, t2) with\n | Z, Z ->\n T\n | S n, S m ->\n let T = contr n m in\n T\nend\n\nmodule H1 (F : Poly_types.T1) = struct\n type _ t = [] : unit t | ( :: ) : 'a F.t * 'b t -> ('a * 'b) t\n\n let rec length : type tail1. tail1 t -> tail1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\nend\n\nmodule H1_1 (F : Poly_types.T2) = struct\n type (_, 's) t =\n | [] : (unit, _) t\n | ( :: ) : ('a, 's) F.t * ('b, 's) t -> ('a * 'b, 's) t\n\n let rec length : type tail1 tail2. (tail1, tail2) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\nend\n\nmodule Id = struct\n type 'a t = 'a\nend\n\nmodule HlistId = H1 (Id)\n","open Core_kernel\nopen Pickles_types\nmodule Max_state_size = Nat.N8\n\nmodule V = struct\n (* Think about versioning here! These vector types *will* change\n serialization if the numbers above change, and so will require a new\n version number. Thus, it's important that these are modules with new\n versioned types, and not just module aliases to the corresponding vector\n implementation.\n *)\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = 'a Vector.Vector_8.Stable.V1.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n type 'a t = 'a Vector.Vector_8.t\n [@@deriving compare, yojson, sexp, hash, equal]\n\n let map = Vector.map\n\n let of_list_exn = Vector.Vector_8.of_list_exn\n\n let to_list = Vector.to_list\nend\n\nlet _type_equal :\n type a. (a V.t, a Vector.With_length(Max_state_size).t) Type_equal.t =\n Type_equal.T\n\nlet typ t = Vector.typ t Max_state_size.n\n\nopen Core_kernel\n\nmodule Value = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t = Zkapp_basic.F.Stable.V1.t V.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n type t = Zkapp_basic.F.t V.t [@@deriving sexp, equal, yojson, hash, compare]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\nend\n\nlet to_input (t : _ V.t) ~f =\n Vector.(reduce_exn (map t ~f) ~f:Random_oracle_input.Chunked.append)\n\nlet deriver inner obj =\n let open Fields_derivers_zkapps.Derivers in\n iso ~map:V.of_list_exn ~contramap:V.to_list\n ((list ~static_length:(Nat.to_int Max_state_size.n) @@ inner @@ o ())\n (o ()) )\n obj\n","open Core_kernel\nopen Kimchi_backend_common\n\nmodule Rounds : sig\n open Pickles_types\n\n module Wrap : Nat.Add.Intf_transparent\n\n module Wrap_vector : Vector.With_version(Wrap).S\n\n module Step : Nat.Add.Intf_transparent\n\n module Step_vector : Vector.With_version(Step).S\nend = struct\n open Pickles_types\n module Wrap = Nat.N15\n module Step = Nat.N16\n\n (* Think about versioning here! These vector types *will* change\n serialization if the numbers above change, and so will require a new\n version number. Thus, it's important that these are modules with new\n versioned types, and not just module aliases to the corresponding vector\n implementation.\n *)\n\n module Wrap_vector = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = 'a Vector.Vector_15.Stable.V1.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n type 'a t = 'a Vector.Vector_15.t\n [@@deriving compare, yojson, sexp, hash, equal]\n\n let map = Vector.map\n\n let of_list_exn = Vector.Vector_15.of_list_exn\n\n let to_list = Vector.to_list\n end\n\n module Step_vector = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = 'a Vector.Vector_16.Stable.V1.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n type 'a t = 'a Vector.Vector_16.t\n [@@deriving compare, yojson, sexp, hash, equal]\n\n let map = Vector.map\n\n let of_list_exn = Vector.Vector_16.of_list_exn\n\n let to_list = Vector.to_list\n end\nend\n\n(* why use a functor here? *)\nmodule Bigint256 =\n Kimchi_backend_common.Bigint.Make\n (Pasta_bindings.BigInt256)\n (struct\n let length_in_bytes = 32\n end)\n\n(* the two pasta fields and curves *)\n\nmodule Fp = Field.Make (struct\n module Bigint = Bigint256\n include Pasta_bindings.Fp\n module Vector = Kimchi_bindings.FieldVectors.Fp\nend)\n\nmodule Fq = Field.Make (struct\n module Bigint = Bigint256\n include Pasta_bindings.Fq\n module Vector = Kimchi_bindings.FieldVectors.Fq\nend)\n\nmodule Vesta = struct\n module Params = struct\n open Fq\n\n let a = zero\n\n let b = of_int 5\n end\n\n include Curve.Make (Fq) (Fp) (Params) (Pasta_bindings.Vesta)\nend\n\nmodule Pallas = struct\n module Params = struct\n open Fp\n\n let a = zero\n\n let b = of_int 5\n end\n\n include Curve.Make (Fp) (Fq) (Params) (Pasta_bindings.Pallas)\nend\n\n(* the polynomial commitment types *)\n\nmodule Fq_poly_comm = Kimchi_backend_common.Poly_comm.Make (struct\n module Curve = Pallas\n module Base_field = Fp\n\n module Backend = struct\n type t = Curve.Affine.Backend.t Kimchi_types.poly_comm\n\n let shifted ({ shifted; _ } : t) = shifted\n\n let unshifted ({ unshifted; _ } : t) = unshifted\n\n let make :\n Curve.Affine.Backend.t array -> Curve.Affine.Backend.t option -> t =\n fun unshifted shifted : t -> { shifted; unshifted }\n end\nend)\n\nmodule Fp_poly_comm = Kimchi_backend_common.Poly_comm.Make (struct\n module Curve = Vesta\n module Base_field = Fq\n\n module Backend = struct\n type t = Curve.Affine.Backend.t Kimchi_types.poly_comm\n\n let shifted ({ shifted; _ } : t) = shifted\n\n let unshifted ({ unshifted; _ } : t) = unshifted\n\n let make :\n Curve.Affine.Backend.t array -> Curve.Affine.Backend.t option -> t =\n fun unshifted shifted : t -> { shifted; unshifted }\n end\nend)\n\n(* poseidon params *)\n\nlet poseidon_params_fp = Sponge.Params.(map pasta_p_kimchi ~f:Fp.of_string)\n\nlet poseidon_params_fq = Sponge.Params.(map pasta_q_kimchi ~f:Fq.of_string)\n","open Core_kernel\nopen Poly_types\nmodule Id = Hlist0.Id\nmodule HlistId = Hlist0.HlistId\nmodule H1_1 = Hlist0.H1_1\n\nmodule E13 (T : T1) = struct\n type ('a, _, _) t = 'a T.t\nend\n\nmodule E23 (T : T2) = struct\n type ('a, 'b, _) t = ('a, 'b) T.t\nend\n\nmodule E01 (T : T0) = struct\n type _ t = T.t\nend\n\nmodule E02 (T : T0) = struct\n type (_, _) t = T.t\nend\n\nmodule E03 (T : T0) = struct\n type (_, _, _) t = T.t\nend\n\nmodule E04 (T : T0) = struct\n type (_, _, _, _) t = T.t\nend\n\nmodule E06 (T : T0) = struct\n type (_, _, _, _, _, _) t = T.t\nend\n\nmodule Tuple2 (F : T3) (G : T3) = struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) F.t * ('a, 'b, 'c) G.t\nend\n\nmodule Tuple3 (F : T3) (G : T3) (H : T3) = struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) F.t * ('a, 'b, 'c) G.t * ('a, 'b, 'c) H.t\nend\n\nmodule Tuple4 (F : T3) (G : T3) (H : T3) (I : T3) = struct\n type ('a, 'b, 'c) t =\n ('a, 'b, 'c) F.t * ('a, 'b, 'c) G.t * ('a, 'b, 'c) H.t * ('a, 'b, 'c) I.t\nend\n\nmodule Tuple5 (F : T3) (G : T3) (H : T3) (I : T3) (J : T3) = struct\n type ('a, 'b, 'c) t =\n ('a, 'b, 'c) F.t\n * ('a, 'b, 'c) G.t\n * ('a, 'b, 'c) H.t\n * ('a, 'b, 'c) I.t\n * ('a, 'b, 'c) J.t\nend\n\nmodule Arg1 = struct\n type ('a, _, _) t = 'a\nend\n\nmodule Arg2 = struct\n type (_, 'a, _) t = 'a\nend\n\nmodule Apply2 (F : T2) (X : T1) (Y : T1) = struct\n type ('a, 'b) t = ('a X.t, 'b Y.t) F.t\nend\n\nmodule Dup (F : T2) = struct\n type 'a t = ('a, 'a) F.t\nend\n\nmodule Length = Hlist0.Length\n\nmodule H1 = struct\n module T = Hlist0.H1\n\n module Iter\n (F : T1) (C : sig\n val f : 'a F.t -> unit\n end) =\n struct\n let rec f : type a. a T(F).t -> unit = function\n | [] ->\n ()\n | x :: xs ->\n C.f x ; f xs\n end\n\n module Of_vector (X : T0) = struct\n let rec f :\n type xs length.\n (xs, length) Length.t -> (X.t, length) Vector.t -> xs T(E01(X)).t =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\n\n module Map\n (F : T1)\n (G : T1) (C : sig\n val f : 'a F.t -> 'a G.t\n end) =\n struct\n let rec f : type a. a T(F).t -> a T(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module Fold\n (F : T1)\n (X : T0) (C : sig\n val f : X.t -> 'a F.t -> X.t\n end) =\n struct\n let rec f : type a. init:X.t -> a T(F).t -> X.t =\n fun ~init xs ->\n match xs with [] -> init | x :: xs -> f ~init:(C.f init x) xs\n end\n\n module Map_reduce\n (F : T1)\n (X : T0) (C : sig\n val reduce : X.t -> X.t -> X.t\n\n val map : 'a F.t -> X.t\n end) =\n struct\n let rec f : type a. X.t -> a T(F).t -> X.t =\n fun acc xs ->\n match xs with [] -> acc | x :: xs -> f (C.reduce acc (C.map x)) xs\n\n let f (type a) (xs : a T(F).t) =\n match xs with\n | [] ->\n failwith \"Hlist.Map_reduce: empty list\"\n | x :: xs ->\n f (C.map x) xs\n end\n\n module To_vector (X : T0) = struct\n let rec f :\n type xs length.\n (xs, length) Length.t -> xs T(E01(X)).t -> (X.t, length) Vector.t =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\n\n module Tuple2 (F : T1) (G : T1) = struct\n type 'a t = 'a F.t * 'a G.t\n end\n\n module Zip (F : T1) (G : T1) = struct\n let rec f : type a. a T(F).t -> a T(G).t -> a T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Typ (Impl : sig\n type field\n end)\n (F : T1)\n (Var : T1)\n (Val : T1) (C : sig\n val f : 'a F.t -> ('a Var.t, 'a Val.t, Impl.field) Snarky_backendless.Typ.t\n end) =\n struct\n let rec f :\n type xs.\n xs T(F).t\n -> (xs T(Var).t, xs T(Val).t, Impl.field) Snarky_backendless.Typ.t =\n let transport, transport_var, tuple2, unit =\n Snarky_backendless.Typ.(transport, transport_var, tuple2, unit)\n in\n fun ts ->\n match ts with\n | t :: ts ->\n let tail = f ts in\n transport\n (tuple2 (C.f t) tail)\n ~there:(fun (x :: xs : _ T(Val).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n |> transport_var\n ~there:(fun (x :: xs : _ T(Var).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n | [] ->\n let there _ = () in\n transport (unit ()) ~there ~back:(fun () : _ T(Val).t -> [])\n |> transport_var ~there ~back:(fun () : _ T(Var).t -> [])\n end\nend\n\nmodule H2 = struct\n module Arg1 = struct\n type ('a, _) t = 'a\n end\n\n module Arg2 = struct\n type (_, 'a) t = 'a\n end\n\n module Tuple2 (F : T2) (G : T2) = struct\n type ('a, 'b) t = ('a, 'b) F.t * ('a, 'b) G.t\n end\n\n module T (F : T2) = struct\n type (_, _) t =\n | [] : (unit, unit) t\n | ( :: ) : ('a1, 'a2) F.t * ('b1, 'b2) t -> ('a1 * 'b1, 'a2 * 'b2) t\n\n let rec length : type tail1 tail2. (tail1, tail2) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\n\n module Zip (F : T2) (G : T2) = struct\n let rec f :\n type a b. (a, b) T(F).t -> (a, b) T(G).t -> (a, b) T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Map\n (F : T2)\n (G : T2) (C : sig\n val f : ('a, 'b) F.t -> ('a, 'b) G.t\n end) =\n struct\n let rec f : type a b. (a, b) T(F).t -> (a, b) T(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module Typ (Impl : sig\n type field\n\n module Typ : sig\n type ('var, 'value) t = ('var, 'value, field) Snarky_backendless.Typ.t\n end\n end) =\n struct\n let transport, transport_var, tuple2, unit =\n Snarky_backendless.Typ.(transport, transport_var, tuple2, unit)\n\n let rec f :\n type vars values.\n (vars, values) T(Impl.Typ).t\n -> ( vars H1.T(Id).t\n , values H1.T(Id).t\n , Impl.field )\n Snarky_backendless.Typ.t =\n fun ts ->\n match ts with\n | [] ->\n let there _ = () in\n transport (unit ()) ~there ~back:(fun () : _ H1.T(Id).t -> [])\n |> transport_var ~there ~back:(fun () : _ H1.T(Id).t -> [])\n | t :: ts ->\n transport\n (tuple2 t (f ts))\n ~there:(fun (x :: xs : _ H1.T(Id).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n |> transport_var\n ~there:(fun (x :: xs : _ H1.T(Id).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n end\nend\n\nmodule H3_2 = struct\n module T (F : sig\n type (_, _, _, _, _) t\n end) =\n struct\n type (_, _, _, 's1, 's2) t =\n | [] : (unit, unit, unit, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 's1, 's2) F.t * ('b1, 'b2, 'b3, 's1, 's2) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 's1, 's2) t\n\n let rec length : type t1 t2 t3 e1 e2. (t1, t2, t3, e1, e2) t -> t1 Length.n\n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H3_3 = struct\n module T (F : sig\n type (_, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, 's1, 's2, 's3) t =\n | [] : (unit, unit, unit, _, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 's1, 's2, 's3) F.t * ('b1, 'b2, 'b3, 's1, 's2, 's3) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 's1, 's2, 's3) t\n\n let rec length :\n type t1 t2 t3 e1 e2 e3. (t1, t2, t3, e1, e2, e3) t -> t1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H3_4 = struct\n module T (F : sig\n type (_, _, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, 's1, 's2, 's3, 's4) t =\n | [] : (unit, unit, unit, _, _, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 's1, 's2, 's3, 's4) F.t\n * ('b1, 'b2, 'b3, 's1, 's2, 's3, 's4) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 's1, 's2, 's3, 's4) t\n\n let rec length :\n type t1 t2 t3 e1 e2 e3 e4. (t1, t2, t3, e1, e2, e3, e4) t -> t1 Length.n\n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H2_1 = struct\n module T (F : sig\n type (_, _, _) t\n end) =\n struct\n type (_, _, 's) t =\n | [] : (unit, unit, _) t\n | ( :: ) :\n ('a1, 'a2, 's) F.t * ('b1, 'b2, 's) t\n -> ('a1 * 'b1, 'a2 * 'b2, 's) t\n\n let rec length : type tail1 tail2 e. (tail1, tail2, e) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\n\n module Iter\n (F : T3) (C : sig\n val f : ('a, 'b, 'c) F.t -> unit\n end) =\n struct\n let rec f : type a b c. (a, b, c) T(F).t -> unit = function\n | [] ->\n ()\n | x :: xs ->\n C.f x ; f xs\n end\n\n module Map_\n (F : T3)\n (G : T3) (Env : sig\n type t\n end) (C : sig\n val f : ('a, 'b, Env.t) F.t -> ('a, 'b, Env.t) G.t\n end) =\n struct\n let rec f : type a b. (a, b, Env.t) T(F).t -> (a, b, Env.t) T(G).t =\n function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module Map\n (F : T3)\n (G : T3) (C : sig\n val f : ('a, 'b, 'c) F.t -> ('a, 'b, 'c) G.t\n end) =\n struct\n let f : type a b c. (a, b, c) T(F).t -> (a, b, c) T(G).t =\n fun xs ->\n let module M =\n Map_ (F) (G)\n (struct\n type t = c\n end)\n (struct\n let f = C.f\n end)\n in\n M.f xs\n end\n\n module Zip (F : T3) (G : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(F).t -> (a, b, c) T(G).t -> (a, b, c) T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Zip3 (F1 : T3) (F2 : T3) (F3 : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(F1).t\n -> (a, b, c) T(F2).t\n -> (a, b, c) T(F3).t\n -> (a, b, c) T(Tuple3(F1)(F2)(F3)).t =\n fun xs ys zs ->\n match (xs, ys, zs) with\n | [], [], [] ->\n []\n | x :: xs, y :: ys, z :: zs ->\n (x, y, z) :: f xs ys zs\n end\n\n module Unzip3 (F1 : T3) (F2 : T3) (F3 : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(Tuple3(F1)(F2)(F3)).t\n -> (a, b, c) T(F1).t * (a, b, c) T(F2).t * (a, b, c) T(F3).t =\n fun ts ->\n match ts with\n | [] ->\n ([], [], [])\n | (x, y, z) :: ts ->\n let xs, ys, zs = f ts in\n (x :: xs, y :: ys, z :: zs)\n end\n\n module Zip4 (F1 : T3) (F2 : T3) (F3 : T3) (F4 : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(F1).t\n -> (a, b, c) T(F2).t\n -> (a, b, c) T(F3).t\n -> (a, b, c) T(F4).t\n -> (a, b, c) T(Tuple4(F1)(F2)(F3)(F4)).t =\n fun xs ys zs ws ->\n match (xs, ys, zs, ws) with\n | [], [], [], [] ->\n []\n | x :: xs, y :: ys, z :: zs, w :: ws ->\n (x, y, z, w) :: f xs ys zs ws\n end\n\n module Zip5 (F1 : T3) (F2 : T3) (F3 : T3) (F4 : T3) (F5 : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(F1).t\n -> (a, b, c) T(F2).t\n -> (a, b, c) T(F3).t\n -> (a, b, c) T(F4).t\n -> (a, b, c) T(F5).t\n -> (a, b, c) T(Tuple5(F1)(F2)(F3)(F4)(F5)).t =\n fun l1 l2 l3 l4 l5 ->\n match (l1, l2, l3, l4, l5) with\n | [], [], [], [], [] ->\n []\n | x1 :: l1, x2 :: l2, x3 :: l3, x4 :: l4, x5 :: l5 ->\n (x1, x2, x3, x4, x5) :: f l1 l2 l3 l4 l5\n end\n\n module Of_vector (X : T0) = struct\n let rec f :\n type e xs ys length.\n (xs, length) Length.t\n -> (ys, length) Length.t\n -> (X.t, length) Vector.t\n -> (xs, ys, e) T(E03(X)).t =\n fun l1 l2 v ->\n match (l1, l2, v) with\n | Z, Z, [] ->\n []\n | S n1, S n2, x :: xs ->\n x :: f n1 n2 xs\n end\n\n module To_vector (X : T0) = struct\n let rec f :\n type e xs ys length.\n (xs, length) Length.t\n -> (xs, ys, e) T(E03(X)).t\n -> (X.t, length) Vector.t =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\nend\n\nmodule H3 = struct\n module T (F : sig\n type (_, _, _) t\n end) =\n struct\n type (_, _, _) t =\n | [] : (unit, unit, unit) t\n | ( :: ) :\n ('a1, 'a2, 'a3) F.t * ('b1, 'b2, 'b3) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3) t\n\n let rec length :\n type tail1 tail2 tail3. (tail1, tail2, tail3) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\n\n module To_vector (X : T0) = struct\n let rec f :\n type a b c length.\n (a, length) Length.t -> (a, b, c) T(E03(X)).t -> (X.t, length) Vector.t\n =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\n\n module Zip (F : T3) (G : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(F).t -> (a, b, c) T(G).t -> (a, b, c) T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Arg1 = struct\n type ('a, _, _) t = 'a\n end\n\n module Map1_to_H1\n (F : T3)\n (G : T1) (C : sig\n val f : ('a, 'b, 'c) F.t -> 'a G.t\n end) =\n struct\n let rec f : type a b c. (a, b, c) T(F).t -> a H1.T(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module Map2_to_H1\n (F : T3)\n (G : T1) (C : sig\n val f : ('a, 'b, 'c) F.t -> 'b G.t\n end) =\n struct\n let rec f : type a b c. (a, b, c) T(F).t -> b H1.T(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module Map\n (F : T3)\n (G : T3) (C : sig\n val f : ('a, 'b, 'c) F.t -> ('a, 'b, 'c) G.t\n end) =\n struct\n let rec f : type a b c. (a, b, c) T(F).t -> (a, b, c) T(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\nend\n\nmodule H4 = struct\n module T (F : sig\n type (_, _, _, _) t\n end) =\n struct\n type (_, _, _, _) t =\n | [] : (unit, unit, unit, unit) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4) F.t * ('b1, 'b2, 'b3, 'b4) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 'a4 * 'b4) t\n\n let rec length :\n type tail1 tail2 tail3 tail4.\n (tail1, tail2, tail3, tail4) t -> tail1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\n\n module Fold\n (F : T4)\n (X : T0) (C : sig\n val f : X.t -> _ F.t -> X.t\n end) =\n struct\n let rec f : type a b c d. init:X.t -> (a, b, c, d) T(F).t -> X.t =\n fun ~init xs ->\n match xs with [] -> init | x :: xs -> f ~init:(C.f init x) xs\n end\n\n module Iter\n (F : T4) (C : sig\n val f : _ F.t -> unit\n end) =\n struct\n let rec f : type a b c d. (a, b, c, d) T(F).t -> unit =\n fun xs -> match xs with [] -> () | x :: xs -> C.f x ; f xs\n end\n\n module Map\n (F : T4)\n (G : T4) (C : sig\n val f : ('a, 'b, 'c, 'd) F.t -> ('a, 'b, 'c, 'd) G.t\n end) =\n struct\n let rec f : type a b c d. (a, b, c, d) T(F).t -> (a, b, c, d) T(G).t =\n function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module To_vector (X : T0) = struct\n let rec f :\n type a b c d length.\n (a, length) Length.t\n -> (a, b, c, d) T(E04(X)).t\n -> (X.t, length) Vector.t =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\n\n module Tuple2 (F : T4) (G : T4) = struct\n type ('a, 'b, 'c, 'd) t = ('a, 'b, 'c, 'd) F.t * ('a, 'b, 'c, 'd) G.t\n end\n\n module Zip (F : T4) (G : T4) = struct\n let rec f :\n type a b c d.\n (a, b, c, d) T(F).t\n -> (a, b, c, d) T(G).t\n -> (a, b, c, d) T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Length_1_to_2 (F : T4) = struct\n let rec f :\n type n xs ys a b.\n (xs, ys, a, b) T(F).t -> (xs, n) Length.t -> (ys, n) Length.t =\n fun xs n -> match (xs, n) with [], Z -> Z | _ :: xs, S n -> S (f xs n)\n end\n\n module Typ (Impl : sig\n type field\n end)\n (F : T4)\n (Var : T3)\n (Val : T3) (C : sig\n val f :\n ('var, 'value, 'n1, 'n2) F.t\n -> ( ('var, 'n1, 'n2) Var.t\n , ('value, 'n1, 'n2) Val.t\n , Impl.field )\n Snarky_backendless.Typ.t\n end) =\n struct\n let transport, transport_var, tuple2, unit =\n Snarky_backendless.Typ.(transport, transport_var, tuple2, unit)\n\n let rec f :\n type vars values ns1 ns2.\n (vars, values, ns1, ns2) T(F).t\n -> ( (vars, ns1, ns2) H3.T(Var).t\n , (values, ns1, ns2) H3.T(Val).t\n , Impl.field )\n Snarky_backendless.Typ.t =\n fun ts ->\n match ts with\n | [] ->\n let there _ = () in\n transport (unit ()) ~there ~back:(fun () : _ H3.T(Val).t -> [])\n |> transport_var ~there ~back:(fun () : _ H3.T(Var).t -> [])\n | t :: ts ->\n transport\n (tuple2 (C.f t) (f ts))\n ~there:(fun (x :: xs : _ H3.T(Val).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n |> transport_var\n ~there:(fun (x :: xs : _ H3.T(Var).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n end\nend\n\nmodule H6 = struct\n module T (F : sig\n type (_, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, _, _) t =\n | [] : (unit, unit, unit, unit, unit, unit) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) F.t * ('b1, 'b2, 'b3, 'b4, 'b5, 'b6) t\n -> ( 'a1 * 'b1\n , 'a2 * 'b2\n , 'a3 * 'b3\n , 'a4 * 'b4\n , 'a5 * 'b5\n , 'a6 * 'b6 )\n t\n\n let rec length :\n type tail1 tail2 tail3 tail4 tail5 tail6.\n (tail1, tail2, tail3, tail4, tail5, tail6) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\n\n module Fold\n (F : T6)\n (X : T0) (C : sig\n val f : X.t -> _ F.t -> X.t\n end) =\n struct\n let rec f :\n type a1 a2 a3 a4 a5 a6.\n init:X.t -> (a1, a2, a3, a4, a5, a6) T(F).t -> X.t =\n fun ~init xs ->\n match xs with [] -> init | x :: xs -> f ~init:(C.f init x) xs\n end\n\n module Iter\n (F : T6) (C : sig\n val f : _ F.t -> unit\n end) =\n struct\n let rec f : type a1 a2 a3 a4 a5 a6. (a1, a2, a3, a4, a5, a6) T(F).t -> unit\n =\n fun xs -> match xs with [] -> () | x :: xs -> C.f x ; f xs\n end\n\n module Map\n (F : T6)\n (G : T6) (C : sig\n val f :\n ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) F.t\n -> ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) G.t\n end) =\n struct\n let rec f :\n type a1 a2 a3 a4 a5 a6.\n (a1, a2, a3, a4, a5, a6) T(F).t -> (a1, a2, a3, a4, a5, a6) T(G).t =\n function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module To_vector (X : T0) = struct\n let rec f :\n type a1 a2 a3 a4 a5 a6 length.\n (a1, length) Length.t\n -> (a1, a2, a3, a4, a5, a6) T(E06(X)).t\n -> (X.t, length) Vector.t =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\n\n module Tuple2 (F : T6) (G : T6) = struct\n type ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) t =\n ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) F.t * ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) G.t\n end\n\n module Zip (F : T6) (G : T6) = struct\n let rec f :\n type a1 a2 a3 a4 a5 a6.\n (a1, a2, a3, a4, a5, a6) T(F).t\n -> (a1, a2, a3, a4, a5, a6) T(G).t\n -> (a1, a2, a3, a4, a5, a6) T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Length_1_to_2 (F : T6) = struct\n let rec f :\n type n a1 a2 a3 a4 a5 a6.\n (a1, a2, a3, a4, a5, a6) T(F).t -> (a1, n) Length.t -> (a2, n) Length.t\n =\n fun xs n -> match (xs, n) with [], Z -> Z | _ :: xs, S n -> S (f xs n)\n end\n\n module Typ (Impl : sig\n type field\n end)\n (F : T6)\n (Var : T4)\n (Val : T4) (C : sig\n val f :\n ('var, 'value, 'ret_var, 'ret_value, 'n1, 'n2) F.t\n -> ( ('var, 'ret_var, 'n1, 'n2) Var.t\n , ('value, 'ret_value, 'n1, 'n2) Val.t\n , Impl.field )\n Snarky_backendless.Typ.t\n end) =\n struct\n let transport, transport_var, tuple2, unit =\n Snarky_backendless.Typ.(transport, transport_var, tuple2, unit)\n\n let rec f :\n type vars values ret_vars ret_values ns1 ns2.\n (vars, values, ret_vars, ret_values, ns1, ns2) T(F).t\n -> ( (vars, ret_vars, ns1, ns2) H4.T(Var).t\n , (values, ret_values, ns1, ns2) H4.T(Val).t\n , Impl.field )\n Snarky_backendless.Typ.t =\n fun ts ->\n match ts with\n | [] ->\n let there _ = () in\n transport (unit ()) ~there ~back:(fun () : _ H4.T(Val).t -> [])\n |> transport_var ~there ~back:(fun () : _ H4.T(Var).t -> [])\n | t :: ts ->\n transport\n (tuple2 (C.f t) (f ts))\n ~there:(fun (x :: xs : _ H4.T(Val).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n |> transport_var\n ~there:(fun (x :: xs : _ H4.T(Var).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n end\nend\n\nmodule H4_2 = struct\n module T (F : sig\n type (_, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, 's1, 's2) t =\n | [] : (unit, unit, unit, unit, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 's1, 's2) F.t * ('b1, 'b2, 'b3, 'b4, 's1, 's2) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 'a4 * 'b4, 's1, 's2) t\n\n let rec length :\n type t1 t2 t3 t4 e1 e2. (t1, t2, t3, t4, e1, e2) t -> t1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H4_4 = struct\n module T (F : sig\n type (_, _, _, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, 's1, 's2, 's3, 's4) t =\n | [] : (unit, unit, unit, unit, _, _, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 's1, 's2, 's3, 's4) F.t\n * ('b1, 'b2, 'b3, 'b4, 's1, 's2, 's3, 's4) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 'a4 * 'b4, 's1, 's2, 's3, 's4) t\n\n let rec length :\n type t1 t2 t3 t4 e1 e2 e3 e4.\n (t1, t2, t3, t4, e1, e2, e3, e4) t -> t1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H4_6 = struct\n module T (F : sig\n type (_, _, _, _, _, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, 's1, 's2, 's3, 's4, 's5, 's6) t =\n | [] : (unit, unit, unit, unit, _, _, _, _, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 's1, 's2, 's3, 's4, 's5, 's6) F.t\n * ('b1, 'b2, 'b3, 'b4, 's1, 's2, 's3, 's4, 's5, 's6) t\n -> ( 'a1 * 'b1\n , 'a2 * 'b2\n , 'a3 * 'b3\n , 'a4 * 'b4\n , 's1\n , 's2\n , 's3\n , 's4\n , 's5\n , 's6 )\n t\n\n let rec length :\n type t1 t2 t3 t4 e1 e2 e3 e4 e5 e6.\n (t1, t2, t3, t4, e1, e2, e3, e4, e5, e6) t -> t1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H6_2 = struct\n module T (F : sig\n type (_, _, _, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, _, _, 's1, 's2) t =\n | [] : (unit, unit, unit, unit, unit, unit, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 'a5, 'a6, 's1, 's2) F.t\n * ('b1, 'b2, 'b3, 'b4, 'b5, 'b6, 's1, 's2) t\n -> ( 'a1 * 'b1\n , 'a2 * 'b2\n , 'a3 * 'b3\n , 'a4 * 'b4\n , 'a5 * 'b5\n , 'a6 * 'b6\n , 's1\n , 's2 )\n t\n\n let rec length :\n type t1 t2 t3 t4 t5 t6 e1 e2.\n (t1, t2, t3, t4, t5, t6, e1, e2) t -> t1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H6_4 = struct\n module T (F : sig\n type (_, _, _, _, _, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, _, _, 's1, 's2, 's3, 's4) t =\n | [] : (unit, unit, unit, unit, unit, unit, _, _, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 'a5, 'a6, 's1, 's2, 's3, 's4) F.t\n * ('b1, 'b2, 'b3, 'b4, 'b5, 'b6, 's1, 's2, 's3, 's4) t\n -> ( 'a1 * 'b1\n , 'a2 * 'b2\n , 'a3 * 'b3\n , 'a4 * 'b4\n , 'a5 * 'b5\n , 'a6 * 'b6\n , 's1\n , 's2\n , 's3\n , 's4 )\n t\n\n let rec length :\n type t1 t2 t3 t4 t5 t6 e1 e2 e3 e4.\n (t1, t2, t3, t4, t5, t6, e1, e2, e3, e4) t -> t1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H3_1 (F : sig\n type (_, _, _, _) t\nend) =\nstruct\n type (_, _, _, 's) t =\n | [] : (unit, unit, unit, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 's) F.t * ('b1, 'b2, 'b3, 's) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 's) t\n\n let rec length :\n type tail1 tail2 tail3 e. (tail1, tail2, tail3, e) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\nend\n\nmodule Map_1_specific\n (F : T2)\n (G : T2) (C : sig\n type b1\n\n type b2\n\n val f : ('a, b1) F.t -> ('a, b2) G.t\n end) =\nstruct\n let rec f : type a. (a, C.b1) H1_1(F).t -> (a, C.b2) H1_1(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\nend\n\nopen Nat\n\nmodule type Max_s = sig\n type ns\n\n type n\n\n val n : n t\n\n val p : (ns, n) H1_1(Lte).t\nend\n\ntype 'ns max = (module Max_s with type ns = 'ns)\n\nlet rec max : type n ns. (n * ns) H1.T(Nat).t -> (n * ns) max =\n fun xs ->\n match xs with\n | [ x ] ->\n let module M = struct\n type nonrec ns = n * ns\n\n type nonrec n = n\n\n let n = x\n\n let p : (_, _) H1_1(Lte).t = [ Lte.refl x ]\n end in\n (module M : Max_s with type ns = n * ns)\n | x :: (_ :: _ as ys) -> (\n let (module Max) = max ys in\n match compare x Max.n with\n | `Lte p_x ->\n let module M = struct\n type nonrec ns = n * ns\n\n type n = Max.n\n\n let n = Max.n\n\n let p : (ns, Max.n) H1_1(Lte).t = p_x :: Max.p\n end in\n (module M)\n | `Gt gt ->\n let max_lt_x = gt_implies_gte x Max.n gt in\n let module M =\n Map_1_specific (Lte) (Lte)\n (struct\n type b1 = Max.n\n\n type b2 = n\n\n let f : type a. (a, Max.n) Lte.t -> (a, n) Lte.t =\n fun a_lt_max -> Lte.trans a_lt_max max_lt_x\n end)\n in\n let module M : Max_s with type ns = n * ns = struct\n type nonrec ns = n * ns\n\n type nonrec n = n\n\n let n = x\n\n let p : (ns, n) H1_1(Lte).t = Lte.refl x :: M.f Max.p\n end in\n (module M) )\n\nlet max_exn : type ns. ns H1.T(Nat).t -> ns max = function\n | [] ->\n failwith \"max_exn: empty list\"\n | _ :: _ as xs ->\n max xs\n\nmodule Maxes = struct\n module type S = sig\n type ns\n\n type length\n\n val length : (ns, length) Length.t\n\n val maxes : ns H1.T(Nat).t\n end\n\n type 'length t = T : 'ns H1.T(Nat).t * ('ns, 'length) Length.t -> 'length t\n\n let rec f : type branches n. ((int, branches) Vector.t, n) Vector.t -> n t =\n function\n | [] ->\n T ([], Length.Z)\n | v :: vs ->\n let (T (maxes, len)) = f vs in\n let (T n) = Nat.of_int (Vector.reduce_exn v ~f:Int.max) in\n T (n :: maxes, S len)\n\n let m (type length) (vs : (_, length) Vector.t) :\n (module S with type length = length) =\n let g :\n type length ns.\n ns H1.T(Nat).t\n -> (ns, length) Length.t\n -> (module S with type length = length) =\n fun maxes length ->\n ( module struct\n type nonrec length = length\n\n type nonrec ns = ns\n\n let length = length\n\n let maxes = maxes\n end )\n in\n let (T (ms, len)) = f vs in\n g ms len\nend\n\nmodule Lengths = struct\n let rec extract :\n type prev_varss ns env.\n (prev_varss, ns, env) H2_1.T(E23(Length)).t -> ns H1.T(Nat).t = function\n | [] ->\n []\n | n :: ns ->\n (* TODO: This is quadratic because of Length.to_nat *)\n Length.to_nat n :: extract ns\n\n type ('prev_varss, 'prev_valss, 'env) t =\n | T :\n ('prev_varss, 'ns, 'env) H2_1.T(E23(Length)).t\n -> ('prev_varss, 'prev_valss, 'env) t\nend\n","open Core_kernel\n\n[@@@warning \"-4\"]\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type 'a t = Infinity | Finite of 'a\n [@@deriving sexp, equal, compare, hash, yojson]\n end\nend]\n\n[@@@warning \"+4\"]\n\nlet finite_exn = function\n | Finite x ->\n x\n | Infinity ->\n failwith \"curve point must not be the point at infinity\"\n","open Core_kernel\nopen Pickles_types\nopen Pickles_base\nmodule Scalars = Scalars\nmodule Domain = Domain\nmodule Opt = Opt\n\ntype 'field plonk_domain =\n < vanishing_polynomial : 'field -> 'field\n ; shifts : 'field Plonk_types.Shifts.t\n ; generator : 'field >\n\ntype 'field domain = < size : 'field ; vanishing_polynomial : 'field -> 'field >\n\nmodule type Bool_intf = sig\n type t\n\n val true_ : t\n\n val false_ : t\n\n val ( &&& ) : t -> t -> t\n\n val ( ||| ) : t -> t -> t\n\n val any : t list -> t\nend\n\nmodule type Field_intf = sig\n type t\n\n val size_in_bits : int\n\n val zero : t\n\n val one : t\n\n val of_int : int -> t\n\n val ( * ) : t -> t -> t\n\n val ( / ) : t -> t -> t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val inv : t -> t\n\n val negate : t -> t\nend\n\nmodule type Field_with_if_intf = sig\n include Field_intf\n\n type bool\n\n val if_ : bool -> then_:(unit -> t) -> else_:(unit -> t) -> t\nend\n\ntype 'f field = (module Field_intf with type t = 'f)\n\nlet pow2pow (type t) ((module F) : t field) (x : t) n : t =\n let rec go acc i = if i = 0 then acc else go F.(acc * acc) (i - 1) in\n go x n\n\n(* x^{2 ^ k} - 1 *)\nlet vanishing_polynomial (type t) ((module F) : t field) domain x =\n let k = Domain.log2_size domain in\n F.(pow2pow (module F) x k - one)\n\nlet domain (type t) ((module F) : t field) ~shifts ~domain_generator\n (domain : Domain.t) : t plonk_domain =\n let log2_size = Domain.log2_size domain in\n let shifts = shifts ~log2_size in\n let generator = domain_generator ~log2_size in\n object\n method shifts = shifts\n\n method vanishing_polynomial x = vanishing_polynomial (module F) domain x\n\n method generator = generator\n end\n\nlet actual_evaluation (type f) (module Field : Field_intf with type t = f)\n (e : Field.t array) (pt : Field.t) ~rounds : Field.t =\n let pt_n =\n let rec go acc i = if i = 0 then acc else go Field.(acc * acc) (i - 1) in\n go pt rounds\n in\n match List.rev (Array.to_list e) with\n | e :: es ->\n List.fold ~init:e es ~f:(fun acc fx -> Field.(fx + (pt_n * acc)))\n | [] ->\n Field.of_int 0\n\nlet evals_of_split_evals field ~zeta ~zetaw (es : _ Plonk_types.Evals.t) ~rounds\n =\n let e = Fn.flip (actual_evaluation field ~rounds) in\n Plonk_types.Evals.map es ~f:(fun (x1, x2) -> (e zeta x1, e zetaw x2))\n\nopen Composition_types.Wrap.Proof_state.Deferred_values.Plonk\n\ntype 'bool all_feature_flags = 'bool Lazy.t Plonk_types.Features.Full.t\n\nlet expand_feature_flags (type boolean)\n (module B : Bool_intf with type t = boolean)\n (features : boolean Plonk_types.Features.t) : boolean all_feature_flags =\n features\n |> Plonk_types.Features.map ~f:(fun x -> lazy x)\n |> Plonk_types.Features.to_full ~or_:(fun x y ->\n lazy B.(Lazy.force x ||| Lazy.force y) )\n\nlet lookup_tables_used feature_flags =\n let module Bool = struct\n type t = Opt.Flag.t\n\n let (true_ : t) = Yes\n\n let (false_ : t) = No\n\n let ( &&& ) (x : t) (y : t) : t =\n match (x, y) with\n | Yes, Yes ->\n Yes\n | Maybe, _ | _, Maybe ->\n Maybe\n | No, _ | _, No ->\n No\n\n let ( ||| ) (x : t) (y : t) : t =\n match (x, y) with\n | Yes, _ | _, Yes ->\n Yes\n | Maybe, _ | _, Maybe ->\n Maybe\n | No, No ->\n No\n\n let any = List.fold_left ~f:( ||| ) ~init:false_\n end in\n let all_feature_flags = expand_feature_flags (module Bool) feature_flags in\n Lazy.force all_feature_flags.uses_lookups\n\nlet get_feature_flag (feature_flags : _ all_feature_flags)\n (feature : Kimchi_types.feature_flag) =\n let lazy_flag =\n Plonk_types.Features.Full.get_feature_flag feature_flags feature\n in\n Option.map ~f:Lazy.force lazy_flag\n\nlet scalars_env (type boolean t) (module B : Bool_intf with type t = boolean)\n (module F : Field_with_if_intf with type t = t and type bool = boolean)\n ~endo ~mds ~field_of_hex ~domain ~srs_length_log2\n ({ alpha; beta; gamma; zeta; joint_combiner; feature_flags } :\n (t, _, boolean) Minimal.t ) (e : (_ * _, _) Plonk_types.Evals.In_circuit.t)\n =\n let feature_flags = expand_feature_flags (module B) feature_flags in\n let witness = Vector.to_array e.w in\n let coefficients = Vector.to_array e.coefficients in\n let var (col, row) =\n let get_eval =\n match (row : Scalars.curr_or_next) with Curr -> fst | Next -> snd\n in\n match[@warning \"-4\"] (col : Scalars.Column.t) with\n | Witness i ->\n get_eval witness.(i)\n | Index Poseidon ->\n get_eval e.poseidon_selector\n | Index Generic ->\n get_eval e.generic_selector\n | Index CompleteAdd ->\n get_eval e.complete_add_selector\n | Index VarBaseMul ->\n get_eval e.mul_selector\n | Index EndoMul ->\n get_eval e.emul_selector\n | Index EndoMulScalar ->\n get_eval e.endomul_scalar_selector\n | Index RangeCheck0 ->\n get_eval (Opt.value_exn e.range_check0_selector)\n | Index RangeCheck1 ->\n get_eval (Opt.value_exn e.range_check1_selector)\n | Index ForeignFieldAdd ->\n get_eval (Opt.value_exn e.foreign_field_add_selector)\n | Index ForeignFieldMul ->\n get_eval (Opt.value_exn e.foreign_field_mul_selector)\n | Index Xor16 ->\n get_eval (Opt.value_exn e.xor_selector)\n | Index Rot64 ->\n get_eval (Opt.value_exn e.rot_selector)\n | Index i ->\n failwithf\n !\"Index %{sexp:Scalars.Gate_type.t}\\n\\\n %! should have been linearized away\"\n i ()\n | Coefficient i ->\n get_eval coefficients.(i)\n | LookupTable ->\n get_eval (Opt.value_exn e.lookup_table)\n | LookupSorted i ->\n get_eval\n (Opt.value_exn (Option.value_exn (Vector.nth e.lookup_sorted i)))\n | LookupAggreg ->\n get_eval (Opt.value_exn e.lookup_aggregation)\n | LookupRuntimeTable ->\n get_eval (Opt.value_exn e.runtime_lookup_table)\n | LookupKindIndex Lookup ->\n get_eval (Opt.value_exn e.lookup_gate_lookup_selector)\n | LookupKindIndex Xor ->\n get_eval (Opt.value_exn e.xor_lookup_selector)\n | LookupKindIndex RangeCheck ->\n get_eval (Opt.value_exn e.range_check_lookup_selector)\n | LookupKindIndex ForeignFieldMul ->\n get_eval (Opt.value_exn e.foreign_field_mul_lookup_selector)\n | LookupRuntimeSelector ->\n get_eval (Opt.value_exn e.runtime_lookup_table_selector)\n in\n let open F in\n let square x = x * x in\n let rec pow x n =\n if n = 0 then one\n else if n = 1 then x\n else\n let y = pow (square x) Int.(n / 2) in\n if n mod 2 = 0 then y else x * y\n in\n let alpha_pows =\n let arr = Array.create ~len:71 one in\n arr.(1) <- alpha ;\n for i = 2 to Int.(Array.length arr - 1) do\n arr.(i) <- alpha * arr.(Int.(i - 1))\n done ;\n arr\n in\n let w4, w3, w2, w1 =\n (* generator^{n - 3} *)\n let gen = domain#generator in\n (* gen_inv = gen^{n - 1} = gen^{-1} *)\n let w1 = one / gen in\n let w2 = square w1 in\n let w3 = w2 * w1 in\n let w4 = lazy (w3 * w1) in\n (w4, w3, w2, w1)\n in\n let zk_polynomial =\n (* Vanishing polynomial of [w1, w2, w3]\n evaluated at x = zeta\n *)\n (zeta - w1) * (zeta - w2) * (zeta - w3)\n in\n let zeta_to_n_minus_1 = lazy (domain#vanishing_polynomial zeta) in\n { Scalars.Env.add = ( + )\n ; sub = ( - )\n ; mul = ( * )\n ; square\n ; alpha_pow = (fun i -> alpha_pows.(i))\n ; var\n ; pow = Tuple2.uncurry pow\n ; field = field_of_hex\n ; cell = Fn.id\n ; double = (fun x -> of_int 2 * x)\n ; zk_polynomial\n ; omega_to_minus_3 = w3\n ; zeta_to_n_minus_1 = domain#vanishing_polynomial zeta\n ; endo_coefficient = endo\n ; mds = (fun (row, col) -> mds.(row).(col))\n ; srs_length_log2\n ; vanishes_on_zero_knowledge_and_previous_rows =\n ( match joint_combiner with\n | None ->\n (* No need to compute anything when not using lookups *)\n F.one\n | Some _ ->\n zk_polynomial * (zeta - Lazy.force w4) )\n ; joint_combiner = Option.value joint_combiner ~default:F.one\n ; beta\n ; gamma\n ; unnormalized_lagrange_basis =\n (fun i ->\n let w_to_i =\n match i with\n | 0 ->\n one\n | 1 ->\n domain#generator\n | -1 ->\n w1\n | -2 ->\n w2\n | -3 ->\n w3\n | -4 ->\n Lazy.force w4\n | _ ->\n failwith \"TODO\"\n in\n Lazy.force zeta_to_n_minus_1 / (zeta - w_to_i) )\n ; if_feature =\n (fun (feature, e1, e2) ->\n let if_ b ~then_ ~else_ =\n match b with None -> e2 () | Some b -> F.if_ b ~then_ ~else_\n in\n let b = get_feature_flag feature_flags feature in\n if_ b ~then_:e1 ~else_:e2 )\n }\n\n(* TODO: not true anymore if lookup is used *)\n\n(** The offset of the powers of alpha for the permutation.\n(see https://github.com/o1-labs/proof-systems/blob/516b16fc9b0fdcab5c608cd1aea07c0c66b6675d/kimchi/src/index.rs#L190) *)\nlet perm_alpha0 : int = 21\n\nmodule Make (Shifted_value : Shifted_value.S) (Sc : Scalars.S) = struct\n (** Computes the ft evaluation at zeta.\n (see https://o1-labs.github.io/mina-book/crypto/plonk/maller_15.html#the-evaluation-of-l)\n *)\n let ft_eval0 (type t) (module F : Field_intf with type t = t) ~domain\n ~(env : t Scalars.Env.t)\n ({ alpha = _; beta; gamma; zeta; joint_combiner = _; feature_flags = _ } :\n _ Minimal.t ) (e : (_ * _, _) Plonk_types.Evals.In_circuit.t) p_eval0 =\n let open Plonk_types.Evals.In_circuit in\n let e0 field = fst (field e) in\n let e1 field = snd (field e) in\n let e0_s = Vector.map e.s ~f:fst in\n let zkp = env.zk_polynomial in\n let alpha_pow = env.alpha_pow in\n let zeta1m1 = env.zeta_to_n_minus_1 in\n let open F in\n let w0 = Vector.to_array e.w |> Array.map ~f:fst in\n let ft_eval0 =\n let a0 = alpha_pow perm_alpha0 in\n let w_n = w0.(Nat.to_int Plonk_types.Permuts_minus_1.n) in\n let init = (w_n + gamma) * e1 z * a0 * zkp in\n (* TODO: This shares some computation with the permutation scalar in\n derive_plonk. Could share between them. *)\n Vector.foldi e0_s ~init ~f:(fun i acc s ->\n ((beta * s) + w0.(i) + gamma) * acc )\n in\n let shifts = domain#shifts in\n let ft_eval0 = ft_eval0 - p_eval0 in\n let ft_eval0 =\n ft_eval0\n - Array.foldi shifts\n ~init:(alpha_pow perm_alpha0 * zkp * e0 z)\n ~f:(fun i acc s -> acc * (gamma + (beta * zeta * s) + w0.(i)))\n in\n let nominator =\n ( zeta1m1\n * alpha_pow Int.(perm_alpha0 + 1)\n * (zeta - env.omega_to_minus_3)\n + (zeta1m1 * alpha_pow Int.(perm_alpha0 + 2) * (zeta - one)) )\n * (one - e0 z)\n in\n let denominator = (zeta - env.omega_to_minus_3) * (zeta - one) in\n let ft_eval0 = ft_eval0 + (nominator / denominator) in\n let constant_term = Sc.constant_term env in\n ft_eval0 - constant_term\n\n (** Computes the list of scalars used in the linearization. *)\n let derive_plonk (type t) ?(with_label = fun _ (f : unit -> t) -> f ())\n (module F : Field_intf with type t = t) ~(env : t Scalars.Env.t) ~shift =\n let _ = with_label in\n let open F in\n fun ({ alpha\n ; beta\n ; gamma\n ; zeta\n ; joint_combiner\n ; feature_flags = actual_feature_flags\n } :\n _ Minimal.t )\n (e : (_ * _, _) Plonk_types.Evals.In_circuit.t)\n (*((e0, e1) : _ Plonk_types.Evals.In_circuit.t Double.t) *) ->\n let open Plonk_types.Evals.In_circuit in\n let e1 field = snd (field e) in\n let zkp = env.zk_polynomial in\n let alpha_pow = env.alpha_pow in\n let w0 = Vector.map e.w ~f:fst in\n let perm =\n let w0 = Vector.to_array w0 in\n with_label __LOC__ (fun () ->\n Vector.foldi e.s\n ~init:(e1 z * beta * alpha_pow perm_alpha0 * zkp)\n ~f:(fun i acc (s, _) -> acc * (gamma + (beta * s) + w0.(i)))\n |> negate )\n in\n In_circuit.map_fields\n ~f:(Shifted_value.of_field (module F) ~shift)\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_domain_size = env.zeta_to_n_minus_1 + F.one\n ; zeta_to_srs_length = pow2pow (module F) zeta env.srs_length_log2\n ; perm\n ; joint_combiner = Opt.of_option joint_combiner\n ; feature_flags = actual_feature_flags\n }\n\n (** Check that computed proof scalars match the expected ones,\n using the native field.\n Note that the expected scalars are used to check\n the linearization in a proof over the other field\n (where those checks are more efficient),\n but we deferred the arithmetic checks until here\n so that we have the efficiency of the native field.\n *)\n let checked (type t)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = t)\n ~shift ~env (plonk : (_, _, _, _ Opt.t, _ Opt.t, _) In_circuit.t) evals =\n let actual =\n derive_plonk ~with_label:Impl.with_label\n (module Impl.Field)\n ~shift ~env\n { alpha = plonk.alpha\n ; beta = plonk.beta\n ; gamma = plonk.gamma\n ; zeta = plonk.zeta\n ; joint_combiner = Opt.to_option_unsafe plonk.joint_combiner\n ; feature_flags = plonk.feature_flags\n }\n evals\n in\n let open Impl in\n let open In_circuit in\n with_label __LOC__ (fun () ->\n with_label __LOC__ (fun () ->\n List.map\n ~f:(fun f -> Shifted_value.equal Field.equal (f plonk) (f actual))\n [ perm ] )\n |> Boolean.all )\nend\n","open Core_kernel\n\ntype ('a, 'n, 'm) t =\n { without_degree_bound : 'n Nat.t; with_degree_bound : ('a, 'm) Vector.t }\n\nlet map t ~f = { t with with_degree_bound = Vector.map t.with_degree_bound ~f }\n\nlet num_bits n = Int.floor_log2 n + 1\n\nlet pow ~one ~mul x n =\n assert (n >= 0) ;\n let k = num_bits n in\n let rec go acc i =\n if i < 0 then acc\n else\n let acc = mul acc acc in\n let b = (n lsr i) land 1 = 1 in\n let acc = if b then mul x acc else acc in\n go acc (i - 1)\n in\n go one (k - 1)\n\nlet create ~without_degree_bound ~with_degree_bound =\n { without_degree_bound; with_degree_bound }\n\nlet combine_commitments _t ~scale ~add ~xi (type n)\n (without_degree_bound : (_, n) Vector.t) with_degree_bound =\n match without_degree_bound with\n | [] ->\n failwith \"combine_commitments: empty list\"\n | init :: without_degree_bound ->\n let polys =\n Vector.to_list without_degree_bound\n @ List.concat_map (Vector.to_list with_degree_bound)\n ~f:(fun (unshifted, shifted) -> [ unshifted; shifted ])\n in\n List.fold_left polys ~init ~f:(fun acc p -> add p (scale acc xi))\n\nlet combine_evaluations' (type a n m)\n ({ without_degree_bound = _; with_degree_bound } : (a, n Nat.s, m) t)\n ~shifted_pow ~mul ~add ~one:_ ~evaluation_point ~xi\n (init :: evals0 : (_, n Nat.s) Vector.t) (evals1 : (_, m) Vector.t) =\n let evals =\n Vector.to_list evals0\n @ List.concat\n (Vector.to_list\n (Vector.map2 with_degree_bound evals1 ~f:(fun deg fx ->\n [ fx; mul (shifted_pow deg evaluation_point) fx ] ) ) )\n in\n List.fold_left evals ~init ~f:(fun acc fx -> add fx (mul acc xi))\n\nlet[@warning \"-45\"] combine_evaluations' (type n) (t : (_, n, _) t) ~shifted_pow\n ~mul ~add ~one ~evaluation_point ~xi (evals0 : (_, n) Vector.t) evals1 =\n match evals0 with\n | Vector.[] ->\n failwith \"Empty evals0\"\n | _ :: _ ->\n combine_evaluations' t ~shifted_pow ~mul ~add ~one ~evaluation_point ~xi\n evals0 evals1\n\nlet combine_evaluations (type f) t ~crs_max_degree ~(mul : f -> f -> f) ~add\n ~one ~evaluation_point ~xi evals0 evals1 =\n let pow = pow ~one ~mul in\n combine_evaluations' t evals0 evals1\n ~shifted_pow:(fun deg x -> pow x (crs_max_degree - deg))\n ~mul ~add ~one ~evaluation_point ~xi\n\nopen Plonk_types.Poly_comm\n\nlet combine_split_commitments _t ~scale_and_add ~init:i ~xi (type n)\n (without_degree_bound : (_, n) Vector.t) with_degree_bound =\n let flat =\n List.concat_map (Vector.to_list without_degree_bound) ~f:Array.to_list\n @ List.concat_map (Vector.to_list with_degree_bound)\n ~f:(fun { With_degree_bound.unshifted; shifted } ->\n Array.to_list unshifted @ [ shifted ] )\n in\n let rec go = function\n | [] ->\n failwith \"combine_split_commitments: empty\"\n | init :: comms -> (\n match i init with\n | None ->\n go comms\n | Some init ->\n List.fold_left comms ~init ~f:(fun acc p ->\n scale_and_add ~acc ~xi p ) )\n in\n go (List.rev flat)\n\nlet combine_split_evaluations (type f f')\n ~(mul_and_add : acc:f' -> xi:f' -> f -> f') ~init:(i : f -> f') ~(xi : f')\n (evals0 : f array list) : f' =\n let flat = List.concat_map evals0 ~f:Array.to_list in\n match List.rev flat with\n | [] ->\n failwith \"combine_split_evaluations: empty\"\n | init :: es ->\n List.fold_left es ~init:(i init) ~f:(fun acc fx ->\n mul_and_add ~acc ~xi fx )\n","type ('a, _) t =\n | [] : ('a, 'n) t\n | ( :: ) : 'a * ('a, 'n) t -> ('a, 'n Nat.s) t\n\nlet rec to_list : type a n. (a, n) t -> a list = function\n | [] ->\n []\n | x :: xs ->\n x :: to_list xs\n\nlet rec _length : type a n. (a, n) t -> int = function\n | [] ->\n 0\n | _ :: xs ->\n 1 + _length xs\n\nlet rec to_vector : type a n. (a, n) t -> a Vector.e = function\n | [] ->\n T []\n | x :: xs ->\n let (T xs) = to_vector xs in\n T (x :: xs)\n\nlet rec of_vector : type a n m. (a, n) Vector.t -> (n, m) Nat.Lte.t -> (a, m) t\n =\n fun v p ->\n match (v, p) with [], _ -> [] | x :: xs, S p -> x :: of_vector xs p\n\nlet rec of_list_and_length_exn : type a n. a list -> n Nat.t -> (a, n) t =\n fun xs n ->\n match (xs, n) with\n | [], _ ->\n []\n | x :: xs, S n ->\n x :: of_list_and_length_exn xs n\n | _ :: _, Z ->\n failwith \"At_most: Length mismatch\"\n\nmodule type S = sig\n type 'a t\n\n include Sigs.Hash_foldable.S1 with type 'a t := 'a t\n\n include Sigs.Comparable.S1 with type 'a t := 'a t\n\n include Sigs.Jsonable.S1 with type 'a t := 'a t\n\n include Sigs.Sexpable.S1 with type 'a t := 'a t\nend\n\nmodule type VERSIONED = sig\n type 'a ty\n\n module Stable : sig\n module V1 : sig\n type 'a t = 'a ty\n\n include Sigs.VERSIONED\n\n include Sigs.Binable.S1 with type 'a t := 'a t\n\n include S with type 'a t := 'a t\n end\n end\n\n type 'a t = 'a Stable.V1.t\n\n include S with type 'a t := 'a t\nend\n\nmodule Make = struct\n module Yojson (N : Nat.Intf) :\n Sigs.Jsonable.S1 with type 'a t := ('a, N.n) t = struct\n let to_yojson f t = Vector.L.to_yojson f (to_list t)\n\n let of_yojson f s =\n Core_kernel.Result.map (Vector.L.of_yojson f s)\n ~f:(Base.Fn.flip of_list_and_length_exn N.n)\n end\n\n module Sexpable (N : Nat.Intf) :\n Core_kernel.Sexpable.S1 with type 'a t := ('a, N.n) t =\n Core_kernel.Sexpable.Of_sexpable1\n (Base.List)\n (struct\n type nonrec 'a t = ('a, N.n) t\n\n let to_sexpable = to_list\n\n let of_sexpable xs = of_list_and_length_exn xs N.n\n end)\nend\n\ntype ('a, 'n) at_most = ('a, 'n) t\n\nmodule With_length (N : Nat.Intf) : S with type 'a t = ('a, N.n) at_most =\nstruct\n type 'a t = ('a, N.n) at_most\n\n let compare c t1 t2 = Base.List.compare c (to_list t1) (to_list t2)\n\n let hash_fold_t f s v = Base.List.hash_fold_t f s (to_list v)\n\n let equal f t1 t2 = List.equal f (to_list t1) (to_list t2)\n\n include Make.Sexpable (N)\n include Make.Yojson (N)\nend\n\nmodule At_most_2 = struct\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N2.n) at_most\n\n include\n Core_kernel.Binable.Of_binable1_without_uuid\n (Core_kernel.List.Stable.V1)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable = to_list\n\n let of_binable xs = of_list_and_length_exn xs Nat.N2.n\n end)\n\n include (\n With_length\n (Nat.N2) :\n module type of With_length (Nat.N2) with type 'a t := 'a t )\n end\n end]\n\n type 'a t = 'a Stable.Latest.t [@@deriving sexp, equal, compare, hash, yojson]\n\n type 'a ty = 'a t\n end\n\nmodule At_most_8 = struct\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N8.n) at_most\n\n include\n Core_kernel.Binable.Of_binable1_without_uuid\n (Core_kernel.List.Stable.V1)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable = to_list\n\n let of_binable xs = of_list_and_length_exn xs Nat.N8.n\n end)\n\n include (\n With_length\n (Nat.N8) :\n module type of With_length (Nat.N8) with type 'a t := 'a t )\n end\n end]\n\n type 'a t = 'a Stable.Latest.t [@@deriving sexp, equal, compare, hash, yojson]\n\n type 'a ty = 'a t\n end\n","(* This file is generated automatically with ocaml_gen. *)\n\nmodule FieldVectors = struct\n module Fp = struct\n type nonrec t\n\n type nonrec elt = Pasta_bindings.Fp.t\n\n external create : unit -> t = \"caml_fp_vector_create\"\n\n external length : t -> int = \"caml_fp_vector_length\"\n\n external emplace_back : t -> elt -> unit = \"caml_fp_vector_emplace_back\"\n\n external get : t -> int -> elt = \"caml_fp_vector_get\"\n\n external set : t -> int -> elt -> unit = \"caml_fp_vector_set\"\n end\n\n module Fq = struct\n type nonrec t\n\n type nonrec elt = Pasta_bindings.Fq.t\n\n external create : unit -> t = \"caml_fq_vector_create\"\n\n external length : t -> int = \"caml_fq_vector_length\"\n\n external emplace_back : t -> elt -> unit = \"caml_fq_vector_emplace_back\"\n\n external get : t -> int -> elt = \"caml_fq_vector_get\"\n\n external set : t -> int -> elt -> unit = \"caml_fq_vector_set\"\n end\nend\n\nmodule Protocol = struct\n module Gates = struct\n module Vector = struct\n module Fp = struct\n type nonrec t\n\n type nonrec elt = Pasta_bindings.Fp.t Kimchi_types.circuit_gate\n\n external create : unit -> t = \"caml_pasta_fp_plonk_gate_vector_create\"\n\n external add : t -> elt -> unit = \"caml_pasta_fp_plonk_gate_vector_add\"\n\n external get : t -> int -> elt = \"caml_pasta_fp_plonk_gate_vector_get\"\n\n external len : t -> int = \"caml_pasta_fp_plonk_gate_vector_len\"\n\n external wrap : t -> Kimchi_types.wire -> Kimchi_types.wire -> unit\n = \"caml_pasta_fp_plonk_gate_vector_wrap\"\n\n external digest : int -> t -> bytes\n = \"caml_pasta_fp_plonk_gate_vector_digest\"\n\n external to_json : int -> t -> string\n = \"caml_pasta_fp_plonk_circuit_serialize\"\n end\n\n module Fq = struct\n type nonrec t\n\n type nonrec elt = Pasta_bindings.Fq.t Kimchi_types.circuit_gate\n\n external create : unit -> t = \"caml_pasta_fq_plonk_gate_vector_create\"\n\n external add : t -> elt -> unit = \"caml_pasta_fq_plonk_gate_vector_add\"\n\n external get : t -> int -> elt = \"caml_pasta_fq_plonk_gate_vector_get\"\n\n external len : t -> int = \"caml_pasta_fq_plonk_gate_vector_len\"\n\n external wrap : t -> Kimchi_types.wire -> Kimchi_types.wire -> unit\n = \"caml_pasta_fq_plonk_gate_vector_wrap\"\n\n external digest : int -> t -> bytes\n = \"caml_pasta_fq_plonk_gate_vector_digest\"\n\n external to_json : int -> t -> string\n = \"caml_pasta_fq_plonk_circuit_serialize\"\n end\n end\n end\n\n module SRS = struct\n module Fp = struct\n type nonrec t\n\n module Poly_comm = struct\n type nonrec t =\n Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n end\n\n external create : int -> t = \"caml_fp_srs_create\"\n\n external write : bool option -> t -> string -> unit = \"caml_fp_srs_write\"\n\n external read : int option -> string -> t option = \"caml_fp_srs_read\"\n\n external lagrange_commitment :\n t\n -> int\n -> int\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fp_srs_lagrange_commitment\"\n\n external add_lagrange_basis : t -> int -> unit\n = \"caml_fp_srs_add_lagrange_basis\"\n\n external commit_evaluations :\n t\n -> int\n -> Pasta_bindings.Fp.t array\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fp_srs_commit_evaluations\"\n\n external b_poly_commitment :\n t\n -> Pasta_bindings.Fp.t array\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fp_srs_b_poly_commitment\"\n\n external batch_accumulator_check :\n t\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity array\n -> Pasta_bindings.Fp.t array\n -> bool = \"caml_fp_srs_batch_accumulator_check\"\n\n external batch_accumulator_generate :\n t\n -> int\n -> Pasta_bindings.Fp.t array\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity array\n = \"caml_fp_srs_batch_accumulator_generate\"\n\n external urs_h : t -> Pasta_bindings.Fq.t Kimchi_types.or_infinity\n = \"caml_fp_srs_h\"\n end\n\n module Fq = struct\n type nonrec t\n\n external create : int -> t = \"caml_fq_srs_create\"\n\n external write : bool option -> t -> string -> unit = \"caml_fq_srs_write\"\n\n external read : int option -> string -> t option = \"caml_fq_srs_read\"\n\n external lagrange_commitment :\n t\n -> int\n -> int\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fq_srs_lagrange_commitment\"\n\n external add_lagrange_basis : t -> int -> unit\n = \"caml_fq_srs_add_lagrange_basis\"\n\n external commit_evaluations :\n t\n -> int\n -> Pasta_bindings.Fq.t array\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fq_srs_commit_evaluations\"\n\n external b_poly_commitment :\n t\n -> Pasta_bindings.Fq.t array\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fq_srs_b_poly_commitment\"\n\n external batch_accumulator_check :\n t\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity array\n -> Pasta_bindings.Fq.t array\n -> bool = \"caml_fq_srs_batch_accumulator_check\"\n\n external batch_accumulator_generate :\n t\n -> int\n -> Pasta_bindings.Fq.t array\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity array\n = \"caml_fq_srs_batch_accumulator_generate\"\n\n external urs_h : t -> Pasta_bindings.Fp.t Kimchi_types.or_infinity\n = \"caml_fq_srs_h\"\n end\n end\n\n module Index = struct\n module Fp = struct\n type nonrec t\n\n external create :\n Gates.Vector.Fp.t\n -> int\n -> Pasta_bindings.Fp.t Kimchi_types.lookup_table array\n -> Pasta_bindings.Fp.t Kimchi_types.runtime_table_cfg array\n -> int\n -> SRS.Fp.t\n -> t\n = \"caml_pasta_fp_plonk_index_create_bytecode\" \"caml_pasta_fp_plonk_index_create\"\n\n external max_degree : t -> int = \"caml_pasta_fp_plonk_index_max_degree\"\n\n external public_inputs : t -> int\n = \"caml_pasta_fp_plonk_index_public_inputs\"\n\n external domain_d1_size : t -> int\n = \"caml_pasta_fp_plonk_index_domain_d1_size\"\n\n external domain_d4_size : t -> int\n = \"caml_pasta_fp_plonk_index_domain_d4_size\"\n\n external domain_d8_size : t -> int\n = \"caml_pasta_fp_plonk_index_domain_d8_size\"\n\n external read : int option -> SRS.Fp.t -> string -> t\n = \"caml_pasta_fp_plonk_index_read\"\n\n external write : bool option -> t -> string -> unit\n = \"caml_pasta_fp_plonk_index_write\"\n end\n\n module Fq = struct\n type nonrec t\n\n external create :\n Gates.Vector.Fq.t\n -> int\n -> Pasta_bindings.Fq.t Kimchi_types.lookup_table array\n -> Pasta_bindings.Fq.t Kimchi_types.runtime_table_cfg array\n -> int\n -> SRS.Fq.t\n -> t\n = \"caml_pasta_fq_plonk_index_create_bytecode\" \"caml_pasta_fq_plonk_index_create\"\n\n external max_degree : t -> int = \"caml_pasta_fq_plonk_index_max_degree\"\n\n external public_inputs : t -> int\n = \"caml_pasta_fq_plonk_index_public_inputs\"\n\n external domain_d1_size : t -> int\n = \"caml_pasta_fq_plonk_index_domain_d1_size\"\n\n external domain_d4_size : t -> int\n = \"caml_pasta_fq_plonk_index_domain_d4_size\"\n\n external domain_d8_size : t -> int\n = \"caml_pasta_fq_plonk_index_domain_d8_size\"\n\n external read : int option -> SRS.Fq.t -> string -> t\n = \"caml_pasta_fq_plonk_index_read\"\n\n external write : bool option -> t -> string -> unit\n = \"caml_pasta_fq_plonk_index_write\"\n end\n end\n\n module VerifierIndex = struct\n module Fp = struct\n type nonrec t =\n ( Pasta_bindings.Fp.t\n , SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n\n external create : Index.Fp.t -> t\n = \"caml_pasta_fp_plonk_verifier_index_create\"\n\n external read : int option -> SRS.Fp.t -> string -> t\n = \"caml_pasta_fp_plonk_verifier_index_read\"\n\n external write : bool option -> t -> string -> unit\n = \"caml_pasta_fp_plonk_verifier_index_write\"\n\n external shifts : int -> Pasta_bindings.Fp.t array\n = \"caml_pasta_fp_plonk_verifier_index_shifts\"\n\n external dummy : unit -> t = \"caml_pasta_fp_plonk_verifier_index_dummy\"\n\n external deep_copy : t -> t\n = \"caml_pasta_fp_plonk_verifier_index_deep_copy\"\n end\n\n module Fq = struct\n type nonrec t =\n ( Pasta_bindings.Fq.t\n , SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n\n external create : Index.Fq.t -> t\n = \"caml_pasta_fq_plonk_verifier_index_create\"\n\n external read : int option -> SRS.Fq.t -> string -> t\n = \"caml_pasta_fq_plonk_verifier_index_read\"\n\n external write : bool option -> t -> string -> unit\n = \"caml_pasta_fq_plonk_verifier_index_write\"\n\n external shifts : int -> Pasta_bindings.Fq.t array\n = \"caml_pasta_fq_plonk_verifier_index_shifts\"\n\n external dummy : unit -> t = \"caml_pasta_fq_plonk_verifier_index_dummy\"\n\n external deep_copy : t -> t\n = \"caml_pasta_fq_plonk_verifier_index_deep_copy\"\n end\n end\n\n module Oracles = struct\n module Fp = struct\n type nonrec t = Pasta_bindings.Fp.t Kimchi_types.oracles\n\n external create :\n Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n array\n -> ( Pasta_bindings.Fp.t\n , SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.prover_proof\n -> t = \"fp_oracles_create_no_public\"\n\n external create_with_public_evals :\n Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n array\n -> ( Pasta_bindings.Fp.t\n , SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n -> t = \"fp_oracles_create\"\n\n external dummy : unit -> Pasta_bindings.Fp.t Kimchi_types.random_oracles\n = \"fp_oracles_dummy\"\n\n external deep_copy :\n Pasta_bindings.Fp.t Kimchi_types.random_oracles\n -> Pasta_bindings.Fp.t Kimchi_types.random_oracles\n = \"fp_oracles_deep_copy\"\n end\n\n module Fq = struct\n type nonrec t = Pasta_bindings.Fq.t Kimchi_types.oracles\n\n external create :\n Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n array\n -> ( Pasta_bindings.Fq.t\n , SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.prover_proof\n -> t = \"fq_oracles_create_no_public\"\n\n external create_with_public_evals :\n Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n array\n -> ( Pasta_bindings.Fq.t\n , SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n -> t = \"fq_oracles_create\"\n\n external dummy : unit -> Pasta_bindings.Fq.t Kimchi_types.random_oracles\n = \"fq_oracles_dummy\"\n\n external deep_copy :\n Pasta_bindings.Fq.t Kimchi_types.random_oracles\n -> Pasta_bindings.Fq.t Kimchi_types.random_oracles\n = \"fq_oracles_deep_copy\"\n end\n end\n\n module Proof = struct\n module Fp = struct\n external create :\n Index.Fp.t\n -> FieldVectors.Fp.t array\n -> Pasta_bindings.Fp.t Kimchi_types.runtime_table array\n -> Pasta_bindings.Fp.t array\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity array\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public = \"caml_pasta_fp_plonk_proof_create\"\n\n external create_and_verify :\n Index.Fp.t\n -> FieldVectors.Fp.t array\n -> Pasta_bindings.Fp.t Kimchi_types.runtime_table array\n -> Pasta_bindings.Fp.t array\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity array\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_create_and_verify\"\n\n external example_with_lookup :\n SRS.Fp.t\n -> Index.Fp.t\n * Pasta_bindings.Fp.t\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_lookup\"\n\n external example_with_ffadd :\n SRS.Fp.t\n -> Index.Fp.t\n * Pasta_bindings.Fp.t\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_ffadd\"\n\n external example_with_xor :\n SRS.Fp.t\n -> Index.Fp.t\n * (Pasta_bindings.Fp.t * Pasta_bindings.Fp.t)\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_xor\"\n\n external example_with_rot :\n SRS.Fp.t\n -> Index.Fp.t\n * (Pasta_bindings.Fp.t * Pasta_bindings.Fp.t)\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_rot\"\n\n external example_with_foreign_field_mul :\n SRS.Fp.t\n -> Index.Fp.t\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_foreign_field_mul\"\n\n external example_with_range_check :\n SRS.Fp.t\n -> Index.Fp.t\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_range_check\"\n\n external example_with_range_check0 :\n SRS.Fp.t\n -> Index.Fp.t\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_range_check0\"\n\n external verify :\n ( Pasta_bindings.Fp.t\n , SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n -> bool = \"caml_pasta_fp_plonk_proof_verify\"\n\n external batch_verify :\n ( Pasta_bindings.Fp.t\n , SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n array\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n array\n -> bool = \"caml_pasta_fp_plonk_proof_batch_verify\"\n\n external dummy :\n unit\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public = \"caml_pasta_fp_plonk_proof_dummy\"\n\n external deep_copy :\n ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_deep_copy\"\n end\n\n module Fq = struct\n external create :\n Index.Fq.t\n -> FieldVectors.Fq.t array\n -> Pasta_bindings.Fq.t Kimchi_types.runtime_table array\n -> Pasta_bindings.Fq.t array\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity array\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public = \"caml_pasta_fq_plonk_proof_create\"\n\n external verify :\n ( Pasta_bindings.Fq.t\n , SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n -> bool = \"caml_pasta_fq_plonk_proof_verify\"\n\n external batch_verify :\n ( Pasta_bindings.Fq.t\n , SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n array\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n array\n -> bool = \"caml_pasta_fq_plonk_proof_batch_verify\"\n\n external dummy :\n unit\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public = \"caml_pasta_fq_plonk_proof_dummy\"\n\n external deep_copy :\n ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fq_plonk_proof_deep_copy\"\n end\n end\nend\n","open Core_kernel\n\ntype 'a t = { mds : 'a array array; round_constants : 'a array array }\n[@@deriving bin_io]\n\nlet map { mds; round_constants } ~f =\n let f = Array.map ~f:(Array.map ~f) in\n { mds = f mds; round_constants = f round_constants }\n","let params_Bn128 =\n { Params.mds =\n [| [| \"15913613074278028058360498857043999222867772811338037425231170199156889337604\"\n ; \"65180538277771794992983614695816638391617290189527384182155063505825555179\"\n ; \"5394145287608961087977235806233358974273334844303649346024304966582176196487\"\n |]\n ; [| \"15414815283538893716009156559702084916211023875136356807248219032453798152465\"\n ; \"3463018243616155786290732419705147785020336294529003837260493734746385539469\"\n ; \"12716468877825667500219920861172138145894921271005565146996037137547785771411\"\n |]\n ; [| \"1792045203208933407244693490495238027092197802128268175009298962707699842710\"\n ; \"76356542649790718492035692281837451271781062546545119705441901238018861818\"\n ; \"9520069514281255561624128661339565451189764370791651000392579220353790670830\"\n |]\n |]\n ; round_constants =\n [| [| \"12455131979215983316735047846658291859029812584241282581257197013302738138666\"\n ; \"20029656970890966196099810168066995443524989185718089119520857141365451679654\"\n ; \"8929913078653797661905726823410775654210481762974885244818731639242977419622\"\n |]\n ; [| \"8662787891019924101534530927954444401015394189462080864609938870691307539536\"\n ; \"20294115837600366998212029140165760858924828875933683067126492672917588261877\"\n ; \"2682014173266320611146882768057075830238591616831154961603507352639750394592\"\n |]\n ; [| \"18907515456503482670621260399010811269866082079896285203284611749350771281411\"\n ; \"1424609887444859910324043210736091906100438801135358613993092433663809225411\"\n ; \"1531059541788158835714117823424146308635531997487162670061618032695665453831\"\n |]\n ; [| \"19444238474448321066398700689084787616548516614414549514749853660756611792379\"\n ; \"2236237945310446639621733106225706828551103453944652411264620402517164583264\"\n ; \"12605646628049520919535266096828454658561884709869426105979276828733666269521\"\n |]\n ; [| \"14653124040822125428573681427514890989900893513402451718822527259901516216058\"\n ; \"1535968898232047429062068090527484451997796559364245278047376516596586180554\"\n ; \"3307538294663905716144414865227035949873283327379581103741297483063276195183\"\n |]\n ; [| \"21111467054595055527346262240389751012262991994706430976179289552457483727796\"\n ; \"17649294376560630922417546944777537620537408190408066211453084495108565929366\"\n ; \"7683463515567855955851784553909126014159314191075450219244796328948411069744\"\n |]\n ; [| \"21262229851583325466767017312569047417622760705999088078958228786464449033067\"\n ; \"11691182518884460508022694337582074624192039580202157360389815110719437213363\"\n ; \"8690728446593494554377477996892461126663797704587025899930929227865493269824\"\n |]\n ; [| \"21622260498668079571860417097494779160364898191075577203239012897437375456411\"\n ; \"21067767847052854366896470071519184914663018103241392453030719014890445499665\"\n ; \"21348828409856354758094844442899573788047317201055667836817119877806560465334\"\n |]\n ; [| \"2704440995725305992776846806711930876273040749514871232837487081811513368296\"\n ; \"1142050494870706434296077676238780951797136607536187326800297147932619878418\"\n ; \"3652944740784795248484484454916800802095288396765069024258114251561069674735\"\n |]\n ; [| \"1747641587474624832364464288237802774971629275511085691789065855359044028198\"\n ; \"14935834110027005954806028171080511939971704126366459140378790942754129686907\"\n ; \"3215720726490672077485888789426411334496962379737529853320875594879037332594\"\n |]\n ; [| \"2892159931078719741396670290810431382361178666606213506995456264415113913847\"\n ; \"1938538891009879014088646889644828497511974353410971027478866497380422633484\"\n ; \"13916214761542255527505866254811968868327635410573168146297241319868121689821\"\n |]\n ; [| \"266821775768872344171470219200118028338254464492956024813242747554382748942\"\n ; \"11055386921184594780372263378420826851562920740321950336882051897732501262543\"\n ; \"2504617730099125455929793538006173214604536705392412461363354681040283013164\"\n |]\n ; [| \"8077046888362371937918818344109572894796988781119069525502907016581642522710\"\n ; \"7281012798633884984170366068851653834509460567285503188952416990462599509288\"\n ; \"11914125581503780978633571238267986373793149282818856451291452464271781243920\"\n |]\n ; [| \"5911373857383996424444312456230128887937254975139357544835683280828995545397\"\n ; \"20728259298426389276714612941176977888429183727869747381529137474366072279101\"\n ; \"8331123017723440628782766975941869108307759426898189357261715346312601104654\"\n |]\n ; [| \"19978529403683797449165109778464832800224916941903951374610236813523844409526\"\n ; \"17316158269457914256007584527534747738658973027567786054549020564540952112346\"\n ; \"7848194400773744361171082305364633343688318123652518347170031226439829254882\"\n |]\n ; [| \"17698087730709566968258013675219881840614043344609152682517330801348583470562\"\n ; \"2484533502052370851335172153342694835144795809438965797062785488685902188726\"\n ; \"13372068881052003992228272108672679285817785895634149926809187580418595890381\"\n |]\n ; [| \"4450005426773734601782625050142815413017019480402129494014819930729323864775\"\n ; \"15031465389782276133463098319911853017052619244999605688724393058338301291115\"\n ; \"6028902109643218557806340932181364476799161079643636815411563224652423572198\"\n |]\n ; [| \"2957732585137901025626087202113249345076588554941059487693780861098604986119\"\n ; \"12565476532112137808460978474958060441970941349010371267577877299656634907765\"\n ; \"10508327646678453674728048391759640526197954899878596680197847666563367632543\"\n |]\n ; [| \"4493451765845812430310778141104432201437429164475176054680492630627878568332\"\n ; \"15095408309586969968044201398966210357547906905122453139947200130015688526573\"\n ; \"10819130048432875198797495465270179395954461390529553930221225323229387202234\"\n |]\n ; [| \"15905267794015672354278595057670574122197927816429433548802165993220415414073\"\n ; \"19290205907831398371768999387869637435049824367233327965730120884036212709842\"\n ; \"15451920390057917627290027104082580122165965120355347782937661856388593985245\"\n |]\n ; [| \"6425598873527092853966039409614693840647173123073098849086711894647944582332\"\n ; \"17307716513182567320564075539526480893558355908652993731441220999922946005081\"\n ; \"19372285427179952013203092658533484049593114439149219035606060254764845851391\"\n |]\n ; [| \"14724939606645168531546334343600232253284320276481307778787768813885931648950\"\n ; \"4684996260500305121238590806572541849891754312215139285622888510153705963000\"\n ; \"19906278135333202031075665370853003279083131420237405129919260859757146418025\"\n |]\n ; [| \"3999693912508849442569285360026642503093489903926874133118153062461080435481\"\n ; \"20129375303694053217240183105192753906500831553949001131297105718176015558964\"\n ; \"17281496576809338419011697046933296343189100335422897604615575811331627359485\"\n |]\n ; [| \"15637748291684046440453413703705692658155214802161964102299272768648229342362\"\n ; \"2094444825794502002152585986969571562449905861771519270554787618649438333195\"\n ; \"1152889601932463959824817875107315518104722504910095364729880245759523916044\"\n |]\n ; [| \"12114165850379066500859611262167642397834899331804245444372878412987365128590\"\n ; \"20821227542001445006023346122554483849065713580779858784021328359824080462519\"\n ; \"3440756720132945332811173288138999408441021502908547499697282473681525253805\"\n |]\n ; [| \"20938628428302899368158656913047855118000040623605421135349389583331392728782\"\n ; \"8850081254230234130482383430433176873344633494243110112848647064077741649744\"\n ; \"1819639941546179668398979507053724449231350395599747300736218202072168364980\"\n |]\n ; [| \"21219092773772827667886204262476112905428217689703647484316763603169544906986\"\n ; \"13148487544990345541730567143235754764404038697816450525897467218977412799129\"\n ; \"13598807739063229961519663325640861142062394342851403440808670891533339780790\"\n |]\n ; [| \"18784327298376147342042823437947970462892869194728299228507919810276864843414\"\n ; \"2764493745803317574883853704043825342340808631956690807684613803167040529511\"\n ; \"21531775639025076953020023111055490895978901214310417059307899853240995381819\"\n |]\n ; [| \"19964398501876039777029130298682737202257582985971095863290288610857831427638\"\n ; \"15003442983970848114681480873546789629160262059108570865485071572172687676835\"\n ; \"20614241966717622390914334053622572167995367802051836931454426877074875942253\"\n |]\n ; [| \"19733168743390283576337440585736332292298547880804855952734808967278966077887\"\n ; \"20530621481603446397085836296967350209890164029268319619481535419199429275412\"\n ; \"12361620530467399202722610329149901344545851901477091854159960517963801528971\"\n |]\n ; [| \"9497854724940806346676139162466690071592872530638144182764466319052293463165\"\n ; \"7549205476288061047040852944548942878112823732145584918107208536541712726277\"\n ; \"9010672859023729500640324904403960830965495099902505763591033382017769059028\"\n |]\n ; [| \"809006882768062359480853341102632220777932068978149301935174282279746446958\"\n ; \"7106371976957177712230305966566701811850820970657101896348127436646177656365\"\n ; \"18845123379649840503129460949570724717923057602542920800815047452665097128575\"\n |]\n ; [| \"14712923944932171466124439335703740452883296028663247289510978550197451911919\"\n ; \"19555759172327736128240171000715903945570888389700763573790859521156095228287\"\n ; \"17179695917466049633838471880559548490881310699092342418090873652775810295378\"\n |]\n ; [| \"18944876856792381816055068913314141690530834943354883079085532905267119397008\"\n ; \"3257630700960849517603336097571474897923100547762764495987576852490355943460\"\n ; \"3963500912949736174926372928446487843084987377580944585294277449817215093365\"\n |]\n ; [| \"21304716730402869084944080869903443431235336418077153507261240151959530377653\"\n ; \"18998265936988640248585036755202701418246223100957416731998639191794797638003\"\n ; \"16839625825914009701942141907800050396084195897386326382915730670235616618695\"\n |]\n ; [| \"16907937154215020261110468963982390213438461071031811101554056252102505124726\"\n ; \"1294898660752289889975651445755491766586322714088107994205473403531724749589\"\n ; \"9172546393414544394143001120250095355087186863911844697260687867341704896778\"\n |]\n ; [| \"18891778779724165209072874482651171817270086247356116562427206569585293483055\"\n ; \"13093554332096549605604948416229955030385793767090042194569924056338021838108\"\n ; \"6540069282618873496342140872069384185118574828832026154295825270730722501809\"\n |]\n ; [| \"11698805795265597745890922320669982345748592147825010914959366790903803563027\"\n ; \"11128587690756409041400570351324823090287237584985813997261416805030246953137\"\n ; \"574796972312053991589591668868339165343116554180562026519971681663627339366\"\n |]\n ; [| \"8263653526367544279471418475309371793291954818747935714794248360166503487859\"\n ; \"495546618036723566920914648951352373868059898268055487677897567226892784967\"\n ; \"2528292188392170914010448139211586215817069915670005292953294092269979070980\"\n |]\n ; [| \"14954597262610438728753406794870316034770442280143947719391702684620418262496\"\n ; \"2873290581141877304970576969082349138229332018341156071844198415188999408160\"\n ; \"7877226570858832633875209751493918650976179001613717862579011309181456152753\"\n |]\n ; [| \"5290811263292128650829809831924435265520706616680110737471312421357061576251\"\n ; \"5711353914598993184207904758686192904620948114158132435163135551043392236587\"\n ; \"9671966951859991559346179676315084295317241890404128352532995814366687016784\"\n |]\n ; [| \"20648234869018782942484412385329986060607455807332118750782252709151244400533\"\n ; \"1521221467156754943933671253020851096017281629892920730907443291972734010497\"\n ; \"6375300799036358132607612364454746219201386369274233783761503007631282551380\"\n |]\n ; [| \"18921242117750773300194037006101341214923275379274370683247849512779159129078\"\n ; \"7813033521740037204631731835076108697814182206021466630450781049551634237483\"\n ; \"7795208366125068859216483161820518701837348485078219412133643408967011329822\"\n |]\n ; [| \"21634048616875364065210304993971256601326650069082669576726378272437410251852\"\n ; \"1440291557054822025042926468154900761163167753541613162663250995564641638121\"\n ; \"8030862880899531201072645375229460968330384014296763956553993045932171788794\"\n |]\n ; [| \"18227143364048378671809657511264604955612895339528675264153781365139338073044\"\n ; \"21758886539711282145698252967647695643837152466011063420158481037553923112829\"\n ; \"2085588517087605436136379278738013214233743532079287631079316773925068862732\"\n |]\n ; [| \"9513664655545306376987968929852776467090105742275395185801917554996684570014\"\n ; \"3550496136894926428779047632731319031180547135184616875506154252232382772731\"\n ; \"17611757480287922505786279147168077243913583114117625089682651438292645979006\"\n |]\n ; [| \"9510531870810299962531161626148485102758508164021526746981465493469502973181\"\n ; \"13147395489659079072941169740078305253501735721348147621757420460777184976765\"\n ; \"20981004218820236011689230170078809973840534961691702543937445515733151438851\"\n |]\n ; [| \"7510474971056266438887013036637998526887329893492694485779774584612719651459\"\n ; \"1410506880075029891986606588556057112819357276074907152324471561666187504226\"\n ; \"8531153700191448965915372279944017070557402838400132057846710117192547288312\"\n |]\n ; [| \"9754021311900999917627020811752417367253388211990562024285328010011773088524\"\n ; \"2596434275792412604724294796434266571220373976229139969740378299737237088707\"\n ; \"12362606196840499695717697542757730593369897628148107607660372162713524022091\"\n |]\n ; [| \"7436712609498458515091822640340398689078308761236724993140849063351217155692\"\n ; \"13658397008139421803306375444518324400013880452735832208526361116879733324843\"\n ; \"8172299227253932586074375157726142633344272790321861656172484971306271304428\"\n |]\n ; [| \"8605586894544301092657394167906502995894014247978769840701086209902531650480\"\n ; \"8900145888985471928279988821934068156350024482295663273746853580585203659117\"\n ; \"10470367937616887936936637392485540045417066546520320064401889047735866701687\"\n |]\n ; [| \"11506602210275354295255815678397482725225279643868372198705067756030230710066\"\n ; \"17848856881287888035559207919717746181941756011012420474955535369227552058196\"\n ; \"19621145748343950799654655801831590696734631175445290325293238308726746856381\"\n |]\n ; [| \"12864577757979281303137787677967581089249504938390812240088160999517854207023\"\n ; \"18146514933233558325125054842576736679593504913006946427595273862389774486334\"\n ; \"17884323247493851213892188228998881081766487773962855826892871743190914823275\"\n |]\n ; [| \"15402752720164650756401756498467037967910822997380610100998339390049962612988\"\n ; \"7603833157231114748089157493970988832295123465399487746989788482408777456140\"\n ; \"2397354421161661799662850246720819176952681967344524176801474312220041680576\"\n |]\n ; [| \"4644616545339594419852483555455431260822330146405566037177120172304445909733\"\n ; \"5263316028405817083848964416595634986103420395264546879434975622138579030157\"\n ; \"17782273009863750298483603933610732253879825505411230932533407287574651036994\"\n |]\n ; [| \"6757311365906043231713330034681410088312690560822302805339061832230418577842\"\n ; \"1747290142831105666564148972092238090059848968766027623980111244846463775952\"\n ; \"15626225602106279302483693031455114927351808163854564654776963760236790234423\"\n |]\n ; [| \"4913834867494755682369542218157533479788980551925269537630059523083653281581\"\n ; \"9877617390649361889067963484857474874019563445507538784053773745685676317984\"\n ; \"8907943459697784281828563593274242625606699321626165523327303792165072591809\"\n |]\n ; [| \"14664441047816797924985624056829230652985567659075289185564514710695287602702\"\n ; \"7007559757050385070202651829819464617707337597545855825279581955097245183469\"\n ; \"9907785227545441866241924986174555965766785257012652276622736289520175209842\"\n |]\n ; [| \"7597089497072493253646609764279824048404496412283438400323292326749646956121\"\n ; \"17909115638003629710512488646279326535029895707443505816458395075119245680309\"\n ; \"19899288359840151413448648239934294957736422087766709732366801832575234898200\"\n |]\n ; [| \"2776453255551777594442164922386336989357594907242688467733231910101268428455\"\n ; \"8731512921802677638551206899688496704819923065834522157915668185471088199231\"\n ; \"4270476107979642660344328132306502268479679050594759895042187137572326348178\"\n |]\n ; [| \"372963191403207230700085823960930798511810380777302780932220121859190714585\"\n ; \"1925392345596430848747460046135384348851089627416455489129305703977614383441\"\n ; \"17789118105598492176513882528357022912279065134405326075480819364512109487507\"\n |]\n ; [| \"20825008332751730091153821568987055752818061964131515789006779860691972036326\"\n ; \"12268072226614207724192089529070006978828099093641075700056577974897967878044\"\n ; \"8022939345678575485891537869705234790517539631432710130025799605516328239965\"\n |]\n ; [| \"15920446357440463160102379501579737913732417583637399015449814673775945192536\"\n ; \"4889967763577997404116252754960720158524059605911680924823220236886032161368\"\n ; \"13012115310019421859484865413402512912208022868124085927375736053832542569552\"\n |]\n ; [| \"11184812848348784840758139578916764774803469528077342079324383443440533140274\"\n ; \"10919525644265283860710095821750480494008303946536963464168615308937735732928\"\n ; \"16643027351354734329387947050668943310718100664075062130784371167893146427056\"\n |]\n ; [| \"2547391079287933146721925003560805204947901674695385307171999864858240689647\"\n ; \"5461671591847528192305502006203904211083239588855740323679605269651748982133\"\n ; \"1475483405991676112203600016600397946486872901513454996978092595555024286449\"\n |]\n ; [| \"5284066352388289958166453130467461920311116585098603685258698324490583696214\"\n ; \"11079707743980425617427448803513138667107248696505015838485445487813501565055\"\n ; \"18819466619498056228169794477791931948230648942982309978769076145394195937041\"\n |]\n ; [| \"20108313126965297449432768889178575293551084908049301416432179490902972394331\"\n ; \"18446218870769123862937242938812447270514023886221086573211479802027270358088\"\n ; \"16636528128134911466622907961467317982179835733058354229921170933476186200761\"\n |]\n ; [| \"21580255665898770000010464770058710398562069327783167608746916860519840032223\"\n ; \"14719915601901504081829966027980062397831689039960210526441564682684152170817\"\n ; \"797386830910520008361185815477523544664694040635544500916993469578452189812\"\n |]\n ; [| \"9191954826842055432037975444679415772735351199913945274909680288228536535340\"\n ; \"11513278700830950317038408125611466230422950302149566779135423862866530023329\"\n ; \"13459513701495368402370574098477760729128222868352131109204646186188457791240\"\n |]\n ; [| \"5838069727284828316721466034821618997221603062621589223178808662165373261546\"\n ; \"6979902978975477924362644821755411140298300026935490428140425890908442375988\"\n ; \"16599678038272927378481138839511139789855186087290435109798146115836043579679\"\n |]\n ; [| \"12381797209422929428691015082010109537263140181969703876017444022025467803832\"\n ; \"6196650026284414689888119006953515712490610535320673834463816720858366634575\"\n ; \"18782265413128936113173411940279630009396595382244197409034789821410800698518\"\n |]\n ; [| \"18317002472599225949038448120242542829985613745531554876060436499109578301758\"\n ; \"1113479082803535302111716504211921283895099225074844625686926178204705529642\"\n ; \"5260759667255734667421232066934840926892602367345740699882163520384512718144\"\n |]\n ; [| \"127322212868745470136356444796372247628159800282485305190839131621480537609\"\n ; \"12956514709922286639520985225111137950302442378466870763868693820049405409474\"\n ; \"16137538628380664965477096166491883462931577135505027115582810475234963977421\"\n |]\n ; [| \"11057045636926688236651567778699977961671424092293844825634750356999128470728\"\n ; \"20835936071817504066403719723663997794776505092359954695254304206506756731833\"\n ; \"11961388648747677421997837882451601307689195235077835309786508479783430361445\"\n |]\n ; [| \"1793573889039951715150662350698925328676543592757846244725079508391393408932\"\n ; \"13402289137612357934827599869485046878369856459821775713222740005646790544884\"\n ; \"6508055411788943934719705492602467864380077642763636443982129530687343724318\"\n |]\n ; [| \"17607902685988307931266356493635411696470169831190714792315124728753478035177\"\n ; \"8194273390415023152581060020119881338779571723515253104919314696738194355344\"\n ; \"14994505851254731180804912001382376960436431877822495675906581329931114145032\"\n |]\n ; [| \"18381184948945816702338052755591260342844745389721883995323025098702517473904\"\n ; \"9186573784864449816023279170257163602574499515262252135042448697937263179368\"\n ; \"16881796086836744646703159464114164393240695449455598565494759189917589453976\"\n |]\n ; [| \"20572234397819806324185746612386811237648846766146640064924937718650897781978\"\n ; \"15398960110011455954857390264976694406010423055791889624651258877641756178391\"\n ; \"7626627472565586612974136909394190701438927259101824156422280944508708088979\"\n |]\n ; [| \"5225513048091970342186287982290643286434413678466132108172918521639972895801\"\n ; \"20796219142718322272479527852102350372678035311367637066794738260059405761892\"\n ; \"18867914789735779656943683552060466421616672953566565464125163675462552310225\"\n |]\n ; [| \"1082743678015977585514191190870862236773423558498135453104771878687511906366\"\n ; \"12623224059252254308457589993365174837697684756635908936641223908438823373531\"\n ; \"12555890586414377546838955106772636059664719538696271061728900536297596172906\"\n |]\n ; [| \"15264924047176739600757644598701762120134127746088692861582462406342309222440\"\n ; \"13735945315945382005247895569035266667172550063549145646185577935658666385507\"\n ; \"16846296242516834547231537358954027537902709068158411294345086281698311539718\"\n |]\n ; [| \"5529559903327977764360588597603235134251022845353553657623467329197099735440\"\n ; \"17896661983150937411004047429485556264820315976705642986609974816436222162633\"\n ; \"6132147645856673317909222426799071493032959293586440635818225286067400272621\"\n |]\n ; [| \"19910536448857177568998054979673460274356626268309923630750601690129744044143\"\n ; \"21837022717353361125929262770547893899304355057483567328441690117551675150495\"\n ; \"18222937567706439527101614170488289588444167715669706061945406480673991437911\"\n |]\n ; [| \"1444795096087046870164826172194881116549489406599247123900277072374333222523\"\n ; \"7789285740743619796571024808404378017415878533792118428790588967260363950606\"\n ; \"2733591517253510124338232417535938539627593736745105875672348998709544742241\"\n |]\n ; [| \"10797236245657229835704604790990749002913266164534811352882924972411330424481\"\n ; \"8586865110658270624125510090452038681539626362312203247529227232785490000213\"\n ; \"16990606351055720221300633612533434675038905235719867684891402550154692840579\"\n |]\n ; [| \"13886834869596827027283068322204563244577723967928602405785473534631482228259\"\n ; \"15370041030312982119820349355806306848945675230473045778175606920520020444465\"\n ; \"4892392164144856036080673702415932177491638051096567008590655427718905654995\"\n |]\n ; [| \"7156056361402750618478307158538015778512650133626207855710105646992193371811\"\n ; \"18611994297623980580066352324654520696209128189173454279498506046357017146863\"\n ; \"20685574625754044704454597610042653981655420607405749168756591785339765348017\"\n |]\n ; [| \"19771798755427122057663307238031585225333077748195038834574552418532105026109\"\n ; \"7198246770791404776745997973411401046335399072925979346193035999274650139809\"\n ; \"4023053642231617394331377349850999955271972515156538475518460583299482183537\"\n |]\n ; [| \"8600241056877374090996492763915201371612819917708477598778176717657922462947\"\n ; \"13457797645730052033686724345687857978500724093559828625307818927699840833531\"\n ; \"16026530057488171235747101959040626414628692240827947554707033614704824950299\"\n |]\n ; [| \"17395049232451382970906883167116397657891664802601579276725674512534883408665\"\n ; \"9339859050789350561021790367067195330588925099928812336960590308144433379361\"\n ; \"2949098252117356570135518983407292742860689840833413663842097549831698684366\"\n |]\n ; [| \"20556719902345568138970735755829852608784985449829745172855204153387982836579\"\n ; \"17130405757403641097651484965062131526367059595476924144885570325828777794585\"\n ; \"12098791849907955483840555979771849699037912527654257328360429401569823685788\"\n |]\n ; [| \"17814517977679061356584950826520510701145481336316888282105225134451035883368\"\n ; \"18340263833447961155645725374025776400999561225129160795675360757778486987388\"\n ; \"2393071357700172397099185245759131983536576193657235776526704600015951290441\"\n |]\n ; [| \"4212550607122984812935174903270756328485507924528581618288369631872316849833\"\n ; \"4619648579309903974086199484827129282821840232468518761664883379486001128848\"\n ; \"11830688953328429351984357834116389341476681935757757908813724623462162230171\"\n |]\n ; [| \"9433820477150269924006815701757707228705128802452735931367255389078887381031\"\n ; \"19125188968599512029274834491491595733696896208317777847233033576184416289376\"\n ; \"5918385816682866756860679567405784562483373873565987668410277610868983146285\"\n |]\n ; [| \"11679489428851609457960439894174478045625452323813143057634803520728058419797\"\n ; \"5724733785096476011403606227853139854344547354731648536310363676109859979599\"\n ; \"17573793517331212796808333696068548553394697853729636886331034644281465518715\"\n |]\n ; [| \"282611654311082728776282944765587839903391931876410017096206359579538734085\"\n ; \"742728073451137928865285752406697012428821295824901554854990717103000537584\"\n ; \"20306380368695786945008272690438693745796297843799468268993907772341096948885\"\n |]\n ; [| \"18100113160685180514467703718098463577197975190144073884222766672672318113538\"\n ; \"3596350844916320672068639652188042917240676939829686824217717083735102849099\"\n ; \"20838832950303269747058536033620845977209873531644245727210334971563271393066\"\n |]\n ; [| \"6253957843395630813948692334683334608532810817769598722493240718085139817265\"\n ; \"19309791485130397858271625213458465097936495981008767692231734090527713082114\"\n ; \"5939164146353625472313254161303475736537743070584069770562424769865448756665\"\n |]\n ; [| \"12298194698807155456066733319264594344499679328227389872285371269582859681345\"\n ; \"10410720333027720675907856932360489614426170334449240317306371002856268450593\"\n ; \"13207537521011022812319141236421268356825327806625537047299253455889808792527\"\n |]\n ; [| \"2622643323130765702269424224791233611920515499144047449633123689743564676648\"\n ; \"7934318163093606910388307192320021056510770283350564327826894301919432120323\"\n ; \"7390981975273378581893427566935692330605702531948453130383999822487328794460\"\n |]\n |]\n }\n\nlet params_Mnt4_298 =\n { Params.mds =\n [| [| \"181324588122329172048070802614406344967661900669343676997796156524662650229663511778086513\"\n ; \"263839662794798230944406038483748877420003467481254943330033497627810628977768312588897021\"\n ; \"47787034086054868794736504598805355240746067397315425760363325479582067585554122384528750\"\n |]\n ; [| \"391385728862913577230643656405794210023251219169789744235774373121108965138889307827345939\"\n ; \"368056256556859616791833365938123080683505948787537081082804782658777406001515743364112843\"\n ; \"249229689710372851346889167834108105226843437678081232334602983010385341756350839066179566\"\n |]\n ; [| \"391761630355250451965959916078641131603140945583687294349414005799846378806556028223600720\"\n ; \"309426222273897994989187985039896323914733463925481353595665936771905869408957537639744345\"\n ; \"429282034891350663871556405902853196474768911490694799502975387461169986038745882893853806\"\n |]\n |]\n ; round_constants =\n [| [| \"78119860594733808983474265082430117124674905785489385612351809573030163625517\"\n ; \"41917899842730241418346215913324270532073353586134123463219061327941260175271\"\n ; \"74594641694171623328644944059182600919855574964222988275913344198970402906473\"\n |]\n ; [| \"96215759378377024990520153908983544755208851791126218239402755616994541522004\"\n ; \"64070601581278917442704840630680311036021557676765751754522901046069205253111\"\n ; \"112123228532462696722378911494343451272980413618911326680094528285518792872677\"\n |]\n ; [| \"84572244072021308337360477634782636535511175281144388234379224309078196768262\"\n ; \"45201095631123410354816854701250642083197167601967427301389500806815426216645\"\n ; \"23419302413627434057960523568681421397183896397903197013759822219271473949448\"\n |]\n ; [| \"63220724218126871510891512179599337793645245415246618202146262033908228783613\"\n ; \"67900966560828272306360950341997532094196196655192755442359232962244590070115\"\n ; \"56382132371728071364028077587343004835658613510701494793375685201885283260755\"\n |]\n ; [| \"80317852656339951095312898663286716255545986714650554749917139819628941702909\"\n ; \"110977183257428423540294096816813859894739618561444416996538397449475628658639\"\n ; \"25195781166503180938390820610484311038421647727795615447439501669639084690800\"\n |]\n ; [| \"108664438541952156416331885221418851366456449596370568350972106298760717710264\"\n ; \"17649294376560630922417546944777537620537408190408066211453084495108565929366\"\n ; \"95236435002924956844837407534938226368352771792739587594037613075251645052212\"\n |]\n ; [| \"43150472723422600689013423057826322506171125106415122422656432973040257528684\"\n ; \"77355911134402286174761911573353899889837132781450260391484427670446862700214\"\n ; \"8690728446593494554377477996892461126663797704587025899930929227865493269824\"\n |]\n ; [| \"109175231986025180460846040078523879514558355792739714578031829643740609438879\"\n ; \"64844253590731404811389281562033735091759746904073461140427127388042062490899\"\n ; \"43237071281695629980341250188156848876595681601471702180515324064382368960951\"\n |]\n ; [| \"2704440995725305992776846806711930876273040749514871232837487081811513368296\"\n ; \"66806779110388532101035294912010606217442229808784290357894909707660045365269\"\n ; \"25541187612624070470730890200174075890643652797181103367956318438136878170352\"\n |]\n ; [| \"89300613074831725721350087269266903129165086877175223066581882601662278010666\"\n ; \"36824076981866281177052433916337787028520068526782493484076995129329938182524\"\n ; \"68880449342008497744225106025198236600142055580985632884415488154606462819445\"\n |]\n ; [| \"68556888546596545408135887526582256648006271867854316538090068824142539400698\"\n ; \"111379753250206255125320675615931203940253796355491142745969887430259465111569\"\n ; \"101469186248899356416491489235841069222521093012237305521090058066171355672289\"\n |]\n ; [| \"87819793263125973233157093200229218382531712066157093399606059493857616731410\"\n ; \"11055386921184594780372263378420826851562920740321950336882051897732501262543\"\n ; \"111945832089295501567161822264292548657346358707472584179854375613919325491249\"\n |]\n ; [| \"95630018375719472826904441325138673248990446382783206900295723762884876505178\"\n ; \"94833984285990985873155989049880754188702918168949640563745233736765833491756\"\n ; \"77578854197021606645372788474039811639438242484066959482386065023999206730771\"\n |]\n ; [| \"27799616729223271646690718201487403976485619375555391888533887467404804041014\"\n ; \"42616502170265664498961018686434252976977548128285781725227341660941880774718\"\n ; \"95884094505080541517768389956970969462501217028562326732054532092615835087122\"\n |]\n ; [| \"107531500891040898338150732759493933154418374543568088749403053559827078391994\"\n ; \"17316158269457914256007584527534747738658973027567786054549020564540952112346\"\n ; \"51624680144452294805663893795879183520785046924484587034566439599591446246116\"\n |]\n ; [| \"17698087730709566968258013675219881840614043344609152682517330801348583470562\"\n ; \"111925747861248746962567200879629070277886617811519137515553806421564944666811\"\n ; \"57148554624730554436721083599187229462914514696466218614205595953570212881615\"\n |]\n ; [| \"92002976914130835490768248031171915767210477082066266868807636677032557847243\"\n ; \"58807951133460826577955909810426403194149348045831674376120801431489918282349\"\n ; \"93581873597000319446791963913210464830992618681307774190204379970955657554666\"\n |]\n ; [| \"46734218328816451470118898692627799522173317355773128175090189234250221977353\"\n ; \"12565476532112137808460978474958060441970941349010371267577877299656634907765\"\n ; \"54284813390357004119220859882274190703294683700710665367594256039714984623777\"\n |]\n ; [| \"92046423253202913319296401122133532555630886766139313429473309376931112550800\"\n ; \"15095408309586969968044201398966210357547906905122453139947200130015688526573\"\n ; \"76483858663950700865536712701042004661599554591777656961315837882956812689085\"\n |]\n ; [| \"37793510665854947576525000802927849210746292216845467892500370179796223909690\"\n ; \"84954934523349224038508216623641462700694917568481430996824733443763638196693\"\n ; \"81116649005575743294029244339854405387811058321603450814032274416116019472096\"\n |]\n ; [| \"28313841745366368076212445154871968929195537523489133192784916081223753077949\"\n ; \"17307716513182567320564075539526480893558355908652993731441220999922946005081\"\n ; \"63148771170858502457695904149048034226689843239981287723002468627916462842625\"\n |]\n ; [| \"14724939606645168531546334343600232253284320276481307778787768813885931648950\"\n ; \"4684996260500305121238590806572541849891754312215139285622888510153705963000\"\n ; \"63682763879011752475568476861367553456179860221069473817315669232908763409259\"\n |]\n ; [| \"47776179656187399887062096850541192680190218704758942820514561435612697426715\"\n ; \"42017618175533328439486588850450028995049195954365035474995309904751824054581\"\n ; \"39169739448648613641258102792190571431737464735838931948313779997907435855102\"\n |]\n ; [| \"37525991163523321662699819448962967746703579202577998445997476955224037837979\"\n ; \"67759173441312327668891803222741396828094999063019622301649400178376863820046\"\n ; \"23041132473771739182071223620364590606653086905326129708428084432335332411661\"\n |]\n ; [| \"77778894465896892167598828497939467663479992533052348475467490972714790615441\"\n ; \"20821227542001445006023346122554483849065713580779858784021328359824080462519\"\n ; \"47217242463811495777303984778653549585537750303740616187093690846833142245039\"\n |]\n ; [| \"42826871300142174590405062658305130206548405024021455479047593769907201224399\"\n ; \"8850081254230234130482383430433176873344633494243110112848647064077741649744\"\n ; \"1819639941546179668398979507053724449231350395599747300736218202072168364980\"\n |]\n ; [| \"21219092773772827667886204262476112905428217689703647484316763603169544906986\"\n ; \"35036730416829620763976972888493029852952403098232484869595671405553221294746\"\n ; \"35487050610902505183766069070898136230610758743267437784506875078109148276407\"\n |]\n ; [| \"62560813042054697786535634928462520639989597995560367915904328183428481834648\"\n ; \"112205708104999693686115882430330200785082630634036862526175634736046083007596\"\n ; \"109084747126382177842005646092084591250172358815974554434100716599544229364287\"\n |]\n ; [| \"63740884245554590221521941789197287379354311786803164550686696984009448418872\"\n ; \"58779928727649398559174292364061339806256990859940639552881479945324304668069\"\n ; \"20614241966717622390914334053622572167995367802051836931454426877074875942253\"\n |]\n ; [| \"41621411615229558798583846330993607380846912281220890296433013153854774573504\"\n ; \"20530621481603446397085836296967350209890164029268319619481535419199429275412\"\n ; \"99914592017824500091708233310179001698739309503141229228952777264267035511439\"\n |]\n ; [| \"9497854724940806346676139162466690071592872530638144182764466319052293463165\"\n ; \"7549205476288061047040852944548942878112823732145584918107208536541712726277\"\n ; \"30898915730863004722886730649661235919513859500318540107289237568593577554645\"\n |]\n ; [| \"22697249754607337581727259086359907309326296469394183645633378468855554942575\"\n ; \"72771100592475003378969523202338527077495914171905204927442739996373603143216\"\n ; \"84509851995167666169868678185342549983568150803791023831909660012392522615426\"\n |]\n ; [| \"36601166816771446688370845080961015541431660429079281633209182736773260407536\"\n ; \"19555759172327736128240171000715903945570888389700763573790859521156095228287\"\n ; \"82844424532983875300577689116331373756526403900340445449185486212503235782229\"\n |]\n ; [| \"40833119728631657038301474658571416779079199343770917422783737091842927892625\"\n ; \"68922359316478675184342553333343300163568193749010867527082189412217781430311\"\n ; \"91516472400306837063911995909475588197278444979245081960087094196120449075833\"\n |]\n ; [| \"21304716730402869084944080869903443431235336418077153507261240151959530377653\"\n ; \"106551237424345741137570659736231801772439680702621554106791455938098031620471\"\n ; \"104392597313271110590927764888829150750277653499050463757708547416538850601163\"\n |]\n ; [| \"16907937154215020261110468963982390213438461071031811101554056252102505124726\"\n ; \"23183141532591565112222057191012766855134687114504142337903677590107533245206\"\n ; \"96725517880771645283128624101279195709280644465575982072053504613644938879246\"\n |]\n ; [| \"84556507395241990875812091718422997082915179448604219593521819129312718969906\"\n ; \"100646525819453650494590571397259055384579251368754179569362740802641255820576\"\n ; \"50316555026297423940834952362583934362215303629664094841692233643882339493043\"\n |]\n ; [| \"77363534410783423412630139556441807611393685349073113946053979350631229049878\"\n ; \"54905073434434959485893381841839373267383966385817882684657825178181863944371\"\n ; \"110016011331508430102821620395154714608084938556260733745010992614542669817451\"\n |]\n ; [| \"52040139270046094723964229965823921970388683619580004402190656733318120479093\"\n ; \"495546618036723566920914648951352373868059898268055487677897567226892784967\"\n ; \"2528292188392170914010448139211586215817069915670005292953294092269979070980\"\n |]\n ; [| \"36842840134449713950999812540127591123318806680559982063089906871196226758113\"\n ; \"112314504940338253416202605695368724580971154020421327790335219348068041886245\"\n ; \"51653712314537383078368021242008468828072907802445786549975419682333073143987\"\n |]\n ; [| \"27179054135131403873076215577181710354069071017096145081169516607932870071868\"\n ; \"93264325401956094073193527739715293258814405715822269809955952297346626219055\"\n ; \"75336695567377817226085396912086909560962335091652231383627608374094112503635\"\n |]\n ; [| \"42536477740858058164730818130587261149155820207748153094480456895727052896150\"\n ; \"45297707210835305388426482743535401273114010430724989418303851665124351001731\"\n ; \"28263543670875633354854018109712021307749750769690268127459707194207091046997\"\n |]\n ; [| \"40809484989590048522440442751358616303471639779690405026946053699354967624695\"\n ; \"51589519265418587649124543325590658874910911006853535317847189422703251228717\"\n ; \"73459936981642894525955700397592343967482441686326322443228255968694436816673\"\n |]\n ; [| \"87298777232393189731949522229743081866971743270330772607820990832164835738703\"\n ; \"23328534428894097247289332213412175849711532153957647506361455182140450133738\"\n ; \"51807348624578081645565456865744011145427112815128832643950401419083788780028\"\n |]\n ; [| \"62003629107726929116302469001779155132709624140360743951550189738290955064278\"\n ; \"109311858027068383034683875948676795998030610067675200794951297783857157095297\"\n ; \"2085588517087605436136379278738013214233743532079287631079316773925068862732\"\n |]\n ; [| \"9513664655545306376987968929852776467090105742275395185801917554996684570014\"\n ; \"91103467624252027317764670613760419385374004736848754250298970998535616755199\"\n ; \"39500000352127197728032684892425352332461947514533659433380855624868454474623\"\n |]\n ; [| \"75175260486328125629270378861920310368403601365269629778076078053196928460032\"\n ; \"56923881233337629517433981230592855430598464522180216309153828833928801967999\"\n ; \"20981004218820236011689230170078809973840534961691702543937445515733151438851\"\n |]\n ; [| \"73175203586574092105626230272409823792532423094740797516874387144340145138310\"\n ; \"45186992623753580336479418079070607289916086076906975839720879934817804495460\"\n ; \"96084125187548549854900995260973117424750860440064269432639526863495781270780\"\n |]\n ; [| \"53530507055579550362119832302266967544350117012822630711681736383163390079758\"\n ; \"24484677147631687826970700541691541659768738376645174313438582486313045584324\"\n ; \"99915577684197600584703320523786830947563355229812244982453188909016758004559\"\n |]\n ; [| \"73101441225016284181831039876112223954723401962484828024235461623078642642543\"\n ; \"57434882751817972247799186935032874577110609253567900895922769490031350316077\"\n ; \"73837027842771758252813592393497967898989365991569964687267097531033696791279\"\n |]\n ; [| \"8605586894544301092657394167906502995894014247978769840701086209902531650480\"\n ; \"8900145888985471928279988821934068156350024482295663273746853580585203659117\"\n ; \"76135096553134713603675854628257365311062159747768423095496501607463292188538\"\n |]\n ; [| \"77171330825793179961995032914169307990870372845116475229799680315757656196917\"\n ; \"17848856881287888035559207919717746181941756011012420474955535369227552058196\"\n ; \"85285874363861776466393873037603415962379724376693393356387850868454172343232\"\n |]\n ; [| \"34752820629818556525384193423224856177797869338806846583786365186093662702640\"\n ; \"61923000676912108769617866333091286856690233713839015114991682235541391477568\"\n ; \"105437294734850952102877811210027981435959945375626993201685688489494148805743\"\n |]\n ; [| \"37290995592003925978648162243724313056459187397796644444696543576625771108605\"\n ; \"95156804644588215637074780475000089186488581067063625121782605228712011438608\"\n ; \"111838568780358037910894878973007194619694503969424695895292495245099084158661\"\n |]\n ; [| \"114085830904535970531084512281741806703564152148485737755668141105183488387818\"\n ; \"27151558900245092306095370161852910074651784795680581223133179808714387525774\"\n ; \"17782273009863750298483603933610732253879825505411230932533407287574651036994\"\n |]\n ; [| \"72422039981423868898452547270453235353957783762070405836433674391957844064693\"\n ; \"23635533014670380888810554717349513178608213369182061967678315431422272271569\"\n ; \"59402711345784829746976504521969665104448536964686633342173372133388407225657\"\n |]\n ; [| \"92466806354851856571355165199186633833982438153589406912422876269386887264049\"\n ; \"9877617390649361889067963484857474874019563445507538784053773745685676317984\"\n ; \"74572672075215609948567780829046067891251792522874268554421916351892498078660\"\n |]\n ; [| \"36552683919656073147232029802086505741533932059491323529262718897271096098319\"\n ; \"28895802628889660292449057575076739706255701997961890168977786141673053679086\"\n ; \"9907785227545441866241924986174555965766785257012652276622736289520175209842\"\n |]\n ; [| \"29485332368911768475893015509537099136952860812699472744021496513325455451738\"\n ; \"39797358509842904932758894391536601623578260107859540160156599261695054175926\"\n ; \"107452259847197252302434271220963395311929879689430847107159618578878468880668\"\n |]\n ; [| \"24664696127391052816688570667643612077905959307658722811431436096677076924072\"\n ; \"52507998665481228083044018390203046881916651866666590845312076558622705190465\"\n ; \"69935204723497468327083545368078327534124772251842862926136799697299751835029\"\n |]\n ; [| \"372963191403207230700085823960930798511810380777302780932220121859190714585\"\n ; \"111366606704792806959979488772421759791592911629496627207620326636856656861526\"\n ; \"39677360977437767398760288273614298000827429534821360419179023551087917983124\"\n |]\n ; [| \"64601494076430280535646633059501605929914790764963584476403188233843589027560\"\n ; \"34156315098453482946438495274327282067376463494057110043754782161473776373661\"\n ; \"73687667961196401152630755105477060056162632832680813161120412165243753726816\"\n |]\n ; [| \"37808689229279738382348785246837013002280781984053433359148018860351753688153\"\n ; \"26778210635417272626362658500217995247072424006327715268521424423461840656985\"\n ; \"13012115310019421859484865413402512912208022868124085927375736053832542569552\"\n |]\n ; [| \"33073055720188060063004545324174039863351833928493376423022587630016341635891\"\n ; \"76584254259783109527449313057522305759653397147785066495263227868665161219779\"\n ; \"38531270223194009551634352795926218399266465064491096474482575354468954922673\"\n |]\n ; [| \"90100362566645034035707547984589905559141359276359522681964816611161474672115\"\n ; \"93014643079204629081291124987233004565276697190519877698472422015954982964601\"\n ; \"110916697765188052223435628742886773389228694903593626715469113528434066764534\"\n |]\n ; [| \"114725280711584666069398481856753837363052938587178775403749719257369626174299\"\n ; \"32967950615819700839673854548770413755655613096921050182183649674389310060672\"\n ; \"106372438106855157117155417458821032302424106544646447353561892891697429919509\"\n |]\n ; [| \"41996555998804572671679174634435850382099449308465335760130383677478780889948\"\n ; \"105999190358126224751922865919841547624707481487885223948004296548330504340556\"\n ; \"16636528128134911466622907961467317982179835733058354229921170933476186200761\"\n |]\n ; [| \"43468498537738045222256870515315985487110433728199201952445121047095648527840\"\n ; \"102272887089258604970815589009009162752025146641624347901234381428987386153285\"\n ; \"797386830910520008361185815477523544664694040635544500916993469578452189812\"\n |]\n ; [| \"96744926314199156321023598425708516126928808801578082649702497034531770517808\"\n ; \"99066250188188051206024031106640566584616407903813704153928240609169764005797\"\n ; \"101012485188852469291356197079506861083321680470016268483997462932491691773708\"\n |]\n ; [| \"49614555470963378761214277525336169174318331863453657910575217035316990252780\"\n ; \"94532874466332578813348267802784511494491757628599627802933242637211676358456\"\n ; \"60376163781951477822973950330025689966951914888122503797194554488987660570913\"\n |]\n ; [| \"99934768696780030317676638063039209891456597783633841250810260768328701786300\"\n ; \"71861378641802240356627336242725340978135703736568776865558429280585792121426\"\n ; \"84446994028646761779912629176051455275041688583492300440129402381138226185369\"\n |]\n ; [| \"18317002472599225949038448120242542829985613745531554876060436499109578301758\"\n ; \"23001721954642810524358122249469196372443463625490878969385130364780514025259\"\n ; \"49037245410934285111914043557449391103989331168177809387278571893536129709378\"\n |]\n ; [| \"65792050828386571136875573680568197513273253001530588336285451691348906024460\"\n ; \"12956514709922286639520985225111137950302442378466870763868693820049405409474\"\n ; \"38025781500219940187723501911749158551479941535921061459281014661810772473038\"\n |]\n ; [| \"98610017124283789125637190759729078315864881693957982200427567103302362453196\"\n ; \"42724178943656779288650125468921272883324869492775989038952508393082565227450\"\n ; \"99514360136104778310983460863480701661882652836741972684579325226086664343913\"\n |]\n ; [| \"111234788248236327826382691076985300771418365594838017963216100441270435887017\"\n ; \"35290532009451633157074005614742321966918220860237810056920944192222599040501\"\n ; \"72172784027306769601458922728374293130025170844011739475076742090414769211169\"\n |]\n ; [| \"61384388429666858375759167984149961873566898632022783479711533101905095026411\"\n ; \"8194273390415023152581060020119881338779571723515253104919314696738194355344\"\n ; \"80659234466772556847544129237154202226081525079070598707001193889658539631883\"\n |]\n ; [| \"62157670692624367146830864246105810519941474190553952682719433471854134465138\"\n ; \"74851302400382275482762496406028988868219592716510355166137061257664688666219\"\n ; \"16881796086836744646703159464114164393240695449455598565494759189917589453976\"\n |]\n ; [| \"42460477269659081546432152357644086326197211166562674408623141905226706277595\"\n ; \"81063688725529281621596607500748519671655516257039992655745871437369181665242\"\n ; \"51403113216244137057466948399908740878535656059933892843818689317660325080213\"\n |]\n ; [| \"49001998791770520786679099472805193463531142479298200795569326894791589887035\"\n ; \"42684462014557597494725933597359625461226399711783671410492942446635214257509\"\n ; \"106420886277092880545929306533089566775810130555230702838917980421765786292693\"\n |]\n ; [| \"110523958037212353696746219917157237679515245560578307171595792811566554384451\"\n ; \"56399709802930804752950401483879725014794413557467977624037632281590440364765\"\n ; \"100108862073771478435824578087801736413858177140360408436521717282600830155374\"\n |]\n ; [| \"59041409790855290045250456089216312297230856546920761548978870779493926213674\"\n ; \"13735945315945382005247895569035266667172550063549145646185577935658666385507\"\n ; \"16846296242516834547231537358954027537902709068158411294345086281698311539718\"\n |]\n ; [| \"114970774262524353875592617323889610576992844847433725376114488262076142213525\"\n ; \"17896661983150937411004047429485556264820315976705642986609974816436222162633\"\n ; \"115573362005053049429141251153085446935774781295666612354309246218946442750706\"\n |]\n ; [| \"85575265064375003235737272215445285540001719469558026661845214249857169530994\"\n ; \"87501751332871186792668480006319719164949448258731670359536302677279100637346\"\n ; \"105775909055063540416087237151517389942637625317333843436738223226977225420379\"\n |]\n ; [| \"110886009455283422981396854898481256559291311408679418842391298005253375700608\"\n ; \"95342257228100720685556647789433478371609336135456255803583405713563597933074\"\n ; \"2733591517253510124338232417535938539627593736745105875672348998709544742241\"\n |]\n ; [| \"32685479117496505057951010536248024091461630564950845696581129158987138920098\"\n ; \"96139836598015371513111133071481139035733083963976340622322043979088723982681\"\n ; \"16990606351055720221300633612533434675038905235719867684891402550154692840579\"\n |]\n ; [| \"13886834869596827027283068322204563244577723967928602405785473534631482228259\"\n ; \"81034769645830807786559566591578132114590768431721148809270219480247445931316\"\n ; \"26780635035984131258327079447673207266040002451512601352288859614294714150612\"\n |]\n ; [| \"72820784976920576285217524394309841044157743334874310886804718206719618858662\"\n ; \"84276722913141806246805569560426345961854221390421557310593118606084442633714\"\n ; \"42573817497593319926701003355299929070203785007821783512454795971915573843634\"\n |]\n ; [| \"41660041627266397279909712983288860313881442148611073178272756605107913521726\"\n ; \"7198246770791404776745997973411401046335399072925979346193035999274650139809\"\n ; \"91576025129588718283317000330880100309465430116820675850311277329602716166005\"\n |]\n ; [| \"30488483928716649313242898509172476460161184318124511942476380904233730958564\"\n ; \"35346040517569327255933130090945133067049088493975862969006023114275649329148\"\n ; \"59803015801166721680239913449555176591725421041660016242103441987856441941533\"\n |]\n ; [| \"17395049232451382970906883167116397657891664802601579276725674512534883408665\"\n ; \"96892830538146451450007413348096295684782382701592949711753407054447667361829\"\n ; \"46725583995795907014628330473921842919957418641665482351238505922983315675600\"\n |]\n ; [| \"20556719902345568138970735755829852608784985449829745172855204153387982836579\"\n ; \"17130405757403641097651484965062131526367059595476924144885570325828777794585\"\n ; \"99651763337265056372826178960800950053231370129318394703153246147873057668256\"\n |]\n ; [| \"17814517977679061356584950826520510701145481336316888282105225134451035883368\"\n ; \"62116749577126511600138536864540326578096290025961229483071769130930103978622\"\n ; \"68057799973217998063838402481530957249181669394905338807621317159743376777292\"\n |]\n ; [| \"26100793478962260035181580648528031417033872324944615961986573818448125345450\"\n ; \"26507891451149179196332605230084404371370204632884553105363087566061809624465\"\n ; \"55607174697006979796477169324630939518573410736589826596210132996613779221405\"\n |]\n ; [| \"75098549092668095590746032937529532494350222003700838962461867948806312867882\"\n ; \"62901674712278062473767645982006145910793625009149846534629441949336033280610\"\n ; \"5918385816682866756860679567405784562483373873565987668410277610868983146285\"\n |]\n ; [| \"99232460916208710346946062875203578399818909925477280432427620267031292402265\"\n ; \"115165948144292852122635634954139515297086369356811820254801384608988902457684\"\n ; \"39462036389170488019054739441325823641943062254145671230029238830857274014332\"\n |]\n ; [| \"109723826013507458840008311671051963282645213933956581735587227292458581212170\"\n ; \"88295699560808238817850908733435797366622278897489038929647807463406234520052\"\n ; \"20306380368695786945008272690438693745796297843799468268993907772341096948885\"\n |]\n ; [| \"39988356032524455736714109463355738665746339590560108227920970859248126609155\"\n ; \"47372836588594871116561451142702593094337405740661755511614125456886719840333\"\n ; \"42727075822142544969304941778878121065758237932060280070908539158139079888683\"\n |]\n ; [| \"115695172202592006925180721060969710051274632819849770440984261650964182295350\"\n ; \"41198034356969673080518030958715740186484860381424802035929938277103521577731\"\n ; \"115380378505550001583545282887589851179279565072664241489053445702744491234750\"\n |]\n ; [| \"56074680442485705900559544809779144521596408129059458559681779642734476672579\"\n ; \"54187206076706271120400668422875039791522899135281309004702779376007885441827\"\n ; \"100760509008368123701304764217450368711018785408289674422092070202193042774995\"\n |]\n ; [| \"2622643323130765702269424224791233611920515499144047449633123689743564676648\"\n ; \"95487289650450707799373930173349121410704227885014701702619711048222666102791\"\n ; \"94943953462630479470879050547964792684799160133612590505176816568790562776928\"\n |]\n |]\n }\n\nlet params_Mnt4_753 =\n { Params.mds =\n [| [| \"18008368437737423474309001369890301521976028259557869102888851965525650962978826556079921598599098888590302388431866694591858505845787597588918688371226882207991627422083815074127761663891796146172734531991290402968541914191945\"\n ; \"32962087054539410523956712909309686802653898657605569239066684150412875533806729129396719808139132458477579312916467576544007112173179883702872518317566248974424872120316787037296877442303550788674087649228607529914336317231815\"\n ; \"5483644920564955035638567475101171013329909513705951195576914157062781400017095978578204379959018576768230785151221956162299596069033091214145892295417145700700562355150808732841416210677611704678816316579070697592848376918151\"\n |]\n ; [| \"22978648816866328436434244623482365207916416489037627250857600725663194263360344221738155318310265722276036466391561221273100146793047089336717612168000266025808046352571957200240941276891050003938106626328014785436301089444973\"\n ; \"30994637628885441247541289546067547358628828834593234742882770745561956454298316691254641971835514862825457645395555821312465912408960063865618013131940007283956832467402859348036195396599351702172170219903104023278420827940135\"\n ; \"7096546890972108774287040498267941446510912236116268882520023333699636048386130304511472040490894498194252489942856762189629237475878134498814298584446894911200379613916180563419809701971057277837757006070684068787238347669992\"\n |]\n ; [| \"36972350749469737754741804679554799140755989986720531577443294433161553396641362942311484418395414339763390349161399190591697773588979458652577643792428305947365748981633559835484411429153283032734484874265223184021528054671667\"\n ; \"41737243523985324129413602960234190443256387558212939183466624464606481865667576817406507424236723364751044981130064473555650490691461017936143464747647507236853158008794221676669840197156981325463879378696484711828785706949884\"\n ; \"17173689835840458026597473076649786448044751322360472626284380020090825232350642484368920024327948574743378803111953285570783101340571478325610471380479472689631139762331626281838772360396878623880994496993923849428256427219637\"\n |]\n |]\n ; round_constants =\n [| [| \"78119860594733808983474265082430117124674905785489385612351809573030163625517\"\n ; \"41917899842730241418346215913324270532073353586134123463219061327941260175271\"\n ; \"74594641694171623328644944059182600919855574964222988275913344198970402906473\"\n |]\n ; [| \"96215759378377024990520153908983544755208851791126218239402755616994541522004\"\n ; \"64070601581278917442704840630680311036021557676765751754522901046069205253111\"\n ; \"112123228532462696722378911494343451272980413618911326680094528285518792872677\"\n |]\n ; [| \"84572244072021308337360477634782636535511175281144388234379224309078196768262\"\n ; \"45201095631123410354816854701250642083197167601967427301389500806815426216645\"\n ; \"23419302413627434057960523568681421397183896397903197013759822219271473949448\"\n |]\n ; [| \"63220724218126871510891512179599337793645245415246618202146262033908228783613\"\n ; \"67900966560828272306360950341997532094196196655192755442359232962244590070115\"\n ; \"56382132371728071364028077587343004835658613510701494793375685201885283260755\"\n |]\n ; [| \"80317852656339951095312898663286716255545986714650554749917139819628941702909\"\n ; \"110977183257428423540294096816813859894739618561444416996538397449475628658639\"\n ; \"25195781166503180938390820610484311038421647727795615447439501669639084690800\"\n |]\n ; [| \"108664438541952156416331885221418851366456449596370568350972106298760717710264\"\n ; \"17649294376560630922417546944777537620537408190408066211453084495108565929366\"\n ; \"95236435002924956844837407534938226368352771792739587594037613075251645052212\"\n |]\n ; [| \"43150472723422600689013423057826322506171125106415122422656432973040257528684\"\n ; \"77355911134402286174761911573353899889837132781450260391484427670446862700214\"\n ; \"8690728446593494554377477996892461126663797704587025899930929227865493269824\"\n |]\n ; [| \"109175231986025180460846040078523879514558355792739714578031829643740609438879\"\n ; \"64844253590731404811389281562033735091759746904073461140427127388042062490899\"\n ; \"43237071281695629980341250188156848876595681601471702180515324064382368960951\"\n |]\n ; [| \"2704440995725305992776846806711930876273040749514871232837487081811513368296\"\n ; \"66806779110388532101035294912010606217442229808784290357894909707660045365269\"\n ; \"25541187612624070470730890200174075890643652797181103367956318438136878170352\"\n |]\n ; [| \"89300613074831725721350087269266903129165086877175223066581882601662278010666\"\n ; \"36824076981866281177052433916337787028520068526782493484076995129329938182524\"\n ; \"68880449342008497744225106025198236600142055580985632884415488154606462819445\"\n |]\n ; [| \"68556888546596545408135887526582256648006271867854316538090068824142539400698\"\n ; \"111379753250206255125320675615931203940253796355491142745969887430259465111569\"\n ; \"101469186248899356416491489235841069222521093012237305521090058066171355672289\"\n |]\n ; [| \"87819793263125973233157093200229218382531712066157093399606059493857616731410\"\n ; \"11055386921184594780372263378420826851562920740321950336882051897732501262543\"\n ; \"111945832089295501567161822264292548657346358707472584179854375613919325491249\"\n |]\n ; [| \"95630018375719472826904441325138673248990446382783206900295723762884876505178\"\n ; \"94833984285990985873155989049880754188702918168949640563745233736765833491756\"\n ; \"77578854197021606645372788474039811639438242484066959482386065023999206730771\"\n |]\n ; [| \"27799616729223271646690718201487403976485619375555391888533887467404804041014\"\n ; \"42616502170265664498961018686434252976977548128285781725227341660941880774718\"\n ; \"95884094505080541517768389956970969462501217028562326732054532092615835087122\"\n |]\n ; [| \"107531500891040898338150732759493933154418374543568088749403053559827078391994\"\n ; \"17316158269457914256007584527534747738658973027567786054549020564540952112346\"\n ; \"51624680144452294805663893795879183520785046924484587034566439599591446246116\"\n |]\n ; [| \"17698087730709566968258013675219881840614043344609152682517330801348583470562\"\n ; \"111925747861248746962567200879629070277886617811519137515553806421564944666811\"\n ; \"57148554624730554436721083599187229462914514696466218614205595953570212881615\"\n |]\n ; [| \"92002976914130835490768248031171915767210477082066266868807636677032557847243\"\n ; \"58807951133460826577955909810426403194149348045831674376120801431489918282349\"\n ; \"93581873597000319446791963913210464830992618681307774190204379970955657554666\"\n |]\n ; [| \"46734218328816451470118898692627799522173317355773128175090189234250221977353\"\n ; \"12565476532112137808460978474958060441970941349010371267577877299656634907765\"\n ; \"54284813390357004119220859882274190703294683700710665367594256039714984623777\"\n |]\n ; [| \"92046423253202913319296401122133532555630886766139313429473309376931112550800\"\n ; \"15095408309586969968044201398966210357547906905122453139947200130015688526573\"\n ; \"76483858663950700865536712701042004661599554591777656961315837882956812689085\"\n |]\n ; [| \"37793510665854947576525000802927849210746292216845467892500370179796223909690\"\n ; \"84954934523349224038508216623641462700694917568481430996824733443763638196693\"\n ; \"81116649005575743294029244339854405387811058321603450814032274416116019472096\"\n |]\n ; [| \"28313841745366368076212445154871968929195537523489133192784916081223753077949\"\n ; \"17307716513182567320564075539526480893558355908652993731441220999922946005081\"\n ; \"63148771170858502457695904149048034226689843239981287723002468627916462842625\"\n |]\n ; [| \"14724939606645168531546334343600232253284320276481307778787768813885931648950\"\n ; \"4684996260500305121238590806572541849891754312215139285622888510153705963000\"\n ; \"63682763879011752475568476861367553456179860221069473817315669232908763409259\"\n |]\n ; [| \"47776179656187399887062096850541192680190218704758942820514561435612697426715\"\n ; \"42017618175533328439486588850450028995049195954365035474995309904751824054581\"\n ; \"39169739448648613641258102792190571431737464735838931948313779997907435855102\"\n |]\n ; [| \"37525991163523321662699819448962967746703579202577998445997476955224037837979\"\n ; \"67759173441312327668891803222741396828094999063019622301649400178376863820046\"\n ; \"23041132473771739182071223620364590606653086905326129708428084432335332411661\"\n |]\n ; [| \"77778894465896892167598828497939467663479992533052348475467490972714790615441\"\n ; \"20821227542001445006023346122554483849065713580779858784021328359824080462519\"\n ; \"47217242463811495777303984778653549585537750303740616187093690846833142245039\"\n |]\n ; [| \"42826871300142174590405062658305130206548405024021455479047593769907201224399\"\n ; \"8850081254230234130482383430433176873344633494243110112848647064077741649744\"\n ; \"1819639941546179668398979507053724449231350395599747300736218202072168364980\"\n |]\n ; [| \"21219092773772827667886204262476112905428217689703647484316763603169544906986\"\n ; \"35036730416829620763976972888493029852952403098232484869595671405553221294746\"\n ; \"35487050610902505183766069070898136230610758743267437784506875078109148276407\"\n |]\n ; [| \"62560813042054697786535634928462520639989597995560367915904328183428481834648\"\n ; \"112205708104999693686115882430330200785082630634036862526175634736046083007596\"\n ; \"109084747126382177842005646092084591250172358815974554434100716599544229364287\"\n |]\n ; [| \"63740884245554590221521941789197287379354311786803164550686696984009448418872\"\n ; \"58779928727649398559174292364061339806256990859940639552881479945324304668069\"\n ; \"20614241966717622390914334053622572167995367802051836931454426877074875942253\"\n |]\n ; [| \"41621411615229558798583846330993607380846912281220890296433013153854774573504\"\n ; \"20530621481603446397085836296967350209890164029268319619481535419199429275412\"\n ; \"99914592017824500091708233310179001698739309503141229228952777264267035511439\"\n |]\n ; [| \"9497854724940806346676139162466690071592872530638144182764466319052293463165\"\n ; \"7549205476288061047040852944548942878112823732145584918107208536541712726277\"\n ; \"30898915730863004722886730649661235919513859500318540107289237568593577554645\"\n |]\n ; [| \"22697249754607337581727259086359907309326296469394183645633378468855554942575\"\n ; \"72771100592475003378969523202338527077495914171905204927442739996373603143216\"\n ; \"84509851995167666169868678185342549983568150803791023831909660012392522615426\"\n |]\n ; [| \"36601166816771446688370845080961015541431660429079281633209182736773260407536\"\n ; \"19555759172327736128240171000715903945570888389700763573790859521156095228287\"\n ; \"82844424532983875300577689116331373756526403900340445449185486212503235782229\"\n |]\n ; [| \"40833119728631657038301474658571416779079199343770917422783737091842927892625\"\n ; \"68922359316478675184342553333343300163568193749010867527082189412217781430311\"\n ; \"91516472400306837063911995909475588197278444979245081960087094196120449075833\"\n |]\n ; [| \"21304716730402869084944080869903443431235336418077153507261240151959530377653\"\n ; \"106551237424345741137570659736231801772439680702621554106791455938098031620471\"\n ; \"104392597313271110590927764888829150750277653499050463757708547416538850601163\"\n |]\n ; [| \"16907937154215020261110468963982390213438461071031811101554056252102505124726\"\n ; \"23183141532591565112222057191012766855134687114504142337903677590107533245206\"\n ; \"96725517880771645283128624101279195709280644465575982072053504613644938879246\"\n |]\n ; [| \"84556507395241990875812091718422997082915179448604219593521819129312718969906\"\n ; \"100646525819453650494590571397259055384579251368754179569362740802641255820576\"\n ; \"50316555026297423940834952362583934362215303629664094841692233643882339493043\"\n |]\n ; [| \"77363534410783423412630139556441807611393685349073113946053979350631229049878\"\n ; \"54905073434434959485893381841839373267383966385817882684657825178181863944371\"\n ; \"110016011331508430102821620395154714608084938556260733745010992614542669817451\"\n |]\n ; [| \"52040139270046094723964229965823921970388683619580004402190656733318120479093\"\n ; \"495546618036723566920914648951352373868059898268055487677897567226892784967\"\n ; \"2528292188392170914010448139211586215817069915670005292953294092269979070980\"\n |]\n ; [| \"36842840134449713950999812540127591123318806680559982063089906871196226758113\"\n ; \"112314504940338253416202605695368724580971154020421327790335219348068041886245\"\n ; \"51653712314537383078368021242008468828072907802445786549975419682333073143987\"\n |]\n ; [| \"27179054135131403873076215577181710354069071017096145081169516607932870071868\"\n ; \"93264325401956094073193527739715293258814405715822269809955952297346626219055\"\n ; \"75336695567377817226085396912086909560962335091652231383627608374094112503635\"\n |]\n ; [| \"42536477740858058164730818130587261149155820207748153094480456895727052896150\"\n ; \"45297707210835305388426482743535401273114010430724989418303851665124351001731\"\n ; \"28263543670875633354854018109712021307749750769690268127459707194207091046997\"\n |]\n ; [| \"40809484989590048522440442751358616303471639779690405026946053699354967624695\"\n ; \"51589519265418587649124543325590658874910911006853535317847189422703251228717\"\n ; \"73459936981642894525955700397592343967482441686326322443228255968694436816673\"\n |]\n ; [| \"87298777232393189731949522229743081866971743270330772607820990832164835738703\"\n ; \"23328534428894097247289332213412175849711532153957647506361455182140450133738\"\n ; \"51807348624578081645565456865744011145427112815128832643950401419083788780028\"\n |]\n ; [| \"62003629107726929116302469001779155132709624140360743951550189738290955064278\"\n ; \"109311858027068383034683875948676795998030610067675200794951297783857157095297\"\n ; \"2085588517087605436136379278738013214233743532079287631079316773925068862732\"\n |]\n ; [| \"9513664655545306376987968929852776467090105742275395185801917554996684570014\"\n ; \"91103467624252027317764670613760419385374004736848754250298970998535616755199\"\n ; \"39500000352127197728032684892425352332461947514533659433380855624868454474623\"\n |]\n ; [| \"75175260486328125629270378861920310368403601365269629778076078053196928460032\"\n ; \"56923881233337629517433981230592855430598464522180216309153828833928801967999\"\n ; \"20981004218820236011689230170078809973840534961691702543937445515733151438851\"\n |]\n ; [| \"73175203586574092105626230272409823792532423094740797516874387144340145138310\"\n ; \"45186992623753580336479418079070607289916086076906975839720879934817804495460\"\n ; \"96084125187548549854900995260973117424750860440064269432639526863495781270780\"\n |]\n ; [| \"53530507055579550362119832302266967544350117012822630711681736383163390079758\"\n ; \"24484677147631687826970700541691541659768738376645174313438582486313045584324\"\n ; \"99915577684197600584703320523786830947563355229812244982453188909016758004559\"\n |]\n ; [| \"73101441225016284181831039876112223954723401962484828024235461623078642642543\"\n ; \"57434882751817972247799186935032874577110609253567900895922769490031350316077\"\n ; \"73837027842771758252813592393497967898989365991569964687267097531033696791279\"\n |]\n ; [| \"8605586894544301092657394167906502995894014247978769840701086209902531650480\"\n ; \"8900145888985471928279988821934068156350024482295663273746853580585203659117\"\n ; \"76135096553134713603675854628257365311062159747768423095496501607463292188538\"\n |]\n ; [| \"77171330825793179961995032914169307990870372845116475229799680315757656196917\"\n ; \"17848856881287888035559207919717746181941756011012420474955535369227552058196\"\n ; \"85285874363861776466393873037603415962379724376693393356387850868454172343232\"\n |]\n ; [| \"34752820629818556525384193423224856177797869338806846583786365186093662702640\"\n ; \"61923000676912108769617866333091286856690233713839015114991682235541391477568\"\n ; \"105437294734850952102877811210027981435959945375626993201685688489494148805743\"\n |]\n ; [| \"37290995592003925978648162243724313056459187397796644444696543576625771108605\"\n ; \"95156804644588215637074780475000089186488581067063625121782605228712011438608\"\n ; \"111838568780358037910894878973007194619694503969424695895292495245099084158661\"\n |]\n ; [| \"114085830904535970531084512281741806703564152148485737755668141105183488387818\"\n ; \"27151558900245092306095370161852910074651784795680581223133179808714387525774\"\n ; \"17782273009863750298483603933610732253879825505411230932533407287574651036994\"\n |]\n ; [| \"72422039981423868898452547270453235353957783762070405836433674391957844064693\"\n ; \"23635533014670380888810554717349513178608213369182061967678315431422272271569\"\n ; \"59402711345784829746976504521969665104448536964686633342173372133388407225657\"\n |]\n ; [| \"92466806354851856571355165199186633833982438153589406912422876269386887264049\"\n ; \"9877617390649361889067963484857474874019563445507538784053773745685676317984\"\n ; \"74572672075215609948567780829046067891251792522874268554421916351892498078660\"\n |]\n ; [| \"36552683919656073147232029802086505741533932059491323529262718897271096098319\"\n ; \"28895802628889660292449057575076739706255701997961890168977786141673053679086\"\n ; \"9907785227545441866241924986174555965766785257012652276622736289520175209842\"\n |]\n ; [| \"29485332368911768475893015509537099136952860812699472744021496513325455451738\"\n ; \"39797358509842904932758894391536601623578260107859540160156599261695054175926\"\n ; \"107452259847197252302434271220963395311929879689430847107159618578878468880668\"\n |]\n ; [| \"24664696127391052816688570667643612077905959307658722811431436096677076924072\"\n ; \"52507998665481228083044018390203046881916651866666590845312076558622705190465\"\n ; \"69935204723497468327083545368078327534124772251842862926136799697299751835029\"\n |]\n ; [| \"372963191403207230700085823960930798511810380777302780932220121859190714585\"\n ; \"111366606704792806959979488772421759791592911629496627207620326636856656861526\"\n ; \"39677360977437767398760288273614298000827429534821360419179023551087917983124\"\n |]\n ; [| \"64601494076430280535646633059501605929914790764963584476403188233843589027560\"\n ; \"34156315098453482946438495274327282067376463494057110043754782161473776373661\"\n ; \"73687667961196401152630755105477060056162632832680813161120412165243753726816\"\n |]\n ; [| \"37808689229279738382348785246837013002280781984053433359148018860351753688153\"\n ; \"26778210635417272626362658500217995247072424006327715268521424423461840656985\"\n ; \"13012115310019421859484865413402512912208022868124085927375736053832542569552\"\n |]\n ; [| \"33073055720188060063004545324174039863351833928493376423022587630016341635891\"\n ; \"76584254259783109527449313057522305759653397147785066495263227868665161219779\"\n ; \"38531270223194009551634352795926218399266465064491096474482575354468954922673\"\n |]\n ; [| \"90100362566645034035707547984589905559141359276359522681964816611161474672115\"\n ; \"93014643079204629081291124987233004565276697190519877698472422015954982964601\"\n ; \"110916697765188052223435628742886773389228694903593626715469113528434066764534\"\n |]\n ; [| \"114725280711584666069398481856753837363052938587178775403749719257369626174299\"\n ; \"32967950615819700839673854548770413755655613096921050182183649674389310060672\"\n ; \"106372438106855157117155417458821032302424106544646447353561892891697429919509\"\n |]\n ; [| \"41996555998804572671679174634435850382099449308465335760130383677478780889948\"\n ; \"105999190358126224751922865919841547624707481487885223948004296548330504340556\"\n ; \"16636528128134911466622907961467317982179835733058354229921170933476186200761\"\n |]\n ; [| \"43468498537738045222256870515315985487110433728199201952445121047095648527840\"\n ; \"102272887089258604970815589009009162752025146641624347901234381428987386153285\"\n ; \"797386830910520008361185815477523544664694040635544500916993469578452189812\"\n |]\n ; [| \"96744926314199156321023598425708516126928808801578082649702497034531770517808\"\n ; \"99066250188188051206024031106640566584616407903813704153928240609169764005797\"\n ; \"101012485188852469291356197079506861083321680470016268483997462932491691773708\"\n |]\n ; [| \"49614555470963378761214277525336169174318331863453657910575217035316990252780\"\n ; \"94532874466332578813348267802784511494491757628599627802933242637211676358456\"\n ; \"60376163781951477822973950330025689966951914888122503797194554488987660570913\"\n |]\n ; [| \"99934768696780030317676638063039209891456597783633841250810260768328701786300\"\n ; \"71861378641802240356627336242725340978135703736568776865558429280585792121426\"\n ; \"84446994028646761779912629176051455275041688583492300440129402381138226185369\"\n |]\n ; [| \"18317002472599225949038448120242542829985613745531554876060436499109578301758\"\n ; \"23001721954642810524358122249469196372443463625490878969385130364780514025259\"\n ; \"49037245410934285111914043557449391103989331168177809387278571893536129709378\"\n |]\n ; [| \"65792050828386571136875573680568197513273253001530588336285451691348906024460\"\n ; \"12956514709922286639520985225111137950302442378466870763868693820049405409474\"\n ; \"38025781500219940187723501911749158551479941535921061459281014661810772473038\"\n |]\n ; [| \"98610017124283789125637190759729078315864881693957982200427567103302362453196\"\n ; \"42724178943656779288650125468921272883324869492775989038952508393082565227450\"\n ; \"99514360136104778310983460863480701661882652836741972684579325226086664343913\"\n |]\n ; [| \"111234788248236327826382691076985300771418365594838017963216100441270435887017\"\n ; \"35290532009451633157074005614742321966918220860237810056920944192222599040501\"\n ; \"72172784027306769601458922728374293130025170844011739475076742090414769211169\"\n |]\n ; [| \"61384388429666858375759167984149961873566898632022783479711533101905095026411\"\n ; \"8194273390415023152581060020119881338779571723515253104919314696738194355344\"\n ; \"80659234466772556847544129237154202226081525079070598707001193889658539631883\"\n |]\n ; [| \"62157670692624367146830864246105810519941474190553952682719433471854134465138\"\n ; \"74851302400382275482762496406028988868219592716510355166137061257664688666219\"\n ; \"16881796086836744646703159464114164393240695449455598565494759189917589453976\"\n |]\n ; [| \"42460477269659081546432152357644086326197211166562674408623141905226706277595\"\n ; \"81063688725529281621596607500748519671655516257039992655745871437369181665242\"\n ; \"51403113216244137057466948399908740878535656059933892843818689317660325080213\"\n |]\n ; [| \"49001998791770520786679099472805193463531142479298200795569326894791589887035\"\n ; \"42684462014557597494725933597359625461226399711783671410492942446635214257509\"\n ; \"106420886277092880545929306533089566775810130555230702838917980421765786292693\"\n |]\n ; [| \"110523958037212353696746219917157237679515245560578307171595792811566554384451\"\n ; \"56399709802930804752950401483879725014794413557467977624037632281590440364765\"\n ; \"100108862073771478435824578087801736413858177140360408436521717282600830155374\"\n |]\n ; [| \"59041409790855290045250456089216312297230856546920761548978870779493926213674\"\n ; \"13735945315945382005247895569035266667172550063549145646185577935658666385507\"\n ; \"16846296242516834547231537358954027537902709068158411294345086281698311539718\"\n |]\n ; [| \"114970774262524353875592617323889610576992844847433725376114488262076142213525\"\n ; \"17896661983150937411004047429485556264820315976705642986609974816436222162633\"\n ; \"115573362005053049429141251153085446935774781295666612354309246218946442750706\"\n |]\n ; [| \"85575265064375003235737272215445285540001719469558026661845214249857169530994\"\n ; \"87501751332871186792668480006319719164949448258731670359536302677279100637346\"\n ; \"105775909055063540416087237151517389942637625317333843436738223226977225420379\"\n |]\n ; [| \"110886009455283422981396854898481256559291311408679418842391298005253375700608\"\n ; \"95342257228100720685556647789433478371609336135456255803583405713563597933074\"\n ; \"2733591517253510124338232417535938539627593736745105875672348998709544742241\"\n |]\n ; [| \"32685479117496505057951010536248024091461630564950845696581129158987138920098\"\n ; \"96139836598015371513111133071481139035733083963976340622322043979088723982681\"\n ; \"16990606351055720221300633612533434675038905235719867684891402550154692840579\"\n |]\n ; [| \"13886834869596827027283068322204563244577723967928602405785473534631482228259\"\n ; \"81034769645830807786559566591578132114590768431721148809270219480247445931316\"\n ; \"26780635035984131258327079447673207266040002451512601352288859614294714150612\"\n |]\n ; [| \"72820784976920576285217524394309841044157743334874310886804718206719618858662\"\n ; \"84276722913141806246805569560426345961854221390421557310593118606084442633714\"\n ; \"42573817497593319926701003355299929070203785007821783512454795971915573843634\"\n |]\n ; [| \"41660041627266397279909712983288860313881442148611073178272756605107913521726\"\n ; \"7198246770791404776745997973411401046335399072925979346193035999274650139809\"\n ; \"91576025129588718283317000330880100309465430116820675850311277329602716166005\"\n |]\n ; [| \"30488483928716649313242898509172476460161184318124511942476380904233730958564\"\n ; \"35346040517569327255933130090945133067049088493975862969006023114275649329148\"\n ; \"59803015801166721680239913449555176591725421041660016242103441987856441941533\"\n |]\n ; [| \"17395049232451382970906883167116397657891664802601579276725674512534883408665\"\n ; \"96892830538146451450007413348096295684782382701592949711753407054447667361829\"\n ; \"46725583995795907014628330473921842919957418641665482351238505922983315675600\"\n |]\n ; [| \"20556719902345568138970735755829852608784985449829745172855204153387982836579\"\n ; \"17130405757403641097651484965062131526367059595476924144885570325828777794585\"\n ; \"99651763337265056372826178960800950053231370129318394703153246147873057668256\"\n |]\n ; [| \"17814517977679061356584950826520510701145481336316888282105225134451035883368\"\n ; \"62116749577126511600138536864540326578096290025961229483071769130930103978622\"\n ; \"68057799973217998063838402481530957249181669394905338807621317159743376777292\"\n |]\n ; [| \"26100793478962260035181580648528031417033872324944615961986573818448125345450\"\n ; \"26507891451149179196332605230084404371370204632884553105363087566061809624465\"\n ; \"55607174697006979796477169324630939518573410736589826596210132996613779221405\"\n |]\n ; [| \"75098549092668095590746032937529532494350222003700838962461867948806312867882\"\n ; \"62901674712278062473767645982006145910793625009149846534629441949336033280610\"\n ; \"5918385816682866756860679567405784562483373873565987668410277610868983146285\"\n |]\n ; [| \"99232460916208710346946062875203578399818909925477280432427620267031292402265\"\n ; \"115165948144292852122635634954139515297086369356811820254801384608988902457684\"\n ; \"39462036389170488019054739441325823641943062254145671230029238830857274014332\"\n |]\n ; [| \"109723826013507458840008311671051963282645213933956581735587227292458581212170\"\n ; \"88295699560808238817850908733435797366622278897489038929647807463406234520052\"\n ; \"20306380368695786945008272690438693745796297843799468268993907772341096948885\"\n |]\n ; [| \"39988356032524455736714109463355738665746339590560108227920970859248126609155\"\n ; \"47372836588594871116561451142702593094337405740661755511614125456886719840333\"\n ; \"42727075822142544969304941778878121065758237932060280070908539158139079888683\"\n |]\n ; [| \"115695172202592006925180721060969710051274632819849770440984261650964182295350\"\n ; \"41198034356969673080518030958715740186484860381424802035929938277103521577731\"\n ; \"115380378505550001583545282887589851179279565072664241489053445702744491234750\"\n |]\n ; [| \"56074680442485705900559544809779144521596408129059458559681779642734476672579\"\n ; \"54187206076706271120400668422875039791522899135281309004702779376007885441827\"\n ; \"100760509008368123701304764217450368711018785408289674422092070202193042774995\"\n |]\n ; [| \"2622643323130765702269424224791233611920515499144047449633123689743564676648\"\n ; \"95487289650450707799373930173349121410704227885014701702619711048222666102791\"\n ; \"94943953462630479470879050547964792684799160133612590505176816568790562776928\"\n |]\n |]\n }\n\nlet params_Bn382_p =\n { Params.mds =\n [| [| \"4926718831512540855203478495979679874185641835428705237807701341316303469093728860979847281433445543762468419547411\"\n ; \"4453596550915421838691584449484083455887331059810907256950733279540412430443020452528503585415545381600691692720802\"\n ; \"1809585458879543727351605930307281128231661313471183867681242998028598391382436278589655704222701087043779610899776\"\n |]\n ; [| \"3780881913608981191949291171826187563049531728010823449829977324390598960444713739971716972221840264885560113043153\"\n ; \"2776232227357305515637478180339794495756715372405744816056109665788926102619439001152349187314657683550310562099867\"\n ; \"5103043266714397927073209822516498302262227174566336138856687248083295588845596823903140201767618523431001452833199\"\n |]\n ; [| \"2159355678817062797712812554732125404698639502388517586006300841333631216487588790808135492514630783259920881851018\"\n ; \"3193464442349738376799117666463048091278737759406985595335727474699041234966227606028409475413066859111860974240541\"\n ; \"3068849848776138129466484826306219095394321880438971409892892215677003762666783452446184790715435684915272918256552\"\n |]\n |]\n ; round_constants =\n [| [| \"78119860594733808983474265082430117124674905785489385612351809573030163625517\"\n ; \"41917899842730241418346215913324270532073353586134123463219061327941260175271\"\n ; \"74594641694171623328644944059182600919855574964222988275913344198970402906473\"\n |]\n ; [| \"96215759378377024990520153908983544755208851791126218239402755616994541522004\"\n ; \"64070601581278917442704840630680311036021557676765751754522901046069205253111\"\n ; \"112123228532462696722378911494343451272980413618911326680094528285518792872677\"\n |]\n ; [| \"84572244072021308337360477634782636535511175281144388234379224309078196768262\"\n ; \"45201095631123410354816854701250642083197167601967427301389500806815426216645\"\n ; \"23419302413627434057960523568681421397183896397903197013759822219271473949448\"\n |]\n ; [| \"63220724218126871510891512179599337793645245415246618202146262033908228783613\"\n ; \"67900966560828272306360950341997532094196196655192755442359232962244590070115\"\n ; \"56382132371728071364028077587343004835658613510701494793375685201885283260755\"\n |]\n ; [| \"80317852656339951095312898663286716255545986714650554749917139819628941702909\"\n ; \"110977183257428423540294096816813859894739618561444416996538397449475628658639\"\n ; \"25195781166503180938390820610484311038421647727795615447439501669639084690800\"\n |]\n ; [| \"108664438541952156416331885221418851366456449596370568350972106298760717710264\"\n ; \"17649294376560630922417546944777537620537408190408066211453084495108565929366\"\n ; \"95236435002924956844837407534938226368352771792739587594037613075251645052212\"\n |]\n ; [| \"43150472723422600689013423057826322506171125106415122422656432973040257528684\"\n ; \"77355911134402286174761911573353899889837132781450260391484427670446862700214\"\n ; \"8690728446593494554377477996892461126663797704587025899930929227865493269824\"\n |]\n ; [| \"109175231986025180460846040078523879514558355792739714578031829643740609438879\"\n ; \"64844253590731404811389281562033735091759746904073461140427127388042062490899\"\n ; \"43237071281695629980341250188156848876595681601471702180515324064382368960951\"\n |]\n ; [| \"2704440995725305992776846806711930876273040749514871232837487081811513368296\"\n ; \"66806779110388532101035294912010606217442229808784290357894909707660045365269\"\n ; \"25541187612624070470730890200174075890643652797181103367956318438136878170352\"\n |]\n ; [| \"89300613074831725721350087269266903129165086877175223066581882601662278010666\"\n ; \"36824076981866281177052433916337787028520068526782493484076995129329938182524\"\n ; \"68880449342008497744225106025198236600142055580985632884415488154606462819445\"\n |]\n ; [| \"68556888546596545408135887526582256648006271867854316538090068824142539400698\"\n ; \"111379753250206255125320675615931203940253796355491142745969887430259465111569\"\n ; \"101469186248899356416491489235841069222521093012237305521090058066171355672289\"\n |]\n ; [| \"87819793263125973233157093200229218382531712066157093399606059493857616731410\"\n ; \"11055386921184594780372263378420826851562920740321950336882051897732501262543\"\n ; \"111945832089295501567161822264292548657346358707472584179854375613919325491249\"\n |]\n ; [| \"95630018375719472826904441325138673248990446382783206900295723762884876505178\"\n ; \"94833984285990985873155989049880754188702918168949640563745233736765833491756\"\n ; \"77578854197021606645372788474039811639438242484066959482386065023999206730771\"\n |]\n ; [| \"27799616729223271646690718201487403976485619375555391888533887467404804041014\"\n ; \"42616502170265664498961018686434252976977548128285781725227341660941880774718\"\n ; \"95884094505080541517768389956970969462501217028562326732054532092615835087122\"\n |]\n ; [| \"107531500891040898338150732759493933154418374543568088749403053559827078391994\"\n ; \"17316158269457914256007584527534747738658973027567786054549020564540952112346\"\n ; \"51624680144452294805663893795879183520785046924484587034566439599591446246116\"\n |]\n ; [| \"17698087730709566968258013675219881840614043344609152682517330801348583470562\"\n ; \"111925747861248746962567200879629070277886617811519137515553806421564944666811\"\n ; \"57148554624730554436721083599187229462914514696466218614205595953570212881615\"\n |]\n ; [| \"92002976914130835490768248031171915767210477082066266868807636677032557847243\"\n ; \"58807951133460826577955909810426403194149348045831674376120801431489918282349\"\n ; \"93581873597000319446791963913210464830992618681307774190204379970955657554666\"\n |]\n ; [| \"46734218328816451470118898692627799522173317355773128175090189234250221977353\"\n ; \"12565476532112137808460978474958060441970941349010371267577877299656634907765\"\n ; \"54284813390357004119220859882274190703294683700710665367594256039714984623777\"\n |]\n ; [| \"92046423253202913319296401122133532555630886766139313429473309376931112550800\"\n ; \"15095408309586969968044201398966210357547906905122453139947200130015688526573\"\n ; \"76483858663950700865536712701042004661599554591777656961315837882956812689085\"\n |]\n ; [| \"37793510665854947576525000802927849210746292216845467892500370179796223909690\"\n ; \"84954934523349224038508216623641462700694917568481430996824733443763638196693\"\n ; \"81116649005575743294029244339854405387811058321603450814032274416116019472096\"\n |]\n ; [| \"28313841745366368076212445154871968929195537523489133192784916081223753077949\"\n ; \"17307716513182567320564075539526480893558355908652993731441220999922946005081\"\n ; \"63148771170858502457695904149048034226689843239981287723002468627916462842625\"\n |]\n ; [| \"14724939606645168531546334343600232253284320276481307778787768813885931648950\"\n ; \"4684996260500305121238590806572541849891754312215139285622888510153705963000\"\n ; \"63682763879011752475568476861367553456179860221069473817315669232908763409259\"\n |]\n ; [| \"47776179656187399887062096850541192680190218704758942820514561435612697426715\"\n ; \"42017618175533328439486588850450028995049195954365035474995309904751824054581\"\n ; \"39169739448648613641258102792190571431737464735838931948313779997907435855102\"\n |]\n ; [| \"37525991163523321662699819448962967746703579202577998445997476955224037837979\"\n ; \"67759173441312327668891803222741396828094999063019622301649400178376863820046\"\n ; \"23041132473771739182071223620364590606653086905326129708428084432335332411661\"\n |]\n ; [| \"77778894465896892167598828497939467663479992533052348475467490972714790615441\"\n ; \"20821227542001445006023346122554483849065713580779858784021328359824080462519\"\n ; \"47217242463811495777303984778653549585537750303740616187093690846833142245039\"\n |]\n ; [| \"42826871300142174590405062658305130206548405024021455479047593769907201224399\"\n ; \"8850081254230234130482383430433176873344633494243110112848647064077741649744\"\n ; \"1819639941546179668398979507053724449231350395599747300736218202072168364980\"\n |]\n ; [| \"21219092773772827667886204262476112905428217689703647484316763603169544906986\"\n ; \"35036730416829620763976972888493029852952403098232484869595671405553221294746\"\n ; \"35487050610902505183766069070898136230610758743267437784506875078109148276407\"\n |]\n ; [| \"62560813042054697786535634928462520639989597995560367915904328183428481834648\"\n ; \"112205708104999693686115882430330200785082630634036862526175634736046083007596\"\n ; \"109084747126382177842005646092084591250172358815974554434100716599544229364287\"\n |]\n ; [| \"63740884245554590221521941789197287379354311786803164550686696984009448418872\"\n ; \"58779928727649398559174292364061339806256990859940639552881479945324304668069\"\n ; \"20614241966717622390914334053622572167995367802051836931454426877074875942253\"\n |]\n ; [| \"41621411615229558798583846330993607380846912281220890296433013153854774573504\"\n ; \"20530621481603446397085836296967350209890164029268319619481535419199429275412\"\n ; \"99914592017824500091708233310179001698739309503141229228952777264267035511439\"\n |]\n ; [| \"9497854724940806346676139162466690071592872530638144182764466319052293463165\"\n ; \"7549205476288061047040852944548942878112823732145584918107208536541712726277\"\n ; \"30898915730863004722886730649661235919513859500318540107289237568593577554645\"\n |]\n ; [| \"22697249754607337581727259086359907309326296469394183645633378468855554942575\"\n ; \"72771100592475003378969523202338527077495914171905204927442739996373603143216\"\n ; \"84509851995167666169868678185342549983568150803791023831909660012392522615426\"\n |]\n ; [| \"36601166816771446688370845080961015541431660429079281633209182736773260407536\"\n ; \"19555759172327736128240171000715903945570888389700763573790859521156095228287\"\n ; \"82844424532983875300577689116331373756526403900340445449185486212503235782229\"\n |]\n ; [| \"40833119728631657038301474658571416779079199343770917422783737091842927892625\"\n ; \"68922359316478675184342553333343300163568193749010867527082189412217781430311\"\n ; \"91516472400306837063911995909475588197278444979245081960087094196120449075833\"\n |]\n ; [| \"21304716730402869084944080869903443431235336418077153507261240151959530377653\"\n ; \"106551237424345741137570659736231801772439680702621554106791455938098031620471\"\n ; \"104392597313271110590927764888829150750277653499050463757708547416538850601163\"\n |]\n ; [| \"16907937154215020261110468963982390213438461071031811101554056252102505124726\"\n ; \"23183141532591565112222057191012766855134687114504142337903677590107533245206\"\n ; \"96725517880771645283128624101279195709280644465575982072053504613644938879246\"\n |]\n ; [| \"84556507395241990875812091718422997082915179448604219593521819129312718969906\"\n ; \"100646525819453650494590571397259055384579251368754179569362740802641255820576\"\n ; \"50316555026297423940834952362583934362215303629664094841692233643882339493043\"\n |]\n ; [| \"77363534410783423412630139556441807611393685349073113946053979350631229049878\"\n ; \"54905073434434959485893381841839373267383966385817882684657825178181863944371\"\n ; \"110016011331508430102821620395154714608084938556260733745010992614542669817451\"\n |]\n ; [| \"52040139270046094723964229965823921970388683619580004402190656733318120479093\"\n ; \"495546618036723566920914648951352373868059898268055487677897567226892784967\"\n ; \"2528292188392170914010448139211586215817069915670005292953294092269979070980\"\n |]\n ; [| \"36842840134449713950999812540127591123318806680559982063089906871196226758113\"\n ; \"112314504940338253416202605695368724580971154020421327790335219348068041886245\"\n ; \"51653712314537383078368021242008468828072907802445786549975419682333073143987\"\n |]\n ; [| \"27179054135131403873076215577181710354069071017096145081169516607932870071868\"\n ; \"93264325401956094073193527739715293258814405715822269809955952297346626219055\"\n ; \"75336695567377817226085396912086909560962335091652231383627608374094112503635\"\n |]\n ; [| \"42536477740858058164730818130587261149155820207748153094480456895727052896150\"\n ; \"45297707210835305388426482743535401273114010430724989418303851665124351001731\"\n ; \"28263543670875633354854018109712021307749750769690268127459707194207091046997\"\n |]\n ; [| \"40809484989590048522440442751358616303471639779690405026946053699354967624695\"\n ; \"51589519265418587649124543325590658874910911006853535317847189422703251228717\"\n ; \"73459936981642894525955700397592343967482441686326322443228255968694436816673\"\n |]\n ; [| \"87298777232393189731949522229743081866971743270330772607820990832164835738703\"\n ; \"23328534428894097247289332213412175849711532153957647506361455182140450133738\"\n ; \"51807348624578081645565456865744011145427112815128832643950401419083788780028\"\n |]\n ; [| \"62003629107726929116302469001779155132709624140360743951550189738290955064278\"\n ; \"109311858027068383034683875948676795998030610067675200794951297783857157095297\"\n ; \"2085588517087605436136379278738013214233743532079287631079316773925068862732\"\n |]\n ; [| \"9513664655545306376987968929852776467090105742275395185801917554996684570014\"\n ; \"91103467624252027317764670613760419385374004736848754250298970998535616755199\"\n ; \"39500000352127197728032684892425352332461947514533659433380855624868454474623\"\n |]\n ; [| \"75175260486328125629270378861920310368403601365269629778076078053196928460032\"\n ; \"56923881233337629517433981230592855430598464522180216309153828833928801967999\"\n ; \"20981004218820236011689230170078809973840534961691702543937445515733151438851\"\n |]\n ; [| \"73175203586574092105626230272409823792532423094740797516874387144340145138310\"\n ; \"45186992623753580336479418079070607289916086076906975839720879934817804495460\"\n ; \"96084125187548549854900995260973117424750860440064269432639526863495781270780\"\n |]\n ; [| \"53530507055579550362119832302266967544350117012822630711681736383163390079758\"\n ; \"24484677147631687826970700541691541659768738376645174313438582486313045584324\"\n ; \"99915577684197600584703320523786830947563355229812244982453188909016758004559\"\n |]\n ; [| \"73101441225016284181831039876112223954723401962484828024235461623078642642543\"\n ; \"57434882751817972247799186935032874577110609253567900895922769490031350316077\"\n ; \"73837027842771758252813592393497967898989365991569964687267097531033696791279\"\n |]\n ; [| \"8605586894544301092657394167906502995894014247978769840701086209902531650480\"\n ; \"8900145888985471928279988821934068156350024482295663273746853580585203659117\"\n ; \"76135096553134713603675854628257365311062159747768423095496501607463292188538\"\n |]\n ; [| \"77171330825793179961995032914169307990870372845116475229799680315757656196917\"\n ; \"17848856881287888035559207919717746181941756011012420474955535369227552058196\"\n ; \"85285874363861776466393873037603415962379724376693393356387850868454172343232\"\n |]\n ; [| \"34752820629818556525384193423224856177797869338806846583786365186093662702640\"\n ; \"61923000676912108769617866333091286856690233713839015114991682235541391477568\"\n ; \"105437294734850952102877811210027981435959945375626993201685688489494148805743\"\n |]\n ; [| \"37290995592003925978648162243724313056459187397796644444696543576625771108605\"\n ; \"95156804644588215637074780475000089186488581067063625121782605228712011438608\"\n ; \"111838568780358037910894878973007194619694503969424695895292495245099084158661\"\n |]\n ; [| \"114085830904535970531084512281741806703564152148485737755668141105183488387818\"\n ; \"27151558900245092306095370161852910074651784795680581223133179808714387525774\"\n ; \"17782273009863750298483603933610732253879825505411230932533407287574651036994\"\n |]\n ; [| \"72422039981423868898452547270453235353957783762070405836433674391957844064693\"\n ; \"23635533014670380888810554717349513178608213369182061967678315431422272271569\"\n ; \"59402711345784829746976504521969665104448536964686633342173372133388407225657\"\n |]\n ; [| \"92466806354851856571355165199186633833982438153589406912422876269386887264049\"\n ; \"9877617390649361889067963484857474874019563445507538784053773745685676317984\"\n ; \"74572672075215609948567780829046067891251792522874268554421916351892498078660\"\n |]\n ; [| \"36552683919656073147232029802086505741533932059491323529262718897271096098319\"\n ; \"28895802628889660292449057575076739706255701997961890168977786141673053679086\"\n ; \"9907785227545441866241924986174555965766785257012652276622736289520175209842\"\n |]\n ; [| \"29485332368911768475893015509537099136952860812699472744021496513325455451738\"\n ; \"39797358509842904932758894391536601623578260107859540160156599261695054175926\"\n ; \"107452259847197252302434271220963395311929879689430847107159618578878468880668\"\n |]\n ; [| \"24664696127391052816688570667643612077905959307658722811431436096677076924072\"\n ; \"52507998665481228083044018390203046881916651866666590845312076558622705190465\"\n ; \"69935204723497468327083545368078327534124772251842862926136799697299751835029\"\n |]\n ; [| \"372963191403207230700085823960930798511810380777302780932220121859190714585\"\n ; \"111366606704792806959979488772421759791592911629496627207620326636856656861526\"\n ; \"39677360977437767398760288273614298000827429534821360419179023551087917983124\"\n |]\n ; [| \"64601494076430280535646633059501605929914790764963584476403188233843589027560\"\n ; \"34156315098453482946438495274327282067376463494057110043754782161473776373661\"\n ; \"73687667961196401152630755105477060056162632832680813161120412165243753726816\"\n |]\n ; [| \"37808689229279738382348785246837013002280781984053433359148018860351753688153\"\n ; \"26778210635417272626362658500217995247072424006327715268521424423461840656985\"\n ; \"13012115310019421859484865413402512912208022868124085927375736053832542569552\"\n |]\n ; [| \"33073055720188060063004545324174039863351833928493376423022587630016341635891\"\n ; \"76584254259783109527449313057522305759653397147785066495263227868665161219779\"\n ; \"38531270223194009551634352795926218399266465064491096474482575354468954922673\"\n |]\n ; [| \"90100362566645034035707547984589905559141359276359522681964816611161474672115\"\n ; \"93014643079204629081291124987233004565276697190519877698472422015954982964601\"\n ; \"110916697765188052223435628742886773389228694903593626715469113528434066764534\"\n |]\n ; [| \"114725280711584666069398481856753837363052938587178775403749719257369626174299\"\n ; \"32967950615819700839673854548770413755655613096921050182183649674389310060672\"\n ; \"106372438106855157117155417458821032302424106544646447353561892891697429919509\"\n |]\n ; [| \"41996555998804572671679174634435850382099449308465335760130383677478780889948\"\n ; \"105999190358126224751922865919841547624707481487885223948004296548330504340556\"\n ; \"16636528128134911466622907961467317982179835733058354229921170933476186200761\"\n |]\n ; [| \"43468498537738045222256870515315985487110433728199201952445121047095648527840\"\n ; \"102272887089258604970815589009009162752025146641624347901234381428987386153285\"\n ; \"797386830910520008361185815477523544664694040635544500916993469578452189812\"\n |]\n ; [| \"96744926314199156321023598425708516126928808801578082649702497034531770517808\"\n ; \"99066250188188051206024031106640566584616407903813704153928240609169764005797\"\n ; \"101012485188852469291356197079506861083321680470016268483997462932491691773708\"\n |]\n ; [| \"49614555470963378761214277525336169174318331863453657910575217035316990252780\"\n ; \"94532874466332578813348267802784511494491757628599627802933242637211676358456\"\n ; \"60376163781951477822973950330025689966951914888122503797194554488987660570913\"\n |]\n ; [| \"99934768696780030317676638063039209891456597783633841250810260768328701786300\"\n ; \"71861378641802240356627336242725340978135703736568776865558429280585792121426\"\n ; \"84446994028646761779912629176051455275041688583492300440129402381138226185369\"\n |]\n ; [| \"18317002472599225949038448120242542829985613745531554876060436499109578301758\"\n ; \"23001721954642810524358122249469196372443463625490878969385130364780514025259\"\n ; \"49037245410934285111914043557449391103989331168177809387278571893536129709378\"\n |]\n ; [| \"65792050828386571136875573680568197513273253001530588336285451691348906024460\"\n ; \"12956514709922286639520985225111137950302442378466870763868693820049405409474\"\n ; \"38025781500219940187723501911749158551479941535921061459281014661810772473038\"\n |]\n ; [| \"98610017124283789125637190759729078315864881693957982200427567103302362453196\"\n ; \"42724178943656779288650125468921272883324869492775989038952508393082565227450\"\n ; \"99514360136104778310983460863480701661882652836741972684579325226086664343913\"\n |]\n ; [| \"111234788248236327826382691076985300771418365594838017963216100441270435887017\"\n ; \"35290532009451633157074005614742321966918220860237810056920944192222599040501\"\n ; \"72172784027306769601458922728374293130025170844011739475076742090414769211169\"\n |]\n ; [| \"61384388429666858375759167984149961873566898632022783479711533101905095026411\"\n ; \"8194273390415023152581060020119881338779571723515253104919314696738194355344\"\n ; \"80659234466772556847544129237154202226081525079070598707001193889658539631883\"\n |]\n ; [| \"62157670692624367146830864246105810519941474190553952682719433471854134465138\"\n ; \"74851302400382275482762496406028988868219592716510355166137061257664688666219\"\n ; \"16881796086836744646703159464114164393240695449455598565494759189917589453976\"\n |]\n ; [| \"42460477269659081546432152357644086326197211166562674408623141905226706277595\"\n ; \"81063688725529281621596607500748519671655516257039992655745871437369181665242\"\n ; \"51403113216244137057466948399908740878535656059933892843818689317660325080213\"\n |]\n ; [| \"49001998791770520786679099472805193463531142479298200795569326894791589887035\"\n ; \"42684462014557597494725933597359625461226399711783671410492942446635214257509\"\n ; \"106420886277092880545929306533089566775810130555230702838917980421765786292693\"\n |]\n ; [| \"110523958037212353696746219917157237679515245560578307171595792811566554384451\"\n ; \"56399709802930804752950401483879725014794413557467977624037632281590440364765\"\n ; \"100108862073771478435824578087801736413858177140360408436521717282600830155374\"\n |]\n ; [| \"59041409790855290045250456089216312297230856546920761548978870779493926213674\"\n ; \"13735945315945382005247895569035266667172550063549145646185577935658666385507\"\n ; \"16846296242516834547231537358954027537902709068158411294345086281698311539718\"\n |]\n ; [| \"114970774262524353875592617323889610576992844847433725376114488262076142213525\"\n ; \"17896661983150937411004047429485556264820315976705642986609974816436222162633\"\n ; \"115573362005053049429141251153085446935774781295666612354309246218946442750706\"\n |]\n ; [| \"85575265064375003235737272215445285540001719469558026661845214249857169530994\"\n ; \"87501751332871186792668480006319719164949448258731670359536302677279100637346\"\n ; \"105775909055063540416087237151517389942637625317333843436738223226977225420379\"\n |]\n ; [| \"110886009455283422981396854898481256559291311408679418842391298005253375700608\"\n ; \"95342257228100720685556647789433478371609336135456255803583405713563597933074\"\n ; \"2733591517253510124338232417535938539627593736745105875672348998709544742241\"\n |]\n ; [| \"32685479117496505057951010536248024091461630564950845696581129158987138920098\"\n ; \"96139836598015371513111133071481139035733083963976340622322043979088723982681\"\n ; \"16990606351055720221300633612533434675038905235719867684891402550154692840579\"\n |]\n ; [| \"13886834869596827027283068322204563244577723967928602405785473534631482228259\"\n ; \"81034769645830807786559566591578132114590768431721148809270219480247445931316\"\n ; \"26780635035984131258327079447673207266040002451512601352288859614294714150612\"\n |]\n ; [| \"72820784976920576285217524394309841044157743334874310886804718206719618858662\"\n ; \"84276722913141806246805569560426345961854221390421557310593118606084442633714\"\n ; \"42573817497593319926701003355299929070203785007821783512454795971915573843634\"\n |]\n ; [| \"41660041627266397279909712983288860313881442148611073178272756605107913521726\"\n ; \"7198246770791404776745997973411401046335399072925979346193035999274650139809\"\n ; \"91576025129588718283317000330880100309465430116820675850311277329602716166005\"\n |]\n ; [| \"30488483928716649313242898509172476460161184318124511942476380904233730958564\"\n ; \"35346040517569327255933130090945133067049088493975862969006023114275649329148\"\n ; \"59803015801166721680239913449555176591725421041660016242103441987856441941533\"\n |]\n ; [| \"17395049232451382970906883167116397657891664802601579276725674512534883408665\"\n ; \"96892830538146451450007413348096295684782382701592949711753407054447667361829\"\n ; \"46725583995795907014628330473921842919957418641665482351238505922983315675600\"\n |]\n ; [| \"20556719902345568138970735755829852608784985449829745172855204153387982836579\"\n ; \"17130405757403641097651484965062131526367059595476924144885570325828777794585\"\n ; \"99651763337265056372826178960800950053231370129318394703153246147873057668256\"\n |]\n ; [| \"17814517977679061356584950826520510701145481336316888282105225134451035883368\"\n ; \"62116749577126511600138536864540326578096290025961229483071769130930103978622\"\n ; \"68057799973217998063838402481530957249181669394905338807621317159743376777292\"\n |]\n ; [| \"26100793478962260035181580648528031417033872324944615961986573818448125345450\"\n ; \"26507891451149179196332605230084404371370204632884553105363087566061809624465\"\n ; \"55607174697006979796477169324630939518573410736589826596210132996613779221405\"\n |]\n ; [| \"75098549092668095590746032937529532494350222003700838962461867948806312867882\"\n ; \"62901674712278062473767645982006145910793625009149846534629441949336033280610\"\n ; \"5918385816682866756860679567405784562483373873565987668410277610868983146285\"\n |]\n ; [| \"99232460916208710346946062875203578399818909925477280432427620267031292402265\"\n ; \"115165948144292852122635634954139515297086369356811820254801384608988902457684\"\n ; \"39462036389170488019054739441325823641943062254145671230029238830857274014332\"\n |]\n ; [| \"109723826013507458840008311671051963282645213933956581735587227292458581212170\"\n ; \"88295699560808238817850908733435797366622278897489038929647807463406234520052\"\n ; \"20306380368695786945008272690438693745796297843799468268993907772341096948885\"\n |]\n ; [| \"39988356032524455736714109463355738665746339590560108227920970859248126609155\"\n ; \"47372836588594871116561451142702593094337405740661755511614125456886719840333\"\n ; \"42727075822142544969304941778878121065758237932060280070908539158139079888683\"\n |]\n ; [| \"115695172202592006925180721060969710051274632819849770440984261650964182295350\"\n ; \"41198034356969673080518030958715740186484860381424802035929938277103521577731\"\n ; \"115380378505550001583545282887589851179279565072664241489053445702744491234750\"\n |]\n ; [| \"56074680442485705900559544809779144521596408129059458559681779642734476672579\"\n ; \"54187206076706271120400668422875039791522899135281309004702779376007885441827\"\n ; \"100760509008368123701304764217450368711018785408289674422092070202193042774995\"\n |]\n ; [| \"2622643323130765702269424224791233611920515499144047449633123689743564676648\"\n ; \"95487289650450707799373930173349121410704227885014701702619711048222666102791\"\n ; \"94943953462630479470879050547964792684799160133612590505176816568790562776928\"\n |]\n |]\n }\n\nlet params_Bn382_q =\n { Params.mds =\n [| [| \"2663538809597650435844500745640128112500797729229320076136089551791530014683740176469459837095745057420024990698304\"\n ; \"3372673220977743741609068262704292488957271565700673274891426149291073445433316668667874458522247135736401556339737\"\n ; \"4702399048364054789745695060954166226249916683594965873315202085308155435886379283955080194729213218481069112754347\"\n |]\n ; [| \"2215778453553447259216822687321394545528815439827126692759606056122905656424424554076355712016973336681821219494537\"\n ; \"1284753801167450198664971157009572170099813485759371112881157467066929464161583508786486164543283350228782139803094\"\n ; \"1136441139974396511543268992916724168911879411721635269198331720240499757381302440272659128030869203409955304203115\"\n |]\n ; [| \"5295202322853619951220986804473857321275810243906349721146315070442772012272591642930885737122084843222525444659152\"\n ; \"2585574180998322214773500417577043354533137309395421285678021891228333612974808568921533701659765694493897008321886\"\n ; \"4327637570022845964174929847928171567054668769686956705326721990617716210727017530524703225454617877992054172811917\"\n |]\n |]\n ; round_constants =\n [| [| \"78119860594733808983474265082430117124674905785489385612351809573030163625517\"\n ; \"41917899842730241418346215913324270532073353586134123463219061327941260175271\"\n ; \"74594641694171623328644944059182600919855574964222988275913344198970402906473\"\n |]\n ; [| \"96215759378377024990520153908983544755208851791126218239402755616994541522004\"\n ; \"64070601581278917442704840630680311036021557676765751754522901046069205253111\"\n ; \"112123228532462696722378911494343451272980413618911326680094528285518792872677\"\n |]\n ; [| \"84572244072021308337360477634782636535511175281144388234379224309078196768262\"\n ; \"45201095631123410354816854701250642083197167601967427301389500806815426216645\"\n ; \"23419302413627434057960523568681421397183896397903197013759822219271473949448\"\n |]\n ; [| \"63220724218126871510891512179599337793645245415246618202146262033908228783613\"\n ; \"67900966560828272306360950341997532094196196655192755442359232962244590070115\"\n ; \"56382132371728071364028077587343004835658613510701494793375685201885283260755\"\n |]\n ; [| \"80317852656339951095312898663286716255545986714650554749917139819628941702909\"\n ; \"110977183257428423540294096816813859894739618561444416996538397449475628658639\"\n ; \"25195781166503180938390820610484311038421647727795615447439501669639084690800\"\n |]\n ; [| \"108664438541952156416331885221418851366456449596370568350972106298760717710264\"\n ; \"17649294376560630922417546944777537620537408190408066211453084495108565929366\"\n ; \"95236435002924956844837407534938226368352771792739587594037613075251645052212\"\n |]\n ; [| \"43150472723422600689013423057826322506171125106415122422656432973040257528684\"\n ; \"77355911134402286174761911573353899889837132781450260391484427670446862700214\"\n ; \"8690728446593494554377477996892461126663797704587025899930929227865493269824\"\n |]\n ; [| \"109175231986025180460846040078523879514558355792739714578031829643740609438879\"\n ; \"64844253590731404811389281562033735091759746904073461140427127388042062490899\"\n ; \"43237071281695629980341250188156848876595681601471702180515324064382368960951\"\n |]\n ; [| \"2704440995725305992776846806711930876273040749514871232837487081811513368296\"\n ; \"66806779110388532101035294912010606217442229808784290357894909707660045365269\"\n ; \"25541187612624070470730890200174075890643652797181103367956318438136878170352\"\n |]\n ; [| \"89300613074831725721350087269266903129165086877175223066581882601662278010666\"\n ; \"36824076981866281177052433916337787028520068526782493484076995129329938182524\"\n ; \"68880449342008497744225106025198236600142055580985632884415488154606462819445\"\n |]\n ; [| \"68556888546596545408135887526582256648006271867854316538090068824142539400698\"\n ; \"111379753250206255125320675615931203940253796355491142745969887430259465111569\"\n ; \"101469186248899356416491489235841069222521093012237305521090058066171355672289\"\n |]\n ; [| \"87819793263125973233157093200229218382531712066157093399606059493857616731410\"\n ; \"11055386921184594780372263378420826851562920740321950336882051897732501262543\"\n ; \"111945832089295501567161822264292548657346358707472584179854375613919325491249\"\n |]\n ; [| \"95630018375719472826904441325138673248990446382783206900295723762884876505178\"\n ; \"94833984285990985873155989049880754188702918168949640563745233736765833491756\"\n ; \"77578854197021606645372788474039811639438242484066959482386065023999206730771\"\n |]\n ; [| \"27799616729223271646690718201487403976485619375555391888533887467404804041014\"\n ; \"42616502170265664498961018686434252976977548128285781725227341660941880774718\"\n ; \"95884094505080541517768389956970969462501217028562326732054532092615835087122\"\n |]\n ; [| \"107531500891040898338150732759493933154418374543568088749403053559827078391994\"\n ; \"17316158269457914256007584527534747738658973027567786054549020564540952112346\"\n ; \"51624680144452294805663893795879183520785046924484587034566439599591446246116\"\n |]\n ; [| \"17698087730709566968258013675219881840614043344609152682517330801348583470562\"\n ; \"111925747861248746962567200879629070277886617811519137515553806421564944666811\"\n ; \"57148554624730554436721083599187229462914514696466218614205595953570212881615\"\n |]\n ; [| \"92002976914130835490768248031171915767210477082066266868807636677032557847243\"\n ; \"58807951133460826577955909810426403194149348045831674376120801431489918282349\"\n ; \"93581873597000319446791963913210464830992618681307774190204379970955657554666\"\n |]\n ; [| \"46734218328816451470118898692627799522173317355773128175090189234250221977353\"\n ; \"12565476532112137808460978474958060441970941349010371267577877299656634907765\"\n ; \"54284813390357004119220859882274190703294683700710665367594256039714984623777\"\n |]\n ; [| \"92046423253202913319296401122133532555630886766139313429473309376931112550800\"\n ; \"15095408309586969968044201398966210357547906905122453139947200130015688526573\"\n ; \"76483858663950700865536712701042004661599554591777656961315837882956812689085\"\n |]\n ; [| \"37793510665854947576525000802927849210746292216845467892500370179796223909690\"\n ; \"84954934523349224038508216623641462700694917568481430996824733443763638196693\"\n ; \"81116649005575743294029244339854405387811058321603450814032274416116019472096\"\n |]\n ; [| \"28313841745366368076212445154871968929195537523489133192784916081223753077949\"\n ; \"17307716513182567320564075539526480893558355908652993731441220999922946005081\"\n ; \"63148771170858502457695904149048034226689843239981287723002468627916462842625\"\n |]\n ; [| \"14724939606645168531546334343600232253284320276481307778787768813885931648950\"\n ; \"4684996260500305121238590806572541849891754312215139285622888510153705963000\"\n ; \"63682763879011752475568476861367553456179860221069473817315669232908763409259\"\n |]\n ; [| \"47776179656187399887062096850541192680190218704758942820514561435612697426715\"\n ; \"42017618175533328439486588850450028995049195954365035474995309904751824054581\"\n ; \"39169739448648613641258102792190571431737464735838931948313779997907435855102\"\n |]\n ; [| \"37525991163523321662699819448962967746703579202577998445997476955224037837979\"\n ; \"67759173441312327668891803222741396828094999063019622301649400178376863820046\"\n ; \"23041132473771739182071223620364590606653086905326129708428084432335332411661\"\n |]\n ; [| \"77778894465896892167598828497939467663479992533052348475467490972714790615441\"\n ; \"20821227542001445006023346122554483849065713580779858784021328359824080462519\"\n ; \"47217242463811495777303984778653549585537750303740616187093690846833142245039\"\n |]\n ; [| \"42826871300142174590405062658305130206548405024021455479047593769907201224399\"\n ; \"8850081254230234130482383430433176873344633494243110112848647064077741649744\"\n ; \"1819639941546179668398979507053724449231350395599747300736218202072168364980\"\n |]\n ; [| \"21219092773772827667886204262476112905428217689703647484316763603169544906986\"\n ; \"35036730416829620763976972888493029852952403098232484869595671405553221294746\"\n ; \"35487050610902505183766069070898136230610758743267437784506875078109148276407\"\n |]\n ; [| \"62560813042054697786535634928462520639989597995560367915904328183428481834648\"\n ; \"112205708104999693686115882430330200785082630634036862526175634736046083007596\"\n ; \"109084747126382177842005646092084591250172358815974554434100716599544229364287\"\n |]\n ; [| \"63740884245554590221521941789197287379354311786803164550686696984009448418872\"\n ; \"58779928727649398559174292364061339806256990859940639552881479945324304668069\"\n ; \"20614241966717622390914334053622572167995367802051836931454426877074875942253\"\n |]\n ; [| \"41621411615229558798583846330993607380846912281220890296433013153854774573504\"\n ; \"20530621481603446397085836296967350209890164029268319619481535419199429275412\"\n ; \"99914592017824500091708233310179001698739309503141229228952777264267035511439\"\n |]\n ; [| \"9497854724940806346676139162466690071592872530638144182764466319052293463165\"\n ; \"7549205476288061047040852944548942878112823732145584918107208536541712726277\"\n ; \"30898915730863004722886730649661235919513859500318540107289237568593577554645\"\n |]\n ; [| \"22697249754607337581727259086359907309326296469394183645633378468855554942575\"\n ; \"72771100592475003378969523202338527077495914171905204927442739996373603143216\"\n ; \"84509851995167666169868678185342549983568150803791023831909660012392522615426\"\n |]\n ; [| \"36601166816771446688370845080961015541431660429079281633209182736773260407536\"\n ; \"19555759172327736128240171000715903945570888389700763573790859521156095228287\"\n ; \"82844424532983875300577689116331373756526403900340445449185486212503235782229\"\n |]\n ; [| \"40833119728631657038301474658571416779079199343770917422783737091842927892625\"\n ; \"68922359316478675184342553333343300163568193749010867527082189412217781430311\"\n ; \"91516472400306837063911995909475588197278444979245081960087094196120449075833\"\n |]\n ; [| \"21304716730402869084944080869903443431235336418077153507261240151959530377653\"\n ; \"106551237424345741137570659736231801772439680702621554106791455938098031620471\"\n ; \"104392597313271110590927764888829150750277653499050463757708547416538850601163\"\n |]\n ; [| \"16907937154215020261110468963982390213438461071031811101554056252102505124726\"\n ; \"23183141532591565112222057191012766855134687114504142337903677590107533245206\"\n ; \"96725517880771645283128624101279195709280644465575982072053504613644938879246\"\n |]\n ; [| \"84556507395241990875812091718422997082915179448604219593521819129312718969906\"\n ; \"100646525819453650494590571397259055384579251368754179569362740802641255820576\"\n ; \"50316555026297423940834952362583934362215303629664094841692233643882339493043\"\n |]\n ; [| \"77363534410783423412630139556441807611393685349073113946053979350631229049878\"\n ; \"54905073434434959485893381841839373267383966385817882684657825178181863944371\"\n ; \"110016011331508430102821620395154714608084938556260733745010992614542669817451\"\n |]\n ; [| \"52040139270046094723964229965823921970388683619580004402190656733318120479093\"\n ; \"495546618036723566920914648951352373868059898268055487677897567226892784967\"\n ; \"2528292188392170914010448139211586215817069915670005292953294092269979070980\"\n |]\n ; [| \"36842840134449713950999812540127591123318806680559982063089906871196226758113\"\n ; \"112314504940338253416202605695368724580971154020421327790335219348068041886245\"\n ; \"51653712314537383078368021242008468828072907802445786549975419682333073143987\"\n |]\n ; [| \"27179054135131403873076215577181710354069071017096145081169516607932870071868\"\n ; \"93264325401956094073193527739715293258814405715822269809955952297346626219055\"\n ; \"75336695567377817226085396912086909560962335091652231383627608374094112503635\"\n |]\n ; [| \"42536477740858058164730818130587261149155820207748153094480456895727052896150\"\n ; \"45297707210835305388426482743535401273114010430724989418303851665124351001731\"\n ; \"28263543670875633354854018109712021307749750769690268127459707194207091046997\"\n |]\n ; [| \"40809484989590048522440442751358616303471639779690405026946053699354967624695\"\n ; \"51589519265418587649124543325590658874910911006853535317847189422703251228717\"\n ; \"73459936981642894525955700397592343967482441686326322443228255968694436816673\"\n |]\n ; [| \"87298777232393189731949522229743081866971743270330772607820990832164835738703\"\n ; \"23328534428894097247289332213412175849711532153957647506361455182140450133738\"\n ; \"51807348624578081645565456865744011145427112815128832643950401419083788780028\"\n |]\n ; [| \"62003629107726929116302469001779155132709624140360743951550189738290955064278\"\n ; \"109311858027068383034683875948676795998030610067675200794951297783857157095297\"\n ; \"2085588517087605436136379278738013214233743532079287631079316773925068862732\"\n |]\n ; [| \"9513664655545306376987968929852776467090105742275395185801917554996684570014\"\n ; \"91103467624252027317764670613760419385374004736848754250298970998535616755199\"\n ; \"39500000352127197728032684892425352332461947514533659433380855624868454474623\"\n |]\n ; [| \"75175260486328125629270378861920310368403601365269629778076078053196928460032\"\n ; \"56923881233337629517433981230592855430598464522180216309153828833928801967999\"\n ; \"20981004218820236011689230170078809973840534961691702543937445515733151438851\"\n |]\n ; [| \"73175203586574092105626230272409823792532423094740797516874387144340145138310\"\n ; \"45186992623753580336479418079070607289916086076906975839720879934817804495460\"\n ; \"96084125187548549854900995260973117424750860440064269432639526863495781270780\"\n |]\n ; [| \"53530507055579550362119832302266967544350117012822630711681736383163390079758\"\n ; \"24484677147631687826970700541691541659768738376645174313438582486313045584324\"\n ; \"99915577684197600584703320523786830947563355229812244982453188909016758004559\"\n |]\n ; [| \"73101441225016284181831039876112223954723401962484828024235461623078642642543\"\n ; \"57434882751817972247799186935032874577110609253567900895922769490031350316077\"\n ; \"73837027842771758252813592393497967898989365991569964687267097531033696791279\"\n |]\n ; [| \"8605586894544301092657394167906502995894014247978769840701086209902531650480\"\n ; \"8900145888985471928279988821934068156350024482295663273746853580585203659117\"\n ; \"76135096553134713603675854628257365311062159747768423095496501607463292188538\"\n |]\n ; [| \"77171330825793179961995032914169307990870372845116475229799680315757656196917\"\n ; \"17848856881287888035559207919717746181941756011012420474955535369227552058196\"\n ; \"85285874363861776466393873037603415962379724376693393356387850868454172343232\"\n |]\n ; [| \"34752820629818556525384193423224856177797869338806846583786365186093662702640\"\n ; \"61923000676912108769617866333091286856690233713839015114991682235541391477568\"\n ; \"105437294734850952102877811210027981435959945375626993201685688489494148805743\"\n |]\n ; [| \"37290995592003925978648162243724313056459187397796644444696543576625771108605\"\n ; \"95156804644588215637074780475000089186488581067063625121782605228712011438608\"\n ; \"111838568780358037910894878973007194619694503969424695895292495245099084158661\"\n |]\n ; [| \"114085830904535970531084512281741806703564152148485737755668141105183488387818\"\n ; \"27151558900245092306095370161852910074651784795680581223133179808714387525774\"\n ; \"17782273009863750298483603933610732253879825505411230932533407287574651036994\"\n |]\n ; [| \"72422039981423868898452547270453235353957783762070405836433674391957844064693\"\n ; \"23635533014670380888810554717349513178608213369182061967678315431422272271569\"\n ; \"59402711345784829746976504521969665104448536964686633342173372133388407225657\"\n |]\n ; [| \"92466806354851856571355165199186633833982438153589406912422876269386887264049\"\n ; \"9877617390649361889067963484857474874019563445507538784053773745685676317984\"\n ; \"74572672075215609948567780829046067891251792522874268554421916351892498078660\"\n |]\n ; [| \"36552683919656073147232029802086505741533932059491323529262718897271096098319\"\n ; \"28895802628889660292449057575076739706255701997961890168977786141673053679086\"\n ; \"9907785227545441866241924986174555965766785257012652276622736289520175209842\"\n |]\n ; [| \"29485332368911768475893015509537099136952860812699472744021496513325455451738\"\n ; \"39797358509842904932758894391536601623578260107859540160156599261695054175926\"\n ; \"107452259847197252302434271220963395311929879689430847107159618578878468880668\"\n |]\n ; [| \"24664696127391052816688570667643612077905959307658722811431436096677076924072\"\n ; \"52507998665481228083044018390203046881916651866666590845312076558622705190465\"\n ; \"69935204723497468327083545368078327534124772251842862926136799697299751835029\"\n |]\n ; [| \"372963191403207230700085823960930798511810380777302780932220121859190714585\"\n ; \"111366606704792806959979488772421759791592911629496627207620326636856656861526\"\n ; \"39677360977437767398760288273614298000827429534821360419179023551087917983124\"\n |]\n ; [| \"64601494076430280535646633059501605929914790764963584476403188233843589027560\"\n ; \"34156315098453482946438495274327282067376463494057110043754782161473776373661\"\n ; \"73687667961196401152630755105477060056162632832680813161120412165243753726816\"\n |]\n ; [| \"37808689229279738382348785246837013002280781984053433359148018860351753688153\"\n ; \"26778210635417272626362658500217995247072424006327715268521424423461840656985\"\n ; \"13012115310019421859484865413402512912208022868124085927375736053832542569552\"\n |]\n ; [| \"33073055720188060063004545324174039863351833928493376423022587630016341635891\"\n ; \"76584254259783109527449313057522305759653397147785066495263227868665161219779\"\n ; \"38531270223194009551634352795926218399266465064491096474482575354468954922673\"\n |]\n ; [| \"90100362566645034035707547984589905559141359276359522681964816611161474672115\"\n ; \"93014643079204629081291124987233004565276697190519877698472422015954982964601\"\n ; \"110916697765188052223435628742886773389228694903593626715469113528434066764534\"\n |]\n ; [| \"114725280711584666069398481856753837363052938587178775403749719257369626174299\"\n ; \"32967950615819700839673854548770413755655613096921050182183649674389310060672\"\n ; \"106372438106855157117155417458821032302424106544646447353561892891697429919509\"\n |]\n ; [| \"41996555998804572671679174634435850382099449308465335760130383677478780889948\"\n ; \"105999190358126224751922865919841547624707481487885223948004296548330504340556\"\n ; \"16636528128134911466622907961467317982179835733058354229921170933476186200761\"\n |]\n ; [| \"43468498537738045222256870515315985487110433728199201952445121047095648527840\"\n ; \"102272887089258604970815589009009162752025146641624347901234381428987386153285\"\n ; \"797386830910520008361185815477523544664694040635544500916993469578452189812\"\n |]\n ; [| \"96744926314199156321023598425708516126928808801578082649702497034531770517808\"\n ; \"99066250188188051206024031106640566584616407903813704153928240609169764005797\"\n ; \"101012485188852469291356197079506861083321680470016268483997462932491691773708\"\n |]\n ; [| \"49614555470963378761214277525336169174318331863453657910575217035316990252780\"\n ; \"94532874466332578813348267802784511494491757628599627802933242637211676358456\"\n ; \"60376163781951477822973950330025689966951914888122503797194554488987660570913\"\n |]\n ; [| \"99934768696780030317676638063039209891456597783633841250810260768328701786300\"\n ; \"71861378641802240356627336242725340978135703736568776865558429280585792121426\"\n ; \"84446994028646761779912629176051455275041688583492300440129402381138226185369\"\n |]\n ; [| \"18317002472599225949038448120242542829985613745531554876060436499109578301758\"\n ; \"23001721954642810524358122249469196372443463625490878969385130364780514025259\"\n ; \"49037245410934285111914043557449391103989331168177809387278571893536129709378\"\n |]\n ; [| \"65792050828386571136875573680568197513273253001530588336285451691348906024460\"\n ; \"12956514709922286639520985225111137950302442378466870763868693820049405409474\"\n ; \"38025781500219940187723501911749158551479941535921061459281014661810772473038\"\n |]\n ; [| \"98610017124283789125637190759729078315864881693957982200427567103302362453196\"\n ; \"42724178943656779288650125468921272883324869492775989038952508393082565227450\"\n ; \"99514360136104778310983460863480701661882652836741972684579325226086664343913\"\n |]\n ; [| \"111234788248236327826382691076985300771418365594838017963216100441270435887017\"\n ; \"35290532009451633157074005614742321966918220860237810056920944192222599040501\"\n ; \"72172784027306769601458922728374293130025170844011739475076742090414769211169\"\n |]\n ; [| \"61384388429666858375759167984149961873566898632022783479711533101905095026411\"\n ; \"8194273390415023152581060020119881338779571723515253104919314696738194355344\"\n ; \"80659234466772556847544129237154202226081525079070598707001193889658539631883\"\n |]\n ; [| \"62157670692624367146830864246105810519941474190553952682719433471854134465138\"\n ; \"74851302400382275482762496406028988868219592716510355166137061257664688666219\"\n ; \"16881796086836744646703159464114164393240695449455598565494759189917589453976\"\n |]\n ; [| \"42460477269659081546432152357644086326197211166562674408623141905226706277595\"\n ; \"81063688725529281621596607500748519671655516257039992655745871437369181665242\"\n ; \"51403113216244137057466948399908740878535656059933892843818689317660325080213\"\n |]\n ; [| \"49001998791770520786679099472805193463531142479298200795569326894791589887035\"\n ; \"42684462014557597494725933597359625461226399711783671410492942446635214257509\"\n ; \"106420886277092880545929306533089566775810130555230702838917980421765786292693\"\n |]\n ; [| \"110523958037212353696746219917157237679515245560578307171595792811566554384451\"\n ; \"56399709802930804752950401483879725014794413557467977624037632281590440364765\"\n ; \"100108862073771478435824578087801736413858177140360408436521717282600830155374\"\n |]\n ; [| \"59041409790855290045250456089216312297230856546920761548978870779493926213674\"\n ; \"13735945315945382005247895569035266667172550063549145646185577935658666385507\"\n ; \"16846296242516834547231537358954027537902709068158411294345086281698311539718\"\n |]\n ; [| \"114970774262524353875592617323889610576992844847433725376114488262076142213525\"\n ; \"17896661983150937411004047429485556264820315976705642986609974816436222162633\"\n ; \"115573362005053049429141251153085446935774781295666612354309246218946442750706\"\n |]\n ; [| \"85575265064375003235737272215445285540001719469558026661845214249857169530994\"\n ; \"87501751332871186792668480006319719164949448258731670359536302677279100637346\"\n ; \"105775909055063540416087237151517389942637625317333843436738223226977225420379\"\n |]\n ; [| \"110886009455283422981396854898481256559291311408679418842391298005253375700608\"\n ; \"95342257228100720685556647789433478371609336135456255803583405713563597933074\"\n ; \"2733591517253510124338232417535938539627593736745105875672348998709544742241\"\n |]\n ; [| \"32685479117496505057951010536248024091461630564950845696581129158987138920098\"\n ; \"96139836598015371513111133071481139035733083963976340622322043979088723982681\"\n ; \"16990606351055720221300633612533434675038905235719867684891402550154692840579\"\n |]\n ; [| \"13886834869596827027283068322204563244577723967928602405785473534631482228259\"\n ; \"81034769645830807786559566591578132114590768431721148809270219480247445931316\"\n ; \"26780635035984131258327079447673207266040002451512601352288859614294714150612\"\n |]\n ; [| \"72820784976920576285217524394309841044157743334874310886804718206719618858662\"\n ; \"84276722913141806246805569560426345961854221390421557310593118606084442633714\"\n ; \"42573817497593319926701003355299929070203785007821783512454795971915573843634\"\n |]\n ; [| \"41660041627266397279909712983288860313881442148611073178272756605107913521726\"\n ; \"7198246770791404776745997973411401046335399072925979346193035999274650139809\"\n ; \"91576025129588718283317000330880100309465430116820675850311277329602716166005\"\n |]\n ; [| \"30488483928716649313242898509172476460161184318124511942476380904233730958564\"\n ; \"35346040517569327255933130090945133067049088493975862969006023114275649329148\"\n ; \"59803015801166721680239913449555176591725421041660016242103441987856441941533\"\n |]\n ; [| \"17395049232451382970906883167116397657891664802601579276725674512534883408665\"\n ; \"96892830538146451450007413348096295684782382701592949711753407054447667361829\"\n ; \"46725583995795907014628330473921842919957418641665482351238505922983315675600\"\n |]\n ; [| \"20556719902345568138970735755829852608784985449829745172855204153387982836579\"\n ; \"17130405757403641097651484965062131526367059595476924144885570325828777794585\"\n ; \"99651763337265056372826178960800950053231370129318394703153246147873057668256\"\n |]\n ; [| \"17814517977679061356584950826520510701145481336316888282105225134451035883368\"\n ; \"62116749577126511600138536864540326578096290025961229483071769130930103978622\"\n ; \"68057799973217998063838402481530957249181669394905338807621317159743376777292\"\n |]\n ; [| \"26100793478962260035181580648528031417033872324944615961986573818448125345450\"\n ; \"26507891451149179196332605230084404371370204632884553105363087566061809624465\"\n ; \"55607174697006979796477169324630939518573410736589826596210132996613779221405\"\n |]\n ; [| \"75098549092668095590746032937529532494350222003700838962461867948806312867882\"\n ; \"62901674712278062473767645982006145910793625009149846534629441949336033280610\"\n ; \"5918385816682866756860679567405784562483373873565987668410277610868983146285\"\n |]\n ; [| \"99232460916208710346946062875203578399818909925477280432427620267031292402265\"\n ; \"115165948144292852122635634954139515297086369356811820254801384608988902457684\"\n ; \"39462036389170488019054739441325823641943062254145671230029238830857274014332\"\n |]\n ; [| \"109723826013507458840008311671051963282645213933956581735587227292458581212170\"\n ; \"88295699560808238817850908733435797366622278897489038929647807463406234520052\"\n ; \"20306380368695786945008272690438693745796297843799468268993907772341096948885\"\n |]\n ; [| \"39988356032524455736714109463355738665746339590560108227920970859248126609155\"\n ; \"47372836588594871116561451142702593094337405740661755511614125456886719840333\"\n ; \"42727075822142544969304941778878121065758237932060280070908539158139079888683\"\n |]\n ; [| \"115695172202592006925180721060969710051274632819849770440984261650964182295350\"\n ; \"41198034356969673080518030958715740186484860381424802035929938277103521577731\"\n ; \"115380378505550001583545282887589851179279565072664241489053445702744491234750\"\n |]\n ; [| \"56074680442485705900559544809779144521596408129059458559681779642734476672579\"\n ; \"54187206076706271120400668422875039791522899135281309004702779376007885441827\"\n ; \"100760509008368123701304764217450368711018785408289674422092070202193042774995\"\n |]\n ; [| \"2622643323130765702269424224791233611920515499144047449633123689743564676648\"\n ; \"95487289650450707799373930173349121410704227885014701702619711048222666102791\"\n ; \"94943953462630479470879050547964792684799160133612590505176816568790562776928\"\n |]\n |]\n }\n\nlet params_Tweedle_p =\n { Params.mds =\n [| [| \"7892482395656804349644706591899634788891398382785975587948820587975527991027\"\n ; \"11929678886172339432249632245409218061683715785450195046937244296345281508001\"\n ; \"14031028727666215233628980515424371116641513455277823607571812548899776279020\"\n |]\n ; [| \"7068151019014908222760412877815939864640073704531562607661785991407609364631\"\n ; \"20000306279614657869922305271027332599039933086359117559307552225546808822661\"\n ; \"11789548007016973514330291636006559052177068373404372008308286066331957081587\"\n |]\n ; [| \"4596429675096962119861928990065498834900102715520185745595618370978168039762\"\n ; \"2419382603939993361171611462560649281200390612440053944534827125842944774778\"\n ; \"4204784055784266414484460653790149892220936342148543538356735100428170988226\"\n |]\n |]\n ; round_constants =\n [| [| \"23871411633030431908815309679954664955316835501833596382711537998018196877083\"\n ; \"10266075254464775081489705012423357777448464454058081904455633881524670629031\"\n ; \"25330590157378829472296364867033252573045672523068709711474216638118028547521\"\n |]\n ; [| \"17731890776914364842025248625325793211421093305063918487984842622991225662959\"\n ; \"11733994571128449437695833182309936427385843597031955163409472509305883070660\"\n ; \"24434628986405408065629924634775662413138564617325268165975978656343592221427\"\n |]\n ; [| \"24536402423562099407865959531182080003010952879037409125240233415066893274478\"\n ; \"6659347569024195568957991805519163899458248905612848191888227437243439812692\"\n ; \"5960767186841646855432896459128104017951108167445308950169111825889581577061\"\n |]\n ; [| \"4971911842906289673901226938513151439879412562713230347716896457803333981940\"\n ; \"309541453644722548825874753903709706899515232384157286261751156736135339003\"\n ; \"2269569616427699911129222135189454646445178229181823882769580159958019242097\"\n |]\n ; [| \"26993878188558092116624938696043644448548700311708990249335713416846104251941\"\n ; \"24517651748676427005644984612090266723222512573361699639974666939135208353913\"\n ; \"1097726622863402924577966380605322382732118204644384325315739877029330402588\"\n |]\n ; [| \"6426758383747111723734570359305954670329012940529176997601958694540682554431\"\n ; \"21998569714212750241527571701712502925679335862585921971643825857153225305984\"\n ; \"11047558033241019082897471004499357092985291837411225795336191143257516860961\"\n |]\n ; [| \"9093665141362071558275397247216897637652502299054137932451490373194253077166\"\n ; \"1800243967051770052116464993247352026875477402681617776355019059173229087774\"\n ; \"26123174928857348712960596162051313701754733407348331834302644408819678596924\"\n |]\n ; [| \"23812410588002831655659233838637953883343555294778677500694584331113461461429\"\n ; \"16568937332253520415004151553015144261880434455738996526515454547064570797856\"\n ; \"17416986733486903313008211792802080561485956593184988794629480990990241332753\"\n |]\n ; [| \"18850099810484503215488003706456560440897969494004838374239261525322319819433\"\n ; \"11994895177966687446998282218714100449449665604701986885520927508332599942486\"\n ; \"1425492478667258597960503405197195915139351100492375612463171033833952312365\"\n |]\n ; [| \"26851566219342728401327392853793780102411433232004161234295219003581835075094\"\n ; \"344621744446962141869707506851008584085694659330775548168637253712934505608\"\n ; \"27869765162837447936932893631710126670776990181965052553686418664996771747596\"\n |]\n ; [| \"16748261191950640387981479364297758560864676430387245694151916012002124597033\"\n ; \"14637099470938912277872449097875538968878222997977657926224477080477442009809\"\n ; \"20134098049637875993058446069963966007404168258760138083222194380042623128253\"\n |]\n ; [| \"172643149346341872053831853059095100992686236318507345773031309275063274280\"\n ; \"21874843113613945727298268457562401417065305917171338167509212463100548326138\"\n ; \"1700476193411517352507365601977550539756670894414173315822287469432716857784\"\n |]\n ; [| \"1993872240998785476519726097091542582716493962333829952600400285464827481667\"\n ; \"8472968691234464451203870490242938239228570177726710854613935637388109305350\"\n ; \"3164353924636797794161130496213914461962109666565363218256253978570495482041\"\n |]\n ; [| \"18244688836192292124520893341941070140825196416664991549095593577108644921872\"\n ; \"19859999153394936655973233989554564211615670588445691525235383025282647829759\"\n ; \"14768311403338750313336252298369831176491426375153840900301806527515974149276\"\n |]\n ; [| \"25048746858150888741163510410158558227335767837462499905107113911114136816901\"\n ; \"9227230998590560160520502436666565937931267956328463227409811272485685606743\"\n ; \"4696776701448869702784130024458706731441259445875220148105235193026890671102\"\n |]\n ; [| \"11301287347994988321521498920971508070471338636236053007115010700214623134272\"\n ; \"748252891813253856881595793948847132117119525095726183576703279303135116231\"\n ; \"1209563742600434023250112835996756101387112259967014633008182172249296990489\"\n |]\n ; [| \"22609170854153903022054335214005629175374223898873094415826508662474540012601\"\n ; \"5756488621395177188006147242675038050365093553404446887430772051137609241084\"\n ; \"12204891034723523196031315166164117720044397647721380430344188362824579202559\"\n |]\n ; [| \"77948413643208929474117747177500706081858969144437292876038062365116961856\"\n ; \"4819244967439699230735093723487091713222852277599700902443121153586483108261\"\n ; \"27255193365519906102265579122686066635100777748346545926565256522831777732553\"\n |]\n ; [| \"17483513281289738114320990201034187042331906234136726563186654929503890752423\"\n ; \"34539753269842243397370782720638857152602526530856732612587217775462538897\"\n ; \"26670389866012575823645511883620356698491268371217559959046672563897471132762\"\n |]\n ; [| \"6221497512567057828130180875424737245292473047926600299819610408205436413046\"\n ; \"19660878074830892741426544634587706872027677058382555048951769961524177907107\"\n ; \"18156934729803692033361542236751723515055361449102326383067242692178901601513\"\n |]\n ; [| \"20073967418251150136032317311523223358394853170230955059721556689651929220184\"\n ; \"27772273899948728907116549961890766782916787451941456619762132483552045169192\"\n ; \"15971692165674397331342925986736499624826262396209267283406828364924966200635\"\n |]\n ; [| \"16416286997172332555663573131890151419265070164405909524639440666852040213934\"\n ; \"20103224377910718515832192173396139379357815331321992767836849578341263715617\"\n ; \"1992082765658661183841193649461040448653056879234437404013909283532649563512\"\n |]\n ; [| \"19951269645786270967009199575056978741590225092285762370657308905017645787726\"\n ; \"9251473059263374648207691341973093388418035271819559725381912479353472754743\"\n ; \"2444980378309704186211898448086030379464888548066321109843797635753120477485\"\n |]\n ; [| \"10928282022919314114783091884635542308337867197724629946199953660957345275397\"\n ; \"20860003419679976346116549953191442898649396106318245755983695478063963781522\"\n ; \"9125646500493112058936359272551424490842840477766749690227538466206819804312\"\n |]\n ; [| \"20177768780524517369036303031063597036475507744395182409567531978700484378289\"\n ; \"23849136275489209274738706275875891467606042431504310216391474226820256396157\"\n ; \"7976082325486396563438765887430351103212480060205218817888924447342264023448\"\n |]\n ; [| \"21218093079130866432053178184495259038615729811686678720305378508679861852386\"\n ; \"22222629794092576664613127689533080951595674722722217395604438734265291507137\"\n ; \"16117082350553416755654415094185598367594750430516162377370652361756124580927\"\n |]\n ; [| \"15386072248373014774707633578974000489889916088461822982033430186915251599101\"\n ; \"20059444943956181967567300338884496353066968918285957577453937920821326774911\"\n ; \"15969043598280333886921493788703960477679932825020353079985508309173442399807\"\n |]\n ; [| \"18441908288363677832500730109945652708871777726808321883963939341572708678438\"\n ; \"9156742662968671243472647671483446293299984596395820828399187385978257187180\"\n ; \"26117513962333705951186643847036445264112495570596099092098117311469761624146\"\n |]\n ; [| \"9227362126330995448990863192270789313546500545949776416489812561581590597341\"\n ; \"1651638493276735214427785026108815161181550587953472105263074483216056083718\"\n ; \"19754190980633296736565417422427507009115461976496493840015545861722778641757\"\n |]\n ; [| \"24059801258623894209907222963420795819610514468735113836904109681657134646406\"\n ; \"2507773721870400383553935214026283806800287719784543798652125141300020939070\"\n ; \"11545619277487756168659369622509301766172311628766869964453828841442812398464\"\n |]\n ; [| \"18599404251801695916676262627086229256833226846935875794848292474360329710182\"\n ; \"7672585728603312485277463389894405790617721546034983006052523579994187672256\"\n ; \"11663243875044039826255065018193844285574447293546626080552543307831236101532\"\n |]\n ; [| \"3736737114971552038249889038312531109770417843384959461392265945390839075490\"\n ; \"15405041123991166901995181017584204362284350353917954151561434093358377932416\"\n ; \"21190402840771768305757114855125881983900480564766015821826135703463049645985\"\n |]\n ; [| \"27657612144465152844076751970773624300501046484432872648148700499103897742199\"\n ; \"20388430216478368624703227056329193371722737732187907129943643410513691213535\"\n ; \"3344820289563345194933219828087298037081196856323727299522946086140971056423\"\n |]\n ; [| \"8527890306194452597728380300408050856248447791462807214374322801696709074298\"\n ; \"3344453085657711280093205964282996094870704440396012352126082601788308767424\"\n ; \"24129621344772065907359832544790760848535846792550779738943452820186937321016\"\n |]\n ; [| \"16682281929114205892868637273887744852593056654081569289385196216494586052059\"\n ; \"13390546402723680321309451408062261872073917009165123815466701909179323058725\"\n ; \"12454401735435545041240744062413508439776638863019945214106500639361960301753\"\n |]\n ; [| \"22691978545214712333682322509829714302565160720214993370385276444403705409774\"\n ; \"9304194978657396762457989504468955280882290742713614422164474050373984880419\"\n ; \"24518330162580075369755426938387542128644607789410819379604533097820563945147\"\n |]\n ; [| \"7793343388923696013769312876044250715843242497839331541419306365445952124334\"\n ; \"15474893610836752417132140205467036343146784962533163791549972307193429176684\"\n ; \"11116443861170111868320138692617094510473035491476329457635995671799970535803\"\n |]\n ; [| \"16877979504226807061419377389528064425375368470773322489308736865456734785901\"\n ; \"12194411710031950769113984418215809481238312707786246344424020890556957457012\"\n ; \"21329761519619810559319231763677758647122208920134924045388361417919054295294\"\n |]\n ; [| \"15486704070124713197776757158780492106937367947624672577943214567891933787258\"\n ; \"21879500021741312414877635555959377131752915257473724817131516706125013556007\"\n ; \"5043420522702480930107029442863985487527788786987286425206067343205474678396\"\n |]\n ; [| \"28416728565535371153714147767297875894376657006631966873680443521362574322416\"\n ; \"28188295006821213084652983277541040229663295908823345264477158493251950224190\"\n ; \"811696348709499453953485215191565713676093511624729934721077050082968313251\"\n |]\n ; [| \"14655407507725921832105500951552761181971660775931368508685072434505922507512\"\n ; \"15452937371493366546640620581126461399707812646853303452806945678641253144882\"\n ; \"2286261699720696752622655970051026147406838467804385944265035557798199981133\"\n |]\n ; [| \"1992557442353308000623574109100253608701924636766704840114158126271278280731\"\n ; \"21694450413109623921951195958057854484852090181678130751969309977692551536018\"\n ; \"9249731319012017779017326743606194923643668526628748858217378905811538368382\"\n |]\n ; [| \"3939219222555454896586029131514042607480723623744884435463307473774574605152\"\n ; \"10797179208934709183850676357345550930799476411664074421966228250898236909457\"\n ; \"16003349341141317690412220236365636756328414540434964599637729177724750393340\"\n |]\n ; [| \"7139886020914795212662604367684684711418131042431587260958077772503994611059\"\n ; \"14548527492795536984793003371667969667596401576140783527415224992442661296652\"\n ; \"27784961580458637262287375576745710987249457442419641954865148924289640098875\"\n |]\n ; [| \"12713866702735338063343936521670481149781186654485300349666527843472483230312\"\n ; \"9092010170409960335483537084430885053488154353385070704782245279718737955046\"\n ; \"5094923690647683377313391496286927104459466521704225286803035696710155177995\"\n |]\n ; [| \"25569861054853573619838769694313237597861085179963737149403330254183532535529\"\n ; \"5878170049851666055783493866996165172583448340223151974352193778036352307943\"\n ; \"3872169186443882698001210463876163485285999493224352597337453067537500276246\"\n |]\n ; [| \"18665784052407501847083570675839500069230593336210620138506436003881713609889\"\n ; \"18152379076079140594000518889838158343416361432991548307242241800589989006514\"\n ; \"15293096858608991177688271468787656348083923851728718260954929346470077552533\"\n |]\n ; [| \"27458404667733046540990542309129625717764044091884418745028933631962947220717\"\n ; \"8006229583150739842023227507854792176671075468287456095936807010603225964853\"\n ; \"6673337136101970490098396053273218923846658878925354650729739777392657741321\"\n |]\n ; [| \"2866189528434329040657150614965317384179174137415824086986689674293245440869\"\n ; \"850286832335872065552208685923468151432517596206010380489009288659201960609\"\n ; \"826167896454325673153913201896766310675528897953588379016483511428072705149\"\n |]\n ; [| \"11091353885350315399281534279307640099073252617438924758095267005171197532901\"\n ; \"24332996362686645308612352679547748916117510430673097992758824281388269163049\"\n ; \"7697281120418309884363241543849152373040915185661630590946085871626953307630\"\n |]\n ; [| \"26903415823976566965446163261389520506645994486239829395342314389345167145490\"\n ; \"16331473399937436063872600675479075998365344725582239128025161788438169634490\"\n ; \"27478782423978673109458866577304881582710228942880032866222151681880849121754\"\n |]\n ; [| \"9157575957419463790299788535651375681659171956515351213017221629165597230565\"\n ; \"7212846269226025424784660189052377648721231465719295820195086840304302908764\"\n ; \"15079360452490344164815517579543356820049766968077892340838182489029333395345\"\n |]\n ; [| \"2164387758948063499404878920144621238577478053584327446777845938241996921307\"\n ; \"21971530571660454464263042379401691171478093875859848797664553305525096942047\"\n ; \"24996214603829854187327550321668003124272776524258345997409641809486816101711\"\n |]\n ; [| \"5012530167147645132123926239187192574015992833971936940239020886743588014969\"\n ; \"3538797852945828178389690727899551008654641317873025930608250831273186708784\"\n ; \"16351872580375794420559957848346781277378485393541927811867651422570033372488\"\n |]\n ; [| \"6649114213329992677018914668592605228429520774140774692558017652328554186338\"\n ; \"18665440706841919461000547042069933770374154186835596054373579551791088230368\"\n ; \"12068241390808361251909200960327581910129328275585071206860621578629194685379\"\n |]\n ; [| \"15905233165225780889629861680805819536375352205513425939444748949014424918343\"\n ; \"12508454002472469574115566912186222048654143934720930056557327011774683943013\"\n ; \"7034709393479901734220602275921317679827342926959053187089378763382019774818\"\n |]\n ; [| \"15071057763697867068980601577937010855726002209360872455781029717330270540558\"\n ; \"26837903264629473479982710556353240390490167539626299502592215453725741017346\"\n ; \"15815857256588462989339312138660989790088642030075547425161293150909179052889\"\n |]\n ; [| \"17790122309815232908548524561514677539176024837185249994150799440752116986971\"\n ; \"25681654720833964361368816492300991096107229186861423365051433302640152727160\"\n ; \"25092605033552047946753252380591729771370646821844905835767238550702091926466\"\n |]\n ; [| \"9133411374125723094094125880554229361676050614544252095679163115115894136841\"\n ; \"26932002400667217014602216630093364493283860795391062254701152928395308796018\"\n ; \"22106228556612087153532192407561886213520535606346621942342426362558131787963\"\n |]\n ; [| \"9406311227783101741290261235550552478435250008098267151139650559181505389852\"\n ; \"27348341640941808284285285580081335760088527770841163602103782109071842104934\"\n ; \"23559463527614164053397335039301766055455415575615533929384690127861601499457\"\n |]\n ; [| \"5619769611055946079310055282596239209008895876149398331145676663636029101157\"\n ; \"13578163259668232168333668013435506407087237516177382960962039602890195751920\"\n ; \"7413830766934399815434854130814997370862812666201550415594211525136216734282\"\n |]\n ; [| \"13792443813595271204983556094168533754933130020885607088800378971405796327369\"\n ; \"27980816529551052578978463084908633402261105969483057107732537724040827783618\"\n ; \"9086585172488644340339192486024741212137636677834987669856236495399842977922\"\n |]\n ; [| \"11313421680706870429846305787628308653216330618143751161363947025312249024761\"\n ; \"4021066901602104243187251101773896805730813605469425950314405128776613579602\"\n ; \"14767121153557006971815403909933008062947309032922288476507340789333378073654\"\n |]\n ; [| \"20370619771295344300690236727919219226792483779515051540457737461170706414475\"\n ; \"19057013717580762168292421969225077213646512718101800237917624429055981813838\"\n ; \"18802159878265458151106922138846829134121904345009173021788332776013230402104\"\n |]\n ; [| \"24016190866456985740426033746487501435211791016346499791546425666381940738421\"\n ; \"287764449305195377184537313636736253449783439200917075011454826449334249192\"\n ; \"28924625533476565101998318658547220617045362556325453564311201040145506030261\"\n |]\n ; [| \"7599844266964312760321206419543935528432789425869947893826782118191539450266\"\n ; \"27134279976752686312431326985386138880800506706870947398386273393113450719312\"\n ; \"16691817056677639737321251699552704590963223686119737935250825199787652805166\"\n |]\n ; [| \"22998044684431557794791841708335486493573768985622899417439899102757564768837\"\n ; \"9401177121715465262238174135751147495308547205972761175814504972150026367535\"\n ; \"26790130566347368063997033116765929382273650193131343958415387299771850673985\"\n |]\n ; [| \"3677775394669979862889071463502051146295423081411873494668961683260168561200\"\n ; \"15979374501543368828047096104571216535562304582450829728472504102636784119438\"\n ; \"27983949821598015961883988148799706647207081688438954093427232113605924435366\"\n |]\n ; [| \"27544538692601828352117435876403689629911776874104761257423949309268045763185\"\n ; \"26518335501934972769761573274318670551390596750003847775195848446258018442847\"\n ; \"4394131430649458263649250511378672198908409479410475627536485368480589477325\"\n |]\n ; [| \"17852065984807648650789061534513315071882379764409167220327155188497750610044\"\n ; \"18175119138227704225937550148743137184987075122850987480893509516338237125431\"\n ; \"9213947738410262749305252213461572203334592178012688401993745223133683403178\"\n |]\n ; [| \"27122114905718250703139963834720424986105744685568269961612244344496328439886\"\n ; \"4760667796367744574889553071124411738303713877930746202875952709775583533416\"\n ; \"6869551919316193097108785401949737566268346424578556997536454243546346759675\"\n |]\n ; [| \"23037512317774976799069981329205938965143927594538311039095844313686020797562\"\n ; \"5054896342931452597037605872652090619656314276168870046892307499425423949760\"\n ; \"23203714262075719720359794801639953965353238316905585901583196491094684440749\"\n |]\n ; [| \"28934221989290923495677613925521064896104825372643558590174660971609344537462\"\n ; \"8088721343567483152949374218613505786573889657303344700058590499312426775261\"\n ; \"21917953186139856111153943474716456656175171733392297547383518245334653482436\"\n |]\n ; [| \"13961331694190054971056058301976924809966415553682688755720832242614168486723\"\n ; \"12544911152480935441357195703690990795365136419393151814200219795399220718629\"\n ; \"21695520803994090395949407367250368059907198292643658069384062711565918112344\"\n |]\n ; [| \"3716150465866919736709076695055976565597785970845650354410730126658608015494\"\n ; \"327336957994661404033945962575518119150720065183392456042720063992483355163\"\n ; \"3665947140103366584087139828849494245835014110441785513464272098210192613654\"\n |]\n ; [| \"26369492318428928735445021592697190549303995382614357682017136715337112747935\"\n ; \"27749815921003845385723497945745117881231921684907697336156182087899053510673\"\n ; \"10355044492217226758344497131673377893070994153140912920311451906060821340248\"\n |]\n ; [| \"4628431130793759981513415398028190279858542396207977476299170127225184781705\"\n ; \"11394587544387541452118107143659899713641924256823223827419604528665720745426\"\n ; \"27501113180347337346361365060944451586249867412705472720376921357546323344395\"\n |]\n ; [| \"28278837938314100710292020893318211455155607281093551519038981321116602349373\"\n ; \"4157302910095235339431818149458321721626091681389723550549352022675823861398\"\n ; \"10647753346148135279439456095440861046789212730332155466632561589399089133326\"\n |]\n ; [| \"16276422291909940897533508339274805427392027844787029744067454575137039713632\"\n ; \"23729032431762932898115881024840919797648524831708845029533918801044987536615\"\n ; \"22905612910561717552380974405189058153230663615322248220713638543054825797666\"\n |]\n ; [| \"5444504530356500737158011550177553406072045906791914738537751528417224842639\"\n ; \"28510386747999403469810407444832806233927676089588288134899522943795774693661\"\n ; \"19805413841948596162239177018362584237164470208997373794301520395085284750539\"\n |]\n ; [| \"19122547678583805564624026606820513504429328853794128995861987147454516637234\"\n ; \"14149390468608933390700184668781640373558946294178094543601697991189519008854\"\n ; \"20866357658195086764903364035397344007481887992484022195436866986726691198910\"\n |]\n ; [| \"3091400614672562681643141264311087165471646584668481415815002651728679925334\"\n ; \"19494024337294025984052821389584821264663721932805988242535888300060571638572\"\n ; \"17644592732159647749467251733367874632398437355549297444150061364959517600595\"\n |]\n ; [| \"20396032354914064522098028139725361423909280526354910804413358051025918529619\"\n ; \"8139121339158552499821459368548404840589616792874943249851117821336073953085\"\n ; \"10922434269468548872208754791993251262753058094227791965335951350558389242990\"\n |]\n ; [| \"15649912252593120246156581284146963323803608017723227709583948225917889870238\"\n ; \"21372394998583927818008072510481270840383010669604639655072625570587680791691\"\n ; \"8898065452020133817419600668300082490862298528579716847829659770466997068972\"\n |]\n ; [| \"18650547661483668504889775893476275079031609582673355265573607371710055926487\"\n ; \"23618674478465955845441421736720381271262239925598902631963493613481722447464\"\n ; \"12891746797231517000473007152761525047439710094872911258902687687042685332250\"\n |]\n ; [| \"1833893631568920050533599834904970213411923339935020486417653785575000615143\"\n ; \"21710180770129352998141024499580964469666455613123734716169584679669510873775\"\n ; \"8320010738639970594139541432443041967828948675894027397631123863826975291437\"\n |]\n ; [| \"20373837152733625366974701596758373355440504238040809868686624790270197493528\"\n ; \"12781438644864943427350664202279855672900381345640622661363395863727232461941\"\n ; \"5622234659258862655204519959448765784253304067430902712408596795866706826032\"\n |]\n ; [| \"1029291849649659108434334644503982141075719243675099861198550852722630712209\"\n ; \"3399484996504249361098308540916753999551454215950119214258113924944098529133\"\n ; \"4228806379514872892076346437718106945625482776494389450700910204388632399170\"\n |]\n ; [| \"16757668050571560648475639292687013846146697092325505133502515482647055695358\"\n ; \"18015084288230839372033169918933220044489391040316918002447358599016172874588\"\n ; \"22518355405199157615512407427389375489730975216718755365792251880852001347523\"\n |]\n ; [| \"20573368860115893940170639217949296882201199808293037762710789923980031371642\"\n ; \"9960840295218443524938341356473179849353725032041141822502293175783147220810\"\n ; \"16607996476430852400280109630637008547605338554739450722762338812055064961040\"\n |]\n ; [| \"7171658568863901784323661701131019863889729147856087046438022012589987643202\"\n ; \"10419002933357804877530761113458274768874412386136675204576115138741608012739\"\n ; \"18861306008102317898949274209011264398227868370415517665809396034224603196914\"\n |]\n ; [| \"1158669061044700880156383735717084681300773582244764163190588381073092936750\"\n ; \"22580910367253859335421514059655021468195876007209097419255510855097011721727\"\n ; \"25227641011701829958282079681052124431202635521215558068499733331989655141417\"\n |]\n ; [| \"17631556489231839623790313532079202613255385273277758734940753078216858815087\"\n ; \"12364579808565613988949646111979230705580282638991093972288646497224214207629\"\n ; \"27329142993476341161848962227966301919437953833554828144399467978240930742586\"\n |]\n ; [| \"18928954276816129093422581186438144214889196137619925522418500128918638106192\"\n ; \"2694991762120052049414391511440055444192349820338943254217225671225856705354\"\n ; \"24550218467559691781293396903076544150117989130151493573851599275085996606415\"\n |]\n ; [| \"2263637838316531719424059727023190126413315239400030877929788886432292775329\"\n ; \"17640968677322424538098309260107170953689147177463962461922714776240524875178\"\n ; \"19443928844574086327434242479460066104315747577578735497796887088983936043942\"\n |]\n ; [| \"11946837349828339651553745139029680016817294186050265590839923356905805035357\"\n ; \"22348022813139862849068148377528486325131041514035743832201785720676226808476\"\n ; \"26916778334032102178669575567836710673110496650392713945070999799105131256857\"\n |]\n ; [| \"6772367578799449199630493680882624055636516414598646521039901701866152406803\"\n ; \"12963643276721087785826784687244852783616903441339291312110495293886231701342\"\n ; \"3495180091566437950872177051556773503914696078922351249973160522225629648761\"\n |]\n ; [| \"19636722086015988900698322500132161186603083218895346390169893819062129539093\"\n ; \"5666220019570366878592707781772835552094759159906603422414363731979336135967\"\n ; \"7874102875783310620499310739194930556976996287514313823549459686051373482140\"\n |]\n ; [| \"14280578027404451144128482988128079454347604231057136906257574339598355143304\"\n ; \"5144471065355127918389406816656570319104327848925794556365711516976530276907\"\n ; \"14225884822276867436898370040228402906367131879332823332133680447067984518507\"\n |]\n ; [| \"28941268628390287870660292646709031665780090480358777746775844529193861308069\"\n ; \"13377111905191945833969566484261585035643984609846866899463874566132398229000\"\n ; \"22564078765828517667859311123307256081299021587637307540298808998440794108520\"\n |]\n |]\n }\n\nlet params_Tweedle_q =\n { Params.mds =\n [| [| \"25915736081177016241546598112391708036536987432422305635260260760208122221944\"\n ; \"16297879259961607025362014922234140032361260365432098634487800168878994764928\"\n ; \"6033733257175634837476818019847848256912403026667817175660404282168388911176\"\n |]\n ; [| \"14045886505657516091660160567697347035599074026719425910347091110613125329282\"\n ; \"28063323679221750580410141978618538612191923017649765586082296380600660325013\"\n ; \"16819697298174473653322938069684433995665518997062997223549599541089417145617\"\n |]\n ; [| \"15413524273045791515306211887939932559344561300389872507948116835986601106260\"\n ; \"36421043490025209186163871592492585408887527098720780722489614383638192290\"\n ; \"19794181301775644846947316991663934780462668882189182094267354309951373752713\"\n |]\n |]\n ; round_constants =\n [| [| \"1407093205071385134019160203229442695267924164910042285561052671714302327117\"\n ; \"11779724282856814171131489762288461172831486048510303387508269258305405159494\"\n ; \"20501356828629986222924519680141334519157249096910596964295651887901812757851\"\n |]\n ; [| \"23419085236318922177448829791267506851321183371308368120588907466638891990218\"\n ; \"23622615725307076779847815917182329276803050417362884676509671384840820735432\"\n ; \"9803250007852134109663616761249682289000165070757264268444033227122154712435\"\n |]\n ; [| \"8258125311635369235384004583299440393524061932038233801638278824513198056900\"\n ; \"7351712538809193694641892798746315547120734114915787568462574210306016208172\"\n ; \"3059129220572147109518378560013963561504677918762824375487834543428745926058\"\n |]\n ; [| \"2042383557155251217884643242454382272036567754448083296933565675865119461967\"\n ; \"15129675271994104178514880712320024929034675263917539062120100905141109232670\"\n ; \"2643699531755105343660845635266167445623854478292984863437116378029552006216\"\n |]\n ; [| \"21874906039195160027003265247067314884270948612748992177669773940314010123091\"\n ; \"19764685963582912390728638382178998584043501872176444130158409984862908383367\"\n ; \"24731701819796788156889906156124721070820824358000508514589474587782991304615\"\n |]\n ; [| \"23349997101843053192913636118003774827214499818459416641628849125511955859433\"\n ; \"24717674860585372478964575915011580548457995997758548284742988139987280611508\"\n ; \"28526106831601024593647394922551831336459814654587212090704645596629587939482\"\n |]\n ; [| \"11124237076008500471717934253870630742394346079041199265139475769025505862924\"\n ; \"5603568104404435184153167261671260274794550222989896759977234085169877356121\"\n ; \"18631968134615245163535085925543871536654560418979608277352837363265788104887\"\n |]\n ; [| \"25622000111684154876169657771818113353862466658383499382458602104118482932612\"\n ; \"14685553097248008037900441153689553464954749573708220558483151708440673116626\"\n ; \"22638290793036874494380252722781129323329912946279958525645948986012903271588\"\n |]\n ; [| \"26722642316240919944771155748582214575762636956156192045531407557947082330441\"\n ; \"11688527178001319047781582359974030014986749568962572618484185726534538143302\"\n ; \"4132435099492261681531450855031935115318187070155419444963918466294918478458\"\n |]\n ; [| \"20141284225901340938890656022639520931541470876509036146369749046098483015757\"\n ; \"18736332138502980964445308743240819782522235173987082303305443804684531454297\"\n ; \"17600693717098925665126422004940106422694608593016843967562670357150381420609\"\n |]\n ; [| \"18592614129146387690177360441516834331069369945676621261719641293117078327702\"\n ; \"14150577074637411884886261168762693600439005064514241836521926118301097417857\"\n ; \"19031036144447273288422615508693769842934451415657310442034112526338125336308\"\n |]\n ; [| \"26053352781064856963576604784372156952426155549559043326273302769112379165473\"\n ; \"12778639913079427028917330759671637587295979742641290726186546285252525246028\"\n ; \"21084419118692958743436020036593002996130380427307664962379311458126599853734\"\n |]\n ; [| \"1683679732388236007430336774551658766186300637910023597309960010871812663155\"\n ; \"382382265518823882035704612421171594350637534457994341641249505478238999843\"\n ; \"24103231983573822934379730503341131278940831646017600293219010706164863268100\"\n |]\n ; [| \"15002924105159692538984514753644972208898096660405454273558411866368262628713\"\n ; \"8060462184755100984999826027229470284760371993470314636251170461776357079944\"\n ; \"8014397154910879842052615519912717212158245202057892272449783600873015574114\"\n |]\n ; [| \"22515836383808274667935072370173638116426359208031587416631515348588332802165\"\n ; \"16360177906204352406408982804994067585455569983797470664902705838290946655225\"\n ; \"7377024122149545148833892203521810447795322854651603924615290711324827954389\"\n |]\n ; [| \"13822535231889686674929431810384661533456403404275348094834293881078653521828\"\n ; \"11336050547636194564207457615233402475265718541062192408495224405268258092008\"\n ; \"18805821644425041501933345241847488386094077373308766699152348641373866215637\"\n |]\n ; [| \"2953706678908410496027875422038498650868917425939787828661796632154883847146\"\n ; \"22240918382283561059183778204822808538520952332636130676150942209160161480801\"\n ; \"16015663662903953014672458804500981049100146349056166187951058089247981862386\"\n |]\n ; [| \"24566120104055916417636960820360051385362045582201684271866443305615866009754\"\n ; \"15228716568582234525417425530930303055506743342549413293218302255768537007353\"\n ; \"28426124059260498940560550539619538039187481771001333967681038135790962915359\"\n |]\n ; [| \"12599554983931780658667521993267051645893868162155451498896637831795673118184\"\n ; \"1743852770826535536371230785504182299307419480962231494027537273484933148311\"\n ; \"16732518316750597282164750160114357349321948404345032126728303794088049194652\"\n |]\n ; [| \"2939281672959978006600800750725734354669446788664764296199685579097815688131\"\n ; \"556549314727718724918645466738763616425350766385166232734551188399043650782\"\n ; \"6329117812888271765311270770521948075037705083688439409207121873030159665123\"\n |]\n ; [| \"6923365867589651412567397268415595797793475737512742162240319715473926481537\"\n ; \"4709424083348196884624344278997759837872647743148178850362091985071988205427\"\n ; \"1605876544033197953000953983514955993933721338350067171290806459066306025695\"\n |]\n ; [| \"4856902810419335425286300966705023110125381957049978608074194350995662024158\"\n ; \"20115199687715104656653685599631056012389662876070860842940278390288575808663\"\n ; \"22603228560902176600736298140950778622069342058615699936072284883863656072632\"\n |]\n ; [| \"24638889469288846994071707357580162402582890839221549302411376340642923220642\"\n ; \"8913206227935260631493024400945766094870661822141101533706907528294845461904\"\n ; \"8927637538483897027107933030206270470499387407187148996083180177802476521625\"\n |]\n ; [| \"25384650098348911768966273053118959028169194481031323865282329732266030144680\"\n ; \"8576715726771771074868969966299138879569870568699811773298590613391459414307\"\n ; \"3736564798057387316276742408343458912069444888643530254776791689428332583857\"\n |]\n ; [| \"20271224536548381827255516591952574401260411805623699585521321246109241454930\"\n ; \"22919819358488746629260266084595897095209320929848482502446393294056491878897\"\n ; \"25806583473442384033721287178211835499298441266111076622895704944892288698730\"\n |]\n ; [| \"11271425654462192981130104009501267954567715499141722773571838183810298369617\"\n ; \"11963379853558729949243781995772428902494203393999693908696977832618218983729\"\n ; \"13559702535330349895320048426685665280396765028909072427284399240094315358267\"\n |]\n ; [| \"27798947305954309531282132451491992692211979630877274468503798794516296093624\"\n ; \"10139836872400883770038180190686397055576624900289129633646571009821193103303\"\n ; \"1681175063131614831383428140062517416675656042319902366945851342455320095975\"\n |]\n ; [| \"762311789472828450694939050895584869062612821719579283252590387322583966709\"\n ; \"2491291459395889912950418486840554679531585085810901240245257580168300654138\"\n ; \"26335391344920052134408519665978324228030775533115901754595026922650621387203\"\n |]\n ; [| \"5213934155193667555020919712276789476025967849892310766358967009263904788906\"\n ; \"21596654192879006807545262299640391626541355389417053174982949135914632601259\"\n ; \"11543651420409105093285035822258612547933041509768934342943688172902948155496\"\n |]\n ; [| \"6912476548173319038280387824458412456324099644037049670165470126637201776352\"\n ; \"1249979215389391088361432819941458017849901973474233553675756693352168310261\"\n ; \"8800672549391869855287240050462700541180857572619168816793782094195159154680\"\n |]\n ; [| \"28839355932304714762685479310377995008738258609935766418698284661589499598024\"\n ; \"9159710460329873378525040285653524567247412401936807205880030247592503719192\"\n ; \"3169998943567105341123452675041701435607857255203848874399754618805253622740\"\n |]\n ; [| \"10847531416223195148660243132827532434469902981120107367281282638460589851312\"\n ; \"14278009698362110794389980561773702824351567830428544578500093225142170712282\"\n ; \"9939277074183953713358210481928994846174442435889738896177490616666695764405\"\n |]\n ; [| \"326943879771829400219165757090427396897467323936588117324383366036029433704\"\n ; \"9374630771131918886890707351323606275428692663736893032376887751531034826056\"\n ; \"11290359581308816011059133790190691320815711617432693226101285885253555535565\"\n |]\n ; [| \"3911773409691474638225302262361438181771774863685935030974147227178932759469\"\n ; \"22956796290890941726039085400420127418179229593189943764136263359967499205095\"\n ; \"24905285680262095209614295868376139501135921243025528029309869104981722146091\"\n |]\n ; [| \"15396187849300264600949181619153171915541270808841426006223982193824166071313\"\n ; \"2021103552199756934225861737484570471349644013573281450873950919842892776230\"\n ; \"27806074863915516268783086994108941110298172438899852542592001290302316983529\"\n |]\n ; [| \"20850985044745265985587285429983550433472508184202273658904387230312500935146\"\n ; \"26750188037261381177305438051189173436844269300804365655670910061723402311840\"\n ; \"5346322587722845563528031827169305184007234875695836707960307122364690080342\"\n |]\n ; [| \"6220486513127683592919002338026088751244535283268014603675952476125549409312\"\n ; \"19903676557766566961511712707831152869695369024367352451363145661501930906935\"\n ; \"1180890285168209978184781715739655933965222804468162152537914819015316336929\"\n |]\n ; [| \"14777748415006576804127517907788573988371775407557947805900937323975909847953\"\n ; \"20105710741166769379631189443035554033451548978342191459802351018727518338375\"\n ; \"15000279473920339785489843141790752670514139742561441953224274301751356279088\"\n |]\n ; [| \"10845580737423146858413611539996656798831260499192914333052323948287095325896\"\n ; \"9807299453661141796892511560669448305233135023678812710641622817525465476789\"\n ; \"18820070346872194506701007873416449730211513161354530152730232231128055179020\"\n |]\n ; [| \"21552635109132824636995550194415349978714050563816356406378271654768042443914\"\n ; \"424252812084212000584148587569013716105926976846895922827871912164530554017\"\n ; \"19731111636912344832419806270898792823432039785853920997930198140374517037138\"\n |]\n ; [| \"22034227457855960657032112217714947497269347815575055932350706059498866808825\"\n ; \"28900549436482563321706115220019073654618056963014478327301367425569435393025\"\n ; \"9690323567346977726143631917040896368566497117131585170975102457752911385070\"\n |]\n ; [| \"24901777589153809722090856106322215040853844303892027345081846927117655474799\"\n ; \"24618629228062397341252905498799061176053328430774401516486784312004562743191\"\n ; \"28607940154394052066154355049458241016994677703128094815451893517962352487603\"\n |]\n ; [| \"28028628276659162325922057320540093432599391103119722511477699756313028345898\"\n ; \"22855357183685501398606162033830514721290735737703014103574096507164859341813\"\n ; \"27834367819357692909285882545810100377631199500915361384737671966983146025809\"\n |]\n ; [| \"1152586797671427538966496719385915934546059520122802470413322678492958894682\"\n ; \"508384107034063705486611598325755112413731704833369868231768120077490444630\"\n ; \"19300657361561951607131776332671479212098250434693263049514294780805629653473\"\n |]\n ; [| \"15470960985350481400842167015023775571355492800121582793999502093397427698383\"\n ; \"17720942074350206208330220964590971549266016335665304491607989853024314401251\"\n ; \"28851134571887486837044103758388058466256575668947796957305978438699899353287\"\n |]\n ; [| \"3578785053164294612963526112344478663211208096085744338409755465254754875674\"\n ; \"21326437066553963598520552760114586864776638322466352011871692222662384645363\"\n ; \"13429745934270095487255860144847939327740721270623398376981782305947706095670\"\n |]\n ; [| \"26319050026331552836426774369067652650059182744902567571224496539143745005789\"\n ; \"1078263435617676875695007120605477838039487913270059992176509301150569425787\"\n ; \"20512958822951485066323868584206248027312484777844371817239233161574729401619\"\n |]\n ; [| \"3439862210936907243622471091733755342416004198449084092526552267425888891334\"\n ; \"26344024615038835357968358502500389300221110985359344438627145422128854936010\"\n ; \"4407509671483019180323111663733989542669030294423331160640503012574051046463\"\n |]\n ; [| \"23686502687109748462558238297713453205336655550865311005650407347470798706276\"\n ; \"20935865617522634258880604534809753050761951325231883554583651243657755177384\"\n ; \"28068466419776916874263313788106583531149883580106732537932576845496874610760\"\n |]\n ; [| \"9340583216031797210406121496934538779821608465213537538754368179509091190496\"\n ; \"8378478185794583011191561708485020796460113225246093188020296866408689405447\"\n ; \"13593729876983630500293152970812869181694169206857373826104652065849275824904\"\n |]\n ; [| \"225582802476164593958918341784756417052231176877435466478201328339339298792\"\n ; \"11190000628324239936372479652026730262762535908110580922398549511844970564726\"\n ; \"14408510109047970600383365920163973974300511112581396474451952115423633760669\"\n |]\n ; [| \"15419712893693617903799150033771605514243986042167614240262941635002474003403\"\n ; \"7731439925760230991749404015249576908754514348048350297750723620909282729431\"\n ; \"19666770682774865023295895307812388197776507921636129891377759111914829255638\"\n |]\n ; [| \"8087212899093356791510655283154899277086785698103236127882829927797366304828\"\n ; \"20433944315277380264641847906582628806193939008300369182185651050982835630279\"\n ; \"19313210645126659866795487832507797079135783289793587088105157706081916299559\"\n |]\n ; [| \"9123328805166387524465533579226697545839760827737590290669661663774141633743\"\n ; \"3879879306261238409785977281757250639343229913301993681022375404219618433235\"\n ; \"9517409716012760917696192179044536803939394129766651220028362590735480122573\"\n |]\n ; [| \"20332463768718929699130730432447025575189976076426482297440430469341755042921\"\n ; \"23053672884236177934514268600149479745125027580775805056144654269680148757624\"\n ; \"25226946353885521968414981773406166683897441042573998588821906686512894266029\"\n |]\n ; [| \"21175609603299698220053961274718080893444373067044100451463712419133495237612\"\n ; \"9553694240553762923597118226736247618469252203348132132110825914961792198835\"\n ; \"17843854580091429191163038608499805869715159461506741160730374911681651289471\"\n |]\n ; [| \"14269966061002750716248007081424385164175906346684599134425437034554624251236\"\n ; \"5362620995145057363259413950799285152609317352806427035690937773014391566299\"\n ; \"4205064533075248547624548681629884406823264917512221686783667975932358100596\"\n |]\n ; [| \"1447928410709031033534935853216514556147486755632766593078722977427728960730\"\n ; \"28245240921931699941506083221177914425757254840948018801597419359119971216733\"\n ; \"26525902932142017663120008236364707593713540498564605735573010501454347937720\"\n |]\n ; [| \"7368631296987951000711115613504553604704592237398914353915901403543114662889\"\n ; \"5554881053965220973295749123586734879290036494602787556161693926447302760390\"\n ; \"24967171202016264042634677694667363841007103245517469364248634966946756557992\"\n |]\n ; [| \"11573826089465863056429265227887713664716641745106347139398991914839486636523\"\n ; \"1937718699958481554769675564975554369566343919737475668546953656937087754563\"\n ; \"11930922536251020493907238369241004043321211518887691790013224522248735046033\"\n |]\n ; [| \"22785017658870359000526032391904855161537701900296638953930381770914415145341\"\n ; \"25976628305796286420142020978093161249350138636110131585936062956834855313329\"\n ; \"16303236307764870561352823146290518191951038219791428310990760657710142544538\"\n |]\n ; [| \"27093108982678491292736852279722292369809241753037402387831341673617292355433\"\n ; \"7240163250117019016769197875995700032806501977645639130984508545602324096827\"\n ; \"22203724525852948038550437387972982668395471437091775649961488356662998264151\"\n |]\n ; [| \"4684246545018636131749425719987566020282183864196151512373949996479685177204\"\n ; \"25146969866420782139590198915491672984778622065064131222228045794185882122026\"\n ; \"27592425452661098730505196328609404774740926022433368462118081059212268546033\"\n |]\n ; [| \"17586009379821990524587867681671154015571782654760878221394286500330572879956\"\n ; \"17466109782412583174035666757463650324907665895615102404350838404505294814861\"\n ; \"6801099680371208186449438911369486272231733437775451500294923992271849771500\"\n |]\n ; [| \"14709234089749348360616371037761032504562743719673952659049173960937006221457\"\n ; \"20550184887334781662092751106487190173000191851604597380877613197870113909079\"\n ; \"28406290890506223928300453112417162962784806964069027890524481548485194752847\"\n |]\n ; [| \"481714770023051785525400834238336329808423276768584726829869103876837700377\"\n ; \"4020991797205864659257764480061098490500855823437474389403990553320209934398\"\n ; \"16337095167623579562847225379575824048052657014596464618336659839371535688692\"\n |]\n ; [| \"23217111278739825984846557926350102803991056777137304871503782411490597852276\"\n ; \"12165535003710678763048152747651928445434323221944097116678948970350369208929\"\n ; \"9488689094750447786105144162385165112898472220919295987197253237633013659895\"\n |]\n ; [| \"15982980312773671675473213613073972898714178082762602910121113887258972139946\"\n ; \"21878657311388335888708327724490657766902944759667044620416025845959804126630\"\n ; \"13675090710467970179628129651886021836957928350486496127049130621993923573755\"\n |]\n ; [| \"20917518447937574010663058701489181063333313587680044759711243380728520685863\"\n ; \"6170213040301483568981693148798365424121650111680781917289361228522864615996\"\n ; \"21775919999815502126259344494851143760329007416636852564546368286124982536695\"\n |]\n ; [| \"24368490522730194755777521472193388991367336341364002103399150275833011922423\"\n ; \"23758037332911549734847840203343330629256629298188143399488142378421247847690\"\n ; \"27571203431800228771338832670745356383939659914478358343820683195821147658740\"\n |]\n ; [| \"13755890941050195595545518932064686480206338615096777475340391971161142758063\"\n ; \"1146646539267290799737842332448542194132747795692489481869657131476583545261\"\n ; \"12804413470423903667943767263817101023115585083457063162343920360142649266798\"\n |]\n ; [| \"14409531300005419187223363160445506887342750079089420367658939335895822993543\"\n ; \"17814204056137953075459933026732902773040596329028927521838357681289997118113\"\n ; \"7817950203232955618618957010364419159456278143380878513604058657652018062980\"\n |]\n ; [| \"25960264684815433578190462022149634694335702464818992353329781703033013233121\"\n ; \"25759640500090985800437893091627346304260382311106694139575298427306966520523\"\n ; \"28367407529609657391892674962602105816261356754665670959257133180337999840539\"\n |]\n ; [| \"14266800571483937742793133924056626153889815742052966634816685646807339508312\"\n ; \"19127339481560024189602206365457486575195002728494501053095019117702139872893\"\n ; \"28519789563308940253093752790854817966629126140155280689836626891738001080737\"\n |]\n ; [| \"6956040341676069594538770374637867923851690699633394576277451833826951657961\"\n ; \"21005839334445364578511922473026653470661503168441639424115223139672665178130\"\n ; \"28315945273881727033707996355494725432549327504432844662583768252508930919892\"\n |]\n ; [| \"23821368050370699560443847027609270446880531147779436118159731211758008434917\"\n ; \"16481474195192864226077436336148187210130651787958956807674920780544075759296\"\n ; \"9201162478838874386717176037702794693750993812982695310231747629926752684935\"\n |]\n ; [| \"28632598467805640977248891280150694716252721359271588938464824193707123356074\"\n ; \"26685464290112784835718410452005685502357915255553654159429733217095134319675\"\n ; \"23238436156616628957271098742219023373736106288667637787431116054734729902810\"\n |]\n ; [| \"11100700451337429910479488290132218019001384186778460632129760648736641453089\"\n ; \"1514360569355020424898405719576361021811778172693203007691280959952152364455\"\n ; \"8340047814157949706510940907075594981467165368035215496966506269014211515161\"\n |]\n ; [| \"2427640653249618892553580189088976454401710146993511837542094625722279344011\"\n ; \"13594733327028460655848011453697829703783521855510653296924838920678502849608\"\n ; \"23299557907058685778984064294190866024328373590131005250950142719507348823505\"\n |]\n ; [| \"16957366136159159628470985738911466666552608209993423872602970163277075193826\"\n ; \"18413473853520613049315131192841305891076833008669861411383562686504219287358\"\n ; \"23006926050889222476128897576830486416666235970076803315213892539278411622015\"\n |]\n ; [| \"9774905316340561579539853883151948424138741303135183297579387042285531085133\"\n ; \"10269962303207382593854468302115992150940915300353510160768219325150644267118\"\n ; \"7959157234270969248940923336563675290410277851870343572948477386731238161393\"\n |]\n ; [| \"16106024964504098503571852149534027928523108637339842287012373190722613251659\"\n ; \"14745173385311451223498911097599033554863252099869795844775385009273683860264\"\n ; \"19937960969760569200449808442711281818884901583558873199752602417155970563987\"\n |]\n ; [| \"3182366146375526747362994559814691338395593175949415378173407263876720083397\"\n ; \"17413302548292738580314411603626834416295685927950587784515273510105438873422\"\n ; \"4889919393105279580426440996922797206571373750340190707744646290242059542853\"\n |]\n ; [| \"12846868702289135169703545726353247801195875942556949295948719366264621666233\"\n ; \"216026894661943610141047365076631027216797294256741428193225490408409896066\"\n ; \"5594507038710796719799954595203002154918429779115131548267228293545608955934\"\n |]\n ; [| \"20683325187150331608421945253309437504612179745536037022444222877738935657188\"\n ; \"17258155199327171857088567149720370973460517702673221805327154937215155098037\"\n ; \"19531451346903375647980488842525266722395393577734760487171780808563121552715\"\n |]\n ; [| \"15001316252470008872398592005036567799341341008679319658354851032874333308382\"\n ; \"3153366364932652911576884248299389708958131128720414599588818761136290661667\"\n ; \"6755239607153943600624506592209826209761618621309160929893160538996653160964\"\n |]\n ; [| \"27386913053417648783169595109305635785586212401824032172587510910095445670008\"\n ; \"13255419335681899162220762381979787288418216927844199356802168847207218078328\"\n ; \"24056932697318807312802542300271008041574260214121915600042800629313367235460\"\n |]\n ; [| \"681706469194140471433006526218256921616949602161281492934799081124952223492\"\n ; \"7859466024237704991714057608591467007441884809553786534483120034131115786526\"\n ; \"16700668341177433681838948975596616692527529309395474903935090736709940070878\"\n |]\n ; [| \"22901316653569929238119228745362176008602504925113946861459962514753719309663\"\n ; \"22640283367220911539563798732800666806616130576227469449706008775827807382817\"\n ; \"19535281588527177916573861327698030605390832518994091195537441015284187660038\"\n |]\n ; [| \"24027911193734335746676746844040947617820732337092851583866178947775548114262\"\n ; \"18133232728995811983770470174587129261332348411742016303225452920487624098342\"\n ; \"5194749654862040835697949936835668263923802179629880492924388865332422989363\"\n |]\n ; [| \"9316005463786577585413113516915677504827184958655839058352363543312786833160\"\n ; \"19044257614252585758763026210126521817485691264322479305708941715087727988354\"\n ; \"24488455675278660807809390650162487037017599485528141481545441190036504950534\"\n |]\n ; [| \"20189530657293446691983795945222508167625355746118650082940427940595276845732\"\n ; \"18164715324891407664606312435855154695754327590709603495801185914278567423821\"\n ; \"3777285533445984127387924239502713396887498568124548831616871789655039173588\"\n |]\n ; [| \"15592830182691848850373386427196961486282012390610273530420460470172877717683\"\n ; \"25760859528166610551872518774575759523111878433095409331041961249196989169616\"\n ; \"24722046352010883056709269730597243888430933191481739010765617998146349934086\"\n |]\n ; [| \"28753571052849887152802307457879116732346031260848508112338593673454875118992\"\n ; \"3001384261845987887110277211273546956213661938635022280612595622904841185681\"\n ; \"14677009419547603678203788843515487352782342288802842850372444676527117589395\"\n |]\n ; [| \"22844611608619408029685336179217843453642421101233912107898751889136663864792\"\n ; \"17906137102637384489732199749359922643081810160900805140716991796711023316200\"\n ; \"586544213343455846993111183121079851951145071960141918284223009850760128570\"\n |]\n ; [| \"10073022737051199071936469142782915912111557650707356761559885949095600793223\"\n ; \"18767707439586621911012683484743285554245197776295242644551355924169214852141\"\n ; \"4119962398253504109413010562733363762918650892359086980174059883847160426733\"\n |]\n ; [| \"22822667561075354253870135521524118501968910357712769905157593725117077725730\"\n ; \"19021134546417697443807407377942768385512805335328886525219419127991328099808\"\n ; \"543520545955418275520704370531208732549254996101593838150191956610790962041\"\n |]\n ; [| \"13465682039988507334664785354077591628283934378748051390584708440723246405022\"\n ; \"14968258475921764664246292128413258686551060309754574320898450232154678954678\"\n ; \"21308271006956028514569991019983954873714018423377636189886404602491045197837\"\n |]\n ; [| \"8144208462590654621513596158704608446866068401332835980335197042714849642337\"\n ; \"20834284501721431645327510539019601687008489803392802952240179181017009408562\"\n ; \"28229089440547774816202807517944174133449953515318622356237408090506536035121\"\n |]\n ; [| \"4701139152778460212311525289989698272661680893554566356761097167593286071097\"\n ; \"1311177055788535572979185179079106285448805711141806719704208925309029338758\"\n ; \"15261537101227695093574937572139198753629872383884947512058428039104133367921\"\n |]\n |]\n }\n\nlet params_Pasta_p_legacy =\n { Params.mds =\n [| [| \"5328350144166205084223774245058198666309664348635459768305312917086056785354\"\n ; \"15214731724107930304595906373487084110291887262136882623959435918484004667388\"\n ; \"22399519358931858664262538157042328690232277435337286643350379269028878354609\"\n |]\n ; [| \"10086628405675314879458652402278736459294354590428582803795166650930540770072\"\n ; \"17127968360683744052278857147989507037142007029142438136689352416106177192235\"\n ; \"14207324749280135281015658576564097509614634975132487654324863824516044294735\"\n |]\n ; [| \"3059104278162906687184746935153057867173086006783171716838577369156969739687\"\n ; \"16755849208683706534025643823697988418063305979108082130624352443958404325985\"\n ; \"16889774624482628108075965871448623911656600744832339664842346756371603433407\"\n |]\n |]\n ; round_constants =\n [| [| \"1346081094044643970582493287085428191977688221215786919106342366360741041016\"\n ; \"10635969173348128974923358283368657934408577270968219574411363948927109531877\"\n ; \"18431955373344919956072236142080066866861234899777299873162413437379924987003\"\n |]\n ; [| \"5797044060651575840084283729791357462720161727701814038830889113712361837236\"\n ; \"931288489507796144596974766082847744938192694315568692730730202141894005205\"\n ; \"13659894470945121760517769979107966886673294523737498361566285362771110125394\"\n |]\n ; [| \"6076231707445968054305995680347976771585015308155855387339303513025362636128\"\n ; \"28822740034050339685362260108484262889265034407340240070058997651710236456303\"\n ; \"23420266473857869790486107029614186913447272961845992963194006142267563993493\"\n |]\n ; [| \"13753917374184785903125509246122783296344288469304898921025291716613575849357\"\n ; \"22396739346703340038555577564698139382745239004673153148674304627904081092826\"\n ; \"13064238335532551154986111986409392866270911640785653458047811526842088084911\"\n |]\n ; [| \"23165923875642452719095776619341762858050322341374771345641255745672274104746\"\n ; \"1876216571769482372914291210815859835162659440705283782713345335434924136736\"\n ; \"25448252060136178247213604035267580231762596830634036926922217427938159849142\"\n |]\n ; [| \"2161875315509206970842862195937323600322108268401381254431163181777726747153\"\n ; \"19159855698625842998331760283165907305622417625829203038229273729196960321630\"\n ; \"24828563875172432296791053766778475681869974948122169083176331088266823626561\"\n |]\n ; [| \"15959479662608710141128458274961057999257961784282074767105536637788386907463\"\n ; \"8006369581283017287449277389162056290714176164680299906116833200510117952858\"\n ; \"18794336794618132129607701188430371953320538976527988886453665523008714542779\"\n |]\n ; [| \"19408271715954593722501381885401160867835377473312521553027032015227895029571\"\n ; \"13654747284005184272412579731446984220568337794941823533879059135026064413631\"\n ; \"14094055032353750931629930778481002727722804310855727808905931659115939920989\"\n |]\n ; [| \"13241818625838429282823260827177433104574315653706102174619924764342778921524\"\n ; \"25709259239494174564705048436260891089407557689981668111890003079561388887725\"\n ; \"26866626910239634723971078462134580196819809568632305020800296809092442642381\"\n |]\n ; [| \"23886826350713085163238005260075062110062681905356997481925492650252417143049\"\n ; \"16853602711255261520713463306790360324679500458440235992292027384928526778856\"\n ; \"18444710386168488194610417945072711530390091945738595259171890487504771614189\"\n |]\n ; [| \"16896789009769903615328691751424474161656500693270070895928499575572871141439\"\n ; \"23842266984616972287898037872537536999393060934879414668030219493005225085992\"\n ; \"24369698563802298585444760814856330583118549706483939267059237951238240608187\"\n |]\n ; [| \"25360195173713628054110426524260405937218170863260484655473435413697869858790\"\n ; \"1486437708678506228822038923353468635394979165769861487132708983207562337116\"\n ; \"18653498960429911228442559598959970807723487073275324556015861725806677047150\"\n |]\n ; [| \"18878179044241268037057256060083772636369783391816038647949347814518015576522\"\n ; \"178715779905629247116805974152863592571182389085419970371289655361443016848\"\n ; \"8381006794425876451998903949255801618132578446062133243427381291481465852184\"\n |]\n ; [| \"4176946262813877719206528849579392120806054050640974718891398605746592169324\"\n ; \"16376345520728802444699629729684297833862527190772376028981704525651968727081\"\n ; \"8399065769082251057361366626601550736334213197703006866551331927128775757919\"\n |]\n ; [| \"15435308585611812393531506745122614542196708285088622615406141986333182280857\"\n ; \"4082259282787276939431186930090898350392871145699460879678141552997816391817\"\n ; \"26348742719959309014730178326877937464605873211235784184917342950648457078699\"\n |]\n ; [| \"9707631711734344681918469569872517425107158187591261754498805460753455298868\"\n ; \"27910768846011709391567916011595957279088224137468948238696800459136335473132\"\n ; \"20407239095656434708569263842372155762970847207558227886302782130015730063802\"\n |]\n ; [| \"22726225412881182965250630589245572283256255052470345984553083359461473893802\"\n ; \"12443967854426795490638709950679156338200426963050610832781263082981525248175\"\n ; \"27102543658848146076219989119639465430524061997280788166887046421706499775415\"\n |]\n ; [| \"14427224233985680214097547669945064793149553513421479297921556194475574770861\"\n ; \"22917454832925781549840198815703114840452733537799472739275668965081704937832\"\n ; \"3455076056123630366063931123762198941796412458154689469887583689725886013901\"\n |]\n ; [| \"4513100023937785913596662867311227004762025658663076805918211014066645403017\"\n ; \"18187619530784075723418065322038024507729605774832001333883311123910954334059\"\n ; \"9447065431426150382325592560406989926365684509675374414068135115024495130938\"\n |]\n ; [| \"3227816098015819796753427754968234889554095489076864339942014527747604603014\"\n ; \"14798316759185072116520458171957899889489461918408669809912344751222514418582\"\n ; \"23013904852315603905843158448056763116188801262838729536210355401378476650033\"\n |]\n ; [| \"20979191509934291452182967564058656088941447895799901211038858159903580333267\"\n ; \"20772973010251235271448378823573767262405703078344288856168565499702414379868\"\n ; \"10105446427739226002497411811738001382334316505480517822035303561899927603685\"\n |]\n ; [| \"11079074761356717003579108002319997196881121172538617046865136940931215263187\"\n ; \"4693927775411489288330326150094711670434597808961717172753867514688725690438\"\n ; \"18581720304902876944842830383273503265470859268712618325357902881821721540119\"\n |]\n ; [| \"3065369948183164725765083504606321683481629263177690053939474679689088169185\"\n ; \"18515622379147081456114962668688706121098539582467584736624699157043365677487\"\n ; \"17563088600719312877716085528177751048248154461245613291986010180187238198006\"\n |]\n ; [| \"26199746176994924146211004840756471702409132230831594954444947705902602287290\"\n ; \"7576136600627345523051497639367002272003104458453478964661395239732811642605\"\n ; \"20058687874612168338994287374025378897088936171250328231848098497610185784281\"\n |]\n ; [| \"16894722532414195606958290526999761110785277556463400588047573469106594850228\"\n ; \"13961730805696859614283621225672002906734926278118993580398533742874863598733\"\n ; \"25256842011135514243352951950573936602906198374305137963222382546140030647211\"\n |]\n ; [| \"18530360047537856737482157200091774590035773602620205695980247565433703032532\"\n ; \"23014819965938599260086897799541446473887833964178378497976832161473586995397\"\n ; \"27911426213258307990762460361663504655967992659180759140364181941291843542489\"\n |]\n ; [| \"1067338118323302017358103178057182291035336430305886255160210378977812067042\"\n ; \"17219092885519007424608854460610388434712113621163885775309496940189894433620\"\n ; \"16432921127615937542183846559291144733339643093361323334499888895135356545408\"\n |]\n ; [| \"28608851042959977114787048070153637607786033079364369200270218128830983558707\"\n ; \"10121629780013165888398831090128011045011860641816380162950736555305748332191\"\n ; \"2348036340843128746981122630521268144839343500596932561106759754644596320722\"\n |]\n ; [| \"16619881370356823200358060093334065394764987467483650323706184068451904156452\"\n ; \"2302436627861989749837563733434625231689351276818486757748445924305258835336\"\n ; \"27514536540953539473280001431110316405453388911725550380123851609652679788049\"\n |]\n ; [| \"9459277727420672604737117687200019308525004979918488827092207438664125039815\"\n ; \"23425670740358068509956137586663046763224562225383386726193078231034380596217\"\n ; \"7641885067011661443791509688937280323563328029517832788240965464798835873658\"\n |]\n ; [| \"9579420382351699601929202663836555665702024548386778299996961509578687980280\"\n ; \"18513671386572584282611234979588379470994484682444053600751415262497237017703\"\n ; \"24923151431234706142737221165378041700050312199585085101919834422744926421604\"\n |]\n ; [| \"21131320841803068139502705966375283830095161079635803028011171241658723560073\"\n ; \"19208476595309656066589572658712717685014329237892885950958199953675225096566\"\n ; \"24023185216737416080949689106968568821656545490748664446389634158498624398204\"\n |]\n ; [| \"7510552996848634969347937904645640209946785877619890235458182993413526028718\"\n ; \"3694415017252995094553868781762548289196990492336482360084813900937464847638\"\n ; \"9219021070107873028263141554048987416559034633883158827414043929220388719352\"\n |]\n ; [| \"5058327241234443421111591959922712922949620710493120384930391763032694640881\"\n ; \"13148252221647574076185511663661016015859769210867362839817254885265598775418\"\n ; \"15186790492457240277904880519227706403545816456632095870015828239411033220638\"\n |]\n ; [| \"2775942914650502409705888572245750999561427024488403026572311267798009048466\"\n ; \"6277965230841030155341171319927732572492215818164736949144854827643964384893\"\n ; \"24144742149845235561087977558785057713814731737434473021812189457617252043745\"\n |]\n ; [| \"25789129719327437503403457598813971826156253950521984610569937361506914183550\"\n ; \"21500534320778995945845999974779950304491968082325255355181901574840373597824\"\n ; \"17185359848218837018503091932245529880546896465437232425673134558221638601375\"\n |]\n ; [| \"12253896579078110143384981818031883112606762215016553811786428215758384195713\"\n ; \"12956658260778456372481429232709881794962204180363200699121804724437678625542\"\n ; \"3023603786717368708677300377055384474816569333060487675635618249403832078921\"\n |]\n ; [| \"4186492855716808019562789862833898284927736051002588766326482010810259565130\"\n ; \"4263939782228419774639068267872291539552889472311225829898746091327730032923\"\n ; \"24068843626280451423530509388397151179174104901782990365720205643492047328816\"\n |]\n ; [| \"14564937827374621319716285527475223392664010281568256859627186463065876537730\"\n ; \"28367596550218705971881480694115935470211319172596432472834880507822452927283\"\n ; \"28712267437482356021504544448225827500268648754270274754623969882031853409874\"\n |]\n ; [| \"4542596163006916397403529184431773692747461300288194722982487051249951403191\"\n ; \"2530461821259252672899452671728393208543894014761816288817584587718369998371\"\n ; \"12886393063011539390567049190923398676964700147222878509238966758839020897414\"\n |]\n ; [| \"21593897590707514492037699253654745501762191795293908682495110982956631870528\"\n ; \"13233005790593128135480716846773978578237145313006994631606474472023504621256\"\n ; \"21621863098292803642478350494794106282518362577273973885587684567452726939909\"\n |]\n ; [| \"26068620073001644720969640099644251616742620988609091568084348314770436291745\"\n ; \"18248589586787935500122854210401321966459127818593446990365211078521058875685\"\n ; \"21247134484403265289037859533347798468858819117600251067578809852124865474448\"\n |]\n ; [| \"7947383127165915366383984718363902897504221803836013123394785749404572432524\"\n ; \"22173041014621867335598230447618036223462011647696367239478182269973488867154\"\n ; \"16773227734018849308448505860847939069870370055633571816925675705713088305139\"\n |]\n ; [| \"10708707957340055662073314227607620808612686977606082605219160019699644826999\"\n ; \"21249897193797038261479589555720746994050836195265348846222835266344091683000\"\n ; \"12581195059139097540117398803363514148192715293133623516709277290477633379593\"\n |]\n ; [| \"19779599816866992123290302397082614570282926215253589712189610064229996603178\"\n ; \"21749216503901548676985371189807470207364320167486559936962401093285243029177\"\n ; \"17600045923623503357380202389718735904174992978547372448837488832457719009224\"\n |]\n ; [| \"2732872979548118117758016335601225525660858727422778256671975055129965858636\"\n ; \"13703031005128062046175331918702218558750713240446179585947851411173844703597\"\n ; \"28447710105386636841938034820015573492556750872924193415447818187228356409281\"\n |]\n ; [| \"28539960355005748517007309210788803416171161412204526246799800716567376494244\"\n ; \"21329318452221893900731030722137844458345358926323127858742388587761302609863\"\n ; \"28135302149599894709369178097439582767613940517471323224020113411362601191873\"\n |]\n ; [| \"24980774120400248734054527936006392540889095705961960837980443629260392758683\"\n ; \"20339911045808632098936066397942175169549806052128535543540543556255197716643\"\n ; \"7929293103930252545581851978492699598413941396422930641071359388697302362494\"\n |]\n ; [| \"8911092207145893152276662096451247820054843777071569723455408545101628926203\"\n ; \"19648860643145256523615441075182036100116634560394529500146405733687718224516\"\n ; \"14635387208623683806428528837466762532853903031263830054986064902455379735903\"\n |]\n ; [| \"11555212214346132926966321609673228184079851030522218543981385635403167028692\"\n ; \"20896918157639814425520058178561910811657326967880217845710779511927814874973\"\n ; \"4650158165912007049140499755153804318686705949436165235742106170124284287326\"\n |]\n ; [| \"13880660273492757167295696447853232191657893303250187467329180558670697369810\"\n ; \"8043529172463774320604378774840863923445982272478964686447801046272917236836\"\n ; \"2134399296482715903442913099374581981696436050603410080564843555725771329441\"\n |]\n ; [| \"27320952903412641133501507962185246982787769547770982814240701526492601978122\"\n ; \"23417491374379751329394424924400186404791519133465537872457405970098902747611\"\n ; \"17612427354278346772575179176139417348059847375297761006336024476146551185903\"\n |]\n ; [| \"10710998507064742997612080847223278109404482930427999113323732519626499166548\"\n ; \"14958094513415797513745395709487730603918953350067504982704138489305723550923\"\n ; \"24096319595904213497633343966229498735553590589105811393277073274927955202995\"\n |]\n ; [| \"17983724131200292654039765185049138356840415443160477259330748730019147254309\"\n ; \"17598096800487588874709548646068838880468456205252324677357706597166777506441\"\n ; \"27420647821110229619898200875848631488422182349567475956209153112306555222281\"\n |]\n ; [| \"448538544835457571662601142415301047108854812427100562339376187510452313026\"\n ; \"23494184556634922103535803143214434479598067155171780264810485708203176455201\"\n ; \"22626342941879801989161990529511235538216563009907378573817996229389756621777\"\n |]\n ; [| \"26128268137723417163973860961686381960826033145738852158792607959175787222856\"\n ; \"20225791828042873305317281581105429726352058325970107209484198122707862156597\"\n ; \"7538871133759632802857159609785118198934349221046986784429069814655215585732\"\n |]\n ; [| \"26184554861259642274153262777073624024579929401668865520166966302070394487366\"\n ; \"28755259264665180745537307265993667261709206143628938749669440804401623257679\"\n ; \"11896066093033549470312328497237649508068258723531931099214795928200015717321\"\n |]\n ; [| \"21657721599978732693249012287058163532690942515202465984736373311077240614059\"\n ; \"9214914097169852704753116653702415951907628005986883140609006971322091003693\"\n ; \"18710111680849814325169297240208687402588261569152088592693815711857504371037\"\n |]\n ; [| \"6813635166770764528979084175325709935892248249948967889926276426090222296643\"\n ; \"20546585456429436268067726231902751119458200511988152296570567167520382569278\"\n ; \"20087466019194902429054761607398988292568594301671509779549344754172952693871\"\n |]\n ; [| \"28185105286740691904534067831357491310995891986363455251895371651360605333143\"\n ; \"10108348212894231193041286244259038275269464277821588425688314560368589986063\"\n ; \"11433633215392393209829215018579238412423821563056156785641278458497271271546\"\n |]\n ; [| \"27870881917195016999862550657996865268956893566432995492427618003637597051321\"\n ; \"102309803677783876701097881491240456320211833502658383473112057006867019389\"\n ; \"22844040227595875612525628393174357057929113317578127744718774517498324646590\"\n |]\n ; [| \"18364790233947478619325319418813215212267974311771564959136180502266118026133\"\n ; \"2480624341921718230432383518425561514824501138863702825916674641657321180841\"\n ; \"16778939567530361665956758171503829349658551798564323167725356065198936433124\"\n |]\n ; [| \"11947564511486966895926950599696532964589539443187518177489990556481125699966\"\n ; \"3133187646540385483015602955087323554103587039123577645562801570574691666057\"\n ; \"27704797101265438206569218421707753788081674727344603874614391656565567951541\"\n |]\n ; [| \"13001484695584753475562184349533365512515447041450030471627087395341039487710\"\n ; \"477322000667279478600757543806155989948171541982639893984064422067850617496\"\n ; \"13913755821658634147813329813115566967428755223601185963529801459396673113438\"\n |]\n ; [| \"16621869429023470107454028095846067937827722393398508604914831452950874033411\"\n ; \"21755744236927410239079501831014076529931327263341620300431356747367343619046\"\n ; \"26538666591151124505694487799121414506088199961481579132019627484065014831180\"\n |]\n ; [| \"3066480818457008068617042549071052338581291837882909165666223566402713429090\"\n ; \"16182268213934119294035309949459684472027705439038023775276926916166831108357\"\n ; \"28907604876608422892474268478706783033050951245339691569015166507728369585190\"\n |]\n ; [| \"27973960109508292680965426133498827831691369851701664449575719912259359998113\"\n ; \"1456924360278399121996742356757866616312146358469991014696110099534285524446\"\n ; \"8234248752911525485438611255163504976087091103090603316695312869292347668495\"\n |]\n ; [| \"8716078950082339630026654067608811496722305720644485560320987802533380421009\"\n ; \"19016744645809919602099479306503354923553336014593353020688463619133130053825\"\n ; \"24379650661051444982012238084495990858827340608012118841005379796362233056432\"\n |]\n ; [| \"2245379544097631382062919677963998259142792890502492881341386639439507471783\"\n ; \"28788137434161061988371619554419440748189388934884757179010092973102292086583\"\n ; \"7187000185648741287953633167647835668543536354944774631102766873251849991238\"\n |]\n ; [| \"18319349500538500800225762827448369057030532278398270164660609327776487168142\"\n ; \"2622932985948021877314529887962683530522545893985767148345336304947201715671\"\n ; \"13805188629797792210337544360632964855143280581052079479249966961215582531026\"\n |]\n ; [| \"27457600993464082637917106210690168172469473943609357897393615707457194410878\"\n ; \"15448646156961779103834447043970817898237835202826003934642165760908058355399\"\n ; \"9396792545729486882231669677795667529746274932273033601723318032992363022062\"\n |]\n ; [| \"9927877141952679457141759789181418464292082444806533413864151258248124544859\"\n ; \"23827901395971835838179844085051957393677906360196119690926757794561937573142\"\n ; \"3273544693673216914876067527455588276979859627093391584406340272737391174619\"\n |]\n ; [| \"19571510438350300564152393820251652609646082150148656806391655428002614034315\"\n ; \"4458840243585913642400750597703353770666314833058197517675446022682775625834\"\n ; \"6452218213610300363069953741424106105609715382419342511693148495219793324457\"\n |]\n ; [| \"14558167930891460678441266912176752652821641543245953113671886345167213541771\"\n ; \"10650967986920075561478528461783351160938460620955779955379459848889204404950\"\n ; \"19990009778942542934049216419052172134625404062770188357110708518621145688588\"\n |]\n ; [| \"26855242974447190235826233682457047761532515293146087151296725996543442567035\"\n ; \"22785340043356532865086769889360674409753343398766563441587096485751538658065\"\n ; \"28603049427449348335651629195385434188071937908693764500052489540779792538285\"\n |]\n ; [| \"20545812864989828913452616721240947168977365844984763819184465128164378967167\"\n ; \"23234068381345797209897730226956922073109641728569353961504167817770340037954\"\n ; \"26031714567641615877877111172701145299483019910006153132858512509897185854695\"\n |]\n ; [| \"9512221744061419790435674197238913998387834650389922233458121639503195504983\"\n ; \"12587458000103271975978240683793268604398305885278203470492658961734100340536\"\n ; \"9670291694005369437277651504604785512303147991710650505302465204429311229197\"\n |]\n ; [| \"26995526763045548800439747262386290359229145489609341602564040676717570935439\"\n ; \"23742712112104280264401317024221734961713400615669958343926511931219510484675\"\n ; \"27931469778579449247589315744656633392873808631802461175539563849884447358271\"\n |]\n ; [| \"20669006894143187877081688942720159738269397552445286314270368345994751825389\"\n ; \"26891772301075275370472640177651637211280740381619976926886106618375467277414\"\n ; \"28387986011980449959047232529988203397251084614417760995257355718700961696092\"\n |]\n ; [| \"6579105010484741592730389416372694666279917604793318157514380025250233913402\"\n ; \"11007035767869292700964744408562802781669930023548892567535397874932420229930\"\n ; \"981148366863906885900456473323410468923514528856216824044152942069412627408\"\n |]\n ; [| \"22213671088722307302576907504985884923571642958053627659840326928319445671280\"\n ; \"1318836216310789598614608105109389429335273432455224127576823891011367206122\"\n ; \"25586582796990779718352441955439394949194222626688223867952982491529809559257\"\n |]\n ; [| \"4923739488579452777913681531125585976446366144127161879759262506690369040090\"\n ; \"23505612338866210737103599484620591026802005128655081877133994175016351514827\"\n ; \"323887003859465324514901860965142186539600668250760639664361851354147799637\"\n |]\n ; [| \"10198923064967306784017949469108033682156920551672348936591491217255268794658\"\n ; \"9593680688139131432883442351722730169325112619984238956948153423155998917175\"\n ; \"27027988263960602112273050725720071355535922812577299127302015348825197871870\"\n |]\n ; [| \"14419883951157390867695097127684346981136020111885301573583640959136319507752\"\n ; \"5104414988075833278683649298543440897371415916271358703850262680431809374355\"\n ; \"24739655595299332818980677669648719986462429574612913501586844601377825836782\"\n |]\n ; [| \"28522818684103966731129743408029731246564480741348128436668680764518115102581\"\n ; \"21520350704208288978690888796633940487888044365108767319141211249242880355961\"\n ; \"17391005598311948834360476853940353239444383292422171321575043660157438608537\"\n |]\n ; [| \"15367833944125677011173327826570204350687925236257190051755087781855930646142\"\n ; \"21715073802090413714601069529558707101797361591183718695054701329871284436172\"\n ; \"8994093285353831008525761670339342200997965950202092028313103110478252647618\"\n |]\n ; [| \"8370824693889782161629525898408725452177580012023459750897244954935682978671\"\n ; \"16123253540853556024347150096993154278773652905830608614979368087152152043083\"\n ; \"3535380953353495025888433493640531836449699255364366295870140701379497967423\"\n |]\n ; [| \"6954518484798178646508803478426114267143074508396663899281411171704702743829\"\n ; \"28903134801897070276701950388422104654018369750191967384271618837091859516942\"\n ; \"20872505363530172448468374920196608937030884647150175861507911076568784054834\"\n |]\n ; [| \"6902861581703501105786795670676641959401710346423594578401934671029571262513\"\n ; \"10124161387604183369443890585742198433184078889862870469507328332805848271064\"\n ; \"10488004060799269337071647841224034919633445750252076195310163972966405029030\"\n |]\n ; [| \"507704911991278613147490289466075160618843900088471236546244459176211783848\"\n ; \"7252739745607302667257774481690407709040936359589867974787811552896597703097\"\n ; \"23278073497974004442836030100920157527910770509761505828038443336325476654930\"\n |]\n ; [| \"22766285055433137793164317120096790621982728188995759745859222009100808389090\"\n ; \"23129058299483468195787339200845749049960038336751758017949899311636830205152\"\n ; \"16665333681978951552434356320651834889869437822496200946959897681307959400425\"\n |]\n ; [| \"12145699202182574939376505075528461451757079041659894988784442097333218352048\"\n ; \"26340666275844437932755852805027863696219004039301187587209926587657008948704\"\n ; \"19208771804191839410002226941825269105677187954811130189835856228258013753206\"\n |]\n ; [| \"21957102494792377508237608216278079874536155315851198461024084071231867104453\"\n ; \"6933367436450995525851693784691226222726503560893470094614235356287049091852\"\n ; \"15707767379191450768747057313641112321773921923533732633534831270357733757271\"\n |]\n ; [| \"27661963645951389261638591385668507557739541354225916772550248746235106571003\"\n ; \"19699458096897937575096494582288688995241392471402204995195057374756282223421\"\n ; \"902873385171181344315871113842580653512118892800584003934454469411716098791\"\n |]\n ; [| \"17184835876565576154014372215369798779520343573944211203710896053325717110660\"\n ; \"664657295519303589036289440053175741110032988007278988577620229144220576240\"\n ; \"10803972669668998371638869508774217165881281885838503958226056357738500321396\"\n |]\n ; [| \"2329846733754251453632375727999372856194157027336139087170310553870624325301\"\n ; \"14139944357035048486675740400655356660678187875721949218090128899571575479791\"\n ; \"18368148273419807418427674359327442879484531833435081951870369910704734685351\"\n |]\n ; [| \"10480273665080572189328459165704340191901489646067580012574464138528963201459\"\n ; \"21773636700078124500346009061678153597323236568110076029811348966753228682835\"\n ; \"18184268307211429260956076021417309535471438696101133218049142374847151474905\"\n |]\n ; [| \"25957533025669311312382992376854735734491934602484112256289764602447226406852\"\n ; \"22223261506176684934865714490719116745135417403915426392159449667435294570739\"\n ; \"22937309162832499167063076416585504361695925730111272512450449042837586253575\"\n |]\n ; [| \"16956181785481598286719868503945127919581091625126206673934113115358441284347\"\n ; \"8497782777197814773596870810881707148695901557289856910220737358078100998191\"\n ; \"21135503731586600979470064722475007625236017670426339278983640892218291297054\"\n |]\n ; [| \"17809297343844488723046665739910571149089769215421130894378638450427880983923\"\n ; \"72435395972188389387093550708873189001876361107443937983754878061522372356\"\n ; \"7511239878692099209014947248389283109997289411550315391143819429585903287870\"\n |]\n |]\n }\n\nlet params_Pasta_q_legacy =\n { Params.mds =\n [| [| \"25059545165736646824438510995018528850798284624488112529736697979897721366717\"\n ; \"16698749787253722942243837797889445179074274353678606740096686335476872429399\"\n ; \"8431542578059462988142441820574484670502416261430105626118810753064502454172\"\n |]\n ; [| \"24729854844697760654067608751525498327180690314591492982304918187023029914826\"\n ; \"1121552144213806241339137182024814961508305746462827911242566288860442556748\"\n ; \"13091758359064753420271764138904670126701916846914918026096660522220974412796\"\n |]\n ; [| \"14318325434506839029297004068378670093722923223466359838374948921878384497878\"\n ; \"21049625586117008961018856577112352485632537866388888422067379870460247825481\"\n ; \"11967204246156045515212780049644733421582972293043836026003728262137316485428\"\n |]\n |]\n ; round_constants =\n [| [| \"27823288320934189888335104419667051541440213716337979953029039814477122015803\"\n ; \"7253519329434178666336171171011092435792450637855327869661074429483992798663\"\n ; \"12943190030917713819083161989292505641412002214667543002424543294305586713622\"\n |]\n ; [| \"27652450736585745228854776198724711889399928847227796610514615862285675851603\"\n ; \"14974144387861463358629448488728583756510094143360287299992064027672013096218\"\n ; \"7097911473075039536684392748485048129620058816999734741035507137919094344000\"\n |]\n ; [| \"9833471627477871590542564294396788818371219099618369953520953128833069622998\"\n ; \"1216722705894969315906023467727879380441696627034784137237245320657648994073\"\n ; \"23711484374443627488130462875874481115682053816071105446952037381155017895779\"\n |]\n ; [| \"20334834189812750348389095362218130162301260954195045344340626330588177435942\"\n ; \"4366529093468402654059406041856606540091882399834904947969748538808812090209\"\n ; \"19522556558624240319308906783506879200944684005866343832929046513996276368523\"\n |]\n ; [| \"23468156490044127088707992399042874063294495237928703268006456122691893114531\"\n ; \"10734041842950229608874281327056547473719120183996972794393760960989413485309\"\n ; \"3234488841736382875399536096222344212453291206089588556042783786752950726222\"\n |]\n ; [| \"7306686533350672818132556583061081086083445583634785280645571504913340166178\"\n ; \"10055837153364380487257619433543992440564488619143210451383396316865395141767\"\n ; \"17005554504252596333905431799020688136174578956026736789538843112027911340688\"\n |]\n ; [| \"11088831290647913265184319169987825710158339243590017331996929570375044581141\"\n ; \"18272514567796081346048223631818362002154999137167000861967874931307115963229\"\n ; \"2041522009924764288246767723256644894737485859434724922096489305438150594740\"\n |]\n ; [| \"11154210356751829838084431411705166756691650190195364032751879907682556256563\"\n ; \"23653929191474563116794828027291046485627178938492016942565292972650213420708\"\n ; \"10285757729660670290227890459658768244478343389595417793240783735403842747803\"\n |]\n ; [| \"27122162076320933627388879342386660773804566925381935727677186578594924773004\"\n ; \"25134653885736994960102027470761976149413229279137043556790564613470281817026\"\n ; \"6659993804933127797936877003954612022106867848874586482405999929720922911898\"\n |]\n ; [| \"1999981756946475588545224006048368808065463727746380893415897089701535614681\"\n ; \"117353258519553885966322353309393133659964765643696354970870351531909803419\"\n ; \"6394630448856946333677807337170062255969284635756530106258303122060761829375\"\n |]\n ; [| \"10402812455948335282625861441472459100503153859758204506020258199084032529891\"\n ; \"24521576250845873373537149390654765866957414335470107480004100764170074644129\"\n ; \"28343148273143818383375888384222625178643820136230475659994359540667696060401\"\n |]\n ; [| \"19466274031477176253567256907114468319559962421369951854132011198919308086813\"\n ; \"15950373298313107490097624474333726880960801439930364792944142444680782981647\"\n ; \"17502012461772831993035812876278636151120700925824710547719185259039723973873\"\n |]\n ; [| \"13427943193313984564171438077343446106584745896824089935661921301233540577663\"\n ; \"19169237962582795898123052276700824726897554497737731003794686518711369308701\"\n ; \"9083808098781854981749406088158848274120691731417104666413783119140757689434\"\n |]\n ; [| \"3085572928600572710130215355481483413152463940337003200200686333839836936060\"\n ; \"6423923726405952993270285921266354528708083436156049822651047436988725799335\"\n ; \"11711163607312960445460153090393005414044253191457667104588071606706527083035\"\n |]\n ; [| \"22862764769570580579955370870655020558642400260785510683021349826526091593487\"\n ; \"27106527830212782583531586155197640258773355519954630305727973089302997251797\"\n ; \"16868720082666046473782251283858811018289758418191781142790257643516182531272\"\n |]\n ; [| \"23158332713461282002423665990353034524451940720249144308509697639018478890344\"\n ; \"4196222884247438401050717959999141753538715859111095883718384227804271580571\"\n ; \"22572557742560406175483660351232922626321427879380236408573364865152875751999\"\n |]\n ; [| \"6498384178588263785275487016065720553418371000134613854044334919909896078231\"\n ; \"19713457172464396779910830357144111010125169288012289325852007667562797201617\"\n ; \"9370618609381654599580351346089018265074763897101213494189302119360756555515\"\n |]\n ; [| \"17332110085907729652621872688438506098032926644356340523235380228784153361946\"\n ; \"15828217198541208438489225959666895536847479530801819210983017536719128875310\"\n ; \"22909304389117426005516739639132057953847831090140119017131773808660581359339\"\n |]\n ; [| \"13274846258473860762348270229895556617343668531781906800111616196606379168678\"\n ; \"20563817685937794654177709363835160405142894424010788995801747935877119235477\"\n ; \"20063600011389636949850146896035168067037303328482473908141578341678944583640\"\n |]\n ; [| \"15561372644915625354729031742269409074452750500059702572378336917069173281200\"\n ; \"1198490580487628040011397824278054034135841708228898001350812771879916960859\"\n ; \"18879421345448691096589106007214815329241576402832734110268197859756832871926\"\n |]\n ; [| \"27399632471000964892968952930054846863781961828780329177494048571243833336763\"\n ; \"2834864942083315409826100384502236980961959328095446142898875620023252496233\"\n ; \"4869045848545701242953923765295279010470656159359352534992875895020324731123\"\n |]\n ; [| \"14325690392479768681007652408098324173976655892283539787053225046370602615453\"\n ; \"25414347192966841451685828069955147897403238857128755301675290249558576625379\"\n ; \"16590289516213461810017744664371295027301564689635234008641715363769691252951\"\n |]\n ; [| \"7999784177991937194560403228390571132248134775394758539082341051882961743020\"\n ; \"27627395050531728876502002078316976742781103442109539911472055005902825690089\"\n ; \"18036356111926470640247668504029296840956365668466479796170120459318979414011\"\n |]\n ; [| \"5913242795575813219801658492942666827872903959995896555280069960017119884723\"\n ; \"14937809672911513589131385409454363020800493802245991188388679796557583708641\"\n ; \"3172852326416764473757677332305817213305384800572730229499136253125245597387\"\n |]\n ; [| \"1832396283457909430686926169612235735546922286254241081539828449889942491358\"\n ; \"28715821183944831340251190244581222742951105435037341519427068245935486106710\"\n ; \"14690804016462235339916279821852369558429158839477443587616468985654313024916\"\n |]\n ; [| \"10594946257886875886350188493790544854294225726533811714616959802551003511354\"\n ; \"16258660270470428008977128056439132854218579917105801771424980524100431529141\"\n ; \"14389177900004589865692617486629808338224936524382373991229450083375030187419\"\n |]\n ; [| \"5254897446260226925010930278774739002366094838197608352776711034691419167908\"\n ; \"10017451766970898293191969301037043760556997294605718695671614691099240320486\"\n ; \"10377472495000399544094005473576037833003171018156457133642162749306784348836\"\n |]\n ; [| \"23218136335641731339524766058408447175805302377930780974300993009302336516500\"\n ; \"20191488824991124775021487716004416112776365506510575739204924567600203901269\"\n ; \"110606975331244410915904098772946457859594892267516924942421765736318866617\"\n |]\n ; [| \"23027069668757981664879070455867290821752779218098836684714327441246591774759\"\n ; \"4589247739673767474307973868199446429401684489991453077155492434850787381702\"\n ; \"6379670142720597470858520674745082918596505550095259476677356817872026090713\"\n |]\n ; [| \"19764864476474764903616550282446756103765436833072775572851316648333869235114\"\n ; \"12894898442410371982703732271804085318212494678649934125021268012840299185637\"\n ; \"4894374129066677193060314651654909732906317879933995748486904122303748724381\"\n |]\n ; [| \"9392947448126670174003480248219776361392113047007441983095267747240201787052\"\n ; \"17448004227122961073493138290943872881683504888463872361350949670680638193246\"\n ; \"24898908270148995600292988565336948748670477048995196059344166957302253353468\"\n |]\n ; [| \"17672969484563875329340665269765905710099865885284111146969980578304648998989\"\n ; \"17315183356963381222871645160515357484888194239021894873634846607120433299603\"\n ; \"16657291105770020999163388035414073826686069942847209725990896237129724531623\"\n |]\n ; [| \"20045358898180937726150285529789401521185856403599282370725965114285467221394\"\n ; \"7604720689465762204259558177050824657125765219907087093134275946944476764623\"\n ; \"4946157133141303389791048466320735878774808191447977218588320463643439643617\"\n |]\n ; [| \"16095543778893367554646246146733094380954235388863918230797975064302848608110\"\n ; \"9495028757440948201524349973141898811031260740727574963230822567659024070475\"\n ; \"15652394153551772951410898217296838776100645778717025418259184512269824513281\"\n |]\n ; [| \"22221075851011525495207739030167842998461976982084095286887110082203892655949\"\n ; \"9773505979109619840461605806117798267810157941804844442655531835520967463113\"\n ; \"9699921110253873916726596291176974227884871755181878140734719120429532053002\"\n |]\n ; [| \"17682231260051753498617845281951269726537935653976607531850308842757348601329\"\n ; \"18026887242590310014427209724078991193599958030254077118842503456583403950827\"\n ; \"25015306241717221564050692754953747248185536052663170582824605966511132780487\"\n |]\n ; [| \"16913017783534832741366331557377027835283393598087920619147327295000966841306\"\n ; \"14346687497088016967038616732353182101844963538110413455107565365722012953284\"\n ; \"5306566980905870284116776586767806070957377455264987606648038923624253495328\"\n |]\n ; [| \"1776756375313230649731428479835496304149043878892306245847918259342669070843\"\n ; \"490116546446566363527874936210269421699868025744627465261205141315457929764\"\n ; \"15895862901922909582174688550455317647454688607836801729345729632260371594678\"\n |]\n ; [| \"13688862447353097641921417721564599384304916802983599264426675175604875742315\"\n ; \"24548198092994361104088706233911543485350973671834385909863857501675802878279\"\n ; \"13459479827606540544689621578844182868859283770589890980132135394570347186061\"\n |]\n ; [| \"24044394058320635022361075601656905043313553792325674538366784156913803812196\"\n ; \"13224911244448701263582762940879464967836683002210854167321246073960841644522\"\n ; \"8458040493721843207908979005771386571338972860793346258045061108188537269575\"\n |]\n ; [| \"3373954096140863425424783847439718500809124286660183499962641073452219575239\"\n ; \"20786023834921480994573103385555575391782193954100981434750965529916600088428\"\n ; \"4062313531423140960397881434049476366932415559401603628257162927863296206641\"\n |]\n ; [| \"1898020409546207805320648144920011726191859363441411206281917919526161244598\"\n ; \"24277367400752675228358431727080852820923883244494414698417676920127526770088\"\n ; \"27041649732785968593009926556186278849799597604234485085263424041769060430672\"\n |]\n ; [| \"21584002498671958383320932658470323644925729001241157174062149135688934590153\"\n ; \"296461973635637542200993277788422285516983090690405454296351759221006819546\"\n ; \"8818839967799505500555627771598501831696804919367222237507197660660892665148\"\n |]\n ; [| \"4439337387294703935549667847378420965887876421209156336246561071020526953695\"\n ; \"27771844118085313731256751422668441516968763521122036346441924658635531209834\"\n ; \"7599670163703076794117421319905831310613637703095599713786252660612843368075\"\n |]\n ; [| \"12193036087689296361781682831088176514376474290884092260169857032550680408546\"\n ; \"25791228645469784134598013409595043692878987806412190415747720776255632142972\"\n ; \"8504882545271841062057911639581320453656588156705418395838850434018335784764\"\n |]\n ; [| \"9130894449689099154616722799255778500706692445872833148087121191022987751351\"\n ; \"21553577145491938499114888018915447040714863615699957078888430024590510223125\"\n ; \"8307396866731830889712140446282281226154409273955284908758959517111805068379\"\n |]\n ; [| \"20697895431092576068009892921110410029570860731610412906827921169156559036877\"\n ; \"25847730491997591203980701133953084257949899509409890411883471391399589272255\"\n ; \"27068530132452520868806589188908435601314783511462339379808399629696227108300\"\n |]\n ; [| \"20579165271364650486101631743580639117276566815442383429004130800710012624677\"\n ; \"2049872261441584532266169243588650339607343237488816821021818230059988793881\"\n ; \"5229222520976935575159907831883087156061470447412599430611711892673497144820\"\n |]\n ; [| \"16888076312477210105490768408731364790051105858421097779712165387651960648918\"\n ; \"2063328481371063362698477795877294174447601367525854450572877036817950486588\"\n ; \"9978860706589405700636863259000379424111716695830255414810479786243742448788\"\n |]\n ; [| \"10317246955612741053663756285229154782235034400014758881046851747850823867516\"\n ; \"13593887292763642751523995903547641851467767154363297491262315140569344482619\"\n ; \"23402502496341059894809445627668621422181262255992641144517916256091271283596\"\n |]\n ; [| \"21967434350664893350794692419887682460286669021917537287854750673456386148796\"\n ; \"23353689534149296842880441871386688481067867589772985300786059302345245225322\"\n ; \"23735357311909906399385947858290446886270449558355528121401365099315742122681\"\n |]\n ; [| \"10912898365787795098976682182552503726774830131561177111534481011887568028225\"\n ; \"24870024081013773996332492735582388115312107253015059784314149687041374665561\"\n ; \"14959251092871859358484341584905048546998757007023469906733200814028817787676\"\n |]\n ; [| \"4862971281682736739478329712142805000991054403202074379778464975706269552737\"\n ; \"18880974505260055428677233450169574923539187497744705144686621167223290501713\"\n ; \"15019860251830177408295304948562135143018077531659007557525973719668356977506\"\n |]\n ; [| \"20568371280002005481616540220671990391004159655382801184704914533391923227442\"\n ; \"17618564901060519653065801707062565705965252069071642419351201848751288646311\"\n ; \"6175806441176276214249342720153255252512916129811023844537243081853881530586\"\n |]\n ; [| \"296698681032659410437385638424768886607081580850224832109048866253174706324\"\n ; \"7268871617745116292779237678539517235521185661165310960197803054547440338193\"\n ; \"16341563652551468195688432165785741488638381548308118992703945905571040710551\"\n |]\n ; [| \"20802839862702262365306655858469071118895773474002102559223288884562755221802\"\n ; \"8463358659774659224604995990679067672391550969286021897665237635502349549078\"\n ; \"15978158329915368408793563753006455633333602546915141756185279989524351398011\"\n |]\n ; [| \"17622341778239430423221939745175386197971754657696111634181640277323050526814\"\n ; \"10608335237642480929422693089800206983573202659550442733156493623334131463648\"\n ; \"4030685945296549297325867649675145444613863086399488872024691844215015865404\"\n |]\n ; [| \"13622512335702925704246239293965891829357706731007005465669806728128070589631\"\n ; \"28096860376731134760587904422020552532782566250134663540225061105608367763617\"\n ; \"23408844245917750106421907693053932839460443870282241477420090247810403742130\"\n |]\n ; [| \"1333283643113200911795408607575124847498003548266053936354869116413818233994\"\n ; \"5114627784027951102582115213264649034477290065123683766415035791913182621990\"\n ; \"12764392856508616755454501281162355366590010491252202055937861522683929322726\"\n |]\n ; [| \"17151467035003081822551161487450697402952914914532916714361135117937359660435\"\n ; \"5790806510531167647314677971786602969791369262808321427822737321737295918626\"\n ; \"25402570155872412453028168278079114058150183483929245811506328339445321991585\"\n |]\n ; [| \"12920564330262937347355086382215038686842973035591062422536047377306795551956\"\n ; \"12250718187966551349934722909284957659425918779784022718640942555655844833782\"\n ; \"20895727170003937274470408646745579174029123755980503191289166493378198853753\"\n |]\n ; [| \"15956841763991535793203092153585710767934653432429666292367107371891246878431\"\n ; \"165004921874760145525553135393467831289178931448821175010841518884068397358\"\n ; \"21701359314438421232412634090067127199084976819670003578888860920096628455908\"\n |]\n ; [| \"6848902582754636090737517131578591551788309332465803574486567584842713095075\"\n ; \"9148729239860297908222294166176107790125495380930731971791358581588488088179\"\n ; \"8358777029774639487464736856867300896187008886831215496030522112768313792659\"\n |]\n ; [| \"27763005231503543326388909385720946430141828710795454442053340035715385775564\"\n ; \"22636772741960501900595405662321074335936299276173491651140399382705798268766\"\n ; \"24200783367862580793810376984298862005065285339141826318611417638508272680935\"\n |]\n ; [| \"822600333766772255824054922496304222560196931439044456446485963982870790028\"\n ; \"11620067212793640354075687381092798024341928813664220586751309617921494471627\"\n ; \"25396694389942268941157432367167881033474136344183279866045115614823524486381\"\n |]\n ; [| \"7950044866662305700342331645322097694799649174330586954392082006195652431589\"\n ; \"22840933456350447931596740831047097851905435130998852812846918451453709541072\"\n ; \"5952562873278923355396014494234833112602416727163262543950012068378966526374\"\n |]\n ; [| \"14941744106899001396490468834896552276228477518658489130424851675983796484223\"\n ; \"8411858922787427790040186603365979935733234451728885815156429633351516622170\"\n ; \"25728130512642084604375585079417861667709258338193885601642539891291402554672\"\n |]\n ; [| \"20604517750643336005470932595806868673102682184328905598449933465373164368567\"\n ; \"18692086501272312775058232861104840534405554074751818414995965413576504506898\"\n ; \"5269470419857278770474250796707995245651827289253410681285877302520855951649\"\n |]\n ; [| \"132958317750014592125353639381410869535729112359715476758774573020346177038\"\n ; \"17193272337125758342712697198430394405858515930784181707588441236523237399507\"\n ; \"6907588900146294348775248591028498082882128985613063249028470164033147125714\"\n |]\n ; [| \"16309200565821244573168333253815499203949927814550835828103574182056728678956\"\n ; \"4607702890113363215119270116443817064683508025122288758534057630367234921015\"\n ; \"11237233790658676278102726466515564713414270355327201961157117083230382852243\"\n |]\n ; [| \"10064330808822528140235288193284673078859867025792057686345339813053087817354\"\n ; \"25051392317202122071857024659315208391485135039862063722352057784569902851363\"\n ; \"22126617513529506569359166365810362424423294611767941651490344758258540414004\"\n |]\n ; [| \"12091746476208536681080525048942500448418433204654951972926283776785275935445\"\n ; \"12111265990251598624141275756247422663513559759757319153701374783734518534525\"\n ; \"26739984777421171183341767053331505211465422029143782259686543457935639077074\"\n |]\n ; [| \"7819054201259648899956766259173509994826070622646983709427380262867238635463\"\n ; \"10445115028929965619698941897016402172414044576496139170399391316067978563932\"\n ; \"19684711726373570147937187126430934630002495670017015298886915356480224463252\"\n |]\n ; [| \"11239307846668865409559961011092791606629566617449107300929575297206367273772\"\n ; \"28805033990368921872277896029043745855817246151363711680251631474098318414959\"\n ; \"18401979852581903763050302976527384564541846667710514970197455751949363551773\"\n |]\n ; [| \"28263368266760706140556936890723050350981960590399696453960533699777929937332\"\n ; \"13171701559671490165454061311663500722478022888953080003164558696925706691950\"\n ; \"19602525380638837013300511621093845194121859856160220235414966930348094741920\"\n |]\n ; [| \"25875044639134258735138554352016034131847861924507451443931721478575773042344\"\n ; \"1286919834973261464274310810959674232070230673485764517044208498391267530988\"\n ; \"12782511029953763844753944101233413908378422219581060868637062846684140416599\"\n |]\n ; [| \"13777170936966635591451775007775796682884247670199445877358680218373012583133\"\n ; \"13914069095415962019849305704612514109938496116014955678392598600149568146470\"\n ; \"6783088795558416833900023860884913748051142639172416787734707305655085393583\"\n |]\n ; [| \"23759768419633407428810307098986751935262813445177317925266674188878521655568\"\n ; \"6216329803333944314103957880878676099988045568818271561443283432381325370083\"\n ; \"25114051080902804484727511815467173212803244349938543937989789439460074114186\"\n |]\n ; [| \"1180226883916835404878157801250992605812628262348217873510319284727730147381\"\n ; \"28284648834460517620415684321276302970692148546984768206724059094698247703614\"\n ; \"24033429483804377793699007789045563117176754720883449007735536724064971910209\"\n |]\n ; [| \"24837980504224007072003842463132805986188595503848986775222831487536454430702\"\n ; \"7321472857412311158120212341338101751477713807416898032253162676888996785560\"\n ; \"16969570257066093255532410834694788936815887939867116143226504248562357179280\"\n |]\n ; [| \"4125673734564343532339577642546830393637205447174011175535077670456408467503\"\n ; \"10632713303134500465283168727266716395067246541628032088845987128902453337705\"\n ; \"9574680283229048309682722855094170144602083182060214720561022770315159925050\"\n |]\n ; [| \"25200516884616393326554198239117840577353244771178619578270272915036798525203\"\n ; \"8016037998616729200273828218865709942562955788458067024686069967773623280702\"\n ; \"23152730567726048528634883257060835573481024340136073260056069507023870894846\"\n |]\n ; [| \"4936905020024289826614920724630062129669650361835193562496220267355967500709\"\n ; \"18184641423707818974834811540508053654673520711184768800680158891503991754351\"\n ; \"27444333582924293137279963432375877042954535401580653830648855025913046131946\"\n |]\n ; [| \"19258787990037904339970574900663327047151333605558856194461096727736980981409\"\n ; \"7307247571008211080591958435739460884694126720317257874083215846110062993851\"\n ; \"26746958803361511836036369403239292474668097850167071971132263374551313661859\"\n |]\n ; [| \"2986707284687082908367239099770334052301679778803284796428725648583327571996\"\n ; \"11076872572044729168706875668696902097477024573484865352103135025101837260335\"\n ; \"7676893881767745856368855909105588397337840304590696665395773396488415841368\"\n |]\n ; [| \"8035879860710675293804855837795384803722427367423273349615911494186867635695\"\n ; \"8777228662288028976220651807443998778731851272244712495838227067153229552036\"\n ; \"9404729766074943289512201205781943537326342248324517034957699512018199204738\"\n |]\n ; [| \"28138039971941229743877350137198714871803339371774209928210486168306126282046\"\n ; \"24746372913562546565307551019536112359520027514996722419915199065654026706269\"\n ; \"5992908251399318789048901337027258610373870655662449861810221050890563237785\"\n |]\n ; [| \"8986662495311798908019190514368815106790964767556070538172234209887075670815\"\n ; \"7819511120920480038906806637526904433010099047963872696607543518954984324963\"\n ; \"20040748576462413617236432113139264992338669108015478382493668322296306085726\"\n |]\n ; [| \"12604124251667268108802430657250418818373981324591677149693775791311237018115\"\n ; \"3713446680888938926487722727702881477451007635693922407499275812693082163524\"\n ; \"4729722979346651955109002515433891123630816656581607922377526264122826791278\"\n |]\n ; [| \"16455155466899261355363975391464726179721089911718581260053823330812044805329\"\n ; \"27164824221249686345132567624748537410457840627513096638619870411838704887939\"\n ; \"16276969634012778467682584281076733912813949584479602315250697584070339970173\"\n |]\n ; [| \"25641921087422510763187305803178924090589997867692682422161021888360562111214\"\n ; \"3667017006482520184366983251713265998942338144600409725070021931240855063242\"\n ; \"16624027448839826107498199322162430278228409173124621849582911009734159268523\"\n |]\n ; [| \"26317000137938324098695631123138063604840025944173958478354566632124186905402\"\n ; \"26340841271036888065816939024344358177648115802586515509528813558078622483283\"\n ; \"26760792070192677486356259617078495242352693159824472284838522738202103374517\"\n |]\n ; [| \"12721771512080997403280267277695539784262535121086502864139373913498888705215\"\n ; \"22548741447254480389350118476622153801605101093013811309651936063066499340364\"\n ; \"27978367330497576661463216897542761474015119849207592150731961184044447336019\"\n |]\n ; [| \"25747063373517637067792390107027157627279718780430393414118399515398493230570\"\n ; \"20151199118555759838932276113163555479083735668386566652089241087017456180596\"\n ; \"18879014815739649515414305835536994932451911664341341839193146489857284960764\"\n |]\n ; [| \"3810373645102571961856835110796286023878561472775937446095180271215591973482\"\n ; \"21670724524877659990430014767408914315012249576025971870416576542969889929722\"\n ; \"3915354581322191374887706360194439190056113572215823372708498368264986411752\"\n |]\n ; [| \"25396010083988081390296945409600690498532747776857675039749936403891275914607\"\n ; \"27390501373018759994091671141783422648482925902652559051505224556105818276432\"\n ; \"21943756395113869385673889596972393684048914861116005493936041142864388308640\"\n |]\n ; [| \"21009529429359499435346117020843766611662779822918934812595290904562681460194\"\n ; \"4403095793362209982879649985124453117401775317228756238293170861698283724152\"\n ; \"13402721305808954031052740171341806281977967539270936940650446104784640742956\"\n |]\n ; [| \"27491349623398243944682353258003517841463983130426355707277141054509970413931\"\n ; \"839162295650533705111165213845914661169544698196543148318540951139745338443\"\n ; \"2360031015226134235320333722839592171180466963140089662936226146376372598269\"\n |]\n ; [| \"23187073805281466301515357725635655379740035976872552251192653562569108948332\"\n ; \"13415450340633894897579130593672628357474718745976391717544515771527056769433\"\n ; \"20551598721856083916810924558283736201557848101716997060847530300465710342492\"\n |]\n ; [| \"3672594647865661748928752317746079229095373133257293162774720337138304704736\"\n ; \"28656412123828764424722913154831876184400121058128257557942467880106263931024\"\n ; \"12488798341044520189714771416078903136558391518843419705687775573556817797577\"\n |]\n |]\n }\n\nlet params_Pasta_p_kimchi =\n { Params.mds =\n [| [| \"12035446894107573964500871153637039653510326950134440362813193268448863222019\"\n ; \"25461374787957152039031444204194007219326765802730624564074257060397341542093\"\n ; \"27667907157110496066452777015908813333407980290333709698851344970789663080149\"\n |]\n ; [| \"4491931056866994439025447213644536587424785196363427220456343191847333476930\"\n ; \"14743631939509747387607291926699970421064627808101543132147270746750887019919\"\n ; \"9448400033389617131295304336481030167723486090288313334230651810071857784477\"\n |]\n ; [| \"10525578725509990281643336361904863911009900817790387635342941550657754064843\"\n ; \"27437632000253211280915908546961303399777448677029255413769125486614773776695\"\n ; \"27566319851776897085443681456689352477426926500749993803132851225169606086988\"\n |]\n |]\n ; round_constants =\n [| [| \"21155079691556475130150866428468322463125560312786319980770950159250751855431\"\n ; \"16883442198399350202652499677723930673110172289234921799701652810789093522349\"\n ; \"17030687036425314703519085065002231920937594822150793091243263847382891822670\"\n |]\n ; [| \"25216718237129482752721276445368692059997901880654047883630276346421457427360\"\n ; \"9054264347380455706540423067244764093107767235485930776517975315876127782582\"\n ; \"26439087121446593160953570192891907825526260324480347638727375735543609856888\"\n |]\n ; [| \"15251000790817261169639394496851831733819930596125214313084182526610855787494\"\n ; \"10861916012597714684433535077722887124099023163589869801449218212493070551767\"\n ; \"18597653523270601187312528478986388028263730767495975370566527202946430104139\"\n |]\n ; [| \"15831416454198644276563319006805490049460322229057756462580029181847589006611\"\n ; \"15171856919255965617705854914448645702014039524159471542852132430360867202292\"\n ; \"15488495958879593647482715143904752785889816789652405888927117106448507625751\"\n |]\n ; [| \"19039802679983063488134304670998725949842655199289961967801223969839823940152\"\n ; \"4720101937153217036737330058775388037616286510783561045464678919473230044408\"\n ; \"10226318327254973427513859412126640040910264416718766418164893837597674300190\"\n |]\n ; [| \"20878756131129218406920515859235137275859844638301967889441262030146031838819\"\n ; \"7178475685651744631172532830973371642652029385893667810726019303466125436953\"\n ; \"1996970955918516145107673266490486752153434673064635795711751450164177339618\"\n |]\n ; [| \"15205545916434157464929420145756897321482314798910153575340430817222504672630\"\n ; \"25660296961552699573824264215804279051322332899472350724416657386062327210698\"\n ; \"13842611741937412200312851417353455040950878279339067816479233688850376089318\"\n |]\n ; [| \"1383799642177300432144836486981606294838630135265094078921115713566691160459\"\n ; \"1135532281155277588005319334542025976079676424839948500020664227027300010929\"\n ; \"4384117336930380014868572224801371377488688194169758696438185377724744869360\"\n |]\n ; [| \"21725577575710270071808882335900370909424604447083353471892004026180492193649\"\n ; \"676128913284806802699862508051022306366147359505124346651466289788974059668\"\n ; \"25186611339598418732666781049829183886812651492845008333418424746493100589207\"\n |]\n ; [| \"10402240124664763733060094237696964473609580414190944671778761753887884341073\"\n ; \"11918307118590866200687906627767559273324023585642003803337447146531313172441\"\n ; \"16895677254395661024186292503536662354181715337630376909778003268311296637301\"\n |]\n ; [| \"23818602699032741669874498456696325705498383130221297580399035778119213224810\"\n ; \"4285193711150023248690088154344086684336247475445482883105661485741762600154\"\n ; \"19133204443389422404056150665863951250222934590192266371578950735825153238612\"\n |]\n ; [| \"5515589673266504033533906836494002702866463791762187140099560583198974233395\"\n ; \"11830435563729472715615302060564876527985621376031612798386367965451821182352\"\n ; \"7510711479224915247011074129666445216001563200717943545636462819681638560128\"\n |]\n ; [| \"24694843201907722940091503626731830056550128225297370217610328578733387733444\"\n ; \"27361655066973784653563425664091383058914302579694897188019422193564924110528\"\n ; \"21606788186194534241166833954371013788633495786419718955480491478044413102713\"\n |]\n ; [| \"19934060063390905409309407607814787335159021816537006003398035237707924006757\"\n ; \"8495813630060004961768092461554180468161254914257386012937942498774724649553\"\n ; \"27524960680529762202005330464726908693944660961000958842417927307941561848461\"\n |]\n ; [| \"15178481650950399259757805400615635703086255035073919114667254549690862896985\"\n ; \"16164780354695672259791105197274509251141405713012804937107314962551600380870\"\n ; \"10529167793600778056702353412758954281652843049850979705476598375597148191979\"\n |]\n ; [| \"721141070179074082553302896292167103755384741083338957818644728290501449040\"\n ; \"22044408985956234023934090378372374883099115753118261312473550998188148912041\"\n ; \"27068254103241989852888872162525066148367014691482601147536314217249046186315\"\n |]\n ; [| \"3880429241956357176819112098792744584376727450211873998699580893624868748961\"\n ; \"17387097125522937623262508065966749501583017524609697127088211568136333655623\"\n ; \"6256814421247770895467770393029354017922744712896100913895513234184920631289\"\n |]\n ; [| \"2942627347777337187690939671601251987500285937340386328746818861972711408579\"\n ; \"24031654937764287280548628128490074801809101323243546313826173430897408945397\"\n ; \"14401457902976567713827506689641442844921449636054278900045849050301331732143\"\n |]\n ; [| \"20170632877385406450742199836933900257692624353889848352407590794211839130727\"\n ; \"24056496193857444725324410428861722338174099794084586764867109123681727290181\"\n ; \"11257913009612703357266904349759250619633397075667824800196659858304604714965\"\n |]\n ; [| \"22228158921984425749199071461510152694025757871561406897041788037116931009246\"\n ; \"9152163378317846541430311327336774331416267016980485920222768197583559318682\"\n ; \"13906695403538884432896105059360907560653506400343268230130536740148070289175\"\n |]\n ; [| \"7220714562509721437034241786731185291972496952091254931195414855962344025067\"\n ; \"27608867305903811397208862801981345878179337369367554478205559689592889691927\"\n ; \"13288465747219756218882697408422850918209170830515545272152965967042670763153\"\n |]\n ; [| \"8251343892709140154567051772980662609566359215743613773155065627504813327653\"\n ; \"22035238365102171608166944627493632660244312563934708756134297161332908879090\"\n ; \"13560937766273321037807329177749403409731524715067067740487246745322577571823\"\n |]\n ; [| \"21652518608959234550262559135285358020552897349934571164032339186996805408040\"\n ; \"22479086963324173427634460342145551255011746993910136574926173581069603086891\"\n ; \"13676501958531751140966255121288182631772843001727158043704693838707387130095\"\n |]\n ; [| \"5680310394102577950568930199056707827608275306479994663197187031893244826674\"\n ; \"25125360450906166639190392763071557410047335755341060350879819485506243289998\"\n ; \"22659254028501616785029594492374243581602744364859762239504348429834224676676\"\n |]\n ; [| \"23101411405087512171421838856759448177512679869882987631073569441496722536782\"\n ; \"24149774013240355952057123660656464942409328637280437515964899830988178868108\"\n ; \"5782097512368226173095183217893826020351125522160843964147125728530147423065\"\n |]\n ; [| \"13540762114500083869920564649399977644344247485313990448129838910231204868111\"\n ; \"20421637734328811337527547703833013277831804985438407401987624070721139913982\"\n ; \"7742664118615900772129122541139124149525273579639574972380600206383923500701\"\n |]\n ; [| \"1109643801053963021778418773196543643970146666329661268825691230294798976318\"\n ; \"16580663920817053843121063692728699890952505074386761779275436996241901223840\"\n ; \"14638514680222429058240285918830106208025229459346033470787111294847121792366\"\n |]\n ; [| \"17080385857812672649489217965285727739557573467014392822992021264701563205891\"\n ; \"26176268111736737558502775993925696791974738793095023824029827577569530708665\"\n ; \"4382756253392449071896813428140986330161215829425086284611219278674857536001\"\n |]\n ; [| \"13934033814940585315406666445960471293638427404971553891617533231178815348902\"\n ; \"27054912732979753314774418228399230433963143177662848084045249524271046173121\"\n ; \"28916070403698593376490976676534962592542013020010643734621202484860041243391\"\n |]\n ; [| \"24820015636966360150164458094894587765384135259446295278101998130934963922381\"\n ; \"7969535238488580655870884015145760954416088335296905520306227531221721881868\"\n ; \"7690547696740080985104189563436871930607055124031711216224219523236060212249\"\n |]\n ; [| \"9712576468091272384496248353414290908377825697488757134833205246106605867289\"\n ; \"12148698031438398980683630141370402088785182722473169207262735228500190477924\"\n ; \"14359657643133476969781351728574842164124292705609900285041476162075031948227\"\n |]\n ; [| \"23563839965372067275137992801035780013422228997724286060975035719045352435470\"\n ; \"4184634822776323233231956802962638484057536837393405750680645555481330909086\"\n ; \"16249511905185772125762038789038193114431085603985079639889795722501216492487\"\n |]\n ; [| \"11001863048692031559800673473526311616702863826063550559568315794438941516621\"\n ; \"4702354107983530219070178410740869035350641284373933887080161024348425080464\"\n ; \"23751680507533064238793742311430343910720206725883441625894258483004979501613\"\n |]\n ; [| \"28670526516158451470169873496541739545860177757793329093045522432279094518766\"\n ; \"3568312993091537758218792253361873752799472566055209125947589819564395417072\"\n ; \"1819755756343439646550062754332039103654718693246396323207323333948654200950\"\n |]\n ; [| \"5372129954699791301953948907349887257752247843844511069896766784624930478273\"\n ; \"17512156688034945920605615850550150476471921176481039715733979181538491476080\"\n ; \"25777105342317622165159064911913148785971147228777677435200128966844208883059\"\n |]\n ; [| \"25350392006158741749134238306326265756085455157012701586003300872637887157982\"\n ; \"20096724945283767296886159120145376967480397366990493578897615204296873954844\"\n ; \"8063283381910110762785892100479219642751540456251198202214433355775540036851\"\n |]\n ; [| \"4393613870462297385565277757207010824900723217720226130342463666351557475823\"\n ; \"9874972555132910032057499689351411450892722671352476280351715757363137891038\"\n ; \"23590926474329902351439438151596866311245682682435235170001347511997242904868\"\n |]\n ; [| \"17723373371137275859467518615551278584842947963894791032296774955869958211070\"\n ; \"2350345015303336966039836492267992193191479606566494799781846958620636621159\"\n ; \"27755207882790211140683010581856487965587066971982625511152297537534623405016\"\n |]\n ; [| \"6584607987789185408123601849106260907671314994378225066806060862710814193906\"\n ; \"609759108847171587253578490536519506369136135254150754300671591987320319770\"\n ; \"28435187585965602110074342250910608316032945187476441868666714022529803033083\"\n |]\n ; [| \"16016664911651770663938916450245705908287192964254704641717751103464322455303\"\n ; \"17551273293154696089066968171579395800922204266630874071186322718903959339163\"\n ; \"20414195497994754529479032467015716938594722029047207834858832838081413050198\"\n |]\n ; [| \"19773307918850685463180290966774465805537520595602496529624568184993487593855\"\n ; \"24598603838812162820757838364185126333280131847747737533989799467867231166980\"\n ; \"11040972566103463398651864390163813377135738019556270484707889323659789290225\"\n |]\n ; [| \"5189242080957784038860188184443287562488963023922086723850863987437818393811\"\n ; \"1435203288979376557721239239445613396009633263160237764653161500252258220144\"\n ; \"13066591163578079667911016543985168493088721636164837520689376346534152547210\"\n |]\n ; [| \"17345901407013599418148210465150865782628422047458024807490502489711252831342\"\n ; \"22139633362249671900128029132387275539363684188353969065288495002671733200348\"\n ; \"1061056418502836172283188490483332922126033656372467737207927075184389487061\"\n |]\n ; [| \"10241738906190857416046229928455551829189196941239601756375665129874835232299\"\n ; \"27808033332417845112292408673209999320983657696373938259351951416571545364415\"\n ; \"18820154989873674261497645724903918046694142479240549687085662625471577737140\"\n |]\n ; [| \"7983688435214640842673294735439196010654951226956101271763849527529940619307\"\n ; \"17067928657801807648925755556866676899145460770352731818062909643149568271566\"\n ; \"24472070825156236829515738091791182856425635433388202153358580534810244942762\"\n |]\n ; [| \"25752201169361795911258625731016717414310986450004737514595241038036936283227\"\n ; \"26041505376284666160132119888949817249574689146924196064963008712979256107535\"\n ; \"23977050489096115210391718599021827780049209314283111721864956071820102846008\"\n |]\n ; [| \"26678257097278788410676026718736087312816016749016738933942134600725962413805\"\n ; \"10480026985951498884090911619636977502506079971893083605102044931823547311729\"\n ; \"21126631300593007055117122830961273871167754554670317425822083333557535463396\"\n |]\n ; [| \"1564862894215434177641156287699106659379648851457681469848362532131406827573\"\n ; \"13247162472821152334486419054854847522301612781818744556576865965657773174584\"\n ; \"8673615954922496961704442777870253767001276027366984739283715623634850885984\"\n |]\n ; [| \"2794525076937490807476666942602262298677291735723129868457629508555429470085\"\n ; \"4656175953888995612264371467596648522808911819700660048695373348629527757049\"\n ; \"23221574237857660318443567292601561932489621919104226163978909845174616477329\"\n |]\n ; [| \"1878392460078272317716114458784636517603142716091316893054365153068227117145\"\n ; \"2370412714505757731457251173604396662292063533194555369091306667486647634097\"\n ; \"17409784861870189930766639925394191888667317762328427589153989811980152373276\"\n |]\n ; [| \"25869136641898166514111941708608048269584233242773814014385564101168774293194\"\n ; \"11361209360311194794795494027949518465383235799633128250259863567683341091323\"\n ; \"14913258820718821235077379851098720071902170702113538811112331615559409988569\"\n |]\n ; [| \"12957012022018304419868287033513141736995211906682903915897515954290678373899\"\n ; \"17128889547450684566010972445328859295804027707361763477802050112063630550300\"\n ; \"23329219085372232771288306767242735245018143857623151155581182779769305489903\"\n |]\n ; [| \"1607741027962933685476527275858938699728586794398382348454736018784568853937\"\n ; \"2611953825405141009309433982109911976923326848135736099261873796908057448476\"\n ; \"7372230383134982628913227482618052530364724821976589156840317933676130378411\"\n |]\n ; [| \"20203606758501212620842735123770014952499754751430660463060696990317556818571\"\n ; \"4678361398979174017885631008335559529633853759463947250620930343087749944307\"\n ; \"27176462634198471376002287271754121925750749676999036165457559387195124025594\"\n |]\n ; [| \"6361981813552614697928697527332318530502852015189048838072565811230204474643\"\n ; \"13815234633287489023151647353581705241145927054858922281829444557905946323248\"\n ; \"10888828634279127981352133512429657747610298502219125571406085952954136470354\"\n |]\n |]\n }\n\nlet params_Pasta_q_kimchi =\n { Params.mds =\n [| [| \"28115781186772277486790024060542467295096710153315236019619365740021995624782\"\n ; \"22098002279041163367053200604969603243328318626084412751290336872362628294144\"\n ; \"10518156075882958317589806716220047551309200159506906232124952575033472931386\"\n |]\n ; [| \"8515206633865386306014865142947895502833797732365705727001733785057042819852\"\n ; \"19310731234716792175834594131802557577955166208124819468043130037927500684373\"\n ; \"361439796332338311597104753147071943681730695313819021679602959964518909239\"\n |]\n ; [| \"2193808570710678216879007026210418088296432071066284289131688133644970611483\"\n ; \"1201496953174589855481629688627002262719699487577300614284420648015658009380\"\n ; \"11619800255560837597192574795389782851917036920101027584480912719351481334717\"\n |]\n |]\n ; round_constants =\n [| [| \"2517640872121921965298496967863234221143680281046699148760560696057284005606\"\n ; \"3391756047431116221709518926936538303706203177575259437741546230828058541679\"\n ; \"28193080211857729746868575888309975056941007202713113547154010421664334143056\"\n |]\n ; [| \"25261619184426186938919514618416881383323154981235406731208902193655587998749\"\n ; \"5438499261516835502981531641588657477212528137520578797088407969732830437134\"\n ; \"1447697894671779324954748568939217281372628544919576009518449387265606369859\"\n |]\n ; [| \"5035532530235542599906399941203951970682478985022204457211063504597080640029\"\n ; \"18548939393800290417015907795270784249198528773378593112394621615021029911007\"\n ; \"28314657632459005492203969796973258399484591559931227050853551342156833947891\"\n |]\n ; [| \"10075465805557971120845970058070916255338843492716768289922460436606689369477\"\n ; \"21985996556868691161386211003270106475915714625334030557267947035839814254081\"\n ; \"9778523497398309788873186849997676949503189428912377745814036481347657299161\"\n |]\n ; [| \"6085447467925843146276340167082679235758707259098174769103982431882228334038\"\n ; \"11214803418623679719680560978819619149235769633101428825693192995405955507848\"\n ; \"20585482519401972421539035665320299097144487427998598740316244173221216198246\"\n |]\n ; [| \"18602266896623204184748247002001496873223612100325866696399863661914256384486\"\n ; \"22165919841309962137671309308234475433816142848229812860682345190836583925843\"\n ; \"22833505632200982123686653495190412951871851216487329681987951602744930627412\"\n |]\n ; [| \"200996541962081036547810490655955282117589336000744078845964972887355639644\"\n ; \"17159390488590225463405148524511348095493761844950655304775985535830170165304\"\n ; \"7519689807382250126180254188667761476713509751388558140260305473388567529705\"\n |]\n ; [| \"14159331841037307097148990917607709903712709092721125605507719995418592745663\"\n ; \"10490695046555645615062072066940833278139280813429718770298136076375411280286\"\n ; \"9996921069626538041923613626115903019578182147993504053879837245826104687293\"\n |]\n ; [| \"28009241574980093348462093077828465154604666812509186537490618830383877236685\"\n ; \"18925279443828804264179873719494108834579217607847079902207023181925588871175\"\n ; \"13126164514615718686767880517156253918404905174962666942976286681458411835722\"\n |]\n ; [| \"1125667389564136291825905670957082668987611691949011617627091942772124917554\"\n ; \"12737072162917928935765906421286553437026542524142430058538254259863452556200\"\n ; \"9855113244149548216327019561589719324434080884827484555441182992249251832158\"\n |]\n ; [| \"6006604346195593001833550983798183088851044846011297061071167569148810544010\"\n ; \"23783465709464699444911580329342599880163107932561352210466223087637763994288\"\n ; \"1581060363083815351710754851350813999229829634252940169154424073664057276774\"\n |]\n ; [| \"24121961545310887440574053281799796355427122479626872394472157625455666323022\"\n ; \"23925781309638869606256007860000699567158045595326122474217734988331349678475\"\n ; \"433512980570318160778040929743715681206456334448542248765142091911433454703\"\n |]\n ; [| \"8080307140515367021419180108267113624095868360927897204642243727009503935719\"\n ; \"13661807750191096117929173962837770733539092996971801228126331071941306856508\"\n ; \"9268394414065063505331314418649987795374055416089324253185088859000252370756\"\n |]\n ; [| \"22374115023493407761095751712373350824513305398485824175669182288521610150311\"\n ; \"22951274634403942446739133926874770994604864227598567536319143390467218980824\"\n ; \"21411532836345163980832919797897483979345524322135010935120723250070247464549\"\n |]\n ; [| \"20688285497159372157224857370703211924056803904697620218749985029000049442943\"\n ; \"8350087190167057556241775495760369408781696125331535735138679647687106863977\"\n ; \"13485893160159637778707269611856683957779710980787754997470728774769162419576\"\n |]\n ; [| \"4621792784192688819920303666439776744566536330750316034321950771579978771021\"\n ; \"13900656491552343190424687336475573267660717627286734246676255663734655019912\"\n ; \"16577037405341365304416318048187907895286388691199320947077947552959834207823\"\n |]\n ; [| \"17453637937712580666297652202332273322112052411250919589546137386514183913993\"\n ; \"9852736110707561006399582579453396957225552488023642073454517393228764176471\"\n ; \"8053970357622019747109700798952789019805031210730923951116580579194625334710\"\n |]\n ; [| \"14566849926060034944494603512439278530775668595134329897253012222562109882008\"\n ; \"8863944349051942080060073891691580009950648437676309749771884964336231381737\"\n ; \"16455762285584757654310476505019438984453107876908065440396394186006196612077\"\n |]\n ; [| \"28098375311516838082882166381119795701982164671360574802728073046992978741339\"\n ; \"13538346067341652694825445642847479918140731375902310280683284825070643960891\"\n ; \"18313412784975078534612748781201087502203257054025866271209086293337241477805\"\n |]\n ; [| \"24807061345703288899043018750567607387907450632666147403804744880717736838940\"\n ; \"16638378638176552952794487891875614248110181610295183306789394461536640085108\"\n ; \"2342874860138849081032934096750004917991517717553229739958552529472431319656\"\n |]\n ; [| \"21631810094765090996871180483650934431972930909326270651252393395613356531282\"\n ; \"2220759912186713489010197903069023809260408491503960321105305330086947471014\"\n ; \"14815764944505758746761442212662459585220143243155504464852948007238083120696\"\n |]\n ; [| \"23947619952183462858644581465494050309407721428302029371055887418452994318961\"\n ; \"25035254658153233628169609451068923631269927394392748023889572264723092874720\"\n ; \"17468020412163678868776493601957969748197290347006692843306595815987772942732\"\n |]\n ; [| \"15262198027618900223004625662874755104828479630165814039838611768431063172994\"\n ; \"25161066724266754383358798644805908588326959881061318668106454787543611445887\"\n ; \"2454250001039770891411267760383268680504653332090622148533496270387793031332\"\n |]\n ; [| \"9171946491887082474979985164918822959719377078284664312866368737511724712644\"\n ; \"6672870238005411132577302023934139592378291207852994424857452575898007687159\"\n ; \"2950400608762766076731526167833938554190979516192019010641815746350334547745\"\n |]\n ; [| \"10653725154501691589476837895400001173933804810435931645261606197625601363132\"\n ; \"12717400214508961810851553873706609743505640660238109459222577386574996883747\"\n ; \"5871058785976817081042949511195036111847495052209270758342334312740290470200\"\n |]\n ; [| \"18192562665205900830717234913238180302424621739145466326708104656354353538015\"\n ; \"19946412409172091711185698839696950657650658896270607012902209489827790455314\"\n ; \"21997416257528392077410699901606794827305154904508120972585193876767785262539\"\n |]\n ; [| \"16525092684784199198745517563091041705366544303388462641935777835264970071331\"\n ; \"27613372589672512522307803997948488817865025374001297632527692577079750053456\"\n ; \"23369674747888778238616865774843237791546925005553032792584302158017141634655\"\n |]\n ; [| \"11012136308159330675912474383855146192700147583104742924419195363346115019405\"\n ; \"20632243971343595216801828590185617698839041744000918292113739726624680548813\"\n ; \"10530371852841765918702282883445676639977895775479854136871270050807595649710\"\n |]\n ; [| \"1610594053831245596683250788274018471388810111366046583216577135605955718023\"\n ; \"452300846172044702598793611907955884294868639769163388132276731316720796255\"\n ; \"22297945145153422883128810575530182077542612397826351322358420927950400316504\"\n |]\n ; [| \"28212510899948152845929142163236606049756849316851154583029383581129293825706\"\n ; \"28325924586146971645663587791728624896861517146549428987043066595915712075981\"\n ; \"23489013325315178311518261165509151135555509351661386106070231815049642443022\"\n |]\n ; [| \"10150108696154604591036176090028652090941375062280095655463112192524823306544\"\n ; \"14935856239824547404885450872472169780177654619496758596151670953532153419587\"\n ; \"4367251608666794961207658726914177158125339342277880902441218521648798930454\"\n |]\n ; [| \"14278046449956534912766622635951826857049583276976844525135170835571509013020\"\n ; \"11627801940273881243235293875277734806211947530882079339115454640100174268255\"\n ; \"22853853581419894582873479603685652928885253184240650995805892818180355600894\"\n |]\n ; [| \"4405193089432137585625363585733613667088817369599257533888439029942466720878\"\n ; \"26434497741746827048559732407319982377645052620918789373329661707603241810667\"\n ; \"23558650878002025381506445692526977061352711282820117441110868042756853707843\"\n |]\n ; [| \"27427423077748345654234924309581695092179468167973406115643356520054395647078\"\n ; \"17585801825757985265979208086560185342609289319992678737491966299829354657891\"\n ; \"22079131836316223121286612953926945430480043835170303484162677394496378207190\"\n |]\n ; [| \"20126865597655889981803452476686954944892814234259869552204215672627920656068\"\n ; \"5591585339015997308682985123056479221565470335707041924016523106405300562835\"\n ; \"9422316572086279209843572429137982927615080330725918371521370800874341571474\"\n |]\n ; [| \"2735677349719528139570614238939713941030373684882307164259316901880218894412\"\n ; \"16229147459127626384090303399894157248853232127961182470501666316464149067069\"\n ; \"17151067888069760812629817914442472623785916486309268828873486698948911058517\"\n |]\n ; [| \"13833972862865550568348750465964022581895521701070662509936215512761615491351\"\n ; \"9624679817699048440664645568701817641311119158936258215534754849666144699339\"\n ; \"10273179847163882031630140477902608240997857384703412878925192706057610103613\"\n |]\n ; [| \"3172037826021850467928085880043492158321918352296515787555947245998877188849\"\n ; \"28890802281119993101506497911757988639840653958256859430239635494708187190915\"\n ; \"23496953773368274731821824281559682992786773767847557735733251263969009271239\"\n |]\n ; [| \"1509044982655321910215442389040863370827049078919961070795919190828975736187\"\n ; \"13927172650979098916742472053302036482743492746437467103459483008024082210879\"\n ; \"17248379591027039069313293591621091031164062825086122980769287846951363066520\"\n |]\n ; [| \"11350333545134487336540967650634077894516131586708748380417042089147896079201\"\n ; \"639497848254405996993150855123515463224731962182127668267769103213580096582\"\n ; \"24528361599642320451530127347946798949257664936307333999618279589325586618880\"\n |]\n ; [| \"8217015496508457685301448884203977810298711070026260090660268003968421268717\"\n ; \"6703444480721420507060701216472376128524677965704475494357937059812166295103\"\n ; \"8051365375874262471960241848873604339195556527603956582828833313772444122472\"\n |]\n ; [| \"10412735174026641936105532807659667596947675372330827493649954160029449767122\"\n ; \"8447576362386697729021229138353952824970707645851763166490398451107606293885\"\n ; \"4802965296970904162106502573136505305073730277702271660292532219583823320181\"\n |]\n ; [| \"3244354881334856885788568976540712586633556478250043997221528214026130052269\"\n ; \"817270901440592571623549787267103386561304980129799240746702119063425010300\"\n ; \"6566338353152134577893356938981496347522747926131278635019050445923229718029\"\n |]\n ; [| \"4854521709622003124815206874897232905514824969466266873443062691298769768277\"\n ; \"12830134034124699064152980183243986699241944691238427861184919962819448276943\"\n ; \"24309439157688106320977023683093060719537142150089588950480669629964661236785\"\n |]\n ; [| \"1853791709949511636795588377016980571084333441972847324139062389997895453872\"\n ; \"11399505004623970417786749745036397690793259153591025248188283534764565207306\"\n ; \"6280235834578097246976697944083887557501831809932305676532914637669922657807\"\n |]\n ; [| \"1516294190187225192808636261678393666537186816904214776860202535671714230097\"\n ; \"5835813607391397757416951433662507638966861369364000865214031356023042341328\"\n ; \"25777313996516799380163546628133415256678997511953860435781885414872422583905\"\n |]\n ; [| \"9749298878960864917089442034293906589697892682402070689770627645324414273893\"\n ; \"19986612197193695239708718365565978831607994386509967951279410162135133793419\"\n ; \"5020585421647265067890838871263925730422335215511670656851726444447972642755\"\n |]\n ; [| \"7256822974971238434100017358319972368738353570339258522235883585691301791128\"\n ; \"9789139064283320903202623693175751994730652446378861671859478926598420184293\"\n ; \"19283468246375057076525422714896652730563534118070235174488237489890270899533\"\n |]\n ; [| \"11487321478704551489982188818171823402443882145686911658585221913500937481156\"\n ; \"16513958012405406860890342996091255867910990589443610357743227675107758695101\"\n ; \"24764429351173766080138047602436205744310671344674490826288279531917797263231\"\n |]\n ; [| \"8256258316375000496541664568891934707113720493937218096466691600593595285909\"\n ; \"26919625894863883593081175799908601863265420311251948374988589188905317081443\"\n ; \"10135851848127171199130812615581006825969108287418884763125596866448544567342\"\n |]\n ; [| \"17567146349912867622479843655652582453162587996421871126612027345809646551661\"\n ; \"2524802431860351616270075327416865184018211992251290134350377936184047953453\"\n ; \"3417609143162661859785838333493682460709943782149216513733553607075915176256\"\n |]\n ; [| \"6906455011502599710165862205505812668908382042647994457156780865092846286493\"\n ; \"21042097659487317081899343674473811663642293019125869396575405454328274948985\"\n ; \"25222370053690749913129090298406788520061040938312366403907461864202905656238\"\n |]\n ; [| \"18933201791079410639949505893100361911334261775545573219434897335758052335005\"\n ; \"14503331557348715387048413780116585195932777696828173626366829282421027153184\"\n ; \"3558781473325529402549318082942465709639711182863041375748599816583729962116\"\n |]\n ; [| \"23932570601084008621895097434501731960424360312878373523779451810455362953625\"\n ; \"13286131463754478912858022007443470896920464302917391606059553157137090717219\"\n ; \"9969435194445819847988134248075866286921574284754991873902788928171429847506\"\n |]\n ; [| \"10821551500865029673311799086099720530496516676117927814621168667836737594374\"\n ; \"57689402905128519605376551862931564078571458212398163192591670282543962941\"\n ; \"4484359679395800410695081358212522306960518636189521201445105538223906998486\"\n |]\n |]\n }\n","open! Core_kernel\nopen! Import\n\nmodule type Slots = sig\n (** [Slots] has types [t1], ..., [t12] of arities 1 to 12 that are isomorphic to tuple\n types of the corresponding arities. Type [('a0, ..., 'a) t] corresponds to\n ['a0 * ... * 'a].\n\n Each type [ti] is an instance of type [('tuple, 'variant) t], in which ['tuple] is\n the tuple type ['a0 * ... * 'a] and ['variant] is an encoding of the tuple type\n in the form: [[ `S0 of `a0 | `S1 of `a1 | ... | `S of `a ]].\n\n The encoding of the slots using a polymorphic variant allows one to write functions\n that are polymorphic in the tuple type, and require that a tuple have a certain\n slot, but allow more slots.\n\n We make [t] itself a polymorphic variant type so that one can easily encode cyclic\n types, e.g. lists, like:\n\n {[\n type 'a slots = ('a, 'a slots Pointer.t) Slots.t2\n ]}\n\n Observe that [slots] in the above is cyclic, but that OCaml allows it because the\n definition expands to:\n\n {[\n type 'a slots = [ `Slots of ('a * 'a slots Pointer.t,\n [ `S0 of 'a\n | `S1 of 'a slots Pointer.t\n ]\n ) u\n ]\n ]}\n\n Ultimately, a [Slots.t] is used as a phantom type that ensures consistent usage of\n the tuples in the data structure containing them. *)\n\n type ('tuple, 'variant) u\n type ('tuple, 'variant) t = [ `Slots of ('tuple, 'variant) u ] [@@deriving sexp_of]\n\n val slots_per_tuple : (_, _) t -> int\n\n type 'a0 t1 = ('a0, [ `S0 of 'a0 ]) t [@@deriving sexp_of]\n type ('a0, 'a1) t2 = ('a0 * 'a1, [ `S0 of 'a0 | `S1 of 'a1 ]) t [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2) t3 = ('a0 * 'a1 * 'a2, [ `S0 of 'a0 | `S1 of 'a1 | `S2 of 'a2 ]) t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3) t4 =\n ('a0 * 'a1 * 'a2 * 'a3, [ `S0 of 'a0 | `S1 of 'a1 | `S2 of 'a2 | `S3 of 'a3 ]) t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4) t5 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4\n , [ `S0 of 'a0 | `S1 of 'a1 | `S2 of 'a2 | `S3 of 'a3 | `S4 of 'a4 ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5) t6 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5\n , [ `S0 of 'a0 | `S1 of 'a1 | `S2 of 'a2 | `S3 of 'a3 | `S4 of 'a4 | `S5 of 'a5 ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6) t7 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7) t8 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8) t9 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9) t10 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n | `S9 of 'a9\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10) t11 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9 * 'a10\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n | `S9 of 'a9\n | `S10 of 'a10\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11) t12 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9 * 'a10 * 'a11\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n | `S9 of 'a9\n | `S10 of 'a10\n | `S11 of 'a11\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11, 'a12) t13 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9 * 'a10 * 'a11 * 'a12\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n | `S9 of 'a9\n | `S10 of 'a10\n | `S11 of 'a11\n | `S12 of 'a12\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11, 'a12, 'a13) t14 =\n ( 'a0\n * 'a1\n * 'a2\n * 'a3\n * 'a4\n * 'a5\n * 'a6\n * 'a7\n * 'a8\n * 'a9\n * 'a10\n * 'a11\n * 'a12\n * 'a13\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n | `S9 of 'a9\n | `S10 of 'a10\n | `S11 of 'a11\n | `S12 of 'a12\n | `S13 of 'a13\n ] )\n t\n [@@deriving sexp_of]\n\n val t1 : _ t1\n val t2 : (_, _) t2\n val t3 : (_, _, _) t3\n val t4 : (_, _, _, _) t4\n val t5 : (_, _, _, _, _) t5\n val t6 : (_, _, _, _, _, _) t6\n val t7 : (_, _, _, _, _, _, _) t7\n val t8 : (_, _, _, _, _, _, _, _) t8\n val t9 : (_, _, _, _, _, _, _, _, _) t9\n val t10 : (_, _, _, _, _, _, _, _, _, _) t10\n val t11 : (_, _, _, _, _, _, _, _, _, _, _) t11\n val t12 : (_, _, _, _, _, _, _, _, _, _, _, _) t12\n val t13 : (_, _, _, _, _, _, _, _, _, _, _, _, _) t13\n val t14 : (_, _, _, _, _, _, _, _, _, _, _, _, _, _) t14\nend\n\nmodule type Slot = sig\n (** A [Slot.t] represents a slot in a tuple type. *)\n type ('variant, 'a) t [@@deriving sexp_of]\n\n val equal : ('v, 'a) t -> ('v, 'a) t -> bool\n\n (** [ti] is the [i]'th slot. *)\n\n val t0 : ([> `S0 of 'a ], 'a) t\n val t1 : ([> `S1 of 'a ], 'a) t\n val t2 : ([> `S2 of 'a ], 'a) t\n val t3 : ([> `S3 of 'a ], 'a) t\n val t4 : ([> `S4 of 'a ], 'a) t\n val t5 : ([> `S5 of 'a ], 'a) t\n val t6 : ([> `S6 of 'a ], 'a) t\n val t7 : ([> `S7 of 'a ], 'a) t\n val t8 : ([> `S8 of 'a ], 'a) t\n val t9 : ([> `S9 of 'a ], 'a) t\n val t10 : ([> `S10 of 'a ], 'a) t\n val t11 : ([> `S11 of 'a ], 'a) t\n val t12 : ([> `S12 of 'a ], 'a) t\n val t13 : ([> `S13 of 'a ], 'a) t\nend\n","open! Core_kernel\nopen! Import\ninclude Tuple_type_intf\n\nmodule Slots = struct\n type u_ = { slots_per_tuple : int } [@@deriving sexp_of]\n type ('tuple, 'variant) u = u_ [@@deriving sexp_of]\n type t_ = [ `Slots of u_ ] [@@deriving sexp_of]\n type ('tuple, 'variant) t = t_ [@@deriving sexp_of]\n\n let slots_per_tuple (`Slots { slots_per_tuple = n }) = n\n\n type 'a0 t1 = t_ [@@deriving sexp_of]\n type ('a0, 'a1) t2 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2) t3 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3) t4 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4) t5 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5) t6 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6) t7 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7) t8 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8) t9 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9) t10 = t_ [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10) t11 = t_\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11) t12 = t_\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11, 'a12) t13 = t_\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11, 'a12, 'a13) t14 =\n t_\n [@@deriving sexp_of]\n\n let t1 = `Slots { slots_per_tuple = 1 }\n let t2 = `Slots { slots_per_tuple = 2 }\n let t3 = `Slots { slots_per_tuple = 3 }\n let t4 = `Slots { slots_per_tuple = 4 }\n let t5 = `Slots { slots_per_tuple = 5 }\n let t6 = `Slots { slots_per_tuple = 6 }\n let t7 = `Slots { slots_per_tuple = 7 }\n let t8 = `Slots { slots_per_tuple = 8 }\n let t9 = `Slots { slots_per_tuple = 9 }\n let t10 = `Slots { slots_per_tuple = 10 }\n let t11 = `Slots { slots_per_tuple = 11 }\n let t12 = `Slots { slots_per_tuple = 12 }\n let t13 = `Slots { slots_per_tuple = 13 }\n let t14 = `Slots { slots_per_tuple = 14 }\nend\n","open! Core_kernel\nmodule Pool = Tuple_pool\nmodule Pointer = Pool.Pointer\n\n(* This pool holds nodes that would be represented more traditionally as:\n\n {[\n type 'a t =\n | Empty\n | Heap of 'a * 'a t list ]}\n\n We will represent them as a left-child, right-sibling tree in a triplet\n (value * left_child * right_sibling). The left child and all right siblings\n of the left child form a linked list representing the subheaps of a given heap:\n\n {v\n A\n /\n B -> C -> D -> E -> F\n / / /\n G H->I->J K->L\n v} *)\n\nmodule Node : sig\n (* Exposing [private int] is a significant performance improvement, because it allows\n the compiler to skip the write barrier. *)\n\n type 'a t = private int\n\n module Id : sig\n type t\n\n val of_int : int -> t\n val equal : t -> t -> bool\n end\n\n module Pool : sig\n type 'a node = 'a t\n type 'a t\n\n val create : min_size:int -> 'a t\n val is_full : 'a t -> bool\n val length : 'a t -> int\n val grow : 'a t -> 'a t\n val copy : 'a t -> 'a node -> 'a node * 'a t\n end\n\n (** [allocate v ~pool] allocates a new node from the pool with no child or sibling *)\n val allocate : 'a -> pool:'a Pool.t -> id:Id.t -> 'a t\n\n (** [free t ~pool] frees [t] for reuse. It is an error to access [t] after this. *)\n val free : 'a t -> pool:'a Pool.t -> unit\n\n (** a special [t] that represents the empty node *)\n val empty : unit -> 'a t\n\n val is_empty : 'a t -> bool\n val equal : 'a t -> 'a t -> bool\n\n (** [value_exn t ~pool] return the value of [t], raise if [is_empty t] *)\n val value_exn : 'a t -> pool:'a Pool.t -> 'a\n\n val id : 'a t -> pool:'a Pool.t -> Id.t\n val child : 'a t -> pool:'a Pool.t -> 'a t\n val sibling : 'a t -> pool:'a Pool.t -> 'a t\n\n (** [prev t] is either the parent of [t] or the sibling immediately left of [t] *)\n val prev : 'a t -> pool:'a Pool.t -> 'a t\n\n (** [add_child t ~child ~pool] Add a child to [t], preserving existing children as\n siblings of [child]. [t] and [child] should not be empty and [child] should have no\n sibling and have no prev node. *)\n val add_child : 'a t -> child:'a t -> pool:'a Pool.t -> unit\n\n (** disconnect and return the sibling *)\n val disconnect_sibling : 'a t -> pool:'a Pool.t -> 'a t\n\n (** disconnect and return the child *)\n val disconnect_child : 'a t -> pool:'a Pool.t -> 'a t\n\n (** [detach t ~pool] removes [t] from the tree, adjusting pointers around it. After\n [detach], [t] is the root of a standalone heap, which is detached from the original\n heap. *)\n val detach : 'a t -> pool:'a Pool.t -> unit\nend = struct\n module Id = Int\n\n let dummy_id : Id.t = -1\n\n type 'a node =\n ('a, 'a node Pointer.t, 'a node Pointer.t, 'a node Pointer.t, Id.t) Pool.Slots.t5\n\n type 'a t = 'a node Pointer.t\n\n let empty = Pointer.null\n let is_empty = Pointer.is_null\n let equal = Pointer.phys_equal\n let value t ~pool = Pool.get pool t Pool.Slot.t0\n let child t ~pool = Pool.get pool t Pool.Slot.t1\n let sibling t ~pool = Pool.get pool t Pool.Slot.t2\n let prev t ~pool = Pool.get pool t Pool.Slot.t3\n let id t ~pool = Pool.get pool t Pool.Slot.t4\n\n (* let set_value t v ~pool = Pool.set pool t Pool.Slot.t0 v *)\n let set_child t v ~pool = Pool.set pool t Pool.Slot.t1 v\n let set_sibling t v ~pool = Pool.set pool t Pool.Slot.t2 v\n let set_prev t v ~pool = Pool.set pool t Pool.Slot.t3 v\n\n let value_exn t ~pool =\n assert (not (is_empty t));\n value t ~pool\n ;;\n\n let allocate value ~pool ~id = Pool.new5 pool value (empty ()) (empty ()) (empty ()) id\n let free t ~pool = Pool.unsafe_free pool t\n\n let disconnect_sibling t ~pool =\n let sibling = sibling t ~pool in\n if not (is_empty sibling)\n then (\n set_sibling t (empty ()) ~pool;\n set_prev sibling (empty ()) ~pool);\n sibling\n ;;\n\n let disconnect_child t ~pool =\n let child = child t ~pool in\n if not (is_empty child)\n then (\n set_child t (empty ()) ~pool;\n set_prev child (empty ()) ~pool);\n child\n ;;\n\n let add_child t ~child:new_child ~pool =\n (* assertions we would make, but for speed:\n assert (not (is_empty t));\n assert (not (is_empty new_child));\n assert (is_empty (sibling new_child ~pool));\n assert (is_empty (prev new_child ~pool));\n *)\n let current_child = disconnect_child t ~pool in\n (* add [new_child] to the list of [t]'s children (which may be empty) *)\n set_sibling new_child current_child ~pool;\n if not (is_empty current_child) then set_prev current_child new_child ~pool;\n set_child t new_child ~pool;\n set_prev new_child t ~pool\n ;;\n\n let detach t ~pool =\n if not (is_empty t)\n then (\n let prev = prev t ~pool in\n if not (is_empty prev)\n then (\n let relation_to_prev = if equal t (child prev ~pool) then `child else `sibling in\n set_prev t (empty ()) ~pool;\n let sibling = disconnect_sibling t ~pool in\n (match relation_to_prev with\n | `child -> set_child prev sibling ~pool\n | `sibling -> set_sibling prev sibling ~pool);\n if not (is_empty sibling) then set_prev sibling prev ~pool))\n ;;\n\n module Pool = struct\n type 'a t = 'a node Pool.t\n type nonrec 'a node = 'a node Pointer.t\n\n let create (type a) ~min_size:capacity : a t =\n Pool.create\n Pool.Slots.t5\n ~capacity\n ~dummy:\n ( (Obj.magic None : a)\n , Pointer.null ()\n , Pointer.null ()\n , Pointer.null ()\n , dummy_id )\n ;;\n\n let is_full t = Pool.is_full t\n let length t = Pool.length t\n let grow t = Pool.grow t\n\n let copy t start =\n let t' = create ~min_size:(Pool.capacity t) in\n let copy_node node to_visit =\n if is_empty node\n then empty (), to_visit\n else (\n (* we use the same id, but that's ok since ids should be unique per heap *)\n let new_node =\n allocate (value_exn node ~pool:t) ~pool:t' ~id:(id node ~pool:t)\n in\n let to_visit =\n (new_node, `child, child node ~pool:t)\n :: (new_node, `sibling, sibling node ~pool:t)\n :: to_visit\n in\n new_node, to_visit)\n in\n let rec loop to_visit =\n match to_visit with\n | [] -> ()\n | (node_to_update, slot, node_to_copy) :: rest ->\n let new_node, to_visit = copy_node node_to_copy rest in\n (match slot with\n | `child -> set_child node_to_update new_node ~pool:t'\n | `sibling -> set_sibling node_to_update new_node ~pool:t');\n if not (is_empty new_node) then set_prev new_node node_to_update ~pool:t';\n loop to_visit\n in\n let new_start, to_visit = copy_node start [] in\n loop to_visit;\n new_start, t'\n ;;\n end\nend\n\ntype 'a t =\n { (* cmp is placed first to short-circuit polymorphic compare *)\n cmp : 'a -> 'a -> int\n ; mutable pool : 'a Node.Pool.t\n ; (* invariant: [root] never has a sibling *)\n mutable root : 'a Node.t\n ; mutable num_of_allocated_nodes : int\n }\n\nlet invariant _ t =\n let rec loop to_visit =\n match to_visit with\n | [] -> ()\n | (node, expected_prev, maybe_parent_value) :: rest ->\n if not (Node.is_empty node)\n then (\n let this_value = Node.value_exn node ~pool:t.pool in\n assert (Node.equal (Node.prev node ~pool:t.pool) expected_prev);\n Option.iter maybe_parent_value ~f:(fun parent_value ->\n assert (t.cmp parent_value this_value <= 0));\n loop\n ((Node.child node ~pool:t.pool, node, Some this_value)\n :: (Node.sibling node ~pool:t.pool, node, maybe_parent_value)\n :: rest))\n else loop rest\n in\n assert (Node.is_empty t.root || Node.is_empty (Node.sibling t.root ~pool:t.pool));\n loop [ t.root, Node.empty (), None ]\n;;\n\nlet create ?(min_size = 1) ~cmp () =\n { cmp\n ; pool = Node.Pool.create ~min_size\n ; root = Node.empty ()\n ; num_of_allocated_nodes = 0\n }\n;;\n\nlet copy { cmp; pool; root; num_of_allocated_nodes } =\n let root, pool = Node.Pool.copy pool root in\n { cmp; pool; root; num_of_allocated_nodes }\n;;\n\nlet allocate t v =\n if Node.Pool.is_full t.pool then t.pool <- Node.Pool.grow t.pool;\n t.num_of_allocated_nodes <- t.num_of_allocated_nodes + 1;\n Node.allocate v ~pool:t.pool ~id:(Node.Id.of_int t.num_of_allocated_nodes)\n;;\n\n(* translation:\n {[\n match root1, root2 with\n | None, h | h, None -> h\n | Some (Node (v1, children1)), Some (Node (v2, children2)) ->\n if v1 < v2\n then Some (Node (v1, root2 :: children1))\n else Some (Node (v2, root1 :: children2))\n ]}\n\n This function assumes neither root has a prev node (usually because the inputs come\n from [disconnect_*] or are the top of the heap or are the output of this function). *)\nlet merge t root1 root2 =\n if Node.is_empty root1\n then root2\n else if Node.is_empty root2\n then root1\n else (\n let add_child t node ~child =\n Node.add_child node ~pool:t.pool ~child;\n node\n in\n let v1 = Node.value_exn root1 ~pool:t.pool in\n let v2 = Node.value_exn root2 ~pool:t.pool in\n if t.cmp v1 v2 < 0\n then add_child t root1 ~child:root2\n else add_child t root2 ~child:root1)\n;;\n\nlet top_exn t =\n if Node.is_empty t.root\n then failwith \"Heap.top_exn called on an empty heap\"\n else Node.value_exn t.root ~pool:t.pool\n;;\n\nlet top t = if Node.is_empty t.root then None else Some (top_exn t)\n\nlet add_node t v =\n let node = allocate t v in\n t.root <- merge t t.root node;\n node\n;;\n\nlet add t v = ignore (add_node t v : _ Node.t)\n\n(* [merge_pairs] takes a list of heap roots and merges consecutive pairs, reducing the\n list of length n to n/2. Then it merges the merged pairs into a single heap. One\n intuition is that this is somewhat like building a single level of a binary tree.\n\n The output heap does not contain the value that was at the root of the input heap.\n\n We break the function into two parts. A first stage that is willing to use limited\n stack instead of heap allocation for bookkeeping, and a second stage that shifts to\n using a list as an accumulator if we go too deep.\n\n This can be made tail recursive and non-allocating by starting with an empty heap and\n merging merged pairs into it. Unfortunately this \"left fold\" version is not what is\n described in the original paper by Fredman et al.; they specifically say that\n children should be merged together from the end of the list to the beginning of the\n list. ([merge] is not associative, so order matters.)\n*)\n(* translation:\n {[\n let rec loop acc = function\n | [] -> acc\n | [head] -> head :: acc\n | head :: next1 :: next2 -> loop (merge head next1 :: acc) next2\n in\n match loop [] children with\n | [] -> None\n | [h] -> Some h\n | x :: xs -> Some (List.fold xs ~init:x ~f:merge)\n ]}\n*)\nlet allocating_merge_pairs t head =\n let rec loop acc head =\n if Node.is_empty head\n then acc\n else (\n let next1 = Node.disconnect_sibling head ~pool:t.pool in\n if Node.is_empty next1\n then head :: acc\n else (\n let next2 = Node.disconnect_sibling next1 ~pool:t.pool in\n loop (merge t head next1 :: acc) next2))\n in\n match loop [] head with\n | [] -> Node.empty ()\n | [ h ] -> h\n | x :: xs -> List.fold xs ~init:x ~f:(fun acc heap -> merge t acc heap)\n;;\n\n(* translation:\n {[\n match t.root with\n | Node (_, children) ->\n let rec loop depth children =\n if depth >= max_stack_depth\n then allocating_merge_pairs t childen\n else begin\n match children with\n | [] -> None\n | [head] -> Some head\n | head :: next1 :: next2 ->\n merge (merge head next1) (loop (depth + 1) next2)\n end\n in\n loop 0 children\n ]}\n*)\nlet merge_pairs =\n let max_stack_depth = 1_000 in\n let rec loop t depth head =\n if depth >= max_stack_depth\n then allocating_merge_pairs t head\n else if Node.is_empty head\n then head\n else (\n let next1 = Node.disconnect_sibling head ~pool:t.pool in\n if Node.is_empty next1\n then head\n else (\n let next2 = Node.disconnect_sibling next1 ~pool:t.pool in\n (* merge the first two nodes in our list, and then merge the result with the\n result of recursively calling merge_pairs on the tail *)\n merge t (merge t head next1) (loop t (depth + 1) next2)))\n in\n fun t head -> loop t 0 head\n;;\n\nlet remove_non_empty t node =\n let pool = t.pool in\n Node.detach node ~pool;\n let merged_children = merge_pairs t (Node.disconnect_child node ~pool) in\n let new_root =\n if Node.equal t.root node then merged_children else merge t t.root merged_children\n in\n Node.free node ~pool;\n t.root <- new_root\n;;\n\nlet remove_top t = if not (Node.is_empty t.root) then remove_non_empty t t.root\n\nlet pop_exn t =\n let r = top_exn t in\n remove_top t;\n r\n;;\n\nlet pop t = if Node.is_empty t.root then None else Some (pop_exn t)\n\nlet pop_if t f =\n match top t with\n | None -> None\n | Some v ->\n if f v\n then (\n remove_top t;\n Some v)\n else None\n;;\n\n(* pairing heaps are not balanced trees, and therefore we can't rely on a balance\n property to stop ourselves from overflowing the stack. *)\nlet fold t ~init ~f =\n let pool = t.pool in\n let rec loop acc to_visit =\n match to_visit with\n | [] -> acc\n | node :: rest ->\n if Node.is_empty node\n then loop acc rest\n else (\n let to_visit = Node.sibling ~pool node :: Node.child ~pool node :: rest in\n loop (f acc (Node.value_exn ~pool node)) to_visit)\n in\n loop init [ t.root ]\n;;\n\n(* almost identical to fold, copied for speed purposes *)\nlet iter t ~f =\n let pool = t.pool in\n let rec loop to_visit =\n match to_visit with\n | [] -> ()\n | node :: rest ->\n if Node.is_empty node\n then loop rest\n else (\n f (Node.value_exn ~pool node);\n let to_visit = Node.sibling ~pool node :: Node.child ~pool node :: rest in\n loop to_visit)\n in\n loop [ t.root ]\n;;\n\nlet length t = Node.Pool.length t.pool\n\nmodule C = Container.Make (struct\n type nonrec 'a t = 'a t\n\n let fold = fold\n let iter = `Custom iter\n let length = `Custom length\n end)\n\nlet is_empty t = Node.is_empty t.root\nlet mem = C.mem\nlet exists = C.exists\nlet for_all = C.for_all\nlet count = C.count\nlet sum = C.sum\nlet find = C.find\nlet find_map = C.find_map\nlet to_list = C.to_list\nlet to_array = C.to_array\nlet min_elt = C.min_elt\nlet max_elt = C.max_elt\nlet fold_result = C.fold_result\nlet fold_until = C.fold_until\n\nlet of_array arr ~cmp =\n let t = create ~min_size:(Array.length arr) ~cmp () in\n Array.iter arr ~f:(fun v -> add t v);\n t\n;;\n\nlet of_list l ~cmp = of_array (Array.of_list l) ~cmp\nlet sexp_of_t f t = Array.sexp_of_t f (to_array t |> Array.sorted_copy ~compare:t.cmp)\n\nmodule Elt = struct\n type nonrec 'a t =\n { mutable node : 'a Node.t\n ; node_id : Node.Id.t\n ; heap : 'a t\n }\n\n (* If ids are different, it means that the node has already been removed by some\n other means (and possibly reused). *)\n let is_node_valid t = Node.Id.equal (Node.id ~pool:t.heap.pool t.node) t.node_id\n\n let value t =\n if is_node_valid t then Some (Node.value_exn t.node ~pool:t.heap.pool) else None\n ;;\n\n let value_exn t =\n if is_node_valid t\n then Node.value_exn t.node ~pool:t.heap.pool\n else failwith \"Heap.value_exn: node was removed from the heap\"\n ;;\n\n let sexp_of_t sexp_of_a t = [%sexp (value t : a option)]\nend\n\nlet remove t (token : _ Elt.t) =\n if not (phys_equal t token.heap)\n then failwith \"cannot remove from a different heap\"\n else if not (Node.is_empty token.node)\n then (\n if Elt.is_node_valid token then remove_non_empty t token.node;\n token.node <- Node.empty ())\n;;\n\nlet add_removable t v =\n let node = add_node t v in\n { Elt.node; heap = t; node_id = Node.id ~pool:t.pool node }\n;;\n\nlet update t token v =\n remove t token;\n add_removable t v\n;;\n\nlet find_elt =\n let rec loop t f nodes =\n match nodes with\n | [] -> None\n | node :: rest ->\n if Node.is_empty node\n then loop t f rest\n else if f (Node.value_exn node ~pool:t.pool)\n then Some { Elt.node; heap = t; node_id = Node.id ~pool:t.pool node }\n else\n loop t f (Node.sibling node ~pool:t.pool :: Node.child node ~pool:t.pool :: rest)\n in\n fun t ~f -> loop t f [ t.root ]\n;;\n\nmodule Unsafe = struct\n module Elt = struct\n type 'a heap = 'a t\n type 'a t = 'a Node.t\n\n let value t heap = Node.value_exn ~pool:heap.pool t\n end\n\n let add_removable = add_node\n let remove = remove_non_empty\n\n let update t elt v =\n remove t elt;\n add_removable t v\n ;;\nend\n","open! Core_kernel\n\nmodule Make (M : sig\n val am_running_test : bool\n end) =\nstruct\n type 'a t = 'a [@@deriving bin_io, compare, sexp]\n\n let sexp_of_t sexp_of_a a =\n if M.am_running_test then Sexp.Atom \"\" else sexp_of_a a\n ;;\n\n module With_non_roundtripping_in_test_of_sexp = struct\n type nonrec 'a t = 'a t [@@deriving bin_io, compare, sexp]\n end\nend\n\nlet%test_module _ =\n (module struct\n module Turned_off = struct\n module Sexp_hidden_in_test_turned_off = Make (struct\n let am_running_test = false\n end)\n\n type nonrec t = int Sexp_hidden_in_test_turned_off.t [@@deriving sexp_of]\n end\n\n module Turned_on = struct\n module Sexp_hidden_in_test_turned_on = Make (struct\n let am_running_test = true\n end)\n\n type nonrec t = int Sexp_hidden_in_test_turned_on.t [@@deriving sexp_of]\n end\n\n let%expect_test \"Turned on\" =\n print_s [%sexp (1024 : Turned_on.t)];\n [%expect {| |}]\n ;;\n\n let%expect_test \"Turned off\" =\n print_s ([%sexp_of: Turned_off.t] 1024);\n [%expect {| 1024 |}]\n ;;\n end)\n;;\n\ninclude Make (struct\n let am_running_test = am_running_test\n end)\n","(* This module exploits the fact that OCaml does not perform context-switches under\n certain conditions. It can therefore avoid using mutexes.\n\n Given the semantics of the current OCaml runtime (and for the foreseeable future), code\n sections documented as atomic below will never contain a context-switch. The deciding\n criterion is whether they contain allocations or calls to external/builtin functions.\n If there is none, a context-switch cannot happen. Assignments without allocations,\n field access, pattern-matching, etc., do not trigger context-switches.\n\n Code reviewers should therefore make sure that the sections documented as atomic below\n do not violate the above assumptions. It is prudent to disassemble the .o file (using\n [objdump -dr]) and examine it. *)\n\nopen! Core_kernel\nopen! Import\n\nmodule Elt = struct\n type 'a t =\n { mutable value : 'a Uopt.t\n ; mutable next : ('a t Uopt.t[@sexp.opaque])\n }\n [@@deriving sexp_of]\n\n let create () = { value = Uopt.none; next = Uopt.none }\nend\n\ntype 'a t =\n { mutable length : int\n (* [front] to [back] has [length + 1] linked elements, where the first [length] hold the\n values in the queue, and the last is [back], holding no value. *)\n ; mutable front : 'a Elt.t\n ; mutable back : 'a Elt.t\n (* [unused_elts] is singly linked via [next], and ends with [sentinel]. All elts in\n [unused_elts] have [Uopt.is_none elt.value]. *)\n ; mutable unused_elts : 'a Elt.t Uopt.t\n }\n[@@deriving fields, sexp_of]\n\nlet invariant _invariant_a t =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~length:(check (fun length -> assert (length >= 0)))\n ~front:\n (check (fun front ->\n let i = ref t.length in\n let r = ref front in\n while !i > 0 do\n decr i;\n let elt = !r in\n r := Uopt.value_exn elt.Elt.next;\n assert (Uopt.is_some elt.value)\n done;\n assert (phys_equal !r t.back)))\n ~back:(check (fun back -> assert (Uopt.is_none back.Elt.value)))\n ~unused_elts:\n (check (fun unused_elts ->\n let r = ref unused_elts in\n while Uopt.is_some !r do\n let elt = Uopt.value_exn !r in\n r := elt.Elt.next;\n assert (Uopt.is_none elt.value)\n done)))\n;;\n\nlet create () =\n let elt = Elt.create () in\n { front = elt; back = elt; length = 0; unused_elts = Uopt.none }\n;;\n\nlet get_unused_elt t =\n (* BEGIN ATOMIC SECTION *)\n if Uopt.is_some t.unused_elts\n then (\n let elt = Uopt.unsafe_value t.unused_elts in\n t.unused_elts <- elt.next;\n elt (* END ATOMIC SECTION *))\n else Elt.create ()\n;;\n\nlet enqueue (type a) (t : a t) (a : a) =\n let new_back = get_unused_elt t in\n (* BEGIN ATOMIC SECTION *)\n t.length <- t.length + 1;\n t.back.value <- Uopt.some a;\n t.back.next <- Uopt.some new_back;\n t.back <- new_back\n;;\n\n(* END ATOMIC SECTION *)\n\nlet return_unused_elt t (elt : _ Elt.t) =\n (* BEGIN ATOMIC SECTION *)\n elt.value <- Uopt.none;\n elt.next <- t.unused_elts;\n t.unused_elts <- Uopt.some elt;\n (* END ATOMIC SECTION *)\n ()\n;;\n\nlet[@cold] raise_dequeue_empty t =\n failwiths\n ~here:[%here]\n \"Thread_safe_queue.dequeue_exn of empty queue\"\n t\n [%sexp_of: _ t]\n;;\n\nlet dequeue_exn t =\n (* BEGIN ATOMIC SECTION *)\n if t.length = 0 then raise_dequeue_empty t;\n let elt = t.front in\n let a = elt.value in\n t.front <- Uopt.unsafe_value elt.next;\n t.length <- t.length - 1;\n (* END ATOMIC SECTION *)\n return_unused_elt t elt;\n Uopt.unsafe_value a\n;;\n\nlet clear_internal_pool t = t.unused_elts <- Uopt.none\n\nmodule Private = struct\n module Uopt = Uopt\nend\n","include Core_kernel.Core_kernel_private.Time_ns_alternate_sexp\n\n(* [after] is like [add], but deals nicely with the case of overflow by instead returning\n [max_value]. Time-source functions use [after] to avoid immediately firing events that\n should never fire, due to the overflow leading to a negative time that appears to be in\n the past. We don't check underflow because that is very unlikely, requiring both a\n negative time and a negative span. *)\nlet after t span =\n let result = add t span in\n if Span.( > ) span Span.zero && result < t then max_value_for_1us_rounding else result\n;;\n","open Core_kernel\nopen Import\n\nlet debug = Debug.monitor\n\ntype t = Types.Monitor.t =\n { name : Info.t\n ; here : Source_code_position.t option\n ; id : int\n ; parent : t option\n ; mutable next_error : exn Types.Ivar.t\n ; (* [Monitor.send_exn] schedules a job for each element of [handlers_for_all_errors]. *)\n mutable handlers_for_all_errors : (Types.Execution_context.t * (exn -> unit)) Bag.t\n ; (* [Monitor.send_exn] extends each tail in [tails_for_all_errors]. *)\n mutable tails_for_all_errors : exn Types.Tail.t list\n ; mutable has_seen_error : bool\n ; mutable is_detached : bool\n }\n[@@deriving fields]\n\nmodule Pretty = struct\n type one =\n { name : Info.t\n ; here : Source_code_position.t option\n ; id : int\n ; has_seen_error : bool\n ; is_detached : bool\n }\n [@@deriving sexp_of]\n\n type t = one list [@@deriving sexp_of]\nend\n\nlet to_pretty =\n let rec loop\n { name\n ; here\n ; id\n ; parent\n ; has_seen_error\n ; is_detached\n ; next_error = _\n ; handlers_for_all_errors = _\n ; tails_for_all_errors = _\n }\n ac\n =\n let ac = { Pretty.name; here; id; has_seen_error; is_detached } :: ac in\n match parent with\n | None -> List.rev ac\n | Some t -> loop t ac\n in\n fun t -> loop t []\n;;\n\nlet sexp_of_t t = Pretty.sexp_of_t (to_pretty t)\n\nlet next_id =\n let r = ref 0 in\n fun () ->\n incr r;\n !r\n;;\n\nlet create_with_parent ?here ?info ?name parent =\n let id = next_id () in\n let name =\n match info, name with\n | Some i, None -> i\n | Some i, Some s -> Info.tag i ~tag:s\n | None, Some s -> Info.of_string s\n | None, None -> Info.create \"id\" id [%sexp_of: int]\n in\n let t =\n { name\n ; here\n ; parent\n ; id\n ; next_error = { cell = Empty }\n ; handlers_for_all_errors = Bag.create ()\n ; tails_for_all_errors = []\n ; has_seen_error = false\n ; is_detached = false\n }\n in\n if debug then Debug.log \"created monitor\" t [%sexp_of: t];\n t\n;;\n\nlet main = create_with_parent ~name:\"main\" None\n","module Time_ns_in_this_directory = Time_ns\nopen Core_kernel\nmodule Time_ns = Time_ns_in_this_directory\ninclude Async_kernel_config.Print_debug_messages_for\n\nlet log message a sexp_of_a =\n eprintf\n \"%s\\n%!\"\n (Sexp.to_string_hum\n ([%sexp_of: Sexp.t * Time_ns.t * string * a]\n (!Async_kernel_config.task_id (), Time_ns.now (), message, a)))\n;;\n\nlet log_string message = log message () [%sexp_of: unit]\n","module Debug_in_this_directory = Debug\nmodule Time_ns_in_this_directory = Time_ns\nopen! Core_kernel\ninclude Int.Replace_polymorphic_compare\nmodule Debug = Debug_in_this_directory\nmodule Time_ns = Time_ns_in_this_directory\nmodule Epoll_max_ready_events = Async_kernel_config.Epoll_max_ready_events\nmodule Max_inter_cycle_timeout = Async_kernel_config.Max_inter_cycle_timeout\nmodule Max_num_open_file_descrs = Async_kernel_config.Max_num_open_file_descrs\nmodule Max_num_threads = Async_kernel_config.Max_num_threads\nmodule Pool = Tuple_pool\n\nmodule Max_num_jobs_per_priority_per_cycle =\n Async_kernel_config.Max_num_jobs_per_priority_per_cycle\n\nlet concat = String.concat\nlet eprint = Core_kernel.Debug.eprint\nlet eprint_s = Core_kernel.Debug.eprint_s\nlet eprints = Core_kernel.Debug.eprints\nlet print_s sexp = printf \"%s\\n%!\" (sexp |> Sexp.to_string_hum)\nlet sec = Time_ns.Span.of_sec\n\n(* We don't want to use these modules in Async_kernel, to avoid difficulties with\n using it on js_of_ocaml. *)\nmodule Thread = struct end\nmodule Unix = struct end\n","open! Core_kernel\nopen! Import\n\ntype t =\n | Normal\n | Low\n[@@deriving sexp_of]\n\nlet normal = Normal\nlet low = Low\n","(* This file defines the mutually recursive types at the heart of Async. The functions\n associated with the types are defined in the corresponding file(s) for each module.\n This file should define only types, not functions, since functions defined inside the\n recursive modules are not inlined.\n\n If you need to add functionality to a module but doing so would create a dependency\n cycle, split the file into pieces as needed to break the cycle, e.g. scheduler0.ml,\n scheduler1.ml, scheduler.ml. *)\n\nopen! Core_kernel\nopen! Import\n\nmodule rec Cell : sig\n type any =\n [ `Empty\n | `Empty_one_handler\n | `Empty_one_or_more_handlers\n | `Full\n | `Indir\n ]\n\n type ('a, 'b) t =\n | Empty_one_or_more_handlers :\n { mutable run : 'a -> unit\n ; execution_context : Execution_context.t\n ; mutable prev : 'a Handler.t\n ; mutable next : 'a Handler.t\n }\n -> ('a, [> `Empty_one_or_more_handlers ]) t\n | Empty_one_handler :\n ('a -> unit) * Execution_context.t\n -> ('a, [> `Empty_one_handler ]) t\n | Empty : ('a, [> `Empty ]) t\n | Full : 'a -> ('a, [> `Full ]) t\n | Indir : 'a Ivar.t -> ('a, [> `Indir ]) t\nend =\n Cell\n\nand Handler : sig\n type 'a t = ('a, [ `Empty_one_or_more_handlers ]) Cell.t\nend =\n Handler\n\nand Ivar : sig\n type 'a t = { mutable cell : ('a, Cell.any) Cell.t }\n\n module Immutable : sig\n type 'a t = { cell : ('a, Cell.any) Cell.t }\n end\nend =\n Ivar\n\nand Deferred : sig\n type +'a t\nend =\n Deferred\n\nand Execution_context : sig\n type t =\n { monitor : Monitor.t\n ; priority : Priority.t\n ; local_storage : Univ_map.t\n ; tid : int\n ; backtrace_history : Backtrace.t list\n }\nend =\n Execution_context\n\nand Monitor : sig\n type t =\n { name : Info.t\n ; here : Source_code_position.t option\n ; id : int\n ; parent : t option\n ; mutable next_error : exn Ivar.t\n ; mutable handlers_for_all_errors : (Execution_context.t * (exn -> unit)) Bag.t\n ; mutable tails_for_all_errors : exn Tail.t list\n ; mutable has_seen_error : bool\n ; mutable is_detached : bool\n }\nend =\n Monitor\n\nand Tail : sig\n type 'a t = { mutable next : 'a Stream.next Ivar.t }\nend =\n Tail\n\nand Stream : sig\n type 'a t = 'a next Deferred.t\n\n and 'a next =\n | Nil\n | Cons of 'a * 'a t\nend =\n Stream\n\n(* We avoid using [module rec] to define [Bvar], so that [to_repr] and [of_repr] are\n inlined. *)\nmodule Bvar : sig\n type ('a, -'permission) t\n\n (** [repr] exists so that we may hide the implementation of a [Bvar.t], and then add a\n phantom type to it upstream. Without this, the phantom type variable would allow\n for anything to be coerced in and out, since it is unused. *)\n type 'a repr =\n { mutable has_any_waiters : bool\n ; mutable ivar : 'a Ivar.t\n }\n\n val of_repr : 'a repr -> ('a, 'permission) t\n val to_repr : ('a, 'permission) t -> 'a repr\nend = struct\n type 'a repr =\n { mutable has_any_waiters : bool\n ; mutable ivar : 'a Ivar.t\n }\n\n type ('a, 'permission) t = 'a repr\n\n let to_repr t = t\n let of_repr t = t\nend\n\nmodule rec Event : sig\n module Status : sig\n type t =\n | Aborted\n | Fired\n | Happening\n | Scheduled\n | Unscheduled\n end\n\n type t =\n { mutable alarm : Job_or_event.t Timing_wheel.Alarm.t\n ; mutable at : Time_ns.t\n ; callback : unit -> unit\n ; execution_context : Execution_context.t\n ; mutable interval : Time_ns.Span.t option\n ; mutable next_fired : t\n ; mutable status : Status.t\n }\nend =\n Event\n\nand External_job : sig\n type t = T : Execution_context.t * ('a -> unit) * 'a -> t\nend =\n External_job\n\nand Job : sig\n type slots = (Execution_context.t, Obj.t -> unit, Obj.t) Pool.Slots.t3\n type t = slots Pool.Pointer.t\nend =\n Job\n\nand Job_or_event : sig\n type t\nend =\n Job_or_event\n\nand Job_pool : sig\n type t = Job.slots Pool.t\nend =\n Job_pool\n\nand Job_queue : sig\n type t =\n { mutable num_jobs_run : int\n ; mutable jobs_left_this_cycle : int\n ; mutable jobs : Obj.t Uniform_array.t\n ; mutable mask : int\n ; mutable front : int\n ; mutable length : int\n }\nend =\n Job_queue\n\nand Jobs : sig\n type t =\n { scheduler : Scheduler.t\n ; mutable job_pool : Job_pool.t\n ; normal : Job_queue.t\n ; low : Job_queue.t\n }\nend =\n Jobs\n\nand Scheduler : sig\n\n type t =\n { mutable check_access : (unit -> unit) option\n ; mutable job_pool : Job_pool.t\n ; normal_priority_jobs : Job_queue.t\n ; low_priority_jobs : Job_queue.t\n ; very_low_priority_workers : Very_low_priority_worker.t Deque.t\n ; mutable main_execution_context : Execution_context.t\n ; mutable current_execution_context : Execution_context.t\n ; mutable uncaught_exn : (Exn.t * Sexp.t) option\n ; mutable cycle_count : int\n ; mutable cycle_start : Time_ns.t\n ; mutable in_cycle : bool\n ; mutable run_every_cycle_start : (unit -> unit) list\n ; mutable run_every_cycle_end : (unit -> unit) list\n ; mutable last_cycle_time : Time_ns.Span.t\n ; mutable last_cycle_num_jobs : int\n ; mutable total_cycle_time : Time_ns.Span.t\n ; mutable time_source : read_write Time_source.t1\n ; external_jobs : External_job.t Thread_safe_queue.t\n ; mutable thread_safe_external_job_hook : unit -> unit\n ; mutable job_queued_hook : (Priority.t -> unit) option\n ; mutable event_added_hook : (Time_ns.t -> unit) option\n ; mutable yield : (unit, read_write) Bvar.t\n ; mutable yield_until_no_jobs_remain : (unit, read_write) Bvar.t\n ; mutable check_invariants : bool\n ; mutable max_num_jobs_per_priority_per_cycle : Max_num_jobs_per_priority_per_cycle.t\n ; mutable record_backtraces : bool\n ; mutable on_start_of_cycle : unit -> unit\n ; mutable on_end_of_cycle : unit -> unit\n ; mutable long_jobs_last_cycle : (Execution_context.t * Time_ns.Span.t) list\n ; mutable cycle_started : bool\n }\nend =\n Scheduler\n\nand Time_source_id : Unique_id.Id = Unique_id.Int63 ()\n\nand Time_source : sig\n type -'rw t1 =\n { id : Time_source_id.t\n ; mutable advance_errors : Error.t list\n ; mutable am_advancing : bool\n ; events : Job_or_event.t Timing_wheel.t\n ; mutable fired_events : Event.t\n ; mutable most_recently_fired : Event.t\n ; handle_fired : Job_or_event.t Timing_wheel.Alarm.t -> unit\n ; is_wall_clock : bool\n ; scheduler : Scheduler.t\n }\nend =\n Time_source\n\nand Very_low_priority_worker : sig\n module Exec_result : sig\n type t =\n | Finished\n | Not_finished\n end\n\n type t =\n { execution_context : Execution_context.t\n ; exec : unit -> Exec_result.t\n }\nend =\n Very_low_priority_worker\n","open! Core_kernel\nopen! Import\nmodule Monitor = Monitor0\n\ntype t = Types.Execution_context.t =\n { monitor : Monitor.t\n ; priority : Priority.t\n ; local_storage : Univ_map.t\n ; tid : int\n ; backtrace_history : Backtrace.t list\n }\n[@@deriving fields, sexp_of]\n\nlet invariant (_ : t) = ()\n\nlet main =\n { monitor = Monitor.main\n ; priority = Priority.normal\n ; local_storage = Univ_map.empty\n ; tid = 0\n ; backtrace_history = []\n }\n;;\n\nlet create_like ?monitor ?priority ?local_storage t =\n let monitor = Option.value monitor ~default:t.monitor in\n { monitor\n ; priority = Option.value priority ~default:t.priority\n ; local_storage = Option.value local_storage ~default:t.local_storage\n ; tid = t.tid\n ; backtrace_history = t.backtrace_history\n }\n;;\n\nlet find_local t key = Univ_map.find t.local_storage key\n\nlet with_local t key data =\n { t with local_storage = Univ_map.change t.local_storage key ~f:(fun _ -> data) }\n;;\n\nlet with_tid t tid =\n { t with tid }\n;;\n\nlet record_backtrace t =\n { t with backtrace_history = Backtrace.get () :: t.backtrace_history }\n;;\n","open! Core_kernel\nopen! Import\nmodule Scheduler = Scheduler0\n\nlet dummy_e = Execution_context.main\nlet dummy_f : Obj.t -> unit = ignore\nlet dummy_a : Obj.t = Obj.repr ()\nlet slots_per_elt = 3\n\nmodule A = Uniform_array\n\n(* This is essentially a specialized [Flat_queue], done for reasons of speed. *)\ntype t = Types.Job_queue.t =\n { mutable num_jobs_run : int\n ; mutable jobs_left_this_cycle : int\n ; (* [jobs] is an array of length [capacity t * slots_per_elt], where each elt has the\n three components of a job ([execution_context], [f], [a]) in consecutive spots in\n [jobs]. [enqueue] doubles the length of [jobs] if [jobs] is full. [jobs] never\n shrinks. [jobs] is somewhat like a [Core_kernel.Pool] specialized to 3-tuples; we\n don't use [Pool] because that implements a set, where [jobs] is a queue. *)\n mutable jobs : (Obj.t A.t[@sexp.opaque])\n ; (* [mask] is [capacity t - 1], and is used for quickly computing [i mod (capacity\n t)] *)\n mutable mask : int\n ; (* [front] is the index of the first job in the queue. The array index of that job's\n execution context is [front * slots_per_elt]. *)\n mutable front : int\n ; mutable length : int\n }\n[@@deriving fields, sexp_of]\n\nlet offset t i = (t.front + i) land t.mask * slots_per_elt\nlet capacity t = t.mask + 1\n\nlet invariant t : unit =\n Invariant.invariant [%here] t [%sexp_of: t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~num_jobs_run:(check (fun num_jobs_run -> assert (num_jobs_run >= 0)))\n ~jobs_left_this_cycle:\n (check (fun jobs_left_this_cycle -> assert (jobs_left_this_cycle >= 0)))\n ~jobs:\n (check (fun jobs ->\n for i = 0 to t.length - 1 do\n Execution_context.invariant\n (Obj.obj (A.get jobs (offset t i)) : Execution_context.t)\n done))\n ~mask:\n (check (fun mask ->\n let capacity = mask + 1 in\n assert (Int.is_pow2 capacity);\n assert (capacity * slots_per_elt = A.length t.jobs)))\n ~front:\n (check (fun front ->\n assert (front >= 0);\n assert (front < capacity t)))\n ~length:\n (check (fun length ->\n assert (length >= 0);\n assert (length <= capacity t))))\n;;\n\nlet create_array ~capacity = A.create_obj_array ~len:(capacity * slots_per_elt)\n\nlet create () =\n let capacity = 1 in\n { num_jobs_run = 0\n ; jobs_left_this_cycle = 0\n ; jobs = create_array ~capacity\n ; mask = capacity - 1\n ; front = 0\n ; length = 0\n }\n;;\n\nlet clear t =\n t.front <- 0;\n t.length <- 0;\n t.jobs_left_this_cycle <- 0\n;;\n\nlet grow t =\n let old_capacity = capacity t in\n let new_capacity = old_capacity * 2 in\n let old_jobs = t.jobs in\n let old_front = t.front in\n let len1 = Int.min t.length (old_capacity - old_front) * slots_per_elt in\n let len2 = (t.length * slots_per_elt) - len1 in\n let new_jobs = create_array ~capacity:new_capacity in\n A.blit\n ~len:len1\n ~src:old_jobs\n ~src_pos:(old_front * slots_per_elt)\n ~dst:new_jobs\n ~dst_pos:0;\n A.blit ~len:len2 ~src:old_jobs ~src_pos:0 ~dst:new_jobs ~dst_pos:len1;\n t.mask <- new_capacity - 1;\n t.jobs <- new_jobs;\n t.front <- 0\n;;\n\nlet set (type a) t i execution_context f a =\n let offset = offset t i in\n A.unsafe_set t.jobs offset (Obj.repr (execution_context : Execution_context.t));\n A.unsafe_set t.jobs (offset + 1) (Obj.repr (f : a -> unit));\n A.unsafe_set t.jobs (offset + 2) (Obj.repr (a : a))\n;;\n\nlet enqueue t execution_context f a =\n if t.length = capacity t then grow t;\n set t t.length execution_context f a;\n t.length <- t.length + 1\n;;\n\nlet set_jobs_left_this_cycle t n =\n if n < 0\n then\n raise_s\n [%message \"Jobs.set_jobs_left_this_cycle got negative number\" (n : int) (t : t)];\n t.jobs_left_this_cycle <- n\n;;\n\nlet can_run_a_job t = t.length > 0 && t.jobs_left_this_cycle > 0\n\nlet run_job t (scheduler : Scheduler.t) execution_context f a =\n t.num_jobs_run <- t.num_jobs_run + 1;\n Scheduler.set_execution_context scheduler execution_context;\n f a\n;;\n\nlet run_external_jobs t (scheduler : Scheduler.t) =\n let external_jobs = scheduler.external_jobs in\n while Thread_safe_queue.length external_jobs > 0 do\n let (External_job.T (execution_context, f, a)) =\n Thread_safe_queue.dequeue_exn external_jobs\n in\n run_job t scheduler execution_context f a\n done\n;;\n\nlet run_jobs (type a) t (scheduler : Scheduler.t) =\n (* We do the [try-with] outside of the [while] because it is cheaper than doing a\n [try-with] for each job. *)\n (* [run_external_jobs] before entering the loop, since it might enqueue a job,\n changing [t.length]. *)\n try\n run_external_jobs t scheduler;\n while can_run_a_job t do\n let this_job = offset t 0 in\n let execution_context : Execution_context.t =\n Obj.obj (A.unsafe_get t.jobs this_job)\n in\n let f : a -> unit = Obj.obj (A.unsafe_get t.jobs (this_job + 1)) in\n let a : a = Obj.obj (A.unsafe_get t.jobs (this_job + 2)) in\n (* We clear out the job right now so that it isn't live at the next minor\n collection. We tried not doing this and saw significant (15% or so) performance\n hits due to spurious promotion. *)\n set t 0 dummy_e dummy_f dummy_a;\n t.front <- (t.front + 1) land t.mask;\n t.length <- t.length - 1;\n t.jobs_left_this_cycle <- t.jobs_left_this_cycle - 1;\n (* It is OK if [run_job] or [run_external_jobs] raises, in which case the exn is\n handled by the outer try-with. The only side effects we have done are to take\n the job out of the queue and decrement [jobs_left_this_cycle]. [run_job] or\n [run_external_jobs] may side effect [t], either by enqueueing jobs, or by\n clearing [t]. *)\n (!Tracing.fns).on_job_enter execution_context ;\n let start = Time_ns.now () in\n run_job t scheduler execution_context f a;\n let this_job_time = Time_ns.(diff (now ()) start) in\n if Float.(Time_ns.Span.to_ms this_job_time >= 2000.) then scheduler.long_jobs_last_cycle <- (execution_context, this_job_time) :: scheduler.long_jobs_last_cycle;\n (!Tracing.fns).on_job_exit execution_context this_job_time ;\n (* [run_external_jobs] at each iteration of the [while] loop, for fairness. *)\n run_external_jobs t scheduler\n done;\n Ok ()\n with\n | exn ->\n (* We call [Exn.backtrace] immediately after catching an unhandled exception, to\n ensure there is no intervening code that interferes with the global backtrace\n state. *)\n let backtrace = Backtrace.Exn.most_recent () in\n Error (exn, backtrace)\n;;\n","type tracing_fns =\n { on_job_enter : Execution_context.t -> unit\n ; on_job_exit : Execution_context.t -> Time_ns.Span.t -> unit }\n\nlet fns = ref { on_job_enter= (fun _ -> ()); on_job_exit= (fun _ _ -> ()) }\n","open! Core_kernel\nopen! Import\ninclude Types.External_job\n\nlet sexp_of_t _ = Sexp.Atom \"\"\n","open! Core_kernel\nopen! Import\nopen Pool\nmodule Pointer = Pointer\nmodule Slot = Slot\n\nlet dummy_e = Execution_context.main\nlet dummy_f : Obj.t -> unit = ignore\nlet dummy_a : Obj.t = Obj.repr ()\n\ntype slots = (Execution_context.t, Obj.t -> unit, (Obj.t[@sexp.opaque])) Slots.t3\n[@@deriving sexp_of]\n\ntype t = slots Pool.t [@@deriving sexp_of]\n\nlet invariant t = Pool.invariant ignore t\nlet create () = create Slots.t3 ~capacity:1 ~dummy:(dummy_e, dummy_f, dummy_a)\n","open! Core_kernel\nopen! Import\nmodule Event = Types.Event\nmodule Job = Types.Job\ninclude Types.Job_or_event\n\n(* This redefinition of [Event] is here so the type checks are right next to\n [Obj.magic]s. *)\nmodule Event_is_block : sig end = struct\n open Types\n open Event\n\n type _t = t =\n { (* must never be immediate *)\n mutable alarm : Job_or_event.t Timing_wheel.Alarm.t\n ; mutable at : Time_ns.t\n ; callback : unit -> unit\n ; execution_context : Execution_context.t\n ; mutable interval : Time_ns.Span.t option\n ; mutable next_fired : t\n ; mutable status : Status.t\n }\nend\n\nmodule Job_is_not_block : sig end = struct\n module Ensure_private_int (M : sig\n type t = private int\n end) =\n struct\n type _t = M.t\n end\n\n include Ensure_private_int (Job)\nend\n\nlet of_event event : t = Obj.magic (event : Event.t)\nlet of_job job : t = Obj.magic (job : Job.t)\nlet is_event (t : t) = Obj.is_block (Obj.repr t)\nlet is_job (t : t) = Obj.is_int (Obj.repr t)\n\nmodule Match = struct\n type _ kind =\n | Event : Event.t kind\n | Job : Job.t kind\n\n type packed = K : _ kind -> packed\n\n let kind t = if is_event t then K Event else K Job\n let project (type a) (_ : a kind) job_or_event = (Obj.magic : t -> a) job_or_event\nend\n","open! Core_kernel\nopen! Import\ninclude Types.Scheduler\n\nlet events t = t.time_source.events\n\nlet set_execution_context t execution_context =\n (* Avoid a caml_modify in most cases. *)\n (* XXX: see where job_queue also modifies current_execution_context *)\n if not (phys_equal t.current_execution_context execution_context) then (\n t.cycle_started <- false ;\n t.current_execution_context <- execution_context )\n","open! Core_kernel\nopen! Import\n\nmodule Time_ns = struct\n include Time_ns\n\n external format : float -> string -> string = \"core_kernel_time_ns_format\"\n\n (* We use a more pleasant format than [Core_kernel.Time_ns.sexp_of_t],\n which has to be messier for round trippability. *)\n let sexp_of_t t =\n [%sexp\n (format (t |> to_span_since_epoch |> Span.to_sec) \"%Y-%m-%dT%H:%M:%S%z\" : string)]\n ;;\nend\n\nmodule Alarm = struct\n include Timing_wheel.Alarm\n\n let is_null t = phys_equal t (null ())\nend\n\nmodule Alarm_precision = Timing_wheel.Alarm_precision\n\nlet default_timing_wheel_config =\n (* 1/8th of a millisecond alarm_precision seems sufficient to avoid having many alarms\n in the same interval, which avoids quadratic insertion sort when firing alarms. And\n the level bits give us levels of >1s, >1m, >1h, >1d. See test in\n [../test/test_synchronous_time_source.ml]. *)\n Timing_wheel.Config.create\n ~alarm_precision:Alarm_precision.(div about_one_millisecond ~pow2:3)\n ~level_bits:(Timing_wheel.Level_bits.create_exn [ 13; 6; 6; 5 ])\n ()\n;;\n\ntype callback = unit -> unit\n\nmodule Id = Types.Time_source_id\n\nmodule T1 = struct\n module Event = struct\n module Status = struct\n type t = Types.Event.Status.t =\n | Aborted\n (* in [fired_events], must not run *)\n | Fired\n (* in [fired_events], ready to run *)\n | Happening\n (* currently running the callback *)\n | Scheduled\n (* in the timing wheel *)\n | Unscheduled (* not in timing wheel or [fired_events] *)\n [@@deriving compare, sexp_of]\n\n let transition_is_allowed ~from ~to_ =\n match from, to_ with\n | Aborted, Unscheduled (* skipped running callback *)\n | Fired, Happening (* started running callback *)\n | Fired, Aborted (* aborted *)\n | Happening, Scheduled (* for repeating events *)\n | Happening, Unscheduled (* event callback finished *)\n | Scheduled, Fired (* moved from timing wheel to [fired_events] *)\n | Scheduled, Unscheduled (* aborted *)\n | Unscheduled, Fired (* event scheduled in the past *)\n | Unscheduled, Scheduled (* event scheduled in the future *) -> true\n | (Aborted | Fired | Happening | Scheduled | Unscheduled), _ -> false\n ;;\n end\n\n type t = Types.Event.t =\n { (* [alarm] is non-null iff the event is in the timing wheel. *)\n mutable alarm : Job_or_event.t Alarm.t\n ; mutable at : Time_ns.t\n ; callback : unit -> unit\n ; execution_context : Execution_context.t\n ; (* [interval] is the period for the periodic events *)\n mutable interval : Time_ns.Span.t option\n ; (* [next_fired] is a singly-linked list of fired events, linked via [next_fired].\n An event is added to the list when it fires, either because it is added with a\n time in the past, or because time advances. [advance_by_alarms] iterates over\n the events in [next_fired] and runs them, emptying the list. *)\n mutable next_fired : t\n ; mutable status : Status.t\n }\n [@@deriving fields]\n\n (* [none] is used to indicate the end of the singly-linked list of fired events. *)\n let rec none =\n { alarm = Alarm.null ()\n ; at = Time_ns.min_value_for_1us_rounding\n ; callback = (fun () -> assert false)\n ; execution_context = Execution_context.main\n ; interval = None\n ; next_fired = none\n ; status = Unscheduled\n }\n ;;\n\n let is_none t = phys_equal t none\n let is_some t = not (is_none t)\n\n let sexp_of_t\n ({ alarm = _\n ; at\n ; callback = _\n ; execution_context = _\n ; interval\n ; next_fired = _\n ; status\n } as t)\n =\n if is_none t\n then [%sexp \"none\"]\n else\n [%message\n \"\" (status : Status.t) (at : Time_ns.t) (interval : Time_ns.Span.t option)]\n ;;\n\n let invariant t =\n Invariant.invariant [%here] t [%sexp_of: t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~alarm:\n (check (fun alarm ->\n [%test_result: bool]\n (Alarm.is_null alarm)\n ~expect:\n (match t.status with\n | Aborted | Fired | Happening | Unscheduled -> true\n | Scheduled -> false)))\n ~at:ignore\n ~callback:ignore\n ~execution_context:ignore\n ~interval:ignore\n ~next_fired:\n (check (fun next_fired ->\n if is_some next_fired\n then (\n match t.status with\n | Aborted | Fired -> ()\n | Happening | Scheduled | Unscheduled -> assert false)))\n ~status:ignore)\n ;;\n\n let compare_at t1 t2 = Time_ns.compare t1.at t2.at\n\n let set_status t to_ =\n let from = t.status in\n if not (Status.transition_is_allowed ~from ~to_)\n then\n raise_s\n [%message\n [%here]\n \"bug -- set_status transition not allowed\"\n (from : Status.t)\n (to_ : Status.t)\n ~event:(t : t)];\n t.status <- to_\n ;;\n end\n\n module Job_or_event = struct\n include Job_or_event\n\n let sexp_of_t t =\n let open Job_or_event.Match in\n let (K k) = kind t in\n match k, project k t with\n | Event, event -> [%sexp (event : Event.t)]\n | Job, _ ->\n (* We don't display the [Job.t]s in [events] because those are\n pool pointers, which are uninformative. *)\n [%message \"\"]\n ;;\n end\n\n type -'rw t = 'rw Types.Time_source.t1 =\n { id : Id.t\n ; (* [advance_errors] accumulates errors raised by alarms run by\n [advance_by_alarms]. *)\n mutable advance_errors : Error.t list\n ; (* [am_advancing] is true only during [advance_by_alarms], and is used to cause\n callbacks to raise if they call [advance_by_alarms]. *)\n mutable am_advancing : bool\n ; events : Job_or_event.t Timing_wheel.t\n ; (* [fired_events] is the front of the singly linked list of fired events, which is\n stored in increasing order of [Event.at]. *)\n mutable fired_events : Event.t\n ; (* [most_recently_fired] is the event that was most recently inserted into\n [fired_events]. It is used as an optimization to allow insertion of subsequent\n events to start later in the list rather than at the beginning. It specifically\n avoids quadratic behavior when inserting multiple events that have exactly the\n same time -- the time source fires such events in the order they were added, and\n we want them to be in that same order in [fired_events]. *)\n mutable most_recently_fired : Event.t\n ; (* We store [handle_fired] in [t] to avoid allocating it every time we call\n [advance_clock]. *)\n handle_fired : Job_or_event.t Alarm.t -> unit\n ; is_wall_clock : bool\n ; scheduler : Scheduler0.t\n }\n [@@deriving fields]\n\n (* We don't include the [id] in the sexp because the user (rightly) can't control it, so\n it's hard to make it deterministic in tests. *)\n let sexp_of_t\n _\n { id = _\n ; advance_errors = _\n ; am_advancing = _\n ; events\n ; fired_events = _\n ; handle_fired = _\n ; is_wall_clock\n ; most_recently_fired = _\n ; scheduler = _\n }\n =\n let now = Timing_wheel.now events in\n if is_wall_clock\n then [%message \"wall_clock\" (now : Time_ns.t)]\n else (\n let all_events = ref [] in\n Timing_wheel.iter events ~f:(fun alarm ->\n all_events := (Alarm.at events alarm, Alarm.value events alarm) :: !all_events);\n let events =\n List.sort !all_events ~compare:(fun (at1, _) (at2, _) -> Time_ns.compare at1 at2)\n |> List.map ~f:snd\n in\n [%message \"\" (now : Time_ns.t) (events : Job_or_event.t list)])\n ;;\n\n let timing_wheel_now t = Timing_wheel.now t.events\n\n let is_in_fired_events t event =\n with_return (fun r ->\n let current = ref t.fired_events in\n while Event.is_some !current do\n if phys_equal !current event then r.return true;\n current := !current.next_fired\n done;\n false)\n ;;\n\n let invariant_with_jobs (type rw) ~job:(job_invariant : Job.t -> unit) (t : rw t) =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~id:ignore\n ~advance_errors:ignore\n ~am_advancing:ignore\n ~events:\n (check (fun events ->\n Timing_wheel.invariant ignore events;\n Timing_wheel.iter events ~f:(fun alarm ->\n let job_or_event = Alarm.value events alarm in\n let open Job_or_event.Match in\n let (K k) = kind job_or_event in\n match k, project k job_or_event with\n | Job, job -> job_invariant job\n | Event, event ->\n assert (phys_equal alarm event.alarm);\n [%test_result: Time_ns.t] event.at ~expect:(Alarm.at events alarm);\n [%test_result: Event.Status.t] event.status ~expect:Scheduled)))\n ~fired_events:\n (check (fun (fired_events : Event.t) ->\n let current = ref fired_events in\n while Event.is_some !current do\n assert (Time_ns.( <= ) !current.at (timing_wheel_now t));\n let next = !current.next_fired in\n if Event.is_some next then assert (Time_ns.( <= ) !current.at next.at);\n current := next\n done))\n ~handle_fired:ignore\n ~is_wall_clock:ignore\n ~most_recently_fired:\n (check (fun most_recently_fired ->\n if Event.is_some t.most_recently_fired\n then assert (is_in_fired_events t most_recently_fired)))\n ~scheduler:ignore)\n ;;\n\n let invariant t = invariant_with_jobs ~job:(fun _ -> ()) t\nend\n\nopen T1\n\ntype t = read T1.t [@@deriving sexp_of]\n\nlet invariant = invariant\nlet invariant_with_jobs = invariant_with_jobs\n\nmodule Read_write = struct\n type t = read_write T1.t [@@deriving sexp_of]\n\n let invariant = invariant\n let invariant_with_jobs = invariant_with_jobs\nend\n\nlet id t = t.id\nlet is_wall_clock t = t.is_wall_clock\nlet length t = Timing_wheel.length t.events\nlet max_allowed_alarm_time t = Timing_wheel.max_allowed_alarm_time t.events\nlet read_only (t : [> read ] T1.t) = (t :> t)\n\n(* [fire t event] sets [event.status = Fired] and inserts [event] into [t.fired_events] in\n sorted time order. *)\nlet fire t (event : Event.t) =\n Event.set_status event Fired;\n event.alarm <- Alarm.null ();\n let prev = ref Event.none in\n let current = ref t.fired_events in\n (* If [event] belongs after [t.most_recently_fired], then we start the insertion there\n rather than at the front of [t.fired_events]. This works nicely if we're getting the\n alarms in non-decreasing time order, which is close to what [Timing_wheel]\n provides (although [Timing_wheel] doesn't guarantee time ordering for times in the\n same interval). *)\n if Event.is_some t.most_recently_fired\n && Time_ns.( >= ) event.at t.most_recently_fired.at\n then (\n prev := t.most_recently_fired;\n current := !prev.next_fired);\n (* We use [Time_ns.( <= )] rather than [<] so that [event] is added after other events\n at the same time. Since [Timing_wheel] fires alarms in a bucket in the order in\n which they were added, using [<=] keeps events at the same time in the order in which\n they were added. *)\n while Event.is_some !current && Time_ns.( <= ) !current.at event.at do\n prev := !current;\n current := !current.next_fired\n done;\n event.next_fired <- !current;\n t.most_recently_fired <- event;\n if Event.is_none !prev then t.fired_events <- event else !prev.next_fired <- event\n;;\n\nlet alarm_precision t = Timing_wheel.alarm_precision t.events\nlet next_alarm_fires_at t = Timing_wheel.next_alarm_fires_at t.events\nlet now t = if t.is_wall_clock then Time_ns.now () else timing_wheel_now t\nlet timing_wheel_now = timing_wheel_now\n\nlet schedule t (event : Event.t) =\n Event.set_status event Scheduled;\n event.alarm <- Timing_wheel.add t.events ~at:event.at (event |> Job_or_event.of_event)\n;;\n\nmodule Event = struct\n include Event\n\n let create_internal t ~at ~interval ~callback =\n { alarm = Alarm.null ()\n ; at\n ; callback\n ; execution_context = t.scheduler.current_execution_context\n ; interval\n ; next_fired = none\n ; status = Unscheduled\n }\n ;;\n\n let add t event =\n if Time_ns.( <= ) event.at (timing_wheel_now t)\n then fire t event\n else schedule t event\n ;;\n\n let create_and_add t ~at ~interval ~callback =\n let event = create_internal t ~at ~interval ~callback in\n add t event;\n event\n ;;\n\n let at t at callback = create_and_add t ~at ~interval:None ~callback\n\n let after t span callback =\n create_and_add t ~at:(Time_ns.after (now t) span) ~interval:None ~callback\n ;;\n\n let require_span_at_least_alarm_precision t span =\n let alarm_precision = alarm_precision t in\n if Time_ns.Span.( < ) span alarm_precision\n then\n raise_s\n [%message\n \"interval span smaller than alarm precision\"\n (span : Time_ns.Span.t)\n (alarm_precision : Time_ns.Span.t)]\n ;;\n\n let at_intervals t span callback =\n require_span_at_least_alarm_precision t span;\n create_and_add t ~at:(now t) ~interval:(Some span) ~callback\n ;;\n\n module Abort_result = struct\n type t =\n | Ok\n | Currently_happening\n | Previously_unscheduled\n [@@deriving sexp_of]\n end\n\n let abort t (event : t) : Abort_result.t =\n match event.status with\n | Aborted -> Previously_unscheduled\n | Happening ->\n if Option.is_none event.interval\n then Currently_happening\n else (\n event.interval <- None;\n Ok)\n | Fired ->\n Event.set_status event Aborted;\n Ok\n | Scheduled ->\n Event.set_status event Unscheduled;\n Timing_wheel.remove t.events event.alarm;\n event.alarm <- Alarm.null ();\n Ok\n | Unscheduled -> Previously_unscheduled\n ;;\n\n let abort_if_possible t event = ignore (abort t event : Abort_result.t)\n\n let abort_exn t event =\n match abort t event with\n | Ok -> ()\n | reason ->\n raise_s\n [%message\n \"[Synchronous_time_source.abort_exn] cannot abort event\"\n (reason : Abort_result.t)]\n ;;\n\n let create t callback = create_internal t ~at:Time_ns.epoch ~interval:None ~callback\n\n let schedule_at_internal t (event : t) at ~interval =\n (* [Fired] is disallowed to prevent the user from entering into an infinite loop. The\n user could specify [at] in the past which would constantly add [callback] to the\n back of [t.next_fired] if this function is called from [callback]. *)\n match event.status with\n | (Aborted | Happening | Scheduled | Fired) as status ->\n Or_error.error_s\n [%message \"cannot schedule an event with status\" ~_:(status : Event.Status.t)]\n | Unscheduled ->\n event.at <- at;\n event.interval <- interval;\n add t event;\n Ok ()\n ;;\n\n let schedule_at t event at = schedule_at_internal t event at ~interval:None\n let schedule_after t event span = schedule_at t event (Time_ns.after (now t) span)\n\n let schedule_at_intervals t event span =\n require_span_at_least_alarm_precision t span;\n schedule_at_internal t event (now t) ~interval:(Some span)\n ;;\n\n module Reschedule_result = struct\n type t =\n | Ok\n | Currently_happening\n | Recently_aborted\n | Recently_fired\n [@@deriving sexp_of]\n end\n\n let reschedule_at t event at : Reschedule_result.t =\n match event.status with\n | Aborted -> Recently_aborted\n | Fired -> Recently_fired\n | Happening -> Currently_happening\n | Scheduled ->\n event.at <- at;\n if Time_ns.( > ) at (timing_wheel_now t)\n then Timing_wheel.reschedule t.events event.alarm ~at\n else (\n Timing_wheel.remove t.events event.alarm;\n fire t event);\n Ok\n | Unscheduled ->\n event.at <- at;\n event.interval <- None;\n add t event;\n Ok\n ;;\n\n let reschedule_after t event span = reschedule_at t event (Time_ns.after (now t) span)\n\n module Option = struct\n type value = t\n type nonrec t = t\n\n let is_none = is_none\n let is_some = is_some\n\n let some value =\n (* This assert shouldn't fail because [t] is a [value] and so should never\n be [none]. *)\n assert (is_some value);\n value\n ;;\n\n (* It should be impossible for [some_is_representable] to return [false]\n because its input is a [value], but since it's only loosely enforced we\n handle the general case. *)\n let some_is_representable value =\n assert (is_some value);\n true\n ;;\n\n let none = none\n let unchecked_value = Fn.id\n let value t ~default = if is_none t then default else unchecked_value t\n\n let value_exn t =\n if is_none t\n then raise_s [%message \"[Synchronous_time_source.Event.Option.value_exn None]\"];\n t\n ;;\n\n let to_option t = if is_none t then None else Some t\n\n let of_option = function\n | None -> none\n | Some t -> some t\n ;;\n\n let sexp_of_t t = to_option t |> [%sexp_of: t option]\n\n module Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n let unsafe_value = Fn.id\n end\n end\n end\n\nend\n\nlet run_after t span callback = ignore (Event.after t span callback : Event.t)\nlet run_at t at callback = ignore (Event.at t at callback : Event.t)\n\nlet run_at_intervals t span callback =\n ignore (Event.at_intervals t span callback : Event.t)\n;;\n\ntype send_exn = Monitor0.t -> ?backtrace:[ `Get | `This of Backtrace.t ] -> exn -> unit\n\nlet run_fired_events t ~(send_exn : send_exn option) =\n let current_execution_context = t.scheduler.current_execution_context in\n while Event.is_some t.fired_events do\n let event = t.fired_events in\n if phys_equal event t.most_recently_fired then t.most_recently_fired <- Event.none;\n t.fired_events <- event.next_fired;\n event.next_fired <- Event.none;\n match event.status with\n | Aborted -> Event.set_status event Unscheduled\n | Happening | Scheduled | Unscheduled -> assert false\n | Fired ->\n Event.set_status event Happening;\n (* We set the execution context so that [event.callback] runs in the same context\n that was in place when [event] was created. *)\n Scheduler0.set_execution_context t.scheduler event.execution_context;\n (match event.callback () with\n | exception exn ->\n (match send_exn with\n | None -> t.advance_errors <- Error.of_exn exn :: t.advance_errors\n | Some send_exn ->\n let backtrace = Backtrace.get () in\n send_exn event.execution_context.monitor exn ~backtrace:(`This backtrace));\n Event.set_status event Unscheduled\n | () ->\n (match event.interval with\n | None -> Event.set_status event Unscheduled\n | Some interval ->\n event.at\n <- Time_ns.next_multiple\n ()\n ~base:event.at\n ~after:(timing_wheel_now t)\n ~interval;\n schedule t event))\n done;\n Scheduler0.set_execution_context t.scheduler current_execution_context\n;;\n\nlet advance_clock t ~to_ ~send_exn =\n Timing_wheel.advance_clock t.events ~to_ ~handle_fired:t.handle_fired;\n run_fired_events t ~send_exn\n;;\n\nlet fire_past_alarms t ~send_exn =\n Timing_wheel.fire_past_alarms t.events ~handle_fired:t.handle_fired;\n run_fired_events t ~send_exn\n;;\n\nlet advance_internal t ~to_ ~send_exn =\n advance_clock t ~to_ ~send_exn;\n fire_past_alarms t ~send_exn\n;;\n\nlet prepare_to_advance t ~send_exn =\n if t.am_advancing\n then raise_s [%message \"cannot call [advance_by_alarms] from callback\"];\n t.am_advancing <- true;\n (match t.advance_errors with\n | [] -> ()\n | _ -> t.advance_errors <- []);\n run_fired_events t ~send_exn\n;;\n\nlet finish_advancing t =\n t.am_advancing <- false;\n match t.advance_errors with\n | [] -> Ok ()\n | errors ->\n t.advance_errors <- [];\n Error (Error.of_list errors)\n;;\n\nlet advance_by_alarms t ~to_ =\n let send_exn = None in\n prepare_to_advance t ~send_exn;\n let continue = ref true in\n while !continue do\n if Timing_wheel.is_empty t.events\n then continue := false\n else (\n let next_alarm_fires_at = Timing_wheel.next_alarm_fires_at_exn t.events in\n if Time_ns.( >= ) next_alarm_fires_at to_\n then continue := false\n else\n (* We use the actual alarm time, rather than [next_alarm_fires_at], so as not to\n expose (or accumulate errors associated with) the precision of\n [Timing_wheel]. *)\n advance_internal\n t\n ~to_:(Timing_wheel.max_alarm_time_in_min_interval_exn t.events)\n ~send_exn)\n done;\n advance_internal t ~to_ ~send_exn;\n finish_advancing t\n;;\n\nlet advance_directly t ~to_ =\n let send_exn = None in\n prepare_to_advance t ~send_exn;\n advance_internal t ~to_ ~send_exn;\n finish_advancing t\n;;\n\nmodule Expert = struct\n let max_alarm_time_in_min_timing_wheel_interval t =\n Timing_wheel.max_alarm_time_in_min_interval t.events\n ;;\n\n let has_events_to_run t = Event.is_some t.fired_events\nend\n","open Core_kernel\nopen Import\ninclude Scheduler0\nmodule Synchronous_time_source = Synchronous_time_source0\nmodule Event = Synchronous_time_source.Event\nmodule Alarm = Timing_wheel.Alarm\nmodule Job_or_event = Synchronous_time_source.T1.Job_or_event\n\nlet debug = Debug.scheduler\n\nmodule Ivar = struct\n open Types.Ivar\n\n let create_with_cell cell = { cell }\n let create () = create_with_cell Empty\n\n let create_full (type a) (a : a) =\n (* We allocate an immutable ivar and then cast it to a mutable ivar. The immutability\n allows OCaml to statically allocate the ivar if [a] is constant. This cast is safe\n because a full ivar is never mutated. We also believe that we will not trigger\n flambda to spuriously repor warning 59, mutation of known immutable data. All\n mutations of an ivar cell, i.e. [foo.cell <- ...], are directly preceded by a\n [match foo.cell] that prevents the [Full] case from reaching the modification. So\n flambda should always eliminate the [foo.cell <- ...] of a constant [Full] ivar,\n and not warn. *)\n (Obj.magic : a Immutable.t -> a t) { cell = Full a }\n ;;\nend\n\nmodule Bvar = struct\n open Types.Bvar\n\n let create () = of_repr { has_any_waiters = false; ivar = Ivar.create () }\nend\n\nmodule Very_low_priority_worker = struct\n module Exec_result = struct\n type t = Types.Very_low_priority_worker.Exec_result.t =\n | Finished\n | Not_finished\n [@@deriving sexp_of]\n end\n\n type t = Types.Very_low_priority_worker.t =\n { execution_context : Execution_context.t\n ; exec : unit -> Exec_result.t\n }\n [@@deriving fields, sexp_of]\n\n let invariant t =\n Invariant.invariant [%here] t [%sexp_of: t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter ~execution_context:(check Execution_context.invariant) ~exec:ignore)\n ;;\nend\n\ntype t = Scheduler0.t =\n { (* [check_access] optionally holds a function to run to check whether access to [t] is\n currently allowed. It is used to detect invalid access to the scheduler from a\n thread. *)\n mutable check_access : (unit -> unit) option\n ; mutable job_pool : Job_pool.t\n ; normal_priority_jobs : Job_queue.t\n ; low_priority_jobs : Job_queue.t\n ; very_low_priority_workers : Very_low_priority_worker.t Deque.t\n ; mutable main_execution_context : Execution_context.t\n ; mutable current_execution_context : Execution_context.t\n (* The scheduler calls [got_uncaught_exn] when an exception bubbles to the top of the\n monitor tree without being handled. This function guarantees to never run another\n job after this by calling [clear] and because [enqueue_job] will never add another\n job. *)\n ; mutable uncaught_exn : (Exn.t * Sexp.t) option\n ; mutable cycle_count : int\n ; mutable cycle_start : Time_ns.t\n ; mutable in_cycle : bool\n ; mutable run_every_cycle_start : (unit -> unit) list\n ; mutable run_every_cycle_end : (unit -> unit) list\n ; mutable last_cycle_time : Time_ns.Span.t\n ; mutable last_cycle_num_jobs : int\n ; mutable total_cycle_time : Time_ns.Span.t\n ; mutable time_source : read_write Synchronous_time_source.T1.t\n (* [external_jobs] is a queue of actions sent from outside of async. This is for the\n case where we want to schedule a job or fill an ivar from a context where it is not\n safe to run async code, because the async lock isn't held. For instance: - in an\n OCaml finalizer, as they can run at any time in any thread.\n\n The way to do it is to queue a thunk in [external_jobs] and call\n [thread_safe_external_job_hook], which is responsible for notifying the scheduler\n that new actions are available.\n\n When using Async on unix, [thread_safe_external_job_hook] is set in [Async_unix]\n to call [Interruptor.thread_safe_interrupt], which will wake up the\n [Async_unix] scheduler and run a cycle.\n\n Note that this hook might be used in other context (js_of_ocaml, mirage).\n\n When running a cycle, we pull external actions at every job and perform them\n immediately. *)\n ; external_jobs : External_job.t Thread_safe_queue.t\n ; mutable thread_safe_external_job_hook : unit -> unit\n (* [job_queued_hook] and [event_added_hook] aim to be used by js_of_ocaml. *)\n (* We use [_ option] here because those hooks will not be set in the common case\n and we want to avoid extra function calls. *)\n ; mutable job_queued_hook : (Priority.t -> unit) option\n ; mutable event_added_hook : (Time_ns.t -> unit) option\n ; mutable yield : ((unit, read_write) Types.Bvar.t[@sexp.opaque])\n ; mutable yield_until_no_jobs_remain :\n ((unit, read_write) Types.Bvar.t[@sexp.opaque] (* configuration*))\n ; mutable check_invariants : bool\n ; mutable max_num_jobs_per_priority_per_cycle : Max_num_jobs_per_priority_per_cycle.t\n ; mutable record_backtraces : bool\n ; mutable on_start_of_cycle : unit -> unit\n ; mutable on_end_of_cycle : unit -> unit\n ; mutable long_jobs_last_cycle : (Execution_context.t * Time_ns.Span.t) list\n ; mutable cycle_started : bool\n }\n[@@deriving fields, sexp_of]\n\nlet uncaught_exn_unwrapped = uncaught_exn\n\nlet uncaught_exn t =\n match t.uncaught_exn with\n | None -> None\n | Some (exn, sexp) ->\n Some (Error.create \"unhandled exception\" (exn, sexp) [%sexp_of: Exn.t * Sexp.t])\n;;\n\nlet num_pending_jobs t =\n Job_queue.length t.normal_priority_jobs + Job_queue.length t.low_priority_jobs\n;;\n\nlet num_jobs_run t =\n Job_queue.num_jobs_run t.normal_priority_jobs\n + Job_queue.num_jobs_run t.low_priority_jobs\n;;\n\nlet last_cycle_num_jobs t = t.last_cycle_num_jobs\n\nlet invariant t : unit =\n try\n let check f field = f (Field.get field t) in\n Fields.iter\n ~check_access:ignore\n ~job_pool:(check Job_pool.invariant)\n ~normal_priority_jobs:(check Job_queue.invariant)\n ~low_priority_jobs:(check Job_queue.invariant)\n ~very_low_priority_workers:\n (check (fun q -> Deque.iter q ~f:Very_low_priority_worker.invariant))\n ~main_execution_context:(check Execution_context.invariant)\n ~current_execution_context:(check Execution_context.invariant)\n ~uncaught_exn:\n (check (fun uncaught_exn ->\n if is_some uncaught_exn then assert (num_pending_jobs t = 0)))\n ~cycle_count:(check (fun cycle_count -> assert (cycle_count >= 0)))\n ~cycle_start:ignore\n ~in_cycle:ignore\n ~run_every_cycle_start:ignore\n ~run_every_cycle_end:ignore\n ~last_cycle_time:ignore\n ~total_cycle_time:ignore\n ~last_cycle_num_jobs:\n (check (fun last_cycle_num_jobs -> assert (last_cycle_num_jobs >= 0)))\n ~time_source:\n (check\n (Synchronous_time_source.Read_write.invariant_with_jobs ~job:(fun job ->\n assert (Pool.pointer_is_valid t.job_pool job))))\n ~external_jobs:ignore\n ~thread_safe_external_job_hook:ignore\n ~job_queued_hook:ignore\n ~event_added_hook:ignore\n ~yield:ignore\n ~yield_until_no_jobs_remain:ignore\n ~check_invariants:ignore\n ~max_num_jobs_per_priority_per_cycle:ignore\n ~record_backtraces:ignore\n ~cycle_started:ignore\n ~long_jobs_last_cycle:ignore\n ~on_start_of_cycle:ignore\n ~on_end_of_cycle:ignore\n with\n | exn -> raise_s [%message \"Scheduler.invariant failed\" (exn : exn) (t : t)]\n;;\n\nlet free_job t job = Pool.free t.job_pool job\n\nlet enqueue t (execution_context : Execution_context.t) f a =\n (* If there's been an uncaught exn, we don't add the job, since we don't want any jobs\n to run once there's been an uncaught exn. *)\n if is_none t.uncaught_exn\n then (\n let priority = execution_context.priority in\n let job_queue =\n match priority with\n | Normal -> t.normal_priority_jobs\n | Low -> t.low_priority_jobs\n in\n Job_queue.enqueue job_queue execution_context f a;\n match t.job_queued_hook with\n | None -> ()\n | Some f -> f priority)\n;;\n\nlet enqueue_job t job ~free_job =\n let job_pool = t.job_pool in\n enqueue\n t\n (Pool.get job_pool job Pool.Slot.t0)\n (Pool.get job_pool job Pool.Slot.t1)\n (Pool.get job_pool job Pool.Slot.t2);\n if free_job then Pool.free t.job_pool job\n;;\n\nlet handle_fired (time_source : _ Synchronous_time_source.T1.t) job_or_event =\n let open Job_or_event.Match in\n let (K k) = kind job_or_event in\n match k, project k job_or_event with\n | Job, job -> enqueue_job time_source.scheduler job ~free_job:true\n | Event, event -> Synchronous_time_source.fire time_source event\n;;\n\nlet create () =\n let now = Time_ns.now () in\n let rec t =\n { check_access = None\n ; job_pool = Job_pool.create ()\n ; normal_priority_jobs = Job_queue.create ()\n ; low_priority_jobs = Job_queue.create ()\n ; very_low_priority_workers = Deque.create ()\n ; main_execution_context = Execution_context.main\n ; current_execution_context = Execution_context.main\n ; uncaught_exn = None\n ; cycle_start = now\n ; cycle_count = 0\n ; in_cycle = false\n ; run_every_cycle_start = []\n ; run_every_cycle_end = []\n ; last_cycle_time = sec 0.\n ; last_cycle_num_jobs = 0\n ; total_cycle_time = sec 0.\n ; time_source\n ; external_jobs = Thread_safe_queue.create ()\n ; thread_safe_external_job_hook = ignore\n ; job_queued_hook = None\n ; event_added_hook = None\n ; yield = Bvar.create ()\n ; yield_until_no_jobs_remain = Bvar.create () (* configuration *)\n ; check_invariants = Async_kernel_config.check_invariants\n ; max_num_jobs_per_priority_per_cycle =\n Async_kernel_config.max_num_jobs_per_priority_per_cycle\n ; record_backtraces = Async_kernel_config.record_backtraces\n ; cycle_started = false\n ; on_start_of_cycle = Fn.id\n ; on_end_of_cycle = Fn.id\n ; long_jobs_last_cycle= []\n }\n and events =\n Timing_wheel.create ~config:Async_kernel_config.timing_wheel_config ~start:now\n and time_source : _ Synchronous_time_source.T1.t =\n { id = Types.Time_source_id.create ()\n ; advance_errors = []\n ; am_advancing = false\n ; events\n ; handle_fired = (fun alarm -> handle_fired time_source (Alarm.value events alarm))\n ; fired_events = Event.none\n ; is_wall_clock = true\n ; most_recently_fired = Event.none\n ; scheduler = t\n }\n in\n t\n;;\n\nlet is_dead t = is_some t.uncaught_exn\nlet set_check_access t f = t.check_access <- f\n\nlet t_ref =\n match Result.try_with create with\n | Ok t -> ref t\n | Error exn ->\n Debug.log \"Async cannot create its raw scheduler\" exn [%sexp_of: exn];\n exit 1\n;;\n\nlet check_access t =\n match t.check_access with\n | None -> ()\n | Some f -> f ()\n;;\n\nlet t () =\n let t = !t_ref in\n check_access t;\n t\n;;\n\nlet current_execution_context t =\n if t.record_backtraces\n then Execution_context.record_backtrace t.current_execution_context\n else t.current_execution_context\n;;\n\nlet with_execution_context t tmp_context ~f =\n let old_context = current_execution_context t in\n set_execution_context t tmp_context;\n protect ~f ~finally:(fun () -> set_execution_context t old_context)\n;;\n\nlet create_job (type a) t execution_context f a =\n if Pool.is_full t.job_pool then t.job_pool <- Pool.grow t.job_pool;\n Pool.new3\n t.job_pool\n execution_context\n (Obj.magic (f : a -> unit) : Obj.t -> unit)\n (Obj.repr (a : a))\n;;\n\nlet got_uncaught_exn t exn sexp =\n if debug then Debug.log \"got_uncaught_exn\" (exn, sexp) [%sexp_of: Exn.t * Sexp.t];\n List.iter [ t.normal_priority_jobs; t.low_priority_jobs ] ~f:Job_queue.clear;\n t.uncaught_exn <- Some (exn, sexp)\n;;\n\n(* [start_cycle t ~max_num_jobs_per_priority] enables subsequent calls of [run_jobs]\n to run up to [max_num_jobs_per_priority] jobs of each priority level. *)\nlet start_cycle t ~max_num_jobs_per_priority =\n let n = Max_num_jobs_per_priority_per_cycle.raw max_num_jobs_per_priority in\n Job_queue.set_jobs_left_this_cycle t.normal_priority_jobs n;\n Job_queue.set_jobs_left_this_cycle t.low_priority_jobs n\n;;\n\n(* [run_jobs t] removes jobs from [t] one at a time and runs them, stopping as soon\n as an unhandled exception is raised, or when no more jobs can be run at any priority,\n as per [~max_num_jobs_per_priority]. *)\nlet rec run_jobs t =\n match Job_queue.run_jobs t.normal_priority_jobs t with\n | Error _ as e -> e\n | Ok () ->\n (match Job_queue.run_jobs t.low_priority_jobs t with\n | Error _ as e -> e\n | Ok () ->\n if Job_queue.can_run_a_job t.normal_priority_jobs\n || Job_queue.can_run_a_job t.low_priority_jobs\n then run_jobs t\n else Ok ())\n;;\n\nlet stabilize t =\n start_cycle\n t\n ~max_num_jobs_per_priority:\n (Max_num_jobs_per_priority_per_cycle.create_exn Int.max_value);\n match run_jobs t with\n | Ok () -> Ok ()\n | Error (exn, _backtrace) -> Error exn\n;;\n\nlet create_time_source\n ?(timing_wheel_config = Async_kernel_config.timing_wheel_config)\n ~now\n ()\n =\n let t = t () in\n let events = Timing_wheel.create ~config:timing_wheel_config ~start:now in\n let rec time_source : _ Synchronous_time_source.T1.t =\n { id = Types.Time_source_id.create ()\n ; advance_errors = []\n ; am_advancing = false\n ; events\n ; handle_fired = (fun alarm -> handle_fired time_source (Alarm.value events alarm))\n ; fired_events = Event.none\n ; is_wall_clock = false\n ; most_recently_fired = Event.none\n ; scheduler = t\n }\n in\n time_source\n;;\n\nlet wall_clock () = Synchronous_time_source.read_only (t ()).time_source\n","open! Core_kernel\nopen! Import\nopen! Deferred_std\nmodule Deferred = Deferred1\nmodule Scheduler = Scheduler1\nmodule Stream = Async_stream\ninclude (Scheduler : module type of Scheduler with module Bvar := Scheduler.Bvar)\n\nlet t = Scheduler.t\n\ninclude Monitor.Exported_for_scheduler\n\nlet find_local key = Execution_context.find_local (current_execution_context (t ())) key\n\nlet with_local key value ~f =\n let t = t () in\n let execution_context =\n Execution_context.with_local (current_execution_context t) key value\n in\n with_execution_context t execution_context ~f\n;;\n\nlet main_execution_context = (t ()).main_execution_context\nlet can_run_a_job t = num_pending_jobs t > 0 || Bvar.has_any_waiters t.yield\nlet has_upcoming_event t = not (Timing_wheel.is_empty (events t))\nlet next_upcoming_event t = Timing_wheel.next_alarm_fires_at (events t)\nlet next_upcoming_event_exn t = Timing_wheel.next_alarm_fires_at_exn (events t)\nlet event_precision t = Timing_wheel.alarm_precision (events t)\nlet cycle_start t = t.cycle_start\nlet run_every_cycle_start t ~f = t.run_every_cycle_start <- f :: t.run_every_cycle_start\nlet run_every_cycle_end t ~f = t.run_every_cycle_end <- f :: t.run_every_cycle_end\n\nlet map_cycle_times t ~f =\n Stream.create (fun tail ->\n run_every_cycle_start t ~f:(fun () -> Tail.extend tail (f t.last_cycle_time)))\n;;\n\nlet long_cycles t ~at_least =\n Stream.create (fun tail ->\n run_every_cycle_start t ~f:(fun () ->\n if Time_ns.Span.( >= ) t.last_cycle_time at_least\n then Tail.extend tail t.last_cycle_time))\n;;\n\nlet long_cycles_with_context t ~at_least =\n Stream.create (fun tail ->\n run_every_cycle_start t ~f:(fun () ->\n if Time_ns.Span.( >= ) t.last_cycle_time at_least\n then Tail.extend tail (t.last_cycle_time,t.current_execution_context)))\n;;\n\nlet long_jobs_with_context t =\n Stream.create (fun tail ->\n run_every_cycle_start t ~f:(fun () ->\n List.iter t.long_jobs_last_cycle ~f:(fun job -> Tail.extend tail job) ; t.long_jobs_last_cycle <- [] ))\n;;\n\nlet cycle_num_jobs t =\n Stream.create (fun tail ->\n run_every_cycle_start t ~f:(fun () -> Tail.extend tail t.last_cycle_num_jobs))\n;;\n\nlet cycle_count t = t.cycle_count\n\nlet set_max_num_jobs_per_priority_per_cycle t int =\n t.max_num_jobs_per_priority_per_cycle\n <- Max_num_jobs_per_priority_per_cycle.create_exn int\n;;\n\nlet max_num_jobs_per_priority_per_cycle t =\n Max_num_jobs_per_priority_per_cycle.raw t.max_num_jobs_per_priority_per_cycle\n;;\n\nlet set_thread_safe_external_job_hook t f = t.thread_safe_external_job_hook <- f\n\nlet thread_safe_enqueue_external_job t execution_context f a =\n Thread_safe_queue.enqueue t.external_jobs (External_job.T (execution_context, f, a));\n t.thread_safe_external_job_hook ()\n;;\n\nlet set_event_added_hook t f = t.event_added_hook <- Some f\nlet set_job_queued_hook t f = t.job_queued_hook <- Some f\n\nlet create_alarm t f =\n let execution_context = current_execution_context t in\n Gc.Expert.Alarm.create (fun () ->\n thread_safe_enqueue_external_job t execution_context f ())\n;;\n\nlet add_finalizer t heap_block f =\n let execution_context = current_execution_context t in\n let finalizer heap_block =\n (* Here we can be in any thread, and may not be holding the async lock. So, we can\n only do thread-safe things.\n\n By putting [heap_block] in [external_jobs], we are keeping it alive until the next\n time the async scheduler gets around to dequeueing it. Calling\n [t.thread_safe_external_job_hook] ensures that will happen in short order. Thus,\n we are not dramatically increasing the lifetime of [heap_block], since the OCaml\n runtime already resurrected [heap_block] so that we could refer to it here. The\n OCaml runtime already removed the finalizer function when it noticed [heap_block]\n could be finalized, so there is no infinite loop in which we are causing the\n finalizer to run again. Also, OCaml does not impose any requirement on finalizer\n functions that they need to dispose of the block, so it's fine that we keep\n [heap_block] around until later. *)\n if Debug.finalizers then Debug.log_string \"enqueueing finalizer\";\n thread_safe_enqueue_external_job t execution_context f heap_block\n in\n if Debug.finalizers then Debug.log_string \"adding finalizer\";\n (* We use [Caml.Gc.finalise] instead of [Core_kernel.Gc.add_finalizer] because the latter\n has its own wrapper around [Caml.Gc.finalise] to run finalizers synchronously. *)\n try Caml.Gc.finalise finalizer heap_block with\n | Invalid_argument _ ->\n (* [Heap_block] ensures that this will only fail for static data, in which case we\n can drop the finalizer since the block will never be collected.*)\n ()\n;;\n\nlet add_finalizer_exn t x f =\n add_finalizer t (Heap_block.create_exn x) (fun heap_block ->\n f (Heap_block.value heap_block))\n;;\n\nlet add_finalizer_last t heap_block f =\n let execution_context = current_execution_context t in\n let finalizer () =\n (* Here we can be in any thread, and may not be holding the async lock. So, we can\n only do thread-safe things. *)\n if Debug.finalizers\n then Debug.log_string \"enqueueing finalizer (using 'last' semantic)\";\n thread_safe_enqueue_external_job t execution_context f ()\n in\n if Debug.finalizers then Debug.log_string \"adding finalizer (using 'last' semantic)\";\n (* We use [Caml.Gc.finalise_last] instead of [Core_kernel.Gc.add_finalizer_last] because\n the latter has its own wrapper around [Caml.Gc.finalise_last] to run finalizers\n synchronously. *)\n try Caml.Gc.finalise_last finalizer heap_block with\n | Invalid_argument _ ->\n (* [Heap_block] ensures that this will only fail for static data, in which case we\n can drop the finalizer since the block will never be collected.*)\n ()\n;;\n\nlet add_finalizer_last_exn t x f = add_finalizer_last t (Heap_block.create_exn x) f\n\n(** [force_current_cycle_to_end] sets the number of normal jobs allowed to run in this\n cycle to zero. Thus, after the currently running job completes, the scheduler will\n switch to low priority jobs and then end the current cycle. *)\nlet force_current_cycle_to_end t =\n Job_queue.set_jobs_left_this_cycle t.normal_priority_jobs 0\n;;\n\n(* We preallocate [send_exn] to avoid allocating it on each call to [advance_clock]. *)\nlet send_exn = Some Monitor.send_exn\n\nlet advance_clock t ~now =\n Synchronous_time_source0.advance_internal t.time_source ~to_:now ~send_exn\n;;\n\nlet run_cycle t =\n if debug then Debug.log \"run_cycle starting\" t [%sexp_of: t];\n t.on_start_of_cycle ();\n let now = Time_ns.now () in\n t.cycle_count <- t.cycle_count + 1;\n t.cycle_start <- now;\n t.in_cycle <- true;\n Bvar.broadcast t.yield ();\n let num_jobs_run_at_start_of_cycle = num_jobs_run t in\n List.iter t.run_every_cycle_start ~f:(fun f -> f ());\n advance_clock t ~now;\n start_cycle t ~max_num_jobs_per_priority:t.max_num_jobs_per_priority_per_cycle;\n let rec run_jobs t =\n match Scheduler.run_jobs t with\n | Ok () -> ()\n | Error (exn, backtrace) ->\n Monitor.send_exn (Monitor.current ()) exn ~backtrace:(`This backtrace);\n (* [run_jobs] stopped due to an exn. There may still be jobs that could be\n run this cycle, so [run_jobs] again. *)\n run_jobs t\n in\n run_jobs t;\n let cycle_time = Time_ns.diff (Time_ns.now ()) t.cycle_start in\n t.last_cycle_time <- cycle_time;\n t.last_cycle_num_jobs <- num_jobs_run t - num_jobs_run_at_start_of_cycle;\n t.total_cycle_time <- Time_ns.Span.(t.total_cycle_time + cycle_time);\n if Bvar.has_any_waiters t.yield_until_no_jobs_remain && num_pending_jobs t = 0\n then Bvar.broadcast t.yield_until_no_jobs_remain ();\n List.iter t.run_every_cycle_end ~f:(fun f -> f ());\n t.in_cycle <- false;\n t.on_end_of_cycle ();\n if debug\n then\n Debug.log\n \"run_cycle finished\"\n (uncaught_exn t, is_some (next_upcoming_event t))\n [%sexp_of: Error.t option * bool]\n;;\n\nlet run_cycles_until_no_jobs_remain () =\n if debug then Debug.log_string \"run_cycles_until_no_jobs_remain starting\";\n let t = t () in\n if is_dead t\n then\n raise_s\n [%message\n \"run_cycles_until_no_jobs_remain cannot proceed -- scheduler is dead\"\n ~scheduler:(t : t)];\n let rec loop () =\n run_cycle t;\n advance_clock t ~now:(Time_ns.now ());\n if can_run_a_job t then loop ()\n in\n loop ();\n (* Reset the current execution context to maintain the invariant that when we're not in\n a job, [current_execution_context = main_execution_context]. *)\n set_execution_context t t.main_execution_context;\n if debug then Debug.log_string \"run_cycles_until_no_jobs_remain finished\";\n Option.iter (uncaught_exn t) ~f:Error.raise\n;;\n\nlet make_async_unusable () =\n let t = !t_ref in\n t.check_access\n <- Some\n (fun () ->\n raise_s [%sexp \"Async scheduler is unusable due to [make_async_unusable]\"])\n;;\n\nlet reset_in_forked_process () =\n if debug then Debug.log_string \"reset_in_forked_process\";\n (* There is no need to empty [main_monitor_hole]. *)\n Scheduler.(t_ref := create ())\n;;\n\nlet check_invariants t = t.check_invariants\nlet set_check_invariants t b = t.check_invariants <- b\nlet set_record_backtraces t b = t.record_backtraces <- b\nlet set_on_start_of_cycle t f = t.on_start_of_cycle <- f\nlet set_on_end_of_cycle t f = t.on_end_of_cycle <- f\nlet yield t = Bvar.wait t.yield\n\nlet yield_until_no_jobs_remain ?(may_return_immediately = false) t =\n if may_return_immediately && num_pending_jobs t = 0\n then return ()\n else Bvar.wait t.yield_until_no_jobs_remain\n;;\n\nlet yield_every ~n =\n if n <= 0\n then raise_s [%message \"Scheduler.yield_every got nonpositive count\" (n : int)]\n else if n = 1\n then stage (fun t -> yield t)\n else (\n let count_until_yield = ref n in\n stage (fun t ->\n decr count_until_yield;\n if !count_until_yield > 0\n then return ()\n else (\n count_until_yield := n;\n yield t)))\n;;\n\nlet total_cycle_time t =\n (* Adjust for the fact the caller's probably an Async job. *)\n if t.in_cycle\n then (\n let this_cycle_time = Time_ns.(diff (now ()) t.cycle_start) in\n Time_ns.Span.(t.total_cycle_time + this_cycle_time))\n else t.total_cycle_time\n;;\n\nmodule Very_low_priority_work = struct\n module Worker_result = Very_low_priority_worker.Exec_result\n\n\n let rec run t = run_workers t ~num_execs_before_yielding:1_000\n\n and run_workers t ~num_execs_before_yielding =\n if num_execs_before_yielding = 0\n then yield_then_run t\n else if not (Deque.is_empty t.very_low_priority_workers)\n then (\n let worker = Deque.dequeue_front_exn t.very_low_priority_workers in\n set_execution_context t worker.execution_context;\n run_worker t worker ~num_execs_before_yielding)\n\n and yield_then_run t =\n if not (Deque.is_empty t.very_low_priority_workers)\n then Deferred.upon (yield t) (fun () -> run t)\n\n and run_worker t worker ~num_execs_before_yielding =\n assert (phys_equal t.current_execution_context worker.execution_context);\n if num_execs_before_yielding = 0\n then (\n Deque.enqueue_front t.very_low_priority_workers worker;\n yield_then_run t)\n else (\n let num_execs_before_yielding = num_execs_before_yielding - 1 in\n match worker.exec () with\n | Finished -> run_workers t ~num_execs_before_yielding\n | Not_finished -> run_worker t worker ~num_execs_before_yielding\n | exception exn ->\n let bt = Backtrace.Exn.most_recent () in\n Monitor.send_exn (Monitor.current ()) exn ~backtrace:(`This bt);\n run_workers t ~num_execs_before_yielding)\n ;;\n\n let enqueue ~f =\n let t = t () in\n let queue = t.very_low_priority_workers in\n let running = not (Deque.is_empty queue) in\n let execution_context =\n Execution_context.create_like (current_execution_context t) ~priority:Low\n in\n Deque.enqueue_back queue { execution_context; exec = f };\n if not running then enqueue t execution_context run t\n ;;\nend\n\nmodule For_bench = struct\n let advance_clock = advance_clock\nend\n","open! Core_kernel\nopen! Import\nmodule Scheduler = Scheduler1\nmodule Cell = Types.Cell\n\ntype any =\n [ `Empty\n | `Empty_one_handler\n | `Empty_one_or_more_handlers\n | `Full\n | `Indir\n ]\n\ntype 'a t = 'a Types.Ivar.t = { mutable cell : ('a, any) cell }\n\n(* The ['b] is used to encode the constructor. This allows us to write functions that\n take only one of the constructors, with no runtime test.\n\n We maintain the invariant that the directed graph with ivars as nodes and [Indir]s as\n edges is acyclic. The only functions that create an [Indir] are [squash] and\n [connect], and for those, the target of the [Indir] is always a non-[Indir]. Thus, the\n newly added edges are never part of a cycle. *)\nand ('a, 'b) cell = ('a, 'b) Types.Cell.t =\n | Empty_one_or_more_handlers :\n { (* [run] is mutable so we can set it to [ignore] when the handler is removed.\n This is used when we install a handler on a full ivar since it is immediately\n added to the scheduler. *)\n mutable run : 'a -> unit\n ; execution_context : Execution_context.t\n ; (* [prev] and [next] circularly doubly link all handlers of the same ivar. *)\n mutable prev : ('a, [ `Empty_one_or_more_handlers ]) cell\n ; mutable next : ('a, [ `Empty_one_or_more_handlers ]) cell\n }\n -> ('a, [> `Empty_one_or_more_handlers ]) cell\n | Empty_one_handler :\n ('a -> unit) * Execution_context.t\n -> ('a, [> `Empty_one_handler ]) cell\n | Empty : ('a, [> `Empty ]) cell\n | Full : 'a -> ('a, [> `Full ]) cell\n | Indir : 'a t -> ('a, [> `Indir ]) cell\n\nmodule Handler = struct\n type 'a t = ('a, [ `Empty_one_or_more_handlers ]) cell\n\n let run (Empty_one_or_more_handlers t : _ t) = t.run\n let execution_context (Empty_one_or_more_handlers t : _ t) = t.execution_context\n let prev (Empty_one_or_more_handlers t : _ t) = t.prev\n let next (Empty_one_or_more_handlers t : _ t) = t.next\n let set_run (Empty_one_or_more_handlers t : _ t) x = t.run <- x\n let set_prev (Empty_one_or_more_handlers t : _ t) x = t.prev <- x\n let set_next (Empty_one_or_more_handlers t : _ t) x = t.next <- x\n\n let create run execution_context =\n (* An optimized implementation of:\n\n {[\n let rec t =\n Empty_one_or_more_handlers\n { run\n ; execution_context\n ; prev = t\n ; next = t }\n in\n h1 ]}\n\n However the compilation of recursive value in OCaml is not optimal: the value is\n allocated twice and copied once (with a loop calling caml_modify). This is not\n necessary for simple recursive definitions like this one.\n\n Instead we allocate the value with dummy fields and update them after. *)\n let t =\n Empty_one_or_more_handlers\n { run; execution_context; prev = Obj.magic None; next = Obj.magic None }\n in\n set_prev t t;\n set_next t t;\n t\n ;;\n\n let create2 run1 execution_context1 run2 execution_context2 =\n (* An optimized implementation of:\n\n {[\n let rec t1 =\n { run = run1\n ; execution_context = execution_context1\n ; prev = t2\n ; next = t2 }\n and t2 =\n { run = run2\n ; execution_context = execution_context2\n ; prev = t1\n ; next = t1 }\n in\n t1 ]} *)\n let t1 =\n Empty_one_or_more_handlers\n { run = run1\n ; execution_context = execution_context1\n ; prev = Obj.magic None\n ; next = Obj.magic None\n }\n in\n let t2 =\n Empty_one_or_more_handlers\n { run = run2; execution_context = execution_context2; prev = t1; next = t1 }\n in\n set_prev t1 t2;\n set_next t1 t2;\n t1\n ;;\n\n let invariant t =\n Execution_context.invariant (execution_context t);\n let r = ref (next t) in\n while not (phys_equal !r t) do\n let t1 = !r in\n assert (phys_equal (prev (next t1)) t1);\n Execution_context.invariant (execution_context t1);\n r := next !r\n done\n ;;\n\n let is_singleton t = phys_equal t (next t)\n\n let length t =\n let n = ref 1 in\n let r = ref (next t) in\n while not (phys_equal !r t) do\n incr n;\n r := next !r\n done;\n !n\n ;;\n\n let enqueue t scheduler v = Scheduler.enqueue scheduler (execution_context t) (run t) v\n\n let schedule_jobs t v =\n let scheduler = Scheduler.t () in\n enqueue t scheduler v;\n let r = ref (next t) in\n while not (phys_equal !r t) do\n enqueue !r scheduler v;\n r := next !r\n done\n ;;\n\n let unlink t =\n set_prev (next t) (prev t);\n set_next (prev t) (next t);\n set_prev t t;\n set_next t t\n ;;\n\n let add t run execution_context =\n let result =\n Empty_one_or_more_handlers { run; execution_context; prev = prev t; next = t }\n in\n set_next (prev t) result;\n set_prev t result;\n result\n ;;\n\n (* [splice t1 t2] creates:\n\n {v\n --> t1 <--> ... <--> last1 <--> t2 <--> ... <--> last2 <--\n | |\n ----------------------------------------------------------\n v} *)\n let splice t1 t2 =\n let last1 = prev t1 in\n let last2 = prev t2 in\n set_next last1 t2;\n set_next last2 t1;\n set_prev t1 last2;\n set_prev t2 last1\n ;;\n\n let of_list l =\n match l with\n | [] -> None\n | (run, execution_context) :: l ->\n let first = create run execution_context in\n let rec loop prev l =\n match l with\n | [] -> set_prev first prev\n | (run, execution_context) :: l ->\n let t =\n Empty_one_or_more_handlers { run; execution_context; prev; next = first }\n in\n set_next prev t;\n loop t l\n in\n loop first l;\n Some first\n ;;\n\n let to_list first =\n let rec loop t acc =\n let acc = (run t, execution_context t) :: acc in\n if phys_equal t first then acc else loop (prev t) acc\n in\n loop (prev first) []\n ;;\n\n let sexp_of_t _ (t : _ t) =\n let (Empty_one_or_more_handlers { run = _; execution_context; next = _; prev = _ }) =\n t\n in\n [%message (execution_context : Execution_context.t)]\n ;;\nend\n\ntype 'a ivar = 'a t\n\n(* Compiled as the identity. *)\nlet cell_of_handler : _ Handler.t -> _ = function\n | Empty_one_or_more_handlers _ as x -> (x :> (_, any) cell)\n;;\n\nlet equal (t : _ t) t' = phys_equal t t'\nlet indir t = { cell = Indir t }\n\ninclude Scheduler.Ivar\n\n(* [squash t] returns the non-[Indir] ivar at the end of the (possibly empty) chain of\n [Indir]s starting with [t] and ensures that all [Indir]s along that chain are replaced\n with an [Indir] pointing to the end of the chain. *)\nlet squash =\n let rec follow indir t =\n (* [indir = Indir t] *)\n match t.cell with\n | Indir t' as indir' -> follow indir' t'\n | _ -> indir\n in\n let rec update t indir =\n match t.cell with\n | Indir t' ->\n t.cell <- indir;\n update t' indir\n | _ -> t\n in\n fun t ->\n match t.cell with\n | Indir t' ->\n (match t'.cell with\n | Indir t'' as indir -> update t (follow indir t'')\n | _ -> t' (* nothing to do, since [t] is a chain with a single [Indir] *))\n | _ -> t\n;;\n\n(* nothing to do, since [t] isn't an [Indir]. *)\n\nlet invariant a_invariant t =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full a -> a_invariant a\n | Empty -> ()\n | Empty_one_handler (_, execution_context) ->\n Execution_context.invariant execution_context\n | Empty_one_or_more_handlers _ as handler -> Handler.invariant handler\n;;\n\nlet sexp_of_t sexp_of_a t : Sexp.t =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full a -> List [ Atom \"Full\"; sexp_of_a a ]\n | Empty | Empty_one_handler _ | Empty_one_or_more_handlers _ -> Atom \"Empty\"\n;;\n\nlet peek t =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full a -> Some a\n | Empty | Empty_one_handler _ | Empty_one_or_more_handlers _ -> None\n;;\n\nlet value t ~if_empty_then_failwith =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full a -> a\n | Empty | Empty_one_handler _ | Empty_one_or_more_handlers _ ->\n failwith if_empty_then_failwith\n;;\n\nlet value_exn t = value t ~if_empty_then_failwith:\"Ivar.value_exn called on empty ivar\"\n\nlet is_empty t =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full _ -> false\n | Empty | Empty_one_handler _ | Empty_one_or_more_handlers _ -> true\n;;\n\nlet is_full t = not (is_empty t)\n\nlet fill t v =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full _ -> raise_s [%message \"Ivar.fill of full ivar\" (t : _ t)]\n | Empty -> t.cell <- Full v\n | Empty_one_handler (run, execution_context) ->\n t.cell <- Full v;\n Scheduler.(enqueue (t ())) execution_context run v\n | Empty_one_or_more_handlers _ as handler ->\n t.cell <- Full v;\n Handler.schedule_jobs handler v\n;;\n\nlet remove_handler t (handler : _ Handler.t) =\n Handler.set_run handler ignore;\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Empty | Empty_one_handler _ ->\n (* These are only possible if [handler] was already removed. *)\n ()\n | Full _ ->\n (* This is possible if [t] was filled before we try to remove the handler. E.g.\n [Deferred.choose] will do this. *)\n ()\n | Empty_one_or_more_handlers _ as cell ->\n if Handler.is_singleton handler\n then t.cell <- Empty\n else (\n if phys_equal handler cell then t.cell <- cell_of_handler (Handler.next handler);\n Handler.unlink handler)\n;;\n\nlet add_handler t run execution_context =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Empty ->\n let handler = Handler.create run execution_context in\n t.cell <- cell_of_handler handler;\n handler\n | Empty_one_handler (run', execution_context') ->\n let handler = Handler.create2 run execution_context run' execution_context' in\n t.cell <- cell_of_handler handler;\n handler\n | Empty_one_or_more_handlers _ as handler -> Handler.add handler run execution_context\n | Full v ->\n let handler = Handler.create run execution_context in\n (* [run] calls [handler.run], which, if [handler] has been removed, has been changed\n to [ignore]. *)\n let run v = Handler.run handler v in\n Scheduler.(enqueue (t ())) execution_context run v;\n handler\n;;\n\nlet has_handlers t =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Empty_one_handler _ | Empty_one_or_more_handlers _ -> true\n | Empty | Full _ -> false\n;;\n\nlet upon' t run = add_handler t run Scheduler.(current_execution_context (t ()))\n\n(* [upon] is conceptually the same as:\n\n {[\n let upon t f = ignore (upon' t run) ]}\n\n However, below is a more efficient implementation, which is worth doing because [upon]\n is very widely used and is so much more common than [upon']. The below implementation\n avoids the use of the bag of handlers in the extremely common case of one handler for\n the deferred. *)\nlet upon t run =\n let scheduler = Scheduler.t () in\n let execution_context = Scheduler.current_execution_context scheduler in\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full v -> Scheduler.enqueue scheduler execution_context run v\n | Empty -> t.cell <- Empty_one_handler (run, execution_context)\n | Empty_one_handler (run', execution_context') ->\n t.cell\n <- cell_of_handler (Handler.create2 run execution_context run' execution_context')\n | Empty_one_or_more_handlers _ as handler ->\n ignore (Handler.add handler run execution_context : _ Handler.t)\n;;\n\n(* [connect] takes ivars [bind_result] and [bind_rhs], and makes [bind_rhs]\n be an [Indir] pointing to the non-indir cell reachable from [bind_result]. On entry\n to [connect], [bind_result] and [bind_rhs] may be chains, since [bind_rhs] is an\n arbitrary user-supplied deferred, and [bind_result] is returned to the user prior to\n being [connect]ed, and may have been converted to an indirection in the case of\n right-nested binds.\n\n The purpose of [connect] is to make tail-recursive bind loops use constant space.\n E.g.:\n\n {[\n let rec loop i =\n if i = 0\n then return ()\n else (\n let%bind () = after (sec 1.) in\n loop (i - 1)) ]}\n\n [connect] makes intermediate bind results all be [Indir]s pointing at the outermost\n bind, rather than being a linear-length chain, with each pointing to the previous one.\n Then, since the program is only holding on to the innermost and outermost binds all the\n intermediate ones can be garbage collected.\n\n [connect] works by squashing its arguments so that the [bind_rhs] always points at the\n ultimate result. *)\nlet connect =\n (* [repoint_indirs ~ivar ~indir ~bind_result] repoints to [indir] all the ivars in the\n chain reachable from [ivar], and returns the non-[Indir] cell at the end of the\n chain. After repointing, we will merge the handlers in that cell with the handlers\n in [bind_result], and put the merged set of handlers in [bind_result]. *)\n let rec repoint_indirs ~ivar ~indir ~bind_result =\n let cell = ivar.cell in\n match cell with\n | Indir ivar' ->\n ivar.cell <- indir;\n repoint_indirs ~ivar:ivar' ~indir ~bind_result\n | Full _ -> cell\n | Empty | Empty_one_handler _ | Empty_one_or_more_handlers _ ->\n (* It is possible that [bind_result] and [bind_rhs] are not equal, but their chains\n of indirs lead to the same non-[Indir] cell, in which case we cannot set that\n cell to point to itself, because that would introduce a cycle. *)\n if not (phys_equal ivar bind_result) then ivar.cell <- indir;\n cell\n in\n fun ~bind_result ~bind_rhs ->\n if not (phys_equal bind_result bind_rhs)\n then (\n let bind_result = squash bind_result in\n let indir = Indir bind_result in\n let bind_rhs_contents = repoint_indirs ~ivar:bind_rhs ~indir ~bind_result in\n (* update [bind_result] with the union of handlers in [bind_result] and\n [bind_rhs] *)\n match bind_result.cell, bind_rhs_contents with\n | Indir _, _ | _, Indir _ -> assert false\n (* fulfilled by [squash] and [repoint_indirs] *)\n (* [connect] is only used in bind, whose ivar is only ever exported as a read-only\n deferred. Thus, [bind_result] must be empty. *)\n | Full _, _ -> assert false\n | _, Empty -> ()\n | Empty, _ -> bind_result.cell <- bind_rhs_contents\n | Empty_one_handler (run, execution_context), Full v ->\n bind_result.cell <- bind_rhs_contents;\n Scheduler.(enqueue (t ())) execution_context run v\n | (Empty_one_or_more_handlers _ as handler), Full v ->\n bind_result.cell <- bind_rhs_contents;\n Handler.schedule_jobs handler v\n | ( Empty_one_handler (run1, execution_context1)\n , Empty_one_handler (run2, execution_context2) ) ->\n let handler1 = Handler.create2 run1 execution_context1 run2 execution_context2 in\n bind_result.cell <- cell_of_handler handler1\n | ( (Empty_one_or_more_handlers _ as handler1)\n , Empty_one_handler (run2, execution_context2) ) ->\n ignore (Handler.add handler1 run2 execution_context2 : _ Handler.t)\n | ( Empty_one_handler (run1, execution_context1)\n , (Empty_one_or_more_handlers _ as handler2) ) ->\n let handler1 = Handler.add handler2 run1 execution_context1 in\n bind_result.cell <- cell_of_handler handler1\n | ( (Empty_one_or_more_handlers _ as handler1)\n , (Empty_one_or_more_handlers _ as handler2) ) ->\n Handler.splice handler1 handler2)\n;;\n","open! Core_kernel\nopen! Import\nmodule Ivar = Ivar0\nmodule Handler = Ivar.Handler\n\n(* Deferreds present a covariant view of ivars. We could actually implement deferreds\n using a record of closures, as in the [essence_of_deferred] record below, for which the\n OCaml type checker can infer covariance. However, doing so would make [Ivar.read] very\n costly, because it would have to allocate lots of closures and a record. Instead of\n doing this, we make deferreds an abstract covariant type, which concretely is just the\n ivar, and use [Obj.magic] to convert back and forth between a deferred and its concrete\n representation as an ivar. This [Obj.magic] is safe because the representation is\n always just an ivar, and the covariance follows from the fact that all the deferred\n operations are equivalent to those implemented directly on top of the\n [essence_of_deferred].\n\n {[\n type (+'a, 'execution_context) essence_of_deferred =\n { peek : unit -> 'a option\n ; is_determined : unit -> bool\n ; upon : ('a -> unit) -> unit\n ; upon' : ('a -> unit) -> Unregister.t\n ; install_removable_handler : ('a, 'execution_context) Raw_handler.t -> Unregister.t; } ]} *)\n\ntype +'a t = 'a Types.Deferred.t\n\n(* the abstract covariant type, equivalent to ivar *)\n\nlet of_ivar (type a) (ivar : a Ivar.t) : a t = Obj.magic ivar\nlet to_ivar (type a) t : a Ivar.t = Obj.magic (t : a t)\nlet invariant invariant_a t = Ivar.invariant invariant_a (to_ivar t)\nlet sexp_of_t sexp_of_a t = Ivar.sexp_of_t sexp_of_a (to_ivar t)\nlet peek t = Ivar.peek (to_ivar t)\nlet return a = of_ivar (Ivar.create_full a)\nlet is_determined t = Ivar.is_full (to_ivar t)\n\nlet value_exn t =\n Ivar.value\n (to_ivar t)\n ~if_empty_then_failwith:\"Deferred.value_exn called on undetermined deferred\"\n;;\n\nlet upon t f = Ivar.upon (to_ivar t) f\n\nlet create f =\n let result = Ivar.create () in\n f result;\n of_ivar result\n;;\n\n(* don't use [create] here as it would allocate one more closure *)\nlet bind t ~f =\n let bind_result = Ivar.create () in\n upon t (fun a -> Ivar.connect ~bind_result ~bind_rhs:(to_ivar (f a)));\n of_ivar bind_result\n;;\n\nlet add_handler t f execution_context = Ivar.add_handler (to_ivar t) f execution_context\nlet remove_handler t h = Ivar.remove_handler (to_ivar t) h\n","open Core_kernel\nmodule Deferred = Deferred0\ninclude Ivar0\n\nlet read = Deferred.of_ivar\nlet fill_if_empty t v = if is_empty t then fill t v\n\ninclude Binable.Of_binable1 [@alert \"-legacy\"]\n (Option)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable t = peek t\n\n let of_binable = function\n | None -> create ()\n | Some a -> create_full a\n ;;\n end)\n","(** [Monad_sequence.S] is a generic interface specifying functions that deal with a\n container and a monad. It is specialized to the [Deferred] monad and used with\n various containers in modules [Deferred.Array], [Deferred.List], [Deferred.Queue], and\n [Deferred.Sequence]. The [Monad_sequence.how] type specifies the parallelism of\n container iterators. *)\n\nopen! Core_kernel\nopen! Import\n\ntype how =\n [ `Parallel (** like [`Max_concurrent_jobs Int.max_value] *)\n | `Sequential\n (** [`Sequential] is often but not always the same as [`Max_concurrent_jobs 1]\n (for example, they differ in the [Or_error] monad). *)\n | `Max_concurrent_jobs of int\n ]\n[@@deriving sexp_of]\n\nmodule type S = sig\n type 'a monad\n type 'a t\n\n val foldi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b monad) -> 'b monad\n val fold : 'a t -> init:'b -> f:('b -> 'a -> 'b monad) -> 'b monad\n val find : 'a t -> f:('a -> bool monad) -> 'a option monad\n val findi : 'a t -> f:(int -> 'a -> bool monad) -> (int * 'a) option monad\n val find_map : 'a t -> f:('a -> 'b option monad) -> 'b option monad\n val find_mapi : 'a t -> f:(int -> 'a -> 'b option monad) -> 'b option monad\n val exists : 'a t -> f:('a -> bool monad) -> bool monad\n val existsi : 'a t -> f:(int -> 'a -> bool monad) -> bool monad\n val for_all : 'a t -> f:('a -> bool monad) -> bool monad\n val for_alli : 'a t -> f:(int -> 'a -> bool monad) -> bool monad\n val all : 'a monad t -> 'a t monad\n val all_unit : unit monad t -> unit monad\n\n (** {2 Deferred iterators}\n\n In the following, the default [how] is [`Sequential] *)\n\n val init : ?how:how -> int -> f:(int -> 'a monad) -> 'a t monad\n val iter : ?how:how -> 'a t -> f:('a -> unit monad) -> unit monad\n val iteri : ?how:how -> 'a t -> f:(int -> 'a -> unit monad) -> unit monad\n val map : ?how:how -> 'a t -> f:('a -> 'b monad) -> 'b t monad\n val mapi : ?how:how -> 'a t -> f:(int -> 'a -> 'b monad) -> 'b t monad\n val filter : ?how:how -> 'a t -> f:('a -> bool monad) -> 'a t monad\n val filteri : ?how:how -> 'a t -> f:(int -> 'a -> bool monad) -> 'a t monad\n val filter_map : ?how:how -> 'a t -> f:('a -> 'b option monad) -> 'b t monad\n val filter_mapi : ?how:how -> 'a t -> f:(int -> 'a -> 'b option monad) -> 'b t monad\n val concat_map : ?how:how -> 'a t -> f:('a -> 'b t monad) -> 'b t monad\n val concat_mapi : ?how:how -> 'a t -> f:(int -> 'a -> 'b t monad) -> 'b t monad\nend\n","open Core_kernel\nmodule Scheduler = Scheduler1\ninclude Deferred0\n\n(* To avoid a space leak, it is necessary that [never] allocates a new ivar whenever it is\n called. Code can bind on [never ()], so if we re-used the ivar, we could endlessly\n accumulate handlers. *)\nlet never () = Ivar.read (Ivar.create ())\n\nmodule M = Monad.Make (struct\n include Deferred0\n\n let map t ~f =\n (* We manually inline [Deferred.create] here, because the non-flambda compiler isn't\n able to optimize away the closure that would be be created. *)\n let result = Ivar.create () in\n upon t (fun a -> Ivar.fill result (f a));\n of_ivar result\n ;;\n\n let map = `Custom map\n end)\n\ninclude M\n\n(* We rebind all the various [return]s because the use of the [Monad.Make] functor\n causes the compiler to not inline [return], and hence makes it impossible to\n statically allocate constants like [return ()]. By rebinding [return] as\n [Deferred0.return], the compiler can see that:\n\n {[\n return a = { Ivar.Immutable. cell = Full a } ]}\n\n And hence, if [a] is constant, then the return is constant and can be statically\n allocated. When compiling with flambda, the compiler inlines [return] and this manual\n rebinding would not help; we've decided to do it anyway so that non-flambda builds\n get the optimization. *)\nlet return = Deferred0.return\n\nmodule Let_syntax = struct\n include M.Let_syntax\n\n let return = Deferred0.return\n\n module Let_syntax = struct\n include M.Let_syntax.Let_syntax\n\n let return = Deferred0.return\n end\nend\n\nopen Let_syntax\n\n(* We shadow [all] on-purpose here, since the default definition introduces a chain of\n binds as long as the list. *)\nlet all = `Make_sure_to_define_all_elsewhere\nlet _ = all\nlet unit = return ()\n\nlet both t1 t2 =\n create (fun result ->\n upon t1 (fun a1 -> upon t2 (fun a2 -> Ivar.fill result (a1, a2))))\n;;\n\nmodule Infix = struct\n include Monad_infix\n\n let ( >>> ) = upon\n let ppx_both = both\nend\n\nopen Infix\n\nlet don't_wait_for (_ : unit t) = ()\n\nmodule Choice = struct\n type +'a t = T : 'b Deferred0.t * ('b -> 'a) -> 'a t\n\n let map (T (t, f1)) ~f:f2 = T (t, fun x -> f2 (f1 x))\nend\n\ntype 'a choice = 'a Choice.t\n\nmodule Unregister = struct\n (* This representation saves 2n words for a list of n choices. *)\n type t =\n | Nil : t\n | Cons : 'a Deferred0.t * 'a Deferred0.Handler.t * t -> t\n\n let rec process = function\n | Nil -> ()\n | Cons (t, handler, rest) ->\n remove_handler t handler;\n process rest\n ;;\nend\n\nlet choice t f = Choice.T (t, f)\n\nlet enabled choices =\n let result = Ivar.create () in\n let unregisters = ref Unregister.Nil in\n let ready _ =\n if Ivar.is_empty result\n then (\n Unregister.process !unregisters;\n Ivar.fill result (fun () ->\n List.rev\n (List.fold choices ~init:[] ~f:(fun ac (Choice.T (t, f)) ->\n match peek t with\n | None -> ac\n | Some v -> f v :: ac))))\n in\n let execution_context = Scheduler.(current_execution_context (t ())) in\n unregisters\n := List.fold choices ~init:Unregister.Nil ~f:(fun acc (Choice.T (t, _)) ->\n Cons (t, Deferred0.add_handler t ready execution_context, acc));\n Ivar.read result\n;;\n\nlet rec choose_result choices =\n match choices with\n | [] -> assert false\n | Choice.T (t, f) :: choices ->\n (match peek t with\n | None -> choose_result choices\n | Some v -> f v)\n;;\n\nlet choose choices =\n let result = Ivar.create () in\n let unregisters = ref Unregister.Nil in\n let ready _ =\n if Ivar.is_empty result\n then (\n Unregister.process !unregisters;\n Ivar.fill result (choose_result choices))\n in\n let execution_context = Scheduler.(current_execution_context (t ())) in\n unregisters\n := List.fold choices ~init:Unregister.Nil ~f:(fun acc (Choice.T (t, _)) ->\n Cons (t, Deferred0.add_handler t ready execution_context, acc));\n Ivar.read result\n;;\n\nlet any_f ts f = choose (List.map ts ~f:(fun t -> choice t f))\nlet any ts = any_f ts Fn.id\nlet any_unit ts = any_f ts (Fn.ignore : unit -> unit)\n\nlet for_ start ~to_ ~do_ =\n let rec loop i =\n if i > to_\n then return ()\n else (\n let%bind () = do_ i in\n loop (i + 1))\n in\n loop start\n;;\n\nlet repeat_until_finished state f =\n create (fun finished ->\n let rec loop state =\n f state\n >>> function\n | `Repeat state -> loop state\n | `Finished result -> Ivar.fill finished result\n in\n loop state)\n;;\n\nlet forever state f =\n repeat_until_finished state (fun state ->\n let%map state = f state in\n `Repeat state)\n >>> never_returns\n;;\n\ntype how = Monad_sequence.how [@@deriving sexp_of]\n\nmodule type Monad_sequence = Monad_sequence.S with type 'a monad := 'a t\n\n\nlet fold t ~init ~f =\n create (fun result ->\n let rec loop t b =\n match t with\n | [] -> Ivar.fill result b\n | x :: xs -> f b x >>> fun b -> loop xs b\n in\n loop t init)\n;;\n\nlet seqmap t ~f = fold t ~init:[] ~f:(fun bs a -> f a >>| fun b -> b :: bs) >>| List.rev\nlet all ds = seqmap ds ~f:Fn.id\nlet all_unit ds = fold ds ~init:() ~f:(fun () d -> d)\nlet ok x = x >>| fun x -> Ok x\n","open Deferred1\ninclude Infix\ninclude Let_syntax\n\nlet choice = choice\nlet choose = choose\nlet don't_wait_for = don't_wait_for\nlet never = never\nlet return = return\nlet upon = upon\n","open! Core_kernel\nopen! Import\n\ntype 'a u =\n | Empty of 'a Ivar.t\n | Full\n[@@deriving sexp_of]\n\ntype 'a t = 'a u ref [@@deriving sexp_of]\n\nlet invariant _ t =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n match !t with\n | Full -> ()\n | Empty ivar -> assert (Ivar.is_empty ivar))\n;;\n\nlet create () =\n let ivar = Ivar.create () in\n let t = ref (Empty ivar) in\n t, Ivar.read ivar\n;;\n\nlet is_empty t =\n match !t with\n | Empty _ -> true\n | Full -> false\n;;\n\nlet fill t a =\n match !t with\n | Empty i ->\n t := Full;\n Ivar.fill i a\n | Full -> raise_s [%message \"attempt to fill full ivar\"]\n;;\n","open! Core_kernel\nopen! Import\nmodule Deferred = Deferred1\n\nmodule Stream = struct\n type 'a t = 'a next Deferred.t\n\n and 'a next = 'a Types.Stream.next =\n | Nil\n | Cons of 'a * 'a t\n\n let sexp_of_t sexp_of_a t =\n let rec loop d ac : Sexp.t =\n match Deferred.peek d with\n | None -> List (List.rev (Sexp.Atom \"...\" :: ac))\n | Some Nil -> List (List.rev ac)\n | Some (Cons (a, t)) -> loop t (sexp_of_a a :: ac)\n in\n loop t []\n ;;\n\n let next t = t\nend\n\ntype 'a t = 'a Types.Tail.t =\n { (* [next] points at the tail of the stream *) mutable next : 'a Stream.next Ivar.t }\n[@@deriving fields]\n\nlet sexp_of_t _ t : Sexp.t =\n Atom (if Ivar.is_empty t.next then \"\" else \"\")\n;;\n\nlet create () = { next = Ivar.create () }\nlet collect t = Ivar.read (next t)\nlet is_closed t = Ivar.is_full (next t)\n\nlet fill_exn t v =\n if is_closed t then raise_s [%message \"stream is closed\"] else Ivar.fill (next t) v\n;;\n\nlet close_exn t = fill_exn t Nil\nlet close_if_open t = if not (is_closed t) then Ivar.fill (next t) Nil\n\nlet extend t v =\n let next = Ivar.create () in\n fill_exn t (Cons (v, Ivar.read next));\n t.next <- next\n;;\n","open Core_kernel\nopen Deferred_std\nmodule Deferred = Deferred1\ninclude Tail.Stream\n\nlet first_exn t =\n match%map next t with\n | Nil -> raise_s [%message \"Stream.first of empty stream\"]\n | Cons (x, _) -> x\n;;\n\nlet fold' t ~init ~f =\n Deferred.create (fun result ->\n let rec loop t b =\n upon (next t) (function\n | Nil -> Ivar.fill result b\n | Cons (v, t) -> upon (f b v) (loop t))\n in\n loop t init)\n;;\n\n(* [fold] is implemented to avoid per-stream-element deferred overhead in the case when\n multiple stream elements are available simultaneously. *)\nlet fold t ~init ~f =\n Deferred.create (fun result ->\n let rec loop t b =\n match Deferred.peek (next t) with\n | None -> upon (next t) (fun next -> loop_next next b)\n | Some next -> loop_next next b\n and loop_next next b =\n match next with\n | Nil -> Ivar.fill result b\n | Cons (v, t) -> loop t (f b v)\n in\n loop t init)\n;;\n\nlet length t = fold t ~init:0 ~f:(fun n _ -> n + 1)\nlet iter' t ~f = fold' t ~init:() ~f:(fun () v -> f v)\n\nlet closed t =\n match Deferred.peek (next t) with\n | Some Nil -> return ()\n | _ -> iter' t ~f:(fun _ -> return ())\n;;\n\nlet iter t ~f =\n don't_wait_for\n (iter' t ~f:(fun a ->\n f a;\n return ()))\n;;\n\nlet create f =\n let tail = Tail.create () in\n (* collect before calling [f], in case [f] immediately extends. *)\n let t = Tail.collect tail in\n f tail;\n t\n;;\n\nlet unfold b ~f =\n create (fun tail ->\n let rec loop b =\n upon (f b) (function\n | None -> Tail.close_exn tail\n | Some (a, b) ->\n Tail.extend tail a;\n loop b)\n in\n loop b)\n;;\n\nlet of_list l =\n create (fun tail ->\n List.iter l ~f:(fun x -> Tail.extend tail x);\n Tail.close_exn tail)\n;;\n\nlet to_list s = fold' s ~init:[] ~f:(fun b a -> return (a :: b)) >>| List.rev\nlet copy_to_tail t tail = iter' t ~f:(fun a -> return (Tail.extend tail a))\n\nlet append t1 t2 =\n create (fun tail ->\n upon (copy_to_tail t1 tail) (fun () ->\n upon (copy_to_tail t2 tail) (fun () -> Tail.close_exn tail)))\n;;\n\nlet concat t =\n create (fun tail ->\n upon (iter' t ~f:(fun t -> copy_to_tail t tail)) (fun () -> Tail.close_exn tail))\n;;\n\nlet filter' t ~f =\n create (fun tail ->\n upon\n (iter' t ~f:(fun v ->\n match%map f v with\n | false -> ()\n | true -> Tail.extend tail v))\n (fun () -> Tail.close_exn tail))\n;;\n\nlet filter_deprecated t ~f = filter' t ~f:(fun a -> return (f a))\n\nlet filter_map' t ~f =\n create (fun tail ->\n upon\n (iter' t ~f:(fun v ->\n match%map f v with\n | None -> ()\n | Some v -> Tail.extend tail v))\n (fun () -> Tail.close_exn tail))\n;;\n\nlet filter_map_deprecated t ~f = filter_map' t ~f:(fun a -> return (f a))\n\nlet map' t ~f =\n create (fun tail ->\n upon\n (iter' t ~f:(fun v -> f v >>| Tail.extend tail))\n (fun () -> Tail.close_exn tail))\n;;\n\nlet map t ~f = map' t ~f:(fun a -> return (f a))\n\nlet first_n s n =\n create (fun tail ->\n let rec loop s n =\n if n = 0\n then Tail.close_exn tail\n else\n upon (next s) (function\n | Nil -> Tail.close_exn tail\n | Cons (x, t) ->\n Tail.extend tail x;\n loop t (n - 1))\n in\n loop s n)\n;;\n\nlet available_now t =\n let rec loop t ac =\n match Deferred.peek (next t) with\n | None | Some Nil -> List.rev ac, t\n | Some (Cons (x, t)) -> loop t (x :: ac)\n in\n loop t []\n;;\n\nlet split ?(stop = Deferred.never ()) ?(f = fun _ -> `Continue) t =\n let reason_for_stopping = Ivar.create () in\n let prefix = Tail.create () in\n let finish v =\n Tail.close_exn prefix;\n Ivar.fill reason_for_stopping v\n in\n let rec loop t =\n choose [ choice stop (fun () -> `Stopped); choice (next t) (fun o -> `Next o) ]\n >>> function\n | `Stopped -> finish (`Stopped t)\n | `Next o ->\n (match o with\n | Nil -> finish `End_of_stream\n | Cons (a, t) ->\n (match f a with\n | `Continue ->\n Tail.extend prefix a;\n loop t\n | `Found b -> finish (`Found (b, t))))\n in\n loop t;\n Tail.collect prefix, Ivar.read reason_for_stopping\n;;\n\nlet find t ~f =\n let _, found = split t ~f:(fun a -> if f a then `Found a else `Continue) in\n match%map found with\n | `Stopped _ -> assert false\n | (`End_of_stream | `Found _) as x -> x\n;;\n\nlet ungroup t =\n create (fun tail ->\n upon\n (iter' t ~f:(fun l ->\n List.iter l ~f:(fun x -> Tail.extend tail x);\n return ()))\n (fun () -> Tail.close_exn tail))\n;;\n\nlet interleave ts =\n create (fun tail ->\n (* The interleaved stream should be closed when the outer stream and all of\n the inner streams have been closed. Keep a count of the number of open\n streams and close the interleaved stream when that count becomes\n zero. *)\n let num_open = ref 1 in\n (* 1 for the outer stream that is open *)\n let close () =\n num_open := !num_open - 1;\n if !num_open = 0 then Tail.close_exn tail\n in\n let outer_closed =\n iter' ts ~f:(fun t ->\n num_open := !num_open + 1;\n upon (copy_to_tail t tail) close;\n return ())\n in\n upon outer_closed close)\n;;\n\nlet take_until t d =\n create (fun tail ->\n let rec loop t =\n upon\n (choose [ choice d (fun () -> `Stop); choice (next t) (fun z -> `Next z) ])\n (function\n | `Stop | `Next Nil -> Tail.close_exn tail\n | `Next (Cons (x, t)) ->\n Tail.extend tail x;\n loop t)\n in\n loop t)\n;;\n\nlet iter_durably' t ~f =\n Deferred.create (fun result ->\n let rec loop t =\n next t\n >>> function\n | Nil -> Ivar.fill result ()\n | Cons (x, t) ->\n Monitor.try_with ~rest:`Raise (fun () -> f x)\n >>> fun z ->\n loop t;\n (match z with\n | Ok () -> ()\n | Error e -> Monitor.send_exn (Monitor.current ()) e)\n in\n loop t)\n;;\n\nlet iter_durably_report_end t ~f =\n Deferred.create (fun result ->\n let rec loop t =\n next t\n >>> function\n | Nil -> Ivar.fill result ()\n | Cons (x, t) ->\n (* We immediately call [loop], thus making the iter durable. Any exceptions\n raised by [f] will not prevent the loop from continuing, and will go to the\n monitor of whomever called [iter_durably_report_end]. *)\n loop t;\n f x\n in\n loop t)\n;;\n\nlet iter_durably t ~f = don't_wait_for (iter_durably_report_end t ~f)\n\nlet of_fun f =\n unfold () ~f:(fun () ->\n let%map a = f () in\n Some (a, ()))\n;;\n","include Synchronous_time_source0\n\nlet create = Scheduler1.create_time_source\nlet wall_clock = Scheduler1.wall_clock\n","open! Core_kernel\nopen! Import\n\ntype ('a, 'permission) t = ('a, 'permission) Types.Bvar.t\n\ntype 'a repr = 'a Types.Bvar.repr =\n { mutable has_any_waiters : bool\n ; mutable ivar : 'a Ivar.t\n }\n[@@deriving fields, sexp_of]\n\nlet invariant invariant_a _ t =\n let repr = Types.Bvar.to_repr t in\n Invariant.invariant [%here] repr [%sexp_of: _ repr] (fun () ->\n let check f = Invariant.check_field repr f in\n Fields_of_repr.iter\n ~has_any_waiters:\n (check (fun has_any_waiters ->\n if Ivar.has_handlers repr.ivar then assert has_any_waiters))\n ~ivar:\n (check (fun ivar ->\n Ivar.invariant invariant_a ivar;\n assert (Ivar.is_empty ivar))))\n;;\n\nlet sexp_of_t _ _ t =\n let { has_any_waiters; ivar = _ } = Types.Bvar.to_repr t in\n (* We don't show [ivar] because it's always empty. *)\n [%message (has_any_waiters : bool)]\n;;\n\ninclude Scheduler1.Bvar\n\nlet broadcast t a =\n let repr = Types.Bvar.to_repr t in\n if repr.has_any_waiters\n then (\n repr.has_any_waiters <- false;\n Ivar.fill repr.ivar a;\n repr.ivar <- Ivar.create ())\n;;\n\nlet wait t =\n let repr = Types.Bvar.to_repr t in\n repr.has_any_waiters <- true;\n Ivar.read repr.ivar\n;;\n\nlet has_any_waiters t =\n let repr = Types.Bvar.to_repr t in\n repr.has_any_waiters\n;;\n","open! Core_kernel\nopen! Import\nopen! Deferred_std\n\nlet debug = Debug.clock\n\nmodule Alarm = Timing_wheel.Alarm\nmodule Deferred = Deferred1\nmodule Scheduler = Scheduler1\n\nlet upon = Deferred.upon\nlet choose = Deferred.choose\nlet choice = Deferred.choice\nlet ( >>> ) = upon\n\nmodule T1 = struct\n include Synchronous_time_source0.T1\n\n (* We don't include the [id] in the sexp because the user (rightly) can't control it, so\n it's hard to make it deterministic in tests. *)\n let sexp_of_t\n _\n { id = _\n ; advance_errors = _\n ; am_advancing = _\n ; events\n ; fired_events = _\n ; handle_fired = _\n ; is_wall_clock\n ; most_recently_fired = _\n ; scheduler = _\n }\n =\n if is_wall_clock\n then [%message \"\"]\n else\n [%message\n (is_wall_clock : bool)\n (* We don't display the [Job.t]s in [events] because those are\n pool pointers, which are uninformative. *)\n (events : _ Timing_wheel.t)]\n ;;\nend\n\nopen T1\n\nmodule Read_write = struct\n type t = read_write T1.t [@@deriving sexp_of]\n\n let invariant = invariant\n let invariant_with_jobs = invariant_with_jobs\nend\n\ntype t = read T1.t [@@deriving sexp_of]\n\nlet invariant = invariant\nlet invariant_with_jobs = invariant_with_jobs\nlet read_only (t : [> read ] T1.t) = (t :> t)\nlet create = Scheduler.create_time_source\nlet wall_clock = Scheduler.wall_clock\nlet alarm_precision t = Timing_wheel.alarm_precision t.events\nlet next_alarm_fires_at t = Timing_wheel.next_alarm_fires_at t.events\nlet timing_wheel_now t = Timing_wheel.now t.events\nlet id t = t.id\n\nmodule Id = Synchronous_time_source0.Id\n\nlet now t =\n if t.is_wall_clock\n then\n (* For the wall-clock time-source, we use [Time_ns.now ()] rather than\n [Timing_wheel.now t.events]. The latter is only updated at the start of each\n cycle. There can be substantial difference between the two when people do long\n running computations or mix blocking code with async. And humans expect that\n wall-clock time is based on [Time.now], not some artifact of async\n implementation. *)\n Time_ns.now ()\n else timing_wheel_now t\n;;\n\n(* We preallocate [send_exn] to avoid allocating it on each call to [advance_clock]. *)\nlet send_exn = Some Monitor.send_exn\nlet advance_directly t ~to_ = Synchronous_time_source0.advance_clock t ~to_ ~send_exn\nlet advance_directly_by t by = advance_directly t ~to_:(Time_ns.after (now t) by)\nlet advance = advance_directly\nlet advance_by = advance_directly_by\nlet fire_past_alarms t = Synchronous_time_source0.fire_past_alarms t ~send_exn\nlet yield t = Bvar.wait (Scheduler.yield t.scheduler)\n\nlet advance_by_alarms ?wait_for t ~to_ =\n let run_queued_alarms () =\n (* Every time we want to run queued alarms we need to yield control back to the\n [Async.Scheduler] and [wait_for] any logic that is supposed to finish at this time\n before advancing. If no [wait_for] logic is specified we can simply yield control\n by invoking [yield t], which enqueues another job at the end of the scheduler job\n queue so alarm jobs have the opportunity to run before we advance. *)\n match wait_for with\n | None -> yield t\n | Some f -> f ()\n in\n let finish () =\n advance_directly t ~to_;\n fire_past_alarms t;\n (* so that alarms scheduled at or before [to_] fire *)\n run_queued_alarms ()\n in\n let rec walk_alarms () =\n match next_alarm_fires_at t with\n | None -> finish ()\n | Some next_alarm_fires_at ->\n if Time_ns.( >= ) next_alarm_fires_at to_\n then finish ()\n else (\n advance_directly t ~to_:next_alarm_fires_at;\n let queued_alarms_ran = run_queued_alarms () in\n if Deferred.is_determined queued_alarms_ran\n then walk_alarms ()\n else (\n let%bind () = queued_alarms_ran in\n walk_alarms ()))\n in\n (* This first [run_queued_alarms] call allows [Clock_ns.every] the opportunity to run\n its continuation deferreds so that they can reschedule alarms. This is particularly\n useful in our \"advance hits intermediate alarms\" unit test below, but likely useful\n in other cases where [every] is synchronously followed by [advance]. *)\n let%bind () = run_queued_alarms () in\n walk_alarms ()\n;;\n\nlet advance_by_alarms_by ?wait_for t by =\n advance_by_alarms ?wait_for t ~to_:(Time_ns.after (now t) by)\n;;\n\nlet span_to_time t span = Time_ns.after (now t) span\n\nlet schedule_job t ~at execution_context f a =\n let alarm =\n Timing_wheel.add\n t.events\n ~at\n (Job_or_event.of_job (Scheduler.create_job t.scheduler execution_context f a))\n in\n (match t.scheduler.event_added_hook with\n | None -> ()\n | Some f -> f at);\n alarm\n;;\n\nlet run_at_internal t time f a =\n let execution_context = Scheduler.current_execution_context t.scheduler in\n if Time_ns.( > ) time (Timing_wheel.now t.events)\n then schedule_job t ~at:time execution_context f a\n else (\n Scheduler.enqueue t.scheduler execution_context f a;\n Alarm.null ())\n;;\n\nlet run_at t time f a = ignore (run_at_internal t time f a : _ Alarm.t)\nlet run_after t span f a = run_at t (span_to_time t span) f a\n\nlet at =\n let fill result = Ivar.fill result () in\n fun t time ->\n if Time_ns.( <= ) time (Timing_wheel.now t.events)\n then return ()\n else (\n let result = Ivar.create () in\n ignore (run_at_internal t time fill result : _ Alarm.t);\n Ivar.read result)\n;;\n\nlet after t span = at t (span_to_time t span)\n\nlet remove_alarm t alarm : unit =\n let job_or_event = Alarm.value t.events alarm in\n (let open Job_or_event.Match in\n let (K k) = kind job_or_event in\n match k, project k job_or_event with\n | Job, job -> Scheduler.free_job t.scheduler job\n | Event, _ ->\n (* This is unreachable because [alarm] only ever comes from [Event.alarm] which only\n ever gets populated by a call to [schedule_job]. *)\n assert false);\n Timing_wheel.remove t.events alarm\n;;\n\nlet remove_alarm_if_scheduled t alarm =\n if Timing_wheel.mem t.events alarm then remove_alarm t alarm\n;;\n\nmodule Event = struct\n module Fired = struct\n type ('a, 'h) t =\n | Aborted of 'a\n | Happened of 'h\n [@@deriving sexp_of]\n end\n\n type ('a, 'h) t =\n { mutable alarm : Job_or_event.t Alarm.t\n ; mutable fire : unit -> unit\n ; (* As long as [Ivar.is_empty fired], we have not yet committed to whether the event\n will happen or be aborted. When [Ivar.is_empty fired], the alarm may or may not\n be in the timing wheel -- if it isn't, then there's a job in Async's job queue\n that will fire the event, unless it is aborted before that job can run. *)\n fired : ('a, 'h) Fired.t Ivar.t\n ; (* [num_fires_to_skip] is used to reschedule events that have fired and entered the\n Async job queue, but have not yet run. Those jobs only run if [num_fires_to_skip\n = 0], and otherwise just decrement it. So, to reschedule an event in such a\n state, we increment [num_fires_to_skip] and add a new alarm to the timing\n wheel. *)\n mutable num_fires_to_skip : int\n ; (* [scheduled_at] is the time at which [t] has most recently been scheduled to fire.\n While [t.alarm] is still in the timing wheel, this is the same as [Alarm.at\n t.alarm]. *)\n mutable scheduled_at : Time_ns.t\n ; time_source : Synchronous_time_source.t\n }\n [@@deriving fields, sexp_of]\n\n type t_unit = (unit, unit) t [@@deriving sexp_of]\n\n let fired t = Ivar.read t.fired\n\n let invariant invariant_a invariant_h t =\n Invariant.invariant [%here] t [%sexp_of: (_, _) t] (fun () ->\n let events = t.time_source.events in\n let check f = Invariant.check_field t f in\n Fields.iter\n ~alarm:\n (check (fun alarm ->\n if Ivar.is_full t.fired\n then assert (not (Timing_wheel.mem events alarm))\n else if Timing_wheel.mem events alarm\n then assert (Job_or_event.is_job (Alarm.value events alarm))))\n ~fire:ignore\n ~fired:\n (check (fun (fired : _ Fired.t Ivar.t) ->\n match Deferred.peek (Ivar.read fired) with\n | None -> ()\n | Some (Aborted a) -> invariant_a a\n | Some (Happened h) -> invariant_h h))\n ~num_fires_to_skip:\n (check (fun num_fires_to_skip -> assert (num_fires_to_skip >= 0)))\n ~scheduled_at:\n (check (fun scheduled_at ->\n if Timing_wheel.mem events t.alarm\n then\n [%test_result: Time_ns.t]\n scheduled_at\n ~expect:(Alarm.at events t.alarm)))\n ~time_source:ignore)\n ;;\n\n module Status = struct\n type ('a, 'h) t =\n | Aborted of 'a\n | Happened of 'h\n | Scheduled_at of Time_ns.t\n [@@deriving sexp_of]\n end\n\n let status t : _ Status.t =\n match Deferred.peek (Ivar.read t.fired) with\n | None -> Scheduled_at t.scheduled_at\n | Some (Aborted a) -> Aborted a\n | Some (Happened h) -> Happened h\n ;;\n\n module Abort_result = struct\n type ('a, 'h) t =\n | Ok\n | Previously_aborted of 'a\n | Previously_happened of 'h\n [@@deriving sexp_of]\n end\n\n let abort t a : _ Abort_result.t =\n if debug then Debug.log \"Time_source.Event.abort\" t [%sexp_of: (_, _) t];\n match Deferred.peek (fired t) with\n | Some (Aborted a) -> Previously_aborted a\n | Some (Happened h) -> Previously_happened h\n | None ->\n Ivar.fill t.fired (Aborted a);\n remove_alarm_if_scheduled t.time_source t.alarm;\n Ok\n ;;\n\n let abort_exn t a =\n match abort t a with\n | Ok -> ()\n | Previously_happened _ ->\n raise_s\n [%message \"Clock.Event.abort_exn failed to abort event that previously happened\"]\n | Previously_aborted _ ->\n raise_s\n [%message \"Clock.Event.abort_exn failed to abort event that previously aborted\"]\n ;;\n\n let abort_if_possible t a = ignore (abort t a : _ Abort_result.t)\n let schedule t = t.alarm <- run_at_internal t.time_source t.scheduled_at t.fire ()\n\n module Reschedule_result = struct\n type ('a, 'h) t =\n | Ok\n | Previously_aborted of 'a\n | Previously_happened of 'h\n [@@deriving sexp_of]\n end\n\n let reschedule_at t at : _ Reschedule_result.t =\n if debug\n then\n Debug.log\n \"Time_source.Event.reschedule_at\"\n (t, at)\n [%sexp_of: (_, _) t * Time_ns.t];\n match Deferred.peek (fired t) with\n | Some (Aborted a) -> Previously_aborted a\n | Some (Happened h) -> Previously_happened h\n | None ->\n let events = t.time_source.events in\n let is_in_timing_wheel = Timing_wheel.mem events t.alarm in\n let am_trying_to_reschedule_in_the_future =\n Time_ns.( > ) at (Timing_wheel.now events)\n in\n t.scheduled_at <- at;\n (match am_trying_to_reschedule_in_the_future, is_in_timing_wheel with\n | false, false -> ()\n | false, true ->\n t.time_source.handle_fired t.alarm;\n Timing_wheel.remove events t.alarm\n | true, false ->\n t.num_fires_to_skip <- t.num_fires_to_skip + 1;\n schedule t\n | true, true -> Timing_wheel.reschedule events t.alarm ~at);\n Ok\n ;;\n\n let reschedule_after t span = reschedule_at t (span_to_time t.time_source span)\n\n let run_at time_source scheduled_at f z =\n if debug then Debug.log \"Time_source.Event.run_at\" scheduled_at [%sexp_of: Time_ns.t];\n let t =\n { alarm = Alarm.null ()\n ; fire = ignore (* set below *)\n ; fired = Ivar.create ()\n ; num_fires_to_skip = 0\n ; scheduled_at\n ; time_source = read_only time_source\n }\n in\n let fire () =\n (* [fire] runs in an Async job. The event may have been aborted after the job\n was enqueued, so [fire] must check [fired]. *)\n if Ivar.is_empty t.fired\n then\n if t.num_fires_to_skip > 0\n then t.num_fires_to_skip <- t.num_fires_to_skip - 1\n else (\n let result = f z in\n (* [f z] may have aborted the event, so we must check [fired] again. *)\n if Ivar.is_empty t.fired then Ivar.fill t.fired (Happened result))\n in\n t.fire <- fire;\n schedule t;\n t\n ;;\n\n let at time_source time = run_at time_source time ignore ()\n\n let run_after time_source span f a =\n run_at time_source (span_to_time time_source span) f a\n ;;\n\n let after time_source span = at time_source (span_to_time time_source span)\nend\n\nlet at_times ?(stop = Deferred.never ()) t next_time =\n let tail = Tail.create () in\n let rec loop () =\n choose\n [ choice stop (fun () -> `Stop); choice (at t (next_time ())) (fun () -> `Tick) ]\n >>> function\n | `Stop -> Tail.close_exn tail\n | `Tick ->\n Tail.extend tail ();\n loop ()\n in\n loop ();\n Tail.collect tail\n;;\n\nlet at_varying_intervals ?stop t compute_span =\n at_times t ?stop (fun () -> Time_ns.after (now t) (compute_span ()))\n;;\n\nlet at_intervals ?start ?stop t interval =\n let start =\n match start with\n | Some x -> x\n | None -> now t\n in\n at_times t ?stop (fun () ->\n Time_ns.next_multiple ~base:start ~after:(now t) ~interval ())\n;;\n\nmodule Continue = struct\n type t =\n | Immediately\n | After of Time_ns.Span.t\n | Next_multiple of Time_ns.t * Time_ns.Span.t\n\n let immediately = Immediately\n\n let at t time_source =\n match t with\n | Immediately -> Timing_wheel.now time_source.events\n | After span -> span_to_time time_source span\n | Next_multiple (base, interval) ->\n Time_ns.next_multiple ~base ~after:(now time_source) ~interval ()\n ;;\nend\n\nlet run_repeatedly\n ?(start = return ())\n ?stop\n ?(continue_on_error = true)\n ?(finished = Ivar.create ())\n t\n ~f\n ~continue\n =\n start\n >>> fun () ->\n let alarm = ref (Alarm.null ()) in\n let stop =\n match stop with\n | None -> Deferred.never ()\n | Some stop ->\n upon stop (fun () ->\n if Timing_wheel.mem t.events !alarm\n then (\n remove_alarm t !alarm;\n Ivar.fill_if_empty finished ()));\n stop\n in\n (* [run_f], [continue_f], and [continue_try_with] are defined so that we allocate their\n closures once, not once per iteration. *)\n let rec run_f () =\n (* Before calling [f], we synchronously check whether [stop] is determined. *)\n if Deferred.is_determined stop\n then Ivar.fill_if_empty finished ()\n else if continue_on_error\n then Monitor.try_with f ~run:`Now ~rest:`Raise >>> continue_try_with\n else (\n let d = f () in\n if Deferred.is_determined d then continue_f () else d >>> continue_f)\n and continue_f () =\n if Deferred.is_determined stop\n then Ivar.fill_if_empty finished ()\n else alarm := run_at_internal t (Continue.at continue t) run_f ()\n and continue_try_with or_error =\n (match or_error with\n | Ok () -> ()\n | Error error -> Monitor.send_exn (Monitor.current ()) error);\n continue_f ()\n in\n run_f ()\n;;\n\nlet every' ?start ?stop ?continue_on_error ?finished t span f =\n if Time_ns.Span.( <= ) span Time_ns.Span.zero\n then\n raise_s [%message \"Time_source.every got nonpositive span\" (span : Time_ns.Span.t)];\n run_repeatedly t ?start ?stop ?continue_on_error ?finished ~f ~continue:(After span)\n;;\n\nlet every ?start ?stop ?continue_on_error t span f =\n every' t ?start ?stop ?continue_on_error ?finished:None span (fun () ->\n f ();\n return ())\n;;\n\nlet run_at_intervals' ?start ?stop ?continue_on_error t interval f =\n let now = now t in\n let base, start =\n match start with\n | None -> now, None\n | Some start ->\n ( start\n , Some\n (at\n t\n (Time_ns.next_multiple\n ()\n ~base:start\n ~after:now\n ~can_equal_after:true\n ~interval)) )\n in\n run_repeatedly\n t\n ?start\n ?stop\n ?continue_on_error\n ~f\n ~continue:(Next_multiple (base, interval))\n;;\n\nlet run_at_intervals ?start ?stop ?continue_on_error t interval f =\n run_at_intervals' ?start ?stop ?continue_on_error t interval (fun () ->\n f ();\n return ())\n;;\n\nlet with_timeout t span d =\n let timeout = Event.after t span in\n choose\n (* The code below does exhaustive case analysis in both [choice]s. Because [timeout]\n does not escape the scope of this function, certain cases should be impossible, and\n are marked as such with exceptions. We do not expect those exceptions to occur,\n but if they do, it likely indicates a bug in [choose] rather than\n [with_timeout]. *)\n [ choice d (fun v ->\n (match Event.abort timeout () with\n (* [Previously_happened] can occur if both [d] and [wait] become determined at\n the same time, e.g. [with_timeout (sec 0.) (return ())]. *)\n | Ok | Previously_happened () -> ()\n | Previously_aborted () ->\n raise_s [%message \"Time_source.with_timeout bug: should only abort once\"]);\n `Result v)\n ; choice (Event.fired timeout) (function\n | Happened () -> `Timeout\n | Aborted () ->\n raise_s\n [%message \"Time_source.with_timeout bug: both completed and timed out\"])\n ]\n;;\n\nlet of_synchronous t = t\nlet to_synchronous t = t\n","open! Base\n\ntype _ t =\n | Stack : 'a Stack.t -> 'a t\n | Counter : { mutable length : int } -> unit t\n[@@deriving sexp_of]\n\nlet of_list list = Stack (Stack.of_list list)\n\nlet create_counter ~length =\n if length < 0\n then\n raise_s\n [%message \"[Stack_or_counter.create_counter] got negative length\" (length : int)];\n Counter { length }\n;;\n\nlet length (type a) (t : a t) =\n match t with\n | Stack s -> Stack.length s\n | Counter r -> r.length\n;;\n\nlet clear (type a) (t : a t) =\n match t with\n | Stack s -> Stack.clear s\n | Counter r -> r.length <- 0\n;;\n\nlet push (type a) (t : a t) a =\n match t with\n | Stack s -> Stack.push s a\n | Counter r -> r.length <- r.length + 1\n;;\n\nlet pop_exn (type a) (t : a t) =\n match t with\n | Stack s -> Stack.pop_exn s\n | Counter r ->\n if r.length = 0 then raise_s [%message \"[Stack_or_counter.pop_exn] of empty stack\"];\n r.length <- r.length - 1\n;;\n\nlet iter (type a) (t : a t) ~(f : a -> unit) =\n match t with\n | Stack s -> Stack.iter s ~f\n | Counter r ->\n for _ = 1 to r.length do\n f ()\n done\n;;\n","open! Core_kernel\nopen! Import\nopen! Deferred_std\nmodule Deferred = Deferred1\n\ntype 'a outcome =\n [ `Ok of 'a\n | `Aborted\n | `Raised of exn\n ]\n[@@deriving sexp_of]\n\nmodule Internal_job : sig\n type 'a t [@@deriving sexp_of]\n\n val create : ('a -> 'b Deferred.t) -> 'a t * 'b outcome Deferred.t\n\n (* Every internal job will eventually be either [run] or [abort]ed, but not both. *)\n\n val run : 'a t -> 'a -> [ `Ok | `Raised ] Deferred.t\n val abort : _ t -> unit\nend = struct\n type 'a t =\n { start : [ `Abort | `Start of 'a ] Ivar.t\n ; outcome : [ `Ok | `Aborted | `Raised ] Deferred.t\n }\n [@@deriving sexp_of]\n\n let create work =\n let start = Ivar.create () in\n let result =\n match%bind Ivar.read start with\n | `Abort -> return `Aborted\n | `Start a ->\n (match%map Monitor.try_with (fun () -> work a) with\n | Ok a -> `Ok a\n | Error exn -> `Raised exn)\n in\n let outcome =\n match%map result with\n | `Ok _ -> `Ok\n | `Aborted -> `Aborted\n | `Raised _ -> `Raised\n in\n let t = { start; outcome } in\n t, result\n ;;\n\n let run t a =\n Ivar.fill t.start (`Start a);\n match%map t.outcome with\n | `Aborted -> assert false\n | (`Ok | `Raised) as x -> x\n ;;\n\n let abort t = Ivar.fill t.start `Abort\nend\n\ntype 'a t =\n { continue_on_error : bool\n ; max_concurrent_jobs : int\n ; (* [job_resources_not_in_use] holds resources that are not currently in use by a\n running job. *)\n job_resources_not_in_use : 'a Stack_or_counter.t\n ;\n (* [jobs_waiting_to_start] is the queue of jobs that haven't yet started. *)\n jobs_waiting_to_start : 'a Internal_job.t Queue.t\n ; (* [0 <= num_jobs_running <= max_concurrent_jobs]. *)\n mutable num_jobs_running : int\n ; (* [capacity_available] is [Some ivar] if user code has called [capacity_available t]\n and is waiting to be notified when capacity is available in the throttle.\n [maybe_start_job] will fill [ivar] when capacity becomes available, i.e. when\n [jobs_waiting_to_start] is empty and [num_jobs_running < max_concurrent_jobs]. *)\n mutable capacity_available : unit Ivar.t option\n ; (* [is_dead] is true if [t] was killed due to a job raising an exception or [kill t]\n being called. *)\n mutable is_dead : bool\n ; (* [cleans] holds functions that will be called to clean each resource when [t] is\n killed. *)\n mutable cleans : ('a -> unit Deferred.t) list\n ; (* [num_resources_not_cleaned] is the number of resources whose clean functions have\n not yet completed. While [t] is alive, [num_resources_not_cleaned =\n max_concurrent_jobs]. Once [t] is killed, [num_resources_not_cleaned] decreases to\n zero over time as the clean functions complete. *)\n mutable num_resources_not_cleaned : int\n ; (* [cleaned] becomes determined when [num_resources_not_cleaned] reaches zero,\n i.e. after [t] is killed and all its clean functions complete. *)\n cleaned : unit Ivar.t\n }\n[@@deriving fields, sexp_of]\n\nlet invariant invariant_a t : unit =\n try\n let check f field = f (Field.get field t) in\n Fields.iter\n ~continue_on_error:ignore\n ~max_concurrent_jobs:\n (check (fun max_concurrent_jobs -> assert (max_concurrent_jobs > 0)))\n ~job_resources_not_in_use:\n (check (fun job_resources_not_in_use ->\n Stack_or_counter.iter job_resources_not_in_use ~f:invariant_a;\n assert (\n Stack_or_counter.length job_resources_not_in_use\n = if t.is_dead then 0 else t.max_concurrent_jobs - t.num_jobs_running)))\n ~jobs_waiting_to_start:\n (check (function jobs_waiting_to_start ->\n if t.is_dead then assert (Queue.is_empty jobs_waiting_to_start)))\n ~num_jobs_running:\n (check (fun num_jobs_running ->\n assert (num_jobs_running >= 0);\n assert (num_jobs_running <= t.max_concurrent_jobs);\n if num_jobs_running < t.max_concurrent_jobs\n then assert (Queue.is_empty t.jobs_waiting_to_start)))\n ~capacity_available:\n (check (function\n | None -> ()\n | Some ivar -> assert (Ivar.is_empty ivar)))\n ~is_dead:ignore\n ~cleans:ignore\n ~num_resources_not_cleaned:\n (check (fun num_resources_not_cleaned ->\n assert (num_resources_not_cleaned >= 0);\n assert (num_resources_not_cleaned <= t.max_concurrent_jobs);\n if num_resources_not_cleaned < t.max_concurrent_jobs then assert t.is_dead))\n ~cleaned:\n (check (fun cleaned ->\n if Ivar.is_full cleaned then assert (t.num_resources_not_cleaned = 0)))\n with\n | exn -> raise_s [%message \"Throttle.invariant failed\" (exn : exn) (t : _ t)]\n;;\n\nmodule T2 = struct\n type nonrec ('a, 'kind) t = 'a t [@@deriving sexp_of]\n\n let invariant invariant_a _ t = invariant invariant_a t\nend\n\nlet num_jobs_waiting_to_start t = Queue.length t.jobs_waiting_to_start\n\nlet clean_resource t a =\n Deferred.all_unit (List.map t.cleans ~f:(fun f -> f a))\n >>> fun () ->\n t.num_resources_not_cleaned <- t.num_resources_not_cleaned - 1;\n if t.num_resources_not_cleaned = 0 then Ivar.fill t.cleaned ()\n;;\n\nlet kill t =\n if not t.is_dead\n then (\n t.is_dead <- true;\n Queue.iter t.jobs_waiting_to_start ~f:Internal_job.abort;\n Queue.clear t.jobs_waiting_to_start;\n Stack_or_counter.iter t.job_resources_not_in_use ~f:(fun a -> clean_resource t a);\n Stack_or_counter.clear t.job_resources_not_in_use)\n;;\n\nlet at_kill t f =\n (* We preserve the execution context so that exceptions raised by [f] go to the monitor\n in effect when [at_kill] was called. *)\n let f = unstage (Monitor.Exported_for_scheduler.preserve_execution_context' f) in\n t.cleans <- f :: t.cleans\n;;\n\nlet cleaned t = Ivar.read t.cleaned\n\nlet rec start_job t =\n assert (not t.is_dead);\n assert (t.num_jobs_running < t.max_concurrent_jobs);\n assert (not (Queue.is_empty t.jobs_waiting_to_start));\n let job = Queue.dequeue_exn t.jobs_waiting_to_start in\n t.num_jobs_running <- t.num_jobs_running + 1;\n let job_resource = Stack_or_counter.pop_exn t.job_resources_not_in_use in\n Internal_job.run job job_resource\n >>> fun res ->\n t.num_jobs_running <- t.num_jobs_running - 1;\n (match res with\n | `Ok -> ()\n | `Raised -> if not t.continue_on_error then kill t);\n if t.is_dead\n then clean_resource t job_resource\n else (\n Stack_or_counter.push t.job_resources_not_in_use job_resource;\n if not (Queue.is_empty t.jobs_waiting_to_start)\n then start_job t\n else (\n match t.capacity_available with\n | None -> ()\n | Some ivar ->\n Ivar.fill ivar ();\n t.capacity_available <- None))\n;;\n\nlet create_internal ~continue_on_error job_resources =\n let max_concurrent_jobs = Stack_or_counter.length job_resources in\n { continue_on_error\n ; max_concurrent_jobs\n ; job_resources_not_in_use = job_resources\n ; jobs_waiting_to_start = Queue.create ()\n ; num_jobs_running = 0\n ; capacity_available = None\n ; is_dead = false\n ; cleans = []\n ; num_resources_not_cleaned = max_concurrent_jobs\n ; cleaned = Ivar.create ()\n }\n;;\n\nlet create_with ~continue_on_error job_resources =\n create_internal ~continue_on_error (Stack_or_counter.of_list job_resources)\n;;\n\nmodule Sequencer = struct\n type nonrec 'a t = 'a t [@@deriving sexp_of]\n\n let create ?(continue_on_error = false) a = create_with ~continue_on_error [ a ]\nend\n\nlet create ~continue_on_error ~max_concurrent_jobs =\n if max_concurrent_jobs <= 0\n then\n raise_s\n [%message\n \"Throttle.create requires positive max_concurrent_jobs, but got\"\n (max_concurrent_jobs : int)];\n create_internal\n ~continue_on_error\n (Stack_or_counter.create_counter ~length:max_concurrent_jobs)\n;;\n\nmodule Job = struct\n type ('a, 'b) t =\n { internal_job : 'a Internal_job.t\n ; result : [ `Ok of 'b | `Aborted | `Raised of exn ] Deferred.t\n }\n\n let result t = t.result\n let abort t = Internal_job.abort t.internal_job\n\n let create f =\n let internal_job, result = Internal_job.create f in\n { internal_job; result }\n ;;\nend\n\nlet enqueue' t f =\n let job = Job.create f in\n if t.is_dead\n then Job.abort job\n else (\n Queue.enqueue t.jobs_waiting_to_start job.internal_job;\n if t.num_jobs_running < t.max_concurrent_jobs then start_job t);\n Job.result job\n;;\n\nlet handle_enqueue_result result =\n match result with\n | `Ok a -> a\n | `Aborted -> raise_s [%message \"throttle aborted job\"]\n | `Raised exn -> raise exn\n;;\n\nlet enqueue t f = enqueue' t f >>| handle_enqueue_result\n\nlet enqueue_exclusive t f =\n let n = t.max_concurrent_jobs in\n if Int.( >= ) n 1_000_000\n then\n raise_s\n [%sexp\n \"[enqueue_exclusive] was called with a very large value of \\\n [max_concurrent_jobs]. This doesn't work.\"];\n let done_ = Ivar.create () in\n assert (n > 0);\n let f_placeholder _slot = Ivar.read done_ in\n for _ = 1 to n - 1 do\n don't_wait_for (enqueue t f_placeholder)\n done;\n let%map result = enqueue' t (fun _slot -> f ()) in\n Ivar.fill done_ ();\n handle_enqueue_result result\n;;\n\nlet monad_sequence_how ?(how = `Sequential) ~f =\n stage\n (match how with\n | `Parallel -> f\n | (`Sequential | `Max_concurrent_jobs _) as how ->\n let max_concurrent_jobs =\n match how with\n | `Sequential -> 1\n | `Max_concurrent_jobs max_concurrent_jobs -> max_concurrent_jobs\n in\n let t = create ~continue_on_error:false ~max_concurrent_jobs in\n fun a -> enqueue t (fun () -> f a))\n;;\n\nlet monad_sequence_how2 ?(how = `Sequential) ~f =\n stage\n (match how with\n | `Parallel -> f\n | (`Sequential | `Max_concurrent_jobs _) as how ->\n let max_concurrent_jobs =\n match how with\n | `Sequential -> 1\n | `Max_concurrent_jobs max_concurrent_jobs -> max_concurrent_jobs\n in\n let t = create ~continue_on_error:false ~max_concurrent_jobs in\n fun a1 a2 -> enqueue t (fun () -> f a1 a2))\n;;\n\nlet prior_jobs_done t =\n (* We queue [t.max_concurrent_jobs] dummy jobs and when they are all started we know\n that all prior jobs finished. We make sure that all dummy jobs wait for the last one\n to get started before finishing. *)\n Deferred.create (fun all_dummy_jobs_running ->\n let dummy_jobs_running = ref 0 in\n for _ = 1 to t.max_concurrent_jobs do\n don't_wait_for\n (enqueue t (fun _ ->\n incr dummy_jobs_running;\n if !dummy_jobs_running = t.max_concurrent_jobs\n then Ivar.fill all_dummy_jobs_running ();\n Ivar.read all_dummy_jobs_running))\n done)\n;;\n\nlet capacity_available t =\n if num_jobs_running t < max_concurrent_jobs t\n then return ()\n else (\n match t.capacity_available with\n | Some ivar -> Ivar.read ivar\n | None -> Deferred.create (fun ivar -> t.capacity_available <- Some ivar))\n;;\n","open! Core_kernel\nopen! Import\ninclude Scheduler\n\nlet enqueue_job execution_context f a = enqueue (t ()) execution_context f a\n\nlet thread_safe_enqueue_job execution_context f a =\n thread_safe_enqueue_external_job (t ()) execution_context f a\n;;\n\nlet current_execution_context () = current_execution_context (t ())\nlet cycle_count () = cycle_count (t ())\nlet cycle_start_ns () = cycle_start (t ())\nlet cycle_start () = Time_ns.to_time_float_round_nearest (cycle_start_ns ())\nlet cycle_times_ns () = map_cycle_times (t ()) ~f:Fn.id\nlet cycle_times () = map_cycle_times (t ()) ~f:Time_ns.Span.to_span_float_round_nearest\nlet total_cycle_time () = total_cycle_time (t ())\nlet long_cycles ~at_least = long_cycles (t ()) ~at_least\nlet long_cycles_with_context ~at_least = long_cycles_with_context (t ()) ~at_least\nlet long_jobs_with_context = long_jobs_with_context (t ())\nlet last_cycle_time () = last_cycle_time (t ())\nlet event_precision_ns () = event_precision (t ())\nlet event_precision () = Time_ns.Span.to_span_float_round_nearest (event_precision_ns ())\n\nlet set_max_num_jobs_per_priority_per_cycle i =\n set_max_num_jobs_per_priority_per_cycle (t ()) i\n;;\n\nlet max_num_jobs_per_priority_per_cycle () = max_num_jobs_per_priority_per_cycle (t ())\nlet set_record_backtraces bool = set_record_backtraces (t ()) bool\nlet force_current_cycle_to_end () = force_current_cycle_to_end (t ())\nlet yield () = yield (t ())\nlet yield_until_no_jobs_remain ?may_return_immediately () =\n yield_until_no_jobs_remain ?may_return_immediately (t ())\n;;\n\nlet yield_every ~n =\n let yield_every = Staged.unstage (yield_every ~n) in\n let t = t () in\n stage (fun () -> yield_every t)\n;;\n\nlet num_jobs_run () = num_jobs_run (t ())\nlet num_pending_jobs () = num_pending_jobs (t ())\n\nmodule Expert = struct\n let run_cycles_until_no_jobs_remain = run_cycles_until_no_jobs_remain\n let set_on_start_of_cycle f = set_on_start_of_cycle (t ()) f\n let set_on_end_of_cycle f = set_on_end_of_cycle (t ()) f\n let last_cycle_num_jobs () = last_cycle_num_jobs (t ())\n let run_every_cycle_start f = run_every_cycle_start (t ()) ~f\n let run_every_cycle_end f = run_every_cycle_end (t ()) ~f\nend\n\nmodule Private = Scheduler\n","open! Core_kernel\nopen! Import\n\nmodule type Clock = Clock_intf.Clock\nmodule type Clock_deprecated = Clock_intf.Clock_deprecated\n\nmodule Scheduler = Scheduler1\n\nlet time_source () = (Scheduler.t ()).time_source |> Time_source.of_synchronous\nlet after span = Time_source.after (time_source ()) span\nlet at time = Time_source.at (time_source ()) time\n\nlet at_varying_intervals ?stop compute_span =\n Time_source.at_varying_intervals ?stop (time_source ()) compute_span\n;;\n\nlet at_intervals ?start ?stop interval =\n Time_source.at_intervals ?start ?stop (time_source ()) interval\n;;\n\nlet every' ?start ?stop ?continue_on_error ?finished span f =\n Time_source.every' ?start ?stop ?continue_on_error ?finished (time_source ()) span f\n;;\n\nlet every ?start ?stop ?continue_on_error span f =\n Time_source.every ?start ?stop ?continue_on_error (time_source ()) span f\n;;\n\nlet run_after span f a = Time_source.run_after (time_source ()) span f a\nlet run_at time f a = Time_source.run_at (time_source ()) time f a\n\nlet run_at_intervals ?start ?stop ?continue_on_error interval f =\n Time_source.run_at_intervals\n ?start\n ?stop\n ?continue_on_error\n (time_source ())\n interval\n f\n;;\n\nlet run_at_intervals' ?start ?stop ?continue_on_error interval f =\n Time_source.run_at_intervals'\n ?start\n ?stop\n ?continue_on_error\n (time_source ())\n interval\n f\n;;\n\nlet with_timeout span d = Time_source.with_timeout (time_source ()) span d\n\nmodule Event = struct\n include Time_source.Event\n\n let after span = after (time_source ()) span\n let run_after span f a = run_after (time_source ()) span f a\n let at time = at (time_source ()) time\n let run_at time f z = run_at (time_source ()) time f z\nend\n","open Core_kernel\nopen Deferred_std\nmodule Deferred = Deferred1\n\nlet foldi t ~init ~f =\n Deferred.create (fun result ->\n let rec loop t i b =\n match t with\n | [] -> Ivar.fill result b\n | x :: xs -> f i b x >>> fun b -> loop xs (i + 1) b\n in\n loop t 0 init)\n;;\n\nlet fold t ~init ~f = foldi t ~init ~f:(fun _ a x -> f a x)\n\nlet seqmapi t ~f =\n foldi t ~init:[] ~f:(fun i bs a ->\n let%map b = f i a in\n b :: bs)\n >>| List.rev\n;;\n\nlet all ds = seqmapi ds ~f:(fun _ x -> x)\nlet all_unit ds = Deferred.ignore_m (fold ds ~init:() ~f:(fun () d -> d))\n\nlet iteri ?(how = `Sequential) t ~f =\n match how with\n | (`Parallel | `Max_concurrent_jobs _) as how ->\n all_unit (List.mapi t ~f:(unstage (Throttle.monad_sequence_how2 ~how ~f)))\n | `Sequential -> foldi t ~init:() ~f:(fun i () x -> f i x)\n;;\n\nlet mapi ?(how = `Sequential) t ~f =\n match how with\n | (`Parallel | `Max_concurrent_jobs _) as how ->\n all (List.mapi t ~f:(unstage (Throttle.monad_sequence_how2 ~how ~f)))\n | `Sequential -> seqmapi t ~f\n;;\n\nlet filteri ?how t ~f =\n let%map bools = mapi t ?how ~f in\n List.rev (List.fold2_exn t bools ~init:[] ~f:(fun ac x b -> if b then x :: ac else ac))\n;;\n\nlet filter_mapi ?how t ~f = mapi t ?how ~f >>| List.filter_opt\nlet concat_mapi ?how t ~f = mapi t ?how ~f >>| List.concat\n\nlet find_mapi t ~f =\n let rec find_mapi t ~f i =\n match t with\n | [] -> return None\n | hd :: tl ->\n (match%bind f i hd with\n | None -> find_mapi tl ~f (i + 1)\n | Some _ as some -> return some)\n in\n find_mapi t ~f 0\n;;\n\nlet findi t ~f =\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if b then Some (i, elt) else None)\n;;\n\nlet find t ~f =\n find_mapi t ~f:(fun _ elt ->\n let%map b = f elt in\n if b then Some elt else None)\n;;\n\nlet existsi t ~f =\n match%map\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if b then Some () else None)\n with\n | Some () -> true\n | None -> false\n;;\n\nlet for_alli t ~f =\n match%map\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if not b then Some () else None)\n with\n | Some () -> false\n | None -> true\n;;\n\nlet iter ?how t ~f = iteri ?how t ~f:(fun _ a -> f a)\nlet map ?how t ~f = mapi ?how t ~f:(fun _ a -> f a)\nlet filter ?how t ~f = filteri ?how t ~f:(fun _ a -> f a)\nlet filter_map ?how t ~f = filter_mapi ?how t ~f:(fun _ a -> f a)\nlet concat_map ?how t ~f = concat_mapi ?how t ~f:(fun _ a -> f a)\nlet find_map t ~f = find_mapi t ~f:(fun _ a -> f a)\nlet exists t ~f = existsi t ~f:(fun _ a -> f a)\nlet for_all t ~f = for_alli t ~f:(fun _ a -> f a)\nlet init ?how n ~f = map ?how (List.init n ~f:Fn.id) ~f\n","open Core_kernel\nopen Deferred_std\nmodule Deferred = Deferred1\n\nmodule T = struct\n type ('a, 'error) t = ('a, 'error) Result.t Deferred.t\nend\n\ninclude T\n\nlet combine t1 t2 ~ok ~err =\n let%map t1 = t1\n and t2 = t2 in\n Result.combine t1 t2 ~ok ~err\n;;\n\ninclude Monad.Make2 (struct\n include T\n\n let return a = Deferred.return (Ok a)\n\n let bind t ~f =\n Deferred.bind t ~f:(function\n | Ok a -> f a\n | Error _ as error -> Deferred.return error)\n ;;\n\n let map t ~f = Deferred.map t ~f:(fun r -> Result.map r ~f)\n let map = `Custom map\n end)\n\nlet fail x = Deferred.return (Error x)\nlet failf format = Printf.ksprintf fail format\nlet map_error t ~f = Deferred.map t ~f:(fun r -> Result.map_error r ~f)\n","open! Core_kernel\nopen! Import\nmodule Deferred = Deferred1\n\nmodule Monitor = struct\n let try_with = Monitor.try_with\nend\n\n(* Copied to [eager_deferred_or_error.ml]. There should be no diffs below this line. *)\n\ninclude (Deferred_result : Monad.S2 with type ('a, 'b) t := ('a, 'b) Deferred_result.t)\n\ntype 'a t = 'a Or_error.t Deferred.t\n\ninclude Applicative.Make (struct\n type nonrec 'a t = 'a t\n\n let return = return\n\n let apply f x =\n Deferred_result.combine\n f\n x\n ~ok:(fun f x -> f x)\n ~err:(fun e1 e2 -> Error.of_list [ e1; e2 ])\n ;;\n\n let map = `Custom map\n end)\n\nmodule Let_syntax = struct\n let return = return\n\n include Monad_infix\n\n module Let_syntax = struct\n let return = return\n let map = map\n let bind = bind\n let both = both\n\n (* from Applicative.Make *)\n module Open_on_rhs = struct end\n end\nend\n\nopen Let_syntax\n\nlet fail error = Deferred.return (Result.fail error)\nlet ok_exn t = Deferred.map t ~f:Or_error.ok_exn\nlet of_exn exn = Deferred.return (Or_error.of_exn exn)\nlet of_exn_result t = Deferred.map t ~f:Or_error.of_exn_result\nlet error msg v sexp_of = Deferred.return (Or_error.error msg v sexp_of)\nlet error_s sexp = Deferred.return (Or_error.error_s sexp)\nlet error_string msg = Deferred.return (Or_error.error_string msg)\nlet errorf format = ksprintf error_string format\nlet tag t ~tag = Deferred.map t ~f:(Or_error.tag ~tag)\nlet tag_s t ~tag = Deferred.map t ~f:(Or_error.tag_s ~tag)\n\nlet tag_arg t message a sexp_of_a =\n Deferred.map t ~f:(fun t -> Or_error.tag_arg t message a sexp_of_a)\n;;\n\nlet unimplemented msg = Deferred.return (Or_error.unimplemented msg)\nlet combine_errors l = Deferred.map (Deferred.all l) ~f:Or_error.combine_errors\nlet combine_errors_unit l = Deferred.map (Deferred.all l) ~f:Or_error.combine_errors_unit\n\nlet filter_ok_at_least_one l =\n Deferred.map (Deferred.all l) ~f:Or_error.filter_ok_at_least_one\n;;\n\nlet find_map_ok l ~f =\n Deferred.repeat_until_finished (l, []) (fun (l, errors) ->\n match l with\n | [] ->\n let errors = Error.of_list (List.rev errors) in\n Deferred.return (`Finished (Error errors))\n | hd :: tl ->\n Deferred.map (f hd) ~f:(function\n | Error current_error -> `Repeat (tl, current_error :: errors)\n | Ok result -> `Finished (Ok result)))\n;;\n\nlet ok_unit = return ()\n\nlet try_with ?extract_exn ?run ?here ?name f =\n Deferred.map (Monitor.try_with ?extract_exn ?run ?here ?name f) ~f:(function\n | Error exn -> Error (Error.of_exn exn)\n | Ok _ as ok -> ok)\n;;\n\nlet try_with_join ?extract_exn ?run ?here ?name f =\n Deferred.map (try_with ?extract_exn ?run ?here ?name f) ~f:Or_error.join\n;;\n\nmodule List = struct\n let foldi list ~init:acc ~f =\n let rec loop i acc = function\n | [] -> return acc\n | hd :: tl ->\n let%bind acc = f i acc hd in\n loop (i + 1) acc tl\n in\n loop 0 acc list\n ;;\n\n let fold t ~init ~f = foldi t ~init ~f:(fun _ a x -> f a x)\n\n let seqmapi t ~f =\n foldi t ~init:[] ~f:(fun i bs a ->\n let%map b = f i a in\n b :: bs)\n >>| List.rev\n ;;\n\n let all = all\n let all_unit = all_unit\n\n let iteri ?(how = `Sequential) t ~f =\n match how with\n | (`Parallel | `Max_concurrent_jobs _) as how ->\n all_unit (List.mapi t ~f:(unstage (Throttle.monad_sequence_how2 ~how ~f)))\n | `Sequential -> foldi t ~init:() ~f:(fun i () x -> f i x)\n ;;\n\n let mapi ?(how = `Sequential) t ~f =\n match how with\n | (`Parallel | `Max_concurrent_jobs _) as how ->\n all (List.mapi t ~f:(unstage (Throttle.monad_sequence_how2 ~how ~f)))\n | `Sequential -> seqmapi t ~f\n ;;\n\n let filter_mapi ?how t ~f = mapi t ?how ~f >>| List.filter_opt\n let concat_mapi ?how t ~f = mapi t ?how ~f >>| List.concat\n\n let filteri ?how t ~f =\n filter_mapi ?how t ~f:(fun i x ->\n let%map b = f i x in\n if b then Some x else None)\n ;;\n\n let find_mapi t ~f =\n let rec find_mapi t ~f i =\n match t with\n | [] -> return None\n | hd :: tl ->\n (match%bind f i hd with\n | None -> find_mapi tl ~f (i + 1)\n | Some _ as some -> return some)\n in\n find_mapi t ~f 0\n ;;\n\n let find_map t ~f = find_mapi t ~f:(fun _ a -> f a)\n\n let findi t ~f =\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if b then Some (i, elt) else None)\n ;;\n\n let find t ~f =\n find_map t ~f:(fun elt ->\n let%map b = f elt in\n if b then Some elt else None)\n ;;\n\n let existsi t ~f =\n match%map\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if b then Some () else None)\n with\n | Some () -> true\n | None -> false\n ;;\n\n let for_alli t ~f =\n match%map\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if not b then Some () else None)\n with\n | Some () -> false\n | None -> true\n ;;\n\n let iter ?how t ~f = iteri ?how t ~f:(fun _ a -> f a)\n let map ?how t ~f = mapi ?how t ~f:(fun _ a -> f a)\n let filter ?how t ~f = filteri ?how t ~f:(fun _ a -> f a)\n let filter_map ?how t ~f = filter_mapi ?how t ~f:(fun _ a -> f a)\n let concat_map ?how t ~f = concat_mapi ?how t ~f:(fun _ a -> f a)\n let find_map t ~f = find_mapi t ~f:(fun _ a -> f a)\n let exists t ~f = existsi t ~f:(fun _ a -> f a)\n let for_all t ~f = for_alli t ~f:(fun _ a -> f a)\n let init ?how n ~f = map ?how (List.init n ~f:Fn.id) ~f\nend\n\nlet rec repeat_until_finished state f =\n match%bind f state with\n | `Repeat state -> repeat_until_finished state f\n | `Finished state -> return state\n;;\n","open Core_kernel\nopen Deferred_std\nmodule List = Deferred_list\n\n(* We implement all of the [Queue] operations by converting the queue to a list and then\n using the corresponding [List] operation. We use lists rather than arrays because\n arrays longer than a certain length are allocated in the major heap, which can cause\n unnecessary promotion of the elements in the queue. Also, when one is folding or\n iterating over an array, the entire array must be kept alive. When folding or\n iterating over a list, only the remaining tail of the list is kept alive. So, using\n arrays rather than lists would increase the live-space needed by the program. *)\n\nlet foldi t ~init ~f = List.foldi (Queue.to_list t) ~init ~f\nlet fold t ~init ~f = List.fold (Queue.to_list t) ~init ~f\nlet all t = List.all (Queue.to_list t) >>| Queue.of_list\nlet all_unit t = List.all_unit (Queue.to_list t)\nlet iter ?how t ~f = List.iter ?how (Queue.to_list t) ~f\nlet iteri ?how t ~f = List.iteri ?how (Queue.to_list t) ~f\nlet map ?how t ~f = List.map ?how (Queue.to_list t) ~f >>| Queue.of_list\nlet mapi ?how t ~f = List.mapi ?how (Queue.to_list t) ~f >>| Queue.of_list\nlet init ?how n ~f = List.init ?how n ~f >>| Queue.of_list\nlet filter ?how t ~f = List.filter ?how (Queue.to_list t) ~f >>| Queue.of_list\nlet filteri ?how t ~f = List.filteri ?how (Queue.to_list t) ~f >>| Queue.of_list\nlet filter_map ?how t ~f = List.filter_map ?how (Queue.to_list t) ~f >>| Queue.of_list\nlet filter_mapi ?how t ~f = List.filter_mapi ?how (Queue.to_list t) ~f >>| Queue.of_list\n\nlet concat_map ?how t ~f =\n List.concat_map ?how (Queue.to_list t) ~f:(fun x -> f x >>| Queue.to_list)\n >>| Queue.of_list\n;;\n\nlet concat_mapi ?how t ~f =\n List.concat_mapi ?how (Queue.to_list t) ~f:(fun i x -> f i x >>| Queue.to_list)\n >>| Queue.of_list\n;;\n\nlet find_map t ~f = List.find_map (Queue.to_list t) ~f\nlet find_mapi t ~f = List.find_mapi (Queue.to_list t) ~f\nlet find t ~f = List.find (Queue.to_list t) ~f\nlet findi t ~f = List.findi (Queue.to_list t) ~f\nlet for_all t ~f = List.for_all (Queue.to_list t) ~f\nlet for_alli t ~f = List.for_alli (Queue.to_list t) ~f\nlet exists t ~f = List.exists (Queue.to_list t) ~f\nlet existsi t ~f = List.existsi (Queue.to_list t) ~f\n","include Deferred1\nmodule Array = Deferred_array\nmodule List = Deferred_list\nmodule Map = Deferred_map\nmodule Memo = Deferred_memo\nmodule Option = Deferred_option\nmodule Or_error = Deferred_or_error\nmodule Queue = Deferred_queue\nmodule Result = Deferred_result\nmodule Sequence = Deferred_sequence\n","open Core_kernel\ninclude Gc\n\n(** [add_finalizer f x] is like [Gc.finalise f x], except that the finalizer is guaranteed\n to run as an Async job (i.e. without interrupting other Async jobs). Unprotected use\n of [Caml.Gc.finalise] or [Core.Gc.add_finalizer] in Async programs is wrong, because\n the finalizers won't hold the async lock, and thus could interleave arbitrarily with\n async jobs. *)\nlet add_finalizer heap_block f = Scheduler.(add_finalizer (t ())) heap_block f\n\nlet add_finalizer_exn heap_block f = Scheduler.(add_finalizer_exn (t ())) heap_block f\nlet add_finalizer_last heap_block f = Scheduler.(add_finalizer_last (t ())) heap_block f\n\nlet add_finalizer_last_exn heap_block f =\n Scheduler.(add_finalizer_last_exn (t ())) heap_block f\n;;\n\nmodule Alarm = struct\n module Alarm = Gc.Expert.Alarm\n\n type t = Alarm.t [@@deriving sexp_of]\n\n let create f = Scheduler.(create_alarm (t ())) f\n let delete = Alarm.delete\nend\n","# 1 \"src/digestif_bi.ml\"\nopen Bigarray_compat\n\ntype t = (char, int8_unsigned_elt, c_layout) Array1.t\n\nlet create n = Array1.create Char c_layout n\n\nlet length = Array1.dim\n\nlet sub = Array1.sub\n\nlet empty = Array1.create Char c_layout 0\n\nlet get = Array1.get\n\nlet copy t =\n let r = create (length t) in\n Array1.blit t r ;\n r\n\nlet init l f =\n let v = Array1.create Char c_layout l in\n for i = 0 to l - 1 do\n Array1.set v i (f i)\n done ;\n v\n\nexternal unsafe_get_32 : t -> int -> int32 = \"%caml_bigstring_get32u\"\n\nexternal unsafe_get_64 : t -> int -> int64 = \"%caml_bigstring_get64u\"\n\nlet unsafe_get_nat : t -> int -> nativeint =\n fun s i ->\n if Sys.word_size = 32\n then Nativeint.of_int32 @@ unsafe_get_32 s i\n else Int64.to_nativeint @@ unsafe_get_64 s i\n\nexternal unsafe_set_32 : t -> int -> int32 -> unit = \"%caml_bigstring_set32u\"\n\nexternal unsafe_set_64 : t -> int -> int64 -> unit = \"%caml_bigstring_set64u\"\n\nlet unsafe_set_nat : t -> int -> nativeint -> unit =\n fun s i v ->\n if Sys.word_size = 32\n then unsafe_set_32 s i (Nativeint.to_int32 v)\n else unsafe_set_64 s i (Int64.of_nativeint v)\n\nlet to_string v = String.init (length v) (Array1.get v)\n\nlet blit_from_bytes src src_off dst dst_off len =\n for i = 0 to len - 1 do\n Array1.set dst (dst_off + i) (Bytes.get src (src_off + i))\n done\n\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\n\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\n\nexternal swapnat : nativeint -> nativeint = \"%bswap_native\"\n\nlet cpu_to_be32 s i v =\n if Sys.big_endian then unsafe_set_32 s i v else unsafe_set_32 s i (swap32 v)\n\nlet cpu_to_le32 s i v =\n if Sys.big_endian then unsafe_set_32 s i (swap32 v) else unsafe_set_32 s i v\n\nlet cpu_to_be64 s i v =\n if Sys.big_endian then unsafe_set_64 s i v else unsafe_set_64 s i (swap64 v)\n\nlet cpu_to_le64 s i v =\n if Sys.big_endian then unsafe_set_64 s i (swap64 v) else unsafe_set_64 s i v\n\nlet be32_to_cpu s i =\n if Sys.big_endian then unsafe_get_32 s i else swap32 @@ unsafe_get_32 s i\n\nlet le32_to_cpu s i =\n if Sys.big_endian then swap32 @@ unsafe_get_32 s i else unsafe_get_32 s i\n\nlet be64_to_cpu s i =\n if Sys.big_endian then unsafe_get_64 s i else swap64 @@ unsafe_get_64 s i\n\nlet le64_to_cpu s i =\n if Sys.big_endian then swap64 @@ unsafe_get_64 s i else unsafe_get_64 s i\n\nlet benat_to_cpu s i =\n if Sys.big_endian then unsafe_get_nat s i else swapnat @@ unsafe_get_nat s i\n\nlet cpu_to_benat s i v =\n if Sys.big_endian\n then unsafe_set_nat s i v\n else unsafe_set_nat s i (swapnat v)\n","# 1 \"src/digestif_by.ml\"\ninclude Bytes\n\nexternal unsafe_get_32 : t -> int -> int32 = \"%caml_string_get32u\"\n\nexternal unsafe_get_64 : t -> int -> int64 = \"%caml_string_get64u\"\n\nlet unsafe_get_nat : t -> int -> nativeint =\n fun s i ->\n if Sys.word_size = 32\n then Nativeint.of_int32 @@ unsafe_get_32 s i\n else Int64.to_nativeint @@ unsafe_get_64 s i\n\nexternal unsafe_set_32 : t -> int -> int32 -> unit = \"%caml_string_set32u\"\n\nexternal unsafe_set_64 : t -> int -> int64 -> unit = \"%caml_string_set64u\"\n\nlet unsafe_set_nat : t -> int -> nativeint -> unit =\n fun s i v ->\n if Sys.word_size = 32\n then unsafe_set_32 s i (Nativeint.to_int32 v)\n else unsafe_set_64 s i (Int64.of_nativeint v)\n\nlet blit_from_bigstring src src_off dst dst_off len =\n for i = 0 to len - 1 do\n set dst (dst_off + i) src.{src_off + i}\n done\n\nlet rpad a size x =\n let l = length a in\n let b = create size in\n blit a 0 b 0 l ;\n fill b l (size - l) x ;\n b\n\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\n\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\n\nexternal swapnat : nativeint -> nativeint = \"%bswap_native\"\n\nlet cpu_to_be32 s i v =\n if Sys.big_endian then unsafe_set_32 s i v else unsafe_set_32 s i (swap32 v)\n\nlet cpu_to_le32 s i v =\n if Sys.big_endian then unsafe_set_32 s i (swap32 v) else unsafe_set_32 s i v\n\nlet cpu_to_be64 s i v =\n if Sys.big_endian then unsafe_set_64 s i v else unsafe_set_64 s i (swap64 v)\n\nlet cpu_to_le64 s i v =\n if Sys.big_endian then unsafe_set_64 s i (swap64 v) else unsafe_set_64 s i v\n\nlet be32_to_cpu s i =\n if Sys.big_endian then unsafe_get_32 s i else swap32 @@ unsafe_get_32 s i\n\nlet le32_to_cpu s i =\n if Sys.big_endian then swap32 @@ unsafe_get_32 s i else unsafe_get_32 s i\n\nlet be64_to_cpu s i =\n if Sys.big_endian then unsafe_get_64 s i else swap64 @@ unsafe_get_64 s i\n\nlet le64_to_cpu s i =\n if Sys.big_endian then swap64 @@ unsafe_get_64 s i else unsafe_get_64 s i\n\nlet benat_to_cpu s i =\n if Sys.big_endian then unsafe_get_nat s i else swapnat @@ unsafe_get_nat s i\n\nlet cpu_to_benat s i v =\n if Sys.big_endian\n then unsafe_set_nat s i v\n else unsafe_set_nat s i (swapnat v)\n","module Nat = struct\n include Nativeint\n\n let ( lxor ) = Nativeint.logxor\nend\n\nmodule type BUFFER = sig\n type t\n\n val length : t -> int\n\n val sub : t -> int -> int -> t\n\n val copy : t -> t\n\n val benat_to_cpu : t -> int -> nativeint\n\n val cpu_to_benat : t -> int -> nativeint -> unit\nend\n\nlet imin (a : int) (b : int) = if a < b then a else b\n\nmodule Make (B : BUFFER) = struct\n let size_of_long = Sys.word_size / 8\n\n (* XXX(dinosaure): I'm not sure about this code. May be we don't need the\n first loop and the _optimization_ is irrelevant. *)\n let xor_into src src_off dst dst_off n =\n let n = ref n in\n let i = ref 0 in\n while !n >= size_of_long do\n B.cpu_to_benat dst (dst_off + !i)\n Nat.(\n B.benat_to_cpu dst (dst_off + !i)\n lxor B.benat_to_cpu src (src_off + !i)) ;\n n := !n - size_of_long ;\n i := !i + size_of_long\n done ;\n while !n > 0 do\n B.cpu_to_benat dst (dst_off + !i)\n Nat.(\n B.benat_to_cpu src (src_off + !i)\n lxor B.benat_to_cpu dst (dst_off + !i)) ;\n incr i ;\n decr n\n done\n\n let xor_into a b n =\n if n > imin (B.length a) (B.length b)\n then raise (Invalid_argument \"Baijiu.Xor.xor_inrot: buffers to small\")\n else xor_into a 0 b 0 n\n\n let xor a b =\n let l = imin (B.length a) (B.length b) in\n let r = B.copy (B.sub b 0 l) in\n xor_into a r l ;\n r\nend\n\nmodule Bytes = Make (Digestif_by)\nmodule Bigstring = Make (Digestif_bi)\n","# 1 \"src/digestif_conv.ml\"\nlet invalid_arg fmt = Format.ksprintf (fun s -> invalid_arg s) fmt\n\nmodule Make (D : sig\n val digest_size : int\nend) =\nstruct\n let to_hex hash =\n let res = Bytes.create (D.digest_size * 2) in\n let chr x =\n match x with\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 -> Char.chr (48 + x)\n | _ -> Char.chr (97 + (x - 10)) in\n for i = 0 to D.digest_size - 1 do\n let v = Char.code hash.[i] in\n Bytes.unsafe_set res (i * 2) (chr (v lsr 4)) ;\n Bytes.unsafe_set res ((i * 2) + 1) (chr (v land 0x0F))\n done ;\n Bytes.unsafe_to_string res\n\n let code x =\n match x with\n | '0' .. '9' -> Char.code x - Char.code '0'\n | 'A' .. 'F' -> Char.code x - Char.code 'A' + 10\n | 'a' .. 'f' -> Char.code x - Char.code 'a' + 10\n | _ -> invalid_arg \"of_hex: %02X\" (Char.code x)\n\n let decode chr1 chr2 = Char.chr ((code chr1 lsl 4) lor code chr2)\n\n let of_hex hex =\n let offset = ref 0 in\n let rec go have_first idx =\n if !offset + idx >= String.length hex\n then '\\x00'\n else\n match hex.[!offset + idx] with\n | ' ' | '\\t' | '\\r' | '\\n' ->\n incr offset ;\n go have_first idx\n | chr2 when have_first -> chr2\n | chr1 ->\n incr offset ;\n let chr2 = go true idx in\n if chr2 <> '\\x00'\n then decode chr1 chr2\n else invalid_arg \"of_hex: odd number of hex characters\" in\n String.init D.digest_size (go false)\n\n let of_hex_opt hex =\n match of_hex hex with\n | digest -> Some digest\n | exception Invalid_argument _ -> None\n\n let consistent_of_hex str =\n let offset = ref 0 in\n let rec go have_first idx =\n if !offset + idx >= String.length str\n then invalid_arg \"Not enough hex value\"\n else\n match str.[!offset + idx] with\n | ' ' | '\\t' | '\\r' | '\\n' ->\n incr offset ;\n go have_first idx\n | chr2 when have_first -> chr2\n | chr1 ->\n incr offset ;\n let chr2 = go true idx in\n decode chr1 chr2 in\n let res = String.init D.digest_size (go false) in\n let is_wsp = function ' ' | '\\t' | '\\r' | '\\n' -> true | _ -> false in\n while\n D.digest_size + !offset < String.length str\n && is_wsp str.[!offset + (D.digest_size * 2)]\n do\n incr offset\n done ;\n if !offset + D.digest_size = String.length str\n then res\n else\n invalid_arg \"Too much enough bytes (reach: %d, expect: %d)\"\n (!offset + (D.digest_size * 2))\n (String.length str)\n\n let consistent_of_hex_opt hex =\n match consistent_of_hex hex with\n | digest -> Some digest\n | exception Invalid_argument _ -> None\n\n let pp ppf hash =\n for i = 0 to D.digest_size - 1 do\n Format.fprintf ppf \"%02x\" (Char.code hash.[i])\n done\n\n let of_raw_string x =\n if String.length x <> D.digest_size\n then invalid_arg \"invalid hash size\"\n else x\n\n let of_raw_string_opt x =\n match of_raw_string x with\n | digest -> Some digest\n | exception Invalid_argument _ -> None\n\n let to_raw_string x = x\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let lnot = Int32.lognot\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\n\n let ror32 a n = (a lsr n) lor (a lsl (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\nend\n\nmodule type S = sig\n type kind = [ `MD5 ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int32 array }\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `MD5 ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int32 array }\n\n let dup ctx = { size = ctx.size; b = By.copy ctx.b; h = Array.copy ctx.h }\n\n let init () =\n let b = By.make 64 '\\x00' in\n {\n size = 0L;\n b;\n h = [| 0x67452301l; 0xefcdab89l; 0x98badcfel; 0x10325476l |];\n }\n\n let f1 x y z = Int32.(z lxor (x land (y lxor z)))\n\n let f2 x y z = f1 z x y\n\n let f3 x y z = Int32.(x lxor y lxor z)\n\n let f4 x y z = Int32.(y lxor (x lor lnot z))\n\n let md5_do_chunk :\n type a. le32_to_cpu:(a -> int -> int32) -> ctx -> a -> int -> unit =\n fun ~le32_to_cpu ctx buf off ->\n let a, b, c, d =\n (ref ctx.h.(0), ref ctx.h.(1), ref ctx.h.(2), ref ctx.h.(3)) in\n let w = Array.make 16 0l in\n for i = 0 to 15 do\n w.(i) <- le32_to_cpu buf (off + (i * 4))\n done ;\n let round f a b c d i k s =\n let open Int32 in\n a := !a + f !b !c !d + w.(i) + k ;\n a := rol32 !a s ;\n a := !a + !b in\n round f1 a b c d 0 0xd76aa478l 7 ;\n round f1 d a b c 1 0xe8c7b756l 12 ;\n round f1 c d a b 2 0x242070dbl 17 ;\n round f1 b c d a 3 0xc1bdceeel 22 ;\n round f1 a b c d 4 0xf57c0fafl 7 ;\n round f1 d a b c 5 0x4787c62al 12 ;\n round f1 c d a b 6 0xa8304613l 17 ;\n round f1 b c d a 7 0xfd469501l 22 ;\n round f1 a b c d 8 0x698098d8l 7 ;\n round f1 d a b c 9 0x8b44f7afl 12 ;\n round f1 c d a b 10 0xffff5bb1l 17 ;\n round f1 b c d a 11 0x895cd7bel 22 ;\n round f1 a b c d 12 0x6b901122l 7 ;\n round f1 d a b c 13 0xfd987193l 12 ;\n round f1 c d a b 14 0xa679438el 17 ;\n round f1 b c d a 15 0x49b40821l 22 ;\n round f2 a b c d 1 0xf61e2562l 5 ;\n round f2 d a b c 6 0xc040b340l 9 ;\n round f2 c d a b 11 0x265e5a51l 14 ;\n round f2 b c d a 0 0xe9b6c7aal 20 ;\n round f2 a b c d 5 0xd62f105dl 5 ;\n round f2 d a b c 10 0x02441453l 9 ;\n round f2 c d a b 15 0xd8a1e681l 14 ;\n round f2 b c d a 4 0xe7d3fbc8l 20 ;\n round f2 a b c d 9 0x21e1cde6l 5 ;\n round f2 d a b c 14 0xc33707d6l 9 ;\n round f2 c d a b 3 0xf4d50d87l 14 ;\n round f2 b c d a 8 0x455a14edl 20 ;\n round f2 a b c d 13 0xa9e3e905l 5 ;\n round f2 d a b c 2 0xfcefa3f8l 9 ;\n round f2 c d a b 7 0x676f02d9l 14 ;\n round f2 b c d a 12 0x8d2a4c8al 20 ;\n round f3 a b c d 5 0xfffa3942l 4 ;\n round f3 d a b c 8 0x8771f681l 11 ;\n round f3 c d a b 11 0x6d9d6122l 16 ;\n round f3 b c d a 14 0xfde5380cl 23 ;\n round f3 a b c d 1 0xa4beea44l 4 ;\n round f3 d a b c 4 0x4bdecfa9l 11 ;\n round f3 c d a b 7 0xf6bb4b60l 16 ;\n round f3 b c d a 10 0xbebfbc70l 23 ;\n round f3 a b c d 13 0x289b7ec6l 4 ;\n round f3 d a b c 0 0xeaa127fal 11 ;\n round f3 c d a b 3 0xd4ef3085l 16 ;\n round f3 b c d a 6 0x04881d05l 23 ;\n round f3 a b c d 9 0xd9d4d039l 4 ;\n round f3 d a b c 12 0xe6db99e5l 11 ;\n round f3 c d a b 15 0x1fa27cf8l 16 ;\n round f3 b c d a 2 0xc4ac5665l 23 ;\n round f4 a b c d 0 0xf4292244l 6 ;\n round f4 d a b c 7 0x432aff97l 10 ;\n round f4 c d a b 14 0xab9423a7l 15 ;\n round f4 b c d a 5 0xfc93a039l 21 ;\n round f4 a b c d 12 0x655b59c3l 6 ;\n round f4 d a b c 3 0x8f0ccc92l 10 ;\n round f4 c d a b 10 0xffeff47dl 15 ;\n round f4 b c d a 1 0x85845dd1l 21 ;\n round f4 a b c d 8 0x6fa87e4fl 6 ;\n round f4 d a b c 15 0xfe2ce6e0l 10 ;\n round f4 c d a b 6 0xa3014314l 15 ;\n round f4 b c d a 13 0x4e0811a1l 21 ;\n round f4 a b c d 4 0xf7537e82l 6 ;\n round f4 d a b c 11 0xbd3af235l 10 ;\n round f4 c d a b 2 0x2ad7d2bbl 15 ;\n round f4 b c d a 9 0xeb86d391l 21 ;\n let open Int32 in\n ctx.h.(0) <- ctx.h.(0) + !a ;\n ctx.h.(1) <- ctx.h.(1) + !b ;\n ctx.h.(2) <- ctx.h.(2) + !c ;\n ctx.h.(3) <- ctx.h.(3) + !d ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n le32_to_cpu:(a -> int -> int32) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~le32_to_cpu ctx buf off len ->\n let idx = ref Int64.(to_int (ctx.size land 0x3FL)) in\n let len = ref len in\n let off = ref off in\n let to_fill = 64 - !idx in\n ctx.size <- Int64.add ctx.size (Int64.of_int !len) ;\n if !idx <> 0 && !len >= to_fill\n then (\n blit buf !off ctx.b !idx to_fill ;\n md5_do_chunk ~le32_to_cpu:By.le32_to_cpu ctx ctx.b 0 ;\n len := !len - to_fill ;\n off := !off + to_fill ;\n idx := 0) ;\n while !len >= 64 do\n md5_do_chunk ~le32_to_cpu ctx buf !off ;\n len := !len - 64 ;\n off := !off + 64\n done ;\n if !len <> 0 then blit buf !off ctx.b !idx !len ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~le32_to_cpu:By.le32_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~le32_to_cpu:Bi.le32_to_cpu\n\n let unsafe_get ctx =\n let index = Int64.(to_int (ctx.size land 0x3FL)) in\n let padlen = if index < 56 then 56 - index else 64 + 56 - index in\n let padding = By.init padlen (function 0 -> '\\x80' | _ -> '\\x00') in\n let bits = By.create 8 in\n By.cpu_to_le64 bits 0 Int64.(ctx.size lsl 3) ;\n unsafe_feed_bytes ctx padding 0 padlen ;\n unsafe_feed_bytes ctx bits 0 8 ;\n let res = By.create (4 * 4) in\n for i = 0 to 3 do\n By.cpu_to_le32 res (i * 4) ctx.h.(i)\n done ;\n res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `RMD160 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let lnot = Int32.lognot\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\n\n let ror32 a n = (a lsr n) lor (a lsl (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\nend\n\nmodule Unsafe : S = struct\n type kind = [ `RMD160 ]\n\n type ctx = { s : int32 array; mutable n : int; h : int32 array; b : Bytes.t }\n\n let dup ctx =\n { s = Array.copy ctx.s; n = ctx.n; h = Array.copy ctx.h; b = By.copy ctx.b }\n\n let init () =\n let b = By.make 64 '\\x00' in\n {\n s = [| 0l; 0l |];\n n = 0;\n b;\n h = [| 0x67452301l; 0xefcdab89l; 0x98badcfel; 0x10325476l; 0xc3d2e1f0l |];\n }\n\n let f x y z = Int32.(x lxor y lxor z)\n\n let g x y z = Int32.(x land y lor (lnot x land z))\n\n let h x y z = Int32.(x lor lnot y lxor z)\n\n let i x y z = Int32.(x land z lor (y land lnot z))\n\n let j x y z = Int32.(x lxor (y lor lnot z))\n\n let ff a b c d e x s =\n let open Int32 in\n a := !a + f !b !c !d + x ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let gg a b c d e x s =\n let open Int32 in\n a := !a + g !b !c !d + x + 0x5a827999l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let hh a b c d e x s =\n let open Int32 in\n a := !a + h !b !c !d + x + 0x6ed9eba1l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let ii a b c d e x s =\n let open Int32 in\n a := !a + i !b !c !d + x + 0x8f1bbcdcl ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let jj a b c d e x s =\n let open Int32 in\n a := !a + j !b !c !d + x + 0xa953fd4el ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let fff a b c d e x s =\n let open Int32 in\n a := !a + f !b !c !d + x ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let ggg a b c d e x s =\n let open Int32 in\n a := !a + g !b !c !d + x + 0x7a6d76e9l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let hhh a b c d e x s =\n let open Int32 in\n a := !a + h !b !c !d + x + 0x6d703ef3l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let iii a b c d e x s =\n let open Int32 in\n a := !a + i !b !c !d + x + 0x5c4dd124l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let jjj a b c d e x s =\n let open Int32 in\n a := !a + j !b !c !d + x + 0x50a28be6l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let rmd160_do_chunk :\n type a. le32_to_cpu:(a -> int -> int32) -> ctx -> a -> int -> unit =\n fun ~le32_to_cpu ctx buff off ->\n let aa, bb, cc, dd, ee, aaa, bbb, ccc, ddd, eee =\n ( ref ctx.h.(0),\n ref ctx.h.(1),\n ref ctx.h.(2),\n ref ctx.h.(3),\n ref ctx.h.(4),\n ref ctx.h.(0),\n ref ctx.h.(1),\n ref ctx.h.(2),\n ref ctx.h.(3),\n ref ctx.h.(4) ) in\n let w = Array.make 16 0l in\n for i = 0 to 15 do\n w.(i) <- le32_to_cpu buff (off + (i * 4))\n done ;\n ff aa bb cc dd ee w.(0) 11 ;\n ff ee aa bb cc dd w.(1) 14 ;\n ff dd ee aa bb cc w.(2) 15 ;\n ff cc dd ee aa bb w.(3) 12 ;\n ff bb cc dd ee aa w.(4) 5 ;\n ff aa bb cc dd ee w.(5) 8 ;\n ff ee aa bb cc dd w.(6) 7 ;\n ff dd ee aa bb cc w.(7) 9 ;\n ff cc dd ee aa bb w.(8) 11 ;\n ff bb cc dd ee aa w.(9) 13 ;\n ff aa bb cc dd ee w.(10) 14 ;\n ff ee aa bb cc dd w.(11) 15 ;\n ff dd ee aa bb cc w.(12) 6 ;\n ff cc dd ee aa bb w.(13) 7 ;\n ff bb cc dd ee aa w.(14) 9 ;\n ff aa bb cc dd ee w.(15) 8 ;\n gg ee aa bb cc dd w.(7) 7 ;\n gg dd ee aa bb cc w.(4) 6 ;\n gg cc dd ee aa bb w.(13) 8 ;\n gg bb cc dd ee aa w.(1) 13 ;\n gg aa bb cc dd ee w.(10) 11 ;\n gg ee aa bb cc dd w.(6) 9 ;\n gg dd ee aa bb cc w.(15) 7 ;\n gg cc dd ee aa bb w.(3) 15 ;\n gg bb cc dd ee aa w.(12) 7 ;\n gg aa bb cc dd ee w.(0) 12 ;\n gg ee aa bb cc dd w.(9) 15 ;\n gg dd ee aa bb cc w.(5) 9 ;\n gg cc dd ee aa bb w.(2) 11 ;\n gg bb cc dd ee aa w.(14) 7 ;\n gg aa bb cc dd ee w.(11) 13 ;\n gg ee aa bb cc dd w.(8) 12 ;\n hh dd ee aa bb cc w.(3) 11 ;\n hh cc dd ee aa bb w.(10) 13 ;\n hh bb cc dd ee aa w.(14) 6 ;\n hh aa bb cc dd ee w.(4) 7 ;\n hh ee aa bb cc dd w.(9) 14 ;\n hh dd ee aa bb cc w.(15) 9 ;\n hh cc dd ee aa bb w.(8) 13 ;\n hh bb cc dd ee aa w.(1) 15 ;\n hh aa bb cc dd ee w.(2) 14 ;\n hh ee aa bb cc dd w.(7) 8 ;\n hh dd ee aa bb cc w.(0) 13 ;\n hh cc dd ee aa bb w.(6) 6 ;\n hh bb cc dd ee aa w.(13) 5 ;\n hh aa bb cc dd ee w.(11) 12 ;\n hh ee aa bb cc dd w.(5) 7 ;\n hh dd ee aa bb cc w.(12) 5 ;\n ii cc dd ee aa bb w.(1) 11 ;\n ii bb cc dd ee aa w.(9) 12 ;\n ii aa bb cc dd ee w.(11) 14 ;\n ii ee aa bb cc dd w.(10) 15 ;\n ii dd ee aa bb cc w.(0) 14 ;\n ii cc dd ee aa bb w.(8) 15 ;\n ii bb cc dd ee aa w.(12) 9 ;\n ii aa bb cc dd ee w.(4) 8 ;\n ii ee aa bb cc dd w.(13) 9 ;\n ii dd ee aa bb cc w.(3) 14 ;\n ii cc dd ee aa bb w.(7) 5 ;\n ii bb cc dd ee aa w.(15) 6 ;\n ii aa bb cc dd ee w.(14) 8 ;\n ii ee aa bb cc dd w.(5) 6 ;\n ii dd ee aa bb cc w.(6) 5 ;\n ii cc dd ee aa bb w.(2) 12 ;\n jj bb cc dd ee aa w.(4) 9 ;\n jj aa bb cc dd ee w.(0) 15 ;\n jj ee aa bb cc dd w.(5) 5 ;\n jj dd ee aa bb cc w.(9) 11 ;\n jj cc dd ee aa bb w.(7) 6 ;\n jj bb cc dd ee aa w.(12) 8 ;\n jj aa bb cc dd ee w.(2) 13 ;\n jj ee aa bb cc dd w.(10) 12 ;\n jj dd ee aa bb cc w.(14) 5 ;\n jj cc dd ee aa bb w.(1) 12 ;\n jj bb cc dd ee aa w.(3) 13 ;\n jj aa bb cc dd ee w.(8) 14 ;\n jj ee aa bb cc dd w.(11) 11 ;\n jj dd ee aa bb cc w.(6) 8 ;\n jj cc dd ee aa bb w.(15) 5 ;\n jj bb cc dd ee aa w.(13) 6 ;\n jjj aaa bbb ccc ddd eee w.(5) 8 ;\n jjj eee aaa bbb ccc ddd w.(14) 9 ;\n jjj ddd eee aaa bbb ccc w.(7) 9 ;\n jjj ccc ddd eee aaa bbb w.(0) 11 ;\n jjj bbb ccc ddd eee aaa w.(9) 13 ;\n jjj aaa bbb ccc ddd eee w.(2) 15 ;\n jjj eee aaa bbb ccc ddd w.(11) 15 ;\n jjj ddd eee aaa bbb ccc w.(4) 5 ;\n jjj ccc ddd eee aaa bbb w.(13) 7 ;\n jjj bbb ccc ddd eee aaa w.(6) 7 ;\n jjj aaa bbb ccc ddd eee w.(15) 8 ;\n jjj eee aaa bbb ccc ddd w.(8) 11 ;\n jjj ddd eee aaa bbb ccc w.(1) 14 ;\n jjj ccc ddd eee aaa bbb w.(10) 14 ;\n jjj bbb ccc ddd eee aaa w.(3) 12 ;\n jjj aaa bbb ccc ddd eee w.(12) 6 ;\n iii eee aaa bbb ccc ddd w.(6) 9 ;\n iii ddd eee aaa bbb ccc w.(11) 13 ;\n iii ccc ddd eee aaa bbb w.(3) 15 ;\n iii bbb ccc ddd eee aaa w.(7) 7 ;\n iii aaa bbb ccc ddd eee w.(0) 12 ;\n iii eee aaa bbb ccc ddd w.(13) 8 ;\n iii ddd eee aaa bbb ccc w.(5) 9 ;\n iii ccc ddd eee aaa bbb w.(10) 11 ;\n iii bbb ccc ddd eee aaa w.(14) 7 ;\n iii aaa bbb ccc ddd eee w.(15) 7 ;\n iii eee aaa bbb ccc ddd w.(8) 12 ;\n iii ddd eee aaa bbb ccc w.(12) 7 ;\n iii ccc ddd eee aaa bbb w.(4) 6 ;\n iii bbb ccc ddd eee aaa w.(9) 15 ;\n iii aaa bbb ccc ddd eee w.(1) 13 ;\n iii eee aaa bbb ccc ddd w.(2) 11 ;\n hhh ddd eee aaa bbb ccc w.(15) 9 ;\n hhh ccc ddd eee aaa bbb w.(5) 7 ;\n hhh bbb ccc ddd eee aaa w.(1) 15 ;\n hhh aaa bbb ccc ddd eee w.(3) 11 ;\n hhh eee aaa bbb ccc ddd w.(7) 8 ;\n hhh ddd eee aaa bbb ccc w.(14) 6 ;\n hhh ccc ddd eee aaa bbb w.(6) 6 ;\n hhh bbb ccc ddd eee aaa w.(9) 14 ;\n hhh aaa bbb ccc ddd eee w.(11) 12 ;\n hhh eee aaa bbb ccc ddd w.(8) 13 ;\n hhh ddd eee aaa bbb ccc w.(12) 5 ;\n hhh ccc ddd eee aaa bbb w.(2) 14 ;\n hhh bbb ccc ddd eee aaa w.(10) 13 ;\n hhh aaa bbb ccc ddd eee w.(0) 13 ;\n hhh eee aaa bbb ccc ddd w.(4) 7 ;\n hhh ddd eee aaa bbb ccc w.(13) 5 ;\n ggg ccc ddd eee aaa bbb w.(8) 15 ;\n ggg bbb ccc ddd eee aaa w.(6) 5 ;\n ggg aaa bbb ccc ddd eee w.(4) 8 ;\n ggg eee aaa bbb ccc ddd w.(1) 11 ;\n ggg ddd eee aaa bbb ccc w.(3) 14 ;\n ggg ccc ddd eee aaa bbb w.(11) 14 ;\n ggg bbb ccc ddd eee aaa w.(15) 6 ;\n ggg aaa bbb ccc ddd eee w.(0) 14 ;\n ggg eee aaa bbb ccc ddd w.(5) 6 ;\n ggg ddd eee aaa bbb ccc w.(12) 9 ;\n ggg ccc ddd eee aaa bbb w.(2) 12 ;\n ggg bbb ccc ddd eee aaa w.(13) 9 ;\n ggg aaa bbb ccc ddd eee w.(9) 12 ;\n ggg eee aaa bbb ccc ddd w.(7) 5 ;\n ggg ddd eee aaa bbb ccc w.(10) 15 ;\n ggg ccc ddd eee aaa bbb w.(14) 8 ;\n fff bbb ccc ddd eee aaa w.(12) 8 ;\n fff aaa bbb ccc ddd eee w.(15) 5 ;\n fff eee aaa bbb ccc ddd w.(10) 12 ;\n fff ddd eee aaa bbb ccc w.(4) 9 ;\n fff ccc ddd eee aaa bbb w.(1) 12 ;\n fff bbb ccc ddd eee aaa w.(5) 5 ;\n fff aaa bbb ccc ddd eee w.(8) 14 ;\n fff eee aaa bbb ccc ddd w.(7) 6 ;\n fff ddd eee aaa bbb ccc w.(6) 8 ;\n fff ccc ddd eee aaa bbb w.(2) 13 ;\n fff bbb ccc ddd eee aaa w.(13) 6 ;\n fff aaa bbb ccc ddd eee w.(14) 5 ;\n fff eee aaa bbb ccc ddd w.(0) 15 ;\n fff ddd eee aaa bbb ccc w.(3) 13 ;\n fff ccc ddd eee aaa bbb w.(9) 11 ;\n fff bbb ccc ddd eee aaa w.(11) 11 ;\n let open Int32 in\n ddd := !ddd + !cc + ctx.h.(1) ;\n (* final result for h[0]. *)\n ctx.h.(1) <- ctx.h.(2) + !dd + !eee ;\n ctx.h.(2) <- ctx.h.(3) + !ee + !aaa ;\n ctx.h.(3) <- ctx.h.(4) + !aa + !bbb ;\n ctx.h.(4) <- ctx.h.(0) + !bb + !ccc ;\n ctx.h.(0) <- !ddd ;\n ()\n\n exception Leave\n\n let feed :\n type a.\n le32_to_cpu:(a -> int -> int32) ->\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~le32_to_cpu ~blit ctx buf off len ->\n let t = ref ctx.s.(0) in\n let off = ref off in\n let len = ref len in\n ctx.s.(0) <- Int32.add !t (Int32.of_int (!len lsl 3)) ;\n if ctx.s.(0) < !t then ctx.s.(1) <- Int32.(ctx.s.(1) + 1l) ;\n ctx.s.(1) <- Int32.add ctx.s.(1) (Int32.of_int (!len lsr 29)) ;\n try\n if ctx.n <> 0\n then (\n let t = 64 - ctx.n in\n if !len < t\n then (\n blit buf !off ctx.b ctx.n !len ;\n ctx.n <- ctx.n + !len ;\n raise Leave) ;\n blit buf !off ctx.b ctx.n t ;\n rmd160_do_chunk ~le32_to_cpu:By.le32_to_cpu ctx ctx.b 0 ;\n off := !off + t ;\n len := !len - t) ;\n while !len >= 64 do\n rmd160_do_chunk ~le32_to_cpu ctx buf !off ;\n off := !off + 64 ;\n len := !len - 64\n done ;\n blit buf !off ctx.b 0 !len ;\n ctx.n <- !len\n with Leave -> ()\n\n let unsafe_feed_bytes ctx buf off len =\n feed ~blit:By.blit ~le32_to_cpu:By.le32_to_cpu ctx buf off len\n\n let unsafe_feed_bigstring ctx buf off len =\n feed ~blit:By.blit_from_bigstring ~le32_to_cpu:Bi.le32_to_cpu ctx buf off\n len\n\n let unsafe_get ctx =\n let i = ref (ctx.n + 1) in\n let res = By.create (5 * 4) in\n By.set ctx.b ctx.n '\\x80' ;\n if !i > 56\n then (\n By.fill ctx.b !i (64 - !i) '\\x00' ;\n rmd160_do_chunk ~le32_to_cpu:By.le32_to_cpu ctx ctx.b 0 ;\n i := 0) ;\n By.fill ctx.b !i (56 - !i) '\\x00' ;\n By.cpu_to_le32 ctx.b 56 ctx.s.(0) ;\n By.cpu_to_le32 ctx.b 60 ctx.s.(1) ;\n rmd160_do_chunk ~le32_to_cpu:By.le32_to_cpu ctx ctx.b 0 ;\n for i = 0 to 4 do\n By.cpu_to_le32 res (i * 4) ctx.h.(i)\n done ;\n res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\nend\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA1 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA1 ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int32 array }\n\n let dup ctx = { size = ctx.size; b = By.copy ctx.b; h = Array.copy ctx.h }\n\n let init () =\n let b = By.make 64 '\\x00' in\n {\n size = 0L;\n b;\n h = [| 0x67452301l; 0xefcdab89l; 0x98badcfel; 0x10325476l; 0xc3d2e1f0l |];\n }\n\n let f1 x y z = Int32.(z lxor (x land (y lxor z)))\n\n let f2 x y z = Int32.(x lxor y lxor z)\n\n let f3 x y z = Int32.((x land y) + (z land (x lxor y)))\n\n let f4 = f2\n\n let k1 = 0x5a827999l\n\n let k2 = 0x6ed9eba1l\n\n let k3 = 0x8f1bbcdcl\n\n let k4 = 0xca62c1d6l\n\n let sha1_do_chunk :\n type a. be32_to_cpu:(a -> int -> int32) -> ctx -> a -> int -> unit =\n fun ~be32_to_cpu ctx buf off ->\n let a = ref ctx.h.(0) in\n let b = ref ctx.h.(1) in\n let c = ref ctx.h.(2) in\n let d = ref ctx.h.(3) in\n let e = ref ctx.h.(4) in\n let w = Array.make 16 0l in\n let m i =\n let ( && ) a b = a land b in\n let ( -- ) a b = a - b in\n let v =\n Int32.(\n rol32\n (w.(i && 0x0F)\n lxor w.((i -- 14) && 0x0F)\n lxor w.((i -- 8) && 0x0F)\n lxor w.((i -- 3) && 0x0F))\n 1) in\n w.(i land 0x0F) <- v ;\n w.(i land 0x0F) in\n let round a b c d e f k w =\n (e := Int32.(!e + rol32 !a 5 + f !b !c !d + k + w)) ;\n b := Int32.(rol32 !b 30) in\n for i = 0 to 15 do\n w.(i) <- be32_to_cpu buf (off + (i * 4))\n done ;\n round a b c d e f1 k1 w.(0) ;\n round e a b c d f1 k1 w.(1) ;\n round d e a b c f1 k1 w.(2) ;\n round c d e a b f1 k1 w.(3) ;\n round b c d e a f1 k1 w.(4) ;\n round a b c d e f1 k1 w.(5) ;\n round e a b c d f1 k1 w.(6) ;\n round d e a b c f1 k1 w.(7) ;\n round c d e a b f1 k1 w.(8) ;\n round b c d e a f1 k1 w.(9) ;\n round a b c d e f1 k1 w.(10) ;\n round e a b c d f1 k1 w.(11) ;\n round d e a b c f1 k1 w.(12) ;\n round c d e a b f1 k1 w.(13) ;\n round b c d e a f1 k1 w.(14) ;\n round a b c d e f1 k1 w.(15) ;\n round e a b c d f1 k1 (m 16) ;\n round d e a b c f1 k1 (m 17) ;\n round c d e a b f1 k1 (m 18) ;\n round b c d e a f1 k1 (m 19) ;\n round a b c d e f2 k2 (m 20) ;\n round e a b c d f2 k2 (m 21) ;\n round d e a b c f2 k2 (m 22) ;\n round c d e a b f2 k2 (m 23) ;\n round b c d e a f2 k2 (m 24) ;\n round a b c d e f2 k2 (m 25) ;\n round e a b c d f2 k2 (m 26) ;\n round d e a b c f2 k2 (m 27) ;\n round c d e a b f2 k2 (m 28) ;\n round b c d e a f2 k2 (m 29) ;\n round a b c d e f2 k2 (m 30) ;\n round e a b c d f2 k2 (m 31) ;\n round d e a b c f2 k2 (m 32) ;\n round c d e a b f2 k2 (m 33) ;\n round b c d e a f2 k2 (m 34) ;\n round a b c d e f2 k2 (m 35) ;\n round e a b c d f2 k2 (m 36) ;\n round d e a b c f2 k2 (m 37) ;\n round c d e a b f2 k2 (m 38) ;\n round b c d e a f2 k2 (m 39) ;\n round a b c d e f3 k3 (m 40) ;\n round e a b c d f3 k3 (m 41) ;\n round d e a b c f3 k3 (m 42) ;\n round c d e a b f3 k3 (m 43) ;\n round b c d e a f3 k3 (m 44) ;\n round a b c d e f3 k3 (m 45) ;\n round e a b c d f3 k3 (m 46) ;\n round d e a b c f3 k3 (m 47) ;\n round c d e a b f3 k3 (m 48) ;\n round b c d e a f3 k3 (m 49) ;\n round a b c d e f3 k3 (m 50) ;\n round e a b c d f3 k3 (m 51) ;\n round d e a b c f3 k3 (m 52) ;\n round c d e a b f3 k3 (m 53) ;\n round b c d e a f3 k3 (m 54) ;\n round a b c d e f3 k3 (m 55) ;\n round e a b c d f3 k3 (m 56) ;\n round d e a b c f3 k3 (m 57) ;\n round c d e a b f3 k3 (m 58) ;\n round b c d e a f3 k3 (m 59) ;\n round a b c d e f4 k4 (m 60) ;\n round e a b c d f4 k4 (m 61) ;\n round d e a b c f4 k4 (m 62) ;\n round c d e a b f4 k4 (m 63) ;\n round b c d e a f4 k4 (m 64) ;\n round a b c d e f4 k4 (m 65) ;\n round e a b c d f4 k4 (m 66) ;\n round d e a b c f4 k4 (m 67) ;\n round c d e a b f4 k4 (m 68) ;\n round b c d e a f4 k4 (m 69) ;\n round a b c d e f4 k4 (m 70) ;\n round e a b c d f4 k4 (m 71) ;\n round d e a b c f4 k4 (m 72) ;\n round c d e a b f4 k4 (m 73) ;\n round b c d e a f4 k4 (m 74) ;\n round a b c d e f4 k4 (m 75) ;\n round e a b c d f4 k4 (m 76) ;\n round d e a b c f4 k4 (m 77) ;\n round c d e a b f4 k4 (m 78) ;\n round b c d e a f4 k4 (m 79) ;\n ctx.h.(0) <- Int32.add ctx.h.(0) !a ;\n ctx.h.(1) <- Int32.add ctx.h.(1) !b ;\n ctx.h.(2) <- Int32.add ctx.h.(2) !c ;\n ctx.h.(3) <- Int32.add ctx.h.(3) !d ;\n ctx.h.(4) <- Int32.add ctx.h.(4) !e ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n be32_to_cpu:(a -> int -> int32) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~be32_to_cpu ctx buf off len ->\n let idx = ref Int64.(to_int (ctx.size land 0x3FL)) in\n let len = ref len in\n let off = ref off in\n let to_fill = 64 - !idx in\n ctx.size <- Int64.add ctx.size (Int64.of_int !len) ;\n if !idx <> 0 && !len >= to_fill\n then (\n blit buf !off ctx.b !idx to_fill ;\n sha1_do_chunk ~be32_to_cpu:By.be32_to_cpu ctx ctx.b 0 ;\n len := !len - to_fill ;\n off := !off + to_fill ;\n idx := 0) ;\n while !len >= 64 do\n sha1_do_chunk ~be32_to_cpu ctx buf !off ;\n len := !len - 64 ;\n off := !off + 64\n done ;\n if !len <> 0 then blit buf !off ctx.b !idx !len ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~be32_to_cpu:By.be32_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~be32_to_cpu:Bi.be32_to_cpu\n\n let unsafe_get ctx =\n let index = Int64.(to_int (ctx.size land 0x3FL)) in\n let padlen = if index < 56 then 56 - index else 64 + 56 - index in\n let padding = By.init padlen (function 0 -> '\\x80' | _ -> '\\x00') in\n let bits = By.create 8 in\n By.cpu_to_be64 bits 0 Int64.(ctx.size lsl 3) ;\n unsafe_feed_bytes ctx padding 0 padlen ;\n unsafe_feed_bytes ctx bits 0 8 ;\n let res = By.create (5 * 4) in\n for i = 0 to 4 do\n By.cpu_to_be32 res (i * 4) ctx.h.(i)\n done ;\n res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\n\n let ror32 a n = (a lsr n) lor (a lsl (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\nend\n\nmodule type S = sig\n type kind = [ `SHA256 ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int32 array }\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA256 ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int32 array }\n\n let dup ctx = { size = ctx.size; b = By.copy ctx.b; h = Array.copy ctx.h }\n\n let init () =\n let b = By.make 128 '\\x00' in\n {\n size = 0L;\n b;\n h =\n [|\n 0x6a09e667l;\n 0xbb67ae85l;\n 0x3c6ef372l;\n 0xa54ff53al;\n 0x510e527fl;\n 0x9b05688cl;\n 0x1f83d9abl;\n 0x5be0cd19l;\n |];\n }\n\n let k =\n [|\n 0x428a2f98l;\n 0x71374491l;\n 0xb5c0fbcfl;\n 0xe9b5dba5l;\n 0x3956c25bl;\n 0x59f111f1l;\n 0x923f82a4l;\n 0xab1c5ed5l;\n 0xd807aa98l;\n 0x12835b01l;\n 0x243185bel;\n 0x550c7dc3l;\n 0x72be5d74l;\n 0x80deb1fel;\n 0x9bdc06a7l;\n 0xc19bf174l;\n 0xe49b69c1l;\n 0xefbe4786l;\n 0x0fc19dc6l;\n 0x240ca1ccl;\n 0x2de92c6fl;\n 0x4a7484aal;\n 0x5cb0a9dcl;\n 0x76f988dal;\n 0x983e5152l;\n 0xa831c66dl;\n 0xb00327c8l;\n 0xbf597fc7l;\n 0xc6e00bf3l;\n 0xd5a79147l;\n 0x06ca6351l;\n 0x14292967l;\n 0x27b70a85l;\n 0x2e1b2138l;\n 0x4d2c6dfcl;\n 0x53380d13l;\n 0x650a7354l;\n 0x766a0abbl;\n 0x81c2c92el;\n 0x92722c85l;\n 0xa2bfe8a1l;\n 0xa81a664bl;\n 0xc24b8b70l;\n 0xc76c51a3l;\n 0xd192e819l;\n 0xd6990624l;\n 0xf40e3585l;\n 0x106aa070l;\n 0x19a4c116l;\n 0x1e376c08l;\n 0x2748774cl;\n 0x34b0bcb5l;\n 0x391c0cb3l;\n 0x4ed8aa4al;\n 0x5b9cca4fl;\n 0x682e6ff3l;\n 0x748f82eel;\n 0x78a5636fl;\n 0x84c87814l;\n 0x8cc70208l;\n 0x90befffal;\n 0xa4506cebl;\n 0xbef9a3f7l;\n 0xc67178f2l;\n |]\n\n let e0 x = Int32.(ror32 x 2 lxor ror32 x 13 lxor ror32 x 22)\n\n let e1 x = Int32.(ror32 x 6 lxor ror32 x 11 lxor ror32 x 25)\n\n let s0 x = Int32.(ror32 x 7 lxor ror32 x 18 lxor (x lsr 3))\n\n let s1 x = Int32.(ror32 x 17 lxor ror32 x 19 lxor (x lsr 10))\n\n let sha256_do_chunk :\n type a. be32_to_cpu:(a -> int -> int32) -> ctx -> a -> int -> unit =\n fun ~be32_to_cpu ctx buf off ->\n let a, b, c, d, e, f, g, h, t1, t2 =\n ( ref ctx.h.(0),\n ref ctx.h.(1),\n ref ctx.h.(2),\n ref ctx.h.(3),\n ref ctx.h.(4),\n ref ctx.h.(5),\n ref ctx.h.(6),\n ref ctx.h.(7),\n ref 0l,\n ref 0l ) in\n let w = Array.make 64 0l in\n for i = 0 to 15 do\n w.(i) <- be32_to_cpu buf (off + (i * 4))\n done ;\n let ( -- ) a b = a - b in\n for i = 16 to 63 do\n w.(i) <- Int32.(s1 w.(i -- 2) + w.(i -- 7) + s0 w.(i -- 15) + w.(i -- 16))\n done ;\n let round a b c d e f g h k w =\n let open Int32 in\n t1 := !h + e1 !e + (!g lxor (!e land (!f lxor !g))) + k + w ;\n t2 := e0 !a + (!a land !b lor (!c land (!a lor !b))) ;\n d := !d + !t1 ;\n h := !t1 + !t2 in\n for i = 0 to 7 do\n round a b c d e f g h k.((i * 8) + 0) w.((i * 8) + 0) ;\n round h a b c d e f g k.((i * 8) + 1) w.((i * 8) + 1) ;\n round g h a b c d e f k.((i * 8) + 2) w.((i * 8) + 2) ;\n round f g h a b c d e k.((i * 8) + 3) w.((i * 8) + 3) ;\n round e f g h a b c d k.((i * 8) + 4) w.((i * 8) + 4) ;\n round d e f g h a b c k.((i * 8) + 5) w.((i * 8) + 5) ;\n round c d e f g h a b k.((i * 8) + 6) w.((i * 8) + 6) ;\n round b c d e f g h a k.((i * 8) + 7) w.((i * 8) + 7)\n done ;\n let open Int32 in\n ctx.h.(0) <- ctx.h.(0) + !a ;\n ctx.h.(1) <- ctx.h.(1) + !b ;\n ctx.h.(2) <- ctx.h.(2) + !c ;\n ctx.h.(3) <- ctx.h.(3) + !d ;\n ctx.h.(4) <- ctx.h.(4) + !e ;\n ctx.h.(5) <- ctx.h.(5) + !f ;\n ctx.h.(6) <- ctx.h.(6) + !g ;\n ctx.h.(7) <- ctx.h.(7) + !h ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n be32_to_cpu:(a -> int -> int32) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~be32_to_cpu ctx buf off len ->\n let idx = ref Int64.(to_int (ctx.size land 0x3FL)) in\n let len = ref len in\n let off = ref off in\n let to_fill = 64 - !idx in\n ctx.size <- Int64.add ctx.size (Int64.of_int !len) ;\n if !idx <> 0 && !len >= to_fill\n then (\n blit buf !off ctx.b !idx to_fill ;\n sha256_do_chunk ~be32_to_cpu:By.be32_to_cpu ctx ctx.b 0 ;\n len := !len - to_fill ;\n off := !off + to_fill ;\n idx := 0) ;\n while !len >= 64 do\n sha256_do_chunk ~be32_to_cpu ctx buf !off ;\n len := !len - 64 ;\n off := !off + 64\n done ;\n if !len <> 0 then blit buf !off ctx.b !idx !len ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~be32_to_cpu:By.be32_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~be32_to_cpu:Bi.be32_to_cpu\n\n let unsafe_get ctx =\n let index = Int64.(to_int (ctx.size land 0x3FL)) in\n let padlen = if index < 56 then 56 - index else 64 + 56 - index in\n let padding = By.init padlen (function 0 -> '\\x80' | _ -> '\\x00') in\n let bits = By.create 8 in\n By.cpu_to_be64 bits 0 Int64.(ctx.size lsl 3) ;\n unsafe_feed_bytes ctx padding 0 padlen ;\n unsafe_feed_bytes ctx bits 0 8 ;\n let res = By.create (8 * 4) in\n for i = 0 to 7 do\n By.cpu_to_be32 res (i * 4) ctx.h.(i)\n done ;\n res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA224 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA224 ]\n\n open Baijiu_sha256.Unsafe\n\n type nonrec ctx = ctx\n\n let init () =\n let b = By.make 128 '\\x00' in\n {\n size = 0L;\n b;\n h =\n [|\n 0xc1059ed8l;\n 0x367cd507l;\n 0x3070dd17l;\n 0xf70e5939l;\n 0xffc00b31l;\n 0x68581511l;\n 0x64f98fa7l;\n 0xbefa4fa4l;\n |];\n }\n\n let unsafe_get ctx =\n let res = unsafe_get ctx in\n By.sub res 0 28\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int64 = struct\n include Int64\n\n let ( lsl ) = Int64.shift_left\n\n let ( lsr ) = Int64.shift_right_logical\n\n let ( asr ) = Int64.shift_right\n\n let ( lor ) = Int64.logor\n\n let ( land ) = Int64.logand\n\n let ( lxor ) = Int64.logxor\n\n let ( + ) = Int64.add\n\n let ror64 a n = (a lsr n) lor (a lsl (64 - n))\n\n let rol64 a n = (a lsl n) lor (a lsr (64 - n))\nend\n\nmodule Unsafe = struct\n type ctx = {\n q : int64 array;\n rsize : int;\n (* block size *)\n mdlen : int;\n (* output size *)\n mutable pt : int;\n }\n\n let dup ctx =\n { q = Array.copy ctx.q; rsize = ctx.rsize; mdlen = ctx.mdlen; pt = ctx.pt }\n\n let init mdlen =\n let rsize = 200 - (2 * mdlen) in\n { q = Array.make 25 0L; rsize; mdlen; pt = 0 }\n\n let keccakf_rounds = 24\n\n let keccaft_rndc : int64 array =\n [|\n 0x0000000000000001L;\n 0x0000000000008082L;\n 0x800000000000808aL;\n 0x8000000080008000L;\n 0x000000000000808bL;\n 0x0000000080000001L;\n 0x8000000080008081L;\n 0x8000000000008009L;\n 0x000000000000008aL;\n 0x0000000000000088L;\n 0x0000000080008009L;\n 0x000000008000000aL;\n 0x000000008000808bL;\n 0x800000000000008bL;\n 0x8000000000008089L;\n 0x8000000000008003L;\n 0x8000000000008002L;\n 0x8000000000000080L;\n 0x000000000000800aL;\n 0x800000008000000aL;\n 0x8000000080008081L;\n 0x8000000000008080L;\n 0x0000000080000001L;\n 0x8000000080008008L;\n |]\n\n let keccaft_rotc : int array =\n [|\n 1;\n 3;\n 6;\n 10;\n 15;\n 21;\n 28;\n 36;\n 45;\n 55;\n 2;\n 14;\n 27;\n 41;\n 56;\n 8;\n 25;\n 43;\n 62;\n 18;\n 39;\n 61;\n 20;\n 44;\n |]\n\n let keccakf_piln : int array =\n [|\n 10;\n 7;\n 11;\n 17;\n 18;\n 3;\n 5;\n 16;\n 8;\n 21;\n 24;\n 4;\n 15;\n 23;\n 19;\n 13;\n 12;\n 2;\n 20;\n 14;\n 22;\n 9;\n 6;\n 1;\n |]\n\n let swap64 = if Sys.big_endian then By.swap64 else fun x -> x\n\n let sha3_keccakf (q : int64 array) =\n if Sys.big_endian then Array.iteri (fun i sti -> q.(i) <- swap64 sti) q ;\n\n for r = 0 to keccakf_rounds - 1 do\n let ( lxor ) = Int64.( lxor ) in\n let lnot = Int64.lognot in\n let ( land ) = Int64.( land ) in\n (* Theta *)\n let bc =\n Array.init 5 (fun i ->\n q.(i) lxor q.(i + 5) lxor q.(i + 10) lxor q.(i + 15) lxor q.(i + 20))\n in\n for i = 0 to 4 do\n let t = bc.((i + 4) mod 5) lxor Int64.rol64 bc.((i + 1) mod 5) 1 in\n for k = 0 to 4 do\n let j = k * 5 in\n q.(j + i) <- q.(j + i) lxor t\n done\n done ;\n\n (* Rho Pi *)\n let t = ref q.(1) in\n let _ =\n Array.iteri\n (fun i rotc ->\n let j = keccakf_piln.(i) in\n bc.(0) <- q.(j) ;\n q.(j) <- Int64.rol64 !t rotc ;\n t := bc.(0))\n keccaft_rotc in\n\n (* Chi *)\n for k = 0 to 4 do\n let j = k * 5 in\n let bc = Array.init 5 (fun i -> q.(j + i)) in\n for i = 0 to 4 do\n q.(j + i) <-\n q.(j + i) lxor (lnot bc.((i + 1) mod 5) land bc.((i + 2) mod 5))\n done\n done ;\n\n (* Iota *)\n q.(0) <- q.(0) lxor keccaft_rndc.(r)\n done ;\n\n if Sys.big_endian then Array.iteri (fun i sti -> q.(i) <- swap64 sti) q\n\n let masks =\n [|\n 0xffffffffffffff00L;\n 0xffffffffffff00ffL;\n 0xffffffffff00ffffL;\n 0xffffffff00ffffffL;\n 0xffffff00ffffffffL;\n 0xffff00ffffffffffL;\n 0xff00ffffffffffffL;\n 0x00ffffffffffffffL;\n |]\n\n let feed :\n type a. get_uint8:(a -> int -> int) -> ctx -> a -> int -> int -> unit =\n fun ~get_uint8 ctx buf off len ->\n let ( && ) = ( land ) in\n\n let ( lxor ) = Int64.( lxor ) in\n let ( land ) = Int64.( land ) in\n let ( lor ) = Int64.( lor ) in\n let ( lsr ) = Int64.( lsr ) in\n let ( lsl ) = Int64.( lsl ) in\n\n let j = ref ctx.pt in\n\n for i = 0 to len - 1 do\n let v =\n (ctx.q.(!j / 8) land (0xffL lsl ((!j && 0x7) * 8))) lsr ((!j && 0x7) * 8)\n in\n let v = v lxor Int64.of_int (get_uint8 buf (off + i)) in\n ctx.q.(!j / 8) <-\n ctx.q.(!j / 8) land masks.(!j && 0x7) lor (v lsl ((!j && 0x7) * 8)) ;\n incr j ;\n if !j >= ctx.rsize\n then (\n sha3_keccakf ctx.q ;\n j := 0)\n done ;\n\n ctx.pt <- !j\n\n let unsafe_feed_bytes ctx buf off len =\n let get_uint8 buf off = Char.code (By.get buf off) in\n feed ~get_uint8 ctx buf off len\n\n let unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit =\n fun ctx buf off len ->\n let get_uint8 buf off = Char.code (Bi.get buf off) in\n feed ~get_uint8 ctx buf off len\n\n let unsafe_get ctx =\n let ( && ) = ( land ) in\n\n let ( lxor ) = Int64.( lxor ) in\n let ( lsl ) = Int64.( lsl ) in\n\n let v = ctx.q.(ctx.pt / 8) in\n let v = v lxor (0x6L lsl ((ctx.pt && 0x7) * 8)) in\n ctx.q.(ctx.pt / 8) <- v ;\n\n let v = ctx.q.((ctx.rsize - 1) / 8) in\n let v = v lxor (0x80L lsl (((ctx.rsize - 1) && 0x7) * 8)) in\n ctx.q.((ctx.rsize - 1) / 8) <- v ;\n\n sha3_keccakf ctx.q ;\n\n (* Get hash *)\n (* if the hash size in bytes is not a multiple of 8 (meaning it is\n not composed of whole int64 words, like for sha3_224), we\n extract the whole last int64 word from the state [ctx.st] and\n cut the hash at the right size after conversion to bytes. *)\n let n =\n let r = ctx.mdlen mod 8 in\n ctx.mdlen + if r = 0 then 0 else 8 - r in\n\n let hash = By.create n in\n for i = 0 to (n / 8) - 1 do\n By.unsafe_set_64 hash (i * 8) ctx.q.(i)\n done ;\n\n By.sub hash 0 ctx.mdlen\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA3_512 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA3_512 ]\n\n open Baijiu_sha3.Unsafe\n\n type nonrec ctx = ctx\n\n let init () = Baijiu_sha3.Unsafe.init 64\n\n let unsafe_get = unsafe_get\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int64 = struct\n include Int64\n\n let ( lsl ) = Int64.shift_left\n\n let ( lsr ) = Int64.shift_right_logical\n\n let ( asr ) = Int64.shift_right\n\n let ( lor ) = Int64.logor\n\n let ( land ) = Int64.logand\n\n let ( lxor ) = Int64.logxor\n\n let ( + ) = Int64.add\n\n let ror64 a n = (a lsr n) lor (a lsl (64 - n))\n\n let rol64 a n = (a lsl n) lor (a lsr (64 - n))\nend\n\nmodule type S = sig\n type kind = [ `SHA512 ]\n\n type ctx = { mutable size : int64 array; b : Bytes.t; h : int64 array }\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA512 ]\n\n type ctx = { mutable size : int64 array; b : Bytes.t; h : int64 array }\n\n let dup ctx =\n { size = Array.copy ctx.size; b = By.copy ctx.b; h = Array.copy ctx.h }\n\n let init () =\n let b = By.make 128 '\\x00' in\n {\n size = [| 0L; 0L |];\n b;\n h =\n [|\n 0x6a09e667f3bcc908L;\n 0xbb67ae8584caa73bL;\n 0x3c6ef372fe94f82bL;\n 0xa54ff53a5f1d36f1L;\n 0x510e527fade682d1L;\n 0x9b05688c2b3e6c1fL;\n 0x1f83d9abfb41bd6bL;\n 0x5be0cd19137e2179L;\n |];\n }\n\n let k =\n [|\n 0x428a2f98d728ae22L;\n 0x7137449123ef65cdL;\n 0xb5c0fbcfec4d3b2fL;\n 0xe9b5dba58189dbbcL;\n 0x3956c25bf348b538L;\n 0x59f111f1b605d019L;\n 0x923f82a4af194f9bL;\n 0xab1c5ed5da6d8118L;\n 0xd807aa98a3030242L;\n 0x12835b0145706fbeL;\n 0x243185be4ee4b28cL;\n 0x550c7dc3d5ffb4e2L;\n 0x72be5d74f27b896fL;\n 0x80deb1fe3b1696b1L;\n 0x9bdc06a725c71235L;\n 0xc19bf174cf692694L;\n 0xe49b69c19ef14ad2L;\n 0xefbe4786384f25e3L;\n 0x0fc19dc68b8cd5b5L;\n 0x240ca1cc77ac9c65L;\n 0x2de92c6f592b0275L;\n 0x4a7484aa6ea6e483L;\n 0x5cb0a9dcbd41fbd4L;\n 0x76f988da831153b5L;\n 0x983e5152ee66dfabL;\n 0xa831c66d2db43210L;\n 0xb00327c898fb213fL;\n 0xbf597fc7beef0ee4L;\n 0xc6e00bf33da88fc2L;\n 0xd5a79147930aa725L;\n 0x06ca6351e003826fL;\n 0x142929670a0e6e70L;\n 0x27b70a8546d22ffcL;\n 0x2e1b21385c26c926L;\n 0x4d2c6dfc5ac42aedL;\n 0x53380d139d95b3dfL;\n 0x650a73548baf63deL;\n 0x766a0abb3c77b2a8L;\n 0x81c2c92e47edaee6L;\n 0x92722c851482353bL;\n 0xa2bfe8a14cf10364L;\n 0xa81a664bbc423001L;\n 0xc24b8b70d0f89791L;\n 0xc76c51a30654be30L;\n 0xd192e819d6ef5218L;\n 0xd69906245565a910L;\n 0xf40e35855771202aL;\n 0x106aa07032bbd1b8L;\n 0x19a4c116b8d2d0c8L;\n 0x1e376c085141ab53L;\n 0x2748774cdf8eeb99L;\n 0x34b0bcb5e19b48a8L;\n 0x391c0cb3c5c95a63L;\n 0x4ed8aa4ae3418acbL;\n 0x5b9cca4f7763e373L;\n 0x682e6ff3d6b2b8a3L;\n 0x748f82ee5defb2fcL;\n 0x78a5636f43172f60L;\n 0x84c87814a1f0ab72L;\n 0x8cc702081a6439ecL;\n 0x90befffa23631e28L;\n 0xa4506cebde82bde9L;\n 0xbef9a3f7b2c67915L;\n 0xc67178f2e372532bL;\n 0xca273eceea26619cL;\n 0xd186b8c721c0c207L;\n 0xeada7dd6cde0eb1eL;\n 0xf57d4f7fee6ed178L;\n 0x06f067aa72176fbaL;\n 0x0a637dc5a2c898a6L;\n 0x113f9804bef90daeL;\n 0x1b710b35131c471bL;\n 0x28db77f523047d84L;\n 0x32caab7b40c72493L;\n 0x3c9ebe0a15c9bebcL;\n 0x431d67c49c100d4cL;\n 0x4cc5d4becb3e42b6L;\n 0x597f299cfc657e2aL;\n 0x5fcb6fab3ad6faecL;\n 0x6c44198c4a475817L;\n |]\n\n let e0 x = Int64.(ror64 x 28 lxor ror64 x 34 lxor ror64 x 39)\n\n let e1 x = Int64.(ror64 x 14 lxor ror64 x 18 lxor ror64 x 41)\n\n let s0 x = Int64.(ror64 x 1 lxor ror64 x 8 lxor (x lsr 7))\n\n let s1 x = Int64.(ror64 x 19 lxor ror64 x 61 lxor (x lsr 6))\n\n let sha512_do_chunk :\n type a. be64_to_cpu:(a -> int -> int64) -> ctx -> a -> int -> unit =\n fun ~be64_to_cpu ctx buf off ->\n let a, b, c, d, e, f, g, h, t1, t2 =\n ( ref ctx.h.(0),\n ref ctx.h.(1),\n ref ctx.h.(2),\n ref ctx.h.(3),\n ref ctx.h.(4),\n ref ctx.h.(5),\n ref ctx.h.(6),\n ref ctx.h.(7),\n ref 0L,\n ref 0L ) in\n let w = Array.make 80 0L in\n for i = 0 to 15 do\n w.(i) <- be64_to_cpu buf (off + (i * 8))\n done ;\n let ( -- ) a b = a - b in\n for i = 16 to 79 do\n w.(i) <- Int64.(s1 w.(i -- 2) + w.(i -- 7) + s0 w.(i -- 15) + w.(i -- 16))\n done ;\n let round a b c d e f g h k w =\n let open Int64 in\n t1 := !h + e1 !e + (!g lxor (!e land (!f lxor !g))) + k + w ;\n t2 := e0 !a + (!a land !b lor (!c land (!a lor !b))) ;\n d := !d + !t1 ;\n h := !t1 + !t2 in\n for i = 0 to 9 do\n round a b c d e f g h k.((i * 8) + 0) w.((i * 8) + 0) ;\n round h a b c d e f g k.((i * 8) + 1) w.((i * 8) + 1) ;\n round g h a b c d e f k.((i * 8) + 2) w.((i * 8) + 2) ;\n round f g h a b c d e k.((i * 8) + 3) w.((i * 8) + 3) ;\n round e f g h a b c d k.((i * 8) + 4) w.((i * 8) + 4) ;\n round d e f g h a b c k.((i * 8) + 5) w.((i * 8) + 5) ;\n round c d e f g h a b k.((i * 8) + 6) w.((i * 8) + 6) ;\n round b c d e f g h a k.((i * 8) + 7) w.((i * 8) + 7)\n done ;\n let open Int64 in\n ctx.h.(0) <- ctx.h.(0) + !a ;\n ctx.h.(1) <- ctx.h.(1) + !b ;\n ctx.h.(2) <- ctx.h.(2) + !c ;\n ctx.h.(3) <- ctx.h.(3) + !d ;\n ctx.h.(4) <- ctx.h.(4) + !e ;\n ctx.h.(5) <- ctx.h.(5) + !f ;\n ctx.h.(6) <- ctx.h.(6) + !g ;\n ctx.h.(7) <- ctx.h.(7) + !h ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n be64_to_cpu:(a -> int -> int64) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~be64_to_cpu ctx buf off len ->\n let idx = ref Int64.(to_int (ctx.size.(0) land 0x7FL)) in\n let len = ref len in\n let off = ref off in\n let to_fill = 128 - !idx in\n ctx.size.(0) <- Int64.add ctx.size.(0) (Int64.of_int !len) ;\n if ctx.size.(0) < Int64.of_int !len\n then ctx.size.(1) <- Int64.succ ctx.size.(1) ;\n if !idx <> 0 && !len >= to_fill\n then (\n blit buf !off ctx.b !idx to_fill ;\n sha512_do_chunk ~be64_to_cpu:By.be64_to_cpu ctx ctx.b 0 ;\n len := !len - to_fill ;\n off := !off + to_fill ;\n idx := 0) ;\n while !len >= 128 do\n sha512_do_chunk ~be64_to_cpu ctx buf !off ;\n len := !len - 128 ;\n off := !off + 128\n done ;\n if !len <> 0 then blit buf !off ctx.b !idx !len ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~be64_to_cpu:By.be64_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~be64_to_cpu:Bi.be64_to_cpu\n\n let unsafe_get ctx =\n let index = Int64.(to_int (ctx.size.(0) land 0x7FL)) in\n let padlen = if index < 112 then 112 - index else 128 + 112 - index in\n let padding = By.init padlen (function 0 -> '\\x80' | _ -> '\\x00') in\n let bits = By.create 16 in\n By.cpu_to_be64 bits 0 Int64.((ctx.size.(1) lsl 3) lor (ctx.size.(0) lsr 61)) ;\n By.cpu_to_be64 bits 8 Int64.(ctx.size.(0) lsl 3) ;\n unsafe_feed_bytes ctx padding 0 padlen ;\n unsafe_feed_bytes ctx bits 0 16 ;\n let res = By.create (8 * 8) in\n for i = 0 to 7 do\n By.cpu_to_be64 res (i * 8) ctx.h.(i)\n done ;\n res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA384 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA384 ]\n\n open Baijiu_sha512.Unsafe\n\n type nonrec ctx = ctx\n\n let init () =\n let b = By.make 128 '\\x00' in\n {\n size = [| 0L; 0L |];\n b;\n h =\n [|\n 0xcbbb9d5dc1059ed8L;\n 0x629a292a367cd507L;\n 0x9159015a3070dd17L;\n 0x152fecd8f70e5939L;\n 0x67332667ffc00b31L;\n 0x8eb44a8768581511L;\n 0xdb0c2e0d64f98fa7L;\n 0x47b5481dbefa4fa4L;\n |];\n }\n\n let unsafe_get ctx =\n let res = unsafe_get ctx in\n By.sub res 0 48\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA3_224 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA3_224 ]\n\n open Baijiu_sha3.Unsafe\n\n type nonrec ctx = ctx\n\n let init () = Baijiu_sha3.Unsafe.init 28\n\n let unsafe_get = unsafe_get\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA3_256 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA3_256 ]\n\n open Baijiu_sha3.Unsafe\n\n type nonrec ctx = ctx\n\n let init () = Baijiu_sha3.Unsafe.init 32\n\n let unsafe_get = unsafe_get\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA3_384 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA3_384 ]\n\n open Baijiu_sha3.Unsafe\n\n type nonrec ctx = ctx\n\n let init () = Baijiu_sha3.Unsafe.init 48\n\n let unsafe_get = unsafe_get\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int64 = struct\n include Int64\n\n let ( lsl ) = Int64.shift_left\n\n let ( lsr ) = Int64.shift_right_logical\n\n let ( asr ) = Int64.shift_right\n\n let ( lor ) = Int64.logor\n\n let ( land ) = Int64.logand\n\n let ( lxor ) = Int64.logxor\n\n let ( + ) = Int64.add\n\n let ror64 a n = (a lsr n) lor (a lsl (64 - n))\n\n let rol64 a n = (a lsl n) lor (a lsr (64 - n))\nend\n\nmodule type S = sig\n type kind = [ `WHIRLPOOL ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int64 array }\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `WHIRLPOOL ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int64 array }\n\n let dup ctx = { size = ctx.size; b = By.copy ctx.b; h = Array.copy ctx.h }\n\n let init () =\n let b = By.make 64 '\\x00' in\n { size = 0L; b; h = Array.make 8 Int64.zero }\n\n let k =\n [|\n [|\n 0x18186018c07830d8L;\n 0x23238c2305af4626L;\n 0xc6c63fc67ef991b8L;\n 0xe8e887e8136fcdfbL;\n 0x878726874ca113cbL;\n 0xb8b8dab8a9626d11L;\n 0x0101040108050209L;\n 0x4f4f214f426e9e0dL;\n 0x3636d836adee6c9bL;\n 0xa6a6a2a6590451ffL;\n 0xd2d26fd2debdb90cL;\n 0xf5f5f3f5fb06f70eL;\n 0x7979f979ef80f296L;\n 0x6f6fa16f5fcede30L;\n 0x91917e91fcef3f6dL;\n 0x52525552aa07a4f8L;\n 0x60609d6027fdc047L;\n 0xbcbccabc89766535L;\n 0x9b9b569baccd2b37L;\n 0x8e8e028e048c018aL;\n 0xa3a3b6a371155bd2L;\n 0x0c0c300c603c186cL;\n 0x7b7bf17bff8af684L;\n 0x3535d435b5e16a80L;\n 0x1d1d741de8693af5L;\n 0xe0e0a7e05347ddb3L;\n 0xd7d77bd7f6acb321L;\n 0xc2c22fc25eed999cL;\n 0x2e2eb82e6d965c43L;\n 0x4b4b314b627a9629L;\n 0xfefedffea321e15dL;\n 0x575741578216aed5L;\n 0x15155415a8412abdL;\n 0x7777c1779fb6eee8L;\n 0x3737dc37a5eb6e92L;\n 0xe5e5b3e57b56d79eL;\n 0x9f9f469f8cd92313L;\n 0xf0f0e7f0d317fd23L;\n 0x4a4a354a6a7f9420L;\n 0xdada4fda9e95a944L;\n 0x58587d58fa25b0a2L;\n 0xc9c903c906ca8fcfL;\n 0x2929a429558d527cL;\n 0x0a0a280a5022145aL;\n 0xb1b1feb1e14f7f50L;\n 0xa0a0baa0691a5dc9L;\n 0x6b6bb16b7fdad614L;\n 0x85852e855cab17d9L;\n 0xbdbdcebd8173673cL;\n 0x5d5d695dd234ba8fL;\n 0x1010401080502090L;\n 0xf4f4f7f4f303f507L;\n 0xcbcb0bcb16c08bddL;\n 0x3e3ef83eedc67cd3L;\n 0x0505140528110a2dL;\n 0x676781671fe6ce78L;\n 0xe4e4b7e47353d597L;\n 0x27279c2725bb4e02L;\n 0x4141194132588273L;\n 0x8b8b168b2c9d0ba7L;\n 0xa7a7a6a7510153f6L;\n 0x7d7de97dcf94fab2L;\n 0x95956e95dcfb3749L;\n 0xd8d847d88e9fad56L;\n 0xfbfbcbfb8b30eb70L;\n 0xeeee9fee2371c1cdL;\n 0x7c7ced7cc791f8bbL;\n 0x6666856617e3cc71L;\n 0xdddd53dda68ea77bL;\n 0x17175c17b84b2eafL;\n 0x4747014702468e45L;\n 0x9e9e429e84dc211aL;\n 0xcaca0fca1ec589d4L;\n 0x2d2db42d75995a58L;\n 0xbfbfc6bf9179632eL;\n 0x07071c07381b0e3fL;\n 0xadad8ead012347acL;\n 0x5a5a755aea2fb4b0L;\n 0x838336836cb51befL;\n 0x3333cc3385ff66b6L;\n 0x636391633ff2c65cL;\n 0x02020802100a0412L;\n 0xaaaa92aa39384993L;\n 0x7171d971afa8e2deL;\n 0xc8c807c80ecf8dc6L;\n 0x19196419c87d32d1L;\n 0x494939497270923bL;\n 0xd9d943d9869aaf5fL;\n 0xf2f2eff2c31df931L;\n 0xe3e3abe34b48dba8L;\n 0x5b5b715be22ab6b9L;\n 0x88881a8834920dbcL;\n 0x9a9a529aa4c8293eL;\n 0x262698262dbe4c0bL;\n 0x3232c8328dfa64bfL;\n 0xb0b0fab0e94a7d59L;\n 0xe9e983e91b6acff2L;\n 0x0f0f3c0f78331e77L;\n 0xd5d573d5e6a6b733L;\n 0x80803a8074ba1df4L;\n 0xbebec2be997c6127L;\n 0xcdcd13cd26de87ebL;\n 0x3434d034bde46889L;\n 0x48483d487a759032L;\n 0xffffdbffab24e354L;\n 0x7a7af57af78ff48dL;\n 0x90907a90f4ea3d64L;\n 0x5f5f615fc23ebe9dL;\n 0x202080201da0403dL;\n 0x6868bd6867d5d00fL;\n 0x1a1a681ad07234caL;\n 0xaeae82ae192c41b7L;\n 0xb4b4eab4c95e757dL;\n 0x54544d549a19a8ceL;\n 0x93937693ece53b7fL;\n 0x222288220daa442fL;\n 0x64648d6407e9c863L;\n 0xf1f1e3f1db12ff2aL;\n 0x7373d173bfa2e6ccL;\n 0x12124812905a2482L;\n 0x40401d403a5d807aL;\n 0x0808200840281048L;\n 0xc3c32bc356e89b95L;\n 0xecec97ec337bc5dfL;\n 0xdbdb4bdb9690ab4dL;\n 0xa1a1bea1611f5fc0L;\n 0x8d8d0e8d1c830791L;\n 0x3d3df43df5c97ac8L;\n 0x97976697ccf1335bL;\n 0x0000000000000000L;\n 0xcfcf1bcf36d483f9L;\n 0x2b2bac2b4587566eL;\n 0x7676c57697b3ece1L;\n 0x8282328264b019e6L;\n 0xd6d67fd6fea9b128L;\n 0x1b1b6c1bd87736c3L;\n 0xb5b5eeb5c15b7774L;\n 0xafaf86af112943beL;\n 0x6a6ab56a77dfd41dL;\n 0x50505d50ba0da0eaL;\n 0x45450945124c8a57L;\n 0xf3f3ebf3cb18fb38L;\n 0x3030c0309df060adL;\n 0xefef9bef2b74c3c4L;\n 0x3f3ffc3fe5c37edaL;\n 0x55554955921caac7L;\n 0xa2a2b2a2791059dbL;\n 0xeaea8fea0365c9e9L;\n 0x656589650fecca6aL;\n 0xbabad2bab9686903L;\n 0x2f2fbc2f65935e4aL;\n 0xc0c027c04ee79d8eL;\n 0xdede5fdebe81a160L;\n 0x1c1c701ce06c38fcL;\n 0xfdfdd3fdbb2ee746L;\n 0x4d4d294d52649a1fL;\n 0x92927292e4e03976L;\n 0x7575c9758fbceafaL;\n 0x06061806301e0c36L;\n 0x8a8a128a249809aeL;\n 0xb2b2f2b2f940794bL;\n 0xe6e6bfe66359d185L;\n 0x0e0e380e70361c7eL;\n 0x1f1f7c1ff8633ee7L;\n 0x6262956237f7c455L;\n 0xd4d477d4eea3b53aL;\n 0xa8a89aa829324d81L;\n 0x96966296c4f43152L;\n 0xf9f9c3f99b3aef62L;\n 0xc5c533c566f697a3L;\n 0x2525942535b14a10L;\n 0x59597959f220b2abL;\n 0x84842a8454ae15d0L;\n 0x7272d572b7a7e4c5L;\n 0x3939e439d5dd72ecL;\n 0x4c4c2d4c5a619816L;\n 0x5e5e655eca3bbc94L;\n 0x7878fd78e785f09fL;\n 0x3838e038ddd870e5L;\n 0x8c8c0a8c14860598L;\n 0xd1d163d1c6b2bf17L;\n 0xa5a5aea5410b57e4L;\n 0xe2e2afe2434dd9a1L;\n 0x616199612ff8c24eL;\n 0xb3b3f6b3f1457b42L;\n 0x2121842115a54234L;\n 0x9c9c4a9c94d62508L;\n 0x1e1e781ef0663ceeL;\n 0x4343114322528661L;\n 0xc7c73bc776fc93b1L;\n 0xfcfcd7fcb32be54fL;\n 0x0404100420140824L;\n 0x51515951b208a2e3L;\n 0x99995e99bcc72f25L;\n 0x6d6da96d4fc4da22L;\n 0x0d0d340d68391a65L;\n 0xfafacffa8335e979L;\n 0xdfdf5bdfb684a369L;\n 0x7e7ee57ed79bfca9L;\n 0x242490243db44819L;\n 0x3b3bec3bc5d776feL;\n 0xabab96ab313d4b9aL;\n 0xcece1fce3ed181f0L;\n 0x1111441188552299L;\n 0x8f8f068f0c890383L;\n 0x4e4e254e4a6b9c04L;\n 0xb7b7e6b7d1517366L;\n 0xebeb8beb0b60cbe0L;\n 0x3c3cf03cfdcc78c1L;\n 0x81813e817cbf1ffdL;\n 0x94946a94d4fe3540L;\n 0xf7f7fbf7eb0cf31cL;\n 0xb9b9deb9a1676f18L;\n 0x13134c13985f268bL;\n 0x2c2cb02c7d9c5851L;\n 0xd3d36bd3d6b8bb05L;\n 0xe7e7bbe76b5cd38cL;\n 0x6e6ea56e57cbdc39L;\n 0xc4c437c46ef395aaL;\n 0x03030c03180f061bL;\n 0x565645568a13acdcL;\n 0x44440d441a49885eL;\n 0x7f7fe17fdf9efea0L;\n 0xa9a99ea921374f88L;\n 0x2a2aa82a4d825467L;\n 0xbbbbd6bbb16d6b0aL;\n 0xc1c123c146e29f87L;\n 0x53535153a202a6f1L;\n 0xdcdc57dcae8ba572L;\n 0x0b0b2c0b58271653L;\n 0x9d9d4e9d9cd32701L;\n 0x6c6cad6c47c1d82bL;\n 0x3131c43195f562a4L;\n 0x7474cd7487b9e8f3L;\n 0xf6f6fff6e309f115L;\n 0x464605460a438c4cL;\n 0xacac8aac092645a5L;\n 0x89891e893c970fb5L;\n 0x14145014a04428b4L;\n 0xe1e1a3e15b42dfbaL;\n 0x16165816b04e2ca6L;\n 0x3a3ae83acdd274f7L;\n 0x6969b9696fd0d206L;\n 0x09092409482d1241L;\n 0x7070dd70a7ade0d7L;\n 0xb6b6e2b6d954716fL;\n 0xd0d067d0ceb7bd1eL;\n 0xeded93ed3b7ec7d6L;\n 0xcccc17cc2edb85e2L;\n 0x424215422a578468L;\n 0x98985a98b4c22d2cL;\n 0xa4a4aaa4490e55edL;\n 0x2828a0285d885075L;\n 0x5c5c6d5cda31b886L;\n 0xf8f8c7f8933fed6bL;\n 0x8686228644a411c2L;\n |];\n [|\n 0xd818186018c07830L;\n 0x2623238c2305af46L;\n 0xb8c6c63fc67ef991L;\n 0xfbe8e887e8136fcdL;\n 0xcb878726874ca113L;\n 0x11b8b8dab8a9626dL;\n 0x0901010401080502L;\n 0x0d4f4f214f426e9eL;\n 0x9b3636d836adee6cL;\n 0xffa6a6a2a6590451L;\n 0x0cd2d26fd2debdb9L;\n 0x0ef5f5f3f5fb06f7L;\n 0x967979f979ef80f2L;\n 0x306f6fa16f5fcedeL;\n 0x6d91917e91fcef3fL;\n 0xf852525552aa07a4L;\n 0x4760609d6027fdc0L;\n 0x35bcbccabc897665L;\n 0x379b9b569baccd2bL;\n 0x8a8e8e028e048c01L;\n 0xd2a3a3b6a371155bL;\n 0x6c0c0c300c603c18L;\n 0x847b7bf17bff8af6L;\n 0x803535d435b5e16aL;\n 0xf51d1d741de8693aL;\n 0xb3e0e0a7e05347ddL;\n 0x21d7d77bd7f6acb3L;\n 0x9cc2c22fc25eed99L;\n 0x432e2eb82e6d965cL;\n 0x294b4b314b627a96L;\n 0x5dfefedffea321e1L;\n 0xd5575741578216aeL;\n 0xbd15155415a8412aL;\n 0xe87777c1779fb6eeL;\n 0x923737dc37a5eb6eL;\n 0x9ee5e5b3e57b56d7L;\n 0x139f9f469f8cd923L;\n 0x23f0f0e7f0d317fdL;\n 0x204a4a354a6a7f94L;\n 0x44dada4fda9e95a9L;\n 0xa258587d58fa25b0L;\n 0xcfc9c903c906ca8fL;\n 0x7c2929a429558d52L;\n 0x5a0a0a280a502214L;\n 0x50b1b1feb1e14f7fL;\n 0xc9a0a0baa0691a5dL;\n 0x146b6bb16b7fdad6L;\n 0xd985852e855cab17L;\n 0x3cbdbdcebd817367L;\n 0x8f5d5d695dd234baL;\n 0x9010104010805020L;\n 0x07f4f4f7f4f303f5L;\n 0xddcbcb0bcb16c08bL;\n 0xd33e3ef83eedc67cL;\n 0x2d0505140528110aL;\n 0x78676781671fe6ceL;\n 0x97e4e4b7e47353d5L;\n 0x0227279c2725bb4eL;\n 0x7341411941325882L;\n 0xa78b8b168b2c9d0bL;\n 0xf6a7a7a6a7510153L;\n 0xb27d7de97dcf94faL;\n 0x4995956e95dcfb37L;\n 0x56d8d847d88e9fadL;\n 0x70fbfbcbfb8b30ebL;\n 0xcdeeee9fee2371c1L;\n 0xbb7c7ced7cc791f8L;\n 0x716666856617e3ccL;\n 0x7bdddd53dda68ea7L;\n 0xaf17175c17b84b2eL;\n 0x454747014702468eL;\n 0x1a9e9e429e84dc21L;\n 0xd4caca0fca1ec589L;\n 0x582d2db42d75995aL;\n 0x2ebfbfc6bf917963L;\n 0x3f07071c07381b0eL;\n 0xacadad8ead012347L;\n 0xb05a5a755aea2fb4L;\n 0xef838336836cb51bL;\n 0xb63333cc3385ff66L;\n 0x5c636391633ff2c6L;\n 0x1202020802100a04L;\n 0x93aaaa92aa393849L;\n 0xde7171d971afa8e2L;\n 0xc6c8c807c80ecf8dL;\n 0xd119196419c87d32L;\n 0x3b49493949727092L;\n 0x5fd9d943d9869aafL;\n 0x31f2f2eff2c31df9L;\n 0xa8e3e3abe34b48dbL;\n 0xb95b5b715be22ab6L;\n 0xbc88881a8834920dL;\n 0x3e9a9a529aa4c829L;\n 0x0b262698262dbe4cL;\n 0xbf3232c8328dfa64L;\n 0x59b0b0fab0e94a7dL;\n 0xf2e9e983e91b6acfL;\n 0x770f0f3c0f78331eL;\n 0x33d5d573d5e6a6b7L;\n 0xf480803a8074ba1dL;\n 0x27bebec2be997c61L;\n 0xebcdcd13cd26de87L;\n 0x893434d034bde468L;\n 0x3248483d487a7590L;\n 0x54ffffdbffab24e3L;\n 0x8d7a7af57af78ff4L;\n 0x6490907a90f4ea3dL;\n 0x9d5f5f615fc23ebeL;\n 0x3d202080201da040L;\n 0x0f6868bd6867d5d0L;\n 0xca1a1a681ad07234L;\n 0xb7aeae82ae192c41L;\n 0x7db4b4eab4c95e75L;\n 0xce54544d549a19a8L;\n 0x7f93937693ece53bL;\n 0x2f222288220daa44L;\n 0x6364648d6407e9c8L;\n 0x2af1f1e3f1db12ffL;\n 0xcc7373d173bfa2e6L;\n 0x8212124812905a24L;\n 0x7a40401d403a5d80L;\n 0x4808082008402810L;\n 0x95c3c32bc356e89bL;\n 0xdfecec97ec337bc5L;\n 0x4ddbdb4bdb9690abL;\n 0xc0a1a1bea1611f5fL;\n 0x918d8d0e8d1c8307L;\n 0xc83d3df43df5c97aL;\n 0x5b97976697ccf133L;\n 0x0000000000000000L;\n 0xf9cfcf1bcf36d483L;\n 0x6e2b2bac2b458756L;\n 0xe17676c57697b3ecL;\n 0xe68282328264b019L;\n 0x28d6d67fd6fea9b1L;\n 0xc31b1b6c1bd87736L;\n 0x74b5b5eeb5c15b77L;\n 0xbeafaf86af112943L;\n 0x1d6a6ab56a77dfd4L;\n 0xea50505d50ba0da0L;\n 0x5745450945124c8aL;\n 0x38f3f3ebf3cb18fbL;\n 0xad3030c0309df060L;\n 0xc4efef9bef2b74c3L;\n 0xda3f3ffc3fe5c37eL;\n 0xc755554955921caaL;\n 0xdba2a2b2a2791059L;\n 0xe9eaea8fea0365c9L;\n 0x6a656589650feccaL;\n 0x03babad2bab96869L;\n 0x4a2f2fbc2f65935eL;\n 0x8ec0c027c04ee79dL;\n 0x60dede5fdebe81a1L;\n 0xfc1c1c701ce06c38L;\n 0x46fdfdd3fdbb2ee7L;\n 0x1f4d4d294d52649aL;\n 0x7692927292e4e039L;\n 0xfa7575c9758fbceaL;\n 0x3606061806301e0cL;\n 0xae8a8a128a249809L;\n 0x4bb2b2f2b2f94079L;\n 0x85e6e6bfe66359d1L;\n 0x7e0e0e380e70361cL;\n 0xe71f1f7c1ff8633eL;\n 0x556262956237f7c4L;\n 0x3ad4d477d4eea3b5L;\n 0x81a8a89aa829324dL;\n 0x5296966296c4f431L;\n 0x62f9f9c3f99b3aefL;\n 0xa3c5c533c566f697L;\n 0x102525942535b14aL;\n 0xab59597959f220b2L;\n 0xd084842a8454ae15L;\n 0xc57272d572b7a7e4L;\n 0xec3939e439d5dd72L;\n 0x164c4c2d4c5a6198L;\n 0x945e5e655eca3bbcL;\n 0x9f7878fd78e785f0L;\n 0xe53838e038ddd870L;\n 0x988c8c0a8c148605L;\n 0x17d1d163d1c6b2bfL;\n 0xe4a5a5aea5410b57L;\n 0xa1e2e2afe2434dd9L;\n 0x4e616199612ff8c2L;\n 0x42b3b3f6b3f1457bL;\n 0x342121842115a542L;\n 0x089c9c4a9c94d625L;\n 0xee1e1e781ef0663cL;\n 0x6143431143225286L;\n 0xb1c7c73bc776fc93L;\n 0x4ffcfcd7fcb32be5L;\n 0x2404041004201408L;\n 0xe351515951b208a2L;\n 0x2599995e99bcc72fL;\n 0x226d6da96d4fc4daL;\n 0x650d0d340d68391aL;\n 0x79fafacffa8335e9L;\n 0x69dfdf5bdfb684a3L;\n 0xa97e7ee57ed79bfcL;\n 0x19242490243db448L;\n 0xfe3b3bec3bc5d776L;\n 0x9aabab96ab313d4bL;\n 0xf0cece1fce3ed181L;\n 0x9911114411885522L;\n 0x838f8f068f0c8903L;\n 0x044e4e254e4a6b9cL;\n 0x66b7b7e6b7d15173L;\n 0xe0ebeb8beb0b60cbL;\n 0xc13c3cf03cfdcc78L;\n 0xfd81813e817cbf1fL;\n 0x4094946a94d4fe35L;\n 0x1cf7f7fbf7eb0cf3L;\n 0x18b9b9deb9a1676fL;\n 0x8b13134c13985f26L;\n 0x512c2cb02c7d9c58L;\n 0x05d3d36bd3d6b8bbL;\n 0x8ce7e7bbe76b5cd3L;\n 0x396e6ea56e57cbdcL;\n 0xaac4c437c46ef395L;\n 0x1b03030c03180f06L;\n 0xdc565645568a13acL;\n 0x5e44440d441a4988L;\n 0xa07f7fe17fdf9efeL;\n 0x88a9a99ea921374fL;\n 0x672a2aa82a4d8254L;\n 0x0abbbbd6bbb16d6bL;\n 0x87c1c123c146e29fL;\n 0xf153535153a202a6L;\n 0x72dcdc57dcae8ba5L;\n 0x530b0b2c0b582716L;\n 0x019d9d4e9d9cd327L;\n 0x2b6c6cad6c47c1d8L;\n 0xa43131c43195f562L;\n 0xf37474cd7487b9e8L;\n 0x15f6f6fff6e309f1L;\n 0x4c464605460a438cL;\n 0xa5acac8aac092645L;\n 0xb589891e893c970fL;\n 0xb414145014a04428L;\n 0xbae1e1a3e15b42dfL;\n 0xa616165816b04e2cL;\n 0xf73a3ae83acdd274L;\n 0x066969b9696fd0d2L;\n 0x4109092409482d12L;\n 0xd77070dd70a7ade0L;\n 0x6fb6b6e2b6d95471L;\n 0x1ed0d067d0ceb7bdL;\n 0xd6eded93ed3b7ec7L;\n 0xe2cccc17cc2edb85L;\n 0x68424215422a5784L;\n 0x2c98985a98b4c22dL;\n 0xeda4a4aaa4490e55L;\n 0x752828a0285d8850L;\n 0x865c5c6d5cda31b8L;\n 0x6bf8f8c7f8933fedL;\n 0xc28686228644a411L;\n |];\n [|\n 0x30d818186018c078L;\n 0x462623238c2305afL;\n 0x91b8c6c63fc67ef9L;\n 0xcdfbe8e887e8136fL;\n 0x13cb878726874ca1L;\n 0x6d11b8b8dab8a962L;\n 0x0209010104010805L;\n 0x9e0d4f4f214f426eL;\n 0x6c9b3636d836adeeL;\n 0x51ffa6a6a2a65904L;\n 0xb90cd2d26fd2debdL;\n 0xf70ef5f5f3f5fb06L;\n 0xf2967979f979ef80L;\n 0xde306f6fa16f5fceL;\n 0x3f6d91917e91fcefL;\n 0xa4f852525552aa07L;\n 0xc04760609d6027fdL;\n 0x6535bcbccabc8976L;\n 0x2b379b9b569baccdL;\n 0x018a8e8e028e048cL;\n 0x5bd2a3a3b6a37115L;\n 0x186c0c0c300c603cL;\n 0xf6847b7bf17bff8aL;\n 0x6a803535d435b5e1L;\n 0x3af51d1d741de869L;\n 0xddb3e0e0a7e05347L;\n 0xb321d7d77bd7f6acL;\n 0x999cc2c22fc25eedL;\n 0x5c432e2eb82e6d96L;\n 0x96294b4b314b627aL;\n 0xe15dfefedffea321L;\n 0xaed5575741578216L;\n 0x2abd15155415a841L;\n 0xeee87777c1779fb6L;\n 0x6e923737dc37a5ebL;\n 0xd79ee5e5b3e57b56L;\n 0x23139f9f469f8cd9L;\n 0xfd23f0f0e7f0d317L;\n 0x94204a4a354a6a7fL;\n 0xa944dada4fda9e95L;\n 0xb0a258587d58fa25L;\n 0x8fcfc9c903c906caL;\n 0x527c2929a429558dL;\n 0x145a0a0a280a5022L;\n 0x7f50b1b1feb1e14fL;\n 0x5dc9a0a0baa0691aL;\n 0xd6146b6bb16b7fdaL;\n 0x17d985852e855cabL;\n 0x673cbdbdcebd8173L;\n 0xba8f5d5d695dd234L;\n 0x2090101040108050L;\n 0xf507f4f4f7f4f303L;\n 0x8bddcbcb0bcb16c0L;\n 0x7cd33e3ef83eedc6L;\n 0x0a2d050514052811L;\n 0xce78676781671fe6L;\n 0xd597e4e4b7e47353L;\n 0x4e0227279c2725bbL;\n 0x8273414119413258L;\n 0x0ba78b8b168b2c9dL;\n 0x53f6a7a7a6a75101L;\n 0xfab27d7de97dcf94L;\n 0x374995956e95dcfbL;\n 0xad56d8d847d88e9fL;\n 0xeb70fbfbcbfb8b30L;\n 0xc1cdeeee9fee2371L;\n 0xf8bb7c7ced7cc791L;\n 0xcc716666856617e3L;\n 0xa77bdddd53dda68eL;\n 0x2eaf17175c17b84bL;\n 0x8e45474701470246L;\n 0x211a9e9e429e84dcL;\n 0x89d4caca0fca1ec5L;\n 0x5a582d2db42d7599L;\n 0x632ebfbfc6bf9179L;\n 0x0e3f07071c07381bL;\n 0x47acadad8ead0123L;\n 0xb4b05a5a755aea2fL;\n 0x1bef838336836cb5L;\n 0x66b63333cc3385ffL;\n 0xc65c636391633ff2L;\n 0x041202020802100aL;\n 0x4993aaaa92aa3938L;\n 0xe2de7171d971afa8L;\n 0x8dc6c8c807c80ecfL;\n 0x32d119196419c87dL;\n 0x923b494939497270L;\n 0xaf5fd9d943d9869aL;\n 0xf931f2f2eff2c31dL;\n 0xdba8e3e3abe34b48L;\n 0xb6b95b5b715be22aL;\n 0x0dbc88881a883492L;\n 0x293e9a9a529aa4c8L;\n 0x4c0b262698262dbeL;\n 0x64bf3232c8328dfaL;\n 0x7d59b0b0fab0e94aL;\n 0xcff2e9e983e91b6aL;\n 0x1e770f0f3c0f7833L;\n 0xb733d5d573d5e6a6L;\n 0x1df480803a8074baL;\n 0x6127bebec2be997cL;\n 0x87ebcdcd13cd26deL;\n 0x68893434d034bde4L;\n 0x903248483d487a75L;\n 0xe354ffffdbffab24L;\n 0xf48d7a7af57af78fL;\n 0x3d6490907a90f4eaL;\n 0xbe9d5f5f615fc23eL;\n 0x403d202080201da0L;\n 0xd00f6868bd6867d5L;\n 0x34ca1a1a681ad072L;\n 0x41b7aeae82ae192cL;\n 0x757db4b4eab4c95eL;\n 0xa8ce54544d549a19L;\n 0x3b7f93937693ece5L;\n 0x442f222288220daaL;\n 0xc86364648d6407e9L;\n 0xff2af1f1e3f1db12L;\n 0xe6cc7373d173bfa2L;\n 0x248212124812905aL;\n 0x807a40401d403a5dL;\n 0x1048080820084028L;\n 0x9b95c3c32bc356e8L;\n 0xc5dfecec97ec337bL;\n 0xab4ddbdb4bdb9690L;\n 0x5fc0a1a1bea1611fL;\n 0x07918d8d0e8d1c83L;\n 0x7ac83d3df43df5c9L;\n 0x335b97976697ccf1L;\n 0x0000000000000000L;\n 0x83f9cfcf1bcf36d4L;\n 0x566e2b2bac2b4587L;\n 0xece17676c57697b3L;\n 0x19e68282328264b0L;\n 0xb128d6d67fd6fea9L;\n 0x36c31b1b6c1bd877L;\n 0x7774b5b5eeb5c15bL;\n 0x43beafaf86af1129L;\n 0xd41d6a6ab56a77dfL;\n 0xa0ea50505d50ba0dL;\n 0x8a5745450945124cL;\n 0xfb38f3f3ebf3cb18L;\n 0x60ad3030c0309df0L;\n 0xc3c4efef9bef2b74L;\n 0x7eda3f3ffc3fe5c3L;\n 0xaac755554955921cL;\n 0x59dba2a2b2a27910L;\n 0xc9e9eaea8fea0365L;\n 0xca6a656589650fecL;\n 0x6903babad2bab968L;\n 0x5e4a2f2fbc2f6593L;\n 0x9d8ec0c027c04ee7L;\n 0xa160dede5fdebe81L;\n 0x38fc1c1c701ce06cL;\n 0xe746fdfdd3fdbb2eL;\n 0x9a1f4d4d294d5264L;\n 0x397692927292e4e0L;\n 0xeafa7575c9758fbcL;\n 0x0c3606061806301eL;\n 0x09ae8a8a128a2498L;\n 0x794bb2b2f2b2f940L;\n 0xd185e6e6bfe66359L;\n 0x1c7e0e0e380e7036L;\n 0x3ee71f1f7c1ff863L;\n 0xc4556262956237f7L;\n 0xb53ad4d477d4eea3L;\n 0x4d81a8a89aa82932L;\n 0x315296966296c4f4L;\n 0xef62f9f9c3f99b3aL;\n 0x97a3c5c533c566f6L;\n 0x4a102525942535b1L;\n 0xb2ab59597959f220L;\n 0x15d084842a8454aeL;\n 0xe4c57272d572b7a7L;\n 0x72ec3939e439d5ddL;\n 0x98164c4c2d4c5a61L;\n 0xbc945e5e655eca3bL;\n 0xf09f7878fd78e785L;\n 0x70e53838e038ddd8L;\n 0x05988c8c0a8c1486L;\n 0xbf17d1d163d1c6b2L;\n 0x57e4a5a5aea5410bL;\n 0xd9a1e2e2afe2434dL;\n 0xc24e616199612ff8L;\n 0x7b42b3b3f6b3f145L;\n 0x42342121842115a5L;\n 0x25089c9c4a9c94d6L;\n 0x3cee1e1e781ef066L;\n 0x8661434311432252L;\n 0x93b1c7c73bc776fcL;\n 0xe54ffcfcd7fcb32bL;\n 0x0824040410042014L;\n 0xa2e351515951b208L;\n 0x2f2599995e99bcc7L;\n 0xda226d6da96d4fc4L;\n 0x1a650d0d340d6839L;\n 0xe979fafacffa8335L;\n 0xa369dfdf5bdfb684L;\n 0xfca97e7ee57ed79bL;\n 0x4819242490243db4L;\n 0x76fe3b3bec3bc5d7L;\n 0x4b9aabab96ab313dL;\n 0x81f0cece1fce3ed1L;\n 0x2299111144118855L;\n 0x03838f8f068f0c89L;\n 0x9c044e4e254e4a6bL;\n 0x7366b7b7e6b7d151L;\n 0xcbe0ebeb8beb0b60L;\n 0x78c13c3cf03cfdccL;\n 0x1ffd81813e817cbfL;\n 0x354094946a94d4feL;\n 0xf31cf7f7fbf7eb0cL;\n 0x6f18b9b9deb9a167L;\n 0x268b13134c13985fL;\n 0x58512c2cb02c7d9cL;\n 0xbb05d3d36bd3d6b8L;\n 0xd38ce7e7bbe76b5cL;\n 0xdc396e6ea56e57cbL;\n 0x95aac4c437c46ef3L;\n 0x061b03030c03180fL;\n 0xacdc565645568a13L;\n 0x885e44440d441a49L;\n 0xfea07f7fe17fdf9eL;\n 0x4f88a9a99ea92137L;\n 0x54672a2aa82a4d82L;\n 0x6b0abbbbd6bbb16dL;\n 0x9f87c1c123c146e2L;\n 0xa6f153535153a202L;\n 0xa572dcdc57dcae8bL;\n 0x16530b0b2c0b5827L;\n 0x27019d9d4e9d9cd3L;\n 0xd82b6c6cad6c47c1L;\n 0x62a43131c43195f5L;\n 0xe8f37474cd7487b9L;\n 0xf115f6f6fff6e309L;\n 0x8c4c464605460a43L;\n 0x45a5acac8aac0926L;\n 0x0fb589891e893c97L;\n 0x28b414145014a044L;\n 0xdfbae1e1a3e15b42L;\n 0x2ca616165816b04eL;\n 0x74f73a3ae83acdd2L;\n 0xd2066969b9696fd0L;\n 0x124109092409482dL;\n 0xe0d77070dd70a7adL;\n 0x716fb6b6e2b6d954L;\n 0xbd1ed0d067d0ceb7L;\n 0xc7d6eded93ed3b7eL;\n 0x85e2cccc17cc2edbL;\n 0x8468424215422a57L;\n 0x2d2c98985a98b4c2L;\n 0x55eda4a4aaa4490eL;\n 0x50752828a0285d88L;\n 0xb8865c5c6d5cda31L;\n 0xed6bf8f8c7f8933fL;\n 0x11c28686228644a4L;\n |];\n [|\n 0x7830d818186018c0L;\n 0xaf462623238c2305L;\n 0xf991b8c6c63fc67eL;\n 0x6fcdfbe8e887e813L;\n 0xa113cb878726874cL;\n 0x626d11b8b8dab8a9L;\n 0x0502090101040108L;\n 0x6e9e0d4f4f214f42L;\n 0xee6c9b3636d836adL;\n 0x0451ffa6a6a2a659L;\n 0xbdb90cd2d26fd2deL;\n 0x06f70ef5f5f3f5fbL;\n 0x80f2967979f979efL;\n 0xcede306f6fa16f5fL;\n 0xef3f6d91917e91fcL;\n 0x07a4f852525552aaL;\n 0xfdc04760609d6027L;\n 0x766535bcbccabc89L;\n 0xcd2b379b9b569bacL;\n 0x8c018a8e8e028e04L;\n 0x155bd2a3a3b6a371L;\n 0x3c186c0c0c300c60L;\n 0x8af6847b7bf17bffL;\n 0xe16a803535d435b5L;\n 0x693af51d1d741de8L;\n 0x47ddb3e0e0a7e053L;\n 0xacb321d7d77bd7f6L;\n 0xed999cc2c22fc25eL;\n 0x965c432e2eb82e6dL;\n 0x7a96294b4b314b62L;\n 0x21e15dfefedffea3L;\n 0x16aed55757415782L;\n 0x412abd15155415a8L;\n 0xb6eee87777c1779fL;\n 0xeb6e923737dc37a5L;\n 0x56d79ee5e5b3e57bL;\n 0xd923139f9f469f8cL;\n 0x17fd23f0f0e7f0d3L;\n 0x7f94204a4a354a6aL;\n 0x95a944dada4fda9eL;\n 0x25b0a258587d58faL;\n 0xca8fcfc9c903c906L;\n 0x8d527c2929a42955L;\n 0x22145a0a0a280a50L;\n 0x4f7f50b1b1feb1e1L;\n 0x1a5dc9a0a0baa069L;\n 0xdad6146b6bb16b7fL;\n 0xab17d985852e855cL;\n 0x73673cbdbdcebd81L;\n 0x34ba8f5d5d695dd2L;\n 0x5020901010401080L;\n 0x03f507f4f4f7f4f3L;\n 0xc08bddcbcb0bcb16L;\n 0xc67cd33e3ef83eedL;\n 0x110a2d0505140528L;\n 0xe6ce78676781671fL;\n 0x53d597e4e4b7e473L;\n 0xbb4e0227279c2725L;\n 0x5882734141194132L;\n 0x9d0ba78b8b168b2cL;\n 0x0153f6a7a7a6a751L;\n 0x94fab27d7de97dcfL;\n 0xfb374995956e95dcL;\n 0x9fad56d8d847d88eL;\n 0x30eb70fbfbcbfb8bL;\n 0x71c1cdeeee9fee23L;\n 0x91f8bb7c7ced7cc7L;\n 0xe3cc716666856617L;\n 0x8ea77bdddd53dda6L;\n 0x4b2eaf17175c17b8L;\n 0x468e454747014702L;\n 0xdc211a9e9e429e84L;\n 0xc589d4caca0fca1eL;\n 0x995a582d2db42d75L;\n 0x79632ebfbfc6bf91L;\n 0x1b0e3f07071c0738L;\n 0x2347acadad8ead01L;\n 0x2fb4b05a5a755aeaL;\n 0xb51bef838336836cL;\n 0xff66b63333cc3385L;\n 0xf2c65c636391633fL;\n 0x0a04120202080210L;\n 0x384993aaaa92aa39L;\n 0xa8e2de7171d971afL;\n 0xcf8dc6c8c807c80eL;\n 0x7d32d119196419c8L;\n 0x70923b4949394972L;\n 0x9aaf5fd9d943d986L;\n 0x1df931f2f2eff2c3L;\n 0x48dba8e3e3abe34bL;\n 0x2ab6b95b5b715be2L;\n 0x920dbc88881a8834L;\n 0xc8293e9a9a529aa4L;\n 0xbe4c0b262698262dL;\n 0xfa64bf3232c8328dL;\n 0x4a7d59b0b0fab0e9L;\n 0x6acff2e9e983e91bL;\n 0x331e770f0f3c0f78L;\n 0xa6b733d5d573d5e6L;\n 0xba1df480803a8074L;\n 0x7c6127bebec2be99L;\n 0xde87ebcdcd13cd26L;\n 0xe468893434d034bdL;\n 0x75903248483d487aL;\n 0x24e354ffffdbffabL;\n 0x8ff48d7a7af57af7L;\n 0xea3d6490907a90f4L;\n 0x3ebe9d5f5f615fc2L;\n 0xa0403d202080201dL;\n 0xd5d00f6868bd6867L;\n 0x7234ca1a1a681ad0L;\n 0x2c41b7aeae82ae19L;\n 0x5e757db4b4eab4c9L;\n 0x19a8ce54544d549aL;\n 0xe53b7f93937693ecL;\n 0xaa442f222288220dL;\n 0xe9c86364648d6407L;\n 0x12ff2af1f1e3f1dbL;\n 0xa2e6cc7373d173bfL;\n 0x5a24821212481290L;\n 0x5d807a40401d403aL;\n 0x2810480808200840L;\n 0xe89b95c3c32bc356L;\n 0x7bc5dfecec97ec33L;\n 0x90ab4ddbdb4bdb96L;\n 0x1f5fc0a1a1bea161L;\n 0x8307918d8d0e8d1cL;\n 0xc97ac83d3df43df5L;\n 0xf1335b97976697ccL;\n 0x0000000000000000L;\n 0xd483f9cfcf1bcf36L;\n 0x87566e2b2bac2b45L;\n 0xb3ece17676c57697L;\n 0xb019e68282328264L;\n 0xa9b128d6d67fd6feL;\n 0x7736c31b1b6c1bd8L;\n 0x5b7774b5b5eeb5c1L;\n 0x2943beafaf86af11L;\n 0xdfd41d6a6ab56a77L;\n 0x0da0ea50505d50baL;\n 0x4c8a574545094512L;\n 0x18fb38f3f3ebf3cbL;\n 0xf060ad3030c0309dL;\n 0x74c3c4efef9bef2bL;\n 0xc37eda3f3ffc3fe5L;\n 0x1caac75555495592L;\n 0x1059dba2a2b2a279L;\n 0x65c9e9eaea8fea03L;\n 0xecca6a656589650fL;\n 0x686903babad2bab9L;\n 0x935e4a2f2fbc2f65L;\n 0xe79d8ec0c027c04eL;\n 0x81a160dede5fdebeL;\n 0x6c38fc1c1c701ce0L;\n 0x2ee746fdfdd3fdbbL;\n 0x649a1f4d4d294d52L;\n 0xe0397692927292e4L;\n 0xbceafa7575c9758fL;\n 0x1e0c360606180630L;\n 0x9809ae8a8a128a24L;\n 0x40794bb2b2f2b2f9L;\n 0x59d185e6e6bfe663L;\n 0x361c7e0e0e380e70L;\n 0x633ee71f1f7c1ff8L;\n 0xf7c4556262956237L;\n 0xa3b53ad4d477d4eeL;\n 0x324d81a8a89aa829L;\n 0xf4315296966296c4L;\n 0x3aef62f9f9c3f99bL;\n 0xf697a3c5c533c566L;\n 0xb14a102525942535L;\n 0x20b2ab59597959f2L;\n 0xae15d084842a8454L;\n 0xa7e4c57272d572b7L;\n 0xdd72ec3939e439d5L;\n 0x6198164c4c2d4c5aL;\n 0x3bbc945e5e655ecaL;\n 0x85f09f7878fd78e7L;\n 0xd870e53838e038ddL;\n 0x8605988c8c0a8c14L;\n 0xb2bf17d1d163d1c6L;\n 0x0b57e4a5a5aea541L;\n 0x4dd9a1e2e2afe243L;\n 0xf8c24e616199612fL;\n 0x457b42b3b3f6b3f1L;\n 0xa542342121842115L;\n 0xd625089c9c4a9c94L;\n 0x663cee1e1e781ef0L;\n 0x5286614343114322L;\n 0xfc93b1c7c73bc776L;\n 0x2be54ffcfcd7fcb3L;\n 0x1408240404100420L;\n 0x08a2e351515951b2L;\n 0xc72f2599995e99bcL;\n 0xc4da226d6da96d4fL;\n 0x391a650d0d340d68L;\n 0x35e979fafacffa83L;\n 0x84a369dfdf5bdfb6L;\n 0x9bfca97e7ee57ed7L;\n 0xb44819242490243dL;\n 0xd776fe3b3bec3bc5L;\n 0x3d4b9aabab96ab31L;\n 0xd181f0cece1fce3eL;\n 0x5522991111441188L;\n 0x8903838f8f068f0cL;\n 0x6b9c044e4e254e4aL;\n 0x517366b7b7e6b7d1L;\n 0x60cbe0ebeb8beb0bL;\n 0xcc78c13c3cf03cfdL;\n 0xbf1ffd81813e817cL;\n 0xfe354094946a94d4L;\n 0x0cf31cf7f7fbf7ebL;\n 0x676f18b9b9deb9a1L;\n 0x5f268b13134c1398L;\n 0x9c58512c2cb02c7dL;\n 0xb8bb05d3d36bd3d6L;\n 0x5cd38ce7e7bbe76bL;\n 0xcbdc396e6ea56e57L;\n 0xf395aac4c437c46eL;\n 0x0f061b03030c0318L;\n 0x13acdc565645568aL;\n 0x49885e44440d441aL;\n 0x9efea07f7fe17fdfL;\n 0x374f88a9a99ea921L;\n 0x8254672a2aa82a4dL;\n 0x6d6b0abbbbd6bbb1L;\n 0xe29f87c1c123c146L;\n 0x02a6f153535153a2L;\n 0x8ba572dcdc57dcaeL;\n 0x2716530b0b2c0b58L;\n 0xd327019d9d4e9d9cL;\n 0xc1d82b6c6cad6c47L;\n 0xf562a43131c43195L;\n 0xb9e8f37474cd7487L;\n 0x09f115f6f6fff6e3L;\n 0x438c4c464605460aL;\n 0x2645a5acac8aac09L;\n 0x970fb589891e893cL;\n 0x4428b414145014a0L;\n 0x42dfbae1e1a3e15bL;\n 0x4e2ca616165816b0L;\n 0xd274f73a3ae83acdL;\n 0xd0d2066969b9696fL;\n 0x2d12410909240948L;\n 0xade0d77070dd70a7L;\n 0x54716fb6b6e2b6d9L;\n 0xb7bd1ed0d067d0ceL;\n 0x7ec7d6eded93ed3bL;\n 0xdb85e2cccc17cc2eL;\n 0x578468424215422aL;\n 0xc22d2c98985a98b4L;\n 0x0e55eda4a4aaa449L;\n 0x8850752828a0285dL;\n 0x31b8865c5c6d5cdaL;\n 0x3fed6bf8f8c7f893L;\n 0xa411c28686228644L;\n |];\n [|\n 0xc07830d818186018L;\n 0x05af462623238c23L;\n 0x7ef991b8c6c63fc6L;\n 0x136fcdfbe8e887e8L;\n 0x4ca113cb87872687L;\n 0xa9626d11b8b8dab8L;\n 0x0805020901010401L;\n 0x426e9e0d4f4f214fL;\n 0xadee6c9b3636d836L;\n 0x590451ffa6a6a2a6L;\n 0xdebdb90cd2d26fd2L;\n 0xfb06f70ef5f5f3f5L;\n 0xef80f2967979f979L;\n 0x5fcede306f6fa16fL;\n 0xfcef3f6d91917e91L;\n 0xaa07a4f852525552L;\n 0x27fdc04760609d60L;\n 0x89766535bcbccabcL;\n 0xaccd2b379b9b569bL;\n 0x048c018a8e8e028eL;\n 0x71155bd2a3a3b6a3L;\n 0x603c186c0c0c300cL;\n 0xff8af6847b7bf17bL;\n 0xb5e16a803535d435L;\n 0xe8693af51d1d741dL;\n 0x5347ddb3e0e0a7e0L;\n 0xf6acb321d7d77bd7L;\n 0x5eed999cc2c22fc2L;\n 0x6d965c432e2eb82eL;\n 0x627a96294b4b314bL;\n 0xa321e15dfefedffeL;\n 0x8216aed557574157L;\n 0xa8412abd15155415L;\n 0x9fb6eee87777c177L;\n 0xa5eb6e923737dc37L;\n 0x7b56d79ee5e5b3e5L;\n 0x8cd923139f9f469fL;\n 0xd317fd23f0f0e7f0L;\n 0x6a7f94204a4a354aL;\n 0x9e95a944dada4fdaL;\n 0xfa25b0a258587d58L;\n 0x06ca8fcfc9c903c9L;\n 0x558d527c2929a429L;\n 0x5022145a0a0a280aL;\n 0xe14f7f50b1b1feb1L;\n 0x691a5dc9a0a0baa0L;\n 0x7fdad6146b6bb16bL;\n 0x5cab17d985852e85L;\n 0x8173673cbdbdcebdL;\n 0xd234ba8f5d5d695dL;\n 0x8050209010104010L;\n 0xf303f507f4f4f7f4L;\n 0x16c08bddcbcb0bcbL;\n 0xedc67cd33e3ef83eL;\n 0x28110a2d05051405L;\n 0x1fe6ce7867678167L;\n 0x7353d597e4e4b7e4L;\n 0x25bb4e0227279c27L;\n 0x3258827341411941L;\n 0x2c9d0ba78b8b168bL;\n 0x510153f6a7a7a6a7L;\n 0xcf94fab27d7de97dL;\n 0xdcfb374995956e95L;\n 0x8e9fad56d8d847d8L;\n 0x8b30eb70fbfbcbfbL;\n 0x2371c1cdeeee9feeL;\n 0xc791f8bb7c7ced7cL;\n 0x17e3cc7166668566L;\n 0xa68ea77bdddd53ddL;\n 0xb84b2eaf17175c17L;\n 0x02468e4547470147L;\n 0x84dc211a9e9e429eL;\n 0x1ec589d4caca0fcaL;\n 0x75995a582d2db42dL;\n 0x9179632ebfbfc6bfL;\n 0x381b0e3f07071c07L;\n 0x012347acadad8eadL;\n 0xea2fb4b05a5a755aL;\n 0x6cb51bef83833683L;\n 0x85ff66b63333cc33L;\n 0x3ff2c65c63639163L;\n 0x100a041202020802L;\n 0x39384993aaaa92aaL;\n 0xafa8e2de7171d971L;\n 0x0ecf8dc6c8c807c8L;\n 0xc87d32d119196419L;\n 0x7270923b49493949L;\n 0x869aaf5fd9d943d9L;\n 0xc31df931f2f2eff2L;\n 0x4b48dba8e3e3abe3L;\n 0xe22ab6b95b5b715bL;\n 0x34920dbc88881a88L;\n 0xa4c8293e9a9a529aL;\n 0x2dbe4c0b26269826L;\n 0x8dfa64bf3232c832L;\n 0xe94a7d59b0b0fab0L;\n 0x1b6acff2e9e983e9L;\n 0x78331e770f0f3c0fL;\n 0xe6a6b733d5d573d5L;\n 0x74ba1df480803a80L;\n 0x997c6127bebec2beL;\n 0x26de87ebcdcd13cdL;\n 0xbde468893434d034L;\n 0x7a75903248483d48L;\n 0xab24e354ffffdbffL;\n 0xf78ff48d7a7af57aL;\n 0xf4ea3d6490907a90L;\n 0xc23ebe9d5f5f615fL;\n 0x1da0403d20208020L;\n 0x67d5d00f6868bd68L;\n 0xd07234ca1a1a681aL;\n 0x192c41b7aeae82aeL;\n 0xc95e757db4b4eab4L;\n 0x9a19a8ce54544d54L;\n 0xece53b7f93937693L;\n 0x0daa442f22228822L;\n 0x07e9c86364648d64L;\n 0xdb12ff2af1f1e3f1L;\n 0xbfa2e6cc7373d173L;\n 0x905a248212124812L;\n 0x3a5d807a40401d40L;\n 0x4028104808082008L;\n 0x56e89b95c3c32bc3L;\n 0x337bc5dfecec97ecL;\n 0x9690ab4ddbdb4bdbL;\n 0x611f5fc0a1a1bea1L;\n 0x1c8307918d8d0e8dL;\n 0xf5c97ac83d3df43dL;\n 0xccf1335b97976697L;\n 0x0000000000000000L;\n 0x36d483f9cfcf1bcfL;\n 0x4587566e2b2bac2bL;\n 0x97b3ece17676c576L;\n 0x64b019e682823282L;\n 0xfea9b128d6d67fd6L;\n 0xd87736c31b1b6c1bL;\n 0xc15b7774b5b5eeb5L;\n 0x112943beafaf86afL;\n 0x77dfd41d6a6ab56aL;\n 0xba0da0ea50505d50L;\n 0x124c8a5745450945L;\n 0xcb18fb38f3f3ebf3L;\n 0x9df060ad3030c030L;\n 0x2b74c3c4efef9befL;\n 0xe5c37eda3f3ffc3fL;\n 0x921caac755554955L;\n 0x791059dba2a2b2a2L;\n 0x0365c9e9eaea8feaL;\n 0x0fecca6a65658965L;\n 0xb9686903babad2baL;\n 0x65935e4a2f2fbc2fL;\n 0x4ee79d8ec0c027c0L;\n 0xbe81a160dede5fdeL;\n 0xe06c38fc1c1c701cL;\n 0xbb2ee746fdfdd3fdL;\n 0x52649a1f4d4d294dL;\n 0xe4e0397692927292L;\n 0x8fbceafa7575c975L;\n 0x301e0c3606061806L;\n 0x249809ae8a8a128aL;\n 0xf940794bb2b2f2b2L;\n 0x6359d185e6e6bfe6L;\n 0x70361c7e0e0e380eL;\n 0xf8633ee71f1f7c1fL;\n 0x37f7c45562629562L;\n 0xeea3b53ad4d477d4L;\n 0x29324d81a8a89aa8L;\n 0xc4f4315296966296L;\n 0x9b3aef62f9f9c3f9L;\n 0x66f697a3c5c533c5L;\n 0x35b14a1025259425L;\n 0xf220b2ab59597959L;\n 0x54ae15d084842a84L;\n 0xb7a7e4c57272d572L;\n 0xd5dd72ec3939e439L;\n 0x5a6198164c4c2d4cL;\n 0xca3bbc945e5e655eL;\n 0xe785f09f7878fd78L;\n 0xddd870e53838e038L;\n 0x148605988c8c0a8cL;\n 0xc6b2bf17d1d163d1L;\n 0x410b57e4a5a5aea5L;\n 0x434dd9a1e2e2afe2L;\n 0x2ff8c24e61619961L;\n 0xf1457b42b3b3f6b3L;\n 0x15a5423421218421L;\n 0x94d625089c9c4a9cL;\n 0xf0663cee1e1e781eL;\n 0x2252866143431143L;\n 0x76fc93b1c7c73bc7L;\n 0xb32be54ffcfcd7fcL;\n 0x2014082404041004L;\n 0xb208a2e351515951L;\n 0xbcc72f2599995e99L;\n 0x4fc4da226d6da96dL;\n 0x68391a650d0d340dL;\n 0x8335e979fafacffaL;\n 0xb684a369dfdf5bdfL;\n 0xd79bfca97e7ee57eL;\n 0x3db4481924249024L;\n 0xc5d776fe3b3bec3bL;\n 0x313d4b9aabab96abL;\n 0x3ed181f0cece1fceL;\n 0x8855229911114411L;\n 0x0c8903838f8f068fL;\n 0x4a6b9c044e4e254eL;\n 0xd1517366b7b7e6b7L;\n 0x0b60cbe0ebeb8bebL;\n 0xfdcc78c13c3cf03cL;\n 0x7cbf1ffd81813e81L;\n 0xd4fe354094946a94L;\n 0xeb0cf31cf7f7fbf7L;\n 0xa1676f18b9b9deb9L;\n 0x985f268b13134c13L;\n 0x7d9c58512c2cb02cL;\n 0xd6b8bb05d3d36bd3L;\n 0x6b5cd38ce7e7bbe7L;\n 0x57cbdc396e6ea56eL;\n 0x6ef395aac4c437c4L;\n 0x180f061b03030c03L;\n 0x8a13acdc56564556L;\n 0x1a49885e44440d44L;\n 0xdf9efea07f7fe17fL;\n 0x21374f88a9a99ea9L;\n 0x4d8254672a2aa82aL;\n 0xb16d6b0abbbbd6bbL;\n 0x46e29f87c1c123c1L;\n 0xa202a6f153535153L;\n 0xae8ba572dcdc57dcL;\n 0x582716530b0b2c0bL;\n 0x9cd327019d9d4e9dL;\n 0x47c1d82b6c6cad6cL;\n 0x95f562a43131c431L;\n 0x87b9e8f37474cd74L;\n 0xe309f115f6f6fff6L;\n 0x0a438c4c46460546L;\n 0x092645a5acac8aacL;\n 0x3c970fb589891e89L;\n 0xa04428b414145014L;\n 0x5b42dfbae1e1a3e1L;\n 0xb04e2ca616165816L;\n 0xcdd274f73a3ae83aL;\n 0x6fd0d2066969b969L;\n 0x482d124109092409L;\n 0xa7ade0d77070dd70L;\n 0xd954716fb6b6e2b6L;\n 0xceb7bd1ed0d067d0L;\n 0x3b7ec7d6eded93edL;\n 0x2edb85e2cccc17ccL;\n 0x2a57846842421542L;\n 0xb4c22d2c98985a98L;\n 0x490e55eda4a4aaa4L;\n 0x5d8850752828a028L;\n 0xda31b8865c5c6d5cL;\n 0x933fed6bf8f8c7f8L;\n 0x44a411c286862286L;\n |];\n [|\n 0x18c07830d8181860L;\n 0x2305af462623238cL;\n 0xc67ef991b8c6c63fL;\n 0xe8136fcdfbe8e887L;\n 0x874ca113cb878726L;\n 0xb8a9626d11b8b8daL;\n 0x0108050209010104L;\n 0x4f426e9e0d4f4f21L;\n 0x36adee6c9b3636d8L;\n 0xa6590451ffa6a6a2L;\n 0xd2debdb90cd2d26fL;\n 0xf5fb06f70ef5f5f3L;\n 0x79ef80f2967979f9L;\n 0x6f5fcede306f6fa1L;\n 0x91fcef3f6d91917eL;\n 0x52aa07a4f8525255L;\n 0x6027fdc04760609dL;\n 0xbc89766535bcbccaL;\n 0x9baccd2b379b9b56L;\n 0x8e048c018a8e8e02L;\n 0xa371155bd2a3a3b6L;\n 0x0c603c186c0c0c30L;\n 0x7bff8af6847b7bf1L;\n 0x35b5e16a803535d4L;\n 0x1de8693af51d1d74L;\n 0xe05347ddb3e0e0a7L;\n 0xd7f6acb321d7d77bL;\n 0xc25eed999cc2c22fL;\n 0x2e6d965c432e2eb8L;\n 0x4b627a96294b4b31L;\n 0xfea321e15dfefedfL;\n 0x578216aed5575741L;\n 0x15a8412abd151554L;\n 0x779fb6eee87777c1L;\n 0x37a5eb6e923737dcL;\n 0xe57b56d79ee5e5b3L;\n 0x9f8cd923139f9f46L;\n 0xf0d317fd23f0f0e7L;\n 0x4a6a7f94204a4a35L;\n 0xda9e95a944dada4fL;\n 0x58fa25b0a258587dL;\n 0xc906ca8fcfc9c903L;\n 0x29558d527c2929a4L;\n 0x0a5022145a0a0a28L;\n 0xb1e14f7f50b1b1feL;\n 0xa0691a5dc9a0a0baL;\n 0x6b7fdad6146b6bb1L;\n 0x855cab17d985852eL;\n 0xbd8173673cbdbdceL;\n 0x5dd234ba8f5d5d69L;\n 0x1080502090101040L;\n 0xf4f303f507f4f4f7L;\n 0xcb16c08bddcbcb0bL;\n 0x3eedc67cd33e3ef8L;\n 0x0528110a2d050514L;\n 0x671fe6ce78676781L;\n 0xe47353d597e4e4b7L;\n 0x2725bb4e0227279cL;\n 0x4132588273414119L;\n 0x8b2c9d0ba78b8b16L;\n 0xa7510153f6a7a7a6L;\n 0x7dcf94fab27d7de9L;\n 0x95dcfb374995956eL;\n 0xd88e9fad56d8d847L;\n 0xfb8b30eb70fbfbcbL;\n 0xee2371c1cdeeee9fL;\n 0x7cc791f8bb7c7cedL;\n 0x6617e3cc71666685L;\n 0xdda68ea77bdddd53L;\n 0x17b84b2eaf17175cL;\n 0x4702468e45474701L;\n 0x9e84dc211a9e9e42L;\n 0xca1ec589d4caca0fL;\n 0x2d75995a582d2db4L;\n 0xbf9179632ebfbfc6L;\n 0x07381b0e3f07071cL;\n 0xad012347acadad8eL;\n 0x5aea2fb4b05a5a75L;\n 0x836cb51bef838336L;\n 0x3385ff66b63333ccL;\n 0x633ff2c65c636391L;\n 0x02100a0412020208L;\n 0xaa39384993aaaa92L;\n 0x71afa8e2de7171d9L;\n 0xc80ecf8dc6c8c807L;\n 0x19c87d32d1191964L;\n 0x497270923b494939L;\n 0xd9869aaf5fd9d943L;\n 0xf2c31df931f2f2efL;\n 0xe34b48dba8e3e3abL;\n 0x5be22ab6b95b5b71L;\n 0x8834920dbc88881aL;\n 0x9aa4c8293e9a9a52L;\n 0x262dbe4c0b262698L;\n 0x328dfa64bf3232c8L;\n 0xb0e94a7d59b0b0faL;\n 0xe91b6acff2e9e983L;\n 0x0f78331e770f0f3cL;\n 0xd5e6a6b733d5d573L;\n 0x8074ba1df480803aL;\n 0xbe997c6127bebec2L;\n 0xcd26de87ebcdcd13L;\n 0x34bde468893434d0L;\n 0x487a75903248483dL;\n 0xffab24e354ffffdbL;\n 0x7af78ff48d7a7af5L;\n 0x90f4ea3d6490907aL;\n 0x5fc23ebe9d5f5f61L;\n 0x201da0403d202080L;\n 0x6867d5d00f6868bdL;\n 0x1ad07234ca1a1a68L;\n 0xae192c41b7aeae82L;\n 0xb4c95e757db4b4eaL;\n 0x549a19a8ce54544dL;\n 0x93ece53b7f939376L;\n 0x220daa442f222288L;\n 0x6407e9c86364648dL;\n 0xf1db12ff2af1f1e3L;\n 0x73bfa2e6cc7373d1L;\n 0x12905a2482121248L;\n 0x403a5d807a40401dL;\n 0x0840281048080820L;\n 0xc356e89b95c3c32bL;\n 0xec337bc5dfecec97L;\n 0xdb9690ab4ddbdb4bL;\n 0xa1611f5fc0a1a1beL;\n 0x8d1c8307918d8d0eL;\n 0x3df5c97ac83d3df4L;\n 0x97ccf1335b979766L;\n 0x0000000000000000L;\n 0xcf36d483f9cfcf1bL;\n 0x2b4587566e2b2bacL;\n 0x7697b3ece17676c5L;\n 0x8264b019e6828232L;\n 0xd6fea9b128d6d67fL;\n 0x1bd87736c31b1b6cL;\n 0xb5c15b7774b5b5eeL;\n 0xaf112943beafaf86L;\n 0x6a77dfd41d6a6ab5L;\n 0x50ba0da0ea50505dL;\n 0x45124c8a57454509L;\n 0xf3cb18fb38f3f3ebL;\n 0x309df060ad3030c0L;\n 0xef2b74c3c4efef9bL;\n 0x3fe5c37eda3f3ffcL;\n 0x55921caac7555549L;\n 0xa2791059dba2a2b2L;\n 0xea0365c9e9eaea8fL;\n 0x650fecca6a656589L;\n 0xbab9686903babad2L;\n 0x2f65935e4a2f2fbcL;\n 0xc04ee79d8ec0c027L;\n 0xdebe81a160dede5fL;\n 0x1ce06c38fc1c1c70L;\n 0xfdbb2ee746fdfdd3L;\n 0x4d52649a1f4d4d29L;\n 0x92e4e03976929272L;\n 0x758fbceafa7575c9L;\n 0x06301e0c36060618L;\n 0x8a249809ae8a8a12L;\n 0xb2f940794bb2b2f2L;\n 0xe66359d185e6e6bfL;\n 0x0e70361c7e0e0e38L;\n 0x1ff8633ee71f1f7cL;\n 0x6237f7c455626295L;\n 0xd4eea3b53ad4d477L;\n 0xa829324d81a8a89aL;\n 0x96c4f43152969662L;\n 0xf99b3aef62f9f9c3L;\n 0xc566f697a3c5c533L;\n 0x2535b14a10252594L;\n 0x59f220b2ab595979L;\n 0x8454ae15d084842aL;\n 0x72b7a7e4c57272d5L;\n 0x39d5dd72ec3939e4L;\n 0x4c5a6198164c4c2dL;\n 0x5eca3bbc945e5e65L;\n 0x78e785f09f7878fdL;\n 0x38ddd870e53838e0L;\n 0x8c148605988c8c0aL;\n 0xd1c6b2bf17d1d163L;\n 0xa5410b57e4a5a5aeL;\n 0xe2434dd9a1e2e2afL;\n 0x612ff8c24e616199L;\n 0xb3f1457b42b3b3f6L;\n 0x2115a54234212184L;\n 0x9c94d625089c9c4aL;\n 0x1ef0663cee1e1e78L;\n 0x4322528661434311L;\n 0xc776fc93b1c7c73bL;\n 0xfcb32be54ffcfcd7L;\n 0x0420140824040410L;\n 0x51b208a2e3515159L;\n 0x99bcc72f2599995eL;\n 0x6d4fc4da226d6da9L;\n 0x0d68391a650d0d34L;\n 0xfa8335e979fafacfL;\n 0xdfb684a369dfdf5bL;\n 0x7ed79bfca97e7ee5L;\n 0x243db44819242490L;\n 0x3bc5d776fe3b3becL;\n 0xab313d4b9aabab96L;\n 0xce3ed181f0cece1fL;\n 0x1188552299111144L;\n 0x8f0c8903838f8f06L;\n 0x4e4a6b9c044e4e25L;\n 0xb7d1517366b7b7e6L;\n 0xeb0b60cbe0ebeb8bL;\n 0x3cfdcc78c13c3cf0L;\n 0x817cbf1ffd81813eL;\n 0x94d4fe354094946aL;\n 0xf7eb0cf31cf7f7fbL;\n 0xb9a1676f18b9b9deL;\n 0x13985f268b13134cL;\n 0x2c7d9c58512c2cb0L;\n 0xd3d6b8bb05d3d36bL;\n 0xe76b5cd38ce7e7bbL;\n 0x6e57cbdc396e6ea5L;\n 0xc46ef395aac4c437L;\n 0x03180f061b03030cL;\n 0x568a13acdc565645L;\n 0x441a49885e44440dL;\n 0x7fdf9efea07f7fe1L;\n 0xa921374f88a9a99eL;\n 0x2a4d8254672a2aa8L;\n 0xbbb16d6b0abbbbd6L;\n 0xc146e29f87c1c123L;\n 0x53a202a6f1535351L;\n 0xdcae8ba572dcdc57L;\n 0x0b582716530b0b2cL;\n 0x9d9cd327019d9d4eL;\n 0x6c47c1d82b6c6cadL;\n 0x3195f562a43131c4L;\n 0x7487b9e8f37474cdL;\n 0xf6e309f115f6f6ffL;\n 0x460a438c4c464605L;\n 0xac092645a5acac8aL;\n 0x893c970fb589891eL;\n 0x14a04428b4141450L;\n 0xe15b42dfbae1e1a3L;\n 0x16b04e2ca6161658L;\n 0x3acdd274f73a3ae8L;\n 0x696fd0d2066969b9L;\n 0x09482d1241090924L;\n 0x70a7ade0d77070ddL;\n 0xb6d954716fb6b6e2L;\n 0xd0ceb7bd1ed0d067L;\n 0xed3b7ec7d6eded93L;\n 0xcc2edb85e2cccc17L;\n 0x422a578468424215L;\n 0x98b4c22d2c98985aL;\n 0xa4490e55eda4a4aaL;\n 0x285d8850752828a0L;\n 0x5cda31b8865c5c6dL;\n 0xf8933fed6bf8f8c7L;\n 0x8644a411c2868622L;\n |];\n [|\n 0x6018c07830d81818L;\n 0x8c2305af46262323L;\n 0x3fc67ef991b8c6c6L;\n 0x87e8136fcdfbe8e8L;\n 0x26874ca113cb8787L;\n 0xdab8a9626d11b8b8L;\n 0x0401080502090101L;\n 0x214f426e9e0d4f4fL;\n 0xd836adee6c9b3636L;\n 0xa2a6590451ffa6a6L;\n 0x6fd2debdb90cd2d2L;\n 0xf3f5fb06f70ef5f5L;\n 0xf979ef80f2967979L;\n 0xa16f5fcede306f6fL;\n 0x7e91fcef3f6d9191L;\n 0x5552aa07a4f85252L;\n 0x9d6027fdc0476060L;\n 0xcabc89766535bcbcL;\n 0x569baccd2b379b9bL;\n 0x028e048c018a8e8eL;\n 0xb6a371155bd2a3a3L;\n 0x300c603c186c0c0cL;\n 0xf17bff8af6847b7bL;\n 0xd435b5e16a803535L;\n 0x741de8693af51d1dL;\n 0xa7e05347ddb3e0e0L;\n 0x7bd7f6acb321d7d7L;\n 0x2fc25eed999cc2c2L;\n 0xb82e6d965c432e2eL;\n 0x314b627a96294b4bL;\n 0xdffea321e15dfefeL;\n 0x41578216aed55757L;\n 0x5415a8412abd1515L;\n 0xc1779fb6eee87777L;\n 0xdc37a5eb6e923737L;\n 0xb3e57b56d79ee5e5L;\n 0x469f8cd923139f9fL;\n 0xe7f0d317fd23f0f0L;\n 0x354a6a7f94204a4aL;\n 0x4fda9e95a944dadaL;\n 0x7d58fa25b0a25858L;\n 0x03c906ca8fcfc9c9L;\n 0xa429558d527c2929L;\n 0x280a5022145a0a0aL;\n 0xfeb1e14f7f50b1b1L;\n 0xbaa0691a5dc9a0a0L;\n 0xb16b7fdad6146b6bL;\n 0x2e855cab17d98585L;\n 0xcebd8173673cbdbdL;\n 0x695dd234ba8f5d5dL;\n 0x4010805020901010L;\n 0xf7f4f303f507f4f4L;\n 0x0bcb16c08bddcbcbL;\n 0xf83eedc67cd33e3eL;\n 0x140528110a2d0505L;\n 0x81671fe6ce786767L;\n 0xb7e47353d597e4e4L;\n 0x9c2725bb4e022727L;\n 0x1941325882734141L;\n 0x168b2c9d0ba78b8bL;\n 0xa6a7510153f6a7a7L;\n 0xe97dcf94fab27d7dL;\n 0x6e95dcfb37499595L;\n 0x47d88e9fad56d8d8L;\n 0xcbfb8b30eb70fbfbL;\n 0x9fee2371c1cdeeeeL;\n 0xed7cc791f8bb7c7cL;\n 0x856617e3cc716666L;\n 0x53dda68ea77bddddL;\n 0x5c17b84b2eaf1717L;\n 0x014702468e454747L;\n 0x429e84dc211a9e9eL;\n 0x0fca1ec589d4cacaL;\n 0xb42d75995a582d2dL;\n 0xc6bf9179632ebfbfL;\n 0x1c07381b0e3f0707L;\n 0x8ead012347acadadL;\n 0x755aea2fb4b05a5aL;\n 0x36836cb51bef8383L;\n 0xcc3385ff66b63333L;\n 0x91633ff2c65c6363L;\n 0x0802100a04120202L;\n 0x92aa39384993aaaaL;\n 0xd971afa8e2de7171L;\n 0x07c80ecf8dc6c8c8L;\n 0x6419c87d32d11919L;\n 0x39497270923b4949L;\n 0x43d9869aaf5fd9d9L;\n 0xeff2c31df931f2f2L;\n 0xabe34b48dba8e3e3L;\n 0x715be22ab6b95b5bL;\n 0x1a8834920dbc8888L;\n 0x529aa4c8293e9a9aL;\n 0x98262dbe4c0b2626L;\n 0xc8328dfa64bf3232L;\n 0xfab0e94a7d59b0b0L;\n 0x83e91b6acff2e9e9L;\n 0x3c0f78331e770f0fL;\n 0x73d5e6a6b733d5d5L;\n 0x3a8074ba1df48080L;\n 0xc2be997c6127bebeL;\n 0x13cd26de87ebcdcdL;\n 0xd034bde468893434L;\n 0x3d487a7590324848L;\n 0xdbffab24e354ffffL;\n 0xf57af78ff48d7a7aL;\n 0x7a90f4ea3d649090L;\n 0x615fc23ebe9d5f5fL;\n 0x80201da0403d2020L;\n 0xbd6867d5d00f6868L;\n 0x681ad07234ca1a1aL;\n 0x82ae192c41b7aeaeL;\n 0xeab4c95e757db4b4L;\n 0x4d549a19a8ce5454L;\n 0x7693ece53b7f9393L;\n 0x88220daa442f2222L;\n 0x8d6407e9c8636464L;\n 0xe3f1db12ff2af1f1L;\n 0xd173bfa2e6cc7373L;\n 0x4812905a24821212L;\n 0x1d403a5d807a4040L;\n 0x2008402810480808L;\n 0x2bc356e89b95c3c3L;\n 0x97ec337bc5dfececL;\n 0x4bdb9690ab4ddbdbL;\n 0xbea1611f5fc0a1a1L;\n 0x0e8d1c8307918d8dL;\n 0xf43df5c97ac83d3dL;\n 0x6697ccf1335b9797L;\n 0x0000000000000000L;\n 0x1bcf36d483f9cfcfL;\n 0xac2b4587566e2b2bL;\n 0xc57697b3ece17676L;\n 0x328264b019e68282L;\n 0x7fd6fea9b128d6d6L;\n 0x6c1bd87736c31b1bL;\n 0xeeb5c15b7774b5b5L;\n 0x86af112943beafafL;\n 0xb56a77dfd41d6a6aL;\n 0x5d50ba0da0ea5050L;\n 0x0945124c8a574545L;\n 0xebf3cb18fb38f3f3L;\n 0xc0309df060ad3030L;\n 0x9bef2b74c3c4efefL;\n 0xfc3fe5c37eda3f3fL;\n 0x4955921caac75555L;\n 0xb2a2791059dba2a2L;\n 0x8fea0365c9e9eaeaL;\n 0x89650fecca6a6565L;\n 0xd2bab9686903babaL;\n 0xbc2f65935e4a2f2fL;\n 0x27c04ee79d8ec0c0L;\n 0x5fdebe81a160dedeL;\n 0x701ce06c38fc1c1cL;\n 0xd3fdbb2ee746fdfdL;\n 0x294d52649a1f4d4dL;\n 0x7292e4e039769292L;\n 0xc9758fbceafa7575L;\n 0x1806301e0c360606L;\n 0x128a249809ae8a8aL;\n 0xf2b2f940794bb2b2L;\n 0xbfe66359d185e6e6L;\n 0x380e70361c7e0e0eL;\n 0x7c1ff8633ee71f1fL;\n 0x956237f7c4556262L;\n 0x77d4eea3b53ad4d4L;\n 0x9aa829324d81a8a8L;\n 0x6296c4f431529696L;\n 0xc3f99b3aef62f9f9L;\n 0x33c566f697a3c5c5L;\n 0x942535b14a102525L;\n 0x7959f220b2ab5959L;\n 0x2a8454ae15d08484L;\n 0xd572b7a7e4c57272L;\n 0xe439d5dd72ec3939L;\n 0x2d4c5a6198164c4cL;\n 0x655eca3bbc945e5eL;\n 0xfd78e785f09f7878L;\n 0xe038ddd870e53838L;\n 0x0a8c148605988c8cL;\n 0x63d1c6b2bf17d1d1L;\n 0xaea5410b57e4a5a5L;\n 0xafe2434dd9a1e2e2L;\n 0x99612ff8c24e6161L;\n 0xf6b3f1457b42b3b3L;\n 0x842115a542342121L;\n 0x4a9c94d625089c9cL;\n 0x781ef0663cee1e1eL;\n 0x1143225286614343L;\n 0x3bc776fc93b1c7c7L;\n 0xd7fcb32be54ffcfcL;\n 0x1004201408240404L;\n 0x5951b208a2e35151L;\n 0x5e99bcc72f259999L;\n 0xa96d4fc4da226d6dL;\n 0x340d68391a650d0dL;\n 0xcffa8335e979fafaL;\n 0x5bdfb684a369dfdfL;\n 0xe57ed79bfca97e7eL;\n 0x90243db448192424L;\n 0xec3bc5d776fe3b3bL;\n 0x96ab313d4b9aababL;\n 0x1fce3ed181f0ceceL;\n 0x4411885522991111L;\n 0x068f0c8903838f8fL;\n 0x254e4a6b9c044e4eL;\n 0xe6b7d1517366b7b7L;\n 0x8beb0b60cbe0ebebL;\n 0xf03cfdcc78c13c3cL;\n 0x3e817cbf1ffd8181L;\n 0x6a94d4fe35409494L;\n 0xfbf7eb0cf31cf7f7L;\n 0xdeb9a1676f18b9b9L;\n 0x4c13985f268b1313L;\n 0xb02c7d9c58512c2cL;\n 0x6bd3d6b8bb05d3d3L;\n 0xbbe76b5cd38ce7e7L;\n 0xa56e57cbdc396e6eL;\n 0x37c46ef395aac4c4L;\n 0x0c03180f061b0303L;\n 0x45568a13acdc5656L;\n 0x0d441a49885e4444L;\n 0xe17fdf9efea07f7fL;\n 0x9ea921374f88a9a9L;\n 0xa82a4d8254672a2aL;\n 0xd6bbb16d6b0abbbbL;\n 0x23c146e29f87c1c1L;\n 0x5153a202a6f15353L;\n 0x57dcae8ba572dcdcL;\n 0x2c0b582716530b0bL;\n 0x4e9d9cd327019d9dL;\n 0xad6c47c1d82b6c6cL;\n 0xc43195f562a43131L;\n 0xcd7487b9e8f37474L;\n 0xfff6e309f115f6f6L;\n 0x05460a438c4c4646L;\n 0x8aac092645a5acacL;\n 0x1e893c970fb58989L;\n 0x5014a04428b41414L;\n 0xa3e15b42dfbae1e1L;\n 0x5816b04e2ca61616L;\n 0xe83acdd274f73a3aL;\n 0xb9696fd0d2066969L;\n 0x2409482d12410909L;\n 0xdd70a7ade0d77070L;\n 0xe2b6d954716fb6b6L;\n 0x67d0ceb7bd1ed0d0L;\n 0x93ed3b7ec7d6ededL;\n 0x17cc2edb85e2ccccL;\n 0x15422a5784684242L;\n 0x5a98b4c22d2c9898L;\n 0xaaa4490e55eda4a4L;\n 0xa0285d8850752828L;\n 0x6d5cda31b8865c5cL;\n 0xc7f8933fed6bf8f8L;\n 0x228644a411c28686L;\n |];\n [|\n 0x186018c07830d818L;\n 0x238c2305af462623L;\n 0xc63fc67ef991b8c6L;\n 0xe887e8136fcdfbe8L;\n 0x8726874ca113cb87L;\n 0xb8dab8a9626d11b8L;\n 0x0104010805020901L;\n 0x4f214f426e9e0d4fL;\n 0x36d836adee6c9b36L;\n 0xa6a2a6590451ffa6L;\n 0xd26fd2debdb90cd2L;\n 0xf5f3f5fb06f70ef5L;\n 0x79f979ef80f29679L;\n 0x6fa16f5fcede306fL;\n 0x917e91fcef3f6d91L;\n 0x525552aa07a4f852L;\n 0x609d6027fdc04760L;\n 0xbccabc89766535bcL;\n 0x9b569baccd2b379bL;\n 0x8e028e048c018a8eL;\n 0xa3b6a371155bd2a3L;\n 0x0c300c603c186c0cL;\n 0x7bf17bff8af6847bL;\n 0x35d435b5e16a8035L;\n 0x1d741de8693af51dL;\n 0xe0a7e05347ddb3e0L;\n 0xd77bd7f6acb321d7L;\n 0xc22fc25eed999cc2L;\n 0x2eb82e6d965c432eL;\n 0x4b314b627a96294bL;\n 0xfedffea321e15dfeL;\n 0x5741578216aed557L;\n 0x155415a8412abd15L;\n 0x77c1779fb6eee877L;\n 0x37dc37a5eb6e9237L;\n 0xe5b3e57b56d79ee5L;\n 0x9f469f8cd923139fL;\n 0xf0e7f0d317fd23f0L;\n 0x4a354a6a7f94204aL;\n 0xda4fda9e95a944daL;\n 0x587d58fa25b0a258L;\n 0xc903c906ca8fcfc9L;\n 0x29a429558d527c29L;\n 0x0a280a5022145a0aL;\n 0xb1feb1e14f7f50b1L;\n 0xa0baa0691a5dc9a0L;\n 0x6bb16b7fdad6146bL;\n 0x852e855cab17d985L;\n 0xbdcebd8173673cbdL;\n 0x5d695dd234ba8f5dL;\n 0x1040108050209010L;\n 0xf4f7f4f303f507f4L;\n 0xcb0bcb16c08bddcbL;\n 0x3ef83eedc67cd33eL;\n 0x05140528110a2d05L;\n 0x6781671fe6ce7867L;\n 0xe4b7e47353d597e4L;\n 0x279c2725bb4e0227L;\n 0x4119413258827341L;\n 0x8b168b2c9d0ba78bL;\n 0xa7a6a7510153f6a7L;\n 0x7de97dcf94fab27dL;\n 0x956e95dcfb374995L;\n 0xd847d88e9fad56d8L;\n 0xfbcbfb8b30eb70fbL;\n 0xee9fee2371c1cdeeL;\n 0x7ced7cc791f8bb7cL;\n 0x66856617e3cc7166L;\n 0xdd53dda68ea77bddL;\n 0x175c17b84b2eaf17L;\n 0x47014702468e4547L;\n 0x9e429e84dc211a9eL;\n 0xca0fca1ec589d4caL;\n 0x2db42d75995a582dL;\n 0xbfc6bf9179632ebfL;\n 0x071c07381b0e3f07L;\n 0xad8ead012347acadL;\n 0x5a755aea2fb4b05aL;\n 0x8336836cb51bef83L;\n 0x33cc3385ff66b633L;\n 0x6391633ff2c65c63L;\n 0x020802100a041202L;\n 0xaa92aa39384993aaL;\n 0x71d971afa8e2de71L;\n 0xc807c80ecf8dc6c8L;\n 0x196419c87d32d119L;\n 0x4939497270923b49L;\n 0xd943d9869aaf5fd9L;\n 0xf2eff2c31df931f2L;\n 0xe3abe34b48dba8e3L;\n 0x5b715be22ab6b95bL;\n 0x881a8834920dbc88L;\n 0x9a529aa4c8293e9aL;\n 0x2698262dbe4c0b26L;\n 0x32c8328dfa64bf32L;\n 0xb0fab0e94a7d59b0L;\n 0xe983e91b6acff2e9L;\n 0x0f3c0f78331e770fL;\n 0xd573d5e6a6b733d5L;\n 0x803a8074ba1df480L;\n 0xbec2be997c6127beL;\n 0xcd13cd26de87ebcdL;\n 0x34d034bde4688934L;\n 0x483d487a75903248L;\n 0xffdbffab24e354ffL;\n 0x7af57af78ff48d7aL;\n 0x907a90f4ea3d6490L;\n 0x5f615fc23ebe9d5fL;\n 0x2080201da0403d20L;\n 0x68bd6867d5d00f68L;\n 0x1a681ad07234ca1aL;\n 0xae82ae192c41b7aeL;\n 0xb4eab4c95e757db4L;\n 0x544d549a19a8ce54L;\n 0x937693ece53b7f93L;\n 0x2288220daa442f22L;\n 0x648d6407e9c86364L;\n 0xf1e3f1db12ff2af1L;\n 0x73d173bfa2e6cc73L;\n 0x124812905a248212L;\n 0x401d403a5d807a40L;\n 0x0820084028104808L;\n 0xc32bc356e89b95c3L;\n 0xec97ec337bc5dfecL;\n 0xdb4bdb9690ab4ddbL;\n 0xa1bea1611f5fc0a1L;\n 0x8d0e8d1c8307918dL;\n 0x3df43df5c97ac83dL;\n 0x976697ccf1335b97L;\n 0x0000000000000000L;\n 0xcf1bcf36d483f9cfL;\n 0x2bac2b4587566e2bL;\n 0x76c57697b3ece176L;\n 0x82328264b019e682L;\n 0xd67fd6fea9b128d6L;\n 0x1b6c1bd87736c31bL;\n 0xb5eeb5c15b7774b5L;\n 0xaf86af112943beafL;\n 0x6ab56a77dfd41d6aL;\n 0x505d50ba0da0ea50L;\n 0x450945124c8a5745L;\n 0xf3ebf3cb18fb38f3L;\n 0x30c0309df060ad30L;\n 0xef9bef2b74c3c4efL;\n 0x3ffc3fe5c37eda3fL;\n 0x554955921caac755L;\n 0xa2b2a2791059dba2L;\n 0xea8fea0365c9e9eaL;\n 0x6589650fecca6a65L;\n 0xbad2bab9686903baL;\n 0x2fbc2f65935e4a2fL;\n 0xc027c04ee79d8ec0L;\n 0xde5fdebe81a160deL;\n 0x1c701ce06c38fc1cL;\n 0xfdd3fdbb2ee746fdL;\n 0x4d294d52649a1f4dL;\n 0x927292e4e0397692L;\n 0x75c9758fbceafa75L;\n 0x061806301e0c3606L;\n 0x8a128a249809ae8aL;\n 0xb2f2b2f940794bb2L;\n 0xe6bfe66359d185e6L;\n 0x0e380e70361c7e0eL;\n 0x1f7c1ff8633ee71fL;\n 0x62956237f7c45562L;\n 0xd477d4eea3b53ad4L;\n 0xa89aa829324d81a8L;\n 0x966296c4f4315296L;\n 0xf9c3f99b3aef62f9L;\n 0xc533c566f697a3c5L;\n 0x25942535b14a1025L;\n 0x597959f220b2ab59L;\n 0x842a8454ae15d084L;\n 0x72d572b7a7e4c572L;\n 0x39e439d5dd72ec39L;\n 0x4c2d4c5a6198164cL;\n 0x5e655eca3bbc945eL;\n 0x78fd78e785f09f78L;\n 0x38e038ddd870e538L;\n 0x8c0a8c148605988cL;\n 0xd163d1c6b2bf17d1L;\n 0xa5aea5410b57e4a5L;\n 0xe2afe2434dd9a1e2L;\n 0x6199612ff8c24e61L;\n 0xb3f6b3f1457b42b3L;\n 0x21842115a5423421L;\n 0x9c4a9c94d625089cL;\n 0x1e781ef0663cee1eL;\n 0x4311432252866143L;\n 0xc73bc776fc93b1c7L;\n 0xfcd7fcb32be54ffcL;\n 0x0410042014082404L;\n 0x515951b208a2e351L;\n 0x995e99bcc72f2599L;\n 0x6da96d4fc4da226dL;\n 0x0d340d68391a650dL;\n 0xfacffa8335e979faL;\n 0xdf5bdfb684a369dfL;\n 0x7ee57ed79bfca97eL;\n 0x2490243db4481924L;\n 0x3bec3bc5d776fe3bL;\n 0xab96ab313d4b9aabL;\n 0xce1fce3ed181f0ceL;\n 0x1144118855229911L;\n 0x8f068f0c8903838fL;\n 0x4e254e4a6b9c044eL;\n 0xb7e6b7d1517366b7L;\n 0xeb8beb0b60cbe0ebL;\n 0x3cf03cfdcc78c13cL;\n 0x813e817cbf1ffd81L;\n 0x946a94d4fe354094L;\n 0xf7fbf7eb0cf31cf7L;\n 0xb9deb9a1676f18b9L;\n 0x134c13985f268b13L;\n 0x2cb02c7d9c58512cL;\n 0xd36bd3d6b8bb05d3L;\n 0xe7bbe76b5cd38ce7L;\n 0x6ea56e57cbdc396eL;\n 0xc437c46ef395aac4L;\n 0x030c03180f061b03L;\n 0x5645568a13acdc56L;\n 0x440d441a49885e44L;\n 0x7fe17fdf9efea07fL;\n 0xa99ea921374f88a9L;\n 0x2aa82a4d8254672aL;\n 0xbbd6bbb16d6b0abbL;\n 0xc123c146e29f87c1L;\n 0x535153a202a6f153L;\n 0xdc57dcae8ba572dcL;\n 0x0b2c0b582716530bL;\n 0x9d4e9d9cd327019dL;\n 0x6cad6c47c1d82b6cL;\n 0x31c43195f562a431L;\n 0x74cd7487b9e8f374L;\n 0xf6fff6e309f115f6L;\n 0x4605460a438c4c46L;\n 0xac8aac092645a5acL;\n 0x891e893c970fb589L;\n 0x145014a04428b414L;\n 0xe1a3e15b42dfbae1L;\n 0x165816b04e2ca616L;\n 0x3ae83acdd274f73aL;\n 0x69b9696fd0d20669L;\n 0x092409482d124109L;\n 0x70dd70a7ade0d770L;\n 0xb6e2b6d954716fb6L;\n 0xd067d0ceb7bd1ed0L;\n 0xed93ed3b7ec7d6edL;\n 0xcc17cc2edb85e2ccL;\n 0x4215422a57846842L;\n 0x985a98b4c22d2c98L;\n 0xa4aaa4490e55eda4L;\n 0x28a0285d88507528L;\n 0x5c6d5cda31b8865cL;\n 0xf8c7f8933fed6bf8L;\n 0x86228644a411c286L;\n |];\n |]\n\n let whirlpool_do_chunk :\n type a. be64_to_cpu:(a -> int -> int64) -> ctx -> a -> int -> unit =\n fun ~be64_to_cpu ctx buf off ->\n let key = Array.init 2 (fun _ -> Array.make 8 Int64.zero) in\n let state = Array.init 2 (fun _ -> Array.make 8 Int64.zero) in\n let m = ref 0 in\n let rc =\n [|\n 0x1823c6e887b8014fL;\n 0x36a6d2f5796f9152L;\n 0x60bc9b8ea30c7b35L;\n 0x1de0d7c22e4bfe57L;\n 0x157737e59ff04adaL;\n 0x58c9290ab1a06b85L;\n 0xbd5d10f4cb3e0567L;\n 0xe427418ba77d95d8L;\n 0xfbee7c66dd17479eL;\n 0xca2dbf07ad5a8333L;\n |] in\n for i = 0 to 7 do\n key.(0).(i) <- ctx.h.(i) ;\n let off = off + (i * 8) in\n state.(0).(i) <- Int64.(be64_to_cpu buf off lxor ctx.h.(i)) ;\n ctx.h.(i) <- state.(0).(i)\n done ;\n let wp_op src shift =\n let mask v = Int64.(to_int (v land 0xffL)) in\n let get_k i =\n k.(i).(mask\n (Int64.shift_right src.((shift + 8 - i) land 7) (56 - (8 * i))))\n in\n Array.fold_left Int64.logxor Int64.zero (Array.init 8 get_k) in\n for i = 0 to 9 do\n let m0, m1 = (!m, !m lxor 1) in\n let upd_key i = key.(m1).(i) <- wp_op key.(m0) i in\n let upd_state i =\n state.(m1).(i) <- Int64.(wp_op state.(m0) i lxor key.(m1).(i)) in\n for i = 0 to 7 do\n upd_key i\n done ;\n key.(m1).(0) <- Int64.(key.(m1).(0) lxor rc.(i)) ;\n for i = 0 to 7 do\n upd_state i\n done ;\n m := !m lxor 1\n done ;\n let upd_hash i = Int64.(ctx.h.(i) <- ctx.h.(i) lxor state.(0).(i)) in\n for i = 0 to 7 do\n upd_hash i\n done ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n be64_to_cpu:(a -> int -> int64) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~be64_to_cpu ctx buf off len ->\n let idx = ref Int64.(to_int (ctx.size land 0x3FL)) in\n let len = ref len in\n let off = ref off in\n let to_fill = 64 - !idx in\n ctx.size <- Int64.add ctx.size (Int64.of_int !len) ;\n if !idx <> 0 && !len >= to_fill\n then (\n blit buf !off ctx.b !idx to_fill ;\n whirlpool_do_chunk ~be64_to_cpu:By.be64_to_cpu ctx ctx.b 0 ;\n len := !len - to_fill ;\n off := !off + to_fill ;\n idx := 0) ;\n while !len >= 64 do\n whirlpool_do_chunk ~be64_to_cpu ctx buf !off ;\n len := !len - 64 ;\n off := !off + 64\n done ;\n if !len <> 0 then blit buf !off ctx.b !idx !len ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~be64_to_cpu:By.be64_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~be64_to_cpu:Bi.be64_to_cpu\n\n let unsafe_get ctx =\n let index = Int64.(to_int (ctx.size land 0x3FL)) + 1 in\n By.set ctx.b (index - 1) '\\x80' ;\n if index > 32\n then (\n By.fill ctx.b index (64 - index) '\\x00' ;\n whirlpool_do_chunk ~be64_to_cpu:By.be64_to_cpu ctx ctx.b 0 ;\n By.fill ctx.b 0 56 '\\x00')\n else By.fill ctx.b index (56 - index) '\\x00' ;\n By.cpu_to_be64 ctx.b 56 Int64.(ctx.size lsl 3) ;\n whirlpool_do_chunk ~be64_to_cpu:By.be64_to_cpu ctx ctx.b 0 ;\n let res = By.create (8 * 8) in\n for i = 0 to 7 do\n By.cpu_to_be64 res (i * 8) ctx.h.(i)\n done ;\n res\nend\n","# 1 \"src/digestif_eq.ml\"\nmodule Make (D : sig\n val digest_size : int\nend) =\nstruct\n let _ = D.digest_size\n\n let equal a b = Eqaf.equal a b\n\n let unsafe_compare a b = String.compare a b\nend\n","let[@inline always] char_chr ch =\n (* Char.chr contains a branch on [ch] and a plt indirection, this\n * implementation ensures well-formedness by construction and avoids that: *)\n Char.unsafe_chr (ch land 0xff)\n\nlet[@inline] get x i = String.unsafe_get x i |> Char.code\n\n(* XXX(dinosaure): we use [unsafe_get] to avoid jump to exception:\n\n sarq $1, %rbx\n movzbq (%rax,%rbx), %rax\n leaq 1(%rax,%rax), %rax\n ret\n*)\n\nexternal unsafe_get_int16 : string -> int -> int = \"%caml_string_get16u\"\nlet[@inline] get16 x i = unsafe_get_int16 x i\n\n(* XXX(dinosaure): same as [unsafe_get] but for [int16]:\n\n sarq $1, %rbx\n movzwq (%rax,%rbx), %rax\n leaq 1(%rax,%rax), %rax\n ret\n*)\n\nlet equal ~ln a b =\n let l1 = ln asr 1 in\n\n (*\n sarq $1, %rcx\n orq $1, %rcx\n *)\n\n let r = ref 0 in\n\n (*\n movq $1, %rdx\n *)\n\n for i = 0 to pred l1 do r := !r lor (get16 a (i * 2) lxor get16 b (i * 2)) done ;\n\n (*\n movq $1, %rsi\n addq $-2, %rcx\n cmpq %rcx, %rsi\n jg .L104\n.L105:\n leaq -1(%rsi,%rsi), %r8\n\n sarq $1, %r8\n movzwq (%rdi,%r8), %r9\n leaq 1(%r9,%r9), %r9\n movzwq (%rbx,%r8), %r8\n leaq 1(%r8,%r8), %r8\n\n // [unsafe_get_int16 a i] and [unsafe_get_int6 b i]\n\n xorq %r9, %r8\n orq $1, %r8\n orq %r8, %rdx\n movq %rsi, %r8\n addq $2, %rsi\n cmpq %rcx, %r8\n jne .L105\n.L104:\n *)\n\n for _ = 1 to ln land 1 do r := !r lor (get a (ln - 1) lxor get b (ln - 1)) done ;\n\n (*\n movq $3, %rsi\n movq %rax, %rcx\n andq $3, %rcx\n cmpq %rcx, %rsi\n jg .L102\n.L103:\n movq %rax, %r8\n addq $-2, %r8\n\n sarq $1, %r8\n movzbq (%rdi,%r8), %r9\n leaq 1(%r9,%r9), %r9\n movzbq (%rbx,%r8), %r8\n leaq 1(%r8,%r8), %r8\n\n // [unsafe_get a i] and [unsafe_get b i]\n\n xorq %r9, %r8\n orq $1, %r8\n orq %r8, %rdx\n movq %rsi, %r8\n addq $2, %rsi\n cmpq %rcx, %r8\n jne .L103\n.L102:\n *)\n\n !r = 0\n\n(*\n cmpq $1, %rdx\n sete %al\n movzbq %al, %rax\n leaq 1(%rax,%rax), %rax\n ret\n*)\n\nlet equal a b =\n let al = String.length a in\n let bl = String.length b in\n if al <> bl\n then false\n else equal ~ln:al a b\n\nlet[@inline always] compare (a:int) b = a - b\nlet[@inline always] sixteen_if_minus_one_or_less n = (n asr Sys.int_size) land 16\nlet[@inline always] eight_if_one_or_more n = ((-n) asr Sys.int_size) land 8\n\nlet compare_le ~ln a b =\n let r = ref 0 in\n let i = ref (pred ln) in\n\n while !i >= 0 do\n let xa = get a !i and xb = get b !i in\n let c = compare xa xb in\n r := !r lor ((sixteen_if_minus_one_or_less c + eight_if_one_or_more c) lsr !r) ;\n decr i ;\n done ;\n\n (!r land 8) - (!r land 16)\n\nlet compare_le_with_len ~len:ln a b =\n let al = String.length a in\n let bl = String.length b in\n if ln = 0 then 0\n else if (al lxor ln) lor (bl lxor ln) <> 0\n then invalid_arg \"compare_le_with_len\"\n else compare_le ~ln a b\n\nlet compare_le a b =\n let al = String.length a in\n let bl = String.length b in\n if al < bl\n then 1\n else if al > bl\n then (-1)\n else compare_le ~ln:al (* = bl *) a b\n\nlet compare_be ~ln a b =\n let r = ref 0 in\n let i = ref 0 in\n\n while !i < ln do\n let xa = get a !i and xb = get b !i in\n let c = compare xa xb in\n r := !r lor ((sixteen_if_minus_one_or_less c + eight_if_one_or_more c) lsr !r) ;\n incr i ;\n done ;\n\n (!r land 8) - (!r land 16)\n\nlet compare_be_with_len ~len:ln a b =\n let al = String.length a in\n let bl = String.length b in\n if ln = 0 then 0\n else if (al lxor ln) lor (bl lxor ln) <> 0\n then invalid_arg \"compare_be_with_len\"\n else compare_be ~ln a b\n\nlet compare_be a b =\n let al = String.length a in\n let bl = String.length b in\n if al < bl then 1\n else if al > bl then (-1)\n else compare_be ~ln:al (* = bl *) a b\n\nlet[@inline always] minus_one_or_less n =\n n lsr (Sys.int_size - 1)\n\nlet[@inline always] one_if_not_zero n =\n minus_one_or_less ((- n) lor n)\n\nlet[@inline always] zero_if_not_zero n =\n (one_if_not_zero n) - 1\n\nlet[@inline always] select_int choose_b a b =\n let mask = ((- choose_b) lor choose_b) asr Sys.int_size in\n (a land (lnot mask)) lor (b land mask)\n\nexternal int_of_bool : bool -> int = \"%identity\"\nexternal unsafe_bool_of_int : int -> bool = \"%identity\"\n\nlet[@inline] bool_of_int n =\n unsafe_bool_of_int (one_if_not_zero n)\n\nlet[@inline always] find_uint8 ~off ~len ~f str =\n let i = ref (len - 1) in\n let a = ref (lnot 0) in\n while !i >= off do\n let byte = get str !i in\n let pred = int_of_bool (f byte) in\n (* XXX(dinosaure): a composition of [f] with [bool_of_int] such as\n [let f = bool_of_int <.> f in] implies an allocation (of a closure).\n To be GC-free, we must store result of [f] into a register, and apply\n [bool_of_int] then (introspection was done on OCaml 4.08.1). *)\n a := select_int (((!i - off) land min_int) lor pred) !a !i ;\n decr i ;\n done ; !a\n\nlet find_uint8 ?(off= 0) ~f str =\n (* XXX(dinosaure): with this overload, OCaml is able to produce 2 [find_uint8].\n One with [off= 0] and one other where [off] is an argument. I think it's about\n cross-module optimization where a call to [find_uint8 ~f v] will directly call\n the first one and a call to [find_uint8 ~off:x ~f v] will call the second one. *)\n let len = String.length str in\n find_uint8 ~off ~len ~f str\n\nlet exists_uint8 ?off ~f str =\n let v = find_uint8 ?off ~f str in\n let r = select_int (v + 1) 0 1 in\n unsafe_bool_of_int r\n\nlet divmod ~(x:int32) ~(m:int32) : int32 * int32 =\n (* Division and remainder being constant-time with respect to [x]\n * ( NOT [m] !). The OCaml variant would be:\n * [(x / m , x mod m)] where [x] is a secret and [m] is not secret.\n * Adapted from the NTRU Prime team's algorithm from\n * supercop/crypto_kem/sntrup761/ref/uint32.c\n * cite the round-2 ntru prime submission to nistpqc (march 2019)\n * Note that in practice this works for at least some much larger [x] and [m],\n * but it's unclear to me how to evaluate *which*, so leaving the original\n * restrictions in.\n *)\n let ( - ) , ( + ), ( * ) = Int32.(sub, add, mul) in\n let ( >> ) = Int32.shift_right_logical in\n if (m <= 0l) then raise (Invalid_argument \"m <= 0\") ;\n if (m >= 16348l) then raise (Invalid_argument \"m >= 16348 not supported\") ;\n\n let of_uint32 uint =\n (* apparently Int64.of_int32 sign-extends ... great... avoid that: *)\n let b = Bytes.make 8 '\\x00' in\n Unsafe.set_int32_le b 0 uint ;\n Unsafe.get_int64_le b 0\n in\n\n let x_0 = x in\n\n let x_2, q_1 =\n let int32_div_unsigned n d =\n (* can be replaced by Int32.unsigned_div\n * from OCaml >= 4.10 *)\n let sub,min_int = Int32.(sub,min_int)in\n let int32_unsigned_compare n m =\n Int32.compare (sub n min_int) (sub m min_int)\n in\n if d < 0_l then\n if int32_unsigned_compare n d < 0 then 0_l else 1_l\n else\n let q =\n let open Int32 in\n shift_left (Int32.div (Int32.shift_right_logical n 1) d) 1 in\n let r = sub n (Int32.mul q d) in\n if int32_unsigned_compare r d >= 0 then Int32.succ q else q\n in\n let v = int32_div_unsigned Int32.min_int m |> of_uint32 in\n (*let v = 0x80_00_00_00 / m in*) (* floored div *)\n let x_1, q_0 =\n let qpart_0 =\n let open Int64 in\n shift_right_logical (mul (of_uint32 x_0) v) 31\n |> to_int32\n in\n x_0 - (qpart_0 * m), qpart_0\n in\n let qpart_1 =\n let open Int64 in\n shift_right_logical (mul (of_uint32 x_1) v) 31\n |> to_int32 in\n x_1 - (qpart_1 * m),\n (q_0 + qpart_1 + 1l) in\n let x_3 = x_2 - m in\n let mask = 0l - (x_3 >> 31) in\n q_1 + mask, x_3 + (Int32.logand mask m)\n\nlet ascii_of_int32 ~digits (n:int32) : string =\n (* Recursively calls [divmod n 10]; the remainder is turned into ASCII\n and the quotient is used for the next division.*)\n if digits < 0 then raise (Invalid_argument \"digits < 0\");\n let out = Bytes.make digits '0' in\n let rec loop x = function\n | -1 -> Bytes.unsafe_to_string out\n | idx ->\n let next, this = divmod ~x ~m:10l in\n Bytes.set out idx @@ char_chr (0x30 lor (Int32.to_int this)) ;\n loop next (pred idx)\n in loop n (pred digits)\n\nlet[@inline always] to_hex_nibble f : char =\n let a = 86 + f in\n let c = 1 + ((a - 71 * ((a land 0x10) lsr 4)) lor 0x20) in\n char_chr c\n\nlet hex_of_string rawbytes =\n String.init (2 * String.length rawbytes)\n (fun idx ->\n let byt = String.get rawbytes (idx lsr 1) |> Char.code in\n (* select which 4 bits to use, this can probably be done faster:*)\n let nib = 0xf land (byt lsr (((lnot idx) land 1) lsl 2)) in\n to_hex_nibble nib)\n\nlet hex_of_bytes rawbytes = hex_of_string (Bytes.unsafe_to_string rawbytes)\n\nlet[@inline always] select_a_if_in_range ~low ~high ~n a b =\n (* select [a] if [low <= n <= high] and [b] if [n] is out of range.*)\n (* NB: ONLY WORKS FOR [0 <= low <= high <= max_int]*)\n (* The idea being that:\n 1.a) if low <= n : (n - low) is positive +\n 1.b) if low > n : (n - low) is negative -\n 2.a) if n <= high: (high - n) is positive +\n 2.b) if n > high: (high - n) is negative -\n We OR the numbers together; we only really care about the sign bit\n which is set when negative.\n Thus both numbers are positive iff (low <= n && n <= high).\n We then select the sign bit with (land min_int) and use that to choose:\n *)\n let out_of_range = (* choose b if out of range *)\n ((n - low) lor (high - n)\n land min_int)\n in\n select_int out_of_range a b\n\nlet lowercase_ascii src =\n (* ct version of String.lowercase_ascii *)\n String.map\n ( fun ch -> let n = Char.code ch in\n (* 0x41 is 'A'; 0x5a is 'Z'; 0x20 controls case for ASCII letters *)\n select_a_if_in_range ~low:0x41 ~high:0x5a ~n (n lor 0x20) (n)\n |> char_chr\n ) src\n\nlet uppercase_ascii src =\n (* ct version of String.uppercase_ascii *)\n String.map\n ( fun ch -> let n = Char.code ch in\n (* 0x61 is 'a'; 0x7a is 'z'; 0x20 controls case for ASCII letters *)\n select_a_if_in_range ~low:0x61 ~high:0x7a ~n (n lxor 0x20) (n)\n |> char_chr\n ) src\n\nlet bytes_of_hex rawhex =\n (* hex length must be multiple of 2: *)\n let error_bitmap = ref ((String.length rawhex land 1) lsl 4) in\n let decoded =\n Bytes.init (String.length rawhex lsr 1)\n (fun idx ->\n let idx = idx lsl 1 in\n let nib idx =\n String.get rawhex idx\n |> Char.code\n |> fun n -> (* uppercase -> lowercase: *)\n select_a_if_in_range ~low:0x41 ~high:0x5a\n ~n\n (n lor 0x20) (* set case bit *)\n n (* leave as-is *)\n |> fun n -> (* now either invalid; lowercase; numeric*)\n (select_a_if_in_range ~low:0x30 ~high:0x39\n ~n\n (n - 0x30) (* numeric: subtract '0' to get [0..9] *)\n (select_a_if_in_range ~low:0x61 ~high:0x66\n ~n\n (* a-f: subtract 'a' and add 10 to get [10..15]: *)\n (n - 0x61 + 10)\n (0xff) (* invalid, ensure we set upper bits of error_bitmap *)\n )\n )\n in\n let nibf0 = nib idx\n and nib0f = nib (succ idx) in\n error_bitmap := !error_bitmap lor nibf0 lor nib0f ;\n char_chr ((nibf0 lsl 4) lor nib0f)\n )\n in\n (* if any non-nibble bits were set in !error_bitmap, decoding failed: *)\n decoded, !error_bitmap land (lnot 0xf)\n\nlet string_of_hex rawhex =\n let byt, error = bytes_of_hex rawhex in\n Bytes.unsafe_to_string byt, error\n","open Core_kernel\nopen Async_kernel\n\n[%%import \"/src/config.mlh\"]\n\nmodule Spec = struct\n type t =\n | On_disk of { directory : string; should_write : bool }\n | S3 of { bucket_prefix : string; install_path : string }\nend\n\n[%%inject \"may_download\", download_snark_keys]\n\nlet may_download = ref may_download\n\nlet set_downloads_enabled b = may_download := b\n\nlet may_download () = !may_download\n\nmodule T (M : sig\n type _ t\nend) =\nstruct\n type ('a, 'b) t = { write : 'a -> 'b -> unit M.t; read : 'a -> 'b M.t }\nend\n\nmodule Disk_storable (M : sig\n type _ t\nend) =\nstruct\n type ('k, 'v) t =\n { to_string : 'k -> string\n ; read : 'k -> path:string -> 'v M.t\n ; write : 'k -> 'v -> string -> unit M.t\n }\nend\n\nmodule type S = sig\n module M : sig\n type _ t\n end\n\n type ('a, 'b) t = ('a, 'b) T(M).t =\n { write : 'a -> 'b -> unit M.t; read : 'a -> 'b M.t }\n\n module Disk_storable : sig\n type ('k, 'v) t = ('k, 'v) Disk_storable(M).t =\n { to_string : 'k -> string\n ; read : 'k -> path:string -> 'v M.t\n ; write : 'k -> 'v -> string -> unit M.t\n }\n\n val of_binable :\n ('k -> string) -> (module Binable.S with type t = 'v) -> ('k, 'v) t\n\n val simple :\n ('k -> string)\n -> ('k -> path:string -> 'v M.t)\n -> ('k -> 'v -> string -> unit M.t)\n -> ('k, 'v) t\n end\n\n val read :\n Spec.t list\n -> ('k, 'v) Disk_storable.t\n -> 'k\n -> ('v * [> `Cache_hit | `Locally_generated ]) M.t\n\n val write : Spec.t list -> ('k, 'v) Disk_storable.t -> 'k -> 'v -> unit M.t\nend\n\nmodule type Sync = S with module M := Or_error\n\nmodule type Async = S with module M := Deferred.Or_error\n\nmodule Trivial : Sync = struct\n include T (Or_error)\n\n module Disk_storable = struct\n include Disk_storable (Or_error)\n\n let of_binable to_string _m =\n let read _ ~path:_ =\n Or_error.error_string \"Key_cache: Trivial store cannot read\"\n in\n let write _k _t _path = Ok () in\n { to_string; read; write }\n\n let simple to_string read write = { to_string; read; write }\n end\n\n let read _spec { Disk_storable.to_string = _; read = _; write = _ } _k =\n Or_error.error_string \"Key_cache: Trivial store cannot read\"\n\n let write _spec { Disk_storable.to_string = _; read = _; write = _ } _k _v =\n Ok ()\nend\n\nmodule Trivial_async : Async = struct\n include T (Deferred.Or_error)\n\n module Disk_storable = struct\n include Disk_storable (Deferred.Or_error)\n\n let of_binable to_string _m =\n let read _ ~path:_ =\n Deferred.Or_error.error_string \"Key_cache: Trivial store cannot read\"\n in\n let write _k _t _path = Deferred.Or_error.return () in\n { to_string; read; write }\n\n let simple to_string read write = { to_string; read; write }\n end\n\n let read _spec { Disk_storable.to_string = _; read = _; write = _ } _k =\n Deferred.Or_error.error_string \"Key_cache: Trivial store cannot read\"\n\n let write _spec { Disk_storable.to_string = _; read = _; write = _ } _k _v =\n Deferred.Or_error.return ()\nend\n\nlet sync = ref (module Trivial : Sync)\n\nlet async = ref (module Trivial_async : Async)\n\nlet set_sync_implementation x = sync := x\n\nlet set_async_implementation x = async := x\n\nmodule Sync : Sync = struct\n include T (Or_error)\n\n module Disk_storable = struct\n include Disk_storable (Or_error)\n\n let of_binable to_string binable =\n let (module M) = !sync in\n M.Disk_storable.of_binable to_string binable\n\n let simple to_string read write =\n let (module M) = !sync in\n M.Disk_storable.simple to_string read write\n end\n\n let read spec ds k =\n let (module M) = !sync in\n M.read spec ds k\n\n let write spec ds k v =\n let (module M) = !sync in\n M.write spec ds k v\nend\n\nmodule Async : Async = struct\n include T (Deferred.Or_error)\n\n module Disk_storable = struct\n include Disk_storable (Deferred.Or_error)\n\n let of_binable to_string binable =\n let (module M) = !async in\n M.Disk_storable.of_binable to_string binable\n\n let simple to_string read write =\n let (module M) = !async in\n M.Disk_storable.simple to_string read write\n end\n\n let read spec ds k =\n let (module M) = !async in\n M.read spec ds k\n\n let write spec ds k v =\n let (module M) = !async in\n M.write spec ds k v\nend\n","open Core_kernel\n\nmodule Partial = struct\n module Bin_io (M : Intf.Input.Bin_io_intf) :\n Intf.Partial.Bin_io_intf with type t := M.t = struct\n open Bin_prot.Type_class\n\n let bin_size_t = M.bin_size_t\n\n let bin_write_t = M.bin_write_t\n\n let bin_read_t buf ~pos_ref =\n Table.attach_finalizer M.id (M.bin_read_t buf ~pos_ref)\n\n let __bin_read_t__ buf ~pos_ref i =\n Table.attach_finalizer M.id (M.__bin_read_t__ buf ~pos_ref i)\n\n let bin_shape_t = M.bin_shape_t\n\n let bin_writer_t = M.bin_writer_t\n\n let bin_reader_t = { read = bin_read_t; vtag_read = __bin_read_t__ }\n\n let bin_t =\n { shape = bin_shape_t; writer = bin_writer_t; reader = bin_reader_t }\n end\n\n module Sexp (M : Intf.Input.Sexp_intf) :\n Intf.Partial.Sexp_intf with type t := M.t = struct\n let sexp_of_t = M.sexp_of_t\n\n let t_of_sexp t = Table.attach_finalizer M.id (M.t_of_sexp t)\n end\n\n module Yojson (M : Intf.Input.Yojson_intf) :\n Intf.Partial.Yojson_intf with type t := M.t = struct\n let to_yojson = M.to_yojson\n\n let of_yojson json =\n M.of_yojson json |> Result.map ~f:(Table.attach_finalizer M.id)\n end\nend\n\nmodule Basic (M : Intf.Input.Basic_intf) :\n Intf.Output.Basic_intf with type t = M.t and type 'a creator := 'a M.creator =\nstruct\n type t = M.t\n\n let create = M.map_creator M.create ~f:(Table.attach_finalizer M.id)\nend\n\nmodule Bin_io (M : Intf.Input.Bin_io_intf) :\n Intf.Output.Bin_io_intf with type t = M.t and type 'a creator := 'a M.creator =\nstruct\n include Basic (M)\n include Partial.Bin_io (M)\nend\n\nmodule Sexp (M : Intf.Input.Sexp_intf) :\n Intf.Output.Sexp_intf with type t = M.t and type 'a creator := 'a M.creator =\nstruct\n include Basic (M)\n include Partial.Sexp (M)\nend\n\nmodule Bin_io_and_sexp (M : Intf.Input.Bin_io_and_sexp_intf) :\n Intf.Output.Bin_io_and_sexp_intf\n with type t = M.t\n and type 'a creator := 'a M.creator = struct\n include Basic (M)\n include Partial.Bin_io (M)\n include Partial.Sexp (M)\nend\n\nmodule Yojson (M : Intf.Input.Yojson_intf) :\n Intf.Output.Yojson_intf with type t = M.t and type 'a creator := 'a M.creator =\nstruct\n include Basic (M)\n include Partial.Yojson (M)\nend\n\nmodule Bin_io_and_yojson (M : Intf.Input.Bin_io_and_yojson_intf) :\n Intf.Output.Bin_io_and_yojson_intf\n with type t = M.t\n and type 'a creator := 'a M.creator = struct\n include Basic (M)\n include Partial.Bin_io (M)\n include Partial.Yojson (M)\nend\n\nmodule Full (M : Intf.Input.Full_intf) :\n Intf.Output.Full_intf with type t = M.t and type 'a creator := 'a M.creator =\nstruct\n include Basic (M)\n include Partial.Bin_io (M)\n include Partial.Sexp (M)\n include Partial.Yojson (M)\nend\n\nmodule Versioned_v1 = struct\n module Basic_intf (M : Intf.Input.Versioned_v1.Basic_intf) : sig\n include\n Intf.Output.Versioned_v1.Basic_intf\n with type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V1 = struct\n include Bin_io (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n end\n\n module Sexp (M : Intf.Input.Versioned_v1.Sexp_intf) : sig\n include\n Intf.Output.Versioned_v1.Sexp_intf\n with type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V1 = struct\n include Bin_io_and_sexp (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n end\n\n module Yojson (M : Intf.Input.Versioned_v1.Yojson_intf) : sig\n include\n Intf.Output.Versioned_v1.Yojson_intf\n with type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V1 = struct\n include Bin_io_and_yojson (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n end\n\n module Full_compare_eq_hash\n (M : Intf.Input.Versioned_v1.Full_compare_eq_hash_intf) : sig\n include\n Intf.Output.Versioned_v1.Full_compare_eq_hash_intf\n with type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V1 = struct\n include Full (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let compare = M.Stable.V1.compare\n\n let equal = M.Stable.V1.equal\n\n let hash = M.Stable.V1.hash\n\n let hash_fold_t = M.Stable.V1.hash_fold_t\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n\n let equal = M.equal\n\n let compare = M.compare\n\n let hash = M.hash\n\n let hash_fold_t = M.hash_fold_t\n end\n\n module Full (M : Intf.Input.Versioned_v1.Full_intf) : sig\n include\n Intf.Output.Versioned_v1.Full_intf\n with type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V1 = struct\n include Full (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n end\nend\n\nmodule Versioned_v2 = struct\n module Sexp (M : Intf.Input.Versioned_v2.Sexp_intf) : sig\n include\n Intf.Output.Versioned_v2.Sexp_intf\n with type Stable.V2.t = M.Stable.V2.t\n and type 'a Stable.V2.creator = 'a M.Stable.V2.creator\n and type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V2 = struct\n include Bin_io_and_sexp (struct\n let id = M.id\n\n include M.Stable.V2\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V2.creator\n end\n\n module V1 = struct\n include Bin_io_and_sexp (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n\n let to_latest = M.Stable.V1.to_latest\n end\n\n module Latest = V2\n end\n\n type t = Stable.V2.t\n end\nend\n","type 'a t\n\nexternal run_in_thread : (unit -> 'a) -> 'a t = \"deferred_run\"\n\nlet block_on_async_exn (_ : unit -> 'a t) : 'a =\n failwith \"You can't block on async execution in JS\"\n\nexternal map : 'a t -> f:('a -> 'b) -> 'b t = \"deferred_map\"\n\nexternal bind : 'a t -> f:('a -> 'b t) -> 'b t = \"deferred_bind\"\n\nexternal upon : 'a t -> ('a -> unit) -> unit = \"deferred_upon\"\n\nexternal upon_exn : 'a t -> ('a -> unit) -> unit = \"deferred_upon_exn\"\n\nexternal is_determined : 'a t -> bool = \"deferred_is_determined\"\n\nexternal peek : 'a t -> 'a option = \"deferred_peek\"\n\nexternal value_exn : 'a t -> 'a = \"deferred_value_exn\"\n\nexternal return : 'a -> 'a t = \"deferred_return\"\n\nexternal create : (('a -> unit) -> unit) -> 'a t = \"deferred_create\"\n\nlet to_deferred promise =\n let module Ivar = Async_kernel.Ivar in\n let ivar = Ivar.create () in\n upon_exn promise (fun x -> Ivar.fill ivar x) ;\n Ivar.read ivar\n\ninclude Base.Monad.Make (struct\n type nonrec 'a t = 'a t\n\n let map = `Custom map\n\n let bind = bind\n\n let return = return\nend)\n","open Core_kernel\n\nlet key = Univ_map.Key.create ~name:\"logger\" sexp_of_opaque\n\nlet with_logger logger f =\n Async_kernel.Async_kernel_scheduler.with_local key logger ~f\n\nlet get_opt () = Async_kernel.Async_kernel_scheduler.find_local key\n\nlet get () = Option.value (get_opt ()) ~default:(Logger.null ())\n","open Intf\nopen Core_kernel\n\nmodule type Inputs_intf = sig\n module Base_field : sig\n type t\n end\n\n module Curve : sig\n module Affine : sig\n type t = Base_field.t * Base_field.t\n\n module Backend : sig\n type t = Base_field.t Kimchi_types.or_infinity\n\n val zero : unit -> t\n\n val create : Base_field.t -> Base_field.t -> t\n end\n\n val of_backend :\n Backend.t -> (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t\n end\n end\n\n module Backend : sig\n type t\n\n val make :\n Curve.Affine.Backend.t array -> Curve.Affine.Backend.t option -> t\n\n val shifted : t -> Curve.Affine.Backend.t option\n\n val unshifted : t -> Curve.Affine.Backend.t array\n end\nend\n\ntype 'a t =\n [ `With_degree_bound of\n ('a * 'a) Pickles_types.Or_infinity.t\n Pickles_types.Plonk_types.Poly_comm.With_degree_bound.t\n | `Without_degree_bound of\n ('a * 'a) Pickles_types.Plonk_types.Poly_comm.Without_degree_bound.t ]\n\nmodule Make (Inputs : Inputs_intf) = struct\n open Inputs\n module Backend = Backend\n\n type nonrec t = Base_field.t t\n\n module G_affine = Curve.Affine.Backend\n\n let g (a, b) = G_affine.create a b\n\n let g_vec arr = Array.map ~f:g arr\n\n let or_infinity_to_backend :\n ('a * 'a) Pickles_types.Or_infinity.t -> 'a Kimchi_types.or_infinity =\n function\n | Infinity ->\n Infinity\n | Finite (x, y) ->\n Finite (x, y)\n\n let or_infinity_of_backend :\n 'a Kimchi_types.or_infinity -> ('a * 'a) Pickles_types.Or_infinity.t =\n function\n | Infinity ->\n Infinity\n | Finite (x, y) ->\n Finite (x, y)\n\n let with_degree_bound_to_backend\n (commitment :\n (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t\n Pickles_types.Plonk_types.Poly_comm.With_degree_bound.t ) : Backend.t =\n Backend.make\n (Array.map ~f:or_infinity_to_backend commitment.unshifted)\n (Some (or_infinity_to_backend commitment.shifted))\n\n let without_degree_bound_to_backend\n (commitment :\n (Base_field.t * Base_field.t)\n Pickles_types.Plonk_types.Poly_comm.Without_degree_bound.t ) : Backend.t\n =\n Backend.make\n (Array.map ~f:(fun x -> Kimchi_types.Finite (fst x, snd x)) commitment)\n None\n\n let to_backend (t : t) : Backend.t =\n match t with\n | `With_degree_bound t ->\n with_degree_bound_to_backend t\n | `Without_degree_bound t ->\n without_degree_bound_to_backend t\n\n let of_backend' (t : Backend.t) =\n ( Backend.unshifted t\n , Option.map (Backend.shifted t) ~f:Curve.Affine.of_backend )\n\n let of_backend_with_degree_bound (t : Backend.t) : t =\n let open Pickles_types.Plonk_types.Poly_comm in\n match Backend.shifted t with\n | None ->\n assert false\n | Some shifted ->\n let shifted = or_infinity_of_backend shifted in\n let unshifted =\n Backend.unshifted t |> Array.map ~f:or_infinity_of_backend\n in\n `With_degree_bound { unshifted; shifted }\n\n (*\n type 'a t =\n [ `With_degree_bound of\n ('a * 'a) Pickles_types.Or_infinity.t\n Pickles_types.Plonk_types.Poly_comm.With_degree_bound.t\n | `Without_degree_bound of\n ('a * 'a) Pickles_types.Plonk_types.Poly_comm.Without_degree_bound.t\n ]\n *)\n\n let of_backend_without_degree_bound (t : Backend.t) =\n let open Pickles_types.Plonk_types.Poly_comm in\n let unshifted = Backend.unshifted t in\n match Backend.shifted t with\n | None ->\n `Without_degree_bound\n (Array.map unshifted ~f:(function\n | Infinity ->\n failwith\n \"Pickles cannot handle point at infinity. Commitments must \\\n be representable in affine coordinates\"\n | Finite (x, y) ->\n (x, y) ) )\n | _ ->\n assert false\nend\n","open Core_kernel\nopen Intf\n\nmodule type Inputs_intf = sig\n module Verifier_index : T0\n\n module Field : sig\n type t\n end\n\n module Proof : sig\n type t\n\n type with_public_evals\n\n module Challenge_polynomial : T0\n\n module Backend : sig\n type t\n\n type with_public_evals\n end\n\n val to_backend :\n Challenge_polynomial.t list -> Field.t list -> t -> Backend.t\n\n val to_backend_with_public_evals :\n Challenge_polynomial.t list\n -> Field.t list\n -> with_public_evals\n -> Backend.with_public_evals\n end\n\n module Backend : sig\n type t = Field.t Kimchi_types.oracles\n\n val create : Verifier_index.t -> Proof.Backend.t -> t\n\n val create_with_public_evals :\n Verifier_index.t -> Proof.Backend.with_public_evals -> t\n end\nend\n\nmodule Make (Inputs : Inputs_intf) = struct\n open Inputs\n\n let create vk prev_challenge input (pi : Proof.t) =\n let pi = Proof.to_backend prev_challenge input pi in\n Backend.create vk pi\n\n let create_with_public_evals vk prev_challenge input\n (pi : Proof.with_public_evals) =\n let pi = Proof.to_backend_with_public_evals prev_challenge input pi in\n Backend.create_with_public_evals vk pi\n\n open Backend\n\n let scalar_challenge t = Scalar_challenge.create t\n\n let alpha (t : t) = t.o.alpha_chal\n\n let beta (t : t) = t.o.beta\n\n let gamma (t : t) = t.o.gamma\n\n let zeta (t : t) = t.o.zeta_chal\n\n let joint_combiner_chal (t : t) = Option.map ~f:fst t.o.joint_combiner\n\n let joint_combiner (t : t) = Option.map ~f:snd t.o.joint_combiner\n\n let digest_before_evaluations (t : t) = t.digest_before_evaluations\n\n let v (t : t) = t.o.v_chal\n\n let u (t : t) = t.o.u_chal\n\n let p_eval_1 (t : t) = fst t.p_eval\n\n let p_eval_2 (t : t) = snd t.p_eval\n\n let opening_prechallenges (t : t) =\n Array.map ~f:scalar_challenge t.opening_prechallenges\nend\n","(** number of witness *)\nlet columns = 15\n\n(** number of columns that take part in the permutation *)\nlet permutation_cols = 7\n","module Poly_comm0 = Poly_comm\nopen Unsigned.Size_t\n\nmodule type Stable_v1 = sig\n module Stable : sig\n module V1 : sig\n type t [@@deriving version, bin_io, sexp, compare, yojson, hash, equal]\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t [@@deriving sexp, compare, yojson]\nend\n\nmodule type Inputs_intf = sig\n open Intf\n\n val name : string\n\n module Rounds : Pickles_types.Nat.Intf\n\n module Gate_vector : sig\n open Unsigned\n\n type t\n\n val wrap : t -> Kimchi_types.wire -> Kimchi_types.wire -> unit\n end\n\n module Urs : sig\n type t\n\n val read : int option -> string -> t option\n\n val write : bool option -> t -> string -> unit\n\n val create : int -> t\n end\n\n module Scalar_field : sig\n include Stable_v1\n\n val one : t\n end\n\n module Constraint_system : sig\n type t\n\n val get_primary_input_size : t -> int\n\n val get_prev_challenges : t -> int option\n\n val set_prev_challenges : t -> int -> unit\n\n val finalize_and_get_gates :\n t\n -> Gate_vector.t\n * Scalar_field.t Kimchi_types.lookup_table array\n * Scalar_field.t Kimchi_types.runtime_table_cfg array\n end\n\n module Index : sig\n type t\n\n (** [create\n gates\n nb_public\n runtime_tables_cfg\n nb_prev_challanges\n srs] *)\n val create :\n Gate_vector.t\n -> int\n -> Scalar_field.t Kimchi_types.lookup_table array\n -> Scalar_field.t Kimchi_types.runtime_table_cfg array\n -> int\n -> Urs.t\n -> t\n end\n\n module Curve : sig\n module Base_field : sig\n type t\n end\n\n module Affine : sig\n type t = Base_field.t * Base_field.t\n end\n end\n\n module Poly_comm : sig\n module Backend : sig\n type t\n end\n\n type t = Curve.Base_field.t Poly_comm0.t\n\n val of_backend_without_degree_bound : Backend.t -> t\n end\n\n module Verifier_index : sig\n type t =\n ( Scalar_field.t\n , Urs.t\n , Poly_comm.Backend.t )\n Kimchi_types.VerifierIndex.verifier_index\n\n val create : Index.t -> t\n end\nend\n\nmodule Make (Inputs : Inputs_intf) = struct\n open Core_kernel\n\n type t = { index : Inputs.Index.t; cs : Inputs.Constraint_system.t }\n\n let name =\n sprintf \"%s_%d_v4\" Inputs.name (Pickles_types.Nat.to_int Inputs.Rounds.n)\n\n let set_urs_info, load_urs =\n let urs_info = Set_once.create () in\n let urs = ref None in\n let degree = 1 lsl Pickles_types.Nat.to_int Inputs.Rounds.n in\n let set_urs_info specs = Set_once.set_exn urs_info Lexing.dummy_pos specs in\n let load () =\n match !urs with\n | Some urs ->\n urs\n | None ->\n let specs =\n match Set_once.get urs_info with\n | None ->\n failwith \"Dlog_based.urs: Info not set\"\n | Some t ->\n t\n in\n let store =\n Key_cache.Sync.Disk_storable.simple\n (fun () -> name)\n (fun () ~path ->\n Or_error.try_with_join (fun () ->\n match Inputs.Urs.read None path with\n | Some urs ->\n Ok urs\n | None ->\n Or_error.errorf\n \"Could not read the URS from disk; its format did \\\n not match the expected format\" ) )\n (fun _ urs path ->\n Or_error.try_with (fun () -> Inputs.Urs.write None urs path) )\n in\n let u =\n match Key_cache.Sync.read specs store () with\n | Ok (u, _) ->\n u\n | Error _e ->\n let urs = Inputs.Urs.create degree in\n let (_ : (unit, Error.t) Result.t) =\n Key_cache.Sync.write\n (List.filter specs ~f:(function\n | On_disk _ ->\n true\n | S3 _ ->\n false ) )\n store () urs\n in\n urs\n in\n urs := Some u ;\n u\n in\n (set_urs_info, load)\n\n let create ~prev_challenges cs =\n let gates, fixed_lookup_tables, runtime_table_cfgs =\n Inputs.Constraint_system.finalize_and_get_gates cs\n in\n let public_input_size =\n Inputs.Constraint_system.get_primary_input_size cs\n in\n let prev_challenges =\n match Inputs.Constraint_system.get_prev_challenges cs with\n | None ->\n Inputs.Constraint_system.set_prev_challenges cs prev_challenges ;\n prev_challenges\n | Some prev_challenges' ->\n assert (prev_challenges = prev_challenges') ;\n prev_challenges'\n in\n let index =\n Inputs.Index.create gates public_input_size fixed_lookup_tables\n runtime_table_cfgs prev_challenges (load_urs ())\n in\n { index; cs }\n\n let vk t = Inputs.Verifier_index.create t.index\n\n let pk t = t\n\n let array_to_vector a = Pickles_types.Vector.of_list (Array.to_list a)\n\n (** does this convert a backend.verifier_index to a pickles_types.verifier_index? *)\n let vk_commitments (t : Inputs.Verifier_index.t) :\n Inputs.Curve.Affine.t Pickles_types.Plonk_verification_key_evals.t =\n let g c : Inputs.Curve.Affine.t =\n match Inputs.Poly_comm.of_backend_without_degree_bound c with\n | `Without_degree_bound x ->\n x.(0)\n | `With_degree_bound _ ->\n assert false\n in\n { sigma_comm =\n Pickles_types.Vector.init Pickles_types.Plonk_types.Permuts.n\n ~f:(fun i -> g t.evals.sigma_comm.(i))\n ; coefficients_comm =\n Pickles_types.Vector.init Pickles_types.Plonk_types.Columns.n\n ~f:(fun i -> g t.evals.coefficients_comm.(i))\n ; generic_comm = g t.evals.generic_comm\n ; psm_comm = g t.evals.psm_comm\n ; complete_add_comm = g t.evals.complete_add_comm\n ; mul_comm = g t.evals.mul_comm\n ; emul_comm = g t.evals.emul_comm\n ; endomul_scalar_comm = g t.evals.endomul_scalar_comm\n }\n\n let full_vk_commitments (t : Inputs.Verifier_index.t) :\n ( Inputs.Curve.Affine.t\n , Inputs.Curve.Affine.t option )\n Pickles_types.Plonk_verification_key_evals.Step.t =\n let g c : Inputs.Curve.Affine.t =\n match Inputs.Poly_comm.of_backend_without_degree_bound c with\n | `Without_degree_bound x ->\n x.(0)\n | `With_degree_bound _ ->\n assert false\n in\n let lookup f =\n let open Option.Let_syntax in\n let%bind l = t.lookup_index in\n f l >>| g\n in\n { sigma_comm =\n Pickles_types.Vector.init Pickles_types.Plonk_types.Permuts.n\n ~f:(fun i -> g t.evals.sigma_comm.(i))\n ; coefficients_comm =\n Pickles_types.Vector.init Pickles_types.Plonk_types.Columns.n\n ~f:(fun i -> g t.evals.coefficients_comm.(i))\n ; generic_comm = g t.evals.generic_comm\n ; psm_comm = g t.evals.psm_comm\n ; complete_add_comm = g t.evals.complete_add_comm\n ; mul_comm = g t.evals.mul_comm\n ; emul_comm = g t.evals.emul_comm\n ; endomul_scalar_comm = g t.evals.endomul_scalar_comm\n ; xor_comm = Option.map ~f:g t.evals.xor_comm\n ; range_check0_comm = Option.map ~f:g t.evals.range_check0_comm\n ; range_check1_comm = Option.map ~f:g t.evals.range_check1_comm\n ; foreign_field_add_comm = Option.map ~f:g t.evals.foreign_field_add_comm\n ; foreign_field_mul_comm = Option.map ~f:g t.evals.foreign_field_mul_comm\n ; rot_comm = Option.map ~f:g t.evals.rot_comm\n ; lookup_table_comm =\n Pickles_types.Vector.init\n Pickles_types.Plonk_types.Lookup_sorted_minus_1.n ~f:(fun i ->\n lookup (fun l -> Option.try_with (fun () -> l.lookup_table.(i))) )\n ; lookup_table_ids = lookup (fun l -> l.table_ids)\n ; runtime_tables_selector = lookup (fun l -> l.runtime_tables_selector)\n ; lookup_selector_lookup = lookup (fun l -> l.lookup_selectors.lookup)\n ; lookup_selector_xor = lookup (fun l -> l.lookup_selectors.xor)\n ; lookup_selector_range_check =\n lookup (fun l -> l.lookup_selectors.range_check)\n ; lookup_selector_ffmul = lookup (fun l -> l.lookup_selectors.ffmul)\n }\nend\n","module Bigint = Bigint\nmodule Field = Field\nmodule Curve = Curve\nmodule Poly_comm = Poly_comm\nmodule Plonk_constraint_system = Plonk_constraint_system\nmodule Dlog_plonk_based_keypair = Dlog_plonk_based_keypair\nmodule Constants = Constants\nmodule Plonk_dlog_proof = Plonk_dlog_proof\nmodule Plonk_dlog_oracles = Plonk_dlog_oracles\nmodule Scalar_challenge = Scalar_challenge\nmodule Endoscale_round = Endoscale_round\nmodule Scale_round = Scale_round\nmodule Endoscale_scalar_round = Endoscale_scalar_round\nmodule Intf = Intf\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\nmodule Backend = Kimchi_backend.Pasta.Vesta_based_plonk\nmodule Impl = Pickles.Impls.Step\nmodule Field = Impl.Field\nmodule Boolean = Impl.Boolean\nmodule As_prover = Impl.As_prover\nmodule Typ = Impl.Typ\n\n(* light-weight wrapper around snarky-ml core *)\n\nlet typ (size_in_fields : int) = Typ.array ~length:size_in_fields Field.typ\n\nlet exists (size_in_fields : int) (compute : unit -> Field.Constant.t array) =\n Impl.exists (typ size_in_fields) ~compute\n\nlet exists_var (compute : unit -> Field.Constant.t) =\n Impl.exists Field.typ ~compute\n\nmodule Run = struct\n let as_prover = Impl.as_prover\n\n let in_prover_block () = As_prover.in_prover_block () |> Js.bool\n\n let run_and_check (f : unit -> unit) =\n try\n Impl.run_and_check_exn (fun () ->\n f () ;\n fun () -> () )\n with exn -> Util.raise_exn exn\n\n let run_unchecked (f : unit -> unit) =\n try\n Impl.run_and_check_exn (fun () ->\n Snarky_backendless.Snark0.set_eval_constraints false ;\n f () ;\n Snarky_backendless.Snark0.set_eval_constraints true ;\n fun () -> () )\n with exn -> Util.raise_exn exn\n\n let constraint_system (main : unit -> unit) =\n let cs =\n Impl.constraint_system ~input_typ:Impl.Typ.unit ~return_typ:Impl.Typ.unit\n (fun () -> main)\n in\n object%js\n val rows = Backend.R1CS_constraint_system.get_rows_len cs\n\n val digest =\n Backend.R1CS_constraint_system.digest cs |> Md5.to_hex |> Js.string\n\n val json =\n Backend.R1CS_constraint_system.to_json cs\n |> Js.string |> Util.json_parse\n end\nend\n\nmodule Field' = struct\n (** add x, y to get a new AST node Add(x, y); handles if x, y are constants *)\n let add x y = Field.add x y\n\n (** scale x by a constant to get a new AST node Scale(c, x); handles if x is a constant; handles c=0,1 *)\n let scale c x = Field.scale x c\n\n (** witnesses z = x*y and constrains it with [assert_r1cs]; handles constants *)\n let mul x y = Field.mul x y\n\n (** evaluates a CVar by unfolding the AST and reading Vars from a list of public input + aux values *)\n let read_var (x : Field.t) = As_prover.read_var x\n\n (** x === y without handling of constants *)\n let assert_equal x y = Impl.assert_ (Impl.Constraint.equal x y)\n\n (** x*y === z without handling of constants *)\n let assert_mul x y z = Impl.assert_ (Impl.Constraint.r1cs x y z)\n\n (** x*x === y without handling of constants *)\n let assert_square x y = Impl.assert_ (Impl.Constraint.square x y)\n\n (** x*x === x without handling of constants *)\n let assert_boolean x = Impl.assert_ (Impl.Constraint.boolean x)\n\n (** check x < y and x <= y.\n this is used in all comparisons, including with assert *)\n let compare (bit_length : int) x y =\n let ({ less; less_or_equal } : Field.comparison_result) =\n Field.compare ~bit_length x y\n in\n (less, less_or_equal)\n\n let to_bits (length : int) x =\n Field.choose_preimage_var ~length x |> Array.of_list\n\n let from_bits bits = Array.to_list bits |> Field.project\n\n (** returns x truncated to the lowest [16 * length_div_16] bits\n => can be used to assert that x fits in [16 * length_div_16] bits.\n\n more efficient than [to_bits] because it uses the [EC_endoscalar] gate;\n does 16 bits per row (vs 1 bits per row that you can do with generic gates).\n *)\n let truncate_to_bits16 (length_div_16 : int) x =\n let _a, _b, x0 =\n Pickles.Scalar_challenge.to_field_checked' ~num_bits:(length_div_16 * 16)\n (module Impl)\n { inner = x }\n in\n x0\n\n (* can be implemented with Field.to_constant_and_terms *)\n let seal x = Pickles.Util.seal (module Impl) x\n\n let to_constant_and_terms x = Field.to_constant_and_terms x\nend\n\nmodule Bool = struct\n let not x = Boolean.not x\n\n let and_ x y = Boolean.(x &&& y)\n\n let or_ x y = Boolean.(x ||| y)\n\n let assert_equal x y = Boolean.Assert.(x = y)\n\n let equals x y = Boolean.equal x y\nend\n\nmodule Group = struct\n let ec_add p1 p2 p3 inf same_x slope inf_z x21_inv =\n let open Impl in\n with_label \"Elliptic Curve Addition\" (fun () ->\n assert_\n { annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.T\n (EC_add_complete\n { p1; p2; p3; inf; same_x; slope; inf_z; x21_inv } )\n } ;\n p3 )\n\n let scale p (scalar_bits : Boolean.var array) =\n Pickles.Step_main_inputs.Ops.scale_fast_msb_bits p\n (Shifted_value scalar_bits)\nend\n\nmodule Circuit = struct\n module Main = struct\n let of_js (main : Field.t array -> unit) =\n let main' public_input () = main public_input in\n main'\n end\n\n let compile main public_input_size =\n let input_typ = typ public_input_size in\n let return_typ = Impl.Typ.unit in\n let cs = Impl.constraint_system ~input_typ ~return_typ (Main.of_js main) in\n Impl.Keypair.generate ~prev_challenges:0 cs\n\n let prove main public_input_size public_input keypair =\n let pk = Impl.Keypair.pk keypair in\n let input_typ = typ public_input_size in\n let return_typ = Impl.Typ.unit in\n Impl.generate_witness_conv ~input_typ ~return_typ\n ~f:(fun { Impl.Proof_inputs.auxiliary_inputs; public_inputs } () ->\n Backend.Proof.create pk ~auxiliary:auxiliary_inputs\n ~primary:public_inputs )\n (Main.of_js main) public_input\n\n let verify public_input proof vk =\n let public_input_vec = Backend.Field.Vector.create () in\n Array.iter public_input ~f:(fun x ->\n Backend.Field.Vector.emplace_back public_input_vec x ) ;\n Backend.Proof.verify proof vk public_input_vec |> Js.bool\n\n module Keypair = struct\n let get_vk t = Impl.Keypair.vk t\n\n external prover_to_json :\n Kimchi_bindings.Protocol.Index.Fp.t -> Js.js_string Js.t\n = \"prover_to_json\"\n\n let get_cs_json t =\n (Impl.Keypair.pk t).index |> prover_to_json |> Util.json_parse\n end\nend\n\nmodule Poseidon = struct\n let update (state : Field.t Random_oracle.State.t) (input : Field.t array) :\n Field.t Random_oracle.State.t =\n Random_oracle.Checked.update ~state input\n\n let hash_to_group (xs : Field.t array) =\n let input = Random_oracle.Checked.hash xs in\n Snark_params.Group_map.Checked.to_group input\n\n (* sponge *)\n\n let to_unchecked (x : Field.t) =\n match x with Constant y -> y | y -> As_prover.read_var y\n\n module Poseidon_sponge_checked =\n Sponge.Make_sponge (Pickles.Step_main_inputs.Sponge.Permutation)\n module Poseidon_sponge =\n Sponge.Make_sponge (Sponge.Poseidon (Pickles.Tick_field_sponge.Inputs))\n\n let sponge_params = Kimchi_pasta_basic.poseidon_params_fp\n\n let sponge_params_checked = Sponge.Params.map sponge_params ~f:Field.constant\n\n type sponge =\n | Checked of Poseidon_sponge_checked.t\n | Unchecked of Poseidon_sponge.t\n\n (* returns a \"sponge\" that stays opaque to JS *)\n let sponge_create (is_checked : bool Js.t) : sponge =\n if Js.to_bool is_checked then\n Checked (Poseidon_sponge_checked.create ?init:None sponge_params_checked)\n else Unchecked (Poseidon_sponge.create ?init:None sponge_params)\n\n let sponge_absorb (sponge : sponge) (field : Field.t) : unit =\n match sponge with\n | Checked s ->\n Poseidon_sponge_checked.absorb s field\n | Unchecked s ->\n Poseidon_sponge.absorb s @@ to_unchecked field\n\n let sponge_squeeze (sponge : sponge) : Field.t =\n match sponge with\n | Checked s ->\n Poseidon_sponge_checked.squeeze s\n | Unchecked s ->\n Poseidon_sponge.squeeze s |> Impl.Field.constant\nend\n\nlet snarky =\n object%js\n method exists = exists\n\n method existsVar = exists_var\n\n val run =\n let open Run in\n object%js\n method asProver = as_prover\n\n val inProverBlock = in_prover_block\n\n method runAndCheck = run_and_check\n\n method runUnchecked = run_unchecked\n\n method constraintSystem = constraint_system\n end\n\n val field =\n let open Field' in\n object%js\n method add = add\n\n method scale = scale\n\n method mul = mul\n\n method readVar = read_var\n\n method assertEqual = assert_equal\n\n method assertMul = assert_mul\n\n method assertSquare = assert_square\n\n method assertBoolean = assert_boolean\n\n method compare = compare\n\n method toBits = to_bits\n\n method fromBits = from_bits\n\n method truncateToBits16 = truncate_to_bits16\n\n method seal = seal\n\n method toConstantAndTerms = to_constant_and_terms\n end\n\n val bool =\n object%js\n method not = Bool.not\n\n method and_ = Bool.and_\n\n method or_ = Bool.or_\n\n method assertEqual = Bool.assert_equal\n\n method equals = Bool.equals\n end\n\n val group =\n object%js\n method ecadd = Group.ec_add\n\n method scale = Group.scale\n end\n\n val circuit =\n object%js\n method compile = Circuit.compile\n\n method prove = Circuit.prove\n\n method verify = Circuit.verify\n\n val keypair =\n object%js\n method getVerificationKey = Circuit.Keypair.get_vk\n\n method getConstraintSystemJSON = Circuit.Keypair.get_cs_json\n end\n end\n\n val poseidon =\n object%js\n method update = Poseidon.update\n\n method hashToGroup = Poseidon.hash_to_group\n\n val sponge =\n object%js\n method create = Poseidon.sponge_create\n\n method absorb = Poseidon.sponge_absorb\n\n method squeeze = Poseidon.sponge_squeeze\n end\n end\n end\n","open Kimchi_backend_common\nopen Kimchi_pasta_basic\n\ninclude\n Plonk_constraint_system.Make (Fp) (Kimchi_bindings.Protocol.Gates.Vector.Fp)\n (struct\n let params = poseidon_params_fp\n end)\n","open Kimchi_backend_common\nopen Kimchi_pasta_basic\n\ninclude\n Plonk_constraint_system.Make (Fq) (Kimchi_bindings.Protocol.Gates.Vector.Fq)\n (struct\n let params = poseidon_params_fq\n end)\n","module Basic = Kimchi_pasta_basic\n\nmodule Pallas_based_plonk = struct\n module Field = Pallas_based_plonk.Field\n module Curve = Pallas_based_plonk.Curve\n module Bigint = Pallas_based_plonk.Bigint\n\n let field_size = Pallas_based_plonk.field_size\n\n module Verification_key = Pallas_based_plonk.Verification_key\n module R1CS_constraint_system = Pallas_based_plonk.R1CS_constraint_system\n module Rounds_vector = Pallas_based_plonk.Rounds_vector\n module Rounds = Pallas_based_plonk.Rounds\n module Keypair = Pallas_based_plonk.Keypair\n module Proof = Pallas_based_plonk.Proof\n module Proving_key = Pallas_based_plonk.Proving_key\n module Oracles = Pallas_based_plonk.Oracles\nend\n\nmodule Vesta_based_plonk = struct\n module Field = Vesta_based_plonk.Field\n module Curve = Vesta_based_plonk.Curve\n module Bigint = Vesta_based_plonk.Bigint\n\n let field_size = Vesta_based_plonk.field_size\n\n module Verification_key = Vesta_based_plonk.Verification_key\n module R1CS_constraint_system = Vesta_based_plonk.R1CS_constraint_system\n module Rounds_vector = Vesta_based_plonk.Rounds_vector\n module Rounds = Vesta_based_plonk.Rounds\n module Keypair = Vesta_based_plonk.Keypair\n module Proof = Vesta_based_plonk.Proof\n module Proving_key = Vesta_based_plonk.Proving_key\n module Oracles = Vesta_based_plonk.Oracles\nend\n\nmodule Pasta = struct\n module Rounds = Pasta.Rounds\n module Bigint256 = Pasta.Bigint256\n module Fp = Pasta.Fp\n module Fq = Pasta.Fq\n module Vesta = Pasta.Vesta\n module Pallas = Pasta.Pallas\nend\n","open Utils\n\nmodule Types = struct\n module type S = V1S0\nend\n\nmodule type Concrete = Types.S with type V1.t = Unsigned.UInt64.t\n\nmodule M = struct\n module V1 = struct\n type t = Unsigned.UInt64.t\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\n(** We first define a [Types] module, with the expected final signature of this\n module (hidden types should be hidden here) *)\nmodule Types = struct\n module type S = sig\n module Fee : V1S0\n\n module Amount : V1S0\n\n module Balance : V1S0\n end\nend\n\n(** We define a module type [Concrete], where we replace hidden types in\n {!Types.S} by their actual definition. This module will not be exported. *)\nmodule type Concrete =\n Types.S\n with type Fee.V1.t = Unsigned.UInt64.t\n and type Amount.V1.t = Unsigned.UInt64.t\n and type Balance.V1.t = Unsigned.UInt64.t\n\n(** Then we define the actual module [M] with its type definitions. It must be\n compatible with {!Concrete} *)\nmodule M = struct\n module Fee = struct\n module V1 = struct\n type t = Unsigned.UInt64.t\n end\n end\n\n module Amount = struct\n module V1 = struct\n type t = Unsigned.UInt64.t\n end\n end\n\n module Balance = struct\n module V1 = struct\n type t = Amount.V1.t\n end\n end\nend\n\n(** [Local_sig] is the type of functors which receive a {!Types.S} module and\n return a complete module signature (with operations etc.) based on these\n types. It will be expected to be given by the implementation module. *)\nmodule type Local_sig = Signature(Types).S\n\n(** To make a full module, the implementation module will have to use [Make] and\n provide: (i) a {!Local_sig} functor to know the final signature of the\n module and (ii) a functor which takes the concrete types defined here and\n make the actual full module, adding type equalities where needed. *)\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n\n(** Finally, we include our module to make the types available to everyone (they\n will be hidden in the MLI *)\ninclude M\n","open Utils\n\nmodule Branch_data = struct\n module Types = struct\n module type S = sig\n module Domain_log2 : V1S0\n\n module V1 : sig\n type t =\n { proofs_verified : Pickles_base.Proofs_verified.V1.t\n ; domain_log2 : Domain_log2.V1.t\n }\n end\n end\n end\n\n module type Concrete = Types.S with type Domain_log2.V1.t = char\n\n module M = struct\n module Domain_log2 = struct\n module V1 = struct\n type t = char\n end\n end\n\n module V1 = struct\n type t =\n { proofs_verified : Pickles_base.Proofs_verified.V1.t\n ; domain_log2 : Domain_log2.V1.t\n }\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Wrap = struct\n module Proof_state = struct\n module Messages_for_next_wrap_proof = struct\n module V1 = struct\n type ('g1, 'bulletproof_challenges) t =\n { challenge_polynomial_commitment : 'g1\n ; old_bulletproof_challenges : 'bulletproof_challenges\n }\n end\n end\n\n module Deferred_values = struct\n module Plonk = struct\n module Minimal = struct\n module V1 = struct\n type ('challenge, 'scalar_challenge, 'bool) t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n ; joint_combiner : 'scalar_challenge option\n ; feature_flags :\n 'bool Pickles_types.Plonk_types.Features.Stable.V1.t\n }\n end\n end\n end\n\n module V1 = struct\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n t =\n { plonk : 'plonk\n ; combined_inner_product : 'fp\n ; b : 'fp\n ; xi : 'scalar_challenge\n ; bulletproof_challenges : 'bulletproof_challenges\n ; branch_data : 'branch_data\n }\n end\n\n module Minimal = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'bulletproof_challenges\n , 'branch_data )\n t =\n { plonk : ('challenge, 'scalar_challenge, 'bool) Plonk.Minimal.V1.t\n ; bulletproof_challenges : 'bulletproof_challenges\n ; branch_data : 'branch_data\n }\n end\n end\n end\n\n module V1 = struct\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n t =\n { deferred_values :\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bp_chals\n , 'index )\n Deferred_values.V1.t\n ; sponge_digest_before_evaluations : 'digest\n ; messages_for_next_wrap_proof : 'messages_for_next_wrap_proof\n }\n end\n\n module Minimal = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n t =\n { deferred_values :\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'bp_chals\n , 'index )\n Deferred_values.Minimal.V1.t\n ; sponge_digest_before_evaluations : 'digest\n ; messages_for_next_wrap_proof : 'messages_for_next_wrap_proof\n }\n end\n end\n end\n\n module Statement = struct\n module V1 = struct\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n t =\n { proof_state :\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Proof_state.V1.t\n ; messages_for_next_step_proof : 'messages_for_next_step_proof\n }\n end\n\n module Minimal = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n t =\n { proof_state :\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Proof_state.Minimal.V1.t\n ; messages_for_next_step_proof : 'messages_for_next_step_proof\n }\n end\n end\n end\nend\n","open Utils\n\nmodule M = struct\n module Backend = struct\n module Tick = struct\n module Field = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\n end\n end\n end\n\n module Wrap_wire_proof = struct\n module Columns_vec = Pickles_types.Vector.Vector_15\n module Coefficients_vec = Pickles_types.Vector.Vector_15\n module Quotient_polynomial_vec = Pickles_types.Vector.Vector_7\n module Permuts_minus_1_vec = Pickles_types.Vector.Vector_6\n\n module Commitments = struct\n module V1 = struct\n type t =\n { w_comm :\n (Pasta_bindings.Fp.t * Pasta_bindings.Fp.t)\n Columns_vec.Stable.V1.t\n ; z_comm : Pasta_bindings.Fp.t * Pasta_bindings.Fp.t\n ; t_comm :\n (Pasta_bindings.Fp.t * Pasta_bindings.Fp.t)\n Quotient_polynomial_vec.Stable.V1.t\n }\n end\n end\n\n module Evaluations = struct\n module V1 = struct\n type t =\n { w :\n (Pasta_bindings.Fq.t * Pasta_bindings.Fq.t)\n Columns_vec.Stable.V1.t\n ; coefficients :\n (Pasta_bindings.Fq.t * Pasta_bindings.Fq.t)\n Columns_vec.Stable.V1.t\n ; z : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; s :\n (Pasta_bindings.Fq.t * Pasta_bindings.Fq.t)\n Permuts_minus_1_vec.Stable.V1.t\n ; generic_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; poseidon_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; complete_add_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; mul_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; emul_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; endomul_scalar_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n }\n end\n end\n\n module V1 = struct\n type t =\n { commitments : Commitments.V1.t\n ; evaluations : Evaluations.V1.t\n ; ft_eval1 : Pasta_bindings.Fq.t\n ; bulletproof :\n ( Pasta_bindings.Fp.t * Pasta_bindings.Fp.t\n , Pasta_bindings.Fq.t )\n Pickles_types.Plonk_types.Openings.Bulletproof.Stable.V1.t\n }\n end\n end\n\n module Proof = struct\n type challenge_constant =\n Pickles_limb_vector.Constant.Make(Pickles_types.Nat.N2).t\n\n type tock_affine = Pasta_bindings.Fp.t * Pasta_bindings.Fp.t\n\n type 'a step_bp_vec = 'a Kimchi_pasta.Basic.Rounds.Step_vector.Stable.V1.t\n\n module Base = struct\n module Wrap = struct\n module V2 = struct\n type digest_constant =\n Pickles_limb_vector.Constant.Make(Pickles_types.Nat.N4).t\n\n type ('messages_for_next_wrap_proof, 'messages_for_next_step_proof) t =\n { statement :\n ( challenge_constant\n , challenge_constant Kimchi_types.scalar_challenge\n , Snark_params.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool\n , 'messages_for_next_wrap_proof\n , digest_constant\n , 'messages_for_next_step_proof\n , challenge_constant Kimchi_types.scalar_challenge\n Pickles_bulletproof_challenge.V1.t\n step_bp_vec\n , Pickles_composition_types.Branch_data.V1.t )\n Pickles_composition_types.Wrap.Statement.Minimal.V1.t\n ; prev_evals :\n ( Snark_params.Tick.Field.t\n , Snark_params.Tick.Field.t array )\n Pickles_types.Plonk_types.All_evals.t\n ; proof : Wrap_wire_proof.V1.t\n }\n end\n end\n end\n\n type ('s, 'mlmb, _) with_data =\n | T :\n ( 'mlmb Pickles_reduced_messages_for_next_proof_over_same_field.Wrap.t\n , ( 's\n , (tock_affine, 'most_recent_width) Pickles_types.Vector.t\n , ( challenge_constant Kimchi_types.scalar_challenge\n Pickles_bulletproof_challenge.V1.t\n step_bp_vec\n , 'most_recent_width )\n Pickles_types.Vector.t )\n Pickles_reduced_messages_for_next_proof_over_same_field.Step.V1.t\n )\n Base.Wrap.V2.t\n -> ('s, 'mlmb, _) with_data\n\n type ('max_width, 'mlmb) t = (unit, 'mlmb, 'max_width) with_data\n\n module Proofs_verified_2 = struct\n module V2 = struct\n type nonrec t = (Pickles_types.Nat.N2.n, Pickles_types.Nat.N2.n) t\n end\n end\n end\n\n module Side_loaded = struct\n module Verification_key = struct\n module Vk = struct\n type t =\n ( Pasta_bindings.Fq.t\n , Kimchi_bindings.Protocol.SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n end\n\n type tock_curve_affine =\n Snark_params.Tick.Field.t * Snark_params.Tick.Field.t\n\n module V2 = struct\n type t =\n ( tock_curve_affine\n , Pickles_base.Proofs_verified.V1.t\n , Vk.t )\n Pickles_base.Side_loaded_verification_key.Poly.V2.t\n end\n\n module Max_width = Pickles_types.Nat.N2\n end\n\n module Proof = struct\n module V2 = struct\n type t =\n (Verification_key.Max_width.n, Verification_key.Max_width.n) Proof.t\n end\n end\n end\nend\n\nmodule Types = struct\n module type S = sig\n module Proof : sig\n type ('a, 'b) t\n\n module Proofs_verified_2 : sig\n module V2 : sig\n type nonrec t = (Pickles_types.Nat.N2.n, Pickles_types.Nat.N2.n) t\n end\n end\n end\n\n module Side_loaded : sig\n module Verification_key : sig\n module Max_width : module type of Pickles_types.Nat.N2\n\n module V2 : sig\n type t\n end\n end\n\n module Proof : sig\n module V2 : sig\n type t =\n (Verification_key.Max_width.n, Verification_key.Max_width.n) Proof.t\n end\n end\n end\n\n module Backend : sig\n module Tick : sig\n module Field : sig\n module V1 : sig\n type t = Pasta_bindings.Fp.t\n end\n end\n end\n end\n end\nend\n\nmodule Concrete_ = M\n\nmodule type Concrete =\n Types.S\n with type Side_loaded.Verification_key.V2.t =\n M.Side_loaded.Verification_key.V2.t\n and type Backend.Tick.Field.V1.t = Pasta_bindings.Fp.t\n and type ('a, 'b) Proof.t = ('a, 'b) M.Proof.t\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","[%%import \"/src/config.mlh\"]\n\nopen Utils\n\nmodule Types = struct\n module type S = sig\n module Digest : V1S0\n\n include V2S0\n end\nend\n\n[%%ifdef consensus_mechanism]\n\nmodule type Concrete =\n Types.S\n with type Digest.V1.t = Pickles.Backend.Tick.Field.V1.t\n and type V2.t =\n Public_key.Compressed.V1.t * Pickles.Backend.Tick.Field.V1.t\n\n[%%else]\n\nmodule type Concrete =\n Types.S\n with type Digest.V1.t = Snark_params.Tick.Field.t\n and type V2.t = Public_key.Compressed.V1.t * Snark_params.Tick.Field.V1.t\n\n[%%endif]\n\nmodule M = struct\n [%%ifdef consensus_mechanism]\n\n module Digest = struct\n module V1 = struct\n type t = Pickles.Backend.Tick.Field.V1.t\n end\n end\n\n module V2 = struct\n type t = Public_key.Compressed.V1.t * Pickles.Backend.Tick.Field.V1.t\n end\n\n [%%else]\n\n module Digest = struct\n module V1 = struct\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module V2 = struct\n type t = Public_key.Compressed.V1.t * Snark_params.Tick.Field.V1.t\n end\n\n [%%endif]\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Account_nonce = struct\n module Types = struct\n module type S = V1S0\n end\n\n module type Concrete = Types.S with type V1.t = Unsigned.UInt32.t\n\n module M = struct\n module V1 = struct\n type t = Unsigned.UInt32.t\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Global_slot_legacy = struct\n module Types = struct\n module type S = V1S0\n end\n\n module type Concrete = Types.S with type V1.t = Unsigned.UInt32.t\n\n module M = struct\n module V1 = struct\n type t = Unsigned.UInt32.t\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Global_slot_since_genesis = struct\n module Types = struct\n module type S = V1S0\n end\n\n type global_slot = Since_genesis of Unsigned.UInt32.t [@@unboxed]\n\n module type Concrete = Types.S with type V1.t = global_slot\n\n module M = struct\n module V1 = struct\n type t = global_slot\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Global_slot_since_hard_fork = struct\n module Types = struct\n module type S = V1S0\n end\n\n type global_slot = Since_hard_fork of Unsigned.UInt32.t [@@unboxed]\n\n module type Concrete = Types.S with type V1.t = global_slot\n\n module M = struct\n module V1 = struct\n type t = global_slot\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Global_slot_span = struct\n module Types = struct\n module type S = V1S0\n end\n\n type global_slot_span = Global_slot_span of Unsigned.UInt32.t [@@unboxed]\n\n module type Concrete = Types.S with type V1.t = global_slot_span\n\n module M = struct\n module V1 = struct\n type t = global_slot_span\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Length = struct\n module Types = struct\n module type S = V1S0\n end\n\n module type Concrete = Types.S with type V1.t = Unsigned.UInt32.t\n\n module M = struct\n module V1 = struct\n type t = Unsigned.UInt32.t\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Index = struct\n module Types = struct\n module type S = V1S0\n end\n\n module type Concrete = Types.S with type V1.t = Unsigned.UInt32.t\n\n module M = struct\n module V1 = struct\n type t = Unsigned.UInt32.t\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module V1 : sig\n type t = private Mina_base_zkapp_basic.F.V1.t\n end\n end\nend\n\nmodule type Concrete = sig\n module V1 : sig\n type t = Pasta_bindings.Fp.t\n end\nend\n\nmodule M = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module V1 : sig\n type t = private\n { receiver_pk : Public_key.Compressed.V1.t; fee : Currency.Fee.V1.t }\n end\n end\nend\n\nmodule type Concrete = sig\n module V1 : sig\n type t =\n { receiver_pk : Public_key.Compressed.V1.t; fee : Currency.Fee.V1.t }\n end\nend\n\nmodule M = struct\n module V1 = struct\n type t =\n { receiver_pk : Public_key.Compressed.V1.t; fee : Currency.Fee.V1.t }\n end\nend\n\nmodule type Local_sig = Utils.Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module V1 : sig\n type t = private\n { receiver : Public_key.Compressed.V1.t\n ; amount : Currency.Amount.V1.t\n ; fee_transfer : Mina_base_coinbase_fee_transfer.V1.t option\n }\n end\n end\nend\n\nmodule M = struct\n module V1 = struct\n type t =\n { receiver : Public_key.Compressed.V1.t\n ; amount : Currency.Amount.V1.t\n ; fee_transfer : Mina_base_coinbase_fee_transfer.V1.t option\n }\n end\nend\n\nmodule type Concrete = sig\n module V1 : sig\n type t =\n { receiver : Public_key.Compressed.V1.t\n ; amount : Currency.Amount.V1.t\n ; fee_transfer : Mina_base_coinbase_fee_transfer.V1.t option\n }\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module Single : sig\n module V2 : sig\n type t = private\n { receiver_pk : Public_key.Compressed.V1.t\n ; fee : Currency.Fee.V1.t\n ; fee_token : Mina_base_token_id.V2.t\n }\n end\n end\n\n module V2 : sig\n type t = private Single.V2.t One_or_two.V1.t\n end\n end\nend\n\nmodule M = struct\n module Single = struct\n module V2 = struct\n type t =\n { receiver_pk : Public_key.Compressed.V1.t\n ; fee : Currency.Fee.V1.t\n ; fee_token : Mina_base_token_id.V2.t\n }\n end\n end\n\n module V2 = struct\n type t = Single.V2.t One_or_two.V1.t\n end\nend\n\nmodule type Concrete = sig\n module Single : sig\n module V2 : sig\n type t =\n { receiver_pk : Public_key.Compressed.V1.t\n ; fee : Currency.Fee.V1.t\n ; fee_token : Mina_base_token_id.V2.t\n }\n end\n end\n\n module V2 : sig\n type t = Single.V2.t One_or_two.V1.t\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module State_stack : sig\n module V1 : sig\n type t\n end\n end\n\n module Stack_versioned : sig\n module V1 : sig\n type nonrec t\n end\n end\n\n module Hash_builder : sig\n module V1 : sig\n type t = private Snark_params.Tick.Field.t\n end\n end\n\n module Hash_versioned : sig\n module V1 : sig\n type t = Hash_builder.V1.t\n end\n end\n end\nend\n\nmodule type Concrete = sig\n module Poly : sig\n type ('tree, 'stack_id) t =\n { tree : 'tree; pos_list : 'stack_id list; new_pos : 'stack_id }\n end\n\n module Stack_hash : sig\n module V1 : sig\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module State_stack : sig\n module Poly : sig\n module V1 : sig\n type 'stack_hash t = { init : 'stack_hash; curr : 'stack_hash }\n end\n end\n\n module V1 : sig\n type t = Stack_hash.V1.t Poly.V1.t\n end\n end\n\n module Coinbase_stack : sig\n module V1 : sig\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module Stack_versioned : sig\n module Poly : sig\n module V1 : sig\n type ('data_stack, 'state_stack) t =\n { data : 'data_stack; state : 'state_stack }\n end\n end\n\n module V1 : sig\n type t = (Coinbase_stack.V1.t, State_stack.V1.t) Poly.V1.t\n end\n end\n\n module Hash_builder : sig\n module V1 : sig\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module Hash_versioned : sig\n module V1 : sig\n type t = Hash_builder.V1.t\n end\n end\nend\n\nmodule M = struct\n module Poly = struct\n type ('tree, 'stack_id) t =\n { tree : 'tree; pos_list : 'stack_id list; new_pos : 'stack_id }\n end\n\n module Stack_hash = struct\n module V1 = struct\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module State_stack = struct\n module Poly = struct\n module V1 = struct\n type 'stack_hash t = { init : 'stack_hash; curr : 'stack_hash }\n end\n end\n\n module V1 = struct\n type t = Stack_hash.V1.t Poly.V1.t\n end\n end\n\n module Coinbase_stack = struct\n module V1 = struct\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module Stack_versioned = struct\n module Poly = struct\n module V1 = struct\n type ('data_stack, 'state_stack) t =\n { data : 'data_stack; state : 'state_stack }\n end\n end\n\n module V1 = struct\n type t = (Coinbase_stack.V1.t, State_stack.V1.t) Poly.V1.t\n end\n end\n\n module Hash_builder = struct\n module V1 = struct\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module Hash_versioned = struct\n module V1 = struct\n type t = Hash_builder.V1.t\n end\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = V1S0\nend\n\nmodule type Concrete = Types.S with type V1.t = string\n\nmodule M = struct\n module V1 = struct\n type t = string\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Poly = struct\n module V1 = struct\n type ('payload, 'pk, 'signature) t =\n { payload : 'payload; signer : 'pk; signature : 'signature }\n end\nend\n\nmodule V1 = struct\n type t =\n ( Mina_base_signed_command_payload.V1.t\n , Public_key.V1.t\n , Mina_base_signature.V1.t )\n Poly.V1.t\nend\n\nmodule V2 = struct\n type t =\n ( Mina_base_signed_command_payload.V2.t\n , Public_key.V1.t\n , Mina_base_signature.V1.t )\n Poly.V1.t\nend\n\nmodule Types = struct\n module type S = sig\n module With_valid_signature : V2S0 with type V2.t = private V2.t\n end\nend\n\nmodule type Concrete = Types.S with type With_valid_signature.V2.t = V2.t\n\nmodule M = struct\n module With_valid_signature = struct\n module V2 = struct\n type t = V2.t\n end\n end\nend\n\nmodule type Local_sig = Utils.Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module Digest : V1S0\n end\nend\n\nmodule type Concrete = Types.S with type Digest.V1.t = string\n\nmodule M = struct\n module Digest = struct\n module V1 = struct\n type t = string\n end\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Digest = struct\n module Types = struct\n module type S = sig\n module V1 : sig\n type t = private Mina_base_zkapp_basic.F.V1.t\n end\n end\n end\n\n module type Concrete = sig\n module V1 : sig\n type t = Pasta_bindings.Fp.t\n end\n end\n\n module M = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module Aux_hash : sig\n type t\n\n module V1 : sig\n type nonrec t = t\n end\n end\n\n module Pending_coinbase_aux : V1S0\n\n module V1 : S0\n end\nend\n\nmodule type Concrete = sig\n module Aux_hash : sig\n type t = string\n\n module V1 : sig\n type nonrec t = t\n end\n end\n\n module Pending_coinbase_aux : sig\n module V1 : sig\n type t = string\n end\n end\n\n module Non_snark : sig\n module V1 : sig\n type t =\n { ledger_hash : Mina_base_ledger_hash.V1.t\n ; aux_hash : Aux_hash.V1.t\n ; pending_coinbase_aux : Pending_coinbase_aux.V1.t\n }\n end\n end\n\n module Poly : sig\n module V1 : sig\n type ('non_snark, 'pending_coinbase_hash) t =\n { non_snark : 'non_snark\n ; pending_coinbase_hash : 'pending_coinbase_hash\n }\n end\n end\n\n module V1 : sig\n type t =\n (Non_snark.V1.t, Mina_base_pending_coinbase.Hash_versioned.V1.t) Poly.V1.t\n end\nend\n\nmodule M = struct\n module Aux_hash = struct\n type t = string\n\n module V1 = struct\n type nonrec t = string\n end\n end\n\n module Pending_coinbase_aux = struct\n module V1 = struct\n type t = string\n end\n end\n\n module Non_snark = struct\n module V1 = struct\n type t =\n { ledger_hash : Mina_base_ledger_hash.V1.t\n ; aux_hash : Aux_hash.V1.t\n ; pending_coinbase_aux : Pending_coinbase_aux.V1.t\n }\n end\n end\n\n module Poly = struct\n module V1 = struct\n type ('non_snark, 'pending_coinbase_hash) t =\n { non_snark : 'non_snark\n ; pending_coinbase_hash : 'pending_coinbase_hash\n }\n end\n end\n\n module V1 = struct\n type t =\n (Non_snark.V1.t, Mina_base_pending_coinbase.Hash_versioned.V1.t) Poly.V1.t\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Digest_types = struct\n module type S = sig\n module Account_update : sig\n module V1 : sig\n type t = private Pasta_bindings.Fp.t\n end\n end\n\n module Forest : sig\n module V1 : sig\n type t = private Pasta_bindings.Fp.t\n end\n end\n end\nend\n\nmodule Digest_M = struct\n module Account_update = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\n end\n\n module Forest = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\n end\nend\n\nmodule type Digest_concrete = sig\n module Account_update : sig\n module V1 : sig\n type t = Pasta_bindings.Fp.t\n end\n end\n\n module Forest : sig\n module V1 : sig\n type t = Pasta_bindings.Fp.t\n end\n end\nend\n\nmodule type Digest_local_sig = Signature(Digest_types).S\n\nmodule Digest_make\n (Signature : Digest_local_sig) (F : functor (A : Digest_concrete) ->\n Signature(A).S) =\n F (Digest_M)\n\nmodule Call_forest = struct\n module Digest = Digest_M\n\n module Tree = struct\n module V1 = struct\n type ('account_update, 'account_update_digest, 'digest) t =\n { account_update : 'account_update\n ; account_update_digest : 'account_update_digest\n ; calls :\n ( ('account_update, 'account_update_digest, 'digest) t\n , 'digest )\n Mina_base_with_stack_hash.V1.t\n list\n }\n end\n end\n\n module V1 = struct\n type ('account_update, 'account_update_digest, 'digest) t =\n ( ('account_update, 'account_update_digest, 'digest) Tree.V1.t\n , 'digest )\n Mina_base_with_stack_hash.V1.t\n list\n end\nend\n\nmodule V1 = struct\n type t =\n { fee_payer : Mina_base_account_update.Fee_payer.V1.t\n ; account_updates :\n ( Mina_base_account_update.V1.t\n , Call_forest.Digest.Account_update.V1.t\n , Call_forest.Digest.Forest.V1.t )\n Call_forest.V1.t\n ; memo : Mina_base_signed_command_memo.V1.t\n }\nend\n\nmodule Valid = struct\n module Verification_key_hash = struct\n module V1 = struct\n type t = Mina_base_zkapp_basic.F.V1.t\n end\n end\n\n module V1 = struct\n type t = { zkapp_command : V1.t }\n end\nend\n\nmodule Transaction_commitment = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2012 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* TODO: remove this open *)\nopen Stdlib0\nmodule Location = Astlib.Location\nmodule Longident = Astlib.Longident\nopen Astlib.Ast_412\n\n[@@@warning \"-9\"]\n\nopen Asttypes\nopen Parsetree\n\ntype 'a with_loc = 'a Location.loc\ntype loc = Location.t\ntype lid = Longident.t with_loc\ntype str = string with_loc\ntype str_opt = string option with_loc\ntype attrs = attribute list\n\nlet default_loc = ref Location.none\n\ntype ref_and_value = R : 'a ref * 'a -> ref_and_value\n\nlet protect_ref =\n let set_ref (R (r, v)) = r := v in\n fun ref f ->\n let (R (r, _)) = ref in\n let backup = R (r, !r) in\n set_ref ref;\n match f () with\n | x ->\n set_ref backup;\n x\n | exception e ->\n set_ref backup;\n raise e\n\nlet with_default_loc l f = protect_ref (R (default_loc, l)) f\n\nmodule Const = struct\n let integer ?suffix i = Pconst_integer (i, suffix)\n let int ?suffix i = integer ?suffix (Int.to_string i)\n let int32 ?(suffix = 'l') i = integer ~suffix (Int32.to_string i)\n let int64 ?(suffix = 'L') i = integer ~suffix (Int64.to_string i)\n let nativeint ?(suffix = 'n') i = integer ~suffix (Nativeint.to_string i)\n let float ?suffix f = Pconst_float (f, suffix)\n let char c = Pconst_char c\n\n let string ?quotation_delimiter ?(loc = !default_loc) s =\n Pconst_string (s, loc, quotation_delimiter)\nend\n\nmodule Attr = struct\n let mk ?(loc = !default_loc) name payload =\n { attr_name = name; attr_payload = payload; attr_loc = loc }\nend\n\nmodule Typ = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n {\n ptyp_desc = d;\n ptyp_loc = loc;\n ptyp_loc_stack = [];\n ptyp_attributes = attrs;\n }\n\n let attr d a = { d with ptyp_attributes = d.ptyp_attributes @ [ a ] }\n let any ?loc ?attrs () = mk ?loc ?attrs Ptyp_any\n let var ?loc ?attrs a = mk ?loc ?attrs (Ptyp_var a)\n let arrow ?loc ?attrs a b c = mk ?loc ?attrs (Ptyp_arrow (a, b, c))\n let tuple ?loc ?attrs a = mk ?loc ?attrs (Ptyp_tuple a)\n let constr ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_constr (a, b))\n let object_ ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_object (a, b))\n let class_ ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_class (a, b))\n let alias ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_alias (a, b))\n let variant ?loc ?attrs a b c = mk ?loc ?attrs (Ptyp_variant (a, b, c))\n let poly ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_poly (a, b))\n let package ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_package (a, b))\n let extension ?loc ?attrs a = mk ?loc ?attrs (Ptyp_extension a)\n\n let force_poly t =\n match t.ptyp_desc with Ptyp_poly _ -> t | _ -> poly ~loc:t.ptyp_loc [] t\n (* -> ghost? *)\n\n let varify_constructors var_names t =\n let check_variable vl loc v =\n if List.mem v vl then\n Location.raise_errorf ~loc \"variable in scope syntax error: %s\" v\n in\n let var_names = List.map (fun v -> v.txt) var_names in\n let rec loop t =\n let desc =\n match t.ptyp_desc with\n | Ptyp_any -> Ptyp_any\n | Ptyp_var x ->\n check_variable var_names t.ptyp_loc x;\n Ptyp_var x\n | Ptyp_arrow (label, core_type, core_type') ->\n Ptyp_arrow (label, loop core_type, loop core_type')\n | Ptyp_tuple lst -> Ptyp_tuple (List.map loop lst)\n | Ptyp_constr ({ txt = Longident.Lident s }, [])\n when List.mem s var_names ->\n Ptyp_var s\n | Ptyp_constr (longident, lst) ->\n Ptyp_constr (longident, List.map loop lst)\n | Ptyp_object (lst, o) -> Ptyp_object (List.map loop_object_field lst, o)\n | Ptyp_class (longident, lst) ->\n Ptyp_class (longident, List.map loop lst)\n | Ptyp_alias (core_type, string) ->\n check_variable var_names t.ptyp_loc string;\n Ptyp_alias (loop core_type, string)\n | Ptyp_variant (row_field_list, flag, lbl_lst_option) ->\n Ptyp_variant\n (List.map loop_row_field row_field_list, flag, lbl_lst_option)\n | Ptyp_poly (string_lst, core_type) ->\n List.iter\n (fun v -> check_variable var_names t.ptyp_loc v.txt)\n string_lst;\n Ptyp_poly (string_lst, loop core_type)\n | Ptyp_package (longident, lst) ->\n Ptyp_package\n (longident, List.map (fun (n, typ) -> (n, loop typ)) lst)\n | Ptyp_extension (s, arg) -> Ptyp_extension (s, arg)\n in\n { t with ptyp_desc = desc }\n and loop_row_field field =\n let prf_desc =\n match field.prf_desc with\n | Rtag (label, flag, lst) -> Rtag (label, flag, List.map loop lst)\n | Rinherit t -> Rinherit (loop t)\n in\n { field with prf_desc }\n and loop_object_field field =\n let pof_desc =\n match field.pof_desc with\n | Otag (label, t) -> Otag (label, loop t)\n | Oinherit t -> Oinherit (loop t)\n in\n { field with pof_desc }\n in\n loop t\nend\n\nmodule Pat = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n {\n ppat_desc = d;\n ppat_loc = loc;\n ppat_loc_stack = [];\n ppat_attributes = attrs;\n }\n\n let attr d a = { d with ppat_attributes = d.ppat_attributes @ [ a ] }\n let any ?loc ?attrs () = mk ?loc ?attrs Ppat_any\n let var ?loc ?attrs a = mk ?loc ?attrs (Ppat_var a)\n let alias ?loc ?attrs a b = mk ?loc ?attrs (Ppat_alias (a, b))\n let constant ?loc ?attrs a = mk ?loc ?attrs (Ppat_constant a)\n let interval ?loc ?attrs a b = mk ?loc ?attrs (Ppat_interval (a, b))\n let tuple ?loc ?attrs a = mk ?loc ?attrs (Ppat_tuple a)\n let construct ?loc ?attrs a b = mk ?loc ?attrs (Ppat_construct (a, b))\n let variant ?loc ?attrs a b = mk ?loc ?attrs (Ppat_variant (a, b))\n let record ?loc ?attrs a b = mk ?loc ?attrs (Ppat_record (a, b))\n let array ?loc ?attrs a = mk ?loc ?attrs (Ppat_array a)\n let or_ ?loc ?attrs a b = mk ?loc ?attrs (Ppat_or (a, b))\n let constraint_ ?loc ?attrs a b = mk ?loc ?attrs (Ppat_constraint (a, b))\n let type_ ?loc ?attrs a = mk ?loc ?attrs (Ppat_type a)\n let lazy_ ?loc ?attrs a = mk ?loc ?attrs (Ppat_lazy a)\n let unpack ?loc ?attrs a = mk ?loc ?attrs (Ppat_unpack a)\n let open_ ?loc ?attrs a b = mk ?loc ?attrs (Ppat_open (a, b))\n let exception_ ?loc ?attrs a = mk ?loc ?attrs (Ppat_exception a)\n let extension ?loc ?attrs a = mk ?loc ?attrs (Ppat_extension a)\nend\n\nmodule Exp = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n {\n pexp_desc = d;\n pexp_loc = loc;\n pexp_loc_stack = [];\n pexp_attributes = attrs;\n }\n\n let attr d a = { d with pexp_attributes = d.pexp_attributes @ [ a ] }\n let ident ?loc ?attrs a = mk ?loc ?attrs (Pexp_ident a)\n let constant ?loc ?attrs a = mk ?loc ?attrs (Pexp_constant a)\n let let_ ?loc ?attrs a b c = mk ?loc ?attrs (Pexp_let (a, b, c))\n let fun_ ?loc ?attrs a b c d = mk ?loc ?attrs (Pexp_fun (a, b, c, d))\n let function_ ?loc ?attrs a = mk ?loc ?attrs (Pexp_function a)\n let apply ?loc ?attrs a b = mk ?loc ?attrs (Pexp_apply (a, b))\n let match_ ?loc ?attrs a b = mk ?loc ?attrs (Pexp_match (a, b))\n let try_ ?loc ?attrs a b = mk ?loc ?attrs (Pexp_try (a, b))\n let tuple ?loc ?attrs a = mk ?loc ?attrs (Pexp_tuple a)\n let construct ?loc ?attrs a b = mk ?loc ?attrs (Pexp_construct (a, b))\n let variant ?loc ?attrs a b = mk ?loc ?attrs (Pexp_variant (a, b))\n let record ?loc ?attrs a b = mk ?loc ?attrs (Pexp_record (a, b))\n let field ?loc ?attrs a b = mk ?loc ?attrs (Pexp_field (a, b))\n let setfield ?loc ?attrs a b c = mk ?loc ?attrs (Pexp_setfield (a, b, c))\n let array ?loc ?attrs a = mk ?loc ?attrs (Pexp_array a)\n let ifthenelse ?loc ?attrs a b c = mk ?loc ?attrs (Pexp_ifthenelse (a, b, c))\n let sequence ?loc ?attrs a b = mk ?loc ?attrs (Pexp_sequence (a, b))\n let while_ ?loc ?attrs a b = mk ?loc ?attrs (Pexp_while (a, b))\n let for_ ?loc ?attrs a b c d e = mk ?loc ?attrs (Pexp_for (a, b, c, d, e))\n let constraint_ ?loc ?attrs a b = mk ?loc ?attrs (Pexp_constraint (a, b))\n let coerce ?loc ?attrs a b c = mk ?loc ?attrs (Pexp_coerce (a, b, c))\n let send ?loc ?attrs a b = mk ?loc ?attrs (Pexp_send (a, b))\n let new_ ?loc ?attrs a = mk ?loc ?attrs (Pexp_new a)\n let setinstvar ?loc ?attrs a b = mk ?loc ?attrs (Pexp_setinstvar (a, b))\n let override ?loc ?attrs a = mk ?loc ?attrs (Pexp_override a)\n let letmodule ?loc ?attrs a b c = mk ?loc ?attrs (Pexp_letmodule (a, b, c))\n let letexception ?loc ?attrs a b = mk ?loc ?attrs (Pexp_letexception (a, b))\n let assert_ ?loc ?attrs a = mk ?loc ?attrs (Pexp_assert a)\n let lazy_ ?loc ?attrs a = mk ?loc ?attrs (Pexp_lazy a)\n let poly ?loc ?attrs a b = mk ?loc ?attrs (Pexp_poly (a, b))\n let object_ ?loc ?attrs a = mk ?loc ?attrs (Pexp_object a)\n let newtype ?loc ?attrs a b = mk ?loc ?attrs (Pexp_newtype (a, b))\n let pack ?loc ?attrs a = mk ?loc ?attrs (Pexp_pack a)\n let open_ ?loc ?attrs a b = mk ?loc ?attrs (Pexp_open (a, b))\n\n let letop ?loc ?attrs let_ ands body =\n mk ?loc ?attrs (Pexp_letop { let_; ands; body })\n\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pexp_extension a)\n let unreachable ?loc ?attrs () = mk ?loc ?attrs Pexp_unreachable\n let case lhs ?guard rhs = { pc_lhs = lhs; pc_guard = guard; pc_rhs = rhs }\n\n let binding_op op pat exp loc =\n { pbop_op = op; pbop_pat = pat; pbop_exp = exp; pbop_loc = loc }\nend\n\nmodule Mty = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pmty_desc = d; pmty_loc = loc; pmty_attributes = attrs }\n\n let attr d a = { d with pmty_attributes = d.pmty_attributes @ [ a ] }\n let ident ?loc ?attrs a = mk ?loc ?attrs (Pmty_ident a)\n let alias ?loc ?attrs a = mk ?loc ?attrs (Pmty_alias a)\n let signature ?loc ?attrs a = mk ?loc ?attrs (Pmty_signature a)\n let functor_ ?loc ?attrs a b = mk ?loc ?attrs (Pmty_functor (a, b))\n let with_ ?loc ?attrs a b = mk ?loc ?attrs (Pmty_with (a, b))\n let typeof_ ?loc ?attrs a = mk ?loc ?attrs (Pmty_typeof a)\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pmty_extension a)\nend\n\nmodule Mod = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pmod_desc = d; pmod_loc = loc; pmod_attributes = attrs }\n\n let attr d a = { d with pmod_attributes = d.pmod_attributes @ [ a ] }\n let ident ?loc ?attrs x = mk ?loc ?attrs (Pmod_ident x)\n let structure ?loc ?attrs x = mk ?loc ?attrs (Pmod_structure x)\n let functor_ ?loc ?attrs arg body = mk ?loc ?attrs (Pmod_functor (arg, body))\n let apply ?loc ?attrs m1 m2 = mk ?loc ?attrs (Pmod_apply (m1, m2))\n let constraint_ ?loc ?attrs m mty = mk ?loc ?attrs (Pmod_constraint (m, mty))\n let unpack ?loc ?attrs e = mk ?loc ?attrs (Pmod_unpack e)\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pmod_extension a)\nend\n\nmodule Sig = struct\n let mk ?(loc = !default_loc) d = { psig_desc = d; psig_loc = loc }\n let value ?loc a = mk ?loc (Psig_value a)\n let type_ ?loc rec_flag a = mk ?loc (Psig_type (rec_flag, a))\n let type_subst ?loc a = mk ?loc (Psig_typesubst a)\n let type_extension ?loc a = mk ?loc (Psig_typext a)\n let exception_ ?loc a = mk ?loc (Psig_exception a)\n let module_ ?loc a = mk ?loc (Psig_module a)\n let mod_subst ?loc a = mk ?loc (Psig_modsubst a)\n let rec_module ?loc a = mk ?loc (Psig_recmodule a)\n let modtype ?loc a = mk ?loc (Psig_modtype a)\n let open_ ?loc a = mk ?loc (Psig_open a)\n let include_ ?loc a = mk ?loc (Psig_include a)\n let class_ ?loc a = mk ?loc (Psig_class a)\n let class_type ?loc a = mk ?loc (Psig_class_type a)\n let extension ?loc ?(attrs = []) a = mk ?loc (Psig_extension (a, attrs))\n let attribute ?loc a = mk ?loc (Psig_attribute a)\nend\n\nmodule Str = struct\n let mk ?(loc = !default_loc) d = { pstr_desc = d; pstr_loc = loc }\n let eval ?loc ?(attrs = []) a = mk ?loc (Pstr_eval (a, attrs))\n let value ?loc a b = mk ?loc (Pstr_value (a, b))\n let primitive ?loc a = mk ?loc (Pstr_primitive a)\n let type_ ?loc rec_flag a = mk ?loc (Pstr_type (rec_flag, a))\n let type_extension ?loc a = mk ?loc (Pstr_typext a)\n let exception_ ?loc a = mk ?loc (Pstr_exception a)\n let module_ ?loc a = mk ?loc (Pstr_module a)\n let rec_module ?loc a = mk ?loc (Pstr_recmodule a)\n let modtype ?loc a = mk ?loc (Pstr_modtype a)\n let open_ ?loc a = mk ?loc (Pstr_open a)\n let class_ ?loc a = mk ?loc (Pstr_class a)\n let class_type ?loc a = mk ?loc (Pstr_class_type a)\n let include_ ?loc a = mk ?loc (Pstr_include a)\n let extension ?loc ?(attrs = []) a = mk ?loc (Pstr_extension (a, attrs))\n let attribute ?loc a = mk ?loc (Pstr_attribute a)\nend\n\nmodule Cl = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pcl_desc = d; pcl_loc = loc; pcl_attributes = attrs }\n\n let attr d a = { d with pcl_attributes = d.pcl_attributes @ [ a ] }\n let constr ?loc ?attrs a b = mk ?loc ?attrs (Pcl_constr (a, b))\n let structure ?loc ?attrs a = mk ?loc ?attrs (Pcl_structure a)\n let fun_ ?loc ?attrs a b c d = mk ?loc ?attrs (Pcl_fun (a, b, c, d))\n let apply ?loc ?attrs a b = mk ?loc ?attrs (Pcl_apply (a, b))\n let let_ ?loc ?attrs a b c = mk ?loc ?attrs (Pcl_let (a, b, c))\n let constraint_ ?loc ?attrs a b = mk ?loc ?attrs (Pcl_constraint (a, b))\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pcl_extension a)\n let open_ ?loc ?attrs a b = mk ?loc ?attrs (Pcl_open (a, b))\nend\n\nmodule Cty = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pcty_desc = d; pcty_loc = loc; pcty_attributes = attrs }\n\n let attr d a = { d with pcty_attributes = d.pcty_attributes @ [ a ] }\n let constr ?loc ?attrs a b = mk ?loc ?attrs (Pcty_constr (a, b))\n let signature ?loc ?attrs a = mk ?loc ?attrs (Pcty_signature a)\n let arrow ?loc ?attrs a b c = mk ?loc ?attrs (Pcty_arrow (a, b, c))\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pcty_extension a)\n let open_ ?loc ?attrs a b = mk ?loc ?attrs (Pcty_open (a, b))\nend\n\nmodule Ctf = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pctf_desc = d; pctf_loc = loc; pctf_attributes = attrs }\n\n let inherit_ ?loc ?attrs a = mk ?loc ?attrs (Pctf_inherit a)\n let val_ ?loc ?attrs a b c d = mk ?loc ?attrs (Pctf_val (a, b, c, d))\n let method_ ?loc ?attrs a b c d = mk ?loc ?attrs (Pctf_method (a, b, c, d))\n let constraint_ ?loc ?attrs a b = mk ?loc ?attrs (Pctf_constraint (a, b))\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pctf_extension a)\n let attribute ?loc a = mk ?loc (Pctf_attribute a)\n let attr d a = { d with pctf_attributes = d.pctf_attributes @ [ a ] }\nend\n\nmodule Cf = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pcf_desc = d; pcf_loc = loc; pcf_attributes = attrs }\n\n let inherit_ ?loc ?attrs a b c = mk ?loc ?attrs (Pcf_inherit (a, b, c))\n let val_ ?loc ?attrs a b c = mk ?loc ?attrs (Pcf_val (a, b, c))\n let method_ ?loc ?attrs a b c = mk ?loc ?attrs (Pcf_method (a, b, c))\n let constraint_ ?loc ?attrs a b = mk ?loc ?attrs (Pcf_constraint (a, b))\n let initializer_ ?loc ?attrs a = mk ?loc ?attrs (Pcf_initializer a)\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pcf_extension a)\n let attribute ?loc a = mk ?loc (Pcf_attribute a)\n let virtual_ ct = Cfk_virtual ct\n let concrete o e = Cfk_concrete (o, e)\n let attr d a = { d with pcf_attributes = d.pcf_attributes @ [ a ] }\nend\n\nmodule Val = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?(prim = []) name typ =\n {\n pval_name = name;\n pval_type = typ;\n pval_attributes = attrs;\n pval_loc = loc;\n pval_prim = prim;\n }\nend\n\nmodule Md = struct\n let mk ?(loc = !default_loc) ?(attrs = []) name typ =\n { pmd_name = name; pmd_type = typ; pmd_attributes = attrs; pmd_loc = loc }\nend\n\nmodule Ms = struct\n let mk ?(loc = !default_loc) ?(attrs = []) name syn =\n {\n pms_name = name;\n pms_manifest = syn;\n pms_attributes = attrs;\n pms_loc = loc;\n }\nend\n\nmodule Mtd = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?typ name =\n {\n pmtd_name = name;\n pmtd_type = typ;\n pmtd_attributes = attrs;\n pmtd_loc = loc;\n }\nend\n\nmodule Mb = struct\n let mk ?(loc = !default_loc) ?(attrs = []) name expr =\n { pmb_name = name; pmb_expr = expr; pmb_attributes = attrs; pmb_loc = loc }\nend\n\nmodule Opn = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?(override = Fresh) expr =\n {\n popen_expr = expr;\n popen_override = override;\n popen_loc = loc;\n popen_attributes = attrs;\n }\nend\n\nmodule Incl = struct\n let mk ?(loc = !default_loc) ?(attrs = []) mexpr =\n { pincl_mod = mexpr; pincl_loc = loc; pincl_attributes = attrs }\nend\n\nmodule Vb = struct\n let mk ?(loc = !default_loc) ?(attrs = []) pat expr =\n { pvb_pat = pat; pvb_expr = expr; pvb_attributes = attrs; pvb_loc = loc }\nend\n\nmodule Ci = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?(virt = Concrete) ?(params = [])\n name expr =\n {\n pci_virt = virt;\n pci_params = params;\n pci_name = name;\n pci_expr = expr;\n pci_attributes = attrs;\n pci_loc = loc;\n }\nend\n\nmodule Type = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?(params = []) ?(cstrs = [])\n ?(kind = Ptype_abstract) ?(priv = Public) ?manifest name =\n {\n ptype_name = name;\n ptype_params = params;\n ptype_cstrs = cstrs;\n ptype_kind = kind;\n ptype_private = priv;\n ptype_manifest = manifest;\n ptype_attributes = attrs;\n ptype_loc = loc;\n }\n\n let constructor ?(loc = !default_loc) ?(attrs = []) ?(args = Pcstr_tuple [])\n ?res name =\n {\n pcd_name = name;\n pcd_args = args;\n pcd_res = res;\n pcd_loc = loc;\n pcd_attributes = attrs;\n }\n\n let field ?(loc = !default_loc) ?(attrs = []) ?(mut = Immutable) name typ =\n {\n pld_name = name;\n pld_mutable = mut;\n pld_type = typ;\n pld_loc = loc;\n pld_attributes = attrs;\n }\nend\n\n(** Type extensions *)\nmodule Te = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?(params = []) ?(priv = Public)\n path constructors =\n {\n ptyext_path = path;\n ptyext_params = params;\n ptyext_constructors = constructors;\n ptyext_private = priv;\n ptyext_loc = loc;\n ptyext_attributes = attrs;\n }\n\n let mk_exception ?(loc = !default_loc) ?(attrs = []) constructor =\n {\n ptyexn_constructor = constructor;\n ptyexn_loc = loc;\n ptyexn_attributes = attrs;\n }\n\n let constructor ?(loc = !default_loc) ?(attrs = []) name kind =\n {\n pext_name = name;\n pext_kind = kind;\n pext_loc = loc;\n pext_attributes = attrs;\n }\n\n let decl ?(loc = !default_loc) ?(attrs = []) ?(args = Pcstr_tuple []) ?res\n name =\n {\n pext_name = name;\n pext_kind = Pext_decl (args, res);\n pext_loc = loc;\n pext_attributes = attrs;\n }\n\n let rebind ?(loc = !default_loc) ?(attrs = []) name lid =\n {\n pext_name = name;\n pext_kind = Pext_rebind lid;\n pext_loc = loc;\n pext_attributes = attrs;\n }\nend\n\nmodule Csig = struct\n let mk self fields = { pcsig_self = self; pcsig_fields = fields }\nend\n\nmodule Cstr = struct\n let mk self fields = { pcstr_self = self; pcstr_fields = fields }\nend\n\n(** Row fields *)\nmodule Rf = struct\n let mk ?(loc = !default_loc) ?(attrs = []) desc =\n { prf_desc = desc; prf_loc = loc; prf_attributes = attrs }\n\n let tag ?loc ?attrs label const tys =\n mk ?loc ?attrs (Rtag (label, const, tys))\n\n let inherit_ ?loc ty = mk ?loc (Rinherit ty)\nend\n\n(** Object fields *)\nmodule Of = struct\n let mk ?(loc = !default_loc) ?(attrs = []) desc =\n { pof_desc = desc; pof_loc = loc; pof_attributes = attrs }\n\n let tag ?loc ?attrs label ty = mk ?loc ?attrs (Otag (label, ty))\n let inherit_ ?loc ty = mk ?loc (Oinherit ty)\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Daniel C. Buenzli *)\n(* *)\n(* Copyright 2014 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nexternal format_int : string -> int -> string = \"caml_format_int\"\n\nlet err_no_pred = \"U+0000 has no predecessor\"\nlet err_no_succ = \"U+10FFFF has no successor\"\nlet err_not_sv i = format_int \"%X\" i ^ \" is not an Unicode scalar value\"\nlet err_not_latin1 u = \"U+\" ^ format_int \"%04X\" u ^ \" is not a latin1 character\"\n\ntype t = int\n\nlet min = 0x0000\nlet max = 0x10FFFF\nlet lo_bound = 0xD7FF\nlet hi_bound = 0xE000\n\nlet bom = 0xFEFF\nlet rep = 0xFFFD\n\nlet succ u =\n if u = lo_bound then hi_bound else\n if u = max then invalid_arg err_no_succ else\n u + 1\n\nlet pred u =\n if u = hi_bound then lo_bound else\n if u = min then invalid_arg err_no_pred else\n u - 1\n\nlet is_valid i = (min <= i && i <= lo_bound) || (hi_bound <= i && i <= max)\nlet of_int i = if is_valid i then i else invalid_arg (err_not_sv i)\nexternal unsafe_of_int : int -> t = \"%identity\"\nexternal to_int : t -> int = \"%identity\"\n\nlet is_char u = u < 256\nlet of_char c = Char.code c\nlet to_char u =\n if u > 255 then invalid_arg (err_not_latin1 u) else\n Char.unsafe_chr u\n\nlet unsafe_to_char = Char.unsafe_chr\n\nlet equal : int -> int -> bool = ( = )\nlet compare : int -> int -> int = Stdlib.compare\nlet hash = to_int\n\n(* UTF codecs tools *)\n\ntype utf_decode = int\n(* This is an int [0xDUUUUUU] decomposed as follows:\n - [D] is four bits for decode information, the highest bit is set if the\n decode is valid. The three lower bits indicate the number of elements\n from the source that were consumed by the decode.\n - [UUUUUU] is the decoded Unicode character or the Unicode replacement\n character U+FFFD if for invalid decodes. *)\n\nlet valid_bit = 27\nlet decode_bits = 24\n\nlet[@inline] utf_decode_is_valid d = (d lsr valid_bit) = 1\nlet[@inline] utf_decode_length d = (d lsr decode_bits) land 0b111\nlet[@inline] utf_decode_uchar d = unsafe_of_int (d land 0xFFFFFF)\nlet[@inline] utf_decode n u = ((8 lor n) lsl decode_bits) lor (to_int u)\nlet[@inline] utf_decode_invalid n = (n lsl decode_bits) lor rep\n\nlet utf_8_byte_length u = match to_int u with\n| u when u < 0 -> assert false\n| u when u <= 0x007F -> 1\n| u when u <= 0x07FF -> 2\n| u when u <= 0xFFFF -> 3\n| u when u <= 0x10FFFF -> 4\n| _ -> assert false\n\nlet utf_16_byte_length u = match to_int u with\n| u when u < 0 -> assert false\n| u when u <= 0xFFFF -> 2\n| u when u <= 0x10FFFF -> 4\n| _ -> assert false\n","module Int = struct\n let to_string = string_of_int\nend\n\nmodule Option = struct\n let map f o = match o with None -> None | Some v -> Some (f v)\nend\n","include Ocaml_common.Location\n\nlet set_input_name name = input_name := name\n\nmodule Error = struct\n [@@@warning \"-37\"]\n\n type old_t (*IF_NOT_AT_LEAST 408 = Ocaml_common.Location.error *) = {\n loc: t;\n msg: string;\n sub: old_t list;\n if_highlight: string;\n }\n\n type location_report_kind (*IF_AT_LEAST 408 = Ocaml_common.Location.report_kind *) =\n | Report_error\n | Report_warning of string\n | Report_warning_as_error of string\n | Report_alert of string\n | Report_alert_as_error of string\n\n type location_msg = (Format.formatter -> unit) loc\n\n type location_report (*IF_AT_LEAST 408 = Ocaml_common.Location.report *) = {\n kind : location_report_kind;\n main : location_msg;\n sub : location_msg list;\n }\n\n type t (*IF_AT_LEAST 408 = Ocaml_common.Location.error *) (*IF_NOT_AT_LEAST 408 = old_t *)\n (** On ocaml >= 4.08: [t] is a [location_report] for which [location_report_kind] must be [Report_error]. *)\n\n type version_specific_t = [`New_error of location_report | `Old_error of old_t]\n\n let version_specific_t_of_t : t -> version_specific_t = fun x ->\n (*IF_AT_LEAST 408 `New_error x *)\n (*IF_NOT_AT_LEAST 408 `Old_error x *)\n\n let is_well_formed error =\n match version_specific_t_of_t error with\n | `New_error { kind = Report_error; _ } -> true\n | `New_error _ -> false\n | `Old_error _ -> true\n\n let string_of_location_msg (msg : location_msg) = Format.asprintf \"%t\" msg.txt\n\n let main_msg error =\n match version_specific_t_of_t error with\n | `New_error { main; _ } ->\n { txt = string_of_location_msg main; loc = main.loc }\n | `Old_error { msg; loc; _ } -> { txt = msg; loc }\n\n let sub_msgs error =\n match version_specific_t_of_t error with\n | `New_error { sub; _ } ->\n List.map\n (fun err -> { txt = string_of_location_msg err; loc = err.loc })\n sub\n | `Old_error { sub; _ } ->\n let rec deeply_flattened_sub_msgs acc = function\n | [] -> acc\n | { loc; msg; sub; _ } :: tail ->\n deeply_flattened_sub_msgs ({ txt = msg; loc } :: acc) (sub @ tail)\n in\n deeply_flattened_sub_msgs [] sub\n\n let of_exn exn =\n (*IF_AT_LEAST 406 match error_of_exn exn with | Some (`Ok e) -> Some e | None | Some `Already_displayed -> None *)\n (*IF_NOT_AT_LEAST 406 error_of_exn exn*)\n\n let _set_main_msg_old error msg = { error with msg }\n\n let _set_main_msg_new error msg =\n let txt ppf = Format.pp_print_string ppf msg in\n let main = { error.main with txt } in\n { error with main }\n\n let set_main_msg error msg =\n (*IF_NOT_AT_LEAST 408 _set_main_msg_old error msg*)\n (*IF_AT_LEAST 408 _set_main_msg_new error msg*)\n\n let _make_error_of_message_old ~sub { loc; txt } =\n let sub =\n List.map\n (fun { loc; txt } -> { loc; msg = txt; sub = []; if_highlight = txt })\n sub\n in\n { loc; msg = txt; sub; if_highlight = txt }\n\n let _make_error_of_message_new ~sub { loc; txt } =\n let mk_txt x ppf = Format.pp_print_string ppf x in\n let mk loc x = { loc; txt = mk_txt x } in\n {\n kind = Report_error;\n main = mk loc txt;\n sub = List.map (fun { loc; txt } -> mk loc txt) sub;\n }\n\n let make ~sub msg =\n (*IF_NOT_AT_LEAST 408 _make_error_of_message_old ~sub msg*)\n (*IF_AT_LEAST 408 _make_error_of_message_new ~sub msg*)\n\n let _set_main_loc_old error loc = { error with loc }\n\n let _set_main_loc_new error loc =\n let main = { error.main with loc } in\n { error with main }\n\n let set_main_loc error loc =\n (*IF_NOT_AT_LEAST 408 _set_main_loc_old error loc*)\n (*IF_AT_LEAST 408 _set_main_loc_new error loc*)\nend\n\nlet raise_errorf ?loc msg = raise_errorf ?loc msg\n","(*$ open Ppxlib_cinaps_helpers $*)\nopen! Import\nmodule Format = Caml.Format\nmodule Filename = Caml.Filename\n\n(* TODO: make the \"deriving.\" depend on the matching attribute name. *)\nlet end_marker_sig =\n Attribute.Floating.declare \"deriving.end\" Signature_item\n Ast_pattern.(pstr nil)\n ()\n\nlet end_marker_str =\n Attribute.Floating.declare \"deriving.end\" Structure_item\n Ast_pattern.(pstr nil)\n ()\n\nmodule type T1 = sig\n type 'a t\nend\n\nmodule Make (M : sig\n type t\n\n val get_loc : t -> Location.t\n val end_marker : (t, unit) Attribute.Floating.t\n\n module Transform (T : T1) : sig\n val apply :\n < structure_item : structure_item T.t\n ; signature_item : signature_item T.t\n ; .. > ->\n t T.t\n end\n\n val parse : Lexing.lexbuf -> t list\n val pp : Format.formatter -> t -> unit\n val to_sexp : t -> Sexp.t\nend) =\nstruct\n let extract_prefix ~pos l =\n let rec loop acc = function\n | [] ->\n let loc =\n { Location.loc_start = pos; loc_end = pos; loc_ghost = false }\n in\n Location.raise_errorf ~loc \"ppxlib: [@@@@@@%s] attribute missing\"\n (Attribute.Floating.name M.end_marker)\n | x :: l -> (\n match Attribute.Floating.convert [ M.end_marker ] x with\n | None -> loop (x :: acc) l\n | Some () -> (List.rev acc, (M.get_loc x).loc_start)\n | exception Failure _ -> loop (x :: acc) l)\n in\n loop [] l\n\n let remove_loc =\n object\n inherit Ast_traverse.map\n method! location _ = Location.none\n method! location_stack _ = []\n end\n\n module M_map = M.Transform (struct\n type 'a t = 'a -> 'a\n end)\n\n let remove_loc x = M_map.apply remove_loc x\n let rec last prev = function [] -> prev | x :: l -> last x l\n\n let diff_asts ~generated ~round_trip =\n let with_temp_file f =\n Exn.protectx (Filename.temp_file \"ppxlib\" \"\") ~finally:Caml.Sys.remove ~f\n in\n with_temp_file (fun fn1 ->\n with_temp_file (fun fn2 ->\n with_temp_file (fun out ->\n let dump fn ast =\n Out_channel.with_file fn ~f:(fun oc ->\n let ppf = Format.formatter_of_out_channel oc in\n Sexp.pp_hum ppf (M.to_sexp ast);\n Format.pp_print_flush ppf ())\n in\n dump fn1 generated;\n dump fn2 round_trip;\n let cmd =\n Printf.sprintf\n \"patdiff -ascii -alt-old generated -alt-new \\\n 'generated->printed->parsed' %s %s &> %s\"\n (Filename.quote fn1) (Filename.quote fn2)\n (Filename.quote out)\n in\n let ok =\n Caml.Sys.command cmd = 1\n ||\n let cmd =\n Printf.sprintf\n \"diff --label generated --label \\\n 'generated->printed->parsed' %s %s &> %s\"\n (Filename.quote fn1) (Filename.quote fn2)\n (Filename.quote out)\n in\n Caml.Sys.command cmd = 1\n in\n if ok then In_channel.read_all out\n else \"\")))\n\n let parse_string s =\n match M.parse (Lexing.from_string s) with [ x ] -> x | _ -> assert false\n\n let rec match_loop ~end_pos ~mismatch_handler ~expected ~source =\n match (expected, source) with\n | [], [] -> ()\n | [], x :: l ->\n let loc =\n { (M.get_loc x) with loc_end = (M.get_loc (last x l)).loc_end }\n in\n mismatch_handler loc []\n | _, [] ->\n let loc =\n { Location.loc_ghost = false; loc_start = end_pos; loc_end = end_pos }\n in\n mismatch_handler loc expected\n | x :: expected, y :: source ->\n let loc = M.get_loc y in\n let x = remove_loc x in\n let y = remove_loc y in\n if Poly.( <> ) x y then (\n let round_trip =\n remove_loc (parse_string (Format.asprintf \"%a@.\" M.pp x))\n in\n if Poly.( <> ) x round_trip then\n Location.raise_errorf ~loc\n \"ppxlib: the corrected code doesn't round-trip.\\n\\\n This is probably a bug in the OCaml printer:\\n\\\n %s\"\n (diff_asts ~generated:x ~round_trip);\n mismatch_handler loc [ x ]);\n match_loop ~end_pos ~mismatch_handler ~expected ~source\n\n let do_match ~pos ~expected ~mismatch_handler source =\n let source, end_pos = extract_prefix ~pos source in\n match_loop ~end_pos ~mismatch_handler ~expected ~source\nend\n\n(*$*)\nmodule Str = Make (struct\n type t = structure_item\n\n let get_loc x = x.pstr_loc\n let end_marker = end_marker_str\n\n module Transform (T : T1) = struct\n let apply o = o#structure_item\n end\n\n let parse = Parse.implementation\n let pp = Pprintast.structure_item\n let to_sexp = Ast_traverse.sexp_of#structure_item\nend)\n\n(*$ str_to_sig _last_text_block *)\nmodule Sig = Make (struct\n type t = signature_item\n\n let get_loc x = x.psig_loc\n let end_marker = end_marker_sig\n\n module Transform (T : T1) = struct\n let apply o = o#signature_item\n end\n\n let parse = Parse.interface\n let pp = Pprintast.signature_item\n let to_sexp = Ast_traverse.sexp_of#signature_item\nend)\n\n(*$*)\n\nlet match_structure = Str.do_match\nlet match_signature = Sig.do_match\n","open Stdlib0\nmodule From = Ast_414\nmodule To = Ast_413\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.13\" missing_feature\n\nlet rec copy_toplevel_phrase :\n Ast_414.Parsetree.toplevel_phrase -> Ast_413.Parsetree.toplevel_phrase =\n function\n | Ast_414.Parsetree.Ptop_def x0 ->\n Ast_413.Parsetree.Ptop_def (copy_structure x0)\n | Ast_414.Parsetree.Ptop_dir x0 ->\n Ast_413.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_414.Parsetree.toplevel_directive -> Ast_413.Parsetree.toplevel_directive\n =\n fun {\n Ast_414.Parsetree.pdir_name;\n Ast_414.Parsetree.pdir_arg;\n Ast_414.Parsetree.pdir_loc;\n } ->\n {\n Ast_413.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_413.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_413.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_414.Parsetree.directive_argument -> Ast_413.Parsetree.directive_argument\n =\n fun { Ast_414.Parsetree.pdira_desc; Ast_414.Parsetree.pdira_loc } ->\n {\n Ast_413.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_413.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_414.Parsetree.directive_argument_desc ->\n Ast_413.Parsetree.directive_argument_desc = function\n | Ast_414.Parsetree.Pdir_string x0 -> Ast_413.Parsetree.Pdir_string x0\n | Ast_414.Parsetree.Pdir_int (x0, x1) ->\n Ast_413.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_414.Parsetree.Pdir_ident x0 ->\n Ast_413.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_414.Parsetree.Pdir_bool x0 -> Ast_413.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_414.Parsetree.expression -> Ast_413.Parsetree.expression =\n fun {\n Ast_414.Parsetree.pexp_desc;\n Ast_414.Parsetree.pexp_loc;\n Ast_414.Parsetree.pexp_loc_stack;\n Ast_414.Parsetree.pexp_attributes;\n } ->\n {\n Ast_413.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_413.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_413.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_413.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_414.Parsetree.expression_desc -> Ast_413.Parsetree.expression_desc =\n function\n | Ast_414.Parsetree.Pexp_ident x0 ->\n Ast_413.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_414.Parsetree.Pexp_constant x0 ->\n Ast_413.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_414.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_414.Parsetree.Pexp_function x0 ->\n Ast_413.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_414.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_413.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_414.Parsetree.Pexp_apply (x0, x1) ->\n Ast_413.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_414.Parsetree.Pexp_match (x0, x1) ->\n Ast_413.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_414.Parsetree.Pexp_try (x0, x1) ->\n Ast_413.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_414.Parsetree.Pexp_tuple x0 ->\n Ast_413.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_414.Parsetree.Pexp_construct (x0, x1) ->\n Ast_413.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_414.Parsetree.Pexp_variant (x0, x1) ->\n Ast_413.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_414.Parsetree.Pexp_record (x0, x1) ->\n Ast_413.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_414.Parsetree.Pexp_field (x0, x1) ->\n Ast_413.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_414.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_414.Parsetree.Pexp_array x0 ->\n Ast_413.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_414.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_414.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_413.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_while (x0, x1) ->\n Ast_413.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_413.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_414.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_413.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_414.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_414.Parsetree.Pexp_send (x0, x1) ->\n Ast_413.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_414.Parsetree.Pexp_new x0 ->\n Ast_413.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_414.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_413.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_override x0 ->\n Ast_413.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_414.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_414.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_413.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_assert x0 ->\n Ast_413.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_414.Parsetree.Pexp_lazy x0 ->\n Ast_413.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_414.Parsetree.Pexp_poly (x0, x1) ->\n Ast_413.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_414.Parsetree.Pexp_object x0 ->\n Ast_413.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_414.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_413.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_pack x0 ->\n Ast_413.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_414.Parsetree.Pexp_open (x0, x1) ->\n Ast_413.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_letop x0 ->\n Ast_413.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_414.Parsetree.Pexp_extension x0 ->\n Ast_413.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_414.Parsetree.Pexp_unreachable -> Ast_413.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_414.Parsetree.letop -> Ast_413.Parsetree.letop =\n fun { Ast_414.Parsetree.let_; Ast_414.Parsetree.ands; Ast_414.Parsetree.body } ->\n {\n Ast_413.Parsetree.let_ = copy_binding_op let_;\n Ast_413.Parsetree.ands = List.map copy_binding_op ands;\n Ast_413.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_414.Parsetree.binding_op -> Ast_413.Parsetree.binding_op =\n fun {\n Ast_414.Parsetree.pbop_op;\n Ast_414.Parsetree.pbop_pat;\n Ast_414.Parsetree.pbop_exp;\n Ast_414.Parsetree.pbop_loc;\n } ->\n {\n Ast_413.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_413.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_413.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_413.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_414.Asttypes.direction_flag -> Ast_413.Asttypes.direction_flag =\n function\n | Ast_414.Asttypes.Upto -> Ast_413.Asttypes.Upto\n | Ast_414.Asttypes.Downto -> Ast_413.Asttypes.Downto\n\nand copy_case : Ast_414.Parsetree.case -> Ast_413.Parsetree.case =\n fun {\n Ast_414.Parsetree.pc_lhs;\n Ast_414.Parsetree.pc_guard;\n Ast_414.Parsetree.pc_rhs;\n } ->\n {\n Ast_413.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_413.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_413.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_414.Parsetree.value_binding -> Ast_413.Parsetree.value_binding =\n fun {\n Ast_414.Parsetree.pvb_pat;\n Ast_414.Parsetree.pvb_expr;\n Ast_414.Parsetree.pvb_attributes;\n Ast_414.Parsetree.pvb_loc;\n } ->\n {\n Ast_413.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_413.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_413.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_413.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_414.Parsetree.pattern -> Ast_413.Parsetree.pattern =\n fun {\n Ast_414.Parsetree.ppat_desc;\n Ast_414.Parsetree.ppat_loc;\n Ast_414.Parsetree.ppat_loc_stack;\n Ast_414.Parsetree.ppat_attributes;\n } ->\n {\n Ast_413.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_413.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_413.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_413.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_414.Parsetree.pattern_desc -> Ast_413.Parsetree.pattern_desc = function\n | Ast_414.Parsetree.Ppat_any -> Ast_413.Parsetree.Ppat_any\n | Ast_414.Parsetree.Ppat_var x0 ->\n Ast_413.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_414.Parsetree.Ppat_alias (x0, x1) ->\n Ast_413.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_414.Parsetree.Ppat_constant x0 ->\n Ast_413.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_414.Parsetree.Ppat_interval (x0, x1) ->\n Ast_413.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_414.Parsetree.Ppat_tuple x0 ->\n Ast_413.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_414.Parsetree.Ppat_construct (x0, x1) ->\n Ast_413.Parsetree.Ppat_construct\n ( copy_loc copy_Longident_t x0,\n Option.map\n (fun x ->\n let x0, x1 = x in\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_pattern x1))\n x1 )\n | Ast_414.Parsetree.Ppat_variant (x0, x1) ->\n Ast_413.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_414.Parsetree.Ppat_record (x0, x1) ->\n Ast_413.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_414.Parsetree.Ppat_array x0 ->\n Ast_413.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_414.Parsetree.Ppat_or (x0, x1) ->\n Ast_413.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_414.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_413.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_414.Parsetree.Ppat_type x0 ->\n Ast_413.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_414.Parsetree.Ppat_lazy x0 ->\n Ast_413.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_414.Parsetree.Ppat_unpack x0 ->\n Ast_413.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_414.Parsetree.Ppat_exception x0 ->\n Ast_413.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_414.Parsetree.Ppat_extension x0 ->\n Ast_413.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_414.Parsetree.Ppat_open (x0, x1) ->\n Ast_413.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_414.Parsetree.core_type -> Ast_413.Parsetree.core_type\n =\n fun {\n Ast_414.Parsetree.ptyp_desc;\n Ast_414.Parsetree.ptyp_loc;\n Ast_414.Parsetree.ptyp_loc_stack;\n Ast_414.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_413.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_413.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_413.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_414.Parsetree.location_stack -> Ast_413.Parsetree.location_stack =\n fun x -> x\n\nand copy_core_type_desc :\n Ast_414.Parsetree.core_type_desc -> Ast_413.Parsetree.core_type_desc =\n function\n | Ast_414.Parsetree.Ptyp_any -> Ast_413.Parsetree.Ptyp_any\n | Ast_414.Parsetree.Ptyp_var x0 -> Ast_413.Parsetree.Ptyp_var x0\n | Ast_414.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_413.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_414.Parsetree.Ptyp_tuple x0 ->\n Ast_413.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_414.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_413.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_414.Parsetree.Ptyp_object (x0, x1) ->\n Ast_413.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_414.Parsetree.Ptyp_class (x0, x1) ->\n Ast_413.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_414.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_413.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_414.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_413.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_414.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_413.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_414.Parsetree.Ptyp_package x0 ->\n Ast_413.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_414.Parsetree.Ptyp_extension x0 ->\n Ast_413.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_414.Parsetree.package_type -> Ast_413.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_414.Parsetree.row_field -> Ast_413.Parsetree.row_field\n =\n fun {\n Ast_414.Parsetree.prf_desc;\n Ast_414.Parsetree.prf_loc;\n Ast_414.Parsetree.prf_attributes;\n } ->\n {\n Ast_413.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_413.Parsetree.prf_loc = copy_location prf_loc;\n Ast_413.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_414.Parsetree.row_field_desc -> Ast_413.Parsetree.row_field_desc =\n function\n | Ast_414.Parsetree.Rtag (x0, x1, x2) ->\n Ast_413.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_414.Parsetree.Rinherit x0 ->\n Ast_413.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_414.Parsetree.object_field -> Ast_413.Parsetree.object_field =\n fun {\n Ast_414.Parsetree.pof_desc;\n Ast_414.Parsetree.pof_loc;\n Ast_414.Parsetree.pof_attributes;\n } ->\n {\n Ast_413.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_413.Parsetree.pof_loc = copy_location pof_loc;\n Ast_413.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_414.Parsetree.attributes -> Ast_413.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_414.Parsetree.attribute -> Ast_413.Parsetree.attribute\n =\n fun {\n Ast_414.Parsetree.attr_name;\n Ast_414.Parsetree.attr_payload;\n Ast_414.Parsetree.attr_loc;\n } ->\n {\n Ast_413.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_413.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_413.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_414.Parsetree.payload -> Ast_413.Parsetree.payload =\n function\n | Ast_414.Parsetree.PStr x0 -> Ast_413.Parsetree.PStr (copy_structure x0)\n | Ast_414.Parsetree.PSig x0 -> Ast_413.Parsetree.PSig (copy_signature x0)\n | Ast_414.Parsetree.PTyp x0 -> Ast_413.Parsetree.PTyp (copy_core_type x0)\n | Ast_414.Parsetree.PPat (x0, x1) ->\n Ast_413.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_414.Parsetree.structure -> Ast_413.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_414.Parsetree.structure_item -> Ast_413.Parsetree.structure_item =\n fun { Ast_414.Parsetree.pstr_desc; Ast_414.Parsetree.pstr_loc } ->\n {\n Ast_413.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_413.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_414.Parsetree.structure_item_desc ->\n Ast_413.Parsetree.structure_item_desc = function\n | Ast_414.Parsetree.Pstr_eval (x0, x1) ->\n Ast_413.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_414.Parsetree.Pstr_value (x0, x1) ->\n Ast_413.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_414.Parsetree.Pstr_primitive x0 ->\n Ast_413.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_414.Parsetree.Pstr_type (x0, x1) ->\n Ast_413.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_414.Parsetree.Pstr_typext x0 ->\n Ast_413.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_414.Parsetree.Pstr_exception x0 ->\n Ast_413.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_414.Parsetree.Pstr_module x0 ->\n Ast_413.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_414.Parsetree.Pstr_recmodule x0 ->\n Ast_413.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_414.Parsetree.Pstr_modtype x0 ->\n Ast_413.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_414.Parsetree.Pstr_open x0 ->\n Ast_413.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_414.Parsetree.Pstr_class x0 ->\n Ast_413.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_414.Parsetree.Pstr_class_type x0 ->\n Ast_413.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_414.Parsetree.Pstr_include x0 ->\n Ast_413.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_414.Parsetree.Pstr_attribute x0 ->\n Ast_413.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_414.Parsetree.Pstr_extension (x0, x1) ->\n Ast_413.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_414.Parsetree.include_declaration ->\n Ast_413.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_414.Parsetree.class_declaration -> Ast_413.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_414.Parsetree.class_expr -> Ast_413.Parsetree.class_expr =\n fun {\n Ast_414.Parsetree.pcl_desc;\n Ast_414.Parsetree.pcl_loc;\n Ast_414.Parsetree.pcl_attributes;\n } ->\n {\n Ast_413.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_413.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_413.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_414.Parsetree.class_expr_desc -> Ast_413.Parsetree.class_expr_desc =\n function\n | Ast_414.Parsetree.Pcl_constr (x0, x1) ->\n Ast_413.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_414.Parsetree.Pcl_structure x0 ->\n Ast_413.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_414.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_413.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_414.Parsetree.Pcl_apply (x0, x1) ->\n Ast_413.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_414.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_413.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_414.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_413.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_414.Parsetree.Pcl_extension x0 ->\n Ast_413.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_414.Parsetree.Pcl_open (x0, x1) ->\n Ast_413.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_414.Parsetree.class_structure -> Ast_413.Parsetree.class_structure =\n fun { Ast_414.Parsetree.pcstr_self; Ast_414.Parsetree.pcstr_fields } ->\n {\n Ast_413.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_413.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_414.Parsetree.class_field -> Ast_413.Parsetree.class_field =\n fun {\n Ast_414.Parsetree.pcf_desc;\n Ast_414.Parsetree.pcf_loc;\n Ast_414.Parsetree.pcf_attributes;\n } ->\n {\n Ast_413.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_413.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_413.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_414.Parsetree.class_field_desc -> Ast_413.Parsetree.class_field_desc =\n function\n | Ast_414.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_413.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_414.Parsetree.Pcf_val x0 ->\n Ast_413.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_414.Parsetree.Pcf_method x0 ->\n Ast_413.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_414.Parsetree.Pcf_constraint x0 ->\n Ast_413.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_414.Parsetree.Pcf_initializer x0 ->\n Ast_413.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_414.Parsetree.Pcf_attribute x0 ->\n Ast_413.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_414.Parsetree.Pcf_extension x0 ->\n Ast_413.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_414.Parsetree.class_field_kind -> Ast_413.Parsetree.class_field_kind =\n function\n | Ast_414.Parsetree.Cfk_virtual x0 ->\n Ast_413.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_414.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_413.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_414.Parsetree.open_declaration -> Ast_413.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_414.Parsetree.module_binding -> Ast_413.Parsetree.module_binding =\n fun {\n Ast_414.Parsetree.pmb_name;\n Ast_414.Parsetree.pmb_expr;\n Ast_414.Parsetree.pmb_attributes;\n Ast_414.Parsetree.pmb_loc;\n } ->\n {\n Ast_413.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_413.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_413.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_413.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_414.Parsetree.module_expr -> Ast_413.Parsetree.module_expr =\n fun {\n Ast_414.Parsetree.pmod_desc;\n Ast_414.Parsetree.pmod_loc;\n Ast_414.Parsetree.pmod_attributes;\n } ->\n {\n Ast_413.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_413.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_413.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_414.Parsetree.module_expr_desc -> Ast_413.Parsetree.module_expr_desc =\n function\n | Ast_414.Parsetree.Pmod_ident x0 ->\n Ast_413.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_414.Parsetree.Pmod_structure x0 ->\n Ast_413.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_414.Parsetree.Pmod_functor (x0, x1) ->\n Ast_413.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_414.Parsetree.Pmod_apply (x0, x1) ->\n Ast_413.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_414.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_413.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_414.Parsetree.Pmod_unpack x0 ->\n Ast_413.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_414.Parsetree.Pmod_extension x0 ->\n Ast_413.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_414.Parsetree.functor_parameter -> Ast_413.Parsetree.functor_parameter =\n function\n | Ast_414.Parsetree.Unit -> Ast_413.Parsetree.Unit\n | Ast_414.Parsetree.Named (x0, x1) ->\n Ast_413.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_414.Parsetree.module_type -> Ast_413.Parsetree.module_type =\n fun {\n Ast_414.Parsetree.pmty_desc;\n Ast_414.Parsetree.pmty_loc;\n Ast_414.Parsetree.pmty_attributes;\n } ->\n {\n Ast_413.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_413.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_413.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_414.Parsetree.module_type_desc -> Ast_413.Parsetree.module_type_desc =\n function\n | Ast_414.Parsetree.Pmty_ident x0 ->\n Ast_413.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_414.Parsetree.Pmty_signature x0 ->\n Ast_413.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_414.Parsetree.Pmty_functor (x0, x1) ->\n Ast_413.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_414.Parsetree.Pmty_with (x0, x1) ->\n Ast_413.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_414.Parsetree.Pmty_typeof x0 ->\n Ast_413.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_414.Parsetree.Pmty_extension x0 ->\n Ast_413.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_414.Parsetree.Pmty_alias x0 ->\n Ast_413.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_414.Parsetree.with_constraint -> Ast_413.Parsetree.with_constraint =\n function\n | Ast_414.Parsetree.Pwith_type (x0, x1) ->\n Ast_413.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_414.Parsetree.Pwith_module (x0, x1) ->\n Ast_413.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_414.Parsetree.Pwith_modtype (x0, x1) ->\n Ast_413.Parsetree.Pwith_modtype\n (copy_loc copy_Longident_t x0, copy_module_type x1)\n | Ast_414.Parsetree.Pwith_modtypesubst (x0, x1) ->\n Ast_413.Parsetree.Pwith_modtypesubst\n (copy_loc copy_Longident_t x0, copy_module_type x1)\n | Ast_414.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_413.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_414.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_413.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_414.Parsetree.signature -> Ast_413.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_414.Parsetree.signature_item -> Ast_413.Parsetree.signature_item =\n fun { Ast_414.Parsetree.psig_desc; Ast_414.Parsetree.psig_loc } ->\n {\n Ast_413.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_413.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_414.Parsetree.signature_item_desc ->\n Ast_413.Parsetree.signature_item_desc = function\n | Ast_414.Parsetree.Psig_value x0 ->\n Ast_413.Parsetree.Psig_value (copy_value_description x0)\n | Ast_414.Parsetree.Psig_type (x0, x1) ->\n Ast_413.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_414.Parsetree.Psig_typesubst x0 ->\n Ast_413.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_414.Parsetree.Psig_typext x0 ->\n Ast_413.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_414.Parsetree.Psig_exception x0 ->\n Ast_413.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_414.Parsetree.Psig_module x0 ->\n Ast_413.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_414.Parsetree.Psig_modsubst x0 ->\n Ast_413.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_414.Parsetree.Psig_recmodule x0 ->\n Ast_413.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_414.Parsetree.Psig_modtype x0 ->\n Ast_413.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_414.Parsetree.Psig_modtypesubst x0 ->\n Ast_413.Parsetree.Psig_modtypesubst (copy_module_type_declaration x0)\n | Ast_414.Parsetree.Psig_open x0 ->\n Ast_413.Parsetree.Psig_open (copy_open_description x0)\n | Ast_414.Parsetree.Psig_include x0 ->\n Ast_413.Parsetree.Psig_include (copy_include_description x0)\n | Ast_414.Parsetree.Psig_class x0 ->\n Ast_413.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_414.Parsetree.Psig_class_type x0 ->\n Ast_413.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_414.Parsetree.Psig_attribute x0 ->\n Ast_413.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_414.Parsetree.Psig_extension (x0, x1) ->\n Ast_413.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_414.Parsetree.class_type_declaration ->\n Ast_413.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_414.Parsetree.class_description -> Ast_413.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_414.Parsetree.class_type -> Ast_413.Parsetree.class_type =\n fun {\n Ast_414.Parsetree.pcty_desc;\n Ast_414.Parsetree.pcty_loc;\n Ast_414.Parsetree.pcty_attributes;\n } ->\n {\n Ast_413.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_413.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_413.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_414.Parsetree.class_type_desc -> Ast_413.Parsetree.class_type_desc =\n function\n | Ast_414.Parsetree.Pcty_constr (x0, x1) ->\n Ast_413.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_414.Parsetree.Pcty_signature x0 ->\n Ast_413.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_414.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_413.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_414.Parsetree.Pcty_extension x0 ->\n Ast_413.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_414.Parsetree.Pcty_open (x0, x1) ->\n Ast_413.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_414.Parsetree.class_signature -> Ast_413.Parsetree.class_signature =\n fun { Ast_414.Parsetree.pcsig_self; Ast_414.Parsetree.pcsig_fields } ->\n {\n Ast_413.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_413.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_414.Parsetree.class_type_field -> Ast_413.Parsetree.class_type_field =\n fun {\n Ast_414.Parsetree.pctf_desc;\n Ast_414.Parsetree.pctf_loc;\n Ast_414.Parsetree.pctf_attributes;\n } ->\n {\n Ast_413.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_413.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_413.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_414.Parsetree.class_type_field_desc ->\n Ast_413.Parsetree.class_type_field_desc = function\n | Ast_414.Parsetree.Pctf_inherit x0 ->\n Ast_413.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_414.Parsetree.Pctf_val x0 ->\n Ast_413.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_414.Parsetree.Pctf_method x0 ->\n Ast_413.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_414.Parsetree.Pctf_constraint x0 ->\n Ast_413.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_414.Parsetree.Pctf_attribute x0 ->\n Ast_413.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_414.Parsetree.Pctf_extension x0 ->\n Ast_413.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_414.Parsetree.extension -> Ast_413.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_414.Parsetree.class_infos ->\n 'g0 Ast_413.Parsetree.class_infos =\n fun f0\n {\n Ast_414.Parsetree.pci_virt;\n Ast_414.Parsetree.pci_params;\n Ast_414.Parsetree.pci_name;\n Ast_414.Parsetree.pci_expr;\n Ast_414.Parsetree.pci_loc;\n Ast_414.Parsetree.pci_attributes;\n } ->\n {\n Ast_413.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_413.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n pci_params;\n Ast_413.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_413.Parsetree.pci_expr = f0 pci_expr;\n Ast_413.Parsetree.pci_loc = copy_location pci_loc;\n Ast_413.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_414.Asttypes.virtual_flag -> Ast_413.Asttypes.virtual_flag = function\n | Ast_414.Asttypes.Virtual -> Ast_413.Asttypes.Virtual\n | Ast_414.Asttypes.Concrete -> Ast_413.Asttypes.Concrete\n\nand copy_include_description :\n Ast_414.Parsetree.include_description ->\n Ast_413.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_414.Parsetree.include_infos ->\n 'g0 Ast_413.Parsetree.include_infos =\n fun f0\n {\n Ast_414.Parsetree.pincl_mod;\n Ast_414.Parsetree.pincl_loc;\n Ast_414.Parsetree.pincl_attributes;\n } ->\n {\n Ast_413.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_413.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_413.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_414.Parsetree.open_description -> Ast_413.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_414.Parsetree.open_infos ->\n 'g0 Ast_413.Parsetree.open_infos =\n fun f0\n {\n Ast_414.Parsetree.popen_expr;\n Ast_414.Parsetree.popen_override;\n Ast_414.Parsetree.popen_loc;\n Ast_414.Parsetree.popen_attributes;\n } ->\n {\n Ast_413.Parsetree.popen_expr = f0 popen_expr;\n Ast_413.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_413.Parsetree.popen_loc = copy_location popen_loc;\n Ast_413.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_414.Asttypes.override_flag -> Ast_413.Asttypes.override_flag = function\n | Ast_414.Asttypes.Override -> Ast_413.Asttypes.Override\n | Ast_414.Asttypes.Fresh -> Ast_413.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_414.Parsetree.module_type_declaration ->\n Ast_413.Parsetree.module_type_declaration =\n fun {\n Ast_414.Parsetree.pmtd_name;\n Ast_414.Parsetree.pmtd_type;\n Ast_414.Parsetree.pmtd_attributes;\n Ast_414.Parsetree.pmtd_loc;\n } ->\n {\n Ast_413.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_413.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_413.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_413.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_414.Parsetree.module_substitution ->\n Ast_413.Parsetree.module_substitution =\n fun {\n Ast_414.Parsetree.pms_name;\n Ast_414.Parsetree.pms_manifest;\n Ast_414.Parsetree.pms_attributes;\n Ast_414.Parsetree.pms_loc;\n } ->\n {\n Ast_413.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_413.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_413.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_413.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_414.Parsetree.module_declaration -> Ast_413.Parsetree.module_declaration\n =\n fun {\n Ast_414.Parsetree.pmd_name;\n Ast_414.Parsetree.pmd_type;\n Ast_414.Parsetree.pmd_attributes;\n Ast_414.Parsetree.pmd_loc;\n } ->\n {\n Ast_413.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_413.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_413.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_413.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_414.Parsetree.type_exception -> Ast_413.Parsetree.type_exception =\n fun {\n Ast_414.Parsetree.ptyexn_constructor;\n Ast_414.Parsetree.ptyexn_loc;\n Ast_414.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_413.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_413.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_414.Parsetree.type_extension -> Ast_413.Parsetree.type_extension =\n fun {\n Ast_414.Parsetree.ptyext_path;\n Ast_414.Parsetree.ptyext_params;\n Ast_414.Parsetree.ptyext_constructors;\n Ast_414.Parsetree.ptyext_private;\n Ast_414.Parsetree.ptyext_loc;\n Ast_414.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_413.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptyext_params;\n Ast_413.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_413.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_413.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_413.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_414.Parsetree.extension_constructor ->\n Ast_413.Parsetree.extension_constructor =\n fun {\n Ast_414.Parsetree.pext_name;\n Ast_414.Parsetree.pext_kind;\n Ast_414.Parsetree.pext_loc;\n Ast_414.Parsetree.pext_attributes;\n } ->\n {\n Ast_413.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_413.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_413.Parsetree.pext_loc = copy_location pext_loc;\n Ast_413.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_414.Parsetree.extension_constructor_kind ->\n Ast_413.Parsetree.extension_constructor_kind = function\n | Ast_414.Parsetree.Pext_decl (x0, x1, x2) -> (\n match x0 with\n | [] ->\n Ast_413.Parsetree.Pext_decl\n (copy_constructor_arguments x1, Option.map copy_core_type x2)\n | hd :: _ ->\n migration_error hd.loc \"type parameters in extension constructors\")\n | Ast_414.Parsetree.Pext_rebind x0 ->\n Ast_413.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_414.Parsetree.type_declaration -> Ast_413.Parsetree.type_declaration =\n fun {\n Ast_414.Parsetree.ptype_name;\n Ast_414.Parsetree.ptype_params;\n Ast_414.Parsetree.ptype_cstrs;\n Ast_414.Parsetree.ptype_kind;\n Ast_414.Parsetree.ptype_private;\n Ast_414.Parsetree.ptype_manifest;\n Ast_414.Parsetree.ptype_attributes;\n Ast_414.Parsetree.ptype_loc;\n } ->\n {\n Ast_413.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_413.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptype_params;\n Ast_413.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_413.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_413.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_413.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_413.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_413.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_414.Asttypes.private_flag -> Ast_413.Asttypes.private_flag = function\n | Ast_414.Asttypes.Private -> Ast_413.Asttypes.Private\n | Ast_414.Asttypes.Public -> Ast_413.Asttypes.Public\n\nand copy_type_kind : Ast_414.Parsetree.type_kind -> Ast_413.Parsetree.type_kind\n = function\n | Ast_414.Parsetree.Ptype_abstract -> Ast_413.Parsetree.Ptype_abstract\n | Ast_414.Parsetree.Ptype_variant x0 ->\n Ast_413.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_414.Parsetree.Ptype_record x0 ->\n Ast_413.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_414.Parsetree.Ptype_open -> Ast_413.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_414.Parsetree.constructor_declaration ->\n Ast_413.Parsetree.constructor_declaration =\n fun {\n Ast_414.Parsetree.pcd_name;\n Ast_414.Parsetree.pcd_vars;\n Ast_414.Parsetree.pcd_args;\n Ast_414.Parsetree.pcd_res;\n Ast_414.Parsetree.pcd_loc;\n Ast_414.Parsetree.pcd_attributes;\n } ->\n match pcd_vars with\n | [] ->\n {\n Ast_413.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_413.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_413.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_413.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_413.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n | hd :: _ -> migration_error hd.loc \"pcd_vars in constructor declarations\"\n\nand copy_constructor_arguments :\n Ast_414.Parsetree.constructor_arguments ->\n Ast_413.Parsetree.constructor_arguments = function\n | Ast_414.Parsetree.Pcstr_tuple x0 ->\n Ast_413.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_414.Parsetree.Pcstr_record x0 ->\n Ast_413.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_414.Parsetree.label_declaration -> Ast_413.Parsetree.label_declaration =\n fun {\n Ast_414.Parsetree.pld_name;\n Ast_414.Parsetree.pld_mutable;\n Ast_414.Parsetree.pld_type;\n Ast_414.Parsetree.pld_loc;\n Ast_414.Parsetree.pld_attributes;\n } ->\n {\n Ast_413.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_413.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_413.Parsetree.pld_type = copy_core_type pld_type;\n Ast_413.Parsetree.pld_loc = copy_location pld_loc;\n Ast_413.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_414.Asttypes.mutable_flag -> Ast_413.Asttypes.mutable_flag = function\n | Ast_414.Asttypes.Immutable -> Ast_413.Asttypes.Immutable\n | Ast_414.Asttypes.Mutable -> Ast_413.Asttypes.Mutable\n\nand copy_injectivity :\n Ast_414.Asttypes.injectivity -> Ast_413.Asttypes.injectivity = function\n | Ast_414.Asttypes.Injective -> Ast_413.Asttypes.Injective\n | Ast_414.Asttypes.NoInjectivity -> Ast_413.Asttypes.NoInjectivity\n\nand copy_variance : Ast_414.Asttypes.variance -> Ast_413.Asttypes.variance =\n function\n | Ast_414.Asttypes.Covariant -> Ast_413.Asttypes.Covariant\n | Ast_414.Asttypes.Contravariant -> Ast_413.Asttypes.Contravariant\n | Ast_414.Asttypes.NoVariance -> Ast_413.Asttypes.NoVariance\n\nand copy_value_description :\n Ast_414.Parsetree.value_description -> Ast_413.Parsetree.value_description =\n fun {\n Ast_414.Parsetree.pval_name;\n Ast_414.Parsetree.pval_type;\n Ast_414.Parsetree.pval_prim;\n Ast_414.Parsetree.pval_attributes;\n Ast_414.Parsetree.pval_loc;\n } ->\n {\n Ast_413.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_413.Parsetree.pval_type = copy_core_type pval_type;\n Ast_413.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_413.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_413.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_414.Parsetree.object_field_desc -> Ast_413.Parsetree.object_field_desc =\n function\n | Ast_414.Parsetree.Otag (x0, x1) ->\n Ast_413.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_414.Parsetree.Oinherit x0 ->\n Ast_413.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_414.Asttypes.arg_label -> Ast_413.Asttypes.arg_label =\n function\n | Ast_414.Asttypes.Nolabel -> Ast_413.Asttypes.Nolabel\n | Ast_414.Asttypes.Labelled x0 -> Ast_413.Asttypes.Labelled x0\n | Ast_414.Asttypes.Optional x0 -> Ast_413.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_414.Asttypes.closed_flag -> Ast_413.Asttypes.closed_flag = function\n | Ast_414.Asttypes.Closed -> Ast_413.Asttypes.Closed\n | Ast_414.Asttypes.Open -> Ast_413.Asttypes.Open\n\nand copy_label : Ast_414.Asttypes.label -> Ast_413.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_414.Asttypes.rec_flag -> Ast_413.Asttypes.rec_flag =\n function\n | Ast_414.Asttypes.Nonrecursive -> Ast_413.Asttypes.Nonrecursive\n | Ast_414.Asttypes.Recursive -> Ast_413.Asttypes.Recursive\n\nand copy_constant : Ast_414.Parsetree.constant -> Ast_413.Parsetree.constant =\n function\n | Ast_414.Parsetree.Pconst_integer (x0, x1) ->\n Ast_413.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_414.Parsetree.Pconst_char x0 -> Ast_413.Parsetree.Pconst_char x0\n | Ast_414.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_413.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_414.Parsetree.Pconst_float (x0, x1) ->\n Ast_413.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_414.Asttypes.loc -> 'g0 Ast_413.Asttypes.loc =\n fun f0 { Ast_414.Asttypes.txt; Ast_414.Asttypes.loc } ->\n { Ast_413.Asttypes.txt = f0 txt; Ast_413.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_413\nmodule To = Ast_414\n\nlet rec copy_toplevel_phrase :\n Ast_413.Parsetree.toplevel_phrase -> Ast_414.Parsetree.toplevel_phrase =\n function\n | Ast_413.Parsetree.Ptop_def x0 ->\n Ast_414.Parsetree.Ptop_def (copy_structure x0)\n | Ast_413.Parsetree.Ptop_dir x0 ->\n Ast_414.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_413.Parsetree.toplevel_directive -> Ast_414.Parsetree.toplevel_directive\n =\n fun {\n Ast_413.Parsetree.pdir_name;\n Ast_413.Parsetree.pdir_arg;\n Ast_413.Parsetree.pdir_loc;\n } ->\n {\n Ast_414.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_414.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_414.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_413.Parsetree.directive_argument -> Ast_414.Parsetree.directive_argument\n =\n fun { Ast_413.Parsetree.pdira_desc; Ast_413.Parsetree.pdira_loc } ->\n {\n Ast_414.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_414.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_413.Parsetree.directive_argument_desc ->\n Ast_414.Parsetree.directive_argument_desc = function\n | Ast_413.Parsetree.Pdir_string x0 -> Ast_414.Parsetree.Pdir_string x0\n | Ast_413.Parsetree.Pdir_int (x0, x1) ->\n Ast_414.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_413.Parsetree.Pdir_ident x0 ->\n Ast_414.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_413.Parsetree.Pdir_bool x0 -> Ast_414.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_413.Parsetree.expression -> Ast_414.Parsetree.expression =\n fun {\n Ast_413.Parsetree.pexp_desc;\n Ast_413.Parsetree.pexp_loc;\n Ast_413.Parsetree.pexp_loc_stack;\n Ast_413.Parsetree.pexp_attributes;\n } ->\n {\n Ast_414.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_414.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_414.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_414.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_413.Parsetree.expression_desc -> Ast_414.Parsetree.expression_desc =\n function\n | Ast_413.Parsetree.Pexp_ident x0 ->\n Ast_414.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pexp_constant x0 ->\n Ast_414.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_413.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_414.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_413.Parsetree.Pexp_function x0 ->\n Ast_414.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_413.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_414.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_413.Parsetree.Pexp_apply (x0, x1) ->\n Ast_414.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_413.Parsetree.Pexp_match (x0, x1) ->\n Ast_414.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_413.Parsetree.Pexp_try (x0, x1) ->\n Ast_414.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_413.Parsetree.Pexp_tuple x0 ->\n Ast_414.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_413.Parsetree.Pexp_construct (x0, x1) ->\n Ast_414.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_413.Parsetree.Pexp_variant (x0, x1) ->\n Ast_414.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_413.Parsetree.Pexp_record (x0, x1) ->\n Ast_414.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_413.Parsetree.Pexp_field (x0, x1) ->\n Ast_414.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_413.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_414.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_413.Parsetree.Pexp_array x0 ->\n Ast_414.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_413.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_414.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_413.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_414.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_while (x0, x1) ->\n Ast_414.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_414.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_413.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_414.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_413.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_414.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_413.Parsetree.Pexp_send (x0, x1) ->\n Ast_414.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_413.Parsetree.Pexp_new x0 ->\n Ast_414.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_414.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_override x0 ->\n Ast_414.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_413.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_414.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_413.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_414.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_assert x0 ->\n Ast_414.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_413.Parsetree.Pexp_lazy x0 ->\n Ast_414.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_413.Parsetree.Pexp_poly (x0, x1) ->\n Ast_414.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_413.Parsetree.Pexp_object x0 ->\n Ast_414.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_413.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_414.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_pack x0 ->\n Ast_414.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_413.Parsetree.Pexp_open (x0, x1) ->\n Ast_414.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_letop x0 ->\n Ast_414.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_413.Parsetree.Pexp_extension x0 ->\n Ast_414.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_413.Parsetree.Pexp_unreachable -> Ast_414.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_413.Parsetree.letop -> Ast_414.Parsetree.letop =\n fun { Ast_413.Parsetree.let_; Ast_413.Parsetree.ands; Ast_413.Parsetree.body } ->\n {\n Ast_414.Parsetree.let_ = copy_binding_op let_;\n Ast_414.Parsetree.ands = List.map copy_binding_op ands;\n Ast_414.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_413.Parsetree.binding_op -> Ast_414.Parsetree.binding_op =\n fun {\n Ast_413.Parsetree.pbop_op;\n Ast_413.Parsetree.pbop_pat;\n Ast_413.Parsetree.pbop_exp;\n Ast_413.Parsetree.pbop_loc;\n } ->\n {\n Ast_414.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_414.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_414.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_414.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_413.Asttypes.direction_flag -> Ast_414.Asttypes.direction_flag =\n function\n | Ast_413.Asttypes.Upto -> Ast_414.Asttypes.Upto\n | Ast_413.Asttypes.Downto -> Ast_414.Asttypes.Downto\n\nand copy_case : Ast_413.Parsetree.case -> Ast_414.Parsetree.case =\n fun {\n Ast_413.Parsetree.pc_lhs;\n Ast_413.Parsetree.pc_guard;\n Ast_413.Parsetree.pc_rhs;\n } ->\n {\n Ast_414.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_414.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_414.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_413.Parsetree.value_binding -> Ast_414.Parsetree.value_binding =\n fun {\n Ast_413.Parsetree.pvb_pat;\n Ast_413.Parsetree.pvb_expr;\n Ast_413.Parsetree.pvb_attributes;\n Ast_413.Parsetree.pvb_loc;\n } ->\n {\n Ast_414.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_414.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_414.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_414.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_413.Parsetree.pattern -> Ast_414.Parsetree.pattern =\n fun {\n Ast_413.Parsetree.ppat_desc;\n Ast_413.Parsetree.ppat_loc;\n Ast_413.Parsetree.ppat_loc_stack;\n Ast_413.Parsetree.ppat_attributes;\n } ->\n {\n Ast_414.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_414.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_414.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_414.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_413.Parsetree.pattern_desc -> Ast_414.Parsetree.pattern_desc = function\n | Ast_413.Parsetree.Ppat_any -> Ast_414.Parsetree.Ppat_any\n | Ast_413.Parsetree.Ppat_var x0 ->\n Ast_414.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_413.Parsetree.Ppat_alias (x0, x1) ->\n Ast_414.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_413.Parsetree.Ppat_constant x0 ->\n Ast_414.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_413.Parsetree.Ppat_interval (x0, x1) ->\n Ast_414.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_413.Parsetree.Ppat_tuple x0 ->\n Ast_414.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_413.Parsetree.Ppat_construct (x0, x1) ->\n Ast_414.Parsetree.Ppat_construct\n ( copy_loc copy_Longident_t x0,\n Option.map\n (fun x ->\n let x0, x1 = x in\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_pattern x1))\n x1 )\n | Ast_413.Parsetree.Ppat_variant (x0, x1) ->\n Ast_414.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_413.Parsetree.Ppat_record (x0, x1) ->\n Ast_414.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_413.Parsetree.Ppat_array x0 ->\n Ast_414.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_413.Parsetree.Ppat_or (x0, x1) ->\n Ast_414.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_413.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_414.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_413.Parsetree.Ppat_type x0 ->\n Ast_414.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Ppat_lazy x0 ->\n Ast_414.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_413.Parsetree.Ppat_unpack x0 ->\n Ast_414.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_413.Parsetree.Ppat_exception x0 ->\n Ast_414.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_413.Parsetree.Ppat_extension x0 ->\n Ast_414.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_413.Parsetree.Ppat_open (x0, x1) ->\n Ast_414.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_413.Parsetree.core_type -> Ast_414.Parsetree.core_type\n =\n fun {\n Ast_413.Parsetree.ptyp_desc;\n Ast_413.Parsetree.ptyp_loc;\n Ast_413.Parsetree.ptyp_loc_stack;\n Ast_413.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_414.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_414.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_414.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_414.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_413.Parsetree.location_stack -> Ast_414.Parsetree.location_stack =\n fun x -> x\n\nand copy_core_type_desc :\n Ast_413.Parsetree.core_type_desc -> Ast_414.Parsetree.core_type_desc =\n function\n | Ast_413.Parsetree.Ptyp_any -> Ast_414.Parsetree.Ptyp_any\n | Ast_413.Parsetree.Ptyp_var x0 -> Ast_414.Parsetree.Ptyp_var x0\n | Ast_413.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_414.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_413.Parsetree.Ptyp_tuple x0 ->\n Ast_414.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_413.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_414.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_object (x0, x1) ->\n Ast_414.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_413.Parsetree.Ptyp_class (x0, x1) ->\n Ast_414.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_414.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_413.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_414.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_413.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_414.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_package x0 ->\n Ast_414.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_413.Parsetree.Ptyp_extension x0 ->\n Ast_414.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_413.Parsetree.package_type -> Ast_414.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_413.Parsetree.row_field -> Ast_414.Parsetree.row_field\n =\n fun {\n Ast_413.Parsetree.prf_desc;\n Ast_413.Parsetree.prf_loc;\n Ast_413.Parsetree.prf_attributes;\n } ->\n {\n Ast_414.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_414.Parsetree.prf_loc = copy_location prf_loc;\n Ast_414.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_413.Parsetree.row_field_desc -> Ast_414.Parsetree.row_field_desc =\n function\n | Ast_413.Parsetree.Rtag (x0, x1, x2) ->\n Ast_414.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_413.Parsetree.Rinherit x0 ->\n Ast_414.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_413.Parsetree.object_field -> Ast_414.Parsetree.object_field =\n fun {\n Ast_413.Parsetree.pof_desc;\n Ast_413.Parsetree.pof_loc;\n Ast_413.Parsetree.pof_attributes;\n } ->\n {\n Ast_414.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_414.Parsetree.pof_loc = copy_location pof_loc;\n Ast_414.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_413.Parsetree.attributes -> Ast_414.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_413.Parsetree.attribute -> Ast_414.Parsetree.attribute\n =\n fun {\n Ast_413.Parsetree.attr_name;\n Ast_413.Parsetree.attr_payload;\n Ast_413.Parsetree.attr_loc;\n } ->\n {\n Ast_414.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_414.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_414.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_413.Parsetree.payload -> Ast_414.Parsetree.payload =\n function\n | Ast_413.Parsetree.PStr x0 -> Ast_414.Parsetree.PStr (copy_structure x0)\n | Ast_413.Parsetree.PSig x0 -> Ast_414.Parsetree.PSig (copy_signature x0)\n | Ast_413.Parsetree.PTyp x0 -> Ast_414.Parsetree.PTyp (copy_core_type x0)\n | Ast_413.Parsetree.PPat (x0, x1) ->\n Ast_414.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_413.Parsetree.structure -> Ast_414.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_413.Parsetree.structure_item -> Ast_414.Parsetree.structure_item =\n fun { Ast_413.Parsetree.pstr_desc; Ast_413.Parsetree.pstr_loc } ->\n {\n Ast_414.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_414.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_413.Parsetree.structure_item_desc ->\n Ast_414.Parsetree.structure_item_desc = function\n | Ast_413.Parsetree.Pstr_eval (x0, x1) ->\n Ast_414.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_413.Parsetree.Pstr_value (x0, x1) ->\n Ast_414.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_413.Parsetree.Pstr_primitive x0 ->\n Ast_414.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_413.Parsetree.Pstr_type (x0, x1) ->\n Ast_414.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_413.Parsetree.Pstr_typext x0 ->\n Ast_414.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_413.Parsetree.Pstr_exception x0 ->\n Ast_414.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_413.Parsetree.Pstr_module x0 ->\n Ast_414.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_413.Parsetree.Pstr_recmodule x0 ->\n Ast_414.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_413.Parsetree.Pstr_modtype x0 ->\n Ast_414.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_413.Parsetree.Pstr_open x0 ->\n Ast_414.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_413.Parsetree.Pstr_class x0 ->\n Ast_414.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_413.Parsetree.Pstr_class_type x0 ->\n Ast_414.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_413.Parsetree.Pstr_include x0 ->\n Ast_414.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_413.Parsetree.Pstr_attribute x0 ->\n Ast_414.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pstr_extension (x0, x1) ->\n Ast_414.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_413.Parsetree.include_declaration ->\n Ast_414.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_413.Parsetree.class_declaration -> Ast_414.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_413.Parsetree.class_expr -> Ast_414.Parsetree.class_expr =\n fun {\n Ast_413.Parsetree.pcl_desc;\n Ast_413.Parsetree.pcl_loc;\n Ast_413.Parsetree.pcl_attributes;\n } ->\n {\n Ast_414.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_414.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_414.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_413.Parsetree.class_expr_desc -> Ast_414.Parsetree.class_expr_desc =\n function\n | Ast_413.Parsetree.Pcl_constr (x0, x1) ->\n Ast_414.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Pcl_structure x0 ->\n Ast_414.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_413.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_414.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_413.Parsetree.Pcl_apply (x0, x1) ->\n Ast_414.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_413.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_414.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_413.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_414.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_413.Parsetree.Pcl_extension x0 ->\n Ast_414.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_413.Parsetree.Pcl_open (x0, x1) ->\n Ast_414.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_413.Parsetree.class_structure -> Ast_414.Parsetree.class_structure =\n fun { Ast_413.Parsetree.pcstr_self; Ast_413.Parsetree.pcstr_fields } ->\n {\n Ast_414.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_414.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_413.Parsetree.class_field -> Ast_414.Parsetree.class_field =\n fun {\n Ast_413.Parsetree.pcf_desc;\n Ast_413.Parsetree.pcf_loc;\n Ast_413.Parsetree.pcf_attributes;\n } ->\n {\n Ast_414.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_414.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_414.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_413.Parsetree.class_field_desc -> Ast_414.Parsetree.class_field_desc =\n function\n | Ast_413.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_414.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_413.Parsetree.Pcf_val x0 ->\n Ast_414.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_413.Parsetree.Pcf_method x0 ->\n Ast_414.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_413.Parsetree.Pcf_constraint x0 ->\n Ast_414.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_413.Parsetree.Pcf_initializer x0 ->\n Ast_414.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_413.Parsetree.Pcf_attribute x0 ->\n Ast_414.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pcf_extension x0 ->\n Ast_414.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_413.Parsetree.class_field_kind -> Ast_414.Parsetree.class_field_kind =\n function\n | Ast_413.Parsetree.Cfk_virtual x0 ->\n Ast_414.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_413.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_414.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_413.Parsetree.open_declaration -> Ast_414.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_413.Parsetree.module_binding -> Ast_414.Parsetree.module_binding =\n fun {\n Ast_413.Parsetree.pmb_name;\n Ast_413.Parsetree.pmb_expr;\n Ast_413.Parsetree.pmb_attributes;\n Ast_413.Parsetree.pmb_loc;\n } ->\n {\n Ast_414.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_414.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_414.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_414.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_413.Parsetree.module_expr -> Ast_414.Parsetree.module_expr =\n fun {\n Ast_413.Parsetree.pmod_desc;\n Ast_413.Parsetree.pmod_loc;\n Ast_413.Parsetree.pmod_attributes;\n } ->\n {\n Ast_414.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_414.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_414.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_413.Parsetree.module_expr_desc -> Ast_414.Parsetree.module_expr_desc =\n function\n | Ast_413.Parsetree.Pmod_ident x0 ->\n Ast_414.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pmod_structure x0 ->\n Ast_414.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_413.Parsetree.Pmod_functor (x0, x1) ->\n Ast_414.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_413.Parsetree.Pmod_apply (x0, x1) ->\n Ast_414.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_413.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_414.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_413.Parsetree.Pmod_unpack x0 ->\n Ast_414.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_413.Parsetree.Pmod_extension x0 ->\n Ast_414.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_413.Parsetree.functor_parameter -> Ast_414.Parsetree.functor_parameter =\n function\n | Ast_413.Parsetree.Unit -> Ast_414.Parsetree.Unit\n | Ast_413.Parsetree.Named (x0, x1) ->\n Ast_414.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_413.Parsetree.module_type -> Ast_414.Parsetree.module_type =\n fun {\n Ast_413.Parsetree.pmty_desc;\n Ast_413.Parsetree.pmty_loc;\n Ast_413.Parsetree.pmty_attributes;\n } ->\n {\n Ast_414.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_414.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_414.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_413.Parsetree.module_type_desc -> Ast_414.Parsetree.module_type_desc =\n function\n | Ast_413.Parsetree.Pmty_ident x0 ->\n Ast_414.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pmty_signature x0 ->\n Ast_414.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_413.Parsetree.Pmty_functor (x0, x1) ->\n Ast_414.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_413.Parsetree.Pmty_with (x0, x1) ->\n Ast_414.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_413.Parsetree.Pmty_typeof x0 ->\n Ast_414.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_413.Parsetree.Pmty_extension x0 ->\n Ast_414.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_413.Parsetree.Pmty_alias x0 ->\n Ast_414.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_413.Parsetree.with_constraint -> Ast_414.Parsetree.with_constraint =\n function\n | Ast_413.Parsetree.Pwith_type (x0, x1) ->\n Ast_414.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_413.Parsetree.Pwith_module (x0, x1) ->\n Ast_414.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_413.Parsetree.Pwith_modtype (x0, x1) ->\n Ast_414.Parsetree.Pwith_modtype\n (copy_loc copy_Longident_t x0, copy_module_type x1)\n | Ast_413.Parsetree.Pwith_modtypesubst (x0, x1) ->\n Ast_414.Parsetree.Pwith_modtypesubst\n (copy_loc copy_Longident_t x0, copy_module_type x1)\n | Ast_413.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_414.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_413.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_414.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_413.Parsetree.signature -> Ast_414.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_413.Parsetree.signature_item -> Ast_414.Parsetree.signature_item =\n fun { Ast_413.Parsetree.psig_desc; Ast_413.Parsetree.psig_loc } ->\n {\n Ast_414.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_414.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_413.Parsetree.signature_item_desc ->\n Ast_414.Parsetree.signature_item_desc = function\n | Ast_413.Parsetree.Psig_value x0 ->\n Ast_414.Parsetree.Psig_value (copy_value_description x0)\n | Ast_413.Parsetree.Psig_type (x0, x1) ->\n Ast_414.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_413.Parsetree.Psig_typesubst x0 ->\n Ast_414.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_413.Parsetree.Psig_typext x0 ->\n Ast_414.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_413.Parsetree.Psig_exception x0 ->\n Ast_414.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_413.Parsetree.Psig_module x0 ->\n Ast_414.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_413.Parsetree.Psig_modsubst x0 ->\n Ast_414.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_413.Parsetree.Psig_recmodule x0 ->\n Ast_414.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_413.Parsetree.Psig_modtype x0 ->\n Ast_414.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_413.Parsetree.Psig_modtypesubst x0 ->\n Ast_414.Parsetree.Psig_modtypesubst (copy_module_type_declaration x0)\n | Ast_413.Parsetree.Psig_open x0 ->\n Ast_414.Parsetree.Psig_open (copy_open_description x0)\n | Ast_413.Parsetree.Psig_include x0 ->\n Ast_414.Parsetree.Psig_include (copy_include_description x0)\n | Ast_413.Parsetree.Psig_class x0 ->\n Ast_414.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_413.Parsetree.Psig_class_type x0 ->\n Ast_414.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_413.Parsetree.Psig_attribute x0 ->\n Ast_414.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Psig_extension (x0, x1) ->\n Ast_414.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_413.Parsetree.class_type_declaration ->\n Ast_414.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_413.Parsetree.class_description -> Ast_414.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_413.Parsetree.class_type -> Ast_414.Parsetree.class_type =\n fun {\n Ast_413.Parsetree.pcty_desc;\n Ast_413.Parsetree.pcty_loc;\n Ast_413.Parsetree.pcty_attributes;\n } ->\n {\n Ast_414.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_414.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_414.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_413.Parsetree.class_type_desc -> Ast_414.Parsetree.class_type_desc =\n function\n | Ast_413.Parsetree.Pcty_constr (x0, x1) ->\n Ast_414.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Pcty_signature x0 ->\n Ast_414.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_413.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_414.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_413.Parsetree.Pcty_extension x0 ->\n Ast_414.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_413.Parsetree.Pcty_open (x0, x1) ->\n Ast_414.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_413.Parsetree.class_signature -> Ast_414.Parsetree.class_signature =\n fun { Ast_413.Parsetree.pcsig_self; Ast_413.Parsetree.pcsig_fields } ->\n {\n Ast_414.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_414.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_413.Parsetree.class_type_field -> Ast_414.Parsetree.class_type_field =\n fun {\n Ast_413.Parsetree.pctf_desc;\n Ast_413.Parsetree.pctf_loc;\n Ast_413.Parsetree.pctf_attributes;\n } ->\n {\n Ast_414.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_414.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_414.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_413.Parsetree.class_type_field_desc ->\n Ast_414.Parsetree.class_type_field_desc = function\n | Ast_413.Parsetree.Pctf_inherit x0 ->\n Ast_414.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_413.Parsetree.Pctf_val x0 ->\n Ast_414.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_413.Parsetree.Pctf_method x0 ->\n Ast_414.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_413.Parsetree.Pctf_constraint x0 ->\n Ast_414.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_413.Parsetree.Pctf_attribute x0 ->\n Ast_414.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pctf_extension x0 ->\n Ast_414.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_413.Parsetree.extension -> Ast_414.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.class_infos ->\n 'g0 Ast_414.Parsetree.class_infos =\n fun f0\n {\n Ast_413.Parsetree.pci_virt;\n Ast_413.Parsetree.pci_params;\n Ast_413.Parsetree.pci_name;\n Ast_413.Parsetree.pci_expr;\n Ast_413.Parsetree.pci_loc;\n Ast_413.Parsetree.pci_attributes;\n } ->\n {\n Ast_414.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_414.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n pci_params;\n Ast_414.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_414.Parsetree.pci_expr = f0 pci_expr;\n Ast_414.Parsetree.pci_loc = copy_location pci_loc;\n Ast_414.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_413.Asttypes.virtual_flag -> Ast_414.Asttypes.virtual_flag = function\n | Ast_413.Asttypes.Virtual -> Ast_414.Asttypes.Virtual\n | Ast_413.Asttypes.Concrete -> Ast_414.Asttypes.Concrete\n\nand copy_include_description :\n Ast_413.Parsetree.include_description ->\n Ast_414.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.include_infos ->\n 'g0 Ast_414.Parsetree.include_infos =\n fun f0\n {\n Ast_413.Parsetree.pincl_mod;\n Ast_413.Parsetree.pincl_loc;\n Ast_413.Parsetree.pincl_attributes;\n } ->\n {\n Ast_414.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_414.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_414.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_413.Parsetree.open_description -> Ast_414.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.open_infos ->\n 'g0 Ast_414.Parsetree.open_infos =\n fun f0\n {\n Ast_413.Parsetree.popen_expr;\n Ast_413.Parsetree.popen_override;\n Ast_413.Parsetree.popen_loc;\n Ast_413.Parsetree.popen_attributes;\n } ->\n {\n Ast_414.Parsetree.popen_expr = f0 popen_expr;\n Ast_414.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_414.Parsetree.popen_loc = copy_location popen_loc;\n Ast_414.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_413.Asttypes.override_flag -> Ast_414.Asttypes.override_flag = function\n | Ast_413.Asttypes.Override -> Ast_414.Asttypes.Override\n | Ast_413.Asttypes.Fresh -> Ast_414.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_413.Parsetree.module_type_declaration ->\n Ast_414.Parsetree.module_type_declaration =\n fun {\n Ast_413.Parsetree.pmtd_name;\n Ast_413.Parsetree.pmtd_type;\n Ast_413.Parsetree.pmtd_attributes;\n Ast_413.Parsetree.pmtd_loc;\n } ->\n {\n Ast_414.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_414.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_414.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_414.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_413.Parsetree.module_substitution ->\n Ast_414.Parsetree.module_substitution =\n fun {\n Ast_413.Parsetree.pms_name;\n Ast_413.Parsetree.pms_manifest;\n Ast_413.Parsetree.pms_attributes;\n Ast_413.Parsetree.pms_loc;\n } ->\n {\n Ast_414.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_414.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_414.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_414.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_413.Parsetree.module_declaration -> Ast_414.Parsetree.module_declaration\n =\n fun {\n Ast_413.Parsetree.pmd_name;\n Ast_413.Parsetree.pmd_type;\n Ast_413.Parsetree.pmd_attributes;\n Ast_413.Parsetree.pmd_loc;\n } ->\n {\n Ast_414.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_414.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_414.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_414.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_413.Parsetree.type_exception -> Ast_414.Parsetree.type_exception =\n fun {\n Ast_413.Parsetree.ptyexn_constructor;\n Ast_413.Parsetree.ptyexn_loc;\n Ast_413.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_414.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_414.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_414.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_413.Parsetree.type_extension -> Ast_414.Parsetree.type_extension =\n fun {\n Ast_413.Parsetree.ptyext_path;\n Ast_413.Parsetree.ptyext_params;\n Ast_413.Parsetree.ptyext_constructors;\n Ast_413.Parsetree.ptyext_private;\n Ast_413.Parsetree.ptyext_loc;\n Ast_413.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_414.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_414.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptyext_params;\n Ast_414.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_414.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_414.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_414.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_413.Parsetree.extension_constructor ->\n Ast_414.Parsetree.extension_constructor =\n fun {\n Ast_413.Parsetree.pext_name;\n Ast_413.Parsetree.pext_kind;\n Ast_413.Parsetree.pext_loc;\n Ast_413.Parsetree.pext_attributes;\n } ->\n {\n Ast_414.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_414.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_414.Parsetree.pext_loc = copy_location pext_loc;\n Ast_414.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_413.Parsetree.extension_constructor_kind ->\n Ast_414.Parsetree.extension_constructor_kind = function\n | Ast_413.Parsetree.Pext_decl (x0, x1) ->\n Ast_414.Parsetree.Pext_decl\n ([], copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_413.Parsetree.Pext_rebind x0 ->\n Ast_414.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_413.Parsetree.type_declaration -> Ast_414.Parsetree.type_declaration =\n fun {\n Ast_413.Parsetree.ptype_name;\n Ast_413.Parsetree.ptype_params;\n Ast_413.Parsetree.ptype_cstrs;\n Ast_413.Parsetree.ptype_kind;\n Ast_413.Parsetree.ptype_private;\n Ast_413.Parsetree.ptype_manifest;\n Ast_413.Parsetree.ptype_attributes;\n Ast_413.Parsetree.ptype_loc;\n } ->\n {\n Ast_414.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_414.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptype_params;\n Ast_414.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_414.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_414.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_414.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_414.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_414.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_413.Asttypes.private_flag -> Ast_414.Asttypes.private_flag = function\n | Ast_413.Asttypes.Private -> Ast_414.Asttypes.Private\n | Ast_413.Asttypes.Public -> Ast_414.Asttypes.Public\n\nand copy_type_kind : Ast_413.Parsetree.type_kind -> Ast_414.Parsetree.type_kind\n = function\n | Ast_413.Parsetree.Ptype_abstract -> Ast_414.Parsetree.Ptype_abstract\n | Ast_413.Parsetree.Ptype_variant x0 ->\n Ast_414.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_413.Parsetree.Ptype_record x0 ->\n Ast_414.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_413.Parsetree.Ptype_open -> Ast_414.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_413.Parsetree.constructor_declaration ->\n Ast_414.Parsetree.constructor_declaration =\n fun {\n Ast_413.Parsetree.pcd_name;\n Ast_413.Parsetree.pcd_args;\n Ast_413.Parsetree.pcd_res;\n Ast_413.Parsetree.pcd_loc;\n Ast_413.Parsetree.pcd_attributes;\n } ->\n {\n Ast_414.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_414.Parsetree.pcd_vars = [];\n Ast_414.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_414.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_414.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_414.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_413.Parsetree.constructor_arguments ->\n Ast_414.Parsetree.constructor_arguments = function\n | Ast_413.Parsetree.Pcstr_tuple x0 ->\n Ast_414.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_413.Parsetree.Pcstr_record x0 ->\n Ast_414.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_413.Parsetree.label_declaration -> Ast_414.Parsetree.label_declaration =\n fun {\n Ast_413.Parsetree.pld_name;\n Ast_413.Parsetree.pld_mutable;\n Ast_413.Parsetree.pld_type;\n Ast_413.Parsetree.pld_loc;\n Ast_413.Parsetree.pld_attributes;\n } ->\n {\n Ast_414.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_414.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_414.Parsetree.pld_type = copy_core_type pld_type;\n Ast_414.Parsetree.pld_loc = copy_location pld_loc;\n Ast_414.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_413.Asttypes.mutable_flag -> Ast_414.Asttypes.mutable_flag = function\n | Ast_413.Asttypes.Immutable -> Ast_414.Asttypes.Immutable\n | Ast_413.Asttypes.Mutable -> Ast_414.Asttypes.Mutable\n\nand copy_injectivity :\n Ast_413.Asttypes.injectivity -> Ast_414.Asttypes.injectivity = function\n | Ast_413.Asttypes.Injective -> Ast_414.Asttypes.Injective\n | Ast_413.Asttypes.NoInjectivity -> Ast_414.Asttypes.NoInjectivity\n\nand copy_variance : Ast_413.Asttypes.variance -> Ast_414.Asttypes.variance =\n function\n | Ast_413.Asttypes.Covariant -> Ast_414.Asttypes.Covariant\n | Ast_413.Asttypes.Contravariant -> Ast_414.Asttypes.Contravariant\n | Ast_413.Asttypes.NoVariance -> Ast_414.Asttypes.NoVariance\n\nand copy_value_description :\n Ast_413.Parsetree.value_description -> Ast_414.Parsetree.value_description =\n fun {\n Ast_413.Parsetree.pval_name;\n Ast_413.Parsetree.pval_type;\n Ast_413.Parsetree.pval_prim;\n Ast_413.Parsetree.pval_attributes;\n Ast_413.Parsetree.pval_loc;\n } ->\n {\n Ast_414.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_414.Parsetree.pval_type = copy_core_type pval_type;\n Ast_414.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_414.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_414.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_413.Parsetree.object_field_desc -> Ast_414.Parsetree.object_field_desc =\n function\n | Ast_413.Parsetree.Otag (x0, x1) ->\n Ast_414.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_413.Parsetree.Oinherit x0 ->\n Ast_414.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_413.Asttypes.arg_label -> Ast_414.Asttypes.arg_label =\n function\n | Ast_413.Asttypes.Nolabel -> Ast_414.Asttypes.Nolabel\n | Ast_413.Asttypes.Labelled x0 -> Ast_414.Asttypes.Labelled x0\n | Ast_413.Asttypes.Optional x0 -> Ast_414.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_413.Asttypes.closed_flag -> Ast_414.Asttypes.closed_flag = function\n | Ast_413.Asttypes.Closed -> Ast_414.Asttypes.Closed\n | Ast_413.Asttypes.Open -> Ast_414.Asttypes.Open\n\nand copy_label : Ast_413.Asttypes.label -> Ast_414.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_413.Asttypes.rec_flag -> Ast_414.Asttypes.rec_flag =\n function\n | Ast_413.Asttypes.Nonrecursive -> Ast_414.Asttypes.Nonrecursive\n | Ast_413.Asttypes.Recursive -> Ast_414.Asttypes.Recursive\n\nand copy_constant : Ast_413.Parsetree.constant -> Ast_414.Parsetree.constant =\n function\n | Ast_413.Parsetree.Pconst_integer (x0, x1) ->\n Ast_414.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_413.Parsetree.Pconst_char x0 -> Ast_414.Parsetree.Pconst_char x0\n | Ast_413.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_414.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_413.Parsetree.Pconst_float (x0, x1) ->\n Ast_414.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_413.Asttypes.loc -> 'g0 Ast_414.Asttypes.loc =\n fun f0 { Ast_413.Asttypes.txt; Ast_413.Asttypes.loc } ->\n { Ast_414.Asttypes.txt = f0 txt; Ast_414.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_413\nmodule To = Ast_412\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.13\" missing_feature\n\nlet rec copy_toplevel_phrase :\n Ast_413.Parsetree.toplevel_phrase -> Ast_412.Parsetree.toplevel_phrase =\n function\n | Ast_413.Parsetree.Ptop_def x0 ->\n Ast_412.Parsetree.Ptop_def (copy_structure x0)\n | Ast_413.Parsetree.Ptop_dir x0 ->\n Ast_412.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_413.Parsetree.toplevel_directive -> Ast_412.Parsetree.toplevel_directive\n =\n fun {\n Ast_413.Parsetree.pdir_name;\n Ast_413.Parsetree.pdir_arg;\n Ast_413.Parsetree.pdir_loc;\n } ->\n {\n Ast_412.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_412.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_412.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_413.Parsetree.directive_argument -> Ast_412.Parsetree.directive_argument\n =\n fun { Ast_413.Parsetree.pdira_desc; Ast_413.Parsetree.pdira_loc } ->\n {\n Ast_412.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_412.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_413.Parsetree.directive_argument_desc ->\n Ast_412.Parsetree.directive_argument_desc = function\n | Ast_413.Parsetree.Pdir_string x0 -> Ast_412.Parsetree.Pdir_string x0\n | Ast_413.Parsetree.Pdir_int (x0, x1) ->\n Ast_412.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_413.Parsetree.Pdir_ident x0 ->\n Ast_412.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_413.Parsetree.Pdir_bool x0 -> Ast_412.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_413.Parsetree.expression -> Ast_412.Parsetree.expression =\n fun {\n Ast_413.Parsetree.pexp_desc;\n Ast_413.Parsetree.pexp_loc;\n Ast_413.Parsetree.pexp_loc_stack;\n Ast_413.Parsetree.pexp_attributes;\n } ->\n {\n Ast_412.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_412.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_412.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_412.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_413.Parsetree.expression_desc -> Ast_412.Parsetree.expression_desc =\n function\n | Ast_413.Parsetree.Pexp_ident x0 ->\n Ast_412.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pexp_constant x0 ->\n Ast_412.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_413.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_413.Parsetree.Pexp_function x0 ->\n Ast_412.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_413.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_412.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_413.Parsetree.Pexp_apply (x0, x1) ->\n Ast_412.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_413.Parsetree.Pexp_match (x0, x1) ->\n Ast_412.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_413.Parsetree.Pexp_try (x0, x1) ->\n Ast_412.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_413.Parsetree.Pexp_tuple x0 ->\n Ast_412.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_413.Parsetree.Pexp_construct (x0, x1) ->\n Ast_412.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_413.Parsetree.Pexp_variant (x0, x1) ->\n Ast_412.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_413.Parsetree.Pexp_record (x0, x1) ->\n Ast_412.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_413.Parsetree.Pexp_field (x0, x1) ->\n Ast_412.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_413.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_413.Parsetree.Pexp_array x0 ->\n Ast_412.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_413.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_413.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_412.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_while (x0, x1) ->\n Ast_412.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_412.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_413.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_412.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_413.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_413.Parsetree.Pexp_send (x0, x1) ->\n Ast_412.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_413.Parsetree.Pexp_new x0 ->\n Ast_412.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_412.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_override x0 ->\n Ast_412.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_413.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_413.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_412.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_assert x0 ->\n Ast_412.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_413.Parsetree.Pexp_lazy x0 ->\n Ast_412.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_413.Parsetree.Pexp_poly (x0, x1) ->\n Ast_412.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_413.Parsetree.Pexp_object x0 ->\n Ast_412.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_413.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_412.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_pack x0 ->\n Ast_412.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_413.Parsetree.Pexp_open (x0, x1) ->\n Ast_412.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_letop x0 ->\n Ast_412.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_413.Parsetree.Pexp_extension x0 ->\n Ast_412.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_413.Parsetree.Pexp_unreachable -> Ast_412.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_413.Parsetree.letop -> Ast_412.Parsetree.letop =\n fun { Ast_413.Parsetree.let_; Ast_413.Parsetree.ands; Ast_413.Parsetree.body } ->\n {\n Ast_412.Parsetree.let_ = copy_binding_op let_;\n Ast_412.Parsetree.ands = List.map copy_binding_op ands;\n Ast_412.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_413.Parsetree.binding_op -> Ast_412.Parsetree.binding_op =\n fun {\n Ast_413.Parsetree.pbop_op;\n Ast_413.Parsetree.pbop_pat;\n Ast_413.Parsetree.pbop_exp;\n Ast_413.Parsetree.pbop_loc;\n } ->\n {\n Ast_412.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_412.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_412.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_412.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_413.Asttypes.direction_flag -> Ast_412.Asttypes.direction_flag =\n function\n | Ast_413.Asttypes.Upto -> Ast_412.Asttypes.Upto\n | Ast_413.Asttypes.Downto -> Ast_412.Asttypes.Downto\n\nand copy_case : Ast_413.Parsetree.case -> Ast_412.Parsetree.case =\n fun {\n Ast_413.Parsetree.pc_lhs;\n Ast_413.Parsetree.pc_guard;\n Ast_413.Parsetree.pc_rhs;\n } ->\n {\n Ast_412.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_412.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_412.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_413.Parsetree.value_binding -> Ast_412.Parsetree.value_binding =\n fun {\n Ast_413.Parsetree.pvb_pat;\n Ast_413.Parsetree.pvb_expr;\n Ast_413.Parsetree.pvb_attributes;\n Ast_413.Parsetree.pvb_loc;\n } ->\n {\n Ast_412.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_412.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_412.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_412.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_413.Parsetree.pattern -> Ast_412.Parsetree.pattern =\n fun {\n Ast_413.Parsetree.ppat_desc;\n Ast_413.Parsetree.ppat_loc;\n Ast_413.Parsetree.ppat_loc_stack;\n Ast_413.Parsetree.ppat_attributes;\n } ->\n {\n Ast_412.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_412.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_412.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_412.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_413.Parsetree.pattern_desc -> Ast_412.Parsetree.pattern_desc = function\n | Ast_413.Parsetree.Ppat_any -> Ast_412.Parsetree.Ppat_any\n | Ast_413.Parsetree.Ppat_var x0 ->\n Ast_412.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_413.Parsetree.Ppat_alias (x0, x1) ->\n Ast_412.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_413.Parsetree.Ppat_constant x0 ->\n Ast_412.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_413.Parsetree.Ppat_interval (x0, x1) ->\n Ast_412.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_413.Parsetree.Ppat_tuple x0 ->\n Ast_412.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_413.Parsetree.Ppat_construct (x0, x1) ->\n Ast_412.Parsetree.Ppat_construct\n ( copy_loc copy_Longident_t x0,\n Option.map\n (fun x ->\n let x0, x1 = x in\n (match x0 with\n | [] -> ()\n | ty :: _ ->\n migration_error ty.Ast_413.Asttypes.loc\n \"existentials in pattern-matching\");\n copy_pattern x1)\n x1 )\n | Ast_413.Parsetree.Ppat_variant (x0, x1) ->\n Ast_412.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_413.Parsetree.Ppat_record (x0, x1) ->\n Ast_412.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_413.Parsetree.Ppat_array x0 ->\n Ast_412.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_413.Parsetree.Ppat_or (x0, x1) ->\n Ast_412.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_413.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_412.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_413.Parsetree.Ppat_type x0 ->\n Ast_412.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Ppat_lazy x0 ->\n Ast_412.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_413.Parsetree.Ppat_unpack x0 ->\n Ast_412.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_413.Parsetree.Ppat_exception x0 ->\n Ast_412.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_413.Parsetree.Ppat_extension x0 ->\n Ast_412.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_413.Parsetree.Ppat_open (x0, x1) ->\n Ast_412.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_413.Parsetree.core_type -> Ast_412.Parsetree.core_type\n =\n fun {\n Ast_413.Parsetree.ptyp_desc;\n Ast_413.Parsetree.ptyp_loc;\n Ast_413.Parsetree.ptyp_loc_stack;\n Ast_413.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_412.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_412.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_412.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_413.Parsetree.location_stack -> Ast_412.Parsetree.location_stack =\n fun x -> List.map copy_location x\n\nand copy_core_type_desc :\n Ast_413.Parsetree.core_type_desc -> Ast_412.Parsetree.core_type_desc =\n function\n | Ast_413.Parsetree.Ptyp_any -> Ast_412.Parsetree.Ptyp_any\n | Ast_413.Parsetree.Ptyp_var x0 -> Ast_412.Parsetree.Ptyp_var x0\n | Ast_413.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_412.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_413.Parsetree.Ptyp_tuple x0 ->\n Ast_412.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_413.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_412.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_object (x0, x1) ->\n Ast_412.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_413.Parsetree.Ptyp_class (x0, x1) ->\n Ast_412.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_412.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_413.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_412.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_413.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_412.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_package x0 ->\n Ast_412.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_413.Parsetree.Ptyp_extension x0 ->\n Ast_412.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_413.Parsetree.package_type -> Ast_412.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_413.Parsetree.row_field -> Ast_412.Parsetree.row_field\n =\n fun {\n Ast_413.Parsetree.prf_desc;\n Ast_413.Parsetree.prf_loc;\n Ast_413.Parsetree.prf_attributes;\n } ->\n {\n Ast_412.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_412.Parsetree.prf_loc = copy_location prf_loc;\n Ast_412.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_413.Parsetree.row_field_desc -> Ast_412.Parsetree.row_field_desc =\n function\n | Ast_413.Parsetree.Rtag (x0, x1, x2) ->\n Ast_412.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_413.Parsetree.Rinherit x0 ->\n Ast_412.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_413.Parsetree.object_field -> Ast_412.Parsetree.object_field =\n fun {\n Ast_413.Parsetree.pof_desc;\n Ast_413.Parsetree.pof_loc;\n Ast_413.Parsetree.pof_attributes;\n } ->\n {\n Ast_412.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_412.Parsetree.pof_loc = copy_location pof_loc;\n Ast_412.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_413.Parsetree.attributes -> Ast_412.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_413.Parsetree.attribute -> Ast_412.Parsetree.attribute\n =\n fun {\n Ast_413.Parsetree.attr_name;\n Ast_413.Parsetree.attr_payload;\n Ast_413.Parsetree.attr_loc;\n } ->\n {\n Ast_412.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_412.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_412.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_413.Parsetree.payload -> Ast_412.Parsetree.payload =\n function\n | Ast_413.Parsetree.PStr x0 -> Ast_412.Parsetree.PStr (copy_structure x0)\n | Ast_413.Parsetree.PSig x0 -> Ast_412.Parsetree.PSig (copy_signature x0)\n | Ast_413.Parsetree.PTyp x0 -> Ast_412.Parsetree.PTyp (copy_core_type x0)\n | Ast_413.Parsetree.PPat (x0, x1) ->\n Ast_412.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_413.Parsetree.structure -> Ast_412.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_413.Parsetree.structure_item -> Ast_412.Parsetree.structure_item =\n fun { Ast_413.Parsetree.pstr_desc; Ast_413.Parsetree.pstr_loc } ->\n {\n Ast_412.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_412.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_413.Parsetree.structure_item_desc ->\n Ast_412.Parsetree.structure_item_desc = function\n | Ast_413.Parsetree.Pstr_eval (x0, x1) ->\n Ast_412.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_413.Parsetree.Pstr_value (x0, x1) ->\n Ast_412.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_413.Parsetree.Pstr_primitive x0 ->\n Ast_412.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_413.Parsetree.Pstr_type (x0, x1) ->\n Ast_412.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_413.Parsetree.Pstr_typext x0 ->\n Ast_412.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_413.Parsetree.Pstr_exception x0 ->\n Ast_412.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_413.Parsetree.Pstr_module x0 ->\n Ast_412.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_413.Parsetree.Pstr_recmodule x0 ->\n Ast_412.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_413.Parsetree.Pstr_modtype x0 ->\n Ast_412.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_413.Parsetree.Pstr_open x0 ->\n Ast_412.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_413.Parsetree.Pstr_class x0 ->\n Ast_412.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_413.Parsetree.Pstr_class_type x0 ->\n Ast_412.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_413.Parsetree.Pstr_include x0 ->\n Ast_412.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_413.Parsetree.Pstr_attribute x0 ->\n Ast_412.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pstr_extension (x0, x1) ->\n Ast_412.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_413.Parsetree.include_declaration ->\n Ast_412.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_413.Parsetree.class_declaration -> Ast_412.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_413.Parsetree.class_expr -> Ast_412.Parsetree.class_expr =\n fun {\n Ast_413.Parsetree.pcl_desc;\n Ast_413.Parsetree.pcl_loc;\n Ast_413.Parsetree.pcl_attributes;\n } ->\n {\n Ast_412.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_412.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_412.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_413.Parsetree.class_expr_desc -> Ast_412.Parsetree.class_expr_desc =\n function\n | Ast_413.Parsetree.Pcl_constr (x0, x1) ->\n Ast_412.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Pcl_structure x0 ->\n Ast_412.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_413.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_412.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_413.Parsetree.Pcl_apply (x0, x1) ->\n Ast_412.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_413.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_412.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_413.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_412.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_413.Parsetree.Pcl_extension x0 ->\n Ast_412.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_413.Parsetree.Pcl_open (x0, x1) ->\n Ast_412.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_413.Parsetree.class_structure -> Ast_412.Parsetree.class_structure =\n fun { Ast_413.Parsetree.pcstr_self; Ast_413.Parsetree.pcstr_fields } ->\n {\n Ast_412.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_412.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_413.Parsetree.class_field -> Ast_412.Parsetree.class_field =\n fun {\n Ast_413.Parsetree.pcf_desc;\n Ast_413.Parsetree.pcf_loc;\n Ast_413.Parsetree.pcf_attributes;\n } ->\n {\n Ast_412.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_412.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_412.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_413.Parsetree.class_field_desc -> Ast_412.Parsetree.class_field_desc =\n function\n | Ast_413.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_412.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_413.Parsetree.Pcf_val x0 ->\n Ast_412.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_413.Parsetree.Pcf_method x0 ->\n Ast_412.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_413.Parsetree.Pcf_constraint x0 ->\n Ast_412.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_413.Parsetree.Pcf_initializer x0 ->\n Ast_412.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_413.Parsetree.Pcf_attribute x0 ->\n Ast_412.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pcf_extension x0 ->\n Ast_412.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_413.Parsetree.class_field_kind -> Ast_412.Parsetree.class_field_kind =\n function\n | Ast_413.Parsetree.Cfk_virtual x0 ->\n Ast_412.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_413.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_412.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_413.Parsetree.open_declaration -> Ast_412.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_413.Parsetree.module_binding -> Ast_412.Parsetree.module_binding =\n fun {\n Ast_413.Parsetree.pmb_name;\n Ast_413.Parsetree.pmb_expr;\n Ast_413.Parsetree.pmb_attributes;\n Ast_413.Parsetree.pmb_loc;\n } ->\n {\n Ast_412.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_412.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_412.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_412.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_413.Parsetree.module_expr -> Ast_412.Parsetree.module_expr =\n fun {\n Ast_413.Parsetree.pmod_desc;\n Ast_413.Parsetree.pmod_loc;\n Ast_413.Parsetree.pmod_attributes;\n } ->\n {\n Ast_412.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_412.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_412.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_413.Parsetree.module_expr_desc -> Ast_412.Parsetree.module_expr_desc =\n function\n | Ast_413.Parsetree.Pmod_ident x0 ->\n Ast_412.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pmod_structure x0 ->\n Ast_412.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_413.Parsetree.Pmod_functor (x0, x1) ->\n Ast_412.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_413.Parsetree.Pmod_apply (x0, x1) ->\n Ast_412.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_413.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_412.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_413.Parsetree.Pmod_unpack x0 ->\n Ast_412.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_413.Parsetree.Pmod_extension x0 ->\n Ast_412.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_413.Parsetree.functor_parameter -> Ast_412.Parsetree.functor_parameter =\n function\n | Ast_413.Parsetree.Unit -> Ast_412.Parsetree.Unit\n | Ast_413.Parsetree.Named (x0, x1) ->\n Ast_412.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_413.Parsetree.module_type -> Ast_412.Parsetree.module_type =\n fun {\n Ast_413.Parsetree.pmty_desc;\n Ast_413.Parsetree.pmty_loc;\n Ast_413.Parsetree.pmty_attributes;\n } ->\n {\n Ast_412.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_412.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_412.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_413.Parsetree.module_type_desc -> Ast_412.Parsetree.module_type_desc =\n function\n | Ast_413.Parsetree.Pmty_ident x0 ->\n Ast_412.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pmty_signature x0 ->\n Ast_412.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_413.Parsetree.Pmty_functor (x0, x1) ->\n Ast_412.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_413.Parsetree.Pmty_with (x0, x1) ->\n Ast_412.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_413.Parsetree.Pmty_typeof x0 ->\n Ast_412.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_413.Parsetree.Pmty_extension x0 ->\n Ast_412.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_413.Parsetree.Pmty_alias x0 ->\n Ast_412.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_413.Parsetree.with_constraint -> Ast_412.Parsetree.with_constraint =\n function\n | Ast_413.Parsetree.Pwith_type (x0, x1) ->\n Ast_412.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_413.Parsetree.Pwith_module (x0, x1) ->\n Ast_412.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_413.Parsetree.Pwith_modtype (_x0, x1) ->\n migration_error x1.Ast_413.Parsetree.pmty_loc \"module type substitution\"\n | Ast_413.Parsetree.Pwith_modtypesubst (_x0, x1) ->\n migration_error x1.Ast_413.Parsetree.pmty_loc\n \"destructive module type substitution\"\n | Ast_413.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_412.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_413.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_412.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_413.Parsetree.signature -> Ast_412.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_413.Parsetree.signature_item -> Ast_412.Parsetree.signature_item =\n fun { Ast_413.Parsetree.psig_desc; Ast_413.Parsetree.psig_loc } ->\n {\n Ast_412.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_412.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_413.Parsetree.signature_item_desc ->\n Ast_412.Parsetree.signature_item_desc = function\n | Ast_413.Parsetree.Psig_value x0 ->\n Ast_412.Parsetree.Psig_value (copy_value_description x0)\n | Ast_413.Parsetree.Psig_type (x0, x1) ->\n Ast_412.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_413.Parsetree.Psig_typesubst x0 ->\n Ast_412.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_413.Parsetree.Psig_typext x0 ->\n Ast_412.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_413.Parsetree.Psig_exception x0 ->\n Ast_412.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_413.Parsetree.Psig_module x0 ->\n Ast_412.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_413.Parsetree.Psig_modsubst x0 ->\n Ast_412.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_413.Parsetree.Psig_recmodule x0 ->\n Ast_412.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_413.Parsetree.Psig_modtype x0 ->\n Ast_412.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_413.Parsetree.Psig_modtypesubst x0 ->\n migration_error x0.Ast_413.Parsetree.pmtd_loc\n \"local module type substitution\"\n | Ast_413.Parsetree.Psig_open x0 ->\n Ast_412.Parsetree.Psig_open (copy_open_description x0)\n | Ast_413.Parsetree.Psig_include x0 ->\n Ast_412.Parsetree.Psig_include (copy_include_description x0)\n | Ast_413.Parsetree.Psig_class x0 ->\n Ast_412.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_413.Parsetree.Psig_class_type x0 ->\n Ast_412.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_413.Parsetree.Psig_attribute x0 ->\n Ast_412.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Psig_extension (x0, x1) ->\n Ast_412.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_413.Parsetree.class_type_declaration ->\n Ast_412.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_413.Parsetree.class_description -> Ast_412.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_413.Parsetree.class_type -> Ast_412.Parsetree.class_type =\n fun {\n Ast_413.Parsetree.pcty_desc;\n Ast_413.Parsetree.pcty_loc;\n Ast_413.Parsetree.pcty_attributes;\n } ->\n {\n Ast_412.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_412.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_412.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_413.Parsetree.class_type_desc -> Ast_412.Parsetree.class_type_desc =\n function\n | Ast_413.Parsetree.Pcty_constr (x0, x1) ->\n Ast_412.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Pcty_signature x0 ->\n Ast_412.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_413.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_412.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_413.Parsetree.Pcty_extension x0 ->\n Ast_412.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_413.Parsetree.Pcty_open (x0, x1) ->\n Ast_412.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_413.Parsetree.class_signature -> Ast_412.Parsetree.class_signature =\n fun { Ast_413.Parsetree.pcsig_self; Ast_413.Parsetree.pcsig_fields } ->\n {\n Ast_412.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_412.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_413.Parsetree.class_type_field -> Ast_412.Parsetree.class_type_field =\n fun {\n Ast_413.Parsetree.pctf_desc;\n Ast_413.Parsetree.pctf_loc;\n Ast_413.Parsetree.pctf_attributes;\n } ->\n {\n Ast_412.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_412.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_412.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_413.Parsetree.class_type_field_desc ->\n Ast_412.Parsetree.class_type_field_desc = function\n | Ast_413.Parsetree.Pctf_inherit x0 ->\n Ast_412.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_413.Parsetree.Pctf_val x0 ->\n Ast_412.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_413.Parsetree.Pctf_method x0 ->\n Ast_412.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_413.Parsetree.Pctf_constraint x0 ->\n Ast_412.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_413.Parsetree.Pctf_attribute x0 ->\n Ast_412.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pctf_extension x0 ->\n Ast_412.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_413.Parsetree.extension -> Ast_412.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.class_infos ->\n 'g0 Ast_412.Parsetree.class_infos =\n fun f0\n {\n Ast_413.Parsetree.pci_virt;\n Ast_413.Parsetree.pci_params;\n Ast_413.Parsetree.pci_name;\n Ast_413.Parsetree.pci_expr;\n Ast_413.Parsetree.pci_loc;\n Ast_413.Parsetree.pci_attributes;\n } ->\n {\n Ast_412.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_412.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n pci_params;\n Ast_412.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_412.Parsetree.pci_expr = f0 pci_expr;\n Ast_412.Parsetree.pci_loc = copy_location pci_loc;\n Ast_412.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_413.Asttypes.virtual_flag -> Ast_412.Asttypes.virtual_flag = function\n | Ast_413.Asttypes.Virtual -> Ast_412.Asttypes.Virtual\n | Ast_413.Asttypes.Concrete -> Ast_412.Asttypes.Concrete\n\nand copy_include_description :\n Ast_413.Parsetree.include_description ->\n Ast_412.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.include_infos ->\n 'g0 Ast_412.Parsetree.include_infos =\n fun f0\n {\n Ast_413.Parsetree.pincl_mod;\n Ast_413.Parsetree.pincl_loc;\n Ast_413.Parsetree.pincl_attributes;\n } ->\n {\n Ast_412.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_412.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_412.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_413.Parsetree.open_description -> Ast_412.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.open_infos ->\n 'g0 Ast_412.Parsetree.open_infos =\n fun f0\n {\n Ast_413.Parsetree.popen_expr;\n Ast_413.Parsetree.popen_override;\n Ast_413.Parsetree.popen_loc;\n Ast_413.Parsetree.popen_attributes;\n } ->\n {\n Ast_412.Parsetree.popen_expr = f0 popen_expr;\n Ast_412.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_412.Parsetree.popen_loc = copy_location popen_loc;\n Ast_412.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_413.Asttypes.override_flag -> Ast_412.Asttypes.override_flag = function\n | Ast_413.Asttypes.Override -> Ast_412.Asttypes.Override\n | Ast_413.Asttypes.Fresh -> Ast_412.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_413.Parsetree.module_type_declaration ->\n Ast_412.Parsetree.module_type_declaration =\n fun {\n Ast_413.Parsetree.pmtd_name;\n Ast_413.Parsetree.pmtd_type;\n Ast_413.Parsetree.pmtd_attributes;\n Ast_413.Parsetree.pmtd_loc;\n } ->\n {\n Ast_412.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_412.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_412.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_412.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_413.Parsetree.module_substitution ->\n Ast_412.Parsetree.module_substitution =\n fun {\n Ast_413.Parsetree.pms_name;\n Ast_413.Parsetree.pms_manifest;\n Ast_413.Parsetree.pms_attributes;\n Ast_413.Parsetree.pms_loc;\n } ->\n {\n Ast_412.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_412.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_412.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_412.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_413.Parsetree.module_declaration -> Ast_412.Parsetree.module_declaration\n =\n fun {\n Ast_413.Parsetree.pmd_name;\n Ast_413.Parsetree.pmd_type;\n Ast_413.Parsetree.pmd_attributes;\n Ast_413.Parsetree.pmd_loc;\n } ->\n {\n Ast_412.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_412.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_412.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_412.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_413.Parsetree.type_exception -> Ast_412.Parsetree.type_exception =\n fun {\n Ast_413.Parsetree.ptyexn_constructor;\n Ast_413.Parsetree.ptyexn_loc;\n Ast_413.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_412.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_412.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_413.Parsetree.type_extension -> Ast_412.Parsetree.type_extension =\n fun {\n Ast_413.Parsetree.ptyext_path;\n Ast_413.Parsetree.ptyext_params;\n Ast_413.Parsetree.ptyext_constructors;\n Ast_413.Parsetree.ptyext_private;\n Ast_413.Parsetree.ptyext_loc;\n Ast_413.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_412.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptyext_params;\n Ast_412.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_412.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_412.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_412.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_413.Parsetree.extension_constructor ->\n Ast_412.Parsetree.extension_constructor =\n fun {\n Ast_413.Parsetree.pext_name;\n Ast_413.Parsetree.pext_kind;\n Ast_413.Parsetree.pext_loc;\n Ast_413.Parsetree.pext_attributes;\n } ->\n {\n Ast_412.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_412.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_412.Parsetree.pext_loc = copy_location pext_loc;\n Ast_412.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_413.Parsetree.extension_constructor_kind ->\n Ast_412.Parsetree.extension_constructor_kind = function\n | Ast_413.Parsetree.Pext_decl (x0, x1) ->\n Ast_412.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_413.Parsetree.Pext_rebind x0 ->\n Ast_412.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_413.Parsetree.type_declaration -> Ast_412.Parsetree.type_declaration =\n fun {\n Ast_413.Parsetree.ptype_name;\n Ast_413.Parsetree.ptype_params;\n Ast_413.Parsetree.ptype_cstrs;\n Ast_413.Parsetree.ptype_kind;\n Ast_413.Parsetree.ptype_private;\n Ast_413.Parsetree.ptype_manifest;\n Ast_413.Parsetree.ptype_attributes;\n Ast_413.Parsetree.ptype_loc;\n } ->\n {\n Ast_412.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_412.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptype_params;\n Ast_412.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_412.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_412.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_412.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_412.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_412.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_413.Asttypes.private_flag -> Ast_412.Asttypes.private_flag = function\n | Ast_413.Asttypes.Private -> Ast_412.Asttypes.Private\n | Ast_413.Asttypes.Public -> Ast_412.Asttypes.Public\n\nand copy_type_kind : Ast_413.Parsetree.type_kind -> Ast_412.Parsetree.type_kind\n = function\n | Ast_413.Parsetree.Ptype_abstract -> Ast_412.Parsetree.Ptype_abstract\n | Ast_413.Parsetree.Ptype_variant x0 ->\n Ast_412.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_413.Parsetree.Ptype_record x0 ->\n Ast_412.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_413.Parsetree.Ptype_open -> Ast_412.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_413.Parsetree.constructor_declaration ->\n Ast_412.Parsetree.constructor_declaration =\n fun {\n Ast_413.Parsetree.pcd_name;\n Ast_413.Parsetree.pcd_args;\n Ast_413.Parsetree.pcd_res;\n Ast_413.Parsetree.pcd_loc;\n Ast_413.Parsetree.pcd_attributes;\n } ->\n {\n Ast_412.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_412.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_412.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_412.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_412.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_413.Parsetree.constructor_arguments ->\n Ast_412.Parsetree.constructor_arguments = function\n | Ast_413.Parsetree.Pcstr_tuple x0 ->\n Ast_412.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_413.Parsetree.Pcstr_record x0 ->\n Ast_412.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_413.Parsetree.label_declaration -> Ast_412.Parsetree.label_declaration =\n fun {\n Ast_413.Parsetree.pld_name;\n Ast_413.Parsetree.pld_mutable;\n Ast_413.Parsetree.pld_type;\n Ast_413.Parsetree.pld_loc;\n Ast_413.Parsetree.pld_attributes;\n } ->\n {\n Ast_412.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_412.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_412.Parsetree.pld_type = copy_core_type pld_type;\n Ast_412.Parsetree.pld_loc = copy_location pld_loc;\n Ast_412.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_413.Asttypes.mutable_flag -> Ast_412.Asttypes.mutable_flag = function\n | Ast_413.Asttypes.Immutable -> Ast_412.Asttypes.Immutable\n | Ast_413.Asttypes.Mutable -> Ast_412.Asttypes.Mutable\n\nand copy_injectivity :\n Ast_413.Asttypes.injectivity -> Ast_412.Asttypes.injectivity = function\n | Ast_413.Asttypes.Injective -> Ast_412.Asttypes.Injective\n | Ast_413.Asttypes.NoInjectivity -> Ast_412.Asttypes.NoInjectivity\n\nand copy_variance : Ast_413.Asttypes.variance -> Ast_412.Asttypes.variance =\n function\n | Ast_413.Asttypes.Covariant -> Ast_412.Asttypes.Covariant\n | Ast_413.Asttypes.Contravariant -> Ast_412.Asttypes.Contravariant\n | Ast_413.Asttypes.NoVariance -> Ast_412.Asttypes.NoVariance\n\nand copy_value_description :\n Ast_413.Parsetree.value_description -> Ast_412.Parsetree.value_description =\n fun {\n Ast_413.Parsetree.pval_name;\n Ast_413.Parsetree.pval_type;\n Ast_413.Parsetree.pval_prim;\n Ast_413.Parsetree.pval_attributes;\n Ast_413.Parsetree.pval_loc;\n } ->\n {\n Ast_412.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_412.Parsetree.pval_type = copy_core_type pval_type;\n Ast_412.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_412.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_412.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_413.Parsetree.object_field_desc -> Ast_412.Parsetree.object_field_desc =\n function\n | Ast_413.Parsetree.Otag (x0, x1) ->\n Ast_412.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_413.Parsetree.Oinherit x0 ->\n Ast_412.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_413.Asttypes.arg_label -> Ast_412.Asttypes.arg_label =\n function\n | Ast_413.Asttypes.Nolabel -> Ast_412.Asttypes.Nolabel\n | Ast_413.Asttypes.Labelled x0 -> Ast_412.Asttypes.Labelled x0\n | Ast_413.Asttypes.Optional x0 -> Ast_412.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_413.Asttypes.closed_flag -> Ast_412.Asttypes.closed_flag = function\n | Ast_413.Asttypes.Closed -> Ast_412.Asttypes.Closed\n | Ast_413.Asttypes.Open -> Ast_412.Asttypes.Open\n\nand copy_label : Ast_413.Asttypes.label -> Ast_412.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_413.Asttypes.rec_flag -> Ast_412.Asttypes.rec_flag =\n function\n | Ast_413.Asttypes.Nonrecursive -> Ast_412.Asttypes.Nonrecursive\n | Ast_413.Asttypes.Recursive -> Ast_412.Asttypes.Recursive\n\nand copy_constant : Ast_413.Parsetree.constant -> Ast_412.Parsetree.constant =\n function\n | Ast_413.Parsetree.Pconst_integer (x0, x1) ->\n Ast_412.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_413.Parsetree.Pconst_char x0 -> Ast_412.Parsetree.Pconst_char x0\n | Ast_413.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_412.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_413.Parsetree.Pconst_float (x0, x1) ->\n Ast_412.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_413.Asttypes.loc -> 'g0 Ast_412.Asttypes.loc =\n fun f0 { Ast_413.Asttypes.txt; Ast_413.Asttypes.loc } ->\n { Ast_412.Asttypes.txt = f0 txt; Ast_412.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_412\nmodule To = Ast_413\n\nlet rec copy_toplevel_phrase :\n Ast_412.Parsetree.toplevel_phrase -> Ast_413.Parsetree.toplevel_phrase =\n function\n | Ast_412.Parsetree.Ptop_def x0 ->\n Ast_413.Parsetree.Ptop_def (copy_structure x0)\n | Ast_412.Parsetree.Ptop_dir x0 ->\n Ast_413.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_412.Parsetree.toplevel_directive -> Ast_413.Parsetree.toplevel_directive\n =\n fun {\n Ast_412.Parsetree.pdir_name;\n Ast_412.Parsetree.pdir_arg;\n Ast_412.Parsetree.pdir_loc;\n } ->\n {\n Ast_413.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_413.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_413.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_412.Parsetree.directive_argument -> Ast_413.Parsetree.directive_argument\n =\n fun { Ast_412.Parsetree.pdira_desc; Ast_412.Parsetree.pdira_loc } ->\n {\n Ast_413.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_413.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_412.Parsetree.directive_argument_desc ->\n Ast_413.Parsetree.directive_argument_desc = function\n | Ast_412.Parsetree.Pdir_string x0 -> Ast_413.Parsetree.Pdir_string x0\n | Ast_412.Parsetree.Pdir_int (x0, x1) ->\n Ast_413.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_412.Parsetree.Pdir_ident x0 ->\n Ast_413.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_412.Parsetree.Pdir_bool x0 -> Ast_413.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_412.Parsetree.expression -> Ast_413.Parsetree.expression =\n fun {\n Ast_412.Parsetree.pexp_desc;\n Ast_412.Parsetree.pexp_loc;\n Ast_412.Parsetree.pexp_loc_stack;\n Ast_412.Parsetree.pexp_attributes;\n } ->\n {\n Ast_413.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_413.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_413.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_413.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_412.Parsetree.expression_desc -> Ast_413.Parsetree.expression_desc =\n function\n | Ast_412.Parsetree.Pexp_ident x0 ->\n Ast_413.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pexp_constant x0 ->\n Ast_413.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_412.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_412.Parsetree.Pexp_function x0 ->\n Ast_413.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_412.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_413.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_412.Parsetree.Pexp_apply (x0, x1) ->\n Ast_413.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_412.Parsetree.Pexp_match (x0, x1) ->\n Ast_413.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_412.Parsetree.Pexp_try (x0, x1) ->\n Ast_413.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_412.Parsetree.Pexp_tuple x0 ->\n Ast_413.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_412.Parsetree.Pexp_construct (x0, x1) ->\n Ast_413.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_412.Parsetree.Pexp_variant (x0, x1) ->\n Ast_413.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_412.Parsetree.Pexp_record (x0, x1) ->\n Ast_413.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_412.Parsetree.Pexp_field (x0, x1) ->\n Ast_413.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_412.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_412.Parsetree.Pexp_array x0 ->\n Ast_413.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_412.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_412.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_413.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_while (x0, x1) ->\n Ast_413.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_413.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_412.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_413.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_412.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_412.Parsetree.Pexp_send (x0, x1) ->\n Ast_413.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_412.Parsetree.Pexp_new x0 ->\n Ast_413.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_413.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_override x0 ->\n Ast_413.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_412.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_412.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_413.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_assert x0 ->\n Ast_413.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_412.Parsetree.Pexp_lazy x0 ->\n Ast_413.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_412.Parsetree.Pexp_poly (x0, x1) ->\n Ast_413.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_412.Parsetree.Pexp_object x0 ->\n Ast_413.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_412.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_413.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_pack x0 ->\n Ast_413.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_412.Parsetree.Pexp_open (x0, x1) ->\n Ast_413.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_letop x0 ->\n Ast_413.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_412.Parsetree.Pexp_extension x0 ->\n Ast_413.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_412.Parsetree.Pexp_unreachable -> Ast_413.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_412.Parsetree.letop -> Ast_413.Parsetree.letop =\n fun { Ast_412.Parsetree.let_; Ast_412.Parsetree.ands; Ast_412.Parsetree.body } ->\n {\n Ast_413.Parsetree.let_ = copy_binding_op let_;\n Ast_413.Parsetree.ands = List.map copy_binding_op ands;\n Ast_413.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_412.Parsetree.binding_op -> Ast_413.Parsetree.binding_op =\n fun {\n Ast_412.Parsetree.pbop_op;\n Ast_412.Parsetree.pbop_pat;\n Ast_412.Parsetree.pbop_exp;\n Ast_412.Parsetree.pbop_loc;\n } ->\n {\n Ast_413.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_413.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_413.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_413.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_412.Asttypes.direction_flag -> Ast_413.Asttypes.direction_flag =\n function\n | Ast_412.Asttypes.Upto -> Ast_413.Asttypes.Upto\n | Ast_412.Asttypes.Downto -> Ast_413.Asttypes.Downto\n\nand copy_case : Ast_412.Parsetree.case -> Ast_413.Parsetree.case =\n fun {\n Ast_412.Parsetree.pc_lhs;\n Ast_412.Parsetree.pc_guard;\n Ast_412.Parsetree.pc_rhs;\n } ->\n {\n Ast_413.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_413.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_413.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_412.Parsetree.value_binding -> Ast_413.Parsetree.value_binding =\n fun {\n Ast_412.Parsetree.pvb_pat;\n Ast_412.Parsetree.pvb_expr;\n Ast_412.Parsetree.pvb_attributes;\n Ast_412.Parsetree.pvb_loc;\n } ->\n {\n Ast_413.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_413.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_413.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_413.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_412.Parsetree.pattern -> Ast_413.Parsetree.pattern =\n fun {\n Ast_412.Parsetree.ppat_desc;\n Ast_412.Parsetree.ppat_loc;\n Ast_412.Parsetree.ppat_loc_stack;\n Ast_412.Parsetree.ppat_attributes;\n } ->\n {\n Ast_413.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_413.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_413.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_413.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_412.Parsetree.pattern_desc -> Ast_413.Parsetree.pattern_desc = function\n | Ast_412.Parsetree.Ppat_any -> Ast_413.Parsetree.Ppat_any\n | Ast_412.Parsetree.Ppat_var x0 ->\n Ast_413.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_412.Parsetree.Ppat_alias (x0, x1) ->\n Ast_413.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_412.Parsetree.Ppat_constant x0 ->\n Ast_413.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_412.Parsetree.Ppat_interval (x0, x1) ->\n Ast_413.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_412.Parsetree.Ppat_tuple x0 ->\n Ast_413.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_412.Parsetree.Ppat_construct (x0, x1) ->\n Ast_413.Parsetree.Ppat_construct\n ( copy_loc copy_Longident_t x0,\n Option.map (fun x -> ([], copy_pattern x)) x1 )\n | Ast_412.Parsetree.Ppat_variant (x0, x1) ->\n Ast_413.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_412.Parsetree.Ppat_record (x0, x1) ->\n Ast_413.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_412.Parsetree.Ppat_array x0 ->\n Ast_413.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_412.Parsetree.Ppat_or (x0, x1) ->\n Ast_413.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_412.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_413.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_412.Parsetree.Ppat_type x0 ->\n Ast_413.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Ppat_lazy x0 ->\n Ast_413.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_412.Parsetree.Ppat_unpack x0 ->\n Ast_413.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_412.Parsetree.Ppat_exception x0 ->\n Ast_413.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_412.Parsetree.Ppat_extension x0 ->\n Ast_413.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_412.Parsetree.Ppat_open (x0, x1) ->\n Ast_413.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_412.Parsetree.core_type -> Ast_413.Parsetree.core_type\n =\n fun {\n Ast_412.Parsetree.ptyp_desc;\n Ast_412.Parsetree.ptyp_loc;\n Ast_412.Parsetree.ptyp_loc_stack;\n Ast_412.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_413.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_413.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_413.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_412.Parsetree.location_stack -> Ast_413.Parsetree.location_stack =\n fun x -> List.map copy_location x\n\nand copy_core_type_desc :\n Ast_412.Parsetree.core_type_desc -> Ast_413.Parsetree.core_type_desc =\n function\n | Ast_412.Parsetree.Ptyp_any -> Ast_413.Parsetree.Ptyp_any\n | Ast_412.Parsetree.Ptyp_var x0 -> Ast_413.Parsetree.Ptyp_var x0\n | Ast_412.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_413.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_412.Parsetree.Ptyp_tuple x0 ->\n Ast_413.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_412.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_413.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_object (x0, x1) ->\n Ast_413.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_412.Parsetree.Ptyp_class (x0, x1) ->\n Ast_413.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_413.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_412.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_413.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_412.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_413.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_package x0 ->\n Ast_413.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_412.Parsetree.Ptyp_extension x0 ->\n Ast_413.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_412.Parsetree.package_type -> Ast_413.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_412.Parsetree.row_field -> Ast_413.Parsetree.row_field\n =\n fun {\n Ast_412.Parsetree.prf_desc;\n Ast_412.Parsetree.prf_loc;\n Ast_412.Parsetree.prf_attributes;\n } ->\n {\n Ast_413.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_413.Parsetree.prf_loc = copy_location prf_loc;\n Ast_413.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_412.Parsetree.row_field_desc -> Ast_413.Parsetree.row_field_desc =\n function\n | Ast_412.Parsetree.Rtag (x0, x1, x2) ->\n Ast_413.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_412.Parsetree.Rinherit x0 ->\n Ast_413.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_412.Parsetree.object_field -> Ast_413.Parsetree.object_field =\n fun {\n Ast_412.Parsetree.pof_desc;\n Ast_412.Parsetree.pof_loc;\n Ast_412.Parsetree.pof_attributes;\n } ->\n {\n Ast_413.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_413.Parsetree.pof_loc = copy_location pof_loc;\n Ast_413.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_412.Parsetree.attributes -> Ast_413.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_412.Parsetree.attribute -> Ast_413.Parsetree.attribute\n =\n fun {\n Ast_412.Parsetree.attr_name;\n Ast_412.Parsetree.attr_payload;\n Ast_412.Parsetree.attr_loc;\n } ->\n {\n Ast_413.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_413.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_413.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_412.Parsetree.payload -> Ast_413.Parsetree.payload =\n function\n | Ast_412.Parsetree.PStr x0 -> Ast_413.Parsetree.PStr (copy_structure x0)\n | Ast_412.Parsetree.PSig x0 -> Ast_413.Parsetree.PSig (copy_signature x0)\n | Ast_412.Parsetree.PTyp x0 -> Ast_413.Parsetree.PTyp (copy_core_type x0)\n | Ast_412.Parsetree.PPat (x0, x1) ->\n Ast_413.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_412.Parsetree.structure -> Ast_413.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_412.Parsetree.structure_item -> Ast_413.Parsetree.structure_item =\n fun { Ast_412.Parsetree.pstr_desc; Ast_412.Parsetree.pstr_loc } ->\n {\n Ast_413.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_413.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_412.Parsetree.structure_item_desc ->\n Ast_413.Parsetree.structure_item_desc = function\n | Ast_412.Parsetree.Pstr_eval (x0, x1) ->\n Ast_413.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_412.Parsetree.Pstr_value (x0, x1) ->\n Ast_413.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_412.Parsetree.Pstr_primitive x0 ->\n Ast_413.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_412.Parsetree.Pstr_type (x0, x1) ->\n Ast_413.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_412.Parsetree.Pstr_typext x0 ->\n Ast_413.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_412.Parsetree.Pstr_exception x0 ->\n Ast_413.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_412.Parsetree.Pstr_module x0 ->\n Ast_413.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_412.Parsetree.Pstr_recmodule x0 ->\n Ast_413.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_412.Parsetree.Pstr_modtype x0 ->\n Ast_413.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_412.Parsetree.Pstr_open x0 ->\n Ast_413.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_412.Parsetree.Pstr_class x0 ->\n Ast_413.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_412.Parsetree.Pstr_class_type x0 ->\n Ast_413.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_412.Parsetree.Pstr_include x0 ->\n Ast_413.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_412.Parsetree.Pstr_attribute x0 ->\n Ast_413.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pstr_extension (x0, x1) ->\n Ast_413.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_412.Parsetree.include_declaration ->\n Ast_413.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_412.Parsetree.class_declaration -> Ast_413.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_412.Parsetree.class_expr -> Ast_413.Parsetree.class_expr =\n fun {\n Ast_412.Parsetree.pcl_desc;\n Ast_412.Parsetree.pcl_loc;\n Ast_412.Parsetree.pcl_attributes;\n } ->\n {\n Ast_413.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_413.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_413.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_412.Parsetree.class_expr_desc -> Ast_413.Parsetree.class_expr_desc =\n function\n | Ast_412.Parsetree.Pcl_constr (x0, x1) ->\n Ast_413.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Pcl_structure x0 ->\n Ast_413.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_412.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_413.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_412.Parsetree.Pcl_apply (x0, x1) ->\n Ast_413.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_412.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_413.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_412.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_413.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_412.Parsetree.Pcl_extension x0 ->\n Ast_413.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_412.Parsetree.Pcl_open (x0, x1) ->\n Ast_413.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_412.Parsetree.class_structure -> Ast_413.Parsetree.class_structure =\n fun { Ast_412.Parsetree.pcstr_self; Ast_412.Parsetree.pcstr_fields } ->\n {\n Ast_413.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_413.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_412.Parsetree.class_field -> Ast_413.Parsetree.class_field =\n fun {\n Ast_412.Parsetree.pcf_desc;\n Ast_412.Parsetree.pcf_loc;\n Ast_412.Parsetree.pcf_attributes;\n } ->\n {\n Ast_413.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_413.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_413.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_412.Parsetree.class_field_desc -> Ast_413.Parsetree.class_field_desc =\n function\n | Ast_412.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_413.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_412.Parsetree.Pcf_val x0 ->\n Ast_413.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_412.Parsetree.Pcf_method x0 ->\n Ast_413.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_412.Parsetree.Pcf_constraint x0 ->\n Ast_413.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_412.Parsetree.Pcf_initializer x0 ->\n Ast_413.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_412.Parsetree.Pcf_attribute x0 ->\n Ast_413.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pcf_extension x0 ->\n Ast_413.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_412.Parsetree.class_field_kind -> Ast_413.Parsetree.class_field_kind =\n function\n | Ast_412.Parsetree.Cfk_virtual x0 ->\n Ast_413.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_412.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_413.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_412.Parsetree.open_declaration -> Ast_413.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_412.Parsetree.module_binding -> Ast_413.Parsetree.module_binding =\n fun {\n Ast_412.Parsetree.pmb_name;\n Ast_412.Parsetree.pmb_expr;\n Ast_412.Parsetree.pmb_attributes;\n Ast_412.Parsetree.pmb_loc;\n } ->\n {\n Ast_413.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_413.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_413.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_413.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_412.Parsetree.module_expr -> Ast_413.Parsetree.module_expr =\n fun {\n Ast_412.Parsetree.pmod_desc;\n Ast_412.Parsetree.pmod_loc;\n Ast_412.Parsetree.pmod_attributes;\n } ->\n {\n Ast_413.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_413.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_413.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_412.Parsetree.module_expr_desc -> Ast_413.Parsetree.module_expr_desc =\n function\n | Ast_412.Parsetree.Pmod_ident x0 ->\n Ast_413.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pmod_structure x0 ->\n Ast_413.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_412.Parsetree.Pmod_functor (x0, x1) ->\n Ast_413.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_412.Parsetree.Pmod_apply (x0, x1) ->\n Ast_413.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_412.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_413.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_412.Parsetree.Pmod_unpack x0 ->\n Ast_413.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_412.Parsetree.Pmod_extension x0 ->\n Ast_413.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_412.Parsetree.functor_parameter -> Ast_413.Parsetree.functor_parameter =\n function\n | Ast_412.Parsetree.Unit -> Ast_413.Parsetree.Unit\n | Ast_412.Parsetree.Named (x0, x1) ->\n Ast_413.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_412.Parsetree.module_type -> Ast_413.Parsetree.module_type =\n fun {\n Ast_412.Parsetree.pmty_desc;\n Ast_412.Parsetree.pmty_loc;\n Ast_412.Parsetree.pmty_attributes;\n } ->\n {\n Ast_413.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_413.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_413.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_412.Parsetree.module_type_desc -> Ast_413.Parsetree.module_type_desc =\n function\n | Ast_412.Parsetree.Pmty_ident x0 ->\n Ast_413.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pmty_signature x0 ->\n Ast_413.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_412.Parsetree.Pmty_functor (x0, x1) ->\n Ast_413.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_412.Parsetree.Pmty_with (x0, x1) ->\n Ast_413.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_412.Parsetree.Pmty_typeof x0 ->\n Ast_413.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_412.Parsetree.Pmty_extension x0 ->\n Ast_413.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_412.Parsetree.Pmty_alias x0 ->\n Ast_413.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_412.Parsetree.with_constraint -> Ast_413.Parsetree.with_constraint =\n function\n | Ast_412.Parsetree.Pwith_type (x0, x1) ->\n Ast_413.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_412.Parsetree.Pwith_module (x0, x1) ->\n Ast_413.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_412.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_413.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_412.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_413.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_412.Parsetree.signature -> Ast_413.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_412.Parsetree.signature_item -> Ast_413.Parsetree.signature_item =\n fun { Ast_412.Parsetree.psig_desc; Ast_412.Parsetree.psig_loc } ->\n {\n Ast_413.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_413.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_412.Parsetree.signature_item_desc ->\n Ast_413.Parsetree.signature_item_desc = function\n | Ast_412.Parsetree.Psig_value x0 ->\n Ast_413.Parsetree.Psig_value (copy_value_description x0)\n | Ast_412.Parsetree.Psig_type (x0, x1) ->\n Ast_413.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_412.Parsetree.Psig_typesubst x0 ->\n Ast_413.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_412.Parsetree.Psig_typext x0 ->\n Ast_413.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_412.Parsetree.Psig_exception x0 ->\n Ast_413.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_412.Parsetree.Psig_module x0 ->\n Ast_413.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_412.Parsetree.Psig_modsubst x0 ->\n Ast_413.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_412.Parsetree.Psig_recmodule x0 ->\n Ast_413.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_412.Parsetree.Psig_modtype x0 ->\n Ast_413.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_412.Parsetree.Psig_open x0 ->\n Ast_413.Parsetree.Psig_open (copy_open_description x0)\n | Ast_412.Parsetree.Psig_include x0 ->\n Ast_413.Parsetree.Psig_include (copy_include_description x0)\n | Ast_412.Parsetree.Psig_class x0 ->\n Ast_413.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_412.Parsetree.Psig_class_type x0 ->\n Ast_413.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_412.Parsetree.Psig_attribute x0 ->\n Ast_413.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Psig_extension (x0, x1) ->\n Ast_413.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_412.Parsetree.class_type_declaration ->\n Ast_413.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_412.Parsetree.class_description -> Ast_413.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_412.Parsetree.class_type -> Ast_413.Parsetree.class_type =\n fun {\n Ast_412.Parsetree.pcty_desc;\n Ast_412.Parsetree.pcty_loc;\n Ast_412.Parsetree.pcty_attributes;\n } ->\n {\n Ast_413.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_413.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_413.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_412.Parsetree.class_type_desc -> Ast_413.Parsetree.class_type_desc =\n function\n | Ast_412.Parsetree.Pcty_constr (x0, x1) ->\n Ast_413.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Pcty_signature x0 ->\n Ast_413.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_412.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_413.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_412.Parsetree.Pcty_extension x0 ->\n Ast_413.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_412.Parsetree.Pcty_open (x0, x1) ->\n Ast_413.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_412.Parsetree.class_signature -> Ast_413.Parsetree.class_signature =\n fun { Ast_412.Parsetree.pcsig_self; Ast_412.Parsetree.pcsig_fields } ->\n {\n Ast_413.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_413.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_412.Parsetree.class_type_field -> Ast_413.Parsetree.class_type_field =\n fun {\n Ast_412.Parsetree.pctf_desc;\n Ast_412.Parsetree.pctf_loc;\n Ast_412.Parsetree.pctf_attributes;\n } ->\n {\n Ast_413.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_413.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_413.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_412.Parsetree.class_type_field_desc ->\n Ast_413.Parsetree.class_type_field_desc = function\n | Ast_412.Parsetree.Pctf_inherit x0 ->\n Ast_413.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_412.Parsetree.Pctf_val x0 ->\n Ast_413.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_412.Parsetree.Pctf_method x0 ->\n Ast_413.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_412.Parsetree.Pctf_constraint x0 ->\n Ast_413.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_412.Parsetree.Pctf_attribute x0 ->\n Ast_413.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pctf_extension x0 ->\n Ast_413.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_412.Parsetree.extension -> Ast_413.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.class_infos ->\n 'g0 Ast_413.Parsetree.class_infos =\n fun f0\n {\n Ast_412.Parsetree.pci_virt;\n Ast_412.Parsetree.pci_params;\n Ast_412.Parsetree.pci_name;\n Ast_412.Parsetree.pci_expr;\n Ast_412.Parsetree.pci_loc;\n Ast_412.Parsetree.pci_attributes;\n } ->\n {\n Ast_413.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_413.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n pci_params;\n Ast_413.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_413.Parsetree.pci_expr = f0 pci_expr;\n Ast_413.Parsetree.pci_loc = copy_location pci_loc;\n Ast_413.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_412.Asttypes.virtual_flag -> Ast_413.Asttypes.virtual_flag = function\n | Ast_412.Asttypes.Virtual -> Ast_413.Asttypes.Virtual\n | Ast_412.Asttypes.Concrete -> Ast_413.Asttypes.Concrete\n\nand copy_include_description :\n Ast_412.Parsetree.include_description ->\n Ast_413.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.include_infos ->\n 'g0 Ast_413.Parsetree.include_infos =\n fun f0\n {\n Ast_412.Parsetree.pincl_mod;\n Ast_412.Parsetree.pincl_loc;\n Ast_412.Parsetree.pincl_attributes;\n } ->\n {\n Ast_413.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_413.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_413.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_412.Parsetree.open_description -> Ast_413.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.open_infos ->\n 'g0 Ast_413.Parsetree.open_infos =\n fun f0\n {\n Ast_412.Parsetree.popen_expr;\n Ast_412.Parsetree.popen_override;\n Ast_412.Parsetree.popen_loc;\n Ast_412.Parsetree.popen_attributes;\n } ->\n {\n Ast_413.Parsetree.popen_expr = f0 popen_expr;\n Ast_413.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_413.Parsetree.popen_loc = copy_location popen_loc;\n Ast_413.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_412.Asttypes.override_flag -> Ast_413.Asttypes.override_flag = function\n | Ast_412.Asttypes.Override -> Ast_413.Asttypes.Override\n | Ast_412.Asttypes.Fresh -> Ast_413.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_412.Parsetree.module_type_declaration ->\n Ast_413.Parsetree.module_type_declaration =\n fun {\n Ast_412.Parsetree.pmtd_name;\n Ast_412.Parsetree.pmtd_type;\n Ast_412.Parsetree.pmtd_attributes;\n Ast_412.Parsetree.pmtd_loc;\n } ->\n {\n Ast_413.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_413.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_413.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_413.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_412.Parsetree.module_substitution ->\n Ast_413.Parsetree.module_substitution =\n fun {\n Ast_412.Parsetree.pms_name;\n Ast_412.Parsetree.pms_manifest;\n Ast_412.Parsetree.pms_attributes;\n Ast_412.Parsetree.pms_loc;\n } ->\n {\n Ast_413.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_413.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_413.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_413.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_412.Parsetree.module_declaration -> Ast_413.Parsetree.module_declaration\n =\n fun {\n Ast_412.Parsetree.pmd_name;\n Ast_412.Parsetree.pmd_type;\n Ast_412.Parsetree.pmd_attributes;\n Ast_412.Parsetree.pmd_loc;\n } ->\n {\n Ast_413.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_413.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_413.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_413.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_412.Parsetree.type_exception -> Ast_413.Parsetree.type_exception =\n fun {\n Ast_412.Parsetree.ptyexn_constructor;\n Ast_412.Parsetree.ptyexn_loc;\n Ast_412.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_413.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_413.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_412.Parsetree.type_extension -> Ast_413.Parsetree.type_extension =\n fun {\n Ast_412.Parsetree.ptyext_path;\n Ast_412.Parsetree.ptyext_params;\n Ast_412.Parsetree.ptyext_constructors;\n Ast_412.Parsetree.ptyext_private;\n Ast_412.Parsetree.ptyext_loc;\n Ast_412.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_413.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptyext_params;\n Ast_413.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_413.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_413.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_413.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_412.Parsetree.extension_constructor ->\n Ast_413.Parsetree.extension_constructor =\n fun {\n Ast_412.Parsetree.pext_name;\n Ast_412.Parsetree.pext_kind;\n Ast_412.Parsetree.pext_loc;\n Ast_412.Parsetree.pext_attributes;\n } ->\n {\n Ast_413.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_413.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_413.Parsetree.pext_loc = copy_location pext_loc;\n Ast_413.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_412.Parsetree.extension_constructor_kind ->\n Ast_413.Parsetree.extension_constructor_kind = function\n | Ast_412.Parsetree.Pext_decl (x0, x1) ->\n Ast_413.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_412.Parsetree.Pext_rebind x0 ->\n Ast_413.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_412.Parsetree.type_declaration -> Ast_413.Parsetree.type_declaration =\n fun {\n Ast_412.Parsetree.ptype_name;\n Ast_412.Parsetree.ptype_params;\n Ast_412.Parsetree.ptype_cstrs;\n Ast_412.Parsetree.ptype_kind;\n Ast_412.Parsetree.ptype_private;\n Ast_412.Parsetree.ptype_manifest;\n Ast_412.Parsetree.ptype_attributes;\n Ast_412.Parsetree.ptype_loc;\n } ->\n {\n Ast_413.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_413.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptype_params;\n Ast_413.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_413.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_413.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_413.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_413.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_413.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_412.Asttypes.private_flag -> Ast_413.Asttypes.private_flag = function\n | Ast_412.Asttypes.Private -> Ast_413.Asttypes.Private\n | Ast_412.Asttypes.Public -> Ast_413.Asttypes.Public\n\nand copy_type_kind : Ast_412.Parsetree.type_kind -> Ast_413.Parsetree.type_kind\n = function\n | Ast_412.Parsetree.Ptype_abstract -> Ast_413.Parsetree.Ptype_abstract\n | Ast_412.Parsetree.Ptype_variant x0 ->\n Ast_413.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_412.Parsetree.Ptype_record x0 ->\n Ast_413.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_412.Parsetree.Ptype_open -> Ast_413.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_412.Parsetree.constructor_declaration ->\n Ast_413.Parsetree.constructor_declaration =\n fun {\n Ast_412.Parsetree.pcd_name;\n Ast_412.Parsetree.pcd_args;\n Ast_412.Parsetree.pcd_res;\n Ast_412.Parsetree.pcd_loc;\n Ast_412.Parsetree.pcd_attributes;\n } ->\n {\n Ast_413.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_413.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_413.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_413.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_413.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_412.Parsetree.constructor_arguments ->\n Ast_413.Parsetree.constructor_arguments = function\n | Ast_412.Parsetree.Pcstr_tuple x0 ->\n Ast_413.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_412.Parsetree.Pcstr_record x0 ->\n Ast_413.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_412.Parsetree.label_declaration -> Ast_413.Parsetree.label_declaration =\n fun {\n Ast_412.Parsetree.pld_name;\n Ast_412.Parsetree.pld_mutable;\n Ast_412.Parsetree.pld_type;\n Ast_412.Parsetree.pld_loc;\n Ast_412.Parsetree.pld_attributes;\n } ->\n {\n Ast_413.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_413.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_413.Parsetree.pld_type = copy_core_type pld_type;\n Ast_413.Parsetree.pld_loc = copy_location pld_loc;\n Ast_413.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_412.Asttypes.mutable_flag -> Ast_413.Asttypes.mutable_flag = function\n | Ast_412.Asttypes.Immutable -> Ast_413.Asttypes.Immutable\n | Ast_412.Asttypes.Mutable -> Ast_413.Asttypes.Mutable\n\nand copy_injectivity :\n Ast_412.Asttypes.injectivity -> Ast_413.Asttypes.injectivity = function\n | Ast_412.Asttypes.Injective -> Ast_413.Asttypes.Injective\n | Ast_412.Asttypes.NoInjectivity -> Ast_413.Asttypes.NoInjectivity\n\nand copy_variance : Ast_412.Asttypes.variance -> Ast_413.Asttypes.variance =\n function\n | Ast_412.Asttypes.Covariant -> Ast_413.Asttypes.Covariant\n | Ast_412.Asttypes.Contravariant -> Ast_413.Asttypes.Contravariant\n | Ast_412.Asttypes.NoVariance -> Ast_413.Asttypes.NoVariance\n\nand copy_value_description :\n Ast_412.Parsetree.value_description -> Ast_413.Parsetree.value_description =\n fun {\n Ast_412.Parsetree.pval_name;\n Ast_412.Parsetree.pval_type;\n Ast_412.Parsetree.pval_prim;\n Ast_412.Parsetree.pval_attributes;\n Ast_412.Parsetree.pval_loc;\n } ->\n {\n Ast_413.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_413.Parsetree.pval_type = copy_core_type pval_type;\n Ast_413.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_413.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_413.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_412.Parsetree.object_field_desc -> Ast_413.Parsetree.object_field_desc =\n function\n | Ast_412.Parsetree.Otag (x0, x1) ->\n Ast_413.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_412.Parsetree.Oinherit x0 ->\n Ast_413.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_412.Asttypes.arg_label -> Ast_413.Asttypes.arg_label =\n function\n | Ast_412.Asttypes.Nolabel -> Ast_413.Asttypes.Nolabel\n | Ast_412.Asttypes.Labelled x0 -> Ast_413.Asttypes.Labelled x0\n | Ast_412.Asttypes.Optional x0 -> Ast_413.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_412.Asttypes.closed_flag -> Ast_413.Asttypes.closed_flag = function\n | Ast_412.Asttypes.Closed -> Ast_413.Asttypes.Closed\n | Ast_412.Asttypes.Open -> Ast_413.Asttypes.Open\n\nand copy_label : Ast_412.Asttypes.label -> Ast_413.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_412.Asttypes.rec_flag -> Ast_413.Asttypes.rec_flag =\n function\n | Ast_412.Asttypes.Nonrecursive -> Ast_413.Asttypes.Nonrecursive\n | Ast_412.Asttypes.Recursive -> Ast_413.Asttypes.Recursive\n\nand copy_constant : Ast_412.Parsetree.constant -> Ast_413.Parsetree.constant =\n function\n | Ast_412.Parsetree.Pconst_integer (x0, x1) ->\n Ast_413.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_412.Parsetree.Pconst_char x0 -> Ast_413.Parsetree.Pconst_char x0\n | Ast_412.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_413.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_412.Parsetree.Pconst_float (x0, x1) ->\n Ast_413.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_412.Asttypes.loc -> 'g0 Ast_413.Asttypes.loc =\n fun f0 { Ast_412.Asttypes.txt; Ast_412.Asttypes.loc } ->\n { Ast_413.Asttypes.txt = f0 txt; Ast_413.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_412\nmodule To = Ast_411\n\nlet rec copy_toplevel_phrase :\n Ast_412.Parsetree.toplevel_phrase -> Ast_411.Parsetree.toplevel_phrase =\n function\n | Ast_412.Parsetree.Ptop_def x0 ->\n Ast_411.Parsetree.Ptop_def (copy_structure x0)\n | Ast_412.Parsetree.Ptop_dir x0 ->\n Ast_411.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_412.Parsetree.toplevel_directive -> Ast_411.Parsetree.toplevel_directive\n =\n fun {\n Ast_412.Parsetree.pdir_name;\n Ast_412.Parsetree.pdir_arg;\n Ast_412.Parsetree.pdir_loc;\n } ->\n {\n Ast_411.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_411.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_411.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_412.Parsetree.directive_argument -> Ast_411.Parsetree.directive_argument\n =\n fun { Ast_412.Parsetree.pdira_desc; Ast_412.Parsetree.pdira_loc } ->\n {\n Ast_411.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_411.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_412.Parsetree.directive_argument_desc ->\n Ast_411.Parsetree.directive_argument_desc = function\n | Ast_412.Parsetree.Pdir_string x0 -> Ast_411.Parsetree.Pdir_string x0\n | Ast_412.Parsetree.Pdir_int (x0, x1) ->\n Ast_411.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_412.Parsetree.Pdir_ident x0 ->\n Ast_411.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_412.Parsetree.Pdir_bool x0 -> Ast_411.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_412.Parsetree.expression -> Ast_411.Parsetree.expression =\n fun {\n Ast_412.Parsetree.pexp_desc;\n Ast_412.Parsetree.pexp_loc;\n Ast_412.Parsetree.pexp_loc_stack;\n Ast_412.Parsetree.pexp_attributes;\n } ->\n {\n Ast_411.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_411.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_411.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_411.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_412.Parsetree.expression_desc -> Ast_411.Parsetree.expression_desc =\n function\n | Ast_412.Parsetree.Pexp_ident x0 ->\n Ast_411.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pexp_constant x0 ->\n Ast_411.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_412.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_412.Parsetree.Pexp_function x0 ->\n Ast_411.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_412.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_411.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_412.Parsetree.Pexp_apply (x0, x1) ->\n Ast_411.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_412.Parsetree.Pexp_match (x0, x1) ->\n Ast_411.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_412.Parsetree.Pexp_try (x0, x1) ->\n Ast_411.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_412.Parsetree.Pexp_tuple x0 ->\n Ast_411.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_412.Parsetree.Pexp_construct (x0, x1) ->\n Ast_411.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_412.Parsetree.Pexp_variant (x0, x1) ->\n Ast_411.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_412.Parsetree.Pexp_record (x0, x1) ->\n Ast_411.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_412.Parsetree.Pexp_field (x0, x1) ->\n Ast_411.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_412.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_412.Parsetree.Pexp_array x0 ->\n Ast_411.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_412.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_412.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_411.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_while (x0, x1) ->\n Ast_411.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_411.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_412.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_411.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_412.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_412.Parsetree.Pexp_send (x0, x1) ->\n Ast_411.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_412.Parsetree.Pexp_new x0 ->\n Ast_411.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_411.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_override x0 ->\n Ast_411.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_412.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_412.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_411.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_assert x0 ->\n Ast_411.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_412.Parsetree.Pexp_lazy x0 ->\n Ast_411.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_412.Parsetree.Pexp_poly (x0, x1) ->\n Ast_411.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_412.Parsetree.Pexp_object x0 ->\n Ast_411.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_412.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_411.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_pack x0 ->\n Ast_411.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_412.Parsetree.Pexp_open (x0, x1) ->\n Ast_411.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_letop x0 ->\n Ast_411.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_412.Parsetree.Pexp_extension x0 ->\n Ast_411.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_412.Parsetree.Pexp_unreachable -> Ast_411.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_412.Parsetree.letop -> Ast_411.Parsetree.letop =\n fun { Ast_412.Parsetree.let_; Ast_412.Parsetree.ands; Ast_412.Parsetree.body } ->\n {\n Ast_411.Parsetree.let_ = copy_binding_op let_;\n Ast_411.Parsetree.ands = List.map copy_binding_op ands;\n Ast_411.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_412.Parsetree.binding_op -> Ast_411.Parsetree.binding_op =\n fun {\n Ast_412.Parsetree.pbop_op;\n Ast_412.Parsetree.pbop_pat;\n Ast_412.Parsetree.pbop_exp;\n Ast_412.Parsetree.pbop_loc;\n } ->\n {\n Ast_411.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_411.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_411.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_411.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_412.Asttypes.direction_flag -> Ast_411.Asttypes.direction_flag =\n function\n | Ast_412.Asttypes.Upto -> Ast_411.Asttypes.Upto\n | Ast_412.Asttypes.Downto -> Ast_411.Asttypes.Downto\n\nand copy_case : Ast_412.Parsetree.case -> Ast_411.Parsetree.case =\n fun {\n Ast_412.Parsetree.pc_lhs;\n Ast_412.Parsetree.pc_guard;\n Ast_412.Parsetree.pc_rhs;\n } ->\n {\n Ast_411.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_411.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_411.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_412.Parsetree.value_binding -> Ast_411.Parsetree.value_binding =\n fun {\n Ast_412.Parsetree.pvb_pat;\n Ast_412.Parsetree.pvb_expr;\n Ast_412.Parsetree.pvb_attributes;\n Ast_412.Parsetree.pvb_loc;\n } ->\n {\n Ast_411.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_411.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_411.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_411.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_412.Parsetree.pattern -> Ast_411.Parsetree.pattern =\n fun {\n Ast_412.Parsetree.ppat_desc;\n Ast_412.Parsetree.ppat_loc;\n Ast_412.Parsetree.ppat_loc_stack;\n Ast_412.Parsetree.ppat_attributes;\n } ->\n {\n Ast_411.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_411.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_411.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_411.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_412.Parsetree.pattern_desc -> Ast_411.Parsetree.pattern_desc = function\n | Ast_412.Parsetree.Ppat_any -> Ast_411.Parsetree.Ppat_any\n | Ast_412.Parsetree.Ppat_var x0 ->\n Ast_411.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_412.Parsetree.Ppat_alias (x0, x1) ->\n Ast_411.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_412.Parsetree.Ppat_constant x0 ->\n Ast_411.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_412.Parsetree.Ppat_interval (x0, x1) ->\n Ast_411.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_412.Parsetree.Ppat_tuple x0 ->\n Ast_411.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_412.Parsetree.Ppat_construct (x0, x1) ->\n Ast_411.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_412.Parsetree.Ppat_variant (x0, x1) ->\n Ast_411.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_412.Parsetree.Ppat_record (x0, x1) ->\n Ast_411.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_412.Parsetree.Ppat_array x0 ->\n Ast_411.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_412.Parsetree.Ppat_or (x0, x1) ->\n Ast_411.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_412.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_411.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_412.Parsetree.Ppat_type x0 ->\n Ast_411.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Ppat_lazy x0 ->\n Ast_411.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_412.Parsetree.Ppat_unpack x0 ->\n Ast_411.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_412.Parsetree.Ppat_exception x0 ->\n Ast_411.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_412.Parsetree.Ppat_extension x0 ->\n Ast_411.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_412.Parsetree.Ppat_open (x0, x1) ->\n Ast_411.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_412.Parsetree.core_type -> Ast_411.Parsetree.core_type\n =\n fun {\n Ast_412.Parsetree.ptyp_desc;\n Ast_412.Parsetree.ptyp_loc;\n Ast_412.Parsetree.ptyp_loc_stack;\n Ast_412.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_411.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_411.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_411.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_412.Parsetree.location_stack -> Ast_411.Parsetree.location_stack =\n fun x -> x\n\nand copy_core_type_desc :\n Ast_412.Parsetree.core_type_desc -> Ast_411.Parsetree.core_type_desc =\n function\n | Ast_412.Parsetree.Ptyp_any -> Ast_411.Parsetree.Ptyp_any\n | Ast_412.Parsetree.Ptyp_var x0 -> Ast_411.Parsetree.Ptyp_var x0\n | Ast_412.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_411.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_412.Parsetree.Ptyp_tuple x0 ->\n Ast_411.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_412.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_411.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_object (x0, x1) ->\n Ast_411.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_412.Parsetree.Ptyp_class (x0, x1) ->\n Ast_411.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_411.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_412.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_411.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_412.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_411.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_package x0 ->\n Ast_411.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_412.Parsetree.Ptyp_extension x0 ->\n Ast_411.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_412.Parsetree.package_type -> Ast_411.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_412.Parsetree.row_field -> Ast_411.Parsetree.row_field\n =\n fun {\n Ast_412.Parsetree.prf_desc;\n Ast_412.Parsetree.prf_loc;\n Ast_412.Parsetree.prf_attributes;\n } ->\n {\n Ast_411.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_411.Parsetree.prf_loc = copy_location prf_loc;\n Ast_411.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_412.Parsetree.row_field_desc -> Ast_411.Parsetree.row_field_desc =\n function\n | Ast_412.Parsetree.Rtag (x0, x1, x2) ->\n Ast_411.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_412.Parsetree.Rinherit x0 ->\n Ast_411.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_412.Parsetree.object_field -> Ast_411.Parsetree.object_field =\n fun {\n Ast_412.Parsetree.pof_desc;\n Ast_412.Parsetree.pof_loc;\n Ast_412.Parsetree.pof_attributes;\n } ->\n {\n Ast_411.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_411.Parsetree.pof_loc = copy_location pof_loc;\n Ast_411.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_412.Parsetree.attributes -> Ast_411.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_412.Parsetree.attribute -> Ast_411.Parsetree.attribute\n =\n fun {\n Ast_412.Parsetree.attr_name;\n Ast_412.Parsetree.attr_payload;\n Ast_412.Parsetree.attr_loc;\n } ->\n {\n Ast_411.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_411.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_411.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_412.Parsetree.payload -> Ast_411.Parsetree.payload =\n function\n | Ast_412.Parsetree.PStr x0 -> Ast_411.Parsetree.PStr (copy_structure x0)\n | Ast_412.Parsetree.PSig x0 -> Ast_411.Parsetree.PSig (copy_signature x0)\n | Ast_412.Parsetree.PTyp x0 -> Ast_411.Parsetree.PTyp (copy_core_type x0)\n | Ast_412.Parsetree.PPat (x0, x1) ->\n Ast_411.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_412.Parsetree.structure -> Ast_411.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_412.Parsetree.structure_item -> Ast_411.Parsetree.structure_item =\n fun { Ast_412.Parsetree.pstr_desc; Ast_412.Parsetree.pstr_loc } ->\n {\n Ast_411.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_411.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_412.Parsetree.structure_item_desc ->\n Ast_411.Parsetree.structure_item_desc = function\n | Ast_412.Parsetree.Pstr_eval (x0, x1) ->\n Ast_411.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_412.Parsetree.Pstr_value (x0, x1) ->\n Ast_411.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_412.Parsetree.Pstr_primitive x0 ->\n Ast_411.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_412.Parsetree.Pstr_type (x0, x1) ->\n Ast_411.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_412.Parsetree.Pstr_typext x0 ->\n Ast_411.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_412.Parsetree.Pstr_exception x0 ->\n Ast_411.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_412.Parsetree.Pstr_module x0 ->\n Ast_411.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_412.Parsetree.Pstr_recmodule x0 ->\n Ast_411.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_412.Parsetree.Pstr_modtype x0 ->\n Ast_411.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_412.Parsetree.Pstr_open x0 ->\n Ast_411.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_412.Parsetree.Pstr_class x0 ->\n Ast_411.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_412.Parsetree.Pstr_class_type x0 ->\n Ast_411.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_412.Parsetree.Pstr_include x0 ->\n Ast_411.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_412.Parsetree.Pstr_attribute x0 ->\n Ast_411.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pstr_extension (x0, x1) ->\n Ast_411.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_412.Parsetree.include_declaration ->\n Ast_411.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_412.Parsetree.class_declaration -> Ast_411.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_412.Parsetree.class_expr -> Ast_411.Parsetree.class_expr =\n fun {\n Ast_412.Parsetree.pcl_desc;\n Ast_412.Parsetree.pcl_loc;\n Ast_412.Parsetree.pcl_attributes;\n } ->\n {\n Ast_411.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_411.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_411.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_412.Parsetree.class_expr_desc -> Ast_411.Parsetree.class_expr_desc =\n function\n | Ast_412.Parsetree.Pcl_constr (x0, x1) ->\n Ast_411.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Pcl_structure x0 ->\n Ast_411.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_412.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_411.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_412.Parsetree.Pcl_apply (x0, x1) ->\n Ast_411.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_412.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_411.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_412.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_411.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_412.Parsetree.Pcl_extension x0 ->\n Ast_411.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_412.Parsetree.Pcl_open (x0, x1) ->\n Ast_411.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_412.Parsetree.class_structure -> Ast_411.Parsetree.class_structure =\n fun { Ast_412.Parsetree.pcstr_self; Ast_412.Parsetree.pcstr_fields } ->\n {\n Ast_411.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_411.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_412.Parsetree.class_field -> Ast_411.Parsetree.class_field =\n fun {\n Ast_412.Parsetree.pcf_desc;\n Ast_412.Parsetree.pcf_loc;\n Ast_412.Parsetree.pcf_attributes;\n } ->\n {\n Ast_411.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_411.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_411.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_412.Parsetree.class_field_desc -> Ast_411.Parsetree.class_field_desc =\n function\n | Ast_412.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_411.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_412.Parsetree.Pcf_val x0 ->\n Ast_411.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_412.Parsetree.Pcf_method x0 ->\n Ast_411.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_412.Parsetree.Pcf_constraint x0 ->\n Ast_411.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_412.Parsetree.Pcf_initializer x0 ->\n Ast_411.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_412.Parsetree.Pcf_attribute x0 ->\n Ast_411.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pcf_extension x0 ->\n Ast_411.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_412.Parsetree.class_field_kind -> Ast_411.Parsetree.class_field_kind =\n function\n | Ast_412.Parsetree.Cfk_virtual x0 ->\n Ast_411.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_412.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_411.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_412.Parsetree.open_declaration -> Ast_411.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_412.Parsetree.module_binding -> Ast_411.Parsetree.module_binding =\n fun {\n Ast_412.Parsetree.pmb_name;\n Ast_412.Parsetree.pmb_expr;\n Ast_412.Parsetree.pmb_attributes;\n Ast_412.Parsetree.pmb_loc;\n } ->\n {\n Ast_411.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_411.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_411.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_411.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_412.Parsetree.module_expr -> Ast_411.Parsetree.module_expr =\n fun {\n Ast_412.Parsetree.pmod_desc;\n Ast_412.Parsetree.pmod_loc;\n Ast_412.Parsetree.pmod_attributes;\n } ->\n {\n Ast_411.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_411.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_411.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_412.Parsetree.module_expr_desc -> Ast_411.Parsetree.module_expr_desc =\n function\n | Ast_412.Parsetree.Pmod_ident x0 ->\n Ast_411.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pmod_structure x0 ->\n Ast_411.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_412.Parsetree.Pmod_functor (x0, x1) ->\n Ast_411.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_412.Parsetree.Pmod_apply (x0, x1) ->\n Ast_411.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_412.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_411.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_412.Parsetree.Pmod_unpack x0 ->\n Ast_411.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_412.Parsetree.Pmod_extension x0 ->\n Ast_411.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_412.Parsetree.functor_parameter -> Ast_411.Parsetree.functor_parameter =\n function\n | Ast_412.Parsetree.Unit -> Ast_411.Parsetree.Unit\n | Ast_412.Parsetree.Named (x0, x1) ->\n Ast_411.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_412.Parsetree.module_type -> Ast_411.Parsetree.module_type =\n fun {\n Ast_412.Parsetree.pmty_desc;\n Ast_412.Parsetree.pmty_loc;\n Ast_412.Parsetree.pmty_attributes;\n } ->\n {\n Ast_411.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_411.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_411.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_412.Parsetree.module_type_desc -> Ast_411.Parsetree.module_type_desc =\n function\n | Ast_412.Parsetree.Pmty_ident x0 ->\n Ast_411.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pmty_signature x0 ->\n Ast_411.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_412.Parsetree.Pmty_functor (x0, x1) ->\n Ast_411.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_412.Parsetree.Pmty_with (x0, x1) ->\n Ast_411.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_412.Parsetree.Pmty_typeof x0 ->\n Ast_411.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_412.Parsetree.Pmty_extension x0 ->\n Ast_411.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_412.Parsetree.Pmty_alias x0 ->\n Ast_411.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_412.Parsetree.with_constraint -> Ast_411.Parsetree.with_constraint =\n function\n | Ast_412.Parsetree.Pwith_type (x0, x1) ->\n Ast_411.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_412.Parsetree.Pwith_module (x0, x1) ->\n Ast_411.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_412.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_411.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_412.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_411.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_412.Parsetree.signature -> Ast_411.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_412.Parsetree.signature_item -> Ast_411.Parsetree.signature_item =\n fun { Ast_412.Parsetree.psig_desc; Ast_412.Parsetree.psig_loc } ->\n {\n Ast_411.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_411.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_412.Parsetree.signature_item_desc ->\n Ast_411.Parsetree.signature_item_desc = function\n | Ast_412.Parsetree.Psig_value x0 ->\n Ast_411.Parsetree.Psig_value (copy_value_description x0)\n | Ast_412.Parsetree.Psig_type (x0, x1) ->\n Ast_411.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_412.Parsetree.Psig_typesubst x0 ->\n Ast_411.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_412.Parsetree.Psig_typext x0 ->\n Ast_411.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_412.Parsetree.Psig_exception x0 ->\n Ast_411.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_412.Parsetree.Psig_module x0 ->\n Ast_411.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_412.Parsetree.Psig_modsubst x0 ->\n Ast_411.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_412.Parsetree.Psig_recmodule x0 ->\n Ast_411.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_412.Parsetree.Psig_modtype x0 ->\n Ast_411.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_412.Parsetree.Psig_open x0 ->\n Ast_411.Parsetree.Psig_open (copy_open_description x0)\n | Ast_412.Parsetree.Psig_include x0 ->\n Ast_411.Parsetree.Psig_include (copy_include_description x0)\n | Ast_412.Parsetree.Psig_class x0 ->\n Ast_411.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_412.Parsetree.Psig_class_type x0 ->\n Ast_411.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_412.Parsetree.Psig_attribute x0 ->\n Ast_411.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Psig_extension (x0, x1) ->\n Ast_411.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_412.Parsetree.class_type_declaration ->\n Ast_411.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_412.Parsetree.class_description -> Ast_411.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_412.Parsetree.class_type -> Ast_411.Parsetree.class_type =\n fun {\n Ast_412.Parsetree.pcty_desc;\n Ast_412.Parsetree.pcty_loc;\n Ast_412.Parsetree.pcty_attributes;\n } ->\n {\n Ast_411.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_411.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_411.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_412.Parsetree.class_type_desc -> Ast_411.Parsetree.class_type_desc =\n function\n | Ast_412.Parsetree.Pcty_constr (x0, x1) ->\n Ast_411.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Pcty_signature x0 ->\n Ast_411.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_412.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_411.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_412.Parsetree.Pcty_extension x0 ->\n Ast_411.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_412.Parsetree.Pcty_open (x0, x1) ->\n Ast_411.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_412.Parsetree.class_signature -> Ast_411.Parsetree.class_signature =\n fun { Ast_412.Parsetree.pcsig_self; Ast_412.Parsetree.pcsig_fields } ->\n {\n Ast_411.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_411.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_412.Parsetree.class_type_field -> Ast_411.Parsetree.class_type_field =\n fun {\n Ast_412.Parsetree.pctf_desc;\n Ast_412.Parsetree.pctf_loc;\n Ast_412.Parsetree.pctf_attributes;\n } ->\n {\n Ast_411.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_411.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_411.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_412.Parsetree.class_type_field_desc ->\n Ast_411.Parsetree.class_type_field_desc = function\n | Ast_412.Parsetree.Pctf_inherit x0 ->\n Ast_411.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_412.Parsetree.Pctf_val x0 ->\n Ast_411.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_412.Parsetree.Pctf_method x0 ->\n Ast_411.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_412.Parsetree.Pctf_constraint x0 ->\n Ast_411.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_412.Parsetree.Pctf_attribute x0 ->\n Ast_411.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pctf_extension x0 ->\n Ast_411.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_412.Parsetree.extension -> Ast_411.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.class_infos ->\n 'g0 Ast_411.Parsetree.class_infos =\n fun f0\n {\n Ast_412.Parsetree.pci_virt;\n Ast_412.Parsetree.pci_params;\n Ast_412.Parsetree.pci_name;\n Ast_412.Parsetree.pci_expr;\n Ast_412.Parsetree.pci_loc;\n Ast_412.Parsetree.pci_attributes;\n } ->\n {\n Ast_411.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_411.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, _ = x1 in\n copy_variance x0 ))\n pci_params;\n Ast_411.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_411.Parsetree.pci_expr = f0 pci_expr;\n Ast_411.Parsetree.pci_loc = copy_location pci_loc;\n Ast_411.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_412.Asttypes.virtual_flag -> Ast_411.Asttypes.virtual_flag = function\n | Ast_412.Asttypes.Virtual -> Ast_411.Asttypes.Virtual\n | Ast_412.Asttypes.Concrete -> Ast_411.Asttypes.Concrete\n\nand copy_include_description :\n Ast_412.Parsetree.include_description ->\n Ast_411.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.include_infos ->\n 'g0 Ast_411.Parsetree.include_infos =\n fun f0\n {\n Ast_412.Parsetree.pincl_mod;\n Ast_412.Parsetree.pincl_loc;\n Ast_412.Parsetree.pincl_attributes;\n } ->\n {\n Ast_411.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_411.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_411.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_412.Parsetree.open_description -> Ast_411.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.open_infos ->\n 'g0 Ast_411.Parsetree.open_infos =\n fun f0\n {\n Ast_412.Parsetree.popen_expr;\n Ast_412.Parsetree.popen_override;\n Ast_412.Parsetree.popen_loc;\n Ast_412.Parsetree.popen_attributes;\n } ->\n {\n Ast_411.Parsetree.popen_expr = f0 popen_expr;\n Ast_411.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_411.Parsetree.popen_loc = copy_location popen_loc;\n Ast_411.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_412.Asttypes.override_flag -> Ast_411.Asttypes.override_flag = function\n | Ast_412.Asttypes.Override -> Ast_411.Asttypes.Override\n | Ast_412.Asttypes.Fresh -> Ast_411.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_412.Parsetree.module_type_declaration ->\n Ast_411.Parsetree.module_type_declaration =\n fun {\n Ast_412.Parsetree.pmtd_name;\n Ast_412.Parsetree.pmtd_type;\n Ast_412.Parsetree.pmtd_attributes;\n Ast_412.Parsetree.pmtd_loc;\n } ->\n {\n Ast_411.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_411.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_411.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_411.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_412.Parsetree.module_substitution ->\n Ast_411.Parsetree.module_substitution =\n fun {\n Ast_412.Parsetree.pms_name;\n Ast_412.Parsetree.pms_manifest;\n Ast_412.Parsetree.pms_attributes;\n Ast_412.Parsetree.pms_loc;\n } ->\n {\n Ast_411.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_411.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_411.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_411.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_412.Parsetree.module_declaration -> Ast_411.Parsetree.module_declaration\n =\n fun {\n Ast_412.Parsetree.pmd_name;\n Ast_412.Parsetree.pmd_type;\n Ast_412.Parsetree.pmd_attributes;\n Ast_412.Parsetree.pmd_loc;\n } ->\n {\n Ast_411.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_411.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_411.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_411.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_412.Parsetree.type_exception -> Ast_411.Parsetree.type_exception =\n fun {\n Ast_412.Parsetree.ptyexn_constructor;\n Ast_412.Parsetree.ptyexn_loc;\n Ast_412.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_411.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_411.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_412.Parsetree.type_extension -> Ast_411.Parsetree.type_extension =\n fun {\n Ast_412.Parsetree.ptyext_path;\n Ast_412.Parsetree.ptyext_params;\n Ast_412.Parsetree.ptyext_constructors;\n Ast_412.Parsetree.ptyext_private;\n Ast_412.Parsetree.ptyext_loc;\n Ast_412.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_411.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, _ = x1 in\n copy_variance x0 ))\n ptyext_params;\n Ast_411.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_411.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_411.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_411.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_412.Parsetree.extension_constructor ->\n Ast_411.Parsetree.extension_constructor =\n fun {\n Ast_412.Parsetree.pext_name;\n Ast_412.Parsetree.pext_kind;\n Ast_412.Parsetree.pext_loc;\n Ast_412.Parsetree.pext_attributes;\n } ->\n {\n Ast_411.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_411.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_411.Parsetree.pext_loc = copy_location pext_loc;\n Ast_411.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_412.Parsetree.extension_constructor_kind ->\n Ast_411.Parsetree.extension_constructor_kind = function\n | Ast_412.Parsetree.Pext_decl (x0, x1) ->\n Ast_411.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_412.Parsetree.Pext_rebind x0 ->\n Ast_411.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_412.Parsetree.type_declaration -> Ast_411.Parsetree.type_declaration =\n fun {\n Ast_412.Parsetree.ptype_name;\n Ast_412.Parsetree.ptype_params;\n Ast_412.Parsetree.ptype_cstrs;\n Ast_412.Parsetree.ptype_kind;\n Ast_412.Parsetree.ptype_private;\n Ast_412.Parsetree.ptype_manifest;\n Ast_412.Parsetree.ptype_attributes;\n Ast_412.Parsetree.ptype_loc;\n } ->\n {\n Ast_411.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_411.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, _ = x1 in\n copy_variance x0 ))\n ptype_params;\n Ast_411.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_411.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_411.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_411.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_411.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_411.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_412.Asttypes.private_flag -> Ast_411.Asttypes.private_flag = function\n | Ast_412.Asttypes.Private -> Ast_411.Asttypes.Private\n | Ast_412.Asttypes.Public -> Ast_411.Asttypes.Public\n\nand copy_type_kind : Ast_412.Parsetree.type_kind -> Ast_411.Parsetree.type_kind\n = function\n | Ast_412.Parsetree.Ptype_abstract -> Ast_411.Parsetree.Ptype_abstract\n | Ast_412.Parsetree.Ptype_variant x0 ->\n Ast_411.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_412.Parsetree.Ptype_record x0 ->\n Ast_411.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_412.Parsetree.Ptype_open -> Ast_411.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_412.Parsetree.constructor_declaration ->\n Ast_411.Parsetree.constructor_declaration =\n fun {\n Ast_412.Parsetree.pcd_name;\n Ast_412.Parsetree.pcd_args;\n Ast_412.Parsetree.pcd_res;\n Ast_412.Parsetree.pcd_loc;\n Ast_412.Parsetree.pcd_attributes;\n } ->\n {\n Ast_411.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_411.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_411.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_411.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_411.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_412.Parsetree.constructor_arguments ->\n Ast_411.Parsetree.constructor_arguments = function\n | Ast_412.Parsetree.Pcstr_tuple x0 ->\n Ast_411.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_412.Parsetree.Pcstr_record x0 ->\n Ast_411.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_412.Parsetree.label_declaration -> Ast_411.Parsetree.label_declaration =\n fun {\n Ast_412.Parsetree.pld_name;\n Ast_412.Parsetree.pld_mutable;\n Ast_412.Parsetree.pld_type;\n Ast_412.Parsetree.pld_loc;\n Ast_412.Parsetree.pld_attributes;\n } ->\n {\n Ast_411.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_411.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_411.Parsetree.pld_type = copy_core_type pld_type;\n Ast_411.Parsetree.pld_loc = copy_location pld_loc;\n Ast_411.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_412.Asttypes.mutable_flag -> Ast_411.Asttypes.mutable_flag = function\n | Ast_412.Asttypes.Immutable -> Ast_411.Asttypes.Immutable\n | Ast_412.Asttypes.Mutable -> Ast_411.Asttypes.Mutable\n\nand copy_variance : Ast_412.Asttypes.variance -> Ast_411.Asttypes.variance =\n function\n | Ast_412.Asttypes.Covariant -> Ast_411.Asttypes.Covariant\n | Ast_412.Asttypes.Contravariant -> Ast_411.Asttypes.Contravariant\n | Ast_412.Asttypes.NoVariance -> Ast_411.Asttypes.Invariant\n\nand copy_value_description :\n Ast_412.Parsetree.value_description -> Ast_411.Parsetree.value_description =\n fun {\n Ast_412.Parsetree.pval_name;\n Ast_412.Parsetree.pval_type;\n Ast_412.Parsetree.pval_prim;\n Ast_412.Parsetree.pval_attributes;\n Ast_412.Parsetree.pval_loc;\n } ->\n {\n Ast_411.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_411.Parsetree.pval_type = copy_core_type pval_type;\n Ast_411.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_411.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_411.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_412.Parsetree.object_field_desc -> Ast_411.Parsetree.object_field_desc =\n function\n | Ast_412.Parsetree.Otag (x0, x1) ->\n Ast_411.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_412.Parsetree.Oinherit x0 ->\n Ast_411.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_412.Asttypes.arg_label -> Ast_411.Asttypes.arg_label =\n function\n | Ast_412.Asttypes.Nolabel -> Ast_411.Asttypes.Nolabel\n | Ast_412.Asttypes.Labelled x0 -> Ast_411.Asttypes.Labelled x0\n | Ast_412.Asttypes.Optional x0 -> Ast_411.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_412.Asttypes.closed_flag -> Ast_411.Asttypes.closed_flag = function\n | Ast_412.Asttypes.Closed -> Ast_411.Asttypes.Closed\n | Ast_412.Asttypes.Open -> Ast_411.Asttypes.Open\n\nand copy_label : Ast_412.Asttypes.label -> Ast_411.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_412.Asttypes.rec_flag -> Ast_411.Asttypes.rec_flag =\n function\n | Ast_412.Asttypes.Nonrecursive -> Ast_411.Asttypes.Nonrecursive\n | Ast_412.Asttypes.Recursive -> Ast_411.Asttypes.Recursive\n\nand copy_constant : Ast_412.Parsetree.constant -> Ast_411.Parsetree.constant =\n function\n | Ast_412.Parsetree.Pconst_integer (x0, x1) ->\n Ast_411.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_412.Parsetree.Pconst_char x0 -> Ast_411.Parsetree.Pconst_char x0\n | Ast_412.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_411.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_412.Parsetree.Pconst_float (x0, x1) ->\n Ast_411.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_412.Asttypes.loc -> 'g0 Ast_411.Asttypes.loc =\n fun f0 { Ast_412.Asttypes.txt; Ast_412.Asttypes.loc } ->\n { Ast_411.Asttypes.txt = f0 txt; Ast_411.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_411\nmodule To = Ast_412\n\nlet rec copy_toplevel_phrase :\n Ast_411.Parsetree.toplevel_phrase -> Ast_412.Parsetree.toplevel_phrase =\n function\n | Ast_411.Parsetree.Ptop_def x0 ->\n Ast_412.Parsetree.Ptop_def (copy_structure x0)\n | Ast_411.Parsetree.Ptop_dir x0 ->\n Ast_412.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_411.Parsetree.toplevel_directive -> Ast_412.Parsetree.toplevel_directive\n =\n fun {\n Ast_411.Parsetree.pdir_name;\n Ast_411.Parsetree.pdir_arg;\n Ast_411.Parsetree.pdir_loc;\n } ->\n {\n Ast_412.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_412.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_412.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_411.Parsetree.directive_argument -> Ast_412.Parsetree.directive_argument\n =\n fun { Ast_411.Parsetree.pdira_desc; Ast_411.Parsetree.pdira_loc } ->\n {\n Ast_412.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_412.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_411.Parsetree.directive_argument_desc ->\n Ast_412.Parsetree.directive_argument_desc = function\n | Ast_411.Parsetree.Pdir_string x0 -> Ast_412.Parsetree.Pdir_string x0\n | Ast_411.Parsetree.Pdir_int (x0, x1) ->\n Ast_412.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_411.Parsetree.Pdir_ident x0 ->\n Ast_412.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_411.Parsetree.Pdir_bool x0 -> Ast_412.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_411.Parsetree.expression -> Ast_412.Parsetree.expression =\n fun {\n Ast_411.Parsetree.pexp_desc;\n Ast_411.Parsetree.pexp_loc;\n Ast_411.Parsetree.pexp_loc_stack;\n Ast_411.Parsetree.pexp_attributes;\n } ->\n {\n Ast_412.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_412.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_412.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_412.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_411.Parsetree.expression_desc -> Ast_412.Parsetree.expression_desc =\n function\n | Ast_411.Parsetree.Pexp_ident x0 ->\n Ast_412.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pexp_constant x0 ->\n Ast_412.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_411.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_411.Parsetree.Pexp_function x0 ->\n Ast_412.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_411.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_412.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_411.Parsetree.Pexp_apply (x0, x1) ->\n Ast_412.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_411.Parsetree.Pexp_match (x0, x1) ->\n Ast_412.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_411.Parsetree.Pexp_try (x0, x1) ->\n Ast_412.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_411.Parsetree.Pexp_tuple x0 ->\n Ast_412.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_411.Parsetree.Pexp_construct (x0, x1) ->\n Ast_412.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_411.Parsetree.Pexp_variant (x0, x1) ->\n Ast_412.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_411.Parsetree.Pexp_record (x0, x1) ->\n Ast_412.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_411.Parsetree.Pexp_field (x0, x1) ->\n Ast_412.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_411.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_411.Parsetree.Pexp_array x0 ->\n Ast_412.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_411.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_411.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_412.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_while (x0, x1) ->\n Ast_412.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_412.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_411.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_412.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_411.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_411.Parsetree.Pexp_send (x0, x1) ->\n Ast_412.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_411.Parsetree.Pexp_new x0 ->\n Ast_412.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_412.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_override x0 ->\n Ast_412.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_411.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_411.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_412.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_assert x0 ->\n Ast_412.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_411.Parsetree.Pexp_lazy x0 ->\n Ast_412.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_411.Parsetree.Pexp_poly (x0, x1) ->\n Ast_412.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_411.Parsetree.Pexp_object x0 ->\n Ast_412.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_411.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_412.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_pack x0 ->\n Ast_412.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_411.Parsetree.Pexp_open (x0, x1) ->\n Ast_412.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_letop x0 ->\n Ast_412.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_411.Parsetree.Pexp_extension x0 ->\n Ast_412.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_411.Parsetree.Pexp_unreachable -> Ast_412.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_411.Parsetree.letop -> Ast_412.Parsetree.letop =\n fun { Ast_411.Parsetree.let_; Ast_411.Parsetree.ands; Ast_411.Parsetree.body } ->\n {\n Ast_412.Parsetree.let_ = copy_binding_op let_;\n Ast_412.Parsetree.ands = List.map copy_binding_op ands;\n Ast_412.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_411.Parsetree.binding_op -> Ast_412.Parsetree.binding_op =\n fun {\n Ast_411.Parsetree.pbop_op;\n Ast_411.Parsetree.pbop_pat;\n Ast_411.Parsetree.pbop_exp;\n Ast_411.Parsetree.pbop_loc;\n } ->\n {\n Ast_412.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_412.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_412.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_412.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_411.Asttypes.direction_flag -> Ast_412.Asttypes.direction_flag =\n function\n | Ast_411.Asttypes.Upto -> Ast_412.Asttypes.Upto\n | Ast_411.Asttypes.Downto -> Ast_412.Asttypes.Downto\n\nand copy_case : Ast_411.Parsetree.case -> Ast_412.Parsetree.case =\n fun {\n Ast_411.Parsetree.pc_lhs;\n Ast_411.Parsetree.pc_guard;\n Ast_411.Parsetree.pc_rhs;\n } ->\n {\n Ast_412.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_412.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_412.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_411.Parsetree.value_binding -> Ast_412.Parsetree.value_binding =\n fun {\n Ast_411.Parsetree.pvb_pat;\n Ast_411.Parsetree.pvb_expr;\n Ast_411.Parsetree.pvb_attributes;\n Ast_411.Parsetree.pvb_loc;\n } ->\n {\n Ast_412.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_412.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_412.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_412.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_411.Parsetree.pattern -> Ast_412.Parsetree.pattern =\n fun {\n Ast_411.Parsetree.ppat_desc;\n Ast_411.Parsetree.ppat_loc;\n Ast_411.Parsetree.ppat_loc_stack;\n Ast_411.Parsetree.ppat_attributes;\n } ->\n {\n Ast_412.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_412.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_412.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_412.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_411.Parsetree.pattern_desc -> Ast_412.Parsetree.pattern_desc = function\n | Ast_411.Parsetree.Ppat_any -> Ast_412.Parsetree.Ppat_any\n | Ast_411.Parsetree.Ppat_var x0 ->\n Ast_412.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_411.Parsetree.Ppat_alias (x0, x1) ->\n Ast_412.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_411.Parsetree.Ppat_constant x0 ->\n Ast_412.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_411.Parsetree.Ppat_interval (x0, x1) ->\n Ast_412.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_411.Parsetree.Ppat_tuple x0 ->\n Ast_412.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_411.Parsetree.Ppat_construct (x0, x1) ->\n Ast_412.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_411.Parsetree.Ppat_variant (x0, x1) ->\n Ast_412.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_411.Parsetree.Ppat_record (x0, x1) ->\n Ast_412.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_411.Parsetree.Ppat_array x0 ->\n Ast_412.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_411.Parsetree.Ppat_or (x0, x1) ->\n Ast_412.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_411.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_412.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_411.Parsetree.Ppat_type x0 ->\n Ast_412.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Ppat_lazy x0 ->\n Ast_412.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_411.Parsetree.Ppat_unpack x0 ->\n Ast_412.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_411.Parsetree.Ppat_exception x0 ->\n Ast_412.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_411.Parsetree.Ppat_extension x0 ->\n Ast_412.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_411.Parsetree.Ppat_open (x0, x1) ->\n Ast_412.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_411.Parsetree.core_type -> Ast_412.Parsetree.core_type\n =\n fun {\n Ast_411.Parsetree.ptyp_desc;\n Ast_411.Parsetree.ptyp_loc;\n Ast_411.Parsetree.ptyp_loc_stack;\n Ast_411.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_412.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_412.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_412.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_411.Parsetree.location_stack -> Ast_412.Parsetree.location_stack =\n fun x -> x\n\nand copy_core_type_desc :\n Ast_411.Parsetree.core_type_desc -> Ast_412.Parsetree.core_type_desc =\n function\n | Ast_411.Parsetree.Ptyp_any -> Ast_412.Parsetree.Ptyp_any\n | Ast_411.Parsetree.Ptyp_var x0 -> Ast_412.Parsetree.Ptyp_var x0\n | Ast_411.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_412.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_411.Parsetree.Ptyp_tuple x0 ->\n Ast_412.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_411.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_412.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_object (x0, x1) ->\n Ast_412.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_411.Parsetree.Ptyp_class (x0, x1) ->\n Ast_412.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_412.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_411.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_412.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_411.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_412.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_package x0 ->\n Ast_412.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_411.Parsetree.Ptyp_extension x0 ->\n Ast_412.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_411.Parsetree.package_type -> Ast_412.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_411.Parsetree.row_field -> Ast_412.Parsetree.row_field\n =\n fun {\n Ast_411.Parsetree.prf_desc;\n Ast_411.Parsetree.prf_loc;\n Ast_411.Parsetree.prf_attributes;\n } ->\n {\n Ast_412.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_412.Parsetree.prf_loc = copy_location prf_loc;\n Ast_412.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_411.Parsetree.row_field_desc -> Ast_412.Parsetree.row_field_desc =\n function\n | Ast_411.Parsetree.Rtag (x0, x1, x2) ->\n Ast_412.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_411.Parsetree.Rinherit x0 ->\n Ast_412.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_411.Parsetree.object_field -> Ast_412.Parsetree.object_field =\n fun {\n Ast_411.Parsetree.pof_desc;\n Ast_411.Parsetree.pof_loc;\n Ast_411.Parsetree.pof_attributes;\n } ->\n {\n Ast_412.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_412.Parsetree.pof_loc = copy_location pof_loc;\n Ast_412.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_411.Parsetree.attributes -> Ast_412.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_411.Parsetree.attribute -> Ast_412.Parsetree.attribute\n =\n fun {\n Ast_411.Parsetree.attr_name;\n Ast_411.Parsetree.attr_payload;\n Ast_411.Parsetree.attr_loc;\n } ->\n {\n Ast_412.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_412.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_412.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_411.Parsetree.payload -> Ast_412.Parsetree.payload =\n function\n | Ast_411.Parsetree.PStr x0 -> Ast_412.Parsetree.PStr (copy_structure x0)\n | Ast_411.Parsetree.PSig x0 -> Ast_412.Parsetree.PSig (copy_signature x0)\n | Ast_411.Parsetree.PTyp x0 -> Ast_412.Parsetree.PTyp (copy_core_type x0)\n | Ast_411.Parsetree.PPat (x0, x1) ->\n Ast_412.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_411.Parsetree.structure -> Ast_412.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_411.Parsetree.structure_item -> Ast_412.Parsetree.structure_item =\n fun { Ast_411.Parsetree.pstr_desc; Ast_411.Parsetree.pstr_loc } ->\n {\n Ast_412.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_412.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_411.Parsetree.structure_item_desc ->\n Ast_412.Parsetree.structure_item_desc = function\n | Ast_411.Parsetree.Pstr_eval (x0, x1) ->\n Ast_412.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_411.Parsetree.Pstr_value (x0, x1) ->\n Ast_412.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_411.Parsetree.Pstr_primitive x0 ->\n Ast_412.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_411.Parsetree.Pstr_type (x0, x1) ->\n Ast_412.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_411.Parsetree.Pstr_typext x0 ->\n Ast_412.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_411.Parsetree.Pstr_exception x0 ->\n Ast_412.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_411.Parsetree.Pstr_module x0 ->\n Ast_412.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_411.Parsetree.Pstr_recmodule x0 ->\n Ast_412.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_411.Parsetree.Pstr_modtype x0 ->\n Ast_412.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_411.Parsetree.Pstr_open x0 ->\n Ast_412.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_411.Parsetree.Pstr_class x0 ->\n Ast_412.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_411.Parsetree.Pstr_class_type x0 ->\n Ast_412.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_411.Parsetree.Pstr_include x0 ->\n Ast_412.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_411.Parsetree.Pstr_attribute x0 ->\n Ast_412.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pstr_extension (x0, x1) ->\n Ast_412.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_411.Parsetree.include_declaration ->\n Ast_412.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_411.Parsetree.class_declaration -> Ast_412.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_411.Parsetree.class_expr -> Ast_412.Parsetree.class_expr =\n fun {\n Ast_411.Parsetree.pcl_desc;\n Ast_411.Parsetree.pcl_loc;\n Ast_411.Parsetree.pcl_attributes;\n } ->\n {\n Ast_412.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_412.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_412.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_411.Parsetree.class_expr_desc -> Ast_412.Parsetree.class_expr_desc =\n function\n | Ast_411.Parsetree.Pcl_constr (x0, x1) ->\n Ast_412.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Pcl_structure x0 ->\n Ast_412.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_411.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_412.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_411.Parsetree.Pcl_apply (x0, x1) ->\n Ast_412.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_411.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_412.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_411.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_412.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_411.Parsetree.Pcl_extension x0 ->\n Ast_412.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_411.Parsetree.Pcl_open (x0, x1) ->\n Ast_412.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_411.Parsetree.class_structure -> Ast_412.Parsetree.class_structure =\n fun { Ast_411.Parsetree.pcstr_self; Ast_411.Parsetree.pcstr_fields } ->\n {\n Ast_412.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_412.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_411.Parsetree.class_field -> Ast_412.Parsetree.class_field =\n fun {\n Ast_411.Parsetree.pcf_desc;\n Ast_411.Parsetree.pcf_loc;\n Ast_411.Parsetree.pcf_attributes;\n } ->\n {\n Ast_412.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_412.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_412.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_411.Parsetree.class_field_desc -> Ast_412.Parsetree.class_field_desc =\n function\n | Ast_411.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_412.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_411.Parsetree.Pcf_val x0 ->\n Ast_412.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_411.Parsetree.Pcf_method x0 ->\n Ast_412.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_411.Parsetree.Pcf_constraint x0 ->\n Ast_412.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_411.Parsetree.Pcf_initializer x0 ->\n Ast_412.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_411.Parsetree.Pcf_attribute x0 ->\n Ast_412.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pcf_extension x0 ->\n Ast_412.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_411.Parsetree.class_field_kind -> Ast_412.Parsetree.class_field_kind =\n function\n | Ast_411.Parsetree.Cfk_virtual x0 ->\n Ast_412.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_411.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_412.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_411.Parsetree.open_declaration -> Ast_412.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_411.Parsetree.module_binding -> Ast_412.Parsetree.module_binding =\n fun {\n Ast_411.Parsetree.pmb_name;\n Ast_411.Parsetree.pmb_expr;\n Ast_411.Parsetree.pmb_attributes;\n Ast_411.Parsetree.pmb_loc;\n } ->\n {\n Ast_412.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_412.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_412.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_412.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_411.Parsetree.module_expr -> Ast_412.Parsetree.module_expr =\n fun {\n Ast_411.Parsetree.pmod_desc;\n Ast_411.Parsetree.pmod_loc;\n Ast_411.Parsetree.pmod_attributes;\n } ->\n {\n Ast_412.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_412.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_412.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_411.Parsetree.module_expr_desc -> Ast_412.Parsetree.module_expr_desc =\n function\n | Ast_411.Parsetree.Pmod_ident x0 ->\n Ast_412.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pmod_structure x0 ->\n Ast_412.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_411.Parsetree.Pmod_functor (x0, x1) ->\n Ast_412.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_411.Parsetree.Pmod_apply (x0, x1) ->\n Ast_412.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_411.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_412.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_411.Parsetree.Pmod_unpack x0 ->\n Ast_412.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_411.Parsetree.Pmod_extension x0 ->\n Ast_412.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_411.Parsetree.functor_parameter -> Ast_412.Parsetree.functor_parameter =\n function\n | Ast_411.Parsetree.Unit -> Ast_412.Parsetree.Unit\n | Ast_411.Parsetree.Named (x0, x1) ->\n Ast_412.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_411.Parsetree.module_type -> Ast_412.Parsetree.module_type =\n fun {\n Ast_411.Parsetree.pmty_desc;\n Ast_411.Parsetree.pmty_loc;\n Ast_411.Parsetree.pmty_attributes;\n } ->\n {\n Ast_412.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_412.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_412.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_411.Parsetree.module_type_desc -> Ast_412.Parsetree.module_type_desc =\n function\n | Ast_411.Parsetree.Pmty_ident x0 ->\n Ast_412.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pmty_signature x0 ->\n Ast_412.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_411.Parsetree.Pmty_functor (x0, x1) ->\n Ast_412.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_411.Parsetree.Pmty_with (x0, x1) ->\n Ast_412.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_411.Parsetree.Pmty_typeof x0 ->\n Ast_412.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_411.Parsetree.Pmty_extension x0 ->\n Ast_412.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_411.Parsetree.Pmty_alias x0 ->\n Ast_412.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_411.Parsetree.with_constraint -> Ast_412.Parsetree.with_constraint =\n function\n | Ast_411.Parsetree.Pwith_type (x0, x1) ->\n Ast_412.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_411.Parsetree.Pwith_module (x0, x1) ->\n Ast_412.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_411.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_412.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_411.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_412.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_411.Parsetree.signature -> Ast_412.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_411.Parsetree.signature_item -> Ast_412.Parsetree.signature_item =\n fun { Ast_411.Parsetree.psig_desc; Ast_411.Parsetree.psig_loc } ->\n {\n Ast_412.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_412.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_411.Parsetree.signature_item_desc ->\n Ast_412.Parsetree.signature_item_desc = function\n | Ast_411.Parsetree.Psig_value x0 ->\n Ast_412.Parsetree.Psig_value (copy_value_description x0)\n | Ast_411.Parsetree.Psig_type (x0, x1) ->\n Ast_412.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_411.Parsetree.Psig_typesubst x0 ->\n Ast_412.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_411.Parsetree.Psig_typext x0 ->\n Ast_412.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_411.Parsetree.Psig_exception x0 ->\n Ast_412.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_411.Parsetree.Psig_module x0 ->\n Ast_412.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_411.Parsetree.Psig_modsubst x0 ->\n Ast_412.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_411.Parsetree.Psig_recmodule x0 ->\n Ast_412.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_411.Parsetree.Psig_modtype x0 ->\n Ast_412.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_411.Parsetree.Psig_open x0 ->\n Ast_412.Parsetree.Psig_open (copy_open_description x0)\n | Ast_411.Parsetree.Psig_include x0 ->\n Ast_412.Parsetree.Psig_include (copy_include_description x0)\n | Ast_411.Parsetree.Psig_class x0 ->\n Ast_412.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_411.Parsetree.Psig_class_type x0 ->\n Ast_412.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_411.Parsetree.Psig_attribute x0 ->\n Ast_412.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Psig_extension (x0, x1) ->\n Ast_412.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_411.Parsetree.class_type_declaration ->\n Ast_412.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_411.Parsetree.class_description -> Ast_412.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_411.Parsetree.class_type -> Ast_412.Parsetree.class_type =\n fun {\n Ast_411.Parsetree.pcty_desc;\n Ast_411.Parsetree.pcty_loc;\n Ast_411.Parsetree.pcty_attributes;\n } ->\n {\n Ast_412.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_412.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_412.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_411.Parsetree.class_type_desc -> Ast_412.Parsetree.class_type_desc =\n function\n | Ast_411.Parsetree.Pcty_constr (x0, x1) ->\n Ast_412.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Pcty_signature x0 ->\n Ast_412.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_411.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_412.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_411.Parsetree.Pcty_extension x0 ->\n Ast_412.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_411.Parsetree.Pcty_open (x0, x1) ->\n Ast_412.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_411.Parsetree.class_signature -> Ast_412.Parsetree.class_signature =\n fun { Ast_411.Parsetree.pcsig_self; Ast_411.Parsetree.pcsig_fields } ->\n {\n Ast_412.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_412.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_411.Parsetree.class_type_field -> Ast_412.Parsetree.class_type_field =\n fun {\n Ast_411.Parsetree.pctf_desc;\n Ast_411.Parsetree.pctf_loc;\n Ast_411.Parsetree.pctf_attributes;\n } ->\n {\n Ast_412.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_412.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_412.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_411.Parsetree.class_type_field_desc ->\n Ast_412.Parsetree.class_type_field_desc = function\n | Ast_411.Parsetree.Pctf_inherit x0 ->\n Ast_412.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_411.Parsetree.Pctf_val x0 ->\n Ast_412.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_411.Parsetree.Pctf_method x0 ->\n Ast_412.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_411.Parsetree.Pctf_constraint x0 ->\n Ast_412.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_411.Parsetree.Pctf_attribute x0 ->\n Ast_412.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pctf_extension x0 ->\n Ast_412.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_411.Parsetree.extension -> Ast_412.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.class_infos ->\n 'g0 Ast_412.Parsetree.class_infos =\n fun f0\n {\n Ast_411.Parsetree.pci_virt;\n Ast_411.Parsetree.pci_params;\n Ast_411.Parsetree.pci_name;\n Ast_411.Parsetree.pci_expr;\n Ast_411.Parsetree.pci_loc;\n Ast_411.Parsetree.pci_attributes;\n } ->\n {\n Ast_412.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_412.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, (copy_variance x1, Ast_412.Asttypes.NoInjectivity)))\n pci_params;\n Ast_412.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_412.Parsetree.pci_expr = f0 pci_expr;\n Ast_412.Parsetree.pci_loc = copy_location pci_loc;\n Ast_412.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_411.Asttypes.virtual_flag -> Ast_412.Asttypes.virtual_flag = function\n | Ast_411.Asttypes.Virtual -> Ast_412.Asttypes.Virtual\n | Ast_411.Asttypes.Concrete -> Ast_412.Asttypes.Concrete\n\nand copy_include_description :\n Ast_411.Parsetree.include_description ->\n Ast_412.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.include_infos ->\n 'g0 Ast_412.Parsetree.include_infos =\n fun f0\n {\n Ast_411.Parsetree.pincl_mod;\n Ast_411.Parsetree.pincl_loc;\n Ast_411.Parsetree.pincl_attributes;\n } ->\n {\n Ast_412.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_412.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_412.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_411.Parsetree.open_description -> Ast_412.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.open_infos ->\n 'g0 Ast_412.Parsetree.open_infos =\n fun f0\n {\n Ast_411.Parsetree.popen_expr;\n Ast_411.Parsetree.popen_override;\n Ast_411.Parsetree.popen_loc;\n Ast_411.Parsetree.popen_attributes;\n } ->\n {\n Ast_412.Parsetree.popen_expr = f0 popen_expr;\n Ast_412.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_412.Parsetree.popen_loc = copy_location popen_loc;\n Ast_412.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_411.Asttypes.override_flag -> Ast_412.Asttypes.override_flag = function\n | Ast_411.Asttypes.Override -> Ast_412.Asttypes.Override\n | Ast_411.Asttypes.Fresh -> Ast_412.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_411.Parsetree.module_type_declaration ->\n Ast_412.Parsetree.module_type_declaration =\n fun {\n Ast_411.Parsetree.pmtd_name;\n Ast_411.Parsetree.pmtd_type;\n Ast_411.Parsetree.pmtd_attributes;\n Ast_411.Parsetree.pmtd_loc;\n } ->\n {\n Ast_412.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_412.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_412.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_412.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_411.Parsetree.module_substitution ->\n Ast_412.Parsetree.module_substitution =\n fun {\n Ast_411.Parsetree.pms_name;\n Ast_411.Parsetree.pms_manifest;\n Ast_411.Parsetree.pms_attributes;\n Ast_411.Parsetree.pms_loc;\n } ->\n {\n Ast_412.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_412.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_412.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_412.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_411.Parsetree.module_declaration -> Ast_412.Parsetree.module_declaration\n =\n fun {\n Ast_411.Parsetree.pmd_name;\n Ast_411.Parsetree.pmd_type;\n Ast_411.Parsetree.pmd_attributes;\n Ast_411.Parsetree.pmd_loc;\n } ->\n {\n Ast_412.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_412.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_412.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_412.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_411.Parsetree.type_exception -> Ast_412.Parsetree.type_exception =\n fun {\n Ast_411.Parsetree.ptyexn_constructor;\n Ast_411.Parsetree.ptyexn_loc;\n Ast_411.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_412.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_412.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_411.Parsetree.type_extension -> Ast_412.Parsetree.type_extension =\n fun {\n Ast_411.Parsetree.ptyext_path;\n Ast_411.Parsetree.ptyext_params;\n Ast_411.Parsetree.ptyext_constructors;\n Ast_411.Parsetree.ptyext_private;\n Ast_411.Parsetree.ptyext_loc;\n Ast_411.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_412.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, (copy_variance x1, Ast_412.Asttypes.NoInjectivity)))\n ptyext_params;\n Ast_412.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_412.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_412.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_412.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_411.Parsetree.extension_constructor ->\n Ast_412.Parsetree.extension_constructor =\n fun {\n Ast_411.Parsetree.pext_name;\n Ast_411.Parsetree.pext_kind;\n Ast_411.Parsetree.pext_loc;\n Ast_411.Parsetree.pext_attributes;\n } ->\n {\n Ast_412.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_412.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_412.Parsetree.pext_loc = copy_location pext_loc;\n Ast_412.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_411.Parsetree.extension_constructor_kind ->\n Ast_412.Parsetree.extension_constructor_kind = function\n | Ast_411.Parsetree.Pext_decl (x0, x1) ->\n Ast_412.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_411.Parsetree.Pext_rebind x0 ->\n Ast_412.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_411.Parsetree.type_declaration -> Ast_412.Parsetree.type_declaration =\n fun {\n Ast_411.Parsetree.ptype_name;\n Ast_411.Parsetree.ptype_params;\n Ast_411.Parsetree.ptype_cstrs;\n Ast_411.Parsetree.ptype_kind;\n Ast_411.Parsetree.ptype_private;\n Ast_411.Parsetree.ptype_manifest;\n Ast_411.Parsetree.ptype_attributes;\n Ast_411.Parsetree.ptype_loc;\n } ->\n {\n Ast_412.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_412.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, (copy_variance x1, Ast_412.Asttypes.NoInjectivity)))\n ptype_params;\n Ast_412.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_412.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_412.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_412.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_412.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_412.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_411.Asttypes.private_flag -> Ast_412.Asttypes.private_flag = function\n | Ast_411.Asttypes.Private -> Ast_412.Asttypes.Private\n | Ast_411.Asttypes.Public -> Ast_412.Asttypes.Public\n\nand copy_type_kind : Ast_411.Parsetree.type_kind -> Ast_412.Parsetree.type_kind\n = function\n | Ast_411.Parsetree.Ptype_abstract -> Ast_412.Parsetree.Ptype_abstract\n | Ast_411.Parsetree.Ptype_variant x0 ->\n Ast_412.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_411.Parsetree.Ptype_record x0 ->\n Ast_412.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_411.Parsetree.Ptype_open -> Ast_412.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_411.Parsetree.constructor_declaration ->\n Ast_412.Parsetree.constructor_declaration =\n fun {\n Ast_411.Parsetree.pcd_name;\n Ast_411.Parsetree.pcd_args;\n Ast_411.Parsetree.pcd_res;\n Ast_411.Parsetree.pcd_loc;\n Ast_411.Parsetree.pcd_attributes;\n } ->\n {\n Ast_412.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_412.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_412.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_412.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_412.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_411.Parsetree.constructor_arguments ->\n Ast_412.Parsetree.constructor_arguments = function\n | Ast_411.Parsetree.Pcstr_tuple x0 ->\n Ast_412.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_411.Parsetree.Pcstr_record x0 ->\n Ast_412.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_411.Parsetree.label_declaration -> Ast_412.Parsetree.label_declaration =\n fun {\n Ast_411.Parsetree.pld_name;\n Ast_411.Parsetree.pld_mutable;\n Ast_411.Parsetree.pld_type;\n Ast_411.Parsetree.pld_loc;\n Ast_411.Parsetree.pld_attributes;\n } ->\n {\n Ast_412.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_412.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_412.Parsetree.pld_type = copy_core_type pld_type;\n Ast_412.Parsetree.pld_loc = copy_location pld_loc;\n Ast_412.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_411.Asttypes.mutable_flag -> Ast_412.Asttypes.mutable_flag = function\n | Ast_411.Asttypes.Immutable -> Ast_412.Asttypes.Immutable\n | Ast_411.Asttypes.Mutable -> Ast_412.Asttypes.Mutable\n\nand copy_variance : Ast_411.Asttypes.variance -> Ast_412.Asttypes.variance =\n function\n | Ast_411.Asttypes.Covariant -> Ast_412.Asttypes.Covariant\n | Ast_411.Asttypes.Contravariant -> Ast_412.Asttypes.Contravariant\n | Ast_411.Asttypes.Invariant -> Ast_412.Asttypes.NoVariance\n\nand copy_value_description :\n Ast_411.Parsetree.value_description -> Ast_412.Parsetree.value_description =\n fun {\n Ast_411.Parsetree.pval_name;\n Ast_411.Parsetree.pval_type;\n Ast_411.Parsetree.pval_prim;\n Ast_411.Parsetree.pval_attributes;\n Ast_411.Parsetree.pval_loc;\n } ->\n {\n Ast_412.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_412.Parsetree.pval_type = copy_core_type pval_type;\n Ast_412.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_412.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_412.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_411.Parsetree.object_field_desc -> Ast_412.Parsetree.object_field_desc =\n function\n | Ast_411.Parsetree.Otag (x0, x1) ->\n Ast_412.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_411.Parsetree.Oinherit x0 ->\n Ast_412.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_411.Asttypes.arg_label -> Ast_412.Asttypes.arg_label =\n function\n | Ast_411.Asttypes.Nolabel -> Ast_412.Asttypes.Nolabel\n | Ast_411.Asttypes.Labelled x0 -> Ast_412.Asttypes.Labelled x0\n | Ast_411.Asttypes.Optional x0 -> Ast_412.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_411.Asttypes.closed_flag -> Ast_412.Asttypes.closed_flag = function\n | Ast_411.Asttypes.Closed -> Ast_412.Asttypes.Closed\n | Ast_411.Asttypes.Open -> Ast_412.Asttypes.Open\n\nand copy_label : Ast_411.Asttypes.label -> Ast_412.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_411.Asttypes.rec_flag -> Ast_412.Asttypes.rec_flag =\n function\n | Ast_411.Asttypes.Nonrecursive -> Ast_412.Asttypes.Nonrecursive\n | Ast_411.Asttypes.Recursive -> Ast_412.Asttypes.Recursive\n\nand copy_constant : Ast_411.Parsetree.constant -> Ast_412.Parsetree.constant =\n function\n | Ast_411.Parsetree.Pconst_integer (x0, x1) ->\n Ast_412.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_411.Parsetree.Pconst_char x0 -> Ast_412.Parsetree.Pconst_char x0\n | Ast_411.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_412.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_411.Parsetree.Pconst_float (x0, x1) ->\n Ast_412.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_411.Asttypes.loc -> 'g0 Ast_412.Asttypes.loc =\n fun f0 { Ast_411.Asttypes.txt; Ast_411.Asttypes.loc } ->\n { Ast_412.Asttypes.txt = f0 txt; Ast_412.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_411\nmodule To = Ast_410\n\nlet rec copy_toplevel_phrase :\n Ast_411.Parsetree.toplevel_phrase -> Ast_410.Parsetree.toplevel_phrase =\n function\n | Ast_411.Parsetree.Ptop_def x0 ->\n Ast_410.Parsetree.Ptop_def (copy_structure x0)\n | Ast_411.Parsetree.Ptop_dir x0 ->\n Ast_410.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_411.Parsetree.toplevel_directive -> Ast_410.Parsetree.toplevel_directive\n =\n fun {\n Ast_411.Parsetree.pdir_name;\n Ast_411.Parsetree.pdir_arg;\n Ast_411.Parsetree.pdir_loc;\n } ->\n {\n Ast_410.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_410.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_410.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_411.Parsetree.directive_argument -> Ast_410.Parsetree.directive_argument\n =\n fun { Ast_411.Parsetree.pdira_desc; Ast_411.Parsetree.pdira_loc } ->\n {\n Ast_410.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_410.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_411.Parsetree.directive_argument_desc ->\n Ast_410.Parsetree.directive_argument_desc = function\n | Ast_411.Parsetree.Pdir_string x0 -> Ast_410.Parsetree.Pdir_string x0\n | Ast_411.Parsetree.Pdir_int (x0, x1) ->\n Ast_410.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_411.Parsetree.Pdir_ident x0 ->\n Ast_410.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_411.Parsetree.Pdir_bool x0 -> Ast_410.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_411.Parsetree.expression -> Ast_410.Parsetree.expression =\n fun {\n Ast_411.Parsetree.pexp_desc;\n Ast_411.Parsetree.pexp_loc;\n Ast_411.Parsetree.pexp_loc_stack;\n Ast_411.Parsetree.pexp_attributes;\n } ->\n {\n Ast_410.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_410.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_410.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_410.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expr x = copy_expression x\n\nand copy_expression_desc :\n Ast_411.Parsetree.expression_desc -> Ast_410.Parsetree.expression_desc =\n function\n | Ast_411.Parsetree.Pexp_ident x0 ->\n Ast_410.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pexp_constant x0 ->\n Ast_410.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_411.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_411.Parsetree.Pexp_function x0 ->\n Ast_410.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_411.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_410.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_411.Parsetree.Pexp_apply (x0, x1) ->\n Ast_410.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_411.Parsetree.Pexp_match (x0, x1) ->\n Ast_410.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_411.Parsetree.Pexp_try (x0, x1) ->\n Ast_410.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_411.Parsetree.Pexp_tuple x0 ->\n Ast_410.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_411.Parsetree.Pexp_construct (x0, x1) ->\n Ast_410.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_411.Parsetree.Pexp_variant (x0, x1) ->\n Ast_410.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_411.Parsetree.Pexp_record (x0, x1) ->\n Ast_410.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_411.Parsetree.Pexp_field (x0, x1) ->\n Ast_410.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_411.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_411.Parsetree.Pexp_array x0 ->\n Ast_410.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_411.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_411.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_410.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_while (x0, x1) ->\n Ast_410.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_410.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_411.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_410.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_411.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_411.Parsetree.Pexp_send (x0, x1) ->\n Ast_410.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_411.Parsetree.Pexp_new x0 ->\n Ast_410.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_410.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_override x0 ->\n Ast_410.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_411.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_411.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_410.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_assert x0 ->\n Ast_410.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_411.Parsetree.Pexp_lazy x0 ->\n Ast_410.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_411.Parsetree.Pexp_poly (x0, x1) ->\n Ast_410.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_411.Parsetree.Pexp_object x0 ->\n Ast_410.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_411.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_410.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_pack x0 ->\n Ast_410.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_411.Parsetree.Pexp_open (x0, x1) ->\n Ast_410.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_letop x0 ->\n Ast_410.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_411.Parsetree.Pexp_extension x0 ->\n Ast_410.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_411.Parsetree.Pexp_unreachable -> Ast_410.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_411.Parsetree.letop -> Ast_410.Parsetree.letop =\n fun { Ast_411.Parsetree.let_; Ast_411.Parsetree.ands; Ast_411.Parsetree.body } ->\n {\n Ast_410.Parsetree.let_ = copy_binding_op let_;\n Ast_410.Parsetree.ands = List.map copy_binding_op ands;\n Ast_410.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_411.Parsetree.binding_op -> Ast_410.Parsetree.binding_op =\n fun {\n Ast_411.Parsetree.pbop_op;\n Ast_411.Parsetree.pbop_pat;\n Ast_411.Parsetree.pbop_exp;\n Ast_411.Parsetree.pbop_loc;\n } ->\n {\n Ast_410.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_410.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_410.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_410.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_411.Asttypes.direction_flag -> Ast_410.Asttypes.direction_flag =\n function\n | Ast_411.Asttypes.Upto -> Ast_410.Asttypes.Upto\n | Ast_411.Asttypes.Downto -> Ast_410.Asttypes.Downto\n\nand copy_case : Ast_411.Parsetree.case -> Ast_410.Parsetree.case =\n fun {\n Ast_411.Parsetree.pc_lhs;\n Ast_411.Parsetree.pc_guard;\n Ast_411.Parsetree.pc_rhs;\n } ->\n {\n Ast_410.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_410.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_410.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_cases : Ast_411.Parsetree.case list -> Ast_410.Parsetree.case list =\n fun x -> List.map copy_case x\n\nand copy_value_binding :\n Ast_411.Parsetree.value_binding -> Ast_410.Parsetree.value_binding =\n fun {\n Ast_411.Parsetree.pvb_pat;\n Ast_411.Parsetree.pvb_expr;\n Ast_411.Parsetree.pvb_attributes;\n Ast_411.Parsetree.pvb_loc;\n } ->\n {\n Ast_410.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_410.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_410.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_410.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_411.Parsetree.pattern -> Ast_410.Parsetree.pattern =\n fun {\n Ast_411.Parsetree.ppat_desc;\n Ast_411.Parsetree.ppat_loc;\n Ast_411.Parsetree.ppat_loc_stack;\n Ast_411.Parsetree.ppat_attributes;\n } ->\n {\n Ast_410.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_410.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_410.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_410.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pat x = copy_pattern x\n\nand copy_pattern_desc :\n Ast_411.Parsetree.pattern_desc -> Ast_410.Parsetree.pattern_desc = function\n | Ast_411.Parsetree.Ppat_any -> Ast_410.Parsetree.Ppat_any\n | Ast_411.Parsetree.Ppat_var x0 ->\n Ast_410.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_411.Parsetree.Ppat_alias (x0, x1) ->\n Ast_410.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_411.Parsetree.Ppat_constant x0 ->\n Ast_410.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_411.Parsetree.Ppat_interval (x0, x1) ->\n Ast_410.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_411.Parsetree.Ppat_tuple x0 ->\n Ast_410.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_411.Parsetree.Ppat_construct (x0, x1) ->\n Ast_410.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_411.Parsetree.Ppat_variant (x0, x1) ->\n Ast_410.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_411.Parsetree.Ppat_record (x0, x1) ->\n Ast_410.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_411.Parsetree.Ppat_array x0 ->\n Ast_410.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_411.Parsetree.Ppat_or (x0, x1) ->\n Ast_410.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_411.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_410.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_411.Parsetree.Ppat_type x0 ->\n Ast_410.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Ppat_lazy x0 ->\n Ast_410.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_411.Parsetree.Ppat_unpack x0 ->\n Ast_410.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_411.Parsetree.Ppat_exception x0 ->\n Ast_410.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_411.Parsetree.Ppat_extension x0 ->\n Ast_410.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_411.Parsetree.Ppat_open (x0, x1) ->\n Ast_410.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_411.Parsetree.core_type -> Ast_410.Parsetree.core_type\n =\n fun {\n Ast_411.Parsetree.ptyp_desc;\n Ast_411.Parsetree.ptyp_loc;\n Ast_411.Parsetree.ptyp_loc_stack;\n Ast_411.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_410.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_410.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_410.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_typ x = copy_core_type x\n\nand copy_location_stack :\n Ast_411.Parsetree.location_stack -> Ast_410.Parsetree.location_stack =\n fun x -> List.map copy_location x\n\nand copy_core_type_desc :\n Ast_411.Parsetree.core_type_desc -> Ast_410.Parsetree.core_type_desc =\n function\n | Ast_411.Parsetree.Ptyp_any -> Ast_410.Parsetree.Ptyp_any\n | Ast_411.Parsetree.Ptyp_var x0 -> Ast_410.Parsetree.Ptyp_var x0\n | Ast_411.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_410.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_411.Parsetree.Ptyp_tuple x0 ->\n Ast_410.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_411.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_410.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_object (x0, x1) ->\n Ast_410.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_411.Parsetree.Ptyp_class (x0, x1) ->\n Ast_410.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_410.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_411.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_410.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_411.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_410.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_package x0 ->\n Ast_410.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_411.Parsetree.Ptyp_extension x0 ->\n Ast_410.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_411.Parsetree.package_type -> Ast_410.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_411.Parsetree.row_field -> Ast_410.Parsetree.row_field\n =\n fun {\n Ast_411.Parsetree.prf_desc;\n Ast_411.Parsetree.prf_loc;\n Ast_411.Parsetree.prf_attributes;\n } ->\n {\n Ast_410.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_410.Parsetree.prf_loc = copy_location prf_loc;\n Ast_410.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_411.Parsetree.row_field_desc -> Ast_410.Parsetree.row_field_desc =\n function\n | Ast_411.Parsetree.Rtag (x0, x1, x2) ->\n Ast_410.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_411.Parsetree.Rinherit x0 ->\n Ast_410.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_411.Parsetree.object_field -> Ast_410.Parsetree.object_field =\n fun {\n Ast_411.Parsetree.pof_desc;\n Ast_411.Parsetree.pof_loc;\n Ast_411.Parsetree.pof_attributes;\n } ->\n {\n Ast_410.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_410.Parsetree.pof_loc = copy_location pof_loc;\n Ast_410.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_411.Parsetree.attributes -> Ast_410.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_411.Parsetree.attribute -> Ast_410.Parsetree.attribute\n =\n fun {\n Ast_411.Parsetree.attr_name;\n Ast_411.Parsetree.attr_payload;\n Ast_411.Parsetree.attr_loc;\n } ->\n {\n Ast_410.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_410.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_410.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_411.Parsetree.payload -> Ast_410.Parsetree.payload =\n function\n | Ast_411.Parsetree.PStr x0 -> Ast_410.Parsetree.PStr (copy_structure x0)\n | Ast_411.Parsetree.PSig x0 -> Ast_410.Parsetree.PSig (copy_signature x0)\n | Ast_411.Parsetree.PTyp x0 -> Ast_410.Parsetree.PTyp (copy_core_type x0)\n | Ast_411.Parsetree.PPat (x0, x1) ->\n Ast_410.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_411.Parsetree.structure -> Ast_410.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_411.Parsetree.structure_item -> Ast_410.Parsetree.structure_item =\n fun { Ast_411.Parsetree.pstr_desc; Ast_411.Parsetree.pstr_loc } ->\n {\n Ast_410.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_410.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_411.Parsetree.structure_item_desc ->\n Ast_410.Parsetree.structure_item_desc = function\n | Ast_411.Parsetree.Pstr_eval (x0, x1) ->\n Ast_410.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_411.Parsetree.Pstr_value (x0, x1) ->\n Ast_410.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_411.Parsetree.Pstr_primitive x0 ->\n Ast_410.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_411.Parsetree.Pstr_type (x0, x1) ->\n Ast_410.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_411.Parsetree.Pstr_typext x0 ->\n Ast_410.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_411.Parsetree.Pstr_exception x0 ->\n Ast_410.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_411.Parsetree.Pstr_module x0 ->\n Ast_410.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_411.Parsetree.Pstr_recmodule x0 ->\n Ast_410.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_411.Parsetree.Pstr_modtype x0 ->\n Ast_410.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_411.Parsetree.Pstr_open x0 ->\n Ast_410.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_411.Parsetree.Pstr_class x0 ->\n Ast_410.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_411.Parsetree.Pstr_class_type x0 ->\n Ast_410.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_411.Parsetree.Pstr_include x0 ->\n Ast_410.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_411.Parsetree.Pstr_attribute x0 ->\n Ast_410.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pstr_extension (x0, x1) ->\n Ast_410.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_411.Parsetree.include_declaration ->\n Ast_410.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_411.Parsetree.class_declaration -> Ast_410.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_411.Parsetree.class_expr -> Ast_410.Parsetree.class_expr =\n fun {\n Ast_411.Parsetree.pcl_desc;\n Ast_411.Parsetree.pcl_loc;\n Ast_411.Parsetree.pcl_attributes;\n } ->\n {\n Ast_410.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_410.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_410.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_411.Parsetree.class_expr_desc -> Ast_410.Parsetree.class_expr_desc =\n function\n | Ast_411.Parsetree.Pcl_constr (x0, x1) ->\n Ast_410.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Pcl_structure x0 ->\n Ast_410.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_411.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_410.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_411.Parsetree.Pcl_apply (x0, x1) ->\n Ast_410.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_411.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_410.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_411.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_410.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_411.Parsetree.Pcl_extension x0 ->\n Ast_410.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_411.Parsetree.Pcl_open (x0, x1) ->\n Ast_410.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_411.Parsetree.class_structure -> Ast_410.Parsetree.class_structure =\n fun { Ast_411.Parsetree.pcstr_self; Ast_411.Parsetree.pcstr_fields } ->\n {\n Ast_410.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_410.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_411.Parsetree.class_field -> Ast_410.Parsetree.class_field =\n fun {\n Ast_411.Parsetree.pcf_desc;\n Ast_411.Parsetree.pcf_loc;\n Ast_411.Parsetree.pcf_attributes;\n } ->\n {\n Ast_410.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_410.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_410.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_411.Parsetree.class_field_desc -> Ast_410.Parsetree.class_field_desc =\n function\n | Ast_411.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_410.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_411.Parsetree.Pcf_val x0 ->\n Ast_410.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_411.Parsetree.Pcf_method x0 ->\n Ast_410.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_411.Parsetree.Pcf_constraint x0 ->\n Ast_410.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_411.Parsetree.Pcf_initializer x0 ->\n Ast_410.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_411.Parsetree.Pcf_attribute x0 ->\n Ast_410.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pcf_extension x0 ->\n Ast_410.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_411.Parsetree.class_field_kind -> Ast_410.Parsetree.class_field_kind =\n function\n | Ast_411.Parsetree.Cfk_virtual x0 ->\n Ast_410.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_411.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_410.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_411.Parsetree.open_declaration -> Ast_410.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_411.Parsetree.module_binding -> Ast_410.Parsetree.module_binding =\n fun {\n Ast_411.Parsetree.pmb_name;\n Ast_411.Parsetree.pmb_expr;\n Ast_411.Parsetree.pmb_attributes;\n Ast_411.Parsetree.pmb_loc;\n } ->\n {\n Ast_410.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_410.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_410.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_410.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_411.Parsetree.module_expr -> Ast_410.Parsetree.module_expr =\n fun {\n Ast_411.Parsetree.pmod_desc;\n Ast_411.Parsetree.pmod_loc;\n Ast_411.Parsetree.pmod_attributes;\n } ->\n {\n Ast_410.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_410.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_410.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_411.Parsetree.module_expr_desc -> Ast_410.Parsetree.module_expr_desc =\n function\n | Ast_411.Parsetree.Pmod_ident x0 ->\n Ast_410.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pmod_structure x0 ->\n Ast_410.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_411.Parsetree.Pmod_functor (x0, x1) ->\n Ast_410.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_411.Parsetree.Pmod_apply (x0, x1) ->\n Ast_410.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_411.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_410.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_411.Parsetree.Pmod_unpack x0 ->\n Ast_410.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_411.Parsetree.Pmod_extension x0 ->\n Ast_410.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_411.Parsetree.functor_parameter -> Ast_410.Parsetree.functor_parameter =\n function\n | Ast_411.Parsetree.Unit -> Ast_410.Parsetree.Unit\n | Ast_411.Parsetree.Named (x0, x1) ->\n Ast_410.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_411.Parsetree.module_type -> Ast_410.Parsetree.module_type =\n fun {\n Ast_411.Parsetree.pmty_desc;\n Ast_411.Parsetree.pmty_loc;\n Ast_411.Parsetree.pmty_attributes;\n } ->\n {\n Ast_410.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_410.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_410.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_411.Parsetree.module_type_desc -> Ast_410.Parsetree.module_type_desc =\n function\n | Ast_411.Parsetree.Pmty_ident x0 ->\n Ast_410.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pmty_signature x0 ->\n Ast_410.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_411.Parsetree.Pmty_functor (x0, x1) ->\n Ast_410.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_411.Parsetree.Pmty_with (x0, x1) ->\n Ast_410.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_411.Parsetree.Pmty_typeof x0 ->\n Ast_410.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_411.Parsetree.Pmty_extension x0 ->\n Ast_410.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_411.Parsetree.Pmty_alias x0 ->\n Ast_410.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_411.Parsetree.with_constraint -> Ast_410.Parsetree.with_constraint =\n function\n | Ast_411.Parsetree.Pwith_type (x0, x1) ->\n Ast_410.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_411.Parsetree.Pwith_module (x0, x1) ->\n Ast_410.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_411.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_410.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_411.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_410.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_411.Parsetree.signature -> Ast_410.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_411.Parsetree.signature_item -> Ast_410.Parsetree.signature_item =\n fun { Ast_411.Parsetree.psig_desc; Ast_411.Parsetree.psig_loc } ->\n {\n Ast_410.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_410.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_411.Parsetree.signature_item_desc ->\n Ast_410.Parsetree.signature_item_desc = function\n | Ast_411.Parsetree.Psig_value x0 ->\n Ast_410.Parsetree.Psig_value (copy_value_description x0)\n | Ast_411.Parsetree.Psig_type (x0, x1) ->\n Ast_410.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_411.Parsetree.Psig_typesubst x0 ->\n Ast_410.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_411.Parsetree.Psig_typext x0 ->\n Ast_410.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_411.Parsetree.Psig_exception x0 ->\n Ast_410.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_411.Parsetree.Psig_module x0 ->\n Ast_410.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_411.Parsetree.Psig_modsubst x0 ->\n Ast_410.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_411.Parsetree.Psig_recmodule x0 ->\n Ast_410.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_411.Parsetree.Psig_modtype x0 ->\n Ast_410.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_411.Parsetree.Psig_open x0 ->\n Ast_410.Parsetree.Psig_open (copy_open_description x0)\n | Ast_411.Parsetree.Psig_include x0 ->\n Ast_410.Parsetree.Psig_include (copy_include_description x0)\n | Ast_411.Parsetree.Psig_class x0 ->\n Ast_410.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_411.Parsetree.Psig_class_type x0 ->\n Ast_410.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_411.Parsetree.Psig_attribute x0 ->\n Ast_410.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Psig_extension (x0, x1) ->\n Ast_410.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_411.Parsetree.class_type_declaration ->\n Ast_410.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_411.Parsetree.class_description -> Ast_410.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_411.Parsetree.class_type -> Ast_410.Parsetree.class_type =\n fun {\n Ast_411.Parsetree.pcty_desc;\n Ast_411.Parsetree.pcty_loc;\n Ast_411.Parsetree.pcty_attributes;\n } ->\n {\n Ast_410.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_410.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_410.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_411.Parsetree.class_type_desc -> Ast_410.Parsetree.class_type_desc =\n function\n | Ast_411.Parsetree.Pcty_constr (x0, x1) ->\n Ast_410.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Pcty_signature x0 ->\n Ast_410.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_411.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_410.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_411.Parsetree.Pcty_extension x0 ->\n Ast_410.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_411.Parsetree.Pcty_open (x0, x1) ->\n Ast_410.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_411.Parsetree.class_signature -> Ast_410.Parsetree.class_signature =\n fun { Ast_411.Parsetree.pcsig_self; Ast_411.Parsetree.pcsig_fields } ->\n {\n Ast_410.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_410.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_411.Parsetree.class_type_field -> Ast_410.Parsetree.class_type_field =\n fun {\n Ast_411.Parsetree.pctf_desc;\n Ast_411.Parsetree.pctf_loc;\n Ast_411.Parsetree.pctf_attributes;\n } ->\n {\n Ast_410.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_410.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_410.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_411.Parsetree.class_type_field_desc ->\n Ast_410.Parsetree.class_type_field_desc = function\n | Ast_411.Parsetree.Pctf_inherit x0 ->\n Ast_410.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_411.Parsetree.Pctf_val x0 ->\n Ast_410.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_411.Parsetree.Pctf_method x0 ->\n Ast_410.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_411.Parsetree.Pctf_constraint x0 ->\n Ast_410.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_411.Parsetree.Pctf_attribute x0 ->\n Ast_410.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pctf_extension x0 ->\n Ast_410.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_411.Parsetree.extension -> Ast_410.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.class_infos ->\n 'g0 Ast_410.Parsetree.class_infos =\n fun f0\n {\n Ast_411.Parsetree.pci_virt;\n Ast_411.Parsetree.pci_params;\n Ast_411.Parsetree.pci_name;\n Ast_411.Parsetree.pci_expr;\n Ast_411.Parsetree.pci_loc;\n Ast_411.Parsetree.pci_attributes;\n } ->\n {\n Ast_410.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_410.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_410.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_410.Parsetree.pci_expr = f0 pci_expr;\n Ast_410.Parsetree.pci_loc = copy_location pci_loc;\n Ast_410.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_411.Asttypes.virtual_flag -> Ast_410.Asttypes.virtual_flag = function\n | Ast_411.Asttypes.Virtual -> Ast_410.Asttypes.Virtual\n | Ast_411.Asttypes.Concrete -> Ast_410.Asttypes.Concrete\n\nand copy_include_description :\n Ast_411.Parsetree.include_description ->\n Ast_410.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.include_infos ->\n 'g0 Ast_410.Parsetree.include_infos =\n fun f0\n {\n Ast_411.Parsetree.pincl_mod;\n Ast_411.Parsetree.pincl_loc;\n Ast_411.Parsetree.pincl_attributes;\n } ->\n {\n Ast_410.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_410.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_410.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_411.Parsetree.open_description -> Ast_410.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.open_infos ->\n 'g0 Ast_410.Parsetree.open_infos =\n fun f0\n {\n Ast_411.Parsetree.popen_expr;\n Ast_411.Parsetree.popen_override;\n Ast_411.Parsetree.popen_loc;\n Ast_411.Parsetree.popen_attributes;\n } ->\n {\n Ast_410.Parsetree.popen_expr = f0 popen_expr;\n Ast_410.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_410.Parsetree.popen_loc = copy_location popen_loc;\n Ast_410.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_411.Asttypes.override_flag -> Ast_410.Asttypes.override_flag = function\n | Ast_411.Asttypes.Override -> Ast_410.Asttypes.Override\n | Ast_411.Asttypes.Fresh -> Ast_410.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_411.Parsetree.module_type_declaration ->\n Ast_410.Parsetree.module_type_declaration =\n fun {\n Ast_411.Parsetree.pmtd_name;\n Ast_411.Parsetree.pmtd_type;\n Ast_411.Parsetree.pmtd_attributes;\n Ast_411.Parsetree.pmtd_loc;\n } ->\n {\n Ast_410.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_410.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_410.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_410.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_411.Parsetree.module_substitution ->\n Ast_410.Parsetree.module_substitution =\n fun {\n Ast_411.Parsetree.pms_name;\n Ast_411.Parsetree.pms_manifest;\n Ast_411.Parsetree.pms_attributes;\n Ast_411.Parsetree.pms_loc;\n } ->\n {\n Ast_410.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_410.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_410.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_410.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_411.Parsetree.module_declaration -> Ast_410.Parsetree.module_declaration\n =\n fun {\n Ast_411.Parsetree.pmd_name;\n Ast_411.Parsetree.pmd_type;\n Ast_411.Parsetree.pmd_attributes;\n Ast_411.Parsetree.pmd_loc;\n } ->\n {\n Ast_410.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_410.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_410.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_410.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_411.Parsetree.type_exception -> Ast_410.Parsetree.type_exception =\n fun {\n Ast_411.Parsetree.ptyexn_constructor;\n Ast_411.Parsetree.ptyexn_loc;\n Ast_411.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_410.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_410.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_411.Parsetree.type_extension -> Ast_410.Parsetree.type_extension =\n fun {\n Ast_411.Parsetree.ptyext_path;\n Ast_411.Parsetree.ptyext_params;\n Ast_411.Parsetree.ptyext_constructors;\n Ast_411.Parsetree.ptyext_private;\n Ast_411.Parsetree.ptyext_loc;\n Ast_411.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_410.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_410.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_410.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_410.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_410.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_411.Parsetree.extension_constructor ->\n Ast_410.Parsetree.extension_constructor =\n fun {\n Ast_411.Parsetree.pext_name;\n Ast_411.Parsetree.pext_kind;\n Ast_411.Parsetree.pext_loc;\n Ast_411.Parsetree.pext_attributes;\n } ->\n {\n Ast_410.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_410.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_410.Parsetree.pext_loc = copy_location pext_loc;\n Ast_410.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_411.Parsetree.extension_constructor_kind ->\n Ast_410.Parsetree.extension_constructor_kind = function\n | Ast_411.Parsetree.Pext_decl (x0, x1) ->\n Ast_410.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_411.Parsetree.Pext_rebind x0 ->\n Ast_410.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_411.Parsetree.type_declaration -> Ast_410.Parsetree.type_declaration =\n fun {\n Ast_411.Parsetree.ptype_name;\n Ast_411.Parsetree.ptype_params;\n Ast_411.Parsetree.ptype_cstrs;\n Ast_411.Parsetree.ptype_kind;\n Ast_411.Parsetree.ptype_private;\n Ast_411.Parsetree.ptype_manifest;\n Ast_411.Parsetree.ptype_attributes;\n Ast_411.Parsetree.ptype_loc;\n } ->\n {\n Ast_410.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_410.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_410.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_410.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_410.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_410.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_410.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_410.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_411.Asttypes.private_flag -> Ast_410.Asttypes.private_flag = function\n | Ast_411.Asttypes.Private -> Ast_410.Asttypes.Private\n | Ast_411.Asttypes.Public -> Ast_410.Asttypes.Public\n\nand copy_type_kind : Ast_411.Parsetree.type_kind -> Ast_410.Parsetree.type_kind\n = function\n | Ast_411.Parsetree.Ptype_abstract -> Ast_410.Parsetree.Ptype_abstract\n | Ast_411.Parsetree.Ptype_variant x0 ->\n Ast_410.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_411.Parsetree.Ptype_record x0 ->\n Ast_410.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_411.Parsetree.Ptype_open -> Ast_410.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_411.Parsetree.constructor_declaration ->\n Ast_410.Parsetree.constructor_declaration =\n fun {\n Ast_411.Parsetree.pcd_name;\n Ast_411.Parsetree.pcd_args;\n Ast_411.Parsetree.pcd_res;\n Ast_411.Parsetree.pcd_loc;\n Ast_411.Parsetree.pcd_attributes;\n } ->\n {\n Ast_410.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_410.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_410.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_410.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_410.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_411.Parsetree.constructor_arguments ->\n Ast_410.Parsetree.constructor_arguments = function\n | Ast_411.Parsetree.Pcstr_tuple x0 ->\n Ast_410.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_411.Parsetree.Pcstr_record x0 ->\n Ast_410.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_411.Parsetree.label_declaration -> Ast_410.Parsetree.label_declaration =\n fun {\n Ast_411.Parsetree.pld_name;\n Ast_411.Parsetree.pld_mutable;\n Ast_411.Parsetree.pld_type;\n Ast_411.Parsetree.pld_loc;\n Ast_411.Parsetree.pld_attributes;\n } ->\n {\n Ast_410.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_410.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_410.Parsetree.pld_type = copy_core_type pld_type;\n Ast_410.Parsetree.pld_loc = copy_location pld_loc;\n Ast_410.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_411.Asttypes.mutable_flag -> Ast_410.Asttypes.mutable_flag = function\n | Ast_411.Asttypes.Immutable -> Ast_410.Asttypes.Immutable\n | Ast_411.Asttypes.Mutable -> Ast_410.Asttypes.Mutable\n\nand copy_variance : Ast_411.Asttypes.variance -> Ast_410.Asttypes.variance =\n function\n | Ast_411.Asttypes.Covariant -> Ast_410.Asttypes.Covariant\n | Ast_411.Asttypes.Contravariant -> Ast_410.Asttypes.Contravariant\n | Ast_411.Asttypes.Invariant -> Ast_410.Asttypes.Invariant\n\nand copy_value_description :\n Ast_411.Parsetree.value_description -> Ast_410.Parsetree.value_description =\n fun {\n Ast_411.Parsetree.pval_name;\n Ast_411.Parsetree.pval_type;\n Ast_411.Parsetree.pval_prim;\n Ast_411.Parsetree.pval_attributes;\n Ast_411.Parsetree.pval_loc;\n } ->\n {\n Ast_410.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_410.Parsetree.pval_type = copy_core_type pval_type;\n Ast_410.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_410.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_410.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_411.Parsetree.object_field_desc -> Ast_410.Parsetree.object_field_desc =\n function\n | Ast_411.Parsetree.Otag (x0, x1) ->\n Ast_410.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_411.Parsetree.Oinherit x0 ->\n Ast_410.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_411.Asttypes.arg_label -> Ast_410.Asttypes.arg_label =\n function\n | Ast_411.Asttypes.Nolabel -> Ast_410.Asttypes.Nolabel\n | Ast_411.Asttypes.Labelled x0 -> Ast_410.Asttypes.Labelled x0\n | Ast_411.Asttypes.Optional x0 -> Ast_410.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_411.Asttypes.closed_flag -> Ast_410.Asttypes.closed_flag = function\n | Ast_411.Asttypes.Closed -> Ast_410.Asttypes.Closed\n | Ast_411.Asttypes.Open -> Ast_410.Asttypes.Open\n\nand copy_label : Ast_411.Asttypes.label -> Ast_410.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_411.Asttypes.rec_flag -> Ast_410.Asttypes.rec_flag =\n function\n | Ast_411.Asttypes.Nonrecursive -> Ast_410.Asttypes.Nonrecursive\n | Ast_411.Asttypes.Recursive -> Ast_410.Asttypes.Recursive\n\nand copy_constant : Ast_411.Parsetree.constant -> Ast_410.Parsetree.constant =\n function\n | Ast_411.Parsetree.Pconst_integer (x0, x1) ->\n Ast_410.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_411.Parsetree.Pconst_char x0 -> Ast_410.Parsetree.Pconst_char x0\n | Ast_411.Parsetree.Pconst_string (x0, _, x2) ->\n Ast_410.Parsetree.Pconst_string (x0, Option.map (fun x -> x) x2)\n | Ast_411.Parsetree.Pconst_float (x0, x1) ->\n Ast_410.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_411.Asttypes.loc -> 'g0 Ast_410.Asttypes.loc =\n fun f0 { Ast_411.Asttypes.txt; Ast_411.Asttypes.loc } ->\n { Ast_410.Asttypes.txt = f0 txt; Ast_410.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_410\nmodule To = Ast_411\n\nlet rec copy_toplevel_phrase :\n Ast_410.Parsetree.toplevel_phrase -> Ast_411.Parsetree.toplevel_phrase =\n function\n | Ast_410.Parsetree.Ptop_def x0 ->\n Ast_411.Parsetree.Ptop_def (copy_structure x0)\n | Ast_410.Parsetree.Ptop_dir x0 ->\n Ast_411.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_410.Parsetree.toplevel_directive -> Ast_411.Parsetree.toplevel_directive\n =\n fun {\n Ast_410.Parsetree.pdir_name;\n Ast_410.Parsetree.pdir_arg;\n Ast_410.Parsetree.pdir_loc;\n } ->\n {\n Ast_411.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_411.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_411.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_410.Parsetree.directive_argument -> Ast_411.Parsetree.directive_argument\n =\n fun { Ast_410.Parsetree.pdira_desc; Ast_410.Parsetree.pdira_loc } ->\n {\n Ast_411.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_411.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_410.Parsetree.directive_argument_desc ->\n Ast_411.Parsetree.directive_argument_desc = function\n | Ast_410.Parsetree.Pdir_string x0 -> Ast_411.Parsetree.Pdir_string x0\n | Ast_410.Parsetree.Pdir_int (x0, x1) ->\n Ast_411.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_410.Parsetree.Pdir_ident x0 ->\n Ast_411.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_410.Parsetree.Pdir_bool x0 -> Ast_411.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_410.Parsetree.expression -> Ast_411.Parsetree.expression =\n fun {\n Ast_410.Parsetree.pexp_desc;\n Ast_410.Parsetree.pexp_loc;\n Ast_410.Parsetree.pexp_loc_stack;\n Ast_410.Parsetree.pexp_attributes;\n } ->\n {\n Ast_411.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_411.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_411.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_411.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expr x = copy_expression x\n\nand copy_expression_desc :\n Ast_410.Parsetree.expression_desc -> Ast_411.Parsetree.expression_desc =\n function\n | Ast_410.Parsetree.Pexp_ident x0 ->\n Ast_411.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pexp_constant x0 ->\n Ast_411.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_410.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_410.Parsetree.Pexp_function x0 ->\n Ast_411.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_410.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_411.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_410.Parsetree.Pexp_apply (x0, x1) ->\n Ast_411.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_410.Parsetree.Pexp_match (x0, x1) ->\n Ast_411.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_410.Parsetree.Pexp_try (x0, x1) ->\n Ast_411.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_410.Parsetree.Pexp_tuple x0 ->\n Ast_411.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_410.Parsetree.Pexp_construct (x0, x1) ->\n Ast_411.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_410.Parsetree.Pexp_variant (x0, x1) ->\n Ast_411.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_410.Parsetree.Pexp_record (x0, x1) ->\n Ast_411.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_410.Parsetree.Pexp_field (x0, x1) ->\n Ast_411.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_410.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_410.Parsetree.Pexp_array x0 ->\n Ast_411.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_410.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_410.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_411.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_while (x0, x1) ->\n Ast_411.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_411.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_410.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_411.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_410.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_410.Parsetree.Pexp_send (x0, x1) ->\n Ast_411.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_410.Parsetree.Pexp_new x0 ->\n Ast_411.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_411.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_override x0 ->\n Ast_411.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_410.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_410.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_411.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_assert x0 ->\n Ast_411.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_410.Parsetree.Pexp_lazy x0 ->\n Ast_411.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_410.Parsetree.Pexp_poly (x0, x1) ->\n Ast_411.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_410.Parsetree.Pexp_object x0 ->\n Ast_411.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_410.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_411.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_pack x0 ->\n Ast_411.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_410.Parsetree.Pexp_open (x0, x1) ->\n Ast_411.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_letop x0 ->\n Ast_411.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_410.Parsetree.Pexp_extension x0 ->\n Ast_411.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_410.Parsetree.Pexp_unreachable -> Ast_411.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_410.Parsetree.letop -> Ast_411.Parsetree.letop =\n fun { Ast_410.Parsetree.let_; Ast_410.Parsetree.ands; Ast_410.Parsetree.body } ->\n {\n Ast_411.Parsetree.let_ = copy_binding_op let_;\n Ast_411.Parsetree.ands = List.map copy_binding_op ands;\n Ast_411.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_410.Parsetree.binding_op -> Ast_411.Parsetree.binding_op =\n fun {\n Ast_410.Parsetree.pbop_op;\n Ast_410.Parsetree.pbop_pat;\n Ast_410.Parsetree.pbop_exp;\n Ast_410.Parsetree.pbop_loc;\n } ->\n {\n Ast_411.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_411.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_411.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_411.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_410.Asttypes.direction_flag -> Ast_411.Asttypes.direction_flag =\n function\n | Ast_410.Asttypes.Upto -> Ast_411.Asttypes.Upto\n | Ast_410.Asttypes.Downto -> Ast_411.Asttypes.Downto\n\nand copy_case : Ast_410.Parsetree.case -> Ast_411.Parsetree.case =\n fun {\n Ast_410.Parsetree.pc_lhs;\n Ast_410.Parsetree.pc_guard;\n Ast_410.Parsetree.pc_rhs;\n } ->\n {\n Ast_411.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_411.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_411.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_cases : Ast_410.Parsetree.case list -> Ast_411.Parsetree.case list =\n fun x -> List.map copy_case x\n\nand copy_value_binding :\n Ast_410.Parsetree.value_binding -> Ast_411.Parsetree.value_binding =\n fun {\n Ast_410.Parsetree.pvb_pat;\n Ast_410.Parsetree.pvb_expr;\n Ast_410.Parsetree.pvb_attributes;\n Ast_410.Parsetree.pvb_loc;\n } ->\n {\n Ast_411.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_411.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_411.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_411.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_410.Parsetree.pattern -> Ast_411.Parsetree.pattern =\n fun {\n Ast_410.Parsetree.ppat_desc;\n Ast_410.Parsetree.ppat_loc;\n Ast_410.Parsetree.ppat_loc_stack;\n Ast_410.Parsetree.ppat_attributes;\n } ->\n {\n Ast_411.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_411.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_411.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_411.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pat x = copy_pattern x\n\nand copy_pattern_desc :\n Ast_410.Parsetree.pattern_desc -> Ast_411.Parsetree.pattern_desc = function\n | Ast_410.Parsetree.Ppat_any -> Ast_411.Parsetree.Ppat_any\n | Ast_410.Parsetree.Ppat_var x0 ->\n Ast_411.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_410.Parsetree.Ppat_alias (x0, x1) ->\n Ast_411.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_410.Parsetree.Ppat_constant x0 ->\n Ast_411.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_410.Parsetree.Ppat_interval (x0, x1) ->\n Ast_411.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_410.Parsetree.Ppat_tuple x0 ->\n Ast_411.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_410.Parsetree.Ppat_construct (x0, x1) ->\n Ast_411.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_410.Parsetree.Ppat_variant (x0, x1) ->\n Ast_411.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_410.Parsetree.Ppat_record (x0, x1) ->\n Ast_411.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_410.Parsetree.Ppat_array x0 ->\n Ast_411.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_410.Parsetree.Ppat_or (x0, x1) ->\n Ast_411.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_410.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_411.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_410.Parsetree.Ppat_type x0 ->\n Ast_411.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Ppat_lazy x0 ->\n Ast_411.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_410.Parsetree.Ppat_unpack x0 ->\n Ast_411.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_410.Parsetree.Ppat_exception x0 ->\n Ast_411.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_410.Parsetree.Ppat_extension x0 ->\n Ast_411.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_410.Parsetree.Ppat_open (x0, x1) ->\n Ast_411.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_410.Parsetree.core_type -> Ast_411.Parsetree.core_type\n =\n fun {\n Ast_410.Parsetree.ptyp_desc;\n Ast_410.Parsetree.ptyp_loc;\n Ast_410.Parsetree.ptyp_loc_stack;\n Ast_410.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_411.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_411.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_411.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_typ x = copy_core_type x\n\nand copy_location_stack :\n Ast_410.Parsetree.location_stack -> Ast_411.Parsetree.location_stack =\n fun x -> List.map copy_location x\n\nand copy_core_type_desc :\n Ast_410.Parsetree.core_type_desc -> Ast_411.Parsetree.core_type_desc =\n function\n | Ast_410.Parsetree.Ptyp_any -> Ast_411.Parsetree.Ptyp_any\n | Ast_410.Parsetree.Ptyp_var x0 -> Ast_411.Parsetree.Ptyp_var x0\n | Ast_410.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_411.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_410.Parsetree.Ptyp_tuple x0 ->\n Ast_411.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_410.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_411.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_object (x0, x1) ->\n Ast_411.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_410.Parsetree.Ptyp_class (x0, x1) ->\n Ast_411.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_411.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_410.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_411.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_410.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_411.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_package x0 ->\n Ast_411.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_410.Parsetree.Ptyp_extension x0 ->\n Ast_411.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_410.Parsetree.package_type -> Ast_411.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_410.Parsetree.row_field -> Ast_411.Parsetree.row_field\n =\n fun {\n Ast_410.Parsetree.prf_desc;\n Ast_410.Parsetree.prf_loc;\n Ast_410.Parsetree.prf_attributes;\n } ->\n {\n Ast_411.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_411.Parsetree.prf_loc = copy_location prf_loc;\n Ast_411.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_410.Parsetree.row_field_desc -> Ast_411.Parsetree.row_field_desc =\n function\n | Ast_410.Parsetree.Rtag (x0, x1, x2) ->\n Ast_411.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_410.Parsetree.Rinherit x0 ->\n Ast_411.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_410.Parsetree.object_field -> Ast_411.Parsetree.object_field =\n fun {\n Ast_410.Parsetree.pof_desc;\n Ast_410.Parsetree.pof_loc;\n Ast_410.Parsetree.pof_attributes;\n } ->\n {\n Ast_411.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_411.Parsetree.pof_loc = copy_location pof_loc;\n Ast_411.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_410.Parsetree.attributes -> Ast_411.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_410.Parsetree.attribute -> Ast_411.Parsetree.attribute\n =\n fun {\n Ast_410.Parsetree.attr_name;\n Ast_410.Parsetree.attr_payload;\n Ast_410.Parsetree.attr_loc;\n } ->\n {\n Ast_411.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_411.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_411.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_410.Parsetree.payload -> Ast_411.Parsetree.payload =\n function\n | Ast_410.Parsetree.PStr x0 -> Ast_411.Parsetree.PStr (copy_structure x0)\n | Ast_410.Parsetree.PSig x0 -> Ast_411.Parsetree.PSig (copy_signature x0)\n | Ast_410.Parsetree.PTyp x0 -> Ast_411.Parsetree.PTyp (copy_core_type x0)\n | Ast_410.Parsetree.PPat (x0, x1) ->\n Ast_411.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_410.Parsetree.structure -> Ast_411.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_410.Parsetree.structure_item -> Ast_411.Parsetree.structure_item =\n fun { Ast_410.Parsetree.pstr_desc; Ast_410.Parsetree.pstr_loc } ->\n {\n Ast_411.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_411.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_410.Parsetree.structure_item_desc ->\n Ast_411.Parsetree.structure_item_desc = function\n | Ast_410.Parsetree.Pstr_eval (x0, x1) ->\n Ast_411.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_410.Parsetree.Pstr_value (x0, x1) ->\n Ast_411.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_410.Parsetree.Pstr_primitive x0 ->\n Ast_411.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_410.Parsetree.Pstr_type (x0, x1) ->\n Ast_411.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_410.Parsetree.Pstr_typext x0 ->\n Ast_411.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_410.Parsetree.Pstr_exception x0 ->\n Ast_411.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_410.Parsetree.Pstr_module x0 ->\n Ast_411.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_410.Parsetree.Pstr_recmodule x0 ->\n Ast_411.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_410.Parsetree.Pstr_modtype x0 ->\n Ast_411.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_410.Parsetree.Pstr_open x0 ->\n Ast_411.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_410.Parsetree.Pstr_class x0 ->\n Ast_411.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_410.Parsetree.Pstr_class_type x0 ->\n Ast_411.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_410.Parsetree.Pstr_include x0 ->\n Ast_411.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_410.Parsetree.Pstr_attribute x0 ->\n Ast_411.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pstr_extension (x0, x1) ->\n Ast_411.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_410.Parsetree.include_declaration ->\n Ast_411.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_410.Parsetree.class_declaration -> Ast_411.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_410.Parsetree.class_expr -> Ast_411.Parsetree.class_expr =\n fun {\n Ast_410.Parsetree.pcl_desc;\n Ast_410.Parsetree.pcl_loc;\n Ast_410.Parsetree.pcl_attributes;\n } ->\n {\n Ast_411.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_411.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_411.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_410.Parsetree.class_expr_desc -> Ast_411.Parsetree.class_expr_desc =\n function\n | Ast_410.Parsetree.Pcl_constr (x0, x1) ->\n Ast_411.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Pcl_structure x0 ->\n Ast_411.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_410.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_411.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_410.Parsetree.Pcl_apply (x0, x1) ->\n Ast_411.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_410.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_411.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_410.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_411.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_410.Parsetree.Pcl_extension x0 ->\n Ast_411.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_410.Parsetree.Pcl_open (x0, x1) ->\n Ast_411.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_410.Parsetree.class_structure -> Ast_411.Parsetree.class_structure =\n fun { Ast_410.Parsetree.pcstr_self; Ast_410.Parsetree.pcstr_fields } ->\n {\n Ast_411.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_411.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_410.Parsetree.class_field -> Ast_411.Parsetree.class_field =\n fun {\n Ast_410.Parsetree.pcf_desc;\n Ast_410.Parsetree.pcf_loc;\n Ast_410.Parsetree.pcf_attributes;\n } ->\n {\n Ast_411.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_411.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_411.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_410.Parsetree.class_field_desc -> Ast_411.Parsetree.class_field_desc =\n function\n | Ast_410.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_411.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_410.Parsetree.Pcf_val x0 ->\n Ast_411.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_410.Parsetree.Pcf_method x0 ->\n Ast_411.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_410.Parsetree.Pcf_constraint x0 ->\n Ast_411.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_410.Parsetree.Pcf_initializer x0 ->\n Ast_411.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_410.Parsetree.Pcf_attribute x0 ->\n Ast_411.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pcf_extension x0 ->\n Ast_411.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_410.Parsetree.class_field_kind -> Ast_411.Parsetree.class_field_kind =\n function\n | Ast_410.Parsetree.Cfk_virtual x0 ->\n Ast_411.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_410.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_411.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_410.Parsetree.open_declaration -> Ast_411.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_410.Parsetree.module_binding -> Ast_411.Parsetree.module_binding =\n fun {\n Ast_410.Parsetree.pmb_name;\n Ast_410.Parsetree.pmb_expr;\n Ast_410.Parsetree.pmb_attributes;\n Ast_410.Parsetree.pmb_loc;\n } ->\n {\n Ast_411.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_411.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_411.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_411.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_410.Parsetree.module_expr -> Ast_411.Parsetree.module_expr =\n fun {\n Ast_410.Parsetree.pmod_desc;\n Ast_410.Parsetree.pmod_loc;\n Ast_410.Parsetree.pmod_attributes;\n } ->\n {\n Ast_411.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_411.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_411.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_410.Parsetree.module_expr_desc -> Ast_411.Parsetree.module_expr_desc =\n function\n | Ast_410.Parsetree.Pmod_ident x0 ->\n Ast_411.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pmod_structure x0 ->\n Ast_411.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_410.Parsetree.Pmod_functor (x0, x1) ->\n Ast_411.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_410.Parsetree.Pmod_apply (x0, x1) ->\n Ast_411.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_410.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_411.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_410.Parsetree.Pmod_unpack x0 ->\n Ast_411.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_410.Parsetree.Pmod_extension x0 ->\n Ast_411.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_410.Parsetree.functor_parameter -> Ast_411.Parsetree.functor_parameter =\n function\n | Ast_410.Parsetree.Unit -> Ast_411.Parsetree.Unit\n | Ast_410.Parsetree.Named (x0, x1) ->\n Ast_411.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_410.Parsetree.module_type -> Ast_411.Parsetree.module_type =\n fun {\n Ast_410.Parsetree.pmty_desc;\n Ast_410.Parsetree.pmty_loc;\n Ast_410.Parsetree.pmty_attributes;\n } ->\n {\n Ast_411.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_411.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_411.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_410.Parsetree.module_type_desc -> Ast_411.Parsetree.module_type_desc =\n function\n | Ast_410.Parsetree.Pmty_ident x0 ->\n Ast_411.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pmty_signature x0 ->\n Ast_411.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_410.Parsetree.Pmty_functor (x0, x1) ->\n Ast_411.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_410.Parsetree.Pmty_with (x0, x1) ->\n Ast_411.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_410.Parsetree.Pmty_typeof x0 ->\n Ast_411.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_410.Parsetree.Pmty_extension x0 ->\n Ast_411.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_410.Parsetree.Pmty_alias x0 ->\n Ast_411.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_410.Parsetree.with_constraint -> Ast_411.Parsetree.with_constraint =\n function\n | Ast_410.Parsetree.Pwith_type (x0, x1) ->\n Ast_411.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_410.Parsetree.Pwith_module (x0, x1) ->\n Ast_411.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_410.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_411.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_410.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_411.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_410.Parsetree.signature -> Ast_411.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_410.Parsetree.signature_item -> Ast_411.Parsetree.signature_item =\n fun { Ast_410.Parsetree.psig_desc; Ast_410.Parsetree.psig_loc } ->\n {\n Ast_411.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_411.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_410.Parsetree.signature_item_desc ->\n Ast_411.Parsetree.signature_item_desc = function\n | Ast_410.Parsetree.Psig_value x0 ->\n Ast_411.Parsetree.Psig_value (copy_value_description x0)\n | Ast_410.Parsetree.Psig_type (x0, x1) ->\n Ast_411.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_410.Parsetree.Psig_typesubst x0 ->\n Ast_411.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_410.Parsetree.Psig_typext x0 ->\n Ast_411.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_410.Parsetree.Psig_exception x0 ->\n Ast_411.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_410.Parsetree.Psig_module x0 ->\n Ast_411.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_410.Parsetree.Psig_modsubst x0 ->\n Ast_411.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_410.Parsetree.Psig_recmodule x0 ->\n Ast_411.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_410.Parsetree.Psig_modtype x0 ->\n Ast_411.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_410.Parsetree.Psig_open x0 ->\n Ast_411.Parsetree.Psig_open (copy_open_description x0)\n | Ast_410.Parsetree.Psig_include x0 ->\n Ast_411.Parsetree.Psig_include (copy_include_description x0)\n | Ast_410.Parsetree.Psig_class x0 ->\n Ast_411.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_410.Parsetree.Psig_class_type x0 ->\n Ast_411.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_410.Parsetree.Psig_attribute x0 ->\n Ast_411.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Psig_extension (x0, x1) ->\n Ast_411.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_410.Parsetree.class_type_declaration ->\n Ast_411.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_410.Parsetree.class_description -> Ast_411.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_410.Parsetree.class_type -> Ast_411.Parsetree.class_type =\n fun {\n Ast_410.Parsetree.pcty_desc;\n Ast_410.Parsetree.pcty_loc;\n Ast_410.Parsetree.pcty_attributes;\n } ->\n {\n Ast_411.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_411.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_411.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_410.Parsetree.class_type_desc -> Ast_411.Parsetree.class_type_desc =\n function\n | Ast_410.Parsetree.Pcty_constr (x0, x1) ->\n Ast_411.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Pcty_signature x0 ->\n Ast_411.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_410.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_411.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_410.Parsetree.Pcty_extension x0 ->\n Ast_411.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_410.Parsetree.Pcty_open (x0, x1) ->\n Ast_411.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_410.Parsetree.class_signature -> Ast_411.Parsetree.class_signature =\n fun { Ast_410.Parsetree.pcsig_self; Ast_410.Parsetree.pcsig_fields } ->\n {\n Ast_411.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_411.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_410.Parsetree.class_type_field -> Ast_411.Parsetree.class_type_field =\n fun {\n Ast_410.Parsetree.pctf_desc;\n Ast_410.Parsetree.pctf_loc;\n Ast_410.Parsetree.pctf_attributes;\n } ->\n {\n Ast_411.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_411.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_411.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_410.Parsetree.class_type_field_desc ->\n Ast_411.Parsetree.class_type_field_desc = function\n | Ast_410.Parsetree.Pctf_inherit x0 ->\n Ast_411.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_410.Parsetree.Pctf_val x0 ->\n Ast_411.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_410.Parsetree.Pctf_method x0 ->\n Ast_411.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_410.Parsetree.Pctf_constraint x0 ->\n Ast_411.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_410.Parsetree.Pctf_attribute x0 ->\n Ast_411.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pctf_extension x0 ->\n Ast_411.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_410.Parsetree.extension -> Ast_411.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.class_infos ->\n 'g0 Ast_411.Parsetree.class_infos =\n fun f0\n {\n Ast_410.Parsetree.pci_virt;\n Ast_410.Parsetree.pci_params;\n Ast_410.Parsetree.pci_name;\n Ast_410.Parsetree.pci_expr;\n Ast_410.Parsetree.pci_loc;\n Ast_410.Parsetree.pci_attributes;\n } ->\n {\n Ast_411.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_411.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_411.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_411.Parsetree.pci_expr = f0 pci_expr;\n Ast_411.Parsetree.pci_loc = copy_location pci_loc;\n Ast_411.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_410.Asttypes.virtual_flag -> Ast_411.Asttypes.virtual_flag = function\n | Ast_410.Asttypes.Virtual -> Ast_411.Asttypes.Virtual\n | Ast_410.Asttypes.Concrete -> Ast_411.Asttypes.Concrete\n\nand copy_include_description :\n Ast_410.Parsetree.include_description ->\n Ast_411.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.include_infos ->\n 'g0 Ast_411.Parsetree.include_infos =\n fun f0\n {\n Ast_410.Parsetree.pincl_mod;\n Ast_410.Parsetree.pincl_loc;\n Ast_410.Parsetree.pincl_attributes;\n } ->\n {\n Ast_411.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_411.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_411.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_410.Parsetree.open_description -> Ast_411.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.open_infos ->\n 'g0 Ast_411.Parsetree.open_infos =\n fun f0\n {\n Ast_410.Parsetree.popen_expr;\n Ast_410.Parsetree.popen_override;\n Ast_410.Parsetree.popen_loc;\n Ast_410.Parsetree.popen_attributes;\n } ->\n {\n Ast_411.Parsetree.popen_expr = f0 popen_expr;\n Ast_411.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_411.Parsetree.popen_loc = copy_location popen_loc;\n Ast_411.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_410.Asttypes.override_flag -> Ast_411.Asttypes.override_flag = function\n | Ast_410.Asttypes.Override -> Ast_411.Asttypes.Override\n | Ast_410.Asttypes.Fresh -> Ast_411.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_410.Parsetree.module_type_declaration ->\n Ast_411.Parsetree.module_type_declaration =\n fun {\n Ast_410.Parsetree.pmtd_name;\n Ast_410.Parsetree.pmtd_type;\n Ast_410.Parsetree.pmtd_attributes;\n Ast_410.Parsetree.pmtd_loc;\n } ->\n {\n Ast_411.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_411.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_411.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_411.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_410.Parsetree.module_substitution ->\n Ast_411.Parsetree.module_substitution =\n fun {\n Ast_410.Parsetree.pms_name;\n Ast_410.Parsetree.pms_manifest;\n Ast_410.Parsetree.pms_attributes;\n Ast_410.Parsetree.pms_loc;\n } ->\n {\n Ast_411.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_411.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_411.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_411.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_410.Parsetree.module_declaration -> Ast_411.Parsetree.module_declaration\n =\n fun {\n Ast_410.Parsetree.pmd_name;\n Ast_410.Parsetree.pmd_type;\n Ast_410.Parsetree.pmd_attributes;\n Ast_410.Parsetree.pmd_loc;\n } ->\n {\n Ast_411.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_411.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_411.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_411.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_410.Parsetree.type_exception -> Ast_411.Parsetree.type_exception =\n fun {\n Ast_410.Parsetree.ptyexn_constructor;\n Ast_410.Parsetree.ptyexn_loc;\n Ast_410.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_411.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_411.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_410.Parsetree.type_extension -> Ast_411.Parsetree.type_extension =\n fun {\n Ast_410.Parsetree.ptyext_path;\n Ast_410.Parsetree.ptyext_params;\n Ast_410.Parsetree.ptyext_constructors;\n Ast_410.Parsetree.ptyext_private;\n Ast_410.Parsetree.ptyext_loc;\n Ast_410.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_411.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_411.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_411.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_411.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_411.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_410.Parsetree.extension_constructor ->\n Ast_411.Parsetree.extension_constructor =\n fun {\n Ast_410.Parsetree.pext_name;\n Ast_410.Parsetree.pext_kind;\n Ast_410.Parsetree.pext_loc;\n Ast_410.Parsetree.pext_attributes;\n } ->\n {\n Ast_411.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_411.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_411.Parsetree.pext_loc = copy_location pext_loc;\n Ast_411.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_410.Parsetree.extension_constructor_kind ->\n Ast_411.Parsetree.extension_constructor_kind = function\n | Ast_410.Parsetree.Pext_decl (x0, x1) ->\n Ast_411.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_410.Parsetree.Pext_rebind x0 ->\n Ast_411.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_410.Parsetree.type_declaration -> Ast_411.Parsetree.type_declaration =\n fun {\n Ast_410.Parsetree.ptype_name;\n Ast_410.Parsetree.ptype_params;\n Ast_410.Parsetree.ptype_cstrs;\n Ast_410.Parsetree.ptype_kind;\n Ast_410.Parsetree.ptype_private;\n Ast_410.Parsetree.ptype_manifest;\n Ast_410.Parsetree.ptype_attributes;\n Ast_410.Parsetree.ptype_loc;\n } ->\n {\n Ast_411.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_411.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_411.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_411.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_411.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_411.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_411.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_411.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_410.Asttypes.private_flag -> Ast_411.Asttypes.private_flag = function\n | Ast_410.Asttypes.Private -> Ast_411.Asttypes.Private\n | Ast_410.Asttypes.Public -> Ast_411.Asttypes.Public\n\nand copy_type_kind : Ast_410.Parsetree.type_kind -> Ast_411.Parsetree.type_kind\n = function\n | Ast_410.Parsetree.Ptype_abstract -> Ast_411.Parsetree.Ptype_abstract\n | Ast_410.Parsetree.Ptype_variant x0 ->\n Ast_411.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_410.Parsetree.Ptype_record x0 ->\n Ast_411.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_410.Parsetree.Ptype_open -> Ast_411.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_410.Parsetree.constructor_declaration ->\n Ast_411.Parsetree.constructor_declaration =\n fun {\n Ast_410.Parsetree.pcd_name;\n Ast_410.Parsetree.pcd_args;\n Ast_410.Parsetree.pcd_res;\n Ast_410.Parsetree.pcd_loc;\n Ast_410.Parsetree.pcd_attributes;\n } ->\n {\n Ast_411.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_411.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_411.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_411.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_411.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_410.Parsetree.constructor_arguments ->\n Ast_411.Parsetree.constructor_arguments = function\n | Ast_410.Parsetree.Pcstr_tuple x0 ->\n Ast_411.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_410.Parsetree.Pcstr_record x0 ->\n Ast_411.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_410.Parsetree.label_declaration -> Ast_411.Parsetree.label_declaration =\n fun {\n Ast_410.Parsetree.pld_name;\n Ast_410.Parsetree.pld_mutable;\n Ast_410.Parsetree.pld_type;\n Ast_410.Parsetree.pld_loc;\n Ast_410.Parsetree.pld_attributes;\n } ->\n {\n Ast_411.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_411.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_411.Parsetree.pld_type = copy_core_type pld_type;\n Ast_411.Parsetree.pld_loc = copy_location pld_loc;\n Ast_411.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_410.Asttypes.mutable_flag -> Ast_411.Asttypes.mutable_flag = function\n | Ast_410.Asttypes.Immutable -> Ast_411.Asttypes.Immutable\n | Ast_410.Asttypes.Mutable -> Ast_411.Asttypes.Mutable\n\nand copy_variance : Ast_410.Asttypes.variance -> Ast_411.Asttypes.variance =\n function\n | Ast_410.Asttypes.Covariant -> Ast_411.Asttypes.Covariant\n | Ast_410.Asttypes.Contravariant -> Ast_411.Asttypes.Contravariant\n | Ast_410.Asttypes.Invariant -> Ast_411.Asttypes.Invariant\n\nand copy_value_description :\n Ast_410.Parsetree.value_description -> Ast_411.Parsetree.value_description =\n fun {\n Ast_410.Parsetree.pval_name;\n Ast_410.Parsetree.pval_type;\n Ast_410.Parsetree.pval_prim;\n Ast_410.Parsetree.pval_attributes;\n Ast_410.Parsetree.pval_loc;\n } ->\n {\n Ast_411.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_411.Parsetree.pval_type = copy_core_type pval_type;\n Ast_411.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_411.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_411.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_410.Parsetree.object_field_desc -> Ast_411.Parsetree.object_field_desc =\n function\n | Ast_410.Parsetree.Otag (x0, x1) ->\n Ast_411.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_410.Parsetree.Oinherit x0 ->\n Ast_411.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_410.Asttypes.arg_label -> Ast_411.Asttypes.arg_label =\n function\n | Ast_410.Asttypes.Nolabel -> Ast_411.Asttypes.Nolabel\n | Ast_410.Asttypes.Labelled x0 -> Ast_411.Asttypes.Labelled x0\n | Ast_410.Asttypes.Optional x0 -> Ast_411.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_410.Asttypes.closed_flag -> Ast_411.Asttypes.closed_flag = function\n | Ast_410.Asttypes.Closed -> Ast_411.Asttypes.Closed\n | Ast_410.Asttypes.Open -> Ast_411.Asttypes.Open\n\nand copy_label : Ast_410.Asttypes.label -> Ast_411.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_410.Asttypes.rec_flag -> Ast_411.Asttypes.rec_flag =\n function\n | Ast_410.Asttypes.Nonrecursive -> Ast_411.Asttypes.Nonrecursive\n | Ast_410.Asttypes.Recursive -> Ast_411.Asttypes.Recursive\n\nand copy_constant : Ast_410.Parsetree.constant -> Ast_411.Parsetree.constant =\n function\n | Ast_410.Parsetree.Pconst_integer (x0, x1) ->\n Ast_411.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_410.Parsetree.Pconst_char x0 -> Ast_411.Parsetree.Pconst_char x0\n | Ast_410.Parsetree.Pconst_string (x0, x1) ->\n Ast_411.Parsetree.Pconst_string\n (x0, Location.none, Option.map (fun x -> x) x1)\n | Ast_410.Parsetree.Pconst_float (x0, x1) ->\n Ast_411.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_410.Asttypes.loc -> 'g0 Ast_411.Asttypes.loc =\n fun f0 { Ast_410.Asttypes.txt; Ast_410.Asttypes.loc } ->\n { Ast_411.Asttypes.txt = f0 txt; Ast_411.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","module From = Ast_410\nmodule To = Ast_409\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.10\" missing_feature\n\nlet map_option f x = match x with None -> None | Some x -> Some (f x)\n\nlet rec copy_toplevel_phrase :\n Ast_410.Parsetree.toplevel_phrase -> Ast_409.Parsetree.toplevel_phrase =\n function\n | Ast_410.Parsetree.Ptop_def x0 ->\n Ast_409.Parsetree.Ptop_def (copy_structure x0)\n | Ast_410.Parsetree.Ptop_dir x0 ->\n Ast_409.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_410.Parsetree.toplevel_directive -> Ast_409.Parsetree.toplevel_directive\n =\n fun {\n Ast_410.Parsetree.pdir_name;\n Ast_410.Parsetree.pdir_arg;\n Ast_410.Parsetree.pdir_loc;\n } ->\n {\n Ast_409.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_409.Parsetree.pdir_arg = map_option copy_directive_argument pdir_arg;\n Ast_409.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_410.Parsetree.directive_argument -> Ast_409.Parsetree.directive_argument\n =\n fun { Ast_410.Parsetree.pdira_desc; Ast_410.Parsetree.pdira_loc } ->\n {\n Ast_409.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_409.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_410.Parsetree.directive_argument_desc ->\n Ast_409.Parsetree.directive_argument_desc = function\n | Ast_410.Parsetree.Pdir_string x0 -> Ast_409.Parsetree.Pdir_string x0\n | Ast_410.Parsetree.Pdir_int (x0, x1) ->\n Ast_409.Parsetree.Pdir_int (x0, map_option (fun x -> x) x1)\n | Ast_410.Parsetree.Pdir_ident x0 ->\n Ast_409.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_410.Parsetree.Pdir_bool x0 -> Ast_409.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_410.Parsetree.expression -> Ast_409.Parsetree.expression =\n fun {\n Ast_410.Parsetree.pexp_desc;\n Ast_410.Parsetree.pexp_loc;\n Ast_410.Parsetree.pexp_loc_stack;\n Ast_410.Parsetree.pexp_attributes;\n } ->\n {\n Ast_409.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_409.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_409.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_409.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_410.Parsetree.expression_desc -> Ast_409.Parsetree.expression_desc =\n function\n | Ast_410.Parsetree.Pexp_ident x0 ->\n Ast_409.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pexp_constant x0 ->\n Ast_409.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_410.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_410.Parsetree.Pexp_function x0 ->\n Ast_409.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_410.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_409.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n map_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_410.Parsetree.Pexp_apply (x0, x1) ->\n Ast_409.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_410.Parsetree.Pexp_match (x0, x1) ->\n Ast_409.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_410.Parsetree.Pexp_try (x0, x1) ->\n Ast_409.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_410.Parsetree.Pexp_tuple x0 ->\n Ast_409.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_410.Parsetree.Pexp_construct (x0, x1) ->\n Ast_409.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, map_option copy_expression x1)\n | Ast_410.Parsetree.Pexp_variant (x0, x1) ->\n Ast_409.Parsetree.Pexp_variant\n (copy_label x0, map_option copy_expression x1)\n | Ast_410.Parsetree.Pexp_record (x0, x1) ->\n Ast_409.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n map_option copy_expression x1 )\n | Ast_410.Parsetree.Pexp_field (x0, x1) ->\n Ast_409.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_410.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_410.Parsetree.Pexp_array x0 ->\n Ast_409.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_410.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, map_option copy_expression x2)\n | Ast_410.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_409.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_while (x0, x1) ->\n Ast_409.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_409.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_410.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_409.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_410.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_coerce\n (copy_expression x0, map_option copy_core_type x1, copy_core_type x2)\n | Ast_410.Parsetree.Pexp_send (x0, x1) ->\n Ast_409.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_410.Parsetree.Pexp_new x0 ->\n Ast_409.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_409.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_override x0 ->\n Ast_409.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_410.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_letmodule\n ( copy_loc\n (function\n | None -> migration_error x0.loc \"anonymous let module\"\n | Some x -> x)\n x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_410.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_409.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_assert x0 ->\n Ast_409.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_410.Parsetree.Pexp_lazy x0 ->\n Ast_409.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_410.Parsetree.Pexp_poly (x0, x1) ->\n Ast_409.Parsetree.Pexp_poly\n (copy_expression x0, map_option copy_core_type x1)\n | Ast_410.Parsetree.Pexp_object x0 ->\n Ast_409.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_410.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_409.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_pack x0 ->\n Ast_409.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_410.Parsetree.Pexp_open (x0, x1) ->\n Ast_409.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_letop x0 ->\n Ast_409.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_410.Parsetree.Pexp_extension x0 ->\n Ast_409.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_410.Parsetree.Pexp_unreachable -> Ast_409.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_410.Parsetree.letop -> Ast_409.Parsetree.letop =\n fun { Ast_410.Parsetree.let_; Ast_410.Parsetree.ands; Ast_410.Parsetree.body } ->\n {\n Ast_409.Parsetree.let_ = copy_binding_op let_;\n Ast_409.Parsetree.ands = List.map copy_binding_op ands;\n Ast_409.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_410.Parsetree.binding_op -> Ast_409.Parsetree.binding_op =\n fun {\n Ast_410.Parsetree.pbop_op;\n Ast_410.Parsetree.pbop_pat;\n Ast_410.Parsetree.pbop_exp;\n Ast_410.Parsetree.pbop_loc;\n } ->\n {\n Ast_409.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_409.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_409.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_409.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_410.Asttypes.direction_flag -> Ast_409.Asttypes.direction_flag =\n function\n | Ast_410.Asttypes.Upto -> Ast_409.Asttypes.Upto\n | Ast_410.Asttypes.Downto -> Ast_409.Asttypes.Downto\n\nand copy_case : Ast_410.Parsetree.case -> Ast_409.Parsetree.case =\n fun {\n Ast_410.Parsetree.pc_lhs;\n Ast_410.Parsetree.pc_guard;\n Ast_410.Parsetree.pc_rhs;\n } ->\n {\n Ast_409.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_409.Parsetree.pc_guard = map_option copy_expression pc_guard;\n Ast_409.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_cases : Ast_410.Parsetree.case list -> Ast_409.Parsetree.cases =\n fun x -> List.map copy_case x\n\nand copy_value_binding :\n Ast_410.Parsetree.value_binding -> Ast_409.Parsetree.value_binding =\n fun {\n Ast_410.Parsetree.pvb_pat;\n Ast_410.Parsetree.pvb_expr;\n Ast_410.Parsetree.pvb_attributes;\n Ast_410.Parsetree.pvb_loc;\n } ->\n {\n Ast_409.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_409.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_409.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_409.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_410.Parsetree.pattern -> Ast_409.Parsetree.pattern =\n fun {\n Ast_410.Parsetree.ppat_desc;\n Ast_410.Parsetree.ppat_loc;\n Ast_410.Parsetree.ppat_loc_stack;\n Ast_410.Parsetree.ppat_attributes;\n } ->\n {\n Ast_409.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_409.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_409.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_409.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_410.Parsetree.pattern_desc -> Ast_409.Parsetree.pattern_desc = function\n | Ast_410.Parsetree.Ppat_any -> Ast_409.Parsetree.Ppat_any\n | Ast_410.Parsetree.Ppat_var x0 ->\n Ast_409.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_410.Parsetree.Ppat_alias (x0, x1) ->\n Ast_409.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_410.Parsetree.Ppat_constant x0 ->\n Ast_409.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_410.Parsetree.Ppat_interval (x0, x1) ->\n Ast_409.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_410.Parsetree.Ppat_tuple x0 ->\n Ast_409.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_410.Parsetree.Ppat_construct (x0, x1) ->\n Ast_409.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, map_option copy_pattern x1)\n | Ast_410.Parsetree.Ppat_variant (x0, x1) ->\n Ast_409.Parsetree.Ppat_variant (copy_label x0, map_option copy_pattern x1)\n | Ast_410.Parsetree.Ppat_record (x0, x1) ->\n Ast_409.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_410.Parsetree.Ppat_array x0 ->\n Ast_409.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_410.Parsetree.Ppat_or (x0, x1) ->\n Ast_409.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_410.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_409.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_410.Parsetree.Ppat_type x0 ->\n Ast_409.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Ppat_lazy x0 ->\n Ast_409.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_410.Parsetree.Ppat_unpack x0 ->\n Ast_409.Parsetree.Ppat_unpack\n (copy_loc\n (function\n | None -> migration_error x0.loc \"anynymous unpack\" | Some x -> x)\n x0)\n | Ast_410.Parsetree.Ppat_exception x0 ->\n Ast_409.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_410.Parsetree.Ppat_extension x0 ->\n Ast_409.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_410.Parsetree.Ppat_open (x0, x1) ->\n Ast_409.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_410.Parsetree.core_type -> Ast_409.Parsetree.core_type\n =\n fun {\n Ast_410.Parsetree.ptyp_desc;\n Ast_410.Parsetree.ptyp_loc;\n Ast_410.Parsetree.ptyp_loc_stack;\n Ast_410.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_409.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_409.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_409.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack : Ast_410.Parsetree.location_stack -> Location.t list =\n fun x -> List.map copy_location x\n\nand copy_core_type_desc :\n Ast_410.Parsetree.core_type_desc -> Ast_409.Parsetree.core_type_desc =\n function\n | Ast_410.Parsetree.Ptyp_any -> Ast_409.Parsetree.Ptyp_any\n | Ast_410.Parsetree.Ptyp_var x0 -> Ast_409.Parsetree.Ptyp_var x0\n | Ast_410.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_409.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_410.Parsetree.Ptyp_tuple x0 ->\n Ast_409.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_410.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_409.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_object (x0, x1) ->\n Ast_409.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_410.Parsetree.Ptyp_class (x0, x1) ->\n Ast_409.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_409.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_410.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_409.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n map_option (fun x -> List.map copy_label x) x2 )\n | Ast_410.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_409.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_package x0 ->\n Ast_409.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_410.Parsetree.Ptyp_extension x0 ->\n Ast_409.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_410.Parsetree.package_type -> Ast_409.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_410.Parsetree.row_field -> Ast_409.Parsetree.row_field\n =\n fun {\n Ast_410.Parsetree.prf_desc;\n Ast_410.Parsetree.prf_loc;\n Ast_410.Parsetree.prf_attributes;\n } ->\n {\n Ast_409.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_409.Parsetree.prf_loc = copy_location prf_loc;\n Ast_409.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_410.Parsetree.row_field_desc -> Ast_409.Parsetree.row_field_desc =\n function\n | Ast_410.Parsetree.Rtag (x0, x1, x2) ->\n Ast_409.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_410.Parsetree.Rinherit x0 ->\n Ast_409.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_410.Parsetree.object_field -> Ast_409.Parsetree.object_field =\n fun {\n Ast_410.Parsetree.pof_desc;\n Ast_410.Parsetree.pof_loc;\n Ast_410.Parsetree.pof_attributes;\n } ->\n {\n Ast_409.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_409.Parsetree.pof_loc = copy_location pof_loc;\n Ast_409.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_410.Parsetree.attributes -> Ast_409.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_410.Parsetree.attribute -> Ast_409.Parsetree.attribute\n =\n fun {\n Ast_410.Parsetree.attr_name;\n Ast_410.Parsetree.attr_payload;\n Ast_410.Parsetree.attr_loc;\n } ->\n {\n Ast_409.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_409.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_409.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_410.Parsetree.payload -> Ast_409.Parsetree.payload =\n function\n | Ast_410.Parsetree.PStr x0 -> Ast_409.Parsetree.PStr (copy_structure x0)\n | Ast_410.Parsetree.PSig x0 -> Ast_409.Parsetree.PSig (copy_signature x0)\n | Ast_410.Parsetree.PTyp x0 -> Ast_409.Parsetree.PTyp (copy_core_type x0)\n | Ast_410.Parsetree.PPat (x0, x1) ->\n Ast_409.Parsetree.PPat (copy_pattern x0, map_option copy_expression x1)\n\nand copy_structure : Ast_410.Parsetree.structure -> Ast_409.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_410.Parsetree.structure_item -> Ast_409.Parsetree.structure_item =\n fun { Ast_410.Parsetree.pstr_desc; Ast_410.Parsetree.pstr_loc } ->\n {\n Ast_409.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_409.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_410.Parsetree.structure_item_desc ->\n Ast_409.Parsetree.structure_item_desc = function\n | Ast_410.Parsetree.Pstr_eval (x0, x1) ->\n Ast_409.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_410.Parsetree.Pstr_value (x0, x1) ->\n Ast_409.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_410.Parsetree.Pstr_primitive x0 ->\n Ast_409.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_410.Parsetree.Pstr_type (x0, x1) ->\n Ast_409.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_410.Parsetree.Pstr_typext x0 ->\n Ast_409.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_410.Parsetree.Pstr_exception x0 ->\n Ast_409.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_410.Parsetree.Pstr_module x0 ->\n Ast_409.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_410.Parsetree.Pstr_recmodule x0 ->\n Ast_409.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_410.Parsetree.Pstr_modtype x0 ->\n Ast_409.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_410.Parsetree.Pstr_open x0 ->\n Ast_409.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_410.Parsetree.Pstr_class x0 ->\n Ast_409.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_410.Parsetree.Pstr_class_type x0 ->\n Ast_409.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_410.Parsetree.Pstr_include x0 ->\n Ast_409.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_410.Parsetree.Pstr_attribute x0 ->\n Ast_409.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pstr_extension (x0, x1) ->\n Ast_409.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_410.Parsetree.include_declaration ->\n Ast_409.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_410.Parsetree.class_declaration -> Ast_409.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_410.Parsetree.class_expr -> Ast_409.Parsetree.class_expr =\n fun {\n Ast_410.Parsetree.pcl_desc;\n Ast_410.Parsetree.pcl_loc;\n Ast_410.Parsetree.pcl_attributes;\n } ->\n {\n Ast_409.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_409.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_409.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_410.Parsetree.class_expr_desc -> Ast_409.Parsetree.class_expr_desc =\n function\n | Ast_410.Parsetree.Pcl_constr (x0, x1) ->\n Ast_409.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Pcl_structure x0 ->\n Ast_409.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_410.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_409.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n map_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_410.Parsetree.Pcl_apply (x0, x1) ->\n Ast_409.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_410.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_409.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_410.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_409.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_410.Parsetree.Pcl_extension x0 ->\n Ast_409.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_410.Parsetree.Pcl_open (x0, x1) ->\n Ast_409.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_410.Parsetree.class_structure -> Ast_409.Parsetree.class_structure =\n fun { Ast_410.Parsetree.pcstr_self; Ast_410.Parsetree.pcstr_fields } ->\n {\n Ast_409.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_409.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_410.Parsetree.class_field -> Ast_409.Parsetree.class_field =\n fun {\n Ast_410.Parsetree.pcf_desc;\n Ast_410.Parsetree.pcf_loc;\n Ast_410.Parsetree.pcf_attributes;\n } ->\n {\n Ast_409.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_409.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_409.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_410.Parsetree.class_field_desc -> Ast_409.Parsetree.class_field_desc =\n function\n | Ast_410.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_409.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n map_option (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_410.Parsetree.Pcf_val x0 ->\n Ast_409.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_410.Parsetree.Pcf_method x0 ->\n Ast_409.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_410.Parsetree.Pcf_constraint x0 ->\n Ast_409.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_410.Parsetree.Pcf_initializer x0 ->\n Ast_409.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_410.Parsetree.Pcf_attribute x0 ->\n Ast_409.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pcf_extension x0 ->\n Ast_409.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_410.Parsetree.class_field_kind -> Ast_409.Parsetree.class_field_kind =\n function\n | Ast_410.Parsetree.Cfk_virtual x0 ->\n Ast_409.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_410.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_409.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_410.Parsetree.open_declaration -> Ast_409.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_410.Parsetree.module_binding -> Ast_409.Parsetree.module_binding =\n fun {\n Ast_410.Parsetree.pmb_name;\n Ast_410.Parsetree.pmb_expr;\n Ast_410.Parsetree.pmb_attributes;\n Ast_410.Parsetree.pmb_loc;\n } ->\n {\n Ast_409.Parsetree.pmb_name =\n copy_loc\n (function\n | Some x -> x\n | None -> migration_error pmb_name.loc \"anonymous module binding\")\n pmb_name;\n Ast_409.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_409.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_409.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_410.Parsetree.module_expr -> Ast_409.Parsetree.module_expr =\n fun {\n Ast_410.Parsetree.pmod_desc;\n Ast_410.Parsetree.pmod_loc;\n Ast_410.Parsetree.pmod_attributes;\n } ->\n {\n Ast_409.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_409.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_409.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_410.Parsetree.module_expr_desc -> Ast_409.Parsetree.module_expr_desc =\n function\n | Ast_410.Parsetree.Pmod_ident x0 ->\n Ast_409.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pmod_structure x0 ->\n Ast_409.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_410.Parsetree.Pmod_functor (x0, x1) ->\n let x, y = copy_functor_parameter x0 in\n Ast_409.Parsetree.Pmod_functor (x, y, copy_module_expr x1)\n | Ast_410.Parsetree.Pmod_apply (x0, x1) ->\n Ast_409.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_410.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_409.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_410.Parsetree.Pmod_unpack x0 ->\n Ast_409.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_410.Parsetree.Pmod_extension x0 ->\n Ast_409.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_410.Parsetree.functor_parameter ->\n string Ast_409.Asttypes.loc * Ast_409.Parsetree.module_type option =\n function\n | Ast_410.Parsetree.Unit -> ({ loc = Location.none; txt = \"*\" }, None)\n | Ast_410.Parsetree.Named (x0, x1) ->\n ( copy_loc (function None -> \"_\" | Some x -> x) x0,\n Some (copy_module_type x1) )\n\nand copy_module_type :\n Ast_410.Parsetree.module_type -> Ast_409.Parsetree.module_type =\n fun {\n Ast_410.Parsetree.pmty_desc;\n Ast_410.Parsetree.pmty_loc;\n Ast_410.Parsetree.pmty_attributes;\n } ->\n {\n Ast_409.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_409.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_409.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_410.Parsetree.module_type_desc -> Ast_409.Parsetree.module_type_desc =\n function\n | Ast_410.Parsetree.Pmty_ident x0 ->\n Ast_409.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pmty_signature x0 ->\n Ast_409.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_410.Parsetree.Pmty_functor (x0, x1) ->\n let x, y = copy_functor_parameter x0 in\n Ast_409.Parsetree.Pmty_functor (x, y, copy_module_type x1)\n | Ast_410.Parsetree.Pmty_with (x0, x1) ->\n Ast_409.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_410.Parsetree.Pmty_typeof x0 ->\n Ast_409.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_410.Parsetree.Pmty_extension x0 ->\n Ast_409.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_410.Parsetree.Pmty_alias x0 ->\n Ast_409.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_410.Parsetree.with_constraint -> Ast_409.Parsetree.with_constraint =\n function\n | Ast_410.Parsetree.Pwith_type (x0, x1) ->\n Ast_409.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_410.Parsetree.Pwith_module (x0, x1) ->\n Ast_409.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_410.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_409.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_410.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_409.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_410.Parsetree.signature -> Ast_409.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_410.Parsetree.signature_item -> Ast_409.Parsetree.signature_item =\n fun { Ast_410.Parsetree.psig_desc; Ast_410.Parsetree.psig_loc } ->\n {\n Ast_409.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_409.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_410.Parsetree.signature_item_desc ->\n Ast_409.Parsetree.signature_item_desc = function\n | Ast_410.Parsetree.Psig_value x0 ->\n Ast_409.Parsetree.Psig_value (copy_value_description x0)\n | Ast_410.Parsetree.Psig_type (x0, x1) ->\n Ast_409.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_410.Parsetree.Psig_typesubst x0 ->\n Ast_409.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_410.Parsetree.Psig_typext x0 ->\n Ast_409.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_410.Parsetree.Psig_exception x0 ->\n Ast_409.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_410.Parsetree.Psig_module x0 ->\n Ast_409.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_410.Parsetree.Psig_modsubst x0 ->\n Ast_409.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_410.Parsetree.Psig_recmodule x0 ->\n Ast_409.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_410.Parsetree.Psig_modtype x0 ->\n Ast_409.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_410.Parsetree.Psig_open x0 ->\n Ast_409.Parsetree.Psig_open (copy_open_description x0)\n | Ast_410.Parsetree.Psig_include x0 ->\n Ast_409.Parsetree.Psig_include (copy_include_description x0)\n | Ast_410.Parsetree.Psig_class x0 ->\n Ast_409.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_410.Parsetree.Psig_class_type x0 ->\n Ast_409.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_410.Parsetree.Psig_attribute x0 ->\n Ast_409.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Psig_extension (x0, x1) ->\n Ast_409.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_410.Parsetree.class_type_declaration ->\n Ast_409.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_410.Parsetree.class_description -> Ast_409.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_410.Parsetree.class_type -> Ast_409.Parsetree.class_type =\n fun {\n Ast_410.Parsetree.pcty_desc;\n Ast_410.Parsetree.pcty_loc;\n Ast_410.Parsetree.pcty_attributes;\n } ->\n {\n Ast_409.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_409.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_409.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_410.Parsetree.class_type_desc -> Ast_409.Parsetree.class_type_desc =\n function\n | Ast_410.Parsetree.Pcty_constr (x0, x1) ->\n Ast_409.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Pcty_signature x0 ->\n Ast_409.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_410.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_409.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_410.Parsetree.Pcty_extension x0 ->\n Ast_409.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_410.Parsetree.Pcty_open (x0, x1) ->\n Ast_409.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_410.Parsetree.class_signature -> Ast_409.Parsetree.class_signature =\n fun { Ast_410.Parsetree.pcsig_self; Ast_410.Parsetree.pcsig_fields } ->\n {\n Ast_409.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_409.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_410.Parsetree.class_type_field -> Ast_409.Parsetree.class_type_field =\n fun {\n Ast_410.Parsetree.pctf_desc;\n Ast_410.Parsetree.pctf_loc;\n Ast_410.Parsetree.pctf_attributes;\n } ->\n {\n Ast_409.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_409.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_409.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_410.Parsetree.class_type_field_desc ->\n Ast_409.Parsetree.class_type_field_desc = function\n | Ast_410.Parsetree.Pctf_inherit x0 ->\n Ast_409.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_410.Parsetree.Pctf_val x0 ->\n Ast_409.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_410.Parsetree.Pctf_method x0 ->\n Ast_409.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_410.Parsetree.Pctf_constraint x0 ->\n Ast_409.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_410.Parsetree.Pctf_attribute x0 ->\n Ast_409.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pctf_extension x0 ->\n Ast_409.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_410.Parsetree.extension -> Ast_409.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.class_infos ->\n 'g0 Ast_409.Parsetree.class_infos =\n fun f0\n {\n Ast_410.Parsetree.pci_virt;\n Ast_410.Parsetree.pci_params;\n Ast_410.Parsetree.pci_name;\n Ast_410.Parsetree.pci_expr;\n Ast_410.Parsetree.pci_loc;\n Ast_410.Parsetree.pci_attributes;\n } ->\n {\n Ast_409.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_409.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_409.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_409.Parsetree.pci_expr = f0 pci_expr;\n Ast_409.Parsetree.pci_loc = copy_location pci_loc;\n Ast_409.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_410.Asttypes.virtual_flag -> Ast_409.Asttypes.virtual_flag = function\n | Ast_410.Asttypes.Virtual -> Ast_409.Asttypes.Virtual\n | Ast_410.Asttypes.Concrete -> Ast_409.Asttypes.Concrete\n\nand copy_include_description :\n Ast_410.Parsetree.include_description ->\n Ast_409.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.include_infos ->\n 'g0 Ast_409.Parsetree.include_infos =\n fun f0\n {\n Ast_410.Parsetree.pincl_mod;\n Ast_410.Parsetree.pincl_loc;\n Ast_410.Parsetree.pincl_attributes;\n } ->\n {\n Ast_409.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_409.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_409.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_410.Parsetree.open_description -> Ast_409.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.open_infos ->\n 'g0 Ast_409.Parsetree.open_infos =\n fun f0\n {\n Ast_410.Parsetree.popen_expr;\n Ast_410.Parsetree.popen_override;\n Ast_410.Parsetree.popen_loc;\n Ast_410.Parsetree.popen_attributes;\n } ->\n {\n Ast_409.Parsetree.popen_expr = f0 popen_expr;\n Ast_409.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_409.Parsetree.popen_loc = copy_location popen_loc;\n Ast_409.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_410.Asttypes.override_flag -> Ast_409.Asttypes.override_flag = function\n | Ast_410.Asttypes.Override -> Ast_409.Asttypes.Override\n | Ast_410.Asttypes.Fresh -> Ast_409.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_410.Parsetree.module_type_declaration ->\n Ast_409.Parsetree.module_type_declaration =\n fun {\n Ast_410.Parsetree.pmtd_name;\n Ast_410.Parsetree.pmtd_type;\n Ast_410.Parsetree.pmtd_attributes;\n Ast_410.Parsetree.pmtd_loc;\n } ->\n {\n Ast_409.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_409.Parsetree.pmtd_type = map_option copy_module_type pmtd_type;\n Ast_409.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_409.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_410.Parsetree.module_substitution ->\n Ast_409.Parsetree.module_substitution =\n fun {\n Ast_410.Parsetree.pms_name;\n Ast_410.Parsetree.pms_manifest;\n Ast_410.Parsetree.pms_attributes;\n Ast_410.Parsetree.pms_loc;\n } ->\n {\n Ast_409.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_409.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_409.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_409.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_410.Parsetree.module_declaration -> Ast_409.Parsetree.module_declaration\n =\n fun {\n Ast_410.Parsetree.pmd_name;\n Ast_410.Parsetree.pmd_type;\n Ast_410.Parsetree.pmd_attributes;\n Ast_410.Parsetree.pmd_loc;\n } ->\n {\n Ast_409.Parsetree.pmd_name =\n copy_loc\n (function\n | None -> migration_error pmd_name.loc \"anonymous module declaration\"\n | Some x -> x)\n pmd_name;\n Ast_409.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_409.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_409.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_410.Parsetree.type_exception -> Ast_409.Parsetree.type_exception =\n fun {\n Ast_410.Parsetree.ptyexn_constructor;\n Ast_410.Parsetree.ptyexn_loc;\n Ast_410.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_409.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_409.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_410.Parsetree.type_extension -> Ast_409.Parsetree.type_extension =\n fun {\n Ast_410.Parsetree.ptyext_path;\n Ast_410.Parsetree.ptyext_params;\n Ast_410.Parsetree.ptyext_constructors;\n Ast_410.Parsetree.ptyext_private;\n Ast_410.Parsetree.ptyext_loc;\n Ast_410.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_409.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_409.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_409.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_409.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_409.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_410.Parsetree.extension_constructor ->\n Ast_409.Parsetree.extension_constructor =\n fun {\n Ast_410.Parsetree.pext_name;\n Ast_410.Parsetree.pext_kind;\n Ast_410.Parsetree.pext_loc;\n Ast_410.Parsetree.pext_attributes;\n } ->\n {\n Ast_409.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_409.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_409.Parsetree.pext_loc = copy_location pext_loc;\n Ast_409.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_410.Parsetree.extension_constructor_kind ->\n Ast_409.Parsetree.extension_constructor_kind = function\n | Ast_410.Parsetree.Pext_decl (x0, x1) ->\n Ast_409.Parsetree.Pext_decl\n (copy_constructor_arguments x0, map_option copy_core_type x1)\n | Ast_410.Parsetree.Pext_rebind x0 ->\n Ast_409.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_410.Parsetree.type_declaration -> Ast_409.Parsetree.type_declaration =\n fun {\n Ast_410.Parsetree.ptype_name;\n Ast_410.Parsetree.ptype_params;\n Ast_410.Parsetree.ptype_cstrs;\n Ast_410.Parsetree.ptype_kind;\n Ast_410.Parsetree.ptype_private;\n Ast_410.Parsetree.ptype_manifest;\n Ast_410.Parsetree.ptype_attributes;\n Ast_410.Parsetree.ptype_loc;\n } ->\n {\n Ast_409.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_409.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_409.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_409.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_409.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_409.Parsetree.ptype_manifest = map_option copy_core_type ptype_manifest;\n Ast_409.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_409.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_410.Asttypes.private_flag -> Ast_409.Asttypes.private_flag = function\n | Ast_410.Asttypes.Private -> Ast_409.Asttypes.Private\n | Ast_410.Asttypes.Public -> Ast_409.Asttypes.Public\n\nand copy_type_kind : Ast_410.Parsetree.type_kind -> Ast_409.Parsetree.type_kind\n = function\n | Ast_410.Parsetree.Ptype_abstract -> Ast_409.Parsetree.Ptype_abstract\n | Ast_410.Parsetree.Ptype_variant x0 ->\n Ast_409.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_410.Parsetree.Ptype_record x0 ->\n Ast_409.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_410.Parsetree.Ptype_open -> Ast_409.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_410.Parsetree.constructor_declaration ->\n Ast_409.Parsetree.constructor_declaration =\n fun {\n Ast_410.Parsetree.pcd_name;\n Ast_410.Parsetree.pcd_args;\n Ast_410.Parsetree.pcd_res;\n Ast_410.Parsetree.pcd_loc;\n Ast_410.Parsetree.pcd_attributes;\n } ->\n {\n Ast_409.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_409.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_409.Parsetree.pcd_res = map_option copy_core_type pcd_res;\n Ast_409.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_409.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_410.Parsetree.constructor_arguments ->\n Ast_409.Parsetree.constructor_arguments = function\n | Ast_410.Parsetree.Pcstr_tuple x0 ->\n Ast_409.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_410.Parsetree.Pcstr_record x0 ->\n Ast_409.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_410.Parsetree.label_declaration -> Ast_409.Parsetree.label_declaration =\n fun {\n Ast_410.Parsetree.pld_name;\n Ast_410.Parsetree.pld_mutable;\n Ast_410.Parsetree.pld_type;\n Ast_410.Parsetree.pld_loc;\n Ast_410.Parsetree.pld_attributes;\n } ->\n {\n Ast_409.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_409.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_409.Parsetree.pld_type = copy_core_type pld_type;\n Ast_409.Parsetree.pld_loc = copy_location pld_loc;\n Ast_409.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_410.Asttypes.mutable_flag -> Ast_409.Asttypes.mutable_flag = function\n | Ast_410.Asttypes.Immutable -> Ast_409.Asttypes.Immutable\n | Ast_410.Asttypes.Mutable -> Ast_409.Asttypes.Mutable\n\nand copy_variance : Ast_410.Asttypes.variance -> Ast_409.Asttypes.variance =\n function\n | Ast_410.Asttypes.Covariant -> Ast_409.Asttypes.Covariant\n | Ast_410.Asttypes.Contravariant -> Ast_409.Asttypes.Contravariant\n | Ast_410.Asttypes.Invariant -> Ast_409.Asttypes.Invariant\n\nand copy_value_description :\n Ast_410.Parsetree.value_description -> Ast_409.Parsetree.value_description =\n fun {\n Ast_410.Parsetree.pval_name;\n Ast_410.Parsetree.pval_type;\n Ast_410.Parsetree.pval_prim;\n Ast_410.Parsetree.pval_attributes;\n Ast_410.Parsetree.pval_loc;\n } ->\n {\n Ast_409.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_409.Parsetree.pval_type = copy_core_type pval_type;\n Ast_409.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_409.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_409.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_410.Parsetree.object_field_desc -> Ast_409.Parsetree.object_field_desc =\n function\n | Ast_410.Parsetree.Otag (x0, x1) ->\n Ast_409.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_410.Parsetree.Oinherit x0 ->\n Ast_409.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_410.Asttypes.arg_label -> Ast_409.Asttypes.arg_label =\n function\n | Ast_410.Asttypes.Nolabel -> Ast_409.Asttypes.Nolabel\n | Ast_410.Asttypes.Labelled x0 -> Ast_409.Asttypes.Labelled x0\n | Ast_410.Asttypes.Optional x0 -> Ast_409.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_410.Asttypes.closed_flag -> Ast_409.Asttypes.closed_flag = function\n | Ast_410.Asttypes.Closed -> Ast_409.Asttypes.Closed\n | Ast_410.Asttypes.Open -> Ast_409.Asttypes.Open\n\nand copy_label : Ast_410.Asttypes.label -> Ast_409.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_410.Asttypes.rec_flag -> Ast_409.Asttypes.rec_flag =\n function\n | Ast_410.Asttypes.Nonrecursive -> Ast_409.Asttypes.Nonrecursive\n | Ast_410.Asttypes.Recursive -> Ast_409.Asttypes.Recursive\n\nand copy_constant : Ast_410.Parsetree.constant -> Ast_409.Parsetree.constant =\n function\n | Ast_410.Parsetree.Pconst_integer (x0, x1) ->\n Ast_409.Parsetree.Pconst_integer (x0, map_option (fun x -> x) x1)\n | Ast_410.Parsetree.Pconst_char x0 -> Ast_409.Parsetree.Pconst_char x0\n | Ast_410.Parsetree.Pconst_string (x0, x1) ->\n Ast_409.Parsetree.Pconst_string (x0, map_option (fun x -> x) x1)\n | Ast_410.Parsetree.Pconst_float (x0, x1) ->\n Ast_409.Parsetree.Pconst_float (x0, map_option (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_410.Asttypes.loc -> 'g0 Ast_409.Asttypes.loc =\n fun f0 { Ast_410.Asttypes.txt; Ast_410.Asttypes.loc } ->\n { Ast_409.Asttypes.txt = f0 txt; Ast_409.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n\nlet copy_expr = copy_expression\nlet copy_pat = copy_pattern\nlet copy_typ = copy_core_type\n","module From = Ast_409\nmodule To = Ast_410\n\nlet map_option f x = match x with None -> None | Some x -> Some (f x)\n\nlet rec copy_toplevel_phrase :\n Ast_409.Parsetree.toplevel_phrase -> Ast_410.Parsetree.toplevel_phrase =\n function\n | Ast_409.Parsetree.Ptop_def x0 ->\n Ast_410.Parsetree.Ptop_def (copy_structure x0)\n | Ast_409.Parsetree.Ptop_dir x0 ->\n Ast_410.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_409.Parsetree.toplevel_directive -> Ast_410.Parsetree.toplevel_directive\n =\n fun {\n Ast_409.Parsetree.pdir_name;\n Ast_409.Parsetree.pdir_arg;\n Ast_409.Parsetree.pdir_loc;\n } ->\n {\n Ast_410.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_410.Parsetree.pdir_arg = map_option copy_directive_argument pdir_arg;\n Ast_410.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_409.Parsetree.directive_argument -> Ast_410.Parsetree.directive_argument\n =\n fun { Ast_409.Parsetree.pdira_desc; Ast_409.Parsetree.pdira_loc } ->\n {\n Ast_410.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_410.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_409.Parsetree.directive_argument_desc ->\n Ast_410.Parsetree.directive_argument_desc = function\n | Ast_409.Parsetree.Pdir_string x0 -> Ast_410.Parsetree.Pdir_string x0\n | Ast_409.Parsetree.Pdir_int (x0, x1) ->\n Ast_410.Parsetree.Pdir_int (x0, map_option (fun x -> x) x1)\n | Ast_409.Parsetree.Pdir_ident x0 ->\n Ast_410.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_409.Parsetree.Pdir_bool x0 -> Ast_410.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_409.Parsetree.expression -> Ast_410.Parsetree.expression =\n fun {\n Ast_409.Parsetree.pexp_desc;\n Ast_409.Parsetree.pexp_loc;\n Ast_409.Parsetree.pexp_loc_stack;\n Ast_409.Parsetree.pexp_attributes;\n } ->\n {\n Ast_410.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_410.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_410.Parsetree.pexp_loc_stack = List.map copy_location pexp_loc_stack;\n Ast_410.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_409.Parsetree.expression_desc -> Ast_410.Parsetree.expression_desc =\n function\n | Ast_409.Parsetree.Pexp_ident x0 ->\n Ast_410.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pexp_constant x0 ->\n Ast_410.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_409.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_function x0 ->\n Ast_410.Parsetree.Pexp_function (copy_cases x0)\n | Ast_409.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_410.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n map_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_409.Parsetree.Pexp_apply (x0, x1) ->\n Ast_410.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_409.Parsetree.Pexp_match (x0, x1) ->\n Ast_410.Parsetree.Pexp_match (copy_expression x0, copy_cases x1)\n | Ast_409.Parsetree.Pexp_try (x0, x1) ->\n Ast_410.Parsetree.Pexp_try (copy_expression x0, copy_cases x1)\n | Ast_409.Parsetree.Pexp_tuple x0 ->\n Ast_410.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_409.Parsetree.Pexp_construct (x0, x1) ->\n Ast_410.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, map_option copy_expression x1)\n | Ast_409.Parsetree.Pexp_variant (x0, x1) ->\n Ast_410.Parsetree.Pexp_variant\n (copy_label x0, map_option copy_expression x1)\n | Ast_409.Parsetree.Pexp_record (x0, x1) ->\n Ast_410.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n map_option copy_expression x1 )\n | Ast_409.Parsetree.Pexp_field (x0, x1) ->\n Ast_410.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_409.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_array x0 ->\n Ast_410.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_409.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, map_option copy_expression x2)\n | Ast_409.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_410.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_while (x0, x1) ->\n Ast_410.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_410.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_409.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_410.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_409.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_coerce\n (copy_expression x0, map_option copy_core_type x1, copy_core_type x2)\n | Ast_409.Parsetree.Pexp_send (x0, x1) ->\n Ast_410.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_409.Parsetree.Pexp_new x0 ->\n Ast_410.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_410.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_override x0 ->\n Ast_410.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_409.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> Some x) x0, copy_module_expr x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_410.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_assert x0 ->\n Ast_410.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_409.Parsetree.Pexp_lazy x0 ->\n Ast_410.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_409.Parsetree.Pexp_poly (x0, x1) ->\n Ast_410.Parsetree.Pexp_poly\n (copy_expression x0, map_option copy_core_type x1)\n | Ast_409.Parsetree.Pexp_object x0 ->\n Ast_410.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_409.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_410.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_pack x0 ->\n Ast_410.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_409.Parsetree.Pexp_open (x0, x1) ->\n Ast_410.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_letop x0 ->\n Ast_410.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_409.Parsetree.Pexp_extension x0 ->\n Ast_410.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_409.Parsetree.Pexp_unreachable -> Ast_410.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_409.Parsetree.letop -> Ast_410.Parsetree.letop =\n fun { Ast_409.Parsetree.let_; Ast_409.Parsetree.ands; Ast_409.Parsetree.body } ->\n {\n Ast_410.Parsetree.let_ = copy_binding_op let_;\n Ast_410.Parsetree.ands = List.map copy_binding_op ands;\n Ast_410.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_409.Parsetree.binding_op -> Ast_410.Parsetree.binding_op =\n fun {\n Ast_409.Parsetree.pbop_op;\n Ast_409.Parsetree.pbop_pat;\n Ast_409.Parsetree.pbop_exp;\n Ast_409.Parsetree.pbop_loc;\n } ->\n {\n Ast_410.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_410.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_410.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_410.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_409.Asttypes.direction_flag -> Ast_410.Asttypes.direction_flag =\n function\n | Ast_409.Asttypes.Upto -> Ast_410.Asttypes.Upto\n | Ast_409.Asttypes.Downto -> Ast_410.Asttypes.Downto\n\nand copy_cases : Ast_409.Parsetree.cases -> Ast_410.Parsetree.case list =\n fun x -> List.map copy_case x\n\nand copy_case : Ast_409.Parsetree.case -> Ast_410.Parsetree.case =\n fun {\n Ast_409.Parsetree.pc_lhs;\n Ast_409.Parsetree.pc_guard;\n Ast_409.Parsetree.pc_rhs;\n } ->\n {\n Ast_410.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_410.Parsetree.pc_guard = map_option copy_expression pc_guard;\n Ast_410.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_409.Parsetree.value_binding -> Ast_410.Parsetree.value_binding =\n fun {\n Ast_409.Parsetree.pvb_pat;\n Ast_409.Parsetree.pvb_expr;\n Ast_409.Parsetree.pvb_attributes;\n Ast_409.Parsetree.pvb_loc;\n } ->\n {\n Ast_410.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_410.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_410.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_410.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_409.Parsetree.pattern -> Ast_410.Parsetree.pattern =\n fun {\n Ast_409.Parsetree.ppat_desc;\n Ast_409.Parsetree.ppat_loc;\n Ast_409.Parsetree.ppat_loc_stack;\n Ast_409.Parsetree.ppat_attributes;\n } ->\n {\n Ast_410.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_410.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_410.Parsetree.ppat_loc_stack = List.map copy_location ppat_loc_stack;\n Ast_410.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_409.Parsetree.pattern_desc -> Ast_410.Parsetree.pattern_desc = function\n | Ast_409.Parsetree.Ppat_any -> Ast_410.Parsetree.Ppat_any\n | Ast_409.Parsetree.Ppat_var x0 ->\n Ast_410.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_409.Parsetree.Ppat_alias (x0, x1) ->\n Ast_410.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_409.Parsetree.Ppat_constant x0 ->\n Ast_410.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_409.Parsetree.Ppat_interval (x0, x1) ->\n Ast_410.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_409.Parsetree.Ppat_tuple x0 ->\n Ast_410.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_409.Parsetree.Ppat_construct (x0, x1) ->\n Ast_410.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, map_option copy_pattern x1)\n | Ast_409.Parsetree.Ppat_variant (x0, x1) ->\n Ast_410.Parsetree.Ppat_variant (copy_label x0, map_option copy_pattern x1)\n | Ast_409.Parsetree.Ppat_record (x0, x1) ->\n Ast_410.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_409.Parsetree.Ppat_array x0 ->\n Ast_410.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_409.Parsetree.Ppat_or (x0, x1) ->\n Ast_410.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_409.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_410.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_409.Parsetree.Ppat_type x0 ->\n Ast_410.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Ppat_lazy x0 ->\n Ast_410.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_409.Parsetree.Ppat_unpack x0 ->\n Ast_410.Parsetree.Ppat_unpack (copy_loc (fun x -> Some x) x0)\n | Ast_409.Parsetree.Ppat_exception x0 ->\n Ast_410.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_409.Parsetree.Ppat_extension x0 ->\n Ast_410.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_409.Parsetree.Ppat_open (x0, x1) ->\n Ast_410.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_409.Parsetree.core_type -> Ast_410.Parsetree.core_type\n =\n fun {\n Ast_409.Parsetree.ptyp_desc;\n Ast_409.Parsetree.ptyp_loc;\n Ast_409.Parsetree.ptyp_loc_stack;\n Ast_409.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_410.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_410.Parsetree.ptyp_loc_stack = List.map copy_location ptyp_loc_stack;\n Ast_410.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n Ast_409.Parsetree.core_type_desc -> Ast_410.Parsetree.core_type_desc =\n function\n | Ast_409.Parsetree.Ptyp_any -> Ast_410.Parsetree.Ptyp_any\n | Ast_409.Parsetree.Ptyp_var x0 -> Ast_410.Parsetree.Ptyp_var x0\n | Ast_409.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_410.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_409.Parsetree.Ptyp_tuple x0 ->\n Ast_410.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_409.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_410.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_object (x0, x1) ->\n Ast_410.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_409.Parsetree.Ptyp_class (x0, x1) ->\n Ast_410.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_410.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_409.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_410.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n map_option (fun x -> List.map copy_label x) x2 )\n | Ast_409.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_410.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_package x0 ->\n Ast_410.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_409.Parsetree.Ptyp_extension x0 ->\n Ast_410.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_409.Parsetree.package_type -> Ast_410.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_409.Parsetree.row_field -> Ast_410.Parsetree.row_field\n =\n fun {\n Ast_409.Parsetree.prf_desc;\n Ast_409.Parsetree.prf_loc;\n Ast_409.Parsetree.prf_attributes;\n } ->\n {\n Ast_410.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_410.Parsetree.prf_loc = copy_location prf_loc;\n Ast_410.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_409.Parsetree.row_field_desc -> Ast_410.Parsetree.row_field_desc =\n function\n | Ast_409.Parsetree.Rtag (x0, x1, x2) ->\n Ast_410.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_409.Parsetree.Rinherit x0 ->\n Ast_410.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_409.Parsetree.object_field -> Ast_410.Parsetree.object_field =\n fun {\n Ast_409.Parsetree.pof_desc;\n Ast_409.Parsetree.pof_loc;\n Ast_409.Parsetree.pof_attributes;\n } ->\n {\n Ast_410.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_410.Parsetree.pof_loc = copy_location pof_loc;\n Ast_410.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_409.Parsetree.attributes -> Ast_410.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_409.Parsetree.attribute -> Ast_410.Parsetree.attribute\n =\n fun {\n Ast_409.Parsetree.attr_name;\n Ast_409.Parsetree.attr_payload;\n Ast_409.Parsetree.attr_loc;\n } ->\n {\n Ast_410.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_410.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_410.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_409.Parsetree.payload -> Ast_410.Parsetree.payload =\n function\n | Ast_409.Parsetree.PStr x0 -> Ast_410.Parsetree.PStr (copy_structure x0)\n | Ast_409.Parsetree.PSig x0 -> Ast_410.Parsetree.PSig (copy_signature x0)\n | Ast_409.Parsetree.PTyp x0 -> Ast_410.Parsetree.PTyp (copy_core_type x0)\n | Ast_409.Parsetree.PPat (x0, x1) ->\n Ast_410.Parsetree.PPat (copy_pattern x0, map_option copy_expression x1)\n\nand copy_structure : Ast_409.Parsetree.structure -> Ast_410.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_409.Parsetree.structure_item -> Ast_410.Parsetree.structure_item =\n fun { Ast_409.Parsetree.pstr_desc; Ast_409.Parsetree.pstr_loc } ->\n {\n Ast_410.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_410.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_409.Parsetree.structure_item_desc ->\n Ast_410.Parsetree.structure_item_desc = function\n | Ast_409.Parsetree.Pstr_eval (x0, x1) ->\n Ast_410.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_409.Parsetree.Pstr_value (x0, x1) ->\n Ast_410.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_409.Parsetree.Pstr_primitive x0 ->\n Ast_410.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_409.Parsetree.Pstr_type (x0, x1) ->\n Ast_410.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_409.Parsetree.Pstr_typext x0 ->\n Ast_410.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_409.Parsetree.Pstr_exception x0 ->\n Ast_410.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_409.Parsetree.Pstr_module x0 ->\n Ast_410.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_409.Parsetree.Pstr_recmodule x0 ->\n Ast_410.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_409.Parsetree.Pstr_modtype x0 ->\n Ast_410.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_409.Parsetree.Pstr_open x0 ->\n Ast_410.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_409.Parsetree.Pstr_class x0 ->\n Ast_410.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_409.Parsetree.Pstr_class_type x0 ->\n Ast_410.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_409.Parsetree.Pstr_include x0 ->\n Ast_410.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_409.Parsetree.Pstr_attribute x0 ->\n Ast_410.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pstr_extension (x0, x1) ->\n Ast_410.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_409.Parsetree.include_declaration ->\n Ast_410.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_409.Parsetree.class_declaration -> Ast_410.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_409.Parsetree.class_expr -> Ast_410.Parsetree.class_expr =\n fun {\n Ast_409.Parsetree.pcl_desc;\n Ast_409.Parsetree.pcl_loc;\n Ast_409.Parsetree.pcl_attributes;\n } ->\n {\n Ast_410.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_410.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_410.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_409.Parsetree.class_expr_desc -> Ast_410.Parsetree.class_expr_desc =\n function\n | Ast_409.Parsetree.Pcl_constr (x0, x1) ->\n Ast_410.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Pcl_structure x0 ->\n Ast_410.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_409.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_410.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n map_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_409.Parsetree.Pcl_apply (x0, x1) ->\n Ast_410.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_409.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_410.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_409.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_410.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_409.Parsetree.Pcl_extension x0 ->\n Ast_410.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_409.Parsetree.Pcl_open (x0, x1) ->\n Ast_410.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_409.Parsetree.class_structure -> Ast_410.Parsetree.class_structure =\n fun { Ast_409.Parsetree.pcstr_self; Ast_409.Parsetree.pcstr_fields } ->\n {\n Ast_410.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_410.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_409.Parsetree.class_field -> Ast_410.Parsetree.class_field =\n fun {\n Ast_409.Parsetree.pcf_desc;\n Ast_409.Parsetree.pcf_loc;\n Ast_409.Parsetree.pcf_attributes;\n } ->\n {\n Ast_410.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_410.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_410.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_409.Parsetree.class_field_desc -> Ast_410.Parsetree.class_field_desc =\n function\n | Ast_409.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_410.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n map_option (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_409.Parsetree.Pcf_val x0 ->\n Ast_410.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_409.Parsetree.Pcf_method x0 ->\n Ast_410.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_409.Parsetree.Pcf_constraint x0 ->\n Ast_410.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_409.Parsetree.Pcf_initializer x0 ->\n Ast_410.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_409.Parsetree.Pcf_attribute x0 ->\n Ast_410.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pcf_extension x0 ->\n Ast_410.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_409.Parsetree.class_field_kind -> Ast_410.Parsetree.class_field_kind =\n function\n | Ast_409.Parsetree.Cfk_virtual x0 ->\n Ast_410.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_409.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_410.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_409.Parsetree.open_declaration -> Ast_410.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_409.Parsetree.module_binding -> Ast_410.Parsetree.module_binding =\n fun {\n Ast_409.Parsetree.pmb_name;\n Ast_409.Parsetree.pmb_expr;\n Ast_409.Parsetree.pmb_attributes;\n Ast_409.Parsetree.pmb_loc;\n } ->\n {\n Ast_410.Parsetree.pmb_name = copy_loc (fun x -> Some x) pmb_name;\n Ast_410.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_410.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_410.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_409.Parsetree.module_expr -> Ast_410.Parsetree.module_expr =\n fun {\n Ast_409.Parsetree.pmod_desc;\n Ast_409.Parsetree.pmod_loc;\n Ast_409.Parsetree.pmod_attributes;\n } ->\n {\n Ast_410.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_410.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_410.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_409.Parsetree.module_expr_desc -> Ast_410.Parsetree.module_expr_desc =\n function\n | Ast_409.Parsetree.Pmod_ident x0 ->\n Ast_410.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pmod_structure x0 ->\n Ast_410.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_409.Parsetree.Pmod_functor (x0, x1, x2) ->\n Ast_410.Parsetree.Pmod_functor\n ( (match (x0.txt, x1) with\n | \"*\", None -> Unit\n | \"_\", Some mt ->\n Named (copy_loc (fun _ -> None) x0, copy_module_type mt)\n | _, Some mt ->\n Named (copy_loc (fun x -> Some x) x0, copy_module_type mt)\n | _ -> assert false),\n copy_module_expr x2 )\n | Ast_409.Parsetree.Pmod_apply (x0, x1) ->\n Ast_410.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_409.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_410.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_409.Parsetree.Pmod_unpack x0 ->\n Ast_410.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_409.Parsetree.Pmod_extension x0 ->\n Ast_410.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type :\n Ast_409.Parsetree.module_type -> Ast_410.Parsetree.module_type =\n fun {\n Ast_409.Parsetree.pmty_desc;\n Ast_409.Parsetree.pmty_loc;\n Ast_409.Parsetree.pmty_attributes;\n } ->\n {\n Ast_410.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_410.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_410.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_409.Parsetree.module_type_desc -> Ast_410.Parsetree.module_type_desc =\n function\n | Ast_409.Parsetree.Pmty_ident x0 ->\n Ast_410.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pmty_signature x0 ->\n Ast_410.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_409.Parsetree.Pmty_functor (x0, x1, x2) ->\n Ast_410.Parsetree.Pmty_functor\n ( (match (x0.txt, x1) with\n | \"*\", None -> Unit\n | \"_\", Some mt ->\n Named (copy_loc (fun _ -> None) x0, copy_module_type mt)\n | _, Some mt ->\n Named (copy_loc (fun x -> Some x) x0, copy_module_type mt)\n | _ -> assert false),\n copy_module_type x2 )\n | Ast_409.Parsetree.Pmty_with (x0, x1) ->\n Ast_410.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_409.Parsetree.Pmty_typeof x0 ->\n Ast_410.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_409.Parsetree.Pmty_extension x0 ->\n Ast_410.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_409.Parsetree.Pmty_alias x0 ->\n Ast_410.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_409.Parsetree.with_constraint -> Ast_410.Parsetree.with_constraint =\n function\n | Ast_409.Parsetree.Pwith_type (x0, x1) ->\n Ast_410.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_409.Parsetree.Pwith_module (x0, x1) ->\n Ast_410.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_409.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_410.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_409.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_410.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_409.Parsetree.signature -> Ast_410.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_409.Parsetree.signature_item -> Ast_410.Parsetree.signature_item =\n fun { Ast_409.Parsetree.psig_desc; Ast_409.Parsetree.psig_loc } ->\n {\n Ast_410.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_410.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_409.Parsetree.signature_item_desc ->\n Ast_410.Parsetree.signature_item_desc = function\n | Ast_409.Parsetree.Psig_value x0 ->\n Ast_410.Parsetree.Psig_value (copy_value_description x0)\n | Ast_409.Parsetree.Psig_type (x0, x1) ->\n Ast_410.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_409.Parsetree.Psig_typesubst x0 ->\n Ast_410.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_409.Parsetree.Psig_typext x0 ->\n Ast_410.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_409.Parsetree.Psig_exception x0 ->\n Ast_410.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_409.Parsetree.Psig_module x0 ->\n Ast_410.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_409.Parsetree.Psig_modsubst x0 ->\n Ast_410.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_409.Parsetree.Psig_recmodule x0 ->\n Ast_410.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_409.Parsetree.Psig_modtype x0 ->\n Ast_410.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_409.Parsetree.Psig_open x0 ->\n Ast_410.Parsetree.Psig_open (copy_open_description x0)\n | Ast_409.Parsetree.Psig_include x0 ->\n Ast_410.Parsetree.Psig_include (copy_include_description x0)\n | Ast_409.Parsetree.Psig_class x0 ->\n Ast_410.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_409.Parsetree.Psig_class_type x0 ->\n Ast_410.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_409.Parsetree.Psig_attribute x0 ->\n Ast_410.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Psig_extension (x0, x1) ->\n Ast_410.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_409.Parsetree.class_type_declaration ->\n Ast_410.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_409.Parsetree.class_description -> Ast_410.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_409.Parsetree.class_type -> Ast_410.Parsetree.class_type =\n fun {\n Ast_409.Parsetree.pcty_desc;\n Ast_409.Parsetree.pcty_loc;\n Ast_409.Parsetree.pcty_attributes;\n } ->\n {\n Ast_410.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_410.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_410.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_409.Parsetree.class_type_desc -> Ast_410.Parsetree.class_type_desc =\n function\n | Ast_409.Parsetree.Pcty_constr (x0, x1) ->\n Ast_410.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Pcty_signature x0 ->\n Ast_410.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_409.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_410.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_409.Parsetree.Pcty_extension x0 ->\n Ast_410.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_409.Parsetree.Pcty_open (x0, x1) ->\n Ast_410.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_409.Parsetree.class_signature -> Ast_410.Parsetree.class_signature =\n fun { Ast_409.Parsetree.pcsig_self; Ast_409.Parsetree.pcsig_fields } ->\n {\n Ast_410.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_410.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_409.Parsetree.class_type_field -> Ast_410.Parsetree.class_type_field =\n fun {\n Ast_409.Parsetree.pctf_desc;\n Ast_409.Parsetree.pctf_loc;\n Ast_409.Parsetree.pctf_attributes;\n } ->\n {\n Ast_410.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_410.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_410.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_409.Parsetree.class_type_field_desc ->\n Ast_410.Parsetree.class_type_field_desc = function\n | Ast_409.Parsetree.Pctf_inherit x0 ->\n Ast_410.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_409.Parsetree.Pctf_val x0 ->\n Ast_410.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_409.Parsetree.Pctf_method x0 ->\n Ast_410.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_409.Parsetree.Pctf_constraint x0 ->\n Ast_410.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_409.Parsetree.Pctf_attribute x0 ->\n Ast_410.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pctf_extension x0 ->\n Ast_410.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_409.Parsetree.extension -> Ast_410.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.class_infos ->\n 'g0 Ast_410.Parsetree.class_infos =\n fun f0\n {\n Ast_409.Parsetree.pci_virt;\n Ast_409.Parsetree.pci_params;\n Ast_409.Parsetree.pci_name;\n Ast_409.Parsetree.pci_expr;\n Ast_409.Parsetree.pci_loc;\n Ast_409.Parsetree.pci_attributes;\n } ->\n {\n Ast_410.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_410.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_410.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_410.Parsetree.pci_expr = f0 pci_expr;\n Ast_410.Parsetree.pci_loc = copy_location pci_loc;\n Ast_410.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_409.Asttypes.virtual_flag -> Ast_410.Asttypes.virtual_flag = function\n | Ast_409.Asttypes.Virtual -> Ast_410.Asttypes.Virtual\n | Ast_409.Asttypes.Concrete -> Ast_410.Asttypes.Concrete\n\nand copy_include_description :\n Ast_409.Parsetree.include_description ->\n Ast_410.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.include_infos ->\n 'g0 Ast_410.Parsetree.include_infos =\n fun f0\n {\n Ast_409.Parsetree.pincl_mod;\n Ast_409.Parsetree.pincl_loc;\n Ast_409.Parsetree.pincl_attributes;\n } ->\n {\n Ast_410.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_410.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_410.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_409.Parsetree.open_description -> Ast_410.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.open_infos ->\n 'g0 Ast_410.Parsetree.open_infos =\n fun f0\n {\n Ast_409.Parsetree.popen_expr;\n Ast_409.Parsetree.popen_override;\n Ast_409.Parsetree.popen_loc;\n Ast_409.Parsetree.popen_attributes;\n } ->\n {\n Ast_410.Parsetree.popen_expr = f0 popen_expr;\n Ast_410.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_410.Parsetree.popen_loc = copy_location popen_loc;\n Ast_410.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_409.Asttypes.override_flag -> Ast_410.Asttypes.override_flag = function\n | Ast_409.Asttypes.Override -> Ast_410.Asttypes.Override\n | Ast_409.Asttypes.Fresh -> Ast_410.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_409.Parsetree.module_type_declaration ->\n Ast_410.Parsetree.module_type_declaration =\n fun {\n Ast_409.Parsetree.pmtd_name;\n Ast_409.Parsetree.pmtd_type;\n Ast_409.Parsetree.pmtd_attributes;\n Ast_409.Parsetree.pmtd_loc;\n } ->\n {\n Ast_410.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_410.Parsetree.pmtd_type = map_option copy_module_type pmtd_type;\n Ast_410.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_410.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_409.Parsetree.module_substitution ->\n Ast_410.Parsetree.module_substitution =\n fun {\n Ast_409.Parsetree.pms_name;\n Ast_409.Parsetree.pms_manifest;\n Ast_409.Parsetree.pms_attributes;\n Ast_409.Parsetree.pms_loc;\n } ->\n {\n Ast_410.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_410.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_410.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_410.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_409.Parsetree.module_declaration -> Ast_410.Parsetree.module_declaration\n =\n fun {\n Ast_409.Parsetree.pmd_name;\n Ast_409.Parsetree.pmd_type;\n Ast_409.Parsetree.pmd_attributes;\n Ast_409.Parsetree.pmd_loc;\n } ->\n {\n Ast_410.Parsetree.pmd_name = copy_loc (fun x -> Some x) pmd_name;\n Ast_410.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_410.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_410.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_409.Parsetree.type_exception -> Ast_410.Parsetree.type_exception =\n fun {\n Ast_409.Parsetree.ptyexn_constructor;\n Ast_409.Parsetree.ptyexn_loc;\n Ast_409.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_410.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_410.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_409.Parsetree.type_extension -> Ast_410.Parsetree.type_extension =\n fun {\n Ast_409.Parsetree.ptyext_path;\n Ast_409.Parsetree.ptyext_params;\n Ast_409.Parsetree.ptyext_constructors;\n Ast_409.Parsetree.ptyext_private;\n Ast_409.Parsetree.ptyext_loc;\n Ast_409.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_410.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_410.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_410.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_410.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_410.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_409.Parsetree.extension_constructor ->\n Ast_410.Parsetree.extension_constructor =\n fun {\n Ast_409.Parsetree.pext_name;\n Ast_409.Parsetree.pext_kind;\n Ast_409.Parsetree.pext_loc;\n Ast_409.Parsetree.pext_attributes;\n } ->\n {\n Ast_410.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_410.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_410.Parsetree.pext_loc = copy_location pext_loc;\n Ast_410.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_409.Parsetree.extension_constructor_kind ->\n Ast_410.Parsetree.extension_constructor_kind = function\n | Ast_409.Parsetree.Pext_decl (x0, x1) ->\n Ast_410.Parsetree.Pext_decl\n (copy_constructor_arguments x0, map_option copy_core_type x1)\n | Ast_409.Parsetree.Pext_rebind x0 ->\n Ast_410.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_409.Parsetree.type_declaration -> Ast_410.Parsetree.type_declaration =\n fun {\n Ast_409.Parsetree.ptype_name;\n Ast_409.Parsetree.ptype_params;\n Ast_409.Parsetree.ptype_cstrs;\n Ast_409.Parsetree.ptype_kind;\n Ast_409.Parsetree.ptype_private;\n Ast_409.Parsetree.ptype_manifest;\n Ast_409.Parsetree.ptype_attributes;\n Ast_409.Parsetree.ptype_loc;\n } ->\n {\n Ast_410.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_410.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_410.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_410.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_410.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_410.Parsetree.ptype_manifest = map_option copy_core_type ptype_manifest;\n Ast_410.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_410.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_409.Asttypes.private_flag -> Ast_410.Asttypes.private_flag = function\n | Ast_409.Asttypes.Private -> Ast_410.Asttypes.Private\n | Ast_409.Asttypes.Public -> Ast_410.Asttypes.Public\n\nand copy_type_kind : Ast_409.Parsetree.type_kind -> Ast_410.Parsetree.type_kind\n = function\n | Ast_409.Parsetree.Ptype_abstract -> Ast_410.Parsetree.Ptype_abstract\n | Ast_409.Parsetree.Ptype_variant x0 ->\n Ast_410.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_409.Parsetree.Ptype_record x0 ->\n Ast_410.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_409.Parsetree.Ptype_open -> Ast_410.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_409.Parsetree.constructor_declaration ->\n Ast_410.Parsetree.constructor_declaration =\n fun {\n Ast_409.Parsetree.pcd_name;\n Ast_409.Parsetree.pcd_args;\n Ast_409.Parsetree.pcd_res;\n Ast_409.Parsetree.pcd_loc;\n Ast_409.Parsetree.pcd_attributes;\n } ->\n {\n Ast_410.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_410.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_410.Parsetree.pcd_res = map_option copy_core_type pcd_res;\n Ast_410.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_410.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_409.Parsetree.constructor_arguments ->\n Ast_410.Parsetree.constructor_arguments = function\n | Ast_409.Parsetree.Pcstr_tuple x0 ->\n Ast_410.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_409.Parsetree.Pcstr_record x0 ->\n Ast_410.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_409.Parsetree.label_declaration -> Ast_410.Parsetree.label_declaration =\n fun {\n Ast_409.Parsetree.pld_name;\n Ast_409.Parsetree.pld_mutable;\n Ast_409.Parsetree.pld_type;\n Ast_409.Parsetree.pld_loc;\n Ast_409.Parsetree.pld_attributes;\n } ->\n {\n Ast_410.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_410.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_410.Parsetree.pld_type = copy_core_type pld_type;\n Ast_410.Parsetree.pld_loc = copy_location pld_loc;\n Ast_410.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_409.Asttypes.mutable_flag -> Ast_410.Asttypes.mutable_flag = function\n | Ast_409.Asttypes.Immutable -> Ast_410.Asttypes.Immutable\n | Ast_409.Asttypes.Mutable -> Ast_410.Asttypes.Mutable\n\nand copy_variance : Ast_409.Asttypes.variance -> Ast_410.Asttypes.variance =\n function\n | Ast_409.Asttypes.Covariant -> Ast_410.Asttypes.Covariant\n | Ast_409.Asttypes.Contravariant -> Ast_410.Asttypes.Contravariant\n | Ast_409.Asttypes.Invariant -> Ast_410.Asttypes.Invariant\n\nand copy_value_description :\n Ast_409.Parsetree.value_description -> Ast_410.Parsetree.value_description =\n fun {\n Ast_409.Parsetree.pval_name;\n Ast_409.Parsetree.pval_type;\n Ast_409.Parsetree.pval_prim;\n Ast_409.Parsetree.pval_attributes;\n Ast_409.Parsetree.pval_loc;\n } ->\n {\n Ast_410.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_410.Parsetree.pval_type = copy_core_type pval_type;\n Ast_410.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_410.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_410.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_409.Parsetree.object_field_desc -> Ast_410.Parsetree.object_field_desc =\n function\n | Ast_409.Parsetree.Otag (x0, x1) ->\n Ast_410.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_409.Parsetree.Oinherit x0 ->\n Ast_410.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_409.Asttypes.arg_label -> Ast_410.Asttypes.arg_label =\n function\n | Ast_409.Asttypes.Nolabel -> Ast_410.Asttypes.Nolabel\n | Ast_409.Asttypes.Labelled x0 -> Ast_410.Asttypes.Labelled x0\n | Ast_409.Asttypes.Optional x0 -> Ast_410.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_409.Asttypes.closed_flag -> Ast_410.Asttypes.closed_flag = function\n | Ast_409.Asttypes.Closed -> Ast_410.Asttypes.Closed\n | Ast_409.Asttypes.Open -> Ast_410.Asttypes.Open\n\nand copy_label : Ast_409.Asttypes.label -> Ast_410.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_409.Asttypes.rec_flag -> Ast_410.Asttypes.rec_flag =\n function\n | Ast_409.Asttypes.Nonrecursive -> Ast_410.Asttypes.Nonrecursive\n | Ast_409.Asttypes.Recursive -> Ast_410.Asttypes.Recursive\n\nand copy_constant : Ast_409.Parsetree.constant -> Ast_410.Parsetree.constant =\n function\n | Ast_409.Parsetree.Pconst_integer (x0, x1) ->\n Ast_410.Parsetree.Pconst_integer (x0, map_option (fun x -> x) x1)\n | Ast_409.Parsetree.Pconst_char x0 -> Ast_410.Parsetree.Pconst_char x0\n | Ast_409.Parsetree.Pconst_string (x0, x1) ->\n Ast_410.Parsetree.Pconst_string (x0, map_option (fun x -> x) x1)\n | Ast_409.Parsetree.Pconst_float (x0, x1) ->\n Ast_410.Parsetree.Pconst_float (x0, map_option (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_409.Asttypes.loc -> 'g0 Ast_410.Asttypes.loc =\n fun f0 { Ast_409.Asttypes.txt; Ast_409.Asttypes.loc } ->\n { Ast_410.Asttypes.txt = f0 txt; Ast_410.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n\nlet copy_expr = copy_expression\nlet copy_pat = copy_pattern\nlet copy_typ = copy_core_type\n","open Stdlib0\nmodule From = Ast_409\nmodule To = Ast_408\n\nlet rec copy_toplevel_phrase :\n Ast_409.Parsetree.toplevel_phrase -> Ast_408.Parsetree.toplevel_phrase =\n function\n | Ast_409.Parsetree.Ptop_def x0 ->\n Ast_408.Parsetree.Ptop_def (copy_structure x0)\n | Ast_409.Parsetree.Ptop_dir x0 ->\n Ast_408.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_409.Parsetree.toplevel_directive -> Ast_408.Parsetree.toplevel_directive\n =\n fun {\n Ast_409.Parsetree.pdir_name;\n Ast_409.Parsetree.pdir_arg;\n Ast_409.Parsetree.pdir_loc;\n } ->\n {\n Ast_408.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_408.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_408.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_409.Parsetree.directive_argument -> Ast_408.Parsetree.directive_argument\n =\n fun { Ast_409.Parsetree.pdira_desc; Ast_409.Parsetree.pdira_loc } ->\n {\n Ast_408.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_408.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_409.Parsetree.directive_argument_desc ->\n Ast_408.Parsetree.directive_argument_desc = function\n | Ast_409.Parsetree.Pdir_string x0 -> Ast_408.Parsetree.Pdir_string x0\n | Ast_409.Parsetree.Pdir_int (x0, x1) ->\n Ast_408.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_409.Parsetree.Pdir_ident x0 ->\n Ast_408.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_409.Parsetree.Pdir_bool x0 -> Ast_408.Parsetree.Pdir_bool x0\n\nand copy_typ : Ast_409.Parsetree.typ -> Ast_408.Parsetree.typ =\n fun x -> copy_core_type x\n\nand copy_pat : Ast_409.Parsetree.pat -> Ast_408.Parsetree.pat =\n fun x -> copy_pattern x\n\nand copy_expr : Ast_409.Parsetree.expr -> Ast_408.Parsetree.expr =\n fun x -> copy_expression x\n\nand copy_expression :\n Ast_409.Parsetree.expression -> Ast_408.Parsetree.expression =\n fun {\n Ast_409.Parsetree.pexp_desc;\n Ast_409.Parsetree.pexp_loc;\n Ast_409.Parsetree.pexp_loc_stack;\n Ast_409.Parsetree.pexp_attributes;\n } ->\n {\n Ast_408.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_408.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_408.Parsetree.pexp_loc_stack = List.map copy_location pexp_loc_stack;\n Ast_408.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_409.Parsetree.expression_desc -> Ast_408.Parsetree.expression_desc =\n function\n | Ast_409.Parsetree.Pexp_ident x0 ->\n Ast_408.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pexp_constant x0 ->\n Ast_408.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_409.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_408.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_function x0 ->\n Ast_408.Parsetree.Pexp_function (copy_cases x0)\n | Ast_409.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_408.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_409.Parsetree.Pexp_apply (x0, x1) ->\n Ast_408.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_409.Parsetree.Pexp_match (x0, x1) ->\n Ast_408.Parsetree.Pexp_match (copy_expression x0, copy_cases x1)\n | Ast_409.Parsetree.Pexp_try (x0, x1) ->\n Ast_408.Parsetree.Pexp_try (copy_expression x0, copy_cases x1)\n | Ast_409.Parsetree.Pexp_tuple x0 ->\n Ast_408.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_409.Parsetree.Pexp_construct (x0, x1) ->\n Ast_408.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_409.Parsetree.Pexp_variant (x0, x1) ->\n Ast_408.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_409.Parsetree.Pexp_record (x0, x1) ->\n Ast_408.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_409.Parsetree.Pexp_field (x0, x1) ->\n Ast_408.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_409.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_408.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_array x0 ->\n Ast_408.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_409.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_408.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_409.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_408.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_while (x0, x1) ->\n Ast_408.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_408.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_409.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_408.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_409.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_408.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_409.Parsetree.Pexp_send (x0, x1) ->\n Ast_408.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_409.Parsetree.Pexp_new x0 ->\n Ast_408.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_408.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_override x0 ->\n Ast_408.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_409.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_408.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_408.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_assert x0 ->\n Ast_408.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_409.Parsetree.Pexp_lazy x0 ->\n Ast_408.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_409.Parsetree.Pexp_poly (x0, x1) ->\n Ast_408.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_409.Parsetree.Pexp_object x0 ->\n Ast_408.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_409.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_408.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_pack x0 ->\n Ast_408.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_409.Parsetree.Pexp_open (x0, x1) ->\n Ast_408.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_letop x0 ->\n Ast_408.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_409.Parsetree.Pexp_extension x0 ->\n Ast_408.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_409.Parsetree.Pexp_unreachable -> Ast_408.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_409.Parsetree.letop -> Ast_408.Parsetree.letop =\n fun { Ast_409.Parsetree.let_; Ast_409.Parsetree.ands; Ast_409.Parsetree.body } ->\n {\n Ast_408.Parsetree.let_ = copy_binding_op let_;\n Ast_408.Parsetree.ands = List.map copy_binding_op ands;\n Ast_408.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_409.Parsetree.binding_op -> Ast_408.Parsetree.binding_op =\n fun {\n Ast_409.Parsetree.pbop_op;\n Ast_409.Parsetree.pbop_pat;\n Ast_409.Parsetree.pbop_exp;\n Ast_409.Parsetree.pbop_loc;\n } ->\n {\n Ast_408.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_408.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_408.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_408.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_409.Asttypes.direction_flag -> Ast_408.Asttypes.direction_flag =\n function\n | Ast_409.Asttypes.Upto -> Ast_408.Asttypes.Upto\n | Ast_409.Asttypes.Downto -> Ast_408.Asttypes.Downto\n\nand copy_cases : Ast_409.Parsetree.cases -> Ast_408.Parsetree.cases =\n fun x -> List.map copy_case x\n\nand copy_case : Ast_409.Parsetree.case -> Ast_408.Parsetree.case =\n fun {\n Ast_409.Parsetree.pc_lhs;\n Ast_409.Parsetree.pc_guard;\n Ast_409.Parsetree.pc_rhs;\n } ->\n {\n Ast_408.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_408.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_408.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_409.Parsetree.value_binding -> Ast_408.Parsetree.value_binding =\n fun {\n Ast_409.Parsetree.pvb_pat;\n Ast_409.Parsetree.pvb_expr;\n Ast_409.Parsetree.pvb_attributes;\n Ast_409.Parsetree.pvb_loc;\n } ->\n {\n Ast_408.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_408.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_408.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_408.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_409.Parsetree.pattern -> Ast_408.Parsetree.pattern =\n fun {\n Ast_409.Parsetree.ppat_desc;\n Ast_409.Parsetree.ppat_loc;\n Ast_409.Parsetree.ppat_loc_stack;\n Ast_409.Parsetree.ppat_attributes;\n } ->\n {\n Ast_408.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_408.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_408.Parsetree.ppat_loc_stack = List.map copy_location ppat_loc_stack;\n Ast_408.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_409.Parsetree.pattern_desc -> Ast_408.Parsetree.pattern_desc = function\n | Ast_409.Parsetree.Ppat_any -> Ast_408.Parsetree.Ppat_any\n | Ast_409.Parsetree.Ppat_var x0 ->\n Ast_408.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_409.Parsetree.Ppat_alias (x0, x1) ->\n Ast_408.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_409.Parsetree.Ppat_constant x0 ->\n Ast_408.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_409.Parsetree.Ppat_interval (x0, x1) ->\n Ast_408.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_409.Parsetree.Ppat_tuple x0 ->\n Ast_408.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_409.Parsetree.Ppat_construct (x0, x1) ->\n Ast_408.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_409.Parsetree.Ppat_variant (x0, x1) ->\n Ast_408.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_409.Parsetree.Ppat_record (x0, x1) ->\n Ast_408.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_409.Parsetree.Ppat_array x0 ->\n Ast_408.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_409.Parsetree.Ppat_or (x0, x1) ->\n Ast_408.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_409.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_408.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_409.Parsetree.Ppat_type x0 ->\n Ast_408.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Ppat_lazy x0 ->\n Ast_408.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_409.Parsetree.Ppat_unpack x0 ->\n Ast_408.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | Ast_409.Parsetree.Ppat_exception x0 ->\n Ast_408.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_409.Parsetree.Ppat_extension x0 ->\n Ast_408.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_409.Parsetree.Ppat_open (x0, x1) ->\n Ast_408.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_409.Parsetree.core_type -> Ast_408.Parsetree.core_type\n =\n fun {\n Ast_409.Parsetree.ptyp_desc;\n Ast_409.Parsetree.ptyp_loc;\n Ast_409.Parsetree.ptyp_loc_stack;\n Ast_409.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_408.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_408.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_408.Parsetree.ptyp_loc_stack = List.map copy_location ptyp_loc_stack;\n Ast_408.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n Ast_409.Parsetree.core_type_desc -> Ast_408.Parsetree.core_type_desc =\n function\n | Ast_409.Parsetree.Ptyp_any -> Ast_408.Parsetree.Ptyp_any\n | Ast_409.Parsetree.Ptyp_var x0 -> Ast_408.Parsetree.Ptyp_var x0\n | Ast_409.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_408.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_409.Parsetree.Ptyp_tuple x0 ->\n Ast_408.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_409.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_408.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_object (x0, x1) ->\n Ast_408.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_409.Parsetree.Ptyp_class (x0, x1) ->\n Ast_408.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_408.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_409.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_408.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_409.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_408.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_package x0 ->\n Ast_408.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_409.Parsetree.Ptyp_extension x0 ->\n Ast_408.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_409.Parsetree.package_type -> Ast_408.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_409.Parsetree.row_field -> Ast_408.Parsetree.row_field\n =\n fun {\n Ast_409.Parsetree.prf_desc;\n Ast_409.Parsetree.prf_loc;\n Ast_409.Parsetree.prf_attributes;\n } ->\n {\n Ast_408.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_408.Parsetree.prf_loc = copy_location prf_loc;\n Ast_408.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_409.Parsetree.row_field_desc -> Ast_408.Parsetree.row_field_desc =\n function\n | Ast_409.Parsetree.Rtag (x0, x1, x2) ->\n Ast_408.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_409.Parsetree.Rinherit x0 ->\n Ast_408.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_409.Parsetree.object_field -> Ast_408.Parsetree.object_field =\n fun {\n Ast_409.Parsetree.pof_desc;\n Ast_409.Parsetree.pof_loc;\n Ast_409.Parsetree.pof_attributes;\n } ->\n {\n Ast_408.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_408.Parsetree.pof_loc = copy_location pof_loc;\n Ast_408.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_409.Parsetree.attributes -> Ast_408.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_409.Parsetree.attribute -> Ast_408.Parsetree.attribute\n =\n fun {\n Ast_409.Parsetree.attr_name;\n Ast_409.Parsetree.attr_payload;\n Ast_409.Parsetree.attr_loc;\n } ->\n {\n Ast_408.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_408.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_408.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_409.Parsetree.payload -> Ast_408.Parsetree.payload =\n function\n | Ast_409.Parsetree.PStr x0 -> Ast_408.Parsetree.PStr (copy_structure x0)\n | Ast_409.Parsetree.PSig x0 -> Ast_408.Parsetree.PSig (copy_signature x0)\n | Ast_409.Parsetree.PTyp x0 -> Ast_408.Parsetree.PTyp (copy_core_type x0)\n | Ast_409.Parsetree.PPat (x0, x1) ->\n Ast_408.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_409.Parsetree.structure -> Ast_408.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_409.Parsetree.structure_item -> Ast_408.Parsetree.structure_item =\n fun { Ast_409.Parsetree.pstr_desc; Ast_409.Parsetree.pstr_loc } ->\n {\n Ast_408.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_408.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_409.Parsetree.structure_item_desc ->\n Ast_408.Parsetree.structure_item_desc = function\n | Ast_409.Parsetree.Pstr_eval (x0, x1) ->\n Ast_408.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_409.Parsetree.Pstr_value (x0, x1) ->\n Ast_408.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_409.Parsetree.Pstr_primitive x0 ->\n Ast_408.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_409.Parsetree.Pstr_type (x0, x1) ->\n Ast_408.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_409.Parsetree.Pstr_typext x0 ->\n Ast_408.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_409.Parsetree.Pstr_exception x0 ->\n Ast_408.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_409.Parsetree.Pstr_module x0 ->\n Ast_408.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_409.Parsetree.Pstr_recmodule x0 ->\n Ast_408.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_409.Parsetree.Pstr_modtype x0 ->\n Ast_408.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_409.Parsetree.Pstr_open x0 ->\n Ast_408.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_409.Parsetree.Pstr_class x0 ->\n Ast_408.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_409.Parsetree.Pstr_class_type x0 ->\n Ast_408.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_409.Parsetree.Pstr_include x0 ->\n Ast_408.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_409.Parsetree.Pstr_attribute x0 ->\n Ast_408.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pstr_extension (x0, x1) ->\n Ast_408.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_409.Parsetree.include_declaration ->\n Ast_408.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_409.Parsetree.class_declaration -> Ast_408.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_409.Parsetree.class_expr -> Ast_408.Parsetree.class_expr =\n fun {\n Ast_409.Parsetree.pcl_desc;\n Ast_409.Parsetree.pcl_loc;\n Ast_409.Parsetree.pcl_attributes;\n } ->\n {\n Ast_408.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_408.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_408.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_409.Parsetree.class_expr_desc -> Ast_408.Parsetree.class_expr_desc =\n function\n | Ast_409.Parsetree.Pcl_constr (x0, x1) ->\n Ast_408.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Pcl_structure x0 ->\n Ast_408.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_409.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_408.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_409.Parsetree.Pcl_apply (x0, x1) ->\n Ast_408.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_409.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_408.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_409.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_408.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_409.Parsetree.Pcl_extension x0 ->\n Ast_408.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_409.Parsetree.Pcl_open (x0, x1) ->\n Ast_408.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_409.Parsetree.class_structure -> Ast_408.Parsetree.class_structure =\n fun { Ast_409.Parsetree.pcstr_self; Ast_409.Parsetree.pcstr_fields } ->\n {\n Ast_408.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_408.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_409.Parsetree.class_field -> Ast_408.Parsetree.class_field =\n fun {\n Ast_409.Parsetree.pcf_desc;\n Ast_409.Parsetree.pcf_loc;\n Ast_409.Parsetree.pcf_attributes;\n } ->\n {\n Ast_408.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_408.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_408.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_409.Parsetree.class_field_desc -> Ast_408.Parsetree.class_field_desc =\n function\n | Ast_409.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_408.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_409.Parsetree.Pcf_val x0 ->\n Ast_408.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_409.Parsetree.Pcf_method x0 ->\n Ast_408.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_409.Parsetree.Pcf_constraint x0 ->\n Ast_408.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_409.Parsetree.Pcf_initializer x0 ->\n Ast_408.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_409.Parsetree.Pcf_attribute x0 ->\n Ast_408.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pcf_extension x0 ->\n Ast_408.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_409.Parsetree.class_field_kind -> Ast_408.Parsetree.class_field_kind =\n function\n | Ast_409.Parsetree.Cfk_virtual x0 ->\n Ast_408.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_409.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_408.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_409.Parsetree.open_declaration -> Ast_408.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_409.Parsetree.module_binding -> Ast_408.Parsetree.module_binding =\n fun {\n Ast_409.Parsetree.pmb_name;\n Ast_409.Parsetree.pmb_expr;\n Ast_409.Parsetree.pmb_attributes;\n Ast_409.Parsetree.pmb_loc;\n } ->\n {\n Ast_408.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n Ast_408.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_408.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_408.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_409.Parsetree.module_expr -> Ast_408.Parsetree.module_expr =\n fun {\n Ast_409.Parsetree.pmod_desc;\n Ast_409.Parsetree.pmod_loc;\n Ast_409.Parsetree.pmod_attributes;\n } ->\n {\n Ast_408.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_408.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_408.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_409.Parsetree.module_expr_desc -> Ast_408.Parsetree.module_expr_desc =\n function\n | Ast_409.Parsetree.Pmod_ident x0 ->\n Ast_408.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pmod_structure x0 ->\n Ast_408.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_409.Parsetree.Pmod_functor (x0, x1, x2) ->\n Ast_408.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n Option.map copy_module_type x1,\n copy_module_expr x2 )\n | Ast_409.Parsetree.Pmod_apply (x0, x1) ->\n Ast_408.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_409.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_408.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_409.Parsetree.Pmod_unpack x0 ->\n Ast_408.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_409.Parsetree.Pmod_extension x0 ->\n Ast_408.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type :\n Ast_409.Parsetree.module_type -> Ast_408.Parsetree.module_type =\n fun {\n Ast_409.Parsetree.pmty_desc;\n Ast_409.Parsetree.pmty_loc;\n Ast_409.Parsetree.pmty_attributes;\n } ->\n {\n Ast_408.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_408.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_408.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_409.Parsetree.module_type_desc -> Ast_408.Parsetree.module_type_desc =\n function\n | Ast_409.Parsetree.Pmty_ident x0 ->\n Ast_408.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pmty_signature x0 ->\n Ast_408.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_409.Parsetree.Pmty_functor (x0, x1, x2) ->\n Ast_408.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n Option.map copy_module_type x1,\n copy_module_type x2 )\n | Ast_409.Parsetree.Pmty_with (x0, x1) ->\n Ast_408.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_409.Parsetree.Pmty_typeof x0 ->\n Ast_408.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_409.Parsetree.Pmty_extension x0 ->\n Ast_408.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_409.Parsetree.Pmty_alias x0 ->\n Ast_408.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_409.Parsetree.with_constraint -> Ast_408.Parsetree.with_constraint =\n function\n | Ast_409.Parsetree.Pwith_type (x0, x1) ->\n Ast_408.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_409.Parsetree.Pwith_module (x0, x1) ->\n Ast_408.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_409.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_408.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_409.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_408.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_409.Parsetree.signature -> Ast_408.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_409.Parsetree.signature_item -> Ast_408.Parsetree.signature_item =\n fun { Ast_409.Parsetree.psig_desc; Ast_409.Parsetree.psig_loc } ->\n {\n Ast_408.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_408.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_409.Parsetree.signature_item_desc ->\n Ast_408.Parsetree.signature_item_desc = function\n | Ast_409.Parsetree.Psig_value x0 ->\n Ast_408.Parsetree.Psig_value (copy_value_description x0)\n | Ast_409.Parsetree.Psig_type (x0, x1) ->\n Ast_408.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_409.Parsetree.Psig_typesubst x0 ->\n Ast_408.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_409.Parsetree.Psig_typext x0 ->\n Ast_408.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_409.Parsetree.Psig_exception x0 ->\n Ast_408.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_409.Parsetree.Psig_module x0 ->\n Ast_408.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_409.Parsetree.Psig_modsubst x0 ->\n Ast_408.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_409.Parsetree.Psig_recmodule x0 ->\n Ast_408.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_409.Parsetree.Psig_modtype x0 ->\n Ast_408.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_409.Parsetree.Psig_open x0 ->\n Ast_408.Parsetree.Psig_open (copy_open_description x0)\n | Ast_409.Parsetree.Psig_include x0 ->\n Ast_408.Parsetree.Psig_include (copy_include_description x0)\n | Ast_409.Parsetree.Psig_class x0 ->\n Ast_408.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_409.Parsetree.Psig_class_type x0 ->\n Ast_408.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_409.Parsetree.Psig_attribute x0 ->\n Ast_408.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Psig_extension (x0, x1) ->\n Ast_408.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_409.Parsetree.class_type_declaration ->\n Ast_408.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_409.Parsetree.class_description -> Ast_408.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_409.Parsetree.class_type -> Ast_408.Parsetree.class_type =\n fun {\n Ast_409.Parsetree.pcty_desc;\n Ast_409.Parsetree.pcty_loc;\n Ast_409.Parsetree.pcty_attributes;\n } ->\n {\n Ast_408.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_408.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_408.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_409.Parsetree.class_type_desc -> Ast_408.Parsetree.class_type_desc =\n function\n | Ast_409.Parsetree.Pcty_constr (x0, x1) ->\n Ast_408.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Pcty_signature x0 ->\n Ast_408.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_409.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_408.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_409.Parsetree.Pcty_extension x0 ->\n Ast_408.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_409.Parsetree.Pcty_open (x0, x1) ->\n Ast_408.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_409.Parsetree.class_signature -> Ast_408.Parsetree.class_signature =\n fun { Ast_409.Parsetree.pcsig_self; Ast_409.Parsetree.pcsig_fields } ->\n {\n Ast_408.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_408.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_409.Parsetree.class_type_field -> Ast_408.Parsetree.class_type_field =\n fun {\n Ast_409.Parsetree.pctf_desc;\n Ast_409.Parsetree.pctf_loc;\n Ast_409.Parsetree.pctf_attributes;\n } ->\n {\n Ast_408.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_408.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_408.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_409.Parsetree.class_type_field_desc ->\n Ast_408.Parsetree.class_type_field_desc = function\n | Ast_409.Parsetree.Pctf_inherit x0 ->\n Ast_408.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_409.Parsetree.Pctf_val x0 ->\n Ast_408.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_409.Parsetree.Pctf_method x0 ->\n Ast_408.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_409.Parsetree.Pctf_constraint x0 ->\n Ast_408.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_409.Parsetree.Pctf_attribute x0 ->\n Ast_408.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pctf_extension x0 ->\n Ast_408.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_409.Parsetree.extension -> Ast_408.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.class_infos ->\n 'g0 Ast_408.Parsetree.class_infos =\n fun f0\n {\n Ast_409.Parsetree.pci_virt;\n Ast_409.Parsetree.pci_params;\n Ast_409.Parsetree.pci_name;\n Ast_409.Parsetree.pci_expr;\n Ast_409.Parsetree.pci_loc;\n Ast_409.Parsetree.pci_attributes;\n } ->\n {\n Ast_408.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_408.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_408.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_408.Parsetree.pci_expr = f0 pci_expr;\n Ast_408.Parsetree.pci_loc = copy_location pci_loc;\n Ast_408.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_409.Asttypes.virtual_flag -> Ast_408.Asttypes.virtual_flag = function\n | Ast_409.Asttypes.Virtual -> Ast_408.Asttypes.Virtual\n | Ast_409.Asttypes.Concrete -> Ast_408.Asttypes.Concrete\n\nand copy_include_description :\n Ast_409.Parsetree.include_description ->\n Ast_408.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.include_infos ->\n 'g0 Ast_408.Parsetree.include_infos =\n fun f0\n {\n Ast_409.Parsetree.pincl_mod;\n Ast_409.Parsetree.pincl_loc;\n Ast_409.Parsetree.pincl_attributes;\n } ->\n {\n Ast_408.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_408.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_408.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_409.Parsetree.open_description -> Ast_408.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.open_infos ->\n 'g0 Ast_408.Parsetree.open_infos =\n fun f0\n {\n Ast_409.Parsetree.popen_expr;\n Ast_409.Parsetree.popen_override;\n Ast_409.Parsetree.popen_loc;\n Ast_409.Parsetree.popen_attributes;\n } ->\n {\n Ast_408.Parsetree.popen_expr = f0 popen_expr;\n Ast_408.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_408.Parsetree.popen_loc = copy_location popen_loc;\n Ast_408.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_409.Asttypes.override_flag -> Ast_408.Asttypes.override_flag = function\n | Ast_409.Asttypes.Override -> Ast_408.Asttypes.Override\n | Ast_409.Asttypes.Fresh -> Ast_408.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_409.Parsetree.module_type_declaration ->\n Ast_408.Parsetree.module_type_declaration =\n fun {\n Ast_409.Parsetree.pmtd_name;\n Ast_409.Parsetree.pmtd_type;\n Ast_409.Parsetree.pmtd_attributes;\n Ast_409.Parsetree.pmtd_loc;\n } ->\n {\n Ast_408.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_408.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_408.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_408.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_409.Parsetree.module_substitution ->\n Ast_408.Parsetree.module_substitution =\n fun {\n Ast_409.Parsetree.pms_name;\n Ast_409.Parsetree.pms_manifest;\n Ast_409.Parsetree.pms_attributes;\n Ast_409.Parsetree.pms_loc;\n } ->\n {\n Ast_408.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_408.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_408.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_408.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_409.Parsetree.module_declaration -> Ast_408.Parsetree.module_declaration\n =\n fun {\n Ast_409.Parsetree.pmd_name;\n Ast_409.Parsetree.pmd_type;\n Ast_409.Parsetree.pmd_attributes;\n Ast_409.Parsetree.pmd_loc;\n } ->\n {\n Ast_408.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n Ast_408.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_408.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_408.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_409.Parsetree.type_exception -> Ast_408.Parsetree.type_exception =\n fun {\n Ast_409.Parsetree.ptyexn_constructor;\n Ast_409.Parsetree.ptyexn_loc;\n Ast_409.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_408.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_408.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_408.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_409.Parsetree.type_extension -> Ast_408.Parsetree.type_extension =\n fun {\n Ast_409.Parsetree.ptyext_path;\n Ast_409.Parsetree.ptyext_params;\n Ast_409.Parsetree.ptyext_constructors;\n Ast_409.Parsetree.ptyext_private;\n Ast_409.Parsetree.ptyext_loc;\n Ast_409.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_408.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_408.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_408.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_408.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_408.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_408.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_409.Parsetree.extension_constructor ->\n Ast_408.Parsetree.extension_constructor =\n fun {\n Ast_409.Parsetree.pext_name;\n Ast_409.Parsetree.pext_kind;\n Ast_409.Parsetree.pext_loc;\n Ast_409.Parsetree.pext_attributes;\n } ->\n {\n Ast_408.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_408.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_408.Parsetree.pext_loc = copy_location pext_loc;\n Ast_408.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_409.Parsetree.extension_constructor_kind ->\n Ast_408.Parsetree.extension_constructor_kind = function\n | Ast_409.Parsetree.Pext_decl (x0, x1) ->\n Ast_408.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_409.Parsetree.Pext_rebind x0 ->\n Ast_408.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_409.Parsetree.type_declaration -> Ast_408.Parsetree.type_declaration =\n fun {\n Ast_409.Parsetree.ptype_name;\n Ast_409.Parsetree.ptype_params;\n Ast_409.Parsetree.ptype_cstrs;\n Ast_409.Parsetree.ptype_kind;\n Ast_409.Parsetree.ptype_private;\n Ast_409.Parsetree.ptype_manifest;\n Ast_409.Parsetree.ptype_attributes;\n Ast_409.Parsetree.ptype_loc;\n } ->\n {\n Ast_408.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_408.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_408.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_408.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_408.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_408.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_408.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_408.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_409.Asttypes.private_flag -> Ast_408.Asttypes.private_flag = function\n | Ast_409.Asttypes.Private -> Ast_408.Asttypes.Private\n | Ast_409.Asttypes.Public -> Ast_408.Asttypes.Public\n\nand copy_type_kind : Ast_409.Parsetree.type_kind -> Ast_408.Parsetree.type_kind\n = function\n | Ast_409.Parsetree.Ptype_abstract -> Ast_408.Parsetree.Ptype_abstract\n | Ast_409.Parsetree.Ptype_variant x0 ->\n Ast_408.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_409.Parsetree.Ptype_record x0 ->\n Ast_408.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_409.Parsetree.Ptype_open -> Ast_408.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_409.Parsetree.constructor_declaration ->\n Ast_408.Parsetree.constructor_declaration =\n fun {\n Ast_409.Parsetree.pcd_name;\n Ast_409.Parsetree.pcd_args;\n Ast_409.Parsetree.pcd_res;\n Ast_409.Parsetree.pcd_loc;\n Ast_409.Parsetree.pcd_attributes;\n } ->\n {\n Ast_408.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_408.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_408.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_408.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_408.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_409.Parsetree.constructor_arguments ->\n Ast_408.Parsetree.constructor_arguments = function\n | Ast_409.Parsetree.Pcstr_tuple x0 ->\n Ast_408.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_409.Parsetree.Pcstr_record x0 ->\n Ast_408.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_409.Parsetree.label_declaration -> Ast_408.Parsetree.label_declaration =\n fun {\n Ast_409.Parsetree.pld_name;\n Ast_409.Parsetree.pld_mutable;\n Ast_409.Parsetree.pld_type;\n Ast_409.Parsetree.pld_loc;\n Ast_409.Parsetree.pld_attributes;\n } ->\n {\n Ast_408.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_408.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_408.Parsetree.pld_type = copy_core_type pld_type;\n Ast_408.Parsetree.pld_loc = copy_location pld_loc;\n Ast_408.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_409.Asttypes.mutable_flag -> Ast_408.Asttypes.mutable_flag = function\n | Ast_409.Asttypes.Immutable -> Ast_408.Asttypes.Immutable\n | Ast_409.Asttypes.Mutable -> Ast_408.Asttypes.Mutable\n\nand copy_variance : Ast_409.Asttypes.variance -> Ast_408.Asttypes.variance =\n function\n | Ast_409.Asttypes.Covariant -> Ast_408.Asttypes.Covariant\n | Ast_409.Asttypes.Contravariant -> Ast_408.Asttypes.Contravariant\n | Ast_409.Asttypes.Invariant -> Ast_408.Asttypes.Invariant\n\nand copy_value_description :\n Ast_409.Parsetree.value_description -> Ast_408.Parsetree.value_description =\n fun {\n Ast_409.Parsetree.pval_name;\n Ast_409.Parsetree.pval_type;\n Ast_409.Parsetree.pval_prim;\n Ast_409.Parsetree.pval_attributes;\n Ast_409.Parsetree.pval_loc;\n } ->\n {\n Ast_408.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_408.Parsetree.pval_type = copy_core_type pval_type;\n Ast_408.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_408.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_408.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_409.Parsetree.object_field_desc -> Ast_408.Parsetree.object_field_desc =\n function\n | Ast_409.Parsetree.Otag (x0, x1) ->\n Ast_408.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_409.Parsetree.Oinherit x0 ->\n Ast_408.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_409.Asttypes.arg_label -> Ast_408.Asttypes.arg_label =\n function\n | Ast_409.Asttypes.Nolabel -> Ast_408.Asttypes.Nolabel\n | Ast_409.Asttypes.Labelled x0 -> Ast_408.Asttypes.Labelled x0\n | Ast_409.Asttypes.Optional x0 -> Ast_408.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_409.Asttypes.closed_flag -> Ast_408.Asttypes.closed_flag = function\n | Ast_409.Asttypes.Closed -> Ast_408.Asttypes.Closed\n | Ast_409.Asttypes.Open -> Ast_408.Asttypes.Open\n\nand copy_label : Ast_409.Asttypes.label -> Ast_408.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_409.Asttypes.rec_flag -> Ast_408.Asttypes.rec_flag =\n function\n | Ast_409.Asttypes.Nonrecursive -> Ast_408.Asttypes.Nonrecursive\n | Ast_409.Asttypes.Recursive -> Ast_408.Asttypes.Recursive\n\nand copy_constant : Ast_409.Parsetree.constant -> Ast_408.Parsetree.constant =\n function\n | Ast_409.Parsetree.Pconst_integer (x0, x1) ->\n Ast_408.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_409.Parsetree.Pconst_char x0 -> Ast_408.Parsetree.Pconst_char x0\n | Ast_409.Parsetree.Pconst_string (x0, x1) ->\n Ast_408.Parsetree.Pconst_string (x0, Option.map (fun x -> x) x1)\n | Ast_409.Parsetree.Pconst_float (x0, x1) ->\n Ast_408.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_409.Asttypes.loc -> 'g0 Ast_408.Asttypes.loc =\n fun f0 { Ast_409.Asttypes.txt; Ast_409.Asttypes.loc } ->\n { Ast_408.Asttypes.txt = f0 txt; Ast_408.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_408\nmodule To = Ast_409\n\nlet rec copy_toplevel_phrase :\n Ast_408.Parsetree.toplevel_phrase -> Ast_409.Parsetree.toplevel_phrase =\n function\n | Ast_408.Parsetree.Ptop_def x0 ->\n Ast_409.Parsetree.Ptop_def (copy_structure x0)\n | Ast_408.Parsetree.Ptop_dir x0 ->\n Ast_409.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_408.Parsetree.toplevel_directive -> Ast_409.Parsetree.toplevel_directive\n =\n fun {\n Ast_408.Parsetree.pdir_name;\n Ast_408.Parsetree.pdir_arg;\n Ast_408.Parsetree.pdir_loc;\n } ->\n {\n Ast_409.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_409.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_409.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_408.Parsetree.directive_argument -> Ast_409.Parsetree.directive_argument\n =\n fun { Ast_408.Parsetree.pdira_desc; Ast_408.Parsetree.pdira_loc } ->\n {\n Ast_409.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_409.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_408.Parsetree.directive_argument_desc ->\n Ast_409.Parsetree.directive_argument_desc = function\n | Ast_408.Parsetree.Pdir_string x0 -> Ast_409.Parsetree.Pdir_string x0\n | Ast_408.Parsetree.Pdir_int (x0, x1) ->\n Ast_409.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_408.Parsetree.Pdir_ident x0 ->\n Ast_409.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_408.Parsetree.Pdir_bool x0 -> Ast_409.Parsetree.Pdir_bool x0\n\nand copy_typ : Ast_408.Parsetree.typ -> Ast_409.Parsetree.typ =\n fun x -> copy_core_type x\n\nand copy_pat : Ast_408.Parsetree.pat -> Ast_409.Parsetree.pat =\n fun x -> copy_pattern x\n\nand copy_expr : Ast_408.Parsetree.expr -> Ast_409.Parsetree.expr =\n fun x -> copy_expression x\n\nand copy_expression :\n Ast_408.Parsetree.expression -> Ast_409.Parsetree.expression =\n fun {\n Ast_408.Parsetree.pexp_desc;\n Ast_408.Parsetree.pexp_loc;\n Ast_408.Parsetree.pexp_loc_stack;\n Ast_408.Parsetree.pexp_attributes;\n } ->\n {\n Ast_409.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_409.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_409.Parsetree.pexp_loc_stack = List.map copy_location pexp_loc_stack;\n Ast_409.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_408.Parsetree.expression_desc -> Ast_409.Parsetree.expression_desc =\n function\n | Ast_408.Parsetree.Pexp_ident x0 ->\n Ast_409.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_408.Parsetree.Pexp_constant x0 ->\n Ast_409.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_408.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_408.Parsetree.Pexp_function x0 ->\n Ast_409.Parsetree.Pexp_function (copy_cases x0)\n | Ast_408.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_409.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_408.Parsetree.Pexp_apply (x0, x1) ->\n Ast_409.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_408.Parsetree.Pexp_match (x0, x1) ->\n Ast_409.Parsetree.Pexp_match (copy_expression x0, copy_cases x1)\n | Ast_408.Parsetree.Pexp_try (x0, x1) ->\n Ast_409.Parsetree.Pexp_try (copy_expression x0, copy_cases x1)\n | Ast_408.Parsetree.Pexp_tuple x0 ->\n Ast_409.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_408.Parsetree.Pexp_construct (x0, x1) ->\n Ast_409.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_408.Parsetree.Pexp_variant (x0, x1) ->\n Ast_409.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_408.Parsetree.Pexp_record (x0, x1) ->\n Ast_409.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_408.Parsetree.Pexp_field (x0, x1) ->\n Ast_409.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_408.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_408.Parsetree.Pexp_array x0 ->\n Ast_409.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_408.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_408.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_409.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_while (x0, x1) ->\n Ast_409.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_409.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_408.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_409.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_408.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_408.Parsetree.Pexp_send (x0, x1) ->\n Ast_409.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_408.Parsetree.Pexp_new x0 ->\n Ast_409.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_408.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_409.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_override x0 ->\n Ast_409.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_408.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | Ast_408.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_409.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_assert x0 ->\n Ast_409.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_408.Parsetree.Pexp_lazy x0 ->\n Ast_409.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_408.Parsetree.Pexp_poly (x0, x1) ->\n Ast_409.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_408.Parsetree.Pexp_object x0 ->\n Ast_409.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_408.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_409.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_pack x0 ->\n Ast_409.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_408.Parsetree.Pexp_open (x0, x1) ->\n Ast_409.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_letop x0 ->\n Ast_409.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_408.Parsetree.Pexp_extension x0 ->\n Ast_409.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_408.Parsetree.Pexp_unreachable -> Ast_409.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_408.Parsetree.letop -> Ast_409.Parsetree.letop =\n fun { Ast_408.Parsetree.let_; Ast_408.Parsetree.ands; Ast_408.Parsetree.body } ->\n {\n Ast_409.Parsetree.let_ = copy_binding_op let_;\n Ast_409.Parsetree.ands = List.map copy_binding_op ands;\n Ast_409.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_408.Parsetree.binding_op -> Ast_409.Parsetree.binding_op =\n fun {\n Ast_408.Parsetree.pbop_op;\n Ast_408.Parsetree.pbop_pat;\n Ast_408.Parsetree.pbop_exp;\n Ast_408.Parsetree.pbop_loc;\n } ->\n {\n Ast_409.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_409.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_409.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_409.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_408.Asttypes.direction_flag -> Ast_409.Asttypes.direction_flag =\n function\n | Ast_408.Asttypes.Upto -> Ast_409.Asttypes.Upto\n | Ast_408.Asttypes.Downto -> Ast_409.Asttypes.Downto\n\nand copy_cases : Ast_408.Parsetree.cases -> Ast_409.Parsetree.cases =\n fun x -> List.map copy_case x\n\nand copy_case : Ast_408.Parsetree.case -> Ast_409.Parsetree.case =\n fun {\n Ast_408.Parsetree.pc_lhs;\n Ast_408.Parsetree.pc_guard;\n Ast_408.Parsetree.pc_rhs;\n } ->\n {\n Ast_409.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_409.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_409.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_408.Parsetree.value_binding -> Ast_409.Parsetree.value_binding =\n fun {\n Ast_408.Parsetree.pvb_pat;\n Ast_408.Parsetree.pvb_expr;\n Ast_408.Parsetree.pvb_attributes;\n Ast_408.Parsetree.pvb_loc;\n } ->\n {\n Ast_409.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_409.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_409.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_409.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_408.Parsetree.pattern -> Ast_409.Parsetree.pattern =\n fun {\n Ast_408.Parsetree.ppat_desc;\n Ast_408.Parsetree.ppat_loc;\n Ast_408.Parsetree.ppat_loc_stack;\n Ast_408.Parsetree.ppat_attributes;\n } ->\n {\n Ast_409.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_409.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_409.Parsetree.ppat_loc_stack = List.map copy_location ppat_loc_stack;\n Ast_409.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_408.Parsetree.pattern_desc -> Ast_409.Parsetree.pattern_desc = function\n | Ast_408.Parsetree.Ppat_any -> Ast_409.Parsetree.Ppat_any\n | Ast_408.Parsetree.Ppat_var x0 ->\n Ast_409.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_408.Parsetree.Ppat_alias (x0, x1) ->\n Ast_409.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_408.Parsetree.Ppat_constant x0 ->\n Ast_409.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_408.Parsetree.Ppat_interval (x0, x1) ->\n Ast_409.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_408.Parsetree.Ppat_tuple x0 ->\n Ast_409.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_408.Parsetree.Ppat_construct (x0, x1) ->\n Ast_409.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_408.Parsetree.Ppat_variant (x0, x1) ->\n Ast_409.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_408.Parsetree.Ppat_record (x0, x1) ->\n Ast_409.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_408.Parsetree.Ppat_array x0 ->\n Ast_409.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_408.Parsetree.Ppat_or (x0, x1) ->\n Ast_409.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_408.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_409.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_408.Parsetree.Ppat_type x0 ->\n Ast_409.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_408.Parsetree.Ppat_lazy x0 ->\n Ast_409.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_408.Parsetree.Ppat_unpack x0 ->\n Ast_409.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | Ast_408.Parsetree.Ppat_exception x0 ->\n Ast_409.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_408.Parsetree.Ppat_extension x0 ->\n Ast_409.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_408.Parsetree.Ppat_open (x0, x1) ->\n Ast_409.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_408.Parsetree.core_type -> Ast_409.Parsetree.core_type\n =\n fun {\n Ast_408.Parsetree.ptyp_desc;\n Ast_408.Parsetree.ptyp_loc;\n Ast_408.Parsetree.ptyp_loc_stack;\n Ast_408.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_409.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_409.Parsetree.ptyp_loc_stack = List.map copy_location ptyp_loc_stack;\n Ast_409.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n Ast_408.Parsetree.core_type_desc -> Ast_409.Parsetree.core_type_desc =\n function\n | Ast_408.Parsetree.Ptyp_any -> Ast_409.Parsetree.Ptyp_any\n | Ast_408.Parsetree.Ptyp_var x0 -> Ast_409.Parsetree.Ptyp_var x0\n | Ast_408.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_409.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_408.Parsetree.Ptyp_tuple x0 ->\n Ast_409.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_408.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_409.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_408.Parsetree.Ptyp_object (x0, x1) ->\n Ast_409.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_408.Parsetree.Ptyp_class (x0, x1) ->\n Ast_409.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_408.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_409.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_408.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_409.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_408.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_409.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_408.Parsetree.Ptyp_package x0 ->\n Ast_409.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_408.Parsetree.Ptyp_extension x0 ->\n Ast_409.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_408.Parsetree.package_type -> Ast_409.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_408.Parsetree.row_field -> Ast_409.Parsetree.row_field\n =\n fun {\n Ast_408.Parsetree.prf_desc;\n Ast_408.Parsetree.prf_loc;\n Ast_408.Parsetree.prf_attributes;\n } ->\n {\n Ast_409.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_409.Parsetree.prf_loc = copy_location prf_loc;\n Ast_409.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_408.Parsetree.row_field_desc -> Ast_409.Parsetree.row_field_desc =\n function\n | Ast_408.Parsetree.Rtag (x0, x1, x2) ->\n Ast_409.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_408.Parsetree.Rinherit x0 ->\n Ast_409.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_408.Parsetree.object_field -> Ast_409.Parsetree.object_field =\n fun {\n Ast_408.Parsetree.pof_desc;\n Ast_408.Parsetree.pof_loc;\n Ast_408.Parsetree.pof_attributes;\n } ->\n {\n Ast_409.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_409.Parsetree.pof_loc = copy_location pof_loc;\n Ast_409.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_408.Parsetree.attributes -> Ast_409.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_408.Parsetree.attribute -> Ast_409.Parsetree.attribute\n =\n fun {\n Ast_408.Parsetree.attr_name;\n Ast_408.Parsetree.attr_payload;\n Ast_408.Parsetree.attr_loc;\n } ->\n {\n Ast_409.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_409.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_409.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_408.Parsetree.payload -> Ast_409.Parsetree.payload =\n function\n | Ast_408.Parsetree.PStr x0 -> Ast_409.Parsetree.PStr (copy_structure x0)\n | Ast_408.Parsetree.PSig x0 -> Ast_409.Parsetree.PSig (copy_signature x0)\n | Ast_408.Parsetree.PTyp x0 -> Ast_409.Parsetree.PTyp (copy_core_type x0)\n | Ast_408.Parsetree.PPat (x0, x1) ->\n Ast_409.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_408.Parsetree.structure -> Ast_409.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_408.Parsetree.structure_item -> Ast_409.Parsetree.structure_item =\n fun { Ast_408.Parsetree.pstr_desc; Ast_408.Parsetree.pstr_loc } ->\n {\n Ast_409.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_409.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_408.Parsetree.structure_item_desc ->\n Ast_409.Parsetree.structure_item_desc = function\n | Ast_408.Parsetree.Pstr_eval (x0, x1) ->\n Ast_409.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_408.Parsetree.Pstr_value (x0, x1) ->\n Ast_409.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_408.Parsetree.Pstr_primitive x0 ->\n Ast_409.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_408.Parsetree.Pstr_type (x0, x1) ->\n Ast_409.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_408.Parsetree.Pstr_typext x0 ->\n Ast_409.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_408.Parsetree.Pstr_exception x0 ->\n Ast_409.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_408.Parsetree.Pstr_module x0 ->\n Ast_409.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_408.Parsetree.Pstr_recmodule x0 ->\n Ast_409.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_408.Parsetree.Pstr_modtype x0 ->\n Ast_409.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_408.Parsetree.Pstr_open x0 ->\n Ast_409.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_408.Parsetree.Pstr_class x0 ->\n Ast_409.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_408.Parsetree.Pstr_class_type x0 ->\n Ast_409.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_408.Parsetree.Pstr_include x0 ->\n Ast_409.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_408.Parsetree.Pstr_attribute x0 ->\n Ast_409.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_408.Parsetree.Pstr_extension (x0, x1) ->\n Ast_409.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_408.Parsetree.include_declaration ->\n Ast_409.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_408.Parsetree.class_declaration -> Ast_409.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_408.Parsetree.class_expr -> Ast_409.Parsetree.class_expr =\n fun {\n Ast_408.Parsetree.pcl_desc;\n Ast_408.Parsetree.pcl_loc;\n Ast_408.Parsetree.pcl_attributes;\n } ->\n {\n Ast_409.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_409.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_409.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_408.Parsetree.class_expr_desc -> Ast_409.Parsetree.class_expr_desc =\n function\n | Ast_408.Parsetree.Pcl_constr (x0, x1) ->\n Ast_409.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_408.Parsetree.Pcl_structure x0 ->\n Ast_409.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_408.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_409.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_408.Parsetree.Pcl_apply (x0, x1) ->\n Ast_409.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_408.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_409.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_408.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_409.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_408.Parsetree.Pcl_extension x0 ->\n Ast_409.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_408.Parsetree.Pcl_open (x0, x1) ->\n Ast_409.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_408.Parsetree.class_structure -> Ast_409.Parsetree.class_structure =\n fun { Ast_408.Parsetree.pcstr_self; Ast_408.Parsetree.pcstr_fields } ->\n {\n Ast_409.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_409.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_408.Parsetree.class_field -> Ast_409.Parsetree.class_field =\n fun {\n Ast_408.Parsetree.pcf_desc;\n Ast_408.Parsetree.pcf_loc;\n Ast_408.Parsetree.pcf_attributes;\n } ->\n {\n Ast_409.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_409.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_409.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_408.Parsetree.class_field_desc -> Ast_409.Parsetree.class_field_desc =\n function\n | Ast_408.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_409.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_408.Parsetree.Pcf_val x0 ->\n Ast_409.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_408.Parsetree.Pcf_method x0 ->\n Ast_409.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_408.Parsetree.Pcf_constraint x0 ->\n Ast_409.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_408.Parsetree.Pcf_initializer x0 ->\n Ast_409.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_408.Parsetree.Pcf_attribute x0 ->\n Ast_409.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_408.Parsetree.Pcf_extension x0 ->\n Ast_409.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_408.Parsetree.class_field_kind -> Ast_409.Parsetree.class_field_kind =\n function\n | Ast_408.Parsetree.Cfk_virtual x0 ->\n Ast_409.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_408.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_409.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_408.Parsetree.open_declaration -> Ast_409.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_408.Parsetree.module_binding -> Ast_409.Parsetree.module_binding =\n fun {\n Ast_408.Parsetree.pmb_name;\n Ast_408.Parsetree.pmb_expr;\n Ast_408.Parsetree.pmb_attributes;\n Ast_408.Parsetree.pmb_loc;\n } ->\n {\n Ast_409.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n Ast_409.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_409.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_409.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_408.Parsetree.module_expr -> Ast_409.Parsetree.module_expr =\n fun {\n Ast_408.Parsetree.pmod_desc;\n Ast_408.Parsetree.pmod_loc;\n Ast_408.Parsetree.pmod_attributes;\n } ->\n {\n Ast_409.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_409.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_409.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_408.Parsetree.module_expr_desc -> Ast_409.Parsetree.module_expr_desc =\n function\n | Ast_408.Parsetree.Pmod_ident x0 ->\n Ast_409.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_408.Parsetree.Pmod_structure x0 ->\n Ast_409.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_408.Parsetree.Pmod_functor (x0, x1, x2) ->\n Ast_409.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n Option.map copy_module_type x1,\n copy_module_expr x2 )\n | Ast_408.Parsetree.Pmod_apply (x0, x1) ->\n Ast_409.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_408.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_409.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_408.Parsetree.Pmod_unpack x0 ->\n Ast_409.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_408.Parsetree.Pmod_extension x0 ->\n Ast_409.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type :\n Ast_408.Parsetree.module_type -> Ast_409.Parsetree.module_type =\n fun {\n Ast_408.Parsetree.pmty_desc;\n Ast_408.Parsetree.pmty_loc;\n Ast_408.Parsetree.pmty_attributes;\n } ->\n {\n Ast_409.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_409.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_409.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_408.Parsetree.module_type_desc -> Ast_409.Parsetree.module_type_desc =\n function\n | Ast_408.Parsetree.Pmty_ident x0 ->\n Ast_409.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_408.Parsetree.Pmty_signature x0 ->\n Ast_409.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_408.Parsetree.Pmty_functor (x0, x1, x2) ->\n Ast_409.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n Option.map copy_module_type x1,\n copy_module_type x2 )\n | Ast_408.Parsetree.Pmty_with (x0, x1) ->\n Ast_409.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_408.Parsetree.Pmty_typeof x0 ->\n Ast_409.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_408.Parsetree.Pmty_extension x0 ->\n Ast_409.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_408.Parsetree.Pmty_alias x0 ->\n Ast_409.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_408.Parsetree.with_constraint -> Ast_409.Parsetree.with_constraint =\n function\n | Ast_408.Parsetree.Pwith_type (x0, x1) ->\n Ast_409.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_408.Parsetree.Pwith_module (x0, x1) ->\n Ast_409.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_408.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_409.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_408.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_409.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_408.Parsetree.signature -> Ast_409.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_408.Parsetree.signature_item -> Ast_409.Parsetree.signature_item =\n fun { Ast_408.Parsetree.psig_desc; Ast_408.Parsetree.psig_loc } ->\n {\n Ast_409.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_409.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_408.Parsetree.signature_item_desc ->\n Ast_409.Parsetree.signature_item_desc = function\n | Ast_408.Parsetree.Psig_value x0 ->\n Ast_409.Parsetree.Psig_value (copy_value_description x0)\n | Ast_408.Parsetree.Psig_type (x0, x1) ->\n Ast_409.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_408.Parsetree.Psig_typesubst x0 ->\n Ast_409.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_408.Parsetree.Psig_typext x0 ->\n Ast_409.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_408.Parsetree.Psig_exception x0 ->\n Ast_409.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_408.Parsetree.Psig_module x0 ->\n Ast_409.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_408.Parsetree.Psig_modsubst x0 ->\n Ast_409.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_408.Parsetree.Psig_recmodule x0 ->\n Ast_409.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_408.Parsetree.Psig_modtype x0 ->\n Ast_409.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_408.Parsetree.Psig_open x0 ->\n Ast_409.Parsetree.Psig_open (copy_open_description x0)\n | Ast_408.Parsetree.Psig_include x0 ->\n Ast_409.Parsetree.Psig_include (copy_include_description x0)\n | Ast_408.Parsetree.Psig_class x0 ->\n Ast_409.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_408.Parsetree.Psig_class_type x0 ->\n Ast_409.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_408.Parsetree.Psig_attribute x0 ->\n Ast_409.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_408.Parsetree.Psig_extension (x0, x1) ->\n Ast_409.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_408.Parsetree.class_type_declaration ->\n Ast_409.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_408.Parsetree.class_description -> Ast_409.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_408.Parsetree.class_type -> Ast_409.Parsetree.class_type =\n fun {\n Ast_408.Parsetree.pcty_desc;\n Ast_408.Parsetree.pcty_loc;\n Ast_408.Parsetree.pcty_attributes;\n } ->\n {\n Ast_409.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_409.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_409.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_408.Parsetree.class_type_desc -> Ast_409.Parsetree.class_type_desc =\n function\n | Ast_408.Parsetree.Pcty_constr (x0, x1) ->\n Ast_409.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_408.Parsetree.Pcty_signature x0 ->\n Ast_409.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_408.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_409.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_408.Parsetree.Pcty_extension x0 ->\n Ast_409.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_408.Parsetree.Pcty_open (x0, x1) ->\n Ast_409.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_408.Parsetree.class_signature -> Ast_409.Parsetree.class_signature =\n fun { Ast_408.Parsetree.pcsig_self; Ast_408.Parsetree.pcsig_fields } ->\n {\n Ast_409.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_409.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_408.Parsetree.class_type_field -> Ast_409.Parsetree.class_type_field =\n fun {\n Ast_408.Parsetree.pctf_desc;\n Ast_408.Parsetree.pctf_loc;\n Ast_408.Parsetree.pctf_attributes;\n } ->\n {\n Ast_409.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_409.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_409.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_408.Parsetree.class_type_field_desc ->\n Ast_409.Parsetree.class_type_field_desc = function\n | Ast_408.Parsetree.Pctf_inherit x0 ->\n Ast_409.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_408.Parsetree.Pctf_val x0 ->\n Ast_409.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_408.Parsetree.Pctf_method x0 ->\n Ast_409.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_408.Parsetree.Pctf_constraint x0 ->\n Ast_409.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_408.Parsetree.Pctf_attribute x0 ->\n Ast_409.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_408.Parsetree.Pctf_extension x0 ->\n Ast_409.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_408.Parsetree.extension -> Ast_409.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_408.Parsetree.class_infos ->\n 'g0 Ast_409.Parsetree.class_infos =\n fun f0\n {\n Ast_408.Parsetree.pci_virt;\n Ast_408.Parsetree.pci_params;\n Ast_408.Parsetree.pci_name;\n Ast_408.Parsetree.pci_expr;\n Ast_408.Parsetree.pci_loc;\n Ast_408.Parsetree.pci_attributes;\n } ->\n {\n Ast_409.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_409.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_409.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_409.Parsetree.pci_expr = f0 pci_expr;\n Ast_409.Parsetree.pci_loc = copy_location pci_loc;\n Ast_409.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_408.Asttypes.virtual_flag -> Ast_409.Asttypes.virtual_flag = function\n | Ast_408.Asttypes.Virtual -> Ast_409.Asttypes.Virtual\n | Ast_408.Asttypes.Concrete -> Ast_409.Asttypes.Concrete\n\nand copy_include_description :\n Ast_408.Parsetree.include_description ->\n Ast_409.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_408.Parsetree.include_infos ->\n 'g0 Ast_409.Parsetree.include_infos =\n fun f0\n {\n Ast_408.Parsetree.pincl_mod;\n Ast_408.Parsetree.pincl_loc;\n Ast_408.Parsetree.pincl_attributes;\n } ->\n {\n Ast_409.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_409.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_409.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_408.Parsetree.open_description -> Ast_409.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_408.Parsetree.open_infos ->\n 'g0 Ast_409.Parsetree.open_infos =\n fun f0\n {\n Ast_408.Parsetree.popen_expr;\n Ast_408.Parsetree.popen_override;\n Ast_408.Parsetree.popen_loc;\n Ast_408.Parsetree.popen_attributes;\n } ->\n {\n Ast_409.Parsetree.popen_expr = f0 popen_expr;\n Ast_409.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_409.Parsetree.popen_loc = copy_location popen_loc;\n Ast_409.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_408.Asttypes.override_flag -> Ast_409.Asttypes.override_flag = function\n | Ast_408.Asttypes.Override -> Ast_409.Asttypes.Override\n | Ast_408.Asttypes.Fresh -> Ast_409.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_408.Parsetree.module_type_declaration ->\n Ast_409.Parsetree.module_type_declaration =\n fun {\n Ast_408.Parsetree.pmtd_name;\n Ast_408.Parsetree.pmtd_type;\n Ast_408.Parsetree.pmtd_attributes;\n Ast_408.Parsetree.pmtd_loc;\n } ->\n {\n Ast_409.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_409.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_409.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_409.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_408.Parsetree.module_substitution ->\n Ast_409.Parsetree.module_substitution =\n fun {\n Ast_408.Parsetree.pms_name;\n Ast_408.Parsetree.pms_manifest;\n Ast_408.Parsetree.pms_attributes;\n Ast_408.Parsetree.pms_loc;\n } ->\n {\n Ast_409.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_409.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_409.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_409.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_408.Parsetree.module_declaration -> Ast_409.Parsetree.module_declaration\n =\n fun {\n Ast_408.Parsetree.pmd_name;\n Ast_408.Parsetree.pmd_type;\n Ast_408.Parsetree.pmd_attributes;\n Ast_408.Parsetree.pmd_loc;\n } ->\n {\n Ast_409.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n Ast_409.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_409.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_409.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_408.Parsetree.type_exception -> Ast_409.Parsetree.type_exception =\n fun {\n Ast_408.Parsetree.ptyexn_constructor;\n Ast_408.Parsetree.ptyexn_loc;\n Ast_408.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_409.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_409.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_408.Parsetree.type_extension -> Ast_409.Parsetree.type_extension =\n fun {\n Ast_408.Parsetree.ptyext_path;\n Ast_408.Parsetree.ptyext_params;\n Ast_408.Parsetree.ptyext_constructors;\n Ast_408.Parsetree.ptyext_private;\n Ast_408.Parsetree.ptyext_loc;\n Ast_408.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_409.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_409.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_409.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_409.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_409.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_408.Parsetree.extension_constructor ->\n Ast_409.Parsetree.extension_constructor =\n fun {\n Ast_408.Parsetree.pext_name;\n Ast_408.Parsetree.pext_kind;\n Ast_408.Parsetree.pext_loc;\n Ast_408.Parsetree.pext_attributes;\n } ->\n {\n Ast_409.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_409.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_409.Parsetree.pext_loc = copy_location pext_loc;\n Ast_409.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_408.Parsetree.extension_constructor_kind ->\n Ast_409.Parsetree.extension_constructor_kind = function\n | Ast_408.Parsetree.Pext_decl (x0, x1) ->\n Ast_409.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_408.Parsetree.Pext_rebind x0 ->\n Ast_409.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_408.Parsetree.type_declaration -> Ast_409.Parsetree.type_declaration =\n fun {\n Ast_408.Parsetree.ptype_name;\n Ast_408.Parsetree.ptype_params;\n Ast_408.Parsetree.ptype_cstrs;\n Ast_408.Parsetree.ptype_kind;\n Ast_408.Parsetree.ptype_private;\n Ast_408.Parsetree.ptype_manifest;\n Ast_408.Parsetree.ptype_attributes;\n Ast_408.Parsetree.ptype_loc;\n } ->\n {\n Ast_409.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_409.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_409.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_409.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_409.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_409.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_409.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_409.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_408.Asttypes.private_flag -> Ast_409.Asttypes.private_flag = function\n | Ast_408.Asttypes.Private -> Ast_409.Asttypes.Private\n | Ast_408.Asttypes.Public -> Ast_409.Asttypes.Public\n\nand copy_type_kind : Ast_408.Parsetree.type_kind -> Ast_409.Parsetree.type_kind\n = function\n | Ast_408.Parsetree.Ptype_abstract -> Ast_409.Parsetree.Ptype_abstract\n | Ast_408.Parsetree.Ptype_variant x0 ->\n Ast_409.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_408.Parsetree.Ptype_record x0 ->\n Ast_409.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_408.Parsetree.Ptype_open -> Ast_409.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_408.Parsetree.constructor_declaration ->\n Ast_409.Parsetree.constructor_declaration =\n fun {\n Ast_408.Parsetree.pcd_name;\n Ast_408.Parsetree.pcd_args;\n Ast_408.Parsetree.pcd_res;\n Ast_408.Parsetree.pcd_loc;\n Ast_408.Parsetree.pcd_attributes;\n } ->\n {\n Ast_409.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_409.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_409.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_409.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_409.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_408.Parsetree.constructor_arguments ->\n Ast_409.Parsetree.constructor_arguments = function\n | Ast_408.Parsetree.Pcstr_tuple x0 ->\n Ast_409.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_408.Parsetree.Pcstr_record x0 ->\n Ast_409.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_408.Parsetree.label_declaration -> Ast_409.Parsetree.label_declaration =\n fun {\n Ast_408.Parsetree.pld_name;\n Ast_408.Parsetree.pld_mutable;\n Ast_408.Parsetree.pld_type;\n Ast_408.Parsetree.pld_loc;\n Ast_408.Parsetree.pld_attributes;\n } ->\n {\n Ast_409.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_409.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_409.Parsetree.pld_type = copy_core_type pld_type;\n Ast_409.Parsetree.pld_loc = copy_location pld_loc;\n Ast_409.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_408.Asttypes.mutable_flag -> Ast_409.Asttypes.mutable_flag = function\n | Ast_408.Asttypes.Immutable -> Ast_409.Asttypes.Immutable\n | Ast_408.Asttypes.Mutable -> Ast_409.Asttypes.Mutable\n\nand copy_variance : Ast_408.Asttypes.variance -> Ast_409.Asttypes.variance =\n function\n | Ast_408.Asttypes.Covariant -> Ast_409.Asttypes.Covariant\n | Ast_408.Asttypes.Contravariant -> Ast_409.Asttypes.Contravariant\n | Ast_408.Asttypes.Invariant -> Ast_409.Asttypes.Invariant\n\nand copy_value_description :\n Ast_408.Parsetree.value_description -> Ast_409.Parsetree.value_description =\n fun {\n Ast_408.Parsetree.pval_name;\n Ast_408.Parsetree.pval_type;\n Ast_408.Parsetree.pval_prim;\n Ast_408.Parsetree.pval_attributes;\n Ast_408.Parsetree.pval_loc;\n } ->\n {\n Ast_409.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_409.Parsetree.pval_type = copy_core_type pval_type;\n Ast_409.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_409.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_409.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_408.Parsetree.object_field_desc -> Ast_409.Parsetree.object_field_desc =\n function\n | Ast_408.Parsetree.Otag (x0, x1) ->\n Ast_409.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_408.Parsetree.Oinherit x0 ->\n Ast_409.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_408.Asttypes.arg_label -> Ast_409.Asttypes.arg_label =\n function\n | Ast_408.Asttypes.Nolabel -> Ast_409.Asttypes.Nolabel\n | Ast_408.Asttypes.Labelled x0 -> Ast_409.Asttypes.Labelled x0\n | Ast_408.Asttypes.Optional x0 -> Ast_409.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_408.Asttypes.closed_flag -> Ast_409.Asttypes.closed_flag = function\n | Ast_408.Asttypes.Closed -> Ast_409.Asttypes.Closed\n | Ast_408.Asttypes.Open -> Ast_409.Asttypes.Open\n\nand copy_label : Ast_408.Asttypes.label -> Ast_409.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_408.Asttypes.rec_flag -> Ast_409.Asttypes.rec_flag =\n function\n | Ast_408.Asttypes.Nonrecursive -> Ast_409.Asttypes.Nonrecursive\n | Ast_408.Asttypes.Recursive -> Ast_409.Asttypes.Recursive\n\nand copy_constant : Ast_408.Parsetree.constant -> Ast_409.Parsetree.constant =\n function\n | Ast_408.Parsetree.Pconst_integer (x0, x1) ->\n Ast_409.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_408.Parsetree.Pconst_char x0 -> Ast_409.Parsetree.Pconst_char x0\n | Ast_408.Parsetree.Pconst_string (x0, x1) ->\n Ast_409.Parsetree.Pconst_string (x0, Option.map (fun x -> x) x1)\n | Ast_408.Parsetree.Pconst_float (x0, x1) ->\n Ast_409.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_408.Asttypes.loc -> 'g0 Ast_409.Asttypes.loc =\n fun f0 { Ast_408.Asttypes.txt; Ast_408.Asttypes.loc } ->\n { Ast_409.Asttypes.txt = f0 txt; Ast_409.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","module From = Ast_408\nmodule To = Ast_407\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.08\" missing_feature\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir\n {\n From.Parsetree.pdir_name;\n From.Parsetree.pdir_arg;\n From.Parsetree.pdir_loc = _;\n } ->\n To.Parsetree.Ptop_dir\n ( pdir_name.Location.txt,\n match pdir_arg with\n | None -> To.Parsetree.Pdir_none\n | Some arg -> copy_directive_argument arg )\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n fun { From.Parsetree.pdira_desc; From.Parsetree.pdira_loc = _pdira_loc } ->\n copy_directive_argument_desc pdira_desc\n\nand copy_directive_argument_desc :\n From.Parsetree.directive_argument_desc -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nand copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_loc_stack = _;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc copy_label x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1) -> (\n match x0.From.Parsetree.popen_expr.From.Parsetree.pmod_desc with\n | Pmod_ident lid ->\n To.Parsetree.Pexp_open\n ( copy_override_flag x0.From.Parsetree.popen_override,\n copy_loc copy_longident lid,\n copy_expression x1 )\n | Pmod_structure _ | Pmod_functor _ | Pmod_apply _ | Pmod_constraint _\n | Pmod_unpack _ | Pmod_extension _ ->\n migration_error x0.From.Parsetree.popen_loc \"complex open\")\n | From.Parsetree.Pexp_letop { let_; ands = _; body = _ } ->\n migration_error let_.pbop_op.loc \"let operators\"\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_loc_stack = _;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_loc_stack = _;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n fun {\n From.Parsetree.prf_desc;\n From.Parsetree.prf_loc = _;\n From.Parsetree.prf_attributes;\n } ->\n match prf_desc with\n | From.Parsetree.Rtag (x0, x1, x2) ->\n To.Parsetree.Rtag\n ( copy_loc copy_label x0,\n copy_attributes prf_attributes,\n copy_bool x1,\n List.map copy_core_type x2 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field : From.Parsetree.object_field -> To.Parsetree.object_field\n =\n fun {\n From.Parsetree.pof_desc;\n From.Parsetree.pof_loc = _;\n From.Parsetree.pof_attributes;\n } ->\n match pof_desc with\n | From.Parsetree.Otag (x0, x1) ->\n To.Parsetree.Otag\n ( copy_loc copy_label x0,\n copy_attributes pof_attributes,\n copy_core_type x1 )\n | From.Parsetree.Oinherit x0 -> To.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun {\n From.Parsetree.attr_name;\n From.Parsetree.attr_payload;\n From.Parsetree.attr_loc = _;\n } ->\n (copy_loc (fun x -> x) attr_name, copy_payload attr_payload)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception\n (let e =\n copy_extension_constructor x0.From.Parsetree.ptyexn_constructor\n in\n {\n e with\n pext_attributes =\n e.pext_attributes @ copy_attributes x0.ptyexn_attributes;\n })\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 -> (\n match x0.From.Parsetree.popen_expr.From.Parsetree.pmod_desc with\n | Pmod_ident lid ->\n To.Parsetree.Pstr_open\n {\n To.Parsetree.popen_lid = copy_loc copy_longident lid;\n To.Parsetree.popen_override =\n copy_override_flag x0.From.Parsetree.popen_override;\n To.Parsetree.popen_loc = copy_location x0.From.Parsetree.popen_loc;\n To.Parsetree.popen_attributes =\n copy_attributes x0.From.Parsetree.popen_attributes;\n }\n | Pmod_structure _ | Pmod_functor _ | Pmod_apply _ | Pmod_constraint _\n | Pmod_unpack _ | Pmod_extension _ ->\n migration_error x0.From.Parsetree.popen_loc \"complex open\")\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n | From.Parsetree.Pcl_open (x0, x1) ->\n To.Parsetree.Pcl_open\n ( copy_override_flag x0.From.Parsetree.popen_override,\n copy_loc copy_longident x0.From.Parsetree.popen_expr,\n copy_class_expr x1 )\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (fun x -> copy_loc (fun x -> x) x) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst (x0, x1) ->\n To.Parsetree.Pwith_typesubst\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typesubst x0 ->\n let x0_loc =\n match x0 with\n | [] -> Location.none\n | { From.Parsetree.ptype_loc; _ } :: _ -> ptype_loc\n in\n migration_error x0_loc \"type substitution in signatures\"\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception\n (let e =\n copy_extension_constructor x0.From.Parsetree.ptyexn_constructor\n in\n {\n e with\n pext_attributes =\n e.pext_attributes @ copy_attributes x0.ptyexn_attributes;\n })\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_modsubst x0 ->\n migration_error x0.pms_loc \"module substitution in signatures\"\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n | From.Parsetree.Pcty_open (x0, x1) ->\n To.Parsetree.Pcty_open\n ( copy_override_flag x0.From.Parsetree.popen_override,\n copy_loc copy_longident x0.From.Parsetree.popen_expr,\n copy_class_type x1 )\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n let x1 =\n match x0.txt with\n | \"ocaml.error\" | \"error\" -> (\n match x1 with\n | PStr (hd :: tl) -> From.Parsetree.PStr (hd :: hd :: tl)\n | _ -> x1)\n | _ -> x1\n in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_expr;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_expr;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\n(* and copy_type_exception :\n From.Parsetree.type_exception -> To.Parsetree.type_exception =\n fun\n { From.Parsetree.ptyexn_constructor = ptyexn_constructor;\n From.Parsetree.ptyexn_loc = ptyexn_loc;\n From.Parsetree.ptyexn_attributes = ptyexn_attributes }\n ->\n {\n To.Parsetree.ptyexn_constructor =\n (copy_extension_constructor ptyexn_constructor);\n To.Parsetree.ptyexn_loc = (copy_location ptyexn_loc);\n To.Parsetree.ptyexn_attributes =\n (copy_attributes ptyexn_attributes)\n }*)\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_loc = _;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","module From = Ast_407\nmodule To = Ast_408\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir\n {\n To.Parsetree.pdir_name =\n { Location.txt = x0; Location.loc = Location.none };\n To.Parsetree.pdir_arg = copy_directive_argument x1;\n To.Parsetree.pdir_loc = Location.none;\n }\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument option\n =\n let wrap pdira_desc =\n Some { To.Parsetree.pdira_desc; To.Parsetree.pdira_loc = Location.none }\n in\n function\n | From.Parsetree.Pdir_none -> None\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0 |> wrap\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1) |> wrap\n | From.Parsetree.Pdir_ident x0 ->\n To.Parsetree.Pdir_ident (copy_longident x0) |> wrap\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0) |> wrap\n\nand copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_loc_stack = [];\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc copy_label x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n ( {\n To.Parsetree.popen_expr =\n {\n To.Parsetree.pmod_desc =\n To.Parsetree.Pmod_ident (copy_loc copy_longident x1);\n To.Parsetree.pmod_loc = x1.Location.loc;\n To.Parsetree.pmod_attributes = [];\n };\n To.Parsetree.popen_override = copy_override_flag x0;\n To.Parsetree.popen_loc = x1.Location.loc;\n To.Parsetree.popen_attributes = [];\n },\n copy_expression x2 )\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_loc_stack = [];\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_loc_stack = [];\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n {\n To.Parsetree.prf_desc =\n To.Parsetree.Rtag\n (copy_loc copy_label x0, copy_bool x2, List.map copy_core_type x3);\n To.Parsetree.prf_loc = x0.Location.loc;\n To.Parsetree.prf_attributes = copy_attributes x1;\n }\n | From.Parsetree.Rinherit x0 ->\n {\n To.Parsetree.prf_desc = To.Parsetree.Rinherit (copy_core_type x0);\n To.Parsetree.prf_loc = x0.From.Parsetree.ptyp_loc;\n To.Parsetree.prf_attributes = [];\n }\n\nand copy_object_field : From.Parsetree.object_field -> To.Parsetree.object_field\n = function\n | From.Parsetree.Otag (x0, x1, x2) ->\n {\n To.Parsetree.pof_desc =\n To.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x2);\n To.Parsetree.pof_loc = x0.Location.loc;\n To.Parsetree.pof_attributes = copy_attributes x1;\n }\n | From.Parsetree.Oinherit x0 ->\n {\n To.Parsetree.pof_desc = To.Parsetree.Oinherit (copy_core_type x0);\n To.Parsetree.pof_loc = x0.From.Parsetree.ptyp_loc;\n To.Parsetree.pof_attributes = [];\n }\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n {\n To.Parsetree.attr_name = copy_loc (fun x -> x) x0;\n To.Parsetree.attr_payload = copy_payload x1;\n To.Parsetree.attr_loc = x0.Location.loc;\n }\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n let atat, at =\n List.partition\n (function\n | { Location.txt = \"ocaml.deprecated\" | \"deprecated\"; _ }, _ ->\n false\n | _ -> true)\n x0.pext_attributes\n in\n let x0 = { x0 with pext_attributes = at } in\n To.Parsetree.Pstr_exception\n {\n To.Parsetree.ptyexn_constructor = copy_extension_constructor x0;\n To.Parsetree.ptyexn_loc = x0.From.Parsetree.pext_loc;\n To.Parsetree.ptyexn_attributes = copy_attributes atat;\n }\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open\n {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n To.Parsetree.Pstr_open\n {\n To.Parsetree.popen_expr =\n {\n To.Parsetree.pmod_desc =\n To.Parsetree.Pmod_ident (copy_loc copy_longident popen_lid);\n To.Parsetree.pmod_loc = popen_loc;\n To.Parsetree.pmod_attributes = [];\n };\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n | From.Parsetree.Pcl_open (x0, x1, x2) ->\n To.Parsetree.Pcl_open\n ( {\n To.Parsetree.popen_expr = copy_loc copy_longident x1;\n To.Parsetree.popen_override = copy_override_flag x0;\n To.Parsetree.popen_loc = x1.Location.loc;\n To.Parsetree.popen_attributes = [];\n },\n copy_class_expr x2 )\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n let fields =\n List.sort\n (fun (a : From.Parsetree.class_field) (b : From.Parsetree.class_field) ->\n compare a.pcf_loc.loc_start.pos_cnum b.pcf_loc.loc_start.pos_cnum)\n pcstr_fields\n in\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (fun x -> copy_loc (fun x -> x) x) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst (x0, x1) ->\n To.Parsetree.Pwith_typesubst\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n let atat, at =\n List.partition\n (function\n | { Location.txt = \"ocaml.deprecated\" | \"deprecated\"; _ }, _ ->\n false\n | _ -> true)\n x0.pext_attributes\n in\n let x0 = { x0 with pext_attributes = at } in\n\n To.Parsetree.Psig_exception\n {\n To.Parsetree.ptyexn_constructor = copy_extension_constructor x0;\n To.Parsetree.ptyexn_loc = x0.From.Parsetree.pext_loc;\n To.Parsetree.ptyexn_attributes = copy_attributes atat;\n }\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n | From.Parsetree.Pcty_open (x0, x1, x2) ->\n To.Parsetree.Pcty_open\n ( {\n To.Parsetree.popen_expr = copy_loc copy_longident x1;\n To.Parsetree.popen_override = copy_override_flag x0;\n To.Parsetree.popen_loc = x1.Location.loc;\n To.Parsetree.popen_attributes = [];\n },\n copy_class_type x2 )\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n let fields =\n List.sort\n (fun (a : From.Parsetree.class_type_field)\n (b : From.Parsetree.class_type_field) ->\n compare a.pctf_loc.loc_start.pos_cnum b.pctf_loc.loc_start.pos_cnum)\n pcsig_fields\n in\n\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n let x1 =\n match x0.txt with\n | \"ocaml.error\" | \"error\" -> (\n match x1 with\n | PStr (hd :: _ :: tl) -> From.Parsetree.PStr (hd :: tl)\n | _ -> x1)\n | _ -> x1\n in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_expr = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_loc = ptyext_path.Location.loc;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_407\nmodule To = Ast_406\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_loc copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field : From.Parsetree.object_field -> To.Parsetree.object_field\n = function\n | From.Parsetree.Otag (x0, x1, x2) ->\n To.Parsetree.Otag\n (copy_loc (fun x -> x) x0, copy_attributes x1, copy_core_type x2)\n | From.Parsetree.Oinherit x -> To.Parsetree.Oinherit (copy_core_type x)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n | From.Parsetree.Pcl_open (ovf, loc, ce) ->\n To.Parsetree.Pcl_open\n (copy_override_flag ovf, copy_loc copy_longident loc, copy_class_expr ce)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (copy_loc (fun x -> x)) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst (x0, x1) ->\n To.Parsetree.Pwith_typesubst\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n | From.Parsetree.Pcty_open (ovf, loc, cty) ->\n To.Parsetree.Pcty_open\n ( copy_override_flag ovf,\n copy_loc copy_longident loc,\n copy_class_type cty )\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_406\nmodule To = Ast_407\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_loc copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field : From.Parsetree.object_field -> To.Parsetree.object_field\n = function\n | From.Parsetree.Otag (x0, x1, x2) ->\n To.Parsetree.Otag\n (copy_loc (fun x -> x) x0, copy_attributes x1, copy_core_type x2)\n | From.Parsetree.Oinherit x -> To.Parsetree.Oinherit (copy_core_type x)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n | From.Parsetree.Pcl_open (ovf, loc, ce) ->\n To.Parsetree.Pcl_open\n (copy_override_flag ovf, copy_loc copy_longident loc, copy_class_expr ce)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (copy_loc (fun x -> x)) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst (x0, x1) ->\n To.Parsetree.Pwith_typesubst\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n | From.Parsetree.Pcty_open (ovf, loc, cty) ->\n To.Parsetree.Pcty_open\n ( copy_override_flag ovf,\n copy_loc copy_longident loc,\n copy_class_type cty )\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_406\nmodule To = Ast_405\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.06\" missing_feature\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (function\n | From.Parsetree.Otag (x0, x1, x2) ->\n ( copy_loc (fun x -> x) x0,\n copy_attributes x1,\n copy_core_type x2 )\n | From.Parsetree.Oinherit _ ->\n migration_error Location.none \"inheritance in object type\")\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0.txt,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n | From.Parsetree.Pcl_open (_, loc, _) ->\n migration_error loc.Location.loc \"module open in class expression\"\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (copy_loc (fun x -> x)) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst ({ txt = Longident.Lident _; _ }, x0) ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst ({ txt = Longident.Lident x0; loc }, x1) ->\n To.Parsetree.Pwith_modsubst ({ txt = x0; loc }, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst ({ loc; _ }, _x0) ->\n migration_error loc \"type substitution inside a submodule\"\n | From.Parsetree.Pwith_modsubst ({ loc; _ }, _x1) ->\n migration_error loc \"module substitution inside a submodule\"\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n | From.Parsetree.Pcty_open (_, loc, _) ->\n migration_error loc.Location.loc \"module open in class type\"\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_405\nmodule To = Ast_406\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n To.Parsetree.Otag\n (copy_loc (fun x -> x) x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( { txt = copy_label x0; loc = Location.none },\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (copy_loc (fun x -> x)) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst\n ( copy_loc (fun x -> Longident.Lident x) x0.From.Parsetree.ptype_name,\n copy_type_declaration x0 )\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> Longident.Lident x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_405\nmodule To = Ast_404\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, x1.From.Asttypes.txt)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (x0.From.Asttypes.txt, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (x0.From.Asttypes.txt, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> x.From.Asttypes.txt) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (fun x -> x.From.Asttypes.txt) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( x0.From.Asttypes.txt,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( x0.From.Asttypes.txt,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_404\nmodule To = Ast_405\n\nlet noloc x = { Location.txt = x; loc = Location.none }\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, noloc x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (noloc x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (noloc x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly (List.map (fun x -> noloc x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (fun x -> noloc x) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( noloc x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( noloc x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_404\nmodule To = Ast_403\n\nlet from_loc { Location.txt = _; loc } = loc\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.04\" missing_feature\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_loc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc loc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception _ -> migration_error loc \"local exceptions\"\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_loc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc loc :\n From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open _ -> migration_error loc \"module open in patterns\"\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly (List.map (fun x -> x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n (copy_override_flag x0, copy_class_expr x1, copy_option (fun x -> x) x2)\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_mutable_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_private_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_403\nmodule To = Ast_404\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly (List.map (fun x -> x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n (copy_override_flag x0, copy_class_expr x1, copy_option (fun x -> x) x2)\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_mutable_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_private_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_402\nmodule To = Ast_403\n\nlet extract_predef_option label typ =\n let open From in\n let open Longident in\n match (label, typ.Parsetree.ptyp_desc) with\n | ( To.Asttypes.Optional _,\n From.Parsetree.Ptyp_constr\n ({ Location.txt = Ldot (Lident \"*predef*\", \"option\"); _ }, [ d ]) ) ->\n d\n | _ -> typ\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n let label = copy_arg_label x0 in\n To.Parsetree.Ptyp_arrow\n ( label,\n copy_core_type (extract_predef_option label x1),\n copy_core_type x2 )\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly (List.map (fun x -> x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type x0 ->\n let recflag, types = type_declarations x0 in\n To.Parsetree.Pstr_type (recflag, types)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n (copy_override_flag x0, copy_class_expr x1, copy_option (fun x -> x) x2)\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type x0 ->\n let recflag, types = type_declarations x0 in\n To.Parsetree.Psig_type (recflag, types)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n let label = copy_arg_label x0 in\n To.Parsetree.Pcty_arrow\n ( label,\n copy_core_type (extract_predef_option label x1),\n copy_class_type x2 )\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_mutable_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_private_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n ( To.Parsetree.Pcstr_tuple (List.map copy_core_type x0),\n copy_option copy_core_type x1 )\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args =\n To.Parsetree.Pcstr_tuple (List.map copy_core_type pcd_args);\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_arg_label : From.Asttypes.label -> To.Asttypes.arg_label =\n fun x ->\n if x <> \"\" then\n if x.[0] = '?' then\n To.Asttypes.Optional (String.sub x 1 (String.length x - 1))\n else To.Asttypes.Labelled x\n else To.Asttypes.Nolabel\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Asttypes.constant -> To.Parsetree.constant = function\n | From.Asttypes.Const_int x0 ->\n To.Parsetree.Pconst_integer (string_of_int x0, None)\n | From.Asttypes.Const_char x0 -> To.Parsetree.Pconst_char x0\n | From.Asttypes.Const_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Asttypes.Const_float x0 -> To.Parsetree.Pconst_float (x0, None)\n | From.Asttypes.Const_int32 x0 ->\n To.Parsetree.Pconst_integer (Int32.to_string x0, Some 'l')\n | From.Asttypes.Const_int64 x0 ->\n To.Parsetree.Pconst_integer (Int64.to_string x0, Some 'L')\n | From.Asttypes.Const_nativeint x0 ->\n To.Parsetree.Pconst_integer (Nativeint.to_string x0, Some 'n')\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nand type_declarations types =\n let is_nonrec (attr, _) = attr.Location.txt = \"nonrec\" in\n match List.map copy_type_declaration types with\n | x :: xs when List.exists is_nonrec x.To.Parsetree.ptype_attributes ->\n let ptype_attributes =\n List.filter (fun x -> not (is_nonrec x)) x.To.Parsetree.ptype_attributes\n in\n (To.Asttypes.Nonrecursive, { x with To.Parsetree.ptype_attributes } :: xs)\n | types -> (To.Asttypes.Recursive, types)\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int x0 -> To.Parsetree.Pdir_int (string_of_int x0, None)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(* This file is used to control what we use from the current compiler and what is embed in\n this library.\n\n It must be opened in all modules, especially the ones coming from the compiler.\n*)\n\nmodule Js = Versions.OCaml_412\nmodule Ocaml = Versions.OCaml_current\n\nmodule Select_ast (Ocaml : Versions.OCaml_version) = struct\n include Js\n\n module Type = struct\n type ('js, 'ocaml) t =\n | Signature\n : (Js.Ast.Parsetree.signature, Ocaml.Ast.Parsetree.signature) t\n | Structure\n : (Js.Ast.Parsetree.structure, Ocaml.Ast.Parsetree.structure) t\n | Toplevel_phrase\n : ( Js.Ast.Parsetree.toplevel_phrase,\n Ocaml.Ast.Parsetree.toplevel_phrase )\n t\n | Expression\n : (Js.Ast.Parsetree.expression, Ocaml.Ast.Parsetree.expression) t\n | Core_type\n : (Js.Ast.Parsetree.core_type, Ocaml.Ast.Parsetree.core_type) t\n | Type_declaration\n : ( Js.Ast.Parsetree.type_declaration,\n Ocaml.Ast.Parsetree.type_declaration )\n t\n | Type_extension\n : ( Js.Ast.Parsetree.type_extension,\n Ocaml.Ast.Parsetree.type_extension )\n t\n | Extension_constructor\n : ( Js.Ast.Parsetree.extension_constructor,\n Ocaml.Ast.Parsetree.extension_constructor )\n t\n | List : ('a, 'b) t -> ('a list, 'b list) t\n | Pair : ('a, 'b) t * ('c, 'd) t -> ('a * 'c, 'b * 'd) t\n end\n\n open Type\n module Of_ocaml = Versions.Convert (Ocaml) (Js)\n module To_ocaml = Versions.Convert (Js) (Ocaml)\n\n let rec of_ocaml : type ocaml js. (js, ocaml) Type.t -> ocaml -> js =\n let open Of_ocaml in\n fun node ->\n match node with\n | Signature -> copy_signature\n | Structure -> copy_structure\n | Toplevel_phrase -> copy_toplevel_phrase\n | Expression -> copy_expression\n | Core_type -> copy_core_type\n | Type_declaration -> copy_type_declaration\n | Type_extension -> copy_type_extension\n | Extension_constructor -> copy_extension_constructor\n | List t -> List.map (of_ocaml t)\n | Pair (a, b) ->\n let f = of_ocaml a in\n let g = of_ocaml b in\n fun (x, y) -> (f x, g y)\n\n let rec to_ocaml : type ocaml js. (js, ocaml) Type.t -> js -> ocaml =\n let open To_ocaml in\n fun node ->\n match node with\n | Signature -> copy_signature\n | Structure -> copy_structure\n | Toplevel_phrase -> copy_toplevel_phrase\n | Expression -> copy_expression\n | Core_type -> copy_core_type\n | Type_declaration -> copy_type_declaration\n | Type_extension -> copy_type_extension\n | Extension_constructor -> copy_extension_constructor\n | List t -> List.map (to_ocaml t)\n | Pair (a, b) ->\n let f = to_ocaml a in\n let g = to_ocaml b in\n fun (x, y) -> (f x, g y)\n\n let of_ocaml_mapper item f ctxt x = to_ocaml item x |> f ctxt |> of_ocaml item\n let to_ocaml_mapper item f ctxt x = of_ocaml item x |> f ctxt |> to_ocaml item\nend\n\nmodule Selected_ast = Select_ast (Ocaml)\nmodule Ast_helper = Ast_helper_lite\n\n(* Modules from Ast_ of Astlib, where is the compiler version the ppxlib driver is compiled with *)\nmodule Parsetree = Selected_ast.Ast.Parsetree\nmodule Asttypes = Selected_ast.Ast.Asttypes\n\n(* Other Astlib modules *)\nmodule Location = Astlib.Location\nmodule Longident = Astlib.Longident\n\nmodule Parse = struct\n include Astlib.Parse\n module Of_ocaml = Versions.Convert (Ocaml) (Js)\n\n let implementation lexbuf = implementation lexbuf |> Of_ocaml.copy_structure\n let interface lexbuf = interface lexbuf |> Of_ocaml.copy_signature\n\n let toplevel_phrase lexbuf =\n toplevel_phrase lexbuf |> Of_ocaml.copy_toplevel_phrase\n\n let use_file lexbuf =\n use_file lexbuf |> List.map Of_ocaml.copy_toplevel_phrase\n\n let core_type lexbuf = core_type lexbuf |> Of_ocaml.copy_core_type\n let expression lexbuf = expression lexbuf |> Of_ocaml.copy_expression\n let pattern lexbuf = pattern lexbuf |> Of_ocaml.copy_pattern\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(** Definition of the OCaml AST *)\n\nopen Import\n\n(* This file is obtained by:\n\n - copying a subset of the corresponding ast_xxx.ml file from Astlib\n (sub-modules Asttypes and Parsetree)\n - adding the type definitions for position, location, loc and longident\n - flattening all the modules\n - removing Asttypes.constant (unused and conflicts with Parsetree.constant)\n - renaming a few types:\n - - Location.t -> location\n - - Longident.t -> longident\n - adding a type longident_loc = longident loc and replacing all the occurrences of the\n latter by the former. This is so that we can override iteration an the level of a\n longident loc\n - adding a type cases = case list\n - replacing all the (*IF_CURRENT = Foo.bar*) by: = Foo.bar\n - removing the extra values at the end of the file\n - replacing app [type ...] by [and ...] to make everything one recursive block\n - adding [@@deriving_inline traverse][@@@end] at the end\n\n To update it to a newer OCaml version, create a new module with the above from the\n latest compiler and add the following module definitions and opens to get it to\n compile:\n [{\n module Ast = Versions.OCaml_4xx\n open Ast.Ast\n module Location = Ocaml_common.Location\n module Longident = Ocaml_common.Longident\n }]\n\n Once you have generated the inlined derived traversal classes by running\n [{ dune build @lint }] you can replace the above mentioned module definitions by a\n [open Import] and update [Import] so that the [Js] module points to\n [Versions.OCaml_4xx].\n*)\n\n(* Source code locations (ranges of positions), used in parsetree. *)\n\ntype position = Lexing.position = {\n pos_fname : string;\n pos_lnum : int;\n pos_bol : int;\n pos_cnum : int;\n}\n\nand location = Location.t = {\n loc_start : position;\n loc_end : position;\n loc_ghost : bool;\n}\n\nand location_stack = location list\n\n(* Note on the use of Lexing.position in this module.\n If [pos_fname = \"\"], then use [!input_name] instead.\n If [pos_lnum = -1], then [pos_bol = 0]. Use [pos_cnum] and\n re-parse the file to get the line and character numbers.\n Else all fields are correct.\n*)\nand 'a loc = 'a Location.loc = { txt : 'a; loc : location }\n\n(* Long identifiers, used in parsetree. *)\nand longident = Longident.t =\n | Lident of string\n | Ldot of longident * string\n | Lapply of longident * longident\n\nand longident_loc = longident loc\n\n(** Auxiliary AST types used by parsetree and typedtree. *)\n\nand rec_flag = Asttypes.rec_flag = Nonrecursive | Recursive\n\nand direction_flag = Asttypes.direction_flag = Upto | Downto\n\n(* Order matters, used in polymorphic comparison *)\nand private_flag = Asttypes.private_flag = Private | Public\nand mutable_flag = Asttypes.mutable_flag = Immutable | Mutable\nand virtual_flag = Asttypes.virtual_flag = Virtual | Concrete\nand override_flag = Asttypes.override_flag = Override | Fresh\nand closed_flag = Asttypes.closed_flag = Closed | Open\nand label = string\n\nand arg_label = Asttypes.arg_label =\n | Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string\n(* ?label:T -> ... *)\n\nand variance = Asttypes.variance = Covariant | Contravariant | NoVariance\nand injectivity = Asttypes.injectivity = Injective | NoInjectivity\n\n(** Abstract syntax tree produced by parsing *)\n\nand constant = Parsetree.constant =\n | Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * location * string option\n (* \"constant\"\n {delim|other constant|delim}\n\n The location span the content of the string, without the delimiters.\n *)\n | Pconst_float of string * char option\n(* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n*)\n\n(** {1 Extension points} *)\n\nand attribute = Parsetree.attribute = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : location;\n}\n(* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n*)\n\nand extension = string loc * payload\n(* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n*)\n\nand attributes = attribute list\n\nand payload = Parsetree.payload =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option\n(* ? P or ? P when E *)\n\n(* Type expressions *)\n\n(** {1 Core language} *)\n\nand core_type = Parsetree.core_type = {\n ptyp_desc : core_type_desc;\n ptyp_loc : location;\n ptyp_loc_stack : location_stack;\n ptyp_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand core_type_desc = Parsetree.core_type_desc =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of longident_loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of longident_loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n(* [%id] *)\n\nand package_type = longident_loc * (longident_loc * core_type) list\n(*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n*)\n\nand row_field = Parsetree.row_field = {\n prf_desc : row_field_desc;\n prf_loc : location;\n prf_attributes : attributes;\n}\n\nand row_field_desc = Parsetree.row_field_desc =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n(* [ | t ] *)\n\nand object_field = Parsetree.object_field = {\n pof_desc : object_field_desc;\n pof_loc : location;\n pof_attributes : attributes;\n}\n\nand object_field_desc = Parsetree.object_field_desc =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n(* Patterns *)\nand pattern = Parsetree.pattern = {\n ppat_desc : pattern_desc;\n ppat_loc : location;\n ppat_loc_stack : location_stack;\n ppat_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand pattern_desc = Parsetree.pattern_desc =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of longident_loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (longident_loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of longident_loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of longident_loc * pattern\n(* M.(P) *)\n\n(* Value expressions *)\nand expression = Parsetree.expression = {\n pexp_desc : expression_desc;\n pexp_loc : location;\n pexp_loc_stack : location_stack;\n pexp_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand expression_desc = Parsetree.expression_desc =\n | Pexp_ident of longident_loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of cases\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * cases\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * cases\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of longident_loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (longident_loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * longident_loc\n (* E.l *)\n | Pexp_setfield of expression * longident_loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of longident_loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n(* . *)\n\nand case = Parsetree.case = {\n (* (P -> E) or (P when E0 -> E) *)\n pc_lhs : pattern;\n pc_guard : expression option;\n pc_rhs : expression;\n}\n\nand letop = Parsetree.letop = {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n}\n\nand binding_op = Parsetree.binding_op = {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : location;\n}\n\n(* Value descriptions *)\nand value_description = Parsetree.value_description = {\n pval_name : string loc;\n pval_type : core_type;\n pval_prim : string list;\n pval_attributes : attributes;\n (* ... [@@id1] [@@id2] *)\n pval_loc : location;\n}\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n(* Type declarations *)\nand type_declaration = Parsetree.type_declaration = {\n ptype_name : string loc;\n ptype_params : (core_type * (variance * injectivity)) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs : (core_type * core_type * location) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind : type_kind;\n ptype_private : private_flag;\n (* = private ... *)\n ptype_manifest : core_type option;\n (* = T *)\n ptype_attributes : attributes;\n (* ... [@@id1] [@@id2] *)\n ptype_loc : location;\n}\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\nand type_kind = Parsetree.type_kind =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\nand label_declaration = Parsetree.label_declaration = {\n pld_name : string loc;\n pld_mutable : mutable_flag;\n pld_type : core_type;\n pld_loc : location;\n pld_attributes : attributes; (* l : T [@id1] [@id2] *)\n}\n\n(* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n*)\nand constructor_declaration = Parsetree.constructor_declaration = {\n pcd_name : string loc;\n pcd_args : constructor_arguments;\n pcd_res : core_type option;\n pcd_loc : location;\n pcd_attributes : attributes; (* C of ... [@id1] [@id2] *)\n}\n\nand constructor_arguments = Parsetree.constructor_arguments =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\nand type_extension = Parsetree.type_extension = {\n ptyext_path : longident_loc;\n ptyext_params : (core_type * (variance * injectivity)) list;\n ptyext_constructors : extension_constructor list;\n ptyext_private : private_flag;\n ptyext_loc : location;\n ptyext_attributes : attributes; (* ... [@@id1] [@@id2] *)\n}\n(*\n type t += ...\n*)\n\nand extension_constructor = Parsetree.extension_constructor = {\n pext_name : string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : location;\n pext_attributes : attributes; (* C of ... [@id1] [@id2] *)\n}\n\nand type_exception = Parsetree.type_exception = {\n ptyexn_constructor : extension_constructor;\n ptyexn_loc : location;\n ptyexn_attributes : attributes;\n}\n\nand extension_constructor_kind = Parsetree.extension_constructor_kind =\n | Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of longident_loc\n(*\n | C = D\n *)\n\n(* Type expressions for the class language *)\n\n(** {1 Class language} *)\n\nand class_type = Parsetree.class_type = {\n pcty_desc : class_type_desc;\n pcty_loc : location;\n pcty_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand class_type_desc = Parsetree.class_type_desc =\n | Pcty_constr of longident_loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n(* let open M in CT *)\n\nand class_signature = Parsetree.class_signature = {\n pcsig_self : core_type;\n pcsig_fields : class_type_field list;\n}\n(* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n*)\n\nand class_type_field = Parsetree.class_type_field = {\n pctf_desc : class_type_field_desc;\n pctf_loc : location;\n pctf_attributes : attributes; (* ... [@@id1] [@@id2] *)\n}\n\nand class_type_field_desc = Parsetree.class_type_field_desc =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n(* [%%id] *)\n\nand 'a class_infos = 'a Parsetree.class_infos = {\n pci_virt : virtual_flag;\n pci_params : (core_type * (variance * injectivity)) list;\n pci_name : string loc;\n pci_expr : 'a;\n pci_loc : location;\n pci_attributes : attributes; (* ... [@@id1] [@@id2] *)\n}\n(* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n*)\n\nand class_description = class_type class_infos\nand class_type_declaration = class_type class_infos\n\n(* Value expressions for the class language *)\nand class_expr = Parsetree.class_expr = {\n pcl_desc : class_expr_desc;\n pcl_loc : location;\n pcl_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand class_expr_desc = Parsetree.class_expr_desc =\n | Pcl_constr of longident_loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n(* let open M in CE *)\n\nand class_structure = Parsetree.class_structure = {\n pcstr_self : pattern;\n pcstr_fields : class_field list;\n}\n(* object(selfpat) ... end\n object ... end (self = Ppat_any)\n*)\n\nand class_field = Parsetree.class_field = {\n pcf_desc : class_field_desc;\n pcf_loc : location;\n pcf_attributes : attributes; (* ... [@@id1] [@@id2] *)\n}\n\nand class_field_desc = Parsetree.class_field_desc =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n(* [%%id] *)\n\nand class_field_kind = Parsetree.class_field_kind =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\nand class_declaration = class_expr class_infos\n(* Type expressions for the module language *)\n\n(** {1 Module language} *)\n\nand module_type = Parsetree.module_type = {\n pmty_desc : module_type_desc;\n pmty_loc : location;\n pmty_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand module_type_desc = Parsetree.module_type_desc =\n | Pmty_ident of longident_loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of longident_loc\n(* (module M) *)\n\nand functor_parameter = Parsetree.functor_parameter =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n(* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\nand signature = signature_item list\n\nand signature_item = Parsetree.signature_item = {\n psig_desc : signature_item_desc;\n psig_loc : location;\n}\n\nand signature_item_desc = Parsetree.signature_item_desc =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n(* [%%id] *)\n\nand module_declaration = Parsetree.module_declaration = {\n pmd_name : string option loc;\n pmd_type : module_type;\n pmd_attributes : attributes;\n (* ... [@@id1] [@@id2] *)\n pmd_loc : location;\n}\n(* S : MT *)\n\nand module_substitution = Parsetree.module_substitution = {\n pms_name : string loc;\n pms_manifest : longident_loc;\n pms_attributes : attributes;\n pms_loc : location;\n}\n\nand module_type_declaration = Parsetree.module_type_declaration = {\n pmtd_name : string loc;\n pmtd_type : module_type option;\n pmtd_attributes : attributes;\n (* ... [@@id1] [@@id2] *)\n pmtd_loc : location;\n}\n(* S = MT\n S (abstract module type declaration, pmtd_type = None)\n*)\n\nand 'a open_infos = 'a Parsetree.open_infos = {\n popen_expr : 'a;\n popen_override : override_flag;\n popen_loc : location;\n popen_attributes : attributes;\n}\n\nand open_description = longident_loc open_infos\n(* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n*)\n\nand open_declaration = module_expr open_infos\n\nand 'a include_infos = 'a Parsetree.include_infos = {\n pincl_mod : 'a;\n pincl_loc : location;\n pincl_attributes : attributes;\n}\n\nand include_description = module_type include_infos\n(* include MT *)\n\nand include_declaration = module_expr include_infos\n(* include ME *)\n\nand with_constraint = Parsetree.with_constraint =\n | Pwith_type of longident_loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of longident_loc * longident_loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of longident_loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of longident_loc * longident_loc\n(* with module X.Y := Z *)\n\n(* Value expressions for the module language *)\nand module_expr = Parsetree.module_expr = {\n pmod_desc : module_expr_desc;\n pmod_loc : location;\n pmod_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand module_expr_desc = Parsetree.module_expr_desc =\n | Pmod_ident of longident_loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n(* [%id] *)\n\nand structure = structure_item list\n\nand structure_item = Parsetree.structure_item = {\n pstr_desc : structure_item_desc;\n pstr_loc : location;\n}\n\nand structure_item_desc = Parsetree.structure_item_desc =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n(* [%%id] *)\n\nand value_binding = Parsetree.value_binding = {\n pvb_pat : pattern;\n pvb_expr : expression;\n pvb_attributes : attributes;\n pvb_loc : location;\n}\n\nand module_binding = Parsetree.module_binding = {\n pmb_name : string option loc;\n pmb_expr : module_expr;\n pmb_attributes : attributes;\n pmb_loc : location;\n}\n(* X = ME *)\n\n(* Toplevel phrases *)\n\n(** {1 Toplevel} *)\n\nand toplevel_phrase = Parsetree.toplevel_phrase =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n(* #use, #load ... *)\n\nand toplevel_directive = Parsetree.toplevel_directive = {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : location;\n}\n\nand directive_argument = Parsetree.directive_argument = {\n pdira_desc : directive_argument_desc;\n pdira_loc : location;\n}\n\nand directive_argument_desc = Parsetree.directive_argument_desc =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of longident\n | Pdir_bool of bool\n\nand cases = case list [@@deriving_inline traverse]\n\nclass virtual map =\n object (self)\n method virtual bool : bool -> bool\n method virtual char : char -> char\n method virtual int : int -> int\n method virtual list : 'a. ('a -> 'a) -> 'a list -> 'a list\n method virtual option : 'a. ('a -> 'a) -> 'a option -> 'a option\n method virtual string : string -> string\n\n method position : position -> position =\n fun { pos_fname; pos_lnum; pos_bol; pos_cnum } ->\n let pos_fname = self#string pos_fname in\n let pos_lnum = self#int pos_lnum in\n let pos_bol = self#int pos_bol in\n let pos_cnum = self#int pos_cnum in\n { pos_fname; pos_lnum; pos_bol; pos_cnum }\n\n method location : location -> location =\n fun { loc_start; loc_end; loc_ghost } ->\n let loc_start = self#position loc_start in\n let loc_end = self#position loc_end in\n let loc_ghost = self#bool loc_ghost in\n { loc_start; loc_end; loc_ghost }\n\n method location_stack : location_stack -> location_stack =\n self#list self#location\n\n method loc : 'a. ('a -> 'a) -> 'a loc -> 'a loc =\n fun _a { txt; loc } ->\n let txt = _a txt in\n let loc = self#location loc in\n { txt; loc }\n\n method longident : longident -> longident =\n fun x ->\n match x with\n | Lident a ->\n let a = self#string a in\n Lident a\n | Ldot (a, b) ->\n let a = self#longident a in\n let b = self#string b in\n Ldot (a, b)\n | Lapply (a, b) ->\n let a = self#longident a in\n let b = self#longident b in\n Lapply (a, b)\n\n method longident_loc : longident_loc -> longident_loc =\n self#loc self#longident\n\n method rec_flag : rec_flag -> rec_flag = fun x -> x\n method direction_flag : direction_flag -> direction_flag = fun x -> x\n method private_flag : private_flag -> private_flag = fun x -> x\n method mutable_flag : mutable_flag -> mutable_flag = fun x -> x\n method virtual_flag : virtual_flag -> virtual_flag = fun x -> x\n method override_flag : override_flag -> override_flag = fun x -> x\n method closed_flag : closed_flag -> closed_flag = fun x -> x\n method label : label -> label = self#string\n\n method arg_label : arg_label -> arg_label =\n fun x ->\n match x with\n | Nolabel -> Nolabel\n | Labelled a ->\n let a = self#string a in\n Labelled a\n | Optional a ->\n let a = self#string a in\n Optional a\n\n method variance : variance -> variance = fun x -> x\n method injectivity : injectivity -> injectivity = fun x -> x\n\n method constant : constant -> constant =\n fun x ->\n match x with\n | Pconst_integer (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n Pconst_integer (a, b)\n | Pconst_char a ->\n let a = self#char a in\n Pconst_char a\n | Pconst_string (a, b, c) ->\n let a = self#string a in\n let b = self#location b in\n let c = self#option self#string c in\n Pconst_string (a, b, c)\n | Pconst_float (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n Pconst_float (a, b)\n\n method attribute : attribute -> attribute =\n fun { attr_name; attr_payload; attr_loc } ->\n let attr_name = self#loc self#string attr_name in\n let attr_payload = self#payload attr_payload in\n let attr_loc = self#location attr_loc in\n { attr_name; attr_payload; attr_loc }\n\n method extension : extension -> extension =\n fun (a, b) ->\n let a = self#loc self#string a in\n let b = self#payload b in\n (a, b)\n\n method attributes : attributes -> attributes = self#list self#attribute\n\n method payload : payload -> payload =\n fun x ->\n match x with\n | PStr a ->\n let a = self#structure a in\n PStr a\n | PSig a ->\n let a = self#signature a in\n PSig a\n | PTyp a ->\n let a = self#core_type a in\n PTyp a\n | PPat (a, b) ->\n let a = self#pattern a in\n let b = self#option self#expression b in\n PPat (a, b)\n\n method core_type : core_type -> core_type =\n fun { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } ->\n let ptyp_desc = self#core_type_desc ptyp_desc in\n let ptyp_loc = self#location ptyp_loc in\n let ptyp_loc_stack = self#location_stack ptyp_loc_stack in\n let ptyp_attributes = self#attributes ptyp_attributes in\n { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes }\n\n method core_type_desc : core_type_desc -> core_type_desc =\n fun x ->\n match x with\n | Ptyp_any -> Ptyp_any\n | Ptyp_var a ->\n let a = self#string a in\n Ptyp_var a\n | Ptyp_arrow (a, b, c) ->\n let a = self#arg_label a in\n let b = self#core_type b in\n let c = self#core_type c in\n Ptyp_arrow (a, b, c)\n | Ptyp_tuple a ->\n let a = self#list self#core_type a in\n Ptyp_tuple a\n | Ptyp_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n Ptyp_constr (a, b)\n | Ptyp_object (a, b) ->\n let a = self#list self#object_field a in\n let b = self#closed_flag b in\n Ptyp_object (a, b)\n | Ptyp_class (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n Ptyp_class (a, b)\n | Ptyp_alias (a, b) ->\n let a = self#core_type a in\n let b = self#string b in\n Ptyp_alias (a, b)\n | Ptyp_variant (a, b, c) ->\n let a = self#list self#row_field a in\n let b = self#closed_flag b in\n let c = self#option (self#list self#label) c in\n Ptyp_variant (a, b, c)\n | Ptyp_poly (a, b) ->\n let a = self#list (self#loc self#string) a in\n let b = self#core_type b in\n Ptyp_poly (a, b)\n | Ptyp_package a ->\n let a = self#package_type a in\n Ptyp_package a\n | Ptyp_extension a ->\n let a = self#extension a in\n Ptyp_extension a\n\n method package_type : package_type -> package_type =\n fun (a, b) ->\n let a = self#longident_loc a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#core_type b in\n (a, b))\n b\n in\n (a, b)\n\n method row_field : row_field -> row_field =\n fun { prf_desc; prf_loc; prf_attributes } ->\n let prf_desc = self#row_field_desc prf_desc in\n let prf_loc = self#location prf_loc in\n let prf_attributes = self#attributes prf_attributes in\n { prf_desc; prf_loc; prf_attributes }\n\n method row_field_desc : row_field_desc -> row_field_desc =\n fun x ->\n match x with\n | Rtag (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#bool b in\n let c = self#list self#core_type c in\n Rtag (a, b, c)\n | Rinherit a ->\n let a = self#core_type a in\n Rinherit a\n\n method object_field : object_field -> object_field =\n fun { pof_desc; pof_loc; pof_attributes } ->\n let pof_desc = self#object_field_desc pof_desc in\n let pof_loc = self#location pof_loc in\n let pof_attributes = self#attributes pof_attributes in\n { pof_desc; pof_loc; pof_attributes }\n\n method object_field_desc : object_field_desc -> object_field_desc =\n fun x ->\n match x with\n | Otag (a, b) ->\n let a = self#loc self#label a in\n let b = self#core_type b in\n Otag (a, b)\n | Oinherit a ->\n let a = self#core_type a in\n Oinherit a\n\n method pattern : pattern -> pattern =\n fun { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } ->\n let ppat_desc = self#pattern_desc ppat_desc in\n let ppat_loc = self#location ppat_loc in\n let ppat_loc_stack = self#location_stack ppat_loc_stack in\n let ppat_attributes = self#attributes ppat_attributes in\n { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes }\n\n method pattern_desc : pattern_desc -> pattern_desc =\n fun x ->\n match x with\n | Ppat_any -> Ppat_any\n | Ppat_var a ->\n let a = self#loc self#string a in\n Ppat_var a\n | Ppat_alias (a, b) ->\n let a = self#pattern a in\n let b = self#loc self#string b in\n Ppat_alias (a, b)\n | Ppat_constant a ->\n let a = self#constant a in\n Ppat_constant a\n | Ppat_interval (a, b) ->\n let a = self#constant a in\n let b = self#constant b in\n Ppat_interval (a, b)\n | Ppat_tuple a ->\n let a = self#list self#pattern a in\n Ppat_tuple a\n | Ppat_construct (a, b) ->\n let a = self#longident_loc a in\n let b = self#option self#pattern b in\n Ppat_construct (a, b)\n | Ppat_variant (a, b) ->\n let a = self#label a in\n let b = self#option self#pattern b in\n Ppat_variant (a, b)\n | Ppat_record (a, b) ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#pattern b in\n (a, b))\n a\n in\n let b = self#closed_flag b in\n Ppat_record (a, b)\n | Ppat_array a ->\n let a = self#list self#pattern a in\n Ppat_array a\n | Ppat_or (a, b) ->\n let a = self#pattern a in\n let b = self#pattern b in\n Ppat_or (a, b)\n | Ppat_constraint (a, b) ->\n let a = self#pattern a in\n let b = self#core_type b in\n Ppat_constraint (a, b)\n | Ppat_type a ->\n let a = self#longident_loc a in\n Ppat_type a\n | Ppat_lazy a ->\n let a = self#pattern a in\n Ppat_lazy a\n | Ppat_unpack a ->\n let a = self#loc (self#option self#string) a in\n Ppat_unpack a\n | Ppat_exception a ->\n let a = self#pattern a in\n Ppat_exception a\n | Ppat_extension a ->\n let a = self#extension a in\n Ppat_extension a\n | Ppat_open (a, b) ->\n let a = self#longident_loc a in\n let b = self#pattern b in\n Ppat_open (a, b)\n\n method expression : expression -> expression =\n fun { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } ->\n let pexp_desc = self#expression_desc pexp_desc in\n let pexp_loc = self#location pexp_loc in\n let pexp_loc_stack = self#location_stack pexp_loc_stack in\n let pexp_attributes = self#attributes pexp_attributes in\n { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes }\n\n method expression_desc : expression_desc -> expression_desc =\n fun x ->\n match x with\n | Pexp_ident a ->\n let a = self#longident_loc a in\n Pexp_ident a\n | Pexp_constant a ->\n let a = self#constant a in\n Pexp_constant a\n | Pexp_let (a, b, c) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n let c = self#expression c in\n Pexp_let (a, b, c)\n | Pexp_function a ->\n let a = self#cases a in\n Pexp_function a\n | Pexp_fun (a, b, c, d) ->\n let a = self#arg_label a in\n let b = self#option self#expression b in\n let c = self#pattern c in\n let d = self#expression d in\n Pexp_fun (a, b, c, d)\n | Pexp_apply (a, b) ->\n let a = self#expression a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#arg_label a in\n let b = self#expression b in\n (a, b))\n b\n in\n Pexp_apply (a, b)\n | Pexp_match (a, b) ->\n let a = self#expression a in\n let b = self#cases b in\n Pexp_match (a, b)\n | Pexp_try (a, b) ->\n let a = self#expression a in\n let b = self#cases b in\n Pexp_try (a, b)\n | Pexp_tuple a ->\n let a = self#list self#expression a in\n Pexp_tuple a\n | Pexp_construct (a, b) ->\n let a = self#longident_loc a in\n let b = self#option self#expression b in\n Pexp_construct (a, b)\n | Pexp_variant (a, b) ->\n let a = self#label a in\n let b = self#option self#expression b in\n Pexp_variant (a, b)\n | Pexp_record (a, b) ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#expression b in\n (a, b))\n a\n in\n let b = self#option self#expression b in\n Pexp_record (a, b)\n | Pexp_field (a, b) ->\n let a = self#expression a in\n let b = self#longident_loc b in\n Pexp_field (a, b)\n | Pexp_setfield (a, b, c) ->\n let a = self#expression a in\n let b = self#longident_loc b in\n let c = self#expression c in\n Pexp_setfield (a, b, c)\n | Pexp_array a ->\n let a = self#list self#expression a in\n Pexp_array a\n | Pexp_ifthenelse (a, b, c) ->\n let a = self#expression a in\n let b = self#expression b in\n let c = self#option self#expression c in\n Pexp_ifthenelse (a, b, c)\n | Pexp_sequence (a, b) ->\n let a = self#expression a in\n let b = self#expression b in\n Pexp_sequence (a, b)\n | Pexp_while (a, b) ->\n let a = self#expression a in\n let b = self#expression b in\n Pexp_while (a, b)\n | Pexp_for (a, b, c, d, e) ->\n let a = self#pattern a in\n let b = self#expression b in\n let c = self#expression c in\n let d = self#direction_flag d in\n let e = self#expression e in\n Pexp_for (a, b, c, d, e)\n | Pexp_constraint (a, b) ->\n let a = self#expression a in\n let b = self#core_type b in\n Pexp_constraint (a, b)\n | Pexp_coerce (a, b, c) ->\n let a = self#expression a in\n let b = self#option self#core_type b in\n let c = self#core_type c in\n Pexp_coerce (a, b, c)\n | Pexp_send (a, b) ->\n let a = self#expression a in\n let b = self#loc self#label b in\n Pexp_send (a, b)\n | Pexp_new a ->\n let a = self#longident_loc a in\n Pexp_new a\n | Pexp_setinstvar (a, b) ->\n let a = self#loc self#label a in\n let b = self#expression b in\n Pexp_setinstvar (a, b)\n | Pexp_override a ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#loc self#label a in\n let b = self#expression b in\n (a, b))\n a\n in\n Pexp_override a\n | Pexp_letmodule (a, b, c) ->\n let a = self#loc (self#option self#string) a in\n let b = self#module_expr b in\n let c = self#expression c in\n Pexp_letmodule (a, b, c)\n | Pexp_letexception (a, b) ->\n let a = self#extension_constructor a in\n let b = self#expression b in\n Pexp_letexception (a, b)\n | Pexp_assert a ->\n let a = self#expression a in\n Pexp_assert a\n | Pexp_lazy a ->\n let a = self#expression a in\n Pexp_lazy a\n | Pexp_poly (a, b) ->\n let a = self#expression a in\n let b = self#option self#core_type b in\n Pexp_poly (a, b)\n | Pexp_object a ->\n let a = self#class_structure a in\n Pexp_object a\n | Pexp_newtype (a, b) ->\n let a = self#loc self#string a in\n let b = self#expression b in\n Pexp_newtype (a, b)\n | Pexp_pack a ->\n let a = self#module_expr a in\n Pexp_pack a\n | Pexp_open (a, b) ->\n let a = self#open_declaration a in\n let b = self#expression b in\n Pexp_open (a, b)\n | Pexp_letop a ->\n let a = self#letop a in\n Pexp_letop a\n | Pexp_extension a ->\n let a = self#extension a in\n Pexp_extension a\n | Pexp_unreachable -> Pexp_unreachable\n\n method case : case -> case =\n fun { pc_lhs; pc_guard; pc_rhs } ->\n let pc_lhs = self#pattern pc_lhs in\n let pc_guard = self#option self#expression pc_guard in\n let pc_rhs = self#expression pc_rhs in\n { pc_lhs; pc_guard; pc_rhs }\n\n method letop : letop -> letop =\n fun { let_; ands; body } ->\n let let_ = self#binding_op let_ in\n let ands = self#list self#binding_op ands in\n let body = self#expression body in\n { let_; ands; body }\n\n method binding_op : binding_op -> binding_op =\n fun { pbop_op; pbop_pat; pbop_exp; pbop_loc } ->\n let pbop_op = self#loc self#string pbop_op in\n let pbop_pat = self#pattern pbop_pat in\n let pbop_exp = self#expression pbop_exp in\n let pbop_loc = self#location pbop_loc in\n { pbop_op; pbop_pat; pbop_exp; pbop_loc }\n\n method value_description : value_description -> value_description =\n fun { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } ->\n let pval_name = self#loc self#string pval_name in\n let pval_type = self#core_type pval_type in\n let pval_prim = self#list self#string pval_prim in\n let pval_attributes = self#attributes pval_attributes in\n let pval_loc = self#location pval_loc in\n { pval_name; pval_type; pval_prim; pval_attributes; pval_loc }\n\n method type_declaration : type_declaration -> type_declaration =\n fun {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } ->\n let ptype_name = self#loc self#string ptype_name in\n let ptype_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n (a, b))\n b\n in\n (a, b))\n ptype_params\n in\n let ptype_cstrs =\n self#list\n (fun (a, b, c) ->\n let a = self#core_type a in\n let b = self#core_type b in\n let c = self#location c in\n (a, b, c))\n ptype_cstrs\n in\n let ptype_kind = self#type_kind ptype_kind in\n let ptype_private = self#private_flag ptype_private in\n let ptype_manifest = self#option self#core_type ptype_manifest in\n let ptype_attributes = self#attributes ptype_attributes in\n let ptype_loc = self#location ptype_loc in\n {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n }\n\n method type_kind : type_kind -> type_kind =\n fun x ->\n match x with\n | Ptype_abstract -> Ptype_abstract\n | Ptype_variant a ->\n let a = self#list self#constructor_declaration a in\n Ptype_variant a\n | Ptype_record a ->\n let a = self#list self#label_declaration a in\n Ptype_record a\n | Ptype_open -> Ptype_open\n\n method label_declaration : label_declaration -> label_declaration =\n fun { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } ->\n let pld_name = self#loc self#string pld_name in\n let pld_mutable = self#mutable_flag pld_mutable in\n let pld_type = self#core_type pld_type in\n let pld_loc = self#location pld_loc in\n let pld_attributes = self#attributes pld_attributes in\n { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes }\n\n method constructor_declaration\n : constructor_declaration -> constructor_declaration =\n fun { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } ->\n let pcd_name = self#loc self#string pcd_name in\n let pcd_args = self#constructor_arguments pcd_args in\n let pcd_res = self#option self#core_type pcd_res in\n let pcd_loc = self#location pcd_loc in\n let pcd_attributes = self#attributes pcd_attributes in\n { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes }\n\n method constructor_arguments\n : constructor_arguments -> constructor_arguments =\n fun x ->\n match x with\n | Pcstr_tuple a ->\n let a = self#list self#core_type a in\n Pcstr_tuple a\n | Pcstr_record a ->\n let a = self#list self#label_declaration a in\n Pcstr_record a\n\n method type_extension : type_extension -> type_extension =\n fun {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } ->\n let ptyext_path = self#longident_loc ptyext_path in\n let ptyext_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n (a, b))\n b\n in\n (a, b))\n ptyext_params\n in\n let ptyext_constructors =\n self#list self#extension_constructor ptyext_constructors\n in\n let ptyext_private = self#private_flag ptyext_private in\n let ptyext_loc = self#location ptyext_loc in\n let ptyext_attributes = self#attributes ptyext_attributes in\n {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n }\n\n method extension_constructor\n : extension_constructor -> extension_constructor =\n fun { pext_name; pext_kind; pext_loc; pext_attributes } ->\n let pext_name = self#loc self#string pext_name in\n let pext_kind = self#extension_constructor_kind pext_kind in\n let pext_loc = self#location pext_loc in\n let pext_attributes = self#attributes pext_attributes in\n { pext_name; pext_kind; pext_loc; pext_attributes }\n\n method type_exception : type_exception -> type_exception =\n fun { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } ->\n let ptyexn_constructor =\n self#extension_constructor ptyexn_constructor\n in\n let ptyexn_loc = self#location ptyexn_loc in\n let ptyexn_attributes = self#attributes ptyexn_attributes in\n { ptyexn_constructor; ptyexn_loc; ptyexn_attributes }\n\n method extension_constructor_kind\n : extension_constructor_kind -> extension_constructor_kind =\n fun x ->\n match x with\n | Pext_decl (a, b) ->\n let a = self#constructor_arguments a in\n let b = self#option self#core_type b in\n Pext_decl (a, b)\n | Pext_rebind a ->\n let a = self#longident_loc a in\n Pext_rebind a\n\n method class_type : class_type -> class_type =\n fun { pcty_desc; pcty_loc; pcty_attributes } ->\n let pcty_desc = self#class_type_desc pcty_desc in\n let pcty_loc = self#location pcty_loc in\n let pcty_attributes = self#attributes pcty_attributes in\n { pcty_desc; pcty_loc; pcty_attributes }\n\n method class_type_desc : class_type_desc -> class_type_desc =\n fun x ->\n match x with\n | Pcty_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n Pcty_constr (a, b)\n | Pcty_signature a ->\n let a = self#class_signature a in\n Pcty_signature a\n | Pcty_arrow (a, b, c) ->\n let a = self#arg_label a in\n let b = self#core_type b in\n let c = self#class_type c in\n Pcty_arrow (a, b, c)\n | Pcty_extension a ->\n let a = self#extension a in\n Pcty_extension a\n | Pcty_open (a, b) ->\n let a = self#open_description a in\n let b = self#class_type b in\n Pcty_open (a, b)\n\n method class_signature : class_signature -> class_signature =\n fun { pcsig_self; pcsig_fields } ->\n let pcsig_self = self#core_type pcsig_self in\n let pcsig_fields = self#list self#class_type_field pcsig_fields in\n { pcsig_self; pcsig_fields }\n\n method class_type_field : class_type_field -> class_type_field =\n fun { pctf_desc; pctf_loc; pctf_attributes } ->\n let pctf_desc = self#class_type_field_desc pctf_desc in\n let pctf_loc = self#location pctf_loc in\n let pctf_attributes = self#attributes pctf_attributes in\n { pctf_desc; pctf_loc; pctf_attributes }\n\n method class_type_field_desc\n : class_type_field_desc -> class_type_field_desc =\n fun x ->\n match x with\n | Pctf_inherit a ->\n let a = self#class_type a in\n Pctf_inherit a\n | Pctf_val a ->\n let a =\n (fun (a, b, c, d) ->\n let a = self#loc self#label a in\n let b = self#mutable_flag b in\n let c = self#virtual_flag c in\n let d = self#core_type d in\n (a, b, c, d))\n a\n in\n Pctf_val a\n | Pctf_method a ->\n let a =\n (fun (a, b, c, d) ->\n let a = self#loc self#label a in\n let b = self#private_flag b in\n let c = self#virtual_flag c in\n let d = self#core_type d in\n (a, b, c, d))\n a\n in\n Pctf_method a\n | Pctf_constraint a ->\n let a =\n (fun (a, b) ->\n let a = self#core_type a in\n let b = self#core_type b in\n (a, b))\n a\n in\n Pctf_constraint a\n | Pctf_attribute a ->\n let a = self#attribute a in\n Pctf_attribute a\n | Pctf_extension a ->\n let a = self#extension a in\n Pctf_extension a\n\n method class_infos : 'a. ('a -> 'a) -> 'a class_infos -> 'a class_infos =\n fun _a\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes } ->\n let pci_virt = self#virtual_flag pci_virt in\n let pci_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n (a, b))\n b\n in\n (a, b))\n pci_params\n in\n let pci_name = self#loc self#string pci_name in\n let pci_expr = _a pci_expr in\n let pci_loc = self#location pci_loc in\n let pci_attributes = self#attributes pci_attributes in\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes }\n\n method class_description : class_description -> class_description =\n self#class_infos self#class_type\n\n method class_type_declaration\n : class_type_declaration -> class_type_declaration =\n self#class_infos self#class_type\n\n method class_expr : class_expr -> class_expr =\n fun { pcl_desc; pcl_loc; pcl_attributes } ->\n let pcl_desc = self#class_expr_desc pcl_desc in\n let pcl_loc = self#location pcl_loc in\n let pcl_attributes = self#attributes pcl_attributes in\n { pcl_desc; pcl_loc; pcl_attributes }\n\n method class_expr_desc : class_expr_desc -> class_expr_desc =\n fun x ->\n match x with\n | Pcl_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n Pcl_constr (a, b)\n | Pcl_structure a ->\n let a = self#class_structure a in\n Pcl_structure a\n | Pcl_fun (a, b, c, d) ->\n let a = self#arg_label a in\n let b = self#option self#expression b in\n let c = self#pattern c in\n let d = self#class_expr d in\n Pcl_fun (a, b, c, d)\n | Pcl_apply (a, b) ->\n let a = self#class_expr a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#arg_label a in\n let b = self#expression b in\n (a, b))\n b\n in\n Pcl_apply (a, b)\n | Pcl_let (a, b, c) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n let c = self#class_expr c in\n Pcl_let (a, b, c)\n | Pcl_constraint (a, b) ->\n let a = self#class_expr a in\n let b = self#class_type b in\n Pcl_constraint (a, b)\n | Pcl_extension a ->\n let a = self#extension a in\n Pcl_extension a\n | Pcl_open (a, b) ->\n let a = self#open_description a in\n let b = self#class_expr b in\n Pcl_open (a, b)\n\n method class_structure : class_structure -> class_structure =\n fun { pcstr_self; pcstr_fields } ->\n let pcstr_self = self#pattern pcstr_self in\n let pcstr_fields = self#list self#class_field pcstr_fields in\n { pcstr_self; pcstr_fields }\n\n method class_field : class_field -> class_field =\n fun { pcf_desc; pcf_loc; pcf_attributes } ->\n let pcf_desc = self#class_field_desc pcf_desc in\n let pcf_loc = self#location pcf_loc in\n let pcf_attributes = self#attributes pcf_attributes in\n { pcf_desc; pcf_loc; pcf_attributes }\n\n method class_field_desc : class_field_desc -> class_field_desc =\n fun x ->\n match x with\n | Pcf_inherit (a, b, c) ->\n let a = self#override_flag a in\n let b = self#class_expr b in\n let c = self#option (self#loc self#string) c in\n Pcf_inherit (a, b, c)\n | Pcf_val a ->\n let a =\n (fun (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#mutable_flag b in\n let c = self#class_field_kind c in\n (a, b, c))\n a\n in\n Pcf_val a\n | Pcf_method a ->\n let a =\n (fun (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#private_flag b in\n let c = self#class_field_kind c in\n (a, b, c))\n a\n in\n Pcf_method a\n | Pcf_constraint a ->\n let a =\n (fun (a, b) ->\n let a = self#core_type a in\n let b = self#core_type b in\n (a, b))\n a\n in\n Pcf_constraint a\n | Pcf_initializer a ->\n let a = self#expression a in\n Pcf_initializer a\n | Pcf_attribute a ->\n let a = self#attribute a in\n Pcf_attribute a\n | Pcf_extension a ->\n let a = self#extension a in\n Pcf_extension a\n\n method class_field_kind : class_field_kind -> class_field_kind =\n fun x ->\n match x with\n | Cfk_virtual a ->\n let a = self#core_type a in\n Cfk_virtual a\n | Cfk_concrete (a, b) ->\n let a = self#override_flag a in\n let b = self#expression b in\n Cfk_concrete (a, b)\n\n method class_declaration : class_declaration -> class_declaration =\n self#class_infos self#class_expr\n\n method module_type : module_type -> module_type =\n fun { pmty_desc; pmty_loc; pmty_attributes } ->\n let pmty_desc = self#module_type_desc pmty_desc in\n let pmty_loc = self#location pmty_loc in\n let pmty_attributes = self#attributes pmty_attributes in\n { pmty_desc; pmty_loc; pmty_attributes }\n\n method module_type_desc : module_type_desc -> module_type_desc =\n fun x ->\n match x with\n | Pmty_ident a ->\n let a = self#longident_loc a in\n Pmty_ident a\n | Pmty_signature a ->\n let a = self#signature a in\n Pmty_signature a\n | Pmty_functor (a, b) ->\n let a = self#functor_parameter a in\n let b = self#module_type b in\n Pmty_functor (a, b)\n | Pmty_with (a, b) ->\n let a = self#module_type a in\n let b = self#list self#with_constraint b in\n Pmty_with (a, b)\n | Pmty_typeof a ->\n let a = self#module_expr a in\n Pmty_typeof a\n | Pmty_extension a ->\n let a = self#extension a in\n Pmty_extension a\n | Pmty_alias a ->\n let a = self#longident_loc a in\n Pmty_alias a\n\n method functor_parameter : functor_parameter -> functor_parameter =\n fun x ->\n match x with\n | Unit -> Unit\n | Named (a, b) ->\n let a = self#loc (self#option self#string) a in\n let b = self#module_type b in\n Named (a, b)\n\n method signature : signature -> signature = self#list self#signature_item\n\n method signature_item : signature_item -> signature_item =\n fun { psig_desc; psig_loc } ->\n let psig_desc = self#signature_item_desc psig_desc in\n let psig_loc = self#location psig_loc in\n { psig_desc; psig_loc }\n\n method signature_item_desc : signature_item_desc -> signature_item_desc =\n fun x ->\n match x with\n | Psig_value a ->\n let a = self#value_description a in\n Psig_value a\n | Psig_type (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#type_declaration b in\n Psig_type (a, b)\n | Psig_typesubst a ->\n let a = self#list self#type_declaration a in\n Psig_typesubst a\n | Psig_typext a ->\n let a = self#type_extension a in\n Psig_typext a\n | Psig_exception a ->\n let a = self#type_exception a in\n Psig_exception a\n | Psig_module a ->\n let a = self#module_declaration a in\n Psig_module a\n | Psig_modsubst a ->\n let a = self#module_substitution a in\n Psig_modsubst a\n | Psig_recmodule a ->\n let a = self#list self#module_declaration a in\n Psig_recmodule a\n | Psig_modtype a ->\n let a = self#module_type_declaration a in\n Psig_modtype a\n | Psig_open a ->\n let a = self#open_description a in\n Psig_open a\n | Psig_include a ->\n let a = self#include_description a in\n Psig_include a\n | Psig_class a ->\n let a = self#list self#class_description a in\n Psig_class a\n | Psig_class_type a ->\n let a = self#list self#class_type_declaration a in\n Psig_class_type a\n | Psig_attribute a ->\n let a = self#attribute a in\n Psig_attribute a\n | Psig_extension (a, b) ->\n let a = self#extension a in\n let b = self#attributes b in\n Psig_extension (a, b)\n\n method module_declaration : module_declaration -> module_declaration =\n fun { pmd_name; pmd_type; pmd_attributes; pmd_loc } ->\n let pmd_name = self#loc (self#option self#string) pmd_name in\n let pmd_type = self#module_type pmd_type in\n let pmd_attributes = self#attributes pmd_attributes in\n let pmd_loc = self#location pmd_loc in\n { pmd_name; pmd_type; pmd_attributes; pmd_loc }\n\n method module_substitution : module_substitution -> module_substitution =\n fun { pms_name; pms_manifest; pms_attributes; pms_loc } ->\n let pms_name = self#loc self#string pms_name in\n let pms_manifest = self#longident_loc pms_manifest in\n let pms_attributes = self#attributes pms_attributes in\n let pms_loc = self#location pms_loc in\n { pms_name; pms_manifest; pms_attributes; pms_loc }\n\n method module_type_declaration\n : module_type_declaration -> module_type_declaration =\n fun { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } ->\n let pmtd_name = self#loc self#string pmtd_name in\n let pmtd_type = self#option self#module_type pmtd_type in\n let pmtd_attributes = self#attributes pmtd_attributes in\n let pmtd_loc = self#location pmtd_loc in\n { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc }\n\n method open_infos : 'a. ('a -> 'a) -> 'a open_infos -> 'a open_infos =\n fun _a { popen_expr; popen_override; popen_loc; popen_attributes } ->\n let popen_expr = _a popen_expr in\n let popen_override = self#override_flag popen_override in\n let popen_loc = self#location popen_loc in\n let popen_attributes = self#attributes popen_attributes in\n { popen_expr; popen_override; popen_loc; popen_attributes }\n\n method open_description : open_description -> open_description =\n self#open_infos self#longident_loc\n\n method open_declaration : open_declaration -> open_declaration =\n self#open_infos self#module_expr\n\n method include_infos\n : 'a. ('a -> 'a) -> 'a include_infos -> 'a include_infos =\n fun _a { pincl_mod; pincl_loc; pincl_attributes } ->\n let pincl_mod = _a pincl_mod in\n let pincl_loc = self#location pincl_loc in\n let pincl_attributes = self#attributes pincl_attributes in\n { pincl_mod; pincl_loc; pincl_attributes }\n\n method include_description : include_description -> include_description =\n self#include_infos self#module_type\n\n method include_declaration : include_declaration -> include_declaration =\n self#include_infos self#module_expr\n\n method with_constraint : with_constraint -> with_constraint =\n fun x ->\n match x with\n | Pwith_type (a, b) ->\n let a = self#longident_loc a in\n let b = self#type_declaration b in\n Pwith_type (a, b)\n | Pwith_module (a, b) ->\n let a = self#longident_loc a in\n let b = self#longident_loc b in\n Pwith_module (a, b)\n | Pwith_typesubst (a, b) ->\n let a = self#longident_loc a in\n let b = self#type_declaration b in\n Pwith_typesubst (a, b)\n | Pwith_modsubst (a, b) ->\n let a = self#longident_loc a in\n let b = self#longident_loc b in\n Pwith_modsubst (a, b)\n\n method module_expr : module_expr -> module_expr =\n fun { pmod_desc; pmod_loc; pmod_attributes } ->\n let pmod_desc = self#module_expr_desc pmod_desc in\n let pmod_loc = self#location pmod_loc in\n let pmod_attributes = self#attributes pmod_attributes in\n { pmod_desc; pmod_loc; pmod_attributes }\n\n method module_expr_desc : module_expr_desc -> module_expr_desc =\n fun x ->\n match x with\n | Pmod_ident a ->\n let a = self#longident_loc a in\n Pmod_ident a\n | Pmod_structure a ->\n let a = self#structure a in\n Pmod_structure a\n | Pmod_functor (a, b) ->\n let a = self#functor_parameter a in\n let b = self#module_expr b in\n Pmod_functor (a, b)\n | Pmod_apply (a, b) ->\n let a = self#module_expr a in\n let b = self#module_expr b in\n Pmod_apply (a, b)\n | Pmod_constraint (a, b) ->\n let a = self#module_expr a in\n let b = self#module_type b in\n Pmod_constraint (a, b)\n | Pmod_unpack a ->\n let a = self#expression a in\n Pmod_unpack a\n | Pmod_extension a ->\n let a = self#extension a in\n Pmod_extension a\n\n method structure : structure -> structure = self#list self#structure_item\n\n method structure_item : structure_item -> structure_item =\n fun { pstr_desc; pstr_loc } ->\n let pstr_desc = self#structure_item_desc pstr_desc in\n let pstr_loc = self#location pstr_loc in\n { pstr_desc; pstr_loc }\n\n method structure_item_desc : structure_item_desc -> structure_item_desc =\n fun x ->\n match x with\n | Pstr_eval (a, b) ->\n let a = self#expression a in\n let b = self#attributes b in\n Pstr_eval (a, b)\n | Pstr_value (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n Pstr_value (a, b)\n | Pstr_primitive a ->\n let a = self#value_description a in\n Pstr_primitive a\n | Pstr_type (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#type_declaration b in\n Pstr_type (a, b)\n | Pstr_typext a ->\n let a = self#type_extension a in\n Pstr_typext a\n | Pstr_exception a ->\n let a = self#type_exception a in\n Pstr_exception a\n | Pstr_module a ->\n let a = self#module_binding a in\n Pstr_module a\n | Pstr_recmodule a ->\n let a = self#list self#module_binding a in\n Pstr_recmodule a\n | Pstr_modtype a ->\n let a = self#module_type_declaration a in\n Pstr_modtype a\n | Pstr_open a ->\n let a = self#open_declaration a in\n Pstr_open a\n | Pstr_class a ->\n let a = self#list self#class_declaration a in\n Pstr_class a\n | Pstr_class_type a ->\n let a = self#list self#class_type_declaration a in\n Pstr_class_type a\n | Pstr_include a ->\n let a = self#include_declaration a in\n Pstr_include a\n | Pstr_attribute a ->\n let a = self#attribute a in\n Pstr_attribute a\n | Pstr_extension (a, b) ->\n let a = self#extension a in\n let b = self#attributes b in\n Pstr_extension (a, b)\n\n method value_binding : value_binding -> value_binding =\n fun { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } ->\n let pvb_pat = self#pattern pvb_pat in\n let pvb_expr = self#expression pvb_expr in\n let pvb_attributes = self#attributes pvb_attributes in\n let pvb_loc = self#location pvb_loc in\n { pvb_pat; pvb_expr; pvb_attributes; pvb_loc }\n\n method module_binding : module_binding -> module_binding =\n fun { pmb_name; pmb_expr; pmb_attributes; pmb_loc } ->\n let pmb_name = self#loc (self#option self#string) pmb_name in\n let pmb_expr = self#module_expr pmb_expr in\n let pmb_attributes = self#attributes pmb_attributes in\n let pmb_loc = self#location pmb_loc in\n { pmb_name; pmb_expr; pmb_attributes; pmb_loc }\n\n method toplevel_phrase : toplevel_phrase -> toplevel_phrase =\n fun x ->\n match x with\n | Ptop_def a ->\n let a = self#structure a in\n Ptop_def a\n | Ptop_dir a ->\n let a = self#toplevel_directive a in\n Ptop_dir a\n\n method toplevel_directive : toplevel_directive -> toplevel_directive =\n fun { pdir_name; pdir_arg; pdir_loc } ->\n let pdir_name = self#loc self#string pdir_name in\n let pdir_arg = self#option self#directive_argument pdir_arg in\n let pdir_loc = self#location pdir_loc in\n { pdir_name; pdir_arg; pdir_loc }\n\n method directive_argument : directive_argument -> directive_argument =\n fun { pdira_desc; pdira_loc } ->\n let pdira_desc = self#directive_argument_desc pdira_desc in\n let pdira_loc = self#location pdira_loc in\n { pdira_desc; pdira_loc }\n\n method directive_argument_desc\n : directive_argument_desc -> directive_argument_desc =\n fun x ->\n match x with\n | Pdir_string a ->\n let a = self#string a in\n Pdir_string a\n | Pdir_int (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n Pdir_int (a, b)\n | Pdir_ident a ->\n let a = self#longident a in\n Pdir_ident a\n | Pdir_bool a ->\n let a = self#bool a in\n Pdir_bool a\n\n method cases : cases -> cases = self#list self#case\n end\n\nclass virtual iter =\n object (self)\n method virtual bool : bool -> unit\n method virtual char : char -> unit\n method virtual int : int -> unit\n method virtual list : 'a. ('a -> unit) -> 'a list -> unit\n method virtual option : 'a. ('a -> unit) -> 'a option -> unit\n method virtual string : string -> unit\n\n method position : position -> unit =\n fun { pos_fname; pos_lnum; pos_bol; pos_cnum } ->\n self#string pos_fname;\n self#int pos_lnum;\n self#int pos_bol;\n self#int pos_cnum\n\n method location : location -> unit =\n fun { loc_start; loc_end; loc_ghost } ->\n self#position loc_start;\n self#position loc_end;\n self#bool loc_ghost\n\n method location_stack : location_stack -> unit = self#list self#location\n\n method loc : 'a. ('a -> unit) -> 'a loc -> unit =\n fun _a { txt; loc } ->\n _a txt;\n self#location loc\n\n method longident : longident -> unit =\n fun x ->\n match x with\n | Lident a -> self#string a\n | Ldot (a, b) ->\n self#longident a;\n self#string b\n | Lapply (a, b) ->\n self#longident a;\n self#longident b\n\n method longident_loc : longident_loc -> unit = self#loc self#longident\n method rec_flag : rec_flag -> unit = fun _ -> ()\n method direction_flag : direction_flag -> unit = fun _ -> ()\n method private_flag : private_flag -> unit = fun _ -> ()\n method mutable_flag : mutable_flag -> unit = fun _ -> ()\n method virtual_flag : virtual_flag -> unit = fun _ -> ()\n method override_flag : override_flag -> unit = fun _ -> ()\n method closed_flag : closed_flag -> unit = fun _ -> ()\n method label : label -> unit = self#string\n\n method arg_label : arg_label -> unit =\n fun x ->\n match x with\n | Nolabel -> ()\n | Labelled a -> self#string a\n | Optional a -> self#string a\n\n method variance : variance -> unit = fun _ -> ()\n method injectivity : injectivity -> unit = fun _ -> ()\n\n method constant : constant -> unit =\n fun x ->\n match x with\n | Pconst_integer (a, b) ->\n self#string a;\n self#option self#char b\n | Pconst_char a -> self#char a\n | Pconst_string (a, b, c) ->\n self#string a;\n self#location b;\n self#option self#string c\n | Pconst_float (a, b) ->\n self#string a;\n self#option self#char b\n\n method attribute : attribute -> unit =\n fun { attr_name; attr_payload; attr_loc } ->\n self#loc self#string attr_name;\n self#payload attr_payload;\n self#location attr_loc\n\n method extension : extension -> unit =\n fun (a, b) ->\n self#loc self#string a;\n self#payload b\n\n method attributes : attributes -> unit = self#list self#attribute\n\n method payload : payload -> unit =\n fun x ->\n match x with\n | PStr a -> self#structure a\n | PSig a -> self#signature a\n | PTyp a -> self#core_type a\n | PPat (a, b) ->\n self#pattern a;\n self#option self#expression b\n\n method core_type : core_type -> unit =\n fun { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } ->\n self#core_type_desc ptyp_desc;\n self#location ptyp_loc;\n self#location_stack ptyp_loc_stack;\n self#attributes ptyp_attributes\n\n method core_type_desc : core_type_desc -> unit =\n fun x ->\n match x with\n | Ptyp_any -> ()\n | Ptyp_var a -> self#string a\n | Ptyp_arrow (a, b, c) ->\n self#arg_label a;\n self#core_type b;\n self#core_type c\n | Ptyp_tuple a -> self#list self#core_type a\n | Ptyp_constr (a, b) ->\n self#longident_loc a;\n self#list self#core_type b\n | Ptyp_object (a, b) ->\n self#list self#object_field a;\n self#closed_flag b\n | Ptyp_class (a, b) ->\n self#longident_loc a;\n self#list self#core_type b\n | Ptyp_alias (a, b) ->\n self#core_type a;\n self#string b\n | Ptyp_variant (a, b, c) ->\n self#list self#row_field a;\n self#closed_flag b;\n self#option (self#list self#label) c\n | Ptyp_poly (a, b) ->\n self#list (self#loc self#string) a;\n self#core_type b\n | Ptyp_package a -> self#package_type a\n | Ptyp_extension a -> self#extension a\n\n method package_type : package_type -> unit =\n fun (a, b) ->\n self#longident_loc a;\n self#list\n (fun (a, b) ->\n self#longident_loc a;\n self#core_type b)\n b\n\n method row_field : row_field -> unit =\n fun { prf_desc; prf_loc; prf_attributes } ->\n self#row_field_desc prf_desc;\n self#location prf_loc;\n self#attributes prf_attributes\n\n method row_field_desc : row_field_desc -> unit =\n fun x ->\n match x with\n | Rtag (a, b, c) ->\n self#loc self#label a;\n self#bool b;\n self#list self#core_type c\n | Rinherit a -> self#core_type a\n\n method object_field : object_field -> unit =\n fun { pof_desc; pof_loc; pof_attributes } ->\n self#object_field_desc pof_desc;\n self#location pof_loc;\n self#attributes pof_attributes\n\n method object_field_desc : object_field_desc -> unit =\n fun x ->\n match x with\n | Otag (a, b) ->\n self#loc self#label a;\n self#core_type b\n | Oinherit a -> self#core_type a\n\n method pattern : pattern -> unit =\n fun { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } ->\n self#pattern_desc ppat_desc;\n self#location ppat_loc;\n self#location_stack ppat_loc_stack;\n self#attributes ppat_attributes\n\n method pattern_desc : pattern_desc -> unit =\n fun x ->\n match x with\n | Ppat_any -> ()\n | Ppat_var a -> self#loc self#string a\n | Ppat_alias (a, b) ->\n self#pattern a;\n self#loc self#string b\n | Ppat_constant a -> self#constant a\n | Ppat_interval (a, b) ->\n self#constant a;\n self#constant b\n | Ppat_tuple a -> self#list self#pattern a\n | Ppat_construct (a, b) ->\n self#longident_loc a;\n self#option self#pattern b\n | Ppat_variant (a, b) ->\n self#label a;\n self#option self#pattern b\n | Ppat_record (a, b) ->\n self#list\n (fun (a, b) ->\n self#longident_loc a;\n self#pattern b)\n a;\n self#closed_flag b\n | Ppat_array a -> self#list self#pattern a\n | Ppat_or (a, b) ->\n self#pattern a;\n self#pattern b\n | Ppat_constraint (a, b) ->\n self#pattern a;\n self#core_type b\n | Ppat_type a -> self#longident_loc a\n | Ppat_lazy a -> self#pattern a\n | Ppat_unpack a -> self#loc (self#option self#string) a\n | Ppat_exception a -> self#pattern a\n | Ppat_extension a -> self#extension a\n | Ppat_open (a, b) ->\n self#longident_loc a;\n self#pattern b\n\n method expression : expression -> unit =\n fun { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } ->\n self#expression_desc pexp_desc;\n self#location pexp_loc;\n self#location_stack pexp_loc_stack;\n self#attributes pexp_attributes\n\n method expression_desc : expression_desc -> unit =\n fun x ->\n match x with\n | Pexp_ident a -> self#longident_loc a\n | Pexp_constant a -> self#constant a\n | Pexp_let (a, b, c) ->\n self#rec_flag a;\n self#list self#value_binding b;\n self#expression c\n | Pexp_function a -> self#cases a\n | Pexp_fun (a, b, c, d) ->\n self#arg_label a;\n self#option self#expression b;\n self#pattern c;\n self#expression d\n | Pexp_apply (a, b) ->\n self#expression a;\n self#list\n (fun (a, b) ->\n self#arg_label a;\n self#expression b)\n b\n | Pexp_match (a, b) ->\n self#expression a;\n self#cases b\n | Pexp_try (a, b) ->\n self#expression a;\n self#cases b\n | Pexp_tuple a -> self#list self#expression a\n | Pexp_construct (a, b) ->\n self#longident_loc a;\n self#option self#expression b\n | Pexp_variant (a, b) ->\n self#label a;\n self#option self#expression b\n | Pexp_record (a, b) ->\n self#list\n (fun (a, b) ->\n self#longident_loc a;\n self#expression b)\n a;\n self#option self#expression b\n | Pexp_field (a, b) ->\n self#expression a;\n self#longident_loc b\n | Pexp_setfield (a, b, c) ->\n self#expression a;\n self#longident_loc b;\n self#expression c\n | Pexp_array a -> self#list self#expression a\n | Pexp_ifthenelse (a, b, c) ->\n self#expression a;\n self#expression b;\n self#option self#expression c\n | Pexp_sequence (a, b) ->\n self#expression a;\n self#expression b\n | Pexp_while (a, b) ->\n self#expression a;\n self#expression b\n | Pexp_for (a, b, c, d, e) ->\n self#pattern a;\n self#expression b;\n self#expression c;\n self#direction_flag d;\n self#expression e\n | Pexp_constraint (a, b) ->\n self#expression a;\n self#core_type b\n | Pexp_coerce (a, b, c) ->\n self#expression a;\n self#option self#core_type b;\n self#core_type c\n | Pexp_send (a, b) ->\n self#expression a;\n self#loc self#label b\n | Pexp_new a -> self#longident_loc a\n | Pexp_setinstvar (a, b) ->\n self#loc self#label a;\n self#expression b\n | Pexp_override a ->\n self#list\n (fun (a, b) ->\n self#loc self#label a;\n self#expression b)\n a\n | Pexp_letmodule (a, b, c) ->\n self#loc (self#option self#string) a;\n self#module_expr b;\n self#expression c\n | Pexp_letexception (a, b) ->\n self#extension_constructor a;\n self#expression b\n | Pexp_assert a -> self#expression a\n | Pexp_lazy a -> self#expression a\n | Pexp_poly (a, b) ->\n self#expression a;\n self#option self#core_type b\n | Pexp_object a -> self#class_structure a\n | Pexp_newtype (a, b) ->\n self#loc self#string a;\n self#expression b\n | Pexp_pack a -> self#module_expr a\n | Pexp_open (a, b) ->\n self#open_declaration a;\n self#expression b\n | Pexp_letop a -> self#letop a\n | Pexp_extension a -> self#extension a\n | Pexp_unreachable -> ()\n\n method case : case -> unit =\n fun { pc_lhs; pc_guard; pc_rhs } ->\n self#pattern pc_lhs;\n self#option self#expression pc_guard;\n self#expression pc_rhs\n\n method letop : letop -> unit =\n fun { let_; ands; body } ->\n self#binding_op let_;\n self#list self#binding_op ands;\n self#expression body\n\n method binding_op : binding_op -> unit =\n fun { pbop_op; pbop_pat; pbop_exp; pbop_loc } ->\n self#loc self#string pbop_op;\n self#pattern pbop_pat;\n self#expression pbop_exp;\n self#location pbop_loc\n\n method value_description : value_description -> unit =\n fun { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } ->\n self#loc self#string pval_name;\n self#core_type pval_type;\n self#list self#string pval_prim;\n self#attributes pval_attributes;\n self#location pval_loc\n\n method type_declaration : type_declaration -> unit =\n fun {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } ->\n self#loc self#string ptype_name;\n self#list\n (fun (a, b) ->\n self#core_type a;\n (fun (a, b) ->\n self#variance a;\n self#injectivity b)\n b)\n ptype_params;\n self#list\n (fun (a, b, c) ->\n self#core_type a;\n self#core_type b;\n self#location c)\n ptype_cstrs;\n self#type_kind ptype_kind;\n self#private_flag ptype_private;\n self#option self#core_type ptype_manifest;\n self#attributes ptype_attributes;\n self#location ptype_loc\n\n method type_kind : type_kind -> unit =\n fun x ->\n match x with\n | Ptype_abstract -> ()\n | Ptype_variant a -> self#list self#constructor_declaration a\n | Ptype_record a -> self#list self#label_declaration a\n | Ptype_open -> ()\n\n method label_declaration : label_declaration -> unit =\n fun { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } ->\n self#loc self#string pld_name;\n self#mutable_flag pld_mutable;\n self#core_type pld_type;\n self#location pld_loc;\n self#attributes pld_attributes\n\n method constructor_declaration : constructor_declaration -> unit =\n fun { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } ->\n self#loc self#string pcd_name;\n self#constructor_arguments pcd_args;\n self#option self#core_type pcd_res;\n self#location pcd_loc;\n self#attributes pcd_attributes\n\n method constructor_arguments : constructor_arguments -> unit =\n fun x ->\n match x with\n | Pcstr_tuple a -> self#list self#core_type a\n | Pcstr_record a -> self#list self#label_declaration a\n\n method type_extension : type_extension -> unit =\n fun {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } ->\n self#longident_loc ptyext_path;\n self#list\n (fun (a, b) ->\n self#core_type a;\n (fun (a, b) ->\n self#variance a;\n self#injectivity b)\n b)\n ptyext_params;\n self#list self#extension_constructor ptyext_constructors;\n self#private_flag ptyext_private;\n self#location ptyext_loc;\n self#attributes ptyext_attributes\n\n method extension_constructor : extension_constructor -> unit =\n fun { pext_name; pext_kind; pext_loc; pext_attributes } ->\n self#loc self#string pext_name;\n self#extension_constructor_kind pext_kind;\n self#location pext_loc;\n self#attributes pext_attributes\n\n method type_exception : type_exception -> unit =\n fun { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } ->\n self#extension_constructor ptyexn_constructor;\n self#location ptyexn_loc;\n self#attributes ptyexn_attributes\n\n method extension_constructor_kind : extension_constructor_kind -> unit =\n fun x ->\n match x with\n | Pext_decl (a, b) ->\n self#constructor_arguments a;\n self#option self#core_type b\n | Pext_rebind a -> self#longident_loc a\n\n method class_type : class_type -> unit =\n fun { pcty_desc; pcty_loc; pcty_attributes } ->\n self#class_type_desc pcty_desc;\n self#location pcty_loc;\n self#attributes pcty_attributes\n\n method class_type_desc : class_type_desc -> unit =\n fun x ->\n match x with\n | Pcty_constr (a, b) ->\n self#longident_loc a;\n self#list self#core_type b\n | Pcty_signature a -> self#class_signature a\n | Pcty_arrow (a, b, c) ->\n self#arg_label a;\n self#core_type b;\n self#class_type c\n | Pcty_extension a -> self#extension a\n | Pcty_open (a, b) ->\n self#open_description a;\n self#class_type b\n\n method class_signature : class_signature -> unit =\n fun { pcsig_self; pcsig_fields } ->\n self#core_type pcsig_self;\n self#list self#class_type_field pcsig_fields\n\n method class_type_field : class_type_field -> unit =\n fun { pctf_desc; pctf_loc; pctf_attributes } ->\n self#class_type_field_desc pctf_desc;\n self#location pctf_loc;\n self#attributes pctf_attributes\n\n method class_type_field_desc : class_type_field_desc -> unit =\n fun x ->\n match x with\n | Pctf_inherit a -> self#class_type a\n | Pctf_val a ->\n (fun (a, b, c, d) ->\n self#loc self#label a;\n self#mutable_flag b;\n self#virtual_flag c;\n self#core_type d)\n a\n | Pctf_method a ->\n (fun (a, b, c, d) ->\n self#loc self#label a;\n self#private_flag b;\n self#virtual_flag c;\n self#core_type d)\n a\n | Pctf_constraint a ->\n (fun (a, b) ->\n self#core_type a;\n self#core_type b)\n a\n | Pctf_attribute a -> self#attribute a\n | Pctf_extension a -> self#extension a\n\n method class_infos : 'a. ('a -> unit) -> 'a class_infos -> unit =\n fun _a\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes } ->\n self#virtual_flag pci_virt;\n self#list\n (fun (a, b) ->\n self#core_type a;\n (fun (a, b) ->\n self#variance a;\n self#injectivity b)\n b)\n pci_params;\n self#loc self#string pci_name;\n _a pci_expr;\n self#location pci_loc;\n self#attributes pci_attributes\n\n method class_description : class_description -> unit =\n self#class_infos self#class_type\n\n method class_type_declaration : class_type_declaration -> unit =\n self#class_infos self#class_type\n\n method class_expr : class_expr -> unit =\n fun { pcl_desc; pcl_loc; pcl_attributes } ->\n self#class_expr_desc pcl_desc;\n self#location pcl_loc;\n self#attributes pcl_attributes\n\n method class_expr_desc : class_expr_desc -> unit =\n fun x ->\n match x with\n | Pcl_constr (a, b) ->\n self#longident_loc a;\n self#list self#core_type b\n | Pcl_structure a -> self#class_structure a\n | Pcl_fun (a, b, c, d) ->\n self#arg_label a;\n self#option self#expression b;\n self#pattern c;\n self#class_expr d\n | Pcl_apply (a, b) ->\n self#class_expr a;\n self#list\n (fun (a, b) ->\n self#arg_label a;\n self#expression b)\n b\n | Pcl_let (a, b, c) ->\n self#rec_flag a;\n self#list self#value_binding b;\n self#class_expr c\n | Pcl_constraint (a, b) ->\n self#class_expr a;\n self#class_type b\n | Pcl_extension a -> self#extension a\n | Pcl_open (a, b) ->\n self#open_description a;\n self#class_expr b\n\n method class_structure : class_structure -> unit =\n fun { pcstr_self; pcstr_fields } ->\n self#pattern pcstr_self;\n self#list self#class_field pcstr_fields\n\n method class_field : class_field -> unit =\n fun { pcf_desc; pcf_loc; pcf_attributes } ->\n self#class_field_desc pcf_desc;\n self#location pcf_loc;\n self#attributes pcf_attributes\n\n method class_field_desc : class_field_desc -> unit =\n fun x ->\n match x with\n | Pcf_inherit (a, b, c) ->\n self#override_flag a;\n self#class_expr b;\n self#option (self#loc self#string) c\n | Pcf_val a ->\n (fun (a, b, c) ->\n self#loc self#label a;\n self#mutable_flag b;\n self#class_field_kind c)\n a\n | Pcf_method a ->\n (fun (a, b, c) ->\n self#loc self#label a;\n self#private_flag b;\n self#class_field_kind c)\n a\n | Pcf_constraint a ->\n (fun (a, b) ->\n self#core_type a;\n self#core_type b)\n a\n | Pcf_initializer a -> self#expression a\n | Pcf_attribute a -> self#attribute a\n | Pcf_extension a -> self#extension a\n\n method class_field_kind : class_field_kind -> unit =\n fun x ->\n match x with\n | Cfk_virtual a -> self#core_type a\n | Cfk_concrete (a, b) ->\n self#override_flag a;\n self#expression b\n\n method class_declaration : class_declaration -> unit =\n self#class_infos self#class_expr\n\n method module_type : module_type -> unit =\n fun { pmty_desc; pmty_loc; pmty_attributes } ->\n self#module_type_desc pmty_desc;\n self#location pmty_loc;\n self#attributes pmty_attributes\n\n method module_type_desc : module_type_desc -> unit =\n fun x ->\n match x with\n | Pmty_ident a -> self#longident_loc a\n | Pmty_signature a -> self#signature a\n | Pmty_functor (a, b) ->\n self#functor_parameter a;\n self#module_type b\n | Pmty_with (a, b) ->\n self#module_type a;\n self#list self#with_constraint b\n | Pmty_typeof a -> self#module_expr a\n | Pmty_extension a -> self#extension a\n | Pmty_alias a -> self#longident_loc a\n\n method functor_parameter : functor_parameter -> unit =\n fun x ->\n match x with\n | Unit -> ()\n | Named (a, b) ->\n self#loc (self#option self#string) a;\n self#module_type b\n\n method signature : signature -> unit = self#list self#signature_item\n\n method signature_item : signature_item -> unit =\n fun { psig_desc; psig_loc } ->\n self#signature_item_desc psig_desc;\n self#location psig_loc\n\n method signature_item_desc : signature_item_desc -> unit =\n fun x ->\n match x with\n | Psig_value a -> self#value_description a\n | Psig_type (a, b) ->\n self#rec_flag a;\n self#list self#type_declaration b\n | Psig_typesubst a -> self#list self#type_declaration a\n | Psig_typext a -> self#type_extension a\n | Psig_exception a -> self#type_exception a\n | Psig_module a -> self#module_declaration a\n | Psig_modsubst a -> self#module_substitution a\n | Psig_recmodule a -> self#list self#module_declaration a\n | Psig_modtype a -> self#module_type_declaration a\n | Psig_open a -> self#open_description a\n | Psig_include a -> self#include_description a\n | Psig_class a -> self#list self#class_description a\n | Psig_class_type a -> self#list self#class_type_declaration a\n | Psig_attribute a -> self#attribute a\n | Psig_extension (a, b) ->\n self#extension a;\n self#attributes b\n\n method module_declaration : module_declaration -> unit =\n fun { pmd_name; pmd_type; pmd_attributes; pmd_loc } ->\n self#loc (self#option self#string) pmd_name;\n self#module_type pmd_type;\n self#attributes pmd_attributes;\n self#location pmd_loc\n\n method module_substitution : module_substitution -> unit =\n fun { pms_name; pms_manifest; pms_attributes; pms_loc } ->\n self#loc self#string pms_name;\n self#longident_loc pms_manifest;\n self#attributes pms_attributes;\n self#location pms_loc\n\n method module_type_declaration : module_type_declaration -> unit =\n fun { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } ->\n self#loc self#string pmtd_name;\n self#option self#module_type pmtd_type;\n self#attributes pmtd_attributes;\n self#location pmtd_loc\n\n method open_infos : 'a. ('a -> unit) -> 'a open_infos -> unit =\n fun _a { popen_expr; popen_override; popen_loc; popen_attributes } ->\n _a popen_expr;\n self#override_flag popen_override;\n self#location popen_loc;\n self#attributes popen_attributes\n\n method open_description : open_description -> unit =\n self#open_infos self#longident_loc\n\n method open_declaration : open_declaration -> unit =\n self#open_infos self#module_expr\n\n method include_infos : 'a. ('a -> unit) -> 'a include_infos -> unit =\n fun _a { pincl_mod; pincl_loc; pincl_attributes } ->\n _a pincl_mod;\n self#location pincl_loc;\n self#attributes pincl_attributes\n\n method include_description : include_description -> unit =\n self#include_infos self#module_type\n\n method include_declaration : include_declaration -> unit =\n self#include_infos self#module_expr\n\n method with_constraint : with_constraint -> unit =\n fun x ->\n match x with\n | Pwith_type (a, b) ->\n self#longident_loc a;\n self#type_declaration b\n | Pwith_module (a, b) ->\n self#longident_loc a;\n self#longident_loc b\n | Pwith_typesubst (a, b) ->\n self#longident_loc a;\n self#type_declaration b\n | Pwith_modsubst (a, b) ->\n self#longident_loc a;\n self#longident_loc b\n\n method module_expr : module_expr -> unit =\n fun { pmod_desc; pmod_loc; pmod_attributes } ->\n self#module_expr_desc pmod_desc;\n self#location pmod_loc;\n self#attributes pmod_attributes\n\n method module_expr_desc : module_expr_desc -> unit =\n fun x ->\n match x with\n | Pmod_ident a -> self#longident_loc a\n | Pmod_structure a -> self#structure a\n | Pmod_functor (a, b) ->\n self#functor_parameter a;\n self#module_expr b\n | Pmod_apply (a, b) ->\n self#module_expr a;\n self#module_expr b\n | Pmod_constraint (a, b) ->\n self#module_expr a;\n self#module_type b\n | Pmod_unpack a -> self#expression a\n | Pmod_extension a -> self#extension a\n\n method structure : structure -> unit = self#list self#structure_item\n\n method structure_item : structure_item -> unit =\n fun { pstr_desc; pstr_loc } ->\n self#structure_item_desc pstr_desc;\n self#location pstr_loc\n\n method structure_item_desc : structure_item_desc -> unit =\n fun x ->\n match x with\n | Pstr_eval (a, b) ->\n self#expression a;\n self#attributes b\n | Pstr_value (a, b) ->\n self#rec_flag a;\n self#list self#value_binding b\n | Pstr_primitive a -> self#value_description a\n | Pstr_type (a, b) ->\n self#rec_flag a;\n self#list self#type_declaration b\n | Pstr_typext a -> self#type_extension a\n | Pstr_exception a -> self#type_exception a\n | Pstr_module a -> self#module_binding a\n | Pstr_recmodule a -> self#list self#module_binding a\n | Pstr_modtype a -> self#module_type_declaration a\n | Pstr_open a -> self#open_declaration a\n | Pstr_class a -> self#list self#class_declaration a\n | Pstr_class_type a -> self#list self#class_type_declaration a\n | Pstr_include a -> self#include_declaration a\n | Pstr_attribute a -> self#attribute a\n | Pstr_extension (a, b) ->\n self#extension a;\n self#attributes b\n\n method value_binding : value_binding -> unit =\n fun { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } ->\n self#pattern pvb_pat;\n self#expression pvb_expr;\n self#attributes pvb_attributes;\n self#location pvb_loc\n\n method module_binding : module_binding -> unit =\n fun { pmb_name; pmb_expr; pmb_attributes; pmb_loc } ->\n self#loc (self#option self#string) pmb_name;\n self#module_expr pmb_expr;\n self#attributes pmb_attributes;\n self#location pmb_loc\n\n method toplevel_phrase : toplevel_phrase -> unit =\n fun x ->\n match x with\n | Ptop_def a -> self#structure a\n | Ptop_dir a -> self#toplevel_directive a\n\n method toplevel_directive : toplevel_directive -> unit =\n fun { pdir_name; pdir_arg; pdir_loc } ->\n self#loc self#string pdir_name;\n self#option self#directive_argument pdir_arg;\n self#location pdir_loc\n\n method directive_argument : directive_argument -> unit =\n fun { pdira_desc; pdira_loc } ->\n self#directive_argument_desc pdira_desc;\n self#location pdira_loc\n\n method directive_argument_desc : directive_argument_desc -> unit =\n fun x ->\n match x with\n | Pdir_string a -> self#string a\n | Pdir_int (a, b) ->\n self#string a;\n self#option self#char b\n | Pdir_ident a -> self#longident a\n | Pdir_bool a -> self#bool a\n\n method cases : cases -> unit = self#list self#case\n end\n\nclass virtual ['acc] fold =\n object (self)\n method virtual bool : bool -> 'acc -> 'acc\n method virtual char : char -> 'acc -> 'acc\n method virtual int : int -> 'acc -> 'acc\n method virtual list : 'a. ('a -> 'acc -> 'acc) -> 'a list -> 'acc -> 'acc\n\n method virtual option\n : 'a. ('a -> 'acc -> 'acc) -> 'a option -> 'acc -> 'acc\n\n method virtual string : string -> 'acc -> 'acc\n\n method position : position -> 'acc -> 'acc =\n fun { pos_fname; pos_lnum; pos_bol; pos_cnum } acc ->\n let acc = self#string pos_fname acc in\n let acc = self#int pos_lnum acc in\n let acc = self#int pos_bol acc in\n let acc = self#int pos_cnum acc in\n acc\n\n method location : location -> 'acc -> 'acc =\n fun { loc_start; loc_end; loc_ghost } acc ->\n let acc = self#position loc_start acc in\n let acc = self#position loc_end acc in\n let acc = self#bool loc_ghost acc in\n acc\n\n method location_stack : location_stack -> 'acc -> 'acc =\n self#list self#location\n\n method loc : 'a. ('a -> 'acc -> 'acc) -> 'a loc -> 'acc -> 'acc =\n fun _a { txt; loc } acc ->\n let acc = _a txt acc in\n let acc = self#location loc acc in\n acc\n\n method longident : longident -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Lident a -> self#string a acc\n | Ldot (a, b) ->\n let acc = self#longident a acc in\n let acc = self#string b acc in\n acc\n | Lapply (a, b) ->\n let acc = self#longident a acc in\n let acc = self#longident b acc in\n acc\n\n method longident_loc : longident_loc -> 'acc -> 'acc =\n self#loc self#longident\n\n method rec_flag : rec_flag -> 'acc -> 'acc = fun _ acc -> acc\n method direction_flag : direction_flag -> 'acc -> 'acc = fun _ acc -> acc\n method private_flag : private_flag -> 'acc -> 'acc = fun _ acc -> acc\n method mutable_flag : mutable_flag -> 'acc -> 'acc = fun _ acc -> acc\n method virtual_flag : virtual_flag -> 'acc -> 'acc = fun _ acc -> acc\n method override_flag : override_flag -> 'acc -> 'acc = fun _ acc -> acc\n method closed_flag : closed_flag -> 'acc -> 'acc = fun _ acc -> acc\n method label : label -> 'acc -> 'acc = self#string\n\n method arg_label : arg_label -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Nolabel -> acc\n | Labelled a -> self#string a acc\n | Optional a -> self#string a acc\n\n method variance : variance -> 'acc -> 'acc = fun _ acc -> acc\n method injectivity : injectivity -> 'acc -> 'acc = fun _ acc -> acc\n\n method constant : constant -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pconst_integer (a, b) ->\n let acc = self#string a acc in\n let acc = self#option self#char b acc in\n acc\n | Pconst_char a -> self#char a acc\n | Pconst_string (a, b, c) ->\n let acc = self#string a acc in\n let acc = self#location b acc in\n let acc = self#option self#string c acc in\n acc\n | Pconst_float (a, b) ->\n let acc = self#string a acc in\n let acc = self#option self#char b acc in\n acc\n\n method attribute : attribute -> 'acc -> 'acc =\n fun { attr_name; attr_payload; attr_loc } acc ->\n let acc = self#loc self#string attr_name acc in\n let acc = self#payload attr_payload acc in\n let acc = self#location attr_loc acc in\n acc\n\n method extension : extension -> 'acc -> 'acc =\n fun (a, b) acc ->\n let acc = self#loc self#string a acc in\n let acc = self#payload b acc in\n acc\n\n method attributes : attributes -> 'acc -> 'acc = self#list self#attribute\n\n method payload : payload -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | PStr a -> self#structure a acc\n | PSig a -> self#signature a acc\n | PTyp a -> self#core_type a acc\n | PPat (a, b) ->\n let acc = self#pattern a acc in\n let acc = self#option self#expression b acc in\n acc\n\n method core_type : core_type -> 'acc -> 'acc =\n fun { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } acc ->\n let acc = self#core_type_desc ptyp_desc acc in\n let acc = self#location ptyp_loc acc in\n let acc = self#location_stack ptyp_loc_stack acc in\n let acc = self#attributes ptyp_attributes acc in\n acc\n\n method core_type_desc : core_type_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Ptyp_any -> acc\n | Ptyp_var a -> self#string a acc\n | Ptyp_arrow (a, b, c) ->\n let acc = self#arg_label a acc in\n let acc = self#core_type b acc in\n let acc = self#core_type c acc in\n acc\n | Ptyp_tuple a -> self#list self#core_type a acc\n | Ptyp_constr (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#list self#core_type b acc in\n acc\n | Ptyp_object (a, b) ->\n let acc = self#list self#object_field a acc in\n let acc = self#closed_flag b acc in\n acc\n | Ptyp_class (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#list self#core_type b acc in\n acc\n | Ptyp_alias (a, b) ->\n let acc = self#core_type a acc in\n let acc = self#string b acc in\n acc\n | Ptyp_variant (a, b, c) ->\n let acc = self#list self#row_field a acc in\n let acc = self#closed_flag b acc in\n let acc = self#option (self#list self#label) c acc in\n acc\n | Ptyp_poly (a, b) ->\n let acc = self#list (self#loc self#string) a acc in\n let acc = self#core_type b acc in\n acc\n | Ptyp_package a -> self#package_type a acc\n | Ptyp_extension a -> self#extension a acc\n\n method package_type : package_type -> 'acc -> 'acc =\n fun (a, b) acc ->\n let acc = self#longident_loc a acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#longident_loc a acc in\n let acc = self#core_type b acc in\n acc)\n b acc\n in\n acc\n\n method row_field : row_field -> 'acc -> 'acc =\n fun { prf_desc; prf_loc; prf_attributes } acc ->\n let acc = self#row_field_desc prf_desc acc in\n let acc = self#location prf_loc acc in\n let acc = self#attributes prf_attributes acc in\n acc\n\n method row_field_desc : row_field_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Rtag (a, b, c) ->\n let acc = self#loc self#label a acc in\n let acc = self#bool b acc in\n let acc = self#list self#core_type c acc in\n acc\n | Rinherit a -> self#core_type a acc\n\n method object_field : object_field -> 'acc -> 'acc =\n fun { pof_desc; pof_loc; pof_attributes } acc ->\n let acc = self#object_field_desc pof_desc acc in\n let acc = self#location pof_loc acc in\n let acc = self#attributes pof_attributes acc in\n acc\n\n method object_field_desc : object_field_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Otag (a, b) ->\n let acc = self#loc self#label a acc in\n let acc = self#core_type b acc in\n acc\n | Oinherit a -> self#core_type a acc\n\n method pattern : pattern -> 'acc -> 'acc =\n fun { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } acc ->\n let acc = self#pattern_desc ppat_desc acc in\n let acc = self#location ppat_loc acc in\n let acc = self#location_stack ppat_loc_stack acc in\n let acc = self#attributes ppat_attributes acc in\n acc\n\n method pattern_desc : pattern_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Ppat_any -> acc\n | Ppat_var a -> self#loc self#string a acc\n | Ppat_alias (a, b) ->\n let acc = self#pattern a acc in\n let acc = self#loc self#string b acc in\n acc\n | Ppat_constant a -> self#constant a acc\n | Ppat_interval (a, b) ->\n let acc = self#constant a acc in\n let acc = self#constant b acc in\n acc\n | Ppat_tuple a -> self#list self#pattern a acc\n | Ppat_construct (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#option self#pattern b acc in\n acc\n | Ppat_variant (a, b) ->\n let acc = self#label a acc in\n let acc = self#option self#pattern b acc in\n acc\n | Ppat_record (a, b) ->\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#longident_loc a acc in\n let acc = self#pattern b acc in\n acc)\n a acc\n in\n let acc = self#closed_flag b acc in\n acc\n | Ppat_array a -> self#list self#pattern a acc\n | Ppat_or (a, b) ->\n let acc = self#pattern a acc in\n let acc = self#pattern b acc in\n acc\n | Ppat_constraint (a, b) ->\n let acc = self#pattern a acc in\n let acc = self#core_type b acc in\n acc\n | Ppat_type a -> self#longident_loc a acc\n | Ppat_lazy a -> self#pattern a acc\n | Ppat_unpack a -> self#loc (self#option self#string) a acc\n | Ppat_exception a -> self#pattern a acc\n | Ppat_extension a -> self#extension a acc\n | Ppat_open (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#pattern b acc in\n acc\n\n method expression : expression -> 'acc -> 'acc =\n fun { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } acc ->\n let acc = self#expression_desc pexp_desc acc in\n let acc = self#location pexp_loc acc in\n let acc = self#location_stack pexp_loc_stack acc in\n let acc = self#attributes pexp_attributes acc in\n acc\n\n method expression_desc : expression_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pexp_ident a -> self#longident_loc a acc\n | Pexp_constant a -> self#constant a acc\n | Pexp_let (a, b, c) ->\n let acc = self#rec_flag a acc in\n let acc = self#list self#value_binding b acc in\n let acc = self#expression c acc in\n acc\n | Pexp_function a -> self#cases a acc\n | Pexp_fun (a, b, c, d) ->\n let acc = self#arg_label a acc in\n let acc = self#option self#expression b acc in\n let acc = self#pattern c acc in\n let acc = self#expression d acc in\n acc\n | Pexp_apply (a, b) ->\n let acc = self#expression a acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#arg_label a acc in\n let acc = self#expression b acc in\n acc)\n b acc\n in\n acc\n | Pexp_match (a, b) ->\n let acc = self#expression a acc in\n let acc = self#cases b acc in\n acc\n | Pexp_try (a, b) ->\n let acc = self#expression a acc in\n let acc = self#cases b acc in\n acc\n | Pexp_tuple a -> self#list self#expression a acc\n | Pexp_construct (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#option self#expression b acc in\n acc\n | Pexp_variant (a, b) ->\n let acc = self#label a acc in\n let acc = self#option self#expression b acc in\n acc\n | Pexp_record (a, b) ->\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#longident_loc a acc in\n let acc = self#expression b acc in\n acc)\n a acc\n in\n let acc = self#option self#expression b acc in\n acc\n | Pexp_field (a, b) ->\n let acc = self#expression a acc in\n let acc = self#longident_loc b acc in\n acc\n | Pexp_setfield (a, b, c) ->\n let acc = self#expression a acc in\n let acc = self#longident_loc b acc in\n let acc = self#expression c acc in\n acc\n | Pexp_array a -> self#list self#expression a acc\n | Pexp_ifthenelse (a, b, c) ->\n let acc = self#expression a acc in\n let acc = self#expression b acc in\n let acc = self#option self#expression c acc in\n acc\n | Pexp_sequence (a, b) ->\n let acc = self#expression a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_while (a, b) ->\n let acc = self#expression a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_for (a, b, c, d, e) ->\n let acc = self#pattern a acc in\n let acc = self#expression b acc in\n let acc = self#expression c acc in\n let acc = self#direction_flag d acc in\n let acc = self#expression e acc in\n acc\n | Pexp_constraint (a, b) ->\n let acc = self#expression a acc in\n let acc = self#core_type b acc in\n acc\n | Pexp_coerce (a, b, c) ->\n let acc = self#expression a acc in\n let acc = self#option self#core_type b acc in\n let acc = self#core_type c acc in\n acc\n | Pexp_send (a, b) ->\n let acc = self#expression a acc in\n let acc = self#loc self#label b acc in\n acc\n | Pexp_new a -> self#longident_loc a acc\n | Pexp_setinstvar (a, b) ->\n let acc = self#loc self#label a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_override a ->\n self#list\n (fun (a, b) acc ->\n let acc = self#loc self#label a acc in\n let acc = self#expression b acc in\n acc)\n a acc\n | Pexp_letmodule (a, b, c) ->\n let acc = self#loc (self#option self#string) a acc in\n let acc = self#module_expr b acc in\n let acc = self#expression c acc in\n acc\n | Pexp_letexception (a, b) ->\n let acc = self#extension_constructor a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_assert a -> self#expression a acc\n | Pexp_lazy a -> self#expression a acc\n | Pexp_poly (a, b) ->\n let acc = self#expression a acc in\n let acc = self#option self#core_type b acc in\n acc\n | Pexp_object a -> self#class_structure a acc\n | Pexp_newtype (a, b) ->\n let acc = self#loc self#string a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_pack a -> self#module_expr a acc\n | Pexp_open (a, b) ->\n let acc = self#open_declaration a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_letop a -> self#letop a acc\n | Pexp_extension a -> self#extension a acc\n | Pexp_unreachable -> acc\n\n method case : case -> 'acc -> 'acc =\n fun { pc_lhs; pc_guard; pc_rhs } acc ->\n let acc = self#pattern pc_lhs acc in\n let acc = self#option self#expression pc_guard acc in\n let acc = self#expression pc_rhs acc in\n acc\n\n method letop : letop -> 'acc -> 'acc =\n fun { let_; ands; body } acc ->\n let acc = self#binding_op let_ acc in\n let acc = self#list self#binding_op ands acc in\n let acc = self#expression body acc in\n acc\n\n method binding_op : binding_op -> 'acc -> 'acc =\n fun { pbop_op; pbop_pat; pbop_exp; pbop_loc } acc ->\n let acc = self#loc self#string pbop_op acc in\n let acc = self#pattern pbop_pat acc in\n let acc = self#expression pbop_exp acc in\n let acc = self#location pbop_loc acc in\n acc\n\n method value_description : value_description -> 'acc -> 'acc =\n fun { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } acc ->\n let acc = self#loc self#string pval_name acc in\n let acc = self#core_type pval_type acc in\n let acc = self#list self#string pval_prim acc in\n let acc = self#attributes pval_attributes acc in\n let acc = self#location pval_loc acc in\n acc\n\n method type_declaration : type_declaration -> 'acc -> 'acc =\n fun {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } acc ->\n let acc = self#loc self#string ptype_name acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#core_type a acc in\n let acc =\n (fun (a, b) acc ->\n let acc = self#variance a acc in\n let acc = self#injectivity b acc in\n acc)\n b acc\n in\n acc)\n ptype_params acc\n in\n let acc =\n self#list\n (fun (a, b, c) acc ->\n let acc = self#core_type a acc in\n let acc = self#core_type b acc in\n let acc = self#location c acc in\n acc)\n ptype_cstrs acc\n in\n let acc = self#type_kind ptype_kind acc in\n let acc = self#private_flag ptype_private acc in\n let acc = self#option self#core_type ptype_manifest acc in\n let acc = self#attributes ptype_attributes acc in\n let acc = self#location ptype_loc acc in\n acc\n\n method type_kind : type_kind -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Ptype_abstract -> acc\n | Ptype_variant a -> self#list self#constructor_declaration a acc\n | Ptype_record a -> self#list self#label_declaration a acc\n | Ptype_open -> acc\n\n method label_declaration : label_declaration -> 'acc -> 'acc =\n fun { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } acc ->\n let acc = self#loc self#string pld_name acc in\n let acc = self#mutable_flag pld_mutable acc in\n let acc = self#core_type pld_type acc in\n let acc = self#location pld_loc acc in\n let acc = self#attributes pld_attributes acc in\n acc\n\n method constructor_declaration : constructor_declaration -> 'acc -> 'acc =\n fun { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } acc ->\n let acc = self#loc self#string pcd_name acc in\n let acc = self#constructor_arguments pcd_args acc in\n let acc = self#option self#core_type pcd_res acc in\n let acc = self#location pcd_loc acc in\n let acc = self#attributes pcd_attributes acc in\n acc\n\n method constructor_arguments : constructor_arguments -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pcstr_tuple a -> self#list self#core_type a acc\n | Pcstr_record a -> self#list self#label_declaration a acc\n\n method type_extension : type_extension -> 'acc -> 'acc =\n fun {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } acc ->\n let acc = self#longident_loc ptyext_path acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#core_type a acc in\n let acc =\n (fun (a, b) acc ->\n let acc = self#variance a acc in\n let acc = self#injectivity b acc in\n acc)\n b acc\n in\n acc)\n ptyext_params acc\n in\n let acc =\n self#list self#extension_constructor ptyext_constructors acc\n in\n let acc = self#private_flag ptyext_private acc in\n let acc = self#location ptyext_loc acc in\n let acc = self#attributes ptyext_attributes acc in\n acc\n\n method extension_constructor : extension_constructor -> 'acc -> 'acc =\n fun { pext_name; pext_kind; pext_loc; pext_attributes } acc ->\n let acc = self#loc self#string pext_name acc in\n let acc = self#extension_constructor_kind pext_kind acc in\n let acc = self#location pext_loc acc in\n let acc = self#attributes pext_attributes acc in\n acc\n\n method type_exception : type_exception -> 'acc -> 'acc =\n fun { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } acc ->\n let acc = self#extension_constructor ptyexn_constructor acc in\n let acc = self#location ptyexn_loc acc in\n let acc = self#attributes ptyexn_attributes acc in\n acc\n\n method extension_constructor_kind\n : extension_constructor_kind -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pext_decl (a, b) ->\n let acc = self#constructor_arguments a acc in\n let acc = self#option self#core_type b acc in\n acc\n | Pext_rebind a -> self#longident_loc a acc\n\n method class_type : class_type -> 'acc -> 'acc =\n fun { pcty_desc; pcty_loc; pcty_attributes } acc ->\n let acc = self#class_type_desc pcty_desc acc in\n let acc = self#location pcty_loc acc in\n let acc = self#attributes pcty_attributes acc in\n acc\n\n method class_type_desc : class_type_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pcty_constr (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#list self#core_type b acc in\n acc\n | Pcty_signature a -> self#class_signature a acc\n | Pcty_arrow (a, b, c) ->\n let acc = self#arg_label a acc in\n let acc = self#core_type b acc in\n let acc = self#class_type c acc in\n acc\n | Pcty_extension a -> self#extension a acc\n | Pcty_open (a, b) ->\n let acc = self#open_description a acc in\n let acc = self#class_type b acc in\n acc\n\n method class_signature : class_signature -> 'acc -> 'acc =\n fun { pcsig_self; pcsig_fields } acc ->\n let acc = self#core_type pcsig_self acc in\n let acc = self#list self#class_type_field pcsig_fields acc in\n acc\n\n method class_type_field : class_type_field -> 'acc -> 'acc =\n fun { pctf_desc; pctf_loc; pctf_attributes } acc ->\n let acc = self#class_type_field_desc pctf_desc acc in\n let acc = self#location pctf_loc acc in\n let acc = self#attributes pctf_attributes acc in\n acc\n\n method class_type_field_desc : class_type_field_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pctf_inherit a -> self#class_type a acc\n | Pctf_val a ->\n (fun (a, b, c, d) acc ->\n let acc = self#loc self#label a acc in\n let acc = self#mutable_flag b acc in\n let acc = self#virtual_flag c acc in\n let acc = self#core_type d acc in\n acc)\n a acc\n | Pctf_method a ->\n (fun (a, b, c, d) acc ->\n let acc = self#loc self#label a acc in\n let acc = self#private_flag b acc in\n let acc = self#virtual_flag c acc in\n let acc = self#core_type d acc in\n acc)\n a acc\n | Pctf_constraint a ->\n (fun (a, b) acc ->\n let acc = self#core_type a acc in\n let acc = self#core_type b acc in\n acc)\n a acc\n | Pctf_attribute a -> self#attribute a acc\n | Pctf_extension a -> self#extension a acc\n\n method class_infos\n : 'a. ('a -> 'acc -> 'acc) -> 'a class_infos -> 'acc -> 'acc =\n fun _a\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes }\n acc ->\n let acc = self#virtual_flag pci_virt acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#core_type a acc in\n let acc =\n (fun (a, b) acc ->\n let acc = self#variance a acc in\n let acc = self#injectivity b acc in\n acc)\n b acc\n in\n acc)\n pci_params acc\n in\n let acc = self#loc self#string pci_name acc in\n let acc = _a pci_expr acc in\n let acc = self#location pci_loc acc in\n let acc = self#attributes pci_attributes acc in\n acc\n\n method class_description : class_description -> 'acc -> 'acc =\n self#class_infos self#class_type\n\n method class_type_declaration : class_type_declaration -> 'acc -> 'acc =\n self#class_infos self#class_type\n\n method class_expr : class_expr -> 'acc -> 'acc =\n fun { pcl_desc; pcl_loc; pcl_attributes } acc ->\n let acc = self#class_expr_desc pcl_desc acc in\n let acc = self#location pcl_loc acc in\n let acc = self#attributes pcl_attributes acc in\n acc\n\n method class_expr_desc : class_expr_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pcl_constr (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#list self#core_type b acc in\n acc\n | Pcl_structure a -> self#class_structure a acc\n | Pcl_fun (a, b, c, d) ->\n let acc = self#arg_label a acc in\n let acc = self#option self#expression b acc in\n let acc = self#pattern c acc in\n let acc = self#class_expr d acc in\n acc\n | Pcl_apply (a, b) ->\n let acc = self#class_expr a acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#arg_label a acc in\n let acc = self#expression b acc in\n acc)\n b acc\n in\n acc\n | Pcl_let (a, b, c) ->\n let acc = self#rec_flag a acc in\n let acc = self#list self#value_binding b acc in\n let acc = self#class_expr c acc in\n acc\n | Pcl_constraint (a, b) ->\n let acc = self#class_expr a acc in\n let acc = self#class_type b acc in\n acc\n | Pcl_extension a -> self#extension a acc\n | Pcl_open (a, b) ->\n let acc = self#open_description a acc in\n let acc = self#class_expr b acc in\n acc\n\n method class_structure : class_structure -> 'acc -> 'acc =\n fun { pcstr_self; pcstr_fields } acc ->\n let acc = self#pattern pcstr_self acc in\n let acc = self#list self#class_field pcstr_fields acc in\n acc\n\n method class_field : class_field -> 'acc -> 'acc =\n fun { pcf_desc; pcf_loc; pcf_attributes } acc ->\n let acc = self#class_field_desc pcf_desc acc in\n let acc = self#location pcf_loc acc in\n let acc = self#attributes pcf_attributes acc in\n acc\n\n method class_field_desc : class_field_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pcf_inherit (a, b, c) ->\n let acc = self#override_flag a acc in\n let acc = self#class_expr b acc in\n let acc = self#option (self#loc self#string) c acc in\n acc\n | Pcf_val a ->\n (fun (a, b, c) acc ->\n let acc = self#loc self#label a acc in\n let acc = self#mutable_flag b acc in\n let acc = self#class_field_kind c acc in\n acc)\n a acc\n | Pcf_method a ->\n (fun (a, b, c) acc ->\n let acc = self#loc self#label a acc in\n let acc = self#private_flag b acc in\n let acc = self#class_field_kind c acc in\n acc)\n a acc\n | Pcf_constraint a ->\n (fun (a, b) acc ->\n let acc = self#core_type a acc in\n let acc = self#core_type b acc in\n acc)\n a acc\n | Pcf_initializer a -> self#expression a acc\n | Pcf_attribute a -> self#attribute a acc\n | Pcf_extension a -> self#extension a acc\n\n method class_field_kind : class_field_kind -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Cfk_virtual a -> self#core_type a acc\n | Cfk_concrete (a, b) ->\n let acc = self#override_flag a acc in\n let acc = self#expression b acc in\n acc\n\n method class_declaration : class_declaration -> 'acc -> 'acc =\n self#class_infos self#class_expr\n\n method module_type : module_type -> 'acc -> 'acc =\n fun { pmty_desc; pmty_loc; pmty_attributes } acc ->\n let acc = self#module_type_desc pmty_desc acc in\n let acc = self#location pmty_loc acc in\n let acc = self#attributes pmty_attributes acc in\n acc\n\n method module_type_desc : module_type_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pmty_ident a -> self#longident_loc a acc\n | Pmty_signature a -> self#signature a acc\n | Pmty_functor (a, b) ->\n let acc = self#functor_parameter a acc in\n let acc = self#module_type b acc in\n acc\n | Pmty_with (a, b) ->\n let acc = self#module_type a acc in\n let acc = self#list self#with_constraint b acc in\n acc\n | Pmty_typeof a -> self#module_expr a acc\n | Pmty_extension a -> self#extension a acc\n | Pmty_alias a -> self#longident_loc a acc\n\n method functor_parameter : functor_parameter -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Unit -> acc\n | Named (a, b) ->\n let acc = self#loc (self#option self#string) a acc in\n let acc = self#module_type b acc in\n acc\n\n method signature : signature -> 'acc -> 'acc = self#list self#signature_item\n\n method signature_item : signature_item -> 'acc -> 'acc =\n fun { psig_desc; psig_loc } acc ->\n let acc = self#signature_item_desc psig_desc acc in\n let acc = self#location psig_loc acc in\n acc\n\n method signature_item_desc : signature_item_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Psig_value a -> self#value_description a acc\n | Psig_type (a, b) ->\n let acc = self#rec_flag a acc in\n let acc = self#list self#type_declaration b acc in\n acc\n | Psig_typesubst a -> self#list self#type_declaration a acc\n | Psig_typext a -> self#type_extension a acc\n | Psig_exception a -> self#type_exception a acc\n | Psig_module a -> self#module_declaration a acc\n | Psig_modsubst a -> self#module_substitution a acc\n | Psig_recmodule a -> self#list self#module_declaration a acc\n | Psig_modtype a -> self#module_type_declaration a acc\n | Psig_open a -> self#open_description a acc\n | Psig_include a -> self#include_description a acc\n | Psig_class a -> self#list self#class_description a acc\n | Psig_class_type a -> self#list self#class_type_declaration a acc\n | Psig_attribute a -> self#attribute a acc\n | Psig_extension (a, b) ->\n let acc = self#extension a acc in\n let acc = self#attributes b acc in\n acc\n\n method module_declaration : module_declaration -> 'acc -> 'acc =\n fun { pmd_name; pmd_type; pmd_attributes; pmd_loc } acc ->\n let acc = self#loc (self#option self#string) pmd_name acc in\n let acc = self#module_type pmd_type acc in\n let acc = self#attributes pmd_attributes acc in\n let acc = self#location pmd_loc acc in\n acc\n\n method module_substitution : module_substitution -> 'acc -> 'acc =\n fun { pms_name; pms_manifest; pms_attributes; pms_loc } acc ->\n let acc = self#loc self#string pms_name acc in\n let acc = self#longident_loc pms_manifest acc in\n let acc = self#attributes pms_attributes acc in\n let acc = self#location pms_loc acc in\n acc\n\n method module_type_declaration : module_type_declaration -> 'acc -> 'acc =\n fun { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } acc ->\n let acc = self#loc self#string pmtd_name acc in\n let acc = self#option self#module_type pmtd_type acc in\n let acc = self#attributes pmtd_attributes acc in\n let acc = self#location pmtd_loc acc in\n acc\n\n method open_infos\n : 'a. ('a -> 'acc -> 'acc) -> 'a open_infos -> 'acc -> 'acc =\n fun _a { popen_expr; popen_override; popen_loc; popen_attributes } acc ->\n let acc = _a popen_expr acc in\n let acc = self#override_flag popen_override acc in\n let acc = self#location popen_loc acc in\n let acc = self#attributes popen_attributes acc in\n acc\n\n method open_description : open_description -> 'acc -> 'acc =\n self#open_infos self#longident_loc\n\n method open_declaration : open_declaration -> 'acc -> 'acc =\n self#open_infos self#module_expr\n\n method include_infos\n : 'a. ('a -> 'acc -> 'acc) -> 'a include_infos -> 'acc -> 'acc =\n fun _a { pincl_mod; pincl_loc; pincl_attributes } acc ->\n let acc = _a pincl_mod acc in\n let acc = self#location pincl_loc acc in\n let acc = self#attributes pincl_attributes acc in\n acc\n\n method include_description : include_description -> 'acc -> 'acc =\n self#include_infos self#module_type\n\n method include_declaration : include_declaration -> 'acc -> 'acc =\n self#include_infos self#module_expr\n\n method with_constraint : with_constraint -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pwith_type (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#type_declaration b acc in\n acc\n | Pwith_module (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#longident_loc b acc in\n acc\n | Pwith_typesubst (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#type_declaration b acc in\n acc\n | Pwith_modsubst (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#longident_loc b acc in\n acc\n\n method module_expr : module_expr -> 'acc -> 'acc =\n fun { pmod_desc; pmod_loc; pmod_attributes } acc ->\n let acc = self#module_expr_desc pmod_desc acc in\n let acc = self#location pmod_loc acc in\n let acc = self#attributes pmod_attributes acc in\n acc\n\n method module_expr_desc : module_expr_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pmod_ident a -> self#longident_loc a acc\n | Pmod_structure a -> self#structure a acc\n | Pmod_functor (a, b) ->\n let acc = self#functor_parameter a acc in\n let acc = self#module_expr b acc in\n acc\n | Pmod_apply (a, b) ->\n let acc = self#module_expr a acc in\n let acc = self#module_expr b acc in\n acc\n | Pmod_constraint (a, b) ->\n let acc = self#module_expr a acc in\n let acc = self#module_type b acc in\n acc\n | Pmod_unpack a -> self#expression a acc\n | Pmod_extension a -> self#extension a acc\n\n method structure : structure -> 'acc -> 'acc = self#list self#structure_item\n\n method structure_item : structure_item -> 'acc -> 'acc =\n fun { pstr_desc; pstr_loc } acc ->\n let acc = self#structure_item_desc pstr_desc acc in\n let acc = self#location pstr_loc acc in\n acc\n\n method structure_item_desc : structure_item_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pstr_eval (a, b) ->\n let acc = self#expression a acc in\n let acc = self#attributes b acc in\n acc\n | Pstr_value (a, b) ->\n let acc = self#rec_flag a acc in\n let acc = self#list self#value_binding b acc in\n acc\n | Pstr_primitive a -> self#value_description a acc\n | Pstr_type (a, b) ->\n let acc = self#rec_flag a acc in\n let acc = self#list self#type_declaration b acc in\n acc\n | Pstr_typext a -> self#type_extension a acc\n | Pstr_exception a -> self#type_exception a acc\n | Pstr_module a -> self#module_binding a acc\n | Pstr_recmodule a -> self#list self#module_binding a acc\n | Pstr_modtype a -> self#module_type_declaration a acc\n | Pstr_open a -> self#open_declaration a acc\n | Pstr_class a -> self#list self#class_declaration a acc\n | Pstr_class_type a -> self#list self#class_type_declaration a acc\n | Pstr_include a -> self#include_declaration a acc\n | Pstr_attribute a -> self#attribute a acc\n | Pstr_extension (a, b) ->\n let acc = self#extension a acc in\n let acc = self#attributes b acc in\n acc\n\n method value_binding : value_binding -> 'acc -> 'acc =\n fun { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } acc ->\n let acc = self#pattern pvb_pat acc in\n let acc = self#expression pvb_expr acc in\n let acc = self#attributes pvb_attributes acc in\n let acc = self#location pvb_loc acc in\n acc\n\n method module_binding : module_binding -> 'acc -> 'acc =\n fun { pmb_name; pmb_expr; pmb_attributes; pmb_loc } acc ->\n let acc = self#loc (self#option self#string) pmb_name acc in\n let acc = self#module_expr pmb_expr acc in\n let acc = self#attributes pmb_attributes acc in\n let acc = self#location pmb_loc acc in\n acc\n\n method toplevel_phrase : toplevel_phrase -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Ptop_def a -> self#structure a acc\n | Ptop_dir a -> self#toplevel_directive a acc\n\n method toplevel_directive : toplevel_directive -> 'acc -> 'acc =\n fun { pdir_name; pdir_arg; pdir_loc } acc ->\n let acc = self#loc self#string pdir_name acc in\n let acc = self#option self#directive_argument pdir_arg acc in\n let acc = self#location pdir_loc acc in\n acc\n\n method directive_argument : directive_argument -> 'acc -> 'acc =\n fun { pdira_desc; pdira_loc } acc ->\n let acc = self#directive_argument_desc pdira_desc acc in\n let acc = self#location pdira_loc acc in\n acc\n\n method directive_argument_desc : directive_argument_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pdir_string a -> self#string a acc\n | Pdir_int (a, b) ->\n let acc = self#string a acc in\n let acc = self#option self#char b acc in\n acc\n | Pdir_ident a -> self#longident a acc\n | Pdir_bool a -> self#bool a acc\n\n method cases : cases -> 'acc -> 'acc = self#list self#case\n end\n\nclass virtual ['acc] fold_map =\n object (self)\n method virtual bool : bool -> 'acc -> bool * 'acc\n method virtual char : char -> 'acc -> char * 'acc\n method virtual int : int -> 'acc -> int * 'acc\n\n method virtual list\n : 'a. ('a -> 'acc -> 'a * 'acc) -> 'a list -> 'acc -> 'a list * 'acc\n\n method virtual option\n : 'a. ('a -> 'acc -> 'a * 'acc) -> 'a option -> 'acc -> 'a option * 'acc\n\n method virtual string : string -> 'acc -> string * 'acc\n\n method position : position -> 'acc -> position * 'acc =\n fun { pos_fname; pos_lnum; pos_bol; pos_cnum } acc ->\n let pos_fname, acc = self#string pos_fname acc in\n let pos_lnum, acc = self#int pos_lnum acc in\n let pos_bol, acc = self#int pos_bol acc in\n let pos_cnum, acc = self#int pos_cnum acc in\n ({ pos_fname; pos_lnum; pos_bol; pos_cnum }, acc)\n\n method location : location -> 'acc -> location * 'acc =\n fun { loc_start; loc_end; loc_ghost } acc ->\n let loc_start, acc = self#position loc_start acc in\n let loc_end, acc = self#position loc_end acc in\n let loc_ghost, acc = self#bool loc_ghost acc in\n ({ loc_start; loc_end; loc_ghost }, acc)\n\n method location_stack : location_stack -> 'acc -> location_stack * 'acc =\n self#list self#location\n\n method loc\n : 'a. ('a -> 'acc -> 'a * 'acc) -> 'a loc -> 'acc -> 'a loc * 'acc =\n fun _a { txt; loc } acc ->\n let txt, acc = _a txt acc in\n let loc, acc = self#location loc acc in\n ({ txt; loc }, acc)\n\n method longident : longident -> 'acc -> longident * 'acc =\n fun x acc ->\n match x with\n | Lident a ->\n let a, acc = self#string a acc in\n (Lident a, acc)\n | Ldot (a, b) ->\n let a, acc = self#longident a acc in\n let b, acc = self#string b acc in\n (Ldot (a, b), acc)\n | Lapply (a, b) ->\n let a, acc = self#longident a acc in\n let b, acc = self#longident b acc in\n (Lapply (a, b), acc)\n\n method longident_loc : longident_loc -> 'acc -> longident_loc * 'acc =\n self#loc self#longident\n\n method rec_flag : rec_flag -> 'acc -> rec_flag * 'acc = fun x acc -> (x, acc)\n\n method direction_flag : direction_flag -> 'acc -> direction_flag * 'acc =\n fun x acc -> (x, acc)\n\n method private_flag : private_flag -> 'acc -> private_flag * 'acc =\n fun x acc -> (x, acc)\n\n method mutable_flag : mutable_flag -> 'acc -> mutable_flag * 'acc =\n fun x acc -> (x, acc)\n\n method virtual_flag : virtual_flag -> 'acc -> virtual_flag * 'acc =\n fun x acc -> (x, acc)\n\n method override_flag : override_flag -> 'acc -> override_flag * 'acc =\n fun x acc -> (x, acc)\n\n method closed_flag : closed_flag -> 'acc -> closed_flag * 'acc =\n fun x acc -> (x, acc)\n\n method label : label -> 'acc -> label * 'acc = self#string\n\n method arg_label : arg_label -> 'acc -> arg_label * 'acc =\n fun x acc ->\n match x with\n | Nolabel -> (Nolabel, acc)\n | Labelled a ->\n let a, acc = self#string a acc in\n (Labelled a, acc)\n | Optional a ->\n let a, acc = self#string a acc in\n (Optional a, acc)\n\n method variance : variance -> 'acc -> variance * 'acc = fun x acc -> (x, acc)\n\n method injectivity : injectivity -> 'acc -> injectivity * 'acc =\n fun x acc -> (x, acc)\n\n method constant : constant -> 'acc -> constant * 'acc =\n fun x acc ->\n match x with\n | Pconst_integer (a, b) ->\n let a, acc = self#string a acc in\n let b, acc = self#option self#char b acc in\n (Pconst_integer (a, b), acc)\n | Pconst_char a ->\n let a, acc = self#char a acc in\n (Pconst_char a, acc)\n | Pconst_string (a, b, c) ->\n let a, acc = self#string a acc in\n let b, acc = self#location b acc in\n let c, acc = self#option self#string c acc in\n (Pconst_string (a, b, c), acc)\n | Pconst_float (a, b) ->\n let a, acc = self#string a acc in\n let b, acc = self#option self#char b acc in\n (Pconst_float (a, b), acc)\n\n method attribute : attribute -> 'acc -> attribute * 'acc =\n fun { attr_name; attr_payload; attr_loc } acc ->\n let attr_name, acc = self#loc self#string attr_name acc in\n let attr_payload, acc = self#payload attr_payload acc in\n let attr_loc, acc = self#location attr_loc acc in\n ({ attr_name; attr_payload; attr_loc }, acc)\n\n method extension : extension -> 'acc -> extension * 'acc =\n fun (a, b) acc ->\n let a, acc = self#loc self#string a acc in\n let b, acc = self#payload b acc in\n ((a, b), acc)\n\n method attributes : attributes -> 'acc -> attributes * 'acc =\n self#list self#attribute\n\n method payload : payload -> 'acc -> payload * 'acc =\n fun x acc ->\n match x with\n | PStr a ->\n let a, acc = self#structure a acc in\n (PStr a, acc)\n | PSig a ->\n let a, acc = self#signature a acc in\n (PSig a, acc)\n | PTyp a ->\n let a, acc = self#core_type a acc in\n (PTyp a, acc)\n | PPat (a, b) ->\n let a, acc = self#pattern a acc in\n let b, acc = self#option self#expression b acc in\n (PPat (a, b), acc)\n\n method core_type : core_type -> 'acc -> core_type * 'acc =\n fun { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } acc ->\n let ptyp_desc, acc = self#core_type_desc ptyp_desc acc in\n let ptyp_loc, acc = self#location ptyp_loc acc in\n let ptyp_loc_stack, acc = self#location_stack ptyp_loc_stack acc in\n let ptyp_attributes, acc = self#attributes ptyp_attributes acc in\n ({ ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes }, acc)\n\n method core_type_desc : core_type_desc -> 'acc -> core_type_desc * 'acc =\n fun x acc ->\n match x with\n | Ptyp_any -> (Ptyp_any, acc)\n | Ptyp_var a ->\n let a, acc = self#string a acc in\n (Ptyp_var a, acc)\n | Ptyp_arrow (a, b, c) ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#core_type b acc in\n let c, acc = self#core_type c acc in\n (Ptyp_arrow (a, b, c), acc)\n | Ptyp_tuple a ->\n let a, acc = self#list self#core_type a acc in\n (Ptyp_tuple a, acc)\n | Ptyp_constr (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#list self#core_type b acc in\n (Ptyp_constr (a, b), acc)\n | Ptyp_object (a, b) ->\n let a, acc = self#list self#object_field a acc in\n let b, acc = self#closed_flag b acc in\n (Ptyp_object (a, b), acc)\n | Ptyp_class (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#list self#core_type b acc in\n (Ptyp_class (a, b), acc)\n | Ptyp_alias (a, b) ->\n let a, acc = self#core_type a acc in\n let b, acc = self#string b acc in\n (Ptyp_alias (a, b), acc)\n | Ptyp_variant (a, b, c) ->\n let a, acc = self#list self#row_field a acc in\n let b, acc = self#closed_flag b acc in\n let c, acc = self#option (self#list self#label) c acc in\n (Ptyp_variant (a, b, c), acc)\n | Ptyp_poly (a, b) ->\n let a, acc = self#list (self#loc self#string) a acc in\n let b, acc = self#core_type b acc in\n (Ptyp_poly (a, b), acc)\n | Ptyp_package a ->\n let a, acc = self#package_type a acc in\n (Ptyp_package a, acc)\n | Ptyp_extension a ->\n let a, acc = self#extension a acc in\n (Ptyp_extension a, acc)\n\n method package_type : package_type -> 'acc -> package_type * 'acc =\n fun (a, b) acc ->\n let a, acc = self#longident_loc a acc in\n let b, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#core_type b acc in\n ((a, b), acc))\n b acc\n in\n ((a, b), acc)\n\n method row_field : row_field -> 'acc -> row_field * 'acc =\n fun { prf_desc; prf_loc; prf_attributes } acc ->\n let prf_desc, acc = self#row_field_desc prf_desc acc in\n let prf_loc, acc = self#location prf_loc acc in\n let prf_attributes, acc = self#attributes prf_attributes acc in\n ({ prf_desc; prf_loc; prf_attributes }, acc)\n\n method row_field_desc : row_field_desc -> 'acc -> row_field_desc * 'acc =\n fun x acc ->\n match x with\n | Rtag (a, b, c) ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#bool b acc in\n let c, acc = self#list self#core_type c acc in\n (Rtag (a, b, c), acc)\n | Rinherit a ->\n let a, acc = self#core_type a acc in\n (Rinherit a, acc)\n\n method object_field : object_field -> 'acc -> object_field * 'acc =\n fun { pof_desc; pof_loc; pof_attributes } acc ->\n let pof_desc, acc = self#object_field_desc pof_desc acc in\n let pof_loc, acc = self#location pof_loc acc in\n let pof_attributes, acc = self#attributes pof_attributes acc in\n ({ pof_desc; pof_loc; pof_attributes }, acc)\n\n method object_field_desc\n : object_field_desc -> 'acc -> object_field_desc * 'acc =\n fun x acc ->\n match x with\n | Otag (a, b) ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#core_type b acc in\n (Otag (a, b), acc)\n | Oinherit a ->\n let a, acc = self#core_type a acc in\n (Oinherit a, acc)\n\n method pattern : pattern -> 'acc -> pattern * 'acc =\n fun { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } acc ->\n let ppat_desc, acc = self#pattern_desc ppat_desc acc in\n let ppat_loc, acc = self#location ppat_loc acc in\n let ppat_loc_stack, acc = self#location_stack ppat_loc_stack acc in\n let ppat_attributes, acc = self#attributes ppat_attributes acc in\n ({ ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes }, acc)\n\n method pattern_desc : pattern_desc -> 'acc -> pattern_desc * 'acc =\n fun x acc ->\n match x with\n | Ppat_any -> (Ppat_any, acc)\n | Ppat_var a ->\n let a, acc = self#loc self#string a acc in\n (Ppat_var a, acc)\n | Ppat_alias (a, b) ->\n let a, acc = self#pattern a acc in\n let b, acc = self#loc self#string b acc in\n (Ppat_alias (a, b), acc)\n | Ppat_constant a ->\n let a, acc = self#constant a acc in\n (Ppat_constant a, acc)\n | Ppat_interval (a, b) ->\n let a, acc = self#constant a acc in\n let b, acc = self#constant b acc in\n (Ppat_interval (a, b), acc)\n | Ppat_tuple a ->\n let a, acc = self#list self#pattern a acc in\n (Ppat_tuple a, acc)\n | Ppat_construct (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#option self#pattern b acc in\n (Ppat_construct (a, b), acc)\n | Ppat_variant (a, b) ->\n let a, acc = self#label a acc in\n let b, acc = self#option self#pattern b acc in\n (Ppat_variant (a, b), acc)\n | Ppat_record (a, b) ->\n let a, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#pattern b acc in\n ((a, b), acc))\n a acc\n in\n let b, acc = self#closed_flag b acc in\n (Ppat_record (a, b), acc)\n | Ppat_array a ->\n let a, acc = self#list self#pattern a acc in\n (Ppat_array a, acc)\n | Ppat_or (a, b) ->\n let a, acc = self#pattern a acc in\n let b, acc = self#pattern b acc in\n (Ppat_or (a, b), acc)\n | Ppat_constraint (a, b) ->\n let a, acc = self#pattern a acc in\n let b, acc = self#core_type b acc in\n (Ppat_constraint (a, b), acc)\n | Ppat_type a ->\n let a, acc = self#longident_loc a acc in\n (Ppat_type a, acc)\n | Ppat_lazy a ->\n let a, acc = self#pattern a acc in\n (Ppat_lazy a, acc)\n | Ppat_unpack a ->\n let a, acc = self#loc (self#option self#string) a acc in\n (Ppat_unpack a, acc)\n | Ppat_exception a ->\n let a, acc = self#pattern a acc in\n (Ppat_exception a, acc)\n | Ppat_extension a ->\n let a, acc = self#extension a acc in\n (Ppat_extension a, acc)\n | Ppat_open (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#pattern b acc in\n (Ppat_open (a, b), acc)\n\n method expression : expression -> 'acc -> expression * 'acc =\n fun { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } acc ->\n let pexp_desc, acc = self#expression_desc pexp_desc acc in\n let pexp_loc, acc = self#location pexp_loc acc in\n let pexp_loc_stack, acc = self#location_stack pexp_loc_stack acc in\n let pexp_attributes, acc = self#attributes pexp_attributes acc in\n ({ pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes }, acc)\n\n method expression_desc : expression_desc -> 'acc -> expression_desc * 'acc =\n fun x acc ->\n match x with\n | Pexp_ident a ->\n let a, acc = self#longident_loc a acc in\n (Pexp_ident a, acc)\n | Pexp_constant a ->\n let a, acc = self#constant a acc in\n (Pexp_constant a, acc)\n | Pexp_let (a, b, c) ->\n let a, acc = self#rec_flag a acc in\n let b, acc = self#list self#value_binding b acc in\n let c, acc = self#expression c acc in\n (Pexp_let (a, b, c), acc)\n | Pexp_function a ->\n let a, acc = self#cases a acc in\n (Pexp_function a, acc)\n | Pexp_fun (a, b, c, d) ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#option self#expression b acc in\n let c, acc = self#pattern c acc in\n let d, acc = self#expression d acc in\n (Pexp_fun (a, b, c, d), acc)\n | Pexp_apply (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#expression b acc in\n ((a, b), acc))\n b acc\n in\n (Pexp_apply (a, b), acc)\n | Pexp_match (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#cases b acc in\n (Pexp_match (a, b), acc)\n | Pexp_try (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#cases b acc in\n (Pexp_try (a, b), acc)\n | Pexp_tuple a ->\n let a, acc = self#list self#expression a acc in\n (Pexp_tuple a, acc)\n | Pexp_construct (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#option self#expression b acc in\n (Pexp_construct (a, b), acc)\n | Pexp_variant (a, b) ->\n let a, acc = self#label a acc in\n let b, acc = self#option self#expression b acc in\n (Pexp_variant (a, b), acc)\n | Pexp_record (a, b) ->\n let a, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#expression b acc in\n ((a, b), acc))\n a acc\n in\n let b, acc = self#option self#expression b acc in\n (Pexp_record (a, b), acc)\n | Pexp_field (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#longident_loc b acc in\n (Pexp_field (a, b), acc)\n | Pexp_setfield (a, b, c) ->\n let a, acc = self#expression a acc in\n let b, acc = self#longident_loc b acc in\n let c, acc = self#expression c acc in\n (Pexp_setfield (a, b, c), acc)\n | Pexp_array a ->\n let a, acc = self#list self#expression a acc in\n (Pexp_array a, acc)\n | Pexp_ifthenelse (a, b, c) ->\n let a, acc = self#expression a acc in\n let b, acc = self#expression b acc in\n let c, acc = self#option self#expression c acc in\n (Pexp_ifthenelse (a, b, c), acc)\n | Pexp_sequence (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#expression b acc in\n (Pexp_sequence (a, b), acc)\n | Pexp_while (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#expression b acc in\n (Pexp_while (a, b), acc)\n | Pexp_for (a, b, c, d, e) ->\n let a, acc = self#pattern a acc in\n let b, acc = self#expression b acc in\n let c, acc = self#expression c acc in\n let d, acc = self#direction_flag d acc in\n let e, acc = self#expression e acc in\n (Pexp_for (a, b, c, d, e), acc)\n | Pexp_constraint (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#core_type b acc in\n (Pexp_constraint (a, b), acc)\n | Pexp_coerce (a, b, c) ->\n let a, acc = self#expression a acc in\n let b, acc = self#option self#core_type b acc in\n let c, acc = self#core_type c acc in\n (Pexp_coerce (a, b, c), acc)\n | Pexp_send (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#loc self#label b acc in\n (Pexp_send (a, b), acc)\n | Pexp_new a ->\n let a, acc = self#longident_loc a acc in\n (Pexp_new a, acc)\n | Pexp_setinstvar (a, b) ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#expression b acc in\n (Pexp_setinstvar (a, b), acc)\n | Pexp_override a ->\n let a, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#expression b acc in\n ((a, b), acc))\n a acc\n in\n (Pexp_override a, acc)\n | Pexp_letmodule (a, b, c) ->\n let a, acc = self#loc (self#option self#string) a acc in\n let b, acc = self#module_expr b acc in\n let c, acc = self#expression c acc in\n (Pexp_letmodule (a, b, c), acc)\n | Pexp_letexception (a, b) ->\n let a, acc = self#extension_constructor a acc in\n let b, acc = self#expression b acc in\n (Pexp_letexception (a, b), acc)\n | Pexp_assert a ->\n let a, acc = self#expression a acc in\n (Pexp_assert a, acc)\n | Pexp_lazy a ->\n let a, acc = self#expression a acc in\n (Pexp_lazy a, acc)\n | Pexp_poly (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#option self#core_type b acc in\n (Pexp_poly (a, b), acc)\n | Pexp_object a ->\n let a, acc = self#class_structure a acc in\n (Pexp_object a, acc)\n | Pexp_newtype (a, b) ->\n let a, acc = self#loc self#string a acc in\n let b, acc = self#expression b acc in\n (Pexp_newtype (a, b), acc)\n | Pexp_pack a ->\n let a, acc = self#module_expr a acc in\n (Pexp_pack a, acc)\n | Pexp_open (a, b) ->\n let a, acc = self#open_declaration a acc in\n let b, acc = self#expression b acc in\n (Pexp_open (a, b), acc)\n | Pexp_letop a ->\n let a, acc = self#letop a acc in\n (Pexp_letop a, acc)\n | Pexp_extension a ->\n let a, acc = self#extension a acc in\n (Pexp_extension a, acc)\n | Pexp_unreachable -> (Pexp_unreachable, acc)\n\n method case : case -> 'acc -> case * 'acc =\n fun { pc_lhs; pc_guard; pc_rhs } acc ->\n let pc_lhs, acc = self#pattern pc_lhs acc in\n let pc_guard, acc = self#option self#expression pc_guard acc in\n let pc_rhs, acc = self#expression pc_rhs acc in\n ({ pc_lhs; pc_guard; pc_rhs }, acc)\n\n method letop : letop -> 'acc -> letop * 'acc =\n fun { let_; ands; body } acc ->\n let let_, acc = self#binding_op let_ acc in\n let ands, acc = self#list self#binding_op ands acc in\n let body, acc = self#expression body acc in\n ({ let_; ands; body }, acc)\n\n method binding_op : binding_op -> 'acc -> binding_op * 'acc =\n fun { pbop_op; pbop_pat; pbop_exp; pbop_loc } acc ->\n let pbop_op, acc = self#loc self#string pbop_op acc in\n let pbop_pat, acc = self#pattern pbop_pat acc in\n let pbop_exp, acc = self#expression pbop_exp acc in\n let pbop_loc, acc = self#location pbop_loc acc in\n ({ pbop_op; pbop_pat; pbop_exp; pbop_loc }, acc)\n\n method value_description\n : value_description -> 'acc -> value_description * 'acc =\n fun { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } acc ->\n let pval_name, acc = self#loc self#string pval_name acc in\n let pval_type, acc = self#core_type pval_type acc in\n let pval_prim, acc = self#list self#string pval_prim acc in\n let pval_attributes, acc = self#attributes pval_attributes acc in\n let pval_loc, acc = self#location pval_loc acc in\n ({ pval_name; pval_type; pval_prim; pval_attributes; pval_loc }, acc)\n\n method type_declaration\n : type_declaration -> 'acc -> type_declaration * 'acc =\n fun {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } acc ->\n let ptype_name, acc = self#loc self#string ptype_name acc in\n let ptype_params, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#core_type a acc in\n let b, acc =\n (fun (a, b) acc ->\n let a, acc = self#variance a acc in\n let b, acc = self#injectivity b acc in\n ((a, b), acc))\n b acc\n in\n ((a, b), acc))\n ptype_params acc\n in\n let ptype_cstrs, acc =\n self#list\n (fun (a, b, c) acc ->\n let a, acc = self#core_type a acc in\n let b, acc = self#core_type b acc in\n let c, acc = self#location c acc in\n ((a, b, c), acc))\n ptype_cstrs acc\n in\n let ptype_kind, acc = self#type_kind ptype_kind acc in\n let ptype_private, acc = self#private_flag ptype_private acc in\n let ptype_manifest, acc =\n self#option self#core_type ptype_manifest acc\n in\n let ptype_attributes, acc = self#attributes ptype_attributes acc in\n let ptype_loc, acc = self#location ptype_loc acc in\n ( {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n },\n acc )\n\n method type_kind : type_kind -> 'acc -> type_kind * 'acc =\n fun x acc ->\n match x with\n | Ptype_abstract -> (Ptype_abstract, acc)\n | Ptype_variant a ->\n let a, acc = self#list self#constructor_declaration a acc in\n (Ptype_variant a, acc)\n | Ptype_record a ->\n let a, acc = self#list self#label_declaration a acc in\n (Ptype_record a, acc)\n | Ptype_open -> (Ptype_open, acc)\n\n method label_declaration\n : label_declaration -> 'acc -> label_declaration * 'acc =\n fun { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } acc ->\n let pld_name, acc = self#loc self#string pld_name acc in\n let pld_mutable, acc = self#mutable_flag pld_mutable acc in\n let pld_type, acc = self#core_type pld_type acc in\n let pld_loc, acc = self#location pld_loc acc in\n let pld_attributes, acc = self#attributes pld_attributes acc in\n ({ pld_name; pld_mutable; pld_type; pld_loc; pld_attributes }, acc)\n\n method constructor_declaration\n : constructor_declaration -> 'acc -> constructor_declaration * 'acc =\n fun { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } acc ->\n let pcd_name, acc = self#loc self#string pcd_name acc in\n let pcd_args, acc = self#constructor_arguments pcd_args acc in\n let pcd_res, acc = self#option self#core_type pcd_res acc in\n let pcd_loc, acc = self#location pcd_loc acc in\n let pcd_attributes, acc = self#attributes pcd_attributes acc in\n ({ pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes }, acc)\n\n method constructor_arguments\n : constructor_arguments -> 'acc -> constructor_arguments * 'acc =\n fun x acc ->\n match x with\n | Pcstr_tuple a ->\n let a, acc = self#list self#core_type a acc in\n (Pcstr_tuple a, acc)\n | Pcstr_record a ->\n let a, acc = self#list self#label_declaration a acc in\n (Pcstr_record a, acc)\n\n method type_extension : type_extension -> 'acc -> type_extension * 'acc =\n fun {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } acc ->\n let ptyext_path, acc = self#longident_loc ptyext_path acc in\n let ptyext_params, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#core_type a acc in\n let b, acc =\n (fun (a, b) acc ->\n let a, acc = self#variance a acc in\n let b, acc = self#injectivity b acc in\n ((a, b), acc))\n b acc\n in\n ((a, b), acc))\n ptyext_params acc\n in\n let ptyext_constructors, acc =\n self#list self#extension_constructor ptyext_constructors acc\n in\n let ptyext_private, acc = self#private_flag ptyext_private acc in\n let ptyext_loc, acc = self#location ptyext_loc acc in\n let ptyext_attributes, acc = self#attributes ptyext_attributes acc in\n ( {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n },\n acc )\n\n method extension_constructor\n : extension_constructor -> 'acc -> extension_constructor * 'acc =\n fun { pext_name; pext_kind; pext_loc; pext_attributes } acc ->\n let pext_name, acc = self#loc self#string pext_name acc in\n let pext_kind, acc = self#extension_constructor_kind pext_kind acc in\n let pext_loc, acc = self#location pext_loc acc in\n let pext_attributes, acc = self#attributes pext_attributes acc in\n ({ pext_name; pext_kind; pext_loc; pext_attributes }, acc)\n\n method type_exception : type_exception -> 'acc -> type_exception * 'acc =\n fun { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } acc ->\n let ptyexn_constructor, acc =\n self#extension_constructor ptyexn_constructor acc\n in\n let ptyexn_loc, acc = self#location ptyexn_loc acc in\n let ptyexn_attributes, acc = self#attributes ptyexn_attributes acc in\n ({ ptyexn_constructor; ptyexn_loc; ptyexn_attributes }, acc)\n\n method extension_constructor_kind\n : extension_constructor_kind ->\n 'acc ->\n extension_constructor_kind * 'acc =\n fun x acc ->\n match x with\n | Pext_decl (a, b) ->\n let a, acc = self#constructor_arguments a acc in\n let b, acc = self#option self#core_type b acc in\n (Pext_decl (a, b), acc)\n | Pext_rebind a ->\n let a, acc = self#longident_loc a acc in\n (Pext_rebind a, acc)\n\n method class_type : class_type -> 'acc -> class_type * 'acc =\n fun { pcty_desc; pcty_loc; pcty_attributes } acc ->\n let pcty_desc, acc = self#class_type_desc pcty_desc acc in\n let pcty_loc, acc = self#location pcty_loc acc in\n let pcty_attributes, acc = self#attributes pcty_attributes acc in\n ({ pcty_desc; pcty_loc; pcty_attributes }, acc)\n\n method class_type_desc : class_type_desc -> 'acc -> class_type_desc * 'acc =\n fun x acc ->\n match x with\n | Pcty_constr (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#list self#core_type b acc in\n (Pcty_constr (a, b), acc)\n | Pcty_signature a ->\n let a, acc = self#class_signature a acc in\n (Pcty_signature a, acc)\n | Pcty_arrow (a, b, c) ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#core_type b acc in\n let c, acc = self#class_type c acc in\n (Pcty_arrow (a, b, c), acc)\n | Pcty_extension a ->\n let a, acc = self#extension a acc in\n (Pcty_extension a, acc)\n | Pcty_open (a, b) ->\n let a, acc = self#open_description a acc in\n let b, acc = self#class_type b acc in\n (Pcty_open (a, b), acc)\n\n method class_signature : class_signature -> 'acc -> class_signature * 'acc =\n fun { pcsig_self; pcsig_fields } acc ->\n let pcsig_self, acc = self#core_type pcsig_self acc in\n let pcsig_fields, acc =\n self#list self#class_type_field pcsig_fields acc\n in\n ({ pcsig_self; pcsig_fields }, acc)\n\n method class_type_field\n : class_type_field -> 'acc -> class_type_field * 'acc =\n fun { pctf_desc; pctf_loc; pctf_attributes } acc ->\n let pctf_desc, acc = self#class_type_field_desc pctf_desc acc in\n let pctf_loc, acc = self#location pctf_loc acc in\n let pctf_attributes, acc = self#attributes pctf_attributes acc in\n ({ pctf_desc; pctf_loc; pctf_attributes }, acc)\n\n method class_type_field_desc\n : class_type_field_desc -> 'acc -> class_type_field_desc * 'acc =\n fun x acc ->\n match x with\n | Pctf_inherit a ->\n let a, acc = self#class_type a acc in\n (Pctf_inherit a, acc)\n | Pctf_val a ->\n let a, acc =\n (fun (a, b, c, d) acc ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#mutable_flag b acc in\n let c, acc = self#virtual_flag c acc in\n let d, acc = self#core_type d acc in\n ((a, b, c, d), acc))\n a acc\n in\n (Pctf_val a, acc)\n | Pctf_method a ->\n let a, acc =\n (fun (a, b, c, d) acc ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#private_flag b acc in\n let c, acc = self#virtual_flag c acc in\n let d, acc = self#core_type d acc in\n ((a, b, c, d), acc))\n a acc\n in\n (Pctf_method a, acc)\n | Pctf_constraint a ->\n let a, acc =\n (fun (a, b) acc ->\n let a, acc = self#core_type a acc in\n let b, acc = self#core_type b acc in\n ((a, b), acc))\n a acc\n in\n (Pctf_constraint a, acc)\n | Pctf_attribute a ->\n let a, acc = self#attribute a acc in\n (Pctf_attribute a, acc)\n | Pctf_extension a ->\n let a, acc = self#extension a acc in\n (Pctf_extension a, acc)\n\n method class_infos\n : 'a.\n ('a -> 'acc -> 'a * 'acc) ->\n 'a class_infos ->\n 'acc ->\n 'a class_infos * 'acc =\n fun _a\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes }\n acc ->\n let pci_virt, acc = self#virtual_flag pci_virt acc in\n let pci_params, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#core_type a acc in\n let b, acc =\n (fun (a, b) acc ->\n let a, acc = self#variance a acc in\n let b, acc = self#injectivity b acc in\n ((a, b), acc))\n b acc\n in\n ((a, b), acc))\n pci_params acc\n in\n let pci_name, acc = self#loc self#string pci_name acc in\n let pci_expr, acc = _a pci_expr acc in\n let pci_loc, acc = self#location pci_loc acc in\n let pci_attributes, acc = self#attributes pci_attributes acc in\n ( { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes },\n acc )\n\n method class_description\n : class_description -> 'acc -> class_description * 'acc =\n self#class_infos self#class_type\n\n method class_type_declaration\n : class_type_declaration -> 'acc -> class_type_declaration * 'acc =\n self#class_infos self#class_type\n\n method class_expr : class_expr -> 'acc -> class_expr * 'acc =\n fun { pcl_desc; pcl_loc; pcl_attributes } acc ->\n let pcl_desc, acc = self#class_expr_desc pcl_desc acc in\n let pcl_loc, acc = self#location pcl_loc acc in\n let pcl_attributes, acc = self#attributes pcl_attributes acc in\n ({ pcl_desc; pcl_loc; pcl_attributes }, acc)\n\n method class_expr_desc : class_expr_desc -> 'acc -> class_expr_desc * 'acc =\n fun x acc ->\n match x with\n | Pcl_constr (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#list self#core_type b acc in\n (Pcl_constr (a, b), acc)\n | Pcl_structure a ->\n let a, acc = self#class_structure a acc in\n (Pcl_structure a, acc)\n | Pcl_fun (a, b, c, d) ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#option self#expression b acc in\n let c, acc = self#pattern c acc in\n let d, acc = self#class_expr d acc in\n (Pcl_fun (a, b, c, d), acc)\n | Pcl_apply (a, b) ->\n let a, acc = self#class_expr a acc in\n let b, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#expression b acc in\n ((a, b), acc))\n b acc\n in\n (Pcl_apply (a, b), acc)\n | Pcl_let (a, b, c) ->\n let a, acc = self#rec_flag a acc in\n let b, acc = self#list self#value_binding b acc in\n let c, acc = self#class_expr c acc in\n (Pcl_let (a, b, c), acc)\n | Pcl_constraint (a, b) ->\n let a, acc = self#class_expr a acc in\n let b, acc = self#class_type b acc in\n (Pcl_constraint (a, b), acc)\n | Pcl_extension a ->\n let a, acc = self#extension a acc in\n (Pcl_extension a, acc)\n | Pcl_open (a, b) ->\n let a, acc = self#open_description a acc in\n let b, acc = self#class_expr b acc in\n (Pcl_open (a, b), acc)\n\n method class_structure : class_structure -> 'acc -> class_structure * 'acc =\n fun { pcstr_self; pcstr_fields } acc ->\n let pcstr_self, acc = self#pattern pcstr_self acc in\n let pcstr_fields, acc = self#list self#class_field pcstr_fields acc in\n ({ pcstr_self; pcstr_fields }, acc)\n\n method class_field : class_field -> 'acc -> class_field * 'acc =\n fun { pcf_desc; pcf_loc; pcf_attributes } acc ->\n let pcf_desc, acc = self#class_field_desc pcf_desc acc in\n let pcf_loc, acc = self#location pcf_loc acc in\n let pcf_attributes, acc = self#attributes pcf_attributes acc in\n ({ pcf_desc; pcf_loc; pcf_attributes }, acc)\n\n method class_field_desc\n : class_field_desc -> 'acc -> class_field_desc * 'acc =\n fun x acc ->\n match x with\n | Pcf_inherit (a, b, c) ->\n let a, acc = self#override_flag a acc in\n let b, acc = self#class_expr b acc in\n let c, acc = self#option (self#loc self#string) c acc in\n (Pcf_inherit (a, b, c), acc)\n | Pcf_val a ->\n let a, acc =\n (fun (a, b, c) acc ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#mutable_flag b acc in\n let c, acc = self#class_field_kind c acc in\n ((a, b, c), acc))\n a acc\n in\n (Pcf_val a, acc)\n | Pcf_method a ->\n let a, acc =\n (fun (a, b, c) acc ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#private_flag b acc in\n let c, acc = self#class_field_kind c acc in\n ((a, b, c), acc))\n a acc\n in\n (Pcf_method a, acc)\n | Pcf_constraint a ->\n let a, acc =\n (fun (a, b) acc ->\n let a, acc = self#core_type a acc in\n let b, acc = self#core_type b acc in\n ((a, b), acc))\n a acc\n in\n (Pcf_constraint a, acc)\n | Pcf_initializer a ->\n let a, acc = self#expression a acc in\n (Pcf_initializer a, acc)\n | Pcf_attribute a ->\n let a, acc = self#attribute a acc in\n (Pcf_attribute a, acc)\n | Pcf_extension a ->\n let a, acc = self#extension a acc in\n (Pcf_extension a, acc)\n\n method class_field_kind\n : class_field_kind -> 'acc -> class_field_kind * 'acc =\n fun x acc ->\n match x with\n | Cfk_virtual a ->\n let a, acc = self#core_type a acc in\n (Cfk_virtual a, acc)\n | Cfk_concrete (a, b) ->\n let a, acc = self#override_flag a acc in\n let b, acc = self#expression b acc in\n (Cfk_concrete (a, b), acc)\n\n method class_declaration\n : class_declaration -> 'acc -> class_declaration * 'acc =\n self#class_infos self#class_expr\n\n method module_type : module_type -> 'acc -> module_type * 'acc =\n fun { pmty_desc; pmty_loc; pmty_attributes } acc ->\n let pmty_desc, acc = self#module_type_desc pmty_desc acc in\n let pmty_loc, acc = self#location pmty_loc acc in\n let pmty_attributes, acc = self#attributes pmty_attributes acc in\n ({ pmty_desc; pmty_loc; pmty_attributes }, acc)\n\n method module_type_desc\n : module_type_desc -> 'acc -> module_type_desc * 'acc =\n fun x acc ->\n match x with\n | Pmty_ident a ->\n let a, acc = self#longident_loc a acc in\n (Pmty_ident a, acc)\n | Pmty_signature a ->\n let a, acc = self#signature a acc in\n (Pmty_signature a, acc)\n | Pmty_functor (a, b) ->\n let a, acc = self#functor_parameter a acc in\n let b, acc = self#module_type b acc in\n (Pmty_functor (a, b), acc)\n | Pmty_with (a, b) ->\n let a, acc = self#module_type a acc in\n let b, acc = self#list self#with_constraint b acc in\n (Pmty_with (a, b), acc)\n | Pmty_typeof a ->\n let a, acc = self#module_expr a acc in\n (Pmty_typeof a, acc)\n | Pmty_extension a ->\n let a, acc = self#extension a acc in\n (Pmty_extension a, acc)\n | Pmty_alias a ->\n let a, acc = self#longident_loc a acc in\n (Pmty_alias a, acc)\n\n method functor_parameter\n : functor_parameter -> 'acc -> functor_parameter * 'acc =\n fun x acc ->\n match x with\n | Unit -> (Unit, acc)\n | Named (a, b) ->\n let a, acc = self#loc (self#option self#string) a acc in\n let b, acc = self#module_type b acc in\n (Named (a, b), acc)\n\n method signature : signature -> 'acc -> signature * 'acc =\n self#list self#signature_item\n\n method signature_item : signature_item -> 'acc -> signature_item * 'acc =\n fun { psig_desc; psig_loc } acc ->\n let psig_desc, acc = self#signature_item_desc psig_desc acc in\n let psig_loc, acc = self#location psig_loc acc in\n ({ psig_desc; psig_loc }, acc)\n\n method signature_item_desc\n : signature_item_desc -> 'acc -> signature_item_desc * 'acc =\n fun x acc ->\n match x with\n | Psig_value a ->\n let a, acc = self#value_description a acc in\n (Psig_value a, acc)\n | Psig_type (a, b) ->\n let a, acc = self#rec_flag a acc in\n let b, acc = self#list self#type_declaration b acc in\n (Psig_type (a, b), acc)\n | Psig_typesubst a ->\n let a, acc = self#list self#type_declaration a acc in\n (Psig_typesubst a, acc)\n | Psig_typext a ->\n let a, acc = self#type_extension a acc in\n (Psig_typext a, acc)\n | Psig_exception a ->\n let a, acc = self#type_exception a acc in\n (Psig_exception a, acc)\n | Psig_module a ->\n let a, acc = self#module_declaration a acc in\n (Psig_module a, acc)\n | Psig_modsubst a ->\n let a, acc = self#module_substitution a acc in\n (Psig_modsubst a, acc)\n | Psig_recmodule a ->\n let a, acc = self#list self#module_declaration a acc in\n (Psig_recmodule a, acc)\n | Psig_modtype a ->\n let a, acc = self#module_type_declaration a acc in\n (Psig_modtype a, acc)\n | Psig_open a ->\n let a, acc = self#open_description a acc in\n (Psig_open a, acc)\n | Psig_include a ->\n let a, acc = self#include_description a acc in\n (Psig_include a, acc)\n | Psig_class a ->\n let a, acc = self#list self#class_description a acc in\n (Psig_class a, acc)\n | Psig_class_type a ->\n let a, acc = self#list self#class_type_declaration a acc in\n (Psig_class_type a, acc)\n | Psig_attribute a ->\n let a, acc = self#attribute a acc in\n (Psig_attribute a, acc)\n | Psig_extension (a, b) ->\n let a, acc = self#extension a acc in\n let b, acc = self#attributes b acc in\n (Psig_extension (a, b), acc)\n\n method module_declaration\n : module_declaration -> 'acc -> module_declaration * 'acc =\n fun { pmd_name; pmd_type; pmd_attributes; pmd_loc } acc ->\n let pmd_name, acc = self#loc (self#option self#string) pmd_name acc in\n let pmd_type, acc = self#module_type pmd_type acc in\n let pmd_attributes, acc = self#attributes pmd_attributes acc in\n let pmd_loc, acc = self#location pmd_loc acc in\n ({ pmd_name; pmd_type; pmd_attributes; pmd_loc }, acc)\n\n method module_substitution\n : module_substitution -> 'acc -> module_substitution * 'acc =\n fun { pms_name; pms_manifest; pms_attributes; pms_loc } acc ->\n let pms_name, acc = self#loc self#string pms_name acc in\n let pms_manifest, acc = self#longident_loc pms_manifest acc in\n let pms_attributes, acc = self#attributes pms_attributes acc in\n let pms_loc, acc = self#location pms_loc acc in\n ({ pms_name; pms_manifest; pms_attributes; pms_loc }, acc)\n\n method module_type_declaration\n : module_type_declaration -> 'acc -> module_type_declaration * 'acc =\n fun { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } acc ->\n let pmtd_name, acc = self#loc self#string pmtd_name acc in\n let pmtd_type, acc = self#option self#module_type pmtd_type acc in\n let pmtd_attributes, acc = self#attributes pmtd_attributes acc in\n let pmtd_loc, acc = self#location pmtd_loc acc in\n ({ pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc }, acc)\n\n method open_infos\n : 'a.\n ('a -> 'acc -> 'a * 'acc) ->\n 'a open_infos ->\n 'acc ->\n 'a open_infos * 'acc =\n fun _a { popen_expr; popen_override; popen_loc; popen_attributes } acc ->\n let popen_expr, acc = _a popen_expr acc in\n let popen_override, acc = self#override_flag popen_override acc in\n let popen_loc, acc = self#location popen_loc acc in\n let popen_attributes, acc = self#attributes popen_attributes acc in\n ({ popen_expr; popen_override; popen_loc; popen_attributes }, acc)\n\n method open_description\n : open_description -> 'acc -> open_description * 'acc =\n self#open_infos self#longident_loc\n\n method open_declaration\n : open_declaration -> 'acc -> open_declaration * 'acc =\n self#open_infos self#module_expr\n\n method include_infos\n : 'a.\n ('a -> 'acc -> 'a * 'acc) ->\n 'a include_infos ->\n 'acc ->\n 'a include_infos * 'acc =\n fun _a { pincl_mod; pincl_loc; pincl_attributes } acc ->\n let pincl_mod, acc = _a pincl_mod acc in\n let pincl_loc, acc = self#location pincl_loc acc in\n let pincl_attributes, acc = self#attributes pincl_attributes acc in\n ({ pincl_mod; pincl_loc; pincl_attributes }, acc)\n\n method include_description\n : include_description -> 'acc -> include_description * 'acc =\n self#include_infos self#module_type\n\n method include_declaration\n : include_declaration -> 'acc -> include_declaration * 'acc =\n self#include_infos self#module_expr\n\n method with_constraint : with_constraint -> 'acc -> with_constraint * 'acc =\n fun x acc ->\n match x with\n | Pwith_type (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#type_declaration b acc in\n (Pwith_type (a, b), acc)\n | Pwith_module (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#longident_loc b acc in\n (Pwith_module (a, b), acc)\n | Pwith_typesubst (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#type_declaration b acc in\n (Pwith_typesubst (a, b), acc)\n | Pwith_modsubst (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#longident_loc b acc in\n (Pwith_modsubst (a, b), acc)\n\n method module_expr : module_expr -> 'acc -> module_expr * 'acc =\n fun { pmod_desc; pmod_loc; pmod_attributes } acc ->\n let pmod_desc, acc = self#module_expr_desc pmod_desc acc in\n let pmod_loc, acc = self#location pmod_loc acc in\n let pmod_attributes, acc = self#attributes pmod_attributes acc in\n ({ pmod_desc; pmod_loc; pmod_attributes }, acc)\n\n method module_expr_desc\n : module_expr_desc -> 'acc -> module_expr_desc * 'acc =\n fun x acc ->\n match x with\n | Pmod_ident a ->\n let a, acc = self#longident_loc a acc in\n (Pmod_ident a, acc)\n | Pmod_structure a ->\n let a, acc = self#structure a acc in\n (Pmod_structure a, acc)\n | Pmod_functor (a, b) ->\n let a, acc = self#functor_parameter a acc in\n let b, acc = self#module_expr b acc in\n (Pmod_functor (a, b), acc)\n | Pmod_apply (a, b) ->\n let a, acc = self#module_expr a acc in\n let b, acc = self#module_expr b acc in\n (Pmod_apply (a, b), acc)\n | Pmod_constraint (a, b) ->\n let a, acc = self#module_expr a acc in\n let b, acc = self#module_type b acc in\n (Pmod_constraint (a, b), acc)\n | Pmod_unpack a ->\n let a, acc = self#expression a acc in\n (Pmod_unpack a, acc)\n | Pmod_extension a ->\n let a, acc = self#extension a acc in\n (Pmod_extension a, acc)\n\n method structure : structure -> 'acc -> structure * 'acc =\n self#list self#structure_item\n\n method structure_item : structure_item -> 'acc -> structure_item * 'acc =\n fun { pstr_desc; pstr_loc } acc ->\n let pstr_desc, acc = self#structure_item_desc pstr_desc acc in\n let pstr_loc, acc = self#location pstr_loc acc in\n ({ pstr_desc; pstr_loc }, acc)\n\n method structure_item_desc\n : structure_item_desc -> 'acc -> structure_item_desc * 'acc =\n fun x acc ->\n match x with\n | Pstr_eval (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#attributes b acc in\n (Pstr_eval (a, b), acc)\n | Pstr_value (a, b) ->\n let a, acc = self#rec_flag a acc in\n let b, acc = self#list self#value_binding b acc in\n (Pstr_value (a, b), acc)\n | Pstr_primitive a ->\n let a, acc = self#value_description a acc in\n (Pstr_primitive a, acc)\n | Pstr_type (a, b) ->\n let a, acc = self#rec_flag a acc in\n let b, acc = self#list self#type_declaration b acc in\n (Pstr_type (a, b), acc)\n | Pstr_typext a ->\n let a, acc = self#type_extension a acc in\n (Pstr_typext a, acc)\n | Pstr_exception a ->\n let a, acc = self#type_exception a acc in\n (Pstr_exception a, acc)\n | Pstr_module a ->\n let a, acc = self#module_binding a acc in\n (Pstr_module a, acc)\n | Pstr_recmodule a ->\n let a, acc = self#list self#module_binding a acc in\n (Pstr_recmodule a, acc)\n | Pstr_modtype a ->\n let a, acc = self#module_type_declaration a acc in\n (Pstr_modtype a, acc)\n | Pstr_open a ->\n let a, acc = self#open_declaration a acc in\n (Pstr_open a, acc)\n | Pstr_class a ->\n let a, acc = self#list self#class_declaration a acc in\n (Pstr_class a, acc)\n | Pstr_class_type a ->\n let a, acc = self#list self#class_type_declaration a acc in\n (Pstr_class_type a, acc)\n | Pstr_include a ->\n let a, acc = self#include_declaration a acc in\n (Pstr_include a, acc)\n | Pstr_attribute a ->\n let a, acc = self#attribute a acc in\n (Pstr_attribute a, acc)\n | Pstr_extension (a, b) ->\n let a, acc = self#extension a acc in\n let b, acc = self#attributes b acc in\n (Pstr_extension (a, b), acc)\n\n method value_binding : value_binding -> 'acc -> value_binding * 'acc =\n fun { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } acc ->\n let pvb_pat, acc = self#pattern pvb_pat acc in\n let pvb_expr, acc = self#expression pvb_expr acc in\n let pvb_attributes, acc = self#attributes pvb_attributes acc in\n let pvb_loc, acc = self#location pvb_loc acc in\n ({ pvb_pat; pvb_expr; pvb_attributes; pvb_loc }, acc)\n\n method module_binding : module_binding -> 'acc -> module_binding * 'acc =\n fun { pmb_name; pmb_expr; pmb_attributes; pmb_loc } acc ->\n let pmb_name, acc = self#loc (self#option self#string) pmb_name acc in\n let pmb_expr, acc = self#module_expr pmb_expr acc in\n let pmb_attributes, acc = self#attributes pmb_attributes acc in\n let pmb_loc, acc = self#location pmb_loc acc in\n ({ pmb_name; pmb_expr; pmb_attributes; pmb_loc }, acc)\n\n method toplevel_phrase : toplevel_phrase -> 'acc -> toplevel_phrase * 'acc =\n fun x acc ->\n match x with\n | Ptop_def a ->\n let a, acc = self#structure a acc in\n (Ptop_def a, acc)\n | Ptop_dir a ->\n let a, acc = self#toplevel_directive a acc in\n (Ptop_dir a, acc)\n\n method toplevel_directive\n : toplevel_directive -> 'acc -> toplevel_directive * 'acc =\n fun { pdir_name; pdir_arg; pdir_loc } acc ->\n let pdir_name, acc = self#loc self#string pdir_name acc in\n let pdir_arg, acc = self#option self#directive_argument pdir_arg acc in\n let pdir_loc, acc = self#location pdir_loc acc in\n ({ pdir_name; pdir_arg; pdir_loc }, acc)\n\n method directive_argument\n : directive_argument -> 'acc -> directive_argument * 'acc =\n fun { pdira_desc; pdira_loc } acc ->\n let pdira_desc, acc = self#directive_argument_desc pdira_desc acc in\n let pdira_loc, acc = self#location pdira_loc acc in\n ({ pdira_desc; pdira_loc }, acc)\n\n method directive_argument_desc\n : directive_argument_desc -> 'acc -> directive_argument_desc * 'acc =\n fun x acc ->\n match x with\n | Pdir_string a ->\n let a, acc = self#string a acc in\n (Pdir_string a, acc)\n | Pdir_int (a, b) ->\n let a, acc = self#string a acc in\n let b, acc = self#option self#char b acc in\n (Pdir_int (a, b), acc)\n | Pdir_ident a ->\n let a, acc = self#longident a acc in\n (Pdir_ident a, acc)\n | Pdir_bool a ->\n let a, acc = self#bool a acc in\n (Pdir_bool a, acc)\n\n method cases : cases -> 'acc -> cases * 'acc = self#list self#case\n end\n\nclass virtual ['ctx] map_with_context =\n object (self)\n method virtual bool : 'ctx -> bool -> bool\n method virtual char : 'ctx -> char -> char\n method virtual int : 'ctx -> int -> int\n method virtual list : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a list -> 'a list\n\n method virtual option\n : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a option -> 'a option\n\n method virtual string : 'ctx -> string -> string\n\n method position : 'ctx -> position -> position =\n fun ctx { pos_fname; pos_lnum; pos_bol; pos_cnum } ->\n let pos_fname = self#string ctx pos_fname in\n let pos_lnum = self#int ctx pos_lnum in\n let pos_bol = self#int ctx pos_bol in\n let pos_cnum = self#int ctx pos_cnum in\n { pos_fname; pos_lnum; pos_bol; pos_cnum }\n\n method location : 'ctx -> location -> location =\n fun ctx { loc_start; loc_end; loc_ghost } ->\n let loc_start = self#position ctx loc_start in\n let loc_end = self#position ctx loc_end in\n let loc_ghost = self#bool ctx loc_ghost in\n { loc_start; loc_end; loc_ghost }\n\n method location_stack : 'ctx -> location_stack -> location_stack =\n self#list self#location\n\n method loc : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a loc -> 'a loc =\n fun _a ctx { txt; loc } ->\n let txt = _a ctx txt in\n let loc = self#location ctx loc in\n { txt; loc }\n\n method longident : 'ctx -> longident -> longident =\n fun ctx x ->\n match x with\n | Lident a ->\n let a = self#string ctx a in\n Lident a\n | Ldot (a, b) ->\n let a = self#longident ctx a in\n let b = self#string ctx b in\n Ldot (a, b)\n | Lapply (a, b) ->\n let a = self#longident ctx a in\n let b = self#longident ctx b in\n Lapply (a, b)\n\n method longident_loc : 'ctx -> longident_loc -> longident_loc =\n self#loc self#longident\n\n method rec_flag : 'ctx -> rec_flag -> rec_flag = fun _ctx x -> x\n\n method direction_flag : 'ctx -> direction_flag -> direction_flag =\n fun _ctx x -> x\n\n method private_flag : 'ctx -> private_flag -> private_flag = fun _ctx x -> x\n method mutable_flag : 'ctx -> mutable_flag -> mutable_flag = fun _ctx x -> x\n method virtual_flag : 'ctx -> virtual_flag -> virtual_flag = fun _ctx x -> x\n\n method override_flag : 'ctx -> override_flag -> override_flag =\n fun _ctx x -> x\n\n method closed_flag : 'ctx -> closed_flag -> closed_flag = fun _ctx x -> x\n method label : 'ctx -> label -> label = self#string\n\n method arg_label : 'ctx -> arg_label -> arg_label =\n fun ctx x ->\n match x with\n | Nolabel -> Nolabel\n | Labelled a ->\n let a = self#string ctx a in\n Labelled a\n | Optional a ->\n let a = self#string ctx a in\n Optional a\n\n method variance : 'ctx -> variance -> variance = fun _ctx x -> x\n method injectivity : 'ctx -> injectivity -> injectivity = fun _ctx x -> x\n\n method constant : 'ctx -> constant -> constant =\n fun ctx x ->\n match x with\n | Pconst_integer (a, b) ->\n let a = self#string ctx a in\n let b = self#option self#char ctx b in\n Pconst_integer (a, b)\n | Pconst_char a ->\n let a = self#char ctx a in\n Pconst_char a\n | Pconst_string (a, b, c) ->\n let a = self#string ctx a in\n let b = self#location ctx b in\n let c = self#option self#string ctx c in\n Pconst_string (a, b, c)\n | Pconst_float (a, b) ->\n let a = self#string ctx a in\n let b = self#option self#char ctx b in\n Pconst_float (a, b)\n\n method attribute : 'ctx -> attribute -> attribute =\n fun ctx { attr_name; attr_payload; attr_loc } ->\n let attr_name = self#loc self#string ctx attr_name in\n let attr_payload = self#payload ctx attr_payload in\n let attr_loc = self#location ctx attr_loc in\n { attr_name; attr_payload; attr_loc }\n\n method extension : 'ctx -> extension -> extension =\n fun ctx (a, b) ->\n let a = self#loc self#string ctx a in\n let b = self#payload ctx b in\n (a, b)\n\n method attributes : 'ctx -> attributes -> attributes =\n self#list self#attribute\n\n method payload : 'ctx -> payload -> payload =\n fun ctx x ->\n match x with\n | PStr a ->\n let a = self#structure ctx a in\n PStr a\n | PSig a ->\n let a = self#signature ctx a in\n PSig a\n | PTyp a ->\n let a = self#core_type ctx a in\n PTyp a\n | PPat (a, b) ->\n let a = self#pattern ctx a in\n let b = self#option self#expression ctx b in\n PPat (a, b)\n\n method core_type : 'ctx -> core_type -> core_type =\n fun ctx { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } ->\n let ptyp_desc = self#core_type_desc ctx ptyp_desc in\n let ptyp_loc = self#location ctx ptyp_loc in\n let ptyp_loc_stack = self#location_stack ctx ptyp_loc_stack in\n let ptyp_attributes = self#attributes ctx ptyp_attributes in\n { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes }\n\n method core_type_desc : 'ctx -> core_type_desc -> core_type_desc =\n fun ctx x ->\n match x with\n | Ptyp_any -> Ptyp_any\n | Ptyp_var a ->\n let a = self#string ctx a in\n Ptyp_var a\n | Ptyp_arrow (a, b, c) ->\n let a = self#arg_label ctx a in\n let b = self#core_type ctx b in\n let c = self#core_type ctx c in\n Ptyp_arrow (a, b, c)\n | Ptyp_tuple a ->\n let a = self#list self#core_type ctx a in\n Ptyp_tuple a\n | Ptyp_constr (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#list self#core_type ctx b in\n Ptyp_constr (a, b)\n | Ptyp_object (a, b) ->\n let a = self#list self#object_field ctx a in\n let b = self#closed_flag ctx b in\n Ptyp_object (a, b)\n | Ptyp_class (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#list self#core_type ctx b in\n Ptyp_class (a, b)\n | Ptyp_alias (a, b) ->\n let a = self#core_type ctx a in\n let b = self#string ctx b in\n Ptyp_alias (a, b)\n | Ptyp_variant (a, b, c) ->\n let a = self#list self#row_field ctx a in\n let b = self#closed_flag ctx b in\n let c = self#option (self#list self#label) ctx c in\n Ptyp_variant (a, b, c)\n | Ptyp_poly (a, b) ->\n let a = self#list (self#loc self#string) ctx a in\n let b = self#core_type ctx b in\n Ptyp_poly (a, b)\n | Ptyp_package a ->\n let a = self#package_type ctx a in\n Ptyp_package a\n | Ptyp_extension a ->\n let a = self#extension ctx a in\n Ptyp_extension a\n\n method package_type : 'ctx -> package_type -> package_type =\n fun ctx (a, b) ->\n let a = self#longident_loc ctx a in\n let b =\n self#list\n (fun ctx (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#core_type ctx b in\n (a, b))\n ctx b\n in\n (a, b)\n\n method row_field : 'ctx -> row_field -> row_field =\n fun ctx { prf_desc; prf_loc; prf_attributes } ->\n let prf_desc = self#row_field_desc ctx prf_desc in\n let prf_loc = self#location ctx prf_loc in\n let prf_attributes = self#attributes ctx prf_attributes in\n { prf_desc; prf_loc; prf_attributes }\n\n method row_field_desc : 'ctx -> row_field_desc -> row_field_desc =\n fun ctx x ->\n match x with\n | Rtag (a, b, c) ->\n let a = self#loc self#label ctx a in\n let b = self#bool ctx b in\n let c = self#list self#core_type ctx c in\n Rtag (a, b, c)\n | Rinherit a ->\n let a = self#core_type ctx a in\n Rinherit a\n\n method object_field : 'ctx -> object_field -> object_field =\n fun ctx { pof_desc; pof_loc; pof_attributes } ->\n let pof_desc = self#object_field_desc ctx pof_desc in\n let pof_loc = self#location ctx pof_loc in\n let pof_attributes = self#attributes ctx pof_attributes in\n { pof_desc; pof_loc; pof_attributes }\n\n method object_field_desc : 'ctx -> object_field_desc -> object_field_desc =\n fun ctx x ->\n match x with\n | Otag (a, b) ->\n let a = self#loc self#label ctx a in\n let b = self#core_type ctx b in\n Otag (a, b)\n | Oinherit a ->\n let a = self#core_type ctx a in\n Oinherit a\n\n method pattern : 'ctx -> pattern -> pattern =\n fun ctx { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } ->\n let ppat_desc = self#pattern_desc ctx ppat_desc in\n let ppat_loc = self#location ctx ppat_loc in\n let ppat_loc_stack = self#location_stack ctx ppat_loc_stack in\n let ppat_attributes = self#attributes ctx ppat_attributes in\n { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes }\n\n method pattern_desc : 'ctx -> pattern_desc -> pattern_desc =\n fun ctx x ->\n match x with\n | Ppat_any -> Ppat_any\n | Ppat_var a ->\n let a = self#loc self#string ctx a in\n Ppat_var a\n | Ppat_alias (a, b) ->\n let a = self#pattern ctx a in\n let b = self#loc self#string ctx b in\n Ppat_alias (a, b)\n | Ppat_constant a ->\n let a = self#constant ctx a in\n Ppat_constant a\n | Ppat_interval (a, b) ->\n let a = self#constant ctx a in\n let b = self#constant ctx b in\n Ppat_interval (a, b)\n | Ppat_tuple a ->\n let a = self#list self#pattern ctx a in\n Ppat_tuple a\n | Ppat_construct (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#option self#pattern ctx b in\n Ppat_construct (a, b)\n | Ppat_variant (a, b) ->\n let a = self#label ctx a in\n let b = self#option self#pattern ctx b in\n Ppat_variant (a, b)\n | Ppat_record (a, b) ->\n let a =\n self#list\n (fun ctx (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#pattern ctx b in\n (a, b))\n ctx a\n in\n let b = self#closed_flag ctx b in\n Ppat_record (a, b)\n | Ppat_array a ->\n let a = self#list self#pattern ctx a in\n Ppat_array a\n | Ppat_or (a, b) ->\n let a = self#pattern ctx a in\n let b = self#pattern ctx b in\n Ppat_or (a, b)\n | Ppat_constraint (a, b) ->\n let a = self#pattern ctx a in\n let b = self#core_type ctx b in\n Ppat_constraint (a, b)\n | Ppat_type a ->\n let a = self#longident_loc ctx a in\n Ppat_type a\n | Ppat_lazy a ->\n let a = self#pattern ctx a in\n Ppat_lazy a\n | Ppat_unpack a ->\n let a = self#loc (self#option self#string) ctx a in\n Ppat_unpack a\n | Ppat_exception a ->\n let a = self#pattern ctx a in\n Ppat_exception a\n | Ppat_extension a ->\n let a = self#extension ctx a in\n Ppat_extension a\n | Ppat_open (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#pattern ctx b in\n Ppat_open (a, b)\n\n method expression : 'ctx -> expression -> expression =\n fun ctx { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } ->\n let pexp_desc = self#expression_desc ctx pexp_desc in\n let pexp_loc = self#location ctx pexp_loc in\n let pexp_loc_stack = self#location_stack ctx pexp_loc_stack in\n let pexp_attributes = self#attributes ctx pexp_attributes in\n { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes }\n\n method expression_desc : 'ctx -> expression_desc -> expression_desc =\n fun ctx x ->\n match x with\n | Pexp_ident a ->\n let a = self#longident_loc ctx a in\n Pexp_ident a\n | Pexp_constant a ->\n let a = self#constant ctx a in\n Pexp_constant a\n | Pexp_let (a, b, c) ->\n let a = self#rec_flag ctx a in\n let b = self#list self#value_binding ctx b in\n let c = self#expression ctx c in\n Pexp_let (a, b, c)\n | Pexp_function a ->\n let a = self#cases ctx a in\n Pexp_function a\n | Pexp_fun (a, b, c, d) ->\n let a = self#arg_label ctx a in\n let b = self#option self#expression ctx b in\n let c = self#pattern ctx c in\n let d = self#expression ctx d in\n Pexp_fun (a, b, c, d)\n | Pexp_apply (a, b) ->\n let a = self#expression ctx a in\n let b =\n self#list\n (fun ctx (a, b) ->\n let a = self#arg_label ctx a in\n let b = self#expression ctx b in\n (a, b))\n ctx b\n in\n Pexp_apply (a, b)\n | Pexp_match (a, b) ->\n let a = self#expression ctx a in\n let b = self#cases ctx b in\n Pexp_match (a, b)\n | Pexp_try (a, b) ->\n let a = self#expression ctx a in\n let b = self#cases ctx b in\n Pexp_try (a, b)\n | Pexp_tuple a ->\n let a = self#list self#expression ctx a in\n Pexp_tuple a\n | Pexp_construct (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#option self#expression ctx b in\n Pexp_construct (a, b)\n | Pexp_variant (a, b) ->\n let a = self#label ctx a in\n let b = self#option self#expression ctx b in\n Pexp_variant (a, b)\n | Pexp_record (a, b) ->\n let a =\n self#list\n (fun ctx (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#expression ctx b in\n (a, b))\n ctx a\n in\n let b = self#option self#expression ctx b in\n Pexp_record (a, b)\n | Pexp_field (a, b) ->\n let a = self#expression ctx a in\n let b = self#longident_loc ctx b in\n Pexp_field (a, b)\n | Pexp_setfield (a, b, c) ->\n let a = self#expression ctx a in\n let b = self#longident_loc ctx b in\n let c = self#expression ctx c in\n Pexp_setfield (a, b, c)\n | Pexp_array a ->\n let a = self#list self#expression ctx a in\n Pexp_array a\n | Pexp_ifthenelse (a, b, c) ->\n let a = self#expression ctx a in\n let b = self#expression ctx b in\n let c = self#option self#expression ctx c in\n Pexp_ifthenelse (a, b, c)\n | Pexp_sequence (a, b) ->\n let a = self#expression ctx a in\n let b = self#expression ctx b in\n Pexp_sequence (a, b)\n | Pexp_while (a, b) ->\n let a = self#expression ctx a in\n let b = self#expression ctx b in\n Pexp_while (a, b)\n | Pexp_for (a, b, c, d, e) ->\n let a = self#pattern ctx a in\n let b = self#expression ctx b in\n let c = self#expression ctx c in\n let d = self#direction_flag ctx d in\n let e = self#expression ctx e in\n Pexp_for (a, b, c, d, e)\n | Pexp_constraint (a, b) ->\n let a = self#expression ctx a in\n let b = self#core_type ctx b in\n Pexp_constraint (a, b)\n | Pexp_coerce (a, b, c) ->\n let a = self#expression ctx a in\n let b = self#option self#core_type ctx b in\n let c = self#core_type ctx c in\n Pexp_coerce (a, b, c)\n | Pexp_send (a, b) ->\n let a = self#expression ctx a in\n let b = self#loc self#label ctx b in\n Pexp_send (a, b)\n | Pexp_new a ->\n let a = self#longident_loc ctx a in\n Pexp_new a\n | Pexp_setinstvar (a, b) ->\n let a = self#loc self#label ctx a in\n let b = self#expression ctx b in\n Pexp_setinstvar (a, b)\n | Pexp_override a ->\n let a =\n self#list\n (fun ctx (a, b) ->\n let a = self#loc self#label ctx a in\n let b = self#expression ctx b in\n (a, b))\n ctx a\n in\n Pexp_override a\n | Pexp_letmodule (a, b, c) ->\n let a = self#loc (self#option self#string) ctx a in\n let b = self#module_expr ctx b in\n let c = self#expression ctx c in\n Pexp_letmodule (a, b, c)\n | Pexp_letexception (a, b) ->\n let a = self#extension_constructor ctx a in\n let b = self#expression ctx b in\n Pexp_letexception (a, b)\n | Pexp_assert a ->\n let a = self#expression ctx a in\n Pexp_assert a\n | Pexp_lazy a ->\n let a = self#expression ctx a in\n Pexp_lazy a\n | Pexp_poly (a, b) ->\n let a = self#expression ctx a in\n let b = self#option self#core_type ctx b in\n Pexp_poly (a, b)\n | Pexp_object a ->\n let a = self#class_structure ctx a in\n Pexp_object a\n | Pexp_newtype (a, b) ->\n let a = self#loc self#string ctx a in\n let b = self#expression ctx b in\n Pexp_newtype (a, b)\n | Pexp_pack a ->\n let a = self#module_expr ctx a in\n Pexp_pack a\n | Pexp_open (a, b) ->\n let a = self#open_declaration ctx a in\n let b = self#expression ctx b in\n Pexp_open (a, b)\n | Pexp_letop a ->\n let a = self#letop ctx a in\n Pexp_letop a\n | Pexp_extension a ->\n let a = self#extension ctx a in\n Pexp_extension a\n | Pexp_unreachable -> Pexp_unreachable\n\n method case : 'ctx -> case -> case =\n fun ctx { pc_lhs; pc_guard; pc_rhs } ->\n let pc_lhs = self#pattern ctx pc_lhs in\n let pc_guard = self#option self#expression ctx pc_guard in\n let pc_rhs = self#expression ctx pc_rhs in\n { pc_lhs; pc_guard; pc_rhs }\n\n method letop : 'ctx -> letop -> letop =\n fun ctx { let_; ands; body } ->\n let let_ = self#binding_op ctx let_ in\n let ands = self#list self#binding_op ctx ands in\n let body = self#expression ctx body in\n { let_; ands; body }\n\n method binding_op : 'ctx -> binding_op -> binding_op =\n fun ctx { pbop_op; pbop_pat; pbop_exp; pbop_loc } ->\n let pbop_op = self#loc self#string ctx pbop_op in\n let pbop_pat = self#pattern ctx pbop_pat in\n let pbop_exp = self#expression ctx pbop_exp in\n let pbop_loc = self#location ctx pbop_loc in\n { pbop_op; pbop_pat; pbop_exp; pbop_loc }\n\n method value_description : 'ctx -> value_description -> value_description =\n fun ctx { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } ->\n let pval_name = self#loc self#string ctx pval_name in\n let pval_type = self#core_type ctx pval_type in\n let pval_prim = self#list self#string ctx pval_prim in\n let pval_attributes = self#attributes ctx pval_attributes in\n let pval_loc = self#location ctx pval_loc in\n { pval_name; pval_type; pval_prim; pval_attributes; pval_loc }\n\n method type_declaration : 'ctx -> type_declaration -> type_declaration =\n fun ctx\n {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } ->\n let ptype_name = self#loc self#string ctx ptype_name in\n let ptype_params =\n self#list\n (fun ctx (a, b) ->\n let a = self#core_type ctx a in\n let b =\n (fun ctx (a, b) ->\n let a = self#variance ctx a in\n let b = self#injectivity ctx b in\n (a, b))\n ctx b\n in\n (a, b))\n ctx ptype_params\n in\n let ptype_cstrs =\n self#list\n (fun ctx (a, b, c) ->\n let a = self#core_type ctx a in\n let b = self#core_type ctx b in\n let c = self#location ctx c in\n (a, b, c))\n ctx ptype_cstrs\n in\n let ptype_kind = self#type_kind ctx ptype_kind in\n let ptype_private = self#private_flag ctx ptype_private in\n let ptype_manifest = self#option self#core_type ctx ptype_manifest in\n let ptype_attributes = self#attributes ctx ptype_attributes in\n let ptype_loc = self#location ctx ptype_loc in\n {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n }\n\n method type_kind : 'ctx -> type_kind -> type_kind =\n fun ctx x ->\n match x with\n | Ptype_abstract -> Ptype_abstract\n | Ptype_variant a ->\n let a = self#list self#constructor_declaration ctx a in\n Ptype_variant a\n | Ptype_record a ->\n let a = self#list self#label_declaration ctx a in\n Ptype_record a\n | Ptype_open -> Ptype_open\n\n method label_declaration : 'ctx -> label_declaration -> label_declaration =\n fun ctx { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } ->\n let pld_name = self#loc self#string ctx pld_name in\n let pld_mutable = self#mutable_flag ctx pld_mutable in\n let pld_type = self#core_type ctx pld_type in\n let pld_loc = self#location ctx pld_loc in\n let pld_attributes = self#attributes ctx pld_attributes in\n { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes }\n\n method constructor_declaration\n : 'ctx -> constructor_declaration -> constructor_declaration =\n fun ctx { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } ->\n let pcd_name = self#loc self#string ctx pcd_name in\n let pcd_args = self#constructor_arguments ctx pcd_args in\n let pcd_res = self#option self#core_type ctx pcd_res in\n let pcd_loc = self#location ctx pcd_loc in\n let pcd_attributes = self#attributes ctx pcd_attributes in\n { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes }\n\n method constructor_arguments\n : 'ctx -> constructor_arguments -> constructor_arguments =\n fun ctx x ->\n match x with\n | Pcstr_tuple a ->\n let a = self#list self#core_type ctx a in\n Pcstr_tuple a\n | Pcstr_record a ->\n let a = self#list self#label_declaration ctx a in\n Pcstr_record a\n\n method type_extension : 'ctx -> type_extension -> type_extension =\n fun ctx\n {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } ->\n let ptyext_path = self#longident_loc ctx ptyext_path in\n let ptyext_params =\n self#list\n (fun ctx (a, b) ->\n let a = self#core_type ctx a in\n let b =\n (fun ctx (a, b) ->\n let a = self#variance ctx a in\n let b = self#injectivity ctx b in\n (a, b))\n ctx b\n in\n (a, b))\n ctx ptyext_params\n in\n let ptyext_constructors =\n self#list self#extension_constructor ctx ptyext_constructors\n in\n let ptyext_private = self#private_flag ctx ptyext_private in\n let ptyext_loc = self#location ctx ptyext_loc in\n let ptyext_attributes = self#attributes ctx ptyext_attributes in\n {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n }\n\n method extension_constructor\n : 'ctx -> extension_constructor -> extension_constructor =\n fun ctx { pext_name; pext_kind; pext_loc; pext_attributes } ->\n let pext_name = self#loc self#string ctx pext_name in\n let pext_kind = self#extension_constructor_kind ctx pext_kind in\n let pext_loc = self#location ctx pext_loc in\n let pext_attributes = self#attributes ctx pext_attributes in\n { pext_name; pext_kind; pext_loc; pext_attributes }\n\n method type_exception : 'ctx -> type_exception -> type_exception =\n fun ctx { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } ->\n let ptyexn_constructor =\n self#extension_constructor ctx ptyexn_constructor\n in\n let ptyexn_loc = self#location ctx ptyexn_loc in\n let ptyexn_attributes = self#attributes ctx ptyexn_attributes in\n { ptyexn_constructor; ptyexn_loc; ptyexn_attributes }\n\n method extension_constructor_kind\n : 'ctx -> extension_constructor_kind -> extension_constructor_kind =\n fun ctx x ->\n match x with\n | Pext_decl (a, b) ->\n let a = self#constructor_arguments ctx a in\n let b = self#option self#core_type ctx b in\n Pext_decl (a, b)\n | Pext_rebind a ->\n let a = self#longident_loc ctx a in\n Pext_rebind a\n\n method class_type : 'ctx -> class_type -> class_type =\n fun ctx { pcty_desc; pcty_loc; pcty_attributes } ->\n let pcty_desc = self#class_type_desc ctx pcty_desc in\n let pcty_loc = self#location ctx pcty_loc in\n let pcty_attributes = self#attributes ctx pcty_attributes in\n { pcty_desc; pcty_loc; pcty_attributes }\n\n method class_type_desc : 'ctx -> class_type_desc -> class_type_desc =\n fun ctx x ->\n match x with\n | Pcty_constr (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#list self#core_type ctx b in\n Pcty_constr (a, b)\n | Pcty_signature a ->\n let a = self#class_signature ctx a in\n Pcty_signature a\n | Pcty_arrow (a, b, c) ->\n let a = self#arg_label ctx a in\n let b = self#core_type ctx b in\n let c = self#class_type ctx c in\n Pcty_arrow (a, b, c)\n | Pcty_extension a ->\n let a = self#extension ctx a in\n Pcty_extension a\n | Pcty_open (a, b) ->\n let a = self#open_description ctx a in\n let b = self#class_type ctx b in\n Pcty_open (a, b)\n\n method class_signature : 'ctx -> class_signature -> class_signature =\n fun ctx { pcsig_self; pcsig_fields } ->\n let pcsig_self = self#core_type ctx pcsig_self in\n let pcsig_fields = self#list self#class_type_field ctx pcsig_fields in\n { pcsig_self; pcsig_fields }\n\n method class_type_field : 'ctx -> class_type_field -> class_type_field =\n fun ctx { pctf_desc; pctf_loc; pctf_attributes } ->\n let pctf_desc = self#class_type_field_desc ctx pctf_desc in\n let pctf_loc = self#location ctx pctf_loc in\n let pctf_attributes = self#attributes ctx pctf_attributes in\n { pctf_desc; pctf_loc; pctf_attributes }\n\n method class_type_field_desc\n : 'ctx -> class_type_field_desc -> class_type_field_desc =\n fun ctx x ->\n match x with\n | Pctf_inherit a ->\n let a = self#class_type ctx a in\n Pctf_inherit a\n | Pctf_val a ->\n let a =\n (fun ctx (a, b, c, d) ->\n let a = self#loc self#label ctx a in\n let b = self#mutable_flag ctx b in\n let c = self#virtual_flag ctx c in\n let d = self#core_type ctx d in\n (a, b, c, d))\n ctx a\n in\n Pctf_val a\n | Pctf_method a ->\n let a =\n (fun ctx (a, b, c, d) ->\n let a = self#loc self#label ctx a in\n let b = self#private_flag ctx b in\n let c = self#virtual_flag ctx c in\n let d = self#core_type ctx d in\n (a, b, c, d))\n ctx a\n in\n Pctf_method a\n | Pctf_constraint a ->\n let a =\n (fun ctx (a, b) ->\n let a = self#core_type ctx a in\n let b = self#core_type ctx b in\n (a, b))\n ctx a\n in\n Pctf_constraint a\n | Pctf_attribute a ->\n let a = self#attribute ctx a in\n Pctf_attribute a\n | Pctf_extension a ->\n let a = self#extension ctx a in\n Pctf_extension a\n\n method class_infos\n : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a class_infos -> 'a class_infos =\n fun _a ctx\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes } ->\n let pci_virt = self#virtual_flag ctx pci_virt in\n let pci_params =\n self#list\n (fun ctx (a, b) ->\n let a = self#core_type ctx a in\n let b =\n (fun ctx (a, b) ->\n let a = self#variance ctx a in\n let b = self#injectivity ctx b in\n (a, b))\n ctx b\n in\n (a, b))\n ctx pci_params\n in\n let pci_name = self#loc self#string ctx pci_name in\n let pci_expr = _a ctx pci_expr in\n let pci_loc = self#location ctx pci_loc in\n let pci_attributes = self#attributes ctx pci_attributes in\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes }\n\n method class_description : 'ctx -> class_description -> class_description =\n self#class_infos self#class_type\n\n method class_type_declaration\n : 'ctx -> class_type_declaration -> class_type_declaration =\n self#class_infos self#class_type\n\n method class_expr : 'ctx -> class_expr -> class_expr =\n fun ctx { pcl_desc; pcl_loc; pcl_attributes } ->\n let pcl_desc = self#class_expr_desc ctx pcl_desc in\n let pcl_loc = self#location ctx pcl_loc in\n let pcl_attributes = self#attributes ctx pcl_attributes in\n { pcl_desc; pcl_loc; pcl_attributes }\n\n method class_expr_desc : 'ctx -> class_expr_desc -> class_expr_desc =\n fun ctx x ->\n match x with\n | Pcl_constr (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#list self#core_type ctx b in\n Pcl_constr (a, b)\n | Pcl_structure a ->\n let a = self#class_structure ctx a in\n Pcl_structure a\n | Pcl_fun (a, b, c, d) ->\n let a = self#arg_label ctx a in\n let b = self#option self#expression ctx b in\n let c = self#pattern ctx c in\n let d = self#class_expr ctx d in\n Pcl_fun (a, b, c, d)\n | Pcl_apply (a, b) ->\n let a = self#class_expr ctx a in\n let b =\n self#list\n (fun ctx (a, b) ->\n let a = self#arg_label ctx a in\n let b = self#expression ctx b in\n (a, b))\n ctx b\n in\n Pcl_apply (a, b)\n | Pcl_let (a, b, c) ->\n let a = self#rec_flag ctx a in\n let b = self#list self#value_binding ctx b in\n let c = self#class_expr ctx c in\n Pcl_let (a, b, c)\n | Pcl_constraint (a, b) ->\n let a = self#class_expr ctx a in\n let b = self#class_type ctx b in\n Pcl_constraint (a, b)\n | Pcl_extension a ->\n let a = self#extension ctx a in\n Pcl_extension a\n | Pcl_open (a, b) ->\n let a = self#open_description ctx a in\n let b = self#class_expr ctx b in\n Pcl_open (a, b)\n\n method class_structure : 'ctx -> class_structure -> class_structure =\n fun ctx { pcstr_self; pcstr_fields } ->\n let pcstr_self = self#pattern ctx pcstr_self in\n let pcstr_fields = self#list self#class_field ctx pcstr_fields in\n { pcstr_self; pcstr_fields }\n\n method class_field : 'ctx -> class_field -> class_field =\n fun ctx { pcf_desc; pcf_loc; pcf_attributes } ->\n let pcf_desc = self#class_field_desc ctx pcf_desc in\n let pcf_loc = self#location ctx pcf_loc in\n let pcf_attributes = self#attributes ctx pcf_attributes in\n { pcf_desc; pcf_loc; pcf_attributes }\n\n method class_field_desc : 'ctx -> class_field_desc -> class_field_desc =\n fun ctx x ->\n match x with\n | Pcf_inherit (a, b, c) ->\n let a = self#override_flag ctx a in\n let b = self#class_expr ctx b in\n let c = self#option (self#loc self#string) ctx c in\n Pcf_inherit (a, b, c)\n | Pcf_val a ->\n let a =\n (fun ctx (a, b, c) ->\n let a = self#loc self#label ctx a in\n let b = self#mutable_flag ctx b in\n let c = self#class_field_kind ctx c in\n (a, b, c))\n ctx a\n in\n Pcf_val a\n | Pcf_method a ->\n let a =\n (fun ctx (a, b, c) ->\n let a = self#loc self#label ctx a in\n let b = self#private_flag ctx b in\n let c = self#class_field_kind ctx c in\n (a, b, c))\n ctx a\n in\n Pcf_method a\n | Pcf_constraint a ->\n let a =\n (fun ctx (a, b) ->\n let a = self#core_type ctx a in\n let b = self#core_type ctx b in\n (a, b))\n ctx a\n in\n Pcf_constraint a\n | Pcf_initializer a ->\n let a = self#expression ctx a in\n Pcf_initializer a\n | Pcf_attribute a ->\n let a = self#attribute ctx a in\n Pcf_attribute a\n | Pcf_extension a ->\n let a = self#extension ctx a in\n Pcf_extension a\n\n method class_field_kind : 'ctx -> class_field_kind -> class_field_kind =\n fun ctx x ->\n match x with\n | Cfk_virtual a ->\n let a = self#core_type ctx a in\n Cfk_virtual a\n | Cfk_concrete (a, b) ->\n let a = self#override_flag ctx a in\n let b = self#expression ctx b in\n Cfk_concrete (a, b)\n\n method class_declaration : 'ctx -> class_declaration -> class_declaration =\n self#class_infos self#class_expr\n\n method module_type : 'ctx -> module_type -> module_type =\n fun ctx { pmty_desc; pmty_loc; pmty_attributes } ->\n let pmty_desc = self#module_type_desc ctx pmty_desc in\n let pmty_loc = self#location ctx pmty_loc in\n let pmty_attributes = self#attributes ctx pmty_attributes in\n { pmty_desc; pmty_loc; pmty_attributes }\n\n method module_type_desc : 'ctx -> module_type_desc -> module_type_desc =\n fun ctx x ->\n match x with\n | Pmty_ident a ->\n let a = self#longident_loc ctx a in\n Pmty_ident a\n | Pmty_signature a ->\n let a = self#signature ctx a in\n Pmty_signature a\n | Pmty_functor (a, b) ->\n let a = self#functor_parameter ctx a in\n let b = self#module_type ctx b in\n Pmty_functor (a, b)\n | Pmty_with (a, b) ->\n let a = self#module_type ctx a in\n let b = self#list self#with_constraint ctx b in\n Pmty_with (a, b)\n | Pmty_typeof a ->\n let a = self#module_expr ctx a in\n Pmty_typeof a\n | Pmty_extension a ->\n let a = self#extension ctx a in\n Pmty_extension a\n | Pmty_alias a ->\n let a = self#longident_loc ctx a in\n Pmty_alias a\n\n method functor_parameter : 'ctx -> functor_parameter -> functor_parameter =\n fun ctx x ->\n match x with\n | Unit -> Unit\n | Named (a, b) ->\n let a = self#loc (self#option self#string) ctx a in\n let b = self#module_type ctx b in\n Named (a, b)\n\n method signature : 'ctx -> signature -> signature =\n self#list self#signature_item\n\n method signature_item : 'ctx -> signature_item -> signature_item =\n fun ctx { psig_desc; psig_loc } ->\n let psig_desc = self#signature_item_desc ctx psig_desc in\n let psig_loc = self#location ctx psig_loc in\n { psig_desc; psig_loc }\n\n method signature_item_desc\n : 'ctx -> signature_item_desc -> signature_item_desc =\n fun ctx x ->\n match x with\n | Psig_value a ->\n let a = self#value_description ctx a in\n Psig_value a\n | Psig_type (a, b) ->\n let a = self#rec_flag ctx a in\n let b = self#list self#type_declaration ctx b in\n Psig_type (a, b)\n | Psig_typesubst a ->\n let a = self#list self#type_declaration ctx a in\n Psig_typesubst a\n | Psig_typext a ->\n let a = self#type_extension ctx a in\n Psig_typext a\n | Psig_exception a ->\n let a = self#type_exception ctx a in\n Psig_exception a\n | Psig_module a ->\n let a = self#module_declaration ctx a in\n Psig_module a\n | Psig_modsubst a ->\n let a = self#module_substitution ctx a in\n Psig_modsubst a\n | Psig_recmodule a ->\n let a = self#list self#module_declaration ctx a in\n Psig_recmodule a\n | Psig_modtype a ->\n let a = self#module_type_declaration ctx a in\n Psig_modtype a\n | Psig_open a ->\n let a = self#open_description ctx a in\n Psig_open a\n | Psig_include a ->\n let a = self#include_description ctx a in\n Psig_include a\n | Psig_class a ->\n let a = self#list self#class_description ctx a in\n Psig_class a\n | Psig_class_type a ->\n let a = self#list self#class_type_declaration ctx a in\n Psig_class_type a\n | Psig_attribute a ->\n let a = self#attribute ctx a in\n Psig_attribute a\n | Psig_extension (a, b) ->\n let a = self#extension ctx a in\n let b = self#attributes ctx b in\n Psig_extension (a, b)\n\n method module_declaration : 'ctx -> module_declaration -> module_declaration\n =\n fun ctx { pmd_name; pmd_type; pmd_attributes; pmd_loc } ->\n let pmd_name = self#loc (self#option self#string) ctx pmd_name in\n let pmd_type = self#module_type ctx pmd_type in\n let pmd_attributes = self#attributes ctx pmd_attributes in\n let pmd_loc = self#location ctx pmd_loc in\n { pmd_name; pmd_type; pmd_attributes; pmd_loc }\n\n method module_substitution\n : 'ctx -> module_substitution -> module_substitution =\n fun ctx { pms_name; pms_manifest; pms_attributes; pms_loc } ->\n let pms_name = self#loc self#string ctx pms_name in\n let pms_manifest = self#longident_loc ctx pms_manifest in\n let pms_attributes = self#attributes ctx pms_attributes in\n let pms_loc = self#location ctx pms_loc in\n { pms_name; pms_manifest; pms_attributes; pms_loc }\n\n method module_type_declaration\n : 'ctx -> module_type_declaration -> module_type_declaration =\n fun ctx { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } ->\n let pmtd_name = self#loc self#string ctx pmtd_name in\n let pmtd_type = self#option self#module_type ctx pmtd_type in\n let pmtd_attributes = self#attributes ctx pmtd_attributes in\n let pmtd_loc = self#location ctx pmtd_loc in\n { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc }\n\n method open_infos\n : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a open_infos -> 'a open_infos =\n fun _a ctx { popen_expr; popen_override; popen_loc; popen_attributes } ->\n let popen_expr = _a ctx popen_expr in\n let popen_override = self#override_flag ctx popen_override in\n let popen_loc = self#location ctx popen_loc in\n let popen_attributes = self#attributes ctx popen_attributes in\n { popen_expr; popen_override; popen_loc; popen_attributes }\n\n method open_description : 'ctx -> open_description -> open_description =\n self#open_infos self#longident_loc\n\n method open_declaration : 'ctx -> open_declaration -> open_declaration =\n self#open_infos self#module_expr\n\n method include_infos\n : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a include_infos -> 'a include_infos\n =\n fun _a ctx { pincl_mod; pincl_loc; pincl_attributes } ->\n let pincl_mod = _a ctx pincl_mod in\n let pincl_loc = self#location ctx pincl_loc in\n let pincl_attributes = self#attributes ctx pincl_attributes in\n { pincl_mod; pincl_loc; pincl_attributes }\n\n method include_description\n : 'ctx -> include_description -> include_description =\n self#include_infos self#module_type\n\n method include_declaration\n : 'ctx -> include_declaration -> include_declaration =\n self#include_infos self#module_expr\n\n method with_constraint : 'ctx -> with_constraint -> with_constraint =\n fun ctx x ->\n match x with\n | Pwith_type (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#type_declaration ctx b in\n Pwith_type (a, b)\n | Pwith_module (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#longident_loc ctx b in\n Pwith_module (a, b)\n | Pwith_typesubst (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#type_declaration ctx b in\n Pwith_typesubst (a, b)\n | Pwith_modsubst (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#longident_loc ctx b in\n Pwith_modsubst (a, b)\n\n method module_expr : 'ctx -> module_expr -> module_expr =\n fun ctx { pmod_desc; pmod_loc; pmod_attributes } ->\n let pmod_desc = self#module_expr_desc ctx pmod_desc in\n let pmod_loc = self#location ctx pmod_loc in\n let pmod_attributes = self#attributes ctx pmod_attributes in\n { pmod_desc; pmod_loc; pmod_attributes }\n\n method module_expr_desc : 'ctx -> module_expr_desc -> module_expr_desc =\n fun ctx x ->\n match x with\n | Pmod_ident a ->\n let a = self#longident_loc ctx a in\n Pmod_ident a\n | Pmod_structure a ->\n let a = self#structure ctx a in\n Pmod_structure a\n | Pmod_functor (a, b) ->\n let a = self#functor_parameter ctx a in\n let b = self#module_expr ctx b in\n Pmod_functor (a, b)\n | Pmod_apply (a, b) ->\n let a = self#module_expr ctx a in\n let b = self#module_expr ctx b in\n Pmod_apply (a, b)\n | Pmod_constraint (a, b) ->\n let a = self#module_expr ctx a in\n let b = self#module_type ctx b in\n Pmod_constraint (a, b)\n | Pmod_unpack a ->\n let a = self#expression ctx a in\n Pmod_unpack a\n | Pmod_extension a ->\n let a = self#extension ctx a in\n Pmod_extension a\n\n method structure : 'ctx -> structure -> structure =\n self#list self#structure_item\n\n method structure_item : 'ctx -> structure_item -> structure_item =\n fun ctx { pstr_desc; pstr_loc } ->\n let pstr_desc = self#structure_item_desc ctx pstr_desc in\n let pstr_loc = self#location ctx pstr_loc in\n { pstr_desc; pstr_loc }\n\n method structure_item_desc\n : 'ctx -> structure_item_desc -> structure_item_desc =\n fun ctx x ->\n match x with\n | Pstr_eval (a, b) ->\n let a = self#expression ctx a in\n let b = self#attributes ctx b in\n Pstr_eval (a, b)\n | Pstr_value (a, b) ->\n let a = self#rec_flag ctx a in\n let b = self#list self#value_binding ctx b in\n Pstr_value (a, b)\n | Pstr_primitive a ->\n let a = self#value_description ctx a in\n Pstr_primitive a\n | Pstr_type (a, b) ->\n let a = self#rec_flag ctx a in\n let b = self#list self#type_declaration ctx b in\n Pstr_type (a, b)\n | Pstr_typext a ->\n let a = self#type_extension ctx a in\n Pstr_typext a\n | Pstr_exception a ->\n let a = self#type_exception ctx a in\n Pstr_exception a\n | Pstr_module a ->\n let a = self#module_binding ctx a in\n Pstr_module a\n | Pstr_recmodule a ->\n let a = self#list self#module_binding ctx a in\n Pstr_recmodule a\n | Pstr_modtype a ->\n let a = self#module_type_declaration ctx a in\n Pstr_modtype a\n | Pstr_open a ->\n let a = self#open_declaration ctx a in\n Pstr_open a\n | Pstr_class a ->\n let a = self#list self#class_declaration ctx a in\n Pstr_class a\n | Pstr_class_type a ->\n let a = self#list self#class_type_declaration ctx a in\n Pstr_class_type a\n | Pstr_include a ->\n let a = self#include_declaration ctx a in\n Pstr_include a\n | Pstr_attribute a ->\n let a = self#attribute ctx a in\n Pstr_attribute a\n | Pstr_extension (a, b) ->\n let a = self#extension ctx a in\n let b = self#attributes ctx b in\n Pstr_extension (a, b)\n\n method value_binding : 'ctx -> value_binding -> value_binding =\n fun ctx { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } ->\n let pvb_pat = self#pattern ctx pvb_pat in\n let pvb_expr = self#expression ctx pvb_expr in\n let pvb_attributes = self#attributes ctx pvb_attributes in\n let pvb_loc = self#location ctx pvb_loc in\n { pvb_pat; pvb_expr; pvb_attributes; pvb_loc }\n\n method module_binding : 'ctx -> module_binding -> module_binding =\n fun ctx { pmb_name; pmb_expr; pmb_attributes; pmb_loc } ->\n let pmb_name = self#loc (self#option self#string) ctx pmb_name in\n let pmb_expr = self#module_expr ctx pmb_expr in\n let pmb_attributes = self#attributes ctx pmb_attributes in\n let pmb_loc = self#location ctx pmb_loc in\n { pmb_name; pmb_expr; pmb_attributes; pmb_loc }\n\n method toplevel_phrase : 'ctx -> toplevel_phrase -> toplevel_phrase =\n fun ctx x ->\n match x with\n | Ptop_def a ->\n let a = self#structure ctx a in\n Ptop_def a\n | Ptop_dir a ->\n let a = self#toplevel_directive ctx a in\n Ptop_dir a\n\n method toplevel_directive : 'ctx -> toplevel_directive -> toplevel_directive\n =\n fun ctx { pdir_name; pdir_arg; pdir_loc } ->\n let pdir_name = self#loc self#string ctx pdir_name in\n let pdir_arg = self#option self#directive_argument ctx pdir_arg in\n let pdir_loc = self#location ctx pdir_loc in\n { pdir_name; pdir_arg; pdir_loc }\n\n method directive_argument : 'ctx -> directive_argument -> directive_argument\n =\n fun ctx { pdira_desc; pdira_loc } ->\n let pdira_desc = self#directive_argument_desc ctx pdira_desc in\n let pdira_loc = self#location ctx pdira_loc in\n { pdira_desc; pdira_loc }\n\n method directive_argument_desc\n : 'ctx -> directive_argument_desc -> directive_argument_desc =\n fun ctx x ->\n match x with\n | Pdir_string a ->\n let a = self#string ctx a in\n Pdir_string a\n | Pdir_int (a, b) ->\n let a = self#string ctx a in\n let b = self#option self#char ctx b in\n Pdir_int (a, b)\n | Pdir_ident a ->\n let a = self#longident ctx a in\n Pdir_ident a\n | Pdir_bool a ->\n let a = self#bool ctx a in\n Pdir_bool a\n\n method cases : 'ctx -> cases -> cases = self#list self#case\n end\n\nclass virtual ['res] lift =\n object (self)\n method virtual record : (string * 'res) list -> 'res\n method virtual constr : string -> 'res list -> 'res\n method virtual tuple : 'res list -> 'res\n method virtual bool : bool -> 'res\n method virtual char : char -> 'res\n method virtual int : int -> 'res\n method virtual list : 'a. ('a -> 'res) -> 'a list -> 'res\n method virtual option : 'a. ('a -> 'res) -> 'a option -> 'res\n method virtual string : string -> 'res\n\n method position : position -> 'res =\n fun { pos_fname; pos_lnum; pos_bol; pos_cnum } ->\n let pos_fname = self#string pos_fname in\n let pos_lnum = self#int pos_lnum in\n let pos_bol = self#int pos_bol in\n let pos_cnum = self#int pos_cnum in\n self#record\n [\n (\"pos_fname\", pos_fname);\n (\"pos_lnum\", pos_lnum);\n (\"pos_bol\", pos_bol);\n (\"pos_cnum\", pos_cnum);\n ]\n\n method location : location -> 'res =\n fun { loc_start; loc_end; loc_ghost } ->\n let loc_start = self#position loc_start in\n let loc_end = self#position loc_end in\n let loc_ghost = self#bool loc_ghost in\n self#record\n [\n (\"loc_start\", loc_start);\n (\"loc_end\", loc_end);\n (\"loc_ghost\", loc_ghost);\n ]\n\n method location_stack : location_stack -> 'res = self#list self#location\n\n method loc : 'a. ('a -> 'res) -> 'a loc -> 'res =\n fun _a { txt; loc } ->\n let txt = _a txt in\n let loc = self#location loc in\n self#record [ (\"txt\", txt); (\"loc\", loc) ]\n\n method longident : longident -> 'res =\n fun x ->\n match x with\n | Lident a ->\n let a = self#string a in\n self#constr \"Lident\" [ a ]\n | Ldot (a, b) ->\n let a = self#longident a in\n let b = self#string b in\n self#constr \"Ldot\" [ a; b ]\n | Lapply (a, b) ->\n let a = self#longident a in\n let b = self#longident b in\n self#constr \"Lapply\" [ a; b ]\n\n method longident_loc : longident_loc -> 'res = self#loc self#longident\n\n method rec_flag : rec_flag -> 'res =\n fun x ->\n match x with\n | Nonrecursive -> self#constr \"Nonrecursive\" []\n | Recursive -> self#constr \"Recursive\" []\n\n method direction_flag : direction_flag -> 'res =\n fun x ->\n match x with\n | Upto -> self#constr \"Upto\" []\n | Downto -> self#constr \"Downto\" []\n\n method private_flag : private_flag -> 'res =\n fun x ->\n match x with\n | Private -> self#constr \"Private\" []\n | Public -> self#constr \"Public\" []\n\n method mutable_flag : mutable_flag -> 'res =\n fun x ->\n match x with\n | Immutable -> self#constr \"Immutable\" []\n | Mutable -> self#constr \"Mutable\" []\n\n method virtual_flag : virtual_flag -> 'res =\n fun x ->\n match x with\n | Virtual -> self#constr \"Virtual\" []\n | Concrete -> self#constr \"Concrete\" []\n\n method override_flag : override_flag -> 'res =\n fun x ->\n match x with\n | Override -> self#constr \"Override\" []\n | Fresh -> self#constr \"Fresh\" []\n\n method closed_flag : closed_flag -> 'res =\n fun x ->\n match x with\n | Closed -> self#constr \"Closed\" []\n | Open -> self#constr \"Open\" []\n\n method label : label -> 'res = self#string\n\n method arg_label : arg_label -> 'res =\n fun x ->\n match x with\n | Nolabel -> self#constr \"Nolabel\" []\n | Labelled a ->\n let a = self#string a in\n self#constr \"Labelled\" [ a ]\n | Optional a ->\n let a = self#string a in\n self#constr \"Optional\" [ a ]\n\n method variance : variance -> 'res =\n fun x ->\n match x with\n | Covariant -> self#constr \"Covariant\" []\n | Contravariant -> self#constr \"Contravariant\" []\n | NoVariance -> self#constr \"NoVariance\" []\n\n method injectivity : injectivity -> 'res =\n fun x ->\n match x with\n | Injective -> self#constr \"Injective\" []\n | NoInjectivity -> self#constr \"NoInjectivity\" []\n\n method constant : constant -> 'res =\n fun x ->\n match x with\n | Pconst_integer (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n self#constr \"Pconst_integer\" [ a; b ]\n | Pconst_char a ->\n let a = self#char a in\n self#constr \"Pconst_char\" [ a ]\n | Pconst_string (a, b, c) ->\n let a = self#string a in\n let b = self#location b in\n let c = self#option self#string c in\n self#constr \"Pconst_string\" [ a; b; c ]\n | Pconst_float (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n self#constr \"Pconst_float\" [ a; b ]\n\n method attribute : attribute -> 'res =\n fun { attr_name; attr_payload; attr_loc } ->\n let attr_name = self#loc self#string attr_name in\n let attr_payload = self#payload attr_payload in\n let attr_loc = self#location attr_loc in\n self#record\n [\n (\"attr_name\", attr_name);\n (\"attr_payload\", attr_payload);\n (\"attr_loc\", attr_loc);\n ]\n\n method extension : extension -> 'res =\n fun (a, b) ->\n let a = self#loc self#string a in\n let b = self#payload b in\n self#tuple [ a; b ]\n\n method attributes : attributes -> 'res = self#list self#attribute\n\n method payload : payload -> 'res =\n fun x ->\n match x with\n | PStr a ->\n let a = self#structure a in\n self#constr \"PStr\" [ a ]\n | PSig a ->\n let a = self#signature a in\n self#constr \"PSig\" [ a ]\n | PTyp a ->\n let a = self#core_type a in\n self#constr \"PTyp\" [ a ]\n | PPat (a, b) ->\n let a = self#pattern a in\n let b = self#option self#expression b in\n self#constr \"PPat\" [ a; b ]\n\n method core_type : core_type -> 'res =\n fun { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } ->\n let ptyp_desc = self#core_type_desc ptyp_desc in\n let ptyp_loc = self#location ptyp_loc in\n let ptyp_loc_stack = self#location_stack ptyp_loc_stack in\n let ptyp_attributes = self#attributes ptyp_attributes in\n self#record\n [\n (\"ptyp_desc\", ptyp_desc);\n (\"ptyp_loc\", ptyp_loc);\n (\"ptyp_loc_stack\", ptyp_loc_stack);\n (\"ptyp_attributes\", ptyp_attributes);\n ]\n\n method core_type_desc : core_type_desc -> 'res =\n fun x ->\n match x with\n | Ptyp_any -> self#constr \"Ptyp_any\" []\n | Ptyp_var a ->\n let a = self#string a in\n self#constr \"Ptyp_var\" [ a ]\n | Ptyp_arrow (a, b, c) ->\n let a = self#arg_label a in\n let b = self#core_type b in\n let c = self#core_type c in\n self#constr \"Ptyp_arrow\" [ a; b; c ]\n | Ptyp_tuple a ->\n let a = self#list self#core_type a in\n self#constr \"Ptyp_tuple\" [ a ]\n | Ptyp_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n self#constr \"Ptyp_constr\" [ a; b ]\n | Ptyp_object (a, b) ->\n let a = self#list self#object_field a in\n let b = self#closed_flag b in\n self#constr \"Ptyp_object\" [ a; b ]\n | Ptyp_class (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n self#constr \"Ptyp_class\" [ a; b ]\n | Ptyp_alias (a, b) ->\n let a = self#core_type a in\n let b = self#string b in\n self#constr \"Ptyp_alias\" [ a; b ]\n | Ptyp_variant (a, b, c) ->\n let a = self#list self#row_field a in\n let b = self#closed_flag b in\n let c = self#option (self#list self#label) c in\n self#constr \"Ptyp_variant\" [ a; b; c ]\n | Ptyp_poly (a, b) ->\n let a = self#list (self#loc self#string) a in\n let b = self#core_type b in\n self#constr \"Ptyp_poly\" [ a; b ]\n | Ptyp_package a ->\n let a = self#package_type a in\n self#constr \"Ptyp_package\" [ a ]\n | Ptyp_extension a ->\n let a = self#extension a in\n self#constr \"Ptyp_extension\" [ a ]\n\n method package_type : package_type -> 'res =\n fun (a, b) ->\n let a = self#longident_loc a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#core_type b in\n self#tuple [ a; b ])\n b\n in\n self#tuple [ a; b ]\n\n method row_field : row_field -> 'res =\n fun { prf_desc; prf_loc; prf_attributes } ->\n let prf_desc = self#row_field_desc prf_desc in\n let prf_loc = self#location prf_loc in\n let prf_attributes = self#attributes prf_attributes in\n self#record\n [\n (\"prf_desc\", prf_desc);\n (\"prf_loc\", prf_loc);\n (\"prf_attributes\", prf_attributes);\n ]\n\n method row_field_desc : row_field_desc -> 'res =\n fun x ->\n match x with\n | Rtag (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#bool b in\n let c = self#list self#core_type c in\n self#constr \"Rtag\" [ a; b; c ]\n | Rinherit a ->\n let a = self#core_type a in\n self#constr \"Rinherit\" [ a ]\n\n method object_field : object_field -> 'res =\n fun { pof_desc; pof_loc; pof_attributes } ->\n let pof_desc = self#object_field_desc pof_desc in\n let pof_loc = self#location pof_loc in\n let pof_attributes = self#attributes pof_attributes in\n self#record\n [\n (\"pof_desc\", pof_desc);\n (\"pof_loc\", pof_loc);\n (\"pof_attributes\", pof_attributes);\n ]\n\n method object_field_desc : object_field_desc -> 'res =\n fun x ->\n match x with\n | Otag (a, b) ->\n let a = self#loc self#label a in\n let b = self#core_type b in\n self#constr \"Otag\" [ a; b ]\n | Oinherit a ->\n let a = self#core_type a in\n self#constr \"Oinherit\" [ a ]\n\n method pattern : pattern -> 'res =\n fun { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } ->\n let ppat_desc = self#pattern_desc ppat_desc in\n let ppat_loc = self#location ppat_loc in\n let ppat_loc_stack = self#location_stack ppat_loc_stack in\n let ppat_attributes = self#attributes ppat_attributes in\n self#record\n [\n (\"ppat_desc\", ppat_desc);\n (\"ppat_loc\", ppat_loc);\n (\"ppat_loc_stack\", ppat_loc_stack);\n (\"ppat_attributes\", ppat_attributes);\n ]\n\n method pattern_desc : pattern_desc -> 'res =\n fun x ->\n match x with\n | Ppat_any -> self#constr \"Ppat_any\" []\n | Ppat_var a ->\n let a = self#loc self#string a in\n self#constr \"Ppat_var\" [ a ]\n | Ppat_alias (a, b) ->\n let a = self#pattern a in\n let b = self#loc self#string b in\n self#constr \"Ppat_alias\" [ a; b ]\n | Ppat_constant a ->\n let a = self#constant a in\n self#constr \"Ppat_constant\" [ a ]\n | Ppat_interval (a, b) ->\n let a = self#constant a in\n let b = self#constant b in\n self#constr \"Ppat_interval\" [ a; b ]\n | Ppat_tuple a ->\n let a = self#list self#pattern a in\n self#constr \"Ppat_tuple\" [ a ]\n | Ppat_construct (a, b) ->\n let a = self#longident_loc a in\n let b = self#option self#pattern b in\n self#constr \"Ppat_construct\" [ a; b ]\n | Ppat_variant (a, b) ->\n let a = self#label a in\n let b = self#option self#pattern b in\n self#constr \"Ppat_variant\" [ a; b ]\n | Ppat_record (a, b) ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#pattern b in\n self#tuple [ a; b ])\n a\n in\n let b = self#closed_flag b in\n self#constr \"Ppat_record\" [ a; b ]\n | Ppat_array a ->\n let a = self#list self#pattern a in\n self#constr \"Ppat_array\" [ a ]\n | Ppat_or (a, b) ->\n let a = self#pattern a in\n let b = self#pattern b in\n self#constr \"Ppat_or\" [ a; b ]\n | Ppat_constraint (a, b) ->\n let a = self#pattern a in\n let b = self#core_type b in\n self#constr \"Ppat_constraint\" [ a; b ]\n | Ppat_type a ->\n let a = self#longident_loc a in\n self#constr \"Ppat_type\" [ a ]\n | Ppat_lazy a ->\n let a = self#pattern a in\n self#constr \"Ppat_lazy\" [ a ]\n | Ppat_unpack a ->\n let a = self#loc (self#option self#string) a in\n self#constr \"Ppat_unpack\" [ a ]\n | Ppat_exception a ->\n let a = self#pattern a in\n self#constr \"Ppat_exception\" [ a ]\n | Ppat_extension a ->\n let a = self#extension a in\n self#constr \"Ppat_extension\" [ a ]\n | Ppat_open (a, b) ->\n let a = self#longident_loc a in\n let b = self#pattern b in\n self#constr \"Ppat_open\" [ a; b ]\n\n method expression : expression -> 'res =\n fun { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } ->\n let pexp_desc = self#expression_desc pexp_desc in\n let pexp_loc = self#location pexp_loc in\n let pexp_loc_stack = self#location_stack pexp_loc_stack in\n let pexp_attributes = self#attributes pexp_attributes in\n self#record\n [\n (\"pexp_desc\", pexp_desc);\n (\"pexp_loc\", pexp_loc);\n (\"pexp_loc_stack\", pexp_loc_stack);\n (\"pexp_attributes\", pexp_attributes);\n ]\n\n method expression_desc : expression_desc -> 'res =\n fun x ->\n match x with\n | Pexp_ident a ->\n let a = self#longident_loc a in\n self#constr \"Pexp_ident\" [ a ]\n | Pexp_constant a ->\n let a = self#constant a in\n self#constr \"Pexp_constant\" [ a ]\n | Pexp_let (a, b, c) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n let c = self#expression c in\n self#constr \"Pexp_let\" [ a; b; c ]\n | Pexp_function a ->\n let a = self#cases a in\n self#constr \"Pexp_function\" [ a ]\n | Pexp_fun (a, b, c, d) ->\n let a = self#arg_label a in\n let b = self#option self#expression b in\n let c = self#pattern c in\n let d = self#expression d in\n self#constr \"Pexp_fun\" [ a; b; c; d ]\n | Pexp_apply (a, b) ->\n let a = self#expression a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#arg_label a in\n let b = self#expression b in\n self#tuple [ a; b ])\n b\n in\n self#constr \"Pexp_apply\" [ a; b ]\n | Pexp_match (a, b) ->\n let a = self#expression a in\n let b = self#cases b in\n self#constr \"Pexp_match\" [ a; b ]\n | Pexp_try (a, b) ->\n let a = self#expression a in\n let b = self#cases b in\n self#constr \"Pexp_try\" [ a; b ]\n | Pexp_tuple a ->\n let a = self#list self#expression a in\n self#constr \"Pexp_tuple\" [ a ]\n | Pexp_construct (a, b) ->\n let a = self#longident_loc a in\n let b = self#option self#expression b in\n self#constr \"Pexp_construct\" [ a; b ]\n | Pexp_variant (a, b) ->\n let a = self#label a in\n let b = self#option self#expression b in\n self#constr \"Pexp_variant\" [ a; b ]\n | Pexp_record (a, b) ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#expression b in\n self#tuple [ a; b ])\n a\n in\n let b = self#option self#expression b in\n self#constr \"Pexp_record\" [ a; b ]\n | Pexp_field (a, b) ->\n let a = self#expression a in\n let b = self#longident_loc b in\n self#constr \"Pexp_field\" [ a; b ]\n | Pexp_setfield (a, b, c) ->\n let a = self#expression a in\n let b = self#longident_loc b in\n let c = self#expression c in\n self#constr \"Pexp_setfield\" [ a; b; c ]\n | Pexp_array a ->\n let a = self#list self#expression a in\n self#constr \"Pexp_array\" [ a ]\n | Pexp_ifthenelse (a, b, c) ->\n let a = self#expression a in\n let b = self#expression b in\n let c = self#option self#expression c in\n self#constr \"Pexp_ifthenelse\" [ a; b; c ]\n | Pexp_sequence (a, b) ->\n let a = self#expression a in\n let b = self#expression b in\n self#constr \"Pexp_sequence\" [ a; b ]\n | Pexp_while (a, b) ->\n let a = self#expression a in\n let b = self#expression b in\n self#constr \"Pexp_while\" [ a; b ]\n | Pexp_for (a, b, c, d, e) ->\n let a = self#pattern a in\n let b = self#expression b in\n let c = self#expression c in\n let d = self#direction_flag d in\n let e = self#expression e in\n self#constr \"Pexp_for\" [ a; b; c; d; e ]\n | Pexp_constraint (a, b) ->\n let a = self#expression a in\n let b = self#core_type b in\n self#constr \"Pexp_constraint\" [ a; b ]\n | Pexp_coerce (a, b, c) ->\n let a = self#expression a in\n let b = self#option self#core_type b in\n let c = self#core_type c in\n self#constr \"Pexp_coerce\" [ a; b; c ]\n | Pexp_send (a, b) ->\n let a = self#expression a in\n let b = self#loc self#label b in\n self#constr \"Pexp_send\" [ a; b ]\n | Pexp_new a ->\n let a = self#longident_loc a in\n self#constr \"Pexp_new\" [ a ]\n | Pexp_setinstvar (a, b) ->\n let a = self#loc self#label a in\n let b = self#expression b in\n self#constr \"Pexp_setinstvar\" [ a; b ]\n | Pexp_override a ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#loc self#label a in\n let b = self#expression b in\n self#tuple [ a; b ])\n a\n in\n self#constr \"Pexp_override\" [ a ]\n | Pexp_letmodule (a, b, c) ->\n let a = self#loc (self#option self#string) a in\n let b = self#module_expr b in\n let c = self#expression c in\n self#constr \"Pexp_letmodule\" [ a; b; c ]\n | Pexp_letexception (a, b) ->\n let a = self#extension_constructor a in\n let b = self#expression b in\n self#constr \"Pexp_letexception\" [ a; b ]\n | Pexp_assert a ->\n let a = self#expression a in\n self#constr \"Pexp_assert\" [ a ]\n | Pexp_lazy a ->\n let a = self#expression a in\n self#constr \"Pexp_lazy\" [ a ]\n | Pexp_poly (a, b) ->\n let a = self#expression a in\n let b = self#option self#core_type b in\n self#constr \"Pexp_poly\" [ a; b ]\n | Pexp_object a ->\n let a = self#class_structure a in\n self#constr \"Pexp_object\" [ a ]\n | Pexp_newtype (a, b) ->\n let a = self#loc self#string a in\n let b = self#expression b in\n self#constr \"Pexp_newtype\" [ a; b ]\n | Pexp_pack a ->\n let a = self#module_expr a in\n self#constr \"Pexp_pack\" [ a ]\n | Pexp_open (a, b) ->\n let a = self#open_declaration a in\n let b = self#expression b in\n self#constr \"Pexp_open\" [ a; b ]\n | Pexp_letop a ->\n let a = self#letop a in\n self#constr \"Pexp_letop\" [ a ]\n | Pexp_extension a ->\n let a = self#extension a in\n self#constr \"Pexp_extension\" [ a ]\n | Pexp_unreachable -> self#constr \"Pexp_unreachable\" []\n\n method case : case -> 'res =\n fun { pc_lhs; pc_guard; pc_rhs } ->\n let pc_lhs = self#pattern pc_lhs in\n let pc_guard = self#option self#expression pc_guard in\n let pc_rhs = self#expression pc_rhs in\n self#record\n [ (\"pc_lhs\", pc_lhs); (\"pc_guard\", pc_guard); (\"pc_rhs\", pc_rhs) ]\n\n method letop : letop -> 'res =\n fun { let_; ands; body } ->\n let let_ = self#binding_op let_ in\n let ands = self#list self#binding_op ands in\n let body = self#expression body in\n self#record [ (\"let_\", let_); (\"ands\", ands); (\"body\", body) ]\n\n method binding_op : binding_op -> 'res =\n fun { pbop_op; pbop_pat; pbop_exp; pbop_loc } ->\n let pbop_op = self#loc self#string pbop_op in\n let pbop_pat = self#pattern pbop_pat in\n let pbop_exp = self#expression pbop_exp in\n let pbop_loc = self#location pbop_loc in\n self#record\n [\n (\"pbop_op\", pbop_op);\n (\"pbop_pat\", pbop_pat);\n (\"pbop_exp\", pbop_exp);\n (\"pbop_loc\", pbop_loc);\n ]\n\n method value_description : value_description -> 'res =\n fun { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } ->\n let pval_name = self#loc self#string pval_name in\n let pval_type = self#core_type pval_type in\n let pval_prim = self#list self#string pval_prim in\n let pval_attributes = self#attributes pval_attributes in\n let pval_loc = self#location pval_loc in\n self#record\n [\n (\"pval_name\", pval_name);\n (\"pval_type\", pval_type);\n (\"pval_prim\", pval_prim);\n (\"pval_attributes\", pval_attributes);\n (\"pval_loc\", pval_loc);\n ]\n\n method type_declaration : type_declaration -> 'res =\n fun {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } ->\n let ptype_name = self#loc self#string ptype_name in\n let ptype_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n self#tuple [ a; b ])\n b\n in\n self#tuple [ a; b ])\n ptype_params\n in\n let ptype_cstrs =\n self#list\n (fun (a, b, c) ->\n let a = self#core_type a in\n let b = self#core_type b in\n let c = self#location c in\n self#tuple [ a; b; c ])\n ptype_cstrs\n in\n let ptype_kind = self#type_kind ptype_kind in\n let ptype_private = self#private_flag ptype_private in\n let ptype_manifest = self#option self#core_type ptype_manifest in\n let ptype_attributes = self#attributes ptype_attributes in\n let ptype_loc = self#location ptype_loc in\n self#record\n [\n (\"ptype_name\", ptype_name);\n (\"ptype_params\", ptype_params);\n (\"ptype_cstrs\", ptype_cstrs);\n (\"ptype_kind\", ptype_kind);\n (\"ptype_private\", ptype_private);\n (\"ptype_manifest\", ptype_manifest);\n (\"ptype_attributes\", ptype_attributes);\n (\"ptype_loc\", ptype_loc);\n ]\n\n method type_kind : type_kind -> 'res =\n fun x ->\n match x with\n | Ptype_abstract -> self#constr \"Ptype_abstract\" []\n | Ptype_variant a ->\n let a = self#list self#constructor_declaration a in\n self#constr \"Ptype_variant\" [ a ]\n | Ptype_record a ->\n let a = self#list self#label_declaration a in\n self#constr \"Ptype_record\" [ a ]\n | Ptype_open -> self#constr \"Ptype_open\" []\n\n method label_declaration : label_declaration -> 'res =\n fun { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } ->\n let pld_name = self#loc self#string pld_name in\n let pld_mutable = self#mutable_flag pld_mutable in\n let pld_type = self#core_type pld_type in\n let pld_loc = self#location pld_loc in\n let pld_attributes = self#attributes pld_attributes in\n self#record\n [\n (\"pld_name\", pld_name);\n (\"pld_mutable\", pld_mutable);\n (\"pld_type\", pld_type);\n (\"pld_loc\", pld_loc);\n (\"pld_attributes\", pld_attributes);\n ]\n\n method constructor_declaration : constructor_declaration -> 'res =\n fun { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } ->\n let pcd_name = self#loc self#string pcd_name in\n let pcd_args = self#constructor_arguments pcd_args in\n let pcd_res = self#option self#core_type pcd_res in\n let pcd_loc = self#location pcd_loc in\n let pcd_attributes = self#attributes pcd_attributes in\n self#record\n [\n (\"pcd_name\", pcd_name);\n (\"pcd_args\", pcd_args);\n (\"pcd_res\", pcd_res);\n (\"pcd_loc\", pcd_loc);\n (\"pcd_attributes\", pcd_attributes);\n ]\n\n method constructor_arguments : constructor_arguments -> 'res =\n fun x ->\n match x with\n | Pcstr_tuple a ->\n let a = self#list self#core_type a in\n self#constr \"Pcstr_tuple\" [ a ]\n | Pcstr_record a ->\n let a = self#list self#label_declaration a in\n self#constr \"Pcstr_record\" [ a ]\n\n method type_extension : type_extension -> 'res =\n fun {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } ->\n let ptyext_path = self#longident_loc ptyext_path in\n let ptyext_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n self#tuple [ a; b ])\n b\n in\n self#tuple [ a; b ])\n ptyext_params\n in\n let ptyext_constructors =\n self#list self#extension_constructor ptyext_constructors\n in\n let ptyext_private = self#private_flag ptyext_private in\n let ptyext_loc = self#location ptyext_loc in\n let ptyext_attributes = self#attributes ptyext_attributes in\n self#record\n [\n (\"ptyext_path\", ptyext_path);\n (\"ptyext_params\", ptyext_params);\n (\"ptyext_constructors\", ptyext_constructors);\n (\"ptyext_private\", ptyext_private);\n (\"ptyext_loc\", ptyext_loc);\n (\"ptyext_attributes\", ptyext_attributes);\n ]\n\n method extension_constructor : extension_constructor -> 'res =\n fun { pext_name; pext_kind; pext_loc; pext_attributes } ->\n let pext_name = self#loc self#string pext_name in\n let pext_kind = self#extension_constructor_kind pext_kind in\n let pext_loc = self#location pext_loc in\n let pext_attributes = self#attributes pext_attributes in\n self#record\n [\n (\"pext_name\", pext_name);\n (\"pext_kind\", pext_kind);\n (\"pext_loc\", pext_loc);\n (\"pext_attributes\", pext_attributes);\n ]\n\n method type_exception : type_exception -> 'res =\n fun { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } ->\n let ptyexn_constructor =\n self#extension_constructor ptyexn_constructor\n in\n let ptyexn_loc = self#location ptyexn_loc in\n let ptyexn_attributes = self#attributes ptyexn_attributes in\n self#record\n [\n (\"ptyexn_constructor\", ptyexn_constructor);\n (\"ptyexn_loc\", ptyexn_loc);\n (\"ptyexn_attributes\", ptyexn_attributes);\n ]\n\n method extension_constructor_kind : extension_constructor_kind -> 'res =\n fun x ->\n match x with\n | Pext_decl (a, b) ->\n let a = self#constructor_arguments a in\n let b = self#option self#core_type b in\n self#constr \"Pext_decl\" [ a; b ]\n | Pext_rebind a ->\n let a = self#longident_loc a in\n self#constr \"Pext_rebind\" [ a ]\n\n method class_type : class_type -> 'res =\n fun { pcty_desc; pcty_loc; pcty_attributes } ->\n let pcty_desc = self#class_type_desc pcty_desc in\n let pcty_loc = self#location pcty_loc in\n let pcty_attributes = self#attributes pcty_attributes in\n self#record\n [\n (\"pcty_desc\", pcty_desc);\n (\"pcty_loc\", pcty_loc);\n (\"pcty_attributes\", pcty_attributes);\n ]\n\n method class_type_desc : class_type_desc -> 'res =\n fun x ->\n match x with\n | Pcty_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n self#constr \"Pcty_constr\" [ a; b ]\n | Pcty_signature a ->\n let a = self#class_signature a in\n self#constr \"Pcty_signature\" [ a ]\n | Pcty_arrow (a, b, c) ->\n let a = self#arg_label a in\n let b = self#core_type b in\n let c = self#class_type c in\n self#constr \"Pcty_arrow\" [ a; b; c ]\n | Pcty_extension a ->\n let a = self#extension a in\n self#constr \"Pcty_extension\" [ a ]\n | Pcty_open (a, b) ->\n let a = self#open_description a in\n let b = self#class_type b in\n self#constr \"Pcty_open\" [ a; b ]\n\n method class_signature : class_signature -> 'res =\n fun { pcsig_self; pcsig_fields } ->\n let pcsig_self = self#core_type pcsig_self in\n let pcsig_fields = self#list self#class_type_field pcsig_fields in\n self#record\n [ (\"pcsig_self\", pcsig_self); (\"pcsig_fields\", pcsig_fields) ]\n\n method class_type_field : class_type_field -> 'res =\n fun { pctf_desc; pctf_loc; pctf_attributes } ->\n let pctf_desc = self#class_type_field_desc pctf_desc in\n let pctf_loc = self#location pctf_loc in\n let pctf_attributes = self#attributes pctf_attributes in\n self#record\n [\n (\"pctf_desc\", pctf_desc);\n (\"pctf_loc\", pctf_loc);\n (\"pctf_attributes\", pctf_attributes);\n ]\n\n method class_type_field_desc : class_type_field_desc -> 'res =\n fun x ->\n match x with\n | Pctf_inherit a ->\n let a = self#class_type a in\n self#constr \"Pctf_inherit\" [ a ]\n | Pctf_val a ->\n let a =\n (fun (a, b, c, d) ->\n let a = self#loc self#label a in\n let b = self#mutable_flag b in\n let c = self#virtual_flag c in\n let d = self#core_type d in\n self#tuple [ a; b; c; d ])\n a\n in\n self#constr \"Pctf_val\" [ a ]\n | Pctf_method a ->\n let a =\n (fun (a, b, c, d) ->\n let a = self#loc self#label a in\n let b = self#private_flag b in\n let c = self#virtual_flag c in\n let d = self#core_type d in\n self#tuple [ a; b; c; d ])\n a\n in\n self#constr \"Pctf_method\" [ a ]\n | Pctf_constraint a ->\n let a =\n (fun (a, b) ->\n let a = self#core_type a in\n let b = self#core_type b in\n self#tuple [ a; b ])\n a\n in\n self#constr \"Pctf_constraint\" [ a ]\n | Pctf_attribute a ->\n let a = self#attribute a in\n self#constr \"Pctf_attribute\" [ a ]\n | Pctf_extension a ->\n let a = self#extension a in\n self#constr \"Pctf_extension\" [ a ]\n\n method class_infos : 'a. ('a -> 'res) -> 'a class_infos -> 'res =\n fun _a\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes } ->\n let pci_virt = self#virtual_flag pci_virt in\n let pci_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n self#tuple [ a; b ])\n b\n in\n self#tuple [ a; b ])\n pci_params\n in\n let pci_name = self#loc self#string pci_name in\n let pci_expr = _a pci_expr in\n let pci_loc = self#location pci_loc in\n let pci_attributes = self#attributes pci_attributes in\n self#record\n [\n (\"pci_virt\", pci_virt);\n (\"pci_params\", pci_params);\n (\"pci_name\", pci_name);\n (\"pci_expr\", pci_expr);\n (\"pci_loc\", pci_loc);\n (\"pci_attributes\", pci_attributes);\n ]\n\n method class_description : class_description -> 'res =\n self#class_infos self#class_type\n\n method class_type_declaration : class_type_declaration -> 'res =\n self#class_infos self#class_type\n\n method class_expr : class_expr -> 'res =\n fun { pcl_desc; pcl_loc; pcl_attributes } ->\n let pcl_desc = self#class_expr_desc pcl_desc in\n let pcl_loc = self#location pcl_loc in\n let pcl_attributes = self#attributes pcl_attributes in\n self#record\n [\n (\"pcl_desc\", pcl_desc);\n (\"pcl_loc\", pcl_loc);\n (\"pcl_attributes\", pcl_attributes);\n ]\n\n method class_expr_desc : class_expr_desc -> 'res =\n fun x ->\n match x with\n | Pcl_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n self#constr \"Pcl_constr\" [ a; b ]\n | Pcl_structure a ->\n let a = self#class_structure a in\n self#constr \"Pcl_structure\" [ a ]\n | Pcl_fun (a, b, c, d) ->\n let a = self#arg_label a in\n let b = self#option self#expression b in\n let c = self#pattern c in\n let d = self#class_expr d in\n self#constr \"Pcl_fun\" [ a; b; c; d ]\n | Pcl_apply (a, b) ->\n let a = self#class_expr a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#arg_label a in\n let b = self#expression b in\n self#tuple [ a; b ])\n b\n in\n self#constr \"Pcl_apply\" [ a; b ]\n | Pcl_let (a, b, c) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n let c = self#class_expr c in\n self#constr \"Pcl_let\" [ a; b; c ]\n | Pcl_constraint (a, b) ->\n let a = self#class_expr a in\n let b = self#class_type b in\n self#constr \"Pcl_constraint\" [ a; b ]\n | Pcl_extension a ->\n let a = self#extension a in\n self#constr \"Pcl_extension\" [ a ]\n | Pcl_open (a, b) ->\n let a = self#open_description a in\n let b = self#class_expr b in\n self#constr \"Pcl_open\" [ a; b ]\n\n method class_structure : class_structure -> 'res =\n fun { pcstr_self; pcstr_fields } ->\n let pcstr_self = self#pattern pcstr_self in\n let pcstr_fields = self#list self#class_field pcstr_fields in\n self#record\n [ (\"pcstr_self\", pcstr_self); (\"pcstr_fields\", pcstr_fields) ]\n\n method class_field : class_field -> 'res =\n fun { pcf_desc; pcf_loc; pcf_attributes } ->\n let pcf_desc = self#class_field_desc pcf_desc in\n let pcf_loc = self#location pcf_loc in\n let pcf_attributes = self#attributes pcf_attributes in\n self#record\n [\n (\"pcf_desc\", pcf_desc);\n (\"pcf_loc\", pcf_loc);\n (\"pcf_attributes\", pcf_attributes);\n ]\n\n method class_field_desc : class_field_desc -> 'res =\n fun x ->\n match x with\n | Pcf_inherit (a, b, c) ->\n let a = self#override_flag a in\n let b = self#class_expr b in\n let c = self#option (self#loc self#string) c in\n self#constr \"Pcf_inherit\" [ a; b; c ]\n | Pcf_val a ->\n let a =\n (fun (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#mutable_flag b in\n let c = self#class_field_kind c in\n self#tuple [ a; b; c ])\n a\n in\n self#constr \"Pcf_val\" [ a ]\n | Pcf_method a ->\n let a =\n (fun (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#private_flag b in\n let c = self#class_field_kind c in\n self#tuple [ a; b; c ])\n a\n in\n self#constr \"Pcf_method\" [ a ]\n | Pcf_constraint a ->\n let a =\n (fun (a, b) ->\n let a = self#core_type a in\n let b = self#core_type b in\n self#tuple [ a; b ])\n a\n in\n self#constr \"Pcf_constraint\" [ a ]\n | Pcf_initializer a ->\n let a = self#expression a in\n self#constr \"Pcf_initializer\" [ a ]\n | Pcf_attribute a ->\n let a = self#attribute a in\n self#constr \"Pcf_attribute\" [ a ]\n | Pcf_extension a ->\n let a = self#extension a in\n self#constr \"Pcf_extension\" [ a ]\n\n method class_field_kind : class_field_kind -> 'res =\n fun x ->\n match x with\n | Cfk_virtual a ->\n let a = self#core_type a in\n self#constr \"Cfk_virtual\" [ a ]\n | Cfk_concrete (a, b) ->\n let a = self#override_flag a in\n let b = self#expression b in\n self#constr \"Cfk_concrete\" [ a; b ]\n\n method class_declaration : class_declaration -> 'res =\n self#class_infos self#class_expr\n\n method module_type : module_type -> 'res =\n fun { pmty_desc; pmty_loc; pmty_attributes } ->\n let pmty_desc = self#module_type_desc pmty_desc in\n let pmty_loc = self#location pmty_loc in\n let pmty_attributes = self#attributes pmty_attributes in\n self#record\n [\n (\"pmty_desc\", pmty_desc);\n (\"pmty_loc\", pmty_loc);\n (\"pmty_attributes\", pmty_attributes);\n ]\n\n method module_type_desc : module_type_desc -> 'res =\n fun x ->\n match x with\n | Pmty_ident a ->\n let a = self#longident_loc a in\n self#constr \"Pmty_ident\" [ a ]\n | Pmty_signature a ->\n let a = self#signature a in\n self#constr \"Pmty_signature\" [ a ]\n | Pmty_functor (a, b) ->\n let a = self#functor_parameter a in\n let b = self#module_type b in\n self#constr \"Pmty_functor\" [ a; b ]\n | Pmty_with (a, b) ->\n let a = self#module_type a in\n let b = self#list self#with_constraint b in\n self#constr \"Pmty_with\" [ a; b ]\n | Pmty_typeof a ->\n let a = self#module_expr a in\n self#constr \"Pmty_typeof\" [ a ]\n | Pmty_extension a ->\n let a = self#extension a in\n self#constr \"Pmty_extension\" [ a ]\n | Pmty_alias a ->\n let a = self#longident_loc a in\n self#constr \"Pmty_alias\" [ a ]\n\n method functor_parameter : functor_parameter -> 'res =\n fun x ->\n match x with\n | Unit -> self#constr \"Unit\" []\n | Named (a, b) ->\n let a = self#loc (self#option self#string) a in\n let b = self#module_type b in\n self#constr \"Named\" [ a; b ]\n\n method signature : signature -> 'res = self#list self#signature_item\n\n method signature_item : signature_item -> 'res =\n fun { psig_desc; psig_loc } ->\n let psig_desc = self#signature_item_desc psig_desc in\n let psig_loc = self#location psig_loc in\n self#record [ (\"psig_desc\", psig_desc); (\"psig_loc\", psig_loc) ]\n\n method signature_item_desc : signature_item_desc -> 'res =\n fun x ->\n match x with\n | Psig_value a ->\n let a = self#value_description a in\n self#constr \"Psig_value\" [ a ]\n | Psig_type (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#type_declaration b in\n self#constr \"Psig_type\" [ a; b ]\n | Psig_typesubst a ->\n let a = self#list self#type_declaration a in\n self#constr \"Psig_typesubst\" [ a ]\n | Psig_typext a ->\n let a = self#type_extension a in\n self#constr \"Psig_typext\" [ a ]\n | Psig_exception a ->\n let a = self#type_exception a in\n self#constr \"Psig_exception\" [ a ]\n | Psig_module a ->\n let a = self#module_declaration a in\n self#constr \"Psig_module\" [ a ]\n | Psig_modsubst a ->\n let a = self#module_substitution a in\n self#constr \"Psig_modsubst\" [ a ]\n | Psig_recmodule a ->\n let a = self#list self#module_declaration a in\n self#constr \"Psig_recmodule\" [ a ]\n | Psig_modtype a ->\n let a = self#module_type_declaration a in\n self#constr \"Psig_modtype\" [ a ]\n | Psig_open a ->\n let a = self#open_description a in\n self#constr \"Psig_open\" [ a ]\n | Psig_include a ->\n let a = self#include_description a in\n self#constr \"Psig_include\" [ a ]\n | Psig_class a ->\n let a = self#list self#class_description a in\n self#constr \"Psig_class\" [ a ]\n | Psig_class_type a ->\n let a = self#list self#class_type_declaration a in\n self#constr \"Psig_class_type\" [ a ]\n | Psig_attribute a ->\n let a = self#attribute a in\n self#constr \"Psig_attribute\" [ a ]\n | Psig_extension (a, b) ->\n let a = self#extension a in\n let b = self#attributes b in\n self#constr \"Psig_extension\" [ a; b ]\n\n method module_declaration : module_declaration -> 'res =\n fun { pmd_name; pmd_type; pmd_attributes; pmd_loc } ->\n let pmd_name = self#loc (self#option self#string) pmd_name in\n let pmd_type = self#module_type pmd_type in\n let pmd_attributes = self#attributes pmd_attributes in\n let pmd_loc = self#location pmd_loc in\n self#record\n [\n (\"pmd_name\", pmd_name);\n (\"pmd_type\", pmd_type);\n (\"pmd_attributes\", pmd_attributes);\n (\"pmd_loc\", pmd_loc);\n ]\n\n method module_substitution : module_substitution -> 'res =\n fun { pms_name; pms_manifest; pms_attributes; pms_loc } ->\n let pms_name = self#loc self#string pms_name in\n let pms_manifest = self#longident_loc pms_manifest in\n let pms_attributes = self#attributes pms_attributes in\n let pms_loc = self#location pms_loc in\n self#record\n [\n (\"pms_name\", pms_name);\n (\"pms_manifest\", pms_manifest);\n (\"pms_attributes\", pms_attributes);\n (\"pms_loc\", pms_loc);\n ]\n\n method module_type_declaration : module_type_declaration -> 'res =\n fun { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } ->\n let pmtd_name = self#loc self#string pmtd_name in\n let pmtd_type = self#option self#module_type pmtd_type in\n let pmtd_attributes = self#attributes pmtd_attributes in\n let pmtd_loc = self#location pmtd_loc in\n self#record\n [\n (\"pmtd_name\", pmtd_name);\n (\"pmtd_type\", pmtd_type);\n (\"pmtd_attributes\", pmtd_attributes);\n (\"pmtd_loc\", pmtd_loc);\n ]\n\n method open_infos : 'a. ('a -> 'res) -> 'a open_infos -> 'res =\n fun _a { popen_expr; popen_override; popen_loc; popen_attributes } ->\n let popen_expr = _a popen_expr in\n let popen_override = self#override_flag popen_override in\n let popen_loc = self#location popen_loc in\n let popen_attributes = self#attributes popen_attributes in\n self#record\n [\n (\"popen_expr\", popen_expr);\n (\"popen_override\", popen_override);\n (\"popen_loc\", popen_loc);\n (\"popen_attributes\", popen_attributes);\n ]\n\n method open_description : open_description -> 'res =\n self#open_infos self#longident_loc\n\n method open_declaration : open_declaration -> 'res =\n self#open_infos self#module_expr\n\n method include_infos : 'a. ('a -> 'res) -> 'a include_infos -> 'res =\n fun _a { pincl_mod; pincl_loc; pincl_attributes } ->\n let pincl_mod = _a pincl_mod in\n let pincl_loc = self#location pincl_loc in\n let pincl_attributes = self#attributes pincl_attributes in\n self#record\n [\n (\"pincl_mod\", pincl_mod);\n (\"pincl_loc\", pincl_loc);\n (\"pincl_attributes\", pincl_attributes);\n ]\n\n method include_description : include_description -> 'res =\n self#include_infos self#module_type\n\n method include_declaration : include_declaration -> 'res =\n self#include_infos self#module_expr\n\n method with_constraint : with_constraint -> 'res =\n fun x ->\n match x with\n | Pwith_type (a, b) ->\n let a = self#longident_loc a in\n let b = self#type_declaration b in\n self#constr \"Pwith_type\" [ a; b ]\n | Pwith_module (a, b) ->\n let a = self#longident_loc a in\n let b = self#longident_loc b in\n self#constr \"Pwith_module\" [ a; b ]\n | Pwith_typesubst (a, b) ->\n let a = self#longident_loc a in\n let b = self#type_declaration b in\n self#constr \"Pwith_typesubst\" [ a; b ]\n | Pwith_modsubst (a, b) ->\n let a = self#longident_loc a in\n let b = self#longident_loc b in\n self#constr \"Pwith_modsubst\" [ a; b ]\n\n method module_expr : module_expr -> 'res =\n fun { pmod_desc; pmod_loc; pmod_attributes } ->\n let pmod_desc = self#module_expr_desc pmod_desc in\n let pmod_loc = self#location pmod_loc in\n let pmod_attributes = self#attributes pmod_attributes in\n self#record\n [\n (\"pmod_desc\", pmod_desc);\n (\"pmod_loc\", pmod_loc);\n (\"pmod_attributes\", pmod_attributes);\n ]\n\n method module_expr_desc : module_expr_desc -> 'res =\n fun x ->\n match x with\n | Pmod_ident a ->\n let a = self#longident_loc a in\n self#constr \"Pmod_ident\" [ a ]\n | Pmod_structure a ->\n let a = self#structure a in\n self#constr \"Pmod_structure\" [ a ]\n | Pmod_functor (a, b) ->\n let a = self#functor_parameter a in\n let b = self#module_expr b in\n self#constr \"Pmod_functor\" [ a; b ]\n | Pmod_apply (a, b) ->\n let a = self#module_expr a in\n let b = self#module_expr b in\n self#constr \"Pmod_apply\" [ a; b ]\n | Pmod_constraint (a, b) ->\n let a = self#module_expr a in\n let b = self#module_type b in\n self#constr \"Pmod_constraint\" [ a; b ]\n | Pmod_unpack a ->\n let a = self#expression a in\n self#constr \"Pmod_unpack\" [ a ]\n | Pmod_extension a ->\n let a = self#extension a in\n self#constr \"Pmod_extension\" [ a ]\n\n method structure : structure -> 'res = self#list self#structure_item\n\n method structure_item : structure_item -> 'res =\n fun { pstr_desc; pstr_loc } ->\n let pstr_desc = self#structure_item_desc pstr_desc in\n let pstr_loc = self#location pstr_loc in\n self#record [ (\"pstr_desc\", pstr_desc); (\"pstr_loc\", pstr_loc) ]\n\n method structure_item_desc : structure_item_desc -> 'res =\n fun x ->\n match x with\n | Pstr_eval (a, b) ->\n let a = self#expression a in\n let b = self#attributes b in\n self#constr \"Pstr_eval\" [ a; b ]\n | Pstr_value (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n self#constr \"Pstr_value\" [ a; b ]\n | Pstr_primitive a ->\n let a = self#value_description a in\n self#constr \"Pstr_primitive\" [ a ]\n | Pstr_type (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#type_declaration b in\n self#constr \"Pstr_type\" [ a; b ]\n | Pstr_typext a ->\n let a = self#type_extension a in\n self#constr \"Pstr_typext\" [ a ]\n | Pstr_exception a ->\n let a = self#type_exception a in\n self#constr \"Pstr_exception\" [ a ]\n | Pstr_module a ->\n let a = self#module_binding a in\n self#constr \"Pstr_module\" [ a ]\n | Pstr_recmodule a ->\n let a = self#list self#module_binding a in\n self#constr \"Pstr_recmodule\" [ a ]\n | Pstr_modtype a ->\n let a = self#module_type_declaration a in\n self#constr \"Pstr_modtype\" [ a ]\n | Pstr_open a ->\n let a = self#open_declaration a in\n self#constr \"Pstr_open\" [ a ]\n | Pstr_class a ->\n let a = self#list self#class_declaration a in\n self#constr \"Pstr_class\" [ a ]\n | Pstr_class_type a ->\n let a = self#list self#class_type_declaration a in\n self#constr \"Pstr_class_type\" [ a ]\n | Pstr_include a ->\n let a = self#include_declaration a in\n self#constr \"Pstr_include\" [ a ]\n | Pstr_attribute a ->\n let a = self#attribute a in\n self#constr \"Pstr_attribute\" [ a ]\n | Pstr_extension (a, b) ->\n let a = self#extension a in\n let b = self#attributes b in\n self#constr \"Pstr_extension\" [ a; b ]\n\n method value_binding : value_binding -> 'res =\n fun { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } ->\n let pvb_pat = self#pattern pvb_pat in\n let pvb_expr = self#expression pvb_expr in\n let pvb_attributes = self#attributes pvb_attributes in\n let pvb_loc = self#location pvb_loc in\n self#record\n [\n (\"pvb_pat\", pvb_pat);\n (\"pvb_expr\", pvb_expr);\n (\"pvb_attributes\", pvb_attributes);\n (\"pvb_loc\", pvb_loc);\n ]\n\n method module_binding : module_binding -> 'res =\n fun { pmb_name; pmb_expr; pmb_attributes; pmb_loc } ->\n let pmb_name = self#loc (self#option self#string) pmb_name in\n let pmb_expr = self#module_expr pmb_expr in\n let pmb_attributes = self#attributes pmb_attributes in\n let pmb_loc = self#location pmb_loc in\n self#record\n [\n (\"pmb_name\", pmb_name);\n (\"pmb_expr\", pmb_expr);\n (\"pmb_attributes\", pmb_attributes);\n (\"pmb_loc\", pmb_loc);\n ]\n\n method toplevel_phrase : toplevel_phrase -> 'res =\n fun x ->\n match x with\n | Ptop_def a ->\n let a = self#structure a in\n self#constr \"Ptop_def\" [ a ]\n | Ptop_dir a ->\n let a = self#toplevel_directive a in\n self#constr \"Ptop_dir\" [ a ]\n\n method toplevel_directive : toplevel_directive -> 'res =\n fun { pdir_name; pdir_arg; pdir_loc } ->\n let pdir_name = self#loc self#string pdir_name in\n let pdir_arg = self#option self#directive_argument pdir_arg in\n let pdir_loc = self#location pdir_loc in\n self#record\n [\n (\"pdir_name\", pdir_name);\n (\"pdir_arg\", pdir_arg);\n (\"pdir_loc\", pdir_loc);\n ]\n\n method directive_argument : directive_argument -> 'res =\n fun { pdira_desc; pdira_loc } ->\n let pdira_desc = self#directive_argument_desc pdira_desc in\n let pdira_loc = self#location pdira_loc in\n self#record [ (\"pdira_desc\", pdira_desc); (\"pdira_loc\", pdira_loc) ]\n\n method directive_argument_desc : directive_argument_desc -> 'res =\n fun x ->\n match x with\n | Pdir_string a ->\n let a = self#string a in\n self#constr \"Pdir_string\" [ a ]\n | Pdir_int (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n self#constr \"Pdir_int\" [ a; b ]\n | Pdir_ident a ->\n let a = self#longident a in\n self#constr \"Pdir_ident\" [ a ]\n | Pdir_bool a ->\n let a = self#bool a in\n self#constr \"Pdir_bool\" [ a ]\n\n method cases : cases -> 'res = self#list self#case\n end\n\n[@@@end]\n","type deriver = ..\n\nlet all = Hashtbl.create 42\n\nlet register name deriver =\n if Hashtbl.mem all name then\n Printf.ksprintf failwith\n \"Ppx_deriviers.register: %S is already registered\" name;\n Hashtbl.add all name deriver\n\nlet lookup name =\n match Hashtbl.find all name with\n | drv -> Some drv\n | exception Not_found -> None\n\nlet derivers () =\n Hashtbl.fold (fun name drv acc -> (name, drv) :: acc) all []\n","module T = struct\n type 'a map = 'a -> 'a\n type 'a iter = 'a -> unit\n type ('a, 'acc) fold = 'a -> 'acc -> 'acc\n type ('a, 'acc) fold_map = 'a -> 'acc -> 'a * 'acc\n type ('ctx, 'a) map_with_context = 'ctx -> 'a -> 'a\n type ('a, 'res) lift = 'a -> 'res\nend\n\nclass map =\n let any x = x in\n object\n method int : int T.map = any\n method string : string T.map = any\n method bool : bool T.map = any\n method char : char T.map = any\n\n method option : 'a. 'a T.map -> 'a option T.map =\n fun f x -> match x with None -> None | Some x -> Some (f x)\n\n method list : 'a. 'a T.map -> 'a list T.map = List.map\n method array : 'a. 'a T.map -> 'a array T.map = Array.map\n end\n\nclass iter =\n let any = ignore in\n object\n method int : int T.iter = any\n method string : string T.iter = any\n method bool : bool T.iter = any\n method char : char T.iter = any\n\n method option : 'a. 'a T.iter -> 'a option T.iter =\n fun f x -> match x with None -> () | Some x -> f x\n\n method list : 'a. 'a T.iter -> 'a list T.iter = List.iter\n method array : 'a. 'a T.iter -> 'a array T.iter = Array.iter\n end\n\nclass ['acc] fold =\n let any _ acc = acc in\n object\n method int : (int, 'acc) T.fold = any\n method string : (string, 'acc) T.fold = any\n method bool : (bool, 'acc) T.fold = any\n method char : (char, 'acc) T.fold = any\n\n method option : 'a. ('a, 'acc) T.fold -> ('a option, 'acc) T.fold =\n fun f x acc -> match x with None -> acc | Some x -> f x acc\n\n method list : 'a. ('a, 'acc) T.fold -> ('a list, 'acc) T.fold =\n let rec loop f l acc =\n match l with [] -> acc | x :: l -> loop f l (f x acc)\n in\n loop\n\n method array : 'a. ('a, 'acc) T.fold -> ('a array, 'acc) T.fold =\n fun f a acc ->\n let r = ref acc in\n for i = 0 to Array.length a - 1 do\n r := f (Array.unsafe_get a i) !r\n done;\n !r\n end\n\nclass ['acc] fold_map =\n let any x acc = (x, acc) in\n object\n method int : (int, 'acc) T.fold_map = any\n method string : (string, 'acc) T.fold_map = any\n method bool : (bool, 'acc) T.fold_map = any\n method char : (char, 'acc) T.fold_map = any\n\n method option : 'a. ('a, 'acc) T.fold_map -> ('a option, 'acc) T.fold_map =\n fun f x acc ->\n match x with\n | None -> (None, acc)\n | Some x ->\n let x, acc = f x acc in\n (Some x, acc)\n\n method list : 'a. ('a, 'acc) T.fold_map -> ('a list, 'acc) T.fold_map =\n let rec loop f l acc =\n match l with\n | [] -> ([], acc)\n | x :: l ->\n let x, acc = f x acc in\n let l, acc = loop f l acc in\n (x :: l, acc)\n in\n loop\n\n method array : 'a. ('a, 'acc) T.fold_map -> ('a array, 'acc) T.fold_map =\n fun f a acc ->\n let len = Array.length a in\n if len = 0 then (a, acc)\n else\n let x, acc = f (Array.unsafe_get a 0) acc in\n let a' = Array.make len x in\n let r = ref acc in\n for i = 1 to len - 1 do\n let x, acc = f (Array.unsafe_get a i) !r in\n Array.unsafe_set a' i x;\n r := acc\n done;\n (a', !r)\n end\n\nclass ['ctx] map_with_context =\n let any _ x = x in\n object\n method int : ('ctx, int) T.map_with_context = any\n method string : ('ctx, string) T.map_with_context = any\n method bool : ('ctx, bool) T.map_with_context = any\n method char : ('ctx, char) T.map_with_context = any\n\n method option\n : 'a.\n ('ctx, 'a) T.map_with_context -> ('ctx, 'a option) T.map_with_context\n =\n fun f ctx x -> match x with None -> None | Some x -> Some (f ctx x)\n\n method list\n : 'a.\n ('ctx, 'a) T.map_with_context -> ('ctx, 'a list) T.map_with_context =\n fun f ctx l -> List.map (f ctx) l\n\n method array\n : 'a.\n ('ctx, 'a) T.map_with_context -> ('ctx, 'a array) T.map_with_context =\n fun f ctx a -> Array.map (f ctx) a\n end\n\nclass virtual ['res] lift =\n object (self)\n method virtual other : 'a. ('a, 'res) T.lift\n method virtual int : (int, 'res) T.lift\n method virtual string : (string, 'res) T.lift\n method virtual bool : (bool, 'res) T.lift\n method virtual char : (char, 'res) T.lift\n method virtual array : 'a. ('a, 'res) T.lift -> ('a array, 'res) T.lift\n method virtual float : (float, 'res) T.lift\n method virtual int32 : (int32, 'res) T.lift\n method virtual int64 : (int64, 'res) T.lift\n method virtual nativeint : (nativeint, 'res) T.lift\n method virtual unit : (unit, 'res) T.lift\n method virtual record : (string * 'res) list -> 'res\n method virtual constr : string -> 'res list -> 'res\n method virtual tuple : 'res list -> 'res\n\n method option : 'a. ('a, 'res) T.lift -> ('a option, 'res) T.lift =\n fun f x ->\n match x with\n | None -> self#constr \"None\" []\n | Some x -> self#constr \"Some\" [ f x ]\n\n method list : 'a. ('a, 'res) T.lift -> ('a list, 'res) T.lift =\n fun f l ->\n match l with\n | [] -> self#constr \"[]\" []\n | x :: l -> self#constr \"::\" [ f x; self#list f l ]\n end\n\nclass type ['res] std_lifters =\n object\n method other : 'a. ('a, 'res) T.lift\n method int : (int, 'res) T.lift\n method string : (string, 'res) T.lift\n method bool : (bool, 'res) T.lift\n method char : (char, 'res) T.lift\n method array : 'a. ('a, 'res) T.lift -> ('a array, 'res) T.lift\n method record : (string * 'res) list -> 'res\n method constr : string -> 'res list -> 'res\n method tuple : 'res list -> 'res\n method float : (float, 'res) T.lift\n method int32 : (int32, 'res) T.lift\n method int64 : (int64, 'res) T.lift\n method nativeint : (nativeint, 'res) T.lift\n method unit : (unit, 'res) T.lift\n method option : 'a. ('a, 'res) T.lift -> ('a option, 'res) T.lift\n method list : 'a. ('a, 'res) T.lift -> ('a list, 'res) T.lift\n end\n","open! Import\n\nmodule T = struct\n type t = longident = Lident of string | Ldot of t * string | Lapply of t * t\n\n let compare : t -> t -> int = Poly.compare\n\n let is_normal_ident_char = function\n | 'A' .. 'Z' | 'a' .. 'z' | '0' .. '9' | '_' | '\\'' -> true\n | _ -> false\n\n let is_normal_ident = function\n | \"asr\" | \"land\" | \"lor\" | \"lsl\" | \"lsr\" | \"lxor\" | \"mod\" | \"or\" -> false\n | string -> String.for_all string ~f:is_normal_ident_char\n\n let short_name string =\n if is_normal_ident string then string else \"( \" ^ string ^ \" )\"\n\n let rec name = function\n | Lident s -> short_name s\n | Ldot (a, b) -> name a ^ \".\" ^ short_name b\n | Lapply (a, b) -> Printf.sprintf \"%s(%s)\" (name a) (name b)\n\n let sexp_of_t t = Sexp.Atom (name t)\nend\n\ninclude T\n\nlet rec flat accu = function\n | Lident s -> s :: accu\n | Ldot (lid, s) -> flat (s :: accu) lid\n | Lapply (_, _) -> invalid_arg \"Ppxlib.Longident.flatten\"\n\nlet flatten_exn lid = flat [] lid\n\nlet last_exn = function\n | Lident s -> s\n | Ldot (_, s) -> s\n | Lapply (_, _) -> invalid_arg \"Ppxlib.Longident.flatten\"\n\nlet unflatten ~init l = List.fold_left l ~init ~f:(fun acc s -> Ldot (acc, s))\n\n(* for cases without dotted operators (e.g. [parse \"A.B.C\"]) *)\nlet parse_simple s =\n match String.split_on_char s ~sep:'.' with\n | [] -> assert false\n | s :: l -> unflatten ~init:(Lident s) l\n\n(* handle [\"A.B.(+.+)\"] or [\"Vec.(.%.()<-)\"] *)\nlet parse s =\n let invalid () =\n invalid_arg (Printf.sprintf \"Ppxlib.Longident.parse: %S\" s)\n in\n match (String.index_opt s '(', String.rindex_opt s ')') with\n | None, None -> parse_simple s\n | None, _ | _, None -> invalid ()\n | Some l, Some r -> (\n if Int.(r <> String.length s - 1) then invalid ();\n let group =\n if Int.(r = l + 1) then \"()\"\n else String.trim (String.sub s ~pos:(l + 1) ~len:(r - l - 1))\n in\n if Int.(l = 0) then Lident group\n else if Char.(s.[l - 1] <> '.') then invalid ()\n else\n let before = String.sub s ~pos:0 ~len:(l - 1) in\n match String.split_on_char before ~sep:'.' with\n | [] -> assert false\n | s :: l -> Ldot (unflatten ~init:(Lident s) l, group))\n\nmodule Map = Map.Make (T)\nmodule Set = Set.Make (T)\n","open! Import\n\ntype t = {\n file_path : string;\n main_module_name : string;\n submodule_path : string loc list;\n value : string loc option;\n in_expr : bool;\n}\n\nlet top_level ~file_path =\n let main_module_name =\n file_path |> Caml.Filename.basename |> Caml.Filename.remove_extension\n |> String.capitalize_ascii\n in\n {\n file_path;\n main_module_name;\n submodule_path = [];\n value = None;\n in_expr = false;\n }\n\nlet file_path t = t.file_path\nlet main_module_name t = t.main_module_name\n\nlet submodule_path t =\n List.rev_map ~f:(fun located -> located.txt) t.submodule_path\n\nlet value t = Option.map ~f:(fun located -> located.txt) t.value\n\nlet fully_qualified_path t =\n let value = value t in\n let submodule_path =\n List.rev_map ~f:(fun located -> Some located.txt) t.submodule_path\n in\n let names = (Some t.main_module_name :: submodule_path) @ [ value ] in\n String.concat ~sep:\".\" @@ List.filter_opt names\n\nlet enter_expr t = { t with in_expr = true }\n\nlet enter_module ~loc module_name t =\n if t.in_expr then t\n else\n { t with submodule_path = { txt = module_name; loc } :: t.submodule_path }\n\nlet enter_value ~loc value_name t =\n if t.in_expr then t else { t with value = Some { txt = value_name; loc } }\n\nlet to_string_path t = String.concat ~sep:\".\" (t.file_path :: submodule_path t)\nlet with_string_path f ~loc ~path = f ~loc ~path:(to_string_path path);;\n\nlet module M = struct\n let a = \"lol\"\nend in\nM.a\n","open Import\nmodule L = Astlib.Location\n\ntype t = location = {\n loc_start : Lexing.position;\n loc_end : Lexing.position;\n loc_ghost : bool;\n}\n\nlet in_file name =\n let loc = { pos_fname = name; pos_lnum = 1; pos_bol = 0; pos_cnum = -1 } in\n { loc_start = loc; loc_end = loc; loc_ghost = true }\n\nlet set_filename loc fn =\n let loc_start = { loc.loc_start with pos_fname = fn } in\n let loc_end = { loc.loc_end with pos_fname = fn } in\n { loc with loc_start; loc_end }\n\nlet none = in_file \"_none_\"\n\nlet init lexbuf fname =\n let open Lexing in\n lexbuf.lex_curr_p <-\n { pos_fname = fname; pos_lnum = 1; pos_bol = 0; pos_cnum = 0 }\n\nlet raise_errorf ?loc fmt = L.raise_errorf ?loc fmt\nlet report_exception = L.report_exception\n\nlet of_lexbuf (lexbuf : Lexing.lexbuf) =\n {\n loc_start = lexbuf.lex_start_p;\n loc_end = lexbuf.lex_curr_p;\n loc_ghost = false;\n }\n\nlet print ppf t =\n Caml.Format.fprintf ppf \"File \\\"%s\\\", line %d, characters %d-%d:\"\n t.loc_start.pos_fname t.loc_start.pos_lnum\n (t.loc_start.pos_cnum - t.loc_start.pos_bol)\n (t.loc_end.pos_cnum - t.loc_start.pos_bol)\n\ntype nonrec 'a loc = 'a loc = { txt : 'a; loc : t }\n\nlet compare_pos p1 p2 =\n let open Lexing in\n let column p =\n (* Manual extract:\n The difference between pos_cnum and pos_bol is the character offset\n within the line (i.e. the column number, assuming each character is\n one column wide). *)\n p.pos_cnum - p.pos_bol\n in\n match Int.compare p1.pos_lnum p2.pos_lnum with\n | 0 -> Int.compare (column p1) (column p2)\n | n -> n\n\nlet min_pos p1 p2 = if compare_pos p1 p2 <= 0 then p1 else p2\nlet max_pos p1 p2 = if compare_pos p1 p2 >= 0 then p1 else p2\n\nlet compare loc1 loc2 =\n match compare_pos loc1.loc_start loc2.loc_start with\n | 0 -> compare_pos loc1.loc_end loc2.loc_end\n | n -> n\n\nmodule Error = struct\n include Ppxlib_ast.Location_error\n\n let createf ~loc fmt = Format.kasprintf (fun str -> make ~loc ~sub:[] str) fmt\nend\n\nlet error_extensionf ~loc fmt =\n Format.kasprintf\n (fun str -> Error.to_extension @@ Error.make ~loc ~sub:[] str)\n fmt\n\nexception Error = L.Error\n\nlet () =\n Caml.Printexc.register_printer (function\n | Error e -> Some (Error.message e)\n | _ -> None)\n","open Import\n\ntype t = Astlib.Location.Error.t\n\nlet to_extension (error : Astlib.Location.Error.t) =\n let open Astlib.Location.Error in\n let open Ast_helper in\n if not (is_well_formed error) then\n raise (Invalid_argument \"to_extension: expected kind Report_error\");\n let sub_msgs = sub_msgs error in\n let main_msg = main_msg error in\n let err_extension_name loc = { Location.loc; txt = \"ocaml.error\" } in\n let mk_string_constant x = Str.eval (Exp.constant (Const.string x)) in\n let extension_of_sub_msg (sub_msg : string Location.loc) =\n Str.extension\n (err_extension_name sub_msg.loc, PStr [ mk_string_constant sub_msg.txt ])\n in\n ( err_extension_name main_msg.loc,\n Parsetree.PStr\n (mk_string_constant main_msg.txt :: List.map extension_of_sub_msg sub_msgs)\n )\n\nlet register_error_of_exn = Astlib.Location.register_error_of_exn\n\nlet message error =\n let { Astlib.Location.txt; _ } = Astlib.Location.Error.main_msg error in\n txt\n\nlet set_message = Astlib.Location.Error.set_main_msg\n\nlet make ~loc txt ~sub =\n let sub = List.map (fun (loc, txt) -> { Astlib.Location.loc; txt }) sub in\n Astlib.Location.Error.make ~sub { loc; txt }\n\nlet update_loc = Astlib.Location.Error.set_main_loc\n\nlet get_location error =\n let { Astlib.Location.loc; _ } = Astlib.Location.Error.main_msg error in\n loc\n\nlet of_exn = Astlib.Location.Error.of_exn\nlet raise error = raise (Astlib.Location.Error error)\n","module Base = struct\n type t = { tool_name : string; code_path : Code_path.t; input_name : string }\n\n let top_level ~tool_name ~file_path ~input_name =\n let code_path = Code_path.top_level ~file_path in\n { tool_name; code_path; input_name }\n\n let code_path t = t.code_path\n let input_name t = t.input_name\n let tool_name t = t.tool_name\n let enter_expr t = { t with code_path = Code_path.enter_expr t.code_path }\n\n let enter_module ~loc name t =\n { t with code_path = Code_path.enter_module ~loc name t.code_path }\n\n let enter_value ~loc name t =\n { t with code_path = Code_path.enter_value ~loc name t.code_path }\nend\n\nmodule Extension = struct\n type t = { extension_point_loc : Location.t; base : Base.t }\n\n let make ~extension_point_loc ~base () = { extension_point_loc; base }\n let extension_point_loc t = t.extension_point_loc\n let code_path t = t.base.code_path\n let input_name t = t.base.input_name\n let tool_name t = t.base.tool_name\n\n let with_loc_and_path f ~ctxt =\n f ~loc:ctxt.extension_point_loc\n ~path:(Code_path.to_string_path ctxt.base.code_path)\nend\n\nmodule Deriver = struct\n type t = { derived_item_loc : Location.t; inline : bool; base : Base.t }\n\n let make ~derived_item_loc ~inline ~base () =\n { derived_item_loc; base; inline }\n\n let derived_item_loc t = t.derived_item_loc\n let code_path t = t.base.code_path\n let input_name t = t.base.input_name\n let tool_name t = t.base.tool_name\n let inline t = t.inline\n\n let with_loc_and_path f ~ctxt =\n f ~loc:ctxt.derived_item_loc\n ~path:(Code_path.to_string_path ctxt.base.code_path)\nend\n","open! Import\n\nclass map =\n object\n inherit Ppxlib_traverse_builtins.map\n inherit Ast.map\n end\n\nclass iter =\n object\n inherit Ppxlib_traverse_builtins.iter\n inherit Ast.iter\n end\n\nclass ['acc] fold =\n object\n inherit ['acc] Ppxlib_traverse_builtins.fold\n inherit ['acc] Ast.fold\n end\n\nclass ['acc] fold_map =\n object\n inherit ['acc] Ppxlib_traverse_builtins.fold_map\n inherit ['acc] Ast.fold_map\n end\n\nclass ['ctx] map_with_context =\n object\n inherit ['ctx] Ppxlib_traverse_builtins.map_with_context\n inherit ['ctx] Ast.map_with_context\n end\n\nclass virtual ['res] lift =\n object\n inherit ['res] Ppxlib_traverse_builtins.lift\n inherit ['res] Ast.lift\n end\n\nlet module_name = function None -> \"_\" | Some name -> name\nlet enter name path = if String.is_empty path then name else path ^ \".\" ^ name\nlet enter_opt name_opt path = enter (module_name name_opt) path\n\nclass map_with_path =\n object\n inherit [string] map_with_context as super\n\n (* WAS:\n method! structure_item_desc path x =\n match x with\n | Pstr_module mb -> super#structure_item_desc (enter mb.pmb_name.txt path) x\n | _ -> super#structure_item_desc path x\n\n Overriding [module_binding] seems to be OK because it does not catch\n local module bindings because at the moment the parsetree doesn't make\n use of [module_binding] for local modules, but that might change in the\n future, so this might be something to keep in mind.\n\n The following:\n\n module A = struct .. end\n module A = struct .. end\n\n is disallowed, but\n\n let _ = .. let module A = struct .. end in ..\n module A = struct .. end\n let _ = .. let module A = struct .. end in ..\n\n isn't, and the \"path\" constructed here would be able to differentiate\n between them. *)\n method! module_binding path mb =\n super#module_binding (enter_opt mb.pmb_name.txt path) mb\n\n method! module_declaration path md =\n super#module_declaration (enter_opt md.pmd_name.txt path) md\n\n method! module_type_declaration path mtd =\n super#module_type_declaration (enter mtd.pmtd_name.txt path) mtd\n end\n\nlet var_names_of =\n object\n inherit [string list] fold as super\n\n method! pattern p acc =\n let acc = super#pattern p acc in\n match p.ppat_desc with Ppat_var { txt; _ } -> txt :: acc | _ -> acc\n end\n\nlet ec_enter_module_opt ~loc name_opt ctxt =\n Expansion_context.Base.enter_module ~loc (module_name name_opt) ctxt\n\nclass map_with_expansion_context =\n object (self)\n inherit [Expansion_context.Base.t] map_with_context as super\n\n method! expression ctxt expr =\n super#expression (Expansion_context.Base.enter_expr ctxt) expr\n\n method! module_binding ctxt mb =\n super#module_binding\n (ec_enter_module_opt ~loc:mb.pmb_loc mb.pmb_name.txt ctxt)\n mb\n\n method! module_declaration ctxt md =\n super#module_declaration\n (ec_enter_module_opt ~loc:md.pmd_loc md.pmd_name.txt ctxt)\n md\n\n method! module_type_declaration ctxt mtd =\n super#module_type_declaration\n (Expansion_context.Base.enter_module ~loc:mtd.pmtd_loc mtd.pmtd_name.txt\n ctxt)\n mtd\n\n method! value_description ctxt vd =\n super#value_description\n (Expansion_context.Base.enter_value ~loc:vd.pval_loc vd.pval_name.txt\n ctxt)\n vd\n\n method! value_binding ctxt { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } =\n let all_var_names = var_names_of#pattern pvb_pat [] in\n let var_name = Stdppx.List.last all_var_names in\n let in_binding_ctxt =\n match var_name with\n | None -> ctxt\n | Some var_name ->\n Expansion_context.Base.enter_value ~loc:pvb_loc var_name ctxt\n in\n let pvb_pat = self#pattern ctxt pvb_pat in\n let pvb_expr = self#expression in_binding_ctxt pvb_expr in\n let pvb_attributes = self#attributes in_binding_ctxt pvb_attributes in\n let pvb_loc = self#location ctxt pvb_loc in\n { pvb_pat; pvb_expr; pvb_attributes; pvb_loc }\n end\n\nclass sexp_of =\n object\n inherit [Sexp.t] Ast.lift\n method int = sexp_of_int\n method string = sexp_of_string\n method bool = sexp_of_bool\n method char = sexp_of_char\n method float = sexp_of_float\n method int32 = sexp_of_int32\n method int64 = sexp_of_int64\n method nativeint = sexp_of_nativeint\n method unit = sexp_of_unit\n method option = sexp_of_option\n method list = sexp_of_list\n method array : 'a. ('a -> Sexp.t) -> 'a array -> Sexp.t = sexp_of_array\n method other : 'a. 'a -> Sexp.t = fun _ -> Sexp.Atom \"_\"\n\n method record fields =\n List\n (List.map fields ~f:(fun (label, sexp) ->\n Sexp.List [ Atom label; sexp ]))\n\n method constr tag args =\n match args with [] -> Atom tag | _ -> List (Atom tag :: args)\n\n method tuple l = List l\n end\n\nlet sexp_of = new sexp_of\n","open! Import\n\nexception Cutoff_met\n\n(* As found here http://rosettacode.org/wiki/Levenshtein_distance#OCaml *)\nlet levenshtein_distance s t cutoff =\n let m = String.length s and n = String.length t in\n if cutoff = 0 || abs (m - n) >= cutoff then None\n else\n (* for all i and j, d.(i).(j) will hold the Levenshtein distance between the\n first i characters of s and the first j characters of t *)\n let d = Array.make_matrix ~dimx:(m + 1) ~dimy:(n + 1) 0 in\n for i = 0 to m do\n (* the distance of any first string to an empty second string *)\n d.(i).(0) <- i\n done;\n for j = 0 to n do\n (* the distance of any second string to an empty first string *)\n d.(0).(j) <- j\n done;\n (* the minimum of each line together with the column index will be used\n to notice cutoff exceeding and return early in that case *)\n let line_min = ref 0 in\n let distance =\n try\n for j = 1 to n do\n if !line_min >= cutoff - 1 && j >= cutoff - 1 then raise Cutoff_met;\n line_min := max m n;\n for i = 1 to m do\n let value =\n if Char.equal s.[i - 1] t.[j - 1] then d.(i - 1).(j - 1)\n (* no operation required *)\n else\n min\n (d.(i - 1).(j) + 1) (* a deletion *)\n (min\n (d.(i).(j - 1) + 1) (* an insertion *)\n (d.(i - 1).(j - 1) + 1) (* a substitution *))\n in\n d.(i).(j) <- value;\n line_min := min !line_min value\n done\n done;\n if d.(m).(n) < cutoff then Some d.(m).(n) else None\n with Cutoff_met -> None\n in\n distance\n\nlet spellcheck names name =\n let cutoff =\n match String.length name with\n | 1 | 2 -> 0\n | 3 | 4 -> 1\n | 5 | 6 -> 2\n | _ -> 3\n in\n let _, suggestions =\n List.fold_left names ~init:(Int.max_int, [])\n ~f:(fun ((best_distance, names_at_best_distance) as acc) registered_name\n ->\n match levenshtein_distance name registered_name cutoff with\n | None -> acc\n | Some dist ->\n if dist < best_distance then (dist, [ registered_name ])\n else if dist > best_distance then acc\n else (dist, registered_name :: names_at_best_distance))\n in\n match List.rev suggestions |> List.filter ~f:(String.( <> ) name) with\n | [] -> None\n | last :: rev_rest ->\n Some\n (Printf.sprintf \"Hint: Did you mean %s%s%s?\"\n (String.concat ~sep:\", \" (List.rev rev_rest))\n (if List.is_empty rev_rest then \"\" else \" or \")\n last)\n","open! Import\n\nexception Expected of Location.t * string\n\nlet fail loc expected = raise (Expected (loc, expected))\n\ntype context = {\n (* [matched] counts how many constructors have been matched. This is used to find what\n pattern matches the most some piece of ast in [Ast_pattern.alt]. In the case where\n all branches fail to match, we report the error from the one that matches the\n most.\n\n This is only incremented by combinators that can fail. *)\n mutable matched : int;\n}\n\ntype ('matched_value, 'k, 'k_result) t =\n | T of (context -> Location.t -> 'matched_value -> 'k -> 'k_result)\n","open Import\nmodule M =\n struct\n let attribute ~loc ~name ~payload =\n { attr_name = name; attr_payload = payload; attr_loc = loc }\n let binding_op ~loc ~op ~pat ~exp =\n { pbop_op = op; pbop_pat = pat; pbop_exp = exp; pbop_loc = loc }\n let case ~lhs ~guard ~rhs =\n { pc_lhs = lhs; pc_guard = guard; pc_rhs = rhs }\n let pcl_constr ~loc x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_constr (x0, x1))\n }\n let pcl_structure ~loc x0 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_structure x0) }\n let pcl_fun ~loc x0 x1 x2 x3 =\n {\n pcl_attributes = [];\n pcl_loc = loc;\n pcl_desc = (Pcl_fun (x0, x1, x2, x3))\n }\n let pcl_apply ~loc x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_apply (x0, x1)) }\n let pcl_let ~loc x0 x1 x2 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_let (x0, x1, x2))\n }\n let pcl_constraint ~loc x0 x1 =\n {\n pcl_attributes = [];\n pcl_loc = loc;\n pcl_desc = (Pcl_constraint (x0, x1))\n }\n let pcl_extension ~loc x0 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_extension x0) }\n let pcl_open ~loc x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_open (x0, x1)) }\n let pcf_inherit ~loc x0 x1 x2 =\n {\n pcf_attributes = [];\n pcf_loc = loc;\n pcf_desc = (Pcf_inherit (x0, x1, x2))\n }\n let pcf_val ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_val x0) }\n let pcf_method ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_method x0) }\n let pcf_constraint ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_constraint x0) }\n let pcf_initializer ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_initializer x0) }\n let pcf_attribute ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_attribute x0) }\n let pcf_extension ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_extension x0) }\n let class_infos ~loc ~virt ~params ~name ~expr =\n {\n pci_virt = virt;\n pci_params = params;\n pci_name = name;\n pci_expr = expr;\n pci_loc = loc;\n pci_attributes = []\n }\n let class_signature ~self ~fields =\n { pcsig_self = self; pcsig_fields = fields }\n let class_structure ~self ~fields =\n { pcstr_self = self; pcstr_fields = fields }\n let pcty_constr ~loc x0 x1 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_constr (x0, x1))\n }\n let pcty_signature ~loc x0 =\n { pcty_attributes = []; pcty_loc = loc; pcty_desc = (Pcty_signature x0)\n }\n let pcty_arrow ~loc x0 x1 x2 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_arrow (x0, x1, x2))\n }\n let pcty_extension ~loc x0 =\n { pcty_attributes = []; pcty_loc = loc; pcty_desc = (Pcty_extension x0)\n }\n let pcty_open ~loc x0 x1 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_open (x0, x1))\n }\n let pctf_inherit ~loc x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_inherit x0) }\n let pctf_val ~loc x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_val x0) }\n let pctf_method ~loc x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_method x0) }\n let pctf_constraint ~loc x0 =\n {\n pctf_attributes = [];\n pctf_loc = loc;\n pctf_desc = (Pctf_constraint x0)\n }\n let pctf_attribute ~loc x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_attribute x0)\n }\n let pctf_extension ~loc x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_extension x0)\n }\n let constructor_declaration ~loc ~name ~args ~res =\n {\n pcd_name = name;\n pcd_args = args;\n pcd_res = res;\n pcd_loc = loc;\n pcd_attributes = []\n }\n let ptyp_any ~loc =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = Ptyp_any\n }\n let ptyp_var ~loc x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_var x0)\n }\n let ptyp_arrow ~loc x0 x1 x2 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_arrow (x0, x1, x2))\n }\n let ptyp_tuple ~loc x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_tuple x0)\n }\n let ptyp_constr ~loc x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_constr (x0, x1))\n }\n let ptyp_object ~loc x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_object (x0, x1))\n }\n let ptyp_class ~loc x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_class (x0, x1))\n }\n let ptyp_alias ~loc x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_alias (x0, x1))\n }\n let ptyp_variant ~loc x0 x1 x2 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_variant (x0, x1, x2))\n }\n let ptyp_poly ~loc x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_poly (x0, x1))\n }\n let ptyp_package ~loc x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_package x0)\n }\n let ptyp_extension ~loc x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_extension x0)\n }\n let pdir_string ~loc x0 =\n { pdira_loc = loc; pdira_desc = (Pdir_string x0) }\n let pdir_int ~loc x0 x1 =\n { pdira_loc = loc; pdira_desc = (Pdir_int (x0, x1)) }\n let pdir_ident ~loc x0 =\n { pdira_loc = loc; pdira_desc = (Pdir_ident x0) }\n let pdir_bool ~loc x0 = { pdira_loc = loc; pdira_desc = (Pdir_bool x0) }\n let pexp_ident ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_ident x0)\n }\n let pexp_constant ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_constant x0)\n }\n let pexp_let ~loc x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_let (x0, x1, x2))\n }\n let pexp_function ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_function x0)\n }\n let pexp_fun ~loc x0 x1 x2 x3 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_fun (x0, x1, x2, x3))\n }\n let pexp_apply ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_apply (x0, x1))\n }\n let pexp_match ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_match (x0, x1))\n }\n let pexp_try ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_try (x0, x1))\n }\n let pexp_tuple ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_tuple x0)\n }\n let pexp_construct ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_construct (x0, x1))\n }\n let pexp_variant ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_variant (x0, x1))\n }\n let pexp_record ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_record (x0, x1))\n }\n let pexp_field ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_field (x0, x1))\n }\n let pexp_setfield ~loc x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_setfield (x0, x1, x2))\n }\n let pexp_array ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_array x0)\n }\n let pexp_ifthenelse ~loc x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_ifthenelse (x0, x1, x2))\n }\n let pexp_sequence ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_sequence (x0, x1))\n }\n let pexp_while ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_while (x0, x1))\n }\n let pexp_for ~loc x0 x1 x2 x3 x4 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_for (x0, x1, x2, x3, x4))\n }\n let pexp_constraint ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_constraint (x0, x1))\n }\n let pexp_coerce ~loc x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_coerce (x0, x1, x2))\n }\n let pexp_send ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_send (x0, x1))\n }\n let pexp_new ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_new x0)\n }\n let pexp_setinstvar ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_setinstvar (x0, x1))\n }\n let pexp_override ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_override x0)\n }\n let pexp_letmodule ~loc x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letmodule (x0, x1, x2))\n }\n let pexp_letexception ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letexception (x0, x1))\n }\n let pexp_assert ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_assert x0)\n }\n let pexp_lazy ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_lazy x0)\n }\n let pexp_poly ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_poly (x0, x1))\n }\n let pexp_object ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_object x0)\n }\n let pexp_newtype ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_newtype (x0, x1))\n }\n let pexp_pack ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_pack x0)\n }\n let pexp_open ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_open (x0, x1))\n }\n let pexp_letop ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letop x0)\n }\n let pexp_extension ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_extension x0)\n }\n let pexp_unreachable ~loc =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = Pexp_unreachable\n }\n let extension_constructor ~loc ~name ~kind =\n {\n pext_name = name;\n pext_kind = kind;\n pext_loc = loc;\n pext_attributes = []\n }\n let include_infos ~loc mod_ =\n { pincl_mod = mod_; pincl_loc = loc; pincl_attributes = [] }\n let label_declaration ~loc ~name ~mutable_ ~type_ =\n {\n pld_name = name;\n pld_mutable = mutable_;\n pld_type = type_;\n pld_loc = loc;\n pld_attributes = []\n }\n let letop ~let_ ~ands ~body = { let_; ands; body }\n let location ~start ~end_ ~ghost =\n { loc_start = start; loc_end = end_; loc_ghost = ghost }\n let module_binding ~loc ~name ~expr =\n { pmb_name = name; pmb_expr = expr; pmb_attributes = []; pmb_loc = loc\n }\n let module_declaration ~loc ~name ~type_ =\n { pmd_name = name; pmd_type = type_; pmd_attributes = []; pmd_loc = loc\n }\n let pmod_ident ~loc x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_ident x0) }\n let pmod_structure ~loc x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_structure x0)\n }\n let pmod_functor ~loc x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_functor (x0, x1))\n }\n let pmod_apply ~loc x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_apply (x0, x1))\n }\n let pmod_constraint ~loc x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_constraint (x0, x1))\n }\n let pmod_unpack ~loc x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_unpack x0) }\n let pmod_extension ~loc x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_extension x0)\n }\n let module_substitution ~loc ~name ~manifest =\n {\n pms_name = name;\n pms_manifest = manifest;\n pms_attributes = [];\n pms_loc = loc\n }\n let pmty_ident ~loc x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_ident x0) }\n let pmty_signature ~loc x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_signature x0)\n }\n let pmty_functor ~loc x0 x1 =\n {\n pmty_attributes = [];\n pmty_loc = loc;\n pmty_desc = (Pmty_functor (x0, x1))\n }\n let pmty_with ~loc x0 x1 =\n {\n pmty_attributes = [];\n pmty_loc = loc;\n pmty_desc = (Pmty_with (x0, x1))\n }\n let pmty_typeof ~loc x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_typeof x0) }\n let pmty_extension ~loc x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_extension x0)\n }\n let pmty_alias ~loc x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_alias x0) }\n let module_type_declaration ~loc ~name ~type_ =\n {\n pmtd_name = name;\n pmtd_type = type_;\n pmtd_attributes = [];\n pmtd_loc = loc\n }\n let otag ~loc x0 x1 =\n { pof_attributes = []; pof_loc = loc; pof_desc = (Otag (x0, x1)) }\n let oinherit ~loc x0 =\n { pof_attributes = []; pof_loc = loc; pof_desc = (Oinherit x0) }\n let open_infos ~loc ~expr ~override =\n {\n popen_expr = expr;\n popen_override = override;\n popen_loc = loc;\n popen_attributes = []\n }\n let ppat_any ~loc =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = Ppat_any\n }\n let ppat_var ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_var x0)\n }\n let ppat_alias ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_alias (x0, x1))\n }\n let ppat_constant ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_constant x0)\n }\n let ppat_interval ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_interval (x0, x1))\n }\n let ppat_tuple ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_tuple x0)\n }\n let ppat_construct ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_construct (x0, x1))\n }\n let ppat_variant ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_variant (x0, x1))\n }\n let ppat_record ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_record (x0, x1))\n }\n let ppat_array ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_array x0)\n }\n let ppat_or ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_or (x0, x1))\n }\n let ppat_constraint ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_constraint (x0, x1))\n }\n let ppat_type ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_type x0)\n }\n let ppat_lazy ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_lazy x0)\n }\n let ppat_unpack ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_unpack x0)\n }\n let ppat_exception ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_exception x0)\n }\n let ppat_extension ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_extension x0)\n }\n let ppat_open ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_open (x0, x1))\n }\n let position ~fname ~lnum ~bol ~cnum =\n { pos_fname = fname; pos_lnum = lnum; pos_bol = bol; pos_cnum = cnum }\n let rtag ~loc x0 x1 x2 =\n { prf_attributes = []; prf_loc = loc; prf_desc = (Rtag (x0, x1, x2)) }\n let rinherit ~loc x0 =\n { prf_attributes = []; prf_loc = loc; prf_desc = (Rinherit x0) }\n let psig_value ~loc x0 = { psig_loc = loc; psig_desc = (Psig_value x0) }\n let psig_type ~loc x0 x1 =\n { psig_loc = loc; psig_desc = (Psig_type (x0, x1)) }\n let psig_typesubst ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_typesubst x0) }\n let psig_typext ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_typext x0) }\n let psig_exception ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_exception x0) }\n let psig_module ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_module x0) }\n let psig_modsubst ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_modsubst x0) }\n let psig_recmodule ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_recmodule x0) }\n let psig_modtype ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_modtype x0) }\n let psig_open ~loc x0 = { psig_loc = loc; psig_desc = (Psig_open x0) }\n let psig_include ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_include x0) }\n let psig_class ~loc x0 = { psig_loc = loc; psig_desc = (Psig_class x0) }\n let psig_class_type ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_class_type x0) }\n let psig_attribute ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_attribute x0) }\n let psig_extension ~loc x0 x1 =\n { psig_loc = loc; psig_desc = (Psig_extension (x0, x1)) }\n let pstr_eval ~loc x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_eval (x0, x1)) }\n let pstr_value ~loc x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_value (x0, x1)) }\n let pstr_primitive ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_primitive x0) }\n let pstr_type ~loc x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_type (x0, x1)) }\n let pstr_typext ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_typext x0) }\n let pstr_exception ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_exception x0) }\n let pstr_module ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_module x0) }\n let pstr_recmodule ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_recmodule x0) }\n let pstr_modtype ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_modtype x0) }\n let pstr_open ~loc x0 = { pstr_loc = loc; pstr_desc = (Pstr_open x0) }\n let pstr_class ~loc x0 = { pstr_loc = loc; pstr_desc = (Pstr_class x0) }\n let pstr_class_type ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_class_type x0) }\n let pstr_include ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_include x0) }\n let pstr_attribute ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_attribute x0) }\n let pstr_extension ~loc x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_extension (x0, x1)) }\n let toplevel_directive ~loc ~name ~arg =\n { pdir_name = name; pdir_arg = arg; pdir_loc = loc }\n let type_declaration ~loc ~name ~params ~cstrs ~kind ~private_ \n ~manifest =\n {\n ptype_name = name;\n ptype_params = params;\n ptype_cstrs = cstrs;\n ptype_kind = kind;\n ptype_private = private_;\n ptype_manifest = manifest;\n ptype_attributes = [];\n ptype_loc = loc\n }\n let type_exception ~loc constructor =\n {\n ptyexn_constructor = constructor;\n ptyexn_loc = loc;\n ptyexn_attributes = []\n }\n let type_extension ~loc ~path ~params ~constructors ~private_ =\n {\n ptyext_path = path;\n ptyext_params = params;\n ptyext_constructors = constructors;\n ptyext_private = private_;\n ptyext_loc = loc;\n ptyext_attributes = []\n }\n let value_binding ~loc ~pat ~expr =\n { pvb_pat = pat; pvb_expr = expr; pvb_attributes = []; pvb_loc = loc }\n let value_description ~loc ~name ~type_ ~prim =\n {\n pval_name = name;\n pval_type = type_;\n pval_prim = prim;\n pval_attributes = [];\n pval_loc = loc\n }\n end\nmodule Make(Loc:sig val loc : Location.t end) =\n struct\n let loc = Loc.loc\n let attribute ~name ~payload =\n { attr_name = name; attr_payload = payload; attr_loc = loc }\n let binding_op ~op ~pat ~exp =\n { pbop_op = op; pbop_pat = pat; pbop_exp = exp; pbop_loc = loc }\n let case ~lhs ~guard ~rhs =\n { pc_lhs = lhs; pc_guard = guard; pc_rhs = rhs }\n let pcl_constr x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_constr (x0, x1))\n }\n let pcl_structure x0 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_structure x0) }\n let pcl_fun x0 x1 x2 x3 =\n {\n pcl_attributes = [];\n pcl_loc = loc;\n pcl_desc = (Pcl_fun (x0, x1, x2, x3))\n }\n let pcl_apply x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_apply (x0, x1)) }\n let pcl_let x0 x1 x2 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_let (x0, x1, x2))\n }\n let pcl_constraint x0 x1 =\n {\n pcl_attributes = [];\n pcl_loc = loc;\n pcl_desc = (Pcl_constraint (x0, x1))\n }\n let pcl_extension x0 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_extension x0) }\n let pcl_open x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_open (x0, x1)) }\n let pcf_inherit x0 x1 x2 =\n {\n pcf_attributes = [];\n pcf_loc = loc;\n pcf_desc = (Pcf_inherit (x0, x1, x2))\n }\n let pcf_val x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_val x0) }\n let pcf_method x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_method x0) }\n let pcf_constraint x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_constraint x0) }\n let pcf_initializer x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_initializer x0) }\n let pcf_attribute x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_attribute x0) }\n let pcf_extension x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_extension x0) }\n let class_infos ~virt ~params ~name ~expr =\n {\n pci_virt = virt;\n pci_params = params;\n pci_name = name;\n pci_expr = expr;\n pci_loc = loc;\n pci_attributes = []\n }\n let class_signature ~self ~fields =\n { pcsig_self = self; pcsig_fields = fields }\n let class_structure ~self ~fields =\n { pcstr_self = self; pcstr_fields = fields }\n let pcty_constr x0 x1 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_constr (x0, x1))\n }\n let pcty_signature x0 =\n { pcty_attributes = []; pcty_loc = loc; pcty_desc = (Pcty_signature x0)\n }\n let pcty_arrow x0 x1 x2 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_arrow (x0, x1, x2))\n }\n let pcty_extension x0 =\n { pcty_attributes = []; pcty_loc = loc; pcty_desc = (Pcty_extension x0)\n }\n let pcty_open x0 x1 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_open (x0, x1))\n }\n let pctf_inherit x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_inherit x0) }\n let pctf_val x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_val x0) }\n let pctf_method x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_method x0) }\n let pctf_constraint x0 =\n {\n pctf_attributes = [];\n pctf_loc = loc;\n pctf_desc = (Pctf_constraint x0)\n }\n let pctf_attribute x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_attribute x0)\n }\n let pctf_extension x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_extension x0)\n }\n let constructor_declaration ~name ~args ~res =\n {\n pcd_name = name;\n pcd_args = args;\n pcd_res = res;\n pcd_loc = loc;\n pcd_attributes = []\n }\n let ptyp_any =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = Ptyp_any\n }\n let ptyp_var x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_var x0)\n }\n let ptyp_arrow x0 x1 x2 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_arrow (x0, x1, x2))\n }\n let ptyp_tuple x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_tuple x0)\n }\n let ptyp_constr x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_constr (x0, x1))\n }\n let ptyp_object x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_object (x0, x1))\n }\n let ptyp_class x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_class (x0, x1))\n }\n let ptyp_alias x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_alias (x0, x1))\n }\n let ptyp_variant x0 x1 x2 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_variant (x0, x1, x2))\n }\n let ptyp_poly x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_poly (x0, x1))\n }\n let ptyp_package x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_package x0)\n }\n let ptyp_extension x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_extension x0)\n }\n let pdir_string x0 = { pdira_loc = loc; pdira_desc = (Pdir_string x0) }\n let pdir_int x0 x1 =\n { pdira_loc = loc; pdira_desc = (Pdir_int (x0, x1)) }\n let pdir_ident x0 = { pdira_loc = loc; pdira_desc = (Pdir_ident x0) }\n let pdir_bool x0 = { pdira_loc = loc; pdira_desc = (Pdir_bool x0) }\n let pexp_ident x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_ident x0)\n }\n let pexp_constant x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_constant x0)\n }\n let pexp_let x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_let (x0, x1, x2))\n }\n let pexp_function x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_function x0)\n }\n let pexp_fun x0 x1 x2 x3 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_fun (x0, x1, x2, x3))\n }\n let pexp_apply x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_apply (x0, x1))\n }\n let pexp_match x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_match (x0, x1))\n }\n let pexp_try x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_try (x0, x1))\n }\n let pexp_tuple x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_tuple x0)\n }\n let pexp_construct x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_construct (x0, x1))\n }\n let pexp_variant x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_variant (x0, x1))\n }\n let pexp_record x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_record (x0, x1))\n }\n let pexp_field x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_field (x0, x1))\n }\n let pexp_setfield x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_setfield (x0, x1, x2))\n }\n let pexp_array x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_array x0)\n }\n let pexp_ifthenelse x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_ifthenelse (x0, x1, x2))\n }\n let pexp_sequence x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_sequence (x0, x1))\n }\n let pexp_while x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_while (x0, x1))\n }\n let pexp_for x0 x1 x2 x3 x4 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_for (x0, x1, x2, x3, x4))\n }\n let pexp_constraint x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_constraint (x0, x1))\n }\n let pexp_coerce x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_coerce (x0, x1, x2))\n }\n let pexp_send x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_send (x0, x1))\n }\n let pexp_new x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_new x0)\n }\n let pexp_setinstvar x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_setinstvar (x0, x1))\n }\n let pexp_override x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_override x0)\n }\n let pexp_letmodule x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letmodule (x0, x1, x2))\n }\n let pexp_letexception x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letexception (x0, x1))\n }\n let pexp_assert x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_assert x0)\n }\n let pexp_lazy x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_lazy x0)\n }\n let pexp_poly x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_poly (x0, x1))\n }\n let pexp_object x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_object x0)\n }\n let pexp_newtype x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_newtype (x0, x1))\n }\n let pexp_pack x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_pack x0)\n }\n let pexp_open x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_open (x0, x1))\n }\n let pexp_letop x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letop x0)\n }\n let pexp_extension x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_extension x0)\n }\n let pexp_unreachable =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = Pexp_unreachable\n }\n let extension_constructor ~name ~kind =\n {\n pext_name = name;\n pext_kind = kind;\n pext_loc = loc;\n pext_attributes = []\n }\n let include_infos mod_ =\n { pincl_mod = mod_; pincl_loc = loc; pincl_attributes = [] }\n let label_declaration ~name ~mutable_ ~type_ =\n {\n pld_name = name;\n pld_mutable = mutable_;\n pld_type = type_;\n pld_loc = loc;\n pld_attributes = []\n }\n let letop ~let_ ~ands ~body = { let_; ands; body }\n let location ~start ~end_ ~ghost =\n { loc_start = start; loc_end = end_; loc_ghost = ghost }\n let module_binding ~name ~expr =\n { pmb_name = name; pmb_expr = expr; pmb_attributes = []; pmb_loc = loc\n }\n let module_declaration ~name ~type_ =\n { pmd_name = name; pmd_type = type_; pmd_attributes = []; pmd_loc = loc\n }\n let pmod_ident x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_ident x0) }\n let pmod_structure x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_structure x0)\n }\n let pmod_functor x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_functor (x0, x1))\n }\n let pmod_apply x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_apply (x0, x1))\n }\n let pmod_constraint x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_constraint (x0, x1))\n }\n let pmod_unpack x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_unpack x0) }\n let pmod_extension x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_extension x0)\n }\n let module_substitution ~name ~manifest =\n {\n pms_name = name;\n pms_manifest = manifest;\n pms_attributes = [];\n pms_loc = loc\n }\n let pmty_ident x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_ident x0) }\n let pmty_signature x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_signature x0)\n }\n let pmty_functor x0 x1 =\n {\n pmty_attributes = [];\n pmty_loc = loc;\n pmty_desc = (Pmty_functor (x0, x1))\n }\n let pmty_with x0 x1 =\n {\n pmty_attributes = [];\n pmty_loc = loc;\n pmty_desc = (Pmty_with (x0, x1))\n }\n let pmty_typeof x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_typeof x0) }\n let pmty_extension x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_extension x0)\n }\n let pmty_alias x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_alias x0) }\n let module_type_declaration ~name ~type_ =\n {\n pmtd_name = name;\n pmtd_type = type_;\n pmtd_attributes = [];\n pmtd_loc = loc\n }\n let otag x0 x1 =\n { pof_attributes = []; pof_loc = loc; pof_desc = (Otag (x0, x1)) }\n let oinherit x0 =\n { pof_attributes = []; pof_loc = loc; pof_desc = (Oinherit x0) }\n let open_infos ~expr ~override =\n {\n popen_expr = expr;\n popen_override = override;\n popen_loc = loc;\n popen_attributes = []\n }\n let ppat_any =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = Ppat_any\n }\n let ppat_var x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_var x0)\n }\n let ppat_alias x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_alias (x0, x1))\n }\n let ppat_constant x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_constant x0)\n }\n let ppat_interval x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_interval (x0, x1))\n }\n let ppat_tuple x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_tuple x0)\n }\n let ppat_construct x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_construct (x0, x1))\n }\n let ppat_variant x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_variant (x0, x1))\n }\n let ppat_record x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_record (x0, x1))\n }\n let ppat_array x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_array x0)\n }\n let ppat_or x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_or (x0, x1))\n }\n let ppat_constraint x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_constraint (x0, x1))\n }\n let ppat_type x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_type x0)\n }\n let ppat_lazy x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_lazy x0)\n }\n let ppat_unpack x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_unpack x0)\n }\n let ppat_exception x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_exception x0)\n }\n let ppat_extension x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_extension x0)\n }\n let ppat_open x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_open (x0, x1))\n }\n let position ~fname ~lnum ~bol ~cnum =\n { pos_fname = fname; pos_lnum = lnum; pos_bol = bol; pos_cnum = cnum }\n let rtag x0 x1 x2 =\n { prf_attributes = []; prf_loc = loc; prf_desc = (Rtag (x0, x1, x2)) }\n let rinherit x0 =\n { prf_attributes = []; prf_loc = loc; prf_desc = (Rinherit x0) }\n let psig_value x0 = { psig_loc = loc; psig_desc = (Psig_value x0) }\n let psig_type x0 x1 =\n { psig_loc = loc; psig_desc = (Psig_type (x0, x1)) }\n let psig_typesubst x0 =\n { psig_loc = loc; psig_desc = (Psig_typesubst x0) }\n let psig_typext x0 = { psig_loc = loc; psig_desc = (Psig_typext x0) }\n let psig_exception x0 =\n { psig_loc = loc; psig_desc = (Psig_exception x0) }\n let psig_module x0 = { psig_loc = loc; psig_desc = (Psig_module x0) }\n let psig_modsubst x0 = { psig_loc = loc; psig_desc = (Psig_modsubst x0) }\n let psig_recmodule x0 =\n { psig_loc = loc; psig_desc = (Psig_recmodule x0) }\n let psig_modtype x0 = { psig_loc = loc; psig_desc = (Psig_modtype x0) }\n let psig_open x0 = { psig_loc = loc; psig_desc = (Psig_open x0) }\n let psig_include x0 = { psig_loc = loc; psig_desc = (Psig_include x0) }\n let psig_class x0 = { psig_loc = loc; psig_desc = (Psig_class x0) }\n let psig_class_type x0 =\n { psig_loc = loc; psig_desc = (Psig_class_type x0) }\n let psig_attribute x0 =\n { psig_loc = loc; psig_desc = (Psig_attribute x0) }\n let psig_extension x0 x1 =\n { psig_loc = loc; psig_desc = (Psig_extension (x0, x1)) }\n let pstr_eval x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_eval (x0, x1)) }\n let pstr_value x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_value (x0, x1)) }\n let pstr_primitive x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_primitive x0) }\n let pstr_type x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_type (x0, x1)) }\n let pstr_typext x0 = { pstr_loc = loc; pstr_desc = (Pstr_typext x0) }\n let pstr_exception x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_exception x0) }\n let pstr_module x0 = { pstr_loc = loc; pstr_desc = (Pstr_module x0) }\n let pstr_recmodule x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_recmodule x0) }\n let pstr_modtype x0 = { pstr_loc = loc; pstr_desc = (Pstr_modtype x0) }\n let pstr_open x0 = { pstr_loc = loc; pstr_desc = (Pstr_open x0) }\n let pstr_class x0 = { pstr_loc = loc; pstr_desc = (Pstr_class x0) }\n let pstr_class_type x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_class_type x0) }\n let pstr_include x0 = { pstr_loc = loc; pstr_desc = (Pstr_include x0) }\n let pstr_attribute x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_attribute x0) }\n let pstr_extension x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_extension (x0, x1)) }\n let toplevel_directive ~name ~arg =\n { pdir_name = name; pdir_arg = arg; pdir_loc = loc }\n let type_declaration ~name ~params ~cstrs ~kind ~private_ ~manifest \n =\n {\n ptype_name = name;\n ptype_params = params;\n ptype_cstrs = cstrs;\n ptype_kind = kind;\n ptype_private = private_;\n ptype_manifest = manifest;\n ptype_attributes = [];\n ptype_loc = loc\n }\n let type_exception constructor =\n {\n ptyexn_constructor = constructor;\n ptyexn_loc = loc;\n ptyexn_attributes = []\n }\n let type_extension ~path ~params ~constructors ~private_ =\n {\n ptyext_path = path;\n ptyext_params = params;\n ptyext_constructors = constructors;\n ptyext_private = private_;\n ptyext_loc = loc;\n ptyext_attributes = []\n }\n let value_binding ~pat ~expr =\n { pvb_pat = pat; pvb_expr = expr; pvb_attributes = []; pvb_loc = loc }\n let value_description ~name ~type_ ~prim =\n {\n pval_name = name;\n pval_type = type_;\n pval_prim = prim;\n pval_attributes = [];\n pval_loc = loc\n }\n end\n","open! Import\n\nmodule Default = struct\n module Located = struct\n type 'a t = 'a Loc.t\n\n let loc (x : _ t) = x.loc\n let mk ~loc x = { loc; txt = x }\n let map f t = { t with txt = f t.txt }\n let map_lident x = map (fun x -> Longident.Lident x) x\n let lident ~loc x = mk ~loc (Longident.parse x)\n end\n\n include Ast_builder_generated.M\n\n let pstr_value_list ~loc rec_flag = function\n | [] -> []\n | vbs -> [ pstr_value ~loc rec_flag vbs ]\n\n let nonrec_type_declaration ~loc:_ ~name:_ ~params:_ ~cstrs:_ ~kind:_\n ~private_:_ ~manifest:_ =\n failwith\n \"Ppxlib.Ast_builder.nonrec_type_declaration: don't use this function\"\n\n let eint ~loc t = pexp_constant ~loc (Pconst_integer (Int.to_string t, None))\n let echar ~loc t = pexp_constant ~loc (Pconst_char t)\n let estring ~loc t = pexp_constant ~loc (Pconst_string (t, loc, None))\n let efloat ~loc t = pexp_constant ~loc (Pconst_float (t, None))\n\n let eint32 ~loc t =\n pexp_constant ~loc (Pconst_integer (Int32.to_string t, Some 'l'))\n\n let eint64 ~loc t =\n pexp_constant ~loc (Pconst_integer (Int64.to_string t, Some 'L'))\n\n let enativeint ~loc t =\n pexp_constant ~loc (Pconst_integer (Nativeint.to_string t, Some 'n'))\n\n let pint ~loc t = ppat_constant ~loc (Pconst_integer (Int.to_string t, None))\n let pchar ~loc t = ppat_constant ~loc (Pconst_char t)\n let pstring ~loc t = ppat_constant ~loc (Pconst_string (t, loc, None))\n let pfloat ~loc t = ppat_constant ~loc (Pconst_float (t, None))\n\n let pint32 ~loc t =\n ppat_constant ~loc (Pconst_integer (Int32.to_string t, Some 'l'))\n\n let pint64 ~loc t =\n ppat_constant ~loc (Pconst_integer (Int64.to_string t, Some 'L'))\n\n let pnativeint ~loc t =\n ppat_constant ~loc (Pconst_integer (Nativeint.to_string t, Some 'n'))\n\n let ebool ~loc t =\n pexp_construct ~loc (Located.lident ~loc (Bool.to_string t)) None\n\n let pbool ~loc t =\n ppat_construct ~loc (Located.lident ~loc (Bool.to_string t)) None\n\n let evar ~loc v = pexp_ident ~loc (Located.mk ~loc (Longident.parse v))\n let pvar ~loc v = ppat_var ~loc (Located.mk ~loc v)\n let eunit ~loc = pexp_construct ~loc (Located.lident ~loc \"()\") None\n let punit ~loc = ppat_construct ~loc (Located.lident ~loc \"()\") None\n let pexp_tuple ~loc l = match l with [ x ] -> x | _ -> pexp_tuple ~loc l\n let ppat_tuple ~loc l = match l with [ x ] -> x | _ -> ppat_tuple ~loc l\n let ptyp_tuple ~loc l = match l with [ x ] -> x | _ -> ptyp_tuple ~loc l\n\n let pexp_tuple_opt ~loc l =\n match l with [] -> None | _ :: _ -> Some (pexp_tuple ~loc l)\n\n let ppat_tuple_opt ~loc l =\n match l with [] -> None | _ :: _ -> Some (ppat_tuple ~loc l)\n\n let ptyp_poly ~loc vars ty =\n match vars with [] -> ty | _ -> ptyp_poly ~loc vars ty\n\n let pexp_apply ~loc e el =\n match (e, el) with\n | _, [] -> e\n | { pexp_desc = Pexp_apply (e, args); pexp_attributes = []; _ }, _ ->\n { e with pexp_desc = Pexp_apply (e, args @ el) }\n | _ -> pexp_apply ~loc e el\n\n let eapply ~loc e el =\n pexp_apply ~loc e (List.map el ~f:(fun e -> (Asttypes.Nolabel, e)))\n\n let eabstract ~loc ps e =\n List.fold_right ps ~init:e ~f:(fun p e ->\n pexp_fun ~loc Asttypes.Nolabel None p e)\n\n let esequence ~loc el =\n match el with\n | [] -> eunit ~loc\n | hd :: tl ->\n List.fold_left tl ~init:hd ~f:(fun acc e -> pexp_sequence ~loc acc e)\n\n let pconstruct cd arg =\n ppat_construct ~loc:cd.pcd_loc (Located.map_lident cd.pcd_name) arg\n\n let econstruct cd arg =\n pexp_construct ~loc:cd.pcd_loc (Located.map_lident cd.pcd_name) arg\n\n let rec elist ~loc l =\n match l with\n | [] -> pexp_construct ~loc (Located.mk ~loc (Longident.Lident \"[]\")) None\n | x :: l ->\n pexp_construct ~loc\n (Located.mk ~loc (Longident.Lident \"::\"))\n (Some (pexp_tuple ~loc [ x; elist ~loc l ]))\n\n let rec plist ~loc l =\n match l with\n | [] -> ppat_construct ~loc (Located.mk ~loc (Longident.Lident \"[]\")) None\n | x :: l ->\n ppat_construct ~loc\n (Located.mk ~loc (Longident.Lident \"::\"))\n (Some (ppat_tuple ~loc [ x; plist ~loc l ]))\n\n let unapplied_type_constr_conv_without_apply ~loc (ident : Longident.t) ~f =\n match ident with\n | Lident n -> pexp_ident ~loc { txt = Lident (f n); loc }\n | Ldot (path, n) -> pexp_ident ~loc { txt = Ldot (path, f n); loc }\n | Lapply _ ->\n Location.raise_errorf ~loc \"unexpected applicative functor type\"\n\n let type_constr_conv ~loc:apply_loc { Loc.loc; txt = longident } ~f args =\n let loc = { loc with loc_ghost = true } in\n match (longident : Longident.t) with\n | Lident _ | Ldot ((Lident _ | Ldot _), _) | Lapply _ -> (\n let ident =\n unapplied_type_constr_conv_without_apply longident ~loc ~f\n in\n match args with\n | [] -> ident\n | _ :: _ -> eapply ~loc:apply_loc ident args)\n | Ldot ((Lapply _ as module_path), n) ->\n let suffix_n functor_ = String.uncapitalize_ascii functor_ ^ \"__\" ^ n in\n let rec gather_lapply functor_args : Longident.t -> Longident.t * _ =\n function\n | Lapply (rest, arg) -> gather_lapply (arg :: functor_args) rest\n | Lident functor_ -> (Lident (suffix_n functor_), functor_args)\n | Ldot (functor_path, functor_) ->\n (Ldot (functor_path, suffix_n functor_), functor_args)\n in\n let ident, functor_args = gather_lapply [] module_path in\n eapply ~loc:apply_loc\n (unapplied_type_constr_conv_without_apply ident ~loc ~f)\n (List.map functor_args ~f:(fun path ->\n pexp_pack ~loc (pmod_ident ~loc { txt = path; loc }))\n @ args)\n\n let unapplied_type_constr_conv ~loc longident ~f =\n type_constr_conv longident ~loc ~f []\n\n let eta_reduce =\n let rec gather_params acc expr =\n match expr with\n | {\n pexp_desc =\n Pexp_fun (label, None (* no default expression *), subpat, body);\n pexp_attributes = [];\n pexp_loc = _;\n pexp_loc_stack = _;\n } -> (\n match subpat with\n | {\n ppat_desc = Ppat_var name;\n ppat_attributes = [];\n ppat_loc = _;\n ppat_loc_stack = _;\n } ->\n gather_params ((label, name, None) :: acc) body\n | {\n ppat_desc =\n Ppat_constraint\n ( {\n ppat_desc = Ppat_var name;\n ppat_attributes = [];\n ppat_loc = _;\n ppat_loc_stack = _;\n },\n ty );\n ppat_attributes = [];\n ppat_loc = _;\n ppat_loc_stack = _;\n } ->\n (* We reduce [fun (x : ty) -> f x] by rewriting it [(f : ty -> _)]. *)\n gather_params ((label, name, Some ty) :: acc) body\n | _ -> (List.rev acc, expr))\n | _ -> (List.rev acc, expr)\n in\n let annotate ~loc expr params =\n if List.exists params ~f:(fun (_, _, ty) -> Option.is_some ty) then\n let ty =\n List.fold_right params ~init:(ptyp_any ~loc)\n ~f:(fun (param_label, param, ty_opt) acc ->\n let loc = param.loc in\n let ty =\n match ty_opt with None -> ptyp_any ~loc | Some ty -> ty\n in\n ptyp_arrow ~loc param_label ty acc)\n in\n pexp_constraint ~loc expr ty\n else expr\n in\n let rec gather_args n x =\n if n = 0 then Some (x, [])\n else\n match x with\n | {\n pexp_desc = Pexp_apply (body, args);\n pexp_attributes = [];\n pexp_loc = _;\n pexp_loc_stack = _;\n } ->\n if List.length args <= n then\n match gather_args (n - List.length args) body with\n | None -> None\n | Some (body, args') -> Some (body, args' @ args)\n else None\n | _ -> None\n in\n fun expr ->\n let params, body = gather_params [] expr in\n match gather_args (List.length params) body with\n | None -> None\n | Some (({ pexp_desc = Pexp_ident _; _ } as f_ident), args) -> (\n match\n List.for_all2 args params\n ~f:(fun (arg_label, arg) (param_label, param, _) ->\n Poly.( = ) (arg_label : arg_label) param_label\n &&\n match arg with\n | {\n pexp_desc = Pexp_ident { txt = Lident name'; _ };\n pexp_attributes = [];\n pexp_loc = _;\n pexp_loc_stack = _;\n } ->\n String.( = ) name' param.txt\n | _ -> false)\n with\n | false -> None\n | true -> Some (annotate ~loc:expr.pexp_loc f_ident params))\n | _ -> None\n\n let eta_reduce_if_possible expr = Option.value (eta_reduce expr) ~default:expr\n\n let eta_reduce_if_possible_and_nonrec expr ~rec_flag =\n match rec_flag with\n | Recursive -> expr\n | Nonrecursive -> eta_reduce_if_possible expr\nend\n\nmodule type Loc = Ast_builder_intf.Loc\nmodule type S = Ast_builder_intf.S\n\nmodule Make (Loc : sig\n val loc : Location.t\nend) : S = struct\n include Ast_builder_generated.Make (Loc)\n\n let pstr_value_list = Default.pstr_value_list\n\n let nonrec_type_declaration ~name ~params ~cstrs ~kind ~private_ ~manifest =\n Default.nonrec_type_declaration ~loc ~name ~params ~cstrs ~kind ~private_\n ~manifest\n\n module Located = struct\n include Default.Located\n\n let loc _ = Loc.loc\n let mk x = mk ~loc:Loc.loc x\n let lident x = lident ~loc:Loc.loc x\n end\n\n let pexp_tuple l = Default.pexp_tuple ~loc l\n let ppat_tuple l = Default.ppat_tuple ~loc l\n let ptyp_tuple l = Default.ptyp_tuple ~loc l\n let pexp_tuple_opt l = Default.pexp_tuple_opt ~loc l\n let ppat_tuple_opt l = Default.ppat_tuple_opt ~loc l\n let ptyp_poly vars ty = Default.ptyp_poly ~loc vars ty\n let pexp_apply e el = Default.pexp_apply ~loc e el\n let eint t = Default.eint ~loc t\n let echar t = Default.echar ~loc t\n let estring t = Default.estring ~loc t\n let efloat t = Default.efloat ~loc t\n let eint32 t = Default.eint32 ~loc t\n let eint64 t = Default.eint64 ~loc t\n let enativeint t = Default.enativeint ~loc t\n let ebool t = Default.ebool ~loc t\n let evar t = Default.evar ~loc t\n let pint t = Default.pint ~loc t\n let pchar t = Default.pchar ~loc t\n let pstring t = Default.pstring ~loc t\n let pfloat t = Default.pfloat ~loc t\n let pint32 t = Default.pint32 ~loc t\n let pint64 t = Default.pint64 ~loc t\n let pnativeint t = Default.pnativeint ~loc t\n let pbool t = Default.pbool ~loc t\n let pvar t = Default.pvar ~loc t\n let eunit = Default.eunit ~loc\n let punit = Default.punit ~loc\n let econstruct = Default.econstruct\n let pconstruct = Default.pconstruct\n let eapply e el = Default.eapply ~loc e el\n let eabstract ps e = Default.eabstract ~loc ps e\n let esequence el = Default.esequence ~loc el\n let elist l = Default.elist ~loc l\n let plist l = Default.plist ~loc l\n\n let type_constr_conv ident ~f args =\n Default.type_constr_conv ~loc ident ~f args\n\n let unapplied_type_constr_conv ident ~f =\n Default.unapplied_type_constr_conv ~loc ident ~f\n\n let eta_reduce = Default.eta_reduce\n let eta_reduce_if_possible = Default.eta_reduce_if_possible\n\n let eta_reduce_if_possible_and_nonrec =\n Default.eta_reduce_if_possible_and_nonrec\nend\n\nlet make loc =\n (module Make (struct\n let loc = loc\n end) : S)\n","open! Import\nmodule Printexc = Caml.Printexc\n\n(* Small helper to find out who is the caller of a function *)\n\ntype t = Printexc.location option\n\nlet get ~skip =\n let skip = __FILE__ :: skip in\n let stack = Printexc.get_callstack 16 in\n let len = Printexc.raw_backtrace_length stack in\n let rec loop pos =\n if pos = len then None\n else\n match\n Printexc.get_raw_backtrace_slot stack pos\n |> Printexc.convert_raw_backtrace_slot |> Printexc.Slot.location\n with\n | None -> None\n | Some loc ->\n if List.mem ~set:skip loc.filename then loop (pos + 1) else Some loc\n in\n loop 0\n","open! Import\nopen Ast_builder.Default\nmodule Buffer = Caml.Buffer\nmodule Format = Caml.Format\n\nlet lident x = Longident.Lident x\n\nlet core_type_of_type_declaration td =\n let loc = td.ptype_name.loc in\n ptyp_constr ~loc\n (Located.map lident td.ptype_name)\n (List.map td.ptype_params ~f:fst)\n\nlet strip_gen_symbol_suffix =\n let chop n ~or_more string pos f =\n let target = !pos - n in\n while !pos > 0 && (or_more || !pos > target) && f string.[!pos - 1] do\n pos := !pos - 1\n done;\n !pos <= target\n in\n fun string ->\n let pos = ref (String.length string) in\n if\n chop 1 ~or_more:false string pos (Char.equal '_')\n && chop 3 ~or_more:true string pos (function\n | '0' .. '9' -> true\n | _ -> false)\n && chop 2 ~or_more:false string pos (Char.equal '_')\n then String.prefix string !pos\n else string\n\nlet gen_symbol =\n let cnt = ref 0 in\n fun ?(prefix = \"_x\") () ->\n cnt := !cnt + 1;\n let prefix = strip_gen_symbol_suffix prefix in\n Printf.sprintf \"%s__%03i_\" prefix !cnt\n\nlet name_type_params_in_td (td : type_declaration) : type_declaration =\n let prefix_string i =\n (* a, b, ..., y, z, aa, bb, ... *)\n String.make ((i / 26) + 1) (Char.chr (Char.code 'a' + (i mod 26)))\n in\n let name_param i (tp, variance) =\n let ptyp_desc =\n match tp.ptyp_desc with\n | Ptyp_any -> Ptyp_var (gen_symbol ~prefix:(prefix_string i) ())\n | Ptyp_var _ as v -> v\n | _ -> Location.raise_errorf ~loc:tp.ptyp_loc \"not a type parameter\"\n in\n ({ tp with ptyp_desc }, variance)\n in\n { td with ptype_params = List.mapi td.ptype_params ~f:name_param }\n\nlet combinator_type_of_type_declaration td ~f =\n let td = name_type_params_in_td td in\n let result_type =\n f ~loc:td.ptype_name.loc (core_type_of_type_declaration td)\n in\n List.fold_right td.ptype_params ~init:result_type\n ~f:(fun (tp, _variance) acc ->\n let loc = tp.ptyp_loc in\n ptyp_arrow ~loc Nolabel (f ~loc tp) acc)\n\nlet string_of_core_type ct =\n let buf = Buffer.create 128 in\n let ppf = Format.formatter_of_buffer buf in\n Pprintast.core_type ppf ct;\n Format.pp_print_flush ppf ();\n Buffer.contents buf\n\nlet get_type_param_name (ty, _) =\n let loc = ty.ptyp_loc in\n match ty.ptyp_desc with\n | Ptyp_var name -> Located.mk ~loc name\n | _ -> Location.raise_errorf ~loc \"not a type parameter\"\n\nexception Type_is_recursive\n\nclass type_is_recursive rec_flag tds =\n object (self)\n inherit Ast_traverse.iter as super\n val type_names : string list = List.map tds ~f:(fun td -> td.ptype_name.txt)\n method return_true () = raise_notrace Type_is_recursive\n\n method! core_type ctype =\n match ctype.ptyp_desc with\n | Ptyp_arrow _ -> ()\n | Ptyp_constr ({ txt = Longident.Lident id; _ }, _)\n when List.mem ~set:type_names id ->\n self#return_true ()\n | _ -> super#core_type ctype\n\n method! constructor_declaration cd =\n (* Don't recurse through cd.pcd_res *)\n match cd.pcd_args with\n | Pcstr_tuple args -> List.iter args ~f:self#core_type\n | Pcstr_record fields -> List.iter fields ~f:self#label_declaration\n\n method! attributes _ = (* Don't recurse through attributes *)\n ()\n\n method go () =\n match rec_flag with\n | Nonrecursive -> Nonrecursive\n | Recursive -> (\n match List.iter tds ~f:self#type_declaration with\n | exception Type_is_recursive -> Recursive\n | () -> Nonrecursive)\n end\n\nlet really_recursive rec_flag tds = (new type_is_recursive rec_flag tds)#go ()\nlet rec last x l = match l with [] -> x | x :: l -> last x l\n\nlet loc_of_name_and_payload name payload =\n match payload with\n | PStr [] -> name.loc\n | PStr (x :: l) -> { x.pstr_loc with loc_end = (last x l).pstr_loc.loc_end }\n | PSig [] -> name.loc\n | PSig (x :: l) -> { x.psig_loc with loc_end = (last x l).psig_loc.loc_end }\n | PTyp t -> t.ptyp_loc\n | PPat (x, None) -> x.ppat_loc\n | PPat (x, Some e) -> { x.ppat_loc with loc_end = e.pexp_loc.loc_end }\n\nlet loc_of_payload { attr_name; attr_payload; attr_loc = _ } =\n loc_of_name_and_payload attr_name attr_payload\n\nlet loc_of_attribute { attr_name; attr_payload; attr_loc = _ } =\n (* TODO: fix this in the compiler, and move the logic to omp when converting\n from older asts. *)\n (* \"ocaml.doc\" attributes are generated with [Location.none], which is not helpful for\n error messages. *)\n if Poly.( = ) attr_name.loc Location.none then\n loc_of_name_and_payload attr_name attr_payload\n else\n {\n attr_name.loc with\n loc_end = (loc_of_name_and_payload attr_name attr_payload).loc_end;\n }\n\nlet loc_of_extension (name, payload) =\n if Poly.( = ) name.loc Location.none then loc_of_name_and_payload name payload\n else\n { name.loc with loc_end = (loc_of_name_and_payload name payload).loc_end }\n\nlet curry_applications expr =\n let open Ast_builder_generated.M in\n match expr.pexp_desc with\n | Pexp_apply (f, orig_forward_args) ->\n let loc = expr.pexp_loc in\n let rec loop = function\n | [] -> f\n | last_arg :: rev_front_args ->\n pexp_apply ~loc (loop rev_front_args) [ last_arg ]\n in\n loop (List.rev orig_forward_args)\n | _ -> expr\n\nlet rec assert_no_attributes = function\n | [] -> ()\n | { attr_name = name; attr_loc = _; attr_payload = _ } :: rest\n when Name.ignore_checks name.Location.txt ->\n assert_no_attributes rest\n | attr :: _ ->\n let loc = loc_of_attribute attr in\n Location.raise_errorf ~loc \"Attributes not allowed here\"\n\nlet assert_no_attributes_in =\n object\n inherit Ast_traverse.iter\n method! attribute a = assert_no_attributes [ a ]\n end\n\nlet attribute_of_warning loc s =\n {\n attr_name = { loc; txt = \"ocaml.ppwarning\" };\n attr_payload = PStr [ pstr_eval ~loc (estring ~loc s) [] ];\n attr_loc = loc;\n }\n\nlet is_polymorphic_variant =\n let rec check = function\n | { ptyp_desc = Ptyp_variant _; _ } -> `Definitely\n | { ptyp_desc = Ptyp_alias (typ, _); _ } -> check typ\n | { ptyp_desc = Ptyp_constr _; _ } -> `Maybe\n | _ -> `Surely_not\n (* Type vars go here even though they could be polymorphic\n variants, however we don't handle it if they get substituted\n by a polymorphic variant that is then included. *)\n in\n fun td ~sig_ ->\n match td.ptype_kind with\n | Ptype_variant _ | Ptype_record _ | Ptype_open -> `Surely_not\n | Ptype_abstract -> (\n match td.ptype_manifest with\n | None -> if sig_ then `Maybe else `Surely_not\n | Some typ -> check typ)\n\nlet mk_named_sig ~loc ~sg_name ~handle_polymorphic_variant = function\n | [ td ]\n when String.equal td.ptype_name.txt \"t\" && List.is_empty td.ptype_cstrs ->\n if\n (not handle_polymorphic_variant)\n && Poly.( = ) (is_polymorphic_variant td ~sig_:true) `Definitely\n then None\n else\n let arity = List.length td.ptype_params in\n if arity >= 4 then None\n else\n let mty =\n if arity = 0 then sg_name else Printf.sprintf \"%s%d\" sg_name arity\n in\n let td = name_type_params_in_td td in\n let for_subst =\n Ast_helper.Type.mk ~loc td.ptype_name ~params:td.ptype_params\n ~manifest:\n (ptyp_constr ~loc\n (Located.map_lident td.ptype_name)\n (List.map ~f:fst td.ptype_params))\n in\n Some\n (include_infos ~loc\n (pmty_with ~loc\n (pmty_ident ~loc (Located.lident mty ~loc))\n [ Pwith_typesubst (Located.lident ~loc \"t\", for_subst) ]))\n | _ -> None\n","open Import\nopen Ast_pattern0\nlet nolabel =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Nolabel -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Nolabel\")\nlet labelled (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Labelled x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"Labelled\")\nlet optional (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Optional x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"Optional\")\nlet attribute ~name:(T name) ~payload:(T payload) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = name ctx (x.attr_name).loc (x.attr_name).txt k in\n let k = payload ctx loc x.attr_payload k in k)\nlet binding_op ~op:(T op) ~pat:(T pat) ~exp:(T exp) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = op ctx (x.pbop_op).loc (x.pbop_op).txt k in\n let k = pat ctx loc x.pbop_pat k in\n let k = exp ctx loc x.pbop_exp k in k)\nlet case ~lhs:(T lhs) ~guard:(T guard) ~rhs:(T rhs) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = lhs ctx loc x.pc_lhs k in\n let k = guard ctx loc x.pc_guard k in\n let k = rhs ctx loc x.pc_rhs k in k)\nlet pcl_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcl_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pcl_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcl_loc in\n let k = f1 ctx loc x.pcl_attributes k in\n let x = { x with pcl_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pcl_constr (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_constr (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constr\"))\nlet pcl_structure (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_structure x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"structure\"))\nlet pcl_fun (T f0) (T f1) (T f2) (T f3) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_fun (x0, x1, x2, x3) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in\n let k = f2 ctx loc x2 k in let k = f3 ctx loc x3 k in k))\n | _ -> fail loc \"fun\"))\nlet pcl_apply (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_apply (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"apply\"))\nlet pcl_let (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_let (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"let\"))\nlet pcl_constraint (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_constraint (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constraint\"))\nlet pcl_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet pcl_open (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_open (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"open\"))\nlet pcf_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcf_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pcf_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcf_loc in\n let k = f1 ctx loc x.pcf_attributes k in\n let x = { x with pcf_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pcf_inherit (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_inherit (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"inherit\"))\nlet pcf_val (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_val x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"val\"))\nlet pcf_method (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_method x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"method\"))\nlet pcf_constraint (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_constraint x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"constraint\"))\nlet pcf_initializer (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_initializer x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"initializer\"))\nlet pcf_attribute (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_attribute x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"attribute\"))\nlet pcf_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet cfk_virtual (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Cfk_virtual x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"virtual\")\nlet cfk_concrete (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Cfk_concrete (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"concrete\")\nlet class_infos_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pci_loc in\n let k = f1 ctx loc x.pci_attributes k in\n let x = { x with pci_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet class_infos ~virt:(T virt) ~params:(T params) ~name:(T name) ~expr:(T\n expr) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pci_attributes;\n (let k = virt ctx loc x.pci_virt k in\n let k = params ctx loc x.pci_params k in\n let k = name ctx (x.pci_name).loc (x.pci_name).txt k in\n let k = expr ctx loc x.pci_expr k in k))\nlet class_signature ~self:(T self) ~fields:(T fields) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = self ctx loc x.pcsig_self k in\n let k = fields ctx loc x.pcsig_fields k in k)\nlet class_structure ~self:(T self) ~fields:(T fields) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = self ctx loc x.pcstr_self k in\n let k = fields ctx loc x.pcstr_fields k in k)\nlet pcty_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcty_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pcty_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcty_loc in\n let k = f1 ctx loc x.pcty_attributes k in\n let x = { x with pcty_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pcty_constr (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcty_attributes;\n (let loc = x.pcty_loc in\n let x = x.pcty_desc in\n match x with\n | Pcty_constr (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constr\"))\nlet pcty_signature (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcty_attributes;\n (let loc = x.pcty_loc in\n let x = x.pcty_desc in\n match x with\n | Pcty_signature x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"signature\"))\nlet pcty_arrow (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcty_attributes;\n (let loc = x.pcty_loc in\n let x = x.pcty_desc in\n match x with\n | Pcty_arrow (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"arrow\"))\nlet pcty_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcty_attributes;\n (let loc = x.pcty_loc in\n let x = x.pcty_desc in\n match x with\n | Pcty_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet pcty_open (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcty_attributes;\n (let loc = x.pcty_loc in\n let x = x.pcty_desc in\n match x with\n | Pcty_open (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"open\"))\nlet pctf_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pctf_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pctf_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pctf_loc in\n let k = f1 ctx loc x.pctf_attributes k in\n let x = { x with pctf_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pctf_inherit (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_inherit x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"inherit\"))\nlet pctf_val (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_val x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"val\"))\nlet pctf_method (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_method x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"method\"))\nlet pctf_constraint (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_constraint x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"constraint\"))\nlet pctf_attribute (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_attribute x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"attribute\"))\nlet pctf_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet closed =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Closed -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Closed\")\nlet open_ =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Open -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Open\")\nlet pconst_integer (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pconst_integer (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"integer\")\nlet pconst_char (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pconst_char x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"char\")\nlet pconst_string (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pconst_string (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"string\")\nlet pconst_float (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pconst_float (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"float\")\nlet pcstr_tuple (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pcstr_tuple x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"tuple\")\nlet pcstr_record (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pcstr_record x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"record\")\nlet constructor_declaration_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcd_loc in\n let k = f1 ctx loc x.pcd_attributes k in\n let x = { x with pcd_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet constructor_declaration ~name:(T name) ~args:(T args) ~res:(T res) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcd_attributes;\n (let k = name ctx (x.pcd_name).loc (x.pcd_name).txt k in\n let k = args ctx loc x.pcd_args k in\n let k = res ctx loc x.pcd_res k in k))\nlet ptyp_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ptyp_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet ptyp_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ptyp_loc in\n let k = f1 ctx loc x.ptyp_attributes k in\n let x = { x with ptyp_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet ptyp_any =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_any -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"any\"))\nlet ptyp_var (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_var x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"var\"))\nlet ptyp_arrow (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_arrow (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"arrow\"))\nlet ptyp_tuple (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_tuple x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"tuple\"))\nlet ptyp_constr (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_constr (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constr\"))\nlet ptyp_object (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_object (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"object\"))\nlet ptyp_class (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_class (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"class\"))\nlet ptyp_alias (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_alias (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"alias\"))\nlet ptyp_variant (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_variant (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"variant\"))\nlet ptyp_poly (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_poly (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"poly\"))\nlet ptyp_package (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_package x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"package\"))\nlet ptyp_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet upto =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Upto -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Upto\")\nlet downto_ =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Downto -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Downto\")\nlet pdira_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pdira_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pdir_string (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pdira_loc in\n let x = x.pdira_desc in\n match x with\n | Pdir_string x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"string\")\nlet pdir_int (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pdira_loc in\n let x = x.pdira_desc in\n match x with\n | Pdir_int (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"int\")\nlet pdir_ident (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pdira_loc in\n let x = x.pdira_desc in\n match x with\n | Pdir_ident x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"ident\")\nlet pdir_bool (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pdira_loc in\n let x = x.pdira_desc in\n match x with\n | Pdir_bool x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"bool\")\nlet pexp_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pexp_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pexp_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pexp_loc in\n let k = f1 ctx loc x.pexp_attributes k in\n let x = { x with pexp_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pexp_ident (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_ident x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"ident\"))\nlet pexp_constant (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_constant x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"constant\"))\nlet pexp_let (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_let (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"let\"))\nlet pexp_function (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_function x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"function\"))\nlet pexp_fun (T f0) (T f1) (T f2) (T f3) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_fun (x0, x1, x2, x3) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in\n let k = f2 ctx loc x2 k in let k = f3 ctx loc x3 k in k))\n | _ -> fail loc \"fun\"))\nlet pexp_apply (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_apply (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"apply\"))\nlet pexp_match (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_match (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"match\"))\nlet pexp_try (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_try (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"try\"))\nlet pexp_tuple (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_tuple x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"tuple\"))\nlet pexp_construct (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_construct (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"construct\"))\nlet pexp_variant (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_variant (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"variant\"))\nlet pexp_record (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_record (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"record\"))\nlet pexp_field (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_field (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx x1.loc x1.txt k in k))\n | _ -> fail loc \"field\"))\nlet pexp_setfield (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_setfield (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx x1.loc x1.txt k in\n let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"setfield\"))\nlet pexp_array (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_array x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"array\"))\nlet pexp_ifthenelse (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_ifthenelse (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"ifthenelse\"))\nlet pexp_sequence (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_sequence (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"sequence\"))\nlet pexp_while (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_while (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"while\"))\nlet pexp_for (T f0) (T f1) (T f2) (T f3) (T f4) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_for (x0, x1, x2, x3, x4) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in\n let k = f2 ctx loc x2 k in\n let k = f3 ctx loc x3 k in let k = f4 ctx loc x4 k in k))\n | _ -> fail loc \"for\"))\nlet pexp_constraint (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_constraint (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constraint\"))\nlet pexp_coerce (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_coerce (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"coerce\"))\nlet pexp_send (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_send (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx x1.loc x1.txt k in k))\n | _ -> fail loc \"send\"))\nlet pexp_new (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_new x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"new\"))\nlet pexp_setinstvar (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_setinstvar (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"setinstvar\"))\nlet pexp_override (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_override x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"override\"))\nlet pexp_letmodule (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_letmodule (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"letmodule\"))\nlet pexp_letexception (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_letexception (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"letexception\"))\nlet pexp_assert (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_assert x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"assert\"))\nlet pexp_lazy (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_lazy x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"lazy\"))\nlet pexp_poly (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_poly (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"poly\"))\nlet pexp_object (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_object x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"object\"))\nlet pexp_newtype (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_newtype (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"newtype\"))\nlet pexp_pack (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_pack x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"pack\"))\nlet pexp_open (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_open (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"open\"))\nlet pexp_letop (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_letop x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"letop\"))\nlet pexp_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet pexp_unreachable =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_unreachable -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"unreachable\"))\nlet extension_constructor_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pext_loc in\n let k = f1 ctx loc x.pext_attributes k in\n let x = { x with pext_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet extension_constructor ~name:(T name) ~kind:(T kind) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pext_attributes;\n (let k = name ctx (x.pext_name).loc (x.pext_name).txt k in\n let k = kind ctx loc x.pext_kind k in k))\nlet pext_decl (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pext_decl (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"decl\")\nlet pext_rebind (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pext_rebind x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"rebind\")\nlet unit =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Unit -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Unit\")\nlet named (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Named (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"Named\")\nlet include_infos_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pincl_loc in\n let k = f1 ctx loc x.pincl_attributes k in\n let x = { x with pincl_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet include_infos ~mod_:(T mod_) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pincl_attributes;\n (let k = mod_ ctx loc x.pincl_mod k in k))\nlet injective =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Injective -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Injective\")\nlet noinjectivity =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | NoInjectivity -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"NoInjectivity\")\nlet label_declaration_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pld_loc in\n let k = f1 ctx loc x.pld_attributes k in\n let x = { x with pld_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet label_declaration ~name:(T name) ~mutable_:(T mutable_) ~type_:(T\n type_) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pld_attributes;\n (let k = name ctx (x.pld_name).loc (x.pld_name).txt k in\n let k = mutable_ ctx loc x.pld_mutable k in\n let k = type_ ctx loc x.pld_type k in k))\nlet letop ~let_:(T let_) ~ands:(T ands) ~body:(T body) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = let_ ctx loc x.let_ k in\n let k = ands ctx loc x.ands k in\n let k = body ctx loc x.body k in k)\nlet location ~start:(T start) ~end_:(T end_) ~ghost:(T ghost) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = start ctx loc x.loc_start k in\n let k = end_ ctx loc x.loc_end k in\n let k = ghost ctx loc x.loc_ghost k in k)\nlet lident (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Lident x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"Lident\")\nlet ldot (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ldot (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"Ldot\")\nlet lapply (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Lapply (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"Lapply\")\nlet module_binding_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmb_loc in\n let k = f1 ctx loc x.pmb_attributes k in\n let x = { x with pmb_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet module_binding ~name:(T name) ~expr:(T expr) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmb_attributes;\n (let k = name ctx (x.pmb_name).loc (x.pmb_name).txt k in\n let k = expr ctx loc x.pmb_expr k in k))\nlet module_declaration_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmd_loc in\n let k = f1 ctx loc x.pmd_attributes k in\n let x = { x with pmd_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet module_declaration ~name:(T name) ~type_:(T type_) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmd_attributes;\n (let k = name ctx (x.pmd_name).loc (x.pmd_name).txt k in\n let k = type_ ctx loc x.pmd_type k in k))\nlet pmod_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmod_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pmod_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmod_loc in\n let k = f1 ctx loc x.pmod_attributes k in\n let x = { x with pmod_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pmod_ident (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_ident x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"ident\"))\nlet pmod_structure (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_structure x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"structure\"))\nlet pmod_functor (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_functor (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"functor\"))\nlet pmod_apply (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_apply (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"apply\"))\nlet pmod_constraint (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_constraint (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constraint\"))\nlet pmod_unpack (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_unpack x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"unpack\"))\nlet pmod_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet module_substitution_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pms_loc in\n let k = f1 ctx loc x.pms_attributes k in\n let x = { x with pms_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet module_substitution ~name:(T name) ~manifest:(T manifest) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pms_attributes;\n (let k = name ctx (x.pms_name).loc (x.pms_name).txt k in\n let k =\n manifest ctx (x.pms_manifest).loc (x.pms_manifest).txt k in\n k))\nlet pmty_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmty_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pmty_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmty_loc in\n let k = f1 ctx loc x.pmty_attributes k in\n let x = { x with pmty_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pmty_ident (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_ident x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"ident\"))\nlet pmty_signature (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_signature x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"signature\"))\nlet pmty_functor (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_functor (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"functor\"))\nlet pmty_with (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_with (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"with\"))\nlet pmty_typeof (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_typeof x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"typeof\"))\nlet pmty_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet pmty_alias (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_alias x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"alias\"))\nlet module_type_declaration_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmtd_loc in\n let k = f1 ctx loc x.pmtd_attributes k in\n let x = { x with pmtd_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet module_type_declaration ~name:(T name) ~type_:(T type_) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmtd_attributes;\n (let k = name ctx (x.pmtd_name).loc (x.pmtd_name).txt k in\n let k = type_ ctx loc x.pmtd_type k in k))\nlet immutable =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Immutable -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Immutable\")\nlet mutable_ =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Mutable -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Mutable\")\nlet pof_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pof_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pof_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pof_loc in\n let k = f1 ctx loc x.pof_attributes k in\n let x = { x with pof_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet otag (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pof_attributes;\n (let loc = x.pof_loc in\n let x = x.pof_desc in\n match x with\n | Otag (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"Otag\"))\nlet oinherit (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pof_attributes;\n (let loc = x.pof_loc in\n let x = x.pof_desc in\n match x with\n | Oinherit x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"Oinherit\"))\nlet open_infos_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.popen_loc in\n let k = f1 ctx loc x.popen_attributes k in\n let x = { x with popen_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet open_infos ~expr:(T expr) ~override:(T override) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.popen_attributes;\n (let k = expr ctx loc x.popen_expr k in\n let k = override ctx loc x.popen_override k in k))\nlet override =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Override -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Override\")\nlet fresh =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Fresh -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Fresh\")\nlet ppat_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ppat_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet ppat_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ppat_loc in\n let k = f1 ctx loc x.ppat_attributes k in\n let x = { x with ppat_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet ppat_any =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_any -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"any\"))\nlet ppat_var (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_var x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"var\"))\nlet ppat_alias (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_alias (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx x1.loc x1.txt k in k))\n | _ -> fail loc \"alias\"))\nlet ppat_constant (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_constant x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"constant\"))\nlet ppat_interval (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_interval (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"interval\"))\nlet ppat_tuple (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_tuple x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"tuple\"))\nlet ppat_construct (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_construct (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"construct\"))\nlet ppat_variant (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_variant (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"variant\"))\nlet ppat_record (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_record (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"record\"))\nlet ppat_array (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_array x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"array\"))\nlet ppat_or (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_or (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"or\"))\nlet ppat_constraint (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_constraint (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constraint\"))\nlet ppat_type (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_type x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"type\"))\nlet ppat_lazy (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_lazy x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"lazy\"))\nlet ppat_unpack (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_unpack x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"unpack\"))\nlet ppat_exception (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_exception x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"exception\"))\nlet ppat_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet ppat_open (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_open (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"open\"))\nlet pstr (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | PStr x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"PStr\")\nlet psig (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | PSig x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"PSig\")\nlet ptyp (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | PTyp x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"PTyp\")\nlet ppat (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | PPat (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"PPat\")\nlet position ~fname:(T fname) ~lnum:(T lnum) ~bol:(T bol) ~cnum:(T cnum) \n =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = fname ctx loc x.pos_fname k in\n let k = lnum ctx loc x.pos_lnum k in\n let k = bol ctx loc x.pos_bol k in\n let k = cnum ctx loc x.pos_cnum k in k)\nlet private_ =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Private -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Private\")\nlet public =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Public -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Public\")\nlet nonrecursive =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Nonrecursive -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Nonrecursive\")\nlet recursive =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Recursive -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Recursive\")\nlet prf_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.prf_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet prf_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.prf_loc in\n let k = f1 ctx loc x.prf_attributes k in\n let x = { x with prf_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet rtag (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.prf_attributes;\n (let loc = x.prf_loc in\n let x = x.prf_desc in\n match x with\n | Rtag (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"Rtag\"))\nlet rinherit (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.prf_attributes;\n (let loc = x.prf_loc in\n let x = x.prf_desc in\n match x with\n | Rinherit x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"Rinherit\"))\nlet psig_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet psig_value (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_value x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"value\")\nlet psig_type (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_type (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"type\")\nlet psig_typesubst (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_typesubst x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"typesubst\")\nlet psig_typext (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_typext x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"typext\")\nlet psig_exception (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_exception x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"exception\")\nlet psig_module (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_module x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"module\")\nlet psig_modsubst (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_modsubst x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"modsubst\")\nlet psig_recmodule (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_recmodule x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"recmodule\")\nlet psig_modtype (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_modtype x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"modtype\")\nlet psig_open (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_open x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"open\")\nlet psig_include (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_include x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"include\")\nlet psig_class (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_class x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"class\")\nlet psig_class_type (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_class_type x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"class_type\")\nlet psig_attribute (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_attribute x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"attribute\")\nlet psig_extension (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_extension (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"extension\")\nlet pstr_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pstr_eval (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_eval (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"eval\")\nlet pstr_value (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_value (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"value\")\nlet pstr_primitive (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_primitive x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"primitive\")\nlet pstr_type (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_type (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"type\")\nlet pstr_typext (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_typext x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"typext\")\nlet pstr_exception (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_exception x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"exception\")\nlet pstr_module (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_module x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"module\")\nlet pstr_recmodule (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_recmodule x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"recmodule\")\nlet pstr_modtype (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_modtype x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"modtype\")\nlet pstr_open (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_open x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"open\")\nlet pstr_class (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_class x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"class\")\nlet pstr_class_type (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_class_type x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"class_type\")\nlet pstr_include (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_include x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"include\")\nlet pstr_attribute (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_attribute x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"attribute\")\nlet pstr_extension (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_extension (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"extension\")\nlet toplevel_directive ~name:(T name) ~arg:(T arg) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = name ctx (x.pdir_name).loc (x.pdir_name).txt k in\n let k = arg ctx loc x.pdir_arg k in k)\nlet ptop_def (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptop_def x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"def\")\nlet ptop_dir (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptop_dir x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"dir\")\nlet type_declaration_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ptype_loc in\n let k = f1 ctx loc x.ptype_attributes k in\n let x = { x with ptype_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet type_declaration ~name:(T name) ~params:(T params) ~cstrs:(T cstrs) \n ~kind:(T kind) ~private_:(T private_) ~manifest:(T manifest) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptype_attributes;\n (let k = name ctx (x.ptype_name).loc (x.ptype_name).txt k in\n let k = params ctx loc x.ptype_params k in\n let k = cstrs ctx loc x.ptype_cstrs k in\n let k = kind ctx loc x.ptype_kind k in\n let k = private_ ctx loc x.ptype_private k in\n let k = manifest ctx loc x.ptype_manifest k in k))\nlet type_exception_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ptyexn_loc in\n let k = f1 ctx loc x.ptyexn_attributes k in\n let x = { x with ptyexn_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet type_exception ~constructor:(T constructor) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyexn_attributes;\n (let k = constructor ctx loc x.ptyexn_constructor k in k))\nlet type_extension_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ptyext_loc in\n let k = f1 ctx loc x.ptyext_attributes k in\n let x = { x with ptyext_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet type_extension ~path:(T path) ~params:(T params) ~constructors:(T\n constructors) ~private_:(T private_) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyext_attributes;\n (let k = path ctx (x.ptyext_path).loc (x.ptyext_path).txt k in\n let k = params ctx loc x.ptyext_params k in\n let k = constructors ctx loc x.ptyext_constructors k in\n let k = private_ ctx loc x.ptyext_private k in k))\nlet ptype_abstract =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptype_abstract -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"abstract\")\nlet ptype_variant (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptype_variant x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"variant\")\nlet ptype_record (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptype_record x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"record\")\nlet ptype_open =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptype_open -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"open\")\nlet value_binding_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pvb_loc in\n let k = f1 ctx loc x.pvb_attributes k in\n let x = { x with pvb_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet value_binding ~pat:(T pat) ~expr:(T expr) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pvb_attributes;\n (let k = pat ctx loc x.pvb_pat k in\n let k = expr ctx loc x.pvb_expr k in k))\nlet value_description_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pval_loc in\n let k = f1 ctx loc x.pval_attributes k in\n let x = { x with pval_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet value_description ~name:(T name) ~type_:(T type_) ~prim:(T prim) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pval_attributes;\n (let k = name ctx (x.pval_name).loc (x.pval_name).txt k in\n let k = type_ ctx loc x.pval_type k in\n let k = prim ctx loc x.pval_prim k in k))\nlet covariant =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Covariant -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Covariant\")\nlet contravariant =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Contravariant -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Contravariant\")\nlet novariance =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | NoVariance -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"NoVariance\")\nlet virtual_ =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Virtual -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Virtual\")\nlet concrete =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Concrete -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Concrete\")\nlet pwith_type (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pwith_type (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"type\")\nlet pwith_module (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pwith_module (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx x1.loc x1.txt k in k))\n | _ -> fail loc \"module\")\nlet pwith_typesubst (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pwith_typesubst (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"typesubst\")\nlet pwith_modsubst (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pwith_modsubst (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx x1.loc x1.txt k in k))\n | _ -> fail loc \"modsubst\")\n","open! Import\ninclude Ast_pattern0\n\nlet save_context ctx = ctx.matched\nlet restore_context ctx backup = ctx.matched <- backup\nlet incr_matched c = c.matched <- c.matched + 1\n\nlet parse (T f) loc ?on_error x k =\n try f { matched = 0 } loc x k\n with Expected (loc, expected) -> (\n match on_error with\n | None -> Location.raise_errorf ~loc \"%s expected\" expected\n | Some f -> f ())\n\nmodule Packed = struct\n type ('a, 'b) t = T : ('a, 'b, 'c) Ast_pattern0.t * 'b -> ('a, 'c) t\n\n let create t f = T (t, f)\n let parse (T (t, f)) loc x = parse t loc x f\nend\n\nlet __ =\n T\n (fun ctx _loc x k ->\n incr_matched ctx;\n k x)\n\nlet __' =\n T\n (fun ctx loc x k ->\n incr_matched ctx;\n k { loc; txt = x })\n\nlet drop =\n T\n (fun ctx _loc _ k ->\n incr_matched ctx;\n k)\n\nlet as__ (T f1) =\n T\n (fun ctx loc x k ->\n let k = f1 ctx loc x (k x) in\n k)\n\nlet cst ~to_string ?(equal = Poly.equal) v =\n T\n (fun ctx loc x k ->\n if equal x v then (\n incr_matched ctx;\n k)\n else fail loc (to_string v))\n\nlet int v = cst ~to_string:Int.to_string v\nlet char v = cst ~to_string:(Printf.sprintf \"%C\") v\nlet string v = cst ~to_string:(Printf.sprintf \"%S\") v\nlet float v = cst ~to_string:Float.to_string v\nlet int32 v = cst ~to_string:Int32.to_string v\nlet int64 v = cst ~to_string:Int64.to_string v\nlet nativeint v = cst ~to_string:Nativeint.to_string v\nlet bool v = cst ~to_string:Bool.to_string v\n\nlet false_ =\n T\n (fun ctx loc x k ->\n match x with\n | false ->\n ctx.matched <- ctx.matched + 1;\n k\n | _ -> fail loc \"false\")\n\nlet true_ =\n T\n (fun ctx loc x k ->\n match x with\n | true ->\n ctx.matched <- ctx.matched + 1;\n k\n | _ -> fail loc \"true\")\n\nlet nil =\n T\n (fun ctx loc x k ->\n match x with\n | [] ->\n ctx.matched <- ctx.matched + 1;\n k\n | _ -> fail loc \"[]\")\n\nlet ( ^:: ) (T f0) (T f1) =\n T\n (fun ctx loc x k ->\n match x with\n | x0 :: x1 ->\n ctx.matched <- ctx.matched + 1;\n let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in\n k\n | _ -> fail loc \"::\")\n\nlet none =\n T\n (fun ctx loc x k ->\n match x with\n | None ->\n ctx.matched <- ctx.matched + 1;\n k\n | _ -> fail loc \"None\")\n\nlet some (T f0) =\n T\n (fun ctx loc x k ->\n match x with\n | Some x0 ->\n ctx.matched <- ctx.matched + 1;\n let k = f0 ctx loc x0 k in\n k\n | _ -> fail loc \"Some\")\n\nlet pair (T f1) (T f2) =\n T\n (fun ctx loc (x1, x2) k ->\n let k = f1 ctx loc x1 k in\n let k = f2 ctx loc x2 k in\n k)\n\nlet ( ** ) = pair\n\nlet triple (T f1) (T f2) (T f3) =\n T\n (fun ctx loc (x1, x2, x3) k ->\n let k = f1 ctx loc x1 k in\n let k = f2 ctx loc x2 k in\n let k = f3 ctx loc x3 k in\n k)\n\nlet alt (T f1) (T f2) =\n T\n (fun ctx loc x k ->\n let backup = save_context ctx in\n try f1 ctx loc x k\n with e1 -> (\n let m1 = save_context ctx in\n restore_context ctx backup;\n try f2 ctx loc x k\n with e2 ->\n let m2 = save_context ctx in\n if m1 >= m2 then (\n restore_context ctx m1;\n raise e1)\n else raise e2))\n\nlet ( ||| ) = alt\nlet map (T func) ~f = T (fun ctx loc x k -> func ctx loc x (f k))\nlet map' (T func) ~f = T (fun ctx loc x k -> func ctx loc x (f loc k))\nlet map_result (T func) ~f = T (fun ctx loc x k -> f (func ctx loc x k))\nlet ( >>| ) t f = map t ~f\nlet map0 (T func) ~f = T (fun ctx loc x k -> func ctx loc x (k f))\nlet map1 (T func) ~f = T (fun ctx loc x k -> func ctx loc x (fun a -> k (f a)))\n\nlet map2 (T func) ~f =\n T (fun ctx loc x k -> func ctx loc x (fun a b -> k (f a b)))\n\nlet map0' (T func) ~f = T (fun ctx loc x k -> func ctx loc x (k (f loc)))\n\nlet map1' (T func) ~f =\n T (fun ctx loc x k -> func ctx loc x (fun a -> k (f loc a)))\n\nlet map2' (T func) ~f =\n T (fun ctx loc x k -> func ctx loc x (fun a b -> k (f loc a b)))\n\nlet alt_option some none =\n alt (map1 some ~f:(fun x -> Some x)) (map0 none ~f:None)\n\nlet many (T f) =\n T (fun ctx loc l k -> k (List.map l ~f:(fun x -> f ctx loc x (fun x -> x))))\n\nlet loc (T f) = T (fun ctx _loc (x : _ Loc.t) k -> f ctx x.loc x.txt k)\nlet pack0 t = map t ~f:(fun f -> f ())\nlet pack2 t = map t ~f:(fun f x y -> f (x, y))\nlet pack3 t = map t ~f:(fun f x y z -> f (x, y, z))\n\ninclude Ast_pattern_generated\n\nlet echar t = pexp_constant (pconst_char t)\nlet estring t = pexp_constant (pconst_string t drop drop)\nlet efloat t = pexp_constant (pconst_float t drop)\nlet pchar t = ppat_constant (pconst_char t)\nlet pstring t = ppat_constant (pconst_string t drop drop)\nlet pfloat t = ppat_constant (pconst_float t drop)\nlet int' (T f) = T (fun ctx loc x k -> f ctx loc (int_of_string x) k)\nlet int32' (T f) = T (fun ctx loc x k -> f ctx loc (Int32.of_string x) k)\nlet int64' (T f) = T (fun ctx loc x k -> f ctx loc (Int64.of_string x) k)\n\nlet nativeint' (T f) =\n T (fun ctx loc x k -> f ctx loc (Nativeint.of_string x) k)\n\nlet const_int t = pconst_integer (int' t) none\nlet const_int32 t = pconst_integer (int32' t) (some (char 'l'))\nlet const_int64 t = pconst_integer (int64' t) (some (char 'L'))\nlet const_nativeint t = pconst_integer (nativeint' t) (some (char 'n'))\nlet eint t = pexp_constant (const_int t)\nlet eint32 t = pexp_constant (const_int32 t)\nlet eint64 t = pexp_constant (const_int64 t)\nlet enativeint t = pexp_constant (const_nativeint t)\nlet pint t = ppat_constant (const_int t)\nlet pint32 t = ppat_constant (const_int32 t)\nlet pint64 t = ppat_constant (const_int64 t)\nlet pnativeint t = ppat_constant (const_nativeint t)\nlet single_expr_payload t = pstr (pstr_eval t nil ^:: nil)\nlet no_label t = cst Asttypes.Nolabel ~to_string:(fun _ -> \"Nolabel\") ** t\n\nlet extension (T f1) (T f2) =\n T\n (fun ctx loc ((name : _ Loc.t), payload) k ->\n let k = f1 ctx name.loc name.txt k in\n let k = f2 ctx loc payload k in\n k)\n\nlet rec parse_elist (e : Parsetree.expression) acc =\n Common.assert_no_attributes e.pexp_attributes;\n match e.pexp_desc with\n | Pexp_construct ({ txt = Lident \"[]\"; _ }, None) -> List.rev acc\n | Pexp_construct ({ txt = Lident \"::\"; _ }, Some arg) -> (\n Common.assert_no_attributes arg.pexp_attributes;\n match arg.pexp_desc with\n | Pexp_tuple [ hd; tl ] -> parse_elist tl (hd :: acc)\n | _ -> fail arg.pexp_loc \"list\")\n | _ -> fail e.pexp_loc \"list\"\n\nlet elist (T f) =\n T\n (fun ctx _loc e k ->\n let l = parse_elist e [] in\n incr_matched ctx;\n k (List.map l ~f:(fun x -> f ctx x.Parsetree.pexp_loc x (fun x -> x))))\n\nlet esequence (T f) =\n T\n (fun ctx _loc e k ->\n let rec parse_seq expr acc =\n match expr.pexp_desc with\n | Pexp_sequence (expr, next) -> parse_seq next (expr :: acc)\n | _ -> expr :: acc\n in\n k\n (List.rev_map (parse_seq e []) ~f:(fun expr ->\n f ctx expr.pexp_loc expr (fun x -> x))))\n\nlet of_func f = T f\nlet to_func (T f) = f\n","open! Import\nopen Common\n\ntype (_, _) equality = Eq : ('a, 'a) equality | Ne : (_, _) equality\n\nmodule Context = struct\n type 'a t =\n | Class_expr : class_expr t\n | Class_field : class_field t\n | Class_type : class_type t\n | Class_type_field : class_type_field t\n | Core_type : core_type t\n | Expression : expression t\n | Module_expr : module_expr t\n | Module_type : module_type t\n | Pattern : pattern t\n | Signature_item : signature_item t\n | Structure_item : structure_item t\n | Ppx_import : type_declaration t\n\n type packed = T : _ t -> packed\n\n let class_expr = Class_expr\n let class_field = Class_field\n let class_type = Class_type\n let class_type_field = Class_type_field\n let core_type = Core_type\n let expression = Expression\n let module_expr = Module_expr\n let module_type = Module_type\n let pattern = Pattern\n let signature_item = Signature_item\n let structure_item = Structure_item\n\n let desc : type a. a t -> string = function\n | Class_expr -> \"class expression\"\n | Class_field -> \"class field\"\n | Class_type -> \"class type\"\n | Class_type_field -> \"class type field\"\n | Core_type -> \"core type\"\n | Expression -> \"expression\"\n | Module_expr -> \"module expression\"\n | Module_type -> \"module type\"\n | Pattern -> \"pattern\"\n | Signature_item -> \"signature item\"\n | Structure_item -> \"structure item\"\n | Ppx_import -> \"type declaration\"\n\n let eq : type a b. a t -> b t -> (a, b) equality =\n fun a b ->\n match (a, b) with\n | Class_expr, Class_expr -> Eq\n | Class_field, Class_field -> Eq\n | Class_type, Class_type -> Eq\n | Class_type_field, Class_type_field -> Eq\n | Core_type, Core_type -> Eq\n | Expression, Expression -> Eq\n | Module_expr, Module_expr -> Eq\n | Module_type, Module_type -> Eq\n | Pattern, Pattern -> Eq\n | Signature_item, Signature_item -> Eq\n | Structure_item, Structure_item -> Eq\n | Ppx_import, Ppx_import -> Eq\n | _ ->\n assert (Poly.( <> ) (T a) (T b));\n Ne\n\n let get_ppx_import_extension type_decl =\n match type_decl with\n | { ptype_manifest = Some { ptyp_desc = Ptyp_extension (name, _); _ }; _ }\n ->\n let virtual_payload =\n Ast_builder.Default.pstr_type ~loc:type_decl.ptype_loc Recursive\n [ type_decl ]\n in\n let attr = [] in\n Some ((name, PStr [ virtual_payload ]), attr)\n | _ -> None\n\n let get_extension : type a. a t -> a -> (extension * attributes) option =\n fun t x ->\n match (t, x) with\n | Class_expr, { pcl_desc = Pcl_extension e; pcl_attributes = a; _ } ->\n Some (e, a)\n | Class_field, { pcf_desc = Pcf_extension e; pcf_attributes = a; _ } ->\n Some (e, a)\n | Class_type, { pcty_desc = Pcty_extension e; pcty_attributes = a; _ } ->\n Some (e, a)\n | Class_type_field, { pctf_desc = Pctf_extension e; pctf_attributes = a; _ }\n ->\n Some (e, a)\n | Core_type, { ptyp_desc = Ptyp_extension e; ptyp_attributes = a; _ } ->\n Some (e, a)\n | Expression, { pexp_desc = Pexp_extension e; pexp_attributes = a; _ } ->\n Some (e, a)\n | Module_expr, { pmod_desc = Pmod_extension e; pmod_attributes = a; _ } ->\n Some (e, a)\n | Module_type, { pmty_desc = Pmty_extension e; pmty_attributes = a; _ } ->\n Some (e, a)\n | Pattern, { ppat_desc = Ppat_extension e; ppat_attributes = a; _ } ->\n Some (e, a)\n | Signature_item, { psig_desc = Psig_extension (e, a); _ } -> Some (e, a)\n | Structure_item, { pstr_desc = Pstr_extension (e, a); _ } -> Some (e, a)\n | Ppx_import, type_decl -> get_ppx_import_extension type_decl\n | _ -> None\n\n let merge_attributes : type a. a t -> a -> attributes -> a =\n fun t x attrs ->\n match t with\n | Class_expr -> { x with pcl_attributes = x.pcl_attributes @ attrs }\n | Class_field -> { x with pcf_attributes = x.pcf_attributes @ attrs }\n | Class_type -> { x with pcty_attributes = x.pcty_attributes @ attrs }\n | Class_type_field -> { x with pctf_attributes = x.pctf_attributes @ attrs }\n | Core_type -> { x with ptyp_attributes = x.ptyp_attributes @ attrs }\n | Expression -> { x with pexp_attributes = x.pexp_attributes @ attrs }\n | Module_expr -> { x with pmod_attributes = x.pmod_attributes @ attrs }\n | Module_type -> { x with pmty_attributes = x.pmty_attributes @ attrs }\n | Pattern -> { x with ppat_attributes = x.ppat_attributes @ attrs }\n | Signature_item ->\n assert_no_attributes attrs;\n x\n | Structure_item ->\n assert_no_attributes attrs;\n x\n | Ppx_import ->\n assert_no_attributes attrs;\n x\nend\n\nlet registrar =\n Name.Registrar.create ~kind:\"extension\" ~current_file:__FILE__\n ~string_of_context:(fun (Context.T ctx) -> Some (Context.desc ctx))\n\nmodule Make (Callback : sig\n type 'a t\nend) =\nstruct\n type ('a, 'b) payload_parser =\n | Payload_parser :\n ('a, 'b, 'c) Ast_pattern.t * 'b Callback.t\n -> ('a, 'c) payload_parser\n\n type ('context, 'payload) t = {\n name : Name.Pattern.t;\n context : 'context Context.t;\n payload : (payload, 'payload) payload_parser;\n with_arg : bool;\n }\n\n let declare :\n type a.\n with_arg:bool ->\n string ->\n a Context.t ->\n (payload, 'b, 'payload) Ast_pattern.t ->\n 'b Callback.t ->\n (a, 'payload) t =\n fun ~with_arg name context pattern k ->\n (* Check that there is no collisions between ppx_import and core_type\n extensions *)\n (match context with\n | Context.Ppx_import ->\n Name.Registrar.check_collisions registrar (Context.T Core_type) name\n | Context.Core_type ->\n Name.Registrar.check_collisions registrar (Context.T Ppx_import) name\n | _ -> ());\n Name.Registrar.register ~kind:`Extension registrar (Context.T context) name;\n {\n name = Name.Pattern.make name;\n context;\n payload = Payload_parser (pattern, k);\n with_arg;\n }\n\n let find ts (ext : extension) =\n let { txt = name; loc } = fst ext in\n let name, arg = Name.split_path name in\n match List.filter ts ~f:(fun t -> Name.Pattern.matches t.name name) with\n | [] -> None\n | _ :: _ :: _ as l ->\n Location.raise_errorf ~loc \"Multiple match for extensions: %s\"\n (String.concat ~sep:\", \"\n (List.map l ~f:(fun t -> Name.Pattern.name t.name)))\n | [ t ] ->\n if (not t.with_arg) && Option.is_some arg then\n Location.raise_errorf ~loc\n \"Extension %s doesn't expect a path argument\" name;\n let arg =\n Option.map arg ~f:(fun s ->\n let shift = String.length name + 1 in\n let start = loc.loc_start in\n {\n txt = Longident.parse s;\n loc =\n {\n loc with\n loc_start = { start with pos_cnum = start.pos_cnum + shift };\n };\n })\n in\n Some (t, arg)\nend\n\nmodule Expert = struct\n include Make (struct\n type 'a t = arg:Longident.t Loc.t option -> 'a\n end)\n\n let declare_with_path_arg name ctx patt f =\n declare ~with_arg:true name ctx patt f\n\n let declare name ctx patt f =\n declare ~with_arg:false name ctx patt (fun ~arg:_ -> f)\n\n let convert ts ~loc ext =\n match find ts ext with\n | None -> None\n | Some ({ payload = Payload_parser (pattern, f); _ }, arg) ->\n Some (Ast_pattern.parse pattern loc (snd ext) (f ~arg))\nend\n\nmodule M = Make (struct\n type 'a t =\n ctxt:Expansion_context.Extension.t -> arg:Longident.t Loc.t option -> 'a\nend)\n\ntype 'a expander_result = Simple of 'a | Inline of 'a list\n\nmodule For_context = struct\n type 'a t = ('a, 'a expander_result) M.t\n\n let convert ts ~ctxt ext =\n let loc = Expansion_context.Extension.extension_point_loc ctxt in\n match M.find ts ext with\n | None -> None\n | Some ({ payload = M.Payload_parser (pattern, f); _ }, arg) -> (\n match Ast_pattern.parse pattern loc (snd ext) (f ~ctxt ~arg) with\n | Simple x -> Some x\n | Inline _ -> failwith \"Extension.convert\")\n\n let convert_inline ts ~ctxt ext =\n let loc = Expansion_context.Extension.extension_point_loc ctxt in\n match M.find ts ext with\n | None -> None\n | Some ({ payload = M.Payload_parser (pattern, f); _ }, arg) -> (\n match Ast_pattern.parse pattern loc (snd ext) (f ~ctxt ~arg) with\n | Simple x -> Some [ x ]\n | Inline l -> Some l)\nend\n\ntype t = T : _ For_context.t -> t\n\nlet check_context_for_inline : type a. func:string -> a Context.t -> unit =\n fun ~func ctx ->\n match ctx with\n | Context.Class_field -> ()\n | Context.Class_type_field -> ()\n | Context.Signature_item -> ()\n | Context.Structure_item -> ()\n | context ->\n Printf.ksprintf invalid_arg \"%s: %s can't be inlined\" func\n (Context.desc context)\n\nlet rec filter_by_context :\n type a. a Context.t -> t list -> a For_context.t list =\n fun context expanders ->\n match expanders with\n | [] -> []\n | T t :: rest -> (\n match Context.eq context t.context with\n | Eq -> t :: filter_by_context context rest\n | Ne -> filter_by_context context rest)\n\nlet fail ctx (name, _) =\n if\n not\n (Name.Whitelisted.is_whitelisted ~kind:`Extension name.txt\n || Name.ignore_checks name.txt)\n then\n Name.Registrar.raise_errorf registrar (Context.T ctx)\n \"Extension `%s' was not translated\" name\n\nlet check_unused =\n object\n inherit Ast_traverse.iter as super\n\n method! extension (name, _) =\n Location.raise_errorf ~loc:name.loc\n \"extension not expected here, Ppxlib.Extension needs updating!\"\n\n method! core_type_desc =\n function\n | Ptyp_extension ext -> fail Core_type ext | x -> super#core_type_desc x\n\n method! pattern_desc =\n function\n | Ppat_extension ext -> fail Pattern ext | x -> super#pattern_desc x\n\n method! expression_desc =\n function\n | Pexp_extension ext -> fail Expression ext | x -> super#expression_desc x\n\n method! class_type_desc =\n function\n | Pcty_extension ext -> fail Class_type ext | x -> super#class_type_desc x\n\n method! class_type_field_desc =\n function\n | Pctf_extension ext -> fail Class_type_field ext\n | x -> super#class_type_field_desc x\n\n method! class_expr_desc =\n function\n | Pcl_extension ext -> fail Class_expr ext | x -> super#class_expr_desc x\n\n method! class_field_desc =\n function\n | Pcf_extension ext -> fail Class_field ext\n | x -> super#class_field_desc x\n\n method! module_type_desc =\n function\n | Pmty_extension ext -> fail Module_type ext\n | x -> super#module_type_desc x\n\n method! signature_item_desc =\n function\n | Psig_extension (ext, _) -> fail Signature_item ext\n | x -> super#signature_item_desc x\n\n method! module_expr_desc =\n function\n | Pmod_extension ext -> fail Module_expr ext\n | x -> super#module_expr_desc x\n\n method! structure_item_desc =\n function\n | Pstr_extension (ext, _) -> fail Structure_item ext\n | x -> super#structure_item_desc x\n end\n\nmodule V3 = struct\n type nonrec t = t\n\n let declare name context pattern k =\n let pattern = Ast_pattern.map_result pattern ~f:(fun x -> Simple x) in\n T\n (M.declare ~with_arg:false name context pattern (fun ~ctxt ~arg:_ ->\n k ~ctxt))\n\n let declare_inline name context pattern k =\n check_context_for_inline context ~func:\"Extension.declare_inline\";\n let pattern = Ast_pattern.map_result pattern ~f:(fun x -> Inline x) in\n T\n (M.declare ~with_arg:false name context pattern (fun ~ctxt ~arg:_ ->\n k ~ctxt))\nend\n\nlet declare name context pattern f =\n V3.declare name context pattern\n (Expansion_context.Extension.with_loc_and_path f)\n\nlet declare_inline name context pattern f =\n V3.declare_inline name context pattern\n (Expansion_context.Extension.with_loc_and_path f)\n\nlet declare_with_path_arg name context pattern k =\n let k' = Expansion_context.Extension.with_loc_and_path k in\n let pattern = Ast_pattern.map_result pattern ~f:(fun x -> Simple x) in\n T (M.declare ~with_arg:true name context pattern k')\n\nlet declare_inline_with_path_arg name context pattern k =\n let k' = Expansion_context.Extension.with_loc_and_path k in\n check_context_for_inline context\n ~func:\"Extension.declare_inline_with_path_arg\";\n let pattern = Ast_pattern.map_result pattern ~f:(fun x -> Inline x) in\n T (M.declare ~with_arg:true name context pattern k')\n\nlet __declare_ppx_import name expand =\n (* This pattern is used to unwrap the type declaration from the payload\n assembled by [Context.get_ppx_import_extension] *)\n let pattern = Ast_pattern.(pstr (pstr_type recursive (__ ^:: nil) ^:: nil)) in\n V3.declare name Context.Ppx_import pattern expand\n\nmodule V2 = struct\n type nonrec t = t\n\n let declare = declare\n let declare_inline = declare_inline\nend\n","(*$ open Ppxlib_cinaps_helpers $*)\nopen! Import\nopen Common\nmodule E = Extension\nmodule EC = Extension.Context\nmodule A = Attribute\nmodule AC = Attribute.Context\n\nmodule Rule = struct\n module Attr_group_inline = struct\n type ('a, 'b, 'c) unpacked = {\n attribute : ('b, 'c) Attribute.t;\n expect : bool;\n expand :\n ctxt:Expansion_context.Deriver.t ->\n Asttypes.rec_flag ->\n 'b list ->\n 'c option list ->\n 'a list;\n }\n\n type ('a, 'b) t = T : ('a, 'b, _) unpacked -> ('a, 'b) t\n\n let attr_name (T t) = Attribute.name t.attribute\n\n let split_normal_and_expect l =\n List.partition l ~f:(fun (T t) -> not t.expect)\n end\n\n module Attr_inline = struct\n type ('a, 'b, 'c) unpacked = {\n attribute : ('b, 'c) Attribute.t;\n expect : bool;\n expand : ctxt:Expansion_context.Deriver.t -> 'b -> 'c -> 'a list;\n }\n\n type ('a, 'b) t = T : ('a, 'b, _) unpacked -> ('a, 'b) t\n\n let attr_name (T t) = Attribute.name t.attribute\n\n let split_normal_and_expect l =\n List.partition l ~f:(fun (T t) -> not t.expect)\n end\n\n module Special_function = struct\n type t = {\n name : string;\n ident : Longident.t;\n expand : Parsetree.expression -> Parsetree.expression option;\n }\n end\n\n module Constant_kind = struct\n type t = Float | Integer\n end\n\n module Constant = struct\n type t = {\n suffix : char;\n kind : Constant_kind.t;\n expand : Location.t -> string -> Parsetree.expression;\n }\n end\n\n module Field = struct\n type 'a t =\n | Extension : Extension.t t\n | Special_function : Special_function.t t\n | Constant : Constant.t t\n | Attr_str_type_decl\n : (structure_item, type_declaration) Attr_group_inline.t t\n | Attr_sig_type_decl\n : (signature_item, type_declaration) Attr_group_inline.t t\n | Attr_str_module_type_decl\n : (structure_item, module_type_declaration) Attr_inline.t t\n | Attr_sig_module_type_decl\n : (signature_item, module_type_declaration) Attr_inline.t t\n | Attr_str_type_ext : (structure_item, type_extension) Attr_inline.t t\n | Attr_sig_type_ext : (signature_item, type_extension) Attr_inline.t t\n | Attr_str_exception : (structure_item, type_exception) Attr_inline.t t\n | Attr_sig_exception : (signature_item, type_exception) Attr_inline.t t\n\n type (_, _) equality = Eq : ('a, 'a) equality | Ne : (_, _) equality\n\n let eq : type a b. a t -> b t -> (a, b) equality =\n fun a b ->\n match (a, b) with\n | Extension, Extension -> Eq\n | Special_function, Special_function -> Eq\n | Constant, Constant -> Eq\n | Attr_str_type_decl, Attr_str_type_decl -> Eq\n | Attr_sig_type_decl, Attr_sig_type_decl -> Eq\n | Attr_str_type_ext, Attr_str_type_ext -> Eq\n | Attr_sig_type_ext, Attr_sig_type_ext -> Eq\n | Attr_str_exception, Attr_str_exception -> Eq\n | Attr_sig_exception, Attr_sig_exception -> Eq\n | Attr_str_module_type_decl, Attr_str_module_type_decl -> Eq\n | Attr_sig_module_type_decl, Attr_sig_module_type_decl -> Eq\n | _ -> Ne\n end\n\n type t = T : 'a Field.t * 'a -> t\n\n type ('a, 'b, 'c) attr_group_inline =\n ('b, 'c) Attribute.t ->\n (ctxt:Expansion_context.Deriver.t ->\n Asttypes.rec_flag ->\n 'b list ->\n 'c option list ->\n 'a list) ->\n t\n\n type ('a, 'b, 'c) attr_inline =\n ('b, 'c) Attribute.t ->\n (ctxt:Expansion_context.Deriver.t -> 'b -> 'c -> 'a list) ->\n t\n\n let rec filter : type a. a Field.t -> t list -> a list =\n fun field l ->\n match l with\n | [] -> []\n | T (field', x) :: l -> (\n match Field.eq field field' with\n | Field.Eq -> x :: filter field l\n | Field.Ne -> filter field l)\n\n let extension ext = T (Extension, ext)\n\n let special_function id f =\n T (Special_function, { name = id; ident = Longident.parse id; expand = f })\n\n let constant kind suffix expand = T (Constant, { suffix; kind; expand })\n\n let attr_str_type_decl attribute expand =\n T (Attr_str_type_decl, T { attribute; expand; expect = false })\n\n let attr_sig_type_decl attribute expand =\n T (Attr_sig_type_decl, T { attribute; expand; expect = false })\n\n let attr_str_module_type_decl attribute expand =\n T (Attr_str_module_type_decl, T { attribute; expand; expect = false })\n\n let attr_sig_module_type_decl attribute expand =\n T (Attr_sig_module_type_decl, T { attribute; expand; expect = false })\n\n let attr_str_type_ext attribute expand =\n T (Attr_str_type_ext, T { attribute; expand; expect = false })\n\n let attr_sig_type_ext attribute expand =\n T (Attr_sig_type_ext, T { attribute; expand; expect = false })\n\n let attr_str_exception attribute expand =\n T (Attr_str_exception, T { attribute; expand; expect = false })\n\n let attr_sig_exception attribute expand =\n T (Attr_sig_exception, T { attribute; expand; expect = false })\n\n let attr_str_type_decl_expect attribute expand =\n T (Attr_str_type_decl, T { attribute; expand; expect = true })\n\n let attr_sig_type_decl_expect attribute expand =\n T (Attr_sig_type_decl, T { attribute; expand; expect = true })\n\n let attr_str_module_type_decl_expect attribute expand =\n T (Attr_str_module_type_decl, T { attribute; expand; expect = true })\n\n let attr_sig_module_type_decl_expect attribute expand =\n T (Attr_sig_module_type_decl, T { attribute; expand; expect = true })\n\n let attr_str_type_ext_expect attribute expand =\n T (Attr_str_type_ext, T { attribute; expand; expect = true })\n\n let attr_sig_type_ext_expect attribute expand =\n T (Attr_sig_type_ext, T { attribute; expand; expect = true })\n\n let attr_str_exception_expect attribute expand =\n T (Attr_str_exception, T { attribute; expand; expect = true })\n\n let attr_sig_exception_expect attribute expand =\n T (Attr_sig_exception, T { attribute; expand; expect = true })\nend\n\nmodule Generated_code_hook = struct\n type 'a single_or_many = Single of 'a | Many of 'a list\n\n type t = {\n f : 'a. 'a Extension.Context.t -> Location.t -> 'a single_or_many -> unit;\n }\n\n let nop = { f = (fun _ _ _ -> ()) }\n let replace t context loc x = t.f context loc x\n\n let insert_after t context (loc : Location.t) x =\n match x with\n | Many [] -> ()\n | _ -> t.f context { loc with loc_start = loc.loc_end } x\nend\n\nlet rec map_node_rec context ts super_call loc base_ctxt x =\n let ctxt =\n Expansion_context.Extension.make ~extension_point_loc:loc ~base:base_ctxt ()\n in\n match EC.get_extension context x with\n | None -> super_call base_ctxt x\n | Some (ext, attrs) -> (\n match E.For_context.convert ts ~ctxt ext with\n | None -> super_call base_ctxt x\n | Some x ->\n map_node_rec context ts super_call loc base_ctxt\n (EC.merge_attributes context x attrs))\n\nlet map_node context ts super_call loc base_ctxt x ~hook =\n let ctxt =\n Expansion_context.Extension.make ~extension_point_loc:loc ~base:base_ctxt ()\n in\n match EC.get_extension context x with\n | None -> super_call base_ctxt x\n | Some (ext, attrs) -> (\n match E.For_context.convert ts ~ctxt ext with\n | None -> super_call base_ctxt x\n | Some x ->\n let generated_code =\n map_node_rec context ts super_call loc base_ctxt\n (EC.merge_attributes context x attrs)\n in\n Generated_code_hook.replace hook context loc (Single generated_code);\n generated_code)\n\nlet rec map_nodes context ts super_call get_loc base_ctxt l ~hook\n ~in_generated_code =\n match l with\n | [] -> []\n | x :: l -> (\n match EC.get_extension context x with\n | None ->\n (* These two lets force the evaluation order, so that errors are reported in the\n same order as they appear in the source file. *)\n let x = super_call base_ctxt x in\n let l =\n map_nodes context ts super_call get_loc base_ctxt l ~hook\n ~in_generated_code\n in\n x :: l\n | Some (ext, attrs) -> (\n let extension_point_loc = get_loc x in\n let ctxt =\n Expansion_context.Extension.make ~extension_point_loc\n ~base:base_ctxt ()\n in\n match E.For_context.convert_inline ts ~ctxt ext with\n | None ->\n let x = super_call base_ctxt x in\n let l =\n map_nodes context ts super_call get_loc base_ctxt l ~hook\n ~in_generated_code\n in\n x :: l\n | Some x ->\n assert_no_attributes attrs;\n let generated_code =\n map_nodes context ts super_call get_loc base_ctxt x ~hook\n ~in_generated_code:true\n in\n if not in_generated_code then\n Generated_code_hook.replace hook context extension_point_loc\n (Many generated_code);\n generated_code\n @ map_nodes context ts super_call get_loc base_ctxt l ~hook\n ~in_generated_code))\n\nlet map_nodes = map_nodes ~in_generated_code:false\n\nlet table_of_special_functions special_functions =\n match\n List.map special_functions\n ~f:(fun { Rule.Special_function.ident; expand; _ } -> (ident, expand))\n (* We expect the lookup to fail most of the time, by making the table big (and\n sparse), we make it more likely to fail quickly *)\n |> Hashtbl.of_alist ~size:(max 1024 (List.length special_functions * 2))\n with\n | Ok table -> table\n | Error ident ->\n Printf.ksprintf invalid_arg\n \"Context_free.V1.map_top_down: %s present twice in list of special \\\n functions\"\n (List.find_map_exn special_functions ~f:(fun r ->\n if Poly.equal r.ident ident then Some r.name else None))\n\n(* [get_group attr l] returns the list of the attributes for each\n node in [l].\n If [l] is empty or if none of the nodes in [l] have an attribute attached,\n [get_group] returns [None].\n If [l] is not empty and at least one of the nodes in [l] has an attribue\n attached, [get_group] returns the equivalent of\n [Some (List.map ~f:(Attribute.get attr) l)]. *)\nlet rec get_group attr l =\n match l with\n | [] -> None\n | x :: l -> (\n match (Attribute.get attr x, get_group attr l) with\n | None, None -> None\n | None, Some vals -> Some (None :: vals)\n | Some value, None -> Some (Some value :: List.map l ~f:(fun _ -> None))\n | Some value, Some vals -> Some (Some value :: vals))\n\n(* Same as [List.rev] then [List.concat] but expecting the input to be of length <= 2 *)\nlet rev_concat = function\n | [] -> []\n | [ x ] -> x\n | [ x; y ] -> y @ x\n | l -> List.concat (List.rev l)\n\nlet sort_attr_group_inline l =\n List.sort l ~cmp:(fun a b ->\n String.compare\n (Rule.Attr_group_inline.attr_name a)\n (Rule.Attr_group_inline.attr_name b))\n\nlet sort_attr_inline l =\n List.sort l ~cmp:(fun a b ->\n String.compare\n (Rule.Attr_inline.attr_name a)\n (Rule.Attr_inline.attr_name b))\n\nlet context_free_attribute_modification ~loc =\n Location.raise_errorf ~loc\n \"A context-free rule deleted or added attribues of a str/sig item\"\n\n(* Returns the code generated by attribute handlers. We don't remove these attributes, as\n another pass might interpret them later. For instance both ppx_deriving and\n ppxlib_deriving interprets [@@deriving] attributes.\n\n This complexity is horrible, but in practice we don't care as [attrs] is always a list\n of one element; it only has [@@deriving].\n*)\nlet handle_attr_group_inline attrs rf ~items ~expanded_items ~loc ~base_ctxt =\n List.fold_left attrs ~init:[] ~f:(fun acc (Rule.Attr_group_inline.T group) ->\n match\n ( get_group group.attribute items,\n get_group group.attribute expanded_items )\n with\n | None, None -> acc\n | None, Some _ | Some _, None -> context_free_attribute_modification ~loc\n | Some values, Some _ ->\n let ctxt =\n Expansion_context.Deriver.make ~derived_item_loc:loc\n ~inline:group.expect ~base:base_ctxt ()\n in\n let expect_items = group.expand ~ctxt rf expanded_items values in\n expect_items :: acc)\n\nlet handle_attr_inline attrs ~item ~expanded_item ~loc ~base_ctxt =\n List.fold_left attrs ~init:[] ~f:(fun acc (Rule.Attr_inline.T a) ->\n match\n (Attribute.get a.attribute item, Attribute.get a.attribute expanded_item)\n with\n | None, None -> acc\n | None, Some _ | Some _, None -> context_free_attribute_modification ~loc\n | Some value, Some _ ->\n let ctxt =\n Expansion_context.Deriver.make ~derived_item_loc:loc\n ~inline:a.expect ~base:base_ctxt ()\n in\n let expect_items = a.expand ~ctxt expanded_item value in\n expect_items :: acc)\n\nmodule Expect_mismatch_handler = struct\n type t = {\n f : 'a. 'a Attribute.Floating.Context.t -> Location.t -> 'a list -> unit;\n }\n\n let nop = { f = (fun _ _ _ -> ()) }\nend\n\nclass map_top_down ?(expect_mismatch_handler = Expect_mismatch_handler.nop)\n ?(generated_code_hook = Generated_code_hook.nop) rules =\n let hook = generated_code_hook in\n\n let special_functions =\n Rule.filter Special_function rules |> table_of_special_functions\n in\n let constants =\n Rule.filter Constant rules\n |> List.map ~f:(fun (c : Rule.Constant.t) -> ((c.suffix, c.kind), c.expand))\n |> Hashtbl.of_alist_exn\n in\n let extensions = Rule.filter Extension rules in\n let class_expr = E.filter_by_context EC.class_expr extensions\n and class_field = E.filter_by_context EC.class_field extensions\n and class_type = E.filter_by_context EC.class_type extensions\n and class_type_field = E.filter_by_context EC.class_type_field extensions\n and core_type = E.filter_by_context EC.core_type extensions\n and expression = E.filter_by_context EC.expression extensions\n and module_expr = E.filter_by_context EC.module_expr extensions\n and module_type = E.filter_by_context EC.module_type extensions\n and pattern = E.filter_by_context EC.pattern extensions\n and signature_item = E.filter_by_context EC.signature_item extensions\n and structure_item = E.filter_by_context EC.structure_item extensions\n and ppx_import = E.filter_by_context EC.Ppx_import extensions in\n\n let attr_str_type_decls, attr_str_type_decls_expect =\n Rule.filter Attr_str_type_decl rules\n |> sort_attr_group_inline |> Rule.Attr_group_inline.split_normal_and_expect\n in\n let attr_sig_type_decls, attr_sig_type_decls_expect =\n Rule.filter Attr_sig_type_decl rules\n |> sort_attr_group_inline |> Rule.Attr_group_inline.split_normal_and_expect\n in\n\n let attr_str_module_type_decls, attr_str_module_type_decls_expect =\n Rule.filter Attr_str_module_type_decl rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n let attr_sig_module_type_decls, attr_sig_module_type_decls_expect =\n Rule.filter Attr_sig_module_type_decl rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n\n let attr_str_type_exts, attr_str_type_exts_expect =\n Rule.filter Attr_str_type_ext rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n let attr_sig_type_exts, attr_sig_type_exts_expect =\n Rule.filter Attr_sig_type_ext rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n\n let attr_str_exceptions, attr_str_exceptions_expect =\n Rule.filter Attr_str_exception rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n let attr_sig_exceptions, attr_sig_exceptions_expect =\n Rule.filter Attr_sig_exception rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n\n let map_node = map_node ~hook in\n let map_nodes = map_nodes ~hook in\n\n object (self)\n inherit Ast_traverse.map_with_expansion_context as super\n\n (* No point recursing into every location *)\n method! location _ x = x\n\n method! core_type base_ctxt x =\n map_node EC.core_type core_type super#core_type x.ptyp_loc base_ctxt x\n\n method! pattern base_ctxt x =\n map_node EC.pattern pattern super#pattern x.ppat_loc base_ctxt x\n\n method! expression base_ctxt e =\n let e =\n match e.pexp_desc with\n | Pexp_extension _ ->\n map_node EC.expression expression\n (fun _ e -> e)\n e.pexp_loc base_ctxt e\n | _ -> e\n in\n let expand_constant kind char text =\n match Hashtbl.find_opt constants (char, kind) with\n | None -> super#expression base_ctxt e\n | Some expand -> self#expression base_ctxt (expand e.pexp_loc text)\n in\n match e.pexp_desc with\n | Pexp_apply (({ pexp_desc = Pexp_ident id; _ } as func), args) -> (\n match Hashtbl.find_opt special_functions id.txt with\n | None ->\n self#pexp_apply_without_traversing_function base_ctxt e func args\n | Some pattern -> (\n match pattern e with\n | None ->\n self#pexp_apply_without_traversing_function base_ctxt e func\n args\n | Some e -> self#expression base_ctxt e))\n | Pexp_ident id -> (\n match Hashtbl.find_opt special_functions id.txt with\n | None -> super#expression base_ctxt e\n | Some pattern -> (\n match pattern e with\n | None -> super#expression base_ctxt e\n | Some e -> self#expression base_ctxt e))\n | Pexp_constant (Pconst_integer (s, Some c)) ->\n expand_constant Integer c s\n | Pexp_constant (Pconst_float (s, Some c)) -> expand_constant Float c s\n | _ -> super#expression base_ctxt e\n\n (* Pre-conditions:\n - e.pexp_desc = Pexp_apply(func, args)\n - func.pexp_desc = Pexp_ident _\n *)\n method private pexp_apply_without_traversing_function base_ctxt e func args\n =\n let { pexp_desc = _; pexp_loc; pexp_attributes; pexp_loc_stack } = e in\n let func =\n let { pexp_desc; pexp_loc; pexp_attributes; pexp_loc_stack } = func in\n let pexp_attributes = self#attributes base_ctxt pexp_attributes in\n {\n pexp_desc;\n pexp_loc (* location doesn't need to be traversed *);\n pexp_attributes;\n pexp_loc_stack;\n }\n in\n let args =\n List.map args ~f:(fun (lab, exp) ->\n (lab, self#expression base_ctxt exp))\n in\n let pexp_attributes = self#attributes base_ctxt pexp_attributes in\n {\n pexp_loc;\n pexp_attributes;\n pexp_desc = Pexp_apply (func, args);\n pexp_loc_stack;\n }\n\n method! class_type base_ctxt x =\n map_node EC.class_type class_type super#class_type x.pcty_loc base_ctxt x\n\n method! class_type_field base_ctxt x =\n map_node EC.class_type_field class_type_field super#class_type_field\n x.pctf_loc base_ctxt x\n\n method! class_expr base_ctxt x =\n map_node EC.class_expr class_expr super#class_expr x.pcl_loc base_ctxt x\n\n method! class_field base_ctxt x =\n map_node EC.class_field class_field super#class_field x.pcf_loc base_ctxt\n x\n\n method! module_type base_ctxt x =\n map_node EC.module_type module_type super#module_type x.pmty_loc base_ctxt\n x\n\n method! module_expr base_ctxt x =\n map_node EC.module_expr module_expr super#module_expr x.pmod_loc base_ctxt\n x\n\n method! structure_item base_ctxt x =\n map_node EC.structure_item structure_item super#structure_item x.pstr_loc\n base_ctxt x\n\n method! signature_item base_ctxt x =\n map_node EC.signature_item signature_item super#signature_item x.psig_loc\n base_ctxt x\n\n method! class_structure base_ctxt { pcstr_self; pcstr_fields } =\n let pcstr_self = self#pattern base_ctxt pcstr_self in\n let pcstr_fields =\n map_nodes EC.class_field class_field super#class_field\n (fun x -> x.pcf_loc)\n base_ctxt pcstr_fields\n in\n { pcstr_self; pcstr_fields }\n\n method! type_declaration base_ctxt x =\n map_node EC.Ppx_import ppx_import super#type_declaration x.ptype_loc\n base_ctxt x\n\n method! class_signature base_ctxt { pcsig_self; pcsig_fields } =\n let pcsig_self = self#core_type base_ctxt pcsig_self in\n let pcsig_fields =\n map_nodes EC.class_type_field class_type_field super#class_type_field\n (fun x -> x.pctf_loc)\n base_ctxt pcsig_fields\n in\n { pcsig_self; pcsig_fields }\n\n (* TODO: try to factorize #structure and #signature without meta-programming *)\n (*$*)\n method! structure base_ctxt st =\n let rec with_extra_items item ~extra_items ~expect_items ~rest\n ~in_generated_code =\n let extra_items =\n loop (rev_concat extra_items) ~in_generated_code:true\n in\n if not in_generated_code then\n Generated_code_hook.insert_after hook Structure_item item.pstr_loc\n (Many extra_items);\n let original_rest = rest in\n let rest = loop rest ~in_generated_code in\n (match expect_items with\n | [] -> ()\n | _ ->\n let expected = rev_concat expect_items in\n let pos = item.pstr_loc.loc_end in\n Code_matcher.match_structure original_rest ~pos ~expected\n ~mismatch_handler:(fun loc repl ->\n expect_mismatch_handler.f Structure_item loc repl));\n item :: (extra_items @ rest)\n and loop st ~in_generated_code =\n match st with\n | [] -> []\n | item :: rest -> (\n let loc = item.pstr_loc in\n match item.pstr_desc with\n | Pstr_extension (ext, attrs) -> (\n let extension_point_loc = item.pstr_loc in\n let ctxt =\n Expansion_context.Extension.make ~extension_point_loc\n ~base:base_ctxt ()\n in\n match E.For_context.convert_inline structure_item ~ctxt ext with\n | None ->\n let item = super#structure_item base_ctxt item in\n let rest = self#structure base_ctxt rest in\n item :: rest\n | Some items ->\n assert_no_attributes attrs;\n let items = loop items ~in_generated_code:true in\n if not in_generated_code then\n Generated_code_hook.replace hook Structure_item\n item.pstr_loc (Many items);\n items @ loop rest ~in_generated_code)\n | _ -> (\n let expanded_item = super#structure_item base_ctxt item in\n match (item.pstr_desc, expanded_item.pstr_desc) with\n | Pstr_type (rf, tds), Pstr_type (exp_rf, exp_tds) ->\n (* No context-free rule can rewrite rec flags atm, this\n assert acts as a failsafe in case it ever changes *)\n assert (Poly.(rf = exp_rf));\n let extra_items =\n handle_attr_group_inline attr_str_type_decls rf ~items:tds\n ~expanded_items:exp_tds ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_group_inline attr_str_type_decls_expect rf\n ~items:tds ~expanded_items:exp_tds ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Pstr_modtype mtd, Pstr_modtype exp_mtd ->\n let extra_items =\n handle_attr_inline attr_str_module_type_decls ~item:mtd\n ~expanded_item:exp_mtd ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_str_module_type_decls_expect\n ~item:mtd ~expanded_item:exp_mtd ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Pstr_typext te, Pstr_typext exp_te ->\n let extra_items =\n handle_attr_inline attr_str_type_exts ~item:te\n ~expanded_item:exp_te ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_str_type_exts_expect ~item:te\n ~expanded_item:exp_te ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Pstr_exception ec, Pstr_exception exp_ec ->\n let extra_items =\n handle_attr_inline attr_str_exceptions ~item:ec\n ~expanded_item:exp_ec ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_str_exceptions_expect ~item:ec\n ~expanded_item:exp_ec ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | _, _ ->\n let rest = self#structure base_ctxt rest in\n expanded_item :: rest))\n in\n loop st ~in_generated_code:false\n\n (*$ str_to_sig _last_text_block *)\n method! signature base_ctxt sg =\n let rec with_extra_items item ~extra_items ~expect_items ~rest\n ~in_generated_code =\n let extra_items =\n loop (rev_concat extra_items) ~in_generated_code:true\n in\n if not in_generated_code then\n Generated_code_hook.insert_after hook Signature_item item.psig_loc\n (Many extra_items);\n let original_rest = rest in\n let rest = loop rest ~in_generated_code in\n (match expect_items with\n | [] -> ()\n | _ ->\n let expected = rev_concat expect_items in\n let pos = item.psig_loc.loc_end in\n Code_matcher.match_signature original_rest ~pos ~expected\n ~mismatch_handler:(fun loc repl ->\n expect_mismatch_handler.f Signature_item loc repl));\n item :: (extra_items @ rest)\n and loop sg ~in_generated_code =\n match sg with\n | [] -> []\n | item :: rest -> (\n let loc = item.psig_loc in\n match item.psig_desc with\n | Psig_extension (ext, attrs) -> (\n let extension_point_loc = item.psig_loc in\n let ctxt =\n Expansion_context.Extension.make ~extension_point_loc\n ~base:base_ctxt ()\n in\n match E.For_context.convert_inline signature_item ~ctxt ext with\n | None ->\n let item = super#signature_item base_ctxt item in\n let rest = self#signature base_ctxt rest in\n item :: rest\n | Some items ->\n assert_no_attributes attrs;\n let items = loop items ~in_generated_code:true in\n if not in_generated_code then\n Generated_code_hook.replace hook Signature_item\n item.psig_loc (Many items);\n items @ loop rest ~in_generated_code)\n | _ -> (\n let expanded_item = super#signature_item base_ctxt item in\n match (item.psig_desc, expanded_item.psig_desc) with\n | Psig_type (rf, tds), Psig_type (exp_rf, exp_tds) ->\n (* No context-free rule can rewrite rec flags atm, this\n assert acts as a failsafe in case it ever changes *)\n assert (Poly.(rf = exp_rf));\n let extra_items =\n handle_attr_group_inline attr_sig_type_decls rf ~items:tds\n ~expanded_items:exp_tds ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_group_inline attr_sig_type_decls_expect rf\n ~items:tds ~expanded_items:exp_tds ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Psig_modtype mtd, Psig_modtype exp_mtd ->\n let extra_items =\n handle_attr_inline attr_sig_module_type_decls ~item:mtd\n ~expanded_item:exp_mtd ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_sig_module_type_decls_expect\n ~item:mtd ~expanded_item:exp_mtd ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Psig_typext te, Psig_typext exp_te ->\n let extra_items =\n handle_attr_inline attr_sig_type_exts ~item:te\n ~expanded_item:exp_te ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_sig_type_exts_expect ~item:te\n ~expanded_item:exp_te ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Psig_exception ec, Psig_exception exp_ec ->\n let extra_items =\n handle_attr_inline attr_sig_exceptions ~item:ec\n ~expanded_item:exp_ec ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_sig_exceptions_expect ~item:ec\n ~expanded_item:exp_ec ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | _, _ ->\n let rest = self#signature base_ctxt rest in\n expanded_item :: rest))\n in\n loop sg ~in_generated_code:false\n\n (*$*)\n end\n","(*$ open Ppxlib_cinaps_helpers $*)\nopen Import\nopen Utils\nmodule Arg = Caml.Arg\n\nlet exe_name = Caml.Filename.basename Caml.Sys.executable_name\nlet args = ref []\nlet add_arg key spec ~doc = args := (key, spec, doc) :: !args\nlet loc_fname = ref None\nlet perform_checks = ref Options.perform_checks\nlet perform_checks_on_extensions = ref Options.perform_checks_on_extensions\nlet perform_locations_check = ref Options.perform_locations_check\nlet debug_attribute_drop = ref false\nlet apply_list = ref None\nlet preprocessor = ref None\nlet no_merge = ref false\nlet request_print_passes = ref false\nlet request_print_transformations = ref false\nlet use_color = ref true\nlet diff_command = ref Options.diff_command\nlet pretty = ref false\nlet styler = ref None\nlet output_metadata_filename = ref None\nlet corrected_suffix = ref \".ppx-corrected\"\n\nmodule Lint_error = struct\n type t = Location.t * string\n\n let of_string loc s = (loc, s)\nend\n\nmodule Cookies = struct\n type t = T\n\n let given_through_cli = ref []\n\n let get T name pattern =\n Option.map (Astlib.Ast_metadata.get_cookie name) ~f:(fun e ->\n let e = Selected_ast.of_ocaml Expression e in\n Ast_pattern.parse pattern e.pexp_loc e Fn.id)\n\n let set T name expr =\n Astlib.Ast_metadata.set_cookie name (Selected_ast.to_ocaml Expression expr)\n\n let handlers = ref []\n let add_handler f = handlers := !handlers @ [ f ]\n\n let add_simple_handler name pattern ~f =\n add_handler (fun T -> f (get T name pattern))\n\n let acknowledge_cookies T = List.iter !handlers ~f:(fun f -> f T)\n let post_handlers = ref []\n let add_post_handler f = post_handlers := !post_handlers @ [ f ]\n let call_post_handlers T = List.iter !post_handlers ~f:(fun f -> f T)\nend\n\nmodule Instrument = struct\n type pos = Before | After\n\n type t = {\n transformation :\n Expansion_context.Base.t -> Parsetree.structure -> Parsetree.structure;\n position : pos;\n }\n\n module V2 = struct\n let make transformation ~position = { transformation; position }\n end\n\n let make transformation ~position =\n let transformation _ st = transformation st in\n V2.make transformation ~position\nend\n\nmodule Transform = struct\n type t = {\n name : string;\n aliases : string list;\n impl :\n (Expansion_context.Base.t -> Parsetree.structure -> Parsetree.structure)\n option;\n intf :\n (Expansion_context.Base.t -> Parsetree.signature -> Parsetree.signature)\n option;\n lint_impl :\n (Expansion_context.Base.t -> Parsetree.structure -> Lint_error.t list)\n option;\n lint_intf :\n (Expansion_context.Base.t -> Parsetree.signature -> Lint_error.t list)\n option;\n preprocess_impl :\n (Expansion_context.Base.t -> Parsetree.structure -> Parsetree.structure)\n option;\n preprocess_intf :\n (Expansion_context.Base.t -> Parsetree.signature -> Parsetree.signature)\n option;\n enclose_impl :\n (Expansion_context.Base.t ->\n Location.t option ->\n Parsetree.structure * Parsetree.structure)\n option;\n enclose_intf :\n (Expansion_context.Base.t ->\n Location.t option ->\n Parsetree.signature * Parsetree.signature)\n option;\n instrument : Instrument.t option;\n rules : Context_free.Rule.t list;\n registered_at : Caller_id.t;\n }\n\n let has_name t name =\n String.equal name t.name || List.exists ~f:(String.equal name) t.aliases\n\n let all : t list ref = ref []\n\n let print_caller_id oc (caller_id : Caller_id.t) =\n match caller_id with\n | None -> output_string oc \"\"\n | Some loc -> Printf.fprintf oc \"%s:%d\" loc.filename loc.line_number\n\n let register ?(extensions = []) ?(rules = []) ?enclose_impl ?enclose_intf\n ?impl ?intf ?lint_impl ?lint_intf ?preprocess_impl ?preprocess_intf\n ?instrument ?(aliases = []) name =\n let rules = List.map extensions ~f:Context_free.Rule.extension @ rules in\n let caller_id = Caller_id.get ~skip:[ Caml.__FILE__ ] in\n (match List.filter !all ~f:(fun ct -> has_name ct name) with\n | [] -> ()\n | ct :: _ ->\n Printf.eprintf \"Warning: code transformation %s registered twice.\\n\"\n name;\n Printf.eprintf \" - first time was at %a\\n\" print_caller_id\n ct.registered_at;\n Printf.eprintf \" - second time is at %a\\n\" print_caller_id caller_id);\n let ct =\n {\n name;\n aliases;\n rules;\n enclose_impl;\n enclose_intf;\n impl;\n intf;\n lint_impl;\n preprocess_impl;\n preprocess_intf;\n lint_intf;\n instrument;\n registered_at = caller_id;\n }\n in\n all := ct :: !all\n\n let rec last prev l = match l with [] -> prev | x :: l -> last x l\n\n let loc_of_list ~get_loc l =\n match l with\n | [] -> None\n | x :: l ->\n let first : Location.t = get_loc x in\n let last = get_loc (last x l) in\n Some { first with loc_end = last.loc_end }\n\n let merge_into_generic_mappers t ~hook ~expect_mismatch_handler ~tool_name\n ~input_name =\n let { rules; enclose_impl; enclose_intf; impl; intf; _ } = t in\n let map =\n new Context_free.map_top_down\n rules ~generated_code_hook:hook ~expect_mismatch_handler\n in\n let gen_header_and_footer context whole_loc f =\n let header, footer = f whole_loc in\n (match whole_loc with\n | Some (loc : Location.t) -> (\n let loc_header = { loc with loc_end = loc.loc_start } in\n let loc_footer = { loc with loc_start = loc.loc_end } in\n (match header with\n | [] -> ()\n | _ -> hook.f context loc_header (Many header));\n match footer with\n | [] -> ()\n | _ -> hook.f context loc_footer (Many footer))\n | None -> (\n match header @ footer with\n | [] -> ()\n | l ->\n let pos =\n {\n Lexing.pos_fname = \"\";\n pos_lnum = 1;\n pos_bol = 0;\n pos_cnum = 0;\n }\n in\n let loc =\n { Location.loc_start = pos; loc_end = pos; loc_ghost = false }\n in\n hook.f context loc (Many l)));\n (header, footer)\n in\n let input_name =\n match input_name with Some input_name -> input_name | None -> \"_none_\"\n in\n let map_impl ctxt st_with_attrs =\n let st =\n let attrs, st =\n List.split_while st_with_attrs ~f:(function\n | { pstr_desc = Pstr_attribute _; _ } -> true\n | _ -> false)\n in\n let file_path = File_path.get_default_path_str st in\n let base_ctxt =\n Expansion_context.Base.top_level ~tool_name ~file_path ~input_name\n in\n let header, footer =\n match enclose_impl with\n | None -> ([], [])\n | Some f ->\n let whole_loc =\n loc_of_list st ~get_loc:(fun st -> st.Parsetree.pstr_loc)\n in\n gen_header_and_footer Structure_item whole_loc (f base_ctxt)\n in\n let attrs = map#structure base_ctxt attrs in\n let st = map#structure base_ctxt st in\n List.concat [ attrs; header; st; footer ]\n in\n match impl with None -> st | Some f -> f ctxt st\n in\n let map_intf ctxt sg_with_attrs =\n let sg =\n let attrs, sg =\n List.split_while sg_with_attrs ~f:(function\n | { psig_desc = Psig_attribute _; _ } -> true\n | _ -> false)\n in\n let file_path = File_path.get_default_path_sig sg in\n let base_ctxt =\n Expansion_context.Base.top_level ~tool_name ~file_path ~input_name\n in\n let header, footer =\n match enclose_intf with\n | None -> ([], [])\n | Some f ->\n let whole_loc =\n loc_of_list sg ~get_loc:(fun sg -> sg.Parsetree.psig_loc)\n in\n gen_header_and_footer Signature_item whole_loc (f base_ctxt)\n in\n let attrs = map#signature base_ctxt attrs in\n let sg = map#signature base_ctxt sg in\n List.concat [ attrs; header; sg; footer ]\n in\n match intf with None -> sg | Some f -> f ctxt sg\n in\n { t with impl = Some map_impl; intf = Some map_intf }\n\n let builtin_of_context_free_rewriters ~hook ~rules ~enclose_impl ~enclose_intf\n ~input_name =\n merge_into_generic_mappers ~hook ~input_name\n {\n name = \"\";\n aliases = [];\n impl = None;\n intf = None;\n lint_impl = None;\n lint_intf = None;\n preprocess_impl = None;\n preprocess_intf = None;\n enclose_impl;\n enclose_intf;\n instrument = None;\n rules;\n registered_at = Caller_id.get ~skip:[];\n }\n\n let partition_transformations ts =\n let before_instrs, after_instrs, rest =\n List.fold_left ts ~init:([], [], []) ~f:(fun (bef_i, aft_i, rest) t ->\n let reduced_t =\n {\n t with\n lint_impl = None;\n lint_intf = None;\n preprocess_impl = None;\n preprocess_intf = None;\n }\n in\n let f instr =\n (instr.Instrument.position, instr.Instrument.transformation)\n in\n match Option.map t.instrument ~f with\n | Some (Before, transf) ->\n ( { reduced_t with impl = Some transf; rules = [] } :: bef_i,\n aft_i,\n reduced_t :: rest )\n | Some (After, transf) ->\n ( bef_i,\n { reduced_t with impl = Some transf; rules = [] } :: aft_i,\n reduced_t :: rest )\n | None -> (bef_i, aft_i, reduced_t :: rest))\n in\n ( `Linters\n (List.filter_map ts ~f:(fun t ->\n if Option.is_some t.lint_impl || Option.is_some t.lint_intf then\n Some\n {\n name = Printf.sprintf \"\" t.name;\n aliases = [];\n impl = None;\n intf = None;\n lint_impl = t.lint_impl;\n lint_intf = t.lint_intf;\n enclose_impl = None;\n enclose_intf = None;\n preprocess_impl = None;\n preprocess_intf = None;\n instrument = None;\n rules = [];\n registered_at = t.registered_at;\n }\n else None)),\n `Preprocess\n (List.filter_map ts ~f:(fun t ->\n if\n Option.is_some t.preprocess_impl\n || Option.is_some t.preprocess_intf\n then\n Some\n {\n name = Printf.sprintf \"\" t.name;\n aliases = [];\n impl = t.preprocess_impl;\n intf = t.preprocess_intf;\n lint_impl = None;\n lint_intf = None;\n enclose_impl = None;\n enclose_intf = None;\n preprocess_impl = None;\n preprocess_intf = None;\n instrument = None;\n rules = [];\n registered_at = t.registered_at;\n }\n else None)),\n `Before_instrs before_instrs,\n `After_instrs after_instrs,\n `Rest rest )\nend\n\nmodule V2 = struct\n let register_transformation = Transform.register\n\n let register_transformation_using_ocaml_current_ast ?impl ?intf ?aliases name\n =\n let impl =\n Option.map impl ~f:(Ppxlib_ast.Selected_ast.of_ocaml_mapper Structure)\n in\n let intf =\n Option.map intf ~f:(Ppxlib_ast.Selected_ast.of_ocaml_mapper Signature)\n in\n register_transformation ?impl ?intf ?aliases name\nend\n\nlet add_ctxt_arg (f : 'a -> 'b) : Expansion_context.Base.t -> 'a -> 'b =\n fun _ x -> f x\n\nlet register_transformation ?extensions ?rules ?enclose_impl ?enclose_intf ?impl\n ?intf ?lint_impl ?lint_intf ?preprocess_impl ?preprocess_intf =\n let impl = Option.map impl ~f:add_ctxt_arg in\n let intf = Option.map intf ~f:add_ctxt_arg in\n let preprocess_impl = Option.map preprocess_impl ~f:add_ctxt_arg in\n let preprocess_intf = Option.map preprocess_intf ~f:add_ctxt_arg in\n let lint_impl = Option.map lint_impl ~f:add_ctxt_arg in\n let lint_intf = Option.map lint_intf ~f:add_ctxt_arg in\n let enclose_impl = Option.map enclose_impl ~f:add_ctxt_arg in\n let enclose_intf = Option.map enclose_intf ~f:add_ctxt_arg in\n V2.register_transformation ?extensions ?rules ?enclose_impl ?enclose_intf\n ?impl ?intf ?lint_impl ?lint_intf ?preprocess_impl ?preprocess_intf\n\nlet register_code_transformation ~name ?(aliases = []) ~impl ~intf =\n register_transformation name ~impl ~intf ~aliases\n [@@warning \"-16\"]\n(* This function triggers a warning 16 as of ocaml 4.12 *)\n\nlet register_transformation_using_ocaml_current_ast ?impl ?intf =\n let impl = Option.map impl ~f:add_ctxt_arg in\n let intf = Option.map intf ~f:add_ctxt_arg in\n V2.register_transformation_using_ocaml_current_ast ?impl ?intf\n\nlet debug_dropped_attribute name ~old_dropped ~new_dropped =\n let print_diff what a b =\n let diff =\n List.filter a ~f:(fun (name : _ Loc.t) ->\n not\n (List.exists b ~f:(fun (name' : _ Location.loc) ->\n name.txt == name'.txt)))\n in\n if not (List.is_empty diff) then (\n Printf.eprintf \"The following attributes %s after applying %s:\\n\" what\n name;\n List.iter diff ~f:(fun { Location.txt; loc } ->\n Caml.Format.eprintf \"- %a: %s\\n\" Location.print loc txt);\n Caml.Format.eprintf \"@.\")\n in\n print_diff \"disappeared\" new_dropped old_dropped;\n print_diff \"reappeared\" old_dropped new_dropped\n\nlet get_whole_ast_passes ~hook ~expect_mismatch_handler ~tool_name ~input_name =\n let cts =\n match !apply_list with\n | None -> List.rev !Transform.all\n | Some names ->\n List.map names ~f:(fun name ->\n List.find !Transform.all ~f:(fun (ct : Transform.t) ->\n Transform.has_name ct name))\n in\n let ( `Linters linters,\n `Preprocess preprocess,\n `Before_instrs before_instrs,\n `After_instrs after_instrs,\n `Rest cts ) =\n Transform.partition_transformations cts\n in\n (* Allow only one preprocessor to assure deterministic order *)\n (if List.length preprocess > 1 then\n let pp =\n String.concat ~sep:\", \" (List.map preprocess ~f:(fun t -> t.name))\n in\n let err =\n Printf.sprintf \"At most one preprocessor is allowed, while got: %s\" pp\n in\n failwith err);\n let make_generic transforms =\n if !no_merge then\n List.map transforms\n ~f:\n (Transform.merge_into_generic_mappers ~hook ~tool_name\n ~expect_mismatch_handler ~input_name)\n else\n (let get_enclosers ~f =\n List.filter_map transforms ~f:(fun (ct : Transform.t) ->\n match f ct with None -> None | Some x -> Some (ct.name, x))\n (* Sort them to ensure deterministic ordering *)\n |> List.sort ~cmp:(fun (a, _) (b, _) -> String.compare a b)\n |> List.map ~f:snd\n in\n\n let rules =\n List.map transforms ~f:(fun (ct : Transform.t) -> ct.rules)\n |> List.concat\n and impl_enclosers = get_enclosers ~f:(fun ct -> ct.enclose_impl)\n and intf_enclosers = get_enclosers ~f:(fun ct -> ct.enclose_intf) in\n match (rules, impl_enclosers, intf_enclosers) with\n | [], [], [] -> transforms\n | _ ->\n let merge_encloser = function\n | [] -> None\n | enclosers ->\n Some\n (fun ctxt loc ->\n let headers, footers =\n List.map enclosers ~f:(fun f -> f ctxt loc) |> List.split\n in\n let headers = List.concat headers in\n let footers = List.concat (List.rev footers) in\n (headers, footers))\n in\n Transform.builtin_of_context_free_rewriters ~rules ~hook\n ~expect_mismatch_handler\n ~enclose_impl:(merge_encloser impl_enclosers)\n ~enclose_intf:(merge_encloser intf_enclosers)\n ~tool_name ~input_name\n :: transforms)\n |> List.filter ~f:(fun (ct : Transform.t) ->\n match (ct.impl, ct.intf) with None, None -> false | _ -> true)\n in\n linters @ preprocess @ before_instrs @ make_generic cts @ after_instrs\n\nlet apply_transforms (type t) ~tool_name ~file_path ~field ~lint_field\n ~dropped_so_far ~hook ~expect_mismatch_handler ~input_name ~f_exception\n ~embed_errors x =\n let exception\n Wrapper of t list * label loc list * (location * label) list * exn\n in\n let cts =\n get_whole_ast_passes ~tool_name ~hook ~expect_mismatch_handler ~input_name\n in\n let return (x, _dropped, lint_errors) =\n ( x,\n List.map lint_errors ~f:(fun (loc, s) ->\n Common.attribute_of_warning loc s) )\n in\n try\n let acc =\n List.fold_left cts ~init:(x, [], [])\n ~f:(fun (x, dropped, (lint_errors : _ list)) (ct : Transform.t) ->\n let input_name =\n match input_name with\n | Some input_name -> input_name\n | None -> \"_none_\"\n in\n let ctxt =\n Expansion_context.Base.top_level ~tool_name ~file_path ~input_name\n in\n let lint_errors =\n match lint_field ct with\n | None -> lint_errors\n | Some f -> (\n try lint_errors @ f ctxt x\n with exn when embed_errors ->\n raise @@ Wrapper (x, dropped, lint_errors, exn))\n in\n match field ct with\n | None -> (x, dropped, lint_errors)\n | Some f ->\n let x =\n try f ctxt x\n with exn when embed_errors ->\n raise @@ Wrapper (x, dropped, lint_errors, exn)\n in\n let dropped =\n if !debug_attribute_drop then (\n let new_dropped = dropped_so_far x in\n debug_dropped_attribute ct.name ~old_dropped:dropped\n ~new_dropped;\n new_dropped)\n else []\n in\n (x, dropped, lint_errors))\n in\n Ok (return acc)\n with Wrapper (x, dropped, lint_errors, exn) ->\n Error (return (f_exception exn :: x, dropped, lint_errors))\n\n(*$*)\n\nlet error_to_str_extension error =\n let loc = Location.none in\n let ext = Location.Error.to_extension error in\n Ast_builder.Default.pstr_extension ~loc ext []\n\nlet exn_to_str_extension exn =\n match Location.Error.of_exn exn with\n | None -> raise exn\n | Some error -> error_to_str_extension error\n\n(*$ str_to_sig _last_text_block *)\n\nlet error_to_sig_extension error =\n let loc = Location.none in\n let ext = Location.Error.to_extension error in\n Ast_builder.Default.psig_extension ~loc ext []\n\nlet exn_to_sig_extension exn =\n match Location.Error.of_exn exn with\n | None -> raise exn\n | Some error -> error_to_sig_extension error\n\n(*$*)\n\nlet error_to_extension error ~(kind : Kind.t) =\n match kind with\n | Intf -> Intf_or_impl.Intf [ error_to_sig_extension error ]\n | Impl -> Intf_or_impl.Impl [ error_to_str_extension error ]\n\nlet exn_to_extension exn ~(kind : Kind.t) =\n match Location.Error.of_exn exn with\n | None -> raise exn\n | Some error -> error_to_extension error ~kind\n\n(* +-----------------------------------------------------------------+\n | Actual rewriting of structure/signatures |\n +-----------------------------------------------------------------+ *)\n\nlet print_passes () =\n let tool_name = \"ppxlib_driver\" in\n let hook = Context_free.Generated_code_hook.nop in\n let expect_mismatch_handler = Context_free.Expect_mismatch_handler.nop in\n let cts =\n get_whole_ast_passes ~hook ~expect_mismatch_handler ~tool_name\n ~input_name:None\n in\n if !perform_checks then\n Printf.printf \"\\n\";\n List.iter cts ~f:(fun ct -> Printf.printf \"%s\\n\" ct.Transform.name);\n if !perform_checks then (\n Printf.printf \"\\n\";\n if !perform_checks_on_extensions then\n Printf.printf \"\\n\")\n\n(*$*)\n\nlet map_structure_gen st ~tool_name ~hook ~expect_mismatch_handler ~input_name\n ~embed_errors =\n Cookies.acknowledge_cookies T;\n if !perform_checks then (\n Attribute.reset_checks ();\n Attribute.collect#structure st);\n let lint lint_errors st =\n let st =\n match lint_errors with\n | [] -> st\n | _ ->\n List.map lint_errors\n ~f:(fun ({ attr_name = { loc; _ }; _ } as attr) ->\n Ast_builder.Default.pstr_attribute ~loc attr)\n @ st\n in\n st\n in\n let cookies_and_check st =\n Cookies.call_post_handlers T;\n if !perform_checks then (\n (* TODO: these two passes could be merged, we now have more passes for\n checks than for actual rewriting. *)\n Attribute.check_unused#structure st;\n if !perform_checks_on_extensions then Extension.check_unused#structure st;\n Attribute.check_all_seen ();\n if !perform_locations_check then\n let open Location_check in\n ignore\n ((enforce_invariants !loc_fname)#structure st\n Non_intersecting_ranges.empty\n : Non_intersecting_ranges.t));\n st\n in\n let file_path = File_path.get_default_path_str st in\n match\n apply_transforms st ~tool_name ~file_path\n ~field:(fun (ct : Transform.t) -> ct.impl)\n ~lint_field:(fun (ct : Transform.t) -> ct.lint_impl)\n ~dropped_so_far:Attribute.dropped_so_far_structure ~hook\n ~expect_mismatch_handler ~input_name\n ~f_exception:(fun exn -> exn_to_str_extension exn)\n ~embed_errors\n with\n | Error (st, lint_errors) -> Error (lint lint_errors st)\n | Ok (st, lint_errors) -> Ok (st |> lint lint_errors |> cookies_and_check)\n\nlet map_structure st =\n match\n map_structure_gen st\n ~tool_name:(Astlib.Ast_metadata.tool_name ())\n ~hook:Context_free.Generated_code_hook.nop\n ~expect_mismatch_handler:Context_free.Expect_mismatch_handler.nop\n ~input_name:None ~embed_errors:false\n with\n | Ok ast | Error ast -> ast\n\n(*$ str_to_sig _last_text_block *)\n\nlet map_signature_gen sg ~tool_name ~hook ~expect_mismatch_handler ~input_name\n ~embed_errors =\n Cookies.acknowledge_cookies T;\n if !perform_checks then (\n Attribute.reset_checks ();\n Attribute.collect#signature sg);\n let lint lint_errors sg =\n let sg =\n match lint_errors with\n | [] -> sg\n | _ ->\n List.map lint_errors\n ~f:(fun ({ attr_name = { loc; _ }; _ } as attr) ->\n Ast_builder.Default.psig_attribute ~loc attr)\n @ sg\n in\n sg\n in\n let cookies_and_check sg =\n Cookies.call_post_handlers T;\n if !perform_checks then (\n (* TODO: these two passes could be merged, we now have more passes for\n checks than for actual rewriting. *)\n Attribute.check_unused#signature sg;\n if !perform_checks_on_extensions then Extension.check_unused#signature sg;\n Attribute.check_all_seen ();\n if !perform_locations_check then\n let open Location_check in\n ignore\n ((enforce_invariants !loc_fname)#signature sg\n Non_intersecting_ranges.empty\n : Non_intersecting_ranges.t));\n sg\n in\n let file_path = File_path.get_default_path_sig sg in\n match\n apply_transforms sg ~tool_name ~file_path\n ~field:(fun (ct : Transform.t) -> ct.intf)\n ~lint_field:(fun (ct : Transform.t) -> ct.lint_intf)\n ~dropped_so_far:Attribute.dropped_so_far_signature ~hook\n ~expect_mismatch_handler ~input_name\n ~f_exception:(fun exn -> exn_to_sig_extension exn)\n ~embed_errors\n with\n | Error (sg, lint_errors) -> Error (lint lint_errors sg)\n | Ok (sg, lint_errors) -> Ok (sg |> lint lint_errors |> cookies_and_check)\n\nlet map_signature sg =\n match\n map_signature_gen sg\n ~tool_name:(Astlib.Ast_metadata.tool_name ())\n ~hook:Context_free.Generated_code_hook.nop\n ~expect_mismatch_handler:Context_free.Expect_mismatch_handler.nop\n ~input_name:None ~embed_errors:false\n with\n | Ok ast | Error ast -> ast\n\n(*$*)\n\n(* +-----------------------------------------------------------------+\n | Entry points |\n +-----------------------------------------------------------------+ *)\n\nlet string_contains_binary_ast s =\n let test magic_number =\n String.is_prefix s ~prefix:(String.sub magic_number ~pos:0 ~len:9)\n in\n test Ast_magic.ast_intf_magic_number || test Ast_magic.ast_impl_magic_number\n\nlet versioned_errorf input_version input_file_name =\n Printf.ksprintf (fun msg ->\n let err =\n Location.Error.make ~loc:(Location.in_file input_file_name) msg ~sub:[]\n in\n Error (err, input_version))\n\nlet remove_no_error fn = try Caml.Sys.remove fn with Sys_error _ -> ()\n\nlet protectx x ~f ~finally =\n match f x with\n | v ->\n finally x;\n v\n | exception e ->\n finally x;\n raise e\n\nlet with_preprocessed_file fn ~f =\n match !preprocessor with\n | None -> f fn\n | Some pp ->\n protectx (Caml.Filename.temp_file \"ocamlpp\" \"\") ~finally:remove_no_error\n ~f:(fun tmpfile ->\n match System.run_preprocessor ~pp ~input:fn ~output:tmpfile with\n | Ok () -> f tmpfile\n | Error (failed_command, fall_back_version) ->\n versioned_errorf fall_back_version fn\n \"Error while running external preprocessor\\nCommand line: %s\\n\"\n failed_command)\n\nlet relocate_mapper =\n object\n inherit [string * string] Ast_traverse.map_with_context\n\n method! position (old_fn, new_fn) pos =\n if String.equal pos.pos_fname old_fn then { pos with pos_fname = new_fn }\n else pos\n end\n\n(* Set the input name globally. This is used by some ppx rewriters\n such as bisect_ppx. *)\nlet set_input_name = Astlib.Location.set_input_name\n\nlet load_input ~(kind : Kind.t) ~input_name ~relocate fn =\n set_input_name input_name;\n let input_source = if String.equal fn \"-\" then Ast_io.Stdin else File fn in\n let input_kind = Ast_io.Possibly_source (kind, input_name) in\n match Ast_io.read input_source ~input_kind with\n | Ok { input_name = ast_input_name; input_version; ast } ->\n let ast_kind = Intf_or_impl.kind ast in\n if not (Kind.equal kind ast_kind) then\n versioned_errorf input_version fn\n \"File contains a binary %s AST but an %s was expected\"\n (Kind.describe ast_kind) (Kind.describe kind)\n else if String.equal ast_input_name input_name || not relocate then (\n set_input_name ast_input_name;\n Ok (ast_input_name, input_version, ast))\n else\n Ok\n ( input_name,\n input_version,\n Intf_or_impl.map_with_context ast relocate_mapper\n (ast_input_name, input_name) )\n | Error (Unknown_version (unknown_magic, fall_back_version)) ->\n versioned_errorf fall_back_version fn\n \"File is a binary ast for an unknown version of OCaml with magic \\\n number '%s'\"\n unknown_magic\n | Error (System_error (error, fall_back_version))\n | Error (Source_parse_error (error, fall_back_version)) ->\n Error (error, fall_back_version)\n | Error Not_a_binary_ast -> assert false\n\nlet load_input_run_as_ppx fn =\n (* If there's an error while loading in run_as_ppx mode, the kind of AST (impl/intf) is still unknown.\n That's why, as opposed to load_input, this function raises errors instead of returning a result:\n handling an error by returning an AST with the error packed as extension node wouldn't be possible. *)\n match Ast_io.read (File fn) ~input_kind:Ast_io.Necessarily_binary with\n | Ok { input_name = ast_input_name; input_version; ast } ->\n let ast =\n match !loc_fname with\n | None ->\n set_input_name ast_input_name;\n ast\n | Some input_name ->\n set_input_name input_name;\n if String.equal ast_input_name input_name then ast\n else\n Intf_or_impl.map_with_context ast relocate_mapper\n (ast_input_name, input_name)\n in\n (* With `--as-ppx`, ocaml calls the standalone separately for every structure/signature item\n with the filename as metadata that it gets from the previous call. relocate_mapper only\n relocates positions whose position filename coincides with that metadata filename.\n So always return the metadata filename itself, even if `-loc-filename` is provided. *)\n (ast_input_name, input_version, ast)\n | Error (Unknown_version (unknown_magic, _)) ->\n Location.raise_errorf ~loc:(Location.in_file fn)\n \"The input is a binary ast for an unknown version of OCaml with magic \\\n number '%s'\"\n unknown_magic\n | Error Not_a_binary_ast ->\n Location.raise_errorf ~loc:(Location.in_file fn)\n \"Expected a binary AST as input\"\n | Error (System_error (error, _)) | Error (Source_parse_error (error, _)) ->\n let open Location.Error in\n Location.set_filename (get_location error) fn |> update_loc error |> raise\n\nlet load_source_file fn =\n let s = In_channel.read_all fn in\n if string_contains_binary_ast s then\n Location.raise_errorf ~loc:(Location.in_file fn)\n \"ppxlib_driver: cannot use -reconcile with binary AST files\";\n s\n\ntype output_mode =\n | Pretty_print\n | Dump_ast\n | Dparsetree\n | Reconcile of Reconcile.mode\n | Null\n\n(*$*)\nlet extract_cookies_str st =\n let st =\n match st with\n | ({\n pstr_desc =\n Pstr_attribute { attr_name = { txt = \"ocaml.ppx.context\"; _ }; _ };\n _;\n } as prefix)\n :: st ->\n let prefix = Ppxlib_ast.Selected_ast.to_ocaml Structure [ prefix ] in\n assert (\n List.is_empty\n (Astlib.Ast_metadata.drop_ppx_context_str ~restore:true prefix));\n st\n | _ -> st\n in\n (* The cli cookies have to be set after restoring the ppx context,\n since restoring the ppx context resets the cookies *)\n List.iter !Cookies.given_through_cli ~f:(fun (name, expr) ->\n Cookies.set T name expr);\n st\n\nlet add_cookies_str st =\n let prefix =\n Astlib.Ast_metadata.add_ppx_context_str ~tool_name:\"ppxlib_driver\" []\n |> Ppxlib_ast.Selected_ast.of_ocaml Structure\n in\n prefix @ st\n\n(*$ str_to_sig _last_text_block *)\nlet extract_cookies_sig sg =\n let sg =\n match sg with\n | ({\n psig_desc =\n Psig_attribute { attr_name = { txt = \"ocaml.ppx.context\"; _ }; _ };\n _;\n } as prefix)\n :: sg ->\n let prefix = Ppxlib_ast.Selected_ast.to_ocaml Signature [ prefix ] in\n assert (\n List.is_empty\n (Astlib.Ast_metadata.drop_ppx_context_sig ~restore:true prefix));\n sg\n | _ -> sg\n in\n (* The cli cookies have to be set after restoring the ppx context,\n since restoring the ppx context resets the cookies *)\n List.iter !Cookies.given_through_cli ~f:(fun (name, expr) ->\n Cookies.set T name expr);\n sg\n\nlet add_cookies_sig sg =\n let prefix =\n Astlib.Ast_metadata.add_ppx_context_sig ~tool_name:\"ppxlib_driver\" []\n |> Ppxlib_ast.Selected_ast.of_ocaml Signature\n in\n prefix @ sg\n\n(*$*)\n\nlet extract_cookies (ast : Intf_or_impl.t) : Intf_or_impl.t =\n match ast with\n | Intf x -> Intf (extract_cookies_sig x)\n | Impl x -> Impl (extract_cookies_str x)\n\nlet add_cookies (ast : Intf_or_impl.t) : Intf_or_impl.t =\n match ast with\n | Intf x -> Intf (add_cookies_sig x)\n | Impl x -> Impl (add_cookies_str x)\n\nlet corrections = ref []\nlet add_to_list r x = r := x :: !r\n\nlet register_correction ~loc ~repl =\n add_to_list corrections\n (Reconcile.Replacement.make_text () ~start:loc.loc_start ~stop:loc.loc_end\n ~repl)\n\nlet process_file_hooks = ref []\nlet register_process_file_hook f = add_to_list process_file_hooks f\n\nmodule File_property = struct\n type 'a t = {\n name : string;\n mutable data : 'a option;\n sexp_of_t : 'a -> Sexp.t;\n }\n\n type packed = T : _ t -> packed\n\n let all = ref []\n let register t = add_to_list all (T t)\n let reset_all () = List.iter !all ~f:(fun (T t) -> t.data <- None)\n\n let dump_and_reset_all () =\n List.filter_map (List.rev !all) ~f:(fun (T t) ->\n match t.data with\n | None -> None\n | Some v ->\n t.data <- None;\n Some (t.name, t.sexp_of_t v))\nend\n\nmodule Create_file_property (Name : sig\n val name : string\nend)\n(T : Sexpable.S) =\nstruct\n let t : _ File_property.t =\n { name = Name.name; data = None; sexp_of_t = T.sexp_of_t }\n\n let () = File_property.register t\n let set x = t.data <- Some x\nend\n\nlet process_ast (ast : Intf_or_impl.t) ~input_name ~tool_name ~hook\n ~expect_mismatch_handler ~embed_errors =\n match ast with\n | Intf x ->\n let ast =\n match\n map_signature_gen x ~tool_name ~hook ~expect_mismatch_handler\n ~input_name:(Some input_name) ~embed_errors\n with\n | Error ast | Ok ast -> ast\n in\n Intf_or_impl.Intf ast\n | Impl x ->\n let ast =\n match\n map_structure_gen x ~tool_name ~hook ~expect_mismatch_handler\n ~input_name:(Some input_name) ~embed_errors\n with\n | Error ast | Ok ast -> ast\n in\n Intf_or_impl.Impl ast\n\nlet process_file (kind : Kind.t) fn ~input_name ~relocate ~output_mode\n ~embed_errors ~output =\n File_property.reset_all ();\n List.iter (List.rev !process_file_hooks) ~f:(fun f -> f ());\n corrections := [];\n let replacements = ref [] in\n let tool_name = \"ppx_driver\" in\n let hook : Context_free.Generated_code_hook.t =\n match output_mode with\n | Reconcile (Using_line_directives | Delimiting_generated_blocks) ->\n {\n f =\n (fun context (loc : Location.t) generated ->\n add_to_list replacements\n (Reconcile.Replacement.make () ~context:(Extension context)\n ~start:loc.loc_start ~stop:loc.loc_end ~repl:generated));\n }\n | _ -> Context_free.Generated_code_hook.nop\n in\n let expect_mismatch_handler : Context_free.Expect_mismatch_handler.t =\n {\n f =\n (fun context (loc : Location.t) generated ->\n add_to_list corrections\n (Reconcile.Replacement.make () ~context:(Floating_attribute context)\n ~start:loc.loc_start ~stop:loc.loc_end ~repl:(Many generated)));\n }\n in\n\n let input_name, input_version, ast =\n let preprocessed_and_loaded =\n with_preprocessed_file fn ~f:(load_input ~kind ~input_name ~relocate)\n in\n match preprocessed_and_loaded with\n | Ok (input_fname, input_version, ast) -> (\n try\n let ast =\n extract_cookies ast\n |> process_ast ~input_name ~tool_name ~hook ~expect_mismatch_handler\n ~embed_errors\n in\n (input_fname, input_version, ast)\n with exn when embed_errors ->\n (input_fname, input_version, exn_to_extension exn ~kind))\n | Error (error, input_version) when embed_errors ->\n (input_name, input_version, error_to_extension error ~kind)\n | Error (error, _) ->\n let open Location.Error in\n Location.set_filename (get_location error) fn\n |> update_loc error |> raise\n in\n Option.iter !output_metadata_filename ~f:(fun fn ->\n let metadata = File_property.dump_and_reset_all () in\n Out_channel.write_all fn\n ~data:\n (List.map metadata ~f:(fun (s, sexp) ->\n Sexp.to_string_hum (Sexp.List [ Atom s; sexp ]) ^ \"\\n\")\n |> String.concat ~sep:\"\"));\n\n let input_contents = lazy (load_source_file fn) in\n let corrected = fn ^ !corrected_suffix in\n let mismatches_found =\n match !corrections with\n | [] ->\n if Caml.Sys.file_exists corrected then Caml.Sys.remove corrected;\n false\n | corrections ->\n Reconcile.reconcile corrections\n ~contents:(Lazy.force input_contents)\n ~output:(Some corrected) ~input_filename:fn ~input_name\n ~target:Corrected ?styler:!styler ~kind;\n true\n in\n\n (match output_mode with\n | Null -> ()\n | Pretty_print ->\n with_output output ~binary:false ~f:(fun oc ->\n let ppf = Caml.Format.formatter_of_out_channel oc in\n (match ast with\n | Intf ast -> Pprintast.signature ppf ast\n | Impl ast -> Pprintast.structure ppf ast);\n let null_ast =\n match ast with Intf [] | Impl [] -> true | _ -> false\n in\n if not null_ast then Caml.Format.pp_print_newline ppf ())\n | Dump_ast ->\n with_output output ~binary:true ~f:(fun oc ->\n Ast_io.write oc\n { input_name; input_version; ast }\n ~add_ppx_context:true)\n | Dparsetree ->\n with_output output ~binary:false ~f:(fun oc ->\n let ppf = Caml.Format.formatter_of_out_channel oc in\n let ast = add_cookies ast in\n (match ast with\n | Intf ast -> Sexp.pp_hum ppf (Ast_traverse.sexp_of#signature ast)\n | Impl ast -> Sexp.pp_hum ppf (Ast_traverse.sexp_of#structure ast));\n Caml.Format.pp_print_newline ppf ())\n | Reconcile mode ->\n Reconcile.reconcile !replacements\n ~contents:(Lazy.force input_contents)\n ~output ~input_filename:fn ~input_name ~target:(Output mode)\n ?styler:!styler ~kind);\n\n if\n mismatches_found && match !diff_command with Some \"-\" -> false | _ -> true\n then (\n Ppxlib_print_diff.print () ~file1:fn ~file2:corrected ~use_color:!use_color\n ?diff_command:!diff_command;\n Caml.exit 1)\n\nlet output_mode = ref Pretty_print\nlet output = ref None\nlet kind = ref None\nlet input = ref None\nlet embed_errors = ref false\n\nlet set_input fn =\n match !input with\n | None -> input := Some fn\n | Some _ -> raise (Arg.Bad \"too many input files\")\n\nlet set_kind k =\n match !kind with\n | Some k' when not (Kind.equal k k') ->\n raise (Arg.Bad \"must specify at most one of -impl or -intf\")\n | _ -> kind := Some k\n\nlet set_output_mode mode =\n match (!output_mode, mode) with\n | Pretty_print, _ -> output_mode := mode\n | _, Pretty_print -> assert false\n | Dump_ast, Dump_ast | Dparsetree, Dparsetree -> ()\n | Reconcile a, Reconcile b when Poly.equal a b -> ()\n | x, y ->\n let arg_of_output_mode = function\n | Pretty_print -> assert false\n | Dump_ast -> \"-dump-ast\"\n | Dparsetree -> \"-dparsetree\"\n | Reconcile Using_line_directives -> \"-reconcile\"\n | Reconcile Delimiting_generated_blocks -> \"-reconcile-with-comments\"\n | Null -> \"-null\"\n in\n raise\n (Arg.Bad\n (Printf.sprintf \"%s and %s are incompatible\" (arg_of_output_mode x)\n (arg_of_output_mode y)))\n\nlet print_transformations () =\n List.iter !Transform.all ~f:(fun (ct : Transform.t) ->\n Printf.printf \"%s\\n\" ct.name)\n\nlet parse_apply_list s =\n let names =\n if String.equal s \"\" then [] else String.split_on_char s ~sep:','\n in\n List.iter names ~f:(fun name ->\n if\n not\n (List.exists !Transform.all ~f:(fun (ct : Transform.t) ->\n Transform.has_name ct name))\n then\n raise\n (Caml.Arg.Bad\n (Printf.sprintf \"code transformation '%s' does not exist\" name)));\n names\n\ntype mask = {\n mutable apply : string list option;\n mutable dont_apply : string list option;\n}\n\nlet mask = { apply = None; dont_apply = None }\n\nlet handle_apply s =\n if Option.is_some mask.apply then\n raise (Arg.Bad \"-apply called too many times\");\n (* This is not strictly necessary but it's more intuitive *)\n if Option.is_some mask.dont_apply then\n raise (Arg.Bad \"-apply must be called before -dont-apply\");\n mask.apply <- Some (parse_apply_list s)\n\nlet handle_dont_apply s =\n if Option.is_some mask.dont_apply then\n raise (Arg.Bad \"-apply called too many times\");\n mask.dont_apply <- Some (parse_apply_list s)\n\nlet interpret_mask () =\n if Option.is_some mask.apply || Option.is_some mask.dont_apply then\n let selected_transform_name ct =\n let is_candidate =\n match mask.apply with\n | None -> true\n | Some names -> List.exists names ~f:(Transform.has_name ct)\n in\n let is_selected =\n match mask.dont_apply with\n | None -> is_candidate\n | Some names ->\n is_candidate && not (List.exists names ~f:(Transform.has_name ct))\n in\n if is_selected then Some ct.name else None\n in\n apply_list :=\n Some (List.filter_map !Transform.all ~f:selected_transform_name)\n\nlet set_cookie s =\n match String.lsplit2 s ~on:'=' with\n | None ->\n raise (Arg.Bad \"invalid cookie, must be of the form \\\"=\\\"\")\n | Some (name, value) ->\n let lexbuf = Lexing.from_string value in\n lexbuf.Lexing.lex_curr_p <-\n {\n Lexing.pos_fname = \"\";\n pos_lnum = 1;\n pos_bol = 0;\n pos_cnum = 0;\n };\n let expr = Parse.expression lexbuf in\n Cookies.given_through_cli := (name, expr) :: !Cookies.given_through_cli\n\nlet shared_args =\n [\n ( \"-loc-filename\",\n Arg.String (fun s -> loc_fname := Some s),\n \" File name to use in locations\" );\n ( \"-reserve-namespace\",\n Arg.String Name.Reserved_namespaces.reserve,\n \" Mark the given namespace as reserved\" );\n (\"-no-check\", Arg.Clear perform_checks, \" Disable checks (unsafe)\");\n (\"-check\", Arg.Set perform_checks, \" Enable checks\");\n ( \"-no-check-on-extensions\",\n Arg.Clear perform_checks_on_extensions,\n \" Disable checks on extension point only\" );\n ( \"-check-on-extensions\",\n Arg.Set perform_checks_on_extensions,\n \" Enable checks on extension point only\" );\n ( \"-no-locations-check\",\n Arg.Clear perform_locations_check,\n \" Disable locations check only\" );\n ( \"-locations-check\",\n Arg.Set perform_locations_check,\n \" Enable locations check only\" );\n ( \"-apply\",\n Arg.String handle_apply,\n \" Apply these transformations in order (comma-separated list)\" );\n ( \"-dont-apply\",\n Arg.String handle_dont_apply,\n \" Exclude these transformations\" );\n ( \"-no-merge\",\n Arg.Set no_merge,\n \" Do not merge context free transformations (better for debugging \\\n rewriters). As a result, the context-free transformations are not all \\\n applied before all impl and intf.\" );\n (\"-cookie\", Arg.String set_cookie, \"NAME=EXPR Set the cookie NAME to EXPR\");\n (\"--cookie\", Arg.String set_cookie, \" Same as -cookie\");\n ]\n\nlet () =\n List.iter shared_args ~f:(fun (key, spec, doc) -> add_arg key spec ~doc)\n\nlet as_pp () =\n set_output_mode Dump_ast;\n embed_errors := true\n\nlet standalone_args =\n [\n ( \"-as-ppx\",\n Arg.Unit (fun () -> raise (Arg.Bad \"-as-ppx must be the first argument\")),\n \" Run as a -ppx rewriter (must be the first argument)\" );\n ( \"--as-ppx\",\n Arg.Unit (fun () -> raise (Arg.Bad \"--as-ppx must be the first argument\")),\n \" Same as -as-ppx\" );\n (\"-as-pp\", Arg.Unit as_pp, \" Shorthand for: -dump-ast -embed-errors\");\n (\"--as-pp\", Arg.Unit as_pp, \" Same as -as-pp\");\n ( \"-o\",\n Arg.String (fun s -> output := Some s),\n \" Output file (use '-' for stdout)\" );\n (\"-\", Arg.Unit (fun () -> set_input \"-\"), \" Read input from stdin\");\n ( \"-dump-ast\",\n Arg.Unit (fun () -> set_output_mode Dump_ast),\n \" Dump the marshaled ast to the output file instead of pretty-printing it\"\n );\n ( \"--dump-ast\",\n Arg.Unit (fun () -> set_output_mode Dump_ast),\n \" Same as -dump-ast\" );\n ( \"-dparsetree\",\n Arg.Unit (fun () -> set_output_mode Dparsetree),\n \" Print the parsetree (same as ocamlc -dparsetree)\" );\n ( \"-embed-errors\",\n Arg.Set embed_errors,\n \" Embed errors in the output AST (default: true when -dump-ast, false \\\n otherwise)\" );\n ( \"-null\",\n Arg.Unit (fun () -> set_output_mode Null),\n \" Produce no output, except for errors\" );\n ( \"-impl\",\n Arg.Unit (fun () -> set_kind Impl),\n \" Treat the input as a .ml file\" );\n (\"--impl\", Arg.Unit (fun () -> set_kind Impl), \" Same as -impl\");\n ( \"-intf\",\n Arg.Unit (fun () -> set_kind Intf),\n \" Treat the input as a .mli file\" );\n (\"--intf\", Arg.Unit (fun () -> set_kind Intf), \" Same as -intf\");\n ( \"-debug-attribute-drop\",\n Arg.Set debug_attribute_drop,\n \" Debug attribute dropping\" );\n ( \"-print-transformations\",\n Arg.Set request_print_transformations,\n \" Print linked-in code transformations, in the order they are applied\" );\n ( \"-print-passes\",\n Arg.Set request_print_passes,\n \" Print the actual passes over the whole AST in the order they are \\\n applied\" );\n ( \"-ite-check\",\n Arg.Unit\n (fun () ->\n Printf.eprintf\n \"Warning: the -ite-check flag is deprecated and has no effect.\\n%!\";\n Extra_warnings.care_about_ite_branch := true),\n \" (no effect -- kept for compatibility)\" );\n ( \"-pp\",\n Arg.String (fun s -> preprocessor := Some s),\n \" Pipe sources through preprocessor (incompatible \\\n with -as-ppx)\" );\n ( \"-reconcile\",\n Arg.Unit (fun () -> set_output_mode (Reconcile Using_line_directives)),\n \" (WIP) Pretty print the output using a mix of the input source and the \\\n generated code\" );\n ( \"-reconcile-with-comments\",\n Arg.Unit\n (fun () -> set_output_mode (Reconcile Delimiting_generated_blocks)),\n \" (WIP) same as -reconcile but uses comments to enclose the generated \\\n code\" );\n (\"-no-color\", Arg.Clear use_color, \" Don't use colors when printing errors\");\n ( \"-diff-cmd\",\n Arg.String (fun s -> diff_command := Some s),\n \" Diff command when using code expectations (use - to disable diffing)\" );\n ( \"-pretty\",\n Arg.Set pretty,\n \" Instruct code generators to improve the prettiness of the generated \\\n code\" );\n (\"-styler\", Arg.String (fun s -> styler := Some s), \" Code styler\");\n ( \"-output-metadata\",\n Arg.String (fun s -> output_metadata_filename := Some s),\n \"FILE Where to store the output metadata\" );\n ( \"-corrected-suffix\",\n Arg.Set_string corrected_suffix,\n \"SUFFIX Suffix to append to corrected files\" );\n ]\n\nlet get_args ?(standalone_args = standalone_args) () =\n standalone_args @ List.rev !args\n\nlet standalone_main () =\n let usage = Printf.sprintf \"%s [extra_args] []\" exe_name in\n let args = get_args () in\n Arg.parse (Arg.align args) set_input usage;\n interpret_mask ();\n if !request_print_transformations then (\n print_transformations ();\n Caml.exit 0);\n if !request_print_passes then (\n print_passes ();\n Caml.exit 0);\n match !input with\n | None ->\n Printf.eprintf \"%s: no input file given\\n%!\" exe_name;\n Caml.exit 2\n | Some fn ->\n let kind =\n match !kind with\n | Some k -> k\n | None -> (\n match Kind.of_filename fn with\n | Some k -> k\n | None ->\n Printf.eprintf\n \"%s: don't know what to do with '%s', use -impl or -intf.\\n\"\n exe_name fn;\n Caml.exit 2)\n in\n let input_name, relocate =\n match !loc_fname with None -> (fn, false) | Some fn -> (fn, true)\n in\n process_file kind fn ~input_name ~relocate ~output_mode:!output_mode\n ~output:!output ~embed_errors:!embed_errors\n\nlet rewrite_binary_ast_file input_fn output_fn =\n let input_name, input_version, ast = load_input_run_as_ppx input_fn in\n let ast =\n try\n let ast = extract_cookies ast in\n let tool_name = Astlib.Ast_metadata.tool_name () in\n let hook = Context_free.Generated_code_hook.nop in\n let expect_mismatch_handler = Context_free.Expect_mismatch_handler.nop in\n process_ast ast ~input_name ~tool_name ~hook ~expect_mismatch_handler\n ~embed_errors:true\n with exn -> exn_to_extension exn ~kind:(Intf_or_impl.kind ast)\n in\n with_output (Some output_fn) ~binary:true ~f:(fun oc ->\n Ast_io.write oc { input_name; input_version; ast } ~add_ppx_context:true)\n\nlet parse_input passed_in_args ~valid_args ~incorrect_input_msg =\n try\n Arg.parse_argv passed_in_args (Arg.align valid_args)\n (fun _ -> raise (Arg.Bad \"anonymous arguments not accepted\"))\n incorrect_input_msg\n with\n | Arg.Bad msg ->\n Printf.eprintf \"%s\" msg;\n Caml.exit 2\n | Arg.Help msg ->\n Printf.eprintf \"%s\" msg;\n Caml.exit 0\n\nlet run_as_ppx_rewriter_main ~standalone_args ~usage input =\n let valid_args = get_args ~standalone_args () in\n match List.rev @@ Array.to_list @@ input with\n | output_fn :: input_fn :: flags_and_prog_name\n when List.length flags_and_prog_name > 0 ->\n let prog_name_and_flags = List.rev flags_and_prog_name |> Array.of_list in\n parse_input prog_name_and_flags ~valid_args ~incorrect_input_msg:usage;\n interpret_mask ();\n rewrite_binary_ast_file input_fn output_fn;\n Caml.exit 0\n | [ help; _ ] when String.equal help \"-help\" || String.equal help \"--help\" ->\n parse_input input ~valid_args ~incorrect_input_msg:usage;\n assert false\n | _ ->\n Printf.eprintf \"Usage: %s\\n%!\" usage;\n Caml.exit 2\n\nlet standalone_run_as_ppx_rewriter () =\n let n = Array.length Caml.Sys.argv in\n let usage =\n Printf.sprintf \"%s -as-ppx [extra_args] \" exe_name\n in\n let argv = Array.make (n - 1) \"\" in\n argv.(0) <- Caml.Sys.argv.(0);\n for i = 1 to n - 2 do\n argv.(i) <- Caml.Sys.argv.(i + 1)\n done;\n let standalone_args =\n List.map standalone_args ~f:(fun (arg, spec, _doc) ->\n (arg, spec, \" Unused with -as-ppx\"))\n in\n run_as_ppx_rewriter_main ~standalone_args ~usage argv\n\nlet standalone () =\n Astlib.init_error_reporting_style_using_env_vars ();\n try\n if\n Array.length Caml.Sys.argv >= 2\n &&\n match Caml.Sys.argv.(1) with \"-as-ppx\" | \"--as-ppx\" -> true | _ -> false\n then standalone_run_as_ppx_rewriter ()\n else standalone_main ();\n Caml.exit 0\n with exn ->\n Location.report_exception Caml.Format.err_formatter exn;\n Caml.exit 1\n\nlet run_as_ppx_rewriter () =\n let usage = Printf.sprintf \"%s [extra_args] \" exe_name in\n let input = Caml.Sys.argv in\n try run_as_ppx_rewriter_main ~standalone_args:[] ~usage input\n with exn ->\n Location.report_exception Caml.Format.err_formatter exn;\n Caml.exit 1\n\nlet pretty () = !pretty\n\nlet enable_checks () =\n (* We do not enable the locations check here, we currently require that one\n to be specifically enabled. *)\n perform_checks := true;\n perform_checks_on_extensions := true\n\nlet enable_location_check () = perform_locations_check := true\nlet disable_location_check () = perform_locations_check := false\nlet map_structure st = map_structure st\n","open! Import\n\nlet mk_attr_noloc txt = Ast_helper.Attr.mk Location.{ txt; loc = none }\nlet hide_attribute : attribute = mk_attr_noloc \"merlin.hide\" (PStr [])\nlet focus_attribute : attribute = mk_attr_noloc \"merlin.focus\" (PStr [])\n\nlet hide_pattern ({ ppat_attributes; _ } as p) =\n { p with ppat_attributes = hide_attribute :: ppat_attributes }\n\nlet focus_pattern ({ ppat_attributes; _ } as p) =\n { p with ppat_attributes = focus_attribute :: ppat_attributes }\n\nlet hide_expression ({ pexp_attributes; _ } as e) =\n { e with pexp_attributes = hide_attribute :: pexp_attributes }\n\nlet focus_expression ({ pexp_attributes; _ } as e) =\n { e with pexp_attributes = focus_attribute :: pexp_attributes }\n","open Import\nopen Ast_builder.Default\n\nlet underscore_binding exp =\n let loc = exp.pexp_loc in\n value_binding ~loc ~pat:(ppat_any ~loc) ~expr:exp\n\nlet vars_of =\n object\n inherit [Longident.t Located.t list] Ast_traverse.fold as super\n\n method! pattern patt acc =\n match patt.ppat_desc with\n | Ppat_var v -> Located.map (fun var -> Longident.Lident var) v :: acc\n | _ -> super#pattern patt acc\n end\n\n(* For every [let x = ...] structure item, add a [let _ = x] *)\nlet add_dummy_user_for_values =\n object\n inherit Ast_traverse.map as super\n\n method! structure st =\n let rec loop st acc =\n match st with\n | [] -> List.rev acc\n | ({ pstr_desc = Pstr_value (_, vbs); pstr_loc = loc } as item) :: rest\n ->\n let vars =\n List.fold_left vbs ~init:[] ~f:(fun acc vb ->\n vars_of#pattern vb.pvb_pat acc)\n in\n let ign =\n pstr_value_list ~loc Nonrecursive\n (List.rev_map vars ~f:(fun v ->\n underscore_binding (pexp_ident ~loc:v.loc v)))\n in\n loop rest (ign @ (item :: acc))\n | item :: rest -> loop rest (item :: acc)\n in\n loop (super#structure st) []\n end\n\nlet binds_module_names =\n object\n inherit [bool] Ast_traverse.fold as super\n\n method! module_binding mb acc =\n match mb.pmb_name.txt with\n | Some (_ : string) -> true\n | None -> super#module_binding mb acc\n\n method! module_declaration md acc =\n match md.pmd_name.txt with\n | Some (_ : string) -> true\n | None -> super#module_declaration md acc\n\n method! module_substitution ms _ =\n match ms.pms_name.txt with (_ : string) -> true\n\n method! functor_parameter fp acc =\n match fp with\n | Unit -> acc\n | Named (name, _) -> (\n match name.txt with\n | Some (_ : string) -> true\n | None -> super#functor_parameter fp acc)\n\n method! pattern pat acc =\n match pat.ppat_desc with\n | Ppat_unpack name -> (\n match name.txt with Some (_ : string) -> true | None -> acc)\n | _ -> super#pattern pat acc\n\n method! expression expr acc =\n match expr.pexp_desc with\n | Pexp_letmodule (name, _, _) -> (\n match name.txt with\n | Some (_ : string) -> true\n | None -> super#expression expr acc)\n | _ -> super#expression expr acc\n end\n","open! Import\ninclude Clause_syntax_intf\n\nmodule Variant = struct\n type ast = constructor_declaration\n\n type t =\n { ast : ast\n ; position : int\n }\n\n let create_list list =\n List.mapi list ~f:(fun position ast ->\n let loc = ast.pcd_loc in\n match ast.pcd_res with\n | Some _ -> unsupported ~loc \"GADT\"\n | None -> { ast; position })\n ;;\n\n let salt t = Some t.position\n let location t = t.ast.pcd_loc\n\n let weight_attribute =\n Attribute.declare\n \"quickcheck.weight\"\n Attribute.Context.constructor_declaration\n Ast_pattern.(pstr (pstr_eval __ nil ^:: nil))\n (fun x -> x)\n ;;\n\n let weight t =\n match Attribute.get weight_attribute t.ast with\n | Some expr -> expr\n | None -> efloat ~loc:{ (location t) with loc_ghost = true } \"1.\"\n ;;\n\n let core_type_list t =\n match t.ast.pcd_args with\n | Pcstr_tuple list -> list\n | Pcstr_record label_decl_list ->\n List.map label_decl_list ~f:(fun label_decl -> label_decl.pld_type)\n ;;\n\n let pattern t ~loc pat_list =\n let arg =\n match t.ast.pcd_args with\n | Pcstr_tuple _ ->\n (match pat_list with\n | [] -> None\n | [ pat ] -> Some pat\n | _ -> Some (ppat_tuple ~loc pat_list))\n | Pcstr_record label_decl_list ->\n let alist =\n List.map2_exn label_decl_list pat_list ~f:(fun label_decl pat ->\n lident_loc label_decl.pld_name, pat)\n in\n Some (ppat_record ~loc alist Closed)\n in\n ppat_construct ~loc (lident_loc t.ast.pcd_name) arg\n ;;\n\n let expression t ~loc _ expr_list =\n let arg =\n match t.ast.pcd_args with\n | Pcstr_tuple _ ->\n (match expr_list with\n | [] -> None\n | [ expr ] -> Some expr\n | _ -> Some (pexp_tuple ~loc expr_list))\n | Pcstr_record label_decl_list ->\n let alist =\n List.map2_exn label_decl_list expr_list ~f:(fun label_decl expr ->\n lident_loc label_decl.pld_name, expr)\n in\n Some (pexp_record ~loc alist None)\n in\n pexp_construct ~loc (lident_loc t.ast.pcd_name) arg\n ;;\nend\n\nmodule Polymorphic_variant = struct\n type ast = row_field\n type t = ast\n\n let create_list = Fn.id\n\n let salt t =\n match t.prf_desc with\n | Rtag (label, _, _) -> Some (Ocaml_common.Btype.hash_variant label.txt)\n | Rinherit _ -> None\n ;;\n\n let location t = t.prf_loc\n\n let weight_attribute =\n Attribute.declare\n \"quickcheck.weight\"\n Attribute.Context.rtag\n Ast_pattern.(pstr (pstr_eval __ nil ^:: nil))\n (fun x -> x)\n ;;\n\n let weight t =\n match Attribute.get weight_attribute t with\n | Some expr -> expr\n | None -> efloat ~loc:{ (location t) with loc_ghost = true } \"1.\"\n ;;\n\n let core_type_list t =\n match t.prf_desc with\n | Rtag (_, _, core_type_list) -> core_type_list\n | Rinherit core_type -> [ core_type ]\n ;;\n\n let pattern t ~loc pat_list =\n match t.prf_desc, pat_list with\n | Rtag (label, true, []), [] -> ppat_variant ~loc label.txt None\n | Rtag (label, false, [ _ ]), [ pat ] -> ppat_variant ~loc label.txt (Some pat)\n | Rtag (label, false, [ _ ]), _ :: _ :: _ ->\n ppat_variant ~loc label.txt (Some (ppat_tuple ~loc pat_list))\n | Rinherit { ptyp_desc; _ }, [ { ppat_desc; _ } ] ->\n (match ptyp_desc with\n | Ptyp_constr (id, []) ->\n (match ppat_desc with\n | Ppat_var var -> ppat_alias ~loc (ppat_type ~loc id) var\n | _ ->\n internal_error\n ~loc\n \"cannot bind a # pattern to anything other than a variable\")\n | _ ->\n unsupported ~loc \"inherited polymorphic variant type that is not a type name\")\n | Rtag (_, true, _ :: _), _ | Rtag (_, false, ([] | _ :: _ :: _)), _ ->\n unsupported ~loc \"intersection type\"\n | Rtag (_, true, []), _ :: _\n | Rtag (_, false, [ _ ]), []\n | Rinherit _, ([] | _ :: _ :: _) ->\n internal_error ~loc \"wrong number of arguments for variant clause\"\n ;;\n\n let expression t ~loc core_type expr_list =\n match t.prf_desc, expr_list with\n | Rtag (label, true, []), [] -> pexp_variant ~loc label.txt None\n | Rtag (label, false, [ _ ]), [ expr ] -> pexp_variant ~loc label.txt (Some expr)\n | Rtag (label, false, [ _ ]), _ :: _ :: _ ->\n pexp_variant ~loc label.txt (Some (pexp_tuple ~loc expr_list))\n | Rinherit inherited_type, [ expr ] ->\n pexp_coerce ~loc expr (Some inherited_type) core_type\n | Rtag (_, true, _ :: _), _ | Rtag (_, false, ([] | _ :: _ :: _)), _ ->\n unsupported ~loc \"intersection type\"\n | Rtag (_, true, []), _ :: _\n | Rtag (_, false, [ _ ]), []\n | Rinherit _, ([] | _ :: _ :: _) ->\n internal_error ~loc \"wrong number of arguments for variant clause\"\n ;;\nend\n","open! Import\ninclude Field_syntax_intf\n\nmodule Tuple = struct\n type ast = core_type\n type t = ast\n\n let create = Fn.id\n let location t = t.ptyp_loc\n let core_type t = t\n let pattern _ ~loc pat_list = ppat_tuple ~loc pat_list\n let expression _ ~loc expr_list = pexp_tuple ~loc expr_list\nend\n\nmodule Record = struct\n type ast = label_declaration\n type t = ast\n\n let create ast =\n match ast.pld_mutable with\n | Immutable -> ast\n | Mutable ->\n (* We intend to support mutable fields and values shortly, but we leave it to a\n separate feature. Integrating mutable values with replayability and shrinking is\n tricky, and we at least have to figure out what caveats to document. *)\n unsupported ~loc:ast.pld_loc \"mutable record field\"\n ;;\n\n let location t = t.pld_loc\n let core_type t = t.pld_type\n\n let pattern list ~loc pat_list =\n let alist =\n List.map2_exn list pat_list ~f:(fun t pat -> lident_loc t.pld_name, pat)\n in\n ppat_record ~loc alist Closed\n ;;\n\n let expression list ~loc expr_list =\n let alist =\n List.map2_exn list expr_list ~f:(fun t expr -> lident_loc t.pld_name, expr)\n in\n pexp_record ~loc alist None\n ;;\nend\n","open! Import\n\nlet any ~loc = [%expr Base_quickcheck.Shrinker.atomic]\nlet arrow ~loc = [%expr Base_quickcheck.Shrinker.atomic]\n\nlet compound_sequence ~loc ~make_compound_expr ~field_pats ~field_exprs ~shrinker_exprs =\n [%expr\n Base.Sequence.round_robin\n [%e\n elist\n ~loc\n (List.map3_exn\n field_pats\n field_exprs\n shrinker_exprs\n ~f:(fun field_pat field_expr shrinker ->\n let loc = { shrinker.pexp_loc with loc_ghost = true } in\n [%expr\n Base.Sequence.map\n (Base_quickcheck.Shrinker.shrink [%e shrinker] [%e field_expr])\n ~f:(fun [%p field_pat] -> [%e make_compound_expr ~loc field_exprs])]))]]\n;;\n\nlet compound\n (type field)\n ~shrinker_of_core_type\n ~loc\n ~fields\n (module Field : Field_syntax.S with type ast = field)\n =\n let fields = List.map fields ~f:Field.create in\n let field_pats, field_exprs = gensyms \"x\" (List.map fields ~f:Field.location) in\n let shrinker_exprs =\n List.map fields ~f:(fun field -> shrinker_of_core_type (Field.core_type field))\n in\n [%expr\n Base_quickcheck.Shrinker.create (fun [%p Field.pattern fields ~loc field_pats] ->\n [%e\n compound_sequence\n ~loc\n ~make_compound_expr:(Field.expression fields)\n ~field_pats\n ~field_exprs\n ~shrinker_exprs])]\n;;\n\nlet variant\n (type clause)\n ~shrinker_of_core_type\n ~loc\n ~variant_type\n ~clauses\n (module Clause : Clause_syntax.S with type ast = clause)\n =\n let clauses = Clause.create_list clauses in\n [%expr\n Base_quickcheck.Shrinker.create\n [%e\n pexp_function\n ~loc\n (List.map clauses ~f:(fun clause ->\n let loc = { (Clause.location clause) with loc_ghost = true } in\n let core_type_list = Clause.core_type_list clause in\n let field_pats, field_exprs =\n gensyms\n \"x\"\n (List.map core_type_list ~f:(fun core_type -> core_type.ptyp_loc))\n in\n let shrinker_exprs = List.map core_type_list ~f:shrinker_of_core_type in\n let lhs = Clause.pattern clause ~loc field_pats in\n let rhs =\n compound_sequence\n ~loc\n ~make_compound_expr:(Clause.expression clause variant_type)\n ~field_pats\n ~field_exprs\n ~shrinker_exprs\n in\n case ~lhs ~guard:None ~rhs))]]\n;;\n","open! Import\n\nlet arrow\n ~generator_of_core_type\n ~observer_of_core_type\n ~loc\n ~arg_label\n ~input_type\n ~output_type\n =\n let input_observer =\n match arg_label with\n | Nolabel | Labelled _ -> observer_of_core_type input_type\n | Optional _ ->\n [%expr Base_quickcheck.Observer.option [%e observer_of_core_type input_type]]\n in\n let output_generator = generator_of_core_type output_type in\n let unlabelled =\n [%expr Base_quickcheck.Generator.fn [%e input_observer] [%e output_generator]]\n in\n match arg_label with\n | Nolabel -> unlabelled\n | Labelled _ | Optional _ ->\n [%expr\n Base_quickcheck.Generator.map\n ~f:[%e fn_map_label ~loc ~from:Nolabel ~to_:arg_label]\n [%e unlabelled]]\n;;\n\nlet compound_generator ~loc ~make_compound_expr generator_list =\n let loc = { loc with loc_ghost = true } in\n let size_pat, size_expr = gensym \"size\" loc in\n let random_pat, random_expr = gensym \"random\" loc in\n [%expr\n Base_quickcheck.Generator.create (fun ~size:[%p size_pat] ~random:[%p random_pat] ->\n [%e\n make_compound_expr\n ~loc\n (List.map generator_list ~f:(fun generator ->\n let loc = { generator.pexp_loc with loc_ghost = true } in\n [%expr\n Base_quickcheck.Generator.generate\n [%e generator]\n ~size:[%e size_expr]\n ~random:[%e random_expr]]))])]\n;;\n\nlet compound\n (type field)\n ~generator_of_core_type\n ~loc\n ~fields\n (module Field : Field_syntax.S with type ast = field)\n =\n let fields = List.map fields ~f:Field.create in\n compound_generator\n ~loc\n ~make_compound_expr:(Field.expression fields)\n (List.map fields ~f:(fun field -> generator_of_core_type (Field.core_type field)))\n;;\n\nlet does_refer_to name_set =\n object (self)\n inherit [bool] Ast_traverse.fold as super\n\n method! core_type ty acc =\n match ty.ptyp_desc with\n | Ptyp_constr (name, args) ->\n acc\n || Set.mem name_set (Longident.name name.txt)\n || List.exists args ~f:(fun arg -> self#core_type arg false)\n | _ -> super#core_type ty acc\n end\n;;\n\nlet clause_is_recursive\n (type clause)\n ~clause\n ~rec_names\n (module Clause : Clause_syntax.S with type t = clause)\n =\n List.exists (Clause.core_type_list clause) ~f:(fun ty ->\n (does_refer_to rec_names)#core_type ty false)\n;;\n\nlet variant\n (type clause)\n ~generator_of_core_type\n ~loc\n ~variant_type\n ~clauses\n ~rec_names\n (module Clause : Clause_syntax.S with type ast = clause)\n =\n let clauses = Clause.create_list clauses in\n let make_generator clause =\n compound_generator\n ~loc:(Clause.location clause)\n ~make_compound_expr:(Clause.expression clause variant_type)\n (List.map (Clause.core_type_list clause) ~f:generator_of_core_type)\n in\n let make_pair clause =\n pexp_tuple\n ~loc:{ (Clause.location clause) with loc_ghost = true }\n [ Clause.weight clause; make_generator clause ]\n in\n match\n List.partition_tf clauses ~f:(fun clause ->\n clause_is_recursive ~clause ~rec_names (module Clause))\n with\n | [], clauses | clauses, [] ->\n let pairs = List.map clauses ~f:make_pair in\n [%expr Base_quickcheck.Generator.weighted_union [%e elist ~loc pairs]]\n | recursive_clauses, nonrecursive_clauses ->\n let size_pat, size_expr = gensym \"size\" loc in\n let nonrec_pat, nonrec_expr = gensym \"gen\" loc in\n let rec_pat, rec_expr = gensym \"gen\" loc in\n let nonrec_pats, nonrec_exprs =\n gensyms \"pair\" (List.map nonrecursive_clauses ~f:Clause.location)\n in\n let rec_pats, rec_exprs =\n gensyms \"pair\" (List.map recursive_clauses ~f:Clause.location)\n in\n let bindings =\n List.map2_exn nonrec_pats nonrecursive_clauses ~f:(fun pat clause ->\n let loc = { (Clause.location clause) with loc_ghost = true } in\n let expr = make_pair clause in\n value_binding ~loc ~pat ~expr)\n @ List.map2_exn rec_pats recursive_clauses ~f:(fun pat clause ->\n let loc = { (Clause.location clause) with loc_ghost = true } in\n let weight_expr = Clause.weight clause in\n let gen_expr =\n [%expr\n Base_quickcheck.Generator.bind\n Base_quickcheck.Generator.size\n ~f:(fun [%p size_pat] ->\n Base_quickcheck.Generator.with_size\n ~size:(Base.Int.pred [%e size_expr])\n [%e make_generator clause])]\n in\n let expr = pexp_tuple ~loc [ weight_expr; gen_expr ] in\n value_binding ~loc ~pat ~expr)\n in\n let body =\n [%expr\n let [%p nonrec_pat] =\n Base_quickcheck.Generator.weighted_union [%e elist ~loc nonrec_exprs]\n and [%p rec_pat] =\n Base_quickcheck.Generator.weighted_union\n [%e elist ~loc (nonrec_exprs @ rec_exprs)]\n in\n Base_quickcheck.Generator.bind Base_quickcheck.Generator.size ~f:(function\n | 0 -> [%e nonrec_expr]\n | _ -> [%e rec_expr])]\n in\n pexp_let ~loc Nonrecursive bindings body\n;;\n","open! Import\n\nlet any ~loc = [%expr Base_quickcheck.Observer.opaque]\n\nlet arrow\n ~observer_of_core_type\n ~generator_of_core_type\n ~loc\n ~arg_label\n ~input_type\n ~output_type\n =\n let input_generator =\n match arg_label with\n | Nolabel | Labelled _ -> generator_of_core_type input_type\n | Optional _ ->\n [%expr Base_quickcheck.Generator.option [%e generator_of_core_type input_type]]\n in\n let output_observer = observer_of_core_type output_type in\n let unlabelled =\n [%expr Base_quickcheck.Observer.fn [%e input_generator] [%e output_observer]]\n in\n match arg_label with\n | Nolabel -> unlabelled\n | Labelled _ | Optional _ ->\n [%expr\n Base_quickcheck.Observer.unmap\n ~f:[%e fn_map_label ~loc ~from:arg_label ~to_:Nolabel]\n [%e unlabelled]]\n;;\n\nlet compound_hash ~loc ~size_expr ~hash_expr ~hash_pat ~observer_exprs ~field_exprs =\n let alist = List.zip_exn observer_exprs field_exprs in\n List.fold_right alist ~init:hash_expr ~f:(fun (observer_expr, field_expr) body_expr ->\n [%expr\n let [%p hash_pat] =\n Base_quickcheck.Observer.observe\n [%e observer_expr]\n [%e field_expr]\n ~size:[%e size_expr]\n ~hash:[%e hash_expr]\n in\n [%e body_expr]])\n;;\n\nlet compound\n (type field)\n ~observer_of_core_type\n ~loc\n ~fields\n (module Field : Field_syntax.S with type ast = field)\n =\n let fields = List.map fields ~f:Field.create in\n let field_pats, field_exprs = gensyms \"x\" (List.map fields ~f:Field.location) in\n let pat = Field.pattern fields ~loc field_pats in\n let observer_exprs =\n List.map fields ~f:(fun field -> observer_of_core_type (Field.core_type field))\n in\n let size_pat, size_expr = gensym \"size\" loc in\n let hash_pat, hash_expr = gensym \"hash\" loc in\n [%expr\n Base_quickcheck.Observer.create\n (fun [%p pat] ~size:[%p size_pat] ~hash:[%p hash_pat] ->\n [%e\n compound_hash ~loc ~size_expr ~hash_expr ~hash_pat ~observer_exprs ~field_exprs])]\n;;\n\nlet variant\n (type clause)\n ~observer_of_core_type\n ~loc\n ~clauses\n (module Clause : Clause_syntax.S with type ast = clause)\n =\n let clauses = Clause.create_list clauses in\n let pat, expr = gensym \"x\" loc in\n let size_pat, size_expr = gensym \"size\" loc in\n let hash_pat, hash_expr = gensym \"hash\" loc in\n [%expr\n Base_quickcheck.Observer.create\n (fun [%p pat] ~size:[%p size_pat] ~hash:[%p hash_pat] ->\n [%e\n pexp_match\n ~loc\n expr\n (List.map clauses ~f:(fun clause ->\n let core_type_list = Clause.core_type_list clause in\n let observer_exprs = List.map core_type_list ~f:observer_of_core_type in\n let field_pats, field_exprs =\n gensyms\n \"x\"\n (List.map core_type_list ~f:(fun core_type -> core_type.ptyp_loc))\n in\n let lhs = Clause.pattern clause ~loc field_pats in\n let body =\n compound_hash\n ~loc\n ~size_expr\n ~hash_expr\n ~hash_pat\n ~observer_exprs\n ~field_exprs\n in\n let rhs =\n match Clause.salt clause with\n | None -> body\n | Some salt ->\n pexp_let\n ~loc\n Nonrecursive\n [ value_binding\n ~loc\n ~pat:hash_pat\n ~expr:\n [%expr\n Base.hash_fold_int [%e hash_expr] [%e eint ~loc salt]]\n ]\n body\n in\n case ~lhs ~guard:None ~rhs))])]\n;;\n","open! Import\n\nlet custom_extension ~loc tag payload =\n match String.equal tag.txt \"custom\" with\n | false -> unsupported ~loc \"uknown extension: %s\" tag.txt\n | true ->\n (match payload with\n | PStr [ { pstr_desc = Pstr_eval (expr, attributes); _ } ] ->\n assert_no_attributes attributes;\n expr\n | _ -> invalid ~loc \"[%%custom] extension expects a single expression as its payload\")\n;;\n\nlet generator_attribute =\n Attribute.declare\n \"quickcheck.generator\"\n Attribute.Context.core_type\n Ast_pattern.(pstr (pstr_eval __ nil ^:: nil))\n (fun x -> x)\n;;\n\nlet rec generator_of_core_type core_type ~gen_env ~obs_env =\n let loc = { core_type.ptyp_loc with loc_ghost = true } in\n match Attribute.get generator_attribute core_type with\n | Some expr -> expr\n | None ->\n (match core_type.ptyp_desc with\n | Ptyp_constr (constr, args) ->\n type_constr_conv\n ~loc\n ~f:generator_name\n constr\n (List.map args ~f:(generator_of_core_type ~gen_env ~obs_env))\n | Ptyp_var tyvar -> Environment.lookup gen_env ~loc ~tyvar\n | Ptyp_arrow (arg_label, input_type, output_type) ->\n Ppx_generator_expander.arrow\n ~generator_of_core_type:(generator_of_core_type ~gen_env ~obs_env)\n ~observer_of_core_type:(observer_of_core_type ~gen_env ~obs_env)\n ~loc\n ~arg_label\n ~input_type\n ~output_type\n | Ptyp_tuple fields ->\n Ppx_generator_expander.compound\n ~generator_of_core_type:(generator_of_core_type ~gen_env ~obs_env)\n ~loc\n ~fields\n (module Field_syntax.Tuple)\n | Ptyp_variant (clauses, Closed, None) ->\n Ppx_generator_expander.variant\n ~generator_of_core_type:(generator_of_core_type ~gen_env ~obs_env)\n ~loc\n ~variant_type:core_type\n ~clauses\n ~rec_names:(Set.empty (module String))\n (module Clause_syntax.Polymorphic_variant)\n | Ptyp_variant (_, Open, _) -> unsupported ~loc \"polymorphic variant type with [>]\"\n | Ptyp_variant (_, _, Some _) -> unsupported ~loc \"polymorphic variant type with [<]\"\n | Ptyp_extension (tag, payload) -> custom_extension ~loc tag payload\n | Ptyp_any\n | Ptyp_object _\n | Ptyp_class _\n | Ptyp_alias _\n | Ptyp_poly _\n | Ptyp_package _ -> unsupported ~loc \"%s\" (short_string_of_core_type core_type))\n\nand observer_of_core_type core_type ~obs_env ~gen_env =\n let loc = { core_type.ptyp_loc with loc_ghost = true } in\n match core_type.ptyp_desc with\n | Ptyp_constr (constr, args) ->\n type_constr_conv\n ~loc\n ~f:observer_name\n constr\n (List.map args ~f:(observer_of_core_type ~obs_env ~gen_env))\n | Ptyp_var tyvar -> Environment.lookup obs_env ~loc ~tyvar\n | Ptyp_arrow (arg_label, input_type, output_type) ->\n Ppx_observer_expander.arrow\n ~observer_of_core_type:(observer_of_core_type ~obs_env ~gen_env)\n ~generator_of_core_type:(generator_of_core_type ~obs_env ~gen_env)\n ~loc\n ~arg_label\n ~input_type\n ~output_type\n | Ptyp_tuple fields ->\n Ppx_observer_expander.compound\n ~observer_of_core_type:(observer_of_core_type ~obs_env ~gen_env)\n ~loc\n ~fields\n (module Field_syntax.Tuple)\n | Ptyp_variant (clauses, Closed, None) ->\n Ppx_observer_expander.variant\n ~observer_of_core_type:(observer_of_core_type ~obs_env ~gen_env)\n ~loc\n ~clauses\n (module Clause_syntax.Polymorphic_variant)\n | Ptyp_variant (_, Open, _) -> unsupported ~loc \"polymorphic variant type with [>]\"\n | Ptyp_variant (_, _, Some _) -> unsupported ~loc \"polymorphic variant type with [<]\"\n | Ptyp_extension (tag, payload) -> custom_extension ~loc tag payload\n | Ptyp_any -> Ppx_observer_expander.any ~loc\n | Ptyp_object _ | Ptyp_class _ | Ptyp_alias _ | Ptyp_poly _ | Ptyp_package _ ->\n unsupported ~loc \"%s\" (short_string_of_core_type core_type)\n;;\n\nlet rec shrinker_of_core_type core_type ~env =\n let loc = { core_type.ptyp_loc with loc_ghost = true } in\n match core_type.ptyp_desc with\n | Ptyp_constr (constr, args) ->\n type_constr_conv\n ~loc\n ~f:shrinker_name\n constr\n (List.map args ~f:(shrinker_of_core_type ~env))\n | Ptyp_var tyvar -> Environment.lookup env ~loc ~tyvar\n | Ptyp_arrow _ -> Ppx_shrinker_expander.arrow ~loc\n | Ptyp_tuple fields ->\n Ppx_shrinker_expander.compound\n ~shrinker_of_core_type:(shrinker_of_core_type ~env)\n ~loc\n ~fields\n (module Field_syntax.Tuple)\n | Ptyp_variant (clauses, Closed, None) ->\n Ppx_shrinker_expander.variant\n ~shrinker_of_core_type:(shrinker_of_core_type ~env)\n ~loc\n ~variant_type:core_type\n ~clauses\n (module Clause_syntax.Polymorphic_variant)\n | Ptyp_variant (_, Open, _) -> unsupported ~loc \"polymorphic variant type with [>]\"\n | Ptyp_variant (_, _, Some _) -> unsupported ~loc \"polymorphic variant type with [<]\"\n | Ptyp_extension (tag, payload) -> custom_extension ~loc tag payload\n | Ptyp_any -> Ppx_shrinker_expander.any ~loc\n | Ptyp_object _ | Ptyp_class _ | Ptyp_alias _ | Ptyp_poly _ | Ptyp_package _ ->\n unsupported ~loc \"%s\" (short_string_of_core_type core_type)\n;;\n\ntype impl =\n { loc : location\n ; pat : pattern\n ; var : expression\n ; exp : expression\n }\n\nlet generator_impl type_decl ~rec_names =\n let loc = type_decl.ptype_loc in\n let pat = pgenerator type_decl.ptype_name in\n let var = egenerator type_decl.ptype_name in\n let exp =\n let pat_list, `Covariant gen_env, `Contravariant obs_env =\n Environment.create_with_variance\n ~loc\n ~covariant:\"generator\"\n ~contravariant:\"observer\"\n type_decl.ptype_params\n in\n let body =\n match type_decl.ptype_kind with\n | Ptype_open -> unsupported ~loc \"open type\"\n | Ptype_variant clauses ->\n Ppx_generator_expander.variant\n ~generator_of_core_type:(generator_of_core_type ~gen_env ~obs_env)\n ~loc\n ~variant_type:[%type: _]\n ~clauses\n ~rec_names\n (module Clause_syntax.Variant)\n | Ptype_record fields ->\n Ppx_generator_expander.compound\n ~generator_of_core_type:(generator_of_core_type ~gen_env ~obs_env)\n ~loc\n ~fields\n (module Field_syntax.Record)\n | Ptype_abstract ->\n (match type_decl.ptype_manifest with\n | Some core_type -> generator_of_core_type core_type ~gen_env ~obs_env\n | None -> unsupported ~loc \"abstract type\")\n in\n List.fold_right pat_list ~init:body ~f:(fun pat body ->\n [%expr fun [%p pat] -> [%e body]])\n in\n { loc; pat; var; exp }\n;;\n\nlet observer_impl type_decl ~rec_names:_ =\n let loc = type_decl.ptype_loc in\n let pat = pobserver type_decl.ptype_name in\n let var = eobserver type_decl.ptype_name in\n let exp =\n let pat_list, `Covariant obs_env, `Contravariant gen_env =\n Environment.create_with_variance\n ~loc\n ~covariant:\"observer\"\n ~contravariant:\"generator\"\n type_decl.ptype_params\n in\n let body =\n match type_decl.ptype_kind with\n | Ptype_open -> unsupported ~loc \"open type\"\n | Ptype_variant clauses ->\n Ppx_observer_expander.variant\n ~observer_of_core_type:(observer_of_core_type ~obs_env ~gen_env)\n ~loc\n ~clauses\n (module Clause_syntax.Variant)\n | Ptype_record fields ->\n Ppx_observer_expander.compound\n ~observer_of_core_type:(observer_of_core_type ~obs_env ~gen_env)\n ~loc\n ~fields\n (module Field_syntax.Record)\n | Ptype_abstract ->\n (match type_decl.ptype_manifest with\n | Some core_type -> observer_of_core_type core_type ~obs_env ~gen_env\n | None -> unsupported ~loc \"abstract type\")\n in\n List.fold_right pat_list ~init:body ~f:(fun pat body ->\n [%expr fun [%p pat] -> [%e body]])\n in\n { loc; pat; var; exp }\n;;\n\nlet shrinker_impl type_decl ~rec_names:_ =\n let loc = type_decl.ptype_loc in\n let pat = pshrinker type_decl.ptype_name in\n let var = eshrinker type_decl.ptype_name in\n let exp =\n let pat_list, env =\n Environment.create ~loc ~prefix:\"shrinker\" type_decl.ptype_params\n in\n let body =\n match type_decl.ptype_kind with\n | Ptype_open -> unsupported ~loc \"open type\"\n | Ptype_variant clauses ->\n Ppx_shrinker_expander.variant\n ~shrinker_of_core_type:(shrinker_of_core_type ~env)\n ~loc\n ~variant_type:[%type: _]\n ~clauses\n (module Clause_syntax.Variant)\n | Ptype_record fields ->\n Ppx_shrinker_expander.compound\n ~shrinker_of_core_type:(shrinker_of_core_type ~env)\n ~loc\n ~fields\n (module Field_syntax.Record)\n | Ptype_abstract ->\n (match type_decl.ptype_manifest with\n | Some core_type -> shrinker_of_core_type core_type ~env\n | None -> unsupported ~loc \"abstract type\")\n in\n List.fold_right pat_list ~init:body ~f:(fun pat body ->\n [%expr fun [%p pat] -> [%e body]])\n in\n { loc; pat; var; exp }\n;;\n\nlet maybe_mutually_recursive decls ~loc ~rec_flag ~of_lazy ~impl =\n let decls = List.map decls ~f:name_type_params_in_td in\n let rec_names =\n match rec_flag with\n | Nonrecursive -> Set.empty (module String)\n | Recursive ->\n Set.of_list (module String) (List.map decls ~f:(fun decl -> decl.ptype_name.txt))\n in\n let impls = List.map decls ~f:(fun decl -> impl decl ~rec_names) in\n match rec_flag with\n | Nonrecursive ->\n pstr_value_list\n ~loc\n Nonrecursive\n (List.map impls ~f:(fun impl ->\n value_binding ~loc:impl.loc ~pat:impl.pat ~expr:impl.exp))\n | Recursive ->\n let pats = List.map impls ~f:(fun impl -> impl.pat) in\n let bindings =\n let inner_bindings =\n List.map impls ~f:(fun inner ->\n value_binding\n ~loc:inner.loc\n ~pat:inner.pat\n ~expr:[%expr [%e of_lazy] [%e inner.var]])\n in\n List.map impls ~f:(fun impl ->\n let body = pexp_let ~loc:impl.loc Nonrecursive inner_bindings impl.exp in\n let lazy_expr = [%expr lazy [%e body]] in\n value_binding ~loc:impl.loc ~pat:impl.pat ~expr:lazy_expr)\n in\n let body =\n pexp_tuple\n ~loc\n (List.map impls ~f:(fun impl -> [%expr [%e of_lazy] [%e impl.var]]))\n in\n pstr_value_list\n ~loc\n Nonrecursive\n [ value_binding\n ~loc\n ~pat:(ppat_tuple ~loc pats)\n ~expr:(pexp_let ~loc Recursive bindings body)\n ]\n;;\n\nlet generator_impl_list decls ~loc ~rec_flag =\n maybe_mutually_recursive\n decls\n ~loc\n ~rec_flag\n ~of_lazy:[%expr Base_quickcheck.Generator.of_lazy]\n ~impl:generator_impl\n;;\n\nlet observer_impl_list decls ~loc ~rec_flag =\n maybe_mutually_recursive\n decls\n ~loc\n ~rec_flag\n ~of_lazy:[%expr Base_quickcheck.Observer.of_lazy]\n ~impl:observer_impl\n;;\n\nlet shrinker_impl_list decls ~loc ~rec_flag =\n maybe_mutually_recursive\n decls\n ~loc\n ~rec_flag\n ~of_lazy:[%expr Base_quickcheck.Shrinker.of_lazy]\n ~impl:shrinker_impl\n;;\n\nlet intf type_decl ~f ~covar ~contravar =\n let covar = Longident.parse (\"Base_quickcheck.\" ^ covar ^ \".t\") in\n let contravar = Longident.parse (\"Base_quickcheck.\" ^ contravar ^ \".t\") in\n let type_decl = name_type_params_in_td type_decl in\n let loc = type_decl.ptype_loc in\n let name = loc_map type_decl.ptype_name ~f in\n let result =\n ptyp_constr\n ~loc\n { loc; txt = covar }\n [ ptyp_constr\n ~loc\n (lident_loc type_decl.ptype_name)\n (List.map type_decl.ptype_params ~f:fst)\n ]\n in\n let type_ =\n List.fold_right\n type_decl.ptype_params\n ~init:result\n ~f:(fun (core_type, (variance, injectivity)) result ->\n let id =\n match (variance, injectivity) with\n | ((NoVariance | Covariant), NoInjectivity) -> covar\n | (Contravariant, NoInjectivity) -> contravar\n | (_, Injective) -> Location.raise_errorf ~loc \"Injective type parameters aren't supported.\"\n in\n let arg = ptyp_constr ~loc { loc; txt = id } [ core_type ] in\n [%type: [%t arg] -> [%t result]])\n in\n psig_value ~loc (value_description ~loc ~name ~type_ ~prim:[])\n;;\n\nlet shrinker_intf = intf ~f:shrinker_name ~covar:\"Shrinker\" ~contravar:\"Shrinker\"\nlet generator_intf = intf ~f:generator_name ~covar:\"Generator\" ~contravar:\"Observer\"\nlet observer_intf = intf ~f:observer_name ~covar:\"Observer\" ~contravar:\"Generator\"\nlet generator_intf_list type_decl_list = List.map type_decl_list ~f:generator_intf\nlet observer_intf_list type_decl_list = List.map type_decl_list ~f:observer_intf\nlet shrinker_intf_list type_decl_list = List.map type_decl_list ~f:shrinker_intf\n\nlet sig_type_decl =\n Deriving.Generator.make_noarg (fun ~loc:_ ~path:_ (_, decls) ->\n generator_intf_list decls @ observer_intf_list decls @ shrinker_intf_list decls)\n;;\n\nlet str_type_decl =\n Deriving.Generator.make_noarg (fun ~loc ~path:_ (rec_flag, decls) ->\n let rec_flag = really_recursive rec_flag decls in\n generator_impl_list ~loc ~rec_flag decls\n @ observer_impl_list ~loc ~rec_flag decls\n @ shrinker_impl_list ~loc ~rec_flag decls)\n;;\n\nlet generator_extension ~loc:_ ~path:_ core_type =\n generator_of_core_type core_type ~gen_env:Environment.empty ~obs_env:Environment.empty\n;;\n\nlet observer_extension ~loc:_ ~path:_ core_type =\n observer_of_core_type core_type ~obs_env:Environment.empty ~gen_env:Environment.empty\n;;\n\nlet shrinker_extension ~loc:_ ~path:_ core_type =\n shrinker_of_core_type core_type ~env:Environment.empty\n;;\n","open! Base\nopen Ppxlib\nopen Ppx_quickcheck_expander\n\nlet (_ : Deriving.t) = Deriving.add \"quickcheck\" ~sig_type_decl ~str_type_decl\nlet (_ : Deriving.t) = Deriving.add \"quickcheck.generator\" ~extension:generator_extension\nlet (_ : Deriving.t) = Deriving.add \"quickcheck.observer\" ~extension:observer_extension\nlet (_ : Deriving.t) = Deriving.add \"quickcheck.shrinker\" ~extension:shrinker_extension\n","module Kimchi_backend_common = struct\n module Field = Kimchi_backend_common.Field\n module Scalar_challenge = Kimchi_backend_common.Scalar_challenge\nend\n\nmodule Field = Kimchi_backend_common.Field\n\nmodule Pasta = struct\n module Basic = Kimchi_pasta.Basic\n module Pallas_based_plonk = Kimchi_pasta.Pallas_based_plonk\n module Pasta = Kimchi_pasta.Pasta\n module Vesta_based_plonk = Kimchi_pasta.Vesta_based_plonk\nend\n","module Tick = struct\n include Kimchi_backend.Pasta.Vesta_based_plonk\n module Inner_curve = Kimchi_backend.Pasta.Pasta.Pallas\nend\n\nmodule Tock = struct\n include Kimchi_backend.Pasta.Pallas_based_plonk\n module Inner_curve = Kimchi_backend.Pasta.Pasta.Vesta\nend\n","(* Based on this paper. https://eprint.iacr.org/2019/403 *)\n\nopen Core_kernel\n\nmodule Spec = struct\n type 'f t = { b : 'f } [@@deriving bin_io]\nend\n\nmodule Params = struct\n type 'f t =\n { u : 'f\n ; fu : 'f\n ; sqrt_neg_three_u_squared_minus_u_over_2 : 'f\n ; sqrt_neg_three_u_squared : 'f\n ; inv_three_u_squared : 'f\n ; b : 'f\n }\n [@@deriving fields, bin_io]\n\n let spec { b; _ } = { Spec.b }\n\n let map\n { u\n ; fu\n ; sqrt_neg_three_u_squared_minus_u_over_2\n ; sqrt_neg_three_u_squared\n ; inv_three_u_squared\n ; b\n } ~f =\n { u = f u\n ; fu = f fu\n ; sqrt_neg_three_u_squared_minus_u_over_2 =\n f sqrt_neg_three_u_squared_minus_u_over_2\n ; sqrt_neg_three_u_squared = f sqrt_neg_three_u_squared\n ; inv_three_u_squared = f inv_three_u_squared\n ; b = f b\n }\n\n (* A deterministic function for constructing a valid choice of parameters for a\n given field. *)\n let create (type t) (module F : Field_intf.S_unchecked with type t = t)\n { Spec.b } =\n let open F in\n let first_map f =\n let rec go i = match f i with Some x -> x | None -> go (i + one) in\n go zero\n in\n let curve_eqn u = (u * u * u) + b in\n let u, fu =\n first_map (fun u ->\n let fu = curve_eqn u in\n if equal u zero || equal fu zero then None else Some (u, fu) )\n in\n let three_u_squared = u * u * of_int 3 in\n let sqrt_neg_three_u_squared = sqrt (negate three_u_squared) in\n { u\n ; fu\n ; sqrt_neg_three_u_squared_minus_u_over_2 =\n (sqrt_neg_three_u_squared - u) / of_int 2\n ; sqrt_neg_three_u_squared\n ; inv_three_u_squared = one / three_u_squared\n ; b\n }\nend\n\nmodule Make\n (Constant : Field_intf.S) (F : sig\n include Field_intf.S\n\n val constant : Constant.t -> t\n end) (P : sig\n val params : Constant.t Params.t\n end) =\nstruct\n open F\n open P\n\n let square x = x * x\n\n let potential_xs t =\n let t2 = t * t in\n let alpha =\n let alpha_inv = (t2 + constant params.fu) * t2 in\n one / alpha_inv\n in\n let x1 =\n let temp = square t2 * alpha * constant params.sqrt_neg_three_u_squared in\n constant params.sqrt_neg_three_u_squared_minus_u_over_2 - temp\n in\n let x2 = negate (constant params.u) - x1 in\n let x3 =\n let t2_plus_fu = t2 + constant params.fu in\n let t2_inv = alpha * t2_plus_fu in\n let temp =\n square t2_plus_fu * t2_inv * constant params.inv_three_u_squared\n in\n constant params.u - temp\n in\n (x1, x2, x3)\nend\n\nlet to_group (type t) (module F : Field_intf.S_unchecked with type t = t)\n ~params t =\n let module M =\n Make\n (F)\n (struct\n include F\n\n let constant = Fn.id\n end)\n (struct\n let params = params\n end)\n in\n let b = params.b in\n let try_decode x =\n let f x = F.((x * x * x) + b) in\n let y = f x in\n if F.is_square y then Some (x, F.sqrt y) else None\n in\n let x1, x2, x3 = M.potential_xs t in\n List.find_map [ x1; x2; x3 ] ~f:try_decode |> Option.value_exn\n\nlet%test_module \"test\" =\n ( module struct\n module Fp = struct\n include\n Snarkette.Fields.Make_fp\n (Snarkette.Nat)\n (struct\n let order =\n Snarkette.Nat.of_string\n \"5543634365110765627805495722742127385843376434033820803590214255538854698464778703795540858859767700241957783601153\"\n end)\n\n let b = of_int 7\n end\n\n module Make_tests (F : sig\n include Field_intf.S_unchecked\n\n val gen : t Quickcheck.Generator.t\n\n val b : t\n end) =\n struct\n module F = struct\n include F\n\n let constant = Fn.id\n end\n\n open F\n\n let params = Params.create (module F) { b }\n\n let curve_eqn u = (u * u * u) + params.b\n\n (* Filter the two points which cause the group-map to blow up. This\n is not an issue in practice because the points we feed into this function\n will be the output of poseidon, and thus (modeling poseidon as a random oracle)\n will not be either of those two points. *)\n let gen =\n Quickcheck.Generator.filter F.gen ~f:(fun t ->\n let t2 = t * t in\n let alpha_inv = (t2 + constant params.fu) * t2 in\n not (equal alpha_inv zero) )\n\n module M =\n Make (F) (F)\n (struct\n let params = params\n end)\n\n let%test_unit \"full map works\" =\n Quickcheck.test ~sexp_of:F.sexp_of_t gen ~f:(fun t ->\n let x, y = to_group (module F) ~params t in\n assert (equal (curve_eqn x) (y * y)) )\n end\n\n module T0 = Make_tests (Fp)\n end )\n","open Core_kernel\nopen Async_kernel\n\nlet autogen_path = \"/tmp/coda_cache_dir\"\n\nlet s3_install_path = \"/tmp/s3_cache_dir\"\n\nlet s3_keys_bucket_prefix =\n \"https://s3-us-west-2.amazonaws.com/snark-keys.o1test.net\"\n\nlet manual_install_path = \"/var/lib/coda\"\n\nlet brew_install_path = \"/usr/local/var/coda\"\n\nlet cache = []\n\nlet env_path = manual_install_path\n\nlet possible_paths base =\n List.map\n [ env_path\n ; brew_install_path\n ; s3_install_path\n ; autogen_path\n ; manual_install_path\n ] ~f:(fun d -> d ^ \"/\" ^ base)\n\nlet load_from_s3 _s3_bucket_prefix _s3_install_path ~logger:_ =\n Deferred.Or_error.fail (Error.createf \"Cannot load files from S3\")\n","(*\n\n This follows the approach of SvdW06 to construct a \"near injection\" from\n a field into an elliptic curve defined over that field. WB19 is also a useful\n reference that details several constructions which are more appropriate in other\n contexts.\n\n Fix an elliptic curve E given by y^2 = x^3 + ax + b over a field \"F\"\n Let f(x) = x^3 + ax + b.\n\n Define the variety V to be\n (x1, x2, x3, x4) : f(x1) f(x2) f(x3) = x4^2.\n\n By a not-too-hard we have a map `V -> E`. Thus, a map of type `F -> V` yields a\n map of type `F -> E` by composing.\n\n Our goal is to construct such a map of type `F -> V`. The paper SvdW06 constructs\n a family of such maps, defined by a collection of values which we'll term `params`.\n\n Define `params` to be the type of records of the form\n { u: F\n ; u_over_2: F\n ; projection_point: { z : F; y : F }\n ; conic_c: F\n ; a: F\n ; b: F }\n such that\n - a and b are the coefficients of our curve's defining equation.\n - u satisfies\n i. 0 <> 3/4 u^2 + a\n ii. 0 <> f(u)\n iii. -f(u) is not a square.\n - conic_c = 3/4 u^2 + a\n - {z; y} satisfy\n i. z^2 + conic_c * y^2 = -f(u)\n\n We will define a map of type `params -> (F -> V)`. Thus, fixing a choice of\n a value of type params, we obtain a map `F -> V` as desired.\n\nSvdW06: Shallue and van de Woestijne, \"Construction of rational points on elliptic curves over finite fields.\" Proc. ANTS 2006. https://works.bepress.com/andrew_shallue/1/download/\nWB19: Riad S. Wahby and Dan Boneh, Fast and simple constant-time hashing to the BLS12-381 elliptic curve. https://eprint.iacr.org/2019/403\n*)\n\n(* we have φ(t) : F -> S\n and φ1(λ) : S -> V with\n V(F) : f(x1)f(x2)f(x3) = x4^2,\n (f is y^2 = x^3 + Bx + C)) (note choice of constant names\n -- A is coeff of x^2 so A = 0 for us)\n\n To construct a rational point on V(F), the authors define\n the surface S(F) and the rational map φ1:S(F)→ V(F), which\n is invertible on its image [SvdW06, Lemma 6]:\n S(F) : y^2(u^2 + uv + v^2 + a) = −f(u)\n\n φ(t) : t → ( u, α(t)/β(t) - u/2, β(t) )\n φ1: (u, v, y) → ( v, −u − v, u + y^2,\n f(u + y^2)·(y^2 + uv + v^2 + ay)/y )\n*)\n\nopen Core_kernel\nmodule Field_intf = Field_intf\nmodule Bw19 = Bw19\n\nlet ( = ) = `Don't_use_polymorphic_compare\n\nlet _ = ( = )\n\nmodule Intf (F : sig\n type t\nend) =\nstruct\n module type S = sig\n val to_group : F.t -> F.t * F.t\n end\nend\n\nmodule type S = sig\n module Spec : sig\n type _ t [@@deriving bin_io]\n end\n\n module Params : sig\n type 'f t [@@deriving bin_io]\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val spec : 'f t -> 'f Spec.t\n\n val create :\n (module Field_intf.S_unchecked with type t = 'f) -> 'f Spec.t -> 'f t\n end\n\n module Make\n (Constant : Field_intf.S) (F : sig\n include Field_intf.S\n\n val constant : Constant.t -> t\n end) (Params : sig\n val params : Constant.t Params.t\n end) : sig\n val potential_xs : F.t -> F.t * F.t * F.t\n end\n\n val to_group :\n (module Field_intf.S_unchecked with type t = 'f)\n -> params:'f Params.t\n -> 'f\n -> 'f * 'f\nend\n\nmodule Conic = struct\n type 'f t = { z : 'f; y : 'f } [@@deriving bin_io]\n\n let map { z; y } ~f = { z = f z; y = f y }\nend\n\nmodule S = struct\n (* S = S(u, v, y) : y^2(u^2 + uv + v^2 + a) = −f(u)\n from (12)\n *)\n type 'f t = { u : 'f; v : 'f; y : 'f }\nend\n\nmodule V = struct\n (* V = V(x1, x2, x3, x4) : f(x1)f(x2)f(x3) = x4^2\n from (8)\n *)\n type 'f t = 'f * 'f * 'f * 'f\nend\n\nmodule Spec = struct\n type 'f t = { a : 'f; b : 'f } [@@deriving fields, bin_io]\nend\n\nmodule Params = struct\n type 'f t =\n { u : 'f\n ; u_over_2 : 'f\n ; projection_point : 'f Conic.t\n ; conic_c : 'f\n ; spec : 'f Spec.t\n }\n [@@deriving fields, bin_io]\n\n let map { u; u_over_2; projection_point; conic_c; spec = { a; b } } ~f =\n { u = f u\n ; u_over_2 = f u_over_2\n ; projection_point = Conic.map ~f projection_point\n ; conic_c = f conic_c\n ; spec = { a = f a; b = f b }\n }\n\n (* A deterministic function for constructing a valid choice of parameters for a\n given field.\n\n We start by finding the first `u` satisfying the constraints described above,\n then find the first `y` satisyfing the condition described above. The other\n values are derived from these two choices*.\n\n *Actually we have one bit of freedom in choosing `z` as z = sqrt(conic_c y^2 - conic_d),\n since there are two square roots.\n *)\n\n let create (type t) (module F : Field_intf.S_unchecked with type t = t)\n ({ Spec.a; b } as spec) =\n let open F in\n let first_map f =\n let rec go i = match f i with Some x -> x | None -> go (i + one) in\n go zero\n in\n let first f = first_map (fun x -> Option.some_if (f x) x) in\n let three_fourths = of_int 3 / of_int 4 in\n let curve_eqn u = (u * u * u) + (a * u) + b in\n let u =\n first (fun u ->\n (* from (15), A = 0, B = Params.a *)\n let check = (three_fourths * u * u) + a in\n let fu = curve_eqn u in\n (not (equal check zero))\n && (not (equal fu zero))\n && not (is_square (negate fu))\n (* imeckler: I added this condition. It prevents the possibility of having\n a point (z, 0) on the conic, which is useful because in the map from the\n conic to S we divide by the \"y\" coordinate of the conic. It's not strictly\n necessary when we have a random input in a large field, but it is still nice to avoid the\n bad case in theory (and for the tests below with a small field). *) )\n in\n (* The coefficients defining the conic z^2 + c y^2 = d\n in (15). *)\n let conic_c = (three_fourths * u * u) + a in\n let conic_d = negate (curve_eqn u) in\n let projection_point =\n first_map (fun y ->\n let z2 = conic_d - (conic_c * y * y) in\n if F.is_square z2 then Some { Conic.z = F.sqrt z2; y } else None )\n in\n { u; u_over_2 = u / of_int 2; conic_c; projection_point; spec }\nend\n\nmodule Make\n (Constant : Field_intf.S) (F : sig\n include Field_intf.S\n\n val constant : Constant.t -> t\n end) (P : sig\n val params : Constant.t Params.t\n end) =\nstruct\n open F\n\n (* For a curve z^2 + c y^2 = d and a point (z0, y0) on the curve, there\n is one other point on the curve which is also on the line through (z0, y0)\n with slope t. This function returns that point. *)\n let field_to_conic t =\n let z0, y0 =\n ( constant P.params.projection_point.z\n , constant P.params.projection_point.y )\n in\n let ct = constant P.params.conic_c * t in\n let s = of_int 2 * ((ct * y0) + z0) / ((ct * t) + one) in\n { Conic.z = z0 - s; y = y0 - (s * t) }\n\n (* From (16) : φ(λ) : F → S : λ → ( u, α(λ)/β(λ) - u/2, β(λ) ) *)\n let conic_to_s { Conic.z; y } =\n { S.u = constant P.params.u\n ; v = (z / y) - constant P.params.u_over_2 (* From (16) *)\n ; y\n }\n\n (* This is here for explanatory purposes. See s_to_v_truncated. *)\n let _s_to_v { S.u; v; y } : _ V.t =\n let curve_eqn x =\n (x * x * x) + (constant P.params.spec.a * x) + constant P.params.spec.b\n in\n let h = (u * u) + (u * v) + (v * v) + constant P.params.spec.a in\n (v, negate (u + v), u + (y * y), curve_eqn (u + (y * y)) * h / y)\n\n (* from (13) *)\n\n (* We don't actually need to compute the final coordinate in V *)\n let s_to_v_truncated { S.u; v; y } = (v, negate (u + v), u + (y * y))\n\n let potential_xs =\n let ( @ ) = Fn.compose in\n s_to_v_truncated @ conic_to_s @ field_to_conic\nend\n\nlet to_group (type t) (module F : Field_intf.S_unchecked with type t = t)\n ~params t =\n let module M =\n Make\n (F)\n (struct\n include F\n\n let constant = Fn.id\n end)\n (struct\n let params = params\n end)\n in\n let { Spec.a; b } = params.spec in\n let try_decode x =\n let f x = F.((x * x * x) + (a * x) + b) in\n let y = f x in\n if F.is_square y then Some (x, F.sqrt y) else None\n in\n let x1, x2, x3 = M.potential_xs t in\n List.find_map [ x1; x2; x3 ] ~f:try_decode |> Option.value_exn\n\nlet%test_module \"test\" =\n ( module struct\n module Fp = struct\n include\n Snarkette.Fields.Make_fp\n (Snarkette.Nat)\n (struct\n let order = Snarkette.Nat.of_int 100003\n end)\n\n let a = of_int 1\n\n let b = of_int 3\n end\n\n module F13 = struct\n type t = int [@@deriving sexp]\n\n let p = 13\n\n let ( + ) x y = (x + y) mod p\n\n let ( * ) x y = x * y mod p\n\n let negate x = (p - x) mod p\n\n let ( - ) x y = (x - y + p) mod p\n\n let equal = Int.equal\n\n let ( / ) x y =\n let rec go i = if equal x (i * y) then i else go (i + 1) in\n if equal y 0 then failwith \"Divide by 0\" else go 1\n\n let sqrt' x =\n let rec go i =\n if Int.equal i p then None\n else if equal (i * i) x then Some i\n else go Int.(i + 1)\n in\n go 0\n\n let sqrt x = Option.value_exn (sqrt' x)\n\n let is_square x = Option.is_some (sqrt' x)\n\n let zero = 0\n\n let one = 1\n\n let of_int = Fn.id\n\n let gen = Int.gen_incl 0 Int.(p - 1)\n\n let a = 1\n\n let b = 3\n end\n\n module Make_tests (F : sig\n include Field_intf.S_unchecked\n\n val gen : t Quickcheck.Generator.t\n\n val a : t\n\n val b : t\n end) =\n struct\n module F = struct\n include F\n\n let constant = Fn.id\n end\n\n open F\n\n let params = Params.create (module F) { a; b }\n\n let curve_eqn u = (u * u * u) + (params.spec.a * u) + params.spec.b\n\n let conic_d =\n let open F in\n negate (curve_eqn params.u)\n\n let on_conic { Conic.z; y } =\n F.(equal ((z * z) + (params.conic_c * y * y)) conic_d)\n\n let on_s { S.u; v; y } =\n F.(equal conic_d (y * y * ((u * u) + (u * v) + (v * v) + a)))\n\n let on_v (x1, x2, x3, x4) =\n F.(equal (curve_eqn x1 * curve_eqn x2 * curve_eqn x3) (x4 * x4))\n\n (* Filter the two points which cause the group-map to blow up. This\n is not an issue in practice because the points we feed into this function\n will be the output of blake2s, and thus (modeling blake2s as a random oracle)\n will not be either of those two points. *)\n let gen =\n Quickcheck.Generator.filter F.gen ~f:(fun t ->\n not F.(equal ((params.conic_c * t * t) + one) zero) )\n\n module M =\n Make (F) (F)\n (struct\n let params = params\n end)\n\n let%test \"projection point well-formed\" = on_conic params.projection_point\n\n let%test_unit \"field-to-conic\" =\n Quickcheck.test ~sexp_of:F.sexp_of_t gen ~f:(fun t ->\n assert (on_conic (M.field_to_conic t)) )\n\n let%test_unit \"conic-to-S\" =\n let conic_gen =\n Quickcheck.Generator.filter_map F.gen ~f:(fun y ->\n let z2 = conic_d - (params.conic_c * y * y) in\n if is_square z2 then Some { Conic.z = sqrt z2; y } else None )\n in\n Quickcheck.test conic_gen ~f:(fun p -> assert (on_s (M.conic_to_s p)))\n\n let%test_unit \"field-to-S\" =\n Quickcheck.test ~sexp_of:F.sexp_of_t gen ~f:(fun t ->\n assert (on_s (Fn.compose M.conic_to_s M.field_to_conic t)) )\n\n (* Schwarz-zippel says if this tests succeeds once, then the probability that\n the implementation is correct is at least 1 - (D / field-size), where D is\n the total degree of the polynomial defining_equation_of_V(s_to_v(t)) which should\n be less than, say, 10. So, this test succeeding gives good evidence of the\n correctness of the implementation (assuming that the implementation is just a\n polynomial, which it is by parametricity!) *)\n let%test_unit \"field-to-V\" =\n Quickcheck.test ~sexp_of:F.sexp_of_t gen ~f:(fun t ->\n let s = M.conic_to_s (M.field_to_conic t) in\n assert (on_v (M._s_to_v s)) )\n\n let%test_unit \"full map works\" =\n Quickcheck.test ~sexp_of:F.sexp_of_t gen ~f:(fun t ->\n let x, y = to_group (module F) ~params t in\n assert (equal (curve_eqn x) (y * y)) )\n end\n\n module T0 = Make_tests (F13)\n module T1 = Make_tests (Fp)\n end )\n","(*\n * Copyright (c) 2006-2009 Citrix Systems Inc.\n * Copyright (c) 2010 Thomas Gazagnaire \n * Copyright (c) 2014-2016 Anil Madhavapeddy \n * Copyright (c) 2016 David Kaloper Meršinjak\n * Copyright (c) 2018 Romain Calascibetta \n *\n * Permission to use, copy, modify, and distribute this software for any\n * purpose with or without fee is hereby granted, provided that the above\n * copyright notice and this permission notice appear in all copies.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES\n * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF\n * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR\n * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES\n * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN\n * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF\n * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.\n *\n *)\n\ntype alphabet =\n { emap : int array\n ; dmap : int array }\n\ntype sub = string * int * int\n\nlet (//) x y =\n if y < 1 then raise Division_by_zero ;\n if x > 0 then 1 + ((x - 1) / y) else 0\n[@@inline]\n\nlet unsafe_get_uint8 t off = Char.code (String.unsafe_get t off)\nlet unsafe_set_uint8 t off v = Bytes.unsafe_set t off (Char.chr v)\nlet unsafe_set_uint16 = Unsafe.unsafe_set_uint16\n\nexternal unsafe_get_uint16 : string -> int -> int = \"%caml_string_get16u\" [@@noalloc]\nexternal swap16 : int -> int = \"%bswap16\" [@@noalloc]\n\nlet none = (-1)\n\n(* We mostly want to have an optional array for [dmap] (e.g. [int option\n array]). So we consider the [none] value as [-1]. *)\n\nlet make_alphabet alphabet =\n if String.length alphabet <> 64 then invalid_arg \"Length of alphabet must be 64\" ;\n if String.contains alphabet '=' then invalid_arg \"Alphabet can not contain padding character\" ;\n let emap = Array.init (String.length alphabet) (fun i -> Char.code (String.get alphabet i)) in\n let dmap = Array.make 256 none in\n String.iteri (fun idx chr -> Array.set dmap (Char.code chr) idx) alphabet ;\n { emap; dmap; }\n\nlet length_alphabet { emap; _ } = Array.length emap\nlet alphabet { emap; _ } = emap\n\nlet default_alphabet = make_alphabet \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\"\nlet uri_safe_alphabet = make_alphabet \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_\"\n\nlet unsafe_set_be_uint16 =\n if Sys.big_endian\n then fun t off v -> unsafe_set_uint16 t off v\n else fun t off v -> unsafe_set_uint16 t off (swap16 v)\n\n(* We make this exception to ensure to keep a control about which exception we\n can raise and avoid appearance of unknown exceptions like an ex-nihilo\n magic rabbit (or magic money?). *)\nexception Out_of_bounds\nexception Too_much_input\n\nlet get_uint8 t off =\n if off < 0 || off >= String.length t then raise Out_of_bounds ;\n unsafe_get_uint8 t off\n\nlet padding = int_of_char '='\n\nlet error_msgf fmt = Format.ksprintf (fun err -> Error (`Msg err)) fmt\n\nlet encode_sub pad { emap; _ } ?(off = 0) ?len input =\n let len = match len with\n | Some len -> len\n | None -> String.length input - off in\n\n if len < 0 || off < 0 || off > String.length input - len\n then error_msgf \"Invalid bounds\"\n else\n let n = len in\n let n' = n // 3 * 4 in\n let res = Bytes.create n' in\n\n let emap i = Array.unsafe_get emap i in\n\n let emit b1 b2 b3 i =\n unsafe_set_be_uint16 res i\n ((emap (b1 lsr 2 land 0x3f) lsl 8)\n lor (emap ((b1 lsl 4) lor (b2 lsr 4) land 0x3f))) ;\n unsafe_set_be_uint16 res (i + 2)\n ((emap ((b2 lsl 2) lor (b3 lsr 6) land 0x3f) lsl 8)\n lor (emap (b3 land 0x3f))) in\n\n let rec enc j i =\n if i = n then ()\n else if i = n - 1\n then emit (unsafe_get_uint8 input (off + i)) 0 0 j\n else if i = n - 2\n then emit (unsafe_get_uint8 input (off + i)) (unsafe_get_uint8 input (off + i + 1)) 0 j\n else\n (emit\n (unsafe_get_uint8 input (off + i))\n (unsafe_get_uint8 input (off + i + 1))\n (unsafe_get_uint8 input (off + i + 2))\n j ;\n enc (j + 4) (i + 3)) in\n\n let rec unsafe_fix = function\n | 0 -> ()\n | i -> unsafe_set_uint8 res (n' - i) padding ; unsafe_fix (i - 1) in\n\n enc 0 0 ;\n\n let pad_to_write = ((3 - n mod 3) mod 3) in\n\n if pad\n then begin unsafe_fix pad_to_write ; Ok (Bytes.unsafe_to_string res, 0, n') end\n else Ok (Bytes.unsafe_to_string res, 0, (n' - pad_to_write))\n(* [pad = false], we don't want to write them. *)\n\nlet encode ?(pad = true) ?(alphabet = default_alphabet) ?off ?len input =\n match encode_sub pad alphabet ?off ?len input with\n | Ok (res, off, len) -> Ok (String.sub res off len)\n | Error _ as err -> err\n\nlet encode_string ?pad ?alphabet input =\n match encode ?pad ?alphabet input with\n | Ok res -> res\n | Error _ -> assert false\n\nlet encode_sub ?(pad = true) ?(alphabet = default_alphabet) ?off ?len input =\n encode_sub pad alphabet ?off ?len input\n\nlet encode_exn ?pad ?alphabet ?off ?len input =\n match encode ?pad ?alphabet ?off ?len input with\n | Ok v -> v\n | Error (`Msg err) -> invalid_arg err\n\nlet decode_sub ?(pad = true) { dmap; _ } ?(off = 0) ?len input =\n let len = match len with\n | Some len -> len\n | None -> String.length input - off in\n\n if len < 0 || off < 0 || off > String.length input - len\n then error_msgf \"Invalid bounds\"\n else\n\n let n = (len // 4) * 4 in\n let n' = (n // 4) * 3 in\n let res = Bytes.create n' in\n let invalid_pad_overflow = pad in\n\n let get_uint8_or_padding =\n if pad then (fun t i -> if i >= len then raise Out_of_bounds ; get_uint8 t (off + i) )\n else (fun t i -> try if i < len then get_uint8 t (off + i) else padding with Out_of_bounds -> padding ) in\n\n let set_be_uint16 t off v =\n (* can not write 2 bytes. *)\n if off < 0 || off + 1 > Bytes.length t then ()\n (* can not write 1 byte but can write 1 byte *)\n else if off < 0 || off + 2 > Bytes.length t then unsafe_set_uint8 t off (v lsr 8)\n (* can write 2 bytes. *)\n else unsafe_set_be_uint16 t off v in\n\n let set_uint8 t off v =\n if off < 0 || off >= Bytes.length t then ()\n else unsafe_set_uint8 t off v in\n\n let emit a b c d j =\n let x = (a lsl 18) lor (b lsl 12) lor (c lsl 6) lor d in\n set_be_uint16 res j (x lsr 8) ;\n set_uint8 res (j + 2) (x land 0xff) in\n\n let dmap i =\n let x = Array.unsafe_get dmap i in\n if x = none then raise Not_found ; x in\n\n let only_padding pad idx =\n\n (* because we round length of [res] to the upper bound of how many\n characters we should have from [input], we got at this stage only padding\n characters and we need to delete them, so for each [====], we delete 3\n bytes. *)\n\n let pad = ref (pad + 3) in\n let idx = ref idx in\n\n while !idx + 4 < len do\n (* use [unsafe_get_uint16] instead [unsafe_get_uint32] to avoid allocation\n of [int32]. Of course, [3d3d3d3d] is [====]. *)\n if unsafe_get_uint16 input (off + !idx) <> 0x3d3d\n || unsafe_get_uint16 input (off + !idx + 2) <> 0x3d3d\n then raise Not_found ;\n (* We got something bad, should be a valid character according to\n [alphabet] but outside the scope. *)\n\n idx := !idx + 4 ;\n pad := !pad + 3 ;\n done ;\n while !idx < len do\n if unsafe_get_uint8 input (off + !idx) <> padding\n then raise Not_found ;\n\n incr idx ;\n done ; !pad in\n\n let rec dec j i =\n if i = n then 0\n else begin\n let (d, pad) =\n let x = get_uint8_or_padding input (i + 3) in\n try (dmap x, 0) with Not_found when x = padding -> (0, 1) in\n (* [Not_found] iff [x ∉ alphabet and x <> '='] can leak. *)\n let (c, pad) =\n let x = get_uint8_or_padding input (i + 2) in\n try (dmap x, pad) with Not_found when x = padding && pad = 1 -> (0, 2) in\n (* [Not_found] iff [x ∉ alphabet and x <> '='] can leak. *)\n let (b, pad) =\n let x = get_uint8_or_padding input (i + 1) in\n try (dmap x, pad) with Not_found when x = padding && pad = 2 -> (0, 3) in\n (* [Not_found] iff [x ∉ alphabet and x <> '='] can leak. *)\n let (a, pad) =\n let x = get_uint8_or_padding input i in\n try (dmap x, pad) with Not_found when x = padding && pad = 3 -> (0, 4) in\n (* [Not_found] iff [x ∉ alphabet and x <> '='] can leak. *)\n\n emit a b c d j ;\n\n if i + 4 = n\n (* end of input in anyway *)\n then match pad with\n | 0 ->\n 0\n | 4 ->\n (* assert (invalid_pad_overflow = false) ; *)\n 3\n (* [get_uint8] lies and if we get [4], that mean we got one or more (at\n most 4) padding character. In this situation, because we round length\n of [res] (see [n // 4]), we need to delete 3 bytes. *)\n | pad ->\n pad\n else match pad with\n | 0 -> dec (j + 3) (i + 4)\n | 4 ->\n (* assert (invalid_pad_overflow = false) ; *)\n only_padding 3 (i + 4)\n (* Same situation than above but we should get only more padding\n characters then. *)\n | pad ->\n if invalid_pad_overflow = true then raise Too_much_input ;\n only_padding pad (i + 4) end in\n\n match dec 0 0 with\n | 0 -> Ok (Bytes.unsafe_to_string res, 0, n')\n | pad -> Ok (Bytes.unsafe_to_string res, 0, (n' - pad))\n | exception Out_of_bounds -> error_msgf \"Wrong padding\"\n (* appear only when [pad = true] and when length of input is not a multiple of 4. *)\n | exception Not_found ->\n (* appear when one character of [input] ∉ [alphabet] and this character <> '=' *)\n error_msgf \"Malformed input\"\n | exception Too_much_input ->\n error_msgf \"Too much input\"\n\nlet decode ?pad ?(alphabet = default_alphabet) ?off ?len input =\n match decode_sub ?pad alphabet ?off ?len input with\n | Ok (res, off, len) -> Ok (String.sub res off len)\n | Error _ as err -> err\n\nlet decode_sub ?pad ?(alphabet = default_alphabet) ?off ?len input =\n decode_sub ?pad alphabet ?off ?len input\n\nlet decode_exn ?pad ?alphabet ?off ?len input =\n match decode ?pad ?alphabet ?off ?len input with\n | Ok res -> res\n | Error (`Msg err) -> invalid_arg err\n","open Core_kernel\n\nmodule Aux (Impl : Snarky_backendless.Snark_intf.Run) = struct\n open Impl\n\n let non_residue : Field.Constant.t Lazy.t =\n let open Field.Constant in\n let rec go i = if not (is_square i) then i else go (i + one) in\n lazy (go (of_int 2))\n\n let sqrt_exn x =\n let y =\n exists Field.typ ~compute:(fun () ->\n Field.Constant.sqrt (As_prover.read_var x) )\n in\n assert_square y x ; y\n\n (* let sqrt_flagged : Field.t -> Field.t * Boolean.var = *)\n let sqrt_flagged x =\n (*\n imeckler: I learned this trick from Dan Boneh\n\n m a known non residue\n\n exists is_square : bool, y.\n if is_square then assert y*y = x else assert y*y = m * x\n\n <=>\n\n assert (y*y = if is_square then x else m * x)\n *)\n let is_square =\n exists Boolean.typ ~compute:(fun () ->\n Field.Constant.is_square (As_prover.read_var x) )\n in\n let m = Lazy.force non_residue in\n (sqrt_exn (Field.if_ is_square ~then_:x ~else_:(Field.scale x m)), is_square)\nend\n\nlet wrap (type f) ((module Impl) : f Snarky_backendless.Snark0.m) ~potential_xs\n ~y_squared =\n let open Impl in\n let module A = Aux (Impl) in\n let open A in\n stage (fun x ->\n let x1, x2, x3 = potential_xs x in\n let y1, b1 = sqrt_flagged (y_squared ~x:x1)\n and y2, b2 = sqrt_flagged (y_squared ~x:x2)\n and y3, b3 = sqrt_flagged (y_squared ~x:x3) in\n Boolean.Assert.any [ b1; b2; b3 ] ;\n let x1_is_first = (b1 :> Field.t)\n and x2_is_first = (Boolean.((not b1) && b2) :> Field.t)\n and x3_is_first = (Boolean.((not b1) && (not b2) && b3) :> Field.t) in\n ( Field.((x1_is_first * x1) + (x2_is_first * x2) + (x3_is_first * x3))\n , Field.((x1_is_first * y1) + (x2_is_first * y2) + (x3_is_first * y3)) ) )\n\nmodule Make\n (M : Snarky_backendless.Snark_intf.Run) (P : sig\n val params : M.field Group_map.Params.t\n end) =\nstruct\n open P\n include Group_map.Make (M.Field.Constant) (M.Field) (P)\n open M\n\n let to_group =\n let { Group_map.Spec.a; b } = Group_map.Params.spec params in\n unstage\n (wrap\n (module M)\n ~potential_xs\n ~y_squared:Field.(fun ~x -> (x * x * x) + scale x a + constant b) )\nend\n","open Core_kernel\nmodule Params = Group_map.Params\n\nlet to_group (type t)\n (module F : Group_map.Field_intf.S_unchecked with type t = t) ~params t =\n let module M =\n Group_map.Make\n (F)\n (struct\n include F\n\n let constant = Fn.id\n end)\n (struct\n let params = params\n end)\n in\n let { Group_map.Spec.a; b } = Params.spec params in\n let try_decode x =\n let f x = F.((x * x * x) + (a * x) + b) in\n let y = f x in\n if F.is_square y then Some (x, F.sqrt y) else None\n in\n let x1, x2, x3 = M.potential_xs t in\n List.find_map [ x1; x2; x3 ] ~f:try_decode |> Option.value_exn\n\nmodule Checked = struct\n open Snarky_backendless\n\n let wrap = Checked_map.wrap\n\n let to_group (type f) (module M : Snark_intf.Run with type field = f) ~params\n t =\n let module G =\n Checked_map.Make\n (M)\n (struct\n let params = params\n end)\n in\n G.to_group t\nend\n","open Core_kernel\nopen Pickles_types\n\nmodule Constant = struct\n type t = int\nend\n\n(* TODO: Optimization(?) Have this have length n - 1 since the last one is\n determined by the remaining ones. *)\ntype ('f, 'n) t =\n ('f Snarky_backendless.Cvar.t Snarky_backendless.Boolean.t, 'n) Vector.t\n\nmodule T (Impl : Snarky_backendless.Snark_intf.Run) = struct\n type nonrec 'n t = (Impl.field, 'n) t\nend\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.Run) = struct\n module Constant = Constant\n open Impl\n include T (Impl)\n\n let of_index i ~length =\n let v = Vector.init length ~f:(fun j -> Field.equal (Field.of_int j) i) in\n Boolean.Assert.any (Vector.to_list v) ;\n v\n\n let of_vector_unsafe = Fn.id\n\n let typ (n : 'n Nat.t) : ('n t, Constant.t) Typ.t =\n let (Typ typ) = Vector.typ Boolean.typ n in\n let typ : _ Typ.t =\n Typ\n { typ with\n check =\n (fun x ->\n Impl.Internal_Basic.Checked.bind (typ.check x) ~f:(fun () ->\n make_checked (fun () ->\n Boolean.Assert.exactly_one (Vector.to_list x) ) ) )\n }\n in\n Typ.transport typ\n ~there:(fun i -> Vector.init n ~f:(( = ) i))\n ~back:(fun v ->\n let i, _ =\n List.findi (Vector.to_list v) ~f:(fun _ b -> b) |> Option.value_exn\n in\n i )\nend\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = { h : Domain.Stable.V1.t }\n [@@deriving fields, sexp, compare, yojson]\n\n let to_latest = Fn.id\n end\nend]\n","open Core_kernel\nopen Pickles_types\n\nmodule T (Impl : Snarky_backendless.Snark_intf.Run) (N : Pickles_types.Nat.Intf) =\nstruct\n open Impl\n\n type t = Field.t\n\n let length = 64 * Nat.to_int N.n\n\n module Constant = Constant.Make (N)\n\n let typ : (Field.t, Constant.t) Typ.t =\n Typ.field\n |> Typ.transport\n ~there:(fun x -> Field.Constant.project (Constant.to_bits x))\n ~back:(fun x ->\n Constant.of_bits (List.take (Field.Constant.unpack x) length) )\nend\n","open Pickles_types\n\ntype 'f t = 'f Snarky_backendless.Cvar.t\n\nmodule Constant = Constant.Make (Nat.N2)\n\nmodule type S = sig\n module Impl : Snarky_backendless.Snark_intf.Run\n\n open Impl\n\n type nonrec t = field t\n\n module Constant : sig\n type t = Constant.t [@@deriving sexp_of]\n\n val to_bits : t -> bool list\n\n val of_bits : bool list -> t\n\n val dummy : t\n end\n\n val typ : (t, Constant.t) Typ.t\n\n val length : int\nend\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.Run) :\n S with module Impl := Impl =\n Make.T (Impl) (Nat.N2)\n","open Pickles_types\nopen Core_kernel\nmodule Limbs = Nat.N4\n\nmodule Constant = struct\n include Limb_vector.Constant.Make (Limbs)\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t =\n Limb_vector.Constant.Hex64.Stable.V1.t Vector.Vector_4.Stable.V1.t\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n (* Force the typechecker to verify that these types are equal. *)\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n open Backend\n\n let to_tick_field x = Tick.Field.of_bits (to_bits x)\n\n let to_tock_field x = Tock.Field.of_bits (to_bits x)\n\n let of_tick_field x = of_bits (Tick.Field.to_bits x)\nend\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.Run) = struct\n open Impl\n\n type t = Field.t\n\n let to_bits = Field.choose_preimage_var ~length:Field.size_in_bits\n\n module Unsafe = struct\n let to_bits_unboolean x =\n with_label __LOC__ (fun () ->\n let length = Field.size_in_bits in\n let res =\n exists\n (Typ.list Boolean.typ_unchecked ~length)\n ~compute:As_prover.(fun () -> Field.Constant.unpack (read_var x))\n in\n Field.Assert.equal x (Field.project res) ;\n res )\n end\n\n let () = assert (Field.size_in_bits < 64 * Nat.to_int Limbs.n)\n\n module Constant = struct\n include Constant\n\n let to_bits x = List.take (to_bits x) Field.size_in_bits\n end\n\n let typ =\n Typ.transport Field.typ\n ~there:(Fn.compose Field.Constant.project Constant.to_bits)\n ~back:(Fn.compose Constant.of_bits Field.Constant.unpack)\nend\n","module D = Digest\nopen Core_kernel\nopen Pickles_types\nopen Hlist\nmodule Sc = Kimchi_backend_common.Scalar_challenge\n\ntype 'f impl = (module Snarky_backendless.Snark_intf.Run with type field = 'f)\n\ntype ('a, 'b, 'c) basic =\n | Unit : (unit, unit, < .. >) basic\n | Field\n : ('field1, 'field2, < field1 : 'field1 ; field2 : 'field2 ; .. >) basic\n | Bool : ('bool1, 'bool2, < bool1 : 'bool1 ; bool2 : 'bool2 ; .. >) basic\n | Digest\n : ( 'digest1\n , 'digest2\n , < digest1 : 'digest1 ; digest2 : 'digest2 ; .. > )\n basic\n | Challenge\n : ( 'challenge1\n , 'challenge2\n , < challenge1 : 'challenge1 ; challenge2 : 'challenge2 ; .. > )\n basic\n | Bulletproof_challenge\n : ( 'bp_chal1\n , 'bp_chal2\n , < bulletproof_challenge1 : 'bp_chal1\n ; bulletproof_challenge2 : 'bp_chal2\n ; .. > )\n basic\n | Branch_data\n : ( 'branch_data1\n , 'branch_data2\n , < branch_data1 : 'branch_data1 ; branch_data2 : 'branch_data2 ; .. >\n )\n basic\n\nmodule type Bool_intf = sig\n type var\n\n val true_ : var\n\n val false_ : var\nend\n\nmodule rec T : sig\n type (_, _, _) t =\n | B : ('a, 'b, 'env) basic -> ('a, 'b, 'env) t\n | Scalar :\n ('a, 'b, (< challenge1 : 'a ; challenge2 : 'b ; .. > as 'env)) basic\n -> ('a Sc.t, 'b Sc.t, 'env) t\n | Vector :\n ('t1, 't2, 'env) t * 'n Nat.t\n -> (('t1, 'n) Vector.t, ('t2, 'n) Vector.t, 'env) t\n | Array : ('t1, 't2, 'env) t * int -> ('t1 array, 't2 array, 'env) t\n | Struct :\n ('xs1, 'xs2, 'env) H2_1.T(T).t\n -> ('xs1 Hlist.HlistId.t, 'xs2 Hlist.HlistId.t, 'env) t\n | Opt :\n { inner : ('a1, 'a2, (< bool1 : bool ; bool2 : 'bool ; .. > as 'env)) t\n ; flag : Opt.Flag.t\n ; dummy1 : 'a1\n ; dummy2 : 'a2\n ; bool : (module Bool_intf with type var = 'bool)\n }\n -> ('a1 option, ('a2, 'bool) Opt.t, 'env) t\n | Opt_unflagged :\n { inner : ('a1, 'a2, (< bool1 : bool ; bool2 : 'bool ; .. > as 'env)) t\n ; flag : Opt.Flag.t\n ; dummy1 : 'a1\n ; dummy2 : 'a2\n }\n -> ('a1 option, 'a2 option, 'env) t\n | Constant : 'a * ('a -> 'a -> unit) * ('a, 'b, 'env) t -> ('a, 'b, 'env) t\nend =\n T\n\ntype ('scalar, 'env) pack =\n { pack : 'a 'b. ('a, 'b, 'env) basic -> 'a option -> 'b -> 'scalar array }\n\nlet rec pack :\n type t v env.\n zero:'scalar\n -> one:'scalar\n -> ('scalar, env) pack\n -> (t, v, env) T.t\n -> t option\n -> v\n -> 'scalar array =\n fun ~zero ~one p spec t_constant_opt t ->\n match spec with\n | B spec ->\n p.pack spec t_constant_opt t\n | Scalar chal ->\n let t_constant_opt =\n Option.map t_constant_opt ~f:(fun { Sc.inner = x } -> x)\n in\n let { Sc.inner = t } = t in\n p.pack chal t_constant_opt t\n | Vector (spec, _) ->\n let t_constant_opt = Option.map ~f:Vector.to_array t_constant_opt in\n let t = Vector.to_array t in\n pack ~zero ~one p (Array (spec, Array.length t)) t_constant_opt t\n | Struct [] ->\n [||]\n | Struct (spec :: specs) ->\n let (hd :: tl) = t in\n let hd_constant_opt, tl_constant_opt =\n match t_constant_opt with\n | None ->\n (None, None)\n | Some (hd :: tl) ->\n (Some hd, Some tl)\n in\n let hd = pack ~zero ~one p spec hd_constant_opt hd in\n Array.append hd (pack ~zero ~one p (Struct specs) tl_constant_opt tl)\n | Array (spec, _) ->\n Array.concat_mapi t ~f:(fun i t ->\n let t_constant_opt =\n Option.map t_constant_opt ~f:(fun t_const -> t_const.(i))\n in\n pack ~zero ~one p spec t_constant_opt t )\n | Opt { inner; dummy1; dummy2; flag = _; bool = _ } -> (\n match t with\n | Nothing ->\n let t_constant_opt = Option.map t_constant_opt ~f:(fun _ -> dummy1) in\n Array.append [| zero |]\n (pack ~zero ~one p inner t_constant_opt dummy2)\n | Just x ->\n let t_constant_opt =\n Option.map ~f:(fun x -> Option.value_exn x) t_constant_opt\n in\n Array.append [| one |] (pack ~zero ~one p inner t_constant_opt x)\n | Maybe (b, x) ->\n let b_constant_opt = Option.map ~f:Option.is_some t_constant_opt in\n let x_constant_opt =\n Option.map ~f:(Option.value ~default:dummy1) t_constant_opt\n in\n Array.append\n (p.pack Bool b_constant_opt b)\n (pack ~zero ~one p inner x_constant_opt x) )\n | Opt_unflagged { inner; dummy1; dummy2; flag = _ } -> (\n match t with\n | None ->\n let t_constant_opt = Option.map t_constant_opt ~f:(fun _ -> dummy1) in\n pack ~zero ~one p inner t_constant_opt dummy2\n | Some x ->\n let t_constant_opt =\n Option.map ~f:(fun x -> Option.value_exn x) t_constant_opt\n in\n pack ~zero ~one p inner t_constant_opt x )\n | Constant (x, _, inner) ->\n pack ~zero ~one p inner (Some x) t\n\ntype ('f, 'env) typ =\n { typ :\n 'var 'value.\n ('value, 'var, 'env) basic -> ('var, 'value, 'f) Snarky_backendless.Typ.t\n }\n\nlet rec typ :\n type f var value env.\n (f, env) typ\n -> (value, var, env) T.t\n -> (var, value, f) Snarky_backendless.Typ.t =\n let open Snarky_backendless.Typ in\n fun t spec ->\n match[@warning \"-45\"] spec with\n | B spec ->\n t.typ spec\n | Scalar chal ->\n Sc.typ (t.typ chal)\n | Vector (spec, n) ->\n Vector.typ (typ t spec) n\n | Array (spec, n) ->\n array ~length:n (typ t spec)\n | Struct [] ->\n let open Hlist.HlistId in\n transport (unit ()) ~there:(fun [] -> ()) ~back:(fun () -> [])\n |> transport_var ~there:(fun [] -> ()) ~back:(fun () -> [])\n | Struct (spec :: specs) ->\n let open Hlist.HlistId in\n tuple2 (typ t spec) (typ t (Struct specs))\n |> transport\n ~there:(fun (x :: xs) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n |> transport_var\n ~there:(fun (x :: xs) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n | Opt { inner; flag; dummy1; dummy2; bool = (module B) } ->\n let bool = typ t (B Bool) in\n let open B in\n (* Always use the same \"maybe\" layout which is a boolean and then the value *)\n Opt.constant_layout_typ bool flag ~dummy:dummy1 ~dummy_var:dummy2 ~true_\n ~false_ (typ t inner)\n | Opt_unflagged { inner; flag; dummy1; dummy2 } -> (\n match flag with\n | Opt.Flag.No ->\n let open Snarky_backendless.Typ in\n unit ()\n |> Snarky_backendless.Typ.transport\n ~there:(function Some _ -> assert false | None -> ())\n ~back:(fun () -> None)\n |> Snarky_backendless.Typ.transport_var\n ~there:(function Some _ -> assert false | None -> ())\n ~back:(fun _ -> None)\n | Opt.Flag.(Yes | Maybe) ->\n typ t inner\n |> Snarky_backendless.Typ.transport\n ~there:(function Some x -> x | None -> dummy1)\n ~back:(fun x -> Some x)\n |> Snarky_backendless.Typ.transport_var\n ~there:(function Some x -> x | None -> dummy2)\n ~back:(fun x -> Some x) )\n | Constant (x, assert_eq, spec) ->\n let (Typ typ) = typ t spec in\n let constant_var =\n let fields, aux = typ.value_to_fields x in\n let fields =\n Array.map fields ~f:(fun x -> Snarky_backendless.Cvar.Constant x)\n in\n typ.var_of_fields (fields, aux)\n in\n let open Snarky_backendless.Typ in\n unit ()\n |> transport ~there:(fun y -> assert_eq x y) ~back:(fun () -> x)\n |> transport_var ~there:(fun _ -> ()) ~back:(fun () -> constant_var)\n\nmodule ETyp = struct\n type ('var, 'value, 'f) t =\n | T :\n ('inner, 'value, 'f) Snarky_backendless.Typ.t\n * ('inner -> 'var)\n * ('var -> 'inner)\n -> ('var, 'value, 'f) t\nend\n\ntype ('f, 'env) etyp =\n { etyp : 'var 'value. ('value, 'var, 'env) basic -> ('var, 'value, 'f) ETyp.t\n }\n\nlet rec etyp :\n type f var value env.\n (f, env) etyp -> (value, var, env) T.t -> (var, value, f) ETyp.t =\n let open Snarky_backendless.Typ in\n fun e spec ->\n match[@warning \"-45\"] spec with\n | B spec ->\n e.etyp spec\n | Scalar chal ->\n let (T (typ, f, f_inv)) = e.etyp chal in\n T (Sc.typ typ, Sc.map ~f, Sc.map ~f:f_inv)\n | Vector (spec, n) ->\n let (T (typ, f, f_inv)) = etyp e spec in\n T (Vector.typ typ n, Vector.map ~f, Vector.map ~f:f_inv)\n | Array (spec, n) ->\n let (T (typ, f, f_inv)) = etyp e spec in\n T (array ~length:n typ, Array.map ~f, Array.map ~f:f_inv)\n | Struct [] ->\n let open Hlist.HlistId in\n let there [] = () in\n let back () = [] in\n T\n ( transport (unit ()) ~there ~back |> transport_var ~there ~back\n , Fn.id\n , Fn.id )\n | Struct (spec :: specs) ->\n let open Hlist.HlistId in\n let (T (t1, f1, f1_inv)) = etyp e spec in\n let (T (t2, f2, f2_inv)) = etyp e (Struct specs) in\n T\n ( tuple2 t1 t2\n |> transport\n ~there:(fun (x :: xs) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n , (fun (x, xs) -> f1 x :: f2 xs)\n , fun (x :: xs) -> (f1_inv x, f2_inv xs) )\n | Opt { inner; flag; dummy1; dummy2; bool = (module B) } ->\n let (T (bool, f_bool, f_bool')) = etyp e (B Bool) in\n let (T (a, f_a, f_a')) = etyp e inner in\n let opt_map ~f1 ~f2 (x : _ Opt.t) : _ Opt.t =\n match x with\n | Nothing ->\n Opt.nothing\n | Just x ->\n Opt.just (f1 x)\n | Maybe (b, x) ->\n Maybe (f2 b, f1 x)\n in\n let f = opt_map ~f1:f_a ~f2:f_bool in\n let f' = opt_map ~f1:f_a' ~f2:f_bool' in\n T\n ( Opt.constant_layout_typ ~dummy:dummy1 ~dummy_var:(f_a' dummy2)\n ~true_:(f_bool' B.true_) ~false_:(f_bool' B.false_) bool flag a\n , f\n , f' )\n | Opt_unflagged { inner; dummy1; dummy2; flag = _ } ->\n let (T (typ, f, f_inv)) = etyp e inner in\n let f x = Some (f x) in\n let f_inv = function None -> f_inv dummy2 | Some x -> f_inv x in\n let typ =\n typ\n |> Snarky_backendless.Typ.transport\n ~there:(Option.value ~default:dummy1) ~back:(fun x -> Some x)\n in\n T (typ, f, f_inv)\n | Constant (x, _assert_eq, spec) ->\n let (T (Typ typ, f, f')) = etyp e spec in\n let constant_var =\n let fields, aux = typ.value_to_fields x in\n let fields =\n Array.map fields ~f:(fun x -> Snarky_backendless.Cvar.Constant x)\n in\n typ.var_of_fields (fields, aux)\n in\n (* We skip any constraints that would be added here, but we *do* use\n the underlying [Typ.t] to make sure that we allocate public inputs\n correctly.\n *)\n T\n ( Typ\n { typ with\n check =\n (fun _ -> Snarky_backendless.Checked_runner.Simple.return ())\n }\n , (fun _ -> f constant_var)\n , f' )\n\nmodule Common (Impl : Snarky_backendless.Snark_intf.Run) = struct\n module Digest = D.Make (Impl)\n module Challenge = Limb_vector.Challenge.Make (Impl)\n open Impl\n\n module Env = struct\n type ('other_field, 'other_field_var, 'a) t =\n < field1 : 'other_field\n ; field2 : 'other_field_var\n ; bool1 : bool\n ; bool2 : Boolean.var\n ; digest1 : Digest.Constant.t\n ; digest2 : Digest.t\n ; challenge1 : Challenge.Constant.t\n ; challenge2 : Challenge.t\n ; bulletproof_challenge1 :\n Challenge.Constant.t Sc.t Bulletproof_challenge.t\n ; bulletproof_challenge2 : Challenge.t Sc.t Bulletproof_challenge.t\n ; branch_data1 : Branch_data.t\n ; branch_data2 : Impl.field Branch_data.Checked.t\n ; .. >\n as\n 'a\n end\nend\n\nlet pack_basic (type field other_field other_field_var)\n ((module Impl) : field impl) =\n let open Impl in\n let module C = Common (Impl) in\n let open C in\n let pack :\n type a b.\n (a, b, ((other_field, other_field_var, 'e) Env.t as 'e)) basic\n -> a option\n -> b\n -> [ `Field of other_field_var | `Packed_bits of Field.t * int ] array =\n fun basic x_constant_opt x ->\n (* TODO *)\n ignore x_constant_opt ;\n match basic with\n | Unit ->\n [||]\n | Field ->\n [| `Field x |]\n | Bool ->\n [| `Packed_bits ((x :> Field.t), 1) |]\n | Digest ->\n [| `Packed_bits (x, Field.size_in_bits) |]\n | Challenge ->\n [| `Packed_bits (x, Challenge.length) |]\n | Branch_data ->\n [| `Packed_bits\n ( Branch_data.Checked.pack (module Impl) x\n , Branch_data.length_in_bits )\n |]\n | Bulletproof_challenge ->\n let { Sc.inner = pre } = Bulletproof_challenge.pack x in\n [| `Packed_bits (pre, Challenge.length) |]\n in\n { pack }\n\nlet pack (type f) ((module Impl) as impl : f impl) t =\n let open Impl in\n pack (pack_basic impl) t\n ~zero:(`Packed_bits (Field.zero, 1))\n ~one:(`Packed_bits (Field.one, 1))\n None\n\nlet typ_basic (type field other_field other_field_var)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = field)\n ~assert_16_bits (field : (other_field_var, other_field) Impl.Typ.t) =\n let open Impl in\n let module C = Common (Impl) in\n let open C in\n let typ :\n type a b.\n (a, b, ((other_field, other_field_var, 'e) Env.t as 'e)) basic\n -> (b, a) Impl.Typ.t =\n fun basic ->\n match basic with\n | Unit ->\n Typ.unit\n | Field ->\n field\n | Bool ->\n Boolean.typ\n | Branch_data ->\n Branch_data.typ (module Impl) ~assert_16_bits\n | Digest ->\n Digest.typ\n | Challenge ->\n Challenge.typ\n | Bulletproof_challenge ->\n Bulletproof_challenge.typ Challenge.typ\n in\n { typ }\n\nlet typ ~assert_16_bits impl field t =\n typ (typ_basic ~assert_16_bits impl field) t\n\nlet packed_typ_basic (type field other_field other_field_var)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = field)\n (field : (other_field_var, other_field, field) ETyp.t) =\n let open Impl in\n let module Digest = D.Make (Impl) in\n let module Challenge = Limb_vector.Challenge.Make (Impl) in\n let module Env = struct\n type ('other_field, 'other_field_var, 'a) t =\n < field1 : 'other_field\n ; field2 : 'other_field_var\n ; bool1 : bool\n ; bool2 : Boolean.var\n ; digest1 : Digest.Constant.t\n ; digest2 : Field.t\n ; challenge1 : Challenge.Constant.t\n ; challenge2 : (* Challenge.t *) Field.t\n ; bulletproof_challenge1 :\n Challenge.Constant.t Sc.t Bulletproof_challenge.t\n ; bulletproof_challenge2 : Field.t Sc.t Bulletproof_challenge.t\n ; branch_data1 : Branch_data.t\n ; branch_data2 : Field.t\n ; .. >\n as\n 'a\n end in\n let etyp :\n type a b.\n (a, b, ((other_field, other_field_var, 'e) Env.t as 'e)) basic\n -> (b, a, field) ETyp.t = function\n | Unit ->\n T (Typ.unit, Fn.id, Fn.id)\n | Field ->\n field\n | Bool ->\n T (Boolean.typ, Fn.id, Fn.id)\n | Digest ->\n T (Digest.typ, Fn.id, Fn.id)\n | Challenge ->\n T (Challenge.typ, Fn.id, Fn.id)\n | Branch_data ->\n T (Branch_data.packed_typ (module Impl), Fn.id, Fn.id)\n | Bulletproof_challenge ->\n let typ =\n let there bp_challenge =\n let { Sc.inner = pre } = Bulletproof_challenge.pack bp_challenge in\n pre\n in\n let back pre = Bulletproof_challenge.unpack { Sc.inner = pre } in\n Typ.transport Challenge.typ ~there ~back\n |> Typ.transport_var ~there ~back\n in\n T (typ, Fn.id, Fn.id)\n in\n { etyp }\n\nlet packed_typ impl field t = etyp (packed_typ_basic impl field) t\n","open Core_kernel\nopen Pickles_types\nmodule Domain = Plonk_checks.Domain\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.Run) = struct\n open Impl\n\n type ('a, 'n) t = 'n One_hot_vector.T(Impl).t * ('a, 'n) Vector.t\n\n (* TODO: Use version in common. *)\n let seal (x : Impl.Field.t) : Impl.Field.t =\n let open Impl in\n match Field.to_constant_and_terms x with\n | None, [ (x, i) ] when Field.Constant.(equal x one) ->\n Snarky_backendless.Cvar.Var i\n | Some c, [] ->\n Field.constant c\n | _ ->\n let y = exists Field.typ ~compute:As_prover.(fun () -> read_var x) in\n Field.Assert.equal x y ; y\n\n let mask (type n) (bits : n One_hot_vector.T(Impl).t) xs =\n with_label __LOC__ (fun () ->\n Vector.map\n (Vector.zip (bits :> (Boolean.var, n) Vector.t) xs)\n ~f:(fun (b, x) -> Field.((b :> t) * x))\n |> Vector.fold ~init:Field.zero ~f:Field.( + ) )\n\n let choose : type a n. (a, n) t -> f:(a -> Field.t) -> Field.t =\n fun (bits, xs) ~f -> mask bits (Vector.map xs ~f)\n\n module Degree_bound = struct\n type nonrec 'n t = (int, 'n) t\n\n let shifted_pow ~crs_max_degree t x =\n let pow = Field.(Pcs_batch.pow ~one ~mul) in\n choose t ~f:(fun deg ->\n let d = deg mod crs_max_degree in\n pow x (crs_max_degree - d) )\n end\n\n module Domain = struct\n let num_shifts = Nat.to_int Pickles_types.Plonk_types.Permuts.n\n\n (** Compute the 'shifts' used by the kimchi permutation argument.\n\n These values are selected deterministically-randomly to appear outside\n of the domain, so that every choice of [i] and [shift] results in a\n distinct value for [shift * domain_generator ^ i].\n\n Note that, for each different domain size, we attempt to use the same\n [shifts], and only sample different ones if the shifts are already a\n member of the domain (ie. there exists some [i] such that\n [shift = domain_generator ^ i]). This ensures that the invariant above\n is satisfied.\n Optimisation: since the shifts for the domains that we use in practise\n are all the same -- none of them have 2-adic order < largest domain\n size -- we can hard-code the shifts instead of using a one-hot mask,\n and this function adds no constraints to the circuit.\n *)\n let shifts (type n) ((which, log2s) : (int, n) t)\n ~(shifts : log2_size:int -> Field.Constant.t array) :\n Field.t Pickles_types.Plonk_types.Shifts.t =\n let all_shifts = Vector.map log2s ~f:(fun d -> shifts ~log2_size:d) in\n match all_shifts with\n | [] ->\n failwith \"Pseudo.Domain.shifts: no domains were given\"\n | shifts :: other_shiftss ->\n (* Runtime check that the shifts across all domains are consistent.\n The optimisation below will not work if this is not true; if the\n domain size or the shifts are modified such that this becomes\n false, [disabled_not_the_same] can be set to true to enable\n dynamic selection within the circuit.\n *)\n let all_the_same =\n Vector.for_all other_shiftss\n ~f:(Array.for_all2_exn ~f:Field.Constant.equal shifts)\n in\n (* Set to true if we do not want to allow dynamic selection of the\n shifts at runtime.\n This is possible because of the optimisation outlined in the\n doc-comment above, but this option and the original code is left\n here in case we transition to a larger domain size that uses\n different shifts than those for smaller domains.\n *)\n let disabled_not_the_same = true in\n if all_the_same then Array.map ~f:Field.constant shifts\n else if disabled_not_the_same then\n failwith \"Pseudo.Domain.shifts: found variable shifts\"\n else\n let get_ith_shift i =\n mask which\n (Vector.map all_shifts ~f:(fun a -> Field.constant a.(i)))\n in\n Array.init num_shifts ~f:get_ith_shift\n\n let generator (type n) ((which, log2s) : (int, n) t) ~domain_generator =\n mask which (Vector.map log2s ~f:(fun d -> domain_generator ~log2_size:d))\n\n type nonrec 'n t = (Domain.t, 'n) t\n\n let to_domain ~shifts:s ~domain_generator (type n) (t : n t) :\n Field.t Plonk_checks.plonk_domain =\n let log2_sizes = Vector.map (snd t) ~f:Domain.log2_size in\n let shifts = shifts (fst t, log2_sizes) ~shifts:s in\n let generator = generator (fst t, log2_sizes) ~domain_generator in\n let max_log2 =\n let _, ds = t in\n List.fold (Vector.to_list ds) ~init:0 ~f:(fun acc d ->\n Int.max acc (Domain.log2_size d) )\n in\n object\n method shifts = shifts\n\n method generator = generator\n\n method vanishing_polynomial x =\n let pow2_pows =\n let res = Array.create ~len:(max_log2 + 1) x in\n for i = 1 to max_log2 do\n res.(i) <- Field.square res.(i - 1)\n done ;\n res\n in\n let open Field in\n seal (choose t ~f:(fun d -> pow2_pows.(Domain.log2_size d)) - one)\n end\n end\nend\n","(* version_bytes.ml -- version bytes for Base58Check encodings *)\n\ntype t = char\n\n(** Base58Check version bytes for individual types\n Each of the following values should be distinct\n*)\n\nlet coinbase : t = '\\x01'\n\nlet secret_box_byteswr : t = '\\x02'\n\nlet fee_transfer_single : t = '\\x03'\n\nlet frontier_hash : t = '\\x04'\n\nlet ledger_hash : t = '\\x05'\n\nlet lite_precomputed : t = '\\x06'\n\nlet proof : t = '\\x0A'\n\nlet random_oracle_base : t = '\\x0B'\n\nlet receipt_chain_hash : t = '\\x0C'\n\nlet epoch_seed : t = '\\x0D'\n\nlet staged_ledger_hash_aux_hash : t = '\\x0E'\n\nlet staged_ledger_hash_pending_coinbase_aux : t = '\\x0F'\n\nlet state_hash : t = '\\x10'\n\nlet state_body_hash : t = '\\x11'\n\n(* don't use \\x12, which was for pre-Berkeley hard fork transaction hashes *)\n\n(* used only to deserialize transaction ids, pre-Berkeley hard fork *)\nlet signed_command_v1 : t = '\\x13'\n\nlet user_command_memo : t = '\\x14'\n\nlet vrf_truncated_output : t = '\\x15'\n\nlet web_pipe : t = '\\x16'\n\nlet coinbase_stack_data : t = '\\x17'\n\nlet coinbase_stack_hash : t = '\\x18'\n\nlet pending_coinbase_hash_builder : t = '\\x19'\n\nlet zkapp_command : t = '\\x1A'\n\nlet verification_key : t = '\\x1B'\n\nlet token_id_key : t = '\\x1C'\n\nlet transaction_hash : t = '\\x1D'\n\n(** used for testing only *)\n\nlet ledger_test_hash : t = '\\x30'\n\n(** The following version bytes are non-sequential; existing\n user key infrastructure depends on them. don't change them!\n*)\n\nlet private_key : t = '\\x5A'\n\nlet non_zero_curve_point_compressed : t = '\\xCB'\n\nlet signature : t = '\\x9A'\n","(* base58_check.ml : implement Base58Check algorithm\n see: https://www.oreilly.com/library/view/mastering-bitcoin-2nd/9781491954379/ch04.html#base58\n also: https://datatracker.ietf.org/doc/html/draft-msporny-base58-03\n\n the algorithm is modified for long strings, to apply encoding on chunks of the input\n*)\n\nopen Core_kernel\n\nexception Invalid_base58_checksum of string\n\nexception Invalid_base58_version_byte of (char * string)\n\nexception Invalid_base58_check_length of string\n\nexception Invalid_base58_character of string\n\n(* same as Bitcoin alphabet *)\nlet mina_alphabet =\n B58.make_alphabet \"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\"\n\nlet version_len = 1\n\nlet checksum_len = 4\n\nmodule Make (M : sig\n val description : string\n\n val version_byte : char\nend) =\nstruct\n let version_byte = M.version_byte\n\n let version_string = String.make 1 version_byte\n\n let max_length = 8192\n\n let compute_checksum payload =\n (* double-hash using SHA256 *)\n let open Digestif.SHA256 in\n let ctx0 = init () in\n let ctx1 = feed_string ctx0 version_string in\n let ctx2 = feed_string ctx1 payload in\n let first_hash = get ctx2 |> to_raw_string in\n let ctx3 = feed_string ctx0 first_hash in\n let second_hash = get ctx3 |> to_raw_string in\n second_hash |> String.sub ~pos:0 ~len:checksum_len\n\n (* we don't name this with _exn, we don't expect to raise an exception\n if we do, we're encoding types that shouldn't be encoded\n *)\n let encode payload =\n let len = String.length payload in\n if len > max_length then\n failwithf\n \"String is too long (%d bytes) to Base58Check-encode, max length is %d\"\n len max_length () ;\n let checksum = compute_checksum payload in\n let bytes = version_string ^ payload ^ checksum |> Bytes.of_string in\n B58.encode mina_alphabet bytes |> Bytes.to_string\n\n let decode_exn s =\n let bytes = Bytes.of_string s in\n let decoded =\n try B58.decode mina_alphabet bytes |> Bytes.to_string\n with B58.Invalid_base58_character ->\n raise (Invalid_base58_character M.description)\n in\n let len = String.length decoded in\n (* input must be at least as long as the version byte and checksum *)\n if len < version_len + checksum_len then\n raise (Invalid_base58_check_length M.description) ;\n let checksum =\n String.sub decoded\n ~pos:(String.length decoded - checksum_len)\n ~len:checksum_len\n in\n let payload =\n String.sub decoded ~pos:1 ~len:(len - version_len - checksum_len)\n in\n if not (String.equal checksum (compute_checksum payload)) then\n raise (Invalid_base58_checksum M.description) ;\n if not (Char.equal decoded.[0] version_byte) then\n raise (Invalid_base58_version_byte (decoded.[0], M.description)) ;\n payload\n\n let decode s =\n let error_str e desc =\n sprintf \"Error decoding %s\\nInvalid base58 %s in %s\" s e desc\n in\n try Ok (decode_exn s) with\n | Invalid_base58_character str ->\n Or_error.error_string (error_str \"character\" str)\n | Invalid_base58_check_length str ->\n Or_error.error_string (error_str \"check length\" str)\n | Invalid_base58_checksum str ->\n Or_error.error_string (error_str \"checksum\" str)\n | Invalid_base58_version_byte (ch, str) ->\n Or_error.error_string\n (error_str\n (sprintf \"version byte \\\\x%02X, expected \\\\x%02X\" (Char.to_int ch)\n (Char.to_int version_byte) )\n str )\nend\n\nmodule Version_bytes = Version_bytes\n","open Core_kernel\n\nmodule type Iso_intf = sig\n type original\n\n type standardized [@@deriving yojson]\n\n val encode : original -> standardized\n\n val decode : standardized -> original\nend\n\nmodule type S = sig\n type t\n\n val to_yojson : t -> Yojson.Safe.t\n\n val of_yojson : Yojson.Safe.t -> t Ppx_deriving_yojson_runtime.error_or\nend\n\nmodule Make (Iso : Iso_intf) = struct\n let to_yojson t = Iso.encode t |> Iso.standardized_to_yojson\n\n let of_yojson json =\n Result.map ~f:Iso.decode (Iso.standardized_of_yojson json)\n\n module For_tests = struct\n let check_encoding t ~equal =\n match of_yojson (to_yojson t) with\n | Ok result ->\n equal t result\n | Error e ->\n failwithf !\"%s\" e ()\n end\nend\n\nmodule For_tests = struct\n let check_encoding (type t) (module M : S with type t = t) t ~equal =\n match M.of_yojson (M.to_yojson t) with\n | Ok result ->\n equal t result\n | Error e ->\n failwithf !\"%s\" e ()\nend\n\nmodule Make_of_int (Iso : sig\n type t\n\n val to_int : t -> int\n\n val of_int : int -> t\nend) =\nMake (struct\n type original = Iso.t\n\n type standardized = int [@@deriving yojson]\n\n let encode = Iso.to_int\n\n let decode = Iso.of_int\nend)\n\nmodule Make_of_string (Iso : sig\n type t\n\n val to_string : t -> string\n\n val of_string : string -> t\nend) =\nMake (struct\n type original = Iso.t\n\n type standardized = string [@@deriving yojson]\n\n let encode = Iso.to_string\n\n let decode = Iso.of_string\nend)\n\nmodule Make_base58_check (T : sig\n type t [@@deriving bin_io]\n\n val description : string\n\n val version_byte : char\nend) =\nstruct\n module Base58_check = Base58_check.Make (T)\n\n let to_base58_check t = Base58_check.encode (Binable.to_string (module T) t)\n\n let of_base58_check s =\n let open Or_error.Let_syntax in\n let%bind decoded = Base58_check.decode s in\n Or_error.try_with (fun () -> Binable.of_string (module T) decoded)\n\n let of_base58_check_exn s = of_base58_check s |> Or_error.ok_exn\n\n let to_yojson t = `String (to_base58_check t)\n\n let of_yojson = function\n | `String s ->\n Result.map_error (of_base58_check s) ~f:Error.to_string_hum\n | json ->\n failwithf \"of_yojson: expect JSON string, got %s\"\n (Yojson.Safe.to_string json)\n ()\nend\n\nmodule type Base58_check_base_intf = sig\n type t\n\n (** Base58Check decoding *)\n val of_base58_check : string -> t Base.Or_error.t\n\n (** Base58Check decoding *)\n val of_base58_check_exn : string -> t\nend\n\nmodule type Base58_check_intf = sig\n type t\n\n (** explicit Base58Check encoding *)\n val to_base58_check : t -> string\n\n include Base58_check_base_intf with type t := t\nend\n\nmodule Make_base64 (T : sig\n type t [@@deriving bin_io]\nend) =\nstruct\n let to_base64 (t : T.t) : string =\n Binable.to_string (module T) t\n |> (* raises only on errors from invalid optional arguments *)\n Base64.encode_exn\n\n let of_base64 b64 : T.t Or_error.t =\n match Base64.decode b64 with\n | Ok s -> (\n try Ok (Binable.of_string (module T) s)\n with Bin_prot.Common.Read_error _ as e ->\n Error (Error.of_exn ~backtrace:`Get e) )\n | Error (`Msg msg) ->\n Error (Error.of_string msg)\nend\n\nmodule type Base64_intf = sig\n type t\n\n val to_base64 : t -> string\n\n val of_base64 : string -> t Or_error.t\nend\n","open Snarky_backendless\nopen Webkit_trace_event\nopen Webkit_trace_event.Output.JSON\nopen Yojson\n\nlet to_string ?buf ?len ?std events =\n to_string ?buf ?len ?std @@ json_of_events events\n\nlet to_channel ?buf ?len ?std out_channel events =\n to_channel ?buf ?len ?std out_channel @@ json_of_events events\n\nlet to_file ?buf ?len ?std filename events =\n let oc = open_out filename in\n to_channel ?buf ?len ?std oc events ;\n close_out oc\n\nmodule Constraints (Snarky_backendless : Snark_intf.Basic) = struct\n (** Create flamechart events for Snarky_backendless constraints.\n\n This creates a chart of labels, associating each label with a 'timestamp'\n equal to the number of constraints at its start and end. *)\n open Snarky_backendless\n\n (** Generate a flamechart for the labels of a checked computation. *)\n let log ?weight (t : unit -> _ Checked.t) : events =\n let rev_events = ref [] in\n let _total =\n constraint_count ?weight t ~log:(fun ?(start = false) label count ->\n rev_events :=\n create_event label\n ~phase:(if start then Measure_start else Measure_end)\n ~timestamp:count\n :: !rev_events )\n in\n List.rev !rev_events\n\n (** Same as [log], but for functions which take [Var.t] arguments.\n Use [apply_args] to apply the corresponding OCaml-typed arguments.\n For example: {[\nopen Snarky_backendless\nmodule Snark = Snark.Make (Backends.Bn128.Default)\nopen Snark\nmodule Constraints = Snarky_log.Constraints (Snark)\n\nlet () = Snarky_log.to_file \"output.json\" @@\n Constraints.log_func ~input:Data_spec.[Field.typ; Field.typ] Field.Checked.mul\n ~apply_args:(fun mul -> mul Field.one Field.one)\n }] *)\n let log_func ~input_typ ~return_typ ~(apply_args : 'k_value -> _ Checked.t)\n (f : 'k_var) : events =\n let f' = conv (fun c -> c) input_typ return_typ f in\n log (fun () -> apply_args f')\nend\n","module B = Bigint\nmodule H_list = Snarky_backendless.H_list\nmodule Challenge = Limb_vector.Challenge\nmodule Types = Composition_types\nmodule Digest = Types.Digest\nmodule Spec = Types.Spec\nmodule Branch_data = Composition_types.Branch_data\nmodule Step_bp_vec = Types.Step_bp_vec\nmodule Nvector = Types.Nvector\nmodule Bulletproof_challenge = Types.Bulletproof_challenge\nmodule Domain = Pickles_base.Domain\nmodule Domains = Pickles_base.Domains\nmodule Scalar_challenge = Kimchi_backend_common.Scalar_challenge\n\nlet debug = false\n","open Core_kernel\nopen Pickles_types\n\nlet rec absorb :\n type a g1 g1_opt f scalar.\n absorb_field:(f -> unit)\n -> absorb_scalar:(scalar -> unit)\n -> g1_to_field_elements:(g1 -> f list)\n -> mask_g1_opt:(g1_opt -> g1)\n -> ( a\n , < scalar : scalar ; g1 : g1 ; g1_opt : g1_opt ; base_field : f > )\n Type.t\n -> a\n -> unit =\n fun ~absorb_field ~absorb_scalar ~g1_to_field_elements ~mask_g1_opt ty t ->\n match ty with\n | Type.PC ->\n List.iter ~f:absorb_field (g1_to_field_elements t)\n | Type.Field ->\n absorb_field t\n | Type.Scalar ->\n absorb_scalar t\n | Type.Without_degree_bound ->\n Array.iter\n ~f:(Fn.compose (List.iter ~f:absorb_field) g1_to_field_elements)\n t\n | Type.With_degree_bound ->\n let Pickles_types.Plonk_types.Poly_comm.With_degree_bound.\n { unshifted; shifted } =\n t\n in\n let absorb x =\n absorb ~absorb_field ~absorb_scalar ~g1_to_field_elements ~mask_g1_opt\n Type.PC (mask_g1_opt x)\n in\n Array.iter unshifted ~f:absorb ;\n absorb shifted\n | ty1 :: ty2 ->\n let absorb t =\n absorb t ~absorb_field ~absorb_scalar ~g1_to_field_elements ~mask_g1_opt\n in\n let t1, t2 = t in\n absorb ty1 t1 ; absorb ty2 t2\n\n(** [ones_vector (module I) ~first_zero n] returns a vector of booleans of\n length n which is all ones until position [first_zero], at which it is zero,\n and zero thereafter. *)\nlet ones_vector :\n type f n.\n first_zero:f Snarky_backendless.Cvar.t\n -> (module Snarky_backendless.Snark_intf.Run with type field = f)\n -> n Nat.t\n -> (f Snarky_backendless.Cvar.t Snarky_backendless.Boolean.t, n) Vector.t =\n fun ~first_zero (module Impl) n ->\n let open Impl in\n let rec go :\n type m. Boolean.var -> int -> m Nat.t -> (Boolean.var, m) Vector.t =\n fun value i m ->\n match[@warning \"-45\"] m with\n | Pickles_types.Nat.Z ->\n Pickles_types.Vector.[]\n | Pickles_types.Nat.S m ->\n let value =\n Boolean.(value && not (Field.equal first_zero (Field.of_int i)))\n in\n Pickles_types.Vector.(value :: go value (i + 1) m)\n in\n go Boolean.true_ 0 n\n\nlet seal (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n (x : Impl.Field.t) : Impl.Field.t =\n let open Impl in\n match Field.to_constant_and_terms x with\n | None, [ (x, i) ] when Field.Constant.(equal x one) ->\n Snarky_backendless.Cvar.Var i\n | Some c, [] ->\n Field.constant c\n | _ ->\n let y = exists Field.typ ~compute:As_prover.(fun () -> read_var x) in\n Field.Assert.equal x y ; y\n\nlet lowest_128_bits (type f) ~constrain_low_bits ~assert_128_bits\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) x =\n let open Impl in\n let pow2 =\n (* 2 ^ n *)\n let rec pow2 x i =\n if i = 0 then x else pow2 Field.Constant.(x + x) (i - 1)\n in\n fun n -> pow2 Field.Constant.one n\n in\n let lo, hi =\n exists\n Typ.(field * field)\n ~compute:(fun () ->\n let lo, hi =\n Field.Constant.unpack (As_prover.read_var x)\n |> Fn.flip List.split_n 128\n in\n (Field.Constant.project lo, Field.Constant.project hi) )\n in\n assert_128_bits hi ;\n if constrain_low_bits then assert_128_bits lo ;\n Field.Assert.equal x Field.(lo + scale hi (pow2 128)) ;\n lo\n","module SC = Scalar_challenge\n\ntype t = Import.Challenge.Constant.t Import.Scalar_challenge.t\n\nmodule Wrap_inner_curve = struct\n let base : Backend.Tock.Field.t = Pasta_bindings.Vesta.endo_base ()\n\n let scalar : Backend.Tick.Field.t = Pasta_bindings.Vesta.endo_scalar ()\n\n let to_field (t : t) : Backend.Tick.Field.t =\n SC.to_field_constant (module Backend.Tick.Field) ~endo:scalar t\nend\n\nmodule Step_inner_curve = struct\n let base : Backend.Tick.Field.t = Pasta_bindings.Pallas.endo_base ()\n\n let scalar : Backend.Tock.Field.t = Pasta_bindings.Pallas.endo_scalar ()\n\n let to_field (t : t) : Backend.Tock.Field.t =\n SC.to_field_constant (module Backend.Tock.Field) ~endo:scalar t\nend\n","open Core_kernel\nopen Pickles_types\nopen Import\nopen Backend\n\nmodule Max_degree = struct\n let step_log2 = Nat.to_int Backend.Tick.Rounds.n\n\n let step = 1 lsl step_log2\n\n let wrap_log2 = Nat.to_int Backend.Tock.Rounds.n\n\n let _wrap = 1 lsl wrap_log2\nend\n\nlet tick_shifts, tock_shifts =\n let mk g =\n let f =\n Memo.general ~cache_size_bound:20 ~hashable:Int.hashable (fun log2_size ->\n g log2_size )\n in\n fun ~log2_size -> f log2_size\n in\n ( mk Kimchi_bindings.Protocol.VerifierIndex.Fp.shifts\n , mk Kimchi_bindings.Protocol.VerifierIndex.Fq.shifts )\n\nlet wrap_domains ~proofs_verified =\n let h =\n match proofs_verified with 0 -> 13 | 1 -> 14 | 2 -> 15 | _ -> assert false\n in\n { Domains.h = Domain.Pow_2_roots_of_unity h }\n\nlet actual_wrap_domain_size ~log_2_domain_size =\n let d =\n match log_2_domain_size with\n | 13 ->\n 0\n | 14 ->\n 1\n | 15 ->\n 2\n | _ ->\n assert false\n in\n Pickles_base.Proofs_verified.of_int d\n\nlet hash_messages_for_next_step_proof ~app_state\n (t : _ Types.Step.Proof_state.Messages_for_next_step_proof.t) =\n let g (x, y) = [ x; y ] in\n Tick_field_sponge.digest Tick_field_sponge.params\n (Types.Step.Proof_state.Messages_for_next_step_proof.to_field_elements t ~g\n ~comm:(fun (x : Tock.Curve.Affine.t) -> Array.of_list (g x))\n ~app_state )\n\nlet dlog_pcs_batch (type nat proofs_verified total)\n ((without_degree_bound, _pi) :\n total Nat.t * (proofs_verified, nat, total) Nat.Adds.t ) =\n Pcs_batch.create ~without_degree_bound ~with_degree_bound:[]\n\nlet when_profiling profiling default =\n match Option.map (Sys.getenv_opt \"PICKLES_PROFILING\") ~f:String.lowercase with\n | None | Some (\"0\" | \"false\") ->\n default\n | Some _ ->\n profiling\n\nlet time lab f =\n when_profiling\n (fun () ->\n let start = Time.now () in\n let x = f () in\n let stop = Time.now () in\n printf \"%s: %s\\n%!\" lab (Time.Span.to_string_hum (Time.diff stop start)) ;\n x )\n f ()\n\nlet bits_to_bytes bits =\n let byte_of_bits bs =\n List.foldi bs ~init:0 ~f:(fun i acc b ->\n if b then acc lor (1 lsl i) else acc )\n |> Char.of_int_exn\n in\n List.map (List.groupi bits ~break:(fun i _ _ -> i mod 8 = 0)) ~f:byte_of_bits\n |> String.of_char_list\n\nlet group_map m ~a ~b =\n let params = Group_map.Params.create m { a; b } in\n stage (fun x -> Group_map.to_group m ~params x)\n\nmodule Shifts = struct\n let tock2 : Backend.Tock.Field.t Shifted_value.Type2.Shift.t =\n Shifted_value.Type2.Shift.create (module Backend.Tock.Field)\n\n let tick1 : Backend.Tick.Field.t Shifted_value.Type1.Shift.t =\n Shifted_value.Type1.Shift.create (module Backend.Tick.Field)\nend\n\nmodule Lookup_parameters = struct\n let tick_zero : _ Composition_types.Zero_values.t =\n Composition_types.Zero_values.\n { value =\n { challenge = Challenge.Constant.zero\n ; scalar =\n Shifted_value.Type2.Shifted_value Impls.Wrap.Field.Constant.zero\n }\n ; var =\n { challenge = Impls.Step.Field.zero\n ; scalar =\n Shifted_value.Type2.Shifted_value\n (Impls.Step.Field.zero, Impls.Step.Boolean.false_)\n }\n }\n\n let tock_zero : _ Composition_types.Zero_values.t =\n Composition_types.Zero_values.\n { value =\n { challenge = Challenge.Constant.zero\n ; scalar =\n Shifted_value.Type2.Shifted_value Impls.Wrap.Field.Constant.zero\n }\n ; var =\n { challenge = Impls.Wrap.Field.zero\n ; scalar = Shifted_value.Type2.Shifted_value Impls.Wrap.Field.zero\n }\n }\nend\n\nlet finite_exn : 'a Kimchi_types.or_infinity -> 'a * 'a = function\n | Kimchi_types.Finite (x, y) ->\n (x, y)\n | Kimchi_types.Infinity ->\n invalid_arg \"finite_exn\"\n\nlet or_infinite_conv : ('a * 'a) Or_infinity.t -> 'a Kimchi_types.or_infinity =\n function\n | Finite (x, y) ->\n Finite (x, y)\n | Infinity ->\n Infinity\n\nmodule Ipa = struct\n open Backend\n\n (* TODO: Make all this completely generic over backend *)\n\n let compute_challenge ~endo_to_field _ c = endo_to_field c\n\n let compute_challenges ~endo_to_field field chals =\n Vector.map chals ~f:(fun prechallenge ->\n Bulletproof_challenge.pack prechallenge\n |> compute_challenge field ~endo_to_field )\n\n module Wrap = struct\n let field =\n (module Tock.Field : Kimchi_backend.Field.S with type t = Tock.Field.t)\n\n let endo_to_field = Endo.Step_inner_curve.to_field\n\n let compute_challenge c = compute_challenge field ~endo_to_field c\n\n let compute_challenges cs = compute_challenges field ~endo_to_field cs\n\n let compute_sg chals =\n let comm =\n Kimchi_bindings.Protocol.SRS.Fq.b_poly_commitment\n (Backend.Tock.Keypair.load_urs ())\n (Pickles_types.Vector.to_array (compute_challenges chals))\n in\n comm.unshifted.(0) |> finite_exn\n end\n\n module Step = struct\n let field =\n (module Tick.Field : Kimchi_backend.Field.S with type t = Tick.Field.t)\n\n let endo_to_field = Endo.Wrap_inner_curve.to_field\n\n let compute_challenge c = compute_challenge field ~endo_to_field c\n\n let compute_challenges cs = compute_challenges field ~endo_to_field cs\n\n let compute_sg chals =\n let comm =\n Kimchi_bindings.Protocol.SRS.Fp.b_poly_commitment\n (Backend.Tick.Keypair.load_urs ())\n (Pickles_types.Vector.to_array (compute_challenges chals))\n in\n comm.unshifted.(0) |> finite_exn\n\n let accumulator_check comm_chals =\n let chals =\n Array.concat\n @@ List.map comm_chals ~f:(fun (_, chals) -> Vector.to_array chals)\n in\n let comms =\n Array.of_list_map comm_chals ~f:(fun (comm, _) ->\n Or_infinity.Finite comm )\n in\n let urs = Backend.Tick.Keypair.load_urs () in\n Promise.run_in_thread (fun () ->\n Kimchi_bindings.Protocol.SRS.Fp.batch_accumulator_check urs\n (Array.map comms ~f:or_infinite_conv)\n chals )\n end\nend\n\nlet tock_unpadded_public_input_of_statement ~feature_flags prev_statement =\n let input =\n let (T (typ, _conv, _conv_inv)) = Impls.Wrap.input ~feature_flags () in\n Impls.Wrap.generate_public_input typ prev_statement\n in\n List.init\n (Backend.Tock.Field.Vector.length input)\n ~f:(Backend.Tock.Field.Vector.get input)\n\nlet tock_public_input_of_statement ~feature_flags s =\n tock_unpadded_public_input_of_statement ~feature_flags s\n\nlet tick_public_input_of_statement ~max_proofs_verified\n (prev_statement : _ Types.Step.Statement.t) =\n let input =\n let (T (input, _conv, _conv_inv)) =\n Impls.Step.input ~proofs_verified:max_proofs_verified\n ~wrap_rounds:Tock.Rounds.n\n in\n Impls.Step.generate_public_input input prev_statement\n in\n List.init\n (Backend.Tick.Field.Vector.length input)\n ~f:(Backend.Tick.Field.Vector.get input)\n\nlet ft_comm ~add:( + ) ~scale ~endoscale:_ ~negate\n ~verification_key:(m : _ Plonk_verification_key_evals.t) ~alpha:_\n ~(plonk : _ Types.Wrap.Proof_state.Deferred_values.Plonk.In_circuit.t)\n ~t_comm =\n let ( * ) x g = scale g x in\n let _, [ sigma_comm_last ] =\n Vector.split m.sigma_comm (snd (Plonk_types.Permuts_minus_1.add Nat.N1.n))\n in\n let f_comm = List.reduce_exn ~f:( + ) [ plonk.perm * sigma_comm_last ] in\n let chunked_t_comm =\n let n = Array.length t_comm in\n let res = ref t_comm.(n - 1) in\n for i = n - 2 downto 0 do\n res := t_comm.(i) + scale !res plonk.zeta_to_srs_length\n done ;\n !res\n in\n f_comm + chunked_t_comm\n + negate (scale chunked_t_comm plonk.zeta_to_domain_size)\n\nlet combined_evaluation (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ~(xi : Impl.Field.t) (without_degree_bound : _ list) =\n let open Impl in\n let open Field in\n let mul_and_add ~(acc : Field.t) ~(xi : Field.t)\n (fx : (Field.t, Boolean.var) Opt.t) : Field.t =\n match fx with\n | Nothing ->\n acc\n | Just fx ->\n fx + (xi * acc)\n | Maybe (b, fx) ->\n Field.if_ b ~then_:(fx + (xi * acc)) ~else_:acc\n in\n with_label __LOC__ (fun () ->\n Pcs_batch.combine_split_evaluations ~mul_and_add\n ~init:(function\n | Just x ->\n x\n | Nothing ->\n Field.zero\n | Maybe (b, x) ->\n (b :> Field.t) * x )\n ~xi without_degree_bound )\n","module D = Composition_types.Digest\nopen Core_kernel\n\nmodule Rounds = struct\n let rounds_full = 55\n\n let initial_ark = false\n\n let rounds_partial = 0\nend\n\nlet high_entropy_bits = 128\n\nmodule type S = sig\n module Inputs : sig\n include module type of Rounds\n\n module Field : Kimchi_backend_common.Field.S\n\n type field := Field.t\n\n val to_the_alpha : field -> field\n\n val alpha : int\n\n module Operations : Sponge.Intf.Operations with type Field.t = field\n end\n\n type field := Inputs.Field.t\n\n (* The name does not really reflect the behavior *and* is somewhat confusing w.r.t\n Inputs.Field. This is almost Sponge.Intf.Sponge *)\n module Field : sig\n type f := Sponge.Poseidon(Inputs).Field.t\n\n type params := f Sponge.Params.t\n\n type state := f Sponge.State.t\n\n type t = f Sponge.t (* TODO: Make this type abstract *)\n\n val create : ?init:state -> params -> t\n\n val make :\n state:state -> params:params -> sponge_state:Sponge.sponge_state -> t\n\n val absorb : t -> f -> unit\n\n val squeeze : t -> f\n\n val copy : t -> t\n\n val state : t -> state\n end\n\n (* TODO: Resuce module types of Sponge.Intf.Sponge *)\n module Bits : sig\n type t\n\n val create : ?init:field Sponge.State.t -> field Sponge.Params.t -> t\n\n val absorb : t -> field -> unit\n\n val squeeze : t -> length:int -> bool list\n\n val copy : t -> t\n\n val state : t -> field Sponge.State.t\n\n val squeeze_field : t -> field\n end\n\n val digest :\n field Sponge.Params.t\n -> Inputs.Field.t Core_kernel.Array.t\n -> (int64, Composition_types.Digest.Limbs.n) Pickles_types.Vector.t\nend\n\nmodule Make (Field : Kimchi_backend.Field.S) :\n S with module Inputs.Field = Field = struct\n module Inputs = struct\n include Rounds\n module Field = Field\n\n let alpha = 7\n\n (* x^7 *)\n let to_the_alpha x =\n (* square |> mul x |> square |> mul x *)\n (* 7 = 1 + 2 (1 + 2) *)\n let open Field in\n let res = square x in\n res *= x ;\n (* x^3 *)\n Mutable.square res ;\n (* x^6 *)\n res *= x ;\n (* x^7 *)\n res\n\n module Operations = struct\n module Field = Field\n\n let add_assign ~state i x = Field.(state.(i) += x)\n\n let apply_affine_map (matrix, constants) v =\n let dotv row =\n Array.reduce_exn (Array.map2_exn row v ~f:Field.( * )) ~f:Field.( + )\n in\n let res = Array.map matrix ~f:dotv in\n for i = 0 to Array.length res - 1 do\n Field.(res.(i) += constants.(i))\n done ;\n res\n\n let copy a = Array.map a ~f:(fun x -> Field.(x + zero))\n end\n end\n\n module Field = Sponge.Make_sponge (Sponge.Poseidon (Inputs))\n\n module Bits =\n Sponge.Bit_sponge.Make\n (Bool)\n (struct\n include Inputs.Field\n\n let high_entropy_bits = high_entropy_bits\n\n let finalize_discarded = ignore\n end)\n (Inputs.Field)\n (Field)\n\n let digest params elts =\n let sponge = Bits.create params in\n Array.iter elts ~f:(Bits.absorb sponge) ;\n Bits.squeeze_field sponge |> Inputs.Field.to_bits |> D.Constant.of_bits\nend\n\nmodule Test\n (Impl : Snarky_backendless.Snark_intf.Run)\n (S_constant : Sponge.Intf.Sponge\n with module Field := Impl.Field.Constant\n and module State := Sponge.State\n and type input := Impl.field\n and type digest := Impl.field)\n (S_checked : Sponge.Intf.Sponge\n with module Field := Impl.Field\n and module State := Sponge.State\n and type input := Impl.Field.t\n and type digest := Impl.Field.t) =\nstruct\n open Impl\n\n let test params : unit =\n let n = 10 in\n let a = Array.init n ~f:(fun _ -> Field.Constant.random ()) in\n Impl.Internal_Basic.Test.test_equal ~sexp_of_t:Field.Constant.sexp_of_t\n ~equal:Field.Constant.equal\n (Typ.array ~length:n Field.typ)\n Field.typ\n (fun a ->\n make_checked (fun () ->\n let s =\n S_checked.create (Sponge.Params.map ~f:Field.constant params)\n in\n Array.iter a ~f:(S_checked.absorb s) ;\n S_checked.squeeze s ) )\n (fun a ->\n let s = S_constant.create params in\n Array.iter a ~f:(S_constant.absorb s) ;\n S_constant.squeeze s )\n a\nend\n","include Make_sponge.Make (Backend.Tick.Field)\n\nlet params = Kimchi_pasta_basic.poseidon_params_fp\n","open Core_kernel\nopen Pickles_types\nopen Backend\nopen Composition_types\nopen Common\n\nlet _wrap_domains = Common.wrap_domains\n\nlet evals =\n lazy\n (let open Plonk_types in\n let e =\n Evals.map Evaluation_lengths.default ~f:(fun n ->\n let a () = Array.create ~len:n (Ro.tock ()) in\n (a (), a ()) )\n in\n let ex =\n { All_evals.With_public_input.evals = e\n ; public_input = (Ro.tock (), Ro.tock ())\n }\n in\n { All_evals.ft_eval1 = Ro.tock (); evals = ex })\n\nlet evals_combined =\n lazy\n (Plonk_types.All_evals.map (Lazy.force evals) ~f1:Fn.id\n ~f2:(Array.reduce_exn ~f:Backend.Tock.Field.( + )) )\n\nmodule Ipa = struct\n module Wrap = struct\n let challenges =\n Vector.init Tock.Rounds.n ~f:(fun _ ->\n let prechallenge = Ro.scalar_chal () in\n { Bulletproof_challenge.prechallenge } )\n\n let challenges_computed =\n lazy\n (Vector.map challenges ~f:(fun { prechallenge } : Tock.Field.t ->\n Ipa.Wrap.compute_challenge prechallenge ) )\n\n let sg =\n lazy (time \"dummy wrap sg\" (fun () -> Ipa.Wrap.compute_sg challenges))\n end\n\n module Step = struct\n let challenges =\n Vector.init Tick.Rounds.n ~f:(fun _ ->\n let prechallenge = Ro.scalar_chal () in\n { Bulletproof_challenge.prechallenge } )\n\n let challenges_computed =\n lazy\n (Vector.map challenges ~f:(fun { prechallenge } : Tick.Field.t ->\n Ipa.Step.compute_challenge prechallenge ) )\n\n let sg =\n lazy (time \"dummy wrap sg\" (fun () -> Ipa.Step.compute_sg challenges))\n end\nend\n","open Core_kernel\nopen Pickles_types\nopen Hlist\nopen Common\nopen Import\nopen Types\nopen Wrap_main_inputs\nopen Impl\nmodule SC = Scalar_challenge\n\n(* Let's define an OCaml encoding for inductive NP sets. Let A be an inductive NP set.\n\n To encode A, we require types [var(A)] and [value(A)] corresponding to\n \\mathcal{U}(A) the underlying set of A.\n\n Let r_1, ..., r_n be the inductive rules of A.\n For each i, let (A_{i, 1}, ..., A_{i, k_i}) be the predecessor inductive sets for rule i.\n\n We define a few type level lists.\n\n - For each rule r_i,\n [prev_vars(r_i) := var(A_{i, 1}) * (var(A_{i, 2}) * (... * var(A_{i, k_i})))]\n [prev_values(r_i) := value(A_{i, 1}) * (value(A_{i, 2}) * (... * value(A_{i, k_i})))]\n\n - [prev_varss(A) := map prev_vars (r_1, ..., r_n)]\n - [prev_valuess(A) := map prev_values (r_1, ..., r_n)]\n\n We use corresponding type variable names throughout this file.\n*)\n\nmodule Old_bulletproof_chals = struct\n type t =\n | T :\n 'max_local_max_proofs_verified Nat.t\n * 'max_local_max_proofs_verified Challenges_vector.t\n -> t\nend\n\nlet pack_statement max_proofs_verified t =\n let open Types.Step in\n Spec.pack\n (module Impl)\n (Statement.spec max_proofs_verified Backend.Tock.Rounds.n)\n (Statement.to_data t)\n\nlet shifts ~log2_size = Common.tock_shifts ~log2_size\n\nlet domain_generator ~log2_size =\n Backend.Tock.Field.domain_generator ~log2_size |> Impl.Field.constant\n\nlet _split_field_typ : (Field.t * Boolean.var, Field.Constant.t) Typ.t =\n Typ.transport\n Typ.(field * Boolean.typ)\n ~there:(fun (x : Field.Constant.t) ->\n let n = Bigint.of_field x in\n let is_odd = Bigint.test_bit n 0 in\n let y = Field.Constant.((if is_odd then x - one else x) / of_int 2) in\n (y, is_odd) )\n ~back:(fun (hi, is_odd) ->\n let open Field.Constant in\n let x = hi + hi in\n if is_odd then x + one else x )\n\n(* Split a field element into its high bits (packed) and the low bit.\n\n It does not check that the \"high bits\" actually fit into n - 1 bits,\n this is deferred to a call to scale_fast2, which performs this check.\n*)\nlet split_field (x : Field.t) : Field.t * Boolean.var =\n let ((y, is_odd) as res) =\n exists\n Typ.(field * Boolean.typ)\n ~compute:(fun () ->\n let x = As_prover.read_var x in\n let n = Bigint.of_field x in\n let is_odd = Bigint.test_bit n 0 in\n let y = Field.Constant.((if is_odd then x - one else x) / of_int 2) in\n (y, is_odd) )\n in\n Field.(Assert.equal ((of_int 2 * y) + (is_odd :> t)) x) ;\n res\n\n(* The SNARK function for wrapping any proof coming from the given set of keys *)\nlet wrap_main\n (type max_proofs_verified branches prev_varss max_local_max_proofs_verifieds)\n ~feature_flags\n (full_signature :\n ( max_proofs_verified\n , branches\n , max_local_max_proofs_verifieds )\n Full_signature.t ) (pi_branches : (prev_varss, branches) Hlist.Length.t)\n (step_keys :\n ( ( Wrap_main_inputs.Inner_curve.Constant.t\n , Wrap_main_inputs.Inner_curve.Constant.t option )\n Wrap_verifier.index'\n , branches )\n Vector.t\n Lazy.t ) (step_widths : (int, branches) Vector.t)\n (step_domains : (Domains.t, branches) Vector.t) ~srs\n (max_proofs_verified :\n (module Nat.Add.Intf with type n = max_proofs_verified) ) :\n (max_proofs_verified, max_local_max_proofs_verifieds) Requests.Wrap.t\n * ( ( _\n , _\n , _ Shifted_value.Type1.t\n , _\n , _\n , _\n , _\n , _\n , _\n , _\n , _ )\n Types.Wrap.Statement.In_circuit.t\n -> unit ) =\n Timer.clock __LOC__ ;\n let module Max_proofs_verified = ( val max_proofs_verified : Nat.Add.Intf\n with type n = max_proofs_verified )\n in\n let T = Max_proofs_verified.eq in\n let branches = Hlist.Length.to_nat pi_branches in\n Timer.clock __LOC__ ;\n let (module Req) =\n Requests.Wrap.(\n (create () : (max_proofs_verified, max_local_max_proofs_verifieds) t))\n in\n Timer.clock __LOC__ ;\n let { Full_signature.padded = _; maxes = (module Max_widths_by_slot) } =\n full_signature\n in\n Timer.clock __LOC__ ;\n let main\n ({ proof_state =\n { deferred_values =\n { plonk\n ; xi\n ; combined_inner_product\n ; b\n ; branch_data\n ; bulletproof_challenges\n }\n ; sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof = messages_for_next_wrap_proof_digest\n }\n ; messages_for_next_step_proof = _\n } :\n ( _\n , _\n , _ Shifted_value.Type1.t\n , _\n , _\n , _\n , _\n , _\n , _\n , _\n , Field.t )\n Types.Wrap.Statement.In_circuit.t ) =\n let logger = Internal_tracing_context_logger.get () in\n with_label __LOC__ (fun () ->\n let which_branch' =\n exists\n (Typ.transport Field.typ ~there:Field.Constant.of_int\n ~back:(fun _ -> failwith \"unimplemented\") )\n ~request:(fun () -> Req.Which_branch)\n in\n let which_branch =\n Wrap_verifier.One_hot_vector.of_index which_branch' ~length:branches\n in\n let actual_proofs_verified_mask =\n Util.ones_vector\n (module Impl)\n ~first_zero:\n (Wrap_verifier.Pseudo.choose\n (which_branch, step_widths)\n ~f:Field.of_int )\n Max_proofs_verified.n\n |> Vector.rev\n in\n let domain_log2 =\n Wrap_verifier.Pseudo.choose\n ( which_branch\n , Vector.map ~f:(fun ds -> Domain.log2_size ds.h) step_domains )\n ~f:Field.of_int\n in\n let () =\n with_label __LOC__ (fun () ->\n (* Check that the branch_data public-input is correct *)\n Branch_data.Checked.pack\n (module Impl)\n { proofs_verified_mask =\n Vector.extend_front_exn actual_proofs_verified_mask Nat.N2.n\n Boolean.false_\n ; domain_log2\n }\n |> Field.Assert.equal branch_data )\n in\n let prev_proof_state =\n with_label __LOC__ (fun () ->\n let open Types.Step.Proof_state in\n let typ =\n typ\n (module Impl)\n ~assert_16_bits:(Wrap_verifier.assert_n_bits ~n:16)\n (Vector.init Max_proofs_verified.n ~f:(fun _ ->\n Plonk_types.Features.none ) )\n (Shifted_value.Type2.typ Field.typ)\n in\n exists typ ~request:(fun () -> Req.Proof_state) )\n in\n let step_plonk_index =\n with_label __LOC__ (fun () ->\n Wrap_verifier.choose_key which_branch\n (Vector.map (Lazy.force step_keys)\n ~f:\n (Plonk_verification_key_evals.Step.map\n ~f:Inner_curve.constant ~f_opt:(function\n | None ->\n Opt.nothing\n | Some x ->\n Opt.just (Inner_curve.constant x) ) ) ) )\n in\n let prev_step_accs =\n with_label __LOC__ (fun () ->\n exists (Vector.typ Inner_curve.typ Max_proofs_verified.n)\n ~request:(fun () -> Req.Step_accs) )\n in\n let old_bp_chals =\n with_label __LOC__ (fun () ->\n let typ =\n let module T =\n H1.Typ (Impls.Wrap) (Nat) (Challenges_vector)\n (Challenges_vector.Constant)\n (struct\n let f (type n) (n : n Nat.t) =\n Vector.typ\n (Vector.typ Field.typ Backend.Tock.Rounds.n)\n n\n end)\n in\n T.f Max_widths_by_slot.maxes\n in\n let module Z = H1.Zip (Nat) (Challenges_vector) in\n let module M =\n H1.Map\n (H1.Tuple2 (Nat) (Challenges_vector))\n (E01 (Old_bulletproof_chals))\n (struct\n let f (type n)\n ((n, v) : n H1.Tuple2(Nat)(Challenges_vector).t) =\n Old_bulletproof_chals.T (n, v)\n end)\n in\n let module V = H1.To_vector (Old_bulletproof_chals) in\n Z.f Max_widths_by_slot.maxes\n (exists typ ~request:(fun () -> Req.Old_bulletproof_challenges))\n |> M.f\n |> V.f Max_widths_by_slot.length )\n in\n let new_bulletproof_challenges =\n with_label __LOC__ (fun () ->\n let evals =\n let ty =\n let ty =\n Plonk_types.All_evals.typ (module Impl) feature_flags\n in\n Vector.typ ty Max_proofs_verified.n\n in\n exists ty ~request:(fun () -> Req.Evals)\n in\n let chals =\n let wrap_domains =\n let all_possible_domains =\n Wrap_verifier.all_possible_domains ()\n in\n let wrap_domain_indices =\n exists (Vector.typ Field.typ Max_proofs_verified.n)\n ~request:(fun () -> Req.Wrap_domain_indices)\n in\n Vector.map wrap_domain_indices ~f:(fun index ->\n let which_branch =\n Wrap_verifier.One_hot_vector.of_index index\n ~length:Wrap_verifier.num_possible_domains\n in\n Wrap_verifier.Pseudo.Domain.to_domain ~shifts\n ~domain_generator\n (which_branch, all_possible_domains) )\n in\n Vector.mapn\n [ (* This is padded to max_proofs_verified for the benefit of wrapping with dummy unfinalized proofs *)\n prev_proof_state.unfinalized_proofs\n ; old_bp_chals\n ; evals\n ; wrap_domains\n ]\n ~f:(fun\n [ { deferred_values\n ; sponge_digest_before_evaluations\n ; should_finalize\n }\n ; old_bulletproof_challenges\n ; evals\n ; wrap_domain\n ]\n ->\n let sponge =\n let s = Sponge.create sponge_params in\n Sponge.absorb s sponge_digest_before_evaluations ;\n s\n in\n\n (* the type of the local max proofs-verified depends on\n which kind of step proof we are wrapping. *)\n (* For each i in [0..max_proofs_verified-1], we have\n max_local_max_proofs_verified, which is the largest\n Local_max_proofs_verified which is the i^th inner proof of a step proof.\n\n Need to compute this value from the which_branch.\n *)\n let (T\n ( _max_local_max_proofs_verified\n , old_bulletproof_challenges ) ) =\n old_bulletproof_challenges\n in\n let old_bulletproof_challenges =\n Wrap_hack.Checked.pad_challenges\n old_bulletproof_challenges\n in\n let finalized, chals =\n with_label __LOC__ (fun () ->\n Wrap_verifier.finalize_other_proof\n (module Wrap_hack.Padded_length)\n ~domain:(wrap_domain :> _ Plonk_checks.plonk_domain)\n ~sponge ~old_bulletproof_challenges deferred_values\n evals )\n in\n Boolean.(Assert.any [ finalized; not should_finalize ]) ;\n chals )\n in\n chals )\n in\n let prev_statement =\n let prev_messages_for_next_wrap_proof =\n Vector.map2 prev_step_accs old_bp_chals\n ~f:(fun sacc (T (max_local_max_proofs_verified, chals)) ->\n Wrap_hack.Checked.hash_messages_for_next_wrap_proof\n max_local_max_proofs_verified\n { challenge_polynomial_commitment = sacc\n ; old_bulletproof_challenges = chals\n } )\n in\n { Types.Step.Statement.messages_for_next_wrap_proof =\n prev_messages_for_next_wrap_proof\n ; proof_state = prev_proof_state\n }\n in\n let openings_proof =\n let shift = Shifts.tick1 in\n exists\n (Plonk_types.Openings.Bulletproof.typ\n ( Typ.transport Wrap_verifier.Other_field.Packed.typ\n ~there:(fun x ->\n (* When storing, make it a shifted value *)\n match\n Shifted_value.Type1.of_field\n (module Backend.Tick.Field)\n ~shift x\n with\n | Shifted_value x ->\n x )\n ~back:(fun x ->\n Shifted_value.Type1.to_field\n (module Backend.Tick.Field)\n ~shift (Shifted_value x) )\n (* When reading, unshift *)\n |> Typ.transport_var\n (* For the var, we just wrap the now shifted underlying value. *)\n ~there:(fun (Shifted_value.Type1.Shifted_value x) -> x)\n ~back:(fun x -> Shifted_value x) )\n Inner_curve.typ\n ~length:(Nat.to_int Backend.Tick.Rounds.n) )\n ~request:(fun () -> Req.Openings_proof)\n in\n let ( sponge_digest_before_evaluations_actual\n , (`Success bulletproof_success, bulletproof_challenges_actual) ) =\n let messages =\n with_label __LOC__ (fun () ->\n exists\n (Plonk_types.Messages.typ\n (module Impl)\n Inner_curve.typ ~bool:Boolean.typ feature_flags\n ~dummy:Inner_curve.Params.one\n ~commitment_lengths:Commitment_lengths.default )\n ~request:(fun () -> Req.Messages) )\n in\n let sponge = Wrap_verifier.Opt.create sponge_params in\n with_label __LOC__ (fun () ->\n [%log internal] \"Wrap_verifier_incrementally_verify_proof\" ;\n let res =\n Wrap_verifier.incrementally_verify_proof max_proofs_verified\n ~actual_proofs_verified_mask ~step_domains\n ~verification_key:step_plonk_index ~srs ~xi ~sponge\n ~public_input:\n (Array.map\n (pack_statement Max_proofs_verified.n prev_statement)\n ~f:(function\n | `Field (Shifted_value x) ->\n `Field (split_field x)\n | `Packed_bits (x, n) ->\n `Packed_bits (x, n) ) )\n ~sg_old:prev_step_accs\n ~advice:{ b; combined_inner_product }\n ~messages ~which_branch ~openings_proof ~plonk\n in\n [%log internal] \"Wrap_verifier_incrementally_verify_proof_done\" ;\n res )\n in\n with_label __LOC__ (fun () ->\n Boolean.Assert.is_true bulletproof_success ) ;\n with_label __LOC__ (fun () ->\n Field.Assert.equal messages_for_next_wrap_proof_digest\n (Wrap_hack.Checked.hash_messages_for_next_wrap_proof\n Max_proofs_verified.n\n { Types.Wrap.Proof_state.Messages_for_next_wrap_proof\n .challenge_polynomial_commitment =\n openings_proof.challenge_polynomial_commitment\n ; old_bulletproof_challenges = new_bulletproof_challenges\n } ) ) ;\n with_label __LOC__ (fun () ->\n Field.Assert.equal sponge_digest_before_evaluations\n sponge_digest_before_evaluations_actual ) ;\n Array.iter2_exn bulletproof_challenges_actual\n (Vector.to_array bulletproof_challenges)\n ~f:(fun\n { prechallenge = { inner = x1 } }\n ({ prechallenge = { inner = x2 } } :\n _ SC.t Bulletproof_challenge.t )\n -> with_label __LOC__ (fun () -> Field.Assert.equal x1 x2) ) ;\n () )\n in\n Timer.clock __LOC__ ;\n ((module Req), main)\n","open Pickles_types\n\nlet default =\n let one = 1 in\n { Plonk_types.Messages.Poly.w =\n Vector.init Plonk_types.Columns.n ~f:(fun _ -> one)\n ; z = one\n ; t = 7\n }\n","let default =\n let one = 1 in\n let open Pickles_types in\n let open Plonk_types in\n Evals.\n { w = Vector.init Columns.n ~f:(fun _ -> one)\n ; coefficients = Vector.init Columns.n ~f:(fun _ -> one)\n ; z = one\n ; s = Vector.init Permuts_minus_1.n ~f:(fun _ -> one)\n ; generic_selector = one\n ; poseidon_selector = one\n ; complete_add_selector = one\n ; mul_selector = one\n ; emul_selector = one\n ; endomul_scalar_selector = one\n ; (* FIXME *)\n range_check0_selector = None\n ; range_check1_selector = None\n ; foreign_field_add_selector = None\n ; foreign_field_mul_selector = None\n ; xor_selector = None\n ; rot_selector = None\n ; lookup_aggregation = None\n ; lookup_table = None\n ; lookup_sorted = Vector.init Nat.N5.n ~f:(fun _ -> None)\n ; runtime_lookup_table = None\n ; runtime_lookup_table_selector = None\n ; xor_lookup_selector = None\n ; lookup_gate_lookup_selector = None\n ; range_check_lookup_selector = None\n ; foreign_field_mul_lookup_selector = None\n }\n","open Core_kernel\nopen Backend\nopen Import\n\nlet bits_random_oracle =\n let h = Digestif.blake2s 32 in\n fun ~length s ->\n Digestif.digest_string h s |> Digestif.to_raw_string h |> String.to_list\n |> List.concat_map ~f:(fun c ->\n let c = Char.to_int c in\n List.init 8 ~f:(fun i -> (c lsr i) land 1 = 1) )\n |> fun a -> List.take a length\n\nlet ro lab length f =\n let r = ref 0 in\n fun () ->\n incr r ;\n f (bits_random_oracle ~length (sprintf \"%s_%d\" lab !r))\n\nlet tock = ro \"fq\" Tock.Field.size_in_bits Tock.Field.of_bits\n\nlet tick = ro \"fp\" Tick.Field.size_in_bits Tick.Field.of_bits\n\nlet chal = ro \"chal\" Challenge.Constant.length Challenge.Constant.of_bits\n\nlet scalar_chal () = Scalar_challenge.create (chal ())\n","module P = Proof\n\nmodule type Statement_intf = Intf.Statement\n\nmodule type Statement_var_intf = Intf.Statement_var\n\nmodule type Statement_value_intf = Intf.Statement_value\n\nmodule SC = Scalar_challenge\nopen Core_kernel\nopen Async_kernel\nopen Import\nopen Pickles_types\nopen Poly_types\nopen Hlist\nopen Backend\n\nexception Return_digest of Md5.t\n\nlet profile_constraints = false\n\nlet verify_promise = Verify.verify\n\nopen Kimchi_backend\nmodule Proof_ = P.Base\nmodule Proof = P\n\nlet pad_messages_for_next_wrap_proof\n (type local_max_proofs_verifieds max_local_max_proofs_verifieds\n max_proofs_verified )\n (module M : Hlist.Maxes.S\n with type ns = max_local_max_proofs_verifieds\n and type length = max_proofs_verified )\n (messages_for_next_wrap_proofs :\n local_max_proofs_verifieds\n H1.T(Proof_.Messages_for_next_proof_over_same_field.Wrap).t ) =\n let dummy_chals = Dummy.Ipa.Wrap.challenges in\n let module Messages =\n H1.T (Proof_.Messages_for_next_proof_over_same_field.Wrap) in\n let module Maxes = H1.T (Nat) in\n let (T (messages_len, _)) = Messages.length messages_for_next_wrap_proofs in\n let (T (maxes_len, _)) = Maxes.length M.maxes in\n let (T difference) =\n let rec sub : type n m. n Nat.t -> m Nat.t -> Nat.e =\n fun x y ->\n let open Nat in\n match (x, y) with\n | _, Z ->\n T x\n | Z, S _ ->\n assert false\n | S x, S y ->\n sub x y\n in\n sub maxes_len messages_len\n in\n let rec go :\n type len ms ns. len Nat.t -> ms Maxes.t -> ns Messages.t -> ms Messages.t\n =\n fun pad maxes messages_for_next_wrap_proofs ->\n match (pad, maxes, messages_for_next_wrap_proofs) with\n | S pad, m :: maxes, _ ->\n { challenge_polynomial_commitment = Lazy.force Dummy.Ipa.Step.sg\n ; old_bulletproof_challenges = Vector.init m ~f:(fun _ -> dummy_chals)\n }\n :: go pad maxes messages_for_next_wrap_proofs\n | S _, [], _ ->\n assert false\n | Z, [], [] ->\n []\n | ( Z\n , m :: maxes\n , messages_for_next_wrap_proof :: messages_for_next_wrap_proofs ) ->\n let messages_for_next_wrap_proof =\n { messages_for_next_wrap_proof with\n old_bulletproof_challenges =\n Vector.extend_exn\n messages_for_next_wrap_proof.old_bulletproof_challenges m\n dummy_chals\n }\n in\n messages_for_next_wrap_proof :: go Z maxes messages_for_next_wrap_proofs\n | Z, [], _ :: _ | Z, _ :: _, [] ->\n assert false\n in\n go difference M.maxes messages_for_next_wrap_proofs\n\nmodule type Proof_intf = sig\n type statement\n\n type t\n\n val verification_key : Verification_key.t Lazy.t\n\n val id : Cache.Wrap.Key.Verification.t Lazy.t\n\n val verify : (statement * t) list -> unit Or_error.t Deferred.t\n\n val verify_promise : (statement * t) list -> unit Or_error.t Promise.t\nend\n\nmodule Prover = struct\n type ('prev_values, 'local_widths, 'local_heights, 'a_value, 'proof) t =\n ?handler:\n ( Snarky_backendless.Request.request\n -> Snarky_backendless.Request.response )\n -> 'a_value\n -> 'proof\nend\n\ntype ('max_proofs_verified, 'branches, 'prev_varss) wrap_main_generic =\n { wrap_main :\n 'max_local_max_proofs_verifieds.\n Domains.t\n -> ( 'max_proofs_verified\n , 'branches\n , 'max_local_max_proofs_verifieds )\n Full_signature.t\n -> ('prev_varss, 'branches) Hlist.Length.t\n -> ( ( Wrap_main_inputs.Inner_curve.Constant.t\n , Wrap_main_inputs.Inner_curve.Constant.t option )\n Wrap_verifier.index'\n , 'branches )\n Vector.t\n Lazy.t\n -> (int, 'branches) Pickles_types.Vector.t\n -> (Import.Domains.t, 'branches) Pickles_types.Vector.t\n -> (module Pickles_types.Nat.Add.Intf with type n = 'max_proofs_verified)\n -> ('max_proofs_verified, 'max_local_max_proofs_verifieds) Requests.Wrap.t\n * ( ( ( Impls.Wrap.Field.t\n , Wrap_verifier.Challenge.t Kimchi_types.scalar_challenge\n , Wrap_verifier.Other_field.Packed.t Shifted_value.Type1.t\n , ( Wrap_verifier.Other_field.Packed.t Shifted_value.Type1.t\n , Impls.Wrap.Boolean.var )\n Opt.t\n , ( Impls.Wrap.Impl.Field.t Composition_types.Scalar_challenge.t\n , Impls.Wrap.Boolean.var )\n Pickles_types__Opt.t\n , Impls.Wrap.Boolean.var )\n Composition_types.Wrap.Proof_state.Deferred_values.Plonk\n .In_circuit\n .t\n , Wrap_verifier.Challenge.t Kimchi_types.scalar_challenge\n , Wrap_verifier.Other_field.Packed.t\n Pickles_types__Shifted_value.Type1.t\n , Impls.Wrap.Field.t\n , Impls.Wrap.Field.t\n , Impls.Wrap.Field.t\n , ( Impls.Wrap.Field.t Import.Scalar_challenge.t\n Import.Types.Bulletproof_challenge.t\n , Backend.Tick.Rounds.n )\n Vector.T.t\n , Impls.Wrap.Field.t )\n Composition_types.Wrap.Statement.t\n -> unit )\n (** An override for wrap_main, which allows for adversarial testing\n with an 'invalid' pickles statement by passing a dummy proof.\n *)\n ; tweak_statement :\n 'actual_proofs_verified 'b 'e.\n ( Import.Challenge.Constant.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , ( Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool )\n Import.Types.Opt.t\n , ( Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , bool )\n Import.Types.Opt.t\n , bool\n , 'max_proofs_verified\n Proof.Base.Messages_for_next_proof_over_same_field.Wrap.t\n , (int64, Composition_types.Digest.Limbs.n) Pickles_types.Vector.vec\n , ( 'b\n , ( Kimchi_pasta.Pallas_based_plonk.Proof.G.Affine.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t\n , ( ( Import.Challenge.Constant.t Import.Scalar_challenge.t\n Import.Bulletproof_challenge.t\n , 'e )\n Pickles_types.Vector.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t )\n Proof.Base.Messages_for_next_proof_over_same_field.Step.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n Import.Types.Bulletproof_challenge.t\n Import.Types.Step_bp_vec.t\n , Import.Types.Branch_data.t )\n Import.Types.Wrap.Statement.In_circuit.t\n -> ( Import.Challenge.Constant.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , ( Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool )\n Import.Types.Opt.t\n , ( Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , bool )\n Import.Types.Opt.t\n , bool\n , 'max_proofs_verified\n Proof.Base.Messages_for_next_proof_over_same_field.Wrap.t\n , ( Limb_vector.Constant.Hex64.t\n , Composition_types.Digest.Limbs.n )\n Pickles_types.Vector.vec\n , ( 'b\n , ( Kimchi_pasta.Pallas_based_plonk.Proof.G.Affine.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t\n , ( ( Import.Challenge.Constant.t Import.Scalar_challenge.t\n Import.Bulletproof_challenge.t\n , 'e )\n Pickles_types.Vector.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t )\n Proof.Base.Messages_for_next_proof_over_same_field.Step.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n Import.Types.Bulletproof_challenge.t\n Import.Types.Step_bp_vec.t\n , Import.Types.Branch_data.t )\n Import.Types.Wrap.Statement.In_circuit.t\n (** A function to modify the statement passed into the wrap proof,\n which will be later passed to recursion pickles rules.\n\n This function can be used to modify the pickles statement in an\n adversarial way, along with [wrap_main] above that allows that\n statement to be accepted.\n *)\n }\n\nmodule Make\n (Arg_var : Statement_var_intf)\n (Arg_value : Statement_value_intf)\n (Ret_var : T0)\n (Ret_value : T0)\n (Auxiliary_var : T0)\n (Auxiliary_value : T0) =\nstruct\n module IR =\n Inductive_rule.T (Arg_var) (Arg_value) (Ret_var) (Ret_value) (Auxiliary_var)\n (Auxiliary_value)\n module HIR = H4.T (IR)\n\n let max_local_max_proofs_verifieds ~self (type n)\n (module Max_proofs_verified : Nat.Intf with type n = n) branches choices =\n let module Local_max_proofs_verifieds = struct\n type t = (int, Max_proofs_verified.n) Vector.t\n end in\n let module M =\n H4.Map (IR) (E04 (Local_max_proofs_verifieds))\n (struct\n module V = H4.To_vector (Int)\n module HT = H4.T (Tag)\n\n module M =\n H4.Map (Tag) (E04 (Int))\n (struct\n let f (type a b c d) (t : (a, b, c, d) Tag.t) : int =\n if Type_equal.Id.same t.id self then\n Nat.to_int Max_proofs_verified.n\n else\n let (module M) = Types_map.max_proofs_verified t in\n Nat.to_int M.n\n end)\n\n let f :\n type a b c d. (a, b, c, d) IR.t -> Local_max_proofs_verifieds.t =\n fun rule ->\n let (T (_, l)) = HT.length rule.prevs in\n Vector.extend_front_exn\n (V.f l (M.f rule.prevs))\n Max_proofs_verified.n 0\n end)\n in\n let module V = H4.To_vector (Local_max_proofs_verifieds) in\n let padded = V.f branches (M.f choices) |> Vector.transpose in\n (padded, Maxes.m padded)\n\n module Lazy_keys = struct\n type t =\n (Impls.Step.Keypair.t * Dirty.t) Lazy.t\n * (Kimchi_bindings.Protocol.VerifierIndex.Fp.t * Dirty.t) Lazy.t\n\n (* TODO Think this is right.. *)\n end\n\n let log_step main _typ name index =\n let module Constraints = Snarky_log.Constraints (Impls.Step.Internal_Basic) in\n let log =\n let weight =\n let sys = Backend.Tick.R1CS_constraint_system.create () in\n fun ({ annotation; basic } : Impls.Step.Constraint.t) ->\n let prev =\n Kimchi_pasta_constraint_system.Vesta_constraint_system.next_row sys\n in\n Backend.Tick.R1CS_constraint_system.add_constraint sys\n ?label:annotation basic ;\n let next =\n Kimchi_pasta_constraint_system.Vesta_constraint_system.next_row sys\n in\n next - prev\n in\n Constraints.log ~weight (fun () -> Impls.Step.make_checked main)\n in\n if profile_constraints then\n Snarky_log.to_file (sprintf \"step-snark-%s-%d.json\" name index) log\n\n let log_wrap main typ name id =\n let module Constraints = Snarky_log.Constraints (Impls.Wrap.Internal_Basic) in\n let log =\n let sys = Backend.Tock.R1CS_constraint_system.create () in\n let weight ({ annotation; basic } : Impls.Wrap.Constraint.t) =\n let prev =\n Kimchi_pasta_constraint_system.Pallas_constraint_system.next_row sys\n in\n Backend.Tock.R1CS_constraint_system.add_constraint sys ?label:annotation\n basic ;\n let next =\n Kimchi_pasta_constraint_system.Pallas_constraint_system.next_row sys\n in\n next - prev\n in\n let log =\n Constraints.log ~weight\n Impls.Wrap.(\n fun () ->\n make_checked (fun () : unit ->\n let x = with_label __LOC__ (fun () -> exists typ) in\n main x () ))\n in\n log\n in\n if profile_constraints then\n Snarky_log.to_file\n (sprintf\n !\"wrap-%s-%{sexp:Type_equal.Id.Uid.t}.json\"\n name (Type_equal.Id.uid id) )\n log\n\n let compile :\n type var value prev_varss prev_valuess widthss heightss max_proofs_verified branches.\n self:(var, value, max_proofs_verified, branches) Tag.t\n -> cache:Key_cache.Spec.t list\n -> proof_cache:Proof_cache.t option\n -> ?disk_keys:\n (Cache.Step.Key.Verification.t, branches) Vector.t\n * Cache.Wrap.Key.Verification.t\n -> ?return_early_digest_exception:bool\n -> ?override_wrap_domain:Pickles_base.Proofs_verified.t\n -> ?override_wrap_main:\n (max_proofs_verified, branches, prev_varss) wrap_main_generic\n -> branches:(module Nat.Intf with type n = branches)\n -> max_proofs_verified:\n (module Nat.Add.Intf with type n = max_proofs_verified)\n -> name:string\n -> constraint_constants:Snark_keys_header.Constraint_constants.t\n -> public_input:\n ( var\n , value\n , Arg_var.t\n , Arg_value.t\n , Ret_var.t\n , Ret_value.t )\n Inductive_rule.public_input\n -> auxiliary_typ:(Auxiliary_var.t, Auxiliary_value.t) Impls.Step.Typ.t\n -> choices:\n ( self:(var, value, max_proofs_verified, branches) Tag.t\n -> (prev_varss, prev_valuess, widthss, heightss) H4.T(IR).t )\n -> unit\n -> ( prev_valuess\n , widthss\n , heightss\n , Arg_value.t\n , ( Ret_value.t\n * Auxiliary_value.t\n * (max_proofs_verified, max_proofs_verified) Proof.t )\n Promise.t )\n H3_2.T(Prover).t\n * _\n * _\n * _ =\n fun ~self ~cache ~proof_cache ?disk_keys\n ?(return_early_digest_exception = false) ?override_wrap_domain\n ?override_wrap_main ~branches:(module Branches) ~max_proofs_verified\n ~name ~constraint_constants ~public_input ~auxiliary_typ ~choices () ->\n let snark_keys_header kind constraint_system_hash =\n { Snark_keys_header.header_version = Snark_keys_header.header_version\n ; kind\n ; constraint_constants\n ; commits =\n { mina = Mina_version.commit_id\n ; marlin = Mina_version.marlin_commit_id\n }\n ; length = (* This is a dummy, it gets filled in on read/write. *) 0\n ; commit_date = Mina_version.commit_date\n ; constraint_system_hash\n ; identifying_hash =\n (* TODO: Proper identifying hash. *)\n constraint_system_hash\n }\n in\n Timer.start __LOC__ ;\n let module Max_proofs_verified = ( val max_proofs_verified : Nat.Add.Intf\n with type n = max_proofs_verified )\n in\n let T = Max_proofs_verified.eq in\n let choices = choices ~self in\n let (T (prev_varss_n, prev_varss_length)) = HIR.length choices in\n let T = Nat.eq_exn prev_varss_n Branches.n in\n let padded, (module Maxes) =\n max_local_max_proofs_verifieds\n ( module struct\n include Max_proofs_verified\n end )\n prev_varss_length choices ~self:self.id\n in\n let full_signature = { Full_signature.padded; maxes = (module Maxes) } in\n Timer.clock __LOC__ ;\n let feature_flags =\n let rec go :\n type a b c d.\n (a, b, c, d) H4.T(IR).t -> Opt.Flag.t Plonk_types.Features.Full.t =\n fun rules ->\n match rules with\n | [] ->\n Plonk_types.Features.Full.none\n | [ r ] ->\n Plonk_types.Features.map r.feature_flags ~f:(function\n | true ->\n Opt.Flag.Yes\n | false ->\n Opt.Flag.No )\n |> Plonk_types.Features.to_full ~or_:Opt.Flag.( ||| )\n | r :: rules ->\n let feature_flags = go rules in\n Plonk_types.Features.Full.map2\n (Plonk_types.Features.to_full ~or_:( || ) r.feature_flags)\n feature_flags ~f:(fun enabled flag ->\n match (enabled, flag) with\n | true, Yes ->\n Opt.Flag.Yes\n | false, No ->\n No\n | _, Maybe | true, No | false, Yes ->\n Maybe )\n in\n go choices\n in\n let wrap_domains =\n match override_wrap_domain with\n | None ->\n let module M =\n Wrap_domains.Make (Arg_var) (Arg_value) (Ret_var) (Ret_value)\n (Auxiliary_var)\n (Auxiliary_value)\n in\n M.f full_signature prev_varss_n prev_varss_length ~max_proofs_verified\n ~feature_flags\n | Some override ->\n Common.wrap_domains\n ~proofs_verified:(Pickles_base.Proofs_verified.to_int override)\n in\n Timer.clock __LOC__ ;\n let module Branch_data = struct\n type ('vars, 'vals, 'n, 'm) t =\n ( Arg_var.t\n , Arg_value.t\n , Ret_var.t\n , Ret_value.t\n , Auxiliary_var.t\n , Auxiliary_value.t\n , Max_proofs_verified.n\n , Branches.n\n , 'vars\n , 'vals\n , 'n\n , 'm )\n Step_branch_data.t\n end in\n let proofs_verifieds =\n let module M =\n H4.Map (IR) (E04 (Int))\n (struct\n module M = H4.T (Tag)\n\n let f : type a b c d. (a, b, c, d) IR.t -> int =\n fun r ->\n let (T (n, _)) = M.length r.prevs in\n Nat.to_int n\n end)\n in\n let module V = H4.To_vector (Int) in\n V.f prev_varss_length (M.f choices)\n in\n let step_data =\n let i = ref 0 in\n Timer.clock __LOC__ ;\n let rec f :\n type a b c d.\n (a, b, c, d) H4.T(IR).t -> (a, b, c, d) H4.T(Branch_data).t = function\n | [] ->\n []\n | rule :: rules ->\n let first =\n Timer.clock __LOC__ ;\n let res =\n Common.time \"make step data\" (fun () ->\n Step_branch_data.create ~index:!i ~feature_flags\n ~actual_feature_flags:rule.feature_flags\n ~max_proofs_verified:Max_proofs_verified.n\n ~branches:Branches.n ~self ~public_input ~auxiliary_typ\n Arg_var.to_field_elements Arg_value.to_field_elements rule\n ~wrap_domains ~proofs_verifieds )\n in\n Timer.clock __LOC__ ; incr i ; res\n in\n first :: f rules\n in\n f choices\n in\n Timer.clock __LOC__ ;\n let step_domains =\n let module M =\n H4.Map (Branch_data) (E04 (Domains))\n (struct\n let f (T b : _ Branch_data.t) = b.domains\n end)\n in\n let module V = H4.To_vector (Domains) in\n V.f prev_varss_length (M.f step_data)\n in\n let cache_handle = ref (Lazy.return `Cache_hit) in\n let accum_dirty t = cache_handle := Cache_handle.(!cache_handle + t) in\n Timer.clock __LOC__ ;\n let step_keypairs =\n let disk_keys =\n Option.map disk_keys ~f:(fun (xs, _) -> Vector.to_array xs)\n in\n let module M =\n H4.Map (Branch_data) (E04 (Lazy_keys))\n (struct\n let etyp =\n Impls.Step.input ~proofs_verified:Max_proofs_verified.n\n ~wrap_rounds:Tock.Rounds.n\n\n let f (T b : _ Branch_data.t) =\n let (T (typ, _conv, conv_inv)) = etyp in\n let main () () =\n let res = b.main ~step_domains () in\n Impls.Step.with_label \"conv_inv\" (fun () -> conv_inv res)\n in\n let () = if true then log_step main typ name b.index in\n let open Impls.Step in\n (* HACK: TODO docs *)\n if return_early_digest_exception then\n raise\n (Return_digest\n ( constraint_system ~input_typ:Typ.unit ~return_typ:typ main\n |> R1CS_constraint_system.digest ) ) ;\n\n let k_p =\n lazy\n (let cs =\n constraint_system ~input_typ:Typ.unit ~return_typ:typ main\n in\n let cs_hash =\n Md5.to_hex (R1CS_constraint_system.digest cs)\n in\n ( Type_equal.Id.uid self.id\n , snark_keys_header\n { type_ = \"step-proving-key\"\n ; identifier = name ^ \"-\" ^ b.rule.identifier\n }\n cs_hash\n , b.index\n , cs ) )\n in\n let k_v =\n match disk_keys with\n | Some ks ->\n Lazy.return ks.(b.index)\n | None ->\n lazy\n (let id, _header, index, cs = Lazy.force k_p in\n let digest = R1CS_constraint_system.digest cs in\n ( id\n , snark_keys_header\n { type_ = \"step-verification-key\"\n ; identifier = name ^ \"-\" ^ b.rule.identifier\n }\n (Md5.to_hex digest)\n , index\n , digest ) )\n in\n let ((pk, vk) as res) =\n Common.time \"step read or generate\" (fun () ->\n Cache.Step.read_or_generate\n ~prev_challenges:(Nat.to_int (fst b.proofs_verified))\n cache k_p k_v\n (Snarky_backendless.Typ.unit ())\n typ main )\n in\n accum_dirty (Lazy.map pk ~f:snd) ;\n accum_dirty (Lazy.map vk ~f:snd) ;\n res\n end)\n in\n M.f step_data\n in\n Timer.clock __LOC__ ;\n let step_vks =\n let module V = H4.To_vector (Lazy_keys) in\n lazy\n (Vector.map (V.f prev_varss_length step_keypairs) ~f:(fun (_, vk) ->\n Tick.Keypair.full_vk_commitments (fst (Lazy.force vk)) ) )\n in\n Timer.clock __LOC__ ;\n let wrap_requests, wrap_main =\n match override_wrap_main with\n | None ->\n let srs = Tick.Keypair.load_urs () in\n Wrap_main.wrap_main ~feature_flags ~srs full_signature\n prev_varss_length step_vks proofs_verifieds step_domains\n max_proofs_verified\n | Some { wrap_main; tweak_statement = _ } ->\n (* Instead of creating a proof using the pickles wrap circuit, we\n have been asked to create proof in an 'adversarial' way, where\n the wrap circuit is some other circuit.\n The [wrap_main] value passed in as part of [override_wrap_main]\n defines the alternative circuit to run; this will usually be a\n dummy circuit that verifies any public input for the purposes of\n testing.\n *)\n wrap_main wrap_domains full_signature prev_varss_length step_vks\n proofs_verifieds step_domains max_proofs_verified\n in\n Timer.clock __LOC__ ;\n let (wrap_pk, wrap_vk), disk_key =\n let open Impls.Wrap in\n let (T (typ, conv, _conv_inv)) = input ~feature_flags () in\n let main x () : unit = wrap_main (conv x) in\n let () = if true then log_wrap main typ name self.id in\n let self_id = Type_equal.Id.uid self.id in\n let disk_key_prover =\n lazy\n (let cs =\n constraint_system ~input_typ:typ\n ~return_typ:(Snarky_backendless.Typ.unit ())\n main\n in\n let cs_hash = Md5.to_hex (R1CS_constraint_system.digest cs) in\n ( self_id\n , snark_keys_header\n { type_ = \"wrap-proving-key\"; identifier = name }\n cs_hash\n , cs ) )\n in\n let disk_key_verifier =\n match disk_keys with\n | None ->\n lazy\n (let id, _header, cs = Lazy.force disk_key_prover in\n let digest = R1CS_constraint_system.digest cs in\n ( id\n , snark_keys_header\n { type_ = \"wrap-verification-key\"; identifier = name }\n (Md5.to_hex digest)\n , digest ) )\n | Some (_, (_id, header, digest)) ->\n Lazy.return (self_id, header, digest)\n in\n let r =\n Common.time \"wrap read or generate \" (fun () ->\n Cache.Wrap.read_or_generate (* Due to Wrap_hack *)\n ~prev_challenges:2 cache disk_key_prover disk_key_verifier typ\n (Snarky_backendless.Typ.unit ())\n main )\n in\n (r, disk_key_verifier)\n in\n Timer.clock __LOC__ ;\n let wrap_vk =\n Lazy.map wrap_vk ~f:(fun ((wrap_vk, _) as res) ->\n let computed_domain_size = wrap_vk.index.domain.log_size_of_group in\n let (Pow_2_roots_of_unity proposed_domain_size) = wrap_domains.h in\n if computed_domain_size <> proposed_domain_size then\n failwithf\n \"This circuit was compiled for proofs using the wrap domain of \\\n size %d, but the actual wrap domain size for the circuit has \\\n size %d. You should pass the ~override_wrap_domain argument to \\\n set the correct domain size.\"\n proposed_domain_size computed_domain_size () ;\n res )\n in\n accum_dirty (Lazy.map wrap_pk ~f:snd) ;\n accum_dirty (Lazy.map wrap_vk ~f:snd) ;\n let wrap_vk = Lazy.map wrap_vk ~f:fst in\n let module S =\n Step.Make (Arg_var) (Arg_value)\n (struct\n include Max_proofs_verified\n end)\n in\n let (typ : (var, value) Impls.Step.Typ.t) =\n match public_input with\n | Input typ ->\n typ\n | Output typ ->\n typ\n | Input_and_output (input_typ, output_typ) ->\n Impls.Step.Typ.(input_typ * output_typ)\n in\n let provers =\n let f :\n type prev_vars prev_values local_widths local_heights.\n (prev_vars, prev_values, local_widths, local_heights) Branch_data.t\n -> Lazy_keys.t\n -> ?handler:\n ( Snarky_backendless.Request.request\n -> Snarky_backendless.Request.response )\n -> Arg_value.t\n -> ( Ret_value.t\n * Auxiliary_value.t\n * (Max_proofs_verified.n, Max_proofs_verified.n) Proof.t )\n Promise.t =\n fun (T b as branch_data) (step_pk, step_vk) ->\n let _, prev_vars_length = b.proofs_verified in\n let step handler next_state =\n let wrap_vk = Lazy.force wrap_vk in\n S.f ?handler branch_data next_state ~prevs_length:prev_vars_length\n ~self ~step_domains ~self_dlog_plonk_index:wrap_vk.commitments\n ~public_input ~auxiliary_typ ~feature_flags\n (Impls.Step.Keypair.pk (fst (Lazy.force step_pk)))\n wrap_vk.index\n in\n let step_vk = fst (Lazy.force step_vk) in\n let wrap ?handler next_state =\n let wrap_vk = Lazy.force wrap_vk in\n let%bind.Promise ( proof\n , return_value\n , auxiliary_value\n , actual_wrap_domains ) =\n step ~proof_cache handler ~maxes:(module Maxes) next_state\n in\n let proof =\n { proof with\n statement =\n { proof.statement with\n messages_for_next_wrap_proof =\n pad_messages_for_next_wrap_proof\n (module Maxes)\n proof.statement.messages_for_next_wrap_proof\n }\n }\n in\n let%map.Promise proof =\n let tweak_statement =\n match override_wrap_main with\n | None ->\n None\n | Some { tweak_statement; wrap_main = _ } ->\n (* Extract the [tweak_statement] part of the\n [override_wrap_main], so that we can run an adversarial\n test.\n\n This function modifies the statement that will be proved\n over, and which gets passed to later recursive pickles\n rules.\n *)\n Some tweak_statement\n in\n Wrap.wrap ~proof_cache ~max_proofs_verified:Max_proofs_verified.n\n ~feature_flags ~actual_feature_flags:b.feature_flags\n full_signature.maxes wrap_requests ?tweak_statement\n ~dlog_plonk_index:wrap_vk.commitments wrap_main ~typ ~step_vk\n ~step_plonk_indices:(Lazy.force step_vks) ~actual_wrap_domains\n (Impls.Wrap.Keypair.pk (fst (Lazy.force wrap_pk)))\n proof\n in\n ( return_value\n , auxiliary_value\n , Proof.T\n { proof with\n statement =\n { proof.statement with\n messages_for_next_step_proof =\n { proof.statement.messages_for_next_step_proof with\n app_state = ()\n }\n }\n } )\n in\n wrap\n in\n let rec go :\n type xs1 xs2 xs3 xs4.\n (xs1, xs2, xs3, xs4) H4.T(Branch_data).t\n -> (xs1, xs2, xs3, xs4) H4.T(E04(Lazy_keys)).t\n -> ( xs2\n , xs3\n , xs4\n , Arg_value.t\n , ( Ret_value.t\n * Auxiliary_value.t\n * (max_proofs_verified, max_proofs_verified) Proof.t )\n Promise.t )\n H3_2.T(Prover).t =\n fun bs ks ->\n match (bs, ks) with\n | [], [] ->\n []\n | b :: bs, k :: ks ->\n f b k :: go bs ks\n in\n go step_data step_keypairs\n in\n Timer.clock __LOC__ ;\n let data : _ Types_map.Compiled.t =\n { branches = Branches.n\n ; proofs_verifieds\n ; max_proofs_verified\n ; public_input = typ\n ; wrap_key = Lazy.map wrap_vk ~f:Verification_key.commitments\n ; wrap_vk = Lazy.map wrap_vk ~f:Verification_key.index\n ; wrap_domains\n ; step_domains\n ; feature_flags\n }\n in\n Timer.clock __LOC__ ;\n Types_map.add_exn self data ;\n (provers, wrap_vk, disk_key, !cache_handle)\nend\n\nmodule Side_loaded = struct\n module V = Verification_key\n\n module Verification_key = struct\n include Side_loaded_verification_key\n\n let to_input (t : t) =\n to_input ~field_of_int:Impls.Step.Field.Constant.of_int t\n\n let of_compiled tag : t =\n let d = Types_map.lookup_compiled tag.Tag.id in\n let actual_wrap_domain_size =\n Common.actual_wrap_domain_size\n ~log_2_domain_size:(Lazy.force d.wrap_vk).domain.log_size_of_group\n in\n { wrap_vk = Some (Lazy.force d.wrap_vk)\n ; wrap_index = Lazy.force d.wrap_key\n ; max_proofs_verified =\n Pickles_base.Proofs_verified.of_nat (Nat.Add.n d.max_proofs_verified)\n ; actual_wrap_domain_size\n }\n\n module Max_width = Width.Max\n end\n\n let in_circuit tag vk = Types_map.set_ephemeral tag { index = `In_circuit vk }\n\n let in_prover tag vk = Types_map.set_ephemeral tag { index = `In_prover vk }\n\n let create ~name ~max_proofs_verified ~feature_flags ~typ =\n Types_map.add_side_loaded ~name\n { max_proofs_verified\n ; public_input = typ\n ; branches = Verification_key.Max_branches.n\n ; feature_flags =\n Plonk_types.Features.to_full ~or_:Opt.Flag.( ||| ) feature_flags\n }\n\n module Proof = struct\n include Proof.Proofs_verified_max\n\n let of_proof : _ Proof.t -> t = Wrap_hack.pad_proof\n end\n\n let verify_promise (type t) ~(typ : (_, t) Impls.Step.Typ.t)\n (ts : (Verification_key.t * t * Proof.t) list) =\n let m =\n ( module struct\n type nonrec t = t\n\n let to_field_elements =\n let (Typ typ) = typ in\n fun x -> fst (typ.value_to_fields x)\n end : Intf.Statement_value\n with type t = t )\n in\n (* TODO: This should be the actual max width on a per proof basis *)\n let max_proofs_verified =\n (module Verification_key.Max_width : Nat.Intf\n with type n = Verification_key.Max_width.n )\n in\n with_return (fun { return } ->\n List.map ts ~f:(fun (vk, x, p) ->\n let vk : V.t =\n { commitments = vk.wrap_index\n ; index =\n ( match vk.wrap_vk with\n | None ->\n return\n (Promise.return\n (Or_error.errorf \"Pickles.verify: wrap_vk not found\") )\n | Some x ->\n x )\n ; data =\n (* This isn't used in verify_heterogeneous, so we can leave this dummy *)\n { constraints = 0 }\n }\n in\n Verify.Instance.T (max_proofs_verified, m, vk, x, p) )\n |> Verify.verify_heterogenous )\n\n let verify ~typ ts = verify_promise ~typ ts |> Promise.to_deferred\n\n let srs_precomputation () : unit =\n let srs = Tock.Keypair.load_urs () in\n List.iter [ 0; 1; 2 ] ~f:(fun i ->\n Kimchi_bindings.Protocol.SRS.Fq.add_lagrange_basis srs\n (Domain.log2_size (Common.wrap_domains ~proofs_verified:i).h) )\nend\n\nlet compile_with_wrap_main_override_promise :\n type var value a_var a_value ret_var ret_value auxiliary_var auxiliary_value prev_varss prev_valuess widthss heightss max_proofs_verified branches.\n ?self:(var, value, max_proofs_verified, branches) Tag.t\n -> ?cache:Key_cache.Spec.t list\n -> ?proof_cache:Proof_cache.t\n -> ?disk_keys:\n (Cache.Step.Key.Verification.t, branches) Vector.t\n * Cache.Wrap.Key.Verification.t\n -> ?return_early_digest_exception:bool\n -> ?override_wrap_domain:Pickles_base.Proofs_verified.t\n -> ?override_wrap_main:\n (max_proofs_verified, branches, prev_varss) wrap_main_generic\n -> public_input:\n ( var\n , value\n , a_var\n , a_value\n , ret_var\n , ret_value )\n Inductive_rule.public_input\n -> auxiliary_typ:(auxiliary_var, auxiliary_value) Impls.Step.Typ.t\n -> branches:(module Nat.Intf with type n = branches)\n -> max_proofs_verified:\n (module Nat.Add.Intf with type n = max_proofs_verified)\n -> name:string\n -> constraint_constants:Snark_keys_header.Constraint_constants.t\n -> choices:\n ( self:(var, value, max_proofs_verified, branches) Tag.t\n -> ( prev_varss\n , prev_valuess\n , widthss\n , heightss\n , a_var\n , a_value\n , ret_var\n , ret_value\n , auxiliary_var\n , auxiliary_value )\n H4_6.T(Inductive_rule).t )\n -> unit\n -> (var, value, max_proofs_verified, branches) Tag.t\n * Cache_handle.t\n * (module Proof_intf\n with type t = (max_proofs_verified, max_proofs_verified) Proof.t\n and type statement = value )\n * ( prev_valuess\n , widthss\n , heightss\n , a_value\n , ( ret_value\n * auxiliary_value\n * (max_proofs_verified, max_proofs_verified) Proof.t )\n Promise.t )\n H3_2.T(Prover).t =\n (* This function is an adapter between the user-facing Pickles.compile API\n and the underlying Make(_).compile function which builds the circuits.\n *)\n fun ?self ?(cache = []) ?proof_cache ?disk_keys\n ?(return_early_digest_exception = false) ?override_wrap_domain\n ?override_wrap_main ~public_input ~auxiliary_typ ~branches\n ~max_proofs_verified ~name ~constraint_constants ~choices () ->\n let self =\n match self with\n | None ->\n Tag.(create ~kind:Compiled name)\n | Some self ->\n self\n in\n (* Extract to_fields methods from the public input declaration. *)\n let (a_var_to_fields : a_var -> _), (a_value_to_fields : a_value -> _) =\n match public_input with\n | Input (Typ typ) ->\n ( (fun x -> fst (typ.var_to_fields x))\n , fun x -> fst (typ.value_to_fields x) )\n | Output _ ->\n ((fun () -> [||]), fun () -> [||])\n | Input_and_output (Typ typ, _) ->\n ( (fun x -> fst (typ.var_to_fields x))\n , fun x -> fst (typ.value_to_fields x) )\n in\n let module A_var = struct\n type t = a_var\n\n let to_field_elements = a_var_to_fields\n end in\n let module A_value = struct\n type t = a_value\n\n let to_field_elements = a_value_to_fields\n end in\n let module Ret_var = struct\n type t = ret_var\n end in\n let module Ret_value = struct\n type t = ret_value\n end in\n let module Auxiliary_var = struct\n type t = auxiliary_var\n end in\n let module Auxiliary_value = struct\n type t = auxiliary_value\n end in\n let module M =\n Make (A_var) (A_value) (Ret_var) (Ret_value) (Auxiliary_var)\n (Auxiliary_value)\n in\n let rec conv_irs :\n type v1ss v2ss wss hss.\n ( v1ss\n , v2ss\n , wss\n , hss\n , a_var\n , a_value\n , ret_var\n , ret_value\n , auxiliary_var\n , auxiliary_value )\n H4_6.T(Inductive_rule).t\n -> (v1ss, v2ss, wss, hss) H4.T(M.IR).t = function\n | [] ->\n []\n | r :: rs ->\n r :: conv_irs rs\n in\n let provers, wrap_vk, wrap_disk_key, cache_handle =\n M.compile ~return_early_digest_exception ~self ~proof_cache ~cache\n ?disk_keys ?override_wrap_domain ?override_wrap_main ~branches\n ~max_proofs_verified ~name ~public_input ~auxiliary_typ\n ~constraint_constants\n ~choices:(fun ~self -> conv_irs (choices ~self))\n ()\n in\n let (module Max_proofs_verified) = max_proofs_verified in\n let T = Max_proofs_verified.eq in\n let module Value = struct\n type t = value\n\n let typ : (var, value) Impls.Step.Typ.t =\n match public_input with\n | Input typ ->\n typ\n | Output typ ->\n typ\n | Input_and_output (input_typ, output_typ) ->\n Impls.Step.Typ.(input_typ * output_typ)\n\n let to_field_elements =\n let (Typ typ) = typ in\n fun x -> fst (typ.value_to_fields x)\n end in\n let module P = struct\n type statement = value\n\n module Max_local_max_proofs_verified = Max_proofs_verified\n\n include\n Proof.Make\n (struct\n include Max_proofs_verified\n end)\n (struct\n include Max_local_max_proofs_verified\n end)\n\n let id = wrap_disk_key\n\n let verification_key = wrap_vk\n\n let verify_promise ts =\n verify_promise\n ( module struct\n include Max_proofs_verified\n end )\n (module Value)\n (Lazy.force verification_key)\n ts\n\n let verify ts = verify_promise ts |> Promise.to_deferred\n end in\n (self, cache_handle, (module P), provers)\n\nlet wrap_main_dummy_override _ _ _ _ _ _ _ =\n let requests =\n (* The requests that the logic in [Wrap.wrap] use to pass\n values into and out of the wrap proof circuit.\n Since these are unnecessary for the dummy circuit below, we\n generate them without using them.\n *)\n Requests.Wrap.create ()\n in\n (* A replacement for the 'wrap' circuit, which makes no\n assertions about the statement that it receives as its first\n argument.\n *)\n let wrap_main _ =\n let module SC' = SC in\n let open Impls.Wrap in\n let open Wrap_main_inputs in\n (* Create some variables to be used in constraints below. *)\n let x = exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3) in\n let y = exists Field.typ ~compute:(fun () -> Field.Constant.of_int 0) in\n let z = exists Field.typ ~compute:(fun () -> Field.Constant.of_int 0) in\n (* Every circuit must use at least 1 of each constraint; we\n use them here.\n *)\n let () =\n let g = Inner_curve.one in\n let sponge = Sponge.create sponge_params in\n Sponge.absorb sponge x ;\n ignore (Sponge.squeeze_field sponge : Field.t) ;\n ignore\n ( SC'.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore (Ops.scale_fast g ~num_bits:5 (Shifted_value x) : Inner_curve.t) ;\n ignore\n ( Wrap_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t )\n in\n (* Pad the circuit so that its domain size matches the one\n that would have been used by the true wrap_main.\n *)\n for _ = 0 to 64000 do\n assert_r1cs x y z\n done\n in\n (requests, wrap_main)\n\nmodule Make_adversarial_test (M : sig\n val tweak_statement :\n ( Import.Challenge.Constant.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , ( Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool )\n Import.Types.Opt.t\n , ( Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , bool )\n Import.Types.Opt.t\n , bool\n , 'max_proofs_verified\n Proof.Base.Messages_for_next_proof_over_same_field.Wrap.t\n , (int64, Composition_types.Digest.Limbs.n) Pickles_types.Vector.vec\n , ( 'b\n , ( Kimchi_pasta.Pallas_based_plonk.Proof.G.Affine.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t\n , ( ( Import.Challenge.Constant.t Import.Scalar_challenge.t\n Import.Bulletproof_challenge.t\n , 'e )\n Pickles_types.Vector.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t )\n Proof.Base.Messages_for_next_proof_over_same_field.Step.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n Import.Types.Bulletproof_challenge.t\n Import.Types.Step_bp_vec.t\n , Import.Types.Branch_data.t )\n Import.Types.Wrap.Statement.In_circuit.t\n -> ( Import.Challenge.Constant.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , ( Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool )\n Import.Types.Opt.t\n , ( Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , bool )\n Import.Types.Opt.t\n , bool\n , 'max_proofs_verified\n Proof.Base.Messages_for_next_proof_over_same_field.Wrap.t\n , ( Limb_vector.Constant.Hex64.t\n , Composition_types.Digest.Limbs.n )\n Pickles_types.Vector.vec\n , ( 'b\n , ( Kimchi_pasta.Pallas_based_plonk.Proof.G.Affine.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t\n , ( ( Import.Challenge.Constant.t Import.Scalar_challenge.t\n Import.Bulletproof_challenge.t\n , 'e )\n Pickles_types.Vector.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t )\n Proof.Base.Messages_for_next_proof_over_same_field.Step.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n Import.Types.Bulletproof_challenge.t\n Import.Types.Step_bp_vec.t\n , Import.Types.Branch_data.t )\n Import.Types.Wrap.Statement.In_circuit.t\n\n val check_verifier_error : Error.t -> unit\nend) =\nstruct\n open Impls.Step\n\n let constraint_constants : Snark_keys_header.Constraint_constants.t =\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n\n let rule self : _ Inductive_rule.t =\n { identifier = \"main\"\n ; prevs = [ self; self ]\n ; main =\n (fun { public_input = () } ->\n let dummy_proof =\n As_prover.Ref.create (fun () ->\n Proof.dummy Nat.N2.n Nat.N2.n Nat.N2.n ~domain_log2:15 )\n in\n { previous_proof_statements =\n [ { public_input = ()\n ; proof = dummy_proof\n ; proof_must_verify = Boolean.false_\n }\n ; { public_input = ()\n ; proof = dummy_proof\n ; proof_must_verify = Boolean.false_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n ; feature_flags = Plonk_types.Features.none_bool\n }\n\n let override_wrap_main =\n { wrap_main = wrap_main_dummy_override\n ; tweak_statement = M.tweak_statement\n }\n\n let tag, _, p, ([ step ] : _ H3_2.T(Prover).t) =\n compile_with_wrap_main_override_promise () ~override_wrap_main\n ~public_input:(Input Typ.unit) ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self -> [ rule self ])\n\n module Proof = (val p)\n\n let proof_with_stmt =\n let (), (), p = Promise.block_on_async_exn (fun () -> step ()) in\n ((), p)\n\n let%test \"should not be able to verify invalid proof\" =\n match\n Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ proof_with_stmt ] )\n with\n | Ok () ->\n false\n | Error err ->\n M.check_verifier_error err ; true\n\n module Recurse_on_bad_proof = struct\n open Impls.Step\n\n type _ Snarky_backendless.Request.t +=\n | Proof : Proof.t Snarky_backendless.Request.t\n\n let handler (proof : Proof.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Proof ->\n respond (Provide proof)\n | _ ->\n respond Unhandled\n\n let _tag, _, p, ([ step ] : _ H3_2.T(Prover).t) =\n Common.time \"compile\" (fun () ->\n compile_with_wrap_main_override_promise ()\n ~public_input:(Input Typ.unit) ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"recurse-on-bad\" ~constraint_constants\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = [ tag; tag ]\n ; main =\n (fun { public_input = () } ->\n let proof =\n exists (Typ.Internal.ref ()) ~request:(fun () -> Proof)\n in\n { previous_proof_statements =\n [ { public_input = ()\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ; { public_input = ()\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n end\n\n let%test \"should not be able to create a recursive proof from an invalid \\\n proof\" =\n try\n let (), (), proof =\n Promise.block_on_async_exn (fun () ->\n Recurse_on_bad_proof.step\n ~handler:(Recurse_on_bad_proof.handler (snd proof_with_stmt))\n () )\n in\n Or_error.is_error\n @@ Promise.block_on_async_exn (fun () ->\n Recurse_on_bad_proof.Proof.verify_promise [ ((), proof) ] )\n with _ -> true\nend\n","module Make\n (Impl : Snarky_backendless.Snark_intf.Run) (B : sig\n open Impl\n\n val params : field Sponge.Params.t\n\n val to_the_alpha : field -> field\n\n module Operations : sig\n val apply_affine_map :\n field array array * field array -> field array -> field array\n end\n end) =\nstruct\n include Make_sponge.Rounds\n\n let round_table start =\n let ({ round_constants; mds } : _ Sponge.Params.t) = B.params in\n (* sbox -> mds -> ark *)\n let apply_round i s =\n let s' = Array.map s ~f:B.to_the_alpha in\n B.Operations.apply_affine_map (mds, round_constants.(i)) s'\n in\n let res =\n Array.init (rounds_full + 1) ~f:(fun _ ->\n Array.create ~len:3 Impl.Field.Constant.zero )\n in\n res.(0) <- start ;\n for i = 0 to rounds_full - 1 do\n res.(i + 1) <- apply_round i res.(i)\n done ;\n res\n\n module Field = Impl.Field\n\n let block_cipher (_params : _ Sponge.Params.t) init =\n let open Impl in\n Impl.with_label __LOC__ (fun () ->\n let t =\n exists\n (Typ.array\n ~length:Int.(rounds_full + 1)\n (Typ.array ~length:3 Field.typ) )\n ~compute:\n As_prover.(fun () -> round_table (Array.map init ~f:read_var))\n in\n t.(0) <- init ;\n (let open Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint in\n with_label __LOC__ (fun () ->\n Impl.assert_\n { basic = T (Poseidon { state = t })\n ; annotation = Some \"plonk-poseidon\"\n } )) ;\n t.(Int.(Array.length t - 1)) )\n\n let add_assign ~state i x =\n state.(i) <- Util.seal (module Impl) Field.(state.(i) + x)\n\n let copy = Array.copy\nend\n","include Make_sponge.Make (Backend.Tock.Field)\n\nlet params = Kimchi_pasta_basic.poseidon_params_fq\n","open Core_kernel\nopen Backend\nopen Pickles_types\n\n(* The actual \"accumulator\" for the wrap proof contains a vector of elements,\n each of which is a vector of bulletproof challenges.\n\n The number of such vectors is equal to the maximum proofs-verified\n amongst all the step branches that that proof is wrapping.\n\n To simplify the implementation when the number of proofs-verified\n varies across proof systems (being either 0, 1, or 2) we secretly\n pad the accumulator so that it always has exactly 2 vectors, padding\n with dummy vectors.\n\n We also then pad with the corresponding dummy commitments when proving\n wrap statements, as in `pad_accumulator` which is used in wrap.ml.\n\n We add them to the **front**, not the back, of the vector of the actual\n \"real\" accumulator values so that we can precompute the sponge states\n resulting from absorbing the padding challenges\n*)\n\nmodule Padded_length = Nat.N2\n\n(* Pad up to length 2 by preprending dummy values. *)\nlet pad_vector (type a) ~dummy (v : (a, _) Vector.t) =\n Vector.extend_front_exn v Padded_length.n dummy\n\n(* Specialized padding function. *)\nlet pad_challenges (chalss : (_ Vector.t, _) Vector.t) =\n pad_vector ~dummy:(Lazy.force Dummy.Ipa.Wrap.challenges_computed) chalss\n\n(* Specialized padding function. *)\nlet pad_accumulator (xs : (Tock.Proof.Challenge_polynomial.t, _) Vector.t) =\n pad_vector xs\n ~dummy:\n { Tock.Proof.Challenge_polynomial.commitment =\n Lazy.force Dummy.Ipa.Wrap.sg\n ; challenges =\n Vector.to_array (Lazy.force Dummy.Ipa.Wrap.challenges_computed)\n }\n |> Vector.to_list\n\n(* Hash the me only, padding first. *)\nlet hash_messages_for_next_wrap_proof (type n) (_max_proofs_verified : n Nat.t)\n (t :\n ( Tick.Curve.Affine.t\n , (_, n) Vector.t )\n Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof.t ) =\n let t =\n { t with\n old_bulletproof_challenges = pad_challenges t.old_bulletproof_challenges\n }\n in\n Tock_field_sponge.digest Tock_field_sponge.params\n (Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof\n .to_field_elements t ~g1:(fun ((x, y) : Tick.Curve.Affine.t) -> [ x; y ])\n )\n\n(* Pad the messages_for_next_wrap_proof of a proof *)\nlet pad_proof (type mlmb) (T p : (mlmb, _) Proof.t) :\n Proof.Proofs_verified_max.t =\n T\n { p with\n statement =\n { p.statement with\n proof_state =\n { p.statement.proof_state with\n messages_for_next_wrap_proof =\n { p.statement.proof_state.messages_for_next_wrap_proof with\n old_bulletproof_challenges =\n pad_vector\n p.statement.proof_state.messages_for_next_wrap_proof\n .old_bulletproof_challenges\n ~dummy:Dummy.Ipa.Wrap.challenges\n }\n }\n }\n }\n\nmodule Checked = struct\n let pad_challenges (chalss : (_ Vector.t, _) Vector.t) =\n pad_vector\n ~dummy:\n (Vector.map ~f:Impls.Wrap.Field.constant\n (Lazy.force Dummy.Ipa.Wrap.challenges_computed) )\n chalss\n\n let pad_commitments (commitments : _ Vector.t) =\n pad_vector\n ~dummy:\n (Tuple_lib.Double.map ~f:Impls.Step.Field.constant\n (Lazy.force Dummy.Ipa.Wrap.sg) )\n commitments\n\n (* We precompute the sponge states that would result from absorbing\n 0, 1, or 2 dummy challenge vectors. This is used to speed up hashing\n inside the circuit. *)\n let dummy_messages_for_next_wrap_proof_sponge_states =\n lazy\n (let module S = Tock_field_sponge.Field in\n let full_state s = (S.state s, s.sponge_state) in\n let sponge = S.create Tock_field_sponge.params in\n let s0 = full_state sponge in\n let chals = Lazy.force Dummy.Ipa.Wrap.challenges_computed in\n Vector.iter ~f:(S.absorb sponge) chals ;\n let s1 = full_state sponge in\n Vector.iter ~f:(S.absorb sponge) chals ;\n let s2 = full_state sponge in\n [| s0; s1; s2 |] )\n\n let hash_constant_messages_for_next_wrap_proof =\n hash_messages_for_next_wrap_proof\n\n (* TODO: No need to hash the entire bulletproof challenges. Could\n just hash the segment of the public input LDE corresponding to them\n that we compute when verifying the previous proof. That is a commitment\n to them. *)\n let hash_messages_for_next_wrap_proof (type n) (max_proofs_verified : n Nat.t)\n (t :\n ( Wrap_main_inputs.Inner_curve.t\n , ((Impls.Wrap.Field.t, Backend.Tock.Rounds.n) Vector.t, n) Vector.t )\n Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof.t ) =\n let open Wrap_main_inputs in\n let sponge =\n (* The sponge states we would reach if we absorbed the padding challenges *)\n let s = Sponge.create sponge_params in\n let state, sponge_state =\n (Lazy.force dummy_messages_for_next_wrap_proof_sponge_states).(2\n - Nat\n .to_int\n max_proofs_verified)\n in\n { s with\n state = Array.map state ~f:Impls.Wrap.Field.constant\n ; sponge_state\n }\n in\n Array.iter ~f:(Sponge.absorb sponge)\n (Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof\n .to_field_elements ~g1:Inner_curve.to_field_elements t ) ;\n Sponge.squeeze_field sponge\n\n (* Check that the pre-absorbing technique works. I.e., that it's consistent with\n the actual definition of hash_messages_for_next_wrap_proof. *)\n let%test_unit \"hash_messages_for_next_wrap_proof correct\" =\n let open Impls.Wrap in\n let test (type n) (n : n Nat.t) =\n let messages_for_next_wrap_proof :\n _ Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof.t =\n let g = Wrap_main_inputs.Inner_curve.Constant.random () in\n { Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof\n .challenge_polynomial_commitment = g\n ; old_bulletproof_challenges =\n Vector.init n ~f:(fun _ ->\n Vector.init Tock.Rounds.n ~f:(fun _ -> Tock.Field.random ()) )\n }\n in\n Internal_Basic.Test.test_equal ~sexp_of_t:Field.Constant.sexp_of_t\n ~equal:Field.Constant.equal\n (Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof.typ\n Wrap_main_inputs.Inner_curve.typ\n (Vector.typ Field.typ Backend.Tock.Rounds.n)\n ~length:n )\n Field.typ\n (fun t -> make_checked (fun () -> hash_messages_for_next_wrap_proof n t))\n (fun t ->\n hash_constant_messages_for_next_wrap_proof n t\n |> Digest.Constant.to_bits |> Impls.Wrap.Field.Constant.project )\n messages_for_next_wrap_proof\n in\n test Nat.N0.n ; test Nat.N1.n ; test Nat.N2.n\nend\n","open Pickles_types\nopen Import\nopen Backend\n\ntype dlog_opening = (Tock.Curve.Affine.t, Tock.Field.t) Types.Step.Bulletproof.t\n\nmodule Constant = struct\n (* Out-of-circuit type for wrap proofs *)\n type t =\n { messages : Tock.Curve.Affine.t Plonk_types.Messages.t\n ; opening : dlog_opening\n }\n [@@deriving hlist]\nend\n\nopen Step_main_inputs\n\nmodule Checked = struct\n (* In-circuit type for wrap proofs *)\n type t =\n { messages :\n (Inner_curve.t, Impl.Boolean.var) Plonk_types.Messages.In_circuit.t\n ; opening :\n ( Inner_curve.t\n , Impls.Step.Other_field.t Shifted_value.Type2.t )\n Types.Step.Bulletproof.t\n }\n [@@deriving hlist]\nend\n\nopen Impls.Step\n\nlet typ : (Checked.t, Constant.t) Typ.t =\n let shift = Shifted_value.Type2.Shift.create (module Tock.Field) in\n Typ.of_hlistable ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:Constant.to_hlist ~value_of_hlist:Constant.of_hlist\n [ Plonk_types.Messages.typ\n (module Impl)\n Inner_curve.typ Plonk_types.Features.Full.none ~bool:Boolean.typ\n ~dummy:Inner_curve.Params.one\n ~commitment_lengths:Commitment_lengths.default\n ; Types.Step.Bulletproof.typ ~length:(Nat.to_int Tock.Rounds.n)\n ( Typ.transport Other_field.typ\n ~there:(fun x ->\n (* When storing, make it a shifted value *)\n match\n Shifted_value.Type2.of_field (module Tock.Field) ~shift x\n with\n | Shifted_value x ->\n x )\n ~back:(fun x ->\n Shifted_value.Type2.to_field\n (module Tock.Field)\n ~shift (Shifted_value x) )\n (* When reading, unshift *)\n |> Typ.transport_var\n (* For the var, we just wrap the now shifted underlying value. *)\n ~there:(fun (Shifted_value.Type2.Shifted_value x) -> x)\n ~back:(fun x -> Shifted_value x) )\n Inner_curve.typ\n ]\n","open Core_kernel\n\ntype ('var, 'value, 'n1, 'n2) id = ('var * 'value * 'n1 * 'n2) Type_equal.Id.t\n\ntype kind = Side_loaded | Compiled\n\ntype ('var, 'value, 'n1, 'n2) t =\n { kind : kind; id : ('var, 'value, 'n1, 'n2) id }\n[@@deriving fields]\n\nlet create ?(kind = Compiled) name =\n { kind; id = Type_equal.Id.create ~name sexp_of_opaque }\n","open Pickles_types.Poly_types\nopen Pickles_types.Hlist\n\nmodule B = struct\n type t = Impls.Step.Boolean.var\nend\n\nmodule Previous_proof_statement = struct\n type ('prev_var, 'width) t =\n { public_input : 'prev_var\n ; proof : ('width, 'width) Proof.t Impls.Step.As_prover.Ref.t\n ; proof_must_verify : B.t\n }\n\n module Constant = struct\n type ('prev_value, 'width) t =\n { public_input : 'prev_value\n ; proof : ('width, 'width) Proof.t\n ; proof_must_verify : bool\n }\n end\nend\n\n(** This type relates the types of the input and output types of an inductive\n rule's [main] function to the type of the public input to the resulting\n circuit.\n*)\ntype ('var, 'value, 'input_var, 'input_value, 'ret_var, 'ret_value) public_input =\n | Input :\n ('var, 'value) Impls.Step.Typ.t\n -> ('var, 'value, 'var, 'value, unit, unit) public_input\n | Output :\n ('ret_var, 'ret_value) Impls.Step.Typ.t\n -> ('ret_var, 'ret_value, unit, unit, 'ret_var, 'ret_value) public_input\n | Input_and_output :\n ('var, 'value) Impls.Step.Typ.t * ('ret_var, 'ret_value) Impls.Step.Typ.t\n -> ( 'var * 'ret_var\n , 'value * 'ret_value\n , 'var\n , 'value\n , 'ret_var\n , 'ret_value )\n public_input\n\n(** The input type of an inductive rule's main function. *)\ntype 'public_input main_input =\n { public_input : 'public_input\n (** The publicly-exposed input to the circuit's main function. *)\n }\n\n(** The return type of an inductive rule's main function. *)\ntype ('prev_vars, 'widths, 'public_output, 'auxiliary_output) main_return =\n { previous_proof_statements :\n ('prev_vars, 'widths) H2.T(Previous_proof_statement).t\n (** A list of booleans, determining whether each previous proof must\n verify.\n *)\n ; public_output : 'public_output\n (** The publicly-exposed output from the circuit's main function. *)\n ; auxiliary_output : 'auxiliary_output\n (** The auxiliary output from the circuit's main function. This value\n is returned to the prover, but not exposed to or used by verifiers.\n *)\n }\n\n(** This type models an \"inductive rule\". It includes\n - the list of previous statements which this one assumes\n - the snarky main function\n\n The types parameters are:\n - ['prev_vars] the tuple-list of public input circuit types to the previous\n proofs.\n - For example, [Boolean.var * (Boolean.var * unit)] represents 2 previous\n proofs whose public inputs are booleans\n - ['prev_values] the tuple-list of public input non-circuit types to the\n previous proofs.\n - For example, [bool * (bool * unit)] represents 2 previous proofs whose\n public inputs are booleans.\n - ['widths] is a tuple list of the maximum number of previous proofs each\n previous proof itself had.\n - For example, [Nat.z Nat.s * (Nat.z * unit)] represents 2 previous\n proofs where the first has at most 1 previous proof and the second had\n zero previous proofs.\n - ['heights] is a tuple list of the number of inductive rules in each of\n the previous proofs\n - For example, [Nat.z Nat.s Nat.s * (Nat.z Nat.s * unit)] represents 2\n previous proofs where the first had 2 inductive rules and the second\n had 1.\n - ['a_var] is the in-circuit type of the [main] function's public input.\n - ['a_value] is the out-of-circuit type of the [main] function's public\n input.\n - ['ret_var] is the in-circuit type of the [main] function's public output.\n - ['ret_value] is the out-of-circuit type of the [main] function's public\n output.\n - ['auxiliary_var] is the in-circuit type of the [main] function's\n auxiliary data, to be returned to the prover but not exposed in the\n public input.\n - ['auxiliary_value] is the out-of-circuit type of the [main] function's\n auxiliary data, to be returned to the prover but not exposed in the\n public input.\n*)\ntype ( 'prev_vars\n , 'prev_values\n , 'widths\n , 'heights\n , 'a_var\n , 'a_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n t =\n { identifier : string\n ; prevs : ('prev_vars, 'prev_values, 'widths, 'heights) H4.T(Tag).t\n ; main :\n 'a_var main_input\n -> ('prev_vars, 'widths, 'ret_var, 'auxiliary_var) main_return\n ; feature_flags : bool Pickles_types.Plonk_types.Features.t\n }\n\nmodule T\n (Statement : T0)\n (Statement_value : T0)\n (Return_var : T0)\n (Return_value : T0)\n (Auxiliary_var : T0)\n (Auxiliary_value : T0) =\nstruct\n type nonrec ('prev_vars, 'prev_values, 'widths, 'heights) t =\n ( 'prev_vars\n , 'prev_values\n , 'widths\n , 'heights\n , Statement.t\n , Statement_value.t\n , Return_var.t\n , Return_value.t\n , Auxiliary_var.t\n , Auxiliary_value.t )\n t\nend\n","open Core_kernel\nopen Pickles_types\nopen Import\nopen Backend\n\n(* We maintain a global hash table which stores for each inductive proof system some\n data.\n*)\ntype inner_curve_var =\n Tick.Field.t Snarky_backendless.Cvar.t\n * Tick.Field.t Snarky_backendless.Cvar.t\n\nmodule Basic = struct\n type ('var, 'value, 'n1, 'n2) t =\n { max_proofs_verified : (module Nat.Add.Intf with type n = 'n1)\n ; public_input : ('var, 'value) Impls.Step.Typ.t\n ; branches : 'n2 Nat.t\n ; wrap_domains : Domains.t\n ; wrap_key : Tick.Inner_curve.Affine.t Plonk_verification_key_evals.t\n ; wrap_vk : Impls.Wrap.Verification_key.t\n ; feature_flags : Opt.Flag.t Plonk_types.Features.Full.t\n }\nend\n\nmodule Side_loaded = struct\n module Ephemeral = struct\n type t =\n { index :\n [ `In_circuit of Side_loaded_verification_key.Checked.t\n | `In_prover of Side_loaded_verification_key.t\n | `In_both of\n Side_loaded_verification_key.t\n * Side_loaded_verification_key.Checked.t ]\n }\n end\n\n module Permanent = struct\n type ('var, 'value, 'n1, 'n2) t =\n { max_proofs_verified : (module Nat.Add.Intf with type n = 'n1)\n ; public_input : ('var, 'value) Impls.Step.Typ.t\n ; feature_flags : Opt.Flag.t Plonk_types.Features.Full.t\n ; branches : 'n2 Nat.t\n }\n end\n\n type ('var, 'value, 'n1, 'n2) t =\n { ephemeral : Ephemeral.t option\n ; permanent : ('var, 'value, 'n1, 'n2) Permanent.t\n }\n\n type packed =\n | T : ('var, 'value, 'n1, 'n2) Tag.id * ('var, 'value, 'n1, 'n2) t -> packed\n\n let to_basic\n { permanent =\n { max_proofs_verified; public_input; branches; feature_flags }\n ; ephemeral\n } =\n let wrap_key, wrap_vk =\n match ephemeral with\n | Some { index = `In_prover i | `In_both (i, _) } ->\n (i.wrap_index, i.wrap_vk)\n | _ ->\n failwithf \"Side_loaded.to_basic: Expected `In_prover (%s)\" __LOC__ ()\n in\n let proofs_verified = Nat.to_int (Nat.Add.n max_proofs_verified) in\n let wrap_vk = Option.value_exn ~here:[%here] wrap_vk in\n { Basic.max_proofs_verified\n ; wrap_vk\n ; public_input\n ; branches\n ; wrap_domains = Common.wrap_domains ~proofs_verified\n ; wrap_key\n ; feature_flags\n }\nend\n\nmodule Compiled = struct\n type ('a_var, 'a_value, 'max_proofs_verified, 'branches) basic =\n { public_input : ('a_var, 'a_value) Impls.Step.Typ.t\n ; proofs_verifieds : (int, 'branches) Vector.t\n (* For each branch in this rule, how many predecessor proofs does it have? *)\n ; wrap_domains : Domains.t\n ; step_domains : (Domains.t, 'branches) Vector.t\n ; feature_flags : Opt.Flag.t Plonk_types.Features.Full.t\n }\n\n (* This is the data associated to an inductive proof system with statement type\n ['a_var], which has ['branches] many \"variants\" each of which depends on at most\n ['max_proofs_verified] many previous statements. *)\n type ('a_var, 'a_value, 'max_proofs_verified, 'branches) t =\n { branches : 'branches Nat.t\n ; max_proofs_verified :\n (module Nat.Add.Intf with type n = 'max_proofs_verified)\n ; proofs_verifieds : (int, 'branches) Vector.t\n (* For each branch in this rule, how many predecessor proofs does it have? *)\n ; public_input : ('a_var, 'a_value) Impls.Step.Typ.t\n ; wrap_key : Tick.Inner_curve.Affine.t Plonk_verification_key_evals.t Lazy.t\n ; wrap_vk : Impls.Wrap.Verification_key.t Lazy.t\n ; wrap_domains : Domains.t\n ; step_domains : (Domains.t, 'branches) Vector.t\n ; feature_flags : Opt.Flag.t Plonk_types.Features.Full.t\n }\n\n type packed =\n | T : ('var, 'value, 'n1, 'n2) Tag.id * ('var, 'value, 'n1, 'n2) t -> packed\n\n let to_basic\n { branches = _\n ; max_proofs_verified\n ; proofs_verifieds = _\n ; public_input\n ; wrap_vk\n ; wrap_domains\n ; step_domains\n ; wrap_key\n ; feature_flags\n } =\n { Basic.max_proofs_verified\n ; wrap_domains\n ; public_input\n ; branches = Vector.length step_domains\n ; wrap_key = Lazy.force wrap_key\n ; wrap_vk = Lazy.force wrap_vk\n ; feature_flags\n }\nend\n\nmodule For_step = struct\n type ('a_var, 'a_value, 'max_proofs_verified, 'branches) t =\n { branches : 'branches Nat.t\n ; max_proofs_verified :\n (module Nat.Add.Intf with type n = 'max_proofs_verified)\n ; proofs_verifieds :\n [ `Known of (Impls.Step.Field.t, 'branches) Vector.t | `Side_loaded ]\n ; public_input : ('a_var, 'a_value) Impls.Step.Typ.t\n ; wrap_key : inner_curve_var Plonk_verification_key_evals.t\n ; wrap_domain :\n [ `Known of Domain.t\n | `Side_loaded of\n Impls.Step.field Pickles_base.Proofs_verified.One_hot.Checked.t ]\n ; step_domains : [ `Known of (Domains.t, 'branches) Vector.t | `Side_loaded ]\n ; feature_flags : Opt.Flag.t Plonk_types.Features.Full.t\n }\n\n let of_side_loaded (type a b c d)\n ({ ephemeral\n ; permanent =\n { branches; max_proofs_verified; public_input; feature_flags }\n } :\n (a, b, c, d) Side_loaded.t ) : (a, b, c, d) t =\n let index =\n match ephemeral with\n | Some { index = `In_circuit i | `In_both (_, i) } ->\n i\n | _ ->\n failwithf \"For_step.side_loaded: Expected `In_circuit (%s)\" __LOC__ ()\n in\n let T = Nat.eq_exn branches Side_loaded_verification_key.Max_branches.n in\n { branches\n ; max_proofs_verified\n ; public_input\n ; proofs_verifieds = `Side_loaded\n ; wrap_key = index.wrap_index\n ; wrap_domain = `Side_loaded index.actual_wrap_domain_size\n ; step_domains = `Side_loaded\n ; feature_flags\n }\n\n let of_compiled\n ({ branches\n ; max_proofs_verified\n ; proofs_verifieds\n ; public_input\n ; wrap_key\n ; wrap_domains\n ; step_domains\n ; feature_flags\n ; wrap_vk = _\n } :\n _ Compiled.t ) =\n { branches\n ; max_proofs_verified\n ; proofs_verifieds =\n `Known (Vector.map proofs_verifieds ~f:Impls.Step.Field.of_int)\n ; public_input\n ; wrap_key =\n Plonk_verification_key_evals.map (Lazy.force wrap_key)\n ~f:Step_main_inputs.Inner_curve.constant\n ; wrap_domain = `Known wrap_domains.h\n ; step_domains = `Known step_domains\n ; feature_flags\n }\nend\n\ntype t =\n { compiled : Compiled.packed Type_equal.Id.Uid.Table.t\n ; side_loaded : Side_loaded.packed Type_equal.Id.Uid.Table.t\n }\n\nlet univ : t =\n { compiled = Type_equal.Id.Uid.Table.create ()\n ; side_loaded = Type_equal.Id.Uid.Table.create ()\n }\n\nlet find t k =\n match Hashtbl.find t k with None -> failwith \"key not found\" | Some x -> x\n\nlet lookup_compiled :\n type var value n m.\n (var, value, n, m) Tag.id -> (var, value, n, m) Compiled.t =\n fun t ->\n let (T (other_id, d)) = find univ.compiled (Type_equal.Id.uid t) in\n let T = Type_equal.Id.same_witness_exn t other_id in\n d\n\nlet lookup_side_loaded :\n type var value n m.\n (var, value, n, m) Tag.id -> (var, value, n, m) Side_loaded.t =\n fun t ->\n let (T (other_id, d)) = find univ.side_loaded (Type_equal.Id.uid t) in\n let T = Type_equal.Id.same_witness_exn t other_id in\n d\n\nlet lookup_basic :\n type var value n m. (var, value, n, m) Tag.t -> (var, value, n, m) Basic.t =\n fun t ->\n match t.kind with\n | Compiled ->\n Compiled.to_basic (lookup_compiled t.id)\n | Side_loaded ->\n Side_loaded.to_basic (lookup_side_loaded t.id)\n\nlet max_proofs_verified :\n type n1. (_, _, n1, _) Tag.t -> (module Nat.Add.Intf with type n = n1) =\n fun tag ->\n match tag.kind with\n | Compiled ->\n (lookup_compiled tag.id).max_proofs_verified\n | Side_loaded ->\n (lookup_side_loaded tag.id).permanent.max_proofs_verified\n\nlet public_input :\n type var value. (var, value, _, _) Tag.t -> (var, value) Impls.Step.Typ.t =\n fun tag ->\n match tag.kind with\n | Compiled ->\n (lookup_compiled tag.id).public_input\n | Side_loaded ->\n (lookup_side_loaded tag.id).permanent.public_input\n\nlet feature_flags :\n type var value.\n (var, value, _, _) Tag.t -> Opt.Flag.t Plonk_types.Features.Full.t =\n fun tag ->\n match tag.kind with\n | Compiled ->\n (lookup_compiled tag.id).feature_flags\n | Side_loaded ->\n (lookup_side_loaded tag.id).permanent.feature_flags\n\nlet _value_to_field_elements :\n type a. (_, a, _, _) Tag.t -> a -> Backend.Tick.Field.t array =\n fun t ->\n let (Typ typ) = public_input t in\n fun x -> fst (typ.value_to_fields x)\n\nlet _lookup_map (type var value c d) (t : (var, value, c, d) Tag.t) ~self\n ~default\n ~(f :\n [ `Compiled of (var, value, c, d) Compiled.t\n | `Side_loaded of (var, value, c, d) Side_loaded.t ]\n -> _ ) =\n match Type_equal.Id.same_witness t.id self with\n | Some _ ->\n default\n | None -> (\n match t.kind with\n | Compiled ->\n let (T (other_id, d)) = find univ.compiled (Type_equal.Id.uid t.id) in\n let T = Type_equal.Id.same_witness_exn t.id other_id in\n f (`Compiled d)\n | Side_loaded ->\n let (T (other_id, d)) =\n find univ.side_loaded (Type_equal.Id.uid t.id)\n in\n let T = Type_equal.Id.same_witness_exn t.id other_id in\n f (`Side_loaded d) )\n\nlet add_side_loaded ~name permanent =\n let (Tag.{ id; _ } as tag) = Tag.(create ~kind:Side_loaded name) in\n Hashtbl.add_exn univ.side_loaded ~key:(Type_equal.Id.uid id)\n ~data:(T (id, { ephemeral = None; permanent })) ;\n tag\n\nlet set_ephemeral { Tag.kind; id } (eph : Side_loaded.Ephemeral.t) =\n assert (match kind with Side_loaded -> true | Compiled -> false) ;\n Hashtbl.update univ.side_loaded (Type_equal.Id.uid id) ~f:(function\n | None ->\n assert false\n | Some (T (id, d)) ->\n let ephemeral =\n match (d.ephemeral, eph.index) with\n | None, _ | Some _, `In_prover _ ->\n (* Giving prover only always resets. *)\n Some eph\n | Some { index = `In_prover prover }, `In_circuit circuit\n | Some { index = `In_both (prover, _) }, `In_circuit circuit ->\n (* In-circuit extends prover if one was given. *)\n Some { index = `In_both (prover, circuit) }\n | _ ->\n (* Otherwise, just use the given value. *)\n Some eph\n in\n T (id, { d with ephemeral }) )\n\nlet add_exn (type var value c d) (tag : (var, value, c, d) Tag.t)\n (data : (var, value, c, d) Compiled.t) =\n Hashtbl.add_exn univ.compiled ~key:(Type_equal.Id.uid tag.id)\n ~data:(Compiled.T (tag.id, data))\n","open Backend\nopen Pickles_types\nopen Import\nmodule Impl = Impls.Step\nmodule One_hot_vector = One_hot_vector.Make (Impl)\n\n(* Let F, K be the two fields (either (Fp, Fq) or (Fq, Fp)).\n Each proof over F has an accumulator state which contains\n - a set of IPA challenges c_0, ..., c_{k-1}, which can be interpreted as F elements.\n - a polynomial commitment challenge_polynomial_commitment, which has coordinates in K.\n\n This part of the accumulator state is finalized by checking that challenge_polynomial_commitment\n is a commitment to the polynomial\n\n f_c := prod_{i = 0}^{k-1} (1 + c_i x^{2^{k-1 - i}})\n\n When incrementally-verifying such a proof in a K-circuit (since we need K-arithmetic to perform\n the group operations on the F-polynomial-commitments that constitute the proof),\n instead of checking this, we get an evaluation E_c at a random point zeta and check\n that challenge_polynomial_commitment opens to E_c at zeta. Then we will need to check that\n E_c = f_c(zeta) = prod_{i = 0}^{k-1} (1 + c_i zeta^{2^{k-1 - i}}).\n\n However, because we are then in a K-circuit, we cannot actually compute f_c(zeta), which requires\n F-arithmetic.\n\n Therefore, after incrementally verifying the F-proof, the challenges (c_0, ..., c_{k-1}) which are\n part of the accumulator of the F-proof we just incrementally verified, must remain part of\n the accumulator of the K-proof, along with E_c (or at least some kind of commitment to it, which is\n what we actually do).\n\n Then, when we incrementally verify that K-proof in an F-circuit, we will check that E_c was\n computed correctly using c_0, ..., c_{k-1} and they along with E_c can be discarded.\n\n So, to summarize, the accumulator state for each proof P (corresponding to an F-circuit)\n contains\n - a set of IPA challenges (thought of as K-elements) for every proof that it incrementally verified inside its circuit\n - a challenge_polynomial_commitment (coordinates in F) for every proof that it incrementally verified inside its circuit\n - a challenge_polynomial_commitment (coordinates in K) corresponding to P's own inner-product argument\n - a set of IPA challenges (thought of as F-elements) corresponding to P's own inner-product argument\n*)\n\ntype challenge = Challenge.Make(Impl).t\n\ntype scalar_challenge = challenge Scalar_challenge.t\n\n(** Represents a proof (along with its accumulation state) which wraps a\n \"step\" proof S on the other curve.\n\n To have some notation, the proof S itself comes from a circuit that verified\n up to 'max_proofs_verified many wrap proofs W_0, ..., W_max_proofs_verified.\n*)\ntype ('app_state, 'max_proofs_verified, 'num_branches) t =\n { app_state : 'app_state\n (** The user-level statement corresponding to this proof. *)\n ; wrap_proof : Wrap_proof.Checked.t\n (** The polynomial commitments, polynomial evaluations, and opening proof corresponding to\n this latest wrap proof.\n *)\n ; proof_state :\n ( challenge\n , scalar_challenge\n , Impl.Field.t Shifted_value.Type1.t\n , ( Impl.Field.t Pickles_types.Shifted_value.Type1.t\n , Impl.Boolean.var )\n Opt.t\n , (scalar_challenge, Impl.Boolean.var) Opt.t\n , Impl.Boolean.var\n , unit\n , Digest.Make(Impl).t\n , scalar_challenge Types.Bulletproof_challenge.t Types.Step_bp_vec.t\n , Impl.field Branch_data.Checked.t )\n Types.Wrap.Proof_state.In_circuit.t\n (** The accumulator state corresponding to the above proof. Contains\n - `deferred_values`: The values necessary for finishing the deferred \"scalar field\" computations.\n That is, computations which are over the \"step\" circuit's internal field that the\n previous \"wrap\" circuit was unable to verify directly, due to its internal field\n being different.\n - `sponge_digest_before_evaluations`: the sponge state: TODO\n - `messages_for_next_wrap_proof`\n *)\n ; prev_proof_evals :\n ( Impl.Field.t\n , Impl.Field.t array\n , Impl.Boolean.var )\n Plonk_types.All_evals.In_circuit.t\n (** The evaluations from the step proof that this proof wraps *)\n ; prev_challenges :\n ((Impl.Field.t, Tick.Rounds.n) Vector.t, 'max_proofs_verified) Vector.t\n (** The challenges c_0, ... c_{k - 1} corresponding to each W_i. *)\n ; prev_challenge_polynomial_commitments :\n (Step_main_inputs.Inner_curve.t, 'max_proofs_verified) Vector.t\n (** The commitments to the \"challenge polynomials\" \\prod_{i = 0}^k (1 + c_{k - 1 - i} x^{2^i})\n corresponding to each of the \"prev_challenges\".\n *)\n }\n[@@deriving hlist]\n\nmodule No_app_state = struct\n type nonrec (_, 'max_proofs_verified, 'num_branches) t =\n (unit, 'max_proofs_verified, 'num_branches) t\nend\n\nmodule Constant = struct\n type challenge = Challenge.Constant.t\n\n type scalar_challenge = challenge Scalar_challenge.t\n\n type ('statement, 'max_proofs_verified) t =\n { app_state : 'statement\n ; wrap_proof : Wrap_proof.Constant.t\n ; proof_state :\n ( challenge\n , scalar_challenge\n , Tick.Field.t Shifted_value.Type1.t\n , Tick.Field.t Shifted_value.Type1.t option\n , scalar_challenge option\n , bool\n , unit\n , Digest.Constant.t\n , scalar_challenge Types.Bulletproof_challenge.t Types.Step_bp_vec.t\n , Branch_data.t )\n Types.Wrap.Proof_state.In_circuit.t\n ; prev_proof_evals :\n (Tick.Field.t, Tick.Field.t array) Plonk_types.All_evals.t\n ; prev_challenges :\n ((Tick.Field.t, Tick.Rounds.n) Vector.t, 'max_proofs_verified) Vector.t\n ; prev_challenge_polynomial_commitments :\n (Tick.Inner_curve.Affine.t, 'max_proofs_verified) Vector.t\n }\n [@@deriving hlist]\n\n module No_app_state = struct\n type nonrec (_, 'max_proofs_verified, _) t = (unit, 'max_proofs_verified) t\n end\nend\n\nlet typ (type n avar aval) ~feature_flags\n (statement : (avar, aval) Impls.Step.Typ.t) (max_proofs_verified : n Nat.t)\n =\n let module Sc = Scalar_challenge in\n let open Impls.Step in\n let open Step_main_inputs in\n let open Step_verifier in\n Snarky_backendless.Typ.of_hlistable ~var_to_hlist:to_hlist\n ~var_of_hlist:of_hlist ~value_to_hlist:Constant.to_hlist\n ~value_of_hlist:Constant.of_hlist\n [ statement\n ; Wrap_proof.typ\n ; Types.Wrap.Proof_state.In_circuit.typ\n (module Impl)\n ~challenge:Challenge.typ ~scalar_challenge:Challenge.typ ~feature_flags\n ~dummy_scalar_challenge:(Sc.create Limb_vector.Challenge.Constant.zero)\n (Shifted_value.Type1.typ Field.typ)\n (Snarky_backendless.Typ.unit ())\n Digest.typ\n (Branch_data.typ\n (module Impl)\n ~assert_16_bits:(Step_verifier.assert_n_bits ~n:16) )\n ; Plonk_types.All_evals.typ\n (module Impl)\n (* Assume we have lookup iff we have runtime tables *)\n feature_flags\n ; Vector.typ (Vector.typ Field.typ Tick.Rounds.n) max_proofs_verified\n ; Vector.typ Inner_curve.typ max_proofs_verified\n ]\n","open Core_kernel\nopen Backend\nopen Impls.Step\nopen Pickles_types\nopen Common\nopen Import\nmodule Shifted_value = Shifted_value.Type2\n\n(* Unfinalized dlog-based proof, along with a flag which is true iff it\n is expected to verify. This allows for situations like the blockchain\n SNARK where we let the previous proof fail in the base case.\n*)\ntype t =\n ( Field.t\n , Field.t Scalar_challenge.t\n , Other_field.t Shifted_value.t\n , ( Field.t Scalar_challenge.t Bulletproof_challenge.t\n , Tock.Rounds.n )\n Pickles_types.Vector.t\n , Field.t\n , Boolean.var )\n Types.Step.Proof_state.Per_proof.In_circuit.t\n\nmodule Plonk_checks = struct\n include Plonk_checks\n include Plonk_checks.Make (Shifted_value) (Plonk_checks.Scalars.Tock)\nend\n\nmodule Constant = struct\n type t =\n ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Tock.Field.t Shifted_value.t\n , ( Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n , Tock.Rounds.n )\n Vector.t\n , Digest.Constant.t\n , bool )\n Types.Step.Proof_state.Per_proof.In_circuit.t\n\n let shift = Shifted_value.Shift.create (module Tock.Field)\n\n let dummy : t Lazy.t =\n lazy\n (let one_chal = Challenge.Constant.dummy in\n let open Ro in\n let alpha = scalar_chal () in\n let beta = chal () in\n let gamma = chal () in\n let zeta = scalar_chal () in\n let chals :\n _ Composition_types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.t\n =\n { alpha = Common.Ipa.Wrap.endo_to_field alpha\n ; beta = Challenge.Constant.to_tock_field beta\n ; gamma = Challenge.Constant.to_tock_field gamma\n ; zeta = Common.Ipa.Wrap.endo_to_field zeta\n ; joint_combiner = None\n ; feature_flags = Plonk_types.Features.none_bool\n }\n in\n let evals =\n Plonk_types.Evals.to_in_circuit\n (Lazy.force Dummy.evals_combined).evals.evals\n in\n let env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tock.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~srs_length_log2:Common.Max_degree.wrap_log2\n ~endo:Endo.Wrap_inner_curve.base ~mds:Tock_field_sponge.params.mds\n ~field_of_hex:\n (Core_kernel.Fn.compose Tock.Field.of_bigint (fun x ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string x ) )\n ~domain:\n (Plonk_checks.domain\n (module Tock.Field)\n (wrap_domains ~proofs_verified:2).h ~shifts:Common.tock_shifts\n ~domain_generator:Tock.Field.domain_generator )\n chals evals\n in\n let plonk =\n let module Field = struct\n include Tock.Field\n end in\n Plonk_checks.derive_plonk (module Field) ~env ~shift chals evals\n |> Composition_types.Step.Proof_state.Deferred_values.Plonk.In_circuit\n .of_wrap\n ~assert_none:(fun x -> assert (Option.is_none (Opt.to_option x)))\n ~assert_false:(fun x -> assert (not x))\n in\n { deferred_values =\n { plonk = { plonk with alpha; beta; gamma; zeta }\n ; combined_inner_product = Shifted_value (tock ())\n ; xi = Scalar_challenge.create one_chal\n ; bulletproof_challenges = Dummy.Ipa.Wrap.challenges\n ; b = Shifted_value (tock ())\n }\n ; should_finalize = false\n ; sponge_digest_before_evaluations = Digest.Constant.dummy\n } )\nend\n\nlet typ ~wrap_rounds:_ : (t, Constant.t) Typ.t =\n Types.Step.Proof_state.Per_proof.typ\n (module Impl)\n (Shifted_value.typ Other_field.typ)\n ~assert_16_bits:(Step_verifier.assert_n_bits ~n:16)\n\nlet dummy : unit -> t =\n Memo.unit (fun () ->\n let (Typ { var_of_fields; value_to_fields; _ }) =\n typ ~wrap_rounds:Backend.Tock.Rounds.n\n in\n let xs, aux = value_to_fields (Lazy.force Constant.dummy) in\n var_of_fields (Array.map ~f:Field.constant xs, aux) )\n","open Import\nopen Types\nopen Pickles_types\nopen Hlist\nopen Snarky_backendless.Request\nopen Backend\n\nmodule Wrap = struct\n module type S = sig\n type max_proofs_verified\n\n type max_local_max_proofs_verifieds\n\n open Impls.Wrap\n open Snarky_backendless.Request\n\n type _ t +=\n | Evals :\n ( (Field.Constant.t, Field.Constant.t array) Plonk_types.All_evals.t\n , max_proofs_verified )\n Vector.t\n t\n | Which_branch : int t\n | Step_accs : (Tock.Inner_curve.Affine.t, max_proofs_verified) Vector.t t\n | Old_bulletproof_challenges :\n max_local_max_proofs_verifieds H1.T(Challenges_vector.Constant).t t\n | Proof_state :\n ( ( ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Field.Constant.t Shifted_value.Type2.t\n , ( Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n , Tock.Rounds.n )\n Vector.t\n , Digest.Constant.t\n , bool )\n Types.Step.Proof_state.Per_proof.In_circuit.t\n , max_proofs_verified )\n Vector.t\n , Digest.Constant.t )\n Types.Step.Proof_state.t\n t\n | Messages : Tock.Inner_curve.Affine.t Plonk_types.Messages.t t\n | Openings_proof :\n ( Tock.Inner_curve.Affine.t\n , Tick.Field.t )\n Plonk_types.Openings.Bulletproof.t\n t\n | Wrap_domain_indices : (Field.Constant.t, max_proofs_verified) Vector.t t\n end\n\n type ('mb, 'ml) t =\n (module S\n with type max_proofs_verified = 'mb\n and type max_local_max_proofs_verifieds = 'ml )\n\n let create : type mb ml. unit -> (mb, ml) t =\n fun () ->\n let module R = struct\n type nonrec max_proofs_verified = mb\n\n type nonrec max_local_max_proofs_verifieds = ml\n\n open Snarky_backendless.Request\n\n type 'a vec = ('a, max_proofs_verified) Vector.t\n\n type _ t +=\n | Evals :\n (Tock.Field.t, Tock.Field.t array) Plonk_types.All_evals.t vec t\n | Which_branch : int t\n | Step_accs : Tock.Inner_curve.Affine.t vec t\n | Old_bulletproof_challenges :\n max_local_max_proofs_verifieds H1.T(Challenges_vector.Constant).t t\n | Proof_state :\n ( ( ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Tock.Field.t Shifted_value.Type2.t\n , ( Challenge.Constant.t Scalar_challenge.t\n Bulletproof_challenge.t\n , Tock.Rounds.n )\n Vector.t\n , Digest.Constant.t\n , bool )\n Types.Step.Proof_state.Per_proof.In_circuit.t\n , max_proofs_verified )\n Vector.t\n , Digest.Constant.t )\n Types.Step.Proof_state.t\n t\n | Messages : Tock.Inner_curve.Affine.t Plonk_types.Messages.t t\n | Openings_proof :\n ( Tock.Inner_curve.Affine.t\n , Tick.Field.t )\n Plonk_types.Openings.Bulletproof.t\n t\n | Wrap_domain_indices : (Tock.Field.t, max_proofs_verified) Vector.t t\n end in\n (module R)\nend\n\nmodule Step = struct\n module type S = sig\n type statement\n\n type return_value\n\n type prev_values\n\n type proofs_verified\n\n (* TODO: As an optimization this can be the local proofs-verified size *)\n type max_proofs_verified\n\n type local_signature\n\n type local_branches\n\n type auxiliary_value\n\n type _ t +=\n | Compute_prev_proof_parts :\n ( prev_values\n , local_signature )\n H2.T(Inductive_rule.Previous_proof_statement.Constant).t\n -> unit t\n | Proof_with_datas :\n ( prev_values\n , local_signature\n , local_branches )\n H3.T(Per_proof_witness.Constant.No_app_state).t\n t\n | Wrap_index : Tock.Curve.Affine.t Plonk_verification_key_evals.t t\n | App_state : statement t\n | Return_value : return_value -> unit t\n | Auxiliary_value : auxiliary_value -> unit t\n | Unfinalized_proofs :\n (Unfinalized.Constant.t, proofs_verified) Vector.t t\n | Messages_for_next_wrap_proof :\n (Digest.Constant.t, max_proofs_verified) Vector.t t\n | Wrap_domain_indices :\n (Pickles_base.Proofs_verified.t, proofs_verified) Vector.t t\n end\n\n let create :\n type proofs_verified local_signature local_branches statement return_value auxiliary_value prev_values max_proofs_verified.\n unit\n -> (module S\n with type local_signature = local_signature\n and type local_branches = local_branches\n and type statement = statement\n and type return_value = return_value\n and type auxiliary_value = auxiliary_value\n and type prev_values = prev_values\n and type proofs_verified = proofs_verified\n and type max_proofs_verified = max_proofs_verified ) =\n fun () ->\n let module R = struct\n type nonrec max_proofs_verified = max_proofs_verified\n\n type nonrec proofs_verified = proofs_verified\n\n type nonrec statement = statement\n\n type nonrec return_value = return_value\n\n type nonrec auxiliary_value = auxiliary_value\n\n type nonrec prev_values = prev_values\n\n type nonrec local_signature = local_signature\n\n type nonrec local_branches = local_branches\n\n type _ t +=\n | Compute_prev_proof_parts :\n ( prev_values\n , local_signature )\n H2.T(Inductive_rule.Previous_proof_statement.Constant).t\n -> unit t\n | Proof_with_datas :\n ( prev_values\n , local_signature\n , local_branches )\n H3.T(Per_proof_witness.Constant.No_app_state).t\n t\n | Wrap_index : Tock.Curve.Affine.t Plonk_verification_key_evals.t t\n | App_state : statement t\n | Return_value : return_value -> unit t\n | Auxiliary_value : auxiliary_value -> unit t\n | Unfinalized_proofs :\n (Unfinalized.Constant.t, proofs_verified) Vector.t t\n | Messages_for_next_wrap_proof :\n (Digest.Constant.t, max_proofs_verified) Vector.t t\n | Wrap_domain_indices :\n (Pickles_base.Proofs_verified.t, proofs_verified) Vector.t t\n end in\n (module R)\nend\n","open Core_kernel\n\nlet l = ref \"\"\n\nlet r = ref (Time.now ())\n\nlet start =\n Common.when_profiling\n (fun loc ->\n r := Time.now () ;\n l := loc )\n ignore\n\nlet clock =\n Common.when_profiling\n (fun loc ->\n let t = Time.now () in\n printf \"%s -> %s: %s\\n%!\" !l loc\n (Time.Span.to_string_hum (Time.diff t !r)) ;\n r := t ;\n l := loc )\n ignore\n","open Core_kernel\nopen Import\n\nlet zk_rows = 3\n\nlet rough_domains =\n let d = Domain.Pow_2_roots_of_unity 20 in\n { Domains.h = d }\n\nlet domains (type field gates) ?feature_flags\n (module Impl : Snarky_backendless.Snark_intf.Run\n with type field = field\n and type R1CS_constraint_system.t = ( field\n , gates )\n Kimchi_backend_common\n .Plonk_constraint_system\n .t )\n (Spec.ETyp.T (typ, conv, _conv_inv))\n (Spec.ETyp.T (return_typ, _ret_conv, ret_conv_inv)) main =\n let main x () = ret_conv_inv (main (conv x)) in\n\n let domains2 sys =\n let open Domain in\n (* Compute the domain required for the lookup tables *)\n let lookup_table_length_log2 =\n match feature_flags with\n | None ->\n 0\n | Some feature_flags ->\n let { Pickles_types.Plonk_types.Features.range_check0\n ; range_check1\n ; foreign_field_add =\n _\n (* Does not use lookup tables, therefore we do\n not need in the computation *)\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n } =\n feature_flags\n in\n let combined_lookup_table_length =\n let range_check_table_used =\n range_check0 || range_check1 || foreign_field_mul || rot\n in\n let xor_table_used = xor in\n (if range_check_table_used then Int.pow 2 12 else 0)\n + (if xor_table_used then Int.pow 2 8 else 0)\n + ( if lookup then (\n Kimchi_backend_common.Plonk_constraint_system\n .finalize_fixed_lookup_tables sys ;\n Kimchi_backend_common.Plonk_constraint_system\n .get_concatenated_fixed_lookup_table_size sys )\n else 0 )\n +\n if runtime_tables then (\n Kimchi_backend_common.Plonk_constraint_system\n .finalize_runtime_lookup_tables sys ;\n Kimchi_backend_common.Plonk_constraint_system\n .get_concatenated_runtime_lookup_table_size sys )\n else 0\n in\n\n Int.ceil_log2 (combined_lookup_table_length + zk_rows + 1)\n in\n let public_input_size =\n Set_once.get_exn\n (Impl.R1CS_constraint_system.get_public_input_size sys)\n [%here]\n in\n let rows =\n zk_rows + public_input_size + Impl.R1CS_constraint_system.get_rows_len sys\n in\n { Domains.h =\n Pow_2_roots_of_unity Int.(max lookup_table_length_log2 (ceil_log2 rows))\n }\n in\n domains2 (Impl.constraint_system ~input_typ:typ ~return_typ main)\n","open Core_kernel\nopen Pickles_types\nopen Import\nopen Kimchi_pasta.Pasta\n\nmodule Verifier_index_json = struct\n module Lookup = struct\n type 't lookup_selectors =\n 't Kimchi_types.VerifierIndex.Lookup.lookup_selectors =\n { lookup : 't option\n ; xor : 't option\n ; range_check : 't option\n ; ffmul : 't option\n }\n [@@deriving yojson]\n\n type lookup_pattern = Kimchi_types.lookup_pattern =\n | Xor\n | Lookup\n | RangeCheck\n | ForeignFieldMul\n [@@deriving yojson]\n\n type lookup_patterns = Kimchi_types.lookup_patterns =\n { xor : bool\n ; lookup : bool\n ; range_check : bool\n ; foreign_field_mul : bool\n }\n [@@deriving yojson]\n\n type lookup_features = Kimchi_types.lookup_features =\n { patterns : lookup_patterns\n ; joint_lookup_used : bool\n ; uses_runtime_tables : bool\n }\n [@@deriving yojson]\n\n type lookup_info = Kimchi_types.VerifierIndex.Lookup.lookup_info =\n { max_per_row : int; max_joint_size : int; features : lookup_features }\n [@@deriving yojson]\n\n type 'polyComm t = 'polyComm Kimchi_types.VerifierIndex.Lookup.t =\n { joint_lookup_used : bool\n ; lookup_table : 'polyComm array\n ; lookup_selectors : 'polyComm lookup_selectors\n ; table_ids : 'polyComm option\n ; lookup_info : lookup_info\n ; runtime_tables_selector : 'polyComm option\n }\n [@@deriving yojson]\n end\n\n type 'fr domain = 'fr Kimchi_types.VerifierIndex.domain =\n { log_size_of_group : int; group_gen : 'fr }\n [@@deriving yojson]\n\n type 'polyComm verification_evals =\n 'polyComm Kimchi_types.VerifierIndex.verification_evals =\n { sigma_comm : 'polyComm array\n ; coefficients_comm : 'polyComm array\n ; generic_comm : 'polyComm\n ; psm_comm : 'polyComm\n ; complete_add_comm : 'polyComm\n ; mul_comm : 'polyComm\n ; emul_comm : 'polyComm\n ; endomul_scalar_comm : 'polyComm\n ; xor_comm : 'polyComm option\n ; range_check0_comm : 'polyComm option\n ; range_check1_comm : 'polyComm option\n ; foreign_field_add_comm : 'polyComm option\n ; foreign_field_mul_comm : 'polyComm option\n ; rot_comm : 'polyComm option\n }\n [@@deriving yojson]\n\n type ('fr, 'sRS, 'polyComm) verifier_index =\n ('fr, 'sRS, 'polyComm) Kimchi_types.VerifierIndex.verifier_index =\n { domain : 'fr domain\n ; max_poly_size : int\n ; public : int\n ; prev_challenges : int\n ; srs : 'sRS\n ; evals : 'polyComm verification_evals\n ; shifts : 'fr array\n ; lookup_index : 'polyComm Lookup.t option\n }\n [@@deriving yojson]\n\n type 'f or_infinity = 'f Kimchi_types.or_infinity =\n | Infinity\n | Finite of ('f * 'f)\n [@@deriving yojson]\n\n type 'g polycomm = 'g Kimchi_types.poly_comm =\n { unshifted : 'g array; shifted : 'g option }\n [@@deriving yojson]\n\n let to_yojson fp fq =\n verifier_index_to_yojson fp\n (fun _ -> `Null)\n (polycomm_to_yojson (or_infinity_to_yojson fq))\nend\n\nmodule Data = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = { constraints : int } [@@deriving yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Repr = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n { commitments :\n Backend.Tock.Curve.Affine.Stable.V1.t\n Plonk_verification_key_evals.Stable.V2.t\n ; data : Data.Stable.V1.t\n }\n [@@deriving to_yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\n[%%versioned_binable\nmodule Stable = struct\n module V2 = struct\n type t =\n { commitments : Backend.Tock.Curve.Affine.t Plonk_verification_key_evals.t\n ; index :\n (Impls.Wrap.Verification_key.t\n [@to_yojson\n Verifier_index_json.to_yojson Backend.Tock.Field.to_yojson\n Backend.Tick.Field.to_yojson] )\n ; data : Data.t\n }\n [@@deriving fields, to_yojson]\n\n let to_latest = Fn.id\n\n let of_repr srs { Repr.commitments = c; data = d } =\n let t : Impls.Wrap.Verification_key.t =\n let log2_size = Int.ceil_log2 d.constraints in\n let public =\n let (T (input, _conv, _conv_inv)) =\n Impls.Wrap.input ~feature_flags:Plonk_types.Features.Full.maybe ()\n in\n let (Typ typ) = input in\n typ.size_in_field_elements\n in\n { domain =\n { log_size_of_group = log2_size\n ; group_gen = Backend.Tock.Field.domain_generator ~log2_size\n }\n ; max_poly_size = 1 lsl Nat.to_int Rounds.Wrap.n\n ; public\n ; prev_challenges = 2 (* Due to Wrap_hack *)\n ; srs\n ; evals =\n (let g (x, y) =\n { Kimchi_types.unshifted = [| Kimchi_types.Finite (x, y) |]\n ; shifted = None\n }\n in\n { sigma_comm = Array.map ~f:g (Vector.to_array c.sigma_comm)\n ; coefficients_comm =\n Array.map ~f:g (Vector.to_array c.coefficients_comm)\n ; generic_comm = g c.generic_comm\n ; mul_comm = g c.mul_comm\n ; psm_comm = g c.psm_comm\n ; emul_comm = g c.emul_comm\n ; complete_add_comm = g c.complete_add_comm\n ; endomul_scalar_comm = g c.endomul_scalar_comm\n ; xor_comm = None\n ; range_check0_comm = None\n ; range_check1_comm = None\n ; foreign_field_add_comm = None\n ; foreign_field_mul_comm = None\n ; rot_comm = None\n } )\n ; shifts = Common.tock_shifts ~log2_size\n ; lookup_index = None\n }\n in\n { commitments = c; data = d; index = t }\n\n include\n Binable.Of_binable\n (Repr.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable { commitments; data; index = _ } =\n { Repr.commitments; data }\n\n let of_binable r = of_repr (Backend.Tock.Keypair.load_urs ()) r\n end)\n end\nend]\n\nlet to_yojson = Stable.Latest.to_yojson\n\nlet dummy_commitments g =\n let open Plonk_types in\n { Plonk_verification_key_evals.sigma_comm =\n Vector.init Permuts.n ~f:(fun _ -> g)\n ; coefficients_comm = Vector.init Columns.n ~f:(fun _ -> g)\n ; generic_comm = g\n ; psm_comm = g\n ; complete_add_comm = g\n ; mul_comm = g\n ; emul_comm = g\n ; endomul_scalar_comm = g\n }\n\nlet dummy_step_commitments g =\n let open Plonk_types in\n { Plonk_verification_key_evals.Step.sigma_comm =\n Vector.init Permuts.n ~f:(fun _ -> g)\n ; coefficients_comm = Vector.init Columns.n ~f:(fun _ -> g)\n ; generic_comm = g\n ; psm_comm = g\n ; complete_add_comm = g\n ; mul_comm = g\n ; emul_comm = g\n ; endomul_scalar_comm = g\n ; xor_comm = None\n ; range_check0_comm = None\n ; range_check1_comm = None\n ; foreign_field_add_comm = None\n ; foreign_field_mul_comm = None\n ; rot_comm = None\n ; lookup_table_comm = Vector.init Lookup_sorted_minus_1.n ~f:(fun _ -> None)\n ; lookup_table_ids = None\n ; runtime_tables_selector = None\n ; lookup_selector_lookup = None\n ; lookup_selector_xor = None\n ; lookup_selector_range_check = None\n ; lookup_selector_ffmul = None\n }\n\nlet dummy =\n lazy\n (let rows = Domain.size (Common.wrap_domains ~proofs_verified:2).h in\n let g = Backend.Tock.Curve.(to_affine_exn one) in\n { Repr.commitments = dummy_commitments g; data = { constraints = rows } }\n |> Stable.Latest.of_repr (Kimchi_bindings.Protocol.SRS.Fq.create 1) )\n","open Core_kernel\nopen Pickles_types\nopen Import\nopen Poly_types\n\n(* Compute the domains corresponding to wrap_main *)\n\n(* TODO: this functor does not depend on any of its argument why? *)\n\nmodule Make\n (A : T0)\n (A_value : T0)\n (Ret_var : T0)\n (Ret_value : T0)\n (Auxiliary_var : T0)\n (Auxiliary_value : T0) =\nstruct\n let f_debug full_signature _num_choices choices_length ~feature_flags\n ~max_proofs_verified =\n let num_choices = Hlist.Length.to_nat choices_length in\n let dummy_step_domains =\n Vector.init num_choices ~f:(fun _ -> Fix_domains.rough_domains)\n in\n let dummy_step_widths =\n Vector.init num_choices ~f:(fun _ ->\n Nat.to_int (Nat.Add.n max_proofs_verified) )\n in\n let dummy_step_keys =\n lazy\n (Vector.init num_choices ~f:(fun _ ->\n let g = Backend.Tock.Inner_curve.(to_affine_exn one) in\n Verification_key.dummy_step_commitments g ) )\n in\n Timer.clock __LOC__ ;\n let srs = Backend.Tick.Keypair.load_urs () in\n let _, main =\n Wrap_main.wrap_main ~feature_flags ~srs full_signature choices_length\n dummy_step_keys dummy_step_widths dummy_step_domains max_proofs_verified\n in\n Timer.clock __LOC__ ;\n let t =\n Fix_domains.domains\n (module Impls.Wrap)\n (Impls.Wrap.input ~feature_flags ())\n (T (Snarky_backendless.Typ.unit (), Fn.id, Fn.id))\n main\n in\n Timer.clock __LOC__ ; t\n\n let f full_signature num_choices choices_length ~feature_flags\n ~max_proofs_verified =\n let res =\n Common.wrap_domains\n ~proofs_verified:(Nat.to_int (Nat.Add.n max_proofs_verified))\n in\n ( if debug then\n let res' =\n f_debug full_signature num_choices choices_length ~feature_flags\n ~max_proofs_verified\n in\n [%test_eq: Domains.t] res res' ) ;\n res\nend\n[@@warning \"-60\"]\n","module SC = Scalar_challenge\nmodule P = Proof\nopen Pickles_types\nopen Hlist\nopen Common\nopen Import\nopen Types\nopen Backend\n\n(* This contains the \"wrap\" prover *)\n\nlet challenge_polynomial =\n Wrap_verifier.challenge_polynomial (module Backend.Tick.Field)\n\nmodule Type1 =\n Plonk_checks.Make\n (Shifted_value.Type1)\n (struct\n let constant_term = Plonk_checks.Scalars.Tick.constant_term\n\n let index_terms = Plonk_checks.Scalars.Tick.index_terms\n end)\n\nlet _vector_of_list (type a t)\n (module V : Snarky_intf.Vector.S with type elt = a and type t = t)\n (xs : a list) : t =\n let r = V.create () in\n List.iter xs ~f:(V.emplace_back r) ;\n r\n\nlet tick_rounds = Nat.to_int Tick.Rounds.n\n\nlet combined_inner_product (type actual_proofs_verified) ~env ~domain ~ft_eval1\n ~actual_proofs_verified:\n (module AB : Nat.Add.Intf with type n = actual_proofs_verified)\n (e : _ Plonk_types.All_evals.With_public_input.t)\n ~(old_bulletproof_challenges : (_, actual_proofs_verified) Vector.t) ~r\n ~plonk ~xi ~zeta ~zetaw =\n let combined_evals =\n Plonk_checks.evals_of_split_evals ~zeta ~zetaw\n (module Tick.Field)\n ~rounds:tick_rounds e.evals\n in\n let ft_eval0 : Tick.Field.t =\n Type1.ft_eval0\n (module Tick.Field)\n plonk ~env ~domain\n (Plonk_types.Evals.to_in_circuit combined_evals)\n (fst e.public_input)\n in\n let T = AB.eq in\n let challenge_polys =\n Vector.map\n ~f:(fun chals -> unstage (challenge_polynomial (Vector.to_array chals)))\n old_bulletproof_challenges\n in\n let a = Plonk_types.Evals.to_list e.evals in\n let combine ~which_eval ~ft pt =\n let f (x, y) = match which_eval with `Fst -> x | `Snd -> y in\n let a = List.map ~f a in\n let v : Tick.Field.t array list =\n List.append\n (List.map (Vector.to_list challenge_polys) ~f:(fun f -> [| f pt |]))\n ([| f e.public_input |] :: [| ft |] :: a)\n in\n let open Tick.Field in\n Pcs_batch.combine_split_evaluations ~xi ~init:Fn.id\n ~mul_and_add:(fun ~acc ~xi fx -> fx + (xi * acc))\n v\n in\n let open Tick.Field in\n combine ~which_eval:`Fst ~ft:ft_eval0 zeta\n + (r * combine ~which_eval:`Snd ~ft:ft_eval1 zetaw)\n\nmodule Deferred_values = Types.Wrap.Proof_state.Deferred_values\n\ntype scalar_challenge_constant = Challenge.Constant.t Scalar_challenge.t\n\ntype deferred_values_and_hints =\n { x_hat_evals : Backend.Tick.Field.t * Backend.Tick.Field.t\n ; sponge_digest_before_evaluations : Tick.Field.t\n ; deferred_values :\n ( ( Challenge.Constant.t\n , scalar_challenge_constant\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , (Tick.Field.t Shifted_value.Type1.t, bool) Opt.t\n , (scalar_challenge_constant, bool) Opt.t\n , bool )\n Deferred_values.Plonk.In_circuit.t\n , scalar_challenge_constant\n , Tick.Field.t Shifted_value.Type1.t\n , Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n , Branch_data.t )\n Deferred_values.t\n }\n\nlet deferred_values (type n) ~(sgs : (Backend.Tick.Curve.Affine.t, n) Vector.t)\n ~actual_feature_flags\n ~(prev_challenges : ((Backend.Tick.Field.t, _) Vector.t, n) Vector.t)\n ~(step_vk : Kimchi_bindings.Protocol.VerifierIndex.Fp.t)\n ~(public_input : Backend.Tick.Field.t list) ~(proof : Backend.Tick.Proof.t)\n ~(actual_proofs_verified : n Nat.t) : deferred_values_and_hints =\n let module O = Tick.Oracles in\n let o =\n O.create step_vk\n Vector.(\n map2 sgs prev_challenges ~f:(fun commitment cs ->\n { Tick.Proof.Challenge_polynomial.commitment\n ; challenges = Vector.to_array cs\n } )\n |> to_list)\n public_input proof\n in\n let x_hat = O.(p_eval_1 o, p_eval_2 o) in\n let scalar_chal f =\n Scalar_challenge.map ~f:Challenge.Constant.of_tick_field (f o)\n in\n let plonk0 =\n { Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.alpha =\n scalar_chal O.alpha\n ; beta = O.beta o\n ; gamma = O.gamma o\n ; zeta = scalar_chal O.zeta\n ; joint_combiner =\n (* TODO: Needs to be changed when lookups are fully implemented *)\n Option.map (O.joint_combiner_chal o)\n ~f:(Scalar_challenge.map ~f:Challenge.Constant.of_tick_field)\n ; feature_flags = actual_feature_flags\n }\n in\n let r = scalar_chal O.u in\n let xi = scalar_chal O.v in\n let module As_field = struct\n let to_field =\n SC.to_field_constant\n (module Tick.Field)\n ~endo:Endo.Wrap_inner_curve.scalar\n\n let r = to_field r\n\n let xi = to_field xi\n\n let zeta = to_field plonk0.zeta\n\n let alpha = to_field plonk0.alpha\n\n let joint_combiner = Option.map ~f:to_field plonk0.joint_combiner\n end in\n let domain = Domain.Pow_2_roots_of_unity step_vk.domain.log_size_of_group in\n let zetaw = Tick.Field.mul As_field.zeta step_vk.domain.group_gen in\n let tick_plonk_minimal =\n { plonk0 with\n zeta = As_field.zeta\n ; alpha = As_field.alpha\n ; joint_combiner = As_field.joint_combiner\n }\n in\n let tick_combined_evals =\n Plonk_checks.evals_of_split_evals\n (module Tick.Field)\n proof.openings.evals ~rounds:(Nat.to_int Tick.Rounds.n)\n ~zeta:As_field.zeta ~zetaw\n |> Plonk_types.Evals.to_in_circuit\n in\n let tick_domain =\n Plonk_checks.domain\n (module Tick.Field)\n domain ~shifts:Common.tick_shifts\n ~domain_generator:Backend.Tick.Field.domain_generator\n in\n let tick_env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tick.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~endo:Endo.Step_inner_curve.base ~mds:Tick_field_sponge.params.mds\n ~srs_length_log2:Common.Max_degree.step_log2\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fp.of_bigint )\n ~domain:tick_domain tick_plonk_minimal tick_combined_evals\n in\n let plonk =\n let module Field = struct\n include Tick.Field\n end in\n Type1.derive_plonk\n (module Field)\n ~shift:Shifts.tick1 ~env:tick_env tick_plonk_minimal tick_combined_evals\n and new_bulletproof_challenges, b =\n let prechals =\n Array.map (O.opening_prechallenges o) ~f:(fun x ->\n Scalar_challenge.map ~f:Challenge.Constant.of_tick_field x )\n in\n let chals = Array.map prechals ~f:(fun x -> Ipa.Step.compute_challenge x) in\n let challenge_poly = unstage (challenge_polynomial chals) in\n let open As_field in\n let b =\n let open Tick.Field in\n challenge_poly zeta + (r * challenge_poly zetaw)\n in\n let prechals = Array.map prechals ~f:Bulletproof_challenge.unpack in\n (prechals, b)\n in\n let shift_value =\n Shifted_value.Type1.of_field (module Tick.Field) ~shift:Shifts.tick1\n and chal = Challenge.Constant.of_tick_field in\n { deferred_values =\n { Types.Wrap.Proof_state.Deferred_values.xi\n ; b = shift_value b\n ; bulletproof_challenges =\n Vector.of_array_and_length_exn new_bulletproof_challenges\n Tick.Rounds.n\n ; combined_inner_product =\n shift_value\n As_field.(\n combined_inner_product (* Note: We do not pad here. *)\n ~actual_proofs_verified:(Nat.Add.create actual_proofs_verified)\n { evals = proof.openings.evals; public_input = x_hat }\n ~r ~xi ~zeta ~zetaw ~old_bulletproof_challenges:prev_challenges\n ~env:tick_env ~domain:tick_domain\n ~ft_eval1:proof.openings.ft_eval1 ~plonk:tick_plonk_minimal)\n ; branch_data =\n { proofs_verified =\n ( match actual_proofs_verified with\n | Z ->\n Branch_data.Proofs_verified.N0\n | S Z ->\n N1\n | S (S Z) ->\n N2\n | S _ ->\n assert false )\n ; domain_log2 =\n Branch_data.Domain_log2.of_int_exn\n step_vk.domain.log_size_of_group\n }\n ; plonk =\n { plonk with\n zeta = plonk0.zeta\n ; alpha = plonk0.alpha\n ; beta = chal plonk0.beta\n ; gamma = chal plonk0.gamma\n ; joint_combiner = Opt.of_option plonk0.joint_combiner\n }\n }\n ; x_hat_evals = x_hat\n ; sponge_digest_before_evaluations = O.digest_before_evaluations o\n }\n\n(* Testing\n -------\n\n Invocation:\n dune exec src/lib/pickles/.pickles.inline-tests/inline_test_runner_pickles.exe \\\n --profile=dev --display short -- inline-test-runner pickles -only-test wrap.ml\n*)\nlet%test_module \"gate finalization\" =\n ( module struct\n type test_options =\n { true_is_yes : Plonk_types.Features.options\n ; true_is_maybe : Plonk_types.Features.options\n ; all_maybes : Plonk_types.Features.options\n }\n\n (* Helper function to convert actual feature flags into 3 test configurations of feature flags\n @param actual_feature_flags The actual feature flags in terms of true/false\n\n @return Corresponding feature flags configs composed of Yes/No/Maybe options\n - one where true is mapped to Yes and false is mapped to No\n - one where true is mapped to Maybe and false is mapped to No\n - one where true and false are both mapped to Maybe *)\n let generate_test_feature_flag_configs\n (actual_feature_flags : Plonk_types.Features.flags) : test_options =\n (* Set up a helper to convert actual feature flags composed of booleans into\n feature flags composed of Yes/No/Maybe options.\n @param actual_feature_flags The actual feature flags in terms of true/false\n @param true_opt Opt type to use for true/enabled features\n @param false_opt Opt type to use for false/disabled features\n @return Corresponding feature flags composed of Yes/No/Maybe values *)\n let compute_feature_flags\n (actual_feature_flags : Plonk_types.Features.flags)\n (true_opt : Opt.Flag.t) (false_opt : Opt.Flag.t) :\n Plonk_types.Features.options =\n Plonk_types.Features.map actual_feature_flags ~f:(function\n | true ->\n true_opt\n | false ->\n false_opt )\n in\n\n (* Generate the 3 configurations of the actual feature flags using\n helper *)\n let open Opt.Flag in\n { true_is_yes = compute_feature_flags actual_feature_flags Yes No\n ; true_is_maybe = compute_feature_flags actual_feature_flags Maybe No\n ; all_maybes = compute_feature_flags actual_feature_flags Maybe Maybe\n }\n\n (* Run the recursive proof tests on the supplied inputs.\n\n @param actual_feature_flags User-specified feature flags, matching those\n required by the backend circuit\n @param public_input list of public inputs (can be empty)\n @param vk Verifier index for backend circuit\n @param proof Backend proof\n\n @return true or throws and exception\n *)\n let run_recursive_proof_test\n (actual_feature_flags : Plonk_types.Features.flags)\n (feature_flags : Plonk_types.Features.options)\n (public_input : Pasta_bindings.Fp.t list)\n (vk : Kimchi_bindings.Protocol.VerifierIndex.Fp.t)\n (proof : Backend.Tick.Proof.t) : Impls.Step.Boolean.value =\n (* Constants helper - takes an OCaml value and converts it to a snarky value, where\n all values here are constant literals. N.b. this should be\n encapsulated as Snarky internals, but it never got merged. *)\n let constant (Typ typ : _ Snarky_backendless.Typ.t) x =\n let xs, aux = typ.value_to_fields x in\n typ.var_of_fields (Array.map xs ~f:Impls.Step.Field.constant, aux)\n in\n\n (* Compute deferred values - in the Pickles recursive proof system, deferred values\n are values from 2 proofs earlier in the recursion hierarchy. Every recursion\n goes through a two-phase process of step and wrap, like so\n\n step <- wrap <- step <- ... <- wrap <- step,\n `<-----------'\n deferred\n\n where there may be multiple children at each level (but let's ignore that!).\n Deferred values are values (part of the public input) that must be passed between\n the two phases in order to be verified correctly-- it works like this.\n\n - The wrap proof is passed the deferred values for its step proof as part of its public input.\n - The wrap proof starts verifying the step proof. As part of this verification it must\n perform all of the group element checks (since it's over the Vesta base field); however,\n at this stage it just assumes that the deferred values of its public input are correct\n (i.e. it defers checking them).\n - The next step proof verifies the wrap proof with a similar process, but using the other\n curve (e.g. Pallas). There are two important things to note:\n - Since it is using the other curve, it can compute the commitments to the public inputs\n of the previous wrap circuit that were passed into it. In other words, the next step\n proof receives data from the previous wrap proof about the previous step proof. Yeah,\n from two proofs back! (e.g. the deferred values)\n - The next step proof also computes the deferred values inside the circuit and verifies\n that they match those used by the previous wrap proof.\n\n The code below generates the deferred values so that we can verifiy that we can actually\n compute those values correctly inside the circuit. Special thanks to Matthew Ryan for\n explaining this in detail. *)\n let { deferred_values; x_hat_evals; sponge_digest_before_evaluations } =\n deferred_values ~actual_feature_flags ~sgs:[] ~prev_challenges:[]\n ~step_vk:vk ~public_input ~proof ~actual_proofs_verified:Nat.N0.n\n in\n\n let full_features =\n Plonk_types.Features.to_full ~or_:Opt.Flag.( ||| ) feature_flags\n in\n\n (* Define Typ.t for Deferred_values.t -- A Type.t defines how to convert a value of some type\n in OCaml into a var in circuit/Snarky.\n\n This complex function is called with two sets of inputs: once for the step circuit and\n once for the wrap circuit. It was decided not to use a functor for this. *)\n let deferred_values_typ =\n let open Impls.Step in\n let open Step_main_inputs in\n let open Step_verifier in\n Wrap.Proof_state.Deferred_values.In_circuit.typ\n (module Impls.Step)\n ~feature_flags:full_features ~challenge:Challenge.typ\n ~scalar_challenge:Challenge.typ\n ~dummy_scalar_challenge:\n (Kimchi_backend_common.Scalar_challenge.create\n Limb_vector.Challenge.Constant.zero )\n (Shifted_value.Type1.typ Field.typ)\n (Branch_data.typ\n (module Impl)\n ~assert_16_bits:(Step_verifier.assert_n_bits ~n:16) )\n in\n\n (* Use deferred_values_typ and the constant helper to prepare deferred_values\n for use in the circuit. We change some [Opt.t] to [Option.t] because that is\n what Type.t is configured to accept. *)\n let deferred_values =\n constant deferred_values_typ\n { deferred_values with\n plonk =\n { deferred_values.plonk with\n joint_combiner =\n Opt.to_option_unsafe deferred_values.plonk.joint_combiner\n }\n }\n (* Prepare all of the evaluations (i.e. all of the columns in the proof that we open)\n for use in the circuit *)\n and evals =\n constant\n (Plonk_types.All_evals.typ (module Impls.Step) full_features)\n { evals = { public_input = x_hat_evals; evals = proof.openings.evals }\n ; ft_eval1 = proof.openings.ft_eval1\n }\n in\n\n (* Run the circuit without generating a proof using run_and_check *)\n Impls.Step.run_and_check (fun () ->\n (* Set up the step sponge from the wrap sponge -- we cannot use the same poseidon\n sponge in both step and wrap because they have different fields.\n\n In order to continue the Fiat-Shamir heuristic across field boundaries we use\n the wrap sponge for everything in the wrap proof, squeeze it one final time and\n expose the squoze value in the public input to the step proof, which absorbs\n said squoze value into the step sponge. :-) This means the step sponge has absorbed\n everything from the proof so far by proxy and that is also over the native field! *)\n let res, _chals =\n let sponge =\n let open Step_main_inputs in\n let sponge = Sponge.create sponge_params in\n Sponge.absorb sponge\n (`Field (Impl.Field.constant sponge_digest_before_evaluations)) ;\n sponge\n in\n\n (* Call finalisation with all of the required details *)\n Step_verifier.finalize_other_proof\n (module Nat.N0)\n ~step_domains:\n (`Known\n [ { h = Pow_2_roots_of_unity vk.domain.log_size_of_group } ]\n )\n ~sponge ~prev_challenges:[] deferred_values evals\n in\n\n (* Read the boolean result from the circuit and make it available\n to the OCaml world. *)\n Impls.Step.(As_prover.(fun () -> read Boolean.typ res)) )\n |> Or_error.ok_exn\n\n (* Common srs value for all tests *)\n let srs =\n Kimchi_bindings.Protocol.SRS.Fp.create (1 lsl Common.Max_degree.step_log2)\n\n type example =\n Kimchi_bindings.Protocol.SRS.Fp.t\n -> Kimchi_bindings.Protocol.Index.Fp.t\n * Pasta_bindings.Fp.t list\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n\n module type SETUP = sig\n val example : example\n\n (* Feature flags tused for backend proof *)\n val actual_feature_flags : bool Plonk_types.Features.t\n end\n\n (* [Make] is the test functor.\n\n Given a test setup, compute different test configurations and define 3\n test for said configurations. *)\n module Make (S : SETUP) = struct\n (* Generate foreign field multiplication test backend proof using Kimchi,\n obtaining the proof and corresponding prover index.\n\n Note: we only want to pay the cost of generating this proof once and\n then reuse it many times for the different recursive proof tests. *)\n let index, public_input, proof = S.example srs\n\n (* Obtain verifier key from prover index and convert backend proof to\n snarky proof *)\n let vk = Kimchi_bindings.Protocol.VerifierIndex.Fp.create index\n\n let proof = Backend.Tick.Proof.of_backend_with_public_evals proof\n\n let test_feature_flags_configs =\n generate_test_feature_flag_configs S.actual_feature_flags\n\n let runtest feature_flags =\n run_recursive_proof_test S.actual_feature_flags feature_flags\n public_input vk proof.proof\n\n let%test \"true -> yes\" = runtest test_feature_flags_configs.true_is_yes\n\n let%test \"true -> maybe\" =\n runtest test_feature_flags_configs.true_is_maybe\n\n let%test \"all maybes\" = runtest test_feature_flags_configs.all_maybes\n end\n\n (* Small combinators to lift gate example signatures to the expected\n signatures for the tests. This amounts to generating the list of public\n inputs from either no public inputs, a single one or a pair of inputs\n returned by the gate example. *)\n\n let no_public_input gate_example srs =\n let index, proof = gate_example srs in\n (index, [], proof)\n\n let public_input_1 gate_example srs =\n let index, public_input, proof = gate_example srs in\n (index, [ public_input ], proof)\n\n let public_input_2 gate_example srs =\n let index, (public_input1, public_input2), proof = gate_example srs in\n (index, [ public_input1; public_input2 ], proof)\n\n let%test_module \"lookup\" =\n ( module Make (struct\n let example =\n public_input_1 (fun srs ->\n Kimchi_bindings.Protocol.Proof.Fp.example_with_lookup srs )\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with\n lookup = true\n ; runtime_tables = true\n }\n end) )\n\n (*\n let%test_module \"foreign field multiplication\" =\n ( module Make (struct\n let example =\n no_public_input\n Kimchi_bindings.Protocol.Proof.Fp.example_with_foreign_field_mul\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with\n range_check0 = true\n ; range_check1 = true\n ; foreign_field_add = true\n ; foreign_field_mul = true\n }\n end) )\n *)\n\n let%test_module \"range check\" =\n ( module Make (struct\n let example =\n no_public_input\n Kimchi_bindings.Protocol.Proof.Fp.example_with_range_check\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with\n range_check0 = true\n ; range_check1 = true\n }\n end) )\n\n let%test_module \"range check 64 bits\" =\n ( module Make (struct\n let example =\n no_public_input\n Kimchi_bindings.Protocol.Proof.Fp.example_with_range_check0\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with range_check0 = true }\n end) )\n\n let%test_module \"xor\" =\n ( module Make (struct\n let example =\n public_input_2 Kimchi_bindings.Protocol.Proof.Fp.example_with_xor\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with xor = true }\n end) )\n\n let%test_module \"rot\" =\n ( module Make (struct\n let example =\n public_input_2 Kimchi_bindings.Protocol.Proof.Fp.example_with_rot\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with\n range_check0 = true\n ; rot = true\n }\n end) )\n\n let%test_module \"foreign field addition\" =\n ( module Make (struct\n let example =\n public_input_1 Kimchi_bindings.Protocol.Proof.Fp.example_with_ffadd\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with\n range_check0 = true\n ; range_check1 = true\n ; foreign_field_add = true\n }\n end) )\n end )\n\nmodule Step_acc = Tock.Inner_curve.Affine\n\n(* The prover for wrapping a proof *)\nlet wrap\n (type actual_proofs_verified max_proofs_verified\n max_local_max_proofs_verifieds ) ~proof_cache\n ~(max_proofs_verified : max_proofs_verified Nat.t)\n (module Max_local_max_proof_verifieds : Hlist.Maxes.S\n with type ns = max_local_max_proofs_verifieds\n and type length = max_proofs_verified )\n (( module\n Req ) :\n (max_proofs_verified, max_local_max_proofs_verifieds) Requests.Wrap.t )\n ~dlog_plonk_index wrap_main ~(typ : _ Impls.Step.Typ.t) ~step_vk\n ~actual_wrap_domains ~step_plonk_indices:_ ~feature_flags\n ~actual_feature_flags ?tweak_statement pk\n ({ statement = prev_statement; prev_evals; proof; index = which_index } :\n ( _\n , _\n , (_, actual_proofs_verified) Vector.t\n , (_, actual_proofs_verified) Vector.t\n , max_local_max_proofs_verifieds\n H1.T(P.Base.Messages_for_next_proof_over_same_field.Wrap).t\n , ( (Tock.Field.t, Tock.Field.t array) Plonk_types.All_evals.t\n , max_proofs_verified )\n Vector.t )\n P.Base.Step.t ) =\n let logger = Internal_tracing_context_logger.get () in\n [%log internal] \"Pickles_wrap_proof\" ;\n let messages_for_next_wrap_proof =\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap)\n (P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared)\n (struct\n let f = P.Base.Messages_for_next_proof_over_same_field.Wrap.prepare\n end)\n in\n M.f prev_statement.messages_for_next_wrap_proof\n in\n let prev_statement_with_hashes : _ Types.Step.Statement.t =\n { proof_state =\n { prev_statement.proof_state with\n messages_for_next_step_proof =\n (let to_field_elements =\n let (Typ typ) = typ in\n fun x -> fst (typ.value_to_fields x)\n in\n (* TODO: Careful here... the length of\n old_buletproof_challenges inside the messages_for_next_step_proof\n might not be correct *)\n Common.hash_messages_for_next_step_proof\n ~app_state:to_field_elements\n (P.Base.Messages_for_next_proof_over_same_field.Step.prepare\n ~dlog_plonk_index\n prev_statement.proof_state.messages_for_next_step_proof ) )\n }\n ; messages_for_next_wrap_proof =\n (let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared)\n (E01 (Digest.Constant))\n (struct\n let f (type n)\n (m :\n n\n P.Base.Messages_for_next_proof_over_same_field.Wrap\n .Prepared\n .t ) =\n Wrap_hack.hash_messages_for_next_wrap_proof\n (Vector.length m.old_bulletproof_challenges)\n m\n end)\n in\n let module V = H1.To_vector (Digest.Constant) in\n V.f Max_local_max_proof_verifieds.length\n (M.f messages_for_next_wrap_proof) )\n }\n in\n let handler (Snarky_backendless.Request.With { request; respond }) =\n let open Req in\n let k x = respond (Provide x) in\n match request with\n | Evals ->\n k prev_evals\n | Step_accs ->\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared)\n (E01 (Step_acc))\n (struct\n let f :\n type a.\n a\n P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared\n .t\n -> Step_acc.t =\n fun t -> t.challenge_polynomial_commitment\n end)\n in\n let module V = H1.To_vector (Step_acc) in\n k\n (V.f Max_local_max_proof_verifieds.length\n (M.f messages_for_next_wrap_proof) )\n | Old_bulletproof_challenges ->\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared)\n (Challenges_vector.Constant)\n (struct\n let f\n (t :\n _\n P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared\n .t ) =\n t.old_bulletproof_challenges\n end)\n in\n k (M.f messages_for_next_wrap_proof)\n | Messages ->\n k proof.messages\n | Openings_proof ->\n k proof.openings.proof\n | Proof_state ->\n k prev_statement_with_hashes.proof_state\n | Which_branch ->\n k which_index\n | Wrap_domain_indices ->\n let all_possible_domains = Wrap_verifier.all_possible_domains () in\n let wrap_domain_indices =\n Vector.map actual_wrap_domains ~f:(fun domain_size ->\n let domain_index =\n Vector.foldi ~init:0 all_possible_domains\n ~f:(fun j acc (Pow_2_roots_of_unity domain) ->\n if Int.equal domain domain_size then j else acc )\n in\n Tock.Field.of_int domain_index )\n in\n k\n (Vector.extend_front_exn wrap_domain_indices max_proofs_verified\n Tock.Field.one )\n | _ ->\n Snarky_backendless.Request.unhandled\n in\n\n let public_input =\n tick_public_input_of_statement ~max_proofs_verified\n prev_statement_with_hashes\n in\n let prev_challenges =\n Vector.map ~f:Ipa.Step.compute_challenges\n prev_statement.proof_state.messages_for_next_step_proof\n .old_bulletproof_challenges\n in\n let actual_proofs_verified = Vector.length prev_challenges in\n let lte =\n Nat.lte_exn actual_proofs_verified\n (Length.to_nat Max_local_max_proof_verifieds.length)\n in\n let sgs =\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared)\n (E01 (Tick.Curve.Affine))\n (struct\n let f :\n type n.\n n P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared.t\n -> _ =\n fun t -> t.challenge_polynomial_commitment\n end)\n in\n let module V = H1.To_vector (Tick.Curve.Affine) in\n Vector.trim_front\n (V.f Max_local_max_proof_verifieds.length\n (M.f messages_for_next_wrap_proof) )\n lte\n in\n [%log internal] \"Wrap_compute_deferred_values\" ;\n let { deferred_values; x_hat_evals; sponge_digest_before_evaluations } =\n deferred_values ~sgs ~prev_challenges ~step_vk ~public_input ~proof\n ~actual_proofs_verified ~actual_feature_flags\n in\n [%log internal] \"Wrap_compute_deferred_values_done\" ;\n let next_statement : _ Types.Wrap.Statement.In_circuit.t =\n let messages_for_next_wrap_proof :\n _ P.Base.Messages_for_next_proof_over_same_field.Wrap.t =\n { challenge_polynomial_commitment =\n proof.openings.proof.challenge_polynomial_commitment\n ; old_bulletproof_challenges =\n Vector.map prev_statement.proof_state.unfinalized_proofs ~f:(fun t ->\n t.deferred_values.bulletproof_challenges )\n }\n in\n { proof_state =\n { deferred_values\n ; sponge_digest_before_evaluations =\n Digest.Constant.of_tick_field sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n }\n ; messages_for_next_step_proof =\n prev_statement.proof_state.messages_for_next_step_proof\n }\n in\n let next_statement =\n match tweak_statement with\n | None ->\n next_statement\n | Some f ->\n (* For adversarial tests, we want to simulate an adversary creating a\n proof that doesn't match the pickles protocol.\n In order to do this, we pass a function [tweak_statement] that takes\n the valid statement that we computed above and 'tweaks' it so that\n the statement is no longer valid. This modified statement is then\n propagated as part of any later recursion.\n *)\n f next_statement\n in\n let messages_for_next_wrap_proof_prepared =\n P.Base.Messages_for_next_proof_over_same_field.Wrap.prepare\n next_statement.proof_state.messages_for_next_wrap_proof\n in\n let next_accumulator =\n Vector.map2\n (Vector.extend_front_exn\n prev_statement.proof_state.messages_for_next_step_proof\n .challenge_polynomial_commitments max_proofs_verified\n (Lazy.force Dummy.Ipa.Wrap.sg) )\n messages_for_next_wrap_proof_prepared.old_bulletproof_challenges\n ~f:(fun sg chals ->\n { Tock.Proof.Challenge_polynomial.commitment = sg\n ; challenges = Vector.to_array chals\n } )\n |> Wrap_hack.pad_accumulator\n in\n let%map.Promise next_proof =\n let (T (input, conv, _conv_inv)) = Impls.Wrap.input ~feature_flags () in\n Common.time \"wrap proof\" (fun () ->\n [%log internal] \"Wrap_generate_witness_conv\" ;\n Impls.Wrap.generate_witness_conv\n ~f:(fun { Impls.Wrap.Proof_inputs.auxiliary_inputs; public_inputs } () ->\n [%log internal] \"Backend_tock_proof_create_async\" ;\n let create_proof () =\n Backend.Tock.Proof.create_async ~primary:public_inputs\n ~auxiliary:auxiliary_inputs pk ~message:next_accumulator\n in\n let%map.Promise proof =\n match proof_cache with\n | None ->\n create_proof ()\n | Some proof_cache -> (\n match\n Proof_cache.get_wrap_proof proof_cache ~keypair:pk\n ~public_input:public_inputs\n with\n | None ->\n let%map.Promise proof = create_proof () in\n Proof_cache.set_wrap_proof proof_cache ~keypair:pk\n ~public_input:public_inputs proof.proof ;\n proof\n | Some proof ->\n Promise.return\n ( { proof; public_evals = None }\n : Tock.Proof.with_public_evals ) )\n in\n [%log internal] \"Backend_tock_proof_create_async_done\" ;\n proof )\n ~input_typ:input\n ~return_typ:(Snarky_backendless.Typ.unit ())\n (fun x () : unit ->\n Impls.Wrap.handle (fun () : unit -> wrap_main (conv x)) handler )\n { messages_for_next_step_proof =\n prev_statement_with_hashes.proof_state\n .messages_for_next_step_proof\n ; proof_state =\n { next_statement.proof_state with\n messages_for_next_wrap_proof =\n Wrap_hack.hash_messages_for_next_wrap_proof\n max_proofs_verified messages_for_next_wrap_proof_prepared\n ; deferred_values =\n { next_statement.proof_state.deferred_values with\n plonk =\n { next_statement.proof_state.deferred_values.plonk with\n joint_combiner =\n Opt.to_option\n next_statement.proof_state.deferred_values.plonk\n .joint_combiner\n }\n }\n }\n } )\n in\n [%log internal] \"Pickles_wrap_proof_done\" ;\n ( { proof = Wrap_wire_proof.of_kimchi_proof next_proof.proof\n ; statement =\n Types.Wrap.Statement.to_minimal next_statement\n ~to_option:Opt.to_option_unsafe\n ; prev_evals =\n { Plonk_types.All_evals.evals =\n { public_input = x_hat_evals; evals = proof.openings.evals }\n ; ft_eval1 = proof.openings.ft_eval1\n }\n }\n : _ P.Base.Wrap.t )\n","module SC = Scalar_challenge\nopen Core_kernel\nopen Pickles_types\nopen Common\nopen Import\nopen Backend\n\n(* TODO: Just stick this in plonk_checks.ml *)\nmodule Plonk_checks = struct\n include Plonk_checks\n module Type1 =\n Plonk_checks.Make (Shifted_value.Type1) (Plonk_checks.Scalars.Tick)\nend\n\nlet expand_deferred (type n most_recent_width)\n ~(evals :\n ( Backend.Tick.Field.t\n , Backend.Tick.Field.t array )\n Pickles_types.Plonk_types.All_evals.t )\n ~(old_bulletproof_challenges :\n ( Challenge.Constant.t Scalar_challenge.Stable.Latest.t\n Bulletproof_challenge.t\n Step_bp_vec.t\n , most_recent_width )\n Pickles_types.Vector.t )\n ~(proof_state :\n ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool\n , n Pickles__.Proof.Base.Messages_for_next_proof_over_same_field.Wrap.t\n , Digest.Constant.t\n , Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n , Branch_data.t )\n Composition_types.Wrap.Proof_state.Minimal.Stable.V1.t ) :\n _ Types.Wrap.Proof_state.Deferred_values.t =\n let module Tick_field = Backend.Tick.Field in\n let tick_field : _ Plonk_checks.field = (module Tick_field) in\n Timer.start __LOC__ ;\n let open Types.Wrap.Proof_state in\n let sc = SC.to_field_constant tick_field ~endo:Endo.Wrap_inner_curve.scalar in\n Timer.clock __LOC__ ;\n let plonk0 = proof_state.deferred_values.plonk in\n let { Deferred_values.Minimal.branch_data; bulletproof_challenges; _ } =\n Deferred_values.Minimal.map_challenges ~f:Challenge.Constant.to_tick_field\n ~scalar:sc proof_state.deferred_values\n in\n let zeta = sc plonk0.zeta in\n let alpha = sc plonk0.alpha in\n let step_domain = Branch_data.domain branch_data in\n let w =\n Tick.Field.domain_generator ~log2_size:(Domain.log2_size step_domain)\n in\n let zetaw = Tick.Field.mul zeta w in\n let tick_plonk_minimal :\n _ Composition_types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.t =\n let chal = Challenge.Constant.to_tick_field in\n { zeta\n ; alpha\n ; beta = chal plonk0.beta\n ; gamma = chal plonk0.gamma\n ; joint_combiner = Option.map ~f:sc plonk0.joint_combiner\n ; feature_flags = plonk0.feature_flags\n }\n in\n let tick_combined_evals =\n Plonk_checks.evals_of_split_evals\n (module Tick.Field)\n evals.evals.evals ~rounds:(Nat.to_int Tick.Rounds.n) ~zeta ~zetaw\n |> Plonk_types.Evals.to_in_circuit\n in\n let tick_domain =\n Plonk_checks.domain\n (module Tick.Field)\n step_domain ~shifts:Common.tick_shifts\n ~domain_generator:Backend.Tick.Field.domain_generator\n in\n let tick_env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tick.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~endo:Endo.Step_inner_curve.base ~mds:Tick_field_sponge.params.mds\n ~srs_length_log2:Common.Max_degree.step_log2\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fp.of_bigint )\n ~domain:tick_domain tick_plonk_minimal tick_combined_evals\n in\n let plonk =\n let p =\n let module Field = struct\n include Tick.Field\n end in\n Plonk_checks.Type1.derive_plonk\n (module Field)\n ~shift:Shifts.tick1 ~env:tick_env tick_plonk_minimal tick_combined_evals\n in\n { p with\n zeta = plonk0.zeta\n ; alpha = plonk0.alpha\n ; beta = plonk0.beta\n ; gamma = plonk0.gamma\n ; joint_combiner = plonk0.joint_combiner\n }\n in\n Timer.clock __LOC__ ;\n let absorb, squeeze =\n let open Tick_field_sponge.Bits in\n let sponge =\n let s = create Tick_field_sponge.params in\n absorb s\n (Digest.Constant.to_tick_field\n proof_state.sponge_digest_before_evaluations ) ;\n s\n in\n let squeeze () =\n let underlying =\n Challenge.Constant.of_bits\n (squeeze sponge ~length:Challenge.Constant.length)\n in\n Scalar_challenge.create underlying\n in\n (absorb sponge, squeeze)\n in\n let old_bulletproof_challenges =\n Vector.map ~f:Ipa.Step.compute_challenges old_bulletproof_challenges\n in\n (let challenges_digest =\n let open Tick_field_sponge.Field in\n let sponge = create Tick_field_sponge.params in\n Vector.iter old_bulletproof_challenges ~f:(Vector.iter ~f:(absorb sponge)) ;\n squeeze sponge\n in\n absorb challenges_digest ;\n absorb evals.ft_eval1 ;\n let xs = Plonk_types.Evals.to_absorption_sequence evals.evals.evals in\n let x1, x2 = evals.evals.public_input in\n absorb x1 ;\n absorb x2 ;\n List.iter xs ~f:(fun (x1, x2) ->\n Array.iter ~f:absorb x1 ; Array.iter ~f:absorb x2 ) ) ;\n let xi_chal = squeeze () in\n let xi = sc xi_chal in\n let r_chal = squeeze () in\n let r = sc r_chal in\n Timer.clock __LOC__ ;\n (* TODO: The deferred values \"bulletproof_challenges\" should get routed\n into a \"batch dlog Tick acc verifier\" *)\n let actual_proofs_verified = Vector.length old_bulletproof_challenges in\n Timer.clock __LOC__ ;\n let combined_inner_product_actual =\n Wrap.combined_inner_product ~env:tick_env ~plonk:tick_plonk_minimal\n ~domain:tick_domain ~ft_eval1:evals.ft_eval1\n ~actual_proofs_verified:(Nat.Add.create actual_proofs_verified)\n evals.evals ~old_bulletproof_challenges ~r ~xi ~zeta ~zetaw\n in\n Timer.clock __LOC__ ;\n let bulletproof_challenges =\n Ipa.Step.compute_challenges bulletproof_challenges\n in\n Timer.clock __LOC__ ;\n let b_actual =\n let challenge_poly =\n unstage\n (Wrap.challenge_polynomial (Vector.to_array bulletproof_challenges))\n in\n Tick.Field.(challenge_poly zeta + (r * challenge_poly zetaw))\n in\n let to_shifted =\n Shifted_value.Type1.of_field (module Tick.Field) ~shift:Shifts.tick1\n in\n { xi = xi_chal\n ; plonk\n ; combined_inner_product = to_shifted combined_inner_product_actual\n ; branch_data\n ; bulletproof_challenges\n ; b = to_shifted b_actual\n }\n","module SC = Scalar_challenge\nopen Pickles_types\nopen Common\nopen Import\n\nmodule Instance = struct\n type t =\n | T :\n (module Nat.Intf with type n = 'n)\n * (module Intf.Statement_value with type t = 'a)\n * Verification_key.t\n * 'a\n * ('n, 'n) Proof.t\n -> t\nend\n\nlet verify_heterogenous (ts : Instance.t list) =\n let module Tick_field = Backend.Tick.Field in\n let logger = Internal_tracing_context_logger.get () in\n [%log internal] \"Verify_heterogenous\"\n ~metadata:[ (\"count\", `Int (List.length ts)) ] ;\n let tick_field : _ Plonk_checks.field = (module Tick_field) in\n let check, result =\n let r = ref [] in\n let result () =\n match !r with\n | [] ->\n Ok ()\n | _ ->\n Error\n ( Error.tag ~tag:\"Pickles.verify\"\n @@ Error.of_list\n @@ List.map !r ~f:(fun lab -> Error.of_string (Lazy.force lab)) )\n in\n ((fun (lab, b) -> if not b then r := lab :: !r), result)\n in\n [%log internal] \"Compute_plonks_and_chals\" ;\n let _computed_bp_chals, deferred_values =\n List.map ts\n ~f:(fun\n (T\n ( _max_proofs_verified\n , _statement\n , key\n , _app_state\n , T\n { statement =\n { proof_state\n ; messages_for_next_step_proof =\n { old_bulletproof_challenges; _ }\n }\n ; prev_evals = evals\n ; proof = _\n } ) )\n ->\n Timer.start __LOC__ ;\n let non_chunking =\n let exception Is_chunked in\n match\n Pickles_types.Plonk_types.Evals.map evals.evals.evals\n ~f:(fun (x, y) ->\n if Array.length x > 1 || Array.length y > 1 then\n raise Is_chunked )\n with\n | exception Is_chunked ->\n false\n | _unit_evals ->\n (* we do not care about _unit_evals, if we reached this point, we\n know all evals have length 1 for they cannot have length 0 *)\n true\n in\n check (lazy \"only uses single chunks\", non_chunking) ;\n check\n ( lazy \"feature flags are consistent with evaluations\"\n , Pickles_types.Plonk_types.Evals.validate_feature_flags\n ~feature_flags:proof_state.deferred_values.plonk.feature_flags\n evals.evals.evals ) ;\n Timer.start __LOC__ ;\n let open Types.Wrap.Proof_state in\n let step_domain =\n Branch_data.domain proof_state.deferred_values.branch_data\n in\n check\n ( lazy \"domain size is small enough\"\n , Domain.log2_size step_domain <= Nat.to_int Backend.Tick.Rounds.n ) ;\n let sc =\n SC.to_field_constant tick_field ~endo:Endo.Wrap_inner_curve.scalar\n in\n Timer.clock __LOC__ ;\n let { Deferred_values.Minimal.plonk = _\n ; branch_data = _\n ; bulletproof_challenges\n } =\n Deferred_values.Minimal.map_challenges\n ~f:Challenge.Constant.to_tick_field ~scalar:sc\n proof_state.deferred_values\n in\n Timer.clock __LOC__ ;\n let deferred_values =\n Wrap_deferred_values.expand_deferred ~evals\n ~old_bulletproof_challenges ~proof_state\n in\n Timer.clock __LOC__ ;\n let deferred_values = { deferred_values with bulletproof_challenges } in\n let () =\n let [ Pow_2_roots_of_unity greatest_wrap_domain\n ; _\n ; Pow_2_roots_of_unity least_wrap_domain\n ] =\n Wrap_verifier.all_possible_domains ()\n in\n let actual_wrap_domain = key.index.domain.log_size_of_group in\n check\n ( lazy\n (sprintf !\"wrap_domain: %i > %i\" actual_wrap_domain\n least_wrap_domain )\n , Int.( <= ) actual_wrap_domain least_wrap_domain ) ;\n check\n ( lazy\n (sprintf !\"wrap_domain: %i < %i\" actual_wrap_domain\n greatest_wrap_domain )\n , Int.( >= ) actual_wrap_domain greatest_wrap_domain )\n in\n (bulletproof_challenges, deferred_values) )\n |> List.unzip\n in\n [%log internal] \"Compute_plonks_and_chals_done\" ;\n let open Backend.Tock.Proof in\n let open Promise.Let_syntax in\n [%log internal] \"Accumulator_check\" ;\n let%bind accumulator_check =\n Ipa.Step.accumulator_check\n (List.map ts ~f:(fun (T (_, _, _, _, T t)) ->\n ( t.statement.proof_state.messages_for_next_wrap_proof\n .challenge_polynomial_commitment\n , Ipa.Step.compute_challenges\n t.statement.proof_state.deferred_values.bulletproof_challenges ) )\n )\n in\n [%log internal] \"Accumulator_check_done\" ;\n Common.time \"batch_step_dlog_check\" (fun () ->\n check (lazy \"batch_step_dlog_check\", accumulator_check) ) ;\n [%log internal] \"Compute_batch_verify_inputs\" ;\n let batch_verify_inputs =\n List.map2_exn ts deferred_values\n ~f:(fun\n (T\n ( (module Max_proofs_verified)\n , (module A_value)\n , key\n , app_state\n , T t ) )\n deferred_values\n ->\n let prepared_statement : _ Types.Wrap.Statement.In_circuit.t =\n { messages_for_next_step_proof =\n Common.hash_messages_for_next_step_proof\n ~app_state:A_value.to_field_elements\n (Reduced_messages_for_next_proof_over_same_field.Step.prepare\n ~dlog_plonk_index:key.commitments\n { t.statement.messages_for_next_step_proof with app_state } )\n ; proof_state =\n { deferred_values =\n { plonk = deferred_values.plonk\n ; combined_inner_product =\n deferred_values.combined_inner_product\n ; b = deferred_values.b\n ; xi = deferred_values.xi\n ; bulletproof_challenges =\n deferred_values.bulletproof_challenges\n ; branch_data = deferred_values.branch_data\n }\n ; sponge_digest_before_evaluations =\n t.statement.proof_state.sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof =\n Wrap_hack.hash_messages_for_next_wrap_proof\n Max_proofs_verified.n\n (Reduced_messages_for_next_proof_over_same_field.Wrap\n .prepare\n t.statement.proof_state.messages_for_next_wrap_proof )\n }\n }\n in\n let input =\n tock_unpadded_public_input_of_statement\n ~feature_flags:Plonk_types.Features.Full.maybe prepared_statement\n in\n let message =\n Wrap_hack.pad_accumulator\n (Vector.map2\n ~f:(fun g cs ->\n { Challenge_polynomial.challenges =\n Vector.to_array (Ipa.Wrap.compute_challenges cs)\n ; commitment = g\n } )\n (Vector.extend_front_exn\n t.statement.messages_for_next_step_proof\n .challenge_polynomial_commitments Max_proofs_verified.n\n (Lazy.force Dummy.Ipa.Wrap.sg) )\n t.statement.proof_state.messages_for_next_wrap_proof\n .old_bulletproof_challenges )\n in\n ( key.index\n , { proof = Wrap_wire_proof.to_kimchi_proof t.proof\n ; public_evals = None\n }\n , input\n , Some message ) )\n in\n [%log internal] \"Compute_batch_verify_inputs_done\" ;\n [%log internal] \"Dlog_check_batch_verify\" ;\n let%map dlog_check = batch_verify batch_verify_inputs in\n [%log internal] \"Dlog_check_batch_verify_done\" ;\n Common.time \"dlog_check\" (fun () -> check (lazy \"dlog_check\", dlog_check)) ;\n result ()\n\nlet verify (type a n) (max_proofs_verified : (module Nat.Intf with type n = n))\n (a_value : (module Intf.Statement_value with type t = a))\n (key : Verification_key.t) (ts : (a * (n, n) Proof.t) list) =\n verify_heterogenous\n (List.map ts ~f:(fun (x, p) ->\n Instance.T (max_proofs_verified, a_value, key, x, p) ) )\n","open Pickles_types\nopen Hlist\nopen Import\nopen Impls.Step\nopen Step_verifier\nmodule B = Inductive_rule.B\n\n(* Converts from the one hot vector representation of a number\n 0 <= i < n\n\n 0 1 ... i-1 i i+1 n-1\n [ 0; 0; ... 0; 1; 0; ...; 0 ]\n\n to the numeric representation i. *)\n\nlet _one_hot_vector_to_num (type n) (v : n Per_proof_witness.One_hot_vector.t) :\n Field.t =\n let n = Vector.length (v :> (Boolean.var, n) Vector.t) in\n Pseudo.choose (v, Vector.init n ~f:Field.of_int) ~f:Fn.id\n\nlet verify_one ~srs\n ({ app_state\n ; wrap_proof\n ; proof_state\n ; prev_proof_evals\n ; prev_challenges\n ; prev_challenge_polynomial_commitments\n } :\n _ Per_proof_witness.t ) (d : _ Types_map.For_step.t)\n (messages_for_next_wrap_proof : Digest.t) (unfinalized : Unfinalized.t)\n (should_verify : B.t) : _ Vector.t * B.t =\n Boolean.Assert.( = ) unfinalized.should_finalize should_verify ;\n let deferred_values = proof_state.deferred_values in\n let finalized, chals =\n with_label __LOC__ (fun () ->\n let sponge_digest = proof_state.sponge_digest_before_evaluations in\n let sponge =\n let open Step_main_inputs in\n let sponge = Sponge.create sponge_params in\n Sponge.absorb sponge (`Field sponge_digest) ;\n sponge\n in\n (* TODO: Refactor args into an \"unfinalized proof\" struct *)\n finalize_other_proof d.max_proofs_verified ~step_domains:d.step_domains\n ~sponge ~prev_challenges deferred_values prev_proof_evals )\n in\n let branch_data = deferred_values.branch_data in\n let sponge_after_index, hash_messages_for_next_step_proof =\n let to_field_elements =\n let (Typ typ) = d.public_input in\n fun x -> fst (typ.var_to_fields x)\n in\n let sponge_after_index, hash_messages_for_next_step_proof =\n (* TODO: Don't rehash when it's not necessary *)\n hash_messages_for_next_step_proof_opt ~index:d.wrap_key to_field_elements\n in\n (sponge_after_index, unstage hash_messages_for_next_step_proof)\n in\n (* prepare the statement to be verified below *)\n let statement =\n let prev_messages_for_next_step_proof =\n with_label __LOC__ (fun () ->\n hash_messages_for_next_step_proof ~widths:d.proofs_verifieds\n ~max_width:(Nat.Add.n d.max_proofs_verified)\n ~proofs_verified_mask:\n (Vector.trim_front branch_data.proofs_verified_mask\n (Nat.lte_exn\n (Vector.length prev_challenge_polynomial_commitments)\n Nat.N2.n ) )\n (* Use opt sponge for cutting off the bulletproof challenges early *)\n { app_state\n ; dlog_plonk_index = d.wrap_key\n ; challenge_polynomial_commitments =\n prev_challenge_polynomial_commitments\n ; old_bulletproof_challenges = prev_challenges\n } )\n in\n (* Returns messages for the next step proof and messages for the next\n wrap proof *)\n { Types.Wrap.Statement.messages_for_next_step_proof =\n prev_messages_for_next_step_proof\n ; proof_state = { proof_state with messages_for_next_wrap_proof }\n }\n in\n (* and when the statement is prepared, we call the step verifier with this\n statement *)\n let verified =\n with_label __LOC__ (fun () ->\n verify ~srs\n ~feature_flags:(Plonk_types.Features.of_full d.feature_flags)\n ~lookup_parameters:\n { use = d.feature_flags.uses_lookups\n ; zero =\n { var =\n { challenge = Field.zero\n ; scalar = Shifted_value Field.zero\n }\n ; value =\n { challenge = Limb_vector.Challenge.Constant.zero\n ; scalar =\n Shifted_value.Type1.Shifted_value Field.Constant.zero\n }\n }\n }\n ~proofs_verified:d.max_proofs_verified ~wrap_domain:d.wrap_domain\n ~is_base_case:(Boolean.not should_verify)\n ~sponge_after_index ~sg_old:prev_challenge_polynomial_commitments\n ~proof:wrap_proof ~wrap_verification_key:d.wrap_key statement\n unfinalized )\n in\n if debug then\n as_prover\n As_prover.(\n fun () ->\n let finalized = read Boolean.typ finalized in\n let verified = read Boolean.typ verified in\n let should_verify = read Boolean.typ should_verify in\n printf \"finalized: %b\\n%!\" finalized ;\n printf \"verified: %b\\n%!\" verified ;\n printf \"should_verify: %b\\n\\n%!\" should_verify) ;\n (chals, Boolean.(verified &&& finalized ||| not should_verify))\n\n(* The SNARK function corresponding to the input inductive rule. *)\nlet step_main :\n type proofs_verified self_branches prev_vars prev_values var value a_var a_value ret_var ret_value auxiliary_var auxiliary_value max_proofs_verified local_branches local_signature.\n (module Requests.Step.S\n with type local_signature = local_signature\n and type local_branches = local_branches\n and type statement = a_value\n and type prev_values = prev_values\n and type max_proofs_verified = max_proofs_verified\n and type proofs_verified = proofs_verified\n and type return_value = ret_value\n and type auxiliary_value = auxiliary_value )\n -> (module Nat.Add.Intf with type n = max_proofs_verified)\n -> self_branches:self_branches Nat.t\n (* How many branches does this proof system have *)\n -> local_signature:local_signature H1.T(Nat).t\n (* The specification, for each proof that this step circuit verifies, of the maximum width used\n by that proof system. *)\n -> local_signature_length:(local_signature, proofs_verified) Hlist.Length.t\n -> local_branches:\n (* For each inner proof of type T , the number of branches that type T has. *)\n local_branches H1.T(Nat).t\n -> local_branches_length:(local_branches, proofs_verified) Hlist.Length.t\n -> proofs_verified:(prev_vars, proofs_verified) Hlist.Length.t\n -> lte:(proofs_verified, max_proofs_verified) Nat.Lte.t\n -> public_input:\n ( var\n , value\n , a_var\n , a_value\n , ret_var\n , ret_value )\n Inductive_rule.public_input\n -> auxiliary_typ:(auxiliary_var, auxiliary_value) Typ.t\n -> basic:\n ( var\n , value\n , max_proofs_verified\n , self_branches )\n Types_map.Compiled.basic\n -> self:(var, value, max_proofs_verified, self_branches) Tag.t\n -> ( prev_vars\n , prev_values\n , local_signature\n , local_branches\n , a_var\n , a_value\n , ret_var\n , ret_value\n , auxiliary_var\n , auxiliary_value )\n Inductive_rule.t\n -> ( unit\n -> ( (Unfinalized.t, max_proofs_verified) Vector.t\n , Field.t\n , (Field.t, max_proofs_verified) Vector.t )\n Types.Step.Statement.t )\n Staged.t =\n fun (module Req) max_proofs_verified ~self_branches ~local_signature\n ~local_signature_length ~local_branches ~local_branches_length\n ~proofs_verified ~lte ~public_input ~auxiliary_typ ~basic ~self rule ->\n let module Typ_with_max_proofs_verified = struct\n type ('var, 'value, 'local_max_proofs_verified, 'local_branches) t =\n ( ( 'var\n , 'local_max_proofs_verified\n , 'local_branches )\n Per_proof_witness.No_app_state.t\n , ( 'value\n , 'local_max_proofs_verified\n , 'local_branches )\n Per_proof_witness.Constant.No_app_state.t )\n Typ.t\n end in\n let feature_flags (d : _ Tag.t) =\n if Type_equal.Id.same self.id d.id then basic.feature_flags\n else Types_map.feature_flags d\n in\n let feature_flags =\n let rec go :\n type pvars pvals ns1 ns2 br.\n (pvars, pvals, ns1, ns2) H4.T(Tag).t\n -> (pvars, br) Length.t\n -> (Opt.Flag.t Plonk_types.Features.Full.t, br) Vector.t =\n fun ds ld ->\n match[@warning \"-4\"] (ds, ld) with\n | [], Z ->\n []\n | d :: ds, S ld ->\n feature_flags d :: go ds ld\n | [], _ ->\n .\n | _ :: _, _ ->\n .\n in\n go rule.prevs proofs_verified\n in\n let prev_proof_typs =\n let rec join :\n type pvars pvals ns1 ns2 br.\n (pvars, pvals, ns1, ns2) H4.T(Tag).t\n -> ns1 H1.T(Nat).t\n -> ns2 H1.T(Nat).t\n -> (pvars, br) Length.t\n -> (ns1, br) Length.t\n -> (ns2, br) Length.t\n -> (Opt.Flag.t Plonk_types.Features.Full.t, br) Vector.t\n -> (pvars, pvals, ns1, ns2) H4.T(Typ_with_max_proofs_verified).t =\n fun ds ns1 ns2 ld ln1 ln2 feature_flagss ->\n match[@warning \"-4\"] (ds, ns1, ns2, ld, ln1, ln2, feature_flagss) with\n | [], [], [], Z, Z, Z, [] ->\n []\n | ( _d :: ds\n , n1 :: ns1\n , _n2 :: ns2\n , S ld\n , S ln1\n , S ln2\n , feature_flags :: feature_flagss ) ->\n let t = Per_proof_witness.typ Typ.unit n1 ~feature_flags in\n t :: join ds ns1 ns2 ld ln1 ln2 feature_flagss\n | [], _, _, _, _, _, _ ->\n .\n | _ :: _, _, _, _, _, _, _ ->\n .\n in\n join rule.prevs local_signature local_branches proofs_verified\n local_signature_length local_branches_length feature_flags\n in\n let module Prev_typ =\n H4.Typ (Impls.Step) (Typ_with_max_proofs_verified)\n (Per_proof_witness.No_app_state)\n (Per_proof_witness.Constant.No_app_state)\n (struct\n let f = Fn.id\n end)\n in\n let (input_typ, output_typ)\n : (a_var, a_value) Typ.t * (ret_var, ret_value) Typ.t =\n match public_input with\n | Input typ ->\n (typ, Typ.unit)\n | Output typ ->\n (Typ.unit, typ)\n | Input_and_output (input_typ, output_typ) ->\n (input_typ, output_typ)\n in\n let main () : _ Types.Step.Statement.t =\n let open Impls.Step in\n let logger = Internal_tracing_context_logger.get () in\n with_label \"step_main\" (fun () ->\n let module Max_proofs_verified = ( val max_proofs_verified : Nat.Add.Intf\n with type n = max_proofs_verified\n )\n in\n let T = Max_proofs_verified.eq in\n let app_state = exists input_typ ~request:(fun () -> Req.App_state) in\n let { Inductive_rule.previous_proof_statements\n ; public_output = ret_var\n ; auxiliary_output = auxiliary_var\n } =\n (* Run the application logic of the rule on the predecessor statements *)\n with_label \"rule_main\" (fun () ->\n rule.main { public_input = app_state } )\n in\n let () =\n exists Typ.unit ~request:(fun () ->\n let ret_value = As_prover.read output_typ ret_var in\n Req.Return_value ret_value )\n in\n let () =\n exists Typ.unit ~request:(fun () ->\n let auxiliary_value =\n As_prover.read auxiliary_typ auxiliary_var\n in\n Req.Auxiliary_value auxiliary_value )\n in\n (* Compute proof parts outside of the prover before requesting values.\n *)\n exists Typ.unit ~request:(fun () ->\n let previous_proof_statements =\n let rec go :\n type prev_vars prev_values ns1 ns2.\n ( prev_vars\n , ns1 )\n H2.T(Inductive_rule.Previous_proof_statement).t\n -> (prev_vars, prev_values, ns1, ns2) H4.T(Tag).t\n -> ( prev_values\n , ns1 )\n H2.T(Inductive_rule.Previous_proof_statement.Constant).t =\n fun previous_proof_statement tags ->\n match (previous_proof_statement, tags) with\n | [], [] ->\n []\n | ( { public_input; proof; proof_must_verify } :: stmts\n , tag :: tags ) ->\n let public_input =\n (fun (type var value n m) (tag : (var, value, n, m) Tag.t)\n (var : var) : value ->\n let typ : (var, value) Typ.t =\n match Type_equal.Id.same_witness self.id tag.id with\n | Some T ->\n basic.public_input\n | None ->\n Types_map.public_input tag\n in\n As_prover.read typ var )\n tag public_input\n in\n { public_input\n ; proof = As_prover.Ref.get proof\n ; proof_must_verify =\n As_prover.read Boolean.typ proof_must_verify\n }\n :: go stmts tags\n in\n go previous_proof_statements rule.prevs\n in\n Req.Compute_prev_proof_parts previous_proof_statements ) ;\n let dlog_plonk_index =\n exists\n ~request:(fun () -> Req.Wrap_index)\n (Plonk_verification_key_evals.typ Inner_curve.typ)\n and prevs =\n exists (Prev_typ.f prev_proof_typs) ~request:(fun () ->\n Req.Proof_with_datas )\n and unfinalized_proofs_unextended =\n exists\n (Vector.typ'\n (Vector.map\n ~f:(fun _feature_flags ->\n Unfinalized.typ ~wrap_rounds:Backend.Tock.Rounds.n )\n feature_flags ) )\n ~request:(fun () -> Req.Unfinalized_proofs)\n and messages_for_next_wrap_proof =\n exists (Vector.typ Digest.typ Max_proofs_verified.n)\n ~request:(fun () -> Req.Messages_for_next_wrap_proof)\n and actual_wrap_domains =\n exists\n (Vector.typ (Typ.Internal.ref ()) (Length.to_nat proofs_verified))\n ~request:(fun () -> Req.Wrap_domain_indices)\n in\n let prevs =\n (* Inject the app-state values into the per-proof witnesses. *)\n let rec go :\n type vars ns1 ns2.\n (vars, ns1, ns2) H3.T(Per_proof_witness.No_app_state).t\n -> (vars, ns1) H2.T(Inductive_rule.Previous_proof_statement).t\n -> (vars, ns1, ns2) H3.T(Per_proof_witness).t =\n fun proofs stmts ->\n match (proofs, stmts) with\n | [], [] ->\n []\n | proof :: proofs, stmt :: stmts ->\n { proof with app_state = stmt.public_input } :: go proofs stmts\n in\n go prevs previous_proof_statements\n in\n let srs = Backend.Tock.Keypair.load_urs () in\n [%log internal] \"Step_compute_bulletproof_challenges\" ;\n let bulletproof_challenges =\n with_label \"prevs_verified\" (fun () ->\n let rec go :\n type vars vals ns1 ns2 n.\n (vars, ns1, ns2) H3.T(Per_proof_witness).t\n -> (vars, vals, ns1, ns2) H4.T(Types_map.For_step).t\n -> vars H1.T(E01(Digest)).t\n -> vars H1.T(E01(Unfinalized)).t\n -> (vars, ns1) H2.T(Inductive_rule.Previous_proof_statement).t\n -> (vars, n) Length.t\n -> actual_wrap_domains:\n ( Pickles_base.Proofs_verified.t As_prover.Ref.t\n , n )\n Vector.t\n -> (_, n) Vector.t * B.t list =\n fun proofs datas messages_for_next_wrap_proofs unfinalizeds stmts\n pi ~actual_wrap_domains ->\n match\n ( proofs\n , datas\n , messages_for_next_wrap_proofs\n , unfinalizeds\n , stmts\n , pi\n , actual_wrap_domains )\n with\n | [], [], [], [], [], Z, [] ->\n ([], [])\n | ( p :: proofs\n , d :: datas\n , messages_for_next_wrap_proof\n :: messages_for_next_wrap_proofs\n , unfinalized :: unfinalizeds\n , { proof_must_verify = should_verify; _ } :: stmts\n , S pi\n , actual_wrap_domain :: actual_wrap_domains ) ->\n let () =\n (* Fail with an error if the proof's domain differs from\n the hard-coded one otherwise.\n *)\n match d.wrap_domain with\n | `Known wrap_domain ->\n as_prover (fun () ->\n let actual_wrap_domain =\n As_prover.Ref.get actual_wrap_domain\n |> Pickles_base.Proofs_verified.to_int\n in\n let actual_wrap_domain =\n Common.wrap_domains\n ~proofs_verified:actual_wrap_domain\n in\n match (wrap_domain, actual_wrap_domain.h) with\n | ( Pow_2_roots_of_unity expected\n , Pow_2_roots_of_unity actual )\n when expected <> actual ->\n failwithf\n \"This circuit was compiled for proofs \\\n using the wrap domain of size %d, but a \\\n proof was given with size %d. You should \\\n pass the ~override_wrap_domain argument \\\n to set the correct domain size.\"\n expected actual ()\n | Pow_2_roots_of_unity _, Pow_2_roots_of_unity _\n ->\n () )\n | `Side_loaded _ ->\n ()\n in\n let chals, v =\n verify_one ~srs p d messages_for_next_wrap_proof\n unfinalized should_verify\n in\n let chalss, vs =\n go proofs datas messages_for_next_wrap_proofs unfinalizeds\n stmts pi ~actual_wrap_domains\n in\n (chals :: chalss, v :: vs)\n in\n let chalss, vs =\n let messages_for_next_wrap_proofs =\n with_label \"messages_for_next_wrap_proofs\" (fun () ->\n let module V = H1.Of_vector (Digest) in\n V.f proofs_verified\n (Vector.trim_front messages_for_next_wrap_proof lte) )\n and unfinalized_proofs =\n let module H = H1.Of_vector (Unfinalized) in\n H.f proofs_verified unfinalized_proofs_unextended\n and datas =\n let self_data :\n ( var\n , value\n , max_proofs_verified\n , self_branches )\n Types_map.For_step.t =\n { branches = self_branches\n ; proofs_verifieds =\n `Known\n (Vector.map basic.proofs_verifieds ~f:Field.of_int)\n ; max_proofs_verified\n ; public_input = basic.public_input\n ; wrap_domain = `Known basic.wrap_domains.h\n ; step_domains = `Known basic.step_domains\n ; wrap_key = dlog_plonk_index\n ; feature_flags = basic.feature_flags\n }\n in\n let module M =\n H4.Map (Tag) (Types_map.For_step)\n (struct\n let f :\n type a1 a2 n m.\n (a1, a2, n, m) Tag.t\n -> (a1, a2, n, m) Types_map.For_step.t =\n fun tag ->\n match Type_equal.Id.same_witness self.id tag.id with\n | Some T ->\n self_data\n | None -> (\n match tag.kind with\n | Compiled ->\n Types_map.For_step.of_compiled\n (Types_map.lookup_compiled tag.id)\n | Side_loaded ->\n Types_map.For_step.of_side_loaded\n (Types_map.lookup_side_loaded tag.id) )\n end)\n in\n M.f rule.prevs\n in\n go prevs datas messages_for_next_wrap_proofs unfinalized_proofs\n previous_proof_statements proofs_verified ~actual_wrap_domains\n in\n Boolean.Assert.all vs ; chalss )\n in\n [%log internal] \"Step_compute_bulletproof_challenges_done\" ;\n let messages_for_next_step_proof =\n let challenge_polynomial_commitments =\n let module M =\n H3.Map (Per_proof_witness) (E03 (Inner_curve))\n (struct\n let f :\n type a b c. (a, b, c) Per_proof_witness.t -> Inner_curve.t\n =\n fun acc ->\n acc.wrap_proof.opening.challenge_polynomial_commitment\n end)\n in\n let module V = H3.To_vector (Inner_curve) in\n V.f proofs_verified (M.f prevs)\n in\n with_label \"hash_messages_for_next_step_proof\" (fun () ->\n let hash_messages_for_next_step_proof =\n let to_field_elements =\n let (Typ typ) = basic.public_input in\n fun x -> fst (typ.var_to_fields x)\n in\n unstage\n (hash_messages_for_next_step_proof ~index:dlog_plonk_index\n to_field_elements )\n in\n let (app_state : var) =\n match public_input with\n | Input _ ->\n app_state\n | Output _ ->\n ret_var\n | Input_and_output _ ->\n (app_state, ret_var)\n in\n hash_messages_for_next_step_proof\n { app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges =\n (* Note: the bulletproof_challenges here are unpadded! *)\n bulletproof_challenges\n } )\n in\n let unfinalized_proofs =\n Vector.extend_front unfinalized_proofs_unextended lte\n Max_proofs_verified.n (Unfinalized.dummy ())\n in\n ( { Types.Step.Statement.proof_state =\n { unfinalized_proofs; messages_for_next_step_proof }\n ; messages_for_next_wrap_proof\n }\n : ( (Unfinalized.t, max_proofs_verified) Vector.t\n , Field.t\n , (Field.t, max_proofs_verified) Vector.t )\n Types.Step.Statement.t ) )\n in\n stage main\n","open Core_kernel\nopen Pickles_types\nopen Hlist\nopen Import\n\n(* The data obtained from \"compiling\" an inductive rule into a circuit. *)\ntype ( 'a_var\n , 'a_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value\n , 'max_proofs_verified\n , 'branches\n , 'prev_vars\n , 'prev_values\n , 'local_widths\n , 'local_heights )\n t =\n | T :\n { proofs_verified :\n 'proofs_verified Nat.t * ('prev_vars, 'proofs_verified) Hlist.Length.t\n ; index : int\n ; lte : ('proofs_verified, 'max_proofs_verified) Nat.Lte.t\n ; domains : Domains.t\n ; rule :\n ( 'prev_vars\n , 'prev_values\n , 'local_widths\n , 'local_heights\n , 'a_var\n , 'a_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n Inductive_rule.t\n ; main :\n step_domains:(Domains.t, 'branches) Vector.t\n -> unit\n -> ( (Unfinalized.t, 'max_proofs_verified) Vector.t\n , Impls.Step.Field.t\n , (Impls.Step.Field.t, 'max_proofs_verified) Vector.t )\n Types.Step.Statement.t\n ; requests :\n (module Requests.Step.S\n with type statement = 'a_value\n and type max_proofs_verified = 'max_proofs_verified\n and type proofs_verified = 'proofs_verified\n and type prev_values = 'prev_values\n and type local_signature = 'local_widths\n and type local_branches = 'local_heights\n and type return_value = 'ret_value\n and type auxiliary_value = 'auxiliary_value )\n ; feature_flags : bool Plonk_types.Features.t\n }\n -> ( 'a_var\n , 'a_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value\n , 'max_proofs_verified\n , 'branches\n , 'prev_vars\n , 'prev_values\n , 'local_widths\n , 'local_heights )\n t\n\n(* Compile an inductive rule. *)\nlet create\n (type branches max_proofs_verified var value a_var a_value ret_var ret_value)\n ~index ~(self : (var, value, max_proofs_verified, branches) Tag.t)\n ~wrap_domains ~(feature_flags : Opt.Flag.t Plonk_types.Features.Full.t)\n ~(actual_feature_flags : bool Plonk_types.Features.t)\n ~(max_proofs_verified : max_proofs_verified Nat.t)\n ~(proofs_verifieds : (int, branches) Vector.t) ~(branches : branches Nat.t)\n ~(public_input :\n ( var\n , value\n , a_var\n , a_value\n , ret_var\n , ret_value )\n Inductive_rule.public_input ) ~auxiliary_typ _var_to_field_elements\n _value_to_field_elements (rule : _ Inductive_rule.t) =\n Timer.clock __LOC__ ;\n let module HT = H4.T (Tag) in\n let (T (self_width, proofs_verified)) = HT.length rule.prevs in\n let rec extract_lengths :\n type a b n m k.\n (a, b, n, m) HT.t\n -> (a, k) Length.t\n -> n H1.T(Nat).t * m H1.T(Nat).t * (n, k) Length.t * (m, k) Length.t =\n fun ts len ->\n match (ts, len) with\n | [], Z ->\n ([], [], Z, Z)\n | t :: ts, S len -> (\n let ns, ms, len_ns, len_ms = extract_lengths ts len in\n match Type_equal.Id.same_witness self.id t.id with\n | Some T ->\n (max_proofs_verified :: ns, branches :: ms, S len_ns, S len_ms)\n | None ->\n let (module M), branches =\n match t.kind with\n | Compiled ->\n let d = Types_map.lookup_compiled t.id in\n (d.max_proofs_verified, d.branches)\n | Side_loaded ->\n let d = Types_map.lookup_side_loaded t.id in\n (d.permanent.max_proofs_verified, d.permanent.branches)\n in\n let T = M.eq in\n (M.n :: ns, branches :: ms, S len_ns, S len_ms) )\n in\n Timer.clock __LOC__ ;\n let widths, heights, local_signature_length, local_branches_length =\n extract_lengths rule.prevs proofs_verified\n in\n let lte = Nat.lte_exn self_width max_proofs_verified in\n let requests = Requests.Step.create () in\n let (typ : (var, value) Impls.Step.Typ.t) =\n match public_input with\n | Input typ ->\n typ\n | Output typ ->\n typ\n | Input_and_output (input_typ, output_typ) ->\n Impls.Step.Typ.(input_typ * output_typ)\n in\n Timer.clock __LOC__ ;\n let step ~step_domains =\n Step_main.step_main requests\n (Nat.Add.create max_proofs_verified)\n rule\n ~basic:\n { public_input = typ\n ; proofs_verifieds\n ; wrap_domains\n ; step_domains\n ; feature_flags\n }\n ~public_input ~auxiliary_typ ~self_branches:branches ~proofs_verified\n ~local_signature:widths ~local_signature_length ~local_branches:heights\n ~local_branches_length ~lte ~self\n |> unstage\n in\n Timer.clock __LOC__ ;\n let own_domains =\n let main =\n step\n ~step_domains:\n (Vector.init branches ~f:(fun _ -> Fix_domains.rough_domains))\n in\n let etyp =\n Impls.Step.input ~proofs_verified:max_proofs_verified\n ~wrap_rounds:Backend.Tock.Rounds.n\n (* TODO *)\n in\n Fix_domains.domains ~feature_flags:actual_feature_flags\n (module Impls.Step)\n (T (Snarky_backendless.Typ.unit (), Fn.id, Fn.id))\n etyp main\n in\n Timer.clock __LOC__ ;\n T\n { proofs_verified = (self_width, proofs_verified)\n ; index\n ; lte\n ; rule\n ; domains = own_domains\n ; main = step\n ; requests\n ; feature_flags = actual_feature_flags\n }\n","module SC = Scalar_challenge\nopen Pickles_types\nopen Poly_types\nopen Hlist\nopen Backend\nopen Tuple_lib\nopen Import\nopen Types\nopen Common\n\n(* This contains the \"step\" prover *)\n\nmodule Make\n (A : T0) (A_value : sig\n type t\n end)\n (Max_proofs_verified : Nat.Add.Intf_transparent) =\nstruct\n let _double_zip = Double.map2 ~f:Core_kernel.Tuple2.create\n\n module E = struct\n type t = Tock.Field.t array Double.t Plonk_types.Evals.t * Tock.Field.t\n end\n\n module Plonk_checks = struct\n include Plonk_checks\n module Type1 = Plonk_checks.Make (Shifted_value.Type1) (Scalars.Tick)\n module Type2 = Plonk_checks.Make (Shifted_value.Type2) (Scalars.Tock)\n end\n\n (* The prover corresponding to the given inductive rule. *)\n let f\n (type (* The maximum number of proofs verified by one of the proof systems verified by this rule :)\n\n In other words: each of the proofs verified by this rule comes from some pickles proof system.\n\n The ith one of those proof systems has a maximum number of proofs N_i that is verified by\n a rule in proof system i. max_local_max_proof_verifieds is the max of the N_i.\n *)\n max_local_max_proof_verifieds self_branches prev_vars prev_values\n local_widths local_heights prevs_length var value ret_var ret_value\n auxiliary_var auxiliary_value ) ?handler ~proof_cache\n (T branch_data :\n ( A.t\n , A_value.t\n , ret_var\n , ret_value\n , auxiliary_var\n , auxiliary_value\n , Max_proofs_verified.n\n , self_branches\n , prev_vars\n , prev_values\n , local_widths\n , local_heights )\n Step_branch_data.t ) (next_state : A_value.t)\n ~maxes:\n (module Maxes : Pickles_types.Hlist.Maxes.S\n with type length = Max_proofs_verified.n\n and type ns = max_local_max_proof_verifieds )\n ~(prevs_length : (prev_vars, prevs_length) Length.t) ~self ~step_domains\n ~feature_flags ~self_dlog_plonk_index\n ~(public_input :\n ( var\n , value\n , A.t\n , A_value.t\n , ret_var\n , ret_value )\n Inductive_rule.public_input )\n ~(auxiliary_typ : (auxiliary_var, auxiliary_value) Impls.Step.Typ.t) pk\n self_dlog_vk :\n ( ( value\n , (_, Max_proofs_verified.n) Vector.t\n , (_, prevs_length) Vector.t\n , (_, prevs_length) Vector.t\n , _\n , (_, Max_proofs_verified.n) Vector.t )\n Proof.Base.Step.t\n * ret_value\n * auxiliary_value\n * (int, prevs_length) Vector.t )\n Promise.t =\n let logger = Internal_tracing_context_logger.get () in\n [%log internal] \"Pickles_step_proof\" ;\n let _ = auxiliary_typ in\n (* unused *)\n let _, prev_vars_length = branch_data.proofs_verified in\n let T = Length.contr prev_vars_length prevs_length in\n let (module Req) = branch_data.requests in\n let T =\n Hlist.Length.contr (snd branch_data.proofs_verified) prev_vars_length\n in\n let prev_values_length =\n let module L12 = H4.Length_1_to_2 (Tag) in\n L12.f branch_data.rule.prevs prev_vars_length\n in\n let lte = branch_data.lte in\n let module X_hat = struct\n type t = Tock.Field.t Double.t\n end in\n let module Statement_with_hashes = struct\n type t =\n ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Tick.Field.t Shifted_value.Type1.t\n , Tick.Field.t Shifted_value.Type1.t option\n , Challenge.Constant.t Scalar_challenge.t option\n , bool\n , Digest.Constant.t\n , Digest.Constant.t\n , Digest.Constant.t\n , Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n , Branch_data.t )\n Wrap.Statement.In_circuit.t\n end in\n let challenge_polynomial =\n Wrap_verifier.challenge_polynomial (module Backend.Tock.Field)\n in\n let expand_proof :\n type var value local_max_proofs_verified m.\n Impls.Wrap.Verification_key.t\n -> 'a\n -> value\n -> (local_max_proofs_verified, local_max_proofs_verified) Proof.t\n -> (var, value, local_max_proofs_verified, m) Tag.t\n -> must_verify:bool\n -> [ `Sg of Tock.Curve.Affine.t ]\n * Unfinalized.Constant.t\n * Statement_with_hashes.t\n * X_hat.t\n * ( value\n , local_max_proofs_verified\n , m )\n Per_proof_witness.Constant.No_app_state.t\n * [ `Actual_wrap_domain of int ] =\n fun dlog_vk dlog_index app_state (T t) tag ~must_verify ->\n let t =\n { t with\n statement =\n { t.statement with\n messages_for_next_step_proof =\n { t.statement.messages_for_next_step_proof with app_state }\n }\n }\n in\n let proof = Wrap_wire_proof.to_kimchi_proof t.proof in\n let data = Types_map.lookup_basic tag in\n let plonk0 = t.statement.proof_state.deferred_values.plonk in\n let plonk =\n let domain =\n Branch_data.domain t.statement.proof_state.deferred_values.branch_data\n in\n let to_field =\n SC.to_field_constant\n (module Tick.Field)\n ~endo:Endo.Wrap_inner_curve.scalar\n in\n let alpha = to_field plonk0.alpha in\n let zeta = to_field plonk0.zeta in\n let zetaw =\n Tick.Field.(\n zeta * domain_generator ~log2_size:(Domain.log2_size domain))\n in\n let combined_evals =\n Plonk_checks.evals_of_split_evals\n (module Tick.Field)\n t.prev_evals.evals.evals ~rounds:(Nat.to_int Tick.Rounds.n) ~zeta\n ~zetaw\n |> Plonk_types.Evals.to_in_circuit\n in\n let plonk_minimal =\n { Composition_types.Wrap.Proof_state.Deferred_values.Plonk.Minimal\n .zeta\n ; alpha\n ; beta = Challenge.Constant.to_tick_field plonk0.beta\n ; gamma = Challenge.Constant.to_tick_field plonk0.gamma\n ; joint_combiner = Option.map ~f:to_field plonk0.joint_combiner\n ; feature_flags = plonk0.feature_flags\n }\n in\n let env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tick.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~srs_length_log2:Common.Max_degree.step_log2\n ~endo:Endo.Step_inner_curve.base ~mds:Tick_field_sponge.params.mds\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fp.of_bigint )\n ~domain:\n (Plonk_checks.domain\n (module Tick.Field)\n domain ~shifts:Common.tick_shifts\n ~domain_generator:Backend.Tick.Field.domain_generator )\n plonk_minimal combined_evals\n in\n time \"plonk_checks\" (fun () ->\n let module Field = struct\n include Tick.Field\n end in\n Plonk_checks.Type1.derive_plonk\n (module Field)\n ~env ~shift:Shifts.tick1 plonk_minimal combined_evals )\n in\n let (module Local_max_proofs_verified) = data.max_proofs_verified in\n let T = Local_max_proofs_verified.eq in\n let statement = t.statement in\n let prev_challenges =\n (* TODO: This is redone in the call to Reduced_messages_for_next_proof_over_same_field.Wrap.prepare *)\n Vector.map ~f:Ipa.Wrap.compute_challenges\n statement.proof_state.messages_for_next_wrap_proof\n .old_bulletproof_challenges\n in\n let deferred_values_computed =\n Wrap_deferred_values.expand_deferred ~evals:t.prev_evals\n ~old_bulletproof_challenges:\n statement.messages_for_next_step_proof.old_bulletproof_challenges\n ~proof_state:statement.proof_state\n in\n let prev_statement_with_hashes :\n ( _\n , _\n , _ Shifted_value.Type1.t\n , _\n , _\n , _\n , _\n , _\n , _\n , _\n , _ )\n Wrap.Statement.In_circuit.t =\n { messages_for_next_step_proof =\n (let to_field_elements =\n let (Typ typ) = data.public_input in\n fun x -> fst (typ.value_to_fields x)\n in\n (* TODO: Only do this hashing when necessary *)\n Common.hash_messages_for_next_step_proof\n (Reduced_messages_for_next_proof_over_same_field.Step.prepare\n ~dlog_plonk_index:dlog_index\n statement.messages_for_next_step_proof )\n ~app_state:to_field_elements )\n ; proof_state =\n { deferred_values =\n (let deferred_values = deferred_values_computed in\n { plonk =\n { plonk with\n zeta = plonk0.zeta\n ; alpha = plonk0.alpha\n ; beta = plonk0.beta\n ; gamma = plonk0.gamma\n ; joint_combiner = plonk0.joint_combiner\n }\n ; combined_inner_product =\n deferred_values.combined_inner_product\n ; b = deferred_values.b\n ; xi = deferred_values.xi\n ; bulletproof_challenges =\n statement.proof_state.deferred_values\n .bulletproof_challenges\n ; branch_data = deferred_values.branch_data\n } )\n ; sponge_digest_before_evaluations =\n statement.proof_state.sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof =\n Wrap_hack.hash_messages_for_next_wrap_proof\n Local_max_proofs_verified.n\n { old_bulletproof_challenges = prev_challenges\n ; challenge_polynomial_commitment =\n statement.proof_state.messages_for_next_wrap_proof\n .challenge_polynomial_commitment\n }\n }\n }\n in\n let module O = Tock.Oracles in\n let o =\n let public_input =\n tock_public_input_of_statement ~feature_flags\n prev_statement_with_hashes\n in\n O.create dlog_vk\n ( Vector.map2\n (Vector.extend_front_exn\n statement.messages_for_next_step_proof\n .challenge_polynomial_commitments Local_max_proofs_verified.n\n (Lazy.force Dummy.Ipa.Wrap.sg) )\n (* This should indeed have length Max_proofs_verified... No! It should have type Max_proofs_verified_a. That is, the max_proofs_verified specific to a proof of this type...*)\n prev_challenges\n ~f:(fun commitment chals ->\n { Tock.Proof.Challenge_polynomial.commitment\n ; challenges = Vector.to_array chals\n } )\n |> Wrap_hack.pad_accumulator )\n public_input proof\n in\n let ((x_hat_1, _x_hat_2) as x_hat) = O.(p_eval_1 o, p_eval_2 o) in\n let scalar_chal f =\n Scalar_challenge.map ~f:Challenge.Constant.of_tock_field (f o)\n in\n let plonk0 =\n { Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.alpha =\n scalar_chal O.alpha\n ; beta = O.beta o\n ; gamma = O.gamma o\n ; zeta = scalar_chal O.zeta\n ; joint_combiner =\n Option.map\n ~f:(Scalar_challenge.map ~f:Challenge.Constant.of_tock_field)\n (O.joint_combiner_chal o)\n ; feature_flags =\n t.statement.proof_state.deferred_values.plonk.feature_flags\n }\n in\n let xi = scalar_chal O.v in\n let r = scalar_chal O.u in\n let sponge_digest_before_evaluations = O.digest_before_evaluations o in\n let to_field =\n SC.to_field_constant\n (module Tock.Field)\n ~endo:Endo.Step_inner_curve.scalar\n in\n let module As_field = struct\n let r = to_field r\n\n let xi = to_field xi\n\n let zeta = to_field plonk0.zeta\n\n let alpha = to_field plonk0.alpha\n\n let joint_combiner = O.joint_combiner o\n end in\n let w =\n Tock.Field.domain_generator ~log2_size:dlog_vk.domain.log_size_of_group\n in\n let zetaw = Tock.Field.mul As_field.zeta w in\n let new_bulletproof_challenges, b =\n let prechals =\n Array.map (O.opening_prechallenges o) ~f:(fun x ->\n Scalar_challenge.map ~f:Challenge.Constant.of_tock_field x )\n in\n let chals =\n Array.map prechals ~f:(fun x -> Ipa.Wrap.compute_challenge x)\n in\n let challenge_polynomial = unstage (challenge_polynomial chals) in\n let open As_field in\n let b =\n let open Tock.Field in\n challenge_polynomial zeta + (r * challenge_polynomial zetaw)\n in\n let prechals =\n Vector.of_list_and_length_exn\n (Array.map prechals ~f:Bulletproof_challenge.unpack |> Array.to_list)\n Tock.Rounds.n\n in\n (prechals, b)\n in\n let challenge_polynomial_commitment =\n if not must_verify then Ipa.Wrap.compute_sg new_bulletproof_challenges\n else proof.openings.proof.challenge_polynomial_commitment\n in\n let witness : _ Per_proof_witness.Constant.No_app_state.t =\n { app_state = ()\n ; proof_state =\n { prev_statement_with_hashes.proof_state with\n messages_for_next_wrap_proof = ()\n }\n ; prev_proof_evals = t.prev_evals\n ; prev_challenge_polynomial_commitments =\n Vector.extend_front_exn\n t.statement.messages_for_next_step_proof\n .challenge_polynomial_commitments Local_max_proofs_verified.n\n (Lazy.force Dummy.Ipa.Wrap.sg)\n (* TODO: This computation is also redone elsewhere. *)\n ; prev_challenges =\n Vector.extend_front_exn\n (Vector.map\n t.statement.messages_for_next_step_proof\n .old_bulletproof_challenges ~f:Ipa.Step.compute_challenges )\n Local_max_proofs_verified.n\n (Lazy.force Dummy.Ipa.Step.challenges_computed)\n ; wrap_proof =\n { opening =\n { proof.openings.proof with challenge_polynomial_commitment }\n ; messages = proof.messages\n }\n }\n in\n let tock_domain =\n Plonk_checks.domain\n (module Tock.Field)\n (Pow_2_roots_of_unity dlog_vk.domain.log_size_of_group)\n ~shifts:Common.tock_shifts\n ~domain_generator:Backend.Tock.Field.domain_generator\n in\n let tock_combined_evals =\n Plonk_checks.evals_of_split_evals\n (module Tock.Field)\n proof.openings.evals ~rounds:(Nat.to_int Tock.Rounds.n)\n ~zeta:As_field.zeta ~zetaw\n |> Plonk_types.Evals.to_in_circuit\n in\n let tock_plonk_minimal =\n { plonk0 with\n zeta = As_field.zeta\n ; alpha = As_field.alpha\n ; joint_combiner = As_field.joint_combiner\n }\n in\n let tock_env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tock.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~domain:tock_domain ~srs_length_log2:Common.Max_degree.wrap_log2\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fq.of_bigint )\n ~endo:Endo.Wrap_inner_curve.base ~mds:Tock_field_sponge.params.mds\n tock_plonk_minimal tock_combined_evals\n in\n let combined_inner_product =\n let e = proof.openings.evals in\n let b_polys =\n Vector.map\n ~f:(fun chals ->\n unstage (challenge_polynomial (Vector.to_array chals)) )\n (Wrap_hack.pad_challenges prev_challenges)\n in\n let a = Plonk_types.Evals.to_list e in\n let open As_field in\n let combine ~which_eval ~ft_eval pt =\n let f (x, y) = match which_eval with `Fst -> x | `Snd -> y in\n let v : Tock.Field.t array list =\n let a = List.map ~f a in\n List.append\n (Vector.to_list (Vector.map b_polys ~f:(fun f -> [| f pt |])))\n ([| f x_hat |] :: [| ft_eval |] :: a)\n in\n let open Tock.Field in\n Pcs_batch.combine_split_evaluations ~xi ~init:Fn.id\n ~mul_and_add:(fun ~acc ~xi fx -> fx + (xi * acc))\n v\n in\n let ft_eval0 =\n Plonk_checks.Type2.ft_eval0\n (module Tock.Field)\n ~domain:tock_domain ~env:tock_env tock_plonk_minimal\n tock_combined_evals x_hat_1\n in\n let open Tock.Field in\n combine ~which_eval:`Fst ~ft_eval:ft_eval0 As_field.zeta\n + (r * combine ~which_eval:`Snd ~ft_eval:proof.openings.ft_eval1 zetaw)\n in\n let chal = Challenge.Constant.of_tock_field in\n let plonk =\n let module Field = struct\n include Tock.Field\n end in\n (* Wrap proof, no features *)\n Plonk_checks.Type2.derive_plonk\n (module Field)\n ~env:tock_env ~shift:Shifts.tock2 tock_plonk_minimal\n tock_combined_evals\n |> Composition_types.Step.Proof_state.Deferred_values.Plonk.In_circuit\n .of_wrap\n ~assert_none:(fun x -> assert (Option.is_none (Opt.to_option x)))\n ~assert_false:(fun x -> assert (not x))\n in\n let shifted_value =\n Shifted_value.Type2.of_field (module Tock.Field) ~shift:Shifts.tock2\n in\n ( `Sg challenge_polynomial_commitment\n , { Types.Step.Proof_state.Per_proof.deferred_values =\n { plonk =\n { plonk with\n zeta = plonk0.zeta\n ; alpha = plonk0.alpha\n ; beta = chal plonk0.beta\n ; gamma = chal plonk0.gamma\n }\n ; combined_inner_product = shifted_value combined_inner_product\n ; xi\n ; bulletproof_challenges = new_bulletproof_challenges\n ; b = shifted_value b\n }\n ; should_finalize = must_verify\n ; sponge_digest_before_evaluations =\n Digest.Constant.of_tock_field sponge_digest_before_evaluations\n }\n , prev_statement_with_hashes\n , x_hat\n , witness\n , `Actual_wrap_domain dlog_vk.domain.log_size_of_group )\n in\n let challenge_polynomial_commitments = ref None in\n let unfinalized_proofs = ref None in\n let statements_with_hashes = ref None in\n let x_hats = ref None in\n let witnesses = ref None in\n let prev_proofs = ref None in\n let return_value = ref None in\n let auxiliary_value = ref None in\n let actual_wrap_domains = ref None in\n let compute_prev_proof_parts prev_proof_requests =\n let ( challenge_polynomial_commitments'\n , unfinalized_proofs'\n , statements_with_hashes'\n , x_hats'\n , witnesses'\n , prev_proofs'\n , actual_wrap_domains' ) =\n let[@warning \"-4\"] rec go :\n type vars values ns ms k.\n (vars, values, ns, ms) H4.T(Tag).t\n -> ( values\n , ns )\n H2.T(Inductive_rule.Previous_proof_statement.Constant).t\n -> (vars, k) Length.t\n -> (Tock.Curve.Affine.t, k) Vector.t\n * (Unfinalized.Constant.t, k) Vector.t\n * (Statement_with_hashes.t, k) Vector.t\n * (X_hat.t, k) Vector.t\n * ( values\n , ns\n , ms )\n H3.T(Per_proof_witness.Constant.No_app_state).t\n * (ns, ns) H2.T(Proof).t\n * (int, k) Vector.t =\n fun ts prev_proof_stmts l ->\n match (ts, prev_proof_stmts, l) with\n | [], [], Z ->\n ([], [], [], [], [], [], [])\n | ( t :: ts\n , { public_input = app_state\n ; proof = p\n ; proof_must_verify = must_verify\n }\n :: prev_proof_stmts\n , S l ) ->\n let dlog_vk, dlog_index =\n if Type_equal.Id.same self.Tag.id t.id then\n (self_dlog_vk, self_dlog_plonk_index)\n else\n let d = Types_map.lookup_basic t in\n (d.wrap_vk, d.wrap_key)\n in\n let `Sg sg, u, s, x, w, `Actual_wrap_domain domain =\n expand_proof dlog_vk dlog_index app_state p t ~must_verify\n and sgs, us, ss, xs, ws, ps, domains = go ts prev_proof_stmts l in\n ( sg :: sgs\n , u :: us\n , s :: ss\n , x :: xs\n , w :: ws\n , p :: ps\n , domain :: domains )\n | _, _ :: _, _ ->\n .\n | _, [], _ ->\n .\n in\n go branch_data.rule.prevs prev_proof_requests prev_vars_length\n in\n challenge_polynomial_commitments := Some challenge_polynomial_commitments' ;\n unfinalized_proofs := Some unfinalized_proofs' ;\n statements_with_hashes := Some statements_with_hashes' ;\n x_hats := Some x_hats' ;\n witnesses := Some witnesses' ;\n prev_proofs := Some prev_proofs' ;\n actual_wrap_domains := Some actual_wrap_domains'\n in\n let unfinalized_proofs = lazy (Option.value_exn !unfinalized_proofs) in\n let unfinalized_proofs_extended =\n lazy\n (Vector.extend_front\n (Lazy.force unfinalized_proofs)\n lte Max_proofs_verified.n\n (Lazy.force Unfinalized.Constant.dummy) )\n in\n let module Extract = struct\n module type S = sig\n type res\n\n val f : _ Proof.t -> res\n end\n end in\n let extract_from_proofs (type res)\n (module Extract : Extract.S with type res = res) =\n let rec go :\n type vars values ns ms len.\n (ns, ns) H2.T(Proof).t\n -> (values, vars, ns, ms) H4.T(Tag).t\n -> (vars, len) Length.t\n -> (res, len) Vector.t =\n fun prevs tags len ->\n match (prevs, tags, len) with\n | [], [], Z ->\n []\n | t :: prevs, _ :: tags, S len ->\n Extract.f t :: go prevs tags len\n in\n go\n (Option.value_exn !prev_proofs)\n branch_data.rule.prevs prev_values_length\n in\n let messages_for_next_step_proof :\n _ Reduced_messages_for_next_proof_over_same_field.Step.t Lazy.t =\n lazy\n (let old_bulletproof_challenges =\n extract_from_proofs\n ( module struct\n type res =\n Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n\n let f (T t : _ Proof.t) =\n t.statement.proof_state.deferred_values.bulletproof_challenges\n end )\n in\n let (return_value : ret_value) = Option.value_exn !return_value in\n let (app_state : value) =\n match public_input with\n | Input _ ->\n next_state\n | Output _ ->\n return_value\n | Input_and_output _ ->\n (next_state, return_value)\n in\n (* Have the sg be available in the opening proof and verify it. *)\n { app_state\n ; challenge_polynomial_commitments =\n Option.value_exn !challenge_polynomial_commitments\n ; old_bulletproof_challenges\n } )\n in\n let messages_for_next_step_proof_prepared =\n lazy\n (Reduced_messages_for_next_proof_over_same_field.Step.prepare\n ~dlog_plonk_index:self_dlog_plonk_index\n (Lazy.force messages_for_next_step_proof) )\n in\n let messages_for_next_wrap_proof_padded =\n let rec pad :\n type n k maxes.\n (Digest.Constant.t, k) Vector.t\n -> maxes H1.T(Nat).t\n -> (maxes, n) Hlist.Length.t\n -> (Digest.Constant.t, n) Vector.t =\n fun xs maxes l ->\n match (xs, maxes, l) with\n | [], [], Z ->\n []\n | _x :: _xs, [], Z ->\n assert false\n | x :: xs, _ :: ms, S n ->\n x :: pad xs ms n\n | [], _m :: ms, S n ->\n let t : _ Types.Wrap.Proof_state.Messages_for_next_wrap_proof.t =\n { challenge_polynomial_commitment = Lazy.force Dummy.Ipa.Step.sg\n ; old_bulletproof_challenges =\n Vector.init Max_proofs_verified.n ~f:(fun _ ->\n Lazy.force Dummy.Ipa.Wrap.challenges_computed )\n }\n in\n Wrap_hack.hash_messages_for_next_wrap_proof Max_proofs_verified.n t\n :: pad [] ms n\n in\n lazy\n (Vector.rev\n (pad\n (Vector.map\n (Vector.rev (Option.value_exn !statements_with_hashes))\n ~f:(fun s -> s.proof_state.messages_for_next_wrap_proof) )\n Maxes.maxes Maxes.length ) )\n in\n let handler (Snarky_backendless.Request.With { request; respond } as r) =\n let k x = respond (Provide x) in\n match request with\n | Req.Compute_prev_proof_parts prev_proof_requests ->\n [%log internal] \"Step_compute_prev_proof_parts\" ;\n compute_prev_proof_parts prev_proof_requests ;\n [%log internal] \"Step_compute_prev_proof_parts_done\" ;\n k ()\n | Req.Proof_with_datas ->\n k (Option.value_exn !witnesses)\n | Req.Wrap_index ->\n k self_dlog_plonk_index\n | Req.App_state ->\n k next_state\n | Req.Return_value res ->\n return_value := Some res ;\n k ()\n | Req.Auxiliary_value res ->\n auxiliary_value := Some res ;\n k ()\n | Req.Unfinalized_proofs ->\n k (Lazy.force unfinalized_proofs)\n | Req.Messages_for_next_wrap_proof ->\n k (Lazy.force messages_for_next_wrap_proof_padded)\n | Req.Wrap_domain_indices ->\n let all_possible_domains = Wrap_verifier.all_possible_domains () in\n let wrap_domain_indices =\n Vector.map (Option.value_exn !actual_wrap_domains)\n ~f:(fun domain_size ->\n let domain_index =\n Vector.foldi ~init:0 all_possible_domains\n ~f:(fun j acc (Pow_2_roots_of_unity domain) ->\n if Int.equal domain domain_size then j else acc )\n in\n Pickles_base.Proofs_verified.of_int domain_index )\n in\n k wrap_domain_indices\n | _ -> (\n match handler with\n | Some f ->\n f r\n | None ->\n Snarky_backendless.Request.unhandled )\n in\n let prev_challenge_polynomial_commitments =\n lazy\n (let to_fold_in =\n extract_from_proofs\n ( module struct\n type res = Tick.Curve.Affine.t\n\n let f (T t : _ Proof.t) =\n t.statement.proof_state.messages_for_next_wrap_proof\n .challenge_polynomial_commitment\n end )\n in\n (* emphatically NOT padded with dummies *)\n Vector.(\n map2 to_fold_in\n (Lazy.force messages_for_next_step_proof_prepared)\n .old_bulletproof_challenges ~f:(fun commitment chals ->\n { Tick.Proof.Challenge_polynomial.commitment\n ; challenges = Vector.to_array chals\n } )\n |> to_list) )\n in\n let%map.Promise ( (next_proof : Tick.Proof.with_public_evals)\n , _next_statement_hashed ) =\n let (T (input, _conv, conv_inv)) =\n Impls.Step.input ~proofs_verified:Max_proofs_verified.n\n ~wrap_rounds:Tock.Rounds.n\n in\n let { Domains.h } = Vector.nth_exn step_domains branch_data.index in\n ksprintf Common.time \"step-prover %d (%d)\" branch_data.index\n (Domain.size h)\n (fun () ->\n let promise_or_error =\n (* Use a try_with to give an informative backtrace.\n If we don't do this, the backtrace will be obfuscated by the\n Promise, and it's significantly harder to track down errors.\n This only applies to errors in the 'witness generation' stage;\n proving errors are emitted inside the promise, and are therefore\n unaffected.\n *)\n Or_error.try_with ~backtrace:true (fun () ->\n [%log internal] \"Step_generate_witness_conv\" ;\n Impls.Step.generate_witness_conv\n ~f:(fun { Impls.Step.Proof_inputs.auxiliary_inputs\n ; public_inputs\n } next_statement_hashed ->\n [%log internal] \"Backend_tick_proof_create_async\" ;\n let create_proof () =\n Backend.Tick.Proof.create_async ~primary:public_inputs\n ~auxiliary:auxiliary_inputs\n ~message:\n (Lazy.force prev_challenge_polynomial_commitments)\n pk\n in\n let%map.Promise proof =\n match proof_cache with\n | None ->\n create_proof ()\n | Some proof_cache -> (\n match\n Proof_cache.get_step_proof proof_cache ~keypair:pk\n ~public_input:public_inputs\n with\n | None ->\n let%map.Promise proof = create_proof () in\n Proof_cache.set_step_proof proof_cache ~keypair:pk\n ~public_input:public_inputs proof.proof ;\n proof\n | Some proof ->\n Promise.return\n ( { proof; public_evals = None }\n : Tick.Proof.with_public_evals ) )\n in\n [%log internal] \"Backend_tick_proof_create_async_done\" ;\n (proof, next_statement_hashed) )\n ~input_typ:Impls.Step.Typ.unit ~return_typ:input\n (fun () () ->\n Impls.Step.handle\n (fun () -> conv_inv (branch_data.main ~step_domains ()))\n handler ) )\n in\n (* Re-raise any captured errors, complete with their backtrace. *)\n Or_error.ok_exn promise_or_error )\n ()\n in\n let prev_evals =\n extract_from_proofs\n ( module struct\n type res = E.t\n\n let f (T t : _ Proof.t) =\n let proof = Wrap_wire_proof.to_kimchi_proof t.proof in\n (proof.openings.evals, proof.openings.ft_eval1)\n end )\n in\n let messages_for_next_wrap_proof =\n let rec go :\n type a.\n (a, a) H2.T(Proof).t\n -> a H1.T(Proof.Base.Messages_for_next_proof_over_same_field.Wrap).t =\n function\n | [] ->\n []\n | T t :: tl ->\n t.statement.proof_state.messages_for_next_wrap_proof :: go tl\n in\n go (Option.value_exn !prev_proofs)\n in\n let next_statement : _ Types.Step.Statement.t =\n { proof_state =\n { unfinalized_proofs = Lazy.force unfinalized_proofs_extended\n ; messages_for_next_step_proof =\n Lazy.force messages_for_next_step_proof\n }\n ; messages_for_next_wrap_proof\n }\n in\n [%log internal] \"Pickles_step_proof_done\" ;\n ( { Proof.Base.Step.proof = next_proof.proof\n ; statement = next_statement\n ; index = branch_data.index\n ; prev_evals =\n Vector.extend_front\n (Vector.map2 prev_evals (Option.value_exn !x_hats)\n ~f:(fun (es, ft_eval1) x_hat ->\n Plonk_types.All_evals.\n { ft_eval1\n ; evals =\n { With_public_input.evals = es; public_input = x_hat }\n } ) )\n lte Max_proofs_verified.n (Lazy.force Dummy.evals)\n }\n , Option.value_exn !return_value\n , Option.value_exn !auxiliary_value\n , Option.value_exn !actual_wrap_domains )\nend\n","type t = [ `Cache_hit | `Generated_something | `Locally_generated ]\n\nlet ( + ) x y =\n match (x, y) with\n | `Generated_something, _ | _, `Generated_something ->\n `Generated_something\n | `Locally_generated, _ | _, `Locally_generated ->\n `Locally_generated\n | `Cache_hit, `Cache_hit ->\n `Cache_hit\n","type t = Dirty.t Lazy.t\n\nlet generate_or_load (t : t) = Lazy.force t\n\nlet ( + ) (t1 : t) (t2 : t) : t = lazy Dirty.(Lazy.force t1 + Lazy.force t2)\n","\nlet params =\n lazy\n (let module T =\n struct\n type t =\n Pickles.Backend.Tick.Field.Stable.Latest.t Group_map.Params.t\n [@@deriving bin_io_unversioned]\n end in\n Core_kernel.Binable.of_string (module T)\n \"\\002\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000i\\2196c[?\\152\\181p\\196\\252\\251\\244\\181\\140\\151w\\n\\154\\140\\220>\\209\\197|\\215\\162<\\2361\\247\\026\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\003\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\005\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\");;\n","let () = Pickles.Backend.Tock.Keypair.set_urs_info Cache_dir.cache\n\nlet () = Pickles.Backend.Tick.Keypair.set_urs_info Cache_dir.cache\n\nmodule Tock = struct\n module Full = Pickles.Impls.Wrap\n module Run = Pickles.Impls.Wrap\n\n let group_map_params () = Lazy.force Group_map_params.params\n\n include Full.Internal_Basic\n module Number = Snarky_backendless.Number.Make (Full.Internal_Basic)\n module Enumerable = Snarky_backendless.Enumerable.Make (Full.Internal_Basic)\n module Inner_curve = Pickles.Backend.Tock.Inner_curve\nend\n\nmodule Tick = struct\n module Full = Pickles.Impls.Step\n module Run = Pickles.Impls.Step\n\n let group_map_params =\n Group_map.Params.create\n (module Pickles.Backend.Tock.Field)\n Pickles.Backend.Tock.Inner_curve.Params.{ a; b }\n\n include Full.Internal_Basic\n module Number = Snarky_backendless.Number.Make (Full.Internal_Basic)\n module Enumerable = Snarky_backendless.Enumerable.Make (Full.Internal_Basic)\n module Inner_curve = Pickles.Backend.Tick.Inner_curve\nend\n","open Core_kernel\ninclude Bigint\n\nlet of_bool (b : bool) : t = if b then one else zero\n\nlet of_bit_fold_lsb ({ fold } : bool Fold_lib.Fold.t) : t =\n fold ~init:(0, zero) ~f:(fun (i, acc) b ->\n (Int.(i + 1), bit_or (shift_left (of_bool b) i) acc) )\n |> snd\n\nlet of_bits_lsb : bool list -> t =\n List.foldi ~init:zero ~f:(fun i acc b ->\n bit_or (shift_left (of_bool b) i) acc )\n","open Core_kernel\n\nmodule Make_test (F : Intf.Basic) = struct\n let test arg_typ gen_arg sexp_of_arg label unchecked checked =\n let open F.Impl in\n let converted x =\n let r =\n run_and_check\n (let open Checked.Let_syntax in\n let%bind x = exists arg_typ ~compute:(As_prover.return x) in\n checked x >>| As_prover.read F.typ)\n |> Or_error.ok_exn\n in\n r\n in\n let open Quickcheck in\n test ~trials:50 gen_arg ~f:(fun x ->\n let r1 = unchecked x in\n let r2 = converted x in\n if not (F.Unchecked.equal r1 r2) then\n failwithf\n !\"%s test failure: %{sexp:arg} -> %{sexp:F.Unchecked.t} vs \\\n %{sexp:F.Unchecked.t}\"\n label x r1 r2 ()\n else () )\n\n let test1 l f g = test F.typ F.Unchecked.gen F.Unchecked.sexp_of_t l f g\n\n let test2 l f g =\n let open F in\n test (Impl.Typ.( * ) typ typ)\n (Quickcheck.Generator.tuple2 Unchecked.gen Unchecked.gen)\n [%sexp_of: Unchecked.t * Unchecked.t] l (Tuple2.uncurry f)\n (Tuple2.uncurry g)\nend\n\nmodule Make (F : Intf.Basic) = struct\n open F.Impl\n open Let_syntax\n open F\n\n let typ = F.typ\n\n let constant = F.constant\n\n let scale = F.scale\n\n let assert_r1cs = F.assert_r1cs\n\n let equal x y =\n Checked.all\n (List.map2_exn (F.to_list x) (F.to_list y) ~f:Field.Checked.equal)\n >>= Boolean.all\n\n let assert_equal x y =\n assert_all\n (List.map2_exn\n ~f:(fun x y -> Constraint.equal x y)\n (F.to_list x) (F.to_list y) )\n\n let ( + ) = F.( + )\n\n let%test_unit \"add\" =\n let module M = Make_test (F) in\n M.test2 \"add\" Unchecked.( + ) (fun x y -> return (x + y))\n\n let ( - ) = F.( - )\n\n let negate = F.negate\n\n let zero = constant Unchecked.zero\n\n let one = constant Unchecked.one\n\n let div_unsafe x y =\n match (to_constant x, to_constant y) with\n | Some x, Some y ->\n return (constant Unchecked.(x / y))\n | _, _ ->\n let%bind x_over_y =\n exists typ\n ~compute:\n As_prover.(map2 (read typ x) (read typ y) ~f:Unchecked.( / ))\n in\n let%map () = assert_r1cs y x_over_y x in\n x_over_y\n\n let assert_square =\n match assert_square with\n | `Custom f ->\n f\n | `Define ->\n fun a a2 -> assert_r1cs a a a2\n\n let ( * ) =\n match ( * ) with\n | `Custom f ->\n f\n | `Define -> (\n fun x y ->\n match (to_constant x, to_constant y) with\n | Some x, Some y ->\n return (constant Unchecked.(x * y))\n | _, _ ->\n let%bind res =\n exists typ\n ~compute:\n As_prover.(\n map2 (read typ x) (read typ y) ~f:Unchecked.( * ))\n in\n let%map () = assert_r1cs x y res in\n res )\n\n let%test_unit \"mul\" =\n let module M = Make_test (F) in\n M.test2 \"mul\" Unchecked.( * ) ( * )\n\n let square =\n match square with\n | `Custom f ->\n f\n | `Define -> (\n fun x ->\n match to_constant x with\n | Some x ->\n return (constant (Unchecked.square x))\n | None ->\n let%bind res =\n exists typ\n ~compute:As_prover.(map (read typ x) ~f:Unchecked.square)\n in\n let%map () = assert_square x res in\n res )\n\n let%test_unit \"square\" =\n let module M = Make_test (F) in\n M.test1 \"square\" Unchecked.square square\n\n let inv_exn =\n match inv_exn with\n | `Custom f ->\n f\n | `Define -> (\n fun t ->\n match to_constant t with\n | Some x ->\n return (constant (Unchecked.inv x))\n | None ->\n let%bind res =\n exists typ\n ~compute:As_prover.(map (read typ t) ~f:Unchecked.inv)\n in\n let%map () = assert_r1cs t res one in\n res )\nend\n\nmodule Make_applicative\n (F : Intf.S)\n (A : Intf.Traversable_applicative with module Impl := F.Impl) =\nstruct\n type t = F.t A.t\n\n type 'a t_ = 'a F.t_ A.t\n\n let constant = A.map ~f:F.constant\n\n let to_constant =\n let exception None_exn in\n fun t ->\n try\n Some\n (A.map t ~f:(fun x ->\n match F.to_constant x with Some x -> x | None -> raise None_exn )\n )\n with None_exn -> None\n\n let if_ b ~then_ ~else_ =\n A.sequence (A.map2 then_ else_ ~f:(fun t e -> F.if_ b ~then_:t ~else_:e))\n\n let scale t x = A.map t ~f:(fun a -> F.scale a x)\n\n let scale' t x = A.map t ~f:(fun a -> F.scale x a)\n\n let negate t = A.map t ~f:F.negate\n\n let ( + ) = A.map2 ~f:F.( + )\n\n let ( - ) = A.map2 ~f:F.( - )\n\n let map_ t ~f = A.map t ~f:(F.map_ ~f)\n\n let map2_ t1 t2 ~f = A.map2 t1 t2 ~f:(fun x1 x2 -> F.map2_ x1 x2 ~f)\nend\n\nmodule F (Impl : Snarky_backendless.Snark_intf.S) :\n Intf.S with type 'a Base.t_ = 'a and type 'a A.t = 'a and module Impl = Impl =\nstruct\n module T = struct\n module Unchecked = struct\n include Impl.Field\n module Nat = Snarkette.Nat\n\n let order = Snarkette.Nat.of_string (Bigint.to_string Impl.Field.size)\n\n let to_yojson x = `String (to_string x)\n\n let of_yojson = function\n | `String s ->\n Ok (of_string s)\n | _ ->\n Error \"Field.of_yojson: expected string\"\n end\n\n module Impl = Impl\n open Impl\n\n let map_ t ~f = f t\n\n let map2_ t1 t2 ~f = f t1 t2\n\n module Base = struct\n type 'a t_ = 'a\n\n module Unchecked = struct\n type t = Field.t t_\n\n let to_yojson x = `String (Field.to_string x)\n\n let of_yojson = function\n | `String s ->\n Ok (Field.of_string s)\n | _ ->\n Error \"Field.of_yojson: expected string\"\n end\n\n type t = Field.Var.t t_\n\n let map_ = map_\n end\n\n module A = struct\n type 'a t = 'a\n\n let map = map_\n\n let map2 = map2_\n\n let sequence = Fn.id\n end\n\n type 'a t_ = 'a\n\n let to_list x = [ x ]\n\n type t = Field.Var.t\n\n let if_ = Field.Checked.if_\n\n let typ = Field.typ\n\n let constant = Field.Var.constant\n\n let to_constant = Field.Var.to_constant\n\n let scale = Field.Var.scale\n\n let mul_field = Field.Checked.mul\n\n let assert_r1cs a b c = assert_r1cs a b c\n\n let ( + ) = Field.Checked.( + )\n\n let ( - ) = Field.Checked.( - )\n\n let negate t = Field.Var.scale t Unchecked.(negate one)\n\n let assert_square = `Custom (fun a c -> assert_square a c)\n\n let ( * ) = `Custom Field.Checked.mul\n\n let square = `Custom Field.Checked.square\n\n let inv_exn = `Custom Field.Checked.inv\n\n let real_part = Fn.id\n end\n\n include T\n include Make (T)\nend\n\n(* Given a field F and s : F (called [non_residue] below)\n such that x^2 - s does not have a root in F, construct\n the field F(sqrt(s)) = F[x] / (x^2 - s) *)\nmodule E2\n (F : Intf.S) (Params : sig\n val non_residue : F.Unchecked.t\n\n val mul_by_non_residue : F.t -> F.t\n end) : sig\n include\n Intf.S_with_primitive_element\n with module Impl = F.Impl\n and module Base = F\n and type 'a A.t = 'a * 'a\n\n val unitary_inverse : t -> t\nend = struct\n open Params\n\n module T = struct\n module Base = F\n module Impl = F.Impl\n open Impl\n module Unchecked = Snarkette.Fields.Make_fp2 (F.Unchecked) (Params)\n\n module A = struct\n type 'a t = 'a * 'a\n\n let map (x, y) ~f = (f x, f y)\n\n let map2 (x1, y1) (x2, y2) ~f = (f x1 x2, f y1 y2)\n\n let sequence (x, y) =\n let%map x = x and y = y in\n (x, y)\n end\n\n let to_list (x, y) = F.to_list x @ F.to_list y\n\n (* A value [(a, b) : t] should be thought of as the field element\n a + b sqrt(s). Then all operations are just what follow algebraically. *)\n\n include Make_applicative (Base) (A)\n\n let mul_field (a, b) x =\n let%map a = Base.mul_field a x and b = Base.mul_field b x in\n (a, b)\n\n let typ = Typ.tuple2 F.typ F.typ\n\n (*\n (a + b sqrt(s))^2\n = a^2 + b^2 s + 2 a b sqrt(s)\n\n So it is clear that the second coordinate of the below definition is correct. Let's\n examine the first coordinate.\n\n t - ab - ab sqrt(s)\n = (a + b) (a + s b) - ab - s a b\n = a^2 + a b + s a b + s b^2 - a b - s a b\n = a^2 + s b^2\n\n so this is correct as well.\n *)\n let square (a, b) =\n let open F in\n let%map ab = a * b and t = (a + b) * (a + mul_by_non_residue b) in\n (t - ab - mul_by_non_residue ab, ab + ab)\n\n let assert_square (a, b) (a2, b2) =\n let open F in\n let ab = scale b2 Field.(one / of_int 2) in\n let%map () = assert_r1cs a b ab\n and () =\n assert_r1cs (a + b)\n (a + mul_by_non_residue b)\n (a2 + ab + mul_by_non_residue ab)\n in\n ()\n\n (*\n (a1 + b1 sqrt(s)) (a2 + b2 sqrt(s))\n = (a1 a2 + b1 b2 s) + (a2 b1 + a1 b2) sqrt(s)\n\n So it is clear that the first coordinate is correct. Let's examine the second\n coordinate.\n\n t - a1 a2 - b1 b2\n = (a1 + b1) (a2 + b2) - a1 a2 - b1 b2\n = a1 a2 + b2 b2 + a1 b2 + a2 b1 - a1 a2 - b1 b2\n = a1 b2 + a2 b1\n\n So this is correct as well.\n *)\n let ( * ) (a1, b1) (a2, b2) =\n let open F in\n let%map a = a1 * a2 and b = b1 * b2 and t = (a1 + b1) * (a2 + b2) in\n (a + mul_by_non_residue b, t - a - b)\n\n let mul_by_primitive_element (a, b) = (mul_by_non_residue b, a)\n\n let assert_r1cs (a1, b1) (a2, b2) (a3, b3) =\n let open F in\n let%bind b = b1 * b2 in\n let a = a3 - mul_by_non_residue b in\n let%map () = assert_r1cs a1 a2 a\n and () = assert_r1cs (a1 + b1) (a2 + b2) (b3 + a + b) in\n ()\n\n let square = `Custom square\n\n let ( * ) = `Custom ( * )\n\n let inv_exn = `Define\n\n let assert_square = `Custom assert_square\n\n let real_part (x, _) = Base.real_part x\n end\n\n include T\n include Make (T)\n\n let unitary_inverse (a, b) = (a, Base.negate b)\nend\n\n(* Given a prime order field F and s : F (called [non_residue] below)\n such that x^3 - s is irreducible, construct\n the field F(cube_root(s)) = F[x] / (x^3 - s).\n\n Let S = cube_root(s) in the following.\n*)\n\nmodule T3 = struct\n type 'a t = 'a * 'a * 'a\n\n let map (x, y, z) ~f = (f x, f y, f z)\n\n let map2 (x1, y1, z1) (x2, y2, z2) ~f = (f x1 x2, f y1 y2, f z1 z2)\nend\n\nmodule E3\n (F : Intf.S) (Params : sig\n val non_residue : F.Unchecked.t\n\n val frobenius_coeffs_c1 : F.Unchecked.t array\n\n val frobenius_coeffs_c2 : F.Unchecked.t array\n\n val mul_by_non_residue : F.t -> F.t\n end) :\n Intf.S_with_primitive_element\n with module Impl = F.Impl\n and module Base = F\n and type 'a A.t = 'a * 'a * 'a = struct\n module T = struct\n module Base = F\n module Unchecked = Snarkette.Fields.Make_fp3 (F.Unchecked) (Params)\n module Impl = F.Impl\n open Impl\n\n module A = struct\n include T3\n\n let sequence (x, y, z) =\n let%map x = x and y = y and z = z in\n (x, y, z)\n end\n\n let to_list (x, y, z) = F.to_list x @ F.to_list y @ F.to_list z\n\n include Make_applicative (Base) (A)\n\n let typ = Typ.tuple3 F.typ F.typ F.typ\n\n let mul_field (a, b, c) x =\n let%map a = Base.mul_field a x\n and b = Base.mul_field b x\n and c = Base.mul_field c x in\n (a, b, c)\n\n (*\n (a1 + S b1 + S^2 c1) (a2 + S b2 + S^2 c2)\n = a1 a2 + S a1 b2 + S^2 a1 c2\n + S b1 a2 + S^2 b1 b2 + S^3 b1 c2\n + S^2 c1 a2 + S^3 c1 b2 + S^4 c1 c2\n = a1 a2 + S a1 b2 + S^2 a1 c2\n + S b1 a2 + S^2 b1 b2 + s b1 c2\n + S^2 c1 a2 + s c1 b2 + s S c1 c2\n = (a1 a2 + s b1 c2 + s c1 b2)\n + S (a1 b2 + b1 a2 + s c1 c2)\n + S^2 (a1 c2 + c1 a2 + b1 b2)\n\n Let us examine the three coordinates in turn.\n\n First coordinate:\n a + s (t1 - b - c)\n = a1 a2 + s ( (b1 + c1) (b2 + c2) - b - c)\n = a1 a2 + s (b1 c2 + b2 c1)\n which is evidently correct.\n\n Second coordinate:\n t2 - a - b + s c\n (a1 + b1) (a2 + b2) - a - b + s c\n a1 b2 + b1 a2 + s c\n which is evidently correct.\n\n Third coordinate:\n t3 - a + b - c\n = (a1 + c1) (a2 + c2) - a + b - c\n = a1 c2 + c1 a2 + b\n which is evidently correct.\n *)\n let ( * ) (a1, b1, c1) (a2, b2, c2) =\n with_label __LOC__ (fun () ->\n let open F in\n let%map a = a1 * a2\n and b = b1 * b2\n and c = c1 * c2\n and t1 = (b1 + c1) * (b2 + c2)\n and t2 = (a1 + b1) * (a2 + b2)\n and t3 = (a1 + c1) * (a2 + c2) in\n ( a + Params.mul_by_non_residue (t1 - b - c)\n , t2 - a - b + Params.mul_by_non_residue c\n , t3 - a + b - c ) )\n\n (*\n (a + S b + S^2 c)^2\n = a^2 + S a b + S^2 a c\n + S a b + S^2 b^2 + S^3 b c\n + S^2 a c + S^3 b c + S^4 c^2\n = a^2 + S a b + S^2 a c\n + S a b + S^2 b^2 + s b c\n + S^2 a c + s b c + S s c^2\n = (a^2 + 2 s b c)\n + S (2 a b + s c^2)\n + S^2 (b^2 + 2 a c)\n\n Let us examine the three coordinates in turn.\n\n First coordinate:\n s0 + s s3\n = a^2 + 2 s b c\n which is evidently correct.\n\n Second coordinate:\n s1 + s s4\n = 2 a b + s c^2\n which is evidently correct.\n\n Third coordinate:\n s1 + s2 + s3 - s0 - s4\n = 2 a b + (a - b + c)^2 + 2 b c - a^2 - c^2\n = 2 a b + a^2 - 2 a b + 2 a c - 2 b c + b^2 + c^2 + 2 b c - a^2 - c^2\n = 2 a c + b^2\n which is evidently correct.\n *)\n let square (a, b, c) =\n let open F in\n let%map s0 = square a\n and ab = a * b\n and bc = b * c\n and s2 = square (a - b + c)\n and s4 = square c in\n let s1 = ab + ab in\n let s3 = bc + bc in\n ( s0 + Params.mul_by_non_residue s3\n , s1 + Params.mul_by_non_residue s4\n , s1 + s2 + s3 - s0 - s4 )\n\n let mul_by_primitive_element (a, b, c) = (Params.mul_by_non_residue c, a, b)\n\n let assert_r1cs (a1, b1, c1) (a2, b2, c2) (a3, b3, c3) =\n with_label __LOC__ (fun () ->\n let open F in\n let%bind b = b1 * b2 and c = c1 * c2 and t1 = (b1 + c1) * (b2 + c2) in\n let a = a3 - Params.mul_by_non_residue (t1 - b - c) in\n let%map () = assert_r1cs a1 a2 a\n and () =\n assert_r1cs (a1 + b1) (a2 + b2)\n (b3 + a + b - Params.mul_by_non_residue c)\n and () = assert_r1cs (a1 + c1) (a2 + c2) (c3 + a - b + c) in\n () )\n\n let square = `Custom square\n\n let ( * ) = `Custom ( * )\n\n let inv_exn = `Define\n\n let assert_square = `Define\n\n let real_part (a, _, _) = F.real_part a\n end\n\n include T\n include Make (T)\nend\n\nmodule F3\n (F : Intf.S with type 'a A.t = 'a and type 'a Base.t_ = 'a) (Params : sig\n val non_residue : F.Unchecked.t\n\n val frobenius_coeffs_c1 : F.Unchecked.t array\n\n val frobenius_coeffs_c2 : F.Unchecked.t array\n end) :\n Intf.S_with_primitive_element\n with module Impl = F.Impl\n and module Base = F\n and type 'a A.t = 'a * 'a * 'a = struct\n module T = struct\n module Base = F\n module Unchecked = Snarkette.Fields.Make_fp3 (F.Unchecked) (Params)\n module Impl = F.Impl\n open Impl\n\n let mul_by_primitive_element (a, b, c) = (F.scale c Params.non_residue, a, b)\n\n module A = struct\n include T3\n\n let sequence (x, y, z) =\n let%map x = x and y = y and z = z in\n (x, y, z)\n end\n\n let to_list (x, y, z) = [ x; y; z ]\n\n include Make_applicative (Base) (A)\n\n let typ = Typ.tuple3 F.typ F.typ F.typ\n\n let mul_field (a, b, c) x =\n let%map a = Base.mul_field a x\n and b = Base.mul_field b x\n and c = Base.mul_field c x in\n (a, b, c)\n\n let assert_r1cs (a0, a1, a2) (b0, b1, b2) (c0, c1, c2) =\n let open F in\n let%bind v0 = a0 * b0 and v4 = a2 * b2 in\n let beta = Params.non_residue in\n let beta_inv = F.Unchecked.inv beta in\n let%map () =\n assert_r1cs\n (a0 + a1 + a2)\n (b0 + b1 + b2)\n ( c1 + c2 + F.scale c0 beta_inv\n + F.(scale v0 Unchecked.(one - beta_inv))\n + F.(scale v4 Unchecked.(one - beta)) )\n and () =\n assert_r1cs\n (a0 - a1 + a2)\n (b0 - b1 + b2)\n ( c2 - c1\n + F.(scale v0 Unchecked.(one + beta_inv))\n - F.scale c0 beta_inv\n + F.(scale v4 Unchecked.(one + beta)) )\n and () =\n let two = Impl.Field.of_int 2 in\n let four = Impl.Field.of_int 4 in\n let sixteen = Impl.Field.of_int 16 in\n let eight_beta_inv = Impl.Field.(mul (of_int 8) beta_inv) in\n assert_r1cs\n (a0 + F.scale a1 two + F.scale a2 four)\n (b0 + F.scale b1 two + F.scale b2 four)\n ( F.scale c1 two + F.scale c2 four + F.scale c0 eight_beta_inv\n + F.(scale v0 Unchecked.(one - eight_beta_inv))\n + F.(scale v4 Unchecked.(sixteen - (beta + beta))) )\n in\n ()\n\n let ( * ) = `Define\n\n let inv_exn = `Define\n\n let square = `Define\n\n let assert_square = `Define\n\n let real_part (a, _, _) = F.real_part a\n end\n\n include T\n include Make (T)\nend\n\nmodule Cyclotomic_square = struct\n module Make_F4 (F2 : Intf.S_with_primitive_element) = struct\n let cyclotomic_square (c0, c1) =\n let open F2 in\n let open Impl in\n let%map b_squared = square (c0 + c1) and a = square c1 in\n let c = b_squared - a in\n let d = mul_by_primitive_element a in\n let e = c - d in\n let f = scale d (Field.of_int 2) + one in\n let g = e - one in\n (f, g)\n end\n\n module Make_F6\n (F2 : Intf.S_with_primitive_element\n with type 'a A.t = 'a * 'a\n and type 'a Base.t_ = 'a)\n (Params : sig\n val cubic_non_residue : F2.Impl.Field.t\n end) =\n struct\n let cyclotomic_square ((x00, x01, x02), (x10, x11, x12)) =\n let open F2.Impl in\n let ((a0, a1) as a) = (x00, x11) in\n let ((b0, b1) as b) = (x10, x02) in\n let ((c0, c1) as c) = (x01, x12) in\n let%map asq0, asq1 = F2.square a\n and bsq0, bsq1 = F2.square b\n and csq0, csq1 = F2.square c in\n let fpos x y =\n Field.(Var.(add (scale x (of_int 3)) (scale y (of_int 2))))\n in\n let fneg x y =\n Field.(Var.(sub (scale x (of_int 3)) (scale y (of_int 2))))\n in\n ( (fneg asq0 a0, fneg bsq0 c0, fneg csq0 b1)\n , ( fpos (Field.Var.scale csq1 Params.cubic_non_residue) b0\n , fpos asq1 a1\n , fpos bsq1 c1 ) )\n end\nend\n\nmodule F6\n (Fq : Intf.S with type 'a A.t = 'a and type 'a Base.t_ = 'a)\n (Fq2 : Intf.S_with_primitive_element\n with module Impl = Fq.Impl\n and type 'a A.t = 'a * 'a\n and type 'a Base.t_ = 'a Fq.t_)\n (Fq3 : sig\n include\n Intf.S_with_primitive_element\n with module Impl = Fq.Impl\n and type 'a A.t = 'a * 'a * 'a\n and type 'a Base.t_ = 'a Fq.t_\n\n module Params : sig\n val non_residue : Fq.Unchecked.t\n\n val frobenius_coeffs_c1 : Fq.Unchecked.t array\n\n val frobenius_coeffs_c2 : Fq.Unchecked.t array\n end\n end) (Params : sig\n val frobenius_coeffs_c1 : Fq.Unchecked.t array\n end) =\nstruct\n include\n E2\n (Fq3)\n (struct\n let non_residue : Fq3.Unchecked.t = Fq.Unchecked.(zero, one, zero)\n\n let mul_by_non_residue = Fq3.mul_by_primitive_element\n end)\n\n let fq_mul_by_non_residue x = Fq.scale x Fq3.Params.non_residue\n\n let special_mul (a0, a1) (b0, b1) =\n let open Impl in\n let%bind v1 = Fq3.(a1 * b1) in\n let%bind v0 =\n let a00, a01, a02 = a0 in\n let _, _, b02 = b0 in\n let%map a00b02 = Fq.(a00 * b02)\n and a01b02 = Fq.(a01 * b02)\n and a02b02 = Fq.(a02 * b02) in\n (fq_mul_by_non_residue a01b02, fq_mul_by_non_residue a02b02, a00b02)\n in\n let beta_v1 = Fq3.mul_by_primitive_element v1 in\n let%map t = Fq3.((a0 + a1) * (b0 + b1)) in\n Fq3.(v0 + beta_v1, t - v0 - v1)\n\n let assert_special_mul ((((a00, a01, a02) as a0), a1) : t)\n ((((_, _, b02) as b0), b1) : t) ((c00, c01, c02), c1) =\n let open Impl in\n let%bind ((v10, v11, v12) as v1) = Fq3.(a1 * b1) in\n let%bind v0 =\n exists Fq3.typ\n ~compute:\n As_prover.(\n map2 ~f:Fq3.Unchecked.( * ) (read Fq3.typ a0) (read Fq3.typ b0))\n (* v0\n = (a00 + s a01 s^2 a02) (s^2 b02)\n = non_residue a01 b02 + non_residue s a02 b02 + s^2 a00 b02 *)\n in\n let%map () =\n let%map () =\n Fq.assert_r1cs a01\n (Fq.scale b02 Fq3.Params.non_residue)\n (Field.Var.linear_combination\n [ (Field.one, c00); (Field.negate Fq3.Params.non_residue, v12) ] )\n and () =\n Fq.assert_r1cs a02 (Fq.scale b02 Fq3.Params.non_residue) Fq.(c01 - v10)\n and () = Fq.assert_r1cs a00 b02 Fq.(c02 - v11) in\n ()\n and () = Fq3.assert_r1cs Fq3.(a0 + a1) Fq3.(b0 + b1) Fq3.(c1 + v0 + v1) in\n ()\n\n let special_div_unsafe a b =\n let open Impl in\n let%bind result =\n exists typ\n ~compute:As_prover.(map2 ~f:Unchecked.( / ) (read typ a) (read typ b))\n in\n (* result * b = a *)\n let%map () = assert_special_mul result b a in\n result\n\n (* TODO: Make sure this is ok *)\n let special_div = special_div_unsafe\n\n include\n Cyclotomic_square.Make_F6\n (Fq2)\n (struct\n let cubic_non_residue = Fq3.Params.non_residue\n end)\n\n let frobenius ((c00, c01, c02), (c10, c11, c12)) power =\n let module Field = Impl.Field in\n let p3 = power mod 3 in\n let p6 = power mod 6 in\n let ( * ) s x = Field.Var.scale x s in\n ( ( c00\n , Fq3.Params.frobenius_coeffs_c1.(p3) * c01\n , Fq3.Params.frobenius_coeffs_c2.(p3) * c02 )\n , ( Params.frobenius_coeffs_c1.(p6) * c10\n , Field.mul\n Params.frobenius_coeffs_c1.(p6)\n Fq3.Params.frobenius_coeffs_c1.(p3)\n * c11\n , Field.mul\n Params.frobenius_coeffs_c1.(p6)\n Fq3.Params.frobenius_coeffs_c2.(p3)\n * c12 ) )\nend\n\nmodule F4\n (Fq2 : Intf.S_with_primitive_element\n with type 'a A.t = 'a * 'a\n and type 'a Base.t_ = 'a)\n (Params : sig\n val frobenius_coeffs_c1 : Fq2.Impl.Field.t array\n end) =\nstruct\n include\n E2\n (Fq2)\n (struct\n let non_residue = Fq2.Impl.Field.(zero, one)\n\n let mul_by_non_residue = Fq2.mul_by_primitive_element\n end)\n\n let special_mul = ( * )\n\n (* TODO: Make sure this is ok *)\n let special_div = div_unsafe\n\n include Cyclotomic_square.Make_F4 (Fq2)\n\n let frobenius ((c00, c01), (c10, c11)) power =\n let module Field = Impl.Field in\n let p2 = Params.frobenius_coeffs_c1.(Int.( * ) (power mod 2) 2) in\n let p4 = Params.frobenius_coeffs_c1.(power mod 4) in\n let ( * ) s x = Field.Var.scale x s in\n ((c00, p2 * c01), (p4 * c10, Field.(p4 * p2) * c11))\nend\n","module Bignum_bigint = Bigint\nopen Core_kernel\n\nmodule type Params_intf = sig\n type field\n\n val a : field\n\n val b : field\nend\n\nmodule type Scalar_intf = sig\n type (_, _) typ\n\n type (_, _) checked\n\n type boolean_var\n\n type var\n\n type t [@@deriving equal, sexp]\n\n val typ : (var, t) typ\n\n val length_in_bits : int\n\n val test_bit : t -> int -> bool\n\n module Checked : sig\n val equal : var -> var -> (boolean_var, _) checked\n\n module Assert : sig\n val equal : var -> var -> (unit, _) checked\n end\n end\nend\n\nmodule type Shifted_intf = sig\n type _ checked\n\n type boolean_var\n\n type curve_var\n\n type t\n\n val zero : t\n\n val add : t -> curve_var -> t checked\n\n (* This is only safe if the result is guaranteed to not be zero. *)\n\n val unshift_nonzero : t -> curve_var checked\n\n val if_ : boolean_var -> then_:t -> else_:t -> t checked\n\n module Assert : sig\n val equal : t -> t -> unit checked\n end\nend\n\nmodule type Weierstrass_checked_intf = sig\n module Impl : Snarky_backendless.Snark_intf.S\n\n open Impl\n\n type unchecked\n\n type t\n\n val typ : (t, unchecked) Typ.t\n\n module Shifted : sig\n module type S =\n Shifted_intf\n with type 'a checked := 'a Checked.t\n and type curve_var := t\n and type boolean_var := Boolean.var\n\n type 'a m = (module S with type t = 'a)\n\n val create : unit -> (module S) Checked.t\n end\n\n val negate : t -> t\n\n val constant : unchecked -> t\n\n val add_unsafe :\n t -> t -> [ `I_thought_about_this_very_carefully of t ] Checked.t\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t Checked.t\n\n val double : t -> t Checked.t\n\n val if_value : Boolean.var -> then_:unchecked -> else_:unchecked -> t\n\n val scale :\n 's Shifted.m\n -> t\n -> Boolean.var Bitstring_lib.Bitstring.Lsb_first.t\n -> init:'s\n -> 's Checked.t\n\n val scale_known :\n 's Shifted.m\n -> unchecked\n -> Boolean.var Bitstring_lib.Bitstring.Lsb_first.t\n -> init:'s\n -> 's Checked.t\n\n val sum : 's Shifted.m -> t list -> init:'s -> 's Checked.t\n\n module Assert : sig\n val on_curve : t -> unit Checked.t\n\n val equal : t -> t -> unit Checked.t\n end\nend\n\nmodule Make_weierstrass_checked\n (F : Snarky_field_extensions.Intf.S) (Scalar : sig\n type t\n\n val of_int : int -> t\n end) (Curve : sig\n type t\n\n val random : unit -> t\n\n val to_affine_exn : t -> F.Unchecked.t * F.Unchecked.t\n\n val of_affine : F.Unchecked.t * F.Unchecked.t -> t\n\n val double : t -> t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\n\n val scale : t -> Scalar.t -> t\n end)\n (Params : Params_intf with type field := F.Unchecked.t) (Override : sig\n val add : (F.t * F.t -> F.t * F.t -> (F.t * F.t) F.Impl.Checked.t) option\n end) :\n Weierstrass_checked_intf\n with module Impl := F.Impl\n and type unchecked := Curve.t\n and type t = F.t * F.t = struct\n open F.Impl\n\n type t = F.t * F.t\n\n let assert_on_curve (x, y) =\n let open F in\n let%bind x2 = square x in\n let%bind x3 = x2 * x in\n let%bind ax = constant Params.a * x in\n assert_square y (x3 + ax + constant Params.b)\n\n let typ : (t, Curve.t) Typ.t =\n let (Typ unchecked) =\n Typ.transport\n Typ.(tuple2 F.typ F.typ)\n ~there:Curve.to_affine_exn ~back:Curve.of_affine\n in\n Typ { unchecked with check = assert_on_curve }\n\n let negate ((x, y) : t) : t = (x, F.negate y)\n\n let constant (t : Curve.t) : t =\n let x, y = Curve.to_affine_exn t in\n F.(constant x, constant y)\n\n let assert_equal (x1, y1) (x2, y2) =\n let%map () = F.assert_equal x1 x2 and () = F.assert_equal y1 y2 in\n ()\n\n module Assert = struct\n let on_curve = assert_on_curve\n\n let equal = assert_equal\n end\n\n open Let_syntax\n\n let%snarkydef_ add' ~div (ax, ay) (bx, by) =\n let open F in\n let%bind lambda = div (by - ay) (bx - ax) in\n let%bind cx =\n exists typ\n ~compute:\n (let open As_prover in\n let open Let_syntax in\n let%map ax = read typ ax\n and bx = read typ bx\n and lambda = read typ lambda in\n Unchecked.(square lambda - (ax + bx)))\n in\n let%bind () =\n (* lambda^2 = cx + ax + bx\n cx = lambda^2 - (ax + bc)\n *)\n assert_square lambda F.(cx + ax + bx)\n in\n let%bind cy =\n exists typ\n ~compute:\n (let open As_prover in\n let open Let_syntax in\n let%map ax = read typ ax\n and ay = read typ ay\n and cx = read typ cx\n and lambda = read typ lambda in\n Unchecked.((lambda * (ax - cx)) - ay))\n in\n let%map () = assert_r1cs lambda (ax - cx) (cy + ay) in\n (cx, cy)\n\n let add' ~div p1 p2 =\n match Override.add with Some add -> add p1 p2 | None -> add' ~div p1 p2\n\n (* This function MUST NOT be called UNLESS you are certain the two points\n on which it is called are not equal. If it is called on equal points,\n the prover can return almost any curve point they want to from this function. *)\n let add_unsafe p q =\n let%map r = add' ~div:F.div_unsafe p q in\n `I_thought_about_this_very_carefully r\n\n let add_exn p q = add' ~div:(fun x y -> F.inv_exn y >>= F.(( * ) x)) p q\n\n (* TODO-someday: Make it so this doesn't have to compute both branches *)\n let if_ b ~then_:(tx, ty) ~else_:(ex, ey) =\n let%map x = F.if_ b ~then_:tx ~else_:ex\n and y = F.if_ b ~then_:ty ~else_:ey in\n (x, y)\n\n module Shifted = struct\n module type S =\n Shifted_intf\n with type 'a checked := 'a Checked.t\n and type curve_var := t\n and type boolean_var := Boolean.var\n\n type 'a m = (module S with type t = 'a)\n\n module Make (M : sig\n val shift : t\n end) : S = struct\n open M\n\n type nonrec t = t\n\n let zero = shift\n\n let if_ = if_\n\n let unshift_nonzero shifted = add_exn (negate shift) shifted\n\n let add shifted x = add_exn shifted x\n\n module Assert = struct\n let equal = assert_equal\n end\n end\n\n let create () : (module S) Checked.t =\n let%map shift =\n exists typ ~compute:As_prover.(map (return ()) ~f:Curve.random)\n in\n let module M = Make (struct\n let shift = shift\n end) in\n (module M : S)\n end\n\n let%snarkydef_ double (ax, ay) =\n let open F in\n let%bind x_squared = square ax in\n let%bind lambda =\n exists typ\n ~compute:\n As_prover.(\n map2 (read typ x_squared) (read typ ay) ~f:(fun x_squared ay ->\n let open F.Unchecked in\n (x_squared + x_squared + x_squared + Params.a) * inv (ay + ay) ))\n in\n let%bind bx =\n exists typ\n ~compute:\n As_prover.(\n map2 (read typ lambda) (read typ ax) ~f:(fun lambda ax ->\n let open F.Unchecked in\n square lambda - (ax + ax) ))\n in\n let%bind by =\n exists typ\n ~compute:\n (let open As_prover in\n let open Let_syntax in\n let%map lambda = read typ lambda\n and ax = read typ ax\n and ay = read typ ay\n and bx = read typ bx in\n F.Unchecked.((lambda * (ax - bx)) - ay))\n in\n let two = Field.of_int 2 in\n let%map () =\n assert_r1cs (F.scale lambda two) ay\n (F.scale x_squared (Field.of_int 3) + F.constant Params.a)\n and () = assert_square lambda (bx + F.scale ax two)\n and () = assert_r1cs lambda (ax - bx) (by + ay) in\n (bx, by)\n\n let if_value (cond : Boolean.var) ~then_ ~else_ =\n let x1, y1 = Curve.to_affine_exn then_ in\n let x2, y2 = Curve.to_affine_exn else_ in\n let cond = (cond :> Field.Var.t) in\n let choose a1 a2 =\n let open Field.Checked in\n F.map2_ a1 a2 ~f:(fun a1 a2 ->\n (a1 * cond) + (a2 * (Field.Var.constant Field.one - cond)) )\n in\n (choose x1 x2, choose y1 y2)\n\n let%snarkydef_ scale (type shifted)\n (module Shifted : Shifted.S with type t = shifted) t\n (c : Boolean.var Bitstring_lib.Bitstring.Lsb_first.t) ~(init : shifted) :\n shifted Checked.t =\n let c = Bitstring_lib.Bitstring.Lsb_first.to_list c in\n let open Let_syntax in\n let rec go i bs0 acc pt =\n match bs0 with\n | [] ->\n return acc\n | b :: bs ->\n let%bind acc' =\n with_label (sprintf \"acc_%d\" i) (fun () ->\n let%bind add_pt = Shifted.add acc pt in\n let don't_add_pt = acc in\n Shifted.if_ b ~then_:add_pt ~else_:don't_add_pt )\n and pt' = double pt in\n go (i + 1) bs acc' pt'\n in\n go 0 c init t\n\n (* This 'looks up' a field element from a lookup table of size 2^2 = 4 with\n a 2 bit index. See https://github.com/zcash/zcash/issues/2234#issuecomment-383736266 for\n a discussion of this trick.\n *)\n let lookup_point (b0, b1) (t1, t2, t3, t4) =\n let%map b0_and_b1 = Boolean.( && ) b0 b1 in\n let lookup_one (a1, a2, a3, a4) =\n let open F.Unchecked in\n let ( * ) x b = F.map_ x ~f:(fun x -> Field.Var.scale b x) in\n let ( +^ ) = F.( + ) in\n F.constant a1\n +^ ((a2 - a1) * (b0 :> Field.Var.t))\n +^ ((a3 - a1) * (b1 :> Field.Var.t))\n +^ ((a4 + a1 - a2 - a3) * (b0_and_b1 :> Field.Var.t))\n in\n let x1, y1 = Curve.to_affine_exn t1\n and x2, y2 = Curve.to_affine_exn t2\n and x3, y3 = Curve.to_affine_exn t3\n and x4, y4 = Curve.to_affine_exn t4 in\n (lookup_one (x1, x2, x3, x4), lookup_one (y1, y2, y3, y4))\n\n (* Similar to the above, but doing lookup in a size 1 table *)\n let lookup_single_bit (b : Boolean.var) (t1, t2) =\n let lookup_one (a1, a2) =\n let open F in\n constant a1\n + map_ Unchecked.(a2 - a1) ~f:(Field.Var.scale (b :> Field.Var.t))\n in\n let x1, y1 = Curve.to_affine_exn t1 and x2, y2 = Curve.to_affine_exn t2 in\n (lookup_one (x1, x2), lookup_one (y1, y2))\n\n let scale_known (type shifted)\n (module Shifted : Shifted.S with type t = shifted) (t : Curve.t)\n (b : Boolean.var Bitstring_lib.Bitstring.Lsb_first.t) ~init =\n let b = Bitstring_lib.Bitstring.Lsb_first.to_list b in\n let sigma = t in\n let n = List.length b in\n let sigma_count = (n + 1) / 2 in\n\n (* = ceil (n / 2.0) *)\n (* We implement a complicated optimzation so that in total\n this costs roughly (1 + 3) * (n / 2) constraints, rather than\n the naive 4*n + 3*n. If scalars were represented with some\n kind of signed digit representation we could probably get it\n down to 2 * (n / 3) + 3 * (n / 3).\n *)\n (* Assume n is even *)\n (* Define\n to_term_unshifted i (b0, b1) =\n match b0, b1 with\n | false, false -> oo\n | true, false -> 2^i * t\n | false, true -> 2^{i+1} * t\n | true, true -> 2^i * t + 2^{i + 1} t\n\n to_term i (b0, b1) =\n sigma + to_term_unshifted i (b0, b1) =\n match b0, b1 with\n | false, false -> sigma\n | true, false -> sigma + 2^i * t\n | false, true -> sigma + 2^{i+1} * t\n | true, true -> sigma + 2^i * t + 2^{i + 1} t\n *)\n let to_term ~two_to_the_i ~two_to_the_i_plus_1 bits =\n lookup_point bits\n ( sigma\n , Curve.(sigma + two_to_the_i)\n , Curve.(sigma + two_to_the_i_plus_1)\n , Curve.(sigma + two_to_the_i + two_to_the_i_plus_1) )\n in\n\n (*\n Say b = b0, b1, .., b_{n-1}.\n We compute\n\n (to_term 0 (b0, b1)\n + to_term 2 (b2, b3)\n + to_term 4 (b4, b5)\n + ...\n + to_term (n-2) (b_{n-2}, b_{n-1}))\n - (n/2) * sigma\n =\n (n/2)*sigma + (b0*2^0 + b1*21 + ... + b_{n-1}*2^{n-1}) t - (n/2) * sigma\n =\n (n/2)*sigma + b * t - (n/2)*sigma\n = b * t\n *)\n let open Let_syntax in\n (* TODO #1152\n Can get away with using an unsafe add if we modify this a bit. *)\n let rec go acc two_to_the_i bits =\n match bits with\n | [] ->\n return acc\n | [ b_i ] ->\n let term =\n lookup_single_bit b_i (sigma, Curve.(sigma + two_to_the_i))\n in\n Shifted.add acc term\n | b_i :: b_i_plus_1 :: rest ->\n let two_to_the_i_plus_1 = Curve.double two_to_the_i in\n let%bind term =\n to_term ~two_to_the_i ~two_to_the_i_plus_1 (b_i, b_i_plus_1)\n in\n let%bind acc = Shifted.add acc term in\n go acc (Curve.double two_to_the_i_plus_1) rest\n in\n let%bind result_with_shift = go init t b in\n let unshift =\n Curve.scale (Curve.negate sigma) (Scalar.of_int sigma_count)\n in\n Shifted.add result_with_shift (constant unshift)\n\n let to_constant (x, y) =\n let open Option.Let_syntax in\n let%map x = F.to_constant x and y = F.to_constant y in\n Curve.of_affine (x, y)\n\n let scale m t c ~init =\n match to_constant t with\n | Some t ->\n scale_known m t c ~init\n | None ->\n scale m t c ~init\n\n let sum (type shifted) (module Shifted : Shifted.S with type t = shifted) xs\n ~init =\n let open Let_syntax in\n let rec go acc = function\n | [] ->\n return acc\n | t :: ts ->\n let%bind acc' = Shifted.add acc t in\n go acc' ts\n in\n go init xs\nend\n","module Length = struct\n type 'a t = ('a list, int) Sigs.predicate2\n\n let equal l len = Caml.List.compare_length_with l len = 0\n\n let unequal l len = Caml.List.compare_length_with l len <> 0\n\n let gte l len = Caml.List.compare_length_with l len >= 0\n\n let gt l len = Caml.List.compare_length_with l len > 0\n\n let lte l len = Caml.List.compare_length_with l len <= 0\n\n let lt l len = Caml.List.compare_length_with l len < 0\n\n module Compare = struct\n let ( = ) = equal\n\n let ( <> ) = unequal\n\n let ( >= ) = gte\n\n let ( > ) = gt\n\n let ( <= ) = lte\n\n let ( < ) = lt\n end\nend\n","open Core_kernel\ninclude Result\nopen Let_syntax\n\nmodule List = struct\n let map ls ~f =\n let%map r =\n List.fold_result ls ~init:[] ~f:(fun t el ->\n let%map h = f el in\n h :: t )\n in\n List.rev r\nend\n","(* bits_intf.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Fold_lib\n\nmodule type Basic = sig\n type t\n\n val fold : t -> bool Fold.t\n\n val size_in_bits : int\nend\n\nmodule type S = sig\n include Basic\n\n val iter : t -> f:(bool -> unit) -> unit\n\n val to_bits : t -> bool list\nend\n\nmodule type Convertible_bits = sig\n include S\n\n val of_bits : bool list -> t\nend\n\n[%%ifdef consensus_mechanism]\n\nopen Tuple_lib\n\nmodule Snarkable = struct\n module type Basic = sig\n type (_, _) typ\n\n type _ checked\n\n type boolean_var\n\n val size_in_bits : int\n\n module Packed : sig\n type var\n\n type value\n\n val typ : (var, value) typ\n\n val size_in_bits : int\n end\n\n module Unpacked : sig\n type var\n\n type value\n\n val typ : (var, value) typ\n\n val var_to_bits : var -> boolean_var Bitstring_lib.Bitstring.Lsb_first.t\n\n val var_of_bits : boolean_var Bitstring_lib.Bitstring.Lsb_first.t -> var\n\n val var_to_triples : var -> boolean_var Triple.t list\n\n val var_of_value : value -> var\n\n val size_in_bits : int\n end\n end\n\n module type Lossy = sig\n include Basic\n\n val project_value : Unpacked.value -> Packed.value\n\n val unpack_value : Packed.value -> Unpacked.value\n\n val project_var : Unpacked.var -> Packed.var\n\n val choose_preimage_var : Packed.var -> Unpacked.var checked\n end\n\n module type Faithful = sig\n include Basic\n\n val pack_value : Unpacked.value -> Packed.value\n\n val unpack_value : Packed.value -> Unpacked.value\n\n val pack_var : Unpacked.var -> Packed.var\n\n val unpack_var : Packed.var -> Unpacked.var checked\n end\n\n module type Small = sig\n type comparison_result\n\n type field_var\n\n include Faithful with type Packed.var = private field_var\n\n val compare_var : Unpacked.var -> Unpacked.var -> comparison_result checked\n\n val increment_var : Unpacked.var -> Unpacked.var checked\n\n val increment_if_var : Unpacked.var -> boolean_var -> Unpacked.var checked\n\n val assert_equal_var : Unpacked.var -> Unpacked.var -> unit checked\n\n val equal_var : Unpacked.var -> Unpacked.var -> boolean_var checked\n\n val var_of_field : field_var -> Unpacked.var checked\n\n val var_of_field_unsafe : field_var -> Packed.var\n\n val if_ :\n boolean_var\n -> then_:Unpacked.var\n -> else_:Unpacked.var\n -> Unpacked.var checked\n end\nend\n\n[%%endif]\n","open Core_kernel\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.S) = struct\n open Impl\n open Let_syntax\n\n let pack_int bs =\n assert (List.length bs < 62) ;\n let rec go pt acc = function\n | [] ->\n acc\n | b :: bs ->\n if b then go (2 * pt) (pt + acc) bs else go (2 * pt) acc bs\n in\n go 1 0 bs\n\n let boolean_assert_lte (x : Boolean.var) (y : Boolean.var) =\n (*\n x <= y\n y == 1 or x = 0\n (y - 1) * x = 0\n *)\n assert_r1cs\n Field.Var.(sub (y :> Field.Var.t) (constant Field.one))\n (x :> Field.Var.t)\n (Field.Var.constant Field.zero)\n\n let assert_decreasing : Boolean.var list -> unit Checked.t =\n let rec go prev (bs0 : Boolean.var list) =\n match bs0 with\n | [] ->\n return ()\n | b :: bs ->\n let%bind () = boolean_assert_lte b prev in\n go b bs\n in\n function [] -> return () | b :: bs -> go b bs\n\n let nth_bit x ~n = (x lsr n) land 1 = 1\n\n let apply_mask mask bs = Checked.all (List.map2_exn mask bs ~f:Boolean.( && ))\n\n let pack_unsafe (bs0 : Boolean.var list) =\n let n = List.length bs0 in\n assert (n <= Field.size_in_bits) ;\n let rec go acc two_to_the_i = function\n | b :: bs ->\n go\n (Field.Var.add acc (Field.Var.scale b two_to_the_i))\n (Field.add two_to_the_i two_to_the_i)\n bs\n | [] ->\n acc\n in\n go (Field.Var.constant Field.zero) Field.one (bs0 :> Field.Var.t list)\n\n type _ Snarky_backendless.Request.t +=\n | N_ones : bool list Snarky_backendless.Request.t\n\n let n_ones ~total_length n =\n let%bind bs =\n exists\n (Typ.list ~length:total_length Boolean.typ)\n ~request:(As_prover.return N_ones)\n ~compute:\n As_prover.(\n map (read_var n) ~f:(fun n ->\n List.init total_length ~f:(fun i ->\n Bigint.(\n compare (of_field (Field.of_int i)) (of_field n) < 0) ) ))\n in\n let%map () =\n Field.Checked.Assert.equal\n (Field.Var.sum (bs :> Field.Var.t list))\n (* This can't overflow since the field is huge *)\n n\n and () = assert_decreasing bs in\n bs\n\n let assert_num_bits_upper_bound bs u =\n let total_length = List.length bs in\n assert (total_length < Field.size_in_bits) ;\n let%bind mask = n_ones ~total_length u in\n let%bind masked = apply_mask mask bs in\n with_label __LOC__ (fun () ->\n Field.Checked.Assert.equal (pack_unsafe masked) (pack_unsafe bs) )\n\n let num_bits_int =\n let rec go acc n = if n = 0 then acc else go (1 + acc) (n lsr 1) in\n go 0\n\n let size_in_bits_size_in_bits = num_bits_int Field.size_in_bits\n\n type _ Snarky_backendless.Request.t +=\n | Num_bits_upper_bound : Field.t Snarky_backendless.Request.t\n\n let num_bits_upper_bound_unchecked x =\n let num_bits =\n match\n List.find_mapi\n (List.rev (Field.unpack x))\n ~f:(fun i x -> if x then Some i else None)\n with\n | Some leading_zeroes ->\n Field.size_in_bits - leading_zeroes\n | None ->\n 0\n in\n num_bits\n\n (* Someday: this could definitely be made more efficient *)\n let num_bits_upper_bound_unpacked : Boolean.var list -> Field.Var.t Checked.t\n =\n fun x_unpacked ->\n let%bind res =\n exists Typ.field\n ~request:(As_prover.return Num_bits_upper_bound)\n ~compute:\n As_prover.(\n map\n (read_var (Field.Var.project x_unpacked))\n ~f:(fun x -> Field.of_int (num_bits_upper_bound_unchecked x)))\n in\n let%map () = assert_num_bits_upper_bound x_unpacked res in\n res\n\n let num_bits_upper_bound ~max_length (x : Field.Var.t) : Field.Var.t Checked.t\n =\n Field.Checked.unpack x ~length:max_length >>= num_bits_upper_bound_unpacked\n\n let%test_module \"Snark_util\" =\n ( module struct\n let () = Random.init 123456789\n\n let random_bitstring length =\n List.init length ~f:(fun _ -> Random.bool ())\n\n let random_n_bit_field_elt n = Field.project (random_bitstring n)\n\n let%test_unit \"compare\" =\n let bit_length = Field.size_in_bits - 2 in\n let random () = random_n_bit_field_elt bit_length in\n let test () =\n let x = random () in\n let y = random () in\n let less, less_or_equal =\n run_and_check\n (let%map { less; less_or_equal } =\n Field.Checked.compare ~bit_length (Field.Var.constant x)\n (Field.Var.constant y)\n in\n As_prover.(\n map2 (read Boolean.typ less)\n (read Boolean.typ less_or_equal)\n ~f:Tuple2.create) )\n |> Or_error.ok_exn\n in\n let r = Bigint.(compare (of_field x) (of_field y)) in\n assert (Bool.equal less (r < 0)) ;\n assert (Bool.equal less_or_equal (r <= 0))\n in\n for _i = 0 to 100 do\n test ()\n done\n\n let%test_unit \"boolean_assert_lte\" =\n Or_error.ok_exn\n (check\n (Checked.all_unit\n [ boolean_assert_lte Boolean.false_ Boolean.false_\n ; boolean_assert_lte Boolean.false_ Boolean.true_\n ; boolean_assert_lte Boolean.true_ Boolean.true_\n ] ) ) ;\n assert (\n Or_error.is_error\n (check (boolean_assert_lte Boolean.true_ Boolean.false_)) )\n\n let%test_unit \"assert_decreasing\" =\n let decreasing bs =\n check (assert_decreasing (List.map ~f:Boolean.var_of_value bs))\n in\n Or_error.ok_exn (decreasing [ true; true; true; false ]) ;\n Or_error.ok_exn (decreasing [ true; true; false; false ]) ;\n assert (Or_error.is_error (decreasing [ true; true; false; true ]))\n\n let%test_unit \"n_ones\" =\n let total_length = 6 in\n let test n =\n let t () =\n n_ones ~total_length (Field.Var.constant (Field.of_int n))\n in\n let handle_with (resp : bool list) =\n handle t (fun (With { request; respond }) ->\n match request with\n | N_ones ->\n respond (Provide resp)\n | _ ->\n unhandled )\n in\n let correct = Int.pow 2 n - 1 in\n let to_bits k =\n List.init total_length ~f:(fun i -> (k lsr i) land 1 = 1)\n in\n for i = 0 to Int.pow 2 total_length - 1 do\n if i = correct then\n Or_error.ok_exn (check (handle_with (to_bits i)))\n else assert (Or_error.is_error (check (handle_with (to_bits i))))\n done\n in\n for n = 0 to total_length do\n test n\n done\n\n let%test_unit \"num_bits_int\" =\n assert (num_bits_int 1 = 1) ;\n assert (num_bits_int 5 = 3) ;\n assert (num_bits_int 17 = 5)\n\n let%test_unit \"num_bits_upper_bound_unchecked\" =\n let f k bs =\n assert (num_bits_upper_bound_unchecked (Field.project bs) = k)\n in\n f 3 [ true; true; true; false; false ] ;\n f 4 [ true; true; true; true; false ] ;\n f 3 [ true; false; true; false; false ] ;\n f 5 [ true; false; true; false; true ]\n\n (*let%test_unit \"num_bits_upper_bound\" =\n let max_length = Field.size_in_bits - 1 in\n let test x =\n let handle_with resp =\n handle\n (num_bits_upper_bound ~max_length (Field.Var.constant x))\n (fun (With {request; respond}) ->\n match request with\n | Num_bits_upper_bound -> respond (Field.of_int resp)\n | _ -> unhandled)\n in\n let true_answer = num_bits_upper_bound_unchecked x in\n for i = 0 to true_answer - 1 do\n if check (handle_with i) ()\n then begin\n let n = Bigint.of_field x in\n failwithf !\"Shouldn't have passed: x=%s, i=%d\"\n (String.init max_length ~f:(fun j -> if Bigint.test_bit n j then '1' else '0'))\n i ();\n end;\n done;\n assert (check (handle_with true_answer) ())\n in\n test (random_n_bit_field_elt max_length)*)\n end )\nend\n","open Snark_bits\n\nmodule type S = sig\n include Snarky_backendless.Snark_intf.S\n\n module Snarkable : sig\n module type S = sig\n type var\n\n type value\n\n val typ : (var, value) Typ.t\n end\n\n module Bits : sig\n module type Faithful =\n Bits_intf.Snarkable.Faithful\n with type ('a, 'b) typ := ('a, 'b) Typ.t\n and type 'a checked := 'a Checked.t\n and type boolean_var := Boolean.var\n\n module type Lossy =\n Bits_intf.Snarkable.Lossy\n with type ('a, 'b) typ := ('a, 'b) Typ.t\n and type 'a checked := 'a Checked.t\n and type boolean_var := Boolean.var\n end\n end\nend\n","(* data_hash.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\n[%%ifdef consensus_mechanism]\n\nopen Bitstring_lib\n\n[%%endif]\n\nmodule type Full_size = Data_hash_intf.Full_size\n\nmodule Make_basic (M : sig\n val length_in_bits : int\nend) =\nstruct\n type t = Field.t [@@deriving sexp, compare, hash]\n\n let to_decimal_string (t : Field.t) = Field.to_string t\n\n let of_decimal_string (s : string) = Field.of_string s\n\n let to_bytes t =\n Fold_lib.(Fold.bool_t_to_string (Fold.of_list (Field.unpack t)))\n\n let length_in_bits = M.length_in_bits\n\n let () = assert (Int.(length_in_bits <= Field.size_in_bits))\n\n let to_input t = Random_oracle.Input.Chunked.field t\n\n [%%ifdef consensus_mechanism]\n\n (* this is in consensus code, because Bigint comes\n from snarky functors\n *)\n let gen : t Quickcheck.Generator.t =\n let m =\n if Int.(length_in_bits = Field.size_in_bits) then\n Bignum_bigint.(Field.size - one)\n else Bignum_bigint.(pow (of_int 2) (of_int length_in_bits) - one)\n in\n Quickcheck.Generator.map\n Bignum_bigint.(gen_incl zero m)\n ~f:(fun x -> Bigint.(to_field (of_bignum_bigint x)))\n\n type var =\n { digest : Random_oracle.Checked.Digest.t\n ; mutable bits : Boolean.var Bitstring.Lsb_first.t option\n }\n\n let var_of_t t =\n let n = Bigint.of_field t in\n { digest = Field.Var.constant t\n ; bits =\n Some\n (Bitstring.Lsb_first.of_list\n (List.init M.length_in_bits ~f:(fun i ->\n Boolean.var_of_value (Bigint.test_bit n i) ) ) )\n }\n\n open Let_syntax\n\n let var_to_hash_packed { digest; _ } = digest\n\n (* TODO: Audit this usage of choose_preimage *)\n let unpack =\n if Int.( = ) length_in_bits Field.size_in_bits then fun x ->\n Field.Checked.choose_preimage_var x ~length:length_in_bits\n >>| fun x -> (x :> Boolean.var list)\n else Field.Checked.unpack ~length:length_in_bits\n\n let%snarkydef_ var_to_bits t =\n match t.bits with\n | Some bits ->\n return (bits :> Boolean.var list)\n | None ->\n let%map bits = unpack t.digest in\n t.bits <- Some (Bitstring.Lsb_first.of_list bits) ;\n bits\n\n let var_to_input (t : var) = Random_oracle.Input.Chunked.field t.digest\n\n (* TODO : use Random oracle.Digest to satisfy Bits_intf.S, move out of\n consensus_mechanism guard\n *)\n module Bs =\n Snark_bits.Bits.Make_field\n (Snark_params.Tick.Field)\n (Snark_params.Tick.Bigint)\n\n include (Bs : module type of Bs with type t := t)\n\n let assert_equal x y = Field.Checked.Assert.equal x.digest y.digest\n\n let equal_var x y = Field.Checked.equal x.digest y.digest\n\n let typ : (var, t) Typ.t =\n Typ.transport_var Typ.field\n ~there:(fun { digest; bits = _ } -> digest)\n ~back:(fun digest -> { digest; bits = None })\n\n [%%endif]\nend\n\nmodule T0 = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Make_full_size (B58_data : Data_hash_intf.Data_hash_descriptor) = struct\n module Basic = Make_basic (struct\n let length_in_bits = Field.size_in_bits\n end)\n\n include Basic\n\n module Base58_check = Codable.Make_base58_check (struct\n (* for compatibility with legacy Base58Check serializations *)\n include T0.Stable.Latest.With_all_version_tags\n\n (* the serialization here is only used for the hash impl which is only\n used for hashtbl, it's ok to disagree with the \"real\" serialization *)\n include Hashable.Make_binable (T0.Stable.Latest)\n include B58_data\n end)\n\n [%%define_locally\n Base58_check.\n (to_base58_check, of_base58_check, of_base58_check_exn, to_yojson, of_yojson)]\n\n module T = struct\n type t = Field.t [@@deriving sexp, compare, hash]\n end\n\n include Comparable.Make (T)\n include Hashable.Make (T)\n\n let of_hash = Fn.id\n\n let to_field = Fn.id\n\n [%%ifdef consensus_mechanism]\n\n let var_of_hash_packed digest = { digest; bits = None }\n\n let var_to_field { digest; _ } = digest\n\n let if_ cond ~then_ ~else_ =\n let%map digest =\n Field.Checked.if_ cond ~then_:then_.digest ~else_:else_.digest\n in\n { digest; bits = None }\n\n [%%endif]\nend\n","type t\n\nexternal create : unit -> t = \"caml_pasta_fp_poseidon_params_create\"\n\nexternal block_cipher : t -> Kimchi_bindings.FieldVectors.Fp.t -> unit\n = \"caml_pasta_fp_poseidon_block_cipher\"\n","let length_in_bytes = 20\n\nmodule T : sig\n type t = private string\n\n val create : string -> t\nend = struct\n type t = string\n\n let padding_char = '*'\n\n let create s : t =\n let string_length = String.length s in\n let r =\n if string_length <= length_in_bytes then\n let diff = length_in_bytes - string_length in\n s ^ String.init diff (fun _ -> padding_char)\n else String.sub s 0 length_in_bytes\n in\n assert (String.length r = length_in_bytes) ;\n r\nend\n\ninclude T\n\nlet protocol_state = create \"MinaProtoState\"\n\nlet protocol_state_body = create \"MinaProtoStateBody\"\n\nlet account = create \"MinaAccount\"\n\nlet side_loaded_vk = create \"MinaSideLoadedVk\"\n\nlet zkapp_account = create \"MinaZkappAccount\"\n\nlet zkapp_payload = create \"MinaZkappPayload\"\n\nlet zkapp_body_mainnet = create \"MainnetZkappBody\"\n\nlet zkapp_body_testnet = create \"TestnetZkappBody\"\n\nlet zkapp_body ?(chain = Mina_signature_kind.t) =\n match chain with\n | Mainnet ->\n zkapp_body_mainnet\n | Testnet ->\n zkapp_body_testnet\n | Other_network chain_name ->\n create (chain_name ^ \"ZkappBody\")\n\nlet merkle_tree i = create (Printf.sprintf \"MinaMklTree%03d\" i)\n\nlet coinbase_merkle_tree i = create (Printf.sprintf \"MinaCbMklTree%03d\" i)\n\nlet merge_snark = create \"MinaMergeSnark\"\n\nlet base_snark = create \"MinaBaseSnark\"\n\nlet transition_system_snark = create \"MinaTransitionSnark\"\n\nlet signature_testnet = create \"CodaSignature\"\n\nlet signature_mainnet = create \"MinaSignatureMainnet\"\n\nlet signature_other chain_name = create (chain_name ^ \"Signature\")\n\nlet receipt_chain_user_command = create \"MinaReceiptUC\"\n\n(* leaving this one with \"Coda\", to preserve the existing hashes *)\nlet receipt_chain_zkapp = create \"CodaReceiptZkapp\"\n\nlet epoch_seed = create \"MinaEpochSeed\"\n\nlet vrf_message = create \"MinaVrfMessage\"\n\nlet vrf_output = create \"MinaVrfOutput\"\n\nlet vrf_evaluation = create \"MinaVrfEvaluation\"\n\nlet pending_coinbases = create \"PendingCoinbases\"\n\nlet coinbase_stack_data = create \"CoinbaseStackData\"\n\n(* length is limited, so we drop some characters here *)\nlet coinbase_stack_state_hash = create \"CoinbaseStackStaHash\"\n\nlet coinbase_stack = create \"CoinbaseStack\"\n\nlet coinbase = create \"Coinbase\"\n\nlet checkpoint_list = create \"MinaCheckpoints\"\n\nlet bowe_gabizon_hash = create \"MinaTockBGHash\"\n\nlet zkapp_precondition = create \"MinaZkappPred\"\n\n(*for Zkapp_precondition.Account.t*)\nlet zkapp_precondition_account = create \"MinaZkappPredAcct\"\n\nlet zkapp_precondition_protocol_state = create \"MinaZkappPredPS\"\n\n(*for Account_update.Account_precondition.t*)\nlet account_update_account_precondition = create \"MinaAcctUpdAcctPred\"\n\nlet account_update_cons = create \"MinaAcctUpdateCons\"\n\nlet account_update_node = create \"MinaAcctUpdateNode\"\n\nlet account_update_stack_frame = create \"MinaAcctUpdStckFrm\"\n\nlet account_update_stack_frame_cons = create \"MinaActUpStckFrmCons\"\n\nlet zkapp_uri = create \"MinaZkappUri\"\n\nlet zkapp_event = create \"MinaZkappEvent\"\n\nlet zkapp_events = create \"MinaZkappEvents\"\n\nlet zkapp_actions = create \"MinaZkappSeqEvents\"\n\nlet zkapp_memo = create \"MinaZkappMemo\"\n\nlet zkapp_test = create \"MinaZkappTest\"\n\nlet derive_token_id = create \"MinaDeriveTokenId\"\n","module Js = struct\n type t\n\n type 'a js_array = t\n\n type ('a, 'b) meth_callback = t\n\n external string : string -> t = \"caml_jsstring_of_string\"\n\n external to_string : t -> string = \"caml_string_of_jsstring\"\n\n external bytestring : string -> t = \"caml_jsbytes_of_string\"\n\n external to_bytestring : t -> string = \"caml_string_of_jsbytes\"\n\n external bool : bool -> t = \"caml_js_from_bool\"\n\n external to_bool : t -> bool = \"caml_js_to_bool\"\n\n external array : 'a array -> t = \"caml_js_from_array\"\n\n external to_array : t -> 'a array = \"caml_js_to_array\"\n\n external number_of_float : float -> t = \"caml_js_from_float\"\n\n external float_of_number : t -> float = \"caml_js_to_float\"\n\n external typeof : t -> t = \"caml_js_typeof\"\n\n external instanceof : t -> t -> bool = \"caml_js_instanceof\"\n\n external debugger : unit -> unit = \"debugger\"\n\n external get : t -> t -> t = \"caml_js_get\"\n\n external set : t -> t -> t -> unit = \"caml_js_set\"\n\n external delete : t -> t -> unit = \"caml_js_delete\"\n\n external call : t -> t -> t array -> t = \"caml_js_call\"\n\n external fun_call : t -> t array -> t = \"caml_js_fun_call\"\n\n external meth_call : t -> string -> t array -> t = \"caml_js_meth_call\"\n\n external new_obj : t -> t array -> t = \"caml_js_new\"\n\n external new_obj_arr : t -> t js_array -> t = \"caml_ojs_new_arr\"\n\n external obj : (string * t) array -> t = \"caml_js_object\"\n\n external equals : t -> t -> bool = \"caml_js_equals\"\n\n external pure_expr : (unit -> 'a) -> 'a = \"caml_js_pure_expr\"\n\n external eval_string : string -> 'a = \"caml_js_eval_string\"\n\n external js_expr : string -> 'a = \"caml_js_expr\"\n\n external pure_js_expr : string -> 'a = \"caml_pure_js_expr\"\n\n external callback_with_arguments :\n (t js_array -> 'b) -> ('c, t js_array -> 'b) meth_callback\n = \"caml_js_wrap_callback_arguments\"\n\n external callback_with_arity : int -> ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n = \"caml_js_wrap_callback_strict\"\n\n external meth_callback : ('b -> 'a) -> ('b, 'a) meth_callback\n = \"caml_js_wrap_meth_callback_unsafe\"\n\n external meth_callback_with_arity : int -> ('b -> 'a) -> ('b, 'a) meth_callback\n = \"caml_js_wrap_meth_callback_strict\"\n\n external meth_callback_with_arguments :\n ('b -> t js_array -> 'a) -> ('b, t js_array -> 'a) meth_callback\n = \"caml_js_wrap_meth_callback_arguments\"\n\n external wrap_callback : ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n = \"caml_js_wrap_callback\"\n\n external wrap_meth_callback : ('a -> 'b) -> ('a, 'b) meth_callback\n = \"caml_js_wrap_meth_callback\"\nend\n\nmodule Sys = struct\n type 'a callback = 'a\n\n external create_file : name:string -> content:string -> unit = \"caml_create_file\"\n\n external read_file : name:string -> string = \"caml_read_file_content\"\n\n external set_channel_output' : out_channel -> (js_string:Js.t -> unit) callback -> unit\n = \"caml_ml_set_channel_output\"\n\n external set_channel_input' : in_channel -> (unit -> string) callback -> unit\n = \"caml_ml_set_channel_refill\"\n\n external mount_point : unit -> string list = \"caml_list_mount_point\"\n\n external mount_autoload : string -> (string -> string -> string option) callback -> unit\n = \"caml_mount_autoload\"\n\n external unmount : string -> unit = \"caml_unmount\"\nend\n\nmodule Error : sig\n type t\n\n val raise_ : t -> 'a\n\n val attach_js_backtrace : exn -> force:bool -> exn\n (** Attach a JavasScript error to an OCaml exception. if [force = false] and a\n JavasScript error is already attached, it will do nothing. This function is useful to\n store and retrieve information about JavaScript stack traces.\n\n Attaching JavasScript errors will happen automatically when compiling with\n [--enable with-js-error]. *)\n\n val of_exn : exn -> t option\n (** Extract a JavaScript error attached to an OCaml exception, if any. This is useful to\n inspect an eventual stack strace, especially when sourcemap is enabled. *)\n\n exception Exn of t\n (** The [Error] exception wrap javascript exceptions when caught by OCaml code.\n In case the javascript exception is not an instance of javascript [Error],\n it will be serialized and wrapped into a [Failure] exception.\n *)\nend = struct\n type t\n\n exception Exn of t\n\n let _ = Callback.register_exception \"jsError\" (Exn (Obj.magic [||]))\n\n let raise_ : t -> 'a = Js.js_expr \"(function (exn) { throw exn })\"\n\n external of_exn : exn -> t option = \"caml_js_error_option_of_exception\"\n\n external attach_js_backtrace : exn -> force:bool -> exn = \"caml_exn_with_js_backtrace\"\nend\n\n[@@@ocaml.warning \"-32-60\"]\n\nmodule For_compatibility_only = struct\n (* Add primitives for compatibility reasons. Existing users might\n depend on it (e.g. gen_js_api), we dont want the ocaml compiler\n to complain about theses missing primitives. *)\n\n external caml_js_from_string : string -> Js.t = \"caml_js_from_string\"\n\n external caml_js_to_byte_string : Js.t -> string = \"caml_js_to_byte_string\"\n\n external caml_js_to_string : Js.t -> string = \"caml_js_to_string\"\n\n external caml_list_of_js_array : 'a Js.js_array -> 'a list = \"caml_list_of_js_array\"\n\n external caml_list_to_js_array : 'a list -> 'a Js.js_array = \"caml_list_to_js_array\"\n\n external variable : string -> 'a = \"caml_js_var\"\nend\n\nmodule Typed_array = struct\n type ('a, 'b) typedArray = Js.t\n\n type arrayBuffer = Js.t\n\n type uint8Array = Js.t\n\n external kind : ('a, 'b) typedArray -> ('a, 'b) Bigarray.kind\n = \"caml_ba_kind_of_typed_array\"\n\n external from_genarray :\n ('a, 'b, Bigarray.c_layout) Bigarray.Genarray.t -> ('a, 'b) typedArray\n = \"caml_ba_to_typed_array\"\n\n external to_genarray :\n ('a, 'b) typedArray -> ('a, 'b, Bigarray.c_layout) Bigarray.Genarray.t\n = \"caml_ba_from_typed_array\"\n\n module Bigstring = struct\n type t = (char, Bigarray.int8_unsigned_elt, Bigarray.c_layout) Bigarray.Array1.t\n\n external to_arrayBuffer : t -> arrayBuffer = \"bigstring_to_array_buffer\"\n\n external to_uint8Array : t -> uint8Array = \"bigstring_to_typed_array\"\n\n external of_arrayBuffer : arrayBuffer -> t = \"bigstring_of_array_buffer\"\n\n external of_uint8Array : uint8Array -> t = \"bigstring_of_typed_array\"\n end\n\n external of_uint8Array : uint8Array -> string = \"caml_string_of_array\"\nend\n\nmodule Int64 = struct\n external create_int64_lo_mi_hi : int -> int -> int -> Int64.t\n = \"caml_int64_create_lo_mi_hi\"\nend\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\n(* This local module [Js] is needed so that the ppx_js extension work within that file. *)\nmodule Js = struct\n type +'a t\n\n type (-'a, +'b) meth_callback\n\n module Unsafe = struct\n type top\n\n type any = top t\n\n type any_js_array = any\n\n external inject : 'a -> any = \"%identity\"\n\n external coerce : _ t -> _ t = \"%identity\"\n\n external get : 'a -> 'b -> 'c = \"caml_js_get\"\n\n external set : 'a -> 'b -> 'c -> unit = \"caml_js_set\"\n\n external delete : 'a -> 'b -> unit = \"caml_js_delete\"\n\n external call : 'a -> 'b -> any array -> 'c = \"caml_js_call\"\n\n external fun_call : 'a -> any array -> 'b = \"caml_js_fun_call\"\n\n external meth_call : 'a -> string -> any array -> 'b = \"caml_js_meth_call\"\n\n external new_obj : 'a -> any array -> 'b = \"caml_js_new\"\n\n external new_obj_arr : 'a -> any_js_array -> 'b = \"caml_ojs_new_arr\"\n\n external obj : (string * any) array -> 'a = \"caml_js_object\"\n\n external equals : 'a -> 'b -> bool = \"caml_js_equals\"\n\n external pure_expr : (unit -> 'a) -> 'a = \"caml_js_pure_expr\"\n\n external eval_string : string -> 'a = \"caml_js_eval_string\"\n\n external js_expr : string -> 'a = \"caml_js_expr\"\n\n external pure_js_expr : string -> 'a = \"caml_pure_js_expr\"\n\n let global = pure_js_expr \"globalThis\"\n\n external callback : ('a -> 'b) -> ('c, 'a -> 'b) meth_callback = \"%identity\"\n\n external callback_with_arguments :\n (any_js_array -> 'b) -> ('c, any_js_array -> 'b) meth_callback\n = \"caml_js_wrap_callback_arguments\"\n\n external callback_with_arity : int -> ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n = \"caml_js_wrap_callback_strict\"\n\n external meth_callback : ('b -> 'a) -> ('b, 'a) meth_callback\n = \"caml_js_wrap_meth_callback_unsafe\"\n\n external meth_callback_with_arity : int -> ('b -> 'a) -> ('b, 'a) meth_callback\n = \"caml_js_wrap_meth_callback_strict\"\n\n external meth_callback_with_arguments :\n ('b -> any_js_array -> 'a) -> ('b, any_js_array -> 'a) meth_callback\n = \"caml_js_wrap_meth_callback_arguments\"\n\n (* DEPRECATED *)\n external variable : string -> 'a = \"caml_js_var\"\n end\n\n (****)\n\n type 'a opt = 'a\n\n type 'a optdef = 'a\n\n external debugger : unit -> unit = \"debugger\"\n\n let null : 'a opt = Unsafe.pure_js_expr \"null\"\n\n external some : 'a -> 'a opt = \"%identity\"\n\n let undefined : 'a optdef = Unsafe.pure_js_expr \"undefined\"\n\n external def : 'a -> 'a optdef = \"%identity\"\n\n module type OPT = sig\n type 'a t\n\n val empty : 'a t\n\n val return : 'a -> 'a t\n\n val map : 'a t -> ('a -> 'b) -> 'b t\n\n val bind : 'a t -> ('a -> 'b t) -> 'b t\n\n val test : 'a t -> bool\n\n val iter : 'a t -> ('a -> unit) -> unit\n\n val case : 'a t -> (unit -> 'b) -> ('a -> 'b) -> 'b\n\n val get : 'a t -> (unit -> 'a) -> 'a\n\n val option : 'a option -> 'a t\n\n val to_option : 'a t -> 'a option\n end\n\n module Opt : OPT with type 'a t = 'a opt = struct\n type 'a t = 'a opt\n\n let empty = null\n\n let return = some\n\n let map x f = if Unsafe.equals x null then null else return (f x)\n\n let bind x f = if Unsafe.equals x null then null else f x\n\n let test x = not (Unsafe.equals x null)\n\n let iter x f = if not (Unsafe.equals x null) then f x\n\n let case x f g = if Unsafe.equals x null then f () else g x\n\n let get x f = if Unsafe.equals x null then f () else x\n\n let option x =\n match x with\n | None -> empty\n | Some x -> return x\n\n let to_option x = case x (fun () -> None) (fun x -> Some x)\n end\n\n module Optdef : OPT with type 'a t = 'a optdef = struct\n type 'a t = 'a optdef\n\n let empty = undefined\n\n let return = def\n\n let map x f = if x == undefined then undefined else return (f x)\n\n let bind x f = if x == undefined then undefined else f x\n\n let test x = x != undefined\n\n let iter x f = if x != undefined then f x\n\n let case x f g = if x == undefined then f () else g x\n\n let get x f = if x == undefined then f () else x\n\n let option x =\n match x with\n | None -> empty\n | Some x -> return x\n\n let to_option x = case x (fun () -> None) (fun x -> Some x)\n end\n\n (****)\n\n let coerce x f g = Opt.get (f x) (fun () -> g x)\n\n let coerce_opt x f g = Opt.get (Opt.bind x f) (fun () -> g x)\n\n (****)\n\n type +'a meth\n\n type +'a gen_prop\n\n type 'a readonly_prop = < get : 'a > gen_prop\n\n type 'a writeonly_prop = < set : 'a -> unit > gen_prop\n\n type 'a prop = < get : 'a ; set : 'a -> unit > gen_prop\n\n type 'a optdef_prop = < get : 'a optdef ; set : 'a -> unit > gen_prop\n\n type +'a constr\n\n (****)\n\n type 'a callback = (unit, 'a) meth_callback\n\n external wrap_callback : ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n = \"caml_js_wrap_callback\"\n\n external wrap_meth_callback : ('a -> 'b) -> ('a, 'b) meth_callback\n = \"caml_js_wrap_meth_callback\"\n\n (****)\n\n let _true = Unsafe.pure_js_expr \"true\"\n\n let _false = Unsafe.pure_js_expr \"false\"\n\n type match_result_handle\n\n type string_array\n\n class type js_string =\n object\n method toString : js_string t meth\n\n method valueOf : js_string t meth\n\n method charAt : int -> js_string t meth\n\n method charCodeAt : int -> float meth\n\n (* This may return NaN... *)\n method concat : js_string t -> js_string t meth\n\n method concat_2 : js_string t -> js_string t -> js_string t meth\n\n method concat_3 : js_string t -> js_string t -> js_string t -> js_string t meth\n\n method concat_4 :\n js_string t -> js_string t -> js_string t -> js_string t -> js_string t meth\n\n method indexOf : js_string t -> int meth\n\n method indexOf_from : js_string t -> int -> int meth\n\n method lastIndexOf : js_string t -> int meth\n\n method lastIndexOf_from : js_string t -> int -> int meth\n\n method localeCompare : js_string t -> float meth\n\n method _match : regExp t -> match_result_handle t opt meth\n\n method replace : regExp t -> js_string t -> js_string t meth\n\n method replace_string : js_string t -> js_string t -> js_string t meth\n\n method search : regExp t -> int meth\n\n method slice : int -> int -> js_string t meth\n\n method slice_end : int -> js_string t meth\n\n method split : js_string t -> string_array t meth\n\n method split_limited : js_string t -> int -> string_array t meth\n\n method split_regExp : regExp t -> string_array t meth\n\n method split_regExpLimited : regExp t -> int -> string_array t meth\n\n method substring : int -> int -> js_string t meth\n\n method substring_toEnd : int -> js_string t meth\n\n method toLowerCase : js_string t meth\n\n method toLocaleLowerCase : js_string t meth\n\n method toUpperCase : js_string t meth\n\n method toLocaleUpperCase : js_string t meth\n\n method trim : js_string t meth\n\n method length : int readonly_prop\n end\n\n and regExp =\n object\n method exec : js_string t -> match_result_handle t opt meth\n\n method test : js_string t -> bool t meth\n\n method toString : js_string t meth\n\n method source : js_string t readonly_prop\n\n method global : bool t readonly_prop\n\n method ignoreCase : bool t readonly_prop\n\n method multiline : bool t readonly_prop\n\n method lastIndex : int prop\n end\n\n (* string is used by ppx_js, it needs to come before any use of the\n new syntax in this file *)\n external string : string -> js_string t = \"caml_jsstring_of_string\"\n\n external to_string : js_string t -> string = \"caml_string_of_jsstring\"\nend\n\ninclude Js\n\nclass type string_constr =\n object\n method fromCharCode : int -> js_string t meth\n end\n\nlet string_constr = Unsafe.global##._String\n\nlet regExp = Unsafe.global##._RegExp\n\nlet regExp_copy = regExp\n\nlet regExp_withFlags = regExp\n\nclass type ['a] js_array =\n object\n method toString : js_string t meth\n\n method toLocaleString : js_string t meth\n\n method concat : 'a js_array t -> 'a js_array t meth\n\n method join : js_string t -> js_string t meth\n\n method pop : 'a optdef meth\n\n method push : 'a -> int meth\n\n method push_2 : 'a -> 'a -> int meth\n\n method push_3 : 'a -> 'a -> 'a -> int meth\n\n method push_4 : 'a -> 'a -> 'a -> 'a -> int meth\n\n method reverse : 'a js_array t meth\n\n method shift : 'a optdef meth\n\n method slice : int -> int -> 'a js_array t meth\n\n method slice_end : int -> 'a js_array t meth\n\n method sort : ('a -> 'a -> float) callback -> 'a js_array t meth\n\n method sort_asStrings : 'a js_array t meth\n\n method splice : int -> int -> 'a js_array t meth\n\n method splice_1 : int -> int -> 'a -> 'a js_array t meth\n\n method splice_2 : int -> int -> 'a -> 'a -> 'a js_array t meth\n\n method splice_3 : int -> int -> 'a -> 'a -> 'a -> 'a js_array t meth\n\n method splice_4 : int -> int -> 'a -> 'a -> 'a -> 'a -> 'a js_array t meth\n\n method unshift : 'a -> int meth\n\n method unshift_2 : 'a -> 'a -> int meth\n\n method unshift_3 : 'a -> 'a -> 'a -> int meth\n\n method unshift_4 : 'a -> 'a -> 'a -> 'a -> int meth\n\n method some : ('a -> int -> 'a js_array t -> bool t) callback -> bool t meth\n\n method every : ('a -> int -> 'a js_array t -> bool t) callback -> bool t meth\n\n method forEach : ('a -> int -> 'a js_array t -> unit) callback -> unit meth\n\n method map : ('a -> int -> 'a js_array t -> 'b) callback -> 'b js_array t meth\n\n method filter : ('a -> int -> 'a js_array t -> bool t) callback -> 'a js_array t meth\n\n method reduce_init :\n ('b -> 'a -> int -> 'a js_array t -> 'b) callback -> 'b -> 'b meth\n\n method reduce : ('a -> 'a -> int -> 'a js_array t -> 'a) callback -> 'a meth\n\n method reduceRight_init :\n ('b -> 'a -> int -> 'a js_array t -> 'b) callback -> 'b -> 'b meth\n\n method reduceRight : ('a -> 'a -> int -> 'a js_array t -> 'a) callback -> 'a meth\n\n method length : int prop\n end\n\nlet object_constructor = Unsafe.global##._Object\n\nlet object_keys o : js_string t js_array t = object_constructor##keys o\n\nlet array_constructor = Unsafe.global##._Array\n\nlet array_empty = array_constructor\n\nlet array_length = array_constructor\n\nlet array_get : 'a #js_array t -> int -> 'a optdef = Unsafe.get\n\nlet array_set : 'a #js_array t -> int -> 'a -> unit = Unsafe.set\n\nlet array_map_poly :\n 'a #js_array t -> ('a -> int -> 'a #js_array t -> 'b) callback -> 'b #js_array t =\n fun a cb -> (Unsafe.coerce a)##map cb\n\nlet array_map f a = array_map_poly a (wrap_callback (fun x _idx _ -> f x))\n\nlet array_mapi f a = array_map_poly a (wrap_callback (fun x idx _ -> f idx x))\n\nclass type match_result =\n object\n inherit [js_string t] js_array\n\n method index : int readonly_prop\n\n method input : js_string t readonly_prop\n end\n\nlet str_array : string_array t -> js_string t js_array t = Unsafe.coerce\n\nlet match_result : match_result_handle t -> match_result t = Unsafe.coerce\n\nclass type number =\n object\n method toString : js_string t meth\n\n method toString_radix : int -> js_string t meth\n\n method toLocaleString : js_string t meth\n\n method toFixed : int -> js_string t meth\n\n method toExponential : js_string t meth\n\n method toExponential_digits : int -> js_string t meth\n\n method toPrecision : int -> js_string t meth\n end\n\nexternal number_of_float : float -> number t = \"caml_js_from_float\"\n\nexternal float_of_number : number t -> float = \"caml_js_to_float\"\n\nclass type date =\n object\n method toString : js_string t meth\n\n method toDateString : js_string t meth\n\n method toTimeString : js_string t meth\n\n method toLocaleString : js_string t meth\n\n method toLocaleDateString : js_string t meth\n\n method toLocaleTimeString : js_string t meth\n\n method valueOf : float meth\n\n method getTime : float meth\n\n method getFullYear : int meth\n\n method getUTCFullYear : int meth\n\n method getMonth : int meth\n\n method getUTCMonth : int meth\n\n method getDate : int meth\n\n method getUTCDate : int meth\n\n method getDay : int meth\n\n method getUTCDay : int meth\n\n method getHours : int meth\n\n method getUTCHours : int meth\n\n method getMinutes : int meth\n\n method getUTCMinutes : int meth\n\n method getSeconds : int meth\n\n method getUTCSeconds : int meth\n\n method getMilliseconds : int meth\n\n method getUTCMilliseconds : int meth\n\n method getTimezoneOffset : int meth\n\n method setTime : float -> float meth\n\n method setFullYear : int -> float meth\n\n method setUTCFullYear : int -> float meth\n\n method setMonth : int -> float meth\n\n method setUTCMonth : int -> float meth\n\n method setDate : int -> float meth\n\n method setUTCDate : int -> float meth\n\n method setDay : int -> float meth\n\n method setUTCDay : int -> float meth\n\n method setHours : int -> float meth\n\n method setUTCHours : int -> float meth\n\n method setMinutes : int -> float meth\n\n method setUTCMinutes : int -> float meth\n\n method setSeconds : int -> float meth\n\n method setUTCSeconds : int -> float meth\n\n method setMilliseconds : int -> float meth\n\n method setUTCMilliseconds : int -> float meth\n\n method toUTCString : js_string t meth\n\n method toISOString : js_string t meth\n\n method toJSON : 'a -> js_string t meth\n end\n\nclass type date_constr =\n object\n method parse : js_string t -> float meth\n\n method _UTC_month : int -> int -> float meth\n\n method _UTC_day : int -> int -> float meth\n\n method _UTC_hour : int -> int -> int -> int -> float meth\n\n method _UTC_min : int -> int -> int -> int -> int -> float meth\n\n method _UTC_sec : int -> int -> int -> int -> int -> int -> float meth\n\n method _UTC_ms : int -> int -> int -> int -> int -> int -> int -> float meth\n\n method now : float meth\n end\n\nlet date_constr = Unsafe.global##._Date\n\nlet date : date_constr t = date_constr\n\nlet date_now : date t constr = date_constr\n\nlet date_fromTimeValue : (float -> date t) constr = date_constr\n\nlet date_month : (int -> int -> date t) constr = date_constr\n\nlet date_day : (int -> int -> int -> date t) constr = date_constr\n\nlet date_hour : (int -> int -> int -> int -> date t) constr = date_constr\n\nlet date_min : (int -> int -> int -> int -> int -> date t) constr = date_constr\n\nlet date_sec : (int -> int -> int -> int -> int -> int -> date t) constr = date_constr\n\nlet date_ms : (int -> int -> int -> int -> int -> int -> int -> date t) constr =\n date_constr\n\nclass type math =\n object\n method _E : float readonly_prop\n\n method _LN2 : float readonly_prop\n\n method _LN10 : float readonly_prop\n\n method _LOG2E : float readonly_prop\n\n method _LOG10E : float readonly_prop\n\n method _PI : float readonly_prop\n\n method _SQRT1_2_ : float readonly_prop\n\n method _SQRT2 : float readonly_prop\n\n method abs : float -> float meth\n\n method acos : float -> float meth\n\n method asin : float -> float meth\n\n method atan : float -> float meth\n\n method atan2 : float -> float -> float meth\n\n method ceil : float -> float meth\n\n method cos : float -> float meth\n\n method exp : float -> float meth\n\n method floor : float -> float meth\n\n method log : float -> float meth\n\n method max : float -> float -> float meth\n\n method max_3 : float -> float -> float -> float meth\n\n method max_4 : float -> float -> float -> float -> float meth\n\n method min : float -> float -> float meth\n\n method min_3 : float -> float -> float -> float meth\n\n method min_4 : float -> float -> float -> float -> float meth\n\n method pow : float -> float -> float meth\n\n method random : float meth\n\n method round : float -> float meth\n\n method sin : float -> float meth\n\n method sqrt : float -> float meth\n\n method tan : float -> float meth\n end\n\nlet math = Unsafe.global##._Math\n\nclass type error =\n object\n method name : js_string t prop\n\n method message : js_string t prop\n\n method stack : js_string t optdef prop\n\n method toString : js_string t meth\n end\n\nlet error_constr = Unsafe.global##._Error\n\nmodule Js_error = struct\n type error_t = error t\n\n include Jsoo_runtime.Error\n\n external of_error : error_t -> t = \"%identity\"\n\n external to_error : t -> error_t = \"%identity\"\n\n let name e = to_string (to_error e)##.name\n\n let message e = to_string (to_error e)##.message\n\n let stack (e : t) : string option =\n Opt.to_option (Opt.map (to_error e)##.stack to_string)\n\n let to_string e = to_string (to_error e)##toString\nend\n\nmodule Magic = struct\n module type T = sig\n exception Error of error t\n end\n\n type ('a, 'b) eq = Eq : ('a, 'a) eq\n\n let (eq : (error t, Js_error.t) eq) = Obj.magic Eq\n\n let m =\n match eq with\n | Eq ->\n (module struct\n exception Error = Js_error.Exn\n end : T)\n\n module Error = (val m : T)\nend\n\ninclude Magic.Error\n\nlet raise_js_error e = Js_error.raise_ (Js_error.of_error e)\n\nlet string_of_error e = Js_error.to_string (Js_error.of_error e)\n\nlet exn_with_js_backtrace = Js_error.attach_js_backtrace\n\nexternal js_error_of_exn : exn -> error t opt = \"caml_js_error_of_exception\"\n\nclass type json =\n object\n method parse : js_string t -> 'a meth\n\n method stringify : 'a -> js_string t meth\n end\n\nlet _JSON : json t = Unsafe.global##._JSON\n\nlet decodeURI (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.decodeURI [| Unsafe.inject s |]\n\nlet decodeURIComponent (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.decodeURIComponent [| Unsafe.inject s |]\n\nlet encodeURI (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.encodeURI [| Unsafe.inject s |]\n\nlet encodeURIComponent (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.encodeURIComponent [| Unsafe.inject s |]\n\nlet escape (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.escape [| Unsafe.inject s |]\n\nlet unescape (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.unescape [| Unsafe.inject s |]\n\nexternal bool : bool -> bool t = \"caml_js_from_bool\"\n\nexternal to_bool : bool t -> bool = \"caml_js_to_bool\"\n\nexternal array : 'a array -> 'a js_array t = \"caml_js_from_array\"\n\nexternal to_array : 'a js_array t -> 'a array = \"caml_js_to_array\"\n\nexternal bytestring : string -> js_string t = \"caml_jsbytes_of_string\"\n\nexternal to_bytestring : js_string t -> string = \"caml_string_of_jsbytes\"\n\nexternal typeof : _ t -> js_string t = \"caml_js_typeof\"\n\nexternal instanceof : _ t -> _ constr -> bool = \"caml_js_instanceof\"\n\nlet isNaN (i : 'a) : bool =\n to_bool (Unsafe.fun_call Unsafe.global##.isNaN [| Unsafe.inject i |])\n\nlet parseInt (s : js_string t) : int =\n let s = Unsafe.fun_call Unsafe.global##.parseInt [| Unsafe.inject s |] in\n if isNaN s then failwith \"parseInt\" else s\n\nlet parseFloat (s : js_string t) : float =\n let s = Unsafe.fun_call Unsafe.global##.parseFloat [| Unsafe.inject s |] in\n if isNaN s then failwith \"parseFloat\" else s\n\nlet _ =\n Printexc.register_printer (function\n | Js_error.Exn e -> Some (Js_error.to_string e)\n | _ -> None)\n\nlet _ =\n Printexc.register_printer (fun e ->\n let e : < .. > t = Obj.magic e in\n if instanceof e array_constructor then None else Some (to_string e##toString))\n\nlet export_js (field : js_string t) x =\n Unsafe.set (Unsafe.pure_js_expr \"jsoo_exports\") field x\n\nlet export field x = export_js (string field) x\n\nlet export_all obj =\n let keys = object_keys obj in\n keys##forEach\n (wrap_callback (fun (key : js_string t) _ _ -> export_js key (Unsafe.get obj key)))\n\n(****)\n\n(* DEPRECATED *)\n\ntype float_prop = float prop\n\nexternal float : float -> float = \"%identity\"\n\nexternal to_float : float -> float = \"%identity\"\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\nmodule Field = Pickles.Impls.Step.Field.Constant\n\nexternal get_ts_bindings : unit -> Js.Unsafe.any Js.Optdef.t = \"getTsBindings\"\n\n(* the ?. operator from JS *)\nlet ( |. ) (value : _ Js.Optdef.t) (key : string) =\n Js.(\n if phys_equal value undefined then undefined\n else Unsafe.get value (string key))\n\nlet lookup kind prefix =\n get_ts_bindings () |. kind |. prefix |> Js.Optdef.to_option\n\nlet of_js x =\n Js.to_array x |> Array.map ~f:(Fn.compose Field.of_string Js.to_string)\n\nlet salt s =\n match lookup \"prefixHashes\" s with\n | Some state ->\n of_js state |> Random_oracle.State.of_array\n | None ->\n Random_oracle.salt s\n\nlet salt_legacy s =\n match lookup \"prefixHashesLegacy\" s with\n | Some state ->\n of_js state |> Random_oracle.Legacy.State.of_array\n | None ->\n Random_oracle.Legacy.salt s\n","open Core_kernel\nopen Hash_prefixes\n\nlet salt (s : Hash_prefixes.t) = Hash_prefix_create.salt (s :> string)\n\nlet salt_legacy (s : Hash_prefixes.t) =\n Hash_prefix_create.salt_legacy (s :> string)\n\nlet receipt_chain_signed_command = salt_legacy receipt_chain_user_command\n\nlet receipt_chain_zkapp_command = salt receipt_chain_user_command\n\nlet receipt_chain_zkapp = salt receipt_chain_zkapp\n\nlet coinbase = salt coinbase\n\nlet pending_coinbases = salt pending_coinbases\n\nlet coinbase_stack_data = salt coinbase_stack_data\n\nlet coinbase_stack_state_hash = salt coinbase_stack_state_hash\n\nlet coinbase_stack = salt coinbase_stack\n\nlet checkpoint_list = salt checkpoint_list\n\nlet merge_snark = salt merge_snark\n\nlet base_snark = salt base_snark\n\nlet protocol_state = salt protocol_state\n\nlet protocol_state_body = salt protocol_state_body\n\nlet merkle_tree =\n let f i = salt (merkle_tree i) in\n (* Cache up to the compiled ledger depth. *)\n let cached = ref [||] in\n fun i ->\n let len = Array.length !cached in\n if i >= len then\n cached :=\n Array.append !cached\n (Array.init (i + 1 - len) ~f:(fun i -> f (i + len))) ;\n !cached.(i)\n\nlet coinbase_merkle_tree =\n let f i = salt (coinbase_merkle_tree i) in\n let cached = ref [||] in\n fun i ->\n let len = Array.length !cached in\n if i >= len then\n cached :=\n Array.append !cached\n (Array.init (i + 1 - len) ~f:(fun i -> f (i + len))) ;\n !cached.(i)\n\nlet vrf_message = salt vrf_message\n\nlet signature_for_mainnet = salt signature_mainnet\n\nlet signature_for_testnet = salt signature_testnet\n\nlet signature_for_other chain_name = salt @@ signature_other chain_name\n\nlet signature ?(signature_kind = Mina_signature_kind.t) =\n match signature_kind with\n | Mainnet ->\n signature_for_mainnet\n | Testnet ->\n signature_for_testnet\n | Other_network chain_name ->\n signature_for_other chain_name\n\nlet signature_for_mainnet_legacy = salt_legacy signature_mainnet\n\nlet signature_for_testnet_legacy = salt_legacy signature_testnet\n\nlet signature_for_other_legacy chain_name =\n salt_legacy @@ signature_other chain_name\n\nlet signature_legacy ?(signature_kind = Mina_signature_kind.t) =\n match signature_kind with\n | Mainnet ->\n signature_for_mainnet_legacy\n | Testnet ->\n signature_for_testnet_legacy\n | Other_network chain_name ->\n signature_for_other_legacy chain_name\n\nlet vrf_output = salt vrf_output\n\nlet vrf_evaluation = salt vrf_evaluation\n\nlet epoch_seed = salt epoch_seed\n\nlet transition_system_snark = salt transition_system_snark\n\nlet account = salt account\n\nlet side_loaded_vk = salt side_loaded_vk\n\nlet zkapp_account = salt zkapp_account\n\nlet zkapp_payload = salt zkapp_payload\n\nlet zkapp_body ?(chain = Mina_signature_kind.t) = salt @@ zkapp_body ~chain\n\nlet zkapp_precondition = salt zkapp_precondition\n\nlet zkapp_precondition_account = salt zkapp_precondition_account\n\nlet zkapp_precondition_protocol_state = salt zkapp_precondition_protocol_state\n\nlet account_update_account_precondition =\n salt account_update_account_precondition\n\nlet account_update_cons = salt account_update_cons\n\nlet account_update_node = salt account_update_node\n\nlet account_update_stack_frame = salt account_update_stack_frame\n\nlet account_update_stack_frame_cons = salt account_update_stack_frame_cons\n\nlet zkapp_uri = salt zkapp_uri\n\nlet zkapp_event = salt zkapp_event\n\nlet zkapp_events = salt zkapp_events\n\nlet zkapp_actions = salt zkapp_actions\n\nlet zkapp_memo = salt zkapp_memo\n\nlet zkapp_test = salt zkapp_test\n\nlet derive_token_id = salt derive_token_id\n","open Core_kernel\nopen Fold_lib\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.S) = struct\n let triple_string trips =\n let to_string b = if b then \"1\" else \"0\" in\n String.concat ~sep:\" \"\n (List.map trips ~f:(fun (b1, b2, b3) ->\n to_string b1 ^ to_string b2 ^ to_string b3 ) )\n\n let checked_to_unchecked typ1 typ2 checked input =\n let open Impl in\n let checked_result =\n run_and_check\n (let%bind input = exists typ1 ~compute:(As_prover.return input) in\n let%map result = checked input in\n As_prover.read typ2 result )\n |> Or_error.ok_exn\n in\n checked_result\n\n let test_to_triples typ fold var_to_triples input =\n let open Impl in\n let checked =\n run_and_check\n (let%bind input = exists typ ~compute:(As_prover.return input) in\n let%map result = var_to_triples input in\n As_prover.all\n (List.map result\n ~f:\n (As_prover.read\n (Typ.tuple3 Boolean.typ Boolean.typ Boolean.typ) ) ) )\n |> Or_error.ok_exn\n in\n let unchecked = Fold.to_list (fold input) in\n if not ([%equal: (bool * bool * bool) list] checked unchecked) then\n failwithf\n !\"Got %s (%d)\\nexpected %s (%d)\"\n (triple_string checked) (List.length checked) (triple_string unchecked)\n (List.length unchecked) ()\n\n let test_equal ?(equal = Poly.( = )) typ1 typ2 checked unchecked input =\n let checked_result = checked_to_unchecked typ1 typ2 checked input in\n assert (equal checked_result (unchecked input))\n\n let arbitrary_string ~len =\n String.init (Random.int len) ~f:(fun _ ->\n Char.of_int_exn (Random.int_incl 0 255) )\n\n let with_randomness r f =\n let s = Caml.Random.get_state () in\n Random.init r ;\n try\n let x = f () in\n Caml.Random.set_state s ; x\n with e -> Caml.Random.set_state s ; raise e\n\n (** utility function to print digests to put in tests, see `check_serialization' below *)\n let print_digest digest = printf \"\\\"\" ; printf \"%s\" digest ; printf \"\\\"\\n%!\"\n\n (** use this function to test Bin_prot serialization of types *)\n let check_serialization (type t) (module M : Binable.S with type t = t)\n (t : t) known_good_digest =\n (* serialize value *)\n let sz = M.bin_size_t t in\n let buf = Bin_prot.Common.create_buf sz in\n ignore (M.bin_write_t buf ~pos:0 t : int) ;\n let bytes = Bytes.create sz in\n Bin_prot.Common.blit_buf_bytes buf bytes ~len:sz ;\n (* compute MD5 digest of serialization *)\n let digest = Md5.digest_bytes bytes |> Md5.to_hex in\n let result = String.equal digest known_good_digest in\n if not result then (\n printf \"Expected digest: \" ;\n print_digest known_good_digest ;\n printf \"Got digest: \" ;\n print_digest digest ) ;\n result\nend\n\ninclude Make (Snark_params.Tick)\n","(* compressed_poly.ml -- versioned type with parameters for compressed curve point *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('field, 'boolean) t =\n ('field, 'boolean) Mina_wire_types.Public_key.Compressed.Poly.V1.t =\n { x : 'field; is_odd : 'boolean }\n [@@deriving compare, equal, hash, hlist]\n end\n end]\nend\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\nmodule Impl = Pickles.Impls.Step\nmodule Field = Impl.Field\n\n(* Ledger - local mina transaction logic for prototyping and testing zkapps *)\n\ntype public_key = Signature_lib.Public_key.Compressed.t\n\nmodule Account_update = Mina_base.Account_update\nmodule Zkapp_command = Mina_base.Zkapp_command\n\nlet ledger_class : < .. > Js.t =\n Js.Unsafe.eval_string {js|(function(v) { this.value = v; return this })|js}\n\nmodule Ledger : Mina_base.Ledger_intf.S = struct\n module Account = Mina_base.Account\n module Account_id = Mina_base.Account_id\n module Ledger_hash = Mina_base.Ledger_hash\n module Token_id = Mina_base.Token_id\n\n type t_ =\n { next_location : int\n ; accounts : Account.t Int.Map.t\n ; locations : int Account_id.Map.t\n }\n\n type t = t_ ref\n\n type location = int\n\n let get (t : t) (loc : location) : Account.t option = Map.find !t.accounts loc\n\n let location_of_account (t : t) (a : Account_id.t) : location option =\n Map.find !t.locations a\n\n let set (t : t) (loc : location) (a : Account.t) : unit =\n t := { !t with accounts = Map.set !t.accounts ~key:loc ~data:a }\n\n let next_location (t : t) : int =\n let loc = !t.next_location in\n t := { !t with next_location = loc + 1 } ;\n loc\n\n let get_or_create (t : t) (id : Account_id.t) :\n (Mina_base.Ledger_intf.account_state * Account.t * location) Or_error.t =\n let loc = location_of_account t id in\n let res =\n match loc with\n | None ->\n let loc = next_location t in\n let a = Account.create id Currency.Balance.zero in\n t := { !t with locations = Map.set !t.locations ~key:id ~data:loc } ;\n set t loc a ;\n (`Added, a, loc)\n | Some loc ->\n (`Existed, Option.value_exn (get t loc), loc)\n in\n Ok res\n\n let[@warning \"-32\"] get_or_create_account (t : t) (id : Account_id.t)\n (a : Account.t) :\n (Mina_base.Ledger_intf.account_state * location) Or_error.t =\n match location_of_account t id with\n | Some loc ->\n let a' = Option.value_exn (get t loc) in\n if Account.equal a a' then Ok (`Existed, loc)\n else\n Or_error.errorf\n !\"account %{sexp: Account_id.t} already present with different \\\n contents\"\n id\n | None ->\n let loc = next_location t in\n t := { !t with locations = Map.set !t.locations ~key:id ~data:loc } ;\n set t loc a ;\n Ok (`Added, loc)\n\n let create_new_account (t : t) (id : Account_id.t) (a : Account.t) :\n unit Or_error.t =\n match location_of_account t id with\n | Some _ ->\n Or_error.errorf !\"account %{sexp: Account_id.t} already present\" id\n | None ->\n let loc = next_location t in\n t := { !t with locations = Map.set !t.locations ~key:id ~data:loc } ;\n set t loc a ;\n Ok ()\n\n let remove_accounts_exn (t : t) (ids : Account_id.t list) : unit =\n let locs = List.filter_map ids ~f:(fun id -> Map.find !t.locations id) in\n t :=\n { !t with\n locations = List.fold ids ~init:!t.locations ~f:Map.remove\n ; accounts = List.fold locs ~init:!t.accounts ~f:Map.remove\n }\n\n (* TODO *)\n let merkle_root (_ : t) : Ledger_hash.t = Field.Constant.zero\n\n let empty ~depth:_ () : t =\n ref\n { next_location = 0\n ; accounts = Int.Map.empty\n ; locations = Account_id.Map.empty\n }\n\n let with_ledger (type a) ~depth ~(f : t -> a) : a = f (empty ~depth ())\n\n let create_masked (t : t) : t = ref !t\n\n let apply_mask (t : t) ~(masked : t) = t := !masked\nend\n\nmodule Transaction_logic = Mina_transaction_logic.Make (Ledger)\n\ntype ledger_class = < value : Ledger.t Js.prop >\n\nlet ledger_constr : (Ledger.t -> ledger_class Js.t) Js.constr =\n Obj.magic ledger_class\n\nlet create_new_account_exn (t : Ledger.t) account_id account =\n Ledger.create_new_account t account_id account |> Or_error.ok_exn\n\nlet default_token_id =\n Mina_base.Token_id.default |> Mina_base.Token_id.to_field_unsafe\n\nlet account_id (pk : public_key) token =\n Mina_base.Account_id.create pk (Mina_base.Token_id.of_field token)\n\nmodule To_js = struct\n let option (transform : 'a -> 'b) (x : 'a option) =\n Js.Optdef.option (Option.map x ~f:transform)\nend\n\nlet check_account_update_signatures zkapp_command =\n let ({ fee_payer; account_updates; memo } : Zkapp_command.t) =\n zkapp_command\n in\n let tx_commitment = Zkapp_command.commitment zkapp_command in\n let full_tx_commitment =\n Zkapp_command.Transaction_commitment.create_complete tx_commitment\n ~memo_hash:(Mina_base.Signed_command_memo.hash memo)\n ~fee_payer_hash:\n (Zkapp_command.Digest.Account_update.create\n (Account_update.of_fee_payer fee_payer) )\n in\n let key_to_string = Signature_lib.Public_key.Compressed.to_base58_check in\n let check_signature who s pk msg =\n match Signature_lib.Public_key.decompress pk with\n | None ->\n failwith\n (sprintf \"Check signature: Invalid key on %s: %s\" who\n (key_to_string pk) )\n | Some pk_ ->\n if\n not\n (Signature_lib.Schnorr.Chunked.verify s\n (Kimchi_pasta.Pasta.Pallas.of_affine pk_)\n (Random_oracle_input.Chunked.field msg) )\n then\n failwith\n (sprintf \"Check signature: Invalid signature on %s for key %s\" who\n (key_to_string pk) )\n else ()\n in\n\n check_signature \"fee payer\" fee_payer.authorization fee_payer.body.public_key\n full_tx_commitment ;\n List.iteri (Zkapp_command.Call_forest.to_account_updates account_updates)\n ~f:(fun i p ->\n let commitment =\n if p.body.use_full_commitment then full_tx_commitment else tx_commitment\n in\n match p.authorization with\n | Signature s ->\n check_signature\n (sprintf \"account_update %d\" i)\n s p.body.public_key commitment\n | Proof _ | None_given ->\n () )\n\nlet add_account_exn (l : Ledger.t) pk (balance : string) =\n let account_id = account_id pk default_token_id in\n let bal_u64 = Unsigned.UInt64.of_string balance in\n let balance = Currency.Balance.of_uint64 bal_u64 in\n let a : Mina_base.Account.t = Mina_base.Account.create account_id balance in\n create_new_account_exn l account_id a\n\nlet create () : ledger_class Js.t =\n let l = Ledger.empty ~depth:20 () in\n new%js ledger_constr l\n\nlet account_to_json =\n let deriver =\n lazy (Mina_base.Account.deriver @@ Fields_derivers_zkapps.o ())\n in\n let to_json (account : Mina_base.Account.t) : Js.Unsafe.any =\n account\n |> Fields_derivers_zkapps.to_json (Lazy.force deriver)\n |> Yojson.Safe.to_string |> Js.string |> Util.json_parse\n in\n to_json\n\nlet get_account l (pk : public_key) (token : Impl.field) :\n Js.Unsafe.any Js.optdef =\n let loc = Ledger.location_of_account l##.value (account_id pk token) in\n let account = Option.bind loc ~f:(Ledger.get l##.value) in\n To_js.option account_to_json account\n\nlet add_account l (pk : public_key) (balance : Js.js_string Js.t) =\n add_account_exn l##.value pk (Js.to_string balance)\n\nlet protocol_state_of_json =\n let deriver =\n lazy\n ( Mina_base.Zkapp_precondition.Protocol_state.View.deriver\n @@ Fields_derivers_zkapps.o () )\n in\n fun (json : Js.js_string Js.t) :\n Mina_base.Zkapp_precondition.Protocol_state.View.t ->\n json |> Js.to_string |> Yojson.Safe.from_string\n |> Fields_derivers_zkapps.of_json (Lazy.force deriver)\n\nlet apply_zkapp_command_transaction l (txn : Zkapp_command.t)\n (account_creation_fee : string)\n (network_state : Mina_base.Zkapp_precondition.Protocol_state.View.t) =\n check_account_update_signatures txn ;\n let ledger = l##.value in\n let application_result =\n Transaction_logic.apply_zkapp_command_unchecked\n ~global_slot:network_state.global_slot_since_genesis\n ~state_view:network_state\n ~constraint_constants:\n { Genesis_constants.Constraint_constants.compiled with\n account_creation_fee = Currency.Fee.of_string account_creation_fee\n }\n ledger txn\n in\n let applied, _ =\n match application_result with\n | Ok res ->\n res\n | Error err ->\n Util.raise_error (Error.to_string_hum err)\n in\n match applied.command.status with\n | Applied ->\n ()\n | Failed failures ->\n Util.raise_error\n ( Mina_base.Transaction_status.Failure.Collection.to_yojson failures\n |> Yojson.Safe.to_string )\n\nlet apply_json_transaction l (tx_json : Js.js_string Js.t)\n (account_creation_fee : Js.js_string Js.t) (network_json : Js.js_string Js.t)\n =\n let txn =\n Zkapp_command.of_json @@ Yojson.Safe.from_string @@ Js.to_string tx_json\n in\n let network_state = protocol_state_of_json network_json in\n apply_zkapp_command_transaction l txn\n (Js.to_string account_creation_fee)\n network_state\n\nlet method_ class_ (name : string) (f : _ Js.t -> _) =\n let prototype = Js.Unsafe.get class_ (Js.string \"prototype\") in\n Js.Unsafe.set prototype (Js.string name) (Js.wrap_meth_callback f)\n\nlet () =\n let static_method name f =\n Js.Unsafe.set ledger_class (Js.string name) (Js.wrap_callback f)\n in\n let method_ name (f : ledger_class Js.t -> _) = method_ ledger_class name f in\n static_method \"create\" create ;\n\n method_ \"getAccount\" get_account ;\n method_ \"addAccount\" add_account ;\n method_ \"applyJsonTransaction\" apply_json_transaction\n","(* public_key.ml *)\n\ninclude Non_zero_curve_point\nmodule Inner_curve = Snark_params.Tick.Inner_curve\n\nlet of_private_key_exn p = of_inner_curve_exn Inner_curve.(scale one p)\n","module type S = sig\n type t [@@deriving equal, sexp]\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t [@@deriving bin_io, equal, sexp]\n end\n\n module Latest : module type of V1\n end\nend\n\nmodule type Hash = sig\n type t [@@deriving compare]\n\n include S with type t := t\n\n val merge : height:int -> t -> t -> t\nend\n\nmodule type Key = S\n\nmodule type Account = sig\n type hash\n\n include S\n\n val data_hash : t -> hash\nend\n","\nlet blockchain_proof () =\n Core_kernel.Binable.of_string (module\n Pickles.Proof.Proofs_verified_2.Stable.Latest)\n \"\\252\\012\\197i\\202m3\\161\\b\\252\\139\\134\\018}\\250\\015\\240\\195\\000\\252\\137\\000\\179\\254\\154\\214\\139{\\252\\017(\\185j\\141\\210\\243\\179\\000\\252\\193\\0075\\134p\\184\\207s\\252\\156\\231\\235\\195%\\236\\155r\\000\\252%O\\171W(\\182[\\n\\252\\242\\128\\235:\\131\\152\\175\\177\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\252\\185*\\167V\\180ps\\173\\252\\252\\158\\241\\213#\\249O6\\000\\252\\000|/\\142b\\028\\135Y\\252\\135\\204&\\162s\\246\\199\\156\\000\\252\\175\\242\\182\\158\\029\\130T#\\252~\\245}\\246\\209k\\185\\213\\000\\252\\246\\134\\144\\160\\208\\247{\\020\\252h*$@\\206b^b\\000\\252\\014\\173V2c\\027\\198\\175\\252\\251\\225\\031\\161\\016r\\128\\t\\000\\252\\145A\\172\\202\\190\\030X\\249\\252\\166\\201\\183>\\153\\213\\030W\\000\\252\\189\\195d\\205\\163PN\\170\\252h\\197\\254\\193\\n\\231\\020\\216\\000\\252m\\222^\\130\\223\\172\\029\\178\\252\\165\\007\\219\\197\\023\\162\\b\\254\\000\\252\\127\\170\\230\\233\\214\\015N\\130\\252,\\127\\185N\\152:\\246\\252\\000\\252\\202\\004\\027q+\\1361\\195\\252)&\\174\\182\\199\\1729\\145\\000\\252\\239Q\\129\\253G\\143\\015\\220\\252\\135\\149;\\196Cz\\169\\000\\000\\252\\1912\\134\\209\\030\\2168`\\252\\171\\005\\170\\162p\\188\\179\\249\\000\\252ZG\\175\\229\\224\\210u\\148\\252\\246\\210\\195\\174\\002\\167\\203\\209\\000\\252\\004|-\\249\\246\\015x\\190\\252T\\226\\2512\\145X=\\225\\000\\252\\019u1\\184\\018\\183p\\198\\252\\b>H\\1543\\204u\\022\\000\\252\\209\\184\\202\\177\\162\\176\\193H\\252\\206\\177q\\192\\227\\004f\\027\\000\\000\\002\\016\\000\\000\\000\\000\\000b\\153TI\\021\\240\\155\\231\\193y\\017D-%H@S\\180Y\\005\\219\\159AV0a\\253}\\1882\\211\\015\\172\\215R\\133\\247\\193\\162O\\199\\177\\230\\226|<\\022:U\\166\\177\\23169\\003\\029\\004\\235\\165^P\\004\\005\\022\\252o\\191\\230\\172\\201\\179\\1303\\252c\\024v\\249XC\\151y\\000\\252\\151\\135\\136\\233\\006+:\\221\\252\\199\\161D)@\\230z\\221\\000\\252\\203\\159\\156\\2440\\229\\232\\198\\252\\221\\156\\160\\205e\\187\\221\\007\\000\\252\\019\\026i\\135\\162Y,S\\252{oe*\\176\\188!\\169\\000\\252\\139\\007\\016\\143\\177w\\156\\226\\252\\238\\012k\\223\\000_\\\\\\248\\000\\252\\135\\156\\176\\007-\\167\\189\\029\\252\\160&_\\233\\226\\151\\027M\\000\\252\\017_\\128V|tu\\156\\252\\232\\241\\206\\250ic\\254\\161\\000\\252M`\\233\\219\\223\\138+\\\\\\252\\155\\247\\016\\242\\140q\\140Z\\000\\252Hk\\224Q\\\\\\179\\192\\\"\\252\\237m\\169@s\\139\\136\\166\\000\\252ndv^\\181\\215\\007\\144\\252\\018\\142N\\2199\\139\\198\\193\\000\\252\\201+?7^\\227ED\\252\\229\\205\\140\\252\\021\\199@\\157\\000\\252N\\170\\188K\\132\\130\\152B\\252\\188\\183\\175\\208\\215'\\169\\151\\000\\252wn\\253\\255[=\\202\\153\\252\\148B\\\\\\021Uj\\230\\239\\000\\252T\\153\\151!q\\178}K\\252@\\200\\147a\\224\\162\\031\\149\\000\\252\\179G\\007\\178\\190\\204\\209,\\252\\029\\002d\\242<\\222\\209[\\000\\000\\252o\\191\\230\\172\\201\\179\\1303\\252c\\024v\\249XC\\151y\\000\\252\\151\\135\\136\\233\\006+:\\221\\252\\199\\161D)@\\230z\\221\\000\\252\\203\\159\\156\\2440\\229\\232\\198\\252\\221\\156\\160\\205e\\187\\221\\007\\000\\252\\019\\026i\\135\\162Y,S\\252{oe*\\176\\188!\\169\\000\\252\\139\\007\\016\\143\\177w\\156\\226\\252\\238\\012k\\223\\000_\\\\\\248\\000\\252\\135\\156\\176\\007-\\167\\189\\029\\252\\160&_\\233\\226\\151\\027M\\000\\252\\017_\\128V|tu\\156\\252\\232\\241\\206\\250ic\\254\\161\\000\\252M`\\233\\219\\223\\138+\\\\\\252\\155\\247\\016\\242\\140q\\140Z\\000\\252Hk\\224Q\\\\\\179\\192\\\"\\252\\237m\\169@s\\139\\136\\166\\000\\252ndv^\\181\\215\\007\\144\\252\\018\\142N\\2199\\139\\198\\193\\000\\252\\201+?7^\\227ED\\252\\229\\205\\140\\252\\021\\199@\\157\\000\\252N\\170\\188K\\132\\130\\152B\\252\\188\\183\\175\\208\\215'\\169\\151\\000\\252wn\\253\\255[=\\202\\153\\252\\148B\\\\\\021Uj\\230\\239\\000\\252T\\153\\151!q\\178}K\\252@\\200\\147a\\224\\162\\031\\149\\000\\252\\179G\\007\\178\\190\\204\\209,\\252\\029\\002d\\242<\\222\\209[\\000\\000\\000\\000\\002H\\1816\\232FT\\165_O\\253\\255\\253\\245\\145\\189\\157<\\161pK\\206\\240\\\\\\165\\157\\194dH\\222\\223\\211\\017k\\026,D\\221!\\199\\205YU\\239\\025\\195\\243\\171\\184B\\014\\027z\\229\\023\\020\\222\\215\\138\\132M\\\"\\007\\245\\005H\\1816\\232FT\\165_O\\253\\255\\253\\245\\145\\189\\157<\\161pK\\206\\240\\\\\\165\\157\\194dH\\222\\223\\211\\017k\\026,D\\221!\\199\\205YU\\239\\025\\195\\243\\171\\184B\\014\\027z\\229\\023\\020\\222\\215\\138\\132M\\\"\\007\\245\\005\\002\\252\\185*\\167V\\180ps\\173\\252\\252\\158\\241\\213#\\249O6\\000\\252\\000|/\\142b\\028\\135Y\\252\\135\\204&\\162s\\246\\199\\156\\000\\252\\175\\242\\182\\158\\029\\130T#\\252~\\245}\\246\\209k\\185\\213\\000\\252\\246\\134\\144\\160\\208\\247{\\020\\252h*$@\\206b^b\\000\\252\\014\\173V2c\\027\\198\\175\\252\\251\\225\\031\\161\\016r\\128\\t\\000\\252\\145A\\172\\202\\190\\030X\\249\\252\\166\\201\\183>\\153\\213\\030W\\000\\252\\189\\195d\\205\\163PN\\170\\252h\\197\\254\\193\\n\\231\\020\\216\\000\\252m\\222^\\130\\223\\172\\029\\178\\252\\165\\007\\219\\197\\023\\162\\b\\254\\000\\252\\127\\170\\230\\233\\214\\015N\\130\\252,\\127\\185N\\152:\\246\\252\\000\\252\\202\\004\\027q+\\1361\\195\\252)&\\174\\182\\199\\1729\\145\\000\\252\\239Q\\129\\253G\\143\\015\\220\\252\\135\\149;\\196Cz\\169\\000\\000\\252\\1912\\134\\209\\030\\2168`\\252\\171\\005\\170\\162p\\188\\179\\249\\000\\252ZG\\175\\229\\224\\210u\\148\\252\\246\\210\\195\\174\\002\\167\\203\\209\\000\\252\\004|-\\249\\246\\015x\\190\\252T\\226\\2512\\145X=\\225\\000\\252\\019u1\\184\\018\\183p\\198\\252\\b>H\\1543\\204u\\022\\000\\252\\209\\184\\202\\177\\162\\176\\193H\\252\\206\\177q\\192\\227\\004f\\027\\000\\000\\252\\185*\\167V\\180ps\\173\\252\\252\\158\\241\\213#\\249O6\\000\\252\\000|/\\142b\\028\\135Y\\252\\135\\204&\\162s\\246\\199\\156\\000\\252\\175\\242\\182\\158\\029\\130T#\\252~\\245}\\246\\209k\\185\\213\\000\\252\\246\\134\\144\\160\\208\\247{\\020\\252h*$@\\206b^b\\000\\252\\014\\173V2c\\027\\198\\175\\252\\251\\225\\031\\161\\016r\\128\\t\\000\\252\\145A\\172\\202\\190\\030X\\249\\252\\166\\201\\183>\\153\\213\\030W\\000\\252\\189\\195d\\205\\163PN\\170\\252h\\197\\254\\193\\n\\231\\020\\216\\000\\252m\\222^\\130\\223\\172\\029\\178\\252\\165\\007\\219\\197\\023\\162\\b\\254\\000\\252\\127\\170\\230\\233\\214\\015N\\130\\252,\\127\\185N\\152:\\246\\252\\000\\252\\202\\004\\027q+\\1361\\195\\252)&\\174\\182\\199\\1729\\145\\000\\252\\239Q\\129\\253G\\143\\015\\220\\252\\135\\149;\\196Cz\\169\\000\\000\\252\\1912\\134\\209\\030\\2168`\\252\\171\\005\\170\\162p\\188\\179\\249\\000\\252ZG\\175\\229\\224\\210u\\148\\252\\246\\210\\195\\174\\002\\167\\203\\209\\000\\252\\004|-\\249\\246\\015x\\190\\252T\\226\\2512\\145X=\\225\\000\\252\\019u1\\184\\018\\183p\\198\\252\\b>H\\1543\\204u\\022\\000\\252\\209\\184\\202\\177\\162\\176\\193H\\252\\206\\177q\\192\\227\\004f\\027\\000\\000:{\\221-N#sE\\216t.\\146\\191u'\\001f@\\238\\128u\\005\\150fI\\237\\246\\129\\015\\128\\21106\\004j\\2083\\133\\221\\031i\\128%\\012\\175\\253p\\b\\001\\136(\\0201\\130L\\169\\1533\\135\\n\\202O\\\\\\131e;\\183=D\\236o\\189M\\132\\028\\133u!\\158\\199\\015\\001\\021JS\\128h\\141\\012~\\202;\\222\\216\\131\\245\\128\\135\\239\\247\\143~\\191\\222\\131\\007qF\\128\\191~\\151\\198\\014\\001\\025\\170\\164\\1530\\233\\178\\162D\\027h\\209\\157c\\215\\019\\160V\\151\\242\\128s\\01739R\\148\\246d\\187b\\017\\001\\197\\021\\245\\023\\014\\220?\\tqX\\248\\217\\137H\\230\\178E\\192x\\222H\\020\\241Qx\\158\\243I\\249\\020\\004\\002\\001C\\193@,\\255\\146\\128\\005\\251d\\017B\\n\\208V\\246r\\176\\002uU},\\214\\237E\\235UI\\252\\191:\\001\\225U\\015BBE\\198\\181\\209\\021\\187\\255Mt\\157:8\\206\\176U\\210\\011\\255;&\\196\\226\\129(\\177\\251-\\001\\170}C.F\\236\\b<\\238\\233\\210M\\251C\\131q:B\\134\\164\\169\\247kL\\153\\216\\217\\\\\\152\\206\\2161\\001I\\183\\002\\137\\241\\162\\241\\191\\219\\021u\\157\\158n\\155Zmz\\237\\175\\134\\027%\\235Y\\145\\161\\243;\\208\\152\\015\\001\\b\\219\\140\\\"\\230\\2379\\250\\166Z\\159\\179\\218\\232\\136{\\027s\\155\\172u\\219R3\\157\\142M\\238\\250\\190o8\\001\\232\\017\\152\\1737?\\255\\211\\156\\229\\158\\154\\137l\\220\\007DE\\\"\\194_=\\020yJ\\210\\173\\235j44$\\001$P\\132\\011V\\2425^o\\198\\165\\208\\203-;\\023\\1607=K\\248\\025\\180\\026c\\028\\182-\\128q\\t\\020\\001\\179\\1366`=\\179Wo\\247\\018\\141E\\144h\\150\\195\\173V\\251\\025 \\001\\001\\173\\011\\219y\\178\\241oM\\020'\\224\\218\\254p\\192c\\016\\250F\\006\\185>\\180B\\130S\\143\\131\\218(\\241?\\001\\149\\209b,\\192\\167\\242\\219\\138\\153\\216\\021e4\\213r\\007\\170\\243\\187\\198\\165\\166\\161\\163\\021\\205\\146Bh\\130\\031\\001R\\210\\183\\129\\190\\0280\\012\\029\\203@ _`$\\007Z\\153\\011>\\214@h^\\164\\134/e\\233F\\233\\026\\0016\\137\\142\\0005\\254\\190\\022\\238\\149\\216\\1441\\223Z\\016\\213a\\217\\152\\174\\208f/]x\\187\\012\\023\\203\\216\\012\\001q#\\154.\\129wF\\242\\151\\015\\170\\222\\241\\174CQ\\\\\\138\\223\\252 \\177o\\025F\\183\\194\\231@\\178\\1902\\001!\\018\\186\\127\\215IgAV;\\148\\136xa*_\\234\\017\\254\\225\\127H\\187\\176\\011\\174\\207{\\223x\\228#\\001\\238\\220$)\\001\\238\\171\\172\\203\\182]%q\\255\\194h\\255\\245\\187f\\247T%\\165\\167\\183Y\\255\\226\\179(\\015\\001{\\r<\\248\\148\\003s\\150\\2073\\2122\\198\\017\\255\\2116\\249\\134ZJ\\143\\210\\031M\\184\\211Gn`h;\\001]\\2030\\190\\252\\242\\243\\217\\150.N.L\\162\\n\\214Lzr\\1990p\\148r\\026GQw\\159\\202\\\"#\\001\\196n\\176;\\144j\\254\\004=\\\"P\\198\\231\\028\\248Pwv\\193\\188\\\"F\\\"y\\128\\252Bw\\004\\254*\\005\\001\\n\\204+o\\253\\166\\002\\250\\226\\0075\\235\\224\\134\\198\\144\\255\\248\\139[\\011\\240\\221\\237\\177\\159\\003:\\190m\\240&\\0017\\140\\201R\\023\\239\\223\\136H\\228l\\219\\2397\\236L\\160\\239#\\169\\185$\\158\\226H\\029\\185\\025S\\144\\130\\011\\001\\225\\\\\\224\\1936\\218c\\206_9\\161\\134-\\155\\005\\004\\184~\\198\\179\\004\\224\\136\\007\\153}\\134K*\\229\\231\\003\\001\\rV!7\\211\\241qk\\016[2\\227\\140\\b\\027\\207\\250 x\\190\\162\\136\\141'o5IJE\\029\\1530\\001\\187\\193\\218H\\155\\205ze\\027\\162Q\\026^\\177\\187\\132\\197@\\014w\\130+UZ\\238\\223\\240Z\\172Z\\153\\024\\001W\\205\\189J{iYG\\001\\127\\241\\0124\\209\\239\\t\\228\\t\\178\\213k\\230\\199\\\\\\188\\194t\\172\\031(\\019\\011\\001\\230|F\\210\\155\\188\\243\\244\\152s\\002p?c\\1406\\012\\000c\\152\\140L\\252\\242\\250-\\004\\235\\249\\201a\\002\\0016Q\\227\\152o^$\\133s\\209W\\185\\141\\132\\028\\217]\\t\\190\\204\\228\\006J\\bQ+\\255i8\\129_\\017\\001\\145\\023\\209\\237E\\027\\137\\203\\187Cu1\\210@\\192\\181Fj\\214Q\\031\\205\\025\\190\\000\\026\\188\\244a\\180~\\011\\001l\\195g\\015\\236\\199\\203@\\rF\\236\\199\\143? \\007\\160\\206\\162^:\\204v0i\\222|1K\\247\\191,\\001\\165c\\201\\149\\241\\255\\143\\199\\234\\160\\027\\019\\178\\193m\\244\\2136B\\161\\155\\168o\\007\\206\\225\\237\\239\\2512-\\030\\001\\139\\159r\\164\\172\\2037\\225A\\027\\148*\\\\y\\190\\247\\191\\021\\182t\\164\\178\\186\\174\\161\\173#5'x\\021\\022\\001y=Q\\211\\206\\254\\164\\247C\\200n\\150,\\n\\195\\023\\235~\\002\\193\\146\\b\\020h\\t\\150}(\\004\\144^;\\001\\249\\166\\162\\185\\201\\nF\\183C\\144\\1632\\024\\2457\\205aW\\238m\\026l\\187\\155yrn9r\\159\\1879\\001\\000\\012Fi\\180\\220\\175\\1870\\186TB\\150,\\0145(\\024\\179\\151\\021j\\165\\156\\000~\\031*\\249\\137\\1858\\001@_\\183\\017\\234\\233\\252\\167\\136u\\219\\141\\182a\\137\\197mBo\\234\\006\\143(&\\254\\\\\\176\\176\\175\\224j\\014\\000\\001\\014P\\025\\239Y[yo\\135.\\218\\232t\\223>k\\209\\233D$\\174\\215\\186Mz\\197\\254Z\\226%$\\021\\001\\206\\206\\146J\\241(\\155\\\"o\\187l\\190\\248\\t\\185D\\\"\\169\\217\\031\\007\\130\\173\\160\\216~\\252\\131\\208\\025\\185\\027\\001JN\\233\\216\\206\\243~pMW\\131n+\\212,idf\\226q\\151\\225f\\229\\164\\172\\135\\175o\\023\\169$\\001\\222~W\\237\\0025\\237\\019\\021\\238|vX/\\232^\\2414\\016W\\026u7\\188\\215\\1899\\025\\242f\\236\\030\\001~\\168\\192\\251%~Q\\024\\229H\\217\\199\\213\\159XX\\202\\021;\\159xPb1=%\\014$\\226\\003)\\020\\001\\157S\\200[\\219\\200\\185\\248\\149\\253<\\242\\133@\\154\\222$\\208w\\198\\177\\251\\136K\\232\\237\\003\\166\\t z\\021\\001\\153\\132\\222Z\\211\\t\\028R?\\144\\219g\\146Rk6\\179\\208\\147k\\218\\138\\168\\170\\130\\017'H\\225\\170\\251-\\001\\210=DU\\\\V\\147$\\006}\\130\\129v2\\164\\180\\139\\227\\020&q\\001\\160\\152s\\025ru\\208(O\\005\\001\\141\\030\\248\\226J\\2075\\230\\143@D\\1282CR\\233!d[\\195T\\176VD\\231\\189N\\179\\168\\014\\157\\019\\001\\173\\177\\175\\207\\175\\254uiekT\\213\\2069\\247\\193\\026U\\149\\143c\\2442\\239\\186\\154\\169c4\\227\\240\\019\\001\\r\\025\\237\\186\\203\\156\\240+\\191\\\\\\028\\016S\\212\\\"G\\149&\\133P8\\192rw*\\n\\151\\015:T\\213%\\001\\137\\172pR\\195oP\\168\\155\\205\\006\\011\\166\\127\\169Dm\\254\\176\\182\\216\\nt\\239a}\\212\\175f\\204 9\\001\\172]\\016U\\230\\220\\133\\230\\150\\205\\226\\228\\205X\\228\\017uVb-\\230\\022\\192K4'\\235\\207Ny!9\\001\\162\\224T\\198[\\145K.\\204\\163\\169\\186\\1635\\160\\214\\165\\001\\156\\251\\177\\156\\224s\\234\\213.\\031\\015\\150?0\\000\\001\\222d\\191\\243\\0223\\131\\175\\\"hwM)\\249s\\130ei%\\163\\132n\\b\\209\\185\\219\\253\\129\\007\\tP\\b\\001\\026y\\201 g\\175:\\147\\227\\142;z\\181Q\\2370\\203%\\152\\190=S\\026\\252\\179\\022\\031\\244dRy\\012\\001\\195\\024\\029\\135\\208\\171J\\153\\206\\200\\133\\179\\212\\222Q\\176\\188\\163+0n\\190\\206\\141\\202\\026\\135+\\192\\239\\196\\029\\001(\\136\\194qd\\185\\0114\\026\\151\\168\\130\\197EOXh\\168\\214\\135\\150\\179\\241\\142\\245B\\128\\238?\\150(:\\001\\207\\230\\245\\252\\199R9=\\203\\252\\148\\018V\\194\\186\\132\\153\\211\\\"(\\174\\026\\221\\018\\r\\015\\190\\204\\2178\\1463\\001\\023\\230\\252\\218\\000c!\\210oh\\226\\150\\139\\bHv6\\007\\2482\\249\\173\\176\\186\\167\\026\\021\\185/y\\136%\\001\\255\\219N\\144\\157w)eu\\239\\022-\\1831X\\022\\147\\168\\174\\026&(\\233\\215\\177\\020\\246\\230H20\\n\\001@\\018\\138\\2202<\\236\\210K_M\\239\\2484\\190\\150\\012\\144\\165\\201}\\022\\206m\\018>\\222\\140\\149\\178\\191<\\001\\146\\245\\252\\220\\012L\\211\\246\\222ByH\\176x1.\\0117D\\182I2\\181Z\\246\\020\\028\\232\\254n\\216,\\001L\\177\\225\\188\\236\\132?\\171~7x\\015D\\136\\rX\\235\\250<(\\180\\192\\201\\019\\174AIZ[\\207[\\025\\001\\192\\200M\\254\\161S\\006\\187\\150'\\021\\185!\\192\\017\\127\\222\\159?\\157\\255\\169sO\\202\\151|\\174\\134T\\1447\\001\\173l\\242Y\\255\\234\\209\\141:\\2538/A\\014w\\026=]\\015&\\020T\\250i\\150\\147\\216\\028E\\204\\128<\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\223\\020\\139\\015&\\240\\031\\139Vn\\220\\030Ql\\169!J\\017\\026\\218\\152\\250\\212J\\199\\014.\\164I\\tW;\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\000\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\000_\\237f\\144(\\136\\155\\028\\146\\165\\241Ac3\\249pC\\228\\027rG\\148\\190z\\212\\148\\177\\t\\235F0\\b\\164\\027o\\160\\129\\149\\020\\157\\254pe\\136\\211o\\168M\\025v\\137\\174\\247\\138\\192t\\153tvYg\\134\\129\\003iyJ\\160\\136\\n=\\235\\242\\019\\1967\\\"\\206\\160\\246J\\151hZz\\179\\147\\218\\244\\137\\146\\240\\0222\\172\\021vgd%\\232v7\\005\\196\\167,N\\160\\197\\169\\028\\029\\238\\1686d\\015Fr.r\\\"O\\232\\249D2LE\\131\\222\\171Jw\\025\\234R;OV&_Y\\027\\245D\\223c\\203H\\018\\162\\213\\236\\031\\025\\127\\028\\020\\169\\n:(\\131\\225u\\236\\213\\219\\164\\213(I\\002\\181k\\170\\162\\209\\029\\238fw\\004u\\015\\144_ V \\188\\131\\199\\226s\\196\\017[F_\\160,\\205\\011\\011\\155\\158vH\\221\\133\\229\\215\\200\\158\\146\\243\\005\\176\\162\\001/\\158\\001J\\154S\\148\\r\\\"1v\\231\\\\+\\n\\015|fS~\\175mR\\192\\192\\244\\r]\\143\\198n\\2295\\212K\\\"96N\\007\\137A\\250\\184G\\182\\140\\028m\\175L\\211<\\239'\\239\\160\\133@R\\225\\018j\\135\\014\\003\\2516\\164nx\\133T\\152_\\019\\240h\\199J\\226J7\\232N\\156\\006l\\215!\\0005\\170\\2109\\225\\150\\006\\031\\030\\235\\243AH\\194e\\132\\002\\019=P\\007\\0167f\\138\\2182\\186q\\2514*\\224\\001\\151\\255\\249A':\\190\\159\\180\\187EGm\\192\\235\\162\\229\\206\\030\\253\\219\\153\\208\\002`\\213b\\190\\185\\172\\154\\030~\\221\\139\\182\\127\\171\\248H\\210\\007\\152\\221\\196K\\243\\179\\227C4\\203\\128`\\250\\2107\\172\\171\\193R\\1330\\209\\194\\129\\219\\026\\029p\\031R\\152o\\238\\174\\154G6eE\\184\\011\\217<%\\1734\\193\\021\\150\\011i\\237Oe\\142^\\202Y\\180\\148w\\170\\249\\127c\\023[\\247\\235\\130d\\0249\\166\\214d&#\\175{\\153bo\\168\\223j\\138\\137\\177\\138?-\\014\\192S#\\245\\179\\127i\\227z`\\\"+9m*\\133\\tp\\196\\183e\\154\\249\\207\\005\\r\\212\\0209:Z%\\017V\\t\\236U\\151x\\129|\\191\\230\\006_\\141EI\\003p\\175\\158\\156e\\217.\\253\\147\\150\\215\\177\\022$+9\\181\\209p@\\006#\\015\\166\\227\\253\\028\\022>\\217\\242\\246\\209\\247\\019?\\141^M\\238\\249H\\027j\\153\\220\\151\\167\\020\\228z(?DJ\\172\\233\\224'\\21178\\018\\214T\\228\\253\\246#:d\\182J\\223\\211\\173F'\\205\\230\\165\\214\\215\\027\\137\\131\\246?fL)L\\197K1\\232\\197\\149\\207\\216\\155d|\\207\\011\\249T#\\182\\021\\005\\201\\161$\\249\\165\\001\\183\\248R\\000\\0052\\204\\tj\\025\\213\\227h)\\174\\\\wo\\2448\\019Kk\\169}\\012\\133\\235\\022\\154\\005\\219t \\214\\028=\\026\\134{\\254\\132g _0?$\\185L\\151\\020;\\182\\b\\143#\\026\\137\\203q\\146\\195\\206\\185hGQ\\127\\r\\139\\204K\\131\\145\\017\\027\\143\\214'P\\244\\219/\\005\\004\\154-\\001\\145tg\\242\\200\\\"\\026\\217\\244\\225\\184\\177\\000|O\\246;\\006zDmw\\158\\031\\185\\206\\0056z\\230\\244\\028\\255\\230\\253\\137g\\019\\011\\161gH\\199<\\003i\\252sOj\\175\\243.\\224 +\\146ng\\209\\003\\202\\136\\208\\2323\\190\\006x\\244\\247R\\145\\166\\152\\2392\\226/\\204\\011\\231\\224\\244v\\205\\238\\\"\\196\\tV\\231 \\188\\186\\143{\\149i\\147B\\185\\t\\135\\198\\207\\220q0!\\234&b\\250\\019~R\\027\\016\\231\\rG\\128Y\\024\\2476\\190\\159\\161\\234P\\192i)^\\128\\145S\\211\\0145_\\n\\nGB\\237\\1294Q\\166\\249wh\\132\\r\\145zV\\249\\182g\\023\\004\\0258\\207\\217S\\n\\2127en\\021\\006\\236!Qz\\128\\137\\2258\\218~\\209M\\180^\\216\\161\\177\\232\\240\\241\\163\\174E\\175*\\174\\201*\\000\\132\\150|2pt\\003\\168hs\\237\\2032S\\218\\rB\\245\\178I\\018\\025\\230\\152\\189\\191Y\\147\\205:\\028:%S\\150\\252l\\194\\022)\\206\\246\\163\\141\\156\\152nP1k\\180.\\031(\\163\\225\\175\\135\\031ui\\250\\203\\rF\\207\\235u\\213?\\170\\219\\220`UL\\153\\188\\221j\\133%\\242\\166\\244\\231\\176\\168#\\237@\\221P\\252\\r\\000i\\n\\152\\217K!p\\237\\251?V\\155\\214\\222\\239\\169\\204\\161;\\t=\\149\\155\\019n\\224\\029/\\152k\\r$n\\142\\134\\243\\219QJ=\\253\\172\\247u\\006h\\011\\2340\\208\\232E\\195\\192\\214W\\250Ld\\201Z\\027%(\\018\\246\\168\\135\\249\\155\\197\\0213\\230Q\\152\\016\\199\\157\\215\\254|\\216\\015\\141\\140\\180\\131\\164\\246Rdg\\202s\\030;\\215wf\\000\\135\\168\\214\\165\\168?d\\000\\006\\188\\167\\1936\\223\\2045\\147\\b\\235\\196D\\254\\000\\230\\130k\\024s\\023k\\187\\196\\195Z@\\203\\002\\248\\217r\\024\\202\\205\\152\\242c\\221X\\181\\174\\143\\193\\184\\021\\242\\201\\197\\221)?\\199\\162\\232\\019p`P5\\249`\\203\\136T\\251\\1315\\025\\134\\204\\1363\\253\\223z\\255:\\252\\176\\021SI\\175P\\145\\227\\205\\024\\192\\146\\237\\149{\\227q\\215\\155\\202>\\0263\\191\\015\\131\\136\\172\\024\\145%\\148A\\004\\231\\\"\\191\\0118O\\193H;\\165\\r\\137F\\004\\220UF\\2284\\196\\202\\182\\000\\028\\194\\188Y\\250\\199\\152Z*zJ\\132\\167V_\\021\\242\\181\\202L\\r\\205\\241\\159\\153\\147q\\t\\185k!\\231\\165A\\209B\\001$\\022Q6\\232\\t?V\\196\\142T\\000\\254\\213\\194\\168j\\232\\2193\\133c\\245\\167\\2341\\166k-\\b3\\226\\183:\\214\\012\\166ac>\\212\\151\\030\\195\\165\\0018\\219\\182|}HB\\191\\254\\239\\177\\003\\229\\141\\147@\\026\\247\\004\\244\\204\\029\\246\\129>q\\241!\\251\\170f\\029\\203\\128\\148^\\241\\024>\\195\\207\\016\\183\\1987\\024JP;\\026\\174\\145\\b\\011R\\190\\155\\240\\240\\187\\017\\145\\157Pm\\240;\\184\\159\\246\\181:\\146\\214\\248\\015\\001\\150\\029\\197@%\\\\\\152T ~X\\178O\\210)\\239\\177n\\018\\005\\166K\\\\\\187\\152ef\\175\\132\\026\\236jM\\141\\165B\\000]9v\\021\\151\\154\\248&\\011\\204\\233'\\149\\244\\0188\\2074\\215{C`\\225\\228\\020\\209\\199\\147}\\172ky\\231M\\2299\\243r\\141\\022\\128\\225\\th\\027Ko\\128\\017\\254\\166\\167X\\248\\233'\\220.\\022\\236\\243\\196\\025\\190o\\149v\\022xd\\2555\\157j {r?\\024\\127w\\134\\021\\210\\240s+7\\175\\022\\153w\\148\\207\\131Id\\216y9'\\166u><\\022\\185\\137!\\213=\\024T\\002\\232t\\243\\024\\168\\025\\253\\242\\243\\172fg& E\\170\\138&fN|\\166\\254\\147\\241Q\\240iP\\139\\130j\\213\\208lqT\\147\\024\\203\\201\\017\\218kt\\208n\\254(\\006\\000.S`[\\128\\026\\215\\254\\167E\\233vj\\221\\141\\169\\2373X\\157u\\143\\1799\\254\\212\\0122\\156Y\\170'\\183z\\135\\136\\176\\127|\\209\\201\\198\\022\\024u\\\\\\202=\\r0:{\\ta$\\206\\012\\002\\220_E\\026\\015\\003.\\030hs\\029\\000\\184G \\003\\136#w~\\198R-\\154\\030\\1586Y \\195\\231\\206\\006J\\222\\012.\\030\\217mb\\229J\\nI\\211\\164L\\145\\158\\180\\176\\1373=d\\1626\\237\\205\\161\\146\\018t\\172i\\003\\186\\2177\\204\\227\\167\\141\\250$-\\140S\\232\\148g\\204\\152m\\2533-\\185\\135\\215lf\\231sZG\\2394\\233\\015(\\195}i,\\132s\\170\\154$k\\184^\\\\C#\\205\\012Zi\\228\\185\\206\\026\\225`\\249aD|1\\174.\\216-8qxB\\189\\227\\023\\021~\\223\\024j[*Z\\194\\1605\\160i\\177\\138\\027\\183\\144\\216\\161\\182\\014&i\\148\\226p\\242\\132\\165W\\196\\024\\175\\235\\250\\172\\162yL\\138\\246\\164v\\203\\027\\148x\\194\\005\\232\\169\\001\\023\\015qq\\021\\229\\151\\019\\200O\\136\\186\\190.\\192)%\\024\\006\\r,\\200+T\\233\\169\\201\\162\\210\\168|\\233\\030\\021]\\217<\\155,?\\206\\227\\015\\163I`\\242G/\\205\\004\\217\\222\\132\\134\\2465\\201\\185mwo\\1741\\\"\\031\\168O\\148\\160\\214\\214K\\224\\185pI\\185*\\226\\197\\138\\140\\185>y!y\\250\\181\\127\\163,F\\149\\171\\231$,|j\\165\\018;A\\170\\142\\172\\232Z~\\238\\184\\235\\178\\\"\\025\\2015;\\146vq\\017\\153\\170\\168\\001\\130\\023\\022\\235\\162\\235\\218\\159\\234\\196B\\226\\158\\249)?\\\\Ev\\147=S\\026n<\\007Q\\1425\\\"A\\005_=\\220\\245\\178\\225$S\\1846\\156B\\014v\\173\\160\\251ln\\023?\\\"q\\170\\025\\236m\\184\\001\\001\\018a\\022\\005\\00056-\\152o \\197\\152\\229<=\\224\\184\\252A0\\004\\132$1r\\175\\137<\\201\\156\\161\\153\\170\\022\\022<\\240\\149\\030j8_\\180\\234\\139^,\\240\\232\\158T\\128z\\153\\147\\139\\n\\182\\156w\\241\\185\\178\\016\\160]\\021.7\\190\\250\\157\\128\\198(\\251\\139?\\127S\\022\\145,\\023T&\\160\\173\\154\\131\\219x\\bG\\2146\\241\\204\\171\\t\\224\\r6\\204+`v\\1941\\132\\004l\\n*\\006 \\133!VD\\254)T\\154bR\\002PU\\189\\251\\028k\\223#\\014\\192z\\145S\\025\\198\\006\\173\\147\\012A\\221\\127\\tr\\\"\\173\\162wjHNu_\\235-I\\028\\238\\128+\\234\\244\\221\\186\\243\\182\\150\\152h\\157~v\\182p\\202\\166]\\219\\217!\\151\\\"z\\176\\200\\223\\1866$\\181\\201\\141:\\136\\030\\170\\213`\\r\\137\\146\\r\\255\\131\\002Py\\210{\\222<\\234\\221\\020B[\\252\\138@\\211\\016\\192D\\022(\\001%\\025\\215o\\239\\001\\007CM\\197k\\177t\\231\\209a\\012\\222/\\200mj\\167+u\\173\\026\\205q\\200\\175\\225\\167\\025\\242\\229\\232?\\206yA\\251\\1541>+\\146bH\\n\\250hg]\\207\\171d\\178\\n\\229\\128\\t=$\\004\\006\\246hK1<\\228\\006i\\189[\\161\\200\\223>\\213<\\237/G<\\003z\\241\\154\\b\\154\\204\\148\\217\\195\\231\\189\\223f\\163#\\216+\\245E\\025\\187\\143/[\\221H\\254\\206\\180Z\\139\\222\\n\\167\\1609\\150\\161\\006B\\017\\181+\\195M&Xxu\\007$\\232\\213R\\174\\156\\232\\250\\229I,}\\020\\169\\230nu\\023\\206*\\018\\131\\\"j\\156\\211\\011\\147\\130\\151\\180{\\233\\154\\000\\252\\192\\190k\\t\\167?\\024'\\252\\012b\\130\\240o\\142W\\253\\000\\252\\213\\243:\\146\\006x\\177\\001\\252\\012\\169\\223\\006\\143(kw\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\252\\185*\\167V\\180ps\\173\\252\\252\\158\\241\\213#\\249O6\\000\\252\\000|/\\142b\\028\\135Y\\252\\135\\204&\\162s\\246\\199\\156\\000\\252\\175\\242\\182\\158\\029\\130T#\\252~\\245}\\246\\209k\\185\\213\\000\\252\\246\\134\\144\\160\\208\\247{\\020\\252h*$@\\206b^b\\000\\252\\014\\173V2c\\027\\198\\175\\252\\251\\225\\031\\161\\016r\\128\\t\\000\\252\\145A\\172\\202\\190\\030X\\249\\252\\166\\201\\183>\\153\\213\\030W\\000\\252\\189\\195d\\205\\163PN\\170\\252h\\197\\254\\193\\n\\231\\020\\216\\000\\252m\\222^\\130\\223\\172\\029\\178\\252\\165\\007\\219\\197\\023\\162\\b\\254\\000\\252\\127\\170\\230\\233\\214\\015N\\130\\252,\\127\\185N\\152:\\246\\252\\000\\252\\202\\004\\027q+\\1361\\195\\252)&\\174\\182\\199\\1729\\145\\000\\252\\239Q\\129\\253G\\143\\015\\220\\252\\135\\149;\\196Cz\\169\\000\\000\\252\\1912\\134\\209\\030\\2168`\\252\\171\\005\\170\\162p\\188\\179\\249\\000\\252ZG\\175\\229\\224\\210u\\148\\252\\246\\210\\195\\174\\002\\167\\203\\209\\000\\252\\004|-\\249\\246\\015x\\190\\252T\\226\\2512\\145X=\\225\\000\\252\\019u1\\184\\018\\183p\\198\\252\\b>H\\1543\\204u\\022\\000\\252\\209\\184\\202\\177\\162\\176\\193H\\252\\206\\177q\\192\\227\\004f\\027\\000\\000\\000\\014\\000\\000\\000\\000\\000b\\153TI\\021\\240\\155\\231\\193y\\017D-%H@S\\180Y\\005\\219\\159AV0a\\253}\\1882\\211\\015\\172\\215R\\133\\247\\193\\162O\\199\\177\\230\\226|<\\022:U\\166\\177\\23169\\003\\029\\004\\235\\165^P\\004\\005\\022\\252o\\191\\230\\172\\201\\179\\1303\\252c\\024v\\249XC\\151y\\000\\252\\151\\135\\136\\233\\006+:\\221\\252\\199\\161D)@\\230z\\221\\000\\252\\203\\159\\156\\2440\\229\\232\\198\\252\\221\\156\\160\\205e\\187\\221\\007\\000\\252\\019\\026i\\135\\162Y,S\\252{oe*\\176\\188!\\169\\000\\252\\139\\007\\016\\143\\177w\\156\\226\\252\\238\\012k\\223\\000_\\\\\\248\\000\\252\\135\\156\\176\\007-\\167\\189\\029\\252\\160&_\\233\\226\\151\\027M\\000\\252\\017_\\128V|tu\\156\\252\\232\\241\\206\\250ic\\254\\161\\000\\252M`\\233\\219\\223\\138+\\\\\\252\\155\\247\\016\\242\\140q\\140Z\\000\\252Hk\\224Q\\\\\\179\\192\\\"\\252\\237m\\169@s\\139\\136\\166\\000\\252ndv^\\181\\215\\007\\144\\252\\018\\142N\\2199\\139\\198\\193\\000\\252\\201+?7^\\227ED\\252\\229\\205\\140\\252\\021\\199@\\157\\000\\252N\\170\\188K\\132\\130\\152B\\252\\188\\183\\175\\208\\215'\\169\\151\\000\\252wn\\253\\255[=\\202\\153\\252\\148B\\\\\\021Uj\\230\\239\\000\\252T\\153\\151!q\\178}K\\252@\\200\\147a\\224\\162\\031\\149\\000\\252\\179G\\007\\178\\190\\204\\209,\\252\\029\\002d\\242<\\222\\209[\\000\\000\\252o\\191\\230\\172\\201\\179\\1303\\252c\\024v\\249XC\\151y\\000\\252\\151\\135\\136\\233\\006+:\\221\\252\\199\\161D)@\\230z\\221\\000\\252\\203\\159\\156\\2440\\229\\232\\198\\252\\221\\156\\160\\205e\\187\\221\\007\\000\\252\\019\\026i\\135\\162Y,S\\252{oe*\\176\\188!\\169\\000\\252\\139\\007\\016\\143\\177w\\156\\226\\252\\238\\012k\\223\\000_\\\\\\248\\000\\252\\135\\156\\176\\007-\\167\\189\\029\\252\\160&_\\233\\226\\151\\027M\\000\\252\\017_\\128V|tu\\156\\252\\232\\241\\206\\250ic\\254\\161\\000\\252M`\\233\\219\\223\\138+\\\\\\252\\155\\247\\016\\242\\140q\\140Z\\000\\252Hk\\224Q\\\\\\179\\192\\\"\\252\\237m\\169@s\\139\\136\\166\\000\\252ndv^\\181\\215\\007\\144\\252\\018\\142N\\2199\\139\\198\\193\\000\\252\\201+?7^\\227ED\\252\\229\\205\\140\\252\\021\\199@\\157\\000\\252N\\170\\188K\\132\\130\\152B\\252\\188\\183\\175\\208\\215'\\169\\151\\000\\252wn\\253\\255[=\\202\\153\\252\\148B\\\\\\021Uj\\230\\239\\000\\252T\\153\\151!q\\178}K\\252@\\200\\147a\\224\\162\\031\\149\\000\\252\\179G\\007\\178\\190\\204\\209,\\252\\029\\002d\\242<\\222\\209[\\000\\000\\000\\000\\000\\000\\001+\\178z\\189\\247\\143\\2441kS\\153\\134\\228\\129.A\\145\\194\\241\\n\\242\\157v\\230\\254R~\\231=!\\028yl\\212\\198\\242\\150\\168\\251\\127\\131#\\239X\\007\\\\zs\\0160C\\178B\\029\\208)\\143\\162\\135]A\\t\\007\\001\\232\\236M\\246\\175l\\000\\155x\\165[\\244t(\\230\\019h\\002\\022w\\232\\189?\\205\\030\\231\\189\\135\\244\\194\\179\\007\\001\\171\\127\\188\\169\\169\\025\\150?7\\222\\003\\216\\141\\161&\\160\\205\\230\\147\\214\\003l\\004\\147xZa\\210\\217|+\\021\\001\\230\\134'\\178\\191Y\\0017\\206(\\161\\160\\185\\131m^\\1274U]Pz\\190\\235B\\022n\\209w\\0182\\019\\001\\202\\255\\136td\\134E\\219\\019a\\176lK\\1963\\255\\243\\153\\1332\\245?\\220\\222\\1769\\1510\\217\\028!.\\001\\031\\250V\\151\\255/)\\b\\214\\187\\140\\195\\139\\006%\\214\\255-\\223\\b\\131M]\\252#S(\\015\\137\\000\\254\\007\\001|\\226\\192\\159]\\201g\\171\\027^\\014\\145\\242\\206Fp\\177\\135\\157a\\020tfM\\012(\\207?\\232\\173\\158$\\001\\239|%z\\143U\\142i\\012\\022\\230U3jT\\150\\205I)-C\\253]Q\\198\\138\\n\\001\\199\\1712\\\"\\001\\245*\\234Y\\196\\237\\148z\\127B\\016\\135\\176\\031\\184\\175\\225\\031`\\135`\\025\\019\\146\\185\\156= Hr'$\\001\\252\\245\\213\\132?Tn\\194\\025\\248\\233LIj\\175\\225\\003\\212x\\148\\181.V\\003\\248\\145\\161W\\184s\\203/\\001\\216\\161\\018p\\254B\\018\\129\\245Ap4\\191\\1863\\149\\251 /\\1654t\\012\\r,I\\175_l\\246\\133&\\001\\168\\215\\239\\213}\\244\\207\\213\\138\\198B=\\189\\144k\\003\\022KRT\\219\\151\\215\\228\\138\\006\\244\\235z\\b\\217#\\0016\\002\\\"\\186\\135\\255W&\\208\\185h\\235|_d\\173\\181\\215\\1512{-\\221Mr\\219\\b6J>\\028\\006\\001\\027\\014\\230\\015\\235\\209Y\\014\\025D\\176\\168\\001\\176\\143\\231&\\204\\2397\\163R\\031\\161`\\005%tp\\015\\003,\\0016/\\136m\\132\\216\\205\\022\\183\\146q;\\002\\bR@\\162\\132d\\000\\254\\167Dt\\252W\\155\\193\\144\\246\\179#\\001\\127nv'\\218\\003\\201\\206\\241\\176\\232F\\219\\146u\\192J\\028\\018\\148=\\180\\247\\\\\\128w\\197n\\151\\rI\\003\\001q\\152\\173\\221\\1574D\\148\\r\\175\\007=\\130g\\185\\226\\153\\180\\243\\181\\1843\\011d\\154\\132\\197\\222\\014\\189&\\014\\001I\\205\\143\\176\\142\\148\\234\\158\\149\\225\\165\\250H\\156\\023\\011\\240\\b\\197\\146\\144!\\224\\248\\185\\173;\\2229j\\254\\031\\001\\170\\\\[\\166\\023HT;Z!\\227\\233?\\158k|x\\252:\\219\\211\\194\\2485]\\135k-\\176\\020\\220*\\001\\208\\018Gy\\165\\174\\157&\\2271H\\t\\003%XFE\\159\\194\\025\\179\\015{S\\178\\246\\146\\235jMa,\\001\\217\\201\\179H\\176\\229~y\\178\\246Zy\\020vn\\238\\254\\154\\165|<\\b\\177{\\176\\\"z\\243!\\131|$\\001h\\215\\b\\021\\197\\241k\\191|\\191\\205\\176\\0024\\255J*\\157H#ss\\184\\211\\243\\127v\\248\\154\\011 \\n\\001\\240\\157?\\185\\133\\198\\149\\159L\\156$Bb\\176z\\140<\\161\\248#\\239\\238\\144\\134\\007Z-\\1301*\\172-\\001cK\\156\\138\\169\\182\\188\\131E\\130\\026\\232s~O\\202\\132{\\204\\2303\\025\\154\\162\\129\\029\\170Z\\245f\\0069\\001\\031\\001*yV\\176\\143\\242\\166]k\\250\\203\\r\\158\\131x\\007]\\134\\196\\177\\235\\127 %\\012\\206\\254a\\242\\17061\\000\\001\\219\\185N\\182+\\183\\223\\190U\\151'#\\173+D\\234i\\183Kx\\029\\132f\\030\\219\\015\\130a\\196\\210b\\007\\001\\b\\233\\155\\220\\240\\133\\201(\\245\\025[\\185\\214x\\156\\206&ls\\248\\241s\\231~%\\140\\192\\145q%\\222?\\001\\216\\162\\189\\210\\028\\162\\025\\221|\\r\\161q\\240\\127\\205l\\196\\031a\\253w\\239v\\176\\136:\\025.\\150i\\137\\004\\001\\1931\\003\\169g8)\\185\\199\\234\\255R\\221d\\215\\243\\149\\006te\\129@\\026\\025\\135\\166\\151]\\180\\178\\139\\012\\001,\\029\\146\\141\\252\\\"\\227\\005\\194\\205\\192F5\\226\\252\\228\\145\\148\\241\\246\\1766!\\187a\\181\\233\\240F\\248\\028\\\"\\001\\245\\169\\182\\166\\249\\031\\031}Cl[8\\148 \\153[\\154\\130\\128\\160\\171\\203\\131\\255\\195\\153\\211\\224\\232\\195\\181\\025\\001\\254\\167\\017\\239!=:D\\020\\175D '\\012\\021U\\180\\216,,\\249]A\\252C\\016\\183\\164\\203\\b\\128\\022\\001\\220k\\224\\182$\\178\\255\\169\\218\\181\\155}\\212\\143\\019L\\130\\192\\205\\225\\136\\162\\248\\199y\\174\\244\\162N\\207%\\n\\001&7bQ\\224\\155\\248m:\\238@\\194\\244\\250\\027\\232Hq?'\\13104\\2247JMY\\017o\\195\\028\\001\\026\\249A\\180a\\187\\007\\231,i\\131\\130\\200V\\252\\006\\235\\207\\223>\\158\\183\\200x\\194\\b\\148F\\1751R\\020\\001Cs\\203R\\152\\181\\132eim=\\181\\2134\\162j\\217\\024\\238\\162Ru}\\187.\\030\\139\\157\\132\\020'\\020\\001g\\233\\236\\138\\198v;\\145u\\235\\133\\212}\\170@\\247 \\018\\166=~\\248-\\138p\\230\\145i+oE\\022\\001\\016\\233\\238\\174\\016\\200s\\194\\141\\015\\020\\192\\158R\\215\\1310\\254w\\229\\002C\\198kM\\153'\\251\\247r\\143\\015\\001\\210\\146S\\003p\\017\\200\\198\\139iDT\\005%6~n\\142ea\\144\\188n\\165>fA\\b\\132\\184\\215=\\001l$ \\220\\001\\025\\tA!\\176so\\133X\\005\\141\\148;\\183\\138\\192\\251tF\\153\\139_x#6\\161\\142\\138)\\208PM\\154j\\223,;t+\\001\\183!\\131]\\179p\\131j\\220\\021\\197\\134\\023\\133u\\019\\028\\231\\166\\134\\255\\029\\184\\1716\\216\\127\\212\\156\\228\\2102\\001\\140e\\254\\2535\\031 \\029\\019\\131\\142\\192\\031\\208\\172\\1714\\204\\171\\132\\\"\\024\\144\\230\\001Ca-\\199\\160n\\020\\001+\\173q\\005e\\000\\011\\029aH\\159\\191(sj_T\\164\\250]\\215\\141&\\001\\248\\144\\162\\192\\153\\133G+\\001r\\025\\005\\193m\\005B7\\011A\\142\\162K\\017\\031\\000E\\200`~\\207r\\178\\240\\206]\\145\\026\\199\\021\\133<\\001\\024\\218F;3z\\187\\187\\224\\133\\b@\\238\\179\\140\\191{\\180\\183v\\021I*\\196\\238\\186F~\\207y\\011\\002\\001`T[\\018\\161@S\\129\\177\\225x\\222m\\177\\233#\\026\\253\\151\\011+v\\177\\209\\222\\018\\179\\b]\\027\\153=\\001bT\\171\\173\\207\\223\\172\\131\\219\\156\\211\\029\\183\\195\\2518`\\004\\200\\152\\005\\227\\253\\227\\236\\003\\250OEt\\225\\018\\001#\\007Q\\194\\241\\172\\027\\014\\2238\\210\\145~\\012Q\\207\\241\\189k\\188\\229b\\149\\170\\244*I\\154#\\141{9\\001\\250Q\\246\\242.P\\174\\210j\\230\\189\\190\\212-\\172a\\178;]aA\\132\\014B\\148\\249\\131\\020\\196?\\r\\b\\001nd\\197\\029\\213\\018E\\1845l\\234Q\\251[\\016t\\028Z\\144yw^\\r\\242\\166\\169\\028%\\185\\131+%\\001\\203\\189\\209J%\\231\\167\\007\\236\\158k\\164\\235\\230\\236\\246\\184\\\\q\\n^\\t\\172\\150\\221R\\024{\\175'\\224\\016\\001\\027\\237%-\\246\\160L\\141\\225\\202\\237\\173O\\173\\137`h:B\\022\\198\\208-w+y\\021m\\218\\020\\234>\\001\\190\\242\\182\\160\\247\\149\\187\\216\\020\\006\\131\\023n\\000%\\201e}W$\\224\\237Tmr\\204\\000c\\159g\\007\\020\\001]\\213\\212@\\213_0f\\236\\137\\175\\005\\242\\026\\228\\145\\201{\\189\\230\\025\\250\\152\\252rQ\\225\\234\\249\\b;\\025\\000\\001\\217a\\003\\155P\\239\\232\\176\\r\\019\\133\\185|\\000\\185\\200\\237\\012;H\\0051&vP\\221\\229q\\017\\172t\\017\\001k\\132?\\218K\\028\\019n\\155\\187\\245I=\\147\\145\\012`\\247\\160\\1684\\233\\237\\240\\003\\023Wr\\247\\182\\170\\019\\001\\148\\151\\018\\200-Zi\\1799\\191Q\\1314n\\198\\237\\163\\190\\207={D&\\248\\227\\bY5Ht\\130\\b\\001\\220L\\245o\\181\\179~O\\005\\253\\205\\021\\198Z\\175G\\002K\\127\\188\\246\\253\\204\\028Z\\2155\\203>V_\\007\\001~el\\158y\\174 \\207\\153\\143\\176#\\167\\018\\001\\224\\243\\151\\213[\\\"\\019DDF\\162\\150\\1355\\000\\003\\\"\\001\\183\\181\\192\\0140\\252\\1361\\194\\004\\t\\158\\154Fmt\\216\\251\\183\\236\\209\\235\\247\\183jD\\221\\203;\\163\\1892\\001*]\\217A\\168\\207\\b,\\160Tg\\158.\\169\\005\\150\\005(;\\nV\\239)\\027)\\003\\209?\\218\\141\\2303\\001\\027\\162z\\209\\210\\021\\209\\239\\144\\007/ !\\143\\154\\237\\189\\247\\197\\\"\\134\\130rGE\\001\\225\\182\\227T\\1462\\001\\223X\\1939\\179\\012vG\\128q.\\140\\209ib\\021\\2546\\134~\\1476\\157p\\187D\\226\\190\\128gB\\024\\001\\139\\225\\168\\152\\238n\\130\\177\\031\\223r\\232\\251\\017\\247&D\\t\\142\\140\\183\\015\\006\\176\\233\\227\\192\\246\\161Z\\253>\\001\\245\\244\\\"\\151\\227\\222\\253\\228\\235\\031\\224\\011_b]R\\029>g\\201\\014\\169d\\184\\129Ui\\182\\238o\\0215\\001\\244\\144h}D\\172:\\007\\254Y\\006%\\240b\\236NW\\003ZhX\\168\\164\\216\\130;\\029\\1417\\150\\2248\\0017\\243\\145\\130\\204\\246\\\\LX\\135\\020\\024\\194\\147{\\211\\159\\023z86\\241)\\167|\\193~rD~W\\004\\001\\023\\022\\153Cf\\029\\180\\023\\128\\158\\135\\130]\\214\\018Q\\156\\018ga~\\165\\147\\153\\217 \\001\\225\\234\\234\\181\\162&\\135DV\\210\\004\\244\\018T(c~\\203\\018\\180]\\206o\\031+\\181CpW\\167],\\0019\\024\\244\\030\\168\\138^\\213^\\176\\020\\242\\025\\214\\132\\143\\251\\235\\\"\\149F#z \\0231\\246\\216Wd,<\\001(\\129\\219\\244kx\\215l\\028\\131\\2286\\189\\160\\133\\012E\\168\\167\\023\\174~\\153(\\130\\170\\241\\207/\\137\\242\\019\\001\\133dZ[\\181jE\\195\\196Md\\221\\227\\172\\240\\020f\\028\\136+\\129\\147T\\\"\\201'u\\027!\\137\\2275\\001\\175\\156\\238U\\220\\131\\172\\011\\175\\169\\024\\166\\181\\1661\\005\\178)\\006N\\162\\\"\\142\\185\\194\\163\\130\\211\\215\\179\\253$\\001\\241\\134r\\239<\\134M\\249\\199U\\200ad\\\\&\\167\\020\\212\\187\\207\\030`l)r\\249\\023\\149\\224\\017\\203\\031\\001A\\222\\168$\\183\\168)M\\247\\228U'\\202\\220\\143\\185^O\\187\\230\\235\\230z\\194ko\\197\\146Kr\\179!\\001\\220-\\145\\200\\201\\141\\151\\243\\193\\172\\201%\\229bry\\238\\186\\158\\179\\224\\2557\\203\\031\\223\\015N4\\171\\1613\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\250_\\130\\146A-\\205\\129F\\016m\\136D\\248\\159\\231\\138\\242\\187Nc\\162\\193,\\239v>K\\202\\n\\192,\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\000\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\000_\\237f\\144(\\136\\155\\028\\146\\165\\241Ac3\\249pC\\228\\027rG\\148\\190z\\212\\148\\177\\t\\235F0\\b\\164\\027o\\160\\129\\149\\020\\157\\254pe\\136\\211o\\168M\\025v\\137\\174\\247\\138\\192t\\153tvYg\\134\\129\\003iyJ\\160\\136\\n=\\235\\242\\019\\1967\\\"\\206\\160\\246J\\151hZz\\179\\147\\218\\244\\137\\146\\240\\0222\\172\\021vgd%\\232v7\\005\\196\\167,N\\160\\197\\169\\028\\029\\238\\1686d\\015Fr.r\\\"O\\232\\249D2LE\\131\\222\\171Jw\\025\\234R;OV&_Y\\027\\245D\\223c\\203H\\018\\162\\213\\236\\031\\025\\127\\028\\020\\169\\n:(\\131\\225u\\236\\213\\219\\164\\213(I\\002\\181k\\170\\162\\209\\029\\238fw\\004u\\015\\144_ V \\188\\131\\199\\226s\\196\\017[F_\\160,\\205\\011\\011\\155\\158vH\\221\\133\\229\\215\\200\\158\\146\\243\\005\\176\\162\\001/\\158\\001J\\154S\\148\\r\\\"1v\\231\\\\+\\n\\015|fS~\\175mR\\192\\192\\244\\r]\\143\\198n\\2295\\212K\\\"96N\\007\\137A\\250\\184G\\182\\140\\028m\\175L\\211<\\239'\\239\\160\\133@R\\225\\018j\\135\\014\\003\\2516\\164nx\\133T\\152_\\019\\240h\\199J\\226J7\\232N\\156\\006l\\215!\\0005\\170\\2109\\225\\150\\006\\031\\030\\235\\243AH\\194e\\132\\002\\019=P\\007\\0167f\\138\\2182\\186q\\2514*\\224\\001\\151\\255\\249A':\\190\\159\\180\\187EGm\\192\\235\\162\\229\\206\\030\\253\\219\\153\\208\\002`\\213b\\190\\185\\172\\154\\030~\\221\\139\\182\\127\\171\\248H\\210\\007\\152\\221\\196K\\243\\179\\227C4\\203\\128`\\250\\2107\\172\\171\\193R\\1330\\209\\194\\129\\219\\026\\029p\\031R\\152o\\238\\174\\154G6eE\\184\\011\\217<%\\1734\\193\\021\\150\\011i\\237Oe\\142^\\202Y\\180\\148w\\170\\249\\127c\\023[\\247\\235\\130d\\0249\\166\\214d&#\\175{\\153bo\\168\\223j\\138\\137\\177\\138?-\\014\\192S#\\245\\179\\127i\\227z`\\\"+9m*\\133\\tp\\196\\183e\\154\\249\\207\\005\\r\\212\\0209:Z%\\017V\\t\\236U\\151x\\129|\\191\\230\\006_\\141EI\\003p\\175\\158\\156e\\217.\\253\\147\\150\\215\\177\\022$+9\\181\\209p@\\006#\\015\\166\\227\\253\\028\\022>\\217\\242\\246\\209\\247\\019?\\141^M\\238\\249H\\027j\\153\\220\\151\\167\\020\\228z(?DJ\\172\\233\\224'\\21178\\018\\214T\\228\\253\\246#:d\\182J\\223\\211\\173F'\\205\\230\\165\\214\\215\\027\\137\\131\\246?fL)L\\197K1\\232\\197\\149\\207\\216\\155d|\\207\\011\\249T#\\182\\021\\005\\201\\161$\\249\\165\\001\\183\\248R\\000\\0052\\204\\tj\\025\\213\\227h)\\174\\\\wo\\2448\\019Kk\\169}\\012\\133\\235\\022\\154\\005\\219t \\214\\028=\\026\\134{\\254\\132g _0?$\\185L\\151\\020;\\182\\b\\143#\\026\\137\\203q\\146\\195\\206\\185hGQ\\127\\r\\139\\204K\\131\\145\\017\\027\\143\\214'P\\244\\219/\\005\\004\\154-\\001\\145tg\\242\\200\\\"\\026\\217\\244\\225\\184\\177\\000|O\\246;\\006zDmw\\158\\031\\185\\206\\0056z\\230\\244\\028\\255\\230\\253\\137g\\019\\011\\161gH\\199<\\003i\\252sOj\\175\\243.\\224 +\\146ng\\209\\003\\202\\136\\208\\2323\\190\\006x\\244\\247R\\145\\166\\152\\2392\\226/\\204\\011\\231\\224\\244v\\205\\238\\\"\\196\\tV\\231 \\188\\186\\143{\\149i\\147B\\185\\t\\135\\198\\207\\220q0!\\234&b\\250\\019~R\\027\\016\\231\\rG\\128Y\\024\\2476\\190\\159\\161\\234P\\192i)^\\128\\145S\\211\\0145_\\n\\nGB\\237\\1294Q\\166\\249wh\\132\\r\\145zV\\249\\182g\\023\\004\\0258\\207\\217S\\n\\2127en\\021\\006\\236!Qz\\128\\137\\2258\\218~\\209M\\180^\\216\\161\\177\\232\\240\\241\\163\\174E\\175*\\174\\201*\\000\\132\\150|2pt\\003\\168hs\\237\\2032S\\218\\rB\\245\\178I\\018\\025\\230\\152\\189\\191Y\\147\\205:\\028:%S\\150\\252l\\194\\022)\\206\\246\\163\\141\\156\\152nP1k\\180.\\031(\\163\\225\\175\\135\\031ui\\250\\203\\rF\\207\\235u\\213?\\170\\219\\220`UL\\153\\188\\221j\\133%\\242\\166\\244\\231\\176\\168#\\237@\\221P\\252\\r\\000i\\n\\152\\217K!p\\237\\251?V\\155\\214\\222\\239\\169\\204\\161;\\t=\\149\\155\\019n\\224\\029/\\152k\\r$n\\142\\134\\243\\219QJ=\\253\\172\\247u\\006h\\011\\2340\\208\\232E\\195\\192\\214W\\250Ld\\201Z\\027%(\\018\\246\\168\\135\\249\\155\\197\\0213\\230Q\\152\\016\\199\\157\\215\\254|\\216\\015\\141\\140\\180\\131\\164\\246Rdg\\202s\\030;\\215wf\\000\\135\\168\\214\\165\\168?d\\000\\006\\188\\167\\1936\\223\\2045\\147\\b\\235\\196D\\254\\000\\230\\130k\\024s\\023k\\187\\196\\195Z@\\203\\002\\248\\217r\\024\\202\\205\\152\\242c\\221X\\181\\174\\143\\193\\184\\021\\242\\201\\197\\221)?\\199\\162\\232\\019p`P5\\249`\\203\\136T\\251\\1315\\025\\134\\204\\1363\\253\\223z\\255:\\252\\176\\021SI\\175P\\145\\227\\205\\024\\192\\146\\237\\149{\\227q\\215\\155\\202>\\0263\\191\\015\\131\\136\\172\\024\\145%\\148A\\004\\231\\\"\\191\\0118O\\193H;\\165\\r\\137F\\004\\220UF\\2284\\196\\202\\182\\000\\028\\194\\188Y\\250\\199\\152Z*zJ\\132\\167V_\\021\\242\\181\\202L\\r\\205\\241\\159\\153\\147q\\t\\185k!\\231\\165A\\209B\\001$\\022Q6\\232\\t?V\\196\\142T\\000\\254\\213\\194\\168j\\232\\2193\\133c\\245\\167\\2341\\166k-\\b3\\226\\183:\\214\\012\\166ac>\\212\\151\\030\\195\\165\\0018\\219\\182|}HB\\191\\254\\239\\177\\003\\229\\141\\147@\\026\\247\\004\\244\\204\\029\\246\\129>q\\241!\\251\\170f\\029\\203\\128\\148^\\241\\024>\\195\\207\\016\\183\\1987\\024JP;\\026\\174\\145\\b\\011R\\190\\155\\240\\240\\187\\017\\145\\157Pm\\240;\\184\\159\\246\\181:\\146\\214\\248\\015\\001\\150\\029\\197@%\\\\\\152T ~X\\178O\\210)\\239\\177n\\018\\005\\166K\\\\\\187\\152ef\\175\\132\\026\\236jM\\141\\165B\\000]9v\\021\\151\\154\\248&\\011\\204\\233'\\149\\244\\0188\\2074\\215{C`\\225\\228\\020\\209\\199\\147}\\172ky\\231M\\2299\\243r\\141\\022\\128\\225\\th\\027Ko\\128\\017\\254\\166\\167X\\248\\233'\\220.\\022\\236\\243\\196\\025\\190o\\149v\\022xd\\2555\\157j {r?\\024\\127w\\134\\021\\210\\240s+7\\175\\022\\153w\\148\\207\\131Id\\216y9'\\166u><\\022\\185\\137!\\213=\\024T\\002\\232t\\243\\024\\168\\025\\253\\242\\243\\172fg& E\\170\\138&fN|\\166\\254\\147\\241Q\\240iP\\139\\130j\\213\\208lqT\\147\\024\\203\\201\\017\\218kt\\208n\\254(\\006\\000.S`[\\128\\026\\215\\254\\167E\\233vj\\221\\141\\169\\2373X\\157u\\143\\1799\\254\\212\\0122\\156Y\\170'\\183z\\135\\136\\176\\127|\\209\\201\\198\\022\\024u\\\\\\202=\\r0:{\\ta$\\206\\012\\002\\220_E\\026\\015\\003.\\030hs\\029\\000\\184G \\003\\136#w~\\198R-\\154\\030\\1586Y \\195\\231\\206\\006J\\222\\012.\\030\\217mb\\229J\\nI\\211\\164L\\145\\158\\180\\176\\1373=d\\1626\\237\\205\\161\\146\\018t\\172i\\003\\186\\2177\\204\\227\\167\\141\\250$-\\140S\\232\\148g\\204\\152m\\2533-\\185\\135\\215lf\\231sZG\\2394\\233\\015(\\195}i,\\132s\\170\\154$k\\184^\\\\C#\\205\\012Zi\\228\\185\\206\\026\\225`\\249aD|1\\174.\\216-8qxB\\189\\227\\023\\021~\\223\\024j[*Z\\194\\1605\\160i\\177\\138\\027\\183\\144\\216\\161\\182\\014&i\\148\\226p\\242\\132\\165W\\196\\024\\175\\235\\250\\172\\162yL\\138\\246\\164v\\203\\027\\148x\\194\\005\\232\\169\\001\\023\\015qq\\021\\229\\151\\019\\200O\\136\\186\\190.\\192)%\\024\\006\\r,\\200+T\\233\\169\\201\\162\\210\\168|\\233\\030\\021]\\217<\\155,?\\206\\227\\015\\163I`\\242G/\\205\\004\\217\\222\\132\\134\\2465\\201\\185mwo\\1741\\\"\\031\\168O\\148\\160\\214\\214K\\224\\185pI\\185*\\226\\197\\138\\140\\185>y!y\\250\\181\\127\\163,F\\149\\171\\231$,|j\\165\\018;A\\170\\142\\172\\232Z~\\238\\184\\235\\178\\\"\\025\\2015;\\146vq\\017\\153\\170\\168\\001\\130\\023\\022\\235\\162\\235\\218\\159\\234\\196B\\226\\158\\249)?\\\\Ev\\147=S\\026n<\\007Q\\1425\\\"A\\005_=\\220\\245\\178\\225$S\\1846\\156B\\014v\\173\\160\\251ln\\023?\\\"q\\170\\025\\236m\\184\\001\\001\\018a\\022\\005\\00056-\\152o \\197\\152\\229<=\\224\\184\\252A0\\004\\132$1r\\175\\137<\\201\\156\\161\\153\\170\\022\\022<\\240\\149\\030j8_\\180\\234\\139^,\\240\\232\\158T\\128z\\153\\147\\139\\n\\182\\156w\\241\\185\\178\\016\\160]\\021.7\\190\\250\\157\\128\\198(\\251\\139?\\127S\\022\\145,\\023T&\\160\\173\\154\\131\\219x\\bG\\2146\\241\\204\\171\\t\\224\\r6\\204+`v\\1941\\132\\004l\\n*\\006 \\133!VD\\254)T\\154bR\\002PU\\189\\251\\028k\\223#\\014\\192z\\145S\\025\\198\\006\\173\\147\\012A\\221\\127\\tr\\\"\\173\\162wjHNu_\\235-I\\028\\238\\128+\\234\\244\\221\\186\\243\\182\\150\\152h\\157~v\\182p\\202\\166]\\219\\217!\\151\\\"z\\176\\200\\223\\1866$\\181\\201\\141:\\136\\030\\170\\213`\\r\\137\\146\\r\\255\\131\\002Py\\210{\\222<\\234\\221\\020B[\\252\\138@\\211\\016\\192D\\022(\\001%\\025\\215o\\239\\001\\007CM\\197k\\177t\\231\\209a\\012\\222/\\200mj\\167+u\\173\\026\\205q\\200\\175\\225\\167\\025\\242\\229\\232?\\206yA\\251\\1541>+\\146bH\\n\\250hg]\\207\\171d\\178\\n\\229\\128\\t=$\\004\\006\\246hK1<\\228\\006i\\189[\\161\\200\\223>\\213<\\237/G<\\003z\\241\\154\\b\\154\\204\\148\\217\\195\\231\\189\\223f\\163#\\216+\\245E\\025\\187\\143/[\\221H\\254\\206\\180Z\\139\\222\\n\\167\\1609\\150\\161\\006B\\017\\181+\\195M&Xxu\\007$\\232\\213R\\174\\156\\232\\250\\229I,}\\020\\169\\230nu\\023\\206*\\018\\131\\\"j\\156\\211\\011\\147\\130\\151\\180\\001\\1770K \\166yd\\132<\\236\\003\\224\\226FW.\\\\\\137>\\220\\201\\145:\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\";;\n","open Core_kernel\n\ntype uint64 = Unsigned.uint64\n\ntype uint32 = Unsigned.uint32\n\nmodule type S = sig\n type t [@@deriving sexp, hash, compare, yojson]\n\n val length_in_bits : int\n\n include Hashable.S with type t := t\n\n include Unsigned.S with type t := t\n\n val ( < ) : t -> t -> bool\n\n val ( > ) : t -> t -> bool\n\n val ( = ) : t -> t -> bool\n\n val ( <= ) : t -> t -> bool\n\n val ( >= ) : t -> t -> bool\n\n val to_bigint : t -> Bigint.t\nend\n\nmodule type F = functor\n (Unsigned : Unsigned.S)\n (M : sig\n val length : int\n end)\n -> S with type t = Unsigned.t\n[@@warning \"-67\"]\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Fold_lib\ninclude Intf\nmodule Intf = Intf\nopen Snark_bits\n\n[%%ifdef consensus_mechanism]\n\nmodule Make_checked\n (N : Unsigned_extended.S)\n (Bits : Bits_intf.Convertible_bits with type t := N.t) =\nstruct\n open Snark_params.Tick\n\n type var = Field.Var.t\n\n let () = assert (Int.(N.length_in_bits < Field.size_in_bits))\n\n let to_input (t : var) =\n Random_oracle.Input.Chunked.packed (t, N.length_in_bits)\n\n let to_input_legacy (t : var) =\n let to_bits (t : var) =\n with_label (sprintf \"to_bits: %s\" __LOC__) (fun () ->\n Field.Checked.choose_preimage_var t ~length:N.length_in_bits )\n in\n Checked.map (to_bits t) ~f:(fun bits ->\n Random_oracle.Input.Legacy.bitstring bits )\n\n let constant n =\n Field.Var.constant\n (Bigint.to_field (Bigint.of_bignum_bigint (N.to_bigint n)))\n\n let () = assert (Int.(N.length_in_bits mod 16 = 0))\n\n let range_check' (t : var) =\n let _, _, actual_packed =\n Pickles.Scalar_challenge.to_field_checked' ~num_bits:N.length_in_bits m\n (Kimchi_backend_common.Scalar_challenge.create t)\n in\n actual_packed\n\n let range_check t =\n let%bind actual = make_checked (fun () -> range_check' t) in\n Field.Checked.Assert.equal actual t\n\n let range_check_flag t =\n let open Pickles.Impls.Step in\n let actual = range_check' t in\n Field.equal actual t\n\n let of_field (x : Field.t) : N.t =\n let of_bits bs =\n (* TODO: Make this efficient *)\n List.foldi bs ~init:N.zero ~f:(fun i acc b ->\n if b then N.(logor (shift_left one i) acc) else acc )\n in\n of_bits (List.take (Field.unpack x) N.length_in_bits)\n\n let to_field (x : N.t) : Field.t = Field.project (Fold.to_list (Bits.fold x))\n\n let typ : (var, N.t) Typ.t =\n let (Typ field_typ) = Field.typ in\n Typ.transport\n (Typ { field_typ with check = range_check })\n ~there:to_field ~back:of_field\n\n let () = assert (N.length_in_bits * 2 < Field.size_in_bits + 1)\n\n let div_mod (x : var) (y : var) =\n let%bind q, r =\n exists (Typ.tuple2 typ typ)\n ~compute:\n As_prover.(\n let%map x = read typ x and y = read typ y in\n (N.div x y, N.rem x y))\n in\n\n (* q * y + r = x\n\n q * y = x - r\n *)\n let%map () = assert_r1cs q y (Field.Var.sub x r) in\n (q, r)\n\n type t = var\n\n let is_succ ~pred ~succ =\n let open Snark_params.Tick in\n let open Field in\n Checked.(equal (pred + Var.constant one) succ)\n\n let gte x y =\n let open Pickles.Impls.Step in\n let xy = Pickles.Util.seal m Field.(x - y) in\n let yx = Pickles.Util.seal m (Field.negate xy) in\n let x_gte_y = range_check_flag xy in\n let y_gte_x = range_check_flag yx in\n Boolean.Assert.any [ x_gte_y; y_gte_x ] ;\n x_gte_y\n\n let op op a b = make_checked (fun () -> op a b)\n\n let ( >= ) a b = op gte a b\n\n let ( <= ) a b = b >= a\n\n let ( < ) a b =\n make_checked (fun () ->\n let open Pickles.Impls.Step in\n Boolean.( &&& ) (gte b a) (Boolean.not (Field.equal b a)) )\n\n let ( > ) a b = b < a\n\n module Assert = struct\n let equal = Field.Checked.Assert.equal\n end\n\n let to_field = Fn.id\n\n module Unsafe = struct\n let of_field = Fn.id\n end\n\n let min a b =\n let%bind a_lte_b = a <= b in\n Field.Checked.if_ a_lte_b ~then_:a ~else_:b\n\n let if_ = Field.Checked.if_\n\n let succ_if (t : var) (c : Boolean.var) =\n Checked.return (Field.Var.add t (c :> Field.Var.t))\n\n let succ (t : var) =\n Checked.return (Field.Var.add t (Field.Var.constant Field.one))\n\n let seal x = make_checked (fun () -> Pickles.Util.seal m x)\n\n let add (x : var) (y : var) =\n let%bind res = seal (Field.Var.add x y) in\n let%map () = range_check res in\n res\n\n let mul (x : var) (y : var) =\n let%bind res = Field.Checked.mul x y in\n let%map () = range_check res in\n res\n\n let subtract_unpacking_or_zero x y =\n let open Pickles.Impls.Step in\n let res = Pickles.Util.seal m Field.(x - y) in\n let neg_res = Pickles.Util.seal m (Field.negate res) in\n let x_gte_y = range_check_flag res in\n let y_gte_x = range_check_flag neg_res in\n Boolean.Assert.any [ x_gte_y; y_gte_x ] ;\n (* If y_gte_x is false, then x_gte_y is true, so x >= y and\n thus there was no underflow.\n\n If y_gte_x is true, then y >= x, which means there was underflow\n iff y != x.\n\n Thus, underflow = (neg_res_good && y != x)\n *)\n let underflow = Boolean.( &&& ) y_gte_x (Boolean.not (Field.equal x y)) in\n (`Underflow underflow, Field.if_ underflow ~then_:Field.zero ~else_:res)\n\n let sub_or_zero a b = make_checked (fun () -> subtract_unpacking_or_zero a b)\n\n (* Unpacking protects against underflow *)\n let sub (x : var) (y : var) =\n let%bind res = seal (Field.Var.sub x y) in\n let%map () = range_check res in\n res\n\n let equal a b = Field.Checked.equal a b\n\n let ( = ) = equal\n\n let zero = Field.Var.constant Field.zero\nend\n\n[%%endif]\n\nopen Snark_params.Tick\n\nmodule Make (N : sig\n type t [@@deriving sexp, compare, hash]\n\n include Unsigned_extended.S with type t := t\n\n val random : unit -> t\nend)\n(Bits : Bits_intf.Convertible_bits with type t := N.t) =\nstruct\n type t = N.t [@@deriving sexp, compare, hash, yojson]\n\n (* can't be automatically derived *)\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n\n let max_value = N.max_int\n\n include Comparable.Make (N)\n\n include (N : module type of N with type t := t)\n\n let sub x y = if x < y then None else Some (N.sub x y)\n\n let to_field n = Bigint.to_field (Bigint.of_bignum_bigint (N.to_bigint n))\n\n [%%ifdef consensus_mechanism]\n\n module Checked = Make_checked (N) (Bits)\n\n (* warning: this typ does not work correctly with the generic if_ *)\n let typ = Checked.typ\n\n [%%endif]\n\n module Bits = Bits\n\n let to_bits = Bits.to_bits\n\n let of_bits = Bits.of_bits\n\n let to_input (t : t) =\n Random_oracle.Input.Chunked.packed (to_field t, N.length_in_bits)\n\n let to_input_legacy t = Random_oracle.Input.Legacy.bitstring (to_bits t)\n\n let fold t = Fold.group3 ~default:false (Bits.fold t)\n\n let gen =\n Quickcheck.Generator.map\n ~f:(fun n -> N.of_string (Bignum_bigint.to_string n))\n (Bignum_bigint.gen_incl Bignum_bigint.zero\n (Bignum_bigint.of_string N.(to_string max_int)) )\n\n let gen_incl min max =\n let open Quickcheck.Let_syntax in\n let%map n =\n Bignum_bigint.gen_incl\n (Bignum_bigint.of_string (N.to_string min))\n (Bignum_bigint.of_string (N.to_string max))\n in\n N.of_string (Bignum_bigint.to_string n)\nend\n\nmodule Make32 () : UInt32 = struct\n open Unsigned_extended\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = UInt32.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include\n Make\n (struct\n include UInt32\n\n let random () =\n let mask = if Random.bool () then one else zero in\n let open UInt32.Infix in\n logor (mask lsl 31)\n ( Int32.max_value |> Random.int32 |> Int64.of_int32\n |> UInt32.of_int64 )\n end)\n (Bits.UInt32)\n\n let to_uint32 = Unsigned_extended.UInt32.to_uint32\n\n let of_uint32 = Unsigned_extended.UInt32.of_uint32\nend\n\nmodule Make64 () : UInt64 = struct\n open Unsigned_extended\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = UInt64.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include\n Make\n (struct\n include UInt64\n\n let random () =\n let mask = if Random.bool () then one else zero in\n let open UInt64.Infix in\n logor (mask lsl 63)\n (Int64.max_value |> Random.int64 |> UInt64.of_int64)\n end)\n (Bits.UInt64)\n\n let to_uint64 = Unsigned_extended.UInt64.to_uint64\n\n let of_uint64 = Unsigned_extended.UInt64.of_uint64\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Fold_lib\nopen Tuple_lib\nopen Unsigned\nopen Snark_bits\nopen Snark_params.Tick\n\nmodule type S_unchecked = sig\n type t [@@deriving sexp, compare, hash, yojson]\n\n include Comparable.S with type t := t\n\n include Hashable.S with type t := t\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n\n val max_value : t\n\n val length_in_bits : int\n\n val gen : t Quickcheck.Generator.t\n\n val gen_incl : t -> t -> t Quickcheck.Generator.t\n\n val zero : t\n\n val one : t\n\n val succ : t -> t\n\n val add : t -> t -> t\n\n val sub : t -> t -> t option\n\n val of_int : int -> t\n\n val to_int : t -> int\n\n (* Someday: I think this only does ones greater than zero, but it doesn't really matter for\n selecting the nonce *)\n\n val random : unit -> t\n\n val of_string : string -> t\n\n val to_string : t -> string\n\n module Bits : Bits_intf.Convertible_bits with type t := t\n\n val to_bits : t -> bool list\n\n val of_bits : bool list -> t\n\n val to_field : t -> Field.t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val to_input_legacy : t -> (_, bool) Random_oracle.Legacy.Input.t\n\n val fold : t -> bool Triple.t Fold.t\nend\n\n[%%ifdef consensus_mechanism]\n\nmodule type S_checked = sig\n type unchecked\n\n type var\n\n val constant : unchecked -> var\n\n type t = var\n\n val zero : t\n\n val succ : t -> t Checked.t\n\n val add : t -> t -> t Checked.t\n\n val mul : t -> t -> t Checked.t\n\n (** [sub_or_zero x y] computes [x - y].\n\n - If the argument to [`Underflow] is true, [x < y] and the returned integer\n value is pinned to [zero].\n - If the argument to [`Underflow] is false, [x >= y] and the returned\n integer value is equal to [x - y]\n *)\n val sub_or_zero : t -> t -> ([ `Underflow of Boolean.var ] * t) Checked.t\n\n (** [sub ~m x y] computes [x - y] and ensures that [0 <= x - y] *)\n val sub : t -> t -> t Checked.t\n\n val is_succ : pred:t -> succ:t -> Boolean.var Checked.t\n\n val min : t -> t -> t Checked.t\n\n val to_input : t -> Field.Var.t Random_oracle.Input.Chunked.t\n\n val to_input_legacy :\n t -> (_, Boolean.var) Random_oracle.Legacy.Input.t Checked.t\n\n val succ_if : t -> Boolean.var -> t Checked.t\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t Checked.t\n\n (** warning: this typ does not work correctly with the generic if_ *)\n val typ : (t, unchecked) Snark_params.Tick.Typ.t\n\n val equal : t -> t -> Boolean.var Checked.t\n\n val div_mod : t -> t -> (t * t) Checked.t\n\n val ( = ) : t -> t -> Boolean.var Checked.t\n\n val ( < ) : t -> t -> Boolean.var Checked.t\n\n val ( > ) : t -> t -> Boolean.var Checked.t\n\n val ( <= ) : t -> t -> Boolean.var Checked.t\n\n val ( >= ) : t -> t -> Boolean.var Checked.t\n\n module Assert : sig\n val equal : t -> t -> unit Checked.t\n end\n\n val to_field : t -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> t\n end\nend\n\n[%%endif]\n\nmodule type S = sig\n include S_unchecked\n\n [%%ifdef consensus_mechanism]\n\n module Checked : S_checked with type unchecked := t\n\n (** warning: this typ does not work correctly with the generic if_ *)\n val typ : (Checked.t, t) Snark_params.Tick.Typ.t\n\n [%%endif]\nend\n\nmodule type UInt32_A = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n include S with type t := t\n\n val to_uint32 : t -> uint32\n\n val of_uint32 : uint32 -> t\nend\n[@@warning \"-32\"]\n\nmodule type UInt32 = UInt32_A with type Stable.V1.t = Unsigned_extended.UInt32.t\n\nmodule type UInt64_A = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n include S with type t := Stable.Latest.t\n\n val to_uint64 : t -> uint64\n\n val of_uint64 : uint64 -> t\nend\n[@@warning \"-32\"]\n\nmodule type UInt64 = UInt64_A with type Stable.V1.t = Unsigned_extended.UInt64.t\n\nmodule type F = functor\n (N : sig\n type t [@@deriving bin_io, sexp, compare, hash]\n\n include Unsigned_extended.S with type t := t\n\n val random : unit -> t\n end)\n (Bits : Bits_intf.Convertible_bits with type t := N.t)\n -> S with type t := N.t and module Bits := Bits\n\n[%%ifdef consensus_mechanism]\n\nmodule type F_checked = functor\n (N : Unsigned_extended.S)\n (Bits : Bits_intf.Convertible_bits with type t := N.t)\n -> S_checked with type unchecked := N.t\n[@@warning \"-67\"]\n\n[%%endif]\n","include Nat.Make32 ()\n","module T = Nat.Make32 ()\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Account_nonce\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include Nat.Intf.UInt32_A with type Stable.V1.t = A.V1.t\n\n include Codable.S with type t := t\n end\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n include T\n\n (* while we could use an int encoding for yojson (an OCaml int is 63-bits)\n we've committed to a string encoding\n *)\n include Codable.Make_of_string (T)\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","module type S_base = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving hash, sexp, compare, equal, yojson]\n end\n end]\n\n val to_uint32 : t -> Unsigned.uint32\n\n val of_uint32 : Unsigned.uint32 -> t\n\n val to_string : t -> string\n\n val of_string : string -> t\n\n val gen : t Core_kernel.Quickcheck.Generator.t\n\n val gen_incl : t -> t -> t Core_kernel.Quickcheck.Generator.t\n\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n\n val zero : t\n\n val one : t\n\n val succ : t -> t\n\n val of_int : int -> t\n\n val to_int : t -> int\n\n val max_value : t\n\n val to_input : t -> Snark_params.Tick.Field.t Random_oracle.Input.Chunked.t\n\n val to_input_legacy : t -> ('a, bool) Random_oracle.Legacy.Input.t\n\n val to_field : t -> Snark_params.Tick.Field.t\n\n val random : unit -> t\n\n include Core_kernel.Comparable.S with type t := t\nend\n\nmodule type S = sig\n include S_base\n\n type global_slot_span\n\n module Checked : sig\n include Intf.S_checked with type unchecked := t\n\n type global_slot_span_checked\n\n open Snark_params.Tick\n\n val add : t -> global_slot_span_checked -> t Checked.t\n\n val sub : t -> global_slot_span_checked -> t Checked.t\n\n val diff : t -> t -> global_slot_span_checked Checked.t\n\n val diff_or_zero :\n t\n -> t\n -> ([ `Underflow of Boolean.var ] * global_slot_span_checked) Checked.t\n end\n\n val typ : (Checked.t, t) Snark_params.Tick.Typ.t\n\n val add : t -> global_slot_span -> t\n\n val sub : t -> global_slot_span -> t option\n\n val diff : t -> t -> global_slot_span option\nend\n\nmodule type S_span = sig\n include S_base\n\n module Checked : Intf.S_checked with type unchecked := t\n\n val typ : (Checked.t, t) Snark_params.Tick.Typ.t\n\n val add : t -> t -> t\n\n val sub : t -> t -> t option\nend\n","(** Legacy global slot implementation *)\n\n(* Used *only* for V1 payments, delegation valid_until field *)\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Global_slot_legacy\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Nat.Intf.UInt32_A with type Stable.V1.t = A.V1.t\nend\n\nmodule T = Nat.Make32 ()\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n include T\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","(** Global slot span implementation *)\n\nopen Core_kernel\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Global_slot_span\n\ntype uint32 = Unsigned.uint32\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include Global_slot_intf.S_span with type Stable.V1.t = A.V1.t\n end\nend\n\nmodule T = Nat.Make32 ()\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Wire_types.global_slot_span = Global_slot_span of T.Stable.V1.t\n [@@unboxed] [@@deriving hash, sexp, compare, equal]\n\n let to_latest = Fn.id\n\n let sexp_of_t (Global_slot_span u32) = Sexp.Atom (T.to_string u32)\n\n let t_of_sexp = function\n | Sexp.Atom i ->\n Global_slot_span (T.of_string i)\n | _ ->\n failwith \"Global_slot.of_sexp: Expected Atom\"\n\n let to_yojson (Global_slot_span t) = `String (T.to_string t)\n\n let of_yojson = function\n | `String s ->\n Ok (Global_slot_span (T.of_string s))\n | `List [ `String \"Global_slot_span\"; `String s ] ->\n Ok (Global_slot_span (T.of_string s))\n | _ ->\n Error \"Global_slot_span.of_yojson: expected string\"\n end\n end]\n\n let to_uint32 (Global_slot_span u32) : uint32 = u32\n\n let of_uint32 u32 : t = Global_slot_span u32\n\n module Checked = struct\n include T.Checked\n\n let constant t = constant @@ to_uint32 t\n\n let typ =\n Snark_params.Tick.Typ.transport T.Checked.typ ~there:to_uint32\n ~back:of_uint32\n end\n\n let sexp_of_t = Stable.Latest.sexp_of_t\n\n let t_of_sexp = Stable.Latest.t_of_sexp\n\n let to_yojson = Stable.Latest.to_yojson\n\n let of_yojson = Stable.Latest.of_yojson\n\n let to_string t = Unsigned.UInt32.to_string @@ to_uint32 t\n\n let of_string s = of_uint32 @@ Unsigned.UInt32.of_string s\n\n let typ = Checked.typ\n\n let gen =\n let%map.Quickcheck u32 = T.gen in\n of_uint32 u32\n\n let gen_incl t1 t2 =\n let u32_1 = to_uint32 t1 in\n let u32_2 = to_uint32 t2 in\n let%map.Quickcheck u32 = T.gen_incl u32_1 u32_2 in\n of_uint32 u32\n\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n\n let zero = of_uint32 T.zero\n\n let one = of_uint32 T.one\n\n let succ t = of_uint32 (T.succ @@ to_uint32 t)\n\n let max_value = of_uint32 Unsigned.UInt32.max_int\n\n let to_field t = T.to_field (to_uint32 t)\n\n let to_input t = T.to_input (to_uint32 t)\n\n let to_input_legacy t = T.to_input_legacy (to_uint32 t)\n\n include Comparable.Make (Stable.Latest)\n\n let add t1 t2 =\n let u32_1 = to_uint32 t1 in\n let u32_2 = to_uint32 t2 in\n let sum = T.add u32_1 u32_2 in\n of_uint32 sum\n\n let sub t1 t2 =\n let u32_1 = to_uint32 t1 in\n let u32_2 = to_uint32 t2 in\n Option.map (T.sub u32_1 u32_2) ~f:of_uint32\n\n let of_int n = of_uint32 (T.of_int n)\n\n let to_int t = T.to_int (to_uint32 t)\n\n let random () = of_uint32 (T.random ())\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\n\ntype uint32 = Unsigned.uint32\n\nmodule type S = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving sexp, compare]\n end\n end]\n\n module T : Intf.UInt32\n\n val to_uint32 : t -> uint32\n\n val of_uint32 : uint32 -> t\nend\n\nmodule Make (M : S) = struct\n type global_slot_span = Global_slot_span.t\n\n module T = M.T\n\n let to_uint32 = M.to_uint32\n\n let of_uint32 = M.of_uint32\n\n module Checked = struct\n include T.Checked\n\n type global_slot_span_checked = Global_slot_span.Checked.t\n\n let constant t = constant (to_uint32 t)\n\n open Snark_params.Tick\n\n let add t (span : global_slot_span_checked) =\n let t' = Global_slot_span.Checked.to_field span |> Unsafe.of_field in\n add t t'\n\n let sub t (span : global_slot_span_checked) =\n let t' = Global_slot_span.Checked.to_field span |> Unsafe.of_field in\n sub t t'\n\n let diff t1 t2 : global_slot_span_checked Checked.t =\n let%map diff = T.Checked.sub t1 t2 in\n let field = T.Checked.to_field diff in\n (* `of_field` is the identity function, here applied to a checked field *)\n Global_slot_span.Checked.Unsafe.of_field field\n\n let typ = Typ.transport T.Checked.typ ~there:to_uint32 ~back:of_uint32\n\n let diff_or_zero t1 t2 =\n let%map underflow, diff = T.Checked.sub_or_zero t1 t2 in\n let field = T.Checked.to_field diff in\n (* `of_field` is the identity function, here applied to a checked field *)\n let span = Global_slot_span.Checked.Unsafe.of_field field in\n (underflow, span)\n end\n\n let to_string t = Unsigned.UInt32.to_string @@ to_uint32 t\n\n let of_string s = of_uint32 @@ Unsigned.UInt32.of_string s\n\n let typ = Checked.typ\n\n let gen =\n let%map.Quickcheck u32 = T.gen in\n of_uint32 u32\n\n let gen_incl t1 t2 =\n let u32_1 = to_uint32 t1 in\n let u32_2 = to_uint32 t2 in\n let%map.Quickcheck u32 = T.gen_incl u32_1 u32_2 in\n of_uint32 u32\n\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n\n let zero = of_uint32 T.zero\n\n let one = of_uint32 T.one\n\n let succ t =\n let u32 = to_uint32 t in\n of_uint32 (T.succ u32)\n\n let max_value = of_uint32 Unsigned.UInt32.max_int\n\n let to_field t = T.to_field (to_uint32 t)\n\n let to_input t = T.to_input (to_uint32 t)\n\n let to_input_legacy t = T.to_input_legacy (to_uint32 t)\n\n include Comparable.Make (M.Stable.Latest)\n\n let add t span =\n let u32_slot = to_uint32 t in\n let u32_span = Global_slot_span.to_uint32 span in\n let u32_sum = T.add u32_slot u32_span in\n of_uint32 u32_sum\n\n let sub t span =\n let u32_slot = to_uint32 t in\n let u32_span = Global_slot_span.to_uint32 span in\n Option.map (T.sub u32_slot u32_span) ~f:of_uint32\n\n let diff t1 t2 =\n let u32_1 = to_uint32 t1 in\n let u32_2 = to_uint32 t2 in\n Option.map (T.sub u32_1 u32_2) ~f:Global_slot_span.of_uint32\n\n let of_int n = of_uint32 (T.of_int n)\n\n let to_int t = T.to_int (to_uint32 t)\n\n let random () = of_uint32 (T.random ())\nend\n","(** Global slot (since genesis) implementation *)\n\nopen Core_kernel\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Global_slot_since_genesis\n\ntype uint32 = Unsigned.uint32\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include\n Global_slot_intf.S\n with type Stable.V1.t = A.V1.t\n and type global_slot_span = Global_slot_span.t\n and type Checked.global_slot_span_checked = Global_slot_span.Checked.t\n end\nend\n\nmodule T = Nat.Make32 ()\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n module M = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Wire_types.global_slot = Since_genesis of T.Stable.V1.t\n [@@unboxed] [@@deriving hash, sexp, compare, equal]\n\n let to_latest = Fn.id\n\n let sexp_of_t (Since_genesis u32) = Sexp.Atom (T.to_string u32)\n\n let t_of_sexp = function\n | Sexp.Atom i ->\n Since_genesis (T.of_string i)\n | _ ->\n failwith \"Global_slot.of_sexp: Expected Atom\"\n\n let to_yojson (Since_genesis u32) = `String (T.to_string u32)\n\n let of_yojson = function\n | `String i ->\n Ok (Since_genesis (T.of_string i))\n | `List [ `String \"Since_genesis\"; `String i ] ->\n Ok (Since_genesis (T.of_string i))\n | _ ->\n Error \"Global_slot.of_yojson: Expected `String\"\n end\n end]\n\n module T = T\n\n let to_uint32 (Since_genesis u32) : uint32 = u32\n\n let of_uint32 u32 : t = Since_genesis u32\n\n let sexp_of_t = Stable.Latest.sexp_of_t\n\n let t_of_sexp = Stable.Latest.t_of_sexp\n\n let to_yojson = Stable.Latest.to_yojson\n\n let of_yojson = Stable.Latest.of_yojson\n end\n\n include M\n include Global_slot.Make (M)\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","(** Global slot (since hard fork) implementation *)\n\nopen Core_kernel\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Global_slot_since_hard_fork\n\ntype uint32 = Unsigned.uint32\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include\n Global_slot_intf.S\n with type Stable.V1.t = A.V1.t\n and type global_slot_span = Global_slot_span.t\n and type Checked.global_slot_span_checked = Global_slot_span.Checked.t\n end\nend\n\nmodule T = Nat.Make32 ()\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n module M = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Wire_types.global_slot = Since_hard_fork of T.Stable.V1.t\n [@@unboxed] [@@deriving hash, compare, equal]\n\n let to_latest = Fn.id\n\n let sexp_of_t (Since_hard_fork u32) = Sexp.Atom (T.to_string u32)\n\n let t_of_sexp = function\n | Sexp.Atom i ->\n Since_hard_fork (T.of_string i)\n | _ ->\n failwith \"Global_slot.of_sexp: Expected Atom\"\n\n let to_yojson (Since_hard_fork u32) = `String (T.to_string u32)\n\n let of_yojson = function\n | `String i ->\n Ok (Since_hard_fork (T.of_string i))\n | `List [ `String \"Since_hard_fork\"; `String i ] ->\n Ok (Since_hard_fork (T.of_string i))\n | _ ->\n Error \"Global_slot.of_yojson: Expected `String\"\n end\n end]\n\n module T = T\n\n let sexp_of_t = Stable.Latest.sexp_of_t\n\n let t_of_sexp = Stable.Latest.t_of_sexp\n\n let to_yojson = Stable.Latest.to_yojson\n\n let of_yojson = Stable.Latest.of_yojson\n\n let to_uint32 (Since_hard_fork u32) : uint32 = u32\n\n let of_uint32 u32 : t = Since_hard_fork u32\n end\n\n include M\n include Global_slot.Make (M)\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","module T = Nat.Make32 ()\n\ninclude T\ninclude Codable.Make_of_string (T)\n","module T = Nat.Make32 ()\n\nmodule Wire_types = Mina_wire_types.Mina_numbers.Index\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include Nat.Intf.UInt32_A with type Stable.V1.t = A.V1.t\n end\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n include T\n\n let to_bits = Bits.to_bits\n\n let of_bits = Bits.of_bits\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","module T = Nat.Make32 ()\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Length\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include Nat.Intf.UInt32_A with type Stable.V1.t = A.V1.t\n end\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n include T\n\n let to_bits = Bits.to_bits\n\n let of_bits = Bits.of_bits\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","module Account_nonce = Account_nonce\nmodule Length = Length\nmodule Index = Index\nmodule Nat = Nat\nmodule Global_slot_legacy = Global_slot_legacy\nmodule Global_slot_since_genesis = Global_slot_since_genesis\nmodule Global_slot_since_hard_fork = Global_slot_since_hard_fork\nmodule Global_slot_span = Global_slot_span\nmodule Hd_index = Hd_index\nmodule Zkapp_version = Zkapp_version\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_bits\nopen Snark_params.Tick\n\ntype uint64 = Unsigned.uint64\n\nmodule type Basic = sig\n type t [@@deriving sexp, compare, hash, yojson]\n\n type magnitude = t [@@deriving sexp, compare]\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n\n val max_int : t\n\n val length_in_bits : int\n\n include Comparable.S with type t := t\n\n val gen_incl : t -> t -> t Quickcheck.Generator.t\n\n val gen : t Quickcheck.Generator.t\n\n include Bits_intf.Convertible_bits with type t := t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val to_input_legacy : t -> (_, bool) Random_oracle.Legacy.Input.t\n\n val zero : t\n\n val one : t\n\n val of_string : string -> t\n\n val to_string : t -> string\n\n val of_mina_string_exn : string -> t\n\n val to_mina_string : t -> string\n\n val to_uint64 : t -> uint64\n\n val of_uint64 : uint64 -> t\n\n (* The functions below are unsafe, because they could overflow or\n underflow. They perform appropriate checks to guard against this\n and either raise Currency_overflow exception or return None\n depending on the error-handling strategy.\n\n It is advisable to use nanomina and mina wherever possible and\n limit the use of _exn veriants to places where a fixed value is\n being converted and hence overflow cannot happen. *)\n val of_mina_int_exn : int -> t\n\n val of_nanomina_int_exn : int -> t\n\n val of_mina_int : int -> t option\n\n val of_nanomina_int : int -> t option\n\n val to_mina_int : t -> int\n\n val to_nanomina_int : t -> int\n\n [%%ifdef consensus_mechanism]\n\n type var\n\n val typ : (var, t) Typ.t\n\n val var_of_t : t -> var\n\n val var_to_bits :\n var -> Boolean.var Bitstring_lib.Bitstring.Lsb_first.t Checked.t\n\n val var_to_input : var -> Field.Var.t Random_oracle.Input.Chunked.t\n\n val var_to_input_legacy :\n var -> (Field.Var.t, Boolean.var) Random_oracle.Input.Legacy.t Checked.t\n\n val equal_var : var -> var -> Boolean.var Checked.t\n\n val pack_var : var -> Field.Var.t\n\n [%%endif]\nend\n\nmodule type Arithmetic_intf = sig\n type t\n\n val add : t -> t -> t option\n\n val add_flagged : t -> t -> t * [ `Overflow of bool ]\n\n val sub : t -> t -> t option\n\n val sub_flagged : t -> t -> t * [ `Underflow of bool ]\n\n val ( + ) : t -> t -> t option\n\n val ( - ) : t -> t -> t option\n\n val scale : t -> int -> t option\nend\n\nmodule type Signed_intf = sig\n type magnitude\n\n type signed_fee\n\n [%%ifdef consensus_mechanism]\n\n type magnitude_var\n\n [%%endif]\n\n type t = (magnitude, Sgn.t) Signed_poly.t\n [@@deriving sexp, hash, compare, equal, yojson]\n\n val gen : t Quickcheck.Generator.t\n\n val create : magnitude:magnitude -> sgn:Sgn.t -> t\n\n val sgn : t -> Sgn.t\n\n val magnitude : t -> magnitude\n\n val zero : t\n\n val is_zero : t -> bool\n\n val is_positive : t -> bool\n\n val is_negative : t -> bool\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val to_input_legacy : t -> (_, bool) Random_oracle.Legacy.Input.t\n\n val add : t -> t -> t option\n\n val add_flagged : t -> t -> t * [ `Overflow of bool ]\n\n val ( + ) : t -> t -> t option\n\n val negate : t -> t\n\n val of_unsigned : magnitude -> t\n\n val to_fee : t -> signed_fee\n\n val of_fee : signed_fee -> t\n\n [%%ifdef consensus_mechanism]\n\n type var (* = (magnitude_var, Sgn.var) Signed_poly.t *)\n\n val create_var : magnitude:magnitude_var -> sgn:Sgn.var -> var\n\n val typ : (var, t) Typ.t\n\n module Checked : sig\n type signed_fee_var\n\n val constant : t -> var\n\n val of_unsigned : magnitude_var -> var\n\n val sgn : var -> Sgn.var Checked.t\n\n val magnitude : var -> magnitude_var Checked.t\n\n val negate : var -> var\n\n val if_ : Boolean.var -> then_:var -> else_:var -> var Checked.t\n\n val to_input : var -> Field.Var.t Random_oracle.Input.Chunked.t Checked.t\n\n val to_input_legacy :\n var -> (_, Boolean.var) Random_oracle.Legacy.Input.t Checked.t\n\n val add : var -> var -> var Checked.t\n\n val add_flagged :\n var -> var -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val assert_equal : var -> var -> unit Checked.t\n\n val equal : var -> var -> Boolean.var Checked.t\n\n val ( + ) : var -> var -> var Checked.t\n\n val to_field_var : var -> Field.Var.t Checked.t\n\n val to_fee : var -> signed_fee_var\n\n val of_fee : signed_fee_var -> var\n\n type t = var\n end\n\n [%%endif]\nend\n\n[%%ifdef consensus_mechanism]\n\nmodule type Checked_arithmetic_intf = sig\n type value\n\n type var\n\n type t = var\n\n type signed_var\n\n val if_ : Boolean.var -> then_:var -> else_:var -> var Checked.t\n\n val add : var -> var -> var Checked.t\n\n val sub : var -> var -> var Checked.t\n\n val sub_flagged :\n var -> var -> (var * [ `Underflow of Boolean.var ]) Checked.t\n\n val sub_or_zero : var -> var -> var Checked.t\n\n val add_flagged : var -> var -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val ( + ) : var -> var -> var Checked.t\n\n val ( - ) : var -> var -> var Checked.t\n\n val add_signed : var -> signed_var -> var Checked.t\n\n val add_signed_flagged :\n var -> signed_var -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val assert_equal : var -> var -> unit Checked.t\n\n val equal : var -> var -> Boolean.var Checked.t\n\n val ( = ) : t -> t -> Boolean.var Checked.t\n\n val ( < ) : t -> t -> Boolean.var Checked.t\n\n val ( > ) : t -> t -> Boolean.var Checked.t\n\n val ( <= ) : t -> t -> Boolean.var Checked.t\n\n val ( >= ) : t -> t -> Boolean.var Checked.t\n\n val scale : Field.Var.t -> var -> var Checked.t\nend\n\n[%%endif]\n\nmodule type S = sig\n include Basic\n\n include Arithmetic_intf with type t := t\n\n [%%ifdef consensus_mechanism]\n\n module Signed :\n Signed_intf with type magnitude := t and type magnitude_var := var\n\n module Checked :\n Checked_arithmetic_intf\n with type var := var\n and type signed_var := Signed.var\n and type value := t\n\n [%%else]\n\n module Signed : Signed_intf with type magnitude := t\n\n [%%endif]\n\n val add_signed_flagged : t -> Signed.t -> t * [ `Overflow of bool ]\nend\n\nmodule type Full = sig\n [%%ifdef consensus_mechanism]\n\n open Snark_params.Tick\n\n module Signed_var : sig\n type 'mag repr = ('mag, Sgn.var) Signed_poly.t\n\n (* Invariant: At least one of these is Some *)\n type nonrec 'mag t =\n { repr : 'mag repr; mutable value : Field.Var.t option }\n end\n\n [%%endif]\n\n module Signed_poly = Signed_poly\n\n module Fee : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t [@@deriving sexp, compare, hash, yojson, equal]\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n end\n end]\n\n include Basic with type t := Stable.Latest.t\n\n include Arithmetic_intf with type t := t\n\n include Codable.S with type t := t\n\n val minimum_user_command_fee : t\n\n val default_transaction_fee : t\n\n val default_snark_worker_fee : t\n\n (* TODO: Get rid of signed fee, use signed amount *)\n [%%ifdef consensus_mechanism]\n\n module Signed :\n Signed_intf\n with type magnitude := t\n and type magnitude_var := var\n and type signed_fee := (t, Sgn.t) Signed_poly.t\n and type Checked.signed_fee_var := Field.Var.t Signed_var.t\n\n [%%else]\n\n module Signed :\n Signed_intf\n with type magnitude := t\n and type signed_fee := (t, Sgn.t) Signed_poly.t\n\n [%%endif]\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n include\n Checked_arithmetic_intf\n with type var := var\n and type signed_var := Signed.var\n and type value := t\n\n val add_signed : var -> Signed.var -> var Checked.t\n end\n\n [%%endif]\n end\n [@@warning \"-32\"]\n\n module Amount : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t [@@deriving sexp, compare, hash, equal, yojson]\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n end\n end]\n\n include Basic with type t := Stable.Latest.t\n\n include Arithmetic_intf with type t := t\n\n include Codable.S with type t := t\n\n [%%ifdef consensus_mechanism]\n\n module Signed :\n Signed_intf\n with type magnitude := t\n and type magnitude_var := var\n and type signed_fee := Fee.Signed.t\n and type Checked.signed_fee_var := Fee.Signed.Checked.t\n\n [%%else]\n\n module Signed :\n Signed_intf with type magnitude := t and type signed_fee := Fee.Signed.t\n\n [%%endif]\n\n (* TODO: Delete these functions *)\n\n val of_fee : Fee.t -> t\n\n val to_fee : t -> Fee.t\n\n val add_fee : t -> Fee.t -> t option\n\n val add_signed_flagged : t -> Signed.t -> t * [ `Overflow of bool ]\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n include\n Checked_arithmetic_intf\n with type var := var\n and type signed_var := Signed.var\n and type value := t\n\n val add_signed : var -> Signed.var -> var Checked.t\n\n val add_signed_flagged :\n var -> Signed.var -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val of_fee : Fee.var -> var\n\n val to_fee : var -> Fee.var\n\n val to_field : var -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> t\n end\n end\n\n [%%endif]\n end\n [@@warning \"-32\"]\n\n module Balance : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving sexp, compare, hash, yojson, equal]\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n end\n end]\n\n include Basic with type t := Stable.Latest.t\n\n val to_amount : t -> Amount.t\n\n val add_amount : t -> Amount.t -> t option\n\n val add_amount_flagged : t -> Amount.t -> t * [ `Overflow of bool ]\n\n val sub_amount : t -> Amount.t -> t option\n\n val sub_amount_flagged : t -> Amount.t -> t * [ `Underflow of bool ]\n\n val add_signed_amount_flagged :\n t -> Amount.Signed.t -> t * [ `Overflow of bool ]\n\n val ( + ) : t -> Amount.t -> t option\n\n val ( - ) : t -> Amount.t -> t option\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n type t = var\n\n val to_amount : t -> Amount.var\n\n val add_signed_amount : var -> Amount.Signed.var -> var Checked.t\n\n val add_amount : var -> Amount.var -> var Checked.t\n\n val sub_amount : var -> Amount.var -> var Checked.t\n\n val sub_amount_flagged :\n var -> Amount.var -> (var * [ `Underflow of Boolean.var ]) Checked.t\n\n val add_amount_flagged :\n var -> Amount.var -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val add_signed_amount_flagged :\n var\n -> Amount.Signed.var\n -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val sub_or_zero : var -> var -> var Checked.t\n\n val sub_amount_or_zero : var -> Amount.var -> var Checked.t\n\n val ( + ) : var -> Amount.var -> var Checked.t\n\n val ( - ) : var -> Amount.var -> var Checked.t\n\n val equal : var -> var -> Boolean.var Checked.t\n\n val ( = ) : var -> var -> Boolean.var Checked.t\n\n val ( < ) : var -> var -> Boolean.var Checked.t\n\n val ( > ) : var -> var -> Boolean.var Checked.t\n\n val ( <= ) : var -> var -> Boolean.var Checked.t\n\n val ( >= ) : var -> var -> Boolean.var Checked.t\n\n val if_ : Boolean.var -> then_:var -> else_:var -> var Checked.t\n\n val to_field : var -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> var\n end\n end\n\n [%%endif]\n end\n [@@warning \"-32\"]\n\n module Fee_rate : sig\n type t\n\n include Arithmetic_intf with type t := t\n\n include Comparable.S with type t := t\n\n include Sexpable.S with type t := t\n\n val of_q : Q.t -> t option\n\n val of_q_exn : Q.t -> t\n\n val to_q : t -> Q.t\n\n (** construct a fee rate from a fee and a weight *)\n val make : Fee.t -> int -> t option\n\n (** construct a fee rate from a fee and a weight *)\n val make_exn : Fee.t -> int -> t\n\n (** convert to uint64, if the fee rate is equivalent to an integer. *)\n val to_uint64 : t -> uint64 option\n\n (** convert to uint64, if the fee rate is equivalent to an integer. *)\n val to_uint64_exn : t -> uint64\n\n val mul : t -> t -> t option\n\n val scale_exn : t -> int -> t\n\n val div : t -> t -> t option\n\n val ( * ) : t -> t -> t option\n end\nend\n","(*\n RE - A regular expression library\n\n Copyright (C) 2001 Jerome Vouillon\n email: Jerome.Vouillon@pps.jussieu.fr\n\n This library is free software; you can redistribute it and/or\n modify it under the terms of the GNU Lesser General Public\n License as published by the Free Software Foundation, with\n linking exception; either version 2.1 of the License, or (at\n your option) any later version.\n\n This library is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\n Lesser General Public License for more details.\n\n You should have received a copy of the GNU Lesser General Public\n License along with this library; if not, write to the Free Software\n Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA\n*)\n\nlet rec iter n f v = if n = 0 then v else iter (n - 1) f (f v)\n\n(****)\n\nlet unknown = -2\nlet break = -3\n\ntype match_info =\n | Match of Group.t\n | Failed\n | Running\n\ntype state =\n { idx : int;\n (* Index of the current position in the position table.\n Not yet computed transitions point to a dummy state where\n [idx] is set to [unknown];\n If [idx] is set to [break] for states that either always\n succeed or always fail. *)\n real_idx : int;\n (* The real index, in case [idx] is set to [break] *)\n next : state array;\n (* Transition table, indexed by color *)\n mutable final :\n (Category.t *\n (Automata.idx * Automata.status)) list;\n (* Mapping from the category of the next character to\n - the index where the next position should be saved\n - possibly, the list of marks (and the corresponding indices)\n corresponding to the best match *)\n desc : Automata.State.t\n (* Description of this state of the automata *) }\n\n(* Automata (compiled regular expression) *)\ntype re =\n { initial : Automata.expr;\n (* The whole regular expression *)\n mutable initial_states : (Category.t * state) list;\n (* Initial states, indexed by initial category *)\n colors : Bytes.t;\n (* Color table *)\n color_repr : Bytes.t;\n (* Table from colors to one character of this color *)\n ncolor : int;\n (* Number of colors. *)\n lnl : int;\n (* Color of the last newline. -1 if unnecessary *)\n tbl : Automata.working_area;\n (* Temporary table used to compute the first available index\n when computing a new state *)\n states : state Automata.State.Table.t;\n (* States of the deterministic automata *)\n group_count : int\n (* Number of groups in the regular expression *) }\n\nlet pp_re ch re = Automata.pp ch re.initial\n\nlet print_re = pp_re\n\n(* Information used during matching *)\ntype info =\n { re : re;\n (* The automata *)\n colors : Bytes.t;\n (* Color table ([x.colors = x.re.colors])\n Shortcut used for performance reasons *)\n mutable positions : int array;\n (* Array of mark positions\n The mark are off by one for performance reasons *)\n pos : int;\n (* Position where the match is started *)\n last : int\n (* Position where the match should stop *) }\n\n\n(****)\n\nlet category re ~color =\n if color = -1 then\n Category.inexistant\n (* Special category for the last newline *)\n else if color = re.lnl then\n Category.(lastnewline ++ newline ++ not_letter)\n else\n Category.from_char (Bytes.get re.color_repr color)\n\n(****)\n\nlet dummy_next = [||]\n\nlet unknown_state =\n { idx = unknown; real_idx = 0;\n next = dummy_next; final = [];\n desc = Automata.State.dummy }\n\nlet mk_state ncol desc =\n let break_state =\n match Automata.status desc with\n | Automata.Running -> false\n | Automata.Failed\n | Automata.Match _ -> true\n in\n { idx = if break_state then break else desc.Automata.State.idx;\n real_idx = desc.Automata.State.idx;\n next = if break_state then dummy_next else Array.make ncol unknown_state;\n final = [];\n desc }\n\nlet find_state re desc =\n try\n Automata.State.Table.find re.states desc\n with Not_found ->\n let st = mk_state re.ncolor desc in\n Automata.State.Table.add re.states desc st;\n st\n\n(**** Match with marks ****)\n\nlet delta info cat ~color st =\n let desc = Automata.delta info.re.tbl cat color st.desc in\n let len = Array.length info.positions in\n if desc.Automata.State.idx = len && len > 0 then begin\n let pos = info.positions in\n info.positions <- Array.make (2 * len) 0;\n Array.blit pos 0 info.positions 0 len\n end;\n desc\n\nlet validate info (s:string) ~pos st =\n let color = Char.code (Bytes.get info.colors (Char.code s.[pos])) in\n let cat = category info.re ~color in\n let desc' = delta info cat ~color st in\n let st' = find_state info.re desc' in\n st.next.(color) <- st'\n\n(*\nlet rec loop info s pos st =\n if pos < info.last then\n let st' = st.next.(Char.code info.cols.[Char.code s.[pos]]) in\n let idx = st'.idx in\n if idx >= 0 then begin\n info.positions.(idx) <- pos;\n loop info s (pos + 1) st'\n end else if idx = break then begin\n info.positions.(st'.real_idx) <- pos;\n st'\n end else begin (* Unknown *)\n validate info s pos st;\n loop info s pos st\n end\n else\n st\n*)\n\nlet rec loop info (s:string) ~pos st =\n if pos < info.last then\n let st' = st.next.(Char.code (Bytes.get info.colors (Char.code s.[pos]))) in\n loop2 info s ~pos st st'\n else\n st\n\nand loop2 info s ~pos st st' =\n if st'.idx >= 0 then begin\n let pos = pos + 1 in\n if pos < info.last then begin\n (* It is important to place these reads before the write *)\n (* But then, we don't have enough registers left to store the\n right position. So, we store the position plus one. *)\n let st'' =\n st'.next.(Char.code (Bytes.get info.colors (Char.code s.[pos]))) in\n info.positions.(st'.idx) <- pos;\n loop2 info s ~pos st' st''\n end else begin\n info.positions.(st'.idx) <- pos;\n st'\n end\n end else if st'.idx = break then begin\n info.positions.(st'.real_idx) <- pos + 1;\n st'\n end else begin (* Unknown *)\n validate info s ~pos st;\n loop info s ~pos st\n end\n\nlet rec loop_no_mark info s ~pos ~last st =\n if pos < last then\n let st' = st.next.(Char.code (Bytes.get info.colors (Char.code s.[pos]))) in\n if st'.idx >= 0 then\n loop_no_mark info s ~pos:(pos + 1) ~last st'\n else if st'.idx = break then\n st'\n else begin (* Unknown *)\n validate info s ~pos st;\n loop_no_mark info s ~pos ~last st\n end\n else\n st\n\nlet final info st cat =\n try\n List.assq cat st.final\n with Not_found ->\n let st' = delta info cat ~color:(-1) st in\n let res = (st'.Automata.State.idx, Automata.status st') in\n st.final <- (cat, res) :: st.final;\n res\n\nlet find_initial_state re cat =\n try\n List.assq cat re.initial_states\n with Not_found ->\n let st = find_state re (Automata.State.create cat re.initial) in\n re.initial_states <- (cat, st) :: re.initial_states;\n st\n\nlet get_color re (s:string) pos =\n if pos < 0 then\n -1\n else\n let slen = String.length s in\n if pos >= slen then\n -1\n else if pos = slen - 1 && re.lnl <> -1 && s.[pos] = '\\n' then\n (* Special case for the last newline *)\n re.lnl\n else\n Char.code (Bytes.get re.colors (Char.code s.[pos]))\n\nlet rec handle_last_newline info ~pos st ~groups =\n let st' = st.next.(info.re.lnl) in\n if st'.idx >= 0 then begin\n if groups then info.positions.(st'.idx) <- pos + 1;\n st'\n end else if st'.idx = break then begin\n if groups then info.positions.(st'.real_idx) <- pos + 1;\n st'\n end else begin (* Unknown *)\n let color = info.re.lnl in\n let real_c = Char.code (Bytes.get info.colors (Char.code '\\n')) in\n let cat = category info.re ~color in\n let desc' = delta info cat ~color:real_c st in\n let st' = find_state info.re desc' in\n st.next.(color) <- st';\n handle_last_newline info ~pos st ~groups\n end\n\nlet rec scan_str info (s:string) initial_state ~groups =\n let pos = info.pos in\n let last = info.last in\n if (last = String.length s\n && info.re.lnl <> -1\n && last > pos\n && String.get s (last - 1) = '\\n')\n then begin\n let info = { info with last = last - 1 } in\n let st = scan_str info s initial_state ~groups in\n if st.idx = break then\n st\n else\n handle_last_newline info ~pos:(last - 1) st ~groups\n end else if groups then\n loop info s ~pos initial_state\n else\n loop_no_mark info s ~pos ~last initial_state\n\nlet match_str ~groups ~partial re s ~pos ~len =\n let slen = String.length s in\n let last = if len = -1 then slen else pos + len in\n let info =\n { re ; colors = re.colors; pos ; last\n ; positions =\n if groups then begin\n let n = Automata.index_count re.tbl + 1 in\n if n <= 10 then\n [|0;0;0;0;0;0;0;0;0;0|]\n else\n Array.make n 0\n end else\n [||] }\n in\n let initial_cat =\n if pos = 0 then\n Category.(search_boundary ++ inexistant)\n else\n Category.(search_boundary\n ++ category re ~color:(get_color re s (pos - 1)))\n in\n let initial_state = find_initial_state re initial_cat in\n let st = scan_str info s initial_state ~groups in\n let res =\n if st.idx = break || partial then\n Automata.status st.desc\n else\n let final_cat =\n if last = slen then\n Category.(search_boundary ++ inexistant)\n else\n Category.(search_boundary ++ category re ~color:(get_color re s last))\n in\n let (idx, res) = final info st final_cat in\n if groups then info.positions.(idx) <- last + 1;\n res\n in\n match res with\n Automata.Match (marks, pmarks) ->\n Match { s ; marks; pmarks ; gpos = info.positions; gcount = re.group_count}\n | Automata.Failed -> Failed\n | Automata.Running -> Running\n\nlet mk_re ~initial ~colors ~color_repr ~ncolor ~lnl ~group_count =\n { initial ;\n initial_states = [];\n colors;\n color_repr;\n ncolor;\n lnl;\n tbl = Automata.create_working_area ();\n states = Automata.State.Table.create 97;\n group_count }\n\n(**** Character sets ****)\n\nlet cseq c c' = Cset.seq (Char.code c) (Char.code c')\nlet cadd c s = Cset.add (Char.code c) s\n\nlet trans_set cache cm s =\n match Cset.one_char s with\n | Some i -> Cset.csingle (Bytes.get cm i)\n | None ->\n let v = (Cset.hash_rec s, s) in\n try\n Cset.CSetMap.find v !cache\n with Not_found ->\n let l =\n Cset.fold_right\n s\n ~f:(fun (i, j) l -> Cset.union (cseq (Bytes.get cm i)\n (Bytes.get cm j)) l)\n ~init:Cset.empty\n in\n cache := Cset.CSetMap.add v l !cache;\n l\n\n(****)\n\ntype regexp =\n Set of Cset.t\n | Sequence of regexp list\n | Alternative of regexp list\n | Repeat of regexp * int * int option\n | Beg_of_line | End_of_line\n | Beg_of_word | End_of_word | Not_bound\n | Beg_of_str | End_of_str\n | Last_end_of_line | Start | Stop\n | Sem of Automata.sem * regexp\n | Sem_greedy of Automata.rep_kind * regexp\n | Group of regexp | No_group of regexp | Nest of regexp\n | Case of regexp | No_case of regexp\n | Intersection of regexp list\n | Complement of regexp list\n | Difference of regexp * regexp\n | Pmark of Pmark.t * regexp\n\nmodule View = struct\n type t = regexp =\n Set of Cset.t\n | Sequence of regexp list\n | Alternative of regexp list\n | Repeat of regexp * int * int option\n | Beg_of_line | End_of_line\n | Beg_of_word | End_of_word | Not_bound\n | Beg_of_str | End_of_str\n | Last_end_of_line | Start | Stop\n | Sem of Automata.sem * regexp\n | Sem_greedy of Automata.rep_kind * regexp\n | Group of regexp | No_group of regexp | Nest of regexp\n | Case of regexp | No_case of regexp\n | Intersection of regexp list\n | Complement of regexp list\n | Difference of regexp * regexp\n | Pmark of Pmark.t * regexp\n\n let view t = t\nend\n\nlet rec pp fmt t =\n let open Fmt in\n let var s re = sexp fmt s pp re in\n let seq s rel = sexp fmt s (list pp) rel in\n match t with\n | Set s -> sexp fmt \"Set\" Cset.pp s\n | Sequence sq -> seq \"Sequence\" sq\n | Alternative alt -> seq \"Alternative\" alt\n | Repeat (re, start, stop) ->\n let pp' fmt () = fprintf fmt \"%a@ %d%a\" pp re start optint stop in\n sexp fmt \"Repeat\" pp' ()\n | Beg_of_line -> str fmt \"Beg_of_line\"\n | End_of_line -> str fmt \"End_of_line\"\n | Beg_of_word -> str fmt \"Beg_of_word\"\n | End_of_word -> str fmt \"End_of_word\"\n | Not_bound -> str fmt \"Not_bound\"\n | Beg_of_str -> str fmt \"Beg_of_str\"\n | End_of_str -> str fmt \"End_of_str\"\n | Last_end_of_line -> str fmt \"Last_end_of_line\"\n | Start -> str fmt \"Start\"\n | Stop -> str fmt \"Stop\"\n | Sem (sem, re) ->\n sexp fmt \"Sem\" (pair Automata.pp_sem pp) (sem, re)\n | Sem_greedy (k, re) ->\n sexp fmt \"Sem_greedy\" (pair Automata.pp_rep_kind pp) (k, re)\n | Group c -> var \"Group\" c\n | No_group c -> var \"No_group\" c\n | Nest c -> var \"Nest\" c\n | Case c -> var \"Case\" c\n | No_case c -> var \"No_case\" c\n | Intersection c -> seq \"Intersection\" c\n | Complement c -> seq \"Complement\" c\n | Difference (a, b) -> sexp fmt \"Difference\" (pair pp pp) (a, b)\n | Pmark (m, r) -> sexp fmt \"Pmark\" (pair Pmark.pp pp) (m, r)\n\nlet rec is_charset = function\n | Set _ ->\n true\n | Alternative l | Intersection l | Complement l ->\n List.for_all is_charset l\n | Difference (r, r') ->\n is_charset r && is_charset r'\n | Sem (_, r) | Sem_greedy (_, r)\n | No_group r | Case r | No_case r ->\n is_charset r\n | Sequence _ | Repeat _ | Beg_of_line | End_of_line\n | Beg_of_word | End_of_word | Beg_of_str | End_of_str\n | Not_bound | Last_end_of_line | Start | Stop\n | Group _ | Nest _ | Pmark (_,_)->\n false\n\n(*XXX Use a better algorithm allowing non-contiguous regions? *)\n\nlet cupper =\n Cset.union (cseq 'A' 'Z')\n (Cset.union (cseq '\\192' '\\214') (cseq '\\216' '\\222'))\nlet clower = Cset.offset 32 cupper\nlet calpha =\n List.fold_right cadd ['\\170'; '\\181'; '\\186'; '\\223'; '\\255']\n (Cset.union clower cupper)\nlet cdigit = cseq '0' '9'\nlet calnum = Cset.union calpha cdigit\nlet cword = cadd '_' calnum\n\nlet colorize c regexp =\n let lnl = ref false in\n let rec colorize regexp =\n match regexp with\n Set s -> Color_map.split s c\n | Sequence l -> List.iter colorize l\n | Alternative l -> List.iter colorize l\n | Repeat (r, _, _) -> colorize r\n | Beg_of_line | End_of_line -> Color_map.split (Cset.csingle '\\n') c\n | Beg_of_word | End_of_word\n | Not_bound -> Color_map.split cword c\n | Beg_of_str | End_of_str\n | Start | Stop -> ()\n | Last_end_of_line -> lnl := true\n | Sem (_, r)\n | Sem_greedy (_, r)\n | Group r | No_group r\n | Nest r | Pmark (_,r) -> colorize r\n | Case _ | No_case _\n | Intersection _\n | Complement _\n | Difference _ -> assert false\n in\n colorize regexp;\n !lnl\n\n(**** Compilation ****)\n\nlet rec equal x1 x2 =\n match x1, x2 with\n Set s1, Set s2 ->\n s1 = s2\n | Sequence l1, Sequence l2 ->\n eq_list l1 l2\n | Alternative l1, Alternative l2 ->\n eq_list l1 l2\n | Repeat (x1', i1, j1), Repeat (x2', i2, j2) ->\n i1 = i2 && j1 = j2 && equal x1' x2'\n | Beg_of_line, Beg_of_line\n | End_of_line, End_of_line\n | Beg_of_word, Beg_of_word\n | End_of_word, End_of_word\n | Not_bound, Not_bound\n | Beg_of_str, Beg_of_str\n | End_of_str, End_of_str\n | Last_end_of_line, Last_end_of_line\n | Start, Start\n | Stop, Stop ->\n true\n | Sem (sem1, x1'), Sem (sem2, x2') ->\n sem1 = sem2 && equal x1' x2'\n | Sem_greedy (k1, x1'), Sem_greedy (k2, x2') ->\n k1 = k2 && equal x1' x2'\n | Group _, Group _ -> (* Do not merge groups! *)\n false\n | No_group x1', No_group x2' ->\n equal x1' x2'\n | Nest x1', Nest x2' ->\n equal x1' x2'\n | Case x1', Case x2' ->\n equal x1' x2'\n | No_case x1', No_case x2' ->\n equal x1' x2'\n | Intersection l1, Intersection l2 ->\n eq_list l1 l2\n | Complement l1, Complement l2 ->\n eq_list l1 l2\n | Difference (x1', x1''), Difference (x2', x2'') ->\n equal x1' x2' && equal x1'' x2''\n | Pmark (m1, r1), Pmark (m2, r2) ->\n Pmark.equal m1 m2 && equal r1 r2\n | _ ->\n false\n\nand eq_list l1 l2 =\n match l1, l2 with\n [], [] ->\n true\n | x1 :: r1, x2 :: r2 ->\n equal x1 x2 && eq_list r1 r2\n | _ ->\n false\n\nlet sequence = function\n | [x] -> x\n | l -> Sequence l\n\nlet rec merge_sequences = function\n | [] ->\n []\n | Alternative l' :: r ->\n merge_sequences (l' @ r)\n | Sequence (x :: y) :: r ->\n begin match merge_sequences r with\n Sequence (x' :: y') :: r' when equal x x' ->\n Sequence [x; Alternative [sequence y; sequence y']] :: r'\n | r' ->\n Sequence (x :: y) :: r'\n end\n | x :: r ->\n x :: merge_sequences r\n\nmodule A = Automata\n\nlet enforce_kind ids kind kind' cr =\n match kind, kind' with\n `First, `First -> cr\n | `First, k -> A.seq ids k cr (A.eps ids)\n | _ -> cr\n\n(* XXX should probably compute a category mask *)\nlet rec translate ids kind ign_group ign_case greedy pos cache c = function\n | Set s ->\n (A.cst ids (trans_set cache c s), kind)\n | Sequence l ->\n (trans_seq ids kind ign_group ign_case greedy pos cache c l, kind)\n | Alternative l ->\n begin match merge_sequences l with\n [r'] ->\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy pos cache c r' in\n (enforce_kind ids kind kind' cr, kind)\n | merged_sequences ->\n (A.alt ids\n (List.map\n (fun r' ->\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy\n pos cache c r' in\n enforce_kind ids kind kind' cr)\n merged_sequences),\n kind)\n end\n | Repeat (r', i, j) ->\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy pos cache c r' in\n let rem =\n match j with\n None ->\n A.rep ids greedy kind' cr\n | Some j ->\n let f =\n match greedy with\n `Greedy ->\n fun rem ->\n A.alt ids\n [A.seq ids kind' (A.rename ids cr) rem; A.eps ids]\n | `Non_greedy ->\n fun rem ->\n A.alt ids\n [A.eps ids; A.seq ids kind' (A.rename ids cr) rem]\n in\n iter (j - i) f (A.eps ids)\n in\n (iter i (fun rem -> A.seq ids kind' (A.rename ids cr) rem) rem, kind)\n | Beg_of_line ->\n (A.after ids Category.(inexistant ++ newline), kind)\n | End_of_line ->\n (A.before ids Category.(inexistant ++ newline), kind)\n | Beg_of_word ->\n (A.seq ids `First\n (A.after ids Category.(inexistant ++ not_letter))\n (A.before ids Category.(inexistant ++ letter)),\n kind)\n | End_of_word ->\n (A.seq ids `First\n (A.after ids Category.(inexistant ++ letter))\n (A.before ids Category.(inexistant ++ not_letter)),\n kind)\n | Not_bound ->\n (A.alt ids [A.seq ids `First\n (A.after ids Category.letter)\n (A.before ids Category.letter);\n A.seq ids `First\n (A.after ids Category.letter)\n (A.before ids Category.letter)],\n kind)\n | Beg_of_str ->\n (A.after ids Category.inexistant, kind)\n | End_of_str ->\n (A.before ids Category.inexistant, kind)\n | Last_end_of_line ->\n (A.before ids Category.(inexistant ++ lastnewline), kind)\n | Start ->\n (A.after ids Category.search_boundary, kind)\n | Stop ->\n (A.before ids Category.search_boundary, kind)\n | Sem (kind', r') ->\n let (cr, kind'') =\n translate ids kind' ign_group ign_case greedy pos cache c r' in\n (enforce_kind ids kind' kind'' cr,\n kind')\n | Sem_greedy (greedy', r') ->\n translate ids kind ign_group ign_case greedy' pos cache c r'\n | Group r' ->\n if ign_group then\n translate ids kind ign_group ign_case greedy pos cache c r'\n else\n let p = !pos in\n pos := !pos + 2;\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy pos cache c r' in\n (A.seq ids `First (A.mark ids p) (\n A.seq ids `First cr (A.mark ids (p + 1))),\n kind')\n | No_group r' ->\n translate ids kind true ign_case greedy pos cache c r'\n | Nest r' ->\n let b = !pos in\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy pos cache c r'\n in\n let e = !pos - 1 in\n if e < b then\n (cr, kind')\n else\n (A.seq ids `First (A.erase ids b e) cr, kind')\n | Difference _ | Complement _ | Intersection _ | No_case _ | Case _ ->\n assert false\n | Pmark (i, r') ->\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy pos cache c r' in\n (A.seq ids `First (A.pmark ids i) cr, kind')\n\nand trans_seq ids kind ign_group ign_case greedy pos cache c = function\n | [] ->\n A.eps ids\n | [r] ->\n let (cr', kind') =\n translate ids kind ign_group ign_case greedy pos cache c r in\n enforce_kind ids kind kind' cr'\n | r :: rem ->\n let (cr', kind') =\n translate ids kind ign_group ign_case greedy pos cache c r in\n let cr'' =\n trans_seq ids kind ign_group ign_case greedy pos cache c rem in\n if A.is_eps cr'' then\n cr'\n else if A.is_eps cr' then\n cr''\n else\n A.seq ids kind' cr' cr''\n\n(**** Case ****)\n\nlet case_insens s =\n Cset.union s (Cset.union (Cset.offset 32 (Cset.inter s cupper))\n (Cset.offset (-32) (Cset.inter s clower)))\n\nlet as_set = function\n | Set s -> s\n | _ -> assert false\n\n(* XXX Should split alternatives into (1) charsets and (2) more\n complex regular expressions; alternative should therefore probably\n be flatten here *)\nlet rec handle_case ign_case = function\n | Set s ->\n Set (if ign_case then case_insens s else s)\n | Sequence l ->\n Sequence (List.map (handle_case ign_case) l)\n | Alternative l ->\n let l' = List.map (handle_case ign_case) l in\n if is_charset (Alternative l') then\n Set (List.fold_left (fun s r -> Cset.union s (as_set r)) Cset.empty l')\n else\n Alternative l'\n | Repeat (r, i, j) ->\n Repeat (handle_case ign_case r, i, j)\n | Beg_of_line | End_of_line | Beg_of_word | End_of_word | Not_bound\n | Beg_of_str | End_of_str | Last_end_of_line | Start | Stop as r ->\n r\n | Sem (k, r) ->\n let r' = handle_case ign_case r in\n if is_charset r' then r' else Sem (k, r')\n | Sem_greedy (k, r) ->\n let r' = handle_case ign_case r in\n if is_charset r' then r' else Sem_greedy (k, r')\n | Group r ->\n Group (handle_case ign_case r)\n | No_group r ->\n let r' = handle_case ign_case r in\n if is_charset r' then r' else No_group r'\n | Nest r ->\n let r' = handle_case ign_case r in\n if is_charset r' then r' else Nest r'\n | Case r ->\n handle_case false r\n | No_case r ->\n handle_case true r\n | Intersection l ->\n let l' = List.map (fun r -> handle_case ign_case r) l in\n Set (List.fold_left (fun s r -> Cset.inter s (as_set r)) Cset.cany l')\n | Complement l ->\n let l' = List.map (fun r -> handle_case ign_case r) l in\n Set (Cset.diff Cset.cany\n (List.fold_left (fun s r -> Cset.union s (as_set r))\n Cset.empty l'))\n | Difference (r, r') ->\n Set (Cset.inter (as_set (handle_case ign_case r))\n (Cset.diff Cset.cany (as_set (handle_case ign_case r'))))\n | Pmark (i,r) -> Pmark (i,handle_case ign_case r)\n\n(****)\n\nlet compile_1 regexp =\n let regexp = handle_case false regexp in\n let c = Color_map.make () in\n let need_lnl = colorize c regexp in\n let (colors, color_repr, ncolor) = Color_map.flatten c in\n let lnl = if need_lnl then ncolor else -1 in\n let ncolor = if need_lnl then ncolor + 1 else ncolor in\n let ids = A.create_ids () in\n let pos = ref 0 in\n let (r, kind) =\n translate ids\n `First false false `Greedy pos (ref Cset.CSetMap.empty) colors regexp in\n let r = enforce_kind ids `First kind r in\n (*Format.eprintf \"<%d %d>@.\" !ids ncol;*)\n mk_re ~initial:r ~colors ~color_repr ~ncolor ~lnl ~group_count:(!pos / 2)\n\n(****)\n\nlet rec anchored = function\n | Sequence l ->\n List.exists anchored l\n | Alternative l ->\n List.for_all anchored l\n | Repeat (r, i, _) ->\n i > 0 && anchored r\n | Set _ | Beg_of_line | End_of_line | Beg_of_word | End_of_word\n | Not_bound | End_of_str | Last_end_of_line | Stop\n | Intersection _ | Complement _ | Difference _ ->\n false\n | Beg_of_str | Start ->\n true\n | Sem (_, r) | Sem_greedy (_, r) | Group r | No_group r | Nest r\n | Case r | No_case r | Pmark (_, r) ->\n anchored r\n\n(****)\n\ntype t = regexp\n\nlet str s =\n let l = ref [] in\n for i = String.length s - 1 downto 0 do\n l := Set (Cset.csingle s.[i]) :: !l\n done;\n Sequence !l\nlet char c = Set (Cset.csingle c)\n\nlet alt = function\n | [r] -> r\n | l -> Alternative l\nlet seq = function\n | [r] -> r\n | l -> Sequence l\n\nlet empty = alt []\nlet epsilon = seq []\nlet repn r i j =\n if i < 0 then invalid_arg \"Re.repn\";\n begin match j with\n | Some j when j < i -> invalid_arg \"Re.repn\"\n | _ -> ()\n end;\n Repeat (r, i, j)\nlet rep r = repn r 0 None\nlet rep1 r = repn r 1 None\nlet opt r = repn r 0 (Some 1)\nlet bol = Beg_of_line\nlet eol = End_of_line\nlet bow = Beg_of_word\nlet eow = End_of_word\nlet word r = seq [bow; r; eow]\nlet not_boundary = Not_bound\nlet bos = Beg_of_str\nlet eos = End_of_str\nlet whole_string r = seq [bos; r; eos]\nlet leol = Last_end_of_line\nlet start = Start\nlet stop = Stop\nlet longest r = Sem (`Longest, r)\nlet shortest r = Sem (`Shortest, r)\nlet first r = Sem (`First, r)\nlet greedy r = Sem_greedy (`Greedy, r)\nlet non_greedy r = Sem_greedy (`Non_greedy, r)\nlet group r = Group r\nlet no_group r = No_group r\nlet nest r = Nest r\nlet mark r = let i = Pmark.gen () in (i,Pmark (i,r))\n\nlet set str =\n let s = ref Cset.empty in\n for i = 0 to String.length str - 1 do\n s := Cset.union (Cset.csingle str.[i]) !s\n done;\n Set !s\n\nlet rg c c' = Set (cseq c c')\n\nlet inter l =\n let r = Intersection l in\n if is_charset r then\n r\n else\n invalid_arg \"Re.inter\"\n\nlet compl l =\n let r = Complement l in\n if is_charset r then\n r\n else\n invalid_arg \"Re.compl\"\n\nlet diff r r' =\n let r'' = Difference (r, r') in\n if is_charset r'' then\n r''\n else\n invalid_arg \"Re.diff\"\n\nlet any = Set Cset.cany\nlet notnl = Set (Cset.diff Cset.cany (Cset.csingle '\\n'))\n\nlet lower = alt [rg 'a' 'z'; char '\\181'; rg '\\223' '\\246'; rg '\\248' '\\255']\nlet upper = alt [rg 'A' 'Z'; rg '\\192' '\\214'; rg '\\216' '\\222']\nlet alpha = alt [lower; upper; char '\\170'; char '\\186']\nlet digit = rg '0' '9'\nlet alnum = alt [alpha; digit]\nlet wordc = alt [alnum; char '_']\nlet ascii = rg '\\000' '\\127'\nlet blank = set \"\\t \"\nlet cntrl = alt [rg '\\000' '\\031'; rg '\\127' '\\159']\nlet graph = alt [rg '\\033' '\\126'; rg '\\160' '\\255']\nlet print = alt [rg '\\032' '\\126'; rg '\\160' '\\255']\nlet punct =\n alt [rg '\\033' '\\047'; rg '\\058' '\\064'; rg '\\091' '\\096';\n rg '\\123' '\\126'; rg '\\160' '\\169'; rg '\\171' '\\180';\n rg '\\182' '\\185'; rg '\\187' '\\191'; char '\\215'; char '\\247']\nlet space = alt [char ' '; rg '\\009' '\\013']\nlet xdigit = alt [digit; rg 'a' 'f'; rg 'A' 'F']\n\nlet case r = Case r\nlet no_case r = No_case r\n\n(****)\n\nlet compile r =\n compile_1 (\n if anchored r then\n group r\n else\n seq [shortest (rep any); group r]\n )\n\nlet exec_internal name ?(pos=0) ?(len = -1) ~partial ~groups re s =\n if pos < 0 || len < -1 || pos + len > String.length s then\n invalid_arg name;\n match_str ~groups ~partial re s ~pos ~len\n\nlet exec ?pos ?len re s =\n match exec_internal \"Re.exec\" ?pos ?len ~groups:true ~partial:false re s with\n Match substr -> substr\n | _ -> raise Not_found\n\nlet exec_opt ?pos ?len re s =\n match exec_internal \"Re.exec_opt\" ?pos ?len ~groups:true ~partial:false\n re s with\n Match substr -> Some substr\n | _ -> None\n\nlet execp ?pos ?len re s =\n match exec_internal ~groups:false ~partial:false \"Re.execp\" ?pos ?len re s with\n Match _substr -> true\n | _ -> false\n\nlet exec_partial ?pos ?len re s =\n match exec_internal ~groups:false ~partial:true \"Re.exec_partial\"\n ?pos ?len re s with\n Match _ -> `Full\n | Running -> `Partial\n | Failed -> `Mismatch\n\nmodule Mark = struct\n\n type t = Pmark.t\n\n let test (g : Group.t) p =\n Pmark.Set.mem p g.pmarks\n\n let all (g : Group.t) = g.pmarks\n\n module Set = Pmark.Set\n\n let equal = Pmark.equal\n\n let compare = Pmark.compare\n\nend\n\ntype split_token =\n [ `Text of string\n | `Delim of Group.t\n ]\n\nmodule Rseq = struct\n let all ?(pos=0) ?len re s : _ Seq.t =\n if pos < 0 then invalid_arg \"Re.all\";\n (* index of the first position we do not consider.\n !pos < limit is an invariant *)\n let limit = match len with\n | None -> String.length s\n | Some l ->\n if l<0 || pos+l > String.length s then invalid_arg \"Re.all\";\n pos+l\n in\n (* iterate on matches. When a match is found, search for the next\n one just after its end *)\n let rec aux pos () =\n if pos >= limit\n then Seq.Nil (* no more matches *)\n else\n match match_str ~groups:true ~partial:false re s\n ~pos ~len:(limit - pos) with\n | Match substr ->\n let p1, p2 = Group.offset substr 0 in\n let pos = if p1=p2 then p2+1 else p2 in\n Seq.Cons (substr, aux pos)\n | Running\n | Failed -> Seq.Nil\n in\n aux pos\n\n let matches ?pos ?len re s : _ Seq.t =\n all ?pos ?len re s\n |> Seq.map (fun sub -> Group.get sub 0)\n\n let split_full ?(pos=0) ?len re s : _ Seq.t =\n if pos < 0 then invalid_arg \"Re.split\";\n let limit = match len with\n | None -> String.length s\n | Some l ->\n if l<0 || pos+l > String.length s then invalid_arg \"Re.split\";\n pos+l\n in\n (* i: start of delimited string\n pos: first position after last match of [re]\n limit: first index we ignore (!pos < limit is an invariant) *)\n let pos0 = pos in\n let rec aux state i pos () = match state with\n | `Idle when pos >= limit ->\n if i < limit then (\n let sub = String.sub s i (limit - i) in\n Seq.Cons (`Text sub, aux state (i+1) pos)\n ) else Seq.Nil\n | `Idle ->\n begin match match_str ~groups:true ~partial:false re s ~pos\n ~len:(limit - pos) with\n | Match substr ->\n let p1, p2 = Group.offset substr 0 in\n let pos = if p1=p2 then p2+1 else p2 in\n let old_i = i in\n let i = p2 in\n if p1 > pos0 then (\n (* string does not start by a delimiter *)\n let text = String.sub s old_i (p1 - old_i) in\n let state = `Yield (`Delim substr) in\n Seq.Cons (`Text text, aux state i pos)\n ) else Seq.Cons (`Delim substr, aux state i pos)\n | Running -> Seq.Nil\n | Failed ->\n if i < limit\n then (\n let text = String.sub s i (limit - i) in\n (* yield last string *)\n Seq.Cons (`Text text, aux state limit pos)\n ) else\n Seq.Nil\n end\n | `Yield x ->\n Seq.Cons (x, aux `Idle i pos)\n in\n aux `Idle pos pos\n\n let split ?pos ?len re s : _ Seq.t =\n let seq = split_full ?pos ?len re s in\n let rec filter seq () = match seq () with\n | Seq.Nil -> Seq.Nil\n | Seq.Cons (`Delim _, tl) -> filter tl ()\n | Seq.Cons (`Text s,tl) -> Seq.Cons (s, filter tl)\n in filter seq\nend\n\nmodule Rlist = struct\n let list_of_seq (s:'a Seq.t) : 'a list =\n Seq.fold_left (fun l x -> x :: l) [] s |> List.rev\n\n let all ?pos ?len re s = Rseq.all ?pos ?len re s |> list_of_seq\n\n let matches ?pos ?len re s = Rseq.matches ?pos ?len re s |> list_of_seq\n\n let split_full ?pos ?len re s = Rseq.split_full ?pos ?len re s |> list_of_seq\n\n let split ?pos ?len re s = Rseq.split ?pos ?len re s |> list_of_seq\nend\n\nmodule Gen = struct\n type 'a gen = unit -> 'a option\n let gen_of_seq (s:'a Seq.t) : 'a gen =\n let r = ref s in\n fun () -> match !r () with\n | Seq.Nil -> None\n | Seq.Cons (x, tl) ->\n r := tl;\n Some x\n\n let split ?pos ?len re s : _ gen =\n Rseq.split ?pos ?len re s |> gen_of_seq\n\n let split_full ?pos ?len re s : _ gen =\n Rseq.split_full ?pos ?len re s |> gen_of_seq\n\n let all ?pos ?len re s = Rseq.all ?pos ?len re s |> gen_of_seq\n\n let matches ?pos ?len re s = Rseq.matches ?pos ?len re s |> gen_of_seq\nend\n\nlet replace ?(pos=0) ?len ?(all=true) re ~f s =\n if pos < 0 then invalid_arg \"Re.replace\";\n let limit = match len with\n | None -> String.length s\n | Some l ->\n if l<0 || pos+l > String.length s then invalid_arg \"Re.replace\";\n pos+l\n in\n (* buffer into which we write the result *)\n let buf = Buffer.create (String.length s) in\n (* iterate on matched substrings. *)\n let rec iter pos =\n if pos < limit\n then\n match match_str ~groups:true ~partial:false re s ~pos ~len:(limit-pos) with\n | Match substr ->\n let p1, p2 = Group.offset substr 0 in\n (* add string between previous match and current match *)\n Buffer.add_substring buf s pos (p1-pos);\n (* what should we replace the matched group with? *)\n let replacing = f substr in\n Buffer.add_string buf replacing;\n if all then\n (* if we matched a non-char e.g. ^ we must manually advance by 1 *)\n iter (\n if p1=p2 then (\n (* a non char could be past the end of string. e.g. $ *)\n if p2 < limit then Buffer.add_char buf s.[p2];\n p2+1\n ) else\n p2)\n else\n Buffer.add_substring buf s p2 (limit-p2)\n | Running -> ()\n | Failed ->\n Buffer.add_substring buf s pos (limit-pos)\n in\n iter pos;\n Buffer.contents buf\n\nlet replace_string ?pos ?len ?all re ~by s =\n replace ?pos ?len ?all re s ~f:(fun _ -> by)\n\nlet witness t =\n let rec witness = function\n | Set c -> String.make 1 (Char.chr (Cset.pick c))\n | Sequence xs -> String.concat \"\" (List.map witness xs)\n | Alternative (x :: _) -> witness x\n | Alternative [] -> assert false\n | Repeat (r, from, _to) ->\n let w = witness r in\n let b = Buffer.create (String.length w * from) in\n for _i=1 to from do\n Buffer.add_string b w\n done;\n Buffer.contents b\n | No_case r -> witness r\n | Intersection _\n | Complement _\n | Difference (_, _) -> assert false\n | Group r\n | No_group r\n | Nest r\n | Sem (_, r)\n | Pmark (_, r)\n | Case r\n | Sem_greedy (_, r) -> witness r\n | Beg_of_line\n | End_of_line\n | Beg_of_word\n | End_of_word\n | Not_bound\n | Beg_of_str\n | Last_end_of_line\n | Start\n | Stop\n | End_of_str -> \"\" in\n witness (handle_case false t)\n\ntype 'a seq = 'a Seq.t\nmodule Seq = Rseq\nmodule List = Rlist\nmodule Group = Group\n\n(** {2 Deprecated functions} *)\n\ntype 'a gen = 'a Gen.gen\nlet all_gen = Gen.all\nlet matches_gen = Gen.matches\nlet split_gen = Gen.split\nlet split_full_gen = Gen.split_full\n\nlet all_seq = Seq.all\nlet matches_seq = Seq.matches\nlet split_seq = Seq.split\nlet split_full_seq = Seq.split_full\n\n\ntype substrings = Group.t\n\nlet get = Group.get\nlet get_ofs = Group.offset\nlet get_all = Group.all\nlet get_all_ofs = Group.all_offset\nlet test = Group.test\n\ntype markid = Mark.t\n\nlet marked = Mark.test\nlet mark_set = Mark.all\n\n(**********************************)\n\n(*\nInformation about the previous character:\n- does not exists\n- is a letter\n- is not a letter\n- is a newline\n- is last newline\n\nBeginning of word:\n- previous is not a letter or does not exist\n- current is a letter or does not exist\n\nEnd of word:\n- previous is a letter or does not exist\n- current is not a letter or does not exist\n\nBeginning of line:\n- previous is a newline or does not exist\n\nBeginning of buffer:\n- previous does not exist\n\nEnd of buffer\n- current does not exist\n\nEnd of line\n- current is a newline or does not exist\n*)\n\n(*\nRep: e = T,e | ()\n - semantics of the comma (shortest/longest/first)\n - semantics of the union (greedy/non-greedy)\n\nBounded repetition\n a{0,3} = (a,(a,a?)?)?\n*)\n\ntype groups = Group.t\n\ninclude Rlist\n","include Ast\n\nlet string_of_pos (pos : Lexing.position) =\n Format.sprintf \"Line %d col %d\" pos.pos_lnum (pos.pos_cnum - pos.pos_bol + 1)\n\nlet parse s =\n let lexbuf = Lexing.from_string s in\n try Ok (Parser.doc Lexer.token lexbuf) with\n | Parser.Error ->\n let pos = lexbuf.lex_start_p in\n Error (Format.sprintf \"%s: Syntax error\" (string_of_pos pos))\n | Lexer.Error msg ->\n let pos = lexbuf.lex_curr_p in\n Error (Format.sprintf \"%s: %s\" (string_of_pos pos) msg)\n","open Core_kernel\nopen Fieldslib\n\nmodule Js_layout = struct\n module Input = struct\n type 'a t =\n < js_layout : [> `Assoc of (string * Yojson.Safe.t) list ] ref ; .. >\n as\n 'a\n end\n\n module Accumulator = struct\n type field = { key : string; value : Yojson.Safe.t; docs : Yojson.Safe.t }\n\n let to_key ({ key; _ } : field) = `String key\n\n let to_entry ({ key; value; _ } : field) : string * Yojson.Safe.t =\n (key, value)\n\n let to_doc_entry ({ key; docs; _ } : field) : string * Yojson.Safe.t =\n (key, docs)\n\n type 'a t = < js_layout_accumulator : field option list ref ; .. > as 'a\n constraint 'a t = 'a Input.t\n end\n\n let docs (s : Fields_derivers.Annotations.Fields.T.t) : Yojson.Safe.t =\n match s.doc with Some t -> `String t | None -> `Null\n\n let add_field ~t_fields_annots t_field field (acc : _ Accumulator.t) :\n _ * _ Accumulator.t =\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let rest = !(acc#js_layout_accumulator) in\n let key =\n Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field)\n in\n let value = !(t_field#js_layout) in\n let new_field =\n if annotations.skip || !(t_field#skip) then None\n else Some Accumulator.{ key; value; docs = docs annotations }\n in\n acc#js_layout_accumulator := new_field :: rest ;\n ((fun _ -> failwith \"Unused\"), acc)\n\n let finish name ~t_toplevel_annots (_creator, obj) =\n let annotations =\n Fields_derivers.Annotations.Top.of_annots ~name t_toplevel_annots\n in\n let accumulator =\n List.filter_map ~f:Fn.id !(obj#js_layout_accumulator) |> List.rev\n in\n obj#js_layout :=\n `Assoc\n [ (\"type\", `String \"object\")\n ; (\"name\", `String annotations.name)\n ; ( \"docs\"\n , match annotations.doc with Some s -> `String s | None -> `Null )\n ; (\"keys\", `List (List.map ~f:Accumulator.to_key accumulator))\n ; (\"entries\", `Assoc (List.map ~f:Accumulator.to_entry accumulator))\n ; ( \"docEntries\"\n , `Assoc (List.map ~f:Accumulator.to_doc_entry accumulator) )\n ] ;\n obj\n\n type leaf_type =\n | String\n | Number\n | Null\n | Field\n | Bool\n | UInt32\n | UInt64\n | PublicKey\n | Sign\n | Custom of string\n\n let leaf_type_to_string = function\n | String ->\n \"string\"\n | Number ->\n \"number\"\n | Null ->\n \"null\"\n | Field ->\n \"Field\"\n | Bool ->\n \"Bool\"\n | UInt32 ->\n \"UInt32\"\n | UInt64 ->\n \"UInt64\"\n | PublicKey ->\n \"PublicKey\"\n | Sign ->\n \"Sign\"\n | Custom s ->\n s\n\n type option_type =\n | Flagged_option\n | Closed_interval of (string * string)\n | Or_undefined\n\n let leaf_type (s : leaf_type) =\n `Assoc [ (\"type\", `String (leaf_type_to_string s)) ]\n\n let of_layout layout obj =\n obj#js_layout := layout ;\n obj\n\n let skip obj =\n obj#skip := true ;\n obj#js_layout := leaf_type Null ;\n obj\n\n let int obj =\n obj#js_layout := leaf_type Number ;\n obj\n\n let string obj =\n obj#js_layout := leaf_type String ;\n obj\n\n let bool obj =\n obj#js_layout := leaf_type Bool ;\n obj\n\n let list ?static_length x obj : _ Input.t =\n let inner = !(x#js_layout) in\n let static_length =\n match static_length with Some length -> `Int length | None -> `Null\n in\n obj#js_layout :=\n `Assoc\n [ (\"type\", `String \"array\")\n ; (\"inner\", inner)\n ; (\"staticLength\", static_length)\n ] ;\n obj\n\n let record (entries : (string * 'a) list) (obj : _ Input.t) : _ Input.t =\n obj#js_layout :=\n `Assoc\n [ (\"type\", `String \"object\")\n ; (\"name\", `String \"Anonymous\")\n ; (\"docs\", `Null)\n ; (\"keys\", `List (List.map ~f:(fun (key, _) -> `String key) entries))\n ; ( \"entries\"\n , `Assoc (List.map ~f:(fun (key, inner) -> (key, inner)) entries) )\n ; ( \"docEntries\"\n , `Assoc (List.map ~f:(fun (key, _) -> (key, `String \"\")) entries) )\n ] ;\n obj\n\n let option x obj ~(js_type : option_type) : _ Input.t =\n let inner = !(x#js_layout) in\n let layout =\n match js_type with\n | Flagged_option ->\n `Assoc\n [ (\"type\", `String \"option\")\n ; (\"optionType\", `String \"flaggedOption\")\n ; (\"inner\", inner)\n ]\n | Closed_interval (min, max) ->\n `Assoc\n [ (\"type\", `String \"option\")\n ; (\"optionType\", `String \"closedInterval\")\n ; (\"rangeMin\", `String min)\n ; (\"rangeMax\", `String max)\n ; (\"inner\", inner)\n ]\n | Or_undefined ->\n `Assoc\n [ (\"type\", `String \"option\")\n ; (\"optionType\", `String \"orUndefined\")\n ; (\"inner\", inner)\n ]\n in\n obj#js_layout := layout ;\n obj\n\n let wrapped x obj =\n obj#js_layout := !(x#js_layout) ;\n obj\n\n let needs_custom_js ~name (x : _ Input.t) (obj : _ Input.t) =\n match !(obj#js_layout) with\n | `Assoc layout ->\n obj#js_layout :=\n `Assoc\n ( layout\n @ [ (\"checkedType\", !(x#js_layout))\n ; (\"checkedTypeName\", `String name)\n ] ) ;\n obj\n | _ ->\n failwith \"impossible\"\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_bits\n\n[%%endif]\n\nmodule type Data_hash_descriptor = sig\n val version_byte : char\n\n val description : string\nend\n\nmodule type Basic = sig\n type t = Field.t [@@deriving sexp, yojson]\n\n val to_decimal_string : t -> string\n\n val of_decimal_string : string -> t\n\n val to_bytes : t -> string\n\n [%%ifdef consensus_mechanism]\n\n val gen : t Quickcheck.Generator.t\n\n type var\n\n val var_to_hash_packed : var -> Random_oracle.Checked.Digest.t\n\n val var_to_input : var -> Field.Var.t Random_oracle.Input.Chunked.t\n\n val var_to_bits : var -> Boolean.var list Checked.t\n\n val typ : (var, t) Typ.t\n\n val assert_equal : var -> var -> unit Checked.t\n\n val equal_var : var -> var -> Boolean.var Checked.t\n\n val var_of_t : t -> var\n\n (* TODO : define bit ops using Random_oracle instead of Pedersen.Digest,\n move this outside of consensus_mechanism guard\n *)\n include Bits_intf.S with type t := t\n\n [%%endif]\n\n val to_base58_check : t -> string\n\n val of_base58_check : string -> t Base.Or_error.t\n\n val of_base58_check_exn : string -> t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\nend\n\nmodule type Full_size = sig\n include Basic\n\n include Comparable.S with type t := t\n\n include Hashable with type t := t\n\n [%%ifdef consensus_mechanism]\n\n val if_ : Boolean.var -> then_:var -> else_:var -> var Checked.t\n\n val var_of_hash_packed : Random_oracle.Checked.Digest.t -> var\n\n val var_to_field : var -> Random_oracle.Checked.Digest.t\n\n [%%endif]\n\n val of_hash : Field.t -> t\n\n val to_field : t -> Field.t\nend\n","module type S = sig\n open Async_kernel\n open Core_kernel\n open Snark_params\n open Snark_bits\n\n module Time : sig\n type t [@@deriving sexp, compare, yojson]\n\n val zero : t\n\n val max_value : t\n\n include Comparable.S with type t := t\n\n include Hashable.S with type t := t\n\n module Controller : sig\n type t [@@deriving sexp, equal, compare]\n\n val create : t -> t\n\n val basic : logger:Logger.t -> t\n\n (** Override the time offset set by the [MINA_TIME_OFFSET] environment\n variable for all block time controllers.\n [enable_setting_offset] must have been called first, and\n [disable_setting_offset] must not have been called, otherwise this\n raises a [Failure].\n *)\n val set_time_offset : Time.Span.t -> unit\n\n (** Get the current time offset, either from the [MINA_TIME_OFFSET]\n environment variable, or as last set by [set_time_offset].\n *)\n val get_time_offset : logger:Logger.t -> Time.Span.t\n\n (** Disallow setting the time offset. This should be run at every\n entrypoint which does not explicitly need to update the time offset.\n *)\n val disable_setting_offset : unit -> unit\n\n (** Allow setting the time offset. This may only be run if\n [disable_setting_offset] has not already been called, otherwise it will\n raise a [Failure].\n *)\n val enable_setting_offset : unit -> unit\n end\n\n [%%versioned:\n module Stable : sig\n [@@@no_toplevel_latest_type]\n\n module V1 : sig\n type nonrec t = t [@@deriving sexp, compare, equal, hash, yojson]\n\n include Hashable.S with type t := t\n end\n end]\n\n module Bits : Bits_intf.Convertible_bits with type t := t\n\n include\n Tick.Snarkable.Bits.Faithful\n with type Unpacked.value = t\n and type Packed.value = t\n and type Packed.var = private Tick.Field.Var.t\n\n val to_input : t -> Tick.Field.t Random_oracle_input.Chunked.t\n\n module Checked : sig\n open Snark_params.Tick\n\n type t\n\n val typ : (t, Stable.Latest.t) Typ.t\n\n val to_input : t -> Field.Var.t Random_oracle_input.Chunked.t\n\n val ( = ) : t -> t -> Boolean.var Checked.t\n\n val ( < ) : t -> t -> Boolean.var Checked.t\n\n val ( > ) : t -> t -> Boolean.var Checked.t\n\n val ( <= ) : t -> t -> Boolean.var Checked.t\n\n val ( >= ) : t -> t -> Boolean.var Checked.t\n\n val to_field : t -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> t\n end\n end\n\n module Span : sig\n type t [@@deriving sexp, compare, equal, yojson]\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving bin_io, equal, sexp, compare, hash, yojson, version]\n end\n end\n\n val of_time_span : Time.Span.t -> t\n\n val to_time_span : t -> Time.Span.t\n\n module Bits : Bits_intf.Convertible_bits with type t := t\n\n include\n Tick.Snarkable.Bits.Faithful\n with type Unpacked.value = t\n and type Packed.value = t\n\n val to_time_ns_span : t -> Core_kernel.Time_ns.Span.t\n\n val of_time_ns_span : Core_kernel.Time_ns.Span.t -> t\n\n val to_string_hum : t -> string\n\n val to_ms : t -> Int64.t\n\n val of_ms : Int64.t -> t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n\n val ( < ) : t -> t -> bool\n\n val ( > ) : t -> t -> bool\n\n val ( = ) : t -> t -> bool\n\n val ( <= ) : t -> t -> bool\n\n val ( >= ) : t -> t -> bool\n\n val min : t -> t -> t\n\n val zero : t\n\n val to_input : t -> Tick.Field.t Random_oracle_input.Chunked.t\n\n module Checked : sig\n type t\n\n val typ : (t, Stable.V1.t) Snark_params.Tick.Typ.t\n\n open Snark_params.Tick\n\n val to_input : t -> Tick.Field.Var.t Random_oracle_input.Chunked.t\n\n val to_field : t -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> t\n end\n end\n end\n\n val field_var_to_unpacked : Tick.Field.Var.t -> Unpacked.var Tick.Checked.t\n\n val diff_checked :\n Unpacked.var -> Unpacked.var -> Span.Unpacked.var Tick.Checked.t\n\n val unpacked_to_number : Span.Unpacked.var -> Tick.Number.t\n\n val add : t -> Span.t -> t\n\n val diff : t -> t -> Span.t\n\n val sub : t -> Span.t -> t\n\n val to_span_since_epoch : t -> Span.t\n\n val of_span_since_epoch : Span.t -> t\n\n val modulus : t -> Span.t -> Span.t\n\n val of_time : Time.t -> t\n\n val to_time_exn : t -> Time.t\n\n val now : Controller.t -> t\n\n val to_int64 : t -> Int64.t\n\n val of_int64 : Int64.t -> t\n\n val of_uint64 : Unsigned.UInt64.t -> t\n\n val to_uint64 : t -> Unsigned.UInt64.t\n\n val of_time_ns : Time_ns.t -> t\n\n val to_string_exn : t -> string\n\n (** Strip time offset *)\n val to_string_system_time_exn : Controller.t -> t -> string\n\n (** Strip time offset *)\n val to_system_time : Controller.t -> t -> t\n\n val of_string_exn : string -> t\n\n val gen_incl : t -> t -> t Quickcheck.Generator.t\n\n val gen : t Quickcheck.Generator.t\n end\n\n include module type of Time with type t = Time.t\n\n module Timeout : sig\n type 'a t\n\n type time\n\n val create : Controller.t -> Span.t -> f:(time -> 'a) -> 'a t\n\n val to_deferred : 'a t -> 'a Async_kernel.Deferred.t\n\n val peek : 'a t -> 'a option\n\n val cancel : Controller.t -> 'a t -> 'a -> unit\n\n val remaining_time : 'a t -> Span.t\n\n val await :\n timeout_duration:Span.t\n -> Controller.t\n -> 'a Deferred.t\n -> [ `Ok of 'a | `Timeout ] Deferred.t\n\n val await_exn :\n timeout_duration:Span.t -> Controller.t -> 'a Deferred.t -> 'a Deferred.t\n end\n with type time := t\nend\n","(* quickcheck_lib.ml *)\n\nopen Core_kernel\nopen Quickcheck.Generator\nopen Quickcheck.Let_syntax\n\nlet of_array array = Quickcheck.Generator.of_list @@ Array.to_list array\n\nlet rec map_gens ls ~f =\n match ls with\n | [] ->\n return []\n | h :: t ->\n let%bind h' = f h in\n let%map t' = map_gens t ~f in\n h' :: t'\n\nlet replicate_gen g n = map_gens (List.init n ~f:Fn.id) ~f:(Fn.const g)\n\nlet init_gen ~f n =\n let rec go : 'a list -> int -> 'a list Quickcheck.Generator.t =\n fun xs n' ->\n if n' < n then f n' >>= fun x -> go (x :: xs) (n' + 1)\n else return @@ List.rev xs\n in\n go [] 0\n\nlet init_gen_array ~f n = map ~f:Array.of_list @@ init_gen ~f n\n\nlet gen_pair g =\n let%map a = g and b = g in\n (a, b)\n\nlet shuffle_arr_inplace arr =\n (* Fisher-Yates shuffle, you need fast swaps for decent performance, so we\n want an array if we're not getting unnecessarily fancy. *)\n let rec go n =\n if n < Array.length arr then (\n let%bind swap_idx = Int.gen_uniform_incl n (Array.length arr - 1) in\n Array.swap arr n swap_idx ;\n go (n + 1) )\n else return arr\n in\n go 0\n\nlet shuffle_arr arr = shuffle_arr_inplace @@ Array.copy arr\n\nlet shuffle list =\n Array.of_list list |> shuffle_arr_inplace |> map ~f:Array.to_list\n\n(* Generate a list with a Dirichlet distribution, used for coming up with random\n splits of a quantity. Symmetric Dirichlet distribution with alpha = 1.\n*)\nlet gen_symm_dirichlet : int -> float list Quickcheck.Generator.t =\n fun n ->\n let open Quickcheck.Generator.Let_syntax in\n let%map gammas =\n map_gens\n (List.init n ~f:(Fn.const ()))\n ~f:(fun _ ->\n let open Quickcheck.Generator.Let_syntax in\n (* technically this should be (0, 1] and not (0, 1) but I expect it\n doesn't matter for our purposes. *)\n let%map uniform = Float.gen_uniform_excl 0. 1. in\n Float.log uniform )\n in\n let sum = List.fold gammas ~init:0. ~f:(fun x y -> x +. y) in\n List.map gammas ~f:(fun gamma -> gamma /. sum)\n\nmodule type Int_s = sig\n type t\n\n val zero : t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val ( > ) : t -> t -> bool\n\n val of_int : int -> t\n\n val to_int : t -> int\nend\n\nlet gen_division_generic (type t) (module M : Int_s with type t = t) (n : t)\n (k : int) : M.t list Quickcheck.Generator.t =\n if k = 0 then Quickcheck.Generator.return []\n else\n let open Quickcheck.Generator.Let_syntax in\n (* Using a symmetric Dirichlet distribution with concentration parameter 1\n defined above gives a distribution with uniform probability density over\n all possible splits of the quantity. See the Wikipedia article for some\n more detail: https://en.wikipedia.org/wiki/Dirichlet_distribution,\n particularly the sections about the flat Dirichlet distribution and\n string cutting.\n *)\n let%bind dirichlet = gen_symm_dirichlet k in\n let n_float = Float.of_int @@ M.to_int n in\n let float_to_mt : float -> t =\n fun fl ->\n match Float.iround_down fl with\n | Some int ->\n M.of_int int\n | None ->\n failwith \"gen_division_generic: out of range\"\n in\n let res = List.map dirichlet ~f:(fun x -> float_to_mt @@ (x *. n_float)) in\n let total = List.fold res ~f:M.( + ) ~init:M.zero in\n return\n ( match res with\n | [] ->\n failwith\n \"empty result list in gen_symm_dirichlet, this should be \\\n impossible. \"\n | head :: rest ->\n (* Going through floating point land may have caused some rounding error. We\n tack it onto the first result so that the sum of the output is equal to n.\n *)\n if M.( > ) n total then M.(head + (n - total)) :: rest\n else M.(head - (total - n)) :: rest )\n\nlet gen_division = gen_division_generic (module Int)\n\nlet gen_division_currency =\n gen_division_generic\n ( module struct\n include Currency.Amount\n\n let ( + ) a b = Option.value_exn (a + b)\n\n let ( - ) a b = Option.value_exn (a - b)\n\n let of_int = of_nanomina_int_exn\n\n let to_int = to_nanomina_int\n end )\n\nlet imperative_fixed_point root ~f =\n let%map f' = fixed_point f in\n f' root\n\nlet gen_imperative_rose_tree ?(p = 0.75) (root_gen : 'a t)\n (node_gen : ('a -> 'a) t) =\n let%bind root = root_gen in\n imperative_fixed_point root ~f:(fun self ->\n match%bind size with\n | 0 ->\n return (fun parent -> Rose_tree.T (parent, []))\n | n ->\n let%bind fork_count = geometric ~p 1 >>| Int.max n in\n let%bind fork_sizes = gen_division n fork_count in\n let positive_fork_sizes =\n List.filter fork_sizes ~f:(fun s -> s > 0)\n in\n let%map forks =\n map_gens positive_fork_sizes ~f:(fun s ->\n tuple2 node_gen (with_size ~size:(s - 1) self) )\n in\n fun parent ->\n Rose_tree.T\n (parent, List.map forks ~f:(fun (this, f) -> f (this parent))) )\n\nlet gen_imperative_ktree ?(p = 0.75) (root_gen : 'a t) (node_gen : ('a -> 'a) t)\n =\n let%bind root = root_gen in\n imperative_fixed_point root ~f:(fun self ->\n match%bind size with\n | 0 ->\n return (fun _ -> [])\n (* this case is optional but more effecient *)\n | 1 ->\n let%map this = node_gen in\n fun parent -> [ this parent ]\n | n ->\n let%bind this = node_gen in\n let%bind fork_count = geometric ~p 1 >>| Int.max n in\n let%bind fork_sizes = gen_division (n - 1) fork_count in\n let%map forks =\n map_gens fork_sizes ~f:(fun s -> with_size ~size:s self)\n in\n fun parent ->\n let x = this parent in\n x :: List.bind forks ~f:(fun f -> f x) )\n\nlet gen_imperative_list (root_gen : 'a t) (node_gen : ('a -> 'a) t) =\n let%bind root = root_gen in\n imperative_fixed_point root ~f:(fun self ->\n match%bind size with\n | 0 ->\n return (fun _ -> [])\n | n ->\n let%bind this = node_gen in\n let%map f = with_size ~size:(n - 1) self in\n fun parent -> parent :: f (this parent) )\n\nlet%test_module \"Quickcheck lib tests\" =\n ( module struct\n let%test_unit \"gen_imperative_list\" =\n let increment = ( + ) 2 in\n let root = 1 in\n let root_gen = return root in\n let gen =\n Int.gen_incl 2 100\n >>= fun size ->\n Quickcheck.Generator.with_size ~size\n (gen_imperative_list root_gen (return increment))\n in\n Quickcheck.test gen ~f:(fun list ->\n match list with\n | [] ->\n failwith \"We assume that our list has at least one element\"\n | x :: xs ->\n assert (x = root) ;\n let result =\n List.fold_result xs ~init:x ~f:(fun elem next_elem ->\n if next_elem = increment elem then Result.return next_elem\n else\n Or_error.errorf\n !\"elements do not add up correctly %d %d\"\n elem next_elem )\n in\n assert (Result.is_ok result) )\n end )\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nlet field_of_bool =\n Snark_params.Tick.(fun b -> if b then Field.one else Field.zero)\n\nlet bit_length_to_triple_length n =\n let r = n mod 3 in\n let k = n / 3 in\n if r = 0 then k else k + 1\n\nlet split_last_exn =\n let rec go acc x xs =\n match xs with [] -> (List.rev acc, x) | x' :: xs -> go (x :: acc) x' xs\n in\n function [] -> failwith \"split_last: Empty list\" | x :: xs -> go [] x xs\n\nlet two_to_the i = Bignum_bigint.(pow (of_int 2) (of_int i))\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_import\n\nmodule type S = sig\n module Digest : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n val of_field : Snark_params.Tick.Field.t -> t\n\n val to_field_unsafe : t -> Snark_params.Tick.Field.t\n\n include Stringable.S with type t := t\n\n (* so we can easily import these into Token_id *)\n module Binables : sig\n include Comparable_binable with type t := t\n\n include Hashable_binable with type t := t\n end\n\n include module type of Binables\n\n val to_input : t -> Snark_params.Tick.Field.t Random_oracle.Input.Chunked.t\n\n val default : t\n\n val gen : t Quickcheck.Generator.t\n\n val gen_non_default : t Quickcheck.Generator.t\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n open Pickles.Impls.Step\n\n type t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val constant : Stable.Latest.t -> t\n\n val equal : t -> t -> Boolean.var\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t\n\n val of_field : Pickles.Impls.Step.Field.t -> t\n\n val to_field_unsafe : t -> Pickles.Impls.Step.Field.t\n\n module Assert : sig\n val equal : t -> t -> unit\n end\n end\n\n val typ : (Checked.t, t) Snark_params.Tick.Typ.t\n\n [%%endif]\n end\n\n [%%versioned:\n module Stable : sig\n module V2 : sig\n type t [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n val create : Public_key.Compressed.t -> Digest.t -> t\n\n val derive_token_id : owner:t -> Digest.t\n\n val empty : t\n\n val invalid : t\n\n val public_key : t -> Public_key.Compressed.t\n\n val of_public_key : Public_key.t -> t\n\n val token_id : t -> Digest.t\n\n val to_input : t -> Snark_params.Tick.Field.t Random_oracle.Input.Chunked.t\n\n val gen : t Quickcheck.Generator.t\n\n include Comparable.S with type t := t\n\n include Hashable.S_binable with type t := t\n\n [%%ifdef consensus_mechanism]\n\n type var\n\n val typ : (var, t) Snark_params.Tick.Typ.t\n\n val var_of_t : t -> var\n\n module Checked : sig\n open Snark_params\n open Tick\n\n val create : Public_key.Compressed.var -> Digest.Checked.t -> var\n\n val public_key : var -> Public_key.Compressed.var\n\n val token_id : var -> Digest.Checked.t\n\n val to_input :\n var -> Snark_params.Tick.Field.Var.t Random_oracle.Input.Chunked.t\n\n val equal : var -> var -> Boolean.var Checked.t\n\n val if_ : Boolean.var -> then_:var -> else_:var -> var Checked.t\n\n val derive_token_id : owner:var -> Digest.Checked.t\n end\n\n [%%endif]\nend\n","(* hash_prefix.ml *)\n\ninclude Hash_prefix_states\n","(* data_hash.ml *)\n\ninclude Data_hash_lib.Data_hash\n","open Core_kernel\n\nmodule Legacy_token = Mina_numbers.Nat.Make64 ()\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Account_id.Digest.Stable.V1.t\n [@@deriving sexp, yojson, equal, compare, hash]\n\n let to_latest = Fn.id\n end\n\n (* for transactions in pre-Berkeley hard fork *)\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Legacy_token.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest token_id =\n Legacy_token.to_field token_id |> Account_id.Digest.of_field\n end\nend]\n\n[%%define_locally\nAccount_id.Digest.\n ( default\n , typ\n , to_input\n , gen\n , gen_non_default\n , to_field_unsafe\n , of_field\n , to_string\n , of_string\n , comparator\n , ( <> ) )]\n\nlet of_string s =\n try Account_id.Digest.of_string s\n with Base58_check.Invalid_base58_check_length _ ->\n Legacy_token.of_string s |> Stable.V1.to_latest\n\ninclude Account_id.Digest.Binables\n\n(* someday, allow this in %%define_locally *)\nmodule Checked = Account_id.Digest.Checked\n\nlet deriver obj =\n (* this doesn't use js_type:Field because it is converted to JSON differently than a normal Field *)\n Fields_derivers_zkapps.iso_string obj ~name:\"TokenId\"\n ~js_type:(Custom \"TokenId\") ~doc:\"String representing a token ID\" ~to_string\n ~of_string:(Fields_derivers_zkapps.except ~f:of_string `Token_id)\n","(** Fee excesses associated with transactions or transitions.\n\n These are represented as a 'left' and 'right' excess, which describe the\n unresolved fee excesses in the fee tokens of the first (or leftmost) and\n last (or rightmost) transactions in the transition.\n\n Assumptions:\n * Transactions are grouped by their fee token.\n * The 'fee transfer' transaction to dispense those fees is part of this\n group.\n * The fee excess for each token is 0 across the group.\n * No transactions with fees paid in another token are executed while the\n previous fee token's excess is non-zero.\n\n By maintaining these assumptions, we can ensure that the un-settled fee\n excesses can be represented by excesses in (at most) 2 tokens.\n Consider, for example, any consecutive subsequence of the transactions\n\n ..[txn@2][ft@2][txn@3][txn@3][ft@3][txn@4][ft@4][txn@5][txn@5][ft@5][txn@6][ft@6]..\n\n where [txn@i] and [ft@i] are transactions and fee transfers respectively\n paid in token i.\n The only groups which may have non-zero fee excesses are those which\n contain the start and end of the subsequence.\n\n The code below also defines a canonical representation where fewer than 2\n tokens have non-zero excesses. See [rebalance] below for details and the\n implementation.\n*)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n[%%ifndef consensus_mechanism]\n\nopen Mina_base_import\n\n[%%endif]\n\nopen Currency\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params\nopen Tick\n\n[%%endif]\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('token, 'fee) t =\n ('token, 'fee) Mina_wire_types.Mina_base.Fee_excess.Poly.V1.t =\n { fee_token_l : 'token\n ; fee_excess_l : 'fee\n ; fee_token_r : 'token\n ; fee_excess_r : 'fee\n }\n [@@deriving compare, equal, hash, sexp, hlist]\n\n let to_yojson token_to_yojson fee_to_yojson\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n `List\n [ `Assoc\n [ (\"token\", token_to_yojson fee_token_l)\n ; (\"amount\", fee_to_yojson fee_excess_l)\n ]\n ; `Assoc\n [ (\"token\", token_to_yojson fee_token_r)\n ; (\"amount\", fee_to_yojson fee_excess_r)\n ]\n ]\n\n let of_yojson token_of_yojson fee_of_yojson = function\n | `List [ `Assoc [ left0; left1 ]; `Assoc [ right0; right1 ] ] -> (\n (* allow for reversed field order: \"be liberal in what you accept\" *)\n let token_and_excess pair0 pair1 =\n match (pair0, pair1) with\n | (\"token\", token), (\"amount\", excess) ->\n Some (token, excess)\n | (\"amount\", excess), (\"token\", token) ->\n Some (token, excess)\n | _ ->\n None\n in\n let left = token_and_excess left0 left1 in\n let right = token_and_excess right0 right1 in\n match (left, right) with\n | Some (fee_token_l, fee_excess_l), Some (fee_token_r, fee_excess_r)\n ->\n let open Result.Let_syntax in\n let%map fee_token_l = token_of_yojson fee_token_l\n and fee_excess_l = fee_of_yojson fee_excess_l\n and fee_token_r = token_of_yojson fee_token_r\n and fee_excess_r = fee_of_yojson fee_excess_r in\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r }\n | _ ->\n Error \"Fee_excess.Poly.Stable.V1.t, unexpected JSON field\" )\n | _ ->\n Error \"Fee_excess.Poly.Stable.V1.t\"\n end\n end]\n\n [%%define_locally Stable.Latest.(to_yojson, of_yojson)]\n\n [%%ifdef consensus_mechanism]\n\n let typ (token_typ : ('token_var, 'token) Typ.t)\n (fee_typ : ('fee_var, 'fee) Typ.t) :\n (('token_var, 'fee_var) t, ('token, 'fee) t) Typ.t =\n Typ.of_hlistable\n [ token_typ; fee_typ; token_typ; fee_typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n [%%endif]\nend\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t =\n ( Token_id.Stable.V2.t\n , (Fee.Stable.V1.t, Sgn.Stable.V1.t) Signed_poly.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving compare, equal, hash, sexp, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\ntype ('token, 'fee) poly = ('token, 'fee) Poly.t =\n { fee_token_l : 'token\n ; fee_excess_l : 'fee\n ; fee_token_r : 'token\n ; fee_excess_r : 'fee\n }\n[@@deriving compare, equal, hash, sexp]\n\nlet poly_to_yojson = Poly.to_yojson\n\nlet poly_of_yojson = Poly.of_yojson\n\n[%%ifdef consensus_mechanism]\n\ntype var = (Token_id.Checked.t, Fee.Signed.var) poly\n\nlet typ : (var, t) Typ.t = Poly.typ Token_id.typ Fee.Signed.typ\n\nlet var_of_t ({ fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } : t) :\n var =\n { fee_token_l = Token_id.Checked.constant fee_token_l\n ; fee_excess_l = Fee.Signed.Checked.constant fee_excess_l\n ; fee_token_r = Token_id.Checked.constant fee_token_r\n ; fee_excess_r = Fee.Signed.Checked.constant fee_excess_r\n }\n\n[%%endif]\n\nlet to_input { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n [ Token_id.to_input fee_token_l\n ; Fee.Signed.to_input fee_excess_l\n ; Token_id.to_input fee_token_r\n ; Fee.Signed.to_input fee_excess_r\n ]\n\n[%%ifdef consensus_mechanism]\n\nlet to_input_checked { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n let fee_token_l = Token_id.Checked.to_input fee_token_l\n and fee_token_r = Token_id.Checked.to_input fee_token_r in\n let%map fee_excess_l = Fee.Signed.Checked.to_input fee_excess_l\n and fee_excess_r = Fee.Signed.Checked.to_input fee_excess_r in\n List.reduce_exn ~f:Random_oracle.Input.Chunked.append\n [ fee_token_l; fee_excess_l; fee_token_r; fee_excess_r ]\n\nlet assert_equal_checked (t1 : var) (t2 : var) =\n Checked.all_unit\n [ [%with_label_ \"fee_token_l\"] (fun () ->\n make_checked (fun () ->\n Token_id.Checked.Assert.equal t1.fee_token_l t2.fee_token_l ) )\n ; [%with_label_ \"fee_excess_l\"] (fun () ->\n Fee.Signed.Checked.assert_equal t1.fee_excess_l t2.fee_excess_l )\n ; [%with_label_ \"fee_token_r\"] (fun () ->\n make_checked (fun () ->\n Token_id.Checked.Assert.equal t1.fee_token_r t2.fee_token_r ) )\n ; [%with_label_ \"fee_excess_r\"] (fun () ->\n Fee.Signed.Checked.assert_equal t1.fee_excess_r t2.fee_excess_r )\n ]\n\n[%%endif]\n\n(** Eliminate a fee excess, either by combining it with one to the left/right,\n or by checking that it is zero.\n*)\nlet eliminate_fee_excess (fee_token_l, fee_excess_l) (fee_token_m, fee_excess_m)\n (fee_token_r, fee_excess_r) =\n let add_err x y =\n match Fee.Signed.add x y with\n | Some z ->\n Or_error.return z\n | None ->\n Or_error.errorf \"Error adding fees: overflow.\"\n in\n let open Or_error.Let_syntax in\n if\n Token_id.equal fee_token_l fee_token_m\n || Fee.(equal zero) fee_excess_l.Signed_poly.magnitude\n then\n let%map fee_excess_l = add_err fee_excess_l fee_excess_m in\n ((fee_token_m, fee_excess_l), (fee_token_r, fee_excess_r))\n else if\n Token_id.equal fee_token_r fee_token_m\n || Fee.(equal zero fee_excess_r.Signed_poly.magnitude)\n then\n let%map fee_excess_r = add_err fee_excess_r fee_excess_m in\n ((fee_token_l, fee_excess_l), (fee_token_m, fee_excess_r))\n else if Fee.(equal zero) fee_excess_m.Signed_poly.magnitude then\n return ((fee_token_l, fee_excess_l), (fee_token_r, fee_excess_r))\n else\n Or_error.errorf\n !\"Error eliminating fee excess: Excess for token %{sexp: Token_id.t} \\\n %{sexp: Fee.Signed.t} was nonzero\"\n fee_token_m fee_excess_m\n\n[%%ifdef consensus_mechanism]\n\n(* We use field elements instead of a currency type here, under the following\n assumptions:\n * the additions and subtractions performed upon members of the currency\n type do not overflow the field size\n - The currency type is currently 64-bit, which is much smaller than the\n field size.\n * it is acceptable for the currency type to overflow/underflow, as long as\n a subsequent subtraction/addition brings it back into the range for the\n currency type.\n - These situations will be rejected by the unchecked code that checks\n each addition/subtraction, but this superset of that behaviour seems\n well-defined, and is still 'correct' in the sense that currency is\n preserved.\n\n This optimisation saves serveral hundred constraints in the proof by not\n unpacking the result of each arithmetic operation.\n*)\nlet%snarkydef_ eliminate_fee_excess_checked (fee_token_l, fee_excess_l)\n (fee_token_m, fee_excess_m) (fee_token_r, fee_excess_r) =\n let open Tick in\n let open Checked.Let_syntax in\n let combine (fee_token, fee_excess) fee_excess_m =\n let%bind fee_token_equal =\n make_checked (fun () -> Token_id.Checked.equal fee_token fee_token_m)\n in\n let%bind fee_excess_zero =\n Field.(Checked.equal (Var.constant zero)) fee_excess\n in\n let%bind may_move = Boolean.(fee_token_equal ||| fee_excess_zero) in\n let%bind fee_token =\n make_checked (fun () ->\n Token_id.Checked.if_ fee_excess_zero ~then_:fee_token_m\n ~else_:fee_token )\n in\n let%map fee_excess_to_move =\n Field.Checked.if_ may_move ~then_:fee_excess_m\n ~else_:Field.(Var.constant zero)\n in\n ( (fee_token, Field.Var.add fee_excess fee_excess_to_move)\n , Field.Var.sub fee_excess_m fee_excess_to_move )\n in\n (* NOTE: Below, we may update the tokens on both sides, even though we only\n promote the excess to one of them. This differs from the unchecked\n version, but\n * the token may only be changed if it is associated with 0 fee excess\n * any intermediate 0 fee excesses can always be either combined or erased\n in later eliminations\n * a fee excess of 0 on the left or right will have its token erased to the\n default\n *)\n let%bind (fee_token_l, fee_excess_l), fee_excess_m =\n combine (fee_token_l, fee_excess_l) fee_excess_m\n in\n let%bind (fee_token_r, fee_excess_r), fee_excess_m =\n combine (fee_token_r, fee_excess_r) fee_excess_m\n in\n let%map () =\n [%with_label_ \"Fee excess is eliminated\"]\n Field.(fun () -> Checked.Assert.equal (Var.constant zero) fee_excess_m)\n in\n ((fee_token_l, fee_excess_l), (fee_token_r, fee_excess_r))\n\n[%%endif]\n\n(* 'Rebalance' to a canonical form, where\n - if there is only 1 nonzero excess, it is to the left\n - any zero fee excess has the default token\n - if the fee tokens are the same, the excesses are combined\n*)\nlet rebalance ({ fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } : t) =\n let open Or_error.Let_syntax in\n (* Use the same token for both if [fee_excess_l] is zero. *)\n let fee_token_l =\n if Fee.(equal zero) fee_excess_l.magnitude then fee_token_r else fee_token_l\n in\n (* Rebalancing. *)\n let%map fee_excess_l, fee_excess_r =\n if Token_id.equal fee_token_l fee_token_r then\n match Fee.Signed.add fee_excess_l fee_excess_r with\n | Some fee_excess_l ->\n return (fee_excess_l, Fee.Signed.zero)\n | None ->\n Or_error.errorf !\"Error adding fees: overflow\"\n else return (fee_excess_l, fee_excess_r)\n in\n (* Use the default token if the excess is zero.\n This allows [verify_complete_merge] to verify a proof without knowledge of\n the particular fee tokens used.\n *)\n let fee_token_l =\n if Fee.(equal zero) fee_excess_l.magnitude then Token_id.default\n else fee_token_l\n in\n let fee_token_r =\n if Fee.(equal zero) fee_excess_r.magnitude then Token_id.default\n else fee_token_r\n in\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r }\n\n[%%ifdef consensus_mechanism]\n\nlet rebalance_checked { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n let open Checked.Let_syntax in\n (* Use the same token for both if [fee_excess_l] is zero. *)\n let%bind fee_token_l =\n let%bind excess_is_zero =\n Field.(Checked.equal (Var.constant zero) fee_excess_l)\n in\n make_checked (fun () ->\n Token_id.Checked.if_ excess_is_zero ~then_:fee_token_r\n ~else_:fee_token_l )\n in\n (* Rebalancing. *)\n let%bind fee_excess_l, fee_excess_r =\n let%bind tokens_equal =\n make_checked (fun () -> Token_id.Checked.equal fee_token_l fee_token_r)\n in\n let%map amount_to_move =\n Field.Checked.if_ tokens_equal ~then_:fee_excess_r\n ~else_:Field.(Var.constant zero)\n in\n ( Field.Var.add fee_excess_l amount_to_move\n , Field.Var.sub fee_excess_r amount_to_move )\n in\n (* Use the default token if the excess is zero. *)\n let%bind fee_token_l =\n let%bind excess_is_zero =\n Field.(Checked.equal (Var.constant zero) fee_excess_l)\n in\n make_checked (fun () ->\n Token_id.Checked.if_ excess_is_zero\n ~then_:Token_id.(Checked.constant default)\n ~else_:fee_token_l )\n in\n let%map fee_token_r =\n let%bind excess_is_zero =\n Field.(Checked.equal (Var.constant zero) fee_excess_r)\n in\n make_checked (fun () ->\n Token_id.Checked.if_ excess_is_zero\n ~then_:Token_id.(Checked.constant default)\n ~else_:fee_token_r )\n in\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r }\n\n[%%endif]\n\n(** Combine the fee excesses from two transitions. *)\nlet combine\n ({ fee_token_l = fee_token1_l\n ; fee_excess_l = fee_excess1_l\n ; fee_token_r = fee_token1_r\n ; fee_excess_r = fee_excess1_r\n } :\n t )\n ({ fee_token_l = fee_token2_l\n ; fee_excess_l = fee_excess2_l\n ; fee_token_r = fee_token2_r\n ; fee_excess_r = fee_excess2_r\n } :\n t ) : t Or_error.t =\n let open Or_error.Let_syntax in\n (* Eliminate fee_excess1_r. *)\n let%bind (fee_token1_l, fee_excess1_l), (fee_token2_l, fee_excess2_l) =\n (* [1l; 1r; 2l; 2r] -> [1l; 2l; 2r] *)\n eliminate_fee_excess\n (fee_token1_l, fee_excess1_l)\n (fee_token1_r, fee_excess1_r)\n (fee_token2_l, fee_excess2_l)\n in\n (* Eliminate fee_excess2_l. *)\n let%bind (fee_token1_l, fee_excess1_l), (fee_token2_r, fee_excess2_r) =\n (* [1l; 2l; 2r] -> [1l; 2r] *)\n eliminate_fee_excess\n (fee_token1_l, fee_excess1_l)\n (fee_token2_l, fee_excess2_l)\n (fee_token2_r, fee_excess2_r)\n in\n rebalance\n { fee_token_l = fee_token1_l\n ; fee_excess_l = fee_excess1_l\n ; fee_token_r = fee_token2_r\n ; fee_excess_r = fee_excess2_r\n }\n\n[%%ifdef consensus_mechanism]\n\nlet%snarkydef_ combine_checked\n { fee_token_l = fee_token1_l\n ; fee_excess_l = fee_excess1_l\n ; fee_token_r = fee_token1_r\n ; fee_excess_r = fee_excess1_r\n }\n { fee_token_l = fee_token2_l\n ; fee_excess_l = fee_excess2_l\n ; fee_token_r = fee_token2_r\n ; fee_excess_r = fee_excess2_r\n } =\n let open Checked.Let_syntax in\n (* Represent amounts as field elements. *)\n let%bind fee_excess1_l = Fee.Signed.Checked.to_field_var fee_excess1_l in\n let%bind fee_excess1_r = Fee.Signed.Checked.to_field_var fee_excess1_r in\n let%bind fee_excess2_l = Fee.Signed.Checked.to_field_var fee_excess2_l in\n let%bind fee_excess2_r = Fee.Signed.Checked.to_field_var fee_excess2_r in\n (* Eliminations. *)\n let%bind (fee_token1_l, fee_excess1_l), (fee_token2_l, fee_excess2_l) =\n (* [1l; 1r; 2l; 2r] -> [1l; 2l; 2r] *)\n [%with_label_ \"Eliminate fee_excess1_r\"] (fun () ->\n eliminate_fee_excess_checked\n (fee_token1_l, fee_excess1_l)\n (fee_token1_r, fee_excess1_r)\n (fee_token2_l, fee_excess2_l) )\n in\n let%bind (fee_token1_l, fee_excess1_l), (fee_token2_r, fee_excess2_r) =\n (* [1l; 2l; 2r] -> [1l; 2r] *)\n [%with_label_ \"Eliminate fee_excess2_l\"] (fun () ->\n eliminate_fee_excess_checked\n (fee_token1_l, fee_excess1_l)\n (fee_token2_l, fee_excess2_l)\n (fee_token2_r, fee_excess2_r) )\n in\n let%bind { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n rebalance_checked\n { fee_token_l = fee_token1_l\n ; fee_excess_l = fee_excess1_l\n ; fee_token_r = fee_token2_r\n ; fee_excess_r = fee_excess2_r\n }\n in\n let convert_to_currency excess =\n let%bind currency_excess =\n exists Fee.Signed.typ\n ~compute:\n As_prover.(\n let%map excess = read Field.typ excess in\n let is_neg =\n Bigint.test_bit (Bigint.of_field excess) (Field.size_in_bits - 1)\n in\n let sgn = if is_neg then Sgn.Neg else Sgn.Pos in\n let excess =\n if is_neg then Field.(mul (negate one) excess) else excess\n in\n let magnitude =\n (* TODO: Add a native coercion [Bigint -> UInt64] in Snarky's FFI\n bindings, use it here.\n *)\n let n = Bigint.of_field excess in\n let total = ref Unsigned_extended.UInt64.zero in\n for i = 0 to Unsigned_extended.UInt64.length_in_bits - 1 do\n if Bigint.test_bit n i then\n total :=\n Unsigned_extended.UInt64.(add !total (shift_left one i))\n done ;\n Fee.of_uint64 !total\n in\n Fee.Signed.create ~magnitude ~sgn)\n in\n let%bind excess_from_currency =\n Fee.Signed.Checked.to_field_var currency_excess\n in\n let%map () =\n [%with_label_ \"Fee excess does not overflow\"] (fun () ->\n Field.Checked.Assert.equal excess excess_from_currency )\n in\n currency_excess\n in\n (* Convert to currency. *)\n let%bind fee_excess_l =\n [%with_label_ \"Check for overflow in fee_excess_l\"] (fun () ->\n convert_to_currency fee_excess_l )\n in\n let%map fee_excess_r =\n [%with_label_ \"Check for overflow in fee_excess_r\"] (fun () ->\n convert_to_currency fee_excess_r )\n in\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r }\n\n[%%endif]\n\nlet empty =\n { fee_token_l = Token_id.default\n ; fee_excess_l = Fee.Signed.zero\n ; fee_token_r = Token_id.default\n ; fee_excess_r = Fee.Signed.zero\n }\n\nlet is_empty { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n Fee.Signed.(equal zero) fee_excess_l\n && Fee.Signed.(equal zero) fee_excess_r\n && Token_id.(equal default) fee_token_l\n && Token_id.(equal default) fee_token_r\n\nlet zero = empty\n\nlet is_zero = is_empty\n\nlet of_single (fee_token_l, fee_excess_l) =\n (* This is safe, we know that we will not hit overflow above. *)\n Or_error.ok_exn\n @@ rebalance\n { fee_token_l\n ; fee_excess_l\n ; fee_token_r = Token_id.default\n ; fee_excess_r = Fee.Signed.zero\n }\n\nlet of_one_or_two excesses =\n let unreduced =\n match excesses with\n | `One (fee_token_l, fee_excess_l) ->\n { fee_token_l\n ; fee_excess_l\n ; fee_token_r = Token_id.default\n ; fee_excess_r = Fee.Signed.zero\n }\n | `Two ((fee_token_l, fee_excess_l), (fee_token_r, fee_excess_r)) ->\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r }\n in\n rebalance unreduced\n\nlet to_one_or_two ({ fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } : t)\n =\n if Fee.(equal zero) fee_excess_r.magnitude then\n `One (fee_token_l, fee_excess_l)\n else `Two ((fee_token_l, fee_excess_l), (fee_token_r, fee_excess_r))\n\n[%%ifdef consensus_mechanism]\n\nlet gen_single ?(token_id = Token_id.gen) ?(excess = Fee.Signed.gen) () :\n (Token_id.t * Fee.Signed.t) Quickcheck.Generator.t =\n Quickcheck.Generator.tuple2 token_id excess\n\nlet gen : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map excesses = One_or_two.gen @@ gen_single () in\n match of_one_or_two excesses with\n | Ok ret ->\n ret\n | Error _ -> (\n (* There is an overflow, just choose the first excess. *)\n match excesses with\n | `One (fee_token_l, fee_excess_l) | `Two ((fee_token_l, fee_excess_l), _)\n ->\n { fee_token_l\n ; fee_excess_l\n ; fee_token_r = Token_id.default\n ; fee_excess_r = Fee.Signed.zero\n } )\n\n[%%endif]\n","open Core_kernel\nopen Snark_params.Tick\n\nmodule type S = sig\n include Data_hash.Full_size\n\n [%%versioned:\n module Stable : sig\n [@@@no_toplevel_latest_type]\n\n module V1 : sig\n type t = Field.t [@@deriving sexp, compare, hash, yojson]\n\n val to_latest : t -> t\n\n include Comparable.S with type t := t\n\n include Hashable_binable with type t := t\n end\n end]\nend\n","include Ledger_hash0\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\nmodule type S = sig\n exception Too_long_user_memo_input\n\n exception Too_long_digestible_string\n\n type t [@@deriving sexp, equal, compare, hash, yojson]\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving bin_io, sexp, equal, compare, hash, yojson, version]\n\n module With_all_version_tags : Bin_prot.Binable.S with type t = t\n end\n\n module Latest = V1\n end\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n type unchecked = t\n\n type t = private Boolean.var array\n\n val constant : unchecked -> t\n end\n\n (** typ representation *)\n val typ : (Checked.t, t) Typ.t\n\n [%%endif]\n\n val dummy : t\n\n val empty : t\n\n val to_base58_check : t -> string\n\n val of_base58_check : string -> t Or_error.t\n\n val of_base58_check_exn : string -> t\n\n (** for a memo of bytes, return a plaintext string\n for a memo of a digest, return a hex-encoded string, prefixed by '0x'\n *)\n val to_string_hum : t -> string\n\n (** is the memo a digest *)\n val is_digest : t -> bool\n\n (** is the memo well-formed *)\n val is_valid : t -> bool\n\n (** bound on length of strings to digest *)\n val max_digestible_string_length : int\n\n (** bound on length of strings or bytes in memo *)\n val max_input_length : int\n\n (** create a memo by digesting a string; raises [Too_long_digestible_string] if\n length exceeds [max_digestible_string_length]\n *)\n val create_by_digesting_string_exn : string -> t\n\n (** create a memo by digesting a string; returns error if\n length exceeds [max_digestible_string_length]\n *)\n val create_by_digesting_string : string -> t Or_error.t\n\n (** create a memo from bytes of length up to max_input_length;\n raise [Too_long_user_memo_input] if length is greater\n *)\n val create_from_bytes_exn : bytes -> t\n\n (** create a memo from bytes of length up to max_input_length; returns\n error is length is greater\n *)\n val create_from_bytes : bytes -> t Or_error.t\n\n (** create a memo from a string of length up to max_input_length;\n raise [Too_long_user_memo_input] if length is greater\n *)\n val create_from_string_exn : string -> t\n\n (** create a memo from a string of length up to max_input_length;\n returns error if length is greater\n *)\n val create_from_string : string -> t Or_error.t\n\n (** convert a memo to a list of bools\n *)\n val to_bits : t -> bool list\n\n (** Quickcheck generator for memos. *)\n val gen : t Quickcheck.Generator.t\n\n (** Compute a standalone hash of the current memo. *)\n val hash : t -> Field.t\n\n (* This type definition was generated by hovering over `deriver` in signed_command_memo.ml and copying the type *)\n val deriver :\n (< contramap : (t -> Yojson.Safe.t) ref\n ; graphql_arg :\n (unit -> Yojson.Safe.t Fields_derivers_graphql.Schema.Arg.arg_typ)\n ref\n ; graphql_fields :\n Yojson.Safe.t Fields_derivers_zkapps.Graphql.Fields.Input.T.t ref\n ; graphql_query : string option ref\n ; graphql_query_accumulator : (string * string option) list ref\n ; map : (Yojson.Safe.t -> t) ref\n ; nullable_graphql_arg :\n ( unit\n -> Yojson.Safe.t option Fields_derivers_graphql.Schema.Arg.arg_typ\n )\n ref\n ; nullable_graphql_fields :\n Yojson.Safe.t option Fields_derivers_zkapps.Graphql.Fields.Input.T.t\n ref\n ; of_json : (Yojson.Safe.t -> Yojson.Safe.t) ref\n ; to_json : (Yojson.Safe.t -> Yojson.Safe.t) ref\n ; js_layout : Yojson.Safe.t ref\n ; .. >\n as\n 'a )\n Fields_derivers_zkapps.Unified_input.t\n Fields_derivers_zkapps.Unified_input.t\n Fields_derivers_zkapps.Unified_input.t\n -> 'a Fields_derivers_zkapps.Unified_input.t\n\n type raw =\n | Digest of string (** The digest of the string, encoded by base58-check *)\n | Bytes of string (** A string containing the raw bytes in the memo. *)\n\n (** Convert into a raw representation.\n\n Raises if the tag or length are invalid.\n *)\n val to_raw_exn : t -> raw\n\n (** Convert back into the raw input bytes.\n\n Raises if the tag or length are invalid, or if the memo was a digest.\n Equivalent to [to_raw_exn] and then a match on [Bytes].\n *)\n val to_raw_bytes_exn : t -> string\n\n (** Convert from a raw representation.\n\n Raises if the digest is not a valid base58-check string, or if the bytes\n string is too long.\n *)\n val of_raw_exn : raw -> t\nend\n","(* transaction_union_payload.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Currency\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nopen Signature_lib\nmodule Tag = Transaction_union_tag\n\nmodule Body = struct\n type ('tag, 'public_key, 'token_id, 'amount, 'bool) t_ =\n { tag : 'tag\n ; source_pk : 'public_key\n ; receiver_pk : 'public_key\n ; token_id : 'token_id\n ; amount : 'amount\n }\n [@@deriving sexp, hlist]\n\n type t =\n (Tag.t, Public_key.Compressed.t, Token_id.t, Currency.Amount.t, bool) t_\n [@@deriving sexp]\n\n let of_user_command_payload_body ~fee_payer_pk = function\n | Signed_command_payload.Body.Payment { receiver_pk; amount } ->\n { tag = Tag.Payment\n ; source_pk = fee_payer_pk\n ; receiver_pk\n ; token_id = Token_id.default\n ; amount\n }\n | Stake_delegation (Set_delegate { new_delegate }) ->\n { tag = Tag.Stake_delegation\n ; source_pk = fee_payer_pk\n ; receiver_pk = new_delegate\n ; token_id = Token_id.default\n ; amount = Currency.Amount.zero\n }\n\n let gen ~fee =\n let open Quickcheck.Generator.Let_syntax in\n let%bind tag = Tag.gen in\n let%map amount =\n let min, max =\n let max_amount_without_overflow =\n Amount.(sub max_int (of_fee fee))\n |> Option.value_exn ?here:None ?message:None ?error:None\n in\n match tag with\n | Payment ->\n (Amount.zero, max_amount_without_overflow)\n | Stake_delegation ->\n (Amount.zero, Amount.zero)\n | Fee_transfer ->\n (Amount.zero, max_amount_without_overflow)\n | Coinbase ->\n (* In this case,\n amount - fee should be defined. In other words,\n amount >= fee *)\n (Amount.of_fee fee, Amount.max_int)\n in\n Amount.gen_incl min max\n and source_pk = Public_key.Compressed.gen\n and receiver_pk = Public_key.Compressed.gen\n and token_id =\n match tag with\n | Payment ->\n Token_id.gen\n | Stake_delegation ->\n return Token_id.default\n | Fee_transfer ->\n return Token_id.default\n | Coinbase ->\n return Token_id.default\n in\n { tag; source_pk; receiver_pk; token_id; amount }\n\n [%%ifdef consensus_mechanism]\n\n type var =\n ( Tag.Unpacked.var\n , Public_key.Compressed.var\n , Token_id.Checked.t\n , Currency.Amount.var\n , Boolean.var )\n t_\n\n let typ =\n Typ.of_hlistable\n [ Tag.unpacked_typ\n ; Public_key.Compressed.typ\n ; Public_key.Compressed.typ\n ; Token_id.typ\n ; Currency.Amount.typ\n ]\n ~var_to_hlist:t__to_hlist ~value_to_hlist:t__to_hlist\n ~var_of_hlist:t__of_hlist ~value_of_hlist:t__of_hlist\n\n module Checked = struct\n let constant ({ tag; source_pk; receiver_pk; token_id; amount } : t) : var =\n { tag = Tag.unpacked_of_t tag\n ; source_pk = Public_key.Compressed.var_of_t source_pk\n ; receiver_pk = Public_key.Compressed.var_of_t receiver_pk\n ; token_id = Token_id.Checked.constant token_id\n ; amount = Currency.Amount.var_of_t amount\n }\n\n let to_input_legacy { tag; source_pk; receiver_pk; token_id; amount } =\n let%map amount = Currency.Amount.var_to_input_legacy amount\n and () =\n make_checked (fun () ->\n Token_id.Checked.Assert.equal token_id\n (Token_id.Checked.constant Token_id.default) )\n in\n let token_id = Signed_command_payload.Legacy_token_id.default_checked in\n Array.reduce_exn ~f:Random_oracle.Input.Legacy.append\n [| Tag.Unpacked.to_input_legacy tag\n ; Public_key.Compressed.Checked.to_input_legacy source_pk\n ; Public_key.Compressed.Checked.to_input_legacy receiver_pk\n ; token_id\n ; amount\n ; Random_oracle.Input.Legacy.bitstring [ Boolean.false_ ]\n |]\n end\n\n [%%endif]\n\n let to_input_legacy { tag; source_pk; receiver_pk; token_id; amount } =\n assert (Token_id.equal token_id Token_id.default) ;\n Array.reduce_exn ~f:Random_oracle.Input.Legacy.append\n [| Tag.to_input_legacy tag\n ; Public_key.Compressed.to_input_legacy source_pk\n ; Public_key.Compressed.to_input_legacy receiver_pk\n ; Signed_command_payload.Legacy_token_id.default\n ; Currency.Amount.to_input_legacy amount\n ; Random_oracle.Input.Legacy.bitstring [ false ]\n |]\nend\n\nmodule Payload_common = struct\n module Poly = struct\n type ('fee, 'public_key, 'token_id, 'nonce, 'global_slot, 'memo) t =\n { fee : 'fee\n ; fee_token : 'token_id\n ; fee_payer_pk : 'public_key\n ; nonce : 'nonce\n ; valid_until : 'global_slot\n ; memo : 'memo\n }\n [@@deriving sexp, hlist]\n end\n\n let to_signed_command_payload_common\n { Poly.fee; fee_payer_pk; nonce; valid_until; memo; fee_token = _ } =\n { Signed_command_payload.Common.Poly.fee\n ; fee_payer_pk\n ; nonce\n ; valid_until\n ; memo\n }\n\n type t =\n ( Currency.Fee.t\n , Public_key.Compressed.t\n , Token_id.t\n , Mina_numbers.Account_nonce.t\n , Mina_numbers.Global_slot_since_genesis.t\n , Signed_command_memo.t )\n Poly.t\n [@@deriving sexp]\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n type value = t\n\n type t =\n ( Currency.Fee.Checked.t\n , Public_key.Compressed.var\n , Token_id.Checked.t\n , Mina_numbers.Account_nonce.Checked.t\n , Mina_numbers.Global_slot_since_genesis.Checked.t\n , Signed_command_memo.Checked.t )\n Poly.t\n\n let constant\n ({ fee; fee_payer_pk; nonce; valid_until; memo; fee_token } : value) : t\n =\n { fee = Currency.Fee.var_of_t fee\n ; fee_payer_pk = Public_key.Compressed.var_of_t fee_payer_pk\n ; fee_token = Token_id.Checked.constant fee_token\n ; nonce = Mina_numbers.Account_nonce.Checked.constant nonce\n ; memo = Signed_command_memo.Checked.constant memo\n ; valid_until =\n Mina_numbers.Global_slot_since_genesis.Checked.constant valid_until\n }\n end\n\n let typ : (Checked.t, t) Typ.t =\n let open Poly in\n Typ.of_hlistable\n [ Currency.Fee.typ\n ; Token_id.typ\n ; Public_key.Compressed.typ\n ; Mina_numbers.Account_nonce.typ\n ; Mina_numbers.Global_slot_since_genesis.typ\n ; Signed_command_memo.typ\n ]\n ~var_to_hlist:to_hlist ~value_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_of_hlist:of_hlist\n\n [%%endif]\nend\n\ntype t = (Payload_common.t, Body.t) Signed_command_payload.Poly.t\n[@@deriving sexp]\n\ntype payload = t [@@deriving sexp]\n\nlet of_user_command_payload\n ({ common = { memo; fee; fee_payer_pk; nonce; valid_until }; body } :\n Signed_command_payload.t ) : t =\n { common =\n { fee\n ; fee_token = Token_id.default\n ; fee_payer_pk\n ; nonce\n ; valid_until\n ; memo\n }\n ; body = Body.of_user_command_payload_body ~fee_payer_pk body\n }\n\nlet gen =\n let open Quickcheck.Generator.Let_syntax in\n let%bind common = Signed_command_payload.Common.gen in\n let%map body = Body.gen ~fee:common.fee in\n Signed_command_payload.Poly.{ common; body }\n\n[%%ifdef consensus_mechanism]\n\ntype var = (Payload_common.Checked.t, Body.var) Signed_command_payload.Poly.t\n\ntype payload_var = var\n\nlet typ : (var, t) Typ.t =\n let to_hlist = Signed_command_payload.Poly.to_hlist in\n let of_hlist = Signed_command_payload.Poly.of_hlist in\n Typ.of_hlistable\n [ Payload_common.typ; Body.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\nlet payload_typ = typ\n\nmodule Checked = struct\n let to_input_legacy ({ common; body } : var) =\n let%map common =\n Signed_command_payload.Common.Checked.to_input_legacy\n (Payload_common.to_signed_command_payload_common common)\n and body = Body.Checked.to_input_legacy body in\n Random_oracle.Input.Legacy.append common body\n\n let constant ({ common; body } : t) : var =\n { common = Payload_common.Checked.constant common\n ; body = Body.Checked.constant body\n }\nend\n\n[%%endif]\n\nlet to_input_legacy ({ common; body } : t) =\n Random_oracle.Input.Legacy.append\n (Signed_command_payload.Common.to_input_legacy\n (Payload_common.to_signed_command_payload_common common) )\n (Body.to_input_legacy body)\n\nlet excess (payload : t) : Amount.Signed.t =\n let tag = payload.body.tag in\n let fee = payload.common.fee in\n let amount = payload.body.amount in\n match tag with\n | Payment | Stake_delegation ->\n (* For all user commands, the fee excess is just the fee. *)\n Amount.Signed.of_unsigned (Amount.of_fee fee)\n | Fee_transfer ->\n Option.value_exn (Amount.add_fee amount fee)\n |> Amount.Signed.of_unsigned |> Amount.Signed.negate\n | Coinbase ->\n Amount.Signed.zero\n\nlet fee_excess ({ body = { tag; amount; _ }; common = { fee; _ } } : t) =\n match tag with\n | Payment | Stake_delegation ->\n (* For all user commands, the fee excess is just the fee. *)\n Fee_excess.of_single (Token_id.default, Fee.Signed.of_unsigned fee)\n | Fee_transfer ->\n let excess =\n Option.value_exn (Amount.add_fee amount fee)\n |> Amount.to_fee |> Fee.Signed.of_unsigned |> Fee.Signed.negate\n in\n Fee_excess.of_single (Token_id.default, excess)\n | Coinbase ->\n Fee_excess.of_single (Token_id.default, Fee.Signed.zero)\n\nlet expected_supply_increase (payload : payload) =\n let tag = payload.body.tag in\n match tag with\n | Coinbase ->\n payload.body.amount\n | Payment | Stake_delegation | Fee_transfer ->\n Amount.zero\n","(* user_command_intf.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Mina_base_import\nopen Core_kernel\nopen Snark_params.Tick\nopen Mina_numbers\n\nmodule type Gen_intf = sig\n type t\n\n module Gen : sig\n (** Generate a single transaction between\n * Generate random keys for sender and receiver\n * for fee $\\in [Currency.Fee.minimum_user_command_fee,\n * Currency.Fee.minimum_user_command_fee+fee_range]$\n * and an amount $\\in [1,max_amount]$\n *)\n val payment :\n ?sign_type:[ `Fake | `Real ]\n -> key_gen:\n (Signature_keypair.t * Signature_keypair.t) Quickcheck.Generator.t\n -> ?nonce:Account_nonce.t\n -> ?min_amount:int\n -> max_amount:int\n -> fee_range:int\n -> unit\n -> t Quickcheck.Generator.t\n\n (** Generate a single transaction between\n * $a, b \\in keys$\n * for fee $\\in [Currency.Fee.minimum_user_command_fee,\n * Currency.Fee.minimum_user_command_fee+fee_range]$\n * and an amount $\\in [1,max_amount]$\n *)\n val payment_with_random_participants :\n ?sign_type:[ `Fake | `Real ]\n -> keys:Signature_keypair.t array\n -> ?nonce:Account_nonce.t\n -> ?min_amount:int\n -> max_amount:int\n -> fee_range:int\n -> unit\n -> t Quickcheck.Generator.t\n\n val stake_delegation :\n key_gen:\n (Signature_keypair.t * Signature_keypair.t) Quickcheck.Generator.t\n -> ?nonce:Account_nonce.t\n -> fee_range:int\n -> unit\n -> t Quickcheck.Generator.t\n\n val stake_delegation_with_random_participants :\n keys:Signature_keypair.t array\n -> ?nonce:Account_nonce.t\n -> fee_range:int\n -> unit\n -> t Quickcheck.Generator.t\n\n (** Generate a valid sequence of payments based on the initial state of a\n ledger. Use this together with Ledger.gen_initial_ledger_state.\n *)\n val sequence :\n ?length:int\n -> ?sign_type:[ `Fake | `Real ]\n -> ( Signature_lib.Keypair.t\n * Currency.Amount.t\n * Mina_numbers.Account_nonce.t\n * Account_timing.t )\n array\n -> t list Quickcheck.Generator.t\n end\nend\n\nmodule type S = sig\n type t [@@deriving sexp, yojson, hash]\n\n (* type of signed commands, pre-Berkeley hard fork *)\n type t_v1\n\n include Comparable.S with type t := t\n\n include Hashable.S with type t := t\n\n val signature : t -> Signature.t\n\n val payload : t -> Signed_command_payload.t\n\n val fee : t -> Currency.Fee.t\n\n val nonce : t -> Account_nonce.t\n\n val signer : t -> Public_key.t\n\n val fee_token : t -> Token_id.t\n\n val fee_payer_pk : t -> Public_key.Compressed.t\n\n val fee_payer : t -> Account_id.t\n\n val fee_excess : t -> Fee_excess.t\n\n val token : t -> Token_id.t\n\n val receiver_pk : t -> Public_key.Compressed.t\n\n val receiver : t -> Account_id.t\n\n val public_keys : t -> Public_key.Compressed.t list\n\n val amount : t -> Currency.Amount.t option\n\n val memo : t -> Signed_command_memo.t\n\n val valid_until : t -> Global_slot_since_genesis.t\n\n (* for filtering *)\n val minimum_fee : Currency.Fee.t\n\n val has_insufficient_fee : t -> bool\n\n val tag : t -> Transaction_union_tag.t\n\n val tag_string : t -> string\n\n val to_input_legacy :\n Signed_command_payload.t -> (Field.t, bool) Random_oracle_input.Legacy.t\n\n include Gen_intf with type t := t\n\n module With_valid_signature : sig\n module Stable : sig\n module Latest : sig\n type nonrec t\n [@@deriving sexp, equal, bin_io, yojson, version, compare, hash]\n\n include Gen_intf with type t := t\n end\n\n module V2 = Latest\n end\n\n type t = Stable.Latest.t [@@deriving sexp, yojson, compare, hash]\n\n include Gen_intf with type t := t\n\n include Comparable.S with type t := t\n end\n\n val sign_payload :\n ?signature_kind:Mina_signature_kind.t\n -> Signature_lib.Private_key.t\n -> Signed_command_payload.t\n -> Signature.t\n\n val sign :\n ?signature_kind:Mina_signature_kind.t\n -> Signature_keypair.t\n -> Signed_command_payload.t\n -> With_valid_signature.t\n\n val check_signature : ?signature_kind:Mina_signature_kind.t -> t -> bool\n\n val create_with_signature_checked :\n ?signature_kind:Mina_signature_kind.t\n -> Signature.t\n -> Public_key.Compressed.t\n -> Signed_command_payload.t\n -> With_valid_signature.t option\n\n val check_valid_keys : t -> bool\n\n module For_tests : sig\n (** the signature kind is an argument, to match `sign`, but ignored *)\n val fake_sign :\n ?signature_kind:Mina_signature_kind.t\n -> Signature_keypair.t\n -> Signed_command_payload.t\n -> With_valid_signature.t\n end\n\n (** checks signature and keys *)\n val check : t -> With_valid_signature.t option\n\n val check_only_for_signature : t -> With_valid_signature.t option\n\n val to_valid_unsafe :\n t\n -> [ `If_this_is_used_it_should_have_a_comment_justifying_it of\n With_valid_signature.t ]\n\n (** Forget the signature check. *)\n val forget_check : With_valid_signature.t -> t\n\n (** returned status always `Accessed for fee payer *)\n val account_access_statuses :\n t\n -> Transaction_status.t\n -> (Account_id.t * [ `Accessed | `Not_accessed ]) list\n\n (** all account ids mentioned in a command *)\n val accounts_referenced : t -> Account_id.t list\n\n val filter_by_participant : t list -> Public_key.Compressed.t -> t list\n\n val of_base58_check_exn_v1 : string -> t_v1 Or_error.t\n\n val to_base58_check_v1 : t_v1 -> string\n\n include Codable.Base64_intf with type t := t\nend\n\nmodule type Full = sig\n module Payload = Signed_command_payload\n\n module Poly : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type ('payload, 'pk, 'signature) t =\n ( 'payload\n , 'pk\n , 'signature )\n Mina_wire_types.Mina_base.Signed_command.Poly.V1.t =\n { payload : 'payload; signer : 'pk; signature : 'signature }\n [@@deriving sexp, hash, yojson, equal, compare]\n end\n end]\n end\n\n [%%versioned:\n module Stable : sig\n [@@@with_top_version_tag]\n\n module V2 : sig\n type t =\n ( Payload.Stable.V2.t\n , Public_key.Stable.V1.t\n , Signature.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, hash, yojson, version]\n\n include Comparable.S with type t := t\n\n include Hashable.S with type t := t\n\n val account_access_statuses :\n t\n -> Transaction_status.t\n -> (Account_id.t * [ `Accessed | `Not_accessed ]) list\n\n val accounts_referenced : t -> Account_id.t list\n end\n\n module V1 : sig\n type t =\n ( Payload.Stable.V1.t\n , Public_key.Stable.V1.t\n , Signature.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving compare, sexp, hash, yojson]\n\n val to_latest : t -> Latest.t\n end\n end]\n\n include S with type t = Stable.V2.t and type t_v1 = Stable.V1.t\nend\n","[%%import \"/src/config.mlh\"]\n\n[%%ifdef consensus_mechanism]\n\ninclude Pickles.Side_loaded.Verification_key\n\n[%%else]\n\nopen Core_kernel\n\nmodule G = struct\n open Snark_params.Tick\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Field.Stable.V1.t * Field.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule R = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n G.Stable.V1.t Pickles_base.Side_loaded_verification_key.Repr.Stable.V2.t\n [@@deriving sexp, compare, equal, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\n[%%versioned_binable\nmodule Stable = struct\n module V2 = struct\n type t =\n ( G.Stable.V1.t\n , unit )\n Pickles_base.Side_loaded_verification_key.Poly.Stable.V2.t\n [@@deriving hash]\n\n open Pickles_base.Side_loaded_verification_key\n\n let to_latest = Fn.id\n\n let to_repr { Poly.step_data; max_width; wrap_index; wrap_vk = _ } =\n { Repr.Stable.V2.step_data; max_width; wrap_index }\n\n let of_repr { Repr.Stable.V2.step_data; max_width; wrap_index = c } =\n { Poly.step_data; max_width; wrap_index = c; wrap_vk = Some () }\n\n include\n Binable.Of_binable\n (R.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable = to_repr\n\n let of_binable = of_repr\n end)\n\n let sexp_of_t t = R.sexp_of_t (to_repr t)\n\n let t_of_sexp sexp = of_repr (R.t_of_sexp sexp)\n\n let to_yojson t = R.to_yojson (to_repr t)\n\n let of_yojson json = Result.map ~f:of_repr (R.of_yojson json)\n\n let equal x y = R.equal (to_repr x) (to_repr y)\n\n let compare x y = R.compare (to_repr x) (to_repr y)\n end\nend]\n\nlet to_input x =\n Pickles_base.Side_loaded_verification_key.to_input\n ~field_of_int:Snark_params.Tick.Field.of_int x\n\nlet dummy : t =\n let open Pickles_types in\n { step_data = At_most.[]\n ; max_width = Pickles_base.Side_loaded_verification_key.Width.zero\n ; wrap_index =\n (let g = Snarkette.Pasta.Pallas.(to_affine_exn one) in\n { sigma_comm = Vector.init Dlog_plonk_types.Permuts.n ~f:(fun _ -> g)\n ; coefficients_comm =\n Vector.init Dlog_plonk_types.Columns.n ~f:(fun _ -> g)\n ; generic_comm = g\n ; psm_comm = g\n ; complete_add_comm = g\n ; mul_comm = g\n ; emul_comm = g\n ; endomul_scalar_comm = g\n } )\n ; wrap_vk = None\n }\n\n[%%endif]\n","(* state_hash.ml *)\nopen Core_kernel\nmodule T = Data_hash_lib.State_hash\ninclude T\n\nmodule State_hashes = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { mutable state_body_hash : State_body_hash.Stable.V1.t option\n ; state_hash : T.Stable.V1.t\n }\n [@@deriving equal, sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let state_hash { state_hash; _ } = state_hash\n\n let state_body_hash t ~compute_hashes =\n match t.state_body_hash with\n | Some state_body_hash ->\n state_body_hash\n | None ->\n let { state_hash; state_body_hash } = compute_hashes () in\n assert (T.equal state_hash t.state_hash) ;\n assert (Option.is_some state_body_hash) ;\n t.state_body_hash <- state_body_hash ;\n Option.value_exn state_body_hash\nend\n\nmodule With_state_hashes = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, State_hashes.Stable.V1.t) With_hash.Stable.V1.t\n [@@deriving equal, sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n type 'a t = ('a, State_hashes.t) With_hash.t\n [@@deriving equal, sexp, to_yojson]\n\n open With_hash\n open State_hashes.Stable.Latest\n\n let data { data; _ } = data\n\n let hashes { hash = hashes; _ } = hashes\n\n let state_hash { hash = { state_hash; _ }; _ } = state_hash\n\n let state_body_hash { hash; data } ~compute_hashes =\n State_hashes.state_body_hash hash ~compute_hashes:(fun () ->\n compute_hashes data )\nend\n","(* verification_key_wire.ml *)\n\nopen Core_kernel\nopen Zkapp_basic\n\n(* the digest functions are declared locally in Zkapp_account, which depends on\n this module; the definitions here avoid a cyclic dependency\n*)\n\nlet digest_vk (t : Side_loaded_verification_key.t) =\n Random_oracle.(\n hash ~init:Hash_prefix_states.side_loaded_vk\n (pack_input (Side_loaded_verification_key.to_input t)))\n\nlet dummy_vk_hash =\n Memo.unit (fun () -> digest_vk Side_loaded_verification_key.dummy)\n\n[%%versioned_binable\nmodule Stable = struct\n module V1 = struct\n module T = struct\n type t = (Side_loaded_verification_key.t, F.t) With_hash.t\n [@@deriving sexp, yojson, equal, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n module M = struct\n type nonrec t = t\n\n (* don't send hash over the wire; restore hash on receipt *)\n\n let to_binable (t : t) = t.data\n\n let of_binable vk : t =\n let data = vk in\n let hash = digest_vk vk in\n { data; hash }\n end\n\n include\n Binable.Of_binable_without_uuid\n (Side_loaded_verification_key.Stable.V2)\n (M)\n end\nend]\n","open Core_kernel\nopen Mina_base_import\nopen Snark_params\nopen Snarky_backendless\nopen Tick\nopen Let_syntax\n\nlet merge_var ~height h1 h2 =\n Random_oracle.Checked.hash ~init:(Hash_prefix.merkle_tree height) [| h1; h2 |]\n\nmodule Merkle_tree =\n Snarky_backendless.Merkle_tree.Checked\n (Tick)\n (struct\n type value = Field.t\n\n type var = Field.Var.t\n\n let typ = Field.typ\n\n let merge ~height h1 h2 =\n Tick.make_checked (fun () -> merge_var ~height h1 h2)\n\n let assert_equal h1 h2 = Field.Checked.Assert.equal h1 h2\n\n let if_ = Field.Checked.if_\n end)\n (struct\n include Account\n\n let hash = Checked.digest\n end)\n\ninclude Ledger_hash0\n\n(* End boilerplate *)\nlet merge ~height (h1 : t) (h2 : t) =\n Random_oracle.hash\n ~init:(Hash_prefix.merkle_tree height)\n [| (h1 :> field); (h2 :> field) |]\n |> of_hash\n\nlet empty_hash = of_hash Outside_hash_image.t\n\nlet%bench \"Ledger_hash.merge ~height:1 empty_hash empty_hash\" =\n merge ~height:1 empty_hash empty_hash\n\nlet of_digest = Fn.compose Fn.id of_hash\n\ntype path = Random_oracle.Digest.t list\n\ntype _ Request.t +=\n | Get_path : Account.Index.t -> path Request.t\n | Get_element : Account.Index.t -> (Account.t * path) Request.t\n | Set : Account.Index.t * Account.t -> unit Request.t\n | Find_index : Account_id.t -> Account.Index.t Request.t\n\nlet reraise_merkle_requests (With { request; respond }) =\n match request with\n | Merkle_tree.Get_path addr ->\n respond (Delegate (Get_path addr))\n | Merkle_tree.Set (addr, account) ->\n respond (Delegate (Set (addr, account)))\n | Merkle_tree.Get_element addr ->\n respond (Delegate (Get_element addr))\n | _ ->\n unhandled\n\nlet get ~depth t addr =\n handle\n (fun () -> Merkle_tree.get_req ~depth (var_to_hash_packed t) addr)\n reraise_merkle_requests\n\n(*\n [modify_account t aid ~filter ~f] implements the following spec:\n\n - finds an account [account] in [t] for [aid] at path [addr] where [filter\n account] holds.\n note that the account is not guaranteed to have identifier [aid]; it might\n be a new account created to satisfy this request.\n - returns a root [t'] of a tree of depth [depth] which is [t] but with the\n account [f account] at path [addr].\n*)\nlet%snarkydef_ modify_account ~depth t aid\n ~(filter : Account.var -> 'a Checked.t) ~f =\n let%bind addr =\n request_witness\n (Account.Index.Unpacked.typ ~ledger_depth:depth)\n As_prover.(map (read Account_id.typ aid) ~f:(fun s -> Find_index s))\n in\n handle\n (fun () ->\n Merkle_tree.modify_req ~depth (var_to_hash_packed t) addr\n ~f:(fun account ->\n let%bind x = filter account in\n f x account ) )\n reraise_merkle_requests\n >>| var_of_hash_packed\n\n(*\n [modify_account_send t aid ~f] implements the following spec:\n\n - finds an account [account] in [t] at path [addr] whose account id is [aid]\n OR it is a fee transfer and is an empty account\n - returns a root [t'] of a tree of depth [depth] which is [t] but with the\n account [f account] at path [addr].\n*)\nlet%snarkydef_ modify_account_send ~depth t aid ~is_writeable ~f =\n modify_account ~depth t aid\n ~filter:(fun account ->\n [%with_label_ \"modify_account_send filter\"] (fun () ->\n let%bind account_already_there =\n Account_id.Checked.equal (Account.identifier_of_var account) aid\n in\n let%bind account_not_there =\n Public_key.Compressed.Checked.equal account.public_key\n Public_key.Compressed.(var_of_t empty)\n in\n let%bind not_there_but_writeable =\n Boolean.(account_not_there && is_writeable)\n in\n let%bind () =\n [%with_label_ \"account is either present or empty and writeable\"]\n (fun () ->\n Boolean.Assert.any\n [ account_already_there; not_there_but_writeable ] )\n in\n return not_there_but_writeable ) )\n ~f:(fun is_empty_and_writeable x -> f ~is_empty_and_writeable x)\n\n(*\n [modify_account_recv t aid ~f] implements the following spec:\n\n - finds an account [account] in [t] at path [addr] whose account id is [aid]\n OR which is an empty account\n - returns a root [t'] of a tree of depth [depth] which is [t] but with the\n account [f account] at path [addr].\n*)\nlet%snarkydef_ modify_account_recv ~depth t aid ~f =\n modify_account ~depth t aid\n ~filter:(fun account ->\n [%with_label_ \"modify_account_recv filter\"] (fun () ->\n let%bind account_already_there =\n Account_id.Checked.equal (Account.identifier_of_var account) aid\n in\n let%bind account_not_there =\n Public_key.Compressed.Checked.equal account.public_key\n Public_key.Compressed.(var_of_t empty)\n in\n let%bind () =\n [%with_label_ \"account is either present or empty\"] (fun () ->\n Boolean.Assert.any [ account_already_there; account_not_there ] )\n in\n return account_not_there ) )\n ~f:(fun is_empty_and_writeable x -> f ~is_empty_and_writeable x)\n","open Snark_params\nopen Snarky_backendless\nopen Tick\n\nmodule type S = sig\n include Ledger_hash_intf0.S\n\n type path = Random_oracle.Digest.t list\n\n type _ Request.t +=\n | Get_path : Account.Index.t -> path Request.t\n | Get_element : Account.Index.t -> (Account.t * path) Request.t\n | Set : Account.Index.t * Account.t -> unit Request.t\n | Find_index : Account_id.t -> Account.Index.t Request.t\n\n val get :\n depth:int -> var -> Account.Index.Unpacked.var -> Account.var Checked.t\n\n val merge : height:int -> t -> t -> t\n\n (** string representation of hash is Base58Check of bin_io representation *)\n val to_base58_check : t -> string\n\n val of_base58_check : string -> t Base.Or_error.t\n\n val empty_hash : t\n\n val of_digest : Random_oracle.Digest.t -> t\n\n val modify_account :\n depth:int\n -> var\n -> Account_id.var\n -> filter:(Account.var -> 'a Checked.t)\n -> f:('a -> Account.var -> Account.var Checked.t)\n -> var Checked.t\n\n val modify_account_send :\n depth:int\n -> var\n -> Account_id.var\n -> is_writeable:Boolean.var\n -> f:\n ( is_empty_and_writeable:Boolean.var\n -> Account.var\n -> Account.var Checked.t )\n -> var Checked.t\n\n val modify_account_recv :\n depth:int\n -> var\n -> Account_id.var\n -> f:\n ( is_empty_and_writeable:Boolean.var\n -> Account.var\n -> Account.var Checked.t )\n -> var Checked.t\nend\n","include Ledger_hash\n\nlet of_ledger_hash (h : Ledger_hash.t) : t = h\n\nlet to_ledger_hash (t : t) : Ledger_hash.t = t\n","open Core_kernel\n\nmodule type S = sig\n module Stable : sig\n module V1 : sig\n type t = private Zkapp_basic.F.t\n\n val to_yojson : t -> Yojson.Safe.t\n\n val of_yojson : Yojson.Safe.t -> t Ppx_deriving_yojson_runtime.error_or\n\n val bin_size_t : t Bin_prot.Size.sizer\n\n val bin_write_t : t Bin_prot.Write.writer\n\n val bin_read_t : t Bin_prot.Read.reader\n\n val __bin_read_t__ : (int -> t) Bin_prot.Read.reader\n\n val bin_shape_t : Bin_prot.Shape.t\n\n val bin_writer_t : t Bin_prot.Type_class.writer\n\n val bin_reader_t : t Bin_prot.Type_class.reader\n\n val bin_t : t Bin_prot.Type_class.t\n\n val __versioned__ : unit\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n val compare : t -> t -> int\n\n val equal : t -> t -> bool\n\n val hash_fold_t :\n Base_internalhash_types.state -> t -> Base_internalhash_types.state\n\n val hash : t -> int\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n\n val to_yojson : t -> Yojson.Safe.t\n\n val of_yojson : Yojson.Safe.t -> t Ppx_deriving_yojson_runtime.error_or\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n val compare : t -> t -> int\n\n val equal : t -> t -> bool\n\n val hash_fold_t :\n Base_internalhash_types.state -> t -> Base_internalhash_types.state\n\n val hash : t -> int\nend\n\nmodule type S_checked = sig\n open Pickles.Impls.Step\n\n type t = private Field.t\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t\n\n val equal : t -> t -> Boolean.var\n\n module Assert : sig\n val equal : t -> t -> unit\n end\nend\n\nmodule type S_aux = sig\n type t\n\n type checked\n\n val typ : (checked, t) Pickles.Impls.Step.Typ.t\n\n val constant : t -> checked\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'comm t = { account_update : 'comm; calls : 'comm }\n [@@deriving hlist, sexp, yojson]\n end\n end]\n\n let to_field_elements (t : 'c t) : 'c array =\n let [ x0; x1 ] = to_hlist t in\n [| x0; x1 |]\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Zkapp_command.Transaction_commitment.Stable.V1.t Poly.Stable.V1.t\n [@@deriving sexp, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\nlet to_field_elements : t -> _ = Poly.to_field_elements\n\nlet of_tree (type account_update)\n ({ account_update = _; account_update_digest; calls } :\n ( account_update\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.Tree.t ) : t =\n { account_update =\n (account_update_digest :> Zkapp_command.Transaction_commitment.t)\n ; calls =\n ( Zkapp_command.Call_forest.hash calls\n :> Zkapp_command.Transaction_commitment.t )\n }\n\nlet zkapp_statements_of_forest' (type data)\n (forest : data Zkapp_command.Call_forest.With_hashes_and_data.t) :\n (data * t) Zkapp_command.Call_forest.With_hashes_and_data.t =\n Zkapp_command.Call_forest.mapi_with_trees forest\n ~f:(fun _i (account_update, data) tree ->\n (account_update, (data, of_tree tree)) )\n\nlet zkapp_statements_of_forest (type account_update)\n (forest : (account_update, _, _) Zkapp_command.Call_forest.t) :\n (account_update * t, _, _) Zkapp_command.Call_forest.t =\n Zkapp_command.Call_forest.mapi_with_trees forest\n ~f:(fun _i account_update tree -> (account_update, of_tree tree))\n\n[%%ifdef consensus_mechanism]\n\nmodule Checked = struct\n type t = Zkapp_command.Transaction_commitment.Checked.t Poly.t\n\n let to_field_elements : t -> _ = Poly.to_field_elements\n\n open Pickles.Impls.Step\n\n module Assert = struct\n let equal (t1 : t) (t2 : t) =\n Array.iter2_exn ~f:Field.Assert.equal (to_field_elements t1)\n (to_field_elements t2)\n end\nend\n\nlet typ =\n let open Poly in\n Typ.of_hlistable\n Zkapp_command.Transaction_commitment.[ typ; typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n[%%endif]\n","open Snark_params.Tick.Run\n\ntype 'a t = 'a As_prover.Ref.t\n\nlet get = As_prover.Ref.get\n\nlet create = As_prover.Ref.create\n\nlet if_ b ~then_ ~else_ =\n create (fun () ->\n get (if Impl.As_prover.read Boolean.typ b then then_ else else_) )\n\nlet map t ~f = create (fun () -> f (get t))\n\nlet typ = Typ.Internal.ref\n","open Core_kernel\n\n(* Same as the type of the field account_updates in Mina_base.Zkapp_command.t *)\ntype t =\n ( Account_update.t\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.t\n\ntype account_update =\n (Account_update.t, Zkapp_command.Digest.Account_update.t) With_hash.t\n\nlet empty () = []\n\nlet if_ = Zkapp_command.value_if\n\nlet is_empty = List.is_empty\n\nlet pop_exn : t -> (Account_update.t * t) * t = function\n | { stack_hash = _\n ; elt = { account_update; calls; account_update_digest = _ }\n }\n :: xs ->\n ((account_update, calls), xs)\n | _ ->\n failwith \"pop_exn\"\n\nlet push ~account_update ~calls t =\n Zkapp_command.Call_forest.cons ~calls account_update t\n\nlet hash (t : t) = Zkapp_command.Call_forest.hash t\n\nopen Snark_params.Tick.Run\n\nmodule Checked = struct\n module F = Zkapp_command.Digest.Forest.Checked\n module V = Prover_value\n\n type account_update =\n { account_update :\n ( Account_update.Body.Checked.t\n , Zkapp_command.Digest.Account_update.Checked.t )\n With_hash.t\n ; control : Control.t Prover_value.t\n }\n\n let account_update_typ () :\n ( account_update\n , (Account_update.t, Zkapp_command.Digest.Account_update.t) With_hash.t\n )\n Typ.t =\n let (Typ typ) =\n Typ.(\n Account_update.Body.typ () * Prover_value.typ ()\n * Zkapp_command.Digest.Account_update.typ)\n |> Typ.transport\n ~back:(fun ((body, authorization), hash) ->\n { With_hash.data = { Account_update.body; authorization }; hash }\n )\n ~there:(fun { With_hash.data = { Account_update.body; authorization }\n ; hash\n } -> ((body, authorization), hash) )\n |> Typ.transport_var\n ~back:(fun ((account_update, control), hash) ->\n { account_update = { hash; data = account_update }; control } )\n ~there:(fun { account_update = { hash; data = account_update }\n ; control\n } -> ((account_update, control), hash) )\n in\n Typ\n { typ with\n check =\n (fun ( { account_update = { hash; data = account_update }\n ; control = _\n } as x ) ->\n Impl.make_checked (fun () ->\n Impl.run_checked (typ.check x) ;\n Field.Assert.equal\n (hash :> Field.t)\n ( Zkapp_command.Call_forest.Digest.Account_update.Checked\n .create account_update\n :> Field.t ) ) )\n }\n\n type t =\n ( ( Account_update.t\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.t\n V.t\n , F.t )\n With_hash.t\n\n let if_ b ~then_:(t : t) ~else_:(e : t) : t =\n { hash = F.if_ b ~then_:t.hash ~else_:e.hash\n ; data = V.if_ b ~then_:t.data ~else_:e.data\n }\n\n let empty =\n Zkapp_command.Digest.Forest.constant\n Zkapp_command.Call_forest.With_hashes.empty\n\n let is_empty ({ hash = x; _ } : t) = F.equal empty x\n\n let empty () : t = { hash = empty; data = V.create (fun () -> []) }\n\n let pop_exn ({ hash = h; data = r } : t) : (account_update * t) * t =\n with_label \"Zkapp_call_forest.pop_exn\" (fun () ->\n let hd_r =\n V.create (fun () -> V.get r |> List.hd_exn |> With_stack_hash.elt)\n in\n let account_update = V.create (fun () -> (V.get hd_r).account_update) in\n let auth =\n V.(create (fun () -> (V.get account_update).authorization))\n in\n let account_update =\n exists (Account_update.Body.typ ()) ~compute:(fun () ->\n (V.get account_update).body )\n in\n let account_update =\n With_hash.of_data account_update\n ~hash_data:Zkapp_command.Digest.Account_update.Checked.create\n in\n let subforest : t =\n let subforest = V.create (fun () -> (V.get hd_r).calls) in\n let subforest_hash =\n exists Zkapp_command.Digest.Forest.typ ~compute:(fun () ->\n Zkapp_command.Call_forest.hash (V.get subforest) )\n in\n { hash = subforest_hash; data = subforest }\n in\n let tl_hash =\n exists Zkapp_command.Digest.Forest.typ ~compute:(fun () ->\n V.get r |> List.tl_exn |> Zkapp_command.Call_forest.hash )\n in\n let tree_hash =\n Zkapp_command.Digest.Tree.Checked.create\n ~account_update:account_update.hash ~calls:subforest.hash\n in\n let hash_cons =\n Zkapp_command.Digest.Forest.Checked.cons tree_hash tl_hash\n in\n F.Assert.equal hash_cons h ;\n ( ( ({ account_update; control = auth }, subforest)\n , { hash = tl_hash\n ; data = V.(create (fun () -> List.tl_exn (get r)))\n } )\n : (account_update * t) * t ) )\n\n let pop ~dummy ~dummy_tree_hash ({ hash = h; data = r } : t) :\n (account_update * t) * t =\n with_label \"Zkapp_call_forest.pop\" (fun () ->\n let hd_r =\n V.create (fun () ->\n match V.get r with\n | hd :: _ ->\n With_stack_hash.elt hd\n | [] ->\n dummy )\n in\n let account_update = V.create (fun () -> (V.get hd_r).account_update) in\n let auth =\n V.(create (fun () -> (V.get account_update).authorization))\n in\n let account_update =\n exists (Account_update.Body.typ ()) ~compute:(fun () ->\n (V.get account_update).body )\n in\n let account_update =\n With_hash.of_data account_update\n ~hash_data:Zkapp_command.Digest.Account_update.Checked.create\n in\n let subforest : t =\n let subforest = V.create (fun () -> (V.get hd_r).calls) in\n let subforest_hash =\n exists Zkapp_command.Digest.Forest.typ ~compute:(fun () ->\n Zkapp_command.Call_forest.hash (V.get subforest) )\n in\n { hash = subforest_hash; data = subforest }\n in\n let tl_hash =\n exists Zkapp_command.Digest.Forest.typ ~compute:(fun () ->\n match V.get r with\n | _ :: tl ->\n Zkapp_command.Call_forest.hash tl\n | [] ->\n Zkapp_command.Digest.Forest.empty )\n in\n let tree_hash =\n Zkapp_command.Digest.Tree.Checked.create\n ~account_update:account_update.hash ~calls:subforest.hash\n in\n let hash_cons =\n Zkapp_command.Digest.Forest.Checked.cons tree_hash tl_hash\n in\n let () =\n let correct = F.equal hash_cons h in\n let empty = F.equal F.empty h in\n let is_dummy =\n Zkapp_command.Digest.Tree.Checked.equal tree_hash dummy_tree_hash\n in\n Boolean.(Assert.any [ correct; empty &&& is_dummy ])\n in\n ( ( ({ account_update; control = auth }, subforest)\n , { hash = tl_hash\n ; data =\n V.(\n create (fun () ->\n match get r with _ :: tl -> tl | [] -> [] ))\n } )\n : (account_update * t) * t ) )\n\n let push\n ~account_update:\n { account_update = { hash = account_update_hash; data = account_update }\n ; control = auth\n } ~calls:({ hash = calls_hash; data = calls } : t)\n ({ hash = tl_hash; data = tl_data } : t) : t =\n with_label \"Zkapp_call_forest.push\" (fun () ->\n let tree_hash =\n Zkapp_command.Digest.Tree.Checked.create\n ~account_update:account_update_hash ~calls:calls_hash\n in\n let hash_cons =\n Zkapp_command.Digest.Forest.Checked.cons tree_hash tl_hash\n in\n let data =\n V.create (fun () ->\n let body =\n As_prover.read (Account_update.Body.typ ()) account_update\n in\n let authorization = V.get auth in\n let tl = V.get tl_data in\n let account_update : Account_update.t = { body; authorization } in\n let calls = V.get calls in\n let res =\n Zkapp_command.Call_forest.cons ~calls account_update tl\n in\n (* Sanity check; we're re-hashing anyway, might as well make sure it's\n consistent.\n *)\n assert (\n Zkapp_command.Digest.Forest.(\n equal\n (As_prover.read typ hash_cons)\n (Zkapp_command.Call_forest.hash res)) ) ;\n res )\n in\n ({ hash = hash_cons; data } : t) )\n\n let hash ({ hash; _ } : t) = hash\nend\n\nlet typ : (Checked.t, t) Typ.t =\n Typ.(Zkapp_command.Digest.Forest.typ * Prover_value.typ ())\n |> Typ.transport\n ~back:(fun (_digest, forest) ->\n Zkapp_command.Call_forest.map\n ~f:(fun account_update -> account_update)\n forest )\n ~there:(fun forest ->\n ( Zkapp_command.Call_forest.hash forest\n , Zkapp_command.Call_forest.map\n ~f:(fun account_update -> account_update)\n forest ) )\n |> Typ.transport_var\n ~back:(fun (digest, forest) -> { With_hash.hash = digest; data = forest })\n ~there:(fun { With_hash.hash = digest; data = forest } ->\n (digest, forest) )\n","open Core_kernel\nopen Mina_base_import\n\nmodule type Full = sig\n module Single : sig\n module Stable : sig\n module V2 : sig\n type t = private\n { receiver_pk : Public_key.Compressed.Stable.V1.t\n ; fee : Currency.Fee.Stable.V1.t\n ; fee_token : Token_id.Stable.V2.t\n }\n [@@deriving bin_io, sexp, compare, equal, yojson, version, hash]\n end\n\n module Latest = V2\n end\n\n type t = Stable.Latest.t = private\n { receiver_pk : Public_key.Compressed.t\n ; fee : Currency.Fee.t\n ; fee_token : Token_id.t\n }\n [@@deriving sexp, compare, yojson, hash]\n\n include Comparable.S with type t := t\n\n include Codable.Base58_check_intf with type t := t\n\n val create :\n receiver_pk:Public_key.Compressed.t\n -> fee:Currency.Fee.t\n -> fee_token:Token_id.t\n -> t\n\n val receiver_pk : t -> Public_key.Compressed.t\n\n val receiver : t -> Account_id.t\n\n val fee : t -> Currency.Fee.t\n\n val fee_token : t -> Token_id.t\n\n module Gen : sig\n val with_random_receivers :\n ?min_fee:int\n -> max_fee:int\n -> token:Token_id.t Quickcheck.Generator.t\n -> Signature_keypair.t array\n -> t Quickcheck.Generator.t\n end\n end\n\n module Stable : sig\n module V2 : sig\n type t = private Single.Stable.V2.t One_or_two.Stable.V1.t\n [@@deriving bin_io, sexp, compare, equal, yojson, version, hash]\n end\n\n module Latest = V2\n end\n\n type t = Stable.Latest.t [@@deriving sexp, compare, yojson, hash]\n\n type single = Single.t = private\n { receiver_pk : Public_key.Compressed.t\n ; fee : Currency.Fee.t\n ; fee_token : Token_id.t\n }\n [@@deriving sexp, compare, yojson, hash]\n\n include Comparable.S with type t := t\n\n val create : Single.t -> Single.t option -> t Or_error.t\n\n val create_single :\n receiver_pk:Public_key.Compressed.t\n -> fee:Currency.Fee.t\n -> fee_token:Token_id.t\n -> t\n\n val to_singles : t -> Single.t One_or_two.t\n\n val of_singles : Single.t One_or_two.t -> t Or_error.t\n\n val fee_excess : t -> Fee_excess.t Or_error.t\n\n val fee_token : single -> Token_id.t\n\n val fee_tokens : t -> Token_id.t One_or_two.t\n\n val receiver_pks : t -> Public_key.Compressed.t list\n\n val receivers : t -> Account_id.t list\n\n val fee_payer_pk : t -> Public_key.Compressed.t\n\n val map : t -> f:(Single.t -> 'b) -> 'b One_or_two.t\n\n val fold : t -> init:'acc -> f:('acc -> Single.t -> 'acc) -> 'acc\n\n val to_list : t -> Single.t list\n\n val to_numbered_list : t -> (int * Single.t) list\nend\n","open Core_kernel\nopen Mina_base_import\n\nmodule type Full = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t = private\n { receiver_pk : Public_key.Compressed.Stable.V1.t\n ; fee : Currency.Fee.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n\n val create : receiver_pk:Public_key.Compressed.t -> fee:Currency.Fee.t -> t\n\n include Comparable.S with type t := t\n\n include Codable.Base58_check_intf with type t := t\n\n val receiver_pk : t -> Public_key.Compressed.t\n\n val receiver : t -> Account_id.t\n\n val fee : t -> Currency.Fee.t\n\n val to_fee_transfer : t -> Fee_transfer.Single.t\n\n module Gen : sig\n (** [gen ?min_fee max_fee] generates fee transfers between [min_fee] and\n [max_fee].\n\n @param min_fee defaults to zero *)\n val gen :\n ?min_fee:Currency.Fee.t -> Currency.Fee.t -> t Quickcheck.Generator.t\n\n (** [with_random_receivers ~key ?min_fee coinbase_amount] creates coinbase\n fee transfers with fees between [min_fee] and [coinbase_amount]\n\n @param min_fee defaults to {!val:Currency.Fee.zero}\n *)\n val with_random_receivers :\n keys:Signature_keypair.t array\n -> ?min_fee:Currency.Fee.t\n -> Currency.Amount.t\n -> t Quickcheck.Generator.t\n end\nend\n","open Core_kernel\nopen Mina_base_import\n\nmodule type Full = sig\n module Fee_transfer = Coinbase_fee_transfer\n\n module Stable : sig\n module V1 : sig\n type t = private\n { receiver : Public_key.Compressed.Stable.V1.t\n ; amount : Currency.Amount.Stable.V1.t\n ; fee_transfer : Fee_transfer.Stable.V1.t option\n }\n [@@deriving sexp, bin_io, compare, equal, version, hash, yojson]\n end\n\n module Latest = V1\n end\n\n (* bin_io intentionally omitted in deriving list *)\n type t = Stable.Latest.t = private\n { receiver : Public_key.Compressed.t\n ; amount : Currency.Amount.t\n ; fee_transfer : Fee_transfer.t option\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n include Codable.Base58_check_intf with type t := t\n\n val receiver_pk : t -> Public_key.Compressed.t\n\n val receiver : t -> Account_id.t\n\n val fee_payer_pk : t -> Public_key.Compressed.t\n\n val amount : t -> Currency.Amount.t\n\n val fee_transfer : t -> Fee_transfer.t option\n\n val account_access_statuses :\n t\n -> Transaction_status.t\n -> (Account_id.t * [ `Accessed | `Not_accessed ]) list\n\n val accounts_referenced : t -> Account_id.t list\n\n val create :\n amount:Currency.Amount.t\n -> receiver:Public_key.Compressed.t\n -> fee_transfer:Fee_transfer.t option\n -> t Or_error.t\n\n val expected_supply_increase : t -> Currency.Amount.t Or_error.t\n\n val fee_excess : t -> Fee_excess.t Or_error.t\n\n module Gen : sig\n val gen :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> (t * [ `Supercharged_coinbase of bool ]) Quickcheck.Generator.t\n\n (** Creates coinbase with reward between [min_amount] and [max_amount]. The generated amount[coinbase_amount] is then used as the upper bound for the fee transfer. *)\n val with_random_receivers :\n keys:Signature_keypair.t array\n -> min_amount:int\n -> max_amount:int\n -> fee_transfer:\n ( coinbase_amount:Currency.Amount.t\n -> Fee_transfer.t Quickcheck.Generator.t )\n -> t Quickcheck.Generator.t\n end\nend\n","(** Pending_coinbase is to keep track of all the coinbase transactions that have been applied to the ledger but for which there is no ledger proof yet. Every ledger proof corresponds to a sequence of coinbase transactions which is part of all the transactions it proves. Each of these sequences[Stack] are stored using the merkle tree representation. The stacks are operated in a FIFO manner by keeping track of its positions in the merkle tree. Whenever a ledger proof is emitted, the oldest stack is removed from the tree and when a new coinbase is applied, the latest stack is updated with the new coinbase.\n The operations on the merkle tree of coinbase stacks include:\n 1) adding a new singleton stack\n 2) updating the latest stack when a new coinbase is added to it\n 2) deleting the oldest stack\n\n A stack can be either be created or modified by pushing a coinbase on to it.\n\n This module also provides an interface for the checked computations required required to prove it in snark\n\n Stack operations are done for transaction snarks and tree operations are done for the blockchain snark*)\n\nopen Core_kernel\nopen Snark_params\nopen Snarky_backendless\nopen Tick\nopen Signature_lib\nopen Currency\n\nmodule type S = sig\n type t [@@deriving sexp, to_yojson]\n\n module Stable : sig\n module V2 : sig\n type nonrec t = t [@@deriving bin_io, sexp, to_yojson, version]\n end\n\n module Latest = V2\n end\n\n module Coinbase_data : sig\n module Stable : sig\n module V1 : sig\n type t = Public_key.Compressed.Stable.V1.t * Amount.Stable.V1.t\n [@@deriving sexp, bin_io, to_yojson]\n end\n\n module Latest = V1\n end\n\n type t = Stable.Latest.t [@@deriving sexp, to_yojson]\n\n type var = Public_key.Compressed.var * Amount.var\n\n val typ : (var, t) Typ.t\n\n val empty : t\n\n val of_coinbase : Coinbase.t -> t\n\n val genesis : t\n\n val var_of_t : t -> var\n end\n\n module type Data_hash_intf = sig\n type t = private Field.t [@@deriving sexp, compare, equal, yojson, hash]\n\n type var\n\n val var_of_t : t -> var\n\n val typ : (var, t) Typ.t\n\n val var_to_hash_packed : var -> Field.Var.t\n\n val equal_var : var -> var -> Boolean.var Tick.Checked.t\n\n val to_bytes : t -> string\n\n val to_bits : t -> bool list\n\n val to_base58_check : t -> string\n\n val of_base58_check_exn : string -> t\n\n val gen : t Quickcheck.Generator.t\n end\n\n module rec Hash : sig\n include Data_hash_intf\n\n val merge : height:int -> t -> t -> t\n\n val empty_hash : t\n\n val of_digest : Random_oracle.Digest.t -> t\n end\n\n module Hash_versioned : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type nonrec t = Hash.t [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n end\n\n module Stack_versioned : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type nonrec t [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n end\n\n module Stack : sig\n type t = Stack_versioned.t [@@deriving sexp, compare, equal, yojson, hash]\n\n type var\n\n val data_hash : t -> Hash.t\n\n val var_of_t : t -> var\n\n val typ : (var, t) Typ.t\n\n val gen : t Quickcheck.Generator.t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val to_bits : t -> bool list\n\n val to_bytes : t -> string\n\n val equal_var : var -> var -> Boolean.var Tick.Checked.t\n\n val var_to_input : var -> Field.Var.t Random_oracle.Input.Chunked.t\n\n val empty : t\n\n (** Creates a new stack with the state stack from an existing stack*)\n val create_with : t -> t\n\n val equal_data : t -> t -> bool\n\n val equal_state_hash : t -> t -> bool\n\n (** The two stacks are connected. This should be used instead of `equal` to\n check one transaction snark statement follow the other.*)\n val connected : ?prev:t option -> first:t -> second:t -> unit -> bool\n\n val push_coinbase : Coinbase.t -> t -> t\n\n val push_state :\n State_body_hash.t -> Mina_numbers.Global_slot_since_genesis.t -> t -> t\n\n module Checked : sig\n type t = var\n\n val push_coinbase : Coinbase_data.var -> t -> t Tick.Checked.t\n\n val push_state :\n State_body_hash.var\n -> Mina_numbers.Global_slot_since_genesis.Checked.var\n -> t\n -> t Tick.Checked.t\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t Tick.Checked.t\n\n val check_merge :\n transition1:t * t -> transition2:t * t -> Boolean.var Tick.Checked.t\n\n val empty : t\n\n val create_with : t -> t\n end\n end\n\n module State_stack : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t\n end\n end]\n end\n\n module Update : sig\n module Action : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t =\n | Update_none\n | Update_one\n | Update_two_coinbase_in_first\n | Update_two_coinbase_in_second\n [@@deriving sexp, to_yojson]\n end\n end]\n\n type var = Boolean.var * Boolean.var\n\n val typ : (var, t) Typ.t\n\n val var_of_t : t -> var\n end\n\n module Poly : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type ('action, 'coinbase_amount) t =\n { action : 'action; coinbase_amount : 'coinbase_amount }\n [@@deriving sexp]\n end\n end]\n end\n\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t = (Action.Stable.V1.t, Amount.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving sexp, to_yojson]\n end\n end]\n\n type var = (Action.var, Amount.var) Poly.t\n\n val genesis : t\n\n val typ : (var, t) Typ.t\n\n val var_of_t : t -> var\n end\n\n val create : depth:int -> unit -> t Or_error.t\n\n (** Delete the oldest stack*)\n val remove_coinbase_stack : depth:int -> t -> (Stack.t * t) Or_error.t\n\n (** Root of the merkle tree that has stacks as leaves*)\n val merkle_root : t -> Hash.t\n\n val handler :\n depth:int -> t -> is_new_stack:bool -> (request -> response) Staged.t\n\n (** Update the current working stack or if [is_new_stack] add as the new working stack*)\n val update_coinbase_stack :\n depth:int -> t -> Stack.t -> is_new_stack:bool -> t Or_error.t\n\n (** Stack that is currently being updated. if [is_new_stack] then a new stack is returned*)\n val latest_stack : t -> is_new_stack:bool -> Stack.t Or_error.t\n\n (** The stack that corresponds to the next ledger proof that is to be generated*)\n val oldest_stack : t -> Stack.t Or_error.t\n\n (** Hash of the auxiliary data (everything except the merkle root (Hash.t))*)\n val hash_extra : t -> string\n\n module Checked : sig\n type var = Hash.var\n\n type path\n\n module Address : sig\n type value\n\n type var\n\n val typ : depth:int -> (var, value) Typ.t\n end\n\n type _ Request.t +=\n | Coinbase_stack_path : Address.value -> path Request.t\n | Get_coinbase_stack : Address.value -> (Stack.t * path) Request.t\n | Set_coinbase_stack : Address.value * Stack.t -> unit Request.t\n | Set_oldest_coinbase_stack : Address.value * Stack.t -> unit Request.t\n | Find_index_of_newest_stacks :\n Update.Action.t\n -> (Address.value * Address.value) Request.t\n | Find_index_of_oldest_stack : Address.value Request.t\n | Get_previous_stack : State_stack.t Request.t\n\n val get : depth:int -> var -> Address.var -> Stack.var Tick.Checked.t\n\n (**\n [update_stack t ~is_new_stack updated_stack] implements the following spec:\n - gets the address[addr] of the latest stack or a new stack\n - finds a coinbase stack in [t] at path [addr] and pushes the coinbase_data on to the stack\n - returns a root [t'] of the tree\n *)\n val add_coinbase :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> var\n -> Update.var\n -> coinbase_receiver:Public_key.Compressed.var\n -> supercharge_coinbase:Boolean.var\n -> State_body_hash.var\n -> Mina_numbers.Global_slot_since_genesis.Checked.t\n -> var Tick.Checked.t\n\n (**\n [pop_coinbases t pk updated_stack] implements the following spec:\n\n - gets the address[addr] of the oldest stack.\n - finds a coinbase stack in [t] at path [addr] and replaces it with empty stack if a [proof_emitted] is true\n - returns a root [t'] of the tree\n *)\n val pop_coinbases :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> var\n -> proof_emitted:Boolean.var\n -> (var * Stack.var) Tick.Checked.t\n end\nend\n","open Async_kernel\n\nlet run_in_thread f = Deferred.return (f ())\n\nlet block_on_async_exn f =\n let res = f () in\n match Async_kernel.Deferred.peek res with\n | Some res ->\n res\n | None ->\n failwith\n \"block_on_async_exn: Cannot block thread, and the deferred computation \\\n did not resolve immediately.\"\n","module type Full = sig\n open Core_kernel\n open Snark_params.Tick\n\n type t [@@deriving sexp, equal, compare, hash, yojson]\n\n include Hashable with type t := t\n\n type value [@@deriving sexp, equal, compare, hash]\n\n type var\n\n val var_of_t : t -> var\n\n val typ : (var, t) Typ.t\n\n val var_to_input : var -> Field.Var.t Random_oracle.Input.Chunked.t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val genesis :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> genesis_ledger_hash:Ledger_hash.t\n -> t\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving bin_io, sexp, equal, compare, hash, yojson, version]\n end\n\n module Latest : module type of V1\n end\n\n module Aux_hash : sig\n type t\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving bin_io, sexp, equal, compare, hash, yojson, version]\n end\n\n module Latest : module type of V1\n end\n\n val of_bytes : string -> t\n\n val to_bytes : t -> string\n\n val to_base58_check : t -> string\n\n val of_base58_check_exn : string -> t\n\n val compare : t -> t -> int\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n val dummy : t\n\n val of_sha256 : Digestif.SHA256.t -> t\n\n val gen : t Quickcheck.Generator.t\n end\n\n module Pending_coinbase_aux : sig\n type t\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving bin_io, sexp, equal, compare, hash, yojson, version]\n end\n\n module Latest : module type of V1\n end\n\n val to_base58_check : t -> string\n\n val of_base58_check_exn : string -> t\n\n val dummy : t\n end\n\n val ledger_hash : t -> Ledger_hash.t\n\n val aux_hash : t -> Aux_hash.t\n\n val pending_coinbase_aux : t -> Pending_coinbase_aux.t\n\n val pending_coinbase_hash : t -> Pending_coinbase.Hash.t\n\n val pending_coinbase_hash_var : var -> Pending_coinbase.Hash.var\n\n val of_aux_ledger_and_coinbase_hash :\n Aux_hash.t -> Ledger_hash.t -> Pending_coinbase.t -> t\nend\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type ('caller, 'zkapp_command) t =\n { caller : 'caller; caller_caller : 'caller; calls : 'zkapp_command }\n [@@deriving make, fields, sexp, yojson]\n end\nend]\n\ntype value =\n ( Token_id.t\n , ( Account_update.t\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.t )\n t\n\ntype ('caller, 'zkapp_command) frame = ('caller, 'zkapp_command) t\n\nlet empty : value =\n { caller = Token_id.default; caller_caller = Token_id.default; calls = [] }\n\nmodule type Stack_frame_digest_intf = sig\n include Digest_intf.S\n\n val create :\n ( Token_id.t\n , ( 'p\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.t )\n frame\n -> t\n\n val gen : t Quickcheck.Generator.t\n\n open Pickles.Impls.Step\n\n module Checked : sig\n include Digest_intf.S_checked\n\n val create :\n hash_zkapp_command:\n ('zkapp_command -> Zkapp_command.Digest.Forest.Checked.t)\n -> (Token_id.Checked.t, 'zkapp_command) frame\n -> t\n end\n\n val typ : (Checked.t, t) Typ.t\nend\n\nmodule Wire_types = Mina_wire_types.Mina_base.Stack_frame.Digest\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Stack_frame_digest_intf with type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Kimchi_backend.Pasta.Basic.Fp.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n open Pickles.Impls.Step\n\n let gen = Field.Constant.gen\n\n let to_input (type p)\n ({ caller; caller_caller; calls } :\n ( Token_id.t\n , ( p\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.t )\n frame ) =\n List.reduce_exn ~f:Random_oracle.Input.Chunked.append\n [ Token_id.to_input caller\n ; Token_id.to_input caller_caller\n ; Random_oracle.Input.Chunked.field\n (Zkapp_command.Call_forest.hash calls :> Field.Constant.t)\n ]\n\n let create frame =\n Random_oracle.hash ~init:Hash_prefix_states.account_update_stack_frame\n (Random_oracle.pack_input (to_input frame))\n\n module Checked = struct\n include Field\n\n let to_input (type zkapp_command)\n ~(hash_zkapp_command :\n zkapp_command -> Zkapp_command.Digest.Forest.Checked.t )\n ({ caller; caller_caller; calls } : _ frame) =\n List.reduce_exn ~f:Random_oracle.Input.Chunked.append\n [ Token_id.Checked.to_input caller\n ; Token_id.Checked.to_input caller_caller\n ; Random_oracle.Input.Chunked.field (hash_zkapp_command calls :> Field.t)\n ]\n\n let create ~hash_zkapp_command frame =\n Random_oracle.Checked.hash\n ~init:Hash_prefix_states.account_update_stack_frame\n (Random_oracle.Checked.pack_input (to_input ~hash_zkapp_command frame))\n end\n\n let typ = Field.typ\nend\n\nmodule Digest = Wire_types.Make (Make_sig) (Make_str)\n\nmodule Checked = struct\n type nonrec 'zkapp_command t = (Token_id.Checked.t, 'zkapp_command) t\n\n let if_ f b ~then_ ~else_ : _ t =\n { caller = Token_id.Checked.if_ b ~then_:then_.caller ~else_:else_.caller\n ; caller_caller =\n Token_id.Checked.if_ b ~then_:then_.caller_caller\n ~else_:else_.caller_caller\n ; calls = f b ~then_:then_.calls ~else_:else_.calls\n }\nend\n","open Core_kernel\nopen Mina_base_import\nopen Snark_params.Tick\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n ( Ledger_hash.Stable.V1.t\n , Account_id.Stable.V2.t\n , Account.Stable.V2.t )\n Sparse_ledger_lib.Sparse_ledger.T.Stable.V2.t\n [@@deriving yojson, sexp]\n\n let to_latest = Fn.id\n end\nend]\n\ntype sparse_ledger = t [@@deriving sexp, to_yojson]\n\nmodule Hash = struct\n include Ledger_hash\n\n let merge = Ledger_hash.merge\nend\n\nmodule Account = struct\n include Account\n\n let data_hash = Fn.compose Ledger_hash.of_digest Account.digest\nend\n\nmodule Global_state = struct\n type t =\n { first_pass_ledger : sparse_ledger\n ; second_pass_ledger : sparse_ledger\n ; fee_excess : Currency.Amount.Signed.t\n ; supply_increase : Currency.Amount.Signed.t\n ; protocol_state : Zkapp_precondition.Protocol_state.View.t\n ; block_global_slot : Mina_numbers.Global_slot_since_genesis.t\n }\n [@@deriving sexp, to_yojson]\nend\n\nmodule M = Sparse_ledger_lib.Sparse_ledger.Make (Hash) (Account_id) (Account)\n\ntype account_state = [ `Added | `Existed ] [@@deriving equal]\n\n(** Create a new 'empty' ledger.\n This ledger has an invalid root hash, and cannot be used except as a\n placeholder.\n*)\nlet empty ~depth () = M.of_hash ~depth Outside_hash_image.t\n\nmodule L = struct\n type t = M.t ref\n\n type location = int\n\n let get : t -> location -> Account.t option =\n fun t loc ->\n Option.try_with (fun () ->\n let account = M.get_exn !t loc in\n if Public_key.Compressed.(equal empty account.public_key) then None\n else Some account )\n |> Option.bind ~f:Fn.id\n\n let location_of_account : t -> Account_id.t -> location option =\n fun t id ->\n try\n let loc = M.find_index_exn !t id in\n let account = M.get_exn !t loc in\n if Public_key.Compressed.(equal empty account.public_key) then None\n else Some loc\n with _ -> None\n\n let set : t -> location -> Account.t -> unit =\n fun t loc a -> t := M.set_exn !t loc a\n\n let get_or_create_exn :\n t -> Account_id.t -> account_state * Account.t * location =\n fun t id ->\n let loc = M.find_index_exn !t id in\n let account = M.get_exn !t loc in\n if Public_key.Compressed.(equal empty account.public_key) then (\n let public_key = Account_id.public_key id in\n let account' : Account.t =\n { account with\n delegate = Some public_key\n ; public_key\n ; token_id = Account_id.token_id id\n }\n in\n set t loc account' ;\n (`Added, account', loc) )\n else (`Existed, account, loc)\n\n let get_or_create t id = Or_error.try_with (fun () -> get_or_create_exn t id)\n\n let get_or_create_account :\n t -> Account_id.t -> Account.t -> (account_state * location) Or_error.t =\n fun t id to_set ->\n Or_error.try_with (fun () ->\n let loc = M.find_index_exn !t id in\n let a = M.get_exn !t loc in\n if Public_key.Compressed.(equal empty a.public_key) then (\n set t loc to_set ;\n (`Added, loc) )\n else (`Existed, loc) )\n\n let create_new_account t id to_set =\n get_or_create_account t id to_set |> Or_error.map ~f:ignore\n\n let remove_accounts_exn : t -> Account_id.t list -> unit =\n fun _t _xs -> failwith \"remove_accounts_exn: not implemented\"\n\n let merkle_root : t -> Ledger_hash.t = fun t -> M.merkle_root !t\n\n let with_ledger : depth:int -> f:(t -> 'a) -> 'a =\n fun ~depth:_ ~f:_ -> failwith \"with_ledger: not implemented\"\n\n (** Create a new ledger mask 'on top of' the given ledger.\n\n Warning: For technical reasons, this mask cannot be applied directly to\n the parent ledger; instead, use\n [apply_mask parent_ledger ~masked:this_ledger] to update the parent\n ledger as necessary.\n *)\n let create_masked t = ref !t\n\n (** [apply_mask ledger ~masked] applies any updates in [masked] to the ledger\n [ledger]. [masked] should be created by calling [create_masked ledger].\n\n Warning: This function may behave unexpectedly if [ledger] was modified\n after calling [create_masked], or the given [ledger] was not used to\n create [masked].\n *)\n let apply_mask t ~masked = t := !masked\n\n (** Create a new 'empty' ledger.\n This ledger has an invalid root hash, and cannot be used except as a\n placeholder.\n *)\n let empty ~depth () = ref (empty ~depth ())\nend\n\n[%%define_locally\nM.\n ( of_hash\n , to_yojson\n , get_exn\n , path_exn\n , set_exn\n , find_index_exn\n , add_path\n , merkle_root\n , iteri )]\n\nlet of_root ~depth (h : Ledger_hash.t) =\n of_hash ~depth (Ledger_hash.of_digest (h :> Random_oracle.Digest.t))\n\nlet get_or_initialize_exn account_id t idx =\n let account = get_exn t idx in\n if Public_key.Compressed.(equal empty account.public_key) then\n let public_key = Account_id.public_key account_id in\n let token_id = Account_id.token_id account_id in\n let delegate =\n (* Only allow delegation if this account is for the default token. *)\n if Token_id.(equal default) token_id then Some public_key else None\n in\n ( `Added\n , { account with\n delegate\n ; public_key\n ; token_id = Account_id.token_id account_id\n } )\n else (`Existed, account)\n\nlet has_locked_tokens_exn ~global_slot ~account_id t =\n let idx = find_index_exn t account_id in\n let _, account = get_or_initialize_exn account_id t idx in\n Account.has_locked_tokens ~global_slot account\n\nlet merkle_root t = Ledger_hash.of_hash (merkle_root t :> Random_oracle.Digest.t)\n\nlet depth t = M.depth t\n\nlet handler t =\n let ledger = ref t in\n let path_exn idx =\n List.map (path_exn !ledger idx) ~f:(function `Left h -> h | `Right h -> h)\n in\n stage (fun (With { request; respond }) ->\n match request with\n | Ledger_hash.Get_element idx ->\n let elt = get_exn !ledger idx in\n let path = (path_exn idx :> Random_oracle.Digest.t list) in\n respond (Provide (elt, path))\n | Ledger_hash.Get_path idx ->\n let path = (path_exn idx :> Random_oracle.Digest.t list) in\n respond (Provide path)\n | Ledger_hash.Set (idx, account) ->\n ledger := set_exn !ledger idx account ;\n respond (Provide ())\n | Ledger_hash.Find_index pk ->\n let index = find_index_exn !ledger pk in\n respond (Provide index)\n | _ ->\n unhandled )\n","module type Full = sig\n open Core_kernel\n open Snark_params\n open Tick\n open Mina_base_import\n\n [@@@warning \"-32\"]\n\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t =\n { fee : Currency.Fee.Stable.V1.t\n ; prover : Public_key.Compressed.Stable.V1.t\n }\n [@@deriving sexp, yojson, equal, compare]\n end\n end]\n\n [@@@warning \"+32\"]\n\n type t = Stable.Latest.t =\n { fee : Currency.Fee.Stable.V1.t\n ; prover : Public_key.Compressed.Stable.V1.t\n }\n [@@deriving sexp, yojson, equal, compare]\n\n val create : fee:Currency.Fee.t -> prover:Public_key.Compressed.t -> t\n\n module Digest : sig\n type t [@@deriving sexp, equal, yojson, hash, compare]\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving sexp, bin_io, hash, compare, equal, yojson, version]\n end\n\n module Latest = V1\n end\n\n module Checked : sig\n type t\n\n val to_input : t -> Field.Var.t Random_oracle.Input.Chunked.t\n end\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val typ : (Checked.t, t) Typ.t\n\n val default : t\n end\n\n val digest : t -> Digest.t\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nlet blockchain_dummy = lazy (Dummy_values.blockchain_proof ())\n\nlet transaction_dummy = lazy (Dummy_values.transaction_proof ())\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Pickles.Proof.Proofs_verified_2.Stable.V2.t\n [@@deriving sexp, yojson, compare]\n\n let to_latest = Fn.id\n\n let to_yojson_full = Pickles.Proof.Proofs_verified_2.to_yojson_full\n end\nend]\n\n[%%define_locally Stable.Latest.(to_yojson, of_yojson, to_yojson_full)]\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n { pending_coinbases : Pending_coinbase.Stable.V2.t; is_new_stack : bool }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\nend]\n","open Core_kernel\n\nmodule type Full = sig\n include Digest_intf.S\n\n val cons : Stack_frame.Digest.t -> t -> t\n\n val empty : t\n\n val gen : t Quickcheck.Generator.t\n\n module Checked : sig\n include Digest_intf.S_checked\n\n val cons : Stack_frame.Digest.Checked.t -> t -> t\n end\n\n include Digest_intf.S_aux with type t := t and type checked := Checked.t\nend\n","open Core_kernel\nmodule Wire_types = Mina_wire_types.Mina_base.Call_stack_digest\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Call_stack_digest_intf.Full with type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Kimchi_backend.Pasta.Basic.Fp.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n open Pickles.Impls.Step\n\n let cons (h : Stack_frame.Digest.t) (t : t) : t =\n Random_oracle.hash ~init:Hash_prefix_states.account_update_stack_frame_cons\n [| (h :> Field.Constant.t); t |]\n\n let empty = Field.Constant.zero\n\n let gen = Field.Constant.gen\n\n module Checked = struct\n include Field\n\n let cons (h : Stack_frame.Digest.Checked.t) (t : t) : t =\n Random_oracle.Checked.hash\n ~init:Hash_prefix_states.account_update_stack_frame_cons\n [| (h :> Field.t); t |]\n end\n\n let constant = Field.constant\n\n let typ = Field.typ\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\n\ntype account_state = [ `Added | `Existed ] [@@deriving equal]\n\nmodule type S = sig\n type t\n\n type location\n\n val get : t -> location -> Account.t option\n\n val location_of_account : t -> Account_id.t -> location option\n\n val set : t -> location -> Account.t -> unit\n\n val get_or_create :\n t -> Account_id.t -> (account_state * Account.t * location) Or_error.t\n\n val get_or_create_account :\n t -> Account_id.t -> Account.t -> (account_state * location) Or_error.t\n\n val create_new_account : t -> Account_id.t -> Account.t -> unit Or_error.t\n\n val remove_accounts_exn : t -> Account_id.t list -> unit\n\n val merkle_root : t -> Ledger_hash.t\n\n val with_ledger : depth:int -> f:(t -> 'a) -> 'a\n\n val empty : depth:int -> unit -> t\n\n val create_masked : t -> t\n\n val apply_mask : t -> masked:t -> unit\nend\n","module Import = Mina_base_import\nmodule Util = Mina_base_util\nmodule Account = Account\nmodule Account_id = Account_id\nmodule Account_timing = Account_timing\nmodule Call_stack_digest = Call_stack_digest\nmodule Coinbase = Coinbase\nmodule Coinbase_fee_transfer = Coinbase_fee_transfer\nmodule Control = Control\nmodule Data_as_hash = Data_as_hash\nmodule Data_hash = Data_hash\nmodule Epoch_data = Epoch_data\nmodule Epoch_ledger = Epoch_ledger\nmodule Epoch_seed = Epoch_seed\nmodule Fee_excess = Fee_excess\nmodule Fee_transfer = Fee_transfer\nmodule Fee_with_prover = Fee_with_prover\nmodule Frozen_ledger_hash = Frozen_ledger_hash\nmodule Frozen_ledger_hash0 = Frozen_ledger_hash0\nmodule Hash_prefix = Hash_prefix\nmodule Ledger_hash = Ledger_hash\nmodule Ledger_hash0 = Ledger_hash0\nmodule Ledger_hash_intf = Ledger_hash_intf\nmodule Ledger_hash_intf0 = Ledger_hash_intf0\nmodule Ledger_intf = Ledger_intf\nmodule Account_update = Account_update\nmodule Payment_payload = Payment_payload\nmodule Pending_coinbase = Pending_coinbase\nmodule Pending_coinbase_intf = Pending_coinbase_intf\nmodule Pending_coinbase_witness = Pending_coinbase_witness\nmodule Permissions = Permissions\nmodule Proof = Proof\nmodule Protocol_constants_checked = Protocol_constants_checked\nmodule Prover_value = Prover_value\nmodule Receipt = Receipt\nmodule Side_loaded_verification_key = Side_loaded_verification_key\nmodule Signature = Signature\nmodule Signed_command = Signed_command\nmodule Signed_command_intf = Signed_command_intf\nmodule Signed_command_memo = Signed_command_memo\nmodule Signed_command_payload = Signed_command_payload\nmodule Zkapp_account = Zkapp_account\nmodule Zkapp_basic = Zkapp_basic\nmodule Zkapp_call_forest = Zkapp_call_forest\nmodule Zkapp_command = Zkapp_command\nmodule Zkapp_precondition = Zkapp_precondition\nmodule Zkapp_state = Zkapp_state\nmodule Zkapp_statement = Zkapp_statement\nmodule Sok_message = Sok_message\nmodule Sparse_ledger_base = Sparse_ledger_base\nmodule Stack_frame = Stack_frame\nmodule Staged_ledger_hash = Staged_ledger_hash\nmodule Stake_delegation = Stake_delegation\nmodule State_body_hash = State_body_hash\nmodule State_hash = State_hash\nmodule Token_id = Token_id\nmodule Transaction_status = Transaction_status\nmodule Transaction_union_payload = Transaction_union_payload\nmodule Transaction_union_tag = Transaction_union_tag\nmodule User_command = User_command\nmodule Verification_key_wire = Verification_key_wire\nmodule With_stack_hash = With_stack_hash\nmodule With_status = With_status\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\n\nlet _console_log_string s = Js_of_ocaml.Firebug.console##log (Js.string s)\n\nlet _console_log s = Js_of_ocaml.Firebug.console##log s\n\nlet _console_dir s : unit =\n let f =\n Js.Unsafe.eval_string {js|(function(s) { console.dir(s, {depth: 5}); })|js}\n in\n Js.Unsafe.(fun_call f [| inject s |])\n\nlet raise_error s =\n Js.Js_error.(raise_ @@ of_error (new%js Js.error_constr (Js.string s)))\n\nexternal raise_exn_js : exn -> Js.js_string Js.t -> 'a = \"custom_reraise_exn\"\n\nlet raise_exn exn = raise_exn_js exn (Js.string (Exn.to_string exn))\n\nlet json_parse (str : Js.js_string Js.t) =\n Js.Unsafe.(fun_call global ##. JSON##.parse [| inject str |])\n","module Js = Js_of_ocaml.Js\n\nlet export () =\n Js.export \"Snarky\" Snarky_bindings.snarky ;\n Js.export \"Ledger\" Local_ledger.ledger_class ;\n Js.export \"Pickles\" Pickles_bindings.pickles ;\n Js.export \"Test\" Consistency_test.test\n\nlet export_global () =\n let snarky_obj =\n Js.Unsafe.(\n let i = inject in\n obj\n [| (\"Snarky\", i Snarky_bindings.snarky)\n ; (\"Ledger\", i Local_ledger.ledger_class)\n ; (\"Pickles\", i Pickles_bindings.pickles)\n ; (\"Test\", i Consistency_test.test)\n |])\n in\n Js.Unsafe.(set global (Js.string \"__snarky\") snarky_obj)\n","let () = Snarky_js_bindings_lib.export_global ()\n\nlet () = Snarky_js_bindings_lib.export ()\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Ensure that [at_exit] functions are called at the end of every program *)\n\nlet _ = do_at_exit()\n"]} \ No newline at end of file +{"version":3.0,"file":"snarky_js_node.bc.js","sourceRoot":"","names":["Object","globalThis","this","get","_T_","global","self","DefaultLocale","defaultStrftime","Strftime","isCommonJS","module","namespace","adaptedStrftime","deprecatedStrftime","joo_global_object","eval","_require","_deprecationWarnings","deprecationWarning","name","instead","console","deprecatedStrftimeTZ","deprecatedStrftimeUTC","deprecatedStrftimeLocalized","adaptForwards","fn","fmt","d","locale","undefined","strftime","timezone","null","utcStrftime","Date","customTimezoneOffset","useUtcTimezone","_locale","_customTimezoneOffset","_useUtcBasedDate","_cachedDateTimestamp","_cachedDate","_strftime","format","date","timestamp","currentTimestamp","getTimestampToUtcOffsetFor","_processFormat","resultString","padding","isInScope","length","extendedTZ","i","currentCharCode","padTill2","Math","hours12","padTill3","weekNumber","tzString","y","day","String","ordinal","off","sign","sep","hours","mins","useUtcBasedDate","timezoneType","parseInt","minutes","numberToPad","paddingChar","hour","firstWeekday","weekday","firstDayOfYearUtc","dateUtc","yday","weekNum","number","ii","Base_am_testing","x","caml_mul","a","b","caml_hash_mix_int","h","caml_hash_mix_jsbytes","s","len","w","log2_ok","jsoo_floor_log2","Infinity","caml_int64_offset","caml_raise_constant","tag","caml_global_data","caml_raise_zero_divide","MlInt64","lo","mi","hi","xhi","offset","modulus","divisor","quotient","q","r","caml_int64_create_lo_mi_hi","caml_int64_bits_of_float","isFinite","isNaN","exp","k","r3","r2","r1","caml_int64_lo32","v","caml_int64_hi32","caml_hash_mix_int64","caml_hash_mix_float","v0","caml_str_repeat","n","l","caml_subarray_to_jsbytes","f","caml_convert_string_to_bytes","caml_jsbytes_of_string","caml_hash_mix_string","caml_hash_mix_bytes_arr","jsoo_is_ascii","caml_utf16_of_utf8","t","c","c1","c2","j","MlBytes","contents","content","caml_ml_bytes_content","caml_hash_mix_bytes","caml_int32_bits_of_float","float32a","int32a","caml_int64_to_bytes","caml_ba_serialize","writer","ba","sz","complex","caml_raise_with_string","msg","caml_invalid_argument","caml_ba_get_size_per_element","kind","caml_ba_create_buffer","size","g","view","data","caml_int32_float_of_bits","caml_int64_of_bytes","caml_int64_float_of_bits","NaN","res","caml_ba_get_size","dims","n_dims","caml_int64_create_lo_hi","caml_array_bound_error","caml_ba_custom_name","Ml_Bigarray","layout","buffer","arg","ofs","Array","im","re","total","k1","k2","Ml_Bigarray_c_1_1","caml_ba_create_unsafe","size_per_element","caml_bytes_of_jsbytes","caml_string_of_jsbytes","caml_failwith","caml_ba_deserialize","reader","num_dims","size_dim","size_dim_hi","size_dim_lo","sixty","int64","caml_ba_compare","caml_ba_hash","num_elts","caml_int32_unmarshal","caml_nativeint_unmarshal","caml_int64_unmarshal","caml_int64_marshal","sizes","caml_int64_compare","caml_int64_hash","caml_custom_ops","caml_hash_mix_final","caml_is_ml_bytes","caml_is_ml_string","caml_hash","count","limit","seed","obj","queue","rd","wr","num","hh","Base_hash_double","Base_hash_string","Base_int_math_int32_clz","Base_int_math_int32_ctz","caml_int64_shift_right_unsigned","caml_int64_is_zero","caml_int64_to_int32","Base_int_math_int64_clz","caml_int64_and","caml_int64_of_int32","Base_int_math_int64_ctz","is_zero","land","small_int64","caml_int64_mul","Base_int_math_int64_pow_stub","base","exponent","one","mul","Base_int_math_int_clz","Base_int_math_int_ctz","Base_int_math_int_popcount","Base_int_math_int_pow_stub","Base_int_math_nativeint_clz","Base_int_math_nativeint_ctz","Base_internalhash_fold_float","Base_internalhash_fold_int","Base_internalhash_fold_int64","Base_internalhash_fold_string","Base_internalhash_get_hash_value","incr_nat","nat","carry_in","carry","add_nat","nat1","ofs1","len1","nat2","ofs2","len2","caml_js_from_array","caml_ba_create","dims_ml","bigstring_alloc","_","caml_ml_bytes_length","caml_convert_bytes_to_array","caml_blit_bytes","s1","i1","s2","i2","caml_bytes_of_array","caml_bigstring_blit_ba_to_bytes","ba1","pos1","bytes2","pos2","slice","bigstring_blit_bigstring_bytes_stub","src","src_pos","dst","dst_pos","caml_array_of_bytes","caml_bigstring_blit_bytes_to_ba","str1","ba2","bigstring_blit_bytes_bigstring_stub","caml_ml_string_length","caml_bytes_unsafe_get","caml_string_unsafe_get","caml_array_of_string","caml_bigstring_blit_string_to_ba","bigstring_blit_string_bigstring_stub","caml_bigstring_blit_ba_to_ba","bigstring_blit_stub","caml_bytes_unsafe_set","caml_string_unsafe_set","caml_ba_get_1","i0","bigstringaf_blit_to_bytes","src_off","dst_off","bin_prot_blit_buf_bytes_stub","caml_check_bound","array","index","caml_check_bound_bigstring","bigstring","bin_prot_blit_buf_float_array_stub","bin_prot_blit_float_array_buf_stub","float64","float64_uint8","bin_prot_blit_string_buf_stub","blit_nat","caml_array_append","a1","a2","l1","l2","caml_array_blit","caml_array_concat","caml_array_fill","caml_array_set","newval","caml_array_sub","caml_ba_blit","caml_ba_dim","caml_ba_dim_1","caml_ba_dim_2","caml_ba_get_2","caml_ba_layout","caml_ba_set_1","caml_ba_set_2","caml_ba_sub","changed_dim","new_dims","new_data","caml_ba_uint8_get16","b1","b2","caml_ba_uint8_get32","b3","b4","caml_ba_uint8_get64","b5","b6","b7","b8","caml_ba_uint8_set16","caml_ba_uint8_set32","caml_ba_uint8_set64","caml_backtrace_status","plonk_wasm","require","caml_bigint_256_bytes_per_limb","caml_bigint_256_compare","caml_bigint_256_div","caml_bigint_256_num_limbs","caml_bytes_to_uint8array","ocaml_bytes","bytes","caml_bigint_256_of_bytes","caml_jsstring_of_string","caml_bigint_256_of_decimal_string","caml_bigint_256_of_numeral","caml_bigint_256_print","caml_js_to_bool","caml_bigint_256_test_bit","caml_create_bytes","caml_bytes_of_uint8array","uint8array","caml_bigint_256_to_bytes","caml_utf8_of_utf16","caml_bytes_of_utf16_jsstring","caml_string_of_jsstring","caml_bigint_256_to_string","caml_bytes_of_string","caml_blit_string","e","caml_bswap16","caml_bytes_bound_error","caml_bytes_get","caml_bytes_get16","caml_bytes_set","caml_bytes_set16","i16","caml_bytes_set32","i32","caml_bytes_set64","i64","caml_call_gen","args","argsLen","extra_args","arguments","nargs","caml_classify_float","caml_compare_val_get_custom","caml_compare_val_number_custom","custom","swap","comp","caml_compare_val_tag","Number","caml_int_compare","caml_bytes_compare","caml_string_compare","caml_compare_val","stack","tag_a","tag_b","caml_compare","caml_convert_raw_backtrace","caml_convert_raw_backtrace_slot","caml_div","caml_ephe_key_offset","caml_weak_create","caml_ephe_create","caml_ephe_data_offset","caml_ephe_get_data","caml_ephe_set_data","caml_weak_set","caml_ephe_set_key","caml_equal","caml_fill_bytes","caml_final_register","caml_float_compare","caml_float_of_string","m","m3","mantissa","caml_parse_format","caml_finish_formatting","rawbuffer","caml_format_float","toFixed","dp","prec","p","caml_format_int","rust_affine_to_caml_affine","pt","infinity","js_class_vector_of_rust_vector","klass","caml_array_of_rust_vector","convert","should_free","rust_val","caml_poly_comm_of_rust_poly_comm","poly_comm","rust_shifted","rust_unshifted","caml_shifted","caml_unshifted","caml_vesta_poly_comm_of_rust","caml_u8array_vector_to_rust_flat_vector","inner_len","pos","caml_fp_srs_b_poly_commitment","srs","chals","rust_affine_of_caml_affine","js_class_vector_to_rust_vector","free_finalization_registry","instance_representative","caml_array_to_rust_vector","mk_new","class_val","caml_fp_vector_to_rust","caml_fp_srs_batch_accumulator_check","comms","rust_comms","rust_chals","ok","caml_fp_srs_batch_accumulator_generate","free_on_finalize","caml_fp_srs_create","caml_fp_srs_h","caml_fp_srs_lagrange_commitment","domain_size","caml_fp_srs_read","path","caml_fp_srs_write","append","caml_fp_vector_create","caml_fp_vector_emplace_back","caml_fp_vector_get","value","Error","caml_fp_vector_length","caml_fq_srs_add_lagrange_basis","log2_size","caml_pallas_poly_comm_of_rust","caml_fq_srs_b_poly_commitment","caml_fq_srs_create","caml_fq_srs_h","caml_fq_srs_lagrange_commitment","caml_fq_srs_read","caml_fq_srs_write","caml_fq_vector_create","caml_fq_vector_emplace_back","caml_fq_vector_get","caml_fq_vector_length","caml_oo_last_id","caml_fresh_oo_id","caml_frexp_float","neg","fs_node_supported","make_path_is_absolute","posix","win32","splitDeviceRe","result","device","isUnc","Boolean","root","path_is_absolute","caml_trailing_slash","caml_current_dir","caml_make_path","comp0","ncomp","unix_error","make_unix_err_args","code","syscall","errno","variant","caml_named_values","caml_named_value","nm","caml_raise_with_args","caml_raise_sys_error","caml_raise_no_such_file","MlFile","MlFakeFile","old","buf","clen","new_str","old_data","MlFakeDevice","Symbol","name_slash","mode","raise_unix","parent","RegExp","seen","file","MlNodeFile","fd","err","buf_offset","MlNodeDevice","consts","key","o","js_stats","to_dir","target","link","file_kind","caml_get_root","caml_root","jsoo_mount_point","resolve_fs_device","caml_create_file","jsoo_create_file","caml_fs_init","tmp","caml_gc_quick_stat","caml_get_current_callstack","caml_get_exception_raw_backtrace","caml_method_cache","caml_get_public_method","cacheid","meths","li","caml_greaterequal","caml_greaterthan","caml_hexstring_of_float","style","exp_sign","sign_str","cst","x_str","idx","caml_marshal_data_size","get32","MlStringReader","caml_float_of_bytes","caml_input_value_from_reader","_magic","_block_len","num_objects","_size_32","_size_64","intern_obj_table","obj_counter","intern_rec","header","ops","expected_size","old_pos","caml_string_of_bytes","caml_input_value_from_bytes","caml_ml_channels","caml_input_value","chanid","chan","caml_int32_bswap","caml_int64_add","caml_int64_bswap","caml_int64_div","caml_int64_is_negative","caml_int64_neg","caml_int64_format","wbase","cvtbl","caml_int64_mod","caml_int64_of_float","caml_int64_ult","caml_parse_sign_and_base","caml_parse_digit","caml_int64_of_string","base64","threshold","caml_int64_or","caml_int64_shift_left","caml_int64_shift_right","caml_int64_sub","caml_int64_to_float","caml_int64_xor","caml_int_of_string","caml_js_eval_string","caml_js_to_array","caml_js_wrap_callback","caml_js_wrap_meth_callback","caml_lazy_make_forward","caml_ldexp_float","caml_lessequal","caml_lessthan","caml_lex_array","caml_lex_engine","tbl","start_state","lexbuf","lex_buffer","lex_buffer_len","lex_start_pos","lex_curr_pos","lex_last_pos","lex_last_action","lex_eof_reached","lex_base","lex_backtrk","lex_default","lex_trans","lex_check","state","backtrk","caml_list_of_js_array","caml_log10_float","caml_make_float_vect","caml_make_vect","init","caml_string_of_array","caml_md5_bytes","add","xx","ff","gg","md5","caml_md5_string","caml_ml_channel_size","caml_ml_channel_size_64","caml_sys_close","caml_ml_flush","output","caml_ml_close_channel","caml_ml_debug_info_status","caml_ml_refill_input","str","str_len","caml_ml_input","caml_ml_may_refill_input","caml_raise_end_of_file","caml_ml_input_char","caml_ml_input_int","caml_std_output","slen","js_print_stderr","js_print_stdout","caml_sys_open_internal","flags","info","caml_sys_open","_perms","caml_ml_open_descriptor_in","refill","fs","channel","caml_ml_open_descriptor_out","caml_ml_out_channels_list","caml_ml_output_bytes","string","jsstring","id","caml_ml_output","caml_ml_output_char","caml_ml_output_int","arr","caml_ml_pos_in","caml_ml_pos_in_64","caml_ml_pos_out","caml_ml_pos_out_64","caml_ml_seek_in","caml_ml_seek_in_64","caml_ml_seek_out","caml_ml_seek_out_64","caml_ml_set_binary_mode","caml_ml_set_channel_name","caml_mod","caml_modf_float","caml_lex_run_mem","mem","curr_pos","caml_lex_run_tag","caml_new_lex_engine","lex_mem","lex_base_code","lex_backtrk_code","lex_default_code","lex_trans_code","lex_check_code","lex_code","pc_off","pstate","base_code","caml_notequal","caml_obj_block","caml_obj_make_forward","caml_obj_tag","Function","caml_out_channel_pos_fd","MlObjectTable","NaiveLookup","objs","caml_list_to_js_array","caml_legacy_custom_code","caml_output_val","Writer","no_sharing","closures","memo","existing_offset","extern_rec","sz_32_64","header_pos","type_of_v","caml_output_value_to_buffer","caml_pallas_add","caml_pallas_double","caml_pallas_endo_base","caml_pallas_endo_scalar","caml_pallas_negate","caml_pallas_of_affine_coordinates","caml_pallas_one","caml_pallas_random","caml_pallas_scale","caml_pallas_sub","caml_pallas_to_affine","caml_pasta_fp_add","caml_pasta_fp_copy","caml_pasta_fp_div","caml_pasta_fp_domain_generator","caml_pasta_fp_equal","caml_option_of_maybe_undefined","caml_pasta_fp_inv","caml_pasta_fp_is_square","caml_pasta_fp_mul","caml_pasta_fp_mut_add","caml_pasta_fp_mut_mul","caml_pasta_fp_square","caml_pasta_fp_mut_square","caml_pasta_fp_sub","caml_pasta_fp_mut_sub","caml_pasta_fp_negate","caml_pasta_fp_of_bigint","caml_pasta_fp_of_bytes","caml_pasta_fp_of_int","caml_pasta_fp_of_string","caml_pasta_fp_plonk_circuit_serialize","public_input_size","gate_vector","caml_plonk_wire_to_rust","wire","caml_plonk_wires_to_rust","wires","caml_fp_plonk_gate_to_rust","gate","caml_pasta_fp_plonk_gate_vector_add","caml_pasta_fp_plonk_gate_vector_create","caml_pasta_fp_plonk_gate_vector_digest","caml_plonk_wire_of_rust","caml_plonk_wires_of_rust","caml_u8array_vector_of_rust_flat_vector","output_len","inner_res","caml_plonk_gate_of_rust","caml_pasta_fp_plonk_gate_vector_get","caml_pasta_fp_plonk_gate_vector_len","caml_pasta_fp_plonk_gate_vector_wrap","caml_fp_runtime_table_cfg_to_rust","caml_runtime_table_cfg","mk_class","caml_runtime_table_cfg_id","caml_runtime_table_cfg_first_column","caml_fp_vector_of_rust","caml_fp_lookup_table_to_rust","caml_lookup_table","caml_lookup_table_id","caml_lookup_table_data","lt_data_length","caml_pasta_fp_plonk_index_create","gates","public_inputs","caml_lookup_tables","caml_runtime_table_cfgs","prev_challenges","urs","wasm_lookup_tables","wasm_runtime_table_cfgs","caml_pasta_fp_plonk_index_create_bytecode","caml_pasta_fp_plonk_index_read","caml_pasta_fp_plonk_index_write","caml_poly_comm_to_rust_poly_comm","poly_comm_class","mk_affine","caml_vesta_poly_comm_to_rust","caml_plonk_domain_to_rust","caml_plonk_verification_evals_to_rust","poly_comm_to_rust","convert_opt","poly_comm_opt","convertArray","sigma_comm","coefficients_comm","generic_comm","psm_comm","complete_add_comm","mul_comm","emul_comm","endomul_scalar_comm","xor_comm","range_check0_comm","range_check1_comm","foreign_field_add_comm","foreign_field_mul_comm","rot_comm","caml_plonk_verification_shifts_to_rust","caml_lookup_table_to_rust","wasm_lookup_table","None","caml_is_none","caml_opt_to_rust","caml_optional_value","to_rust","caml_lookup_selectors_to_rust","wasm_lookup_selectors","xor","lookup","range_check","ffmul","caml_lookup_patterns_to_rust","wasm_lookup_patterns","foreign_field_mul","caml_lookup_features_to_rust","wasm_lookup_features","patterns","joint_lookup_used","uses_runtime_tables","caml_lookup_info_to_rust","wasm_lookup_info","max_per_row","max_poly_size","features","caml_plonk_lookup_verifier_index_to_rust","caml_lookup_verifier_index","lookup_selectors_class","lookup_table","lookup_selectors","table_ids","lookup_info","runtime_tables_selector","caml_plonk_verifier_index_to_rust","domain_class","verification_evals_class","verification_shifts_class","lookup_verifier_index_class","domain","public_","evals","shifts","lookup_index_to_rust","lidx","wasm_lookup_index","caml_pasta_fp_plonk_verifier_index_to_rust","caml_fp_lookup_commitments_to_rust","caml_lc","wasm_sorted","wasm_aggreg","wasm_runtime","caml_pasta_fp_commitments_to_rust","w_comm","z_comm","t_comm","caml_pasta_fp_opening_proof_to_rust","convert_affines","affines","lr","delta","z1","z2","sg","l_ocaml","r_ocaml","PERMUTS_MINUS_1","COLUMNS","caml_pasta_fp_proof_evaluations_to_rust","caml_pasta_fp_proof_to_rust","public_evals","commitments","proof","evals_actual","ft_eval1","chals_len","prev_challenges_scalars","prev_challenges_comms","caml_pasta_fp_plonk_proof_batch_verify","indexes","proofs","caml_fp_lookup_commitments_of_rust","wasm_lc","sorted","aggreg","wasm_lc_runtime","caml_runtime","caml_opt_of_rust","value_of_rust","caml_pasta_fp_commitments_of_rust","caml_lookup","caml_pasta_fp_opening_proof_of_rust","tuple","caml_pasta_fp_proof_evaluations_of_rust","caml_pasta_fp_proof_of_rust","messages","caml_fp_runtime_table_to_rust","caml_runtime_table","caml_runtime_table_id","caml_runtime_table_data","caml_pasta_fp_plonk_proof_create","witness_cols","caml_runtime_tables","prev_sgs","wasm_runtime_tables","caml_pasta_fp_plonk_proof_example_with_ffadd","caml_pasta_fp_plonk_proof_example_with_lookup","caml_pasta_fp_plonk_proof_example_with_range_check","caml_pasta_fp_plonk_proof_example_with_range_check0","caml_pasta_fp_plonk_proof_example_with_rot","caml_pasta_fp_plonk_proof_example_with_xor","caml_pasta_fp_plonk_proof_verify","column_of_rust","col","gate_type","variable_of_rust","variable","row","polish_token_of_rust","token","wrap","ptr","index_term_of_rust","term","token_class","column","coefficient","linearization_of_rust","linearization","affine_class","F","WasmPolishToken","WasmIndexTerm","constant_term","index_terms","wasmIndexTerm","caml_plonk_domain_of_rust","log_size_of_group","group_gen","caml_plonk_verification_evals_of_rust","affine_klass","caml_plonk_verification_shifts_of_rust","caml_map_of_rust_vector","converter_to_rust","caml_bool_of_rust","bool","caml_lookup_selectors_of_rust","poly_comm_of_rust","caml_lookup_patterns_of_rust","caml_lookup_features_of_rust","caml_lookup_patterns","caml_joint_lookup_used","caml_uses_runtime_tables","caml_lookup_info_of_rust","caml_max_per_row","caml_max_joint_size","caml_lookup_features","caml_lookup_verifier_index_of_rust","caml_lookup_selectors","caml_table_ids","caml_lookup_info","caml_runtime_tables_selector","caml_plonk_verifier_index_of_rust","caml_lookup_index","caml_pasta_fp_plonk_verifier_index_of_rust","caml_pasta_fp_plonk_verifier_index_create","vk","vk_caml","caml_pasta_fp_plonk_verifier_index_read","caml_pasta_fp_plonk_verifier_index_shifts","caml_pasta_fp_plonk_verifier_index_write","caml_pasta_fp_poseidon_block_cipher","_fake_params","fp_vector","wasm_flat_vector","new_fp_vector","caml_pasta_fp_poseidon_params_create","caml_pasta_fp_print","caml_pasta_fp_random","caml_pasta_fp_rng","caml_pasta_fp_size","caml_pasta_fp_size_in_bits","caml_pasta_fp_sqrt","caml_pasta_fp_to_bigint","caml_pasta_fp_to_bytes","caml_pasta_fp_to_string","caml_pasta_fp_two_adic_root_of_unity","caml_pasta_fq_add","caml_pasta_fq_copy","caml_pasta_fq_div","caml_pasta_fq_domain_generator","caml_pasta_fq_equal","caml_pasta_fq_inv","caml_pasta_fq_is_square","caml_pasta_fq_mul","caml_pasta_fq_mut_add","caml_pasta_fq_mut_mul","caml_pasta_fq_square","caml_pasta_fq_mut_square","caml_pasta_fq_sub","caml_pasta_fq_mut_sub","caml_pasta_fq_negate","caml_pasta_fq_of_bigint","caml_pasta_fq_of_bytes","caml_pasta_fq_of_int","caml_pasta_fq_of_string","caml_pasta_fq_plonk_circuit_serialize","caml_fq_plonk_gate_to_rust","caml_pasta_fq_plonk_gate_vector_add","caml_pasta_fq_plonk_gate_vector_create","caml_pasta_fq_plonk_gate_vector_digest","caml_pasta_fq_plonk_gate_vector_get","caml_pasta_fq_plonk_gate_vector_len","caml_pasta_fq_plonk_gate_vector_wrap","caml_fq_vector_to_rust","caml_fq_runtime_table_cfg_to_rust","caml_fq_lookup_table_to_rust","caml_pasta_fq_plonk_index_create","caml_pasta_fq_plonk_index_create_bytecode","caml_pasta_fq_plonk_index_domain_d1_size","caml_pasta_fq_plonk_index_read","caml_pasta_fq_plonk_index_write","caml_pallas_poly_comm_to_rust","caml_pasta_fq_plonk_verifier_index_to_rust","caml_fq_lookup_commitments_to_rust","caml_pasta_fq_commitments_to_rust","caml_pasta_fq_opening_proof_to_rust","caml_pasta_fq_proof_evaluations_to_rust","caml_pasta_fq_proof_to_rust","caml_pasta_fq_plonk_proof_batch_verify","caml_fq_lookup_commitments_of_rust","caml_pasta_fq_commitments_of_rust","caml_pasta_fq_opening_proof_of_rust","caml_fq_vector_of_rust","caml_pasta_fq_proof_evaluations_of_rust","caml_pasta_fq_proof_of_rust","caml_fq_runtime_table_to_rust","caml_pasta_fq_plonk_proof_create","caml_pasta_fq_plonk_proof_verify","caml_pasta_fq_plonk_verifier_index_of_rust","caml_pasta_fq_plonk_verifier_index_create","caml_pasta_fq_plonk_verifier_index_shifts","caml_pasta_fq_print","caml_pasta_fq_random","caml_pasta_fq_rng","caml_pasta_fq_size","caml_pasta_fq_size_in_bits","caml_pasta_fq_sqrt","caml_pasta_fq_to_bigint","caml_pasta_fq_to_bytes","caml_pasta_fq_to_string","caml_pasta_fq_two_adic_root_of_unity","caml_raw_backtrace_slot","caml_record_backtrace","caml_register_global","name_opt","caml_register_named_value","caml_restore_raw_backtrace","exn","bt","caml_set_oo_id","caml_bytes_equal","caml_string_equal","caml_string_bound_error","caml_string_get","caml_string_get16","caml_string_get32","caml_string_get64","caml_bytes_lessequal","caml_string_lessequal","caml_string_greaterequal","caml_bytes_lessthan","caml_string_lessthan","caml_string_greaterthan","caml_string_notequal","caml_argv","main","argv","args2","caml_sys_argv","caml_sys_const_max_wosize","os_type","caml_sys_const_ostype_cygwin","caml_sys_const_ostype_win32","caml_executable_name","caml_sys_executable_name","caml_sys_exit","caml_sys_file_exists","caml_sys_get_config","caml_sys_getcwd","caml_raise_not_found","caml_sys_getenv","caml_sys_isatty","_chan","caml_sys_random_seed","buff","now","caml_sys_remove","caml_sys_system_command","cmd","caml_trampoline","caml_trampoline_return","caml_update_dummy","caml_vesta_add","caml_vesta_double","caml_vesta_endo_base","caml_vesta_endo_scalar","caml_vesta_negate","caml_vesta_of_affine_coordinates","caml_vesta_one","caml_vesta_random","caml_vesta_scale","caml_vesta_sub","caml_vesta_to_affine","caml_return_exn_constant","caml_wrap_exception","num_digits_nat","compare_nat","core_array_unsafe_float_blit","core_array_unsafe_int_blit","core_kernel_gc_minor_words","core_kernel_time_ns_format","time","formatjs","jstring","caml_md5_chan","chan_len","core_md5_fd","ic","MlNat","create_nat","custom_reraise_exn","fallbackMessage","decr_nat","borrow","deferred_bind","deferred","func","newDeferred","anotherDeferred","deferred_map","deferred_return","Promise","deferred_run","deferred_to_promise","deferred_upon_exn","div_helper","z","div_digit_nat","natq","ofsq","natr","ofsr","rem","num_leading_zero_bits_in_digit","shift_left_nat","nbits","shift_right_nat","set_to_zero_nat","nat_of_array","mult_digit_nat","nat3","ofs3","x1","x2","x3","sub_nat","div_nat","quo","expect_test_collector_saved_stderr","expect_test_collector_saved_stdout","expect_test_collector_after_test","vstdout","vstderr","expect_test_collector_before_test","voutput","caml_random_oracles_of_rust","joint_combiner_chal","joint_combiner","joint_combiner_ocaml","caml_oracles_of_rust","fp_oracles_create","lgr_comm","verifier_index","fp_oracles_create_no_public","fq_oracles_create","fq_oracles_create_no_public","tsBindings","getTsBindings","serialize_nat","deserialize_nat","caml_hash_nat","initialize_nat","integers_int32_of_uint32","integers_size_t_size","unit","integers_uint_of_string","max_val","negative","no_digits","ten","max_base_10","UInt32","integers_uint32_of_int64","integers_uint32_of_string","integers_uint16_of_string","integers_uint32_add","integers_uint32_div","integers_uint32_logand","integers_uint32_logor","integers_uint32_logxor","integers_uint32_max","integers_uint32_to_int64","integers_uint32_mul","x_64","y_64","integers_uint32_of_int","integers_uint32_of_int32","integers_uint32_rem","integers_uint32_shift_left","integers_uint32_shift_right","integers_uint32_sub","integers_uint32_to_int","caml_new_string","integers_uint32_to_string","UInt64","integers_uint64_add","integers_uint64_div","integers_uint64_logand","integers_uint64_logor","integers_uint64_logxor","integers_uint64_max","integers_uint64_mul","integers_uint64_of_int","integers_uint64_of_int64","integers_uint64_of_string","integers_uint64_of_uint32","integers_uint64_rem","integers_uint64_shift_left","integers_uint64_shift_right","integers_uint64_sub","integers_uint64_to_int","integers_uint64_to_int64","integers_uint64_to_string","integers_uint8_of_string","integers_uint_size","integers_ulong_size","integers_ulonglong_size","integers_uint8_deserialize","integers_uint16_deserialize","integers_uint32_serialize","integers_uint32_deserialize","integers_uint32_hash","integers_uint32_compare","integers_uint64_compare","integers_uint64_hash","integers_uint64_marshal","integers_uint64_unmarshal","integers_unsigned_init","integers_ushort_size","is_digit_int","is_digit_zero","land_digit_nat","lor_digit_nat","bigInt","BASE","LOG_BASE","MAX_INT","MAX_INT_ARR","smallToArray","DEFAULT_ALPHABET","BigInt","supportsNativeBigInt","Integer","radix","alphabet","caseSensitive","parseValue","parseBase","BigInteger","SmallInteger","NativeBigInt","isPrecise","arrayToSmall","trim","compareAbs","createArray","truncate","l_a","l_b","sum","addAny","addSmall","subtract","a_l","b_l","difference","subtractAny","subtractSmall","small","multiplyLong","product","a_i","b_j","multiplySmall","shiftLeft","multiplyKaratsuba","ac","bd","abcd","useKaratsuba","abs","multiplySmallAndArray","square","a_j","divMod1","divisorMostSignificantDigit","lambda","remainder","quotientDigit","shift","divModSmall","divMod2","part","guess","xlen","highx","highy","check","divModAny","comparison","qSign","mod","mSign","_0","_1","_2","isBasicPrime","millerRabinTest","nPrev","strict","isPrime","bits","logN","iterations","newT","newR","lastT","lastR","powersOfTwo","powers2Length","highestPower2","shift_isSmall","remQuo","bitwise","xSign","ySign","xRem","yRem","xDigit","yDigit","xDivMod","yDivMod","LOBMASK_I","LOBMASK_BI","roughLOB","integerLogarithm","max","min","gcd","lcm","randBetween","low","high","range","digits","toBase","restricted","top","digit","text","absBase","alphabetValues","isNegative","start","parseBaseFromArray","val","pow","stringify","out","left","divmod","toBaseString","zeros","parseStringValue","split","decimalPlace","isValid","parseNumberValue","ml_z_normalize","ml_z_abs","ml_z_add","ml_z_compare","ml_z_div","ml_z_divexact","ml_z_equal","ml_z_fits_int","ml_z_fits_int32","ml_z_format","cas","width","alt","dir","pad","prefix","pre","ml_z_gcd","ml_z_hash","acc","caml_zarith_marshal","block","caml_zarith_unmarshal","negate","ml_z_init","ml_z_logand","ml_z_logor","ml_z_mul","ml_z_neg","ml_z_numbits","upperBound","ml_z_of_bits","base1","ml_z_of_float","f1","ml_z_of_int","ml_z_of_int64","jsoo_z_of_js_string_base","bc","ml_z_of_substring_base","ml_z_pow","ml_z_pred","ml_z_rem","ml_z_shift_left","amt","ml_z_shift_right","ml_z_sign","ml_z_sub","ml_z_succ","ml_z_testbit","ml_z_to_bits","ml_z_to_int","ml_z_fits_int64","ml_z_to_int64","mask","mult_nat","len3","nth_digit_nat","prover_to_json","set_digit_nat","set_digit_nat_native","ms_to_nano","time_now_nanoseconds_since_unix_epoch_or_zero","ms","ms_i63","unix_inet_addr_of_string","caml_fatal_uncaught_exception","throw_errors","collect_strings","caml_setup_uncaught_exception_handler","origin","event","zero$0","y$0","minus_one$0","zero_pos","sub_format","formatting_lit","opt","locfmt","null$0","current_dir_name","parent_dir_name","dir_sep","quotequote","null$1","current_dir_name$0","parent_dir_name$0","dir_sep$0","null$2","current_dir_name$1","parent_dir_name$1","dir_sep$1","module_name","tp_loc","module_name$2","ocaml_lex_tables","m1","m2","m4","h01","the_generic_group$2","mask$0","the_generic_group$3","module_name$13","module_name$14","elided_message","null$3","tp_loc$0","tp_loc$1","tp_loc$2","flags$0","am_recording_environment_varia","name$3","name$4","name$5","name$6","name$7","name$8","name$9","name$10","name$11","name$12","name$13","name$14","name$15","name$16","name$17","name$18","name$19","name$20","name$21","name$22","name$23","ocaml_lex_tables$0","int64$1","golden_gamma","beginning_of_file","err$2","err$1","err$0","tp_loc$3","name$26","tp_loc$4","name$27","tp_loc$5","tp_loc$6","name$28","tp_loc$7","tp_loc$8","name$29","tp_loc$9","tp_loc$10","name$30","tp_loc$11","name$31","name$32","default_seed","default_shrink_attempts","name$55","name$56","name$57","name$58","name$59","name$60","name$61","name$62","name$63","name$64","name$65","name$66","name$67","name$68","name$69","name$70","name$71","name$72","name$73","name$74","name$75","unit_of_time_list","name$77","name$78","name$81","name$80","name$79","module_name$24","tp_loc$14","all$2","name$82","tp_loc$15","name$83","module_name$25","name$84","name$85","suffix$6","suffix","tp_loc$16","module_name$26","module_name$27","suffix$13","module_name$28","name$86","name$87","module_name$29","tp_loc$17","tp_loc$18","atom","record$1","label","ocaml_lex_tables$1","ocaml_lex_tables$2","ocaml_lex_tables$3","name$89","module_name$30","name$90","tp_loc$19","tp_loc$20","tp_loc$21","label$0","pos$0","tp_loc$22","tp_loc$23","tp_loc$24","pos$1","op","tp_loc$25","tp_loc$26","tp_loc$27","tp_loc$28","state$11","state$10","state$9","state$8","state$7","state$6","state$5","state$4","state$3","state$2","state$1","state$0","feature_flags","maybe","tp_loc$29","none$1","actual_feature_flags","tp_loc$30","tp_loc$31","tp_loc$32","tp_loc$33","tp_loc$34","tp_loc$35","tp_loc$36","tp_loc$37","tp_loc$38","tp_loc$39","tp_loc$40","tp_loc$41","tp_loc$42","tp_loc$43","tp_loc$44","tp_loc$45","pos$3","pos$2","slots","slots$0","name$91","n$0","here","tp_loc$46","none$2","arg$0","tp_loc$47","level_bits$0","here$0","here$1","here$2","here$3","here$4","here$5","tp_loc$48","tp_loc$49","tp_loc$50","tp_loc$51","list$1","tp_loc$52","list$2","tp_loc$53","empty$15","v_print_debug_messages_for","environment_variable","job_queue","deferred0","deferred1","monitor","import0","error$0","pos$4","fmt$0","fmt$1","start$0","expected","id$2","pos$9","pos$8","pos$7","pos$6","pos$5","tp_loc$54","state$12","tp_loc$55","tp_loc$56","state$13","tp_loc$57","pos$10","tp_loc$58","tp_loc$59","pos$12","pos$11","tp_loc$65","tp_loc$60","tp_loc$61","tp_loc$62","tp_loc$63","tp_loc$64","pos$13","pos$16","pos$15","pos$14","name$92","id$3","name$93","id$4","pos$18","pos$17","ast_impl_magic_number","ast_intf_magic_number","right","fmt$4","fmt$5","fmt$6","opt$1","cs","infix_symbols","special_infix_strings","reset_ctxt","ast_impl_magic_number$0","ast_intf_magic_number$0","ast_impl_magic_number$1","ast_intf_magic_number$1","ast_impl_magic_number$2","ast_intf_magic_number$2","ast_impl_magic_number$3","ast_intf_magic_number$3","ast_impl_magic_number$4","ast_intf_magic_number$4","ast_impl_magic_number$5","ast_intf_magic_number$5","ast_impl_magic_number$6","ast_intf_magic_number$6","ast_impl_magic_number$7","ast_intf_magic_number$7","ast_impl_magic_number$8","ast_intf_magic_number$8","ast_impl_magic_number$9","ast_intf_magic_number$9","ast_impl_magic_number$10","ast_intf_magic_number$10","ast_impl_magic_number$11","ast_intf_magic_number$11","pos$19","txt","string_version","string_version$0","string_version$1","string_version$2","string_version$3","string_version$4","string_version$5","string_version$6","string_version$7","string_version$8","string_version$10","string_version$11","flags$2","flags$1","prefix$3","kind$2","vals","prefix$4","warnings","prefix$5","pos$24","pos$23","pos$22","pos$21","pos$20","tp_loc$66","tp_loc$67","tp_loc$68","tp_loc$69","state$15","state$14","tp_loc$70","tp_loc$71","state$16","tp_loc$72","state$21","state$20","state$19","state$18","state$17","tp_loc$73","tp_loc$74","tp_loc$75","tp_loc$76","tp_loc$77","tp_loc$78","tp_loc$79","tp_loc$80","commit_id","commit_date","marlin_commit_id","pos$31","pos$30","pos$29","pos$28","pos$27","pos$26","pos$25","state$25","initial_prefix","prefix$7","state$24","state$23","state$22","tp_loc$81","tp_loc$82","tp_loc$83","tp_loc$84","tp_loc$85","tp_loc$86","prefix$6","acc$0","state$27","state$26","tp_loc$87","tp_loc$88","tp_loc$89","pos$32","b_010","b_002","pos$34","pos$33","state$28","tp_loc$90","sponge_name","pos$35","description$0","state$30","tp_loc$91","sponge_name$0","pos$43","pos$42","pos$41","pos$40","t2$2","t1$2","t2$3","t1$3","pos$39","pos$38","pos$37","pos$36","t2$0","t1$0","t2$1","t1$1","v0$0","t$7","pos$48","pos$47","pos$46","pos$45","t2$4","t1$4","t2$5","t1$5","pos$44","domains","t$8","tp_loc$92","tp_loc$93","pos$64","pos$63","pos$62","pos$61","pos$60","pos$59","pos$58","pos$57","pos$56","pos$55","pos$54","pos$53","pos$52","pos$51","pos$50","pos$49","tp_loc$94","pos$65","tagname","branches","pos$67","pos$66","tp_loc$95","tp_loc$96","pos$68","pos$69","description$1","description$2","tp_loc$97","tp_loc$98","tp_loc$99","tp_loc$100","tp_loc$101","pos$72","message$2","state$33","tp_loc$106","pos$71","message$1","state$32","tp_loc$102","tp_loc$103","tp_loc$104","tp_loc$105","hex_key_odd","hex_key_even","deriver","state$34","tp_loc$107","tp_loc$108","pos$73","cany","v$99","v$100","v$101","v$102","v$103","v$104","ocaml_lex_tables$5","type_kind$0","directive_location","pos$80","pos$79","pos$78","t1$6","t1$7","t1$8","pos$77","pos$76","pos$75","t2$7","t2$8","t2$9","key$1","pos$74","t2$6","introspection_query_raw","pos$84","prefix$8","suffix$14","pos$83","pos$82","pos$81","doc$0","v1","v2","manual","pos$88","pos$87","pos$86","pos$85","state$35","v$105","state$36","tp_loc$109","tp_loc$110","pos$94","pos$93","t2$11","pos$92","pos$91","t2$10","pos$90","pos$89","description$3","compiled","coinbase_amount_string","account_creation_fee_string","genesis_state_timestamp_string","env$1","tp_loc$112","err$3","tp_loc$111","description$4","tp_loc$113","state$37","tp_loc$114","tp_loc$115","description$5","pos$95","tp_loc$116","tp_loc$117","state$39","state$38","tp_loc$118","tp_loc$119","description$6","pos$98","pos$97","state$40","pos$96","tp_loc$120","tp_loc$121","t1$9","empty$35","pos$99","s$2","s$1","s$0","description$7","state$42","state$41","tp_loc$122","tp_loc$123","pos$100","tp_loc$124","tp_loc$125","empty$37","state$45","state$44","state$43","tp_loc$126","tp_loc$127","tp_loc$128","tp_loc$129","tp_loc$130","state$47","state$46","tp_loc$131","tp_loc$132","description$8","description$9","description$10","tp_loc$133","tp_loc$134","tp_loc$135","five","state$48","empty_stack_msg","salt_phrase","deriver_name","salt_phrase$0","deriver_name$0","salt_phrase$1","tp_loc$136","state$49","default$10","tp_loc$137","tp_loc$138","description$11","tp_loc$139","pos$105","pos$104","pos$103","pos$102","t2$13","pos$101","t2$12","tp_loc$140","tp_loc$141","tp_loc$142","epoch_data$0","dummy_value","tp_loc$143","tp_loc$144","tp_loc$145","tp_loc$146","tp_loc$147","tp_loc$148","tp_loc$149","tp_loc$150","tp_loc$151","tp_loc$152","tp_loc$153","tp_loc$154","tp_loc$155","tp_loc$156","tp_loc$157","tp_loc$158","tp_loc$159","tp_loc$160","tp_loc$161","tp_loc$162","tp_loc$163","tp_loc$164","tp_loc$165","tp_loc$166","tp_loc$167","tp_loc$168","tp_loc$169","state$54","state$53","state$52","tp_loc$170","description$12","tp_loc$171","tp_loc$172","state$56","state$55","tp_loc$173","description$13","tp_loc$174","state$58","state$57","tp_loc$175","description$14","tp_loc$176","state$63","state$62","state$61","state$60","state$59","tp_loc$177","description$15","description$16","tp_loc$178","tp_loc$179","description$17","tp_loc$180","tp_loc$181","tp_loc$182","tp_loc$183","tp_loc$184","tp_loc$185","tp_loc$186","tp_loc$187","tp_loc$188","tp_loc$189","state$67","state$66","state$65","state$64","description$18","description$19","tp_loc$190","names$1","tp_loc$191","names$2","tp_loc$192","tp_loc$193","state$69","state$68","tp_loc$194","tp_loc$195","pos$107","pos$106","tp_loc$196","tp_loc$197","transaction_id$1","expected_hash$1","transaction_id$0","expected_hash$0","transaction_id","expected_hash","description$20","pos$108","update_failed","kind$3","tp_loc$198","tp_loc$199","tp_loc$200","tp_loc$201","tp_loc$202","tp_loc$203","tp_loc$204","tp_loc$205","tp_loc$206","nsf_tag","min_balance_tag","description$22","description$21","name$99","erase_rel","rest","rest$0","rest$1","rest$2","rest$3","rest$4","rest$5","rest$6","rest$7","ty","rest$8","ty1","rest$9","rest$10","rest$11","rest$12","rest$13","concat_fmtty","fmtty1","fmtty2","ty2","concat_fmt","fmt1","fmt2","pad$0","pad$1","iconv","prec$0","pad$2","iconv$0","prec$1","pad$3","iconv$1","prec$2","pad$4","iconv$2","prec$3","pad$5","fconv","pad$6","chr","fmtty","pad$7","fmtty$0","pad$8","rest$14","rest$15","rest$16","fmting_lit","rest$17","fmting_gen","rest$18","rest$19","char_set","width_opt","rest$20","counter","rest$21","rest$22","ign","rest$23","arity","cur","failwith","invalid_arg","lnot","nan","max_finite_value","max_queue_length","min$0","symbol","char_of_int","bool_of_string","int_to_string","valid_float_lexem","i$0","string_of_float","tl","hd","open_out_gen","perm","open_out","open_out_bin","flush_all","iter","output_string","oc","output_substring","close_out","open_in_gen","open_in_bin","input","unsafe_really_input","ofs$0","len$0","len$1","ofs$1","really_input","really_input_string","prerr_string","symbol$0","str2","exit_function","at_exit","f_yet_to_run","old_exit","new_exit$0","new_exit","success","do_at_exit","exit","retcode","close_in","os_type$0","cygwin","arch_big_endian","num_bits_int","is_block","lazy_tag","object_tag","forward_tag","slot","extension_name","max_ephe_length","raise_undefined","force_lazy_block","blk","closure","empty","append$0","seq1","seq2","next","map","seq","filter_map","seq$0","flat_map","fold_left","acc$1","unfold","u","u$0","some","default$0","map$0","fold","none","iter$0","is_none","map$1","map_error","equal","param$0","nth","l$0","l$1","n$1","rev_append","l1$0","l2$0","l1$1","l2$1","rev","param","accu","accu$0","accu$1","assoc_exn","find_exn","xs","ry","rx","cmp","rev_sort","tl$1","x2$0","x1$0","n1","n2","sort","tl$0","t2","h2","t1","h1","c$0","c$1","c$2","c$3","c$4","c$5","c$6","accu$2","aux","tail","min$1","max$0","to_string$0","is_space","apply1","seplen","is_space$0","i$1","i$2","index_rec","lim","lowercase_ascii$0","capitalize_ascii","uncapitalize_ascii","to_buffer","sx","sy","la","lb","res$0","hd$0","zero","minus_one","succ","pred","abs$0","min$2","max$1","lognot","int32_to_string","succ$0","pred$0","abs$1","bit_not","int64_to_string","y$1","min_nativeint","max_nativeint","nativeint_to_string","engine","sth","with_positions","aux_buffer","read","newlen","newbuf","env","clear_parser","height","create","hl","h$0","hr","bal","lv","ll","lrr","lrv","lrl","rr","rv","rl","rlr","rlv","rll","singleton","add_min_element","add_max_element","join","rh","lh","min_elt","min_elt_opt","max_elt","param$1","max_elt_opt","remove_min_elt","r$0","concat","pres","pres$0","is_empty","remove","union","r2$0","r1$0","inter","split_bis","disjoint","s1$0","s2$0","s2$1","diff","cons_enum","e$0","e$1","compare","e2$2","e1$2","e1","e2","e2$0","e1$0","e2$1","e1$1","subset","for_all","exists","filter","pv","partition","lf","lt","rf","rt","cardinal","elements_aux","elements","find","find_first","v$0","find_first_opt","find_last","find_last_opt","find_opt","try_join","v$1","of_list","sub","l$3","x0","l$4","x0$0","l$5","x0$1","nl","mid","l$2","x4","add_seq","of_seq","seq_of_enum","to_seq","snoc_enum","rev_seq_of_enum","to_rev_seq","to_seq_from","ld","lrd","rld","d$0","min_binding","min_binding_opt","max_binding","max_binding_opt","remove_min_binding","update","data$0","mapi","m$0","add_min_binding","add_max_binding","concat_or_join","merge","d1","d2","d2$0","d1$0","d2$1","d1$1","pvd","fvd","m$1","bindings_aux","bindings","clear","push","pop_opt","top_opt","clear$0","cell","resize","more","old_len","new_len","new_buffer","uchar_utf_8_byte_length_max","new_position","create_char_set","add_in_char_set","str_ind","pad_of_pad_opt","pad_opt","param_format_of_ignored_format","pad_opt$0","pad_opt$1","pad_opt$2","pad_opt$3","pad_opt$4","prec_opt","pad_opt$5","ndec","pad_opt$6","pad_opt$7","pad_opt$8","default_float_precision","buffer_create","init_size","buffer_check_size","overhead","min_len","buffer_add_char","buffer_add_string","buffer_contents","char_of_iconv","string_of_formatting_lit","str$0","bprint_fmtty","sub_fmtty","sub_fmtty$0","symm","trans","rest2","rest2$0","rest2$1","rest2$2","rest2$3","rest2$4","rest2$5","rest2$6","rest2$7","ty2$0","rest2$8","ty22","ty21","fmtty_rel_det","f4","f2","rest2$9","rest2$10","rest2$11","rest2$12","rest2$13","de","ed","af","fa","de$0","ed$0","af$0","fa$0","de$1","ed$1","af$1","fa$1","de$2","ed$2","af$2","fa$2","de$3","ed$3","af$3","fa$3","de$4","ed$4","af$4","fa$4","de$5","ed$5","af$5","fa$5","de$6","ed$6","af$6","fa$6","de$7","ed$7","af$7","fa$7","de$8","ed$8","af$8","fa$8","jd","dj","ga","ag","de$9","ed$9","af$9","fa$9","de$10","ed$10","af$10","fa$10","de$11","ed$11","af$11","fa$11","de$12","ed$12","af$12","fa$12","de$13","ed$13","af$13","fa$13","fmtty_of_precision_fmtty","fmtty_of_padding_fmtty","fmtty_of_custom","arity$0","fmtty_of_fmt","ty_rest","prec_ty","ty_rest$0","prec_ty$0","ty_rest$1","prec_ty$1","ty_rest$2","prec_ty$2","ty_rest$3","prec_ty$3","fmtty$1","fmtty$2","fmtty$3","ty$0","fmtty$4","fmtty$5","type_padding","padty","padty$0","type_padprec","type_ignored_format_substituti","type_format_gen","fmtty_rest","sub_fmtty_rest","sub_fmtty_rest$0","fmtty_rest$0","sub_fmtty_rest$1","sub_fmtty_rest$2","fmtty_rest$1","sub_fmtty_rest$3","fmt$2","sub_fmtty_rest$4","fmtty_rest$2","sub_fmtty_rest$5","fmt$3","sub_fmtty_rest$6","fmtty_rest$3","sub_fmtty_rest$7","sub_fmtty_rest$8","fmtty_rest$4","sub_fmtty_rest$9","sub_fmtty_rest$10","fmtty_rest$5","sub_fmtty_rest$11","sub_fmtty_rest$12","fmtty_rest$6","sub_fmtty_rest$13","fmt$7","sub_fmtty_rest$14","fmtty_rest$7","sub2_fmtty","sub_fmtty_rest$15","sub2_fmtty$0","fmt$8","sub_fmtty_rest$16","fmtty_rest$8","sub2_fmtty$1","sub1_fmtty","sub_fmtty_rest$17","sub2_fmtty$2","sub1_fmtty$0","fmt$9","sub_fmtty_rest$18","fmtty_rest$9","sub_fmtty_rest$19","fmt$10","sub_fmtty_rest$20","fmtty_rest$10","sub_fmtty_rest$21","fmt$11","sub_fmtty_rest$22","fmtty_rest$11","sub_fmtty_rest$23","fmt$12","sub_fmtty_rest$24","fmtty_rest$12","sub_fmtty_rest$25","fmt$13","sub_fmtty_rest$26","fmt_rest","fmt_rest$0","fmt_rest$1","fmt_rest$2","fmt_rest$3","fmt_rest$4","fmt_rest$5","prec$4","fmtty$6","fmt_rest$6","prec$5","prec$6","fmtty$7","fmt_rest$7","prec$7","prec$8","fmtty$8","fmt_rest$8","fmtty$9","fmt_rest$9","fmtty$10","fmt_rest$10","fmtty$11","fmt_rest$11","fmtty$12","fmt_rest$12","fmtty$13","sub_fmtty1","fmt_rest$13","sub_fmtty$1","fmtty$14","fmt$14","fmt_rest$14","fmtty$15","fmt$15","fmt_rest$15","fmtty$16","fmt$16","fmt_rest$16","fmtty$17","fmt$17","fmt_rest$17","formatting_gen","fmtty3","fmt3","str$1","fmt1$0","fmtty2$0","fmt2$0","fmtty3$0","fmt3$0","fmtty_rest$13","fmt_rest$18","fmtty$18","fmt$18","fmtty_rest$14","fmt_rest$19","fmtty$19","fmt$19","fmtty_rest$15","fmt_rest$20","fmtty$20","fmt$20","type_ignored_param_one","fmtty_rest$16","fmtty$21","fmt$21","sub_fmtty$2","sub_fmtty$3","fmtty$22","fmt$22","sub_fmtty$4","type_format","recast","fix_padding","width$0","fix_int_precision","res$1","string_to_caml_string","format_of_fconv","symb","transform_int_alt","put","convert_int","convert_int32","convert_nativeint","convert_int64","convert_float","hex","caml_special_val","string_of_fmtty","make_printf$0","k$0","new_acc","make_printf","make_padding","make_int_padding_precision","p$0","p$1","acc$2","acc$3","acc$4","k$3","kacc","k$1","k$4","k$2","make_ignored_param","make_custom$0","make_invalid_arg","make_from_fmtty$0","make_from_fmtty","make_custom","output_acc","p$2","p$3","p$4","bufput_acc","strput_acc","failwith_message","open_box_of_string","invalid_box","parse_spaces","parse_lword","j$0","j$1","parse_int","wstart","wend","box_name","nstart","nend","indent","exp_end","box_type","make_padding_fmt_ebb","make_padprec_fmt_ebb","fmt_ebb_of_string","legacy_behavior","flag","legacy_behavior$0","invalid_format_message","unexpected_end_of_format","end_ind","invalid_format_without","expected_character","add_literal","lit_start","parse_positive","str_ind$0","str_ind$1","parse_integer","next_ind","incompatible_flag","pct_ind","option","subfmt","compute_int_conv","plus","hash","space","plus$0","hash$0","space$0","search_subformat_end","sub_end","str_ind$2","sub_end$0","str_ind$3","sub_end$1","str_ind$4","str_ind$5","sub_end$2","str_ind$6","str_ind$7","parse_magic_size","str_ind_1","str_ind_2","str_ind_3","parse","parse_good_break","formatting_lit$0","str_ind_4","str_ind_5","parse_tag","is_open_tag","ind","sub_str","sub_fmt","sub_format$0","formatting$0","formatting","parse_flags","minus","set_flag","new_ind","parse_after_padding","parse_literal","parse_after_precision","symb$0","minus$0","parse_conversion","parse_conv","padprec","plus_used","hash_used","space_used","ign_used","pad_used","prec_used","get_plus","get_hash","get_space","get_ign","get_pad","get_prec","get_padprec","get_int_pad","check_no_0","opt_of_pad","width$1","get_pad_opt","get_padprec_opt","fmt_result","ignored$2","counter$0","ignored$6","ignored$7","char_set$1","add_char","add_range","fail_single_percent","parse_char_set_content","parse_char_set_after_char$0","parse_char_set_after_char","reverse","char_set$0","char_set$2","ignored$9","char_format","fmt_rest$21","fmt_rest$22","pad$9","fmt_rest$23","ignored$10","fmt_rest$24","pad$10","fmt_rest$25","sub_fmt$0","fmt_rest$26","ignored$11","ignored$3","ignored$5","ignored$8","space$1","hash$1","plus$2","ignored$4","ignored","ignored$0","ignored$1","plus$1","ign$0","fprintf","bprintf","ksprintf","sprintf","assoc3","y2","y1","split$0","make_symlist","help_action","add_help","speclist","add2","current","bool_of_string_opt","int_of_string_opt","float_of_string_opt","parse_and_expand_argv_dynamic_","allow_expand","anonfun","errmsg","initpos","convert_error","error","progname","doc","spec","follow$0","action","keyword","no_arg$0","follow","no_arg","get_arg$0","get_arg","consume_arg$0","consume_arg","treat_action$0","treat_action","f$0","f$1","r$1","f$2","arg$1","r$2","arg$2","x$0","f$3","arg$3","x$1","r$3","arg$4","x$2","specs","f$4","arg$5","f$5","f$6","f$7","arg$6","newarg","before","after","parse_argv","sth$0","speclist$0","second_word","loop","max_arg_len","kwd","replace_leading_tab","align","completed","ksd","msg$0","cutcol$0","spaces$0","cutcol","kwd_len","spaces","printers","field","other_fields","to_string$1","conv","char$0","line","char$1","line$0","file$0","char$2","line$1","file$1","constructor","convert_raw_backtrace","format_backtrace_slot","is_raise","print_raw_backtrace","outchan","raw_backtrace","backtrace","raw_backtrace_to_string","get_backtrace","register_printer","old_printers","new_printers","errors","default_uncaught_exception_han","status","uncaught_exception_handler","empty_backtrace","handle_uncaught_exception","debugger_in_use","exn$0","raw_backtrace$0","protect","finally$0","work","finally_no_exn","work_exn","work_bt","char_hex","new_state","assign","st1","st2","full_init","seed$0","make$1","make_self_init","copy$1","curval","newval30","init$2","get_state","set_state","ongoing_traversal","flip_ongoing_traversal","params","randomized_default","prng","initial_size","random","clear$2","reset$0","copy_bucketlist","key$0","next$0","copy$2","length$1","resize$0","indexfun","odata","osize","nsize$0","ndata","inplace","indexfun$0","nsize","ndata_tail","cell$0","nidx","match","match$0","iter$4","do_bucket","old_trav","filter_map_inplace_bucket","filter_map_inplace","fold$0","b$0","bucket_length","stats","mbl","histo","to_seq$0","tbl_data","buck","buck$0","buck$1","to_seq_keys","to_seq_values","key_index","bucket","next1","next2","k3","d3","next3","find_all","find_in_bucket","replace","replace_seq","id$0","unknown","pp_enqueue","pp_infinity","pp_output_string","pp_output_newline","format_pp_text","format_string","break_new_line","real_indent","break_line","break_same_line","format_pp_token","size$0","tabs","add_tab","ls","tag_name","marker","breaks","fits","box_type$0","off$0","insertion_point","tabs$0","first","head","tab","off$1","insertion_point$0","width$2","box_type$1","tbox","tag_name$0","marker$0","advance_left","pending_count","enqueue_advance","tok","enqueue_string_as","initialize_scan_stack","queue_elem","set_size","left_total","scan_push","elem","pp_open_box_gen","br_ty","pp_flush_queue","pp_print_as_size","isize","pp","blank_line","display_indent","default_pp_mark_open_tag","default_pp_mark_close_tag","default_pp_print_open_tag","default_pp_print_close_tag","flush","pp_queue","sys_tok","scan_stack","ppf","pp_buffer_size","pp_make_buffer","flush_buffer_formatter","pp_print_list","pp_v","opt$0","pp_sep","vs","compute_tag","tag_acc","output_formatting_lit","output_acc$0","bty","p$5","p$6","strput_acc$0","size$1","flush_standard_formatters","null_char","next_char","ib","peek_char","checked_peek_char","end_of_input","char_count","reset_token","invalidate_current_char","token_string","token_buffer","skip_char","ignore_char","store_char","default_token_buffer_size","create$2","iname","scan_raise_at_end","from_ic","scan_close_ic","eof","bad_input","bad_input_escape","bad_token_length","message","bad_float","bad_hex_float","character_mismatch","ci","check_this_char","check_char","token_char","token_bool","integer_conversion_of_char","token_int_literal","token_float","scan_decimal_digit_star","scan_unsigned_decimal_int","scan_digit_plus","basis","digitp","width$3","is_binary_digit","scan_binary_int","is_octal_digit","scan_octal_int","is_hexa_digit","scan_hexadecimal_int","scan_sign","scan_optionally_signed_decimal","scan_int_conversion","scan_fractional_part","scan_exponent_part","scan_float","precision","precision$0","check_case_insensitive_string","lowercase","scan_hex_float","width$4","width$5","width$6","width$10","width$7","width$8","width$9","scan_caml_float_rest","width_precision","frac_width","scan_caml_float","scan_string","stp","scan_char","hexadecimal_value_of_char","check_next_char","check_next_char_for_char","check_next_char_for_string","scan_backslash_char","c0","get_digit","get_digit$0","c1$0","c2$0","scan_caml_char","find_stop","scan_caml_string","find_stop$0","skip_spaces","scan_chars_in_char_set","scan_indic","scan_chars","ef","get_counter","width_of_pad_opt","stopper_of_formatting_lit","fmting","take_format_readers$0","take_fmtty_format_readers$0","new_k","readers_rest","take_format_readers","fmt$23","fmt$24","fmt$25","take_fmtty_format_readers","make_scanf","readers","scan$0","str_rest","pad_prec_scanf","scan$1","scan$2","scan","scan$3","scan$4","conv$0","scan$5","conv$1","scan$6","conv$2","scan$7","scan$8","fmting_lit$0","str$2","stp$0","str_rest$0","rest$24","rest$25","rest$26","arg_rest","sscanf","apply","args$0","exc","register_exception","initial_object_size","public_method_label","compare$0","compare$1","compare$2","table_count","dummy_met","fit_size","new_table","pub_labels","methods","resize$1","new_size","old_size","new_buck","method_count","inst_var_count","new_method","table","get_method_label","get_method_labels","names","set_method","element","get_method","to_list$0","new_slot","new_variable","to_array","get_variable","create_table","public_methods","tags","met","lab","init_class","inherits","cla","virt_meths$1","concr_meths$0","super$0","vars","virt_meths","concr_meths","virt_meth_labs","concr_meth_labs","tvars","by_name","by_label","hm","vars$0","virt_meths$0","saved_vars","saved_hidden_meths","by_label$0","by_name$0","make_class","pub_meths","class_init","env_init","create_object_opt","obj_0","run_initializers_opt","inits","new_cache","set_methods","clo","clo$0","n$2","n$3","n$4","n$5","n$6","x$3","n$7","x$4","n$8","n$9","x$5","f$8","e$2","n$10","x$6","f$9","n$11","x$7","n$12","x$8","n$13","n$14","e$3","n$15","m$2","x$9","m$3","n$16","m$4","e$4","n$17","m$5","n$18","init_mod_block","loc","comps$0","modu","shape","fn$0","undef","comps","init_mod","update_mod_block","cl","update_mod","generic_basename","is_dir_sep","generic_dirname","is_relative","is_implicit","check_suffix","suff","len_s","len_suf","chop_suffix_opt","filename","len_f","quote","quote_command","stdin","stdout","stderr","basename","dirname","is_dir_sep$0","is_relative$0","is_implicit$0","check_suffix$0","chop_suffix_opt$0","temp_dir_name","quote$0","add_bs","loop$0","loop_bs","quote_cmd_filename","quote_command$0","drive_and_path","dirname$0","drive","basename$0","basename$1","dirname$1","dir_sep$2","is_dir_sep$1","is_relative$1","temp_dir_name$0","quote$1","basename$2","concat$0","prng$0","temp_file_name","temp_dir","rnd","temp_file","try_name","counter$1","create$3","dim","create$4","dim1","dim2","create$5","of_bool","sexp_of_string","sexp_of_ref","sexp_of_a","sexp_of_option","sexp_of_b","sexp_of_list","lst","sexp_of_array","ar","lst_ref","compare$4","exn_id_map","clean_up_handler","old_exn_id_map","new_exn_id_map","add$1","sexp_of_exn","finalise","ephe","find_auto","sexp","exn_to_string","what","of_bool$0","string_of_sexp","int_of_sexp","int32_of_sexp","int64_of_sexp","nativeint_of_sexp","ref_of_sexp","a_of_sexp","option_of_sexp","el","b_of_sexp","b_sexp","a_sexp","list_of_sexp","rev_lst","array_of_sexp","t$0","t_of_sexp$1","get_flc_error","handler","extension_constructor","tuple_of_size_n_expected","stag_no_args","stag_incorrect_n_args","stag_takes_args","nested_list_invalid_sum","empty_list_invalid_sum","unexpected_stag","record_only_pairs_expected","record_superfluous_fields","rev_fld_names","fld_names_str","record_duplicate_fields","record_extra_fields","record_undefined_elements","undefined$0","record_list_instead_atom","no_variant_match","no_matching_variant_found","ptag_no_args","ptag_incorrect_n_args","cnstr","ptag_takes_args","nested_list_invalid_poly_var","empty_list_invalid_poly_var","empty_type","scale","symbol$1","symbol$2","symbol$3","symbol$4","symbol$5","symbol$6","ascending","descending","equal$1","max$2","min$3","symbol$7","symbol$8","symbol$9","symbol$10","symbol$11","symbol$12","ascending$0","descending$0","compare_int64","equal_int64","max$3","min$4","symbol$13","symbol$14","symbol$15","symbol$16","symbol$17","symbol$18","ascending$1","descending$1","compare_nativeint","equal_nativeint","max$4","min$5","compare_bool","equal_bool","compare$6","compare_float","equal_float","compare_string","equal_string","asr","lor","lsl","lsr","lxor","decr","incr","am_testing","failwithf","getenv","var$0","of_int_exn","of_msb_first","hash_fold_unit","as_int","hash_fold_int32","hash_fold_char","hash_fold_bool","hash_fold_nativeint","hash_fold_option","hash_fold_elem","hash_fold_list","list$0","list","hash_fold_lazy_t","hash_fold_ref_frozen","hash_fold_array_frozen","hash_nativeint","hash_int64","hash_int32","hash_char","hash_int","hash_bool","hash_string","hash_float","hash_unit","compare_state","state_to_string","create$6","run","folder","of_fold","hash_fold_t","hash_fold_t$4","hash_fold_t$7","func$1","t$1","t$2","t$3","t$4","t$5","type_name","compare$11","compare_option","compare_elt","concat$1","ys","num_bits","word_size","formatter","v1$0","reraise","to_string$3","protectx","final_exn","protect$0","does_raise","pp$0","raise_without_backtrace","initialize_module","is_alive","return$0","a$0","map_via_bind","ma","symbol_bind","symbol_map","symbol_bind$0","symbol_map$0","symbol_bind$1","symbol_map$1","both","ignore_m","ts","all","all_unit","bind","map$5","bind$0","return$1","map$6","get$0","fst","snd","fst$0","snd$0","fold_result","fold_until","iter$1","return$5","join$1","bits$0","int32","bound","make$3","make_self_init$0","allow_in_tests","assign$0","int$0","bits$1","full_range_int64","bits$2","full_range_int_on_64bits","raise_crossed_bounds","lower_bound","upper_bound","string_of_bound","int$1","init$3","set_state$0","const$0","symbol$43","compare_list","equal_list","derived_map","map2","ta","tb","map3","tc","invariant$1","sexp_of_t","bounds_crossed","lower","upper","lower$0","upper$0","try_with$0","ok_exn","error_s","pass","fail","fail_s","name$0","protect$2","extract_name","alist","first_failure","t_of_sexp$4","sexp_of_t$8","compare$18","hash_fold_t$12","hsv","symbol$45","symbol$46","symbol$47","symbol$48","symbol$49","symbol$50","ascending$6","descending$6","compare$19","equal$4","max$8","min$9","of_string$1","to_string$5","incl","excl","incl$0","excl$0","incl$1","excl$1","incl$2","excl$2","between","clamp_exn","clamp","comparator","validate_lbound","validate_ubound","validate_bound","find_first_satisfying","hi$0","lo$1","lo$0","lo$2","find_last_satisfying","binary_search","how","binary_search_segmented","segment_of","is_left","is_right","unsafe_blit","blit","blito","src_len","sth$1","subo","create_like","length$0","unsafe_blit$0","is_none$0","is_some","equal_option","symbol_bind$2","bind$6","return$9","map$15","join$3","second","other","either","combine","other_loop","return_loop","combine_all","other_loop$0","return_loop$0","combine_all_unit","to_option","with_return$0","ret","combine$1","bind$7","either$0","combine$2","bind$8","iteri","foldi","foldi$0","counti","existsi","for_alli","find_mapi","findi","bind$10","return$11","map$17","create_zero","create$9","get$2","unsafe_set_with_caml_modify","unsafe_set_int_assuming_curren","unsafe_set","old_obj","abs_float","one_ulp","upper_bound_for_int","is_x_minus_one_exact","lower_bound_for_int","min_int_as_float","clamp_unchecked","hash_fold_t$14","t_of_sexp$6","sexp_of_t$11","equal$6","compare$23","comparator$2","compare$25","comparator$4","init$6","convert_failure","to_string","num_bits_nativeint","int_to_int32_trunc","int_to_int32","int_to_int32_exn","int32_to_int_exn","int_to_int64","int64_to_int_trunc","min$11","max$10","int64_is_representable_as_int","int64_to_int","int64_to_int_exn","int_to_nativeint","nativeint_to_int_trunc","nativeint_to_int","nativeint_to_int_exn","int32_to_int64","min$12","max$11","int64_is_representable_as_int3","int64_to_int32_exn","int32_to_nativeint","nativeint_to_int32_exn","nativeint_to_int64","min$28","max$29","to_nativeint_exn","min$13","max$12","int64_is_representable_as_int6","insert_delimiter_every","delimiter","chars_per_delimiter","input_length","has_sign","num_digits","num_delimiters","output_length","input_pos","output_pos","num_chars_until_delimiter","first_digit_pos","insert_delimiter","delimiter$0","make_suffix","to_string_hum","invalid","of_string_with_delimiter","of_string","ocaml_lex_state","ocaml_lex_state$0","body","body$0","int32_positive_overflow_bounds","int_positive_overflow_bounds","int63_on_int64_positive_overfl","int64_positive_overflow_bounds","int64_negative_overflow_bounds","negative_exponent","overflow","pow$0","rval","round_down","round_up","round_towards_zero","to_multiple_of","round_nearest","modulus_minus_remainder","round","int64_popcount","int32_popcount","popcount","popcount$0","t_sexp_grammar","of_float_unchecked","comparator$6","validate_lbound$2","validate_ubound$2","validate_bound$2","validate_positive","validate_non_negative","validate_negative","validate_non_positive","is_positive","is_non_negative","is_negative","is_non_positive","to_string_hum$2","sexp_of_t$13","zero$2","minus_one$2","pp$9","invariant$2","pred$2","succ$2","to_int$2","of_int$0","max_value_30_bits","abs$3","symbol$57","symbol$58","symbol$59","symbol$60","symbol$61","incr$0","decr$0","shift_right","shift_right_logical","shift_left","bit_not$0","bit_or","bit_and","bit_xor","symbol$62","ceil_pow2","floor_pow2","is_pow2","floor_log2","ceil_log2","symbol$63","symbol$64","symbol$65","bswap16","ctz","clz","sexp_of_t$14","symbol$66","symbol$67","symbol$68","symbol$69","symbol$70","symbol$71","equal$7","compare$27","min$14","max$13","ascending$8","descending$8","between$3","clamp_exn$3","clamp$3","comparator$7","validate_lbound$3","validate_ubound$3","validate_bound$3","t_of_sexp_direct","empty$4","to_list$5","mem$4","add$5","remove$2","of_list$3","never_returns","func$5","t_sexp_grammar$0","of_string$11","validate_lbound$6","validate_ubound$6","validate_bound$6","validate_positive$0","validate_non_negative$0","validate_negative$0","validate_non_positive$0","is_positive$0","is_non_negative$0","is_negative$0","is_non_positive$0","sign$0","invariant$3","num_bits$0","shift_right_logical$0","shift_right$0","shift_left$0","bit_xor$0","bit_or$0","bit_and$0","rem$0","symbol$84","to_float","of_float_unchecked$0","of_float","ceil_pow2$0","floor_pow2$0","is_pow2$0","floor_log2$0","ceil_log2$0","between$6","clamp_exn$6","clamp$6","symbol$85","symbol$86","symbol$87","symbol$88","incr$1","decr$1","pow$1","symbol$89","symbol$90","symbol$91","symbol$92","round$0","round_towards_zero$0","round_down$0","round_up$0","round_nearest$0","ctz$0","clz$0","is_empty$5","of_alist_exn$0","set$3","add_exn$1","add$7","change$1","remove$5","nth$5","of_tree$1","of_sorted_array_unchecked$2","of_alist$0","of_iteri$0","of_increasing_iterator_uncheck$2","hash$13","t_sexp_grammar$1","of_string$13","shift_right_logical$1","shift_right$1","shift_left$1","bit_xor$1","bit_or$1","bit_and$1","rem$1","symbol$93","to_float$0","of_float_unchecked$1","num_bits$1","of_float$0","symbol$94","bswap32","bswap48","validate_lbound$7","validate_ubound$7","validate_bound$7","validate_positive$1","validate_non_negative$1","validate_negative$1","validate_non_positive$1","is_positive$1","is_non_negative$1","is_negative$1","is_non_positive$1","sign$1","invariant$4","between$7","clamp_exn$7","clamp$7","symbol$95","symbol$96","symbol$97","symbol$98","incr$2","decr$2","of_int64","to_int64","ceil_pow2$1","floor_pow2$1","is_pow2$1","floor_log2$1","ceil_log2$1","to_string_hum$4","sexp_of_t$21","pp$11","symbol$99","symbol$100","symbol$101","round$1","round_towards_zero$1","round_down$1","round_up$1","round_nearest$1","ctz$1","clz$1","the_group$2","t_sexp_grammar$2","comparator$11","wrap_modulo","invariant$5","symbol$102","symbol$103","neg$2","abs$4","one$0","succ$3","pred$3","min_value$1","max_value$1","lnot$0","land$0","lxor$0","lor$0","lsl$0","asr$0","lsr$0","pow$2","symbol$104","symbol$105","rem$2","popcount$1","to_int64$0","of_int64$0","of_int64_exn","of_int64_trunc","t_of_sexp$10","sexp_of_t$22","compare$33","is_pow2$2","clz$2","ctz$2","floor_pow2$2","ceil_pow2$2","floor_log2$2","ceil_log2$2","the_group$3","t_sexp_grammar$3","func$6","invalid_str","sign_and_signedness","to_string$15","of_string$15","signedness","pos_str","int63","int63$0","bswap16$0","bswap32$0","bswap48$0","float_lower_bound$2","float_upper_bound$2","minus_one$3","one$1","zero$3","num_bits$2","to_float$1","of_float_unchecked$2","of_float$1","validate_lbound$8","validate_ubound$8","validate_bound$8","validate_positive$2","validate_non_negative$2","validate_negative$2","validate_non_positive$2","is_positive$2","is_non_negative$2","is_negative$2","is_non_positive$2","sign$2","between$8","clamp_unchecked$4","clamp_exn$8","clamp$8","symbol$106","incr$3","decr$3","of_int$1","of_int_exn$0","to_int$3","to_int_exn","to_int_trunc","of_int32","of_int32_exn","to_int32","to_int32_exn","to_int32_trunc","of_nativeint$0","of_nativeint_exn","of_nativeint_trunc","to_nativeint$0","to_nativeint_exn$0","to_nativeint_trunc","hash$15","to_string$16","of_string$16","to_string$17","repr","validate_lbound$9","validate_ubound$9","validate_bound$9","func$7","t_sexp_grammar$4","compare_int32","of_string$18","num_bits$3","shift_right_logical$2","shift_right$2","shift_left$2","bit_xor$2","bit_or$2","bit_and$2","rem$3","symbol$110","to_float$2","of_float_unchecked$3","of_float$2","validate_lbound$10","validate_ubound$10","validate_bound$10","validate_positive$3","validate_non_negative$3","validate_negative$3","validate_non_positive$3","is_positive$3","is_non_negative$3","is_negative$3","is_non_positive$3","sign$3","symbol$111","symbol$112","symbol$113","symbol$114","symbol$115","symbol$116","descending$11","min$17","max$16","equal_int32","between$10","clamp_exn$10","clamp$10","invariant$6","symbol$117","symbol$118","symbol$119","symbol$120","incr$4","decr$4","pow$3","symbol$121","ceil_pow2$3","floor_pow2$3","is_pow2$3","floor_log2$3","ceil_log2$3","to_string_hum$6","sexp_of_t$24","pp$14","symbol$122","symbol$123","symbol$124","round$3","round_towards_zero$3","round_down$3","round_up$3","round_nearest$3","ctz$3","clz$3","hash_fold_t$20","hashable","of_key","Key","to_key","max$18","empty$9","height$1","update_height","old_height","new_height","balance","tree","left_node_left","left_node_right","lr_left","lr_right","right_node_left","right_node_right","rl_left","rl_right","set_left","tree$0","set_right","add$8","added","findi_and_call_impl","arg1","arg2","call_if_found","call_if_not_found","if_found","if_not_found","find_and_call","call_if_found$0","call_if_not_found$0","call_if_found$1","call_if_not_found$1","call_if_found$2","call_if_not_found$2","call_if_found$3","call_if_not_found$3","call_if_found$4","call_if_not_found$4","if_not_found$0","remove_min_elt$1","remove$6","removed","fold$11","init$0","rkey","rdata","rkey$0","rdata$0","rkey$1","rdata$1","lkey","ldata","right$0","init$1","data$1","iter$16","mapi_inplace","value$0","clear$4","mem$7","remove$7","length$15","inv$0","inv","left_key","right_key","to_list$7","add$10","iter$18","magnitude","round$5","sexp_of_float","validate$2","validate_positive$5","validate_non_negative$5","validate_negative$5","validate_non_positive$5","create$23","unsafe_blit$4","elide","to_string_list","sexp_of_t$27","initialize_module$0","ocamlrunparam_mentions_backtra","symbol$140","symbol$141","symbol$142","symbol$143","libname_ref","set$5","unset","add_environment_var","libs_to_entries","lookup_rev_lib","libname","force_drop","add_bench","type_conv_path","startpos","endpos","test_spec","entry","empty$10","eval_fail","custom_printf_001","equal_option$0","create$24","eq","xs$1","xs$0","map$23","uuid","int$2","pair","t_of_sexp$14","of_a","sexp_args$7","v1$5","v0$15","v0$16","v1$6","sexp_args$5","v1$1","v0$11","v0$12","v1$2","sexp_args$1","v0$3","v0$4","sexp_args$2","v0$5","v0$6","sexp_args","sexp_args$4","v0$9","v0$10","field_sexps","sorted_field","duplicates","extra","field_sexp","fvalue","sorted_value","sexp_args$6","v1$3","v0$13","v0$14","v1$4","sexp_args$3","v0$7","v0$8","sexp_args$0","v0$1","v0$2","map$24","to_string$21","v_sorted","bnds","bnds$0","digest_layer","to_digest","to_digest$0","equal$16","opaque","create$25","desc","apply$0","def","recurse","tid","get_poly_variant","annotate","basetype","poly_variant","var$1","apply$1","recurse$0","define","record","create$26","compare$36","a_064","b_065","b_067","a_066","cmp_a","a_068","b_069","b_015","b_013","a_014","b_019","b_017","a_020","b_021","b_023","a_024","b_025","b_027","a_028","b_029","t_031","t_030","t_033","t_032","b_035","a_036","b_037","t_039","t_038","t_041","t_040","a_042","b_043","b_045","a_004","b_005","t_007","t_006","t_009","t_008","a_048","b_049","b_053","b_051","a_054","b_055","b_059","b_057","a_060","b_061","b_063","t_of_sexp$15","equal_t0","var$2","apply$2","recurse$1","get_poly_variant$0","opaque$0","to_digest$1","to_digest$2","annotate$0","basetype$0","tuple$0","poly_variant$0","var$3","recurse$2","apply$3","define$0","record$0","variant$0","create$27","trips","members","scheme","custom_printf_108","v0$17","v1$7","v0$18","v0$19","v1$8","v1$9","v0$20","v_members","v_loc","v_gid","bnds$1","bnds$2","v1$10","v2$0","is_cyclic_0","via_VR","group","set","visited","trav_tid","trav","ts$0","lookup$0","a_109","b_110","t_112","t_111","t_114","t_113","extend","tenv","depth","look_env","extend_new_tid","def_t","tenv$0","exec","sequence_defining","acc_ys","eval_app","gid","formals","record_or_normal_variant","cyclic","cyclic_no_VR","venv","eval_definition","eval_poly_constr","eval_list","binds","alts","xss","vid","loc$0","custom_printf_115","tid$0","in_group","eval$0","bin_write_unit","bin_write_bool","all_bin_write_small_int","all_bin_write_int16","all_bin_write_int32","bin_write_char","bin_write_int","bin_write_nat0","bin_write_string","new_pos","bin_write_float","bin_write_el","pair$0","bin_write_a","bin_write_b","els_pos$1","els_pos$0","els_pos","els_pos_ref","bin_write_variant_int","bin_write_int_8bit","bin_read_unit","pos_ref","bin_read_bool","safe_bin_read_neg_int8","safe_bin_read_int16","bin_read_nat0","ch","bin_read_bytes","start_pos","bin_read_string","bin_read_char","bin_read_int","bin_read_float","bin_read_int32","bin_read_int64","bin_read_nativeint","bin_read_ref","bin_read_el","bin_read_option","bin_read_pair","bin_read_a","bin_read_b","bin_read_list","dummy_float_buf","max_float_array_length","el$1","maybe_float","el$0","bin_read_variant_int","bin_read_int_8bit","bin_shape_array","pair$1","bin_size_unit","bin_size_bool","bin_size_char","bin_size_int","bin_size_nat0","bin_size_string_or_bytes","size_len","bin_size_string","bin_size_float","bin_size_int32","bin_size_int64","bin_size_el","bin_size_a","bin_size_b","len$2","bin_size_len","total_len","total_len_ref","variant_wrong_type","pair$2","bin_writer_el1","bin_writer_el2","pair$3","bin_reader_el1","bin_reader_el2","pair$4","bin_el1","bin_el2","cnv_writer","cnv","tp_class","cnv_reader","vtag","pre_test_hook","nanoseconds_since_unix_epoch","create$28","binary","may_eof","really_input_exn","input_byte","input_char","already_read","to_read","already_read$0","to_read$0","mach","with_file","binary$0","fail_if_exists$0","perm$0","fail_if_exists","sth$2","value$1","am_recording_value","am_recording","of_string$22","to_string$22","nanos","to_string_with_same_unit","of_string$23","Format","create$29","nested_timer","definition_timer","record_start","record_until","until","gc_stats_after","gc_stats_before","runtime","gc_events","nested$0","nested_timing_events","timing_event","nested","timing_events_to_strings","duration_strings","duration_string","description","compactions","major_collections","minor_collections","to_list","strings","left_column_width","fake_timing_events","print_recorded_timing_events","timing_events","notify_of_overriding","override","timing_events$0","nested_timing_event","uid$0","witness","next$1","cmp$0","same_witness$0","nm1","nm2","uid","typename_of_t","args_labels","ocaml_repr","tyid","traverse","internal_use_only","is_polymorphic","internal_use_only$0","index$0","is_mutable","tyid$0","traverse$0","internal_use_only$1","typename_of_t$0","has_double_array_tag","create$0","internal_use_only$2","typename_of_int","typename_of_int32","typename_of_int64","typename_of_nativeint","typename_of_char","typename_of_float","typename_of_string","typename_of_bytes","typename_of_bool","typename_of_unit","typename_of_option","typename_of_list","typename_of_array","typename_of_lazy_t","typename_of_ref","typename_of_function","typename_of_tuple2","typename_of_tuple3","typename_of_tuple4","typename_of_tuple5","rep","rep$0","rep$1","rep$2","rep$3","rep$4","name$24","b$1","a$1","b$2","a$2","typename_of_t$1","rng","dom","rep$5","rep$6","same_witness$1","r2$1","r2$2","r2$3","r2$4","rng2","dom2","b2$0","a2$0","b1$0","a1$0","b2$1","a2$1","b1$1","a1$1","c2$1","b2$2","a2$2","c1$1","b1$2","a1$2","r2$5","r2$6","r2$7","name2","same$0","same_witness_exn$0","typerep_and_typename_of_int63_","repr_of_poly_variant","hash_variant","double_array_value","double$0","simple","named","of_p1","of_p2","of_p3","typename_of_named","typerep_of_t","v$106","dir_or_error","sexp_of_t$28","v_end_pos","v_start_pos","v_line_start","v_line_number","v_filename","bnds$3","compare$37","of_string$24","expected_length","tests_run","protect$3","current$2","set$7","absolute_filename","unset$0","flushed","upon_unreleasable_issue","get_position","extract_output","ocaml_lex_state$1","ocaml_lex_state$2","relative_filename","with_ic","fname","get_outputs_and_cleanup","last_ofs","next_ofs","outputs","trailing_output","current_test","get_current","save_output","location","save_and_return_output","prev_pos","prev_pos$0","trailing","blocks","final_flush","max_attempts","file_digest","expectations","uncaught_exn_expectation","uncaught_exn","saved_output","run$0","defined_in","inline_test_config","registering_tests_for","return$12","bind$11","to_run","of_int$3","mix_bits","mix64","z$0","z$1","random_int64","create$30","random_state","gamma","odd_gamma","next_int64","bool$0","int64$0","maximum","draw$0","draw","int$3","int32$0","nativeint","unit_float_from_int64","float$0","bits_to_represent","log_uniform","min_bits","max_bits","log_uniform$0","log_uniform$1","log_uniform$2","log_uniform$3","return$13","tf","tx","map$26","map$27","values","weights","value_array","weight","cumulative","choice","lazy_t","of_generator","min_length","max_length","max_length$0","remaining","max_index","let_syntax_267","value_t","list_generic","elt_gen","list_with_length","char_print_uniform","char_uniform","small_int","allow_zero","weighted_low","weighted_high","small_non_negative_int","let_syntax_002","uniform_inclusive","log_uniform_inclusive","non_uniform","inclusive","log_inclusive","uniform_all","quickcheck_generator$0","float_zero_exponent","float_zero_mantissa","float_max_positive_subnormal_v","float_subnormal_exponent","float_min_subnormal_mantissa","float_max_subnormal_mantissa","float_min_normal_exponent","float_max_normal_exponent","float_max_nan_mantissa","float_inf_exponent","float_inf_mantissa","float_nan_exponent","float_min_nan_mantissa","float_num_mantissa_bits","float_normal_mantissa","float_exponent_weighted_low","float_exponent_weighted_high","midpoint","float_exponent","float_zero","let_syntax_004","let_syntax_005","float_subnormal","float_normal","float_infinite","let_syntax_010","let_syntax_011","float_nan","float_matching_classes","quickcheck_generator$1","float_finite_non_zero","lower_inclusive","upper_inclusive","char_gen","let_syntax_033","key_gen","data_gen","keys","keys$0","bigarray1","elts","elts$0","offset$1","offset$0","max_total_size","max_b","b_weighted_low","bigarray2_dim","bigarray2","quickcheck_shrinker","f_inverse","of_shrinker","elt_t","list_t","shrinker","shrink_list","shrink_tree","key_t","data_t","drop_keys","shrink_keys","smaller_key","shrink_data","smaller_data","elt","drop_elts","shrink_elts","smaller_elt","default_config","lazy_nondeterministic_state","with_sample","generator","config","examples","number_of_size_values","remaining_sizes","sequence","run$1","config$0","examples$0","M","error$1","error$2","input$0","shrink_count$1","alternates$2","shrink_count","alternates","shrink_count$0","alternates$0","alternate","alternates$1","with_sample_exn","quickcheck_observer","sizes$0","key_obs","data_obs","elt_obs","length$16","create$31","max_mem_waiting_gc_in_bytes","create$32","unsafe_blit$5","length$17","to_string$23","of_string$25","sexp_of_pos","v_offset","v_col","v_line","sexp_of_range","make_range_incl","last_pos","create$33","initial_pos","reset$2","add_uint16","add_bits","int_buf","add_gen","instr","instr_bits","add_newline","create$34","chunks","chunk","no_more","next_instruction_bits","added_bits","advance","skip","offset_shift","offset_shift_num_bits","skip$0","offset_shift$0","offset_shift_num_bits$0","skip$1","offset_shift$1","offset_shift_num_bits$1","offset_shift$2","skip$2","advance_exn","find$7","sub_sexp_count","loop_list","sexps","loop$1","finalize","find$8","find$9","empty$11","get_many","empty$12","get_single","get_many$0","v_location","v_sub_sexp","v_user_exn","position","initial_state","error_state","rev_chunks","chunk_pos","extra_bits","is_ignoring","is_not_ignoring","raise$0","at_eof","reason","old_parser_exn","current_pos","set_automaton_state","advance$0","advance_eol","newline_offset","add_token_char","add_atom_char","add_quoted_atom_char","check_new_sexp_allowed","is_single","add_pos","add_first_char","eps_add_first_char_hash","start_quoted_string","eps_add_escaped_cr","hex_val","add_dec_escape_char","opening","do_reset_positions","reset_positions","toplevel_sexp_or_comment_added","saved_offset","saved_full_sexps","stack$0","is_top_level","comment_added_assuming_cst","sexp_added","inner_comment_depth","is_comment","make_list","add_comment_to_stack_cst","comment","add_sexp_to_stack_cst","rev_comments","hash_semi_pos","closing","stack$1","end_pos","make_loc","add_non_quoted_atom_pos","eps_push_atom","push_quoted_atom","start_line_comment","end_line_comment","eps_eoi_check","create$35","Stack","tr_00","tr_01","tr_02","tr_03","tr_04","tr_05","tr_06","tr_07","tr_08","tr_09","tr_10","tr_11","tr_12","tr_13","tr_14","tr_15","tr_16","tr_17","tr_18","tr_19","tr_20","tr_21","tr_22","tr_23","tr_24","tr_25","tr_26","tr_27","tr_28","tr_29","tr_30","stack$2","tr_31","tr_32","tr_33","tr_34","tr_35","tr_36","tr_37","tr_38","tr_39","tr_40","tr_41","tr_42","tr_43","tr_44","tr_45","tr_46","tr_47","tr_48","tr_49","tr_50","tr_51","tr_52","tr_53","tr_54","tr_55","tr_56","tr_57","tr_58","tr_59","tr_60","tr_61","tr_62","tr_63","tr_64","tr_65","tr_66","tr_67","tr_68","tr_69","tr_70","tr_71","tr_72","tr_73","tr_74","tr_75","tr_76","tr_77","tr_78","tr_eoi_00","tr_eoi_01","tr_eoi_02","tr_eoi_03","tr_eoi_04","tr_eoi_05","tr_eoi_06","tr_eoi_07","transitions","transitions_eoi","old_parser_approx_cont_states","feed_eoi","feed_substring_unsafe","stop","feed_subbytes_unsafe","match$1","make_value","mode$0","make_value$0","make_value$1","mode$1","make_value$2","mode$2","make_value$3","make_value$4","mode$3","make_value$5","mode$4","make_value$6","make_value$7","mode$5","make_value$8","make_value$9","apply_f","apply_f$0","apply_f$1","to_binable","of_binable","bin_shape_t","of_bigstring","to_bigstring","prefix_with_length","bigstring_length","group$3","bin_shape_t$0","bin_size_t","bin_write_t","bin_writer_t","bin_read_t","vint","bin_read_t$0","bin_reader_t","bin_t","compare$38","a_001","hash_fold_t$21","hash$20","t_of_sexp$16","sexp_of_t$29","group$4","bin_shape_t$1","bin_size_t$0","bin_write_t$0","bin_writer_t$0","bin_read_t$1","bin_read_t$2","bin_reader_t$0","bin_t$0","compare$39","a_003","b_004","hash_fold_t$22","hash$21","t_of_sexp$17","sexp_of_t$30","group$5","bin_shape_t$2","bin_size_t$1","bin_write_t$1","bin_writer_t$1","bin_read_t$3","bin_read_t$4","bin_reader_t$1","bin_t$1","compare$40","a_005","b_006","hash_fold_t$23","hash$22","t_of_sexp$18","atom$0","t_of_sexp$19","sexp_of_t$31","group$6","bin_shape_t$3","bin_size_t$2","size_args","bin_write_t$2","bin_writer_t$2","bin_read_t$5","arg_1","bin_read_t$6","bin_reader_t$2","bin_t$2","compare$41","a_007","b_008","right_010","left_009","hash_fold_t$24","hsv$0","hash$23","t_of_sexp$20","t_of_sexp$21","sexp_of_t$32","group$7","bin_shape_t$4","bin_size_t$3","bin_write_t$3","bin_writer_t$3","bin_read_t$7","bin_read_t$8","bin_reader_t$3","bin_t$3","compare$42","a_011","b_012","right_016","left_015","hash_fold_t$25","hash$24","t_of_sexp$22","sexp_of_t$33","group$8","bin_shape_t$5","bin_size_t$4","bin_write_t$4","bin_writer_t$4","bin_read_t$9","bin_read_t$10","bin_reader_t$4","bin_t$4","compare$43","a_017","b_018","hash_fold_t$26","hash$25","t_of_sexp$23","sexp_of_t$34","group$9","bin_shape_t$6","t_of_sexp","size_of_a","write_a","a_029","b_030","a_031","b_032","group$10","bin_shape_t$7","bin_size_t$8","bin_write_t$8","bin_read_t$17","bin_shape_t$14","failwiths","of_alist","of_alist_report_all_dups","of_alist_or_error","of_alist_exn","of_alist_multi","create_mapped","create_with_key","create_with_key_or_error","create_with_key_exn","variant3","generator_033","generator_034","generator_035","size_040","random_041","size_038","random_039","size_036","random_037","tuple2","generator_166","generator_167","size_168","random_169","tuple3","generator_184","generator_185","generator_186","size_187","random_188","of_hash","list_with_length$0","empty$13","nondeterministic_state","random_state_of_seed","make_seed","make_shrink_count","make_config","trials","shrink_attempts","make_test_m","quickcheck_generator","sexp_of","quickcheck_shrinker$0","random_value","gen","random_sequence","test","testable","test_or_error","test_m","test_distinct_values","distinct_values","actual_count","sexp_of_elt","test_can_generate","sexp_of_value","default_sizes","map_t","set_t","create$39","representative","inner_node","inner","descendants","descendants$0","get$8","union$2","create$40","equal$17","union_find_get_check_no_pendin","check_no_pending_iterations","incr_length","incr_pending_iters","decr_pending_iters","with_iteration_2","with_iteration_3","with_iteration_4","create_aux","is_singleton","value$2","unsafe_split_or_splice","unsafe_split_or_splice_after","unsafe_split_or_splice_before","check_two_nodes_no_pending_ite","split_or_splice_before","insert_before","node","dummy_header","unlink","create$41","iter$20","length$19","fold$13","elt$0","iter$21","length$20","to_list$8","sexp_of_t$35","first$0","insert_empty","new_elt","add$11","remove_one","remove$8","move_to_front","first$1","after_elt","move_to_back","last","sexp_of_key","sexp_of_data","invariant","kv","growth_allowed","ensure_can_modify","lookup_exn","find_map","enqueue","back_or_front","enqueue_back","enqueue_front","enqueue_exn","enqueue_back_exn","enqueue_front_exn","lookup_and_move_to_back_exn","lookup_and_move_to_back","lookup_and_move_to_front_exn","lookup_and_move_to_front","dequeue_with_key","maybe_kv","dequeue_with_key_exn","dequeue_back_with_key","dequeue_back_with_key_exn","dequeue_front_with_key","dequeue_front_with_key_exn","dequeue","dequeue_back","dequeue_front","first_with_key","dequeue_exn","dequeue_back_exn","dequeue_front_exn","count$0","sum$0","min_elt$0","max_elt$0","fold_result$0","fold_until$0","dequeue_all","remove_exn","lookup_and_remove","replace_exn","drop","drop_back","drop_front","sexp_of_t$0","of_data","hash_fold_t$0","bin_size_t$13","bin_write_t$13","bin_read_t$26","bin_read_t$27","t_of_sexp$25","sexp_of_t$36","equal$18","compare$45","hash_fold_t$30","bin_size_t$14","bin_write_t$14","bin_read_t$28","bin_read_t$29","typename_of_t$2","hash_fold_t$31","hash$30","comparator$14","bin_size_t$16","bin_write_t$16","bin_read_t$32","bin_read_t$33","bin_size_t$17","bin_write_t$17","bin_read_t$34","bin_read_t$35","bin_size_t$18","bin_write_t$18","bin_read_t$36","bin_read_t$37","of_string$27","bin_size_t$19","bin_write_t$19","bin_read_t$38","bin_read_t$39","bin_shape_t$38","bin_writer_t$19","bin_reader_t$19","bin_t$19","to_q","group$44","bin_shape_array$1","bin_size_array$0","bin_write_array$0","bin_read_array$1","compare_array","len_a","len_b","equal_array","group$45","bool$1","group$46","bin_shape_char$0","func$8","group$47","bin_shape_float$0","group$48","bin_shape_int","func$9","group$49","bin_shape_list$0","bin_size_list$0","bin_write_list$0","bin_read_list$0","compare_list$0","a_037","b_038","a_039","b_040","equal_list$0","a_041","b_042","a_043","b_044","group$50","bin_shape_option$0","bin_size_option$0","bin_write_option$0","bin_read_option$0","compare_option$0","a_049","b_050","a_051","b_052","equal_option$1","a_053","b_054","a_055","b_056","group$51","bin_shape_string","func$10","group$52","bin_shape_unit$0","group$53","bin_shape_sexp_list","group$54","bin_shape_sexp_option","group$55","bin_shape_t$48","sexp_of_t$37","t_of_sexp$26","compare$46","before_first_transition","to_external","of_external","bin_shape_t$50","group$56","bin_shape_t$51","group$57","bin_shape_t$52","group$58","bin_shape_t$53","compare$47","original_filename","zone","digest","bool_of_int","long$0","int32_of_char","input_long_as_int32","sb1","sb2","sb3","sb4","input_long_as_int","input_long_as_int63","input_long_long_as_int63","int63_of_char","long_long","result$0","result$1","result$2","result$3","result$4","result$5","result$6","input_list","lst$0","input_array","input_regime","utc_offset_in_seconds","is_dst","abbrv_index","abbrv","input_tz_file_gen","input_transition","input_leap_second","utc_local_count","std_wall_count","leap_count","transition_count","type_count","transition_times","transition_indices","regimes","raw_abbrvs","abbrvs","next_index","abbrvs$0","indexed_abbrvs","leap_seconds","regime","new_regime","start_time_in_seconds_since_ep","ltt","default_local_time_type","input_leap_second_gen","time_in_seconds_since_epoch","seconds","read_header","magic","input_tz_file_v1","input_tz_file","zonename","version","x_001","make_zone","of_utc_offset","sexp_of_t$39","likely_machine_zones","utc","name$76","reset_transition_cache","get_regime_exn","effective_start_time","index_lower_bound_contains_sec","index_upper_bound_contains_sec","binary_search_index_of_seconds","transition","index_of_seconds_since_epoch","index$1","index$2","index$3","index$4","index_has_prev_clock_shift","index_has_next_clock_shift","index_prev_clock_shift_time_ex","index_prev_clock_shift_amount_","index_abbreviation_exn","validation_failed","create_exn","raw","to_type_id","sexp_of_t$40","sexp_of_type_id","type_id","type_id1","type_id2","name_of_key","uid_of_key","type_id_name","type_id_uid","sexp_of_t$1","mem_by_id","remove_by_id","add_exn","change_exn","change","orig","to_alist","sexp_of_t$2","invariant$0","empty$0","set$0","mem$0","mem_by_id$0","find$0","find_exn$0","add$0","add_exn$0","change$0","change_exn$0","update$0","remove$0","remove_by_id$0","to_alist$0","find$10","empty$14","race_free_create_loop","make","new_x","create$42","uncurry","group$59","bin_shape_t$54","bin_size_t$23","bin_write_t$24","bin_writer_t$25","bin_read_t$48","bin_read_t$49","bin_reader_t$25","bin_t$25","compare$48","hash_fold_t$33","hash$32","size_018","random_019","size_016","random_017","size_014","random_015","size_012","random_013","size_010","random_011","size_008","random_009","size_006","random_007","to_string$26","of_string_internal","of_int_exn$2","of_string$29","compare$49","comparator$15","hash$33","int63_ten","int63_twenty","int63_billion","digits_of_positive_int63","digits_of_int63_max_value","max_int63_with","billions","digit_of_char","write_1_digit_int","return_tens_and_write_ones","tens","ones","write_2_digit_int","write_3_digit_int","write_4_digit_int","write_5_digit_int","write_6_digit_int","write_7_digit_int","write_8_digit_int","write_9_digit_int","read_1_digit_int","read_2_digit_int","max_scale","check_pos$0","check_write","write_2_digit_int$0","write_3_digit_int$0","write_int63","digits$1","int63$1","custom_printf_003","custom_printf_004","digits$0","check_read","read_1_digit_int$0","read_2_digit_int$0","t_of_sexp$29","sexp_of_t$42","compare$50","hash_fold_t$34","of_int_exn$3","to_int$5","to_binable$1","of_binable$1","bin_size_t$24","bin_write_t$25","bin_read_t$50","bin_read_t$51","bin_shape_t$55","bin_writer_t$26","bin_reader_t$26","bin_t$26","num_months","t_of_sexp$30","all_strings","hash$34","bin_shape_t$56","create0","year","month","all_strings$0","days_in_month","bin_read_t$52","bin_read_t$53","bin_reader_t$27","bin_size_t$25","bin_write_t$26","bin_writer_t$27","bin_t$27","unchecked_value","none$0","to_string$27","parse_year4","parse_day","ensure","month_num","month_abrv","year$0","of_string$30","y_field","m_field","d_field","field_sexp$3","field_sexp$0","field_sexp$1","fvalue$0","field_sexp$2","fvalue$1","d_value","m_value","y_value","t_of_sexp$31","sexp_of_t$43","compare$52","sexp_of_t$44","compare$54","unix_epoch","of_year","of_date","c_10_000","c_14_780","c_3_652_425","to_date","days","ddd","ddd$0","y$2","unix_epoch$0","add_days","gen_incl","quickcheck_generator$3","hash$35","suffixes","am_suffixes","pm_suffixes","find_suffix","suffixes$0","suffixes$1","has_colon","decrement_length_if_ends_in_sp","invalid_string","parse$0","am_or_pm","expect_minutes_and_seconds","hr$1","expect_seconds","subsec_nonzero","subsec_len","subsec_pos","sec","sec$1","nonzero","hr$0","sec$0","subsec_len$0","parse_iso8601_extended","verify","of_binable$2","to_binable$2","t_of_sexp$32","to_string$28","x_abs","of_string$31","float_of_string","group$60","bin_shape_t$57","bin_writer_t$28","bin_reader_t$28","bin_t$28","t_of_sexp$33","format_decimal","tenths","units","compare$55","t_of_sexp$34","sign_field","hr_field","min_field","sec_field","ms_field","us_field","ns_field","field_sexp$7","fvalue$2","field_sexp$4","fvalue$3","field_sexp$5","fvalue$4","field_sexp$6","fvalue$5","ns_value","us_value","ms_value","sec_value","min_value","hr_value","sign_value","sexp_of_t$45","v_ns","v_us","v_ms","v_sec","v_min","v_hr","v_sign","bnds$4","bnds$5","robust_comparison_tolerance","symbol$145","symbol$146","symbol$147","symbol$148","symbol$149","symbol$150","robustly_compare","integral","fractional","nanoseconds","nanoseconds$0","seconds$0","ns","microseconds","us","milliseconds","to_span_since_epoch","divide_by_unit_of_time","unit_of_time","scale_by_unit_of_time","sth$3","sth$4","sth$5","sth$6","span","percent","factor","abs_t","suffix_of_unit_of_time","invalid_string$0","state_is_final","invalid_string$1","magnitude$0","suffix_index","unit_of_time_list$0","unit_of_time$0","float_string","magnitude$1","string_of_float_without_traili","sum$3","sum_t","to_float_string","fixup_unit_of_time","sum_t$0","rem_t","fixup_magnitude","to_int_string_and_sum","unit_span","new_sum_t","new_rem_t","next_magnitude","next_sum_t","next_rem_t","new_sum_t$0","symbol$153","magnitude_string","day_string","hour_string","sum_t$1","minute_string","order_of_magnitude_of_first_di","half_ulp","order_of_magnitude_of_final_di","number_of_digits","decimals","align_decimal","float$1","suffix$7","group$61","bin_shape_t$58","bin_writer_t$29","bin_reader_t$29","bin_t$29","hash$36","t_of_sexp$36","group$62","bin_shape_t$59","bin_writer_t$30","bin_reader_t$30","bin_t$30","t_of_sexp$37","symbol$154","symbol$155","symbol$156","symbol$157","symbol$158","symbol$159","robustly_compare$0","to_span_since_start_of_day","is_valid","of_span_since_start_of_day_unc","span_since_start_of_day_is_val","of_span_since_start_of_day","start_of_next_day","start_of_day","add$12","sub$4","next$3","candidate","prev$0","diff$1","approximate_end_of_day","create$44","ns$0","us$0","ms$0","to_parts$0","to_string_gen","drop_ms","drop_us","drop_us$0","dont_print_us","dont_print_ms","dont_print_s","to_string_trimmed","to_sec_string","to_millisec_string","small_diff","ofday1","ofday2","to_string$30","create_from_parsed","subsec","of_string$33","t_of_sexp$38","sexp_of_t$47","of_string_iso8601_extended","gen_incl$1","gen_uniform_incl$0","quickcheck_generator$4","quickcheck_observer$4","quickcheck_shrinker$3","group$63","bin_shape_t$60","bin_writer_t$31","bin_reader_t$31","bin_t$31","hash$37","t_of_sexp$39","group$64","bin_shape_t$61","bin_writer_t$32","bin_reader_t$32","bin_t$32","t_of_sexp$40","epoch","is_earlier","is_later","of_span_in_seconds","span_in_seconds","of_time_in_seconds","time_in_seconds","time$0","index_of_date_and_ofday","relative","index_offset_from_utc_exn","index_prev_clock_shift_time_ex$0","index_next_clock_shift_time_ex","index_prev_clock_shift_amount_$0","index_next_clock_shift_amount_","abbreviation","index_prev_clock_shift","prev_clock_shift","next_clock_shift","date_and_ofday_of_absolute_tim","offset_from_utc","absolute_time_of_date_and_ofda","abs_diff","of_date_ofday","ofday","of_date_ofday_precise","proposed_time","shift_amount","shift_start","shift_backwards","date_cache","reset_date_cache","set_date_cache","rel","effective_day_start","effective_day_until","cache_start_incl","cache_until_excl","to_ofday","to_date_ofday","to_date_ofday_precise","clock_shift_after","clock_shift_before_or_at","amount","ofday$0","ambiguity","amount$0","from_tz","to_tz","start_time","utc_offset$0","utc_epoch","offset_string","utc_offset","is_utc","to_string_abs_parts","offset_string$0","to_string_abs_trimmed","to_string_abs","to_string_iso8601_basic","to_filename_string","of_filename_string","date$0","ofday$1","of_localized_string","occurrence","before_or_after","first_guess_date","first_guess","increment","ensure_colon_in_offset","offset_length","of_string_gen","default_zone","find_zone","ofday$2","tz","ofday$3","date$1","ofday_to_sec","od","tz$0","utc_offset$1","utc_t","zone_name","gen_uniform_incl","of_synthetic_span_since_epoch","to_synthetic_span_since_epoch","to_absolute","of_absolute","absolute","sec_per_day","to_days_from_epoch","days_from_epoch_approx","ofday_of_days_from_epoch","days_from_epoch","days_from_epoch_in_sec","date_of_days_from_epoch","to_date$0","next_multiple_internal","can_equal_after","interval","base_to_after","can_equal_before","float_ns","group$65","bin_shape_t$62","nanosecond$0","microsecond$0","millisecond$0","second$1","minute$0","hour$0","max_value_for_1us_rounding","min_value_for_1us_rounding","of_int_sec$0","of_sec","to_sec$0","to_int_sec","group$66","bin_shape_t$63","bin_writer_t$33","bin_reader_t$33","bin_t$33","compare$56","number_of_digits_to_write","span_part_magnitude","write_char","write_2_chars","char1","char2","write_digits","write_if_non_empty","nanos_of_millisecond","nanos_of_microsecond","int63_60","int63_24","digits_of_d","digits_of_h","digits_of_m","decimal_unit","decimal_unit_integer","decimal_unit_billionths","decimals_of_decimal_unit","sign_len","d_len","h_len","m_len","digits_len","decimals_len","decimal_unit_len","string_length","int63_10","min_mult10_without_underflow","invalid_string$2","add_without_underflow","min_factor_of","min_days_without_underflow","min_hours_without_underflow","min_minutes_without_underflow","min_seconds_without_underflow","min_milliseconds_without_under","min_microseconds_without_under","min_nanoseconds_without_underf","neg_ns","round_ties_before_negating","has_digit","end_of_digits","digit$0","neg_integer","decimal_pos","end_of_decimals","scale$0","min_without_underflow","neg_integer_ns","neg_nanos_of_part","divisor$0","round_at","numerator","denominator","comparator$17","compare$57","float$2","suffix$0","group$67","bin_shape_t$64","bin_writer_t$34","bin_reader_t$34","bin_t$34","compare$58","hash$38","group$68","bin_shape_t$65","bin_writer_t$35","bin_reader_t$35","bin_t$35","group$69","bin_shape_t$66","create_from_parsed$0","of_string$35","t_of_sexp$42","to_string$32","thousand","sexp_of_t$49","group$70","bin_shape_t$67","bin_writer_t$36","bin_reader_t$36","bin_t$36","group$72","bin_shape_t$69","bin_size_t$26","bin_write_t$27","bin_read_t$54","bin_read_t$55","t_of_sexp$43","sexp_of_t$51","of_format","to_format","create$45","set_exn","get_exn","compare$60","t_of_sexp$44","minor_words_field","promoted_words_field","major_words_field","minor_collections_field","major_collections_field","heap_words_field","heap_chunks_field","live_words_field","live_blocks_field","free_words_field","free_blocks_field","largest_free_field","fragments_field","compactions_field","top_heap_words_field","stack_size_field","forced_major_collections_field","field_sexp$17","fvalue$6","field_sexp$8","fvalue$7","field_sexp$9","fvalue$8","field_sexp$10","fvalue$9","field_sexp$11","fvalue$10","field_sexp$12","fvalue$11","field_sexp$13","fvalue$12","field_sexp$14","fvalue$13","field_sexp$15","fvalue$14","field_sexp$16","fvalue$15","forced_major_collections_value","stack_size_value","top_heap_words_value","compactions_value","fragments_value","largest_free_value","free_blocks_value","free_words_value","live_blocks_value","live_words_value","heap_chunks_value","heap_words_value","major_collections_value","minor_collections_value","major_words_value","promoted_words_value","minor_words_value","sexp_of_t$52","v_forced_major_collections","v_stack_size","v_top_heap_words","v_compactions","v_fragments","v_largest_free","v_free_blocks","v_free_words","v_live_blocks","v_live_words","v_heap_chunks","v_heap_words","v_major_collections","v_minor_collections","v_major_words","v_promoted_words","v_minor_words","bnds$6","arg$7","bnds$7","arg$8","bnds$8","arg$9","bnds$9","arg$10","bnds$10","arg$11","bnds$11","arg$12","bnds$12","arg$13","bnds$13","arg$14","bnds$14","arg$15","bnds$15","compare$61","t_of_sexp$45","minor_heap_size_field","major_heap_increment_field","space_overhead_field","verbose_field","max_overhead_field","stack_limit_field","allocation_policy_field","window_size_field","custom_major_ratio_field","custom_minor_ratio_field","custom_minor_max_size_field","custom_minor_max_size_value","custom_minor_ratio_value","custom_major_ratio_value","window_size_value","allocation_policy_value","stack_limit_value","max_overhead_value","verbose_value","space_overhead_value","major_heap_increment_value","minor_heap_size_value","sexp_of_t$53","v_minor_heap_size","v_major_heap_increment","v_space_overhead","v_verbose","v_max_overhead","v_stack_limit","v_allocation_policy","v_custom_minor_max_size","v_custom_minor_ratio","v_custom_major_ratio","v_window_size","return$14","capture","general","hashable$2","cache_size_bound","hashable$1","cache$0","hashable$0","cache","really_call_f","create$46","initial_length","never_shrink","never_shrink$0","initial_length$0","arr_length","length$21","is_empty$7","assert_not_empty","of_array$3","new_arr","actual_front","actual_back","old_arr","break_pos","get$9","i_from_zero","apparent_front","apparent_back","true_i","max_int","add$15","sub$6","div","rem$5","logand","logor","logxor","shift_left$4","shift_right$4","of_int$4","of_int64$1","to_int64$2","zero$5","one$3","lognot$1","succ$5","pred$5","compare$62","equal$20","max$20","min$20","pp$17","max_int$0","add$16","sub$7","mul$0","div$0","rem$6","logand$0","logor$0","logxor$0","shift_left$5","shift_right$5","of_int$5","of_int64$2","to_int64$3","zero$6","one$4","lognot$2","succ$6","pred$6","compare$63","equal$21","max$21","min$21","pp$18","max_int$1","zero$7","one$5","lognot$3","succ$7","pred$7","compare$64","equal$22","max$22","min$22","pp$19","max_int$2","succ$8","pred$8","compare$65","max$23","min$23","pp$20","of_byte_size","to_binable$3","of_binable$3","to_binable$4","of_binable$4","pp_open_xbox","extra_box","open_tag","close_tag","tag_string","fprint_opt_label","lp","fprint_t","fprint_list_body_stick_left","fprint_list","indent$0","cl$0","sep$0","op$0","base_indent","sep_indent","close_extra$0","open_extra$0","close_extra","open_extra","equal$25","create$47","really_extend","slen0","reqlen","create$48","make_room","shrlen","alloc$0","add_sub","add_substring","write_stringlit","add$17","clear$5","contents$0","json_error","utf8_of_code","maxbits","is_object_or_array","init_lexer","lnum","buf$0","buf$1","write_special","ob","finish_string","json_string_of_string","float_needs_period","tuple$1","variant$1","std","ob$0","s$3","hex$0","write_special$0","finish_string$0","write_string","write_null","write_bool","max_digits","write_digits$0","write_int","float_needs_period$0","iter2$4","f_elt","f_sep","write_t","write_std_json","to_string$34","std$0","read_junk","junk","to_basic","hex$1","write_special$1","finish_string$1","write_string$0","write_null$0","write_bool$0","max_digits$0","write_digits$1","write_int$0","float_needs_period$1","iter2$5","f_sep$0","write_t$0","write_std_json$0","to_string$35","hex$2","custom_error","descr","offs","bol","file_line","read_junk$0","long_error","extra_junk","extract_positive_int","extract_negative_int","newline","read_colon","read_object_sep","read_object_end","read_tuple_sep","read_tuple_end","read_array_sep","read_array_end","finish_string$2","ocaml_lex_state$3","ocaml_lex_state$4","high10","low10","read_ident","finish_comment","read_space","read_json$0","ocaml_lex_read_json_rec","field_name","read_json","field_name$0","cons","finish_variant","read_eof","junk$0","from_lexbuf","stream","from_string$0","typerr","js","assoc","member","to_string$36","read_junk$1","junk$1","symbol_bind$5","symbol$169","map_bind","safe_map","func$11","func$12","var_to_bits","gen$0","equal$26","rhs1","rhs0","lhs1","lhs0","of_interval","canonicalize","a4","a3","disjoint_union_exn","of_intervals_exn","is","is$0","invariant$9","gen_from","min_size","go","gen$1","gen_disjoint_pair","y0","y3","num_bits$5","compare$66","equal$27","symbol$170","symbol$171","of_int$6","symbol$172","symbol$173","symbol$174","symbol$175","to_int_exn$1","to_string$37","of_string$38","shift_left$6","shift_right$6","log_and","log_or","two_to_the_i","compare$67","is_integer_string","char_is_digit","of_string_base","of_string_no_underscores","group$74","bin_shape_t$71","bin_size_t$28","bin_write_t$29","bin_read_t$58","bin_read_t$59","arg_1$0","to_binable$5","of_binable$5","t_of_sexp$46","sexp_of_t$54","bin_size_t$29","bin_write_t$30","bin_read_t$60","bin_read_t$61","bin_shape_t$72","bin_writer_t$37","bin_reader_t$37","bin_t$37","to_string_hum$11","range_at_depth","random_bigint_at_depth","prev_depth","range$0","tolerance_factor","depth$0","int$4","bits$3","extra_bytes","num_bytes","hash$40","to_string$39","char_is_hex_digit","of_hex_string_no_underscores","of_string$40","module_name$31","cvar_of_sexp","of_f","sexp_of_cvar","of_index","var$5","bind$1","return$2","unhandled","fail$0","run$2","label_stack","req","hs","handle","req$1","create_single","request","bind$13","return$15","run$3","map2$4","read_var","value_of_fields","var_to_fields","field_vars","fields","map$29","symbol_bind$6","bind$14","return$16","map$30","join$8","ignore_m$0","all$3","all_unit$0","run$4","rc","rc$0","value$3","cases","add_case","case$0","sexp_of_basic","of_basic","unhandled$0","sexp_of_t$55","t_of_sexp$47","to_basic$0","map$31","v3","Field","get_value","override_label","label_opt","basic","equal$28","boolean$0","r1cs","annotation","unit$0","create$49","get$10","emplace_back","length$22","dummy_vector","get$11","T","make$4","num_inputs","next_auxiliary","system","eval_constraints","log_constraint","with_witness","is_running","eval_constraints$0","as_prover","set_as_prover","set_stack","set_handler","constraint_count","direct","assert_equal","assert_all","assert_square","assert_r1cs","assert","with_label","handle_as_prover","exists_handle","request_witness","mk_lazy","create$50","stack_to_string","eval_constraints_ref","run$5","return$17","map$32","bind$15","symbol_bind$7","symbol_map$2","bind$16","return$18","map$33","join$9","ignore_m$1","all$4","all_unit$1","field_vec_id","pack_field_vec","field_vec","auxiliary_input","t0","handlers","return_typ","auxiliary_output_data","output$0","true_output","auxiliary_input_size","run_and_check_exn","get_one","run_and_check","run_and_check_deferred_exn","run_and_check_deferred","run_unchecked","run_and_check_exn$0","run_and_check$0","check_exn","alloc_var","next_input","store_field_elt","primary_input","collect_input_constraints","input_typ","alloc_input","constraint_system_auxiliary","size_in_field_elements","var_of_fields","retval","circuit","r1cs_h","return_typ$0","checked","checked$0","constraint_system","generate_public_input","value_to_fields","store_field_elt$0","cont0","k0","fields$0","generate_auxiliary_input","primary","generate_witness_conv","auxiliary","read_cvar","output$1","inputs","generate_witness","generate_witness$0","generate_witness_conv$0","constraint_system$0","generate_auxiliary_input$0","generate_public_input$0","generate_witness$1","generate_witness_conv$1","constraint_system$1","run_unchecked$0","run_and_check$1","run_and_check_exn$1","check$0","check_exn$0","snarkless","typ","ref","transport","there","back","transport_var","auxes","num_fields","end_pos$0","fieldss","hlist","spec0","spec0$0","typ1","typ2","typ3","tuple4","typ4","tuple5","typ5","tuple6","typ6","of_hlistable","var_to_hlist","var_of_hlist","value_to_hlist","value_of_hlist","field$0","transport$0","transport_var$0","array$0","hlist$0","tuple2$0","tuple3$0","tuple4$0","tuple5$0","tuple6$0","of_hlistable$0","field_to_int","bs","to_field","of_field","typ$0","to_bits","ith_bit","if$0","then","else$0","t_of_sexp$48","non_empty_tree_of_sexp","tree_of_sexp","implied_root","entry_hash","addr0","path0","addr","let_syntax_001","fetch_and_update_req","prev_path","prev","next_entry_hash","new_root","let_syntax_003","prev_entry_hash","modify_req","get_req","update_req","let_syntax_006","let_syntax_007","let_syntax_008","let_syntax_009","pow2","bigint_num_bits","two_to_the","of_bits","mul_pow_2","multiplied","div_pow_2","divided","divided_of_bits","clamp_to_n_bits","bs$0","bit_length","less","less_or_equal","to_var","constant","tick_n","of_pow_2","ceil_div_pow_2","floor_div","m_divides_n","mod_pow_2","x_div_n","n_x_div_n","set_constraint_logger","clear_constraint_logger","constant$0","all$5","assert$0","exists$1","all$6","join$0","map$2","perform","z_inv","x_inv","y_inv","then$0","true$0","false$0","not","if$1","and_for_square_constraint_syst","x_plus_y","both_false","any","all_zero","to_constant","var_of_value","typ$1","typ_unchecked","num_true","any$0","all$0","any$1","all$1","equal$0","of_cvar","is_true","any$2","exactly_one","not$0","any$3","choose_preimage_unchecked","packing_sum","choose_preimage","lc","choose_preimage_flagged","all_unit$2","all$8","fold_map","any$5","all$9","foldi$1","iteri$0","mapi$0","fold_map$0","existsi$0","exists$0","for_alli$0","for_all$1","two","project","pack","unpack","unpack_flagged","lo_bigint","hi_bigint","gen_uniform","parity","square$0","sqrt","quadratic_nonresidue","sqrt_check","is_square","typf","answer","alpha_packed","alpha","not_all_zeros","lte","gt","gte","non_zero","not_equal","of_binary","eval$1","lt_binary","ys$0","ys$1","lt_bitstring_value","field_size_bits","unpack_full","parity$0","unpack_full$0","unpack_full$1","lt_value","chunk_for_equality","chunk_size","t1_b","t1_a","t2_a","equal$2","equal_expect_true","equal$3","correct_answer","if$2","then_aux","else_aux","else$1","res_aux","res_aux$0","checked_to_unchecked","checked_result","test_equal","unchecked","add_constraint","set_primary_input_size","set_auxiliary_input_size","get_public_input_size","get_rows_len","of_bignum_bigint","to_bignum_bigint","two_to_the_i$0","two_to_the_i$1","negate$0","to_bignum_bigint$0","of_bignum_bigint$0","of_f$0","context","scale$1","scale$2","terms$1","constant$1","to_constant_and_terms","neg_one","linear_combination","terms","var_indices","t_of_sexp$0","basic_field","annotation_field","annotation_value","basic_value","v_annotation","v_basic","fm","constraint_logger","run_as_prover","as_prover$0","old_stack","var2","var1","var2$0","var1$0","var3","var2$1","var1$1","system$0","C","with_handler","store_value","log","at_label_boundary","run_as_prover$0","get_value$0","constraint_count$0","direct$0","next_auxiliary$0","with_handler$0","with_label$0","mk_lazy$0","as_prover$1","add_constraint$0","fake_state","log_constraint$0","sys","constraint_count$1","direct$1","next_auxiliary$1","with_handler$1","with_label$1","mk_lazy$1","as_prover$2","add_constraint$1","ignore_m$2","such_that","such_that$0","compute","request$0","provider","custom_printf_002","symbol_map$3","bind$2","return$3","map$3","join$2","ignore_m$3","all_unit$3","as_prover$3","mk_lazy$2","request_witness$0","exists_handle$0","exists$2","handle$0","handle_as_prover$0","next_auxiliary$2","with_label$2","assert_r1cs$0","assert_square$0","assert_all$0","assert_equal$0","direct$2","constraint_count$2","set_constraint_logger$0","clear_constraint_logger$0","symbol_bind$4","symbol_map$4","bind$3","return$4","map$4","ignore_m$4","all_unit$4","as_prover$4","mk_lazy$3","request_witness$1","request$1","exists_handle$1","exists$3","unhandled$1","handle$1","handle_as_prover$1","next_auxiliary$3","with_label$3","assert$1","assert_r1cs$1","assert_square$1","assert_all$1","assert_equal$1","direct$3","constraint_count$3","functor_counter","active_counters","is_active_functor_id","active","dump","in_prover","in_checked_computation","as_stateful","make_checked","size_in_bits","func$0","of_int","print","sub$0","sqrt$0","is_square$0","size_in_bits$0","print$0","random$0","of_string$0","unpack$0","project$0","zero$1","mul$1","square$1","inv$1","is_square$1","sqrt$1","unpack$1","parity$1","choose_preimage_var","equal$5","eval_as_prover","in_prover_block","of_int$2","one$2","sub$1","mul$2","inv$2","square$2","sqrt$2","is_square$2","size_in_bits$1","print$1","random$1","negate$1","symbol$19","symbol$20","unpack$2","project$1","parity$2","run_prover","mark_active","counters","mark_active_deferred","compute$0","lbl","inject_wrapper","finalize_is_running","cached_state","prover_block","this_functor_id","run_checked","shape_tbl","register","path_to_type","ty_decl","shape$0","canonical1","canonical2","create$51","substring","buffer_len","length$23","bytes_for_client_to_commit","offset_in_buffer","apply$5","unsafe_get_char","count_while","lift2","succ1","input1","more1","succ2","input2","more2","symbol$188","symbol$189","more$0","marks","prompt","parser_uncommitted_bytes","parser_committed_bytes","continue$0","demand_input","ensure_suspended","commit","peek_char_fail","satisfy","count_while$0","with_buffer","input_len","count_while1","succ$1","fail$1","string$2","take_while","take_while1","ps","failure_msg","cons$2","many1","steps","max_steps","interpolation","to_int$6","of_int$8","add$18","create$52","N","eq$0","pi","t_plus_n","compare$68","lte_exn","eq_exn","num_commitments_without_degree","to_nat","contr","singleton$0","func$13","length$24","func$14","hhead_off","xss$0","tls","hds","mapn","nth$6","idx$0","idx$1","zip","to_list$9","to_array$4","init$9","map$34","of_list$7","of_list_and_length_exn","of_array_and_length_exn","fold$14","for_all$9","foldi$4","reduce_exn$1","to_yojson","poly_a","of_yojson","for_reader","cnv$0","cnv$1","a_to_b","b_to_a","b_sizer","cnv$2","b_writer","cnv$3","cnv$4","b_reader","cnv$5","sh","to_yojson$0","of_yojson$0","of_list_exn","there$0","back$0","append$5","adds","adds$0","rev$0","split$6","transpose","tails","heads","trim_front","extend_front_exn","dummy","extend_exn","extended","extend_front","bin_shape_t$73","bin_size_t$30","bin_write_t$31","bin_read_t$62","bin_shape_t$74","bin_size_t$31","bin_write_t$32","bin_read_t$63","bin_read_t$64","compare$69","hash_fold_t$37","equal$29","t_of_sexp$49","sexp_of_t$56","compare$70","hash_fold_t$38","equal$30","to_yojson$1","of_yojson$1","t_of_sexp$50","sexp_of_t$57","bin_shape_t$75","bin_size_t$32","bin_write_t$33","bin_read_t$65","compare$71","hash_fold_t$39","equal$31","to_yojson$2","of_yojson$2","t_of_sexp$51","sexp_of_t$58","compare$72","hash_fold_t$40","equal$32","to_yojson$3","of_yojson$3","t_of_sexp$52","sexp_of_t$59","to_list$10","bin_shape_t$76","bin_size_t$33","bin_write_t$34","bin_read_t$66","compare$73","hash_fold_t$41","equal$33","to_yojson$4","of_yojson$4","t_of_sexp$53","sexp_of_t$60","compare$74","hash_fold_t$42","equal$34","to_yojson$5","of_yojson$5","t_of_sexp$54","sexp_of_t$61","bin_shape_t$77","bin_size_t$34","bin_write_t$35","bin_read_t$67","compare$75","hash_fold_t$43","equal$35","t_of_sexp$55","sexp_of_t$62","compare$76","hash_fold_t$44","equal$36","to_yojson$6","of_yojson$6","t_of_sexp$56","sexp_of_t$63","bin_shape_t$78","bin_size_t$35","bin_write_t$36","bin_read_t$68","compare$77","hash_fold_t$45","equal$37","to_yojson$7","of_yojson$7","t_of_sexp$57","sexp_of_t$64","compare$78","equal$38","t_of_sexp$58","sexp_of_t$65","of_list_exn$0","bin_shape_t$79","bin_size_t$36","bin_write_t$37","bin_read_t$69","compare$79","hash_fold_t$46","equal$39","to_yojson$8","of_yojson$8","t_of_sexp$59","sexp_of_t$66","compare$80","hash_fold_t$47","equal$40","to_yojson$9","of_yojson$9","t_of_sexp$60","sexp_of_t$67","bin_shape_t$80","bin_size_t$37","bin_write_t$38","bin_read_t$70","compare$81","hash_fold_t$48","equal$41","to_yojson$10","of_yojson$10","t_of_sexp$61","sexp_of_t$68","to_yojson$11","poly_f","arg0","symbol$190","group$75","bin_shape_t$81","bin_size_t$38","size_of_f","bin_write_t$39","write_f","bin_writer_t$38","bin_writer_f","bin_read_t$71","bin_read_t$72","bin_reader_t$38","bin_reader_f","bin_t$38","bin_f","versioned","t_of_sexp$62","sexp_of_t$69","compare$82","cmp_f","equal$42","hash_fold_t$49","hash_fold_f","a0","to_yojson$12","symbol$191","t_of_sexp$63","sexp_of_t$70","compare$83","a_009","hash_fold_t$50","map$35","map$36","create$53","equal$43","to_yojson$13","symbol$192","group$76","bin_shape_t$82","bin_size_t$39","bin_write_t$40","bin_writer_t$39","bin_read_t$73","bin_read_t$74","bin_reader_t$39","bin_t$39","versioned$0","t_of_sexp$64","sexp_of_t$71","compare$84","b_020","a_019","equal$44","a_021","b_022","b_024","a_023","hash_fold_t$51","to_yojson$14","symbol$193","t_of_sexp$65","sexp_of_t$72","compare$85","a_025","b_026","b_028","a_027","hash_fold_t$52","typ$2","func$15","map$37","create$54","of_field$0","to_field$0","equal$45","maxes","just","nothing","to_option_unsafe","value_exn$1","of_option","symbol$194","map$38","constant_layout_typ","bool_typ","a_typ","dummy_var","bool_typ$0","bool_typ$1","typ$3","hash_fold_array","group$77","bin_shape_t$83","t_of_sexp$66","range_check0_field","range_check1_field","foreign_field_add_field","foreign_field_mul_field","xor_field","rot_field","lookup_field","runtime_tables_field","runtime_tables_value","lookup_value","rot_value","xor_value","foreign_field_mul_value","foreign_field_add_value","range_check1_value","range_check0_value","to_hlist","runtime_tables","rot","foreign_field_add","range_check1","range_check0","of_hlist","of_full","to_full","lookup_pattern_range_check","table_width_at_least_2","table_width_at_least_1","lookups_per_row_4","lookups_per_row_3","to_data","map$39","group$78","bin_shape_t$84","bin_size_t$40","v25","v24","v23","v22","v21","v20","v19","v18","v17","v16","v15","v14","v13","v12","v11","v10","v9","v8","v7","v6","v5","v4","size$2","size$3","size$4","size$5","size$6","size$7","size$8","size$9","size$10","size$11","size$12","size$13","size$14","size$15","size$16","size$17","size$18","size$19","size$20","size$21","size$22","bin_write_t$41","bin_read_t$75","v_w","v_coefficients","v_z","v_s","v_generic_selector","v_poseidon_selector","v_complete_add_selector","v_mul_selector","v_emul_selector","v_endomul_scalar_selector","v_range_check0_selector","v_range_check1_selector","v_foreign_field_add_selector","v_foreign_field_mul_selector","v_xor_selector","v_rot_selector","v_lookup_aggregation","v_lookup_table","v_lookup_sorted","v_runtime_lookup_table","v_runtime_lookup_table_selecto","v_xor_lookup_selector","v_lookup_gate_lookup_selector","v_range_check_lookup_selector","v_foreign_field_mul_lookup_sel","t_of_sexp$67","w_field","coefficients_field","z_field","s_field","generic_selector_field","poseidon_selector_field","complete_add_selector_field","mul_selector_field","emul_selector_field","endomul_scalar_selector_field","range_check0_selector_field","range_check1_selector_field","foreign_field_add_selector_fie","foreign_field_mul_selector_fie","xor_selector_field","rot_selector_field","lookup_aggregation_field","lookup_table_field","lookup_sorted_field","runtime_lookup_table_field","runtime_lookup_table_selector_","xor_lookup_selector_field","lookup_gate_lookup_selector_fi","range_check_lookup_selector_fi","foreign_field_mul_lookup_selec","field_sexp$25","fvalue$16","field_sexp$18","fvalue$17","field_sexp$19","fvalue$18","field_sexp$20","fvalue$19","field_sexp$21","fvalue$20","field_sexp$22","fvalue$21","field_sexp$23","fvalue$22","field_sexp$24","fvalue$23","foreign_field_mul_lookup_selec$0","range_check_lookup_selector_va","lookup_gate_lookup_selector_va","xor_lookup_selector_value","runtime_lookup_table_selector_$0","runtime_lookup_table_value","lookup_sorted_value","lookup_table_value","lookup_aggregation_value","rot_selector_value","xor_selector_value","foreign_field_mul_selector_val","foreign_field_add_selector_val","range_check1_selector_value","range_check0_selector_value","endomul_scalar_selector_value","emul_selector_value","mul_selector_value","complete_add_selector_value","poseidon_selector_value","generic_selector_value","s_value","z_value","coefficients_value","w_value","to_yojson$15","fields$1","fields$2","fields$3","fields$4","fields$5","fields$6","fields$7","fields$8","fields$9","fields$10","x$10","fields$11","x$11","fields$12","x$12","fields$13","x$13","fields$14","fields$15","fields$16","fields$17","fields$18","fields$19","fields$20","fields$21","fields$22","fields$23","fields$24","symbol$195","arg24","arg23","arg22","arg21","arg20","arg19","arg18","arg17","arg16","arg15","arg14","arg13","arg12","arg11","arg10","arg9","arg8","arg7","arg6","arg5","arg4","arg3","xs$13","xs$6","xs$5","xs$4","xs$3","xs$2","xs$12","xs$11","xs$10","xs$9","xs$8","xs$7","xs$19","x$17","xs$18","x$16","xs$17","x$15","xs$16","x$14","xs$15","xs$14","xs$25","x$23","xs$24","x$22","xs$23","x$21","xs$22","x$20","xs$21","x$19","xs$20","x$18","t_of_sexp$68","sexp_of_t$73","arg$16","bnds$16","arg$17","bnds$17","arg$18","bnds$18","arg$19","bnds$19","arg$20","bnds$20","arg$21","bnds$21","arg$22","bnds$22","arg$23","bnds$23","compare$86","a_093","b_094","a_095","b_096","a_097","b_098","a_099","b_100","a_101","b_102","a_103","b_104","a_105","b_106","a_107","b_108","a_111","b_112","a_113","b_114","a_115","b_116","a_117","b_118","a_119","b_120","a_121","b_122","n$19","a_123","b_124","n$20","a_125","b_126","n$21","a_127","b_128","n$22","a_129","b_130","a_131","b_132","hash_fold_t$53","hash_fold_a","hsv$1","hsv$2","hsv$3","hsv$4","hsv$5","hsv$6","hsv$7","hsv$8","hsv$9","hsv$10","hsv$11","hsv$12","hsv$13","hsv$14","hsv$15","hsv$16","hsv$17","hsv$18","hsv$19","hsv$20","hsv$21","hsv$22","hsv$23","equal$46","a_133","b_134","a_135","b_136","a_137","b_138","a_139","b_140","a_141","b_142","a_143","b_144","a_145","b_146","a_147","b_148","a_149","b_150","a_151","b_152","a_153","b_154","a_155","b_156","a_157","b_158","a_159","b_160","a_161","b_162","a_163","b_164","a_165","b_166","a_167","b_168","a_169","b_170","a_171","b_172","to_hlist$0","range_check_lookup_selector","lookup_gate_lookup_selector","xor_lookup_selector","runtime_lookup_table_selector","runtime_lookup_table","lookup_sorted","lookup_aggregation","rot_selector","xor_selector","foreign_field_mul_selector","foreign_field_add_selector","range_check1_selector","range_check0_selector","endomul_scalar_selector","emul_selector","mul_selector","complete_add_selector","poseidon_selector","generic_selector","coefficients","of_hlist$0","validate_feature_flags","enable_if","range_check_lookup","to_hlist$1","of_hlist$1","map$40","to_list$11","always_present","optional_gates","to_absorption_sequence","to_in_circuit","map$41","to_list$12","group$79","to_hlist$2","public_input","of_hlist$2","to_hlist$3","of_hlist$3","p2","p1","group$80","f_multi","to_hlist$4","of_hlist$4","to_hlist$5","of_hlist$5","typ$4","Impl","single","uses_lookups","lookups_per_row_3$0","lookups_per_row_4$0","evals$0","group$81","bin_shape_t$85","fq","bin_size_t$41","size_of_g","size_of_fq","bin_write_t$42","write_g","write_fq","bin_read_t$76","of_g","of_fq","v_lr","v_z_1","v_z_2","v_delta","v_challenge_polynomial_commitm","poly_g","poly_fq","lr_field","z_1_field","z_2_field","delta_field","challenge_polynomial_commitmen","challenge_polynomial_commitmen$0","delta_value","z_2_value","z_1_value","lr_value","cmp_g","cmp_fq","a_261","b_262","a_263","b_264","t_266","t_265","t_268","t_267","hash_fold_g","hash_fold_fq","e0","a_269","b_270","a_271","b_272","t_274","t_273","t_276","t_275","to_hlist$6","z_2","z_1","of_hlist$6","group$82","to_yojson$17","symbol$196","group$83","bin_shape_t$86","bin_size_t$42","bin_write_t$43","bin_read_t$77","compare$88","a_341","b_342","a_343","b_344","equal$48","a_345","b_346","a_347","b_348","to_yojson$18","symbol$197","compare$89","a_349","b_350","a_351","b_352","equal$49","a_353","b_354","a_355","b_356","group$84","bin_shape_t$87","to_hlist$7","sorted_5th_column","of_hlist$7","to_hlist$8","of_hlist$8","group$85","bin_shape_t$88","to_hlist$9","of_hlist$9","to_hlist$10","of_hlist$10","typ$6","commitment_lengths","w_lens","wo","fqv","group$86","t_of_sexp$70","of_g$0","of_fqv","sexp$0","field_sexps$2","messages_field","openings_field","duplicates$2","extra$2","tail$2","sexp$1","field_sexps$0","proof_field","evals_field","ft_eval1_field","duplicates$0","extra$0","tail$0","ft_eval1_value","evals_value","proof_value","sexp$2","field_sexps$1","w_comm_field","z_comm_field","t_comm_field","duplicates$1","extra$1","tail$1","aggreg_field","runtime_field","runtime_value","aggreg_value","t_comm_value","z_comm_value","w_comm_value","openings_value","messages_value","t_of_sexp$71","sorted_5th_column_field","sorted_5th_column_value","group$87","bin_shape_t$89","comm","bin_size_t$43","size_of_comm","bin_write_t$44","write_comm","bin_read_t$78","of_comm","v_sigma_comm","v_coefficients_comm","v_generic_comm","v_psm_comm","v_complete_add_comm","v_mul_comm","v_emul_comm","v_endomul_scalar_comm","t_of_sexp$72","sigma_comm_field","coefficients_comm_field","generic_comm_field","psm_comm_field","complete_add_comm_field","mul_comm_field","emul_comm_field","endomul_scalar_comm_field","endomul_scalar_comm_value","emul_comm_value","mul_comm_value","complete_add_comm_value","psm_comm_value","generic_comm_value","coefficients_comm_value","sigma_comm_value","to_hlist$11","of_hlist$11","typ$7","map$42","f_opt","lookup_selector_ffmul","lookup_selector_range_check","lookup_selector_xor","lookup_selector_lookup","lookup_table_ids","lookup_table_comm","pow$6","combine_split_commitments","scale_and_add","xi","without_degree_bound","with_degree_bound","shifted","unshifted","flat","combine_split_evaluations","mul_and_add","evals0","es","fx","to_list$13","to_vector","of_vector","of_list_and_length_exn$0","of_sexpable","of_binable$6","bin_shape_t$90","bin_size_t$44","bin_write_t$45","bin_read_t$79","of_binable$7","map$43","round_constants","mds","pasta_p_legacy","pasta_p_kimchi","pasta_q_kimchi","id$1","make$5","sponge_state","capacity","sponge_state_of_sexp","sexp_of_sponge_state","copy","rate","absorb","squeeze","debug","operation","sponge","fe","to_blocks","field_elems","num_blocks","create_block","global_pos","sexpifier","first_half_rounds_full","block_cipher","sbox","constant_offset","second_half_rounds_full","slots_per_tuple","arch_sixtyfour$0","max_slot","t3","t4","t5","t13","masked_tuple_id_num_bits","max_array_length","tuple_id_mask","init$10","create$55","header_index","tuple_id","header_index_mask","invariant$10","slot_index","first_slot_index","null$4","is_null","is_used","metadata_index","start_of_tuples_index","max_capacity","array_indices_per_tuple","tuple_num_to_header_index","tuple_num","sexp_of_t$75","sexp_of_ty","v_capacity","v_slots_per_tuple","v_length","v_next_id","v_first_free","v_dummy","unsafe_set_header","pointer_is_valid","pointer","header_index$1","header_index$0","is_full","unsafe_add_to_free_list","metadata","set_metadata","create_array","unsafe_init_range","tuple_num$0","create_with_dummy","slots_per_tuple$0","max_capacity$0","grow","capacity$0","old_capacity","next_id","dummy$0","capacity$1","metadata$1","metadata$0","malloc","first_free","get$12","set$9","bin_writer_a","bin_reader_a","bin_a","group$0","t_of_sexp$73","sexp_of_t$76","validate$3","sexp_of_t$78","max_num_bits","invariant$11","of_int$9","symbol$198","symbol$199","pow2$0","num_bits_internal","create_exn$1","ints","extend_to_max_num_bits","ints$0","level_bits_default","to_sexpable$0","alarm_precision","of_sexpable$0","sexp_of_t$80","v_level_bits","v_alarm_precision","bnd","create$56","level_bits","max_num_bits$0","num_keys","add_clamp_to_max","min_key_in_same_slot","min_key_in_same_slot_mask","value$4","next$5","pool","slot$0","min_key_in_same_slot$0","num_levels","min_allowed_key","max_allowed_key","add_elt","pool$1","pool$0","levels","level_index","level","v_elts","v_max_allowed_key$0","v_min_allowed_key$0","v_key","level_index$0","level_index$1","level$0","v_diff_max_min_allowed_key","v_min_key_in_same_slot_mask","v_keys_per_slot","v_bits_per_slot","v_slots_mask","v_bits","v_index","v_min_allowed_key","v_max_allowed_key","v_slots","interval_num_internal","interval_num_unchecked","interval_num_start_unchecked","interval_num","default$1","sexp_of_t$81","v_how_to_dump","v_dump_if_delayed_by","t_of_sexp$76","sexp_of_t$82","equal$50","x_003","x_004","t_of_sexp$77","sexp_of_t$83","t_of_sexp$78","sexp_of_t$84","timing_wheel_config","thread_pool_cpu_affinity","report_thread_pool_stuck_for","record_backtraces","print_debug_messages_for","min_inter_cycle_timeout","max_num_jobs_per_priority_per_","max_num_threads","max_num_open_file_descrs","max_inter_cycle_timeout","file_descr_watcher","epoll_max_ready_events","dump_core_on_job_delay","detect_invalid_access_from_thr","check_invariants","abort_after_thread_pool_stuck_","timing_wheel_config$0","thread_pool_cpu_affinity$0","report_thread_pool_stuck_for$0","record_backtraces$0","print_debug_messages_for$0","min_inter_cycle_timeout$0","max_num_jobs_per_priority_per_$0","max_num_threads$0","max_num_open_file_descrs$0","max_inter_cycle_timeout$0","file_descr_watcher$0","epoll_max_ready_events$0","dump_core_on_job_delay$0","detect_invalid_access_from_thr$0","check_invariants$0","abort_after_thread_pool_stuck_$0","default_timing_wheel_config_fo","level_bits$1","alarm_precision$0","default_timing_wheel_config","default$2","v_timing_wheel_config","v_report_thread_pool_stuck_for","v_record_backtraces","v_min_inter_cycle_timeout","v_max_num_jobs_per_priority_pe","v_max_num_threads","v_max_num_open_file_descrs","v_max_inter_cycle_timeout","v_file_descr_watcher","v_epoll_max_ready_events","v_dump_core_on_job_delay","v_detect_invalid_access_from_t","v_check_invariants","v_abort_after_thread_pool_stuc","usage","to_sexp","name1","bnd$0","bnd$1","v$2","bnd$2","v$3","bnd$3","v$4","bnd$4","v$5","bnd$5","v$6","bnd$6","v$7","bnd$7","v$8","bnd$8","v$9","bnd$9","v$10","bnd$10","v$11","bnd$11","v$12","bnd$12","v$13","bnd$13","v$14","bnd$14","check_invariants_field","dump_core_on_job_delay_field","epoll_max_ready_events_field","file_descr_watcher_field","max_inter_cycle_timeout_field","max_num_open_file_descrs_field","max_num_threads_field","min_inter_cycle_timeout_field","print_debug_messages_for_field","record_backtraces_field","report_thread_pool_stuck_for_f","thread_pool_cpu_affinity_field","timing_wheel_config_field","alarm_precision_field","level_bits_field","capacity_field","num_key_bits","alarm_precision_value","sexp$3","sexp$4","dump_if_delayed_by_field","how_to_dump_field","how_to_dump_value","dump_if_delayed_by_value","timing_wheel_config_value","thread_pool_cpu_affinity_value","report_thread_pool_stuck_for_v","record_backtraces_value","print_debug_messages_for_value","min_inter_cycle_timeout_value","max_num_threads_value","max_num_open_file_descrs_value","max_inter_cycle_timeout_value","file_descr_watcher_value","epoll_max_ready_events_value","dump_core_on_job_delay_value","check_invariants_value","print_debug_messages_for$1","debug$0","symbol$200","check_invariants$1","max_num_jobs_per_priority_per_$1","record_backtraces$1","normal","sexp_of_one","v_is_detached","v_has_seen_error","v_id","v_here","v_name","loop$2","has_seen_error","is_detached","ac$0","sexp_of_t$85","create_with_parent","dummy_e","dummy_f","dummy_a","create_array$0","create$57","none$3","is_none$1","is_some$1","create$59","enqueue$0","execution_context","priority","new_capacity","old_jobs","old_front","new_jobs","create$60","time_source","max_level_min_allowed_key","bits_per_slot","keys_per_slot","diff_max_min_allowed_key","levels$0","tw","prev_level_max_allowed_key","num_levels$0","min_allowed_key_before","desired_min_allowed_key","level_min_allowed_key","level_min_allowed_key$0","slots$1","max_allowed_key$0","alarm","job_pool","from","to","at","current_execution_context","set_prev","set_next","create$61","create2","run1","execution_context1","run2","execution_context2","enqueue$1","scheduler","schedule_jobs","add$19","squash","indir","execution_context$0","bind_result","bind_rhs","bind_result$0","ivar","ivar$0","last1","last2","handler1","execution_context2$0","run2$0","handler1$0","fill_if_empty","to_binable$6","of_binable$8","map$44","bind$18","map$45","bind$19","map$46","both$0","symbol_map$5","choices","unregisters","choices$0","choices$1","handler$0","handler$1","monitor$0","backtrace_history","monitor$1","name$1","backtrace$0","backtrace$1","traces","backtrace$2","list_if_not_empty","return$20","bind$20","map$47","return$21","apply$6","map$48","return$22","equal$51","combine$3","sexp_of_t$87","v_pipe_id","v_values_read","values_sent_downstream","values_sent_downstream_and_flu","when_sent_downstream","fill_with_eof","sexp_of_t$88","v_ready","v_fill_when_num_values_read","fill$2","sexp_of_pipe","of_phantom","v_info","v_buffer","v_size_budget","v_pushback","v_num_values_read","v_read_closed","v_closed","v_blocked_reads","v_blocked_flushes","v_consumers","v_upstream_flusheds","v_consumer","v_wants","is_closed","length$25","is_empty$9","sexp_of_phantom","id_ref","update_pushback","close","close$0","values_were_read","consumer","consumer$0","flush_result","consume_one","consume","ensure_consumer_matches","start_read","gen_read_now","values_available","downstream_flushed","ready","expect","got","create$63","length$26","sub$8","copy$4","init$11","be32_to_cpu","le32_to_cpu","be64_to_cpu","le64_to_cpu","benat_to_cpu","cpu_to_benat","blit_from_bigstring","cpu_to_be32","cpu_to_be64","be32_to_cpu$0","le32_to_cpu$0","be64_to_cpu$0","le64_to_cpu$0","benat_to_cpu$0","cpu_to_benat$0","imin","size_of_long","xor_into","invalid_arg$0","ror64","dup","ctx","param_to_bytes","iv","max_outlen","increment_counter","inc","sigma","compress","a_idx","b_idx","c_idx","d_idx","feed$0","in_off","in_len","fill","unsafe_feed_bytes","unsafe_feed_bigstring","with_outlen_and_key","outlen","param_bytes","with_outlen_and_bytes_key","with_outlen_and_bigstring_key","unsafe_get$0","ror32","dup$0","iv$0","max_outlen$0","increment_counter$0","sigma$0","compress$0","feed$1","unsafe_feed_bytes$0","unsafe_feed_bigstring$0","with_outlen_and_key$0","with_outlen_and_bytes_key$0","with_outlen_and_bigstring_key$0","unsafe_get$1","dup$1","init$12","f3","md5_do_chunk","feed$2","to_fill","unsafe_feed_bytes$1","unsafe_feed_bigstring$1","unsafe_get$2","padlen","rol32","dup$2","init$13","g$0","jj","fff","ggg","hhh","iii","jjj","rmd160_do_chunk","eee","ccc","bbb","aaa","ee","dd","cc","bb","aa","feed$3","unsafe_feed_bytes$2","unsafe_feed_bigstring$2","unsafe_get$3","rol32$0","dup$3","init$14","f1$0","f4$0","f3$0","k4","sha1_do_chunk","feed$4","unsafe_feed_bytes$3","unsafe_feed_bigstring$3","unsafe_get$4","ror32$0","dup$4","init$15","sha256_do_chunk","feed$5","unsafe_feed_bytes$4","unsafe_feed_bigstring$4","unsafe_get$5","init$16","unsafe_get$6","dup$5","unsafe_feed_bytes$5","unsafe_feed_bigstring$5","rol64","dup$6","init$17","mdlen","rsize","keccaft_rndc","keccaft_rotc","keccakf_piln","sha3_keccakf","rotc","bc$0","masks","feed$6","get_uint8","unsafe_feed_bytes$6","unsafe_feed_bigstring$6","unsafe_get$7","ror64$0","dup$7","init$18","sha512_do_chunk","feed$7","unsafe_feed_bytes$7","unsafe_feed_bigstring$7","unsafe_get$8","init$19","unsafe_get$9","dup$8","unsafe_feed_bytes$8","unsafe_feed_bigstring$8","init$20","init$21","init$22","init$23","dup$9","init$24","whirlpool_do_chunk","i$3","wp_op","get_k","m0","feed$8","unsafe_feed_bytes$9","unsafe_feed_bigstring$9","unsafe_get$10","digest_size","block_size","len$3","unsafe_feed_string","unsafe_get","chr$0","chr1","chr2","have_first","ln","bl","feed_bytes","feed_string","feed_bigstring","feedi_bytes","feed","feedi_string","feedi_bigstring","digest_bytes","digest_string","digest_bigstring","digesti_bytes","digesti_string","digesti_bigstring","digestv_bytes","digestv_string","digestv_bigstring","bytes_opad","bytes_ipad","norm_bytes","bigstring_opad","bigstring_ipad","norm_bigstring","hmaci_bytes","outer","hmaci_string","ctx$0","hmaci_bigstring","hmac_bytes","hmac_string","hmac_bigstring","hmacv_bytes","bufs","hmacv_string","hmacv_bigstring","maci_bytes","maci_string","maci_bigstring","mac_bytes","mac_string","mac_bigstring","macv_bytes","macv_string","macv_bigstring","digest_size$0","module_of","b2b","b2s","read$0","ds","of_char_exn","to_int$7","decode","encode","byte$0","to_hex$0","charify","hexified","to_u4","actual","not_implemented","to_binable$7","of_binable$9","empty$16","group$88","bin_shape_t$91","path$0","log$1","internal","empty_quartiles","allocation_times","now$0","get_lifetime_ms","mean","indices","lifetimes","q1","q2","q3_offset","q3","q4","compute_statistics","run_test","time_offsets","expected_quartiles","message$0","comparator$0","comparator$1","message$3","comparator$3","table$0","attach_finalizer","object_id","info_opt","data_opt","statistics","json","block_on_async_exn","to_deferred","promise","map$49","bind$21","return$23","return$24","map$50","get$13","t_of_sexp$79","accs_field","bits_field","ss_field","base_field","n_prev_field","n_next_field","n_next_value","n_prev_value","base_value","ss_value","bits_value","accs_value","map$51","n_next","n_prev","ss","accs","group$89","bin_shape_t$92","bin_size_t$45","bin_write_t$46","bin_read_t$80","v_inner","to_yojson$19","of_yojson$12","t_of_sexp$80","inner_field","inner_value","sexp_of_t$89","compare$90","equal$52","hash_fold_t$55","typ$8","map$52","y_squared","t_004","t_003","t_005","t_010","t_012","t_011","hash_fold_t$1","to_backend","of_backend","to_affine_or_infinity","to_affine_exn","of_affine","find_y","point_near_x","g_vec","or_infinity_to_backend","or_infinity_of_backend","with_degree_bound_to_backend","commitment","without_degree_bound_to_backen","of_backend_with_degree_bound","shifted$0","of_backend_without_degree_boun","tuple15_to_vec","w14","w13","w12","w11","w10","w9","w8","w7","w6","w5","w4","w3","w2","w1","w0","tuple15_of_vec","group$90","v_challenges","v_commitment","challenges_field","commitment_field","commitment_value","challenges_value","a_013","b_014","to_latest","hash_fold_array$0","poly_fqv","poly_g$0","arg1$2","arg0$2","arg2$1","arg1$1","arg0$1","arg2$0","arg1$0","arg0$0","size_of_fqv","v2$1","v3$0","write_fqv","v_w_comm","v_z_comm","v_t_comm","v_lookup","v_aggreg","v_runtime","v_messages","v_proof","v_evals","v_ft_eval1","v_openings","version$0","cmp_g$1","cmp_g$0","a_455","b_456","n$32","n$29","a_391","b_392","a_393","b_394","n$30","a_395","b_396","n$31","a_397","b_398","a_399","b_400","a_401","b_402","a_403","b_404","a_363","b_364","a_365","b_366","cmp_fqv","cmp_fq$0","a_281","b_282","a_457","b_458","n$27","n$23","a_247","b_248","t_250","t_249","t_252","t_251","n$24","n$25","n$26","a_283","b_284","t_286","t_285","t_288","t_287","n$28","a_015","b_016","a_033","b_034","a_035","b_036","a_045","b_046","a_047","b_048","t_of_sexp$2","arg$31","bnds$29","bnds$37","arg$24","bnds$30","arg$25","bnds$24","arg$26","bnds$25","arg$27","bnds$26","arg$28","bnds$27","arg$29","bnds$28","arg$30","bnds$31","arg$32","bnds$38","bnds$32","arg$33","bnds$33","arg$34","bnds$34","arg$35","bnds$35","arg$36","bnds$36","arg$37","bnds$39","hsv$33","hash_fold_fqv","hsv$29","hsv$30","hsv$31","hsv$32","hsv$24","hsv$25","hsv$26","hsv$27","hsv$28","a_465","b_466","a_407","b_408","a_409","b_410","a_411","b_412","a_413","b_414","a_415","b_416","a_417","b_418","a_419","b_420","a_369","b_370","a_371","b_372","a_293","b_294","a_467","b_468","a_255","b_256","t_258","t_257","t_260","t_259","a_295","b_296","t_298","t_297","t_300","t_299","a_057","b_058","a_059","b_060","a_061","b_062","a_063","b_064","a_065","b_066","a_067","b_068","a_069","b_070","a_071","b_072","a_073","b_074","a_075","b_076","a_077","b_078","a_079","b_080","a_081","b_082","a_083","b_084","a_085","b_086","a_087","b_088","a_089","b_090","a_091","b_092","map_creator","openings","to_latest$0","arg3$0","a_475","b_476","a_423","b_424","a_425","b_426","a_427","b_428","a_429","b_430","a_431","b_432","a_433","b_434","a_435","b_436","a_375","b_376","a_377","b_378","a_379","b_380","a_305","b_306","a_477","b_478","a_307","b_308","t_310","t_309","t_312","t_311","t_of_sexp$3","sexp_of_t$3","v_sorted_5th_column","a_485","b_486","a_439","b_440","a_441","b_442","a_443","b_444","a_445","b_446","a_447","b_448","a_449","b_450","a_451","b_452","a_383","b_384","a_385","b_386","a_387","b_388","a_317","b_318","a_487","b_488","a_319","b_320","t_322","t_321","t_324","t_323","map_creator$0","create$1","compare$3","hash_fold_t$2","map_creator$1","sexp_of_t$4","fq_array_to_vec","vec","opening_proof_of_backend_exn","gpair","g2","g1","eval_of_backend","evals_to_tuple","zeta_omega","zeta","gs","of_backend_with_public_evals","eval_to_backend","vec_to_array","V","evals_of_tuple","chal_polys","pcwo","lr$0","challenges","to_backend$0","to_backend_with_public_evals","to_backend_with_public_evals$0","pk","create_async","batch_verify","logger","vks_and_v","batch_verify$0","prev_challenge","pi$0","create_with_public_evals","scalar_challenge","beta","digest_before_evaluations","p_eval_1","p_eval_2","opening_prechallenges","columns","permutation_cols","map$53","s3","yr","xr","n_acc","yp","xp","yt","xt","map$54","x7","x6","x5","a8","b0","n8","n0","bin_shape_t_tagged","read_version","all_tag_versions","bin_read_all_tagged_to_latest","saved_pos","pos_ref$0","domain_generator","over","t_of_sexp$81","compare$91","compare$92","cmp_row","to_rust_wire","t_of_sexp$82","of_v","field_sexps$12","l_field","r_field","o_field","c_field","duplicates$12","extra$12","tail$7","field_sexp$60","field_sexp$41","field_sexp$42","fvalue$36","field_sexp$43","fvalue$37","field_sexp$44","fvalue$38","field_sexp$45","fvalue$39","field_sexp$46","fvalue$40","c_value","o_value","r_value","l_value","field_sexps$4","state_field","duplicates$4","extra$4","state_value","field_sexps$11","p1_field","p2_field","p3_field","inf_field","same_x_field","slope_field","inf_z_field","x21_inv_field","duplicates$11","extra$11","tail$6","field_sexp$59","field_sexp$32","field_sexp$33","fvalue$28","field_sexp$34","fvalue$29","field_sexp$35","fvalue$30","field_sexp$36","fvalue$31","field_sexp$37","fvalue$32","field_sexp$38","fvalue$33","field_sexp$39","fvalue$34","field_sexp$40","fvalue$35","x21_inv_value","inf_z_value","slope_value","same_x_value","inf_value","p3_value","p2_value","p1_value","field_sexps$8","state_field$0","duplicates$8","extra$8","tail$3","state_value$0","field_sexps$9","state_field$1","xs_field","ys_field","n_acc_field","duplicates$9","extra$9","tail$4","field_sexp$58","field_sexp$26","field_sexp$27","field_sexp$28","fvalue$24","field_sexp$29","fvalue$25","xt_field","yt_field","xp_field","yp_field","xr_field","yr_field","s1_field","s3_field","b1_field","b2_field","b3_field","b4_field","b4_value","b3_value","b2_value","b1_value","s3_value","s1_value","yr_value","xr_value","n_acc_value","yp_value","xp_value","yt_value","xt_value","field_sexp$30","fvalue$26","ys_value","xs_value","state_value$1","field_sexps$10","state_field$2","duplicates$10","extra$10","tail$5","field_sexp$31","fvalue$27","n0_field","n8_field","a0_field","b0_field","a8_field","b8_field","x0_field","x1_field","x2_field","x3_field","x4_field","x5_field","x6_field","x7_field","x7_value","x6_value","x5_value","x4_value","x3_value","x2_value","x1_value","x0_value","b8_value","a8_value","b0_value","a0_value","n8_value","n0_value","state_value$2","field_sexps$5","w0_field","w1_field","w2_field","w3_field","w4_field","w5_field","w6_field","duplicates$5","extra$5","field_sexp$57","w6_value","w5_value","w4_value","w3_value","w2_value","w1_value","w0_value","field_sexps$3","v0_field","v0p0_field$0","v0p1_field$0","v0p2_field","v0p3_field","v0p4_field","v0p5_field","v0c0_field","v0c1_field","v0c2_field","v0c3_field","v0c4_field","v0c5_field","v0c6_field","v0c7_field","compact_field","duplicates$3","extra$3","iter$2","compact_value","v0c7_value","v0c6_value","v0c5_value","v0c4_value","v0c3_value","v0c2_value","v0c1_value","v0c0_value","v0p5_value","v0p4_value","v0p3_value","v0p2_value","v0p1_value$0","v0p0_value$0","v0_value","v2_field","v12_field","v2c0_field","v2p0_field","v2p1_field","v2p2_field","v2p3_field","v2c1_field","v2c2_field","v2c3_field","v2c4_field","v2c5_field","v2c6_field","v2c7_field","v2c8_field","v2c9_field","v2c10_field","v2c11_field","v0p0_field","v0p1_field","v1p0_field","v1p1_field","v2c12_field","v2c13_field","v2c14_field","v2c15_field","v2c16_field","v2c17_field","v2c18_field","v2c19_field","v2c19_value","v2c18_value","v2c17_value","v2c16_value","v2c15_value","v2c14_value","v2c13_value","v2c12_value","v1p1_value","v1p0_value","v0p1_value","v0p0_value","v2c11_value","v2c10_value","v2c9_value","v2c8_value","v2c7_value","v2c6_value","v2c5_value","v2c4_value","v2c3_value","v2c2_value","v2c1_value","v2p3_value","v2p2_value","v2p1_value","v2p0_value","v2c0_value","v12_value","v2_value","in1_field","in2_field","out_field","in1_0_field","in1_1_field","in1_2_field","in1_3_field","in2_0_field","in2_1_field","in2_2_field","in2_3_field","out_0_field","out_1_field","out_2_field","out_3_field","out_3_value","out_2_value","out_1_value","out_0_value","in2_3_value","in2_2_value","in2_1_value","in2_0_value","in1_3_value","in1_2_value","in1_1_value","in1_0_value","out_value","in2_value","in1_value","field_sexps$7","left_input_lo_field","left_input_mi_field","left_input_hi_field","right_input_lo_field","right_input_mi_field","right_input_hi_field","field_overflow_field","carry_field","foreign_field_modulus0_field","foreign_field_modulus1_field","foreign_field_modulus2_field$0","duplicates$7","extra$7","field_sexp$56","foreign_field_modulus2_value$0","foreign_field_modulus1_value","foreign_field_modulus0_value","carry_value","field_overflow_value","right_input_hi_value","right_input_mi_value","right_input_lo_value","left_input_hi_value","left_input_mi_value","left_input_lo_value","field_sexps$6","left_input0_field","left_input1_field","left_input2_field","right_input0_field","right_input1_field","right_input2_field","remainder01_field","remainder2_field","quotient0_field","quotient1_field","quotient2_field","quotient_hi_bound_field","product1_lo_field","product1_hi_0_field","product1_hi_1_field","carry0_field","carry1_0_field","carry1_12_field","carry1_24_field","carry1_36_field","carry1_48_field","carry1_60_field","carry1_72_field","carry1_84_field","carry1_86_field","carry1_88_field","carry1_90_field","foreign_field_modulus2_field","neg_foreign_field_modulus0_fie","neg_foreign_field_modulus1_fie","neg_foreign_field_modulus2_fie","duplicates$6","extra$6","iter$3","neg_foreign_field_modulus2_val","neg_foreign_field_modulus1_val","neg_foreign_field_modulus0_val","foreign_field_modulus2_value","carry1_90_value","carry1_88_value","carry1_86_value","carry1_84_value","carry1_72_value","carry1_60_value","carry1_48_value","carry1_36_value","carry1_24_value","carry1_12_value","carry1_0_value","carry0_value","product1_hi_1_value","product1_hi_0_value","product1_lo_value","quotient_hi_bound_value","quotient2_value","quotient1_value","quotient0_value","remainder2_value","remainder01_value","right_input2_value","right_input1_value","right_input0_value","left_input2_value","left_input1_value","left_input0_value","word_field","rotated_field","excess_field","bound_limb0_field","bound_limb1_field","bound_limb2_field","bound_limb3_field","bound_crumb0_field","bound_crumb1_field","bound_crumb2_field","bound_crumb3_field","bound_crumb4_field","bound_crumb5_field","bound_crumb6_field","bound_crumb7_field","two_to_rot_field","two_to_rot_value","bound_crumb7_value","bound_crumb6_value","bound_crumb5_value","bound_crumb4_value","bound_crumb3_value","bound_crumb2_value","bound_crumb1_value","bound_crumb0_value","bound_limb3_value","bound_limb2_value","bound_limb1_value","bound_limb0_value","excess_value","rotated_value","word_value","field_sexps$14","id_field$0","data_field","duplicates$14","extra$14","tail$9","field_sexp$55","field_sexp$50","field_sexp$51","fvalue$43","field_sexp$52","fvalue$44","data_value","id_value$0","field_sexps$13","id_field","first_column_field","duplicates$13","extra$13","tail$8","field_sexp$54","field_sexp$47","field_sexp$48","fvalue$41","field_sexp$49","fvalue$42","first_column_value","id_value","kind_field","values_field","coeffs_field","field_sexp$53","coeffs_value","values_value","kind_value","sexp_of_t$90","v_c","v_m","v_o","v_r","v_l","v_state","v_x21_inv","v_inf_z","v_slope","v_same_x","v_inf","v_p3","v_p2","v_p1","v_state$0","v_n_next","v_n_prev","v_base","v_ss","v_accs","v_n_acc","v_ys","v_xs","v_state$1","v_b4","v_b3","v_b2","v_b1","v_s3","v_s1","v_yr","v_xr","v_yp","v_xp","v_yt","v_xt","v_state$2","v_x7","v_x6","v_x5","v_x4","v_x3","v_x2","v_x1","v_x0","v_b8","v_a8","v_b0","v_a0","v_n8","v_n0","v_w6","v_w5","v_w4","v_w3","v_w2","v_w1","v_w0","v_compact","v_v0c7","v_v0c6","v_v0c5","v_v0c4","v_v0c3","v_v0c2","v_v0c1","v_v0c0","v_v0p5","v_v0p4","v_v0p3","v_v0p2","v_v0p1","v_v0p0","v_v0","bnds$40","arg$38","bnds$41","arg$39","bnds$42","arg$40","bnds$43","arg$41","bnds$44","v_v2c19","v_v2c18","v_v2c17","v_v2c16","v_v2c15","v_v2c14","v_v2c13","v_v2c12","v_v1p1","v_v1p0","v_v0p1$0","v_v0p0$0","v_v2c11","v_v2c10","v_v2c9","v_v2c8","v_v2c7","v_v2c6","v_v2c5","v_v2c4","v_v2c3","v_v2c2","v_v2c1","v_v2p3","v_v2p2","v_v2p1","v_v2p0","v_v2c0","v_v12","v_v2","arg$42","bnds$45","arg$43","bnds$46","arg$44","bnds$47","arg$45","bnds$48","arg$46","bnds$49","arg$47","bnds$50","arg$48","bnds$51","arg$49","bnds$52","arg$50","bnds$53","arg$51","bnds$54","arg$52","bnds$55","arg$53","bnds$56","arg$54","bnds$57","arg$55","bnds$58","arg$56","bnds$59","arg$57","bnds$60","arg$58","bnds$61","arg$59","bnds$62","arg$60","bnds$63","arg$61","bnds$64","arg$62","bnds$65","arg$63","bnds$66","arg$64","bnds$67","arg$65","bnds$68","arg$66","bnds$69","arg$67","bnds$70","arg$68","bnds$71","arg$69","bnds$72","arg$70","bnds$73","arg$71","bnds$74","v_out_3","v_out_2","v_out_1","v_out_0","v_in2_3","v_in2_2","v_in2_1","v_in2_0","v_in1_3","v_in1_2","v_in1_1","v_in1_0","v_out","v_in2","v_in1","arg$72","bnds$75","arg$73","bnds$76","arg$74","bnds$77","arg$75","bnds$78","arg$76","bnds$79","arg$77","bnds$80","arg$78","bnds$81","arg$79","bnds$82","arg$80","bnds$83","arg$81","bnds$84","arg$82","bnds$85","arg$83","bnds$86","arg$84","bnds$87","arg$85","bnds$88","arg$86","bnds$89","v_foreign_field_modulus2","v_foreign_field_modulus1","v_foreign_field_modulus0","v_carry","v_field_overflow","v_right_input_hi","v_right_input_mi","v_right_input_lo","v_left_input_hi","v_left_input_mi","v_left_input_lo","arg$87","bnds$90","arg$88","bnds$91","arg$89","bnds$92","arg$90","bnds$93","arg$91","bnds$94","arg$92","bnds$95","arg$93","bnds$96","arg$94","bnds$97","arg$95","bnds$98","arg$96","bnds$99","arg$97","bnds$100","arg$98","bnds$101","v_neg_foreign_field_modulus2","v_neg_foreign_field_modulus1","v_neg_foreign_field_modulus0","v_foreign_field_modulus2$0","v_carry1_90","v_carry1_88","v_carry1_86","v_carry1_84","v_carry1_72","v_carry1_60","v_carry1_48","v_carry1_36","v_carry1_24","v_carry1_12","v_carry1_0","v_carry0","v_product1_hi_1","v_product1_hi_0","v_product1_lo","v_quotient_hi_bound","v_quotient2","v_quotient1","v_quotient0","v_remainder2","v_remainder01","v_right_input2","v_right_input1","v_right_input0","v_left_input2","v_left_input1","v_left_input0","arg$99","bnds$102","arg$100","bnds$103","arg$101","bnds$104","arg$102","bnds$105","arg$103","bnds$106","arg$104","bnds$107","arg$105","bnds$108","arg$106","bnds$109","arg$107","bnds$110","arg$108","bnds$111","arg$109","bnds$112","arg$110","bnds$113","arg$111","bnds$114","arg$112","bnds$115","arg$113","bnds$116","arg$114","bnds$117","arg$115","bnds$118","arg$116","bnds$119","arg$117","bnds$120","arg$118","bnds$121","arg$119","bnds$122","arg$120","bnds$123","arg$121","bnds$124","arg$122","bnds$125","arg$123","bnds$126","arg$124","bnds$127","arg$125","bnds$128","arg$126","bnds$129","arg$127","bnds$130","arg$128","bnds$131","arg$129","bnds$132","v_two_to_rot","v_bound_crumb7","v_bound_crumb6","v_bound_crumb5","v_bound_crumb4","v_bound_crumb3","v_bound_crumb2","v_bound_crumb1","v_bound_crumb0","v_bound_limb3","v_bound_limb2","v_bound_limb1","v_bound_limb0","v_excess","v_rotated","v_word","arg$130","bnds$133","arg$131","bnds$134","arg$132","bnds$135","arg$133","bnds$136","arg$134","bnds$137","arg$135","bnds$138","arg$136","bnds$139","arg$137","bnds$140","arg$138","bnds$141","arg$139","bnds$142","arg$140","bnds$143","arg$141","bnds$144","arg$142","bnds$145","arg$143","bnds$146","arg$144","bnds$147","arg$145","bnds$148","v_data","bnds$149","arg$146","bnds$150","arg$147","bnds$151","v_first_column","v_id$0","arg$148","bnds$152","arg$149","bnds$153","v_coeffs","v_values","v_kind","arg$150","bnds$154","arg$151","bnds$155","arg$152","bnds$156","map$55","fp","x21_inv","inf_z","slope","same_x","inf","p3","compact","v0c7","v0c6","v0c5","v0c4","v0c3","v0c2","v0c1","v0c0","v0p5","v0p4","v0p3","v0p2","v0p1","v0p0","v2c19","v2c18","v2c17","v2c16","v2c15","v2c14","v2c13","v2c12","v1p1","v1p0","v0p1$0","v0p0$0","v2c11","v2c10","v2c9","v2c8","v2c7","v2c6","v2c5","v2c4","v2c3","v2c2","v2c1","v2p3","v2p2","v2p1","v2p0","v2c0","out_3","out_2","out_1","out_0","in2_3","in2_2","in2_1","in2_0","in1_3","in1_2","in1_1","in1_0","in2","in1","foreign_field_modulus2","foreign_field_modulus1","foreign_field_modulus0","field_overflow","right_input_hi","right_input_mi","right_input_lo","left_input_hi","left_input_mi","left_input_lo","neg_foreign_field_modulus2","neg_foreign_field_modulus1","neg_foreign_field_modulus0","foreign_field_modulus2$0","carry1_90","carry1_88","carry1_86","carry1_84","carry1_72","carry1_60","carry1_48","carry1_36","carry1_24","carry1_12","carry1_0","carry0","product1_hi_1","product1_hi_0","product1_lo","quotient_hi_bound","quotient2","quotient1","quotient0","remainder2","remainder01","right_input2","right_input1","right_input0","left_input2","left_input1","left_input0","two_to_rot","bound_crumb7","bound_crumb6","bound_crumb5","bound_crumb4","bound_crumb3","bound_crumb2","bound_crumb1","bound_crumb0","bound_limb3","bound_limb2","bound_limb1","bound_limb0","excess","rotated","word","first_column","coeffs","eval_one","vo","co","vr","cr","vl","vl$0","vr$0","vo$0","custom_printf_009","custom_printf_010","custom_printf_011","custom_printf_012","custom_printf_013","custom_printf_014","custom_printf_015","custom_printf_016","custom_printf_017","custom_printf_018","compare$93","hash_fold_t$56","a0$0","hash$41","t_of_sexp$83","sexp_of_t$91","get_concatenated_fixed_lookup_","flts","flt","get_concatenated_runtime_looku","rt_cfgs","rt_cfg","finalize_fixed_lookup_tables","fixed_lt_rev","finalize_runtime_lookup_tables","rt_cfgs_rev","t_028","t_027","t_029","compute_witness","external_values","internal_values","num_rows","custom_printf_039","i_after_input","cols","row_idx","col_idx","map_runtime_tables","cfgs","rt_idx","compute_value","vidx","vv","id_int32","union_find","create_internal","get_auxiliary_input_size","get_primary_input_size","get_prev_challenges","num_pub_inputs","set_prev_challenges","num_prev_challenges","next_row","get_concatenated_fixed_lookup_$0","get_concatenated_runtime_looku$0","add_row","vars_for_perm","finalize_and_get_gates","runtime_tables_cfg$0","gates_rev","fixed_lookup_tables","runtime_tables_cfg","rust_gates","pub_selectors","pub_input_gate_specs_rev","public_var","row_field","col_field","col_value","row_value","v_row","equivalence_classes","pos_map","update_gate_with_permutation_i","public_gates","public_gates$0","absolute_row","gates$0","relative_row","add_gates","wired_to","wired_to$0","md5_digest","num_constraints","to_json","add_generic_constraint","coeffs2","o2","coeffs$0","constr","red","terms$0","terms_list","lx","go$0","lx$0","rs","s1x1_plus_s2x2","reduce_to_v","xo","xo$0","x3$0","x3$1","x3$2","ratio","ratio$0","x2$1","red_pr","l_s","r_s","o$0","coeff","add_round_state","s5","s4","reduce_curve_point","x1$1","x2$2","x3$3","curr_row","add_endoscale_round","vars$1","add_endoscale_scalar_round","red_w0","red_w1","red_w2","red_w3","red_w4","red_w5","red_w6","vars$2","lookup1","lookup2","lookup3","vars$3","coeff$0","v2$2","vars_curr","vars_next","vars$4","vars_curr$0","vars_next$0","vars_curr$1","values$0","urs_info","degree","set_urs_info","load","urs$0","store","urs$1","runtime_table_cfgs","prev_challenges$0","prev_challenges$1","array_to_vector","vk_commitments","full_vk_commitments","to_list$14","of_list$8","group3","pt$0","tuples","string_bits","test_bit","to_bytes$0","bit","of_bytes$0","hash$42","hash_fold_t$57","to_yojson$20","of_yojson$13","length_in_bits","order","length_in_bytes","remaining_bytes","extended_euclidean","inv_no_mod","euler","while$0","t_minus_1_over_2","b2m","of_bigint","to_bigint","make_gen","t_of_bignum_bigint","make_gen_full","bignum_bigint_of_t","fold_bits","group$91","bin_shape_t$93","group$92","bin_shape_t$94","bin_size_t$46","bin_write_t$47","bin_read_t$81","to_yojson$21","of_yojson$14","compare$94","equal$53","of_bytes$1","to_bytes$1","of_decimal_string","to_string$42","test_bit$0","div$1","compare$95","num_limbs","bytes_per_limb","to_hex","to_hex_string","of_hex_string","of_numeral","double$1","one$8","symbol$205","double$2","one$9","to_affine_exn$0","of_affine$0","symbol$206","make$6","unshifted$0","make$7","sponge_params","sponge_params_constant","to_field$1","of_field$1","with_lagrange","vks","create_aux$0","prev_chals","prev_comms","computed_witness","create$64","to_binable$8","of_binable$10","create$65","of_data$0","to_field$2","of_field$2","with_lagrange$0","create_aux$1","create_async$0","create$66","to_binable$9","of_binable$11","create$67","create_with_public_evals$0","digest_size_in_bits","digest_size_in_bytes","char_generator","of_hex$0","digest_bigstring$0","digest_string$0","to_raw_string$0","of_raw_string$0","hash$2","bits_to_string","finished","string_to_bits","pct","pot","mct","mot","loc$2","last$0","last$1","map$60","raise_errorf","fixity_of_string","first_is","last_is","needs_parens","needs_spaces","protect_ident","view_expr","exp$0","is_simple_construct","under_semi","ctxt","list$4","fu","option$0","paren","print_longident$0","longident_loc","delim","mutable_flag","virtual_flag","rec_flag","nonrec_flag","direction_flag","private_flag","constant_string","tyvar","tyvar_loc","f$11","module_type$5","mt2","mt1","module_type$2","module_type1","mt2$0","with_constraint","td","ls$0","type_declaration$2","core_type","li2","li$0","td$0","ls$1","li$1","ls$2","li2$0","li$2","module_type1$0","attributes","signature_item$1","me","module_expr$0","extension","e$6","sugar_expr","label_x_expression_param","simple_expr","s$4","expression2","eo$0","eo$1","l$6","e$7","s$5","l$7","string_x_expression","e$8","e$9","ct","e$10","case_list","label_exp","cd","extension_constructor$4","e$5","ands","let$0","binding_op$1","eo","expression_under_ifthenelse","class_structure$2","expression2$0","simple_expr$0","longident_x_expression","e3","df","expression","pattern$0","ct$0","cto1","lid","pattern$6","pattern1$0","pattern_list_helper","pat2","pat1","simple_pattern","pattern1","simple_pattern$0","po","closed","longident_x_pattern","with_paren","simple_name","pc_rhs","pc_guard","pc_lhs","constructor_declaration","attrs","core_type1","record_declaration","priv","manifest","constructor_declaration$0","pcd","intro","variants","constraints","ct2","ct1","lbls","type_record_field","pld","type_param","structure_item$0","item_attributes","vd","value_description$2","type_def_list","te","type_extension$0","exception_declaration","me$1","me$0","arg_opt","mt","decls","pmb","expr","attrs$0","md","class_constraint","class_type$3","class_declaration","cl$2","cl$1","class_expr$2","class_params_def","class_type_declaration_list","floating_attribute","item_extension","binding$0","binding","pp_print_pexp_function","tyvars_str","tyvars","args_tyvars","gadt_pattern","gadt_exp","tyvars$0","e_ct","e_tyvars","pt_ct","pt_tyvars","check_variable","var_names","core_type$0","lst$1","loop_object_field","lst$2","longident","core_type$1","lbl_lst_option","row_field_list","loop_row_field","core_type$2","string_lst","lst$3","longident$0","prf_desc","pof_desc","ety","tyvars$1","ct$1","payload","me2","me1","mt$0","alias","pms","pmd","s$6","s$7","class_description","exported","type_decl","ce","ce$0","ce$1","so","ovf","ovf$0","ovf$1","class_type_declaration","vf","mf","vf$0","pf","type_with_label","print_indexop","path_prefix","print_index","rem_args","print_path","other_args","i3","i2$0","i1$0","i1$1","left$0","txt$0","core_field_type","field_var","first_is_inherit","type_variant_helper","ctl","cstrs","pp$26","pp$27","migration_error","missing_feature","copy_loc","f0","copy_structure","copy_structure_item","copy_toplevel_phrase","pdir_loc","pdir_arg","pdir_name","copy_directive_argument","pdira_loc","pdira_desc","x0$2","copy_attributes","copy_attribute","copy_constant","copy_rec_flag","copy_arg_label","copy_constructor_arguments","copy_core_type","copy_label_declaration","copy_extension_constructor","pext_attributes","pext_loc","pext_kind","pext_name","copy_Longident_t","copy_extension","copy_payload","copy_signature","copy_signature_item","copy_functor_parameter","copy_module_type","copy_override_flag","copy_open_infos","popen_attributes","popen_loc","popen_override","popen_expr","copy_open_declaration","copy_module_expr","copy_closed_flag","ptyp_attributes","ptyp_loc_stack","ptyp_loc","ptyp_desc","x0$3","copy_object_field","x1$2","x0$4","x1$3","x0$5","x1$4","x0$6","copy_label","copy_row_field","x1$5","x0$7","x0$8","x1$6","x0$10","x0$9","copy_pattern","ppat_attributes","ppat_loc_stack","ppat_loc","ppat_desc","x0$11","x0$12","x0$13","x0$14","x0$15","copy_class_structure","pcstr_fields","pcstr_self","copy_class_field","pmty_attributes","pmty_loc","pmty_desc","copy_with_constraint","pmod_attributes","pmod_loc","pmod_desc","copy_expression","copy_binding_op","pbop_loc","pbop_exp","pbop_pat","pbop_op","copy_expression_desc","copy_value_binding","copy_case","x1$7","x1$8","x1$9","x1$10","x1$11","x0$16","x2$3","x1$12","x0$17","x1$13","x0$18","x2$4","x1$14","x0$19","x1$15","x0$20","x0$21","x1$16","x0$22","x0$23","x2$5","x1$17","x0$24","x1$18","x0$25","x0$26","x0$27","x1$19","x0$28","x0$29","x1$20","x0$30","x0$31","x1$21","x0$32","x0$33","x0$34","pexp_attributes","pexp_loc_stack","pexp_loc","pexp_desc","pvb_loc","pvb_attributes","pvb_expr","pvb_pat","prf_attributes","prf_loc","pof_attributes","pof_loc","attr_loc","attr_payload","attr_name","copy_value_description","pval_loc","pval_attributes","pval_prim","pval_type","pval_name","copy_variance","copy_injectivity","copy_private_flag","copy_type_extension","ptyext_attributes","ptyext_loc","ptyext_private","ptyext_constructors","ptyext_params","ptyext_path","copy_type_exception","ptyexn_attributes","ptyexn_loc","ptyexn_constructor","copy_module_type_declaration","pmtd_loc","pmtd_attributes","pmtd_type","pmtd_name","copy_include_infos","pincl_attributes","pincl_loc","pincl_mod","copy_module_binding","pmb_loc","pmb_attributes","pmb_expr","pmb_name","pstr_loc","pstr_desc","copy_type_declaration","copy_class_declaration","copy_class_type_declaration","copy_virtual_flag","copy_class_infos","pci_attributes","pci_loc","pci_expr","pci_name","pci_params","pci_virt","copy_class_expr","copy_open_description","copy_class_type","pcty_attributes","pcty_loc","pcty_desc","pcsig_fields","pcsig_self","copy_class_type_field","pcl_attributes","pcl_loc","pcl_desc","copy_mutable_flag","copy_class_field_kind","pcf_attributes","pcf_loc","pcf_desc","ptype_loc","ptype_attributes","ptype_manifest","ptype_private","ptype_kind","ptype_cstrs","ptype_params","ptype_name","copy_constructor_declaration","copy_module_declaration","pmd_loc","pmd_attributes","pmd_type","pmd_name","psig_loc","psig_desc","pms_loc","pms_attributes","pms_manifest","pms_name","copy_class_description","pctf_attributes","pctf_loc","pctf_desc","pcd_attributes","pcd_loc","pcd_res","pcd_args","pcd_vars","pcd_name","pld_attributes","pld_loc","pld_type","pld_mutable","pld_name","copy_loc$0","copy_structure$0","copy_structure_item$0","copy_toplevel_phrase$0","copy_directive_argument$0","copy_attributes$0","copy_attribute$0","copy_constant$0","copy_rec_flag$0","copy_arg_label$0","copy_constructor_arguments$0","copy_core_type$0","copy_label_declaration$0","copy_extension_constructor$0","copy_Longident_t$0","copy_extension$0","copy_payload$0","copy_signature$0","copy_signature_item$0","copy_functor_parameter$0","copy_module_type$0","copy_override_flag$0","copy_open_infos$0","copy_open_declaration$0","copy_module_expr$0","copy_closed_flag$0","copy_object_field$0","copy_label$0","copy_row_field$0","copy_pattern$0","copy_class_structure$0","copy_class_field$0","copy_with_constraint$0","copy_expression$0","copy_binding_op$0","copy_expression_desc$0","copy_value_binding$0","copy_case$0","copy_value_description$0","copy_variance$0","copy_injectivity$0","copy_private_flag$0","copy_type_extension$0","copy_type_exception$0","copy_module_type_declaration$0","copy_include_infos$0","copy_module_binding$0","copy_type_declaration$0","copy_class_declaration$0","copy_class_type_declaration$0","copy_virtual_flag$0","copy_class_infos$0","copy_class_expr$0","copy_open_description$0","copy_class_type$0","copy_class_type_field$0","copy_mutable_flag$0","copy_class_field_kind$0","copy_constructor_declaration$0","copy_module_declaration$0","copy_class_description$0","migration_error$0","copy_loc$1","copy_structure$1","copy_structure_item$1","copy_toplevel_phrase$1","copy_directive_argument$1","copy_attributes$1","copy_attribute$1","copy_location_stack","copy_location","copy_constant$1","copy_rec_flag$1","copy_arg_label$1","copy_constructor_arguments$1","copy_core_type$1","copy_label_declaration$1","copy_extension_constructor$1","copy_Longident_t$1","copy_extension$1","copy_payload$1","copy_signature$1","copy_signature_item$1","copy_functor_parameter$1","copy_module_type$1","copy_override_flag$1","copy_open_infos$1","copy_open_declaration$1","copy_module_expr$1","copy_closed_flag$1","copy_object_field$1","copy_label$1","copy_row_field$1","copy_pattern$1","copy_class_structure$1","copy_class_field$1","copy_with_constraint$1","copy_expression$1","copy_binding_op$1","copy_expression_desc$1","copy_value_binding$1","copy_case$1","copy_value_description$1","copy_variance$1","copy_injectivity$1","copy_private_flag$1","copy_type_extension$1","copy_type_exception$1","copy_module_type_declaration$1","copy_include_infos$1","copy_module_binding$1","copy_type_declaration$1","copy_class_declaration$1","copy_class_type_declaration$1","copy_virtual_flag$1","copy_class_infos$1","copy_class_expr$1","copy_open_description$1","copy_class_type$1","copy_class_type_field$1","copy_mutable_flag$1","copy_class_field_kind$1","copy_constructor_declaration$1","copy_module_declaration$1","copy_class_description$1","copy_loc$2","copy_structure$2","copy_structure_item$2","copy_toplevel_phrase$2","copy_directive_argument$2","copy_attributes$2","copy_attribute$2","copy_location_stack$0","copy_location$0","copy_constant$2","copy_rec_flag$2","copy_arg_label$2","copy_constructor_arguments$2","copy_core_type$2","copy_label_declaration$2","copy_extension_constructor$2","copy_Longident_t$2","copy_extension$2","copy_payload$2","copy_signature$2","copy_signature_item$2","copy_functor_parameter$2","copy_module_type$2","copy_override_flag$2","copy_open_infos$2","copy_open_declaration$2","copy_module_expr$2","copy_closed_flag$2","copy_object_field$2","copy_label$2","copy_row_field$2","copy_pattern$2","copy_class_structure$2","copy_class_field$2","copy_with_constraint$2","copy_expression$2","copy_binding_op$2","copy_expression_desc$2","copy_value_binding$2","copy_case$2","copy_value_description$2","copy_variance$2","copy_injectivity$2","copy_private_flag$2","copy_type_extension$2","copy_type_exception$2","copy_module_type_declaration$2","copy_include_infos$2","copy_module_binding$2","copy_type_declaration$2","copy_class_declaration$2","copy_class_type_declaration$2","copy_virtual_flag$2","copy_class_infos$2","copy_class_expr$2","copy_open_description$2","copy_class_type$2","copy_class_type_field$2","copy_mutable_flag$2","copy_class_field_kind$2","copy_constructor_declaration$2","copy_module_declaration$2","copy_class_description$2","copy_loc$3","copy_structure$3","copy_structure_item$3","copy_toplevel_phrase$3","copy_directive_argument$3","copy_attributes$3","copy_attribute$3","copy_constant$3","copy_rec_flag$3","copy_arg_label$3","copy_constructor_arguments$3","copy_core_type$3","copy_label_declaration$3","copy_extension_constructor$3","copy_Longident_t$3","copy_extension$3","copy_payload$3","copy_signature$3","copy_signature_item$3","copy_functor_parameter$3","copy_module_type$3","copy_override_flag$3","copy_open_infos$3","copy_open_declaration$3","copy_module_expr$3","copy_closed_flag$3","copy_object_field$3","copy_label$3","copy_row_field$3","copy_pattern$3","copy_class_structure$3","copy_class_field$3","copy_with_constraint$3","copy_expression$3","copy_binding_op$3","copy_expression_desc$3","copy_value_binding$3","copy_case$3","copy_value_description$3","copy_variance$3","copy_private_flag$3","copy_type_extension$3","copy_type_exception$3","copy_module_type_declaration$3","copy_include_infos$3","copy_module_binding$3","copy_type_declaration$3","copy_class_declaration$3","copy_class_type_declaration$3","copy_virtual_flag$3","copy_class_infos$3","copy_class_expr$3","copy_open_description$3","copy_class_type$3","copy_class_type_field$3","copy_mutable_flag$3","copy_class_field_kind$3","copy_constructor_declaration$3","copy_module_declaration$3","copy_class_description$3","copy_loc$4","copy_structure$4","copy_structure_item$4","copy_toplevel_phrase$4","copy_directive_argument$4","copy_attributes$4","copy_attribute$4","copy_constant$4","copy_rec_flag$4","copy_arg_label$4","copy_constructor_arguments$4","copy_core_type$4","copy_label_declaration$4","copy_extension_constructor$4","copy_Longident_t$4","copy_extension$4","copy_payload$4","copy_signature$4","copy_signature_item$4","copy_functor_parameter$4","copy_module_type$4","copy_override_flag$4","copy_open_infos$4","copy_open_declaration$4","copy_module_expr$4","copy_closed_flag$4","copy_object_field$4","copy_label$4","copy_row_field$4","copy_pattern$4","copy_class_structure$4","copy_class_field$4","copy_with_constraint$4","copy_expression$4","copy_binding_op$4","copy_expression_desc$4","copy_value_binding$4","copy_case$4","copy_value_description$4","copy_variance$4","copy_private_flag$4","copy_type_extension$4","copy_type_exception$4","copy_module_type_declaration$4","copy_include_infos$4","copy_module_binding$4","copy_type_declaration$4","copy_class_declaration$4","copy_class_type_declaration$4","copy_virtual_flag$4","copy_class_infos$4","copy_class_expr$4","copy_open_description$4","copy_class_type$4","copy_class_type_field$4","copy_mutable_flag$4","copy_class_field_kind$4","copy_constructor_declaration$4","copy_module_declaration$4","copy_class_description$4","copy_loc$5","copy_structure$5","copy_structure_item$5","copy_toplevel_phrase$5","copy_directive_argument$5","copy_attributes$5","copy_attribute$5","copy_location_stack$1","copy_location$1","copy_constant$5","copy_rec_flag$5","copy_arg_label$5","copy_constructor_arguments$5","copy_core_type$5","copy_label_declaration$5","copy_extension_constructor$5","copy_Longident_t$5","copy_extension$5","copy_payload$5","copy_signature$5","copy_signature_item$5","copy_functor_parameter$5","copy_module_type$5","copy_override_flag$5","copy_open_infos$5","copy_open_declaration$5","copy_module_expr$5","copy_closed_flag$5","copy_object_field$5","copy_label$5","copy_row_field$5","copy_pattern$5","copy_class_structure$5","copy_class_field$5","copy_with_constraint$5","copy_expression$5","copy_binding_op$5","copy_expression_desc$5","copy_value_binding$5","copy_case$5","copy_value_description$5","copy_variance$5","copy_private_flag$5","copy_type_extension$5","copy_type_exception$5","copy_module_type_declaration$5","copy_include_infos$5","copy_module_binding$5","copy_type_declaration$5","copy_class_declaration$5","copy_class_type_declaration$5","copy_virtual_flag$5","copy_class_infos$5","copy_class_expr$5","copy_open_description$5","copy_class_type$5","copy_class_type_field$5","copy_mutable_flag$5","copy_class_field_kind$5","copy_constructor_declaration$5","copy_module_declaration$5","copy_class_description$5","copy_loc$6","copy_structure$6","copy_structure_item$6","copy_toplevel_phrase$6","copy_directive_argument$6","copy_attributes$6","copy_attribute$6","copy_location_stack$2","copy_location$2","copy_constant$6","copy_rec_flag$6","copy_arg_label$6","copy_constructor_arguments$6","copy_core_type$6","copy_label_declaration$6","copy_extension_constructor$6","copy_Longident_t$6","copy_extension$6","copy_payload$6","copy_signature$6","copy_signature_item$6","copy_functor_parameter$6","copy_module_type$6","copy_override_flag$6","copy_open_infos$6","copy_open_declaration$6","copy_module_expr$6","copy_closed_flag$6","copy_object_field$6","copy_label$6","copy_row_field$6","copy_pattern$6","copy_class_structure$6","copy_class_field$6","copy_with_constraint$6","copy_expression$6","copy_binding_op$6","copy_expression_desc$6","copy_value_binding$6","copy_case$6","copy_value_description$6","copy_variance$6","copy_private_flag$6","copy_type_extension$6","copy_type_exception$6","copy_module_type_declaration$6","copy_include_infos$6","copy_module_binding$6","copy_type_declaration$6","copy_class_declaration$6","copy_class_type_declaration$6","copy_virtual_flag$6","copy_class_infos$6","copy_class_expr$6","copy_open_description$6","copy_class_type$6","copy_class_type_field$6","copy_mutable_flag$6","copy_class_field_kind$6","copy_constructor_declaration$6","copy_module_declaration$6","copy_class_description$6","migration_error$1","map_option","copy_loc$7","copy_structure$7","copy_structure_item$7","copy_toplevel_phrase$7","copy_directive_argument$7","copy_attributes$7","copy_attribute$7","copy_location_stack$3","copy_location$3","copy_constant$7","copy_rec_flag$7","copy_arg_label$7","copy_constructor_arguments$7","copy_core_type$7","copy_label_declaration$7","copy_extension_constructor$7","copy_Longident_t$7","copy_extension$7","copy_payload$7","copy_signature$7","copy_signature_item$7","copy_functor_parameter$7","copy_module_type$7","copy_override_flag$7","copy_open_infos$7","copy_open_declaration$7","copy_module_expr$7","copy_closed_flag$7","copy_object_field$7","copy_label$7","copy_row_field$7","copy_pattern$7","copy_class_structure$7","copy_class_field$7","copy_with_constraint$7","copy_expression$7","copy_binding_op$7","copy_expression_desc$7","copy_value_binding$7","copy_case$7","copy_value_description$7","copy_variance$7","copy_private_flag$7","copy_type_extension$7","copy_type_exception$7","copy_module_type_declaration$7","copy_include_infos$7","copy_module_binding$7","copy_type_declaration$7","copy_class_declaration$7","copy_class_type_declaration$7","copy_virtual_flag$7","copy_class_infos$7","copy_class_expr$7","copy_open_description$7","copy_class_type$7","copy_class_type_field$7","copy_mutable_flag$7","copy_class_field_kind$7","copy_constructor_declaration$7","copy_module_declaration$7","copy_class_description$7","map_option$0","copy_loc$8","copy_structure$8","copy_structure_item$8","copy_toplevel_phrase$8","copy_directive_argument$8","copy_attributes$8","copy_attribute$8","copy_constant$8","copy_rec_flag$8","copy_arg_label$8","copy_constructor_arguments$8","copy_core_type$8","copy_label_declaration$8","copy_extension_constructor$8","copy_Longident_t$8","copy_extension$8","copy_payload$8","copy_signature$8","copy_signature_item$8","copy_override_flag$8","copy_open_infos$8","copy_open_declaration$8","copy_module_expr$8","copy_closed_flag$8","copy_location$4","copy_object_field$8","copy_label$8","copy_row_field$8","copy_pattern$8","copy_class_structure$8","copy_class_field$8","copy_cases","copy_case$8","copy_module_type$8","copy_with_constraint$8","copy_expression$8","copy_binding_op$8","copy_expression_desc$8","copy_value_binding$8","copy_value_description$8","copy_variance$8","copy_private_flag$8","copy_type_extension$8","copy_type_exception$8","copy_module_type_declaration$8","copy_include_infos$8","copy_module_binding$8","copy_type_declaration$8","copy_class_declaration$8","copy_class_type_declaration$8","copy_virtual_flag$8","copy_class_infos$8","copy_class_expr$8","copy_open_description$8","copy_class_type$8","copy_class_type_field$8","copy_mutable_flag$8","copy_class_field_kind$8","copy_constructor_declaration$8","copy_module_declaration$8","copy_class_description$8","copy_loc$9","copy_structure$9","copy_structure_item$9","copy_toplevel_phrase$9","copy_directive_argument$9","copy_attributes$9","copy_attribute$9","copy_constant$9","copy_rec_flag$9","copy_arg_label$9","copy_constructor_arguments$9","copy_core_type$9","copy_label_declaration$9","copy_extension_constructor$9","copy_Longident_t$9","copy_extension$9","copy_payload$9","copy_signature$9","copy_signature_item$9","copy_override_flag$9","copy_open_infos$9","copy_open_declaration$9","copy_module_expr$9","copy_closed_flag$9","copy_location$5","copy_object_field$9","copy_label$9","copy_row_field$9","copy_pattern$9","copy_class_structure$9","copy_class_field$9","copy_cases$0","copy_case$9","copy_module_type$9","copy_with_constraint$9","copy_expression$9","copy_binding_op$9","copy_expression_desc$9","copy_value_binding$9","copy_value_description$9","copy_variance$9","copy_private_flag$9","copy_type_extension$9","copy_type_exception$9","copy_module_type_declaration$9","copy_include_infos$9","copy_module_binding$9","copy_type_declaration$9","copy_class_declaration$9","copy_class_type_declaration$9","copy_virtual_flag$9","copy_class_infos$9","copy_class_expr$9","copy_open_description$9","copy_class_type$9","copy_class_type_field$9","copy_mutable_flag$9","copy_class_field_kind$9","copy_constructor_declaration$9","copy_module_declaration$9","copy_class_description$9","copy_loc$10","copy_structure$10","copy_structure_item$10","copy_toplevel_phrase$10","copy_directive_argument$10","copy_attributes$10","copy_attribute$10","copy_constant$10","copy_rec_flag$10","copy_arg_label$10","copy_constructor_arguments$10","copy_core_type$10","copy_label_declaration$10","copy_extension_constructor$10","copy_Longident_t$10","copy_extension$10","copy_payload$10","copy_signature$10","copy_signature_item$10","copy_override_flag$10","copy_open_infos$10","copy_open_declaration$10","copy_module_expr$10","copy_closed_flag$10","copy_location$6","copy_object_field$10","copy_label$10","copy_row_field$10","copy_pattern$10","copy_class_structure$10","copy_class_field$10","copy_cases$1","copy_case$10","copy_module_type$10","copy_with_constraint$10","copy_expression$10","copy_binding_op$10","copy_expression_desc$10","copy_value_binding$10","copy_value_description$10","copy_variance$10","copy_private_flag$10","copy_type_extension$10","copy_type_exception$10","copy_module_type_declaration$10","copy_include_infos$10","copy_module_binding$10","copy_type_declaration$10","copy_class_declaration$10","copy_class_type_declaration$10","copy_virtual_flag$10","copy_class_infos$10","copy_class_expr$10","copy_open_description$10","copy_class_type$10","copy_class_type_field$10","copy_mutable_flag$10","copy_class_field_kind$10","copy_constructor_declaration$10","copy_module_declaration$10","copy_class_description$10","migration_error$2","copy_bool","copy_option","copy_structure$11","copy_structure_item$11","copy_toplevel_phrase$11","copy_attributes$11","copy_attribute$11","copy_loc$11","copy_constant$11","copy_rec_flag$11","copy_arg_label$11","copy_constructor_arguments$11","copy_core_type$11","copy_label_declaration$11","copy_extension_constructor$11","copy_longident","copy_override_flag$11","copy_extension$11","copy_payload$11","copy_signature$11","copy_signature_item$11","copy_closed_flag$11","copy_object_field$11","copy_label$11","copy_row_field$11","copy_pattern$11","copy_class_structure$11","copy_class_field$11","copy_module_type$11","copy_with_constraint$11","copy_module_expr$11","copy_expression$11","copy_expression_desc$11","copy_value_binding$11","copy_case$11","copy_value_description$11","copy_variance$11","copy_private_flag$11","copy_type_extension$11","copy_module_type_declaration$11","copy_include_infos$11","copy_module_binding$11","copy_type_declaration$11","copy_class_declaration$11","copy_class_type_declaration$11","copy_virtual_flag$11","copy_class_infos$11","copy_class_expr$11","copy_class_type$11","copy_class_type_field$11","copy_mutable_flag$11","copy_class_field_kind$11","copy_constructor_declaration$11","copy_module_declaration$11","x0_loc","copy_class_description$11","copy_toplevel_phrase$12","copy_directive_argument$11","copy_expression$12","copy_expression_desc$12","copy_direction_flag","copy_case$12","copy_value_binding$12","copy_pattern$12","copy_pattern_desc","copy_core_type$12","copy_core_type_desc","copy_package_type","copy_row_field$12","copy_object_field$12","copy_attributes$12","copy_attribute$12","copy_payload$12","copy_structure$12","copy_structure_item$12","copy_structure_item_desc","copy_include_declaration","copy_class_declaration$12","copy_class_expr$12","copy_class_expr_desc","copy_class_structure$12","copy_class_field$12","copy_class_field_desc","copy_class_field_kind$12","copy_module_binding$12","copy_module_expr$12","copy_module_expr_desc","copy_module_type$12","copy_module_type_desc","copy_with_constraint$12","copy_signature$12","copy_signature_item$12","copy_signature_item_desc","copy_class_type_declaration$12","copy_class_description$12","copy_class_type$12","copy_class_type_desc","copy_class_signature","copy_class_type_field$12","copy_class_type_field_desc","copy_extension$12","copy_class_infos$12","copy_virtual_flag$12","copy_include_description","copy_include_infos$12","copy_open_description$11","copy_override_flag$12","copy_module_type_declaration$12","copy_module_declaration$12","copy_type_extension$12","copy_extension_constructor$12","copy_extension_constructor_kin","copy_type_declaration$12","copy_private_flag$12","copy_type_kind","copy_constructor_declaration$12","copy_constructor_arguments$12","copy_label_declaration$12","copy_mutable_flag$12","copy_variance$12","copy_value_description$12","copy_arg_label$12","copy_closed_flag$12","copy_label$12","copy_rec_flag$12","copy_constant$12","copy_option$0","copy_longident$0","copy_loc$12","copy_location$7","copy_bool$0","wrap$2","x2$6","atat","popen_lid","copy_attributes$13","copy_attribute$13","copy_loc$13","copy_option$1","copy_constant$13","copy_rec_flag$13","copy_arg_label$13","copy_constructor_arguments$13","copy_core_type$13","copy_label_declaration$13","copy_extension_constructor$13","copy_longident$1","copy_override_flag$13","copy_extension$13","copy_payload$13","copy_signature$13","copy_signature_item$13","copy_structure$13","copy_structure_item$13","copy_closed_flag$13","copy_object_field$13","copy_label$13","copy_row_field$13","copy_pattern$13","copy_class_structure$13","copy_class_field$13","copy_module_type$13","copy_with_constraint$13","copy_module_expr$13","copy_expression$13","copy_expression_desc$13","copy_value_binding$13","copy_case$13","copy_bool$1","copy_value_description$13","copy_variance$13","copy_private_flag$13","copy_type_extension$13","copy_module_type_declaration$13","copy_open_description$12","copy_include_infos$13","copy_module_binding$13","copy_type_declaration$13","copy_class_declaration$13","copy_class_type_declaration$13","copy_virtual_flag$13","copy_class_infos$13","copy_class_expr$13","copy_class_type$13","copy_class_type_field$13","cty","copy_class_field_kind$13","copy_mutable_flag$13","copy_constructor_declaration$13","copy_module_declaration$13","copy_class_description$13","copy_toplevel_phrase$13","copy_attributes$14","copy_attribute$14","copy_loc$14","copy_option$2","copy_constant$14","copy_rec_flag$14","copy_arg_label$14","copy_constructor_arguments$14","copy_core_type$14","copy_label_declaration$14","copy_extension_constructor$14","copy_longident$2","copy_override_flag$14","copy_extension$14","copy_payload$14","copy_signature$14","copy_signature_item$14","copy_structure$14","copy_structure_item$14","copy_closed_flag$14","copy_object_field$14","copy_label$14","copy_row_field$14","copy_pattern$14","copy_class_structure$14","copy_class_field$14","copy_module_type$14","copy_with_constraint$14","copy_module_expr$14","copy_expression$14","copy_expression_desc$14","copy_value_binding$14","copy_case$14","copy_bool$2","copy_value_description$14","copy_variance$14","copy_private_flag$14","copy_type_extension$14","copy_module_type_declaration$14","copy_open_description$13","copy_include_infos$14","copy_module_binding$14","copy_type_declaration$14","copy_class_declaration$14","copy_class_type_declaration$14","copy_virtual_flag$14","copy_class_infos$14","copy_class_expr$14","copy_class_type$14","copy_class_type_field$14","copy_class_field_kind$14","copy_mutable_flag$14","copy_constructor_declaration$14","copy_module_declaration$14","copy_class_description$14","copy_toplevel_phrase$14","migration_error$3","copy_attributes$15","copy_attribute$15","copy_loc$15","copy_option$3","copy_constant$15","copy_rec_flag$15","copy_arg_label$15","copy_constructor_arguments$15","copy_core_type$15","copy_label_declaration$15","copy_extension_constructor$15","copy_longident$3","copy_override_flag$15","copy_extension$15","copy_payload$15","copy_signature$15","copy_signature_item$15","copy_structure$15","copy_structure_item$15","copy_closed_flag$15","copy_label$15","copy_row_field$15","copy_pattern$15","copy_class_structure$15","copy_class_field$15","copy_module_type$15","copy_with_constraint$15","copy_module_expr$15","copy_expression$15","copy_expression_desc$15","copy_value_binding$15","copy_case$15","copy_bool$3","copy_value_description$15","copy_variance$15","copy_private_flag$15","copy_type_extension$15","copy_module_type_declaration$15","copy_open_description$14","copy_include_infos$15","copy_module_binding$15","copy_type_declaration$15","copy_class_declaration$15","copy_class_type_declaration$15","copy_virtual_flag$15","copy_class_infos$15","copy_class_expr$15","copy_class_type$15","copy_class_type_field$15","copy_class_field_kind$15","copy_mutable_flag$15","copy_constructor_declaration$15","loc$1","copy_module_declaration$15","copy_class_description$15","copy_toplevel_phrase$15","copy_attributes$16","copy_attribute$16","copy_loc$16","copy_option$4","copy_constant$16","copy_rec_flag$16","copy_arg_label$16","copy_constructor_arguments$16","copy_core_type$16","copy_label_declaration$16","copy_extension_constructor$16","copy_longident$4","copy_override_flag$16","copy_extension$16","copy_payload$16","copy_signature$16","copy_signature_item$16","copy_structure$16","copy_structure_item$16","copy_closed_flag$16","copy_label$16","copy_row_field$16","copy_pattern$16","copy_class_structure$16","copy_class_field$16","copy_module_type$16","copy_with_constraint$16","copy_module_expr$16","copy_expression$16","copy_expression_desc$16","copy_value_binding$16","copy_case$16","copy_bool$4","copy_value_description$16","copy_variance$16","copy_private_flag$16","copy_type_extension$16","copy_module_type_declaration$16","copy_open_description$15","copy_include_infos$16","copy_module_binding$16","copy_type_declaration$16","copy_class_declaration$16","copy_class_type_declaration$16","copy_virtual_flag$16","copy_class_infos$16","copy_class_expr$16","copy_class_type$16","copy_class_type_field$16","copy_class_field_kind$16","copy_mutable_flag$16","copy_constructor_declaration$16","copy_module_declaration$16","copy_class_description$16","copy_toplevel_phrase$16","copy_attributes$17","copy_attribute$17","copy_loc$17","copy_option$5","copy_constant$17","copy_rec_flag$17","copy_arg_label$17","copy_constructor_arguments$17","copy_core_type$17","copy_label_declaration$17","copy_extension_constructor$17","copy_longident$5","copy_override_flag$17","copy_extension$17","copy_payload$17","copy_signature$17","copy_signature_item$17","copy_structure$17","copy_structure_item$17","copy_closed_flag$17","copy_label$17","copy_row_field$17","copy_pattern$17","copy_class_structure$17","copy_class_field$17","copy_module_type$17","copy_with_constraint$17","copy_module_expr$17","copy_expression$17","copy_expression_desc$17","copy_value_binding$17","copy_case$17","copy_bool$5","copy_value_description$17","copy_variance$17","copy_private_flag$17","copy_type_extension$17","copy_module_type_declaration$17","copy_open_description$16","copy_include_infos$17","copy_module_binding$17","copy_type_declaration$17","copy_class_declaration$17","copy_class_type_declaration$17","copy_virtual_flag$17","copy_class_infos$17","copy_class_expr$17","copy_class_type$17","copy_class_type_field$17","copy_class_field_kind$17","copy_mutable_flag$17","copy_constructor_declaration$17","copy_module_declaration$17","copy_class_description$17","copy_toplevel_phrase$17","noloc","copy_attributes$18","copy_attribute$18","copy_loc$18","copy_option$6","copy_constant$18","copy_rec_flag$18","copy_arg_label$18","copy_constructor_arguments$18","copy_core_type$18","copy_label_declaration$18","copy_extension_constructor$18","copy_longident$6","copy_override_flag$18","copy_extension$18","copy_payload$18","copy_signature$18","copy_signature_item$18","copy_structure$18","copy_structure_item$18","copy_closed_flag$18","copy_label$18","copy_row_field$18","copy_pattern$18","copy_class_structure$18","copy_class_field$18","copy_module_type$18","copy_with_constraint$18","copy_module_expr$18","copy_expression$18","copy_expression_desc$18","copy_value_binding$18","copy_case$18","copy_bool$6","copy_value_description$18","copy_variance$18","copy_private_flag$18","copy_type_extension$18","copy_module_type_declaration$18","copy_open_description$17","copy_include_infos$18","copy_module_binding$18","copy_type_declaration$18","copy_class_declaration$18","copy_class_type_declaration$18","copy_virtual_flag$18","copy_class_infos$18","copy_class_expr$18","copy_class_type$18","copy_class_type_field$18","copy_class_field_kind$18","copy_mutable_flag$18","copy_constructor_declaration$18","copy_module_declaration$18","copy_class_description$18","copy_toplevel_phrase$18","migration_error$4","copy_attributes$19","copy_attribute$19","copy_loc$19","copy_option$7","copy_constant$19","copy_rec_flag$19","copy_arg_label$19","copy_override_flag$19","copy_extension$19","copy_payload$19","copy_signature$19","copy_signature_item$19","copy_structure$19","copy_structure_item$19","copy_closed_flag$19","copy_core_type$19","copy_longident$7","copy_label$19","copy_row_field$19","copy_pattern$19","copy_class_structure$19","copy_class_field$19","copy_module_type$19","copy_with_constraint$19","copy_module_expr$19","copy_expression$19","copy_expression_desc$19","copy_value_binding$19","copy_case$19","copy_bool$7","copy_value_description$19","copy_constructor_arguments$19","copy_label_declaration$19","copy_extension_constructor$19","copy_variance$19","copy_private_flag$19","copy_type_extension$19","copy_module_type_declaration$19","copy_open_description$18","copy_include_infos$19","copy_module_binding$19","copy_type_declaration$19","copy_class_declaration$19","copy_class_type_declaration$19","copy_virtual_flag$19","copy_class_infos$19","copy_class_expr$19","copy_class_type$19","copy_class_type_field$19","copy_class_field_kind$19","copy_mutable_flag$19","copy_constructor_declaration$19","copy_module_declaration$19","copy_class_description$19","copy_toplevel_phrase$19","copy_attributes$20","copy_attribute$20","copy_loc$20","copy_option$8","copy_constant$20","copy_rec_flag$20","copy_arg_label$20","copy_override_flag$20","copy_extension$20","copy_payload$20","copy_signature$20","copy_signature_item$20","copy_structure$20","copy_structure_item$20","copy_closed_flag$20","copy_core_type$20","copy_longident$8","copy_label$20","copy_row_field$20","copy_pattern$20","copy_class_structure$20","copy_class_field$20","copy_module_type$20","copy_with_constraint$20","copy_module_expr$20","copy_expression$20","copy_expression_desc$20","copy_value_binding$20","copy_case$20","copy_bool$8","copy_value_description$20","copy_constructor_arguments$20","copy_label_declaration$20","copy_extension_constructor$20","copy_variance$20","copy_private_flag$20","copy_type_extension$20","copy_module_type_declaration$20","copy_open_description$19","copy_include_infos$20","copy_module_binding$20","copy_type_declaration$20","copy_class_declaration$20","copy_class_type_declaration$20","copy_virtual_flag$20","copy_class_infos$20","copy_class_expr$20","copy_class_type$20","copy_class_type_field$20","copy_class_field_kind$20","copy_mutable_flag$20","copy_constructor_declaration$20","copy_module_declaration$20","copy_class_description$20","copy_toplevel_phrase$20","inject_predef_option","ident","migration_error$5","copy_attributes$21","copy_attribute$21","copy_loc$21","copy_option$9","copy_constant$21","copy_rec_flag$21","copy_arg_label$21","copy_override_flag$21","copy_extension$21","copy_payload$21","copy_signature$21","copy_signature_item$21","copy_structure$21","copy_structure_item$21","copy_closed_flag$21","copy_core_type$21","copy_longident$9","copy_label$21","copy_row_field$21","copy_pattern$21","copy_class_structure$21","copy_class_field$21","copy_module_type$21","copy_with_constraint$21","copy_module_expr$21","copy_expression$21","copy_expression_desc$21","copy_value_binding$21","copy_case$21","copy_bool$9","type_declarations$3","recflag","types","copy_type_declaration$21","copy_value_description$21","copy_constructor_arguments$21","copy_extension_constructor$21","copy_variance$21","copy_private_flag$21","copy_type_extension$21","copy_module_type_declaration$21","copy_open_description$20","copy_include_infos$21","copy_module_binding$21","copy_class_declaration$21","copy_class_type_declaration$21","copy_virtual_flag$21","copy_class_infos$21","copy_class_expr$21","copy_class_type$21","copy_class_type_field$21","copy_class_field_kind$21","copy_mutable_flag$21","copy_constructor_declaration$21","copy_label_declaration$21","copy_module_declaration$21","copy_class_description$21","copy_toplevel_phrase$21","extract_predef_option","copy_attributes$22","copy_attribute$22","copy_loc$22","copy_option$10","copy_constant$22","copy_rec_flag$22","copy_arg_label$22","copy_override_flag$22","copy_extension$22","copy_payload$22","copy_signature$22","copy_signature_item$22","copy_structure$22","copy_structure_item$22","copy_closed_flag$22","copy_core_type$22","copy_longident$10","copy_label$22","copy_row_field$22","copy_pattern$22","copy_class_structure$22","copy_class_field$22","copy_module_type$22","copy_with_constraint$22","copy_module_expr$22","copy_expression$22","copy_expression_desc$22","copy_value_binding$22","copy_case$22","copy_bool$10","type_declarations$4","is_nonrec","attr","types$0","copy_type_declaration$22","copy_value_description$22","copy_extension_constructor$22","copy_variance$22","copy_private_flag$22","copy_type_extension$22","copy_module_type_declaration$22","copy_open_description$21","copy_include_infos$22","copy_module_binding$22","copy_class_declaration$22","copy_class_type_declaration$22","copy_virtual_flag$22","copy_class_infos$22","copy_class_expr$22","copy_class_type$22","copy_class_type_field$22","copy_class_field_kind$22","copy_mutable_flag$22","copy_constructor_declaration$22","copy_label_declaration$22","copy_module_declaration$22","copy_class_description$22","copy_toplevel_phrase$22","migration_info","id$7","migration_identity","compose$2","migration_functions","is_undefined","immediate_migration","A","direction","funs","B","To","to2","migration_info$0","migration_info$1","migration_info$2","migration_info$3","migration_info$4","migration_info$5","migration_info$6","migration_info$7","migration_info$8","migration_info$10","migration_info$11","version$1","version$2","version$3","version$4","version$5","version$6","version$7","version$9","version$10","of_ocaml","to_ocaml","of_ocaml_mapper","item","to_ocaml_mapper","parse$1","parse$2","self_1","a$3","a$4","a$5","a$6","pdira_desc$0","pdira_loc$0","pdir_name$0","pdir_arg$0","pdir_loc$0","pmb_name$0","pmb_expr$0","pmb_attributes$0","pmb_loc$0","pvb_pat$0","pvb_expr$0","pvb_attributes$0","pvb_loc$0","b$3","b$4","a$7","a$8","a$9","a$10","a$11","a$12","a$13","a$14","a$15","a$16","a$17","a$18","a$19","a$20","a$21","a$22","a$23","a$24","a$25","a$26","b$5","a$27","a$28","b$6","pstr_desc$0","pstr_loc$0","pmod_desc$0","pmod_loc$0","pmod_attributes$0","pincl_mod$0","pincl_loc$0","pincl_attributes$0","popen_expr$0","popen_override$0","popen_loc$0","popen_attributes$0","pmtd_name$0","pmtd_type$0","pmtd_attributes$0","pmtd_loc$0","pms_name$0","pms_manifest$0","pms_attributes$0","pms_loc$0","pmd_name$0","pmd_type$0","pmd_attributes$0","pmd_loc$0","psig_desc$0","psig_loc$0","pmty_desc$0","pmty_loc$0","pmty_attributes$0","pcf_desc$0","pcf_loc$0","pcf_attributes$0","pcstr_self$0","pcstr_fields$0","b$7","b$8","b$9","b$10","pcl_desc$0","pcl_loc$0","pcl_attributes$0","pci_virt$0","pci_params$0","pci_name$0","pci_expr$0","pci_loc$0","pci_attributes$0","d$1","d$2","pctf_desc$0","pctf_loc$0","pctf_attributes$0","pcsig_self$0","pcsig_fields$0","pcty_desc$0","pcty_loc$0","pcty_attributes$0","ptyexn_constructor$0","ptyexn_loc$0","ptyexn_attributes$0","pext_name$0","pext_kind$0","pext_loc$0","pext_attributes$0","ptyext_path$0","ptyext_params$0","ptyext_constructors$0","ptyext_private$0","ptyext_loc$0","ptyext_attributes$0","pcd_name$0","pcd_args$0","pcd_res$0","pcd_loc$0","pcd_attributes$0","pld_name$0","pld_mutable$0","pld_type$0","pld_loc$0","pld_attributes$0","ptype_name$0","ptype_params$0","ptype_cstrs$0","ptype_kind$0","ptype_private$0","ptype_manifest$0","ptype_attributes$0","ptype_loc$0","pval_name$0","pval_type$0","pval_prim$0","pval_attributes$0","pval_loc$0","pbop_op$0","pbop_pat$0","pbop_exp$0","pbop_loc$0","let$1","ands$0","pc_lhs$0","pc_guard$0","pc_rhs$0","b$11","b$12","b$13","b$14","b$15","b$16","b$17","b$18","b$19","a$29","a$30","b$20","b$21","a$31","a$32","b$22","b$23","a$33","a$34","b$24","c$7","b$25","a$35","a$36","b$26","c$8","b$27","a$37","a$38","b$28","c$9","b$29","a$39","a$40","b$30","c$10","b$31","a$41","a$42","b$32","a$43","a$44","b$33","a$45","a$46","b$34","a$47","a$48","c$11","b$35","a$49","a$50","b$36","c$12","b$37","a$51","a$52","b$38","a$53","a$54","a$55","a$56","b$39","a$57","a$58","b$40","a$59","a$60","b$41","a$61","a$62","b$42","a$63","a$64","b$43","a$65","a$66","b$44","a$67","a$68","a$69","a$70","pexp_desc$0","pexp_loc$0","pexp_loc_stack$0","pexp_attributes$0","ppat_desc$0","ppat_loc$0","ppat_loc_stack$0","ppat_attributes$0","pof_desc$0","pof_loc$0","pof_attributes$0","prf_desc$0","prf_loc$0","prf_attributes$0","ptyp_desc$0","ptyp_loc$0","ptyp_loc_stack$0","ptyp_attributes$0","attr_name$0","attr_payload$0","attr_loc$0","loc_ghost","loc_end","loc_start","loc_start$0","loc_end$0","loc_ghost$0","pos_cnum","pos_bol","pos_lnum","pos_fname","pos_fname$0","pos_lnum$0","pos_bol$0","pos_cnum$0","self_2","self_3","acc$5","acc$6","acc$7","acc$8","acc$9","acc$10","acc$11","acc$12","acc$13","acc$14","acc$15","acc$16","acc$17","acc$18","acc$19","acc$20","acc$21","acc$22","acc$23","acc$24","acc$25","acc$26","acc$27","acc$28","acc$29","acc$30","acc$31","acc$32","acc$33","acc$34","acc$35","acc$36","acc$37","acc$38","acc$39","acc$40","acc$41","acc$42","acc$43","acc$44","acc$45","acc$46","acc$47","acc$48","acc$49","acc$50","acc$51","acc$52","acc$53","acc$54","acc$55","self_4","acc$56","acc$57","acc$58","acc$59","acc$60","acc$61","acc$62","acc$63","acc$64","acc$65","acc$66","acc$67","acc$68","self_5","self_6","lookup$1","drv","compare$112","equal$65","protectx$0","add$27","add_exn$3","find_opt$1","of_alist$5","alist$0","f$12","read_all_into","map$63","fold_right$6","symbol$210","concat$4","is_empty$12","filter_map$9","concat_map$2","assoc_opt","iter$32","is_some$2","map$64","is_empty$13","prefix$2","drop_prefix$0","index_opt","rindex_opt","split_on_char$0","find_opt$2","to_string_path","located","in_file$0","loc$4","raise_errorf$0","enter_module","enter_value$0","module_name$32","enter","enter_opt","self_7","mtd","mb","self_8","var_names_of","ec_enter_module_opt","self_9","var_name","var_name$0","in_binding_ctxt","sexp_of$0","self_10","levenshtein_distance","cutoff","line_min","distance","spellcheck$2","registered_name","names_at_best_distance","best_distance","dist","suggestions","rev_rest","ptyp_any","ptyp_constr","pexp_ident","pexp_constant","pexp_let","pexp_fun","pexp_construct","pexp_variant","pexp_record","include_infos$0","ppat_any","ppat_constant","ppat_construct","ppat_variant","ppat_record","pstr_eval","pstr_value","value_binding$0","pat","short_name","name$96","flatten_exn","unflatten","parse$3","map$66","map_lident","lident","vbs","pexp_tuple","ppat_tuple","pexp_apply","unapplied_type_constr_conv_wit","apply_loc","suffix_n","functor","functor_args","functor$0","functor_path","ident$0","gather_args","subpat","param_label","arg_label","ty_opt","attribute","binding_op","lhs","guard","rhs","pcl_constr","pcl_structure","pcl_fun","pcl_apply","pcl_let","pcl_constraint","pcl_extension","pcl_open","pcf_inherit","pcf_val","pcf_method","pcf_constraint","pcf_initializer","pcf_attribute","pcf_extension","class_infos","virt","class_signature","class_structure","pcty_constr","pcty_signature","pcty_arrow","pcty_extension","pcty_open","pctf_inherit","pctf_val","pctf_method","pctf_constraint","pctf_attribute","pctf_extension","ptyp_var","ptyp_arrow","ptyp_object","ptyp_class","ptyp_alias","ptyp_variant","ptyp_package","ptyp_extension","pdir_string","pdir_int","pdir_ident","pdir_bool","pexp_constant$0","pexp_function","pexp_fun$0","pexp_match","pexp_try","pexp_construct$0","pexp_field","pexp_setfield","pexp_array","pexp_ifthenelse","pexp_sequence","pexp_while","pexp_for","pexp_constraint","pexp_coerce","pexp_send","pexp_new","pexp_setinstvar","pexp_override","pexp_letmodule","pexp_letexception","pexp_assert","pexp_lazy","pexp_poly","pexp_object","pexp_newtype","pexp_pack","pexp_open","pexp_letop","pexp_extension","pexp_unreachable","include_infos","label_declaration","mutable","type","letop","end","ghost","module_binding","module_declaration","pmod_ident","pmod_structure","pmod_functor","pmod_apply","pmod_constraint","pmod_unpack","pmod_extension","module_substitution","pmty_ident","pmty_signature","pmty_functor","pmty_with","pmty_typeof","pmty_extension","pmty_alias","module_type_declaration","otag","oinherit","open_infos","ppat_var","ppat_alias","ppat_constant$0","ppat_interval","ppat_construct$0","ppat_array","ppat_or","ppat_constraint","ppat_type","ppat_lazy","ppat_unpack","ppat_exception","ppat_extension","ppat_open","cnum","rtag","rinherit","psig_value","psig_type","psig_typesubst","psig_typext","psig_exception","psig_module","psig_modsubst","psig_recmodule","psig_modtype","psig_open","psig_include","psig_class","psig_class_type","psig_attribute","psig_extension","pstr_primitive","pstr_type","pstr_typext","pstr_exception","pstr_module","pstr_recmodule","pstr_modtype","pstr_open","pstr_class","pstr_class_type","pstr_include","pstr_attribute","pstr_extension","toplevel_directive","type_declaration","private$0","type_exception","type_extension","constructors","value_binding","value_description","prim","nonrec_type_declaration","mk","lident$0","pexp_tuple$0","ppat_tuple$0","ptyp_tuple","pexp_tuple_opt","ppat_tuple_opt","ptyp_poly","pexp_apply$0","eint$0","echar","estring$0","efloat$0","eint32","eint64","enativeint","ebool","evar$0","pint","pchar","pstring","pfloat","pint32","pint64","pnativeint","pbool","pvar$0","eunit$0","punit","eapply$0","eabstract","esequence","elist$0","plist$0","type_constr_conv$0","unapplied_type_constr_conv","make$9","get$15","fold_dot_suffixes","collapse_after_at","parts","parts$1","parts$0","make$10","matches","matched","create_set","fully_qualified_names","attributes$0","list$5","is_whitelisted","reserve","is_in_reserved_namespaces","ignore_checks","create$74","current_file","string_of_context","get_all_for_context","check_collisions_local","caller","all_for_context","declared_at","context$0","check_collisions","register$1","kind$0","raise_errorf$1","white_list","white_list$0","other_contexts","current_context","a_or_an","rev_others","others","meths$0","nmeths","nvals","pstr","pstr_eval$0","restore_context","backup","incr_matched","parse$4","on_error","param$2","f2$0","nil","symbol$211","symbol$212","map$67","many","single_expr_payload","get_pstr_eval","st","get_pstr_extension","get_psig_extension","get_attributes","get_attribute_if_is_floating_n","dummy_ext","name$97","registrar","declare","pattern","not_seen","mark_as_seen","do_mark_as_seen","get$16","longest_match","longest_match$1","longest_match$0","attr$0","name$98","declare$0","convert$0","check_attribute","item$0","item$1","closed_flag","end_marker","end_marker_str","extract_prefix","remove_loc","remove_loc$0","prev$1","diff_asts","generated","round_trip","with_temp_file","fn1","fn2","ast","cmd$0","parse_string","match_loop","mismatch_handler","source","expected$0","source$0","source$1","expected$1","do_match","get_loc","get_loc$0","to_sexp$0","match_structure","match_signature","class_expr$3","class_field$1","class_type$4","class_type_field$0","expression$0","module_expr$1","module_type$3","pattern$1","signature_item$2","structure_item$1","get_extension","virtual_payload","merge_attributes","registrar$0","with_arg","ext","i$4","convert$1","convert_inline","filter_by_context","expanders","expanders$0","fail$2","split_normal_and_expect","split_normal_and_expect$0","filter$7","extension$0","attr_str_type_decl","expand","attr_sig_type_decl","attr_str_module_type_decl","attr_sig_module_type_decl","attr_str_type_ext","attr_sig_type_ext","attr_str_exception","attr_sig_exception","attr_str_type_decl_expect","attr_sig_type_decl_expect","attr_str_module_type_decl_expe","attr_sig_module_type_decl_expe","attr_str_type_ext_expect","attr_sig_type_ext_expect","attr_str_exception_expect","attr_sig_exception_expect","hook","replace$0","insert_after","map_nodes","super_call","base_ctxt","in_generated_code","extension_point_loc","generated_code","get_group","vals$0","rev_concat","sort_attr_group_inline","sort_attr_inline","context_free_attribute_modific","handle_attr_group_inline","items","expanded_items","expect_items","handle_attr_inline","expanded_item","expect_mismatch_handler","items$0","exp_tds","exp_rf","tds","extra_items","with_extra_items","exp_te","extra_items$0","expect_items$0","exp_ec","ec","extra_items$1","expect_items$1","exp_mtd","extra_items$2","expect_items$2","original_rest","repl","pexp_attributes$1","pexp_attributes$2","expand_constant","rules","special_functions","special_functions$0","extensions","class_expr","class_field","class_type","class_type_field","module_expr","module_type","signature_item","structure_item","ppx_import","attr_sig_exceptions_expect","attr_sig_exceptions","map_node","ctxt$0","ext$0","mk_attr_noloc","hide_attribute","add_arg","loc_fname","perform_checks$0","perform_checks_on_extensions$0","perform_locations_check$0","no_merge","given_through_cli","has_name","all$7","print_caller_id","caller_id","add_ctxt_arg","register_transformation","enclose_impl","enclose_intf","impl","intf","lint_impl","lint_intf","preprocess_impl","preprocess_intf","impl$0","intf$0","preprocess_impl$0","preprocess_intf$0","lint_impl$0","lint_intf$0","enclose_impl$0","enclose_intf$0","instrument","extensions$0","rules$0","aliases","rules$1","new_fn","old_fn","parse_apply_list","mask$1","handle_apply","handle_dont_apply","set_cookie","shared_args","pretty","patt","vars_of","st$2","st$0","vb","st$1","add_dummy_user_for_values","binds_module_names","do_insert_unused_warning_attri","keep_w32_impl","keep_w32_intf","keep_w32_spec","conv_w32_spec","keep_w32_impl$0","keep_w60_impl","keep_w60_intf","keep_w60_spec","names$0","create$75","apply$8","make_noarg","deps$0","deps","arg_names","apply_all","generators","spellcheck_msg","str_type_decl","str_type_ext","str_exception","str_module_type_decl","sig_type_decl","sig_type_ext","sig_exception","sig_module_type_decl","resolve_actual_derivers","collected","resolve_internal","not_supported","spellcheck","resolve","resolve_all","derivers","derivers_and_args","named_generators","actual_deriver_name","dep","dep_name","add$29","extension$1","actual_deriver","invalid_with","generator_name_of_id","f$13","mk_deriving_attr","generator_name","disable_warnings_attribute","warning","inline_doc_attr","wrap_str","hide","warnings$0","warnings$2","warnings$1","wrap_sig","sg$0","sg$1","merge_generators","expand_str_type_decls","expand_sig_type_decls","expand_str_module_type_decl","generators$0","expand_sig_module_type_decl","expand_str_exception","expand_sig_exception","expand_str_type_ext","expand_sig_type_ext","expand_sig","expand_str","rule_str","rule_sig","rule_str_expect","rule_sig_expect","deriving_attr","deriving_attr_expect","rules_type_decl","rules_type_ext","rules_exception","rules_module_type_decl","error$6","unsupported","internal_error","short_string_of_core_type","loc_map$0","lident_loc","prefixed_type_name","observer_name","shrinker_name","pname","ename","gensym","sym","gensyms","loc_list","fn_map_label","f_expr","f_pat","x_expr","x_pat","create_list","salt","location$0","weight_attribute","weight$3","core_type_list","label_decl_list","label_decl","pattern$2","pat_list","expression$1","expr_list","create_list$0","salt$0","location$1","weight_attribute$0","weight$4","core_type_list$0","pattern$3","expression$2","create$76","location$2","pattern$4","expression$3","create$77","location$3","core_type$3","pattern$5","expression$4","compound_sequence","make_compound_expr","field_pats","field_exprs","shrinker_exprs","compound","shrinker_of_core_type","variant$2","variant_type","clauses","Clause","clauses$0","clause","empty$31","lookup$2","of_alist$6","variance_error","create_with_variance","covariant","contravariant","param_list","injectivity","variance","expr$0","pat$0","by_variance_list","covariant_t","tyvar$0","contravariant_t","compound_generator","generator_list","size_expr","size_pat","random_expr","random_pat","compound$0","generator_of_core_type","variant$3","rec_names","make_generator","make_pair","nonrecursive_clauses","nonrec_expr","nonrec_pat","rec_expr","rec_pat","nonrec_exprs","nonrec_pats","rec_exprs","rec_pats","weight_expr","gen_expr","pairs","compound_hash","hash_expr","hash_pat","observer_exprs","body_expr","field_expr","observer_expr","compound$1","observer_of_core_type","variant$4","custom_extension","generator_attribute","obs_env","gen_env","output_type","input_type","generator_of_core_type$0","input_generator","output_observer","unlabelled","observer_of_core_type$0","input_observer","output_generator","generator_impl","observer_impl","shrinker_impl","maybe_mutually_recursive","of_lazy","decls$0","decl","impls","pats","inner_bindings","lazy_expr","covar","contravar","covar$0","contravar$0","type_decl$0","shrinker_intf","generator_intf","observer_intf","sig_type_decl$0","str_type_decl$0","rec_flag$0","generator_extension","observer_extension","shrinker_extension","create$78","fu$0","three_u_squared","sqrt_neg_three_u_squared","potential_xs","alpha_inv","temp","t2_plus_fu","t2_inv","temp$0","try_decode","group$93","bin_shape_t$97","group$94","bin_shape_t$98","group$95","create$79","first_map","three_fourths","curve_eqn","conic_c","conic_d","projection_point","field_to_conic","z0","conic_to_s","s_to_v","s_to_v_truncated","to_group","include","on_conic","on_s","on_v","conic_gen","symbol$213","unsafe_set_uint8","make_alphabet","emap","dmap","default_alphabet","unsafe_set_be_uint16","error_msgf","encode_exn","alphabet$0","emap$0","emit","decode$0","invalid_pad_overflow","get_uint8_or_padding","dmap$0","only_padding","wrap$3","non_residue","sqrt_flagged","x2_is_first","x3_is_first","to_group$0","append$6","field_elements","to_input","packeds","packed","xn","pack_to_fields","acc_n","packed_bits","append$7","field_elements$0","bitstring","pack_bits","max_size","bitstrings","field_bits","rev_fields","remaining_length","remaining_bits","packed_field_elements","pack_to_fields$0","return$25","bind$24","map$68","run$6","u8","u32","many$0","exactly","t_036","t_035","t_037","bits_of_byte","string_of_field","field_of_string","gen_field","gen_input","middle","serialized","len_to_string","u8x32","parser","normalized","v_bitstrings","v_field_elements","bools_equal","bitstring_bits","input_field","packed_fields","final_field_idx","input_bitstrings$3","input_bitstrings","packed_fields$0","packed_fields$1","packed_field","bp","input_bitstrings$0","input_bitstring","bi","packed_fields$2","input_bitstrings$1","packed_fields$3","input_bitstrings$2","of_vector_unsafe","group$96","bin_shape_t$99","bin_write_t$50","bin_read_t$86","t_of_sexp$85","sexp_of_t$93","hash_fold_proofs_verified","path$4","to_int$8","of_int$10","to_input$0","to_input$1","one_hot","typ$10","group$97","bin_shape_t$100","path$5","group$98","bin_shape_t$101","bin_read_t$87","group$99","bin_shape_t$102","bin_size_t$49","bin_write_t$51","bin_read_t$88","group$100","bin_shape_t$103","group$101","bin_shape_t$104","t_of_sexp$86","sexp_of_t$94","compare$113","hash_fold_t$58","hash$49","path$6","equal$66","group$102","bin_shape_t$105","path$7","h$1","to_bits$0","to_yojson$22","symbol$214","of_yojson$15","yojson","to_hex$3","of_hex","sexp_of_t$95","t_of_sexp$87","group$103","bin_shape_t$106","path$8","n_expected","of_tick_field","of_tock_field","to_tick_field","to_tock_field","of_bits_msb","v_proofs_verified","v_domain_log2","domain_log2","proofs_verified","proofs_verified_field","domain_log2_field","domain_log2_value","proofs_verified_value","proofs_verified_mask","four","packed_typ","y7","y6","y5","y4","assert_16_bits","group$104","bin_shape_t$107","challenge","bin_size_t$50","size_of_challenge","bin_write_t$52","write_challenge","bin_read_t$89","of_challenge","v_prechallenge","to_yojson$23","poly_challenge","of_yojson$16","t_of_sexp$88","prechallenge_field","prechallenge_value","sexp_of_t$96","compare$114","cmp_challenge","hash_fold_t$59","hash_fold_challenge","equal$67","prechallenge","typ$11","chal","to_yojson$24","symbol$215","group$105","digest$0","size_of_digest","write_digest","bin_writer_t$42","bin_read_t$90","of_digest","bin_reader_t$42","bin_t$42","version$11","versioned$1","compare$115","of_digest$0","of_digest$1","hash_fold_digest","hash$50","equal$68","path$9","to_bits_unboolean","pack$0","t_constant_opt","spec$0","t_constant_opt$0","spec$1","t_constant_opt$1","spec$2","t_constant_opt$2","spec$3","spec$4","t_const","spec$5","tl_constant_opt","hd_constant_opt","hd$1","dummy2","dummy1","t_constant_opt$3","t_constant_opt$4","b_constant_opt","x_constant_opt","dummy2$0","dummy1$0","inner$0","t_constant_opt$5","t_constant_opt$6","spec$6","t_constant_opt$7","typ$12","flag$0","assert_eq","constant_var","etyp","f_inv","f_inv$0","f_inv$1","f1_inv","f2_inv","f_bool","f_bool$0","f_a","f_a$0","opt_map","f_inv$2","f_inv$3","typ$5","pack$1","typ$13","etyp$0","bp_challenge","group$106","to_hlist$13","zeta_to_domain_size","zeta_to_srs_length","of_hlist$13","to_minimal","group$107","to_hlist$14","branch_data","bulletproof_challenges","combined_inner_product","plonk","of_hlist$14","group$108","map_challenges","scalar","typ$14","dummy_scalar_challenge","constant_typ","bool_typ_of_flag","group$109","bin_shape_t$108","bin_size_t$51","size_of_g1","size_of_bulletproof_challenges","bin_write_t$53","write_g1","write_bulletproof_challenges","bin_read_t$91","of_g1","of_bulletproof_challenges","v_old_bulletproof_challenges","to_hlist$15","old_bulletproof_challenges","of_hlist$15","to_field_elements","g1_to_field_elements","scalar_challenge$0","group$110","to_hlist$16","messages_for_next_wrap_proof","sponge_digest_before_evaluatio","deferred_values","of_hlist$16","bulletproof_challenges$0","bool$2","fp$0","scalar_challenge$1","challenge$0","group$111","to_field_elements_without_inde","app_state_to_field_elements","app_state","bp_chals","digest$1","fp$1","scalar_challenge$2","plonk$0","bp_chals$0","digest$2","messages_for_next_wrap_proof$0","bool$3","fp$2","scalar_challenge$3","challenge$1","group$112","f8","f7","f6","f5","maybe_constant","feature_flags_spec","use","to_data$0","option_map","messages_for_next_step_proof","of_data$1","feature_flags$0","to_minimal$0","proof_state","to_wrap","opt_none","of_wrap","assert_none","assert_false","map_challenges$0","bp_log2","to_data$1","should_finalize","of_data$2","typ$15","to_hlist$17","unfinalized_proofs","of_hlist$17","to_data$2","of_data$3","per_proof","hash_fold_t$60","hash$51","compare$116","t_of_sexp$89","sexp_of_t$97","hash_fold_t$61","hash$52","compare$117","t_of_sexp$90","sexp_of_t$98","equal$69","rhs0$0","lhs0$0","rhs0$1","lhs0$1","rhs0$2","lhs0$2","rhs0$3","lhs0$3","hash_fold_t$62","a0$1","a0$2","a0$3","hash$53","compare$118","t_of_sexp$91","sexp_of_t$99","if_feature","unnormalized_lagrange_basis","vanishes_on_zero_knowledge_and","endo_coefficient","alpha_pow","x_0","x_1","x_2","x_3","x_4","x_5","x_6","x_7","x_8","x_9","x_10","x_11","x_12","x_13","x_14","x_15","x_15$0","x_16","x_15$1","x_16$0","x_17","x_18","x_18$0","x_19","x_18$1","x_19$0","x_20","x_21","x_21$0","x_22","x_21$1","x_22$0","x_23","x_24","x_24$0","x_25","x_24$1","x_25$0","x_26","x_27","x_27$0","x_28","x_27$1","x_28$0","x_29","x_30","x_31","x_32","x_33","x_34","x_35","x_36","x_37","x_38","x_39","x_40","x_41","x_42","x_43","x_44","x_45","x_46","x_47","x_48","constant_term$0","index_terms$0","pow2pow","shifts$0","zetaw","rounds","expand_feature_flags","all_feature_flags","endo","field_of_hex","srs_length_log2","get_eval","zk_polynomial","zeta_to_n_minus_1","feature","lazy_flag","w_to_i","perm_alpha0","ft_eval0","p_eval0","e0_s","zkp","zeta1m1","w_n","ft_eval0$0","ft_eval0$1","nominator","ft_eval0$2","derive_plonk","w0$0","seal","choose","shifted_pow","crs_max_degree","deg","num_shifts","log2s","all_shifts","other_shiftss","all_the_same","which","to_domain","log2_sizes","generator$0","max_log2","mina_alphabet","version_byte","version_byte$0","version_byte$1","version_byte$2","version_byte$3","version_byte$4","version_byte$5","version_byte$6","version_byte$7","version_byte$8","version_byte$9","version_byte$10","version_byte$11","version_byte$12","version_byte$13","version_byte$14","version_byte$15","version_byte$16","version_byte$17","checksum_len","version_string","compute_checksum","ctx0","ctx1","ctx2","first_hash","ctx3","second_hash","checksum","decode_exn","decoded","error_str","check_encoding","to_base58_check","of_base58_check","of_base58_check_exn","to_base64","of_base64","b64","rev_events","log_func","apply_args","ay","ax","x_squared","x_squared$0","ay$0","lambda$0","ax$0","bx","bx$0","by","cx","cx$0","cy","assert_on_curve","typ_unchecked$0","ey","ex","unshift_nonzero","bs0","S","bs0$0","add_pt","windows","g3","pow2s","group_map","unrelated_base","div_unsafe","add_unsafe","lookup_point","b0_and_b1","lookup_one","pc","bs$1","windows_required","bit_pair","with_shifts","unshift","multiscale_known","scale_known","conditional_negation","p_plus_q_plus_p","lambda_1","lambda_2","scale_fast","scale_constant","bs$2","message$4","message$5","comparator$5","compare$119","to_yojson$25","of_yojson$17","sexp_of_t$100","t_of_sexp$92","compare$120","sexpifier$0","v_identifier","v_type","compare$121","to_int","compare$122","t_of_sexp$93","previous_state_hash_field","previous_length_field","genesis_slot_field","genesis_slot_value","previous_length_value","previous_state_hash_value","sexp_of_t$101","v_genesis_slot","v_previous_length","v_previous_state_hash","compare$123","sexpifier$1","v_fork","v_account_creation_fee","v_supercharged_coinbase_factor","v_coinbase_amount","v_pending_coinbase_depth","v_transaction_capacity","v_block_window_duration_ms","v_work_delay","v_ledger_depth","v_sub_windows_per_window","compare$124","header_version","to_yojson$26","compare$125","prefix_len","parse_lexbuf","yojson_parsebuffer","read_prefix","valid_header","valid_header_string","valid_header_with_prefix","fake_prefix","partial_prefix","from_string","initial_prefix_len","write_with_header","expected_max_size_log2","append_data","header_string","length_offset","length_string","length_data_offset","out_channel","true_length","true_length_string","true_length_padding","read_with_header","read_data","file_length","header_json","sexp_to_yojson","info_internal_repr_to_yojson","info$5","info$0","tag$0","info$1","tag$1","infos","trunc_after$0","acc_len","infos$0","rev_json_infos","infos$2","info$3","json_info$0","acc_infos$0","acc_len$1","infos$1","info$2","json_info","acc_infos","acc_len$0","length$2","trunc_after$1","json_infos","info$4","base_pairs","trunc_after","json$0","tag_to_json","jsons","jsons$0","group$113","bin_shape_t$109","path$10","group$114","bin_shape_t$110","path$11","group$115","bin_shape_t$111","path$12","sexp_of_t$102","v_bulletproof","v_evaluations","v_commitments","v1$11","v1$12","v1$13","v1$14","to_kimchi_proof","bulletproof","evaluations","of_kimchi_proof","debug$1","absorb_field","absorb_scalar","mask_g1_opt","absorb$0","absorb$1","ones_vector","first_zero","lowest_128_bits","constrain_low_bits","assert_128_bits","num_bits$6","to_field_checked","bits_msb","nybbles_per_row","rows","nybbles_by_row","to_field_checked$0","to_field_constant","r_2i1","test$0","seal$0","rounds_rev","n_acc_prev","xq1","yq1","s1_squared","xq2","yq2","s3_squared","random_point","endo_inv","gy","gx","endo_to_field","base$0","scalar$0","endo_to_field$0","forbidden_shifted_values","two_to_n","neg_two_to_n","representatives","generate$0","keypair","forbidden_shifted_values$0","other_mod","high$0","check$5","x_eq","b_eq","typ$16","wrap_rounds","forbidden_shifted_values$1","typ$17","t0$0","check$7","typ_unchecked$1","typ$18","input$1","high_entropy_bits","to_the_alpha","add_assign","apply_affine_map","constants","matrix","dotv","copy$0","underlying","last_squeezed","squeeze_field","step_log2","step","mk$24","tock_shifts","tick_shifts","wrap_domains","hash_messages_for_next_step_pr","app_state$0","dlog_plonk_index","dlog_pcs_batch","when_profiling","profiling","tock2","finite_exn","or_infinite_conv","compute_challenge","compute_challenges","field$2","compute_challenge$0","compute_challenges$0","compute_sg","field$3","compute_challenge$1","compute_challenges$1","tock_unpadded_public_input_of_","prev_statement","tick_public_input_of_statement","max_proofs_verified","ft_comm","sigma_comm_last","f_comm","chunked_t_comm","combined_evaluation","fx$0","fx$1","needs_final_permute_if_empty","of_sponge","add_in","i_equals_0","i_equals_j","cond_permute","permute","permuted","consume_pairs","pos_after","add_in_y_after_perm","add_in_y_before_perm","num_pairs","empty_imput","should_permute","consume_all_pending","pos_after$0","recombine","original_sponge","xs_curr","next_index_curr","curr_i","n_pre","filtered","pre$0","filtered_res","opt_res","custom_printf_006","custom_printf_007","custom_printf_008","add_fast","check_finite","p1$0","p2$0","same_x_bool","x1_squared","y1$0","add_fast$0","bits_per_chunk","chunks_needed","scale_fast_msb_bits","y_base","x_base","y_acc","x_acc","x_res","y_res","slopes","accs$0","scale_fast_unpack","scale_fast2","s_odd","s_div_2","s_div_2_bits","chunks_needed$0","actual_bits_used","bits_lsb","scale_fast2$0","Scalar_field","s_parts","custom_printf_005","one$10","lengths","one$11","default$8","hash$54","ro","tock","tick","scalar_chal","evals_combined","dummy_chals","challenges_computed","challenges_computed$0","group$116","bin_shape_t$112","bpcs","bin_size_t$52","size_of_s","size_of_challenge_polynomial_c","size_of_bpcs","bin_write_t$54","write_s","write_challenge_polynomial_com","write_bpcs","bin_read_t$92","of_s","of_challenge_polynomial_commit","of_bpcs","v_app_state","prepare","group$117","bin_shape_t$113","bin_read_t$93","path$13","t_of_sexp$94","sexp_of_t$103","hash_fold_t$63","f$14","read_step_circuit_field_elemen","prover_fe","sponge_params$0","one$12","group_size_in_bits","constant$4","typ$19","inv_exn","symbol$216","symbol$217","symbol$218","negate$2","inv_exn$0","symbol$219","symbol$220","symbol$221","equal$70","t_of_sexp$95","sexp_of_t$104","scale$3","zero$10","symbol$222","negate$3","to_affine_exn$1","of_affine$1","typ$20","typ_unchecked$2","constant$5","symbol$223","double$3","scale$4","to_field_elements$0","scale_inv","negate$4","one$13","if$3","h$2","max$25","hash_fold_vk","group$118","bin_shape_t$114","bin_size_t$53","bin_write_t$55","bin_read_t$94","bin_read_t$95","v_max_proofs_verified","v_actual_wrap_domain_size","v_wrap_index","path$14","versioned$2","func$16","to_repr","wrap_index","actual_wrap_domain_size","of_repr","public$0","wrap_vk","max_proofs_verified_field","actual_wrap_domain_size_field","wrap_index_field","wrap_index_value","actual_wrap_domain_size_value","max_proofs_verified_value","cmp_comm","to_binable$10","of_binable$12","bin_size_t$54","bin_write_t$56","bin_read_t$96","bin_read_t$97","bin_shape_t$115","bin_writer_t$43","bin_reader_t$43","bin_t$43","path$15","g$1","to_hlist$18","of_hlist$18","to_input$2","max_proofs_verified$0","actual_wrap_domain_size$0","bp_chals$1","messages_for_next_wrap_proof$1","fp$3","scalar_challenge$4","challenge$2","group$119","bin_shape_t$116","bin_size_t$55","size_of_messages_for_next_wrap","size_of_messages_for_next_step","v3$6","v2$18","v1$18","size$45","size_of_scalar_challenge","v2$6","v3$2","v2$5","v3$1","v2$4","v6$0","v5$0","v4$0","v2$3","size$46","size_of_f_multi$0","size_of_f_multi","size$47","v4$2","v3$5","v2$17","v1$17","v3$3","v2$7","size$41","v2$8","size$23","size$42","v8$0","v7$0","v6$1","v5$1","v4$1","v3$4","v2$9","size$24","size$25","size$26","v2$10","size$27","size$28","size$29","v2$11","size$30","size$31","v2$12","size$32","size$33","v2$13","size$34","size$35","v2$14","size$36","size$37","v2$15","v1$15","size$38","size$39","v2$16","v1$16","size$40","size$43","size$44","bin_write_t$57","write_messages_for_next_wrap_p","write_messages_for_next_step_p","write_scalar_challenge","write_f_multi$0","write_f_multi","bin_read_t$98","of_messages_for_next_wrap_proo","of_messages_for_next_step_proo","bin_read_t$99","of_scalar_challenge","v_alpha","v_beta","v_gamma","v_zeta","v_joint_combiner","v_range_check0","v_range_check1","v_foreign_field_add","v_foreign_field_mul","v_xor","v_rot","v_runtime_tables","v_feature_flags","v_plonk","v_bulletproof_challenges","v_branch_data","v_deferred_values","v_sponge_digest_before_evaluat","v_messages_for_next_wrap_proof","v_proof_state","v_messages_for_next_step_proof","v_statement","of_f_multi$0","of_f_multi","v_public_input","v_evals$0","v_prev_evals","v_ft_eval1$0","most_recent_width","g0","tick_arr","fields$53","fields$44","fields$45","fields$46","fields$34","fields$35","arg1$3","arg0$3","fields$36","arg1$4","arg0$4","fields$37","arg1$5","arg0$5","fields$38","arg1$6","arg0$6","fields$39","fields$40","arg1$7","arg0$7","fields$41","fields$42","fields$43","fields$47","fields$30","fields$31","fields$32","fields$33","fields$48","fields$54","poly_f_multi$0","poly_f_multi","fields$55","poly_bool","poly_scalar_challenge","fields$27","fields$49","fields$50","fields$51","fields$52","fields$28","fields$25","fields$26","fields$29","fields$56","xs$60","xs$61","arg2$6","arg1$12","arg0$12","xs$62","x$37","xs$39","xs$40","xs$42","x$26","xs$55","xs$56","arg2$5","arg1$11","arg0$11","xs$59","x$36","xs$58","x$35","xs$57","x$34","xs$41","x$25","xs$34","xs$35","arg2$2","xs$38","x$24","xs$26","xs$29","xs$28","xs$27","arg5$0","arg4$0","state$31","state$29","xs$37","xs$30","xs$31","xs$33","xs$32","xs$36","xs$63","x$38","xs$49","xs$50","state$51","arg3$1","arg2$4","arg1$10","arg0$10","xs$54","x$33","xs$53","x$32","xs$43","xs$44","arg2$3","arg1$8","arg0$8","xs$47","x$29","state$50","xs$46","x$28","xs$45","x$27","arg1$9","arg0$9","xs$52","x$31","xs$48","xs$51","x$30","xs$64","x$39","poly_f_multi$1","n$34","cmp_scalar_challenge","n$33","n$38","n$37","a_173","b_174","n$36","a_177","b_178","a_179","b_180","a_181","b_182","a_183","b_184","cmp_f_multi","n$35","t_222","t_221","t_224","t_223","a_225","b_226","t_228","t_227","t_230","t_229","t_042","t_044","t_043","t_046","t_045","t_048","t_047","t_052","t_051","t_054","t_053","t_174","t_173","t_176","t_175","t_180","t_179","t_182","t_181","t_184","t_183","t_186","t_185","a_187","b_188","t_190","t_189","t_192","t_191","t_194","t_193","t_196","t_195","t_198","t_197","t_200","t_199","t_202","t_201","t_204","t_203","t_206","t_205","t_208","t_207","t_210","t_209","t_212","t_211","t_214","t_213","t_216","t_215","a_287","b_288","t_290","t_289","t_292","t_291","statement_field","prev_evals_field","sexp$6","of_bp_chals","of_scalar_challenge$0","proof_state_field","messages_for_next_step_proof_f","deferred_values_field","messages_for_next_wrap_proof_f","old_bulletproof_challenges_fie","old_bulletproof_challenges_val","plonk_field","bulletproof_challenges_field","branch_data_field","alpha_field","beta_field","gamma_field","zeta_field","joint_combiner_field","feature_flags_field","feature_flags_value","joint_combiner_value","zeta_value","gamma_value","beta_value","alpha_value","branch_data_value","bulletproof_challenges_value","plonk_value","messages_for_next_wrap_proof_v","sponge_digest_before_evaluatio$0","deferred_values_value","sexp$5","app_state_field","challenge_polynomial_commitmen$1","old_bulletproof_challenges_fie$0","old_bulletproof_challenges_val$0","challenge_polynomial_commitmen$2","app_state_value","messages_for_next_step_proof_v","proof_state_value","sexp$7","commitments_field","evaluations_field","ft_eval1_field$0","bulletproof_field","bulletproof_value","ft_eval1_value$0","evaluations_value","commitments_value","sexp$8","of_f_multi$2","evals_field$0","of_f_multi$1","public_input_field","public_input_value","evals_value$0","prev_evals_value","statement_value","v_old_bulletproof_challenges$0","v_challenge_polynomial_commitm$0","hsv$43","hash_fold_scalar_challenge","hsv$42","hsv$46","hsv$41","hsv$45","hsv$44","hash_fold_f_multi$0","hash_fold_f_multi","e0$0","e0$1","e0$2","e1$3","e0$3","e1$4","e0$4","e1$5","e0$5","hsv$34","hsv$35","e1$6","e0$6","hsv$36","hsv$37","e1$7","e0$7","hsv$38","hsv$39","hsv$40","a_185","b_186","a_201","b_202","a_205","b_206","a_207","b_208","a_209","b_210","a_211","b_212","t_236","t_235","t_238","t_237","a_239","b_240","t_242","t_241","t_244","t_243","t_060","t_059","t_062","t_061","t_064","t_063","t_066","t_065","t_070","t_069","t_072","t_071","a_219","b_220","t_232","t_231","t_234","t_233","a_235","b_236","t_240","t_239","t_246","t_245","t_248","t_247","t_254","t_253","t_256","t_255","t_262","t_261","t_264","t_263","a_303","b_304","a_297","b_298","t_302","t_301","to_yojson_full","group$120","bin_shape_t$117","bin_size_t$56","bin_write_t$58","bin_read_t$100","bin_read_t$101","path$16","of_yojson$18","to_yojson$27","sexp_of_t$106","t_of_sexp$97","hash$56","hash_fold_t$65","equal$72","compare$127","of_repr$0","to_repr$0","versioned$3","path$17","of_yojson$19","to_yojson$28","to_yojson_full$0","sexp_of_t$107","t_of_sexp$98","hash$57","hash_fold_t$66","equal$73","compare$128","group$121","bin_shape_t$118","bin_size_t$57","bin_write_t$59","bin_read_t$102","bin_read_t$103","path$18","of_yojson$20","to_yojson$29","sexp_of_t$108","t_of_sexp$99","hash$58","hash_fold_t$67","equal$74","compare$129","of_repr$1","to_repr$1","versioned$4","path$19","read_wrap_circuit_field_elemen","sponge_params$1","squeeze_field$0","one$14","group_size_in_bits$0","constant$6","typ$22","if$4","scale$5","inv_exn$1","symbol$224","symbol$225","symbol$226","negate$5","negate$6","square$3","inv_exn$2","symbol$227","symbol$228","symbol$229","assert_square$2","assert_r1cs$2","equal$76","t_of_sexp$101","sexp_of_t$110","scale$6","random$2","zero$11","symbol$230","negate$7","to_affine_exn$2","of_affine$2","multiscale_known$0","typ$23","typ_unchecked$3","constant$7","symbol$231","double$4","scale$7","to_field_elements$1","scale_inv$0","negate$8","g$2","if$5","h$3","pad_vector","pad_challenges","chalss","pad_accumulator","hash_messages_for_next_wrap_pr","of_proof","dummy_messages_for_next_wrap_p","full_state","s0","hash_messages_for_next_wrap_pr$0","challenge_polynomial","num_possible_domains","all_possible_domains","to_bits_unsafe","absorb_shifted","absorb_shifted$0","print_g","print_w","print_chal","print_bool","scalar_to_field","assert_n_bits","lowest_128_bits$0","squeeze_challenge","squeeze_scalar","bullet_reduce","gammas","prechallenges","gammas_i","term_and_challenge","left_term","right_term","equal_g","choose_key","nones","maybes","none_sum","some_sum","some_is_yes","b_g","maybe_sum","maybe_is_yes","is_yes","no_2","maybe_2","yes_2","no_1","maybe_1","yes_1","b_x","lagrange","which_branch","scaled_lagrange","lagrange_with_correction","base_and_correction","pr","h_precomp","finite","batch","without_bound","with_bound","keep","point","check_bulletproof","pcs_batch","advice","combined_polynomial","scale_fast$0","lr_prod","uc","p_prime","cq","b_u","z_1_g_plus_b_u","z2_h","absorb$2","iter2","j1","zeta_1","gamma_1","beta_1","alpha_1","j0","zeta_0","gamma_0","beta_0","alpha_0","j1$0","j1$1","var_to_fields$0","assert_eq_plonk","index_to_field_elements","g_opt","simulate_optional_sponge_with_","sponge_state_before","state_before","incrementally_verify_proof","Max_proofs_verified","actual_proofs_verified_mask","step_domains","sg_old","openings_proof","sg_old$0","sample","sample_scalar","index_sponge","index_digest","without","absorb_g","public_input$0","non_constant_part","constant_part","corr","correction","x_hat","x_hat$0","compute_joint_combiner","absorb_sorted_1","absorb_sorted_2_to_4","absorb_sorted_5","z$2","sponge2$0","joint_combiner_if_true$0","sponge2","joint_combiner_if_true","joint_combiner$2","compute_lookup_table_comm","second_column","runtime$0","has_runtime","second_column_with_runtime","runtime$1","runtime$2","has_runtime$0","sum$1","second_with_runtime","rest_rev","comm$0","scaled_acc","comm$1","has_comm","scaled_acc$0","has_acc","comm$2","scaled_acc$1","comm$3","has_comm$0","scaled_acc$2","acc_with_comm","joint_combiner$0","joint_combiner$1","lookup_table_comm$0","lookup_table_comm$1","b_lookup_table_comm","lookup_sorted_minus_1","aggreg$0","sponge$0","sponge_before_evaluations","sigma_comm_init","ft_comm$0","len_1_add","len_1","len_2_add","len_2","len_3_add","len_4_add","len_5_add","len_5","len_6_add","len_6","append_chain","undo_chunking","mask_evals","challenge_polynomial$0","actual_evaluation","pt_to_n","pt_n_acc","shift1","shift2","map_plonk_to_field","finalize_other_proof","Proofs_verified","sg_olds","sg_evals","sg_evals2","sg_evals1","challenge_digest","xi_actual","r_actual","xi_actual$0","xi$0","xi_correct","plonk_minimal","zeta_n","zetaw_n","combined_evals","evals2","evals1","ft","sg_evals$0","actual_combined_inner_product","combined_inner_product_correct","challenge_poly","b_actual","b_correct","plonk_checks_passed","to_hlist$19","of_hlist$19","to_hlist$20","of_hlist$20","shift$0","typ$24","create$82","find$17","lookup_compiled","other_id","lookup_side_loaded","lookup_basic","wrap_domains$0","wrap_vk$1","wrap_key$0","ephemeral","wrap_key","wrap_vk$0","set_ephemeral","eph","prover","add_exn$4","print_fp","add_opt","constant_part$0","rr$0","xi_acc","p_is_finite","acc_is_finite","xi_acc$0","p_is_finite$0","is_finite","xi_acc$1","assert_eq_deferred_values","lagrange_commitment","public_input_commitment_dynami","lagrange_commitment$0","select_curve_points","points_for_domain","points","sponge_after_index","receive","domain$0","z_comm$0","t_comm$0","vanishing_polynomial","should_square","side_loaded_domain","max_n","vanishing_polynomial$0","d_unchecked","a_002","b_003","pow2_pow","squeeze_challenge$0","domain_for_compiled","unique_domains","which_log2","actual_width_mask","opt_sponge","a_008","b_009","a_010","b_011","a_006","b_007","xi$1","b_used","state_to_field_elements","after_index","hash_messages_for_next_step_pr$0","not_opt","hash_inputs","sponge$1","accumulation_verifier","accumulator_verification_key","prev_accumulators","new_accumulator","is_base_case","lookup_parameters","wrap_domain","wrap_verification_key","statement","unfinalized","bulletproof_challenges_actual","bulletproof_success","to_hlist$21","prev_challenge_polynomial_comm","prev_proof_evals","wrap_proof","of_hlist$21","to_hlist$22","of_hlist$22","shift$1","dummy$1","one_chal","typ$25","dummy$2","create$83","r$4","start$3","clock","is_odd","wrap_main","full_signature","pi_branches","step_keys","step_widths","Req","Max_widths_by_slot","messages_for_next_wrap_proof_d","which_branch$0","prev_proof_state","step_plonk_index","prev_step_accs","old_bp_chals","new_bulletproof_challenges","wrap_domain_indices","old_bulletproof_challenges$0","old_bulletproof_challenges$1","finalized","prev_messages_for_next_wrap_pr","sacc","max_local_max_proofs_verified","rough_domains","domains$0","ret_conv_inv","main$0","range_check_table_used","combined_lookup_table_length","lookup_table_length_log2","group$122","bin_shape_t$119","path$20","group$123","bin_shape_t$120","bin_size_t$58","bin_write_t$60","bin_read_t$104","bin_read_t$105","v_constraints","path$21","poly_polyComm","versioned$5","of_repr$2","to_binable$11","of_binable$13","path$22","f_debug","num_choices","choices_length","num_choices$0","dummy_step_domains","dummy_step_widths","dummy_step_keys","compare$131","right_026","left_025","right_014","left_013","t_018","t_017","t_020","t_019","right_022","left_021","right_004","left_003","right_030","left_029","t_034","right_006","left_005","right_008","left_007","right_012","left_011","t_of_sexp$102","t_of_sexp$103","sexp_of_t$111","or_infinity_to_yojson","poly_comm_to_yojson","poly_caml_g","verifier_index_to_yojson","poly_fr","poly_srs","poly_poly_comm","step_verification_key_to_yojso","wrap_verification_key_to_yojso","get_proof","verification_key","for_vk","set_proof","constant_term$1","index_terms$1","tick_rounds","AB","challenge_polys","which_eval","sgs","step_vk","actual_proofs_verified","tick_plonk_minimal","tick_combined_evals","tick_domain","tick_env","prechals","shift_value","compute_feature_flags","true_opt","false_opt","test_feature_flags_configs","runtest","deferred_values$0","x_hat_evals","full_features","deferred_values_typ","deferred_values$1","no_public_input","gate_example","public_input_1","public_input_2","public_input2","public_input1","example","actual_feature_flags$0","expand_deferred","tick_field","sc","plonk0","step_domain","w$0","challenges_digest","lookup_final_terms","xi_chal","r_chal","combined_inner_product_actual","to_shifted","verify_heterogenous","non_chunking","least_wrap_domain","actual_wrap_domain","accumulator_check","batch_verify_inputs","A_value","prepared_statement","dlog_check","comm_chals","verify_promise","a_value","create$84","proofs_verifieds","auxiliary_typ","var_to_field_elements","value_to_field_elements","rule","self_width","extract_lengths","len_ms","len_ns","branches$0","local_branches_length","local_signature_length","heights","widths","requests","output_typ","ld$0","ds$0","ns1","ns2","ln1","ln2","feature_flagss","feature_flagss$0","ln2$0","ln1$0","ns2$0","ns1$0","prev_proof_typs","output_typ$0","input_typ$0","auxiliary_var","ret_var","previous_proof_statements","ret_value","auxiliary_value","previous_proof_statement","tags$0","stmts","proof_must_verify","public_input$1","previous_proof_statements$0","prevs","unfinalized_proofs_unextended","actual_wrap_domains","stmts$0","stmt","proofs$0","prevs$0","datas","messages_for_next_wrap_proofs","unfinalizeds","actual_wrap_domains$0","should_verify","unfinalizeds$0","messages_for_next_wrap_proofs$0","datas$0","actual_wrap_domain$0","actual_wrap_domain$1","sponge_digest","prev_messages_for_next_step_pr","verified","self_data","own_domains","proof_cache","next_state","Maxes","prevs_length","self_dlog_plonk_index","self_dlog_vk","prev_vars_length","prev_values_length","expand_proof","dlog_vk","dlog_index","must_verify","Local_max_proofs_verified","deferred_values_computed","x_hat_1","zeta$0","alpha$0","zetaw$0","tock_domain","tock_combined_evals","tock_plonk_minimal","true$1","false$1","tock_env","b_polys","ft_eval","shifted_value","statements_with_hashes","x_hats","witnesses","prev_proofs","return_value","unfinalized_proofs$0","unfinalized_proofs_extended","extract_from_proofs","Extract","return_value$0","messages_for_next_step_proof_p","messages_for_next_wrap_proof_p","respond","prev_proof_requests","prev_proof_stmts","prev_proof_stmts$0","ws","prev_proofs$0","witnesses$0","x_hats$0","statements_with_hashes$0","unfinalized_proofs$1","domain_index","to_fold_in","next_proof","prev_evals","next_statement","conv_inv","promise_or_error","next_statement_hashed","auxiliary_inputs","create_proof","proof_cache$0","proof_json","to_string$44","to_string$45","s_p","header_read","s_v","read_or_generate","k_p","k_v","dirty","k_v$0","pk$0","vk$0","header_version_field","constraint_constants_field","commits_field","length_field","commit_date_field","constraint_system_hash_field","identifying_hash_field","type_field","identifier_field","identifier_value","type_value","sub_windows_per_window_field","ledger_depth_field","work_delay_field","block_window_duration_ms_field","transaction_capacity_field","pending_coinbase_depth_field","coinbase_amount_field","supercharged_coinbase_factor_f","account_creation_fee_field","fork_field","fork_value","account_creation_fee_value","supercharged_coinbase_factor_v","coinbase_amount_value","pending_coinbase_depth_value","transaction_capacity_value","block_window_duration_ms_value","work_delay_value","ledger_depth_value","sub_windows_per_window_value","mina_field","marlin_field","marlin_value","mina_value","identifying_hash_value","constraint_system_hash_value","commit_date_value","length_value","commits_value","constraint_constants_value","header_version_value","v_identifying_hash","v_constraint_system_hash","v_commit_date","v_commits","v_constraint_constants","v_header_version","v_marlin","v_mina","t_022","to_string$46","to_string$47","s_p$0","read_or_generate$0","kp","vk$1","symbol$232","generate_or_load","pad_messages_for_next_wrap_pro","messages_len","maxes_len","maxes$0","maxes$1","compile_with_wrap_main_overrid","disk_keys$0","override_wrap_domain","override_wrap_main","Branches","constraint_constants","self$0","self$1","a_value_to_fields","a_var_to_fields","a_value_to_fields$0","a_var_to_fields$0","conv_irs","snark_keys_header","constraint_system_hash","prev_varss_length","prev_varss_n","padded","enabled","step_data","cache_handle","accum_dirty","disk_keys","cs_hash","ks","step_keypairs","step_vks","wrap_main$0","wrap_main$1","wrap_requests","self_id","disk_key_prover","wrap_disk_key","wrap_pk","computed_domain_size","ks$0","step_pk","step_vk$0","proof$0","which_index","tweak_statement","tweak_statement$0","prev_statement_with_hashes","next_statement$0","next_accumulator","provers","cache_handle$0","verify_promise$0","wrap_main_dummy_override","dummy_id","write","of_compiled","in_circuit","permanent","verify$0","srs_precomputation","compile_promise","return_early_digest_exception","compile","proof_module","adjust_provers","dummy_constraints","b0$0","example$0","prev_input","self_correct","s_neg_one","b_neg_one","b0$1","recursion_proof","recursion_input","no_recursion_proof","no_recursion_input","no_recursive_input","no_recursive_proof","prev_proof","s_neg_one$0","b_neg_one$0","b0$2","example2","example1","s_neg_one$1","b_neg_one$1","b0$3","example2$0","example1$0","b0$4","blinding_value","b0$5","dummy_proof","pairing_vk","tick_combined_evals$0","combined_inner_product$0","overwritten_prechals","chals$0","sg_new","proof_with_stmt","assocs","example_proof","example_input","example_proof$0","example_input$0","example_proof$1","example_input$1","side_loaded_tag","maybe_features","params$1","v_u","v_u_over_2","v_y","v_projection_point","v_conic_c","v_a","v_b","v_spec","group_map_params","arg_typ","gen_arg","sexp_of_arg","test1","test2","mul_field","real_part","x_over_y","let_syntax_016","let_syntax_017","let_syntax_018","let_syntax_012","let_syntax_013","let_syntax_014","let_syntax_015","if_value","cond","Shifted","sigma_count","two_to_the_i_plus_1","result_with_shift","let_syntax_021","let_syntax_022","let_syntax_019","let_syntax_020","func$17","length$27","get$17","set$13","length$28","get$18","set$14","bools","v_of_list","pack_value","var_of_bits","var_to_triples","unpack_var","var_of_field_unsafe","unpack_value","compare_var","increment_if_var","increment_var","equal_var","assert_equal_var","pack_int","boolean_assert_lte","assert_decreasing","nth_bit","apply_mask","pack_unsafe","n_ones","total_length","assert_num_bits_upper_bound","masked","size_in_bits_size_in_bits","num_bits_upper_bound_unchecked","leading_zeroes","num_bits_upper_bound_unpacked","x_unpacked","num_bits_upper_bound","decreasing","handle_with$0","handle_with","resp","correct","t_of_sexp$105","sexp_of_t$113","hash_fold_t$69","compare$132","t_of_sexp$106","sexp_of_t$114","bin_size_t$59","bin_write_t$61","bin_read_t$106","bin_read_t$107","empty$32","equal$78","typ$26","t_of_sexp$107","sexp_of_t$115","add$31","typ$27","negate$9","constant$10","if$8","double$5","scale$8","sum$4","make_checked$1","params$2","block_cipher$1","add_assign$1","copy$10","to_bits$1","update$5","hash$60","pow2$1","to_bits$2","params$3","hash$61","pack_input","pack_input$0","prefix_to_field","params$4","rounds_full$0","initial_ark$0","rounds_partial$0","to_the_alpha$1","hash$62","pack_input$1","to_the_alpha$2","seal$1","add_assign$2","apply_affine_map$0","copy$11","params$5","length_in_bytes$1","padding_char","create$85","protocol_state","protocol_state_body","account","side_loaded_vk","zkapp_account","zkapp_payload","zkapp_body_mainnet","zkapp_body_testnet","merge_snark","base_snark","transition_system_snark","signature_testnet","signature_mainnet","signature_other","chain_name","receipt_chain_user_command","receipt_chain_zkapp","epoch_seed","vrf_message","vrf_output","vrf_evaluation","pending_coinbases","coinbase_stack_data","coinbase_stack_state_hash","coinbase_stack","coinbase","checkpoint_list","zkapp_precondition","zkapp_precondition_account","zkapp_precondition_protocol_st","account_update_account_precond","account_update_cons","account_update_node","account_update_stack_frame","account_update_stack_frame_con","zkapp_uri","zkapp_event","zkapp_events","zkapp_actions","zkapp_memo","zkapp_test","derive_token_id","raise$1","to_option$0","array_length","export$0","jsoo_exports","symbol$233","lookup$3","of_js","salt$1","salt$2","salt_legacy","cached","cached$0","signature_kind","crypto_hash_prefix","hash_prefix","hash_prefix$0","triple_string","test_to_triples","arbitrary_string","with_randomness","print_digest","check_serialization","known_good_digest","group$124","bin_shape_t$121","group$125","field$4","group$126","create$86","bin_read_t$108","v_x","v_is_odd","bin_size_t$60","bin_write_t$62","to_hlist$23","of_hlist$23","gen$2","group$127","bin_shape_t$122","path$23","version$12","group$128","bin_shape_typ","group$129","bin_shape_t$123","create$87","bin_read_t$109","bin_read_t$110","bin_reader_t$44","bin_size_t$61","bin_write_t$63","bin_writer_t$44","bin_t$44","group$130","size_of_pk","write_pk","bin_writer_t$45","bin_read_t$111","of_pk","bin_reader_t$45","bin_t$45","version$13","equal_key","compare_key$2","hash_fold_t$70","hash$63","to_yojson$32","of_yojson$22","of_pk$0","of_public_key","hash_fold_t$71","uncompressed","path$24","group$131","bin_shape_typ$0","group$132","public_key","create$88","bin_read_t$112","key_to_string","compress$1","empty$33","to_input$3","to_input_legacy","typ$28","var_of_t","equal$79","odd_eq","to_input$4","decompress","y_parity","decompress_exn","compare$133","t_026","t_025","hash_fold_t$72","of_yojson$23","compressed","to_yojson$33","sexp_of_t$117","t_of_sexp$109","path$25","group$133","bin_shape_t_tagged$0","create$89","bin_read_t$113","bin_size_t$62","bin_write_t$64","group$134","bin_shape_t$124","bin_size_t$63","bin_write_t$65","bin_writer_t$46","bin_read_t$114","bin_read_t$115","bin_reader_t$46","bin_t$46","compare$134","version$14","t_of_sexp$110","upperbound","path$26","group$135","bin_shape_typ$1","bin_size_typ","bin_write_typ","bin_read_typ","group$136","bin_shape_t_tagged$1","create$90","bin_read_t$116","bin_read_t$117","bin_reader_t$47","bin_size_t$64","bin_write_t$66","bin_writer_t$47","bin_t$47","is_even","derive","k_prime","r_pt","verifier","final_check","e_pk","s_g_e_pk","y_even","r_correct","verifies","assert_verifies","ry_even","network_id_mainnet","network_id_testnet","make_derive","network_id","private_key","network_id_mainnet$0","derive_for_mainnet","derive_for_testnet","make_hash","py","px","hash$64","hash_for_mainnet","hash_for_testnet","hash_checked","make_derive$0","derive$0","derive_for_mainnet$0","derive_for_testnet$0","make_hash$0","hash$65","hash_for_mainnet$0","hash_for_testnet$0","hash_checked$0","gen_legacy","gen_chunked","pubkey","const_typ","group$137","bin_shape_t$125","path$27","t_of_sexp$111","public_key_field","private_key_field","private_key_value","public_key_value","sexp_of_t$118","v_private_key","v_public_key","compare$135","pk2","pk1","of_private_key_exn","gen$3","t_of_sexp$112","sexp_of_t$119","compare$136","group$138","bin_shape_t$126","path$28","t_of_sexp$113","sexp_of_t$120","gen$4","to_field$3","typ$29","one_half","is_pos","constant$11","pos$70","if$9","to_yojson$34","poly_hash","poly_account","group$139","bin_size_t$65","size_of_hash","size_of_account","bin_write_t$67","write_hash","write_account","bin_read_t$118","of_account","arg_1$1","arg_2","arg_3","t_of_sexp$114","sexp_of_t$121","to_yojson$35","of_yojson$24","equal$80","cmp_hash","cmp_account","cmp_hash$0","cmp_account$0","a_021$0","b_022$0","cmp_account$2","cmp_account$1","cmp_hash$2","cmp_hash$1","t_of_sexp$115","sexp_of_t$122","hash$66","group$140","bin_shape_t$127","indexes_field","depth_field","tree_field","tree_value","depth_value","indexes_value","v_tree","v_depth","v_indexes","merkle_root","add_path","account_id","build_tree","h_r","h_l","path$1","find_index_exn","aid","custom_printf_043","custom_printf_044","acct","go_right","expected_kind","custom_printf_045","path_exn","v_favorite_number","name_field","favorite_number_field","favorite_number_value","name_value","data_hash","favorite_number","prune_hash_branches","let_syntax_055","hex_char_to_bits4","bits4_to_hex_char","bits_by_n","bitsn","bits_by_8s","of_unpackable","padding_bit","bytes$0","of_field$3","pack$2","bytes_rev","of_public_key_compressed","to_public_key_compressed","pk_compressed_roundtrip_test","hex_key","field0","field_key_attr","make_lident_cmp","dhall_type_of_core_type","Ast_builder","dhall_type_fun","params$0","mod_path","dhall_type_fun$0","nm$0","mod_path$0","dhall_variant_from_constructor","ctor_decl","tys_expr","dhall_field_from_label_declara","generate_dhall_type","dhall_type","ctor_decls","label_decls","ty_name","generate_dhall_types","type_decls","attributes$1","str_type_decl$1","group$141","bin_shape_t$128","group$142","bin_shape_typ$2","group$143","bin_shape_t$129","path$29","of_yojson$25","to_yojson$36","t_of_sexp$116","sexp_of_t$123","hash_fold_t$73","func$18","compare$137","equal$81","version$15","bin_size_t$66","bin_write_t$68","bin_read_t$119","bin_read_t$120","path$30","group$144","bin_shape_t_tagged$2","create$91","bin_read_typ$0","bin_read_typ$1","bin_size_typ$0","bin_write_typ$0","to_yojson$37","of_yojson$26","t_of_sexp$117","sexp_of_t$124","hash_fold_t$74","hash$67","hashable$3","add$32","sub$9","div$2","rem$8","max_value$3","logand$1","logor$1","logxor$1","shift_left$7","shift_right$7","of_int$11","to_int$9","of_ms$0","to_ms$0","of_string$45","to_string$48","zero$12","one$15","lognot$6","succ$9","pred$9","compare$138","equal$82","max$26","min$25","pp$28","symbol$234","symbol$235","symbol$236","symbol$237","symbol$238","to_uint64","of_uint64","group$145","bin_shape_t$130","group$146","bin_shape_typ$3","group$147","bin_shape_t$131","path$31","of_yojson$27","to_yojson$38","t_of_sexp$118","sexp_of_t$125","hash_fold_t$75","func$19","compare$139","equal$83","bin_size_t$67","bin_write_t$69","bin_read_t$121","bin_read_t$122","path$32","group$148","bin_shape_t_tagged$3","create$92","to_yojson$39","of_yojson$28","t_of_sexp$119","sexp_of_t$126","length_in_bits$0","hash_fold_t$76","hash$68","hashable$4","add$33","sub$10","div$3","rem$9","max_int$3","logand$2","logor$2","logxor$2","shift_left$8","shift_right$8","of_int$12","to_int$10","of_int64$3","to_int64$4","of_string$46","to_string$49","zero$13","one$16","lognot$7","succ$10","pred$10","compare$140","equal$84","max$27","min$26","pp$29","symbol$239","symbol$240","symbol$241","symbol$242","symbol$243","to_bigint$0","to_uint32","of_uint32","actual_packed","range_check$0","range_check_flag","field_typ","div_mod","is_succ","xy","yx","x_gte_y","y_gte_x","a_lte_b","succ_if","subtract_unpacking_or_zero","neg_res","underflow","sub_or_zero","group$1","read_version$0","max_value","u32_1","u32_2","zero$14","symbol$244","diff_or_zero","u32_slot","u32_span","u32_sum","diff$0","to_uint32$0","of_uint32$0","zero$15","equal$85","zero$16","succ$11","group$149","bin_shape_t$132","sgn","t_fields_annots","t_toplevel_annots","t_of_sexp$120","of_magnitude","of_sgn","magnitude_field","sgn_field","sgn_value","magnitude_value","sexp_of_t$127","v_sgn","v_magnitude","sgn$0","precision_exp","to_mina_string","whole","num$1","num_stripped_zeros","num$0","num_stripped_zeros$0","of_mina_string_exn","decimal","decimal_length","pack_var","var_to_bits$0","var_to_bits$1","var_to_input","var_to_input_legacy","modulus_as_field","double_modulus_as_field","range_check_flagged","adjustment_factor","out_of_range","t_adjusted","unit_to_nano","to_mina_int","sub_flagged","add_flagged","add_signed_flagged","u64","of_nanomina_int","of_mina_int","of_nanomina_int_exn","of_mina_int_exn","typ_to_hlist","typ_of_hlist","compare_magnitude","sgn_to_bool","to_input_legacy$0","add_flagged$0","of_unsigned","to_fee","of_fee","repr_typ","create_var","mag","to_input_legacy$1","of_unsigned$0","let_syntax_025","let_syntax_026","add_flagged$1","let_syntax_027","let_syntax_028","yv","xv","res_magnitude","res_value","let_syntax_029","let_syntax_030","let_syntax_031","let_syntax_032","let_syntax_034","let_syntax_035","let_syntax_036","let_syntax_037","let_syntax_038","to_fee$0","of_fee$0","sub_flagged$0","y_lt_x","add_flagged$2","add_signed","add_signed_flagged$0","expect_failure","expect_success","qc_test_fast","custom_printf_040","custom_printf_041","custom_printf_042","custom_printf_046","after_format","custom_printf_050","custom_printf_047","custom_printf_048","custom_printf_049","formatted","has_decimal","trailing_zero","trailing_zero$0","custom_printf_051","custom_printf_052","currency_length","bin_writer_typ","bin_reader_typ","bin_typ","bin_size_t_tagged","bin_write_t_tagged","bin_writer_t_tagged","bin_read_t_tagged","bin_read_t_tagged$0","v_version","v_t","bin_reader_t_tagged","bin_t_tagged","minimum_user_command_fee","default_transaction_fee","default_snark_worker_fee","fee","add_fee","sexp_of_magnitude","magnitude_of_sexp","to_uint64$0","of_uint64$0","to_nanomina_int","pack_var$0","equal_var$0","var_to_input_legacy$0","var_to_input$0","var_of_t$0","to_nanomina_int$0","to_mina_int$0","of_nanomina_int$0","of_mina_int$0","of_nanomina_int_exn$0","of_mina_int_exn$0","of_uint64$1","to_uint64$1","to_mina_string$0","of_mina_string_exn$0","of_bits$0","gen_incl$0","validate_bound$0","validate_ubound$0","validate_lbound$0","clamp$0","clamp_exn$0","between$0","length_in_bits$1","dhall_type$0","compare_magnitude$0","magnitude_of_sexp$0","sexp_of_magnitude$0","to_amount","add_amount","add_amount_flagged","sub_amount","sub_amount_flagged","add_signed_amount_flagged","to_amount$0","uint64_to_z","uint64_of_z","max_uint64_z","fits_uint64","check_q","den","of_q","of_q_exn","make_exn","to_uint64$2","to_uint64_exn","fr","sub_flagged$1","scale_exn","sexp_of_fee","sexp_of_weight","sub_flagged_checked","u_checked","m_checked","union$6","diff$4","single$0","empty$34","csingle","cseq","cadd","cupper","clower","calpha","cdigit","calnum","eRR","menhir_discard","menhir_env","lexer","menhir_errorcase","menhir_stack","menhir_s","menhir_stack$0","menhir_s$0","menhir_s$1","menhir_stack$1","menhir_s$2","menhir_stack$2","menhir_s$3","menhir_stack$3","menhir_s$4","menhir_stack$4","menhir_s$5","menhir_stack$5","menhir_s$6","menhir_stack$6","menhir_s$7","menhir_stack$7","menhir_s$8","menhir_stack$8","menhir_s$9","menhir_stack$9","menhir_s$10","menhir_stack$10","menhir_s$11","menhir_stack$11","menhir_s$12","menhir_stack$12","menhir_s$13","menhir_stack$13","menhir_s$14","menhir_stack$14","menhir_s$15","menhir_stack$15","menhir_s$16","menhir_stack$16","menhir_s$17","menhir_stack$17","menhir_s$18","menhir_stack$18","menhir_s$19","menhir_stack$19","menhir_s$20","menhir_stack$20","menhir_s$21","menhir_stack$21","menhir_s$22","menhir_stack$22","menhir_s$23","menhir_stack$23","menhir_s$24","menhir_stack$24","menhir_s$25","menhir_stack$25","menhir_s$26","menhir_stack$26","menhir_s$27","menhir_stack$27","menhir_s$28","menhir_stack$28","menhir_s$29","menhir_stack$29","menhir_s$30","menhir_stack$30","menhir_s$31","menhir_stack$31","menhir_s$32","menhir_stack$32","menhir_s$33","menhir_stack$33","menhir_s$34","menhir_stack$34","menhir_s$35","menhir_stack$35","menhir_s$36","menhir_stack$36","menhir_s$37","menhir_stack$37","menhir_s$38","menhir_stack$38","menhir_s$39","menhir_stack$39","menhir_s$40","menhir_stack$40","menhir_s$41","menhir_stack$41","menhir_s$42","menhir_stack$42","menhir_s$43","menhir_stack$43","menhir_fail","menhir_goto_field","menhir_goto_selection","menhir_goto_operation","menhir_goto_definition","tok$0","menhir_run1$0","menhir_run2$0","menhir_run3$0","menhir_run4$0","menhir_run78$0","menhir_goto_loption_selection_","_6","_3","_5","_4","_3$0","_1$0","menhir_reduce40","menhir_env$0","menhir_env$1","menhir_run5","_2$0","_4$0","_2$1","_3$1","_2$2","menhir_run6","menhir_run7","menhir_run8","menhir_run10","menhir_run11","menhir_run12","menhir_run9","menhir_run14","menhir_reduce30","menhir_goto_value_parser_const","menhir_reduce24","menhir_goto_option_default_val","menhir_reduce36","menhir_run87","menhir_run93","menhir_goto_typ","menhir_reduce34","menhir_goto_value_parser_value","menhir_reduce26","menhir_goto_loption_arguments","menhir_run20","menhir_reduce32","tok$1","menhir_reduce28","menhir_run98","menhir_run99","menhir_run100","menhir_run97","menhir_run27","menhir_run103","menhir_run104","menhir_run105","menhir_goto_value","menhir_goto_list_directive","tok$2","tok$3","menhir_goto_loption_variable_d","menhir_env$2","menhir_run26","menhir_run28","menhir_run29","menhir_run34","menhir_run25","menhir_run32","menhir_run33","menhir_run36","menhir_goto_enum_value","menhir_reduce38","menhir_run22","menhir_goto_option_name","menhir_goto_name","menhir_env$3","tok$4","v$23","tok$11","tok$12","v$24","menhir_goto_option_type_condit","tok$7","menhir_env$5","tok$8","v$15","v$16","v$17","tok$9","menhir_env$6","tok$10","v$18","v$19","v$20","v$21","v$22","tok$5","menhir_env$4","tok$6","menhir_run13","menhir_goto_keyword_name","menhir_goto_fragment_name","menhir_goto_optype","menhir_run1","menhir_run2","menhir_run3","menhir_run4","menhir_run78","token$0","lcp","string_of_pos","parse$5","find$18","map$70","map_s","map_p","enum_value","deprecated","coerce","enum$0","string_of_const_value","string_of_arg_typ","eval_arg_error","arg_name","field_type","found_str","guid","non_null","value_to_const_value","variable_map","props","props$0","eval_arg","coerced","eval_arglist","arglist","key_values","arglist$0","arglist$1","const_value","arglist$2","arglist$3","schema","mutations","subscriptions","mutation_name","subscription_name","query_name","obj$0","io_field","abstract_field","subscription_field","enum$1","non_null$0","union$0","interface$0","add_type","abstract_typ","obj_of_subscription_obj","string$0","guid$0","skip_directive","include_directive","unless_visited","arg_list_types","memo$0","memo$1","arg_types","argtyp","argtyp$0","argtyp$1","argtyp$2","visited$0","reducer","opt$2","types_of_schema","args_to_list","no_abstracts","enum_value$0","input_value","interfaces","arg_list","directive","schema$0","subs","mut","add_built_in_fields","schema_field","matches_type_condition","type_condition","abstract$0","should_include_field","directives","arguments$0","eval_directive","arguments$1","alias_or_name","merge_selections","matching","selection_sets","selection_set","collect_fields","include_field","spread","fragment","condition","matches_type_condition$0","field_from_object","field_from_subscription_object","coerce_or_null","src$0","map_fields_with_order","error_to_json","extension_props","error_response","resolve_fields","execution_order","query_field","resolve_field","resolve_info","resolver","unlifted_value","resolved","present","lifted_value","src$1","data_to_json","errors$0","field_error","to_response","msg$1","subscribe","subs_field","source_stream","execute_operation","query","data_errs","collect_fragments","validate_fragment_selection","fragment_map","selection","fragment_spread","validate_fragment","inline_fragment","validate_fragments","fragment_names","cycle","collect_and_validate_fragments","fragments","collect_operations","select_operation","operation_name","operations","execute","variables","default_variables","default_value","variables$0","execution_ctx","find$19","find_string","t_toplevel_annots$0","sexp_of_t$128","v_doc","of_annots","t_fields_annots$0","sexpifier$2","v_deprecated","v_skip","compare$141","of_annots$0","annots","under_to_camel","prefix_us","ws$0","name_under_to_camel","add_field","skip_data","f_input","annotations","ref_as_pipe","inner_acc","graphql_arg_coerce","graphql_arg_fields","creator_input","finish","creator","add_field$0","t_field","finish$0","graphql_fields_accumulator","graphql_fields","nullable_graphql_fields","contramap","arg_to_yojson_rec","arg_to_yojson","acc_obj","graphql_query_accumulator","scalar$1","int$6","string$4","wrapped","option$1","list$6","inner_query","bind$25","map$71","initial_buffer","upstream_flushed","downstream_flushed$0","output_closed","blocked_read","ivar$1","iter$34","message_of_field_error","extensions_of_field_error","parse_query","introspection_query","graphql_arg","nullable_graphql_arg","graphql_arg_accumulator","graphql_creator","graphql_query","raw_server","init_acc","merge_acc","force_breaks1","force_breaks2","force_breaks1$0","force_breaks","children","new_children","param$3","acc0","acc1","new_x1","acc2","new_x2","query_schema","query_for_all","hit_server","hit_server_query","hit_server_args","bar","skipped","foo_hello","bar$0","skipped$0","foo_hello$0","make_creator","foo_hello_fun","skipped_fun","bar_fun","compile_acc","compile_acc$0","foo_hello_gen","compile_acc$1","skipped_gen","compile_acc$2","bar_gen","manual_typ","manual_typ$0","foo","foo$0","make_creator$0","foo_fun","foo_gen","manual_typ$1","derived","manual_typ$2","typ_input","generated_typ","generated_arg_typ","generated_query","to_json_accumulator","int$7","string$5","list$7","add_field$1","finished_obj","finish$1","of_json","int$8","string$6","list$8","of_json_creator","full_derivers","group$150","bin_shape_t$133","t_fields_annots$1","t_toplevel_annots$1","t_of_sexp$121","of_h","hash_field","hash_value","sexp_of_t$129","v_hash","hash$69","data$3","hash$70","data$4","sexp_of_t$130","compare$142","cmp_h","hash$71","map$72","to_key$0","to_entry","to_doc_entry","docs","leaf_type","js_layout","js_layout_accumulator","js_type","invalid_scalar_to_string","raise_invalid_scalar","except","iso_string","uint64","uint32","js_only","js_leaf","leaf","js_record","entries","global_slot_since_genesis","global_slot_since_hard_fork","global_slot_span","a_opt","static_length$0","static_length","iso","iso_record","of_record","to_record","record_deriver","add_field$2","new_field","finish$2","accumulator","needs_custom_js","balance_change","sign_to_string","sign_of_string","sgn_fun","magnitude_fun","magnitude_gen","sgn_gen","inner_query$0","json_to_safe","print_schema","full","query_top_level","json_to_string_gql","arg_query","out_query","in_schema","out_schema","run_query","unwrap","verification_key_with_hash","hash_fun","data_fun","hash_gen","baz","foo1","baz$0","foo1$0","baz_fun","foo1_fun","foo1_gen","baz_gen","v_nothing","v_field","nothing$0","nothing_fun","field_fun","compile_acc$3","field_gen","compile_acc$4","nothing_gen","public_key$0","obj$1","compile_acc$5","public_key_gen","group$151","bin_shape_t$134","bin_writer_t$48","bin_reader_t$48","bin_t$48","version$16","func$20","path$33","group$152","bin_shape_typ$4","group$153","bin_shape_t$135","create$93","bin_read_t$123","bin_read_t$124","bin_reader_t$49","bin_size_t$68","bin_write_t$70","bin_writer_t$49","bin_t$49","to_decimal_string","to_bytes","curr","curr$0","var_to_hash_packed","var_of_hash_packed","var_to_field","group$154","state_hash","bin_writer_t$50","bin_reader_t$50","bin_t$50","hash$72","path$34","of_string$47","group$155","bin_shape_t$136","pending_coinbase_depth","init$28","genesis_timestamp_of_string","of_time","compare$143","poly_length","poly_delta","poly_genesis_state_timestamp","group$156","bin_shape_t$137","genesis_state_timestamp","to_hlist$24","slots_per_sub_window","slots_per_epoch","of_hlist$24","compare$144","group$157","bin_shape_t$138","path$35","compare$145","compiled$0","max_epoch_length","hash_typ","time_offset","setting_enabled","disable_setting_offset","enable_setting_offset","set_time_offset","tm","env_offset","get_time_offset","var_of_field","pack_value$0","unpack_value$0","unpack_var$0","compare_var$0","increment_var$0","increment_if_var$0","assert_equal_var$0","var_of_field$0","var_of_field_unsafe$0","of_time_span","to_time_span","to_time_ns_span","of_time_ns_span","int64_ns","to_time_exn","t_int64","now$1","field_var_to_unpacked","diff_checked","unpacked_to_number","to_string_exn","of_time_ns","to_system_time","to_string_system_time_exn","of_string_exn","time_beginning","time_end","time_beginning_int64","time_end_int64","int64_time_span","pack_value$1","unpack_value$1","pack_var$1","unpack_var$1","compare_var$1","increment_var$1","increment_if_var$1","assert_equal_var$1","equal_var$1","var_of_field$1","var_of_field_unsafe$1","of_time$0","to_time_exn$0","now$2","field_var_to_unpacked$0","epoch$0","of_span_since_epoch","diff_checked$0","modulus$0","unpacked_to_number$0","to_string_exn$0","of_time_ns$0","to_system_time$0","to_string_system_time_exn$0","of_string_exn$0","ctrl","cancel_ivar","span$0","timeout","cancel","peek","remaining_time","current_time","time_elapsed","await$0","timeout_duration","time_controller","await_exn","group$158","bin_read_t$125","bin_read_t$126","t_of_sexp$122","to_list$15","to_numbered_list","def2","def1","map$73","fold$19","gen$5","inner_gen","of_array$4","map_gens","gen_division_generic","dirichlet","n_float","uniform","gen_division","symbol$245","zero$18","symbol$246","symbol$247","gen_division_currency","root_gen","node_gen","this$0","next_elem","field_of_bool","of_bigstring_exn","to_bigstring$0","to_field_unsafe","gen_non_default","to_field_unsafe$0","t_014","t_013","of_public_key$0","token_id","owner","token_id$0","derive_token_id$1","tid2","tid1","pk_equal","tid_equal","tid_else","pk_else","tid_then","pk_then","create$94","equal$86","group$159","t_of_sexp$123","of_slot","of_slot_span","of_balance","of_amount","initial_minimum_balance_field","cliff_time_field","cliff_amount_field","vesting_period_field","vesting_increment_field","vesting_increment_value","vesting_period_value","cliff_amount_value","cliff_time_value","initial_minimum_balance_value","group$160","timing","t_of_sexp$124","path$36","vesting_increment","vesting_period","cliff_amount","cliff_time","initial_minimum_balance","is_timed","vesting_increment$0","vesting_period$0","cliff_amount$0","cliff_time$0","initial_minimum_balance$0","is_timed$0","t_fields_annots$2","t_toplevel_annots$2","deriver$1","vesting_increment_fun","vesting_period_fun","cliff_amount_fun","cliff_time_fun","initial_minimum_balance_fun","is_timed_fun","is_timed_gen","initial_minimum_balance_gen","cliff_time_gen","cliff_amount_gen","vesting_period_gen","vesting_increment_gen","slot_span_one","balance_unused","amount_unused","to_input$5","typ$30","deriver$2","group$161","group$162","field$5","version$17","group$163","bin_shape_t_tagged$4","create$95","bin_read_t$127","bin_size_t$69","bin_write_t$71","group$164","bin_shape_t$139","bin_size_t$70","bin_write_t$72","bin_read_t$128","t_of_sexp$125","sexp_of_t$131","compare$146","hash_fold_t$77","group$165","bin_shape_t$140","bin_read_t$129","bin_read_t$130","bin_reader_t$51","bin_size_t$71","bin_write_t$73","bin_writer_t$51","bin_t$51","path$37","group$166","bin_shape_typ$5","group$167","bin_shape_t_tagged$5","create$96","bin_read_t$131","bin_size_t$72","bin_write_t$74","authorization","group$168","bin_shape_t$141","path$38","sexp_of_t$132","gen$6","dummy_signature","let_syntax_297","signature_deriver","t_fields_annots$3","t_toplevel_annots$3","signature$3","signature$4","deriver$3","signature_fun","proof_fun","proof_gen","signature_gen","signature","to_record$0","of_record$0","deriver$4","control","typ$31","to_input$6","t_fields_annots$4","t_toplevel_annots$4","hash$73","data$5","hash$74","data$6","deriver$5","to_yojson$40","symbol$248","group$169","id$8","bin_size_t$73","bin_write_t$75","bin_read_t$132","t_of_sexp$126","sexp_of_t$133","equal$87","compare$147","hash_fold_t$78","path$39","to_yojson$41","symbol$249","group$170","bin_size_t$74","bin_write_t$76","bin_read_t$133","t_of_sexp$127","sexp_of_t$134","compare$148","hash_fold_t$79","path$40","group$171","bin_shape_typ$6","bin_size_typ$1","bin_write_typ$1","bin_read_typ$2","group$172","create$97","to_yojson$42","symbol$250","default_caller","of_string$48","equal$88","deriver$6","group$173","to_hlist$25","fee_excess_r","fee_token_r","fee_excess_l","fee_token_l","of_hlist$25","typ$32","token_typ","fee_typ","group$174","bin_shape_t$142","path$41","rebalance","fee_token_l$0","fee_token_r$0","fee_excess_l$0","zero$19","of_one_or_two","excesses","unreduced","gen_single","group$175","group$176","group$177","token_id$1","group$178","create$98","group$179","bin_shape_t$143","path$42","group$180","bin_shape_t$144","path$43","group$181","bin_shape_typ$7","group$182","bin_shape_t_tagged$6","create$99","dummy$4","to_yojson$43","of_yojson$29","t_of_sexp$128","sexp_of_t$135","equal$89","compare$149","group$183","ledger","bin_writer_t$52","bin_reader_t$52","bin_t$52","hash$75","path$44","group$184","bin_shape_t$145","write_controller","of_controller","of_controller$0","of_controller$1","hash_fold_controller","path$45","sexp_of_t$136","gen_for_proof_authorization","gen_for_signature_authorizatio","gen_for_none_given_authorizati","to_string$50","of_string$49","to_hlist$26","signature_sufficient","signature_necessary","of_hlist$26","to_input$7","encode$0","decode$1","to_input$8","t$9","typ$33","to_input$9","check$10","group$185","bin_shape_t$146","controller","to_hlist$27","set_timing","set_voting_for","increment_nonce","set_token_symbol","edit_action_state","set_zkapp_uri","set_verification_key","set_permissions","set_delegate","send","access","edit_state","of_hlist$27","set_timing$0","set_voting_for$0","increment_nonce$0","set_token_symbol$0","edit_action_state$0","set_zkapp_uri$0","set_verification_key$0","set_permissions$0","set_delegate$0","receive$0","send$0","access$0","edit_state$0","t_fields_annots$5","t_toplevel_annots$5","set_timing$1","set_voting_for$1","increment_nonce$1","set_token_symbol$1","edit_action_state$1","set_zkapp_uri$1","set_verification_key$1","set_permissions$1","set_delegate$1","receive$1","send$1","access$1","edit_state$1","set_timing$2","set_voting_for$2","increment_nonce$2","set_token_symbol$2","edit_action_state$2","set_zkapp_uri$2","set_verification_key$2","set_permissions$2","set_delegate$2","receive$2","send$2","access$2","edit_state$2","to_input$10","group$186","permissions","size_of_permissions","write_permissions","of_permissions","v_edit_state","v_access","v_send","v_receive","v_set_delegate","v_set_permissions","v_set_verification_key","v_set_zkapp_uri","v_edit_action_state","v_set_token_symbol","v_increment_nonce","v_set_voting_for","v_set_timing","t_of_sexp$129","edit_state_field","access_field","send_field","receive_field","set_delegate_field","set_permissions_field","set_verification_key_field","set_zkapp_uri_field","edit_action_state_field","set_token_symbol_field","increment_nonce_field","set_voting_for_field","set_timing_field","set_timing_value","set_voting_for_value","increment_nonce_value","set_token_symbol_value","edit_action_state_value","set_zkapp_uri_value","set_verification_key_value","set_permissions_value","set_delegate_value","receive_value","send_value","access_value","edit_state_value","of_permissions$0","compare$150","hash_fold_t$80","path$46","to_input$11","typ$34","to_input$12","auth_required","deriver$7","set_timing_fun","set_voting_for_fun","increment_nonce_fun","set_token_symbol_fun","edit_action_state_fun","set_zkapp_uri_fun","set_verification_key_fun","set_permissions_fun","set_delegate_fun","receive_fun","send_fun","access_fun","edit_state_fun","edit_state_gen","access_gen","send_gen","receive_gen","set_delegate_gen","set_permissions_gen","set_verification_key_gen","compile_acc$6","set_zkapp_uri_gen","compile_acc$7","edit_action_state_gen","compile_acc$8","set_token_symbol_gen","compile_acc$9","increment_nonce_gen","compile_acc$10","set_voting_for_gen","compile_acc$11","set_timing_gen","digest_length_byte","memo_length","max_digestible_string_length","digest_tag","bytes_tag","is_digest","create_by_digesting_string_exn","ndx","create_by_digesting_string","create_from_value_exn","create_from_bytes_exn","create_from_bytes","create_from_string_exn","create_from_string","to_raw_exn","to_raw_bytes_exn","of_raw_exn","base58_check","memo_var","aux$0","arr$0","group$187","bin_shape_t$147","path$47","group$188","bin_shape_typ$8","group$189","bin_shape_t$148","path$48","group$190","bin_shape_typ$9","group$191","bin_shape_t_tagged$7","create$100","generator_013","to_yojson$44","group$192","bin_shape_t$149","t_of_sexp$130","sexp_of_t$137","path$49","sexp_of_t$138","compare$151","predicate","source_not_present","receiver_not_present","amount_insufficient_to_create_","cannot_pay_creation_fee_in_tok","source_insufficient_balance","source_minimum_balance_violati","receiver_already_exists","token_owner_not_caller","overflow$0","global_excess_overflow","local_excess_overflow","local_supply_increase_overflow","global_supply_increase_overflo","signed_command_on_zkapp_accoun","zkapp_account_not_present","update_not_permitted_balance","update_not_permitted_access","update_not_permitted_timing","update_not_permitted_delegate","update_not_permitted_app_state","update_not_permitted_verificat","update_not_permitted_action_st","update_not_permitted_zkapp_uri","update_not_permitted_token_sym","update_not_permitted_permissio","update_not_permitted_nonce","update_not_permitted_voting_fo","zkapp_command_replay_check_fai","fee_payer_nonce_must_increase","fee_payer_must_be_signed","account_balance_precondition_u","account_nonce_precondition_uns","account_receipt_chain_hash_pre","account_delegate_precondition_","account_action_state_precondit","account_app_state_precondition","predicate$0","source_not_present$0","receiver_not_present$0","amount_insufficient_to_create_$0","cannot_pay_creation_fee_in_tok$0","source_insufficient_balance$0","source_minimum_balance_violati$0","receiver_already_exists$0","token_owner_not_caller$0","overflow$1","global_excess_overflow$0","local_excess_overflow$0","local_supply_increase_overflow$0","global_supply_increase_overflo$0","signed_command_on_zkapp_accoun$0","zkapp_account_not_present$0","update_not_permitted_balance$0","update_not_permitted_access$0","update_not_permitted_timing$0","update_not_permitted_delegate$0","update_not_permitted_app_state$0","update_not_permitted_verificat$0","update_not_permitted_action_st$0","update_not_permitted_zkapp_uri$0","update_not_permitted_token_sym$0","update_not_permitted_permissio$0","update_not_permitted_nonce$0","update_not_permitted_voting_fo$0","zkapp_command_replay_check_fai$0","fee_payer_nonce_must_increase$0","fee_payer_must_be_signed$0","account_balance_precondition_u$0","account_nonce_precondition_uns$0","account_receipt_chain_hash_pre$0","account_delegate_precondition_$0","account_action_state_precondit$0","account_app_state_precondition$0","account_proved_state_precondit","account_is_new_precondition_un","protocol_state_precondition_un","unexpected_verification_key_ha","valid_while_precondition_unsat","incorrect_nonce","invalid_fee_excess","cancelled","fold$20","predicate_fun","source_not_present_fun","receiver_not_present_fun","source_insufficient_balance_fu","receiver_already_exists_fun","token_owner_not_caller_fun","overflow_fun","global_excess_overflow_fun","local_excess_overflow_fun","zkapp_account_not_present_fun","update_not_permitted_balance_f","update_not_permitted_access_fu","update_not_permitted_timing_fu","update_not_permitted_delegate_","update_not_permitted_nonce_fun","fee_payer_nonce_must_increase_","fee_payer_must_be_signed_fun","account_proved_state_precondit$0","account_is_new_precondition_un$0","protocol_state_precondition_un$0","unexpected_verification_key_ha$0","valid_while_precondition_unsat$0","incorrect_nonce_fun","invalid_fee_excess_fun","cancelled_fun","group$193","bin_shape_t$150","path$50","to_yojson$45","group$194","bin_shape_t$151","path$51","to_display","display","empty$36","of_single_failure","is_empty$14","add$34","failure","describe","group$195","bin_shape_t$152","path$52","min$27","max$28","of_enum","equal$90","gen$7","equal$91","of_t","test_mask","payment","stake_delegation","fee_transfer","coinbase$0","typ$35","to_hlist$28","is_user_command","is_coinbase","is_fee_transfer","is_stake_delegation","is_payment","of_hlist$28","typ$36","equal$92","payment$0","stake_delegation$0","fee_transfer$0","coinbase$1","to_bits_t","to_bits_var","bool_var","bit3","bit2","bit1","acc3","add_if_true","base_typ","typ$37","unpacked_t_of_t","t_of_unpacked_t","unpacked","bits_t_of_t","t_of_bits_t","unpacked_typ","test_predicate","one_of","one$17","default$9","group$196","group$197","group$198","global_slot","nonce","token_id$2","public_key$1","group$199","create$101","to_hlist$29","valid_until","fee_payer_pk","of_hlist$29","symbol$251","group$200","bin_shape_t$153","bin_size_t$75","bin_write_t$77","bin_writer_t$53","bin_read_t$134","bin_read_t$135","v_fee","v_fee_payer_pk","v_nonce","v_valid_until","v_memo","bin_reader_t$53","bin_t$53","t_of_sexp$131","fee_field","fee_payer_pk_field","nonce_field","valid_until_field","memo_field","memo_value","valid_until_value","nonce_value","fee_payer_pk_value","fee_value","sexp_of_t$139","hash_fold_t$81","path$53","group$201","bin_shape_t$154","bin_size_t$76","bin_write_t$78","bin_read_t$136","v_fee_token","t_of_sexp$132","fee_token_field","fee_token_value","sexp_of_t$140","hash_fold_t$82","path$54","group$202","bin_shape_typ$10","group$203","common","create$102","let_syntax_073","gen$8","group$204","bin_shape_t$155","bin_size_t$77","bin_write_t$79","bin_read_t$137","v_receiver_pk","v_amount","v_new_delegate","t_of_sexp$133","new_delegate_field","new_delegate_value","receiver_pk_field","amount_field","amount_value","receiver_pk_value","sexp_of_t$141","hash_fold_t$83","path$55","group$205","bin_shape_t$156","bin_size_t$78","bin_write_t$80","bin_read_t$138","v_source_pk","v_token_id","v_delegator","t_of_sexp$134","delegator_field","delegator_value","source_pk_field","token_id_field","token_id_value","source_pk_value","sexp_of_t$142","hash_fold_t$84","path$56","group$206","bin_shape_typ$11","group$207","bin_shape_t_tagged$8","create$103","to_yojson$46","poly_common","poly_body","symbol$252","group$208","bin_shape_t$157","bin_size_t$79","size_of_common","size_of_body","bin_write_t$81","write_common","write_body","bin_read_t$139","of_common","of_body","v_common","v_body","t_of_sexp$135","common_field","body_field","body_value","common_value","sexp_of_t$143","hash_fold_t$85","hash_fold_common","hash_fold_body","compare$152","cmp_common","cmp_body","group$209","common$0","group$210","create$104","to_hlist$30","of_hlist$30","group$211","bin_shape_t$158","bin_size_t$80","bin_write_t$82","bin_read_t$140","t_of_sexp$136","sexp_of_t$144","hash_fold_t$86","path$57","group$212","bin_shape_t$159","bin_size_t$81","bin_write_t$83","bin_read_t$141","t_of_sexp$137","sexp_of_t$145","hash_fold_t$87","path$58","group$213","bin_shape_typ$12","group$214","bin_shape_t_tagged$9","create$105","bin_read_t$142","read_version$6","read_version$5","read_version$3","read_version$2","read_version$4","read_version$1","bin_size_t$82","bin_write_t$84","create$106","fee$0","fee_payer","nonce$0","receiver","payload$0","new_delegate","max_amount","receiver_pk","generator_012","t_to_hlist","source_pk","t_of_hlist","typ$38","to_hlist$31","fee_token","of_hlist$31","typ$39","of_user_command_payload","max_amount_without_overflow","poly_payload","poly_pk","poly_signature","size_of_payload","size_of_signature","write_payload","write_signature","bin_writer_payload","bin_writer_pk","bin_writer_signature","of_payload","of_signature","v_payload","v_signer","v_signature","bin_reader_payload","bin_reader_pk","bin_reader_signature","bin_payload","bin_pk","bin_signature","cmp_payload","cmp_pk","cmp_signature","payload_field","signer_field","signature_field","signature_value","signer_value","payload_value","hash_fold_payload","hash_fold_pk","hash_fold_signature","account_access_statuses","acct_id","accounts_referenced","bin_writer_typ$0","bin_reader_typ$0","bin_typ$0","bin_size_t_tagged$0","bin_write_t_tagged$0","bin_writer_t_tagged$0","bin_read_t_tagged$1","bin_read_t_tagged$2","bin_reader_t_tagged$0","bin_t_tagged$0","poly_public_key","bin_read_typ$3","bin_read_typ$4","cmp_public_key","signer","payment_payload","stake_delegation_payload","payload$1","bin_size_typ$2","bin_write_typ$2","bin_writer_typ$1","bin_read_typ$5","bin_read_typ$6","bin_reader_typ$1","bin_typ$1","bin_size_t_tagged$1","bin_write_t_tagged$1","bin_writer_t_tagged$1","bin_read_t_tagged$3","bin_read_t_tagged$4","bin_reader_t_tagged$1","bin_t_tagged$1","bin_writer_typ$2","bin_reader_typ$2","bin_typ$2","bin_size_t_tagged$2","bin_write_t_tagged$2","bin_writer_t_tagged$2","bin_read_t_tagged$5","bin_read_t_tagged$6","bin_reader_t_tagged$2","bin_t_tagged$2","bin_reader_t$5","bin_writer_t$5","bin_t$5","top_tag_versions","bin_read_top_tagged_to_latest","has_insufficient_fee","fee_payer$0","fee_excess","receiver$0","valid_until$0","sign_payload","fake_sign","gen_inner","fee_range","create_body","min_fee","max_fee","with_random_participants","gen_inner$0","min_amount","sign_type","gen_with_random_participants","gen_with_random_participants$0","payment_with_random_participan","stake_delegation_with_random_p","account_info","n_commands","currency_splits","command_senders","account_nonces","sender","rest_splits","this_split","sender_pk","sender_pk$0","splits","command_splits","command_splits$0","spend_all","amount_to_spend","swap_idx","group$11","bin_writer_t$6","bin_reader_t$6","bin_t$6","hash_fold_t$3","to_valid_unsafe","bin_size_typ$3","bin_write_typ$3","bin_writer_typ$3","bin_read_typ$7","bin_read_typ$8","bin_reader_typ$3","bin_typ$3","bin_size_t_tagged$3","bin_write_t_tagged$3","bin_writer_t_tagged$3","bin_read_t_tagged$7","bin_read_t_tagged$8","bin_reader_t_tagged$3","bin_t_tagged$3","bin_read_t$11","bin_read_t$12","bin_reader_t$7","bin_size_t$5","bin_write_t$5","bin_writer_t$7","bin_t$7","check_signature","public_keys","check_valid_keys","create_with_signature_checked","gen_test","check_only_for_signature","forget_check","filter_by_participant","user_commands","user_command","group$215","receipt_chain_hash","bin_writer_t$54","bin_reader_t$54","bin_t$54","hash$76","path$59","empty$38","group$216","bin_shape_t$160","bin_writer_t$55","bin_reader_t$55","bin_t$55","hash$77","path$60","group$217","bin_shape_t$161","path$61","group$218","bin_shape_t$162","to_hlist$32","of_hlist$32","to_input$13","of_option$0","to_option$1","map$74","typ$40","option_typ","lazy_option_typ","group$219","bin_shape_t$163","bin_size_t$83","bin_write_t$85","bin_read_t$143","t_of_sexp$138","sexp_of_t$146","compare$153","hash_fold_t$88","t_of_sexp$139","sexp_of_t$147","map$75","to_option$2","of_option$1","is_set","is_keep","deriver$8","gen$9","gen_a","typ$41","optional_typ","to_input$14","to_input$15","group$220","bin_shape_t$164","bin_size_t$84","bin_write_t$86","bin_read_t$144","t_of_sexp$140","sexp_of_t$148","compare$154","hash_fold_t$89","sexp_of_t$149","compare$155","gen$10","to_option$3","of_option$2","deriver_base","deriver$9","to_input$16","typ$42","ignore","group$221","bin_shape_t$165","path$62","to_hlist$33","of_hlist$33","encode$1","decode$2","invalid_public_key","digest_vk","dummy_vk_hash","t_of_sexp$141","sexp_of_t$150","equal$93","hash_fold_t$90","to_binable$12","of_binable$14","path$63","group$222","bin_shape_t$166","bin_size_t$85","bin_write_t$87","bin_read_t$145","typ$43","group$223","t_of_sexp$142","path$64","to_input$17","deriver$10","t_of_sexp$143","sexp_of_t$151","hash$78","empty_hash","push_hash","push_event","push_to_data_as_hash","events","pop_from_data_as_hash","events$0","typ$44","to_input$18","deriver$11","hash$79","typ$45","var_to_input$1","to_input$19","deriver$12","empty$39","max_length$1","check$11","t_of_sexp$144","to_binable$13","of_binable$15","path$65","group$224","t_of_sexp$145","of_app_state","of_vk","of_zkapp_version","of_zkapp_uri","verification_key_field","zkapp_version_field","action_state_field","last_action_slot_field","proved_state_field","zkapp_uri_field","zkapp_uri_value","proved_state_value","last_action_slot_value","action_state_value","zkapp_version_value","verification_key_value","to_hlist$34","proved_state","last_action_slot","action_state","zkapp_version","of_hlist$34","zkapp_uri$1","zkapp_uri$2","proved_state$0","last_action_slot$0","action_state$0","zkapp_version$0","verification_key$0","app_state$1","t_fields_annots$6","t_toplevel_annots$6","group$225","bin_shape_t$167","bin_size_t$86","bin_write_t$88","bin_read_t$146","v_verification_key","v_zkapp_version","v_action_state","v_last_action_slot","v_proved_state","v_zkapp_uri","t_of_sexp$146","sexp_of_t$152","path$66","zkapp_uri_non_preimage","hash_zkapp_uri_opt","zkapp_uri_opt","hash$80","typ$46","zkapp_uri_to_input","digest$4","default_digest","action_state_deriver","list_5","gen_uri","app_state$2","seq_state","last_sequence_slot","group$226","bin_shape_t$168","bin_writer_t$56","bin_reader_t$56","bin_t$56","hash$81","path$67","max_length$2","check$12","t_of_sexp$147","to_binable$14","of_binable$16","path$68","num_bits$7","to_field$4","byte_index","to_input$20","of_field$4","chars","typ$47","typ$48","var_to_input$2","group$227","t_of_sexp$148","of_id","of_token_symbol","of_nonce","of_receipt_chain_hash","of_delegate","of_state_hash","of_timing","of_zkapp_opt","token_symbol_field","balance_field","receipt_chain_hash_field","delegate_field","voting_for_field","timing_field","permissions_field","zkapp_field","zkapp_value","permissions_value","timing_value","voting_for_value","delegate_value","receipt_chain_hash_value","balance_value","token_symbol_value","zkapp","permissions$0","timing$0","voting_for","delegate","receipt_chain_hash$0","nonce$1","balance$1","token_symbol","token$1","public_key$2","zkapp$0","permissions$1","timing$1","voting_for$0","delegate$0","receipt_chain_hash$1","nonce$2","balance$2","token_symbol$0","token_id$3","public_key$3","fold$21","public_key_fun","token_id_fun","token_symbol_fun","balance_fun","nonce_fun","receipt_chain_hash_fun","delegate_fun","voting_for_fun","timing_fun","permissions_fun","zkapp_fun","to_hlist$35","of_hlist$35","t_fields_annots$7","t_toplevel_annots$7","group$228","bin_shape_t$169","path$69","delegate$1","group$229","zkapp_opt","bin_shape_t$170","bin_size_t$87","bin_write_t$89","bin_read_t$147","bin_read_t$148","v_token_symbol","v_balance","v_receipt_chain_hash","v_delegate","v_voting_for","v_timing","v_initial_minimum_balance","v_cliff_time","v_cliff_amount","v_vesting_period","v_vesting_increment","v_permissions","v_zkapp","t_of_sexp$149","sexp_of_t$153","equal$94","cmp_amount","path$70","check$13","path$71","to_yojson$47","poly_field","poly_controller","poly_amount","symbol$253","arg10$0","arg9$0","arg8$0","arg7$0","arg6$1","arg5$1","arg4$2","arg3$2","arg6$0","arg4$1","hash_zkapp_account_opt","delegate_opt","digest$5","typ$49","account$0","zkapp$1","typ$50","hash$82","create$107","min_balance_at_slot","min_balance_past_cliff","global_slot_u32","cliff_time_u32","vesting_period_u32","num_periods","vesting_decrement","has_permission","has_permission_to_send","has_permission_to_receive","gen_with_constrained_balance","vesting_end","gen_any_vesting_range","let_syntax_102","vesting_slots","vesting_periods_count","max_cliff_amt","to_vest","vi","group$230","bin_shape_t$171","ledger_hash","t_fields_annots$8","t_toplevel_annots$8","to_hlist$36","total_currency","of_hlist$36","hash$83","total_currency$0","hash$84","total_currency_fun","total_currency_gen","group$231","bin_shape_t$172","path$72","group$232","bin_shape_t$173","bin_writer_t$57","bin_reader_t$57","bin_t$57","hash$85","path$73","group$233","bin_shape_t$174","epoch_ledger","start_checkpoint","lock_checkpoint","t_fields_annots$9","t_toplevel_annots$9","to_hlist$37","epoch_length","of_hlist$37","ledger$0","epoch_length$0","lock_checkpoint$0","start_checkpoint$0","ledger$1","ledger_fun","seed_fun","start_checkpoint_fun","lock_checkpoint_fun","epoch_length_fun","ledger_gen","seed_gen","start_checkpoint_gen","lock_checkpoint_gen","epoch_length_gen","group$234","bin_shape_t$175","path$74","merge$10","if$10","merge$11","f$15","of_digest$2","group$235","bin_shape_t$176","t_fields_annots$10","t_toplevel_annots$10","to_hlist$38","of_hlist$38","to_input$21","deriver$13","upper_fun","lower_fun","lower_gen","upper_gen","v_upper","v_lower","run$7","length$29","balance$3","global_slot$0","group$236","bin_shape_t$177","bin_size_t$88","bin_write_t$90","bin_read_t$149","t_of_sexp$150","lower_field","upper_field","upper_value","lower_value","sexp_of_t$154","hash_fold_t$91","compare$156","cmp_a$0","compare$157","deriver$14","range_max","range_uint32","range_uint64","nonce$3","balance$4","amount$1","length$30","deriver$15","v_foo","gen$11","compare_a","to_input$22","to_input$23","to_input_checked","typ$51","check$14","run$8","init$29","action_state$1","boolean$1","receipt_chain_hash$2","frozen_ledger_hash","state_hash$0","token_id$4","epoch_seed$0","public_key$4","to_input$24","check$15","typ$52","receipt_chain_hash$3","balance$5","nonce$4","group$237","account$1","t_of_sexp$151","is_new_field","is_new_value","sexp_of_t$155","v_is_new","path$75","t_fields_annots$11","t_toplevel_annots$11","to_hlist$39","is_new","of_hlist$39","sexp_of_t$156","compare$158","proved_state$1","action_state$2","delegate$2","receipt_chain_hash$4","nonce$5","balance$6","is_new$0","proved_state$2","action_state$3","delegate$3","receipt_chain_hash$5","nonce$6","balance$7","gen$12","accept","nonce$7","deriver$16","is_new_fun","proved_state_fun","action_state_fun","state_fun","balance_gen","nonce_gen","receipt_chain_hash_gen","delegate_gen","state_gen","action_state_gen","proved_state_gen","is_new_gen","to_input$25","to_hlist$40","of_hlist$40","group$238","bin_shape_t$178","size_of_epoch_data","write_epoch_data","of_epoch_data","v_total_currency","v_ledger","v_seed","v_start_checkpoint","v_lock_checkpoint","v_epoch_length","t_of_sexp$152","ledger_field","seed_field","start_checkpoint_field","lock_checkpoint_field","epoch_length_field","total_currency_field","total_currency_value","epoch_length_value","lock_checkpoint_value","start_checkpoint_value","seed_value","ledger_value","of_epoch_data$0","hash_fold_epoch_data","compare$159","a_189","b_190","a_193","b_194","a_197","b_198","path$76","deriver$17","a_203","b_204","min_epoch_length","gen$13","to_input$26","to_input$27","group$239","bin_shape_t$179","snarked_ledger_hash","epoch_data","to_hlist$41","next_epoch_data","staking_epoch_data","min_window_density","blockchain_length","of_hlist$41","t_of_sexp$153","of_snarked_ledger_hash","of_length","of_global_slot","snarked_ledger_hash_field","blockchain_length_field","min_window_density_field","global_slot_since_genesis_fiel","staking_epoch_data_field","next_epoch_data_field","next_epoch_data_value","staking_epoch_data_value","global_slot_since_genesis_valu","min_window_density_value","blockchain_length_value","snarked_ledger_hash_value","t_fields_annots$12","t_toplevel_annots$12","total_currency$1","next_epoch_data$0","staking_epoch_data$0","global_slot_since_genesis$0","total_currency$2","min_window_density$0","blockchain_length$0","snarked_ledger_hash$0","make_creator$1","snarked_ledger_hash_fun","blockchain_length_fun","min_window_density_fun","global_slot_since_genesis_fun","staking_epoch_data_fun","next_epoch_data_fun","snarked_ledger_hash_gen","blockchain_length_gen","min_window_density_gen","global_slot_since_genesis_gen","staking_epoch_data_gen","next_epoch_data_gen","group$240","protocol_state$1","t_of_sexp$154","sexp_of_t$157","v_next_epoch_data","v_staking_epoch_data","v_global_slot_since_genesis","v_min_window_density","v_blockchain_length","v_snarked_ledger_hash","compare$160","a_233","b_234","cmp_epoch_data","a_251","b_252","cmp_length","a_241","b_242","a_237","b_238","a_249","b_250","a_245","b_246","path$77","deriver$18","snarked_ledger_hash$1","max_min_window_density","gen$14","to_input$28","group$241","bin_shape_t$180","path$78","epoch_data_deriver","frozen_ledger_hash$0","state_hash$1","epoch_seed$1","length$31","amount$2","global_slot$1","typ$53","t1$10","a_313","b_314","group$242","bin_shape_t$181","path$79","gen$15","typ$54","group$243","bin_shape_t$182","path$80","to_hlist$42","user","of_hlist$42","group$244","account_transition","group$245","path$81","group$246","group$247","bin_shape_t$183","path$82","group$248","bin_shape_t$184","path$83","to_hlist$43","verification_key_hash","is_proved","is_signed","of_hlist$43","t_fields_annots$13","t_toplevel_annots$13","verification_key_hash$0","is_proved$0","is_signed$0","to_hlist$44","of_hlist$44","typ$55","deriver$19","verification_key_hash_fun","is_proved_fun","is_signed_fun","is_signed_gen","is_proved_gen","verification_key_hash_gen","to_structured","of_structured_exn","let_syntax_269","vk_hash","deriver$20","typ$56","group$249","bin_shape_t$185","path$84","let_syntax_268","t_fields_annots$14","t_toplevel_annots$14","to_hlist$45","inherit_from_parent","parents_own_token","of_hlist$45","inherit_from_parent$0","parents_own_token$0","typ$57","sum_squared","typ$58","to_input$29","to_variant","of_variant","deriver$21","inherit_from_parent_fun","parents_own_token_fun","parents_own_token_gen","inherit_from_parent_gen","deriver$22","typ$59","group$250","bin_shape_t$186","bin_size_t$89","bin_write_t$91","bin_read_t$150","t_of_sexp$155","sexp_of_t$158","hash_fold_t$92","path$85","t_fields_annots$15","t_toplevel_annots$15","t_of_sexp$156","sexp_of_t$159","to_hlist$46","of_hlist$46","vesting_increment$1","vesting_period$1","cliff_amount$1","cliff_time$1","initial_minimum_balance$1","vesting_increment$2","vesting_period$2","cliff_amount$2","cliff_time$2","initial_minimum_balance$2","to_input$30","dummy$5","to_account_timing","of_account_timing","to_hlist$47","of_hlist$47","to_input$31","typ$60","deriver$23","group$251","bin_shape_t$187","path$86","t_fields_annots$16","t_toplevel_annots$16","voting_for$1","timing$2","token_symbol$1","zkapp_uri$3","permissions$2","verification_key$1","delegate$4","app_state$3","voting_for$2","timing$3","token_symbol$2","zkapp_uri$4","permissions$3","verification_key$2","delegate$5","app_state$4","to_hlist$48","of_hlist$48","gen$16","permissions_auth","token_account","token_gen","uri_gen","auth_tag","auth_required_gen","to_hlist$49","of_hlist$49","noop","to_input$32","deriver$24","zkapp_uri_fun","verification_key_fun","app_state_fun","app_state_gen","verification_key_gen","permissions_gen","zkapp_uri_gen","token_symbol_gen","timing_gen","voting_for_gen","group$252","bin_shape_t$188","path$87","precondition","gen$17","deriver$25","group$253","bin_shape_t$189","path$88","t_fields_annots$17","t_toplevel_annots$17","to_hlist$50","valid_while","network","of_hlist$50","account$2","valid_while$0","account$3","network$0","deriver$26","valid_while_fun","account_fun","network_fun","network_gen","account_gen","valid_while_gen","let_syntax_265","to_hlist$51","of_hlist$51","group$254","bin_shape_t$190","bin_size_t$90","bin_write_t$92","bin_read_t$151","t_of_sexp$157","sexp_of_t$160","hash_fold_t$93","compare$161","a_142","b_143","a_144","b_145","a_146","b_147","path$89","group$255","bin_shape_t$191","path$90","t_fields_annots$18","t_toplevel_annots$18","authorization_kind","may_use_token","implicit_account_creation_fee","use_full_commitment","preconditions","call_depth","call_data","actions","increment_nonce$3","update$6","token_id$5","public_key$5","authorization_kind$0","may_use_token$0","implicit_account_creation_fee$0","use_full_commitment$0","preconditions$0","call_depth$0","call_data$0","actions$0","increment_nonce$4","balance_change$0","update$7","token_id$6","public_key$6","deriver$27","authorization_kind_fun","may_use_token_fun","implicit_account_creation_fee_$0","use_full_commitment_fun","preconditions_fun","call_depth_fun","call_data_fun","actions_fun","events_fun","balance_change_fun","update_fun","token_id_gen","update_gen","balance_change_gen","events_gen","actions_gen","call_data_gen","call_depth_gen","preconditions_gen","use_full_commitment_gen","implicit_account_creation_fee_","may_use_token_gen","compile_acc$12","authorization_kind_gen","group$256","bin_shape_t$192","path$91","group$257","bin_shape_t$193","sexp_of_t$161","v_authorization_kind","v_may_use_token","v_implicit_account_creation_fe","v_use_full_commitment","v_preconditions","v_call_data","v_actions","v_events","v_balance_change","v_update","v_valid_while","v_account","v_network","compare$162","a_206","b_207","path$92","to_hlist$52","of_hlist$52","of_graphql_repr","group$258","bin_shape_t$194","path$93","t_fields_annots$19","t_toplevel_annots$19","nonce$8","fee$1","public_key$7","nonce$9","valid_until$1","fee$2","public_key$8","let_syntax_242","gen$18","deriver$28","valid_until_fun","fee_fun","fee_gen","valid_until_gen","of_fee_payer","to_hlist$53","of_hlist$53","chain","typ$61","non_preimage","to_input$33","create_body$0","let_syntax_246","let_syntax_249","let_syntax_250","let_syntax_294","let_syntax_259","let_syntax_262","let_syntax_263","let_syntax_296","group$259","bin_shape_t$195","path$94","t_fields_annots$20","t_toplevel_annots$20","authorization$0","authorization$1","deriver$29","authorization_fun","body_fun","body_gen","authorization_gen","group$260","bin_shape_t$196","path$95","group$261","bin_shape_t$197","size_of_account_update","v8$1","v7$2","v6$2","v5$2","v7$1","size_of_length","write_account_update","write_length","of_account_update","v_delegate$0","v_authorization","t_of_sexp$158","authorization_field","update_field","balance_change_field","events_field","actions_field","call_data_field","preconditions_field","use_full_commitment_field","may_use_token_field","authorization_kind_field","network_field","account_field","valid_while_field","valid_while_value","account_value","network_value","authorization_kind_value","may_use_token_value","use_full_commitment_value","preconditions_value","call_data_value","actions_value","events_value","balance_change_value","update_value","authorization_value","sexp_of_t$162","hash_fold_account_update","hash_fold_length","hash$86","path$96","t_of_sexp$159","sexp_of_t$163","of_graphql_repr$0","quickcheck_generator$5","digest$6","create$108","group$262","bin_shape_t$198","hash_fold_t$94","hash$87","path$97","t_fields_annots$21","t_toplevel_annots$21","authorization$2","body$1","authorization$3","body$2","let_syntax_274","deriver$30","of_fee_payer$0","balance_change$1","public_key$9","token_id$7","increment_nonce$5","group$263","bin_shape_t$199","bin_size_t$91","size_of_field","bin_write_t$93","write_field","bin_read_t$152","v_elt","v_stack_hash","t_of_sexp$160","elt_field","stack_hash_field","stack_hash_value","elt_value","sexp_of_t$164","compare$163","cmp_field","hash_fold_t$95","hash_fold_field","group$264","bin_shape_t$200","t_of_sexp$161","status_field","status_value","sexp_of_t$165","v_status","map$76","group$265","bin_size_t$92","size_of_account_update_digest","bin_write_t$94","write_account_update_digest","bin_read_t$153","of_account_update_digest","v_account_update","v_account_update_digest","v_calls","t_of_sexp$162","account_update_field","account_update_digest_field","calls_field","calls_value","account_update_digest_value","account_update_value","sexp_of_t$166","compare$164","cmp_account_update","cmp_account_update_digest","cmp_digest","hash_fold_t$96","hash_fold_account_update_diges","t_of_sexp$163","fold$22","calls","account_update","mapi_forest_with_trees","map$77","func$2","h_tl","cons$0","func$3","func$4","account_update_digest","stack_hash","group$266","bin_shape_t$201","t_of_sexp$164","sexp_of_t$167","quickcheck_shrinker$4","quickcheck_generator$6","size_138","random_139","size_136","random_137","quickcheck_observer$0","x_128","size_129","hash_130","x_135","hash_130$0","hash_130$1","size_133","hash_134","x_132","x_131","hash_134$0","hash_134$1","quickcheck_shrinker$5","x_125","x_127","x_126","of_account_updates_map","account_update_depth","account_updates","siblings","to_account_updates_map","collect","hash$88","accumulate_hashes","hash_account_update","calls$0","node_hash","group$267","bin_shape_t$202","group$268","bin_shape_t$203","path$98","empty$40","group$269","bin_shape_t$204","path$99","group$270","bin_shape_t$205","path$100","version$18","t_of_sexp$165","fee_payer_field","account_updates_field","account_updates_value","fee_payer_value","sexp_of_t$168","v_account_updates","v_fee_payer","compare$165","a_224","b_225","a_230","b_231","a_228","b_229","a_226","b_227","hash_fold_t$97","group$271","bin_shape_t$206","bin_size_t$93","bin_write_t$95","bin_read_t$154","bin_read_t$155","path$101","let_syntax_275","let_syntax_273","calls_length","to_wire","forget_hashes","forget_hash","of_binable$17","path$102","group$272","bin_shape_typ$13","t_fields_annots$22","t_toplevel_annots$22","t_of_sexp$166","sexp_of_t$169","memo$2","account_updates$0","fee_payer$1","fee_payer$2","status_sym","if$11","group$273","bin_shape_t$207","path$103","create_complete","memo_hash","fee_payer_hash","group$274","bin_shape_t$208","path$104","group$275","bin_shape_t$209","t_of_sexp$167","zkapp_command_field","zkapp_command_value","sexp_of_t$170","v_zkapp_command","hash_fold_t$98","path$105","account_updates_deriver","of_zkapp_command_with_depth","to_zkapp_command_with_depth","memo_fun","account_updates_fun","fee_payer_fun","fee_payer_gen","account_updates_gen","memo_gen","group$276","bin_shape_t$210","to_hlist$54","of_hlist$54","group$277","bin_shape_t$211","path$106","forest","group$278","bin_shape_t$212","t_of_sexp$168","of_u","sexp_of_t$171","compare$166","cmp_u","cmp_s","hash_fold_t$99","hash_fold_u","hash_fold_s","to_signed_command","gen_signed","group$279","bin_shape_t$213","t_of_sexp$169","sexp_of_t$172","hash_fold_t$100","path$107","group$280","bin_shape_t$214","path$108","group$281","bin_shape_t$215","t_of_sexp$170","sexp_of_t$173","hash_fold_t$101","path$109","with_random_receivers","size_args$0","a_012","a_016","a_018","single_to_yojson","single_of_yojson","single_of_sexp","sexp_of_single","compare_single","hash_fold_single","hash_single","to_singles","of_singles","custom_printf_026","custom_printf_027","two$0","singles","receiver_pks","receivers","ft$0","ft$1","fee_tokens","to_fee_transfer","coinbase_amount","v_receiver","v_fee_transfer","receiver_field","fee_transfer_field","fee_transfer_value","receiver_value","cb","access_status","account_ids","adjusted_fee_transfer","expected_supply_increase","increase","supercharged_coinbase","of_coinbase","incr_by_one","push$0","check_merge","to_latest$1","path$2","poly_stack_hash","size_of_stack_hash","write_stack_hash","bin_writer_stack_hash","of_stack_hash","v_init","v_curr","bin_reader_stack_hash","bin_stack_hash","init_field","curr_field","curr_value","init_value","cmp_stack_hash","hash_fold_stack_hash","to_latest$2","path$3","var_of_t$1","push$1","state_body_hash","empty$1","push$2","check_merge$0","correct_transition","eq_target","eq_src","same_update","bin_shape_t$8","hash$3","to_latest$3","bin_shape_t$9","versioned$6","t_of_sexp$5","sexp_of_t$5","to_latest$4","sexp_of_t$6","var_of_t$2","no_update","update_two_stacks_coinbase_in_","update_two_stacks_coinbase_in_$0","poly_action","poly_coinbase_amount","size_of_action","size_of_coinbase_amount","write_action","write_coinbase_amount","bin_writer_action","bin_writer_coinbase_amount","of_action","of_coinbase_amount","v_action","bin_reader_action","bin_reader_coinbase_amount","bin_action","bin_coinbase_amount","versioned$7","t_of_sexp$7","action_field","action_value","sexp_of_t$7","t_of_sexp$8","bin_shape_t$10","bin_writer_t$8","bin_reader_t$8","bin_t$8","versioned$8","t_of_sexp$9","sexp_of_t$9","to_latest$5","sexp_of_t$10","genesis","var_of_t$3","poly_data_stack","poly_state_stack","data_stack","state_stack","size_of_data_stack","size_of_state_stack","write_data_stack","write_state_stack","bin_writer_t$9","bin_writer_data_stack","bin_writer_state_stack","of_data_stack","of_state_stack","bin_reader_t$9","bin_reader_data_stack","bin_reader_state_stack","bin_t$9","bin_data_stack","bin_state_stack","version$8","versioned$9","hash_fold_data_stack","hash_fold_state_stack","t_of_sexp$11","cmp_data_stack","cmp_state_stack","a_044","t_of_sexp$12","sexp_of_t$12","a_046","b_047","bin_shape_t$11","bin_size_t$6","bin_write_t$6","bin_writer_t$10","bin_read_t$13","bin_read_t$14","bin_reader_t$10","bin_t$10","versioned$10","equal$8","a_050","a_052","hash_fold_t$5","hash$4","t_of_sexp$13","a_056","a_058","to_latest$6","equal$9","hash_fold_t$6","hash$5","sexp_of_t$15","compare$7","group$12","bin_shape_t$12","bin_size_t$7","bin_write_t$7","bin_writer_t$11","bin_read_t$15","bin_read_t$16","bin_reader_t$11","bin_t$11","equal$10","compare$8","sexp_of_t$16","versioned$11","hash$6","to_latest$7","equal$11","compare$9","sexp_of_t$17","hash_fold_t$8","hash$7","group$13","bin_shape_t$13","bin_writer_t$12","bin_read_t$18","bin_reader_t$12","bin_t$12","versioned$12","sexp_of_t$18","to_latest$8","symbol$21","sexp_of_t$19","max_coinbase_stack_count","hash_fold_t$9","sexp_of_t$20","compare$10","a_076","b_077","symbol$22","equal$12","hash_fold_t$10","hash$8","hash_var","var_of_t$4","num_pad_bits","pad_bits","empty$2","create_with","equal_state_hash","equal_data","connected","coinbase_stack_connected","state_stack_connected","state_stack_connected$0","push_coinbase","push_state","push_coinbase$0","push_state$0","check_merge$1","valid_coinbase_stacks","valid_state_stacks","create_with$0","equal$13","a_082","b_083","compare$12","a_084","b_085","hash_fold_t$11","hash$9","var_of_t$5","empty_hash$0","merge$0","sexp_of_t$23","hash_var$0","hash$10","merge$1","reraise_merkle_requests","addr$0","addr$1","add_coinbase","coinbase_receiver","supercharge_coinbase","addr2","addr1","equal_to_zero","update_stack1","total_coinbase_amount","rem_amount","no_coinbase_in_this_stack","amount1_equal_to_zero","amount2_equal_to_zero","no_coinbase","stack_with_amount1","stack_with_amount2","previous_state_stack","stack_initialized","stack_with_state_hash","update_state","stack_with_coinbase","stack_with_state","update_second_stack","act","pop_coinbases","proof_emitted","let_syntax_086","let_syntax_087","poly_tree","poly_stack_id","of_tree","of_stack_id","pos_list_field","new_pos_field","new_pos_value","pos_list_value","v_new_pos","v_pos_list","to_yojson$16","t_of_sexp$24","sexp_of_t$25","hash_at_level","cur_hash","root_hash","key$2","key$3","height$0","merkle_root$0","get_stack","find_index","next_stack_id","is_new_stack","incr_index","latest_stack_id","curr_stack_id","current_stack","prev_stack_id","latest_stack","prev_stack","oldest_stack_id","remove_oldest_stack_id","oldest_stack","update_stack","stack_index","stack_before","stack_after","add_coinbase$0","add_state","update_coinbase_stack","remove_coinbase_stack","hash_extra","pos_list","pending_coinbase","coinbase_stack_path_exn","stack_id","stack_id$0","index1","stack_id$1","index2","idx$2","prev_state","symbol$23","group$14","bin_size_t$9","size_of_tree","size_of_stack_id","bin_write_t$9","write_tree","write_stack_id","bin_writer_t$13","bin_writer_tree","bin_writer_stack_id","bin_read_t$19","bin_read_t$20","bin_reader_t$13","bin_reader_tree","bin_reader_stack_id","bin_t$13","bin_tree","bin_stack_id","versioned$13","sexp_of_t$26","symbol$24","symbol$25","group$15","bin_size_t$10","bin_write_t$10","bin_writer_t$14","bin_read_t$21","bin_read_t$22","bin_reader_t$14","bin_t$14","versioned$14","t_of_sexp$27","to_latest$9","coinbases_gen","cbs","after_adding","after_del","add_coinbase_with_zero_checks","max_coinbase_amount","t_with_state","interim_tree","coinbase_data","cb_var","f_add_coinbase","amount_var","action_var","coinbase_receiver_var","supercharge_coinbase_var","state_body_hash_var","global_slot_var","checked_merkle_root","f_pop_coinbase","unchecked_after_pop","comp$0","checked_merkle_root_after_pop","add_remove_check","coinbase_lists","coinbase_lists$0","pc$0","coinbase_lists$1","coinbases$0","stacks","coinbases","initial_coinbase","updated","new_stack","new_stack$0","pending_coinbases_updated","added_stacks","expected_stack","updated_pending_coinbases","popped_stack","pc$1","coinbase_lists$2","coinbase_lists_gen","of_bytes","of_sha256","length_in_bytes$0","to_base58_check$0","of_base58_check_exn$0","v_ledger_hash","v_aux_hash","v_pending_coinbase_aux","ledger_hash_field","aux_hash_field","pending_coinbase_aux_field","pending_coinbase_aux_value","aux_hash_value","ledger_hash_value","pending_coinbase_aux","aux_hash","pending_coinbase_aux$0","aux_hash$0","ledger_hash$0","ledger_hash_fun","aux_hash_fun","pending_coinbase_aux_fun","ledger_hash_gen","aux_hash_gen","pending_coinbase_aux_gen","map_poly","for_all$0","set_all_mutable_fields","value_of_sexp","compare_value","hash_fold_value","pending_coinbase_aux$1","aux_hash$1","ledger_hash$1","pending_coinbase_aux$2","aux_hash$2","ledger_hash$2","fold$1","map_poly$0","to_list$1","fold$2","for_all$2","to_list$2","set_all_mutable_fields$0","value_to_yojson","genesis_ledger_hash","fold$3","ledger_hash$3","aux_hash$3","of_ledger_aux_coinbase_hash","warn_improper_transport","poly_non_snark","poly_pending_coinbase_hash","non_snark","pending_coinbase_hash","size_of_non_snark","size_of_pending_coinbase_hash","write_non_snark","write_pending_coinbase_hash","bin_writer_non_snark","bin_writer_pending_coinbase_ha","of_non_snark","of_pending_coinbase_hash","v_non_snark","v_pending_coinbase_hash","bin_reader_non_snark","bin_reader_pending_coinbase_ha","bin_non_snark","bin_pending_coinbase_hash","non_snark_field","pending_coinbase_hash_field","pending_coinbase_hash_value","non_snark_value","cmp_non_snark","cmp_pending_coinbase_hash","hash_fold_non_snark","hash_fold_pending_coinbase_has","hash_value$0","ledger_hash$4","aux_hash$4","pending_coinbase_aux$3","pending_coinbase_hash_var","of_aux_ledger_and_coinbase_has","genesis$0","non_snark$0","pending_coinbase_hash$0","caller_caller","hash_zkapp_command","group$282","bin_shape_t$216","path$110","v_prover","prover_field","prover_value","compare$167","group$283","bin_shape_t$217","sexpifier$3","v_genesis_state_timestamp","v_slots_per_sub_window","v_slots_per_epoch","v_k","path$111","compare$168","end_time","gen$19","value_of_t","typ$62","p_var","transaction_dummy","group$284","bin_shape_t$218","path$112","group$285","bin_shape_t$219","path$113","group$286","bin_shape_t$220","t_of_sexp$171","sexp_of_t$174","compare$169","path$114","equal_account_state","group$287","bin_shape_t$221","command","t_of_sexp$172","of_command","sexp_of_t$175","compare$170","cmp_command","hash_fold_t$102","hash_fold_command","group$288","bin_shape_t$222","t_of_sexp$173","sexp_of_t$176","compare$171","hash_fold_t$103","func$21","path$115","group$289","bin_shape_t$223","t_of_sexp$174","sexp_of_t$177","compare$172","hash_fold_t$104","func$22","path$116","compare_hash","group$290","bin_shape_t$224","bin_read_t$156","bin_read_t$157","bin_reader_t$58","bin_size_t$94","bin_write_t$96","bin_writer_t$58","bin_t$58","mk_hasher","bin_size_t$95","bin_write_t$97","bin_read_t$158","bin_read_t$159","bin_shape_t$225","bin_writer_t$59","bin_reader_t$59","bin_t$59","signed_cmd_hasher_v1","signed_cmd_hasher","zkapp_cmd_hasher","hash_signed_command_v1","cmd_dummy_signature","hash_signed_command_v2","acct_update","dummy_auth","cmd_dummy_signatures_and_proof","hash_of_transaction_id","cmd_v1","group$291","bin_shape_t$226","t_of_sexp$175","sexp_of_t$178","compare$173","path$117","group$292","bin_shape_t$227","t_of_sexp$176","sexp_of_t$179","compare$174","path$118","group$293","signed_amount","group$294","failure_status_tbl","bin_shape_t$228","path$119","group$295","bin_shape_t$229","path$120","t_of_sexp$177","user_command_field","user_command_value","sexp_of_t$180","v_user_command","group$296","bin_shape_t$230","path$121","t_of_sexp$178","previous_delegate_field","previous_delegate_value","new_accounts_field","new_accounts_value","sexp_of_t$181","v_new_accounts","v_previous_delegate","group$297","bin_shape_t$231","path$122","t_of_sexp$179","sexp_of_t$182","group$298","bin_shape_t$232","path$123","t_of_sexp$180","accounts_field","command_field","command_value","accounts_value","sexp_of_t$183","v_command","v_accounts","group$299","bin_shape_t$233","path$124","t_of_sexp$181","sexp_of_t$184","group$300","bin_shape_t$234","path$125","t_of_sexp$182","burned_tokens_field","burned_tokens_value","sexp_of_t$185","v_burned_tokens","group$301","bin_shape_t$235","path$126","t_of_sexp$183","coinbase_field","coinbase_value","sexp_of_t$186","v_coinbase","group$302","bin_shape_t$236","path$127","t_of_sexp$184","sexp_of_t$187","group$303","bin_shape_t$237","path$128","t_of_sexp$185","previous_hash_field","varying_field","varying_value","previous_hash_value","sexp_of_t$188","v_varying","v_previous_hash","burned_tokens","varying","supply_increase","burned_tokens$0","account_creation_fee_int","new_accounts","zc","num_accounts_created","account_creation_fees","txn","process_decreases","amts","timing_error_to_user_command_s","validate_timing_with_min_balan","txn_amount","txn_global_slot","account_balance","proposed_new_balance","curr_min_balance","curr_min_balance$0","invalid_timing","invalid_balance","possibly_error","validate_timing_with_min_balan$0","min_balance","validate_timing","error_opt","get_with_location","set_with_location","sub_account_creation_fee","transaction","transaction_status","get_new_accounts","has_locked_tokens","apply_user_command_unchecked","signer_pk","fee_payer_account","fee_payer_location","ok_or_reject","compute_updates","receiver_account","receiver_location","receiver_amount","updated_accounts","previous_delegate","applied_body","located_accounts","applied_common","apply_user_command","second_pass_ledger","value_if","is_empty$0","assert_with_failure_status_tbl","ecol","proof_verifies","signature_verifies","get_zkapp","set_zkapp","is_non_neg","of_constant_fee","set_or_keep","or_default","add_check","eff","global_state","local_state","new_account","local_state$0","global_state$0","or_err","pop_call_stack","next_call_stack","next_frame","update_action_state","s1_updated","is_this_slot","is_empty_or_this_slot","s5$0","s4$0","s3$0","is_start","is_empty_call_forest","is_start$0","will_succeed","start_data$2","start_data$3","first_pass_ledger","call_stack","to_pop","start_data$0","start_data$1","call_stack$1","to_pop$0","next_forest","current_is_empty","call_stack$0","current_forest","remainder_of_current_forest","account_update_forest","account_update$0","may_use_parents_own_token","may_use_token_inherited_from_p","account_update_forest_empty","remainder_of_current_forest_em","popped_call_stack","newly_popped_frame","remainder_of_current_forest_fr","new_call_stack","new_frame","local_state$1","account_update_token_id","default_token_or_token_owner_w","full_transaction_commitment","transaction_commitment","start_data","full_tx_commitment_on_start","tx_commitment","full_tx_commitment","local_state$35","account_is_new","self_delegate","zkapp$2","matching_verification_key_hash","local_state$2","local_state$3","protocol_state_predicate_satis","local_state$4","valid_while_satisfied","local_state$5","local_state$6","local_state$7","precondition_has_constant_nonc","increments_nonce_and_constrain","depends_on_the_fee_payers_nonc","does_not_use_a_signature","local_state$8","account_update_token","account_update_token_is_defaul","account_is_untimed","local_state$9","account_creation_fee","local_state$10","neg_creation_fee","creation_overflow","balance_change_for_creation","pay_creation_fee","creation_overflow$0","local_state$11","pay_creation_fee_from_excess","failed1","local_state$12","account_creation_fee$0","excess_update_failed","excess_minus_creation_fee","local_state$13","supply_increase_update_failed","supply_increase_minus_creation","local_state$14","is_receiver","has_permission$0","local_state$15","invalid_timing$1","invalid_timing$0","local_state$16","has_permission$1","local_state$17","keeping_app_state","changing_entire_app_state","has_permission$2","local_state$18","has_permission$3","local_state$19","has_permission$4","local_state$20","has_permission$5","local_state$21","has_permission$6","local_state$22","base_delegate","has_permission$7","local_state$23","has_permission$8","local_state$24","old_hash","has_permission$9","local_state$25","index_input","has_permission$10","local_state$26","local_delta","new_local_fee_excess","overflowed","new_local_fee_excess$0","local_state$27","local_state$28","is_last_account_update","local_state$29","delta_settled","valid_fee_excess","local_state$30","is_start_or_last","update_global_state_fee_excess","global_excess_update_failed","local_state$31","local_state$32","local_state$33","should_update","local_state$34","update_action_state$0","apply_zkapp_command_first_pass","state_view","previous_hash","original_first_pass_account_st","perform$0","user_acc","eta","apply_zkapp_command_first_pass$0","partial_stmt","apply_zkapp_command_second_pas","account_states","acc_opt","original_account_states","step_all","l_state","g_state","states","reversed_failure_status_tbl","account_ids_originally_not_in_","loc_and_acct","successfully_applied","failure_status_tbl$0","valid_result","loc_opt","other_account_update_accounts_","apply_zkapp_command_unchecked_","apply_zkapp_command_unchecked","state_res","account_update_applied","update_timing_when_no_deductio","has_permission_to_receive$0","receiver_account_id","init_account","single_failure","no_failure","append_entry","apply_fee_transfer","transfer","failures","ft_with_status","modify_timing","modify_balance","ft2","ft1","account_id1","can_receive1","action1","account_id2","new_accounts1","can_receive2","action2","balance1","timing2","balance2","burned_tokens1","burned_tokens2","new_accounts2","can_receive","apply_coinbase","failures1","transferee_timing_prev","transferee_update","receiver_reward","receiver_id","coinbase_receiver_timing","receiver_balance","coinbase_with_status","new_receiver_timing","transferee","transferee_id","transferee_account","transferee_location","apply_transaction_first_pass","txn_state_view","applied","txn$0","partially_applied","apply_transaction_second_pass","applied$0","previous_hash$0","applied$1","previous_hash$1","apply_transactions","txns","min_init_balance","max_init_balance","num_accounts","num_transactions","mk_gen","num_transactions$0","init_ledger","nonces","receiver_is_new","gen_index","receiver_index","nonces$0","let_syntax_041","let_syntax_042","raise_error","raise_exn","json_parse","binary_string_to_base58_check","bin_string","binary_string_of_base58_check","base58","public_key_to_base58","public_key_of_base58","pk_base58","private_key_to_base58","sk","private_key_of_base58","sk_base58","token_id_to_base58","token_id_of_base58","memo_to_base58","memo_hash_base58","memo_base58","derive$1","derive_checked","deriver$31","body_deriver","of_json$0","hash_to_group","sign_field_element","is_mainnet","typ$63","account_update$1","transaction_commitments","tx_json","zkapp_public_input","account_update_index","pack_input$2","timing_input","permissions_input","update_input","account_precondition_input","network_precondition_input","body_input","ok_exn$0","hash_payment","command$0","hash_payment_v1","b58","serialize_common","serialize_payment","serialize_payment_v1","example_payment","hashPayment","hashPaymentV1","serializeCommon","serializePayment","serializePaymentV1","examplePayment","accountUpdate","transactionCommitments","zkappPublicInput","signFieldElement","dummySignature","deriveChecked","toBase58","ofBase58","publicKeyToBase58","publicKeyOfBase58","privateKeyToBase58","privateKeyOfBase58","tokenIdToBase58","tokenIdOfBase58","memoToBase58","memoHashBase58","test$1","class$1","get$19","location_of_account","set$16","next_location","get_or_create","get_or_create_account","create_new_account","remove_accounts_exn","ids","locs","empty$41","with_ledger","create_masked","default_token_id","account_id$0","create$109","deriver$32","last_action_slot_fun","zkapp_version_fun","zkapp_version_gen","last_action_slot_gen","compile_acc$13","compile_acc$14","compile_acc$15","compile_acc$16","zkapp_gen","transform","get_account","add_account","balance$0","bal_u64","deriver$33","apply_json_transaction","network_json","network_state","who","application_result","static_method","method","prototype","public_input_typ","statement_typ","input_size","output_size","inner_curve_typ","should_verifys_js","js_bool","should_verifys","public_output_size","statements","nat_modules_list","nat_add_modules_list","pickles_compile","max_proofs","to_js_provers","prove","js_prevs","public_output","previous_proofs_should_verify","previous_public_inputs","should_verifys$0","public_inputs$0","prevs$1","proof_to_base64","proof$1","proof_of_base64","dummy_base64_proof","dummy_verification_key","pickles","typ$64","size_in_fields","exists$12","exists_var","run_and_check$3","run_unchecked$3","constraint_system$3","add$35","scale$9","mul$3","read_var$0","assert_mul","assert_square$5","assert_boolean","compare$175","to_bits$3","from_bits","truncate_to_bits16","length_div_16","seal$2","and","or","equals","ec_add","scale$10","scalar_bits","of_js$0","verify$1","public_input_vec","get_vk","get_cs_json","update$8","hash_to_group$0","sponge_params_checked","sponge_create","is_checked","sponge_absorb","sponge_squeeze","existsVar","poseidon","hashToGroup","getVerificationKey","getConstraintSystemJSON","ecadd","assertEqual","readVar","assertMul","assertSquare","assertBoolean","toBits","fromBits","truncateToBits16","toConstantAndTerms","asProver","inProverBlock","runAndCheck","runUnchecked","constraintSystem","snarky","export$1","export_global","snarky_obj"],"sources":["","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/strftime.js","/home/soc/codes/o1-labs/mina/_opam/lib/base/runtime.js","/builtin/+ints.js","/builtin/+hash.js","/builtin/+ieee_754.js","/builtin/+int64.js","/builtin/+fail.js","/builtin/+stdlib.js","/builtin/+mlBytes.js","/builtin/+bigarray.js","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/overrides.js","/builtin/+marshal.js","/home/soc/codes/o1-labs/mina/_opam/lib/base/base_internalhash_types/runtime.js","/builtin/+nat.js","/builtin/+jslib.js","/home/soc/codes/o1-labs/mina/_opam/lib/base_bigstring/runtime.js","/builtin/+bigstring.js","/home/soc/codes/o1-labs/mina/_opam/lib/bigstringaf/runtime.js","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/runtime.js","/builtin/+array.js","/builtin/+backtrace.js","/workspace_root/src/lib/snarkyjs/src/bindings/kimchi/js/node_js/node_backend.js","/workspace_root/src/lib/snarkyjs/src/bindings/kimchi/js/bindings.js","/builtin/+compare.js","/builtin/+weak.js","/builtin/+gc.js","/builtin/+format.js","/builtin/+obj.js","/builtin/+fs_node.js","/builtin/+fs.js","/builtin/+unix.js","/builtin/+sys.js","/builtin/+fs_fake.js","/builtin/+io.js","/builtin/+lexing.js","/builtin/+md5.js","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/collector/runtime.js","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/runtime.js","/workspace_root/src/lib/promise/js/promise.js","/workspace_root/src/lib/integers_stubs_js/runtime.js","/home/soc/codes/o1-labs/mina/_opam/lib/zarith_stubs_js/biginteger.js","/home/soc/codes/o1-labs/mina/_opam/lib/zarith_stubs_js/runtime.js","/home/soc/codes/o1-labs/mina/_opam/lib/time_now/runtime.js","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/obj.ml","/workspace_root/src/lib/pickles/limb_vector/constant.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/int64.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/random.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/lexing.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalFormat.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/printexc.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/filename.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/exn.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/sign0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hex_lexer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/popcount.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int63_emul.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/backtrace.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_bench/runtime-lib/benchmark_accumulator.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/shape/bin_shape.ml","/home/soc/codes/o1-labs/mina/_opam/lib/stdio/in_channel.ml","/home/soc/codes/o1-labs/mina/_opam/lib/stdio/out_channel.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_module_timer/runtime/ppx_module_timer_runtime.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/std_internal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/collector/check_backtraces.ml","/home/soc/codes/o1-labs/mina/_opam/lib/splittable_random/splittable_random.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/positions.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/perms.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/quickcheck.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/std_internal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/span_float.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/tuple.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/digit_string_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/month.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/date0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/percent.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ofday_float.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/span_ns.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ofday_ns.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/gc.ml","/home/soc/codes/o1-labs/mina/_opam/lib/easy-format/easy_format.ml","/home/soc/codes/o1-labs/mina/_opam/lib/yojson/yojson.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bignum/bigint/bigint.ml","/workspace_root/src/lib/snarky/src/base/cvar.ml","/workspace_root/src/lib/snarky/src/base/constraint.ml","/workspace_root/src/lib/snarky/src/base/backend_extended.ml","/workspace_root/src/lib/snarky/src/base/checked_runner.ml","/workspace_root/src/lib/snarky/src/base/utils.ml","/workspace_root/src/lib/snarky/src/base/merkle_tree.ml","/workspace_root/src/lib/snarky/src/base/snark0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bigstringaf/bigstringaf.ml","/workspace_root/src/lib/pickles_types/shifted_value.ml","/workspace_root/src/lib/pickles_types/plonk_types.ml","/workspace_root/src/lib/pickles/pickles.ml","/workspace_root/src/lib/pickles_types/plonk_verification_key_evals.ml","/workspace_root/src/lib/snarky/sponge/sponge.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/tuple_pool/tuple_pool.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/validate.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/thread_pool_cpu_affinity/thread_pool_cpu_affinity.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/uopt/uopt.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/timing_wheel/timing_wheel.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/async_kernel_config.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/monitor.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/async_kernel.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_blake2b.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_blake2s.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/digestif.ml","/workspace_root/src/lib/hex/hex.ml","/workspace_root/src/lib/logger/fake/logger.ml","/workspace_root/src/lib/allocation_functor/table.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/scale_round.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/scalar_challenge.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/curve.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/plonk_dlog_proof.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/bigint.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/endoscale_round.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/endoscale_scalar_round.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/field.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/plonk_constraint_system.ml","/workspace_root/src/lib/snarky/fold_lib/fold.ml","/workspace_root/src/lib/snarky/snarkette/fields.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/vesta_based_plonk.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/pallas_based_plonk.ml","/workspace_root/src/lib/blake2/blake2.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_412.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/pprintast.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_413.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_414.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_411.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_410.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_409.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_408.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_407.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_406.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_405.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_404.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_403.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/ast_402.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_403_402.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast/versions.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/stdppx/stdppx.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/name.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalOO.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/deriving.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/environment.ml","/workspace_root/src/lib/random_oracle_input/random_oracle_input.ml","/workspace_root/src/lib/pickles_base/proofs_verified.ml","/workspace_root/src/lib/pickles_base/side_loaded_verification_key.ml","/workspace_root/src/lib/pickles_base/domain.ml","/workspace_root/src/lib/pickles/composition_types/branch_data.ml","/workspace_root/src/lib/pickles/composition_types/bulletproof_challenge.ml","/workspace_root/src/lib/pickles/composition_types/composition_types.ml","/workspace_root/src/lib/pickles/plonk_checks/scalars.ml","/workspace_root/src/lib/mina_version/normal/mina_version.ml","/workspace_root/src/lib/snarky/snarky_curve/snarky_curve.ml","/workspace_root/src/lib/snark_keys_header/snark_keys_header.ml","/workspace_root/src/lib/error_json/error_json.ml","/workspace_root/src/lib/pickles/wrap_wire_proof.ml","/workspace_root/src/lib/pickles/scalar_challenge.ml","/workspace_root/src/lib/pickles/impls.ml","/workspace_root/src/lib/pickles/plonk_curve_ops.ml","/workspace_root/src/lib/pickles/reduced_messages_for_next_proof_over_same_field.ml","/workspace_root/src/lib/pickles/step_main_inputs.ml","/workspace_root/src/lib/pickles/side_loaded_verification_key.ml","/workspace_root/src/lib/pickles/proof.ml","/workspace_root/src/lib/pickles/wrap_main_inputs.ml","/workspace_root/src/lib/pickles/wrap_verifier.ml","/workspace_root/src/lib/pickles_types/opt.ml","/workspace_root/src/lib/pickles/step_verifier.ml","/workspace_root/src/lib/pickles/proof_cache.ml","/workspace_root/src/lib/pickles/cache.ml","/workspace_root/src/lib/snark_params/snark_params.ml","/workspace_root/src/lib/random_oracle/permutation/external/random_oracle_permutation.ml","/workspace_root/src/lib/random_oracle/random_oracle.ml","/workspace_root/src/lib/non_zero_curve_point/non_zero_curve_point.ml","/workspace_root/src/lib/signature_lib/private_key.ml","/workspace_root/src/lib/signature_lib/schnorr.ml","/workspace_root/src/lib/signature_lib/keypair.ml","/workspace_root/src/lib/sgn/sgn.ml","/workspace_root/src/lib/sparse_ledger_lib/sparse_ledger.ml","/workspace_root/src/lib/rosetta_coding/coding.ml","/workspace_root/src/lib/ppx_dhall_type/deriving.ml","/workspace_root/src/lib/currency/signed_poly.ml","/workspace_root/src/lib/currency/currency.ml","/home/soc/codes/o1-labs/mina/_opam/lib/re/cset.ml","/home/soc/codes/o1-labs/mina/_opam/lib/graphql_parser/parser.ml","/home/soc/codes/o1-labs/mina/_opam/lib/graphql_parser/lexer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/graphql/graphql_schema.ml","/workspace_root/src/lib/fields_derivers/fields_derivers.ml","/workspace_root/src/lib/fields_derivers_graphql/fields_derivers_graphql.ml","/workspace_root/src/lib/fields_derivers_json/fields_derivers_json.ml","/workspace_root/src/lib/with_hash/with_hash.ml","/workspace_root/src/lib/fields_derivers_zkapps/fields_derivers_zkapps.ml","/workspace_root/src/lib/data_hash_lib/state_hash.ml","/workspace_root/src/lib/genesis_constants/genesis_constants.ml","/workspace_root/src/lib/block_time/block_time.ml","/workspace_root/src/lib/one_or_two/one_or_two.ml","/workspace_root/src/lib/mina_base/account_id.ml","/workspace_root/src/lib/mina_base/account_timing.ml","/workspace_root/src/lib/mina_base/signature.ml","/workspace_root/src/lib/mina_base/control.ml","/workspace_root/src/lib/mina_base/payment_payload.ml","/workspace_root/src/lib/mina_base/ledger_hash0.ml","/workspace_root/src/lib/mina_base/permissions.ml","/workspace_root/src/lib/mina_base/signed_command_memo.ml","/workspace_root/src/lib/mina_base/stake_delegation.ml","/workspace_root/src/lib/mina_base/transaction_status.ml","/workspace_root/src/lib/mina_base/transaction_union_tag.ml","/workspace_root/src/lib/mina_base/signed_command_payload.ml","/workspace_root/src/lib/mina_base/signed_command.ml","/workspace_root/src/lib/mina_base/receipt.ml","/workspace_root/src/lib/mina_base/state_body_hash.ml","/workspace_root/src/lib/mina_base/zkapp_basic.ml","/workspace_root/src/lib/mina_base/zkapp_account.ml","/workspace_root/src/lib/mina_base/account.ml","/workspace_root/src/lib/mina_base/epoch_ledger.ml","/workspace_root/src/lib/mina_base/epoch_seed.ml","/workspace_root/src/lib/mina_base/epoch_data.ml","/workspace_root/src/lib/mina_base/zkapp_precondition.ml","/workspace_root/src/lib/mina_base/data_as_hash.ml","/workspace_root/src/lib/mina_base/account_update.ml","/workspace_root/src/lib/mina_base/with_stack_hash.ml","/workspace_root/src/lib/mina_base/with_status.ml","/workspace_root/src/lib/mina_base/zkapp_command.ml","/workspace_root/src/lib/mina_base/user_command.ml","/workspace_root/src/lib/mina_base/fee_transfer.ml","/workspace_root/src/lib/mina_base/coinbase_fee_transfer.ml","/workspace_root/src/lib/mina_base/coinbase.ml","/workspace_root/src/lib/mina_base/pending_coinbase.ml","/workspace_root/src/lib/mina_base/staged_ledger_hash.ml","/workspace_root/src/lib/mina_base/sok_message.ml","/workspace_root/src/lib/mina_base/protocol_constants_checked.ml","/workspace_root/src/lib/mina_base/fee_with_prover.ml","/workspace_root/src/lib/transaction/transaction.ml","/workspace_root/src/lib/transaction/transaction_hash.ml","/workspace_root/src/lib/transaction_logic/mina_transaction_logic.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/consistency_test.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/pickles_bindings.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalFormatBasics.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalAtomic.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/stdlib.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/base.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/stdlib.mli","/home/soc/codes/o1-labs/mina/_opam/lib/base/int_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/float0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/pipe.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int_conversions.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/list.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/import.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/sys0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/write.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalLazy.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/lazy.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/seq.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/option.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/result.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/char.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/int.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/bytes.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/string.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/marshal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/int32.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/nativeint.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/parsing.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/set.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/map.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/stack.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/queue.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/buffer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/printf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_bigstring/base_bigstring.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/arg.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/fun.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/digest.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/random.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/hashtbl.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/attribute.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/format.ml","/home/soc/codes/o1-labs/mina/_opam/lib/re/fmt.ml","/home/soc/codes/o1-labs/mina/_opam/lib/re/pmark.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/scanf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/callback.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/camlinternalMod.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/bigarray.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib0/lazy_group_id.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib0/sexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib0/sexp_conv.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/ephemeron.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib0/sexp_conv_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/span_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/import0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/printf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/array0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/char0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/list0.ml","/workspace_root/src/lib/snarky/bitstring_lib/bitstring.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hash.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/ppx_compare_lib.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/string0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/sexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/sexpable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/word_size.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/pretty_printer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/core_kernel.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/with_return.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/monad.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/comparator.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/field.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/source_code_position0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/list1.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/result.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/container_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/container.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/lazy.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/monad_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/fn.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/list.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/ordering.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/applicative.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/info.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/invariant.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/maybe_bound.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/or_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/comparable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/identifiable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/comparable_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/unit.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/ordered_collection_common.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/binary_search.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/binary_searchable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/bytes0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/blit.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/option.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/either.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/indexed_container.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/sequence.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/obj_array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/uniform_array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/char.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/string.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/bytes.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/pow_overflow_bounds.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int_math.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/type_equal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/univ_map.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/option_array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/stack.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/set.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/set_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/queue.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/nothing.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/never_returns.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/nativeint.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/map.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/map_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int64.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/bool.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int32.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/int63.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hashtbl.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hashtbl_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hashable_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/avltree.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hash_set_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/hash_set.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/float.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/buffer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_assert/runtime-lib/runtime.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base/md5/md5_lib.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/common.ml","/workspace_root/src/lib/pickles_types/vector.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/read.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/shape.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/size.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/type_class.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/utils.ml","/home/soc/codes/o1-labs/mina/_opam/lib/bin_prot/std.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_inline_test/config/inline_test_config.ml","/home/soc/codes/o1-labs/mina/_opam/lib/time_now/time_now.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_inline_test/runtime-lib/runtime.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/typename.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/make_typename.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/variant_and_record_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/typerep_obj.ml","/home/soc/codes/o1-labs/mina/_opam/lib/typerep/type_abstract.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/common/file.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/collector/expect_test_collector.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/config_types/expect_test_config_types_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/config_types/expect_test_config_types.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_expect/config/expect_test_config.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/generator.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/bigarray_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/observer0.ml","/workspace_root/src/lib/pickles/opt_sponge.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/shrinker.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/test.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/observer.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/base_for_tests/test_blit.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/base_for_tests/test_binary_searchable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/parsexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/automaton_stack.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/of_sexp_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/parse_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/parser_automaton_internal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/parser_automaton.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/kind.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/automaton_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/parser.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/conv.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib/pre_sexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/parsexp/old_parser_cont_state.ml","/home/soc/codes/o1-labs/mina/_opam/lib/sexplib/conv.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/import.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/sexpable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/binable_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/binable0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/printf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/comparator.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/result.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/container.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/deprecate_pipe_bang.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/fn.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ordered_collection_common.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/sequence.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/source_code_position0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/info.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/t.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/list0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hashtbl.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hash_set.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/or_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/map.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/set.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/comparable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/doubly_linked_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/list.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/option.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/union_find.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/doubly_linked.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/bag.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/sexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hash_queue.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hashable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/identifiable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/bool.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hexdump_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/hexdump.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/string.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/bytes.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/char.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/core_pervasives.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/sign.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/float.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/int.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/int32.ml","/workspace_root/src/lib/unsigned_extended/unsigned_extended.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/int64.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/int63.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/unit.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/interfaces.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/lazy.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/nativeint.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/nothing.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ordering.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ref.ml","/workspace_root/src/lib/transaction_logic/zkapp_command_logic.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/byte_units0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/bigstring.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/core_bin_prot.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/md5.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/zone_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/binable.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/zone.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/source_code_position.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/validated.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/type_equal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/univ_map_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/unit_of_time.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/unique_id.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/uniform_array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/day_of_week.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/ofday_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/stable_internal.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/float_with_finite_only_serialization.ml","/workspace_root/src/lib/timeout_lib/timeout_lib.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time_float0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time_float.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time_ns.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/time_ns_alternate_sexp.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/set_once.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/heap_block.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/queue.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/option_array.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/memo.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/deque.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/debug.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/bag_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/integers/unsigned.ml","/home/soc/codes/o1-labs/mina/_opam/lib/biniou/bi_util.ml","/home/soc/codes/o1-labs/mina/_opam/lib/biniou/bi_outbuf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/biniou/bi_share.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_deriving_yojson/runtime/ppx_deriving_yojson_runtime.ml","/workspace_root/src/lib/crypto/kimchi_bindings/stubs/pasta_bindings.ml","/workspace_root/src/lib/snarky/tuple_lib/double.ml","/workspace_root/src/lib/snarky/tuple_lib/intf.ml","/workspace_root/src/lib/snarky/tuple_lib/four.ml","/workspace_root/src/lib/snarky/tuple_lib/quadruple.ml","/workspace_root/src/lib/snarky/tuple_lib/triple.ml","/workspace_root/src/lib/snarky/tuple_lib/tuple_lib.ml","/workspace_root/src/lib/snark_bits/bits.ml","/workspace_root/src/lib/snarky/interval_union/interval_union.ml","/workspace_root/src/lib/snarky/snarkette/nat.ml","/workspace_root/src/lib/snarky/src/base/handle.ml","/workspace_root/src/lib/snarky/src/base/monad_let.ml","/workspace_root/src/lib/snarky/src/base/request.ml","/workspace_root/src/lib/snarky/src/base/checked.ml","/workspace_root/src/lib/snarky/src/base/types.ml","/workspace_root/src/lib/snarky/src/base/as_prover0.ml","/workspace_root/src/lib/snarky/src/base/run_state.ml","/workspace_root/src/lib/snarky/src/base/checked_intf.ml","/workspace_root/src/lib/snarky/src/base/as_prover_ref.ml","/workspace_root/src/lib/snarky/src/base/boolean.ml","/workspace_root/src/lib/snarky/src/base/runners.ml","/workspace_root/src/lib/snarky/src/base/typ.ml","/workspace_root/src/lib/snarky/src/base/monad_sequence.ml","/workspace_root/src/lib/snarky/src/base/enumerable.ml","/workspace_root/src/lib/snarky/src/base/number.ml","/workspace_root/src/lib/snarky/src/base/snark.ml","/workspace_root/src/lib/ppx_version/runtime/shapes.ml","/home/soc/codes/o1-labs/mina/_opam/lib/angstrom/input.ml","/home/soc/codes/o1-labs/mina/_opam/lib/angstrom/parser.ml","/home/soc/codes/o1-labs/mina/_opam/lib/angstrom/angstrom.ml","/workspace_root/src/lib/logproc_lib/interpolator.ml","/workspace_root/src/lib/structured_log_events/structured_log_events.ml","/workspace_root/src/lib/pickles_types/nat.ml","/workspace_root/src/lib/pickles_types/hlist0.ml","/workspace_root/src/lib/mina_base/zkapp_state.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/basic/kimchi_pasta_basic.ml","/workspace_root/src/lib/pickles_types/hlist.ml","/workspace_root/src/lib/pickles_types/or_infinity.ml","/workspace_root/src/lib/pickles/plonk_checks/plonk_checks.ml","/workspace_root/src/lib/pickles_types/pcs_batch.ml","/workspace_root/src/lib/pickles_types/at_most.ml","/workspace_root/src/lib/crypto/kimchi_bindings/stubs/kimchi_bindings.ml","/workspace_root/src/lib/snarky/sponge/params.ml","/workspace_root/src/lib/snarky/sponge/constants.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/tuple_pool/tuple_type_intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/tuple_pool/tuple_type.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/pairing_heap/pairing_heap.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/sexp_hidden_in_test/sexp_hidden_in_test.ml","/home/soc/codes/o1-labs/mina/_opam/lib/core_kernel/thread_safe_queue/thread_safe_queue.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/time_ns.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/monitor0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/debug.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/import.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/priority.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/types.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/execution_context.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/job_queue.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/tracing.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/external_job.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/job_pool.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/job_or_event.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/scheduler0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/synchronous_time_source0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/scheduler1.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/scheduler.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/ivar0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred0.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/ivar.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/monad_sequence.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred1.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred_std.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/ivar_filler.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/tail.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/async_stream.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/synchronous_time_source.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/bvar.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/time_source.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/stack_or_counter.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/throttle.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/async_kernel_scheduler.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/clock_ns.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred_list.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred_result.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred_or_error.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred_queue.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/deferred.ml","/home/soc/codes/o1-labs/mina/_opam/.opam-switch/build/async_kernel.v0.14.0/_build/default/src/async_gc.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/digestif_bi.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/digestif_by.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/xor.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/digestif_conv.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_md5.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_rmd160.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha1.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha256.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha224.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha3.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha3_512.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha512.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha384.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha3_224.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha3_256.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_sha3_384.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/baijiu_whirlpool.ml","/home/soc/codes/o1-labs/mina/_opam/lib/digestif/ocaml/digestif_eq.ml","/home/soc/codes/o1-labs/mina/_opam/lib/eqaf/eqaf.ml","/workspace_root/src/lib/key_cache/key_cache.ml","/workspace_root/src/lib/allocation_functor/make.ml","/workspace_root/src/lib/promise/js/promise.ml","/workspace_root/src/lib/internal_tracing/context_logger/internal_tracing_context_logger.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/poly_comm.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/plonk_dlog_oracles.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/constants.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/dlog_plonk_based_keypair.ml","/workspace_root/src/lib/crypto/kimchi_backend/common/kimchi_backend_common.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/snarky_bindings.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/constraint_system/caml/vesta_constraint_system.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/constraint_system/caml/pallas_constraint_system.ml","/workspace_root/src/lib/crypto/kimchi_backend/pasta/kimchi_pasta.ml","/workspace_root/src/lib/mina_wire_types/block_time.ml","/workspace_root/src/lib/mina_wire_types/currency.ml","/workspace_root/src/lib/mina_wire_types/pickles/pickles_composition_types.ml","/workspace_root/src/lib/mina_wire_types/pickles/pickles.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_account_id.ml","/workspace_root/src/lib/mina_wire_types/mina_numbers.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_call_stack_digest.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_coinbase_fee_transfer.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_coinbase.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_fee_transfer.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_pending_coinbase.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_signed_command_memo.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_signed_command.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_sok_message.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_stack_frame.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_staged_ledger_hash.ml","/workspace_root/src/lib/mina_wire_types/mina_base/mina_base_zkapp_command.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast/ast_helper_lite.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/uchar.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/stdlib0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/location.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/code_matcher.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_414_413.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_413_414.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_413_412.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_412_413.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_412_411.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_411_412.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_411_410.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_410_411.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_410_409.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_409_410.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_409_408.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_408_409.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_408_407.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_407_408.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_407_406.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_406_407.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_406_405.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_405_406.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_405_404.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_404_405.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_404_403.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_403_404.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/astlib/migrate_402_403.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast/import.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast/ast.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppx_derivers/ppx_derivers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/traverse_builtins/ppxlib_traverse_builtins.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/longident.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/code_path.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/location.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast/location_error.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/expansion_context.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_traverse.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/spellcheck.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_pattern0.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_builder_generated.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_builder.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/caller_id.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/common.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_pattern_generated.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ast_pattern.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/extension.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/context_free.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/driver.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/merlin_helpers.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ppxlib/ignore_unused_warning.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/clause_syntax.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/field_syntax.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/ppx_shrinker_expander.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/ppx_generator_expander.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/ppx_observer_expander.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/expander/ppx_quickcheck_expander.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base_quickcheck/ppx_quickcheck/ppx_quickcheck.ml","/workspace_root/src/lib/crypto/kimchi_backend/kimchi_backend.ml","/workspace_root/src/lib/pickles/backend/backend.ml","/workspace_root/src/lib/snarky/group_map/bw19.ml","/workspace_root/src/lib/cache_dir/fake/cache_dir.ml","/workspace_root/src/lib/snarky/group_map/group_map.ml","/home/soc/codes/o1-labs/mina/_opam/lib/base64/base64.ml","/workspace_root/src/lib/snarky_group_map/checked_map.ml","/workspace_root/src/lib/snarky_group_map/snarky_group_map.ml","/workspace_root/src/lib/pickles/one_hot_vector/one_hot_vector.ml","/workspace_root/src/lib/pickles_base/domains.ml","/workspace_root/src/lib/pickles/limb_vector/make.ml","/workspace_root/src/lib/pickles/limb_vector/challenge.ml","/workspace_root/src/lib/pickles/composition_types/digest.ml","/workspace_root/src/lib/pickles/composition_types/spec.ml","/workspace_root/src/lib/pickles/pseudo/pseudo.ml","/workspace_root/src/lib/base58_check/version_bytes.ml","/workspace_root/src/lib/base58_check/base58_check.ml","/workspace_root/src/lib/codable/codable.ml","/workspace_root/src/lib/snarky_log/snarky_log.ml","/workspace_root/src/lib/pickles/import.ml","/workspace_root/src/lib/pickles/util.ml","/workspace_root/src/lib/pickles/endo.ml","/workspace_root/src/lib/pickles/common.ml","/workspace_root/src/lib/pickles/make_sponge.ml","/workspace_root/src/lib/pickles/tick_field_sponge.ml","/workspace_root/src/lib/pickles/dummy.ml","/workspace_root/src/lib/pickles/wrap_main.ml","/workspace_root/src/lib/pickles/commitment_lengths.ml","/workspace_root/src/lib/pickles/evaluation_lengths.ml","/workspace_root/src/lib/pickles/ro.ml","/workspace_root/src/lib/pickles/compile.ml","/workspace_root/src/lib/pickles/sponge_inputs.ml","/workspace_root/src/lib/pickles/tock_field_sponge.ml","/workspace_root/src/lib/pickles/wrap_hack.ml","/workspace_root/src/lib/pickles/wrap_proof.ml","/workspace_root/src/lib/pickles/tag.ml","/workspace_root/src/lib/pickles/inductive_rule.ml","/workspace_root/src/lib/pickles/types_map.ml","/workspace_root/src/lib/pickles/per_proof_witness.ml","/workspace_root/src/lib/pickles/unfinalized.ml","/workspace_root/src/lib/pickles/requests.ml","/workspace_root/src/lib/pickles/timer.ml","/workspace_root/src/lib/pickles/fix_domains.ml","/workspace_root/src/lib/pickles/verification_key.ml","/workspace_root/src/lib/pickles/wrap_domains.ml","/workspace_root/src/lib/pickles/wrap.ml","/workspace_root/src/lib/pickles/wrap_deferred_values.ml","/workspace_root/src/lib/pickles/verify.ml","/workspace_root/src/lib/pickles/step_main.ml","/workspace_root/src/lib/pickles/step_branch_data.ml","/workspace_root/src/lib/pickles/step.ml","/workspace_root/src/lib/pickles/dirty.ml","/workspace_root/src/lib/pickles/cache_handle.ml","/workspace_root/src/lib/crypto_params/group_map_params.ml","/workspace_root/src/lib/crypto_params/crypto_params.ml","/workspace_root/src/lib/bignum_bigint/bignum_bigint.ml","/workspace_root/src/lib/snarky_field_extensions/field_extensions.ml","/workspace_root/src/lib/snarky_curves/snarky_curves.ml","/workspace_root/src/lib/mina_stdlib/list.ml","/workspace_root/src/lib/mina_stdlib/result.ml","/workspace_root/src/lib/snark_bits/bits_intf.ml","/workspace_root/src/lib/snark_params/snark_util.ml","/workspace_root/src/lib/snark_params/snark_intf.ml","/workspace_root/src/lib/data_hash_lib/data_hash.ml","/workspace_root/src/lib/crypto/kimchi_bindings/pasta_fp_poseidon/kimchi_pasta_fp_poseidon.ml","/workspace_root/src/lib/hash_prefixes/hash_prefixes.ml","/home/soc/codes/o1-labs/mina/_opam/lib/js_of_ocaml-compiler/runtime/jsoo_runtime.ml","/home/soc/codes/o1-labs/mina/_opam/lib/js_of_ocaml/js.ml","/workspace_root/src/lib/hash_prefix_states/hash_prefix_create/js/hash_prefix_create.ml","/workspace_root/src/lib/hash_prefix_states/hash_prefix_states.ml","/workspace_root/src/lib/test_util/test_util.ml","/workspace_root/src/lib/non_zero_curve_point/compressed_poly.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/local_ledger.ml","/workspace_root/src/lib/signature_lib/public_key.ml","/workspace_root/src/lib/sparse_ledger_lib/inputs.ml","/workspace_root/src/lib/dummy_values/dummy_values.ml","/workspace_root/src/lib/unsigned_extended/intf.ml","/workspace_root/src/lib/mina_numbers/nat.ml","/workspace_root/src/lib/mina_numbers/intf.ml","/workspace_root/src/lib/mina_numbers/zkapp_version.ml","/workspace_root/src/lib/mina_numbers/account_nonce.ml","/workspace_root/src/lib/mina_numbers/global_slot_intf.ml","/workspace_root/src/lib/mina_numbers/global_slot_legacy.ml","/workspace_root/src/lib/mina_numbers/global_slot_span.ml","/workspace_root/src/lib/mina_numbers/global_slot.ml","/workspace_root/src/lib/mina_numbers/global_slot_since_genesis.ml","/workspace_root/src/lib/mina_numbers/global_slot_since_hard_fork.ml","/workspace_root/src/lib/mina_numbers/hd_index.ml","/workspace_root/src/lib/mina_numbers/index.ml","/workspace_root/src/lib/mina_numbers/length.ml","/workspace_root/src/lib/mina_numbers/mina_numbers.ml","/workspace_root/src/lib/currency/intf.ml","/home/soc/codes/o1-labs/mina/_opam/lib/re/core.ml","/home/soc/codes/o1-labs/mina/_opam/lib/graphql_parser/graphql_parser.ml","/workspace_root/src/lib/fields_derivers_zkapps/fields_derivers_js.ml","/workspace_root/src/lib/data_hash_lib/data_hash_intf.ml","/workspace_root/src/lib/block_time/intf.ml","/workspace_root/src/lib/quickcheck_lib/quickcheck_lib.ml","/workspace_root/src/lib/mina_base/util/mina_base_util.ml","/workspace_root/src/lib/mina_base/account_id_intf.ml","/workspace_root/src/lib/mina_base/hash_prefix.ml","/workspace_root/src/lib/mina_base/data_hash.ml","/workspace_root/src/lib/mina_base/token_id.ml","/workspace_root/src/lib/mina_base/fee_excess.ml","/workspace_root/src/lib/mina_base/ledger_hash_intf0.ml","/workspace_root/src/lib/mina_base/frozen_ledger_hash0.ml","/workspace_root/src/lib/mina_base/signed_command_memo_intf.ml","/workspace_root/src/lib/mina_base/transaction_union_payload.ml","/workspace_root/src/lib/mina_base/signed_command_intf.ml","/workspace_root/src/lib/mina_base/side_loaded_verification_key.ml","/workspace_root/src/lib/mina_base/state_hash.ml","/workspace_root/src/lib/mina_base/verification_key_wire.ml","/workspace_root/src/lib/mina_base/ledger_hash.ml","/workspace_root/src/lib/mina_base/ledger_hash_intf.ml","/workspace_root/src/lib/mina_base/frozen_ledger_hash.ml","/workspace_root/src/lib/mina_base/digest_intf.ml","/workspace_root/src/lib/mina_base/zkapp_statement.ml","/workspace_root/src/lib/mina_base/prover_value.ml","/workspace_root/src/lib/mina_base/zkapp_call_forest.ml","/workspace_root/src/lib/mina_base/fee_transfer_intf.ml","/workspace_root/src/lib/mina_base/coinbase_fee_transfer_intf.ml","/workspace_root/src/lib/mina_base/coinbase_intf.ml","/workspace_root/src/lib/mina_base/pending_coinbase_intf.ml","/workspace_root/src/lib/run_in_thread/fake/run_in_thread.ml","/workspace_root/src/lib/mina_base/staged_ledger_hash_intf.ml","/workspace_root/src/lib/mina_base/stack_frame.ml","/workspace_root/src/lib/mina_base/sparse_ledger_base.ml","/workspace_root/src/lib/mina_base/sok_message_intf.ml","/workspace_root/src/lib/mina_base/proof.ml","/workspace_root/src/lib/mina_base/pending_coinbase_witness.ml","/workspace_root/src/lib/mina_base/call_stack_digest_intf.ml","/workspace_root/src/lib/mina_base/call_stack_digest.ml","/workspace_root/src/lib/mina_base/ledger_intf.ml","/workspace_root/src/lib/mina_base/mina_base.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/util.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/lib/snarky_js_bindings_lib.ml","/workspace_root/src/lib/snarkyjs/src/bindings/ocaml/snarky_js_node.ml","/home/soc/codes/o1-labs/mina/_opam/lib/ocaml/std_exit.ml"],"mappings":"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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KCg4BPC;KACAC;;KC/WgBC;;;;;;;;;;;;;;KA0GVC;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA+HAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAGAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAoUgCC;;;;;;;;;;;;;;;;;;;;;;;;KAtjC5BC;KA9CZC;;KAIAC;;;;;;;;;;;;;KA+HAC;KCsyBEC;KACAC;KCGAC;KACAC;KCfAC;KACAC;KCDAC;KACAC;KCFAC;KACAC;KCUAC;KACAC;KCxFAC;KACAC;KCCAC;KACAC;KCpBAC;KACAC;KCHAC;KACAC;KCJAC;KACAC;KCrCAC;KACAC;KCmIIC;KA39BAC;;;;KCqYJC;KAOAC;KAOAC;KAOAC;KAOAC;KAOAC;KAOAC;KAOAC;KAOAC;KAOAC;;KAcAC;KAOAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KC/NEC;KAhJAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAuKWC;KC1KXC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KC2I8BC;KAANzvC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KC6c1B0vC;KAnKAC;;;;;;;;;;;;;;;;;;;;;;;;;;;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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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BAqnD;qB4LgJFmU;qBAGAD;qBAIAyC;qBACAD;;;qBG7CE5Z;qBAbAJ;qBA4CAM;qBAlBAD;qBH+CF2X;qBAmDAV;qBGlNMt7D;qBADAD;qBHgONw7D;;qBAIA6C;qBAIAC;qBAGAG;qBAGAD;qBAGAD;qBAMAe;qBAMAD;;qBlL1GE+nB;qByU6LIQ;kBTvXK;mBSmUqB;;;;;;;;uB7T9I1BroB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBZiBJ7H;uByU+LImwB;mBAlE0B;;;;uB7VvSb/2B;;;uByMiDjBxN;uBAaAM;uBzMjCExO;uBA7Beyb;uBoMyaf1jB;uBEjYI0mB;uBtMxCW9C;uByMHjBvwD;uBzMGiBswC;;;;;;uBoM6ZfI;uBADAD;uBpM5ZeG;;;;;;;;uBsMwCX2gB;;;;uBACAG;;;;;;;;;uBtMzCWS;;uBsM8CnBiB;uBtM9CmB/uF;uBCoDHC;uBDpDGC;;;;;;;uBsMqFnBivF;uBACAD;uBtMtFmBhB;;uBsM2FnBkB;uBtM3FmB5C;;;;;;uBsMiHX6C;;;;;uBtMjHW5zD;;;;;;;;uBUtBjBgnD;uBVsBiB4J;;;;uByMkGjBjN;uBAaAI;uBzM/GiBgP;;uByMyJjB7O;uBzMzJiBG;;;uBE6LJh6H;uBAAHF;uBF7LOumI;;;;;;;;;;uBoB0HjB+1B;uByU6PIe;mBAhF0B;;;;qBvJrQhCn7B;qBAIQ0B;;qBGkCNxK;qBAgBAG;;qBjLeF0I;qB4K0ZItf;;qBEzdIwf;qBG1CNhsD;qBH0CM8wC;;;;;;qBF6cJI;qBADAD;qBE5cIG;;;;;;;;qBoF+KE6a;;;;qBACAG;;;;;;;;;qBpF9KFS;;;;qBoBAQhtD;;qBpBWhBwuD;qBACAD;qBACAD;qBAGAM;qBAKAnB;;qBAsBAqB;qBACAD;qBACAR;qBACAb;qBAGAuB;qBA2CAxB;qBAEAD;qBACAD;;qBAWAD;qBAGAD;qBAtCQ6B;;;;;;;;qBAeRL;qBAMApB;qBAEAD;qBACAD;;qBAIAtG;qBAOAqG;qBAGAD;qBAIAuB;qBACAD;qBGhCE5K;qBAkBAC;q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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAgBAE;qBAhBAF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAwBAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAIAC;;;;;;;;;;qBAJAD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAWAE;;;;;;;;;;qBAXAF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAkBAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAIAC;;;;;;;;;;qBAJAD;;;;;;;qBAIAC;;;;;;qBAJAD;;;;;;;;;;;;;;;;;;;;;;;;;;qBAIAC;;;;;;qBAJAD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBAWAE;;;;;;;;;;qBAXAF;;;;;;;qBAWAE;;;;;;qBAXAF;;;;;;;;;;;;;;;;;;;;;;;;;;qBAWAE;;;;;;qBA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;;;;;;;;;;;;;;;;;;;qDpLgEJnzB;;;4BoLhEI;;;;;qEAU4B;;;wBAV5B,gDAU4B;;wBAV5B;;;;;;;;kDX1DyDozB;2BW0DzD;;;;;;;;6BvDkUJnxB;;;2BuDlUI;;;;;;;;;;;;oCvDkUJA,gBAjGAP;oCA0IAW;;;2BuD3WI;;;sDAU4B;;;;;wBAV5B;iCACE;;2BACA;;;2BACA;;iCACA;;2BACA;;;;;iC7LugBJvqC;;;2B6LtgBI;;;;;;;2BACA;;;;;;;;;;;kC7LqgBJA,ebveE8c;iCayYF5c;;;2B6LraI;;;;;oEAC0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAa5B,yBAAgD;;;;;;;;;;;;;;;;;uBXjFS+1D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wB;0BFIrD,oCACK;;;0DAA0B;4CAGA,gCAAiB;sBauH1D;;;;;;;;;;;;;;;;uBX/H+DkB;;;;;;;;;;;;;;;;;;;;;;;;uBW+H/D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBArHoC;;;;;;kBAwHZ;;kBpXjIpBv9B;kBI4HFsV;kBmUrIS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBnUoITD;kBJ5HEtV;kBqXVN;;kB9CEa;mB8CFb;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAIQ;wFAA0C;kBAIA;;kBrXG5CC;kBI4HFsV;kBADAD;kBJ5HEtV;kBsXRN;;kBAKG;;kBtXIGC;kBI4HFsV;kBADAD;kBJ5HEtV;kBuXVN;;kBhDEa;mBgDGb;;;;8C,gCAAgD;mBAAhD;0C;mBAAA;;sB,wCAAgD;mBAAhD;;sBrD6KE;mBqD7KF;;sB,O1D0aI4Q,+B0D1a4C;kBAAhD;kBhDHa;kBgDQX;;;;;;;;kBhDRW;;;sBgDiCX,oDAAuE;kBAMlB;;kBvX9BjD3Q;kBI4HFsV;kBADAD;kBJ5HEtV;kBwXVN;;kBjDEa;mBiDFb;;sBAwBiC,sDAA+B;mBAxBhE;;sBA4BmC,yDAAiC;mBA5BpE;;sBAgCmD;sEAAiC;mBAhCpF;;sBAoC4C;sEAAiC;mBApC7E;;sBAwCuC;sEAAiC;mBAxCxE;;sBA4CyC;sEAAiC;mBA5C1E;;sBAmDM;uFAGC;mBAtDP;;sBA0D0C;8EAA0C;mBA1DpF;;sBAiEM;8EAEC;mBAnEP;;sBAuE8C;8EAA0C;mBAvExF;;;sBA8EM;;;;;;;iCAIC;;mBAgBD;;;;;;;kC,sCAA8C;mBAA9C;;;;;;iFAA8C;mBAA9C;;;;;;6DAA8C;mBAA9C;;;;;;;;sBAQgB;oDAA8B,iCAAa,EAAC;;;sBAGlD;;uBACM,iB/L2LTL;uB+L5LG;sBACM;;wBACZ;0BAAgB;;;;2BACV;qCAEM,oBADF;0BAFM;;;sBAKlB,QAAC;;;;;;uBnESCvB;;;;;;;;;;;;;;;;;;;;uBHioBN4iC;uBAGE/kG;;;;;;;;;;;;wBsEzmB4B;iD,0BAAgC;;wBACpC,uCAAwC;;;0BAQnC,kBtE6lB/B+kG,gCsE7lBqE;;;wBAenE;yBtEzKF3rD;;;;;yBsEyKE;;;;;;;;;iD,6BAA2C;wBAA3C;;;;;qFAA2C;wBAA3C;;;;;iEAA2C;wBAA3C;;;;;;0BAQgB;wDAA8B,iCAAa,EAAC;;0BAGlD;wCtEskBVp5C;2BsErkBgB,iB/L6GT0jE;2B+L9GG;0BACM;;4BACZ;8BAAgB;;;;+BACV;;+BAGJ,0BtE1LRtqB;;+BsEwLgB;8BAFM;;;0BAUlB,QAAC;;;;;kCnE1EC+oB;;;;;;;;;8BHioBN4iC;8BAGE/kG;;;;;;;;;;;;8BGpoBIgiE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBHooBJhiE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBsEriBiC;;kBxXjNjCgkE;kBI4HFsV;kBmUrIS;;;;;;uBrB+vBPt5E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qBvF5dAqf;;;;;;;;;;;;;;;qB0FxKI2iD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBH+eR/D;;;;;;;;;;;;;;sBG/eQ+D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBjTSNqX;kBJ5HEtV;kByXVN;;kBlDEa;mBkDFb;;sBAmBqB;+BpEqLf/jE;wBCtD2B,sDAA8B;+BDsDzD8E;wBClD4B;wBA9ChC,UAEc,qCACF;wBA2CoB,MAzCxB;wBACR,qBAAyB,kBAAO;wBAAhC,QAwCgE;+BD+C9DigG;wBC5CuC;wBAtCzC,iBACiB;wBAqCwB,IAnCvC,aAAQ,iBAAe;wBACvB;;;4BACU;;6BAxFP,iBACE,oBAEH;oDAwFa,wBAA+D;wBAJ9E,QAkCoF;;wBmEnIpE,iBnEwCQ;+B/HobtBz6D,uCkM5d4C;;mDAQzB,2BAA0B;;;wBAe7C;;;;;;;;0BAaU;;2BACM,iBhM8OTo5B;2BgM/OG;0BACM;;4BACZ;8BAAQ;8BACR;8BADQ;;;0BAGV,QAAC;;;;;kCpE8DCvB;;;;;;;;8BAwEN4iC;8BAGE/kG;;;;;mBoExMN;;;;uBpEwMMA;;;;;;;;;;;;;;kBoE7G6D;;kBzXhF7DgkE;kBI4HFsV;kBmUrIS;;;;;uBlBsMPt5E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBjTlEFq5E;kBJ5HEtV;kB0XVN;;kBnDEa,ImDFb;kBAGA;;;;;;sC;;kBnDDa,ImDCb;kBAoBI;;;;;;sC;;kBnDrBS,ImDqBT;kBAOA;;;;;;sC;;kBAKD;;kB1XxBGC;kBI4HFsV;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0gEhE,sB,gBqCxkDHA;wBrCykDA;kEqCzkDAA,qB2C9bqD;;wBhF2gEjD,iCqC7kDJA;wBrC6kDI;;6CqC7kDJA;wBrC+kDyB,QgF1gEqC;;wBhF8gEhE,qBACE,gBqCplDAA,gBrColDyB;wBADhB;;qEqCnlDTA;uC2C1bgF;;wBhFkhE7D;iCqCxlDnBA,WrCwlDmB,+BqCxlDnBA,Y2CzbsE;;wBhFuhEtE;iCqC9lDAA,WrC8lDA,sBqC9lDAA,e2Cxb0E;;wBhF4hE1E;iCqCpmDAA;iCrComDA,uCqCpmDAA,e2CrbwD;;wBhF+hExD;iCqC1mDAA;iCrC0mDA,oCqC1mDAA,e2ClbkF;;wBACjE,kB3CibjBA,iB2Cjb4D;;wBhFm9D9D,qBACE,gBqCniDAA,gBrCmiDyB;wBADhB;0EqCliDTA,kB2Chb8E;;wBhFu9D3D;iCqCviDnBA,WrCuiDmB,8BqCviDnBA,Y2C/aoE;;wBAC3C,sB3C8azBA,mB2C9a4E;;wBhF29D5E;iCqC7iDAA,WrC6iDA,qBqC7iDAA,e2C7awE;;wBhFg+DxE;iCqCnjDAA;iCrCmjDA,sCqCnjDAA,e2C1auD;;wBhFm+DvD;iCqCzjDAA;iCrCyjDA,mCqCzjDAA,e2CvagF;;wBAC9D,kB3CsalBA,iB2Cta8D;;wBhFohE3C;iCqC9mDnBA;iCrC8mDmB,4CqC9mDnBA,Y2CnaoE;qDAG5C,wBAAsC;oD3C+ZtD+uC,QAAQC;wBAEpB;;oDADIhvC,WADQ+uC,QAAQC;;uD,OpCk3DhBl8B,UoCj3DA9S,mB2C7Z2D;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBA8J3D;;;;;kBpDzZO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wBoDqec,mCAAyB;;wBhFq1CV,0CgFl1C4B;;;0BASnC,oDAAsC;;;;0BhF21CrE,egFt1CE;0BhF0rBF;4BAG6C;qFAA8B;0BADnE;;8C/IlqCJvI,oB+IkqCyB;yCgF5rB8C;;;wBAlD3E;;;;;;;;;;;;;;;iD,6BAA2C;wBAA3C;;;;;qFAA2C;wBAA3C;;;;;iEAA2C;wBAA3C;;;;;;0BAUgB;wDAA8B,iCAAa,EAAC;;0BAG1D,kBAAoC,yBAAO;0BAnFrC;0BACP,qBACE;0BAFK;;4BAKF;yD;0BAAA,sBACO;0BACY,qBA4EgD;;;;;;;;;;;;;;wBhFwrDrE,8CgFr4DkD;6CAErC,WAAI;;wBACL,uB,mBAAuB;;wBhFqlDrC,sDgFplDqE;;wB;uChFwlDvE,2CgFvlDmD;;wBhF0nDnD,8CgFvnDoD;;wBhF6nDlD;yFgF1nDmE;;wBhF8nD/D;;;wBACqB,QgF9nDgB;;wB;;iChFmoD3C;yCgFloD6D;;wBhFqoDrB,kDgFpoDW;;wBhFuoD/C,4CgFtoDmD;;wBhF0oDnD;mCgFzoDmE;;wBhF6oDnE,0DgF5oD2D;;wBhFglDzD;;;wBACqB,QgFhlDU;;wB;uChFqlDrC,mDgFplDuD;;wBACpC,mCAA0B;;wBAxLrC,sCAyL+D;;wBhFwlDnE,yCgFvlD6C;;wBhF2lD7C,0DgF1lD6D;;wBhF8lD7D,uDgF7lDqD;;wBhFimDnD;;;wBAEqB,QgFlmDoB;0CAEjC,QAAC;6ChFwoDf,oCgFvoDyC;2ChF0oD1B,oBgFzoDU;yChF0oDZ,mBgFzoDQ;;wBACA,mCAA4B;;wBAC5B,mCAA4B;;wBACxB,uCAAgC;;wBhF6pDzD,+CgF5pD6D;;wBhFiqD7D,2CgFhqDiD;;wBhFoqDjD,oCgFnqD6C;6CAC3B,iCAAyB;;wBhF0qD3C;;;;gDAA8C,6BAAQ,EgFzqDX;;wBhF6qD3C,kDgF5qDyC;yChForDzC,gCgFnrDiC;2CAClB,+BAAsB;wChFyrDX,+BgFxrDK;4ChF+rD/B,mCgF1rDyC;;wBhFmsDzC,wCgF9rDqD;;wBhFksDjD,wCgFjsD6C;2ChFqsD7C,qCgFpsDmC;;wBhFwsDnC,oCgFvsDqC;;wBhF2sDrC,yCgF1sD2C;;wBhF8sD3C,wCgF7sD6C;;wBhFktD/C;;;;;sCgFjtDqD;;wBhFwtDrD;;;;;sCgFvtDmD;;wBhF8tDnD;;;;;sCgF7tDmD;;wBhFouDnD;;;;;sCgFnuDiD;;wBhF2uDjD;;;yCgF1uD+C;;wBhFivDjD,sCgFhvDyD;4ChFovDzD,oCgFnvDuC;;wBhF6vDvC,qDgFvvD6E;;wBhF2vD7E;qEgFxvDwD;;wBhFkwDpD,sCgF/vDqC;0ChF4wDf,iCgFjwDS;;wBhFowDnC,oDgFnwD6E;;wBhFwwD3E;;;kCgFrwD8C;;wBhF+wDhD,2DgF3wDqD;;wBhFqxDrD,8CgFlxDqE;;wBhFsxDrE,uCgFrxDmD;;wBACzC,uB,O/EopENob,0B+EppEuB;;wBACb;0BhFuxD+B,8CgFvxDV;2ChF0xDnC,8BgFzxDiC;;;wBhFmyDjC;;;;;mCgFhyDiF;;wBhFwyDhC,uCgFryD4B;;wBhFwyD7E,kDgFryDqD;;wBA1QC,kDA6QM;;wBAxT5D,gDAyToE;wDAlT3C,oBAmT8B;;wBAhTvD,kDAiTmE;;wBhF6wD7B,uCgF7nDuC;;;0BAQ5C,qCAAoC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BzF7bnEP;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kByF0lBH;;kB3XrqBGuV;kBI4HFsV;kBmUrIS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uB3B0BXyrB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBxS0GE1rB;kBJ5HEtV;kB4XVN;;kBrDEa;mBqDFb;sCtC0F0B,uCsC5DgD;mBA9B1E;;sBxC2NE,gBAAYylC;wBACO,IAAbrtD,WADMqtD;wBAKH,sB,UAJHrtD;wBAEF;yBADE7wH;0BACF;4BACE,4BAHA6wH;;;0CACA7wH,EAFMk+K,MAQI,CwCnMwD;mBAhC1E,0BAkDmD,wBAAe;mBAlDlE;;sBAqD6B;sBtEFL;;;mDsEEwC,4BtEFmB,EsEEC;mBArDpF;;sBAyDI,0BACE,4BAAmB;sBADM;qEACL;mBA1D1B;;sB,I5CgqBMrtD;6C4Clfe,U5CkffA,gB4ClfuC;;wBACL,mC5CiflCA,iB4Cjf6E;;wBAG/E,wC5C8eEA,iB4C9ekD;;wBvF0rCpD,qBAEkB,U2C9sBhBA,gB3C8sBoC;wBADpC,gC2C7sBAA;wB3C6sBA,+CuFxrCyD;;4CvFqqCV,U2C1rB/CA,iB4CteqC;;wBvFmqCnB,U2C7rBlBA,W3C6rBkB,W2C7rBlBA,sB4CreuC;0CAC3B,iB5CoeZA,a4CpeiC;;wBAzDf,U5C6hBlBA,W4C7hBkB,Y5C6hBlBA,c4CneyC;;wBAtDvB,U5CyhBlBA,W4CzhBkB,gB5CyhBlBA,c4CleiD;;wBvFwrC9B,U2CttBnBA,W3CstBmB,a2CttBnBA,e4CjemC;;wBvF2rCrC,4B2C1tBEA,c4CheuD;;wBvF8rCpC,U2C9tBnBA,W3C8tBmB,c2C9tBnBA,e4C/d+B;;wBvFksCxB,U2CnuBPA,W3CmuBO,oB2CnuBPA,e4C9d6C;;wBAGvC,gC5C2dNA,2B4C3dwD;oD5C0dhD2rC;wBAEZ,oCADI3rC,WADQ2rC;;uD,UACR3rC,mB4Cvd+D;;;;;;;;;;;;;;;;;;;mBAzMrE;kBAmUM;kBrDjUO;;;;;;;;;;;;;;;;;;;;;;;8CqDyYS,4BAAoB;4CvFwxBV,gCuFvxB2B;;;0BAQlC,wCAA4B;;;;0BvFsyBjD,euFlyB0B;0BvFsab;;8CzI5yBTvI,oByI4yB8B;yCuFtaiD;;0BAI/E;+CAAa,iBAAoC;;;wBAlDrD;;;;;;;;;0BAUgB,+BAAoB,wBAAK,EAAG;;0BAG1C,kBAAoC,yBAAO;0BA9ErC;0BACP,qBACE;0BAEH;4BAGQ;qCACE;qCACA,yBAA4B;0BAHpC,gCAAgB,2BAwEuD;;;;;;;;;;;;;4CAxKzD,YAA4B;+CvFggCiB,kCuF//Bf;yCvF8/BjC,kBuF7/Ba;2CvF+/BX,oBuF9/Be;6CvF+/Bf,kBuF9/Be;0CvF+/BhB,mBuF9/Bc;gDvF+/BV,qBuF9/BkB;0CvF+/BtB,mBuF9/Bc;gDvF+/BV,qBuF9/BkB;2CvF+/BvB,gBuF9/Ba;+CvF+/BT,oBuF9/BiB;0CACpB,mBAAc;2CvF+/Bb,oBuF9/Be;yCvF+/BhB,kBuF9/Bc;;wBvFihCiC,+CuFhhCf;2CvF8/B9B,oBuF7/BgB;4CvF8/Bf,qBuF7/BiB;0CvF8/BnB,mBuF7/Be;0CvF8/Bf,mBuF7/Be;yCvF8/BhB,kBuF7/Bc;6CvF8/BV,sBuF7/BkB;6CvF8/BlB,sBuF7/BkB;8CvF8/BhB,uBuF7/BoB;;wBvF8/Bd,uB,oCuF7/B0B;oDvF8/B1B,6BuF7/B0B;;wBACzB,iCAAsC;wCvF6/BZ,gCuF5/Bf;2CvF6/BqB,kCuF5/Bf;;wBvF6/BuB,sCuF5/Bf;;wBvF+/Bf,sCuF9/BmB;wCAC5C,4BAAwB;wCACxB,4BAAwB;2CACrB,+BAA2B;8CvFkgCiB,iCuFjgCf;8CvFkgCe,iCuFjgCf;6CvFkgCa,gCuFjgCf;;wBvFogCF,0CuFngCsB;;wBvFsgCX,sCuFrgCW;4CvFsgCH,mCuFrgCf;;wBvFsgCyB,oCuFrgCf;;wBvFwgChB,wCuFvgCoB;0CAC5C,8BAA0B;gDACtB,gCAA8B;;wBAC1B,oCAAkC;2CvFwgCC,kCuFvgCf;;wBvF0gCK,iDuFzgC6B;;wBvF6gC5E,4CuF1gCyD;;wBvF8gCpB,uCuF3gCmB;;wBvF8gC3B;4D,gBuF7gCiB;;wBvFghCN,0CuF/gCsB;;wBvFmhCzB,sCuFlhCmB;0CvFqhCD,iCuFphCf;wCvFqhC5B,iBuFphCY;;wBvFqhC6C,sCuFphCf;4CACxC,QAAC;0CACD,QAAC;;;wBvFwhCf;yFuFrhC4E;;wBvFwhC3B,uCuFrhCiC;;wBvFwhClF,kDuFrhC0D;;;wBvFyhC1D;;;;;;mCuFrhCqF;6C,iCAIzC;;wBvF6hC3B,oDuF1hC6C;;wBvFkiC7C;;;yBA5QX;wBADA;0EuFpxB8C;;;wBApQpD,gDAuQoE;wDAnQ/C,oBAoQkC;;wBAhQvD,kDAiQmE;gDA4I/C,8BAAoB;8CvF62BZ,6BuF52BkC;;;0BAS1D,2CAAoE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBA+IzE;;kB5X9jBGowB;kBI4HFsV;kBmUrIS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBnUoITD;kBJ5HEtV;kB6QVN;;kBAkEG;;kB7QvDGC;kBI4HFsV;kBADAD;kBJ5HEtV;kB6XVN;;kBtDEa;mBsDFb;oC;mBAAA;;;;;;;;uBhH2MW9uE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBgH3MX;;;;;;;;;uBhH2MWA;;;;;;;;;;;;;;;;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uDLt2B;kBJ5HEtV;kBwYVN;;kBjEEa;mBiEAb;;mBAA0C;oC;kBAAA;kBjEA7B;mBiEKP;;mBAAqC;oC;mBAAA,kBzE8EvCuR,c/HPArD;mBwMvEuC,kB3EwGvCsB;mB2ExGuC;;;qBzE8EvC+B;qB/HPArD;qB6HiCAsB;;;;;;mB2ExGuC;;;;qB3SqqBjC/nC;qB8D3eJxB;;;;;;;;;qB4B6CA2G;qBADAD;;;;;;;;;qBsFjBK+oB;;;;mB2HrNgC,qB;mBAAA;;;;kBAkBvC;kBAED;;kBxYhBGuK;kBI4HFsV;kBADAD;kBJ5HEtV;kByYKN;;kBAsHG;;kBzY1HGC;kBI4HFsV;kBADAD;kBJ5HEtV;kB0YVN;;kBAW4B,sBAAC,WjN8RhBH;kBiNzIV;;kB1YrJGI;kBI4HFsV;kBADAD;kBJ5HEtV;kB2YVN;;kBpEEa;mBoEWP;;mBAAmC;oC;mBAAA,kB5EkHrC6R,gB/HqCApD;mB2MvJqC,kB9E4QrCsB;mB8E5QqC;;;qB5EkHrC8B;qB/HqCApD;qB6HqHAsB;;;;;;qBtI+XE/iC;qBAaAtF;qBACAxB;;kBoNzpBmC;;qB5EkHrC2rC;qB/HqCApD;qB6HqHAsB;;;;;;qBtI4YEroC;qBAbAsF;qBAcA9G;;kBgJpqBO;mBoE4BT;;mBAAmC;oC;mBAAA,kB5EiGnC2rC,gB/HqCApD;mB2MtImC,kB9E2PnCsB;mB8E3PmC;;;qB5EiGnC8B;qB/HqCApD;qB6HqHAsB;;;;;;qBtI4YEroC;qBACAxB;qBsFreKqX;kB8HnK4B;;;qB5EiGnCs0B;qB/HqCApD;qB6HqHAsB;;;;;;qBtI4YEroC;qBsFpeK4V;qBtFqeLpX;;kBoNxoBiC;kBpE5B1B;mBoEyCP;;mBAAmC;oC;mBAAA,kB5EoFrC2rC,gB/HqCApD;mB2MzHqC,kB9E8OrCsB;mB8E9OqC;;;qB5EoFrC8B;qB/HqCApD;qB6HqHAsB;;;;;;mB8E9OqC;;;;qBpN0nBnCroC;qBACAxB;;;;;;;;;qBAbA+G;qBADAD;;;;;;;;;;;;qBsCroBF3iG;mB8KwBqC,2B;mBAAA;;;;;;;;;;;;;;;;sBAkBvC,0CAA6D;mBAlBtB;;sBAqCvC,sDAA4E;kBAK3D;;kB3Y1Eb41H;kBI4HFsV;kBADAD;kBJ5HEtV;kB4YVN;;kBrEEa;mBqEIT;;mBAA2C;oC;kBAAA;kBA4B+B;;kB5YvBxEC;kBI4HFsV;kBADAD;kBJ5HEtV;kB6YVN;;;kBtEEa;mBsEKP;;mBAAiC;oC;mBAAA,mB9EoGnCwR,c/HkBAlD;mB6MtHmC,mBhFuRnC0B;mBgFvRmC;;;qB9EoGnCwB;qB/HkBAlD;qB6HiKA0B;;;;;;mBgFvRmC;;qBlTa/BhzB;;;;;;;;;;;;;;;;;;;;;;;;;;mBkTb+B,qB;mBAAA;;;;;mBAgBnC;;mBAAiC;oC;mBAAA,mB9EoFjCw0B,c/HkBAlD;mB6MtGiC,mBhFuQjC0B;mBgFvQiC;;;qB9EoFjCwB;qB/HkBAlD;qB6HiKA0B;;;;;;;;qBhD7FO3yB;kBgI1K0B;;;qB9EoFjCm0B;qB/HkBAlD;qB6HiKA0B;;;;;;;qBhD7FO5yB;;;kBgItJiE;;kB7YhCtE6iB;kBI4HFsV;kBADAD;kBJ5HEtV;kB8YVN;;kBAauC;;kB9YFjCC;kBI4HFsV;kBADAD;kBJ5HEtV;kB+YVN;;kBxEEa;mBwEGT;;mBAI4D;oC;mBAAA,8BAJ5D,QAI4D;;;sBAJ5D;;;qEAI4D;;;;sBAJ5D,gDAI4D;;;sBAJ5D;;;+BACE,gBACA,iBACA,SAC0D;;;;kBxEPnD;mBwEOmD;;;;;;;;;;;;;;;;;;qBpZ2D1DhpB;qBAJAJ;qBAEAE;qBACAC;qBAJAJ;qBAEAE;qBAOAO;qBADAD;qBAGAG;qBADAD;qBAJAJ;qBACAC;;;;;;;;;mBoZ7D0D,2B;mBAAA;;;kBAMlB;;kB/YJxC+oB;kBI4HFsV;kBADAD;kBJ5HEtV;kBgZVN;;kBzEEa;mByEuBX;;mBAA2C;oC;mBAAA,mBjF0GzC8R,e/HuDAnD;mBgNjKyC,mBnFkSzCuB;mBmFlSyC;;;;;;;;;uBjF0GzC4B;uB/HuDAnD;uB6HiIAuB;;;;;;;uBtIQEpjC;uBAcAgyB;;mByNxTuC;;;;;uBjF0GzCgT;uB/HuDAnD;uB6HiIAuB;;;;;;uBtIQEpjC;;uBAcAgyB;;mByNxTuC;;;;;;;;;qBzN2SvC/xB;qBADAD;;;mByN1SuC;;sB;;wBA4BlB,+CAAyC;6CAC9C,kBAAO;;wBACR,oDAAkB;;wBACd,8CAAyC;6CAC7C,oBAAM;6CACD,wBAAQ;;wBAGpB;wBACR;;oEAIM;;;;;;;;;;kBAiBV;kBAmCkE;;kBhZ3G9DmzB;kBI4HFsV;kBADAD;kBJ5HEtV;kBiZVN;;kB1EEa;mB0EKP;;mBAA4C;oC;mBAAA,mBlFqG9CyR,a/HwBAlD;mBiN7H8C,mBpF8R9C0B;mBoF9R8C;;;qBlFqG9CwB;qB/HwBAlD;qB6HiKA0B;;;;;;;qBtIkFEtoC;qBb9QEwb;qBenCEb;kB8IpEG;mB0EgBP;;mBAAgC;oC;mBAAA,mBlF0FlCmvB,a/HwBAlD;mBiNlHkC,mBpFmRlC0B;mBoFnRkC;;;qBlF0FlCwB;qB/HwBAlD;qB6HiKA0B;;;;;;mBoFnRkC;;qBrPA9BpgC;;qB2BqWFlI;qBb9QEwb;;qBkBhFJ9xD;qB6CsIEw5C;qBAJAJ;qBAEAE;qBACAC;qBAJAJ;qBAEAE;qBAOAM;;qBAEAE;qBADAD;qBAHAH;qBACAC;;;;qBhD5FIuX;;;;;mBwNpD4B,qB;mBAAA;;;;;;;;;;;;;;;;;;;kBAWpC;kBAS4E;;kBjZ3BxE2d;kBI4HFsV;kBmUrIS;;;qB9F6JP1qC;qBAJAJ;qBAEAE;qBACAC;qBAJAJ;qBAEAE;qBAOAM;;qBAEAE;qBADAD;kBrO9BFqqC;kBJ5HEtV;kBkZVN;;kB3EEa;mB2EGP;;mBAAkC;oC;mBAAA,mBnFwIpC+R;mBmFxIoC,mBrFgUpC5B;mBqFhUoC;;;qBnFwIpC4B;;qBFwLA5B;;;;;;mBqFhUoC;;;qBvYoHtCta;qB4KsSIjuB;qBEzVIyxB;;qBG5CNx+D;qBH4CM48D;;;;;;qBF6UJS;qBADAnC;qBE5UIiC;;qBF4UJjC;qBE5UIgC;;;;;;;;;mByNjE8B,qB;mBAAA;;;;;;;kBAUtC;kBAS8E;;kBlZb1EkI;kBI4HFsV;kBADAD;kBJ5HEtV;kBoZVN;;kB7EEa;mB6EGP;;mBAAkC;oC;mBAAA,mBrFgJpCgS;mBqFhJoC,mBvFiVpC5B;mBuFjVoC;;;qBrFgJpC4B;;qBFiMA5B;;;;;;mBuFjVoC;;qBjasDlCtgC;qBA7Beyb;qBoMyaf1jB;qBEjYI0mB;qBtMxCW9C;qByMHjBvwD;qBzMGiBswC;;;;;;qBoM6ZfI;qBADAD;qBpM5ZeG;;;;;;;;qBsMwCX2gB;;;;mB2NjE8B,qB;mBAAA;;;;;;kB7EH3B,I9IuEHihD;kB2NpE8B;kBAUtC;kBAS8E;;kBpZb1EztC;kBI4HFsV;kBADAD;kBJ5HEtV;kBqZVN;;kB9EEa;mB8EFb;;;;qBFuFUstC;;;;mBEvFV,2B;mBAAA;;;;;;;;;;qB5CUiEK;;;;;;;;mB4CVjE;;sBAkBM;;;gC3OuFEb;;;;;;;yC2OpFsD;mBAGvB;;;;;;;;;;;;;;;;;;;;;;kB9EtB1B;mB8EsB0B;;;;;;;;;;;;qBlY+J/B7yC;;;;;;;;;;;;;;;;;;;;;;;;;;mBkY/J+B,qB;mBAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAmDrC;kBAS8E;;kBrZzE1EgG;kBI4HFsV;kBADAD;kBJ5HEtV;kBsZVN;;kB/EEa;mB+EIP;;mBAAgD;oC;mBAAA;;;sBAOhD;;kFACgD;wB3EqRhDge;;;;;;;;;;;;;;;;;;kBJjSO;mB+EsBP;;mBAAiC;oC;mBAAA,mBvF4DnC1M,c/HbArD;mBsN/CmC,mBzF+EnCqB;mByF/EmC;;;qBvF4DnCgC;qB/HbArD;qB6HgCAqB;;;;;;mByF/EmC;;;;;;;;;;;;;;;;;;;;;;;;;;;;wC;mBAAA;;;;;;kBAapB;;kBtZ1BbrP;kBI4HFsV;kBADAD;kBJ5HEtV;kBuZRN;;kBAwByB;;kBvZfnBC;kBI4HFsV;kBADAD;kBJ5HEtV;kBwZVN;;kBjFEa;mBiFIT;;8C,gCAAwD;kBAAxD;kBAW2B;;kBxZNzBC;kBI4HFsV;kBADAD;kBJ5HEtV;kByZVN;;kBlFEa;mBkFGP;;mBAAsC;oC;mBAAA;sC5FoWxCqQ;mB4FpWwC;;;;;qB5FoWxCA;;;;;;mB4FpWwC;;;qB9YgI1CjpB;qB4K0ZItf;;qBEzdIwf;qBG1CNhsD;qBH0CM8wC;;;;;;qBF6cJI;qBADAD;qBE5cIG;;;;;;;;qBoF+KE6a;;;;mB4IhPgC;oC;kBAAA;;kBAU1C;kBASkF;;kBzZb9E0Y;kBI4HFsV;kBADAD;kBJ5HEtV;kB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8xC;kBAKF,0BAPEC;kBA+KuD;;kB/Z9KvD9xC;kBI4HFsV;kBADAD;kBJ5HEtV;kBgaVN;;kBAqDG;;kBha1CGC;kBI4HFsV;kBADAD;kBJ5HEtV;kBiaVN;;kB1FEa;mB0FFb;gCAGoB,kBrP4BZksC,aqP5BY,UAA+B;mBAHnD;gCAIoB,6BrP2BZD,gBqP3B+C;mBAJvD;sC,kBrP+BQI,uBqPxB0D;mBAPlE,oB,4BAQwC;mBARxC,yB,kBrP+BQH,eqPdgD;mBAjBxD;;sBAkBwC,gCrPahCD,gBqPboD;mBAlB5D;;;;;wB/QoBMJ;;;;;;mB+QpBN;;;;;;;;;kB1FEa;mB0FFb,qBAqDwB,kBAAgB;mBArDxC,0BxSuRMoG;mBwSvRN;;;;uBxSuRMA;;;;mBwSvRN;kBAwImE;;kBja7H7DhyC;kBI4HFsV;kBADAD;kBJ5HEtV;kBkaRN;;kBAmIG;;kBla1HGC;kBI4HFsV;kBADAD;kBJ5HEtV;kBmaVN;;kB5FEa;mB4FFb;;sBAKwC,iC9MmKpCyrB,yB8MnKgE;mBALpE;;sBAMwC,kB9MoKpCD,iB8MpKoC,oBAAkB;kBAOW;;kBnaF/DvrB;kBI4HFsV;kBADAD;kBJ5HEtV;kBoaAN;;kB7FRa,kC6FQb;kB/LqHM/4B;;;;sB;wDzDhGEilE;;;kB2J7BK;mB6FuBDiG;mBAIAC;6BAAY7qL;sBAAI,sDAAJA,EAAW;mBAUvB8qL,4BAAsB,SAAE;2BAVxBD,YAUAC;;;;qB1PkEJvF;;;;8C;mB8LwBuDwF;2B4DpGnDF,YAUAC;2B7OgVN1qE,Yb9QEwb;mC;kB6JvGK;mB6F2DL;;;;;;;;;;qCP8IG2rD,mBlZxCXwC;;mByZtGQ;mBAKyB;oC,UALzBiB;mBAYA;;;;;;;8DzZ0FRlD;;mByZ1FQ;mBAIyB;oC,UAJzBoD;mBAQA;;;;;;;8DApBKD;;mBAoBL;mBAIyB;oC,UAJzBG;;;6B5DgDuDL;;8B4DpElDE;iCzZsGbhD,iByZ1FakD;mCzZ0FbrE,kByZlFauE;mCzZkFbrC;kByZ3EM;;;;;;;;gCzZ2ENe;;;kB4TjKa;mB6FiGkB;6BAGbl5G,GAAGF,IAAK,kBxPvElBk0G,WwPuEUh0G,MAAGF,MAAmC;mB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;kDAZJypN;4BA+BI;6BA+BR,4BAjCEJ;6BAiCF,2BAIExvR,GAFoB,OAEpBA,SAAqB;6BAItB,0BAdC6vR;6BAgBC,wBA5CyBN;6BA4CzB;;;8BAHH9vR;;iD2IkUAggH,axLjeFi5B,a6C+JEj5I;;;;;;uC2IkUAggH,aXndE2lE,ahIiJF1rG;;;4BAtCQ,IAiDW8mC,W2IkInBJ,Y3ItLYxhF;qCAoDO4hF;;;;;0BAGnB,8BAAa;sBAuR6D;;sB5C1c1E24B;sBI4HFsV;sBADAD;sBJ5HEtV;sB6gBVN;;sBAwQiB;;sB7gB7PXC;sBI4HFsV;sBADAD;sBJ5HEtV;sB8gBVN;;sBAGsC;;sB9gBQhCC;sBI4HFsV;sBADAD;sBJ5HEtV;sB+gBVN;;sBAkDsB;;sB/gBvChBC;sBI4HFsV;sBADAD;sBJ5HEtV;sBghBVN;;sB/E+EoB,I+EqEO56C,aAahB3lF,QAAS,cAATA,SAA4B;sBA4Xf;;sBhhBlhBlBwgI;sBI4HFsV;sBADAD;sBJ5HEtV;sBihBVN;;sBAiDQ;;sBjhBtCFC;sBI4HFsV;sBADAD;sBJ5HEtV;sBkhBVN;;sBA4U8E;;sBlhBjUxEC;sBI4HFsV;sBADAD;sBJ5HEtV;sBogBVN;;sBAsB6B;sBnEyDT;;iCmE5BOv3B;0BQnBF,0BCwBf,ETJW1vC;0BACjB,SAxByB/xE;4BAyBrB,eQXKw5E;8BACA,sBAREj6E,KAOFi6E,IACPxL;iCAVyB,URkBV+D;;;+BQfsD,ORetDA,QQhBNxyE;8BRgBMwyE,UQRf/D;sCRUsE;4BAApE,OAHmByzC;4BAGnB;oCAAoG;0BAzB3E,aAAJzhH,EAsBFyhH;iCSKrBlhH,CTFyG;sBA4Q5G;;sBpgBvTG04I;sBI4HFsV;sBADAD;sBJ5HEtV;sBmhBVN;;sBAmB6B,uBAAuB;sBAmC1B;;sBnhB3CpBC;sBI4HFsV;sBADAD;sBJ5HEtV;sBohBVN;;sBA4DG;;sBphBjDGC;sBI4HFsV;sBADAD;sBJ5HEtV;sBqhBVN;;sBAoGuD;;sBrhBzFjDC;sBI4HFsV;sBADAD;sBJ5HEtV;sBshBVN;;sBrF+EoB;uBqF/EpB,mBAmBe97I,GAAI,oBAAJA,GAA0B;uBAnBz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EACApH,EAlBFygS,KAQArzL,GAyEoB;4BACtB,MAhEIptG,EACA8W,EAJAhT,EACAC,EACAqD,EAjBFq5R,KAQArzL,GA0EoB;4BACtB,MAlEIhmG,EACApH,EACA8W,EAJAhT,EACAC,EAhBF08R,KAQArzL,GA2EoB;4BACtB,MApEIrpG,EACAqD,EACApH,EACA8W,EAJAhT,EAfF28R,KAQArzL,GA4EoB;4BACtB,MAtEItpG,EACAC,EACAqD,EACApH,EACA8W,EAnBF2pR,KAQArzL,GA6EoB;4BACtB,MAnEIt2F,EAJAhT,EACAC,EACAqD,EACApH,EAlBFygS,KAQArzL,GA8EoB;4BACtB,MArEIptG,EACA8W,EAJAhT,EACAC,EACAqD,EAjBFq5R,KAQArzL,GA+EoB;4BACtB,MAvEIhmG,EACApH,EACA8W,EAJAhT,EACAC,EAhBF08R,KAQArzL,GAgFoB;4BACtB,MAzEIrpG,EACAqD,EACApH,EACA8W,EAJAhT,EAfF28R,KAQArzL,GAiFoB;4BACtB,MA3EItpG,EACAC,EACAqD,EACApH,EACA8W,EAnBF2pR,KAQArzL,GAkFoB;4BACtB,MAxEIt2F,EAJAhT,EACAC,EACAqD,EACApH,EAlBFygS,KAQArzL,GAmFoB;4BACtB,MA1EIptG,EACA8W,EAJAhT,EACAC,EACAqD,EAjBFq5R,KAQArzL,GAoFoB;4BACtB,MA5EIhmG,EACApH,EACA8W,EAJAhT,EACAC,EAhBF08R,KAQArzL,GAqFoB;4BACtB,MA9EIrpG,EACAqD,EACApH,EACA8W,EAJAhT,EAfF28R,KAQArzL,GAsFoB;4BACtB,MAhFItpG,EACAC,EACAqD,EACApH,EACA8W,EAnBF2pR,KAQArzL,GAuFoB;4BACtB,MA7EIt2F,EAJAhT,EACAC,EACAqD,EACApH,EAlBFygS,KAQArzL,GAwFoB;4BACtB,MA/EIptG,EACA8W,EAJAhT,EACAC,EACAqD,EAjBFq5R,KAQArzL,GAyFoB;4BACtB,MAjFIhmG,EACApH,EACA8W,EAJAhT,EACAC,EAhBF08R,KAQArzL,GA0FoB;4BACtB,MAnFIrpG,EACAqD,EACApH,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AG,OqJvpCJ/xL,oBrJupCI+rL;mEACA+F;6BAFAG;;gCqcr0CFlrD;gD,OhT+KF/mI;gCrJspCI8rL;mEACAkG;6BA4DAG,UA7DAD;6BA6DAE,sCACAX;sCADAW;mCqB7vCFjtH;qCrB4vCFmtH,cqBzvCMriL;8B,OATN86K,kCASM96K;;;;mCAHJxsH;;6BrB+rCF8uS;;gCqcp0CE7rD;yCrcq0CWz2H,S,OwE/1Cf89H,sBxE+1Ce99H;gCqBhsCXoiL;;6BrB+rCFG,OwE91CFzkD,sBxE81CEwkD;oCwE91CFxkD,sBxE81CEykD;;6BA5IEE;;gCqJppBF9qL;yCrJoyBaw6I;2CAxDX+J,YAwDWl8I;oC,OwEl2Cf89H,sBxEk2Ce99H;;mCAxDXA,IwE1yCJ89H,gBxE0yCIoe,YAwDW/J;mCAxDXtqF,sBAwDWr0K;oDqJpyBbmkH,iBrJ4uBEukJ,kBAwDW1oQ;gCAJbgvS;;mCqB/rCEhvS;;;6BrBmjCAkvS;8BwEltCJ5kD;yCxEmtCc99H;;;;;;;gCADVyiL;;;;;6BAsBFK,wBAtBED;;qCA7vBF3wC,YAqxBalyI;;;;qCAiLbqiL,cAjLariL;qCAiLbqiL,cAjLax6H;;;6BArxBb7nD,eqc3bEy2H,erc2bFyb,YAmxBA4wC;6BAnxBAj7H,iBqc3bE4uE,erc2bFyb;;8C0R0Ha3e,e1R1Hb2e;;;;;;;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;;;gC0RqGa9f;yC1RlFOpyH;kC,kBqJsFpBrI,iBrJzGAu6I,YAmBoBlyI;gCAnBpBkzI;;;yCqJyGAv7I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;;yCqJyGAv6I,iBrJzGAu6I;6BAmxBAuB;yCqJ1qBA97I,iBrJzGAu6I;oDAmxBAuB;mCqBzkCE7uK;4B,IAAAo7B,IwLcFlH;;qCxLdEo8D,qBAK+C;mCAL/Cx1G;4BAIE,SrBwvCJ+8N,QqB3vCMhyH;+EAAoB;4BrB4vCR,GqB7vChB6xE,gBrB6vCgB;sCqB7vChBD,SrB6vCgB,MqB7vChBC;4BrB6vCgB,SA9DlBogD,QA8DeqG,wCAAE;4BA7DgC;;;;;;;;kC0RjtBpCrsD;2C1RitBAusD;oCAAG;sDAAHE,wCAAE;6CAAFF;mDAAmC;;;;8BAAC;gCACjC;;;;;6CAAHI,wCAAE;;;gCAAC;kCACA;;;;;+CAAHE,wCAAE;;;kCAAC;;;;;sCvBnsCtBjpH;iDuBosCmBmpH;0CAAoC,SAxD/CjoC,MAwDWmoC;4CAAG;8DAAHE,wCAAE;qDAAFF;2DAAmC;0CAxDpB,GAwDfF,gBAxDe;;iDAwDfC;2CAxDe,MAwDfD;2CAxDe;;uDAAHM,sCAAE;;;0CAAC;4CAAgB,gBAwD/BN;4CAxD+B;wDAwD/BC;qDvBpsCnBppH;gEuB4oCgE2pH,sCAAE;;;4CAAhB;;;sDAwDuB;;;;;;;;;;8BkJx1BjE;;;qC7H3WA5nD;;+BrBykCF8hD;yCqBtkCM0B;kCAAe;oDAAfE;2FAAc;2CAAdF;iDrB2vCuB;+BArL7BzB;yCqBvkCMzzH;gFrB4vCiB;8BApLD;;;;+CAALw5H,yCAAG;+BAAE,eAoLNE,wCApLD;8BAtBM;;;;;;;;6CAATE;;;;;;;mDADV/oC,MACUipC,kBAAO;;;;gCAAE;kCACT;;oCACA;;sCACE;;kDAJZjpC;;;;;;;;;;;;;;iCA7vBFlsH;2CAqxBau1J;;;;;;;iDAFb1G,QAEa4G,kBAAW;gCApxBb;;;;;;;;sC0RwLEruD;+C1RxLLj8D,sCAAE;;;;kCAAC;oCACW;;;;;wC0RuLTi8D;iD1RvLMyuD,sCAAE;;;oCAAC;sCACd;;wCACG;;;;;4C0RsHE3xD;qD1RtHL6xD,sCAAE;;;wCAAC;0CACY;;4CACC;;8CACI;;gDACT;;kDACC;;oDACU;;sDACC;;;;;mEAAHE,sCAAE;;;sDAAC;wDACA;;;;;qEAAHE,sCAAE;;;wDAAC;0DACK;;;;;uEAAHE,sCAAE;;;0DAAC;4DACA;;;;;yEAAHE,sCAAE;;;4DAAC;8DACd;;;;;2EAAHE,sCAAE;;;8DAAC;gEACA;;;;;6EAAHE,sCAAE;;;gEAAC;kEACM;;;;;+EAAHE,sCAAE;;;kEAAC;oEACN;;;;;iFAAHE,sCAAE;;;oEAAC;sEACQ;;;;;0E0RkFjBh0D;mF1RlFOk0D;4EAAG;8FAAHE,sCAAE;qFAAFF;2FAAS;;;sEAAC;wEACA;;;;;qFAAHI,sCAAE;;;wEAAC;0EACS;;;;;uFAAHE,sCAAE;;;0EAAC;4EACV;;;;;yFAAHE,sCAAE;;;4EAAC;8EACQ;;;;;2FAAHE,sCAAE;;;8EAAC;gFACA;;;;;6FAAHE,sCAAE;;;gFAAC;;;;;oFvB/U3C7sH;+FuBgV8C+sH,sCAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gDA0vB1CjJ;;;;;wCqBrkC+C;0BAGpC,IAALhpR,GAAK;mCAWLmyR,YAAYz2S,EAAGR,EAAGu0B,SAAU2iR;4BAAa,kBAA1Bl3S,EAA0B,WAA7BQ,EAAM+zB,SAAU2iR,UAAoC;0BAX3D,SAaLzlJ,SAAQl9H,SAAU2iR;4BACpB,UADU3iR,SAAU2iR,SAEE;0BAff;;;6BARXxzD;;;6BACOrvE;6BADPC;;;6BACEmB;;;;6BADFy2H;6BACEthD;;;;;;;6BAOI9lO;6BAWAmyR;6BAEAxlJ;2BAbK;;;;;;;;;;;;;;;;;;;;;;2Bwf/Hfx8E;mCxfsJUw+F,WwfvLOt5J,IAAKouI;4BACU;4DADfpuI,IAAKouI,SACqC;mCxfsLjDorB,awfpLWx5J,IAAKouI,QAAQxtJ;4BACF;4DADXof,IAAKouI,QAAQxtJ,GAC+B;;2BxfmLvD64K;oCwf9LRb,2Bxf8LQa;;2BwftKRoG;;;2BAOAikE;;mCxfmKMk5D,mBAjCE,YAAoB;0BAF1B;0Cwf/JFpkI;0Bxf+JE;;;;;;;;;;;;;6BwfvHJ99F;6BAxCEqgG;;6Bxf8LQ7B;;6Bwf9LRV;;6Bxf8LQa;;6BwftKRoG;;6BAOAikE;;6BxfmKMk5D;2BAnCJ;mCAwCFzyD,YrB6tCFxmJ;4BqB7tCW,SrB6tCXusM,SqB7tC8BztS;;;6FAAI,EAAJA,IAAU;4BAA7B,SrB6tCXutQ,QqB7tCwBvtQ,gCAAI;4BAAjB,SrB6tCX0tS,SqB7tCY1tS,mCAAU;4BrB6tCtB;;6BAxLQ;6BAwLR;6BAxLQ;6BAHJqhO;;;;;;;sCAEa,gCAFb;mFAEwB;;+BAFxB7H;;;;gEA2LJk0E;+BA3LIrsE;6BA2LJm7B,mCA3LIf,WA2LJa;;6BA3DA;;4BAIa;;;;4CAJb,+BA2DAoxC,UAvDa1tS,EAAyB;+BA7DpC,MA6DW+gG;+BA7DX;8BAIc;;;;8BAyDH;+BA7DX46J;+BAGI,4BA0DO56J,SA7DX46J;+BAGI,MA0DO56J;8BA3Da;;;;8BA2Db;+BA7DX86J;qCA6DW96J;+BA7DX+6J;;gE0R7jCAzX,Y1R6jCAipB;;;;;4BAoHF;6BA3DAtR;;;;gEA2DA0xC;+BA3DA1xC;;;;gEA2DA0xC;+BA3DAzxC;;;;;;;;oC0RtnCErS;6C1RunCW5pP,GADb,+BA2DA0tS,UA1Da1tS,EAAyB;;+BADtCk8P;6BA2DAQ,mCA3DAN,YA2DAI;0DqB7tC2E;0BAxCvE,SAwCF91I,SAAS1zC;qCrB6tCXy6N;8B;oCqB7tC8Bn6N;;;oFAAI,QAAJA;;0CACmB;4BADtC,SrB6tCXi6L,QqB7tCwBvtQ,gCAAI;4BAAjB,SrB6tCX0tS,SqB7tCY1tS,mCAAU;sCAAXgzE;kCrB6tCX8sL,MqB7tCW9sL,SrB6tCX4sL;;;;;;;wCAC8BF,MAD9BE,SAC8BzD;;;;0CA5L1B7oL,GA4L0B6oL,QA5L1B/+G;;;;;;;6CAEI4hH,KAFJ5hH;6CAEIr8C;6CAFJj7C;;;;;;qD;;;;;;4DAAA8xF;;;;+DAEa,eAFbizG,MAEa,aAFbA,WAEwB;+DAFxB,0CAEwB;2DAFxB;qDAEa,YAGyC;iDAHlD9pJ;+CAFJ82C;kDAEImnH;6CAFJl6O;;;;6CAGIm6O,KAHJ7hH;6CAGIx8C;6CAHJ,6BAGIA;6CAHJw8C,KAGI6hH;6CAHJn6O;;;;6CACIq4H,KADJC;6CACIp9I;6CADJgmD;yEA2LJ0nP,kBA1LQ1tS,GADJ43I;kDACIuF;6CADJr4H;;;;;;;;;gD,gBAAA+yH;;;;;uHAKsD;+CALtDD;;oCkJ9tBE;wClJy5BNlnF,gCAC8BgvM,MAD9B/uM;;sCACI6uM,MADJI,SACIvD;;;;wCA5DJ+C,MA4DI/C,QA5DJ8C;;;;;;;;;;8CAIIa,MAJJb,SAII/hJ;0CAAS,iBAATA;;;4CAAS;+EAAyC;6CAAzC;0DAJb,6BA2DAswL,UAvDa1tS,EAAyB;;sDAAlCo9G;;;8CA7DF,SA6DEA,OA7DF0hJ;;;;;;;;;;;qDAGIO,KAHJP;qDAGIziJ;qDAHJ,iCAGIA,KAHJsiJ;0DAGIU;qDAHJx5M;;;wDAIIy5M,KAJJR,QAII5iJ;oDAAU,iBAAVA;;;qDAAU;wFAAS;4DAAT,qBAAVA;;qDAJJ12D;0DAII85M;qDAJJz5M;;;;qDACI05M,KADJT;qDACI9iJ;qDADJt2D;;6E0R7jCA4+L,Y1R6jCAgpB,QACItxJ;uDADJiyL;;;0DACI1uC;qDADJ15M;;;wDAEIg5M,KAFJC,QAEI59J;oDAAoB,iBAApBA;;;qDAAoB;wFAAS;4DAAT,qBAApBA;;qDAFJt7C;0DAEIi5M;qDAFJh5M;;;;;;;;;wD,gBAAA84M;;;;;;;;+IAM8D;uDAN9DqvC;;;4CA6DW,Uia/2CXz7E;;2Cja22CFliK;iDAII2vM;2CAJJ31M;;;;2CAGI41M,MAHJd;2CAGIriJ;2CAHJ7sD;;;;mEA2DAy9O,UAxDI5wL;6CAHJs9L;iDAGIn6C;2CAHJ51M;;;;2CACIu0M,MADJO;2CACIviJ;2CADJ1sD;;;;iD0RtnCE25L;0D1RunCW7pP,GADb,6BA2DA0tS,UA1Da1tS,EAAyB;+CAAlC48G;6CADJkxL;;;iDACIlvC;2CADJv0M;;;;2CAEI60M,MAFJC;2CAEI1iJ;2CAFJjyD;;;mEA2DAkjP,UAzDIjxL;6CAFJoxL;;iDAEI3uC;2CAFJ70M;;;;;;;;;8C,gBAAAs0M;;;;;;;;qIAM8D;6CAN9DkvC;;;sCA2DAp9O,gCACI+uM,MADJ7uM;;;;;;kGAE+C;4BAF/C,YqB7tC2E;0BAxCvE,SAwCFgnD;4BAAwC,SrB6tC1Cy3L,QqB7tCYhjH;wEAAU;4BrB8tCJ,GqB9tChBF,gBrB8tCgB;sCqB9tChBC,SrB8tCgB,MqB9tChBD;4BrB8tCgB,SA5DlBgiF,MA4DemsC,wCAAE;4BA3DsB;iCA2DrBx+L;;8BA3DqB;;;;;kC0R7gCnC4tI;2C1R6gCS8wD;oCAAG;sDAAHE,sCAAE;6CAAFF;mDAAyB;;;8BAAC;gCACvB;;;;;6CAAHI,sCAAE;;;gCAAC;kCACA;;;;;+CAAHE,sCAAE;;;kCAAC;mCACgC;;;oCAwD9Bh/L;qCAxD8B;gDAAnCk/L;yCAA0B,SA7DrC3L,QA6DW6L;2CAAG;6DAAHE,sCAAE;oDAAFF;0DAAyB;yCA5DpB,GA4DLF,gBA5DK;;gDA4DLC;0CA5DK,MA4DLD;0CA5DK;;6C0Rp9Bd72D;sD1Ro9BWm3D,wCAAE;;;yCAAC;2CACW;kDA2DhBL;4CA3DgB,MA2DhBD;4CA3DgB;;wDAAHQ,wCAAE;;;2CAAC;6CACd,gBA0DFR;6CA1DE;+CACI,UAyDNC,SAzDM,MAyDND;+CAzDM;iEAAHU,wCAAE;;;6CADH;2CADc;yCADX,QA4D6B;;;;uCAwD7B5/L,IAzDFD;;qCAyDEC,IA1DFF;;mCA0DEE,IA3DqBppC;qCA2DrBopC;8BAAuC;qCqB9tCvDswE;+BrB8tCuD,MqB9tCvDD;+BrB8tCuD;yCqB9tC3B2mH;kCAAK;oDAALjmH;oFAAI;2CAAJimH;iDrB8tCyB;+BAAE;yCqB9tCjCF;yErB8tCyB;8BA3LvB;8BA2L+B;+BA3L/B;;8CAALgJ,uCAAG;+BAAE;;2CA2LgBE,wCA3LvB;;;;8BAAO;gCACI;;;;;6CAAbE;;;;;;;qDAAO,QAAPE,cAAW;;;gCAAE,iBACX,0BADWt0P;8BADJ;4BA2LR,UqB9tCyD;0BAxCvE,SAwCF00P;4B;4BAA4B,sB,OgIH1B73L;4BhIG0B,+CAA5BjhH;0BAxCE,SAwCF+4S;4B;qCrB6tCFxpC,c,OqJ1tCIrwJ;4BrJ0tCJ;;;wCqB7tCElgH;6BrB6tCF,WqB7tCEA;6BrBkiCE,WA4L0B0sS;6BA5L1B,QA4L0BA;6BA5L1B,QA4L0BA;6BAzLtB;;6BAwLR;6BAzLQlnP;8BArxBJg5M;;;mCAqxBa9lM;;wCAyLjB63M,OAzLiBnwQ;wCAyLjBmwQ,OAzLiB73M;;gCAAT8zO;iEACA3uJ;6BAFA3/C;iEACA4/C;6BA0LsB1/C,SA3LtBsmD;6BA2LsBy5D,oCAD9BF;6BA3DA,SA4DIquF;6BA5DJ,SA4DIA;6BA5DJ,SA4DIA;6BA5DJ,SA4DIA;6BA5DJ;qCAzDE9hC,Y,OqJtmCEtqJ;;6BrJmqCA3hB;8BqJjyBAuhB;;kCrJouBF;;;;;mCAIIn8G,IqJxuBFm8G,erJouBF0qJ,KAII6hC;;mCADA;uEACAxuJ;mCAFA3/C,MqJtuBF4hB,erJouBF0qJ,KAEIwvC;uEACAl8J;mCAFA1/C,iB0RtkC2B6jJ,a1RqkC/BuoB,KACI5sH;uEACA8G;4CADAC;gCA4DFwnJ;iEAJJxnJ;6BAGIjmD,MqJlqCAwhB,oBrJkqCAgsL;iEACA30I;6BAFAz4D,MqJjqCAohB,oBrJiqCA+rL;iEACA9pG;6BAFAjjG;;gCqc10CFsoJ;gD,OhT0KEtnI;gCrJgqCA8rL;iEACA5pG;6BA0DA4b,SA3DAD;6BA2DAM,oCAA0BF;sCAA1BE;0BqBtwCA,SAwCFgqF;qCrB6tCFmK,cqB7tC8BriL;8B,OA7C1B86K,2BA6C0B96K;;;;mCAA5BxsH;;6BrBkqCF2+P;;gCqcz0CEnb;yCrc00CWh3H,S,OwEz2CX89H,sBxEy2CW99H;gCqBnqCXuyI;;6BrBkqCFH,MwEx2CEtU,sBxEw2CFqU;mCwEx2CErU,sBxEw2CFsU;;6BA2DAE;;gCqJr2BI36I;yCrJ8yBSy6I;2CA7DX8J,YA6DWl8I;oC,OwE52CX89H,sBxE42CW99H;;mCA7DXA,e0Rj9BEyxH,e1Ri9BFyqB,YA6DW9J;mCA7DXvqF,iBqJjvBElwD,iBrJivBFukJ,gBA6DW1oQ;mCA7DX2+P,wBA6DW3+P;oDqJ9yBTmkH,iBrJivBFukJ,kBA6DW1oQ;gCAJb6+P;;mCqBlqCE7+P;6BrBkiCEwsH,+BA2LJsyI;;6BA3LIzqF;8BAnxBAoqF;yCAqxBajyI;;;;yCAyLjBqiL,cAzLiBriL;yCAyLjBqiL,cAzLiBx6H;;gCAFb7nD;;;0BqB1kCA,SAwCFj7B;4B,IAAAi7B,IwLzBElH;;qCxLyBFo/K,qBAC+C;0BAzC7C,SAwCFjgE;4BAAwC,SrB6tC1CykE,QqB7tCYniH;wEAAU;4BrB8tCJ,GqB9tChBH,gBrB8tCgB;sCqB9tChBC,SrB8tCgB,MqB9tChBD;4BrB8tCgB,SA5DlBohF,MA4DesuC,wCAAE;4BA3DsB;;;;;;;;kC0RzgCnC7yD;2C1RygCS+yD;oCAAG;sDAAHE,sCAAE;6CAAFF;mDAAyB;;;;8BAAC;gCACvB;;;;;6CAAHI,sCAAE;;;gCAAC;kCACA;;;;;+CAAHE,sCAAE;;;kCAAC;;;;;sCvB7sClBhwH;iDuB8sCekwH;0CAA0B,SA7DrC9N,QA6DWgO;4CAAG;8DAAHE,sCAAE;qDAAFF;2DAAyB;0CA5DpB,GA4DLF,gBA5DK;;iDA4DLC;2CA5DK,MA4DLD;2CA5DK;;8C0Rh9Bd94D;uD1Rg9BWo5D,wCAAE;;;0CAAC;4CACW;mDA2DhBL;;6CA3DgB;;yDAAHO,wCAAE;;;4CAAC;8CACd,kBA0DFR;8CA1DE;0DA0DFC;uDvB9sCfnwH;kEuBqpCkB4wH,wCAAE;;;8CADH;;;;;sDA0DgC;;;;;;;;;;8BkJl2BzC;;;qC7HpUJ7wH;;+BrBkiCE8jH;yCqBliC0BgH;kCAAK;oDAALE;oFAAI;2CAAJF;iDrB8tCyB;+BA5LnD1pC;yCqBliCoBhhF;yErB8tCyB;8BA3LvB;;;;8CAAL2wH,uCAAG;+BAAE;;2CA2LgBE,wCA3LvB;;;;8BAAO;gCACI;;;;;6CAAbE;;;;;;;mDAFbrN,QAEauN,kBAAW;;;gCAAE,gBAF1BjwC;gCAE0B;;;;wCqBpiC6C;0BAGhE,IAALpkK,KAAK;mCAQLy0M,cAAYh7S,EAAGR,EAAGu0B,SAAU2iR;4BAAa,kBAA1Bl3S,EAA0B,WAA7BQ,EAAM+zB,SAAU2iR,UAAoC;0BAR3D,SAULuE,SAAQlnR,SAAU2iR;4BACpB,UADU3iR,SAAU2iR,SAEE;0BAZf;;;6BAHTxyD;;;;;;;;;6BAGI39I;6BAQAy0M;6BAEAC;2BAVK;;;;;;;;;;;;;;mCA6CPx5S,EAAE1B,EAAEP;4BAAwB,qBAAxBA,EAAFO;4BAA0B,qCAAK;0BA7C1B,SA+CPu7S,gBAAgB52R;4BACR,IAAN62R,IAAM;4BACV;8BAFkB72R,aAEK4yP,IAAM,+BADzBikC,IACmBjkC,GAAmC;4BAA1D,OADIikC,GAED;0BAlDM,SAsDPC,6BAA8Bz7S;4BAChC,SAAI0B,EAAG27F;8BACL,kCADKA;8BkbvPM,UAEX,IADK5gG,WACL,OADKA;8BAGL,sBlboP6D;4BAD/D,SAGIi/S;8BAEK,IAFOC,YAAJC,YAEH,QAFOD;8BAEb,YAFSC;4BASwB,YAbJ57S,MAYtB,QAZsBA,MAYtB,MAZsBA,KAYtB,MAZsBA;4BAS5B,eAT4BA,KAI5B07S,+BAUH;0BApEQ,SAsEPG;;6BAyBGtmD;6BADAgQ;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADA91O;6BADA+1O;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BAHAC;6BAEA1pQ;6BADA4mC;6BAFA1mC;2CA8C4B1C;8BACzB;;yCAAgC,wBA7BnCorQ,cA4B4BprQ,SACwB,EAAC;4BADtD;;6BAvT+BwuS,GA4Q9BhsS;6BA5Q0BisS,GA4Q1BjsS;6BA5QsBksS,GA4QtBlsS;6BA5QkBmsS,GA4QlBnsS;6BA5QcosS,GA4QdpsS;6BA5QUqsS,GA4QVrsS;6BAyBY,qBA3BZ0pQ;4BA0BC;mDA3BDxpQ;;oCAEA0mC;uCA3QUylQ,MAAID,MAAID,MAAID,MAAID,MAAID;oCA6Q9BviC;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACA/1O;;oCAEA61O;oCACAD;oCACAD;oCACAD;oCACAD;oCACAhQ;0BA/FI,SA+HPumD;gCAAwBC,oBAANC;2CAAMD;0BA/HjB,SAkIPxU,WAAYvnS;4BACF;gEADEA;6BAGZ,aAAwC,gBAH5BA,MAHZ87S;4BAMA,SAEE5sC,GAAGzyQ;8BACC,kCADDA;;gCAGD,IADoBw/S,YACpB,OADoBA;8BAGpB,8BAAY;4BAGhB;0DAbYj8S,SAKVkvQ;6BAQF,SAZEz8O,MACA/B,MAFU1wB;4BAaZ,eASgBT;8BAcM;gD0MpBAqzH,O1MMNrzH,KAjBd2vQ;+BA8BmB,SAbL3vQ;+BAOF;;;oCAEgB;oCAAV,2BATJA,uBAYmB;8BALrB,eAHU/E;gCAAQ,2BAJhB+E,KAIQ/E,UAAoB;8BAF9B,oDAaH;4BAhBL;8C0MLgBo4H,O1MhBV5yH;6BAmBC,SAnBDA;4BAkBC;qCwftTjBwsG,YxfgTMl7E,OAMW,GAlBDtxB,4BAuCqC;0BAzK1C,SA2KPk8S,6BAA8Bl8S;4BAGf,qB0M5BO4yH,O1MyBQ5yH,KA5C9B87S;4BA8CQ,qBAFsB97S,YAI/B;0BA/KQ,SAiLPm8S;4BA6CgB;6BApBd5mD;6BADAgQ;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADA91O;6BADA+1O;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAC;6BADAzpQ;6BADA4mC;6BADA8iO;6BADAxpQ;6BA4Cc,iBA1Bd0oQ;6BASa,qBA1Bbc;mCAEA1pQ;;;;;6BArXuCgsS;6BAAJC;6BAAJC;6BAAJC;6BAAJC;6BAAJC,GAqXnBrsS;4BAuBE;mDA1BFE;oCAEA0mC;uCApXmBylQ,GAAID,GAAID,GAAID,GAAID,GAAID;;oCAsXvCviC;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACAD;oCACA/1O;;oCAEA61O;oCACAD;oCACAD;oCACAD;oCACAD;oCACAhQ;0BA1MK,SAuOP6mD,aACQC;4B,gBACPr9S;8BACwB,qBAFjBq9S,KACPr9S;8BACQ,yBAFDq9S,KACPr9S,SACiC;0BA1O3B,SA4OPs9S;gCAAsBP,oBAANC;2CAAMD;0BA5Of,SA+OPzU,WAAaiV,WAA0C5/E;;;6BAKhDhqM;6BADAjC;;6BAD+B25O;6BAAPx4O;6BAALo6O;6BAALC;6BAAJt6O;;6BAFuBjD;6BAAR6C;6BAARD;6BAARD;qCAQd5vB,EAAEjF,GAAI,kCAAJA,GAA4D;qCAC9D+/S,KAAKx8S;8BAAI,6CAAJA,GAAkD;4BAClD;;;gCARU4xB;;kCAQM,0BAAqB,QAAZ52B,GAAO,YAAVyB,SAAoB;6BA0B/C;;gCArCW8/S;;kCAsCN;;;;;4CAA+CG,uBAANjgT,EAAGzB,QAM1C;6BAXD,sBAAgB,OA7BjB01B,MAPP4rR;6BAkCS,QA5B6BjyC;6BAyB1B,SAjBVoyC,KAiBU,EAzBmB5qR,OAAVq6O,IAAKD;6BAcpB;;gC0M9GgBr5I;gC1M8FkBjkG;yCAgBR3uB;kCAMV;oD0MpHA4yH,O1M8GU5yH,KAP9Bw8S;mCAYmB,WALWx8S;mCAKX,MALWA;kC6NnUpC,SAEY;kC7NmUM;+CACE,SAAc,WAHEA,aAP9Bw8S;;gDAcS;6BATE,WAdmBhrR;6BAanB,WAbWD;4BAYX;sDAAe,OAZZD,OASdkrR;;;oCALK7pR;oCALgDgqM;;0BA/OhD,SA8RPggF,aAAWJ,WAAW5/E,cAAc38N;4BACf,kBADVu8S,WACU,QADC5/E,eAAc38N,EACgB;0BA/R7C,SAiSP48S;4BAA+BL,WAC/B5/E;4BAEQ;6BAFgBpqM;6BAAPE;6BAET,iBAHuB8pR,WAC/B5/E,cAAiBlqM;4BAGF;+C0MnJOmgG,O1MgJErgG,aAtDxB+pR;;0BA5OO,SAwSPO;4BAA6BN,WAAW5/E,cAAc38N;4BACf;qCADVu8S,WACU,QADC5/E,eAAc38N,EACgB;0BAzS/D,SA2SPo+G,SAAQnR,QAAQ6vM,GAAI9+E,QAASE;4BAC/B,GADUjxH;6BAEwC,MAFxCA,WACNsvM,WACyCv/S;;iCADzCu/S;4BAIF;;;;kCAJEA;kDAIqB,IAAOG,oBAAP,OAAOA,UACd;6BAIhB;;gCATEH;;kCAUG,IAAOtU;kCAAP,kCAAOA,YACiC;6BAG7C;;yCAfgB6U,GAAI9+E,QAASE,UAI3Bw+E,WAKAlqR;4BAMF,oCADEvwB,IAI4B;0BA7TvB,SA+TP86S,aAAc9vM,QAAQ6vM,GAAI9+E,QAASE;4BACrC,GADgBjxH;6BAEkC,MAFlCA,WACZsvM,WACyCv/S;;iCADzCu/S;4BAIF;;;;kCAJEA;kDAIqB,IAAOG,oBAAP,OAAOA,UACd;6BAIhB;;gCATEH;;kCAUG,IAAOtU;kCAAP,kCAAOA,YACiC;4BAF7C,eAIchmS;8BAIhB,oCAJgBA,IAIgB;4BAH9B;;;yCAfsB66S,GAAI9+E,QAASE,UAIjCw+E,WAKAlqR;4BAMF,iDAG8B;0BAjVvB,SAmVPwqR,aAAer9M,KACdmrB;4BACU,IAATmyL,OAAS;4BACE;8BAAf,oBADIA;4BAAS;6BAETC;8BACF;gCAJCpyL;;kCAIuB;;;;;mCAIhB,iBATOnrB,KAKsB5vB;mCAE/B,+BACE,QAHiCl9D,WAAP7S;kCAE5B,UAFwBu4B,GACtBhlB,EAKK;4BAEA;8BAAf,oBAXI0pS;4BAYW;8BAAf,oBAZIA;4BAYW,eACC/kS;8BAKD;gCAAf,oBAlBI+kS;8BAkBW,OALC/kS,MAMV;4BAHF;wCAdAglS,0B;6BAaA,WAbAA,0B;6BAYF;6EAKI;0BAxWG,eA0W2BntO,IAAM,eAANA,GAAsB;0BAAzC,SAAfotO;4B,OAvBAH;0BAuBe,SAEf9+G,OAAQjxF,QAAQjtG,EAAEu4B,GAAGw3C;4BAIlB;0EAJkBA;6BAErB;2DACG,QAHKk9B,iBAAQjtG;4BAEhB,2BAFkBu4B,SAKZ;0BAPS;;;;;kCA1Zf0xQ;;;kCA6CF7mL;;;;;kCAGIszJ;kCAQA2kC;kCwf1LJtsL;;kCAOA+1H;;kCxfwNEpjP;kCAEA65S;kCAOAE;kCAgBAI;kCAyDAC;kCAGAvU;kCAyCA2U;kCAMAC;kCAsDAC;kCAKAE;kCAGAhV;kCA+CAqV;kCAGAC;kCAOAC;kCAGAz+L;kCAoBA2+L;kCAoBAC;kCAuBAG;kCAEAj/G;sBAMH;;sBvDrjBGxlD;sBI4HFsV;sBADAD;sBJ5HEtV;sBmjBVN;;sBlH+EoB;;;mCkHjCd/jE,OAAOn8C,GAAG6kR,eAAepyO,MAAO0wK;4BACzB,IAAL2hE,KAAK,wBADGD,eAAepyO,MAAO0wK;4BACzB,+BADAnjN,GACL8kR,KACgB;mCAElBC;4BAAyB/kR,GAAG6kR,eAAepyO,MAC1C0wK;4BACM,IAAL2hE,KAAK,wBAFqBD,eAAepyO,MAC1C0wK;4BACM,+BAFkBnjN,GAEvB8kR,KACkC;mCAIpCE,iBAAiBv9S,GAAI,UAAJA,EAA6B;mCAE9C8pO,MAAO9pO,GAAS,OAATA,OAAuB;mCAE9Bw9S,KAAMx9S,GAAS,OAATA,OAAiB;mCAEvB85J,MAAO95J,GAAS,OAATA,OAAkB;mCAEzBg8S,KAAMh8S,GAAS,OAATA,OAAsB;mCAE5B0lC,oBAAqB1lC;4BAAS,sB;4BAAA,kBlT6RR4yH,OkT7RD5yH,cAA6C;mCAElE2lC,eAAgB3lC;4BAAS,sB;4BAAA,kBlT2RH4yH,OkT3RN5yH,cAA6C;mCAE7Dy9S,0BAA2Bz9S,GAAS,OAATA,IAAoC;mCAE/DhB,EAAGgB,GAAS,OAATA,QAAmB;mCAEtBkuE,EAAGluE,GAAS,OAATA,QAAmB;mCAEtB09S,SAAU19S,GAAS,OAATA,OAAqB;mCAE/B29S,SAAU39S,GAAS,OAATA,OAAqB;mCAE/B49S,sBAAuB59S;4BACzB,YADyBA,KAxBvBu9S,iBAyBmD;;kCApCnD7oO;kCAIA4oO;kCAOAC;kCAEAzzE;kCAEA0zE;kCAEA1jJ;kCAEAkiJ;kCAEAt2Q;kCAEAC;kCAEA83Q;kCAEAz+S;kCAEAkvE;kCAEAwvO;kCAEAC;kCAEAC;sBAEH;;sBnjBxEGllK;sBI4HFsV;sBADAD;sBJ5HEtV;sBwDVN;;sBAwHG;;sBxD7GGC;sBI4HFsV;sBADAD;sBJ5HEtV;sBojBTN;;sBAGwB;;sBpjBOlBC;sBI4HFsV;sBADAD;sBJ5HEtV;sByDVN;;sBwY+EoB;;;;;;;;;;;;;sBxYzEhB;;;;;;;;sBwYyEgB;uBmH9EpB;;uB3fKI;uCAmB+Dh5I;0BAa1D;2BAboD8N;2BAAJD;2BAAJF;2BAAJD;2BAAJ6wS;2BAAJr1S;2BAAJs1S;2BAAJC;2BAAPC;2BAAJC;2BAAJC;2BAAJC;2BAAJC;2BAaD,iBAb0D9+S,EAAN8N;2BAYpD,iBAZ0D9N,EAAV6N;2BAWhD,iBAX0D7N,EAAd2N;2BAU5C,iBAV0D3N,EAAlB0N;2BASxC,iBAT0D1N,EAAtBu+S;2BAQpC,iBAR0Dv+S,EAA1BkJ;2BAOhC,iBAP0DlJ,EAA9Bw+S;2BAM5B,iBAN0Dx+S,EAAlCy+S;2BAKrB,iBALuDz+S,EAAzC0+S;2BAIjB,iBAJ0D1+S,EAA7C2+S;2BAGb,iBAH0D3+S,EAAjD4+S;2BAET,iBAF0D5+S,EAArD6+S;0BACL;6CAD0D7+S,EAAzD8+S;;;;;;;;;;;;;sBA8BP;;sBzD5CG7lK;sBI4HFsV;sBADAD;sBJ5HEtV;sB0DVN;;sBuY+EoB;;;;;;;;;;;;;;sBvY1EhB;;;;;;;;sBuY0EgB;uBvYtDhB+lK;uCAAgE/+S;0BAc3D;2BAdqDg/S;2BAAJC;2BAAJC;2BAAJxkO;2BAAJr1C;2BAAJD;2BAAJD;2BAAJ+0C;2BAAJ/rE;2BAAJgxS;2BAAJC;2BAAJ/1D;2BAAJg2D;2BAAJC;2BAcD,iBAd2Dt/S,EAANg/S;2BAarD,iBAb2Dh/S,EAAVi/S;2BAYjD,iBAZ2Dj/S,EAAdk/S;2BAW7C,iBAX2Dl/S,EAAlB06E;2BAUzC,iBAV2D16E,EAAtBqlC;2BASrC,iBAT2DrlC,EAA1BolC;2BAQjC,iBAR2DplC,EAA9BmlC;2BAO7B,iBAP2DnlC,EAAlCk6E;2BAMzB,iBAN2Dl6E,EAAtCmO;2BAKrB,iBAL2DnO,EAA1Cm/S;2BAIjB,iBAJ2Dn/S,EAA9Co/S;2BAGb,iBAH2Dp/S,EAAlDqpP;2BAET,iBAF2DrpP,EAAtDq/S;0BACL;6CAD2Dr/S,EAA1Ds/S;;;;;;;;;;;;;;sBAgCP;;sB1D9CGrmK;sBI4HFsV;sBADAD;sBJ5HEtV;sB2DVN;;sBsY+EoB;;;0BtYiEP;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2BAEQ;;;;;2B6SjB0Cs6B;;;;;;;;;;;2B7SiB1C;;mCAmED1qD,YAtBErrH,EAAEP;4BAC8B;gDAD9BA;6BAXLjC;6BAAEmyO;6BAAav9K;4BACxB;8BAAG,GADM50D,MAlCbk6O,mCA6CgB13O,EAXYoyD;8BAIjB;;qDALU9vD,EACR9E;kCAIsC,SAJvB40D,MAAbu9K;kCAAav9K;+BAOI,wBAPjBu9K;+BAOiB,IAPnBnyO;;+BAAEmyO;+BAAav9K,MAGlB4e;uCASoD;0BAEnD,SAmBG+lB,Y,OoLjCdq0B,QpLiCcC;0BAnBH,SAmBG5wC,QAjBF5G,GAAGF;4BAAmC,2BAAnCA,IAAoB,uBAAvBE;4BAAuB,wCAA6B;0BAFrD,SAmBG6sK,UAbA19O;4BACkB,2BADlBA;4BACJ,iDAAoC;0BAPnC,SAmBG49O,UAVAx9O;4B,UAAAA;8BAGR,IADMtD,EAFEsD;8BAGL,2BAAW,uBADRtD;4BAGN,YAA2B;0BAvDjC;wC6SxByD01K;0B7SwBzD;;;;;;;;;;;;;;;+ChDUNsV;;2BgDVMk3H;2DAAsD;mCAAtD9qI;;qD+GhDEuR,c/GgDF7rK;;;;4BAAsD,OAAtD5Z,CAAsD;mCAAtDm0K;;;;;;;4BAAsD,OAAtDn0K,CAAsD;8BAAtDo0K;;;;;;qE+GhDEmR,c/GgDF7tH;mFAAsD;mCAAtDs8G;;;;;4C+GhDEwR,e/GgDF5rK;+DAAsD;;2BAAtDq6J;;2BAJYirI;;;;oFA6Db;mCA7DaC;;;;;;;;;;wFA6Db;4BA7Da;;+FA6Db;mCAKCG,iBAAkBzoS;4BAAY,wBAAZA,UAAsC;0BAElD,4BAEC;mCAGPkgI,IAAIt6I,GAAiB,gCAAjBA,GAHJq2E,KAG0C;0BAHnC,SAKPy2J,KAAK9sO,GAAiB,gCAAjBA,GALLq2E,KAK4C;0BALrC,SAOPkvJ,QAAQhiO;4BAEF,IAAJV,EAAI,gBAFEU;4BAGgB,cAnFxB00O,aAmFwB,qBADtBp1O,GACyC;0BAVpC,SAYPykO,QAAQnC;4BACV,eAA2CjtL,IAAI/3C;8BACjC,IAANwyD,MAAM,iBAD6Bza;8BAC7B,OADiC/3C,EAEjC,iBADNwyD,MAhBNzoD,KAgBMyoD,KAC0B;4BAFxB,gCADAwyK,IAZR9uJ,WAekC;;;;;;;;;;8BAG5B,IAAJ9yE,EAAI;8BACD;iDADHA,EACY,iBAAW,iBADvBA;;4DACsC;;;;;;;;;;8BAGlC;;+BAEN;;;mC6SlHyD+yK;;;;;;;;kC7SoHtD;;qC6SpHsDA;;;;;;;;oC7SiHhDliG;+BACT;;+BADSxsB;;2DAAe;;uCAAfkD,iDAGwC;mCAW/CvlC,IAAIhiB,EAAG+yH,OAAQ,wBAAX/yH,EAAG+yH,MAAuB;mCAE9BnsH,IAAI5G,EAAG+yH,OAAQ,wBAAX/yH,EAAG+yH,MAAuB;mCAI9Bt5C,IAAIz5E,EAAG+yH,OAAQ,wBAAX/yH,EAAG+yH,MAAuB;mCAE9BikJ,KAAMuoC,KAAKv/S,GAAI,wBAATu/S,KAAKv/S,EAAe;yCAR1BgiB,IAEApb,UAIA6yE,IAEAu9L;mCAGFv1N,GAAGhiD,EAAEO,EAAE+yH,OAAQ,kBAAZtzH,EAAEO,EAAE+yH,MAAkB;;0BAEhB,SAATppD,oB,OAFAloB;0BAES;0BAEA,SAATgqB,sB,OAJAhqB;0BAIS;0BAEA,SAATwhE,sB,OANAxhE;;;;;;;;;;8BASM,IAAJhlD,EAAI;8BACA,wBADJA,EACI,QAAS,QADbA,IACyB;;;;;;;;;;8BAG7B,eAIUmlO;gCACiC;4CAAS,QAD1CA;iCACgB,aADhBA;iCACgB;;iCAAXv9K;;kC,O4HqNb26D,a5BjTAN;yChG4FamS;kCAAK,uCAAL0jD,YAAS;;yCAATjtH,qDAAkD;8BAJ/D;;;;;;;;;0DAvIAotL,qBuGu+CEr4E;6CvG51C+D;;;;oCAxEnDqhF;;oCA5Dd4K;;;oC6SxByDv1E;;;;;;;;oC7SoF3Ct7F;;;;;qCA5Dds8F;;;;;;;;mCAJYorI;kCAgEEzhE;;;;;kC6SpF2C3qE;;;;;;;;kC7SoF3C1qD;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCArEd5mH;kCAuEA69S;kCAEA34S;kCAEAmsE;kCAGAikE;kCAEAwyF;kCA9EAmL;kCAgFA1S;kCAKA+B;;;;;;kCAsCAp6J;kCAEA8B;kCAEAw3C;sBAaH;;sB3DnRGy1B;sBI4HFsV;sBADAD;sBJ5HEtV;sB4DTN;;sBqY8EoB;uBrY9EpB;iCAOE14B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BwHugBM;qCxHvgBN;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gEAmBiB;uBA1BnB;iCAyDEyzD;;;;;8BAAyB,IAAhBgB,MAAT5kH,SAAyB,uBAAhB4kH;;oCAAThB;4CAAS;0BAA4C,IAAxBgC,MAA7B5lH;0BAAqD,uBAAxB4lH,MACG;uBA1DlC;iCA2EEmqI;0BAAsB,GAAtBhpI,gBAAsB;2CAAtBgpI;0BAAsB,eAAY,UAAlChpI,mBAAsBr3K,CAAI;uBA3E5B;;8BAsG0B41B,aAALI,2BAAKJ;uBAtG1B;iCAuJI4qR;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BwHuXI;qCxHvXJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kGAgKiB;sDAhKjBlkK;;;;;;;;;gDAC4B;6EAD5BwkK;;kDAC4B;;;;;;wDAAI;;;yEADhC3rF,KACgCv5E;yEADhC4kK,KACgCzlK;yDAAJqmK,aAAIvlK;;;;oDAAJulK;qDAAI,yBADhC94P,YAC4B64P;;;+CAAa;4EADzCL;;iDACyC;;;;;;uDAAI;;;wEAD7C3rF,KAC6Cp4E;wEAD7CyjK,KAC6C78J;wDAAJ29J,aAAItkK;;;;mDAAJskK;oDAAI,yBAD7Ch5P,YACyC+4P;;;8CAAa;2EADtDP;;gDACsD;;sEADtD3rF,KACsDosF;;;6CAAvC;0EADfT;;+CACe;;;;;;qDAAI;;;uEADnB3rF,KACmBn5E;uEADnBwkK,KACmBz8J;sDAAJ29J,aAAIzlK;;;;iDAAJylK;kDAAI,yBADnBp5P,YACem5P;;;4CAA+C;yEAD9DX;;8CAC8D;;oEAD9D3rF,KAC8DwsF;;2CAD9D;;;;;;;;;wCACejB;kCADf,MAC4BC;kCAD5B,MACyCC;kCADzC,MACsDxlH;kCADtD,MAC8DylH;;;;oCAARhlH;oCAAbimH;oCAAbC;oCAAbC;qDAAaD,QAAaD,QAAajmH,QAAQgmH;iCAD9D;;;;oDACenB;;qDAAaC;;sDAAaC;;uDAAaxlH;0DAAQylH;;;gCAD9DoB;gCAGkBC;gCAHlBC;;;;;;;;;;;;;;;;;;4CAGkB;wEAHlBA;;;;+DAGkB7mH,aAHlBn+L;;mDAGkBm+L,aAHlB;;+CAGkBiF;gD2H6ChB5+E;kE,OAAAA,c3HhDF6+L;kDAGkBllH;;2CAHlB;;;;;;;;2CAGkB4mH;iCAHlB,cAGkBG,qBAHlB,UAGkBA;iCAHlB;qEAGkBH;;;gCAHlBI;gCAKQC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCAZRC;;;;;;;;;;;;;;;;;;;;;;;kGAgKiB;sDAhKjBzmK;;;;;;;;;;;;mDAYQ;gFAZRymK;;qDAYQ;;2EAZRvC,KAYQ4C;;;kDAFA;+EAVRL;;oDAUQ;;0EAVRvC,KAUQ8C;;;iDADA;8EATRP;;mDASQ;;yEATRvC,KASQgD;;;gDAFA;6EAPRT;;kDAOQ;;;;;;wDAAK;;;yEAPbvC,KAOa1gT;yEAPb0gT,KAOapoP;yDAALurP,aAAK1xP;;;;oDAAL0xP;qDAAK,yBAPbr7P,YAOQo7P;;;+CADA;4EANRX;;iDAMQ;;;;;;uDAAK;;;wEANbvC,KAMatjK;wEANbsjK,KAMaplK;wDAALyoK,aAAK1mK;;;;mDAAL0mK;oDAAK,yBANbv7P,YAMQs7P;;;8CADA;2EALRb;;gDAKQ;;;;;;sDAAK;;;uEALbvC,KAKa/kK;uEALb+kK,KAKa9jK;uDAALqnK,aAAKroK;;;;kDAALqoK;mDAAK,yBALbz7P,YAKQw7P;;;6CAMA;0EAXRf;;+CAWQ;;qEAXRvC,KAWQwD;;;4CAHA;yEARRjB;;8CAQQ;;oEARRvC,KAQQ0D;;2CARR;;;;;;;;;wCAKQ3B;kCALR,MAMQC;kCANR,MAOQC;kCAPR,MAQQC;kCARR,MASQC;kCATR,MAUQC;kCAVR,MAWQC;kCAXR,MAYQC;;;;;;;;;;;;;;;;;;;oCADAuB;oCADAC;oCADAC;oCADAC;oCADAC;oCADAC;oCADAC;;;2CACAD;2CACAD;2CACAD;2CACAD;2CACAD;2CACAD;2CACAD;iCAZR;;;;oDAKQ7B;;qDACAC;;sDACAC;;uDACAC;;wDACAC;;yDACAC;;0DACAC;6DACAC;;;gCAZR8B;gCAckBC;gCAdlBC;;;;;;;;;;;;;;;;;;4CAckB;wEAdlBA;;;;iEAckB5uD,cAdlBn4J;;;gDAckBm4J;iDAdlB;;+CAckBa;gD2HkChBp1I;kE,OnInMF0jL,aQmJAmb;kDAckBtqD;;2CAdlB;;;;;;;;2CAckB2uD;iCAdlB;uCAckBI,uBAdlB,UAckBA;iCAdlB;qEAckBJ;;;gCAdlBK;gCAgBQC;gCAAoCC;gCAASC;gCAASC;gCAhB9DC;;;;;;;;;;;;;;;;;;;;;;;kGAgKiB;sDAhKjBjpK;;;;;;;;+CAgBqD;2EAhBrDipK;;iDAgBqD;;uEAhBrD/E,KAgBqDoF;;;8CAAT;0EAhB5CL;;gDAgB4C;;sEAhB5C/E,KAgB4CqF;;;6CAApC;yEAhBRN;;+CAgBQ;;;iD2HgCN5jM;4D9HlMFlB;;;;;;;;;;;;;;;;;;;;;uD;uDAAA;;;;;;;;;;iE2HygBI;mE3HzgBJ;;;;;;;;;0HAegC;8EAfhC67B;;;;;;;;;;;;;;2EAEI;qGAFJF;;6EAEI;;gGGgJJokK,KHhJIjlH;;;0EAKA;oGAPJn/C;;4EAOI;;iGG2IJokK,KH3IIhlH;;;yEAHA;mGAJJp/C;;2EAII;;gGG8IJokK,KH9II9kH;;;wEAHA;kGADJt/C;;0EACI;;+FGiJJokK,KHjJIllH;;;uEAKA;iGANJl/C;;yEAMI;;8FG4IJokK,KH5IIhgH;;;sEAHA;gGAHJpkD;;wEAGI;;6FG+IJokK,KH/II9/G;;;qEAMA;+FATJtkD;;uEASI;;4FGyIJokK,KHzII5/G;;;;;;;;;;;0EADA;oGARJxkD;;4EAQI;;iGG0IJokK,KH1IIlgH;;;yEAHA;mGALJlkD;;2EAKI;;gGG6IJokK,KH7IIpmG;;;wEAQA;kGAbJh+D;;0EAaI;;+FGqIJokK,KHrIIlmG;;;uEADA;iGAZJl+D;;yEAYI;;8FGsIJokK,KHtIIhmG;;;sEADA;gGAXJp+D;;wEAWI;;8FGuIJokK,KHvII9lG;;;qEADA;+FAVJt+D;;uEAUI;;6FGwIJokK,KHxII5lG;;+EAVJ;;;;kEAegC;qDAfhC;;;;;;4DACIqrG;sDADJ,MAEIC;sDAFJ,MAGIC;sDAHJ,MAIIC;sDAJJ,MAKId;sDALJ,MAMIe;sDANJ,MAOIC;sDAPJ,MAQIC;sDARJ,MASIC;sDATJ,MAUIC;sDAVJ,MAWIC;sDAXJ,MAYIC;sDAZJ,MAaIC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wDADAE;wDADAC;wDADAC;wDADAC;wDADAC;wDADAC;wDADAC;wDADAC;wDADAC;wDADAC;wDADAC;wDADAC;;;+DACAD;+DACAD;+DACAD;+DACAD;+DACAD;+DACAD;+DACAD;+DACAD;+DACAD;+DACAD;+DACAD;+DACAD;qDAbJ;;;;wEACIZ;;yEACAC;;0EACAC;;2EACAC;;4EACAd;;6EACAe;;8EACAC;;+EACAC;;gFACAC;;iFACAC;;kFACAC;;mFACAC;sFACAC;mDGqJIb;;;4CAAsD;wEAhB9DR;;8CAgB8D;;oEAhB9D/E,KAgB8DkH;;2CAhB9D;;;;;;;;;wCAgBQvC;kCAhBR,MAgB4CC;kCAhB5C,MAgBqDC;kCAhBrD,MAgB8DC;;;;oCAATsC;oCAATC;oCAApCC;2DAAoCD,SAASD,SAASP;iCAhB9D;;;;oDAgBQlC;;qDAAoCC;;sDAASC;yDAASC;;;gCAhB9DyC;gCAiBuBC;gCAjBvBC;;;;;;;;;;;;;;;;;;4CAiBuB;yEAjBvBA;;;;iEAiBuBG,cAjBvBlqN;;;gDAiBuBkqN;iDAjBvB;;+CAiBuBC;gD2H+BrB1mM;2D7HnMFlB;;;;;;;;;;;;;;;;;;;;;;sD;sDAAA;;;;;;;;;;gE0H0gBI;kE1H1gBJ;;;;;;;;;yHAgBgC;6EAhBhC67B;;;;;;;;;;;;;;0EAcI;oGAdJF;;4EAcI;;+FEqIJokK,KFrIIjlH;;;yEADA;mGAbJn/C;;2EAaI;;gGEsIJokK,KFtIIhlH;;;wEADA;kGAZJp/C;;0EAYI;;+FEuIJokK,KFvII9kH;;;uEADA;iGAXJt/C;;yEAWI;;8FEwIJokK,KFxIIllH;;;sEADA;gGAVJl/C;;wEAUI;;6FEyIJokK,KFzIIhgH;;;qEADA;+FATJpkD;;uEASI;;4FE0IJokK,KF1II9/G;;;oEADA;8FARJtkD;;sEAQI;;2FE2IJokK,KF3II5/G;;;;;;;;;;;;0EADA;oGAPJxkD;;4EAOI;;iGE4IJokK,KF5IIlgH;;;yEALA;mGAFJlkD;;2EAEI;;gGEiJJokK,KFjJIpmG;;;wEADA;kGADJh+D;;0EACI;;+FEkJJokK,KFlJIlmG;;;uEAKA;iGANJl+D;;yEAMI;;8FE6IJokK,KF7IIhmG;;;sEAFA;gGAJJp+D;;wEAII;;8FE+IJokK,KF/II9lG;;;qEACA;+FALJt+D;;uEAKI;;6FE8IJokK,KF9II5lG;;;oEAFA;8FAHJx+D;;sEAGI;;4FEgJJokK,KFhJI1lG;;8EAHJ;;;;iEAgBgC;oDAhBhC;;;;;;2DACIwtG;qDADJ,MAEIC;qDAFJ,MAGIC;qDAHJ,MAIIC;qDAJJ,MAKIC;qDALJ,MAMIC;qDANJ,MAOIC;qDAPJ,MAQIC;qDARJ,MASIC;qDATJ,MAUIC;qDAVJ,MAWIC;qDAXJ,MAYIC;qDAZJ,MAaIC;qDAbJ,MAcIC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uDADAE;uDADAC;uDADAC;uDADAC;uDADAC;uDADAC;uDADAC;uDADAC;uDADAC;uDADAC;uDADAC;uDADAC;uDADAC;;;8DACAD;8DACAD;8DACAD;8DACAD;8DACAD;8DACAD;8DACAD;8DACAD;8DACAD;8DACAD;8DACAD;8DACAD;8DACAD;oDAdJ;;;;uEACId;;wEACAC;;yEACAC;;0EACAC;;2EACAC;;4EACAC;;6EACAC;;8EACAC;;+EACAC;;gFACAC;;iFACAC;;kFACAC;;mFACAC;sFACAC;kDEsJmBf;;2CAjBvB;;;;;;;;2CAiBuBJ;iCAjBvB;uCAiBuBkC,uBAjBvB,UAiBuBA;iCAjBvB;qEAiBuBlC;;;gCAjBvBmC;gCAmBQC;gCAASC;gCAASC;gCAASC;gCAASC;gCAASC;gCAASC;gCAnB9DC;;;;;;;;;;;;;;;;;;;;;;;kGAgKiB;sDAhKjBruK;;;;;;;;;;;kDAmB8D;8EAnB9DquK;;oDAmB8D;;yEAnB9DnK,KAmB8D9/G;;;iDAAT;6EAnBrDiqH;;mDAmBqD;;wEAnBrDnK,KAmBqD5/G;;;gDAAT;4EAnB5C+pH;;kDAmB4C;;uEAnB5CnK,KAmB4ClgH;;;+CAAT;2EAnBnCqqH;;iDAmBmC;;sEAnBnCnK,KAmBmCpmG;;;8CAAT;0EAnB1BuwG;;gDAmB0B;;qEAnB1BnK,KAmB0BlmG;;;6CAAT;yEAnBjBqwG;;+CAmBiB;;oEAnBjBnK,KAmBiBhmG;;;4CAAT;wEAnBRmwG;;8CAmBQ;;mEAnBRnK,KAmBQ9lG;;2CAnBR;;;;;;;;;wCAmBQ0vG;kCAnBR,MAmBiBC;kCAnBjB,MAmB0BC;kCAnB1B,MAmBmCC;kCAnBnC,MAmB4CC;kCAnB5C,MAmBqDC;kCAnBrD,MAmB8DC;;;;;;;;;;;;;;;;;oCAATK;oCAATC;oCAATC;oCAATC;oCAATC;oCAATC;;;2CAASD;2CAASD;2CAASD;2CAASD;2CAASD;2CAASD;iCAnB9D;;;;oDAmBQV;;qDAASC;;sDAASC;;uDAASC;;wDAASC;;yDAASC;4DAASC;;;gCAnB9DW;gCAqBQC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCAEAC;gCArCRC;;;;mC;mCAAA;;;;;;;;;;6CwHuXI;+CxHvXJ;;;;;;;;;sGAgKiB;0DAhKjBhwK;;;;;;;;;;;;;;;wDA2BQ;oFA3BRgwK;;0DA2BQ;;6EA3BR9L,KA2BQjlH;;;uDADA;mFA1BR+wH;;yDA0BQ;;8EA1BR9L,KA0BQhlH;;;sDADA;kFAzBR8wH;;wDAyBQ;;6EAzBR9L,KAyBQ9kH;;;qDADA;iFAxBR4wH;;uDAwBQ;;4EAxBR9L,KAwBQllH;;;oDADA;gFAvBRgxH;;sDAuBQ;;2EAvBR9L,KAuBQhgH;;;mDADA;+EAtBR8rH;;qDAsBQ;;0EAtBR9L,KAsBQ9/G;;;kDAaA;8EAnCR4rH;;oDAmCQ;;yEAnCR9L,KAmCQ5/G;;;iDADA;6EAlCR0rH;;mDAkCQ;;wEAlCR9L,KAkCQlgH;;;;;;;;;;;;;wDADA;oFAjCRgsH;;0DAiCQ;;+EAjCR9L,KAiCQpmG;;;uDADA;mFAhCRkyG;;yDAgCQ;;8EAhCR9L,KAgCQlmG;;;sDADA;kFA/BRgyG;;wDA+BQ;;6EA/BR9L,KA+BQhmG;;;qDADA;iFA9BR8xG;;uDA8BQ;;6EA9BR9L,KA8BQ9lG;;;oDADA;gFA7BR4xG;;sDA6BQ;;4EA7BR9L,KA6BQ5lG;;;mDADA;+EA5BR0xG;;qDA4BQ;;2EA5BR9L,KA4BQ1lG;;;kDAPA;8EArBRwxG;;oDAqBQ;;0EArBR9L,KAqBQxlG;;;iDAgBA;6EArCRsxG;;mDAqCQ;;yEArCRn3F,KAqCQja;;2DArCR;;;;8CAgKiB;+BAhKjB;;;;;;;sCAqBQowG;gCArBR,MAsBQC;gCAtBR,MAuBQC;gCAvBR,MAwBQC;gCAxBR,MAyBQC;gCAzBR,MA0BQC;gCA1BR,MA2BQC;gCA3BR,MA4BQC;gCA5BR,MA6BQC;gCA7BR,MA8BQC;gCA9BR,MA+BQC;gCA/BR,MAgCQC;gCAhCR,MAiCQC;gCAjCR,MAkCQC;gCAlCR,MAmCQC;gCAnCR,MAqCQC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAFAK;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;;;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCAEAD;+BArCR;;;;kDAqBQnB;;mDACAC;;oDACAC;;qDACAC;;sDACAC;;uDACAC;;wDACAC;;yDACAC;;0DACAC;;2DACAC;;4DACAC;;6DACAC;;8DACAC;;+DACAC;;gEACAC;mEAEAC;;;gCArCRl8C;gCA0CQs9C;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACeC;gCACfC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCAvERh/C;;;;mC;mCAAA;;;;;;;;;;6CwHuXI;+CxHvXJ;;;;;;;;;sGAgKiB;0DAhKjBh0H;;;;;;;;;;;;;;;;;0DAgDQ;sFAhDRg0H;;4DAgDQ;;+EAhDRkwC,KAgDQjlH;;;yDADA;qFA/CR+0E;;2DA+CQ;;gFA/CRkwC,KA+CQhlH;;;wDADA;oFA9CR80E;;0DA8CQ;;+EA9CRkwC,KA8CQ9kH;;;uDADA;mFA7CR40E;;yDA6CQ;;8EA7CRkwC,KA6CQllH;;;sDAYe;kFAzDvBg1E;;wDAyDuB;;6EAzDvBkwC,KAyDuBhgH;;;qDADf;iFAxDR8vE;;uDAwDQ;;4EAxDRkwC,KAwDQ9/G;;;oDADA;gFAvDR4vE;;sDAuDQ;;2EAvDRkwC,KAuDQ5/G;;;;;;;;;;;;0DADA;sFAtDR0vE;;4DAsDQ;;iFAtDRkwC,KAsDQlgH;;;yDADA;qFArDRgwE;;2DAqDQ;;gFArDRkwC,KAqDQpmG;;;wDADA;oFApDRk2D;;0DAoDQ;;+EApDRkwC,KAoDQlmG;;;uDADA;mFAnDRg2D;;yDAmDQ;;8EAnDRkwC,KAmDQhmG;;;sDADA;kFAlDR81D;;wDAkDQ;;8EAlDRkwC,KAkDQ9lG;;;qDAqBA;iFAvER41D;;uDAuEQ;;6EAvERkwC,KAuEQ5lG;;;oDADA;gFAtER01D;;sDAsEQ;;4EAtERkwC,KAsEQ1lG;;;;kDADA;8EArERw1D;;oDAqEQ;;0EArERkwC,KAqEQxlG;;;;;;;;;;;;;;;;0DADA;sFApERs1D;;4DAoEQ;;kFApERkwC,KAoEQtlG;;;yDADA;qFAnERo1D;;2DAmEQ;;iFAnERkwC,KAmEQplG;;;wDADA;oFAlERk1D;;0DAkEQ;;gFAlERkwC,KAkEQtmG;;;uDADA;mFAjERo2D;;yDAiEQ;;+EAjERkwC,KAiEQpqD;;;sDADA;kFAhERka;;wDAgEQ;;8EAhERkwC,KAgEQlqD;;;qDALA;iFA3DRga;;uDA2DQ;;6EA3DRkwC,KA2DQhqD;;;oDADA;gFA1DR8Z;;sDA0DQ;;4EA1DRkwC,KA0DQ9pD;;;mDATA;+EAjDR4Z;;qDAiDQ;;2EAjDRkwC,KAiDQ5pD;;;;;;;;;;;;yDALA;qFA5CR0Z;;2DA4CQ;;iFA5CRkwC,KA4CQ1pD;;;wDAFA;oFA1CRwZ;;0DA0CQ;;gFA1CRkwC,KA0CQxpD;;;uDAqBA;mFA/DRsZ;;yDA+DQ;;+EA/DRkwC,KA+DQtqD;;;sDADA;kFA9DRoa;;wDA8DQ;;8EA9DRkwC,KA8DQmF;;;qDAnBA;iFA3CRr1C;;uDA2CQ;;6EA3CRkwC,KA2CQoF;;;oDAkBA;gFA7DRt1C;;sDA6DQ;;4EA7DRkwC,KA6DQqF;;;mDADA;+EA5DRv1C;;qDA4DQ;;2EA5DRkwC,KA4DQuF;;;6DA5DR;;;;8CAgKiB;+BAhKjB;;;;;;;sCA0CQ0H;gCA1CR,MA2CQC;gCA3CR,MA4CQC;gCA5CR,MA6CQC;gCA7CR,MA8CQC;gCA9CR,MA+CQC;gCA/CR,MAgDQC;gCAhDR,MAiDQC;gCAjDR,MAkDQC;gCAlDR,MAmDQC;gCAnDR,MAoDQC;gCApDR,MAqDQC;gCArDR,MAsDQC;gCAtDR,MAuDQC;gCAvDR,MAwDQC;gCAxDR,MAyDuBC;gCAzDvB,MA0DQC;gCA1DR,MA2DQC;gCA3DR,MA4DQC;gCA5DR,MA6DQC;gCA7DR,MA8DQC;gCA9DR,MA+DQC;gCA/DR,MAgEQC;gCAhER,MAiEQC;gCAjER,MAkEQC;gCAlER,MAmEQC;gCAnER,MAoEQC;gCApER,MAqEQC;gCArER,MAsEQC;gCAtER,MAuEQC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCADAE;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADeC;kCADfC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;;;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACeD;yCACfD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;+BAvER;;;;kDA0CQ9B;;mDACAC;;oDACAC;;qDACAC;;sDACAC;;uDACAC;;wDACAC;;yDACAC;;0DACAC;;2DACAC;;4DACAC;;6DACAC;;8DACAC;;+DACAC;;gEACAC;;iEACeC;;kEACfC;;mEACAC;;oEACAC;;qEACAC;;sEACAC;;uEACAC;;wEACAC;;yEACAC;;0EACAC;;2EACAC;;4EACAC;;6EACAC;;8EACAC;iFACAC;;;gCAvERpzK;gCA0EQm1K;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCAxFR/1K;;;;mC;mCAAA;;;;;;;;;;6CwHuXI;+CxHvXJ;;;;;;;;;sGAgKiB;0DAhKjBE;;;;;;;;;;;;;;;wDAwFQ;kFAxFRF;;0DAwFQ;;6EAxFRokK,KAwFQjlH;;;uDADA;iFAvFRn/C;;yDAuFQ;;8EAvFRokK,KAuFQhlH;;;sDADA;gFAtFRp/C;;wDAsFQ;;6EAtFRokK,KAsFQ9kH;;;qDADA;+EArFRt/C;;uDAqFQ;;4EArFRokK,KAqFQllH;;;oDATA;8EA5ERl/C;;sDA4EQ;;2EA5ERokK,KA4EQhgH;;;mDAQA;6EApFRpkD;;qDAoFQ;;0EApFRokK,KAoFQ9/G;;;kDADA;4EAnFRtkD;;oDAmFQ;;yEAnFRokK,KAmFQ5/G;;;iDADA;2EAlFRxkD;;mDAkFQ;;wEAlFRokK,KAkFQlgH;;;;;;;;;;;;uDADA;iFAjFRlkD;;yDAiFQ;;8EAjFRokK,KAiFQpmG;;;sDANA;gFA3ERh+D;;wDA2EQ;;6EA3ERokK,KA2EQlmG;;;qDAKA;+EAhFRl+D;;uDAgFQ;;4EAhFRokK,KAgFQhmG;;;oDADA;8EA/ERp+D;;sDA+EQ;;4EA/ERokK,KA+EQ9lG;;;mDADA;6EA9ERt+D;;qDA8EQ;;2EA9ERokK,KA8EQ5lG;;;kDADA;4EA7ERx+D;;oDA6EQ;;0EA7ERokK,KA6EQ1lG;;;iDAHA;2EA1ER1+D;;mDA0EQ;;yEA1ERokK,KA0EQxlG;;2DA1ER;;;;8CAgKiB;+BAhKjB;;;;;;sCA0EQq2G;gCA1ER,MA2EQC;gCA3ER,MA4EQC;gCA5ER,MA6EQC;gCA7ER,MA8EQC;gCA9ER,MA+EQC;gCA/ER,MAgFQC;gCAhFR,MAiFQC;gCAjFR,MAkFQC;gCAlFR,MAmFQC;gCAnFR,MAoFQC;gCApFR,MAqFQC;gCArFR,MAsFQC;gCAtFR,MAuFQC;gCAvFR,MAwFQC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCADAE;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;;;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;+BAxFR;;;;kDA0EQf;;mDACAC;;oDACAC;;qDACAC;;sDACAC;;uDACAC;;wDACAC;;yDACAC;;0DACAC;;2DACAC;;4DACAC;;6DACAC;;8DACAC;;+DACAC;kEACAC;;;gCAxFRgB;gCA2FQC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACmBC;gCACnBC;gCACAC;gCACA/zH;gCAtGRg0H;;;;;;;;;;;;;;;;;;;;;;;kGAgKiB;sDAhKjBz3K;;;;;;;;;;;;;kDAsGQ;8EAtGRy3K;;oDAsGQ;;0EAtGR5+F,KAsGQra;;;iDAPA;6EA/FRi5G;;mDA+FQ;;yEA/FRvT,KA+FQxlG;;;gDADA;4EA9FR+4G;;kDA8FQ;;wEA9FRvT,KA8FQtlG;;;+CAEA;2EAhGR64G;;iDAgGQ;;uEAhGRvT,KAgGQplG;;;8CAJA;0EA5FR24G;;gDA4FQ;;sEA5FRvT,KA4FQtmG;;;6CADA;yEA3FR65G;;+CA2FQ;;qEA3FRvT,KA2FQpqD;;;;;;;;;;;kDAEA;8EA7FR29D;;oDA6FQ;;0EA7FRvT,KA6FQlqD;;;iDAQA;6EArGRy9D;;mDAqGQ;;yEArGR5+F,KAqGQqhC;;;gDADA;4EApGRu9D;;kDAoGQ;;wEApGR5+F,KAoGQuhC;;;+CADmB;2EAnG3Bq9D;;iDAmG2B;;uEAnG3B5+F,KAmG2ByhC;;;8CAFnB;0EAjGRm9D;;gDAiGQ;;sEAjGRvT,KAiGQ1pD;;;6CACA;yEAlGRi9D;;+CAkGQ;;qEAlGRvT,KAkGQxpD;;wDAlGR;;;;;;;;;;wCA2FQo8D;kCA3FR,MA4FQC;kCA5FR,MA6FQC;kCA7FR,MA8FQC;kCA9FR,MA+FQC;kCA/FR,MAgGQC;kCAhGR,MAiGQC;kCAjGR,MAkGQC;kCAlGR,MAmG2BC;kCAnG3B,MAoGQC;kCApGR,MAqGQC;kCArGR,MAsGQ/zH;;;;;;;;;;;;;;;;;;;;;;;;;;;oCADAm0H;oCADAC;oCADmBC;oCADnBC;oCADAC;oCADAC;oCADAC;oCADAC;oCADAC;oCADAC;oCADAC;;;2CACAD;2CACAD;2CACAD;2CACAD;2CACAD;2CACAD;2CACAD;2CACmBD;2CACnBD;2CACAD;2CACA9yH;iCAtGR;;;;oDA2FQgyH;;qDACAC;;sDACAC;;uDACAC;;wDACAC;;yDACAC;;0DACAC;;2DACAC;;4DACmBC;;6DACnBC;;8DACAC;iEACA/zH;;;gCAtGR80H;gCAyGQC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACmBC;gCACnBC;gCACAC;gCACAC;gCAvIRC;;;;mC;mCAAA;;;;;;;;;;6CwHuXI;+CxHvXJ;;;;;;;;;sGAgKiB;0DAhKjBv6K;;;;;;;;;;;;;;;;;;2DA8GQ;uFA9GRu6K;;6DA8GQ;;gFA9GRrW,KA8GQjlH;;;0DADA;sFA7GRs7H;;4DA6GQ;;iFA7GRrW,KA6GQhlH;;;yDADA;qFA5GRq7H;;2DA4GQ;;gFA5GRrW,KA4GQ9kH;;;wDAIA;oFAhHRm7H;;0DAgHQ;;+EAhHRrW,KAgHQllH;;;uDADA;mFA/GRu7H;;yDA+GQ;;8EA/GRrW,KA+GQhgH;;;sDAKA;kFApHRq2H;;wDAoHQ;;6EApHRrW,KAoHQ9/G;;;qDADA;iFAnHRm2H;;uDAmHQ;;4EAnHRrW,KAmHQ5/G;;;oDADA;gFAlHRi2H;;sDAkHQ;;2EAlHRrW,KAkHQlgH;;;;;;;;;;;;0DADA;sFAjHRu2H;;4DAiHQ;;iFAjHRrW,KAiHQpmG;;;yDAIA;qFArHRy8G;;2DAqHQ;;gFArHRrW,KAqHQlmG;;;wDAEA;oFAvHRu8G;;0DAuHQ;;+EAvHRrW,KAuHQhmG;;;uDADA;mFAtHRq8G;;yDAsHQ;;+EAtHRrW,KAsHQ9lG;;;sDAiBA;kFAvIRm8G;;wDAuIQ;;8EAvIR1hG,KAuIQva;;;qDADA;iFAtIRi8G;;uDAsIQ;;6EAtIR1hG,KAsIQra;;;oDADA;gFArIR+7G;;sDAqIQ;;4EArIR1hG,KAqIQna;;;;kDA1BA;8EA3GR67G;;oDA2GQ;;0EA3GRrW,KA2GQtlG;;;;;;;;;;;;;;;;0DADA;sFA1GR27G;;4DA0GQ;;kFA1GRrW,KA0GQplG;;;yDADA;qFAzGRy7G;;2DAyGQ;;iFAzGRrW,KAyGQtmG;;;wDA2BmB;oFApI3B28G;;0DAoI2B;;gFApI3B1hG,KAoI2BihC;;;uDADnB;mFAnIRygE;;yDAmIQ;;+EAnIRrW,KAmIQlqD;;;sDADA;kFAlIRugE;;wDAkIQ;;8EAlIRrW,KAkIQhqD;;;qDADA;iFAjIRqgE;;uDAiIQ;;6EAjIRrW,KAiIQ9pD;;;oDADA;gFAhIRmgE;;sDAgIQ;;4EAhIRrW,KAgIQ5pD;;;mDADA;+EA/HRigE;;qDA+HQ;;2EA/HRrW,KA+HQ1pD;;;;;;;;;;;;yDADA;qFA9HR+/D;;2DA8HQ;;iFA9HRrW,KA8HQxpD;;;wDADA;oFA7HR6/D;;0DA6HQ;;gFA7HRrW,KA6HQtqD;;;uDADA;mFA5HR2gE;;yDA4HQ;;+EA5HRrW,KA4HQmF;;;sDADA;kFA3HRkR;;wDA2HQ;;8EA3HRrW,KA2HQoF;;;qDADA;iFA1HRiR;;uDA0HQ;;6EA1HRrW,KA0HQqF;;;oDADA;gFAzHRgR;;sDAyHQ;;4EAzHRrW,KAyHQuF;;;mDADA;+EAxHR8Q;;qDAwHQ;;2EAxHRrW,KAwHQkH;;;6DAxHR;;;;8CAgKiB;+BAhKjB;;;;;;;sCAyGQoN;gCAzGR,MA0GQC;gCA1GR,MA2GQC;gCA3GR,MA4GQC;gCA5GR,MA6GQC;gCA7GR,MA8GQC;gCA9GR,MA+GQC;gCA/GR,MAgHQC;gCAhHR,MAiHQC;gCAjHR,MAkHQC;gCAlHR,MAmHQC;gCAnHR,MAoHQC;gCApHR,MAqHQC;gCArHR,MAsHQC;gCAtHR,MAuHQC;gCAvHR,MAwHQC;gCAxHR,MAyHQC;gCAzHR,MA0HQC;gCA1HR,MA2HQC;gCA3HR,MA4HQC;gCA5HR,MA6HQC;gCA7HR,MA8HQC;gCA9HR,MA+HQC;gCA/HR,MAgIQC;gCAhIR,MAiIQC;gCAjIR,MAkIQC;gCAlIR,MAmIQC;gCAnIR,MAoI2BC;gCApI3B,MAqIQC;gCArIR,MAsIQC;gCAtIR,MAuIQC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCADAK;kCADAC;kCADmBC;kCADnBC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;;;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACmBD;yCACnBD;yCACAD;yCACAD;+BAvIR;;;;kDAyGQlC;;mDACAC;;oDACAC;;qDACAC;;sDACAC;;uDACAC;;wDACAC;;yDACAC;;0DACAC;;2DACAC;;4DACAC;;6DACAC;;8DACAC;;+DACAC;;gEACAC;;iEACAC;;kEACAC;;mEACAC;;oEACAC;;qEACAC;;sEACAC;;uEACAC;;wEACAC;;yEACAC;;0EACAC;;2EACAC;;4EACAC;;6EACmBC;;8EACnBC;;+EACAC;kFACAC;;;gCAvIRlmD;gCA2IQqoD;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACAC;gCACmBC;gCA1J3BhpD;;;;mC;mCAAA;;;;;;;;;;6CwHuXI;+CxHvXJ;;;;;;;;;sGAgKiB;0DAhKjBx0H;;;;;;;;;;;;;;;wDA2IQ;oFA3IRw0H;;0DA2IQ;;6EA3IR0vC,KA2IQjlH;;;uDAemB;mFA1J3Bu1E;;yDA0J2B;;8EA1J3B37C,KA0J2B35B;;;sDAdnB;kFA5IRs1E;;wDA4IQ;;6EA5IR0vC,KA4IQ9kH;;;qDACA;iFA7IRo1E;;uDA6IQ;;4EA7IR0vC,KA6IQllH;;;oDAIA;gFAjJRw1E;;sDAiJQ;;2EAjJR0vC,KAiJQhgH;;;mDADA;+EAhJRswE;;qDAgJQ;;0EAhJR0vC,KAgJQ9/G;;;kDADA;8EA/IRowE;;oDA+IQ;;yEA/IR0vC,KA+IQ5/G;;;iDADA;6EA9IRkwE;;mDA8IQ;;wEA9IR0vC,KA8IQlgH;;;;;;;;;;;;;wDAWA;oFAzJRwwE;;0DAyJQ;;+EAzJR0vC,KAyJQpmG;;;uDADA;mFAxJR02D;;yDAwJQ;;8EAxJR0vC,KAwJQlmG;;;sDADA;kFAvJRw2D;;wDAuJQ;;6EAvJR0vC,KAuJQhmG;;;qDADA;iFAtJRs2D;;uDAsJQ;;6EAtJR0vC,KAsJQ9lG;;;oDADA;gFArJRo2D;;sDAqJQ;;4EArJR0vC,KAqJQ5lG;;;mDADA;+EApJRk2D;;qDAoJQ;;2EApJR0vC,KAoJQ1lG;;;kDADA;8EAnJRg2D;;oDAmJQ;;0EAnJR0vC,KAmJQxlG;;;iDADA;6EAlJR81D;;mDAkJQ;;yEAlJR0vC,KAkJQtlG;;2DAlJR;;;;8CAgKiB;+BAhKjB;;;;;;;sCA2IQ69G;gCA3IR,MA4IQC;gCA5IR,MA6IQC;gCA7IR,MA8IQC;gCA9IR,MA+IQC;gCA/IR,MAgJQC;gCAhJR,MAiJQC;gCAjJR,MAkJQC;gCAlJR,MAmJQC;gCAnJR,MAoJQC;gCApJR,MAqJQC;gCArJR,MAsJQC;gCAtJR,MAuJQC;gCAvJR,MAwJQC;gCAxJR,MAyJQC;gCAzJR,MA0J2BC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCADnBE;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;;;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACAD;yCACmBD;+BA1J3B;;;;kDA2IQhB;;mDACAC;;oDACAC;;qDACAC;;sDACAC;;uDACAC;;wDACAC;;yDACAC;;0DACAC;;2DACAC;;4DACAC;;6DACAC;;8DACAC;;+DACAC;;gEACAC;mEACmBC;;;gCA1J3BiB;gCA4J6BC;gCAAYC;gCA5JzCC;;;;;;;;;;;;;;;;;;;;;;;kGAgKiB;sDAhKjB5+K;;;;;;6CA4J6B;0EA5J7B4+K;;+CA4J6B;;;;;4CAAY;yEA5JzCA;;8CA4JyC;;;gD2H5GvCv5M;kE,OAAAA,c3HhDFwzG;kDA4JyCsmG;;2CA5JzC;;;;;;;;2CA4J6BT,cA5J7B,MA4JyCC;;2DAAZW;yDAAYD;iCA5JzC;;;;oDA4J6BX;uDAAYC;;;gCA5JzCY;gCA6J4BC;gCAAYC;gCA7JxCC;;;;;;;;;;;;;;;;;;;;;;;kGAgKiB;sDAhKjB1/K;;;;;;6CA6J4B;0EA7J5B0/K;;+CA6J4B;;;;;4CAAY;yEA7JxCA;;8CA6JwC;;yD2H7GtCr6M,c3HhDFwzG,KA6JwConG;;2CA7JxC;;;;;;;;2CA6J4BT,YA7J5B,MA6JwCC;;mEAAZW;uDAAYD;iCA7JxC;;;;oDA6J4BX;uDAAYC;;;gCA7JxC1qD;gCA+JQsrD;gCAA2BC;gCAAmBC;gCA/JtDprD;;;;;;;;;;;;;;;;;;;;;;;kGAgKiB;sDAhKjBn1H;;;;;;;8CA+JmC;0EA/JnCm1H;;gDA+JmC;;wD2H/GjC9vJ,c3HhDF6+L,KA+JmCjlH;;;6CAA3B;yEA/JRk2E;;+CA+JQ;;;;;4CAA8C;wEA/JtDA;;8CA+JsD;;wD2H/GpD9vJ,c3HhDFwzG,KA+JsDz5B;;2CA/JtD;;;;;;;;;wCA+JQihI;kCA/JR,MA+JmCC;kCA/JnC,MA+JsDC;;;;oCAAnBG;oCAA3BC;yDAA2BD,aAAmBD;iCA/JtD;;;;oDA+JQJ;;qDAA2BC;wDAAmBC;;0BA/JtD,sCAgKiB;uBAvTrB;iCAuJIrc;;;6BAC8D;;8BAAR4c;8BAAbC;8BAAbC;8BAAbC;8BAA+C,eAD9DpoG,KAC8DgoG;;8BAAR,iBADtDhoG,KACsDioG;kEAAQ7/K;8BAAR,GAAb8/K;8BAAa,GAAbA;8BAAIprQ,gBAD7CkjK,KAC6Cr1N;8CAD7C0gT,KAC6CpoP;8BAAJwlC,YAAI3rC;8BAAJmyF,oCAAa5G;8BAAtBpC,KAAJkiL;8BAAIpgL,KAAJogL;8BAAIngL,gBADhCg4E,KACgCj4E;8CADhCsjK,KACgCplK;8BAAJt9C,YAAIq/C;8BAAJkH,oCAAaD;8BAAtB1H,KAAJ6gL;8BAAI9hL,KAAJ8hL;8BAAI7hL,gBADnBy5E,KACmB15E;8CADnB+kK,KACmB9jK;8BAAJz+C,YAAIy9C;8BAAJub,oCAAa5S;gDAAb4S;;6BAEb;;;8BAAgB74D;+B2HmDhBwhB;iD,OAAAA,c3HtDF4gM,aAGkBgd;kEAAhB37H;gDAAgBC;;6BASV;;8BADA47H;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BAOA,iBAZRxd,KAYQid;;8BADA,iBAXRjd,KAWQkd;kEACAjgH;8BAFA,iBAVR+iG,KAUQmd;kEACAhgH;8BAFA,iBATR6iG,KASQod;kEACA//G;8BAFA,iBARR2iG,KAQQqd;mEACA9/G;8BADA,KADA+/G;8BACA,KADAA;8BAAKjiL,gBAPb2kK,KAOa5kK;8CAPb4kK,KAOazlK;8BAALijE,aAAKniE;8BAALsiE,sCACAF;8BAFKt6D,KAALo6K;8BAAKhhL,KAALghL;8BAAK/gL,gBANbwjK,KAMazjK;8CANbyjK,KAMa78J;8BAALu6D,aAAKlhE;8BAALqhE,sCACAF;8BAFKp6D,KAALi6K;8BAAKhiL,KAALgiL;8BAAK/hL,iBALbukK,KAKaxkK;+CALbwkK,KAKaz8J;8BAALq6D,aAAKniE;8BAALsiE,sCACAF;gDADAE;;6BASN;;;8BAAgBD;+B2HwChB1+F;;mCnIzMF;;;;;;;oCAMI,eQ6IJ4gM,KR7II0d;;oCADA,iBQ8IJ1d,KR9II2d;wEACA5gL;oCADA,GADA6gL;oCACA,GADAA;oCAAOnsQ,gBQ+IXuuP,KR/IW1gT;oDQ+IX0gT,KR/IWpoP;oCAAPwlC,YAAO3rC;oCAAPmyF,oCACA5G;oCAFA1/C,MmIsMF8hB,c3HtDF4gM,KRhJI6d;wEACAj6K;oCAFAnmD,MmIuMF2hB,c3HtDF4gM,KRjJIjgC;wEACAl8H;oCAFAjmD;qCmIwMFwhB;;;0CnIxMUxnD;;0DQkJZooP,KRlJY1gT;0DQkJZ0gT,KRlJYpoP;;uCAARkmQ;wEACArnK;6CADA4qC;iCQgKco8H;oEAAhBx/G;gDAAgBE;;6BAE4C;;8BAAT6/G;8BAATC;8BAApCC;8BAAsD,kBAhB9Dle,KAgB8D+d;;8BAAT,kBAhBrD/d,KAgBqDge;oEAASpgE;8BAAlB,kBAhB5CoiD,KAgB4Cie;oEAASngE;8BAA7CD;+B2HsCNz+I;;mC9HxMF;;;;;;;;;;;;;;oCAaI,eGqIJ4gM,KHrIIme;;oCADA,iBGsIJne,KHtIIoe;wEACArhL;oCAFA,iBGuIJijK,KHvIIqe;wEACArhL;oCAFA,iBGwIJgjK,KHxIIse;wEACA16K;oCAFA,iBGyIJo8J,KHzIIue;wEACA16K;oCAFA,iBG0IJm8J,KH1IIwe;wEACA/nK;oCAFA,iBG2IJupJ,KH3IIye;wEACAp9H;oCAFA,iBG4IJ2+G,KH5II0e;wEACAp9H;oCAFA,iBG6IJ0+G,KH7II+d;wEACA9gH;oCAFA,iBG8IJ+iG,KH9II2e;wEACAxhH;oCAFA,iBG+IJ6iG,KH/II4e;wEACAvhH;oCAFA,kBGgJJ2iG,KHhJI6e;0EACAthH;oCAFA,kBGiJJyiG,KHjJI8e;0EACArhH;mCADA;iCGiKIygH;oEAAoClgE;gDAApCE;;6BACN;;;8BAAqBH;+B2HqCrB3+I;;mC7HzMF;;;;;;;;;;;;;;;oCAcI,eEqIJ4gM,KFrIIgf;;oCADA,iBEsIJhf,KFtIIif;wEACAliL;oCAFA,iBEuIJijK,KFvIIkf;wEACAliL;oCAFA,iBEwIJgjK,KFxIImf;wEACAv7K;oCAFA,iBEyIJo8J,KFzIIof;wEACAv7K;oCAFA,iBE0IJm8J,KF1IIqf;wEACA5oK;oCAFA,iBE2IJupJ,KF3IIsf;wEACAj+H;oCAFA,iBE4IJ2+G,KF5IIuf;wEACAj+H;oCAFA,iBE6IJ0+G,KF7IIwf;wEACAviH;oCAFA,iBE8IJ+iG,KF9IIyf;wEACAtiH;oCAFA,iBE+IJ6iG,KF/II0f;wEACAriH;oCAFA,kBEgJJ2iG,KFhJI2f;0EACApiH;oCAFA,kBEiJJyiG,KFjJI4f;0EACAniH;oCAFA,kBEkJJuiG,KFlJI6f;0EACAliH;mCADA;iCEmKmBohH;oEAArB3gE;gDAAqBE;;6BAEuC;;8BAATyhE;8BAATC;8BAATC;8BAATC;8BAATC;8BAATC;8BAAsD,kBAnB9DpgB,KAmB8D8f;;8BAAT,kBAnBrD9f,KAmBqD+f;oEAASvhE;8BAAlB,kBAnB5CwhD,KAmB4CggB;oEAASthE;8BAAlB,kBAnBnCshD,KAmBmCigB;oEAAShwB;8BAAlB,kBAnB1B+P,KAmB0BkgB;oEAAS/vB;8BAAlB,kBAnBjB6P,KAmBiBmgB;oEAAS9vB;8BAAlB,kBAnBR2P,KAmBQogB;oEAAS7vB;6BAAT;;6BAkBA;;8BAFA+vB;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BAgBA,kBArCRzsG,KAqCQ0rG;;8BAFA,kBAnCRrgB,KAmCQsgB;oEAEA1wB;8BAHA,kBAlCRoQ,KAkCQugB;oEACAxwB;8BAFA,kBAjCRiQ,KAiCQwgB;oEACA7vB;8BAFA,kBAhCRqP,KAgCQygB;oEACA3vB;8BAFA,kBA/BRkP,KA+BQ0gB;oEACA1vB;8BAFA,kBA9BRgP,KA8BQ2gB;oEACAzvB;8BAFA,kBA7BR8O,KA6BQ4gB;oEACAxvB;8BAFA,kBA5BR4O,KA4BQ6gB;oEACAvvB;8BAFA,kBA3BR0O,KA2BQ8gB;oEACAjxB;8BAFA,kBA1BRmQ,KA0BQ+gB;oEACAlwB;8BAFA,kBAzBRmP,KAyBQghB;oEACAxvB;8BAFA,kBAxBRwO,KAwBQihB;oEACAI;8BAFA,kBAvBRrhB,KAuBQkhB;oEACAK;8BAFA,kBAtBRvhB,KAsBQmhB;oEACAM;8BAFA,kBArBRzhB,KAqBQohB;oEACAO;6BADA;;6BAkDA;;8BADAI;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADeC;8BADfC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BA6BA,kBAvER3jB,KAuEQ8hB;;8BADA,kBAtER9hB,KAsEQ+hB;oEACA8B;8BAFA,kBArER7jB,KAqEQgiB;oEACA+B;8BAFA,kBApER/jB,KAoEQiiB;oEACAgC;8BAFA,kBAnERjkB,KAmEQkiB;oEACAiC;8BAFA,kBAlERnkB,KAkEQmiB;oEACAkC;8BAFA,kBAjERrkB,KAiEQoiB;oEACAmC;8BAFA,kBAhERvkB,KAgEQqiB;oEACAoC;8BAFA,kBA/DRzkB,KA+DQsiB;oEACAqC;8BAFA,kBA9DR3kB,KA8DQuiB;oEACAsC;8BAFA,kBA7DR7kB,KA6DQwiB;oEACAuC;8BAFA,kBA5DR/kB,KA4DQyiB;oEACAwC;8BAFA,kBA3DRjlB,KA2DQ0iB;oEACAyC;8BAFA,kBA1DRnlB,KA0DQ2iB;oEACA0C;8BAFe,kBAzDvBrlB,KAyDuB4iB;oEACf2C;8BAFA,kBAxDRvlB,KAwDQ6iB;oEACe4C;8BAFf,kBAvDRzlB,KAuDQ8iB;oEACA6C;8BAFA,kBAtDR3lB,KAsDQ+iB;oEACA8C;8BAFA,kBArDR7lB,KAqDQgjB;oEACA+C;8BAFA,kBApDR/lB,KAoDQijB;oEACAgD;8BAFA,kBAnDRjmB,KAmDQkjB;oEACAiD;8BAFA,kBAlDRnmB,KAkDQmjB;oEACAkD;8BAFA,kBAjDRrmB,KAiDQojB;oEACAmD;8BAFA,kBAhDRvmB,KAgDQqjB;oEACAoD;8BAFA,kBA/CRzmB,KA+CQsjB;oEACAqD;8BAFA,kBA9CR3mB,KA8CQujB;oEACAsD;8BAFA,kBA7CR7mB,KA6CQwjB;oEACAuD;8BAFA,kBA5CR/mB,KA4CQyjB;oEACAwD;8BAFA,kBA3CRjnB,KA2CQ0jB;oEACAyD;8BAFA,kBA1CRnnB,KA0CQ2jB;oEACA0D;6BADA;;6BA8CA;;8BADAI;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BAcA,kBAxFRtoB,KAwFQwnB;;8BADA,kBAvFRxnB,KAuFQynB;oEACAe;8BAFA,kBAtFRxoB,KAsFQ0nB;oEACAgB;8BAFA,kBArFR1oB,KAqFQ2nB;oEACAiB;8BAFA,kBApFR5oB,KAoFQ4nB;oEACAkB;8BAFA,kBAnFR9oB,KAmFQ6nB;oEACAmB;8BAFA,kBAlFRhpB,KAkFQ8nB;oEACAoB;8BAFA,kBAjFRlpB,KAiFQ+nB;oEACAqB;8BAFA,kBAhFRppB,KAgFQgoB;oEACAsB;8BAFA,kBA/ERtpB,KA+EQioB;oEACAuB;8BAFA,kBA9ERxpB,KA8EQkoB;oEACAwB;8BAFA,kBA7ER1pB,KA6EQmoB;oEACAyB;8BAFA,kBA5ER5pB,KA4EQooB;oEACA0B;8BAFA,kBA3ER9pB,KA2EQqoB;oEACA2B;8BAFA,kBA1ERhqB,KA0EQsoB;oEACA4B;6BADA;;6BA4BA;;8BADAG;8BADAC;8BADmBC;8BADnBC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BAWA,kBAtGRp2G,KAsGQvzB;;8BADA,kBArGRuzB,KAqGQ01G;oEACAY;8BAFA,kBApGRt2G,KAoGQ21G;oEACAa;8BAFmB,kBAnG3Bx2G,KAmG2B41G;oEACnBc;8BAFA,kBAlGRrrB,KAkGQwqB;oEACmBe;8BAFnB,kBAjGRvrB,KAiGQyqB;oEACAgB;8BAFA,kBAhGRzrB,KAgGQ0qB;oEACAiB;8BAFA,kBA/FR3rB,KA+FQ2qB;oEACAkB;8BAFA,kBA9FR7rB,KA8FQ4qB;oEACAmB;8BAFA,kBA7FR/rB,KA6FQ6qB;oEACAoB;8BAFA,kBA5FRjsB,KA4FQ8qB;qEACAqB;8BAFA,kBA3FRnsB,KA2FQ+qB;qEACAsB;6BADA;;6BA4CA;;8BADAI;8BADAC;8BADmBC;8BADnBC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BA8BA,kBAvIR35G,KAuIQ63G;;8BADA,mBAtIR73G,KAsIQ83G;sEACA+B;8BAFA,mBArIR75G,KAqIQ+3G;sEACAgC;8BAFmB,mBApI3B/5G,KAoI2Bg4G;sEACnBiC;8BAFA,mBAnIR5uB,KAmIQ4sB;sEACmBkC;8BAFnB,mBAlIR9uB,KAkIQ6sB;sEACAmC;8BAFA,mBAjIRhvB,KAiIQ8sB;sEACAoC;8BAFA,mBAhIRlvB,KAgIQ+sB;sEACAqC;8BAFA,mBA/HRpvB,KA+HQgtB;sEACAsC;8BAFA,mBA9HRtvB,KA8HQitB;sEACAuC;8BAFA,mBA7HRxvB,KA6HQktB;sEACAwC;8BAFA,mBA5HR1vB,KA4HQmtB;sEACAyC;8BAFA,mBA3HR5vB,KA2HQotB;sEACA0C;8BAFA,mBA1HR9vB,KA0HQqtB;sEACA2C;8BAFA,mBAzHRhwB,KAyHQstB;sEACA4C;8BAFA,mBAxHRlwB,KAwHQutB;sEACA6C;8BAFA,mBAvHRpwB,KAuHQwtB;sEACA8C;8BAFA,mBAtHRtwB,KAsHQytB;sEACA+C;8BAFA,mBArHRxwB,KAqHQ0tB;sEACAgD;8BAFA,mBApHR1wB,KAoHQ2tB;sEACAiD;8BAFA,mBAnHR5wB,KAmHQ4tB;sEACAkD;8BAFA,mBAlHR9wB,KAkHQ6tB;sEACAmD;8BAFA,mBAjHRhxB,KAiHQ8tB;sEACAoD;8BAFA,mBAhHRlxB,KAgHQ+tB;sEACAqD;8BAFA,mBA/GRpxB,KA+GQguB;sEACAsD;8BAFA,mBA9GRtxB,KA8GQiuB;sEACAuD;8BAFA,mBA7GRxxB,KA6GQkuB;sEACAwD;8BAFA,mBA5GR1xB,KA4GQmuB;sEACAyD;8BAFA,mBA3GR5xB,KA2GQouB;sEACA0D;8BAFA,mBA1GR9xB,KA0GQquB;sEACA2D;8BAFA,mBAzGRhyB,KAyGQsuB;sEACA4D;6BADA;;6BAiDmB;;8BADnBI;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BADAC;8BAemB,mBA1J3Bz+G,KA0J2B09G;;8BADnB,mBAzJRryB,KAyJQsyB;sEACmBgB;8BAFnB,mBAxJRtzB,KAwJQuyB;sEACAiB;8BAFA,mBAvJRxzB,KAuJQwyB;sEACAkB;8BAFA,mBAtJR1zB,KAsJQyyB;sEACAmB;8BAFA,mBArJR5zB,KAqJQ0yB;sEACAoB;8BAFA,mBApJR9zB,KAoJQ2yB;sEACAqB;8BAFA,mBAnJRh0B,KAmJQ4yB;sEACAsB;8BAFA,mBAlJRl0B,KAkJQ6yB;sEACAuB;8BAFA,mBAjJRp0B,KAiJQ8yB;sEACAwB;8BAFA,mBAhJRt0B,KAgJQ+yB;sEACAyB;8BAFA,mBA/IRx0B,KA+IQgzB;sEACA0B;8BAFA,mBA9IR10B,KA8IQizB;sEACA2B;8BAFA,mBA7IR50B,KA6IQkzB;sEACA4B;8BAFA,mBA5IR90B,KA4IQmzB;sEACA6B;8BAFA,mBA3IRh1B,KA2IQozB;sEACA8B;6BADA;;6BAiBqB;8BAAYG;8BAAZ/rD;8BAA3BgsD;8BAAuCC;+B2HtGvCn2N;iD,OAAAA,c3HtDFu1G,aA4JyC0gH;sEAAvCC;8BAA2B,mB6H9OvBtjM,a7H8OuBs3I;sEAAYksD;6BAAZ;;6BACD;8BAAYG;8BAAZC;8BAAYC,Q2HvGtCz2N,c3HtDFu1G,KA6JwCghH;;8BAAZ,mB6H/OtB3jM,a7H+OsB4jM;sEAAYE;6BAAZ;;;8BAE0BG;8BAAnBC;8BAA3BC;8BAA8CC,Q2HzGpDh3N,c3HtDFu1G,KA+JsDshH;;8BAAnBK,Q2HzGjCl3N,c3HtDF4gM,KA+JmCk2B;sEAAmBG;6BA/SxD,OA+SUF;;;;;;;;;;;;;;;;;;;yEAA2BI;gDAA3BE,WACS;uBAvTrB;iCA0T0Bv2U,EAAgBP;0BACpC,SAAIg3U;4BAAkB,IAAXz7U,WAAHyB,WAAc,iBADcgD,EACzBzE;4BAAM,qBADmByE,EAC5BhD;0BAAR,OADoBuD;;6BAKc;8BAFZC,EAHFD;8BAGD6S,EAHC7S;8BAGJgb,EAHIhb;8BAGP3B,EAHO2B;8BAGVT,EAHUS;8BAIZuT;;qCAAMvY,WAAHyB,WAAY,UAAZA,EAAY,WAJagD,EAItBzE;8BACoB,QAFlBggB;8BAES,QAFZ3c;6BAEG,YAFNkB,eAASsT,EAAG5S;;6BAIlB,IADSshB,MANOvhB;6BAOG,eADVuhB,eAC4B9kB,GAAK,YAALA,EAPLgD,EAOwB;;6BAU1C;8BATyCi3U,QARvC12U;8BAQgC22U,MARhC32U;8BAQyB42U,MARzB52U;8BAQiB62U,OARjB72U;8BAQY82U,IARZ92U;8BAQQ+2U,GARR/2U;8BAQI+nQ,GARJ/nQ;8BAQAgoQ,GARAhoQ;8BAiBF,iBAjBkBP,EAQuBi3U;8BAQ3C,iBAhBoBj3U,EAQgBk3U;8BAOpC,iBAfoBl3U,EAQSm3U;8BAM5B,iBAdmBn3U,EAQCo3U;8BAKvB,iBAbsBp3U,EAQJq3U;8BAInB,SAJeC;8BAGf,SAHWhvE;6BAEX,aAFOC;;6BAYhB,IADSvlN,QAnBOziD;6BAqBJ,eAFHyiD,iBAEqBhmD,GAAK,cAALA,EArBEgD,EAqBuB;;6BAM3C;8BALgB0+S,MAtBZn+S;8BAsBQmpH,GAtBRnpH;8BAsBI+vE,GAtBJ/vE;8BAsBHwiD,QAtBGxiD;8BA2BJ,iBA3BoBP,EAsBJ0+S;8BAInB,iBA1BuB1+S,EAsBR0pH;8BAGf,iBAzBuB1pH,EAsBZswE;6BAER;0CAFCvtB,iBAEiB/lD,GAAK,cAALA,EAxBEgD,EAwB2B;;;;;6BAM3D,IADc8iD,QA7BEviD;6BAgCV,eAHQuiD,iBAGU9lD,GAAK,cAALA,EAhCQgD,EAgC4B;;6BAUnD;8BARsBspS,GAlCf/oS;8BAkCWgpS,GAlCXhpS;8BAkCOipS,GAlCPjpS;8BAkCGkpS,GAlCHlpS;8BAkCDmpS,GAlCCnpS;8BAkCLopS,GAlCKppS;8BAkCTqpS,GAlCSrpS;8BA0CP,iBA1CuBP,EAkCDspS;8BAOtB,iBAzCuBtpS,EAkCLupS;8BAMlB,iBAxCuBvpS,EAkCTwpS;8BAKd,iBAvCuBxpS,EAkCbypS;8BAIV,iBAtCuBzpS,EAkCjB0pS;8BAGN,iBArCuB1pS,EAkCrB2pS;6BAEF;gDApCuB3pS,EAkCzB4pS;;;;;;;;6BA2CI;8BAjBT2tC,QA5Dch3U;8BA2Ddi3U,KA3Dcj3U;8BA0Ddk3U,KA1Dcl3U;8BAyDdm3U,KAzDcn3U;8BAwDdo3U,KAxDcp3U;8BAuDdq3U,KAvDcr3U;8BAsDds3U,KAtDct3U;8BAqDdu3U,KArDcv3U;8BAoDdw3U,KApDcx3U;8BAmDdy3U,KAnDcz3U;8BAkDd03U,KAlDc13U;8BAiDd23U,KAjDc33U;8BAgDd43U,KAhDc53U;8BA+Cd63U,KA/Cc73U;8BA8Cd83U,KA9Cc93U;8BA6CdZ,GA7CcY;8BA6EL,iBA7EqBP,EA2D9Bw3U;8BAiBS,iBA5EqBx3U,EA0D9By3U;8BAiBS,iBA3EqBz3U,EAyD9B03U;8BAiBS,iBA1EqB13U,EAwD9B23U;8BAiBS,iBAzEqB33U,EAuD9B43U;8BAiBS,iBAxEqB53U,EAsD9B63U;8BAiBS,iBAvEqB73U,EAqD9B83U;8BAiBS,iBAtEqB93U,EAoD9B+3U;8BAiBS,iBArEqB/3U,EAmD9Bg4U;8BAiBS,iBApEqBh4U,EAkD9Bi4U;8BAiBS,iBAnEqBj4U,EAiD9Bk4U;8BAiBS,iBAlEqBl4U,EAgD9Bm4U;8BAiBS,iBAjEqBn4U,EA+C9Bo4U;8BAiBS,iBAhEqBp4U,EA8C9Bq4U;6BAiBO;gDA/DuBr4U,EA6C9BL;;;;;;;;;;;;;;;qCAeA43U;;6BAkFU;8BAhCVe,MA9Gc/3U;8BA6Gdg4U,MA7Gch4U;8BA4Gdi4U,MA5Gcj4U;8BA2Gdk4U,MA3Gcl4U;8BA0Gdm4U,MA1Gcn4U;8BAyGdo4U,MAzGcp4U;8BAwGdq4U,MAxGcr4U;8BAuGds4U,MAvGct4U;8BAsGdu4U,KAtGcv4U;8BAqGdw4U,KArGcx4U;8BAoGdy4U,OApGcz4U;8BAmGd04U,OAnGc14U;8BAkGd24U,MAlGc34U;8BAiGd44U,MAjGc54U;8BAgGC64U,KAhGD74U;8BA+Fd84U,KA/Fc94U;8BA8Fd+4U,KA9Fc/4U;8BA6Fdg5U,KA7Fch5U;8BA4Fdi5U,KA5Fcj5U;8BA2Fdk5U,KA3Fcl5U;8BA0Fdm5U,KA1Fcn5U;8BAyFdo5U,KAzFcp5U;8BAwFdq5U,KAxFcr5U;8BAuFds5U,KAvFct5U;8BAsFdu5U,KAtFcv5U;8BAqFdw5U,KArFcx5U;8BAoFdy5U,KApFcz5U;8BAmFd05U,KAnFc15U;8BAkFdqwP,IAlFcrwP;8BAiFI23D,GAjFJ33D;8BA8IJ,iBA9IoBP,EA8G9Bs4U;8BA+BU,iBA7IoBt4U,EA6G9Bu4U;8BA+BU,iBA5IoBv4U,EA4G9Bw4U;8BA+BU,iBA3IoBx4U,EA2G9By4U;8BA+BU,iBA1IoBz4U,EA0G9B04U;8BA+BU,iBAzIoB14U,EAyG9B24U;8BA+BU,iBAxIoB34U,EAwG9B44U;8BA+BU,iBAvIoB54U,EAuG9B64U;8BA+BS,iBAtIqB74U,EAsG9B84U;8BA+BS,iBArIqB94U,EAqG9B+4U;8BA+BS,iBApIqB/4U,EAoG9Bg5U;8BA+BS,iBAnIqBh5U,EAmG9Bi5U;8BA+BU,iBAlIoBj5U,EAkG9Bk5U;8BA+BU,iBAjIoBl5U,EAiG9Bm5U;8BA+BwB,iBAhIMn5U,EAgGfo5U;8BA+BN,iBA/HqBp5U,EA+F9Bq5U;8BA+BS,iBA9HqBr5U,EA8F9Bs5U;8BA+BS,iBA7HqBt5U,EA6F9Bu5U;8BA+BS,iBA5HqBv5U,EA4F9Bw5U;8BA+BS,iBA3HqBx5U,EA2F9By5U;8BA+BS,iBA1HqBz5U,EA0F9B05U;8BA+BS,iBAzHqB15U,EAyF9B25U;8BA+BS,iBAxHqB35U,EAwF9B45U;8BA+BS,iBAvHqB55U,EAuF9B65U;8BA+BS,iBAtHqB75U,EAsF9B85U;8BA+BS,iBArHqB95U,EAqF9B+5U;8BA+BS,iBApHqB/5U,EAoF9Bg6U;8BA+BS,iBAnHqBh6U,EAmF9Bi6U;8BA+BQ,iBAlHsBj6U,EAkF9B4wP;6BA+ByB;gDAjHK5wP,EAiFZk4D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BA+FR;8BAjBVgiR,MA/Jc35U;8BA8Jd45U,MA9Jc55U;8BA6Jd65U,MA7Jc75U;8BA4Jd85U,MA5Jc95U;8BA2Jd+5U,MA3Jc/5U;8BA0Jdg6U,MA1Jch6U;8BAyJdi6U,MAzJcj6U;8BAwJdk6U,MAxJcl6U;8BAuJdm6U,MAvJcn6U;8BAsJdo6U,MAtJcp6U;8BAqJdq6U,MArJcr6U;8BAoJds6U,MApJct6U;8BAmJd8yC,IAnJc9yC;8BAkJdu6U,IAlJcv6U;8BAiJdw6U,IAjJcx6U;8BAgLJ,iBAhLoBP,EA+J9Bk6U;8BAgBU,iBA/KoBl6U,EA8J9Bm6U;8BAgBU,iBA9KoBn6U,EA6J9Bo6U;8BAgBU,iBA7KoBp6U,EA4J9Bq6U;8BAgBU,iBA5KoBr6U,EA2J9Bs6U;8BAgBU,iBA3KoBt6U,EA0J9Bu6U;8BAgBU,iBA1KoBv6U,EAyJ9Bw6U;8BAgBU,iBAzKoBx6U,EAwJ9By6U;8BAgBU,iBAxKoBz6U,EAuJ9B06U;8BAgBU,iBAvKoB16U,EAsJ9B26U;8BAgBU,iBAtKoB36U,EAqJ9B46U;8BAgBU,iBArKoB56U,EAoJ9B66U;8BAgBQ,iBApKsB76U,EAmJ9BqzC;8BAgBQ,iBAnKsBrzC,EAkJ9B86U;6BAgBQ;gDAlKsB96U,EAiJ9B+6U;;;;;;;;;;;;;;;;6BAuDU;8BAVVn/U,KA9Lc2E;8BA6Ldy6U,uBA7Lcz6U;8BA4Ld06U,uBA5Lc16U;8BA2LK26U,uBA3LL36U;8BA0Ld2H,MA1Lc3H;8BAyLd46U,eAzLc56U;8BAwLd66U,eAxLc76U;8BAuLd86U,eAvLc96U;8BAsLd+6U,eAtLc/6U;8BAqLdg7U,cArLch7U;8BAoLdi7U,cApLcj7U;8BAmLdk7U,cAnLcl7U;8BAwMJ,iBAxMoBP,EA0L9BkI;8BAamB,iBAvMWlI,EAyL9Bm7U;8BAamB,iBAtMWn7U,EAwL9Bo7U;8BAamB,iBArMWp7U,EAuL9Bq7U;8BAamB,iBApMWr7U,EAsL9Bs7U;8BAakB,iBAnMYt7U,EAqL9Bu7U;8BAakB,iBAlMYv7U,EAoL9Bw7U;6BAakB;gDAjMYx7U,EAmL9By7U;;;;;;;;qCAQmBP;qCACnBD;qCACAD;qCACAp/U;;6BA4Ec;8BA7Bd8/U,2BA7Ocn7U;8BA4Odo7U,2BA5Ocp7U;8BA2Odq7U,2BA3Ocr7U;8BA0OKs7U,yBA1OLt7U;8BAyOdu7U,UAzOcv7U;8BAwOdw7U,UAxOcx7U;8BAuOdy7U,UAvOcz7U;8BAsOd07U,UAtOc17U;8BAqOd27U,UArOc37U;8BAoOd47U,UApOc57U;8BAmOd67U,UAnOc77U;8BAkOd87U,UAlOc97U;8BAiOd+7U,UAjOc/7U;8BAgOdg8U,UAhOch8U;8BA+Ndi8U,SA/Ncj8U;8BA8Ndk8U,OA9Ncl8U;8BA6Ndm8U,cA7Ncn8U;8BA4Ndo8U,cA5Ncp8U;8BA2Ndq8U,YA3Ncr8U;8BA0Nds8U,kBA1Nct8U;8BAyNdu8U,UAzNcv8U;8BAwNdw8U,UAxNcx8U;8BAuNdy8U,UAvNcz8U;8BAsNd08U,WAtNc18U;8BAqNd28U,YArNc38U;8BAoNd48U,aApNc58U;8BAmNd68U,aAnNc78U;8BAkNd88U,aAlNc98U;8BAiNd+8U,YAjNc/8U;8BAgNdg9U,YAhNch9U;8BA+Mdi9U,YA/Mcj9U;8BA0QA,iBA1QgBP,EAyO9B87U;8BAgCc,iBAzQgB97U,EAwO9B+7U;8BAgCc,iBAxQgB/7U,EAuO9Bg8U;8BAgCc,iBAvQgBh8U,EAsO9Bi8U;8BAgCc,iBAtQgBj8U,EAqO9Bk8U;8BAgCc,iBArQgBl8U,EAoO9Bm8U;8BAgCc,iBApQgBn8U,EAmO9Bo8U;8BAgCc,iBAnQgBp8U,EAkO9Bq8U;8BAgCc,iBAlQgBr8U,EAiO9Bs8U;8BAgCc,iBAjQgBt8U,EAgO9Bu8U;8BAgCa,iBAhQiBv8U,EA+N9Bw8U;8BAgCW,iBA/PmBx8U,EA8N9By8U;8BAgCkB,iBA9PYz8U,EA6N9B08U;8BAgCkB,iBA7PY18U,EA4N9B28U;8BAgCgB,iBA5Pc38U,EA2N9B48U;8BAgCsB,iBA3PQ58U,EA0N9B68U;8BAgCc,iBA1PgB78U,EAyN9B88U;8BAgCc,iBAzPgB98U,EAwN9B+8U;8BAgCc,iBAxPgB/8U,EAuN9Bg9U;8BAgCe,iBAvPeh9U,EAsN9Bi9U;8BAgCgB,iBAtPcj9U,EAqN9Bk9U;8BAgCiB,iBArPal9U,EAoN9Bm9U;8BAgCiB,iBApPan9U,EAmN9Bo9U;8BAgCiB,iBAnPap9U,EAkN9Bq9U;8BAgCgB,iBAlPcr9U,EAiN9Bs9U;8BAgCgB,iBAjPct9U,EAgN9Bu9U;6BAgCgB;gDAhPcv9U,EA+M9Bw9U;;;;;;;;;;;;;;;;;;;;;;;;;;;qCA2BmB3B;qCACnBD;qCACAD;qCACAD;;6BAoEiB;8BAjBE+B,WAhSLl9U;8BA+Rdm9U,aA/Rcn9U;8BA8Rdo9U,aA9Rcp9U;8BA6Rdq9U,aA7Rcr9U;8BA4Rds9U,aA5Rct9U;8BA2Rdu9U,aA3Rcv9U;8BA0Rdw9U,aA1Rcx9U;8BAyRdy9U,aAzRcz9U;8BAwRd09U,aAxRc19U;8BAuRd29U,YAvRc39U;8BAsRd49U,YAtRc59U;8BAqRd69U,YArRc79U;8BAoRd89U,YApRc99U;8BAmRd+9U,OAnRc/9U;8BAkRdg+U,QAlRch+U;8BAiRIi+U,KAjRJj+U;8BAiTG,iBAjTaP,EA+R9B09U;8BAiBiB,iBAhTa19U,EA8R9B29U;8BAiBiB,iBA/Sa39U,EA6R9B49U;8BAiBiB,iBA9Sa59U,EA4R9B69U;8BAiBiB,iBA7Sa79U,EA2R9B89U;8BAiBiB,iBA5Sa99U,EA0R9B+9U;8BAiBiB,iBA3Sa/9U,EAyR9Bg+U;8BAiBiB,iBA1Sah+U,EAwR9Bi+U;8BAiBgB,iBAzScj+U,EAuR9Bk+U;8BAiBgB,iBAxScl+U,EAsR9Bm+U;8BAiBgB,iBAvScn+U,EAqR9Bo+U;8BAiBgB,iBAtScp+U,EAoR9Bq+U;8BAiBW,iBArSmBr+U,EAmR9Bs+U;8BAiBY,iBApSkBt+U,EAkR9Bu+U;6BAiBS;gDAnSqBv+U,EAiRZw+U;;;;;;;;;;;;;;;qCAeCf;wCAoBGt7U,KApTR5B,KAoTIukB,GApTJvkB,gBAoTIukB,GAAI3iB;;iCAIDs8U,aAxTPl+U,KAwTGwmG,KAxTHxmG;wCAwTGwmG,KAAI03O;;iCAELC,OA1TFn+U,KA0TNw7J,OA1TMx7J,KA0TZuB,KA1TYvB;6BA2TK,WADjBuB,KACiB,KADXi6J,OA1TsB/7J,GA0Td0+U,QACgC;uBArnB5D;iCA4nBgBhoT;0B,gBACPioT,SAAoBp+U;4BACvB,SADuBA;8BAIV;+BADoCC,EAH1BD;+BAGuB6S,EAHvB7S;;+BAGmBq+U;+BAAJC;qCAHft+U;+BAGOu+U;+BAAJC;qCAHHx+U;+BAGLy+U;+BAAJ1jO;+BACD,gBAJVqjO,SAGeK;+BAEL,gBALVL,SAG2BG;+BAGjB,gBANVH,SAGuCC;+BAG7B,MAPHloT;+BAWuC,iBAXvCA,MAKFuoT,KACAC;+BAKmC,oBAXjCxoT,MAIoCtjB,YAAG5S;+BAOjB,oBAXtBk2B,MAI4BmoT,GAG9BM;+BAIa,oBAXXzoT,MAIgBqoT,GAElBG;+BAIF,kBACI,WAXAxoT,MAII4kF,GACN2jO;8BAQG,cAbDvoT,YASFl0B,KAcC;8BAlBI;+BAgBe,iBArBlBk0B,MAKFuoT,KACAC;+BAeoB;;;;;iDANnBE;sEAfC1oT,KAeD0oT,mBAKe;;+BACI;;;;;iDANnBC;sEAfC3oT,KAeD2oT,mBAKe;;+BACI;;;;;iDANnBC;sEAfC5oT,KAeD4oT,mBAKe;;+BACI;;;;;iDANnBC;sEAfC7oT,KAeD6oT,mBAKe;;+BACI;;;;;iDANnBC;sEAfC9oT,KAeD8oT,mBAKe;;+BACI;;;;;iDANnBC;sEAfC/oT,KAeD+oT,mBAKe;;+BACI;;;;;iDANnBC;sEAfChpT,KAeDgpT,mBAKe;;+BACI;;;;;iDANnBC;sEAfCjpT,KAeDipT,mBAKe;;+BACI;;;;;iDANnBC;sEAfClpT,KAeDkpT,mBAKe;;8BANlB;;;;;mDACGC;wEAfCnpT,KAeDmpT,mBAKe;;;gCAhBVvkO;gCACN2jO;gCADkBF;gCAElBG;gCAF8BL;gCAG9BM;gCAHsC/rU;;gCAAG5S;gCAKzCgC;8BAKF;4BAWF,QAAI;uBArpBd;oCAuJI49S,0BAmKI22B,OAiUAlsG;uBA3nBR;;;iCA2qBIogB;;;;;8BACgB,IAAdG,MADFJ,SACgB,uBAAdI;;oCADFH;4CACE;0BAEc,IAAdI,MAHFL;0BAGgB,yCAAdK,MAI8B;uBAlrBpC;iCA2qBI37H;0B,SAAAxsH;4BACE,OADFA,OACE,iCADFwsH;4BACE,kBgG3pBE7G,chG2pBF0uD;0BAEA,SAHFr0K,OAGE,iCAHFwsH;0BAGE;uBA9qBN;iCA2qBI1yH;0B,IAAA0yH,ImL1fElH;;mCnL0fFu3N,sBAOgC;uBAlrBpC;iCA2qBIz/N;;;;;;;;;;;;4BwH7JI,cxH6JJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;gEAOgC;uBAlrBpC;;0BA2qBI;4BACE,gC8GpkBE6b,a9GokBFx8H;;0BAEA;yDAI8B;sBAlrBpC,UA2qBImgV;sBqY7lBgB;uBrY9EpB;;;2BA2qBIC;;;;;uBA3qBJ;;iCAswB6CxvG;0BAC3C,UAD2CA;0BAC3C,kBAEI;0BAFJ,IAMI;;4CAIqBr7L,IAAIorS;qCAHvB;;6CAGuBA;;yCAFL,iBAEKA;4CAAJprS,eAAmC;;mCAL7BmrS,KAKqC;uBAjxBtE;iCAmxB+C9vG;0BAC7C,UAD6CA;0BAC7C,kBAEI;0BAFJ,IAMI;;4CACOr7L,IAAKurS;qCACR,OADGvrS,OAAKurS,yBAC8B;;mCAHhBD,QAIf;uBA7xBjB;iCA+xBiCjwG;0BAC/B,UAD+BA;0BAC/B;4BAEI,IADkCowG;4BAG9B,wBAH8BA;4BAG9B;0BAEJ,sBAA0D;uBAtyBhE;iCAwyBmCpwG;0BACjC,UADiCA;0BACjC;4BAEI,IADiCswG;4BAEH,wBAFGA;4BAEH;0BAE9B,sBAAmE;uBA9yBzE;;mCAo4BMj4N;;6BAASzwC,GAATj1E;6BAAS4oQ,GAAT5oQ;6BAASq0K,+BAAT7nD,IAASo8I;;;mCAATx3K;4B,IAAAo7B,ImLntBAlH;oEnLmtBAI,mBAAsD;mCAAtDoxD,UAAS15D;4BAAT,SAASA;;;;;;;;;;;4DAATv4D,YAASu4D,KAA6C;mCAAtD+N;;;;6BAASv8D,gB6H/zBLugF,a7H+zBK1yI;;0DAA6C;mCAAtDq4E;4BAAS;mCAAT6zK;6BAAS,MAATA;6BAAS,MAATC;6BAAS,MAATA;6BAAS;2CAAQ,iBAARg1F,cAAY;;;uCAArBl4N;;mCA8CAq4N,gBAAiB1wG,IAAU2wG;4BAG3B;;6BAEsB,0BALL3wG;6BAKK,SAApBnmN,oBALemmN;6BAQjB;;gCwf17BF6tE;gDxf27BM,sBAHFgjC,gBAGoC;6BADtC,MAHEh3T;6BAGF;;kCAIFrvB;8BACE;gCAAe,qBAbYmmV,gBAY7BnmV;gCACS,iBAAP,iBANEyH,UAKJzH;;;gCACiB,UADjBA;;;4BAGA,SAAIu+E,KAAK/4E,EAAErB;8BACH,8BADCqB,EAAErB;8BACH,UAIF,IADGlC,WACH,OADGA;8BAHD;8BAEF;;;;;;;2DAAWqkV;;wGAA2C;;;uCAHjDniV;6CAKJ;4BALP,SAQIiyO;kCAAc3wO,WAAJ6nO;6CACiDnzL;gCAAL;yCAAal4C;iCAI3D,QAJ2DA,KAC7D+gG,IAGE,WA5BiBmjP,gBA2BVtjP;;iCAGP,QAN2D5gG,KAC7D+gG,IAKE,KA5BRojP,gBA2BejjP;gCALuC,UAQ1C,kBARoD3gG,EAC1DwgG;gCAOM,yBAR+C7oD,UAQrC;8BARL,mBADPmzL,GACO,QADH7nO;4BARlB,eAoB2C8gV,cAAcC;8BACrD,IAAIC,QADmCF,gBA9BvCl3T;8BA+BA;uCADqDm3T;gDAE5BE,QAAQ76N;yCAC7B,GAD6BA;;;6CAKzB,mBAA2B,iBA1CVs6N,gBAyCJ7iM;6CACA;gDAAb,iBAnCR77I,IA8ByBi/U,sBADrBD;;;;6CAMiB;2CAEb,mBAAS,QA5CFjxG,OA2CMtuF,OAED,cADRomF;2CAES;8CAAb,iBAvCR7lO,IA8ByBi/U,sBADrBD;;;2CASQxqU;2CACS,2BA5CrBmqU,gBAyCqBl/L,MAETjrI;yCALJ,QAOgD,EAAE;4BAZ9D,QAAW,aAnCQu5N;4BAiDM;;mCAjDNA;4BAiDM;iCACrBse,eAGE;;6BAIA;;8BAPFA;+BAOE;iCAD0B8yF;0CACFC;mCAAL;;;oCAEb;;uCAF4CnD;gDAEZ1jV,EAAEwE;yCAO3B;qDAjBfmiV,sBAQmC58T,GAEOvlB,MAAFxE,EAFd6mV;yCASX,aAGI;oCAVX,MAF2B98T,GACzB3iB;mCACF,OAYE+2E,EACA;4BAId;8BAAgD;uCACxC2oQ,cAAc7kV;gCAAI,+BAAJA,SAAmC;8BAC3C;iDAFwC8nB;+BAGvC,mBAH4CzH;+BAI9C,iBAJmD9d;+BAS7C,4BAAmB,kBAP9BonJ;+BAeF;qDA5CF+6L,sBAoCIM,SANAF;+BAgBD,cAHCtoQ;8BAGD;gCACe;yDAJdA;iCAIc;;iCACP,oBA/CXq1K,eA8CS+yF;gCAIP,iBAHI1oQ,MADAn+E,YAhBFgnV;gCAgBc;;;0CAIG;4BAxBzB,OAAU,aA5ESxxG;4BA4EnB,UArEI/tO,IA2CAqsP,eAoDiB;mCAEnBozF,WAAW1xG,IAAIhxO;4BACjB,sBACI,iBAFaA,EAEM;4BADvB,2BADagxO,QAAIhxO,QAEQ;mCAGvB2iV,gBAAiBh9G,SAASqL,IAAIlI;4BACxB,IAAJ9oO,EAAI;4BACA,WAFoBgxO,OACxBhxO;4BAEJ,oBAH4BgxO,OACxBhxO,KAD4B8oO,GAAbnD;4BAGnB,UAFI3lO,EAGQ;mCAGV01E;4BAcc;;6BADK;6BAXD;6BADE;6BAEJ;4BAOM;;;;;;;;;;;;;;0CAKvB;mCAGCktQ,yBAAyB5hV,GAAI,OAAJA,KAA0B;mCAGnD6hV,uBAAuB7hV;4BAAI,eAAJA,WAAgD;mCAGvE8hV,oBAAoB9hV,GAAI,OAAJA,QAAkC;mCAGtDssO,yBAAyBtsO,EAAEvD,GAAI,QAAJA,EAAI,QAA2B;mCAG1D4vO,uBAAwB2D,IAAS+xG;4BACnC,eAD0B/xG,aAAS+xG,eAC0B;mCAG3DC,oBAAqBhyG,IAASiyG;4BAChC,eADuBjyG,cAASiyG,oBACgC;mCAE9D11G,sBAAuByD,KAAW,OAAXA,MAAoC;mCAE3DxD,aAAcwD,KA9UG,cA8UHA,OAA2B;mCAEzCkyG,SAAUlyG,KAAW,OAAXA,MAAuB;mCAEjCmyG,iCAA0CnyG;4BAC5C,sCAD4CA,IACA;mCAE1CoyG,iCAA4CpyG;4BAC9C,sCAD8CA,IACA;mCAU5ChmN,KAAMgmN,IAAIj1N,IAAIua,IAAKJ;4BACb,WADA86M,IAAIj1N;4BACJ,8BADAi1N,OAAIj1N,OAAIua,IAAKJ,KAE4C;mCAQ/DmtT,QAAQryG,MAA8BzuO,KAAK48U;4BAC7C,UADUnuG;4BACV;8BAQI;;+BAAe,qBwf/mCnB8tE;+BlMiBA;8BtTgmCI;gCADIwkC;yCAC8BptT,IAAIz4B;kCAClC;2CADkCA,WACZA,GAfL,YAGfuzO,IAYoBvzO,KAZpBuzO,QAW4B96M,IACwB,EAAC;8BAD3D,kBAXoC3zB,SAAK48U,QAI3BtyT;8BAOd,SAXMmkN;8BAWN,cAXMA;8BAWN;4BARA,sBAgBoC;mCAMlCuyG,uBAAuBvyG;4BAC7B;wCAD6BA;8BAC7B;0CAD6BA;;;;oCAOzB,IAHiDwyG;oCAGjD,sBAHiDA;uCAJxBxyG;gCAUzB,6BAVyBA;;gCAazB,+BAbyBA;8BAC7B,UAD6BA;;;;iCAeamuG;iCAAHnjU;iCAAH3c;iCAAHkB;gCAE7B,QAjByBywO,OAeIzwO,EAAGlB,EAAG2c,KAAGmjU;gCAEtC;;8BAhBJ;+BAmB4BsE;+BAC2BC,oBArB1B1yG;;+BAsBwB2yG;+BAGhC;+BAIf,0BA7BuB3yG;+BA6BvB;+BAEkB;qCArmCTnmN;+BAqmCS;;oCAEpByL;gCACE;sCAAIytT,cADNztT;kCAEE,KAnCuB06M,IAkCnB+yG,cADNztT;kCAEE;;8CAJEutT,eACAC;kCAEF,UADFxtT;;;8BAhCJ;+BA/OA;yCA31BFisO,MA61BM5+P;kC,UAAAA;;mCA71BG;;mEAAT4+P;oCAkBAD,MAlBS,WgGxCHh5I,chGwCG6G;;mCAAoB;;qEAA7BoyI;oCAkBAD,MAlB6B,WgGxCvBh5I,chGwCuB0uD;oDgGxCvB1uD,chG0DNg5I,MA20BM3+P;+BAFJ;yCAEIlG;kC,IAAA0yH,ImLruBFlH;0EnLquBEI,mBAA0D;+BAF9D;yCAEIroH;kCA30BN,SA20BMA,KA30BN,0CA20BMA;kCA30BN;+CA20BMA;mCA30BN;;;;;;;;;;;;;;;4CwHmcM;8CxHncN;;;;;;;;;gGA20BMA,EA30BkE;yDAAxE47I;;;;;;gDAAgB;0EAAhBF;;kDAAgB;kDAlBhB;;;;;;;;;;;4DAkBgBG,OAlBhB;sEAkBgBA,OAlBhB;;;;;;;;;;;;;;;;;;uGAkBgBA,UAlBhBtqF;;;;kEAkBgBsqF,OAlBhB;;;;;;;;4DAkBgBA,UAlBhBY;;;;+DAkBgBZ,OAlBhB;;2DAkBgBA,OAlBhB;;yDAkBgBA,OAlBhB;kEAkBgBA,OAlBhB;kDAkBgBmnM;;+CAAY;yEAA5BtnM;;iDAA4B;;;;8CAA5B;;;;4FA20BM17I;oCA30BN;mFA20BMA;oCA30BN,UAAgBgjV,aAAhB,MAA4BC;;6DAAZE;0DAAYD;oCAA5B;;6CA20BMljV;;uDA30BUgjV;0DAAYC;+BAy0B1B;yCAEIjkV;kCA30BN;yCA20BMA;mCA30BN,MA20BMA;mCA30BsB,e8G6BtB48H,a9G7BsByoC;;kCAlB5B,SAkBgB++K;mCAlBP;uCAkBOA;oCAlBP,gB8G+CHxnN,a9G/CGx8H;oCAkBOolD,qBAlBP+M;;mCAAoB;yCAkBb6xR;oCAlBa,gB8G+CvBxnN,a9G/CuB4gB;oCAkBbh4F,qBAlBai4F;kCAkB7B,IAAgBK,oCAAYD;4CAAZC;+BAy0Bd;yCAEIg9B;kCAAe;oDAANk1H,2CAAK;2CAAdl1H;iDAAyB;+BAF7B;2CAEIzxD;+BAFJ;;+BAQ0B;;yCACqBttG,IAAKnZ;kCACxC,IAAJssE,EAAI,oBAoOiB8hK,QArOkBj1N;kCACnC;oCACiD;sCAInD,IADG8/N;sCACH,OAN0Cj5O,qB,OyPjyB9Cu1I,OzPsyBO0jG;sCACH,OADGA;oCADH,kCAJ0Cj5O,KAOtC;kCALyB,gBAD/BssE;kCAC+B,2BAHnCm1Q,gCAQU;8BAPd,oBAqO6BrzG;8BAC7B;+BA9NU;;yCAC+B6K;kCACrC,eAEuDq0D;oCAAM;sDAAN5mH,2CAAK;6CAAL4mH;mDAAgB;kCAArE,IADEz/N,MACF,eAHmCorK;kCAGnC,eAEyC7vK,MAAMtoD;oCAC7C,2BAmQA4gU,QApQuCt4Q,MAAMtoD,OACF;kCAL7B,GACd+sD;uCADuCM,GACvCN,SADkChzE,EAClCgzE,yBADuCM,MAALtzE;;;mDAClCgzE,kBAI6C;8BANrD,oBAVI4zQ;8BAuOJ;+BAiDQE;yCAAmCjuT,IAClCzT;kCACH;yCADGA;mCAGC;;sCwfrrCVi8R;+CxfqrCwD5oR;wCAC1C,IATOvgB,OAIsB2gB,IAIaJ;wCAPrC,mCAFXouT,QACa3uU,SASiB;kCAD5B,UAHDkN,oBAKF;+BAIgB,0BA5BfihU;+BA8BF;;kCAFEU;2CAE6BE,aAAat5T;oCACxC;gDAD2Bs5T,cAAat5T,KAElC;+BAIA,mBAhDYq4T;+BAkDtB;;kCAFE52T;2CAEsB+3T,aAAax5T;oCACjC;gDADoBw5T,cAAax5T,KAEW;+BAK1B;yCAIVyB;kCACZ;2CADYA;oDACYnqB;6CA1lC9B,eAEaiT;+CAAuB,UAAvBA,OAAuB,MAAvBA;;gDA9DT,qBADWna;;gDAIX,uBAFiBwvE,MAHNngD;qEAgEiD;6CAD9D;4DAylC4BnoB;8CAzlC5B,OAylC4BA;8CAzlC5B,KAylC4BA;8CAhlCf,gBAFQoiV,SA5BrBlkC;8CAsCE,uBARAmkC;8CAOA,uBAPAA;8CAMA,uBANAA;8CAKA,uBALAA;8CAIA,uBAJAA;8CAGA,uBAHAA;8CAEA;;iEAFAA;;;;;;;wEAuhCInB,cAzhCSrhV,KAGb2oB,MAH6Bi0T,QAolCwB,EAAE;8BAEvD,UAzBIsF;8BA0BJ,UAlBIE;8BApER;+BAyFiB,2BAhqCF95T,kBA+lCP+4T;+BAkEa,iBADbn3J;8BACa,YAAbu4J,WAlEApB;8BAkEa,UAlEbA,WAJ+CF,oBACFC,oBA2EI;mCAGvD/7K,SAAS5mK,GAEP,uBAFOA,GAEP,QAG+C;mCAEjDikV,gBAAgBj0G;4BACA,iCADAA,KACA;uDAAdnkN,MACW;mCAEbq4T,QAASl0G;4BAGO;0DAHPA;6BAGO;6BACM,0BAJbA;4BAIa,2BAApBnmN,kBADAgC,MAEiC;mCAG/B4/J,OAAQukD;4BACd;wCADcA;8BACd,mBAEI,SAHUA;8BACd,IAGYvkD;8BACR,OADQA,OACF;mCA2CR04J,uBAAwB5kV,EAAGlB,EAAG2c,EAAEmjU,OAAOnuG;4BACzC,UADyCA;4BACzC;8BAMiB;;+BADGo0G;+BAAJC;+BAAJxlV;+BAAJkN;+BACS,kBAPiBoyU,OAMdiG;8BAEhB,QARqCp0G,OAAfzwO,EAAGlB,EAAG2c,EAMxBjP,GAAIlN,GAAIwlV,MACRC;8BACJ;;4BAJA,gBAJsB/kV,EAAGlB,EAAG2c,EAAEmjU;4BAI9B,QAKgC;mCA8FlC/xG,qBAAwB4D,IAw4BxBu0G;4BAn4BQ,SAANC,InC/3CFxkV;8BmCw0CgB;;+BADgD;;;;8BnCl1CpE,SAAQwwN;;;;;;;;;oCAEF,IADOvwN;oCACN;wEAAa,yBADPA;;;oCAGP,IADEjB;oCACF,mCADEA;;oCAKe;qCADV6lC;qCAAJD;qCACc,oCADdA;qCACc;;gDAAbyoM;6CAAID;6CADDvoM;;;oCADJ;qCADK7kC;qCAAHhD;qCACF,yBADEA;;6CAAGgD;;8BAOA;wCAbkC2G,IAANmsE,OAYtC9yE;+BACU;;+BACD,0BADPC,EAboC6yE,WAapC7yE;8BmCmvCJ,eAA4C00C;gCAAL;;yCAAKA;yCAAQn6C;kDACvBQ;2CACrB,GADqBA;4CACwB,QADxBA,KACjBiH,IAAyC,kBAFJxF,EAEDw7C;;gDAApCh2C,IAFqCxF;2CAGlC,gCADHwF,cAC0C,EAAI;8BAH1D;mDAiFcwrO;+BAQZ;;kCAFEg3G;;2CAEqC1pU,IAAKnZ,KAAK+yC,KAC7C,aADwC/yC,KAALmZ,KAAU45B,IAC3B;+BAEP,mBALb8vS;8BAKa,GAXb9/G;gDAYG5zJ,IAZH4zJ,sBAYG5zJ;;+BAGH;8BACG,GATH2zQ;;;kCA7BJ;mCAwDkBx6Q,GA3Bdw6Q;mCA2BOC;mCAxDX;;sCAAa;;;0CAQM;2CAHH3kV;2CAAP2kV;2CACCE,QADDF;2CAGU,WAHH3kV;2CAGG;;2CACQ;8DAkEDgwO,gBArEhB60G,YAEAC,GAAI70Q;2CACa;;0CACrB;+CAJI40Q;+CAEI50Q;+CACJ80Q;qDADAD,GAGa;4CAgEG90G;0CAjEpB,iBADI+0G;wCALJ,IADItoV;wCACJ,mBADIA;sCADJ,8BAWwB;mCAb9B,aAwDkBytE;mCAEF+F;mCAAJ60Q;mCAEF;;sCAtCNngH,SAqDsBqL,mBAnBf20G,WAECG,GAAI70Q;kCAEN,GAtCN00J,aA8CmCloO,EA9CnCkoO,YA8CmCtnI;kCApEvC;kCA+DQ;0CAPGsnP;uCAEK10Q;uCACJhuE;6CADA6iV,GAQK,gCAEsBznP;oCAOb2yI;kCAZlB,4BAJI/tO;gCAjBU,IAAT4iV;gCAAS,GApBlBlgH;kCA0BQ;uCA1BRA;mCA2BU,yBAHC3zJ,KA6BWg/J,mBAjCb60G;mCAOC;mCAGoB;kCADtB;0CATCA;;uCAMGjyQ;gEAFD5B;oCA6BWg/J;kCAxBd,4BAHIp9J;gCAHJ,8BAHCiyQ;8BADL;4BAuCE,SAENG,YAAavoV;8BACT,cADSA,GACT;;gCAWI,8BAnBcuzO;gCAmBd,UAEF,IADG3yI,aACH,OADGA;gCADD;iCAIM,8BAvBQ2yI;iCAyBwB;gCADxC;qCADIxyI,+CAvBYwyI;gCA2BhB,oBA3BgBA,cAuBZxyI;gCAIJ,OAJIA;8BAfN,IACIG;8BACH,mCAAuB,OADpBA;8BADJ;+BAIS,qBAZSqyI,gBASdryI;+BAGK;;+BAGY;8BADrB;mCALIA,UAGAnrB,uCAZcw9J;8BAclB,OAFIx9J,EAgBC;4BAvBH,GAm4BR+xQ;8BAx2BS;+BADiC5sR,GAy2B1C4sR;+BAz2BsC7sR,GAy2BtC6sR;+BAx2BS,UAD6B7sR;+BACrB,UADyBC;+BACzB;;;;;kCAmBO;kCAAN;;gCAHkC;iCAHrBstR;iCAGqB;iCAAV;gCAAlC;gDAHuBA,yCA7CPj1G;8BAgCf;;gCAW2C;;iCAAV;gCAAlC;;;;;yCA3CgBA;8BAgCf;+BACoBk1G;;+BAKkB;+BAAlB;8BAArB;;;0CALqBA;;uCAjCLl1G;+BAw4BxBu0G;8BAn1BS;+BADmC9sH,GAo1B5C8sH;+BAp1BwC1gM,KAo1BxC0gM;+BAp1BoCh7N,KAo1BpCg7N;+BAn1BS,YAD2Bh7N;+BACnB,YADuBs6B;+BACf,UADmB4zE;+BACnB;;;;;;;oCAmCM;oCAAb;;kCAH4B;mCAFE3yL;mCAEF;;kCAAtC;kDAFwCA,yCAnFxBkrM;;;kCAiF4B;;;;mCAA5B;kCAAhB;4FAjFgBA;gCAyEU;iCAFYm1G;;;iCAEZ;iCAAV;gCAAhB;;;4CAFsCA;;yCAvEtBn1G;8BAqDf;;;;kCAwB2C;;;;;kCAA5C;;;;8CAAO;2CA7ESA;gCAqEU;iCAJYo1G;;;iCAIZ;;gCAA1B;;;4CAJsCA;4CAI/B;yCArESp1G;8BAqDf;;gCAU2C;;iCAAV;gCAAlC;;;;;yCA/DgBA;8BAqDf;+BACmCq1G;;+BAKP;;8BAA7B;;;0CALoCA;;uCAtDpBr1G;+BAw4BxBu0G;8BA/yB2C,MA+yB3CA,UA9yBa,YADyBvlV,GACzB;wCAAJvC;gCAQiB,4BARpBO;gCAQY,qBARZA;;8BADqC;+BAGlCqgG,IAFA5gG;;;;;8BAKD;0CAHC4gG;;;0CAGM;uCA/FS2yI;+BAw4BxBu0G;8BApyBoC;+BADK15C,KAqyBzC05C;+BAryBqC7pM,KAqyBrC6pM;+BApyBoC,YADK15C;+BACL;;+BAAR,YADSnwJ;+BACT;;wCAAjB91G;;kCA2CO,qBA3CXj8B;;gCA6BmB;;iCAIJ,wBAjCfA;iCAkCK,4BAtIYqnO,QAqIds1G;gCACE;kCAEF,oBAAqC,iBAxIvBt1G,IAiIJnrM;kCAOO,0BAxIHmrM,IAuIX1/J;gCANa,UAUoB,kBAvCvC3nE;gCAsCG;uCATUk8B,2CAjIImrM;gCA0Id,2BA1IcA,QAqIds1G,MAJUzgT;8BA7BgB,UAAzBD;;gCAoBW;iEApBfj8B;iCAqBK,4BAzHYqnO,QAwHdu1G;gCACE;kCAEF,oBAAqC,iBA3HvBv1G,IA0HX3/J;kCACc,0BA3HH2/J;gCAwHF,UAMwB;gCADpC;mDAzBHrnO,+BApGiBqnO;gCA6Hd,2BA7HcA,QAwHdu1G;8BApB0B,IAElBC;8BACT,qBAHF78U;gCAIQ,gCAJRA;gCAIQ;kCACgC,qBAzGvBqnO,IAsGNw1G;kCAGS,0BAzGHx1G;gCA0Gb;8BAEO,qBARXrnO;gCAaC;gCACE;;4CAZQ68U;;4CAFX78U,GAcc;yCAlHGqnO;8BAoGY,IAS5B;8BACE;;0CARQw1G;;0CAFX78U,GAUc;uCA9GGqnO;+BAw4BxBu0G;;;;iCA5sBgB;kCA5CwBtkV;kCAAH4S;kCAAHmI;kCAAH3c;kCAAHkB;kCAqBtBwxE,OArBkC9wE;kCAsBlCwlV;;qCACI;sCADOhpV;sCAAHO;sCACJ,UADOP;sCACP;;;uCAEiB,4BAHbO;uCAGD,2BAJP+zE;uCAIO;qCAFH,IAKKssB;qCACQ,wCAPTrgG,SAMCqgG;kCAgBC,eA5CY99F;kCA4CZ;;kCACA,eA7CelB;kCA6Cf;;kCACH,eA9CqB2c;kCA8CrB;wD;kCAAA,sB,kBqM/uCS43G;kCrM+uCT;wD;kCAAA,sB;;iCAML,GARI5jD,OACAsH;mCAOA;4DARNovQ,IACAC;oCAIAnqQ,IAGM,wBApDyB3oE;;iCwHlhCnC,kBxHmkCI2oE,IAME;iCAXQ;kCAWkD,MAlC5DzK;kCAqCmB,YAZhB60Q;kCAYO,YAbJtvQ;kCAaL,eAdKtH,iBAKNwM;kCAQ4C,YAXzCoqQ;kCAW8B,YAZ3BtvQ;iCAYgB;gDAbhBtH,uBA5LYghK;;iCAkNtB;;kCAEE;wCAJ2BzuN,sB,kBAzM7ByjU;kCAiNIc;4CAAiBtrN;qCAgBT;sCAhBgCurN;sCAAJC;sCAAJhoC;sCAAJn1S;sCAAJF;sCAgBhB,0BAhB4Bq9U;sCAe5B,0BAf4BA;sCAc5B,0BAd4BA;sCAa5B,0BAbwBhoC;sCAYxB,0BAZwBA;sCAWxB,0BAXwBA;sCAUxB,0BAVoBn1S;sCASpB,0BAToBA;sCAQpB,0BARoBA;sCAOpB,0BAPgCk9U;sCAMhC,0BANgCA;sCAKhC,0BALgCA;sCAIhC,0BAJgBp9U;sCAGhB,0BAHgBA;sCAEhB;;4DAFgBA;;;;;;;;;;;;;;;sCAEhB,MAFS6xH;sCAkC2B,MAlC3BA;sCAkC2B;;0CAAzC;;sCADyC,MAjC3BA;sCAiC2B;;0CAAzC;;sCADyC,MAhC3BA;sCAgC2B;;0CAAzC;;sCADyC,MA/B3BA;sCA+B2B;;0CAAzC;;sCADyC,MA9B3BA;sCA8B2B;;0CAAzC;;sCADyC,MA7B3BA;sCA6B2B;;0CAAzC;;sCADyC,MA5B3BA;sCA4B2B;;0CAAzC;;sCADyC,MA3B3BA;sCA2B2B;;0CAAzC;;sCADyC,MA1B3BA;sCA0B2B;;0CAAzC;;sCADyC,MAzB3BA;sCAyB2B;;0CAAzC;;sCADyC,MAxB3BA;sCAwB2B;;0CAAzC;;sCADyC;;0CAAzC;;sCADqC;;0CAArC,8BAtBcA;;sCAqBuB;;0CAArC,8BArBcA;;sCAoBuB;;;2CAArC,8BApBcA;;;;;;;;;;;;;;;;qCAoBjB,eA5OkBw1G,IAyNhBv5H,OAkBA0nO;kCAqD8B,gBA1EhC17R;;;;;;;;;;;;;;;;;;;;;+CAkEE,IADoB2+H;+CACpB;;gDApBM,0BAmBcA;gDApBd,0BAoBcA;gDArBd;;sEAqBcA;;;;;;;;;;;;;;;+CArBd,eAlQU4uD,IAiQhBv5H;iDAyB4BvsC;6CAC5B;6FAD4BA;;mCAI5B;;iCAWO;kCAP6CwsQ;kCAAPC;kCAAPC;kCAARC;kCAALC;kCAAJC;kCAAJhvE;kCAAJC;kCACfi+E;;qCAA4C,IAArBjrV,WAAHyB,WAAwB,kBAArBzB;qCAAM,sBAATyB;kCAMX,4BAPMurQ;kCAON;;kCACA,4BARUD;kCAQV;;kCACA,4BATcgvE;kCASd;;kCAYH,qBArBgDL;kCAoBhD,qBApByCC;kCAmBzC,qBAnBkCC;kCAkBlC,qBAlB0BC;kCAiB1B;;uCAVNqP;uCAAIrrP;uCACJsrP;uCAAIvrP;uCACJwrP;uCAAIx1H;uCAQE,YAjBqBkmH;;;;;;;;;iCAiBrB,eAnTY9mG,IA4SlB94H;;iCAoBJ;;;;4CAiDUsjB;qCA1BO;sCAhBwCirK,OA0C/CjrK;sCA1CuCkrK,OA0CvClrK;;sCA1CmC8jL;sCAAJC;sCAAX5Y,GA0CpBnrK;sCA1CczqF,KA0CdyqF;sCA1CQorK,KA0CRprK;sCA1BO,0BAhBCorK;sCAeD,0BAfCA;sCAcD,0BAdCA;sCAaD,0BAbCA;sCAYD,0BAZCA;sCAWD,0BAXCA;sCAUD,0BAVCA;sCASD,0BATCA;sCAKD,0BALCA;sCAID;;2CAJwB2Y;2CAAID;2CAI5B,iBAJC1Y;;2CAA+BF;2CAAQD;;;;;;;;;;sCA+B7C,0BA/BkBE;sCA8BlB,0BA9BkBA;sCA6BlB,0BA7BkBA;sCA4BlB,0BA5BkBA;sCA2BlB,0BA3BkBA;sCA0BlB,0BA1BY51P;sCAyBZ,0BAzBYA;sCAwBZ,0BAxBYA;sCAuBZ,0BAvBYA;sCAsBZ,0BAtBYA;sCAqBP,0BArBC61P;sCAoBD;;4DApBCA;;;;;;;;;;;;;;;qCAqChB,QA5WoB51D,IAwUhBq2G;qCAoCJ,QA5WoBr2G,IA0VhBkyG;qCA1BF1nV;6CAiD+C;iCADnD;mCAEE;qCAnD2BgoD,wB,OR/rDjCgjP,aQu4CIw/C;;iCAyWA;;iCAMY;kCAFoC7mC;kCAAJh1L;kCAAJp5C;kCAAPxtB;kCAErB;;qCAFqBA,wB,OH5uDrCw7P,aG+3CIinC;kCA+WY;4CAEaxqN;qCACvB;sCAAIllG;;2CADmBklG;;;;;;;;;;;;;;;qCACvB,eAzXoBw1G,IAyXhB16M,UAkBqC;iCAE3C,OAvBIgtB,QAEAgkS;iCAFQ;kCAgCF,qBAlCsCnoC;kCAiCtC,qBAjCkCh1L;kCAgClC;6DAhC8Bp5C;iCAgC9B,eApZYigK,IA+YlBu2G;;;kCAoBalkS;kCAEbmkS;4CAA4BhsN;qCAC9B;sCAAIllG;;2CAD0BklG;;;;;;;;;;;;;;;qCAC9B,eAtaoBw1G,IAsahB16M,UAkB2C;wD,OFhzDrDkpR,aE+3CIwmC;iCAqbI;0CAzBa3iS;;4C,OoG7nDf+qE,UpG+nDEo5N;;iCA2BS;kCAFsCz9C;kCAAJC;kCAAJC;kCAAJC;kCAAJC;kCAAJC;kCAAJC;kCAEd,mBAFcA;kCAId,mBAJkBD;kCAMlB,mBANsBD;kCAQtB,mBAR0BD;kCAU1B,mBAV8BD;kCAY9B,mBAZkCD;kCAclC,mBAdsCD;kCActC;;uCAZT09C;uCAEAC;uCAEAC;uCAEAC;uCAEAC;uCAEAC;uCAEAC;kCAAS,WAZTN,UAEAC,OAEAC;kCAQS,WAZTF,UAMAG,OAEAC;kCAIS,WAZTJ,UAUAK,OAEAC;iCAAS,YAaTI,WADAD,WADAD,QAvdkBj3G;iCA4cT,eA5cSA,IA6clBg3G;;iCAwDM;kCArBNhQ;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADA14U;kCAoCM,qBAtBN63U;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM,qBAtBNC;kCAqBM;;mDAtBN14U;;;;;;;;;;;;;;;kCAuCW,0BAxBX43U;iCAyByB,eAzgBPhnG,IAsflBo3G,aAkBAC;;iCAuDM;kCAtBNtP;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADeC;kCADfC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADArpF;kCADkBi3F;kCAmDZ,qBArCNxO;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNC;kCAoCM,qBArCNrpF;kCAoCwB;;mDArCNi3F;;;;;;;;;;;;;;;kCAqEZ,qBAxCNvP;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCM,qBAxCNC;kCAuCqB;;mDAxCNC;;;;;;;;;;;;;;;iCAyDnB,QAplBsB7oG,IAgjBlBu3G;iCAoCJ,eAplBsBv3G,IAkkBlBw3G;;iCAuEM;kCAnCN7N;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAxnS;kCADAynS;kCADAC;kCAiDM,qBAnCNb;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNxnS;kCAkCM,qBAnCNynS;kCAkCM;;mDAnCNC;;;;;;;;;;;;;;;iCAmCM,eA3nBYxqG,IA0nBlBq2G;;iCAkEM;kCA/BNhrV;kCADAo/U;kCADAC;kCADmBC;kCADnBhzU;kCADAizU;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCA0CM,qBAnCNvzU;kCAkCM,qBAnCNizU;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCM,qBAnCNC;kCAkCwB;;mDAnCxBC;;;;;;;;;;;;;;;iCAqDF;0CAvsBoBlrG;0CAorBlBy3G;;;2CA1BmB9M;2CACnBD;2CACAD;2CACAp/U;;iCAoHM;kCArCN8/U;kCADAC;kCADAC;kCADmBC;kCADnBC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCAmEM,qBAzCN1B;kCAwCM,qBAzCNC;kCAwCM,qBAzCNC;kCAwCM,qBAzCNC;kCAwCM,qBA5CNI;kCA2CM,qBA5CNC;kCA2CM,qBA5CNC;kCA2CM,qBA5CNC;kCA2CM,qBA/CNI;kCA8CM,qBArDNO;kCAoDM,qBArDNC;kCAoDM,qBArDNC;kCAoDM,qBArDNC;kCAoDM,qBArDNC;kCAoDM;;mDArDNC;;;;;;;;;;;;;;;kCAmFM,qBApENf;kCAmEM,qBA5DNP;kCA2DM,qBA5DNC;kCA2DM,qBA5DNC;kCA2DM,qBAjENM;kCAgEM,qBAjENC;kCAgEM,qBAlENE;kCAiEM,qBAlENC;kCAiEM,qBAlENC;kCAiEM,qBAlENC;kCAiEM,qBAlENC;kCAiEM;;mDAlENC;;;;;;;;;;;;;;;iCAmFJ;mCAvyBsB3sG;mCAkwBlB03G;;;oCAzBmBpM;oCACnBD;oCACAD;oCACAD;iCA2DJ,eAvyBsBnrG,IAqxBlB23G;;iCAgFM;kCAtCazK;kCADnBC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCADAC;kCAqDM,qBAvCNd;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCM,qBAvCNC;kCAsCwB;;mDAvCxBC;;;;;;;;;;;;;;;iCAwDwB,eAx2BNjuG,IAs1BlB43G,kBAvBmB1K;;qCA0CqBt7U,cAAJ2iB,kBAz2BlByrN;;mCA42BlB;;6CAHoCzrN,GAAI3iB,MAEN8gV;mCAClC,YAAIjqQ;mCAAJ;iCAKA;;qCAGuCylQ,sBAAJ13O,oBAp3BjBwpI;;mCAu3BlB;;iDAHmCxpI,KAAI03O,cAENyE;mCACjC,YAAIzC;mCAAJ;iCAKA;;iCAKF;kCAFoC/B;kCAAR3iL;kCAANj6J;kCAEtB;;;8CAAsB/G;uCAIlB;;kDAAuC,oCANfghK,OAENhhK,UAI+B,EAAC;iCAJtD,eAj4BoBw1O,IAg4BlB63G,SADoBtmV,KAAc48U;4BAW/B,yBAA2B,OAFpCoG;4BAES,2CACH;;kCArvCN7vQ;kCAqCA63J;kCAhBAs1G;kCASAx1G;kCAZAu1G;kCASAt1G;kCAHAw1G;kCAUAE;kCAKAx1G;kCAEA01G;kCAEAC;kCAGAC;kCArTFjC;kCASAE;kCAwmBEj0G;kCA9dAs0G;kCAoTA95K;kCApGI27K;kCA2GJ0B;kCAYIx4J;kCARJy4J;sBA2iCH;;sB5DlxEGxrM;sBI4HFsV;sBADAD;sBJ5HEtV;sBqjBVN;;sBpH+EoB;;;0BoHuCe;;;2BAA/B;2BAGe;;2BAEI;mCAHjBuvM,aAIepqP;4BAAQ,eAHrBkqP,mBAGalqP,MAAwD;0BADtD,SAEfqqP;4BACF,UAJE/7T;4BAIF,UAEI,IADGg8T,eACH,OADGA;4BADP,UALEJ;4BAUU;6BAIF,eALFlqP,MAIK59F;;iCAJL49F,MAGE;4BAAuC,qBAgBlC1xE,IAAI/V;8BACT;;uDAA6B,iCADxB+V,IAAI/V,KACkD,EAAC;4BAjBrB,qBAOhCA;8BACP;;;yCACU,oCAFHA;yCAEG,UAEF,IADG+V,aACH,UADGA;yCAGH,oBAEiC,EAAE;4BAV/C;sDACa,OAtBnB9zB,IAsBuB;6BAcX,eAvBJwlG,MAOAuqP;4BAgBI;oDACAj6Q,aAFJC,IAEID;;8BAGQ,IAANk6Q,MAAM,wBAlClBL;8BAqCY,OA9BNnqP,sBA8B4B,yBAIT;8BAPP,IALZzvB,IAKMi6Q;4BAYV,YAjBIj6Q;4BAiBJ,OAjBIA,GAkBH;0BA/CY,SAmDjBuG,OAAQzoD,gBAAgB88B;4BAExB;2DAFwBA;6BAExB;;;6BAGA,0CALwBA;6BAQlB,gCARkBA;4BAQlB;8BAKF,IADGu/R;8BACI,qBAbHr8T,gBAYDq8T;;8BACH,IANFC,kBAKKD;;8BAFH,wBAVoBv/R,GAAhB98B;kCAONs8T,kBAPMt8T;4BAER;6BAgBqC;6BADrC;;;gCAhBEJ;gCAGAhC;gCAHO64T;gCAAqB2F;gCAM5BE;;4BAUF,UADEr9U,MAhBsB69C,GAoBb;0BAvEM,SAyEjBxwB,GAAGv4B,GAAI,gCAAJA,KAAwC;0BAzE1B,SA2EjB88S,GAAG98S,GAAI,OAAJA,CAAK;0BA3ES,SA6EjBwoV,gBAAgB7rV,GAAiC,yBAAjCA,GAAkD;0BA7EjD,SAgFjB8rV,eAAgBzoV;4BAElB,SAAI0B,EAAEzB;8BACE,kCADFA;8BACE,yBAIF;8BAJE,IACkBxD;8BACpB,wBADoBA,OAGR;4BAaM;qCApBNuD;6BAmBJ,QAnBIA;6BAkBL,QAlBKA;6BAiBI,QAjBJA;6BAgBL,QAhBKA;6BAeD,QAfCA;4BAeD,eADHxF;8BAAO,0BAdHwF,QAcJxF,UAAoC;4BAD9C;2CAFUA;8BAAO,0BAXHwF,QAWJxF,UAA6B;4BADvC;;;;;;;;0CAWH;0BArGkB,SAuGjBkuV,oBAAqB1oV;4BAIvB,SAAI0B,EAAEzB;8BACE,kCADFA;8BACE,yBAIF;8BAJE,IACkBxD;8BACpB,wBADoBA,OAGR;4BALlB,SAOIkyB,OAAOlvB;8BACT,eACSF;gCACT,qBAHSE,EAEAF;gCACT,wCAVEmC,EAUO;8BAFT,qCAZqB1B,WAcZ;4BA8Be;mDAAYT,GAAK,OAALA,OAA6B;6BAD/D,sBAAYA,GAAK,OAALA,OAAmC;6BAF3B,sBAAYA,GAAK,OAALA,OAA2B;6BADpC,sBAAYA,GAAK,OAALA,OAA8B;6BADzC,sBAAYA,GAAK,OAALA,IAA8B;6BADjD,sBAAYA,GAAK,OAALA,IAAgB;4BAA5B,eAF2C/E;8BACxD;gDAAY+E;yCAAK;kEAA2B,wBAAhCA,KAD4C/E,SACM,EAAC,EAAC;4BAFpE;;6BAFS,iBpT6FWo4H,OoT9HD5yH,SAInB0B;6BA4BuB,iBpT8FHkxH,OoT9HD5yH,SAInB0B;6BA2BuB,iBpT+FHkxH,OoT9HD5yH,SAInB0B;6BA0BkB,iBpTgGEkxH,OoT9HD5yH,SAInB0B;6BAyBkB,iBpTiGEkxH,OoT9HD5yH,SAInB0B;6BAwBS,iBpTkGWkxH,OoT9HD5yH,QAInB0B;6BAuBoB,QA3BD1B;6BA0BT,QA1BSA;6BAyBV,QAzBUA;6BAwBD,QAxBCA;6BAuBV,QAvBUA;6BAsBN,QAtBMA;4BAsBN,eADHxF;8BAAO,0BArBEwF,QAqBTxF,UAAoC;4BAD9C;2CAFUA;8BAAO,0BAlBEwF,QAkBTxF,UAA6B;4BADvC;;;;;;;;;;;;;;;;;;;;;0CA4BH;0BApJkB;kCANjBpC;kCAGA4vV;kCAKEC;kCAiDFvzQ;kCAsBAn8C;kCAEAukR;kCAEA0rC;kCAGAC;kCAuBAC;sBA8CH;;sBrjBrQGhwM;sBI4HFsV;sBADAD;sBJ5HEtV;sBsjBVN;;sBAakB;;sBtjBFZC;sBI4HFsV;sBADAD;sBJ5HEtV;sB6DVN;;sBoY+EoB;uBpY/EpB;iCA0Caz4I;0BACkB,4B;0BAApB,+BADEA,cACsC;uBA3CnD;iCA6Ca+vE;0BACX,mBAAeluD,KAAMpiB,GAAK,mBADfswE,GACIluD,KAAMpiB,EAA0B,EAAG;;;;;;;;;;0BAMlD,eACUswE;4BAAsC,IAAfngB,MAAe,WAAS,UAA/CmgB;;8BAA6B;yCAANwkG,uCAAK,EAA5BxkG,GAAuBngB;;0DAAsC;0BADvD;;;;;;;;;wDwGkSR4tG;yCxGjSgE;sBoY0BtD;uBpYjBhBqrL;iCAAQx6Q,UAASruE;0BACnB;2CACU6hB,KAAMpiB;oCACV,qBAC2C7C;sCAAd;yCAAUglO;;;;;4CAGnB;6CADFi9E;6CAAJ1xS;6CAAJC,GAF6Bw0N;6CAGnB,gBALVniO,EAEyBiU,MAEjBmrS,GAAJ1xS,GAAJC;4CACU,UAAN07U,QAH6BlsV;sCAMjC,UANyB8W,MAAQ9W,EAAJglO,IAMd;oCANvB;sDAJW5hO,QAET6hB;qCAEF;;uCADM+/M;;;;;;sDAmBJ;0CARA,kBAZMniO,EACNiU;wCAaA,kBAdMjU,EACNiU,kBAHA26D;sCAkBA,kBAhBM5uE,EACNiU,YAHA26D;oCAoBA,OAjBA36D,EAmBY,EACrB;;;;;;;;;;0BAGD,eACUq8D;4BAEE;sCAFFA;6BAGO,kBAAQ,SAAiB,UAHhCA;6BAIE,SADJg5Q;6BACI,EAFJzpV;6BADJ;6BAMW;8CAFPjB;;gCAE0B,WAF1BA,sBAEyD,OANzDgwE,SAMgE;6BAAjE,aAPG0B;6BAUH;;gCAPCg5Q;;kCAOkB;4CAAM57U,MAAIC,MAAIE,OAAsB;6BAAvD;;6BAES+2C;;8B,O0H6YZ26D,abzYE4c;qC7GJU/K;8BAAI;gDAAJ8lD,0CAAG;uCAAHpB;6CAAQ;;8BAARztH;4BACL,oBAXHxoD,mBAEAX;0DASoB;0BAdZ;;;;;;;;;wDwG8PR6+J;yCxGhPsB;sBoYvBZ;uBpYyBhBwrL;;0BACF;gDAEgBvpV;oC+NysBhB;oCACoB;iDAAc;sCAA2B;;uC/NvsB/CqzL;iDADA7yL;mDACAo7E,OAAO7gF,EAAEm6C;4C;qDAHPl1C,EAGOk1C,IALD,iBAIR10C,MACOzF,cAA+B;iDAAtC6gF;uDADAp7E;uCAEJ;;;;;;;uC+NssBqC;;;+C/NrsBA,EAC9C;sBAiByD;;sB7DvHtDy4I;sBI4HFsV;sBADAD;sBJ5HEtV;sB6cVN;;sBZ+EoB;uBY/EpB;iCAkBaz4I,EAAExF;0BACP;wDAA8B,cADzBwF,EAAExF,iBAC8D;uBAnB7E;iCAqBaiC;0BACH,iBADGA,GACH,WAAJ6C;0BAAI;mCACJ20N;4CAC0BstE;qCAC1B,SAAIthS,EAAEzF;uCACJ,IAAI2uV,SAFoB5nD,cACpB/mS;uCAED,gBANEiC,EAKD0sV,UADA3uV,GAEiC;qCAGoB;;sCAAR;sCAAR;sCAAR;sCAAR;sCAAR;sCAAR;qCAAR;;;;;;;;;;;;;;;oDAA4D,EAAE;uBA9BvE;iCAgCaiC;0BACX;mCADWA;;4CACuCjC,EAAEm6C,IAAI10C;qCACzC,cADqC00C,IACrC,aAAY,SAD6B10C,OAANzF,OACU,EAAE;uBAlChE,cAuDMi3N,aAEAD;uBAzDN;;;;;wCAgESxxN,GAAI,0BAAJA,EAAyB;uBAhElC;iCAkEgBlD,EAAEkD;0BAAoB,kBjThD9BsoH,ciTgDQxrH,EAAsB,mBAApBkD,GAA4B;uBAlE9C;iCAoEcA,GAAY,sCAAZA,GAAyB;uBApEvC;;0B;4BAwEM,IADMhD,WACH,2BADGA;0BAGN,YAAsC;uBA1E5C,oBAgCIosV,WAXAF;uBArBJ;;;;;;;;sBAqFI;;sB7c1EExwM;sBI4HFsV;sB6bxDgB;;;yBY3EhB+iE;yBAgEAw4H;yBAEAC;;;;;;;;;;;yBApBA14H;yBAgBAw4H;yBAFAD;;;yBAhDAn4H;yBAgCAK;yBAFAP;yBAVAC;yBAIAG;yBAFAD;yBAMAE;yBAFAC;yBAhCAI;yBAFAC;yBAIAC;yBAEAC;yBAIAo3H;yBAZAp4H;yBA0BAu4H;yBAXAF;sBzciHAn7L;sBJ5HEtV;sB8DVN;;sBmY+EoB;;;0BnY0HL;;2BAED;2BAEyB,iCArEtBj+I;2BAqEQ;;;;4BAQrBq0E,kB,yBAAApyE,EAAyD;0BARpC,SAQrBihP,UAASjhP,8BAAG;0BARS,SAQrBmhP,UAASnhP,8BAAG;0BARS;;;;;;mCAQrBs3F,iCAAyD;0BAE9B;4CAVvB01P;2BAoBA;+BAEK,0BAZLE;0BAUA,SAKEz2K,WAAet5J,IAAMouI,QAAQmrB;4BAC/B,sCADuBnrB,WACiC;0BANxD,SAQE+qB,kBAAe,OAlBjB42K,eAkBgC;0BARhC,SAUE32K,YAAYp5J,IAAKjF,IAAI3U;4BACd;2CuJpEbkkK,iBvJoEiC,mBADNlkK;6BAEf,gBADJ4hO;4BAEJ,kBAFIA,KADUhoN,IAAKjF,IAEfrV;4BAEI,GAFJA,IAtBJqqV;8BAyBoB,UAzBpBA;8BAyBoB,cAHhBrqV;oCAGF9E,EAHE8E;gCAIA;gDANUsa,IAAKjF,MAKjBna;kCACE,UADFA;;;4BAGF,OARmBma,MApBnBg1U,mBA4B2B;0BAlB3B,SAoBEv2K,aAAWx5J,IAAKouI;4BAClB;mCADkBA;6BAEI,8BAFTpuI;4BAGV,GADCgwU,kBAhCJD;6BAkCE;gDAlCFA,gBAgCIC;4BADJ;6BAOI;;gCuJnFR3lL,gBvJ2EsBjc,eA9BlB2hM,iBA8Ba/vU;6BAOX;4BAGS,aAxCX+vU,kBA8BkB3hM;4BAUP,OAJPhoJ,CAKH;0BA/BD;;;;+BADEwyK;+BASAO;+BAEAC;+BAUAI;+BAfAF;2BALF;;;;;;;;mCAkCAznG,SAAMhvE,EAAEzB;4BAAI,2CAANyB,EAAEzB;4BAAI,sCAAoB;0BAlChC,SAoCAioH,SAAMxmH,EAAEzB;4BAAI,2CAANyB,EAAEzB;4BAAI,sCAAoB;0BApChC,SAsCAkoH,SAAMzmH,EAAEzB;4BAAI,2CAANyB,EAAEzB;4BAAI,sCAAkB;0BAtC9B,SAwCAkzC,OAAOzxC,GAAI,gBAAJA,IAAS;0BAxChB,SA0CIotV,mBAAmBltV,EAAEC;4BACxB,cAvDLiyE,MAsD6BjyE,EAlEzBwyD,OAmEmB,UADIzyD,EAnIdnC,EAiET40D;4BAqEM;sDAHmBxyD,EAGE,mBAHJD,EAAEC;6BAGnB;;;4BAEK;oCADT/D;oCAAMmC;oCACG,SADNyB,EACU,SAAC,mBALOE,EAAEC,GAIjB5B,IACoB;0BA/C5B,SAiDA8uV,WAAWrtV;4BACE,6BADFA,WACE;mCAARE,CACN;0BAnDC,SAqDAo6I,IAAIt6I;4BAAI,mCAAJA;4BAAI,sCAAyB;0BArDjC,SAuDA0mH,SAAM1mH,EAAEzB,GAAQ,gBAAVyB,EAAU,WAARzB,GAAoB;mCA3K9B2uE,OAAOltE,EAAE6C;4BACH,yBADGA,GASC,IARRX,UACOg2C,IAyBEn6C,EAzBEwvE;4BACb;8BAAQ,GADKA,QACO,OADXr1B;8BAGG;4CAHHA;+BAIM,yBANNr1C,EAEI0qE,KAIwB,SAD/B5a,MALC3yD,GAKD2yD;+BAEQ,IALD4a;+BAAJr1B,IAIHq5B;+BAJOhE;uCAOG;0BAGqB;;2BAAb;2BAAT,yBAyFb0/Q;2BAzFa;mCADfhgH,UAEEjtO;4BAAW,kBA2FfoyE,MA3Fe,OAAXpyE,EADAstV,OAeSvvV,EAdkB;0BADd;2BA8BbwF;;;+BAX6B;;gCAAR,qBAsErB0pV;gCApFS1/Q;+BAAI;iCAAG,sBADJ1qE,EACH0qE;mCAgBH,yBAjBM1qE,EACH0qE,KAUAiI;mCAAI;qCAQuB,gCAR3BA;;uCAA6B;;wCAYI;wCAAb;wCAAL,yBANtBjyE;wCAMsB;uCADK,UArBpBgqE,IAqBoB,OAXIvtE,EAM/BuD;qCAEkC,IARiB,aAA5CiyE;;iCAV4C,QAA5CjI;;0BALI,SAiCX00B,KAAMsrP,QAAQnoU,KAAKpiB;4B,IAALk2I;4BACpB;8BAAG,cADSq0M,QAAQr0M;gCACmB,sBADdl2I,EAALk2I;8BACmC,OADnCA,OACuC;0BAlC1C,SAoCXiuF,KAAKhnO,EAAE0C;gCAAF2lG,MAAE7gD;4BAAI;8BAAG,mBAAPA;gCAAuC,QAAvCA,YAAuB,WAAzB6gD,aAAE7gD;;8BAAmD,OAArD6gD,IAAsD;0BApChD,SAsCfskI,KAYE5sO;4BACF;gDArBEqD;6BAqBF,oBArBEA,mBmI7HJktE,iBnI6HIltE;6BAyBA;;;6BAEM,SAPNrD,EAGIstV;6BAKE,WARNttV,EAOEO;6BAEI,WADJT,EADAS;4BAEI;8BAKJ;8BAxBJ;gCAGE;gCAAkB,iBAAZgtV,KAAKr3U,UAA+B;8BAH5C;wCAwBcjW;+BAxBd;;;qCACU,IAAMstV,aAAe,sBAmDjCr7Q,MAnDkBq7Q,IA1BL1vV,EA0BoC;;;;+BAyBjC,OAFHopC,GAAS5kC;+BAGN,WADJ9B;+BAEgB,eAJTT,EAEPS;8BAEK,UADLu8J,IACK,SAJD78J,EAGJ68J,iBACgC;4BATlC;sCAP2B71H,EAO/BhnC,EADAH,EAP4BuC;6BAU9B;;yCACeuU,GAAS,sBA8B5Bs7D,MA9BmBt7D,KA/CN/Y,EA+C8B;;;6BADvC;mCADI6iG,GAUL;mCA+FD8sP,UAAU1tV,GAAI,0BAAJA,UAAsB;mCAEhC2tV,iBAFc,YAAkB;mCAIhC/gH,OAAOrpO,G,0BAAAA,IAA8B;mCAErCqqV,SAASjtK,IAAIx/K,GAAGE;4BAClB,SAAIwsV,mBAAmBhrV;8BAAI,uBAAJA,GAAI,gCAAiC;4BACnC,yBAFd89K,IAAIx/K,GAAGE,IACdwsV,mBACsD;mCAGxDC,cAAcntK;4BACL,IAAP37K,KAAO,gCAxFPioV;4BAyF6B,gBAFjBtsK,IHrHczoI,IGuHG,SAD7BlzC,KHtHaqwN,cGuH2B;0BAEpC,IAAN10C,IAAM;mCAENmf,SAAS3+L,GAAGE;4BACd,SAAI0sV,mBAAmBxqV;8BAAI,uCAAJA,GAAqC;4BACX,6BAFnClC;4BAEW,8CAFdF,UAE6D;0BAExD,IAAdwrO,YAAc;mCAEdx5B,iBAAiBhyM,GAAGE;4BACtB,SAAI0sV,mBAAmBxqV;8BAAI,uCAAJA,GAAqC;4BAE1D,6BAHoBlC;4BAEW;2EAFdF,UAGM;0BALT,SAOdylG;4BAAY,2BAPZ+lI,YAO+C;0BAPjC,SASdqhH,UAAUnrV;4BACZ;6CAEiBq1C,IADDl1C;0CACC2vD,UAAI50D;sCACb;wCAAQ,GADKA,MAlHjBivV,eAmHqC,OADxBr6R;wCAE6B;6CAFzB50D;yCAEL,iBAHAiF,EACC2vD,MAEM,mBALX9vD,EAGS9E;yCAAJ40D;yCAAI50D;iDAIN,EACd;0BAEW,SAAVwnO;4B,OkG/II50G,UnG7INu7N,WCkRE8B;0BAUU,SAEVl8Q,KAAKjvE,GAAwC,0BAAxCA,GAAqD;0BAFhD,SAIVykO,QAAQh0L;oCAjINqf,kBAiIMrf;;;oCAID6xL,YAALhlO;;iCACmC;2DAvM1BpC;kCAuMHwzE,MAAgB;;qCAAhBA;gCACQ,wBADRA,oBADD4zJ;;8BAKN,iDAA0C;0BAbjC;mCAuBV7sL,OAAOt4C,GAAI,kCAAJA,EAAwB;;;;;;;;;;8BAE8B;;+BAAb,UAAC;+BAAZ;+BAAHo7Q;+BAAG;;+BAAHxzN;;sEAAC;;uCAAD4D,qDAAoC;;;;;;;;;;8BAItD;;+BAAZ;+BADN;8BACM,4BAjJFyhS;gCAkJgC;qDAAa;iCAAjC,QAAM,iBAFlB9sV;iCAESi7Q;iCAAG;;iCAAHxzN;;;0EAAC;;yCAAD2D;8BACR,QAAE;;;;;;;;;;8BAGP,SAAQviC,IAAI9oB;gC;;;wCAGHozE,cAALtzE;;;;;;;iDACiB67C;2C,GAAAA;;;mFAAC;;oDAADyP;4DAJTprD,EAGRF;sCACkC;6DAD7BszE;kCADH;8BAII,IAANqtG,IAAM,2B2HlDZ/gD;8B3HkDY;;;;;;;;;uCAAN+gD;gDACmC99K;yCAC3B;kDAD2BA;0CAErB,YADV8kD;0CAE4C,uBAF5CA;0CAE+B;0CAAV,0BAFrBA;yCAEA,gBAAM,iBADNosB,WACsD,EAAE;;kCA7JhEktK;;;;;;;;;;;;;;;;;kCAHIgsG;kCA1ESlvV;kCAiET40D;kCA0DAqc;kCAIAy3C;kCAFAD;kCAmBAE;kCAfAj1E;kCAoCFkvI;kCAEAmf;kCAIA6sC;kCAEAx5B;kCAKAvsG;kCAmCAtuD;kCAvEEgiG;kCAYFsyF;;;;kCAwCAtF;kCA1CAqmH;kCAFAD;kCA8BAM;kCAYAl8Q;kCAFAyzJ;kCAzHEynH;kCArFF//G;kCAuCAH;sBA+mBH;;sB9DnwBG7wF;sBI4HFsV;sBADAD;sBJ5HEtV;sBueVN;;sBtC+EoB;uBsChDZ;;;;;;;uC3K+N0B8sG;;uB2K/N1B;iCAAQ5oP,G,UAAR+tV,kBAAQ/tV,KACuC;uBAoB/C;;;;;;;uC3K0M0B8pP;;uB2K1M1B;iCAAQ9pP,G,UAARiuV,kBAAQjuV,KACuC;uBAD/C;iCAAK+8K,UAAL16K;0B,kB3K0M0B0nP,c2K1MrBhtE,UAAL16K;;iCAAK26K,QAAL//J;0B;8C3K0M0B+sO,e2K1MrBhtE,SAAL//J,UAC+C;uBAD/C;iCAAKugI,KAALvgI;0B;8C3K0M0BgtO,c2K1MrBzsG,MAALvgI,YAC+C;uBAD/C;iCAKJ+jO;0CAAYlhP;4BAAZ,6B3K8LAuqP,a2K9LArJ,QAAYlhP,EAAqB,CACc;uBAN3C;iCAKJkhP;0CAAYlhP;4BAAZ,6B3K8LAwqP,a2K9LAtJ,QAAYlhP,EAAqB,CACc;uBAN3C;iCAKJgiJ;0BAAe;mC3KwSbooG;4C2KxSU4E,+BAAZhtG,MAAYgtG,YAAE;mCAAdH;yCAAiC;uBAL7B;iCAKJ7sG;0BAAe;mC3K4SbsoG;4C2K5SUjtE,+BAAZr7B,MAAYq7B,YAAE;mCAAdF;yCAAiC;uBAL7B;;wC;uBAAA;wC;uBAAA;;0B;uBAAA;wC;uBAAA,sB;uBAAA;;0B;uBAAA;;0B;uBAAA;;0B;uBAAA;;2B/aEU;;4BAEK;yCAFjBgyK,UAEAC;2BAAiB,SAIjBC,OAAO9rV;6BACE,IAAP4B,KAAO,yBADF5B;6BAEQ,sCAA0B,SADvC4B,OAC8D;2BAN/C,SAQjBmqV,cAAc/rV,GAAW,2BAAXA,GAAmB;2BARhB,SAUjB8tH,UAAU9tH,GAAI,kCAAJA,GAAqC;2BAV9B,SAYjBgsV,cAAgB1zS,IAAgBt7C;6BAClC,GADkBs7C,IAAU,QAAVA,eAAU27B,aAAV0kB;6BACc;+BAAb,gBADe37F;;;;+BACS,gBADTA;;;+BAE1B,IAAJg+D,IAAI,YAF0Bh+D;+BAGlC;;;;;;4DAA2B,iBAHT27F,kBAEd39B,IAC6D;2DAEtD;;;;;;;;;;+BAIT;;wCAiCI/9D,oBAjCqD,6BAAgB;gCAEnE,gBAAO,SAHXwR;gCAIiB,qBAAkB,cAAe,gBAA3CoiE;gCAAU;;gCAAVxsB;;mDoHjDPwgI,WpHiDOrR,YAAM;;wCAANrsH,OoHjDPw9H,apHiDO9zD,oCAA8D;oCAEvE4oD,UAAUz8K;6BAAkB,kCoHnD1B0nL,apHmDQ1nL,GAAsC;2BAShD;;2CAEK;2BAFL,SAKEk2K,WAAet5J,IAAMouI,QAAQmrB;6BAC/B,sCADuBnrB,WACqC;2BAN5D,SAQE+qB,kBAAe,OAWb91K,GAX4B;2BARhC,SAUE+1K,YAAYp5J,IAAKjF,IAAI3U;6BACX,IAARyO,MAAQ,yBADWzO;6BAGvB,yBAFIyO,QADUmL,IAAKjF,IASf1X;6BANJ,OAHmB0X,MASf1X,OAJK;2BAfT,SAiBEm2K,aAAWx5J,IAAKouI;6BAClB;oCADkBA;8BACI,8BADTpuI;6BAGV,mBAFCgwU,gBACA3sV;+BAEF;iEAHE2sV;6BAAJ,IAKIn7U,MAAQ,yBANCmL,IAAKouI,WAEd/qJ;6BAIQ,aAJRA,MAFc+qJ;6BAMN,gCAARv5I,MAEU;2BAzBd;;;;gCADE+jK;gCASAO;gCAEAC;gCAOAI;gCAZAF;4BALF;;;;;;;;oCA4BA+4K,WAAWjvV,EAAGyJ;6BAAO;sCAAVzJ,EAAU,sBAAVA,GAAGyJ,KAA0C;2BA5BxD;;;;;;;;;mCATAgzK;mCAhBA3rD;mCAzDJ69N;mCAEAD;mCAEAD;mCAEA52G;mCAEA22G;mCAIAD;mCAEAD;mCAEAD;mCA6BIO;mCAEAC;mCAsDI5uV;mCAlDJ6uV;mCAIAC;mCAIAC;mCAmDAC;;uB+anEE,sB;uBAAA;;0B;uBAAA;;0B;uBAAA;;yC;;;;uBAAA;;0B;uBAAA,sB;uBAAA,sB;uBAAA;;0B;uBAAA;;0B;uBAAA;wC;uBAAA;;0B;uBAAA;;0B;uBAAA;;0B;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA;;0B;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA;8C;uBAAA;8C;uBAAA;8C;uBAAA;8C;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA;wC;uBAAA;;;;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBAAA,sB;uBAAA;;0B;uBAAA;;0B;uBAAA;;yC;;;;uBAAA;;0B;uBAAA,sB;uBAAA,sB;uBAAA;;0B;uBAAA;;0B;uBAAA;wC;uBAAA;;0B;uBAAA;;0B;uBAAA;;0B;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA;;0B;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA;8C;uBAAA;8C;uBAAA;8C;uBAAA;8C;uBAAA,sB;uBAAA,sB;uBAAA,sB;uBAAA;wC;uBAAA;;;;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBAAA;uBA4CI;uCAAJrvV;uBAAI,sB;uBAAA,sB;uBAAA,sB;uBAAA;8C;uBAAA;8C;uBAAA,sB;uBAAA;8C;uBAAA;;0B;uBAAA;;;yC;;;;;;;;;uBAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wC;;uBAAA;;;;;;;;;;uBAYA;yCAAJqoG;uBAAI,sB;uBAAA,sB;uBAAA,sB;uBAAA;8C;uBAAA;8C;uBAAA,sB;uBAAA;8C;uBAAA;;0B;uBAAA;;;yC;;;;;;;;;uBAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wC;;uBAAA;;;;;;;;;;+C,IAeOgwK;uBAfP;wC,IAiBSC;uBAjBT;iCAqBHA,UAAUD,SAAe,UAAzBC,UAAUD,QAAqC;uBArB5C;;;;;8BAmBJy3E,OAJAz3E,QAEAC;uBAjBI;wC,IAgCOD;uBAhCP;wC,IAkCSC;uBAlCT;iCAsCHA,UAAUD,SAAe,UAAzBC,UAAUD,QAAqC;uBAtC5C;;;;;8BAoCJ23E,OAJAxkD,UAEAukD;uBAUgC,qBlchIlCn2E;uBkckIkC;+BlchIlCC;sBkcgIqE;;sBve/IrE/9H;sBI4HFsV;sBADAD;sBJ5HEtV;sBwjBVN;;sBvH+EoB;uBuH/EpB,SD6MMo0M;uBC7MN;;0B;uBAAA;;0B;uBAAA;;0B;uBAAA;;0B;uBAAA;;0B;uBAAA;;;2B;;;;;;uBAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wC;uBAAA;;;;;;;;;;;;;;;sBAOQ;;sBxjBIFn0M;sBI4HFsV;sBADAD;sBJ5HEtV;sByjBVN;;sBxH+EoB;uBwH/EpB,S9cQIq0M;uB8cRJ;;0B;uBAAA;;0B;uBAAA;;0B;uBAAA;;0B;uBAAA;;0B;uBAAA;;;2B;;;;;;uBAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wC;uBAAA;;;;;;;;;;;;;;sBAOQ;;sBzjBIFp0M;sBI4HFsV;sBADAD;sBJ5HEtV;sB+DVN;;sBkY+EoB;uBlY/EpB;;;;;;;;;;;;;;;+CASkB,sBAAgB;uBATlC;;;;iCAwCkBh5I,EAAG84B;0BACnB,UADmBA,MAJD,kBAICA;;mCAAH94B;mCAJE;qCAAdwW;8CAC2Bzb;uCAC3B,6CAFAyb,YAC2Bzb,EAC0C;mCAEtD+9B,GAC+B;uBAzCpD;;;2B;uBAAA;;;;;2B;;uBAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6C;uBAAA;;0B;uBAAA;;+C;;;uBAAA;;;2B;;uBAAA;;;2BAqDM2vB;;;;;;;;;;uBArDN;iCAqFqBglS,IAAIpiO;0BACnB;;qCAAiC,8CADlBoiO,IAAIpiO,GACiC,EAAC;uBAtF3D;iCAwFsBp2C,OAAQooO,GAAgB9+E,QAAQE,UAAUkvH,WACxDC;0BAEF,SAAI1M,gBAAgBnmV;4BAEf;8CAFeA,EAEX,8BAL+BwjO;6BAKX,qCALWA,QAGpBxjO;4BAGM,UAHNA,IAGM,8BANcwjO;4BAMd,qCANsBE,gBAMP;0BAKvC;kDAXsB4+E,MAGpB6jC;2BAQF;;2BAEa,SAAa,iBAHxB2M;2BAOF;;8BqfxGJzvC;uCrfwG+D3oR;gCACzC;;uCALhB2rT;iCAKgB;;sCACdvrT;kCACE;oCAAwD;;;yCAAtB,iBAVtCg4T,iBAOyDp4T,cAEvDI;;oCACE,8BAFEs6H;oCAEsD,UAD1Dt6H;;;gCAGA,OAJIs6H,OAIG;0BALX;mCAjBcl7E;mCAAQooO;mCAgBpBxoR;mCANkBg6N;mCAVoC8+F;mCACxDC,WAuB+D;uBAhHvE;iCAkHsBvwC,GAAiB9+E,QAASE,UAAWkvH,WAClDC;0BACH;;qCACUvwC,GAAGvhF,gBAAgB+yB,eAAeriO,gBAAgBuI;qCACxD;;gDACI;yDAFEsoR,GAAGvhF,gBAAgB+yB,eAAeriO,gBAAgBuI,SAEa,EAAE;mCAL3DsoR;mCAAiB9+E;mCAASE;mCAAWkvH;mCAClDC,WAI0E;uBAvHnF;iCAyHgBvwC,GAAiB9+E,QAASE,UAAWkvH,WAAYC;0BAC3D;;qC;;mCADUvwC;mCAAiB9+E;mCAASE;mCAAWkvH;mCAAYC,WACI;uBA1HrE;;;;yBAyHQE;yBAPAxwC;;2B;yBA7BAC;uBArFR;;;;;;;;;2BAmEM70P;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBAnEN,6BAqJ2B,QAAE;uBArJ7B,8BAuJ4B,sBAAe;uBAvJ3C,SAqJYqlS,aAEAC;uBAvJZ;;;;;;;uC;sBkY+EoB;uBlY/EpB;;0B;uBA2KiB,0B,OAnIbR;uBAmIa;;0B;uBAEkB;wC,OArI/BA;uBAqI+B,WAF3BS,UAEApwC;uBAA2B;;sBAE/B;;sB/DpKE5kK;sBI4HFsV;sBADAD;sBJ5HEtV;sBgEVN;;sBiY+EoB;uBjY/EpB;;;;;;;;;;;;;;;iDASkB,sBAAgB;uBATlC;;;;iCAyCkBh5I,EAAG84B;0BACnB,UADmBA,MAJD,kBAICA;;mCAAH94B;mCAJE;qCAAdwW;8CAC2Bzb;uCAC3B,6CAFAyb,YAC2Bzb,EAC0C;mCAEtD+9B,GAC+B;uBA1CpD;;;2B;uBAAA;;;;;2B;;uBAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6C;uBAAA;;0B;uBAAA;;+C;;;uBAAA;;;2B;;uBAAA;;;2BAsDM6vB;;;;;;;;;;uBAtDN;iCAsFqB8kS,IAAIpiO;0BACnB;;qCAAiC,8CADlBoiO,IAAIpiO,GACiC,EAAC;uBAvF3D;iCAyFsBp2C,OAAQooO,GAAiB9+E,QAASE,UAAWkvH,WAC1DC;0BAEH,SAAI1M,gBAAgBnmV;4BAEf;8CAFeA,EAEX,8BALgCwjO;6BAKZ,qCALYA,QAGrBxjO;4BAGM,UAHNA,IAGM,8BANewjO;4BAMf,qCANwBE,gBAMT;0BAKvC;kDAXsB4+E,MAGpB6jC;2BAQF;;2BAEa,SAAa,iBAHxB2M;2BAOF;;8BofzGJzvC;uCpfyG+D3oR;gCACzC;;uCALhB2rT;iCAKgB;;sCACdvrT;kCACE;oCAAwD;;;yCAAtB,iBAVtCg4T,iBAOyDp4T,cAEvDI;;oCACE,8BAFEs6H;oCAEsD,UAD1Dt6H;;;gCAGA,OAJIs6H,OAIG;0BALX;mCAjBcl7E;mCAAQooO;mCAgBpBxoR;mCANkBg6N;mCAVuC8+F;mCAC1DC,WAuB8D;uBAjHvE;iCAmHsBvwC,GAAiB9+E,QAASE,UAAWkvH,WAClDC;0BACH;;qCACUvwC,GAAGvhF,gBAAgB+yB,eAAeriO,gBAAgBuI;qCACxD;;gDACI;yDAFEsoR,GAAGvhF,gBAAgB+yB,eAAeriO,gBAAgBuI,SAEa,EAAE;mCAL3DsoR;mCAAiB9+E;mCAASE;mCAAWkvH;mCAClDC,WAI0E;uBAxHnF;iCA0HgBvwC,GAAiB9+E,QAASE,UAAWkvH,WAAYC;0BAC3D;;qC;;mCADUvwC;mCAAiB9+E;mCAASE;mCAAWkvH;mCAAYC,WACQ;uBA3HzE;;;;yBA0HQY;yBAPAD;;2B;yBA7BA7wC;uBAtFR;;;;;;;;;2BAoEM90P;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBApEN,6BAsJ2B,QAAE;uBAtJ7B,8BAwJ4B,sBAAe;uBAxJ3C,SAsJY6lS,aAEAC;uBAxJZ;;;;;;;uC;sBiY+EoB;uBjY/EpB;;0B;uBA4KiB;wC,OAnIbL;uBAmIa;;0B;uBAEkB;wC,OArI/BA;uBAqI+B,aAF3BM,UAEAC;uBAA2B;;;sBAE/B;;sBhErKE31M;sBI4HFsV;sBADAD;sBJ5HEtV;sB0jBVN;;sBA2CG;;sB1jBhCGC;sBI4HFsV;sBADAD;sBJ5HEtV;sBiEVN;;sBgY+EoB;uBhY/EpB;;;;;;;;2BAGM61M;2BAEAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAOS,SAAPx6P,Y,O+F2KEq5B;0B/F3KK,SAEP/E,YAAY9mG,MAAMvhB;4BAA2B;qCAAjCuhB,MAAiC,iBAA3BvhB,GAA4C;0BAU9D;;2BAmBF,gCApBIwuV;2BAoBJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BA/BEz6P;6BAEAs0B;;;;6BAQA+0D;2BAqBF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BA/BElpF;6BAEAmwF;6BAEA5sG;6BAEA2hD;6BAEAjD;6BAEAo5F;;;2BAqBF;;;;mCAYAx1H,mCAAqD;0BAZrD;;;;;mCAcIiwM,iBAFJ,YAAqD;0BAZrD,SAgBItsD,UAAU19O;4BAA4B,uCAA5BA,GAAyC;0BAhBvD,SAkBI49O,UAAW5+O;4B,UAAAA;8BAIT,MAJSA,KAIT,eACUvC,GAAK,UAALA,EAAgB;8BACxB,gCAHIO;4BAKN,YAA2B;0BA1BjC;;;kCA+BE20E;2BA/BF;;;;;;;;;2BAYA;;0BAZA;2BAYA;;;;;;;;;;6BAEIq4N;6BAEAtsD;6BAEAE;;;;;;;;;;2BANJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mCA2CAmxG,eAAeh/S;4BACT,MADSA,gBACT,KAAJzwC;4BAAI;qCAQJrC;8CACoB+0E;uCAAK,eAALA,QARCr9B,MAAKn6C;uCAC5B;yCAAoB;gDADQA;0CACR,mBAFlB8E,MACctB,SAAYxD;yCACgB,GAAxCw0V,SACa,kBAFMr6S;yCACH;0CAGlB,MAJc32C,SAAYxD;0CAIb;4DANAu1C,uBAEQ4E,WAAKn6C,EAALm6C;0CAKrB,IAL0Bn6C;0CAALm6C;0CAAKn6C;kDAQoB,EAAC;0BArDjD,SAuDAy0V,eAAejyV;4BACjB;+DADiBA;8CAGPxC;uCACc,sBAJPwC,EAGPxC,WAEF4F,EAFE5F;uCAGD,SAFDyF,MACAG,qBACsB,EAAE;0BA7D9B;kCApDAkuV;kCAEAC;;;;kCAkDAptO;;kCA0BJu9H;;kCAEAmwG;;;;;;;kCqUlCOzzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCrUiDH2zC;kCAYAE;uBA9GN;;;;;;;;;;;;;;;;0BA4HI;8CAAuB;2BADvB;;;2BADS5qS;;8C2G3FLwgI,W3G2FKukE,YAAM;;mCAAN7gM,O2G3FLo8H,a3G2FK9zD,oCAEkC;;;;;;;;;;0BAG7C;;;;;;;;;mCsFgFQ8uC;4CtF/EO9uF;qCAAU;0DAAgB,iBAA1BA;sCAAU;;sCAAVxsB;;yD2GjGTwgI,W3GiGS9M,YAAM;;8CAANzvH,O2GjGTq8H,a3GiGS9zD,oCAA6C,EAAE;;;sBjErH1D6nB;sBI4HFsV;sB6bxDgB;uB0H7EL;;uBCEA;;;;;;;uBCDE;;;;uBCGG;;;;;;;;;uBCFL;;;;uBCDE;;;;;;;;;;;;;;uBCDF;;uBCAA;;uBCAA;;uBCAA;;;;uBCAA;;;;;;;;;;;;;;;;;;;;;;;;;;uBCAA;;uBCCD;;;uBCDC;;;uBCCE;;uBCDF;;;;;;;;;;;uBCAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wB;;;;;;;;;;;;;;;;;;sB1I6EF;yBlQ3DhBh2I,SACAu0D;;uB;;;;;;4CADAv0D,M;;;;;;;;;;sBkQ2DgB;;;;;;;6ClQ7DhBs0D;;;;;;;sBkQ6DgB;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2CtOsNdynB;2C5BnRFznB;sBkQ6DgB;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCtQ+ed7C;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gDP/CE;gD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BwC4CuC;0B,SAUxB2lR,W;mCADDC,W;;oCAAAA;oCACCD;oCACAD;oCACCD;kC;;;;;;;;;;;;;;;;;;sCrMpkBFp8S;;;;;0B;;;;;;;4B6J4gBd;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uC7QgcZ,oB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4E0CvgBF62D;;uB;;;;;;;sBmOuEc;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;;;;;;uB;;;sBAAA;uB;;;;;sBAAA;;;;0B;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kC7QgcZ;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCwCqpBAe;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BxCrpBA,yB;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4D1QqvBd/gC;;qC;;;;;;gD8BxyBF+wB;;;;;+C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gDAAAA;;;;;;;;;;;8B;;;;gDAAAA;;;;;;8B;;;;;gDAAAA;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BjCmfI,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2CO+CFjxB;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oEAAAA;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4CAAAA;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCP/CE;;iD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2CAAA;;;;;;;;;;;2C;;;;;;;;;;;2DwZ5cG6lR,M;;;;;;6CrjBhEWx8S;4B;;;gEsMgBlBhwB,a;;;;;;;;;;;;;;;;;;;;;;;;0BzC4fI;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEwZ5cGwsU;0B;;;;;;;0BxZ4cH;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;kC;;;;;;;;;kEmB5dJ39Q,4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6CEwCO;6CD+HT,uBADS30E;4CACT,SAAIuC;uDADKvC;;8CAGC,wBAFNuC,GAEM,MAFNA,UAEM;;oDACR/E;gDAAsB;;6EAJfwC,EAIPxC;mD,mCAAAA;wEADI6D,EACJ7D;kDAAsB,UAAtBA;;;8CADQ,UAAJ6D;4C;;;;;;;;;;;;;;;;;;;;;;8CX3GDkB,WAAH5C,W,OAAAA,K,OAAAA;0C;;;;;;wEAAG4C;;;;;;kC;;;;;;;;;;;;0B+B0vBuC;;;;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEgXxyBnC+vV;mC;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B,mDAAAA;0B;;;;;;;;;;;;;;sB3IYS,uB;;;;;sBAAA;;;;;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wC2IZTA;uB;;;;;;;;;;;;;;;0BxZ4cH;0B;;;;;;;;;;;;;;;;yCwZ5cGA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;qEAAAA;0B;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;qEAAAA;0B;;;;qEAAAA;0B;;;;;qEAAAA;0B;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;qEAAAA;0B;;;;qEAAAA;0B;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;qEAAAA;0B;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;qEAAAA;0B;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;qEAAAA;0B;;;;;;;qEAAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxZ4cH;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDarfJpiR;iC;;;;;;kDAAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BbqfI;;uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;;;;;;;;;;;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;sE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wE+BpYgB6lF,I;yEAAAA,I;qEAAAA,M;kEAAAA,M;;;2CyXxEbu8L;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BtlBoJT;;;8B;;;;;;;8B8LwTM,c;;;8B9LxTN;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB2cxIkB;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oC4IrCH,WAAJ90V;oCAAI,YAAJA;;;;;mC;;2CAAAA,E,gDAAAA;iC;;;kC1XkGX;wCAAIma,IADkBo+I;oCACtB,GADsBA,UAClBp+I,IACoB,OAFFo+I,IAHpB51E;oCAIF;qCAC4D,MAFtC41E;qCXmftB;;wC;qCAAA;sDAGkB;oCACT;qCAGA;sCAMA;wCAOA,mBAQF;wCAPH;8CWvgBAp+I;yCXugBA;0CApBA68B,MAoBI4vI;;6CAEH,qBWzgBDzsK;6CX0gBC,UW1gBDA;6CX2gBC,UW3gBDA;6CX4gBC,UALGysK;;;uCAPJ;+CWhgBAzsK;wCXggBA;yCAbA68B,MAaI+9S;;4CAEH,qBWlgBD56U;4CXmgBC,UWngBDA;4CXogBC,UAJG46U;;;sCANJ;8CW1fA56U;uCX0fA;wCAPA68B,MAOIg+S;;2CAEH,qBW5fD76U;2CX6fC,UAHG66U;;;sCAHJ,qBWvfA76U,eAEArV;;sCAEE,OALgByzJ,IAHpB51E;oCASG,SALDxoE,MAEArV;;;;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iC/BiYE;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;;;;;;;;;;;;;;uD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,gB;;;;;;;;;;;;;;;0BAAA,+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,qB;;;;0DGqTFqqE;mC;;;;;;;;iCAhyBFe,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BH2eI,mB;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;0B7QgcZ;;qD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;;;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;;;;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;;;;;;;;;;;;;;;;;;;;;;0E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,gB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2CwCqpBAggC;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BxCrpBA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCwZ5cG4kP;;;2B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxZ4cH;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kD2IZTA,Q;;;;;;;;;;;;;;;;;;;;;;;;6BAAAA;;;;6B;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAAA;;;;;4B;;;;;;;;;;;;sCAAAA;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB3IYS;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6B2IZTA;;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yBAAAA;;;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCxZ4cH;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8B7QgcZ;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ;;;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAAA;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8CwZ5cGA,mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4CAAAA,M;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BxZ4cH;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BAAA,qB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iDAAA;;8C;;;mDgBtfJ7gR;;uD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BhBsfI;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ,uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gEwZ5cG6gR;6B;;;;;;;;;;;;;;;;;;;;;;;;;kEAAAA;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB3IYS;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gE2IZTA;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8CAAAA;;;6B;;;;;;;;sB3IYS;uB;;;;;;;;;;;;;;;;;0B7QgcZ;4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wDejcArhR,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB8PCY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8B7QgcZ;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEwZ5cGqhR;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxZ4cH;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDarfJpiR;;0B;;;;;;;;;;;;;;;;;;;;;;qCbqfI;sC;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mC7QgcZ,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;;;;;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;;;;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCAAA;;;;;;;;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;gC;;;;;;;;;;;;;;;;;;4BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0B7QgcZ;;;;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDAAA;8D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,kB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAAA;gD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4CAAA;4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAAA;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2CAAA;oD;;;;;;;;;0BAAA;;;;;;;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;;;;;;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAAA;wD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;+B;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;sC7QgcZ,mB;;;;;;;;;;;;;;;;;;sB6QhcY;mD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gD2IZToiR;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mChXimCH5kP;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDAAAA,oBCjpCJ5nF;yC;;;;;;;;;;;;;;;;uDtBsBA4uD,K;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCnBseI;;;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ;4B;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;gEpQ3ChB3C,oB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCT2eI,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA,sB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCAAA;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;qD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA,sB;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;gD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCSyDN,SAAQ0qJ,OAAO10E,MAAMp3E;oCACnB,SADao3E;sCAGX;;kEAAmBpwG,IAAIl4C,GAAK,UAALA,EAAJk4C,IAAe,QAHjBg5B;oCAKR,qBALQA;oCAKR;0CAEMF,cAAHhxE;sCAAiB,UAAjBA,EAAiB,OAPlBsoJ,cAOIt3E;oCADF,QACqC;kCAPtD,0BADSI;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BTxDH;;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCwCqpBA68B;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CxCrpBA,sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAAA;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iC7QgcZ;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uEwZ5cG4kP;;;;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxZ4cH,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;0B;;;;;;;;sBAAA;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mCrOqlCZ5kP;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxCrpBA;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCgBpfM;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BhBofN;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;;;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDAAA;mD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4B7QgcZ;;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,mB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mEwZ5cG4kP;;;;;;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCvY3CP3gR,sB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB4PuDgB;;;;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0B7QgcZ;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCwCqpBA+7B;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDgXjmCG4kP;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BxZ4cH,+C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDAAA;;;0D;;;uEwZ5cGA;0D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BxZ4cH;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAAA;wD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8CAAA;8C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0B7QgcZ;mC;;;;;;;;;;;;;;;;;;;;;;;;;8BwZ5cGA;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BxZ4cH;wE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8DwZ5cGA,kB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCxZ4cH;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;;;;;;;;;;;;;;;;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;;2B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;;;;;;;;;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2BAAA;;;;;;;;;;;;;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6CAAA,gB;;;;;;;;;;;;;;;;4BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;kC;;;;;;;;;;;;;;;;;;8BAAA;;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gFwZ5cGA,S;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4ChYpBPt8Q;;;;mC;;;;;;;;;4CzNjBiBO;;;;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BiMifb;qC;;;;;;;;;;;;;;;;;;;;;;;;yES3dJl9D;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEAAAA;;;;gC;;;;;;;;;;;;;;;;;uEAAAA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gEAAAA;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iEAAAA;;;;mD;;;;;;;;;;;;;;;;;;;;6CMlBIq3D;kC;;;gEAAAA,6B;4DAuBAI;4B,OAlCJT;0B,IAEO5wE,E;iDAAO,UAAPA,EAFP4wE,O;;;;;;;iEN6BAh3D;6B;;;;;;;0CM7BAg3D;kC;;;;;;;;;2CAWIK,+B;;;;;;;;;;+DAXJL;oC;;;;;;;;;6CAWIK;kC;4DAuBAI;4B;;;;;qCAvBAJ;0B,OAXJL,K;;;;;;;wDAWIK,uB;;;;;;;;;;;uENkBJr3D;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEAAAA;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDT2dI;;mD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDezeAu3D;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BfyeA;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA;;;;;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA,qB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAAA;;;sC;;;;;;;;;;;;;;;;;;;qCAAA;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;;;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAAA;;;;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;+B;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;;;;2D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCwCqpBA88B,oD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBqOrlCY;;;0B;;;;;;;;;;;;;;;;;;;;;8B7QgcZ;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iCAAA;;;;wD;;;;;;;;;;;;;;;;0BAAA;;;;;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAAA;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qFiB9fJ/0F;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BjB8fI;;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,mB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sEwZ5cG25U;;4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BxZ4cH;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCuB3UN;;;;iCACa90V;gCACX;qCADWA,MADT8E;;;oCAGQ,qBAFC9E,G;;;;;;;;8CAEqB,QAFrBA;oCAED;;;;;;;;uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BvBwUN;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCAAA;;;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;oC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,2B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gDAAA;kD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA;;;yD;;;;;;;;;;;;;sFwZ5cG80V,M;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCxZ4cH;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDwZ5cGA,Q;;;2EAAAA;oC,kCAAAA,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kEAAAA;;;;;;;;;;;;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BxZ4cH;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;;;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDAAA;oD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCGqTF3lR;;;;;8BHrTE;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qDhQrDhBuD;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+E2YyCOoiR,yB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6CxZ4cH;wD;;;;;;;iFwZ5cGA,O;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yCxZ4cH;kD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uEwZ5cGA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2DxZ4cH;;;;;;;2D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yDAAA;;;;;;;yD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yDAAA,yB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2EwZ5cGA;oD;;;yEAAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB3IYS;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kErOqlCZ5kP,oBCjpCJ5nF;uD;;;;;;;;;;kEDipCI4nF,oBCjpCJ5nF;uD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBoO4DgB;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kC7QgcZ;;;;;;;;oC;;;;;;;;;;;;;;;;0BAAA,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uDarfJoqD;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0DAAAA;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDAAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kEAAAA;iD;;;;;;;;;;;;;;;;;;;;;;;;;;;gDbqfI,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2DarfJA;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yEAAAA;oC;;;;;;;;;2EAAAA;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sDAAAA;oC;;;;;;;;;;;;;;;;;;;;sBgQqDgB;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kC7QgcZ;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CwZ5cGoiR;;;;;uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BxZ4cH;uD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8DgBvfJ/gR,sB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BhBufI;;;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0DwZ5cG+gR,a;;;;;;;;;;0DAAAA;;;;;iE;;;sB3IYS;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6B7QgcZ;+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAAA;oG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wEgBxfJhhR,+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BhBwfI;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA;6B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAAA;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gD2IZTghR,uB;;;uEAAAA,K;;;wDjZ2fL7lR,gB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAAAA;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BP/CE;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yEwZ5cG6lR;;;;;;0D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCxZ4cH;;;;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;;kC;;;;;;;;;;;;4BAAA;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCarfJpiR;;0B;;;;;;;;;;;oE/M6BAL;;;qEAJAF;;6C;;;;;;;;;;;;;;;;;;;;;;;;;sB+c4BgB;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8B7QgcZ;;;;kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mDQ7dAjD,MD4gBFD,kC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BP/CE;;;;;mC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uCAAA;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kDAAA,uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iEQ7dAC,MD4gBFD;;;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0DP/CE;0D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6CAAA,qC;;;wDO+CFA;uC;;;;;;;;;;;;;;;uCP/CE;uC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qEQ7dAC,MD4gBFD;8C;;;;;;;;;;iEC5gBEC,MD4gBFD;2C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iEAAAA;wC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCP/CE;;yC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,gB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;uB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qC7P7DhB2E,K;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BhB6fI;;;0BiBzfO;4BAAqB,IAALpvE;4B,4BAAAA;;;0BAA2B,Y;;;;;;;;;;;;;;;;;;;;;sCR6K/CO,0BAAJ3C,WAAFD;kCAAc,sBAAdA,iBAAM4C;iDAAJ3C;;;4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BT4UC;;8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA,c;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;;;8B;;;;;;;;;;;;;;;;;4BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAAA,a;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;;;;;;mE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,mB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;;;2B;;;;;;;;;;;;;;;;;;;;;;;;uC/c1BhBgwE;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BkM0dI,mB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oDwZ5cG0iR;iC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BxZ4cH;uC;;;;;;;;;;;0BAAA;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAAA;qC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6ClMxdJziR;6C;;;;;;;;;;;;;;;;;;;+CAAAA,oB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BkMwdI,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4CAAA;qD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gCAAA;0C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+B7QgcZ,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAAA,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA;;;4C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;+BAAA,wB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAAA;;;sC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0BAAA,Y;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAAA;gC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sCAAA,a;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sB6QhcY;;;;;sB;;;;;;sBAAA;;;;0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0B7QgcZ;;4B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;qCAAA,Y;;;;;;;;;;;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BimB;0BAEf,sB;0BAAA,eAMGz+c;4BAAL,MAAKA,KACc,cADqBvD;4BACtC;mCADGuD,CAEA;0BANZ;;iDAGO,MA5CL8mO,4BAuCA7qI;2BAEF;;;2BAUQ,0BAXFojI,IR2uCY8lO,UAWAC;0BQ3uCV,eACsC3oc,GAAW,kBAZ3C2hc,MAY2C,UAAX3hc,GAAsB;0BAD5D;kCAANslO;2CACmBtlO,GAAa,4BAZvBgD,EAYUhD,GAAkB;wCAA8B;uBAnDrE,ORivCE8/a;uBQjvCF,yBRivCEA;uBQjvCF,SRivCEA;uBQjvCF,aRivCEA;uBQjvCF,MRivCEA;uBQjvCF,URivCEA;uBQjvCF,QRivCEA;uBQjvCF,YRivCEA;uBQjvCF,eRivCEA;uBQjvCF,YRivCEA;uBQjvCF,oBRivCEA;uBQjvCF,SRivCEA;uBQjvCF,YRivCEA;uBQjvCF,URivCEA;uBQjvCF,SRivCEA;uBQjvCF,aRivCEA;uBQjvCF,cRivCEA;uBQjvCF,gBRivCEA;uBQjvCF,YRivCEA;uBQjvCF,iBRivCEA;uBQjvCF,kBRivCEA;uBQjvCF,URivCEA;uBQjvCF,URivCEA;uBQjvCF,SRivCEA;uBQjvCF,gBRivCEA;uBQjvCF,SRivCEA;uBQjvCF,mBRivCEA;uBQjvCF,KRivCEA;uBQjvCF,aRivCEA;uBQjvCF,eRivCEA;uBQjvCF,oBRivCEA;uBQjvCF,mBRivCEA;uBQjvCF,wBRivCEA;uBQjvCF,wBRivCEA;uBQjvCF,gBRivCEA;uBQjvCF,gBRivCEA;uBQjvCF,oBRivCEA;uBQjvCF,yBRivCEA;uBQjvCF,YRivCEA;uBQjvCF,QRivCEA;uBQjvCF,mBRivCEA;uBQjvCF,wBRivCEA;uBQjvCF,0BRivCEA;uBQjvCF,YRivCEA;uBQjvCF,yBRivCEA;uBQjvCF,WRivCEA;uBQjvCF,cRivCEA;uBQjvCF,SRivCEA;uBQjvCF,aRivCEA;sBQjvCF,QRivCEA;sBoWhwCY;uB5Ved,eRivCEA;uBQjvCF;;;2BAmFmB;;;4BAGd,gCAHE4hC,UACAzpO;2BAEF,SAEEj1O,EAAEhD;6BACJ,IAAIwB,QRwpCPs+a;6BQvpCM,gCAD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AIC;0BAAmCC;;0BAA7C;;;;mEAAMF,UAANnvZ;;;;;yCAAUovZ,+BAAVnvZ;;gEAA6CovZ,aAA7CtvP,IAaqD;uBAbrD;;0BAAMwvP;0BAAIC;0BAAmCC;0BAA7Cvtc;;;;;;;4CAAMqtc,QAANrtc;;uCAAUstc,+BAAVttc;4CAA6Cutc,WAA7Cvtc,aAaqD;uBAbrD;;0BAAMytc,KAAIC,+BAAmCC,QAA7C3tc;0BASI;kDATEytc,KAANztc;2BAUI;uCAVM0tc,+BAAV1tc;2BAWI,wCAXyC2tc,QAA7C3tc;0BAWI;kCAFA4tc;kCACA19M;kCACAs3L,6BAEiD;uBAbrD;iCAiBSgf;;2BAGP9e;2BADAj3L;2BADAo4L;0BAQA;kCARAA;kCADO2d;kCAEP/1M;kCAOA,OANAi3L,2BqjBiJA6f;uBrjB5HA;;;;;;;4BgYxBQx2H;8B3Y5BI2uG;gCvCERxzJ,0BuQyPsBjmD,ezUnMvBg4M;;uBoHJH;uBAK+C;wC,UAL/C6vB;uBAK+C;iCgY7B/C1od;0B,qB3K+N0B8gP,cuFvKxB/5D;gD,O9VlFNggH;mCkb0BSrsH,iB,O3Y5BT8/Q;4CgO2P8Bh0M,c2K/NrB9rE,UAAL16K;uBhY6B+C;iCgY7B/C4a;0B,qB3K+N0BmmO,euFvKxB/5D;;4B,O9VlFNggH;mCkb0BSrsH;4B,O3Y5BT+/Q;;8CgO2P8Bj0M,e2K/NrB9rE,SAAL//J,UhY6B+C;;iCgY7B/CA;0B,qB3K+N0BomO,cuFvKxB/5D;;4B,O9VlFNggH;mCkb0BS9rJ;4B,O3Y5BTy/S;;8CgO2P8Bl0M,c2K/NrBvrG,MAALvgI,YhY6B+C;uBAL/C;uCAAK+tc;sB0VwBO;uB1VxBZ;iCAWJ3nd;0B;0BACE,sB,OlD9DFqmS;0BkD8DE;mCgY/BF9/C;mD,O3YjCA2zM;mCW+DAl6b;uBAXI;iCAWJhB;0B;uDlD7DAwnS;;mCkb+BAhgD;mD,O3YjCA6zM;mCW+DAr7b;uBAXI;iCAWJmwH;0B;mCgY9BAg3H;4ChY+BEh3H;qC,OXhEFqrU;uDWgEErrU;gD,OlD9DFw3K,2BkD8DEx3K;;;mCADFA;;uBAXI;;;;2BAqCkCmyU;2BAAjCj3L;0BAID;kCAJCA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gH;gD,OuCFAyzJ;;+CgO2P8B15M,cuFvKxB/5D;mCtTslBOkoS;4B,OxCxqBbloL;0BwCuqBM;2BAAO0zJ,6B+N9aiB35M,cuFvKxB/5D;2BtTqlBA,KaxoBFgoS;2BbwoBE,KaxoBFA;2BbiZE,KAuPAvzU;2BAvPA,KAuPAA;2BAvPA,KAuPAA;2BArbE,KA8LFH;2BA9LE,KA8LFA;2BA9LE,KA8LFA;2BAzYI,KA2MF8B;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME;;;;4DAgoBGs9S,kBAhoBHi1B;;;4DAgoBGj1B,kBAhoBH3uJ;;;;;;;;8BlFuHd7hH,kBkF0gBiBglS,yBAjoBHO;2B3DmKR,G2DnKQD;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR;;;;;;;2B2DwCM;;;;;;gCA3ME78N;gC3DmKR;2B2DwCM;0D0YnMJo5F,oB1YmMIwjI;2BA8LF;;;;8BA9LE;2BA8LF;2BAuPA;;;;8BAvPA;;;2CajZIX,+BbiZJQ;2BajZF;;;;8BbwoBE;;;2CaxoBmCP,+BbwoBnCM;2BaxoBF;mCxEkoCQU;4B,OvBngChB7nS;0BuBmgCM;;gCwEloCE+mS;2BxEkoCF,KwEloCEA;2BxEkoCF;mCAnCYe;;6BAoCUl3Z;;0DADZi3Z,kBACYl3Z;8DADZk3Z,kBACYj3Z;0BApCpB;gCAmCF+iF;2BAnCE,KAmCFA;2BACa4sM,KApCX/9N;2BAoCWsxB,KApCXtxB;2BAoCW6nI;2BApCX;;;;oDAoCWA;2BADb;;;;;2CAnCEF,OAzqBF3B,cAyqBYs/N,gBAAVhrU;2BwE/lCA;;;;8BxEkoCF;2BiE/+BF,KOnJIgqU;2BPmJJ,KOnJIA;2BPmJJ,MOnJIA;2BPmJJ,MOnJIA;2BPnBF,KAsKFqB;2BAtKE,KAsKFA;2BAtKE,KAsKFA;;2BAtKE;;;;;;gCyN6O4B1pO;;;mCzN1OrB7tL;;;;;;gCAHPsrF;;;2BAMMivG;;;2BANN;;;;;2CAMMA;2BAgKR;;;;;;gCAtKEq9N;;kCyN6O4B/rO;;;qCzNrOrB7rL;;;;;;kCARPw3Z;2BA0CA,IA4HFF;2BA5HE,GA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE,KA4HFA;2BA5HE;;;;;;gCyNmM4BzpO;;;mCzNhMrB7tL;;;;;;gCAHP0rF;;;;;;gCyNmM4BmiG;;;mCzN7LrB7tL;;;;;;gCANPo4Z;;;2BAQQK;;;2BARR;;;;;2CAQQA;2BARR;;;;;gCyNmM4B9tO;;;mCzNzLrB3qL;;;;;;gCAVPk4Z;;;2BAaMW;;;2BAbN;;;;;2CAaMA;2BAbN;;2BAeMG;;;2BAfN;;;;;2CAeMA;2BAfN;;2BAiBMG;;;2BAjBN;;;;;2CAiBMA;2BAjBN;;2BAmBMG;;;2BAnBN;;;;;2CAmBMA;2BAnBN;;2BAqBMI;;;2BArBN;;;;;2CAqBMA;2BArBN;;2BAuBMI;;;2BAqGR;;;;;;gCA5HEH;;6CAuBMG;2BAqGR;;;;;;mCOnJI3C;;;qCPmJJ6C;qCjEgiCI1oN;;;0CiE3hCItxM;;;;;;;uCALRo3Z,OOvHmD;uBA5B/C;;0BAAM8C;0BAA+BC;0BxEmoC3Bl4c;0BwEnoCV82C;;;;;;;4CkN0N0BqvL,euFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA0zJ;;+CgO2P8B35M,euFvKxB/5D;mCtTslBO+rS;4B,OxCxqBb/rL;0BwCuqBM;2BAAO2zJ,2B+N9aiB55M,euFvKxB/5D;2BtTqlBA,KaxoBF+nS;2BbwoBE,KaxoBFA;2BbiZE,KAuPAvzU;2BAvPA,KAuPAA;2BAvPA,KAuPAA;2BArbE,KA8LFH;2BA9LE,KA8LFA;2BA9LE,KA8LFA;2BAzYI,KA2MF8B;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,KA2MFA;2BA3ME,8B3D2nCIviI,IwEnoCV82C,ObQMsrF;6CAgoBG29S,gB3D2fC//a,I2D3nCJutC;6CAgoBGwyY,gB3D2fC//a,I2D3nCJ2tC;yD3D2nCI3tC,I2D3nCJ0tC;;4BlFuHd4hI,mBkF0gBiB6oS,uB3D0fCn4c,I2D3nCJkuC;2B3DmKR,G2DnKQyma;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,G2DnKQA;2B3DmKR,oBAw9BY30c,I2D3nCJ42C,O3DmKRkH;iDAw9BY99C,IAx9BZjF;iDAw9BYiF,IAx9BZwnC;iDAw9BYxnC,IAx9BZ4nC;iDAw9BY5nC,IAx9BZoqC;iDAw9BYpqC,IAx9BZmqC;iDAw9BYnqC,IAx9BZssC;iDAw9BYtsC,IAx9BZgtC;2B2DwCM2J,O0YnMJw6R,qBrcmnCUnxU,I2Dh7BN+sC;2BA8LFsB,wB3DkvBQruC,I2Dh7BN22C;2BA8LF,oB3DkvBQ32C,I2DlvBRquC;;uCajZI4pa,+BxEmoCIj4c,I2DlvBRouC;2B3DkvBQO;uCwEnoC2Bupa,+BxEmoC3Bl4c,I2D3fRmuC;;mC3D0fMiqa;4B,OvBngChBhrS;0BuBmgCM,oCwEloCE8mS,SxEkoCF,KwEloCEA;0BxEkoCF,SAnCYmE,cAoCAr4c;;6BAAU+9C;;mCADZq6Z,gBACEp4c,QAAU89C;mCADZs6Z,gBACEp4c,IAAUwnC;0BApCpB;gCAmCFs5F;2BAnCE,KAmCFA;2BACa4sM,KApCX/9N;2BAoCWsxB,KApCXtxB;2BAoCW7iE,uBAAD9sC,WAACihI;2BApCXp0F,uBAoCU7sC,IAAC8sC;2BADb+J,OA5sBA0hM,eAyqBY8/N,cAoCAr4c,IApCV6sC;2BwE/lCAD,uBxEmoCU5sC,IADZ62C;2BiE/+BF,KOnJIo9Z;2BPmJJ,KOnJIA;2BPmJJ,MOnJIA;2BPmJJ,MOnJIA;2BPnBF,KAsKFqB;2BAtKE,KAsKFA;2BAtKE,KAsKFA;2BAtKE5ma;;;gCyN6O4Bm9L;yCzN1OtB7rO;;mCAAC+9C;;yEAAD/9C,QAAC89C;yEAAD99C,IAACwnC;8BjEmpCKxnC;8BwEnoCV4sC;8BPnBFy8F;2BAMMqsU,KANNF;2BAMMhsU,KANNgsU;2BAMMzka,uCjEgpCM/wC,IiEtpCZ0uC,OAMM86F;2BANN/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A;6B2DrJQqc;6BADAG,O0FshBZ9+F,e1F4FIwzW,oBAlnBQK;mEACAl1Q;6BAFA;mEACAE;6BAFA;mEACAE;6BAFA;mEACAE;6BAFA;mEACAE;6BADA;6BAmNF+/C,sCAKAF;6BA4LFK,UAjMEH;6BAiMF+xC,sCAQAvxC;6BAgPAwxC,UAxPAD;6BAwPAI,sCAUAF;6BapoBNC,Ub0nBMC;6Ba1nBNS,sCAYAH;sCAZAG;mCAyIJvoL;4B,UAAA1lH;qCb2dM4ie,2BalmBEp2W;8B,OrDrERw3K,2BqDqEQx3K;;;;;;6Bb9BE6yI,OAgoBJujO,2Ba3dND;6BbrKUrjO;;oCAgoBJsjO,2BAhoBIrjO;6B3DmKRE;;gCqJoXAt7I;gC1FyGIy+W;gCAhoBIpjO;;;6B3DmKRhzI;;;;;;;6BwE/HMwyI,+BxE+HND;;6B2DwCM8jO;;gC0Y9LR1+O;yC7XuBQ33H;kC,Od7ERqrU;oDc6EQrrU;6C,OrD3ERw3K,2BqD2EQx3K;;;;;6BbqWFkzI,wBA9LEmjO;6BarCJjjO,wBbmOEF;;6BalOAC,+BADFC;6BAKAkjO;qDHrJJzd,eGiJM1lN;;6BAKAojO,iCADFD;6BAEEE;;;;gCADAD;;;2CACAv2W;8B;uC6XhKN23H;gD7XgKM33H;yC,OdtNNqrU;2DcsNMrrU;oD,OrDpNNw3K,2BqDoNMx3K;;;;;;6BArJNy2W;;qEAqJMD;mCARNhje;qCxEq9BEkje,oBwEllC8B12W;8B,OA/EhC89H,gCA+EgC99H;;qCxE+iC5B22W,kBAoCoB32W;;;;qCADtB02W,oBACsB12W;qCADtB02W,oBACsB7uT;;;;6BAATp/F;;oDwEnmCfguZ,OxEmmCer6N;6BApCXzJ,uBAoCWD;6BADbD,MA5sBAR,eAyqBE0kO;6BwE/jCJ/jO,wBxEkmCEH;mCwEr9BFj/P;;;6BPhME6/P;;gCoYmBFrc;yCpYhBSh3H;;;;;;;gCOgDT4yI;;;6BP7CQhqL;;+DANNyqL,OAMMujO;6BANNrjO,kCAMMD;;6BAgKRE;;gCyN4KE1e;yCzN1UO90H;;;;;;;gCARPuzI;;;;6BA0CAE;;gCoYvBFzc;yCpY0BSh3H;;;;;;;gCAyHTwzI;;;6BA5HEkvC;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/5D;;4B,O9VlFNggH;;4B,OuCFA0zJ;;;;8B4QoIAzjL;;gC,O+HnFI80E;4C/HmFJ90E;;4B,OjQzHE+wM;;;4CqNgP4BjnO,enO9LrBpmE;;iCiB5BLi4S;;qC,Ob4UE9wB;;mCapCFlnb;;qCAkB+C;;iCAD7CA;0B,qBkN/FwBomO,cuFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA2zJ;;;;8B4QoIA1jL;;gC,O+HnFI80E;4C/HmFJ90E;;4B,OjQzHEkxM;;4CqNgP4BpnO,crNvM1B4nO;;iCGnBAsK;;qC,Ob4UEjxB;;mCanBArnb;;;uBAC6C;iCAlB/CA;0B,qBkN9E0BomO,cuFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA2zJ;;;;8B4QoIA1jL;;gC,O+HnFI80E;4C/HmFJ90E;;4B,OjQzHEkxM;;4CqNgP4BpnO,crNvM1B4nO;;iCGnBAyK;;qC,Ob4UEpxB;;mCapCFrnb;2CAkB+C;uBAlB/C;uCAAKuxd;sBuV7PO;uBvV6PZ;;;;;;;;;;;;gCAuCWe;uBAvCX;;yBAAKf;yBAALC;;;;mD;uBAAA;;;;;;;;uBAmCF;;sBuVhSc;uBvVgSd;;;;;;;;;;;4C;;wBjB1RUp1C;0B8YjCAnrG;4B3YjDIyuG;8BvCERxzJ,0BuQyPsBjmD,ezUnMvBg4M;uBuHoTL;6BjB1RU7B;;;2B,OcvE0C0wB,gB5FqJ1Dx8R;;6B8EnGgB2rQ,gBcTH8xB;;;wC,OVyTiCjnB;uBaiCtC;;;;;;;4C,OA7WoE+sB;;uBA6WpE;uBAmB+C;wC,UAnB/Cqf;uBAmB+C;iCAnB/C9te;0B,qBkNnJ0B8gP,cuFvKxB/5D;gD,O9VlFNggH;gD,OuCFAyzJ;gD,O2YiDI1uG;gD,O9YiCAmrG;;gD,OAAAA;;4B,OcvEF2wB;yCdkDE5nd;4B,kBmO8L0B8gP,cnO9LrBpmE,UAAL16K;;iCiB5BA0ud;mD,Ob4UE/sB;;mCaiCF3hc;uBAmB+C;iCAnB/C4a;0B,qBkNnJ0BmmO,euFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA0zJ;;4B,O2YiDI3uG;;4B,O9YiCAmrG;;;4B,OAAAA;;4B,OcvEF8wB;;yCdkDEptc;4B;gDmO8L0BmmO,enO9LrBpmE,SAAL//J;;iCiB5BAg4c;;qC,Ob4UE9wB;;mCaiCFlnb;;qCAmB+C;;iCAD7CA;0B,qBkNrKwBomO,cuFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA2zJ;;4B,O2YiDI5uG;;4B,O9YiCAmrG;;;4B,OAAAA;;4B,OcvEFixB;;4B,OdkDEtxB,ccTA8xB;;iCGnBAsK;;qC,Ob4UEjxB;;mCamDArnb;;;uBAC6C;iCAnB/CA;0B,qBkNnJ0BomO,cuFvKxB/5D;;4B,O9VlFNggH;;4B,OuCFA2zJ;;4B,O2YiDI5uG;;4B,O9YiCAmrG;;;4B,OAAAA;;4B,OcvEFixB;;4B,OdkDEtxB,ccTA8xB;;iCGnBAyK;;qC,Ob4UEpxB;;mCaiCFrnb;2CAmB+C;uBAnB/C;uCAAKmzd;sBuVlUO;uBvVkUZ;;;;;;;;;;;;;gCAwCWe;uBAxCX;;yBAAKf;yBAALC;;;;mD;uBAAA;;;;;;;;uBAoCF;;sBuVtWc;uBvVsWd;;;;;;;;;;sBAoBH;;sB1G9bGt0V;sBI4HFsV;sB6bxDgB;;;;;;;;;;;;;;;;;;;;;;;;;;;sB7buDhBD;sBJ5HEtV;sBsqBVN;;sBrO+EoB;uBqO/EpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sBAEkD;;sBtqBS5CC;sBI4HFsV;sBADAD;sBJ5HEtV;sB2GVN;;sBAiBM;;;;;;;;;;;;;;;;sBsV8Dc;uBtV3DR;iCAM+B8+H;0BACzB,IAAZ4wM,UAAY,sCADyB5wM;0BAGzB;uEAFZ4wM,WAEwC;uBATlC;;;;;;;;;;;;;;;;;;uBAgBC;uBAII,uBAhCbr7H,uBdu0CIyvF;uBcvyCS;;;;yBAhCbzvF;;;uBAgCa;wC,aduyCTyvF;uBcvyCS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2BA8BTjsX;2BA5CJ29a;uBAca;;;;;;;;;;;;;;0B;;sCduyCT1xD;;;;mCcv0CJzvF,uBA6E6B;sBsVNb;;;uBtV+BJ,kBrDqEVrlD,cAtGA0kD;uBqDiCU;kCdiuCRowF;uBcjuCQ,OdiuCRA;uBcjuCQ,KdiuCRA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;;qCukB3PXqa;;;;;;;;oC9oBmCMjD;oC2gBzFSyV;mC3gBqHXlxK;;mCuEtFJxsE;;qC;;;;;;;;;;;;;;kCvE/DE2xO;kCAEAlvT;;;;;;kCA+PAs/T;kCASAE;uBAxTN;;2B;;;;;;;uBAAA;;;sBAykF6C;;sBnCjkFvChlX;sBI4HFsV;sBADAD;sBJ5HEtV;sB2rBTN;;sB1P8EoB;uB0P9EhBioX;;;2BAIK;;;;;8CjDkIPzyE;;4BiDlIYz7Q,eAALxuB;+CAC6CpqI;6BjDiIpD,sCiDjIoDouI;oCAD7CorB;;;8BjDmIH,qBiDnIGx5J;8BjDoIH,4BiDpIGA;8BjD0GO,qBiD1GPA;8BjD0Ge,qBiD1GfA;8BjD0Ge,sBAAR24O,IAAQsuQ;8BA4BlB,2BiDtIGjnf;8BjD8HO,qBiD9HPA;8BjD8He,qBiD9HfA;8BjD8He,UAARonf,IAAQC;;qCAKlBN;qCACAC;qCACAE;qCACAC;qCACAG,OiDrIkC;+BAF/B7tV;;6BjDkIP;;iCiDlIOr0K;8BjDkIP,GiDlIOA;8BjDkIP,GiDlIOA;8BjDkIP,KiDlIOA;8BjDkIP,KiDlIOA;8BjDkIP;;8BAxBA,GAwBAy4N;8BAxBA,GAwBAA;8BAxBA;8BAwBA;;;;iCAxBA;8BAwBA;8BAJA,KAIAm5B;8BAJA,KAIAA;8BAJA;;;sCAIAI;sCAJA;oCiD9HOh+E;;;8BjDkIP,GiDlIOh0K;8BjDkIP,GiDlIOA;8BjDkIP,GiDlIOA;8BjDkIP,KiDlIOA;8BjDkIP,KiDlIOA;8BjDkIP,uBiDlIO4a,UjDkIP8gI;qDiDlIO9gI,IjDkIPoqC;8BAxBA,GAwBAyzK;8BAxBA,GAwBAA;8BAxBA,qBiD1GO79M,IjD0GPmqC;qDiD1GOnqC,IjD0GPjF;8BAwBA,uBiDlIOiF,IjDkIPwnC;8BAJA,KAIAwvM;8BAJA,KAIAA;8BAJA,uBiD9HOh3O,IjD8HPssC;qDiD9HOtsC,IjD8HP4nC,WiD5HsC;;4BAF/ByxH;qCAAKT,YAALS;;;;;;;qCAAKT;qCAALS;;;0CAE+B;sBAGi0B;;sB3rBCn2Bv6B;sBI4HFsV;sBADAD;sBJ5HEtV;sB4rBVN;;sBAAS,wBnDcLqoE;sBm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sDlrS;4BAE1C,iDACN;uBAHV;uBAeM;;;;;;;4C,OylBnBsBswgB,8BhT+LnBxlV;;uBzS5KH;uBAA8D;wC,UAA9DqmV;;uCAAKC;sB6UgDO;uB7UhDkD;uBAA9D;;;;;;;;4C,OylBnBF7uN;8BhT+LKz3H;;uBzS5KH;uBAA8D;wC,UAA9DymV;;;;;;;;;yCzGoIRlmV,2ByGpIammV;;uBAAL;uBAA8D;wC,UAA9DC;uBAA8D,mBAA9DlugB,iBAA8D;;iCAA9D4Z;;mDsD0EA6rK,ctD1EA7rK;6BylBnBFwzf,erjBmBEtH,oBpCAAlsf;;;0BAA8D,OAA9D5Z,CAA8D;;iCAA9D4Z;;;;;;;0BAA8D,OAA9D5Z,CAA8D;0CAA9DqugB;uBAA8D;iCAA9DrugB;;;;;mEsD0EAulL,ctD1EA7tH;;mDylBnBF61c,crjBkBA3H,mBpCCEjuc,IAA8D;;iCAA9D/9C;;;;;0CsD0EA4rK,etD1EA5rK;iCylBnBF4zf,erjBkBA3H,oBpCCEjsf,WAA8D;0CAA9D40f;uBAA8D,YAA9DL;uBAA8D;uBAchE;;;;;;;4C,OylBjCwBpB,8BhT+LnBxlV;;uBzS9JL;uBAuBG,mB,UAvBHqnV;uBAuBG;iCAtBDn/b;0BylBlCF;8BzlBkCEA;2BylBlCF,GzlBkCEA;2BylBlCF,wCrjBkBAm2b,cqjBlBAluc;;uBzlBwDG;iCylBxDH99C,UzlBkCE61D;0BylBlCF;8BzlBkCEA;2BylBlCF,GzlBkCEA;2BylBlCF,erjBkBAo2b,eqjBlBAjsf;4DzlBmCmC;uBAqBhC,mBwC4IIi1f;uBxC5IJ;iCAtB6Cj1f,IylBlChDouI,QzlBkCgDmrB;0BylBlChD;uBzlBwDG;iCylBxDHv5J;0BAEI;0CrjBiBFksf,eqjBnBFlsf;2BAEgB,yBAFhBA;0BAEgB,UAAZyzf,IAAYC,SzlBiCmB;uBAqBhC,mBwC4II2B,MAqCPD;uBxCjLG,YwCuJElyN,GxC9KLiyN,gBACEG;uBAsBC;;iCAtBD17V;0BylBhCM,GzlBgCNA,gBylBhCM;0BzlBgCK,qB6DmlCTyyV,S7DnlCFzyV;sEAA8D;uBAsB7D;iCAtBDmD;0BylBhCM,GzlBgCNA,gByl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8P;uBAGqD;;0BAHrD;;;6BP/KA,GO+KAz0b;6BP/KA,GO+KAA;;6BP/KA;;;;;0BO+KA,kBHlLF,KGkLEG;;gDHlLF,0CGqLuD;;iCAHrDjhI;;;;;6BP/KA,GO+KA8gI;6BP/KA,GO+KAA;6BPtJF;6BAzBE,aO+KA9gI,IPtJFoqC,MAzBE0T;oDO+KA99C,IP/KAjF;0BO+KA;;;2BHlLF,KGkLEkmI;2BHlLF,yBGkLEjhI,IHlLFmqC;0CGkLEnqC,IHlLFwnC,WGqLuD;;iCAHrDxnC;;;4BPtJF;;6BArBM,oBO2KJA;6BP3K+B,0BO2K/BA;6BP3K+B,SAA3B41jB,cAA2BC;sCO2K/Bn5Z;;4BHlLF,4BGkLE18J;4BHlLF;6BACsB;mDGiLpBA;yCHjLoB81jB;;iCGiLpBh9W,QHlLF,uBGkLE1qE;;mEAGqD;;iCAHrDjoC;;;;;;;;;;;;4B8BmVE,c9BnVF;;;;;;;;;;;;;;;;;;;;kCHlLF,SGkLE3gH;;;;;;;2DHlLF,2BGkLEA;;;;;;;;;;;;;0CHlLF;;;;;;;;;;;;;;;;;;;;;uDACsB;mFADtBgxQ;;;;0EACsBp1E,aADtBv+L;;8DACsBu+L,aADtB,sCGkLE57L;yDHjLoB;;sDADtB;;;;;8CGkLEmyD;+CHlLF,mDGkLEnyD;;6CHlLF;kDGkLEmyD,KHlLF,0CGkLEnyD;;+CHlLF,UACsBwwkB;+CADtB;gFGkLEr+gB,QHjLoBs+gB;;;iDGiLpBt+gB;kDHlLF;;oDGkLEnyD;gEHjLoBwwkB;;;2CGiLpBr+gB,KHlLF,mCGkLEnyD;;8CHlLF,kCGkLEA;uDHlLF,2BGkLEA;;;;;;;gCP/KA,SO+KAo9I;0CP/KA,oCO+KAA;;kCP/KA;+CO+KAA;mCP/KA;;;;;;;;;;;;;;;;;;;;;;;;;iGO+KAA,KP1KsD;yDALtDZ;;;;;;gDAII;0EAJJF;;kDAII;;;;;+CAA2B;yEAJ/BA;;iDAI+B;;;;8CAJ/B;;;;;sCO+KAe;uCP/KA,iDO+KAD;;qCP/KA;0CO+KAC,KP/KA,wCO+KAD;;uCP/KA;8CAIIszb;wCAJJ,MAI+BC;;;;;yCAA3BE;yCO2KJxzb,QP3KIwzb,kBAA2BD;;;;;yCO2K/Bvzb;0CP/KA;;4CO+KAD;;sDP3KIszb;yDAA2BC;;0CO2K/Btzb;;iEAGqD;;;0BAHrD;4BACE;;6BPhLF,SOgLED;6BPhLF,cOgLEA;6BP5K6B;;6BAA3B;iEAA2BK;6BAA3B;kDO4KFz9I;0BACA;;2BHpLJ,eGoLIq9I;2BHnLkB;;;gDGmLlBlrF,SACmD;;iCAHrDylH;0B,SAAAr0K;4BACE;gCADFA;6BACE,iCADFq0K;;6BP/KA7nD,eawOA0gZ,eb/MFvuQ,MOuJIxY;oDPhLF35H,IOgLE25H;0BACA,SAFFnmP,OAEE,iCAFFq0K;4CMyDA64V,eT1OAtuQ,MGmLEk+E;uBAFF;uCAAK2vP;sB2S7GS;uB3SwHd;;;;;;;;;0CPvJGrd;6CI5BA2N;;uBGmLH;uBAMqD;wC,UANrD2Q;uBAMqD;;0BANrD;;;6BP/KA,GO+KA31b;6BP/KA,GO+KAA;6BP/KA,GO+KAA;6BP/KA,GO+KAA;;6BP/KA;;;sE6lBPFg0a,c7lBOEj3V;;;;;0BO+KA;;2BHnLF,KGmLE58E;2BHnLF,KGmLEA;2BHnLF;;;;kFGyLuD;;iCANrDjhI;;;;;6BP/KA,GO+KA8gI;6BP/KA,GO+KAA;6BP/KA,GO+KAA;6BP/KA,GO+KAA;6BPvJF;6BAxBE,aO+KA9gI,IPvJFgtC,MAxBE8Q;4CO+KA99C,IP/KAjF;8C6lBPFg6iB,etlBsLE/0iB,IP/KAwnC;oDO+KAxnC,IP/KA4nC;0BO+KA;;;2BHnLF,KGmLEq5F;2BHnLF,KGmLEA;2BHnLF,yBGmLEjhI,IHnLF+sC;0CGmLE/sC,IHnLFoqC;0CGmLEpqC,IHnLFmqC,WGyLuD;;iCANrDnqC;;;4BPvJF;;6BAvBM,kBO8KJA;6BP7KI,oBO6KJA;6BP5KI,sB6lBVNg1iB,etlBsLEh1iB;6BP3KI,0BO2KJA;6BP3KI,SAHA82jB,YACAlB,cACAmB,WACAlB;sCO2KJn5Z;;4BHnLF,4BGmLE18J;4BHnLF;6BAEQ;gDGiLNA;8BHhLM,qBGgLNA;yCHjLMg3jB,YACAlB;;iCGgLNh9W,QHnLF,uBGmLE1qE;;mEAMqD;;iCANrDjoC;;;;;;;;;;;;4B8BwUE,c9BxUF;;;;;;;;;;;;;;;;;;;;kCHnLF,SGmLE3gH;;;;;;;2DHnLF,2BGmLEA;;;;;;;;;;;;;0CHnLF;;;;;;;;;;;;;;;;;;;;;;;;;;;yGGmLEA,GH9K6C;iEAL/Cw8I;;;;;;wDAGQ;oFAHRw0H;;0DAGQ;;;;;uDADA;mFAFRA;;yDAEQ;;;;sDAFR;;;;;8CGmLE7+M;+CHnLF,mDGmLEnyD;;6CHnLF;kDGmLEmyD,KHnLF,0CGmLEnyD;;+CHnLF;sDAEQ0xkB;gDAFR,MAGQlB;;;;;iDADAmB;iDGiLNx/gB,QHjLMw/gB,gBACAlB;;;;;iDGgLNt+gB;kDHnLF;;oDGmLEnyD;;8DHjLM0xkB;iEACAlB;;;2CGgLNr+gB,KHnLF,mCGmLEnyD;;8CHnLF,kCGmLEA;uDHnLF,2BGmLEA;;;;;;;gCP/KA,SO+KAo9I;0CP/KA,oCO+KAA;;kCP/KA;+CO+KAA;mCP/KA;;;;;;;;;;;;;;;;;;;;;;;;;;;iGO+KAA,KPzKsD;yDANtDZ;;;;;;;;kDAGI;4EAHJF;;oDAGI;;uE6lBVNmza,c7lBUMh0X;;;iDAFA;2EADJn/C;;mDACI;;;;;gDACA;0EAFJA;;kDAEI;;;;;+CAEA;yEAJJA;;iDAII;;;;8CAJJ;;;;;sCO+KAe;uCP/KA,iDO+KAD;;qCP/KA;0CO+KAC,KP/KA,wCO+KAD;;uCP/KA;8CACIw0b;wCADJ,MAEIlB;wCAFJ,MAGImB;wCAHJ,MAIIlB;;;;;yCADAmB;yCADAjB;yCADAkB;yCO8KJ10b;;2CP9KI00b;2CACAlB;2CACAiB;2CACAlB;;;;;yCO2KJvzb;0CP/KA;;4CO+KAD;;sDP9KIw0b;;uDACAlB;;wDACAmB;2DACAlB;;0CO2KJtzb;;iEAMqD;;;0BANrD;4BACE;;6BPhLF,SOgLED;6BPhLF,WOgLEA;6BPhLF,cOgLEA;6BPhLF,YOgLEA;6BP5KE;;6BADA,iB6lBVNsya,c7lBUM6hB;iEACA9zb;6BAFA;iEACAC;6BAFA;iEACA4G;6BADA;kDO+KFtkJ;0BACA;;2BHrLJ,eGqLIq9I;2BHrLJ,YGqLIA;2BHlLI;;2BADA;+DACA8Z;2BADA;gDGmLJhlG,SAImD;;iCANrDiwM;0B,SAAA7+P;4BACE;gCADFA;6BACE,iCADF6+P;;6BP/KAryI,ea6NA0gZ,ebrMFpuQ,MOwJI3Y;6BPhLF9xE,iBa6NA64V,eb7NA1gZ,IOgLE25H;6BPhLFwY,iB6lBPF0tT,e7lBOEh4Y,MOgLE8xE;oDPhLFwY,MOgLExY;0BACA;gCAFFnmP;2BAEE,iCAFF6+P;2BHlLAD,iBSgOAsuQ,eThOAnuQ,MGoLE+9E;4CM4CFowL,eThOAtuQ,MGoLEk+E;uBAFF;uCAAK6wP;sB2SxHS;uB3SwHd;;;;;;;;;0CPvJFle;6CI5BA2N;;uBGmLE;uBAMqD;wC,UANrDwR;;;;;;;;;yC3IpCNzpZ,2B2IoCW0pZ;;uBAAL;uBAMqD;wC,UANrDC;uBAMqD,oBANrDzxkB,iBAMqD;;iCA2CrD6xkB;;4BAIsB;2DAJtBC;6BAII,gCAJJD;4BAII,oBAJJ/zW,SAKsD;uBAhDD;iCA2CrD+zW;;4B;8BAAA;;;;;;;;qCAIIj4b,KAJJC;qCAIIp9I;qCAJJ,kCAIIA,GAJJ43I;0CAIIuF;qCAJJr4H;;;mCAIsBm6O,KAJtB7hH;mCAIsBx8C;mCAJtB,qCAIsBA;mCAJtBw8C,KAIsB6hH;mCAJtBn6O;;;;;;gGAKsD;4BALtD,YAKsD;;uBALtD;;;;;;;;;;iCAAsBwtjB;0B,UAAtBiD,mBAAsBjD,mBAKgC;uBALtD;iCAAMoD,eAASC;0BAAf;;;mEAAMD,eAANz6gB;;8DAAe06gB,aAAfz6gB,IAKsD;uBALtD;iCAAM26gB,aAASC,WAAf34jB;;;;4CAAM04jB,aAAN14jB;4CAAe24jB,WAAf34jB,aAKsD;uBALtD;iCAAM64jB,UAASC,QAAf94jB;0BAII;+CAJE64jB,UAAN74jB;2BAIsB,kBAJP84jB,QAAf94jB;0BAIsB,UAAlB+4jB,SAAkBC,OACgC;uBALtD;;;;;;;;;;;;;;;;;;;;;oC8BuRE;sC9BvRF;;;;;;;;;8FAKsD;iDALtDh3b;;;;;;wCAII;kEAJJF;;0CAII;;6DAJJ+2b,UAII53Y;;;uCAAkB;iEAJtBn/C;;yCAIsB;;8DAJtBg3b,QAIsB53Y;;sCAJtB;;;;;;;;sCAIIg4Y,gBAJJ,MAIsBC;;sDAAlBE;qDAAkBD;4BAJtB;;;;+CAIIF;kDAAkBC,8BACgC;uBALtD;;;;;2BAIsB,eAJtBL,QAIsBE;;2BAAlB,iBAJJH,UAIIE;+DAAkB91b;0BAAlB,iBACkD;uBALtD;;0B,IAAAm6B;;;;0BAIa,GAJb8oF,gBAIa;2CAJbyzU;0BAIa,eAAgB,WAJ7BC,4BAIal0kB,CAAO;;uBAJpB;;;;;;;;;;uBAAsBo0kB;uBAAtB;;;;;;;;;;;uC3IrFN5rZ;;;;yC2IqF4BvuD;mC,UAAtBk6c,mBAAsBC;;;;uBAAtB,qCAKsD;uBALtD;;;oCAII3E,UAAkBx1c,QACgC;uBALtD;;;oCAIIw1c,OAAkBx1c,KACgC;uBALtD;uBAkBF;;;;;;;;+B,OAlBwB04c,gBA7KjB5F;8BAiHA+C;;uBA8EP;uBAC+C;wC,UAD/C2E;uBAC+C;iCAD/C/0kB;0B,OAlBEkzkB,cA7KA5F,cAiHA+C,cA8EFrwkB;uBAC+C;iCAD/C4a;0B,OAlBEy4jB;mCA7KA9F,eAiHA+C,eA8EF11jB,UAC+C;;iCAD/CA;0B,OAlBE44jB;mCA7KA9F,eAiHA6C,eA8EF31jB,YAC+C;;iCAD/C5Z;0B,OAlBE6ykB,cA7KA3F,cAiHAyC,cA8EF3vkB;uBAC+C;iCAD/ChB;0B,OAlBEk0kB,cA7KArF,cAiHAqC,cA8EFlxkB;uBAC+C;iCAD/CmwH;0B,OAlBEgkd;mCA7KArF,eAiHAqC,eA8EFhhd;;uCAAK6kd;sB2S3LW;uB3S2LhB;uBASA;;;;;;;;+B,OA3BwB/B,gBA9JjBhE;8BA6GAqC;;uBA4EP;uBAC+C;wC,UAD/CkE;uBAC+C;iCAD/Cx1kB;0B,OA3BEkzkB,cA9JAhE,cA6GAqC,cA4EFvxkB;uBAC+C;iCAD/C4a;0B,OA3BEy4jB;mCA9JAlE,eA6GAqC,eA4EF52jB,UAC+C;;iCAD/CA;0B,OA3BE44jB;mCA9JApE,eA6GAqC,eA4EF72jB,YAC+C;;iCAD/C5Z;0B,OA3BE6ykB,cA9JAvE,cA6GAuC,cA4EF7wkB;uBAC+C;iCAD/ChB;0B,OA3BEk0kB,cA9JAzE,cA6GA2C,cA4EFpykB;uBAC+C;iCAD/CmwH;0B,OA3BEgkd;mCA9JAzE,eA6GA2C,eA4EFlid;;uCAAKsld;sB2SpMW;uB3SoMhB;;;;;;;;qCA3BEl7c;+B,UAAAo6c;8BAjDAjC;;uBA4EF;uBAC+C;wC,UAD/CuD;;;;;;;;;yC3IhHJntZ,2B2IgHSotZ;;uBAAL;uBAC+C;wC,UAD/CC;uBAC+C,oBAD/Cn1kB,iBAC+C;;iCA7E7C4Z;0BA4EF;qDoB1KI6rK,cpB8FF7rK;2BAiDA,0BoB/IE6rK,cpB8FF7rK;2BA7GA,0BoBeE6rK,cpB8FF7rK;2BA7GA;;;;2BA/BE,0BoB8CA6rK,cpB8FF7rK;2BA3IM,uBA2INA;2BA1IM,eA0INA;2BAzIM,kBAyINA;2BAxIM,yBAwINA;2BAvIM,+BAuINA;2BAtIM,wBAsINA;2BAtIM;;6BALA+yjB;6BACA0B;6BACAzB;6BACAC;6BACAC;6BACAC;0BANJ;;0BA+BF;;0BAyLF;2BA5EE,0BoB9FEtnZ,cpB8FF7rK;;;4BPvJF;uD2ByDI6rK,cpB8FF7rK;6BPvJF;6BAxBE,wB2BiFE6rK,cpB8FF7rK;6BP9KI,eO8KJA;6BP7KI,iBO6KJA;6BP5KI,cO4KJA;6BP3KI,0BO2KJA;6BP3KI,SAHA82jB,YACAlB,cACAmB,WACAlB;4BAJJ;;4BAwBF;;gCOuJEvud;;;6BHnLF;wDuBqFIukE,cpB8FF7rK;8BHnLF,wBGmLEA;6BHnLF;8BAEQ;8CGiLNA;+BHhLM,kBGgLNA;+BHnLF5Z,KAEQ4wkB,YACAlB;;kCAHR1vkB,yBGmLEgoJ;6BHnLF;;iCGmLE9mC,OHnLFlhH;;gCGmLEkhH;;;0BA4EF,WAvBMyxd,SArDJzxd;0BAiDA;;0BA2BF;;0BAC+C,OAD/CuH,GAC+C;;iCAD/CzoH;;;;;;+DoB1KIulL,cpB0KJw1R;2BA3BE,mBA2BFoV;2BA3BE;;;+DoB/IE5qS,cpB+IFu1R;;;2BA9JA,mBA8JAl3T;2BA9JA;;;+DoBeE2hC,cpBfF/qC;;;;;2BA/BE,mBA+BF0zU;2BA/BE;;;+DoB8CA3oS,cpB9CAlrC;;;;;;;;;;;;2BA6LF;;;;;;gCA9JAm3G;;;kCA/BED;;2BA4IF,mBAiDA+9N;2BAjDA;;;+DoB9FE/pS,cpB8FFliC;;;;4BPvJF,kBOuJEJ;4BPvJF;;;gE2ByDIsiC,c3BzDJ7qC;;4BAxBE,gBAwBFmwJ;4BAxBE;;;gE2BiFEtlH,c3BjFFh8D;;;;;;;;;;;;;;iCAwBFwnI;;;mCAxBED;;;2BO+KA;;4BHnLF,mBGmLE1tG;4BHnLF;;;gEuBqFImiC,cvBrFJvpC;;;;;;;;;;;;mCG+PA41G;;;qCA3BED;;gFAjDAF,iBA6E6C;;iCA7E7C73O,IA4EFyyC;;;;;6CoB1KIm5H,epB8FF5rK,IA4EFyyC;2BA3BE,mBA2BF8ja;2BA3BE;;6CoB/IE3qS,epB8FF5rK,IA4EF+wC,OA3BEmwZ;;;2BA9JA,mBA8JAl3T;2BA9JA;;6CoBeE4hC,epB8FF5rK,IA7GA0uC;;;;;2BA/BE,mBA+BF4la;2BA/BE;;6CoB8CA1oS,epB8FF5rK,IA7GAquC,OA/BEoyF;;;;;;;kDA4IFzgI,IA5IEkuC;sCA4IFluC,IA5IE8sC;sCA4IF9sC,IA5IE6sC;mDA4IF7sC,IA5IE4sC;mDA4IF5sC,IA5IEutC;mDA4IFvtC,IA5IE2tC;2BA4IF,mBAiDA+na;2BAjDA;;6CoB9FE9pS,epB8FF5rK,IAiDA0tC,OAjDA+7F;;;;;6BPvJF,kBOuJEJ;6BPvJF;;8C2ByDIuiC,epB8FF5rK,IPvJFouC;;6BAxBE,gBAwBF6iP;6BAxBE;;8C2BiFErlH,epB8FF5rK,IPvJFmqC,MAxBEwlE;;;;;sCO+KA3vG,IP/KAoqC;wCO+KApqC,IP/KAjF;wCO+KAiF,IP/KAwnC;oDO+KAxnC,IP/KA4nC;0BO2PF;2BA5EE;;2BHnLF,mBGmLE4hG;2BHnLF;;4CuBqFIoiC,epB8FF5rK,IHnLFmuC;;;oDGmLEnuC,IHnLF+sC;sCGmLE/sC,IHnLFssC;sCGmLEtsC,IHnLFgtC,WGgQ+C;;iCAOvCwqe,IAAK66C,aAAcP,MAAOM,YAAa1kjB,KAAMiyG;0BAM/C;qCANE63Z,IAAK66C,aAAcP,MAMrB,QAN4BM,mBAAa1kjB;kCAAMiyG,KAUtD;uBAjBgD,eAmB1Cv5H,GAAS,OAATA,OAAqB;uBAnBqB;iCAyBpCA;0BAAS,kBmlBpOtB8ljB,UnlBoOa9ljB,QuQ6mBT2vjB,evQ7mB0E;uBAzB7B,iBA2BxC3vjB,GAAS,OAATA,OAAuB;uBA3BiB,qBA6BlCA,GAAS,OAATA,OAA6B;uBA7BK,gBA+BzCA,GAAS,OAATA,OAAsB;uBA/BmB;iCAqCrCA;0BAAS,UAATA;0BApFV;gCACUm7V;8CmlB7JZ2qN,UnlB6JY3qN,WuQorBRw0N;0BvQjmBiB,IAhFf,mBHvMO,aGsMQymB;0BHtMR,kBslBuCbtwB,UtlBtCiBuwB,a0Qu3Bb1mB,evQjmBqC;uBArCQ;iCA2CvC3vjB;0BACV,UADUA;0BACV;4BAEI,IADMm7V,iBACN,UADMA;0BAGN,QAAI;uBAhDyC,SPxN/Cm3N;uBOwN+C;;iCA4ExCyc;0BAEsB;sDAFtBA;2BAEP;4CAAiB;0BAAjB,eAGMx1c,MACR,UANSw1c,OAKDx1c,KACa;0BAhJnB;4BAGK,mBAAsC,IAAL1gI,WAAK,UAALA;4BAAf,IAAL0a;4BAAK,UAALA,EAA4C;0BP9IhE,eACSgjkB;2CACDrpY,QACR,UAFSqpY,YACDrpY,OACoB;4BADX,yCOwITopY;4BPxIS;0BAFjB;uEagQE12a;;;;;;uClJ5TE20B;gC,sBAFM0rY,cAEN1rY;;;;;;;;2CADAE;oC,sBADE+hZ,cACF/hZ;;;2E4IwViB;oDAnPjBy6Y;sBAmQyC;sBtJ3WzCx2b;sBADAD;sBkvBNN;sBAyQG;sBlvBlQGC;sBADAD;sBivBNN;sBhT2EoB;uBgT3EpB;;0BAaE;;;;;;;kCACIj7I;qCACAk5kB,aACAH,eACArxB,YACAh4W,aAEoB;uBApB1B;;0BAaE;;;;;;;;;;oCACI1vM,IACAk5kB,UACAH,YACArxB,SACAh4W,OAEoB;uBAuEtB;;;;2B5lBoLA+9X;8BjCtKEt6D;0B6nB5FJ8lE;;;;uBA8EE;;0BAqDA;;;;;;;;kCACIrlD;;mCACA0lD;sCACA7K,gBACAP,SACAM,eACA1kjB,YAEoB;uBA7DxB;;0BAqDA;;;;;;;;;;;;oCACI8pgB,IACA0lD,UACA7K,aACAP,MACAM,YACA1kjB,KAEoB;uBAmDxB;;;;;uC7nBlGEqpf;0B6nBuCFkmE;;;;uBA2DA;;;2BAoB6Dt9c;;2BAA/CjyG;2BAAgC0kjB;2BAAPN;2BAAdO;2BAAL76C;mCAAyC73Z;;;4BApMR2zE;4BAAbqpY;uCAoMftK,aApMesK,YpV23BtC5mB,eoV33BmDziX;;;oCAoMQ3zE;4BA7L1B88c;;kCA6LVpK,aA7LUoK,apVo3BjC1mB;;qCoVvrBkBv+B,IpVurBlBu+B,eoVvrBuBsc,aAAcP,MAAOM,YAAhC1kjB;;uBApBd;iCAmCOynjB;yCACDx1c,MACR,UAFSw1c,OACDx1c,KACoC;oCAFnCw1c;0BAnMP,eACSvxkB;4BAIiB;;6BAApB;8CAAQ;4BAAR,OAJGA;;mCAEEg0C,IACH0liB,4BADFzliB;yCAAKD,cAALC;;mCAAKD,IACH0liB,4BADFzliB;;+BAgBE;;gCAhBGD;gCAALC,IAgBG;4BAdiB,IAHlBoxL,eAmBN,qBAlBIpxL,IAAKD;mCAFFh0C;yCAuBLqhK;;;;iCAKE,2BpV80BJ8wZ;;;;gCoVn1BE9wZ;iCAOE,2BpV40BJ8wZ;;;;gCoVn1BE9wZ;iCASE,2BpV00BJ8wZ;;;;;+BoVn1BEzK;+BADAqxB;+BADAG;+BApBIxpY;wCADC1vM,IAqBLk5kB,UACAH,YACArxB,SAtBIh4W;;iErlB0RRttC,QqlBpQIf;iErlBoQJe;iEqlB1RQijE;;0BAFR,wC5lBlBA+lW;;oDCsFEsG;sB2lB4IJ;;2BAlDI8H,UA/GAJ;wBA+JA/C;wBACAC;wBADAD;wBACAC;sBhT/Kc;uBgTuMhB/mD;;;2BAA2BxzZ;2BAARw1c;2BAhJwC7hY,OAgJhC3zE;2BAhJsB2rb,SAgJtB3rb;2BAhJSg9c,YAgJTh9c;2BAhJFm9c,UAgJEn9c;2BAhJP/7H,IAgJO+7H;0BA/IpB,cRjHGs2b,SQgHuC3K,SpVoxB/CyK;4BoV5wBG;;6BADA,2BAPsDziX;6BAKtD,sBAL+BqpY;6BAI/B,sBAJoBG;6B5lBgHE,gBAAoB,gB4lBhH3Bl5kB;6B5lBpFD8P;6BAAJF;6BAAJD;;;;iCCuDPmkb,aDvDOnkb,MAAIC,MAAIE;;;iCC/BjB+9jB;;;gC/D+DAj6I;6B+DsB0D9pa,K2lB8KzCynjB;6B3lB9K4B/C,Y2lB8K5B+C;6B3lB9KqBrD,M2lB8KrBqD;6B3lB9KO9C,a2lB8KP8C;6B3lB9KE39C,I2lB8KF29C;6B3lBtKd,gBAAU,iBAR6CznjB;6BAOvD,uBAP0C0kjB;6BAM1C,uBANmCN;6BAKnC,sBALqBO;mC/DtBxB76I;qC+DyBG;;6DAHgBggG;wCArFnBi6C;;;;;uC/D+DAj6I;;;sB0pB4OW;sBjvBnTX14S;sBADAD;sBuJRN;sB0S6EoB;uB1S7EpB;;mCAwBQilG;;8BAKsC;6DALtC25V;+BAKwB,gCALxBD;+BAKI;uDALJD;8BAKI,oBALJj/U,SAM+C;mCAN/CvuL;;8B;oCAAAoG;;;;;;;;;yCAKwB6pE,KALxBC;yCAKwBp9I;yCALxB,mCAKwBA,GALxB63I;8CAKwBsF;yCALxBr4H;;;uCAKsCm6O,KALtC7hH;uCAKsCx8C;uCALtC,+CAKsCA;uCALtCw8C,KAKsC6hH;uCALtCn6O;;;qCAKIk6O,KALJ5hH;qCAKIr8C;qCALJ,mCAKIA,KALJ62C;0CAKIonH;qCALJl6O;;;;;;;;;kHAM+C;8BAN/C,YAM+C;0BAN/C;;;;;;;;;;;;mCAAiCixJ;4B,UAAjCxuB,eAAiCm3M,gCAMc;0BAN/C;4BAAMm8O,gBAAUzoE,WAAK0oE;4BAArB;;;;qEAAMD,gBAAN5/gB;0EAAgBm3c,WAAhBl3c;;kEAAqB4/gB,kBAArB9/W,IAM+C;0BAN/C;4BAAM+/W,cAAU1oE,SAAK2oE,gBAArB79jB;;;;;8CAAM49jB,cAAN59jB;8CAAgBk1f,SAAhBl1f;8CAAqB69jB,gBAArB79jB,aAM+C;0BAN/C;4BAAM89jB,mBAAUC,cAAKC;4BAArB;;qCAAqBA;+BAArB,MAAgBD;+BAAhB,MAAMD;8BAAN;gC,OAAA1ka,6CAM+C;4BAN/C;;;+CAAM0ka;+CAAUC;+CAAKC;+CAArB54kB,EAM+C;;0BAN/C;4BAAM64kB,WAAU5oE,MAAK6oE,aAArBl+jB;6EAM+C;0BAN/C;4BAAMi+jB,WAAU5oE,MAAK6oE,aAArBl+jB;4BAKI;kDALEi+jB,WAANj+jB;6BAKwB,oBALRq1f,MAAhBr1f;6BAKsC,uBALjBk+jB,aAArBl+jB;4BAKsC,UAAlCm+jB,UAAoBC,SAAcC,YACS;0BAN/C;4BAAMC,mBAAUC,cAAKC;4BAArB;8B,OAAAlla;uCAAMgla;uCAAUC;uCAAKC;uCAArBx+jB;;4CAM+C;4BAN/C;;sC,OAAAw5J;+CAAM8ka;+CAAUC;+CAAKC;+CAArBx+jB;uDAM+C;;0BAN/C;;;;;;;;;0CAM+C;0BAN/C;;;4BAKc,GALd45J,gBAKc;6CALdgla;4BAKc;8BAAmB,mBALjCC;8BAKiC;uCAAiB,WALlDC;uCAKiCt0hB;4BAAnB,QAAQ;0BALtB;;;;;;;;;;;;;;;;;;;;;sC6BqfA;wC7BrfA;;;;;;;;;gGAM+C;mDAN/Cw3F;;;;;;;2CAKwB;qEALxBF;;6CAKwB;;gEALxBuzX,MAKwBp0U;;;0CAAc;oEALtCn/C;;4CAKsC;;iEALtCo8b,aAKsCh9Y;;;yCAAlC;mEALJp/C;;2CAKI;;gEALJm8b,WAKI78Y;;wCALJ;;;;;;;;;qCAKI29Y;+BALJ,MAKwBC;+BALxB,MAKsCC;;;;iCAAdE;iCAApBC;wDAAoBD,aAAcD;8BALtC;;;;iDAKIH;;kDAAoBC;qDAAcC,oCACS;0BAN/C;;;;;6BAKsC,eALtCf,aAKsCG;;6BAAd,iBALxBhpE,MAKwB+oE;iEAAcn7b;6BAAlC,iBALJg7b,WAKIE;iEAAoBj7b;4BAApB,iBAC2C;0BAN/C;;;;;;;4BAKc,GALdy3B,gBAKc;iDALdika;4BAKc;8BAAmB,qBALjCC;8BAKiC,2BALjCC;8BAKiC;;;wCAAX;0BALtB;;;;;;;;;;;;mCAAiCzqE;4B,UAAjC7xP,iBAAiC++E,gCAMc;0BAN/C;4BAAMm8O,gBAAUzoE,WAAK0oE;4BAArB;;;;qEAAMD,gBAAN5/gB;0EAAgBm3c,WAAhBl3c;;kEAAqB4/gB,kBAArB9/W,IAM+C;0BAN/C;4BAAM+/W,cAAU1oE,SAAK2oE,gBAArB79jB;;;;;8CAAM49jB,cAAN59jB;8CAAgBk1f,SAAhBl1f;8CAAqB69jB,gBAArB79jB,aAM+C;0BAN/C;4BAAM89jB,mBAAUC,cAAKC;4BAArB;;qCAAqBA;+BAArB,MAAgBD;+BAAhB,MAAMD;8BAAN;gC,OAAAtkE,+CAM+C;4BAN/C;;;+CAAMskE;+CAAUC;+CAAKC;+CAArB54kB,EAM+C;;0BAN/C;4BAAM64kB,WAAU5oE,MAAK6oE,aAArBl+jB;6EAM+C;0BAN/C;4BAAMi+jB,WAAU5oE,MAAK6oE,aAArBl+jB;4BAKI;kDALEi+jB,WAANj+jB;6BAKwB,oBALRq1f,MAAhBr1f;6BAKsC,uBALjBk+jB,aAArBl+jB;4BAKsC,UAAlCm+jB,UAAoBC,SAAcC,YACS;0BAN/C;4BAAMC,mBAAUC,cAAKC;4BAArB;8B,OAAA/kE;uCAAM6kE;uCAAUC;uCAAKC;uCAArBx+jB;;4CAM+C;4BAN/C;;sC,OAAAingB;+CAAMq3D;+CAAUC;+CAAKC;+CAArBx+jB;uDAM+C;;0BAN/C;;;;;;;;;0CAM+C;0BAN/C;;;;;;;;;;;;2C5IyIRkuK;;4C4IzIyCmmV;;;0BAAjC;4B,UAAAya,iDAM+C;0BAN/C;4BAAM4uD,gBAAUzoE,WAAK0oE;4BAArB;;;qEmB+EAhyZ,cnB/EA7tH;;;;;uCAAM4/gB,gBAAUzoE,WAAK0oE,kBAArB5/gB,IAM+C;0BAN/C;4BAAM6/gB,cAAU1oE,SAAK2oE,gBAArB79jB;;;;8CmB+EA4rK,enB/EA5rK;;qCAAM49jB,cAAU1oE,SAAK2oE,gBAArB79jB,aAM+C;0BAN/C;4BAAM89jB,mBAAUC,cAAKC;4BAArB;;qCAAqBA;+BAArB,MAAgBD;+BAAhB,MAAMD;8BAAN;gC,OAAAjnD,oDAM+C;4BAN/C;;;+CAAMinD;+CAAUC;+CAAKC;+CAArB54kB,EAM+C;;0BAN/C;4BAAM64kB,WAAU5oE,MAAK6oE,aAArBl+jB;6EAM+C;0BAN/C;4BAAMi+jB,WAAU5oE,MAAK6oE,aAArBl+jB;;kDmB+EA6rK,cnB/EA7rK;;6CAAMi+jB,WAAU5oE,MAAK6oE,aAArBl+jB;oDAM+C;0BAN/C;4BAAMs+jB,mBAAUC,cAAKC;4BAArB;8B,OAAAznD;uCAAMunD;uCAAUC;uCAAKC;uCAArBx+jB;;4CAM+C;4BAN/C;;sC,OAAAg3gB;+CAAMsnD;+CAAUC;+CAAKC;+CAArBx+jB;uDAM+C;;0BAN/C;;;;;;;;;;;;0CAM+C;0BAN/C,iCAM+C;0BAN/C;;;;;;;4BAM+C,OAN/C5Z,CAM+C;0BAN/C;;;;;;;4BAM+C,OAN/CA,CAM+C;0BAN/C;;;8B,OAAAm0K;;;;sC,OAAAD;0CAM+C;0BAN/C;wEAM+C;0BAN/C;4B,OAAAu8W,8CAM+C;0BAN/C;;;8B,OAAAz8W;;;;sC,OAAAD;0CAM+C;0BAN/C;;;;wFAM+C;0BAN/C;;;6BAAiCk6V;6BAAjCkF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BAAiC3gW;6BAAjCO;;;;;;;;;;;;;;;;;;8BAKsC;6DALtCska;+BAKwB,gCALxBD;+BAKI;uDALJD;8BAKI,oBALJj/U,SAM+C;0BAN/C;;8B;oCAAAnoL;;;;;;;;;yCAKwB6pE,KALxBC;yCAKwBp9I;yCALxB,mCAKwBA,GALxB63I;8CAKwBsF;yCALxBr4H;;;uCAKsCm6O,KALtC7hH;uCAKsCx8C;uCALtC,+CAKsCA;uCALtCw8C,KAKsC6hH;uCALtCn6O;;;qCAKIk6O,KALJ5hH;qCAKIr8C;qCALJ,mCAKIA,KALJ62C;0CAKIonH;qCALJl6O;;;;;;;;;kHAM+C;8BAN/C,YAM+C;0BAN/C;;4BAKc,GALdg0J,gBAKc;6CALdija;4BAKc;8BAAmB,mBALjCC;8BAKiC;uCAAiB,WALlDC;uCAKiCt0hB;4BAAnB,QAAQ;0BALtB;;;;;;;;;;;;;;;;;;;;;sC6BqfA;wC7BrfA;;;;;;;;;gGAM+C;mDAN/Cw3F;;;;;;;2CAKwB;qEALxBF;;6CAKwB;;gEALxBuzX,MAKwBp0U;;;0CAAc;oEALtCn/C;;4CAKsC;;iEALtCo8b,aAKsCh9Y;;;yCAAlC;mEALJp/C;;2CAKI;;gEALJm8b,WAKI78Y;;wCALJ;;;;;;;;;qCAKI29Y;+BALJ,MAKwBC;+BALxB,MAKsCC;;;;iCAAdE;iCAApBC;wDAAoBD,aAAcD;8BALtC;;;;iDAKIH;;kDAAoBC;qDAAcC,oCACS;0BAN/C;;;;;6BAKsC,eALtCf,aAKsCG;;6BAAd,iBALxBhpE,MAKwB+oE;iEAAcn7b;6BAAlC,iBALJg7b,WAKIE;iEAAoBj7b;4BAApB,iBAC2C;0BAN/C;;;;;;;;4BAKc,GALd65B,gBAKc;iDALd6ha;4BAKc;8BAAmB,qBALjCC;8BAKiC,2BALjCC;8BAKiC;;;wCAAX;0BALtB;;;;;;;;;;;;mCAyBF53V,YACErkP;2CAEEA,6BAAqB;4BAFvB,eACEA,yBAAsB;4BADxB,eAAEA;8BDsNG,eAAqBA;gCA9E5B,SA8E4BA;kCA9E5B;wCA8E4BA;mCP7P5Bw5N,mBA0BoC,0BOqJpCqxB;mCP/KAxpB;gDA0BC,WwgB2DD2xS,ajgB0FAnoR,UP/KArxB;;gCO+KA;wCA8E4Bx5N;iCHhQ9By7P,qBACqC,WogBuFnCu3Q,ajgB0FA9kO;;;;;kFHlLFzyC,mBGgQ8C;8BAA9C;;kDAlOIz7P;;+DAwCE,uBAxCFA;iEAuCE,uBAvCFA;iEAsCE,uBAtCFA;;yDAqCE,WigBqBJgzgB,ajgB1DEhzgB;;yDAoCE,0BApCFA;wEAkOwB;;uCCtNtBA,EAAmB;4BADvB;iFACEA,EAGgB;0BA7BhB,SAyBFwmH,SACExmH;2CAEEA,6BAAqB;4BAFvB,eACEA,yBAAsB;4BADxB,eAAEA;8BDsNG,eAAqBkhG;gC,UAAAA;;;;;;;;;;4CA5E1B;;;4DAFF2pJ,MAEE,aAFFA,MAEoD;sDAFpDkjD;;;;;;;;;;;;;;;;;oDHjLA;8DADFG;sDACE,SADFA,UACEnvC;;;;;4DAAmC;6DAAfD,KAApBC;6DAAoBh+J;6DAAe,mBogByFnCkya,apgBzFoBlya;6DAApBg+J,KAAoBD;6DAApBh5M;;;;;;;;2FADF+kM,MACE,aADFA,MACwE;;;;;4CiCogBpE;mD+Q7gBJt4B;;;;0C7S2LI;;;0DADFs4B,MACE,aADFA,MAC0C;;mDAD1C+iD;;;4CP/KA,OO+KAA,UP/KAxwJ;;;;;;;mDAI+B6hH,KAJ/B7hH;mDAI+Bx8C;mDAJ/B76C,gBA0BoC,0BAtBL66C;mDAJ/Bw8C,KAI+B6hH;mDAJ/Bn6O;;;;mDAIIq4H,KAJJC;mDAIIp9I;mDAJJgmD,WA0BC,WwgB6DDitd,axgBnFIjzgB,GAJJ43I;wDAIIuF;mDAJJr4H;;;;;;;;;;0GAKsD;;;iDoThBxDytM;gC7S0LE,YA8E4C;8BAA9C;2DAAUvyN,uBAAkB,SCtNtBA,EAAmB;4BADvB;iFACEA,EAGgB;0BAJlB;;;;;;;;;sEDuNGu3kB;kCTpPAhqB;;2BU6BEl2Y,iBAALjB;;4B;mDDuNFoha,oBTpPAhqB,cU6BEjrjB;;4B;;qDDuNFk1kB,qBTpPAhqB;qCU6BEtwiB;;uCAKwC;8BALxCq7J;kDAIEr7J;4B;;qDDmNJu6jB,qBTpPAhqB;qCUiCIvwiB;;;mCAJF01iB;4B;;qDDuNF6kB,qBTpPAhqB;qCU6BEvwiB;6CAKwC;;2BALxCw7J;sCAAKtB,cAALmB;;;;4BAIE,eADE65H;6DAAqB;4BACvB,eAFEhF,4CAAsB;4BAExB,eAHE/xH;8BDsN0C,eAAlB8oF;gCA9E5B,GA8E4BA,gBA9E5B;yCA8E4BA;;;oCA7Eb,IAAbg1C,MA6E0B/0C;oCPzPV,aO4KhB+0C,MP5KgB;oCO4KH,IP5KGv2S,EAsBjB,uBOsJCu2S;iDP5KgBv2S;6CAsBkB,oCOsJlCu2S;6CP5KgBv2S;kCO4KhB;0CA6E0BuhQ;kDA7E1B;gCACsB,IAAtBk1C,MA4E0Bj1C;gCHhQ9B,iBGoLIi1C,QHpLJ,uBGoLIA,SA4E0C;8BAAE;gDAAtCr1C;yCA3NI,GA2NJA,gBA3NI;yCA6BR,IA7BQtoJ,IA6BR,2BA8LIsoJ;kDA3NItoJ;2CA8BR,IA7BiBlpC,IA6BjB,cA6LIwxL;oDA1NaxxL;6CA8BjB,IA7BU9qB,IA6BV,wBA4LIs8M;sDAzNMt8M;+CA8BV,IA7BgB9kD,EA6BhB,wBA2LIohQ;4DAxNYphQ,EA8BhB,wBA0LIohQ,mBAxNYphQ;6CADN;2CADO;yCADT,UA2Nc;;uCCtNtBy4K;6CAAmB;4BAGrB;sEAJFqxE,YAIkB;mCAJlBjoI;4B;oDDuNFizd,clClCFziE,cyBlNEy4C,cU6BEpqjB;;4B;oDDuNFq0kB,clClCF3iE,cyBlNE24C,cU6BErrjB;;4B;;qCDuNFs1kB;qClCtFEhjE;qCyB9JFi5C;qCU6BEp7b;;mCAOI66K,iBAPJ,YAKwC;mCAMtC+zQ;4B,IAXF5ub,IwF+HAlH;;qCxF/HAo/K,kBAWE5qS,GAA6C;mCAE7Cs3F,0BAA6C;;;;6BAb/CogB;;;;6BAWE4pc;6BAXF5pc;;;;6BAaEpgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mCAMEqlf,8BAA6Cj4e;4B,IAAlBg6P;4BDoQnC,GCpQqDh6P;8BD0QjD;8CACmCk4e,SAAW,UAAXA,kBAAmC;+BAAnE,gBAAW,SC3QiBl+O;8BD0Q9B,uBC1Q8BA;4BDsQ/B,eAEUk+O,SAAW,UAAXA,kBAA+B;4BADxB,sBCvQcl+O;4BDuQ3B,2BCvQ2BA;mCAG3Bm+O,oBAAqBt5kB;4BACvB,sBACK,IAAMq5kB,iBAAN,OAAMA,OAA6B;4BAD/B,sCADcr5kB,WAEiB;0BAxB1C;wCAAK8zK;0BAAL;+DAAKA;2BAALo/V;;;;;;;;;;;;;6C5IgHNprV,2B4IhHMorV;;;;;;;qEmBsDE3tV,cnBtDF7tH;iFAKwC;mCALxCiihB;;;;8CmBsDEn0Z,enBtDF5rK;gEAKwC;;2BALxCggkB;;;6EAKwC;mCALxCE;;kDmBsDEr0Z,cnBtDF7rK;;oDAKwC;;2BALxCmgkB;;;;;;;6DAKwC;mCALxC7ka;;;;;;;4BAKwC,OALxCl1K,CAKwC;mCALxCm1K;;;;;;;4BAKwC,OALxCn1K,CAKwC;8BALxCw2K;;mEAKwC;mCALxCxB;4EAKwC;;2BALxCoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BAAKtC;6BAALitW;;;;;;;;;;;6BAOI/2O;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BAYAovS;6BAGAE;;mCAQJ73V,YACEhlP;2CAEEA,6BAAqB;4BAFvB,eACEA,yBAAsB;4BADxB,eAAEA;8BDiMG,eAAqBA;gCA5E5B,SA4E4BA;kCA5E5B;wCA4E4BA;mCA5E5B;mCPtJA;6CAAEA,qBwgBiDFgzgB,axgBjDEhzgB,EAAiC;mCAzBnCw5N,mBA2BE,0BOoJFqxB;mCP/KAxpB,qBA0BE,aOqJFwpB,UP/KArxB;mCAEI,qCO6KJqxB,UP/KAxpB;mCACI,qCO8KJwpB,UP/KA4Q;;;;gCO+KA;wCA4E4Bz7P;iCH/P9B27P,qBAGuB,WogB2ErBq3Q,ajgBqGA9kO;iCHnLFtyC;8CAEoB,WogB4ElBo3Q,ajgBqGA9kO,YHnLFvyC;;;;;qGG+P8C;8BAA9C;;kDAxNI37P;;+DAqCE,uBArCFA;iEAoCE,uBApCFA;iEAmCE,uBAnCFA;;yDAiCE,WigBMJgzgB,ajgBvCEhzgB;iEAkCE,aAlCFA;;yDAgCE,0BAhCFA;wEAwNwB;;uCCjMtBA,EAAmB;4BADvB;iFACEA,EAGgB;mCAJlBymH,SACEzmH;2CAEEA,6BAAqB;4BAFvB,eACEA,yBAAsB;4BADxB,eAAEA;8BDiMG,eAAqBq8G;gC,UAAAA;;;;;;;;;;4CA1E1B;;;4DAFFwuI,MAEE,aAFFA,MAEoD;sDAFpD+iD;;;;;;;;;;;;;;;;;oDHlLA;8DADFM;sDACE,SADFA,UACErvC;;;;;;;6DACMS,KADNT;6DACM3iJ;6DADNx2D,WACkB,WogB8ElButd,apgB9EM/2Z,KAFR+xL;6DACEpvC,KACMS;6DADN15M;;;;6DAEM25M,KAFNV;6DAEM7iJ;6DAFNr2D,WADFooP,OAGuB,WogB6ErBklO,apgB7EMj3Z;6DAFN6iJ,KAEMU;6DAFN35M;;;;;;;;;8DADFqoP;;gEACE;yEADFF,sBACE,aADFljD,WAIO;;;;;4CiCufH;mD+Q7gBJt4B;;;;0C7SsMI;;0DADFs4B,MACE,aADFA,MAC0C;2CPvJ1C;qDAAE7qP,qBwgBmDFizgB,axgBnDEjzgB,EAAiC;;;mDOsJnCo4d;;;gDP/KA9kZ,GO+KA8kZ,UP/KAh7U;;;;;;;;;;;mDAII2hH,KAJJ3hH;mDAIIl8C;mDAJJr7C,0BA2BE,0BAvBEq7C;mDAJJk8C,KAII2hH;mDAJJj6O;;;;mDAEIk6O,KAFJ5hH;mDAEIr8C;mDAFJ,gCAEIA,KAFJ82C;wDAEImnH;mDAFJl6O;;;;mDACIm6O,KADJ7hH;mDACIx8C;mDADJ,2BACIA,KADJg3C;wDACIqnH;mDADJn6O;;;;mDAGIq4H,KAHJC;mDAGIp9I;mDAHJgmD,qBA0BE,WAvBEhmD,GAHJ2+P;wDAGIxhH;mDAHJr4H;;;;;;;;;;;;;;;;0IAMsD;;;iDoT5BxDytM;gC7SqME,YA4E4C;8BAA9C;;kDAAUv/I;2C,UAAAA;iDAxNNM,GAwNMN,SAxNNoqE;;;;;;;;;;;;;;;;;;4DAKID,KALJC;4DAKIp9I;4DALJgmD;oFAoCE,uBA/BEhmD,GALJy+P;iEAKIthH;4DALJr4H;;;0DAIIm6O,KAJJ7hH;0DAIIx8C;0DAJJ76C;6EAmCE,uBA/BE66C,KAJJ89J;+DAIIO;0DAJJn6O;;;wDAMIk6O,KANJ5hH;wDAMIr8C;wDANJj7C;qFAqCE,uBA/BEi7C;wDANJq8C,KAMI4hH;wDANJl6O;;;sDAEIi6O,KAFJ3hH;sDAEIl8C;sDAFJr7C,gBAkCE,WAhCEq7C,KAFJ22C;2DAEIknH;sDAFJj6O;;;oDAGIg6O,KAHJ1hH;oDAGIphC;oDAHJp2D;kEAiCE,WigBQJqtd,ajgBtCMj3Z,KAHJ2iJ;yDAGIG;oDAHJh6O;;;kDACI+5O,KADJzhH;kDACIlhC;kDADJv2D;sDAgCE,0BA/BEu2D,KADJ07B;uDACIinH;kDADJ/5O;;;;;;;;;;;;;;;;;;;0KAQsD;2CARtD,YAwNwB;;uCCjMtB9kB,EAAmB;4BADvB;iFACEA,EAGgB;0BAJlB;;;;;;;;;sEDkMGg4kB;kCT7PAzqB;;2BU2DEl1Y,iBAALiB;;4B;mDDkMF2+Z,oBT7PAzqB,cU2DEjrjB;;4B;;qDDkMF21kB,qBT7PAzqB;qCU2DEtwiB;;uCAKwC;8BALxC69J;kDAIE79J;4B;;qDD8LJg7jB,qBT7PAzqB;qCU+DIvwiB;;;mCAJFugkB;4B;;qDDkMFvF,qBT7PAzqB;qCU2DEvwiB;6CAKwC;;2BALxCg+J;sCAAK9C,cAAL2C;;;;4BAIE,eADEg0E;6DAAqB;4BACvB,eAFEH,4CAAsB;4BAExB,eAHEP;8BDiM0C,eAAlBqY;gCA5E5B,GA4E4BA,gBA5E5B;yCA4E4BA;;;oCA3Eb;2CA2EaC;qCP/N5B;+CAHE6rC,8CAAiC;oCAxBnB,aO+KduH,MP/Kc;oCO+KD,IP/KCn3S,0BO+Kdm3S;oCP/Kc;sCACE,gCO8KhBA;sCP9KgB;wCAwBhB,IAvBavnO,IAuBb,W6lBjCJ6/e,qBtlBuLIt4Q;qDP7KavnO;iDAwBb,oCOqJAunO;iDP7KavnO;sCADG;oCADF;kCO+Kd;0CA2E0Bk0L;kDA3E1B;gCACsB,IAAtBzE,MA0E0B0E;gCH/P9B,aGqLI1E,MHrLJ;gCGqL0B,IHnLNvmJ,2BGmLhBumJ;gCHnLgB,iBACG,uBGkLnBA,UHnLgBvmJ,GG6P0B;8BAAE;gDAAtC8qJ;yCAvNI,GAuNJA,gBAvNI;yCA+BR,IA/BQ7qJ,IA+BR,2BAwLI6qJ;kDAvNI7qJ;2CAiCR,IAhCcnpC,IAgCd,WslB5EN6/e,YtlBkQU7rT;oDAtNUh0L;6CA+Bd,IA9BiBkpC,IA8BjB,cAuLI8qJ;sDArNa9qJ;+CAgCjB,IA/BUh0D,IA+BV,wBAqLI8+M;wDApNM9+M;iDAgCV,IA/BgB9kD,EA+BhB,wBAoLI4jQ;8DAnNY5jQ,EAgChB,wBAmLI4jQ,mBAnNY5jQ;+CADN;6CADO;2CADH;yCADN,UAuNc;;uCCjMtByrP;6CAAmB;4BAGrB;sEAJFH,YAIkB;mCAJlB4kD;4B;oDDkMFqlS,clC3CFljE,cyBlNEy4C,cU2DEpqjB;;4B;oDDkMF80kB,clC3CFpjE,cyBlNE24C,cU2DErrjB;;4B;;qCDkMF+1kB;qClC/FEzjE;qCyB9JFi5C;qCU2DEp7b;;;4B,IAAAA,IwFiGAlH;;qCxFjGAmzL,qBAKwC;mCAEpCxE;4BAGE;6BAH4Bg2Q;6BAARytB;6BAATl/O;6BAGX;gEAHWA;6BAGX;;+BAHWA;;;+BAET6wO;+BAFS7wO;6BAGX,MAHWA;4BAGX;6BAcI;;2CADMm/O;8BAFR/gd,QAGM68c;;6BAOJ;;8BJrFiCC,aIoFlBkE;8BATjBhhd,WJ3EmC88c;4BIgErC,IAFAmE,aAKEzL,OAQAx1c;4BAaJ,UA1BEihd,UADoBH,OAAQztB;0BAPlC;0CAAK93Y;0BAAL;;;;;;;;;;kEDkMFsga;oClC/FEtjE;kCyB9JFu5C;;2BU2DO7rC,mBAALnoW;;4B;;qCDkMFw+Z;qClC/FE5jE;qCyB9JFu5C;qCU2DExsjB;;4B;;;uCDkMF82kB;uClC/FE5jE;uCyB9JFu5C;qCU2DE7xiB;;uCAKwC;8BALxC+gkB;kDAIE/gkB;4B;;;uCD8LJ07jB;uClC/FEtjE;uCyB9JFu5C;qCU+DI3xiB;;;mCAJFihkB;4B;;;uCDkMFvF;uClC/FEtjE;uCyB9JFu5C;qCU2DE3xiB;6CAKwC;0BALxC;;;+BAAK4lgB,gBAALm7D;;;;;;;;;6C5IkFN7yZ,2B4IlFW03V;;2BAALsF;;;;;qEmBwBEv/V,cnBxBF7tH;iFAKwC;mCALxCujhB;;;;8CmBwBEz1Z,enBxBF5rK;gEAKwC;;2BALxCshkB;;;6EAKwC;mCALxCE;;kDmBwBE31Z,cnBxBF7rK;;oDAKwC;;2BALxCyhkB;;;;;;;6DAKwC;mCALxChla;;;;;;;4BAKwC,OALxCr2K,CAKwC;mCALxCu2K;;;;;;;4BAKwC,OALxCv2K,CAKwC;8BALxC84K;;mEAKwC;mCALxC3C;4EAKwC;0BALxC;;;;;;6BAAKqpW;6BAALi7D;;;;;;;;;;;;;;;;;;;;;;;;+DAAK3la;2BAAL8uW;;;;;;;;;;;;;6C5IkFN97V,2B4IlFM87V;;;;;;;qEmBwBEr+V,cnBxBF7tH;iFAKwC;mCALxCikhB;;;;8CmBwBEn2Z,enBxBF5rK;gEAKwC;;2BALxCgikB;;;6EAKwC;mCALxCE;;kDmBwBEr2Z,cnBxBF7rK;;oDAKwC;;2BALxCmikB;;;;;;;6DAKwC;mCALxCrka;;;;;;;4BAKwC,OALxC13K,CAKwC;mCALxC23K;;;;;;;4BAKwC,OALxC33K,CAKwC;8BALxCi8kB;;mEAKwC;mCALxCzka;4EAKwC;;2BALxC0ka;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BAAKpna;6BAALs6Y;;;;;;;;;;;;;;6BAOIx4Q;;;2BAlDQsI;;;;;;iEAiFb;mCAjFaC;;;;;;;;;;wFAiFb;4BAjFa;;+FAiFb;;;;;sCAjFavlS;;8DAiFb;2BAjFawikB;;;;;;iEAiFb;;mCAjFaC;;;;;;;;;;wFAiFb;4BAjFa;;+FAiFb;;;;;;6BAjFan9R;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mCA2FZ0tQ;4B,IAAiBA;mCAEjBzxN,e,IAAeA;0BAET,SAANi2L,W,OSkDIhka,UVgHN4od,MCpKE76O;0BAIQ,SAARuwO;4B,OSgDIt+c,UVwHN8od,QC5KE/6O;0BAIQ;mCAKRmhP,qBAAqBt8kB;4BAAkB,cAAlBA,GAAkB,wCAAoB;0BALnD,SAORq6kB,c,IAASA;0BAPD,SASRvD,iBAAoB,OsQ0wBpBnnB,ctQ1wBoC;0BAT5B,SAWRsc;4B,IAAgB9wO,iBDyJK,OCzJLA;0BAXR,SAaRohP;4B,IAAaphP,wBDyJf86O,UCzJe96O;0BAbL,SAeRqhP;4BDiL+D;6BCjLjDrhP;6BDiLiD,YCjLjDA;6BDiLiB;4BulB2MhC;;;wChVwYCw0N;wCgV3YsBQ;wChV2YtBR;;0BtQnxBQ,SAiBRn6hB,aD0EgB,OuQwrBhBm6hB;0BtQnxBQ,SAmBR4mB;4BD6JoB,IC7JLiE,mBD6JK,MC7JLA;4BDkEjB,mBAEI,IADMr/O,iBACN,OADMA;4BA0FY,IAxFHi7O;4BACf,OADeA;0BCxFT,SAqBRqG;4B,IAAYthP,wBD6Jdg7O,SC7Jch7O;0BAEH,SAAT9tJ;4B,OSyBIjgF,UVwIN8/E,OC5LEiuJ;0BA6BO,SAAP7zU,Y,OSuBI8lG,UV4HNg5a,OChLEjrM;0BA+Bc,SAAduhP;4B,OSqBItvd,UV0HN4+c,YC9KE7wO;0BA+Bc,SAEd39V;4B,IAAO29V,iBDuED,aCvECA;0BAFO,SAIdr0I,WAAY9mN,GACd,aADcA,sBAKE;0BATA,SAWd0wgB,gBAAiBv1K;4BAED,iDAFCA,SAEiC;0BAbpC,SAedwhP,aAAcxwE,eAAgB8I,YAC7B95K;4BAED,0BAFCA;4BAED;+CAHcgxK,eAAgB8I,kBAGL;0BAlBX,SAoBd55gB,KAAM8wgB,eAAgB5S,GAA2Bp+J;4BAIrC,uBAJNgxK,eAAgB5S,MAA2Bp+J;4BAIrC,UAJqCA,QAA3Bo+J,YAKvB;0BAzBe,SA6BZqjF,gBAA6BrjF,GAC5Bp+J;4BACH,UADGA,QAD4Bo+J,MWwjD7BmyD,cXtjD8D;0BA/BlD,iBA6BZkxB;0BA7BY,SAmCZC,UAAWxhlB,KAAoDukK,QAC7DtnH,IAA6BwkiB,UAAUC;4BAC3C,GADIzkiB,IAAQ,QAARA,aAAQ27B,aAARy3f;4BAEU;;qCAAVsR,UAF6BF;6BAEnB;6BAMZ,+BANEE,QACAC;6BAKF;;;;+BACE31jB;+BAFA8pgB;;+BAHsC+kD;+BAAhCkE;6CAMF9gd;gCAKE;wDANNjyG;iCAGF;6CALE8pgB,IAMc,WATRipD,WAJN3O,cAUInyc;gCAEN,kBAbWl+H,KAKHg/kB,OAONl/O,QAOgB;8BARL,qBAV4B4hP,YAIjC1C,OAAgClE;8BAM3B;;;4DAHX9nD,eAEA1uX;iEAV6DC;6EAmB7C;0BAtDN,SAwDZs9a,yBAA0Bp9a,KAAMsd;4BACO,IglB9LlC17K,EhlB8LkC,WADbo+J;;kCglB5LdljK,WAAVD,uBAAUC;gChlB6LVgjK,+BglB9LGl+J;8ChlB6L2B07K,IAC9Bxd,QACQ;0BA1DE,SA6DVu9a;4BAAW9hlB,KAAoDukK,QAC9D8ra,MAAQpzhB,IAAiBg+hB,WAAYwG;4BACxC,GADWxkiB,IAAa,QAAbA,kBAAa27B,aAAbmpgB;mCA3BXP;qCA0BaxhlB;qCAAoDukK;qCAC9D8ra;qCAAqCoR;;uCAErC,IAA8C3G;uCAA9C,eAEKjpY;yCAKU,wBAP+BipY,UAEzCjpY,QAKgD;uCAPrD;;wCAGD,+BALSkwY,WAAiB9G;wCAK1B;wFAIsD;0BAvE5C,SAyEVl5Z,IAAM9kI;4B,GAAAA;6BAAY,QAAZA,iBAAY27B;;iCAAZopgB;4BACR,gBADQA;8BAKJ;;;kC;gEA1DNhilB;8BA0DM;gC,OAjBF8hlB;;4BAeE;gD;4BAAA;8B,OAfFA;;0BA7DU,SAgFVG;4BAA8BD,UAAWv9a,KAAM4ra,MAAO0R,WACrD9G,WAAYwG;4BACf;qCAF2Ch9a;8CAEDF;uCACtC;oDAH4By9a;gDAEUz9a;gDAFO8ra;gDAAO0R;gDACrD9G;gDAAYwG,UAEsD,EAAE;0BAnF3D;;+BA6DVK,YAYA//Z,IAOAkga;0BAhFU,SAuFV/tX,MAAK3vD,QAAS8ra,MAAOoR;4BACvB;8BACE,IAA+CzG;8BAIpB,kCAJoBA,gBAIkB;4BALnE;;mD;qCADOz2a;qCAAS8ra;qCAAOoR;2CAM4C;0BA7FvD,SA+FVS;4BAA8Bz9a,KAAM4ra,MAAOoR;4BAC7C;qCADgCh9a;;uC;gDAR9ByvD,YAQoCm8W,MAAOoR,mBACc;0BAhG/C;+CAuFVvtX,MAQAguX;2BA/FU;;;;mCA4GZl7a,SASE/nK,OAASg+C,IAAmBoliB;4BAChC,GADapliB;6BAAY,QAAZA,iBAAY27B;;iCAAZopgB;4BACb,eAESM;8BAGD,GAHCA,iBAGoB;8BAEV,IglBpQHr+kB,EhlB4PgBo+kB;8BAQb;gCA2Cf;iCA1CwBE;iCAAjBC;iCA0CP;;oCAnD4BH;oDAmDf,IAAYhS,eAAZ,OAAYA,KAAmB;gCAA5C;yCA1COmS;kDAkDuCE;2CACH;;8DAnDnBH,gBAkDsBG;2CAN/B;gDAGRhugB,YAALtzE,sBAAKszE;;sDADH;2CAKuC;4CAAzBiugB;4CAAZC;4CACqB,yBA7DCP,aA2DkBK;4CAEnB;2CACzB,iBArDsBH,gBAkDsBG;;2CAC5BC;2CAAyB;4CAG7B,uBAbZF,eAS4CC;4CAKjB,uBADvBrS;2CACJ,iBAdAoS,eAS4CC;2CAK5C,eACS3sD;6CAUwC;yEAVxCA;8CAUP;+DAAkC,qBAfhC6sD;6CAeF,eAEO9H;+CAQS;uEAxBd+H;gDAyBF;;mDArBO9sD,IAoBH+sD,YAtBFzS,oBAcKyK,SAHLjpY;gDAYF,oBAtFKmwY,UAjGbhilB;gDAkMgB,iBAPNslI,SA7BAu9c,UAuBA/iP;+CAaM,wCAAuB;6CAhB5B;uFglB7UK77V;;;;0DhlB0UIwd;mDACU;2EA/EE4gkB,aA8EZ5gkB;oDACU;qEAAdy8e,MAC6B;8FAiBN;2CAzBxB;uEAZL0kF;4CAWO;4CAAL;4CADO;4CAAT;4FA2B6B;8BAzFpB;gCAqCgB,IAASG;gCAAT;yCAASA;kDACPhriB;2CACzB;oDADyBA;6DACEgD;sDACC;kFADDA,UACmB,EAAE,EAAI;8BAxC7C,eAGLioiB;gCAGa;0DAHbA;;;;gCAGa,eAEbR;iDAOAD;oCAeT;gEAtBSC,gBAOAD,iBAegC;kCglBzSlD,SAAQptX,GACHzgJ,GhlB2RgBv1E;oCglB1RhB,mBhlB0RgBA,EglBrRD8E;sCALH;sDAAa7C,GAAK,aAALA,EADzBszE,IhlB2RgBv1E,UglB1RmC;;iDhlB2RhC+jlB;0CACc;kEA3BFb,aAyBfljlB;2CAEiB;6CADd+jlB;+CAELC,gBADGnrc;;2CAKA;uEALAA;4CACHmrc,gBAGA;0CAIF;mDglB9Lfp6B;mDhlBuLiBo6B;mDAOF,iBArBJF,iBAWQ9jlB,UAUe;;;6EW+zC9B6hK;;oCqkBlmDW,8BAFZtsF,IAEuB;mDAH5B;;;;oCpe+mB+B;;;;;wC5GzVK;;yD;;qC4GyVhB;;;;;kCADV;;mCoellBV,YADUm3C;mCAXV;6CAAW5nH;sCACN,mBADMA,EAHWqlB;;;mDAKT85jB;4CACT,KANkB95jB,IAGXrlB,EAEEm/kB,UACT,UAHOn/kB,UAIG;wCAFU;kFAFbA,EAHWqlB;;sCAQf,iBAReA,IAQL;gDALjB;oFhlByRkD;8BA1BvC;gDglBzKTo/hB,ahlBgKW45B,WglB/POr+kB;+BhlBuQZ;;+EAsFqC;4BA7FvC;;qCAJEhF,O7InIJ0iK;4B6IuIE,iDA6FuC;0BAtN3B;;;6BAmCZ6/a;6BAqBAK;;;6BA2CAlU;6BAEAwU;6BAEAvU;6BAEAwU;6BAGAp7a;0BA5GY,SA6NZ2/E,YAASvlP,sCAAW;0BA7NR,SA6NZ0mH,SAAS1mH,sCAAW;0BAApB;;2BAAKu5K,iBAAL0oa;;;;;;;sCAAK1oa,cAAL2oa;;;;;;;wEAA2D;0BAA3D;;;;;0CAAK3oa;0BAAL;;;;;;6BAAKA;6BAALyC;;;;;;;;;;;;;;;;;qFAA2D;0BAA3D,wDAA2D;0BAA3D;;;;;wEAA2D;0BAA3D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mCAgBFsma,gBAAgB/+kB,GAClB,oBADkBA,EACuC;0BAjBrD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6BA9SGiwgB;6BAAL+uE;;;;;;;;;;;;;;;;;;;;;;;;6BAqUE1ihB;6BAEAuyY;2BAzBA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mCAmCFwxI,gBAAiBl0E;4BAGjB;6BAHoDygD;6BAARytB;6BAATl/O;6BAGnC,sBAHmCA;6BAEnC,iBjG1OA3O,YiGwO4C6tP;4BAE5C;+CAFiBluE,eAAmCygD;0BAnClD,SAwCF0zB,YAAYtglB;4BACE,2BADFA,GAEC,qBAFDA;4BAEC,UADXi2kB,aACAE,YACmB;0BA3CnB,SA6CFoK,iBAAiBvglB;4BACnB,eAAqC88S,IAClB,0BADkBA,IACQ;4BADhC,6BADM98S,SAE4B;0BA/C3C,SAiDFwglB;4BAA+Br0E,eAAeygD,UAAUytB,OAAOl/O;4BACjE,eACSk/O;8BACT;oCAHiEl/O,QAExDk/O,OAFuCztB;+BAIhC,sBAJiBzgD,eAG7BnsgB;+BACY,YAAqC,iBADjDA;8BACmE,qBADnEA,EACsE;4BAFxD,qBAFwCq6kB;4BAExC,iDAEwD;0BArDtE,eAyDKv6a;4BAID,kBAJCA;4BAID,sDAAyD;8BAN/D2gb,iBAGA,qBhCjZFjpE;;;;;;;;;;8BgCuZA;;;;;;;;;uCATEipE;gDAS0CzglB;yCAAY,qBAAZA;uEAA+B,EAAC;;;;;;;;;;8BAG5E;;;;;;;;;uCAZEyglB;gDggBjZuDzglB;yChgB8ZrD;;;0CggB7ZE,uBAAY,oBADuCA;yCACnD;0CAEF,2CAHqDA,EAEpDkY;;0CAGD,iDADIvI;;uEhgB0ZqE,EAAE;mCAG7Es/B,MAAMjvC;4BAAoB;qDAApBA;6BAAoB,YAAqB,iBAAzCA;4BAA2D,qBAA3DA,EAA8D;mCAGpE0glB,yBAAyB1glB;4BAAmB,iCAAnBA,KAAwC;mCAEjE2glB,aAAa3glB,GAAI,OAAJA,CAAK;mCAElB4glB,sBAAsBC,cAAc1wE;4BACtC;qCADwB0wE;8CACUC;uCAKvB,2BAN2B3wE;uCAK9B,sB,OS3RF/iZ;uCTyRA,iCAF4B0zd,oBAMA,EAAE;;;;;;;;;4CAMpC,gCAAiC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kCAzV/Bl0B;kCAEAzxN;kCAEAi2L;kCAEAs6C;;kCAKA4Q;kCAEAjC;kCAEAvD;kCAEA7K;kCAEAsQ;kCAEAC;kCAEAhnjB;kCAEA+gjB;kCAEAkG;kCAEApvY;kCAEA/lL;kCAEAo1jB;kCAEAl/kB;kCAEAspN;kCAOA4pT;kCAIAisE;kCAKAthlB;;;;kCAyNA0jlB;;;;;;kCAmBAsB;kCAKAC;kCAKAC;kCAIAC;kCAMAC;kCAgBAxxiB;kCAGAyxiB;kCAEAC;kCAEAC;uBA3cN;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wC;uBAAA;;;;;;;;;;;;;;;;;sBA2d6C;sBvJldvCloc;sBADAD;sBwJNN;sByS2EoB;uBzS3EpB,8BkBsWU81T,elBxVFhyY;uBAdR;;;;;;;;;;uBA0BM;;uBAEG;wC,UAFHwkhB;uBAEG,mBAFHn7E;uBAEG,mBADDE,ekBsVEC;uBlBrVD;2BI2LEi7E,mBJ7LLC,gBACEC;uBACC,iBADDzklB,6BAAsE;uBACrE,gB6iB+GLgpgB,Y7iBhHIC;uBACC;;;2B6iB+GLF;2B7iBjHEI;;2BACEE;2BkBsVEC;2Bd1JCi7E;2BJ7LLC;2BACEC;;;2B6iBgHJz7E;2B7iBhHIE;;uBACC;uBAFH;uCI6LKq7E;sBqS5IS;uBzS9BdM;wBACF,iBAAQ,oBAAC;sBAkFV;sBxJzHG5oc;sBADAD;sBmvBNN;sBlT2EoB;uBkT3EpB;;;;;;;;;;;sBAA4C;sBnvBOtCC;sBADAD;sByJVN;sBwS+EoB;uBxS/EpB;0CAMMm2T,eAFApyY;uBAJN;;;sBASY,2BwBwtCFwpc;sBgRlpCU;uBxS7DhB;;uBAEG;wC,UAFHu7E;uBAEG,mBDUD37E;uBCVC,mBDWCE,ekBsVEC;uBjBjWH,YADIy7E,gBADPC,gBACEC;uBACC,iBADDjllB,6BAAsE;sBACrE,U4iB2HHgpgB,Y7iBhHIC;sBCXD;;yB4iB2HHF;yB7iBjHEI;;yBACEE;yBkBsVEC;yBjBlWCy7E;yBADPC;yBACEC;;yBDYEh8E;yB6iBgHJD;yB7iBhHIE;yBCZFi8E;sBwS4Dc,IxS7DhBC;uCACOL;sBAc+C;sBzJtBpD9oc;sBADAD;sBovBTN;sBnT8EoB;uBmTtEd;;;;;;;;;uCzuB0JNuwC,mB8IhJWw4Z;0CGwMAxlC;;uBwlBlNL;uBAImC;wC,UAJnC8lC;;uCAAKC;sBnTsES,ImTtEd;sBA8BA;;;;;;0C,O/mBhCY5tC;4B+mBEP4tC;;sBAoDR;sBpvBlDGrpc;sBA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;;oEJlLA+hX,cIkLAj1Q;;;gDjJ7CN1nE,kBiJ6Ca4lV,WAAPn+Q;;oEJlLAk1Q,cIkLAn1Q;;;;;0BhB3LA,GgB2LAD;2BhB3LA;+BgB2LAA;4BhB3LAK,GgB2LAL;4BhB3LA/4B,GgB2LA+4B;4BhB3LA74L,GgB2LA64L;4BhB3LA94L,GgB2LA84L;4BhB3LA;;;;;;;0BgB2LA;;;;;sDjJ7CNvnE,kBgJ4DI8ha,cCfEz6V;uBAqE+C;iChB/OjD12O,IgBiOEkuC;0BAvDA;+BAuDA9oD;2BAvDA,IAuDAA;2BAvDA,GAuDAA;2BAvDA,GAuDAA;2BAvDA,GAuDAA;2BAvDA,GAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;2BAvDA,KAuDAA;;;2BAvDA,ehB1KF4a,IgBiOEkuC,OAvDAyhE;4CglBzMFwkc,ehmB+BAn0iB,IgB0KEssC;kDhB1KFtsC,IgB0KEgtC;kDhB1KFhtC,IgB0KE+sC;kDhB1KF/sC,IgB0KE8sC;4CJlLAm/c,eZQFjsf,IgB0KE6sC;kCjJ7CNyiI,mBiJ6Ca4lV,ShB1KTl1f,IgB0KE4sC;6CJlLAq/c,eZQFjsf,IgB0KEquC;2BhB1KF;;;;0BAjBE,GgB2LAuoM;2BhB3LA;+BgB2LAA;4BhB3LAK,GgB2LAL;4BhB3LA/4B,GgB2LA+4B;4BhB3LA74L,GgB2LA64L;4BhB3LA94L,GgB2LA84L;4BhB3LA,uBAiBF52O;4BAjBE,uBAiBFA,IAjBEjF;mDAiBFiF,IAjBEwnC;mDAiBFxnC,IAjBE4nC;mDAiBF5nC,IAjBEoqC;4BgB2LAuD,OhB3LA,iBAiBF3tC,IAjBEmqC;;+BgB2LAwD,OhB3LA,mBAiBF3tC;0BgB0KE,6BhB1KFA,IgB0KE2tC;iCjJ7CN2hI,mBgJ4DI8ha,efzLApxkB,IgB0KE0tC,WAqE+C;;iCAD7C1tC;0BApEF,sCAoEEouI;uBAC6C;iChB/OjDpuI;0BgBsLM;;;8ChBtLNA;2BgBuLM,sBglBtNNo0iB,ehmB+BAp0iB;2BgBwLM,gChBxLNA;2BgByLM,2BhBzLNA;2BgB0LM,yBhB1LNA;2BgB2LM,gCJlMFksf,eZOJl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A;2BH/wBF,GEDAuqH;2BFCA,GEDAA;;;2BFCA;oDHoOA86d,cF9MAz+E,cKtBAluc;2BEDA;;;;oDFCAj2D,KG4JA45lB,oBH5JA1jiB;2BEDA;;gDLqOA0shB,cF9MAz+E,cOvBA/hX;;;gDLqOAwgc,cF9MAz+E,cOvBAnuS;;;gDLqOA4sX,cF9MAz+E,cOvBA/0Q;8DC6JAwqW,oBD7JAzqW;uBCyxBiD;iCHxxBjDh3O,QG+wBE5a;0BDhxBF;8BCgxBEA;2BDhxBF,GCgxBEA;2BDhxBF,GCgxBEA;2BDhxBF,KCgxBEA;2BDhxBF,KCgxBEA;2BH/wBF,GEDAuqH;2BFCA,GEDAA;2BCgxBE;;2BH/wBFrjE,MHoOAo+hB,eF9MAz+E,eKtBAjsf;2BEDAmqC,MC6JAu3iB,qBH5JA1hlB;2BEDAoqC,MLqOAsgiB,eF9MAz+E,eKtBAjsf,IEDAmqC;iCLqOAugiB,eF9MAz+E,eKtBAjsf,IEDAoqC;iCLqOAsgiB,eF9MAz+E,eKtBAjsf,IEDA4nC;iCC6JA85iB,qBH5JA1hlB,IEDAwnC,SCyxBiD;;iCHxxBjDxnC;0BG+wBE;;;2BH3wBE+6hB,OHgOJ4vC,eF7MEz+E,eKvBFlsf;2BAIyB2nlB,iBGwJzBhG,qBH5JA3hlB;2BEWI4nlB,YFPA7sD,OAAqB4sD;2BEQrBE,OLwNJld,eF7MEz+E,eKvBFlsf;2BEaI8nlB;4BLuNJnd,eF7MEz+E,eKvBFlsf;2BEgBI+nlB,kBLoNJpd,eF7MEz+E,eKvBFlsf;2BEiBIgolB,eC2IJrG,qBH5JA3hlB;;kCEWI4nlB;kCACAC;kCACAC;kCAGAC;kCACAC,eCuwB6C;;iCAT/C5hmB;0BAII;0BDpxBN,SCgxBEA,KDhxBF,2CCgxBEA;0BAII;2BDpxBN,cCgxBEA;2BDhxBF;;;;;;;;;;;;;;;;;;oCqBwgBE;sCrBxgBF;;;;;;;;;yFCgxBEA,ED5vBmE;iDApBrE47I;;;;;;;;;2CAcI;uEAdJw0H;;6CAcI;;uDLuNJo0U,cF7ME9+E,cOVE9qU;;;0CADA;sEAbJw1E;;4CAaI;;sDLwNJo0U,cF7ME9+E,cOXE5lU;;;yCAIA;qEAjBJswE;;2CAiBI;;qDLoNJo0U,cF7ME9+E,cOPE1lU;;;wCALA;oEAZJowE;;0CAYI,IFXJrwJ,KEWI;0CFXJ;+CEWI87B,OFXJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gHAKqE;mEALrED;;;;;;0DAIyB;oFAJzBF;;4DAIyB;;sEGwJzB8/c,oBHxJyB3ga;;;yDAArB;mFAJJn/C;;2DAII;;qEHgOJ8oc,cF7ME9+E,cKnBE5qU;;wDAJJ;;;;;gDEWIj/C;iDFXJ;;;oDEWIA,OFXJ;;;wDAII24Z;kDAJJ,MAIyB2tD;;;;;mDAArB1tD;mDEOA54Z,UFPA44Z,WAAqB2tD;;;;;mDEOrBvmd;oDFXJ;;;;gEAII24Z;mEAAqB2tD;;0CEOrBL;;uCAMA;mEAlBJ1xV;;yCAkBI;;mDC2IJorV,oBD3IIt7Z;;sCAlBJ;;;;uFCgxBElgM;4BDhxBF;8ECgxBEA;4BDhxBF;mCAYI8hmB;6BAZJ,MAaIC;6BAbJ,MAcIC;6BAdJ,MAiBIC;6BAjBJ,MAkBIC;;;;+BADAI;+BAHAC;+BADAC;+BADAC;;;sCACAD;sCACAD;sCAGAD;sCACAD;4BAlBJ;;qCCgxBErimB;;+CDpwBE8hmB;;gDACAC;;iDACAC;;kDAGAC;qDACAC;uBCuwB6C;iCAT/CljmB;0BDhxBF;0CCgxBEA;2BDhxBF,kBCgxBEA;2BDhxBF,mBCgxBEA;2BDhxBF,OCgxBEA;2BDhxBF,SCgxBEA;;2BD9vBEwlD,MC2IJq3iB,2BD3II+F;;2BADA1kgB,MLoNJunf,cF7ME9+E,cOPEg8F;+DACAj+c;2BAJAtmD,MLuNJqnf,cF7ME9+E,cOVE+7F;+DAGA/9c;2BAJApmD,MLwNJknf,cF7ME9+E,cOXE87F;+DACAlrc;2BFbJ,iBEWIirc;2BFXJ,OEWIA;2BFPqB9jgB,MGwJzBm+f,oBHxJyB0F;;2BAArBzjgB,MHgOJ2mf,cF7ME9+E,cKnBEgvC;+DAAqB93Z;2BEOrBl6I,OFPAm6I;2BEOAskD,kCACAD;oCADAC;uBC6wB6C;iCARzCjyE,IADNxsH;;;2BAEM8+P,MN7iBRkjV,qBM4iBQx1d;2BAGFqyI,MAvnBNs6V,+BAqnBQr6V;2BAGFF,MNhjBNojV,qBM+iBMnjV,MAJJ7+P;2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2BArgCA;;;;;;8BoUnqBAs3H;gD,O5UwFA3D,4BQ2kBAzoc;;;iDR3kBAyoc,cEwGOj0E,WMmePhkO;;0DR3kBAi4S,oBQ2kBAz0H;;;iDR3kBAy0H,cEiHOnqB,oBM0dP9oG;;;iDR3kBAizH,cRpFAx+Z,cgB+pBAsrS;;0DR3kBAkzH,oBQ2kBAnzH;;;iDR3kBAmzH,cQ2aEsrB,cAgKFoQ;2BAygBA;;;;;2CAzgBAxsX,QR3kBA8wV,cF1EAl9E,cUqpBAn2C;2BtC9qBF,GsCurCEV;2BtCvrCF;2BsCurCE;0DtCvrCF;2BsCurCE;;;;;;2BAxLA,KAwLAv+N;2BAxLA,KAwLAA;2BAxLA,KAwLAA;2BAxLA;;;;mCFzGSiuX;4B,OAvvBTpjB;0BAsvBE;gCE0GF7gd;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE;oDN9qBF6pc,cF9MAz+E,cQ43BE5pX;;;;yDAtvBFq/c,oBAsvBE5sI;;0DAtvBF4sI,oBAsvBE7sI;;;2BE0GF;;;;8BF1GE;2BA1cF,GEojBAlnI;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,KEojBAA;2BFpjBA;oDA5SA+zQ,6BA4SAxgd;;yDA5SAwgd,0BA4SA1jiB;;;gDNpOA0shB,cF9MAz+E,cQkbAnuS;;yDNpOA4sX,cE5BOx1E,WIgQPh+Q;;;;;;8BsUhcA41V;gD,O5U4NApC,4BMoOAzzV;;;gDNpOAyzV,mCMoOA1zV;+DNpOA0zV,mBMoOA3zV;2BEojBA;;;;oDFpjBAQ,ONpOAmzV,mBMoOA5zV;2BE4uBA;;;;;2CAxLA8+N,QFh2BA8rI,0BEg2BAltI;2BAwLA;;;0BAjqCA,UAiqCA/9N;;;2BAjqCA;iCAiqCAA;;6BAjqCA,mCVGAw1Q,cUHAzpX;0BF+3BE;2BE8xBF+0U;;uEA5fAH;0BpBlrCF,UoB8qDEzC;;;2BpB9qDF,SoB8qDEA;4BpB9qDF;kCoB8qDEA;;8BpB9qDF;;;kCoB8qDEA;mCpB9qDF;uDoB8qDE4C,cAE8D;;iC1ClrDhEt3c,I0CgrDE2uC;;;;2BA5fA,IA4fA66F;2BA5fA,IA4fAA;2BA5fA,IA4fAA;2BA5fA,IA4fAA;2BA5fA,GA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,KA4fAA;2BA5fA,e1CprCFxpI,I0CgrDE2uC,OA5fA06F;4C0kBrrCF8qa,epnBCAn0iB,I0CorCE6sC;2BAzgBA,KAygBA0oa;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA,KAygBAA;2BAzgBA;;4BoUnqBAu3H;;gC,O5UwFA3D;8BlChGFnpkB;8B0C2qBE4sC;;kCR3kBAu8hB,eEwGOj0E,SpCxMTl1f,I0C2qBEo0C;kCR3kBA+0hB,qBlChGFnpkB,I0C2qBE81C;kCR3kBAqzhB,eEiHOnqB,kBpCjNTh/iB,I0C2qBEk2C;kCR3kBAizhB,eRpFAx+Z,e1BZF3qK,I0C2qBEi2C;kCR3kBAkzhB,qBlChGFnpkB,I0C2qBEs2C;kCR3kBA6yhB,eQ2aEsrB,e1C3gBJz0lB,I0C2qBEs3C;2BAygBAF,ORplCA+xhB,eF1EAl9E,ehCtBFjsf,I0C2qBEq3C;2BtC9qBF,GsCurCE89Z;2BtCvrCF,GsCurCEA;2BtCvrCF,8BJGAn1c,I0CorCEo3C,OtCvrCF0G;2BJGA;4BIHAC;8BJGA;;2B0CorCE,uB1CprCF/9C,I0CorCEwnC;iD1CprCFxnC,I0CorCEutC;iD1CprCFvtC,I0CorCE2tC;kE1CprCF3tC,I0CorCE0tC;2BAxLA,KAwLAkpM;2BAxLA,KAwLAA;2BAxLA,KAwLAA;2BFtPA;;;mCA3CSmuX;4B,OAvvBTrjB;0BAsvBE;gCE0GF9gd;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GE,KE0GFA;2BF1GEpuF,ON9qBFk4hB,eF9MAz+E,ehCtBFjsf,I0C4/BEkuC,OF1GEk0F;8CxCl5BJpiI,IwCk5BIwyC;8CxCl5BJxyC,IwCk5BImqC;kCAtvBFu3iB,qBxC5JF1hlB,IwCk5BIssC;kCAtvBFo1iB,qBxC5JF1hlB,IwCk5BI+wC;kDxCl5BJ/wC,IwCk5BIyyC;kDxCl5BJzyC,IwCk5BIgtC;2BA1cF,GEojBA8na;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,GEojBAA;2BFpjBA,KEojBAA;2BFpjBA,KEojBAA;2BFpjBAvia,OA5SAmviB,8BxC5JF1hlB,I0C4/BE+sC,MFpjBAk0F;kCA5SAygd,2BxC5JF1hlB,IwCwcEuyC;kCNpOAm4hB,eF9MAz+E,ehCtBFjsf,IwCwcEsyC;kCNpOAo4hB,eE5BOx1E,SpCxMTl1f,IwCwcEqyC;;;4BsUhcAy6hB;;gC,O5U4NApC;8BlCpOF1qkB;8BwCwcE00C;;kCNpOAg2hB,oClCpOF1qkB,IwCwcEy0C;kCNpOAi2hB,oBlCpOF1qkB,IwCwcEw0C;2BEojBAF,ORxxBAo2hB,oBlCpOF1qkB,IwCwcEu0C;2BE4uBAF,OFxhCAqtiB,2BxC5JF1hlB,I0C4/BEs0C;2BAwLA,uB1CprCFt0C,I0CorCEq0C;kD1CprCFr0C,I0CorCEquC;0BA5hCA,OA4hCAooM;8CA5hCA,mB1CxJFz2O,I0CwJEouC;uCA4hCAD,OA5hCA,mB1CxJFnuC,I0CwJEouC;wCA4hCAD,OA5hCA,mB1CxJFnuC,I0CwJEouC;0BArIA,UAiqCAooM;2BAjqCA;4BA6pDA9nM;6BA5fA8nM;+BAjqCA,mB1CnBFx2O,I0CorCEmuC;+BAjqCA,mB1CnBFnuC,I0CorCEmuC;;2BAjqCA;iCAiqCAqoM;4BAjqCA,yB1CnBFx2O,I0CorCEmuC;4BA4fAO,OA7pDA,WVGAu9c,ehCtBFjsf,I0CmBE8sC;0BpBjBF,UoB8qDE0na;2BpB9qDF,0BtBFAx0c,I0CgrDE0uC;;4BpB9qDF,SoB8qDE8la;8BpB9qDF,SoB8qDEA,QpB9qDF,yBtBFAx0c,I0CgrDE0uC;8BpB9qDF,oCtBFA1uC,IsBEA4nC;qCoB8qDE4sa,QpB9qDF,yBtBFAx0c,I0CgrDE0uC;4BpB9qDF,sBtBFA1uC,IsBEAoqC,YoBgrDgE;;iC1ClrDhEpqC;0B0CqrCM;8C1CrrCNA;2B0CsrCM,sB0kBvrCNo0iB,epnBCAp0iB;2B0C2qBE;2BACI4tc;4BoUpqBJm/H;;gC,O5UwFA3D;8BlChGFppkB;;2B0C8qBMilmB,aR9kBJ77B,eEwGO/zE,MpCxMTr1f;2B0C+qBMsxkB,mBR/kBJlI,qBlChGFppkB;2B0CirBMy5kB,cRjlBJrQ,eEiHOnqB,epCjNTj/iB;2B0CkrBM2xkB,YRllBJvI,eRpFAx+Z,c1BZF5qK;2B0CmrBM84kB,eRnlBJ1P,qBlChGFppkB;2B0CqrBMm5kB,SRrlBJ/P,eQ2aEsrB,e1C3gBJ10lB;2B0CsrBMk5kB,aRtlBJ9P,eFzEEl9E,ehCvBJlsf;2B0CurCMwgmB;;6BA3gBA5yJ;6BAEAq3J;6BACA3zB;6BAEAmI;6BACA9H;6BACAmH;6BAEAK;6BACAD;2BtCvrBF,sCJCJl5kB;;;;;;2B0CwrCMugmB,oBtCzrCFzvF,YAAwBD;2BsC2rCtB,kC1C1rCN7wgB;2B0C2rCM,wB1C3rCNA;2B0C4rCM,yB1C5rCNA;2B0C6rCM,4C1C7rCNA;2BwC87BE;;;mCA3CS2qlB;4B,OAvvBThJ;0BAwwBM;2BADA8L;4BN/rBN9iB,eF7MEz+E,ehCvBJlsf;2BwCo6BQ,8BxCp6BRA;2BwCg7BQ,+BxCh7BRA;2BwCi7BQ2nlB,iBArxBNhG,qBxC5JF3hlB;2BwCk7BQstlB;4BAtxBN3L,qBxC5JF3hlB;2BwCm7BQ,mCxCn7BRA;2BwCo7BQ,gCxCp7BRA;2BwCo7BQ;;6BAjBAytlB;6BACAD;6BAYAD;6BACA5F;6BACA2F;6BACAD;6BACAD;2BA3eFrU,UA7SJ4I,8BxC5JF3hlB;2BwC0cMizjB,QA9SJ0uB,2BxC5JF3hlB;2BwC2cMg5kB;4BNvOJrO,eF7MEz+E,ehCvBJlsf;2BwC4cMi5kB,WNxOJtO,eE5BOt1E,MpCxMTr1f;;2BwC6cMkjT;4BsUrcJ6pR;;gC,O5U4NApC;8BlCpOF3qkB;;2BwC8cMwxkB;4BN1OJ7G,oClC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;;;oCACIjsC,cADJ,MAC6BisC;;6DAAzBhsC;iDAAyBytC;0BAD7B;;;;6CACI1tC;gDAAyBisC,sCACiC;;;0BAF9D;0BpB9qDF,UoB+qD+BF;;;2BpB/qD/B,SoB+qD+BA;4BpB9qD7B;gCoB8qD6BA;6BpB9qD7B;6BoB8qD6Bn8mB,mBpB9qD7B4uD;;4BACA;kCoB6qD6ButjB;6BpB7qD7B;6BoB6qD6Bn8mB,mBpB7qD7B85I;0BoB4qDA;2BAC6BK,kCAD7BD;2BACI;+DAAyBC;0BAAzB,iBAC0D;;iCAF9D+pV;;;2BA5fA50L,kBNv8BA49N,eMm8CAhpC;2BArgCAp1L,kB0kB5qBF48Q,e1kBqrCEp8Q;;;2BAzgBAzvC;;8BoUnqBA5d;uCpUqqBMz1H;gC,OR7kBNi0d,qCQ6kBMj0d;8BAFNsiL;;kCR3kBA2xS,eE6IAvzE,eM8bArtQ;kCR3kBA4gV,e2lBnFA+C,enlB8pBA1jV;kCR3kBA2gV,eToRF5nB,eiBuTE94T;kCR3kBA0gV,ekBzEEt+Z,eVopBF69E;kCR3kBAygV,ekBzEEt+Z,eVopBF89E;kCR3kBAwgV,eQ2aEqrB,eAgKF58T;2BAygBAE,ORplCAqxS,qBQ2kBAtxS;;2B1C3qBF3iL,+B0CorCE4iL;;;8B1CprCsC,2BAAxC5iL;8BAAoC,2BAApCA;2B0CorCEuiL;kCAjGE2jU,eAiGF3jU;kCAjGE2jU,eAiGF1jU;2BFrPIJ,wCEqPJK;;;mCFlSEgvU,iBA8CEzxf;4B,OApyBJ2se,4BAoyBI3se;;2BA9CFmzI,ON9qBFqiV,qBM2tBIpzS;2BA7CFvvC;2BAgDEC,OAhDF2+W;2BA+CEx+W,OAryBJ05V,+BAsyBI75V;2BAhDFI,OAtvBFy5V,4BAqyBI15V;2BA/CFF;2BE0GFC,OF1GEwgW;;2BA1cFnhW,MA5SAs6V,+BEg2BA35V;2BFpjBAV,MA5SAq6V,4BA4SAt6V;iCNpOAmjV,qBMoOAljV;iCNpOAkjV,eESA90E,eI2NAnuQ;;;;8BsUhcA9c;uCtUqcYz1H;gC,ONzOZw1d,qCMyOYx1d;8BALZwyI;;iCNpOAgjV,qCMoOA/iV;iCNpOA+iV,6BMoOA9iV;2BEojBAE,ORxxB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7E,qCACIxxf;;yCAAFA;;8BADFmyI;;yDAqVAnyI;uBA7BA;;uBA8CM;;;;;;;;;uCH+jCDmyf;;;;;mC,OGr6CmDkF;4CHm3CnDtI,gBvJrhDXh0b;;;;uB0JwgBY;uBAS+C;wC,UAT/C0gc;uBAS+C;;0BAT/C;;;;2BH+jCN,KG/jCMlwe;2BH+jCN,KG/jCMA;2BH2nBJ,GAocFnxB;2BApcE,GAocFA;2BApcE,GAocFA;2BApcE,GAocFA;2BApcE;;;;;gDvJnoCR0/D,8BuJmoCQwuC;2BAocF;;;;8BApcE;2BG3nBI;;;;8BH+jCN;;4B,OGhuDE0sZ;qCA2TIhG;0BAsWA;;;;;8B1JxgBZj2b;;kC,OwJ9JIu6b;gCEsqBQ53U;;kFAS+C;;iCAT/CjxR;;;;;2BH+jCN,KG/jCM8gI;2BH+jCN,KG/jCMA;2BH2nBJ,GAocFnxB;2BApcE,GAocFA;2BApcE,GAocFA;2BApcE,GAocFA;2BApcE,aG3nBI3vG,UH2nBJ89C;2DG3nBI99C,IH2nBJjF;iCvJnoCRu0K,+B0JwgBYtvK,IH2nBJwnC;2BAocFI,6BG/jCM5nC,IH2nBJssC;2BG3nBIlC,MxBrpBRkmgB,ewBqpBQtwiB,IH+jCN4nC;;4B,OGhuDE6ikB;qCA2TI3F;;;;;;;2BAsWA93jB;4B1JxgBZuhI;;gC,OwJ9JIw6b;;8BEsqBQ/omB;;;uEAS+C;;iCAT/CA;2EAS+C;;iCAT/CA;0BH4nBA;8CG5nBAA;2BH6nBA,gCG7nBAA;2BH8nBAkzjB,cvJtoCZ3jZ,8B0JwgBYvvK;2BHgoBA,+BGhoBAA;2BHgoBA,UAJAu9f,aACAw1D,MACAG,cAEAD;2BAicF,+BGjkCEjzjB;2BHikCF,eADAg5jB,OACAksC;;4B,OGluDFyF;qCA2TI3F;0BA6WI;2BALAoL;4B1J1gBhB5hc;;gC,OwJ9JIy6b;8BEsqBQjpmB;;2BAOI,8BAPJA;0BAOI,UANAqwmB,YACAD,kBAKAj9C,OAE2C;uBAT/C;wCAAK89C;sB4R5lBG;uB5RypBNM;wBAfF;mCAIWC;2CAHEC;8BACT;oCAEOzF,eADIC;8DACJD;;;;qDHq/BjB1E,uBGr/BiBkK;qC3JvkBjB9uc;uC2Jo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DAAgC;sCAAhC;wC6B8DwC;0BAAlD;;;;+C7B9DFu7T,mB6BYSrwY;2BAkDFM,iBAALspG;;4B7B9DF,c6B8DEp9Q;;+B7B9DUwR,K6B8DVxR;+B7B9DiC24D,GAAvBnnD;+BAAuBknD,GAAvBlnD;+BAAuB/O,6B6BY/BsxK,W7BZ+Br7G;+BAAvBw+G,gCAAuBz0K,K6BY/BsxK,W7BZ+Bp7G;2DAAvBu+G;uC6B8DVl3K,K7B9DUuxnB,Y6BYRx9c,W7BZQl/D;;mC6B8DVmgE;4B7B9DF,c6B8DEh1K;;+B7B9DUwR,K6B8DVxR;+B7B9DU2V,IsDyXZkzI,sBzB3TEjuI;+B7B9DiC+9C,GAAvBnnD;+BAAuBknD,GAAvBlnD;+BAAuB4wC,M6BY/B4xH,YAkDFp5J,I7B9DUjF,IAAuB+iD;qC6BY/Bs7G,YAkDFp5J,I7B9DiCwnC;;6BAAvByyD,O6B8DV70G;6B7B9DUwiD,MsDyXZqmG,sBzB3TEjuI;mCAlDEo5J,YAkDFp5J,I7B9DU4nC,a6B+DqC;8BAD/CyyH;gDAA4Br6J;4B,O7B9D9BkpiB,e6BYI1vY,aAkD0Bx5J;mCAA5Bu6J;4B,O7B9DF4uY,e6BYI3vY,aAkDFx5J,YAC+C;;2BAD/Cw6J;sCAAKtB,cAALmB;;;4B,gB7B9DFl0D;;gE6BYI05D,U7BZJ15D;;;;;oDAC+C;qC6B6D7C//G;;4B7B9DF,c6B8DEhB;;+B7B9DUI,G6B8DVJ;+B7B9DiC04D,GAAvBt4D;+BAAuBmyD,KAAvBnyD;+BAAuBo9I,K6BY/B1uB,U7BZ+Bv8D;oC6BY/Bu8D,U7BZ+Bp2D;;gCAAvB+kF,K6B8DVz9I;kDAlDE8uH,U7BZQ2uB;mC6B8DVtoC;4BAA4B,S7B9D9BsqC,M6B8DWK,wCAAkB;4B7B9D7B,G6B8DE0xe,gB7B9DF;0C6B8DEA;;gC7B9DiC;iCAAnCv4c,U6B8DEp5B;iC7B9DFq5B,S6B8DEs4c;iC7B9DiC5oI,MAAnC1vU;iCAAmC2vU,MAAnC3vU;iCAAmC4vU,MAAnC7vU;iCAAmC8vU,MAAnC9vU;iCAAmC;+CAAK,MAAL2vU;;uC6B8DjC/oW;mC7B9DF6oW,U6B8DE7oW,S7B9DF8oW,S6B8DE6oI;sC7B9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;+BADzBxpB;yDiDkgBiD;0BAJ/C;;;;;;;;gCjD9f2B68S;;;;;2BiD8ftB0hH,kBAALD;;4BjD9fF;gCiD8fEp9nB;6BjD9fF,GiD8fEA;6BjD9fF,GiD8fEA;;;;6BjD9fF;;;;;gC9G8HNkpL;;;qC8G7HqBvwH;;;;wEiDmEb4tH,cjDnEa5tH;kCADfD;;sEiDoEE6tH,cjDpEF5tH;;uDA7BAkhd,0BA6BAphT;mCiD8fEt9C;4BjD9fF;gCiD8fEn7K;6BjD9fF,GiD8fEA;6BjD9fF,GiD8fEA;;;;6BjD9fFwiD;8B9G8HN2mI;yC8G7HoBvuK;;mCAAC+9C;;0DAAD/9C,QAAC89C;oDiDmEb8tH,ejDnEY5rK,IAACwnC;gCiD6fbxnC;;gCjD9fF89C;4CiDoEE8tH,eA0bA5rK,IjD9fF4nC;mCA7BAw3d,2BiD2hBEp/f,IjD9fFjF,OiDmgB8B;8BAL5B2nnB;iDAIE1inB;4BjDlgBJ,sCiDkgBIouI;mCAJFu0e;;;;;6BjD7fEnhH;8B9G6HVhzV;yC8G7HUxuK;;mCAAW89C,oBAAX99C;mCAAW+9C,ciDmEb8tH,cjDnEE7rK;4CAAW89C;gCiD6fb99C;;6BjD5fE,mBiDkEF6rK,cA0bA7rK;6BjD3fEshgB,OAhCJ/B,2BiD2hBEv/f;sCjD7fEwhgB,UACAD,QACAD,OiDggB0B;;2BAL5BshH;uCAAKH,eAALC;;;;;;;;4BjD9fF,SiD8fEt8nB,KjD9fF,2CiD8fEA;4BjD9fF;yCiD8fEA;6BjD9fF;;;;;;;;;;;;;;;;sC2D0eE;wC3D1eF;;;;;;;;;2FiD8fEA,EjDzfuB;mDALzB47I;;;;;;;2CAGI;qEAHJF;;6CAGI;;gEAhCJ89X,0BAgCI3+U;;;0CAFA;oEADJn/C;;4CACI;;;8C8DscJ36B;yD9DtcehB;kDAAD,SAACA;;;;;;;;;;;kFADf/qD,aACe+qD,KAAgB;gDAA3B+6E;;;yCACA;mEAFJp/C;;2CAEI;;;;wCAFJ;;;;uFiD8fE17I;8BjD9fF;8EiD8fEA;8BjD9fF;qCACI46gB;+BADJ,MAEIC;+BAFJ,MAGIC;;;;iCADAE;iCADAC;wDACAD,YACAD;8BAHJ;;uCiD8fE/6gB;;iD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","sourcesContent":[null,"//\n// strftime\n// github.com/samsonjs/strftime\n// @_sjs\n//\n// Copyright 2010 - 2015 Sami Samhuri \n//\n// MIT License\n// http://sjs.mit-license.org\n//\n\n;(function() {\n\n var DefaultLocale = {\n days: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'],\n shortDays: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n months: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],\n shortMonths: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n AM: 'AM',\n PM: 'PM',\n am: 'am',\n pm: 'pm',\n formats: {\n D: '%m/%d/%y',\n F: '%Y-%m-%d',\n R: '%H:%M',\n T: '%H:%M:%S',\n X: '%T',\n c: '%a %b %d %X %Y',\n r: '%I:%M:%S %p',\n v: '%e-%b-%Y',\n x: '%D'\n }\n },\n defaultStrftime = new Strftime(DefaultLocale, 0, false),\n isCommonJS = typeof module !== 'undefined',\n namespace;\n\n // CommonJS / Node module\n if (isCommonJS) {\n namespace = module.exports = adaptedStrftime;\n namespace.strftime = deprecatedStrftime;\n if(joo_global_object) joo_global_object.strftime = adaptedStrftime;\n }\n // Browsers and other environments\n else {\n // Get the global object. Works in ES3, ES5, and ES5 strict mode.\n namespace = joo_global_object || (function() { return this || (1,eval)('this'); }());\n namespace.strftime = adaptedStrftime;\n }\n\n // Deprecated API, to be removed in v1.0\n var _require = isCommonJS ? \"require('strftime')\" : \"strftime\";\n var _deprecationWarnings = {};\n function deprecationWarning(name, instead) {\n if (!_deprecationWarnings[name]) {\n if (typeof console !== 'undefined' && typeof console.warn == 'function') {\n console.warn(\"[WARNING] \" + name + \" is deprecated and will be removed in version 1.0. Instead, use `\" + instead + \"`.\");\n }\n _deprecationWarnings[name] = true;\n }\n }\n\n namespace.strftimeTZ = deprecatedStrftimeTZ;\n namespace.strftimeUTC = deprecatedStrftimeUTC;\n namespace.localizedStrftime = deprecatedStrftimeLocalized;\n\n // Adapt the old API while preserving the new API.\n function adaptForwards(fn) {\n fn.localize = defaultStrftime.localize.bind(defaultStrftime);\n fn.timezone = defaultStrftime.timezone.bind(defaultStrftime);\n fn.utc = defaultStrftime.utc.bind(defaultStrftime);\n }\n\n adaptForwards(adaptedStrftime);\n function adaptedStrftime(fmt, d, locale) {\n // d and locale are optional, check if this is (format, locale)\n if (d && d.days) {\n locale = d;\n d = undefined;\n }\n if (locale) {\n deprecationWarning(\"`\" + _require + \"(format, [date], [locale])`\", \"var s = \" + _require + \".localize(locale); s(format, [date])\");\n }\n var strftime = locale ? defaultStrftime.localize(locale) : defaultStrftime;\n return strftime(fmt, d);\n }\n\n adaptForwards(deprecatedStrftime);\n function deprecatedStrftime(fmt, d, locale) {\n if (locale) {\n deprecationWarning(\"`\" + _require + \".strftime(format, [date], [locale])`\", \"var s = \" + _require + \".localize(locale); s(format, [date])\");\n }\n else {\n deprecationWarning(\"`\" + _require + \".strftime(format, [date])`\", _require + \"(format, [date])\");\n }\n var strftime = locale ? defaultStrftime.localize(locale) : defaultStrftime;\n return strftime(fmt, d);\n }\n\n function deprecatedStrftimeTZ(fmt, d, locale, timezone) {\n // locale is optional, check if this is (format, date, timezone)\n if ((typeof locale == 'number' || typeof locale == 'string') && timezone == null) {\n timezone = locale;\n locale = undefined;\n }\n\n if (locale) {\n deprecationWarning(\"`\" + _require + \".strftimeTZ(format, date, locale, tz)`\", \"var s = \" + _require + \".localize(locale).timezone(tz); s(format, [date])` or `var s = \" + _require + \".localize(locale); s.timezone(tz)(format, [date])\");\n }\n else {\n deprecationWarning(\"`\" + _require + \".strftimeTZ(format, date, tz)`\", \"var s = \" + _require + \".timezone(tz); s(format, [date])` or `\" + _require + \".timezone(tz)(format, [date])\");\n }\n\n var strftime = (locale ? defaultStrftime.localize(locale) : defaultStrftime).timezone(timezone);\n return strftime(fmt, d);\n }\n\n var utcStrftime = defaultStrftime.utc();\n function deprecatedStrftimeUTC(fmt, d, locale) {\n if (locale) {\n deprecationWarning(\"`\" + _require + \".strftimeUTC(format, date, locale)`\", \"var s = \" + _require + \".localize(locale).utc(); s(format, [date])\");\n }\n else {\n deprecationWarning(\"`\" + _require + \".strftimeUTC(format, [date])`\", \"var s = \" + _require + \".utc(); s(format, [date])\");\n }\n var strftime = locale ? utcStrftime.localize(locale) : utcStrftime;\n return strftime(fmt, d);\n }\n\n function deprecatedStrftimeLocalized(locale) {\n deprecationWarning(\"`\" + _require + \".localizedStrftime(locale)`\", _require + \".localize(locale)\");\n return defaultStrftime.localize(locale);\n }\n // End of deprecated API\n\n // Polyfill Date.now for old browsers.\n if (typeof Date.now !== 'function') {\n Date.now = function() {\n return +new Date();\n };\n }\n\n function Strftime(locale, customTimezoneOffset, useUtcTimezone) {\n var _locale = locale || DefaultLocale,\n _customTimezoneOffset = customTimezoneOffset || 0,\n _useUtcBasedDate = useUtcTimezone || false,\n\n // we store unix timestamp value here to not create new Date() each iteration (each millisecond)\n // Date.now() is 2 times faster than new Date()\n // while millisecond precise is enough here\n // this could be very helpful when strftime triggered a lot of times one by one\n _cachedDateTimestamp = 0,\n _cachedDate;\n\n function _strftime(format, date) {\n var timestamp;\n\n if (!date) {\n var currentTimestamp = Date.now();\n if (currentTimestamp > _cachedDateTimestamp) {\n _cachedDateTimestamp = currentTimestamp;\n _cachedDate = new Date(_cachedDateTimestamp);\n\n timestamp = _cachedDateTimestamp;\n\n if (_useUtcBasedDate) {\n // how to avoid duplication of date instantiation for utc here?\n // we tied to getTimezoneOffset of the current date\n _cachedDate = new Date(_cachedDateTimestamp + getTimestampToUtcOffsetFor(_cachedDate) + _customTimezoneOffset);\n }\n }\n date = _cachedDate;\n }\n else {\n timestamp = date.getTime();\n\n if (_useUtcBasedDate) {\n date = new Date(date.getTime() + getTimestampToUtcOffsetFor(date) + _customTimezoneOffset);\n }\n }\n\n return _processFormat(format, date, _locale, timestamp);\n }\n\n function _processFormat(format, date, locale, timestamp) {\n var resultString = '',\n padding = null,\n isInScope = false,\n length = format.length,\n extendedTZ = false;\n\n for (var i = 0; i < length; i++) {\n\n var currentCharCode = format.charCodeAt(i);\n\n if (isInScope === true) {\n // '-'\n if (currentCharCode === 45) {\n padding = '';\n continue;\n }\n // '_'\n else if (currentCharCode === 95) {\n padding = ' ';\n continue;\n }\n // '0'\n else if (currentCharCode === 48) {\n padding = '0';\n continue;\n }\n // ':'\n else if (currentCharCode === 58) {\n if (extendedTZ) {\n if (typeof console !== 'undefined' && typeof console.warn == 'function') {\n console.warn(\"[WARNING] detected use of unsupported %:: or %::: modifiers to strftime\");\n }\n }\n extendedTZ = true;\n continue;\n }\n\n switch (currentCharCode) {\n\n // Examples for new Date(0) in GMT\n\n // 'Thursday'\n // case 'A':\n case 65:\n resultString += locale.days[date.getDay()];\n break;\n\n // 'January'\n // case 'B':\n case 66:\n resultString += locale.months[date.getMonth()];\n break;\n\n // '19'\n // case 'C':\n case 67:\n resultString += padTill2(Math.floor(date.getFullYear() / 100), padding);\n break;\n\n // '01/01/70'\n // case 'D':\n case 68:\n resultString += _processFormat(locale.formats.D, date, locale, timestamp);\n break;\n\n // '1970-01-01'\n // case 'F':\n case 70:\n resultString += _processFormat(locale.formats.F, date, locale, timestamp);\n break;\n\n // '00'\n // case 'H':\n case 72:\n resultString += padTill2(date.getHours(), padding);\n break;\n\n // '12'\n // case 'I':\n case 73:\n resultString += padTill2(hours12(date.getHours()), padding);\n break;\n\n // '000'\n // case 'L':\n case 76:\n resultString += padTill3(Math.floor(timestamp % 1000));\n break;\n\n // '00'\n // case 'M':\n case 77:\n resultString += padTill2(date.getMinutes(), padding);\n break;\n\n // 'am'\n // case 'P':\n case 80:\n resultString += date.getHours() < 12 ? locale.am : locale.pm;\n break;\n\n // '00:00'\n // case 'R':\n case 82:\n resultString += _processFormat(locale.formats.R, date, locale, timestamp);\n break;\n\n // '00'\n // case 'S':\n case 83:\n resultString += padTill2(date.getSeconds(), padding);\n break;\n\n // '00:00:00'\n // case 'T':\n case 84:\n resultString += _processFormat(locale.formats.T, date, locale, timestamp);\n break;\n\n // '00'\n // case 'U':\n case 85:\n resultString += padTill2(weekNumber(date, 'sunday'), padding);\n break;\n\n // '00'\n // case 'W':\n case 87:\n resultString += padTill2(weekNumber(date, 'monday'), padding);\n break;\n\n // '16:00:00'\n // case 'X':\n case 88:\n resultString += _processFormat(locale.formats.X, date, locale, timestamp);\n break;\n\n // '1970'\n // case 'Y':\n case 89:\n resultString += date.getFullYear();\n break;\n\n // 'GMT'\n // case 'Z':\n case 90:\n if (_useUtcBasedDate && _customTimezoneOffset === 0) {\n resultString += \"GMT\";\n }\n else {\n // fixme optimize\n var tzString = date.toString().match(/\\(([\\w\\s]+)\\)/);\n resultString += tzString && tzString[1] || '';\n }\n break;\n\n // 'Thu'\n // case 'a':\n case 97:\n resultString += locale.shortDays[date.getDay()];\n break;\n\n // 'Jan'\n // case 'b':\n case 98:\n resultString += locale.shortMonths[date.getMonth()];\n break;\n\n // ''\n // case 'c':\n case 99:\n resultString += _processFormat(locale.formats.c, date, locale, timestamp);\n break;\n\n // '01'\n // case 'd':\n case 100:\n resultString += padTill2(date.getDate(), padding);\n break;\n\n // ' 1'\n // case 'e':\n case 101:\n resultString += padTill2(date.getDate(), padding == null ? ' ' : padding);\n break;\n\n // 'Jan'\n // case 'h':\n case 104:\n resultString += locale.shortMonths[date.getMonth()];\n break;\n\n // '000'\n // case 'j':\n case 106:\n var y = new Date(date.getFullYear(), 0, 1);\n var day = Math.ceil((date.getTime() - y.getTime()) / (1000 * 60 * 60 * 24));\n resultString += padTill3(day);\n break;\n\n // ' 0'\n // case 'k':\n case 107:\n resultString += padTill2(date.getHours(), padding == null ? ' ' : padding);\n break;\n\n // '12'\n // case 'l':\n case 108:\n resultString += padTill2(hours12(date.getHours()), padding == null ? ' ' : padding);\n break;\n\n // '01'\n // case 'm':\n case 109:\n resultString += padTill2(date.getMonth() + 1, padding);\n break;\n\n // '\\n'\n // case 'n':\n case 110:\n resultString += '\\n';\n break;\n\n // '1st'\n // case 'o':\n case 111:\n resultString += String(date.getDate()) + ordinal(date.getDate());\n break;\n\n // 'AM'\n // case 'p':\n case 112:\n resultString += date.getHours() < 12 ? locale.AM : locale.PM;\n break;\n\n // '12:00:00 AM'\n // case 'r':\n case 114:\n resultString += _processFormat(locale.formats.r, date, locale, timestamp);\n break;\n\n // '0'\n // case 's':\n case 115:\n resultString += Math.floor(timestamp / 1000);\n break;\n\n // '\\t'\n // case 't':\n case 116:\n resultString += '\\t';\n break;\n\n // '4'\n // case 'u':\n case 117:\n var day = date.getDay();\n resultString += day === 0 ? 7 : day;\n break; // 1 - 7, Monday is first day of the week\n\n // ' 1-Jan-1970'\n // case 'v':\n case 118:\n resultString += _processFormat(locale.formats.v, date, locale, timestamp);\n break;\n\n // '4'\n // case 'w':\n case 119:\n resultString += date.getDay();\n break; // 0 - 6, Sunday is first day of the week\n\n // '12/31/69'\n // case 'x':\n case 120:\n resultString += _processFormat(locale.formats.x, date, locale, timestamp);\n break;\n\n // '70'\n // case 'y':\n case 121:\n resultString += ('' + date.getFullYear()).slice(2);\n break;\n\n // '+0000'\n // case 'z':\n case 122:\n if (_useUtcBasedDate && _customTimezoneOffset === 0) {\n resultString += extendedTZ ? \"+00:00\" : \"+0000\";\n }\n else {\n var off;\n if (_customTimezoneOffset !== 0) {\n off = _customTimezoneOffset / (60 * 1000);\n }\n else {\n off = -date.getTimezoneOffset();\n }\n var sign = off < 0 ? '-' : '+';\n var sep = extendedTZ ? ':' : '';\n var hours = Math.floor(Math.abs(off / 60));\n var mins = Math.abs(off % 60);\n resultString += sign + padTill2(hours) + sep + padTill2(mins);\n }\n break;\n\n default:\n resultString += format[i];\n break;\n }\n\n padding = null;\n isInScope = false;\n continue;\n }\n\n // '%'\n if (currentCharCode === 37) {\n isInScope = true;\n continue;\n }\n\n resultString += format[i];\n }\n\n return resultString;\n }\n\n var strftime = _strftime;\n\n strftime.localize = function(locale) {\n return new Strftime(locale || _locale, _customTimezoneOffset, _useUtcBasedDate);\n };\n\n strftime.timezone = function(timezone) {\n var customTimezoneOffset = _customTimezoneOffset;\n var useUtcBasedDate = _useUtcBasedDate;\n\n var timezoneType = typeof timezone;\n if (timezoneType === 'number' || timezoneType === 'string') {\n useUtcBasedDate = true;\n\n // ISO 8601 format timezone string, [-+]HHMM\n if (timezoneType === 'string') {\n var sign = timezone[0] === '-' ? -1 : 1,\n hours = parseInt(timezone.slice(1, 3), 10),\n minutes = parseInt(timezone.slice(3, 5), 10);\n\n customTimezoneOffset = sign * ((60 * hours) + minutes) * 60 * 1000;\n // in minutes: 420\n }\n else if (timezoneType === 'number') {\n customTimezoneOffset = timezone * 60 * 1000;\n }\n }\n\n return new Strftime(_locale, customTimezoneOffset, useUtcBasedDate);\n };\n\n strftime.utc = function() {\n return new Strftime(_locale, _customTimezoneOffset, true);\n };\n\n return strftime;\n }\n\n function padTill2(numberToPad, paddingChar) {\n if (paddingChar === '' || numberToPad > 9) {\n return numberToPad;\n }\n if (paddingChar == null) {\n paddingChar = '0';\n }\n return paddingChar + numberToPad;\n }\n\n function padTill3(numberToPad) {\n if (numberToPad > 99) {\n return numberToPad;\n }\n if (numberToPad > 9) {\n return '0' + numberToPad;\n }\n return '00' + numberToPad;\n }\n\n function hours12(hour) {\n if (hour === 0) {\n return 12;\n }\n else if (hour > 12) {\n return hour - 12;\n }\n return hour;\n }\n\n // firstWeekday: 'sunday' or 'monday', default is 'sunday'\n //\n // Pilfered & ported from Ruby's strftime implementation.\n function weekNumber(date, firstWeekday) {\n firstWeekday = firstWeekday || 'sunday';\n\n // This works by shifting the weekday back by one day if we\n // are treating Monday as the first day of the week.\n var weekday = date.getDay();\n if (firstWeekday === 'monday') {\n if (weekday === 0) // Sunday\n weekday = 6;\n else\n weekday--;\n }\n\n var firstDayOfYearUtc = Date.UTC(date.getFullYear(), 0, 1),\n dateUtc = Date.UTC(date.getFullYear(), date.getMonth(), date.getDate()),\n yday = Math.floor((dateUtc - firstDayOfYearUtc) / 86400000),\n weekNum = (yday + 7 - weekday) / 7;\n\n return Math.floor(weekNum);\n }\n\n // Get the ordinal suffix for a number: st, nd, rd, or th\n function ordinal(number) {\n var i = number % 10;\n var ii = number % 100;\n\n if ((ii >= 11 && ii <= 13) || i === 0 || i >= 4) {\n return 'th';\n }\n switch (i) {\n case 1: return 'st';\n case 2: return 'nd';\n case 3: return 'rd';\n }\n }\n\n function getTimestampToUtcOffsetFor(date) {\n return (date.getTimezoneOffset() || 0) * 60000;\n }\n\n}());\n","//Provides: Base_int_math_int_popcount const\nfunction Base_int_math_int_popcount(v) {\n v = v - ((v >>> 1) & 0x55555555);\n v = (v & 0x33333333) + ((v >>> 2) & 0x33333333);\n return ((v + (v >>> 4) & 0xF0F0F0F) * 0x1010101) >>> 24;\n}\n\n//Provides: Base_clear_caml_backtrace_pos const\nfunction Base_clear_caml_backtrace_pos(x) {\n return 0;\n}\n\n//Provides: Base_int_math_int32_clz const\nfunction Base_int_math_int32_clz(x) {\n var n = 32;\n var y;\n y = x >>16; if (y != 0) { n = n -16; x = y; }\n y = x >> 8; if (y != 0) { n = n - 8; x = y; }\n y = x >> 4; if (y != 0) { n = n - 4; x = y; }\n y = x >> 2; if (y != 0) { n = n - 2; x = y; }\n y = x >> 1; if (y != 0) return n - 2;\n return n - x;\n}\n\n//Provides: Base_int_math_int_clz const\n//Requires: Base_int_math_int32_clz\nfunction Base_int_math_int_clz(x) { return Base_int_math_int32_clz(x); }\n\n//Provides: Base_int_math_nativeint_clz const\n//Requires: Base_int_math_int32_clz\nfunction Base_int_math_nativeint_clz(x) { return Base_int_math_int32_clz(x); }\n\n//Provides: Base_int_math_int64_clz const\n//Requires: caml_int64_shift_right_unsigned, caml_int64_is_zero, caml_int64_to_int32\nfunction Base_int_math_int64_clz(x) {\n var n = 64;\n var y;\n y = caml_int64_shift_right_unsigned(x, 32);\n if (!caml_int64_is_zero(y)) { n = n -32; x = y; }\n y = caml_int64_shift_right_unsigned(x, 16);\n if (!caml_int64_is_zero(y)) { n = n -16; x = y; }\n y = caml_int64_shift_right_unsigned(x, 8);\n if (!caml_int64_is_zero(y)) { n = n - 8; x = y; }\n y = caml_int64_shift_right_unsigned(x, 4);\n if (!caml_int64_is_zero(y)) { n = n - 4; x = y; }\n y = caml_int64_shift_right_unsigned(x, 2);\n if (!caml_int64_is_zero(y)) { n = n - 2; x = y; }\n y = caml_int64_shift_right_unsigned(x, 1);\n if (!caml_int64_is_zero(y)) return n - 2;\n return n - caml_int64_to_int32(x);\n}\n\n//Provides: Base_int_math_int32_ctz const\nfunction Base_int_math_int32_ctz(x) {\n if (x === 0) { return 32; }\n var n = 1;\n if ( (x & 0x0000FFFF) === 0) { n = n + 16; x = x >> 16; }\n if ( (x & 0x000000FF) === 0) { n = n + 8; x = x >> 8; }\n if ( (x & 0x0000000F) === 0) { n = n + 4; x = x >> 4; }\n if ( (x & 0x00000003) === 0) { n = n + 2; x = x >> 2; }\n return n - (x & 1);\n}\n\n//Provides: Base_int_math_int_ctz const\n//Requires: Base_int_math_int32_ctz\nfunction Base_int_math_int_ctz(x) { return Base_int_math_int32_ctz(x); }\n\n//Provides: Base_int_math_nativeint_ctz const\n//Requires: Base_int_math_int32_ctz\nfunction Base_int_math_nativeint_ctz(x) { return Base_int_math_int32_ctz(x); }\n\n//Provides: Base_int_math_int64_ctz const\n//Requires: caml_int64_shift_right_unsigned, caml_int64_is_zero, caml_int64_to_int32\n//Requires: caml_int64_and, caml_int64_of_int32, caml_int64_create_lo_mi_hi\nfunction Base_int_math_int64_ctz(x) {\n if (caml_int64_is_zero(x)) { return 64; }\n var n = 1;\n function is_zero (x) { return caml_int64_is_zero(x); }\n function land (x,y) { return caml_int64_and(x, y); }\n function small_int64(x) { return caml_int64_create_lo_mi_hi(x,0,0); }\n if (is_zero(land(x, caml_int64_create_lo_mi_hi(0xFFFFFF, 0x0000FF, 0x0000)))) {\n n = n + 32; x = caml_int64_shift_right_unsigned(x, 32);\n }\n if (is_zero(land(x, small_int64(0x00FFFF)))) {\n n = n + 16; x = caml_int64_shift_right_unsigned(x, 16);\n }\n if (is_zero(land(x, small_int64(0x0000FF)))) {\n n = n + 8; x = caml_int64_shift_right_unsigned(x, 8);\n }\n if (is_zero(land(x, small_int64(0x00000F)))) {\n n = n + 4; x = caml_int64_shift_right_unsigned(x, 4);\n }\n if (is_zero(land(x, small_int64(0x000003)))) {\n n = n + 2; x = caml_int64_shift_right_unsigned(x, 2);\n }\n return n - (caml_int64_to_int32(caml_int64_and(x, small_int64(0x000001))));\n}\n\n//Provides: Base_int_math_int_pow_stub const\nfunction Base_int_math_int_pow_stub(base, exponent) {\n var one = 1;\n var mul = [one, base, one, one];\n var res = one;\n while (!exponent==0) {\n mul[1] = (mul[1] * mul[3]) | 0;\n mul[2] = (mul[1] * mul[1]) | 0;\n mul[3] = (mul[2] * mul[1]) | 0;\n res = (res * mul[exponent & 3]) | 0;\n exponent = exponent >> 2;\n }\n return res;\n}\n\n//Provides: Base_int_math_int64_pow_stub const\n//Requires: caml_int64_mul, caml_int64_is_zero, caml_int64_shift_right_unsigned\n//Requires: caml_int64_create_lo_hi, caml_int64_lo32\nfunction Base_int_math_int64_pow_stub(base, exponent) {\n var one = caml_int64_create_lo_hi(1,0);\n var mul = [one, base, one, one];\n var res = one;\n while (!caml_int64_is_zero(exponent)) {\n mul[1] = caml_int64_mul(mul[1], mul[3]);\n mul[2] = caml_int64_mul(mul[1], mul[1]);\n mul[3] = caml_int64_mul(mul[2], mul[1]);\n res = caml_int64_mul(res, mul[caml_int64_lo32(exponent) & 3]);\n exponent = caml_int64_shift_right_unsigned(exponent, 2);\n }\n return res;\n}\n\n//Provides: Base_hash_string mutable\n//Requires: caml_hash\nfunction Base_hash_string(s) {\n return caml_hash(1,1,0,s)\n}\n//Provides: Base_hash_double const\n//Requires: caml_hash\nfunction Base_hash_double(d) {\n return caml_hash(1,1,0,d);\n}\n\n//Provides: Base_am_testing const\n//Weakdef\nfunction Base_am_testing(x) {\n return 0;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_format_int const (const, const)\n//Requires: caml_parse_format, caml_finish_formatting, caml_str_repeat\n//Requires: caml_string_of_jsbytes, caml_jsbytes_of_string\nfunction caml_format_int(fmt, i) {\n if (caml_jsbytes_of_string(fmt) == \"%d\") return caml_string_of_jsbytes(\"\"+i);\n var f = caml_parse_format(fmt);\n if (i < 0) { if (f.signedconv) { f.sign = -1; i = -i; } else i >>>= 0; }\n var s = i.toString(f.base);\n if (f.prec >= 0) {\n f.filler = ' ';\n var n = f.prec - s.length;\n if (n > 0) s = caml_str_repeat (n, '0') + s;\n }\n return caml_finish_formatting(f, s);\n}\n\n//Provides: caml_parse_sign_and_base\n//Requires: caml_string_unsafe_get, caml_ml_string_length\nfunction caml_parse_sign_and_base (s) {\n var i = 0, len = caml_ml_string_length(s), base = 10, sign = 1;\n if (len > 0) {\n switch (caml_string_unsafe_get(s,i)) {\n case 45: i++; sign = -1; break;\n case 43: i++; sign = 1; break;\n }\n }\n if (i + 1 < len && caml_string_unsafe_get(s, i) == 48)\n switch (caml_string_unsafe_get(s, i + 1)) {\n case 120: case 88: base = 16; i += 2; break;\n case 111: case 79: base = 8; i += 2; break;\n case 98: case 66: base = 2; i += 2; break;\n case 117: case 85: i += 2; break;\n }\n return [i, sign, base];\n}\n\n//Provides: caml_parse_digit\nfunction caml_parse_digit(c) {\n if (c >= 48 && c <= 57) return c - 48;\n if (c >= 65 && c <= 90) return c - 55;\n if (c >= 97 && c <= 122) return c - 87;\n return -1;\n}\n\n//Provides: caml_int_of_string (const)\n//Requires: caml_ml_string_length, caml_string_unsafe_get\n//Requires: caml_parse_sign_and_base, caml_parse_digit, caml_failwith\nfunction caml_int_of_string (s) {\n var r = caml_parse_sign_and_base (s);\n var i = r[0], sign = r[1], base = r[2];\n var len = caml_ml_string_length(s);\n var threshold = -1 >>> 0;\n var c = (i < len)?caml_string_unsafe_get(s, i):0;\n var d = caml_parse_digit(c);\n if (d < 0 || d >= base) caml_failwith(\"int_of_string\");\n var res = d;\n for (i++;i= base) break;\n res = base * res + d;\n if (res > threshold) caml_failwith(\"int_of_string\");\n }\n if (i != len) caml_failwith(\"int_of_string\");\n // For base different from 10, we expect an unsigned representation,\n // hence any value of 'res' (less than 'threshold') is acceptable.\n // But we have to convert the result back to a signed integer.\n res = sign * res;\n if ((base == 10) && ((res | 0) != res))\n /* Signed representation expected, allow -2^(nbits-1) to 2^(nbits-1) - 1 */\n caml_failwith(\"int_of_string\");\n return res | 0;\n}\n\n//Provides: caml_mul const\nfunction caml_mul(a,b){\n return Math.imul(a,b);\n}\n\n//Provides: caml_div\n//Requires: caml_raise_zero_divide\nfunction caml_div(x,y) {\n if (y == 0) caml_raise_zero_divide ();\n return (x/y)|0;\n}\n\n//Provides: caml_mod\n//Requires: caml_raise_zero_divide\nfunction caml_mod(x,y) {\n if (y == 0) caml_raise_zero_divide ();\n return x%y;\n}\n\n//Provides: caml_bswap16\nfunction caml_bswap16(x) {\n return ((((x & 0x00FF) << 8) |\n ((x & 0xFF00) >> 8)));\n}\n//Provides: caml_int32_bswap\nfunction caml_int32_bswap(x) {\n return (((x & 0x000000FF) << 24) |\n ((x & 0x0000FF00) << 8) |\n ((x & 0x00FF0000) >>> 8) |\n ((x & 0xFF000000) >>> 24));\n}\n//Provides: caml_int64_bswap\n//Requires: caml_int64_to_bytes, caml_int64_of_bytes\nfunction caml_int64_bswap(x) {\n var y = caml_int64_to_bytes(x);\n return caml_int64_of_bytes([y[7], y[6], y[5], y[4], y[3], y[2], y[1], y[0]]);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Hashtbl\n\n//Provides: caml_hash_univ_param mutable\n//Requires: caml_is_ml_string, caml_is_ml_bytes\n//Requires: caml_ml_bytes_content\n//Requires: caml_int64_to_bytes, caml_int64_bits_of_float, caml_custom_ops\n//Requires: caml_ml_bytes_length, caml_jsbytes_of_string\nfunction caml_hash_univ_param (count, limit, obj) {\n var hash_accu = 0;\n function hash_aux (obj) {\n limit --;\n if (count < 0 || limit < 0) return;\n if (obj instanceof Array && obj[0] === (obj[0]|0)) {\n switch (obj[0]) {\n case 248:\n // Object\n count --;\n hash_accu = (hash_accu * 65599 + obj[2]) | 0;\n break;\n case 250:\n // Forward\n limit++; hash_aux(obj); break;\n default:\n count --;\n hash_accu = (hash_accu * 19 + obj[0]) | 0;\n for (var i = obj.length - 1; i > 0; i--) hash_aux (obj[i]);\n }\n } else if (caml_is_ml_bytes(obj)) {\n count --;\n var content = caml_ml_bytes_content(obj);\n if(typeof content === \"string\") {\n\tfor (var b = content, l = b.length, i = 0; i < l; i++)\n hash_accu = (hash_accu * 19 + b.charCodeAt(i)) | 0;\n } else { /* ARRAY */\n for (var a = content, l = a.length, i = 0; i < l; i++)\n hash_accu = (hash_accu * 19 + a[i]) | 0;\n }\n } else if (caml_is_ml_string(obj)) {\n var jsbytes = caml_jsbytes_of_string(obj);\n for (var b = jsbytes, l = jsbytes.length, i = 0; i < l; i++)\n hash_accu = (hash_accu * 19 + b.charCodeAt(i)) | 0;\n } else if (typeof obj === \"string\") {\n for (var b = obj, l = obj.length, i = 0; i < l; i++)\n hash_accu = (hash_accu * 19 + b.charCodeAt(i)) | 0;\n } else if (obj === (obj|0)) {\n // Integer\n count --;\n hash_accu = (hash_accu * 65599 + obj) | 0;\n } else if (obj === +obj) {\n // Float\n count--;\n var p = caml_int64_to_bytes (caml_int64_bits_of_float (obj));\n for (var i = 7; i >= 0; i--) hash_accu = (hash_accu * 19 + p[i]) | 0;\n } else if(obj && obj.caml_custom) {\n if(caml_custom_ops[obj.caml_custom] && caml_custom_ops[obj.caml_custom].hash) {\n var h = caml_custom_ops[obj.caml_custom].hash(obj) | 0;\n hash_accu = (hash_accu * 65599 + h) | 0;\n }\n }\n }\n hash_aux (obj);\n return hash_accu & 0x3FFFFFFF;\n}\n\n//function ROTL32(x,n) { return ((x << n) | (x >>> (32-n))); }\n//Provides: caml_hash_mix_int\n//Requires: caml_mul\nfunction caml_hash_mix_int(h,d) {\n d = caml_mul(d, 0xcc9e2d51|0);\n d = ((d << 15) | (d >>> (32-15))); // ROTL32(d, 15);\n d = caml_mul(d, 0x1b873593);\n h ^= d;\n h = ((h << 13) | (h >>> (32-13))); //ROTL32(h, 13);\n return (((h + (h << 2))|0) + (0xe6546b64|0))|0;\n}\n\n//Provides: caml_hash_mix_final\n//Requires: caml_mul\nfunction caml_hash_mix_final(h) {\n h ^= h >>> 16;\n h = caml_mul (h, 0x85ebca6b|0);\n h ^= h >>> 13;\n h = caml_mul (h, 0xc2b2ae35|0);\n h ^= h >>> 16;\n return h;\n}\n\n//Provides: caml_hash_mix_float\n//Requires: caml_int64_bits_of_float, caml_hash_mix_int64\nfunction caml_hash_mix_float (h, v0) {\n return caml_hash_mix_int64(h, caml_int64_bits_of_float (v0));\n}\n//Provides: caml_hash_mix_int64\n//Requires: caml_hash_mix_int\n//Requires: caml_int64_lo32, caml_int64_hi32\nfunction caml_hash_mix_int64 (h, v) {\n h = caml_hash_mix_int(h, caml_int64_lo32(v));\n h = caml_hash_mix_int(h, caml_int64_hi32(v));\n return h;\n}\n\n//Provides: caml_hash_mix_jsbytes\n//Requires: caml_hash_mix_int\nfunction caml_hash_mix_jsbytes(h, s) {\n var len = s.length, i, w;\n for (i = 0; i + 4 <= len; i += 4) {\n w = s.charCodeAt(i)\n | (s.charCodeAt(i+1) << 8)\n | (s.charCodeAt(i+2) << 16)\n | (s.charCodeAt(i+3) << 24);\n h = caml_hash_mix_int(h, w);\n }\n w = 0;\n switch (len & 3) {\n case 3: w = s.charCodeAt(i+2) << 16;\n case 2: w |= s.charCodeAt(i+1) << 8;\n case 1:\n w |= s.charCodeAt(i);\n h = caml_hash_mix_int(h, w);\n default:\n }\n h ^= len;\n return h;\n}\n\n//Provides: caml_hash_mix_bytes_arr\n//Requires: caml_hash_mix_int\nfunction caml_hash_mix_bytes_arr(h, s) {\n var len = s.length, i, w;\n for (i = 0; i + 4 <= len; i += 4) {\n w = s[i]\n | (s[i+1] << 8)\n | (s[i+2] << 16)\n | (s[i+3] << 24);\n h = caml_hash_mix_int(h, w);\n }\n w = 0;\n switch (len & 3) {\n case 3: w = s[i+2] << 16;\n case 2: w |= s[i+1] << 8;\n case 1: w |= s[i];\n h = caml_hash_mix_int(h, w);\n default:\n }\n h ^= len;\n return h;\n}\n\n//Provides: caml_hash_mix_bytes\n//Requires: caml_ml_bytes_content\n//Requires: caml_hash_mix_jsbytes\n//Requires: caml_hash_mix_bytes_arr\nfunction caml_hash_mix_bytes(h, v) {\n var content = caml_ml_bytes_content(v);\n if(typeof content === \"string\")\n return caml_hash_mix_jsbytes(h, content)\n else /* ARRAY */\n return caml_hash_mix_bytes_arr(h, content);\n}\n\n//Provides: caml_hash_mix_string\n//Requires: caml_hash_mix_jsbytes, caml_jsbytes_of_string\nfunction caml_hash_mix_string(h, v) {\n return caml_hash_mix_jsbytes(h, caml_jsbytes_of_string(v));\n}\n\n\n//Provides: caml_hash mutable\n//Requires: caml_is_ml_string, caml_is_ml_bytes\n//Requires: caml_hash_mix_int, caml_hash_mix_final\n//Requires: caml_hash_mix_float, caml_hash_mix_string, caml_hash_mix_bytes, caml_custom_ops\n//Requires: caml_hash_mix_jsbytes\nfunction caml_hash (count, limit, seed, obj) {\n var queue, rd, wr, sz, num, h, v, i, len;\n sz = limit;\n if (sz < 0 || sz > 256) sz = 256;\n num = count;\n h = seed;\n queue = [obj]; rd = 0; wr = 1;\n while (rd < wr && num > 0) {\n v = queue[rd++];\n if (v && v.caml_custom){\n if(caml_custom_ops[v.caml_custom] && caml_custom_ops[v.caml_custom].hash) {\n var hh = caml_custom_ops[v.caml_custom].hash(v);\n h = caml_hash_mix_int (h, hh);\n num --;\n }\n }\n else if (v instanceof Array && v[0] === (v[0]|0)) {\n switch (v[0]) {\n case 248:\n // Object\n h = caml_hash_mix_int(h, v[2]);\n num--;\n break;\n case 250:\n // Forward\n queue[--rd] = v[1];\n break;\n default:\n var tag = ((v.length - 1) << 10) | v[0];\n h = caml_hash_mix_int(h, tag);\n for (i = 1, len = v.length; i < len; i++) {\n if (wr >= sz) break;\n queue[wr++] = v[i];\n }\n break;\n }\n } else if (caml_is_ml_bytes(v)) {\n h = caml_hash_mix_bytes(h,v)\n num--;\n } else if (caml_is_ml_string(v)) {\n h = caml_hash_mix_string(h,v)\n num--;\n } else if (typeof v === \"string\") {\n h = caml_hash_mix_jsbytes(h,v)\n num--;\n } else if (v === (v|0)) {\n // Integer\n h = caml_hash_mix_int(h, v+v+1);\n num--;\n } else if (v === +v) {\n // Float\n h = caml_hash_mix_float(h,v);\n num--;\n }\n }\n h = caml_hash_mix_final(h);\n return h & 0x3FFFFFFF;\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: jsoo_floor_log2\nvar log2_ok = Math.log2 && Math.log2(1.1235582092889474E+307) == 1020\nfunction jsoo_floor_log2(x) {\n if(log2_ok) return Math.floor(Math.log2(x))\n var i = 0;\n if (x == 0) return -Infinity;\n if(x>=1) {while (x>=2) {x/=2; i++} }\n else {while (x < 1) {x*=2; i--} };\n return i;\n}\n\n//Provides: caml_int64_bits_of_float const\n//Requires: jsoo_floor_log2, caml_int64_create_lo_mi_hi\nfunction caml_int64_bits_of_float (x) {\n if (!isFinite(x)) {\n if (isNaN(x))\n return caml_int64_create_lo_mi_hi(1, 0, 0x7ff0);\n if (x > 0)\n return caml_int64_create_lo_mi_hi(0, 0, 0x7ff0)\n else\n return caml_int64_create_lo_mi_hi(0, 0, 0xfff0)\n }\n var sign = (x==0 && 1/x == -Infinity)?0x8000:(x>=0)?0:0x8000;\n if (sign) x = -x;\n // Int64.bits_of_float 1.1235582092889474E+307 = 0x7fb0000000000000L\n // using Math.LOG2E*Math.log(x) in place of Math.log2 result in precision lost\n var exp = jsoo_floor_log2(x) + 1023;\n if (exp <= 0) {\n exp = 0;\n x /= Math.pow(2,-1026);\n } else {\n x /= Math.pow(2,exp-1027);\n if (x < 16) {\n x *= 2; exp -=1; }\n if (exp == 0) {\n x /= 2; }\n }\n var k = Math.pow(2,24);\n var r3 = x|0;\n x = (x - r3) * k;\n var r2 = x|0;\n x = (x - r2) * k;\n var r1 = x|0;\n r3 = (r3 &0xf) | sign | exp << 4;\n return caml_int64_create_lo_mi_hi(r1, r2, r3);\n}\n\n//Provides: caml_int32_bits_of_float const\n//Requires: jsoo_floor_log2\nfunction caml_int32_bits_of_float (x) {\n var float32a = new globalThis.Float32Array(1);\n float32a[0] = x;\n var int32a = new globalThis.Int32Array(float32a.buffer);\n return int32a[0] | 0;\n}\n\n//FP literals can be written using the hexadecimal\n//notation 0xp from ISO C99.\n//https://github.com/dankogai/js-hexfloat/blob/master/hexfloat.js\n//Provides: caml_hexstring_of_float const\n//Requires: caml_string_of_jsstring, caml_str_repeat\nfunction caml_hexstring_of_float (x, prec, style) {\n if (!isFinite(x)) {\n if (isNaN(x)) return caml_string_of_jsstring(\"nan\");\n return caml_string_of_jsstring ((x > 0)?\"infinity\":\"-infinity\");\n }\n var sign = (x==0 && 1/x == -Infinity)?1:(x>=0)?0:1;\n if(sign) x = -x;\n var exp = 0;\n if (x == 0) { }\n else if (x < 1) {\n while (x < 1 && exp > -1022) { x *= 2; exp-- }\n } else {\n while (x >= 2) { x /= 2; exp++ }\n }\n var exp_sign = exp < 0 ? '' : '+';\n var sign_str = '';\n if (sign) sign_str = '-'\n else {\n switch(style){\n case 43 /* '+' */: sign_str = '+'; break;\n case 32 /* ' ' */: sign_str = ' '; break;\n default: break;\n }\n }\n if (prec >= 0 && prec < 13) {\n /* If a precision is given, and is small, round mantissa accordingly */\n var cst = Math.pow(2,prec * 4);\n x = Math.round(x * cst) / cst;\n }\n var x_str = x.toString(16);\n if(prec >= 0){\n var idx = x_str.indexOf('.');\n if(idx<0) {\n x_str += '.' + caml_str_repeat(prec, '0');\n }\n else {\n var size = idx+1+prec;\n if(x_str.length < size)\n x_str += caml_str_repeat(size - x_str.length, '0');\n else\n x_str = x_str.substr(0,size);\n }\n }\n return caml_string_of_jsstring (sign_str + '0x' + x_str + 'p' + exp_sign + exp.toString(10));\n}\n\n//Provides: caml_int64_float_of_bits const\nfunction caml_int64_float_of_bits (x) {\n var lo = x.lo;\n var mi = x.mi;\n var hi = x.hi;\n var exp = (hi & 0x7fff) >> 4;\n if (exp == 2047) {\n if ((lo|mi|(hi&0xf)) == 0)\n return (hi & 0x8000)?(-Infinity):Infinity;\n else\n return NaN;\n }\n var k = Math.pow(2,-24);\n var res = (lo*k+mi)*k+(hi&0xf);\n if (exp > 0) {\n res += 16;\n res *= Math.pow(2,exp-1027);\n } else\n res *= Math.pow(2,-1026);\n if (hi & 0x8000) res = - res;\n return res;\n}\n\n//Provides: caml_nextafter_float const\n//Requires: caml_int64_float_of_bits, caml_int64_bits_of_float, caml_int64_add, caml_int64_sub,caml_int64_of_int32\nfunction caml_nextafter_float (x,y) {\n if(isNaN(x) || isNaN(y)) return NaN;\n if(x==y) return y;\n if(x==0){\n if(y < 0)\n return -Math.pow(2, -1074)\n else\n return Math.pow(2, -1074)\n }\n var bits = caml_int64_bits_of_float(x);\n var one = caml_int64_of_int32(1);\n if ((x0))\n bits = caml_int64_add(bits, one)\n else\n bits = caml_int64_sub(bits, one)\n return caml_int64_float_of_bits(bits);\n}\n\n//Provides: caml_trunc_float\nfunction caml_trunc_float(x){\n return Math.trunc(x);\n}\n\n//Provides: caml_int32_float_of_bits const\nfunction caml_int32_float_of_bits (x) {\n var int32a = new globalThis.Int32Array(1);\n int32a[0] = x;\n var float32a = new globalThis.Float32Array(int32a.buffer);\n return float32a[0];\n}\n\n//Provides: caml_classify_float const\nfunction caml_classify_float (x) {\n if (isFinite (x)) {\n if (Math.abs(x) >= 2.2250738585072014e-308) return 0;\n if (x != 0) return 1;\n return 2;\n }\n return isNaN(x)?4:3;\n}\n//Provides: caml_modf_float const\nfunction caml_modf_float (x) {\n if (isFinite (x)) {\n var neg = (1/x) < 0;\n x = Math.abs(x);\n var i = Math.floor (x);\n var f = x - i;\n if (neg) { i = -i; f = -f; }\n return [0, f, i];\n }\n if (isNaN (x)) return [0, NaN, NaN];\n return [0, 1/x, x];\n}\n//Provides: caml_ldexp_float const\nfunction caml_ldexp_float (x,exp) {\n exp |= 0;\n if (exp > 1023) {\n exp -= 1023;\n x *= Math.pow(2, 1023);\n if (exp > 1023) { // in case x is subnormal\n exp -= 1023;\n x *= Math.pow(2, 1023);\n }\n }\n if (exp < -1023) {\n exp += 1023;\n x *= Math.pow(2, -1023);\n }\n x *= Math.pow(2, exp);\n return x;\n}\n//Provides: caml_frexp_float const\n//Requires: jsoo_floor_log2\nfunction caml_frexp_float (x) {\n if ((x == 0) || !isFinite(x)) return [0, x, 0];\n var neg = x < 0;\n if (neg) x = - x;\n var exp = Math.max(-1023, jsoo_floor_log2(x) + 1);\n x *= Math.pow(2,-exp);\n while (x < 0.5) {\n x *= 2;\n exp--;\n }\n while (x >= 1) {\n x *= 0.5;\n exp++;\n }\n if (neg) x = - x;\n return [0, x, exp];\n}\n\n//Provides: caml_float_compare const\nfunction caml_float_compare (x, y) {\n if (x === y) return 0;\n if (x < y) return -1;\n if (x > y) return 1;\n if (x === x) return 1;\n if (y === y) return -1;\n return 0;\n}\n\n//Provides: caml_copysign_float const\nfunction caml_copysign_float (x, y) {\n if (y == 0) y = 1 / y;\n x = Math.abs(x);\n return (y < 0)?(-x):x;\n}\n\n//Provides: caml_signbit_float const\nfunction caml_signbit_float(x) {\n if (x == 0) x = 1 / x;\n return (x < 0)?1:0;\n}\n\n//Provides: caml_expm1_float const\nfunction caml_expm1_float (x) { return Math.expm1(x); }\n//Provides: caml_exp2_float const\nfunction caml_exp2_float(x) { return Math.pow(2, x); }\n//Provides: caml_log1p_float const\nfunction caml_log1p_float(x) { return Math.log1p(x); }\n//Provides: caml_log2_float const\nfunction caml_log2_float(x) { return Math.log2(x); }\n//Provides: caml_hypot_float const\nfunction caml_hypot_float (x, y) { return Math.hypot(x, y); }\n//Provides: caml_log10_float const\nfunction caml_log10_float (x) { return Math.log10(x); }\n//Provides: caml_cosh_float const\nfunction caml_cosh_float (x) { return Math.cosh(x); }\n//Provides: caml_acosh_float const\nfunction caml_acosh_float (x) { return Math.acosh(x); }\n//Provides: caml_sinh_float const\nfunction caml_sinh_float (x) { return Math.sinh(x); }\n//Provides: caml_asinh_float const\nfunction caml_asinh_float (x) { return Math.asinh(x); }\n//Provides: caml_tanh_float const\nfunction caml_tanh_float (x) { return Math.tanh(x); }\n//Provides: caml_atanh_float const\nfunction caml_atanh_float (x) { return Math.atanh(x); }\n//Provides: caml_round_float const\nfunction caml_round_float (x) { return Math.round(x); }\n//Provides: caml_cbrt_float const\nfunction caml_cbrt_float (x) { return Math.cbrt(x); }\n\n//Provides: caml_erf_float const\nfunction caml_erf_float(x) {\n var a1 = 0.254829592;\n var a2 = -0.284496736;\n var a3 = 1.421413741;\n var a4 = -1.453152027;\n var a5 = 1.061405429;\n var p = 0.3275911;\n\n var sign = 1;\n if (x < 0) {\n sign = -1;\n }\n x = Math.abs(x);\n var t = 1.0 / (1.0 + p * x);\n var y = 1.0 - ((((a5 * t + a4) * t + a3) * t + a2) * t + a1) * t * Math.exp(-x * x);\n\n return sign * y;\n}\n\n//Provides: caml_erfc_float const\n//Requires: caml_erf_float\nfunction caml_erfc_float(x) {\n return 1 - caml_erf_float(x);\n}\n\n\n//Provides: caml_fma_float const\nfunction caml_fma_float(x, y, z) {\n var SPLIT = Math.pow(2, 27) + 1;\n var MIN_VALUE = Math.pow(2, -1022);\n var EPSILON = Math.pow(2, -52);\n var C = 416;\n var A = Math.pow(2, +C);\n var B = Math.pow(2, -C);\n\n function multiply (a, b) {\n var at = SPLIT * a;\n var ahi = at - (at - a);\n var alo = a - ahi;\n var bt = SPLIT * b;\n var bhi = bt - (bt - b);\n var blo = b - bhi;\n var p = a * b;\n var e = ((ahi * bhi - p) + ahi * blo + alo * bhi) + alo * blo;\n return {\n p: p,\n e: e\n };\n };\n\n function add (a, b) {\n var s = a + b;\n var v = s - a;\n var e = (a - (s - v)) + (b - v);\n return {\n s: s,\n e: e\n };\n };\n\n function adjust (x, y) {\n return x !== 0 && y !== 0 && SPLIT * x - (SPLIT * x - x) === x ? x * (1 + (x < 0 ? -1 : +1) * (y < 0 ? -1 : +1) * EPSILON) : x;\n };\n\n if (x === 0 || x !== x || x === +1 / 0 || x === -1 / 0 ||\n y === 0 || y !== y || y === +1 / 0 || y === -1 / 0) {\n return x * y + z;\n }\n if (z === 0) {\n return x * y;\n }\n if (z !== z || z === +1 / 0 || z === -1 / 0) {\n return z;\n }\n\n var scale = 1;\n while (Math.abs(x) > A) {\n scale *= A;\n x *= B;\n }\n while (Math.abs(y) > A) {\n scale *= A;\n y *= B;\n }\n if (scale === 1 / 0) {\n return x * y * scale;\n }\n while (Math.abs(x) < B) {\n scale *= B;\n x *= A;\n }\n while (Math.abs(y) < B) {\n scale *= B;\n y *= A;\n }\n if (scale === 0) {\n return z;\n }\n\n var xs = x;\n var ys = y;\n var zs = z / scale;\n\n if (Math.abs(zs) > Math.abs(xs * ys) * 4 / EPSILON) {\n return z;\n }\n if (Math.abs(zs) < Math.abs(xs * ys) * EPSILON / 4 * EPSILON / 4) {\n zs = (z < 0 ? -1 : +1) * MIN_VALUE;\n }\n\n var xy = multiply(xs, ys);\n var s = add(xy.p, zs);\n var u = add(xy.e, s.e);\n var i = add(s.s, u.s);\n\n var f = i.s + adjust(i.e, u.e);\n if (f === 0) {\n return f;\n }\n\n var fs = f * scale;\n if (Math.abs(fs) > MIN_VALUE) {\n return fs;\n }\n\n // It is possible that there was extra rounding for a denormalized value.\n return fs + adjust(f - fs / scale, i.e) * scale;\n}\n\n//Provides: caml_format_float const\n//Requires: caml_parse_format, caml_finish_formatting\nfunction caml_format_float (fmt, x) {\n function toFixed(x,dp) {\n if (Math.abs(x) < 1.0) {\n return x.toFixed(dp);\n } else {\n var e = parseInt(x.toString().split('+')[1]);\n if (e > 20) {\n e -= 20;\n x /= Math.pow(10,e);\n x += (new Array(e+1)).join('0');\n if(dp > 0) {\n x = x + '.' + (new Array(dp+1)).join('0');\n }\n return x;\n }\n else return x.toFixed(dp)\n }\n }\n var s, f = caml_parse_format(fmt);\n var prec = (f.prec < 0)?6:f.prec;\n if (x < 0 || (x == 0 && 1/x == -Infinity)) { f.sign = -1; x = -x; }\n if (isNaN(x)) { s = \"nan\"; f.filler = ' '; }\n else if (!isFinite(x)) { s = \"inf\"; f.filler = ' '; }\n else\n switch (f.conv) {\n case 'e':\n var s = x.toExponential(prec);\n // exponent should be at least two digits\n var i = s.length;\n if (s.charAt(i - 3) == 'e')\n s = s.slice (0, i - 1) + '0' + s.slice (i - 1);\n break;\n case 'f':\n s = toFixed(x, prec); break;\n case 'g':\n prec = prec?prec:1;\n s = x.toExponential(prec - 1);\n var j = s.indexOf('e');\n var exp = +s.slice(j + 1);\n if (exp < -4 || x >= 1e21 || x.toFixed(0).length > prec) {\n // remove trailing zeroes\n var i = j - 1; while (s.charAt(i) == '0') i--;\n if (s.charAt(i) == '.') i--;\n s = s.slice(0, i + 1) + s.slice(j);\n i = s.length;\n if (s.charAt(i - 3) == 'e')\n s = s.slice (0, i - 1) + '0' + s.slice (i - 1);\n break;\n } else {\n var p = prec;\n if (exp < 0) { p -= exp + 1; s = x.toFixed(p); }\n else while (s = x.toFixed(p), s.length > prec + 1) p--;\n if (p) {\n // remove trailing zeroes\n var i = s.length - 1; while (s.charAt(i) == '0') i--;\n if (s.charAt(i) == '.') i--;\n s = s.slice(0, i + 1);\n }\n }\n break;\n }\n return caml_finish_formatting(f, s);\n}\n\n//Provides: caml_float_of_string (const)\n//Requires: caml_failwith, caml_jsbytes_of_string\nfunction caml_float_of_string(s) {\n var res;\n s = caml_jsbytes_of_string(s)\n res = +s;\n if ((s.length > 0) && (res === res)) return res;\n s = s.replace(/_/g,\"\");\n res = +s;\n if (((s.length > 0) && (res === res)) || /^[+-]?nan$/i.test(s)) return res;\n var m = /^ *([+-]?)0x([0-9a-f]+)\\.?([0-9a-f]*)(p([+-]?[0-9]+))?/i.exec(s);\n // 1 2 3 5\n if(m){\n var m3 = m[3].replace(/0+$/,'');\n var mantissa = parseInt(m[1] + m[2] + m3, 16);\n var exponent = (m[5]|0) - 4*m3.length;\n res = mantissa * Math.pow(2, exponent);\n return res;\n }\n if(/^\\+?inf(inity)?$/i.test(s)) return Infinity;\n if(/^-inf(inity)?$/i.test(s)) return -Infinity;\n caml_failwith(\"float_of_string\");\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_int64_offset\nvar caml_int64_offset = Math.pow(2, -24);\n\n//Provides: MlInt64\n//Requires: caml_int64_offset, caml_raise_zero_divide\nfunction MlInt64 (lo,mi,hi) {\n this.lo = lo & 0xffffff;\n this.mi = mi & 0xffffff;\n this.hi = hi & 0xffff;\n}\nMlInt64.prototype.caml_custom = \"_j\"\nMlInt64.prototype.copy = function () {\n return new MlInt64(this.lo,this.mi,this.hi);\n}\n\nMlInt64.prototype.ucompare = function (x) {\n if (this.hi > x.hi) return 1;\n if (this.hi < x.hi) return -1;\n if (this.mi > x.mi) return 1;\n if (this.mi < x.mi) return -1;\n if (this.lo > x.lo) return 1;\n if (this.lo < x.lo) return -1;\n return 0;\n}\nMlInt64.prototype.compare = function (x) {\n var hi = this.hi << 16;\n var xhi = x.hi << 16;\n if (hi > xhi) return 1;\n if (hi < xhi) return -1;\n if (this.mi > x.mi) return 1;\n if (this.mi < x.mi) return -1;\n if (this.lo > x.lo) return 1;\n if (this.lo < x.lo) return -1;\n return 0;\n}\nMlInt64.prototype.neg = function () {\n var lo = - this.lo;\n var mi = - this.mi + (lo >> 24);\n var hi = - this.hi + (mi >> 24);\n return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.add = function (x) {\n var lo = this.lo + x.lo;\n var mi = this.mi + x.mi + (lo >> 24);\n var hi = this.hi + x.hi + (mi >> 24);\n return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.sub = function (x) {\n var lo = this.lo - x.lo;\n var mi = this.mi - x.mi + (lo >> 24);\n var hi = this.hi - x.hi + (mi >> 24);\n return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.mul = function (x) {\n var lo = this.lo * x.lo;\n var mi = ((lo * caml_int64_offset) | 0) + this.mi * x.lo + this.lo * x.mi;\n var hi = ((mi * caml_int64_offset) | 0) + this.hi * x.lo + this.mi * x.mi + this.lo * x.hi;\n return new MlInt64(lo, mi, hi);\n}\nMlInt64.prototype.isZero = function () {\n return (this.lo|this.mi|this.hi) == 0;\n}\nMlInt64.prototype.isNeg = function () {\n return (this.hi << 16) < 0;\n}\nMlInt64.prototype.and = function (x) {\n return new MlInt64(this.lo & x.lo, this.mi & x.mi, this.hi & x.hi);\n}\nMlInt64.prototype.or = function (x) {\n return new MlInt64(this.lo|x.lo, this.mi|x.mi, this.hi|x.hi);\n}\nMlInt64.prototype.xor = function (x) {\n return new MlInt64(this.lo^x.lo, this.mi^x.mi, this.hi^x.hi);\n}\nMlInt64.prototype.shift_left = function (s) {\n s = s & 63;\n if (s == 0) return this;\n if (s < 24) {\n return new MlInt64 (this.lo << s,\n (this.mi << s) | (this.lo >> (24 - s)),\n (this.hi << s) | (this.mi >> (24 - s)));\n }\n if (s < 48)\n return new MlInt64 (0,\n this.lo << (s - 24),\n (this.mi << (s - 24)) | (this.lo >> (48 - s)));\n return new MlInt64(0, 0, this.lo << (s - 48))\n}\nMlInt64.prototype.shift_right_unsigned = function (s) {\n s = s & 63;\n if (s == 0) return this;\n if (s < 24)\n return new MlInt64 (\n (this.lo >> s) | (this.mi << (24 - s)),\n (this.mi >> s) | (this.hi << (24 - s)),\n (this.hi >> s));\n if (s < 48)\n return new MlInt64 (\n (this.mi >> (s - 24)) | (this.hi << (48 - s)),\n (this.hi >> (s - 24)),\n 0);\n return new MlInt64 (this.hi >> (s - 48), 0, 0);\n}\nMlInt64.prototype.shift_right = function (s) {\n s = s & 63;\n if (s == 0) return this;\n var h = (this.hi << 16) >> 16;\n if (s < 24)\n return new MlInt64 (\n (this.lo >> s) | (this.mi << (24 - s)),\n (this.mi >> s) | (h << (24 - s)),\n ((this.hi << 16) >> s) >>> 16);\n var sign = (this.hi << 16) >> 31;\n if (s < 48)\n return new MlInt64 (\n (this.mi >> (s - 24)) | (this.hi << (48 - s)),\n (this.hi << 16) >> (s - 24) >> 16,\n sign & 0xffff);\n return new MlInt64 ((this.hi << 16) >> (s - 32), sign, sign);\n}\nMlInt64.prototype.lsl1 = function () {\n this.hi = (this.hi << 1) | (this.mi >> 23);\n this.mi = ((this.mi << 1) | (this.lo >> 23)) & 0xffffff;\n this.lo = (this.lo << 1) & 0xffffff;\n}\nMlInt64.prototype.lsr1 = function () {\n this.lo = ((this.lo >>> 1) | (this.mi << 23)) & 0xffffff;\n this.mi = ((this.mi >>> 1) | (this.hi << 23)) & 0xffffff;\n this.hi = this.hi >>> 1;\n}\nMlInt64.prototype.udivmod = function (x) {\n var offset = 0;\n var modulus = this.copy();\n var divisor = x.copy();\n var quotient = new MlInt64(0,0,0);\n while (modulus.ucompare(divisor) > 0) {\n offset++;\n divisor.lsl1();\n }\n while (offset >= 0) {\n offset --;\n quotient.lsl1();\n if (modulus.ucompare(divisor) >= 0) {\n quotient.lo ++;\n modulus = modulus.sub(divisor);\n }\n divisor.lsr1();\n }\n return { quotient : quotient, modulus : modulus };\n}\nMlInt64.prototype.div = function (y)\n{\n var x = this;\n if (y.isZero()) caml_raise_zero_divide ();\n var sign = x.hi ^ y.hi;\n if (x.hi & 0x8000) x = x.neg();\n if (y.hi & 0x8000) y = y.neg();\n var q = x.udivmod(y).quotient;\n if (sign & 0x8000) q = q.neg();\n return q;\n}\nMlInt64.prototype.mod = function (y)\n{\n var x = this;\n if (y.isZero()) caml_raise_zero_divide ();\n var sign = x.hi;\n if (x.hi & 0x8000) x = x.neg();\n if (y.hi & 0x8000) y = y.neg();\n var r = x.udivmod(y).modulus;\n if (sign & 0x8000) r = r.neg();\n return r;\n}\nMlInt64.prototype.toInt = function () {\n return this.lo | (this.mi << 24);\n}\nMlInt64.prototype.toFloat = function () {\n return ((this.hi << 16) * Math.pow(2, 32) + this.mi * Math.pow(2, 24)) + this.lo;\n}\nMlInt64.prototype.toArray = function () {\n return [this.hi >> 8,\n this.hi & 0xff,\n this.mi >> 16,\n (this.mi >> 8) & 0xff,\n this.mi & 0xff,\n this.lo >> 16,\n (this.lo >> 8) & 0xff,\n this.lo & 0xff];\n}\nMlInt64.prototype.lo32 = function () {\n return this.lo | ((this.mi & 0xff) << 24);\n}\nMlInt64.prototype.hi32 = function () {\n return ((this.mi >>> 8) & 0xffff) | (this.hi << 16);\n}\n\n//Provides: caml_int64_ult const\nfunction caml_int64_ult(x,y) { return x.ucompare(y) < 0; }\n\n//Provides: caml_int64_compare const\nfunction caml_int64_compare(x,y, total) { return x.compare(y) }\n\n//Provides: caml_int64_neg const\nfunction caml_int64_neg (x) { return x.neg() }\n\n//Provides: caml_int64_add const\nfunction caml_int64_add (x, y) { return x.add(y) }\n\n//Provides: caml_int64_sub const\nfunction caml_int64_sub (x, y) { return x.sub(y) }\n\n//Provides: caml_int64_mul const\n//Requires: caml_int64_offset\nfunction caml_int64_mul(x,y) { return x.mul(y) }\n\n//Provides: caml_int64_is_zero const\nfunction caml_int64_is_zero(x) { return +x.isZero(); }\n\n//Provides: caml_int64_is_negative const\nfunction caml_int64_is_negative(x) { return +x.isNeg(); }\n\n//Provides: caml_int64_and const\nfunction caml_int64_and (x, y) { return x.and(y); }\n\n//Provides: caml_int64_or const\nfunction caml_int64_or (x, y) { return x.or(y); }\n\n//Provides: caml_int64_xor const\nfunction caml_int64_xor (x, y) { return x.xor(y) }\n\n//Provides: caml_int64_shift_left const\nfunction caml_int64_shift_left (x, s) { return x.shift_left(s) }\n\n//Provides: caml_int64_shift_right_unsigned const\nfunction caml_int64_shift_right_unsigned (x, s) { return x.shift_right_unsigned(s) }\n\n//Provides: caml_int64_shift_right const\nfunction caml_int64_shift_right (x, s) { return x.shift_right(s) }\n\n//Provides: caml_int64_div const\nfunction caml_int64_div (x, y) { return x.div(y) }\n\n//Provides: caml_int64_mod const\nfunction caml_int64_mod (x, y) { return x.mod(y) }\n\n//Provides: caml_int64_of_int32 const\n//Requires: MlInt64\nfunction caml_int64_of_int32 (x) {\n return new MlInt64(x & 0xffffff, (x >> 24) & 0xffffff, (x >> 31) & 0xffff)\n}\n\n//Provides: caml_int64_to_int32 const\nfunction caml_int64_to_int32 (x) { return x.toInt() }\n\n//Provides: caml_int64_to_float const\nfunction caml_int64_to_float (x) { return x.toFloat () }\n\n//Provides: caml_int64_of_float const\n//Requires: caml_int64_offset, MlInt64\nfunction caml_int64_of_float (x) {\n if (x < 0) x = Math.ceil(x);\n return new MlInt64(\n x & 0xffffff,\n Math.floor(x * caml_int64_offset) & 0xffffff,\n Math.floor(x * caml_int64_offset * caml_int64_offset) & 0xffff);\n}\n\n//Provides: caml_int64_format const\n//Requires: caml_parse_format, caml_finish_formatting\n//Requires: caml_int64_is_negative, caml_int64_neg\n//Requires: caml_int64_of_int32, caml_int64_to_int32\n//Requires: caml_int64_is_zero, caml_str_repeat\nfunction caml_int64_format (fmt, x) {\n var f = caml_parse_format(fmt);\n if (f.signedconv && caml_int64_is_negative(x)) {\n f.sign = -1; x = caml_int64_neg(x);\n }\n var buffer = \"\";\n var wbase = caml_int64_of_int32(f.base);\n var cvtbl = \"0123456789abcdef\";\n do {\n var p = x.udivmod(wbase);\n x = p.quotient;\n buffer = cvtbl.charAt(caml_int64_to_int32(p.modulus)) + buffer;\n } while (! caml_int64_is_zero(x));\n if (f.prec >= 0) {\n f.filler = ' ';\n var n = f.prec - buffer.length;\n if (n > 0) buffer = caml_str_repeat (n, '0') + buffer;\n }\n return caml_finish_formatting(f, buffer);\n}\n\n//Provides: caml_int64_of_string\n//Requires: caml_parse_sign_and_base, caml_failwith, caml_parse_digit\n//Requires: caml_int64_of_int32, caml_int64_ult\n//Requires: caml_int64_add, caml_int64_mul, caml_int64_neg\n//Requires: caml_ml_string_length,caml_string_unsafe_get, MlInt64\nfunction caml_int64_of_string(s) {\n var r = caml_parse_sign_and_base (s);\n var i = r[0], sign = r[1], base = r[2];\n var base64 = caml_int64_of_int32(base);\n var threshold =\n new MlInt64(0xffffff, 0xfffffff, 0xffff).udivmod(base64).quotient;\n var c = caml_string_unsafe_get(s, i);\n var d = caml_parse_digit(c);\n if (d < 0 || d >= base) caml_failwith(\"int_of_string\");\n var res = caml_int64_of_int32(d);\n for (;;) {\n i++;\n c = caml_string_unsafe_get(s, i);\n if (c == 95) continue;\n d = caml_parse_digit(c);\n if (d < 0 || d >= base) break;\n /* Detect overflow in multiplication base * res */\n if (caml_int64_ult(threshold, res)) caml_failwith(\"int_of_string\");\n d = caml_int64_of_int32(d);\n res = caml_int64_add(caml_int64_mul(base64, res), d);\n /* Detect overflow in addition (base * res) + d */\n if (caml_int64_ult(res, d)) caml_failwith(\"int_of_string\");\n }\n if (i != caml_ml_string_length(s)) caml_failwith(\"int_of_string\");\n if (base == 10 && caml_int64_ult(new MlInt64(0, 0, 0x8000), res))\n caml_failwith(\"int_of_string\");\n if (sign < 0) res = caml_int64_neg(res);\n return res;\n}\n\n//Provides: caml_int64_create_lo_mi_hi const\n//Requires: MlInt64\nfunction caml_int64_create_lo_mi_hi(lo, mi, hi){\n return new MlInt64(lo, mi, hi)\n}\n//Provides: caml_int64_create_lo_hi const\n//Requires: MlInt64\nfunction caml_int64_create_lo_hi(lo, hi){\n return new MlInt64 (\n lo & 0xffffff,\n ((lo >>> 24) & 0xff) | ((hi & 0xffff) << 8),\n (hi >>> 16) & 0xffff);\n}\n//Provides: caml_int64_lo32 const\nfunction caml_int64_lo32(v){ return v.lo32() }\n\n//Provides: caml_int64_hi32 const\nfunction caml_int64_hi32(v){ return v.hi32() }\n\n//Provides: caml_int64_of_bytes const\n//Requires: MlInt64\nfunction caml_int64_of_bytes(a) {\n return new MlInt64(a[7] << 0 | (a[6] << 8) | (a[5] << 16),\n a[4] << 0 | (a[3] << 8) | (a[2] << 16),\n a[1] << 0 | (a[0] << 8));\n}\n//Provides: caml_int64_to_bytes const\nfunction caml_int64_to_bytes(x) { return x.toArray() }\n\n//Provides: caml_int64_hash const\nfunction caml_int64_hash(v){\n return (v.lo32()) ^ (v.hi32())\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Raise exception\n\n//Provides: caml_raise_constant (const)\nfunction caml_raise_constant (tag) { throw tag; }\n\n//Provides: caml_return_exn_constant (const)\nfunction caml_return_exn_constant (tag) { return tag; }\n\n//Provides: caml_raise_with_arg (const, const)\nfunction caml_raise_with_arg (tag, arg) { throw [0, tag, arg]; }\n\n//Provides: caml_raise_with_args (const, const)\nfunction caml_raise_with_args (tag, args) { throw [0, tag].concat(args); }\n\n//Provides: caml_raise_with_string (const, const)\n//Requires: caml_raise_with_arg, caml_string_of_jsbytes\nfunction caml_raise_with_string (tag, msg) {\n caml_raise_with_arg (tag, caml_string_of_jsbytes(msg));\n}\n\n//Provides: caml_failwith (const)\n//Requires: caml_raise_with_string, caml_global_data, caml_string_of_jsbytes\nfunction caml_failwith (msg) {\n if(!caml_global_data.Failure)\n caml_global_data.Failure=[248,caml_string_of_jsbytes(\"Failure\"),-3];\n caml_raise_with_string(caml_global_data.Failure, msg);\n}\n\n\n//Provides: caml_invalid_argument (const)\n//Requires: caml_raise_with_string, caml_global_data\nfunction caml_invalid_argument (msg) {\n caml_raise_with_string(caml_global_data.Invalid_argument, msg);\n}\n\n//Provides: caml_raise_end_of_file\n//Requires: caml_raise_constant, caml_global_data\nfunction caml_raise_end_of_file () {\n caml_raise_constant(caml_global_data.End_of_file);\n}\n\n//Provides: caml_raise_zero_divide\n//Requires: caml_raise_constant, caml_global_data\nfunction caml_raise_zero_divide () {\n caml_raise_constant(caml_global_data.Division_by_zero);\n}\n\n//Provides: caml_raise_not_found\n//Requires: caml_raise_constant, caml_global_data\nfunction caml_raise_not_found () {\n caml_raise_constant(caml_global_data.Not_found); }\n\n\n//Provides: caml_array_bound_error\n//Requires: caml_invalid_argument\nfunction caml_array_bound_error () {\n caml_invalid_argument(\"index out of bounds\");\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_call_gen (const, shallow)\n//Weakdef\nfunction caml_call_gen(f, args) {\n if(f.fun)\n return caml_call_gen(f.fun, args);\n //FIXME, can happen with too many arguments\n if(typeof f !== \"function\") return f;\n var n = f.length | 0;\n if(n === 0) return f.apply(null,args);\n var argsLen = args.length | 0;\n var d = n - argsLen | 0;\n if (d == 0)\n return f.apply(null, args);\n else if (d < 0) {\n return caml_call_gen(f.apply(null,args.slice(0,n)),args.slice(n));\n }\n else {\n return function (){\n var extra_args = (arguments.length == 0)?1:arguments.length;\n var nargs = new Array(args.length+extra_args);\n for(var i = 0; i < args.length; i++ ) nargs[i] = args[i];\n for(var i = 0; i < arguments.length; i++ ) nargs[args.length+i] = arguments[i];\n return caml_call_gen(f, nargs)\n }\n }\n}\n\n//Provides: caml_named_values\nvar caml_named_values = {};\n\n//Provides: caml_register_named_value (const,const)\n//Requires: caml_named_values, caml_jsbytes_of_string\nfunction caml_register_named_value(nm,v) {\n caml_named_values[caml_jsbytes_of_string(nm)] = v;\n return 0;\n}\n\n//Provides: caml_named_value\n//Requires: caml_named_values\nfunction caml_named_value(nm) {\n return caml_named_values[nm]\n}\n\n//Provides: caml_global_data\nvar caml_global_data = [0];\n\n//Provides: caml_register_global (const, shallow, const)\n//Requires: caml_global_data\nfunction caml_register_global (n, v, name_opt) {\n if(name_opt && globalThis.toplevelReloc)\n n = globalThis.toplevelReloc(name_opt);\n caml_global_data[n + 1] = v;\n if(name_opt) caml_global_data[name_opt] = v;\n}\n\n//Provides: caml_get_global_data mutable\n//Requires: caml_global_data\nfunction caml_get_global_data () { return caml_global_data; }\n\n//Provides: caml_is_printable const (const)\nfunction caml_is_printable(c) { return +(c > 31 && c < 127); }\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010-2014 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n// An OCaml string is an object with three fields:\n// - tag 't'\n// - length 'l'\n// - contents 'c'\n//\n// The contents of the string can be either a JavaScript array or\n// a JavaScript string. The length of this string can be less than the\n// length of the OCaml string. In this case, remaining bytes are\n// assumed to be zeroes. Arrays are mutable but consumes more memory\n// than strings. A common pattern is to start from an empty string and\n// progressively fill it from the start. Partial strings makes it\n// possible to implement this efficiently.\n//\n// When converting to and from UTF-16, we keep track of whether the\n// string is composed only of ASCII characters (in which case, no\n// conversion needs to be performed) or not.\n//\n// The string tag can thus take the following values:\n// full string BYTE | UNKNOWN: 0\n// BYTE | ASCII: 9\n// BYTE | NOT_ASCII: 8\n// string prefix PARTIAL: 2\n// array ARRAY: 4\n//\n// One can use bit masking to discriminate these different cases:\n// known_encoding(x) = x&8\n// is_ascii(x) = x&1\n// kind(x) = x&6\n\n//Provides: caml_str_repeat\nfunction caml_str_repeat(n, s) {\n if(n == 0) return \"\";\n if (s.repeat) {return s.repeat(n);} // ECMAscript 6 and Firefox 24+\n var r = \"\", l = 0;\n for(;;) {\n if (n & 1) r += s;\n n >>= 1;\n if (n == 0) return r;\n s += s;\n l++;\n if (l == 9) {\n s.slice(0,1); // flatten the string\n // then, the flattening of the whole string will be faster,\n // as it will be composed of larger pieces\n }\n }\n}\n\n//Provides: caml_subarray_to_jsbytes\n//Weakdef\n// Pre ECMAScript 5, [apply] would not support array-like object.\n// In such setup, Typed_array would be implemented as polyfill, and [f.apply] would\n// fail here. Mark the primitive as Weakdef, so that people can override it easily.\nfunction caml_subarray_to_jsbytes (a, i, len) {\n var f = String.fromCharCode;\n if (i == 0 && len <= 4096 && len == a.length) return f.apply (null, a);\n var s = \"\";\n for (; 0 < len; i += 1024,len-=1024)\n s += f.apply (null, a.slice(i,i + Math.min(len, 1024)));\n return s;\n}\n\n//Provides: caml_utf8_of_utf16\nfunction caml_utf8_of_utf16(s) {\n for (var b = \"\", t = b, c, d, i = 0, l = s.length; i < l; i++) {\n c = s.charCodeAt(i);\n if (c < 0x80) {\n for (var j = i + 1; (j < l) && (c = s.charCodeAt(j)) < 0x80; j++);\n if (j - i > 512) { t.substr(0, 1); b += t; t = \"\"; b += s.slice(i, j) }\n else t += s.slice(i, j);\n if (j == l) break;\n i = j;\n }\n if (c < 0x800) {\n t += String.fromCharCode(0xc0 | (c >> 6));\n t += String.fromCharCode(0x80 | (c & 0x3f));\n } else if (c < 0xd800 || c >= 0xdfff) {\n t += String.fromCharCode(0xe0 | (c >> 12),\n 0x80 | ((c >> 6) & 0x3f),\n 0x80 | (c & 0x3f));\n } else if (c >= 0xdbff || i + 1 == l ||\n (d = s.charCodeAt(i + 1)) < 0xdc00 || d > 0xdfff) {\n // Unmatched surrogate pair, replaced by \\ufffd (replacement character)\n t += \"\\xef\\xbf\\xbd\";\n } else {\n i++;\n c = (c << 10) + d - 0x35fdc00;\n t += String.fromCharCode(0xf0 | (c >> 18),\n 0x80 | ((c >> 12) & 0x3f),\n 0x80 | ((c >> 6) & 0x3f),\n 0x80 | (c & 0x3f));\n }\n if (t.length > 1024) {t.substr(0, 1); b += t; t = \"\";}\n }\n return b+t;\n}\n\n//Provides: caml_utf16_of_utf8\nfunction caml_utf16_of_utf8(s) {\n for (var b = \"\", t = \"\", c, c1, c2, v, i = 0, l = s.length; i < l; i++) {\n c1 = s.charCodeAt(i);\n if (c1 < 0x80) {\n for (var j = i + 1; (j < l) && (c1 = s.charCodeAt(j)) < 0x80; j++);\n if (j - i > 512) { t.substr(0, 1); b += t; t = \"\"; b += s.slice(i, j) }\n else t += s.slice(i, j);\n if (j == l) break;\n i = j;\n }\n v = 1;\n if ((++i < l) && (((c2 = s.charCodeAt(i)) & -64) == 128)) {\n c = c2 + (c1 << 6);\n if (c1 < 0xe0) {\n v = c - 0x3080;\n if (v < 0x80) v = 1;\n } else {\n v = 2;\n if ((++i < l) && (((c2 = s.charCodeAt(i)) & -64) == 128)) {\n c = c2 + (c << 6);\n if (c1 < 0xf0) {\n v = c - 0xe2080;\n if ((v < 0x800) || ((v >= 0xd7ff) && (v < 0xe000))) v = 2;\n } else {\n v = 3;\n if ((++i < l) && (((c2 = s.charCodeAt(i)) & -64) == 128) &&\n (c1 < 0xf5)) {\n v = c2 - 0x3c82080 + (c << 6);\n if (v < 0x10000 || v > 0x10ffff) v = 3;\n }\n }\n }\n }\n }\n if (v < 4) { // Invalid sequence\n i -= v;\n t += \"\\ufffd\";\n } else if (v > 0xffff)\n t += String.fromCharCode(0xd7c0 + (v >> 10), 0xdc00 + (v & 0x3FF))\n else\n t += String.fromCharCode(v);\n if (t.length > 1024) {t.substr(0, 1); b += t; t = \"\";}\n }\n return b+t;\n}\n\n//Provides: jsoo_is_ascii\nfunction jsoo_is_ascii (s) {\n // The regular expression gets better at around this point for all browsers\n if (s.length < 24) {\n // Spidermonkey gets much slower when s.length >= 24 (on 64 bit archs)\n for (var i = 0; i < s.length; i++) if (s.charCodeAt(i) > 127) return false;\n return true;\n } else\n return !/[^\\x00-\\x7f]/.test(s);\n}\n\n//Provides: caml_bytes_unsafe_get mutable\nfunction caml_bytes_unsafe_get (s, i) {\n switch (s.t & 6) {\n default: /* PARTIAL */\n if (i >= s.c.length) return 0;\n case 0: /* BYTES */\n return s.c.charCodeAt(i);\n case 4: /* ARRAY */\n return s.c[i]\n }\n}\n\n//Provides: caml_bytes_unsafe_set\n//Requires: caml_convert_bytes_to_array\nfunction caml_bytes_unsafe_set (s, i, c) {\n // The OCaml compiler uses Char.unsafe_chr on integers larger than 255!\n c &= 0xff;\n if (s.t != 4 /* ARRAY */) {\n if (i == s.c.length) {\n s.c += String.fromCharCode (c);\n if (i + 1 == s.l) s.t = 0; /*BYTES | UNKOWN*/\n return 0;\n }\n caml_convert_bytes_to_array (s);\n }\n s.c[i] = c;\n return 0;\n}\n\n//Provides: caml_string_bound_error\n//Requires: caml_invalid_argument\nfunction caml_string_bound_error () {\n caml_invalid_argument (\"index out of bounds\");\n}\n\n//Provides: caml_bytes_bound_error\n//Requires: caml_invalid_argument\nfunction caml_bytes_bound_error () {\n caml_invalid_argument (\"index out of bounds\");\n}\n\n//Provides: caml_string_get\n//Requires: caml_string_bound_error, caml_string_unsafe_get\n//Requires: caml_ml_string_length\nfunction caml_string_get (s, i) {\n if (i >>> 0 >= caml_ml_string_length(s)) caml_string_bound_error();\n return caml_string_unsafe_get (s, i);\n}\n\n//Provides: caml_string_get16\n//Requires: caml_string_unsafe_get, caml_string_bound_error\n//Requires: caml_ml_string_length\nfunction caml_string_get16(s,i) {\n if (i >>> 0 >= caml_ml_string_length(s) - 1) caml_string_bound_error();\n var b1 = caml_string_unsafe_get (s, i),\n b2 = caml_string_unsafe_get (s, i + 1);\n return (b2 << 8 | b1);\n}\n\n//Provides: caml_bytes_get16\n//Requires: caml_bytes_unsafe_get, caml_bytes_bound_error\nfunction caml_bytes_get16(s,i) {\n if (i >>> 0 >= s.l - 1) caml_bytes_bound_error();\n var b1 = caml_bytes_unsafe_get (s, i),\n b2 = caml_bytes_unsafe_get (s, i + 1);\n return (b2 << 8 | b1);\n}\n\n//Provides: caml_string_get32\n//Requires: caml_string_unsafe_get, caml_string_bound_error\n//Requires: caml_ml_string_length\nfunction caml_string_get32(s,i) {\n if (i >>> 0 >= caml_ml_string_length(s) - 3) caml_string_bound_error();\n var b1 = caml_string_unsafe_get (s, i),\n b2 = caml_string_unsafe_get (s, i + 1),\n b3 = caml_string_unsafe_get (s, i + 2),\n b4 = caml_string_unsafe_get (s, i + 3);\n return (b4 << 24 | b3 << 16 | b2 << 8 | b1);\n}\n\n//Provides: caml_bytes_get32\n//Requires: caml_bytes_unsafe_get, caml_bytes_bound_error\nfunction caml_bytes_get32(s,i) {\n if (i >>> 0 >= s.l - 3) caml_bytes_bound_error();\n var b1 = caml_bytes_unsafe_get (s, i),\n b2 = caml_bytes_unsafe_get (s, i + 1),\n b3 = caml_bytes_unsafe_get (s, i + 2),\n b4 = caml_bytes_unsafe_get (s, i + 3);\n return (b4 << 24 | b3 << 16 | b2 << 8 | b1);\n}\n\n//Provides: caml_string_get64\n//Requires: caml_string_unsafe_get, caml_string_bound_error\n//Requires: caml_int64_of_bytes\n//Requires: caml_ml_string_length\nfunction caml_string_get64(s,i) {\n if (i >>> 0 >= caml_ml_string_length(s) - 7) caml_string_bound_error();\n var a = new Array(8);\n for(var j = 0; j < 8; j++){\n a[7 - j] = caml_string_unsafe_get (s, i + j);\n }\n return caml_int64_of_bytes(a);\n}\n\n//Provides: caml_bytes_get64\n//Requires: caml_bytes_unsafe_get, caml_bytes_bound_error\n//Requires: caml_int64_of_bytes\nfunction caml_bytes_get64(s,i) {\n if (i >>> 0 >= s.l - 7) caml_bytes_bound_error();\n var a = new Array(8);\n for(var j = 0; j < 8; j++){\n a[7 - j] = caml_bytes_unsafe_get (s, i + j);\n }\n return caml_int64_of_bytes(a);\n}\n\n//Provides: caml_bytes_get\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_get\nfunction caml_bytes_get (s, i) {\n if (i >>> 0 >= s.l) caml_bytes_bound_error();\n return caml_bytes_unsafe_get (s, i);\n}\n\n//Provides: caml_string_set\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set (s, i, c) {\n caml_failwith(\"caml_string_set\");\n}\n\n//Provides: caml_string_set\n//Requires: caml_string_unsafe_set, caml_string_bound_error\n//If: !js-string\nfunction caml_string_set (s, i, c) {\n if (i >>> 0 >= s.l) caml_string_bound_error();\n return caml_string_unsafe_set (s, i, c);\n}\n\n//Provides: caml_bytes_set16\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\nfunction caml_bytes_set16(s,i,i16){\n if (i >>> 0 >= s.l - 1) caml_bytes_bound_error();\n var b2 = 0xFF & i16 >> 8,\n b1 = 0xFF & i16;\n caml_bytes_unsafe_set (s, i + 0, b1);\n caml_bytes_unsafe_set (s, i + 1, b2);\n return 0\n}\n\n//Provides: caml_string_set16\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set16(s,i,i16){\n caml_failwith(\"caml_string_set16\");\n}\n\n//Provides: caml_string_set16\n//Requires: caml_bytes_set16\n//If: !js-string\nfunction caml_string_set16(s,i,i16){\n return caml_bytes_set16(s,i,i16);\n}\n\n//Provides: caml_bytes_set32\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\nfunction caml_bytes_set32(s,i,i32){\n if (i >>> 0 >= s.l - 3) caml_bytes_bound_error();\n var b4 = 0xFF & i32 >> 24,\n b3 = 0xFF & i32 >> 16,\n b2 = 0xFF & i32 >> 8,\n b1 = 0xFF & i32;\n caml_bytes_unsafe_set (s, i + 0, b1);\n caml_bytes_unsafe_set (s, i + 1, b2);\n caml_bytes_unsafe_set (s, i + 2, b3);\n caml_bytes_unsafe_set (s, i + 3, b4);\n return 0\n}\n\n//Provides: caml_string_set32\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set32(s,i,i32){\n caml_failwith(\"caml_string_set32\");\n}\n\n//Provides: caml_string_set32\n//Requires: caml_bytes_set32\n//If: !js-string\nfunction caml_string_set32(s,i,i32){\n return caml_bytes_set32(s,i,i32);\n}\n\n//Provides: caml_bytes_set64\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\n//Requires: caml_int64_to_bytes\nfunction caml_bytes_set64(s,i,i64){\n if (i >>> 0 >= s.l - 7) caml_bytes_bound_error();\n var a = caml_int64_to_bytes(i64);\n for(var j = 0; j < 8; j++) {\n caml_bytes_unsafe_set (s, i + 7 - j, a[j]);\n }\n return 0\n}\n\n//Provides: caml_string_set64\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_set64(s,i,i64){\n caml_failwith(\"caml_string_set64\");\n}\n\n//Provides: caml_string_set64\n//Requires: caml_bytes_set64\n//If: !js-string\nfunction caml_string_set64(s,i,i64){\n return caml_bytes_set64(s,i,i64);\n}\n\n//Provides: caml_bytes_set\n//Requires: caml_bytes_bound_error, caml_bytes_unsafe_set\nfunction caml_bytes_set (s, i, c) {\n if (i >>> 0 >= s.l) caml_bytes_bound_error();\n return caml_bytes_unsafe_set (s, i, c);\n}\n\n//Provides: caml_bytes_of_utf16_jsstring\n//Requires: jsoo_is_ascii, caml_utf8_of_utf16, MlBytes\nfunction caml_bytes_of_utf16_jsstring (s) {\n var tag = 9 /* BYTES | ASCII */;\n if (!jsoo_is_ascii(s))\n tag = 8 /* BYTES | NOT_ASCII */, s = caml_utf8_of_utf16(s);\n return new MlBytes(tag, s, s.length);\n}\n\n\n//Provides: MlBytes\n//Requires: caml_convert_string_to_bytes, jsoo_is_ascii, caml_utf16_of_utf8\nfunction MlBytes (tag, contents, length) {\n this.t=tag; this.c=contents; this.l=length;\n}\nMlBytes.prototype.toString = function(){\n switch (this.t) {\n case 9: /*BYTES | ASCII*/\n return this.c;\n default:\n caml_convert_string_to_bytes(this);\n case 0: /*BYTES | UNKOWN*/\n if (jsoo_is_ascii(this.c)) {\n this.t = 9; /*BYTES | ASCII*/\n return this.c;\n }\n this.t = 8; /*BYTES | NOT_ASCII*/\n case 8: /*BYTES | NOT_ASCII*/\n return this.c;\n }\n};\nMlBytes.prototype.toUtf16 = function (){\n var r = this.toString();\n if(this.t == 9) return r\n return caml_utf16_of_utf8(r);\n}\nMlBytes.prototype.slice = function (){\n var content = this.t == 4 ? this.c.slice() : this.c;\n return new MlBytes(this.t,content,this.l);\n}\n\n//Provides: caml_convert_string_to_bytes\n//Requires: caml_str_repeat, caml_subarray_to_jsbytes\nfunction caml_convert_string_to_bytes (s) {\n /* Assumes not BYTES */\n if (s.t == 2 /* PARTIAL */)\n s.c += caml_str_repeat(s.l - s.c.length, '\\0')\n else\n s.c = caml_subarray_to_jsbytes (s.c, 0, s.c.length);\n s.t = 0; /*BYTES | UNKOWN*/\n}\n\n//Provides: caml_convert_bytes_to_array\nfunction caml_convert_bytes_to_array (s) {\n /* Assumes not ARRAY */\n if(globalThis.Uint8Array) {\n var a = new globalThis.Uint8Array(s.l);\n } else {\n var a = new Array(s.l);\n }\n var b = s.c, l = b.length, i = 0;\n for (; i < l; i++) a[i] = b.charCodeAt(i);\n for (l = s.l; i < l; i++) a[i] = 0;\n s.c = a;\n s.t = 4; /* ARRAY */\n return a;\n}\n\n//Provides: caml_array_of_bytes mutable\n//Requires: caml_convert_bytes_to_array\nfunction caml_array_of_bytes (s) {\n if (s.t != 4 /* ARRAY */) caml_convert_bytes_to_array(s);\n return s.c;\n}\n\n//Provides: caml_array_of_string mutable\n//Requires: caml_convert_bytes_to_array\n//Requires: caml_ml_string_length, caml_string_unsafe_get\nfunction caml_array_of_string (s) {\n var l = caml_ml_string_length(s);\n var a = new Array(l);\n var i = 0;\n for (; i < l; i++) a[i] = caml_string_unsafe_get(s,i);\n return a;\n}\n\n//Provides: caml_create_string const\n//Requires: MlBytes, caml_invalid_argument\n//If: !js-string\nfunction caml_create_string(len) {\n if(len < 0) caml_invalid_argument(\"String.create\");\n return new MlBytes(len?2:9,\"\",len);\n}\n\n//Provides: caml_create_string const\n//Requires: caml_invalid_argument\n//If: js-string\nfunction caml_create_string(len) {\n caml_invalid_argument(\"String.create\");\n}\n\n//Provides: caml_create_bytes const\n//Requires: MlBytes,caml_invalid_argument\nfunction caml_create_bytes(len) {\n if (len < 0) caml_invalid_argument(\"Bytes.create\");\n return new MlBytes(len?2:9,\"\",len);\n}\n\n//Provides: caml_string_of_array\n//Requires: caml_subarray_to_jsbytes, caml_string_of_jsbytes\nfunction caml_string_of_array (a) {\n return caml_string_of_jsbytes(caml_subarray_to_jsbytes(a,0,a.length));\n}\n\n//Provides: caml_bytes_of_array\n//Requires: MlBytes\nfunction caml_bytes_of_array (a) {\n return new MlBytes(4,a,a.length);\n}\n\n//Provides: caml_bytes_compare mutable\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_compare(s1, s2) {\n (s1.t & 6) && caml_convert_string_to_bytes(s1);\n (s2.t & 6) && caml_convert_string_to_bytes(s2);\n return (s1.c < s2.c)?-1:(s1.c > s2.c)?1:0;\n}\n\n\n//Provides: caml_bytes_equal mutable (const, const)\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_equal(s1, s2) {\n if(s1 === s2) return 1;\n (s1.t & 6) && caml_convert_string_to_bytes(s1);\n (s2.t & 6) && caml_convert_string_to_bytes(s2);\n return (s1.c == s2.c)?1:0;\n}\n\n//Provides: caml_string_notequal mutable (const, const)\n//Requires: caml_string_equal\nfunction caml_string_notequal(s1, s2) { return 1-caml_string_equal(s1, s2); }\n\n//Provides: caml_bytes_notequal mutable (const, const)\n//Requires: caml_bytes_equal\nfunction caml_bytes_notequal(s1, s2) { return 1-caml_bytes_equal(s1, s2); }\n\n//Provides: caml_bytes_lessequal mutable\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_lessequal(s1, s2) {\n (s1.t & 6) && caml_convert_string_to_bytes(s1);\n (s2.t & 6) && caml_convert_string_to_bytes(s2);\n return (s1.c <= s2.c)?1:0;\n}\n\n//Provides: caml_bytes_lessthan mutable\n//Requires: caml_convert_string_to_bytes\nfunction caml_bytes_lessthan(s1, s2) {\n (s1.t & 6) && caml_convert_string_to_bytes(s1);\n (s2.t & 6) && caml_convert_string_to_bytes(s2);\n return (s1.c < s2.c)?1:0;\n}\n\n//Provides: caml_string_greaterequal\n//Requires: caml_string_lessequal\nfunction caml_string_greaterequal(s1, s2) {\n return caml_string_lessequal(s2,s1);\n}\n//Provides: caml_bytes_greaterequal\n//Requires: caml_bytes_lessequal\nfunction caml_bytes_greaterequal(s1, s2) {\n return caml_bytes_lessequal(s2,s1);\n}\n\n//Provides: caml_string_greaterthan\n//Requires: caml_string_lessthan\nfunction caml_string_greaterthan(s1, s2) {\n return caml_string_lessthan(s2, s1);\n}\n\n//Provides: caml_bytes_greaterthan\n//Requires: caml_bytes_lessthan\nfunction caml_bytes_greaterthan(s1, s2) {\n return caml_bytes_lessthan(s2, s1);\n}\n\n//Provides: caml_fill_bytes\n//Requires: caml_str_repeat, caml_convert_bytes_to_array\nfunction caml_fill_bytes(s, i, l, c) {\n if (l > 0) {\n if (i == 0 && (l >= s.l || (s.t == 2 /* PARTIAL */ && l >= s.c.length))) {\n if (c == 0) {\n s.c = \"\";\n s.t = 2; /* PARTIAL */\n } else {\n s.c = caml_str_repeat (l, String.fromCharCode(c));\n s.t = (l == s.l)?0 /* BYTES | UNKOWN */ :2; /* PARTIAL */\n }\n } else {\n if (s.t != 4 /* ARRAY */) caml_convert_bytes_to_array(s);\n for (l += i; i < l; i++) s.c[i] = c;\n }\n }\n return 0;\n}\n\n//Provides: caml_fill_string\n//Requires: caml_fill_bytes\nvar caml_fill_string = caml_fill_bytes\n\n//Provides: caml_blit_bytes\n//Requires: caml_subarray_to_jsbytes, caml_convert_bytes_to_array\nfunction caml_blit_bytes(s1, i1, s2, i2, len) {\n if (len == 0) return 0;\n if ((i2 == 0) &&\n (len >= s2.l || (s2.t == 2 /* PARTIAL */ && len >= s2.c.length))) {\n s2.c = (s1.t == 4 /* ARRAY */)?\n caml_subarray_to_jsbytes(s1.c, i1, len):\n (i1 == 0 && s1.c.length == len)?s1.c:s1.c.substr(i1, len);\n s2.t = (s2.c.length == s2.l)?0 /* BYTES | UNKOWN */ :2; /* PARTIAL */\n } else if (s2.t == 2 /* PARTIAL */ && i2 == s2.c.length) {\n s2.c += (s1.t == 4 /* ARRAY */)?\n caml_subarray_to_jsbytes(s1.c, i1, len):\n (i1 == 0 && s1.c.length == len)?s1.c:s1.c.substr(i1, len);\n s2.t = (s2.c.length == s2.l)?0 /* BYTES | UNKOWN */ :2; /* PARTIAL */\n } else {\n if (s2.t != 4 /* ARRAY */) caml_convert_bytes_to_array(s2);\n var c1 = s1.c, c2 = s2.c;\n if (s1.t == 4 /* ARRAY */) {\n if (i2 <= i1) {\n for (var i = 0; i < len; i++) c2 [i2 + i] = c1 [i1 + i];\n } else {\n for (var i = len - 1; i >= 0; i--) c2 [i2 + i] = c1 [i1 + i];\n }\n } else {\n var l = Math.min (len, c1.length - i1);\n for (var i = 0; i < l; i++) c2 [i2 + i] = c1.charCodeAt(i1 + i);\n for (; i < len; i++) c2 [i2 + i] = 0;\n }\n }\n return 0;\n}\n\n//Provides: caml_blit_string\n//Requires: caml_blit_bytes, caml_bytes_of_string\nfunction caml_blit_string(a,b,c,d,e) {\n caml_blit_bytes(caml_bytes_of_string(a),b,c,d,e);\n return 0\n}\n\n//Provides: caml_ml_bytes_length const\nfunction caml_ml_bytes_length(s) { return s.l }\n\n//Provides: caml_string_unsafe_get const\n//If: js-string\nfunction caml_string_unsafe_get (s, i) {\n return s.charCodeAt(i);\n}\n\n//Provides: caml_string_unsafe_set\n//Requires: caml_failwith\n//If: js-string\nfunction caml_string_unsafe_set (s, i, c) {\n caml_failwith(\"caml_string_unsafe_set\");\n}\n\n//Provides: caml_ml_string_length const\n//If: js-string\nfunction caml_ml_string_length(s) {\n return s.length\n}\n\n//Provides: caml_string_compare const\n//If: js-string\nfunction caml_string_compare(s1, s2) {\n return (s1 < s2)?-1:(s1 > s2)?1:0;\n}\n\n//Provides: caml_string_equal const\n//If: js-string\nfunction caml_string_equal(s1, s2) {\n if(s1 === s2) return 1;\n return 0;\n}\n\n//Provides: caml_string_lessequal const\n//If: js-string\nfunction caml_string_lessequal(s1, s2) {\n return (s1 <= s2)?1:0;\n}\n\n//Provides: caml_string_lessthan const\n//If: js-string\nfunction caml_string_lessthan(s1, s2) {\n return (s1 < s2)?1:0;\n}\n\n//Provides: caml_string_of_bytes\n//Requires: caml_convert_string_to_bytes, caml_string_of_jsbytes\n//If: js-string\nfunction caml_string_of_bytes(s) {\n (s.t & 6) && caml_convert_string_to_bytes(s);\n return caml_string_of_jsbytes(s.c);\n}\n\n//Provides: caml_bytes_of_string const\n//Requires: caml_bytes_of_jsbytes, caml_jsbytes_of_string\n//If: js-string\nfunction caml_bytes_of_string(s) {\n return caml_bytes_of_jsbytes(caml_jsbytes_of_string(s));\n}\n\n//Provides: caml_string_of_jsbytes const\n//If: js-string\nfunction caml_string_of_jsbytes(x) { return x }\n\n//Provides: caml_jsbytes_of_string const\n//If: js-string\nfunction caml_jsbytes_of_string(x) { return x }\n\n//Provides: caml_jsstring_of_string const\n//Requires: jsoo_is_ascii, caml_utf16_of_utf8\n//If: js-string\nfunction caml_jsstring_of_string(s) {\n if(jsoo_is_ascii(s))\n return s;\n return caml_utf16_of_utf8(s); }\n\n//Provides: caml_string_of_jsstring const\n//Requires: jsoo_is_ascii, caml_utf8_of_utf16, caml_string_of_jsbytes\n//If: js-string\nfunction caml_string_of_jsstring (s) {\n if (jsoo_is_ascii(s))\n return caml_string_of_jsbytes(s)\n else return caml_string_of_jsbytes(caml_utf8_of_utf16(s));\n}\n\n//Provides: caml_bytes_of_jsbytes const\n//Requires: MlBytes\nfunction caml_bytes_of_jsbytes(s) { return new MlBytes(0,s,s.length); }\n\n\n// The section below should be used when use-js-string=false\n\n//Provides: caml_string_unsafe_get const\n//Requires: caml_bytes_unsafe_get\n//If: !js-string\nfunction caml_string_unsafe_get (s, i) {\n return caml_bytes_unsafe_get(s,i);\n}\n\n//Provides: caml_string_unsafe_set\n//Requires: caml_bytes_unsafe_set\n//If: !js-string\nfunction caml_string_unsafe_set (s, i, c) {\n return caml_bytes_unsafe_set(s,i,c);\n}\n\n//Provides: caml_ml_string_length const\n//Requires: caml_ml_bytes_length\n//If: !js-string\nfunction caml_ml_string_length(s) {\n return caml_ml_bytes_length(s)\n}\n\n//Provides: caml_string_compare\n//Requires: caml_bytes_compare\n//If: !js-string\nfunction caml_string_compare(s1, s2) {\n return caml_bytes_compare(s1,s2)\n}\n\n//Provides: caml_string_equal\n//Requires: caml_bytes_equal\n//If: !js-string\nfunction caml_string_equal(s1, s2) {\n return caml_bytes_equal(s1,s2)\n}\n\n//Provides: caml_string_lessequal\n//Requires: caml_bytes_lessequal\n//If: !js-string\nfunction caml_string_lessequal(s1, s2) {\n return caml_bytes_lessequal(s1,s2)\n}\n\n//Provides: caml_string_lessthan\n//Requires: caml_bytes_lessthan\n//If: !js-string\nfunction caml_string_lessthan(s1, s2) {\n return caml_bytes_lessthan(s1,s2)\n}\n\n//Provides: caml_string_of_bytes\n//If: !js-string\nfunction caml_string_of_bytes(s) { return s }\n\n//Provides: caml_bytes_of_string const\n//If: !js-string\nfunction caml_bytes_of_string(s) { return s }\n\n//Provides: caml_string_of_jsbytes const\n//Requires: caml_bytes_of_jsbytes\n//If: !js-string\nfunction caml_string_of_jsbytes(s) { return caml_bytes_of_jsbytes(s); }\n\n//Provides: caml_jsbytes_of_string const\n//Requires: caml_convert_string_to_bytes\n//If: !js-string\nfunction caml_jsbytes_of_string(s) {\n (s.t & 6) && caml_convert_string_to_bytes(s);\n return s.c }\n\n//Provides: caml_jsstring_of_string mutable (const)\n//If: !js-string\nfunction caml_jsstring_of_string(s){\n return s.toUtf16()\n}\n\n//Provides: caml_string_of_jsstring\n//Requires: caml_bytes_of_utf16_jsstring\n//If: !js-string\nfunction caml_string_of_jsstring (s) {\n return caml_bytes_of_utf16_jsstring(s);\n}\n\n//Provides: caml_is_ml_bytes\n//Requires: MlBytes\nfunction caml_is_ml_bytes(s) {\n return (s instanceof MlBytes);\n}\n\n//Provides: caml_ml_bytes_content\n//Requires: MlBytes, caml_convert_string_to_bytes\nfunction caml_ml_bytes_content(s) {\n switch (s.t & 6) {\n default: /* PARTIAL */\n caml_convert_string_to_bytes(s);\n case 0: /* BYTES */\n return s.c;\n case 4:\n return s.c\n }\n}\n\n//Provides: caml_is_ml_string\n//Requires: jsoo_is_ascii\n//If: js-string\nfunction caml_is_ml_string(s) {\n return (typeof s === \"string\" && !/[^\\x00-\\xff]/.test(s));\n}\n\n//Provides: caml_is_ml_string\n//Requires: caml_is_ml_bytes\n//If: !js-string\nfunction caml_is_ml_string(s) {\n return caml_is_ml_bytes(s);\n}\n\n// The functions below are deprecated\n\n//Provides: caml_js_to_byte_string const\n//Requires: caml_string_of_jsbytes\nfunction caml_js_to_byte_string(s) { return caml_string_of_jsbytes(s) }\n\n//Provides: caml_new_string\n//Requires: caml_string_of_jsbytes\nfunction caml_new_string (s) { return caml_string_of_jsbytes(s) }\n\n//Provides: caml_js_from_string mutable (const)\n//Requires: caml_jsstring_of_string\nfunction caml_js_from_string(s) {\n return caml_jsstring_of_string(s)\n}\n\n//Provides: caml_to_js_string mutable (const)\n//Requires: caml_jsstring_of_string\nfunction caml_to_js_string(s) {\n return caml_jsstring_of_string(s)\n}\n\n//Provides: caml_js_to_string const\n//Requires: caml_string_of_jsstring\nfunction caml_js_to_string (s) {\n return caml_string_of_jsstring(s);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard, Andy Ray\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n//\n// Bigarray.\n//\n// - all bigarray types including Int64 and Complex.\n// - fortran + c layouts\n// - sub/slice/reshape\n// - retain fast path for 1d array access\n\n//Provides: caml_ba_init const\nfunction caml_ba_init() {\n return 0;\n}\n\n//Provides: caml_ba_get_size\n//Requires: caml_invalid_argument\nfunction caml_ba_get_size(dims) {\n var n_dims = dims.length;\n var size = 1;\n for (var i = 0; i < n_dims; i++) {\n if (dims[i] < 0)\n caml_invalid_argument(\"Bigarray.create: negative dimension\");\n size = size * dims[i];\n }\n return size;\n}\n\n//Provides: caml_ba_get_size_per_element\nfunction caml_ba_get_size_per_element(kind){\n switch(kind){\n case 7: case 10: case 11: return 2;\n default: return 1;\n }\n}\n\n//Provides: caml_ba_create_buffer\n//Requires: caml_ba_get_size_per_element\n//Requires: caml_invalid_argument\nfunction caml_ba_create_buffer(kind, size){\n var g = globalThis;\n var view;\n switch(kind){\n case 0: view = g.Float32Array; break;\n case 1: view = g.Float64Array; break;\n case 2: view = g.Int8Array; break;\n case 3: view = g.Uint8Array; break;\n case 4: view = g.Int16Array; break;\n case 5: view = g.Uint16Array; break;\n case 6: view = g.Int32Array; break;\n case 7: view = g.Int32Array; break;\n case 8: view = g.Int32Array; break;\n case 9: view = g.Int32Array; break;\n case 10: view = g.Float32Array; break;\n case 11: view = g.Float64Array; break;\n case 12: view = g.Uint8Array; break;\n }\n if (!view) caml_invalid_argument(\"Bigarray.create: unsupported kind\");\n var data = new view(size * caml_ba_get_size_per_element(kind));\n return data;\n}\n\n//Provides: caml_ba_custom_name\n//Version: < 4.11\nvar caml_ba_custom_name = \"_bigarray\"\n\n//Provides: caml_ba_custom_name\n//Version: >= 4.11\nvar caml_ba_custom_name = \"_bigarr02\"\n\n//Provides: Ml_Bigarray\n//Requires: caml_array_bound_error, caml_invalid_argument, caml_ba_custom_name\n//Requires: caml_int64_create_lo_hi, caml_int64_hi32, caml_int64_lo32\nfunction Ml_Bigarray (kind, layout, dims, buffer) {\n\n this.kind = kind ;\n this.layout = layout;\n this.dims = dims;\n this.data = buffer;\n}\n\nMl_Bigarray.prototype.caml_custom = caml_ba_custom_name;\n\nMl_Bigarray.prototype.offset = function (arg) {\n var ofs = 0;\n if(typeof arg === \"number\") arg = [arg];\n if (! (arg instanceof Array)) caml_invalid_argument(\"bigarray.js: invalid offset\");\n if (this.dims.length != arg.length)\n caml_invalid_argument(\"Bigarray.get/set: bad number of dimensions\");\n if(this.layout == 0 /* c_layout */) {\n for (var i = 0; i < this.dims.length; i++) {\n if (arg[i] < 0 || arg[i] >= this.dims[i])\n caml_array_bound_error();\n ofs = (ofs * this.dims[i]) + arg[i];\n }\n } else {\n for (var i = this.dims.length - 1; i >= 0; i--) {\n if (arg[i] < 1 || arg[i] > this.dims[i]){\n caml_array_bound_error();\n }\n ofs = (ofs * this.dims[i]) + (arg[i] - 1);\n }\n }\n return ofs;\n}\n\nMl_Bigarray.prototype.get = function (ofs) {\n switch(this.kind){\n case 7:\n // Int64\n var l = this.data[ofs * 2 + 0];\n var h = this.data[ofs * 2 + 1];\n return caml_int64_create_lo_hi(l,h);\n case 10: case 11:\n // Complex32, Complex64\n var r = this.data[ofs * 2 + 0];\n var i = this.data[ofs * 2 + 1];\n return [254, r, i];\n default:\n return this.data[ofs]\n }\n}\n\nMl_Bigarray.prototype.set = function (ofs,v) {\n switch(this.kind){\n case 7:\n // Int64\n this.data[ofs * 2 + 0] = caml_int64_lo32(v);\n this.data[ofs * 2 + 1] = caml_int64_hi32(v);\n break;\n case 10: case 11:\n // Complex32, Complex64\n this.data[ofs * 2 + 0] = v[1];\n this.data[ofs * 2 + 1] = v[2];\n break;\n default:\n this.data[ofs] = v;\n break;\n }\n return 0\n}\n\n\nMl_Bigarray.prototype.fill = function (v) {\n switch(this.kind){\n case 7:\n // Int64\n var a = caml_int64_lo32(v);\n var b = caml_int64_hi32(v);\n if(a == b){\n this.data.fill(a);\n }\n else {\n for(var i = 0; i y)\n return 1;\n if (x != y) {\n if (!total) return NaN;\n if (x == x) return 1;\n if (y == y) return -1;\n }\n }\n break;\n case 7:\n // Int64\n for (var i = 0; i < this.data.length; i+=2) {\n // Check highest bits first\n if (this.data[i+1] < b.data[i+1])\n return -1;\n if (this.data[i+1] > b.data[i+1])\n return 1;\n if ((this.data[i] >>> 0) < (b.data[i] >>> 0))\n return -1;\n if ((this.data[i] >>> 0) > (b.data[i] >>> 0))\n return 1;\n }\n break;\n case 2:\n case 3:\n case 4:\n case 5:\n case 6:\n case 8:\n case 9:\n case 12:\n for (var i = 0; i < this.data.length; i++) {\n if (this.data[i] < b.data[i])\n return -1;\n if (this.data[i] > b.data[i])\n return 1;\n }\n break;\n }\n return 0;\n}\n\n//Provides: Ml_Bigarray_c_1_1\n//Requires: Ml_Bigarray, caml_array_bound_error, caml_invalid_argument\nfunction Ml_Bigarray_c_1_1(kind, layout, dims, buffer) {\n this.kind = kind ;\n this.layout = layout;\n this.dims = dims;\n this.data = buffer;\n}\n\nMl_Bigarray_c_1_1.prototype = new Ml_Bigarray()\nMl_Bigarray_c_1_1.prototype.offset = function (arg) {\n if(typeof arg !== \"number\"){\n if((arg instanceof Array) && arg.length == 1)\n arg = arg[0];\n else caml_invalid_argument(\"Ml_Bigarray_c_1_1.offset\");\n }\n if (arg < 0 || arg >= this.dims[0])\n caml_array_bound_error();\n return arg;\n}\n\nMl_Bigarray_c_1_1.prototype.get = function (ofs) {\n return this.data[ofs];\n}\n\nMl_Bigarray_c_1_1.prototype.set = function (ofs,v) {\n this.data[ofs] = v;\n return 0\n}\n\nMl_Bigarray_c_1_1.prototype.fill = function (v) {\n this.data.fill(v);\n return 0\n}\n\n//Provides: caml_ba_compare\nfunction caml_ba_compare(a,b,total){\n return a.compare(b,total)\n}\n\n//Provides: caml_ba_create_unsafe\n//Requires: Ml_Bigarray, Ml_Bigarray_c_1_1, caml_ba_get_size, caml_ba_get_size_per_element\n//Requires: caml_invalid_argument\nfunction caml_ba_create_unsafe(kind, layout, dims, data){\n var size_per_element = caml_ba_get_size_per_element(kind);\n if(caml_ba_get_size(dims) * size_per_element != data.length) {\n caml_invalid_argument(\"length doesn't match dims\");\n }\n if(layout == 0 && // c_layout\n dims.length == 1 && // Array1\n size_per_element == 1) // 1-to-1 mapping\n return new Ml_Bigarray_c_1_1(kind, layout, dims, data);\n return new Ml_Bigarray(kind, layout, dims, data);\n\n}\n\n\n//Provides: caml_ba_create\n//Requires: caml_js_from_array\n//Requires: caml_ba_get_size, caml_ba_create_unsafe\n//Requires: caml_ba_create_buffer\nfunction caml_ba_create(kind, layout, dims_ml) {\n var dims = caml_js_from_array(dims_ml);\n var data = caml_ba_create_buffer(kind, caml_ba_get_size(dims));\n return caml_ba_create_unsafe(kind, layout, dims, data);\n}\n\n//Provides: caml_ba_change_layout\n//Requires: caml_ba_create_unsafe\nfunction caml_ba_change_layout(ba, layout) {\n if(ba.layout == layout) return ba;\n var new_dims = []\n for(var i = 0; i < ba.dims.length; i++) new_dims[i] = ba.dims[ba.dims.length - i - 1];\n return caml_ba_create_unsafe(ba.kind, layout, new_dims, ba.data);\n}\n\n//Provides: caml_ba_kind\nfunction caml_ba_kind(ba) {\n return ba.kind;\n}\n\n//Provides: caml_ba_layout\nfunction caml_ba_layout(ba) {\n return ba.layout;\n}\n\n//Provides: caml_ba_num_dims\nfunction caml_ba_num_dims(ba) {\n return ba.dims.length;\n}\n\n//Provides: caml_ba_dim\n//Requires: caml_invalid_argument\nfunction caml_ba_dim(ba, i) {\n if (i < 0 || i >= ba.dims.length)\n caml_invalid_argument(\"Bigarray.dim\");\n return ba.dims[i];\n}\n\n//Provides: caml_ba_dim_1\n//Requires: caml_ba_dim\nfunction caml_ba_dim_1(ba) {\n return caml_ba_dim(ba, 0);\n}\n\n//Provides: caml_ba_dim_2\n//Requires: caml_ba_dim\nfunction caml_ba_dim_2(ba) {\n return caml_ba_dim(ba, 1);\n}\n\n//Provides: caml_ba_dim_3\n//Requires: caml_ba_dim\nfunction caml_ba_dim_3(ba) {\n return caml_ba_dim(ba, 2);\n}\n\n//Provides: caml_ba_get_generic\n//Requires: caml_js_from_array\nfunction caml_ba_get_generic(ba, i) {\n var ofs = ba.offset(caml_js_from_array(i));\n return ba.get(ofs);\n}\n\n//Provides: caml_ba_uint8_get16\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_get16(ba, i0) {\n var ofs = ba.offset(i0);\n if(ofs + 1 >= ba.data.length) caml_array_bound_error();\n var b1 = ba.get(ofs);\n var b2 = ba.get(ofs + 1);\n return (b1 | (b2 << 8));\n}\n\n//Provides: caml_ba_uint8_get32\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_get32(ba, i0) {\n var ofs = ba.offset(i0);\n if(ofs + 3 >= ba.data.length) caml_array_bound_error();\n var b1 = ba.get(ofs+0);\n var b2 = ba.get(ofs+1);\n var b3 = ba.get(ofs+2);\n var b4 = ba.get(ofs+3);\n return ( (b1 << 0) |\n (b2 << 8) |\n (b3 << 16) |\n (b4 << 24) );\n}\n\n//Provides: caml_ba_uint8_get64\n//Requires: caml_array_bound_error, caml_int64_of_bytes\nfunction caml_ba_uint8_get64(ba, i0) {\n var ofs = ba.offset(i0);\n if(ofs + 7 >= ba.data.length) caml_array_bound_error();\n var b1 = ba.get(ofs+0);\n var b2 = ba.get(ofs+1);\n var b3 = ba.get(ofs+2);\n var b4 = ba.get(ofs+3);\n var b5 = ba.get(ofs+4);\n var b6 = ba.get(ofs+5);\n var b7 = ba.get(ofs+6);\n var b8 = ba.get(ofs+7);\n return caml_int64_of_bytes([b8,b7,b6,b5,b4,b3,b2,b1]);\n}\n\n//Provides: caml_ba_get_1\nfunction caml_ba_get_1(ba, i0) {\n return ba.get(ba.offset(i0));\n}\n\n//Provides: caml_ba_get_2\nfunction caml_ba_get_2(ba, i0, i1) {\n return ba.get(ba.offset([i0,i1]));\n}\n\n//Provides: caml_ba_get_3\nfunction caml_ba_get_3(ba, i0, i1, i2) {\n return ba.get(ba.offset([i0,i1,i2]));\n}\n\n//Provides: caml_ba_set_generic\n//Requires: caml_js_from_array\nfunction caml_ba_set_generic(ba, i, v) {\n ba.set(ba.offset(caml_js_from_array(i)), v);\n return 0\n}\n\n//Provides: caml_ba_uint8_set16\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_set16(ba, i0, v) {\n var ofs = ba.offset(i0);\n if(ofs + 1 >= ba.data.length) caml_array_bound_error();\n ba.set(ofs+0, v & 0xff);\n ba.set(ofs+1, (v >>> 8) & 0xff);\n return 0;\n}\n\n//Provides: caml_ba_uint8_set32\n//Requires: caml_array_bound_error\nfunction caml_ba_uint8_set32(ba, i0, v) {\n var ofs = ba.offset(i0);\n if(ofs + 3 >= ba.data.length) caml_array_bound_error();\n ba.set(ofs+0, v & 0xff);\n ba.set(ofs+1, (v >>> 8) & 0xff);\n ba.set(ofs+2, (v >>> 16) & 0xff);\n ba.set(ofs+3, (v >>> 24) & 0xff);\n return 0;\n}\n\n//Provides: caml_ba_uint8_set64\n//Requires: caml_array_bound_error, caml_int64_to_bytes\nfunction caml_ba_uint8_set64(ba, i0, v) {\n var ofs = ba.offset(i0);\n if(ofs + 7 >= ba.data.length) caml_array_bound_error();\n var v = caml_int64_to_bytes(v);\n for(var i = 0; i < 8; i++) ba.set(ofs+i, v[7-i])\n return 0;\n}\n\n//Provides: caml_ba_set_1\nfunction caml_ba_set_1(ba, i0, v) {\n ba.set(ba.offset(i0), v);\n return 0\n}\n\n//Provides: caml_ba_set_2\nfunction caml_ba_set_2(ba, i0, i1, v) {\n ba.set(ba.offset([i0,i1]), v);\n return 0;\n}\n\n//Provides: caml_ba_set_3\nfunction caml_ba_set_3(ba, i0, i1, i2, v) {\n ba.set(ba.offset([i0,i1,i2]), v);\n return 0;\n}\n\n//Provides: caml_ba_fill\nfunction caml_ba_fill(ba, v) {\n ba.fill(v);\n return 0;\n}\n\n//Provides: caml_ba_blit\n//Requires: caml_invalid_argument\nfunction caml_ba_blit(src, dst) {\n if (dst.dims.length != src.dims.length)\n caml_invalid_argument(\"Bigarray.blit: dimension mismatch\");\n for (var i = 0; i < dst.dims.length; i++)\n if (dst.dims[i] != src.dims[i])\n caml_invalid_argument(\"Bigarray.blit: dimension mismatch\");\n dst.data.set(src.data);\n return 0;\n}\n\n//Provides: caml_ba_sub\n//Requires: caml_invalid_argument, caml_ba_create_unsafe, caml_ba_get_size\n//Requires: caml_ba_get_size_per_element\nfunction caml_ba_sub(ba, ofs, len) {\n var changed_dim;\n var mul = 1;\n if (ba.layout == 0) {\n for (var i = 1; i < ba.dims.length; i++)\n mul = mul * ba.dims[i];\n changed_dim = 0;\n } else {\n for (var i = 0; i < (ba.dims.length - 1); i++)\n mul = mul * ba.dims[i];\n changed_dim = ba.dims.length - 1;\n ofs = ofs - 1;\n }\n if (ofs < 0 || len < 0 || (ofs + len) > ba.dims[changed_dim]){\n caml_invalid_argument(\"Bigarray.sub: bad sub-array\");\n }\n var new_dims = [];\n for (var i = 0; i < ba.dims.length; i++)\n new_dims[i] = ba.dims[i];\n new_dims[changed_dim] = len;\n mul *= caml_ba_get_size_per_element(ba.kind);\n var new_data = ba.data.subarray(ofs * mul, (ofs + len) * mul);\n return caml_ba_create_unsafe(ba.kind, ba.layout, new_dims, new_data);\n}\n\n//Provides: caml_ba_slice\n//Requires: caml_js_from_array, caml_ba_create_unsafe, caml_invalid_argument, caml_ba_get_size\n//Requires: caml_ba_get_size_per_element\nfunction caml_ba_slice(ba, vind) {\n vind = caml_js_from_array(vind);\n var num_inds = vind.length;\n var index = [];\n var sub_dims = [];\n var ofs;\n\n if (num_inds > ba.dims.length)\n caml_invalid_argument(\"Bigarray.slice: too many indices\");\n\n // Compute offset and check bounds\n if (ba.layout == 0) {\n for (var i = 0; i < num_inds; i++)\n index[i] = vind[i];\n for (; i < ba.dims.length; i++)\n index[i] = 0;\n sub_dims = ba.dims.slice(num_inds);\n } else {\n for (var i = 0; i < num_inds; i++)\n index[ba.dims.length - num_inds + i] = vind[i];\n for (var i = 0; i < ba.dims.length - num_inds; i++)\n index[i] = 1;\n sub_dims = ba.dims.slice(0, ba.dims.length - num_inds);\n }\n ofs = ba.offset(index);\n var size = caml_ba_get_size(sub_dims);\n var size_per_element = caml_ba_get_size_per_element(ba.kind);\n var new_data = ba.data.subarray(ofs * size_per_element, (ofs + size) * size_per_element);\n return caml_ba_create_unsafe(ba.kind, ba.layout, sub_dims, new_data);\n}\n\n//Provides: caml_ba_reshape\n//Requires: caml_js_from_array, caml_invalid_argument, caml_ba_create_unsafe, caml_ba_get_size\nfunction caml_ba_reshape(ba, vind) {\n vind = caml_js_from_array(vind);\n var new_dim = [];\n var num_dims = vind.length;\n\n if (num_dims < 0 || num_dims > 16){\n caml_invalid_argument(\"Bigarray.reshape: bad number of dimensions\");\n }\n var num_elts = 1;\n for (var i = 0; i < num_dims; i++) {\n new_dim[i] = vind[i];\n if (new_dim[i] < 0)\n caml_invalid_argument(\"Bigarray.reshape: negative dimension\");\n num_elts = num_elts * new_dim[i];\n }\n\n var size = caml_ba_get_size(ba.dims);\n // Check that sizes agree\n if (num_elts != size)\n caml_invalid_argument(\"Bigarray.reshape: size mismatch\");\n return caml_ba_create_unsafe(ba.kind, ba.layout, new_dim, ba.data);\n}\n\n//Provides: caml_ba_serialize\n//Requires: caml_int64_bits_of_float, caml_int64_to_bytes\n//Requires: caml_int32_bits_of_float\nfunction caml_ba_serialize(writer, ba, sz) {\n writer.write(32, ba.dims.length);\n writer.write(32, (ba.kind | (ba.layout << 8)));\n if(ba.caml_custom == \"_bigarr02\")\n for(var i = 0; i < ba.dims.length; i++) {\n if(ba.dims[i] < 0xffff)\n writer.write(16, ba.dims[i]);\n else {\n writer.write(16, 0xffff);\n writer.write(32, 0);\n writer.write(32, ba.dims[i]);\n }\n }\n else\n for(var i = 0; i < ba.dims.length; i++) writer.write(32,ba.dims[i])\n switch(ba.kind){\n case 2: //Int8Array\n case 3: //Uint8Array\n case 12: //Uint8Array\n for(var i = 0; i < ba.data.length; i++){\n writer.write(8, ba.data[i]);\n }\n break;\n case 4: // Int16Array\n case 5: // Uint16Array\n for(var i = 0; i < ba.data.length; i++){\n writer.write(16, ba.data[i]);\n }\n break;\n case 6: // Int32Array (int32)\n for(var i = 0; i < ba.data.length; i++){\n writer.write(32, ba.data[i]);\n }\n break;\n case 8: // Int32Array (int)\n case 9: // Int32Array (nativeint)\n writer.write(8,0);\n for(var i = 0; i < ba.data.length; i++){\n writer.write(32, ba.data[i]);\n }\n break;\n case 7: // Int32Array (int64)\n for(var i = 0; i < ba.data.length / 2; i++){\n var b = caml_int64_to_bytes(ba.get(i));\n for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n }\n break;\n case 1: // Float64Array\n for(var i = 0; i < ba.data.length; i++){\n var b = caml_int64_to_bytes(caml_int64_bits_of_float(ba.get(i)));\n for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n }\n break;\n case 0: // Float32Array\n for(var i = 0; i < ba.data.length; i++){\n var b = caml_int32_bits_of_float(ba.get(i));\n writer.write(32, b);\n }\n break;\n case 10: // Float32Array (complex32)\n for(var i = 0; i < ba.data.length / 2; i++){\n var j = ba.get(i);\n writer.write(32, caml_int32_bits_of_float(j[1]));\n writer.write(32, caml_int32_bits_of_float(j[2]));\n }\n break;\n case 11: // Float64Array (complex64)\n for(var i = 0; i < ba.data.length / 2; i++){\n var complex = ba.get(i);\n var b = caml_int64_to_bytes(caml_int64_bits_of_float(complex[1]));\n for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n var b = caml_int64_to_bytes(caml_int64_bits_of_float(complex[2]));\n for (var j = 0; j < 8; j++) writer.write (8, b[j]);\n }\n break;\n }\n sz[0] = (4 + ba.dims.length) * 4;\n sz[1] = (4 + ba.dims.length) * 8;\n}\n\n//Provides: caml_ba_deserialize\n//Requires: caml_ba_create_unsafe, caml_failwith\n//Requires: caml_ba_get_size\n//Requires: caml_int64_of_bytes, caml_int64_float_of_bits\n//Requires: caml_int32_float_of_bits\n//Requires: caml_ba_create_buffer\nfunction caml_ba_deserialize(reader, sz, name){\n var num_dims = reader.read32s();\n if (num_dims < 0 || num_dims > 16)\n caml_failwith(\"input_value: wrong number of bigarray dimensions\");\n var tag = reader.read32s();\n var kind = tag & 0xff\n var layout = (tag >> 8) & 1;\n var dims = []\n if(name == \"_bigarr02\")\n for (var i = 0; i < num_dims; i++) {\n var size_dim = reader.read16u();\n if(size_dim == 0xffff){\n var size_dim_hi = reader.read32u();\n var size_dim_lo = reader.read32u();\n if(size_dim_hi != 0)\n caml_failwith(\"input_value: bigarray dimension overflow in 32bit\");\n size_dim = size_dim_lo;\n }\n dims.push(size_dim);\n }\n else\n for (var i = 0; i < num_dims; i++) dims.push(reader.read32u());\n var size = caml_ba_get_size(dims);\n var data = caml_ba_create_buffer(kind, size);\n var ba = caml_ba_create_unsafe(kind, layout, dims, data);\n switch(kind){\n case 2: //Int8Array\n for(var i = 0; i < size; i++){\n data[i] = reader.read8s();\n }\n break;\n case 3: //Uint8Array\n case 12: //Uint8Array\n for(var i = 0; i < size; i++){\n data[i] = reader.read8u();\n }\n break;\n case 4: // Int16Array\n for(var i = 0; i < size; i++){\n data[i] = reader.read16s();\n }\n break;\n case 5: // Uint16Array\n for(var i = 0; i < size; i++){\n data[i] = reader.read16u();\n }\n break;\n case 6: // Int32Array (int32)\n for(var i = 0; i < size; i++){\n data[i] = reader.read32s();\n }\n break;\n case 8: // Int32Array (int)\n case 9: // Int32Array (nativeint)\n var sixty = reader.read8u();\n if(sixty) caml_failwith(\"input_value: cannot read bigarray with 64-bit OCaml ints\");\n for(var i = 0; i < size; i++){\n data[i] = reader.read32s();\n }\n break;\n case 7: // (int64)\n var t = new Array(8);;\n for(var i = 0; i < size; i++){\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n var int64 = caml_int64_of_bytes(t);\n ba.set(i,int64);\n }\n break;\n case 1: // Float64Array\n var t = new Array(8);;\n for(var i = 0; i < size; i++){\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n var f = caml_int64_float_of_bits(caml_int64_of_bytes(t));\n ba.set(i,f);\n }\n break;\n case 0: // Float32Array\n for(var i = 0; i < size; i++){\n var f = caml_int32_float_of_bits(reader.read32s());\n ba.set(i,f);\n }\n break;\n case 10: // Float32Array (complex32)\n for(var i = 0; i < size; i++){\n var re = caml_int32_float_of_bits(reader.read32s());\n var im = caml_int32_float_of_bits(reader.read32s());\n ba.set(i,[254,re,im]);\n }\n break;\n case 11: // Float64Array (complex64)\n var t = new Array(8);;\n for(var i = 0; i < size; i++){\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n var re = caml_int64_float_of_bits(caml_int64_of_bytes(t));\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n var im = caml_int64_float_of_bits(caml_int64_of_bytes(t));\n ba.set(i,[254,re,im]);\n }\n break\n }\n sz[0] = (4 + num_dims) * 4;\n return caml_ba_create_unsafe(kind, layout, dims, data);\n}\n\n//Deprecated\n//Provides: caml_ba_create_from\n//Requires: caml_ba_create_unsafe, caml_invalid_argument, caml_ba_get_size_per_element\nfunction caml_ba_create_from(data1, data2, jstyp, kind, layout, dims){\n if(data2 || caml_ba_get_size_per_element(kind) == 2){\n caml_invalid_argument(\"caml_ba_create_from: use return caml_ba_create_unsafe\");\n }\n return caml_ba_create_unsafe(kind, layout, dims, data1);\n}\n\n//Provides: caml_ba_hash const\n//Requires: caml_ba_get_size, caml_hash_mix_int, caml_hash_mix_float\nfunction caml_ba_hash(ba){\n var num_elts = caml_ba_get_size(ba.dims);\n var h = 0;\n switch(ba.kind){\n case 2: //Int8Array\n case 3: //Uint8Array\n case 12: //Uint8Array\n if(num_elts > 256) num_elts = 256;\n var w = 0, i =0;\n for(i = 0; i + 4 <= ba.data.length; i+=4){\n w = ba.data[i+0] | (ba.data[i+1] << 8) | (ba.data[i+2] << 16) | (ba.data[i+3] << 24);\n h = caml_hash_mix_int(h,w);\n }\n w = 0;\n switch (num_elts & 3) {\n case 3: w = ba.data[i+2] << 16; /* fallthrough */\n case 2: w |= ba.data[i+1] << 8; /* fallthrough */\n case 1: w |= ba.data[i+0];\n h = caml_hash_mix_int(h, w);\n }\n break;\n case 4: // Int16Array\n case 5: // Uint16Array\n if(num_elts > 128) num_elts = 128;\n var w = 0, i =0;\n for(i = 0; i + 2 <= ba.data.length; i+=2){\n w = ba.data[i+0] | (ba.data[i+1] << 16);\n h = caml_hash_mix_int(h,w);\n }\n if ((num_elts & 1) != 0)\n h = caml_hash_mix_int(h, ba.data[i]);\n break;\n case 6: // Int32Array (int32)\n if (num_elts > 64) num_elts = 64;\n for (var i = 0; i < num_elts; i++) h = caml_hash_mix_int(h, ba.data[i]);\n break;\n case 8: // Int32Array (int)\n case 9: // Int32Array (nativeint)\n if (num_elts > 64) num_elts = 64;\n for (var i = 0; i < num_elts; i++) h = caml_hash_mix_int(h, ba.data[i]);\n break;\n case 7: // Int32Array (int64)\n if (num_elts > 32) num_elts = 32;\n num_elts *= 2\n for (var i = 0; i < num_elts; i++) {\n h = caml_hash_mix_int(h, ba.data[i]);\n }\n break;\n case 10: // Float32Array (complex32)\n num_elts *=2; /* fallthrough */\n case 0: // Float32Array\n if (num_elts > 64) num_elts = 64;\n for (var i = 0; i < num_elts; i++) h = caml_hash_mix_float(h, ba.data[i]);\n break;\n case 11: // Float64Array (complex64)\n num_elts *=2; /* fallthrough */\n case 1: // Float64Array\n if (num_elts > 32) num_elts = 32;\n for (var i = 0; i < num_elts; i++) h = caml_hash_mix_float(h, ba.data[i]);\n break;\n }\n return h;\n}\n\n//Provides: caml_ba_to_typed_array mutable\nfunction caml_ba_to_typed_array(ba){\n return ba.data;\n}\n\n//Provides: caml_ba_kind_of_typed_array mutable\n//Requires: caml_invalid_argument\nfunction caml_ba_kind_of_typed_array(ta){\n var g = globalThis;\n var kind;\n if (ta instanceof g.Float32Array) kind = 0;\n else if (ta instanceof g.Float64Array) kind = 1;\n else if (ta instanceof g.Int8Array) kind = 2;\n else if (ta instanceof g.Uint8Array) kind = 3;\n else if (ta instanceof g.Int16Array) kind = 4;\n else if (ta instanceof g.Uint16Array) kind = 5;\n else if (ta instanceof g.Int32Array) kind = 6;\n else if (ta instanceof g.Uint32Array) kind = 6;\n else caml_invalid_argument(\"caml_ba_kind_of_typed_array: unsupported kind\");\n return kind;\n}\n\n//Provides: caml_ba_from_typed_array mutable\n//Requires: caml_ba_kind_of_typed_array\n//Requires: caml_ba_create_unsafe\nfunction caml_ba_from_typed_array(ta){\n var kind = caml_ba_kind_of_typed_array(ta);\n return caml_ba_create_unsafe(kind, 0, [ta.length], ta);\n}\n","/* global globalThis\n */\n\n//Provides: caml_raise_with_string (const, const)\nfunction caml_raise_with_string(tag, msg) {\n throw globalThis.Error(msg.c);\n}\n\n//Provides: custom_reraise_exn\nfunction custom_reraise_exn(exn, fallbackMessage) {\n // this handles the common case of a JS Error reraised by OCaml\n // in that case, the error will first be wrapped in OCaml with \"caml_wrap_exception\"\n // (defined in js_of_ocaml-compiler / jslib.js)\n // which results in [0, caml_named_value(\"jsError\"), err]\n var err = exn[2];\n if (err instanceof globalThis.Error) {\n throw err;\n } else {\n throw Error(fallbackMessage);\n }\n}\n\n/**\n * This overrides the handler for uncaught exceptions in js_of_ocaml,\n * fixing the flaw that by default, no actual `Error`s are thrown,\n * but other objects (arrays) which are missing an error trace.\n * This override should make it much easier to find the source of an error.\n */\n//Provides: caml_fatal_uncaught_exception\nfunction caml_fatal_uncaught_exception(err) {\n // first, we search for an actual error inside `err`,\n // since this is the best thing to throw\n function throw_errors(err) {\n if (err instanceof Error) throw err;\n else if (Array.isArray(err)) {\n err.forEach(throw_errors);\n }\n }\n throw_errors(err);\n // if this didn't throw an error, let's log whatever we got\n console.dir(err, { depth: 20 });\n // now, try to collect all strings in the error and throw that\n function collect_strings(err, acc) {\n var str = undefined;\n if (typeof err === 'string') {\n str = err;\n } else if (err && err.constructor && err.constructor.name === 'MlBytes') {\n str = err.c;\n } else if (Array.isArray(err)) {\n err.forEach(function (e) {\n collect_strings(e, acc);\n });\n }\n if (!str) return acc.string;\n if (acc.string === undefined) acc.string = str;\n else acc.string = acc.string + '\\n' + str;\n return acc.string;\n }\n var str = collect_strings(err, {});\n if (str !== undefined) throw globalThis.Error(str);\n // otherwise, just throw an unhelpful error\n console.dir(err, { depth: 10 });\n throw globalThis.Error('Unknown error thrown from OCaml');\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_marshal_constants\nvar caml_marshal_constants = {\n PREFIX_SMALL_BLOCK: 0x80,\n PREFIX_SMALL_INT: 0x40,\n PREFIX_SMALL_STRING: 0x20,\n CODE_INT8: 0x00,\n CODE_INT16: 0x01,\n CODE_INT32: 0x02,\n CODE_INT64: 0x03,\n CODE_SHARED8: 0x04,\n CODE_SHARED16: 0x05,\n CODE_SHARED32: 0x06,\n CODE_BLOCK32: 0x08,\n CODE_BLOCK64: 0x13,\n CODE_STRING8: 0x09,\n CODE_STRING32: 0x0A,\n CODE_DOUBLE_BIG: 0x0B,\n CODE_DOUBLE_LITTLE: 0x0C,\n CODE_DOUBLE_ARRAY8_BIG: 0x0D,\n CODE_DOUBLE_ARRAY8_LITTLE: 0x0E,\n CODE_DOUBLE_ARRAY32_BIG: 0x0F,\n CODE_DOUBLE_ARRAY32_LITTLE: 0x07,\n CODE_CODEPOINTER: 0x10,\n CODE_INFIXPOINTER: 0x11,\n CODE_CUSTOM: 0x12,\n CODE_CUSTOM_LEN: 0x18,\n CODE_CUSTOM_FIXED: 0x19\n}\n\n\n//Provides: MlStringReader\n//Requires: caml_string_of_jsbytes, caml_jsbytes_of_string\nfunction MlStringReader (s, i) { this.s = caml_jsbytes_of_string(s); this.i = i; }\nMlStringReader.prototype = {\n read8u:function () { return this.s.charCodeAt(this.i++); },\n read8s:function () { return this.s.charCodeAt(this.i++) << 24 >> 24; },\n read16u:function () {\n var s = this.s, i = this.i;\n this.i = i + 2;\n return (s.charCodeAt(i) << 8) | s.charCodeAt(i + 1)\n },\n read16s:function () {\n var s = this.s, i = this.i;\n this.i = i + 2;\n return (s.charCodeAt(i) << 24 >> 16) | s.charCodeAt(i + 1);\n },\n read32u:function () {\n var s = this.s, i = this.i;\n this.i = i + 4;\n return ((s.charCodeAt(i) << 24) | (s.charCodeAt(i+1) << 16) |\n (s.charCodeAt(i+2) << 8) | s.charCodeAt(i+3)) >>> 0;\n },\n read32s:function () {\n var s = this.s, i = this.i;\n this.i = i + 4;\n return (s.charCodeAt(i) << 24) | (s.charCodeAt(i+1) << 16) |\n (s.charCodeAt(i+2) << 8) | s.charCodeAt(i+3);\n },\n readstr:function (len) {\n var i = this.i;\n this.i = i + len;\n return caml_string_of_jsbytes(this.s.substring(i, i + len));\n }\n}\n\n//Provides: BigStringReader\n//Requires: caml_string_of_array, caml_ba_get_1\nfunction BigStringReader (bs, i) { this.s = bs; this.i = i; }\nBigStringReader.prototype = {\n read8u:function () { return caml_ba_get_1(this.s,this.i++); },\n read8s:function () { return caml_ba_get_1(this.s,this.i++) << 24 >> 24; },\n read16u:function () {\n var s = this.s, i = this.i;\n this.i = i + 2;\n return (caml_ba_get_1(s,i) << 8) | caml_ba_get_1(s,i + 1)\n },\n read16s:function () {\n var s = this.s, i = this.i;\n this.i = i + 2;\n return (caml_ba_get_1(s,i) << 24 >> 16) | caml_ba_get_1(s,i + 1);\n },\n read32u:function () {\n var s = this.s, i = this.i;\n this.i = i + 4;\n return ((caml_ba_get_1(s,i) << 24) | (caml_ba_get_1(s,i+1) << 16) |\n (caml_ba_get_1(s,i+2) << 8) | caml_ba_get_1(s,i+3) ) >>> 0;\n },\n read32s:function () {\n var s = this.s, i = this.i;\n this.i = i + 4;\n return (caml_ba_get_1(s,i) << 24) | (caml_ba_get_1(s,i+1) << 16) |\n (caml_ba_get_1(s,i+2) << 8) | caml_ba_get_1(s,i+3);\n },\n readstr:function (len) {\n var i = this.i;\n var arr = new Array(len)\n for(var j = 0; j < len; j++){\n arr[j] = caml_ba_get_1(this.s, i+j);\n }\n this.i = i + len;\n return caml_string_of_array(arr);\n }\n}\n\n\n\n//Provides: caml_float_of_bytes\n//Requires: caml_int64_float_of_bits, caml_int64_of_bytes\nfunction caml_float_of_bytes (a) {\n return caml_int64_float_of_bits (caml_int64_of_bytes (a));\n}\n\n//Provides: caml_input_value_from_string mutable\n//Requires: MlStringReader, caml_input_value_from_reader\nfunction caml_input_value_from_string(s,ofs) {\n var reader = new MlStringReader (s, typeof ofs==\"number\"?ofs:ofs[0]);\n return caml_input_value_from_reader(reader, ofs)\n}\n\n//Provides: caml_input_value_from_bytes mutable\n//Requires: MlStringReader, caml_input_value_from_reader, caml_string_of_bytes\nfunction caml_input_value_from_bytes(s,ofs) {\n var reader = new MlStringReader (caml_string_of_bytes(s), typeof ofs==\"number\"?ofs:ofs[0]);\n return caml_input_value_from_reader(reader, ofs)\n}\n\n//Provides: caml_int64_unmarshal\n//Requires: caml_int64_of_bytes\nfunction caml_int64_unmarshal(reader, size){\n var t = new Array(8);;\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n size[0] = 8;\n return caml_int64_of_bytes (t);\n}\n\n//Provides: caml_int64_marshal\n//Requires: caml_int64_to_bytes\nfunction caml_int64_marshal(writer, v, sizes) {\n var b = caml_int64_to_bytes (v);\n for (var i = 0; i < 8; i++) writer.write (8, b[i]);\n sizes[0] = 8; sizes[1] = 8;\n}\n\n//Provides: caml_int32_unmarshal\nfunction caml_int32_unmarshal(reader, size){\n size[0] = 4;\n return reader.read32s ();\n}\n\n//Provides: caml_nativeint_unmarshal\n//Requires: caml_failwith\nfunction caml_nativeint_unmarshal(reader, size){\n switch (reader.read8u ()) {\n case 1:\n size[0] = 4;\n return reader.read32s ();\n case 2:\n caml_failwith(\"input_value: native integer value too large\");\n default: caml_failwith(\"input_value: ill-formed native integer\");\n }\n}\n\n//Provides: caml_custom_ops\n//Requires: caml_int64_unmarshal, caml_int64_marshal, caml_int64_compare, caml_int64_hash\n//Requires: caml_int32_unmarshal, caml_nativeint_unmarshal\n//Requires: caml_ba_serialize, caml_ba_deserialize, caml_ba_compare, caml_ba_hash\nvar caml_custom_ops =\n {\"_j\": {\n deserialize : caml_int64_unmarshal,\n serialize : caml_int64_marshal,\n fixed_length : 8,\n compare : caml_int64_compare,\n hash : caml_int64_hash\n },\n \"_i\": {\n deserialize : caml_int32_unmarshal,\n fixed_length : 4,\n },\n \"_n\": {\n deserialize : caml_nativeint_unmarshal,\n fixed_length : 4,\n },\n \"_bigarray\":{\n deserialize : (function (reader, sz) {return caml_ba_deserialize (reader,sz,\"_bigarray\")}),\n serialize : caml_ba_serialize,\n compare : caml_ba_compare,\n hash: caml_ba_hash,\n },\n \"_bigarr02\":{\n deserialize : (function (reader, sz) {return caml_ba_deserialize (reader,sz,\"_bigarr02\")}),\n serialize : caml_ba_serialize,\n compare : caml_ba_compare,\n hash: caml_ba_hash,\n }\n }\n\n//Provides: caml_input_value_from_reader mutable\n//Requires: caml_failwith\n//Requires: caml_float_of_bytes, caml_custom_ops\n\nfunction caml_input_value_from_reader(reader, ofs) {\n var _magic = reader.read32u ()\n var _block_len = reader.read32u ();\n var num_objects = reader.read32u ();\n var _size_32 = reader.read32u ();\n var _size_64 = reader.read32u ();\n var stack = [];\n var intern_obj_table = (num_objects > 0)?[]:null;\n var obj_counter = 0;\n function intern_rec () {\n var code = reader.read8u ();\n if (code >= 0x40 /*cst.PREFIX_SMALL_INT*/) {\n if (code >= 0x80 /*cst.PREFIX_SMALL_BLOCK*/) {\n var tag = code & 0xF;\n var size = (code >> 4) & 0x7;\n var v = [tag];\n if (size == 0) return v;\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n stack.push(v, size);\n return v;\n } else\n return (code & 0x3F);\n } else {\n if (code >= 0x20/*cst.PREFIX_SMALL_STRING */) {\n var len = code & 0x1F;\n var v = reader.readstr (len);\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n } else {\n switch(code) {\n case 0x00: //cst.CODE_INT8:\n return reader.read8s ();\n case 0x01: //cst.CODE_INT16:\n return reader.read16s ();\n case 0x02: //cst.CODE_INT32:\n return reader.read32s ();\n case 0x03: //cst.CODE_INT64:\n caml_failwith(\"input_value: integer too large\");\n break;\n case 0x04: //cst.CODE_SHARED8:\n var offset = reader.read8u ();\n return intern_obj_table[obj_counter - offset];\n case 0x05: //cst.CODE_SHARED16:\n var offset = reader.read16u ();\n return intern_obj_table[obj_counter - offset];\n case 0x06: //cst.CODE_SHARED32:\n var offset = reader.read32u ();\n return intern_obj_table[obj_counter - offset];\n case 0x08: //cst.CODE_BLOCK32:\n var header = reader.read32u ();\n var tag = header & 0xFF;\n var size = header >> 10;\n var v = [tag];\n if (size == 0) return v;\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n stack.push(v, size);\n return v;\n case 0x13: //cst.CODE_BLOCK64:\n caml_failwith (\"input_value: data block too large\");\n break;\n case 0x09: //cst.CODE_STRING8:\n var len = reader.read8u();\n var v = reader.readstr (len);\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n case 0x0A: //cst.CODE_STRING32:\n var len = reader.read32u();\n var v = reader.readstr (len);\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n case 0x0C: //cst.CODE_DOUBLE_LITTLE:\n var t = new Array(8);;\n for (var i = 0;i < 8;i++) t[7 - i] = reader.read8u ();\n var v = caml_float_of_bytes (t);\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n case 0x0B: //cst.CODE_DOUBLE_BIG:\n var t = new Array(8);;\n for (var i = 0;i < 8;i++) t[i] = reader.read8u ();\n var v = caml_float_of_bytes (t);\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n case 0x0E: //cst.CODE_DOUBLE_ARRAY8_LITTLE:\n var len = reader.read8u();\n var v = new Array(len+1);\n v[0] = 254;\n var t = new Array(8);;\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n for (var i = 1;i <= len;i++) {\n for (var j = 0;j < 8;j++) t[7 - j] = reader.read8u();\n v[i] = caml_float_of_bytes (t);\n }\n return v;\n case 0x0D: //cst.CODE_DOUBLE_ARRAY8_BIG:\n var len = reader.read8u();\n var v = new Array(len+1);\n v[0] = 254;\n var t = new Array(8);;\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n for (var i = 1;i <= len;i++) {\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n v [i] = caml_float_of_bytes (t);\n }\n return v;\n case 0x07: //cst.CODE_DOUBLE_ARRAY32_LITTLE:\n var len = reader.read32u();\n var v = new Array(len+1);\n v[0] = 254;\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n var t = new Array(8);;\n for (var i = 1;i <= len;i++) {\n for (var j = 0;j < 8;j++) t[7 - j] = reader.read8u();\n v[i] = caml_float_of_bytes (t);\n }\n return v;\n case 0x0F: //cst.CODE_DOUBLE_ARRAY32_BIG:\n var len = reader.read32u();\n var v = new Array(len+1);\n v[0] = 254;\n var t = new Array(8);;\n for (var i = 1;i <= len;i++) {\n for (var j = 0;j < 8;j++) t[j] = reader.read8u();\n v [i] = caml_float_of_bytes (t);\n }\n return v;\n case 0x10: //cst.CODE_CODEPOINTER:\n case 0x11: //cst.CODE_INFIXPOINTER:\n caml_failwith (\"input_value: code pointer\");\n break;\n case 0x12: //cst.CODE_CUSTOM:\n case 0x18: //cst.CODE_CUSTOM_LEN:\n case 0x19: //cst.CODE_CUSTOM_FIXED:\n var c, s = \"\";\n while ((c = reader.read8u ()) != 0) s += String.fromCharCode (c);\n var ops = caml_custom_ops[s];\n var expected_size;\n if(!ops)\n caml_failwith(\"input_value: unknown custom block identifier\");\n switch(code){\n case 0x12: // cst.CODE_CUSTOM (deprecated)\n break;\n case 0x19: // cst.CODE_CUSTOM_FIXED\n if(!ops.fixed_length)\n caml_failwith(\"input_value: expected a fixed-size custom block\");\n expected_size = ops.fixed_length;\n break;\n case 0x18: // cst.CODE_CUSTOM_LEN\n expected_size = reader.read32u ();\n // Skip size64\n reader.read32s(); reader.read32s();\n break;\n }\n var old_pos = reader.i;\n var size = [0];\n var v = ops.deserialize(reader, size);\n if(expected_size != undefined){\n if(expected_size != size[0])\n caml_failwith(\"input_value: incorrect length of serialized custom block\");\n }\n if (intern_obj_table) intern_obj_table[obj_counter++] = v;\n return v;\n default:\n caml_failwith (\"input_value: ill-formed message\");\n }\n }\n }\n }\n var res = intern_rec ();\n while (stack.length > 0) {\n var size = stack.pop();\n var v = stack.pop();\n var d = v.length;\n if (d < size) stack.push(v, size);\n v[d] = intern_rec ();\n }\n if (typeof ofs!=\"number\") ofs[0] = reader.i;\n return res;\n}\n\n//Provides: caml_marshal_data_size mutable\n//Requires: caml_failwith, caml_bytes_unsafe_get\nfunction caml_marshal_data_size (s, ofs) {\n function get32(s,i) {\n return (caml_bytes_unsafe_get(s, i) << 24) |\n (caml_bytes_unsafe_get(s, i + 1) << 16) |\n (caml_bytes_unsafe_get(s, i + 2) << 8) |\n caml_bytes_unsafe_get(s, i + 3);\n }\n if (get32(s, ofs) != (0x8495A6BE|0))\n caml_failwith(\"Marshal.data_size: bad object\");\n return (get32(s, ofs + 4));\n}\n\n//Provides: MlObjectTable\nvar MlObjectTable;\nif (typeof globalThis.WeakMap === 'undefined') {\n MlObjectTable = function() {\n /* polyfill (using linear search) */\n function NaiveLookup(objs) { this.objs = objs; }\n NaiveLookup.prototype.get = function(v) {\n for (var i = 0; i < this.objs.length; i++) {\n if (this.objs[i] === v) return i;\n }\n };\n NaiveLookup.prototype.set = function() {\n // Do nothing here. [MlObjectTable.store] will push to [this.objs] directly.\n };\n\n return function MlObjectTable() {\n this.objs = []; this.lookup = new NaiveLookup(this.objs);\n };\n }();\n}\nelse {\n MlObjectTable = function MlObjectTable() {\n this.objs = []; this.lookup = new globalThis.WeakMap();\n };\n}\n\nMlObjectTable.prototype.store = function(v) {\n this.lookup.set(v, this.objs.length);\n this.objs.push(v);\n}\n\nMlObjectTable.prototype.recall = function(v) {\n var i = this.lookup.get(v);\n return (i === undefined)\n ? undefined : this.objs.length - i; /* index is relative */\n}\n\n//Provides: caml_legacy_custom_code\n//Version: >= 4.08\nvar caml_legacy_custom_code = false\n\n//Provides: caml_legacy_custom_code\n//Version: < 4.08\nvar caml_legacy_custom_code = true\n\n//Provides: caml_output_val\n//Requires: caml_int64_to_bytes, caml_failwith\n//Requires: caml_int64_bits_of_float\n//Requires: caml_is_ml_bytes, caml_ml_bytes_length, caml_bytes_unsafe_get\n//Requires: caml_is_ml_string, caml_ml_string_length, caml_string_unsafe_get\n//Requires: MlObjectTable, caml_list_to_js_array, caml_legacy_custom_code, caml_custom_ops\n//Requires: caml_invalid_argument,caml_string_of_jsbytes\nvar caml_output_val = function (){\n function Writer () { this.chunk = []; }\n Writer.prototype = {\n chunk_idx:20, block_len:0, obj_counter:0, size_32:0, size_64:0,\n write:function (size, value) {\n for (var i = size - 8;i >= 0;i -= 8)\n this.chunk[this.chunk_idx++] = (value >> i) & 0xFF;\n },\n write_at:function (pos, size, value) {\n var pos = pos;\n for (var i = size - 8;i >= 0;i -= 8)\n this.chunk[pos++] = (value >> i) & 0xFF;\n },\n write_code:function (size, code, value) {\n this.chunk[this.chunk_idx++] = code;\n for (var i = size - 8;i >= 0;i -= 8)\n this.chunk[this.chunk_idx++] = (value >> i) & 0xFF;\n },\n write_shared:function (offset) {\n if (offset < (1 << 8)) this.write_code(8, 0x04 /*cst.CODE_SHARED8*/, offset);\n else if (offset < (1 << 16)) this.write_code(16, 0x05 /*cst.CODE_SHARED16*/, offset);\n else this.write_code(32, 0x06 /*cst.CODE_SHARED32*/, offset);\n },\n pos:function () { return this.chunk_idx },\n finalize:function () {\n this.block_len = this.chunk_idx - 20;\n this.chunk_idx = 0;\n this.write (32, 0x8495A6BE);\n this.write (32, this.block_len);\n this.write (32, this.obj_counter);\n this.write (32, this.size_32);\n this.write (32, this.size_64);\n return this.chunk;\n }\n }\n return function (v, flags) {\n flags = caml_list_to_js_array(flags);\n\n var no_sharing = (flags.indexOf(0 /*Marshal.No_sharing*/) !== -1),\n closures = (flags.indexOf(1 /*Marshal.Closures*/) !== -1);\n /* Marshal.Compat_32 is redundant since integers are 32-bit anyway */\n\n if (closures)\n globalThis.console.warn(\"in caml_output_val: flag Marshal.Closures is not supported.\");\n\n var writer = new Writer ();\n var stack = [];\n var intern_obj_table = no_sharing ? null : new MlObjectTable();\n\n function memo(v) {\n if (no_sharing) return false;\n var existing_offset = intern_obj_table.recall(v);\n if (existing_offset) { writer.write_shared(existing_offset); return true; }\n else { intern_obj_table.store(v); return false; }\n }\n\n function extern_rec (v) {\n if (v.caml_custom) {\n if (memo(v)) return;\n var name = v.caml_custom;\n var ops = caml_custom_ops[name];\n var sz_32_64 = [0,0];\n if(!ops.serialize)\n caml_invalid_argument(\"output_value: abstract value (Custom)\");\n if(caml_legacy_custom_code) {\n writer.write (8, 0x12 /*cst.CODE_CUSTOM*/);\n for (var i = 0; i < name.length; i++)\n writer.write (8, name.charCodeAt(i));\n writer.write(8, 0);\n ops.serialize(writer, v, sz_32_64);\n } else if(ops.fixed_length == undefined){\n writer.write (8, 0x18 /*cst.CODE_CUSTOM_LEN*/);\n for (var i = 0; i < name.length; i++)\n writer.write (8, name.charCodeAt(i));\n writer.write(8, 0);\n var header_pos = writer.pos ();\n for(var i = 0; i < 12; i++) {\n writer.write(8, 0);\n }\n ops.serialize(writer, v, sz_32_64);\n writer.write_at(header_pos, 32, sz_32_64[0]);\n writer.write_at(header_pos + 4, 32, 0); // zero\n writer.write_at(header_pos + 8, 32, sz_32_64[1]);\n } else {\n writer.write (8, 0x19 /*cst.CODE_CUSTOM_FIXED*/);\n for (var i = 0; i < name.length; i++)\n writer.write (8, name.charCodeAt(i));\n writer.write(8, 0);\n var old_pos = writer.pos();\n ops.serialize(writer, v, sz_32_64);\n if (ops.fixed_length != writer.pos() - old_pos)\n caml_failwith(\"output_value: incorrect fixed sizes specified by \" + name);\n }\n writer.size_32 += 2 + ((sz_32_64[0] + 3) >> 2);\n writer.size_64 += 2 + ((sz_32_64[1] + 7) >> 3);\n }\n else if (v instanceof Array && v[0] === (v[0]|0)) {\n if (v[0] == 251) {\n caml_failwith(\"output_value: abstract value (Abstract)\");\n }\n if (v.length > 1 && memo(v)) return;\n if (v[0] < 16 && v.length - 1 < 8)\n writer.write (8, 0x80 /*cst.PREFIX_SMALL_BLOCK*/ + v[0] + ((v.length - 1)<<4));\n else\n writer.write_code(32, 0x08 /*cst.CODE_BLOCK32*/, ((v.length-1) << 10) | v[0]);\n writer.size_32 += v.length;\n writer.size_64 += v.length;\n if (v.length > 1) stack.push (v, 1);\n } else if (caml_is_ml_bytes(v)) {\n if(!(caml_is_ml_bytes(caml_string_of_jsbytes(\"\")))) {\n caml_failwith(\"output_value: [Bytes.t] cannot safely be marshaled with [--enable use-js-string]\");\n }\n if (memo(v)) return;\n var len = caml_ml_bytes_length(v);\n if (len < 0x20)\n writer.write (8, 0x20 /*cst.PREFIX_SMALL_STRING*/ + len);\n else if (len < 0x100)\n writer.write_code (8, 0x09/*cst.CODE_STRING8*/, len);\n else\n writer.write_code (32, 0x0A /*cst.CODE_STRING32*/, len);\n for (var i = 0;i < len;i++)\n writer.write (8, caml_bytes_unsafe_get(v,i));\n writer.size_32 += 1 + (((len + 4) / 4)|0);\n writer.size_64 += 1 + (((len + 8) / 8)|0);\n } else if (caml_is_ml_string(v)) {\n var len = caml_ml_string_length(v);\n if (len < 0x20)\n writer.write (8, 0x20 /*cst.PREFIX_SMALL_STRING*/ + len);\n else if (len < 0x100)\n writer.write_code (8, 0x09/*cst.CODE_STRING8*/, len);\n else\n writer.write_code (32, 0x0A /*cst.CODE_STRING32*/, len);\n for (var i = 0;i < len;i++)\n writer.write (8, caml_string_unsafe_get(v,i));\n writer.size_32 += 1 + (((len + 4) / 4)|0);\n writer.size_64 += 1 + (((len + 8) / 8)|0);\n } else {\n if (v != (v|0)){\n var type_of_v = typeof v;\n //\n // If a float happens to be an integer it is serialized as an integer\n // (Js_of_ocaml cannot tell whether the type of an integer number is\n // float or integer.) This can result in unexpected crashes when\n // unmarshalling using the standard runtime. It seems better to\n // systematically fail on marshalling.\n //\n // if(type_of_v != \"number\")\n caml_failwith(\"output_value: abstract value (\"+type_of_v+\")\");\n // var t = caml_int64_to_bytes(caml_int64_bits_of_float(v));\n // writer.write (8, 0x0B /*cst.CODE_DOUBLE_BIG*/);\n // for(var i = 0; i<8; i++){writer.write(8,t[i])}\n }\n else if (v >= 0 && v < 0x40) {\n writer.write (8, 0X40 /*cst.PREFIX_SMALL_INT*/ + v);\n } else {\n if (v >= -(1 << 7) && v < (1 << 7))\n writer.write_code(8, 0x00 /*cst.CODE_INT8*/, v);\n else if (v >= -(1 << 15) && v < (1 << 15))\n writer.write_code(16, 0x01 /*cst.CODE_INT16*/, v);\n else\n writer.write_code(32, 0x02 /*cst.CODE_INT32*/, v);\n }\n }\n }\n extern_rec (v);\n while (stack.length > 0) {\n var i = stack.pop ();\n var v = stack.pop ();\n if (i + 1 < v.length) stack.push (v, i + 1);\n extern_rec (v[i]);\n }\n if (intern_obj_table) writer.obj_counter = intern_obj_table.objs.length;\n writer.finalize();\n return writer.chunk;\n }\n} ();\n\n//Provides: caml_output_value_to_string mutable\n//Requires: caml_output_val, caml_string_of_array\nfunction caml_output_value_to_string (v, flags) {\n return caml_string_of_array (caml_output_val (v, flags));\n}\n\n//Provides: caml_output_value_to_bytes mutable\n//Requires: caml_output_val, caml_bytes_of_array\nfunction caml_output_value_to_bytes (v, flags) {\n return caml_bytes_of_array (caml_output_val (v, flags));\n}\n\n//Provides: caml_output_value_to_buffer\n//Requires: caml_output_val, caml_failwith, caml_blit_bytes\nfunction caml_output_value_to_buffer (s, ofs, len, v, flags) {\n var t = caml_output_val (v, flags);\n if (t.length > len) caml_failwith (\"Marshal.to_buffer: buffer overflow\");\n caml_blit_bytes(t, 0, s, ofs, t.length);\n return 0;\n}\n","//Provides: Base_internalhash_fold_int64\n//Requires: caml_hash_mix_int64\nvar Base_internalhash_fold_int64 = caml_hash_mix_int64;\n//Provides: Base_internalhash_fold_int\n//Requires: caml_hash_mix_int\nvar Base_internalhash_fold_int = caml_hash_mix_int;\n//Provides: Base_internalhash_fold_float\n//Requires: caml_hash_mix_float\nvar Base_internalhash_fold_float = caml_hash_mix_float;\n//Provides: Base_internalhash_fold_string\n//Requires: caml_hash_mix_string\nvar Base_internalhash_fold_string = caml_hash_mix_string;\n//Provides: Base_internalhash_get_hash_value\n//Requires: caml_hash_mix_final\nfunction Base_internalhash_get_hash_value(seed) {\n var h = caml_hash_mix_final(seed);\n return h & 0x3FFFFFFF;\n}\n","//Provides: initialize_nat\n//Requires: caml_custom_ops\n//Requires: serialize_nat, deserialize_nat, caml_hash_nat\nfunction initialize_nat() {\n caml_custom_ops[\"_nat\"] =\n { deserialize : deserialize_nat,\n serialize : serialize_nat,\n hash : caml_hash_nat\n }\n}\n\n//Provides: MlNat\nfunction MlNat(x){\n this.data = new globalThis.Int32Array(x);\n // length_nat isn't external, so we have to make the Obj.size\n // work out right. The +2 to array length seems to work.\n this.length = this.data.length + 2\n}\n\nMlNat.prototype.caml_custom = \"_nat\";\n\n//Provides: caml_hash_nat\n//Requires: caml_hash_mix_int, num_digits_nat\nfunction caml_hash_nat(x) {\n var len = num_digits_nat(x, 0, x.data.length);\n var h = 0;\n for (var i = 0; i < len; i++) {\n h = caml_hash_mix_int(h, x.data[i]);\n }\n return h;\n}\n\n\n//Provides: nat_of_array\n//Requires: MlNat\nfunction nat_of_array(l){\n return new MlNat(l);\n}\n\n//Provides: create_nat\n//Requires: MlNat\nfunction create_nat(size) {\n var arr = new MlNat(size);\n for(var i = 0; i < size; i++) {\n arr.data[i] = -1;\n }\n return arr;\n}\n\n//Provides: set_to_zero_nat\nfunction set_to_zero_nat(nat, ofs, len) {\n for(var i = 0; i < len; i++) {\n nat.data[ofs+i] = 0;\n }\n return 0;\n}\n\n//Provides: blit_nat\nfunction blit_nat(nat1, ofs1, nat2, ofs2, len) {\n for(var i = 0; i < len; i++) {\n nat1.data[ofs1+i] = nat2.data[ofs2+i];\n }\n return 0;\n}\n\n//Provides: set_digit_nat\nfunction set_digit_nat(nat, ofs, digit) {\n nat.data[ofs] = digit;\n return 0;\n}\n\n//Provides: nth_digit_nat\nfunction nth_digit_nat(nat, ofs) {\n return nat.data[ofs];\n}\n\n//Provides: set_digit_nat_native\nfunction set_digit_nat_native(nat, ofs, digit) {\n nat.data[ofs] = digit;\n return 0;\n}\n\n//Provides: nth_digit_nat_native\nfunction nth_digit_nat_native(nat, ofs) {\n return nat.data[ofs];\n}\n\n//Provides: num_digits_nat\nfunction num_digits_nat(nat, ofs, len) {\n for(var i = len - 1; i >= 0; i--) {\n if(nat.data[ofs+i] != 0) return i+1;\n }\n return 1; // 0 counts as 1 digit\n}\n\n//Provides: num_leading_zero_bits_in_digit\nfunction num_leading_zero_bits_in_digit(nat, ofs) {\n var a = nat.data[ofs];\n var b = 0;\n if(a & 0xFFFF0000) { b +=16; a >>>=16; }\n if(a & 0xFF00) { b += 8; a >>>= 8; }\n if(a & 0xF0) { b += 4; a >>>= 4; }\n if(a & 12) { b += 2; a >>>= 2; }\n if(a & 2) { b += 1; a >>>= 1; }\n if(a & 1) { b += 1; }\n return 32 - b;\n}\n\n//Provides: is_digit_int\nfunction is_digit_int(nat, ofs) {\n if (nat.data[ofs] >= 0) return 1\n return 0;\n}\n\n//Provides: is_digit_zero\nfunction is_digit_zero(nat, ofs) {\n if(nat.data[ofs] == 0) return 1;\n return 0;\n}\n\n//Provides: is_digit_odd\nfunction is_digit_odd(nat, ofs) {\n if(nat.data[ofs] & 1) return 1;\n return 0;\n}\n\n//Provides: incr_nat\nfunction incr_nat(nat, ofs, len, carry_in) {\n var carry = carry_in;\n for(var i = 0; i < len; i++) {\n var x = (nat.data[ofs+i] >>> 0) + carry;\n nat.data[ofs+i] = (x | 0);\n if(x == (x >>> 0)) {\n carry = 0;\n break;\n } else {\n carry = 1;\n }\n }\n return carry;\n}\n\n// len1 >= len2\n//Provides: add_nat\n//Requires: incr_nat\nfunction add_nat(nat1, ofs1, len1, nat2, ofs2, len2, carry_in) {\n var carry = carry_in;\n for(var i = 0; i < len2; i++) {\n var x = (nat1.data[ofs1+i] >>> 0) + (nat2.data[ofs2+i] >>> 0) + carry;\n nat1.data[ofs1+i] = x\n if(x == (x >>> 0)) {\n carry = 0;\n } else {\n carry = 1;\n }\n }\n return incr_nat(nat1, ofs1+len2, len1-len2, carry);\n}\n\n//Provides: complement_nat\nfunction complement_nat(nat, ofs, len) {\n for(var i = 0; i < len; i++) {\n nat.data[ofs+i] = (-1 >>> 0) - (nat.data[ofs+i] >>> 0);\n }\n}\n\n// ocaml flips carry_in\n//Provides: decr_nat\nfunction decr_nat(nat, ofs, len, carry_in) {\n var borrow = (carry_in == 1) ? 0 : 1;\n for(var i = 0; i < len; i++) {\n var x = (nat.data[ofs+i] >>>0) - borrow;\n nat.data[ofs+i] = x;\n if (x >= 0) {\n borrow = 0;\n break;\n } else {\n borrow = 1;\n }\n }\n return (borrow == 1) ? 0 : 1;\n}\n\n// ocaml flips carry_in\n// len1 >= len2\n//Provides: sub_nat\n//Requires: decr_nat\nfunction sub_nat(nat1, ofs1, len1, nat2, ofs2, len2, carry_in) {\n var borrow = (carry_in == 1) ? 0 : 1;\n for(var i = 0; i < len2; i++) {\n var x = (nat1.data[ofs1+i] >>> 0) - (nat2.data[ofs2+i] >>> 0) - borrow;\n nat1.data[ofs1+i] = x;\n if (x >= 0) {\n borrow = 0;\n } else {\n borrow = 1;\n }\n }\n return decr_nat(nat1, ofs1+len2, len1-len2, (borrow==1)?0:1);\n}\n\n// nat1 += nat2 * nat3[ofs3]\n// len1 >= len2\n//Provides: mult_digit_nat\n//Requires: add_nat, nat_of_array\nfunction mult_digit_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat3, ofs3) {\n var carry = 0;\n var a = (nat3.data[ofs3] >>> 0);\n for(var i = 0; i < len2; i++) {\n var x1 = (nat1.data[ofs1+i] >>> 0) + (nat2.data[ofs2+i] >>> 0) * (a & 0x0000FFFF) + carry;\n var x2 = (nat2.data[ofs2+i] >>> 0) * (a >>> 16);\n carry = Math.floor(x2/65536);\n var x3 = x1 + (x2 % 65536) * 65536;\n nat1.data[ofs1+i] = x3;\n carry += Math.floor(x3/4294967296);\n }\n\n if(len2 < len1 && carry) {\n return add_nat(nat1, ofs1+len2, len1-len2, nat_of_array([carry]), 0, 1, 0);\n } else {\n return carry;\n }\n}\n\n// nat1 += nat2 * nat3\n// len1 >= len2 + len3.\n//Provides: mult_nat\n//Requires: mult_digit_nat\nfunction mult_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat3, ofs3, len3) {\n var carry = 0;\n for(var i = 0; i < len3; i++) {\n carry += mult_digit_nat(nat1, ofs1+i, len1-i, nat2, ofs2, len2, nat3, ofs3+i);\n }\n return carry;\n}\n\n// nat1 = 2 * nat1 + nat2 * nat2\n// len1 >= 2 * len2\n//Provides: square_nat\n//Requires: mult_nat, add_nat\nfunction square_nat(nat1, ofs1, len1, nat2, ofs2, len2) {\n var carry = 0;\n carry += add_nat(nat1, ofs1, len1, nat1, ofs1, len1, 0);\n carry += mult_nat(nat1, ofs1, len1, nat2, ofs2, len2, nat2, ofs2, len2);\n return carry;\n}\n\n\n// 0 <= shift < 32\n//Provides: shift_left_nat\nfunction shift_left_nat(nat1, ofs1, len1, nat2, ofs2, nbits) {\n if(nbits == 0) {\n nat2.data[ofs2] = 0;\n return 0;\n }\n var wrap = 0;\n for(var i = 0; i < len1; i++) {\n var a = (nat1.data[ofs1+i] >>> 0);\n nat1.data[ofs1+i] = (a << nbits) | wrap;\n wrap = a >>> (32 - nbits);\n }\n nat2.data[ofs2] = wrap;\n return 0;\n}\n\n// Assuming c > a, returns [quotient, remainder] of (a<<32 + b)/c\n//Provides: div_helper\nfunction div_helper(a, b, c) {\n var x = a * 65536 + (b>>>16);\n var y = Math.floor(x/c) * 65536;\n var z = (x % c) * 65536;\n var w = z + (b & 0x0000FFFF);\n return [y + Math.floor(w/c), w % c];\n}\n\n// nat1[ofs1+len] < nat2[ofs2]\n//Provides: div_digit_nat\n//Requires: div_helper\nfunction div_digit_nat(natq, ofsq, natr, ofsr, nat1, ofs1, len, nat2, ofs2) {\n var rem = (nat1.data[ofs1+len-1] >>>0);\n // natq[ofsq+len-1] is guaranteed to be zero (due to the MSD requirement),\n // and should not be written to.\n for(var i = len-2; i >= 0; i--) {\n var x = div_helper(rem, (nat1.data[ofs1+i] >>> 0), (nat2.data[ofs2] >>> 0));\n natq.data[ofsq+i] = x[0];\n rem = x[1];\n }\n natr.data[ofsr] = rem;\n return 0;\n}\n\n// nat1[nat2:] := nat1 / nat2\n// nat1[:nat2] := nat1 % nat2\n// len1 > len2, nat2[ofs2+len2-1] > nat1[ofs1+len1-1]\n//Provides: div_nat\n//Requires: div_digit_nat, div_helper, num_leading_zero_bits_in_digit, shift_left_nat, shift_right_nat, create_nat, set_to_zero_nat, mult_digit_nat, sub_nat, compare_nat, nat_of_array\nfunction div_nat(nat1, ofs1, len1, nat2, ofs2, len2) {\n if(len2 == 1) {\n div_digit_nat(nat1, ofs1+1, nat1, ofs1, nat1, ofs1, len1, nat2, ofs2);\n return 0;\n }\n\n var s = num_leading_zero_bits_in_digit(nat2, ofs2+len2-1);\n shift_left_nat(nat2, ofs2, len2, nat_of_array([0]), 0, s);\n shift_left_nat(nat1, ofs1, len1, nat_of_array([0]), 0, s);\n\n var d = (nat2.data[ofs2+len2-1] >>> 0) + 1;\n var a = create_nat(len2+1);\n for (var i = len1 - 1; i >= len2; i--) {\n // Decent lower bound on quo\n var quo = d == 4294967296 ? (nat1.data[ofs1+i] >>> 0) : div_helper((nat1.data[ofs1+i] >>> 0), (nat1.data[ofs1+i-1] >>>0), d)[0];\n set_to_zero_nat(a, 0, len2+1);\n mult_digit_nat(a, 0, len2+1, nat2, ofs2, len2, nat_of_array([quo]), 0);\n sub_nat(nat1, ofs1+i-len2, len2+1, a, 0, len2+1, 1);\n\n while (nat1.data[ofs1+i] != 0 || compare_nat(nat1, ofs1+i-len2, len2, nat2, ofs2, len2) >= 0) {\n quo = quo + 1;\n sub_nat(nat1, ofs1+i-len2, len2+1, nat2, ofs2, len2, 1);\n }\n\n nat1.data[ofs1+i] = quo;\n }\n\n shift_right_nat(nat1, ofs1, len2, nat_of_array([0]), 0, s); // shift remainder\n shift_right_nat(nat2, ofs2, len2, nat_of_array([0]), 0, s); // restore\n return 0;\n}\n\n\n// 0 <= shift < 32\n//Provides: shift_right_nat\nfunction shift_right_nat(nat1, ofs1, len1, nat2, ofs2, nbits) {\n if(nbits == 0) {\n nat2.data[ofs2] = 0;\n return 0;\n }\n var wrap = 0;\n for(var i = len1-1; i >= 0; i--) {\n var a = nat1.data[ofs1+i] >>> 0;\n nat1.data[ofs1+i] = (a >>> nbits) | wrap;\n wrap = a << (32 - nbits);\n }\n nat2.data[ofs2] = wrap;\n return 0;\n}\n\n//Provides: compare_digits_nat\nfunction compare_digits_nat(nat1, ofs1, nat2, ofs2) {\n if(nat1.data[ofs1] > nat2.data[ofs2]) return 1;\n if(nat1.data[ofs1] < nat2.data[ofs2]) return -1;\n return 0;\n}\n\n//Provides: compare_nat\n//Requires: num_digits_nat\nfunction compare_nat(nat1, ofs1, len1, nat2, ofs2, len2) {\n var a = num_digits_nat(nat1, ofs1, len1);\n var b = num_digits_nat(nat2, ofs2, len2);\n if(a > b) return 1;\n if(a < b) return -1;\n for(var i = len1 - 1; i >= 0; i--) {\n if ((nat1.data[ofs1+i] >>> 0) > (nat2.data[ofs2+i] >>> 0)) return 1;\n if ((nat1.data[ofs1+i] >>> 0) < (nat2.data[ofs2+i] >>> 0)) return -1;\n }\n return 0;\n}\n\n//Provides: compare_nat_real\n//Requires: compare_nat\nfunction compare_nat_real(nat1,nat2){\n return compare_nat(nat1,0,nat1.data.length,nat2,0,nat2.data.length);\n}\n\n//Provides: land_digit_nat\nfunction land_digit_nat(nat1, ofs1, nat2, ofs2) {\n nat1.data[ofs1] &= nat2.data[ofs2];\n return 0;\n}\n\n//Provides: lor_digit_nat\nfunction lor_digit_nat(nat1, ofs1, nat2, ofs2) {\n nat1.data[ofs1] |= nat2.data[ofs2];\n return 0;\n}\n\n//Provides: lxor_digit_nat\nfunction lxor_digit_nat(nat1, ofs1, nat2, ofs2) {\n nat1.data[ofs1] ^= nat2.data[ofs2];\n return 0;\n}\n\n\n//Provides: serialize_nat\nfunction serialize_nat(writer, nat, sz){\n var len = nat.data.length;\n writer.write(32, len);\n for(var i = 0; i < len; i++){\n writer.write(32, nat.data[i]);\n }\n sz[0] = len * 4;\n sz[1] = len * 8;\n}\n\n//Provides: deserialize_nat\n//Requires: MlNat\nfunction deserialize_nat(reader, sz){\n var len = reader.read32s();\n var nat = new MlNat(len);\n for(var i = 0; i < len; i++){\n nat.data[i] = reader.read32s();\n }\n sz[0] = len * 4;\n return nat;\n}\n","// Js_of_ocaml library\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Jslib\n\n//Provides: caml_js_pure_expr const\nfunction caml_js_pure_expr (f) { return f(); }\n\n//Provides: caml_js_set (mutable, const, const)\nfunction caml_js_set(o,f,v) { o[f]=v;return 0}\n//Provides: caml_js_get mutable (const, const)\nfunction caml_js_get(o,f) { return o[f]; }\n//Provides: caml_js_delete (mutable, const)\nfunction caml_js_delete(o,f) { delete o[f]; return 0}\n\n//Provides: caml_js_instanceof (const, const)\nfunction caml_js_instanceof(o,c) { return (o instanceof c) ? 1 : 0; }\n\n//Provides: caml_js_typeof (const)\nfunction caml_js_typeof(o) { return typeof o; }\n\n//Provides:caml_trampoline\nfunction caml_trampoline(res) {\n var c = 1;\n while(res && res.joo_tramp){\n res = res.joo_tramp.apply(null, res.joo_args);\n c++;\n }\n return res;\n}\n\n//Provides:caml_trampoline_return\nfunction caml_trampoline_return(f,args) {\n return {joo_tramp:f,joo_args:args};\n}\n\n//Provides: js_print_stdout (const)\n//Requires: caml_utf16_of_utf8\nfunction js_print_stdout(s) {\n var s = caml_utf16_of_utf8(s);\n var g = globalThis;\n if (g.process && g.process.stdout && g.process.stdout.write) {\n g.process.stdout.write(s)\n } else {\n // Do not output the last \\n if present\n // as console logging display a newline at the end\n if(s.charCodeAt(s.length - 1) == 10)\n s = s.substr(0,s.length - 1 );\n var v = g.console;\n v && v.log && v.log(s);\n }\n}\n//Provides: js_print_stderr (const)\n//Requires: caml_utf16_of_utf8\nfunction js_print_stderr(s) {\n var s = caml_utf16_of_utf8(s);\n var g = globalThis;\n if (g.process && g.process.stdout && g.process.stdout.write) {\n g.process.stderr.write(s)\n } else {\n // Do not output the last \\n if present\n // as console logging display a newline at the end\n if(s.charCodeAt(s.length - 1) == 10)\n s = s.substr(0,s.length - 1 );\n var v = g.console;\n v && v.error && v.error(s);\n }\n}\n\n//Provides: caml_is_js\nfunction caml_is_js() {\n return 1;\n}\n\n//Provides: caml_wrap_exception const (const)\n//Requires: caml_global_data,caml_string_of_jsstring,caml_named_value\n//Requires: caml_return_exn_constant\nfunction caml_wrap_exception(e) {\n if(e instanceof Array) return e;\n //Stack_overflow: chrome, safari\n if(globalThis.RangeError\n && e instanceof globalThis.RangeError\n && e.message\n && e.message.match(/maximum call stack/i))\n return caml_return_exn_constant(caml_global_data.Stack_overflow);\n //Stack_overflow: firefox\n if(globalThis.InternalError\n && e instanceof globalThis.InternalError\n && e.message\n && e.message.match(/too much recursion/i))\n return caml_return_exn_constant(caml_global_data.Stack_overflow);\n //Wrap Error in Js.Error exception\n if(e instanceof globalThis.Error && caml_named_value(\"jsError\"))\n return [0,caml_named_value(\"jsError\"),e];\n //fallback: wrapped in Failure\n return [0,caml_global_data.Failure,caml_string_of_jsstring (String(e))];\n}\n\n// Experimental\n//Provides: caml_exn_with_js_backtrace\n//Requires: caml_global_data\nfunction caml_exn_with_js_backtrace(exn, force) {\n //never reraise for constant exn\n if(!exn.js_error || force || exn[0] == 248) exn.js_error = new globalThis.Error(\"Js exception containing backtrace\");\n return exn;\n}\n\n\n//Provides: caml_js_error_option_of_exception\nfunction caml_js_error_option_of_exception(exn) {\n if(exn.js_error) { return [0, exn.js_error]; }\n return 0;\n}\n\n\n\n//Provides: caml_js_from_bool const (const)\nfunction caml_js_from_bool(x) { return !!x; }\n//Provides: caml_js_to_bool const (const)\nfunction caml_js_to_bool(x) { return +x; }\n//Provides: caml_js_from_float const (const)\nfunction caml_js_from_float(x) { return x; }\n//Provides: caml_js_to_float const (const)\nfunction caml_js_to_float(x) { return x; }\n\n//Provides: caml_js_from_array mutable (shallow)\nfunction caml_js_from_array(a) {\n return a.slice(1);\n}\n//Provides: caml_js_to_array mutable (shallow)\nfunction caml_js_to_array(a) {\n var len = a.length;\n var b = new Array(len+1);\n b[0] = 0;\n for(var i=0;i=0; i--){\n var e = a[i];\n l = [0,e,l];\n }\n return l\n}\n\n//Provides: caml_list_to_js_array const (const)\nfunction caml_list_to_js_array(l){\n var a = [];\n for(; l !== 0; l = l[2]) {\n a.push(l[1]);\n }\n return a;\n}\n\n//Provides: caml_js_var mutable (const)\n//Requires: js_print_stderr\n//Requires: caml_jsstring_of_string\nfunction caml_js_var(x) {\n var x = caml_jsstring_of_string(x);\n //Checks that x has the form ident[.ident]*\n if(!x.match(/^[a-zA-Z_$][a-zA-Z_$0-9]*(\\.[a-zA-Z_$][a-zA-Z_$0-9]*)*$/)){\n js_print_stderr(\"caml_js_var: \\\"\" + x + \"\\\" is not a valid JavaScript variable. continuing ..\");\n //globalThis.console.error(\"Js.Unsafe.eval_string\")\n }\n return eval(x);\n}\n//Provides: caml_js_call (const, mutable, shallow)\n//Requires: caml_js_from_array\nfunction caml_js_call(f, o, args) { return f.apply(o, caml_js_from_array(args)); }\n//Provides: caml_js_fun_call (const, shallow)\n//Requires: caml_js_from_array\nfunction caml_js_fun_call(f, a) {\n switch (a.length) {\n case 1: return f();\n case 2: return f (a[1]);\n case 3: return f (a[1],a[2]);\n case 4: return f (a[1],a[2],a[3]);\n case 5: return f (a[1],a[2],a[3],a[4]);\n case 6: return f (a[1],a[2],a[3],a[4],a[5]);\n case 7: return f (a[1],a[2],a[3],a[4],a[5],a[6]);\n case 8: return f (a[1],a[2],a[3],a[4],a[5],a[6],a[7]);\n }\n return f.apply(null, caml_js_from_array(a));\n}\n//Provides: caml_js_meth_call (mutable, const, shallow)\n//Requires: caml_jsstring_of_string\n//Requires: caml_js_from_array\nfunction caml_js_meth_call(o, f, args) {\n return o[caml_jsstring_of_string(f)].apply(o, caml_js_from_array(args));\n}\n//Provides: caml_js_new (const, shallow)\n//Requires: caml_js_from_array\nfunction caml_js_new(c, a) {\n switch (a.length) {\n case 1: return new c;\n case 2: return new c (a[1]);\n case 3: return new c (a[1],a[2]);\n case 4: return new c (a[1],a[2],a[3]);\n case 5: return new c (a[1],a[2],a[3],a[4]);\n case 6: return new c (a[1],a[2],a[3],a[4],a[5]);\n case 7: return new c (a[1],a[2],a[3],a[4],a[5],a[6]);\n case 8: return new c (a[1],a[2],a[3],a[4],a[5],a[6],a[7]);\n }\n function F() { return c.apply(this, caml_js_from_array(a)); }\n F.prototype = c.prototype;\n return new F;\n}\n//Provides: caml_ojs_new_arr (const, shallow)\n//Requires: caml_js_from_array\nfunction caml_ojs_new_arr(c, a) {\n switch (a.length) {\n case 0: return new c;\n case 1: return new c (a[0]);\n case 2: return new c (a[0],a[1]);\n case 3: return new c (a[0],a[1],a[2]);\n case 4: return new c (a[0],a[1],a[2],a[3]);\n case 5: return new c (a[0],a[1],a[2],a[3],a[4]);\n case 6: return new c (a[0],a[1],a[2],a[3],a[4],a[5]);\n case 7: return new c (a[0],a[1],a[2],a[3],a[4],a[5],a[6]);\n }\n function F() { return c.apply(this, a); }\n F.prototype = c.prototype;\n return new F;\n}\n//Provides: caml_js_wrap_callback const (const)\n//Requires: caml_call_gen\nfunction caml_js_wrap_callback(f) {\n return function () {\n var len = arguments.length;\n if(len > 0){\n var args = new Array(len);\n for (var i = 0; i < len; i++) args[i] = arguments[i];\n return caml_call_gen(f, args);\n } else {\n return caml_call_gen(f, [undefined]);\n }\n }\n}\n\n//Provides: caml_js_wrap_callback_arguments\n//Requires: caml_call_gen\nfunction caml_js_wrap_callback_arguments(f) {\n return function() {\n var len = arguments.length;\n var args = new Array(len);\n for (var i = 0; i < len; i++) args[i] = arguments[i];\n return caml_call_gen(f, [args]);\n }\n}\n//Provides: caml_js_wrap_callback_strict const\n//Requires: caml_call_gen\nfunction caml_js_wrap_callback_strict(arity, f) {\n return function () {\n var n = arguments.length;\n if(n == arity && f.length == arity) return f.apply(null, arguments);\n var args = new Array(arity);\n var len = Math.min(arguments.length, arity)\n for (var i = 0; i < len; i++) args[i] = arguments[i];\n return caml_call_gen(f, args);\n };\n}\n//Provides: caml_js_wrap_meth_callback const (const)\n//Requires: caml_call_gen\nfunction caml_js_wrap_meth_callback(f) {\n return function () {\n var len = arguments.length;\n var args = new Array(len + 1);\n args[0] = this;\n for (var i = 0; i < len; i++) args[i+1] = arguments[i];\n return caml_call_gen(f,args);\n }\n}\n//Provides: caml_js_wrap_meth_callback_arguments const (const)\n//Requires: caml_call_gen\nfunction caml_js_wrap_meth_callback_arguments(f) {\n return function () {\n var len = arguments.length;\n var args = new Array(len);\n for (var i = 0; i < len; i++) args[i] = arguments[i];\n return caml_call_gen(f,[this,args]);\n }\n}\n//Provides: caml_js_wrap_meth_callback_strict const\n//Requires: caml_call_gen\nfunction caml_js_wrap_meth_callback_strict(arity, f) {\n return function () {\n var args = new Array(arity + 1);\n var len = Math.min(arguments.length, arity)\n args[0] = this;\n for (var i = 0; i < len; i++) args[i+1] = arguments[i];\n return caml_call_gen(f, args);\n };\n}\n//Provides: caml_js_wrap_meth_callback_unsafe const (const)\n//Requires: caml_call_gen\nfunction caml_js_wrap_meth_callback_unsafe(f) {\n return function () {\n var len = arguments.length;\n var args = new Array(len + 1);\n args[0] = this;\n for (var i = 0; i < len; i++) args[i+1] = arguments[i];\n return f.apply(null, args); }\n}\n//Provides: caml_js_equals mutable (const, const)\nfunction caml_js_equals (x, y) { return +(x == y); }\n\n//Provides: caml_js_eval_string (const)\n//Requires: caml_jsstring_of_string\nfunction caml_js_eval_string (s) {return eval(caml_jsstring_of_string(s));}\n\n//Provides: caml_js_expr (const)\n//Requires: js_print_stderr\n//Requires: caml_jsstring_of_string\nfunction caml_js_expr(s) {\n js_print_stderr(\"caml_js_expr: fallback to runtime evaluation\\n\");\n return eval(caml_jsstring_of_string(s));}\n\n//Provides: caml_pure_js_expr const (const)\n//Requires: js_print_stderr\n//Requires: caml_jsstring_of_string\nfunction caml_pure_js_expr (s){\n js_print_stderr(\"caml_pure_js_expr: fallback to runtime evaluation\\n\");\n return eval(caml_jsstring_of_string(s));}\n\n//Provides: caml_js_object (object_literal)\n//Requires: caml_jsstring_of_string\nfunction caml_js_object (a) {\n var o = {};\n for (var i = 1; i < a.length; i++) {\n var p = a[i];\n o[caml_jsstring_of_string(p[1])] = p[2];\n }\n return o;\n}\n","///////// BIGSTRING\n\n//Provides: bigstring_alloc\n//Requires: caml_ba_create\nfunction bigstring_alloc(_,size){\n return caml_ba_create(12, 0, [0,size]);\n}\n\n//Provides: bigstring_is_mmapped_stub\nfunction bigstring_is_mmapped_stub(x){\n return 0;\n}\n\n//Provides: bigstring_blit_stub\n//Requires: caml_bigstring_blit_ba_to_ba\nfunction bigstring_blit_stub(s1, i1, s2, i2, len){\n return caml_bigstring_blit_ba_to_ba(s1,i1,s2,i2,len);\n}\n\n//Provides: bigstring_blit_bytes_bigstring_stub\n//Requires: caml_bigstring_blit_bytes_to_ba\nfunction bigstring_blit_bytes_bigstring_stub(src, src_pos, dst, dst_pos, len){\n return caml_bigstring_blit_bytes_to_ba(src,src_pos,dst,dst_pos,len);\n}\n\n//Provides: bigstring_blit_bigstring_bytes_stub\n//Requires: caml_bigstring_blit_ba_to_bytes\nfunction bigstring_blit_bigstring_bytes_stub(src, src_pos, dst, dst_pos, len){\n return caml_bigstring_blit_ba_to_bytes(src,src_pos,dst,dst_pos,len);\n}\n\n//Provides: bigstring_blit_string_bigstring_stub\n//Requires: caml_bigstring_blit_string_to_ba\nfunction bigstring_blit_string_bigstring_stub(src, src_pos, dst, dst_pos, len){\n return caml_bigstring_blit_string_to_ba(src,src_pos,dst,dst_pos,len);\n}\n\n//Provides: bigstring_memset_stub\n//Requires: caml_ba_set_1\nfunction bigstring_memset_stub(bigstring, v_pos, v_len, v_char) {\n for (var i = 0; i < v_len; i++) {\n caml_ba_set_1(bigstring, v_pos + i, v_char);\n }\n}\n\n//Provides: bigstring_memcmp_stub\n//Requires: caml_ba_get_1\nfunction bigstring_memcmp_stub(v_s1, v_s1_pos, v_s2, v_s2_pos, v_len){\n for (var i = 0; i < v_len; i++) {\n var a = caml_ba_get_1(v_s1,v_s1_pos + i);\n var b = caml_ba_get_1(v_s2,v_s2_pos + i);\n if (a < b) return -1;\n if (a > b) return 1;\n }\n return 0;\n}\n\n//Provides: internalhash_fold_bigstring\n//Requires: caml_hash_mix_bigstring\nvar internalhash_fold_bigstring = caml_hash_mix_bigstring\n\n//Provides: bigstring_find\n//Requires: caml_ba_get_1\nfunction bigstring_find(bs, chr, pos, len){\n while(len > 0){\n if(caml_ba_get_1(bs,pos) == chr) return pos;\n pos++;\n len--;\n }\n return -1;\n}\n","///////// BIGSTRING\n\n//Provides: caml_hash_mix_bigstring\n//Requires: caml_hash_mix_bytes_arr\nfunction caml_hash_mix_bigstring(h, bs) {\n return caml_hash_mix_bytes_arr(h,bs.data);\n}\n\n//Provides: bigstring_to_array_buffer mutable\nfunction bigstring_to_array_buffer(bs) {\n return bs.data.buffer\n}\n\n//Provides: bigstring_to_typed_array mutable\nfunction bigstring_to_typed_array(bs) {\n return bs.data\n}\n\n//Provides: bigstring_of_array_buffer mutable\n//Requires: caml_ba_create_unsafe\nfunction bigstring_of_array_buffer(ab) {\n var ta = new globalThis.Uint8Array(ab);\n return caml_ba_create_unsafe(12, 0, [ta.length], ta);\n}\n\n//Provides: bigstring_of_typed_array mutable\n//Requires: caml_ba_create_unsafe\nfunction bigstring_of_typed_array(ba) {\n var ta = new globalThis.Uint8Array(ba.buffer, ba.byteOffset, ba.length * ba.BYTES_PER_ELEMENT);\n return caml_ba_create_unsafe(12, 0, [ta.length], ta);\n}\n\n//Provides: caml_bigstring_memcmp\n//Requires: caml_ba_get_1\nfunction caml_bigstring_memcmp(s1, pos1, s2, pos2, len){\n for (var i = 0; i < len; i++) {\n var a = caml_ba_get_1(s1,pos1 + i);\n var b = caml_ba_get_1(s2,pos2 + i);\n if (a < b) return -1;\n if (a > b) return 1;\n }\n return 0;\n}\n\n//Provides: caml_bigstring_blit_ba_to_ba\n//Requires: caml_invalid_argument, caml_array_bound_error\nfunction caml_bigstring_blit_ba_to_ba(ba1, pos1, ba2, pos2, len){\n if(12 != ba1.kind)\n caml_invalid_argument(\"caml_bigstring_blit_ba_to_ba: kind mismatch\");\n if(12 != ba2.kind)\n caml_invalid_argument(\"caml_bigstring_blit_ba_to_ba: kind mismatch\");\n if(len == 0) return 0;\n var ofs1 = ba1.offset(pos1);\n var ofs2 = ba2.offset(pos2);\n if(ofs1 + len > ba1.data.length){\n caml_array_bound_error();\n }\n if(ofs2 + len > ba2.data.length){\n caml_array_bound_error();\n }\n var slice = ba1.data.subarray(ofs1,ofs1+len);\n ba2.data.set(slice,pos2);\n return 0\n}\n\n//Provides: caml_bigstring_blit_string_to_ba\n//Requires: caml_invalid_argument, caml_array_bound_error, caml_array_of_string\n//Requires: caml_ml_string_length\nfunction caml_bigstring_blit_string_to_ba(str1, pos1, ba2, pos2, len){\n if(12 != ba2.kind)\n caml_invalid_argument(\"caml_bigstring_blit_string_to_ba: kind mismatch\");\n if(len == 0) return 0;\n var ofs2 = ba2.offset(pos2);\n if(pos1 + len > caml_ml_string_length(str1)) {\n caml_array_bound_error();\n }\n if(ofs2 + len > ba2.data.length) {\n caml_array_bound_error();\n }\n var slice = caml_array_of_string(str1).slice(pos1,pos1 + len);\n ba2.data.set(slice,ofs2);\n return 0\n}\n\n//Provides: caml_bigstring_blit_bytes_to_ba\n//Requires: caml_invalid_argument, caml_array_bound_error, caml_array_of_bytes\n//Requires: caml_ml_bytes_length\nfunction caml_bigstring_blit_bytes_to_ba(str1, pos1, ba2, pos2, len){\n if(12 != ba2.kind)\n caml_invalid_argument(\"caml_bigstring_blit_string_to_ba: kind mismatch\");\n if(len == 0) return 0;\n var ofs2 = ba2.offset(pos2);\n if(pos1 + len > caml_ml_bytes_length(str1)) {\n caml_array_bound_error();\n }\n if(ofs2 + len > ba2.data.length) {\n caml_array_bound_error();\n }\n var slice = caml_array_of_bytes(str1).slice(pos1,pos1 + len);\n ba2.data.set(slice,ofs2);\n return 0\n}\n\n//Provides: caml_bigstring_blit_ba_to_bytes\n//Requires: caml_invalid_argument, caml_array_bound_error\n//Requires: caml_blit_bytes, caml_bytes_of_array\n//Requires: caml_ml_bytes_length\nfunction caml_bigstring_blit_ba_to_bytes(ba1, pos1, bytes2, pos2, len){\n if(12 != ba1.kind)\n caml_invalid_argument(\"caml_bigstring_blit_string_to_ba: kind mismatch\");\n if(len == 0) return 0;\n var ofs1 = ba1.offset(pos1);\n if(ofs1 + len > ba1.data.length){\n caml_array_bound_error();\n }\n if(pos2 + len > caml_ml_bytes_length(bytes2)){\n caml_array_bound_error();\n }\n var slice = ba1.data.slice(ofs1, ofs1+len);\n caml_blit_bytes(caml_bytes_of_array(slice), 0, bytes2, pos2, len);\n return 0\n}\n","/*----------------------------------------------------------------------------\n Copyright (c) 2017 Inhabited Type LLC.\n\n All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions\n are met:\n\n 1. Redistributions of source code must retain the above copyright\n notice, this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in the\n documentation and/or other materials provided with the distribution.\n\n 3. Neither the name of the author nor the names of his contributors\n may be used to endorse or promote products derived from this software\n without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS ``AS IS'' AND ANY EXPRESS\n OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR\n ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\n STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN\n ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n POSSIBILITY OF SUCH DAMAGE.\n ----------------------------------------------------------------------------*/\n\n//Provides: bigstringaf_blit_to_bytes\n//Requires: caml_string_unsafe_set, caml_ba_get_1\nfunction bigstringaf_blit_to_bytes(src, src_off, dst, dst_off, len) {\n for (var i = 0; i < len; i++) {\n caml_string_unsafe_set(dst, dst_off + i, caml_ba_get_1(src, src_off + i));\n }\n}\n\n//Provides: bigstringaf_blit_to_bigstring\n//Requires: caml_ba_set_1, caml_ba_get_1\nfunction bigstringaf_blit_to_bigstring(src, src_off, dst, dst_off, len) {\n for (var i = 0; i < len; i++) {\n caml_ba_set_1(dst, dst_off + i, caml_ba_get_1(src, src_off + i));\n }\n}\n\n//Provides: bigstringaf_blit_from_bytes\n//Requires: caml_ba_set_1, caml_string_unsafe_get\nfunction bigstringaf_blit_from_bytes(src, src_off, dst, dst_off, len) {\n for (var i = 0; i < len; i++) {\n caml_ba_set_1(dst, dst_off + i, caml_string_unsafe_get(src, src_off + i));\n }\n}\n\n//Provides: bigstringaf_memcmp_bigstring\n//Requires: caml_ba_get_1, caml_int_compare\nfunction bigstringaf_memcmp_bigstring(ba1, ba1_off, ba2, ba2_off, len) {\n for (var i = 0; i < len; i++) {\n var c = caml_int_compare(caml_ba_get_1(ba1, ba1_off + i), caml_ba_get_1(ba2, ba2_off + i));\n if (c != 0) return c\n }\n return 0;\n}\n\n//Provides: bigstringaf_memcmp_string\n//Requires: caml_ba_get_1, caml_int_compare, caml_string_unsafe_get\nfunction bigstringaf_memcmp_string(ba, ba_off, str, str_off, len) {\n for (var i = 0; i < len; i++) {\n var c = caml_int_compare(caml_ba_get_1(ba, ba_off + i), caml_string_unsafe_get(str, str_off + i));\n if (c != 0) return c\n }\n return 0;\n}\n","///////// BIN_PROT\n\n//Provides: caml_check_bound_bigstring\n//Requires: caml_array_bound_error\nfunction caml_check_bound_bigstring(bigstring, i){\n if (i >>> 0 >= bigstring.data.length) caml_array_bound_error();\n}\n\n//Provides: bin_prot_blit_buf_float_array_stub\n//Requires: caml_check_bound, caml_check_bound_bigstring\nfunction bin_prot_blit_buf_float_array_stub(src_pos, src, dst_pos, dst, len){\n if(len == 0) return 0;\n caml_check_bound(dst,dst_pos); // first pos\n caml_check_bound(dst,dst_pos+len-1); // last pos\n caml_check_bound_bigstring(src, src_pos); /* first pos */\n caml_check_bound_bigstring(src, src_pos + len * 8 - 1); /* last pos */\n var view = new joo_global_object.Float64Array(len);\n var buffer = new joo_global_object.Uint8Array(view.buffer);\n buffer.set(src.data.subarray(src_pos, src_pos + (len * 8)));\n for(var i = 0; i < len; i++){\n // [+ 1] because the tag is at pos 0 \n dst[dst_pos+i+1] = view[i];\n }\n return 0\n}\n//Provides: bin_prot_blit_buf_bytes_stub\n//Requires: caml_bigstring_blit_ba_to_bytes\nfunction bin_prot_blit_buf_bytes_stub(src_pos, src, dst_pos, dst, len){\n return caml_bigstring_blit_ba_to_bytes(src, src_pos, dst, dst_pos, len);\n}\n//Provides: bin_prot_blit_float_array_buf_stub\n//Requires: caml_check_bound, caml_check_bound_bigstring\nfunction bin_prot_blit_float_array_buf_stub(src_pos,src, dst_pos, dst, len){\n if(len == 0) return 0 \n caml_check_bound (src, src_pos); // first pos \n caml_check_bound (src, src_pos + len - 1); // last pos\n caml_check_bound_bigstring(dst, dst_pos); /* first pos */\n caml_check_bound_bigstring(dst, dst_pos + len * 8 - 1); /* last pos */\n // [+ 1] because the tag is at pos 0\n src_pos = src_pos + 1\n var float64 = new joo_global_object.Float64Array(src.slice(src_pos,src_pos + len));\n var float64_uint8 = new joo_global_object.Uint8Array(float64.buffer);\n var view = dst.data.subarray(dst_pos, dst_pos + (len * 8));\n view.set(float64_uint8);\n return 0\n}\n//Provides: bin_prot_blit_string_buf_stub\n//Requires: caml_bigstring_blit_string_to_ba\nfunction bin_prot_blit_string_buf_stub (src_pos, src, dst_pos, dst, len){\n return caml_bigstring_blit_string_to_ba(src,src_pos, dst, dst_pos,len);\n}\n//Provides: bin_prot_blit_bytes_buf_stub\n//Requires: caml_bigstring_blit_string_to_ba\nfunction bin_prot_blit_bytes_buf_stub (src_pos, src, dst_pos, dst, len){\n return caml_bigstring_blit_string_to_ba(src,src_pos, dst, dst_pos,len);\n}\n\n//Provides: bin_prot_blit_buf_stub\n//Requires: caml_bigstring_blit_ba_to_ba, bigstring_of_typed_array\nfunction bin_prot_blit_buf_stub (src_pos, src, dst_pos, dst, len){\n // [bin_prot_blit_buf_stub] is used with mixed bigarray kinds.\n // Converter everything to bigarray of char before the blit.\n if(src.kind != 12) // 12 is the char kind\n src = bigstring_of_typed_array(src.data);\n if(dst.kind != 12) // 12 is the char kind\n dst = bigstring_of_typed_array(dst.data);\n return caml_bigstring_blit_ba_to_ba(src,src_pos,dst,dst_pos,len);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Array\n\n//Provides: caml_array_sub mutable\nfunction caml_array_sub (a, i, len) {\n var a2 = new Array(len+1);\n a2[0]=0;\n for(var i2 = 1, i1= i+1; i2 <= len; i2++,i1++ ){\n a2[i2]=a[i1];\n }\n return a2;\n}\n\n//Provides: caml_array_append mutable\nfunction caml_array_append(a1, a2) {\n var l1 = a1.length, l2 = a2.length;\n var l = l1+l2-1\n var a = new Array(l);\n a[0] = 0;\n var i = 1,j = 1;\n for(;i= 1; j--) a2[i2 + j] = a1[i1 + j];\n };\n return 0;\n}\n\n//Provides: caml_floatarray_blit\nfunction caml_floatarray_blit(a1, i1, a2, i2, len) {\n if (i2 <= i1) {\n for (var j = 1; j <= len; j++) a2[i2 + j] = a1[i1 + j];\n } else {\n for (var j = len; j >= 1; j--) a2[i2 + j] = a1[i1 + j];\n };\n return 0;\n}\n\n///////////// Pervasive\n//Provides: caml_array_set (mutable, const, const)\n//Requires: caml_array_bound_error\nfunction caml_array_set (array, index, newval) {\n if ((index < 0) || (index >= array.length - 1)) caml_array_bound_error();\n array[index+1]=newval; return 0;\n}\n\n//Provides: caml_array_get mutable (const, const)\n//Requires: caml_array_bound_error\nfunction caml_array_get (array, index) {\n if ((index < 0) || (index >= array.length - 1)) caml_array_bound_error();\n return array[index+1];\n}\n\n//Provides: caml_array_fill\nfunction caml_array_fill(array, ofs, len, v){\n for(var i = 0; i < len; i++){\n array[ofs+i+1] = v;\n }\n return 0;\n}\n\n//Provides: caml_check_bound (const, const)\n//Requires: caml_array_bound_error\nfunction caml_check_bound (array, index) {\n if (index >>> 0 >= array.length - 1) caml_array_bound_error();\n return array;\n}\n\n//Provides: caml_make_vect const (const, const)\n//Requires: caml_array_bound_error\nfunction caml_make_vect (len, init) {\n if (len < 0) caml_array_bound_error();\n var len = len + 1 | 0;\n var b = new Array(len);\n b[0]=0;\n for (var i = 1; i < len; i++) b[i] = init;\n return b;\n}\n\n//Provides: caml_make_float_vect const (const)\n//Requires: caml_array_bound_error\nfunction caml_make_float_vect(len){\n if (len < 0) caml_array_bound_error();\n var len = len + 1 | 0;\n var b = new Array(len);\n b[0]=254;\n for (var i = 1; i < len; i++) b[i] = 0;\n return b\n}\n//Provides: caml_floatarray_create const (const)\n//Requires: caml_array_bound_error\nfunction caml_floatarray_create(len){\n if (len < 0) caml_array_bound_error();\n var len = len + 1 | 0;\n var b = new Array(len);\n b[0]=254;\n for (var i = 1; i < len; i++) b[i] = 0;\n return b\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_ml_debug_info_status const\nfunction caml_ml_debug_info_status () { return 0; }\n//Provides: caml_backtrace_status const\nfunction caml_backtrace_status () { return 0; }\n//Provides: caml_get_exception_backtrace const\nfunction caml_get_exception_backtrace () { return 0; }\n//Provides: caml_get_exception_raw_backtrace const\nfunction caml_get_exception_raw_backtrace () { return [0]; }\n//Provides: caml_record_backtrace\nfunction caml_record_backtrace () { return 0; }\n//Provides: caml_convert_raw_backtrace const\nfunction caml_convert_raw_backtrace () { return [0]; }\n//Provides: caml_raw_backtrace_length\nfunction caml_raw_backtrace_length() { return 0; }\n//Provides: caml_raw_backtrace_next_slot\nfunction caml_raw_backtrace_next_slot() { return 0 }\n//Provides: caml_raw_backtrace_slot\n//Requires: caml_invalid_argument\nfunction caml_raw_backtrace_slot () {\n caml_invalid_argument(\"Printexc.get_raw_backtrace_slot: index out of bounds\");\n}\n//Provides: caml_restore_raw_backtrace\nfunction caml_restore_raw_backtrace(exn, bt) { return 0 }\n//Provides: caml_get_current_callstack const\nfunction caml_get_current_callstack () { return [0]; }\n\n//Provides: caml_convert_raw_backtrace_slot\n//Requires: caml_failwith\nfunction caml_convert_raw_backtrace_slot(){\n caml_failwith(\"caml_convert_raw_backtrace_slot\");\n}\n","// Provides: plonk_wasm\nvar plonk_wasm = require('./plonk_wasm.js');\n","/* global globalThis, plonk_wasm, caml_js_to_bool, caml_jsstring_of_string,\n caml_string_of_jsstring\n caml_create_bytes, caml_bytes_unsafe_set, caml_bytes_unsafe_get, caml_ml_bytes_length,\n UInt64, caml_int64_of_int32\n*/\n\n// Provides: tsBindings\nvar tsBindings = globalThis.__snarkyTsBindings;\n\n// Provides: getTsBindings\n// Requires: tsBindings\nfunction getTsBindings() {\n return tsBindings;\n}\n\n// Provides: caml_bytes_of_uint8array\n// Requires: caml_create_bytes, caml_bytes_unsafe_set\nvar caml_bytes_of_uint8array = function (uint8array) {\n var length = uint8array.length;\n var ocaml_bytes = caml_create_bytes(length);\n for (var i = 0; i < length; i++) {\n // No need to convert here: OCaml Char.t is just an int under the hood.\n caml_bytes_unsafe_set(ocaml_bytes, i, uint8array[i]);\n }\n return ocaml_bytes;\n};\n\n// Provides: caml_bytes_to_uint8array\n// Requires: caml_ml_bytes_length, caml_bytes_unsafe_get\nvar caml_bytes_to_uint8array = function (ocaml_bytes) {\n var length = caml_ml_bytes_length(ocaml_bytes);\n var bytes = new globalThis.Uint8Array(length);\n for (var i = 0; i < length; i++) {\n // No need to convert here: OCaml Char.t is just an int under the hood.\n bytes[i] = caml_bytes_unsafe_get(ocaml_bytes, i);\n }\n return bytes;\n};\n\n// Provides: caml_bigint_256_of_numeral\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_bigint_256_of_numeral = function (s, len, base) {\n return plonk_wasm.caml_bigint_256_of_numeral(\n caml_jsstring_of_string(s),\n len,\n base\n );\n};\n\n// Provides: caml_bigint_256_of_decimal_string\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_bigint_256_of_decimal_string = function (s) {\n return plonk_wasm.caml_bigint_256_of_decimal_string(\n caml_jsstring_of_string(s)\n );\n};\n\n// Provides: caml_bigint_256_num_limbs\n// Requires: plonk_wasm\nvar caml_bigint_256_num_limbs = plonk_wasm.caml_bigint_256_num_limbs;\n\n// Provides: caml_bigint_256_bytes_per_limb\n// Requires: plonk_wasm\nvar caml_bigint_256_bytes_per_limb = plonk_wasm.caml_bigint_256_bytes_per_limb;\n\n// Provides: caml_bigint_256_div\n// Requires: plonk_wasm\nvar caml_bigint_256_div = plonk_wasm.caml_bigint_256_div;\n\n// Provides: caml_bigint_256_compare\n// Requires: plonk_wasm\nvar caml_bigint_256_compare = plonk_wasm.caml_bigint_256_compare;\n\n// Provides: caml_bigint_256_print\n// Requires: plonk_wasm\nvar caml_bigint_256_print = plonk_wasm.caml_bigint_256_print;\n\n// Provides: caml_bigint_256_to_string\n// Requires: plonk_wasm, caml_string_of_jsstring\nvar caml_bigint_256_to_string = function (x) {\n return caml_string_of_jsstring(plonk_wasm.caml_bigint_256_to_string(x));\n};\n\n// Provides: caml_bigint_256_test_bit\n// Requires: plonk_wasm, caml_js_to_bool\nvar caml_bigint_256_test_bit = function (x, i) {\n return caml_js_to_bool(plonk_wasm.caml_bigint_256_test_bit(x, i));\n};\n\n// Provides: caml_bigint_256_to_bytes\n// Requires: plonk_wasm, caml_bytes_of_uint8array\nvar caml_bigint_256_to_bytes = function (x) {\n return caml_bytes_of_uint8array(plonk_wasm.caml_bigint_256_to_bytes(x));\n};\n\n// Provides: caml_bigint_256_of_bytes\n// Requires: plonk_wasm, caml_bytes_to_uint8array\nvar caml_bigint_256_of_bytes = function (ocaml_bytes) {\n return plonk_wasm.caml_bigint_256_of_bytes(\n caml_bytes_to_uint8array(ocaml_bytes)\n );\n};\n\n// Provides: caml_bigint_256_deep_copy\n// Requires: plonk_wasm\nvar caml_bigint_256_deep_copy = plonk_wasm.caml_bigint_256_deep_copy;\n\n// Provides: caml_pasta_fp_copy\nvar caml_pasta_fp_copy = function (x, y) {\n for (var i = 0, l = x.length; i < l; i++) {\n x[i] = y[i];\n }\n};\n\n// Provides: caml_option_of_maybe_undefined\nvar caml_option_of_maybe_undefined = function (x) {\n if (x === undefined) {\n return 0; // None\n } else {\n return [0, x]; // Some(x)\n }\n};\n\n// Provides: caml_option_to_maybe_undefined\nvar caml_option_to_maybe_undefined = function (x) {\n if (x === 0) {\n // None\n return undefined;\n } else {\n return x[1];\n }\n};\n\n// Provides: caml_pasta_fp_size_in_bits\n// Requires: plonk_wasm\nvar caml_pasta_fp_size_in_bits = plonk_wasm.caml_pasta_fp_size_in_bits;\n\n// Provides: caml_pasta_fp_size\n// Requires: plonk_wasm\nvar caml_pasta_fp_size = plonk_wasm.caml_pasta_fp_size;\n\n// Provides: caml_pasta_fp_add\n// Requires: plonk_wasm\nvar caml_pasta_fp_add = plonk_wasm.caml_pasta_fp_add;\n\n// Provides: caml_pasta_fp_sub\n// Requires: plonk_wasm\nvar caml_pasta_fp_sub = plonk_wasm.caml_pasta_fp_sub;\n\n// Provides: caml_pasta_fp_negate\n// Requires: plonk_wasm\nvar caml_pasta_fp_negate = plonk_wasm.caml_pasta_fp_negate;\n\n// Provides: caml_pasta_fp_mul\n// Requires: plonk_wasm\nvar caml_pasta_fp_mul = plonk_wasm.caml_pasta_fp_mul;\n\n// Provides: caml_pasta_fp_div\n// Requires: plonk_wasm\nvar caml_pasta_fp_div = plonk_wasm.caml_pasta_fp_div;\n\n// Provides: caml_pasta_fp_inv\n// Requires: plonk_wasm, caml_option_of_maybe_undefined\nvar caml_pasta_fp_inv = function (x) {\n return caml_option_of_maybe_undefined(plonk_wasm.caml_pasta_fp_inv(x));\n};\n\n// Provides: caml_pasta_fp_square\n// Requires: plonk_wasm\nvar caml_pasta_fp_square = plonk_wasm.caml_pasta_fp_square;\n\n// Provides: caml_pasta_fp_is_square\n// Requires: plonk_wasm, caml_js_to_bool\nvar caml_pasta_fp_is_square = function (x) {\n return caml_js_to_bool(plonk_wasm.caml_pasta_fp_is_square(x));\n};\n\n// Provides: caml_pasta_fp_sqrt\n// Requires: plonk_wasm, caml_option_of_maybe_undefined\nvar caml_pasta_fp_sqrt = function (x) {\n return caml_option_of_maybe_undefined(plonk_wasm.caml_pasta_fp_sqrt(x));\n};\n\n// Provides: caml_pasta_fp_of_int\n// Requires: plonk_wasm\nvar caml_pasta_fp_of_int = plonk_wasm.caml_pasta_fp_of_int;\n\n// Provides: caml_pasta_fp_to_string\n// Requires: plonk_wasm, caml_string_of_jsstring\nvar caml_pasta_fp_to_string = function (x) {\n return caml_string_of_jsstring(plonk_wasm.caml_pasta_fp_to_string(x));\n};\n\n// Provides: caml_pasta_fp_of_string\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fp_of_string = function (x) {\n return plonk_wasm.caml_pasta_fp_of_string(caml_jsstring_of_string(x));\n};\n\n// Provides: caml_pasta_fp_print\n// Requires: plonk_wasm\nvar caml_pasta_fp_print = plonk_wasm.caml_pasta_fp_print;\n\n// Provides: caml_pasta_fp_mut_add\n// Requires: caml_pasta_fp_copy, caml_pasta_fp_add\nvar caml_pasta_fp_mut_add = function (x, y) {\n caml_pasta_fp_copy(x, caml_pasta_fp_add(x, y));\n};\n\n// Provides: caml_pasta_fp_mut_sub\n// Requires: caml_pasta_fp_copy, caml_pasta_fp_sub\nvar caml_pasta_fp_mut_sub = function (x, y) {\n caml_pasta_fp_copy(x, caml_pasta_fp_sub(x, y));\n};\n\n// Provides: caml_pasta_fp_mut_mul\n// Requires: caml_pasta_fp_copy, caml_pasta_fp_mul\nvar caml_pasta_fp_mut_mul = function (x, y) {\n caml_pasta_fp_copy(x, caml_pasta_fp_mul(x, y));\n};\n\n// Provides: caml_pasta_fp_mut_square\n// Requires: caml_pasta_fp_copy, caml_pasta_fp_square\nvar caml_pasta_fp_mut_square = function (x) {\n caml_pasta_fp_copy(x, caml_pasta_fp_square(x));\n};\n\n// Provides: caml_pasta_fp_compare\n// Requires: plonk_wasm\nvar caml_pasta_fp_compare = plonk_wasm.caml_pasta_fp_compare;\n\n// Provides: caml_pasta_fp_equal\n// Requires: plonk_wasm\nvar caml_pasta_fp_equal = plonk_wasm.caml_pasta_fp_equal;\n\n// Provides: caml_pasta_fp_random\n// Requires: plonk_wasm\nvar caml_pasta_fp_random = plonk_wasm.caml_pasta_fp_random;\n\n// Provides: caml_pasta_fp_rng\n// Requires: plonk_wasm\nvar caml_pasta_fp_rng = plonk_wasm.caml_pasta_fp_rng;\n\n// Provides: caml_pasta_fp_to_bigint\n// Requires: plonk_wasm\nvar caml_pasta_fp_to_bigint = plonk_wasm.caml_pasta_fp_to_bigint;\n\n// Provides: caml_pasta_fp_of_bigint\n// Requires: plonk_wasm\nvar caml_pasta_fp_of_bigint = plonk_wasm.caml_pasta_fp_of_bigint;\n\n// Provides: caml_pasta_fp_two_adic_root_of_unity\n// Requires: plonk_wasm\nvar caml_pasta_fp_two_adic_root_of_unity =\n plonk_wasm.caml_pasta_fp_two_adic_root_of_unity;\n\n// Provides: caml_pasta_fp_domain_generator\n// Requires: plonk_wasm\nvar caml_pasta_fp_domain_generator = plonk_wasm.caml_pasta_fp_domain_generator;\n\n// Provides: caml_pasta_fp_to_bytes\n// Requires: plonk_wasm, caml_bytes_of_uint8array\nvar caml_pasta_fp_to_bytes = function (x) {\n var res = plonk_wasm.caml_pasta_fp_to_bytes(x);\n return caml_bytes_of_uint8array(plonk_wasm.caml_pasta_fp_to_bytes(x));\n};\n\n// Provides: caml_pasta_fp_of_bytes\n// Requires: plonk_wasm, caml_bytes_to_uint8array\nvar caml_pasta_fp_of_bytes = function (ocaml_bytes) {\n return plonk_wasm.caml_pasta_fp_of_bytes(\n caml_bytes_to_uint8array(ocaml_bytes)\n );\n};\n\n// Provides: caml_pasta_fp_deep_copy\n// Requires: plonk_wasm\nvar caml_pasta_fp_deep_copy = plonk_wasm.caml_pasta_fp_deep_copy;\n\n// Provides: caml_pasta_fq_copy\nvar caml_pasta_fq_copy = function (x, y) {\n for (var i = 0, l = x.length; i < l; i++) {\n x[i] = y[i];\n }\n};\n\n// Provides: caml_pasta_fq_size_in_bits\n// Requires: plonk_wasm\nvar caml_pasta_fq_size_in_bits = plonk_wasm.caml_pasta_fq_size_in_bits;\n\n// Provides: caml_pasta_fq_size\n// Requires: plonk_wasm\nvar caml_pasta_fq_size = plonk_wasm.caml_pasta_fq_size;\n\n// Provides: caml_pasta_fq_add\n// Requires: plonk_wasm\nvar caml_pasta_fq_add = plonk_wasm.caml_pasta_fq_add;\n\n// Provides: caml_pasta_fq_sub\n// Requires: plonk_wasm\nvar caml_pasta_fq_sub = plonk_wasm.caml_pasta_fq_sub;\n\n// Provides: caml_pasta_fq_negate\n// Requires: plonk_wasm\nvar caml_pasta_fq_negate = plonk_wasm.caml_pasta_fq_negate;\n\n// Provides: caml_pasta_fq_mul\n// Requires: plonk_wasm\nvar caml_pasta_fq_mul = plonk_wasm.caml_pasta_fq_mul;\n\n// Provides: caml_pasta_fq_div\n// Requires: plonk_wasm\nvar caml_pasta_fq_div = plonk_wasm.caml_pasta_fq_div;\n\n// Provides: caml_pasta_fq_inv\n// Requires: plonk_wasm, caml_option_of_maybe_undefined\nvar caml_pasta_fq_inv = function (x) {\n return caml_option_of_maybe_undefined(plonk_wasm.caml_pasta_fq_inv(x));\n};\n\n// Provides: caml_pasta_fq_square\n// Requires: plonk_wasm\nvar caml_pasta_fq_square = plonk_wasm.caml_pasta_fq_square;\n\n// Provides: caml_pasta_fq_is_square\n// Requires: plonk_wasm, caml_js_to_bool\nvar caml_pasta_fq_is_square = function (x) {\n return caml_js_to_bool(plonk_wasm.caml_pasta_fq_is_square(x));\n};\n\n// Provides: caml_pasta_fq_sqrt\n// Requires: plonk_wasm, caml_option_of_maybe_undefined\nvar caml_pasta_fq_sqrt = function (x) {\n return caml_option_of_maybe_undefined(plonk_wasm.caml_pasta_fq_sqrt(x));\n};\n\n// Provides: caml_pasta_fq_of_int\n// Requires: plonk_wasm\nvar caml_pasta_fq_of_int = plonk_wasm.caml_pasta_fq_of_int;\n\n// Provides: caml_pasta_fq_to_string\n// Requires: plonk_wasm, caml_string_of_jsstring\nvar caml_pasta_fq_to_string = function (x) {\n return caml_string_of_jsstring(plonk_wasm.caml_pasta_fq_to_string(x));\n};\n\n// Provides: caml_pasta_fq_of_string\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fq_of_string = function (x) {\n return plonk_wasm.caml_pasta_fq_of_string(caml_jsstring_of_string(x));\n};\n\n// Provides: caml_pasta_fq_print\n// Requires: plonk_wasm\nvar caml_pasta_fq_print = plonk_wasm.caml_pasta_fq_print;\n\n// Provides: caml_pasta_fq_mut_add\n// Requires: caml_pasta_fq_copy, caml_pasta_fq_add\nvar caml_pasta_fq_mut_add = function (x, y) {\n caml_pasta_fq_copy(x, caml_pasta_fq_add(x, y));\n};\n\n// Provides: caml_pasta_fq_mut_sub\n// Requires: caml_pasta_fq_copy, caml_pasta_fq_sub\nvar caml_pasta_fq_mut_sub = function (x, y) {\n caml_pasta_fq_copy(x, caml_pasta_fq_sub(x, y));\n};\n\n// Provides: caml_pasta_fq_mut_mul\n// Requires: caml_pasta_fq_copy, caml_pasta_fq_mul\nvar caml_pasta_fq_mut_mul = function (x, y) {\n caml_pasta_fq_copy(x, caml_pasta_fq_mul(x, y));\n};\n\n// Provides: caml_pasta_fq_mut_square\n// Requires: caml_pasta_fq_copy, caml_pasta_fq_square\nvar caml_pasta_fq_mut_square = function (x) {\n caml_pasta_fq_copy(x, caml_pasta_fq_square(x));\n};\n\n// Provides: caml_pasta_fq_compare\n// Requires: plonk_wasm\nvar caml_pasta_fq_compare = plonk_wasm.caml_pasta_fq_compare;\n\n// Provides: caml_pasta_fq_equal\n// Requires: plonk_wasm\nvar caml_pasta_fq_equal = plonk_wasm.caml_pasta_fq_equal;\n\n// Provides: caml_pasta_fq_random\n// Requires: plonk_wasm\nvar caml_pasta_fq_random = plonk_wasm.caml_pasta_fq_random;\n\n// Provides: caml_pasta_fq_rng\n// Requires: plonk_wasm\nvar caml_pasta_fq_rng = plonk_wasm.caml_pasta_fq_rng;\n\n// Provides: caml_pasta_fq_to_bigint\n// Requires: plonk_wasm\nvar caml_pasta_fq_to_bigint = plonk_wasm.caml_pasta_fq_to_bigint;\n\n// Provides: caml_pasta_fq_of_bigint\n// Requires: plonk_wasm\nvar caml_pasta_fq_of_bigint = plonk_wasm.caml_pasta_fq_of_bigint;\n\n// Provides: caml_pasta_fq_two_adic_root_of_unity\n// Requires: plonk_wasm\nvar caml_pasta_fq_two_adic_root_of_unity =\n plonk_wasm.caml_pasta_fq_two_adic_root_of_unity;\n\n// Provides: caml_pasta_fq_domain_generator\n// Requires: plonk_wasm\nvar caml_pasta_fq_domain_generator = plonk_wasm.caml_pasta_fq_domain_generator;\n\n// Provides: caml_pasta_fq_to_bytes\n// Requires: plonk_wasm, caml_bytes_of_uint8array\nvar caml_pasta_fq_to_bytes = function (x) {\n var res = plonk_wasm.caml_pasta_fq_to_bytes(x);\n return caml_bytes_of_uint8array(plonk_wasm.caml_pasta_fq_to_bytes(x));\n};\n\n// Provides: caml_pasta_fq_of_bytes\n// Requires: plonk_wasm, caml_bytes_to_uint8array\nvar caml_pasta_fq_of_bytes = function (ocaml_bytes) {\n return plonk_wasm.caml_pasta_fq_of_bytes(\n caml_bytes_to_uint8array(ocaml_bytes)\n );\n};\n\n// Provides: caml_pasta_fq_deep_copy\n// Requires: plonk_wasm\nvar caml_pasta_fq_deep_copy = plonk_wasm.caml_pasta_fq_deep_copy;\n\n// Provides: caml_u8array_vector_to_rust_flat_vector\nvar caml_u8array_vector_to_rust_flat_vector = function (v) {\n var i = 1; // The first entry is the OCaml tag for arrays\n var len = v.length - i;\n if (len === 0) {\n return new globalThis.Uint8Array(0);\n }\n var inner_len = v[i].length;\n var res = new globalThis.Uint8Array(len * inner_len);\n for (var pos = 0; i <= len; i++) {\n for (var j = 0; j < inner_len; j++, pos++) {\n res[pos] = v[i][j];\n }\n }\n return res;\n};\n\n// Provides: caml_u8array_vector_of_rust_flat_vector\nvar caml_u8array_vector_of_rust_flat_vector = function (v, inner_len) {\n var len = v.length;\n var output_len = len / inner_len;\n var res = new Array(output_len + 1);\n res[0] = 0; // OCaml tag before array contents, so that we can use this with arrays or vectors\n for (var i = 1, pos = 0; i <= output_len; i++) {\n var inner_res = new globalThis.Uint8Array(inner_len);\n for (var j = 0; j < inner_len; j++, pos++) {\n inner_res[j] = v[pos];\n }\n res[i] = inner_res;\n }\n return res;\n};\n\n// Provides: js_class_vector_to_rust_vector\nvar js_class_vector_to_rust_vector = function (v) {\n var len = v.length;\n var res = new globalThis.Uint32Array(len);\n for (var i = 0; i < len; i++) {\n // Beware: caller may need to do finalizer things to avoid these\n // pointers disappearing out from under us.\n res[i] = v[i].__wbg_ptr;\n }\n return res;\n};\n\n// Provides: js_class_vector_of_rust_vector\nvar js_class_vector_of_rust_vector = function (v, klass) {\n // return v.map(klass.__wrap)\n var len = v.length;\n var res = new Array(len);\n for (var i = 0; i < len; i++) {\n // Beware: the caller may need to add finalizers to these.\n res[i] = klass.__wrap(v[i]);\n }\n return res;\n};\n\n// Provides: caml_fp_vector_create\nvar caml_fp_vector_create = function () {\n return [0]; // OCaml tag for arrays, so that we can use the same utility fns on both\n};\n\n// Provides: caml_fp_vector_length\nvar caml_fp_vector_length = function (v) {\n return v.length - 1;\n};\n\n// Provides: caml_fp_vector_emplace_back\nvar caml_fp_vector_emplace_back = function (v, x) {\n v.push(x);\n};\n\n// Provides: caml_fp_vector_get\nvar caml_fp_vector_get = function (v, i) {\n var value = v[i + 1];\n if (value === undefined) {\n throw Error(\n 'caml_fp_vector_get: Index out of bounds, got ' + i + '/' + (v.length - 1)\n );\n }\n return new globalThis.Uint8Array(value);\n};\n\n// Provides: caml_fp_vector_to_rust\n// Requires: caml_u8array_vector_to_rust_flat_vector\nvar caml_fp_vector_to_rust = function (v) {\n return caml_u8array_vector_to_rust_flat_vector(v);\n};\n\n// Provides: caml_fp_vector_of_rust\n// Requires: caml_u8array_vector_of_rust_flat_vector\nvar caml_fp_vector_of_rust = function (v) {\n // TODO: Hardcoding this is a little brittle\n return caml_u8array_vector_of_rust_flat_vector(v, 32);\n};\n\n// Provides: caml_fq_vector_create\nvar caml_fq_vector_create = function () {\n return [0]; // OCaml tag for arrays, so that we can use the same utility fns on both\n};\n\n// Provides: caml_fq_vector_length\nvar caml_fq_vector_length = function (v) {\n return v.length - 1;\n};\n\n// Provides: caml_fq_vector_emplace_back\nvar caml_fq_vector_emplace_back = function (v, x) {\n v.push(x);\n};\n\n// Provides: caml_fq_vector_get\nvar caml_fq_vector_get = function (v, i) {\n var value = v[i + 1];\n if (value === undefined) {\n throw Error(\n 'caml_fq_vector_get: Index out of bounds, got ' + i + '/' + (v.length - 1)\n );\n }\n return new globalThis.Uint8Array(value);\n};\n\n// Provides: caml_fq_vector_to_rust\n// Requires: caml_u8array_vector_to_rust_flat_vector\nvar caml_fq_vector_to_rust = function (v) {\n return caml_u8array_vector_to_rust_flat_vector(v);\n};\n\n// Provides: caml_fq_vector_of_rust\n// Requires: caml_u8array_vector_of_rust_flat_vector\nvar caml_fq_vector_of_rust = function (v) {\n // TODO: Hardcoding this is a little brittle\n return caml_u8array_vector_of_rust_flat_vector(v, 32);\n};\n\n// Provides: free_finalization_registry\nvar free_finalization_registry = new globalThis.FinalizationRegistry(function (\n instance_representative\n) {\n instance_representative.free();\n});\n\n// Provides: free_on_finalize\n// Requires: free_finalization_registry\nvar free_on_finalize = function (x) {\n // This is an unfortunate hack: we're creating a second instance of the\n // class to be able to call free on it. We can't pass the value itself,\n // since the registry holds a strong reference to the representative value.\n //\n // However, the class is only really a wrapper around a pointer, with a\n // reference to the class' prototype as its __prototype__.\n //\n // It might seem cleaner to call the destructor here on the pointer\n // directly, but unfortunately the destructor name is some mangled internal\n // string generated by wasm_bindgen. For now, this is the best,\n // least-brittle way to free once the original class instance gets collected.\n var instance_representative = x.constructor.__wrap(x.__wbg_ptr);\n free_finalization_registry.register(x, instance_representative, x);\n return x;\n};\n\n// Provides: rust_affine_to_caml_affine\nvar rust_affine_to_caml_affine = function (pt) {\n var infinity = pt.infinity;\n if (infinity) {\n pt.free();\n return 0;\n } else {\n var x = pt.x;\n var y = pt.y;\n pt.free();\n return [0, [0, x, y]];\n }\n};\n\n// Provides: rust_affine_of_caml_affine\nvar rust_affine_of_caml_affine = function (pt, klass) {\n var res = new klass();\n if (pt === 0) {\n res.infinity = true;\n } else {\n // Layout is [0, [0, x, y]]\n // First 0 is the tag (it's the 0th constructor that takes arguments)\n // Second 0 is the block marker for the anonymous tuple arguments\n res.x = pt[1][1];\n res.y = pt[1][2];\n }\n return res;\n};\n\n// Provides: caml_pallas_one\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_one = function () {\n var res = plonk_wasm.caml_pallas_one();\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_add\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_add = function (x, y) {\n var res = plonk_wasm.caml_pallas_add(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_sub\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_sub = function (x, y) {\n var res = plonk_wasm.caml_pallas_sub(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_negate\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_negate = function (x) {\n var res = plonk_wasm.caml_pallas_negate(x);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_double\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_double = function (x) {\n var res = plonk_wasm.caml_pallas_double(x);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_scale\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_scale = function (x, y) {\n var res = plonk_wasm.caml_pallas_scale(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_random\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_random = function () {\n var res = plonk_wasm.caml_pallas_random();\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_rng\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_rng = function (i) {\n var res = plonk_wasm.caml_pallas_rng(i);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_to_affine\n// Requires: plonk_wasm, rust_affine_to_caml_affine\nvar caml_pallas_to_affine = function (pt) {\n var res = plonk_wasm.caml_pallas_to_affine(pt);\n return rust_affine_to_caml_affine(res);\n};\n\n// Provides: caml_pallas_of_affine\n// Requires: plonk_wasm, rust_affine_of_caml_affine, free_on_finalize\nvar caml_pallas_of_affine = function (pt) {\n var res = plonk_wasm.caml_pallas_of_affine(\n rust_affine_of_caml_affine(pt, plonk_wasm.caml_pallas_affine_one)\n );\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_of_affine_coordinates\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pallas_of_affine_coordinates = function (x, y) {\n var res = plonk_wasm.caml_pallas_of_affine_coordinates(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_pallas_endo_base\n// Requires: plonk_wasm\nvar caml_pallas_endo_base = plonk_wasm.caml_pallas_endo_base;\n\n// Provides: caml_pallas_endo_scalar\n// Requires: plonk_wasm\nvar caml_pallas_endo_scalar = plonk_wasm.caml_pallas_endo_scalar;\n\n// Provides: caml_pallas_affine_deep_copy\n// Requires: plonk_wasm, rust_affine_of_caml_affine, rust_affine_to_caml_affine\nvar caml_pallas_affine_deep_copy = function (pt) {\n return rust_affine_to_caml_affine(\n plonk_wasm.caml_pallas_affine_deep_copy(\n rust_affine_of_caml_affine(pt, plonk_wasm.caml_pallas_affine_one)\n )\n );\n};\n\n// Provides: caml_vesta_one\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_one = function () {\n var res = plonk_wasm.caml_vesta_one();\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_add\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_add = function (x, y) {\n var res = plonk_wasm.caml_vesta_add(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_sub\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_sub = function (x, y) {\n var res = plonk_wasm.caml_vesta_sub(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_negate\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_negate = function (x) {\n var res = plonk_wasm.caml_vesta_negate(x);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_double\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_double = function (x) {\n var res = plonk_wasm.caml_vesta_double(x);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_scale\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_scale = function (x, y) {\n var res = plonk_wasm.caml_vesta_scale(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_random\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_random = function () {\n var res = plonk_wasm.caml_vesta_random();\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_rng\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_rng = function (i) {\n var res = plonk_wasm.caml_vesta_rng(i);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_to_affine\n// Requires: plonk_wasm, rust_affine_to_caml_affine\nvar caml_vesta_to_affine = function (pt) {\n var res = plonk_wasm.caml_vesta_to_affine(pt);\n return rust_affine_to_caml_affine(res);\n};\n\n// Provides: caml_vesta_of_affine\n// Requires: plonk_wasm, rust_affine_of_caml_affine, free_on_finalize\nvar caml_vesta_of_affine = function (pt) {\n var res = plonk_wasm.caml_vesta_of_affine(\n rust_affine_of_caml_affine(pt, plonk_wasm.caml_vesta_affine_one)\n );\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_of_affine_coordinates\n// Requires: plonk_wasm, free_on_finalize\nvar caml_vesta_of_affine_coordinates = function (x, y) {\n var res = plonk_wasm.caml_vesta_of_affine_coordinates(x, y);\n free_on_finalize(res);\n return res;\n};\n\n// Provides: caml_vesta_endo_base\n// Requires: plonk_wasm\nvar caml_vesta_endo_base = plonk_wasm.caml_vesta_endo_base;\n\n// Provides: caml_vesta_endo_scalar\n// Requires: plonk_wasm\nvar caml_vesta_endo_scalar = plonk_wasm.caml_vesta_endo_scalar;\n\n// Provides: caml_vesta_affine_deep_copy\n// Requires: plonk_wasm, rust_affine_of_caml_affine, rust_affine_to_caml_affine\nvar caml_vesta_affine_deep_copy = function (pt) {\n return rust_affine_to_caml_affine(\n plonk_wasm.caml_vesta_affine_deep_copy(\n rust_affine_of_caml_affine(pt, plonk_wasm.caml_vesta_affine_one)\n )\n );\n};\n\n// Provides: caml_array_of_rust_vector\n// Requires: js_class_vector_of_rust_vector\nvar caml_array_of_rust_vector = function (v, klass, convert, should_free) {\n v = js_class_vector_of_rust_vector(v, klass);\n var len = v.length;\n var res = new Array(len + 1);\n res[0] = 0; // OCaml tag before array contents\n for (var i = 0; i < len; i++) {\n var rust_val = v[i];\n res[i + 1] = convert(rust_val);\n if (should_free) {\n rust_val.free();\n }\n }\n return res;\n};\n\n// Provides: caml_array_to_rust_vector\n// Requires: js_class_vector_to_rust_vector, free_finalization_registry\nvar caml_array_to_rust_vector = function (v, convert, mk_new) {\n v = v.slice(1); // Copy, dropping OCaml tag\n for (var i = 0, l = v.length; i < l; i++) {\n var class_val = convert(v[i], mk_new);\n v[i] = class_val;\n // Don't free when GC runs; rust will free on its end.\n free_finalization_registry.unregister(class_val);\n }\n return js_class_vector_to_rust_vector(v);\n};\n\n// Provides: caml_poly_comm_of_rust_poly_comm\n// Requires: rust_affine_to_caml_affine, caml_array_of_rust_vector\nvar caml_poly_comm_of_rust_poly_comm = function (\n poly_comm,\n klass,\n should_free\n) {\n var rust_shifted = poly_comm.shifted;\n var rust_unshifted = poly_comm.unshifted;\n var caml_shifted;\n if (rust_shifted === undefined) {\n caml_shifted = 0;\n } else {\n caml_shifted = [0, rust_affine_to_caml_affine(rust_shifted)];\n }\n var caml_unshifted = caml_array_of_rust_vector(\n rust_unshifted,\n klass,\n rust_affine_to_caml_affine,\n should_free\n );\n return [0, caml_unshifted, caml_shifted];\n};\n\n// Provides: caml_poly_comm_to_rust_poly_comm\n// Requires: rust_affine_of_caml_affine, caml_array_to_rust_vector\nvar caml_poly_comm_to_rust_poly_comm = function (\n poly_comm,\n poly_comm_class,\n mk_affine\n) {\n var caml_unshifted = poly_comm[1];\n var caml_shifted = poly_comm[2];\n var rust_shifted = undefined;\n if (caml_shifted !== 0) {\n rust_shifted = rust_affine_of_caml_affine(caml_shifted[1], mk_affine);\n }\n var rust_unshifted = caml_array_to_rust_vector(\n caml_unshifted,\n rust_affine_of_caml_affine,\n mk_affine\n );\n return new poly_comm_class(rust_unshifted, rust_shifted);\n};\n\n// Provides: caml_vesta_poly_comm_of_rust\n// Requires: plonk_wasm, caml_poly_comm_of_rust_poly_comm\nvar caml_vesta_poly_comm_of_rust = function (x) {\n return caml_poly_comm_of_rust_poly_comm(x, plonk_wasm.WasmGVesta, false);\n};\n\n// Provides: caml_vesta_poly_comm_to_rust\n// Requires: plonk_wasm, caml_poly_comm_to_rust_poly_comm\nvar caml_vesta_poly_comm_to_rust = function (x) {\n return caml_poly_comm_to_rust_poly_comm(\n x,\n plonk_wasm.WasmFpPolyComm,\n plonk_wasm.caml_vesta_affine_one\n );\n};\n\n// Provides: caml_pallas_poly_comm_of_rust\n// Requires: plonk_wasm, caml_poly_comm_of_rust_poly_comm\nvar caml_pallas_poly_comm_of_rust = function (x) {\n return caml_poly_comm_of_rust_poly_comm(x, plonk_wasm.WasmGPallas, false);\n};\n\n// Provides: caml_pallas_poly_comm_to_rust\n// Requires: plonk_wasm, caml_poly_comm_to_rust_poly_comm\nvar caml_pallas_poly_comm_to_rust = function (x) {\n return caml_poly_comm_to_rust_poly_comm(\n x,\n plonk_wasm.WasmFqPolyComm,\n plonk_wasm.caml_pallas_affine_one\n );\n};\n\n// Provides: caml_fp_srs_create\n// Requires: plonk_wasm, free_on_finalize\nvar caml_fp_srs_create = function (i) {\n return free_on_finalize(plonk_wasm.caml_fp_srs_create(i));\n};\n\n// Provides: caml_fp_srs_write\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_fp_srs_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_fp_srs_write(append, t, caml_jsstring_of_string(path));\n};\n\n// Provides: caml_fp_srs_read\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_fp_srs_read = function (offset, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n var res = plonk_wasm.caml_fp_srs_read(offset, caml_jsstring_of_string(path));\n if (res) {\n return [0, res]; // Some(res)\n } else {\n return 0; // None\n }\n};\n\n// Provides: caml_fp_srs_lagrange_commitment\n// Requires: plonk_wasm, caml_vesta_poly_comm_of_rust\nvar caml_fp_srs_lagrange_commitment = function (t, domain_size, i) {\n var res = plonk_wasm.caml_fp_srs_lagrange_commitment(t, domain_size, i);\n return caml_vesta_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fp_srs_commit_evaluations\n// Requires: plonk_wasm, caml_vesta_poly_comm_of_rust, caml_fp_vector_to_rust\nvar caml_fp_srs_commit_evaluations = function (t, domain_size, fps) {\n var res = plonk_wasm.caml_fp_srs_commit_evaluations(\n t,\n domain_size,\n caml_fp_vector_to_rust(fps)\n );\n return caml_vesta_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fp_srs_b_poly_commitment\n// Requires: plonk_wasm, caml_vesta_poly_comm_of_rust, caml_u8array_vector_to_rust_flat_vector\nvar caml_fp_srs_b_poly_commitment = function (srs, chals) {\n var res = plonk_wasm.caml_fp_srs_b_poly_commitment(\n srs,\n caml_u8array_vector_to_rust_flat_vector(chals)\n );\n return caml_vesta_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fp_srs_batch_accumulator_check\n// Requires: plonk_wasm, rust_affine_of_caml_affine, caml_array_to_rust_vector, caml_fp_vector_to_rust\nvar caml_fp_srs_batch_accumulator_check = function (srs, comms, chals) {\n var rust_comms = caml_array_to_rust_vector(\n comms,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_vesta_affine_one\n );\n var rust_chals = caml_fp_vector_to_rust(chals);\n var ok = plonk_wasm.caml_fp_srs_batch_accumulator_check(\n srs,\n rust_comms,\n rust_chals\n );\n return ok;\n};\n\n// Provides: caml_fp_srs_batch_accumulator_generate\n// Requires: plonk_wasm, rust_affine_to_caml_affine, caml_array_of_rust_vector, caml_fp_vector_to_rust\nvar caml_fp_srs_batch_accumulator_generate = function (srs, comms, chals) {\n var rust_chals = caml_fp_vector_to_rust(chals);\n var rust_comms = plonk_wasm.caml_fp_srs_batch_accumulator_generate(\n srs,\n comms,\n rust_chals\n );\n return caml_array_of_rust_vector(\n rust_comms,\n plonk_wasm.WasmGVesta,\n rust_affine_to_caml_affine,\n false\n );\n};\n\n// Provides: caml_fp_srs_h\n// Requires: plonk_wasm, rust_affine_to_caml_affine\nvar caml_fp_srs_h = function (t) {\n return rust_affine_to_caml_affine(plonk_wasm.caml_fp_srs_h(t));\n};\n\n// Provides: caml_fq_srs_create\n// Requires: plonk_wasm, free_on_finalize\nvar caml_fq_srs_create = function (i) {\n return free_on_finalize(plonk_wasm.caml_fq_srs_create(i));\n};\n\n// Provides: caml_fq_srs_write\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_fq_srs_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_fq_srs_write(append, t, caml_jsstring_of_string(path));\n};\n\n// Provides: caml_fq_srs_read\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_fq_srs_read = function (offset, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n var res = plonk_wasm.caml_fq_srs_read(offset, caml_jsstring_of_string(path));\n if (res) {\n return [0, res]; // Some(res)\n } else {\n return 0; // None\n }\n};\n\n// Provides: caml_fq_srs_lagrange_commitment\n// Requires: plonk_wasm, caml_pallas_poly_comm_of_rust\nvar caml_fq_srs_lagrange_commitment = function (t, domain_size, i) {\n var res = plonk_wasm.caml_fq_srs_lagrange_commitment(t, domain_size, i);\n return caml_pallas_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fq_srs_commit_evaluations\n// Requires: plonk_wasm, caml_pallas_poly_comm_of_rust, caml_fq_vector_to_rust\nvar caml_fq_srs_commit_evaluations = function (t, domain_size, fqs) {\n var res = plonk_wasm.caml_fq_srs_commit_evaluations(\n t,\n domain_size,\n caml_fq_vector_to_rust(fqs)\n );\n return caml_pallas_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fq_srs_b_poly_commitment\n// Requires: plonk_wasm, caml_pallas_poly_comm_of_rust, caml_u8array_vector_to_rust_flat_vector\nvar caml_fq_srs_b_poly_commitment = function (srs, chals) {\n var res = plonk_wasm.caml_fq_srs_b_poly_commitment(\n srs,\n caml_u8array_vector_to_rust_flat_vector(chals)\n );\n return caml_pallas_poly_comm_of_rust(res);\n};\n\n// Provides: caml_fq_srs_batch_accumulator_check\n// Requires: plonk_wasm, rust_affine_of_caml_affine, caml_array_to_rust_vector, caml_fq_vector_to_rust\nvar caml_fq_srs_batch_accumulator_check = function (srs, comms, chals) {\n var rust_comms = caml_array_to_rust_vector(\n comms,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_pallas_affine_one\n );\n var rust_chals = caml_fq_vector_to_rust(chals);\n var ok = plonk_wasm.caml_fq_srs_batch_accumulator_check(\n srs,\n rust_comms,\n rust_chals\n );\n return ok;\n};\n\n// Provides: caml_fq_srs_batch_accumulator_generate\n// Requires: plonk_wasm, rust_affine_to_caml_affine, caml_array_of_rust_vector, caml_fq_vector_to_rust\nvar caml_fq_srs_batch_accumulator_generate = function (srs, comms, chals) {\n var rust_chals = caml_fq_vector_to_rust(chals);\n var rust_comms = plonk_wasm.caml_fq_srs_batch_accumulator_generate(\n srs,\n comms,\n rust_chals\n );\n return caml_array_of_rust_vector(\n rust_comms,\n plonk_wasm.WasmGPallas,\n rust_affine_to_caml_affine,\n false\n );\n};\n\n// Provides: caml_fq_srs_h\n// Requires: plonk_wasm, rust_affine_to_caml_affine\nvar caml_fq_srs_h = function (t) {\n return rust_affine_to_caml_affine(plonk_wasm.caml_fq_srs_h(t));\n};\n\n// Provides: caml_fq_srs_add_lagrange_basis\n// Requires: plonk_wasm\nfunction caml_fq_srs_add_lagrange_basis(srs, log2_size) {\n return plonk_wasm.caml_fq_srs_add_lagrange_basis(srs, log2_size);\n}\n\n// Provides: caml_plonk_wire_of_rust\nvar caml_plonk_wire_of_rust = function (wire) {\n var res = [0, wire.row, wire.col];\n wire.free();\n return res;\n};\n\n// Provides: caml_plonk_wire_to_rust\n// Requires: plonk_wasm\nvar caml_plonk_wire_to_rust = function (wire) {\n return plonk_wasm.Wire.create(wire[1], wire[2]);\n};\n\n// Provides: caml_plonk_wires_of_rust\n// Requires: caml_plonk_wire_of_rust\nvar caml_plonk_wires_of_rust = function (wires) {\n var res = [\n 0,\n caml_plonk_wire_of_rust(wires[0]),\n caml_plonk_wire_of_rust(wires[1]),\n caml_plonk_wire_of_rust(wires[2]),\n caml_plonk_wire_of_rust(wires[3]),\n caml_plonk_wire_of_rust(wires[4]),\n caml_plonk_wire_of_rust(wires[5]),\n caml_plonk_wire_of_rust(wires[6]),\n ];\n wires.free();\n return res;\n};\n\n// Provides: caml_plonk_wires_to_rust\n// Requires: plonk_wasm, caml_plonk_wire_to_rust\nvar caml_plonk_wires_to_rust = function (wires) {\n return new plonk_wasm.WasmGateWires(\n caml_plonk_wire_to_rust(wires[1]),\n caml_plonk_wire_to_rust(wires[2]),\n caml_plonk_wire_to_rust(wires[3]),\n caml_plonk_wire_to_rust(wires[4]),\n caml_plonk_wire_to_rust(wires[5]),\n caml_plonk_wire_to_rust(wires[6]),\n caml_plonk_wire_to_rust(wires[7])\n );\n};\n\n// Provides: caml_plonk_gate_of_rust\n// Requires: caml_plonk_wires_of_rust, caml_u8array_vector_of_rust_flat_vector\nvar caml_plonk_gate_of_rust = function (gate) {\n // TODO: Hardcoding 32 here is a little brittle\n var res = [\n 0,\n gate.typ,\n caml_plonk_wires_of_rust(gate.wires),\n caml_u8array_vector_of_rust_flat_vector(gate.c, 32),\n ];\n gate.free();\n return res;\n};\n\n// Provides: caml_fp_plonk_gate_to_rust\n// Requires: plonk_wasm, caml_plonk_wires_to_rust, caml_u8array_vector_to_rust_flat_vector\nvar caml_fp_plonk_gate_to_rust = function (gate) {\n return new plonk_wasm.WasmFpGate(\n gate[1],\n caml_plonk_wires_to_rust(gate[2]),\n caml_u8array_vector_to_rust_flat_vector(gate[3])\n );\n};\n\n// Provides: caml_fq_plonk_gate_to_rust\n// Requires: plonk_wasm, caml_plonk_wires_to_rust, caml_u8array_vector_to_rust_flat_vector\nvar caml_fq_plonk_gate_to_rust = function (gate) {\n // TODO: Hardcoding 32 here is a little brittle\n return new plonk_wasm.WasmFqGate(\n gate[1],\n caml_plonk_wires_to_rust(gate[2]),\n caml_u8array_vector_to_rust_flat_vector(gate[3])\n );\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_create\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pasta_fp_plonk_gate_vector_create = function () {\n return free_on_finalize(plonk_wasm.caml_pasta_fp_plonk_gate_vector_create());\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_add\n// Requires: plonk_wasm, caml_fp_plonk_gate_to_rust\nvar caml_pasta_fp_plonk_gate_vector_add = function (v, x) {\n return plonk_wasm.caml_pasta_fp_plonk_gate_vector_add(\n v,\n caml_fp_plonk_gate_to_rust(x)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_get\n// Requires: plonk_wasm, caml_plonk_gate_of_rust\nvar caml_pasta_fp_plonk_gate_vector_get = function (v, i) {\n return caml_plonk_gate_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_gate_vector_get(v, i)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_len\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_gate_vector_len = function (v) {\n return plonk_wasm.caml_pasta_fp_plonk_gate_vector_len(v);\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_wrap\n// Requires: plonk_wasm, caml_plonk_wire_to_rust\nvar caml_pasta_fp_plonk_gate_vector_wrap = function (v, x, y) {\n return plonk_wasm.caml_pasta_fp_plonk_gate_vector_wrap(\n v,\n caml_plonk_wire_to_rust(x),\n caml_plonk_wire_to_rust(y)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_gate_vector_digest\n// Requires: plonk_wasm, caml_bytes_of_uint8array\nvar caml_pasta_fp_plonk_gate_vector_digest = function (\n public_input_size,\n gate_vector\n) {\n var uint8array = plonk_wasm.caml_pasta_fp_plonk_gate_vector_digest(\n public_input_size,\n gate_vector\n );\n return caml_bytes_of_uint8array(uint8array);\n};\n\n// Provides: caml_pasta_fp_plonk_circuit_serialize\n// Requires: plonk_wasm, caml_string_of_jsstring\nvar caml_pasta_fp_plonk_circuit_serialize = function (\n public_input_size,\n gate_vector\n) {\n return caml_string_of_jsstring(\n plonk_wasm.caml_pasta_fp_plonk_circuit_serialize(\n public_input_size,\n gate_vector\n )\n );\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_create\n// Requires: plonk_wasm, free_on_finalize\nvar caml_pasta_fq_plonk_gate_vector_create = function () {\n return free_on_finalize(plonk_wasm.caml_pasta_fq_plonk_gate_vector_create());\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_add\n// Requires: plonk_wasm, caml_fq_plonk_gate_to_rust\nvar caml_pasta_fq_plonk_gate_vector_add = function (v, x) {\n return plonk_wasm.caml_pasta_fq_plonk_gate_vector_add(\n v,\n caml_fq_plonk_gate_to_rust(x)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_get\n// Requires: plonk_wasm, caml_plonk_gate_of_rust\nvar caml_pasta_fq_plonk_gate_vector_get = function (v, i) {\n return caml_plonk_gate_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_gate_vector_get(v, i)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_len\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_gate_vector_len = function (v) {\n return plonk_wasm.caml_pasta_fq_plonk_gate_vector_len(v);\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_wrap\n// Requires: plonk_wasm, caml_plonk_wire_to_rust\nvar caml_pasta_fq_plonk_gate_vector_wrap = function (v, x, y) {\n return plonk_wasm.caml_pasta_fq_plonk_gate_vector_wrap(\n v,\n caml_plonk_wire_to_rust(x),\n caml_plonk_wire_to_rust(y)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_gate_vector_digest\n// Requires: plonk_wasm, caml_bytes_of_uint8array\nvar caml_pasta_fq_plonk_gate_vector_digest = function (\n public_input_size,\n gate_vector\n) {\n var uint8array = plonk_wasm.caml_pasta_fq_plonk_gate_vector_digest(\n public_input_size,\n gate_vector\n );\n return caml_bytes_of_uint8array(uint8array);\n};\n\n// Provides: caml_pasta_fq_plonk_circuit_serialize\n// Requires: plonk_wasm, caml_string_of_jsstring\nvar caml_pasta_fq_plonk_circuit_serialize = function (\n public_input_size,\n gate_vector\n) {\n return caml_string_of_jsstring(\n plonk_wasm.caml_pasta_fq_plonk_circuit_serialize(\n public_input_size,\n gate_vector\n )\n );\n};\n\n// Provides: caml_fp_runtime_table_cfg_to_rust\n// Requires: plonk_wasm, caml_fp_vector_to_rust\nvar caml_fp_runtime_table_cfg_to_rust = function (\n caml_runtime_table_cfg,\n mk_class\n) {\n // A value caml_runtime_table_cfg is a record on the OCaml side.\n // The converter should be changed if CamlRuntimeTableCfg is modified.\n // id field: int32\n var caml_runtime_table_cfg_id = caml_runtime_table_cfg[1];\n // first_column field: Caml array of fq element\n var caml_runtime_table_cfg_first_column = caml_runtime_table_cfg[2];\n var res = new mk_class(\n caml_runtime_table_cfg_id,\n caml_fp_vector_to_rust(caml_runtime_table_cfg_first_column)\n );\n return res;\n};\n\n// Provides: caml_fp_lookup_table_to_rust\n// Requires: plonk_wasm, caml_fp_vector_of_rust\nvar caml_fp_lookup_table_to_rust = function (caml_lookup_table, mk_class) {\n // A value lookup table is a caml record with an id and a data field.\n // The converter should be changed if CamlLookupTable is modified.\n // id field: int32\n var caml_lookup_table_id = caml_lookup_table[1];\n // data field: caml array of fq vectors\n var caml_lookup_table_data = caml_lookup_table[2];\n // caml_lookup_table_data is a Caml array, starting with 0 for the runtime repr.\n // removing 1 for the 0 used by jsoo to represent values.\n var lt_data_length = caml_lookup_table_data.length - 1;\n var data = new plonk_wasm.WasmVecVecFp(lt_data_length);\n for (var i = 1; i < lt_data_length; i++) {\n data.push(caml_fp_vector_of_rust(caml_lookup_table_data.get(i - 1)));\n }\n var res = new mk_class(caml_lookup_table_id, data);\n return res;\n};\n\n// Provides: caml_fq_lookup_table_to_rust\n// Requires: plonk_wasm, caml_fq_vector_to_rust\nvar caml_fq_lookup_table_to_rust = function (caml_lookup_table, mk_class) {\n // A value lookup table is a caml record with an id and a data field.\n // The converter should be changed if CamlLookupTable is modified.\n // id field: int32\n var caml_lookup_table_id = caml_lookup_table[1];\n // data field: caml array of fq vectors\n var caml_lookup_table_data = caml_lookup_table[2];\n // caml_lookup_table_data is a Caml array, starting with 0 for the runtime repr.\n // removing 1 for the 0 used by jsoo to represent values.\n var lt_data_length = caml_lookup_table_data.length - 1;\n var data = new plonk_wasm.WasmVecVecFq(lt_data_length);\n for (var i = 1; i < lt_data_length; i++) {\n data.push(caml_fq_vector_to_rust(caml_lookup_table_data.get(i - 1)));\n }\n var res = new mk_class(caml_lookup_table_id, data);\n return res;\n};\n\n// Provides: caml_pasta_fp_plonk_index_create\n// Requires: plonk_wasm, free_on_finalize, caml_array_to_rust_vector, caml_fp_runtime_table_cfg_to_rust, caml_fp_lookup_table_to_rust\nvar caml_pasta_fp_plonk_index_create = function (\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n) {\n var wasm_lookup_tables = caml_array_to_rust_vector(\n caml_lookup_tables,\n caml_fp_lookup_table_to_rust,\n plonk_wasm.WasmPastaFpLookupTable\n );\n\n var wasm_runtime_table_cfgs = caml_array_to_rust_vector(\n caml_runtime_table_cfgs,\n caml_fp_runtime_table_cfg_to_rust,\n plonk_wasm.WasmPastaFpRuntimeTableCfg\n );\n\n var t = plonk_wasm.caml_pasta_fp_plonk_index_create(\n gates,\n public_inputs,\n wasm_lookup_tables,\n wasm_runtime_table_cfgs,\n prev_challenges,\n urs\n );\n return free_on_finalize(t);\n};\n\n// Provides: caml_pasta_fp_plonk_index_create_bytecode\n// Requires: caml_pasta_fp_plonk_index_create\nvar caml_pasta_fp_plonk_index_create_bytecode = function (\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n) {\n return caml_pasta_fp_plonk_index_create(\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n );\n};\n\n// Provides: caml_pasta_fp_plonk_index_max_degree\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_index_max_degree =\n plonk_wasm.caml_pasta_fp_plonk_index_max_degree;\n\n// Provides: caml_pasta_fp_plonk_index_public_inputs\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_index_public_inputs =\n plonk_wasm.caml_pasta_fp_plonk_index_public_inputs;\n\n// Provides: caml_pasta_fp_plonk_index_domain_d1_size\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_index_domain_d1_size =\n plonk_wasm.caml_pasta_fp_plonk_index_domain_d1_size;\n\n// Provides: caml_pasta_fp_plonk_index_domain_d4_size\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_index_domain_d4_size =\n plonk_wasm.caml_pasta_fp_plonk_index_domain_d4_size;\n\n// Provides: caml_pasta_fp_plonk_index_domain_d8_size\n// Requires: plonk_wasm\nvar caml_pasta_fp_plonk_index_domain_d8_size =\n plonk_wasm.caml_pasta_fp_plonk_index_domain_d8_size;\n\n// Provides: caml_pasta_fp_plonk_index_read\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fp_plonk_index_read = function (offset, urs, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n return plonk_wasm.caml_pasta_fp_plonk_index_read(\n offset,\n urs,\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_index_write\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fp_plonk_index_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_pasta_fp_plonk_index_write(\n append,\n t,\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_fq_runtime_table_cfg_to_rust\n// Requires: plonk_wasm, caml_fq_vector_to_rust\nvar caml_fq_runtime_table_cfg_to_rust = function (\n caml_runtime_table_cfg,\n mk_class\n) {\n // A value caml_runtime_table_cfg is a record on the OCaml side.\n // The converter should be changed if CamlRuntimeTableCfg is modified.\n // id field: int32\n var caml_runtime_table_cfg_id = caml_runtime_table_cfg[1];\n // first_column field: Caml array of fq element\n var caml_runtime_table_cfg_first_column = caml_runtime_table_cfg[2];\n var res = new mk_class(\n caml_runtime_table_cfg_id,\n caml_fq_vector_to_rust(caml_runtime_table_cfg_first_column)\n );\n return res;\n};\n\n// Provides: caml_pasta_fq_plonk_index_create\n// Requires: plonk_wasm, free_on_finalize, caml_array_to_rust_vector, caml_fq_runtime_table_cfg_to_rust, caml_fq_lookup_table_to_rust\nvar caml_pasta_fq_plonk_index_create = function (\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n) {\n var wasm_lookup_tables = caml_array_to_rust_vector(\n caml_lookup_tables,\n caml_fq_lookup_table_to_rust,\n plonk_wasm.WasmPastaFqLookupTable\n );\n\n var wasm_runtime_table_cfgs = caml_array_to_rust_vector(\n caml_runtime_table_cfgs,\n caml_fq_runtime_table_cfg_to_rust,\n plonk_wasm.WasmPastaFqRuntimeTableCfg\n );\n\n return free_on_finalize(\n plonk_wasm.caml_pasta_fq_plonk_index_create(\n gates,\n public_inputs,\n wasm_lookup_tables,\n wasm_runtime_table_cfgs,\n prev_challenges,\n urs\n )\n );\n};\n\n// Provides: caml_pasta_fq_plonk_index_create_bytecode\n// Requires: caml_pasta_fq_plonk_index_create\nvar caml_pasta_fq_plonk_index_create_bytecode = function (\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n) {\n return caml_pasta_fq_plonk_index_create(\n gates,\n public_inputs,\n caml_lookup_tables,\n caml_runtime_table_cfgs,\n prev_challenges,\n urs\n );\n};\n\n// Provides: caml_pasta_fq_plonk_index_max_degree\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_index_max_degree =\n plonk_wasm.caml_pasta_fq_plonk_index_max_degree;\n\n// Provides: caml_pasta_fq_plonk_index_public_inputs\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_index_public_inputs =\n plonk_wasm.caml_pasta_fq_plonk_index_public_inputs;\n\n// Provides: caml_pasta_fq_plonk_index_domain_d1_size\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_index_domain_d1_size =\n plonk_wasm.caml_pasta_fq_plonk_index_domain_d1_size;\n\n// Provides: caml_pasta_fq_plonk_index_domain_d4_size\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_index_domain_d4_size =\n plonk_wasm.caml_pasta_fq_plonk_index_domain_d4_size;\n\n// Provides: caml_pasta_fq_plonk_index_domain_d8_size\n// Requires: plonk_wasm\nvar caml_pasta_fq_plonk_index_domain_d8_size =\n plonk_wasm.caml_pasta_fq_plonk_index_domain_d8_size;\n\n// Provides: caml_pasta_fq_plonk_index_read\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fq_plonk_index_read = function (offset, urs, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n return plonk_wasm.caml_pasta_fq_plonk_index_read(\n offset,\n urs,\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_index_write\n// Requires: plonk_wasm, caml_jsstring_of_string\nvar caml_pasta_fq_plonk_index_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_pasta_fq_plonk_index_write(\n append,\n t,\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_plonk_domain_of_rust\nvar caml_plonk_domain_of_rust = function (x) {\n var log_size_of_group = x.log_size_of_group;\n var group_gen = x.group_gen;\n x.free();\n return [0, log_size_of_group, group_gen];\n};\n\n// Provides: caml_plonk_domain_to_rust\n// Requires: free_on_finalize\nvar caml_plonk_domain_to_rust = function (x, klass) {\n // TODO: Check if this gets finalized\n return new klass(x[1], x[2]);\n};\n\n// Provides: caml_plonk_verification_evals_of_rust\n// Requires: caml_poly_comm_of_rust_poly_comm, js_class_vector_of_rust_vector, plonk_wasm\nvar caml_plonk_verification_evals_of_rust = function (x, affine_klass) {\n var convert = function (poly_comm) {\n return caml_poly_comm_of_rust_poly_comm(poly_comm, affine_klass, false);\n };\n\n var convert_opt = function (poly_comm_opt) {\n // Borrowing from caml_option_of_maybe_undefined\n if (poly_comm_opt === undefined) {\n return 0;\n }\n return [\n 0,\n caml_poly_comm_of_rust_poly_comm(poly_comm_opt, affine_klass, false),\n ];\n };\n\n // var convertArray = function(comms) {\n // var n = comms.length;\n // var res = new Array(n-1);\n // for (var i = 1; i < n; i++) {\n // res[i-1] = convert(comms[i]);\n // }\n // return js_class_vector_to_rust_vector(res);\n // };\n\n // should be inverse of the above ^\n // TODO: make work for both Wasm..PolyComm types\n var convertArray = function (comms) {\n comms = js_class_vector_of_rust_vector(comms, plonk_wasm.WasmFqPolyComm);\n // comms = js_class_vector_of_rust_vector(comms, plonk_wasm.WasmFpPolyComm);\n return [0].concat(comms.map(convert));\n };\n\n var sigma_comm = convertArray(x.sigma_comm);\n var coefficients_comm = convertArray(x.coefficients_comm);\n var generic_comm = convert(x.generic_comm);\n var psm_comm = convert(x.psm_comm);\n var complete_add_comm = convert(x.complete_add_comm);\n var mul_comm = convert(x.mul_comm);\n var emul_comm = convert(x.emul_comm);\n var endomul_scalar_comm = convert(x.endomul_scalar_comm);\n\n var xor_comm = convert_opt(x.xor_comm);\n var range_check0_comm = convert_opt(x.range_check0_comm);\n var range_check1_comm = convert_opt(x.range_check1_comm);\n var foreign_field_add_comm = convert_opt(x.foreign_field_add_comm);\n var foreign_field_mul_comm = convert_opt(x.foreign_field_mul_comm);\n var rot_comm = convert_opt(x.rot_comm);\n\n x.free();\n return [\n 0,\n sigma_comm,\n coefficients_comm,\n generic_comm,\n psm_comm,\n complete_add_comm,\n mul_comm,\n emul_comm,\n endomul_scalar_comm,\n xor_comm,\n range_check0_comm,\n range_check1_comm,\n foreign_field_add_comm,\n foreign_field_mul_comm,\n rot_comm,\n ];\n};\n\n// Provides: caml_plonk_verification_evals_to_rust\n// Requires: caml_poly_comm_to_rust_poly_comm, js_class_vector_to_rust_vector\nvar caml_plonk_verification_evals_to_rust = function (\n x,\n klass,\n poly_comm_to_rust\n) {\n var convert_opt = function (poly_comm_opt) {\n // Borrowing from caml_option_to_maybe_undefined\n if (poly_comm_opt === 0) {\n return undefined;\n }\n return poly_comm_to_rust(poly_comm_opt[1]);\n };\n\n var convertArray = function (comms) {\n var n = comms.length;\n var res = new Array(n - 1);\n for (var i = 1; i < n; i++) {\n res[i - 1] = poly_comm_to_rust(comms[i]);\n }\n return js_class_vector_to_rust_vector(res);\n };\n\n var sigma_comm = convertArray(x[1]);\n var coefficients_comm = convertArray(x[2]);\n var generic_comm = poly_comm_to_rust(x[3]);\n var psm_comm = poly_comm_to_rust(x[4]);\n var complete_add_comm = poly_comm_to_rust(x[5]);\n var mul_comm = poly_comm_to_rust(x[6]);\n var emul_comm = poly_comm_to_rust(x[7]);\n var endomul_scalar_comm = poly_comm_to_rust(x[8]);\n\n var xor_comm = convert_opt(x[9]);\n var range_check0_comm = convert_opt(x[10]);\n var range_check1_comm = convert_opt(x[11]);\n var foreign_field_add_comm = convert_opt(x[12]);\n var foreign_field_mul_comm = convert_opt(x[13]);\n var rot_comm = convert_opt(x[14]);\n\n return new klass(\n sigma_comm,\n coefficients_comm,\n generic_comm,\n psm_comm,\n complete_add_comm,\n mul_comm,\n emul_comm,\n endomul_scalar_comm,\n xor_comm,\n range_check0_comm,\n range_check1_comm,\n foreign_field_add_comm,\n foreign_field_mul_comm,\n rot_comm\n );\n};\n\n// Provides: caml_plonk_verification_shifts_of_rust\nvar caml_plonk_verification_shifts_of_rust = function (x) {\n var res = [0, x.s0, x.s1, x.s2, x.s3, x.s4, x.s5, x.s6];\n x.free();\n return res;\n};\n\n// Provides: caml_plonk_verification_shifts_to_rust\nvar caml_plonk_verification_shifts_to_rust = function (x, klass) {\n return new klass(x[1], x[2], x[3], x[4], x[5], x[6], x[7]);\n};\n\n// Provides: column_of_rust\nfunction column_of_rust(col) {\n // type nonrec column = Witness of int | Z | LookupSorted of int | LookupAggreg | LookupTable | LookupKindIndex of int | Index of gate_type | Coefficient of int\n var tag = col.tag;\n var gate_type = col.gate_type;\n var i = col.i;\n col.free();\n return (\n {\n 0: [tag, i],\n 2: [tag, i],\n 5: [tag, i],\n 6: [tag, gate_type],\n 7: [tag, i],\n }[tag] || tag\n );\n}\n\n// Provides: variable_of_rust\n// Requires: column_of_rust\nfunction variable_of_rust(variable) {\n // col * row\n var col = variable.col;\n var row = variable.row; // 0, 1\n variable.free();\n return [0, column_of_rust(col), row];\n}\n\n// Provides: polish_token_of_rust\n// Requires: variable_of_rust\nfunction polish_token_of_rust(token) {\n var tag = token.tag;\n var i0 = token.i0;\n var i1 = token.i1;\n var f = token.f;\n var v = variable_of_rust(token.v);\n token.free();\n return (\n {\n 5: [5, i0, i1],\n 6: [6, f],\n 7: [7, v],\n 9: [9, i0],\n 14: [14, i0],\n 16: [16, i0],\n }[tag] || tag\n );\n}\n\n// Provides: index_term_of_rust\n// Requires: column_of_rust, js_class_vector_of_rust_vector, polish_token_of_rust\nfunction index_term_of_rust(term, token_class) {\n // pub column: WasmColumn,\n // pub coefficient: WasmVector,\n var column = column_of_rust(term.column);\n var coefficient = js_class_vector_of_rust_vector(\n term.coefficient,\n token_class\n );\n coefficient = coefficient.map(polish_token_of_rust);\n coefficient = [0].concat(coefficient);\n term.free();\n return [0, column, coefficient];\n}\n\n// Provides: wrap\nfunction wrap(ptr, klass) {\n var obj = Object.create(klass.prototype);\n obj.__wbg_ptr= ptr;\n return obj;\n}\n\n// Provides: linearization_of_rust\n// Requires: plonk_wasm, js_class_vector_of_rust_vector, polish_token_of_rust, wrap, index_term_of_rust\nfunction linearization_of_rust(linearization, affine_class) {\n var F = affine_class === plonk_wasm.WasmGVesta ? 'Fq' : 'Fp';\n var WasmPolishToken = plonk_wasm['Wasm' + F + 'PolishToken'];\n var WasmIndexTerm = plonk_wasm['Wasm' + F + 'IndexTerm'];\n\n var constant_term = js_class_vector_of_rust_vector(\n linearization.constant_term,\n WasmPolishToken\n );\n constant_term = constant_term.map(polish_token_of_rust);\n constant_term = [0].concat(constant_term);\n\n var index_terms = Array.from(linearization.index_terms).map(function (ptr) {\n var wasmIndexTerm = wrap(ptr, WasmIndexTerm);\n return index_term_of_rust(wasmIndexTerm, WasmPolishToken);\n });\n index_terms = [0].concat(index_terms);\n\n linearization.free();\n return [0, constant_term, index_terms];\n}\n\n// Provides: None\nvar None = 0;\n\n// Provides: caml_is_none\n// Requires: None\nvar caml_is_none = function (v) {\n return v === None;\n};\n\n// Provides: caml_map_of_rust_vector\n// Requires: js_class_vector_of_rust_vector\nvar caml_map_of_rust_vector = function (v, klass, converter_to_rust) {\n var a = js_class_vector_of_rust_vector(v, klass);\n var res = [0];\n for (var i = 0; i < a.length; ++i) {\n res.push(converter_to_rust(a[i]));\n }\n return res;\n};\n\n// Provides: caml_opt_of_rust\n// Requires: None\nvar caml_opt_of_rust = function (value, value_of_rust) {\n if (value === undefined) {\n return None;\n } else {\n return [0, value_of_rust(value)];\n }\n};\n\n// Provides: caml_bool_of_rust\nvar caml_bool_of_rust = function (bool) {\n return bool;\n};\n\n// Provides: caml_lookup_patterns_of_rust\n// Requires: plonk_wasm, caml_bool_of_rust\nvar caml_lookup_patterns_of_rust = function (wasm_lookup_patterns) {\n return [\n 0,\n caml_bool_of_rust(wasm_lookup_patterns.xor),\n caml_bool_of_rust(wasm_lookup_patterns.lookup),\n caml_bool_of_rust(wasm_lookup_patterns.range_check),\n caml_bool_of_rust(wasm_lookup_patterns.foreign_field_mul),\n ];\n};\n\n// Provides: caml_lookup_features_of_rust\n// Requires: plonk_wasm, caml_lookup_patterns_of_rust, caml_bool_of_rust\nvar caml_lookup_features_of_rust = function (wasm_lookup_features) {\n var caml_lookup_patterns = caml_lookup_patterns_of_rust(\n wasm_lookup_features.patterns\n );\n var caml_joint_lookup_used = caml_bool_of_rust(\n wasm_lookup_features.joint_lookup_used\n );\n var caml_uses_runtime_tables = caml_bool_of_rust(\n wasm_lookup_features.uses_runtime_tables\n );\n\n return [\n 0,\n caml_lookup_patterns,\n caml_joint_lookup_used,\n caml_uses_runtime_tables,\n ];\n};\n\n// Provides: caml_lookup_info_of_rust\n// Requires: plonk_wasm, caml_lookup_features_of_rust\nvar caml_lookup_info_of_rust = function (wasm_lookup_info) {\n var caml_max_per_row = wasm_lookup_info.max_per_row;\n var caml_max_joint_size = wasm_lookup_info.max_joint_size;\n var caml_lookup_features = caml_lookup_features_of_rust(\n wasm_lookup_info.features\n );\n\n return [0, caml_max_per_row, caml_max_joint_size, caml_lookup_features];\n};\n\n// Provides: caml_lookup_selectors_of_rust\n// Requires: plonk_wasm, caml_opt_of_rust\nvar caml_lookup_selectors_of_rust = function (\n wasm_lookup_selectors,\n poly_comm_of_rust\n) {\n var xor = caml_opt_of_rust(wasm_lookup_selectors.xor, poly_comm_of_rust);\n var lookup = caml_opt_of_rust(\n wasm_lookup_selectors.lookup,\n poly_comm_of_rust\n );\n var range_check = caml_opt_of_rust(\n wasm_lookup_selectors.range_check,\n poly_comm_of_rust\n );\n var ffmul = caml_opt_of_rust(wasm_lookup_selectors.ffmul, poly_comm_of_rust);\n\n return [0, xor, lookup, range_check, ffmul];\n};\n\n// Provides: caml_lookup_verifier_index_of_rust\n// Requires: plonk_wasm, caml_map_of_rust_vector, caml_bool_of_rust, caml_lookup_selectors_of_rust, caml_opt_of_rust, caml_lookup_info_of_rust\nvar caml_lookup_verifier_index_of_rust = function (\n wasm_lookup_index,\n poly_comm_class,\n poly_comm_of_rust\n) {\n var caml_joint_lookup_used = caml_bool_of_rust(\n wasm_lookup_index.join_lookup_used\n );\n\n // lookup table\n var caml_lookup_table = caml_map_of_rust_vector(\n wasm_lookup_index.lookup_table,\n poly_comm_class,\n poly_comm_of_rust\n );\n\n var caml_lookup_selectors = caml_lookup_selectors_of_rust(\n wasm_lookup_index.lookup_selectors,\n poly_comm_of_rust\n );\n\n var caml_table_ids = caml_opt_of_rust(\n wasm_lookup_index.table_ids,\n poly_comm_of_rust\n );\n\n var caml_lookup_info = caml_lookup_info_of_rust(\n wasm_lookup_index.lookup_info\n );\n\n var caml_runtime_tables_selector = caml_opt_of_rust(\n wasm_lookup_index.runtime_tables_selector,\n poly_comm_of_rust\n );\n\n return [\n 0,\n caml_joint_lookup_used,\n caml_lookup_table,\n caml_lookup_selectors,\n caml_table_ids,\n caml_lookup_info,\n caml_runtime_tables_selector,\n ];\n};\n\n// Provides: caml_plonk_verifier_index_of_rust\n// Requires: linearization_of_rust, caml_plonk_domain_of_rust, caml_plonk_verification_evals_of_rust, caml_plonk_verification_shifts_of_rust, free_on_finalize, None, caml_opt_of_rust, caml_lookup_verifier_index_of_rust\nvar caml_plonk_verifier_index_of_rust = function (x, affine_class) {\n var domain = caml_plonk_domain_of_rust(x.domain);\n var max_poly_size = x.max_poly_size;\n var public_ = x.public_;\n var prev_challenges = x.prev_challenges;\n var srs = free_on_finalize(x.srs);\n var evals = caml_plonk_verification_evals_of_rust(x.evals, affine_class);\n var shifts = caml_plonk_verification_shifts_of_rust(x.shifts);\n // TODO: Handle linearization correctly!\n // var linearization = linearization_of_rust(x.linearization, affine_class);\n\n var caml_lookup_index = caml_opt_of_rust(\n x.lookup_index,\n caml_lookup_verifier_index_of_rust\n );\n\n x.free();\n return [\n 0,\n domain,\n max_poly_size,\n public_,\n prev_challenges,\n srs,\n evals,\n shifts,\n caml_lookup_index,\n ];\n};\n\n// Provides: caml_opt_to_rust\n// Requires: caml_is_none, None\nvar caml_opt_to_rust = function (caml_optional_value, to_rust) {\n // to_rust expects the parameters of the variant. A `Some vx` is represented\n // as [0, vx]\n if (caml_is_none(caml_optional_value)) {\n return undefined;\n } else {\n return to_rust(caml_optional_value[1]);\n }\n};\n\n// Provides: caml_lookup_selectors_to_rust\n// Requires: plonk_wasm, caml_opt_to_rust\nvar caml_lookup_selectors_to_rust = function (\n wasm_lookup_selectors,\n klass,\n poly_comm_to_rust\n) {\n var xor = caml_opt_to_rust(wasm_lookup_selectors[1], poly_comm_to_rust);\n var lookup = caml_opt_to_rust(wasm_lookup_selectors[2], poly_comm_to_rust);\n var range_check = caml_opt_to_rust(\n wasm_lookup_selectors[3],\n poly_comm_to_rust\n );\n var ffmul = caml_opt_to_rust(wasm_lookup_selectors[4], poly_comm_to_rust);\n\n return new klass(xor, lookup, range_check, ffmul);\n};\n\n// Provides: caml_lookup_table_to_rust\n// Requires: plonk_wasm, caml_array_to_rust_vector, rust_affine_of_caml_affine\nvar caml_lookup_table_to_rust = function (wasm_lookup_table, mk_affine) {\n return caml_array_to_rust_vector(\n wasm_lookup_table,\n rust_affine_of_caml_affine,\n mk_affine\n );\n};\n\n// Provides: caml_lookup_patterns_to_rust\n// Requires: plonk_wasm\nvar caml_lookup_patterns_to_rust = function (wasm_lookup_patterns, klass) {\n var xor = wasm_lookup_patterns[1];\n var lookup = wasm_lookup_patterns[2];\n var range_check = wasm_lookup_patterns[3];\n var foreign_field_mul = wasm_lookup_patterns[4];\n\n return new plonk_wasm.LookupPatterns(\n xor,\n lookup,\n range_check,\n foreign_field_mul\n );\n};\n\n// Provides: caml_lookup_features_to_rust\n// Requires: plonk_wasm, caml_lookup_patterns_to_rust\nvar caml_lookup_features_to_rust = function (wasm_lookup_features) {\n var patterns = caml_lookup_patterns_to_rust(wasm_lookup_features[1]);\n var joint_lookup_used = wasm_lookup_features[2];\n var uses_runtime_tables = wasm_lookup_features[3];\n\n return new plonk_wasm.LookupFeatures(\n patterns,\n joint_lookup_used,\n uses_runtime_tables\n );\n};\n\n// Provides: caml_lookup_info_to_rust\n// Requires: plonk_wasm, caml_lookup_features_to_rust\nvar caml_lookup_info_to_rust = function (wasm_lookup_info) {\n var max_per_row = wasm_lookup_info[1];\n var max_poly_size = wasm_lookup_info[2];\n var features = caml_lookup_features_to_rust(wasm_lookup_info[3]);\n\n return new plonk_wasm.LookupInfo(max_per_row, max_poly_size, features);\n};\n\n// Provides: caml_plonk_lookup_verifier_index_to_rust\n// Requires: plonk_wasm, caml_lookup_table_to_rust, caml_lookup_selectors_to_rust, caml_lookup_info_to_rust, caml_opt_to_rust\nvar caml_plonk_lookup_verifier_index_to_rust = function (\n caml_lookup_verifier_index,\n klass,\n poly_comm_to_rust,\n lookup_selectors_class,\n mk_affine\n) {\n // joint_lookup_used\n var joint_lookup_used = caml_lookup_verifier_index[1];\n\n // lookup_table\n var lookup_table = caml_lookup_table_to_rust(\n caml_lookup_verifier_index[2],\n mk_affine\n );\n\n // lookup_selectors\n var lookup_selectors = caml_lookup_selectors_to_rust(\n caml_lookup_verifier_index[3],\n lookup_selectors_class,\n poly_comm_to_rust\n );\n\n // table_ids\n var table_ids = caml_opt_to_rust(\n caml_lookup_verifier_index[4],\n poly_comm_to_rust\n );\n\n // lookup_info\n var lookup_info = caml_lookup_info_to_rust(caml_lookup_verifier_index[5]);\n\n // runtime_tables_selector\n var runtime_tables_selector = caml_opt_to_rust(\n caml_lookup_verifier_index[6],\n poly_comm_to_rust\n );\n\n return new klass(\n joint_lookup_used,\n lookup_table,\n lookup_selectors,\n table_ids,\n lookup_info,\n runtime_tables_selector\n );\n};\n\n// Provides: caml_plonk_verifier_index_to_rust\n// Requires: caml_plonk_domain_to_rust, caml_plonk_verification_evals_to_rust, caml_plonk_verification_shifts_to_rust, free_finalization_registry, caml_plonk_lookup_verifier_index_to_rust, caml_opt_to_rust, caml_poly_comm_to_rust_poly_comm\nvar caml_plonk_verifier_index_to_rust = function (\n x,\n klass,\n domain_class,\n verification_evals_class,\n poly_comm_class,\n mk_affine,\n verification_shifts_class,\n lookup_verifier_index_class,\n lookup_selectors_class\n) {\n // Defining how to translate polynomial commitments from OCaml back to Rust\n var poly_comm_to_rust = function (poly_comm) {\n return caml_poly_comm_to_rust_poly_comm(\n poly_comm,\n poly_comm_class,\n mk_affine\n );\n };\n\n var domain = caml_plonk_domain_to_rust(x[1], domain_class);\n var max_poly_size = x[2];\n var public_ = x[3];\n var prev_challenges = x[4];\n var srs = x[5];\n\n var evals = caml_plonk_verification_evals_to_rust(\n x[6],\n verification_evals_class,\n poly_comm_to_rust\n );\n\n var shifts = caml_plonk_verification_shifts_to_rust(\n x[7],\n verification_shifts_class\n );\n\n //////////////////////////////////////////////////////////////////////////////\n // The lookup_index_to_rust function is defined only in order to be able to //\n // use the generic caml_opt_to_rust function. //\n // //\n // We could as well inline it but I preferred not having to think about //\n // internal representation of values yet again. //\n //////////////////////////////////////////////////////////////////////////////\n var lookup_index_to_rust = function (lidx) {\n return caml_plonk_lookup_verifier_index_to_rust(\n lidx,\n lookup_verifier_index_class,\n poly_comm_to_rust,\n lookup_selectors_class,\n mk_affine\n );\n };\n\n var wasm_lookup_index = caml_opt_to_rust(x[8], lookup_index_to_rust);\n\n return new klass(\n domain,\n max_poly_size,\n public_,\n prev_challenges,\n srs,\n evals,\n shifts,\n wasm_lookup_index\n );\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_of_rust\n// Requires: plonk_wasm, caml_plonk_verifier_index_of_rust\nvar caml_pasta_fp_plonk_verifier_index_of_rust = function (x) {\n return caml_plonk_verifier_index_of_rust(x, plonk_wasm.WasmGVesta);\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_to_rust\n// Requires: plonk_wasm, caml_plonk_verifier_index_to_rust\nvar caml_pasta_fp_plonk_verifier_index_to_rust = function (x) {\n return caml_plonk_verifier_index_to_rust(\n x,\n plonk_wasm.WasmFpPlonkVerifierIndex,\n plonk_wasm.WasmFpDomain,\n plonk_wasm.WasmFpPlonkVerificationEvals,\n plonk_wasm.WasmFpPolyComm,\n plonk_wasm.caml_vesta_affine_one,\n plonk_wasm.WasmFpShifts,\n plonk_wasm.WasmFpLookupVerifierIndex,\n plonk_wasm.WasmFpLookupSelectors\n );\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_create\n// Requires: plonk_wasm, caml_pasta_fp_plonk_verifier_index_of_rust\nvar caml_pasta_fp_plonk_verifier_index_create = function (x) {\n var vk = plonk_wasm.caml_pasta_fp_plonk_verifier_index_create(x);\n var vk_caml = caml_pasta_fp_plonk_verifier_index_of_rust(vk);\n return vk_caml;\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_read\n// Requires: plonk_wasm, caml_jsstring_of_string, caml_pasta_fp_plonk_verifier_index_of_rust\nvar caml_pasta_fp_plonk_verifier_index_read = function (offset, urs, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n return caml_pasta_fp_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_verifier_index_read(\n offset,\n urs,\n caml_jsstring_of_string(path)\n )\n );\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_write\n// Requires: plonk_wasm, caml_jsstring_of_string, caml_pasta_fp_plonk_verifier_index_to_rust\nvar caml_pasta_fp_plonk_verifier_index_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_pasta_fp_plonk_verifier_index_write(\n append,\n caml_pasta_fp_plonk_verifier_index_to_rust(t),\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_shifts\n// Requires: plonk_wasm, caml_plonk_verification_shifts_of_rust\nvar caml_pasta_fp_plonk_verifier_index_shifts = function (log2_size) {\n return caml_plonk_verification_shifts_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_verifier_index_shifts(log2_size)\n );\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_dummy\n// Requires: plonk_wasm, caml_pasta_fp_plonk_verifier_index_of_rust\nvar caml_pasta_fp_plonk_verifier_index_dummy = function () {\n var res = plonk_wasm.caml_pasta_fp_plonk_verifier_index_dummy();\n return caml_pasta_fp_plonk_verifier_index_of_rust(res);\n // return caml_pasta_fp_plonk_verifier_index_of_rust(plonk_wasm.caml_pasta_fp_plonk_verifier_index_dummy());\n};\n\n// Provides: caml_pasta_fp_plonk_verifier_index_deep_copy\n// Requires: plonk_wasm, caml_pasta_fp_plonk_verifier_index_of_rust, caml_pasta_fp_plonk_verifier_index_to_rust\nvar caml_pasta_fp_plonk_verifier_index_deep_copy = function (x) {\n return caml_pasta_fp_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_verifier_index_deep_copy(\n caml_pasta_fp_plonk_verifier_index_to_rust(x)\n )\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_of_rust\n// Requires: plonk_wasm, caml_plonk_verifier_index_of_rust\nvar caml_pasta_fq_plonk_verifier_index_of_rust = function (x) {\n return caml_plonk_verifier_index_of_rust(x, plonk_wasm.WasmGPallas);\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_to_rust\n// Requires: plonk_wasm, caml_plonk_verifier_index_to_rust\nvar caml_pasta_fq_plonk_verifier_index_to_rust = function (x) {\n return caml_plonk_verifier_index_to_rust(\n x,\n plonk_wasm.WasmFqPlonkVerifierIndex,\n plonk_wasm.WasmFqDomain,\n plonk_wasm.WasmFqPlonkVerificationEvals,\n plonk_wasm.WasmFqPolyComm,\n plonk_wasm.caml_pallas_affine_one,\n plonk_wasm.WasmFqShifts,\n plonk_wasm.WasmFqLookupVerifierIndex,\n plonk_wasm.WasmFqLookupSelectors\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_create\n// Requires: plonk_wasm, caml_pasta_fq_plonk_verifier_index_of_rust\nvar caml_pasta_fq_plonk_verifier_index_create = function (x) {\n return caml_pasta_fq_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_verifier_index_create(x)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_read\n// Requires: plonk_wasm, caml_jsstring_of_string, caml_pasta_fq_plonk_verifier_index_of_rust\nvar caml_pasta_fq_plonk_verifier_index_read = function (offset, urs, path) {\n if (offset === 0) {\n offset = undefined;\n } else {\n offset = offset[1];\n }\n return caml_pasta_fq_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_verifier_index_read(\n offset,\n urs,\n caml_jsstring_of_string(path)\n )\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_write\n// Requires: plonk_wasm, caml_jsstring_of_string, caml_pasta_fq_plonk_verifier_index_to_rust\nvar caml_pasta_fq_plonk_verifier_index_write = function (append, t, path) {\n if (append === 0) {\n append = undefined;\n } else {\n append = append[1];\n }\n return plonk_wasm.caml_pasta_fq_plonk_verifier_index_write(\n append,\n caml_pasta_fq_plonk_verifier_index_to_rust(t),\n caml_jsstring_of_string(path)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_shifts\n// Requires: plonk_wasm, caml_plonk_verification_shifts_of_rust\nvar caml_pasta_fq_plonk_verifier_index_shifts = function (log2_size) {\n return caml_plonk_verification_shifts_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_verifier_index_shifts(log2_size)\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_dummy\n// Requires: plonk_wasm, caml_pasta_fq_plonk_verifier_index_of_rust\nvar caml_pasta_fq_plonk_verifier_index_dummy = function () {\n return caml_pasta_fq_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_verifier_index_dummy()\n );\n};\n\n// Provides: caml_pasta_fq_plonk_verifier_index_deep_copy\n// Requires: plonk_wasm, caml_pasta_fq_plonk_verifier_index_of_rust, caml_pasta_fq_plonk_verifier_index_to_rust\nvar caml_pasta_fq_plonk_verifier_index_deep_copy = function (x) {\n return caml_pasta_fq_plonk_verifier_index_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_verifier_index_deep_copy(\n caml_pasta_fq_plonk_verifier_index_to_rust(x)\n )\n );\n};\n\n// Provides: COLUMNS\nvar COLUMNS = 15;\n// Provides: PERMUTS_MINUS_1\nvar PERMUTS_MINUS_1 = 6;\n\n// Provides: caml_pasta_fp_proof_evaluations_to_rust\n// Requires: plonk_wasm, caml_fp_vector_to_rust, PERMUTS_MINUS_1, COLUMNS\nvar caml_pasta_fp_proof_evaluations_to_rust = function (x) {\n return x;\n};\n\n// Provides: caml_pasta_fp_proof_evaluations_of_rust\n// Requires: plonk_wasm, caml_fp_vector_of_rust, COLUMNS, PERMUTS_MINUS_1\nvar caml_pasta_fp_proof_evaluations_of_rust = function (x) {\n return x;\n};\n\n// Provides: caml_pasta_fp_opening_proof_to_rust\n// Requires: plonk_wasm, caml_array_to_rust_vector, rust_affine_of_caml_affine\nvar caml_pasta_fp_opening_proof_to_rust = function (x) {\n var convert_affines = function (affines) {\n return caml_array_to_rust_vector(\n affines,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_vesta_affine_one\n );\n };\n var lr = x[1];\n var delta = rust_affine_of_caml_affine(\n x[2],\n plonk_wasm.caml_vesta_affine_one\n );\n var z1 = x[3];\n var z2 = x[4];\n var sg = rust_affine_of_caml_affine(x[5], plonk_wasm.caml_vesta_affine_one);\n var len = lr.length;\n // We pass l and r as separate vectors over the FFI\n var l_ocaml = new Array(len);\n var r_ocaml = new Array(len);\n for (var i = 1; i < len; i++) {\n l_ocaml[i] = lr[i][1];\n r_ocaml[i] = lr[i][2];\n }\n var l = convert_affines(l_ocaml);\n var r = convert_affines(r_ocaml);\n return new plonk_wasm.WasmFpOpeningProof(l, r, delta, z1, z2, sg);\n};\n\n// Provides: caml_pasta_fp_opening_proof_of_rust\n// Requires: plonk_wasm, caml_array_of_rust_vector, rust_affine_to_caml_affine\nvar caml_pasta_fp_opening_proof_of_rust = function (x) {\n var convert_affines = function (affines) {\n return caml_array_of_rust_vector(\n affines,\n plonk_wasm.WasmGVesta,\n rust_affine_to_caml_affine,\n false\n );\n };\n var l = convert_affines(x.lr_0);\n var r = convert_affines(x.lr_1);\n var delta = rust_affine_to_caml_affine(x.delta);\n var z1 = x.z1;\n var z2 = x.z2;\n var sg = rust_affine_to_caml_affine(x.sg);\n x.free();\n var len = l.length;\n if (len !== r.length) {\n throw new Error(\"l and r lengths don't match\");\n }\n var lr = new Array(len);\n lr[0] = 0;\n for (var i = 1; i < len; i++) {\n var tuple = new Array(3);\n tuple[0] = 0;\n tuple[1] = l[i];\n tuple[2] = r[i];\n lr[i] = tuple;\n }\n return [0, lr, delta, z1, z2, sg];\n};\n\n// Provides: caml_fp_lookup_commitments_to_rust\n// Requires: plonk_wasm, caml_vesta_poly_comm_to_rust, js_class_vector_to_rust_vector\nvar caml_fp_lookup_commitments_to_rust = function (caml_lc) {\n var convertArray = function (v) {\n var n = v.length - 1;\n var res = new Array(n);\n for (var i = 0; i < n; ++i) {\n res[i] = caml_vesta_poly_comm_to_rust(v[i + 1]);\n }\n return js_class_vector_to_rust_vector(res);\n };\n\n var wasm_sorted = convertArray(caml_lc[1]);\n var wasm_aggreg = caml_vesta_poly_comm_to_rust(caml_lc[2]);\n var wasm_runtime;\n if (caml_lc[3] === 0) {\n wasm_runtime = undefined;\n } else {\n wasm_runtime = caml_vesta_poly_comm_to_rust(caml_lc[3][1]);\n }\n return plonk_wasm.WasmFpLookupCommitments(\n wasm_sorted,\n wasm_aggreg,\n wasm_runtime\n );\n};\n\n// Provides: caml_pasta_fp_commitments_to_rust\n// Requires: plonk_wasm, caml_vesta_poly_comm_to_rust, js_class_vector_to_rust_vector, caml_fp_lookup_commitments_to_rust, caml_opt_to_rust\nvar caml_pasta_fp_commitments_to_rust = function (x) {\n var convertArray = function (v) {\n var n = v.length - 1;\n var res = new Array(n);\n for (var i = 0; i < n; ++i) {\n res[i] = caml_vesta_poly_comm_to_rust(v[i + 1]);\n }\n // TODO need to do finalizer things?\n return js_class_vector_to_rust_vector(res);\n };\n\n var w_comm = convertArray(x[1]);\n var z_comm = caml_vesta_poly_comm_to_rust(x[2]);\n var t_comm = caml_vesta_poly_comm_to_rust(x[3]);\n var lookup = caml_opt_to_rust(x[4], caml_fp_lookup_commitments_to_rust);\n return new plonk_wasm.WasmFpProverCommitments(w_comm, z_comm, t_comm, lookup);\n};\n\n// Provides: caml_fp_lookup_commitments_of_rust\n// Requires: caml_vesta_poly_comm_of_rust, js_class_vector_of_rust_vector, plonk_wasm\nvar caml_fp_lookup_commitments_of_rust = function (wasm_lc) {\n var convertArray = function (v) {\n var a = js_class_vector_of_rust_vector(v, plonk_wasm.WasmFpPolyComm);\n var res = [0];\n for (var i = 0; i < a.length; ++i) {\n res.push(caml_vesta_poly_comm_of_rust(a[i]));\n }\n return res;\n };\n\n var sorted = convertArray(wasm_lc.sorted);\n var aggreg = caml_vesta_poly_comm_of_rust(wasm_lc.aggreg);\n var wasm_lc_runtime = wasm_lc.runtime;\n var caml_runtime;\n if (wasm_lc_runtime === undefined) {\n caml_runtime = 0;\n } else {\n caml_runtime = [0, caml_vesta_poly_comm_of_rust(wasm_lc_runtime)];\n }\n wasm_lc.free();\n return [0, sorted, aggreg, caml_runtime];\n};\n\n// Provides: caml_pasta_fp_commitments_of_rust\n// Requires: caml_vesta_poly_comm_of_rust, js_class_vector_of_rust_vector, plonk_wasm, caml_fp_lookup_commitments_of_rust, caml_opt_of_rust\nvar caml_pasta_fp_commitments_of_rust = function (x) {\n var convertArray = function (v) {\n var a = js_class_vector_of_rust_vector(v, plonk_wasm.WasmFpPolyComm);\n var res = [0];\n for (var i = 0; i < a.length; ++i) {\n // TODO Check this. Could be off by 1\n res.push(caml_vesta_poly_comm_of_rust(a[i]));\n }\n return res;\n };\n\n var w_comm = convertArray(x.w_comm);\n var z_comm = caml_vesta_poly_comm_of_rust(x.z_comm);\n var t_comm = caml_vesta_poly_comm_of_rust(x.t_comm);\n var caml_lookup = caml_opt_of_rust(\n x.lookup,\n caml_fp_lookup_commitments_of_rust\n );\n x.free();\n return [0, w_comm, z_comm, t_comm, caml_lookup];\n};\n\n// Provides: caml_pasta_fp_proof_to_rust\n// Requires: plonk_wasm, caml_pasta_fp_commitments_to_rust, caml_pasta_fp_opening_proof_to_rust, caml_pasta_fp_proof_evaluations_to_rust, caml_fp_vector_to_rust, caml_vesta_poly_comm_to_rust, js_class_vector_to_rust_vector\nvar caml_pasta_fp_proof_to_rust = function (x) {\n var public_evals = x[1];\n x = x[2];\n var commitments = caml_pasta_fp_commitments_to_rust(x[1]);\n var proof = caml_pasta_fp_opening_proof_to_rust(x[2]);\n var evals = caml_pasta_fp_proof_evaluations_to_rust(x[3]);\n var evals_actual = new Array(evals.length + 1);\n evals_actual[0] = 0;\n evals_actual[1] = public_evals;\n for (var i = 2, l = evals_actual.length; i < l; i++) {\n evals_actual[i] = evals[i - 1];\n }\n var ft_eval1 = x[4];\n var public_ = caml_fp_vector_to_rust(x[5]);\n var prev_challenges = x[6];\n var chals_len = prev_challenges.length;\n var prev_challenges_scalars = new plonk_wasm.WasmVecVecFp(chals_len - 1);\n var prev_challenges_comms = new Array(chals_len - 1);\n for (var i = 1; i < chals_len; i++) {\n prev_challenges_scalars.push(caml_fp_vector_to_rust(prev_challenges[i][1]));\n prev_challenges_comms[i - 1] = caml_vesta_poly_comm_to_rust(\n prev_challenges[i][2]\n );\n }\n prev_challenges_comms = js_class_vector_to_rust_vector(prev_challenges_comms);\n return new plonk_wasm.WasmFpProverProof(\n commitments,\n proof,\n evals_actual,\n ft_eval1,\n public_,\n prev_challenges_scalars,\n prev_challenges_comms\n );\n};\n\n// Provides: caml_pasta_fp_proof_of_rust\n// Requires: plonk_wasm, caml_pasta_fp_commitments_of_rust, caml_pasta_fp_opening_proof_of_rust, caml_pasta_fp_proof_evaluations_of_rust, caml_fp_vector_of_rust, js_class_vector_of_rust_vector, caml_vesta_poly_comm_of_rust\nvar caml_pasta_fp_proof_of_rust = function (x) {\n var messages = caml_pasta_fp_commitments_of_rust(x.commitments);\n var proof = caml_pasta_fp_opening_proof_of_rust(x.proof);\n var evals = caml_pasta_fp_proof_evaluations_of_rust(x.evals);\n var public_evals = evals[1];\n var evals_actual = new Array(evals.length - 1);\n evals_actual[0] = 0;\n for (var i = 2, l = evals.length; i < l; i++) {\n evals_actual[i - 1] = evals[i];\n }\n var ft_eval1 = x.ft_eval1;\n var public_ = caml_fp_vector_of_rust(x.public_);\n var prev_challenges_scalars = x.prev_challenges_scalars;\n var prev_challenges_comms = js_class_vector_of_rust_vector(\n x.prev_challenges_comms,\n plonk_wasm.WasmFpPolyComm\n );\n var chals_len = prev_challenges_comms.length;\n var prev_challenges = new Array(chals_len);\n prev_challenges[0] = 0;\n for (var i = 1; i < chals_len; i++) {\n var res = new Array(3);\n res[0] = 0;\n res[1] = caml_fp_vector_of_rust(prev_challenges_scalars.get(i - 1));\n // TODO Check this. Could be off by 1\n res[2] = caml_vesta_poly_comm_of_rust(prev_challenges_comms[i]);\n prev_challenges[i] = res;\n }\n return [\n 0,\n public_evals,\n [0, messages, proof, evals_actual, ft_eval1, public_, prev_challenges],\n ];\n};\n\n// Provides: caml_fp_runtime_table_to_rust\n// Requires: plonk_wasm, caml_fp_vector_to_rust\nvar caml_fp_runtime_table_to_rust = function (caml_runtime_table, mk_class) {\n // A value caml_runtime_table is a record on the OCaml side.\n // id field: int32\n var caml_runtime_table_id = caml_runtime_table[1];\n // data field: Caml array of fq elements\n var caml_runtime_table_data = caml_runtime_table[2];\n var res = new mk_class(\n caml_runtime_table_id,\n caml_fp_vector_to_rust(caml_runtime_table_data)\n );\n return res;\n};\n\n// Provides: caml_pasta_fp_plonk_proof_create\n// Requires: plonk_wasm, caml_fp_vector_to_rust, caml_array_to_rust_vector, rust_affine_of_caml_affine, caml_pasta_fp_proof_of_rust, caml_fp_runtime_table_to_rust\nvar caml_pasta_fp_plonk_proof_create = function (\n index,\n witness_cols,\n caml_runtime_tables,\n prev_challenges,\n prev_sgs\n) {\n var w = new plonk_wasm.WasmVecVecFp(witness_cols.length - 1);\n for (var i = 1; i < witness_cols.length; i++) {\n w.push(caml_fp_vector_to_rust(witness_cols[i]));\n }\n witness_cols = w;\n prev_challenges = caml_fp_vector_to_rust(prev_challenges);\n var wasm_runtime_tables = caml_array_to_rust_vector(\n caml_runtime_tables,\n caml_fp_runtime_table_to_rust,\n plonk_wasm.WasmFpRuntimeTable\n );\n prev_sgs = caml_array_to_rust_vector(\n prev_sgs,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_vesta_affine_one\n );\n var res = plonk_wasm.caml_pasta_fp_plonk_proof_create(\n index,\n witness_cols,\n wasm_runtime_tables,\n prev_challenges,\n prev_sgs\n );\n var proof = caml_pasta_fp_proof_of_rust(res);\n return proof;\n};\n\n// Provides: caml_pasta_fp_plonk_proof_verify\n// Requires: plonk_wasm, caml_array_to_rust_vector, caml_vesta_poly_comm_to_rust, caml_pasta_fp_plonk_verifier_index_to_rust, caml_pasta_fp_proof_to_rust\nvar caml_pasta_fp_plonk_proof_verify = function (index, proof) {\n index = caml_pasta_fp_plonk_verifier_index_to_rust(index);\n proof = caml_pasta_fp_proof_to_rust(proof);\n return plonk_wasm.caml_pasta_fp_plonk_proof_verify(index, proof);\n};\n\n// Provides: caml_pasta_fp_plonk_proof_batch_verify\n// Requires: plonk_wasm, caml_array_to_rust_vector, caml_vesta_poly_comm_to_rust, caml_pasta_fp_plonk_verifier_index_to_rust, caml_pasta_fp_proof_to_rust\nvar caml_pasta_fp_plonk_proof_batch_verify = function (indexes, proofs) {\n indexes = caml_array_to_rust_vector(\n indexes,\n caml_pasta_fp_plonk_verifier_index_to_rust\n );\n proofs = caml_array_to_rust_vector(proofs, caml_pasta_fp_proof_to_rust);\n return plonk_wasm.caml_pasta_fp_plonk_proof_batch_verify(indexes, proofs);\n};\n\n// Provides: caml_pasta_fp_plonk_proof_dummy\n// Requires: plonk_wasm, caml_pasta_fp_proof_of_rust\nvar caml_pasta_fp_plonk_proof_dummy = function () {\n return caml_pasta_fp_proof_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_proof_dummy()\n );\n};\n\n// Provides: caml_pasta_fp_plonk_proof_deep_copy\n// Requires: plonk_wasm, caml_pasta_fp_proof_to_rust, caml_pasta_fp_proof_of_rust\nvar caml_pasta_fp_plonk_proof_deep_copy = function (proof) {\n return caml_pasta_fp_proof_of_rust(\n plonk_wasm.caml_pasta_fp_plonk_proof_deep_copy(\n caml_pasta_fp_proof_to_rust(proof)\n )\n );\n};\n\n// Provides: caml_pasta_fq_proof_evaluations_to_rust\n// Requires: plonk_wasm, caml_fq_vector_to_rust, PERMUTS_MINUS_1, COLUMNS\nvar caml_pasta_fq_proof_evaluations_to_rust = function (x) {\n return x;\n};\n\n// Provides: caml_pasta_fq_proof_evaluations_of_rust\n// Requires: plonk_wasm, caml_fq_vector_of_rust, COLUMNS, PERMUTS_MINUS_1\nvar caml_pasta_fq_proof_evaluations_of_rust = function (x) {\n return x;\n};\n\n// Provides: caml_pasta_fq_opening_proof_to_rust\n// Requires: plonk_wasm, caml_array_to_rust_vector, rust_affine_of_caml_affine\nvar caml_pasta_fq_opening_proof_to_rust = function (x) {\n var convert_affines = function (affines) {\n return caml_array_to_rust_vector(\n affines,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_pallas_affine_one\n );\n };\n var lr = x[1];\n var delta = rust_affine_of_caml_affine(\n x[2],\n plonk_wasm.caml_pallas_affine_one\n );\n var z1 = x[3];\n var z2 = x[4];\n var sg = rust_affine_of_caml_affine(x[5], plonk_wasm.caml_pallas_affine_one);\n var len = lr.length;\n // We pass l and r as separate vectors over the FFI\n var l_ocaml = new Array(len);\n var r_ocaml = new Array(len);\n for (var i = 1; i < len; i++) {\n l_ocaml[i] = lr[i][1];\n r_ocaml[i] = lr[i][2];\n }\n var l = convert_affines(l_ocaml);\n var r = convert_affines(r_ocaml);\n return new plonk_wasm.WasmFqOpeningProof(l, r, delta, z1, z2, sg);\n};\n\n// Provides: caml_pasta_fq_opening_proof_of_rust\n// Requires: plonk_wasm, caml_array_of_rust_vector, rust_affine_to_caml_affine\nvar caml_pasta_fq_opening_proof_of_rust = function (x) {\n var convert_affines = function (affines) {\n return caml_array_of_rust_vector(\n affines,\n plonk_wasm.WasmGPallas,\n rust_affine_to_caml_affine,\n false\n );\n };\n var l = convert_affines(x.lr_0);\n var r = convert_affines(x.lr_1);\n var delta = rust_affine_to_caml_affine(x.delta);\n var z1 = x.z1;\n var z2 = x.z2;\n var sg = rust_affine_to_caml_affine(x.sg);\n x.free();\n var len = l.length;\n if (len !== r.length) {\n throw new Error(\"l and r lengths don't match\");\n }\n var lr = new Array(len);\n lr[0] = 0;\n for (var i = 1; i < len; i++) {\n var tuple = new Array(3);\n tuple[0] = 0;\n tuple[1] = l[i];\n tuple[2] = r[i];\n lr[i] = tuple;\n }\n return [0, lr, delta, z1, z2, sg];\n};\n\n// Provides: caml_fq_lookup_commitments_to_rust\n// Requires: plonk_wasm, caml_pallas_poly_comm_to_rust, js_class_vector_to_rust_vector, caml_opt_to_rust\nvar caml_fq_lookup_commitments_to_rust = function (caml_lc) {\n var convertArray = function (v) {\n var n = v.length - 1;\n var res = new Array(n);\n for (var i = 0; i < n; ++i) {\n res[i] = caml_pallas_poly_comm_to_rust(v[i + 1]);\n }\n return js_class_vector_to_rust_vector(res);\n };\n\n var wasm_sorted = convertArray(caml_lc[1]);\n var wasm_aggreg = caml_pallas_poly_comm_to_rust(caml_lc[2]);\n var wasm_runtime = caml_opt_to_rust(\n caml_lc[3],\n caml_pallas_poly_comm_to_rust\n );\n return plonk_wasm.WasmFqLookupCommitments(\n wasm_sorted,\n wasm_aggreg,\n wasm_runtime\n );\n};\n\n// Provides: caml_pasta_fq_commitments_to_rust\n// Requires: plonk_wasm, caml_pallas_poly_comm_to_rust, js_class_vector_to_rust_vector, caml_fq_lookup_commitments_to_rust, caml_opt_to_rust\nvar caml_pasta_fq_commitments_to_rust = function (x) {\n var convertArray = function (v) {\n var n = v.length - 1;\n var res = new Array(n);\n for (var i = 0; i < n; ++i) {\n res[i] = caml_pallas_poly_comm_to_rust(v[i + 1]);\n }\n return js_class_vector_to_rust_vector(res);\n };\n\n var w_comm = convertArray(x[1]);\n var z_comm = caml_pallas_poly_comm_to_rust(x[2]);\n var t_comm = caml_pallas_poly_comm_to_rust(x[3]);\n var lookup = caml_opt_to_rust(x[4], caml_fq_lookup_commitments_to_rust);\n return new plonk_wasm.WasmFqProverCommitments(w_comm, z_comm, t_comm, lookup);\n};\n\n// Provides: caml_fq_lookup_commitments_of_rust\n// Requires: caml_pallas_poly_comm_of_rust, js_class_vector_of_rust_vector, plonk_wasm\nvar caml_fq_lookup_commitments_of_rust = function (wasm_lc) {\n var convertArray = function (v) {\n var a = js_class_vector_of_rust_vector(v, plonk_wasm.WasmFqPolyComm);\n var res = [0];\n for (var i = 0; i < a.length; ++i) {\n res.push(caml_pallas_poly_comm_of_rust(a[i]));\n }\n return res;\n };\n\n var sorted = convertArray(wasm_lc.sorted);\n var aggreg = caml_pallas_poly_comm_of_rust(wasm_lc.aggreg);\n var wasm_lc_runtime = wasm_lc.runtime;\n var caml_runtime;\n if (wasm_lc_runtime === undefined) {\n caml_runtime = 0;\n } else {\n caml_runtime = [0, caml_pallas_poly_comm_of_rust(wasm_lc_runtime)];\n }\n wasm_lc.free();\n return [0, sorted, aggreg, caml_runtime];\n};\n\n// Provides: caml_pasta_fq_commitments_of_rust\n// Requires: caml_pallas_poly_comm_of_rust, js_class_vector_of_rust_vector, plonk_wasm, caml_fq_lookup_commitments_of_rust, caml_opt_of_rust\nvar caml_pasta_fq_commitments_of_rust = function (x) {\n var convertArray = function (v) {\n var a = js_class_vector_of_rust_vector(v, plonk_wasm.WasmFqPolyComm);\n var res = [0];\n for (var i = 0; i < a.length; ++i) {\n // TODO Check this. Could be off by 1\n res.push(caml_pallas_poly_comm_of_rust(a[i]));\n }\n return res;\n };\n\n var w_comm = convertArray(x.w_comm);\n var z_comm = caml_pallas_poly_comm_of_rust(x.z_comm);\n var t_comm = caml_pallas_poly_comm_of_rust(x.t_comm);\n var caml_lookup = caml_opt_of_rust(\n x.lookup,\n caml_fq_lookup_commitments_of_rust\n );\n x.free();\n return [0, w_comm, z_comm, t_comm, caml_lookup];\n};\n\n// Provides: caml_pasta_fq_proof_to_rust\n// Requires: plonk_wasm, caml_pasta_fq_commitments_to_rust, caml_pasta_fq_opening_proof_to_rust, caml_pasta_fq_proof_evaluations_to_rust, caml_fq_vector_to_rust, caml_pallas_poly_comm_to_rust, js_class_vector_to_rust_vector\nvar caml_pasta_fq_proof_to_rust = function (x) {\n var public_evals = x[1];\n x = x[2];\n var messages = caml_pasta_fq_commitments_to_rust(x[1]);\n var proof = caml_pasta_fq_opening_proof_to_rust(x[2]);\n var evals = caml_pasta_fq_proof_evaluations_to_rust(x[3]);\n var evals_actual = new Array(evals.length + 1);\n evals_actual[0] = 0;\n evals_actual[1] = public_evals;\n for (var i = 2, l = evals_actual.length; i < l; i++) {\n evals_actual[i] = evals[i - 1];\n }\n var ft_eval1 = x[4];\n var public_ = caml_fq_vector_to_rust(x[5]);\n var prev_challenges = x[6];\n var chals_len = prev_challenges.length;\n var prev_challenges_scalars = new plonk_wasm.WasmVecVecFq(chals_len - 1);\n var prev_challenges_comms = new Array(chals_len - 1);\n for (var i = 1; i < chals_len; i++) {\n prev_challenges_scalars.push(caml_fq_vector_to_rust(prev_challenges[i][1]));\n prev_challenges_comms[i - 1] = caml_pallas_poly_comm_to_rust(\n prev_challenges[i][2]\n );\n }\n prev_challenges_comms = js_class_vector_to_rust_vector(prev_challenges_comms);\n return new plonk_wasm.WasmFqProverProof(\n messages,\n proof,\n evals_actual,\n ft_eval1,\n public_,\n prev_challenges_scalars,\n prev_challenges_comms\n );\n};\n\n// Provides: caml_pasta_fq_proof_of_rust\n// Requires: plonk_wasm, caml_pasta_fq_commitments_of_rust, caml_pasta_fq_opening_proof_of_rust, caml_pasta_fq_proof_evaluations_of_rust, caml_fq_vector_of_rust, js_class_vector_of_rust_vector, caml_pallas_poly_comm_of_rust\nvar caml_pasta_fq_proof_of_rust = function (x) {\n var messages = caml_pasta_fq_commitments_of_rust(x.commitments);\n var proof = caml_pasta_fq_opening_proof_of_rust(x.proof);\n var evals = caml_pasta_fq_proof_evaluations_of_rust(x.evals);\n var public_evals = evals[1];\n var evals_actual = new Array(evals.length - 1);\n evals_actual[0] = 0;\n for (var i = 2, l = evals.length; i < l; i++) {\n evals_actual[i - 1] = evals[i];\n }\n var ft_eval1 = x.ft_eval1;\n var public_ = caml_fq_vector_of_rust(x.public_);\n var prev_challenges_scalars = x.prev_challenges_scalars;\n var prev_challenges_comms = js_class_vector_of_rust_vector(\n x.prev_challenges_comms,\n plonk_wasm.WasmFqPolyComm\n );\n var chals_len = prev_challenges_comms.length;\n var prev_challenges = new Array(chals_len);\n prev_challenges[0] = 0;\n for (var i = 1; i < chals_len; i++) {\n var res = new Array(3);\n res[0] = 0;\n res[1] = caml_fq_vector_of_rust(prev_challenges_scalars.get(i - 1));\n res[2] = caml_pallas_poly_comm_of_rust(prev_challenges_comms[i]);\n prev_challenges[i] = res;\n }\n return [\n 0,\n public_evals,\n [0, messages, proof, evals_actual, ft_eval1, public_, prev_challenges],\n ];\n};\n\n// Provides: caml_fq_runtime_table_to_rust\n// Requires: plonk_wasm, caml_fq_vector_to_rust\nvar caml_fq_runtime_table_to_rust = function (caml_runtime_table, mk_class) {\n // A value caml_runtime_table is a record on the OCaml side.\n // id field: int32\n var caml_runtime_table_id = caml_runtime_table[1];\n // data field: Caml array of fq elements\n var caml_runtime_table_data = caml_runtime_table[2];\n var res = new mk_class(\n caml_runtime_table_id,\n caml_fq_vector_to_rust(caml_runtime_table_data)\n );\n return res;\n};\n\n// Provides: caml_pasta_fq_plonk_proof_create\n// Requires: plonk_wasm, caml_fq_vector_to_rust, caml_array_to_rust_vector, rust_affine_of_caml_affine, caml_pasta_fq_proof_of_rust, caml_fq_runtime_table_to_rust\nvar caml_pasta_fq_plonk_proof_create = function (\n index,\n witness_cols,\n caml_runtime_tables,\n prev_challenges,\n prev_sgs\n) {\n var w = new plonk_wasm.WasmVecVecFq(witness_cols.length - 1);\n for (var i = 1; i < witness_cols.length; i++) {\n w.push(caml_fq_vector_to_rust(witness_cols[i]));\n }\n witness_cols = w;\n prev_challenges = caml_fq_vector_to_rust(prev_challenges);\n var wasm_runtime_tables = caml_array_to_rust_vector(\n caml_runtime_tables,\n caml_fq_runtime_table_to_rust,\n plonk_wasm.WasmFqRuntimeTable\n );\n prev_sgs = caml_array_to_rust_vector(\n prev_sgs,\n rust_affine_of_caml_affine,\n plonk_wasm.caml_pallas_affine_one\n );\n var res = plonk_wasm.caml_pasta_fq_plonk_proof_create(\n index,\n witness_cols,\n wasm_runtime_tables,\n prev_challenges,\n prev_sgs\n );\n var proof = caml_pasta_fq_proof_of_rust(res);\n return proof;\n};\n\n// Provides: caml_pasta_fq_plonk_proof_verify\n// Requires: plonk_wasm, caml_array_to_rust_vector, caml_pallas_poly_comm_to_rust, caml_pasta_fq_plonk_verifier_index_to_rust, caml_pasta_fq_proof_to_rust\nvar caml_pasta_fq_plonk_proof_verify = function (index, proof) {\n index = caml_pasta_fq_plonk_verifier_index_to_rust(index);\n proof = caml_pasta_fq_proof_to_rust(proof);\n return plonk_wasm.caml_pasta_fq_plonk_proof_verify(index, proof);\n};\n\n// Provides: caml_pasta_fq_plonk_proof_batch_verify\n// Requires: plonk_wasm, caml_array_to_rust_vector, caml_pallas_poly_comm_to_rust, caml_pasta_fq_plonk_verifier_index_to_rust, caml_pasta_fq_proof_to_rust\nvar caml_pasta_fq_plonk_proof_batch_verify = function (indexes, proofs) {\n indexes = caml_array_to_rust_vector(\n indexes,\n caml_pasta_fq_plonk_verifier_index_to_rust\n );\n proofs = caml_array_to_rust_vector(proofs, caml_pasta_fq_proof_to_rust);\n return plonk_wasm.caml_pasta_fq_plonk_proof_batch_verify(indexes, proofs);\n};\n\n// Provides: caml_pasta_fq_plonk_proof_dummy\n// Requires: plonk_wasm, caml_pasta_fq_proof_of_rust\nvar caml_pasta_fq_plonk_proof_dummy = function () {\n return caml_pasta_fq_proof_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_proof_dummy()\n );\n};\n\n// Provides: caml_pasta_fq_plonk_proof_deep_copy\n// Requires: plonk_wasm, caml_pasta_fq_proof_to_rust, caml_pasta_fq_proof_of_rust\nvar caml_pasta_fq_plonk_proof_deep_copy = function (proof) {\n return caml_pasta_fq_proof_of_rust(\n plonk_wasm.caml_pasta_fq_plonk_proof_deep_copy(\n caml_pasta_fq_proof_to_rust(proof)\n )\n );\n};\n\n// Provides: caml_random_oracles_of_rust\n// Requires: caml_u8array_vector_of_rust_flat_vector, caml_option_of_maybe_undefined\nvar caml_random_oracles_of_rust = function (x) {\n var joint_combiner_chal = x.joint_combiner_chal;\n var joint_combiner = x.joint_combiner;\n var joint_combiner_ocaml = undefined;\n if (joint_combiner_chal !== undefined && joint_combiner !== undefined) {\n joint_combiner_ocaml = [0, [0, joint_combiner_chal], joint_combiner];\n }\n return [\n 0,\n caml_option_of_maybe_undefined(joint_combiner_ocaml),\n x.beta,\n x.gamma,\n [0, x.alpha_chal],\n x.alpha,\n x.zeta,\n x.v,\n x.u,\n [0, x.zeta_chal],\n [0, x.v_chal],\n [0, x.u_chal],\n ];\n};\n\n// Provides: caml_random_oracles_to_rust\n// Requires: caml_u8array_vector_to_rust_flat_vector, caml_option_to_maybe_undefined\nvar caml_random_oracles_to_rust = function (x, roKlass) {\n // var caml_vector = [0, x[1], x[2], x[3][1], x[4], x[5], x[6], x[7], x[8][1], x[9][1], x[10][1]];\n var joint_combiner_ocaml = caml_option_to_maybe_undefined(x[1]);\n var joint_combiner_chal = undefined;\n var joint_combiner = undefined;\n if (joint_combiner_ocaml !== undefined) {\n joint_combiner_chal = joint_combiner_ocaml[1][1];\n joint_combiner = joint_combiner_ocaml[2];\n }\n return new roKlass(\n joint_combiner_chal,\n joint_combiner,\n x[2],\n x[3],\n x[4][1],\n x[5],\n x[6],\n x[7],\n x[8],\n x[9][1],\n x[10][1],\n x[11][1]\n );\n};\n\n// Provides: caml_oracles_of_rust\n// Requires: caml_u8array_vector_of_rust_flat_vector, caml_random_oracles_of_rust\nvar caml_oracles_of_rust = function (x) {\n return [\n 0,\n caml_random_oracles_of_rust(x.o),\n [0, x.p_eval0, x.p_eval1],\n caml_u8array_vector_of_rust_flat_vector(\n x.opening_prechallenges,\n 32 /* TODO: Don't hardcode */\n ),\n x.digest_before_evaluations,\n ];\n};\n\n// Provides: caml_oracles_to_rust\n// Requires: caml_u8array_vector_to_rust_flat_vector, caml_random_oracles_to_rust\nvar caml_oracles_to_rust = function (x, klass, roKlass) {\n return new klass(\n caml_random_oracles_to_rust(x[1], roKlass),\n x[2][1],\n x[2][2],\n caml_u8array_vector_to_rust_flat_vector(x[3]),\n x[4]\n );\n};\n\n// Provides: fp_oracles_create\n// Requires: plonk_wasm, caml_oracles_of_rust, caml_array_to_rust_vector, caml_vesta_poly_comm_to_rust, caml_pasta_fp_plonk_verifier_index_to_rust, caml_pasta_fp_proof_to_rust\nvar fp_oracles_create = function (lgr_comm, verifier_index, proof) {\n return caml_oracles_of_rust(\n plonk_wasm.fp_oracles_create(\n caml_array_to_rust_vector(lgr_comm, caml_vesta_poly_comm_to_rust),\n caml_pasta_fp_plonk_verifier_index_to_rust(verifier_index),\n caml_pasta_fp_proof_to_rust(proof)\n )\n );\n};\n\n// Provides: fp_oracles_create_no_public\n// Requires: fp_oracles_create\nvar fp_oracles_create_no_public = function (lgr_comm, verifier_index, proof) {\n return fp_oracles_create(lgr_comm, verifier_index, [0, 0, proof]);\n};\n\n// Provides: fp_oracles_dummy\n// Requires: plonk_wasm, caml_oracles_of_rust\nvar fp_oracles_dummy = function () {\n return caml_oracles_of_rust(plonk_wasm.fp_oracles_dummy());\n};\n\n// Provides: fp_oracles_deep_copy\n// Requires: plonk_wasm, caml_oracles_of_rust, caml_oracles_to_rust\nvar fp_oracles_deep_copy = function (x) {\n return caml_oracles_of_rust(\n plonk_wasm.fp_oracles_deep_copy(\n caml_oracles_to_rust(\n x,\n plonk_wasm.WasmFpOracles,\n plonk_wasm.WasmFpRandomOracles\n )\n )\n );\n};\n\n// Provides: fq_oracles_create\n// Requires: plonk_wasm, caml_oracles_of_rust, caml_array_to_rust_vector, caml_pallas_poly_comm_to_rust, caml_pasta_fq_plonk_verifier_index_to_rust, caml_pasta_fq_proof_to_rust\nvar fq_oracles_create = function (lgr_comm, verifier_index, proof) {\n return caml_oracles_of_rust(\n plonk_wasm.fq_oracles_create(\n caml_array_to_rust_vector(lgr_comm, caml_pallas_poly_comm_to_rust),\n caml_pasta_fq_plonk_verifier_index_to_rust(verifier_index),\n caml_pasta_fq_proof_to_rust(proof)\n )\n );\n};\n\n// Provides: fq_oracles_create_no_public\n// Requires: fq_oracles_create\nvar fq_oracles_create_no_public = function (lgr_comm, verifier_index, proof) {\n return fq_oracles_create(lgr_comm, verifier_index, [0, 0, proof]);\n};\n\n// Provides: fq_oracles_dummy\n// Requires: plonk_wasm, caml_oracles_of_rust\nvar fq_oracles_dummy = function () {\n return caml_oracles_of_rust(plonk_wasm.fq_oracles_dummy());\n};\n\n// Provides: fq_oracles_deep_copy\n// Requires: plonk_wasm, caml_oracles_of_rust, caml_oracles_to_rust\nvar fq_oracles_deep_copy = function (x) {\n return caml_oracles_of_rust(\n plonk_wasm.fq_oracles_deep_copy(\n caml_oracles_to_rust(\n x,\n plonk_wasm.WasmFqOracles,\n plonk_wasm.WasmFqRandomOracles\n )\n )\n );\n};\n\n// This is fake -- parameters are only needed on the Rust side, so no need to return something meaningful\n// Provides: caml_pasta_fp_poseidon_params_create\nfunction caml_pasta_fp_poseidon_params_create() {\n return [0];\n}\n// Provides: caml_pasta_fq_poseidon_params_create\nfunction caml_pasta_fq_poseidon_params_create() {\n return [0];\n}\n\n// Provides: caml_pasta_fp_poseidon_block_cipher\n// Requires: plonk_wasm, caml_fp_vector_to_rust, caml_fp_vector_of_rust\nfunction caml_pasta_fp_poseidon_block_cipher(_fake_params, fp_vector) {\n // 1. get permuted field vector from rust\n var wasm_flat_vector = plonk_wasm.caml_pasta_fp_poseidon_block_cipher(\n caml_fp_vector_to_rust(fp_vector)\n );\n var new_fp_vector = caml_fp_vector_of_rust(wasm_flat_vector);\n // 2. write back modified field vector to original one\n new_fp_vector.forEach(function (a, i) {\n fp_vector[i] = a;\n });\n}\n\n// Provides: caml_pasta_fq_poseidon_block_cipher\n// Requires: plonk_wasm, caml_fq_vector_to_rust, caml_fq_vector_of_rust\nfunction caml_pasta_fq_poseidon_block_cipher(_fake_params, fq_vector) {\n // 1. get permuted field vector from rust\n var wasm_flat_vector = plonk_wasm.caml_pasta_fq_poseidon_block_cipher(\n caml_fq_vector_to_rust(fq_vector)\n );\n var new_fq_vector = caml_fq_vector_of_rust(wasm_flat_vector);\n // 2. write back modified field vector to original one\n new_fq_vector.forEach(function (a, i) {\n fq_vector[i] = a;\n });\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_lookup\nfunction caml_pasta_fp_plonk_proof_example_with_lookup() {\n // This is only used in the pickles unit tests\n throw new Error(\n 'Unimplemented caml_pasta_fp_plonk_proof_example_with_lookup'\n );\n}\n\n// Provides: prover_to_json\n// Requires: plonk_wasm\nvar prover_to_json = plonk_wasm.prover_to_json;\n\n// Provides: integers_uint64_of_uint32\n// Requires: UInt64, caml_int64_of_int32\nfunction integers_uint64_of_uint32(i) {\n // Same as integers_uint64_of_int\n return new UInt64(caml_int64_of_int32(i));\n}\n\n/////////////////////////////////////////////////////////////////////////////\n// The *_example_* functions below are only used in the pickles unit tests //\n/////////////////////////////////////////////////////////////////////////////\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_ffadd\nfunction caml_pasta_fp_plonk_proof_example_with_ffadd() {\n throw new Error('Unimplemented caml_pasta_fp_plonk_proof_example_with_ffadd');\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_foreign_field_mul\nfunction caml_pasta_fp_plonk_proof_example_with_foreign_field_mul() {\n throw new Error(\n 'Unimplemented caml_pasta_fp_plonk_proof_example_with_foreign_field_mul'\n );\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_range_check\nfunction caml_pasta_fp_plonk_proof_example_with_range_check() {\n throw new Error(\n 'Unimplemented caml_pasta_fp_plonk_proof_example_with_range_check'\n );\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_range_check0\nfunction caml_pasta_fp_plonk_proof_example_with_range_check0() {\n throw new Error(\n 'Unimplemented caml_pasta_fp_plonk_proof_example_with_range_check0'\n );\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_rot\nfunction caml_pasta_fp_plonk_proof_example_with_rot() {\n throw new Error('Unimplemented caml_pasta_fp_plonk_proof_example_with_rot');\n}\n\n// Provides: caml_pasta_fp_plonk_proof_example_with_xor\nfunction caml_pasta_fp_plonk_proof_example_with_xor() {\n throw new Error('Unimplemented caml_pasta_fp_plonk_proof_example_with_xor');\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_compare_val_tag\n//Requires: caml_is_ml_string, caml_is_ml_bytes\nfunction caml_compare_val_tag(a){\n if (typeof a === \"number\") return 1000; // int_tag (we use it for all numbers)\n else if (caml_is_ml_bytes(a)) return 252; // string_tag\n else if (caml_is_ml_string(a)) return 1252; // ocaml string (if different from bytes)\n else if (a instanceof Array && a[0] === (a[0]>>>0) && a[0] <= 255) {\n // Look like an ocaml block\n var tag = a[0] | 0;\n // ignore double_array_tag because we cannot accurately set\n // this tag when we create an array of float.\n return (tag == 254)?0:tag\n }\n else if (a instanceof String) return 12520; // javascript string, like string_tag (252)\n else if (typeof a == \"string\") return 12520; // javascript string, like string_tag (252)\n else if (a instanceof Number) return 1000; // int_tag (we use it for all numbers)\n else if (a && a.caml_custom) return 1255; // like custom_tag (255)\n else if (a && a.compare) return 1256; // like custom_tag (255)\n else if (typeof a == \"function\") return 1247; // like closure_tag (247)\n else if (typeof a == \"symbol\") return 1251;\n return 1001; //out_of_heap_tag\n}\n\n//Provides: caml_compare_val_get_custom\n//Requires: caml_custom_ops\nfunction caml_compare_val_get_custom(a){\n return caml_custom_ops[a.caml_custom] && caml_custom_ops[a.caml_custom].compare;\n}\n\n//Provides: caml_compare_val_number_custom\n//Requires: caml_compare_val_get_custom\nfunction caml_compare_val_number_custom(num, custom, swap, total) {\n var comp = caml_compare_val_get_custom(custom);\n if(comp) {\n var x = (swap > 0)?comp(custom,num,total):comp(num,custom,total);\n if(total && x != x) return swap; // total && nan\n if(+x != +x) return +x; // nan\n if((x | 0) != 0) return (x | 0); // !nan\n }\n return swap\n}\n\n//Provides: caml_compare_val (const, const, const)\n//Requires: caml_int_compare, caml_string_compare, caml_bytes_compare\n//Requires: caml_invalid_argument, caml_compare_val_get_custom, caml_compare_val_tag\n//Requires: caml_compare_val_number_custom\n//Requires: caml_jsbytes_of_string\nfunction caml_compare_val (a, b, total) {\n var stack = [];\n for(;;) {\n if (!(total && a === b)) {\n var tag_a = caml_compare_val_tag(a);\n // forward_tag ?\n if(tag_a == 250) { a = a[1]; continue }\n\n var tag_b = caml_compare_val_tag(b);\n // forward_tag ?\n if(tag_b == 250) { b = b[1]; continue }\n\n // tags are different\n if(tag_a !== tag_b) {\n if(tag_a == 1000) {\n if(tag_b == 1255) { //immediate can compare against custom\n return caml_compare_val_number_custom(a, b, -1, total);\n }\n return -1\n }\n if(tag_b == 1000) {\n if(tag_a == 1255) { //immediate can compare against custom\n return caml_compare_val_number_custom(b, a, 1, total);\n }\n return 1\n }\n return (tag_a < tag_b)?-1:1;\n }\n switch(tag_a){\n // 246: Lazy_tag handled bellow\n case 247: // Closure_tag\n // Cannot happen\n caml_invalid_argument(\"compare: functional value\");\n break\n case 248: // Object\n var x = caml_int_compare(a[2], b[2]);\n if (x != 0) return (x | 0);\n break;\n case 249: // Infix\n // Cannot happen\n caml_invalid_argument(\"compare: functional value\");\n break\n case 250: // Forward tag\n // Cannot happen, handled above\n caml_invalid_argument(\"equal: got Forward_tag, should not happen\");\n break;\n case 251: //Abstract\n caml_invalid_argument(\"equal: abstract value\");\n break;\n case 252: // OCaml bytes\n if (a !== b) {\n var x = caml_bytes_compare(a, b);\n if (x != 0) return (x | 0);\n };\n break;\n case 253: // Double_tag\n // Cannot happen\n caml_invalid_argument(\"equal: got Double_tag, should not happen\");\n break;\n case 254: // Double_array_tag\n // Cannot happen, handled above\n caml_invalid_argument(\"equal: got Double_array_tag, should not happen\");\n break\n case 255: // Custom_tag\n caml_invalid_argument(\"equal: got Custom_tag, should not happen\");\n break;\n case 1247: // Function\n caml_invalid_argument(\"compare: functional value\");\n break;\n case 1255: // Custom\n var comp = caml_compare_val_get_custom(a);\n if(comp != caml_compare_val_get_custom(b)){\n return (a.caml_custom b) return 1;\n if (a != b) {\n if (!total) return NaN;\n if (a == a) return 1;\n if (b == b) return -1;\n }\n break;\n case 1001: // The rest\n // Here we can be in the following cases:\n // 1. JavaScript primitive types\n // 2. JavaScript object that can be coerced to primitive types\n // 3. JavaScript object than cannot be coerced to primitive types\n //\n // (3) will raise a [TypeError]\n // (2) will coerce to primitive types using [valueOf] or [toString]\n // (2) and (3), after eventual coercion\n // - if a and b are strings, apply lexicographic comparison\n // - if a or b are not strings, convert a and b to number\n // and apply standard comparison\n //\n // Exception: `!=` will not coerce/convert if both a and b are objects\n if (a < b) return -1;\n if (a > b) return 1;\n if (a != b) {\n if (!total) return NaN;\n if (a == a) return 1;\n if (b == b) return -1;\n }\n break;\n case 1251: // JavaScript Symbol, no ordering.\n if(a !== b) {\n if (!total) return NaN;\n return 1;\n }\n break;\n case 1252: // ocaml strings\n var a = caml_jsbytes_of_string(a);\n var b = caml_jsbytes_of_string(b);\n if(a !== b) {\n if(a < b) return -1;\n if(a > b) return 1;\n }\n break;\n case 12520: // javascript strings\n var a = a.toString();\n var b = b.toString();\n if(a !== b) {\n if(a < b) return -1;\n if(a > b) return 1;\n }\n break;\n case 246: // Lazy_tag\n case 254: // Double_array\n default: // Block with other tag\n if (a.length != b.length) return (a.length < b.length)?-1:1;\n if (a.length > 1) stack.push(a, b, 1);\n break;\n }\n }\n if (stack.length == 0) return 0;\n var i = stack.pop();\n b = stack.pop();\n a = stack.pop();\n if (i + 1 < a.length) stack.push(a, b, i + 1);\n a = a[i];\n b = b[i];\n }\n}\n//Provides: caml_compare (const, const)\n//Requires: caml_compare_val\nfunction caml_compare (a, b) { return caml_compare_val (a, b, true); }\n//Provides: caml_int_compare mutable (const, const)\nfunction caml_int_compare (a, b) {\n if (a < b) return (-1); if (a == b) return 0; return 1;\n}\n//Provides: caml_equal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_equal (x, y) { return +(caml_compare_val(x,y,false) == 0); }\n//Provides: caml_notequal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_notequal (x, y) { return +(caml_compare_val(x,y,false) != 0); }\n//Provides: caml_greaterequal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_greaterequal (x, y) { return +(caml_compare_val(x,y,false) >= 0); }\n//Provides: caml_greaterthan mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_greaterthan (x, y) { return +(caml_compare_val(x,y,false) > 0); }\n//Provides: caml_lessequal mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_lessequal (x, y) { return +(caml_compare_val(x,y,false) <= 0); }\n//Provides: caml_lessthan mutable (const, const)\n//Requires: caml_compare_val\nfunction caml_lessthan (x, y) { return +(caml_compare_val(x,y,false) < 0); }\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n// Weak API, but without the weak semantics\n\n//Provides: caml_ephe_key_offset\nvar caml_ephe_key_offset = 3\n\n//Provides: caml_ephe_data_offset\nvar caml_ephe_data_offset = 2\n\n//Provides: caml_weak_create\n//Requires: caml_ephe_key_offset, caml_invalid_argument\nfunction caml_weak_create (n) {\n if (n < 0) caml_invalid_argument (\"Weak.create\");\n var x = [251,\"caml_ephe_list_head\"];\n x.length = caml_ephe_key_offset + n;\n return x;\n}\n\n//Provides: caml_weak_set\n//Requires: caml_ephe_key_offset, caml_invalid_argument\nfunction caml_weak_set(x, i, v) {\n if(i < 0 || caml_ephe_key_offset + i >= x.length)\n caml_invalid_argument (\"Weak.set\");\n x[caml_ephe_key_offset + i] = v;\n return 0;\n}\n//Provides: caml_weak_get\n//Requires: caml_ephe_key_offset, caml_invalid_argument\nfunction caml_weak_get(x, i) {\n if(i < 0 || caml_ephe_key_offset + i >= x.length)\n caml_invalid_argument (\"Weak.get_key\");\n return (x[caml_ephe_key_offset + i ]===undefined)?0:x[caml_ephe_key_offset + i];\n}\n//Provides: caml_weak_get_copy\n//Requires: caml_weak_get,caml_ephe_key_offset\n//Requires: caml_obj_dup, caml_invalid_argument\nfunction caml_weak_get_copy(x, i) {\n if(i < 0 || caml_ephe_key_offset + i >= x.length)\n caml_invalid_argument (\"Weak.get_copy\");\n var y = caml_weak_get(x, i);\n if (y === 0) return y;\n var z = y[1];\n if (z instanceof Array) return [0, caml_obj_dup(z)];\n return y;\n}\n\n//Provides: caml_weak_check mutable\n//Requires: caml_ephe_key_offset\nfunction caml_weak_check(x, i) {\n if(x[caml_ephe_key_offset + i]!==undefined && x[caml_ephe_key_offset + i] !==0)\n return 1;\n else\n return 0;\n}\n\n//Provides: caml_weak_blit\n//Requires: caml_array_blit\n//Requires: caml_ephe_key_offset\nfunction caml_weak_blit(a1, i1, a2, i2, len) {\n // minus one because caml_array_blit works on ocaml array\n caml_array_blit(a1, caml_ephe_key_offset + i1 - 1,\n a2, caml_ephe_key_offset + i2 - 1,\n len);\n return 0;\n}\n\n//Provides: caml_ephe_create\n//Requires: caml_weak_create\nvar caml_ephe_create = caml_weak_create\n\n//Provides: caml_ephe_blit_key\n//Requires: caml_weak_blit\nvar caml_ephe_blit_key = caml_weak_blit\n\n//Provides: caml_ephe_get_key\n//Requires: caml_weak_get\nvar caml_ephe_get_key = caml_weak_get\n\n//Provides: caml_ephe_get_key_copy\n//Requires: caml_weak_get_copy\nvar caml_ephe_get_key_copy = caml_weak_get_copy\n\n//Provides: caml_ephe_check_key\n//Requires: caml_weak_check\nvar caml_ephe_check_key = caml_weak_check\n\n//Provides: caml_ephe_set_key\n//Requires: caml_weak_set\nfunction caml_ephe_set_key(x, i, v) {\n return caml_weak_set(x, i, [0, v])\n}\n\n//Provides: caml_ephe_unset_key\n//Requires: caml_weak_set\nfunction caml_ephe_unset_key(x, i) {\n return caml_weak_set(x, i, 0)\n}\n\n//Provides: caml_ephe_blit_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_blit_data(src, dst){\n dst[caml_ephe_data_offset] = src[caml_ephe_data_offset];\n return 0;\n}\n\n//Provides: caml_ephe_get_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_get_data(x){\n if(x[caml_ephe_data_offset] === undefined)\n return 0;\n else\n return [0, x[caml_ephe_data_offset]];\n}\n\n//Provides: caml_ephe_get_data_copy\n//Requires: caml_ephe_data_offset\n//Requires: caml_obj_dup\nfunction caml_ephe_get_data_copy(x){\n if(x[caml_ephe_data_offset] === undefined)\n return 0;\n else\n return [0, caml_obj_dup(x[caml_ephe_data_offset])];\n}\n\n//Provides: caml_ephe_set_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_set_data(x, data){\n x[caml_ephe_data_offset] = data;\n return 0;\n}\n\n//Provides: caml_ephe_unset_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_unset_data(x, data){\n x[caml_ephe_data_offset] = undefined;\n return 0;\n}\n\n//Provides: caml_ephe_check_data\n//Requires: caml_ephe_data_offset\nfunction caml_ephe_check_data(x){\n if(x[caml_ephe_data_offset] === undefined)\n return 0;\n else\n return 1;\n}\n","\n\n//Provides: caml_gc_minor\nfunction caml_gc_minor(){ return 0}\n//Provides: caml_gc_major\nfunction caml_gc_major(){ return 0}\n//Provides: caml_gc_full_major\nfunction caml_gc_full_major(){ return 0}\n//Provides: caml_gc_compaction\nfunction caml_gc_compaction(){ return 0}\n//Provides: caml_gc_counters\nfunction caml_gc_counters() { return [254,0,0,0] }\n//Provides: caml_gc_quick_stat\nfunction caml_gc_quick_stat(){\n return [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]\n}\n//Provides: caml_gc_stat\nfunction caml_gc_stat() {\n return [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]\n}\n\n//Provides: caml_gc_set\nfunction caml_gc_set(_control) {\n return 0;\n}\n\n//Provides: caml_gc_get\nfunction caml_gc_get(){\n return [0,0,0,0,0,0,0,0,0]\n}\n\n//Provides: caml_memprof_set\nfunction caml_memprof_set(_control) {\n return 0;\n}\n\n//Provides: caml_final_register const\nfunction caml_final_register () { return 0; }\n//Provides: caml_final_register_called_without_value const\nfunction caml_final_register_called_without_value () { return 0; }\n//Provides: caml_final_release const\nfunction caml_final_release () { return 0; }\n\n//Provides: caml_memprof_start\nfunction caml_memprof_start(rate,stack_size,tracker){\n return 0;\n}\n\n//Provides: caml_memprof_stop\nfunction caml_memprof_stop(unit) {\n return 0;\n}\n\n//Provides: caml_eventlog_resume\nfunction caml_eventlog_resume(unit) { return 0; }\n\n//Provides: caml_eventlog_pause\nfunction caml_eventlog_pause(unit) { return 0; }\n\n//Provides: caml_gc_huge_fallback_count\nfunction caml_gc_huge_fallback_count(unit) { return 0; }\n\n//Provides: caml_gc_major_slice\nfunction caml_gc_major_slice(work) { return 0; }\n\n//Provides: caml_gc_minor_words\nfunction caml_gc_minor_words(unit) { return 0; }\n\n//Provides: caml_get_minor_free\nfunction caml_get_minor_free(unit) { return 0; }\n\n//Provides: caml_get_major_bucket\nfunction caml_get_major_bucket(n) { return 0; }\n\n//Provides: caml_get_major_credit\nfunction caml_get_major_credit(n) { return 0; }\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Format\n\n//Provides: caml_parse_format\n//Requires: caml_jsbytes_of_string, caml_invalid_argument\nfunction caml_parse_format (fmt) {\n fmt = caml_jsbytes_of_string(fmt);\n var len = fmt.length;\n if (len > 31) caml_invalid_argument(\"format_int: format too long\");\n var f =\n { justify:'+', signstyle:'-', filler:' ', alternate:false,\n base:0, signedconv:false, width:0, uppercase:false,\n sign:1, prec:-1, conv:'f' };\n for (var i = 0; i < len; i++) {\n var c = fmt.charAt(i);\n switch (c) {\n case '-':\n f.justify = '-'; break;\n case '+': case ' ':\n f.signstyle = c; break;\n case '0':\n f.filler = '0'; break;\n case '#':\n f.alternate = true; break;\n case '1': case '2': case '3': case '4': case '5':\n case '6': case '7': case '8': case '9':\n f.width = 0;\n while (c=fmt.charCodeAt(i) - 48, c >= 0 && c <= 9) {\n f.width = f.width * 10 + c; i++\n }\n i--;\n break;\n case '.':\n f.prec = 0;\n i++;\n while (c=fmt.charCodeAt(i) - 48, c >= 0 && c <= 9) {\n f.prec = f.prec * 10 + c; i++\n }\n i--;\n case 'd': case 'i':\n f.signedconv = true; /* fallthrough */\n case 'u':\n f.base = 10; break;\n case 'x':\n f.base = 16; break;\n case 'X':\n f.base = 16; f.uppercase = true; break;\n case 'o':\n f.base = 8; break;\n case 'e': case 'f': case 'g':\n f.signedconv = true; f.conv = c; break;\n case 'E': case 'F': case 'G':\n f.signedconv = true; f.uppercase = true;\n f.conv = c.toLowerCase (); break;\n }\n }\n return f;\n}\n\n//Provides: caml_finish_formatting\n//Requires: caml_string_of_jsbytes\nfunction caml_finish_formatting(f, rawbuffer) {\n if (f.uppercase) rawbuffer = rawbuffer.toUpperCase();\n var len = rawbuffer.length;\n /* Adjust len to reflect additional chars (sign, etc) */\n if (f.signedconv && (f.sign < 0 || f.signstyle != '-')) len++;\n if (f.alternate) {\n if (f.base == 8) len += 1;\n if (f.base == 16) len += 2;\n }\n /* Do the formatting */\n var buffer = \"\";\n if (f.justify == '+' && f.filler == ' ')\n for (var i = len; i < f.width; i++) buffer += ' ';\n if (f.signedconv) {\n if (f.sign < 0) buffer += '-';\n else if (f.signstyle != '-') buffer += f.signstyle;\n }\n if (f.alternate && f.base == 8) buffer += '0';\n if (f.alternate && f.base == 16) buffer += \"0x\";\n if (f.justify == '+' && f.filler == '0')\n for (var i = len; i < f.width; i++) buffer += '0';\n buffer += rawbuffer;\n if (f.justify == '-')\n for (var i = len; i < f.width; i++) buffer += ' ';\n return caml_string_of_jsbytes(buffer);\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: caml_update_dummy\nfunction caml_update_dummy (x, y) {\n if( typeof y===\"function\" ) { x.fun = y; return 0; }\n if( y.fun ) { x.fun = y.fun; return 0; }\n var i = y.length; while (i--) x[i] = y[i]; return 0;\n}\n\n//Provides: caml_obj_is_block const (const)\nfunction caml_obj_is_block (x) { return +(x instanceof Array); }\n\n\n//Provides: caml_obj_tag\n//Requires: caml_is_ml_bytes, caml_is_ml_string\nfunction caml_obj_tag (x) {\n if ((x instanceof Array) && x[0] == (x[0] >>> 0))\n return x[0]\n else if (caml_is_ml_bytes(x))\n return 252\n else if (caml_is_ml_string(x))\n return 252\n else if ((x instanceof Function) || typeof x == \"function\")\n return 247\n else if (x && x.caml_custom)\n return 255\n else\n return 1000\n}\n\n//Provides: caml_obj_set_tag (mutable, const)\nfunction caml_obj_set_tag (x, tag) { x[0] = tag; return 0; }\n//Provides: caml_obj_block const (const,const)\nfunction caml_obj_block (tag, size) {\n var o = new Array(size+1);\n o[0]=tag;\n for (var i = 1; i <= size; i++) o[i] = 0;\n return o;\n}\n\n//Provides: caml_obj_with_tag\nfunction caml_obj_with_tag(tag,x) {\n var l = x.length;\n var a = new Array(l);\n a[0] = tag;\n for(var i = 1; i < l; i++ ) a[i] = x[i];\n return a;\n}\n\n//Provides: caml_obj_dup mutable (const)\nfunction caml_obj_dup (x) {\n var l = x.length;\n var a = new Array(l);\n for(var i = 0; i < l; i++ ) a[i] = x[i];\n return a;\n}\n\n//Provides: caml_obj_truncate (mutable, const)\n//Requires: caml_invalid_argument\nfunction caml_obj_truncate (x, s) {\n if (s<=0 || s + 1 > x.length)\n caml_invalid_argument (\"Obj.truncate\");\n if (x.length != s + 1) x.length = s + 1;\n return 0;\n}\n\n//Provides: caml_obj_make_forward\nfunction caml_obj_make_forward (b,v) {\n b[0]=250;\n b[1]=v;\n return 0\n}\n\n//Provides: caml_lazy_make_forward const (const)\nfunction caml_lazy_make_forward (v) { return [250, v]; }\n\n///////////// CamlinternalOO\n//Provides: caml_get_public_method const\nvar caml_method_cache = [];\nfunction caml_get_public_method (obj, tag, cacheid) {\n var meths = obj[1];\n var ofs = caml_method_cache[cacheid];\n if (ofs === undefined) {\n // Make sure the array is not sparse\n for (var i = caml_method_cache.length; i < cacheid; i++)\n caml_method_cache[i] = 0;\n } else if (meths[ofs] === tag) {\n return meths[ofs - 1];\n }\n var li = 3, hi = meths[1] * 2 + 1, mi;\n while (li < hi) {\n mi = ((li+hi) >> 1) | 1;\n if (tag < meths[mi+1]) hi = mi-2;\n else li = mi;\n }\n caml_method_cache[cacheid] = li + 1;\n /* return 0 if tag is not there */\n return (tag == meths[li+1] ? meths[li] : 0);\n}\n\n//Provides: caml_oo_last_id\nvar caml_oo_last_id = 0;\n\n//Provides: caml_set_oo_id\n//Requires: caml_oo_last_id\nfunction caml_set_oo_id (b) {\n b[2]=caml_oo_last_id++;\n return b;\n}\n\n//Provides: caml_fresh_oo_id const\n//Requires: caml_oo_last_id\nfunction caml_fresh_oo_id() {\n return caml_oo_last_id++;\n}\n\n//Provides: caml_obj_raw_field\nfunction caml_obj_raw_field(o,i) { return o[i+1] }\n\n//Provides: caml_obj_set_raw_field\nfunction caml_obj_set_raw_field(o,i,v) { return o[i+1] = v }\n\n//Provides: caml_obj_reachable_words\nfunction caml_obj_reachable_words(o) { return 0; }\n\n//Provides: caml_obj_add_offset\n//Requires: caml_failwith\nfunction caml_obj_add_offset(v,offset) {\n caml_failwith(\"Obj.add_offset is not supported\");\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: fs_node_supported\nfunction fs_node_supported () {\n return (\n typeof globalThis.process !== 'undefined'\n && typeof globalThis.process.versions !== 'undefined'\n && typeof globalThis.process.versions.node !== 'undefined')\n}\n//Provides: fs_node_supported\n//If: browser\nfunction fs_node_supported () {\n return false\n}\n\n\n//Provides: MlNodeDevice\n//Requires: MlNodeFile, caml_raise_sys_error, caml_raise_with_args\n//Requires: make_unix_err_args, caml_named_value, caml_string_of_jsstring\nfunction MlNodeDevice(root) {\n this.fs = require('fs');\n this.root = root;\n}\nMlNodeDevice.prototype.nm = function(name) {\n return (this.root + name);\n}\nMlNodeDevice.prototype.exists = function(name) {\n try {\n return this.fs.existsSync(this.nm(name))?1:0;\n } catch (err) {\n return 0;\n }\n}\nMlNodeDevice.prototype.mkdir = function(name, mode, raise_unix) {\n try {\n this.fs.mkdirSync(this.nm(name),{mode:mode});\n return 0\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.rmdir = function(name, raise_unix) {\n try {\n this.fs.rmdirSync(this.nm(name));\n return 0\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.readdir = function(name, raise_unix) {\n try {\n return this.fs.readdirSync(this.nm(name));\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.is_dir = function(name) {\n try {\n return this.fs.statSync(this.nm(name)).isDirectory()?1:0;\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n}\nMlNodeDevice.prototype.unlink = function(name, raise_unix) {\n try {\n var b = this.fs.existsSync(this.nm(name))?1:0;\n this.fs.unlinkSync(this.nm(name));\n return b;\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.open = function(name, f, raise_unix) {\n var consts = require('constants');\n var res = 0;\n for(var key in f){\n switch(key){\n case \"rdonly\" : res |= consts.O_RDONLY; break;\n case \"wronly\" : res |= consts.O_WRONLY; break;\n case \"append\" :\n res |= consts.O_WRONLY | consts.O_APPEND;\n break;\n case \"create\" : res |= consts.O_CREAT; break;\n case \"truncate\" : res |= consts.O_TRUNC; break;\n case \"excl\" : res |= consts.O_EXCL; break;\n case \"binary\" : res |= consts.O_BINARY; break;\n case \"text\" : res |= consts.O_TEXT; break;\n case \"nonblock\" : res |= consts.O_NONBLOCK; break;\n }\n }\n try {\n var fd = this.fs.openSync(this.nm(name), res);\n return new MlNodeFile(fd);\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\n\nMlNodeDevice.prototype.rename = function(o, n, raise_unix) {\n try {\n this.fs.renameSync(this.nm(o), this.nm(n));\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.stat = function(name, raise_unix) {\n try {\n var js_stats = this.fs.statSync(this.nm(name));\n return this.stats_from_js(js_stats);\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.lstat = function(name, raise_unix) {\n try {\n var js_stats = this.fs.lstatSync(this.nm(name));\n return this.stats_from_js(js_stats);\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.symlink = function(to_dir, target, path, raise_unix) {\n try {\n this.fs.symlinkSync(this.nm(target), this.nm(path), to_dir ? 'dir' : 'file');\n return 0;\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.readlink = function(name, raise_unix) {\n try {\n var link = this.fs.readlinkSync(this.nm(name), 'utf8');\n return caml_string_of_jsstring(link);\n } catch (err) {\n this.raise_nodejs_error(err, raise_unix);\n }\n}\nMlNodeDevice.prototype.raise_nodejs_error = function(err, raise_unix) {\n var unix_error = caml_named_value(\"Unix.Unix_error\");\n if (raise_unix && unix_error) {\n var args = make_unix_err_args(err.code, err.syscall, err.path, err.errno);\n caml_raise_with_args(unix_error, args);\n } else {\n caml_raise_sys_error(err.toString());\n }\n}\nMlNodeDevice.prototype.stats_from_js = function(js_stats) {\n /* ===Unix.file_kind===\n * type file_kind =\n * S_REG (** Regular file *)\n * | S_DIR (** Directory *)\n * | S_CHR (** Character device *)\n * | S_BLK (** Block device *)\n * | S_LNK (** Symbolic link *)\n * | S_FIFO (** Named pipe *)\n * | S_SOCK (** Socket *)\n */\n var file_kind;\n if (js_stats.isFile()) {\n file_kind = 0;\n } else if (js_stats.isDirectory()) {\n file_kind = 1;\n } else if (js_stats.isCharacterDevice()) {\n file_kind = 2;\n } else if (js_stats.isBlockDevice()) {\n file_kind = 3;\n } else if (js_stats.isSymbolicLink()) {\n file_kind = 4;\n } else if (js_stats.isFIFO()) {\n file_kind = 5;\n } else if (js_stats.isSocket()) {\n file_kind = 6;\n }\n /* ===Unix.stats===\n * type stats =\n * { st_dev : int; (** Device number *)\n * st_ino : int; (** Inode number *)\n * st_kind : file_kind; (** Kind of the file *)\n * st_perm : file_perm; (** Access rights *)\n * st_nlink : int; (** Number of links *)\n * st_uid : int; (** User id of the owner *)\n * st_gid : int; (** Group ID of the file's group *)\n * st_rdev : int; (** Device ID (if special file) *)\n * st_size : int; (** Size in bytes *)\n * st_atime : float; (** Last access time *)\n * st_mtime : float; (** Last modification time *)\n * st_ctime : float; (** Last status change time *)\n * }\n */\n return BLOCK(\n 0,\n js_stats.dev,\n js_stats.ino,\n file_kind,\n js_stats.mode,\n js_stats.nlink,\n js_stats.uid,\n js_stats.gid,\n js_stats.rdev,\n js_stats.size,\n js_stats.atimeMs,\n js_stats.mtimeMs,\n js_stats.ctimeMs\n );\n}\n\nMlNodeDevice.prototype.constructor = MlNodeDevice\n\n//Provides: MlNodeDevice\n//If: browser\nfunction MlNodeDevice() {\n}\n\n//Provides: MlNodeFile\n//Requires: MlFile, caml_array_of_string, caml_array_of_bytes, caml_bytes_set, caml_raise_sys_error\nfunction MlNodeFile(fd){\n this.fs = require('fs');\n this.fd = fd;\n}\nMlNodeFile.prototype = new MlFile ();\n\nMlNodeFile.prototype.truncate = function(len){\n try {\n this.fs.ftruncateSync(this.fd,len|0)\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n}\nMlNodeFile.prototype.length = function () {\n try {\n return this.fs.fstatSync(this.fd).size;\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n}\nMlNodeFile.prototype.write = function(offset,buf,buf_offset,len){\n var a = caml_array_of_string(buf);\n if(! (a instanceof globalThis.Uint8Array))\n a = new globalThis.Uint8Array(a);\n var buffer = globalThis.Buffer.from(a);\n try {\n this.fs.writeSync(this.fd, buffer, buf_offset, len, offset);\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n return 0;\n}\nMlNodeFile.prototype.read = function(offset,buf,buf_offset,len){\n var a = caml_array_of_bytes(buf);\n if(! (a instanceof globalThis.Uint8Array))\n a = new globalThis.Uint8Array(a);\n var buffer = globalThis.Buffer.from(a);\n try {\n this.fs.readSync(this.fd, buffer, buf_offset, len, offset);\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n for(var i = 0; i < len; i++){\n caml_bytes_set(buf,buf_offset + i,buffer[buf_offset+i]);\n }\n return 0\n}\nMlNodeFile.prototype.read_one = function(offset){\n var a = new globalThis.Uint8Array(1);\n var buffer = globalThis.Buffer.from(a);\n try {\n this.fs.readSync(this.fd, buffer, 0, 1, offset);\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n return buffer[0];\n}\nMlNodeFile.prototype.close = function(){\n try {\n this.fs.closeSync(this.fd);\n } catch (err) {\n caml_raise_sys_error(err.toString());\n }\n}\n\nMlNodeFile.prototype.constructor = MlNodeFile;\n\n//Provides: MlNodeFile\n//If: browser\nfunction MlNodeFile(){\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Dummy filesystem\n\n//Provides: caml_trailing_slash\nfunction caml_trailing_slash(name){\n return (name.slice(-1) !== \"/\") ? (name + \"/\") : name;\n}\n\n//Provides: caml_current_dir\n//Requires: caml_trailing_slash, fs_node_supported\nif(fs_node_supported () && globalThis.process && globalThis.process.cwd)\n var caml_current_dir = globalThis.process.cwd().replace(/\\\\/g,'/');\nelse\n var caml_current_dir = \"/static\";\ncaml_current_dir = caml_trailing_slash(caml_current_dir);\n\n//Provides: caml_get_root\n//Requires: path_is_absolute\nfunction caml_get_root(path){\n var x = path_is_absolute(path);\n if (!x) return;\n return x[0] + \"/\"}\n\n//Provides: caml_root\n//Requires: caml_get_root, caml_current_dir, caml_failwith\nvar caml_root = caml_get_root(caml_current_dir) || caml_failwith(\"unable to compute caml_root\");\n\n\n//Provides: MlFile\nfunction MlFile(){ }\n\n//Provides: path_is_absolute\n//Requires: fs_node_supported\nfunction make_path_is_absolute() {\n function posix(path) {\n if (path.charAt(0) === '/') return [\"\", path.substring(1)];\n return;\n }\n\n function win32(path) {\n // https://github.com/nodejs/node/blob/b3fcc245fb25539909ef1d5eaa01dbf92e168633/lib/path.js#L56\n var splitDeviceRe = /^([a-zA-Z]:|[\\\\/]{2}[^\\\\/]+[\\\\/]+[^\\\\/]+)?([\\\\/])?([\\s\\S]*?)$/;\n var result = splitDeviceRe.exec(path);\n var device = result[1] || '';\n var isUnc = Boolean(device && device.charAt(1) !== ':');\n\n // UNC paths are always absolute\n if (Boolean(result[2] || isUnc)) {\n var root = (result[1] || '');\n var sep = (result[2] || '');\n return [root, path.substring(root.length + sep.length)]\n }\n return;\n }\n if(fs_node_supported () && globalThis.process && globalThis.process.platform) {\n return globalThis.process.platform === 'win32' ? win32 : posix;\n }\n else return posix\n}\nvar path_is_absolute = make_path_is_absolute();\n\n//Provides: caml_make_path\n//Requires: caml_current_dir\n//Requires: caml_jsstring_of_string, path_is_absolute\nfunction caml_make_path (name) {\n name=caml_jsstring_of_string(name);\n if( !path_is_absolute(name) )\n name = caml_current_dir + name;\n var comp0 = path_is_absolute(name);\n var comp = comp0[1].split(\"/\");\n var ncomp = []\n for(var i = 0; i1) ncomp.pop(); break;\n case \".\": break;\n default: ncomp.push(comp[i]);break\n }\n }\n ncomp.unshift(comp0[0]);\n ncomp.orig = name;\n return ncomp;\n}\n\n//Provides:jsoo_mount_point\n//Requires: MlFakeDevice, MlNodeDevice, caml_root, fs_node_supported\nvar jsoo_mount_point = []\nif (fs_node_supported()) {\n jsoo_mount_point.push({path:caml_root,device:new MlNodeDevice(caml_root)});\n} else {\n jsoo_mount_point.push({path:caml_root,device:new MlFakeDevice(caml_root)});\n}\njsoo_mount_point.push({path:\"/static/\", device:new MlFakeDevice(\"/static/\")});\n\n//Provides:caml_list_mount_point\n//Requires: jsoo_mount_point, caml_string_of_jsbytes\nfunction caml_list_mount_point(){\n var prev = 0\n for(var i = 0; i < jsoo_mount_point.length; i++){\n var old = prev;\n prev = [0, caml_string_of_jsbytes(jsoo_mount_point[i].path), old]\n }\n return prev;\n}\n\n//Provides: resolve_fs_device\n//Requires: caml_make_path, jsoo_mount_point, caml_raise_sys_error, caml_get_root, MlNodeDevice, caml_trailing_slash, fs_node_supported\nfunction resolve_fs_device(name){\n var path = caml_make_path(name);\n var name = path.join(\"/\");\n var name_slash = caml_trailing_slash(name);\n var res;\n for(var i = 0; i < jsoo_mount_point.length; i++) {\n var m = jsoo_mount_point[i];\n if(name_slash.search(m.path) == 0\n && (!res || res.path.length < m.path.length))\n res = {path:m.path,device:m.device,rest:name.substring(m.path.length,name.length)};\n }\n if( !res && fs_node_supported()) {\n var root = caml_get_root(name);\n if (root && root.match(/^[a-zA-Z]:\\/$/)){\n var m = {path:root,device:new MlNodeDevice(root)};\n jsoo_mount_point.push(m);\n res = {path:m.path,device:m.device,rest:name.substring(m.path.length,name.length)};\n }\n }\n if( res ) return res;\n caml_raise_sys_error(\"no device found for \" + name_slash);\n}\n\n//Provides: caml_mount_autoload\n//Requires: MlFakeDevice, caml_make_path, jsoo_mount_point, caml_trailing_slash\nfunction caml_mount_autoload(name,f){\n var path = caml_make_path(name);\n var name = caml_trailing_slash(path.join(\"/\"));\n jsoo_mount_point.push({path:name,device:new MlFakeDevice(name,f)})\n return 0;\n}\n\n//Provides: caml_unmount\n//Requires: jsoo_mount_point, caml_make_path, caml_trailing_slash\nfunction caml_unmount(name){\n var path = caml_make_path(name);\n var name = caml_trailing_slash(path.join(\"/\"));\n var idx = -1;\n for(var i = 0; i < jsoo_mount_point.length; i++)\n if(jsoo_mount_point[i].path == name) idx = i;\n if(idx > -1) jsoo_mount_point.splice(idx,1);\n return 0\n}\n\n//Provides: caml_sys_getcwd\n//Requires: caml_current_dir, caml_string_of_jsbytes\nfunction caml_sys_getcwd() {\n return caml_string_of_jsbytes(caml_current_dir);\n}\n\n//Provides: caml_sys_chdir\n//Requires: caml_current_dir, caml_raise_no_such_file, resolve_fs_device, caml_trailing_slash, caml_jsbytes_of_string\nfunction caml_sys_chdir(dir) {\n var root = resolve_fs_device(dir);\n if(root.device.exists(root.rest)) {\n if(root.rest) caml_current_dir = caml_trailing_slash(root.path + root.rest);\n else caml_current_dir = root.path;\n return 0;\n }\n else {\n caml_raise_no_such_file(caml_jsbytes_of_string(dir));\n }\n}\n\n//Provides: caml_raise_no_such_file\n//Requires: caml_raise_sys_error\nfunction caml_raise_no_such_file(name){\n caml_raise_sys_error (name + \": No such file or directory\");\n}\n\n//Provides: caml_raise_not_a_dir\n//Requires: caml_raise_sys_error\nfunction caml_raise_not_a_dir(name){\n caml_raise_sys_error (name + \": Not a directory\");\n}\n\n//Provides: caml_sys_file_exists\n//Requires: resolve_fs_device\nfunction caml_sys_file_exists (name) {\n var root = resolve_fs_device(name);\n return root.device.exists(root.rest);\n}\n\n//Provides: caml_sys_read_directory\n//Requires: caml_string_of_jsbytes\n//Requires: caml_raise_not_a_dir, resolve_fs_device\nfunction caml_sys_read_directory(name){\n var root = resolve_fs_device(name);\n var a = root.device.readdir(root.rest);\n var l = new Array(a.length + 1);\n l[0] = 0;\n for(var i=0;i start) r+=\", \";\n var v = bucket[i]\n if(typeof v == \"number\")\n r+= v.toString();\n else if(v instanceof MlBytes){\n r+= '\"' + v.toString() + '\"';\n }\n else if(typeof v == \"string\"){\n r+= '\"' + v.toString() + '\"';\n }\n else r += \"_\";\n }\n r += \")\"\n } else if (exn[0] == 248){\n r += exn[1]\n }\n return r\n}\n\n//Provides: caml_fatal_uncaught_exception\n//Requires: caml_named_value, caml_format_exception\nfunction caml_fatal_uncaught_exception(err){\n if(err instanceof Array && (err[0] == 0 || err[0] == 248)) {\n var handler = caml_named_value(\"Printexc.handle_uncaught_exception\");\n if(handler) handler(err,false);\n else {\n var msg = caml_format_exception(err);\n var at_exit = caml_named_value(\"Pervasives.do_at_exit\");\n if(at_exit) { at_exit(0) }\n globalThis.console.error(\"Fatal error: exception \" + msg + \"\\n\");\n }\n }\n else {\n throw err\n }\n}\n\n\n//Provides: caml_set_static_env\nfunction caml_set_static_env(k,v){\n if(!globalThis.jsoo_static_env)\n globalThis.jsoo_static_env = {}\n globalThis.jsoo_static_env[k] = v;\n return 0;\n}\n//Provides: caml_sys_getenv (const)\n//Requires: caml_raise_not_found\n//Requires: caml_string_of_jsstring\n//Requires: caml_jsstring_of_string\nfunction caml_sys_getenv (name) {\n var g = globalThis;\n var n = caml_jsstring_of_string(name);\n //nodejs env\n if(g.process\n && g.process.env\n && g.process.env[n] != undefined)\n return caml_string_of_jsstring(g.process.env[n]);\n if(globalThis.jsoo_static_env\n && globalThis.jsoo_static_env[n])\n return caml_string_of_jsstring(globalThis.jsoo_static_env[n])\n caml_raise_not_found ();\n}\n\n//Provides: caml_sys_unsafe_getenv\n//Requires: caml_sys_getenv\nfunction caml_sys_unsafe_getenv(name){\n return caml_sys_getenv (name);\n}\n\n//Provides: caml_argv\n//Requires: caml_string_of_jsstring\nvar caml_argv = ((function () {\n var g = globalThis;\n var main = \"a.out\";\n var args = []\n\n if(g.process\n && g.process.argv\n && g.process.argv.length > 1) {\n var argv = g.process.argv\n //nodejs\n main = argv[1];\n args = argv.slice(2);\n }\n\n var p = caml_string_of_jsstring(main);\n var args2 = [0, p];\n for(var i = 0; i < args.length; i++)\n args2.push(caml_string_of_jsstring(args[i]));\n return args2;\n})())\n\n//Provides: caml_executable_name\n//Requires: caml_argv\nvar caml_executable_name = caml_argv[1]\n\n//Provides: caml_sys_get_argv\n//Requires: caml_argv\nfunction caml_sys_get_argv (a) {\n return [0, caml_argv[1], caml_argv];\n}\n\n//Provides: caml_sys_argv\n//Requires: caml_argv\nfunction caml_sys_argv (a) {\n return caml_argv;\n}\n\n//Provides: caml_sys_modify_argv\n//Requires: caml_argv\nfunction caml_sys_modify_argv(arg){\n caml_argv = arg;\n return 0;\n}\n\n//Provides: caml_sys_executable_name const\n//Requires: caml_executable_name\nfunction caml_sys_executable_name(a){\n return caml_executable_name\n}\n\n//Provides: caml_sys_system_command\n//Requires: caml_jsstring_of_string\nfunction caml_sys_system_command(cmd){\n var cmd = caml_jsstring_of_string(cmd);\n if (typeof require != \"undefined\"\n && require('child_process')\n && require('child_process').execSync) {\n try {require('child_process').execSync(cmd,{stdio: 'inherit'}); return 0}\n catch (e) {return 1}\n }\n else return 127;\n}\n\n//Provides: caml_sys_time mutable\nvar caml_initial_time = (new Date()).getTime() * 0.001;\nfunction caml_sys_time () {\n var now = (new Date()).getTime();\n return now * 0.001 - caml_initial_time;\n}\n\n//Provides: caml_sys_time_include_children\n//Requires: caml_sys_time\nfunction caml_sys_time_include_children(b) {\n return caml_sys_time();\n}\n\n//Provides: caml_sys_random_seed mutable\n//The function needs to return an array since OCaml 4.0...\nfunction caml_sys_random_seed () {\n if(globalThis.crypto) {\n if(typeof globalThis.crypto.getRandomValues === 'function'){\n // Webbrowsers\n var a = new globalThis.Uint32Array(1);\n globalThis.crypto.getRandomValues(a);\n return [0,a[0]];\n } else if(globalThis.crypto.randomBytes === 'function'){\n // Nodejs\n var buff = globalThis.crypto.randomBytes(4);\n var a = new globalThis.Uint32Array(buff);\n return [0,a[0]];\n }\n }\n var now = (new Date()).getTime();\n var x = now^0xffffffff*Math.random();\n return [0,x];\n}\n\n//Provides: caml_sys_const_big_endian const\nfunction caml_sys_const_big_endian () { return 0; }\n\n//Provides: caml_sys_const_word_size const\nfunction caml_sys_const_word_size () { return 32; }\n\n//Provides: caml_sys_const_int_size const\nfunction caml_sys_const_int_size () { return 32; }\n\n//Provides: caml_sys_const_max_wosize const\n// max_int / 4 so that the following does not overflow\n//let max_string_length = word_size / 8 * max_array_length - 1;;\nfunction caml_sys_const_max_wosize () { return (0x7FFFFFFF/4) | 0;}\n\n//Provides: caml_sys_const_ostype_unix const\n//Requires: os_type\nfunction caml_sys_const_ostype_unix () { return os_type == \"Unix\" ? 1 : 0; }\n//Provides: caml_sys_const_ostype_win32 const\n//Requires: os_type\nfunction caml_sys_const_ostype_win32 () { return os_type == \"Win32\" ? 1 : 0; }\n//Provides: caml_sys_const_ostype_cygwin const\n//Requires: os_type\nfunction caml_sys_const_ostype_cygwin () { return os_type == \"Cygwin\" ? 1 : 0; }\n\n//Provides: caml_sys_const_backend_type const\n//Requires: caml_string_of_jsbytes\nfunction caml_sys_const_backend_type () {\n return [0, caml_string_of_jsbytes(\"js_of_ocaml\")];\n}\n\n//Provides: os_type\nvar os_type = (globalThis.process &&\n globalThis.process.platform &&\n globalThis.process.platform == \"win32\") ? \"Cygwin\" : \"Unix\";\n\n\n//Provides: caml_sys_get_config const\n//Requires: caml_string_of_jsbytes, os_type\nfunction caml_sys_get_config () {\n return [0, caml_string_of_jsbytes(os_type), 32, 0];\n}\n\n//Provides: caml_sys_isatty\nfunction caml_sys_isatty(_chan) {\n return 0;\n}\n\n//Provides: caml_runtime_variant\n//Requires: caml_string_of_jsbytes\nfunction caml_runtime_variant(_unit) {\n return caml_string_of_jsbytes(\"\");\n}\n//Provides: caml_runtime_parameters\n//Requires: caml_string_of_jsbytes\nfunction caml_runtime_parameters(_unit) {\n return caml_string_of_jsbytes(\"\");\n}\n\n//Provides: caml_install_signal_handler const\nfunction caml_install_signal_handler(){return 0}\n\n//Provides: unix_inet_addr_of_string\nfunction unix_inet_addr_of_string () {return 0;}\n\n\n\n//Provides: caml_runtime_warnings\nvar caml_runtime_warnings = 0;\n\n//Provides: caml_ml_enable_runtime_warnings\n//Requires: caml_runtime_warnings\nfunction caml_ml_enable_runtime_warnings (bool) {\n caml_runtime_warnings = bool;\n return 0;\n}\n\n//Provides: caml_ml_runtime_warnings_enabled\n//Requires: caml_runtime_warnings\nfunction caml_ml_runtime_warnings_enabled (_unit) {\n return caml_runtime_warnings;\n}\n\n\n//Provides: caml_spacetime_enabled const (const)\nfunction caml_spacetime_enabled(_unit) {\n return 0;\n}\n\n//Provides: caml_sys_const_naked_pointers_checked const (const)\nfunction caml_sys_const_naked_pointers_checked(_unit) {\n return 0;\n}\n\n//Provides: caml_register_channel_for_spacetime const (const)\nfunction caml_register_channel_for_spacetime(_channel) {\n return 0;\n}\n\n//Provides: caml_spacetime_only_works_for_native_code\n//Requires: caml_failwith\nfunction caml_spacetime_only_works_for_native_code() {\n caml_failwith(\"Spacetime profiling only works for native code\");\n}\n\n//Always\n//Requires: caml_fatal_uncaught_exception\nfunction caml_setup_uncaught_exception_handler() {\n var g = globalThis;\n if(g.process && g.process.on) {\n g.process.on('uncaughtException', function (err, origin) {\n caml_fatal_uncaught_exception(err);\n g.process.exit (2);\n })\n }\n else if(g.addEventListener){\n g.addEventListener('error', function(event){\n if(event.error){\n caml_fatal_uncaught_exception(event.error);\n }\n });\n }\n}\ncaml_setup_uncaught_exception_handler();\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n//Provides: MlFakeDevice\n//Requires: MlFakeFile, caml_create_bytes\n//Requires: caml_raise_sys_error, caml_raise_no_such_file\n//Requires: caml_string_of_jsbytes, caml_string_of_jsstring\n//Requires: caml_bytes_of_array, caml_bytes_of_string, caml_bytes_of_jsbytes\n//Requires: caml_is_ml_bytes, caml_is_ml_string\n//Requires: caml_named_value, caml_raise_with_args, caml_named_values\n//Requires: make_unix_err_args\nfunction MlFakeDevice (root, f) {\n this.content={};\n this.root = root;\n this.lookupFun = f;\n}\nMlFakeDevice.prototype.nm = function(name) {\n return (this.root + name);\n}\nMlFakeDevice.prototype.create_dir_if_needed = function(name) {\n var comp = name.split(\"/\");\n var res = \"\";\n for(var i = 0; i < comp.length - 1; i++){\n res += comp[i] + \"/\";\n if(this.content[res]) continue;\n this.content[res] = Symbol(\"directory\");\n }\n}\nMlFakeDevice.prototype.slash = function(name){\n return /\\/$/.test(name)?name:(name + \"/\");\n}\nMlFakeDevice.prototype.lookup = function(name) {\n if(!this.content[name] && this.lookupFun) {\n var res = this.lookupFun(caml_string_of_jsbytes(this.root), caml_string_of_jsbytes(name));\n if(res !== 0) {\n this.create_dir_if_needed(name);\n this.content[name]=new MlFakeFile(caml_bytes_of_string(res[1]));\n }\n }\n}\nMlFakeDevice.prototype.exists = function(name) {\n // The root of the device exists\n if(name == \"\") return 1;\n // Check if a directory exists\n var name_slash = this.slash(name);\n if(this.content[name_slash]) return 1;\n // Check if a file exists\n this.lookup(name);\n return this.content[name]?1:0;\n}\nMlFakeDevice.prototype.mkdir = function(name,mode, raise_unix) {\n var unix_error = raise_unix && caml_named_value('Unix.Unix_error');\n if(this.exists(name)) {\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"EEXIST\", \"mkdir\", this.nm(name)));\n }\n else {\n caml_raise_sys_error(name + \": File exists\");\n }\n }\n var parent = /^(.*)\\/[^/]+/.exec(name);\n parent = (parent && parent[1]) || '';\n if(!this.exists(parent)){\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"ENOENT\", \"mkdir\", this.nm(parent)));\n }\n else {\n caml_raise_sys_error(parent + \": No such file or directory\");\n }\n }\n if(!this.is_dir(parent)){\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"ENOTDIR\", \"mkdir\", this.nm(parent)));\n }\n else {\n caml_raise_sys_error(parent + \": Not a directory\");\n }\n }\n this.create_dir_if_needed(this.slash(name));\n}\nMlFakeDevice.prototype.rmdir = function(name, raise_unix) {\n var unix_error = raise_unix && caml_named_value('Unix.Unix_error');\n var name_slash = (name == \"\")?\"\":(this.slash(name));\n var r = new RegExp(\"^\" + name_slash + \"([^/]+)\");\n if(!this.exists(name)) {\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"ENOENT\", \"rmdir\", this.nm(name)));\n }\n else {\n caml_raise_sys_error(name + \": No such file or directory\");\n }\n }\n if(!this.is_dir(name)) {\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"ENOTDIR\", \"rmdir\", this.nm(name)));\n }\n else {\n caml_raise_sys_error(name + \": Not a directory\");\n }\n }\n for(var n in this.content) {\n if(n.match(r)) {\n if (unix_error) {\n caml_raise_with_args(unix_error, make_unix_err_args(\"ENOTEMPTY\", \"rmdir\", this.nm(name)));\n } else {\n caml_raise_sys_error(this.nm(name) + \": Directory not empty\");\n }\n }\n }\n delete this.content[name_slash];\n}\nMlFakeDevice.prototype.readdir = function(name) {\n var name_slash = (name == \"\")?\"\":(this.slash(name));\n if(!this.exists(name)) {\n caml_raise_sys_error(name + \": No such file or directory\");\n }\n if(!this.is_dir(name)) {\n caml_raise_sys_error(name + \": Not a directory\");\n }\n var r = new RegExp(\"^\" + name_slash + \"([^/]+)\");\n var seen = {}\n var a = [];\n for(var n in this.content) {\n var m = n.match(r);\n if(m && !seen[m[1]]) {seen[m[1]] = true; a.push(m[1])}\n }\n return a;\n}\nMlFakeDevice.prototype.is_dir = function(name) {\n if(name == \"\") return true;\n var name_slash = this.slash(name);\n return this.content[name_slash]?1:0;\n}\nMlFakeDevice.prototype.unlink = function(name) {\n var ok = this.content[name]?true:false;\n delete this.content[name];\n return ok;\n}\nMlFakeDevice.prototype.open = function(name, f) {\n if(f.rdonly && f.wronly)\n caml_raise_sys_error(this.nm(name) + \" : flags Open_rdonly and Open_wronly are not compatible\");\n if(f.text && f.binary)\n caml_raise_sys_error(this.nm(name) + \" : flags Open_text and Open_binary are not compatible\");\n this.lookup(name);\n if (this.content[name]) {\n if (this.is_dir(name)) caml_raise_sys_error(this.nm(name) + \" : is a directory\");\n if (f.create && f.excl) caml_raise_sys_error(this.nm(name) + \" : file already exists\");\n var file = this.content[name];\n if(f.truncate) file.truncate();\n return file;\n } else if (f.create) {\n this.create_dir_if_needed(name);\n this.content[name] = new MlFakeFile(caml_create_bytes(0));\n return this.content[name];\n } else {\n caml_raise_no_such_file (this.nm(name));\n }\n}\n\nMlFakeDevice.prototype.register= function (name,content){\n var file;\n if(this.content[name]) caml_raise_sys_error(this.nm(name) + \" : file already exists\");\n if(caml_is_ml_bytes(content))\n file = new MlFakeFile(content);\n if(caml_is_ml_string(content))\n file = new MlFakeFile(caml_bytes_of_string(content));\n else if(content instanceof Array)\n file = new MlFakeFile(caml_bytes_of_array(content));\n else if(typeof content === \"string\")\n file = new MlFakeFile(caml_bytes_of_jsbytes(content));\n else if(content.toString) {\n var bytes = caml_bytes_of_string(caml_string_of_jsstring(content.toString()));\n file = new MlFakeFile(bytes);\n }\n if(file){\n this.create_dir_if_needed(name);\n this.content[name] = file;\n }\n else caml_raise_sys_error(this.nm(name) + \" : registering file with invalid content type\");\n}\n\nMlFakeDevice.prototype.constructor = MlFakeDevice\n\n//Provides: MlFakeFile\n//Requires: MlFile\n//Requires: caml_create_bytes, caml_ml_bytes_length, caml_blit_bytes, caml_blit_string\n//Requires: caml_bytes_get\nfunction MlFakeFile(content){\n this.data = content;\n}\nMlFakeFile.prototype = new MlFile ();\nMlFakeFile.prototype.truncate = function(len){\n var old = this.data;\n this.data = caml_create_bytes(len|0);\n caml_blit_bytes(old, 0, this.data, 0, len);\n}\nMlFakeFile.prototype.length = function () {\n return caml_ml_bytes_length(this.data);\n}\nMlFakeFile.prototype.write = function(offset,buf,pos,len){\n var clen = this.length();\n if(offset + len >= clen) {\n var new_str = caml_create_bytes(offset + len);\n var old_data = this.data;\n this.data = new_str;\n caml_blit_bytes(old_data, 0, this.data, 0, clen);\n }\n caml_blit_string(buf, pos, this.data, offset, len);\n return 0\n}\nMlFakeFile.prototype.read = function(offset,buf,pos,len){\n var clen = this.length();\n caml_blit_bytes(this.data, offset, buf, pos, len);\n return 0\n}\nMlFakeFile.prototype.read_one = function(offset){\n return caml_bytes_get(this.data, offset);\n}\nMlFakeFile.prototype.close = function(){\n\n}\nMlFakeFile.prototype.constructor = MlFakeFile\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2014 Jérôme Vouillon, Hugo Heuzard\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n///////////// Io\n\n//Provides: caml_sys_close\n//Requires: caml_global_data\nfunction caml_sys_close(fd) {\n delete caml_global_data.fds[fd];\n return 0;\n}\n\n//Provides: caml_std_output\n//Requires: caml_string_of_jsbytes, caml_ml_string_length, caml_ml_channels\nfunction caml_std_output(chanid,s){\n var chan = caml_ml_channels[chanid];\n var str = caml_string_of_jsbytes(s);\n var slen = caml_ml_string_length(str);\n chan.file.write(chan.offset, str, 0, slen);\n chan.offset += slen;\n return 0;\n}\n\n//Provides: caml_sys_open\n//Requires: caml_raise_sys_error, caml_global_data\n//Requires: caml_create_bytes,MlFakeFile\n//Requires: js_print_stderr, js_print_stdout\n//Requires: caml_std_output\n//Requires: resolve_fs_device\n//Requires: caml_jsbytes_of_string\nfunction caml_sys_open_internal(idx,output,file,flags) {\n if(caml_global_data.fds === undefined) caml_global_data.fds = new Array();\n flags=flags?flags:{};\n var info = {};\n info.file = file;\n info.offset = flags.append?file.length():0;\n info.flags = flags;\n info.output = output;\n caml_global_data.fds[idx] = info;\n if(!caml_global_data.fd_last_idx || idx > caml_global_data.fd_last_idx)\n caml_global_data.fd_last_idx = idx;\n return idx;\n}\nfunction caml_sys_open (name, flags, _perms) {\n var f = {};\n while(flags){\n switch(flags[1]){\n case 0: f.rdonly = 1;break;\n case 1: f.wronly = 1;break;\n case 2: f.append = 1;break;\n case 3: f.create = 1;break;\n case 4: f.truncate = 1;break;\n case 5: f.excl = 1; break;\n case 6: f.binary = 1;break;\n case 7: f.text = 1;break;\n case 8: f.nonblock = 1;break;\n }\n flags=flags[2];\n }\n if(f.rdonly && f.wronly)\n caml_raise_sys_error(caml_jsbytes_of_string(name) + \" : flags Open_rdonly and Open_wronly are not compatible\");\n if(f.text && f.binary)\n caml_raise_sys_error(caml_jsbytes_of_string(name) + \" : flags Open_text and Open_binary are not compatible\");\n var root = resolve_fs_device(name);\n var file = root.device.open(root.rest,f);\n var idx = caml_global_data.fd_last_idx?caml_global_data.fd_last_idx:0;\n return caml_sys_open_internal (idx+1,caml_std_output,file,f);\n}\ncaml_sys_open_internal(0,caml_std_output, new MlFakeFile(caml_create_bytes(0))); //stdin\ncaml_sys_open_internal(1,js_print_stdout, new MlFakeFile(caml_create_bytes(0))); //stdout\ncaml_sys_open_internal(2,js_print_stderr, new MlFakeFile(caml_create_bytes(0))); //stderr\n\n\n// ocaml Channels\n\n//Provides: caml_ml_set_channel_name\nfunction caml_ml_set_channel_name() {\n return 0\n}\n\n//Provides: caml_ml_channels\nvar caml_ml_channels = new Array();\n\n//Provides: caml_ml_out_channels_list\n//Requires: caml_ml_channels\nfunction caml_ml_out_channels_list () {\n var l = 0;\n for(var c = 0; c < caml_ml_channels.length; c++){\n if(caml_ml_channels[c] && caml_ml_channels[c].opened && caml_ml_channels[c].out)\n l=[0,caml_ml_channels[c].fd,l];\n }\n return l;\n}\n\n\n//Provides: caml_ml_open_descriptor_out\n//Requires: caml_ml_channels, caml_global_data\n//Requires: caml_raise_sys_error\nfunction caml_ml_open_descriptor_out (fd) {\n var data = caml_global_data.fds[fd];\n if(data.flags.rdonly) caml_raise_sys_error(\"fd \"+ fd + \" is readonly\");\n var channel = {\n file:data.file,\n offset:data.offset,\n fd:fd,\n opened:true,\n out:true,\n buffer:\"\"\n };\n caml_ml_channels[channel.fd]=channel;\n return channel.fd;\n}\n\n//Provides: caml_ml_open_descriptor_in\n//Requires: caml_global_data,caml_sys_open,caml_raise_sys_error, caml_ml_channels\n//Requires: fs_node_supported, caml_string_of_jsstring\nfunction caml_ml_open_descriptor_in (fd) {\n var data = caml_global_data.fds[fd];\n if(data.flags.wronly) caml_raise_sys_error(\"fd \"+ fd + \" is writeonly\");\n var refill = null;\n if(fd == 0 && fs_node_supported()){\n var fs = require('fs');\n refill = function () {\n return caml_string_of_jsstring(fs.readFileSync(0, 'utf8'))};\n }\n var channel = {\n file:data.file,\n offset:data.offset,\n fd:fd,\n opened:true,\n out: false,\n refill:refill\n };\n caml_ml_channels[channel.fd]=channel;\n return channel.fd;\n}\n\n\n//Provides: caml_channel_descriptor\n//Requires: caml_global_data, caml_ml_channels\nfunction caml_channel_descriptor(chanid){\n var chan = caml_ml_channels[chanid];\n return chan.fd;\n}\n\n//Provides: win_filedescr_of_channel\n//Requires: caml_channel_descriptor\nvar win_filedescr_of_channel = caml_channel_descriptor\n\n//Provides: caml_ml_set_binary_mode\n//Requires: caml_global_data, caml_ml_channels\nfunction caml_ml_set_binary_mode(chanid,mode){\n var chan = caml_ml_channels[chanid];\n var data = caml_global_data.fds[chan.fd];\n data.flags.text = !mode\n data.flags.binary = mode\n return 0;\n}\n\n//Input from in_channel\n\n//Provides: caml_ml_close_channel\n//Requires: caml_ml_flush, caml_ml_channels\n//Requires: caml_sys_close\nfunction caml_ml_close_channel (chanid) {\n var chan = caml_ml_channels[chanid];\n caml_ml_flush(chanid);\n chan.opened = false;\n chan.file.close();\n caml_sys_close(chan.fd)\n return 0;\n}\n\n//Provides: caml_ml_channel_size\n//Requires: caml_ml_channels\nfunction caml_ml_channel_size(chanid) {\n var chan = caml_ml_channels[chanid];\n return chan.file.length();\n}\n\n//Provides: caml_ml_channel_size_64\n//Requires: caml_int64_of_float,caml_ml_channels\nfunction caml_ml_channel_size_64(chanid) {\n var chan = caml_ml_channels[chanid];\n return caml_int64_of_float(chan.file.length ());\n}\n\n//Provides: caml_ml_set_channel_output\n//Requires: caml_ml_channels, caml_global_data\nfunction caml_ml_set_channel_output(chanid,f) {\n var chan = caml_ml_channels[chanid];\n caml_global_data.fds[chan.fd].output = f;\n return 0;\n}\n\n//Provides: caml_ml_set_channel_refill\n//Requires: caml_ml_channels, caml_global_data\nfunction caml_ml_set_channel_refill(chanid,f) {\n caml_ml_channels[chanid].refill = f;\n return 0;\n}\n\n//Provides: caml_ml_refill_input\n//Requires: caml_ml_string_length\nfunction caml_ml_refill_input (chan) {\n var str = chan.refill();\n var str_len = caml_ml_string_length(str);\n if (str_len == 0) chan.refill = null;\n chan.file.write(chan.file.length(), str, 0, str_len);\n return str_len;\n}\n\n//Provides: caml_ml_may_refill_input\n//Requires: caml_ml_refill_input, caml_ml_channels\nfunction caml_ml_may_refill_input (chanid) {\n var chan = caml_ml_channels[chanid];\n if (chan.refill == null) return;\n if (chan.file.length() != chan.offset) return;\n caml_ml_refill_input (chan);\n}\n\n//Provides: caml_ml_input\n//Requires: caml_ml_refill_input, caml_ml_channels\nfunction caml_ml_input (chanid, s, i, l) {\n var chan = caml_ml_channels[chanid];\n var l2 = chan.file.length() - chan.offset;\n if (l2 == 0 && chan.refill != null) l2 = caml_ml_refill_input(chan);\n if (l2 < l) l = l2;\n chan.file.read(chan.offset, s, i, l);\n chan.offset += l;\n return l;\n}\n\n//Provides: caml_input_value\n//Requires: caml_marshal_data_size, caml_input_value_from_bytes, caml_create_bytes, caml_ml_channels\nfunction caml_input_value (chanid) {\n var chan = caml_ml_channels[chanid];\n\n var buf = caml_create_bytes(8);\n chan.file.read(chan.offset,buf,0,8);\n\n // Header is 20 bytes\n var len = caml_marshal_data_size (buf, 0) + 20;\n\n var buf = caml_create_bytes(len);\n chan.file.read(chan.offset,buf,0,len);\n\n var offset = [0];\n var res = caml_input_value_from_bytes(buf, offset);\n chan.offset = chan.offset + offset[0];\n return res;\n}\n\n//Provides: caml_ml_input_char\n//Requires: caml_raise_end_of_file, caml_array_bound_error\n//Requires: caml_ml_may_refill_input, caml_ml_channels\nfunction caml_ml_input_char (chanid) {\n var chan = caml_ml_channels[chanid];\n caml_ml_may_refill_input(chanid);\n if (chan.offset >= chan.file.length())\n caml_raise_end_of_file();\n var res = chan.file.read_one(chan.offset);\n chan.offset++;\n return res;\n}\n\n//Provides: caml_ml_input_int\n//Requires: caml_raise_end_of_file\n//Requires: caml_ml_refill_input, caml_ml_channels\nfunction caml_ml_input_int (chanid) {\n var chan = caml_ml_channels[chanid];\n var file = chan.file;\n while ((chan.offset + 3) >= file.length()) {\n var l = caml_ml_refill_input(chan);\n if (l == 0) caml_raise_end_of_file();\n }\n var o = chan.offset;\n var r =(file.read_one(o ) << 24)\n | (file.read_one(o+1) << 16)\n | (file.read_one(o+2) << 8)\n | (file.read_one(o+3));\n chan.offset+=4;\n return r;\n}\n\n//Provides: caml_ml_seek_in\n//Requires: caml_raise_sys_error, caml_ml_channels\nfunction caml_ml_seek_in(chanid,pos){\n var chan = caml_ml_channels[chanid];\n if (chan.refill != null) caml_raise_sys_error(\"Illegal seek\");\n chan.offset = pos;\n return 0;\n}\n\n//Provides: caml_ml_seek_in_64\n//Requires: caml_int64_to_float, caml_raise_sys_error, caml_ml_channels\nfunction caml_ml_seek_in_64(chanid,pos){\n var chan = caml_ml_channels[chanid];\n if (chan.refill != null) caml_raise_sys_error(\"Illegal seek\");\n chan.offset = caml_int64_to_float(pos);\n return 0;\n}\n\n//Provides: caml_ml_pos_in\n//Requires: caml_ml_channels\nfunction caml_ml_pos_in(chanid) {return caml_ml_channels[chanid].offset}\n\n//Provides: caml_ml_pos_in_64\n//Requires: caml_int64_of_float, caml_ml_channels\nfunction caml_ml_pos_in_64(chanid) {return caml_int64_of_float(caml_ml_channels[chanid].offset)}\n\n//Provides: caml_ml_input_scan_line\n//Requires: caml_array_bound_error\n//Requires: caml_ml_may_refill_input, caml_ml_channels\nfunction caml_ml_input_scan_line(chanid){\n var chan = caml_ml_channels[chanid];\n caml_ml_may_refill_input(chanid);\n var p = chan.offset;\n var len = chan.file.length();\n if(p >= len) { return 0;}\n while(true) {\n if(p >= len) return - (p - chan.offset);\n if(chan.file.read_one(p) == 10) return p - chan.offset + 1;\n p++;\n }\n}\n\n//Provides: caml_ml_flush\n//Requires: caml_raise_sys_error, caml_global_data, caml_ml_channels\nfunction caml_ml_flush (chanid) {\n var chan = caml_ml_channels[chanid];\n if(! chan.opened) caml_raise_sys_error(\"Cannot flush a closed channel\");\n if(!chan.buffer || chan.buffer == \"\") return 0;\n if(chan.fd\n && caml_global_data.fds[chan.fd]\n && caml_global_data.fds[chan.fd].output) {\n var output = caml_global_data.fds[chan.fd].output;\n switch(output.length){\n case 2: output(chanid,chan.buffer);break;\n default: output(chan.buffer)\n };\n }\n chan.buffer = \"\";\n return 0;\n}\n\n//output to out_channel\n\n//Provides: caml_ml_output_bytes\n//Requires: caml_ml_flush,caml_ml_bytes_length\n//Requires: caml_create_bytes, caml_blit_bytes, caml_raise_sys_error, caml_ml_channels, caml_string_of_bytes\n//Requires: caml_jsbytes_of_string\nfunction caml_ml_output_bytes(chanid,buffer,offset,len) {\n var chan = caml_ml_channels[chanid];\n if(! chan.opened) caml_raise_sys_error(\"Cannot output to a closed channel\");\n var bytes;\n if(offset == 0 && caml_ml_bytes_length(buffer) == len)\n bytes = buffer;\n else {\n bytes = caml_create_bytes(len);\n caml_blit_bytes(buffer,offset,bytes,0,len);\n }\n var string = caml_string_of_bytes(bytes);\n var jsstring = caml_jsbytes_of_string(string);\n var id = jsstring.lastIndexOf(\"\\n\");\n if(id < 0)\n chan.buffer+=jsstring;\n else {\n chan.buffer+=jsstring.substr(0,id+1);\n caml_ml_flush (chanid);\n chan.buffer += jsstring.substr(id+1);\n }\n return 0;\n}\n\n//Provides: caml_ml_output\n//Requires: caml_ml_output_bytes, caml_bytes_of_string\nfunction caml_ml_output(chanid,buffer,offset,len){\n return caml_ml_output_bytes(chanid,caml_bytes_of_string(buffer),offset,len);\n}\n\n//Provides: caml_ml_output_char\n//Requires: caml_ml_output\n//Requires: caml_string_of_jsbytes\nfunction caml_ml_output_char (chanid,c) {\n var s = caml_string_of_jsbytes(String.fromCharCode(c));\n caml_ml_output(chanid,s,0,1);\n return 0;\n}\n\n//Provides: caml_output_value\n//Requires: caml_output_value_to_string, caml_ml_output,caml_ml_string_length\nfunction caml_output_value (chanid,v,flags) {\n var s = caml_output_value_to_string(v, flags);\n caml_ml_output(chanid,s,0,caml_ml_string_length(s));\n return 0;\n}\n\n\n//Provides: caml_ml_seek_out\n//Requires: caml_ml_channels, caml_ml_flush\nfunction caml_ml_seek_out(chanid,pos){\n caml_ml_flush(chanid);\n caml_ml_channels[chanid].offset = pos;\n return 0;\n}\n\n//Provides: caml_ml_seek_out_64\n//Requires: caml_int64_to_float, caml_ml_channels, caml_ml_flush\nfunction caml_ml_seek_out_64(chanid,pos){\n caml_ml_flush(chanid);\n caml_ml_channels[chanid].offset = caml_int64_to_float(pos);\n return 0;\n}\n\n//Provides: caml_ml_pos_out\n//Requires: caml_ml_channels, caml_ml_flush\nfunction caml_ml_pos_out(chanid) {\n caml_ml_flush(chanid);\n return caml_ml_channels[chanid].offset\n}\n\n//Provides: caml_ml_pos_out_64\n//Requires: caml_int64_of_float, caml_ml_channels, caml_ml_flush\nfunction caml_ml_pos_out_64(chanid) {\n caml_ml_flush(chanid);\n return caml_int64_of_float (caml_ml_channels[chanid].offset);\n}\n\n//Provides: caml_ml_output_int\n//Requires: caml_ml_output\n//Requires: caml_string_of_array\nfunction caml_ml_output_int (chanid,i) {\n var arr = [(i>>24) & 0xFF,(i>>16) & 0xFF,(i>>8) & 0xFF,i & 0xFF ];\n var s = caml_string_of_array(arr);\n caml_ml_output(chanid,s,0,4);\n return 0\n}\n\n//Provides: caml_ml_is_buffered\nfunction caml_ml_is_buffered(c) { return 1 }\n\n//Provides: caml_ml_set_buffered\nfunction caml_ml_set_buffered(c,v) { return 0 }\n","/***********************************************************************/\n/* */\n/* Objective Caml */\n/* */\n/* Xavier Leroy, projet Cristal, INRIA Rocquencourt */\n/* */\n/* Copyright 1996 Institut National de Recherche en Informatique et */\n/* en Automatique. All rights reserved. This file is distributed */\n/* under the terms of the GNU Lesser General Public License, with */\n/* the special exception on linking described in file ../LICENSE. */\n/* */\n/***********************************************************************/\n\n/* $Id: lexing.c 6045 2004-01-01 16:42:43Z doligez $ */\n\n/* The table-driven automaton for lexers generated by camllex. */\n\n//Provides: caml_lex_array\n//Requires: caml_jsbytes_of_string\nfunction caml_lex_array(s) {\n s = caml_jsbytes_of_string(s);\n var l = s.length / 2;\n var a = new Array(l);\n for (var i = 0; i < l; i++)\n a[i] = (s.charCodeAt(2 * i) | (s.charCodeAt(2 * i + 1) << 8)) << 16 >> 16;\n return a;\n}\n\n//Provides: caml_lex_engine\n//Requires: caml_failwith, caml_lex_array, caml_array_of_bytes\nfunction caml_lex_engine(tbl, start_state, lexbuf) {\n var lex_buffer = 2;\n var lex_buffer_len = 3;\n var lex_start_pos = 5;\n var lex_curr_pos = 6;\n var lex_last_pos = 7;\n var lex_last_action = 8;\n var lex_eof_reached = 9;\n var lex_base = 1;\n var lex_backtrk = 2;\n var lex_default = 3;\n var lex_trans = 4;\n var lex_check = 5;\n\n if (!tbl.lex_default) {\n tbl.lex_base = caml_lex_array (tbl[lex_base]);\n tbl.lex_backtrk = caml_lex_array (tbl[lex_backtrk]);\n tbl.lex_check = caml_lex_array (tbl[lex_check]);\n tbl.lex_trans = caml_lex_array (tbl[lex_trans]);\n tbl.lex_default = caml_lex_array (tbl[lex_default]);\n }\n\n var c, state = start_state;\n\n var buffer = caml_array_of_bytes(lexbuf[lex_buffer]);\n\n if (state >= 0) {\n /* First entry */\n lexbuf[lex_last_pos] = lexbuf[lex_start_pos] = lexbuf[lex_curr_pos];\n lexbuf[lex_last_action] = -1;\n } else {\n /* Reentry after refill */\n state = -state - 1;\n }\n for(;;) {\n /* Lookup base address or action number for current state */\n var base = tbl.lex_base[state];\n if (base < 0) return -base-1;\n /* See if it's a backtrack point */\n var backtrk = tbl.lex_backtrk[state];\n if (backtrk >= 0) {\n lexbuf[lex_last_pos] = lexbuf[lex_curr_pos];\n lexbuf[lex_last_action] = backtrk;\n }\n /* See if we need a refill */\n if (lexbuf[lex_curr_pos] >= lexbuf[lex_buffer_len]){\n if (lexbuf[lex_eof_reached] == 0)\n return -state - 1;\n else\n c = 256;\n }else{\n /* Read next input char */\n c = buffer[lexbuf[lex_curr_pos]];\n lexbuf[lex_curr_pos] ++;\n }\n /* Determine next state */\n if (tbl.lex_check[base + c] == state)\n state = tbl.lex_trans[base + c];\n else\n state = tbl.lex_default[state];\n /* If no transition on this char, return to last backtrack point */\n if (state < 0) {\n lexbuf[lex_curr_pos] = lexbuf[lex_last_pos];\n if (lexbuf[lex_last_action] == -1)\n caml_failwith(\"lexing: empty token\");\n else\n return lexbuf[lex_last_action];\n }else{\n /* Erase the EOF condition only if the EOF pseudo-character was\n consumed by the automaton (i.e. there was no backtrack above)\n */\n if (c == 256) lexbuf[lex_eof_reached] = 0;\n }\n }\n}\n\n/***********************************************/\n/* New lexer engine, with memory of positions */\n/***********************************************/\n\n//Provides: caml_new_lex_engine\n//Requires: caml_failwith, caml_lex_array\n//Requires: caml_jsbytes_of_string, caml_array_of_bytes\nfunction caml_lex_run_mem(s, i, mem, curr_pos) {\n for (;;) {\n var dst = s.charCodeAt(i); i++;\n if (dst == 0xff) return;\n var src = s.charCodeAt(i); i++;\n if (src == 0xff)\n mem [dst + 1] = curr_pos;\n else\n mem [dst + 1] = mem [src + 1];\n }\n}\n\nfunction caml_lex_run_tag(s, i, mem) {\n for (;;) {\n var dst = s.charCodeAt(i); i++;\n if (dst == 0xff) return ;\n var src = s.charCodeAt(i); i++;\n if (src == 0xff)\n mem [dst + 1] = -1;\n else\n mem [dst + 1] = mem [src + 1];\n }\n}\n\nfunction caml_new_lex_engine(tbl, start_state, lexbuf) {\n var lex_buffer = 2;\n var lex_buffer_len = 3;\n var lex_start_pos = 5;\n var lex_curr_pos = 6;\n var lex_last_pos = 7;\n var lex_last_action = 8;\n var lex_eof_reached = 9;\n var lex_mem = 10;\n var lex_base = 1;\n var lex_backtrk = 2;\n var lex_default = 3;\n var lex_trans = 4;\n var lex_check = 5;\n var lex_base_code = 6;\n var lex_backtrk_code = 7;\n var lex_default_code = 8;\n var lex_trans_code = 9;\n var lex_check_code = 10;\n var lex_code = 11;\n\n if (!tbl.lex_default) {\n tbl.lex_base = caml_lex_array (tbl[lex_base]);\n tbl.lex_backtrk = caml_lex_array (tbl[lex_backtrk]);\n tbl.lex_check = caml_lex_array (tbl[lex_check]);\n tbl.lex_trans = caml_lex_array (tbl[lex_trans]);\n tbl.lex_default = caml_lex_array (tbl[lex_default]);\n }\n if (!tbl.lex_default_code) {\n tbl.lex_base_code = caml_lex_array (tbl[lex_base_code]);\n tbl.lex_backtrk_code = caml_lex_array (tbl[lex_backtrk_code]);\n tbl.lex_check_code = caml_lex_array (tbl[lex_check_code]);\n tbl.lex_trans_code = caml_lex_array (tbl[lex_trans_code]);\n tbl.lex_default_code = caml_lex_array (tbl[lex_default_code]);\n }\n if (tbl.lex_code == null) tbl.lex_code = caml_jsbytes_of_string(tbl[lex_code]);\n\n var c, state = start_state;\n\n var buffer = caml_array_of_bytes(lexbuf[lex_buffer]);\n\n if (state >= 0) {\n /* First entry */\n lexbuf[lex_last_pos] = lexbuf[lex_start_pos] = lexbuf[lex_curr_pos];\n lexbuf[lex_last_action] = -1;\n } else {\n /* Reentry after refill */\n state = -state - 1;\n }\n for(;;) {\n /* Lookup base address or action number for current state */\n var base = tbl.lex_base[state];\n if (base < 0) {\n var pc_off = tbl.lex_base_code[state];\n caml_lex_run_tag(tbl.lex_code, pc_off, lexbuf[lex_mem]);\n return -base-1;\n }\n /* See if it's a backtrack point */\n var backtrk = tbl.lex_backtrk[state];\n if (backtrk >= 0) {\n var pc_off = tbl.lex_backtrk_code[state];\n caml_lex_run_tag(tbl.lex_code, pc_off, lexbuf[lex_mem]);\n lexbuf[lex_last_pos] = lexbuf[lex_curr_pos];\n lexbuf[lex_last_action] = backtrk;\n }\n /* See if we need a refill */\n if (lexbuf[lex_curr_pos] >= lexbuf[lex_buffer_len]){\n if (lexbuf[lex_eof_reached] == 0)\n return -state - 1;\n else\n c = 256;\n }else{\n /* Read next input char */\n c = buffer[lexbuf[lex_curr_pos]];\n lexbuf[lex_curr_pos] ++;\n }\n /* Determine next state */\n var pstate = state ;\n if (tbl.lex_check[base + c] == state)\n state = tbl.lex_trans[base + c];\n else\n state = tbl.lex_default[state];\n /* If no transition on this char, return to last backtrack point */\n if (state < 0) {\n lexbuf[lex_curr_pos] = lexbuf[lex_last_pos];\n if (lexbuf[lex_last_action] == -1)\n caml_failwith(\"lexing: empty token\");\n else\n return lexbuf[lex_last_action];\n }else{\n /* If some transition, get and perform memory moves */\n var base_code = tbl.lex_base_code[pstate], pc_off;\n if (tbl.lex_check_code[base_code + c] == pstate)\n pc_off = tbl.lex_trans_code[base_code + c];\n else\n pc_off = tbl.lex_default_code[pstate];\n if (pc_off > 0)\n caml_lex_run_mem\n (tbl.lex_code, pc_off, lexbuf[lex_mem], lexbuf[lex_curr_pos]);\n /* Erase the EOF condition only if the EOF pseudo-character was\n consumed by the automaton (i.e. there was no backtrack above)\n */\n if (c == 256) lexbuf[lex_eof_reached] = 0;\n }\n }\n}\n","// Js_of_ocaml runtime support\n// http://www.ocsigen.org/js_of_ocaml/\n// Copyright (C) 2010 Jérôme Vouillon\n// Laboratoire PPS - CNRS Université Paris Diderot\n//\n// This program is free software; you can redistribute it and/or modify\n// it under the terms of the GNU Lesser General Public License as published by\n// the Free Software Foundation, with linking exception;\n// either version 2.1 of the License, or (at your option) any later version.\n//\n// This program is distributed in the hope that it will be useful,\n// but WITHOUT ANY WARRANTY; without even the implied warranty of\n// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n// GNU Lesser General Public License for more details.\n//\n// You should have received a copy of the GNU Lesser General Public License\n// along with this program; if not, write to the Free Software\n// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n\n\n//Provides: caml_md5_chan\n//Requires: caml_md5_string, caml_string_of_array,caml_ml_channels\n//Requires: caml_raise_end_of_file, caml_create_bytes, caml_string_of_bytes\nfunction caml_md5_chan(chanid,len){\n var chan = caml_ml_channels[chanid];\n var chan_len = chan.file.length();\n if(len<0) len = chan_len - chan.offset;\n if(chan.offset + len > chan_len) caml_raise_end_of_file();\n var buf = caml_create_bytes(len);\n chan.file.read(chan.offset,buf,0,len);\n return caml_md5_string(caml_string_of_bytes(buf),0,len);\n}\n\n//Provides: caml_md5_string\n//Requires: caml_bytes_of_string, caml_md5_bytes\nfunction caml_md5_string(s, ofs, len) {\n return caml_md5_bytes(caml_bytes_of_string(s),ofs,len);\n}\n\n//Provides: caml_md5_bytes\n//Requires: caml_string_of_array, caml_ml_bytes_content\nvar caml_md5_bytes = function () {\n function add (x, y) { return (x + y) | 0; }\n function xx(q,a,b,x,s,t) {\n a = add(add(a, q), add(x, t));\n return add((a << s) | (a >>> (32 - s)), b);\n }\n function ff(a,b,c,d,x,s,t) {\n return xx((b & c) | ((~b) & d), a, b, x, s, t);\n }\n function gg(a,b,c,d,x,s,t) {\n return xx((b & d) | (c & (~d)), a, b, x, s, t);\n }\n function hh(a,b,c,d,x,s,t) { return xx(b ^ c ^ d, a, b, x, s, t); }\n function ii(a,b,c,d,x,s,t) { return xx(c ^ (b | (~d)), a, b, x, s, t); }\n\n function md5(buffer, length) {\n var i = length;\n buffer[i >> 2] |= 0x80 << (8 * (i & 3));\n for (i = (i & ~0x3) + 8;(i & 0x3F) < 60 ;i += 4)\n buffer[(i >> 2) - 1] = 0;\n buffer[(i >> 2) -1] = length << 3;\n buffer[i >> 2] = (length >> 29) & 0x1FFFFFFF;\n\n var w = [0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476];\n\n for(i = 0; i < buffer.length; i += 16) {\n var a = w[0], b = w[1], c = w[2], d = w[3];\n\n a = ff(a, b, c, d, buffer[i+ 0], 7, 0xD76AA478);\n d = ff(d, a, b, c, buffer[i+ 1], 12, 0xE8C7B756);\n c = ff(c, d, a, b, buffer[i+ 2], 17, 0x242070DB);\n b = ff(b, c, d, a, buffer[i+ 3], 22, 0xC1BDCEEE);\n a = ff(a, b, c, d, buffer[i+ 4], 7, 0xF57C0FAF);\n d = ff(d, a, b, c, buffer[i+ 5], 12, 0x4787C62A);\n c = ff(c, d, a, b, buffer[i+ 6], 17, 0xA8304613);\n b = ff(b, c, d, a, buffer[i+ 7], 22, 0xFD469501);\n a = ff(a, b, c, d, buffer[i+ 8], 7, 0x698098D8);\n d = ff(d, a, b, c, buffer[i+ 9], 12, 0x8B44F7AF);\n c = ff(c, d, a, b, buffer[i+10], 17, 0xFFFF5BB1);\n b = ff(b, c, d, a, buffer[i+11], 22, 0x895CD7BE);\n a = ff(a, b, c, d, buffer[i+12], 7, 0x6B901122);\n d = ff(d, a, b, c, buffer[i+13], 12, 0xFD987193);\n c = ff(c, d, a, b, buffer[i+14], 17, 0xA679438E);\n b = ff(b, c, d, a, buffer[i+15], 22, 0x49B40821);\n\n a = gg(a, b, c, d, buffer[i+ 1], 5, 0xF61E2562);\n d = gg(d, a, b, c, buffer[i+ 6], 9, 0xC040B340);\n c = gg(c, d, a, b, buffer[i+11], 14, 0x265E5A51);\n b = gg(b, c, d, a, buffer[i+ 0], 20, 0xE9B6C7AA);\n a = gg(a, b, c, d, buffer[i+ 5], 5, 0xD62F105D);\n d = gg(d, a, b, c, buffer[i+10], 9, 0x02441453);\n c = gg(c, d, a, b, buffer[i+15], 14, 0xD8A1E681);\n b = gg(b, c, d, a, buffer[i+ 4], 20, 0xE7D3FBC8);\n a = gg(a, b, c, d, buffer[i+ 9], 5, 0x21E1CDE6);\n d = gg(d, a, b, c, buffer[i+14], 9, 0xC33707D6);\n c = gg(c, d, a, b, buffer[i+ 3], 14, 0xF4D50D87);\n b = gg(b, c, d, a, buffer[i+ 8], 20, 0x455A14ED);\n a = gg(a, b, c, d, buffer[i+13], 5, 0xA9E3E905);\n d = gg(d, a, b, c, buffer[i+ 2], 9, 0xFCEFA3F8);\n c = gg(c, d, a, b, buffer[i+ 7], 14, 0x676F02D9);\n b = gg(b, c, d, a, buffer[i+12], 20, 0x8D2A4C8A);\n\n a = hh(a, b, c, d, buffer[i+ 5], 4, 0xFFFA3942);\n d = hh(d, a, b, c, buffer[i+ 8], 11, 0x8771F681);\n c = hh(c, d, a, b, buffer[i+11], 16, 0x6D9D6122);\n b = hh(b, c, d, a, buffer[i+14], 23, 0xFDE5380C);\n a = hh(a, b, c, d, buffer[i+ 1], 4, 0xA4BEEA44);\n d = hh(d, a, b, c, buffer[i+ 4], 11, 0x4BDECFA9);\n c = hh(c, d, a, b, buffer[i+ 7], 16, 0xF6BB4B60);\n b = hh(b, c, d, a, buffer[i+10], 23, 0xBEBFBC70);\n a = hh(a, b, c, d, buffer[i+13], 4, 0x289B7EC6);\n d = hh(d, a, b, c, buffer[i+ 0], 11, 0xEAA127FA);\n c = hh(c, d, a, b, buffer[i+ 3], 16, 0xD4EF3085);\n b = hh(b, c, d, a, buffer[i+ 6], 23, 0x04881D05);\n a = hh(a, b, c, d, buffer[i+ 9], 4, 0xD9D4D039);\n d = hh(d, a, b, c, buffer[i+12], 11, 0xE6DB99E5);\n c = hh(c, d, a, b, buffer[i+15], 16, 0x1FA27CF8);\n b = hh(b, c, d, a, buffer[i+ 2], 23, 0xC4AC5665);\n\n a = ii(a, b, c, d, buffer[i+ 0], 6, 0xF4292244);\n d = ii(d, a, b, c, buffer[i+ 7], 10, 0x432AFF97);\n c = ii(c, d, a, b, buffer[i+14], 15, 0xAB9423A7);\n b = ii(b, c, d, a, buffer[i+ 5], 21, 0xFC93A039);\n a = ii(a, b, c, d, buffer[i+12], 6, 0x655B59C3);\n d = ii(d, a, b, c, buffer[i+ 3], 10, 0x8F0CCC92);\n c = ii(c, d, a, b, buffer[i+10], 15, 0xFFEFF47D);\n b = ii(b, c, d, a, buffer[i+ 1], 21, 0x85845DD1);\n a = ii(a, b, c, d, buffer[i+ 8], 6, 0x6FA87E4F);\n d = ii(d, a, b, c, buffer[i+15], 10, 0xFE2CE6E0);\n c = ii(c, d, a, b, buffer[i+ 6], 15, 0xA3014314);\n b = ii(b, c, d, a, buffer[i+13], 21, 0x4E0811A1);\n a = ii(a, b, c, d, buffer[i+ 4], 6, 0xF7537E82);\n d = ii(d, a, b, c, buffer[i+11], 10, 0xBD3AF235);\n c = ii(c, d, a, b, buffer[i+ 2], 15, 0x2AD7D2BB);\n b = ii(b, c, d, a, buffer[i+ 9], 21, 0xEB86D391);\n\n w[0] = add(a, w[0]);\n w[1] = add(b, w[1]);\n w[2] = add(c, w[2]);\n w[3] = add(d, w[3]);\n }\n\n var t = new Array(16);\n for (var i = 0; i < 4; i++)\n for (var j = 0; j < 4; j++)\n t[i * 4 + j] = (w[i] >> (8 * j)) & 0xFF;\n return t;\n }\n\n return function (s, ofs, len) {\n // FIX: maybe we should perform the computation by chunk of 64 bytes\n // as in http://www.myersdaily.org/joseph/javascript/md5.js\n var buf = [];\n var content = caml_ml_bytes_content(s);\n if(typeof content === \"string\"){\n var b = content;\n for (var i = 0; i < len; i+=4) {\n var j = i + ofs;\n buf[i>>2] =\n b.charCodeAt(j) | (b.charCodeAt(j+1) << 8) |\n (b.charCodeAt(j+2) << 16) | (b.charCodeAt(j+3) << 24);\n }\n for (; i < len; i++) buf[i>>2] |= b.charCodeAt(i + ofs) << (8 * (i & 3));\n } else { /* ARRAY */\n var a = content;\n for (var i = 0; i < len; i+=4) {\n var j = i + ofs;\n buf[i>>2] = a[j] | (a[j+1] << 8) | (a[j+2] << 16) | (a[j+3] << 24);\n }\n for (; i < len; i++) buf[i>>2] |= a[i + ofs] << (8 * (i & 3));\n }\n return caml_string_of_array(md5(buf, len));\n }\n} ();\n","//Provides: expect_test_collector_saved_stdout\nvar expect_test_collector_saved_stdout \n//Provides: expect_test_collector_saved_stderr\nvar expect_test_collector_saved_stderr\n\n//Provides: expect_test_collector_before_test\n//Requires: caml_global_data, caml_ml_channels\n//Requires: expect_test_collector_saved_stderr, expect_test_collector_saved_stdout\nfunction expect_test_collector_before_test (voutput, vstdout, vstderr){\n expect_test_collector_saved_stderr = caml_ml_channels[vstderr];\n expect_test_collector_saved_stdout = caml_ml_channels[vstdout];\n var output = caml_ml_channels[voutput];\n caml_ml_channels[vstdout] = output;\n caml_ml_channels[vstderr] = output;\n return 0;\n}\n\n//Provides: expect_test_collector_after_test\n//Requires: caml_global_data, caml_ml_channels\n//Requires: expect_test_collector_saved_stderr, expect_test_collector_saved_stdout\nfunction expect_test_collector_after_test (vstdout, vstderr){\n caml_ml_channels[vstdout] = expect_test_collector_saved_stdout;\n caml_ml_channels[vstderr] = expect_test_collector_saved_stderr;\n return 0;\n}\n\n//Provides:caml_out_channel_pos_fd\n//Requires: caml_global_data, caml_ml_channels\nfunction caml_out_channel_pos_fd(chan){\n var info = caml_ml_channels[chan];\n return info.offset\n}\n","///////// CORE_KERNEL\n\n//Provides: core_array_unsafe_int_blit\n//Requires: caml_array_blit\nvar core_array_unsafe_int_blit = caml_array_blit\n//Provides: core_array_unsafe_float_blit\n//Requires: caml_array_blit\nvar core_array_unsafe_float_blit = caml_array_blit\n\n//Provides: core_kernel_time_ns_format\n//Requires: caml_jsbytes_of_string, caml_string_of_jsbytes\nfunction core_kernel_time_ns_format(time,format){\n var d = new Date(time * 1000);\n var formatjs = caml_jsbytes_of_string(format);\n var jstring = joo_global_object.strftime(formatjs, d);\n return caml_string_of_jsbytes(jstring);\n}\n\n//Provides: core_kernel_gc_compactions\nfunction core_kernel_gc_compactions () { return 0 }\n//Provides: core_kernel_gc_heap_chunks\nfunction core_kernel_gc_heap_chunks () { return 0 }\n//Provides: core_kernel_gc_heap_words\nfunction core_kernel_gc_heap_words () { return 0 }\n//Provides: core_kernel_gc_major_collections\nfunction core_kernel_gc_major_collections () { return 0 }\n//Provides: core_kernel_gc_major_plus_minor_words\nfunction core_kernel_gc_major_plus_minor_words () { return 0 }\n//Provides: core_kernel_gc_major_words\nfunction core_kernel_gc_major_words () { return 0 }\n//Provides: core_kernel_gc_minor_collections\nfunction core_kernel_gc_minor_collections () { return 0 }\n//Provides: core_kernel_gc_minor_words\nfunction core_kernel_gc_minor_words () { return 0 }\n//Provides: core_kernel_gc_promoted_words\nfunction core_kernel_gc_promoted_words () { return 0 }\n//Provides: core_kernel_gc_top_heap_words\nfunction core_kernel_gc_top_heap_words () { return 0 }\n\n//Provides: Core_kernel_heap_block_is_heap_block\nfunction Core_kernel_heap_block_is_heap_block(x){\n return +(x instanceof Array);\n}\n\n//Provides: core_md5_fd\n//Requires: caml_ml_open_descriptor_in, caml_md5_chan, caml_ml_close_channel\nfunction core_md5_fd(fd){\n var ic = caml_ml_open_descriptor_in(fd);\n try {\n return caml_md5_chan(ic, -1);\n } finally {\n caml_ml_close_channel(ic);\n }\n}\n\n//Provides: core_md5_digest_subbigstring\n//Requires: caml_md5_string, caml_blit_string, caml_create_bytes\n//Requires: bigstring_blit_bigstring_bytes_stub, caml_string_of_bytes\nfunction core_md5_digest_subbigstring(buf, ofs, len, res){\n var bytes = caml_create_bytes(len);\n bigstring_blit_bigstring_bytes_stub(buf, ofs, bytes, 0, len);\n var res2 = caml_md5_string(caml_string_of_bytes(bytes), 0, len);\n caml_blit_string(res2, 0, res, 0, 16);\n return 0;\n}\n\n//Bigstring\n\n//Provides: bigstring_destroy_stub\n//Requires: caml_invalid_argument\nfunction bigstring_destroy_stub(v_bstr) {\n if (v_bstr.hasOwnProperty('__is_deallocated')) {\n caml_invalid_argument(\"bigstring_destroy: bigstring is already deallocated\");\n }\n // Mutate the original bigstring in-place, to simulate what the C version does\n v_bstr.__is_deallocated = true;\n v_bstr.data = new v_bstr.data.__proto__.constructor(0);\n v_bstr.dims = [ 0 ];\n return 0;\n}\n\n//Provides: bigstring_realloc\n//Requires: caml_invalid_argument, caml_ba_create_unsafe, bigstring_destroy_stub\nfunction bigstring_realloc(bigstring, size) {\n if (bigstring.hasOwnProperty('__is_deallocated')) {\n caml_invalid_argument(\"bigstring_realloc: bigstring is already deallocated\");\n }\n\n var new_data = new bigstring.data.__proto__.constructor(size);\n new_data.set(bigstring.data.slice(0, size));\n var new_bigstring = caml_ba_create_unsafe(bigstring.kind, bigstring.layout, [size], new_data);\n bigstring_destroy_stub(bigstring);\n\n return new_bigstring;\n}\n","// Provides: deferred_run\nfunction deferred_run(func) {\n var deferred = {\n promise: Promise.resolve()\n .then(func) // the ocaml types don't know this, but func can actually be async or sync\n .then(function (value) {\n deferred.value = value;\n deferred.isDetermined = true;\n return value;\n })\n .catch(function (err) {\n deferred.error = err;\n deferred.isError = true;\n deferred.isDetermined = true;\n throw err;\n }),\n isError: false,\n isDetermined: false,\n };\n return deferred;\n}\n\n// Provides: deferred_map\nfunction deferred_map(deferred, func) {\n var newDeferred = {\n promise: deferred.promise\n .then(func) // the ocaml types don't know this, but func can actually be async or sync\n .then(function (value) {\n newDeferred.value = value;\n newDeferred.isDetermined = true;\n return value;\n })\n .catch(function (err) {\n newDeferred.error = err;\n newDeferred.isError = true;\n newDeferred.isDetermined = true;\n throw err;\n }),\n isError: false,\n isDetermined: false,\n };\n return newDeferred;\n}\n\n// Provides: deferred_bind\nfunction deferred_bind(deferred, func) {\n var newDeferred = {\n promise: deferred.promise\n .then(func)\n .then(function (anotherDeferred) {\n return anotherDeferred.promise;\n })\n .then(function (value) {\n newDeferred.value = value;\n newDeferred.isDetermined = true;\n return value;\n })\n .catch(function (err) {\n newDeferred.error = err;\n newDeferred.isError = true;\n newDeferred.isDetermined = true;\n throw err;\n }),\n isError: false,\n isDetermined: false,\n };\n return newDeferred;\n}\n\n// Provides: deferred_upon\nfunction deferred_upon(deferred, func) {\n deferred.promise\n .then(function () {\n func(deferred.value);\n })\n .catch(function () {});\n}\n\n// Provides: deferred_upon_exn\nfunction deferred_upon_exn(deferred, func) {\n deferred.promise.then(function () {\n func(deferred.value);\n });\n}\n\n// Provides: deferred_is_determined\nfunction deferred_is_determined(deferred) {\n return deferred.isDetermined;\n}\n\n// Provides: deferred_peek\nfunction deferred_peek(deferred) {\n if (!deferred.isDetermined || deferred.isError) {\n return 0;\n }\n return [0, deferred.value];\n}\n\n// Provides: deferred_value_exn\nfunction deferred_value_exn(deferred) {\n if (!deferred.isDetermined) {\n throw Error(\"Deferred has not returned yet.\");\n }\n if (deferred.isError) {\n throw deferred.error;\n }\n return deferred.value;\n}\n\n// Provides: deferred_return\nfunction deferred_return(value) {\n return {\n promise: Promise.resolve(value),\n value: value,\n isError: false,\n isDetermined: true,\n };\n}\n\n// Provides: deferred_create\nfunction deferred_create(promise_creator) {\n var deferred = {\n promise: new Promise(function (resolve) {\n promise_creator(resolve);\n })\n .then(function (value) {\n deferred.value = value;\n deferred.isDetermined = true;\n })\n .catch(function (err) {\n deferred.error = err;\n deferred.isError = true;\n deferred.isDetermined = true;\n throw err;\n }),\n isError: false,\n isDetermined: false,\n };\n return deferred;\n}\n\n// Provides: deferred_to_promise\nfunction deferred_to_promise(deferred) {\n return deferred.promise;\n}\n\n// Provides: deferred_of_promise\nfunction deferred_of_promise(promise) {\n var deferred = {\n promise: promise\n .then(function (value) {\n deferred.value = value;\n deferred.isDetermined = true;\n return value;\n })\n .catch(function (err) {\n deferred.error = err;\n deferred.isError = true;\n deferred.isDetermined = true;\n throw err;\n }),\n isError: false,\n isDetermined: false,\n };\n return deferred;\n}\n","// This code supports both Array and MlInt64 implementations of int64 in\n// js_of_ocaml (pre- vs post-887507db1eb8efd779070cbedab3774098a52939).\n//\n// Compilation is currently broken on the MlInt64 implementation, due to\n// removed internal js_of_ocaml primitives. Removing these (and the Array\n// implementations, signalled by [instanceof Array] checks) will cause\n// compilation to succeed.\n//\n// TODO: build-time magic to stub the unavailable primitives on later versions.\n\n//Provides: UInt32 const\nvar UInt32 = (function() {\n var UInt32 = function(x) {\n this.value = x >>> 0;\n };\n UInt32.prototype.caml_custom = \"integers:uint32\";\n return UInt32;\n})();\n\n//Provides: integers_int32_of_uint32\nfunction integers_int32_of_uint32(i) {\n return (i.value | 0);\n}\n\n//Provides: integers_size_t_size\nfunction integers_size_t_size(unit) {\n return 4; // Set size_t = u32\n}\n\n//Provides: integers_uint16_of_string\n//Requires: integers_uint32_of_string\nfunction integers_uint16_of_string(x) {\n var y = integers_uint32_of_string(x);\n return (y.value & 0xFFFF);\n}\n\n//Provides: integers_uint32_add\n//Requires: UInt32\nfunction integers_uint32_add(x, y) {\n return new UInt32(x.value + y.value);\n}\n\n//Provides: integers_uint32_sub\n//Requires: UInt32\nfunction integers_uint32_sub(x, y) {\n return new UInt32(x.value - y.value);\n}\n\n//Provides: integers_uint32_div\n//Requires: UInt32\nfunction integers_uint32_div(x, y) {\n return new UInt32(x.value / y.value);\n}\n\n//Provides: integers_uint32_logand\n//Requires: UInt32\nfunction integers_uint32_logand(x, y) {\n return new UInt32(x.value & y.value);\n}\n\n//Provides: integers_uint32_logor\n//Requires: UInt32\nfunction integers_uint32_logor(x, y) {\n return new UInt32(x.value | y.value);\n}\n\n//Provides: integers_uint32_logxor\n//Requires: UInt32\nfunction integers_uint32_logxor(x, y) {\n return new UInt32(x.value ^ y.value);\n}\n\n//Provides: integers_uint32_max\n//Requires: UInt32\nfunction integers_uint32_max(unit) {\n return new UInt32(0xFFFFFFFF);\n}\n\n//Provides: integers_uint32_mul\n//Requires: integers_uint32_to_int64, caml_int64_mul, caml_int64_to_int32, UInt32\nfunction integers_uint32_mul(x, y) {\n // Convert to 64-bit and compute there.\n var x_64 = integers_uint32_to_int64(x);\n var y_64 = integers_uint32_to_int64(y);\n return new UInt32 (caml_int64_to_int32(caml_int64_mul(x_64, y_64)));\n}\n\n//Provides: integers_uint32_of_int\n//Requires: UInt32\nfunction integers_uint32_of_int(i) {\n return new UInt32(i);\n}\n\n//Provides: integers_uint32_of_int32\n//Requires: UInt32\nfunction integers_uint32_of_int32(i) {\n return new UInt32(i);\n}\n\n//Provides: integers_uint32_of_int64\n//Requires: caml_int64_to_int32, UInt32\nfunction integers_uint32_of_int64(i) {\n return new UInt32(caml_int64_to_int32(i));\n}\n\n//Provides: integers_uint32_of_string\n//Requires: integers_uint_of_string, integers_uint32_of_int64, caml_int64_create_lo_mi_hi\nfunction integers_uint32_of_string(s) {\n // To match the C implementation, we should parse the string as an uint64\n // and then downcast.\n var max_val = caml_int64_create_lo_mi_hi(0xffffff, 0xffffff, 0xffff);\n return integers_uint32_of_int64(integers_uint_of_string(s, max_val));\n}\n\n//Provides: integers_uint32_rem\n//Requires: caml_raise_zero_divide, UInt32\nfunction integers_uint32_rem(x, y) {\n if (y.value == 0) {\n caml_raise_zero_divide();\n }\n return new UInt32(x.value % y.value);\n}\n\n//Provides: integers_uint32_shift_left\n//Requires: UInt32\nfunction integers_uint32_shift_left(x, y) {\n return new UInt32(x.value << y);\n}\n\n//Provides: integers_uint32_shift_right\n//Requires: UInt32\nfunction integers_uint32_shift_right(x, y) {\n return new UInt32(x.value >>> y);\n}\n\n//Provides: integers_uint32_to_int\nfunction integers_uint32_to_int(i) {\n return (i.value | 0);\n}\n\n//Provides: integers_uint32_to_int64\n//Requires: caml_int64_create_lo_mi_hi\nfunction integers_uint32_to_int64(i) {\n return caml_int64_create_lo_mi_hi(i.value & 0xffffff, (i.value >>> 24) & 0xffffff, 0);\n}\n\n//Provides: integers_uint32_to_string\n//Requires: caml_new_string\nfunction integers_uint32_to_string(i) {\n return caml_new_string(i.value.toString());\n}\n\n//Provides: UInt64 const\nvar UInt64 = (function () {\n var UInt64 = function (x) {\n this.value = x; // x is an MlInt64\n };\n UInt64.prototype.caml_custom = \"integers:uint64\";\n return UInt64;\n})();\n\n//Provides: integers_uint64_add\n//Requires: caml_int64_add, UInt64\nfunction integers_uint64_add(x, y) {\n return new UInt64(caml_int64_add(x.value, y.value));\n}\n\n//Provides: integers_uint64_div\n//Requires: caml_raise_zero_divide, UInt64\nfunction integers_uint64_div(x, y) {\n if (y.value.isZero()) {\n caml_raise_zero_divide();\n }\n // Coerce the high parts to be unsigned before division.\n x.value.hi = x.value.hi >>> 0;\n y.value.hi = y.value.hi >>> 0;\n return new UInt64(x.value.udivmod(y.value).quotient);\n}\n\n//Provides: integers_uint64_logand\n//Requires: caml_int64_and, UInt64\nfunction integers_uint64_logand(x, y) {\n return new UInt64(caml_int64_and(x.value, y.value));\n}\n\n//Provides: integers_uint64_logor\n//Requires: caml_int64_or, UInt64\nfunction integers_uint64_logor(x, y) {\n return new UInt64(caml_int64_or(x.value, y.value));\n}\n\n//Provides: integers_uint64_logxor\n//Requires: caml_int64_xor, UInt64\nfunction integers_uint64_logxor(x, y) {\n return new UInt64(caml_int64_xor(x.value, y.value));\n}\n\n//Provides: integers_uint64_max\n//Requires: caml_int64_create_lo_mi_hi, UInt64\nfunction integers_uint64_max(unit) {\n var x = caml_int64_create_lo_mi_hi(0xffffff, 0xffffff, 0xffff);\n x.hi = x.hi >>> 0;\n return new UInt64(x);\n}\n\n//Provides: integers_uint64_mul\n//Requires: caml_int64_mul, UInt64\nfunction integers_uint64_mul(x, y) {\n return new UInt64(caml_int64_mul(x.value, y.value));\n}\n\n//Provides: integers_uint64_of_int\n//Requires: caml_int64_of_int32, UInt64\nfunction integers_uint64_of_int(i) {\n return new UInt64(caml_int64_of_int32(i));\n}\n\n//Provides: integers_uint64_of_int64\n//Requires: caml_int64_create_lo_mi_hi, UInt64\nfunction integers_uint64_of_int64(i) {\n return new UInt64(caml_int64_create_lo_mi_hi(i.lo, i.mi, i.hi >>> 0));\n}\n\n//Provides: integers_uint_of_string\n//Requires: caml_ml_string_length, caml_failwith, caml_string_unsafe_get, caml_int64_create_lo_mi_hi, caml_int64_of_int32, caml_parse_digit, caml_int64_ult, caml_int64_add, caml_int64_mul, caml_int64_neg\nfunction integers_uint_of_string(s, max_val) {\n // Note: This code matches the behavior of the C function.\n // In particular,\n // - only base-10 numbers are accepted\n // - negative numbers are accepted and coerced to 2's-complement uint64\n // - the longest numeric prefix is accepted, only raising an error when there\n // isn't a numeric prefix\n var i = 0, len = caml_ml_string_length(s), negative = false;\n if (i >= len) {\n caml_failwith(\"int_of_string\");\n }\n var c = caml_string_unsafe_get(s, i);\n if (c === 45) { // Minus sign\n i++;\n negative = true;\n } else if (c === 43) { // Plus sign\n i++;\n }\n var no_digits = true;\n // Ensure that the high byte is unsigned before division.\n max_val.hi = max_val.hi >>> 0;\n var ten = caml_int64_of_int32(10);\n var max_base_10 = max_val.udivmod(ten).quotient;\n var res = caml_int64_of_int32(0);\n for (; i < len; i++) {\n var c = caml_string_unsafe_get(s, i);\n var d = caml_parse_digit(c);\n if (d < 0 || d >= 10) {\n break;\n }\n no_digits = false;\n // Any digit here would overflow. Pin to the maximum value.\n if (caml_int64_ult(max_base_10, res)) {\n return max_val;\n }\n d = caml_int64_of_int32(d);\n res = caml_int64_add(caml_int64_mul(ten, res), d);\n // The given digit was too large. Pin to the maximum value.\n if (caml_int64_ult(res, d)) {\n return max_val;\n }\n }\n if (no_digits) {\n caml_failwith(\"int_of_string\");\n }\n if (negative) {\n res = caml_int64_neg(res);\n }\n // Set the high byte as unsigned.\n res.hi = res.hi >>> 0;\n return res;\n}\n\n//Provides: integers_uint64_of_string\n//Requires: integers_uint_of_string, caml_int64_create_lo_mi_hi, UInt64\nfunction integers_uint64_of_string(s) {\n var max_val = caml_int64_create_lo_mi_hi(0xffffff, 0xffffff, 0xffff);\n return new UInt64(integers_uint_of_string(s, max_val));\n}\n\n//Provides: integers_uint64_rem\n//Requires: caml_raise_zero_divide, caml_int64_is_zero, UInt64\nfunction integers_uint64_rem(x, y) {\n if (y.value.isZero()) {\n caml_raise_zero_divide();\n }\n // Coerce the high parts to be unsigned before division.\n x.value.hi = x.value.hi >>> 0;\n y.value.hi = y.value.hi >>> 0;\n return new UInt64(x.value.udivmod(y.value).modulus);\n}\n\n//Provides: integers_uint64_shift_left\n//Requires: caml_int64_shift_left, UInt64\nfunction integers_uint64_shift_left(x, y) {\n return new UInt64(caml_int64_shift_left(x.value, y));\n}\n\n//Provides: integers_uint64_shift_right\n//Requires: caml_int64_shift_right_unsigned, UInt64\nfunction integers_uint64_shift_right(x, y) {\n return new UInt64(caml_int64_shift_right_unsigned(x.value, y));\n}\n\n//Provides: integers_uint64_sub\n//Requires: caml_int64_sub, UInt64\nfunction integers_uint64_sub(x, y) {\n return new UInt64(caml_int64_sub(x.value, y.value));\n}\n\n//Provides: integers_uint64_to_int\n//Requires: caml_int64_to_int32\nfunction integers_uint64_to_int(i) {\n return caml_int64_to_int32(i.value);\n}\n\n//Provides: integers_uint64_to_int64\n//Requires: caml_int64_create_lo_mi_hi\nfunction integers_uint64_to_int64(i) {\n i = i.value;\n return caml_int64_create_lo_mi_hi(i.lo, i.mi, i.hi | 0);\n}\n\n//Provides: integers_uint64_to_string\n//Requires: caml_int64_format, caml_new_string\nfunction integers_uint64_to_string(i) {\n return caml_int64_format(caml_new_string(\"%u\"), i.value);\n}\n\n//Provides: integers_uint64_unmarshal\n//Requires: caml_int64_unmarshal, UInt64\nfunction integers_uint64_unmarshal(reader, size){\n return new UInt64(caml_int64_unmarshal(reader, size));\n}\n \n//Provides: integers_uint64_marshal\n//Requires: caml_int64_marshal\nfunction integers_uint64_marshal(writer, v, sizes) {\n caml_int64_marshal(writer, v.value, sizes);\n}\n\n//Provides: integers_uint64_hash\n//Requires: caml_int64_hash\nfunction integers_uint64_hash(v) {\n return caml_int64_hash(v.value);\n}\n\n//Provides: integers_uint8_of_string\n//Requires: integers_uint32_of_string\nfunction integers_uint8_of_string(x) {\n var y = integers_uint32_of_string(x);\n return (x.value & 0xFF);\n}\n\n//Provides: integers_uint_size\nfunction integers_uint_size(unit) {\n return 4;\n}\n\n//Provides: integers_ulong_size\nfunction integers_ulong_size(unit) {\n return 4;\n}\n\n//Provides: integers_ulonglong_size\nfunction integers_ulonglong_size(unit) {\n return 8;\n}\n\n//Provides: integers_unsigned_init\n//Requires: caml_custom_ops, integers_uint8_deserialize, integers_uint16_deserialize, integers_uint32_serialize, integers_uint32_deserialize, integers_uint32_hash, integers_uint32_compare, integers_uint64_compare, integers_uint64_hash, integers_uint64_marshal, integers_uint64_unmarshal\nfunction integers_unsigned_init(unit) {\n caml_custom_ops[\"integers:uint8\"] =\n { deserialize: integers_uint8_deserialize\n , fixed_length: 1 };\n caml_custom_ops[\"integers:uint16\"] =\n { deserialize: integers_uint16_deserialize\n , fixed_length: 2 };\n caml_custom_ops[\"integers:uint32\"] =\n { serialize: integers_uint32_serialize\n , deserialize: integers_uint32_deserialize\n , fixed_length: 4\n , hash: integers_uint32_hash\n , compare: integers_uint32_compare };\n caml_custom_ops[\"integers:uint64\"] =\n { serialize: integers_uint64_marshal\n , deserialize: integers_uint64_unmarshal\n , hash: integers_uint64_hash\n , compare: integers_uint64_compare };\n return unit;\n}\n\n//Provides: integers_ushort_size\nfunction integers_ushort_size(unit) {\n return 4;\n}\n\n//Provides: integers_uint32_serialize\nfunction integers_uint32_serialize(writer, v, size) {\n writer.write(32, v.value);\n size[0] = 4;\n size[1] = 4;\n}\n\n//Provides: integers_uint8_deserialize\nfunction integers_uint8_deserialize(reader, size) {\n size[0] = 1;\n return reader.read8u();\n}\n\n//Provides: integers_uint16_deserialize\nfunction integers_uint16_deserialize(reader, size) {\n size[0] = 2;\n return reader.read16u();\n}\n\n//Provides: integers_uint32_deserialize\n//Requires: UInt32\nfunction integers_uint32_deserialize(reader, size) {\n size[0] = 4;\n return new UInt32(reader.read32u());\n}\n\n//Provides: integers_uint32_hash\nfunction integers_uint32_hash(v) {\n return v.value;\n}\n\n//Provides: integers_uint32_compare\nfunction integers_uint32_compare(x, y) {\n if (x.value > y.value) { return 1; }\n if (x.value < y.value) { return -1; }\n return 0;\n}\n\n//Provides: integers_uint64_compare\n//Requires: caml_int64_compare\nfunction integers_uint64_compare(x, y) {\n x.value.hi = x.value.hi >>> 0;\n y.value.hi = y.value.hi >>> 0;\n return x.value.ucompare(y.value);\n}\n","//Imported from https://github.com/peterolson/BigInteger.js#4e99b15b7951338f164728377c906caae5a78202\n\n//Provides: bigInt const\nvar bigInt = (function (undefined) {\n \"use strict\";\n\n var BASE = 1e7,\n LOG_BASE = 7,\n MAX_INT = 9007199254740992,\n MAX_INT_ARR = smallToArray(MAX_INT),\n DEFAULT_ALPHABET = \"0123456789abcdefghijklmnopqrstuvwxyz\";\n\n var BigInt = joo_global_object.BigInt;\n\n var supportsNativeBigInt = typeof BigInt === \"function\";\n\n function Integer(v, radix, alphabet, caseSensitive) {\n if (typeof v === \"undefined\") return Integer[0];\n if (typeof radix !== \"undefined\") return +radix === 10 && !alphabet ? parseValue(v) : parseBase(v, radix, alphabet, caseSensitive);\n return parseValue(v);\n }\n\n function BigInteger(value, sign) {\n this.value = value;\n this.sign = sign;\n this.isSmall = false;\n this.caml_custom = '_z';\n }\n BigInteger.prototype = Object.create(Integer.prototype);\n\n function SmallInteger(value) {\n this.value = value;\n this.sign = value < 0;\n this.isSmall = true;\n this.caml_custom = '_z';\n }\n SmallInteger.prototype = Object.create(Integer.prototype);\n\n function NativeBigInt(value) {\n this.value = value;\n this.caml_custom = '_z';\n }\n NativeBigInt.prototype = Object.create(Integer.prototype);\n\n function isPrecise(n) {\n return -MAX_INT < n && n < MAX_INT;\n }\n\n function smallToArray(n) { // For performance reasons doesn't reference BASE, need to change this function if BASE changes\n if (n < 1e7)\n return [n];\n if (n < 1e14)\n return [n % 1e7, Math.floor(n / 1e7)];\n return [n % 1e7, Math.floor(n / 1e7) % 1e7, Math.floor(n / 1e14)];\n }\n\n function arrayToSmall(arr) { // If BASE changes this function may need to change\n trim(arr);\n var length = arr.length;\n if (length < 4 && compareAbs(arr, MAX_INT_ARR) < 0) {\n switch (length) {\n case 0: return 0;\n case 1: return arr[0];\n case 2: return arr[0] + arr[1] * BASE;\n default: return arr[0] + (arr[1] + arr[2] * BASE) * BASE;\n }\n }\n return arr;\n }\n\n function trim(v) {\n var i = v.length;\n while (v[--i] === 0);\n v.length = i + 1;\n }\n\n function createArray(length) { // function shamelessly stolen from Yaffle's library https://github.com/Yaffle/BigInteger\n var x = new Array(length);\n var i = -1;\n while (++i < length) {\n x[i] = 0;\n }\n return x;\n }\n\n function truncate(n) {\n if (n > 0) return Math.floor(n);\n return Math.ceil(n);\n }\n\n function add(a, b) { // assumes a and b are arrays with a.length >= b.length\n var l_a = a.length,\n l_b = b.length,\n r = new Array(l_a),\n carry = 0,\n base = BASE,\n sum, i;\n for (i = 0; i < l_b; i++) {\n sum = a[i] + b[i] + carry;\n carry = sum >= base ? 1 : 0;\n r[i] = sum - carry * base;\n }\n while (i < l_a) {\n sum = a[i] + carry;\n carry = sum === base ? 1 : 0;\n r[i++] = sum - carry * base;\n }\n if (carry > 0) r.push(carry);\n return r;\n }\n\n function addAny(a, b) {\n if (a.length >= b.length) return add(a, b);\n return add(b, a);\n }\n\n function addSmall(a, carry) { // assumes a is array, carry is number with 0 <= carry < MAX_INT\n var l = a.length,\n r = new Array(l),\n base = BASE,\n sum, i;\n for (i = 0; i < l; i++) {\n sum = a[i] - base + carry;\n carry = Math.floor(sum / base);\n r[i] = sum - carry * base;\n carry += 1;\n }\n while (carry > 0) {\n r[i++] = carry % base;\n carry = Math.floor(carry / base);\n }\n return r;\n }\n\n BigInteger.prototype.add = function (v) {\n var n = parseValue(v);\n if (this.sign !== n.sign) {\n return this.subtract(n.negate());\n }\n var a = this.value, b = n.value;\n if (n.isSmall) {\n return new BigInteger(addSmall(a, Math.abs(b)), this.sign);\n }\n return new BigInteger(addAny(a, b), this.sign);\n };\n BigInteger.prototype.plus = BigInteger.prototype.add;\n\n SmallInteger.prototype.add = function (v) {\n var n = parseValue(v);\n var a = this.value;\n if (a < 0 !== n.sign) {\n return this.subtract(n.negate());\n }\n var b = n.value;\n if (n.isSmall) {\n if (isPrecise(a + b)) return new SmallInteger(a + b);\n b = smallToArray(Math.abs(b));\n }\n return new BigInteger(addSmall(b, Math.abs(a)), a < 0);\n };\n SmallInteger.prototype.plus = SmallInteger.prototype.add;\n\n NativeBigInt.prototype.add = function (v) {\n return new NativeBigInt(this.value + parseValue(v).value);\n }\n NativeBigInt.prototype.plus = NativeBigInt.prototype.add;\n\n function subtract(a, b) { // assumes a and b are arrays with a >= b\n var a_l = a.length,\n b_l = b.length,\n r = new Array(a_l),\n borrow = 0,\n base = BASE,\n i, difference;\n for (i = 0; i < b_l; i++) {\n difference = a[i] - borrow - b[i];\n if (difference < 0) {\n difference += base;\n borrow = 1;\n } else borrow = 0;\n r[i] = difference;\n }\n for (i = b_l; i < a_l; i++) {\n difference = a[i] - borrow;\n if (difference < 0) difference += base;\n else {\n r[i++] = difference;\n break;\n }\n r[i] = difference;\n }\n for (; i < a_l; i++) {\n r[i] = a[i];\n }\n trim(r);\n return r;\n }\n\n function subtractAny(a, b, sign) {\n var value;\n if (compareAbs(a, b) >= 0) {\n value = subtract(a, b);\n } else {\n value = subtract(b, a);\n sign = !sign;\n }\n value = arrayToSmall(value);\n if (typeof value === \"number\") {\n if (sign) value = -value;\n return new SmallInteger(value);\n }\n return new BigInteger(value, sign);\n }\n\n function subtractSmall(a, b, sign) { // assumes a is array, b is number with 0 <= b < MAX_INT\n var l = a.length,\n r = new Array(l),\n carry = -b,\n base = BASE,\n i, difference;\n for (i = 0; i < l; i++) {\n difference = a[i] + carry;\n carry = Math.floor(difference / base);\n difference %= base;\n r[i] = difference < 0 ? difference + base : difference;\n }\n r = arrayToSmall(r);\n if (typeof r === \"number\") {\n if (sign) r = -r;\n return new SmallInteger(r);\n } return new BigInteger(r, sign);\n }\n\n BigInteger.prototype.subtract = function (v) {\n var n = parseValue(v);\n if (this.sign !== n.sign) {\n return this.add(n.negate());\n }\n var a = this.value, b = n.value;\n if (n.isSmall)\n return subtractSmall(a, Math.abs(b), this.sign);\n return subtractAny(a, b, this.sign);\n };\n BigInteger.prototype.minus = BigInteger.prototype.subtract;\n\n SmallInteger.prototype.subtract = function (v) {\n var n = parseValue(v);\n var a = this.value;\n if (a < 0 !== n.sign) {\n return this.add(n.negate());\n }\n var b = n.value;\n if (n.isSmall) {\n return new SmallInteger(a - b);\n }\n return subtractSmall(b, Math.abs(a), a >= 0);\n };\n SmallInteger.prototype.minus = SmallInteger.prototype.subtract;\n\n NativeBigInt.prototype.subtract = function (v) {\n return new NativeBigInt(this.value - parseValue(v).value);\n }\n NativeBigInt.prototype.minus = NativeBigInt.prototype.subtract;\n\n BigInteger.prototype.negate = function () {\n return new BigInteger(this.value, !this.sign);\n };\n SmallInteger.prototype.negate = function () {\n var sign = this.sign;\n var small = new SmallInteger(-this.value);\n small.sign = !sign;\n return small;\n };\n NativeBigInt.prototype.negate = function () {\n return new NativeBigInt(-this.value);\n }\n\n BigInteger.prototype.abs = function () {\n return new BigInteger(this.value, false);\n };\n SmallInteger.prototype.abs = function () {\n return new SmallInteger(Math.abs(this.value));\n };\n NativeBigInt.prototype.abs = function () {\n return new NativeBigInt(this.value >= 0 ? this.value : -this.value);\n }\n\n\n function multiplyLong(a, b) {\n var a_l = a.length,\n b_l = b.length,\n l = a_l + b_l,\n r = createArray(l),\n base = BASE,\n product, carry, i, a_i, b_j;\n for (i = 0; i < a_l; ++i) {\n a_i = a[i];\n for (var j = 0; j < b_l; ++j) {\n b_j = b[j];\n product = a_i * b_j + r[i + j];\n carry = Math.floor(product / base);\n r[i + j] = product - carry * base;\n r[i + j + 1] += carry;\n }\n }\n trim(r);\n return r;\n }\n\n function multiplySmall(a, b) { // assumes a is array, b is number with |b| < BASE\n var l = a.length,\n r = new Array(l),\n base = BASE,\n carry = 0,\n product, i;\n for (i = 0; i < l; i++) {\n product = a[i] * b + carry;\n carry = Math.floor(product / base);\n r[i] = product - carry * base;\n }\n while (carry > 0) {\n r[i++] = carry % base;\n carry = Math.floor(carry / base);\n }\n return r;\n }\n\n function shiftLeft(x, n) {\n var r = [];\n while (n-- > 0) r.push(0);\n return r.concat(x);\n }\n\n function multiplyKaratsuba(x, y) {\n var n = Math.max(x.length, y.length);\n\n if (n <= 30) return multiplyLong(x, y);\n n = Math.ceil(n / 2);\n\n var b = x.slice(n),\n a = x.slice(0, n),\n d = y.slice(n),\n c = y.slice(0, n);\n\n var ac = multiplyKaratsuba(a, c),\n bd = multiplyKaratsuba(b, d),\n abcd = multiplyKaratsuba(addAny(a, b), addAny(c, d));\n\n var product = addAny(addAny(ac, shiftLeft(subtract(subtract(abcd, ac), bd), n)), shiftLeft(bd, 2 * n));\n trim(product);\n return product;\n }\n\n // The following function is derived from a surface fit of a graph plotting the performance difference\n // between long multiplication and karatsuba multiplication versus the lengths of the two arrays.\n function useKaratsuba(l1, l2) {\n return -0.012 * l1 - 0.012 * l2 + 0.000015 * l1 * l2 > 0;\n }\n\n BigInteger.prototype.multiply = function (v) {\n var n = parseValue(v),\n a = this.value, b = n.value,\n sign = this.sign !== n.sign,\n abs;\n if (n.isSmall) {\n if (b === 0) return Integer[0];\n if (b === 1) return this;\n if (b === -1) return this.negate();\n abs = Math.abs(b);\n if (abs < BASE) {\n return new BigInteger(multiplySmall(a, abs), sign);\n }\n b = smallToArray(abs);\n }\n if (useKaratsuba(a.length, b.length)) // Karatsuba is only faster for certain array sizes\n return new BigInteger(multiplyKaratsuba(a, b), sign);\n return new BigInteger(multiplyLong(a, b), sign);\n };\n\n BigInteger.prototype.times = BigInteger.prototype.multiply;\n\n function multiplySmallAndArray(a, b, sign) { // a >= 0\n if (a < BASE) {\n return new BigInteger(multiplySmall(b, a), sign);\n }\n return new BigInteger(multiplyLong(b, smallToArray(a)), sign);\n }\n SmallInteger.prototype._multiplyBySmall = function (a) {\n if (isPrecise(a.value * this.value)) {\n return new SmallInteger(a.value * this.value);\n }\n return multiplySmallAndArray(Math.abs(a.value), smallToArray(Math.abs(this.value)), this.sign !== a.sign);\n };\n BigInteger.prototype._multiplyBySmall = function (a) {\n if (a.value === 0) return Integer[0];\n if (a.value === 1) return this;\n if (a.value === -1) return this.negate();\n return multiplySmallAndArray(Math.abs(a.value), this.value, this.sign !== a.sign);\n };\n SmallInteger.prototype.multiply = function (v) {\n return parseValue(v)._multiplyBySmall(this);\n };\n SmallInteger.prototype.times = SmallInteger.prototype.multiply;\n\n NativeBigInt.prototype.multiply = function (v) {\n return new NativeBigInt(this.value * parseValue(v).value);\n }\n NativeBigInt.prototype.times = NativeBigInt.prototype.multiply;\n\n function square(a) {\n //console.assert(2 * BASE * BASE < MAX_INT);\n var l = a.length,\n r = createArray(l + l),\n base = BASE,\n product, carry, i, a_i, a_j;\n for (i = 0; i < l; i++) {\n a_i = a[i];\n carry = 0 - a_i * a_i;\n for (var j = i; j < l; j++) {\n a_j = a[j];\n product = 2 * (a_i * a_j) + r[i + j] + carry;\n carry = Math.floor(product / base);\n r[i + j] = product - carry * base;\n }\n r[i + l] = carry;\n }\n trim(r);\n return r;\n }\n\n BigInteger.prototype.square = function () {\n return new BigInteger(square(this.value), false);\n };\n\n SmallInteger.prototype.square = function () {\n var value = this.value * this.value;\n if (isPrecise(value)) return new SmallInteger(value);\n return new BigInteger(square(smallToArray(Math.abs(this.value))), false);\n };\n\n NativeBigInt.prototype.square = function (v) {\n return new NativeBigInt(this.value * this.value);\n }\n\n function divMod1(a, b) { // Left over from previous version. Performs faster than divMod2 on smaller input sizes.\n var a_l = a.length,\n b_l = b.length,\n base = BASE,\n result = createArray(b.length),\n divisorMostSignificantDigit = b[b_l - 1],\n // normalization\n lambda = Math.ceil(base / (2 * divisorMostSignificantDigit)),\n remainder = multiplySmall(a, lambda),\n divisor = multiplySmall(b, lambda),\n quotientDigit, shift, carry, borrow, i, l, q;\n if (remainder.length <= a_l) remainder.push(0);\n divisor.push(0);\n divisorMostSignificantDigit = divisor[b_l - 1];\n for (shift = a_l - b_l; shift >= 0; shift--) {\n quotientDigit = base - 1;\n if (remainder[shift + b_l] !== divisorMostSignificantDigit) {\n quotientDigit = Math.floor((remainder[shift + b_l] * base + remainder[shift + b_l - 1]) / divisorMostSignificantDigit);\n }\n // quotientDigit <= base - 1\n carry = 0;\n borrow = 0;\n l = divisor.length;\n for (i = 0; i < l; i++) {\n carry += quotientDigit * divisor[i];\n q = Math.floor(carry / base);\n borrow += remainder[shift + i] - (carry - q * base);\n carry = q;\n if (borrow < 0) {\n remainder[shift + i] = borrow + base;\n borrow = -1;\n } else {\n remainder[shift + i] = borrow;\n borrow = 0;\n }\n }\n while (borrow !== 0) {\n quotientDigit -= 1;\n carry = 0;\n for (i = 0; i < l; i++) {\n carry += remainder[shift + i] - base + divisor[i];\n if (carry < 0) {\n remainder[shift + i] = carry + base;\n carry = 0;\n } else {\n remainder[shift + i] = carry;\n carry = 1;\n }\n }\n borrow += carry;\n }\n result[shift] = quotientDigit;\n }\n // denormalization\n remainder = divModSmall(remainder, lambda)[0];\n return [arrayToSmall(result), arrayToSmall(remainder)];\n }\n\n function divMod2(a, b) { // Implementation idea shamelessly stolen from Silent Matt's library http://silentmatt.com/biginteger/\n // Performs faster than divMod1 on larger input sizes.\n var a_l = a.length,\n b_l = b.length,\n result = [],\n part = [],\n base = BASE,\n guess, xlen, highx, highy, check;\n while (a_l) {\n part.unshift(a[--a_l]);\n trim(part);\n if (compareAbs(part, b) < 0) {\n result.push(0);\n continue;\n }\n xlen = part.length;\n highx = part[xlen - 1] * base + part[xlen - 2];\n highy = b[b_l - 1] * base + b[b_l - 2];\n if (xlen > b_l) {\n highx = (highx + 1) * base;\n }\n guess = Math.ceil(highx / highy);\n do {\n check = multiplySmall(b, guess);\n if (compareAbs(check, part) <= 0) break;\n guess--;\n } while (guess);\n result.push(guess);\n part = subtract(part, check);\n }\n result.reverse();\n return [arrayToSmall(result), arrayToSmall(part)];\n }\n\n function divModSmall(value, lambda) {\n var length = value.length,\n quotient = createArray(length),\n base = BASE,\n i, q, remainder, divisor;\n remainder = 0;\n for (i = length - 1; i >= 0; --i) {\n divisor = remainder * base + value[i];\n q = truncate(divisor / lambda);\n remainder = divisor - q * lambda;\n quotient[i] = q | 0;\n }\n return [quotient, remainder | 0];\n }\n\n function divModAny(self, v) {\n var value, n = parseValue(v);\n if (supportsNativeBigInt) {\n return [new NativeBigInt(self.value / n.value), new NativeBigInt(self.value % n.value)];\n }\n var a = self.value, b = n.value;\n var quotient;\n if (b === 0) throw new Error(\"Cannot divide by zero\");\n if (self.isSmall) {\n if (n.isSmall) {\n return [new SmallInteger(truncate(a / b)), new SmallInteger(a % b)];\n }\n return [Integer[0], self];\n }\n if (n.isSmall) {\n if (b === 1) return [self, Integer[0]];\n if (b == -1) return [self.negate(), Integer[0]];\n var abs = Math.abs(b);\n if (abs < BASE) {\n value = divModSmall(a, abs);\n quotient = arrayToSmall(value[0]);\n var remainder = value[1];\n if (self.sign) remainder = -remainder;\n if (typeof quotient === \"number\") {\n if (self.sign !== n.sign) quotient = -quotient;\n return [new SmallInteger(quotient), new SmallInteger(remainder)];\n }\n return [new BigInteger(quotient, self.sign !== n.sign), new SmallInteger(remainder)];\n }\n b = smallToArray(abs);\n }\n var comparison = compareAbs(a, b);\n if (comparison === -1) return [Integer[0], self];\n if (comparison === 0) return [Integer[self.sign === n.sign ? 1 : -1], Integer[0]];\n\n // divMod1 is faster on smaller input sizes\n if (a.length + b.length <= 200)\n value = divMod1(a, b);\n else value = divMod2(a, b);\n\n quotient = value[0];\n var qSign = self.sign !== n.sign,\n mod = value[1],\n mSign = self.sign;\n if (typeof quotient === \"number\") {\n if (qSign) quotient = -quotient;\n quotient = new SmallInteger(quotient);\n } else quotient = new BigInteger(quotient, qSign);\n if (typeof mod === \"number\") {\n if (mSign) mod = -mod;\n mod = new SmallInteger(mod);\n } else mod = new BigInteger(mod, mSign);\n return [quotient, mod];\n }\n\n BigInteger.prototype.divmod = function (v) {\n var result = divModAny(this, v);\n return {\n quotient: result[0],\n remainder: result[1]\n };\n };\n NativeBigInt.prototype.divmod = SmallInteger.prototype.divmod = BigInteger.prototype.divmod;\n\n\n BigInteger.prototype.divide = function (v) {\n return divModAny(this, v)[0];\n };\n NativeBigInt.prototype.over = NativeBigInt.prototype.divide = function (v) {\n return new NativeBigInt(this.value / parseValue(v).value);\n };\n SmallInteger.prototype.over = SmallInteger.prototype.divide = BigInteger.prototype.over = BigInteger.prototype.divide;\n\n BigInteger.prototype.mod = function (v) {\n return divModAny(this, v)[1];\n };\n NativeBigInt.prototype.mod = NativeBigInt.prototype.remainder = function (v) {\n return new NativeBigInt(this.value % parseValue(v).value);\n };\n SmallInteger.prototype.remainder = SmallInteger.prototype.mod = BigInteger.prototype.remainder = BigInteger.prototype.mod;\n\n BigInteger.prototype.pow = function (v) {\n var n = parseValue(v),\n a = this.value,\n b = n.value,\n value, x, y;\n if (b === 0) return Integer[1];\n if (a === 0) return Integer[0];\n if (a === 1) return Integer[1];\n if (a === -1) return n.isEven() ? Integer[1] : Integer[-1];\n if (n.sign) {\n return Integer[0];\n }\n if (!n.isSmall) throw new Error(\"The exponent \" + n.toString() + \" is too large.\");\n if (this.isSmall) {\n if (isPrecise(value = Math.pow(a, b)))\n return new SmallInteger(truncate(value));\n }\n x = this;\n y = Integer[1];\n while (true) {\n if (b & 1 === 1) {\n y = y.times(x);\n --b;\n }\n if (b === 0) break;\n b /= 2;\n x = x.square();\n }\n return y;\n };\n SmallInteger.prototype.pow = BigInteger.prototype.pow;\n\n NativeBigInt.prototype.pow = function (v) {\n var n = parseValue(v);\n var a = this.value, b = n.value;\n var _0 = BigInt(0), _1 = BigInt(1), _2 = BigInt(2);\n if (b === _0) return Integer[1];\n if (a === _0) return Integer[0];\n if (a === _1) return Integer[1];\n if (a === BigInt(-1)) return n.isEven() ? Integer[1] : Integer[-1];\n if (n.isNegative()) return new NativeBigInt(_0);\n var x = this;\n var y = Integer[1];\n while (true) {\n if ((b & _1) === _1) {\n y = y.times(x);\n --b;\n }\n if (b === _0) break;\n b /= _2;\n x = x.square();\n }\n return y;\n }\n\n BigInteger.prototype.modPow = function (exp, mod) {\n exp = parseValue(exp);\n mod = parseValue(mod);\n if (mod.isZero()) throw new Error(\"Cannot take modPow with modulus 0\");\n var r = Integer[1],\n base = this.mod(mod);\n if (exp.isNegative()) {\n exp = exp.multiply(Integer[-1]);\n base = base.modInv(mod);\n }\n while (exp.isPositive()) {\n if (base.isZero()) return Integer[0];\n if (exp.isOdd()) r = r.multiply(base).mod(mod);\n exp = exp.divide(2);\n base = base.square().mod(mod);\n }\n return r;\n };\n NativeBigInt.prototype.modPow = SmallInteger.prototype.modPow = BigInteger.prototype.modPow;\n\n function compareAbs(a, b) {\n if (a.length !== b.length) {\n return a.length > b.length ? 1 : -1;\n }\n for (var i = a.length - 1; i >= 0; i--) {\n if (a[i] !== b[i]) return a[i] > b[i] ? 1 : -1;\n }\n return 0;\n }\n\n BigInteger.prototype.compareAbs = function (v) {\n var n = parseValue(v),\n a = this.value,\n b = n.value;\n if (n.isSmall) return 1;\n return compareAbs(a, b);\n };\n SmallInteger.prototype.compareAbs = function (v) {\n var n = parseValue(v),\n a = Math.abs(this.value),\n b = n.value;\n if (n.isSmall) {\n b = Math.abs(b);\n return a === b ? 0 : a > b ? 1 : -1;\n }\n return -1;\n };\n NativeBigInt.prototype.compareAbs = function (v) {\n var a = this.value;\n var b = parseValue(v).value;\n a = a >= 0 ? a : -a;\n b = b >= 0 ? b : -b;\n return a === b ? 0 : a > b ? 1 : -1;\n }\n\n BigInteger.prototype.compare = function (v) {\n // See discussion about comparison with Infinity:\n // https://github.com/peterolson/BigInteger.js/issues/61\n if (v === Infinity) {\n return -1;\n }\n if (v === -Infinity) {\n return 1;\n }\n\n var n = parseValue(v),\n a = this.value,\n b = n.value;\n if (this.sign !== n.sign) {\n return n.sign ? 1 : -1;\n }\n if (n.isSmall) {\n return this.sign ? -1 : 1;\n }\n return compareAbs(a, b) * (this.sign ? -1 : 1);\n };\n BigInteger.prototype.compareTo = BigInteger.prototype.compare;\n\n SmallInteger.prototype.compare = function (v) {\n if (v === Infinity) {\n return -1;\n }\n if (v === -Infinity) {\n return 1;\n }\n\n var n = parseValue(v),\n a = this.value,\n b = n.value;\n if (n.isSmall) {\n return a == b ? 0 : a > b ? 1 : -1;\n }\n if (a < 0 !== n.sign) {\n return a < 0 ? -1 : 1;\n }\n return a < 0 ? 1 : -1;\n };\n SmallInteger.prototype.compareTo = SmallInteger.prototype.compare;\n\n NativeBigInt.prototype.compare = function (v) {\n if (v === Infinity) {\n return -1;\n }\n if (v === -Infinity) {\n return 1;\n }\n var a = this.value;\n var b = parseValue(v).value;\n return a === b ? 0 : a > b ? 1 : -1;\n }\n NativeBigInt.prototype.compareTo = NativeBigInt.prototype.compare;\n\n BigInteger.prototype.equals = function (v) {\n return this.compare(v) === 0;\n };\n NativeBigInt.prototype.eq = NativeBigInt.prototype.equals = SmallInteger.prototype.eq = SmallInteger.prototype.equals = BigInteger.prototype.eq = BigInteger.prototype.equals;\n\n BigInteger.prototype.notEquals = function (v) {\n return this.compare(v) !== 0;\n };\n NativeBigInt.prototype.neq = NativeBigInt.prototype.notEquals = SmallInteger.prototype.neq = SmallInteger.prototype.notEquals = BigInteger.prototype.neq = BigInteger.prototype.notEquals;\n\n BigInteger.prototype.greater = function (v) {\n return this.compare(v) > 0;\n };\n NativeBigInt.prototype.gt = NativeBigInt.prototype.greater = SmallInteger.prototype.gt = SmallInteger.prototype.greater = BigInteger.prototype.gt = BigInteger.prototype.greater;\n\n BigInteger.prototype.lesser = function (v) {\n return this.compare(v) < 0;\n };\n NativeBigInt.prototype.lt = NativeBigInt.prototype.lesser = SmallInteger.prototype.lt = SmallInteger.prototype.lesser = BigInteger.prototype.lt = BigInteger.prototype.lesser;\n\n BigInteger.prototype.greaterOrEquals = function (v) {\n return this.compare(v) >= 0;\n };\n NativeBigInt.prototype.geq = NativeBigInt.prototype.greaterOrEquals = SmallInteger.prototype.geq = SmallInteger.prototype.greaterOrEquals = BigInteger.prototype.geq = BigInteger.prototype.greaterOrEquals;\n\n BigInteger.prototype.lesserOrEquals = function (v) {\n return this.compare(v) <= 0;\n };\n NativeBigInt.prototype.leq = NativeBigInt.prototype.lesserOrEquals = SmallInteger.prototype.leq = SmallInteger.prototype.lesserOrEquals = BigInteger.prototype.leq = BigInteger.prototype.lesserOrEquals;\n\n BigInteger.prototype.isEven = function () {\n return (this.value[0] & 1) === 0;\n };\n SmallInteger.prototype.isEven = function () {\n return (this.value & 1) === 0;\n };\n NativeBigInt.prototype.isEven = function () {\n return (this.value & BigInt(1)) === BigInt(0);\n }\n\n BigInteger.prototype.isOdd = function () {\n return (this.value[0] & 1) === 1;\n };\n SmallInteger.prototype.isOdd = function () {\n return (this.value & 1) === 1;\n };\n NativeBigInt.prototype.isOdd = function () {\n return (this.value & BigInt(1)) === BigInt(1);\n }\n\n BigInteger.prototype.isPositive = function () {\n return !this.sign;\n };\n SmallInteger.prototype.isPositive = function () {\n return this.value > 0;\n };\n NativeBigInt.prototype.isPositive = SmallInteger.prototype.isPositive;\n\n BigInteger.prototype.isNegative = function () {\n return this.sign;\n };\n SmallInteger.prototype.isNegative = function () {\n return this.value < 0;\n };\n NativeBigInt.prototype.isNegative = SmallInteger.prototype.isNegative;\n\n BigInteger.prototype.isUnit = function () {\n return false;\n };\n SmallInteger.prototype.isUnit = function () {\n return Math.abs(this.value) === 1;\n };\n NativeBigInt.prototype.isUnit = function () {\n return this.abs().value === BigInt(1);\n }\n\n BigInteger.prototype.isZero = function () {\n return false;\n };\n SmallInteger.prototype.isZero = function () {\n return this.value === 0;\n };\n NativeBigInt.prototype.isZero = function () {\n return this.value === BigInt(0);\n }\n\n BigInteger.prototype.isDivisibleBy = function (v) {\n var n = parseValue(v);\n if (n.isZero()) return false;\n if (n.isUnit()) return true;\n if (n.compareAbs(2) === 0) return this.isEven();\n return this.mod(n).isZero();\n };\n NativeBigInt.prototype.isDivisibleBy = SmallInteger.prototype.isDivisibleBy = BigInteger.prototype.isDivisibleBy;\n\n function isBasicPrime(v) {\n var n = v.abs();\n if (n.isUnit()) return false;\n if (n.equals(2) || n.equals(3) || n.equals(5)) return true;\n if (n.isEven() || n.isDivisibleBy(3) || n.isDivisibleBy(5)) return false;\n if (n.lesser(49)) return true;\n // we don't know if it's prime: let the other functions figure it out\n }\n\n function millerRabinTest(n, a) {\n var nPrev = n.prev(),\n b = nPrev,\n r = 0,\n d, t, i, x;\n while (b.isEven()) b = b.divide(2), r++;\n next: for (i = 0; i < a.length; i++) {\n if (n.lesser(a[i])) continue;\n x = bigInt(a[i]).modPow(b, n);\n if (x.isUnit() || x.equals(nPrev)) continue;\n for (d = r - 1; d != 0; d--) {\n x = x.square().mod(n);\n if (x.isUnit()) return false;\n if (x.equals(nPrev)) continue next;\n }\n return false;\n }\n return true;\n }\n\n // Set \"strict\" to true to force GRH-supported lower bound of 2*log(N)^2\n BigInteger.prototype.isPrime = function (strict) {\n var isPrime = isBasicPrime(this);\n if (isPrime !== undefined) return isPrime;\n var n = this.abs();\n var bits = n.bitLength();\n if (bits <= 64)\n return millerRabinTest(n, [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37]);\n var logN = Math.log(2) * bits.toJSNumber();\n var t = Math.ceil((strict === true) ? (2 * Math.pow(logN, 2)) : logN);\n for (var a = [], i = 0; i < t; i++) {\n a.push(bigInt(i + 2));\n }\n return millerRabinTest(n, a);\n };\n NativeBigInt.prototype.isPrime = SmallInteger.prototype.isPrime = BigInteger.prototype.isPrime;\n\n BigInteger.prototype.isProbablePrime = function (iterations) {\n var isPrime = isBasicPrime(this);\n if (isPrime !== undefined) return isPrime;\n var n = this.abs();\n var t = iterations === undefined ? 5 : iterations;\n for (var a = [], i = 0; i < t; i++) {\n a.push(bigInt.randBetween(2, n.minus(2)));\n }\n return millerRabinTest(n, a);\n };\n NativeBigInt.prototype.isProbablePrime = SmallInteger.prototype.isProbablePrime = BigInteger.prototype.isProbablePrime;\n\n BigInteger.prototype.modInv = function (n) {\n var t = bigInt.zero, newT = bigInt.one, r = parseValue(n), newR = this.abs(), q, lastT, lastR;\n while (!newR.isZero()) {\n q = r.divide(newR);\n lastT = t;\n lastR = r;\n t = newT;\n r = newR;\n newT = lastT.subtract(q.multiply(newT));\n newR = lastR.subtract(q.multiply(newR));\n }\n if (!r.isUnit()) throw new Error(this.toString() + \" and \" + n.toString() + \" are not co-prime\");\n if (t.compare(0) === -1) {\n t = t.add(n);\n }\n if (this.isNegative()) {\n return t.negate();\n }\n return t;\n };\n\n NativeBigInt.prototype.modInv = SmallInteger.prototype.modInv = BigInteger.prototype.modInv;\n\n BigInteger.prototype.next = function () {\n var value = this.value;\n if (this.sign) {\n return subtractSmall(value, 1, this.sign);\n }\n return new BigInteger(addSmall(value, 1), this.sign);\n };\n SmallInteger.prototype.next = function () {\n var value = this.value;\n if (value + 1 < MAX_INT) return new SmallInteger(value + 1);\n return new BigInteger(MAX_INT_ARR, false);\n };\n NativeBigInt.prototype.next = function () {\n return new NativeBigInt(this.value + BigInt(1));\n }\n\n BigInteger.prototype.prev = function () {\n var value = this.value;\n if (this.sign) {\n return new BigInteger(addSmall(value, 1), true);\n }\n return subtractSmall(value, 1, this.sign);\n };\n SmallInteger.prototype.prev = function () {\n var value = this.value;\n if (value - 1 > -MAX_INT) return new SmallInteger(value - 1);\n return new BigInteger(MAX_INT_ARR, true);\n };\n NativeBigInt.prototype.prev = function () {\n return new NativeBigInt(this.value - BigInt(1));\n }\n\n var powersOfTwo = [1];\n while (2 * powersOfTwo[powersOfTwo.length - 1] <= BASE) powersOfTwo.push(2 * powersOfTwo[powersOfTwo.length - 1]);\n var powers2Length = powersOfTwo.length, highestPower2 = powersOfTwo[powers2Length - 1];\n\n function shift_isSmall(n) {\n return Math.abs(n) <= BASE;\n }\n\n BigInteger.prototype.shiftLeft = function (v) {\n var n = parseValue(v).toJSNumber();\n if (!shift_isSmall(n)) {\n throw new Error(String(n) + \" is too large for shifting.\");\n }\n if (n < 0) return this.shiftRight(-n);\n var result = this;\n if (result.isZero()) return result;\n while (n >= powers2Length) {\n result = result.multiply(highestPower2);\n n -= powers2Length - 1;\n }\n return result.multiply(powersOfTwo[n]);\n };\n NativeBigInt.prototype.shiftLeft = SmallInteger.prototype.shiftLeft = BigInteger.prototype.shiftLeft;\n\n BigInteger.prototype.shiftRight = function (v) {\n var remQuo;\n var n = parseValue(v).toJSNumber();\n if (!shift_isSmall(n)) {\n throw new Error(String(n) + \" is too large for shifting.\");\n }\n if (n < 0) return this.shiftLeft(-n);\n var result = this;\n while (n >= powers2Length) {\n if (result.isZero() || (result.isNegative() && result.isUnit())) return result;\n remQuo = divModAny(result, highestPower2);\n result = remQuo[1].isNegative() ? remQuo[0].prev() : remQuo[0];\n n -= powers2Length - 1;\n }\n remQuo = divModAny(result, powersOfTwo[n]);\n return remQuo[1].isNegative() ? remQuo[0].prev() : remQuo[0];\n };\n NativeBigInt.prototype.shiftRight = SmallInteger.prototype.shiftRight = BigInteger.prototype.shiftRight;\n\n function bitwise(x, y, fn) {\n y = parseValue(y);\n var xSign = x.isNegative(), ySign = y.isNegative();\n var xRem = xSign ? x.not() : x,\n yRem = ySign ? y.not() : y;\n var xDigit = 0, yDigit = 0;\n var xDivMod = null, yDivMod = null;\n var result = [];\n while (!xRem.isZero() || !yRem.isZero()) {\n xDivMod = divModAny(xRem, highestPower2);\n xDigit = xDivMod[1].toJSNumber();\n if (xSign) {\n xDigit = highestPower2 - 1 - xDigit; // two's complement for negative numbers\n }\n\n yDivMod = divModAny(yRem, highestPower2);\n yDigit = yDivMod[1].toJSNumber();\n if (ySign) {\n yDigit = highestPower2 - 1 - yDigit; // two's complement for negative numbers\n }\n\n xRem = xDivMod[0];\n yRem = yDivMod[0];\n result.push(fn(xDigit, yDigit));\n }\n var sum = fn(xSign ? 1 : 0, ySign ? 1 : 0) !== 0 ? bigInt(-1) : bigInt(0);\n for (var i = result.length - 1; i >= 0; i -= 1) {\n sum = sum.multiply(highestPower2).add(bigInt(result[i]));\n }\n return sum;\n }\n\n BigInteger.prototype.not = function () {\n return this.negate().prev();\n };\n NativeBigInt.prototype.not = SmallInteger.prototype.not = BigInteger.prototype.not;\n\n BigInteger.prototype.and = function (n) {\n return bitwise(this, n, function (a, b) { return a & b; });\n };\n NativeBigInt.prototype.and = SmallInteger.prototype.and = BigInteger.prototype.and;\n\n BigInteger.prototype.or = function (n) {\n return bitwise(this, n, function (a, b) { return a | b; });\n };\n NativeBigInt.prototype.or = SmallInteger.prototype.or = BigInteger.prototype.or;\n\n BigInteger.prototype.xor = function (n) {\n return bitwise(this, n, function (a, b) { return a ^ b; });\n };\n NativeBigInt.prototype.xor = SmallInteger.prototype.xor = BigInteger.prototype.xor;\n\n var LOBMASK_I = 1 << 30, LOBMASK_BI = (BASE & -BASE) * (BASE & -BASE) | LOBMASK_I;\n function roughLOB(n) { // get lowestOneBit (rough)\n // SmallInteger: return Min(lowestOneBit(n), 1 << 30)\n // BigInteger: return Min(lowestOneBit(n), 1 << 14) [BASE=1e7]\n var v = n.value,\n x = typeof v === \"number\" ? v | LOBMASK_I :\n typeof v === \"bigint\" ? v | BigInt(LOBMASK_I) :\n v[0] + v[1] * BASE | LOBMASK_BI;\n return x & -x;\n }\n\n function integerLogarithm(value, base) {\n if (base.compareTo(value) <= 0) {\n var tmp = integerLogarithm(value, base.square(base));\n var p = tmp.p;\n var e = tmp.e;\n var t = p.multiply(base);\n return t.compareTo(value) <= 0 ? { p: t, e: e * 2 + 1 } : { p: p, e: e * 2 };\n }\n return { p: bigInt(1), e: 0 };\n }\n\n BigInteger.prototype.bitLength = function () {\n var n = this;\n if (n.compareTo(bigInt(0)) < 0) {\n n = n.negate().subtract(bigInt(1));\n }\n if (n.compareTo(bigInt(0)) === 0) {\n return bigInt(0);\n }\n return bigInt(integerLogarithm(n, bigInt(2)).e).add(bigInt(1));\n }\n NativeBigInt.prototype.bitLength = SmallInteger.prototype.bitLength = BigInteger.prototype.bitLength;\n\n function max(a, b) {\n a = parseValue(a);\n b = parseValue(b);\n return a.greater(b) ? a : b;\n }\n function min(a, b) {\n a = parseValue(a);\n b = parseValue(b);\n return a.lesser(b) ? a : b;\n }\n function gcd(a, b) {\n a = parseValue(a).abs();\n b = parseValue(b).abs();\n if (a.equals(b)) return a;\n if (a.isZero()) return b;\n if (b.isZero()) return a;\n var c = Integer[1], d, t;\n while (a.isEven() && b.isEven()) {\n d = min(roughLOB(a), roughLOB(b));\n a = a.divide(d);\n b = b.divide(d);\n c = c.multiply(d);\n }\n while (a.isEven()) {\n a = a.divide(roughLOB(a));\n }\n do {\n while (b.isEven()) {\n b = b.divide(roughLOB(b));\n }\n if (a.greater(b)) {\n t = b; b = a; a = t;\n }\n b = b.subtract(a);\n } while (!b.isZero());\n return c.isUnit() ? a : a.multiply(c);\n }\n function lcm(a, b) {\n a = parseValue(a).abs();\n b = parseValue(b).abs();\n return a.divide(gcd(a, b)).multiply(b);\n }\n function randBetween(a, b) {\n a = parseValue(a);\n b = parseValue(b);\n var low = min(a, b), high = max(a, b);\n var range = high.subtract(low).add(1);\n if (range.isSmall) return low.add(Math.floor(Math.random() * range));\n var digits = toBase(range, BASE).value;\n var result = [], restricted = true;\n for (var i = 0; i < digits.length; i++) {\n var top = restricted ? digits[i] : BASE;\n var digit = truncate(Math.random() * top);\n result.push(digit);\n if (digit < top) restricted = false;\n }\n return low.add(Integer.fromArray(result, BASE, false));\n }\n\n var parseBase = function (text, base, alphabet, caseSensitive) {\n alphabet = alphabet || DEFAULT_ALPHABET;\n text = String(text);\n if (!caseSensitive) {\n text = text.toLowerCase();\n alphabet = alphabet.toLowerCase();\n }\n var length = text.length;\n var i;\n var absBase = Math.abs(base);\n var alphabetValues = {};\n for (i = 0; i < alphabet.length; i++) {\n alphabetValues[alphabet[i]] = i;\n }\n for (i = 0; i < length; i++) {\n var c = text[i];\n if (c === \"-\") continue;\n if (c in alphabetValues) {\n if (alphabetValues[c] >= absBase) {\n if (c === \"1\" && absBase === 1) continue;\n throw new Error(c + \" is not a valid digit in base \" + base + \".\");\n }\n }\n }\n base = parseValue(base);\n var digits = [];\n var isNegative = text[0] === \"-\";\n for (i = isNegative ? 1 : 0; i < text.length; i++) {\n var c = text[i];\n if (c in alphabetValues) digits.push(parseValue(alphabetValues[c]));\n else if (c === \"<\") {\n var start = i;\n do { i++; } while (text[i] !== \">\" && i < text.length);\n digits.push(parseValue(text.slice(start + 1, i)));\n }\n else throw new Error(c + \" is not a valid character\");\n }\n return parseBaseFromArray(digits, base, isNegative);\n };\n\n function parseBaseFromArray(digits, base, isNegative) {\n var val = Integer[0], pow = Integer[1], i;\n for (i = digits.length - 1; i >= 0; i--) {\n val = val.add(digits[i].times(pow));\n pow = pow.times(base);\n }\n return isNegative ? val.negate() : val;\n }\n\n function stringify(digit, alphabet) {\n alphabet = alphabet || DEFAULT_ALPHABET;\n if (digit < alphabet.length) {\n return alphabet[digit];\n }\n return \"<\" + digit + \">\";\n }\n\n function toBase(n, base) {\n base = bigInt(base);\n if (base.isZero()) {\n if (n.isZero()) return { value: [0], isNegative: false };\n throw new Error(\"Cannot convert nonzero numbers to base 0.\");\n }\n if (base.equals(-1)) {\n if (n.isZero()) return { value: [0], isNegative: false };\n if (n.isNegative())\n return {\n value: [].concat.apply([], Array.apply(null, Array(-n.toJSNumber()))\n .map(Array.prototype.valueOf, [1, 0])\n ),\n isNegative: false\n };\n\n var arr = Array.apply(null, Array(n.toJSNumber() - 1))\n .map(Array.prototype.valueOf, [0, 1]);\n arr.unshift([1]);\n return {\n value: [].concat.apply([], arr),\n isNegative: false\n };\n }\n\n var neg = false;\n if (n.isNegative() && base.isPositive()) {\n neg = true;\n n = n.abs();\n }\n if (base.isUnit()) {\n if (n.isZero()) return { value: [0], isNegative: false };\n\n return {\n value: Array.apply(null, Array(n.toJSNumber()))\n .map(Number.prototype.valueOf, 1),\n isNegative: neg\n };\n }\n var out = [];\n var left = n, divmod;\n while (left.isNegative() || left.compareAbs(base) >= 0) {\n divmod = left.divmod(base);\n left = divmod.quotient;\n var digit = divmod.remainder;\n if (digit.isNegative()) {\n digit = base.minus(digit).abs();\n left = left.next();\n }\n out.push(digit.toJSNumber());\n }\n out.push(left.toJSNumber());\n return { value: out.reverse(), isNegative: neg };\n }\n\n function toBaseString(n, base, alphabet) {\n var arr = toBase(n, base);\n return (arr.isNegative ? \"-\" : \"\") + arr.value.map(function (x) {\n return stringify(x, alphabet);\n }).join('');\n }\n\n BigInteger.prototype.toArray = function (radix) {\n return toBase(this, radix);\n };\n\n SmallInteger.prototype.toArray = function (radix) {\n return toBase(this, radix);\n };\n\n NativeBigInt.prototype.toArray = function (radix) {\n return toBase(this, radix);\n };\n\n BigInteger.prototype.toString = function (radix, alphabet) {\n if (radix === undefined) radix = 10;\n if (radix !== 10) return toBaseString(this, radix, alphabet);\n var v = this.value, l = v.length, str = String(v[--l]), zeros = \"0000000\", digit;\n while (--l >= 0) {\n digit = String(v[l]);\n str += zeros.slice(digit.length) + digit;\n }\n var sign = this.sign ? \"-\" : \"\";\n return sign + str;\n };\n\n SmallInteger.prototype.toString = function (radix, alphabet) {\n if (radix === undefined) radix = 10;\n if (radix != 10) return toBaseString(this, radix, alphabet);\n return String(this.value);\n };\n\n NativeBigInt.prototype.toString = SmallInteger.prototype.toString;\n\n NativeBigInt.prototype.toJSON = BigInteger.prototype.toJSON = SmallInteger.prototype.toJSON = function () { return this.toString(); }\n\n BigInteger.prototype.valueOf = function () {\n return parseInt(this.toString(), 10);\n };\n BigInteger.prototype.toJSNumber = BigInteger.prototype.valueOf;\n\n SmallInteger.prototype.valueOf = function () {\n return this.value;\n };\n SmallInteger.prototype.toJSNumber = SmallInteger.prototype.valueOf;\n NativeBigInt.prototype.valueOf = NativeBigInt.prototype.toJSNumber = function () {\n return parseInt(this.toString(), 10);\n }\n\n function parseStringValue(v) {\n if (isPrecise(+v)) {\n var x = +v;\n if (x === truncate(x))\n return supportsNativeBigInt ? new NativeBigInt(BigInt(x)) : new SmallInteger(x);\n throw new Error(\"Invalid integer: \" + v);\n }\n var sign = v[0] === \"-\";\n if (sign) v = v.slice(1);\n var split = v.split(/e/i);\n if (split.length > 2) throw new Error(\"Invalid integer: \" + split.join(\"e\"));\n if (split.length === 2) {\n var exp = split[1];\n if (exp[0] === \"+\") exp = exp.slice(1);\n exp = +exp;\n if (exp !== truncate(exp) || !isPrecise(exp)) throw new Error(\"Invalid integer: \" + exp + \" is not a valid exponent.\");\n var text = split[0];\n var decimalPlace = text.indexOf(\".\");\n if (decimalPlace >= 0) {\n exp -= text.length - decimalPlace - 1;\n text = text.slice(0, decimalPlace) + text.slice(decimalPlace + 1);\n }\n if (exp < 0) throw new Error(\"Cannot include negative exponent part for integers\");\n text += (new Array(exp + 1)).join(\"0\");\n v = text;\n }\n var isValid = /^([0-9][0-9]*)$/.test(v);\n if (!isValid) throw new Error(\"Invalid integer: \" + v);\n if (supportsNativeBigInt) {\n return new NativeBigInt(BigInt(sign ? \"-\" + v : v));\n }\n var r = [], max = v.length, l = LOG_BASE, min = max - l;\n while (max > 0) {\n r.push(+v.slice(min, max));\n min -= l;\n if (min < 0) min = 0;\n max -= l;\n }\n trim(r);\n return new BigInteger(r, sign);\n }\n\n function parseNumberValue(v) {\n if (supportsNativeBigInt) {\n return new NativeBigInt(BigInt(v));\n }\n if (isPrecise(v)) {\n if (v !== truncate(v)) throw new Error(v + \" is not an integer.\");\n return new SmallInteger(v);\n }\n return parseStringValue(v.toString());\n }\n\n function parseValue(v) {\n if (typeof v === \"number\") {\n return parseNumberValue(v);\n }\n if (typeof v === \"string\") {\n return parseStringValue(v);\n }\n if (typeof v === \"bigint\") {\n return new NativeBigInt(v);\n }\n return v;\n }\n // Pre-define numbers in range [-999,999]\n for (var i = 0; i < 1000; i++) {\n Integer[i] = parseValue(i);\n if (i > 0) Integer[-i] = parseValue(-i);\n }\n // Backwards compatibility\n Integer.one = Integer[1];\n Integer.zero = Integer[0];\n Integer.minusOne = Integer[-1];\n Integer.max = max;\n Integer.min = min;\n Integer.gcd = gcd;\n Integer.lcm = lcm;\n Integer.isInstance = function (x) { return x instanceof BigInteger || x instanceof SmallInteger || x instanceof NativeBigInt; };\n Integer.randBetween = randBetween;\n\n Integer.fromArray = function (digits, base, isNegative) {\n return parseBaseFromArray(digits.map(parseValue), parseValue(base || 10), isNegative);\n };\n\n return Integer;\n})();\n","/* global bigInt */\n/* eslint-disable no-unused-vars */\n\n// We represent a [Z.t] as a javascript 32bit integers if it fits or as a bigInt.\n\n//Provides: ml_z_normalize\n//Requires: bigInt\nfunction ml_z_normalize(x){\n var y = x.toJSNumber () | 0;\n if(x.equals(bigInt(y))) return y;\n return x;\n}\n\n//Provides: ml_z_mul_overflows\nfunction ml_z_mul_overflows(x,y){\n var z = x*y;\n return z != (z|0);\n}\n\n//external init: unit -> unit\n//Provides: ml_z_init\n//Requires: caml_zarith_marshal, caml_zarith_unmarshal, caml_custom_ops, ml_z_hash, ml_z_compare\nfunction ml_z_init(unit) {\n caml_custom_ops['_z'] =\n { serialize : caml_zarith_marshal,\n deserialize : caml_zarith_unmarshal,\n hash : ml_z_hash,\n compare : ml_z_compare,\n };\n return 0 }\n\n//external ml_z_install_frametable: unit -> unit\n//Provides: ml_z_install_frametable const\nfunction ml_z_install_frametable(unit) { return 0 }\n\n//external neg: t -> t\n//Provides: ml_z_neg const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_neg(z1) {\n return ml_z_normalize(bigInt(z1).negate());\n}\n\n//external add: t -> t -> t\n//Provides: ml_z_add const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_add(z1, z2) {\n return ml_z_normalize(bigInt(z1).add(bigInt(z2)));\n}\n\n//external sub: t -> t -> t\n//Provides: ml_z_sub const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_sub(z1, z2) {\n return ml_z_normalize(bigInt(z1).subtract(bigInt(z2)));\n}\n\n//external mul: t -> t -> t\n//Provides: ml_z_mul const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_mul(z1, z2) {\n return ml_z_normalize(bigInt(z1).multiply(bigInt(z2)));\n}\n\n//external div: t -> t -> t\n//Provides: ml_z_div\n//Requires: bigInt, caml_raise_zero_divide, ml_z_normalize\nfunction ml_z_div(z1, z2) {\n z2 = bigInt(z2)\n if(z2.equals(bigInt(0))) caml_raise_zero_divide();\n return ml_z_normalize(bigInt(z1).divide(bigInt(z2)))\n}\n\n//external cdiv: t -> t -> t\n//Provides: ml_z_cdiv\n//Requires: bigInt, ml_z_div, ml_z_sign, ml_z_add\nfunction ml_z_cdiv(z1, z2) {\n var z1_pos = ml_z_sign(z1);\n var z2_pos = ml_z_sign(z2);\n if (z1_pos * z2_pos > 0) /* Multiplication is like a signwise xor */ {\n if (!bigInt(z1).mod(bigInt(z2)).equals(bigInt(0))) {\n return ml_z_add(ml_z_div(z1, z2), bigInt(1)) ;\n }\n }\n return ml_z_div(z1, z2);\n}\n\n//external fdiv: t -> t -> t\n//Provides: ml_z_fdiv\n//Requires: bigInt, ml_z_div, ml_z_sign, ml_z_sub\nfunction ml_z_fdiv(z1, z2) {\n var z1_pos = ml_z_sign(z1);\n var z2_pos = ml_z_sign(z2);\n if (z1_pos * z2_pos < 0) /* Multiplication is like a signwise xor */ {\n if (!bigInt(z1).mod(bigInt(z2)).equals(bigInt(0))) {\n return ml_z_sub(ml_z_div(z1, z2), bigInt(1)) ;\n }\n }\n return ml_z_div(z1, z2);\n}\n\n//external rem: t -> t -> t\n//Provides: ml_z_rem\n//Requires: bigInt, caml_raise_zero_divide, ml_z_normalize\nfunction ml_z_rem(z1, z2) {\n z2 = bigInt(z2);\n if (z2.equals(bigInt(0))) {\n caml_raise_zero_divide();\n }\n return ml_z_normalize(bigInt(z1).mod(z2));\n}\n\n//external div_rem: t -> t -> (t * t)\n//Provides: ml_z_div_rem\n//Requires: ml_z_div, ml_z_rem\nfunction ml_z_div_rem(z1, z2) {\n return [0, ml_z_div(z1,z2), ml_z_rem(z1, z2)]\n}\n//external succ: t -> t\n//Provides: ml_z_succ const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_succ(z1) {\n return ml_z_normalize(bigInt(z1).next());\n}\n\n//external pred: t -> t\n//Provides: ml_z_pred const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_pred(z1) {\n return ml_z_normalize(bigInt(z1).prev());\n}\n\n//external abs: t -> t\n//Provides: ml_z_abs const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_abs(z1) {\n return ml_z_normalize(bigInt(z1).abs());\n}\n\n//external logand: t -> t -> t\n//Provides: ml_z_logand const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_logand(z1, z2) {\n return ml_z_normalize(bigInt(z1).and(bigInt(z2)));\n}\n\n//external logor: t -> t -> t\n//Provides: ml_z_logor const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_logor(z1, z2) {\n return ml_z_normalize(bigInt(z1).or(bigInt(z2)));\n}\n\n//external logxor: t -> t -> t\n//Provides: ml_z_logxor const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_logxor(z1, z2) {\n return ml_z_normalize(bigInt(z1).xor(bigInt(z2)));\n}\n\n//external lognot: t -> t\n//Provides: ml_z_lognot const\n//Requires: bigInt,ml_z_normalize\nfunction ml_z_lognot(z1) {\n return ml_z_normalize(bigInt(z1).not());\n}\n\n//external shift_left: t -> int -> t\n//Provides: ml_z_shift_left const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_shift_left(z1, amt) {\n return ml_z_normalize(bigInt(z1).shiftLeft(amt));\n}\n\n//external shift_right: t -> int -> t\n//Provides: ml_z_shift_right const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_shift_right(z1, amt) {\n return ml_z_normalize(bigInt(z1).shiftRight(amt));\n}\n\n//external shift_right_trunc: t -> int -> t\n//Provides: ml_z_shift_right_trunc const\n//Requires: bigInt, ml_z_div\nfunction ml_z_shift_right_trunc(z1, z2) {\n return ml_z_div(bigInt(z1), bigInt(2).pow(z2))\n}\n\n//external of_int: int -> t\n//Provides: ml_z_of_int const\n//Requires: bigInt\nfunction ml_z_of_int(i) {\n return i | 0;\n}\n\n//external of_int32: int32 -> t\n//Provides: ml_z_of_int32 const\n//Requires: ml_z_of_int\nfunction ml_z_of_int32(i32) {\n return ml_z_of_int(i32);\n}\n\n//external of_nativeint: nativeint -> t\n//Provides: ml_z_of_nativeint const\n//Requires: ml_z_of_int\nfunction ml_z_of_nativeint(z) {\n return ml_z_of_int(z)\n}\n\n//external of_int64: int64 -> t\n//Provides: ml_z_of_int64 const\n//Requires: bigInt, caml_int64_compare, caml_int64_neg, ml_z_normalize\n//Requires: caml_int64_create_lo_hi,caml_int64_hi32,caml_int64_lo32\nfunction ml_z_of_int64(i64) {\n var neg = false;\n if(caml_int64_compare(i64, caml_int64_create_lo_hi(0,0)) < 0) {\n neg = true;\n i64 = caml_int64_neg(i64)\n }\n var lo = caml_int64_lo32(i64) >>> 0;\n var hi = caml_int64_hi32(i64) >>> 0;\n var x = bigInt(lo).add(bigInt(hi).shiftLeft(32));\n if(neg) { x = x.negate() };\n return ml_z_normalize(x)\n}\n\n//external of_float: float -> t\n//Provides: ml_z_of_float\n//Requires: bigInt, caml_raise_constant, caml_named_value, ml_z_normalize\nfunction ml_z_of_float(f1) {\n if(f1 == Infinity || f1 == -Infinity || f1 != f1)\n caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n return ml_z_normalize(bigInt(f1<0?Math.ceil(f1):Math.floor(f1)));\n}\n\n//external to_int: t -> int\n//Provides: ml_z_to_int\n//Requires: bigInt, caml_raise_constant, caml_named_value\nfunction ml_z_to_int(z1) {\n if (z1 == (z1 | 0)) return z1 | 0;\n caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n}\n\n//external to_int32: t -> int32\n//Provides: ml_z_to_int32\n//Requires: ml_z_to_int\nfunction ml_z_to_int32(z1) { return ml_z_to_int(z1) }\n\n//external to_int64: t -> int64\n//Provides: ml_z_to_int64\n//Requires: bigInt, ml_z_fits_int64, caml_raise_constant, caml_named_value\n//Requires: caml_int64_create_lo_hi\nfunction ml_z_to_int64(z1) {\n z1 = bigInt(z1)\n if(!ml_z_fits_int64(z1)) {\n caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n }\n var mask = bigInt(0xffffffff)\n var lo = z1.and(mask).toJSNumber();\n var hi = z1.shiftRight(32).and(mask).toJSNumber();\n var x = caml_int64_create_lo_hi(lo, hi);\n return x;\n}\n\n//external testbit: t -> bool\n//Provides: ml_z_testbit\n//Requires: bigInt\nfunction ml_z_testbit(z,pos){\n z = bigInt(z);\n return (z.shiftRight(pos).and(bigInt(1)).toJSNumber())|0;\n}\n\n//external to_nativeint: t -> nativeint\n//Provides: ml_z_to_nativeint\n//Requires: ml_z_to_int\nfunction ml_z_to_nativeint(z1) { return ml_z_to_int(z1) }\n\n//external format: string -> t -> string\n//Provides: ml_z_format \n//Requires: bigInt\n//Requires: caml_jsbytes_of_string, caml_failwith, caml_string_of_jsbytes, ml_z_normalize\nfunction ml_z_format(fmt, z1) {\n z1 = bigInt(z1);\n var fmt = caml_jsbytes_of_string(fmt);\n // https://github.com/ocaml/Zarith/blob/d0555d451ce295c4497f24a8d9993f8dd23097df/z.mlip#L297\n var base = 10;\n var cas = 0;\n var width = 0;\n var alt = 0;\n var dir = 0;\n var sign = '';\n var pad = ' ';\n var idx = 0;\n var prefix=\"\";\n while(fmt[idx] == '%') idx++;\n for(;; idx++) {\n if(fmt[idx] == '#') alt = 1;\n else if (fmt[idx] == '0') pad = '0';\n else if (fmt[idx] == '-') dir = 1;\n else if (fmt[idx] == ' ' || fmt[idx] == '+') sign = fmt[idx];\n else break;\n }\n if(z1.lt(bigInt(0))){sign = '-';z1 = z1.negate()};\n for(;fmt[idx]>='0' && fmt[idx] <='9';idx++)\n width=10*width + (+fmt[idx]);\n switch(fmt[idx]){\n case 'i': case 'd': case 'u': break;\n case 'b': base = 2; if(alt) prefix = \"0b\"; break;\n case 'o': base = 8; if(alt) prefix = \"0o\"; break;\n case 'x': base = 16; if(alt) prefix = \"0x\"; break;\n case 'X': base = 16; if(alt) prefix = \"0X\"; cas = 1; break;\n default:\n caml_failwith(\"Unsupported format '\" + fmt + \"'\");\n }\n if (dir) pad = ' ';\n var res = z1.toString(base);\n if (cas === 1) {\n res = res.toUpperCase();\n }\n var size = res.length;\n if (pad == ' ') {\n if(dir) {\n res = sign + prefix + res;\n for(;res.length= 48 && code <= 57) return code - 48;\n if(code >= 97 && code <= 102) return code - 97 + 10;\n if(code >= 65 && code <= 70) return code - 65 + 10;\n }\n var i = 0;\n if(s[i] == '-') i++;\n for( ; i < s.length ; i++){\n var c = digit(s.charCodeAt(i));\n if(c == undefined || c >= base)\n caml_invalid_argument(\"Z.of_substring_base: invalid digit\");\n }\n return ml_z_normalize(bigInt(s, base));\n \n}\n\n//external of_substring_base: int -> string -> pos:int -> len:int -> t\n//Provides: ml_z_of_substring_base\n//Requires: jsoo_z_of_js_string_base, caml_jsbytes_of_string, caml_invalid_argument, caml_ml_string_length\nfunction ml_z_of_substring_base(base, s, pos, len) {\n s = caml_jsbytes_of_string(s);\n if(pos != 0 || len != s.length) {\n if (s.length - pos < len) {\n caml_invalid_argument(\"Z.of_substring_base: invalid offset or length\");\n }\n s = s.slice(pos,pos+len);\n }\n return jsoo_z_of_js_string_base(base, s);\n}\n\n//external compare: t -> t -> int\n//Provides: ml_z_compare const\n//Requires: bigInt\nfunction ml_z_compare(z1, z2) {\n return bigInt(z1).compare(bigInt(z2));\n}\n\n//external equal: t -> t -> bool\n//Provides: ml_z_equal const\n//Requires: bigInt\nfunction ml_z_equal(z1, z2) {\n return bigInt(z1).equals(bigInt(z2));\n}\n\n//external sign: t -> int\n//Provides: ml_z_sign const\n//Requires: bigInt\nfunction ml_z_sign(z1) {\n return bigInt(z1).compare(bigInt.zero);\n}\n\n//external gcd: t -> t -> t\n//Provides: ml_z_gcd\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_gcd(z1, z2) {\n return ml_z_normalize(bigInt.gcd(bigInt(z1), bigInt(z2)).abs());\n}\n\n//external numbits: t -> int\n//Provides: ml_z_numbits const\n//Requires: bigInt\nfunction ml_z_numbits(z1) {\n z1 = bigInt(z1).abs();\n var n = 0;\n var upperBound = bigInt.one;\n while (upperBound.leq(z1)) {\n n += 1;\n upperBound = upperBound.multiply(2);\n }\n return n; // 2^{n-1} <= |x| < 2^n\n}\n\n//external fits_int: t -> bool\n//Provides: ml_z_fits_int const\n//Requires: bigInt\nfunction ml_z_fits_int(z1) {\n if(z1 == (z1 | 0)) return 1;\n else return 0;\n}\n\n//external fits_int32: t -> bool\n//Provides: ml_z_fits_int32\n//Requires: ml_z_fits_int\nfunction ml_z_fits_int32(z1) {\n return ml_z_fits_int(z1);\n}\n\n//external fits_int64: t -> bool\n//Provides: ml_z_fits_int64\n//Requires: bigInt\nfunction ml_z_fits_int64(z1) {\n z1 = bigInt(z1)\n if (z1.compare(bigInt(\"9223372036854775807\")) <= 0 && z1.compare(bigInt(\"-9223372036854775808\")) >= 0)\n return 1\n else\n return 0\n}\n\n//external fits_nativeint: t -> bool\n//Provides: ml_z_fits_nativeint\n//Requires: ml_z_fits_int\nfunction ml_z_fits_nativeint(z1) {\n return ml_z_fits_int(z1);\n}\n\n//external powm: t -> t -> t -> t\n//Provides: ml_z_powm\n//Requires: bigInt, ml_z_normalize, ml_z_invert, caml_raise_zero_divide\nfunction ml_z_powm(z1, z2, z3) {\n var zero = bigInt(0);\n var one = bigInt(1);\n z1 = bigInt(z1);\n z2 = bigInt(z2);\n z3 = bigInt(z3);\n if(z3.equals(zero)) caml_raise_zero_divide();\n if(z3.abs().equals(one)) return 0;\n if(z2.equals(zero)) return 1;\n if(z2.lt(0)) {\n var inv = bigInt(ml_z_invert(z1, z3));\n var r = inv.modPow(z2.negate(), z3);\n if(r.lt(zero)) r = r.add(z3.abs());\n return ml_z_normalize(r);\n } else {\n var r = bigInt(z1).modPow(z2, z3);\n if(r.lt(zero)) r = r.add(z3.abs());\n return ml_z_normalize(r);\n }\n}\n\n//external pown: t -> t -> t\n//Provides: ml_z_pow\n//Requires: bigInt, caml_failwith, ml_z_normalize, caml_invalid_argument\nfunction ml_z_pow(z1, i1) {\n i1 = bigInt(i1);\n if (i1.lt(bigInt(0))) {\n caml_invalid_argument(\"Z.pow: exponent must be nonnegative\");\n }\n return ml_z_normalize(bigInt(z1).pow(i1));\n}\n\n//external hash: t -> int\n//Provides: ml_z_hash const\n//Requires: bigInt, caml_hash_mix_int\nfunction ml_z_hash(z1) {\n var a = bigInt(z1).toArray(Math.pow(2, 32));\n var acc = 0;\n for (var i = 0; i < a.value.length; i++) {\n acc = caml_hash_mix_int(acc, a.value[i]);\n }\n if(a.value.length % 2 != 0) {\n acc = caml_hash_mix_int(acc, 0);\n }\n if(a.isNegative){\n acc = acc + 1\n }\n return acc | 0\n}\n\n//external to_bits: t -> string\n//Provides: ml_z_to_bits const\n//Requires: caml_string_of_jsbytes, caml_str_repeat, bigInt\nfunction ml_z_to_bits(z1) {\n z1 = bigInt(z1).abs();\n var res = \"\";\n while(!z1.equals(bigInt(0))){\n res += String.fromCharCode(z1.mod(bigInt(256)));\n z1 = z1.divide(bigInt(256));\n }\n while(res.length % 4 != 0){\n res += String.fromCharCode(0);\n }\n return caml_string_of_jsbytes(res);\n}\n\n//external of_bits: string -> t\n//Provides: ml_z_of_bits const\n//Requires: caml_string_unsafe_get, caml_ml_string_length, bigInt, ml_z_normalize\nfunction ml_z_of_bits(z1) {\n var r = bigInt.zero\n var base1 = bigInt(256);\n var base = bigInt.one;\n for(var i = 0; i < caml_ml_string_length(z1); i++){\n var d = caml_string_unsafe_get(z1,i);\n r = bigInt(base).multiply(d).add(r);\n base = bigInt(base).multiply(base1);\n }\n return ml_z_normalize(r);\n}\n\n//external powm_sec: t -> t -> t -> t\n//Provides: ml_z_powm_sec\n//Requires: bigInt, caml_failwith, ml_z_powm, caml_invalid_argument\nfunction ml_z_powm_sec(z1, z2, z3) {\n z3 = bigInt(z3).abs();\n // powm_sec requires that the exponent be positive\n var one = bigInt(1);\n if (bigInt(z2).lt(one)) {\n caml_invalid_argument(\"Z.powm_sec: exponent must be positive\");\n }\n if (!bigInt(z3).and(one).equals(one)) {\n caml_invalid_argument(\"Z.powm_sec: modulus must be odd\");\n }\n return ml_z_powm(z1, z2, z3)\n}\n\n//external root: t -> int -> t\n//Provides: ml_z_root\n//Requires: ml_z_pow, bigInt, ml_z_normalize, caml_invalid_argument\nfunction ml_z_root(z, i) {\n var zero = bigInt(0);\n var one = bigInt(1);\n z = bigInt(z);\n\n if (i % 2 === 0 && z.lt(zero)) {\n caml_invalid_argument(\"Z.root: even root of a negative number\");\n }\n\n if (z.equals(zero) || z.equals(one)) {\n return ml_z_normalize(z);\n }\n\n var start = zero;\n var end = z;\n var ans = null;\n\n var two = bigInt(2);\n\n while (start.leq(end))\n {\n var mid = start.add(end).divide(two);\n var po = mid.pow(i);\n if (po.equals(z)) {\n return ml_z_normalize(mid);\n } else if (po.lt(z)) {\n start = mid.next();\n ans = mid;\n } else {\n end = mid.prev();\n }\n }\n return ml_z_normalize(ans);\n}\n\n//external invert: t -> t -> t\n//Provides: ml_z_invert\n//Requires: bigInt, caml_raise_zero_divide, ml_z_gcdext_intern, ml_z_normalize\nfunction ml_z_invert(a, n) {\n // Because [a.modInv(n)] produces different results for edge cases,\n // we wrote our own implementation based on gcdext_intern.\n a = bigInt(a);\n n = bigInt(n);\n var zero = bigInt(0);\n var one = bigInt(1);\n if(n.abs().equals(one))\n return 0;\n if (n.equals(zero) && a.abs().equals(one)) {\n return a;\n }\n if (n.equals(zero) || a.equals(zero)) {\n caml_raise_zero_divide();\n }\n var x = ml_z_gcdext_intern(a, n);\n var r = bigInt(x[2]);\n var tmp = bigInt(a).multiply(r).mod(n);\n if(tmp.lt(zero)) tmp = tmp.add(n.abs());\n if(r.lt(zero)) r = r.add(n.abs());\n if(tmp.equals(one)) {\n return ml_z_normalize(r);\n }\n caml_raise_zero_divide();\n}\n\n//external perfect_power: t -> bool\n//Provides: ml_z_perfect_power\n//Requires: bigInt, caml_failwith, ml_z_numbits, ml_z_root, ml_z_pow\nfunction ml_z_perfect_power(z) {\n // Return true if op is a perfect power, i.e., if there exist integers a and\n // b, with b > 1, such that op = a^b.\n // Otherwise false.\n z = bigInt(z);\n var zero = bigInt(0);\n var one = bigInt(1);\n\n if (z.equals(zero) || z.equals(one) || z.equals(one.negate())) {\n return 1;\n }\n var log2z = ml_z_numbits(z.abs());\n for (var b = 2; b <= log2z; b++) {\n if(z.lt(zero) && b % 2 == 0) continue;\n var zp = z.abs();\n var p = bigInt(ml_z_root(zp, b));\n if(z.lt(zero)) p = p.negate();\n var r = bigInt(ml_z_pow(p, b));\n if (z.equals(r)) {\n return 1;\n }\n }\n return 0;\n}\n\n//external perfect_square: t -> bool\n//Provides: ml_z_perfect_square\n//Requires: bigInt, ml_z_root\nfunction ml_z_perfect_square(z) {\n z = bigInt(z);\n if (z.lt(bigInt(0))) {\n return 0;\n }\n var root = bigInt(ml_z_root(z, 2));\n if (root.multiply(root).eq(z)) {\n return 1;\n }\n else {\n return 0\n };\n}\n\n//external probab_prime: t -> int -> int\n//Provides: ml_z_probab_prime const\n//Requires: bigInt\nfunction ml_z_probab_prime(z, i) {\n if (bigInt(z).isProbablePrime(i)) {\n return 1;\n } else {\n return 0;\n }\n}\n\n//external nextprime: t -> t\n//Provides: ml_z_nextprime const\n//Requires: bigInt, ml_z_normalize\nfunction ml_z_nextprime(z1) {\n // Interestingly, the zarith next_prime only returns \n // probabalistic primes. We do the same, with the \n // same probablistic parameter of 25.\n // https://fossies.org/dox/gmp-6.1.2/mpz_2nextprime_8c_source.html\n \n z1 = bigInt(z1)\n var one = bigInt(1);\n var two = bigInt(2);\n\n if (z1.lt(one) || z1.equals(one)) {\n return 2;\n }\n\n if (z1.and(one).equals(one)) {\n z1 = z1.add(two);\n } else {\n z1 = z1.add(one);\n }\n\n while (true) {\n if (z1.isProbablePrime(25)) {\n return ml_z_normalize(z1);\n } else {\n z1 = z1.add(two)\n }\n }\n}\n\n//external extract: t -> int -> int -> t\n//Provides: ml_z_extract\n//Requires: caml_failwith, bigInt, ml_z_normalize\nfunction ml_z_extract(z1, pos, len) {\n z1 = bigInt(z1);\n return ml_z_normalize(z1.shiftRight(pos).and(bigInt(2).pow(len).subtract(1)));\n}\n\n//external gcdext_intern: t -> t -> (t * t * bool)\n//Provides: ml_z_gcdext_intern\n//Requires: bigInt, caml_raise_zero_divide, ml_z_normalize\nfunction ml_z_gcdext_intern(z1, z2) {\n z1 = bigInt(z1);\n z2 = bigInt(z2);\n var gcd = bigInt.gcd(z1,z2);\n var a = z1;\n var b = z2;\n var x = bigInt(0);\n var lastx = bigInt(1);\n var y = bigInt(1);\n var lasty = bigInt(1);\n var q, t, r;\n if(z1.equals(bigInt(0))) {\n caml_raise_zero_divide();\n }\n while(!b.equals(bigInt(0))) {\n q = a.divide(b);\n r = a.subtract(q.multiply(b));\n t = x;\n x = lastx.subtract(q.multiply(x));\n lastx = t;\n t = y;\n y = lasty.subtract(q.multiply(y));\n lasty = t;\n a = b;\n b = r;\n }\n if(a.lt(bigInt(0)))\n return [0,ml_z_normalize(a.negate()),ml_z_normalize(lastx.negate()),1]\n else\n return [0,ml_z_normalize(a),ml_z_normalize(lastx),1]\n}\n\n//external sqrt: t -> t\n//Provides: ml_z_sqrt\n//Requires: bigInt, ml_z_root, caml_invalid_argument\nfunction ml_z_sqrt(z1) {\n var z = bigInt(z1);\n var zero = bigInt(0);\n if (z.lt(zero)) {\n caml_invalid_argument(\"Z.sqrt: square root of a negative number\");\n }\n return ml_z_root(z, 2);\n}\n\n//external sqrt_rem: t -> (t * t)\n//Provides: ml_z_sqrt_rem\n//Requires: bigInt, ml_z_root, caml_invalid_argument, ml_z_normalize\nfunction ml_z_sqrt_rem(z) {\n z = bigInt(z);\n var zero = bigInt(0);\n if (z.lt(zero)) {\n caml_invalid_argument(\"Z.sqrt_rem: square root of a negative number\");\n }\n var root = bigInt(ml_z_root(z, 2));\n var mul = root.multiply(root);\n var diff = z.subtract(mul);\n return [0, ml_z_normalize(root), ml_z_normalize(diff)]\n}\n\n//external trailing_zeros: t -> int\n//Provides: ml_z_trailing_zeros const\n//Requires: bigInt\nfunction ml_z_trailing_zeros(z) {\n z = bigInt(z).abs();\n var zero = bigInt(0);\n var one = bigInt(1);\n if (z.equals(zero)) {\n // max_int in 32bit\n return 0x7fffffff;\n }\n var i = 0\n z = z.xor(z.prev()).shiftRight(1);\n for (i = 0; !z.equals(bigInt.zero); i++) {\n z = z.shiftRight(1);\n }\n return i;\n}\n\n//external popcount: t -> int\n//Provides: ml_z_popcount\n//Requires: bigInt, caml_raise_constant, caml_named_value\nfunction ml_z_popcount(z) {\n z = bigInt(z);\n var zero = bigInt(0);\n var one = bigInt(1);\n if (z.lt(zero)) {\n caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n }\n var i;\n for (i = 0; !z.equals(zero); i++) {\n z = z.and(z.prev());\n }\n if(i != (i|0)) caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n return i|0;\n}\n\n//external hamdist: t -> t -> int\n//Provides: ml_z_hamdist\n//Requires: bigInt, ml_z_popcount, caml_invalid_argument, caml_raise_constant, caml_named_value\nfunction ml_z_hamdist(z1, z2) {\n if(bigInt(z1).isNegative() != bigInt(z2).isNegative ()){\n caml_raise_constant(caml_named_value(\"ml_z_overflow\"));\n }\n if((z1 != (z1 | 0) || z2 != (z2 | 0)) && (bigInt(z1).isNegative() || bigInt(z2).isNegative ())){\n caml_invalid_argument(\"Z.hamdist: negative arguments\");\n }\n return ml_z_popcount(bigInt(z1).xor(bigInt(z2)));\n}\n\n//external size: t -> int\n//Provides: ml_z_size const\n//Requires: bigInt\nfunction ml_z_size(z1) {\n // Claim to be a 32-bit architecture.\n return bigInt(z1).toArray(Math.pow(2, 32)).value.length;\n}\n\n//external divexact: t -> t -> t\n//Provides: ml_z_divexact\n//Requires: bigInt, ml_z_div\nfunction ml_z_divexact(z1, z2) {\n return ml_z_div(z1, z2);\n}\n\n//Provides: caml_zarith_marshal\n//Requires: bigInt\nfunction caml_zarith_marshal(writer, v, sz) {\n v = bigInt(v);\n var bits = v.toArray(Math.pow(2, 32));\n writer.write(8, bits.isNegative ?1 : 0);\n var block = bits.value.length;\n var len = block * 4;\n writer.write(32, len);\n for(var i = block - 1; i >= 0; i --){\n writer.write(8, (bits.value[i] >>> 0 ) & 0xff);\n writer.write(8, (bits.value[i] >>> 8 ) & 0xff);\n writer.write(8, (bits.value[i] >>> 16) & 0xff);\n writer.write(8, (bits.value[i] >>> 24) & 0xff);\n }\n sz[0] = 4 * (1 + (((len + 3) / 4) | 0));\n sz[1] = 8 * (1 + (((len + 7) / 8) | 0));\n}\n\n//Provides: caml_zarith_unmarshal\n//Requires: bigInt, caml_failwith, ml_z_normalize\nfunction caml_zarith_unmarshal(reader, sz) {\n var negate;\n switch(reader.read8u ()) {\n case 1: negate = true; break;\n case 0: negate = false; break;\n default: caml_failwith(\"input_value: z (malformed input)\");\n }\n var len = reader.read32u();\n var x = bigInt(0);\n for(var i = 0; i < len / 4; i++){\n var y = bigInt(reader.read8u());\n y = y.add((reader.read8u()) << 8);\n y = y.add((reader.read8u()) << 16);\n y = y.add(((reader.read8u()) << 24) >>> 0);\n x = y.shiftLeft(i * 32).add(x);\n }\n if(negate) x = x.negate();\n sz[0] = len + 4;\n return ml_z_normalize(x)\n}\n","///////// TIME_NOW\n\n//Provides: time_now_nanoseconds_since_unix_epoch_or_zero\n//Requires: caml_int64_mul, caml_int64_of_float, caml_int64_of_int32\nvar ms_to_nano = caml_int64_of_int32(1000*1000);\nfunction time_now_nanoseconds_since_unix_epoch_or_zero(){\n var ms = Date.now();\n // multiple by two - int63 integers are shifted to the left\n var ms_i63 = caml_int64_of_float(ms*2);\n return caml_int64_mul(ms_i63,ms_to_nano);\n}\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Operations on internal representations of values *)\n\ntype t\n\ntype raw_data = nativeint\n\nexternal repr : 'a -> t = \"%identity\"\nexternal obj : t -> 'a = \"%identity\"\nexternal magic : 'a -> 'b = \"%identity\"\nexternal is_int : t -> bool = \"%obj_is_int\"\nlet [@inline always] is_block a = not (is_int a)\nexternal tag : t -> int = \"caml_obj_tag\" [@@noalloc]\nexternal set_tag : t -> int -> unit = \"caml_obj_set_tag\"\nexternal size : t -> int = \"%obj_size\"\nexternal reachable_words : t -> int = \"caml_obj_reachable_words\"\nexternal field : t -> int -> t = \"%obj_field\"\nexternal set_field : t -> int -> t -> unit = \"%obj_set_field\"\nexternal floatarray_get : floatarray -> int -> float = \"caml_floatarray_get\"\nexternal floatarray_set :\n floatarray -> int -> float -> unit = \"caml_floatarray_set\"\nlet [@inline always] double_field x i = floatarray_get (obj x : floatarray) i\nlet [@inline always] set_double_field x i v =\n floatarray_set (obj x : floatarray) i v\nexternal raw_field : t -> int -> raw_data = \"caml_obj_raw_field\"\nexternal set_raw_field : t -> int -> raw_data -> unit\n = \"caml_obj_set_raw_field\"\n\nexternal new_block : int -> int -> t = \"caml_obj_block\"\nexternal dup : t -> t = \"caml_obj_dup\"\nexternal truncate : t -> int -> unit = \"caml_obj_truncate\"\nexternal add_offset : t -> Int32.t -> t = \"caml_obj_add_offset\"\nexternal with_tag : int -> t -> t = \"caml_obj_with_tag\"\n\nlet first_non_constant_constructor_tag = 0\nlet last_non_constant_constructor_tag = 245\n\nlet lazy_tag = 246\nlet closure_tag = 247\nlet object_tag = 248\nlet infix_tag = 249\nlet forward_tag = 250\n\nlet no_scan_tag = 251\n\nlet abstract_tag = 251\nlet string_tag = 252\nlet double_tag = 253\nlet double_array_tag = 254\nlet custom_tag = 255\nlet final_tag = custom_tag\n\n\nlet int_tag = 1000\nlet out_of_heap_tag = 1001\nlet unaligned_tag = 1002\n\nmodule Closure = struct\n type info = {\n arity: int;\n start_env: int;\n }\n\n let info_of_raw (info : nativeint) =\n let open Nativeint in\n let arity =\n (* signed: negative for tupled functions *)\n if Sys.word_size = 64 then\n to_int (shift_right info 56)\n else\n to_int (shift_right info 24)\n in\n let start_env =\n (* start_env is unsigned, but we know it can always fit an OCaml\n integer so we use [to_int] instead of [unsigned_to_int]. *)\n to_int (shift_right_logical (shift_left info 8) 9) in\n { arity; start_env }\n\n (* note: we expect a closure, not an infix pointer *)\n let info (obj : t) =\n assert (tag obj = closure_tag);\n info_of_raw (raw_field obj 1)\nend\n\nmodule Extension_constructor =\nstruct\n type t = extension_constructor\n let of_val x =\n let x = repr x in\n let slot =\n if (is_block x) && (tag x) <> object_tag && (size x) >= 1 then field x 0\n else x\n in\n let name =\n if (is_block slot) && (tag slot) = object_tag then field slot 0\n else invalid_arg \"Obj.extension_constructor\"\n in\n if (tag name) = string_tag then (obj slot : t)\n else invalid_arg \"Obj.extension_constructor\"\n\n let [@inline always] name (slot : t) =\n (obj (field (repr slot) 0) : string)\n\n let [@inline always] id (slot : t) =\n (obj (field (repr slot) 1) : int)\nend\n\nlet extension_constructor = Extension_constructor.of_val\nlet extension_name = Extension_constructor.name\nlet extension_id = Extension_constructor.id\n\nmodule Ephemeron = struct\n type obj_t = t\n\n type t (** ephemeron *)\n\n (** To change in sync with weak.h *)\n let additional_values = 2\n let max_ephe_length = Sys.max_array_length - additional_values\n\n external create : int -> t = \"caml_ephe_create\";;\n let create l =\n if not (0 <= l && l <= max_ephe_length) then\n invalid_arg \"Obj.Ephemeron.create\";\n create l\n\n let length x = size(repr x) - additional_values\n\n let raise_if_invalid_offset e o msg =\n if not (0 <= o && o < length e) then\n invalid_arg msg\n\n external get_key: t -> int -> obj_t option = \"caml_ephe_get_key\"\n let get_key e o =\n raise_if_invalid_offset e o \"Obj.Ephemeron.get_key\";\n get_key e o\n\n external get_key_copy: t -> int -> obj_t option = \"caml_ephe_get_key_copy\"\n let get_key_copy e o =\n raise_if_invalid_offset e o \"Obj.Ephemeron.get_key_copy\";\n get_key_copy e o\n\n external set_key: t -> int -> obj_t -> unit = \"caml_ephe_set_key\"\n let set_key e o x =\n raise_if_invalid_offset e o \"Obj.Ephemeron.set_key\";\n set_key e o x\n\n external unset_key: t -> int -> unit = \"caml_ephe_unset_key\"\n let unset_key e o =\n raise_if_invalid_offset e o \"Obj.Ephemeron.unset_key\";\n unset_key e o\n\n external check_key: t -> int -> bool = \"caml_ephe_check_key\"\n let check_key e o =\n raise_if_invalid_offset e o \"Obj.Ephemeron.check_key\";\n check_key e o\n\n external blit_key : t -> int -> t -> int -> int -> unit\n = \"caml_ephe_blit_key\"\n\n let blit_key e1 o1 e2 o2 l =\n if l < 0 || o1 < 0 || o1 > length e1 - l\n || o2 < 0 || o2 > length e2 - l\n then invalid_arg \"Obj.Ephemeron.blit_key\"\n else if l <> 0 then blit_key e1 o1 e2 o2 l\n\n external get_data: t -> obj_t option = \"caml_ephe_get_data\"\n external get_data_copy: t -> obj_t option = \"caml_ephe_get_data_copy\"\n external set_data: t -> obj_t -> unit = \"caml_ephe_set_data\"\n external unset_data: t -> unit = \"caml_ephe_unset_data\"\n external check_data: t -> bool = \"caml_ephe_check_data\"\n external blit_data : t -> t -> unit = \"caml_ephe_blit_data\"\n\nend\n","open Core_kernel\nopen Pickles_types\n\ntype 'n t = (Int64.t, 'n) Vector.t [@@deriving sexp_of]\n\nlet to_bits t =\n Vector.to_list t\n |> List.concat_map ~f:(fun n ->\n let test_bit i = Int64.(shift_right n i land one = one) in\n List.init 64 ~f:test_bit )\n\nmodule Hex64 = struct\n module T = struct\n type t = Int64.t [@@deriving yojson]\n\n (* Modify the [of_yojson] handler to add a case for [`String].\n This isn't necessary when using Yojson's parser, because it will\n correctly infer [`Intlit] for any possible value that appears here.\n However, if this json was constructed from a GraphQL query then it will\n be encoded as a [`String] and the conversion will fail unless we handle\n it ourselves.\n *)\n let of_yojson yojson =\n match yojson with\n | `String x -> (\n try Result.Ok (Int64.of_string x)\n with _ -> Result.Error \"Constant.Make.Hex64.t\" )\n | _ ->\n of_yojson yojson\n\n include (Int64 : module type of Int64 with type t := t)\n\n let to_hex t =\n let lo = t land of_int 0xffffff in\n let mi = (t lsr 24) land of_int 0xffffff in\n let hi = (t lsr 48) land of_int 0xffff in\n sprintf \"%04x%06x%06x\" (to_int_exn hi) (to_int_exn mi) (to_int_exn lo)\n\n let of_hex h =\n let f s = Hex.of_string (\"0x\" ^ s) in\n let hi, lo = String.(f (sub h ~pos:0 ~len:8), f (sub h ~pos:8 ~len:8)) in\n (hi lsl 32) lor lo\n\n let%test_unit \"int64 hex\" =\n Quickcheck.test (Int64.gen_incl zero max_value) ~f:(fun x ->\n assert (equal x (of_hex (to_hex x))) )\n\n let sexp_of_t = Fn.compose String.sexp_of_t to_hex\n\n let t_of_sexp = Fn.compose of_hex String.t_of_sexp\n end\n\n include T\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t = (T.t[@version_asserted])\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Make (N : Pickles_types.Nat.Intf) = struct\n module A = Vector.With_length (N)\n\n let length = 64 * Nat.to_int N.n\n\n type t = Hex64.t A.t [@@deriving sexp, compare, yojson, hash, equal]\n\n let to_bits = to_bits\n\n let of_bits bits =\n let pack =\n List.foldi ~init:Int64.zero ~f:(fun i acc b ->\n if b then Int64.(acc lor shift_left one i) else acc )\n in\n let bits =\n List.groupi ~break:(fun i _ _ -> i mod 64 = 0) bits |> List.map ~f:pack\n in\n let n = List.length bits in\n let n_expected = Nat.to_int N.n in\n assert (n <= n_expected) ;\n let bits = bits @ List.init (n_expected - n) ~f:(fun _ -> Int64.zero) in\n Vector.of_list_and_length_exn bits N.n\n\n let of_tick_field x =\n of_bits (List.take (Backend.Tick.Field.to_bits x) length)\n\n let of_tock_field x =\n of_bits (List.take (Backend.Tock.Field.to_bits x) length)\n\n let to_tick_field t = Backend.Tick.Field.of_bits (to_bits t)\n\n let to_tock_field t = Backend.Tock.Field.of_bits (to_bits t)\n\n let dummy : t = Vector.init N.n ~f:(fun _ -> Int64.one)\n\n let zero : t = Vector.init N.n ~f:(fun _ -> Int64.zero)\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Int64]: 64-bit integers *)\n\nexternal neg : int64 -> int64 = \"%int64_neg\"\nexternal add : int64 -> int64 -> int64 = \"%int64_add\"\nexternal sub : int64 -> int64 -> int64 = \"%int64_sub\"\nexternal mul : int64 -> int64 -> int64 = \"%int64_mul\"\nexternal div : int64 -> int64 -> int64 = \"%int64_div\"\nexternal rem : int64 -> int64 -> int64 = \"%int64_mod\"\nexternal logand : int64 -> int64 -> int64 = \"%int64_and\"\nexternal logor : int64 -> int64 -> int64 = \"%int64_or\"\nexternal logxor : int64 -> int64 -> int64 = \"%int64_xor\"\nexternal shift_left : int64 -> int -> int64 = \"%int64_lsl\"\nexternal shift_right : int64 -> int -> int64 = \"%int64_asr\"\nexternal shift_right_logical : int64 -> int -> int64 = \"%int64_lsr\"\nexternal of_int : int -> int64 = \"%int64_of_int\"\nexternal to_int : int64 -> int = \"%int64_to_int\"\nexternal of_float : float -> int64\n = \"caml_int64_of_float\" \"caml_int64_of_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal to_float : int64 -> float\n = \"caml_int64_to_float\" \"caml_int64_to_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal of_int32 : int32 -> int64 = \"%int64_of_int32\"\nexternal to_int32 : int64 -> int32 = \"%int64_to_int32\"\nexternal of_nativeint : nativeint -> int64 = \"%int64_of_nativeint\"\nexternal to_nativeint : int64 -> nativeint = \"%int64_to_nativeint\"\n\nlet zero = 0L\nlet one = 1L\nlet minus_one = -1L\nlet succ n = add n 1L\nlet pred n = sub n 1L\nlet abs n = if n >= 0L then n else neg n\nlet min_int = 0x8000000000000000L\nlet max_int = 0x7FFFFFFFFFFFFFFFL\nlet lognot n = logxor n (-1L)\n\nlet unsigned_to_int =\n let max_int = of_int Stdlib.max_int in\n fun n ->\n if compare zero n <= 0 && compare n max_int <= 0 then\n Some (to_int n)\n else\n None\n\nexternal format : string -> int64 -> string = \"caml_int64_format\"\nlet to_string n = format \"%d\" n\n\nexternal of_string : string -> int64 = \"caml_int64_of_string\"\n\nlet of_string_opt s =\n (* TODO: expose a non-raising primitive directly. *)\n try Some (of_string s)\n with Failure _ -> None\n\n\n\nexternal bits_of_float : float -> int64\n = \"caml_int64_bits_of_float\" \"caml_int64_bits_of_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal float_of_bits : int64 -> float\n = \"caml_int64_float_of_bits\" \"caml_int64_float_of_bits_unboxed\"\n [@@unboxed] [@@noalloc]\n\ntype t = int64\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nlet equal (x: t) (y: t) = compare x y = 0\n\nlet unsigned_compare n m =\n compare (sub n min_int) (sub m min_int)\n\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\n\n(* Unsigned division from signed division of the same\n bitness. See Warren Jr., Henry S. (2013). Hacker's Delight (2 ed.), Sec 9-3.\n*)\nlet unsigned_div n d =\n if d < zero then\n if unsigned_compare n d < 0 then zero else one\n else\n let q = shift_left (div (shift_right_logical n 1) d) 1 in\n let r = sub n (mul q d) in\n if unsigned_compare r d >= 0 then succ q else q\n\nlet unsigned_rem n d =\n sub n (mul (unsigned_div n d) d)\n","open! Import\nmodule Array = Array0\nmodule Int = Int0\nmodule Char = Char0\n\n(* Unfortunately, because the standard library does not expose\n [Caml.Random.State.default], we have to construct our own. We then build the\n [Caml.Random.int], [Caml.Random.bool] functions and friends using that default state in\n exactly the same way as the standard library.\n\n One other trickiness is that we need access to the unexposed [Caml.Random.State.assign]\n function, which accesses the unexposed state representation. So, we copy the\n [State.repr] type definition and [assign] function to here from the standard library,\n and use [Obj.magic] to get access to the underlying implementation. *)\n\n(* Regression tests ought to be deterministic because that way anyone who breaks the test\n knows that it's their code that broke the test. If tests are nondeterministic, a test\n failure may instead happen because the test runner got unlucky and uncovered an\n existing bug in the code supposedly being \"protected\" by the test in question. *)\nlet forbid_nondeterminism_in_tests ~allow_in_tests =\n if am_testing\n then (\n match allow_in_tests with\n | Some true -> ()\n | None | Some false ->\n failwith\n \"initializing Random with a nondeterministic seed is forbidden in inline tests\")\n;;\n\nexternal random_seed : unit -> int array = \"caml_sys_random_seed\"\n\nlet random_seed ?allow_in_tests () =\n forbid_nondeterminism_in_tests ~allow_in_tests;\n random_seed ()\n;;\n\nmodule State = struct\n (* We allow laziness only for the definition of [default], below, which may lazily call\n [make_self_init]. For all other purposes, we create and use [t] eagerly. *)\n type t = Caml.Random.State.t Lazy.t\n\n let bits t = Caml.Random.State.bits (Lazy.force t)\n let bool t = Caml.Random.State.bool (Lazy.force t)\n let int t x = Caml.Random.State.int (Lazy.force t) x\n let int32 t x = Caml.Random.State.int32 (Lazy.force t) x\n let int64 t x = Caml.Random.State.int64 (Lazy.force t) x\n let nativeint t x = Caml.Random.State.nativeint (Lazy.force t) x\n let make seed = Lazy.from_val (Caml.Random.State.make seed)\n let copy t = Lazy.from_val (Caml.Random.State.copy (Lazy.force t))\n let char t = int t 256 |> Char.unsafe_of_int\n let ascii t = int t 128 |> Char.unsafe_of_int\n\n let make_self_init ?allow_in_tests () =\n forbid_nondeterminism_in_tests ~allow_in_tests;\n Lazy.from_val (Caml.Random.State.make_self_init ())\n ;;\n\n module Repr = struct\n type t =\n { st : int array\n ; mutable idx : int\n }\n\n let of_state : Caml.Random.State.t -> t = Caml.Obj.magic\n end\n\n let assign t1 t2 =\n let t1 = Repr.of_state (Lazy.force t1) in\n let t2 = Repr.of_state (Lazy.force t2) in\n Array.blit ~src:t2.st ~src_pos:0 ~dst:t1.st ~dst_pos:0 ~len:(Array.length t1.st);\n t1.idx <- t2.idx\n ;;\n\n let full_init t seed = assign t (make seed)\n\n let default =\n if am_testing\n then (\n (* We define Base's default random state as a copy of OCaml's default random state.\n This means that programs that use Base.Random will see the same sequence of\n random bits as if they had used Caml.Random. However, because [get_state] returns\n a copy, Base.Random and OCaml.Random are not using the same state. If a program\n used both, each of them would go through the same sequence of random bits. To\n avoid that, we reset OCaml's random state to a different seed, giving it a\n different sequence. *)\n let t = Caml.Random.get_state () in\n Caml.Random.init 137;\n Lazy.from_val t)\n else\n lazy\n (* Outside of tests, we initialize random state nondeterministically and lazily.\n We force the random initialization to be lazy so that we do not pay any cost\n for it in programs that do not use randomness. *)\n (Lazy.force (make_self_init ()))\n ;;\n\n let int_on_64bits t bound =\n if bound <= 0x3FFFFFFF (* (1 lsl 30) - 1 *)\n then int t bound\n else Caml.Int64.to_int (int64 t (Caml.Int64.of_int bound))\n ;;\n\n let int_on_32bits t bound =\n (* Not always true with the JavaScript backend. *)\n if bound <= 0x3FFFFFFF (* (1 lsl 30) - 1 *)\n then int t bound\n else Caml.Int32.to_int (int32 t (Caml.Int32.of_int bound))\n ;;\n\n let int =\n match Word_size.word_size with\n | W64 -> int_on_64bits\n | W32 -> int_on_32bits\n ;;\n\n let full_range_int64 =\n let open Caml.Int64 in\n let bits state = of_int (bits state) in\n fun state ->\n logxor\n (bits state)\n (logxor (shift_left (bits state) 30) (shift_left (bits state) 60))\n ;;\n\n let full_range_int32 =\n let open Caml.Int32 in\n let bits state = of_int (bits state) in\n fun state -> logxor (bits state) (shift_left (bits state) 30)\n ;;\n\n let full_range_int_on_64bits state = Caml.Int64.to_int (full_range_int64 state)\n let full_range_int_on_32bits state = Caml.Int32.to_int (full_range_int32 state)\n\n let full_range_int =\n match Word_size.word_size with\n | W64 -> full_range_int_on_64bits\n | W32 -> full_range_int_on_32bits\n ;;\n\n let full_range_nativeint_on_64bits state =\n Caml.Int64.to_nativeint (full_range_int64 state)\n ;;\n\n let full_range_nativeint_on_32bits state =\n Caml.Nativeint.of_int32 (full_range_int32 state)\n ;;\n\n let full_range_nativeint =\n match Word_size.word_size with\n | W64 -> full_range_nativeint_on_64bits\n | W32 -> full_range_nativeint_on_32bits\n ;;\n\n let raise_crossed_bounds name lower_bound upper_bound string_of_bound =\n Printf.failwithf\n \"Random.%s: crossed bounds [%s > %s]\"\n name\n (string_of_bound lower_bound)\n (string_of_bound upper_bound)\n ()\n [@@cold] [@@inline never] [@@local never] [@@specialise never]\n ;;\n\n let int_incl =\n let rec in_range state lo hi =\n let int = full_range_int state in\n if int >= lo && int <= hi then int else in_range state lo hi\n in\n fun state lo hi ->\n if lo > hi then raise_crossed_bounds \"int\" lo hi Int.to_string;\n let diff = hi - lo in\n if diff = Int.max_value\n then lo + (full_range_int state land Int.max_value)\n else if diff >= 0\n then lo + int state (Int.succ diff)\n else in_range state lo hi\n ;;\n\n let int32_incl =\n let open Int32_replace_polymorphic_compare in\n let rec in_range state lo hi =\n let int = full_range_int32 state in\n if int >= lo && int <= hi then int else in_range state lo hi\n in\n let open Caml.Int32 in\n fun state lo hi ->\n if lo > hi then raise_crossed_bounds \"int32\" lo hi to_string;\n let diff = sub hi lo in\n if diff = max_int\n then add lo (logand (full_range_int32 state) max_int)\n else if diff >= 0l\n then add lo (int32 state (succ diff))\n else in_range state lo hi\n ;;\n\n let nativeint_incl =\n let open Nativeint_replace_polymorphic_compare in\n let rec in_range state lo hi =\n let int = full_range_nativeint state in\n if int >= lo && int <= hi then int else in_range state lo hi\n in\n let open Caml.Nativeint in\n fun state lo hi ->\n if lo > hi then raise_crossed_bounds \"nativeint\" lo hi to_string;\n let diff = sub hi lo in\n if diff = max_int\n then add lo (logand (full_range_nativeint state) max_int)\n else if diff >= 0n\n then add lo (nativeint state (succ diff))\n else in_range state lo hi\n ;;\n\n let int64_incl =\n let open Int64_replace_polymorphic_compare in\n let rec in_range state lo hi =\n let int = full_range_int64 state in\n if int >= lo && int <= hi then int else in_range state lo hi\n in\n let open Caml.Int64 in\n fun state lo hi ->\n if lo > hi then raise_crossed_bounds \"int64\" lo hi to_string;\n let diff = sub hi lo in\n if diff = max_int\n then add lo (logand (full_range_int64 state) max_int)\n else if diff >= 0L\n then add lo (int64 state (succ diff))\n else in_range state lo hi\n ;;\n\n (* Return a uniformly random float in [0, 1). *)\n let rec rawfloat state =\n let open Float_replace_polymorphic_compare in\n let scale = 0x1p-30 in\n (* 2^-30 *)\n let r1 = Caml.float_of_int (bits state) in\n let r2 = Caml.float_of_int (bits state) in\n let result = ((r1 *. scale) +. r2) *. scale in\n (* With very small probability, result can round up to 1.0, so in that case, we just\n try again. *)\n if result < 1.0 then result else rawfloat state\n ;;\n\n let float state hi = rawfloat state *. hi\n\n let float_range state lo hi =\n let open Float_replace_polymorphic_compare in\n if lo > hi then raise_crossed_bounds \"float\" lo hi Caml.string_of_float;\n lo +. float state (hi -. lo)\n ;;\nend\n\nlet default = State.default\nlet bits () = State.bits default\nlet int x = State.int default x\nlet int32 x = State.int32 default x\nlet nativeint x = State.nativeint default x\nlet int64 x = State.int64 default x\nlet float x = State.float default x\nlet int_incl x y = State.int_incl default x y\nlet int32_incl x y = State.int32_incl default x y\nlet nativeint_incl x y = State.nativeint_incl default x y\nlet int64_incl x y = State.int64_incl default x y\nlet float_range x y = State.float_range default x y\nlet bool () = State.bool default\nlet char () = State.char default\nlet ascii () = State.ascii default\nlet full_init seed = State.full_init default seed\nlet init seed = full_init [| seed |]\nlet self_init ?allow_in_tests () = full_init (random_seed ?allow_in_tests ())\nlet set_state s = State.assign default s\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* The run-time library for lexers generated by camllex *)\n\ntype position = {\n pos_fname : string;\n pos_lnum : int;\n pos_bol : int;\n pos_cnum : int;\n}\n\nlet dummy_pos = {\n pos_fname = \"\";\n pos_lnum = 0;\n pos_bol = 0;\n pos_cnum = -1;\n}\n\ntype lexbuf =\n { refill_buff : lexbuf -> unit;\n mutable lex_buffer : bytes;\n mutable lex_buffer_len : int;\n mutable lex_abs_pos : int;\n mutable lex_start_pos : int;\n mutable lex_curr_pos : int;\n mutable lex_last_pos : int;\n mutable lex_last_action : int;\n mutable lex_eof_reached : bool;\n mutable lex_mem : int array;\n mutable lex_start_p : position;\n mutable lex_curr_p : position;\n }\n\ntype lex_tables =\n { lex_base: string;\n lex_backtrk: string;\n lex_default: string;\n lex_trans: string;\n lex_check: string;\n lex_base_code : string;\n lex_backtrk_code : string;\n lex_default_code : string;\n lex_trans_code : string;\n lex_check_code : string;\n lex_code: string;}\n\nexternal c_engine : lex_tables -> int -> lexbuf -> int = \"caml_lex_engine\"\nexternal c_new_engine : lex_tables -> int -> lexbuf -> int\n = \"caml_new_lex_engine\"\n\nlet engine tbl state buf =\n let result = c_engine tbl state buf in\n if result >= 0 && buf.lex_curr_p != dummy_pos then begin\n buf.lex_start_p <- buf.lex_curr_p;\n buf.lex_curr_p <- {buf.lex_curr_p\n with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n end;\n result\n\n\nlet new_engine tbl state buf =\n let result = c_new_engine tbl state buf in\n if result >= 0 && buf.lex_curr_p != dummy_pos then begin\n buf.lex_start_p <- buf.lex_curr_p;\n buf.lex_curr_p <- {buf.lex_curr_p\n with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n end;\n result\n\nlet lex_refill read_fun aux_buffer lexbuf =\n let read =\n read_fun aux_buffer (Bytes.length aux_buffer) in\n let n =\n if read > 0\n then read\n else (lexbuf.lex_eof_reached <- true; 0) in\n (* Current state of the buffer:\n <-------|---------------------|----------->\n | junk | valid data | junk |\n ^ ^ ^ ^\n 0 start_pos buffer_end Bytes.length buffer\n *)\n if lexbuf.lex_buffer_len + n > Bytes.length lexbuf.lex_buffer then begin\n (* There is not enough space at the end of the buffer *)\n if lexbuf.lex_buffer_len - lexbuf.lex_start_pos + n\n <= Bytes.length lexbuf.lex_buffer\n then begin\n (* But there is enough space if we reclaim the junk at the beginning\n of the buffer *)\n Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos\n lexbuf.lex_buffer 0\n (lexbuf.lex_buffer_len - lexbuf.lex_start_pos)\n end else begin\n (* We must grow the buffer. Doubling its size will provide enough\n space since n <= String.length aux_buffer <= String.length buffer.\n Watch out for string length overflow, though. *)\n let newlen =\n Int.min (2 * Bytes.length lexbuf.lex_buffer) Sys.max_string_length in\n if lexbuf.lex_buffer_len - lexbuf.lex_start_pos + n > newlen\n then failwith \"Lexing.lex_refill: cannot grow buffer\";\n let newbuf = Bytes.create newlen in\n (* Copy the valid data to the beginning of the new buffer *)\n Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos\n newbuf 0\n (lexbuf.lex_buffer_len - lexbuf.lex_start_pos);\n lexbuf.lex_buffer <- newbuf\n end;\n (* Reallocation or not, we have shifted the data left by\n start_pos characters; update the positions *)\n let s = lexbuf.lex_start_pos in\n lexbuf.lex_abs_pos <- lexbuf.lex_abs_pos + s;\n lexbuf.lex_curr_pos <- lexbuf.lex_curr_pos - s;\n lexbuf.lex_start_pos <- 0;\n lexbuf.lex_last_pos <- lexbuf.lex_last_pos - s;\n lexbuf.lex_buffer_len <- lexbuf.lex_buffer_len - s ;\n let t = lexbuf.lex_mem in\n for i = 0 to Array.length t-1 do\n let v = t.(i) in\n if v >= 0 then\n t.(i) <- v-s\n done\n end;\n (* There is now enough space at the end of the buffer *)\n Bytes.blit aux_buffer 0 lexbuf.lex_buffer lexbuf.lex_buffer_len n;\n lexbuf.lex_buffer_len <- lexbuf.lex_buffer_len + n\n\nlet zero_pos = {\n pos_fname = \"\";\n pos_lnum = 1;\n pos_bol = 0;\n pos_cnum = 0;\n}\n\nlet from_function ?(with_positions = true) f =\n { refill_buff = lex_refill f (Bytes.create 512);\n lex_buffer = Bytes.create 1024;\n lex_buffer_len = 0;\n lex_abs_pos = 0;\n lex_start_pos = 0;\n lex_curr_pos = 0;\n lex_last_pos = 0;\n lex_last_action = 0;\n lex_mem = [||];\n lex_eof_reached = false;\n lex_start_p = if with_positions then zero_pos else dummy_pos;\n lex_curr_p = if with_positions then zero_pos else dummy_pos;\n }\n\nlet from_channel ?with_positions ic =\n from_function ?with_positions (fun buf n -> input ic buf 0 n)\n\nlet from_string ?(with_positions = true) s =\n { refill_buff = (fun lexbuf -> lexbuf.lex_eof_reached <- true);\n lex_buffer = Bytes.of_string s; (* have to make a copy for compatibility\n with unsafe-string mode *)\n lex_buffer_len = String.length s;\n lex_abs_pos = 0;\n lex_start_pos = 0;\n lex_curr_pos = 0;\n lex_last_pos = 0;\n lex_last_action = 0;\n lex_mem = [||];\n lex_eof_reached = true;\n lex_start_p = if with_positions then zero_pos else dummy_pos;\n lex_curr_p = if with_positions then zero_pos else dummy_pos;\n }\n\nlet set_position lexbuf position =\n lexbuf.lex_curr_p <- {position with pos_fname = lexbuf.lex_curr_p.pos_fname};\n lexbuf.lex_abs_pos <- position.pos_cnum\n\nlet set_filename lexbuf fname =\n lexbuf.lex_curr_p <- {lexbuf.lex_curr_p with pos_fname = fname}\n\nlet with_positions lexbuf = lexbuf.lex_curr_p != dummy_pos\n\nlet lexeme lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n Bytes.sub_string lexbuf.lex_buffer lexbuf.lex_start_pos len\n\nlet sub_lexeme lexbuf i1 i2 =\n let len = i2-i1 in\n Bytes.sub_string lexbuf.lex_buffer i1 len\n\nlet sub_lexeme_opt lexbuf i1 i2 =\n if i1 >= 0 then begin\n let len = i2-i1 in\n Some (Bytes.sub_string lexbuf.lex_buffer i1 len)\n end else begin\n None\n end\n\nlet sub_lexeme_char lexbuf i = Bytes.get lexbuf.lex_buffer i\n\nlet sub_lexeme_char_opt lexbuf i =\n if i >= 0 then\n Some (Bytes.get lexbuf.lex_buffer i)\n else\n None\n\n\nlet lexeme_char lexbuf i =\n Bytes.get lexbuf.lex_buffer (lexbuf.lex_start_pos + i)\n\nlet lexeme_start lexbuf = lexbuf.lex_start_p.pos_cnum\nlet lexeme_end lexbuf = lexbuf.lex_curr_p.pos_cnum\n\nlet lexeme_start_p lexbuf = lexbuf.lex_start_p\nlet lexeme_end_p lexbuf = lexbuf.lex_curr_p\n\nlet new_line lexbuf =\n let lcp = lexbuf.lex_curr_p in\n if lcp != dummy_pos then\n lexbuf.lex_curr_p <-\n { lcp with\n pos_lnum = lcp.pos_lnum + 1;\n pos_bol = lcp.pos_cnum;\n }\n\n\n\n(* Discard data left in lexer buffer. *)\n\nlet flush_input lb =\n lb.lex_curr_pos <- 0;\n lb.lex_abs_pos <- 0;\n let lcp = lb.lex_curr_p in\n if lcp != dummy_pos then\n lb.lex_curr_p <- {zero_pos with pos_fname = lcp.pos_fname};\n lb.lex_buffer_len <- 0;\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Benoit Vaugon, ENSTA *)\n(* *)\n(* Copyright 2014 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nopen CamlinternalFormatBasics\n\n(******************************************************************************)\n (* Tools to manipulate scanning set of chars (see %[...]) *)\n\ntype mutable_char_set = bytes\n\n(* Create a fresh, empty, mutable char set. *)\nlet create_char_set () = Bytes.make 32 '\\000'\n\n(* Add a char in a mutable char set. *)\nlet add_in_char_set char_set c =\n let ind = int_of_char c in\n let str_ind = ind lsr 3 and mask = 1 lsl (ind land 0b111) in\n Bytes.set char_set str_ind\n (char_of_int (int_of_char (Bytes.get char_set str_ind) lor mask))\n\nlet freeze_char_set char_set =\n Bytes.to_string char_set\n\n(* Compute the complement of a char set. *)\nlet rev_char_set char_set =\n let char_set' = create_char_set () in\n for i = 0 to 31 do\n Bytes.set char_set' i\n (char_of_int (int_of_char (String.get char_set i) lxor 0xFF));\n done;\n Bytes.unsafe_to_string char_set'\n\n(* Return true if a `c' is in `char_set'. *)\nlet is_in_char_set char_set c =\n let ind = int_of_char c in\n let str_ind = ind lsr 3 and mask = 1 lsl (ind land 0b111) in\n (int_of_char (String.get char_set str_ind) land mask) <> 0\n\n\n(******************************************************************************)\n (* Ignored param conversion *)\n\n(* GADT used to abstract an existential type parameter. *)\n(* See param_format_of_ignored_format. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) param_format_ebb = Param_format_EBB :\n ('x -> 'a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) param_format_ebb\n\n(* Compute a padding associated to a pad_option (see \"%_42d\"). *)\nlet pad_of_pad_opt pad_opt = match pad_opt with\n | None -> No_padding\n | Some width -> Lit_padding (Right, width)\n\n(* Compute a precision associated to a prec_option (see \"%_.42f\"). *)\nlet prec_of_prec_opt prec_opt = match prec_opt with\n | None -> No_precision\n | Some ndec -> Lit_precision ndec\n\n(* Turn an ignored param into its equivalent not-ignored format node. *)\n(* Used for format pretty-printing and Scanf. *)\nlet param_format_of_ignored_format : type a b c d e f x y .\n (a, b, c, d, y, x) ignored -> (x, b, c, y, e, f) fmt ->\n (a, b, c, d, e, f) param_format_ebb =\nfun ign fmt -> match ign with\n | Ignored_char ->\n Param_format_EBB (Char fmt)\n | Ignored_caml_char ->\n Param_format_EBB (Caml_char fmt)\n | Ignored_string pad_opt ->\n Param_format_EBB (String (pad_of_pad_opt pad_opt, fmt))\n | Ignored_caml_string pad_opt ->\n Param_format_EBB (Caml_string (pad_of_pad_opt pad_opt, fmt))\n | Ignored_int (iconv, pad_opt) ->\n Param_format_EBB (Int (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n | Ignored_int32 (iconv, pad_opt) ->\n Param_format_EBB\n (Int32 (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n | Ignored_nativeint (iconv, pad_opt) ->\n Param_format_EBB\n (Nativeint (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n | Ignored_int64 (iconv, pad_opt) ->\n Param_format_EBB\n (Int64 (iconv, pad_of_pad_opt pad_opt, No_precision, fmt))\n | Ignored_float (pad_opt, prec_opt) ->\n Param_format_EBB\n (Float ((Float_flag_, Float_f),\n pad_of_pad_opt pad_opt, prec_of_prec_opt prec_opt, fmt))\n | Ignored_bool pad_opt ->\n Param_format_EBB (Bool (pad_of_pad_opt pad_opt, fmt))\n | Ignored_format_arg (pad_opt, fmtty) ->\n Param_format_EBB (Format_arg (pad_opt, fmtty, fmt))\n | Ignored_format_subst (pad_opt, fmtty) ->\n Param_format_EBB\n (Format_subst (pad_opt, fmtty, fmt))\n | Ignored_reader ->\n Param_format_EBB (Reader fmt)\n | Ignored_scan_char_set (width_opt, char_set) ->\n Param_format_EBB (Scan_char_set (width_opt, char_set, fmt))\n | Ignored_scan_get_counter counter ->\n Param_format_EBB (Scan_get_counter (counter, fmt))\n | Ignored_scan_next_char ->\n Param_format_EBB (Scan_next_char fmt)\n\n\n(******************************************************************************)\n (* Types *)\n\ntype ('b, 'c) acc_formatting_gen =\n | Acc_open_tag of ('b, 'c) acc\n | Acc_open_box of ('b, 'c) acc\n\n(* Reversed list of printing atoms. *)\n(* Used to accumulate printf arguments. *)\nand ('b, 'c) acc =\n | Acc_formatting_lit of ('b, 'c) acc * formatting_lit\n (* Special fmtting (box) *)\n | Acc_formatting_gen of ('b, 'c) acc * ('b, 'c) acc_formatting_gen\n (* Special fmtting (box) *)\n | Acc_string_literal of ('b, 'c) acc * string (* Literal string *)\n | Acc_char_literal of ('b, 'c) acc * char (* Literal char *)\n | Acc_data_string of ('b, 'c) acc * string (* Generated string *)\n | Acc_data_char of ('b, 'c) acc * char (* Generated char *)\n | Acc_delay of ('b, 'c) acc * ('b -> 'c)\n (* Delayed printing (%a, %t) *)\n | Acc_flush of ('b, 'c) acc (* Flush *)\n | Acc_invalid_arg of ('b, 'c) acc * string\n (* Raise Invalid_argument msg *)\n | End_of_acc\n\n(* List of heterogeneous values. *)\n(* Used to accumulate scanf callback arguments. *)\ntype ('a, 'b) heter_list =\n | Cons : 'c * ('a, 'b) heter_list -> ('c -> 'a, 'b) heter_list\n | Nil : ('b, 'b) heter_list\n\n(* Existential Black Boxes. *)\n(* Used to abstract some existential type parameters. *)\n\n(* GADT type associating a padding and an fmtty. *)\n(* See the type_padding function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) padding_fmtty_ebb = Padding_fmtty_EBB :\n ('x, 'y) padding * ('y, 'b, 'c, 'd, 'e, 'f) fmtty ->\n ('x, 'b, 'c, 'd, 'e, 'f) padding_fmtty_ebb\n\n(* GADT type associating a padding, a precision and an fmtty. *)\n(* See the type_padprec function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) padprec_fmtty_ebb = Padprec_fmtty_EBB :\n ('x, 'y) padding * ('y, 'z) precision * ('z, 'b, 'c, 'd, 'e, 'f) fmtty ->\n ('x, 'b, 'c, 'd, 'e, 'f) padprec_fmtty_ebb\n\n(* GADT type associating a padding and an fmt. *)\n(* See make_padding_fmt_ebb and parse_format functions. *)\ntype ('a, 'b, 'c, 'e, 'f) padding_fmt_ebb = Padding_fmt_EBB :\n (_, 'x -> 'a) padding *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'e, 'f) padding_fmt_ebb\n\n(* GADT type associating a precision and an fmt. *)\n(* See make_precision_fmt_ebb and parse_format functions. *)\ntype ('a, 'b, 'c, 'e, 'f) precision_fmt_ebb = Precision_fmt_EBB :\n (_, 'x -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'e, 'f) precision_fmt_ebb\n\n(* GADT type associating a padding, a precision and an fmt. *)\n(* See make_padprec_fmt_ebb and parse_format functions. *)\ntype ('p, 'b, 'c, 'e, 'f) padprec_fmt_ebb = Padprec_fmt_EBB :\n ('x, 'y) padding * ('y, 'p -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('p, 'b, 'c, 'e, 'f) padprec_fmt_ebb\n\n(* Abstract the 'a and 'd parameters of an fmt. *)\n(* Output type of the format parsing function. *)\ntype ('b, 'c, 'e, 'f) fmt_ebb = Fmt_EBB :\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('b, 'c, 'e, 'f) fmt_ebb\n\n(* GADT type associating an fmtty and an fmt. *)\n(* See the type_format_gen function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) fmt_fmtty_ebb = Fmt_fmtty_EBB :\n ('a, 'b, 'c, 'd, 'y, 'x) fmt *\n ('x, 'b, 'c, 'y, 'e, 'f) fmtty ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt_fmtty_ebb\n\n(* GADT type associating an fmtty and an fmt. *)\n(* See the type_ignored_format_substitution function. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) fmtty_fmt_ebb = Fmtty_fmt_EBB :\n ('a, 'b, 'c, 'd, 'y, 'x) fmtty *\n ('x, 'b, 'c, 'y, 'e, 'f) fmt_fmtty_ebb ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmtty_fmt_ebb\n\n(* Abstract all fmtty type parameters. *)\n(* Used to compare format types. *)\ntype fmtty_ebb = Fmtty_EBB : ('a, 'b, 'c, 'd, 'e, 'f) fmtty -> fmtty_ebb\n\n(* Abstract all padding type parameters. *)\n(* Used to compare paddings. *)\ntype padding_ebb = Padding_EBB : ('a, 'b) padding -> padding_ebb\n\n(* Abstract all precision type parameters. *)\n(* Used to compare precisions. *)\ntype precision_ebb = Precision_EBB : ('a, 'b) precision -> precision_ebb\n\n(******************************************************************************)\n (* Constants *)\n\n(* Default precision for float printing. *)\nlet default_float_precision fconv =\n match snd fconv with\n | Float_f | Float_e | Float_E | Float_g | Float_G | Float_h | Float_H\n | Float_CF -> -6\n (* For %h %H and %#F formats, a negative precision means \"as many digits as\n necessary\". For the other FP formats, we take the absolute value\n of the precision, hence 6 digits by default. *)\n | Float_F -> 12\n (* Default precision for OCaml float printing (%F). *)\n\n(******************************************************************************)\n (* Externals *)\n\nexternal format_float: string -> float -> string\n = \"caml_format_float\"\nexternal format_int: string -> int -> string\n = \"caml_format_int\"\nexternal format_int32: string -> int32 -> string\n = \"caml_int32_format\"\nexternal format_nativeint: string -> nativeint -> string\n = \"caml_nativeint_format\"\nexternal format_int64: string -> int64 -> string\n = \"caml_int64_format\"\nexternal hexstring_of_float: float -> int -> char -> string\n = \"caml_hexstring_of_float\"\n\n(******************************************************************************)\n (* Tools to pretty-print formats *)\n\n(* Type of extensible character buffers. *)\ntype buffer = {\n mutable ind : int;\n mutable bytes : bytes;\n}\n\n(* Create a fresh buffer. *)\nlet buffer_create init_size = { ind = 0; bytes = Bytes.create init_size }\n\n(* Check size of the buffer and grow it if needed. *)\nlet buffer_check_size buf overhead =\n let len = Bytes.length buf.bytes in\n let min_len = buf.ind + overhead in\n if min_len > len then (\n let new_len = Int.max (len * 2) min_len in\n let new_str = Bytes.create new_len in\n Bytes.blit buf.bytes 0 new_str 0 len;\n buf.bytes <- new_str;\n )\n\n(* Add the character `c' to the buffer `buf'. *)\nlet buffer_add_char buf c =\n buffer_check_size buf 1;\n Bytes.set buf.bytes buf.ind c;\n buf.ind <- buf.ind + 1\n\n(* Add the string `s' to the buffer `buf'. *)\nlet buffer_add_string buf s =\n let str_len = String.length s in\n buffer_check_size buf str_len;\n String.blit s 0 buf.bytes buf.ind str_len;\n buf.ind <- buf.ind + str_len\n\n(* Get the content of the buffer. *)\nlet buffer_contents buf =\n Bytes.sub_string buf.bytes 0 buf.ind\n\n(***)\n\n(* Convert an integer conversion to char. *)\nlet char_of_iconv iconv = match iconv with\n | Int_d | Int_pd | Int_sd | Int_Cd -> 'd' | Int_i | Int_pi | Int_si\n | Int_Ci -> 'i' | Int_x | Int_Cx -> 'x' | Int_X | Int_CX -> 'X' | Int_o\n | Int_Co -> 'o' | Int_u | Int_Cu -> 'u'\n\n(* Convert a float conversion to char. *)\n(* `cF' will be 'F' for displaying format and 'g' to call libc printf *)\nlet char_of_fconv ?(cF='F') fconv = match snd fconv with\n | Float_f -> 'f' | Float_e -> 'e'\n | Float_E -> 'E' | Float_g -> 'g'\n | Float_G -> 'G' | Float_F -> cF\n | Float_h -> 'h' | Float_H -> 'H'\n | Float_CF -> 'F'\n\n\n(* Convert a scanning counter to char. *)\nlet char_of_counter counter = match counter with\n | Line_counter -> 'l'\n | Char_counter -> 'n'\n | Token_counter -> 'N'\n\n(***)\n\n(* Print a char_set in a buffer with the OCaml format lexical convention. *)\nlet bprint_char_set buf char_set =\n let rec print_start set =\n let is_alone c =\n let before, after = Char.(chr (code c - 1), chr (code c + 1)) in\n is_in_char_set set c\n && not (is_in_char_set set before && is_in_char_set set after) in\n if is_alone ']' then buffer_add_char buf ']';\n print_out set 1;\n if is_alone '-' then buffer_add_char buf '-';\n and print_out set i =\n if i < 256 then\n if is_in_char_set set (char_of_int i) then print_first set i\n else print_out set (i + 1)\n and print_first set i =\n match char_of_int i with\n | '\\255' -> print_char buf 255;\n | ']' | '-' -> print_out set (i + 1);\n | _ -> print_second set (i + 1);\n and print_second set i =\n if is_in_char_set set (char_of_int i) then\n match char_of_int i with\n | '\\255' ->\n print_char buf 254;\n print_char buf 255;\n | ']' | '-' when not (is_in_char_set set (char_of_int (i + 1))) ->\n print_char buf (i - 1);\n print_out set (i + 1);\n | _ when not (is_in_char_set set (char_of_int (i + 1))) ->\n print_char buf (i - 1);\n print_char buf i;\n print_out set (i + 2);\n | _ ->\n print_in set (i - 1) (i + 2);\n else (\n print_char buf (i - 1);\n print_out set (i + 1);\n )\n and print_in set i j =\n if j = 256 || not (is_in_char_set set (char_of_int j)) then (\n print_char buf i;\n print_char buf (int_of_char '-');\n print_char buf (j - 1);\n if j < 256 then print_out set (j + 1);\n ) else\n print_in set i (j + 1);\n and print_char buf i = match char_of_int i with\n | '%' -> buffer_add_char buf '%'; buffer_add_char buf '%';\n | '@' -> buffer_add_char buf '%'; buffer_add_char buf '@';\n | c -> buffer_add_char buf c;\n in\n buffer_add_char buf '[';\n print_start (\n if is_in_char_set char_set '\\000'\n then ( buffer_add_char buf '^'; rev_char_set char_set )\n else char_set\n );\n buffer_add_char buf ']'\n\n(***)\n\n(* Print a padty in a buffer with the format-like syntax. *)\nlet bprint_padty buf padty = match padty with\n | Left -> buffer_add_char buf '-'\n | Right -> ()\n | Zeros -> buffer_add_char buf '0'\n\n(* Print the '_' of an ignored flag if needed. *)\nlet bprint_ignored_flag buf ign_flag =\n if ign_flag then buffer_add_char buf '_'\n\n(***)\n\nlet bprint_pad_opt buf pad_opt = match pad_opt with\n | None -> ()\n | Some width -> buffer_add_string buf (Int.to_string width)\n\n(***)\n\n(* Print padding in a buffer with the format-like syntax. *)\nlet bprint_padding : type a b . buffer -> (a, b) padding -> unit =\nfun buf pad -> match pad with\n | No_padding -> ()\n | Lit_padding (padty, n) ->\n bprint_padty buf padty;\n buffer_add_string buf (Int.to_string n);\n | Arg_padding padty ->\n bprint_padty buf padty;\n buffer_add_char buf '*'\n\n(* Print precision in a buffer with the format-like syntax. *)\nlet bprint_precision : type a b . buffer -> (a, b) precision -> unit =\n fun buf prec -> match prec with\n | No_precision -> ()\n | Lit_precision n ->\n buffer_add_char buf '.';\n buffer_add_string buf (Int.to_string n);\n | Arg_precision ->\n buffer_add_string buf \".*\"\n\n(***)\n\n(* Print the optional '+', ' ' or '#' associated to an int conversion. *)\nlet bprint_iconv_flag buf iconv = match iconv with\n | Int_pd | Int_pi -> buffer_add_char buf '+'\n | Int_sd | Int_si -> buffer_add_char buf ' '\n | Int_Cx | Int_CX | Int_Co | Int_Cd | Int_Ci | Int_Cu ->\n buffer_add_char buf '#'\n | Int_d | Int_i | Int_x | Int_X | Int_o | Int_u -> ()\n\n(* Print an complete int format in a buffer (ex: \"%3.*d\"). *)\nlet bprint_int_fmt buf ign_flag iconv pad prec =\n buffer_add_char buf '%';\n bprint_ignored_flag buf ign_flag;\n bprint_iconv_flag buf iconv;\n bprint_padding buf pad;\n bprint_precision buf prec;\n buffer_add_char buf (char_of_iconv iconv)\n\n(* Print a complete int32, nativeint or int64 format in a buffer. *)\nlet bprint_altint_fmt buf ign_flag iconv pad prec c =\n buffer_add_char buf '%';\n bprint_ignored_flag buf ign_flag;\n bprint_iconv_flag buf iconv;\n bprint_padding buf pad;\n bprint_precision buf prec;\n buffer_add_char buf c;\n buffer_add_char buf (char_of_iconv iconv)\n\n(***)\n\n(* Print the optional '+', ' ' and/or '#' associated to a float conversion. *)\nlet bprint_fconv_flag buf fconv =\n begin match fst fconv with\n | Float_flag_p -> buffer_add_char buf '+'\n | Float_flag_s -> buffer_add_char buf ' '\n | Float_flag_ -> () end;\n match snd fconv with\n | Float_CF -> buffer_add_char buf '#'\n | Float_f | Float_e | Float_E | Float_g | Float_G\n | Float_F | Float_h | Float_H -> ()\n\n(* Print a complete float format in a buffer (ex: \"%+*.3f\"). *)\nlet bprint_float_fmt buf ign_flag fconv pad prec =\n buffer_add_char buf '%';\n bprint_ignored_flag buf ign_flag;\n bprint_fconv_flag buf fconv;\n bprint_padding buf pad;\n bprint_precision buf prec;\n buffer_add_char buf (char_of_fconv fconv)\n\n(* Compute the literal string representation of a Formatting_lit. *)\n(* Used by Printf and Scanf where formatting is not interpreted. *)\nlet string_of_formatting_lit formatting_lit = match formatting_lit with\n | Close_box -> \"@]\"\n | Close_tag -> \"@}\"\n | Break (str, _, _) -> str\n | FFlush -> \"@?\"\n | Force_newline -> \"@\\n\"\n | Flush_newline -> \"@.\"\n | Magic_size (str, _) -> str\n | Escaped_at -> \"@@\"\n | Escaped_percent -> \"@%\"\n | Scan_indic c -> \"@\" ^ (String.make 1 c)\n\n(***)\n\n(* Print a literal char in a buffer, escape '%' by \"%%\". *)\nlet bprint_char_literal buf chr = match chr with\n | '%' -> buffer_add_string buf \"%%\"\n | _ -> buffer_add_char buf chr\n\n(* Print a literal string in a buffer, escape all '%' by \"%%\". *)\nlet bprint_string_literal buf str =\n for i = 0 to String.length str - 1 do\n bprint_char_literal buf str.[i]\n done\n\n(******************************************************************************)\n (* Format pretty-printing *)\n\n(* Print a complete format type (an fmtty) in a buffer. *)\nlet rec bprint_fmtty : type a b c d e f g h i j k l .\n buffer -> (a, b, c, d, e, f, g, h, i, j, k, l) fmtty_rel -> unit =\nfun buf fmtty -> match fmtty with\n | Char_ty rest -> buffer_add_string buf \"%c\"; bprint_fmtty buf rest;\n | String_ty rest -> buffer_add_string buf \"%s\"; bprint_fmtty buf rest;\n | Int_ty rest -> buffer_add_string buf \"%i\"; bprint_fmtty buf rest;\n | Int32_ty rest -> buffer_add_string buf \"%li\"; bprint_fmtty buf rest;\n | Nativeint_ty rest -> buffer_add_string buf \"%ni\"; bprint_fmtty buf rest;\n | Int64_ty rest -> buffer_add_string buf \"%Li\"; bprint_fmtty buf rest;\n | Float_ty rest -> buffer_add_string buf \"%f\"; bprint_fmtty buf rest;\n | Bool_ty rest -> buffer_add_string buf \"%B\"; bprint_fmtty buf rest;\n | Alpha_ty rest -> buffer_add_string buf \"%a\"; bprint_fmtty buf rest;\n | Theta_ty rest -> buffer_add_string buf \"%t\"; bprint_fmtty buf rest;\n | Any_ty rest -> buffer_add_string buf \"%?\"; bprint_fmtty buf rest;\n | Reader_ty rest -> buffer_add_string buf \"%r\"; bprint_fmtty buf rest;\n\n | Ignored_reader_ty rest ->\n buffer_add_string buf \"%_r\";\n bprint_fmtty buf rest;\n\n | Format_arg_ty (sub_fmtty, rest) ->\n buffer_add_string buf \"%{\"; bprint_fmtty buf sub_fmtty;\n buffer_add_string buf \"%}\"; bprint_fmtty buf rest;\n | Format_subst_ty (sub_fmtty, _, rest) ->\n buffer_add_string buf \"%(\"; bprint_fmtty buf sub_fmtty;\n buffer_add_string buf \"%)\"; bprint_fmtty buf rest;\n\n | End_of_fmtty -> ()\n\n(***)\n\nlet rec int_of_custom_arity : type a b c .\n (a, b, c) custom_arity -> int =\n function\n | Custom_zero -> 0\n | Custom_succ x -> 1 + int_of_custom_arity x\n\n(* Print a complete format in a buffer. *)\nlet bprint_fmt buf fmt =\n let rec fmtiter : type a b c d e f .\n (a, b, c, d, e, f) fmt -> bool -> unit =\n fun fmt ign_flag -> match fmt with\n | String (pad, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_padding buf pad; buffer_add_char buf 's';\n fmtiter rest false;\n | Caml_string (pad, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_padding buf pad; buffer_add_char buf 'S';\n fmtiter rest false;\n\n | Int (iconv, pad, prec, rest) ->\n bprint_int_fmt buf ign_flag iconv pad prec;\n fmtiter rest false;\n | Int32 (iconv, pad, prec, rest) ->\n bprint_altint_fmt buf ign_flag iconv pad prec 'l';\n fmtiter rest false;\n | Nativeint (iconv, pad, prec, rest) ->\n bprint_altint_fmt buf ign_flag iconv pad prec 'n';\n fmtiter rest false;\n | Int64 (iconv, pad, prec, rest) ->\n bprint_altint_fmt buf ign_flag iconv pad prec 'L';\n fmtiter rest false;\n | Float (fconv, pad, prec, rest) ->\n bprint_float_fmt buf ign_flag fconv pad prec;\n fmtiter rest false;\n\n | Char rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf 'c'; fmtiter rest false;\n | Caml_char rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf 'C'; fmtiter rest false;\n | Bool (pad, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_padding buf pad; buffer_add_char buf 'B';\n fmtiter rest false;\n | Alpha rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf 'a'; fmtiter rest false;\n | Theta rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf 't'; fmtiter rest false;\n | Custom (arity, _, rest) ->\n for _i = 1 to int_of_custom_arity arity do\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf '?';\n done;\n fmtiter rest false;\n | Reader rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf 'r'; fmtiter rest false;\n | Flush rest ->\n buffer_add_string buf \"%!\";\n fmtiter rest ign_flag;\n\n | String_literal (str, rest) ->\n bprint_string_literal buf str;\n fmtiter rest ign_flag;\n | Char_literal (chr, rest) ->\n bprint_char_literal buf chr;\n fmtiter rest ign_flag;\n\n | Format_arg (pad_opt, fmtty, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_pad_opt buf pad_opt; buffer_add_char buf '{';\n bprint_fmtty buf fmtty; buffer_add_char buf '%'; buffer_add_char buf '}';\n fmtiter rest false;\n | Format_subst (pad_opt, fmtty, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_pad_opt buf pad_opt; buffer_add_char buf '(';\n bprint_fmtty buf fmtty; buffer_add_char buf '%'; buffer_add_char buf ')';\n fmtiter rest false;\n\n | Scan_char_set (width_opt, char_set, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_pad_opt buf width_opt; bprint_char_set buf char_set;\n fmtiter rest false;\n | Scan_get_counter (counter, rest) ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n buffer_add_char buf (char_of_counter counter);\n fmtiter rest false;\n | Scan_next_char rest ->\n buffer_add_char buf '%'; bprint_ignored_flag buf ign_flag;\n bprint_string_literal buf \"0c\"; fmtiter rest false;\n\n | Ignored_param (ign, rest) ->\n let Param_format_EBB fmt' = param_format_of_ignored_format ign rest in\n fmtiter fmt' true;\n\n | Formatting_lit (fmting_lit, rest) ->\n bprint_string_literal buf (string_of_formatting_lit fmting_lit);\n fmtiter rest ign_flag;\n | Formatting_gen (fmting_gen, rest) ->\n begin match fmting_gen with\n | Open_tag (Format (_, str)) ->\n buffer_add_string buf \"@{\"; buffer_add_string buf str\n | Open_box (Format (_, str)) ->\n buffer_add_string buf \"@[\"; buffer_add_string buf str\n end;\n fmtiter rest ign_flag;\n\n | End_of_format -> ()\n\n in fmtiter fmt false\n\n(***)\n\n(* Convert a format to string. *)\nlet string_of_fmt fmt =\n let buf = buffer_create 16 in\n bprint_fmt buf fmt;\n buffer_contents buf\n\n(******************************************************************************)\n (* Type extraction *)\n\ntype (_, _) eq = Refl : ('a, 'a) eq\n\n(* Invariant: this function is the identity on values.\n\n In particular, if (ty1, ty2) have equal values, then\n (trans (symm ty1) ty2) respects the 'trans' precondition. *)\nlet rec symm : type a1 b1 c1 d1 e1 f1 a2 b2 c2 d2 e2 f2 .\n (a1, b1, c1, d1, e1, f1,\n a2, b2, c2, d2, e2, f2) fmtty_rel\n-> (a2, b2, c2, d2, e2, f2,\n a1, b1, c1, d1, e1, f1) fmtty_rel\n= function\n | Char_ty rest -> Char_ty (symm rest)\n | Int_ty rest -> Int_ty (symm rest)\n | Int32_ty rest -> Int32_ty (symm rest)\n | Int64_ty rest -> Int64_ty (symm rest)\n | Nativeint_ty rest -> Nativeint_ty (symm rest)\n | Float_ty rest -> Float_ty (symm rest)\n | Bool_ty rest -> Bool_ty (symm rest)\n | String_ty rest -> String_ty (symm rest)\n | Theta_ty rest -> Theta_ty (symm rest)\n | Alpha_ty rest -> Alpha_ty (symm rest)\n | Any_ty rest -> Any_ty (symm rest)\n | Reader_ty rest -> Reader_ty (symm rest)\n | Ignored_reader_ty rest -> Ignored_reader_ty (symm rest)\n | Format_arg_ty (ty, rest) ->\n Format_arg_ty (ty, symm rest)\n | Format_subst_ty (ty1, ty2, rest) ->\n Format_subst_ty (ty2, ty1, symm rest)\n | End_of_fmtty -> End_of_fmtty\n\nlet rec fmtty_rel_det : type a1 b c d1 e1 f1 a2 d2 e2 f2 .\n (a1, b, c, d1, e1, f1,\n a2, b, c, d2, e2, f2) fmtty_rel ->\n ((f1, f2) eq -> (a1, a2) eq)\n * ((a1, a2) eq -> (f1, f2) eq)\n * ((e1, e2) eq -> (d1, d2) eq)\n * ((d1, d2) eq -> (e1, e2) eq)\n= function\n | End_of_fmtty ->\n (fun Refl -> Refl),\n (fun Refl -> Refl),\n (fun Refl -> Refl),\n (fun Refl -> Refl)\n | Char_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | String_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Int_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Int32_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Int64_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Nativeint_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Float_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Bool_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n\n | Theta_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Alpha_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Any_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Reader_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n (fun Refl -> let Refl = ed Refl in Refl),\n (fun Refl -> let Refl = de Refl in Refl)\n | Ignored_reader_ty rest ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n (fun Refl -> let Refl = ed Refl in Refl),\n (fun Refl -> let Refl = de Refl in Refl)\n | Format_arg_ty (_ty, rest) ->\n let fa, af, ed, de = fmtty_rel_det rest in\n (fun Refl -> let Refl = fa Refl in Refl),\n (fun Refl -> let Refl = af Refl in Refl),\n ed, de\n | Format_subst_ty (ty1, ty2, rest) ->\n let fa, af, ed, de = fmtty_rel_det rest in\n let ty = trans (symm ty1) ty2 in\n let ag, ga, dj, jd = fmtty_rel_det ty in\n (fun Refl -> let Refl = fa Refl in let Refl = ag Refl in Refl),\n (fun Refl -> let Refl = ga Refl in let Refl = af Refl in Refl),\n (fun Refl -> let Refl = ed Refl in let Refl = dj Refl in Refl),\n (fun Refl -> let Refl = jd Refl in let Refl = de Refl in Refl)\n\n(* Precondition: we assume that the two fmtty_rel arguments have equal\n values (at possibly distinct types); this invariant comes from the way\n fmtty_rel witnesses are produced by the type-checker\n\n The code below uses (assert false) when this assumption is broken. The\n code pattern is the following:\n\n | Foo x, Foo y ->\n (* case where indeed both values\n start with constructor Foo *)\n | Foo _, _\n | _, Foo _ ->\n (* different head constructors: broken precondition *)\n assert false\n*)\nand trans : type\n a1 b1 c1 d1 e1 f1\n a2 b2 c2 d2 e2 f2\n a3 b3 c3 d3 e3 f3\n.\n (a1, b1, c1, d1, e1, f1,\n a2, b2, c2, d2, e2, f2) fmtty_rel\n-> (a2, b2, c2, d2, e2, f2,\n a3, b3, c3, d3, e3, f3) fmtty_rel\n-> (a1, b1, c1, d1, e1, f1,\n a3, b3, c3, d3, e3, f3) fmtty_rel\n= fun ty1 ty2 -> match ty1, ty2 with\n | Char_ty rest1, Char_ty rest2 -> Char_ty (trans rest1 rest2)\n | String_ty rest1, String_ty rest2 -> String_ty (trans rest1 rest2)\n | Bool_ty rest1, Bool_ty rest2 -> Bool_ty (trans rest1 rest2)\n | Int_ty rest1, Int_ty rest2 -> Int_ty (trans rest1 rest2)\n | Int32_ty rest1, Int32_ty rest2 -> Int32_ty (trans rest1 rest2)\n | Int64_ty rest1, Int64_ty rest2 -> Int64_ty (trans rest1 rest2)\n | Nativeint_ty rest1, Nativeint_ty rest2 -> Nativeint_ty (trans rest1 rest2)\n | Float_ty rest1, Float_ty rest2 -> Float_ty (trans rest1 rest2)\n\n | Alpha_ty rest1, Alpha_ty rest2 -> Alpha_ty (trans rest1 rest2)\n | Alpha_ty _, _ -> assert false\n | _, Alpha_ty _ -> assert false\n\n | Theta_ty rest1, Theta_ty rest2 -> Theta_ty (trans rest1 rest2)\n | Theta_ty _, _ -> assert false\n | _, Theta_ty _ -> assert false\n\n | Any_ty rest1, Any_ty rest2 -> Any_ty (trans rest1 rest2)\n | Any_ty _, _ -> assert false\n | _, Any_ty _ -> assert false\n\n | Reader_ty rest1, Reader_ty rest2 -> Reader_ty (trans rest1 rest2)\n | Reader_ty _, _ -> assert false\n | _, Reader_ty _ -> assert false\n\n | Ignored_reader_ty rest1, Ignored_reader_ty rest2 ->\n Ignored_reader_ty (trans rest1 rest2)\n | Ignored_reader_ty _, _ -> assert false\n | _, Ignored_reader_ty _ -> assert false\n\n | Format_arg_ty (ty1, rest1), Format_arg_ty (ty2, rest2) ->\n Format_arg_ty (trans ty1 ty2, trans rest1 rest2)\n | Format_arg_ty _, _ -> assert false\n | _, Format_arg_ty _ -> assert false\n\n | Format_subst_ty (ty11, ty12, rest1),\n Format_subst_ty (ty21, ty22, rest2) ->\n let ty = trans (symm ty12) ty21 in\n let _, f2, _, f4 = fmtty_rel_det ty in\n let Refl = f2 Refl in\n let Refl = f4 Refl in\n Format_subst_ty (ty11, ty22, trans rest1 rest2)\n | Format_subst_ty _, _ -> assert false\n | _, Format_subst_ty _ -> assert false\n\n | End_of_fmtty, End_of_fmtty -> End_of_fmtty\n | End_of_fmtty, _ -> assert false\n | _, End_of_fmtty -> assert false\n\nlet rec fmtty_of_formatting_gen : type a b c d e f .\n (a, b, c, d, e, f) formatting_gen ->\n (a, b, c, d, e, f) fmtty =\nfun formatting_gen -> match formatting_gen with\n | Open_tag (Format (fmt, _)) -> fmtty_of_fmt fmt\n | Open_box (Format (fmt, _)) -> fmtty_of_fmt fmt\n\n(* Extract the type representation (an fmtty) of a format. *)\nand fmtty_of_fmt : type a b c d e f .\n (a, b, c, d, e, f) fmt -> (a, b, c, d, e, f) fmtty =\nfun fmtty -> match fmtty with\n | String (pad, rest) ->\n fmtty_of_padding_fmtty pad (String_ty (fmtty_of_fmt rest))\n | Caml_string (pad, rest) ->\n fmtty_of_padding_fmtty pad (String_ty (fmtty_of_fmt rest))\n\n | Int (_, pad, prec, rest) ->\n let ty_rest = fmtty_of_fmt rest in\n let prec_ty = fmtty_of_precision_fmtty prec (Int_ty ty_rest) in\n fmtty_of_padding_fmtty pad prec_ty\n | Int32 (_, pad, prec, rest) ->\n let ty_rest = fmtty_of_fmt rest in\n let prec_ty = fmtty_of_precision_fmtty prec (Int32_ty ty_rest) in\n fmtty_of_padding_fmtty pad prec_ty\n | Nativeint (_, pad, prec, rest) ->\n let ty_rest = fmtty_of_fmt rest in\n let prec_ty = fmtty_of_precision_fmtty prec (Nativeint_ty ty_rest) in\n fmtty_of_padding_fmtty pad prec_ty\n | Int64 (_, pad, prec, rest) ->\n let ty_rest = fmtty_of_fmt rest in\n let prec_ty = fmtty_of_precision_fmtty prec (Int64_ty ty_rest) in\n fmtty_of_padding_fmtty pad prec_ty\n | Float (_, pad, prec, rest) ->\n let ty_rest = fmtty_of_fmt rest in\n let prec_ty = fmtty_of_precision_fmtty prec (Float_ty ty_rest) in\n fmtty_of_padding_fmtty pad prec_ty\n\n | Char rest -> Char_ty (fmtty_of_fmt rest)\n | Caml_char rest -> Char_ty (fmtty_of_fmt rest)\n | Bool (pad, rest) ->\n fmtty_of_padding_fmtty pad (Bool_ty (fmtty_of_fmt rest))\n | Alpha rest -> Alpha_ty (fmtty_of_fmt rest)\n | Theta rest -> Theta_ty (fmtty_of_fmt rest)\n | Custom (arity, _, rest) -> fmtty_of_custom arity (fmtty_of_fmt rest)\n | Reader rest -> Reader_ty (fmtty_of_fmt rest)\n\n | Format_arg (_, ty, rest) ->\n Format_arg_ty (ty, fmtty_of_fmt rest)\n | Format_subst (_, ty, rest) ->\n Format_subst_ty (ty, ty, fmtty_of_fmt rest)\n\n | Flush rest -> fmtty_of_fmt rest\n | String_literal (_, rest) -> fmtty_of_fmt rest\n | Char_literal (_, rest) -> fmtty_of_fmt rest\n\n | Scan_char_set (_, _, rest) -> String_ty (fmtty_of_fmt rest)\n | Scan_get_counter (_, rest) -> Int_ty (fmtty_of_fmt rest)\n | Scan_next_char rest -> Char_ty (fmtty_of_fmt rest)\n | Ignored_param (ign, rest) -> fmtty_of_ignored_format ign rest\n | Formatting_lit (_, rest) -> fmtty_of_fmt rest\n | Formatting_gen (fmting_gen, rest) ->\n concat_fmtty (fmtty_of_formatting_gen fmting_gen) (fmtty_of_fmt rest)\n\n | End_of_format -> End_of_fmtty\n\nand fmtty_of_custom : type x y a b c d e f .\n (a, x, y) custom_arity -> (a, b, c, d, e, f) fmtty ->\n (y, b, c, d, e, f) fmtty =\nfun arity fmtty -> match arity with\n | Custom_zero -> fmtty\n | Custom_succ arity -> Any_ty (fmtty_of_custom arity fmtty)\n\n(* Extract the fmtty of an ignored parameter followed by the rest of\n the format. *)\nand fmtty_of_ignored_format : type x y a b c d e f .\n (a, b, c, d, y, x) ignored ->\n (x, b, c, y, e, f) fmt ->\n (a, b, c, d, e, f) fmtty =\nfun ign fmt -> match ign with\n | Ignored_char -> fmtty_of_fmt fmt\n | Ignored_caml_char -> fmtty_of_fmt fmt\n | Ignored_string _ -> fmtty_of_fmt fmt\n | Ignored_caml_string _ -> fmtty_of_fmt fmt\n | Ignored_int (_, _) -> fmtty_of_fmt fmt\n | Ignored_int32 (_, _) -> fmtty_of_fmt fmt\n | Ignored_nativeint (_, _) -> fmtty_of_fmt fmt\n | Ignored_int64 (_, _) -> fmtty_of_fmt fmt\n | Ignored_float (_, _) -> fmtty_of_fmt fmt\n | Ignored_bool _ -> fmtty_of_fmt fmt\n | Ignored_format_arg _ -> fmtty_of_fmt fmt\n | Ignored_format_subst (_, fmtty) -> concat_fmtty fmtty (fmtty_of_fmt fmt)\n | Ignored_reader -> Ignored_reader_ty (fmtty_of_fmt fmt)\n | Ignored_scan_char_set _ -> fmtty_of_fmt fmt\n | Ignored_scan_get_counter _ -> fmtty_of_fmt fmt\n | Ignored_scan_next_char -> fmtty_of_fmt fmt\n\n(* Add an Int_ty node if padding is taken as an extra argument (ex: \"%*s\"). *)\nand fmtty_of_padding_fmtty : type x a b c d e f .\n (x, a) padding -> (a, b, c, d, e, f) fmtty -> (x, b, c, d, e, f) fmtty =\n fun pad fmtty -> match pad with\n | No_padding -> fmtty\n | Lit_padding _ -> fmtty\n | Arg_padding _ -> Int_ty fmtty\n\n(* Add an Int_ty node if precision is taken as an extra argument (ex: \"%.*f\").*)\nand fmtty_of_precision_fmtty : type x a b c d e f .\n (x, a) precision -> (a, b, c, d, e, f) fmtty -> (x, b, c, d, e, f) fmtty =\n fun prec fmtty -> match prec with\n | No_precision -> fmtty\n | Lit_precision _ -> fmtty\n | Arg_precision -> Int_ty fmtty\n\n(******************************************************************************)\n (* Format typing *)\n\n(* Exception raised when a format does not match a given format type. *)\nexception Type_mismatch\n\n(* Type a padding. *)\n(* Take an Int_ty from the fmtty if the integer should be kept as argument. *)\n(* Raise Type_mismatch in case of type mismatch. *)\nlet type_padding : type a b c d e f x y .\n (x, y) padding -> (a, b, c, d, e, f) fmtty ->\n (a, b, c, d, e, f) padding_fmtty_ebb =\nfun pad fmtty -> match pad, fmtty with\n | No_padding, _ -> Padding_fmtty_EBB (No_padding, fmtty)\n | Lit_padding (padty, w), _ -> Padding_fmtty_EBB (Lit_padding (padty,w),fmtty)\n | Arg_padding padty, Int_ty rest -> Padding_fmtty_EBB (Arg_padding padty,rest)\n | _ -> raise Type_mismatch\n\n(* Convert a (upadding, uprecision) to a (padding, precision). *)\n(* Take one or two Int_ty from the fmtty if needed. *)\n(* Raise Type_mismatch in case of type mismatch. *)\nlet type_padprec : type a b c d e f x y z .\n (x, y) padding -> (y, z) precision -> (a, b, c, d, e, f) fmtty ->\n (a, b, c, d, e, f) padprec_fmtty_ebb =\nfun pad prec fmtty -> match prec, type_padding pad fmtty with\n | No_precision, Padding_fmtty_EBB (pad, rest) ->\n Padprec_fmtty_EBB (pad, No_precision, rest)\n | Lit_precision p, Padding_fmtty_EBB (pad, rest) ->\n Padprec_fmtty_EBB (pad, Lit_precision p, rest)\n | Arg_precision, Padding_fmtty_EBB (pad, Int_ty rest) ->\n Padprec_fmtty_EBB (pad, Arg_precision, rest)\n | _, Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n\n(* Type a format according to an fmtty. *)\n(* If typing succeed, generate a copy of the format with the same\n type parameters as the fmtty. *)\n(* Raise [Failure] with an error message in case of type mismatch. *)\nlet rec type_format :\n type a1 b1 c1 d1 e1 f1\n a2 b2 c2 d2 e2 f2 .\n (a1, b1, c1, d1, e1, f1) fmt\n -> (a2, b2, c2, d2, e2, f2) fmtty\n -> (a2, b2, c2, d2, e2, f2) fmt\n= fun fmt fmtty -> match type_format_gen fmt fmtty with\n | Fmt_fmtty_EBB (fmt', End_of_fmtty) -> fmt'\n | _ -> raise Type_mismatch\n\nand type_format_gen :\n type a1 b1 c1 d1 e1 f1\n a2 b2 c2 d2 e2 f2 .\n (a1, b1, c1, d1, e1, f1) fmt\n -> (a2, b2, c2, d2, e2, f2) fmtty\n -> (a2, b2, c2, d2, e2, f2) fmt_fmtty_ebb\n= fun fmt fmtty -> match fmt, fmtty with\n | Char fmt_rest, Char_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Char fmt', fmtty')\n | Caml_char fmt_rest, Char_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Caml_char fmt', fmtty')\n | String (pad, fmt_rest), _ -> (\n match type_padding pad fmtty with\n | Padding_fmtty_EBB (pad, String_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (String (pad, fmt'), fmtty')\n | Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n )\n | Caml_string (pad, fmt_rest), _ -> (\n match type_padding pad fmtty with\n | Padding_fmtty_EBB (pad, String_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Caml_string (pad, fmt'), fmtty')\n | Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n )\n | Int (iconv, pad, prec, fmt_rest), _ -> (\n match type_padprec pad prec fmtty with\n | Padprec_fmtty_EBB (pad, prec, Int_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Int (iconv, pad, prec, fmt'), fmtty')\n | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n )\n | Int32 (iconv, pad, prec, fmt_rest), _ -> (\n match type_padprec pad prec fmtty with\n | Padprec_fmtty_EBB (pad, prec, Int32_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Int32 (iconv, pad, prec, fmt'), fmtty')\n | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n )\n | Nativeint (iconv, pad, prec, fmt_rest), _ -> (\n match type_padprec pad prec fmtty with\n | Padprec_fmtty_EBB (pad, prec, Nativeint_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Nativeint (iconv, pad, prec, fmt'), fmtty')\n | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n )\n | Int64 (iconv, pad, prec, fmt_rest), _ -> (\n match type_padprec pad prec fmtty with\n | Padprec_fmtty_EBB (pad, prec, Int64_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Int64 (iconv, pad, prec, fmt'), fmtty')\n | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n )\n | Float (fconv, pad, prec, fmt_rest), _ -> (\n match type_padprec pad prec fmtty with\n | Padprec_fmtty_EBB (pad, prec, Float_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Float (fconv, pad, prec, fmt'), fmtty')\n | Padprec_fmtty_EBB (_, _, _) -> raise Type_mismatch\n )\n | Bool (pad, fmt_rest), _ -> (\n match type_padding pad fmtty with\n | Padding_fmtty_EBB (pad, Bool_ty fmtty_rest) ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Bool (pad, fmt'), fmtty')\n | Padding_fmtty_EBB (_, _) -> raise Type_mismatch\n )\n | Flush fmt_rest, fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Flush fmt', fmtty')\n\n | String_literal (str, fmt_rest), fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (String_literal (str, fmt'), fmtty')\n | Char_literal (chr, fmt_rest), fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Char_literal (chr, fmt'), fmtty')\n\n | Format_arg (pad_opt, sub_fmtty, fmt_rest),\n Format_arg_ty (sub_fmtty', fmtty_rest) ->\n if Fmtty_EBB sub_fmtty <> Fmtty_EBB sub_fmtty' then raise Type_mismatch;\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Format_arg (pad_opt, sub_fmtty', fmt'), fmtty')\n | Format_subst (pad_opt, sub_fmtty, fmt_rest),\n Format_subst_ty (sub_fmtty1, _sub_fmtty2, fmtty_rest) ->\n if Fmtty_EBB (erase_rel sub_fmtty) <> Fmtty_EBB (erase_rel sub_fmtty1) then\n raise Type_mismatch;\n let Fmt_fmtty_EBB (fmt', fmtty') =\n type_format_gen fmt_rest (erase_rel fmtty_rest)\n in\n Fmt_fmtty_EBB (Format_subst (pad_opt, sub_fmtty1, fmt'), fmtty')\n (* Printf and Format specific constructors: *)\n | Alpha fmt_rest, Alpha_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Alpha fmt', fmtty')\n | Theta fmt_rest, Theta_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Theta fmt', fmtty')\n\n (* Format specific constructors: *)\n | Formatting_lit (formatting_lit, fmt_rest), fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Formatting_lit (formatting_lit, fmt'), fmtty')\n | Formatting_gen (formatting_gen, fmt_rest), fmtty_rest ->\n type_formatting_gen formatting_gen fmt_rest fmtty_rest\n\n (* Scanf specific constructors: *)\n | Reader fmt_rest, Reader_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Reader fmt', fmtty')\n | Scan_char_set (width_opt, char_set, fmt_rest), String_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Scan_char_set (width_opt, char_set, fmt'), fmtty')\n | Scan_get_counter (counter, fmt_rest), Int_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt_rest fmtty_rest in\n Fmt_fmtty_EBB (Scan_get_counter (counter, fmt'), fmtty')\n | Ignored_param (ign, rest), fmtty_rest ->\n type_ignored_param ign rest fmtty_rest\n\n | End_of_format, fmtty_rest -> Fmt_fmtty_EBB (End_of_format, fmtty_rest)\n\n | _ -> raise Type_mismatch\n\nand type_formatting_gen : type a1 a3 b1 b3 c1 c3 d1 d3 e1 e2 e3 f1 f2 f3 .\n (a1, b1, c1, d1, e1, f1) formatting_gen ->\n (f1, b1, c1, e1, e2, f2) fmt ->\n (a3, b3, c3, d3, e3, f3) fmtty ->\n (a3, b3, c3, d3, e3, f3) fmt_fmtty_ebb =\nfun formatting_gen fmt0 fmtty0 -> match formatting_gen with\n | Open_tag (Format (fmt1, str)) ->\n let Fmt_fmtty_EBB (fmt2, fmtty2) = type_format_gen fmt1 fmtty0 in\n let Fmt_fmtty_EBB (fmt3, fmtty3) = type_format_gen fmt0 fmtty2 in\n Fmt_fmtty_EBB (Formatting_gen (Open_tag (Format (fmt2, str)), fmt3), fmtty3)\n | Open_box (Format (fmt1, str)) ->\n let Fmt_fmtty_EBB (fmt2, fmtty2) = type_format_gen fmt1 fmtty0 in\n let Fmt_fmtty_EBB (fmt3, fmtty3) = type_format_gen fmt0 fmtty2 in\n Fmt_fmtty_EBB (Formatting_gen (Open_box (Format (fmt2, str)), fmt3), fmtty3)\n\n(* Type an Ignored_param node according to an fmtty. *)\nand type_ignored_param : type p q x y z t u v a b c d e f .\n (x, y, z, t, q, p) ignored ->\n (p, y, z, q, u, v) fmt ->\n (a, b, c, d, e, f) fmtty ->\n (a, b, c, d, e, f) fmt_fmtty_ebb =\nfun ign fmt fmtty -> match ign with\n | Ignored_char as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_caml_char as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_string _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_caml_string _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_int _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_int32 _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_nativeint _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_int64 _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_float _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_bool _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_scan_char_set _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_scan_get_counter _ as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_scan_next_char as ign' -> type_ignored_param_one ign' fmt fmtty\n | Ignored_format_arg (pad_opt, sub_fmtty) ->\n type_ignored_param_one (Ignored_format_arg (pad_opt, sub_fmtty)) fmt fmtty\n | Ignored_format_subst (pad_opt, sub_fmtty) ->\n let Fmtty_fmt_EBB (sub_fmtty', Fmt_fmtty_EBB (fmt', fmtty')) =\n type_ignored_format_substitution sub_fmtty fmt fmtty in\n Fmt_fmtty_EBB (Ignored_param (Ignored_format_subst (pad_opt, sub_fmtty'),\n fmt'),\n fmtty')\n | Ignored_reader -> (\n match fmtty with\n | Ignored_reader_ty fmtty_rest ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt fmtty_rest in\n Fmt_fmtty_EBB (Ignored_param (Ignored_reader, fmt'), fmtty')\n | _ -> raise Type_mismatch\n )\n\nand type_ignored_param_one : type a1 a2 b1 b2 c1 c2 d1 d2 e1 e2 f1 f2 .\n (a2, b2, c2, d2, d2, a2) ignored ->\n (a1, b1, c1, d1, e1, f1) fmt ->\n (a2, b2, c2, d2, e2, f2) fmtty ->\n (a2, b2, c2, d2, e2, f2) fmt_fmtty_ebb\n= fun ign fmt fmtty ->\n let Fmt_fmtty_EBB (fmt', fmtty') = type_format_gen fmt fmtty in\n Fmt_fmtty_EBB (Ignored_param (ign, fmt'), fmtty')\n\n(* Typing of the complex case: \"%_(...%)\". *)\nand type_ignored_format_substitution : type w x y z p s t u a b c d e f .\n (w, x, y, z, s, p) fmtty ->\n (p, x, y, s, t, u) fmt ->\n (a, b, c, d, e, f) fmtty -> (a, b, c, d, e, f) fmtty_fmt_ebb =\nfun sub_fmtty fmt fmtty -> match sub_fmtty, fmtty with\n | Char_ty sub_fmtty_rest, Char_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Char_ty sub_fmtty_rest', fmt')\n | String_ty sub_fmtty_rest, String_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (String_ty sub_fmtty_rest', fmt')\n | Int_ty sub_fmtty_rest, Int_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Int_ty sub_fmtty_rest', fmt')\n | Int32_ty sub_fmtty_rest, Int32_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Int32_ty sub_fmtty_rest', fmt')\n | Nativeint_ty sub_fmtty_rest, Nativeint_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Nativeint_ty sub_fmtty_rest', fmt')\n | Int64_ty sub_fmtty_rest, Int64_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Int64_ty sub_fmtty_rest', fmt')\n | Float_ty sub_fmtty_rest, Float_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Float_ty sub_fmtty_rest', fmt')\n | Bool_ty sub_fmtty_rest, Bool_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Bool_ty sub_fmtty_rest', fmt')\n | Alpha_ty sub_fmtty_rest, Alpha_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Alpha_ty sub_fmtty_rest', fmt')\n | Theta_ty sub_fmtty_rest, Theta_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Theta_ty sub_fmtty_rest', fmt')\n | Reader_ty sub_fmtty_rest, Reader_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Reader_ty sub_fmtty_rest', fmt')\n | Ignored_reader_ty sub_fmtty_rest, Ignored_reader_ty fmtty_rest ->\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Ignored_reader_ty sub_fmtty_rest', fmt')\n\n | Format_arg_ty (sub2_fmtty, sub_fmtty_rest),\n Format_arg_ty (sub2_fmtty', fmtty_rest) ->\n if Fmtty_EBB sub2_fmtty <> Fmtty_EBB sub2_fmtty' then raise Type_mismatch;\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution sub_fmtty_rest fmt fmtty_rest in\n Fmtty_fmt_EBB (Format_arg_ty (sub2_fmtty', sub_fmtty_rest'), fmt')\n | Format_subst_ty (sub1_fmtty, sub2_fmtty, sub_fmtty_rest),\n Format_subst_ty (sub1_fmtty', sub2_fmtty', fmtty_rest) ->\n (* TODO define Fmtty_rel_EBB to remove those erase_rel *)\n if Fmtty_EBB (erase_rel sub1_fmtty) <> Fmtty_EBB (erase_rel sub1_fmtty')\n then raise Type_mismatch;\n if Fmtty_EBB (erase_rel sub2_fmtty) <> Fmtty_EBB (erase_rel sub2_fmtty')\n then raise Type_mismatch;\n let sub_fmtty' = trans (symm sub1_fmtty') sub2_fmtty' in\n let _, f2, _, f4 = fmtty_rel_det sub_fmtty' in\n let Refl = f2 Refl in\n let Refl = f4 Refl in\n let Fmtty_fmt_EBB (sub_fmtty_rest', fmt') =\n type_ignored_format_substitution (erase_rel sub_fmtty_rest) fmt fmtty_rest\n in\n Fmtty_fmt_EBB (Format_subst_ty (sub1_fmtty', sub2_fmtty',\n symm sub_fmtty_rest'),\n fmt')\n | End_of_fmtty, fmtty ->\n Fmtty_fmt_EBB (End_of_fmtty, type_format_gen fmt fmtty)\n | _ -> raise Type_mismatch\n\n(* This implementation of `recast` is a bit disappointing. The\n invariant provided by the type are very strong: the input format's\n type is in relation to the output type's as witnessed by the\n fmtty_rel argument. One would at first expect this function to be\n total, and implementable by exhaustive pattern matching. Instead,\n we reuse the highly partial and much less well-defined function\n `type_format` that has lost all knowledge of the correspondence\n between the argument's types.\n\n Besides the fact that this function reuses a lot of the\n `type_format` logic (eg.: seeing Int_ty in the fmtty parameter does\n not let you match on Int only, as you may in fact have Float\n (Arg_padding, ...) (\"%.*d\") beginning with an Int_ty), it is also\n a partial function, because the typing information in a format is\n not quite enough to reconstruct it unambiguously. For example, the\n format types of \"%d%_r\" and \"%_r%d\" have the same format6\n parameters, but they are not at all exchangeable, and putting one\n in place of the other must result in a dynamic failure.\n\n Given that:\n - we'd have to duplicate a lot of non-trivial typing logic from type_format\n - this wouldn't even eliminate (all) the dynamic failures\n we decided to just reuse type_format directly for now.\n*)\nlet recast :\n type a1 b1 c1 d1 e1 f1\n a2 b2 c2 d2 e2 f2\n .\n (a1, b1, c1, d1, e1, f1) fmt\n -> (a1, b1, c1, d1, e1, f1,\n a2, b2, c2, d2, e2, f2) fmtty_rel\n -> (a2, b2, c2, d2, e2, f2) fmt\n= fun fmt fmtty ->\n type_format fmt (erase_rel (symm fmtty))\n\n(******************************************************************************)\n (* Printing tools *)\n\n(* Add padding spaces around a string. *)\nlet fix_padding padty width str =\n let len = String.length str in\n let width, padty =\n abs width,\n (* while literal padding widths are always non-negative,\n dynamically-set widths (Arg_padding, eg. %*d) may be negative;\n we interpret those as specifying a padding-to-the-left; this\n means that '0' may get dropped even if it was explicitly set,\n but:\n - this is what the legacy implementation does, and\n we preserve compatibility if possible\n - we could only signal this issue by failing at runtime,\n which is not very nice... *)\n if width < 0 then Left else padty in\n if width <= len then str else\n let res = Bytes.make width (if padty = Zeros then '0' else ' ') in\n begin match padty with\n | Left -> String.blit str 0 res 0 len\n | Right -> String.blit str 0 res (width - len) len\n | Zeros when len > 0 && (str.[0] = '+' || str.[0] = '-' || str.[0] = ' ') ->\n Bytes.set res 0 str.[0];\n String.blit str 1 res (width - len + 1) (len - 1)\n | Zeros when len > 1 && str.[0] = '0' && (str.[1] = 'x' || str.[1] = 'X') ->\n Bytes.set res 1 str.[1];\n String.blit str 2 res (width - len + 2) (len - 2)\n | Zeros ->\n String.blit str 0 res (width - len) len\n end;\n Bytes.unsafe_to_string res\n\n(* Add '0' padding to int, int32, nativeint or int64 string representation. *)\nlet fix_int_precision prec str =\n let prec = abs prec in\n let len = String.length str in\n match str.[0] with\n | ('+' | '-' | ' ') as c when prec + 1 > len ->\n let res = Bytes.make (prec + 1) '0' in\n Bytes.set res 0 c;\n String.blit str 1 res (prec - len + 2) (len - 1);\n Bytes.unsafe_to_string res\n | '0' when prec + 2 > len && len > 1 && (str.[1] = 'x' || str.[1] = 'X') ->\n let res = Bytes.make (prec + 2) '0' in\n Bytes.set res 1 str.[1];\n String.blit str 2 res (prec - len + 4) (len - 2);\n Bytes.unsafe_to_string res\n | '0' .. '9' | 'a' .. 'f' | 'A' .. 'F' when prec > len ->\n let res = Bytes.make prec '0' in\n String.blit str 0 res (prec - len) len;\n Bytes.unsafe_to_string res\n | _ ->\n str\n\n(* Escape a string according to the OCaml lexing convention. *)\nlet string_to_caml_string str =\n let str = String.escaped str in\n let l = String.length str in\n let res = Bytes.make (l + 2) '\\\"' in\n String.unsafe_blit str 0 res 1 l;\n Bytes.unsafe_to_string res\n\n(* Generate the format_int/int32/nativeint/int64 first argument\n from an int_conv. *)\nlet format_of_iconv = function\n | Int_d | Int_Cd -> \"%d\" | Int_pd -> \"%+d\" | Int_sd -> \"% d\"\n | Int_i | Int_Ci -> \"%i\" | Int_pi -> \"%+i\" | Int_si -> \"% i\"\n | Int_x -> \"%x\" | Int_Cx -> \"%#x\"\n | Int_X -> \"%X\" | Int_CX -> \"%#X\"\n | Int_o -> \"%o\" | Int_Co -> \"%#o\"\n | Int_u | Int_Cu -> \"%u\"\n\nlet format_of_iconvL = function\n | Int_d | Int_Cd -> \"%Ld\" | Int_pd -> \"%+Ld\" | Int_sd -> \"% Ld\"\n | Int_i | Int_Ci -> \"%Li\" | Int_pi -> \"%+Li\" | Int_si -> \"% Li\"\n | Int_x -> \"%Lx\" | Int_Cx -> \"%#Lx\"\n | Int_X -> \"%LX\" | Int_CX -> \"%#LX\"\n | Int_o -> \"%Lo\" | Int_Co -> \"%#Lo\"\n | Int_u | Int_Cu -> \"%Lu\"\n\nlet format_of_iconvl = function\n | Int_d | Int_Cd -> \"%ld\" | Int_pd -> \"%+ld\" | Int_sd -> \"% ld\"\n | Int_i | Int_Ci -> \"%li\" | Int_pi -> \"%+li\" | Int_si -> \"% li\"\n | Int_x -> \"%lx\" | Int_Cx -> \"%#lx\"\n | Int_X -> \"%lX\" | Int_CX -> \"%#lX\"\n | Int_o -> \"%lo\" | Int_Co -> \"%#lo\"\n | Int_u | Int_Cu -> \"%lu\"\n\nlet format_of_iconvn = function\n | Int_d | Int_Cd -> \"%nd\" | Int_pd -> \"%+nd\" | Int_sd -> \"% nd\"\n | Int_i | Int_Ci -> \"%ni\" | Int_pi -> \"%+ni\" | Int_si -> \"% ni\"\n | Int_x -> \"%nx\" | Int_Cx -> \"%#nx\"\n | Int_X -> \"%nX\" | Int_CX -> \"%#nX\"\n | Int_o -> \"%no\" | Int_Co -> \"%#no\"\n | Int_u | Int_Cu -> \"%nu\"\n\n(* Generate the format_float first argument from a float_conv. *)\nlet format_of_fconv fconv prec =\n let prec = abs prec in\n let symb = char_of_fconv ~cF:'g' fconv in\n let buf = buffer_create 16 in\n buffer_add_char buf '%';\n bprint_fconv_flag buf fconv;\n buffer_add_char buf '.';\n buffer_add_string buf (Int.to_string prec);\n buffer_add_char buf symb;\n buffer_contents buf\n\nlet transform_int_alt iconv s =\n match iconv with\n | Int_Cd | Int_Ci | Int_Cu ->\n let digits =\n let n = ref 0 in\n for i = 0 to String.length s - 1 do\n match String.unsafe_get s i with\n | '0'..'9' -> incr n\n | _ -> ()\n done;\n !n\n in\n let buf = Bytes.create (String.length s + (digits - 1) / 3) in\n let pos = ref 0 in\n let put c = Bytes.set buf !pos c; incr pos in\n let left = ref ((digits - 1) mod 3 + 1) in\n for i = 0 to String.length s - 1 do\n match String.unsafe_get s i with\n | '0'..'9' as c ->\n if !left = 0 then (put '_'; left := 3); decr left; put c\n | c -> put c\n done;\n Bytes.unsafe_to_string buf\n | _ -> s\n\n(* Convert an integer to a string according to a conversion. *)\nlet convert_int iconv n =\n transform_int_alt iconv (format_int (format_of_iconv iconv) n)\nlet convert_int32 iconv n =\n transform_int_alt iconv (format_int32 (format_of_iconvl iconv) n)\nlet convert_nativeint iconv n =\n transform_int_alt iconv (format_nativeint (format_of_iconvn iconv) n)\nlet convert_int64 iconv n =\n transform_int_alt iconv (format_int64 (format_of_iconvL iconv) n)\n\n(* Convert a float to string. *)\n(* Fix special case of \"OCaml float format\". *)\nlet convert_float fconv prec x =\n let hex () =\n let sign =\n match fst fconv with\n | Float_flag_p -> '+'\n | Float_flag_s -> ' '\n | _ -> '-' in\n hexstring_of_float x prec sign in\n let add_dot_if_needed str =\n let len = String.length str in\n let rec is_valid i =\n if i = len then false else\n match str.[i] with\n | '.' | 'e' | 'E' -> true\n | _ -> is_valid (i + 1) in\n if is_valid 0 then str else str ^ \".\" in\n let caml_special_val str = match classify_float x with\n | FP_normal | FP_subnormal | FP_zero -> str\n | FP_infinite -> if x < 0.0 then \"neg_infinity\" else \"infinity\"\n | FP_nan -> \"nan\" in\n match snd fconv with\n | Float_h -> hex ()\n | Float_H -> String.uppercase_ascii (hex ())\n | Float_CF -> caml_special_val (hex ())\n | Float_F ->\n let str = format_float (format_of_fconv fconv prec) x in\n caml_special_val (add_dot_if_needed str)\n | Float_f | Float_e | Float_E | Float_g | Float_G ->\n format_float (format_of_fconv fconv prec) x\n\n(* Convert a char to a string according to the OCaml lexical convention. *)\nlet format_caml_char c =\n let str = Char.escaped c in\n let l = String.length str in\n let res = Bytes.make (l + 2) '\\'' in\n String.unsafe_blit str 0 res 1 l;\n Bytes.unsafe_to_string res\n\n(* Convert a format type to string *)\nlet string_of_fmtty fmtty =\n let buf = buffer_create 16 in\n bprint_fmtty buf fmtty;\n buffer_contents buf\n\n(******************************************************************************)\n (* Generic printing function *)\n\n(* Make a generic printing function. *)\n(* Used to generate Printf and Format printing functions. *)\n(* Parameters:\n k: a continuation finally applied to the output stream and the accumulator.\n o: the output stream (see k, %a and %t).\n acc: rev list of printing entities (string, char, flush, formatting, ...).\n fmt: the format. *)\nlet rec make_printf : type a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt -> a =\nfun k acc fmt -> match fmt with\n | Char rest ->\n fun c ->\n let new_acc = Acc_data_char (acc, c) in\n make_printf k new_acc rest\n | Caml_char rest ->\n fun c ->\n let new_acc = Acc_data_string (acc, format_caml_char c) in\n make_printf k new_acc rest\n | String (pad, rest) ->\n make_padding k acc rest pad (fun str -> str)\n | Caml_string (pad, rest) ->\n make_padding k acc rest pad string_to_caml_string\n | Int (iconv, pad, prec, rest) ->\n make_int_padding_precision k acc rest pad prec convert_int iconv\n | Int32 (iconv, pad, prec, rest) ->\n make_int_padding_precision k acc rest pad prec convert_int32 iconv\n | Nativeint (iconv, pad, prec, rest) ->\n make_int_padding_precision k acc rest pad prec convert_nativeint iconv\n | Int64 (iconv, pad, prec, rest) ->\n make_int_padding_precision k acc rest pad prec convert_int64 iconv\n | Float (fconv, pad, prec, rest) ->\n make_float_padding_precision k acc rest pad prec fconv\n | Bool (pad, rest) ->\n make_padding k acc rest pad string_of_bool\n | Alpha rest ->\n fun f x -> make_printf k (Acc_delay (acc, fun o -> f o x)) rest\n | Theta rest ->\n fun f -> make_printf k (Acc_delay (acc, f)) rest\n | Custom (arity, f, rest) ->\n make_custom k acc rest arity (f ())\n | Reader _ ->\n (* This case is impossible, by typing of formats. *)\n (* Indeed, since printf and co. take a format4 as argument, the 'd and 'e\n type parameters of fmt are obviously equals. The Reader is the\n only constructor which touch 'd and 'e type parameters of the format\n type, it adds an (->) to the 'd parameters. Consequently, a format4\n cannot contain a Reader node, except in the sub-format associated to\n an %{...%}. It's not a problem because make_printf do not call\n itself recursively on the sub-format associated to %{...%}. *)\n assert false\n | Flush rest ->\n make_printf k (Acc_flush acc) rest\n\n | String_literal (str, rest) ->\n make_printf k (Acc_string_literal (acc, str)) rest\n | Char_literal (chr, rest) ->\n make_printf k (Acc_char_literal (acc, chr)) rest\n\n | Format_arg (_, sub_fmtty, rest) ->\n let ty = string_of_fmtty sub_fmtty in\n (fun str ->\n ignore str;\n make_printf k (Acc_data_string (acc, ty)) rest)\n | Format_subst (_, fmtty, rest) ->\n fun (Format (fmt, _)) -> make_printf k acc\n (concat_fmt (recast fmt fmtty) rest)\n\n | Scan_char_set (_, _, rest) ->\n let new_acc = Acc_invalid_arg (acc, \"Printf: bad conversion %[\") in\n fun _ -> make_printf k new_acc rest\n | Scan_get_counter (_, rest) ->\n (* This case should be refused for Printf. *)\n (* Accepted for backward compatibility. *)\n (* Interpret %l, %n and %L as %u. *)\n fun n ->\n let new_acc = Acc_data_string (acc, format_int \"%u\" n) in\n make_printf k new_acc rest\n | Scan_next_char rest ->\n fun c ->\n let new_acc = Acc_data_char (acc, c) in\n make_printf k new_acc rest\n | Ignored_param (ign, rest) ->\n make_ignored_param k acc ign rest\n\n | Formatting_lit (fmting_lit, rest) ->\n make_printf k (Acc_formatting_lit (acc, fmting_lit)) rest\n | Formatting_gen (Open_tag (Format (fmt', _)), rest) ->\n let k' kacc =\n make_printf k (Acc_formatting_gen (acc, Acc_open_tag kacc)) rest in\n make_printf k' End_of_acc fmt'\n | Formatting_gen (Open_box (Format (fmt', _)), rest) ->\n let k' kacc =\n make_printf k (Acc_formatting_gen (acc, Acc_open_box kacc)) rest in\n make_printf k' End_of_acc fmt'\n\n | End_of_format ->\n k acc\n\n(* Delay the error (Invalid_argument \"Printf: bad conversion %_\"). *)\n(* Generate functions to take remaining arguments (after the \"%_\"). *)\nand make_ignored_param : type x y a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, y, x) ignored ->\n (x, b, c, y, e, f) fmt -> a =\nfun k acc ign fmt -> match ign with\n | Ignored_char -> make_invalid_arg k acc fmt\n | Ignored_caml_char -> make_invalid_arg k acc fmt\n | Ignored_string _ -> make_invalid_arg k acc fmt\n | Ignored_caml_string _ -> make_invalid_arg k acc fmt\n | Ignored_int (_, _) -> make_invalid_arg k acc fmt\n | Ignored_int32 (_, _) -> make_invalid_arg k acc fmt\n | Ignored_nativeint (_, _) -> make_invalid_arg k acc fmt\n | Ignored_int64 (_, _) -> make_invalid_arg k acc fmt\n | Ignored_float (_, _) -> make_invalid_arg k acc fmt\n | Ignored_bool _ -> make_invalid_arg k acc fmt\n | Ignored_format_arg _ -> make_invalid_arg k acc fmt\n | Ignored_format_subst (_, fmtty) -> make_from_fmtty k acc fmtty fmt\n | Ignored_reader -> assert false\n | Ignored_scan_char_set _ -> make_invalid_arg k acc fmt\n | Ignored_scan_get_counter _ -> make_invalid_arg k acc fmt\n | Ignored_scan_next_char -> make_invalid_arg k acc fmt\n\n\n(* Special case of printf \"%_(\". *)\nand make_from_fmtty : type x y a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, y, x) fmtty ->\n (x, b, c, y, e, f) fmt -> a =\nfun k acc fmtty fmt -> match fmtty with\n | Char_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | String_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Int_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Int32_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Nativeint_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Int64_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Float_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Bool_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Alpha_ty rest -> fun _ _ -> make_from_fmtty k acc rest fmt\n | Theta_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Any_ty rest -> fun _ -> make_from_fmtty k acc rest fmt\n | Reader_ty _ -> assert false\n | Ignored_reader_ty _ -> assert false\n | Format_arg_ty (_, rest) -> fun _ -> make_from_fmtty k acc rest fmt\n | End_of_fmtty -> make_invalid_arg k acc fmt\n | Format_subst_ty (ty1, ty2, rest) ->\n let ty = trans (symm ty1) ty2 in\n fun _ -> make_from_fmtty k acc (concat_fmtty ty rest) fmt\n\n(* Insert an Acc_invalid_arg in the accumulator and continue to generate\n closures to get the remaining arguments. *)\nand make_invalid_arg : type a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt -> a =\nfun k acc fmt ->\n make_printf k (Acc_invalid_arg (acc, \"Printf: bad conversion %_\")) fmt\n\n(* Fix padding, take it as an extra integer argument if needed. *)\nand make_padding : type x z a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt ->\n (x, z -> a) padding -> (z -> string) -> x =\n fun k acc fmt pad trans -> match pad with\n | No_padding ->\n fun x ->\n let new_acc = Acc_data_string (acc, trans x) in\n make_printf k new_acc fmt\n | Lit_padding (padty, width) ->\n fun x ->\n let new_acc = Acc_data_string (acc, fix_padding padty width (trans x)) in\n make_printf k new_acc fmt\n | Arg_padding padty ->\n fun w x ->\n let new_acc = Acc_data_string (acc, fix_padding padty w (trans x)) in\n make_printf k new_acc fmt\n\n(* Fix padding and precision for int, int32, nativeint or int64. *)\n(* Take one or two extra integer arguments if needed. *)\nand make_int_padding_precision : type x y z a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt ->\n (x, y) padding -> (y, z -> a) precision -> (int_conv -> z -> string) ->\n int_conv -> x =\n fun k acc fmt pad prec trans iconv -> match pad, prec with\n | No_padding, No_precision ->\n fun x ->\n let str = trans iconv x in\n make_printf k (Acc_data_string (acc, str)) fmt\n | No_padding, Lit_precision p ->\n fun x ->\n let str = fix_int_precision p (trans iconv x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | No_padding, Arg_precision ->\n fun p x ->\n let str = fix_int_precision p (trans iconv x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Lit_padding (padty, w), No_precision ->\n fun x ->\n let str = fix_padding padty w (trans iconv x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Lit_padding (padty, w), Lit_precision p ->\n fun x ->\n let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Lit_padding (padty, w), Arg_precision ->\n fun p x ->\n let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Arg_padding padty, No_precision ->\n fun w x ->\n let str = fix_padding padty w (trans iconv x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Arg_padding padty, Lit_precision p ->\n fun w x ->\n let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Arg_padding padty, Arg_precision ->\n fun w p x ->\n let str = fix_padding padty w (fix_int_precision p (trans iconv x)) in\n make_printf k (Acc_data_string (acc, str)) fmt\n\n(* Convert a float, fix padding and precision if needed. *)\n(* Take the float argument and one or two extra integer arguments if needed. *)\nand make_float_padding_precision : type x y a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt ->\n (x, y) padding -> (y, float -> a) precision -> float_conv -> x =\n fun k acc fmt pad prec fconv -> match pad, prec with\n | No_padding, No_precision ->\n fun x ->\n let str = convert_float fconv (default_float_precision fconv) x in\n make_printf k (Acc_data_string (acc, str)) fmt\n | No_padding, Lit_precision p ->\n fun x ->\n let str = convert_float fconv p x in\n make_printf k (Acc_data_string (acc, str)) fmt\n | No_padding, Arg_precision ->\n fun p x ->\n let str = convert_float fconv p x in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Lit_padding (padty, w), No_precision ->\n fun x ->\n let str = convert_float fconv (default_float_precision fconv) x in\n let str' = fix_padding padty w str in\n make_printf k (Acc_data_string (acc, str')) fmt\n | Lit_padding (padty, w), Lit_precision p ->\n fun x ->\n let str = fix_padding padty w (convert_float fconv p x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Lit_padding (padty, w), Arg_precision ->\n fun p x ->\n let str = fix_padding padty w (convert_float fconv p x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Arg_padding padty, No_precision ->\n fun w x ->\n let str = convert_float fconv (default_float_precision fconv) x in\n let str' = fix_padding padty w str in\n make_printf k (Acc_data_string (acc, str')) fmt\n | Arg_padding padty, Lit_precision p ->\n fun w x ->\n let str = fix_padding padty w (convert_float fconv p x) in\n make_printf k (Acc_data_string (acc, str)) fmt\n | Arg_padding padty, Arg_precision ->\n fun w p x ->\n let str = fix_padding padty w (convert_float fconv p x) in\n make_printf k (Acc_data_string (acc, str)) fmt\nand make_custom : type x y a b c d e f .\n ((b, c) acc -> f) -> (b, c) acc ->\n (a, b, c, d, e, f) fmt ->\n (a, x, y) custom_arity -> x -> y =\n fun k acc rest arity f -> match arity with\n | Custom_zero -> make_printf k (Acc_data_string (acc, f)) rest\n | Custom_succ arity ->\n fun x ->\n make_custom k acc rest arity (f x)\n\nlet const x _ = x\n\nlet rec make_iprintf : type a b c d e f state.\n (state -> f) -> state -> (a, b, c, d, e, f) fmt -> a =\n fun k o fmt -> match fmt with\n | Char rest ->\n const (make_iprintf k o rest)\n | Caml_char rest ->\n const (make_iprintf k o rest)\n | String (No_padding, rest) ->\n const (make_iprintf k o rest)\n | String (Lit_padding _, rest) ->\n const (make_iprintf k o rest)\n | String (Arg_padding _, rest) ->\n const (const (make_iprintf k o rest))\n | Caml_string (No_padding, rest) ->\n const (make_iprintf k o rest)\n | Caml_string (Lit_padding _, rest) ->\n const (make_iprintf k o rest)\n | Caml_string (Arg_padding _, rest) ->\n const (const (make_iprintf k o rest))\n | Int (_, pad, prec, rest) ->\n fn_of_padding_precision k o rest pad prec\n | Int32 (_, pad, prec, rest) ->\n fn_of_padding_precision k o rest pad prec\n | Nativeint (_, pad, prec, rest) ->\n fn_of_padding_precision k o rest pad prec\n | Int64 (_, pad, prec, rest) ->\n fn_of_padding_precision k o rest pad prec\n | Float (_, pad, prec, rest) ->\n fn_of_padding_precision k o rest pad prec\n | Bool (No_padding, rest) ->\n const (make_iprintf k o rest)\n | Bool (Lit_padding _, rest) ->\n const (make_iprintf k o rest)\n | Bool (Arg_padding _, rest) ->\n const (const (make_iprintf k o rest))\n | Alpha rest ->\n const (const (make_iprintf k o rest))\n | Theta rest ->\n const (make_iprintf k o rest)\n | Custom (arity, _, rest) ->\n fn_of_custom_arity k o rest arity\n | Reader _ ->\n (* This case is impossible, by typing of formats. See the\n note in the corresponding case for make_printf. *)\n assert false\n | Flush rest ->\n make_iprintf k o rest\n | String_literal (_, rest) ->\n make_iprintf k o rest\n | Char_literal (_, rest) ->\n make_iprintf k o rest\n | Format_arg (_, _, rest) ->\n const (make_iprintf k o rest)\n | Format_subst (_, fmtty, rest) ->\n fun (Format (fmt, _)) ->\n make_iprintf k o\n (concat_fmt (recast fmt fmtty) rest)\n | Scan_char_set (_, _, rest) ->\n const (make_iprintf k o rest)\n | Scan_get_counter (_, rest) ->\n const (make_iprintf k o rest)\n | Scan_next_char rest ->\n const (make_iprintf k o rest)\n | Ignored_param (ign, rest) ->\n make_ignored_param (fun _ -> k o) (End_of_acc) ign rest\n | Formatting_lit (_, rest) ->\n make_iprintf k o rest\n | Formatting_gen (Open_tag (Format (fmt', _)), rest) ->\n make_iprintf (fun koc -> make_iprintf k koc rest) o fmt'\n | Formatting_gen (Open_box (Format (fmt', _)), rest) ->\n make_iprintf (fun koc -> make_iprintf k koc rest) o fmt'\n | End_of_format ->\n k o\nand fn_of_padding_precision :\n type x y z a b c d e f state.\n (state -> f) -> state -> (a, b, c, d, e, f) fmt ->\n (x, y) padding -> (y, z -> a) precision -> x =\n fun k o fmt pad prec -> match pad, prec with\n | No_padding , No_precision ->\n const (make_iprintf k o fmt)\n | No_padding , Lit_precision _ ->\n const (make_iprintf k o fmt)\n | No_padding , Arg_precision ->\n const (const (make_iprintf k o fmt))\n | Lit_padding _, No_precision ->\n const (make_iprintf k o fmt)\n | Lit_padding _, Lit_precision _ ->\n const (make_iprintf k o fmt)\n | Lit_padding _, Arg_precision ->\n const (const (make_iprintf k o fmt))\n | Arg_padding _, No_precision ->\n const (const (make_iprintf k o fmt))\n | Arg_padding _, Lit_precision _ ->\n const (const (make_iprintf k o fmt))\n | Arg_padding _, Arg_precision ->\n const (const (const (make_iprintf k o fmt)))\nand fn_of_custom_arity : type x y a b c d e f state.\n (state -> f) ->\n state -> (a, b, c, d, e, f) fmt -> (a, x, y) custom_arity -> y =\n fun k o fmt -> function\n | Custom_zero ->\n make_iprintf k o fmt\n | Custom_succ arity ->\n const (fn_of_custom_arity k o fmt arity)\n\n(******************************************************************************)\n (* Continuations for make_printf *)\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n printing entities (string, char, flus, ...) in an output_stream. *)\n(* Used as a continuation of make_printf. *)\nlet rec output_acc o acc = match acc with\n | Acc_formatting_lit (p, fmting_lit) ->\n let s = string_of_formatting_lit fmting_lit in\n output_acc o p; output_string o s;\n | Acc_formatting_gen (p, Acc_open_tag acc') ->\n output_acc o p; output_string o \"@{\"; output_acc o acc';\n | Acc_formatting_gen (p, Acc_open_box acc') ->\n output_acc o p; output_string o \"@[\"; output_acc o acc';\n | Acc_string_literal (p, s)\n | Acc_data_string (p, s) -> output_acc o p; output_string o s\n | Acc_char_literal (p, c)\n | Acc_data_char (p, c) -> output_acc o p; output_char o c\n | Acc_delay (p, f) -> output_acc o p; f o\n | Acc_flush p -> output_acc o p; flush o\n | Acc_invalid_arg (p, msg) -> output_acc o p; invalid_arg msg;\n | End_of_acc -> ()\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n printing entities (string, char, flus, ...) in a buffer. *)\n(* Used as a continuation of make_printf. *)\nlet rec bufput_acc b acc = match acc with\n | Acc_formatting_lit (p, fmting_lit) ->\n let s = string_of_formatting_lit fmting_lit in\n bufput_acc b p; Buffer.add_string b s;\n | Acc_formatting_gen (p, Acc_open_tag acc') ->\n bufput_acc b p; Buffer.add_string b \"@{\"; bufput_acc b acc';\n | Acc_formatting_gen (p, Acc_open_box acc') ->\n bufput_acc b p; Buffer.add_string b \"@[\"; bufput_acc b acc';\n | Acc_string_literal (p, s)\n | Acc_data_string (p, s) -> bufput_acc b p; Buffer.add_string b s\n | Acc_char_literal (p, c)\n | Acc_data_char (p, c) -> bufput_acc b p; Buffer.add_char b c\n | Acc_delay (p, f) -> bufput_acc b p; f b\n | Acc_flush p -> bufput_acc b p;\n | Acc_invalid_arg (p, msg) -> bufput_acc b p; invalid_arg msg;\n | End_of_acc -> ()\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n printing entities (string, char, flus, ...) in a buffer. *)\n(* Differ from bufput_acc by the interpretation of %a and %t. *)\n(* Used as a continuation of make_printf. *)\nlet rec strput_acc b acc = match acc with\n | Acc_formatting_lit (p, fmting_lit) ->\n let s = string_of_formatting_lit fmting_lit in\n strput_acc b p; Buffer.add_string b s;\n | Acc_formatting_gen (p, Acc_open_tag acc') ->\n strput_acc b p; Buffer.add_string b \"@{\"; strput_acc b acc';\n | Acc_formatting_gen (p, Acc_open_box acc') ->\n strput_acc b p; Buffer.add_string b \"@[\"; strput_acc b acc';\n | Acc_string_literal (p, s)\n | Acc_data_string (p, s) -> strput_acc b p; Buffer.add_string b s\n | Acc_char_literal (p, c)\n | Acc_data_char (p, c) -> strput_acc b p; Buffer.add_char b c\n | Acc_delay (p, f) -> strput_acc b p; Buffer.add_string b (f ())\n | Acc_flush p -> strput_acc b p;\n | Acc_invalid_arg (p, msg) -> strput_acc b p; invalid_arg msg;\n | End_of_acc -> ()\n\n(******************************************************************************)\n (* Error management *)\n\n(* Raise [Failure] with a pretty-printed error message. *)\nlet failwith_message (Format (fmt, _)) =\n let buf = Buffer.create 256 in\n let k acc = strput_acc buf acc; failwith (Buffer.contents buf) in\n make_printf k End_of_acc fmt\n\n(******************************************************************************)\n (* Formatting tools *)\n\n(* Convert a string to an open block description (indent, block_type) *)\nlet open_box_of_string str =\n if str = \"\" then (0, Pp_box) else\n let len = String.length str in\n let invalid_box () = failwith_message \"invalid box description %S\" str in\n let rec parse_spaces i =\n if i = len then i else\n match str.[i] with\n | ' ' | '\\t' -> parse_spaces (i + 1)\n | _ -> i\n and parse_lword i j =\n if j = len then j else\n match str.[j] with\n | 'a' .. 'z' -> parse_lword i (j + 1)\n | _ -> j\n and parse_int i j =\n if j = len then j else\n match str.[j] with\n | '0' .. '9' | '-' -> parse_int i (j + 1)\n | _ -> j in\n let wstart = parse_spaces 0 in\n let wend = parse_lword wstart wstart in\n let box_name = String.sub str wstart (wend - wstart) in\n let nstart = parse_spaces wend in\n let nend = parse_int nstart nstart in\n let indent =\n if nstart = nend then 0 else\n try int_of_string (String.sub str nstart (nend - nstart))\n with Failure _ -> invalid_box () in\n let exp_end = parse_spaces nend in\n if exp_end <> len then invalid_box ();\n let box_type = match box_name with\n | \"\" | \"b\" -> Pp_box\n | \"h\" -> Pp_hbox\n | \"v\" -> Pp_vbox\n | \"hv\" -> Pp_hvbox\n | \"hov\" -> Pp_hovbox\n | _ -> invalid_box () in\n (indent, box_type)\n\n(******************************************************************************)\n (* Parsing tools *)\n\n(* Create a padding_fmt_ebb from a padding and a format. *)\n(* Copy the padding to disjoin the type parameters of argument and result. *)\nlet make_padding_fmt_ebb : type x y .\n (x, y) padding -> (_, _, _, _, _, _) fmt ->\n (_, _, _, _, _) padding_fmt_ebb =\nfun pad fmt -> match pad with\n | No_padding -> Padding_fmt_EBB (No_padding, fmt)\n | Lit_padding (s, w) -> Padding_fmt_EBB (Lit_padding (s, w), fmt)\n | Arg_padding s -> Padding_fmt_EBB (Arg_padding s, fmt)\n\n(* Create a precision_fmt_ebb from a precision and a format. *)\n(* Copy the precision to disjoin the type parameters of argument and result. *)\nlet make_precision_fmt_ebb : type x y .\n (x, y) precision -> (_, _, _, _, _, _) fmt ->\n (_, _, _, _, _) precision_fmt_ebb =\nfun prec fmt -> match prec with\n | No_precision -> Precision_fmt_EBB (No_precision, fmt)\n | Lit_precision p -> Precision_fmt_EBB (Lit_precision p, fmt)\n | Arg_precision -> Precision_fmt_EBB (Arg_precision, fmt)\n\n(* Create a padprec_fmt_ebb from a padding, a precision and a format. *)\n(* Copy the padding and the precision to disjoin type parameters of arguments\n and result. *)\nlet make_padprec_fmt_ebb : type x y z t .\n (x, y) padding -> (z, t) precision ->\n (_, _, _, _, _, _) fmt ->\n (_, _, _, _, _) padprec_fmt_ebb =\nfun pad prec fmt ->\n let Precision_fmt_EBB (prec, fmt') = make_precision_fmt_ebb prec fmt in\n match pad with\n | No_padding -> Padprec_fmt_EBB (No_padding, prec, fmt')\n | Lit_padding (s, w) -> Padprec_fmt_EBB (Lit_padding (s, w), prec, fmt')\n | Arg_padding s -> Padprec_fmt_EBB (Arg_padding s, prec, fmt')\n\n(******************************************************************************)\n (* Format parsing *)\n\n(* Parse a string representing a format and create a fmt_ebb. *)\n(* Raise [Failure] in case of invalid format. *)\nlet fmt_ebb_of_string ?legacy_behavior str =\n (* Parameters naming convention: *)\n (* - lit_start: start of the literal sequence. *)\n (* - str_ind: current index in the string. *)\n (* - end_ind: end of the current (sub-)format. *)\n (* - pct_ind: index of the '%' in the current micro-format. *)\n (* - zero: is the '0' flag defined in the current micro-format. *)\n (* - minus: is the '-' flag defined in the current micro-format. *)\n (* - plus: is the '+' flag defined in the current micro-format. *)\n (* - hash: is the '#' flag defined in the current micro-format. *)\n (* - space: is the ' ' flag defined in the current micro-format. *)\n (* - ign: is the '_' flag defined in the current micro-format. *)\n (* - pad: padding of the current micro-format. *)\n (* - prec: precision of the current micro-format. *)\n (* - symb: char representing the conversion ('c', 's', 'd', ...). *)\n (* - char_set: set of characters as bitmap (see scanf %[...]). *)\n\n let legacy_behavior = match legacy_behavior with\n | Some flag -> flag\n | None -> true\n (* When this flag is enabled, the format parser tries to behave as\n the <4.02 implementations, in particular it ignores most benine\n nonsensical format. When the flag is disabled, it will reject any\n format that is not accepted by the specification.\n\n A typical example would be \"%+ d\": specifying both '+' (if the\n number is positive, pad with a '+' to get the same width as\n negative numbers) and ' ' (if the number is positive, pad with\n a space) does not make sense, but the legacy (< 4.02)\n implementation was happy to just ignore the space.\n *)\n in\n\n (* Raise [Failure] with a friendly error message. *)\n let invalid_format_message str_ind msg =\n failwith_message\n \"invalid format %S: at character number %d, %s\"\n str str_ind msg\n in\n\n (* Used when the end of the format (or the current sub-format) was encountered\n unexpectedly. *)\n let unexpected_end_of_format end_ind =\n invalid_format_message end_ind\n \"unexpected end of format\"\n in\n\n (* Used for %0c: no other widths are implemented *)\n let invalid_nonnull_char_width str_ind =\n invalid_format_message str_ind\n \"non-zero widths are unsupported for %c conversions\"\n in\n (* Raise [Failure] with a friendly error message about an option dependency\n problem. *)\n let invalid_format_without str_ind c s =\n failwith_message\n \"invalid format %S: at character number %d, '%c' without %s\"\n str str_ind c s\n in\n\n (* Raise [Failure] with a friendly error message about an unexpected\n character. *)\n let expected_character str_ind expected read =\n failwith_message\n \"invalid format %S: at character number %d, %s expected, read %C\"\n str str_ind expected read\n in\n\n (* Parse the string from beg_ind (included) to end_ind (excluded). *)\n let rec parse : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n fun beg_ind end_ind -> parse_literal beg_ind beg_ind end_ind\n\n (* Read literal characters up to '%' or '@' special characters. *)\n and parse_literal : type e f . int -> int -> int -> (_, _, e, f) fmt_ebb =\n fun lit_start str_ind end_ind ->\n if str_ind = end_ind then add_literal lit_start str_ind End_of_format else\n match str.[str_ind] with\n | '%' ->\n let Fmt_EBB fmt_rest = parse_format str_ind end_ind in\n add_literal lit_start str_ind fmt_rest\n | '@' ->\n let Fmt_EBB fmt_rest = parse_after_at (str_ind + 1) end_ind in\n add_literal lit_start str_ind fmt_rest\n | _ ->\n parse_literal lit_start (str_ind + 1) end_ind\n\n (* Parse a format after '%' *)\n and parse_format : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n fun pct_ind end_ind -> parse_ign pct_ind (pct_ind + 1) end_ind\n\n and parse_ign : type e f . int -> int -> int -> (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind ->\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | '_' -> parse_flags pct_ind (str_ind+1) end_ind true\n | _ -> parse_flags pct_ind str_ind end_ind false\n\n and parse_flags : type e f . int -> int -> int -> bool -> (_, _, e, f) fmt_ebb\n =\n fun pct_ind str_ind end_ind ign ->\n let zero = ref false and minus = ref false\n and plus = ref false and space = ref false\n and hash = ref false in\n let set_flag str_ind flag =\n (* in legacy mode, duplicate flags are accepted *)\n if !flag && not legacy_behavior then\n failwith_message\n \"invalid format %S: at character number %d, duplicate flag %C\"\n str str_ind str.[str_ind];\n flag := true;\n in\n let rec read_flags str_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n begin match str.[str_ind] with\n | '0' -> set_flag str_ind zero; read_flags (str_ind + 1)\n | '-' -> set_flag str_ind minus; read_flags (str_ind + 1)\n | '+' -> set_flag str_ind plus; read_flags (str_ind + 1)\n | '#' -> set_flag str_ind hash; read_flags (str_ind + 1)\n | ' ' -> set_flag str_ind space; read_flags (str_ind + 1)\n | _ ->\n parse_padding pct_ind str_ind end_ind\n !zero !minus !plus !hash !space ign\n end\n in\n read_flags str_ind\n\n (* Try to read a digital or a '*' padding. *)\n and parse_padding : type e f .\n int -> int -> int -> bool -> bool -> bool -> bool -> bool -> bool ->\n (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind zero minus plus hash space ign ->\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n let padty = match zero, minus with\n | false, false -> Right\n | false, true -> Left\n | true, false -> Zeros\n | true, true ->\n if legacy_behavior then Left\n else incompatible_flag pct_ind str_ind '-' \"0\" in\n match str.[str_ind] with\n | '0' .. '9' ->\n let new_ind, width = parse_positive str_ind end_ind 0 in\n parse_after_padding pct_ind new_ind end_ind minus plus hash space ign\n (Lit_padding (padty, width))\n | '*' ->\n parse_after_padding pct_ind (str_ind + 1) end_ind minus plus hash space\n ign (Arg_padding padty)\n | _ ->\n begin match padty with\n | Left ->\n if not legacy_behavior then\n invalid_format_without (str_ind - 1) '-' \"padding\";\n parse_after_padding pct_ind str_ind end_ind minus plus hash space ign\n No_padding\n | Zeros ->\n (* a '0' padding indication not followed by anything should\n be interpreted as a Right padding of width 0. This is used\n by scanning conversions %0s and %0c *)\n parse_after_padding pct_ind str_ind end_ind minus plus hash space ign\n (Lit_padding (Right, 0))\n | Right ->\n parse_after_padding pct_ind str_ind end_ind minus plus hash space ign\n No_padding\n end\n\n (* Is precision defined? *)\n and parse_after_padding : type x e f .\n int -> int -> int -> bool -> bool -> bool -> bool -> bool ->\n (x, _) padding -> (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind minus plus hash space ign pad ->\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | '.' ->\n parse_precision pct_ind (str_ind + 1) end_ind minus plus hash space ign\n pad\n | symb ->\n parse_conversion pct_ind (str_ind + 1) end_ind plus hash space ign pad\n No_precision pad symb\n\n (* Read the digital or '*' precision. *)\n and parse_precision : type x e f .\n int -> int -> int -> bool -> bool -> bool -> bool -> bool ->\n (x, _) padding -> (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind minus plus hash space ign pad ->\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n let parse_literal minus str_ind =\n let new_ind, prec = parse_positive str_ind end_ind 0 in\n parse_after_precision pct_ind new_ind end_ind minus plus hash space ign\n pad (Lit_precision prec) in\n match str.[str_ind] with\n | '0' .. '9' -> parse_literal minus str_ind\n | ('+' | '-') as symb when legacy_behavior ->\n (* Legacy mode would accept and ignore '+' or '-' before the\n integer describing the desired precision; note that this\n cannot happen for padding width, as '+' and '-' already have\n a semantics there.\n\n That said, the idea (supported by this tweak) that width and\n precision literals are \"integer literals\" in the OCaml sense is\n still blatantly wrong, as 123_456 or 0xFF are rejected. *)\n parse_literal (minus || symb = '-') (str_ind + 1)\n | '*' ->\n parse_after_precision pct_ind (str_ind + 1) end_ind minus plus hash space\n ign pad Arg_precision\n | _ ->\n if legacy_behavior then\n (* note that legacy implementation did not ignore '.' without\n a number (as it does for padding indications), but\n interprets it as '.0' *)\n parse_after_precision pct_ind str_ind end_ind minus plus hash space ign\n pad (Lit_precision 0)\n else\n invalid_format_without (str_ind - 1) '.' \"precision\"\n\n (* Try to read the conversion. *)\n and parse_after_precision : type x y z t e f .\n int -> int -> int -> bool -> bool -> bool -> bool -> bool ->\n (x, y) padding -> (z, t) precision -> (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind minus plus hash space ign pad prec ->\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n let parse_conv (type u) (type v) (padprec : (u, v) padding) =\n parse_conversion pct_ind (str_ind + 1) end_ind plus hash space ign pad\n prec padprec str.[str_ind] in\n (* in legacy mode, some formats (%s and %S) accept a weird mix of\n padding and precision, which is merged as a single padding\n information. For example, in %.10s the precision is implicitly\n understood as padding %10s, but the left-padding component may\n be specified either as a left padding or a negative precision:\n %-.3s and %.-3s are equivalent to %-3s *)\n match pad with\n | No_padding -> (\n match minus, prec with\n | _, No_precision -> parse_conv No_padding\n | false, Lit_precision n -> parse_conv (Lit_padding (Right, n))\n | true, Lit_precision n -> parse_conv (Lit_padding (Left, n))\n | false, Arg_precision -> parse_conv (Arg_padding Right)\n | true, Arg_precision -> parse_conv (Arg_padding Left)\n )\n | pad -> parse_conv pad\n\n (* Case analysis on conversion. *)\n and parse_conversion : type x y z t u v e f .\n int -> int -> int -> bool -> bool -> bool -> bool -> (x, y) padding ->\n (z, t) precision -> (u, v) padding -> char -> (_, _, e, f) fmt_ebb =\n fun pct_ind str_ind end_ind plus hash space ign pad prec padprec symb ->\n (* Flags used to check option usages/compatibilities. *)\n let plus_used = ref false and hash_used = ref false\n and space_used = ref false and ign_used = ref false\n and pad_used = ref false and prec_used = ref false in\n\n (* Access to options, update flags. *)\n let get_plus () = plus_used := true; plus\n and get_hash () = hash_used := true; hash\n and get_space () = space_used := true; space\n and get_ign () = ign_used := true; ign\n and get_pad () = pad_used := true; pad\n and get_prec () = prec_used := true; prec\n and get_padprec () = pad_used := true; padprec in\n\n let get_int_pad () : (x,y) padding =\n (* %5.3d is accepted and meaningful: pad to length 5 with\n spaces, but first pad with zeros upto length 3 (0-padding\n is the interpretation of \"precision\" for integer formats).\n\n %05.3d is redundant: pad to length 5 *with zeros*, but\n first pad with zeros... To add insult to the injury, the\n legacy implementation ignores the 0-padding indication and\n does the 5 padding with spaces instead. We reuse this\n interpretation for compatibility, but statically reject this\n format when the legacy mode is disabled, to protect strict\n users from this corner case. *)\n match get_pad (), get_prec () with\n | pad, No_precision -> pad\n | No_padding, _ -> No_padding\n | Lit_padding (Zeros, n), _ ->\n if legacy_behavior then Lit_padding (Right, n)\n else incompatible_flag pct_ind str_ind '0' \"precision\"\n | Arg_padding Zeros, _ ->\n if legacy_behavior then Arg_padding Right\n else incompatible_flag pct_ind str_ind '0' \"precision\"\n | Lit_padding _ as pad, _ -> pad\n | Arg_padding _ as pad, _ -> pad in\n\n (* Check that padty <> Zeros. *)\n let check_no_0 symb (type a b) (pad : (a, b) padding) : (a,b) padding =\n match pad with\n | No_padding -> pad\n | Lit_padding ((Left | Right), _) -> pad\n | Arg_padding (Left | Right) -> pad\n | Lit_padding (Zeros, width) ->\n if legacy_behavior then Lit_padding (Right, width)\n else incompatible_flag pct_ind str_ind symb \"0\"\n | Arg_padding Zeros ->\n if legacy_behavior then Arg_padding Right\n else incompatible_flag pct_ind str_ind symb \"0\"\n in\n\n (* Get padding as a pad_option (see \"%_\", \"%{\", \"%(\" and \"%[\").\n (no need for legacy mode tweaking, those were rejected by the\n legacy parser as well) *)\n let opt_of_pad c (type a) (type b) (pad : (a, b) padding) = match pad with\n | No_padding -> None\n | Lit_padding (Right, width) -> Some width\n | Lit_padding (Zeros, width) ->\n if legacy_behavior then Some width\n else incompatible_flag pct_ind str_ind c \"'0'\"\n | Lit_padding (Left, width) ->\n if legacy_behavior then Some width\n else incompatible_flag pct_ind str_ind c \"'-'\"\n | Arg_padding _ -> incompatible_flag pct_ind str_ind c \"'*'\"\n in\n let get_pad_opt c = opt_of_pad c (get_pad ()) in\n let get_padprec_opt c = opt_of_pad c (get_padprec ()) in\n\n (* Get precision as a prec_option (see \"%_f\").\n (no need for legacy mode tweaking, those were rejected by the\n legacy parser as well) *)\n let get_prec_opt () = match get_prec () with\n | No_precision -> None\n | Lit_precision ndec -> Some ndec\n | Arg_precision -> incompatible_flag pct_ind str_ind '_' \"'*'\"\n in\n\n let fmt_result = match symb with\n | ',' ->\n parse str_ind end_ind\n | 'c' ->\n let char_format fmt_rest = (* %c *)\n if get_ign ()\n then Fmt_EBB (Ignored_param (Ignored_char, fmt_rest))\n else Fmt_EBB (Char fmt_rest)\n in\n let scan_format fmt_rest = (* %0c *)\n if get_ign ()\n then Fmt_EBB (Ignored_param (Ignored_scan_next_char, fmt_rest))\n else Fmt_EBB (Scan_next_char fmt_rest)\n in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n begin match get_pad_opt 'c' with\n | None -> char_format fmt_rest\n | Some 0 -> scan_format fmt_rest\n | Some _n ->\n if not legacy_behavior\n then invalid_nonnull_char_width str_ind\n else (* legacy ignores %c widths *) char_format fmt_rest\n end\n | 'C' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then Fmt_EBB (Ignored_param (Ignored_caml_char,fmt_rest))\n else Fmt_EBB (Caml_char fmt_rest)\n | 's' ->\n let pad = check_no_0 symb (get_padprec ()) in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then\n let ignored = Ignored_string (get_padprec_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padding_fmt_EBB (pad', fmt_rest') =\n make_padding_fmt_ebb pad fmt_rest in\n Fmt_EBB (String (pad', fmt_rest'))\n | 'S' ->\n let pad = check_no_0 symb (get_padprec ()) in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then\n let ignored = Ignored_caml_string (get_padprec_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padding_fmt_EBB (pad', fmt_rest') =\n make_padding_fmt_ebb pad fmt_rest in\n Fmt_EBB (Caml_string (pad', fmt_rest'))\n | 'd' | 'i' | 'x' | 'X' | 'o' | 'u' ->\n let iconv = compute_int_conv pct_ind str_ind (get_plus ()) (get_hash ())\n (get_space ()) symb in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then\n let ignored = Ignored_int (iconv, get_pad_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n Fmt_EBB (Int (iconv, pad', prec', fmt_rest'))\n | 'N' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n let counter = Token_counter in\n if get_ign () then\n let ignored = Ignored_scan_get_counter counter in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n Fmt_EBB (Scan_get_counter (counter, fmt_rest))\n | 'l' | 'n' | 'L' when str_ind=end_ind || not (is_int_base str.[str_ind]) ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n let counter = counter_of_char symb in\n if get_ign () then\n let ignored = Ignored_scan_get_counter counter in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n Fmt_EBB (Scan_get_counter (counter, fmt_rest))\n | 'l' ->\n let iconv =\n compute_int_conv pct_ind (str_ind + 1) (get_plus ()) (get_hash ())\n (get_space ()) str.[str_ind] in\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n if get_ign () then\n let ignored = Ignored_int32 (iconv, get_pad_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n Fmt_EBB (Int32 (iconv, pad', prec', fmt_rest'))\n | 'n' ->\n let iconv =\n compute_int_conv pct_ind (str_ind + 1) (get_plus ())\n (get_hash ()) (get_space ()) str.[str_ind] in\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n if get_ign () then\n let ignored = Ignored_nativeint (iconv, get_pad_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n Fmt_EBB (Nativeint (iconv, pad', prec', fmt_rest'))\n | 'L' ->\n let iconv =\n compute_int_conv pct_ind (str_ind + 1) (get_plus ()) (get_hash ())\n (get_space ()) str.[str_ind] in\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n if get_ign () then\n let ignored = Ignored_int64 (iconv, get_pad_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n make_padprec_fmt_ebb (get_int_pad ()) (get_prec ()) fmt_rest in\n Fmt_EBB (Int64 (iconv, pad', prec', fmt_rest'))\n | 'f' | 'e' | 'E' | 'g' | 'G' | 'F' | 'h' | 'H' ->\n let fconv =\n compute_float_conv pct_ind str_ind\n (get_plus ()) (get_hash ()) (get_space ()) symb in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then\n let ignored = Ignored_float (get_pad_opt '_', get_prec_opt ()) in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padprec_fmt_EBB (pad', prec', fmt_rest') =\n make_padprec_fmt_ebb (get_pad ()) (get_prec ()) fmt_rest in\n Fmt_EBB (Float (fconv, pad', prec', fmt_rest'))\n | 'b' | 'B' ->\n let pad = check_no_0 symb (get_padprec ()) in\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then\n let ignored = Ignored_bool (get_padprec_opt '_') in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n let Padding_fmt_EBB (pad', fmt_rest') =\n make_padding_fmt_ebb pad fmt_rest in\n Fmt_EBB (Bool (pad', fmt_rest'))\n | 'a' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Alpha fmt_rest)\n | 't' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Theta fmt_rest)\n | 'r' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n if get_ign () then Fmt_EBB (Ignored_param (Ignored_reader, fmt_rest))\n else Fmt_EBB (Reader fmt_rest)\n | '!' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Flush fmt_rest)\n | ('%' | '@') as c ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Char_literal (c, fmt_rest))\n | '{' ->\n let sub_end = search_subformat_end str_ind end_ind '}' in\n let Fmt_EBB sub_fmt = parse str_ind sub_end in\n let Fmt_EBB fmt_rest = parse (sub_end + 2) end_ind in\n let sub_fmtty = fmtty_of_fmt sub_fmt in\n if get_ign () then\n let ignored = Ignored_format_arg (get_pad_opt '_', sub_fmtty) in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n Fmt_EBB (Format_arg (get_pad_opt '{', sub_fmtty, fmt_rest))\n | '(' ->\n let sub_end = search_subformat_end str_ind end_ind ')' in\n let Fmt_EBB fmt_rest = parse (sub_end + 2) end_ind in\n let Fmt_EBB sub_fmt = parse str_ind sub_end in\n let sub_fmtty = fmtty_of_fmt sub_fmt in\n if get_ign () then\n let ignored = Ignored_format_subst (get_pad_opt '_', sub_fmtty) in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n Fmt_EBB (Format_subst (get_pad_opt '(', sub_fmtty, fmt_rest))\n | '[' ->\n let next_ind, char_set = parse_char_set str_ind end_ind in\n let Fmt_EBB fmt_rest = parse next_ind end_ind in\n if get_ign () then\n let ignored = Ignored_scan_char_set (get_pad_opt '_', char_set) in\n Fmt_EBB (Ignored_param (ignored, fmt_rest))\n else\n Fmt_EBB (Scan_char_set (get_pad_opt '[', char_set, fmt_rest))\n | '-' | '+' | '#' | ' ' | '_' ->\n failwith_message\n \"invalid format %S: at character number %d, \\\n flag %C is only allowed after the '%%', before padding and precision\"\n str pct_ind symb\n | _ ->\n failwith_message\n \"invalid format %S: at character number %d, \\\n invalid conversion \\\"%%%c\\\"\" str (str_ind - 1) symb\n in\n (* Check for unused options, and reject them as incompatible.\n\n Such checks need to be disabled in legacy mode, as the legacy\n parser silently ignored incompatible flags. *)\n if not legacy_behavior then begin\n if not !plus_used && plus then\n incompatible_flag pct_ind str_ind symb \"'+'\";\n if not !hash_used && hash then\n incompatible_flag pct_ind str_ind symb \"'#'\";\n if not !space_used && space then\n incompatible_flag pct_ind str_ind symb \"' '\";\n if not !pad_used && Padding_EBB pad <> Padding_EBB No_padding then\n incompatible_flag pct_ind str_ind symb \"`padding'\";\n if not !prec_used && Precision_EBB prec <> Precision_EBB No_precision then\n incompatible_flag pct_ind str_ind (if ign then '_' else symb)\n \"`precision'\";\n if ign && plus then incompatible_flag pct_ind str_ind '_' \"'+'\";\n end;\n (* this last test must not be disabled in legacy mode,\n as ignoring it would typically result in a different typing\n than what the legacy parser used *)\n if not !ign_used && ign then\n begin match symb with\n (* argument-less formats can safely be ignored in legacy mode *)\n | ('@' | '%' | '!' | ',') when legacy_behavior -> ()\n | _ ->\n incompatible_flag pct_ind str_ind symb \"'_'\"\n end;\n fmt_result\n\n (* Parse formatting information (after '@'). *)\n and parse_after_at : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n fun str_ind end_ind ->\n if str_ind = end_ind then Fmt_EBB (Char_literal ('@', End_of_format))\n else\n match str.[str_ind] with\n | '[' ->\n parse_tag false (str_ind + 1) end_ind\n | ']' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Close_box, fmt_rest))\n | '{' ->\n parse_tag true (str_ind + 1) end_ind\n | '}' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Close_tag, fmt_rest))\n | ',' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Break (\"@,\", 0, 0), fmt_rest))\n | ' ' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Break (\"@ \", 1, 0), fmt_rest))\n | ';' ->\n parse_good_break (str_ind + 1) end_ind\n | '?' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (FFlush, fmt_rest))\n | '\\n' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Force_newline, fmt_rest))\n | '.' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Flush_newline, fmt_rest))\n | '<' ->\n parse_magic_size (str_ind + 1) end_ind\n | '@' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Escaped_at, fmt_rest))\n | '%' when str_ind + 1 < end_ind && str.[str_ind + 1] = '%' ->\n let Fmt_EBB fmt_rest = parse (str_ind + 2) end_ind in\n Fmt_EBB (Formatting_lit (Escaped_percent, fmt_rest))\n | '%' ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Char_literal ('@', fmt_rest))\n | c ->\n let Fmt_EBB fmt_rest = parse (str_ind + 1) end_ind in\n Fmt_EBB (Formatting_lit (Scan_indic c, fmt_rest))\n\n (* Try to read the optional after \"@{\" or \"@[\". *)\n and parse_tag : type e f . bool -> int -> int -> (_, _, e, f) fmt_ebb =\n fun is_open_tag str_ind end_ind ->\n try\n if str_ind = end_ind then raise Not_found;\n match str.[str_ind] with\n | '<' ->\n let ind = String.index_from str (str_ind + 1) '>' in\n if ind >= end_ind then raise Not_found;\n let sub_str = String.sub str str_ind (ind - str_ind + 1) in\n let Fmt_EBB fmt_rest = parse (ind + 1) end_ind in\n let Fmt_EBB sub_fmt = parse str_ind (ind + 1) in\n let sub_format = Format (sub_fmt, sub_str) in\n let formatting =\n if is_open_tag then Open_tag sub_format else Open_box sub_format in\n Fmt_EBB (Formatting_gen (formatting, fmt_rest))\n | _ ->\n raise Not_found\n with Not_found ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n let sub_format = Format (End_of_format, \"\") in\n let formatting =\n if is_open_tag then Open_tag sub_format else Open_box sub_format in\n Fmt_EBB (Formatting_gen (formatting, fmt_rest))\n\n (* Try to read the optional after \"@;\". *)\n and parse_good_break : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n fun str_ind end_ind ->\n let next_ind, formatting_lit =\n try\n if str_ind = end_ind || str.[str_ind] <> '<' then raise Not_found;\n let str_ind_1 = parse_spaces (str_ind + 1) end_ind in\n match str.[str_ind_1] with\n | '0' .. '9' | '-' -> (\n let str_ind_2, width = parse_integer str_ind_1 end_ind in\n let str_ind_3 = parse_spaces str_ind_2 end_ind in\n match str.[str_ind_3] with\n | '>' ->\n let s = String.sub str (str_ind-2) (str_ind_3-str_ind+3) in\n str_ind_3 + 1, Break (s, width, 0)\n | '0' .. '9' | '-' ->\n let str_ind_4, offset = parse_integer str_ind_3 end_ind in\n let str_ind_5 = parse_spaces str_ind_4 end_ind in\n if str.[str_ind_5] <> '>' then raise Not_found;\n let s = String.sub str (str_ind-2) (str_ind_5-str_ind+3) in\n str_ind_5 + 1, Break (s, width, offset)\n | _ -> raise Not_found\n )\n | _ -> raise Not_found\n with Not_found | Failure _ ->\n str_ind, Break (\"@;\", 1, 0)\n in\n let Fmt_EBB fmt_rest = parse next_ind end_ind in\n Fmt_EBB (Formatting_lit (formatting_lit, fmt_rest))\n\n (* Parse the size in a . *)\n and parse_magic_size : type e f . int -> int -> (_, _, e, f) fmt_ebb =\n fun str_ind end_ind ->\n match\n try\n let str_ind_1 = parse_spaces str_ind end_ind in\n match str.[str_ind_1] with\n | '0' .. '9' | '-' ->\n let str_ind_2, size = parse_integer str_ind_1 end_ind in\n let str_ind_3 = parse_spaces str_ind_2 end_ind in\n if str.[str_ind_3] <> '>' then raise Not_found;\n let s = String.sub str (str_ind - 2) (str_ind_3 - str_ind + 3) in\n Some (str_ind_3 + 1, Magic_size (s, size))\n | _ -> None\n with Not_found | Failure _ ->\n None\n with\n | Some (next_ind, formatting_lit) ->\n let Fmt_EBB fmt_rest = parse next_ind end_ind in\n Fmt_EBB (Formatting_lit (formatting_lit, fmt_rest))\n | None ->\n let Fmt_EBB fmt_rest = parse str_ind end_ind in\n Fmt_EBB (Formatting_lit (Scan_indic '<', fmt_rest))\n\n (* Parse and construct a char set. *)\n and parse_char_set str_ind end_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n\n let char_set = create_char_set () in\n let add_char c =\n add_in_char_set char_set c;\n in\n let add_range c c' =\n for i = int_of_char c to int_of_char c' do\n add_in_char_set char_set (char_of_int i);\n done;\n in\n\n let fail_single_percent str_ind =\n failwith_message\n \"invalid format %S: '%%' alone is not accepted in character sets, \\\n use %%%% instead at position %d.\" str str_ind\n in\n\n (* Parse the first character of a char set. *)\n let rec parse_char_set_start str_ind end_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n let c = str.[str_ind] in\n parse_char_set_after_char (str_ind + 1) end_ind c\n\n (* Parse the content of a char set until the first ']'. *)\n and parse_char_set_content str_ind end_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | ']' ->\n str_ind + 1\n | '-' ->\n add_char '-';\n parse_char_set_content (str_ind + 1) end_ind\n | c ->\n parse_char_set_after_char (str_ind + 1) end_ind c\n\n (* Test for range in char set. *)\n and parse_char_set_after_char str_ind end_ind c =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | ']' ->\n add_char c;\n str_ind + 1\n | '-' ->\n parse_char_set_after_minus (str_ind + 1) end_ind c\n | ('%' | '@') as c' when c = '%' ->\n add_char c';\n parse_char_set_content (str_ind + 1) end_ind\n | c' ->\n if c = '%' then fail_single_percent str_ind;\n (* note that '@' alone is accepted, as done by the legacy\n implementation; the documentation specifically requires %@\n so we could warn on that *)\n add_char c;\n parse_char_set_after_char (str_ind + 1) end_ind c'\n\n (* Manage range in char set (except if the '-' the last char before ']') *)\n and parse_char_set_after_minus str_ind end_ind c =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | ']' ->\n add_char c;\n add_char '-';\n str_ind + 1\n | '%' ->\n if str_ind + 1 = end_ind then unexpected_end_of_format end_ind;\n begin match str.[str_ind + 1] with\n | ('%' | '@') as c' ->\n add_range c c';\n parse_char_set_content (str_ind + 2) end_ind\n | _ -> fail_single_percent str_ind\n end\n | c' ->\n add_range c c';\n parse_char_set_content (str_ind + 1) end_ind\n in\n let str_ind, reverse =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | '^' -> str_ind + 1, true\n | _ -> str_ind, false in\n let next_ind = parse_char_set_start str_ind end_ind in\n let char_set = freeze_char_set char_set in\n next_ind, (if reverse then rev_char_set char_set else char_set)\n\n (* Consume all next spaces, raise an Failure if end_ind is reached. *)\n and parse_spaces str_ind end_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n if str.[str_ind] = ' ' then parse_spaces (str_ind + 1) end_ind else str_ind\n\n (* Read a positive integer from the string, raise a Failure if end_ind is\n reached. *)\n and parse_positive str_ind end_ind acc =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | '0' .. '9' as c ->\n let new_acc = acc * 10 + (int_of_char c - int_of_char '0') in\n if new_acc > Sys.max_string_length then\n failwith_message\n \"invalid format %S: integer %d is greater than the limit %d\"\n str new_acc Sys.max_string_length\n else\n parse_positive (str_ind + 1) end_ind new_acc\n | _ -> str_ind, acc\n\n (* Read a positive or negative integer from the string, raise a Failure\n if end_ind is reached. *)\n and parse_integer str_ind end_ind =\n if str_ind = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind] with\n | '0' .. '9' -> parse_positive str_ind end_ind 0\n | '-' -> (\n if str_ind + 1 = end_ind then unexpected_end_of_format end_ind;\n match str.[str_ind + 1] with\n | '0' .. '9' ->\n let next_ind, n = parse_positive (str_ind + 1) end_ind 0 in\n next_ind, -n\n | c ->\n expected_character (str_ind + 1) \"digit\" c\n )\n | _ -> assert false\n\n (* Add a literal to a format from a literal character sub-sequence. *)\n and add_literal : type a d e f .\n int -> int -> (a, _, _, d, e, f) fmt ->\n (_, _, e, f) fmt_ebb =\n fun lit_start str_ind fmt -> match str_ind - lit_start with\n | 0 -> Fmt_EBB fmt\n | 1 -> Fmt_EBB (Char_literal (str.[lit_start], fmt))\n | size -> Fmt_EBB (String_literal (String.sub str lit_start size, fmt))\n\n (* Search the end of the current sub-format\n (i.e. the corresponding \"%}\" or \"%)\") *)\n and search_subformat_end str_ind end_ind c =\n if str_ind = end_ind then\n failwith_message\n \"invalid format %S: unclosed sub-format, \\\n expected \\\"%%%c\\\" at character number %d\" str c end_ind;\n match str.[str_ind] with\n | '%' ->\n if str_ind + 1 = end_ind then unexpected_end_of_format end_ind;\n if str.[str_ind + 1] = c then (* End of format found *) str_ind else\n begin match str.[str_ind + 1] with\n | '_' ->\n (* Search for \"%_(\" or \"%_{\". *)\n if str_ind + 2 = end_ind then unexpected_end_of_format end_ind;\n begin match str.[str_ind + 2] with\n | '{' ->\n let sub_end = search_subformat_end (str_ind + 3) end_ind '}' in\n search_subformat_end (sub_end + 2) end_ind c\n | '(' ->\n let sub_end = search_subformat_end (str_ind + 3) end_ind ')' in\n search_subformat_end (sub_end + 2) end_ind c\n | _ -> search_subformat_end (str_ind + 3) end_ind c\n end\n | '{' ->\n (* %{...%} sub-format found. *)\n let sub_end = search_subformat_end (str_ind + 2) end_ind '}' in\n search_subformat_end (sub_end + 2) end_ind c\n | '(' ->\n (* %(...%) sub-format found. *)\n let sub_end = search_subformat_end (str_ind + 2) end_ind ')' in\n search_subformat_end (sub_end + 2) end_ind c\n | '}' ->\n (* Error: %(...%}. *)\n expected_character (str_ind + 1) \"character ')'\" '}'\n | ')' ->\n (* Error: %{...%). *)\n expected_character (str_ind + 1) \"character '}'\" ')'\n | _ ->\n search_subformat_end (str_ind + 2) end_ind c\n end\n | _ -> search_subformat_end (str_ind + 1) end_ind c\n\n (* Check if symb is a valid int conversion after \"%l\", \"%n\" or \"%L\" *)\n and is_int_base symb = match symb with\n | 'd' | 'i' | 'x' | 'X' | 'o' | 'u' -> true\n | _ -> false\n\n (* Convert a char (l, n or L) to its associated counter. *)\n and counter_of_char symb = match symb with\n | 'l' -> Line_counter | 'n' -> Char_counter\n | 'L' -> Token_counter | _ -> assert false\n\n (* Convert (plus, symb) to its associated int_conv. *)\n and compute_int_conv pct_ind str_ind plus hash space symb =\n match plus, hash, space, symb with\n | false, false, false, 'd' -> Int_d | false, false, false, 'i' -> Int_i\n | false, false, true, 'd' -> Int_sd | false, false, true, 'i' -> Int_si\n | true, false, false, 'd' -> Int_pd | true, false, false, 'i' -> Int_pi\n | false, false, false, 'x' -> Int_x | false, false, false, 'X' -> Int_X\n | false, true, false, 'x' -> Int_Cx | false, true, false, 'X' -> Int_CX\n | false, false, false, 'o' -> Int_o\n | false, true, false, 'o' -> Int_Co\n | false, false, false, 'u' -> Int_u\n | false, true, false, 'd' -> Int_Cd\n | false, true, false, 'i' -> Int_Ci\n | false, true, false, 'u' -> Int_Cu\n | _, true, _, 'x' when legacy_behavior -> Int_Cx\n | _, true, _, 'X' when legacy_behavior -> Int_CX\n | _, true, _, 'o' when legacy_behavior -> Int_Co\n | _, true, _, ('d' | 'i' | 'u') ->\n if legacy_behavior then (* ignore *)\n compute_int_conv pct_ind str_ind plus false space symb\n else incompatible_flag pct_ind str_ind symb \"'#'\"\n | true, _, true, _ ->\n if legacy_behavior then\n (* plus and space: legacy implementation prefers plus *)\n compute_int_conv pct_ind str_ind plus hash false symb\n else incompatible_flag pct_ind str_ind ' ' \"'+'\"\n | false, _, true, _ ->\n if legacy_behavior then (* ignore *)\n compute_int_conv pct_ind str_ind plus hash false symb\n else incompatible_flag pct_ind str_ind symb \"' '\"\n | true, _, false, _ ->\n if legacy_behavior then (* ignore *)\n compute_int_conv pct_ind str_ind false hash space symb\n else incompatible_flag pct_ind str_ind symb \"'+'\"\n | false, _, false, _ -> assert false\n\n (* Convert (plus, space, symb) to its associated float_conv. *)\n and compute_float_conv pct_ind str_ind plus hash space symb =\n let flag = match plus, space with\n | false, false -> Float_flag_\n | false, true -> Float_flag_s\n | true, false -> Float_flag_p\n | true, true ->\n (* plus and space: legacy implementation prefers plus *)\n if legacy_behavior then Float_flag_p\n else incompatible_flag pct_ind str_ind ' ' \"'+'\" in\n let kind = match hash, symb with\n | _, 'f' -> Float_f\n | _, 'e' -> Float_e\n | _, 'E' -> Float_E\n | _, 'g' -> Float_g\n | _, 'G' -> Float_G\n | _, 'h' -> Float_h\n | _, 'H' -> Float_H\n | false, 'F' -> Float_F\n | true, 'F' -> Float_CF\n | _ -> assert false in\n flag, kind\n\n (* Raise [Failure] with a friendly error message about incompatible options.*)\n and incompatible_flag : type a . int -> int -> char -> string -> a =\n fun pct_ind str_ind symb option ->\n let subfmt = String.sub str pct_ind (str_ind - pct_ind) in\n failwith_message\n \"invalid format %S: at character number %d, \\\n %s is incompatible with '%c' in sub-format %S\"\n str pct_ind option symb subfmt\n\n in parse 0 (String.length str)\n\n(******************************************************************************)\n (* Guarded string to format conversions *)\n\n(* Convert a string to a format according to an fmtty. *)\n(* Raise [Failure] with an error message in case of type mismatch. *)\nlet format_of_string_fmtty str fmtty =\n let Fmt_EBB fmt = fmt_ebb_of_string str in\n try Format (type_format fmt fmtty, str)\n with Type_mismatch ->\n failwith_message\n \"bad input: format type mismatch between %S and %S\"\n str (string_of_fmtty fmtty)\n\n(* Convert a string to a format compatible with an other format. *)\n(* Raise [Failure] with an error message in case of type mismatch. *)\nlet format_of_string_format str (Format (fmt', str')) =\n let Fmt_EBB fmt = fmt_ebb_of_string str in\n try Format (type_format fmt (fmtty_of_fmt fmt'), str)\n with Type_mismatch ->\n failwith_message\n \"bad input: format type mismatch between %S and %S\" str str'\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nopen Printf\n\ntype t = exn = ..\n\nlet printers = Atomic.make []\n\nlet locfmt = format_of_string \"File \\\"%s\\\", line %d, characters %d-%d: %s\"\n\nlet field x i =\n let f = Obj.field x i in\n if not (Obj.is_block f) then\n sprintf \"%d\" (Obj.magic f : int) (* can also be a char *)\n else if Obj.tag f = Obj.string_tag then\n sprintf \"%S\" (Obj.magic f : string)\n else if Obj.tag f = Obj.double_tag then\n string_of_float (Obj.magic f : float)\n else\n \"_\"\n\nlet rec other_fields x i =\n if i >= Obj.size x then \"\"\n else sprintf \", %s%s\" (field x i) (other_fields x (i+1))\n\nlet fields x =\n match Obj.size x with\n | 0 -> \"\"\n | 1 -> \"\"\n | 2 -> sprintf \"(%s)\" (field x 1)\n | _ -> sprintf \"(%s%s)\" (field x 1) (other_fields x 2)\n\nlet use_printers x =\n let rec conv = function\n | hd :: tl ->\n (match hd x with\n | None | exception _ -> conv tl\n | Some s -> Some s)\n | [] -> None in\n conv (Atomic.get printers)\n\nlet to_string_default = function\n | Out_of_memory -> \"Out of memory\"\n | Stack_overflow -> \"Stack overflow\"\n | Match_failure(file, line, char) ->\n sprintf locfmt file line char (char+5) \"Pattern matching failed\"\n | Assert_failure(file, line, char) ->\n sprintf locfmt file line char (char+6) \"Assertion failed\"\n | Undefined_recursive_module(file, line, char) ->\n sprintf locfmt file line char (char+6) \"Undefined recursive module\"\n | x ->\n let x = Obj.repr x in\n if Obj.tag x <> 0 then\n (Obj.magic (Obj.field x 0) : string)\n else\n let constructor =\n (Obj.magic (Obj.field (Obj.field x 0) 0) : string) in\n constructor ^ (fields x)\n\nlet to_string e =\n match use_printers e with\n | Some s -> s\n | None -> to_string_default e\n\nlet print fct arg =\n try\n fct arg\n with x ->\n eprintf \"Uncaught exception: %s\\n\" (to_string x);\n flush stderr;\n raise x\n\nlet catch fct arg =\n try\n fct arg\n with x ->\n flush stdout;\n eprintf \"Uncaught exception: %s\\n\" (to_string x);\n exit 2\n\ntype raw_backtrace_slot\ntype raw_backtrace_entry = private int\ntype raw_backtrace = raw_backtrace_entry array\n\nlet raw_backtrace_entries bt = bt\n\nexternal get_raw_backtrace:\n unit -> raw_backtrace = \"caml_get_exception_raw_backtrace\"\n\nexternal raise_with_backtrace: exn -> raw_backtrace -> 'a\n = \"%raise_with_backtrace\"\n\ntype backtrace_slot =\n | Known_location of {\n is_raise : bool;\n filename : string;\n line_number : int;\n start_char : int;\n end_char : int;\n is_inline : bool;\n defname : string;\n }\n | Unknown_location of {\n is_raise : bool\n }\n\n(* to avoid warning *)\nlet _ = [Known_location { is_raise = false; filename = \"\";\n line_number = 0; start_char = 0; end_char = 0;\n is_inline = false; defname = \"\" };\n Unknown_location { is_raise = false }]\n\nexternal convert_raw_backtrace_slot:\n raw_backtrace_slot -> backtrace_slot = \"caml_convert_raw_backtrace_slot\"\n\nexternal convert_raw_backtrace:\n raw_backtrace -> backtrace_slot array = \"caml_convert_raw_backtrace\"\n\nlet convert_raw_backtrace bt =\n try Some (convert_raw_backtrace bt)\n with Failure _ -> None\n\nlet format_backtrace_slot pos slot =\n let info is_raise =\n if is_raise then\n if pos = 0 then \"Raised at\" else \"Re-raised at\"\n else\n if pos = 0 then \"Raised by primitive operation at\" else \"Called from\"\n in\n match slot with\n | Unknown_location l ->\n if l.is_raise then\n (* compiler-inserted re-raise, skipped *) None\n else\n Some (sprintf \"%s unknown location\" (info false))\n | Known_location l ->\n Some (sprintf \"%s %s in file \\\"%s\\\"%s, line %d, characters %d-%d\"\n (info l.is_raise) l.defname l.filename\n (if l.is_inline then \" (inlined)\" else \"\")\n l.line_number l.start_char l.end_char)\n\nlet print_exception_backtrace outchan backtrace =\n match backtrace with\n | None ->\n fprintf outchan\n \"(Program not linked with -g, cannot print stack backtrace)\\n\"\n | Some a ->\n for i = 0 to Array.length a - 1 do\n match format_backtrace_slot i a.(i) with\n | None -> ()\n | Some str -> fprintf outchan \"%s\\n\" str\n done\n\nlet print_raw_backtrace outchan raw_backtrace =\n print_exception_backtrace outchan (convert_raw_backtrace raw_backtrace)\n\n(* confusingly named: prints the global current backtrace *)\nlet print_backtrace outchan =\n print_raw_backtrace outchan (get_raw_backtrace ())\n\nlet backtrace_to_string backtrace =\n match backtrace with\n | None ->\n \"(Program not linked with -g, cannot print stack backtrace)\\n\"\n | Some a ->\n let b = Buffer.create 1024 in\n for i = 0 to Array.length a - 1 do\n match format_backtrace_slot i a.(i) with\n | None -> ()\n | Some str -> bprintf b \"%s\\n\" str\n done;\n Buffer.contents b\n\nlet raw_backtrace_to_string raw_backtrace =\n backtrace_to_string (convert_raw_backtrace raw_backtrace)\n\nlet backtrace_slot_is_raise = function\n | Known_location l -> l.is_raise\n | Unknown_location l -> l.is_raise\n\nlet backtrace_slot_is_inline = function\n | Known_location l -> l.is_inline\n | Unknown_location _ -> false\n\ntype location = {\n filename : string;\n line_number : int;\n start_char : int;\n end_char : int;\n}\n\nlet backtrace_slot_location = function\n | Unknown_location _ -> None\n | Known_location l ->\n Some {\n filename = l.filename;\n line_number = l.line_number;\n start_char = l.start_char;\n end_char = l.end_char;\n }\n\nlet backtrace_slot_defname = function\n | Unknown_location _\n | Known_location { defname = \"\" } -> None\n | Known_location l -> Some l.defname\n\nlet backtrace_slots raw_backtrace =\n (* The documentation of this function guarantees that Some is\n returned only if a part of the trace is usable. This gives us\n a bit more work than just convert_raw_backtrace, but it makes the\n API more user-friendly -- otherwise most users would have to\n reimplement the \"Program not linked with -g, sorry\" logic\n themselves. *)\n match convert_raw_backtrace raw_backtrace with\n | None -> None\n | Some backtrace ->\n let usable_slot = function\n | Unknown_location _ -> false\n | Known_location _ -> true in\n let rec exists_usable = function\n | (-1) -> false\n | i -> usable_slot backtrace.(i) || exists_usable (i - 1) in\n if exists_usable (Array.length backtrace - 1)\n then Some backtrace\n else None\n\nlet backtrace_slots_of_raw_entry entry =\n backtrace_slots [| entry |]\n\nmodule Slot = struct\n type t = backtrace_slot\n let format = format_backtrace_slot\n let is_raise = backtrace_slot_is_raise\n let is_inline = backtrace_slot_is_inline\n let location = backtrace_slot_location\n let name = backtrace_slot_defname\nend\n\nlet raw_backtrace_length bt = Array.length bt\n\nexternal get_raw_backtrace_slot :\n raw_backtrace -> int -> raw_backtrace_slot = \"caml_raw_backtrace_slot\"\n\nexternal get_raw_backtrace_next_slot :\n raw_backtrace_slot -> raw_backtrace_slot option\n = \"caml_raw_backtrace_next_slot\"\n\n(* confusingly named:\n returns the *string* corresponding to the global current backtrace *)\nlet get_backtrace () = raw_backtrace_to_string (get_raw_backtrace ())\n\nexternal record_backtrace: bool -> unit = \"caml_record_backtrace\"\nexternal backtrace_status: unit -> bool = \"caml_backtrace_status\"\n\nlet rec register_printer fn =\n let old_printers = Atomic.get printers in\n let new_printers = fn :: old_printers in\n let success = Atomic.compare_and_set printers old_printers new_printers in\n if not success then register_printer fn\n\nexternal get_callstack: int -> raw_backtrace = \"caml_get_current_callstack\"\n\nlet exn_slot x =\n let x = Obj.repr x in\n if Obj.tag x = 0 then Obj.field x 0 else x\n\nlet exn_slot_id x =\n let slot = exn_slot x in\n (Obj.obj (Obj.field slot 1) : int)\n\nlet exn_slot_name x =\n let slot = exn_slot x in\n (Obj.obj (Obj.field slot 0) : string)\n\nexternal get_debug_info_status : unit -> int = \"caml_ml_debug_info_status\"\n\n(* Descriptions for errors in startup.h. See also backtrace.c *)\nlet errors = [| \"\";\n (* FILE_NOT_FOUND *)\n \"(Cannot print locations:\\n \\\n bytecode executable program file not found)\";\n (* BAD_BYTECODE *)\n \"(Cannot print locations:\\n \\\n bytecode executable program file appears to be corrupt)\";\n (* WRONG_MAGIC *)\n \"(Cannot print locations:\\n \\\n bytecode executable program file has wrong magic number)\";\n (* NO_FDS *)\n \"(Cannot print locations:\\n \\\n bytecode executable program file cannot be opened;\\n \\\n -- too many open files. Try running with OCAMLRUNPARAM=b=2)\"\n|]\n\nlet default_uncaught_exception_handler exn raw_backtrace =\n eprintf \"Fatal error: exception %s\\n\" (to_string exn);\n print_raw_backtrace stderr raw_backtrace;\n let status = get_debug_info_status () in\n if status < 0 then\n prerr_endline errors.(abs status);\n flush stderr\n\nlet uncaught_exception_handler = ref default_uncaught_exception_handler\n\nlet set_uncaught_exception_handler fn = uncaught_exception_handler := fn\n\nlet empty_backtrace : raw_backtrace = [| |]\n\nlet try_get_raw_backtrace () =\n try\n get_raw_backtrace ()\n with _ (* Out_of_memory? *) ->\n empty_backtrace\n\nlet handle_uncaught_exception' exn debugger_in_use =\n try\n (* Get the backtrace now, in case one of the [at_exit] function\n destroys it. *)\n let raw_backtrace =\n if debugger_in_use (* Same test as in [runtime/printexc.c] *) then\n empty_backtrace\n else\n try_get_raw_backtrace ()\n in\n (try Stdlib.do_at_exit () with _ -> ());\n try\n !uncaught_exception_handler exn raw_backtrace\n with exn' ->\n let raw_backtrace' = try_get_raw_backtrace () in\n eprintf \"Fatal error: exception %s\\n\" (to_string exn);\n print_raw_backtrace stderr raw_backtrace;\n eprintf \"Fatal error in uncaught exception handler: exception %s\\n\"\n (to_string exn');\n print_raw_backtrace stderr raw_backtrace';\n flush stderr\n with\n | Out_of_memory ->\n prerr_endline\n \"Fatal error: out of memory in uncaught exception handler\"\n\n(* This function is called by [caml_fatal_uncaught_exception] in\n [runtime/printexc.c] which expects no exception is raised. *)\nlet handle_uncaught_exception exn debugger_in_use =\n try\n handle_uncaught_exception' exn debugger_in_use\n with _ ->\n (* There is not much we can do at this point *)\n ()\n\nexternal register_named_value : string -> 'a -> unit\n = \"caml_register_named_value\"\n\nlet () =\n register_named_value \"Printexc.handle_uncaught_exception\"\n handle_uncaught_exception\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy and Damien Doligez, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nlet generic_quote quotequote s =\n let l = String.length s in\n let b = Buffer.create (l + 20) in\n Buffer.add_char b '\\'';\n for i = 0 to l - 1 do\n if s.[i] = '\\''\n then Buffer.add_string b quotequote\n else Buffer.add_char b s.[i]\n done;\n Buffer.add_char b '\\'';\n Buffer.contents b\n\n(* This function implements the Open Group specification found here:\n [[1]] http://pubs.opengroup.org/onlinepubs/9699919799/utilities/basename.html\n In step 1 of [[1]], we choose to return \".\" for empty input.\n (for compatibility with previous versions of OCaml)\n In step 2, we choose to process \"//\" normally.\n Step 6 is not implemented: we consider that the [suffix] operand is\n always absent. Suffixes are handled by [chop_suffix] and [chop_extension].\n*)\nlet generic_basename is_dir_sep current_dir_name name =\n let rec find_end n =\n if n < 0 then String.sub name 0 1\n else if is_dir_sep name n then find_end (n - 1)\n else find_beg n (n + 1)\n and find_beg n p =\n if n < 0 then String.sub name 0 p\n else if is_dir_sep name n then String.sub name (n + 1) (p - n - 1)\n else find_beg (n - 1) p\n in\n if name = \"\"\n then current_dir_name\n else find_end (String.length name - 1)\n\n(* This function implements the Open Group specification found here:\n [[2]] http://pubs.opengroup.org/onlinepubs/9699919799/utilities/dirname.html\n In step 6 of [[2]], we choose to process \"//\" normally.\n*)\nlet generic_dirname is_dir_sep current_dir_name name =\n let rec trailing_sep n =\n if n < 0 then String.sub name 0 1\n else if is_dir_sep name n then trailing_sep (n - 1)\n else base n\n and base n =\n if n < 0 then current_dir_name\n else if is_dir_sep name n then intermediate_sep n\n else base (n - 1)\n and intermediate_sep n =\n if n < 0 then String.sub name 0 1\n else if is_dir_sep name n then intermediate_sep (n - 1)\n else String.sub name 0 (n + 1)\n in\n if name = \"\"\n then current_dir_name\n else trailing_sep (String.length name - 1)\n\nmodule type SYSDEPS = sig\n val null : string\n val current_dir_name : string\n val parent_dir_name : string\n val dir_sep : string\n val is_dir_sep : string -> int -> bool\n val is_relative : string -> bool\n val is_implicit : string -> bool\n val check_suffix : string -> string -> bool\n val chop_suffix_opt : suffix:string -> string -> string option\n val temp_dir_name : string\n val quote : string -> string\n val quote_command :\n string -> ?stdin: string -> ?stdout: string -> ?stderr: string\n -> string list -> string\n val basename : string -> string\n val dirname : string -> string\nend\n\nmodule Unix : SYSDEPS = struct\n let null = \"/dev/null\"\n let current_dir_name = \".\"\n let parent_dir_name = \"..\"\n let dir_sep = \"/\"\n let is_dir_sep s i = s.[i] = '/'\n let is_relative n = String.length n < 1 || n.[0] <> '/'\n let is_implicit n =\n is_relative n\n && (String.length n < 2 || String.sub n 0 2 <> \"./\")\n && (String.length n < 3 || String.sub n 0 3 <> \"../\")\n let check_suffix name suff =\n String.ends_with ~suffix:suff name\n\n let chop_suffix_opt ~suffix filename =\n let len_s = String.length suffix and len_f = String.length filename in\n if len_f >= len_s then\n let r = String.sub filename (len_f - len_s) len_s in\n if r = suffix then\n Some (String.sub filename 0 (len_f - len_s))\n else\n None\n else\n None\n\n let temp_dir_name =\n try Sys.getenv \"TMPDIR\" with Not_found -> \"/tmp\"\n let quote = generic_quote \"'\\\\''\"\n let quote_command cmd ?stdin ?stdout ?stderr args =\n String.concat \" \" (List.map quote (cmd :: args))\n ^ (match stdin with None -> \"\" | Some f -> \" <\" ^ quote f)\n ^ (match stdout with None -> \"\" | Some f -> \" >\" ^ quote f)\n ^ (match stderr with None -> \"\" | Some f -> if stderr = stdout\n then \" 2>&1\"\n else \" 2>\" ^ quote f)\n let basename = generic_basename is_dir_sep current_dir_name\n let dirname = generic_dirname is_dir_sep current_dir_name\nend\n\nmodule Win32 : SYSDEPS = struct\n let null = \"NUL\"\n let current_dir_name = \".\"\n let parent_dir_name = \"..\"\n let dir_sep = \"\\\\\"\n let is_dir_sep s i = let c = s.[i] in c = '/' || c = '\\\\' || c = ':'\n let is_relative n =\n (String.length n < 1 || n.[0] <> '/')\n && (String.length n < 1 || n.[0] <> '\\\\')\n && (String.length n < 2 || n.[1] <> ':')\n let is_implicit n =\n is_relative n\n && (String.length n < 2 || String.sub n 0 2 <> \"./\")\n && (String.length n < 2 || String.sub n 0 2 <> \".\\\\\")\n && (String.length n < 3 || String.sub n 0 3 <> \"../\")\n && (String.length n < 3 || String.sub n 0 3 <> \"..\\\\\")\n let check_suffix name suff =\n String.length name >= String.length suff &&\n (let s = String.sub name (String.length name - String.length suff)\n (String.length suff) in\n String.lowercase_ascii s = String.lowercase_ascii suff)\n\n let chop_suffix_opt ~suffix filename =\n let len_s = String.length suffix and len_f = String.length filename in\n if len_f >= len_s then\n let r = String.sub filename (len_f - len_s) len_s in\n if String.lowercase_ascii r = String.lowercase_ascii suffix then\n Some (String.sub filename 0 (len_f - len_s))\n else\n None\n else\n None\n\n\n let temp_dir_name =\n try Sys.getenv \"TEMP\" with Not_found -> \".\"\n let quote s =\n let l = String.length s in\n let b = Buffer.create (l + 20) in\n Buffer.add_char b '\\\"';\n let rec loop i =\n if i = l then Buffer.add_char b '\\\"' else\n match s.[i] with\n | '\\\"' -> loop_bs 0 i;\n | '\\\\' -> loop_bs 0 i;\n | c -> Buffer.add_char b c; loop (i+1);\n and loop_bs n i =\n if i = l then begin\n Buffer.add_char b '\\\"';\n add_bs n;\n end else begin\n match s.[i] with\n | '\\\"' -> add_bs (2*n+1); Buffer.add_char b '\\\"'; loop (i+1);\n | '\\\\' -> loop_bs (n+1) (i+1);\n | _ -> add_bs n; loop i\n end\n and add_bs n = for _j = 1 to n do Buffer.add_char b '\\\\'; done\n in\n loop 0;\n Buffer.contents b\n(*\nQuoting commands for execution by cmd.exe is difficult.\n1- Each argument is first quoted using the \"quote\" function above, to\n protect it against the processing performed by the C runtime system,\n then cmd.exe's special characters are escaped with '^', using\n the \"quote_cmd\" function below. For more details, see\n https://blogs.msdn.microsoft.com/twistylittlepassagesallalike/2011/04/23\n2- The command and the redirection files, if any, must be double-quoted\n in case they contain spaces. This quoting is interpreted by cmd.exe,\n not by the C runtime system, hence the \"quote\" function above\n cannot be used. The two characters we don't know how to quote\n inside a double-quoted cmd.exe string are double-quote and percent.\n We just fail if the command name or the redirection file names\n contain a double quote (not allowed in Windows file names, anyway)\n or a percent. See function \"quote_cmd_filename\" below.\n3- The whole string passed to Sys.command is then enclosed in double\n quotes, which are immediately stripped by cmd.exe. Otherwise,\n some of the double quotes from step 2 above can be misparsed.\n See e.g. https://stackoverflow.com/a/9965141\n*)\n let quote_cmd s =\n let b = Buffer.create (String.length s + 20) in\n String.iter\n (fun c ->\n match c with\n | '(' | ')' | '!' | '^' | '%' | '\\\"' | '<' | '>' | '&' | '|' ->\n Buffer.add_char b '^'; Buffer.add_char b c\n | _ ->\n Buffer.add_char b c)\n s;\n Buffer.contents b\n let quote_cmd_filename f =\n if String.contains f '\\\"' || String.contains f '%' then\n failwith (\"Filename.quote_command: bad file name \" ^ f)\n else if String.contains f ' ' then\n \"\\\"\" ^ f ^ \"\\\"\"\n else\n f\n (* Redirections in cmd.exe: see https://ss64.com/nt/syntax-redirection.html\n and https://docs.microsoft.com/en-us/previous-versions/windows/it-pro/windows-xp/bb490982(v=technet.10)\n *)\n let quote_command cmd ?stdin ?stdout ?stderr args =\n String.concat \"\" [\n \"\\\"\";\n quote_cmd_filename cmd;\n \" \";\n quote_cmd (String.concat \" \" (List.map quote args));\n (match stdin with None -> \"\" | Some f -> \" <\" ^ quote_cmd_filename f);\n (match stdout with None -> \"\" | Some f -> \" >\" ^ quote_cmd_filename f);\n (match stderr with None -> \"\" | Some f ->\n if stderr = stdout\n then \" 2>&1\"\n else \" 2>\" ^ quote_cmd_filename f);\n \"\\\"\"\n ]\n let has_drive s =\n let is_letter = function\n | 'A' .. 'Z' | 'a' .. 'z' -> true\n | _ -> false\n in\n String.length s >= 2 && is_letter s.[0] && s.[1] = ':'\n let drive_and_path s =\n if has_drive s\n then (String.sub s 0 2, String.sub s 2 (String.length s - 2))\n else (\"\", s)\n let dirname s =\n let (drive, path) = drive_and_path s in\n let dir = generic_dirname is_dir_sep current_dir_name path in\n drive ^ dir\n let basename s =\n let (_drive, path) = drive_and_path s in\n generic_basename is_dir_sep current_dir_name path\nend\n\nmodule Cygwin : SYSDEPS = struct\n let null = \"/dev/null\"\n let current_dir_name = \".\"\n let parent_dir_name = \"..\"\n let dir_sep = \"/\"\n let is_dir_sep = Win32.is_dir_sep\n let is_relative = Win32.is_relative\n let is_implicit = Win32.is_implicit\n let check_suffix = Win32.check_suffix\n let chop_suffix_opt = Win32.chop_suffix_opt\n let temp_dir_name = Unix.temp_dir_name\n let quote = Unix.quote\n let quote_command = Unix.quote_command\n let basename = generic_basename is_dir_sep current_dir_name\n let dirname = generic_dirname is_dir_sep current_dir_name\nend\n\nmodule Sysdeps =\n (val (match Sys.os_type with\n | \"Win32\" -> (module Win32: SYSDEPS)\n | \"Cygwin\" -> (module Cygwin: SYSDEPS)\n | _ -> (module Unix: SYSDEPS)))\n\ninclude Sysdeps\n\nlet concat dirname filename =\n let l = String.length dirname in\n if l = 0 || is_dir_sep dirname (l-1)\n then dirname ^ filename\n else dirname ^ dir_sep ^ filename\n\nlet chop_suffix name suff =\n if check_suffix name suff\n then String.sub name 0 (String.length name - String.length suff)\n else invalid_arg \"Filename.chop_suffix\"\n\nlet extension_len name =\n let rec check i0 i =\n if i < 0 || is_dir_sep name i then 0\n else if name.[i] = '.' then check i0 (i - 1)\n else String.length name - i0\n in\n let rec search_dot i =\n if i < 0 || is_dir_sep name i then 0\n else if name.[i] = '.' then check i (i - 1)\n else search_dot (i - 1)\n in\n search_dot (String.length name - 1)\n\nlet extension name =\n let l = extension_len name in\n if l = 0 then \"\" else String.sub name (String.length name - l) l\n\nlet chop_extension name =\n let l = extension_len name in\n if l = 0 then invalid_arg \"Filename.chop_extension\"\n else String.sub name 0 (String.length name - l)\n\nlet remove_extension name =\n let l = extension_len name in\n if l = 0 then name else String.sub name 0 (String.length name - l)\n\nexternal open_desc: string -> open_flag list -> int -> int = \"caml_sys_open\"\nexternal close_desc: int -> unit = \"caml_sys_close\"\n\nlet prng = lazy(Random.State.make_self_init ())\n\nlet temp_file_name temp_dir prefix suffix =\n let rnd = (Random.State.bits (Lazy.force prng)) land 0xFFFFFF in\n concat temp_dir (Printf.sprintf \"%s%06x%s\" prefix rnd suffix)\n\n\nlet current_temp_dir_name = ref temp_dir_name\n\nlet set_temp_dir_name s = current_temp_dir_name := s\nlet get_temp_dir_name () = !current_temp_dir_name\n\nlet temp_file ?(temp_dir = !current_temp_dir_name) prefix suffix =\n let rec try_name counter =\n let name = temp_file_name temp_dir prefix suffix in\n try\n close_desc(open_desc name [Open_wronly; Open_creat; Open_excl] 0o600);\n name\n with Sys_error _ as e ->\n if counter >= 1000 then raise e else try_name (counter + 1)\n in try_name 0\n\nlet open_temp_file ?(mode = [Open_text]) ?(perms = 0o600)\n ?(temp_dir = !current_temp_dir_name) prefix suffix =\n let rec try_name counter =\n let name = temp_file_name temp_dir prefix suffix in\n try\n (name,\n open_out_gen (Open_wronly::Open_creat::Open_excl::mode) perms name)\n with Sys_error _ as e ->\n if counter >= 1000 then raise e else try_name (counter + 1)\n in try_name 0\n","open! Import\n\ntype t = exn [@@deriving_inline sexp_of]\n\nlet sexp_of_t = (sexp_of_exn : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n[@@@end]\n\nlet exit = Caml.exit\n\nexception Finally of t * t [@@deriving_inline sexp]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add [%extension_constructor Finally] (function\n | Finally (v0, v1) ->\n let v0 = sexp_of_t v0\n and v1 = sexp_of_t v1 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"exn.ml.Finally\"; v0; v1 ]\n | _ -> assert false)\n;;\n\n[@@@end]\n\nexception Reraised of string * t [@@deriving_inline sexp]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add [%extension_constructor Reraised] (function\n | Reraised (v0, v1) ->\n let v0 = sexp_of_string v0\n and v1 = sexp_of_t v1 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"exn.ml.Reraised\"; v0; v1 ]\n | _ -> assert false)\n;;\n\n[@@@end]\n\nexception Sexp of Sexp.t\n\n(* We install a custom exn-converter rather than use:\n\n {[\n exception Sexp of Sexp.t [@@deriving_inline sexp]\n (* ... *)\n [@@@end]\n ]}\n\n to eliminate the extra wrapping of [(Sexp ...)]. *)\nlet () =\n Sexplib.Conv.Exn_converter.add [%extension_constructor Sexp] (function\n | Sexp t -> t\n | _ ->\n (* Reaching this branch indicates a bug in sexplib. *)\n assert false)\n;;\n\nlet create_s sexp = Sexp sexp\nlet reraise exc str = raise (Reraised (str, exc))\nlet reraisef exc format = Printf.ksprintf (fun str () -> reraise exc str) format\nlet to_string exc = Sexp.to_string_hum ~indent:2 (sexp_of_exn exc)\nlet to_string_mach exc = Sexp.to_string_mach (sexp_of_exn exc)\nlet sexp_of_t = sexp_of_exn\n\nlet protectx ~f x ~(finally : _ -> unit) =\n match f x with\n | res ->\n finally x;\n res\n | exception exn ->\n raise\n (match finally x with\n | () -> exn\n | exception final_exn -> Finally (exn, final_exn))\n;;\n\nlet protect ~f ~finally = protectx ~f () ~finally\n\nlet does_raise (type a) (f : unit -> a) =\n try\n ignore (f () : a);\n false\n with\n | _ -> true\n;;\n\ninclude Pretty_printer.Register_pp (struct\n type t = exn\n\n let pp ppf t =\n match sexp_of_exn_opt t with\n | Some sexp -> Sexp.pp_hum ppf sexp\n | None -> Caml.Format.pp_print_string ppf (Caml.Printexc.to_string t)\n ;;\n\n let module_name = \"Base.Exn\"\n end)\n\nlet print_with_backtrace exc raw_backtrace =\n Caml.Format.eprintf \"@[<2>Uncaught exception:@\\n@\\n@[%a@]@]@\\n@.\" pp exc;\n if Caml.Printexc.backtrace_status ()\n then Caml.Printexc.print_raw_backtrace Caml.stderr raw_backtrace;\n Caml.flush Caml.stderr\n;;\n\nlet set_uncaught_exception_handler () =\n Caml.Printexc.set_uncaught_exception_handler print_with_backtrace\n;;\n\nlet handle_uncaught_aux ~do_at_exit ~exit f =\n try f () with\n | exc ->\n let raw_backtrace = Caml.Printexc.get_raw_backtrace () in\n (* One reason to run [do_at_exit] handlers before printing out the error message is\n that it helps curses applications bring the terminal in a good state, otherwise the\n error message might get corrupted. Also, the OCaml top-level uncaught exception\n handler does the same. *)\n if do_at_exit\n then (\n try Caml.do_at_exit () with\n | _ -> ());\n (try print_with_backtrace exc raw_backtrace with\n | _ ->\n (try\n Caml.Printf.eprintf \"Exn.handle_uncaught could not print; exiting anyway\\n%!\"\n with\n | _ -> ()));\n exit 1\n;;\n\nlet handle_uncaught_and_exit f = handle_uncaught_aux f ~exit ~do_at_exit:true\n\nlet handle_uncaught ~exit:must_exit f =\n handle_uncaught_aux f ~exit:(if must_exit then exit else ignore) ~do_at_exit:must_exit\n;;\n\nlet reraise_uncaught str func =\n try func () with\n | exn -> raise (Reraised (str, exn))\n;;\n\nexternal clear_backtrace : unit -> unit = \"Base_clear_caml_backtrace_pos\" [@@noalloc]\n\nlet raise_without_backtrace e =\n (* We clear the backtrace to reduce confusion, so that people don't think whatever\n is stored corresponds to this raise. *)\n clear_backtrace ();\n Caml.raise_notrace e\n;;\n\nlet initialize_module () = set_uncaught_exception_handler ()\n\nmodule Private = struct\n let clear_backtrace = clear_backtrace\nend\n","(* This is broken off to avoid circular dependency between Sign and Comparable. *)\n\nopen! Import\n\ntype t =\n | Neg\n | Zero\n | Pos\n[@@deriving_inline sexp, compare, hash, enumerate]\n\nlet t_of_sexp =\n (let _tp_loc = \"sign0.ml.t\" in\n function\n | Ppx_sexp_conv_lib.Sexp.Atom (\"neg\" | \"Neg\") -> Neg\n | Ppx_sexp_conv_lib.Sexp.Atom (\"zero\" | \"Zero\") -> Zero\n | Ppx_sexp_conv_lib.Sexp.Atom (\"pos\" | \"Pos\") -> Pos\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"neg\" | \"Neg\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"zero\" | \"Zero\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"pos\" | \"Pos\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> t)\n;;\n\nlet sexp_of_t =\n (function\n | Neg -> Ppx_sexp_conv_lib.Sexp.Atom \"Neg\"\n | Zero -> Ppx_sexp_conv_lib.Sexp.Atom \"Zero\"\n | Pos -> Ppx_sexp_conv_lib.Sexp.Atom \"Pos\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\nlet compare = (Ppx_compare_lib.polymorphic_compare : t -> t -> int)\n\nlet (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n (fun hsv arg ->\n match arg with\n | Neg -> Ppx_hash_lib.Std.Hash.fold_int hsv 0\n | Zero -> Ppx_hash_lib.Std.Hash.fold_int hsv 1\n | Pos -> Ppx_hash_lib.Std.Hash.fold_int hsv 2\n : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state)\n;;\n\nlet (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func arg =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (let hsv = Ppx_hash_lib.Std.Hash.create () in\n hash_fold_t hsv arg)\n in\n fun x -> func x\n;;\n\nlet all = ([ Neg; Zero; Pos ] : t list)\n\n[@@@end]\n\nmodule Replace_polymorphic_compare = struct\n let ( < ) (x : t) y = Poly.( < ) x y\n let ( <= ) (x : t) y = Poly.( <= ) x y\n let ( <> ) (x : t) y = Poly.( <> ) x y\n let ( = ) (x : t) y = Poly.( = ) x y\n let ( > ) (x : t) y = Poly.( > ) x y\n let ( >= ) (x : t) y = Poly.( >= ) x y\n let ascending (x : t) y = Poly.ascending x y\n let descending (x : t) y = Poly.descending x y\n let compare (x : t) y = Poly.compare x y\n let equal (x : t) y = Poly.equal x y\n let max (x : t) y = if x >= y then x else y\n let min (x : t) y = if x <= y then x else y\nend\n\nlet of_string s = t_of_sexp (sexp_of_string s)\nlet to_string t = string_of_sexp (sexp_of_t t)\n\nlet to_int = function\n | Neg -> -1\n | Zero -> 0\n | Pos -> 1\n;;\n\nlet _ = hash\n\n(* Ignore the hash function produced by [@@deriving_inline hash] *)\nlet hash = to_int\nlet module_name = \"Base.Sign\"\nlet of_int n = if n < 0 then Neg else if n = 0 then Zero else Pos\n","# 1 \"src/hex_lexer.mll\"\n \ntype result =\n| Neg of string\n| Pos of string\n\n# 8 \"src/hex_lexer.ml\"\nlet __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\000\\000\\001\\000\\001\\000\\002\\000\\027\\000\\082\\000\\105\\000\\\n \";\n Lexing.lex_backtrk =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\001\\000\\\n \";\n Lexing.lex_default =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\002\\000\\000\\000\\000\\000\\\n \\001\\000\\003\\000\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\005\\000\\005\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\000\\000\\000\\000\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\000\\000\\000\\000\\000\\000\\\n \\006\\000\\004\\000\\000\\000\\000\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\000\\000\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\006\\000\\004\\000\\005\\000\\000\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\007\\000\\007\\000\\007\\000\\007\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\007\\000\\007\\000\\007\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\000\\000\\000\\000\\000\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\007\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\007\\000\\000\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\000\\000\\002\\000\\004\\000\\004\\000\\004\\000\\004\\000\\004\\000\\004\\000\\\n \\004\\000\\004\\000\\004\\000\\004\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\004\\000\\004\\000\\004\\000\\004\\000\\004\\000\\\n \\004\\000\\255\\255\\255\\255\\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\005\\000\\005\\000\\005\\000\\255\\255\\255\\255\\255\\255\\\n \\001\\000\\003\\000\\255\\255\\255\\255\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\255\\255\\004\\000\\004\\000\\004\\000\\004\\000\\004\\000\\\n \\004\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\001\\000\\003\\000\\005\\000\\255\\255\\005\\000\\005\\000\\005\\000\\005\\000\\\n \\005\\000\\005\\000\\006\\000\\006\\000\\006\\000\\006\\000\\006\\000\\006\\000\\\n \\006\\000\\006\\000\\006\\000\\006\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\006\\000\\006\\000\\006\\000\\006\\000\\006\\000\\\n \\006\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\007\\000\\007\\000\\007\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\255\\255\\255\\255\\255\\255\\006\\000\\006\\000\\006\\000\\006\\000\\006\\000\\\n \\006\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\007\\000\\255\\255\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\007\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec parse_hex lexbuf =\n __ocaml_lex_parse_hex_rec lexbuf 0\nand __ocaml_lex_parse_hex_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n# 8 \"src/hex_lexer.mll\"\n body\n# 135 \"src/hex_lexer.ml\"\n= Lexing.sub_lexeme lexbuf (lexbuf.Lexing.lex_start_pos + 3) lexbuf.Lexing.lex_curr_pos in\n# 14 \"src/hex_lexer.mll\"\n ( Neg body )\n# 139 \"src/hex_lexer.ml\"\n\n | 1 ->\nlet\n# 8 \"src/hex_lexer.mll\"\n body\n# 145 \"src/hex_lexer.ml\"\n= Lexing.sub_lexeme lexbuf (lexbuf.Lexing.lex_start_pos + 2) lexbuf.Lexing.lex_curr_pos in\n# 15 \"src/hex_lexer.mll\"\n ( Pos body )\n# 149 \"src/hex_lexer.ml\"\n\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_parse_hex_rec lexbuf __ocaml_lex_state\n\n;;\n\n","open! Import\n\n(* C stub for int popcount to use the POPCNT instruction where possible *)\nexternal int_popcount : int -> int = \"Base_int_math_int_popcount\" [@@noalloc]\n\n(* To maintain javascript compatibility and enable unboxing, we implement popcount in\n OCaml rather than use C stubs. Implementation adapted from:\n https://en.wikipedia.org/wiki/Hamming_weight#Efficient_implementation *)\nlet int64_popcount =\n let open Caml.Int64 in\n let ( + ) = add in\n let ( - ) = sub in\n let ( * ) = mul in\n let ( lsr ) = shift_right_logical in\n let ( land ) = logand in\n let m1 = 0x5555555555555555L in\n (* 0b01010101... *)\n let m2 = 0x3333333333333333L in\n (* 0b00110011... *)\n let m4 = 0x0f0f0f0f0f0f0f0fL in\n (* 0b00001111... *)\n let h01 = 0x0101010101010101L in\n (* 1 bit set per byte *)\n fun [@inline] x ->\n (* gather the bit count for every pair of bits *)\n let x = x - ((x lsr 1) land m1) in\n (* gather the bit count for every 4 bits *)\n let x = (x land m2) + ((x lsr 2) land m2) in\n (* gather the bit count for every byte *)\n let x = (x + (x lsr 4)) land m4 in\n (* sum the bit counts in the top byte and shift it down *)\n to_int ((x * h01) lsr 56)\n;;\n\nlet int32_popcount =\n (* On 64-bit systems, this is faster than implementing using [int32] arithmetic. *)\n let mask = 0xffff_ffffL in\n fun [@inline] x -> int64_popcount (Caml.Int64.logand (Caml.Int64.of_int32 x) mask)\n;;\n\nlet nativeint_popcount =\n match Caml.Nativeint.size with\n | 32 -> fun [@inline] x -> int32_popcount (Caml.Nativeint.to_int32 x)\n | 64 -> fun [@inline] x -> int64_popcount (Caml.Int64.of_nativeint x)\n | _ -> assert false\n;;\n","(* A 63bit integer is a 64bit integer with its bits shifted to the left\n and its lowest bit set to 0.\n This is the same kind of encoding as OCaml int on 64bit architecture.\n The only difference being the lowest bit (immediate bit) set to 1. *)\n\nopen! Import\ninclude Int64_replace_polymorphic_compare\n\n\nmodule T0 = struct\n module T = struct\n type t = int64 [@@deriving_inline compare, hash, sexp, sexp_grammar]\n\n let compare = (compare_int64 : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int64\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int64 in\n fun x -> func x\n ;;\n\n let t_of_sexp = (int64_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_int64 : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group)\n =\n { implicit_vars = [ \"int64\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ int64_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"int63_emul.ml.T0.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n end\n\n include T\n include Comparator.Make (T)\nend\n\nmodule Conv = Int_conversions\n\nmodule W : sig\n\n type t = int64\n\n include module type of struct\n include T0\n end\n with type t := t\n\n val wrap_exn : Caml.Int64.t -> t\n val wrap_modulo : Caml.Int64.t -> t\n val unwrap : t -> Caml.Int64.t\n\n (** Returns a non-negative int64 that is equal to the input int63 modulo 2^63. *)\n val unwrap_unsigned : t -> Caml.Int64.t\n\n val invariant : t -> unit\n val add : t -> t -> t\n val sub : t -> t -> t\n val neg : t -> t\n val abs : t -> t\n val succ : t -> t\n val pred : t -> t\n val mul : t -> t -> t\n val pow : t -> t -> t\n val div : t -> t -> t\n val rem : t -> t -> t\n val popcount : t -> int\n val bit_not : t -> t\n val bit_xor : t -> t -> t\n val bit_or : t -> t -> t\n val bit_and : t -> t -> t\n val shift_left : t -> int -> t\n val shift_right : t -> int -> t\n val shift_right_logical : t -> int -> t\n val min_value : t\n val max_value : t\n val to_int64 : t -> Caml.Int64.t\n val of_int64 : Caml.Int64.t -> t option\n val of_int64_exn : Caml.Int64.t -> t\n val of_int64_trunc : Caml.Int64.t -> t\n val compare : t -> t -> int\n val ceil_pow2 : t -> t\n val floor_pow2 : t -> t\n val ceil_log2 : t -> int\n val floor_log2 : t -> int\n val is_pow2 : t -> bool\n val clz : t -> int\n val ctz : t -> int\nend = struct\n type t = int64\n\n include (\n T0 :\n module type of struct\n include T0\n end\n with type t := t)\n\n let wrap_exn x =\n (* Raises if the int64 value does not fit on int63. *)\n Conv.int64_fit_on_int63_exn x;\n Caml.Int64.mul x 2L\n ;;\n\n let wrap x =\n if Conv.int64_is_representable_as_int63 x then Some (Caml.Int64.mul x 2L) else None\n ;;\n\n let wrap_modulo x = Caml.Int64.mul x 2L\n let unwrap x = Caml.Int64.shift_right x 1\n let unwrap_unsigned x = Caml.Int64.shift_right_logical x 1\n\n (* This does not use wrap or unwrap to avoid generating exceptions in the case of\n overflows. This is to preserve the semantics of int type on 64 bit architecture. *)\n let f2 f a b =\n Caml.Int64.mul (f (Caml.Int64.shift_right a 1) (Caml.Int64.shift_right b 1)) 2L\n ;;\n\n let mask = 0xffff_ffff_ffff_fffeL\n let m x = Caml.Int64.logand x mask\n let invariant t = assert (m t = t)\n let add x y = Caml.Int64.add x y\n let sub x y = Caml.Int64.sub x y\n let neg x = Caml.Int64.neg x\n let abs x = Caml.Int64.abs x\n let one = wrap_exn 1L\n let succ a = add a one\n let pred a = sub a one\n let min_value = m Caml.Int64.min_int\n let max_value = m Caml.Int64.max_int\n let bit_not x = m (Caml.Int64.lognot x)\n let bit_and = Caml.Int64.logand\n let bit_xor = Caml.Int64.logxor\n let bit_or = Caml.Int64.logor\n let shift_left x i = Caml.Int64.shift_left x i\n let shift_right x i = m (Caml.Int64.shift_right x i)\n let shift_right_logical x i = m (Caml.Int64.shift_right_logical x i)\n let pow = f2 Int_math.Private.int63_pow_on_int64\n let mul a b = Caml.Int64.mul a (Caml.Int64.shift_right b 1)\n let div a b = wrap_modulo (Caml.Int64.div a b)\n let rem a b = Caml.Int64.rem a b\n let popcount x = Popcount.int64_popcount x\n let to_int64 t = unwrap t\n let of_int64 t = wrap t\n let of_int64_exn t = wrap_exn t\n let of_int64_trunc t = wrap_modulo t\n let t_of_sexp x = wrap_exn (int64_of_sexp x)\n let sexp_of_t x = sexp_of_int64 (unwrap x)\n let compare (x : t) y = compare x y\n let is_pow2 x = Int64.is_pow2 (unwrap x)\n\n let clz x =\n (* We run Int64.clz directly on the wrapped int63 value. This is correct because the\n bits of the int63_emul are left-aligned in the Int64. *)\n Int64.clz x\n ;;\n\n let ctz x = Int64.ctz (unwrap x)\n let floor_pow2 x = Int64.floor_pow2 (unwrap x) |> wrap_exn\n let ceil_pow2 x = Int64.floor_pow2 (unwrap x) |> wrap_exn\n let floor_log2 x = Int64.floor_log2 (unwrap x)\n let ceil_log2 x = Int64.ceil_log2 (unwrap x)\nend\n\nopen W\n\nmodule T = struct\n type t = W.t [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n W.hash_fold_t\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = W.hash in\n fun x -> func x\n ;;\n\n let t_of_sexp = (W.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (W.sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"W.t\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ W.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"int63_emul.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n type comparator_witness = W.comparator_witness\n\n let comparator = W.comparator\n let compare = W.compare\n let invariant = W.invariant\n\n (* We don't expect [hash] to follow the behavior of int in 64bit architecture *)\n let _ = hash\n let hash (x : t) = Caml.Hashtbl.hash x\n let invalid_str x = Printf.failwithf \"Int63.of_string: invalid input %S\" x ()\n\n (*\n \"sign\" refers to whether the number starts with a '-'\n \"signedness = false\" means the rest of the number is parsed as unsigned and then cast\n to signed with wrap-around modulo 2^i\n \"signedness = true\" means no such craziness happens\n\n The terminology and the logic is due to the code in byterun/ints.c in ocaml 4.03\n ([parse_sign_and_base] function).\n\n Signedness equals true for plain decimal number (e.g. 1235, -6789)\n\n Signedness equals false in the following cases:\n - [0xffff], [-0xffff] (hexadecimal representation)\n - [0b0101], [-0b0101] (binary representation)\n - [0o1237], [-0o1237] (octal representation)\n - [0u9812], [-0u9812] (unsigned decimal representation - available from OCaml 4.03) *)\n let sign_and_signedness x =\n let len = String.length x in\n let open Int_replace_polymorphic_compare in\n let pos, sign =\n if 0 < len\n then (\n match x.[0] with\n | '-' -> 1, `Neg\n | '+' -> 1, `Pos\n | _ -> 0, `Pos)\n else 0, `Pos\n in\n if pos + 2 < len\n then (\n let c1 = x.[pos] in\n let c2 = x.[pos + 1] in\n match c1, c2 with\n | '0', '0' .. '9' -> sign, true\n | '0', _ -> sign, false\n | _ -> sign, true)\n else sign, true\n ;;\n\n let to_string x = Caml.Int64.to_string (unwrap x)\n\n let of_string str =\n try\n let sign, signedness = sign_and_signedness str in\n if signedness\n then of_int64_exn (Caml.Int64.of_string str)\n else (\n let pos_str =\n match sign with\n | `Neg -> String.sub str ~pos:1 ~len:(String.length str - 1)\n | `Pos -> str\n in\n let int64 = Caml.Int64.of_string pos_str in\n (* unsigned 63-bit int must parse as a positive signed 64-bit int *)\n if Int64_replace_polymorphic_compare.( < ) int64 0L then invalid_str str;\n let int63 = wrap_modulo int64 in\n match sign with\n | `Neg -> neg int63\n | `Pos -> int63)\n with\n | _ -> invalid_str str\n ;;\n\n let bswap16 t = wrap_modulo (Int64.bswap16 (unwrap t))\n let bswap32 t = wrap_modulo (Int64.bswap32 (unwrap t))\n let bswap48 t = wrap_modulo (Int64.bswap48 (unwrap t))\nend\n\ninclude T\n\nlet num_bits = 63\nlet float_lower_bound = Float0.lower_bound_for_int num_bits\nlet float_upper_bound = Float0.upper_bound_for_int num_bits\nlet shift_right_logical = shift_right_logical\nlet shift_right = shift_right\nlet shift_left = shift_left\nlet bit_not = bit_not\nlet bit_xor = bit_xor\nlet bit_or = bit_or\nlet bit_and = bit_and\nlet popcount = popcount\nlet abs = abs\nlet pred = pred\nlet succ = succ\nlet pow = pow\nlet rem = rem\nlet neg = neg\nlet max_value = max_value\nlet min_value = min_value\nlet minus_one = wrap_exn Caml.Int64.minus_one\nlet one = wrap_exn Caml.Int64.one\nlet zero = wrap_exn Caml.Int64.zero\nlet is_pow2 = is_pow2\nlet floor_pow2 = floor_pow2\nlet ceil_pow2 = ceil_pow2\nlet floor_log2 = floor_log2\nlet ceil_log2 = ceil_log2\nlet clz = clz\nlet ctz = ctz\nlet to_float x = Caml.Int64.to_float (unwrap x)\nlet of_float_unchecked x = wrap_modulo (Caml.Int64.of_float x)\n\nlet of_float t =\n let open Float_replace_polymorphic_compare in\n if t >= float_lower_bound && t <= float_upper_bound\n then wrap_modulo (Caml.Int64.of_float t)\n else\n Printf.invalid_argf\n \"Int63.of_float: argument (%f) is out of range or NaN\"\n (Float0.box t)\n ()\n;;\n\nlet of_int64 = of_int64\nlet of_int64_exn = of_int64_exn\nlet of_int64_trunc = of_int64_trunc\nlet to_int64 = to_int64\n\ninclude Comparable.Validate_with_zero (struct\n include T\n\n let zero = zero\n end)\n\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet ( / ) = div\nlet ( * ) = mul\nlet ( - ) = sub\nlet ( + ) = add\nlet ( ~- ) = neg\nlet ( ** ) b e = pow b e\nlet incr r = r := !r + one\nlet decr r = r := !r - one\n\n(* We can reuse conversion function from/to int64 here. *)\nlet of_int x = wrap_exn (Conv.int_to_int64 x)\nlet of_int_exn x = of_int x\nlet to_int x = Conv.int64_to_int (unwrap x)\nlet to_int_exn x = Conv.int64_to_int_exn (unwrap x)\nlet to_int_trunc x = Conv.int64_to_int_trunc (unwrap x)\nlet of_int32 x = wrap_exn (Conv.int32_to_int64 x)\nlet of_int32_exn x = of_int32 x\nlet to_int32 x = Conv.int64_to_int32 (unwrap x)\nlet to_int32_exn x = Conv.int64_to_int32_exn (unwrap x)\nlet to_int32_trunc x = Conv.int64_to_int32_trunc (unwrap x)\nlet of_nativeint x = of_int64 (Conv.nativeint_to_int64 x)\nlet of_nativeint_exn x = wrap_exn (Conv.nativeint_to_int64 x)\nlet of_nativeint_trunc x = of_int64_trunc (Conv.nativeint_to_int64 x)\nlet to_nativeint x = Conv.int64_to_nativeint (unwrap x)\nlet to_nativeint_exn x = Conv.int64_to_nativeint_exn (unwrap x)\nlet to_nativeint_trunc x = Conv.int64_to_nativeint_trunc (unwrap x)\n\ninclude Conv.Make (T)\n\ninclude Conv.Make_hex (struct\n type t = T.t [@@deriving_inline compare, hash]\n\n let compare = (T.compare : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n T.hash_fold_t\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = T.hash in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let zero = zero\n let neg = ( ~- )\n let ( < ) = ( < )\n\n let to_string i =\n (* the use of [unwrap_unsigned] here is important for the case of [min_value] *)\n Printf.sprintf \"%Lx\" (unwrap_unsigned i)\n ;;\n\n let of_string s = of_string (\"0x\" ^ s)\n let module_name = \"Base.Int63.Hex\"\n end)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string x = to_string x\n let module_name = \"Base.Int63\"\n end)\n\nmodule Pre_O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Int64_replace_polymorphic_compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int_exn = of_int_exn\nend\n\nmodule O = struct\n include Pre_O\n\n include Int_math.Make (struct\n type nonrec t = t\n\n include Pre_O\n\n let rem = rem\n let to_float = to_float\n let of_float = of_float\n let of_string = T.of_string\n let to_string = T.to_string\n end)\n\n let ( land ) = bit_and\n let ( lor ) = bit_or\n let ( lxor ) = bit_xor\n let lnot = bit_not\n let ( lsl ) = shift_left\n let ( asr ) = shift_right\n let ( lsr ) = shift_right_logical\nend\n\ninclude O\n\n(* [Int63] and [Int63.O] agree value-wise *)\n\nmodule Repr = struct\n type emulated = t\n\n type ('underlying_type, 'intermediate_type) t =\n | Int : (int, int) t\n | Int64 : (int64, emulated) t\nend\n\nlet repr = Repr.Int64\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Int64_replace_polymorphic_compare\n","open! Import\nmodule Sys = Sys0\n\ntype t = Caml.Printexc.raw_backtrace\n\nlet elide = ref am_testing\nlet elided_message = \"\"\n\nlet get ?(at_most_num_frames = Int.max_value) () =\n Caml.Printexc.get_callstack at_most_num_frames\n;;\n\nlet to_string t =\n if !elide then elided_message else Caml.Printexc.raw_backtrace_to_string t\n;;\n\nlet to_string_list t = String.split_lines (to_string t)\nlet sexp_of_t t = Sexp.List (List.map (to_string_list t) ~f:(fun x -> Sexp.Atom x))\n\nmodule Exn = struct\n let set_recording = Caml.Printexc.record_backtrace\n let am_recording = Caml.Printexc.backtrace_status\n let most_recent () = Caml.Printexc.get_raw_backtrace ()\n\n (* We turn on backtraces by default if OCAMLRUNPARAM doesn't explicitly mention them. *)\n let maybe_set_recording () =\n let ocamlrunparam_mentions_backtraces =\n match Sys.getenv \"OCAMLRUNPARAM\" with\n | None -> false\n | Some x -> List.exists (String.split x ~on:',') ~f:(String.is_prefix ~prefix:\"b\")\n in\n if not ocamlrunparam_mentions_backtraces then set_recording true\n ;;\n\n (* the caller set something, they are responsible *)\n\n let with_recording b ~f =\n let saved = am_recording () in\n set_recording b;\n Exn.protect ~f ~finally:(fun () -> set_recording saved)\n ;;\nend\n\nlet initialize_module () = Exn.maybe_set_recording ()\n","let unique_id =\n let r = ref 0 in\n fun () -> incr r; !r\n\n(* Used to track the current libname in such a way that for functor applications, it is\n the calling libraries name that gets registered. *)\nmodule Current_libname = struct\n let null = \"\"\n let libname_ref = ref null\n\n let set str = libname_ref := str\n let unset () = libname_ref := null\n let get () = !libname_ref\nend\n\nmodule Current_bench_module_stack = struct\n let t = ref []\n\n let push s = t := s :: !t\n\n let pop_exn () = t := List.tl !t\n\n let to_name () =\n match !t with\n | [] -> None\n | ms -> Some (String.concat \".\" (List.rev ms))\nend\n\n(* This is the main data structure of this module. An [Entry.t] represents a benchmark\n along with some metadata about is position, arguments etc. *)\nmodule Entry = struct\n\n type 'a indexed_spec = {\n arg_name : string;\n arg_values : int list;\n thunk : int -> unit -> 'a;\n }\n\n type test_spec =\n | Regular_thunk : ([`init] -> unit -> 'a) -> test_spec\n | Indexed_thunk : 'a indexed_spec -> test_spec\n\n type t = {\n unique_id : int;\n code : string;\n type_conv_path : string;\n name : string;\n filename : string;\n line : int;\n startpos : int;\n endpos : int;\n test_spec : test_spec;\n bench_module_name : string option;\n }\n\n let compare t1 t2 = compare t1.unique_id t2.unique_id\n\n let get_indexed_arg_name t =\n match t.test_spec with\n | Regular_thunk _ -> None\n | Indexed_thunk {arg_name; _} -> Some arg_name\n\n (* Extracts module name from [\"filename.ml.Module\"], which is the format of [ext_name]\n as set by [typeconv]. *)\n let get_module_name_opt t =\n let str = t.type_conv_path in\n let len = String.length str in\n let rec loop i =\n if i + 4 <= len\n then\n if String.sub str i 4 = \".ml.\"\n then Some (String.sub str (i + 4) (len - i - 4))\n else loop (i + 1)\n else None\n in\n loop 0\nend\n\n(* Inspect system environment variables to decide if benchmarks are being run. This is\n called by the code generated by the [pa_bench] syntax to decide if the global hashtable\n should be populated. *)\nlet add_environment_var =\n let v =\n try Sys.getenv \"BENCHMARKS_RUNNER\" with\n | Not_found -> \"\"\n in\n v = \"TRUE\"\n\n(* This hashtable contains all the benchmarks from all the of libraries that have been\n loaded. At the time the benchmarks are registering themselves with [ppx_bench_lib] we\n don't yet know which libraries will need to be run. *)\nlet libs_to_entries : (string, Entry.t list) Hashtbl.t = Hashtbl.create 10\n\nlet lookup_rev_lib ~libname =\n try Hashtbl.find libs_to_entries libname\n with Not_found -> []\n\nlet lookup_lib ~libname =\n List.rev (lookup_rev_lib ~libname)\n\nlet force_drop =\n (* Useful for js_of_ocaml to perform deadcode elimination.\n see ppx/ppx_inline_test/runtime-lib/runtime.ml [Action.get] for more details *)\n try ignore (Sys.getenv \"FORCE_DROP_BENCH\" : string); true\n with Not_found -> false\n\nlet get_mode () =\n if force_drop\n then `Ignore\n else `Collect\n\nlet[@inline never] add_bench\n ~name\n ~code\n ~filename\n ~type_conv_path\n ~line\n ~startpos\n ~endpos\n test_spec\n =\n match get_mode () with\n | `Ignore -> ()\n | `Collect ->\n let libname = Current_libname.get () in\n let entry = { Entry.\n code; unique_id = unique_id ();\n type_conv_path; bench_module_name = Current_bench_module_stack.to_name ();\n name; filename; line; startpos; endpos; test_spec;\n } in\n Hashtbl.add libs_to_entries libname (entry :: lookup_rev_lib ~libname)\n\nlet[@inline never] add_bench_module\n ~name\n ~code:_\n ~type_conv_path:_\n ~filename:_\n ~line:_\n ~startpos:_\n ~endpos:_\n f =\n match get_mode () with\n | `Ignore -> ()\n | `Collect ->\n (* Running f registers the benchmarks using BENCH *)\n Current_bench_module_stack.push name;\n try\n f ();\n Current_bench_module_stack.pop_exn ();\n with ex ->\n Current_bench_module_stack.pop_exn ();\n raise ex\n","open! Base\n\nmodule Location : sig\n include Identifiable.S\nend = struct\n include String\nend\n\nmodule Uuid : sig\n include Identifiable.S\nend = struct\n include String\nend\n\nlet eval_fail loc fmt =\n Printf.ksprintf (fun s -> failwith (Printf.sprintf !\"%{Location}: %s\" loc s)) fmt\n;;\n\nlet equal_option equal a b =\n match a, b with\n | Some _, None | None, Some _ -> false\n | None, None -> true\n | Some x, Some y -> equal x y\n;;\n\nmodule Sorted_table : sig\n type 'a t [@@deriving compare, sexp]\n\n val create : Location.t -> eq:('a -> 'a -> bool) -> (string * 'a) list -> 'a t\n val expose : 'a t -> (string * 'a) list\n val map : 'a t -> f:('a -> 'b) -> 'b t\nend = struct\n type 'a t = { sorted : (string * 'a) list } [@@deriving compare, sexp]\n\n let merge_check_adjacent_dups\n : eq:('a -> 'a -> bool) -> (string * 'a) list\n -> [ `Ok of (string * 'a) list | `Mismatch of string ]\n =\n fun ~eq ->\n let rec loop acc ~last_key ~last_value = function\n | [] -> `Ok (List.rev acc)\n | (key, value) :: xs ->\n if String.(last_key = key)\n then\n if eq last_value value\n then loop acc ~last_key ~last_value xs\n else `Mismatch key\n else loop ((key, value) :: acc) ~last_key:key ~last_value:value xs\n in\n function\n | [] -> `Ok []\n | (key, value) :: xs -> loop [ key, value ] ~last_key:key ~last_value:value xs\n ;;\n\n let create loc ~eq xs =\n let sorted = List.sort ~compare:(fun (s1, _) (s2, _) -> String.compare s1 s2) xs in\n match merge_check_adjacent_dups ~eq sorted with\n | `Ok sorted -> { sorted }\n | `Mismatch s ->\n eval_fail loc \"Different shapes for duplicated polymorphic constructor: `%s\" s ()\n ;;\n\n let expose t = t.sorted\n let map t ~f = { sorted = List.map t.sorted ~f:(fun (k, v) -> k, f v) }\nend\n\nmodule Digest : sig\n type t = Md5_lib.t [@@deriving compare, sexp]\n\n val to_md5 : t -> Md5_lib.t\n val of_md5 : Md5_lib.t -> t\n val to_hex : t -> string\n val constructor : string -> t list -> t\n val list : t list -> t\n val pair : t -> t -> t\n val string : string -> t\n val uuid : Uuid.t -> t\n val int : int -> t\n val option : t option -> t\nend = struct\n include Md5_lib\n\n let to_md5 t = t\n let of_md5 t = t\n let sexp_of_t t = t |> to_hex |> sexp_of_string\n let t_of_sexp s = s |> string_of_sexp |> of_hex_exn\n let uuid u = string (Uuid.to_string u)\n let int x = string (Int.to_string x)\n let pair x y = string (to_binary x ^ to_binary y)\n let list l = string (String.concat ~sep:\"\" (List.map ~f:to_binary l))\n let constructor s l = string (s ^ to_binary (list l))\n\n let option = function\n | None -> constructor \"none\" []\n | Some x -> constructor \"some\" [ x ]\n ;;\nend\n\nmodule Canonical_exp_constructor = struct\n (* ['a t] is a non-recursive type, used to represent 1-layer of expression. The\n recursive knot is tied below in [Canonical_full.Exp.t]. *)\n type 'a t =\n | Annotate of Uuid.t * 'a\n | Base of Uuid.t * 'a list\n | Tuple of 'a list\n | Record of (string * 'a) list\n | Variant of (string * 'a list) list\n (* Polymorphic variants are insensitive to the order the constructors are listed *)\n | Poly_variant of 'a option Sorted_table.t\n (* Left-hand-side of [Application] is a potentially recursive definition: it\n can refer to itself using [Rec_app (i, _)] where [i] is the depth of this\n application node (how many application nodes are above it).\n It also has its own scope of type variables so it can not refer to type variables\n of the enclosing scope.\n *)\n | Application of 'a * 'a list\n | Rec_app of int * 'a list\n | Var of int\n [@@deriving sexp, compare]\n\n let map x ~f =\n match x with\n | Annotate (u, x) -> Annotate (u, f x)\n | Base (s, xs) -> Base (s, List.map ~f xs)\n | Tuple xs -> Tuple (List.map ~f xs)\n | Record l -> Record (List.map l ~f:(fun (s, x) -> s, f x))\n | Variant l -> Variant (List.map l ~f:(fun (s, xs) -> s, List.map ~f xs))\n | Poly_variant t -> Poly_variant (Sorted_table.map t ~f:(Option.map ~f))\n | Application (x, l) -> Application (f x, List.map ~f l)\n | Rec_app (t, l) -> Rec_app (t, List.map ~f l)\n | Var v -> Var v\n ;;\n\n let to_string t = Sexp.to_string (sexp_of_t (fun _ -> Atom \"...\") t)\nend\n\nmodule Create_digest : sig\n (* Digest various expression forms *)\n\n val digest_layer : Digest.t Canonical_exp_constructor.t -> Digest.t\nend = struct\n let digest_layer = function\n | Canonical_exp_constructor.Annotate (u, x) ->\n Digest.constructor \"annotate\" [ Digest.uuid u; x ]\n | Base (u, l) -> Digest.constructor \"base\" [ Digest.uuid u; Digest.list l ]\n | Tuple l -> Digest.constructor \"tuple\" [ Digest.list l ]\n | Record l ->\n Digest.constructor\n \"record\"\n [ Digest.list (List.map l ~f:(fun (s, t) -> Digest.pair (Digest.string s) t)) ]\n | Variant l ->\n Digest.constructor\n \"variant\"\n [ Digest.list\n (List.map l ~f:(fun (s, l) -> Digest.pair (Digest.string s) (Digest.list l)))\n ]\n | Poly_variant table ->\n Digest.constructor\n \"poly_variant\"\n [ Digest.list\n (List.map (Sorted_table.expose table) ~f:(fun (x, y) ->\n Digest.pair (Digest.string x) (Digest.option y)))\n ]\n | Application (x, l) -> Digest.constructor \"application\" [ x; Digest.list l ]\n | Rec_app (n, l) -> Digest.constructor \"rec_app\" [ Digest.int n; Digest.list l ]\n | Var n -> Digest.constructor \"var\" [ Digest.int n ]\n ;;\nend\n\nmodule Visibility = struct\n type visible = Visible\n type opaque = Opaque\n\n let _ = Visible\n let _ = Opaque\nend\n\nmodule type Canonical = sig\n type t\n\n val to_digest : t -> Digest.t\n\n module Exp1 : sig\n type _ t\n\n val var : int -> _ t\n val recurse : int -> _ t list -> _ t\n val apply : 'a t -> 'a t list -> _ t\n val opaque : _ t -> Visibility.opaque t\n\n val get_poly_variant\n : Visibility.visible t\n -> (Visibility.opaque t option Sorted_table.t, string) Result.t\n end\n\n module Def : sig\n type t = Visibility.visible Exp1.t\n end\n\n module Create : sig\n val annotate : Uuid.t -> _ Exp1.t -> _ Exp1.t\n val basetype : Uuid.t -> _ Exp1.t list -> _ Exp1.t\n val tuple : _ Exp1.t list -> _ Exp1.t\n val poly_variant : Location.t -> (string * _ Exp1.t option) list -> _ Exp1.t\n val var : int -> _ Exp1.t\n val recurse : int -> _ Exp1.t list -> _ Exp1.t\n val apply : 'a Exp1.t -> 'a Exp1.t list -> _ Exp1.t\n val define : Visibility.visible Exp1.t -> Def.t\n val record : (string * _ Exp1.t) list -> _ Exp1.t\n val variant : (string * _ Exp1.t list) list -> _ Exp1.t\n val create : _ Exp1.t -> t\n end\nend\n\nmodule Canonical_digest : Canonical = struct\n type t = Canonical of Digest.t\n\n let to_digest (Canonical x) = x\n\n module CD = Create_digest\n\n module Exp1 = struct\n type opaque = Digest.t\n\n type 'a t =\n | Poly_variant of opaque option Sorted_table.t\n | Non_poly_variant of (string * opaque)\n | Opaque : opaque -> Visibility.opaque t\n\n let to_digest (type a) (x : a t) =\n match x with\n | Opaque x -> x\n | Non_poly_variant (_, x) -> x\n | Poly_variant x -> CD.digest_layer (Poly_variant x)\n ;;\n\n let equal (type a) (x : a t) (y : a t) =\n Digest.compare (to_digest x) (to_digest y) = 0\n ;;\n\n let opaque x = Opaque (to_digest x)\n\n let create x =\n let x = Canonical_exp_constructor.map ~f:to_digest x in\n let desc = Canonical_exp_constructor.to_string x in\n match x with\n | Canonical_exp_constructor.Poly_variant l -> Poly_variant l\n | Base _ -> Non_poly_variant (desc, CD.digest_layer x)\n | Annotate _ ->\n (* It's unsafe to use deriving bin_io when inheriting from a polymorphic variant\n that has a custom bin_io. If we forbid that, we can happily reject here\n anything that's annotated. *)\n Non_poly_variant (desc, CD.digest_layer x)\n | Application _ ->\n (* Application can really be a poly-variant you can inherit from! But it's a\n rare situation that mostly (only?) arises with inheritance from recursive\n polymorpic variants, which we've not seen anywhere yet. So we reject it. *)\n Non_poly_variant (desc, CD.digest_layer x)\n | Rec_app _ ->\n (* You can only get the [Rec_app] constructor for type-references within the\n mutual group being defined. References which\n follow after the current group will always be [Application]s.\n\n And since ocaml rejects references in `inheritance' position to types within\n the current group (see example) with:\n\n Error: The type constructor t\n is not yet completely defined\n\n then its ok to say that a rec-app is something that can't be inherited from and\n return [Non_poly_variant].\n\n And unlike the [Application] case, it should never be possible to see\n an error message with the [desc] = [Rec_app].\n\n Example: [type t = [`a of [ | t] ]]\n Here, [| t] would be an example of inheritance from a Rec_app, which\n is rejected by the compiler.\n *)\n Non_poly_variant (desc, CD.digest_layer x)\n | Var _ | Tuple _ | Record _ | Variant _ ->\n Non_poly_variant (desc, CD.digest_layer x)\n ;;\n\n let var x = create (Var x)\n let apply def l = create (Application (def, l))\n let recurse tid l = create (Rec_app (tid, l))\n\n let get_poly_variant (x : Visibility.visible t) =\n match x with\n | Non_poly_variant (desc, _) -> Error desc\n | Poly_variant l -> Ok (Sorted_table.map ~f:(Option.map ~f:(fun x -> Opaque x)) l)\n ;;\n end\n\n module Def = struct\n type t = Visibility.visible Exp1.t\n end\n\n module Create = struct\n let annotate u x = Exp1.create (Annotate (u, x))\n let basetype u l = Exp1.create (Base (u, l))\n let tuple l = Exp1.create (Tuple l)\n\n let poly_variant loc l =\n Exp1.create\n (Poly_variant (Sorted_table.create loc ~eq:(equal_option Exp1.equal) l))\n ;;\n\n let var x = Exp1.create (Var x)\n let apply x l = Exp1.create (Application (x, l))\n let recurse t l = Exp1.create (Rec_app (t, l))\n let define x = x\n let record l = Exp1.create (Record l)\n let variant l = Exp1.create (Variant l)\n let create e = Canonical (Exp1.to_digest e)\n end\nend\n\nmodule Canonical_full : sig\n type t [@@deriving compare, sexp]\n\n include Canonical with type t := t\n\n val to_string_hum : t -> string\nend = struct\n module CD = Create_digest\n\n module Exp1 = struct\n type t0 = Exp of t0 Canonical_exp_constructor.t [@@deriving compare, sexp]\n\n let equal_t0 x y = compare_t0 x y = 0\n\n type 'a t = t0 [@@deriving compare, sexp]\n\n let var x = Exp (Canonical_exp_constructor.Var x)\n let apply d xs = Exp (Canonical_exp_constructor.Application (d, xs))\n let recurse r xs = Exp (Canonical_exp_constructor.Rec_app (r, xs))\n\n let poly_variant loc xs =\n Exp\n (Canonical_exp_constructor.Poly_variant\n (Sorted_table.create loc ~eq:(equal_option equal_t0) xs))\n ;;\n\n let get_poly_variant = function\n | Exp (Poly_variant tab) -> Ok tab\n | Exp cc -> Error (Canonical_exp_constructor.to_string cc)\n ;;\n\n let opaque t = t\n\n let rec to_digest = function\n | Exp e -> CD.digest_layer (Canonical_exp_constructor.map ~f:to_digest e)\n ;;\n end\n\n module Def = struct\n (* A [Def.t] is an expression which may be applied *)\n type t = Exp1.t0 [@@deriving compare, sexp]\n end\n\n (* A canonical shape [t] is an [Exp1.t]. *)\n type t = Exp1.t0 [@@deriving compare, sexp]\n\n let to_digest e = Exp1.to_digest e\n\n module Create = struct\n let annotate u x = Exp1.Exp (Annotate (u, x))\n let basetype u xs = Exp1.Exp (Base (u, xs))\n let tuple xs = Exp1.Exp (Tuple xs)\n let poly_variant loc xs = Exp1.poly_variant loc xs\n let var n = Exp1.Exp (Var n)\n let recurse r xs = Exp1.recurse r xs\n let apply d xs = Exp1.apply d xs\n let define x = x\n let record xs = Exp1.Exp (Record xs)\n let variant xs = Exp1.Exp (Variant xs)\n let create exp = exp\n end\n\n let to_string_hum t = Sexp.to_string_hum (sexp_of_t t)\nend\n\nmodule Tid : sig\n include Identifiable.S\nend = struct\n include String\nend\n\nmodule Vid : sig\n include Identifiable.S\nend = struct\n include String\nend\n\nmodule Gid : sig\n (* unique group-id, used as key for Tenv below *)\n type t [@@deriving compare, sexp_of]\n\n val create : unit -> t\nend = struct\n type t = int [@@deriving compare, sexp_of]\n\n let r = ref 0\n\n let create () =\n let u = !r in\n r := 1 + u;\n u\n ;;\nend\n\nmodule Expression = struct\n type 't poly_constr =\n [ `Constr of string * 't option\n | `Inherit of Location.t * 't\n ]\n [@@deriving compare, sexp_of]\n\n module Group : sig\n type 'a t [@@deriving compare, sexp_of]\n\n val create : Location.t -> (Tid.t * Vid.t list * 'a) list -> 'a t\n val id : 'a t -> Gid.t\n val lookup : 'a t -> Tid.t -> Vid.t list * 'a\n end = struct\n type 'a t =\n { gid : Gid.t\n ; loc : Location.t\n ; members : (Tid.t * (Vid.t list * 'a)) list\n }\n [@@deriving compare, sexp_of]\n\n let create loc trips =\n let gid = Gid.create () in\n let members = List.map trips ~f:(fun (x, vs, t) -> x, (vs, t)) in\n { gid; loc; members }\n ;;\n\n let id g = g.gid\n\n let lookup g tid =\n match List.Assoc.find g.members ~equal:Tid.( = ) tid with\n | Some scheme -> scheme\n | None ->\n eval_fail\n g.loc\n !\"impossible: lookup_group, unbound type-identifier: %{Tid}\"\n tid\n ()\n ;;\n end\n\n type t =\n | Annotate of Uuid.t * t\n | Base of Uuid.t * t list\n | Record of (string * t) list\n | Variant of (string * t list) list\n | Tuple of t list\n | Poly_variant of (Location.t * t poly_constr list)\n | Var of (Location.t * Vid.t)\n | Rec_app of Tid.t * t list\n | Top_app of t Group.t * Tid.t * t list\n [@@deriving variants, sexp_of]\n\n type group = t Group.t\n\n let group = Group.create\n\n type poly_variant_row = t poly_constr\n\n let constr s t = `Constr (s, t)\n let inherit_ loc t = `Inherit (loc, t)\n let var loc t = Var (loc, t)\n let poly_variant loc xs = Poly_variant (loc, xs)\n let basetype = base\n\n (* \"VR\" stands for \"variant or record\" *)\n\n let is_cyclic_0 ~(via_VR : bool) : group -> Tid.t -> bool =\n fun group tid ->\n let set = ref [] in\n let visited tid = List.mem !set tid ~equal:Tid.equal in\n let add tid = set := tid :: !set in\n let rec trav = function\n (* We look for cycles by traversing the structure of type-expressions *)\n | Annotate (_, t) -> trav t\n | Base (_, ts) | Tuple ts | Top_app (_, _, ts) -> List.iter ts ~f:trav\n (* ..including poly-variants *)\n | Poly_variant (_, cs) ->\n List.iter cs ~f:(function\n | `Constr (_, None) -> ()\n | `Constr (_, Some t) -> trav t\n | `Inherit (_loc, t) -> trav t)\n (* .. and records & (normal) variants *)\n | Record xs -> if via_VR then List.iter xs ~f:(fun (_, t) -> trav t) else ()\n | Variant xs ->\n if via_VR then List.iter xs ~f:(fun (_, ts) -> List.iter ~f:trav ts) else ()\n (* We dont follow type-vars *)\n | Var _ -> ()\n (* traverse (recursive) type-apps when first encountered *)\n | Rec_app (tid, ts) ->\n if visited tid\n then ()\n else (\n add tid;\n trav_tid tid);\n List.iter ts ~f:trav\n and trav_tid tid =\n let _, body = Group.lookup group tid in\n trav body\n in\n trav_tid tid;\n let res = visited tid in\n (*let _ss = String.concat ~sep:\",\" (List.map (!set) ~f:(sprintf !\"%{Tid}\")) in*)\n (*Printf.printf !\"is_cylic: %{Tid} --> (%s) %b -- %s%!\" tid _ss res (Group.loc group);*)\n res\n ;;\n\n let is_cyclic = is_cyclic_0 ~via_VR:true\n let is_cyclic_with_no_intervening_VR = is_cyclic_0 ~via_VR:false\nend\n\ninclude Expression\n\nmodule Evaluation (Canonical : Canonical) = struct\n (* [Venv.t]\n Environment for resolving type-vars *)\n module Venv : sig\n type t\n\n val lookup : t -> Vid.t -> Visibility.visible Canonical.Exp1.t option\n val create : (Vid.t * Visibility.visible Canonical.Exp1.t) list -> t\n end = struct\n type t = Visibility.visible Canonical.Exp1.t Map.M(Vid).t\n\n let create =\n List.fold\n ~init:(Map.empty (module Vid))\n ~f:(fun t (k, v) -> Map.set ~key:k ~data:v t)\n ;;\n\n let lookup t k = Map.find t k\n end\n\n module Applicand = struct\n type t =\n | Recursion_level of int\n | Definition of Canonical.Def.t\n end\n\n (* [Tenv.t]\n Environment for resolving type-definitions *)\n module Tenv : sig\n type key = Gid.t * Tid.t\n type t\n\n val find : t -> key -> [ `Recursion_level of int ] option\n val empty : t\n val extend : t -> key -> [ `Recursion_level of int ] -> t\n end = struct\n module Key = struct\n module T = struct\n type t = Gid.t * Tid.t [@@deriving compare, sexp_of]\n end\n\n include T\n include Comparator.Make (T)\n end\n\n type key = Key.t\n type t = [ `Recursion_level of int ] Map.M(Key).t\n\n let find t k = Map.find t k\n let empty = Map.empty (module Key)\n let extend t k v = Map.set ~key:k ~data:v t\n end\n\n (* [Defining.t]\n Monad for managing un-rolling depth, and maintaing a [Tenv.t] *)\n module Defining : sig\n type 'a t\n\n val return : 'a -> 'a t\n val bind : 'a t -> ('a -> 'b t) -> 'b t\n val look_env : Tenv.key -> Applicand.t option t\n val extend_new_tid : Tenv.key -> Canonical.Def.t t -> Applicand.t t\n val exec : 'a t -> 'a\n end = struct\n type 'a t = depth:int -> Tenv.t -> 'a\n\n let return x ~depth:_ _tenv = x\n\n let bind t f ~depth tenv =\n let x = t ~depth tenv in\n (f x) ~depth tenv\n ;;\n\n let look_env key ~depth:_ tenv =\n let result = Tenv.find tenv key in\n Option.map ~f:(fun (`Recursion_level x) -> Applicand.Recursion_level x) result\n ;;\n\n let extend_new_tid key def_t ~depth tenv =\n Applicand.Definition\n (let value = `Recursion_level depth in\n let tenv = Tenv.extend tenv key value in\n def_t ~depth:(depth + 1) tenv)\n ;;\n\n let exec t = t ~depth:0 Tenv.empty\n end\n\n type 'a defining = 'a Defining.t\n\n let ( >>= ) = Defining.bind\n let return = Defining.return\n\n let sequence_defining : 'a list -> f:('a -> 'b defining) -> 'b list defining =\n fun xs ~f ->\n let rec loop acc_ys = function\n | [] -> return (List.rev acc_ys)\n | x :: xs -> f x >>= fun y -> loop (y :: acc_ys) xs\n in\n loop [] xs\n ;;\n\n (*\n Shape evaluation.\n\n Shapes are evaluated to canonical-shape (expressions), with additional defs collected\n in the [defining] monad, which also manages generation/mapping to [Canonical.Tid.t]\n\n There is downwards context of [group] and [Venv.t]\n The (current) [group] changes when the case for [Top_app] calls [eval_app].\n\n The current [Venv.t] is abandoned when [eval_app] is called, and then re-created after\n the decision has been made to either inline the type-application, or make a reference\n to a type-definition, which is created at most once for each (Gid.t * Tid.t).\n\n We make a type-definition always for Records and Variants, and in addition for any\n other cyclic type-definition.\n *)\n\n let rec eval : group -> Venv.t -> t -> Visibility.visible Canonical.Exp1.t defining =\n fun group venv t ->\n match t with\n | Record binds ->\n sequence_defining binds ~f:(fun (s, x) ->\n eval group venv x >>= fun y -> return (s, y))\n >>= fun binds -> return (Canonical.Create.record binds)\n | Variant alts ->\n sequence_defining alts ~f:(fun (s, xs) ->\n eval_list group venv xs >>= fun ys -> return (s, ys))\n >>= fun alts -> return (Canonical.Create.variant alts)\n | Var (loc, vid) ->\n (match Venv.lookup venv vid with\n | Some x -> return x\n | None -> eval_fail loc !\"Free type variable: '%{Vid}\" vid ())\n | Annotate (s, t) ->\n eval group venv t >>= fun v -> return (Canonical.Create.annotate s v)\n | Base (s, ts) ->\n eval_list group venv ts >>= fun vs -> return (Canonical.Create.basetype s vs)\n | Tuple ts ->\n eval_list group venv ts >>= fun vs -> return (Canonical.Create.tuple vs)\n | Top_app (in_group, tid, args) ->\n eval_list group venv args\n >>= fun args ->\n (* args evaluated in current group *)\n eval_app in_group tid args\n (* group changed here *)\n | Rec_app (tid, args) ->\n eval_list group venv args >>= fun args -> eval_app group tid args\n | Poly_variant (loc, cs) ->\n sequence_defining ~f:(eval_poly_constr group venv) cs\n >>= fun xss -> return (Canonical.Create.poly_variant loc (List.concat xss))\n\n and eval_list : group -> Venv.t -> t list -> _ Canonical.Exp1.t list defining =\n fun group venv ts -> sequence_defining ts ~f:(eval group venv)\n\n and eval_poly_constr\n : group -> Venv.t -> t poly_constr\n -> (string * Visibility.opaque Canonical.Exp1.t option) list defining\n =\n fun group venv c ->\n match c with\n | `Constr (s, None) -> return [ s, None ]\n | `Constr (s, Some t) ->\n eval group venv t >>= fun v -> return [ s, Some (Canonical.Exp1.opaque v) ]\n | `Inherit (loc, t) ->\n eval group venv t\n >>= fun v ->\n (match Canonical.Exp1.get_poly_variant v with\n | Ok tab -> return (Sorted_table.expose tab)\n | Error desc ->\n eval_fail\n loc\n \"The shape for an inherited type is not described as a polymorphic-variant: %s\"\n desc\n ())\n\n and eval_definition : group -> Vid.t list -> t -> Canonical.Def.t defining =\n fun group formals body ->\n let venv = Venv.create (List.mapi formals ~f:(fun i x -> x, Canonical.Exp1.var i)) in\n eval group venv body >>= fun v -> return (Canonical.Create.define v)\n\n and eval_app : group -> Tid.t -> _ Canonical.Exp1.t list -> _ Canonical.Exp1.t defining\n =\n fun group tid args ->\n let gid = Group.id group in\n let formals, body = Group.lookup group tid in\n let record_or_normal_variant =\n match body with\n | Record _ | Variant _ -> true\n | Tuple _ | Annotate _ | Base _ | Poly_variant _ | Var _ | Rec_app _ | Top_app _ ->\n false\n in\n let cyclic = is_cyclic group tid in\n let cyclic_no_VR = is_cyclic_with_no_intervening_VR group tid in\n if (record_or_normal_variant && cyclic) || cyclic_no_VR\n then\n Defining.look_env (gid, tid)\n >>= (function\n | Some recurse -> return recurse\n | None ->\n Defining.extend_new_tid (gid, tid) (eval_definition group formals body))\n >>= function\n | Recursion_level r -> return (Canonical.Exp1.recurse r args)\n | Definition def -> return (Canonical.Exp1.apply def args)\n else (\n let venv =\n match List.zip formals args with\n | Ok x -> Venv.create x\n | Unequal_lengths -> failwith \"apply, incorrect type application arity\"\n in\n eval group venv body)\n ;;\n\n (* top level entry point for evaluation *)\n let eval : t -> Canonical.t =\n fun t ->\n let group = group (Location.of_string \"top-level\") [] in\n let venv = Venv.create [] in\n let v = Defining.exec (eval group venv t) in\n Canonical.Create.create v\n ;;\nend\n\nmodule Canonical = struct\n include Canonical_full\n\n module Exp = struct\n type t = Visibility.visible Exp1.t\n end\nend\n\ninclude Evaluation (Canonical_full)\nmodule Canonical_selected = Canonical_digest\nmodule Evaluation_to_digest = Evaluation (Canonical_selected)\n\nlet eval_to_digest exp = Canonical_selected.to_digest (Evaluation_to_digest.eval exp)\nlet eval_to_digest_string exp = Digest.to_hex (eval_to_digest exp)\n\nmodule For_typerep = struct\n exception Not_a_tuple of t [@@deriving sexp_of]\n\n let deconstruct_tuple_exn t =\n match t with\n | Tuple ts -> ts\n | _ -> raise (Not_a_tuple t)\n ;;\nend\n","open! Base\nopen! Import\n\ntype t = Caml.in_channel\n\nlet equal (t1 : t) t2 = phys_equal t1 t2\n\nlet seek = Caml.LargeFile.seek_in\nlet pos = Caml.LargeFile.pos_in\nlet length = Caml.LargeFile.in_channel_length\n\nlet stdin = Caml.stdin\n\nlet create ?(binary = true) file =\n let flags = [Open_rdonly] in\n let flags = if binary then Open_binary :: flags else flags in\n Caml.open_in_gen flags 0o000 file\n;;\n\nlet close = Caml.close_in\n\nlet with_file ?binary file ~f = Exn.protectx (create ?binary file) ~f ~finally:close\n\nlet may_eof f = try Some (f ()) with End_of_file -> None\n\nlet input t ~buf ~pos ~len = Caml.input t buf pos len\nlet really_input t ~buf ~pos ~len =\n may_eof (fun () -> Caml.really_input t buf pos len)\nlet really_input_exn t ~buf ~pos ~len =\n Caml.really_input t buf pos len\nlet input_byte t = may_eof (fun () -> Caml.input_byte t)\nlet input_char t = may_eof (fun () -> Caml.input_char t)\nlet input_binary_int t = may_eof (fun () -> Caml.input_binary_int t)\nlet unsafe_input_value t = may_eof (fun () -> Caml.input_value t)\nlet input_buffer t buf ~len = may_eof (fun () -> Caml.Buffer.add_channel buf t len)\n\nlet set_binary_mode = Caml.set_binary_mode_in\n\nlet input_all t =\n (* We use 65536 because that is the size of OCaml's IO buffers. *)\n let chunk_size = 65536 in\n let buffer = Buffer.create chunk_size in\n let rec loop () =\n Caml.Buffer.add_channel buffer t chunk_size;\n loop ()\n in\n try loop () with\n | End_of_file -> Buffer.contents buffer\n;;\n\nlet trim ~fix_win_eol line =\n if fix_win_eol then begin\n let len = String.length line in\n if len > 0\n && Char.equal (String.get line (len - 1)) '\\r'\n then String.sub line ~pos:0 ~len:(len - 1)\n else line\n end\n else line\n\nlet input_line ?(fix_win_eol = true) t =\n match may_eof (fun () -> Caml.input_line t) with\n | None -> None\n | Some line -> Some (trim ~fix_win_eol line)\n;;\n\nlet input_line_exn ?(fix_win_eol = true) t =\n let line = Caml.input_line t in\n trim ~fix_win_eol line\n\nlet fold_lines ?fix_win_eol t ~init ~f =\n let rec loop ac =\n match input_line ?fix_win_eol t with\n | None -> ac\n | Some line -> loop (f ac line)\n in\n loop init\n;;\n\nlet input_lines ?fix_win_eol t =\n List.rev\n (fold_lines ?fix_win_eol t ~init:[] ~f:(fun lines line -> line :: lines))\n;;\n\nlet iter_lines ?fix_win_eol t ~f =\n fold_lines ?fix_win_eol t ~init:() ~f:(fun () line -> f line)\n;;\n\nlet read_lines ?fix_win_eol fname = with_file fname ~f:(input_lines ?fix_win_eol)\n\nlet read_all fname = with_file fname ~f:input_all\n","open! Base\nopen! Import\n\ntype t = Caml.out_channel\n\nlet equal (t1 : t) t2 = phys_equal t1 t2\n\nlet seek = Caml.LargeFile.seek_out\nlet pos = Caml.LargeFile.pos_out\nlet length = Caml.LargeFile.out_channel_length\n\nlet stdout = Caml.stdout\nlet stderr = Caml.stderr\n\nlet sexp_of_t t =\n if phys_equal t stderr\n then Sexp.Atom \"\"\n else if phys_equal t stdout\n then Sexp.Atom \"\"\n else Sexp.Atom \"\"\n;;\n\ntype 'a with_create_args =\n ?binary:bool\n -> ?append:bool\n -> ?fail_if_exists:bool\n -> ?perm:int\n -> 'a\n\nlet create ?(binary = true) ?(append = false) ?(fail_if_exists = false) ?(perm = 0o666) file =\n let flags = [Open_wronly; Open_creat] in\n let flags = (if binary then Open_binary else Open_text) :: flags in\n let flags = (if append then Open_append else Open_trunc) :: flags in\n let flags = (if fail_if_exists then Open_excl :: flags else flags) in\n Caml.open_out_gen flags perm file\n;;\n\nlet set_binary_mode = Caml.set_binary_mode_out\n\nlet flush = Caml.flush\n\nlet close = Caml.close_out\nlet close_no_err = Caml.close_out_noerr\n\nlet output t ~buf ~pos ~len = Caml.output t buf pos len\nlet output_substring t ~buf ~pos ~len = Caml.output_substring t buf pos len\nlet output_string = Caml.output_string\nlet output_bytes = Caml.output_bytes\nlet output_char = Caml.output_char\nlet output_byte = Caml.output_byte\nlet output_binary_int = Caml.output_binary_int\nlet output_buffer = Caml.Buffer.output_buffer\nlet output_value = Caml.output_value\n\nlet newline t = output_string t \"\\n\"\n\nlet output_lines t lines =\n List.iter lines ~f:(fun line -> output_string t line; newline t)\n;;\n\nlet printf = Caml.Printf.printf\nlet eprintf = Caml.Printf.eprintf\nlet fprintf = Caml.Printf.fprintf\nlet kfprintf = Caml.Printf.kfprintf\n\nlet print_string = Caml.print_string\nlet print_endline = Caml.print_endline\nlet prerr_endline = Caml.prerr_endline\n\nlet print_s ?mach sexp =\n print_endline\n (match mach with\n | Some () -> Sexp.to_string_mach sexp\n | None -> Sexp.to_string_hum sexp)\n;;\n\nlet eprint_s ?mach sexp =\n prerr_endline\n (match mach with\n | Some () -> Sexp.to_string_mach sexp\n | None -> Sexp.to_string_hum sexp)\n;;\n\n\nlet with_file ?binary ?append ?fail_if_exists ?perm file ~f =\n Exn.protectx (create ?binary ?append ?fail_if_exists ?perm file) ~f ~finally:close\n;;\n\nlet write_lines file lines = with_file file ~f:(fun t -> output_lines t lines)\n\nlet write_all file ~data = with_file file ~f:(fun t -> output_string t data)\n","open! Base\nmodule Gc = Caml.Gc\n\nexternal __MODULE__ : string = \"%loc_MODULE\"\n\nlet am_recording_environment_variable = \"PPX_MODULE_TIMER\"\n\nlet get_am_recording_environment_variable () =\n (* avoid Caml.Sys.getenv_opt to preserve 4.04.x compatibility *)\n match Caml.Sys.getenv am_recording_environment_variable with\n | value -> Some value\n | exception _ -> None\n;;\n\nlet am_recording_value = get_am_recording_environment_variable ()\nlet am_recording = Option.is_some am_recording_value\n\nmodule Duration = struct\n type t = Int63.t\n\n let to_nanoseconds t = t\n let of_nanoseconds t = t\n\n module type Format = sig\n val of_string : string -> t\n val to_string_with_same_unit : t list -> string list\n end\n\n module Default_format = struct\n let of_string string = String.chop_suffix_exn string ~suffix:\"ns\" |> Int63.of_string\n let to_string nanos = Int63.to_string nanos ^ \"ns\"\n let to_string_with_same_unit list = List.map list ~f:to_string\n end\n\n let format = ref (module Default_format : Format)\n\n let of_string string =\n let (module Format) = !format in\n Format.of_string string\n ;;\n\n let to_string_with_same_unit string =\n let (module Format) = !format in\n Format.to_string_with_same_unit string\n ;;\nend\n\nmodule Gc_events = struct\n type t =\n { minor_collections : int\n ; major_collections : int\n ; compactions : int\n }\nend\n\nmodule Timing_event = struct\n type t =\n { description : string\n ; runtime : Duration.t\n ; gc_events : Gc_events.t\n ; nested_timing_events : t list\n }\nend\n\nmodule Timer = struct\n type t =\n { mutable currently_running_description : string\n ; mutable currently_running_start_time : Duration.t\n ; mutable currently_running_gc_stats : Gc.stat\n ; mutable nested_timer : t option\n ; mutable timing_events_in_reverse_chronological_order : Timing_event.t list\n }\n\n let create ?nested_timer () =\n { currently_running_description = \"\"\n ; currently_running_start_time = Int63.zero\n ; currently_running_gc_stats = Gc.quick_stat ()\n ; nested_timer\n ; timing_events_in_reverse_chronological_order = []\n }\n ;;\n\n let reset t =\n t.currently_running_description <- \"\";\n t.currently_running_start_time <- Int63.zero;\n match t.nested_timer with\n | None -> ()\n | Some nested -> nested.timing_events_in_reverse_chronological_order <- []\n ;;\n\n let record_start t description =\n if am_recording\n then (\n assert (String.is_empty t.currently_running_description);\n t.currently_running_description <- description;\n t.currently_running_gc_stats <- Gc.quick_stat ();\n (* call [Time_now] as late as possible before running the module body *)\n t.currently_running_start_time <- Time_now.nanoseconds_since_unix_epoch ())\n ;;\n\n let record_until t description =\n if am_recording\n then (\n (* compute [Time_now] as soon as possible after running the module body *)\n let until = Time_now.nanoseconds_since_unix_epoch () in\n let start = t.currently_running_start_time in\n let gc_stats_after = Gc.quick_stat () in\n let gc_stats_before = t.currently_running_gc_stats in\n let runtime = Int63.( - ) until start in\n assert (String.equal t.currently_running_description description);\n let gc_events : Gc_events.t =\n { minor_collections =\n gc_stats_after.minor_collections - gc_stats_before.minor_collections\n ; major_collections =\n gc_stats_after.major_collections - gc_stats_before.major_collections\n ; compactions = gc_stats_after.compactions - gc_stats_before.compactions\n }\n in\n let nested_timing_events =\n match t.nested_timer with\n | None -> []\n | Some nested -> List.rev nested.timing_events_in_reverse_chronological_order\n in\n let timing_event : Timing_event.t =\n { description; runtime; gc_events; nested_timing_events }\n in\n t.timing_events_in_reverse_chronological_order\n <- timing_event :: t.timing_events_in_reverse_chronological_order;\n reset t)\n ;;\nend\n\nlet definition_timer = Timer.create ()\nlet module_timer = Timer.create ~nested_timer:definition_timer ()\nlet record_start module_name = Timer.record_start module_timer module_name\nlet record_until module_name = Timer.record_until module_timer module_name\nlet record_definition_start loc = Timer.record_start definition_timer loc\nlet record_definition_until loc = Timer.record_until definition_timer loc\n\nlet gc_events_suffix_string\n ({ minor_collections; major_collections; compactions } : Gc_events.t)\n =\n let to_list description count =\n if count = 0 then [] else [ Int.to_string count ^ \" \" ^ description ]\n in\n let strings =\n to_list \"minor collections\" minor_collections\n @ to_list \"major collections\" major_collections\n @ to_list \"compactions\" compactions\n in\n if List.is_empty strings then \"\" else \"; GC: \" ^ String.concat strings ~sep:\", \"\n;;\n\nlet with_left_column_right_justified list =\n let left_column_width =\n List.fold list ~init:0 ~f:(fun width (left, _) -> Int.max width (String.length left))\n in\n List.map list ~f:(fun (left, right) ->\n Printf.sprintf \"%*s %s\" left_column_width left right)\n;;\n\nlet rec timing_events_to_strings list ~indent =\n let duration_strings =\n List.map list ~f:(fun (timing_event : Timing_event.t) -> timing_event.runtime)\n |> Duration.to_string_with_same_unit\n in\n let prefix = String.make indent ' ' in\n List.map2_exn\n duration_strings\n list\n ~f:(fun duration_string\n { runtime = _; description; gc_events; nested_timing_events }\n ->\n ( duration_string\n , description\n ^ gc_events_suffix_string gc_events\n ^ String.concat\n (List.map\n (timing_events_to_strings nested_timing_events ~indent:(indent + 4))\n ~f:(fun line -> \"\\n\" ^ line)) ))\n |> with_left_column_right_justified\n |> List.map ~f:(fun line -> prefix ^ line)\n;;\n\nlet fake_timing_events =\n let gc_events i : Gc_events.t =\n { minor_collections = (if i % 2 = 1 then 1 else 0)\n ; major_collections = (if i % 4 = 3 then 1 else 0)\n ; compactions = (if i % 8 = 7 then 1 else 0)\n }\n in\n lazy\n (List.init 12 ~f:(fun i ->\n ({ description = Printf.sprintf \"Fake__Dependency_%d\" (i + 1)\n ; runtime = Int63.of_int (900 * (i + 1))\n ; gc_events = gc_events i\n ; nested_timing_events =\n (if (i + 1) % 4 = 0\n then\n List.init (i + 1) ~f:(fun j ->\n ({ description = Printf.sprintf \"Line %d\" (j + 1)\n ; runtime = Int63.of_int (900 * (j + 1))\n ; gc_events = gc_events j\n ; nested_timing_events = []\n }\n : Timing_event.t))\n else [])\n }\n : Timing_event.t)))\n;;\n\nlet print_recorded_timing_events timing_events =\n let notify_of_overriding () =\n Stdio.print_endline \"ppx_module_timer: overriding time measurements for testing\"\n in\n let timing_events =\n match Option.value_exn am_recording_value with\n | \"FAKE_MODULES\" ->\n notify_of_overriding ();\n force fake_timing_events\n | string ->\n (match Duration.of_string string with\n | override ->\n notify_of_overriding ();\n List.mapi timing_events ~f:(fun index (timing_event : Timing_event.t) ->\n let runtime = Int63.( * ) override (Int63.of_int (index + 1)) in\n let nested_timing_events =\n List.mapi\n timing_event.nested_timing_events\n ~f:(fun index nested_timing_event ->\n let runtime = Int63.( * ) override (Int63.of_int (index + 1)) in\n { nested_timing_event with runtime })\n in\n { timing_event with runtime; nested_timing_events })\n | exception _ -> timing_events)\n in\n timing_events |> timing_events_to_strings ~indent:0 |> List.iter ~f:Stdio.print_endline\n;;\n\nlet () =\n if am_recording\n then\n Caml.at_exit (fun () ->\n print_recorded_timing_events\n (List.rev module_timer.timing_events_in_reverse_chronological_order))\n;;\n","module Name_of = struct\n let typename_of_int =\n let module M = Typename.Make0(struct type t = int let name = \"int\" end) in\n M.typename_of_t\n\n let typename_of_int32 =\n let module M = Typename.Make0(struct type t = int32 let name = \"int32\" end) in\n M.typename_of_t\n\n let typename_of_int64 =\n let module M = Typename.Make0(struct type t = int64 let name = \"int64\" end) in\n M.typename_of_t\n\n let typename_of_nativeint =\n let module M = Typename.Make0(struct\n type t = nativeint\n let name = \"nativeint\"\n end) in\n M.typename_of_t\n\n let typename_of_char =\n let module M = Typename.Make0(struct type t = char let name = \"char\" end) in\n M.typename_of_t\n\n let typename_of_float =\n let module M = Typename.Make0(struct type t = float let name = \"float\" end) in\n M.typename_of_t\n\n let typename_of_string =\n let module M = Typename.Make0(struct type t = string let name = \"string\" end) in\n M.typename_of_t\n\n let typename_of_bytes =\n let module M = Typename.Make0(struct type t = bytes let name = \"bytes\" end) in\n M.typename_of_t\n\n let typename_of_bool =\n let module M = Typename.Make0(struct type t = bool let name = \"bool\" end) in\n M.typename_of_t\n\n let typename_of_unit =\n let module M = Typename.Make0(struct type t = unit let name = \"unit\" end) in\n M.typename_of_t\n\n module M_option = Typename.Make1(struct type 'a t = 'a option let name = \"option\" end)\n let typename_of_option = M_option.typename_of_t\n\n module M_list = Typename.Make1(struct type 'a t = 'a list let name = \"list\" end)\n let typename_of_list = M_list.typename_of_t\n\n module M_array = Typename.Make1(struct type 'a t = 'a array let name = \"array\" end)\n let typename_of_array = M_array.typename_of_t\n\n module M_lazy_t = Typename.Make1(struct type 'a t = 'a lazy_t let name = \"lazy_t\" end)\n let typename_of_lazy_t = M_lazy_t.typename_of_t\n\n module M_ref = Typename.Make1(struct type 'a t = 'a ref let name = \"ref\" end)\n let typename_of_ref = M_ref.typename_of_t\n\n module M_function = Typename.Make2(struct\n type ('a, 'b) t = 'a -> 'b\n let name = \"function\"\n end)\n let typename_of_function = M_function.typename_of_t\n\n type tuple0 = unit\n module M_tuple0 = Typename.Make0(struct type t = tuple0 let name = \"tuple0\" end)\n let typename_of_tuple0 = M_tuple0.typename_of_t\n\n module M_tuple2 = Typename.Make2(struct\n type ('a, 'b) t = 'a * 'b\n let name = \"tuple2\"\n end)\n let typename_of_tuple2 = M_tuple2.typename_of_t\n\n module M_tuple3 = Typename.Make3(struct\n type ('a, 'b, 'c) t = 'a * 'b * 'c\n let name = \"tuple3\"\n end)\n let typename_of_tuple3 = M_tuple3.typename_of_t\n\n module M_tuple4 = Typename.Make4(struct\n type ('a, 'b, 'c, 'd) t = 'a * 'b * 'c * 'd\n let name = \"tuple4\"\n end)\n let typename_of_tuple4 = M_tuple4.typename_of_t\n\n module M_tuple5 = Typename.Make5(struct\n type ('a, 'b, 'c, 'd, 'e) t = 'a * 'b * 'c *'d * 'e\n let name = \"tuple5\"\n end)\n let typename_of_tuple5 = M_tuple5.typename_of_t\nend\n\nmodule rec Typerep : sig\n\n type _ t =\n | Int : int t\n | Int32 : int32 t\n | Int64 : int64 t\n | Nativeint : nativeint t\n | Char : char t\n | Float : float t\n | String : string t\n | Bytes : bytes t\n | Bool : bool t\n | Unit : unit t\n | Option : 'a t -> 'a option t\n | List : 'a t -> 'a list t\n | Array : 'a t -> 'a array t\n | Lazy : 'a t -> 'a lazy_t t\n | Ref : 'a t -> 'a ref t\n | Function : ('dom t * 'rng t) -> ('dom -> 'rng) t\n | Tuple : 'a Typerep.Tuple.t -> 'a t\n | Record : 'a Typerep.Record.t -> 'a t\n | Variant : 'a Typerep.Variant.t -> 'a t\n | Named : ('a Typerep.Named.t * 'a t lazy_t option) -> 'a t\n\n type packed = T : 'a t -> packed\n\n module Named : sig\n module type T0 = sig\n type named\n type t\n val typename_of_named : named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, named) Type_equal.t\n end\n module type T1 = sig\n type 'a named\n type a val a : a Typerep.t\n type t\n val typename_of_named : 'a Typename.t -> 'a named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, a named) Type_equal.t\n end\n module type T2 = sig\n type ('a, 'b) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> ('a, 'b) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b) named) Type_equal.t\n end\n module type T3 = sig\n type ('a, 'b, 'c) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> ('a, 'b, 'c) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c) named) Type_equal.t\n end\n module type T4 = sig\n type ('a, 'b, 'c, 'd) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type d val d : d Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> 'd Typename.t\n -> ('a, 'b, 'c, 'd) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c, d) named) Type_equal.t\n end\n module type T5 = sig\n type ('a, 'b, 'c, 'd, 'e) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type d val d : d Typerep.t\n type e val e : e Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> 'd Typename.t\n -> 'e Typename.t\n -> ('a, 'b, 'c, 'd, 'e) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c, d, e) named) Type_equal.t\n end\n (* there the module is necessary because we need to deal with a type [t] with\n parameters whose kind is not representable as a type variable: ['a 't], even with\n a gadt. *)\n type 'a t =\n | T0 of (module T0 with type t = 'a)\n | T1 of (module T1 with type t = 'a)\n | T2 of (module T2 with type t = 'a)\n | T3 of (module T3 with type t = 'a)\n | T4 of (module T4 with type t = 'a)\n | T5 of (module T5 with type t = 'a)\n\n val arity : _ t -> int\n val typename_of_t : 'a t -> 'a Typename.t\n val name : _ t -> string\n end\n\n module Tuple : sig\n (* these constructors could be plunged at toplevel of Typerep.t, however it is less\n verbose that way *)\n type _ t =\n | T2 : ('a Typerep.t * 'b Typerep.t)\n -> ('a * 'b) t\n | T3 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t)\n -> ('a * 'b * 'c) t\n | T4 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t * 'd Typerep.t)\n -> ('a * 'b * 'c * 'd) t\n | T5 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t * 'd Typerep.t * 'e Typerep.t)\n -> ('a * 'b * 'c * 'd * 'e) t\n\n val arity : _ t -> int\n val typename_of_t : 'a t -> 'a Typename.t\n end\n\n include Variant_and_record_intf.S with type 'a t := 'a Typerep.t\n\n val same : _ t -> _ t -> bool\n val same_witness : 'a t -> 'b t -> ('a, 'b) Type_equal.t option\n val same_witness_exn : 'a t -> 'b t -> ('a, 'b) Type_equal.t\n val typename_of_t : 'a t -> 'a Typename.t\n val head : 'a t -> 'a t\nend = struct\n\n type _ t =\n | Int : int t\n | Int32 : int32 t\n | Int64 : int64 t\n | Nativeint : nativeint t\n | Char : char t\n | Float : float t\n | String : string t\n | Bytes : bytes t\n | Bool : bool t\n | Unit : unit t\n | Option : 'a t -> 'a option t\n | List : 'a t -> 'a list t\n | Array : 'a t -> 'a array t\n | Lazy : 'a t -> 'a lazy_t t\n | Ref : 'a t -> 'a ref t\n | Function : ('dom t * 'rng t) -> ('dom -> 'rng) t\n | Tuple : 'a Typerep.Tuple.t -> 'a t\n | Record : 'a Typerep.Record.t -> 'a t\n | Variant : 'a Typerep.Variant.t -> 'a t\n | Named : ('a Typerep.Named.t * 'a t lazy_t option) -> 'a t\n\n type packed = T : 'a t -> packed\n\n module Named = struct\n module type T0 = sig\n type named\n type t\n val typename_of_named : named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, named) Type_equal.t\n end\n module type T1 = sig\n type 'a named\n type a val a : a Typerep.t\n type t\n val typename_of_named : 'a Typename.t -> 'a named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, a named) Type_equal.t\n end\n module type T2 = sig\n type ('a, 'b) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> ('a, 'b) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b) named) Type_equal.t\n end\n module type T3 = sig\n type ('a, 'b, 'c) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> ('a, 'b, 'c) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c) named) Type_equal.t\n end\n module type T4 = sig\n type ('a, 'b, 'c, 'd) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type d val d : d Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> 'd Typename.t\n -> ('a, 'b, 'c, 'd) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c, d) named) Type_equal.t\n end\n module type T5 = sig\n type ('a, 'b, 'c, 'd, 'e) named\n type a val a : a Typerep.t\n type b val b : b Typerep.t\n type c val c : c Typerep.t\n type d val d : d Typerep.t\n type e val e : e Typerep.t\n type t\n val typename_of_named :\n 'a Typename.t\n -> 'b Typename.t\n -> 'c Typename.t\n -> 'd Typename.t\n -> 'e Typename.t\n -> ('a, 'b, 'c, 'd, 'e) named Typename.t\n val typename_of_t : t Typename.t\n val witness : (t, (a, b, c, d, e) named) Type_equal.t\n end\n (* there the module is necessary because we need to deal with a type [t] with\n parameters whose kind is not representable as a type variable: ['a 't], even with\n a gadt. *)\n type 'a t =\n | T0 of (module T0 with type t = 'a)\n | T1 of (module T1 with type t = 'a)\n | T2 of (module T2 with type t = 'a)\n | T3 of (module T3 with type t = 'a)\n | T4 of (module T4 with type t = 'a)\n | T5 of (module T5 with type t = 'a)\n\n let arity = function\n | T0 _ -> 0\n | T1 _ -> 1\n | T2 _ -> 2\n | T3 _ -> 3\n | T4 _ -> 4\n | T5 _ -> 5\n\n let typename_of_t (type a) = function\n | T0 rep ->\n let module T = (val rep : T0 with type t = a) in\n T.typename_of_t\n | T1 rep ->\n let module T = (val rep : T1 with type t = a) in\n T.typename_of_t\n | T2 rep ->\n let module T = (val rep : T2 with type t = a) in\n T.typename_of_t\n | T3 rep ->\n let module T = (val rep : T3 with type t = a) in\n T.typename_of_t\n | T4 rep ->\n let module T = (val rep : T4 with type t = a) in\n T.typename_of_t\n | T5 rep ->\n let module T = (val rep : T5 with type t = a) in\n T.typename_of_t\n\n let name rep =\n Typename.Uid.name (Typename.uid (typename_of_t rep))\n end\n\n module Tuple = struct\n (* these constructors could be plunged at toplevel of Typerep.t, however it is less\n verbose this way *)\n type _ t =\n | T2 : ('a Typerep.t * 'b Typerep.t)\n -> ('a * 'b) t\n | T3 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t)\n -> ('a * 'b * 'c) t\n | T4 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t * 'd Typerep.t)\n -> ('a * 'b * 'c * 'd) t\n | T5 : ('a Typerep.t * 'b Typerep.t * 'c Typerep.t * 'd Typerep.t * 'e Typerep.t)\n -> ('a * 'b * 'c * 'd * 'e) t\n\n let arity : type a. a t -> int = function\n | Typerep.Tuple.T2 _ -> 2\n | Typerep.Tuple.T3 _ -> 3\n | Typerep.Tuple.T4 _ -> 4\n | Typerep.Tuple.T5 _ -> 5\n\n let typename_of_t : type a. a t -> a Typename.t = function\n | T2 (a, b) ->\n Name_of.typename_of_tuple2\n (Typerep.typename_of_t a)\n (Typerep.typename_of_t b)\n | T3 (a, b, c) ->\n Name_of.typename_of_tuple3\n (Typerep.typename_of_t a)\n (Typerep.typename_of_t b)\n (Typerep.typename_of_t c)\n | T4 (a, b, c, d) ->\n Name_of.typename_of_tuple4\n (Typerep.typename_of_t a)\n (Typerep.typename_of_t b)\n (Typerep.typename_of_t c)\n (Typerep.typename_of_t d)\n | T5 (a, b, c, d, e) ->\n Name_of.typename_of_tuple5\n (Typerep.typename_of_t a)\n (Typerep.typename_of_t b)\n (Typerep.typename_of_t c)\n (Typerep.typename_of_t d)\n (Typerep.typename_of_t e)\n end\n\n include Variant_and_record_intf.M (struct type 'a rep = 'a t type 'a t = 'a rep end)\n\n let rec typename_of_t : type a. a t -> a Typename.t = function\n | Int -> Name_of.typename_of_int\n | Int32 -> Name_of.typename_of_int32\n | Int64 -> Name_of.typename_of_int64\n | Nativeint -> Name_of.typename_of_nativeint\n | Char -> Name_of.typename_of_char\n | Float -> Name_of.typename_of_float\n | String -> Name_of.typename_of_string\n | Bytes -> Name_of.typename_of_bytes\n | Bool -> Name_of.typename_of_bool\n | Unit -> Name_of.typename_of_unit\n\n | Option rep -> Name_of.typename_of_option (typename_of_t rep)\n | List rep -> Name_of.typename_of_list (typename_of_t rep)\n | Array rep -> Name_of.typename_of_array (typename_of_t rep)\n | Lazy rep -> Name_of.typename_of_lazy_t (typename_of_t rep)\n | Ref rep -> Name_of.typename_of_ref (typename_of_t rep)\n\n | Function (dom, rng) ->\n Name_of.typename_of_function (typename_of_t dom) (typename_of_t rng)\n\n | Tuple rep -> Typerep.Tuple.typename_of_t rep\n\n | Record rep -> Typerep.Record.typename_of_t rep\n | Variant rep -> Typerep.Variant.typename_of_t rep\n\n | Named (name, _) -> Named.typename_of_t name\n ;;\n\n let rec same_witness : type a b. a t -> b t -> (a, b) Type_equal.t option = fun t1 t2 ->\n let module E = Type_equal in\n match t1, t2 with\n | Named (name1, r1), Named (name2, r2) -> begin\n match Typename.same_witness\n (Named.typename_of_t name1)\n (Named.typename_of_t name2) with\n | Some E.T as x -> x\n | None ->\n match r1, r2 with\n | Some (lazy t1), Some (lazy t2) -> same_witness t1 t2\n | Some (lazy t1), None -> same_witness t1 t2\n | None, Some (lazy t2) -> same_witness t1 t2\n | None, None -> None\n end\n | Named (_, r1), t2 -> begin\n match r1 with\n | Some (lazy t1) -> same_witness t1 t2\n | None -> None\n end\n | t1, Named (_, r2) -> begin\n match r2 with\n | Some (lazy t2) -> same_witness t1 t2\n | None -> None\n end\n | Int , Int -> Some E.T\n | Int32 , Int32 -> Some E.T\n | Int64 , Int64 -> Some E.T\n | Nativeint , Nativeint -> Some E.T\n | Char , Char -> Some E.T\n | Float , Float -> Some E.T\n | String , String -> Some E.T\n | Bytes , Bytes -> Some E.T\n | Bool , Bool -> Some E.T\n | Unit , Unit -> Some E.T\n | Option r1, Option r2 -> begin\n match same_witness r1 r2 with\n | None as x -> x\n | Some E.T as x -> x\n end\n | List r1, List r2 -> begin\n match same_witness r1 r2 with\n | None as x -> x\n | Some E.T as x -> x\n end\n | Array r1, Array r2 -> begin\n match same_witness r1 r2 with\n | None as x -> x\n | Some E.T as x -> x\n end\n | Lazy r1, Lazy r2 -> begin\n match same_witness r1 r2 with\n | None as x -> x\n | Some E.T as x -> x\n end\n | Ref r1, Ref r2 -> begin\n match same_witness r1 r2 with\n | None as x -> x\n | Some E.T as x -> x\n end\n | Function (dom1, rng1), Function (dom2, rng2) -> begin\n match same_witness dom1 dom2, same_witness rng1 rng2 with\n | Some E.T, Some E.T -> Some E.T\n | None, _ | _, None -> None\n end\n | Tuple t1, Tuple t2 -> begin\n let module T = Typerep.Tuple in\n match t1, t2 with\n | T.T2 (a1, b1), T.T2 (a2, b2) -> begin\n match same_witness a1 a2, same_witness b1 b2 with\n | Some E.T, Some E.T -> Some E.T\n | None, _ | _, None -> None\n end\n | T.T3 (a1, b1, c1), T.T3 (a2, b2, c2) -> begin\n match\n same_witness a1 a2,\n same_witness b1 b2,\n same_witness c1 c2\n with\n | Some E.T, Some E.T, Some E.T -> Some E.T\n | None, _, _\n | _, None, _\n | _, _, None\n -> None\n end\n | T.T4 (a1, b1, c1, d1), T.T4 (a2, b2, c2, d2) -> begin\n match\n same_witness a1 a2,\n same_witness b1 b2,\n same_witness c1 c2,\n same_witness d1 d2\n with\n | Some E.T, Some E.T, Some E.T, Some E.T -> Some E.T\n | None, _, _, _\n | _, None, _, _\n | _, _, None, _\n | _, _, _, None\n -> None\n end\n | T.T5 (a1, b1, c1, d1, e1), T.T5 (a2, b2, c2, d2, e2) -> begin\n match\n same_witness a1 a2,\n same_witness b1 b2,\n same_witness c1 c2,\n same_witness d1 d2,\n same_witness e1 e2\n with\n | Some E.T, Some E.T, Some E.T, Some E.T, Some E.T -> Some E.T\n | None, _, _, _, _\n | _, None, _, _, _\n | _, _, None, _, _\n | _, _, _, None, _\n | _, _, _, _, None\n -> None\n end\n | T.T2 _, _ -> None\n | T.T3 _, _ -> None\n | T.T4 _, _ -> None\n | T.T5 _, _ -> None\n end\n | Record r1, Record r2 ->\n Typename.same_witness\n (Typerep.Record.typename_of_t r1)\n (Typerep.Record.typename_of_t r2)\n | Variant r1, Variant r2 ->\n Typename.same_witness\n (Typerep.Variant.typename_of_t r1)\n (Typerep.Variant.typename_of_t r2)\n | Int, _ -> None\n | Int32, _ -> None\n | Int64, _ -> None\n | Nativeint, _ -> None\n | Char, _ -> None\n | Float, _ -> None\n | String, _ -> None\n | Bytes, _ -> None\n | Bool, _ -> None\n | Unit, _ -> None\n | Option _, _ -> None\n | List _, _ -> None\n | Array _, _ -> None\n | Lazy _, _ -> None\n | Ref _, _ -> None\n | Function _, _ -> None\n | Tuple _, _ -> None\n | Record _, _ -> None\n | Variant _, _ -> None\n ;;\n\n let same a b = same_witness a b <> None\n let same_witness_exn a b =\n match same_witness a b with\n | Some proof -> proof\n | None -> assert false\n\n let rec head = function\n | Typerep.Named (_, Some (lazy t)) -> head t\n | t -> t\nend\n\nlet typerep_of_int = Typerep.Int\nlet typerep_of_int32 = Typerep.Int32\nlet typerep_of_int64 = Typerep.Int64\nlet typerep_of_nativeint = Typerep.Nativeint\nlet typerep_of_char = Typerep.Char\nlet typerep_of_float = Typerep.Float\nlet typerep_of_string = Typerep.String\nlet typerep_of_bytes = Typerep.Bytes\nlet typerep_of_bool = Typerep.Bool\nlet typerep_of_unit = Typerep.Unit\n\nlet typerep_of_option rep = Typerep.Option rep\nlet typerep_of_list rep = Typerep.List rep\nlet typerep_of_array rep = Typerep.Array rep\nlet typerep_of_lazy_t rep = Typerep.Lazy rep\nlet typerep_of_ref rep = Typerep.Ref rep\n\nlet typerep_of_function dom rng = Typerep.Function (dom, rng)\n\nlet typerep_of_tuple0 = Typerep.Unit\nlet typerep_of_tuple2 a b = Typerep.Tuple (Typerep.Tuple.T2 (a, b))\nlet typerep_of_tuple3 a b c = Typerep.Tuple (Typerep.Tuple.T3 (a, b, c))\nlet typerep_of_tuple4 a b c d = Typerep.Tuple (Typerep.Tuple.T4 (a, b, c, d))\nlet typerep_of_tuple5 a b c d e = Typerep.Tuple (Typerep.Tuple.T5 (a, b, c, d, e))\n\ninclude Name_of\nlet value_tuple0 = ()\n\nlet typerep_of_int63, typename_of_int63 =\n let typerep_and_typename_of_int63_repr\n : type a b . (a, b) Base.Int63.Private.Repr.t -> a Typerep.t * a Typename.t\n = function\n | Base.Int63.Private.Repr.Int -> typerep_of_int, typename_of_int\n | Base.Int63.Private.Repr.Int64 -> typerep_of_int64, typename_of_int64\n in\n typerep_and_typename_of_int63_repr Base.Int63.Private.repr\n","let __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\000\\000\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\005\\000\\000\\000\\000\\000\\001\\000\\255\\255\\002\\000\\000\\000\\000\\000\\\n \\001\\000\\000\\000\\002\\000\\001\\000\\003\\000\\000\\000\\003\\000\\003\\000\\\n \\000\\000\\001\\000\\009\\000\\005\\000\\002\\000\\004\\000\\017\\000\\012\\000\\\n \\014\\000\\004\\000\\017\\000\\018\\000\\026\\000\\028\\000\\005\\000\\027\\000\\\n \\016\\000\\020\\000\\023\\000\\006\\000\\085\\000\\253\\255\\254\\255\\001\\000\\\n \\046\\000\\047\\000\\040\\000\\031\\000\\046\\000\\048\\000\\007\\000\\079\\000\\\n \\028\\000\\062\\000\\008\\000\\255\\255\\009\\000\\067\\000\\067\\000\\103\\000\\\n \\100\\000\\105\\000\\095\\000\\107\\000\\095\\000\\113\\000\\010\\000\\104\\000\\\n \\104\\000\\116\\000\\104\\000\\122\\000\\104\\000\\116\\000\\111\\000\\113\\000\\\n \\011\\000\\116\\000\\117\\000\\125\\000\\127\\000\\012\\000\\126\\000\\115\\000\\\n \\119\\000\\122\\000\\013\\000\";\n Lexing.lex_backtrk =\n \"\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\";\n Lexing.lex_default =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\047\\000\\000\\000\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\008\\000\\012\\000\\014\\000\\024\\000\\012\\000\\039\\000\\012\\000\\055\\000\\\n \\059\\000\\061\\000\\071\\000\\059\\000\\086\\000\\059\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\001\\000\\048\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\002\\000\\049\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\034\\000\\003\\000\\029\\000\\007\\000\\006\\000\\010\\000\\009\\000\\\n \\023\\000\\004\\000\\017\\000\\019\\000\\021\\000\\018\\000\\027\\000\\025\\000\\\n \\015\\000\\026\\000\\016\\000\\005\\000\\011\\000\\020\\000\\022\\000\\028\\000\\\n \\030\\000\\013\\000\\031\\000\\032\\000\\033\\000\\035\\000\\036\\000\\037\\000\\\n \\038\\000\\040\\000\\041\\000\\042\\000\\043\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\081\\000\\\n \\050\\000\\051\\000\\052\\000\\053\\000\\054\\000\\060\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\057\\000\\056\\000\\058\\000\\062\\000\\046\\000\\063\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\064\\000\\065\\000\\066\\000\\067\\000\\068\\000\\069\\000\\070\\000\\072\\000\\\n \\073\\000\\074\\000\\075\\000\\076\\000\\077\\000\\078\\000\\079\\000\\080\\000\\\n \\082\\000\\083\\000\\084\\000\\085\\000\\087\\000\\088\\000\\089\\000\\090\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\045\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\007\\000\\011\\000\\013\\000\\023\\000\\033\\000\\038\\000\\043\\000\\054\\000\\\n \\058\\000\\060\\000\\070\\000\\080\\000\\085\\000\\090\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\047\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\047\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\001\\000\\002\\000\\028\\000\\006\\000\\005\\000\\008\\000\\008\\000\\\n \\022\\000\\003\\000\\016\\000\\018\\000\\020\\000\\017\\000\\026\\000\\024\\000\\\n \\014\\000\\025\\000\\015\\000\\004\\000\\010\\000\\019\\000\\021\\000\\027\\000\\\n \\029\\000\\009\\000\\030\\000\\031\\000\\032\\000\\034\\000\\035\\000\\036\\000\\\n \\037\\000\\039\\000\\040\\000\\041\\000\\042\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\048\\000\\\n \\049\\000\\050\\000\\051\\000\\052\\000\\053\\000\\056\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\055\\000\\055\\000\\057\\000\\061\\000\\044\\000\\062\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\063\\000\\064\\000\\065\\000\\066\\000\\067\\000\\068\\000\\069\\000\\071\\000\\\n \\072\\000\\073\\000\\074\\000\\075\\000\\076\\000\\077\\000\\078\\000\\079\\000\\\n \\081\\000\\082\\000\\083\\000\\084\\000\\086\\000\\087\\000\\088\\000\\089\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\044\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec check lexbuf =\n __ocaml_lex_check_rec lexbuf 0\nand __ocaml_lex_check_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n# 4 \"collector/check_backtraces.mll\"\n ( true )\n# 163 \"collector/check_backtraces.ml\"\n\n | 1 ->\n# 5 \"collector/check_backtraces.mll\"\n ( not_at_bos lexbuf )\n# 168 \"collector/check_backtraces.ml\"\n\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_check_rec lexbuf __ocaml_lex_state\n\nand not_at_bos lexbuf =\n __ocaml_lex_not_at_bos_rec lexbuf 44\nand __ocaml_lex_not_at_bos_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n# 8 \"collector/check_backtraces.mll\"\n ( true )\n# 180 \"collector/check_backtraces.ml\"\n\n | 1 ->\n# 9 \"collector/check_backtraces.mll\"\n ( not_at_bos lexbuf )\n# 185 \"collector/check_backtraces.ml\"\n\n | 2 ->\n# 10 \"collector/check_backtraces.mll\"\n ( false )\n# 190 \"collector/check_backtraces.ml\"\n\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_not_at_bos_rec lexbuf __ocaml_lex_state\n\n;;\n\n# 12 \"collector/check_backtraces.mll\"\n \n let contains_backtraces s = check (Lexing.from_string s)\n\n# 201 \"collector/check_backtraces.ml\"\n","(** This module implements \"Fast Splittable Pseudorandom Number Generators\" by Steele et.\n al. (1). The paper's algorithm provides decent randomness for most purposes, but\n sacrifices cryptographic-quality randomness in favor of performance. The original\n implementation was tested with DieHarder and BigCrush; see the paper for details.\n\n Our implementation is a port from Java to OCaml of the paper's algorithm. Other than\n the choice of initial seed for [create], our port should be faithful. We have not\n re-run the DieHarder or BigCrush tests on our implementation. Our port is also not as\n performant as the original; two factors that hurt us are boxed [int64] values and lack\n of a POPCNT primitive.\n\n (1) http://2014.splashcon.org/event/oopsla2014-fast-splittable-pseudorandom-number-generators\n (also mirrored at http://gee.cs.oswego.edu/dl/papers/oopsla14.pdf)\n\n Beware when implementing this interface; it is easy to implement a [split] operation\n whose output is not as \"independent\" as it seems (2). This bug caused problems for\n Haskell's Quickcheck library for a long time.\n\n (2) Schaathun, \"Evaluation of splittable pseudo-random generators\", JFP 2015.\n http://www.hg.schaathun.net/research/Papers/hgs2015jfp.pdf\n*)\n\nopen! Base\nopen Int64.O\n\nlet is_odd x = x lor 1L = x\n\nlet popcount = Int64.popcount\n\nmodule State = struct\n\n type t =\n { mutable seed : int64\n ; odd_gamma : int64\n }\n\n let golden_gamma = 0x9e37_79b9_7f4a_7c15L\n\n let of_int seed =\n { seed = Int64.of_int seed\n ; odd_gamma = golden_gamma\n }\n\n let copy { seed ; odd_gamma } = { seed ; odd_gamma }\n\n let mix_bits z n =\n z lxor (z lsr n)\n\n let mix64 z =\n let z = (mix_bits z 33) * 0xff51_afd7_ed55_8ccdL in\n let z = (mix_bits z 33) * 0xc4ce_b9fe_1a85_ec53L in\n mix_bits z 33\n\n let mix64_variant13 z =\n let z = (mix_bits z 30) * 0xbf58_476d_1ce4_e5b9L in\n let z = (mix_bits z 27) * 0x94d0_49bb_1331_11ebL in\n mix_bits z 31\n\n let mix_odd_gamma z =\n let z = (mix64_variant13 z) lor 1L in\n let n = popcount (z lxor (z lsr 1)) in\n (* The original paper uses [>=] in the conditional immediately below; however this is\n a typo, and we correct it by using [<]. This was fixed in response to [1] and [2].\n\n [1] https://github.com/janestreet/splittable_random/issues/1\n [2] http://www.pcg-random.org/posts/bugs-in-splitmix.html\n *)\n if Int.( < ) n 24\n then z lxor 0xaaaa_aaaa_aaaa_aaaaL\n else z\n\n let%test_unit \"odd gamma\" =\n for input = -1_000_000 to 1_000_000 do\n let output = mix_odd_gamma (Int64.of_int input) in\n if not (is_odd output) then\n Error.raise_s [%message\n \"gamma value is not odd\"\n (input : int)\n (output : int64)]\n done\n\n let next_seed t =\n let next = t.seed + t.odd_gamma in\n t.seed <- next;\n next\n\n let of_seed_and_gamma ~seed ~gamma =\n let seed = mix64 seed in\n let odd_gamma = mix_odd_gamma gamma in\n { seed; odd_gamma }\n\n let random_int64 random_state =\n Random.State.int64_incl random_state Int64.min_value Int64.max_value\n\n let create random_state =\n let seed = random_int64 random_state in\n let gamma = random_int64 random_state in\n of_seed_and_gamma ~seed ~gamma\n\n let split t =\n let seed = next_seed t in\n let gamma = next_seed t in\n of_seed_and_gamma ~seed ~gamma\n\n let next_int64 t = mix64 (next_seed t)\n\n (* [perturb] is not from any external source, but provides a way to mix in external\n entropy with a pseudo-random state. *)\n let perturb t salt =\n let next = t.seed + mix64 (Int64.of_int salt) in\n t.seed <- next\n\nend\n\nlet bool state = is_odd (State.next_int64 state)\n\n(* We abuse terminology and refer to individual values as biased or unbiased. More\n properly, what is unbiased is the sampler that results if we keep only these \"unbiased\"\n values. *)\nlet remainder_is_unbiased\n ~draw\n ~remainder\n ~draw_maximum\n ~remainder_maximum\n =\n let open Int64.O in\n draw - remainder <= draw_maximum - remainder_maximum\n\nlet%test_unit \"remainder_is_unbiased\" =\n (* choosing a range of 10 values based on a range of 105 values *)\n let draw_maximum = 104L in\n let remainder_maximum = 9L in\n let is_unbiased draw =\n let remainder = Int64.rem draw (Int64.succ remainder_maximum) in\n remainder_is_unbiased ~draw ~remainder ~draw_maximum ~remainder_maximum\n in\n for i = 0 to 99 do\n [%test_result: bool]\n (is_unbiased (Int64.of_int i))\n ~expect:true\n ~message:(Int.to_string i)\n done;\n for i = 100 to 104 do\n [%test_result: bool]\n (is_unbiased (Int64.of_int i))\n ~expect:false\n ~message:(Int.to_string i)\n done\n\n(* This implementation of bounded randomness is adapted from [Random.State.int*] in the\n OCaml standard library. The purpose is to use the minimum number of calls to\n [next_int64] to produce a number uniformly chosen within the given range. *)\nlet int64 =\n let open Int64.O in\n let rec between state ~lo ~hi =\n let draw = State.next_int64 state in\n if lo <= draw && draw <= hi\n then draw\n else between state ~lo ~hi\n in\n let rec non_negative_up_to state maximum =\n let draw = State.next_int64 state land Int64.max_value in\n let remainder = Int64.rem draw (Int64.succ maximum) in\n if remainder_is_unbiased\n ~draw\n ~remainder\n ~draw_maximum:Int64.max_value\n ~remainder_maximum:maximum\n then remainder\n else non_negative_up_to state maximum\n in\n fun state ~lo ~hi ->\n if lo > hi then begin\n Error.raise_s [%message \"int64: crossed bounds\" (lo : int64) (hi : int64)]\n end;\n let diff = hi - lo in\n if diff = Int64.max_value\n then ((State.next_int64 state) land Int64.max_value) + lo\n else if diff >= 0L\n then (non_negative_up_to state diff) + lo\n else between state ~lo ~hi\n\nlet int state ~lo ~hi =\n let lo = Int64.of_int lo in\n let hi = Int64.of_int hi in\n (* truncate unneeded bits *)\n Int64.to_int_trunc (int64 state ~lo ~hi)\n\nlet int32 state ~lo ~hi =\n let lo = Int64.of_int32 lo in\n let hi = Int64.of_int32 hi in\n (* truncate unneeded bits *)\n Int64.to_int32_trunc (int64 state ~lo ~hi)\n\nlet nativeint state ~lo ~hi =\n let lo = Int64.of_nativeint lo in\n let hi = Int64.of_nativeint hi in\n (* truncate unneeded bits *)\n Int64.to_nativeint_trunc (int64 state ~lo ~hi)\n\nlet int63 state ~lo ~hi =\n let lo = Int63.to_int64 lo in\n let hi = Int63.to_int64 hi in\n (* truncate unneeded bits *)\n Int63.of_int64_trunc (int64 state ~lo ~hi)\n\nlet double_ulp = 2. **. -53.\n\nlet%test_unit \"double_ulp\" =\n let open Float.O in\n match Word_size.word_size with\n | W64 ->\n assert (1.0 -. double_ulp < 1.0);\n assert (1.0 -. (double_ulp /. 2.0) = 1.0)\n | W32 ->\n (* 32-bit OCaml uses a 64-bit float representation but 80-bit float instructions, so\n rounding works differently due to the conversion back and forth. *)\n assert (1.0 -. double_ulp < 1.0);\n assert (1.0 -. (double_ulp /. 2.0) <= 1.0)\n\nlet unit_float_from_int64 int64 =\n (Int64.to_float (int64 lsr 11)) *. double_ulp\n\nlet%test_unit \"unit_float_from_int64\" = begin\n let open Float.O in\n assert (unit_float_from_int64 0x0000_0000_0000_0000L = 0.);\n assert (unit_float_from_int64 0xffff_ffff_ffff_ffffL < 1.0);\n assert (unit_float_from_int64 0xffff_ffff_ffff_ffffL = (1.0 -. double_ulp));\nend\n\nlet unit_float state =\n unit_float_from_int64 (State.next_int64 state)\n\n(* Note about roundoff error:\n\n Although [float state ~lo ~hi] is nominally inclusive of endpoints, we are relying on\n the fact that [unit_float] never returns 1., because there are pairs [(lo,hi)] for\n which [lo +. 1. *. (hi -. lo) > hi]. There are also pairs [(lo,hi)] and values of [x]\n with [x < 1.] such that [lo +. x *. (hi -. lo) = hi], so it would not be correct to\n document this as being exclusive of [hi].\n*)\nlet float =\n let rec finite_float state ~lo ~hi =\n let range = hi -. lo in\n if Float.is_finite range\n then (lo +. (unit_float state *. range))\n else begin\n (* If [hi - lo] is infinite, then [hi + lo] is finite because [hi] and [lo] have\n opposite signs. *)\n let mid = (hi +. lo) /. 2. in\n if bool state\n (* Depending on rounding, the recursion with [~hi:mid] might be inclusive of [mid],\n which would mean the two cases overlap on [mid]. The alternative is to increment\n or decrement [mid] using [one_ulp] in either of the calls, but then if the first\n case is exclusive we leave a \"gap\" between the two ranges. There's no perfectly\n uniform solution, so we use the simpler code that does not call [one_ulp]. *)\n then finite_float state ~lo ~hi:mid\n else finite_float state ~lo:mid ~hi\n end\n in\n fun state ~lo ~hi ->\n if not (Float.is_finite lo && Float.is_finite hi)\n then begin\n raise_s [%message\n \"float: bounds are not finite numbers\"\n (lo : float)\n (hi : float)]\n end;\n if Float.( > ) lo hi\n then begin\n raise_s [%message\n \"float: bounds are crossed\"\n (lo : float)\n (hi : float)]\n end;\n finite_float state ~lo ~hi\n\nlet%bench_fun \"unit_float_from_int64\" =\n let int64 = 1L in\n fun () -> unit_float_from_int64 int64\n\nmodule Log_uniform = struct\n module Make (M : sig include Int.S val uniform : State.t -> lo:t -> hi:t -> t end) : sig\n val log_uniform : State.t -> lo:M.t -> hi:M.t -> M.t\n end = struct\n open M\n\n let bits_to_represent t =\n assert (t >= zero);\n let t = ref t in\n let n = ref 0 in\n while !t > zero do\n t := shift_right !t 1;\n Int.incr n;\n done;\n !n\n\n let%test_unit \"bits_to_represent\" =\n let test n expect = [%test_result: int] (bits_to_represent n) ~expect in\n test (M.of_int_exn 0) 0;\n test (M.of_int_exn 1) 1;\n test (M.of_int_exn 2) 2;\n test (M.of_int_exn 3) 2;\n test (M.of_int_exn 4) 3;\n test (M.of_int_exn 5) 3;\n test (M.of_int_exn 6) 3;\n test (M.of_int_exn 7) 3;\n test (M.of_int_exn 8) 4;\n test (M.of_int_exn 100) 7;\n test M.max_value (Int.pred M.num_bits);\n ;;\n\n let min_represented_by_n_bits n =\n if Int.equal n 0\n then zero\n else shift_left one (Int.pred n)\n\n let%test_unit \"min_represented_by_n_bits\" =\n let test n expect = [%test_result: M.t] (min_represented_by_n_bits n) ~expect in\n test 0 (M.of_int_exn 0);\n test 1 (M.of_int_exn 1);\n test 2 (M.of_int_exn 2);\n test 3 (M.of_int_exn 4);\n test 4 (M.of_int_exn 8);\n test 7 (M.of_int_exn 64);\n test (Int.pred M.num_bits) (M.shift_right_logical M.min_value 1);\n ;;\n\n let max_represented_by_n_bits n =\n pred (shift_left one n)\n\n let%test_unit \"max_represented_by_n_bits\" =\n let test n expect = [%test_result: M.t] (max_represented_by_n_bits n) ~expect in\n test 0 (M.of_int_exn 0);\n test 1 (M.of_int_exn 1);\n test 2 (M.of_int_exn 3);\n test 3 (M.of_int_exn 7);\n test 4 (M.of_int_exn 15);\n test 7 (M.of_int_exn 127);\n test (Int.pred M.num_bits) M.max_value;\n ;;\n\n let log_uniform state ~lo ~hi =\n let min_bits = bits_to_represent lo in\n let max_bits = bits_to_represent hi in\n let bits = int state ~lo:min_bits ~hi:max_bits in\n uniform state\n ~lo:(min_represented_by_n_bits bits |> max lo)\n ~hi:(max_represented_by_n_bits bits |> min hi)\n end\n\n module For_int = Make (struct include Int let uniform = int end)\n module For_int32 = Make (struct include Int32 let uniform = int32 end)\n module For_int63 = Make (struct include Int63 let uniform = int63 end)\n module For_int64 = Make (struct include Int64 let uniform = int64 end)\n module For_nativeint = Make (struct include Nativeint let uniform = nativeint end)\n\n let int = For_int.log_uniform\n let int32 = For_int32.log_uniform\n let int63 = For_int63.log_uniform\n let int64 = For_int64.log_uniform\n let nativeint = For_nativeint.log_uniform\nend\n\n","(* This module builds a buffer of \"instructions\", in order to represent a compact sequence\n of delimiting positions and newlines. The parser stores the positions of each:\n\n - newline\n - beginning of atom\n - end of atom\n - left parenthesis\n - right parenthesis\n\n Instructions are encoded as a sequence bits. The next instruction is determined by\n looking at the next few bits:\n\n - bit 0 represents a saved position followed by an offset increment\n - bits 10 represent an offset increment\n - bits 110 are followed by 5 bits of payload. The 5-bit payloads of any subsequent 110-\n instructions are squashed to form a number (least significant 5-bit chunk first).\n This number + 5 represents an offset increment\n - bits 1110 marks the beginning of a new line (with offset incremented)\n - bits 1111 represent a position saved twice followed by an offset increment\n\n For instance let's consider the following sexp:\n\n {[\n {|\n(abc\n \"foo\n bar\"\n)\n|}\n ]}\n\n the sequence of instructions to record in order to reconstruct the position of any\n sub-sexp is:\n\n - 0 save position and advance 1: first '('\n - 0 save position and advance 1: start of \"abc\"\n - 10 advance 1\n - 0 save position and advance 1: end of \"abc\"\n - 1110 newline\n - 1100_0001 advance 6\n - 0 save position and advance 1: start of \"foo\\n bar\"\n - 10 advance 1\n - 10 advance 1\n - 10 advance 1\n - 1110 newline\n - 1100_0000 advance 5\n - 0 save position and advance 1: end of \"foo\\n bar\"\n - 1110 newline\n - 0 save position and advance 1: last ')'\n\n (we save the position after the closing parenthesis)\n\n The total sequence is 42 bits, so we need 6 bytes to store it\n\n The sequence of bits is encoded as a sequence of 16-bit values, where the earlier bits\n are most significant.\n\n Note that the parser stores the end positions as inclusive. This way only single\n character atoms require a double positions. If we were storing end positions as\n exclusive, we would need double positions for [)(] and [a(], which are likely to be\n frequent in s-expressions printed with the non [_hum] printer. We expect single\n character atoms to be less frequent so it makes sense to penalize them instead.\n*)\n\nopen! Import\n\ntype pos =\n { line : int\n ; col : int\n ; offset : int\n }\n[@@deriving_inline sexp_of]\n\nlet sexp_of_pos =\n (function\n | { line = v_line; col = v_col; offset = v_offset } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_int v_offset in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"offset\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_col in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"col\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_line in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"line\"; arg ] :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : pos -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet compare_pos = Caml.compare\nlet beginning_of_file = { line = 1; col = 0; offset = 0 }\nlet shift_pos pos ~cols = { pos with col = pos.col + cols; offset = pos.offset + cols }\n\ntype range =\n { start_pos : pos\n ; end_pos : pos\n }\n[@@deriving_inline sexp_of]\n\nlet sexp_of_range =\n (function\n | { start_pos = v_start_pos; end_pos = v_end_pos } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_pos v_end_pos in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"end_pos\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_pos v_start_pos in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"start_pos\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : range -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet compare_range = Caml.compare\n\nlet make_range_incl ~start_pos ~last_pos =\n { start_pos; end_pos = shift_pos last_pos ~cols:1 }\n;;\n\nmodule Chunk : sig\n (** Represents an array of [length/2] signed 16-bit values *)\n type t\n\n (** Length in bytes. *)\n val length : int\n\n val alloc : unit -> t\n\n (** [get16 ~pos] and [set16 ~pos] manipulate the [pos/2]th stored value.\n [pos] must be even.\n [set16 x] only uses the 16 least significant bits of [x]. *)\n val get16 : t -> pos:int -> int\n\n val set16 : t -> pos:int -> int -> unit\nend = struct\n type t = bytes\n\n (* OCaml strings always waste two bytes at the end, so we take a power of two minus two\n to be sure we don't waste space. *)\n let length = 62\n let alloc () = Bytes.create length\n let get16 = Bytes0.get16\n let set16 = Bytes0.set16\n\n (* If we want to make a [Positions.t] serializable:\n\n {[\n external bswap16 : int -> int = \"%bswap16\";;\n\n let get16 =\n if Caml.Sys.arch_big_endian then\n fun buf ~pos -> get16 buf ~pos |> bswap16\n else\n get16\n\n let set16 =\n if Caml.Sys.arch_big_endian then\n fun buf ~pos x -> set16 buf ~pos (bswap16 x)\n else\n set16\n ]}\n\n *)\nend\n\ntype t_ =\n { chunks : Chunk.t list\n ; (* [num_bytes * 8 + extra_bits] is the number of bits stored in [chunks].\n The last [extra_bits] bits will be stored as the *least* significant bits\n of the appropriate pair of bytes of the last chunk. *)\n num_bytes : int\n ; extra_bits : int\n ; initial_pos : pos\n }\n\ntype t = t_ Lazy.t\n\nlet memory_footprint_in_bytes (lazy t) =\n let num_fields = 4 in\n let header_words = 1 in\n let word_bytes =\n match Sys.word_size with\n | 32 -> 4\n | 64 -> 8\n | _ -> assert false\n in\n let chunk_words =\n let div_ceil a b = (a + b - 1) / b in\n let n =\n div_ceil\n (Chunk.length\n + 1 (* NUL terminating bytes *)\n + 1 (* number of wasted bytes to fill a word *))\n word_bytes\n in\n n + header_words\n in\n let pos_fields = 3 in\n let pos_words = header_words + pos_fields in\n let list_cons_words = header_words + 2 in\n (header_words\n + num_fields\n + pos_words\n + (List.length t.chunks * (chunk_words + list_cons_words)))\n * word_bytes\n;;\n\nmodule Builder = struct\n type t =\n { mutable chunk : Chunk.t\n ; mutable chunk_pos : int\n ; mutable filled_chunks : Chunk.t list (* Filled chunks in reverse order *)\n ; mutable offset : int\n (* Offset of the last saved position or newline plus\n one, or [initial_pos] *)\n ; mutable int_buf : int\n (* the [num_bits] least significant bits of [int_buf]\n are the bits not yet pushed to [chunk]. *)\n ; mutable num_bits : int (* number of bits stored in [int_buf] *)\n ; mutable initial_pos : pos\n }\n\n let invariant t =\n assert (t.chunk_pos >= 0 && t.chunk_pos <= Chunk.length);\n assert (t.offset >= t.initial_pos.offset);\n assert (t.num_bits <= 15)\n ;;\n\n let check_invariant = false\n let invariant t = if check_invariant then invariant t\n\n let create ?(initial_pos = beginning_of_file) () =\n { chunk = Chunk.alloc ()\n ; chunk_pos = 0\n ; filled_chunks = []\n ; offset = initial_pos.offset\n ; int_buf = 0\n ; num_bits = 0\n ; initial_pos\n }\n ;;\n\n let reset t (pos : pos) =\n (* We need a new chunk as [contents] keeps the current chunk in the closure of the\n lazy value. *)\n t.chunk <- Chunk.alloc ();\n t.chunk_pos <- 0;\n t.filled_chunks <- [];\n t.offset <- pos.offset;\n t.int_buf <- 0;\n t.num_bits <- 0;\n t.initial_pos <- pos\n ;;\n\n let[@inlined never] alloc_new_chunk t =\n t.filled_chunks <- t.chunk :: t.filled_chunks;\n t.chunk <- Chunk.alloc ();\n t.chunk_pos <- 0\n ;;\n\n let add_uint16 t n =\n if t.chunk_pos = Chunk.length then alloc_new_chunk t;\n Chunk.set16 t.chunk ~pos:t.chunk_pos n\n ;;\n\n let add_bits t n ~num_bits =\n let int_buf = (t.int_buf lsl num_bits) lor n in\n let num_bits = t.num_bits + num_bits in\n t.int_buf <- int_buf;\n if num_bits < 16\n then t.num_bits <- num_bits\n else (\n let num_bits = num_bits - 16 in\n t.num_bits <- num_bits;\n add_uint16 t (int_buf lsr num_bits);\n t.chunk_pos <- t.chunk_pos + 2\n (* no need to clear the bits of int_buf we just wrote, as further set16 will ignore\n these extra bits. *))\n ;;\n\n let contents t =\n (* Flush the current [t.int_buf] *)\n add_uint16 t t.int_buf;\n let rev_chunks = t.chunk :: t.filled_chunks in\n let chunk_pos = t.chunk_pos in\n let extra_bits = t.num_bits in\n let initial_pos = t.initial_pos in\n lazy\n { chunks = List.rev rev_chunks\n ; num_bytes = ((List.length rev_chunks - 1) * Chunk.length) + chunk_pos\n ; extra_bits\n ; initial_pos\n }\n ;;\n\n let long_shift t n =\n let n = ref (n - 5) in\n while !n > 0 do\n add_bits t (0b1100_0000 lor (!n land 0b0001_1111)) ~num_bits:8;\n n := !n lsr 5\n done\n ;;\n\n (* precondition: n >= 5 *)\n let[@inlined never] add_gen_slow t n ~instr ~instr_bits =\n long_shift t n;\n add_bits t instr ~num_bits:instr_bits\n ;;\n\n let shift4 = 0b10_10_10_10\n\n let[@inline always] add_gen t ~offset ~instr ~instr_bits =\n invariant t;\n let n = offset - t.offset in\n t.offset <- offset + 1;\n match n with\n | 0 | 1 | 2 | 3 | 4 ->\n let num_bits = (n lsl 1) + instr_bits in\n add_bits\n t\n ((shift4 lsl instr_bits) lor instr land ((1 lsl num_bits) - 1))\n ~num_bits\n | 5\n | 6\n | 7\n | 8\n | 9\n | 10\n | 11\n | 12\n | 13\n | 14\n | 15\n | 16\n | 17\n | 18\n | 19\n | 20\n | 21\n | 22\n | 23\n | 24\n | 25\n | 26\n | 27\n | 28\n | 29\n | 30\n | 31\n | 32\n | 33\n | 34\n | 35\n | 36 ->\n add_bits\n t\n (((0b1100_0000 lor (n - 5)) lsl instr_bits) lor instr)\n ~num_bits:(8 + instr_bits)\n | _ ->\n if n < 0 then invalid_arg \"Parsexp.Positions.add_gen\";\n add_gen_slow t n ~instr ~instr_bits\n ;;\n\n let add t ~offset = add_gen t ~offset ~instr:0b0 ~instr_bits:1\n let add_twice t ~offset = add_gen t ~offset ~instr:0b1111 ~instr_bits:4\n let add_newline t ~offset = add_gen t ~offset ~instr:0b1110 ~instr_bits:4\nend\n\ntype positions = t\n\nmodule Iterator : sig\n type t\n\n val create : positions -> t\n\n exception No_more\n\n (* [advance t ~skip] ignores [skip] saved positions and returns the next saved position.\n Raises [No_more] when reaching the end of the position set. *)\n val advance_exn : t -> skip:int -> pos\nend = struct\n type t =\n { mutable chunk : Chunk.t\n ; mutable chunks : Chunk.t list\n ; (* [num_bytes * 8 + extra_bits] is the number of bits available from [instr_pos] in\n [chunk :: chunks]. *)\n mutable num_bytes : int\n ; extra_bits : int\n ; mutable instr_pos : int (* position in [chunk] *)\n ; mutable offset : int\n ; mutable line : int\n ; mutable bol : int\n ; mutable int_buf : int\n ; mutable num_bits : int (* Number of bits not yet consumed in [int_buf] *)\n ; mutable pending : pos option\n }\n\n let create ((lazy p) : positions) =\n match p.chunks with\n | [] -> assert false\n | chunk :: chunks ->\n { chunk\n ; chunks\n ; num_bytes = p.num_bytes\n ; extra_bits = p.extra_bits\n ; instr_pos = 0\n ; offset = p.initial_pos.offset\n ; line = p.initial_pos.line\n ; bol = p.initial_pos.offset - p.initial_pos.col\n ; int_buf = 0\n ; num_bits = 0\n ; pending = None\n }\n ;;\n\n exception No_more\n\n let no_more () = raise_notrace No_more\n\n let[@inlined never] fetch_chunk t =\n match t.chunks with\n | [] -> assert false\n | chunk :: chunks ->\n t.instr_pos <- 0;\n t.num_bytes <- t.num_bytes - Chunk.length;\n t.chunk <- chunk;\n t.chunks <- chunks\n ;;\n\n let fetch t =\n if t.instr_pos > t.num_bytes then no_more ();\n if t.instr_pos = Chunk.length then fetch_chunk t;\n let v = Chunk.get16 t.chunk ~pos:t.instr_pos in\n let added_bits = if t.instr_pos = t.num_bytes then t.extra_bits else 16 in\n t.int_buf <- (t.int_buf lsl added_bits) lor (v land ((1 lsl added_bits) - 1));\n t.num_bits <- t.num_bits + added_bits;\n t.instr_pos <- t.instr_pos + 2\n ;;\n\n let next_instruction_bits t ~num_bits =\n if t.num_bits < num_bits\n then (\n fetch t;\n if t.num_bits < num_bits then no_more ());\n let n = (t.int_buf lsr (t.num_bits - num_bits)) land ((1 lsl num_bits) - 1) in\n t.num_bits <- t.num_bits - num_bits;\n n\n ;;\n\n (* [offset_shift] and [offset_shift_num_bits] encode the offset number\n specified by the immediately preceding [110] instructions. *)\n let rec advance t ~skip ~offset_shift ~offset_shift_num_bits =\n match next_instruction_bits t ~num_bits:1 with\n | 0 ->\n (* bit seq 0 -> new item *)\n let offset = t.offset + offset_shift in\n t.offset <- offset + 1;\n if skip = 0\n then { line = t.line; col = offset - t.bol; offset }\n else advance t ~skip:(skip - 1) ~offset_shift:0 ~offset_shift_num_bits:0\n | _ ->\n (match next_instruction_bits t ~num_bits:1 with\n | 0 ->\n (* bit seq 10 -> shift *)\n t.offset <- t.offset + offset_shift + 1;\n advance t ~skip ~offset_shift:0 ~offset_shift_num_bits:0\n | _ ->\n (match next_instruction_bits t ~num_bits:1 with\n | 0 ->\n (* bit seq 110 -> long shift *)\n let n = next_instruction_bits t ~num_bits:5 in\n let offset_shift = if offset_shift_num_bits = 0 then 5 else offset_shift in\n advance\n t\n ~skip\n ~offset_shift:(offset_shift + (n lsl offset_shift_num_bits))\n ~offset_shift_num_bits:(offset_shift_num_bits + 5)\n | _ ->\n (match next_instruction_bits t ~num_bits:1 with\n | 0 ->\n (* bit seq 1110 -> newline *)\n t.offset <- t.offset + offset_shift + 1;\n t.bol <- t.offset;\n t.line <- t.line + 1;\n advance t ~skip ~offset_shift:0 ~offset_shift_num_bits:0\n | _ ->\n (* bit seq 1111 -> 2 new items *)\n let offset = t.offset + offset_shift in\n t.offset <- offset + 1;\n if skip <= 1\n then (\n let pos = { line = t.line; col = offset - t.bol; offset } in\n if skip = 0 then t.pending <- Some pos;\n pos)\n else advance t ~skip:(skip - 2) ~offset_shift:0 ~offset_shift_num_bits:0)))\n ;;\n\n let advance_exn t ~skip =\n match t.pending with\n | Some pos ->\n t.pending <- None;\n if skip = 0\n then pos\n else advance t ~skip:(skip - 1) ~offset_shift:0 ~offset_shift_num_bits:0\n | None -> advance t ~skip ~offset_shift:0 ~offset_shift_num_bits:0\n ;;\nend\n\nlet find t a b =\n if a < 0 || b <= a then invalid_arg \"Parsexp.Positions.find\";\n let iter = Iterator.create t in\n try\n let start_pos = Iterator.advance_exn iter ~skip:a in\n let last_pos = Iterator.advance_exn iter ~skip:(b - a - 1) in\n make_range_incl ~start_pos ~last_pos\n with\n | Iterator.No_more -> failwith \"Parsexp.Position.find\"\n;;\n\nlet rec sub_sexp_count (sexp : Sexp.t) =\n match sexp with\n | Atom _ -> 1\n | List l -> List.fold_left l ~init:1 ~f:(fun acc x -> acc + sub_sexp_count x)\n;;\n\nmodule Sexp_search = struct\n exception Found of int\n\n let rec loop ~sub index (sexp : Sexp.t) =\n if sexp == sub\n then raise_notrace (Found index)\n else (\n match sexp with\n | Atom _ -> index + 2\n | List l ->\n let index = loop_list ~sub (index + 1) l in\n index + 1)\n\n and loop_list ~sub index (sexps : Sexp.t list) =\n List.fold_left sexps ~init:index ~f:(loop ~sub)\n ;;\n\n let finalize t ~sub a =\n let b = a + (sub_sexp_count sub * 2) - 1 in\n Some (find t a b)\n ;;\n\n let find_sub_sexp_phys t sexp ~sub =\n match loop ~sub 0 sexp with\n | (_ : int) -> None\n | exception Found n -> finalize t ~sub n\n ;;\n\n let find_sub_sexp_in_list_phys t sexps ~sub =\n match loop_list ~sub 0 sexps with\n | (_ : int) -> None\n | exception Found n -> finalize t ~sub n\n ;;\nend\n\nlet find_sub_sexp_phys = Sexp_search.find_sub_sexp_phys\nlet find_sub_sexp_in_list_phys = Sexp_search.find_sub_sexp_in_list_phys\n\nlet to_list t =\n let iter = Iterator.create t in\n let rec loop acc =\n match Iterator.advance_exn iter ~skip:0 with\n | exception Iterator.No_more -> List.rev acc\n | pos -> loop (pos :: acc)\n in\n loop []\n;;\n\nlet to_array t = to_list t |> Array.of_list\nlet compare t1 t2 = Caml.compare (to_array t1) (to_array t2)\nlet sexp_of_t t = sexp_of_array sexp_of_pos (to_array t)\n","open! Import\nmodule Binable = Binable0\n\n(* All the types as exposed in the mli are defined in this [Types] module. The rest of\n this file is simply overriding all the bin_io, compare, and sexp functions to raise\n exceptions. *)\nmodule Types = struct\n module Nobody = struct\n type t [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Nobody\"\n end\n\n module Me = struct\n type t [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Me\"\n end\n\n module Read = struct\n type t = [ `Read ] [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Read\"\n end\n\n module Write = struct\n type t = [ `Who_can_write of Me.t ] [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Write\"\n end\n\n module Immutable = struct\n type t =\n [ Read.t\n | `Who_can_write of Nobody.t\n ]\n [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Immutable\"\n end\n\n module Read_write = struct\n type t =\n [ Read.t\n | Write.t\n ]\n [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Read_write\"\n end\n\n module Upper_bound = struct\n type 'a t =\n [ Read.t\n | `Who_can_write of 'a\n ]\n [@@deriving bin_io, compare, hash, sexp]\n\n let name = \"Upper_bound\"\n end\nend\n\nlet failwithf = Printf.failwithf\n\n(* This is an explicit module type instead of just given inline as the return signature of\n [Only_used_as_phantom_type1] to avoid an unused value warning with bin_io values. *)\nmodule type Sexpable_binable_comparable = sig\n type 'a t = 'a [@@deriving bin_io, compare, hash, sexp]\nend\n\n(* Override all bin_io, sexp, compare functions to raise exceptions *)\nmodule Only_used_as_phantom_type1 (Name : sig\n val name : string\n end) : Sexpable_binable_comparable = struct\n type 'a t = 'a\n\n let sexp_of_t _ _ = failwithf \"Unexpectedly called [%s.sexp_of_t]\" Name.name ()\n let t_of_sexp _ _ = failwithf \"Unexpectedly called [%s.t_of_sexp]\" Name.name ()\n let compare _ _ _ = failwithf \"Unexpectedly called [%s.compare]\" Name.name ()\n let hash_fold_t _ _ _ = failwithf \"Unexpectedly called [%s.hash_fold_t]\" Name.name ()\n\n include Binable.Of_binable1_without_uuid [@alert \"-legacy\"]\n (struct\n type 'a t = 'a [@@deriving bin_io]\n end)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable _ =\n failwithf \"Unexpectedly used %s bin_io serialization\" Name.name ()\n ;;\n\n let of_binable _ =\n failwithf \"Unexpectedly used %s bin_io deserialization\" Name.name ()\n ;;\n end)\nend\n\nmodule Only_used_as_phantom_type0 (T : sig\n type t [@@deriving bin_io, compare, hash, sexp]\n\n val name : string\n end) : sig\n type t = T.t [@@deriving bin_io, compare, hash, sexp_poly]\nend = struct\n module M = Only_used_as_phantom_type1 (T)\n\n type t = T.t M.t [@@deriving bin_io, compare, hash, sexp]\n\n let __t_of_sexp__ = t_of_sexp\nend\n\nmodule Stable = struct\n module V1 = struct\n module Nobody = Only_used_as_phantom_type0 (Types.Nobody)\n module Me = Only_used_as_phantom_type0 (Types.Me)\n module Read = Only_used_as_phantom_type0 (Types.Read)\n module Write = Only_used_as_phantom_type0 (Types.Write)\n module Read_write = Only_used_as_phantom_type0 (Types.Read_write)\n module Immutable = Only_used_as_phantom_type0 (Types.Immutable)\n\n type nobody = Nobody.t [@@deriving bin_io, compare, hash, sexp]\n type me = Me.t [@@deriving bin_io, compare, hash, sexp]\n\n module Upper_bound = struct\n module M = Only_used_as_phantom_type1 (Types.Upper_bound)\n\n type 'a t = 'a Types.Upper_bound.t M.t [@@deriving bin_io, compare, hash, sexp]\n\n let __t_of_sexp__ = t_of_sexp\n end\n end\n\n module Export = struct\n type read = V1.Read.t [@@deriving bin_io, compare, hash, sexp]\n type write = V1.Write.t [@@deriving compare, hash, sexp]\n type immutable = V1.Immutable.t [@@deriving bin_io, compare, hash, sexp]\n type read_write = V1.Read_write.t [@@deriving bin_io, compare, hash, sexp]\n type 'a perms = 'a V1.Upper_bound.t [@@deriving bin_io, compare, hash, sexp]\n end\nend\n\ninclude Stable.V1\nmodule Export = Stable.Export\n","open! Import\nopen Quickcheck_intf\nopen Base_quickcheck\nmodule Array = Base.Array\nmodule Bool = Base.Bool\nmodule Char = Base.Char\nmodule Float = Base.Float\nmodule Int = Base.Int\nmodule List = Base.List\nmodule Option = Base.Option\nmodule Type_equal = Base.Type_equal\n\nmodule Polymorphic_types = struct\n type ('a, 'b) variant2 =\n [ `A of 'a\n | `B of 'b\n ]\n [@@deriving quickcheck]\n\n type ('a, 'b, 'c) variant3 =\n [ `A of 'a\n | `B of 'b\n | `C of 'c\n ]\n [@@deriving quickcheck]\n\n type ('a, 'b, 'c, 'd) variant4 =\n [ `A of 'a\n | `B of 'b\n | `C of 'c\n | `D of 'd\n ]\n [@@deriving quickcheck]\n\n type ('a, 'b, 'c, 'd, 'e) variant5 =\n [ `A of 'a\n | `B of 'b\n | `C of 'c\n | `D of 'd\n | `E of 'e\n ]\n [@@deriving quickcheck]\n\n type ('a, 'b, 'c, 'd, 'e, 'f) variant6 =\n [ `A of 'a\n | `B of 'b\n | `C of 'c\n | `D of 'd\n | `E of 'e\n | `F of 'f\n ]\n [@@deriving quickcheck]\n\n type ('a, 'b) tuple2 = 'a * 'b [@@deriving quickcheck]\n type ('a, 'b, 'c) tuple3 = 'a * 'b * 'c [@@deriving quickcheck]\n type ('a, 'b, 'c, 'd) tuple4 = 'a * 'b * 'c * 'd [@@deriving quickcheck]\n type ('a, 'b, 'c, 'd, 'e) tuple5 = 'a * 'b * 'c * 'd * 'e [@@deriving quickcheck]\n\n type ('a, 'b, 'c, 'd, 'e, 'f) tuple6 = 'a * 'b * 'c * 'd * 'e * 'f\n [@@deriving quickcheck]\n\n type (-'a, -'b, 'r) fn2 = 'a -> 'b -> 'r [@@deriving quickcheck]\n type (-'a, -'b, -'c, 'r) fn3 = 'a -> 'b -> 'c -> 'r [@@deriving quickcheck]\n type (-'a, -'b, -'c, -'d, 'r) fn4 = 'a -> 'b -> 'c -> 'd -> 'r [@@deriving quickcheck]\n\n type (-'a, -'b, -'c, -'d, -'e, 'r) fn5 = 'a -> 'b -> 'c -> 'd -> 'e -> 'r\n [@@deriving quickcheck]\n\n type (-'a, -'b, -'c, -'d, -'e, -'f, 'r) fn6 = 'a -> 'b -> 'c -> 'd -> 'e -> 'f -> 'r\n [@@deriving quickcheck]\nend\n\nmodule Observer = struct\n include Observer\n\n let of_hash (type a) (module M : Deriving_hash with type t = a) =\n of_hash_fold M.hash_fold_t\n ;;\n\n let variant2 = Polymorphic_types.quickcheck_observer_variant2\n let variant3 = Polymorphic_types.quickcheck_observer_variant3\n let variant4 = Polymorphic_types.quickcheck_observer_variant4\n let variant5 = Polymorphic_types.quickcheck_observer_variant5\n let variant6 = Polymorphic_types.quickcheck_observer_variant6\n let tuple2 = Polymorphic_types.quickcheck_observer_tuple2\n let tuple3 = Polymorphic_types.quickcheck_observer_tuple3\n let tuple4 = Polymorphic_types.quickcheck_observer_tuple4\n let tuple5 = Polymorphic_types.quickcheck_observer_tuple5\n let tuple6 = Polymorphic_types.quickcheck_observer_tuple6\n let of_predicate a b ~f = unmap (variant2 a b) ~f:(fun x -> if f x then `A x else `B x)\n let singleton () = opaque\n let doubleton f = of_predicate (singleton ()) (singleton ()) ~f\n let enum _ ~f = unmap int ~f\n\n let of_list list ~equal =\n let f x =\n match List.findi list ~f:(fun _ y -> equal x y) with\n | None -> failwith \"Quickcheck.Observer.of_list: value not found\"\n | Some (i, _) -> i\n in\n enum (List.length list) ~f\n ;;\n\n let of_fun f = create (fun x ~size ~hash -> observe (f ()) x ~size ~hash)\n\n let comparison ~compare ~eq ~lt ~gt =\n unmap\n (variant3 lt (singleton ()) gt)\n ~f:(fun x ->\n let c = compare x eq in\n if c < 0 then `A x else if c > 0 then `C x else `B x)\n ;;\nend\n\nmodule Generator = struct\n include Generator\n open Let_syntax\n\n let singleton = return\n\n let doubleton x y =\n create (fun ~size:_ ~random -> if Splittable_random.bool random then x else y)\n ;;\n\n let of_fun f = create (fun ~size ~random -> generate (f ()) ~size ~random)\n\n let of_sequence ~p seq =\n if Float.( <= ) p 0. || Float.( > ) p 1.\n then\n failwith (Printf.sprintf \"Generator.of_sequence: probability [%f] out of bounds\" p);\n Sequence.delayed_fold\n seq\n ~init:()\n ~finish:(fun () -> failwith \"Generator.of_sequence: ran out of values\")\n ~f:(fun () x ~k -> weighted_union [ p, singleton x; 1. -. p, of_fun k ])\n ;;\n\n let rec bounded_geometric ~p ~maximum init =\n if init = maximum\n then singleton maximum\n else\n weighted_union\n [ p, singleton init\n ; 1. -. p, of_fun (fun () -> bounded_geometric ~p ~maximum (init + 1))\n ]\n ;;\n\n let geometric ~p init = bounded_geometric ~p ~maximum:Int.max_value init\n let small_non_negative_int = small_positive_or_zero_int\n let small_positive_int = small_strictly_positive_int\n let list_with_length length t = list_with_length t ~length\n let variant2 = Polymorphic_types.quickcheck_generator_variant2\n let variant3 = Polymorphic_types.quickcheck_generator_variant3\n let variant4 = Polymorphic_types.quickcheck_generator_variant4\n let variant5 = Polymorphic_types.quickcheck_generator_variant5\n let variant6 = Polymorphic_types.quickcheck_generator_variant6\n let tuple2 = Polymorphic_types.quickcheck_generator_tuple2\n let tuple3 = Polymorphic_types.quickcheck_generator_tuple3\n let tuple4 = Polymorphic_types.quickcheck_generator_tuple4\n let tuple5 = Polymorphic_types.quickcheck_generator_tuple5\n let tuple6 = Polymorphic_types.quickcheck_generator_tuple6\n let fn2 = Polymorphic_types.quickcheck_generator_fn2\n let fn3 = Polymorphic_types.quickcheck_generator_fn3\n let fn4 = Polymorphic_types.quickcheck_generator_fn4\n let fn5 = Polymorphic_types.quickcheck_generator_fn5\n let fn6 = Polymorphic_types.quickcheck_generator_fn6\n\n let compare_fn dom =\n fn dom int >>| fun get_index x y -> [%compare: int] (get_index x) (get_index y)\n ;;\n\n let equal_fn dom = compare_fn dom >>| fun cmp x y -> Int.( = ) (cmp x y) 0\nend\n\nmodule Shrinker = struct\n include Shrinker\n\n let empty () = atomic\n let variant2 = Polymorphic_types.quickcheck_shrinker_variant2\n let variant3 = Polymorphic_types.quickcheck_shrinker_variant3\n let variant4 = Polymorphic_types.quickcheck_shrinker_variant4\n let variant5 = Polymorphic_types.quickcheck_shrinker_variant5\n let variant6 = Polymorphic_types.quickcheck_shrinker_variant6\n let tuple2 = Polymorphic_types.quickcheck_shrinker_tuple2\n let tuple3 = Polymorphic_types.quickcheck_shrinker_tuple3\n let tuple4 = Polymorphic_types.quickcheck_shrinker_tuple4\n let tuple5 = Polymorphic_types.quickcheck_shrinker_tuple5\n let tuple6 = Polymorphic_types.quickcheck_shrinker_tuple6\nend\n\nmodule Let_syntax = struct\n module Let_syntax = struct\n include Generator\n module Open_on_rhs = Generator\n end\n\n include Generator.Monad_infix\n\n let return = Generator.return\nend\n\nmodule Configure (Config : Quickcheck_config) = struct\n include Config\n\n let nondeterministic_state = lazy (Random.State.make_self_init ())\n\n let random_state_of_seed seed =\n match seed with\n | `Nondeterministic -> Splittable_random.State.create (force nondeterministic_state)\n | `Deterministic str -> Splittable_random.State.of_int ([%hash: string] str)\n ;;\n\n let make_seed seed : Test.Config.Seed.t =\n match seed with\n | `Nondeterministic -> Nondeterministic\n | `Deterministic string -> Deterministic string\n ;;\n\n let make_shrink_count = function\n | `Exhaustive -> Int.max_value\n | `Limit n -> n\n ;;\n\n let make_config ~seed ~sizes ~trials ~shrink_attempts : Test.Config.t =\n { seed = make_seed (Option.value seed ~default:default_seed)\n ; sizes = Option.value sizes ~default:default_sizes\n ; test_count = Option.value trials ~default:default_trial_count\n ; shrink_count =\n make_shrink_count (Option.value shrink_attempts ~default:default_shrink_attempts)\n }\n ;;\n\n let make_test_m (type a) ~gen ~shrinker ~sexp_of : (module Test.S with type t = a) =\n let module M = struct\n type t = a\n\n let quickcheck_generator = gen\n let quickcheck_shrinker = Option.value shrinker ~default:Shrinker.atomic\n let sexp_of_t = Option.value sexp_of ~default:[%sexp_of: _]\n end\n in\n (module M)\n ;;\n\n let random_value ?(seed = default_seed) ?(size = 30) gen =\n let random = random_state_of_seed seed in\n Generator.generate gen ~size ~random\n ;;\n\n let random_sequence ?seed ?sizes gen =\n let config =\n make_config ~seed ~sizes ~trials:(Some Int.max_value) ~shrink_attempts:None\n in\n let return = ref Sequence.empty in\n Test.with_sample_exn ~config gen ~f:(fun sequence -> return := sequence);\n !return\n ;;\n\n let iter ?seed ?sizes ?trials gen ~f =\n let config = make_config ~seed ~sizes ~trials ~shrink_attempts:None in\n Test.with_sample_exn ~config gen ~f:(fun sequence -> Sequence.iter sequence ~f)\n ;;\n\n let test ?seed ?sizes ?trials ?shrinker ?shrink_attempts ?sexp_of ?examples gen ~f =\n let config = make_config ~seed ~sizes ~trials ~shrink_attempts in\n let test_m = make_test_m ~gen ~shrinker ~sexp_of in\n Test.run_exn ~config ?examples ~f test_m\n ;;\n\n let test_or_error\n ?seed\n ?sizes\n ?trials\n ?shrinker\n ?shrink_attempts\n ?sexp_of\n ?examples\n gen\n ~f\n =\n let config = make_config ~seed ~sizes ~trials ~shrink_attempts in\n let test_m = make_test_m ~gen ~shrinker ~sexp_of in\n Test.run ~config ?examples ~f test_m\n ;;\n\n let test_distinct_values\n (type key)\n ?seed\n ?sizes\n ?sexp_of\n gen\n ~trials\n ~distinct_values\n ~compare\n =\n let module S =\n Caml.Set.Make (struct\n type t = key\n\n let compare = compare\n end)\n in\n let fail set =\n let expect_count = distinct_values in\n let actual_count = S.cardinal set in\n let values =\n match sexp_of with\n | None -> None\n | Some sexp_of_elt -> Some [%sexp (S.elements set : elt list)]\n in\n raise_s\n [%message\n \"insufficient distinct values\"\n (trials : int)\n (expect_count : int)\n (actual_count : int)\n (values : (Base.Sexp.t option[@sexp.option]))]\n in\n with_return (fun r ->\n let set = ref S.empty in\n iter ?seed ?sizes ~trials gen ~f:(fun elt ->\n set := S.add elt !set;\n if S.cardinal !set >= distinct_values then r.return ());\n fail !set)\n ;;\n\n let test_can_generate\n ?seed\n ?sizes\n ?(trials = default_can_generate_trial_count)\n ?sexp_of\n gen\n ~f\n =\n let r = ref [] in\n let f_and_enqueue return x = if f x then return `Can_generate else r := x :: !r in\n match\n With_return.with_return (fun return ->\n iter ?seed ?sizes ~trials gen ~f:(f_and_enqueue return.return);\n `Cannot_generate)\n with\n | `Can_generate -> ()\n | `Cannot_generate ->\n (match sexp_of with\n | None -> failwith \"cannot generate\"\n | Some sexp_of_value ->\n Error.raise_s [%message \"cannot generate\" ~attempts:(!r : value list)])\n ;;\nend\n\ninclude Configure (struct\n let default_seed = `Deterministic \"an arbitrary but deterministic string\"\n\n let default_trial_count =\n match Word_size.word_size with\n | W64 -> 10_000\n | W32 -> 1_000\n ;;\n\n let default_can_generate_trial_count = 10_000\n let default_shrink_attempts = `Limit 1000\n\n let default_sizes =\n Sequence.cycle_list_exn (List.range 0 30 ~stop:`inclusive)\n ;;\n end)\n\nmodule type S = S\nmodule type S1 = S1\nmodule type S2 = S2\nmodule type S_int = S_int\nmodule type S_range = S_range\n\ntype nonrec seed = seed\ntype nonrec shrink_attempts = shrink_attempts\n\nmodule type Quickcheck_config = Quickcheck_config\nmodule type Quickcheck_configured = Quickcheck_configured\n","(* We don't just include Sexplib.Std because one can only define Hashtbl once in this\n module. *)\n\nopen! Import\n\n(** [include]d first so that everything else shadows it *)\ninclude Core_pervasives\n\ninclude Int.Replace_polymorphic_compare\ninclude Base_quickcheck.Export\ninclude Deprecate_pipe_bang\ninclude Either.Export\ninclude From_sexplib\ninclude Interfaces\ninclude List.Infix\ninclude Never_returns\ninclude Ordering.Export\ninclude Perms.Export\ninclude Result.Export\n\ntype -'a return = 'a With_return.return = private { return : 'b. 'a -> 'b } [@@unboxed]\n\ninclude struct\n exception Bug of string [@deprecated \"[since 2020-03] Don't use [Bug]\"]\n [@@deriving sexp]\nend [@@alert \"-deprecated\"]\n\n\n(** Raised if malloc in C bindings fail (errno * size). *)\nexception C_malloc_exn of int * int\n\n(* errno, size *)\nlet () = Callback.register_exception \"C_malloc_exn\" (C_malloc_exn (0, 0))\n\nexception Finally = Exn.Finally\n\nlet fst3 (x, _, _) = x\nlet snd3 (_, y, _) = y\nlet trd3 (_, _, z) = z\n\nlet[@deprecated \"[since 2018-12] Use [Option.value_exn]\"] uw = function\n | Some x -> x\n | None ->\n raise Caml.Not_found\n;;\n\n(** [phys_same] is like [phys_equal], but with a more general type. [phys_same] is useful\n when dealing with existential types, when one has a packed value and an unpacked value\n that one wants to check are physically equal. One can't use [phys_equal] in such a\n situation because the types are different. *)\nlet phys_same (type a b) (a : a) (b : b) = phys_equal a (Obj.magic b : a)\n\nlet ( % ) = Int.( % )\nlet ( /% ) = Int.( /% )\nlet ( // ) = Int.( // )\nlet ( ==> ) a b = (not a) || b\nlet bprintf = Printf.bprintf\nlet const = Fn.const\nlet eprintf = Printf.eprintf\nlet error = Or_error.error\nlet error_s = Or_error.error_s\nlet failwithf = Base.Printf.failwithf\n\nlet failwithp =\n (Error.failwithp [@alert \"-deprecated\"])\n[@@deprecated \"[since 2020-03] Use [failwiths] instead.\"]\n;;\n\nlet failwiths = Error.failwiths\nlet force = Base.Lazy.force\nlet fprintf = Printf.fprintf\nlet ident = Fn.id\n\nlet invalid_argf = Base.Printf.invalid_argf\nlet ifprintf = Printf.ifprintf\nlet is_none = Option.is_none\nlet is_some = Option.is_some\nlet ksprintf = Printf.ksprintf\nlet ok_exn = Or_error.ok_exn\nlet phys_equal = Base.phys_equal\nlet phys_same = phys_same\nlet print_s = Stdio.print_s\nlet eprint_s = Stdio.eprint_s\nlet printf = Printf.printf\nlet protect = Exn.protect\nlet protectx = Exn.protectx\nlet raise_s = Error.raise_s\nlet round = Float.round\nlet ( **. ) = Base.( **. )\n\nlet sprintf = Printf.sprintf\nlet stage = Staged.stage\nlet unstage = Staged.unstage\nlet with_return = With_return.with_return\nlet with_return_option = With_return.with_return_option\n\n(* With the following aliases, we are just making extra sure that the toplevel sexp\n converters line up with the ones in our modules. *)\n\n\ninclude Typerep_lib.Std_internal\n\ninclude (\nstruct\n (* [deriving hash] is missing for [array], [bytes], and [ref] since these types are\n mutable. *)\n type 'a array = 'a Array.t\n [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n\n type bool = Bool.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type char = Char.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type float = Float.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type int = Int.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type int32 = Int32.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type int64 = Int64.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type 'a lazy_t = 'a Lazy.t\n [@@deriving bin_io, compare, hash, sexp, sexp_grammar, typerep]\n\n type 'a list = 'a List.t\n [@@deriving bin_io, compare, hash, equal, sexp, sexp_grammar, typerep]\n\n type nativeint = Nativeint.t\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type 'a option = 'a Option.t\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type string = String.t\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type bytes = Bytes.t [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n\n type 'a ref = 'a Ref.t\n [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n\n type unit = Unit.t\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n (* Bin_prot has optimized functions for float arrays *)\n type float_array = Bin_prot.Std.float_array [@@deriving bin_io]\n\n include (\n struct\n type float_array = Float.t array\n [@@deriving compare, sexp, sexp_grammar, typerep]\n end :\n sig\n type float_array [@@deriving compare, sexp, sexp_grammar, typerep]\n end\n with type float_array := float_array)\nend :\nsig\n type 'a array [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n type bool [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type char [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type float [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type int [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type int32 [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type int64 [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type 'a lazy_t [@@deriving bin_io, compare, hash, sexp, sexp_grammar, typerep]\n type 'a list [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type nativeint\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type 'a option\n [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type string [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n type bytes [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n type 'a ref [@@deriving bin_io, compare, equal, sexp, sexp_grammar, typerep]\n type unit [@@deriving bin_io, compare, equal, hash, sexp, sexp_grammar, typerep]\n\n type float_array = float array\n [@@deriving bin_io, compare, sexp, sexp_grammar, typerep]\nend\nwith type 'a array := 'a array\nwith type bool := bool\nwith type char := char\nwith type float := float\nwith type int := int\nwith type int32 := int32\nwith type int64 := int64\nwith type 'a list := 'a list\nwith type nativeint := nativeint\nwith type 'a option := 'a option\nwith type string := string\nwith type bytes := bytes\nwith type 'a lazy_t := 'a lazy_t\nwith type 'a ref := 'a ref\nwith type unit := unit)\n\nlet sexp_of_exn = Exn.sexp_of_t\n\n\n(* The below declarations define converters for the special types recognized by pa-sexp.\n E.g. this allows the following to work:\n\n type t = { foo : int sexp_option } [@@deriving bin_io, compare, hash, sexp] *)\ninclude struct\n [@@@ocaml.warning \"-3\"]\n\n type 'a sexp_array = 'a array\n [@@deriving bin_io, compare, typerep]\n [@@deprecated \"[since 2019-03] use [@sexp.array] instead\"]\n\n type sexp_bool = bool\n [@@deriving bin_io, compare, hash, typerep]\n [@@deprecated \"[since 2019-03] use [@sexp.bool] instead\"]\n\n type 'a sexp_list = 'a list\n [@@deriving bin_io, compare, hash, typerep]\n [@@deprecated \"[since 2019-03] use [@sexp.list] instead\"]\n\n type 'a sexp_option = 'a option\n [@@deriving bin_io, compare, hash, typerep]\n [@@deprecated \"[since 2019-03] use [@sexp.option] instead\"]\n\n type 'a sexp_opaque = 'a\n [@@deriving bin_io, compare, hash, typerep]\n [@@deprecated \"[since 2019-03] use [@sexp.opaque] instead\"]\nend\n\n(* The code below checks that the signatures in core_map.mli and core_set.mli are\n consistent with the generic map and set signatures defined in map_intf.ml\n and core_set_intf.ml. *)\n\nlet () =\n let module T = struct\n type 'a elt = 'a\n type 'a cmp = 'a\n end\n in\n let module M : sig\n open Set_intf\n\n module Tree : sig\n type ('a, 'b) t\n\n include\n Creators_and_accessors2_with_comparator\n with type ('a, 'b) set := ('a, 'b) t\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) t\n with type ('a, 'b) named := ('a, 'b) Tree.Named.t\n end\n\n type ('a, 'b) t\n\n include\n Accessors2\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type ('a, 'b) named := ('a, 'b) Named.t\n\n include\n Creators_generic\n with type ('a, 'b) set := ('a, 'b) t\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type 'a elt := 'a T.elt\n with type 'a cmp := 'a T.cmp\n with type ('a, 'cmp, 'z) options :=\n ('a, 'cmp, 'z) Set_intf.With_first_class_module.t\n end =\n Set\n in\n ()\n;;\n\nlet () =\n let module T = struct\n type 'k key = 'k\n type 'c cmp = 'c\n end\n in\n let module M : sig\n open Map_intf\n\n module Tree : sig\n type ('a, 'b, 'c) t\n\n include\n Creators_and_accessors3_with_comparator\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) t\n end\n\n type ('a, 'b, 'c) t\n\n include\n Accessors3\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n\n include\n Creators_generic\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n with type ('a, 'cmp, 'z) options :=\n ('a, 'cmp, 'z) Map_intf.With_first_class_module.t\n with type 'k key := 'k T.key\n with type 'c cmp := 'c T.cmp\n end =\n Map\n in\n ()\n;;\n\n","open! Import\nopen Std_internal\nopen! Int.Replace_polymorphic_compare\n\nmodule Stable = struct\n module V1 = struct\n module Parts = struct\n type t =\n { sign : Sign.t\n ; hr : int\n ; min : int\n ; sec : int\n ; ms : int\n ; us : int\n ; ns : int\n }\n [@@deriving compare, sexp]\n end\n\n module type Like_a_float = sig\n type t [@@deriving bin_io, hash, quickcheck, typerep]\n\n include Comparable.S_common with type t := t\n include Comparable.With_zero with type t := t\n include Floatable with type t := t\n\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val zero : t\n val robust_comparison_tolerance : t\n val abs : t -> t\n val neg : t -> t\n val scale : t -> float -> t\n end\n\n module T : sig\n type underlying = float [@@deriving hash]\n type t = private underlying [@@deriving bin_io, hash]\n\n include Like_a_float with type t := t\n include Robustly_comparable with type t := t\n\n module Constant : sig\n val nanoseconds_per_second : float\n val microseconds_per_second : float\n val milliseconds_per_second : float\n val nanosecond : t\n val microsecond : t\n val millisecond : t\n val second : t\n val minute : t\n val hour : t\n val day : t\n end\n\n val to_parts : t -> Parts.t\n val next : t -> t\n val prev : t -> t\n end = struct\n type underlying = float [@@deriving hash]\n type t = underlying [@@deriving hash]\n\n let next t = Float.one_ulp `Up t\n let prev t = Float.one_ulp `Down t\n\n (* IF THIS REPRESENTATION EVER CHANGES, ENSURE THAT EITHER\n (1) all values serialize the same way in both representations, or\n (2) you add a new Time.Span version to stable.ml *)\n include (\n struct\n include Float\n\n let sign = sign_exn\n end :\n Like_a_float with type t := t)\n\n (* due to precision limitations in float we can't expect better than microsecond\n precision *)\n include Float.Robust_compare.Make (struct\n let robust_comparison_tolerance = 1E-6\n end)\n\n (* this prevents any worry about having these very common names redefined below and\n makes their usage within this module safer. Constant is included at the very\n bottom to re-export these constants in a more convenient way *)\n module Constant = struct\n let nanoseconds_per_second = 1E9\n let microseconds_per_second = 1E6\n let milliseconds_per_second = 1E3\n\n (* spans are stored as a float in seconds *)\n let nanosecond = of_float (1. /. nanoseconds_per_second)\n let microsecond = of_float (1. /. microseconds_per_second)\n let millisecond = of_float (1. /. milliseconds_per_second)\n let second = of_float 1.\n let minute = of_float 60.\n let hour = of_float (60. *. 60.)\n let day = of_float (24. *. 60. *. 60.)\n end\n\n\n let to_parts t : Parts.t =\n let sign = Float.sign_exn t in\n let t = abs t in\n let integral = Float.round_down t in\n let fractional = t -. integral in\n let seconds = Float.iround_down_exn integral in\n let nanoseconds = Float.iround_nearest_exn (fractional *. 1E9) in\n let seconds, nanoseconds =\n if Int.equal nanoseconds 1_000_000_000\n then Int.succ seconds, 0\n else seconds, nanoseconds\n in\n let sec = seconds mod 60 in\n let minutes = seconds / 60 in\n let min = minutes mod 60 in\n let hr = minutes / 60 in\n let ns = nanoseconds mod 1000 in\n let microseconds = nanoseconds / 1000 in\n let us = microseconds mod 1000 in\n let milliseconds = microseconds / 1000 in\n let ms = milliseconds in\n { sign; hr; min; sec; ms; us; ns }\n ;;\n end\n\n let ( / ) t f = T.of_float ((t : T.t :> float) /. f)\n let ( // ) (f : T.t) (t : T.t) = (f :> float) /. (t :> float)\n\n (* Multiplying by 1E3 is more accurate than division by 1E-3 *)\n let to_ns (x : T.t) = (x :> float) *. T.Constant.nanoseconds_per_second\n let to_us (x : T.t) = (x :> float) *. T.Constant.microseconds_per_second\n let to_ms (x : T.t) = (x :> float) *. T.Constant.milliseconds_per_second\n let to_sec (x : T.t) = (x :> float)\n let to_min x = x // T.Constant.minute\n let to_hr x = x // T.Constant.hour\n let to_day x = x // T.Constant.day\n let to_int63_seconds_round_down_exn x = Float.int63_round_down_exn (to_sec x)\n let ( ** ) f (t : T.t) = T.of_float (f *. (t :> float))\n\n (* Division by 1E3 is more accurate than multiplying by 1E-3 *)\n let of_ns x = T.of_float (x /. T.Constant.nanoseconds_per_second)\n let of_us x = T.of_float (x /. T.Constant.microseconds_per_second)\n let of_ms x = T.of_float (x /. T.Constant.milliseconds_per_second)\n let of_sec x = T.of_float x\n let of_int_sec x = of_sec (Float.of_int x)\n let of_int32_seconds sec = of_sec (Int32.to_float sec)\n\n (* Note that [Int63.to_float] can lose precision, but only on inputs large enough that\n [of_sec] in either the Time_ns or Time_float case would lose precision (or just be\n plain out of bounds) anyway. *)\n let of_int63_seconds sec = of_sec (Int63.to_float sec)\n let of_min x = x ** T.Constant.minute\n let of_hr x = x ** T.Constant.hour\n let of_day x = x ** T.Constant.day\n\n let divide_by_unit_of_time t unit_of_time =\n match (unit_of_time : Unit_of_time.t) with\n | Nanosecond -> to_ns t\n | Microsecond -> to_us t\n | Millisecond -> to_ms t\n | Second -> to_sec t\n | Minute -> to_min t\n | Hour -> to_hr t\n | Day -> to_day t\n ;;\n\n let scale_by_unit_of_time float unit_of_time =\n match (unit_of_time : Unit_of_time.t) with\n | Nanosecond -> of_ns float\n | Microsecond -> of_us float\n | Millisecond -> of_ms float\n | Second -> of_sec float\n | Minute -> of_min float\n | Hour -> of_hr float\n | Day -> of_day float\n ;;\n\n let create\n ?(sign = Sign.Pos)\n ?(day = 0)\n ?(hr = 0)\n ?(min = 0)\n ?(sec = 0)\n ?(ms = 0)\n ?(us = 0)\n ?(ns = 0)\n ()\n =\n let ( + ) = T.( + ) in\n let t =\n of_day (Float.of_int day)\n + of_hr (Float.of_int hr)\n + of_min (Float.of_int min)\n + of_sec (Float.of_int sec)\n + of_ms (Float.of_int ms)\n + of_us (Float.of_int us)\n + of_ns (Float.of_int ns)\n in\n match sign with\n | Neg -> T.( - ) T.zero t\n | Pos | Zero -> t\n ;;\n\n include T\n include Constant\n\n let randomize t ~percent = Span_helpers.randomize t ~percent ~scale\n\n let to_short_string t =\n let ({ sign; hr; min; sec; ms; us; ns } : Parts.t) = to_parts t in\n Span_helpers.short_string ~sign ~hr ~min ~sec ~ms ~us ~ns\n ;;\n\n (* WARNING: if you are going to change this function in any material way, make sure\n you update Stable appropriately. *)\n let of_string_v1_v2 (s : string) ~is_v2 =\n try\n match s with\n | \"\" -> failwith \"empty string\"\n | _ ->\n let float n =\n match String.drop_suffix s n with\n | \"\" -> failwith \"no number given\"\n | s ->\n let v = Float.of_string s in\n Validate.maybe_raise (Float.validate_ordinary v);\n v\n in\n let len = String.length s in\n (match s.[Int.( - ) len 1] with\n | 's' ->\n if Int.( >= ) len 2 && Char.( = ) s.[Int.( - ) len 2] 'm'\n then of_ms (float 2)\n else if is_v2 && Int.( >= ) len 2 && Char.( = ) s.[Int.( - ) len 2] 'u'\n then of_us (float 2)\n else if is_v2 && Int.( >= ) len 2 && Char.( = ) s.[Int.( - ) len 2] 'n'\n then of_ns (float 2)\n else T.of_float (float 1)\n | 'm' -> of_min (float 1)\n | 'h' -> of_hr (float 1)\n | 'd' -> of_day (float 1)\n | _ ->\n if is_v2\n then failwith \"Time spans must end in ns, us, ms, s, m, h, or d.\"\n else failwith \"Time spans must end in ms, s, m, h, or d.\")\n with\n | exn ->\n invalid_argf \"Span.of_string could not parse '%s': %s\" s (Exn.to_string exn) ()\n ;;\n\n let of_sexp_error_exn exn sexp = of_sexp_error (Exn.to_string exn) sexp\n\n exception T_of_sexp of Sexp.t * exn [@@deriving sexp]\n exception T_of_sexp_expected_atom_but_got of Sexp.t [@@deriving sexp]\n\n let t_of_sexp_v1_v2 sexp ~is_v2 =\n match sexp with\n | Sexp.Atom x ->\n (try of_string_v1_v2 x ~is_v2 with\n | exn -> of_sexp_error_exn (T_of_sexp (sexp, exn)) sexp)\n | Sexp.List _ -> of_sexp_error_exn (T_of_sexp_expected_atom_but_got sexp) sexp\n ;;\n\n let string ~is_v2 suffix float =\n if is_v2\n (* This is the same float-to-string conversion used in [Float.sexp_of_t]. It's like\n [Float.to_string], but may leave off trailing period. *)\n then !Sexplib.Conv.default_string_of_float float ^ suffix\n else sprintf \"%g%s\" float suffix\n ;;\n\n (* WARNING: if you are going to change this function in any material way, make sure\n you update Stable appropriately. *)\n (* I'd like it to be the case that you could never construct an infinite span, but I\n can't think of a good way to enforce it. So this to_string function can produce\n strings that will raise an exception when they are fed to of_string *)\n let to_string_v1_v2 (t : T.t) ~is_v2 =\n (* this is a sad broken abstraction... *)\n let module C = Float.Class in\n match Float.classify (t :> float) with\n | C.Subnormal | C.Zero -> \"0s\"\n | C.Infinite -> if T.( > ) t T.zero then \"inf\" else \"-inf\"\n | C.Nan -> \"nan\"\n | C.Normal ->\n let ( < ) = T.( < ) in\n let abs_t = T.of_float (Float.abs (t :> float)) in\n if is_v2 && abs_t < T.Constant.microsecond\n then string ~is_v2 \"ns\" (to_ns t)\n else if is_v2 && abs_t < T.Constant.millisecond\n then string ~is_v2 \"us\" (to_us t)\n else if abs_t < T.Constant.second\n then string ~is_v2 \"ms\" (to_ms t)\n else if abs_t < T.Constant.minute\n then string ~is_v2 \"s\" (to_sec t)\n else if abs_t < T.Constant.hour\n then string ~is_v2 \"m\" (to_min t)\n else if abs_t < T.Constant.day\n then string ~is_v2 \"h\" (to_hr t)\n else string ~is_v2 \"d\" (to_day t)\n ;;\n\n let sexp_of_t_v1_v2 t ~is_v2 = Sexp.Atom (to_string_v1_v2 t ~is_v2)\n let t_of_sexp sexp = t_of_sexp_v1_v2 sexp ~is_v2:false\n let sexp_of_t t = sexp_of_t_v1_v2 t ~is_v2:false\n end\n\n module V2 = struct\n include V1\n\n let t_of_sexp sexp = t_of_sexp_v1_v2 sexp ~is_v2:true\n let sexp_of_t t = sexp_of_t_v1_v2 t ~is_v2:true\n end\n\n module V3 = struct\n include V1\n\n let to_unit_of_time t : Unit_of_time.t =\n let open T in\n let open Constant in\n let abs_t = T.abs t in\n if abs_t >= day\n then Day\n else if abs_t >= hour\n then Hour\n else if abs_t >= minute\n then Minute\n else if abs_t >= second\n then Second\n else if abs_t >= millisecond\n then Millisecond\n else if abs_t >= microsecond\n then Microsecond\n else Nanosecond\n ;;\n\n let of_unit_of_time : Unit_of_time.t -> T.t =\n let open T.Constant in\n function\n | Nanosecond -> nanosecond\n | Microsecond -> microsecond\n | Millisecond -> millisecond\n | Second -> second\n | Minute -> minute\n | Hour -> hour\n | Day -> day\n ;;\n\n let suffix_of_unit_of_time unit_of_time =\n match (unit_of_time : Unit_of_time.t) with\n | Nanosecond -> \"ns\"\n | Microsecond -> \"us\"\n | Millisecond -> \"ms\"\n | Second -> \"s\"\n | Minute -> \"m\"\n | Hour -> \"h\"\n | Day -> \"d\"\n ;;\n\n module Of_string = struct\n let invalid_string string ~reason =\n let message = \"Time.Span.of_string: \" ^ reason in\n raise_s [%message message string]\n ;;\n\n let rec find_unit_of_time_by_suffix string ~index unit_of_time_list =\n match unit_of_time_list with\n | [] -> invalid_string string ~reason:\"invalid span part suffix\"\n | unit_of_time :: rest ->\n let suffix = suffix_of_unit_of_time unit_of_time in\n if String.is_substring_at string ~pos:index ~substring:suffix\n then unit_of_time\n else find_unit_of_time_by_suffix string ~index rest\n ;;\n\n let parse_suffix string ~index =\n (* We rely on the fact that \"ms\" comes before \"m\" in [Unit_of_time.all] to get a\n correct match on millisecond timestamps. This assumption is demonstrated in the\n expect test below. *)\n find_unit_of_time_by_suffix string ~index Unit_of_time.all\n ;;\n\n (* We validate magnitude strings so that we know where the unit-of-time suffix\n begins, and so that only sensible strings are allowed. We do not want to be as\n permissive as [Float.of_string]; for example, hexadecimal span magnitudes are not\n allowed. After validation, we still use [Float.of_string] to produce the actual\n value. *)\n module Float_parser = struct\n (* [In_decimal_have_digit] includes having a digit before the decimal point. *)\n type state =\n | In_integer_need_digit\n | In_integer_have_digit\n | In_decimal_need_digit\n | In_decimal_have_digit\n | In_exponent_need_digit_or_sign\n | In_exponent_need_digit\n | In_exponent_have_digit\n\n type token =\n | Digit\n | Point\n | Under\n | Sign\n | Expt\n\n let state_is_final = function\n | In_integer_have_digit | In_decimal_have_digit | In_exponent_have_digit ->\n true\n | In_integer_need_digit\n | In_decimal_need_digit\n | In_exponent_need_digit_or_sign\n | In_exponent_need_digit -> false\n ;;\n\n let token_of_char = function\n | '0' .. '9' -> Some Digit\n | '.' -> Some Point\n | '_' -> Some Under\n | '-' | '+' -> Some Sign\n | 'E' | 'e' -> Some Expt\n | _ -> None\n ;;\n\n let invalid_string string =\n invalid_string string ~reason:\"invalid span part magnitude\"\n ;;\n\n let rec find_index_after_float_in_state string ~index ~len ~state =\n let open Int.O in\n if index = len\n then if state_is_final state then index else invalid_string string\n else (\n match token_of_char string.[index] with\n | None -> if state_is_final state then index else invalid_string string\n | Some token ->\n let state =\n match state, token with\n | In_integer_need_digit, Digit -> In_integer_have_digit\n | In_integer_need_digit, Point -> In_decimal_need_digit\n | In_integer_need_digit, Under\n | In_integer_need_digit, Sign\n | In_integer_need_digit, Expt -> invalid_string string\n | In_integer_have_digit, Digit | In_integer_have_digit, Under ->\n In_integer_have_digit\n | In_integer_have_digit, Point -> In_decimal_have_digit\n | In_integer_have_digit, Expt -> In_exponent_need_digit_or_sign\n | In_integer_have_digit, Sign -> invalid_string string\n | In_decimal_need_digit, Digit -> In_decimal_have_digit\n | In_decimal_need_digit, Point\n | In_decimal_need_digit, Under\n | In_decimal_need_digit, Expt\n | In_decimal_need_digit, Sign -> invalid_string string\n | In_decimal_have_digit, Digit | In_decimal_have_digit, Under ->\n In_decimal_have_digit\n | In_decimal_have_digit, Expt -> In_exponent_need_digit_or_sign\n | In_decimal_have_digit, Point | In_decimal_have_digit, Sign ->\n invalid_string string\n | In_exponent_need_digit_or_sign, Digit -> In_exponent_have_digit\n | In_exponent_need_digit_or_sign, Sign -> In_exponent_need_digit\n | In_exponent_need_digit_or_sign, Point\n | In_exponent_need_digit_or_sign, Under\n | In_exponent_need_digit_or_sign, Expt -> invalid_string string\n | In_exponent_need_digit, Digit -> In_exponent_have_digit\n | In_exponent_need_digit, Point\n | In_exponent_need_digit, Under\n | In_exponent_need_digit, Expt\n | In_exponent_need_digit, Sign -> invalid_string string\n | In_exponent_have_digit, Digit | In_exponent_have_digit, Under ->\n In_exponent_have_digit\n | In_exponent_have_digit, Point\n | In_exponent_have_digit, Expt\n | In_exponent_have_digit, Sign -> invalid_string string\n in\n find_index_after_float_in_state string ~index:(index + 1) ~len ~state)\n ;;\n\n let find_index_after_float string ~index ~len =\n find_index_after_float_in_state string ~index ~len ~state:In_integer_need_digit\n ;;\n end\n\n let rec accumulate_magnitude string ~magnitude ~index ~len =\n if Int.equal index len\n then magnitude\n else (\n let suffix_index = Float_parser.find_index_after_float string ~index ~len in\n let unit_of_time = parse_suffix string ~index:suffix_index in\n let until_index =\n Int.( + ) suffix_index (String.length (suffix_of_unit_of_time unit_of_time))\n in\n let float_string =\n String.sub string ~pos:index ~len:(Int.( - ) suffix_index index)\n in\n let float = Float.of_string float_string in\n let magnitude = magnitude + scale_by_unit_of_time float unit_of_time in\n accumulate_magnitude string ~magnitude ~index:until_index ~len)\n ;;\n\n let parse_magnitude string ~index ~len =\n accumulate_magnitude string ~magnitude:T.zero ~index ~len\n ;;\n\n let of_string string =\n let open Int.O in\n match string with\n | \"NANs\" -> of_sec Float.nan\n | \"-INFs\" -> of_sec Float.neg_infinity\n | \"INFs\" -> of_sec Float.infinity\n | _ ->\n let len = String.length string in\n if len = 0 then invalid_string string ~reason:\"empty input\";\n let negative, index =\n match string.[0] with\n | '-' -> true, 1\n | '+' -> false, 1\n | _ -> false, 0\n in\n if index >= len then invalid_string string ~reason:\"empty input\";\n let magnitude = parse_magnitude string ~index ~len in\n if negative then T.neg magnitude else magnitude\n ;;\n end\n\n let of_string = Of_string.of_string\n\n module To_string = struct\n let string_of_float_without_trailing_decimal float =\n let string = Float.to_string float in\n let suffix = \".\" in\n if String.is_suffix string ~suffix\n then String.chop_suffix_exn string ~suffix\n else string\n ;;\n\n (* As we build up a string, we keep a running sum of the value that will be read\n back in, so that we can compute the remainder that needs to be generated. *)\n let sum ~sum_t ~unit_of_time ~magnitude =\n sum_t + scale_by_unit_of_time magnitude unit_of_time\n ;;\n\n (* For some units (very large numbers of days, or seconds and smaller) we just\n render a float directly, with a fix for roundoff error. *)\n let to_float_string ~abs_t ~unit_of_time ~fixup_unit_of_time =\n let magnitude = divide_by_unit_of_time abs_t unit_of_time in\n let sum_t = sum ~sum_t:zero ~unit_of_time ~magnitude in\n if sum_t = abs_t\n then\n string_of_float_without_trailing_decimal magnitude\n ^ suffix_of_unit_of_time unit_of_time\n else (\n let magnitude =\n if sum_t < abs_t\n then magnitude\n else divide_by_unit_of_time (prev abs_t) unit_of_time\n in\n let sum_t = sum ~sum_t:zero ~unit_of_time ~magnitude in\n let rem_t = abs_t - sum_t in\n let fixup_magnitude = divide_by_unit_of_time rem_t fixup_unit_of_time in\n string_of_float_without_trailing_decimal magnitude\n ^ suffix_of_unit_of_time unit_of_time\n (* [rem_t] is at ULP size of [abs_t], it needs just one bit of precision *)\n ^ sprintf \"%.1g\" fixup_magnitude\n ^ suffix_of_unit_of_time fixup_unit_of_time)\n ;;\n\n (* For non-decimal units (minutes and greater), we render an integer magnitude, and\n return that with the running sum so the remainder can be rendered at a smaller\n unit. *)\n let to_int_string_and_sum unit_of_time ~abs_t ~sum_t =\n let unit_span = of_unit_of_time unit_of_time in\n let rem_t = abs_t - sum_t in\n (* We calculate the approximate multiple of [unit_of_time] that needs to be\n added to [sum_t]. Due to rounding, this can be off by one (we've never seen a\n case off by two or more), so we re-compute the remainder and correct if\n necessary. *)\n let magnitude = Float.round_down (rem_t // unit_span) in\n let new_sum_t = sum ~sum_t ~unit_of_time ~magnitude in\n let new_rem_t = abs_t - new_sum_t in\n let magnitude =\n if new_rem_t = zero\n then magnitude\n else if new_rem_t < zero\n then magnitude -. 1.\n else (\n let next_magnitude = magnitude +. 1. in\n let next_sum_t = sum ~sum_t ~unit_of_time ~magnitude:next_magnitude in\n let next_rem_t = abs_t - next_sum_t in\n if next_rem_t < zero then magnitude else next_magnitude)\n in\n if Float.( <= ) magnitude 0.\n then \"\", sum_t\n else (\n let new_sum_t = sum ~sum_t ~unit_of_time ~magnitude in\n let string =\n Int63.to_string (Int63.of_float magnitude)\n ^ suffix_of_unit_of_time unit_of_time\n in\n string, new_sum_t)\n ;;\n\n let decimal_order_of_magnitude t = Float.log10 (to_sec t)\n\n (* The final seconds-or-smaller unit needs to be printed with enough digits to\n round-trip the whole span (which is minutes or greater); this can be\n significantly fewer digits than would be needed for the seconds-or-smaller\n remainder itself. *)\n let to_float_string_after_int_strings ~sum_t ~abs_t =\n if sum_t >= abs_t\n then \"\"\n else (\n let rem_t = abs_t - sum_t in\n let unit_of_time = to_unit_of_time rem_t in\n let unit_span = of_unit_of_time unit_of_time in\n let magnitude = rem_t // unit_span in\n let new_sum_t = sum ~sum_t ~unit_of_time ~magnitude in\n let new_rem_t = abs_t - new_sum_t in\n if abs rem_t <= abs new_rem_t\n then \"\"\n else (\n let order_of_magnitude_of_first_digit =\n Float.iround_down_exn (decimal_order_of_magnitude rem_t)\n in\n let half_ulp = (abs_t - prev abs_t) / 2. in\n let order_of_magnitude_of_final_digit =\n (* This works out to rounding down, except in the case of exact integers,\n which are decremented. This makes sure we always stop at a digit with\n strictly more precision than half the ULP. *)\n Int.pred (Float.iround_up_exn (decimal_order_of_magnitude half_ulp))\n in\n let number_of_digits =\n let open Int.O in\n 1 + order_of_magnitude_of_first_digit - order_of_magnitude_of_final_digit\n in\n let suffix = suffix_of_unit_of_time unit_of_time in\n sprintf \"%.*g\" number_of_digits magnitude ^ suffix))\n ;;\n\n (* This helper avoids unnecessary allocation, because for our use below, it is\n common to have either or both arguments be empty. Currently (2018-02), the\n built-in [^] allocates even when appending to an empty string. *)\n let ( ^? ) x y =\n if String.is_empty x then y else if String.is_empty y then x else x ^ y\n ;;\n\n let to_string t =\n let float = to_float t in\n if not (Float.is_finite float)\n then\n if (* We print specific special strings for non-finite floats *)\n Float.is_nan float\n then \"NANs\"\n else if Float.is_negative float\n then \"-INFs\"\n else \"INFs\"\n else if t = zero\n then \"0s\"\n else (\n let unit_of_time = to_unit_of_time t in\n let abs_t = abs t in\n let sign = if t < zero then \"-\" else \"\" in\n let magnitude_string =\n match unit_of_time with\n (* We can use normal float notation for seconds and sub-second units, they are\n readable with a decimal point. *)\n | Nanosecond | Microsecond | Millisecond | Second ->\n to_float_string ~abs_t ~unit_of_time ~fixup_unit_of_time:Nanosecond\n (* For large enough values that the ULP is a day or more, we can use float\n notation because we are expressing a single, very large integer. *)\n | Day when next abs_t - abs_t >= day ->\n to_float_string ~abs_t ~unit_of_time ~fixup_unit_of_time:Day\n (* For everything in between, we need to use integer units of days, hours,\n and/or minutes, because those units are not readable as decimals, and we\n tack on a decimal remainder of a seconds-or-smaller unit if necessary. *)\n | Minute | Hour | Day ->\n let sum_t = zero in\n let day_string, sum_t = to_int_string_and_sum ~abs_t ~sum_t Day in\n let hour_string, sum_t = to_int_string_and_sum ~abs_t ~sum_t Hour in\n let minute_string, sum_t = to_int_string_and_sum ~abs_t ~sum_t Minute in\n let float_string = to_float_string_after_int_strings ~abs_t ~sum_t in\n day_string ^? hour_string ^? minute_string ^? float_string\n in\n sign ^? magnitude_string)\n ;;\n end\n\n let to_string = To_string.to_string\n let sexp_of_t t = Sexp.Atom (to_string t)\n\n let t_of_sexp s =\n match s with\n | Sexp.Atom x ->\n (try of_string x with\n | exn -> of_sexp_error (Exn.to_string exn) s)\n | Sexp.List _ ->\n of_sexp_error \"Time.Span.Stable.V3.t_of_sexp: sexp must be an Atom\" s\n ;;\n end\nend\n\ninclude Stable.V3\n\nlet to_proportional_float = to_float\n\nlet to_string_hum\n ?(delimiter = '_')\n ?(decimals = 3)\n ?(align_decimal = false)\n ?unit_of_time\n t\n =\n let float, suffix =\n match Option.value unit_of_time ~default:(to_unit_of_time t) with\n | Day -> to_day t, \"d\"\n | Hour -> to_hr t, \"h\"\n | Minute -> to_min t, \"m\"\n | Second -> to_sec t, \"s\"\n | Millisecond -> to_ms t, \"ms\"\n | Microsecond -> to_us t, \"us\"\n | Nanosecond -> to_ns t, \"ns\"\n in\n let prefix =\n Float.to_string_hum float ~delimiter ~decimals ~strip_zero:(not align_decimal)\n in\n let suffix =\n if align_decimal && Int.( = ) (String.length suffix) 1 then suffix ^ \" \" else suffix\n in\n prefix ^ suffix\n;;\n\nlet gen_incl lo hi =\n Float.gen_incl (to_sec lo) (to_sec hi) |> Quickcheck.Generator.map ~f:of_sec\n;;\n\nlet gen_uniform_incl lo hi =\n (* Technically exclusive rather than inclusive, but otherwise satisfies the contract to\n within 1ulp of the given bounds. *)\n Float.gen_uniform_excl (to_sec lo) (to_sec hi) |> Quickcheck.Generator.map ~f:of_sec\n;;\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Core_kernel.Time.Span\"\n end)\n\ninclude Hashable.Make_binable (struct\n type nonrec t = t [@@deriving bin_io, compare, hash, sexp_of]\n\n (* Previous versions rendered hash-based containers using float serialization rather\n than time serialization, so when reading hash-based containers in we accept either\n serialization. *)\n let t_of_sexp sexp =\n match Float.t_of_sexp sexp with\n | float -> of_float float\n | exception _ -> t_of_sexp sexp\n ;;\n end)\n\nmodule C = struct\n type t = T.t [@@deriving bin_io]\n type comparator_witness = T.comparator_witness\n\n let comparator = T.comparator\n\n (* In 108.06a and earlier, spans in sexps of Maps and Sets were raw floats. From 108.07\n through 109.13, the output format remained raw as before, but both the raw and pretty\n format were accepted as input. From 109.14 on, the output format was changed from\n raw to pretty, while continuing to accept both formats. Once we believe most\n programs are beyond 109.14, we will switch the input format to no longer accept\n raw. *)\n let sexp_of_t = sexp_of_t\n\n let t_of_sexp sexp =\n match Option.try_with (fun () -> T.of_float (Float.t_of_sexp sexp)) with\n | Some t -> t\n | None -> t_of_sexp sexp\n ;;\nend\n\nmodule Map = Map.Make_binable_using_comparator (C)\nmodule Set = Set.Make_binable_using_comparator (C)\n\nmodule Private = struct\n let suffix_of_unit_of_time = suffix_of_unit_of_time\n let parse_suffix = Stable.V3.Of_string.parse_suffix\nend\n","open! Import\n\nmodule type T = sig\n type t\nend\n\nmodule Make (T1 : T) (T2 : T) = struct\n type t = T1.t * T2.t\nend\n\nmodule T2 = struct\n type ('a, 'b) t = 'a * 'b [@@deriving sexp, typerep]\n\n let create a b = a, b\n\n let curry f =\n ();\n fun a b -> f (a, b)\n ;;\n\n let uncurry f =\n ();\n fun (a, b) -> f a b\n ;;\n\n external get1 : ('a, _) t -> 'a = \"%field0\"\n external get2 : (_, 'a) t -> 'a = \"%field1\"\n\n let map1 ~f (x, y) = f x, y\n let map2 ~f (x, y) = x, f y\n let map (x, y) ~f = f x, f y\n let map_fst (x, y) ~f = f x, y\n let map_snd (x, y) ~f = x, f y\n\n let compare ~cmp1 ~cmp2 (x, y) (x', y') =\n match cmp1 x x' with\n | 0 -> cmp2 y y'\n | i -> i\n ;;\n\n let equal ~eq1 ~eq2 (x, y) (x', y') = eq1 x x' && eq2 y y'\n let swap (a, b) = b, a\n\n include Comparator.Derived2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t [@@deriving sexp_of]\n\n let compare cmp1 cmp2 = compare ~cmp1 ~cmp2\n end)\nend\n\nmodule T3 = struct\n type ('a, 'b, 'c) t = 'a * 'b * 'c [@@deriving sexp, typerep]\n\n let create a b c = a, b, c\n\n let curry f =\n ();\n fun a b c -> f (a, b, c)\n ;;\n\n let uncurry f =\n ();\n fun (a, b, c) -> f a b c\n ;;\n\n let map1 ~f (x, y, z) = f x, y, z\n let map2 ~f (x, y, z) = x, f y, z\n let map3 ~f (x, y, z) = x, y, f z\n let map (x, y, z) ~f = f x, f y, f z\n let map_fst (x, y, z) ~f = f x, y, z\n let map_snd (x, y, z) ~f = x, f y, z\n let map_trd (x, y, z) ~f = x, y, f z\n\n external get1 : ('a, _, _) t -> 'a = \"%field0\"\n external get2 : (_, 'a, _) t -> 'a = \"%field1\"\n\n (* There's no %field2....*)\n let get3 (_, _, a) = a\n\n (* lexicographic comparison *)\n let compare ~cmp1 ~cmp2 ~cmp3 (x, y, z) (x', y', z') =\n let c1 = cmp1 x x' in\n if c1 <> 0\n then c1\n else (\n let c2 = cmp2 y y' in\n if c2 <> 0 then c2 else cmp3 z z')\n ;;\n\n let equal ~eq1 ~eq2 ~eq3 (x, y, z) (x', y', z') = eq1 x x' && eq2 y y' && eq3 z z'\nend\n\nmodule type Comparable_sexpable = sig\n type t [@@deriving sexp]\n\n include Comparable.S with type t := t\nend\n\nmodule type Hashable_sexpable = sig\n type t [@@deriving sexp]\n\n include Hashable.S with type t := t\nend\n\nmodule type Hasher_sexpable = sig\n type t [@@deriving compare, hash, sexp]\nend\n\nmodule Sexpable (S1 : Sexpable.S) (S2 : Sexpable.S) = struct\n type t = S1.t * S2.t [@@deriving sexp]\nend\n\nmodule Binable (B1 : Binable.S) (B2 : Binable.S) = struct\n type t = B1.t * B2.t [@@deriving bin_io]\nend\n\nmodule Comparable_plain (S1 : Comparable.S_plain) (S2 : Comparable.S_plain) = struct\n module T = struct\n type t = S1.t * S2.t\n\n type comparator_witness =\n (S1.comparator_witness, S2.comparator_witness) T2.comparator_witness\n\n let comparator = T2.comparator S1.comparator S2.comparator\n let sexp_of_t = comparator.sexp_of_t\n end\n\n include T\n include Comparable.Make_plain_using_comparator (T)\nend\n\nmodule Comparable (S1 : Comparable_sexpable) (S2 : Comparable_sexpable) = struct\n module T = struct\n include Sexpable (S1) (S2)\n\n let compare (s1, s2) (s1', s2') =\n match S1.compare s1 s1' with\n | 0 -> S2.compare s2 s2'\n | x -> x\n ;;\n end\n\n include T\n include Comparable.Make (T)\nend\n\nmodule Hasher (H1 : Hasher_sexpable) (H2 : Hasher_sexpable) = struct\n module T = struct\n type t = H1.t * H2.t [@@deriving compare, hash, sexp]\n end\n\n include T\n include Hashable.Make (T)\nend\n\nmodule Hasher_sexpable_of_hashable_sexpable (S : Hashable_sexpable) :\n Hasher_sexpable with type t = S.t = struct\n include S\n\n let hash_fold_t state t = hash_fold_int state (hash t)\nend\n\nmodule Hashable_t (S1 : Hashable_sexpable) (S2 : Hashable_sexpable) =\n Hasher\n (Hasher_sexpable_of_hashable_sexpable\n (S1))\n (Hasher_sexpable_of_hashable_sexpable (S2))\n\nmodule Hashable = Hashable_t\n","open! Import\nopen Std_internal\nopen Int.Replace_polymorphic_compare\n\nmodule Round = struct\n type t =\n | Toward_positive_infinity\n | Toward_negative_infinity\n [@@deriving compare, sexp_of]\nend\n\nlet module_name = \"Digit_string_helpers\"\nlet int63_two = Int63.of_int 2\nlet int63_ten = Int63.of_int 10\nlet int63_twenty = Int63.of_int 20\nlet int63_billion = Int63.of_int 1_000_000_000\nlet max_billions = Int63.( / ) Int63.max_value int63_billion\n\nlet rec digits_of_positive_int63 n =\n if Int63.( < ) n int63_ten\n then 1\n else Int.succ (digits_of_positive_int63 (Int63.( / ) n int63_ten))\n;;\n\nlet digits_of_int63_max_value = digits_of_positive_int63 Int63.max_value\n\nlet rec max_int63_with ~digits =\n match digits with\n | 1 -> Int63.of_int 9\n | 2 -> Int63.of_int 99\n | 3 -> Int63.of_int 999\n | 4 -> Int63.of_int 9_999\n | 5 -> Int63.of_int 99_999\n | 6 -> Int63.of_int 999_999\n | 7 -> Int63.of_int 9_999_999\n | 8 -> Int63.of_int 99_999_999\n | 9 -> Int63.of_int 999_999_999\n | _ ->\n if digits >= digits_of_int63_max_value\n then Int63.max_value\n else (\n let billions = Int63.succ (max_int63_with ~digits:(digits - 9)) in\n Int63.pred (Int63.( * ) int63_billion billions))\n;;\n\nmodule Unsafe = struct\n let unsafe_char_of_digit n = Char.unsafe_of_int (Char.to_int '0' + n)\n let digit_of_char char = Char.get_digit_exn char\n\n let write_1_digit_int bytes ~pos int =\n Bytes.unsafe_set bytes pos (unsafe_char_of_digit int)\n ;;\n\n let return_tens_and_write_ones bytes ~pos int =\n let tens = int / 10 in\n let ones = int - (tens * 10) in\n write_1_digit_int bytes ~pos ones;\n tens\n ;;\n\n let write_2_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 1) int in\n write_1_digit_int bytes ~pos tens\n ;;\n\n let write_3_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 2) int in\n write_2_digit_int bytes ~pos tens\n ;;\n\n let write_4_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 3) int in\n write_3_digit_int bytes ~pos tens\n ;;\n\n let write_5_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 4) int in\n write_4_digit_int bytes ~pos tens\n ;;\n\n let write_6_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 5) int in\n write_5_digit_int bytes ~pos tens\n ;;\n\n let write_7_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 6) int in\n write_6_digit_int bytes ~pos tens\n ;;\n\n let write_8_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 7) int in\n write_7_digit_int bytes ~pos tens\n ;;\n\n let write_9_digit_int bytes ~pos int =\n let tens = return_tens_and_write_ones bytes ~pos:(pos + 8) int in\n write_8_digit_int bytes ~pos tens\n ;;\n\n let return_billions_and_write_remainder bytes ~pos int63 =\n let billions = Int63.( / ) int63 int63_billion in\n let remainder = Int63.( - ) int63 (Int63.( * ) billions int63_billion) in\n write_9_digit_int bytes ~pos (Int63.to_int_exn remainder);\n billions\n ;;\n\n let rec write_int63 bytes ~pos ~digits int63 =\n match digits with\n | 1 -> write_1_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 2 -> write_2_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 3 -> write_3_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 4 -> write_4_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 5 -> write_5_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 6 -> write_6_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 7 -> write_7_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 8 -> write_8_digit_int bytes ~pos (Int63.to_int_exn int63)\n | 9 -> write_9_digit_int bytes ~pos (Int63.to_int_exn int63)\n | _ ->\n let digits_of_billions = digits - 9 in\n let billions =\n return_billions_and_write_remainder bytes ~pos:(pos + digits_of_billions) int63\n in\n write_int63 bytes ~pos ~digits:digits_of_billions billions\n ;;\n\n let read_1_digit_int string ~pos = digit_of_char (String.unsafe_get string pos)\n\n let read_2_digit_int string ~pos =\n (read_1_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 1)\n ;;\n\n let read_3_digit_int string ~pos =\n (read_2_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 2)\n ;;\n\n let read_4_digit_int string ~pos =\n (read_3_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 3)\n ;;\n\n let read_5_digit_int string ~pos =\n (read_4_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 4)\n ;;\n\n let read_6_digit_int string ~pos =\n (read_5_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 5)\n ;;\n\n let read_7_digit_int string ~pos =\n (read_6_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 6)\n ;;\n\n let read_8_digit_int string ~pos =\n (read_7_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 7)\n ;;\n\n let read_9_digit_int string ~pos =\n (read_8_digit_int string ~pos * 10) + read_1_digit_int string ~pos:(pos + 8)\n ;;\n\n let raise_int63_overflow name =\n invalid_argf \"%s.%s: overflow reading int63\" module_name name ()\n ;;\n\n let rec read_int63 string ~pos ~digits =\n match digits with\n | 1 -> Int63.of_int (read_1_digit_int string ~pos)\n | 2 -> Int63.of_int (read_2_digit_int string ~pos)\n | 3 -> Int63.of_int (read_3_digit_int string ~pos)\n | 4 -> Int63.of_int (read_4_digit_int string ~pos)\n | 5 -> Int63.of_int (read_5_digit_int string ~pos)\n | 6 -> Int63.of_int (read_6_digit_int string ~pos)\n | 7 -> Int63.of_int (read_7_digit_int string ~pos)\n | 8 -> Int63.of_int (read_8_digit_int string ~pos)\n | 9 -> Int63.of_int (read_9_digit_int string ~pos)\n | _ ->\n let digits_of_billions = digits - 9 in\n let billions = read_int63 string ~pos ~digits:digits_of_billions in\n let remainder =\n Int63.of_int (read_9_digit_int string ~pos:(pos + digits_of_billions))\n in\n if Int63.( > ) billions max_billions then raise_int63_overflow \"read_int63\";\n let sum = Int63.( + ) (Int63.( * ) billions int63_billion) remainder in\n if Int63.( < ) sum Int63.zero then raise_int63_overflow \"read_int63\";\n sum\n ;;\n\n let divide_and_round_up ~numerator ~denominator =\n let open Int63.O in\n (numerator + denominator - Int63.one) /% denominator\n ;;\n\n let raise_invalid_decimal name =\n invalid_argf \"%s.%s: invalid decimal character\" module_name name ()\n ;;\n\n (* Reads the portion of string between [pos] and [pos+decimals-1], inclusive, and\n interperets it as a positive decimal part of a number, which we call [x].\n\n Let [i] and [r] be the integer part and remaining fractional part of\n [x * scale / divisor].\n\n If [r < round_at/divisor], returns [i].\n If [r = round_at/divisor], returns [i] or [i+1] based on [round_exact].\n If [r > round_at/divisor], returns [i+1].\n\n Assumes without checking that [scale] and [divisor] are both positive and\n less than [Int63.max_value / 10] (to avoid internal overflow during the algorithm\n when multiplying by 10), and that [round_at >= 0] and [round_at < divisor]. *)\n let read_int63_decimal_rounded\n string\n ~pos:start\n ~decimals\n ~scale\n ~divisor\n ~round_at\n ~round_exact\n ~allow_underscore\n =\n let open Int63.O in\n let until = Int.( + ) start decimals in\n (* The loop invariant is that each iteration, we strip off the next decimal digit and\n update [sum], [round_at], and [divisor] such that the desired result is:\n\n [ sum + round(remaining_digits_of_x_parsed_as_decimal * scale / divisor) ]\n where \"round\" rounds based on the new value of [round_at].\n *)\n let divisor = ref divisor in\n let round_at = ref round_at in\n let sum = ref Int63.zero in\n let pos = ref start in\n (* Stop if we run out of characters, or if further digits cannot increase our sum. *)\n while Int.( <> ) !pos until && !round_at < scale do\n (match String.unsafe_get string !pos with\n | '0' .. '9' as char ->\n let digit = Int63.of_int (digit_of_char char) in\n (* Every new decimal place implicitly scales our numerator by a factor of ten,\n so must also effectively scale our denominator.\n\n 0.abcdef * scale/divisor [round at round_at]\n = a.bcdef * scale/(divisor*10) [round at round_at*10]\n\n Then redefine divisor := divisor*10 and round_at := round_at*10, so we have:\n a.bcdef * scale/divisor [round at round_at] *)\n divisor := !divisor * int63_ten;\n round_at := !round_at * int63_ten;\n (* Next we work out the part of the sum based on our current digit:\n\n a.bcdef * scale/divisor [round at round_at]\n = a.bcdef * scale/divisor - round_at / divisor [round at 0]\n = (a*scale-round_at) / divisor + 0.bcdef * scale/divisor [round at 0]\n\n Decompose the first term into integer and remainder parts.\n Since we have already subtracted [round_at], we decompose based\n on the ceiling rather than the floor of the division,\n e.g. 5/3 would decompose as 2 + (-1)/3, rather than 1 + (2/3).\n\n = increment + remainder/divisor + 0.bcdef * scale/divisor [round at 0]\n = increment + 0.bcdef * scale/divisor [round at -remainder]\n *)\n let numerator = (digit * scale) - !round_at in\n let denominator = !divisor in\n let increment = divide_and_round_up ~numerator ~denominator in\n let remainder = numerator - (increment * denominator) in\n (* Now just accumulate the new increment and iterate on the remaining part:\n 0.bcdef * scale/divisor [round at -remainder].\n\n Since [remainder] is between [-(divisor-1)] and [0] inclusive, the new\n [round_at] will be within [0] and [divisor-1] inclusive. *)\n round_at := -remainder;\n sum := !sum + increment;\n (* This line prevents the divisor from growing without bound and overflowing. If\n this line actually changes the divisor, then the divisor is larger than the\n scale, so the sum will increase if and only if [parsed_remaining_digits *\n scale (> or >=) round_at], which doesn't depend on how much larger the\n divisor is. So this change is safe. *)\n divisor := Int63.min denominator scale\n | '_' when allow_underscore -> ()\n | _ -> raise_invalid_decimal \"read_int63_decimal\");\n pos := Int.succ !pos\n done;\n if !round_at = zero\n then (\n match round_exact with\n | Round.Toward_negative_infinity -> ()\n | Round.Toward_positive_infinity -> sum := !sum + Int63.one);\n !sum\n ;;\n\n let read_int63_decimal string ~pos ~decimals ~scale ~round_ties ~allow_underscore =\n read_int63_decimal_rounded\n string\n ~pos\n ~decimals\n ~scale:(Int63.( * ) scale int63_two)\n ~divisor:int63_two\n ~round_at:Int63.one\n ~round_exact:round_ties\n ~allow_underscore\n ;;\nend\n\nlet min_scale = Int63.one\nlet max_scale = Int63.( / ) Int63.max_value int63_twenty\n\nlet raise_negative_decimals name ~decimals =\n invalid_argf \"%s.%s: decimals=%d is negative\" module_name name decimals ()\n;;\n\nlet raise_non_positive_digits name ~digits =\n invalid_argf \"%s.%s: digits=%d is not a positive number\" module_name name digits ()\n;;\n\nlet raise_scale_out_of_bounds name ~scale =\n invalid_argf\n \"%s.%s: scale=%Ld out of range [%Ld, %Ld]\"\n module_name\n name\n (Int63.to_int64 scale)\n (Int63.to_int64 min_scale)\n (Int63.to_int64 max_scale)\n ()\n;;\n\nlet raise_pos_out_of_bounds name ~len ~pos ~digits =\n if pos < 0 || pos >= len\n then\n invalid_argf\n \"%s.%s: pos=%d out of range for string of length %d\"\n module_name\n name\n pos\n len\n ()\n else\n invalid_argf\n \"%s.%s: %d digits do not fit at pos %d in string of length %d\"\n module_name\n name\n digits\n pos\n len\n ()\n;;\n\nlet raise_int_out_of_bounds name ~max int =\n invalid_argf \"%s.%s: %d out of range [0, %d]\" module_name name int max ()\n;;\n\nlet raise_int63_out_of_bounds name ~max int63 =\n invalid_argf\n !\"%s.%s: %{Int63} out of range [0, %{Int63}]\"\n module_name\n name\n int63\n max\n ()\n;;\n\nlet check_decimals name ~decimals =\n if decimals < 0 then raise_negative_decimals name ~decimals\n;;\n\nlet check_digits name ~digits = if digits < 1 then raise_non_positive_digits name ~digits\n\nlet check_pos name ~len ~pos ~digits =\n if pos < 0 || pos + digits > len then raise_pos_out_of_bounds name ~len ~pos ~digits\n;;\n\nlet check_int name ~max int =\n if int < 0 || int > max then raise_int_out_of_bounds name ~max int\n;;\n\nlet check_int63 name ~max int63 =\n if Int63.( < ) int63 Int63.zero || Int63.( > ) int63 max\n then raise_int63_out_of_bounds name ~max int63\n;;\n\nlet check_scale name ~scale =\n if Int63.( < ) scale min_scale || Int63.( > ) scale max_scale\n then raise_scale_out_of_bounds name ~scale\n;;\n\nlet check_write name ~bytes ~pos ~digits ~max int =\n let len = Bytes.length bytes in\n check_pos name ~digits ~len ~pos;\n check_int name ~max int\n;;\n\nlet check_write63 name ~bytes ~pos ~digits int63 =\n check_digits name ~digits;\n let max = max_int63_with ~digits in\n let len = Bytes.length bytes in\n check_pos name ~digits ~len ~pos;\n check_int63 name ~max int63\n;;\n\nlet write_1_digit_int bytes ~pos int =\n check_write \"write_1_digit_int\" ~bytes ~pos ~digits:1 ~max:9 int;\n Unsafe.write_1_digit_int bytes ~pos int\n;;\n\nlet write_2_digit_int bytes ~pos int =\n check_write \"write_2_digit_int\" ~bytes ~pos ~digits:2 ~max:99 int;\n Unsafe.write_2_digit_int bytes ~pos int\n;;\n\nlet write_3_digit_int bytes ~pos int =\n check_write \"write_3_digit_int\" ~bytes ~pos ~digits:3 ~max:999 int;\n Unsafe.write_3_digit_int bytes ~pos int\n;;\n\nlet write_4_digit_int bytes ~pos int =\n check_write \"write_4_digit_int\" ~bytes ~pos ~digits:4 ~max:9_999 int;\n Unsafe.write_4_digit_int bytes ~pos int\n;;\n\nlet write_5_digit_int bytes ~pos int =\n check_write \"write_5_digit_int\" ~bytes ~pos ~digits:5 ~max:99_999 int;\n Unsafe.write_5_digit_int bytes ~pos int\n;;\n\nlet write_6_digit_int bytes ~pos int =\n check_write \"write_6_digit_int\" ~bytes ~pos ~digits:6 ~max:999_999 int;\n Unsafe.write_6_digit_int bytes ~pos int\n;;\n\nlet write_7_digit_int bytes ~pos int =\n check_write \"write_7_digit_int\" ~bytes ~pos ~digits:7 ~max:9_999_999 int;\n Unsafe.write_7_digit_int bytes ~pos int\n;;\n\nlet write_8_digit_int bytes ~pos int =\n check_write \"write_8_digit_int\" ~bytes ~pos ~digits:8 ~max:99_999_999 int;\n Unsafe.write_8_digit_int bytes ~pos int\n;;\n\nlet write_9_digit_int bytes ~pos int =\n check_write \"write_9_digit_int\" ~bytes ~pos ~digits:9 ~max:999_999_999 int;\n Unsafe.write_9_digit_int bytes ~pos int\n;;\n\nlet write_int63 bytes ~pos ~digits int63 =\n check_write63 \"write_int63\" ~bytes ~pos ~digits int63;\n Unsafe.write_int63 bytes ~pos ~digits int63\n;;\n\nlet check_read name ~string ~pos ~digits =\n let len = String.length string in\n check_pos name ~digits ~len ~pos\n;;\n\nlet check_read63 name ~string ~pos ~digits =\n check_digits name ~digits;\n let len = String.length string in\n check_pos name ~digits ~len ~pos\n;;\n\nlet check_read63_decimal name ~string ~pos ~decimals ~scale =\n let len = String.length string in\n check_decimals name ~decimals;\n check_scale name ~scale;\n check_pos name ~digits:decimals ~len ~pos\n;;\n\nlet read_1_digit_int string ~pos =\n check_read \"read_1_digit_int\" ~string ~pos ~digits:1;\n Unsafe.read_1_digit_int string ~pos\n;;\n\nlet read_2_digit_int string ~pos =\n check_read \"read_2_digit_int\" ~string ~pos ~digits:2;\n Unsafe.read_2_digit_int string ~pos\n;;\n\nlet read_3_digit_int string ~pos =\n check_read \"read_3_digit_int\" ~string ~pos ~digits:3;\n Unsafe.read_3_digit_int string ~pos\n;;\n\nlet read_4_digit_int string ~pos =\n check_read \"read_4_digit_int\" ~string ~pos ~digits:4;\n Unsafe.read_4_digit_int string ~pos\n;;\n\nlet read_5_digit_int string ~pos =\n check_read \"read_5_digit_int\" ~string ~pos ~digits:5;\n Unsafe.read_5_digit_int string ~pos\n;;\n\nlet read_6_digit_int string ~pos =\n check_read \"read_6_digit_int\" ~string ~pos ~digits:6;\n Unsafe.read_6_digit_int string ~pos\n;;\n\nlet read_7_digit_int string ~pos =\n check_read \"read_7_digit_int\" ~string ~pos ~digits:7;\n Unsafe.read_7_digit_int string ~pos\n;;\n\nlet read_8_digit_int string ~pos =\n check_read \"read_8_digit_int\" ~string ~pos ~digits:8;\n Unsafe.read_8_digit_int string ~pos\n;;\n\nlet read_9_digit_int string ~pos =\n check_read \"read_9_digit_int\" ~string ~pos ~digits:9;\n Unsafe.read_9_digit_int string ~pos\n;;\n\nlet read_int63 string ~pos ~digits =\n check_read63 \"read_int63\" ~string ~pos ~digits;\n Unsafe.read_int63 string ~pos ~digits\n;;\n\nlet read_int63_decimal string ~pos ~decimals ~scale ~round_ties ~allow_underscore =\n check_read63_decimal \"read_int63_decimal\" ~string ~pos ~decimals ~scale;\n Unsafe.read_int63_decimal string ~pos ~decimals ~scale ~round_ties ~allow_underscore\n;;\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n type t =\n | Jan\n | Feb\n | Mar\n | Apr\n | May\n | Jun\n | Jul\n | Aug\n | Sep\n | Oct\n | Nov\n | Dec\n [@@deriving sexp, compare, hash, variants, equal]\n\n let failwithf = Printf.failwithf\n\n let of_int_exn i : t =\n match i with\n | 1 -> Jan\n | 2 -> Feb\n | 3 -> Mar\n | 4 -> Apr\n | 5 -> May\n | 6 -> Jun\n | 7 -> Jul\n | 8 -> Aug\n | 9 -> Sep\n | 10 -> Oct\n | 11 -> Nov\n | 12 -> Dec\n | _ -> failwithf \"Month.of_int_exn %d\" i ()\n ;;\n\n let of_int i =\n try Some (of_int_exn i) with\n | _ -> None\n ;;\n\n let to_int (t : t) =\n match t with\n | Jan -> 1\n | Feb -> 2\n | Mar -> 3\n | Apr -> 4\n | May -> 5\n | Jun -> 6\n | Jul -> 7\n | Aug -> 8\n | Sep -> 9\n | Oct -> 10\n | Nov -> 11\n | Dec -> 12\n ;;\n\n include Binable.Stable.Of_binable.V1 [@alert \"-legacy\"]\n (Int)\n (struct\n type nonrec t = t\n\n let to_binable t = to_int t - 1\n let of_binable i = of_int_exn (i + 1)\n end)\n end\nend\n\nlet num_months = 12\n\nmodule T = struct\n include Stable.V1\n\n let all = [ Jan; Feb; Mar; Apr; May; Jun; Jul; Aug; Sep; Oct; Nov; Dec ]\n let hash = to_int\nend\n\ninclude T\n\ninclude (\n Hashable.Make_binable (struct\n include T\n end) :\n Hashable.S_binable with type t := t)\n\ninclude Comparable.Make_binable (struct\n include T\n\n (* In 108.06a and earlier, months in sexps of Maps and Sets were raw ints. From 108.07\n through 109.13, the output format remained raw as before, but both the raw and\n pretty format were accepted as input. From 109.14 on, the output format was\n changed from raw to pretty, while continuing to accept both formats. Once we believe\n most programs are beyond 109.14, we will switch the input format to no longer accept\n raw. *)\n let t_of_sexp sexp =\n match Option.try_with (fun () -> Int.t_of_sexp sexp) with\n | Some i -> of_int_exn (i + 1)\n | None -> T.t_of_sexp sexp\n ;;\n end)\n\n(* Replace the overriden sexp converters from [Comparable.Make_binable] with the ordinary\n symbolic converters. *)\nlet sexp_of_t = T.sexp_of_t\nlet t_of_sexp = T.t_of_sexp\nlet shift t i = of_int_exn (1 + Int.( % ) (to_int t - 1 + i) num_months)\n\nlet all_strings =\n lazy\n (Array.of_list (List.map all ~f:(fun variant -> Sexp.to_string (sexp_of_t variant))))\n;;\n\nlet to_string (t : t) =\n let all_strings = Lazy.force all_strings in\n all_strings.(to_int t - 1)\n;;\n\nlet of_string =\n let table =\n lazy\n (let module T = String.Table in\n let table = T.create ~size:num_months () in\n Array.iteri (Lazy.force all_strings) ~f:(fun i s ->\n let t = of_int_exn (i + 1) in\n Hashtbl.set table ~key:s ~data:t;\n Hashtbl.set table ~key:(String.lowercase s) ~data:t;\n Hashtbl.set table ~key:(String.uppercase s) ~data:t);\n table)\n in\n fun str ->\n match Hashtbl.find (Lazy.force table) str with\n | Some x -> x\n | None -> failwithf \"Invalid month: %s\" str ()\n;;\n\nmodule Export = struct\n type month = t =\n | Jan\n | Feb\n | Mar\n | Apr\n | May\n | Jun\n | Jul\n | Aug\n | Sep\n | Oct\n | Nov\n | Dec\nend\n","open! Import\nopen Std_internal\nopen Digit_string_helpers\n\nlet is_leap_year ~year = (year mod 4 = 0 && not (year mod 100 = 0)) || year mod 400 = 0\n\n(* Create a local private date type to ensure that all dates are created via\n Date.create_exn.\n*)\nmodule Stable = struct\n module V1 = struct\n module Without_comparable = struct\n module T : sig\n type t [@@immediate] [@@deriving bin_io, hash, typerep]\n\n val create_exn : y:int -> m:Month.Stable.V1.t -> d:int -> t\n val year : t -> int\n val month : t -> Month.Stable.V1.t\n val day : t -> int\n val days_in_month : year:int -> month:Month.t -> int\n val to_int : t -> int\n val of_int_exn : int -> t\n val invalid_value__for_internal_use_only : t\n end = struct\n (* We used to store dates like this:\n type t = { y: int; m: Month.Stable.V1.t; d: int; }\n In the below we make sure that the bin_io representation is\n identical (and the stable unit tests check this)\n\n In memory we use the following much more compact representation:\n 2 bytes year\n 1 byte month\n 1 byte day\n\n all packed into a single immediate int (so from 4 words down to 1).\n *)\n type t = int\n [@@deriving\n hash, typerep, bin_shape ~basetype:\"899ee3e0-490a-11e6-a10a-a3734f733566\"]\n\n let create0 ~year ~month ~day =\n (* create_exn's validation make sure that each value fits *)\n (year lsl 16) lor (Month.to_int month lsl 8) lor day\n ;;\n\n let year t = t lsr 16\n let month t = Month.of_int_exn ((t lsr 8) land 0xff)\n let day t = t land 0xff\n\n let days_in_month ~year ~month =\n match (month : Month.t) with\n | Jan | Mar | May | Jul | Aug | Oct | Dec -> 31\n | Apr | Jun | Sep | Nov -> 30\n | Feb -> if is_leap_year ~year then 29 else 28\n ;;\n\n let create_exn ~y:year ~m:month ~d:day =\n (* year, month, and day need to be passed as parameters to avoid allocating\n a closure (see unit test below) *)\n let invalid ~year ~month ~day msg =\n invalid_argf\n !\"Date.create_exn ~y:%d ~m:%{Month} ~d:%d error: %s\"\n year\n month\n day\n msg\n ()\n in\n if year < 0 || year > 9999\n then invalid ~year ~month ~day \"year outside of [0..9999]\";\n if day <= 0 then invalid ~year ~month ~day \"day <= 0\";\n let days_in_month = days_in_month ~year ~month in\n if day > days_in_month\n then invalid ~year ~month ~day (sprintf \"%d day month violation\" days_in_month);\n create0 ~year ~month ~day\n ;;\n\n (* We don't use Make_binable here, because that would go via an immediate\n tuple or record. That is exactly the 32 bytes we worked so hard above to\n get rid of. We also don't want to just bin_io the integer directly\n because that would mean a new bin_io format. *)\n\n let bin_read_t buf ~pos_ref =\n let year = Int.bin_read_t buf ~pos_ref in\n let month = Month.Stable.V1.bin_read_t buf ~pos_ref in\n let day = Int.bin_read_t buf ~pos_ref in\n create0 ~year ~month ~day\n ;;\n\n let __bin_read_t__ _buf ~pos_ref =\n (* __bin_read_t is only needed for variants *)\n Bin_prot.Common.raise_variant_wrong_type \"Date.t\" !pos_ref\n ;;\n\n let bin_reader_t =\n { Bin_prot.Type_class.read = bin_read_t; vtag_read = __bin_read_t__ }\n ;;\n\n let bin_size_t t =\n Int.bin_size_t (year t) + Month.bin_size_t (month t) + Int.bin_size_t (day t)\n ;;\n\n let bin_write_t buf ~pos t =\n let pos = Int.bin_write_t buf ~pos (year t) in\n let pos = Month.bin_write_t buf ~pos (month t) in\n Int.bin_write_t buf ~pos (day t)\n ;;\n\n let bin_writer_t = { Bin_prot.Type_class.size = bin_size_t; write = bin_write_t }\n\n let bin_t =\n { Bin_prot.Type_class.reader = bin_reader_t\n ; writer = bin_writer_t\n ; shape = bin_shape_t\n }\n ;;\n\n let to_int t = t\n let of_int_exn n = create_exn ~y:(year n) ~m:(month n) ~d:(day n)\n let invalid_value__for_internal_use_only = 0\n\n let%test \"invalid value\" =\n Exn.does_raise (fun () ->\n (of_int_exn invalid_value__for_internal_use_only : t))\n ;;\n end\n\n include T\n\n\n (** YYYY-MM-DD *)\n let to_string_iso8601_extended t =\n let buf = Bytes.create 10 in\n write_4_digit_int buf ~pos:0 (year t);\n Bytes.set buf 4 '-';\n write_2_digit_int buf ~pos:5 (Month.to_int (month t));\n Bytes.set buf 7 '-';\n write_2_digit_int buf ~pos:8 (day t);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf\n ;;\n\n let to_string = to_string_iso8601_extended\n\n (** YYYYMMDD *)\n let to_string_iso8601_basic t =\n let buf = Bytes.create 8 in\n write_4_digit_int buf ~pos:0 (year t);\n write_2_digit_int buf ~pos:4 (Month.to_int (month t));\n write_2_digit_int buf ~pos:6 (day t);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf\n ;;\n\n (** MM/DD/YYYY *)\n let to_string_american t =\n let buf = Bytes.create 10 in\n write_2_digit_int buf ~pos:0 (Month.to_int (month t));\n Bytes.set buf 2 '/';\n write_2_digit_int buf ~pos:3 (day t);\n Bytes.set buf 5 '/';\n write_4_digit_int buf ~pos:6 (year t);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf\n ;;\n\n let parse_year4 str pos = read_4_digit_int str ~pos\n let parse_month str pos = Month.of_int_exn (read_2_digit_int str ~pos)\n let parse_day str pos = read_2_digit_int str ~pos\n\n (** YYYYMMDD *)\n let of_string_iso8601_basic str ~pos =\n if pos + 8 > String.length str\n then invalid_arg \"Date.of_string_iso8601_basic: pos + 8 > string length\";\n create_exn\n ~y:(parse_year4 str pos)\n ~m:(parse_month str (pos + 4))\n ~d:(parse_day str (pos + 6))\n ;;\n\n (* WARNING: if you are going to change this function in a material way, be sure you\n understand the implications of working in Stable *)\n let of_string s =\n let invalid () = failwith (\"invalid date: \" ^ s) in\n let ensure b = if not b then invalid () in\n let month_num ~year ~month ~day =\n create_exn\n ~y:(parse_year4 s year)\n ~m:(parse_month s month)\n ~d:(parse_day s day)\n in\n let month_abrv ~year ~month ~day =\n create_exn\n ~y:(parse_year4 s year)\n ~m:(Month.of_string (String.sub s ~pos:month ~len:3))\n ~d:(parse_day s day)\n in\n if String.contains s '/'\n then (\n let y, m, d =\n match String.split s ~on:'/' with\n | [ a; b; c ] ->\n if String.length a = 4 then a, b, c (* y/m/d *) else c, a, b (* m/d/y *)\n | _ -> invalid ()\n in\n let year = Int.of_string y in\n let year =\n if year >= 100 then year else if year < 75 then 2000 + year else 1900 + year\n in\n let month = Month.of_int_exn (Int.of_string m) in\n let day = Int.of_string d in\n create_exn ~y:year ~m:month ~d:day)\n else if String.contains s '-'\n then (\n (* yyyy-mm-dd *)\n ensure (String.length s = 10 && Char.( = ) s.[4] '-' && Char.( = ) s.[7] '-');\n month_num ~year:0 ~month:5 ~day:8)\n else if String.contains s ' '\n then\n if String.length s = 11 && Char.( = ) s.[2] ' ' && Char.( = ) s.[6] ' '\n then (* DD MMM YYYY *)\n month_abrv ~day:0 ~month:3 ~year:7\n else (\n (* YYYY MMM DD *)\n ensure (String.length s = 11 && Char.( = ) s.[4] ' ' && Char.( = ) s.[8] ' ');\n month_abrv ~day:9 ~month:5 ~year:0)\n else if String.length s = 9\n then (* DDMMMYYYY *)\n month_abrv ~day:0 ~month:2 ~year:5\n else if String.length s = 8\n then (* assume YYYYMMDD *)\n month_num ~year:0 ~month:4 ~day:6\n else invalid ()\n ;;\n\n let of_string s =\n try of_string s with\n | exn -> invalid_argf \"Date.of_string (%s): %s\" s (Exn.to_string exn) ()\n ;;\n\n module Sexpable = struct\n module Old_date = struct\n type t =\n { y : int\n ; m : int\n ; d : int\n }\n [@@deriving sexp]\n\n let to_date t = T.create_exn ~y:t.y ~m:(Month.of_int_exn t.m) ~d:t.d\n end\n\n let t_of_sexp = function\n | Sexp.Atom s -> of_string s\n | Sexp.List _ as sexp -> Old_date.to_date (Old_date.t_of_sexp sexp)\n ;;\n\n let t_of_sexp s =\n try t_of_sexp s with\n | Of_sexp_error _ as exn -> raise exn\n | Invalid_argument a -> of_sexp_error a s\n ;;\n\n let sexp_of_t t = Sexp.Atom (to_string t)\n end\n\n include Sexpable\n\n let compare t1 t2 =\n let n = Int.compare (year t1) (year t2) in\n if n <> 0\n then n\n else (\n let n = Month.compare (month t1) (month t2) in\n if n <> 0 then n else Int.compare (day t1) (day t2))\n ;;\n\n include (val Comparator.Stable.V1.make ~compare ~sexp_of_t)\n end\n\n include Without_comparable\n include Comparable.Stable.V1.Make (Without_comparable)\n end\n\n module Option = struct\n module V1 = struct\n type t = int\n [@@deriving\n bin_io\n , bin_shape ~basetype:\"826a3e79-3321-451a-9707-ed6c03b84e2f\"\n , compare\n , hash\n , typerep]\n\n let none = V1.(to_int invalid_value__for_internal_use_only)\n let is_none t = t = none\n let is_some t = not (is_none t)\n let some_is_representable _ = true\n let some t = V1.to_int t\n let unchecked_value = V1.of_int_exn\n let to_option t = if is_some t then Some (unchecked_value t) else None\n\n let of_option opt =\n match opt with\n | None -> none\n | Some v -> some v\n ;;\n\n let value_exn t =\n if is_some t\n then unchecked_value t\n else raise_s [%message [%here] \"Date.Option.value_exn none\"]\n ;;\n\n let value t ~default = if is_some t then unchecked_value t else default\n let sexp_of_t t = to_option t |> Option.sexp_of_t V1.sexp_of_t\n let t_of_sexp sexp = (Option.t_of_sexp V1.t_of_sexp) sexp |> of_option\n end\n end\nend\n\nmodule Without_comparable = Stable.V1.Without_comparable\ninclude Without_comparable\nmodule C = Comparable.Make_binable_using_comparator (Without_comparable)\ninclude C\n\nmodule O = struct\n include (C : Comparable.Infix with type t := t)\nend\n\ninclude (\n Hashable.Make_binable (struct\n include T\n include Sexpable\n include Binable\n\n let compare (a : t) (b : t) = compare a b\n end) :\n Hashable.S_binable with type t := t)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let module_name = \"Core_kernel.Date\"\n let to_string = to_string\n end)\n\nlet unix_epoch = create_exn ~y:1970 ~m:Jan ~d:1\n\n(* The Days module is used for calculations that involve adding or removing a known number\n of days from a date. Internally the date is translated to a day number, the days are\n added, and the new date is returned. Those interested in the math can read:\n\n http://alcor.concordia.ca/~gpkatch/gdate-method.html\n\n note: unit tests are in lib_test/time_test.ml\n*)\nmodule Days : sig\n type date = t\n type t [@@immediate]\n\n val of_date : date -> t\n val to_date : t -> date\n val diff : t -> t -> int\n val add_days : t -> int -> t\n val unix_epoch : t\nend\nwith type date := t = struct\n open Int\n\n type t = int\n\n let of_year y = (365 * y) + (y / 4) - (y / 100) + (y / 400)\n\n let of_date date =\n let m = (Month.to_int (month date) + 9) % 12 in\n let y = year date - (m / 10) in\n of_year y + (((m * 306) + 5) / 10) + (day date - 1)\n ;;\n\n let c_10_000 = Int63.of_int 10_000\n let c_14_780 = Int63.of_int 14_780\n let c_3_652_425 = Int63.of_int 3_652_425\n\n let to_date days =\n let y =\n let open Int63 in\n to_int_exn (((c_10_000 * of_int days) + c_14_780) / c_3_652_425)\n in\n let ddd = days - of_year y in\n let y, ddd =\n if ddd < 0\n then (\n let y = y - 1 in\n y, days - of_year y)\n else y, ddd\n in\n let mi = ((100 * ddd) + 52) / 3_060 in\n let y = y + ((mi + 2) / 12) in\n let m = ((mi + 2) % 12) + 1 in\n let d = ddd - (((mi * 306) + 5) / 10) + 1 in\n create_exn ~y ~m:(Month.of_int_exn m) ~d\n ;;\n\n let unix_epoch = of_date unix_epoch\n let add_days t days = t + days\n let diff t1 t2 = t1 - t2\nend\n\nlet add_days t days = Days.to_date (Days.add_days (Days.of_date t) days)\nlet diff t1 t2 = Days.diff (Days.of_date t1) (Days.of_date t2)\n\nlet add_months t n =\n let total_months = Month.to_int (month t) + n in\n let y = year t + (total_months /% 12) in\n let m = total_months % 12 in\n (* correct for december *)\n let y, m = if Int.( = ) m 0 then y - 1, m + 12 else y, m in\n let m = Month.of_int_exn m in\n (* handle invalid dates for months with fewer number of days *)\n let rec try_create d =\n try create_exn ~y ~m ~d with\n | _exn ->\n assert (Int.( >= ) d 1);\n try_create (d - 1)\n in\n try_create (day t)\n;;\n\nlet add_years t n = add_months t (n * 12)\n\n(* http://en.wikipedia.org/wiki/Determination_of_the_day_of_the_week#Purely_mathematical_methods\n\n note: unit tests in lib_test/time_test.ml\n*)\nlet day_of_week =\n let table = [| 0; 3; 2; 5; 0; 3; 5; 1; 4; 6; 2; 4 |] in\n fun t ->\n let m = Month.to_int (month t) in\n let y = if Int.( < ) m 3 then year t - 1 else year t in\n Day_of_week.of_int_exn\n ((y + (y / 4) - (y / 100) + (y / 400) + table.(m - 1) + day t) % 7)\n;;\n\n(* http://en.wikipedia.org/wiki/Ordinal_date *)\nlet non_leap_year_table = [| 0; 31; 59; 90; 120; 151; 181; 212; 243; 273; 304; 334 |]\nlet leap_year_table = [| 0; 31; 60; 91; 121; 152; 182; 213; 244; 274; 305; 335 |]\n\nlet ordinal_date t =\n let table =\n if is_leap_year ~year:(year t) then leap_year_table else non_leap_year_table\n in\n let offset = table.(Month.to_int (month t) - 1) in\n day t + offset\n;;\n\nlet last_week_of_year y =\n let first_of_year = create_exn ~y ~m:Jan ~d:1 in\n let is t day = Day_of_week.equal (day_of_week t) day in\n if is first_of_year Thu || (is_leap_year ~year:y && is first_of_year Wed)\n then 53\n else 52\n;;\n\n(* See http://en.wikipedia.org/wiki/ISO_week_date or ISO 8601 for the details of this\n algorithm.\n\n Uses a [~f] argument to avoid allocating a tuple when called by [week_number].\n*)\nlet call_with_week_and_year t ~f =\n let ordinal = ordinal_date t in\n let weekday = Day_of_week.iso_8601_weekday_number (day_of_week t) in\n (* [ordinal - weekday + 4] is the ordinal of this week's Thursday, then (n + 6) / 7 is\n division by 7 rounding up *)\n let week = (ordinal - weekday + 10) / 7 in\n let year = year t in\n if Int.( < ) week 1\n then f ~week:(last_week_of_year (year - 1)) ~year:(year - 1)\n else if Int.( > ) week (last_week_of_year year)\n then f ~week:1 ~year:(year + 1)\n else f ~week ~year\n;;\n\nlet week_number_and_year t = call_with_week_and_year t ~f:(fun ~week ~year -> week, year)\nlet week_number t = call_with_week_and_year t ~f:(fun ~week ~year:_ -> week)\nlet is_weekend t = Day_of_week.is_sun_or_sat (day_of_week t)\nlet is_weekday t = not (is_weekend t)\nlet is_business_day t ~is_holiday = is_weekday t && not (is_holiday t)\n\nlet rec diff_weekend_days t1 t2 =\n if t1 < t2\n then -diff_weekend_days t2 t1\n else (\n (* Basic date diff *)\n let diff = diff t1 t2 in\n (* Compute the number of Saturday -> Sunday crossings *)\n let d1 = day_of_week t1 in\n let d2 = day_of_week t2 in\n let num_satsun_crossings =\n if Int.( < ) (Day_of_week.to_int d1) (Day_of_week.to_int d2)\n then 1 + (diff / 7)\n else diff / 7\n in\n (num_satsun_crossings * 2)\n + (if Day_of_week.( = ) d2 Day_of_week.Sun then 1 else 0)\n + if Day_of_week.( = ) d1 Day_of_week.Sun then -1 else 0)\n;;\n\nlet diff_weekdays t1 t2 = diff t1 t2 - diff_weekend_days t1 t2\n\nlet add_days_skipping t ~skip n =\n let step = if Int.( >= ) n 0 then 1 else -1 in\n let rec loop t k =\n let t_next = add_days t step in\n if skip t then loop t_next k else if Int.( = ) k 0 then t else loop t_next (k - 1)\n in\n loop t (abs n)\n;;\n\nlet rec first_day_satisfying t ~step ~condition =\n if condition t then t else first_day_satisfying (add_days t step) ~step ~condition\n;;\n\nlet next_day_satisfying t ~step ~condition =\n let next_day = add_days t step in\n first_day_satisfying next_day ~step ~condition\n;;\n\nlet following_weekday t = next_day_satisfying t ~step:1 ~condition:is_weekday\nlet previous_weekday t = next_day_satisfying t ~step:(-1) ~condition:is_weekday\nlet round_forward_to_weekday t = first_day_satisfying t ~step:1 ~condition:is_weekday\nlet round_backward_to_weekday t = first_day_satisfying t ~step:(-1) ~condition:is_weekday\n\nlet round_forward_to_business_day t ~is_holiday =\n first_day_satisfying t ~step:1 ~condition:(is_business_day ~is_holiday)\n;;\n\nlet round_backward_to_business_day t ~is_holiday =\n first_day_satisfying t ~step:(-1) ~condition:(is_business_day ~is_holiday)\n;;\n\nlet add_weekdays t n = add_days_skipping t ~skip:is_weekend n\nlet add_weekdays_rounding_in_direction_of_step = add_weekdays\n\nlet add_weekdays_rounding_forward t n =\n add_days_skipping (round_forward_to_weekday t) ~skip:is_weekend n\n;;\n\nlet add_weekdays_rounding_backward t n =\n add_days_skipping (round_backward_to_weekday t) ~skip:is_weekend n\n;;\n\nlet add_business_days t ~is_holiday n =\n add_days_skipping t n ~skip:(fun d -> is_weekend d || is_holiday d)\n;;\n\nlet add_business_days_rounding_in_direction_of_step = add_business_days\n\nlet add_business_days_rounding_forward t ~is_holiday n =\n add_days_skipping (round_forward_to_business_day ~is_holiday t) n ~skip:(fun d ->\n not (is_business_day ~is_holiday d))\n;;\n\nlet add_business_days_rounding_backward t ~is_holiday n =\n add_days_skipping (round_backward_to_business_day ~is_holiday t) n ~skip:(fun d ->\n not (is_business_day ~is_holiday d))\n;;\n\nlet dates_between ~min:t1 ~max:t2 =\n let rec loop t l = if t < t1 then l else loop (add_days t (-1)) (t :: l) in\n loop t2 []\n;;\n\nlet weekdays_between ~min ~max =\n let all_dates = dates_between ~min ~max in\n Option.value_map (List.hd all_dates) ~default:[] ~f:(fun first_date ->\n (* to avoid a system call on every date, we just get the weekday for the first\n date and use it to get all the other weekdays *)\n let first_weekday = day_of_week first_date in\n let date_and_weekdays =\n List.mapi all_dates ~f:(fun i date -> date, Day_of_week.shift first_weekday i)\n in\n List.filter_map date_and_weekdays ~f:(fun (date, weekday) ->\n if Day_of_week.is_sun_or_sat weekday then None else Some date))\n;;\n\nlet business_dates_between ~min ~max ~is_holiday =\n weekdays_between ~min ~max |> List.filter ~f:(fun d -> not (is_holiday d))\n;;\n\nlet first_strictly_after t ~on:dow =\n let dow = Day_of_week.to_int dow in\n let tplus1 = add_days t 1 in\n let cur = Day_of_week.to_int (day_of_week tplus1) in\n let diff = (dow + 7 - cur) mod 7 in\n add_days tplus1 diff\n;;\n\nmodule For_quickcheck = struct\n open Quickcheck\n\n let gen_uniform_incl d1 d2 =\n if d1 > d2\n then\n raise_s\n [%message\n \"Date.gen_uniform_incl: bounds are crossed\"\n ~lower_bound:(d1 : t)\n ~upper_bound:(d2 : t)];\n Generator.map (Int.gen_uniform_incl 0 (diff d2 d1)) ~f:(fun days -> add_days d1 days)\n ;;\n\n let gen_incl d1 d2 =\n Generator.weighted_union\n [ 1., Generator.return d1; 1., Generator.return d2; 18., gen_uniform_incl d1 d2 ]\n ;;\n\n let quickcheck_generator = gen_incl (of_string \"1900-01-01\") (of_string \"2100-01-01\")\n let quickcheck_observer = Observer.create (fun t ~size:_ ~hash -> hash_fold_t hash t)\n let quickcheck_shrinker = Shrinker.empty ()\nend\n\nlet quickcheck_generator = For_quickcheck.quickcheck_generator\nlet gen_incl = For_quickcheck.gen_incl\nlet gen_uniform_incl = For_quickcheck.gen_uniform_incl\nlet quickcheck_observer = For_quickcheck.quickcheck_observer\nlet quickcheck_shrinker = For_quickcheck.quickcheck_shrinker\n\nmodule Private = struct\n let leap_year_table = leap_year_table\n let non_leap_year_table = non_leap_year_table\n let ordinal_date = ordinal_date\nend\n\nmodule Option = struct\n module Stable = Stable.Option\n include Stable.V1\n\n module Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n let unsafe_value = unchecked_value\n end\n end\n\n let quickcheck_generator =\n Quickcheck.Generator.map\n (Option.quickcheck_generator quickcheck_generator)\n ~f:of_option\n ;;\n\n let quickcheck_shrinker =\n Quickcheck.Shrinker.map\n (Option.quickcheck_shrinker quickcheck_shrinker)\n ~f:of_option\n ~f_inverse:to_option\n ;;\n\n let quickcheck_observer =\n Quickcheck.Observer.of_hash\n (module struct\n type nonrec t = t [@@deriving hash]\n end)\n ;;\n\n include Comparable.Make_plain (struct\n type nonrec t = t [@@deriving compare, sexp_of]\n end)\nend\n","open! Import\nopen Std_internal\n\nmodule Stable = struct\n module V1 = struct\n type t = (float[@quickcheck.generator Float.gen_finite])\n [@@deriving compare, hash, quickcheck, typerep]\n\n let of_mult f = f\n let to_mult t = t\n let of_percentage f = f /. 100.\n let to_percentage t = t *. 100.\n let of_bp f = f /. 10_000.\n let to_bp t = t *. 10_000.\n let of_bp_int i = of_bp (Float.of_int i)\n let to_bp_int t = Float.to_int (to_bp t)\n\n let round_significant p ~significant_digits =\n Float.round_significant p ~significant_digits\n ;;\n\n let round_decimal_mult p ~decimal_digits = Float.round_decimal p ~decimal_digits\n\n let round_decimal_percentage p ~decimal_digits =\n Float.round_decimal (p *. 100.) ~decimal_digits /. 100.\n ;;\n\n let round_decimal_bp p ~decimal_digits =\n Float.round_decimal (p *. 10000.) ~decimal_digits /. 10000.\n ;;\n\n module Format = struct\n type t =\n | Exponent of int\n | Exponent_E of int\n | Decimal of int\n | Ocaml\n | Compact of int\n | Compact_E of int\n | Hex of int\n | Hex_E of int\n [@@deriving sexp_of]\n\n let exponent ~precision = Exponent precision\n let exponent_E ~precision = Exponent_E precision\n let decimal ~precision = Decimal precision\n let ocaml = Ocaml\n let compact ~precision = Compact precision\n let compact_E ~precision = Compact_E precision\n let hex ~precision = Hex precision\n let hex_E ~precision = Hex_E precision\n\n let format_float t =\n match t with\n | Exponent precision -> sprintf \"%.*e\" precision\n | Exponent_E precision -> sprintf \"%.*E\" precision\n | Decimal precision -> sprintf \"%.*f\" precision\n | Ocaml -> sprintf \"%F\"\n | Compact precision -> sprintf \"%.*g\" precision\n | Compact_E precision -> sprintf \"%.*G\" precision\n | Hex precision -> sprintf \"%.*h\" precision\n | Hex_E precision -> sprintf \"%.*H\" precision\n ;;\n end\n\n let format x format =\n let x_abs = Float.abs x in\n let string float = Format.format_float format float in\n if Float.( = ) x_abs 0.\n then \"0x\"\n else if Float.( >= ) x_abs 1.\n then string (x *. 1.) ^ \"x\"\n else if Float.( >= ) x_abs 0.01\n then string (x *. 100.) ^ \"%\"\n else string (x *. 10_000.) ^ \"bp\"\n ;;\n\n module Stringable = struct\n type t = float\n\n (* WARNING - PLEASE READ BEFORE EDITING THESE FUNCTIONS:\n\n The string converters in Stable.V1 should never change. If you are changing the\n semantics of anything that affects the sexp or bin-io representation of values of\n this type (this includes to_string and of_string) make a Stable.V2 and make your\n changes there. Thanks! *)\n let to_string x =\n let x_abs = Float.abs x in\n let string float = sprintf \"%.6G\" float in\n if Float.( = ) x_abs 0.\n then \"0x\"\n else if Float.( >= ) x_abs 1.\n then string (x *. 1.) ^ \"x\"\n else if Float.( >= ) x_abs 0.01\n then string (x *. 100.) ^ \"%\"\n else string (x *. 10_000.) ^ \"bp\"\n ;;\n\n let really_of_string str float_of_string =\n match String.chop_suffix str ~suffix:\"x\" with\n | Some str -> float_of_string str\n | None ->\n (match String.chop_suffix str ~suffix:\"%\" with\n | Some str -> float_of_string str *. 0.01\n | None ->\n (match String.chop_suffix str ~suffix:\"bp\" with\n | Some str -> of_bp (float_of_string str)\n | None -> failwithf \"Percent.of_string: must end in x, %%, or bp: %s\" str ()))\n ;;\n\n let of_string str =\n let float str = Float_with_finite_only_serialization.t_of_sexp (Sexp.Atom str) in\n really_of_string str float\n ;;\n\n let of_string_allow_nan_and_inf str = really_of_string str Float.of_string\n end\n\n include (\n Stringable :\n sig\n type t\n\n val of_string : string -> t\n val to_string : t -> string\n end\n with type t := t)\n\n include (Sexpable.Stable.Of_stringable.V1 (Stringable) : Sexpable.S with type t := t)\n include (Float : Binable with type t := t)\n\n include Comparable.Make_binable (struct\n type nonrec t = t [@@deriving compare, sexp_of, bin_io]\n\n (* Previous versions rendered comparable-based containers using float\n serialization rather than percent serialization, so when reading\n comparable-based containers in we accept either serialization. *)\n let t_of_sexp sexp =\n match Float.t_of_sexp sexp with\n | float -> float\n | exception _ -> t_of_sexp sexp\n ;;\n end)\n end\n\n module Option = struct\n module V1 = struct\n type t = V1.t [@@deriving bin_io, compare, hash, typerep]\n\n let none = Float.nan\n let is_none t = Float.is_nan t\n let is_some t = not (is_none t)\n let some_is_representable = is_some\n let some = Fn.id\n let unchecked_value = Fn.id\n let to_option t = if is_some t then Some (unchecked_value t) else None\n\n let of_option opt =\n match opt with\n | None -> none\n | Some v -> some v\n ;;\n\n let value_exn t =\n if is_some t\n then unchecked_value t\n else raise_s [%message [%here] \"Percent.Option.value_exn none\"]\n ;;\n\n let value t ~default = if is_some t then unchecked_value t else default\n let sexp_of_t t = to_option t |> Option.sexp_of_t V1.sexp_of_t\n let t_of_sexp sexp = (Option.t_of_sexp V1.t_of_sexp) sexp |> of_option\n end\n end\nend\n\ninclude Stable.V1\n\nmodule Option = struct\n module Stable = Stable.Option\n include Stable.V1\n\n module Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n let unsafe_value = unchecked_value\n end\n end\nend\n\nlet is_zero t = t = 0.\nlet apply t f = t *. f\nlet scale t f = t *. f\n\ninclude (\nstruct\n include Float\n\n let sign = sign_exn\nend :\nsig\n val zero : t\n val ( * ) : t -> t -> t\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val abs : t -> t\n val neg : t -> t\n val is_nan : t -> bool\n val is_inf : t -> bool\n val sign_exn : t -> Sign.t\n\n include Comparable.With_zero with type t := t\n include Robustly_comparable with type t := t\nend)\n\nlet validate = Float.validate_ordinary\nlet of_string_allow_nan_and_inf s = Stringable.of_string_allow_nan_and_inf s\nlet t_of_sexp_allow_nan_and_inf sexp = of_string_allow_nan_and_inf (Sexp.to_string sexp)\n","open! Import\nopen Std_internal\nopen Digit_string_helpers\nopen! Int.Replace_polymorphic_compare\nmodule Span = Span_float\n\n(* Create an abstract type for Ofday to prevent us from confusing it with\n other floats.\n*)\nmodule Stable = struct\n module V1 = struct\n module T : sig\n type underlying = float\n type t = private underlying [@@deriving bin_io, hash, typerep]\n\n include Comparable.S_common with type t := t\n include Robustly_comparable with type t := t\n include Floatable with type t := t\n\n val add : t -> Span.t -> t option\n val sub : t -> Span.t -> t option\n val next : t -> t option\n val prev : t -> t option\n val diff : t -> t -> Span.t\n val of_span_since_start_of_day_exn : Span.t -> t\n val of_span_since_start_of_day_unchecked : Span.t -> t\n val span_since_start_of_day_is_valid : Span.t -> bool\n val to_span_since_start_of_day : t -> Span.t\n val start_of_day : t\n val start_of_next_day : t\n end = struct\n (* Number of seconds since midnight. *)\n type underlying = Float.t\n\n include (\n struct\n include Float\n\n let sign = sign_exn\n end :\n sig\n type t = underlying [@@deriving bin_io, hash, typerep]\n\n include Comparable.S_common with type t := t\n include Comparable.With_zero with type t := t\n include Robustly_comparable with type t := t\n include Floatable with type t := t\n end)\n\n (* IF THIS REPRESENTATION EVER CHANGES, ENSURE THAT EITHER\n (1) all values serialize the same way in both representations, or\n (2) you add a new Time.Ofday version to stable.ml *)\n\n (* due to precision limitations in float we can't expect better than microsecond\n precision *)\n include Float.Robust_compare.Make (struct\n let robust_comparison_tolerance = 1E-6\n end)\n\n let to_span_since_start_of_day t = Span.of_sec t\n\n (* Another reasonable choice would be only allowing Ofday.t to be < 24hr, but this\n choice was made early on and people became used to being able to easily call 24hr\n the end of the day. It's a bit sad because it shares that moment with the\n beginning of the next day, and round trips oddly if passed through\n Time.to_date_ofday/Time.of_date_ofday.\n\n Note: [Schedule.t] requires that the end of day be representable, as it's the\n only way to write a schedule in terms of [Ofday.t]s that spans two weekdays. *)\n (* ofday must be >= 0 and <= 24h *)\n let is_valid (t : t) =\n let t = to_span_since_start_of_day t in\n Span.( <= ) Span.zero t && Span.( <= ) t Span.day\n ;;\n\n let of_span_since_start_of_day_unchecked span = Span.to_sec span\n\n let span_since_start_of_day_is_valid span =\n is_valid (of_span_since_start_of_day_unchecked span)\n ;;\n\n let of_span_since_start_of_day_exn span =\n let module C = Float.Class in\n let s = Span.to_sec span in\n match Float.classify s with\n | C.Infinite ->\n invalid_arg \"Ofday.of_span_since_start_of_day_exn: infinite value\"\n | C.Nan -> invalid_arg \"Ofday.of_span_since_start_of_day_exn: NaN value\"\n | C.Normal | C.Subnormal | C.Zero ->\n if not (is_valid s)\n then invalid_argf !\"Ofday out of range: %{Span}\" span ()\n else s\n ;;\n\n let start_of_day = 0.\n let start_of_next_day = of_span_since_start_of_day_exn Span.day\n\n let add (t : t) (span : Span.t) =\n let t = t +. Span.to_sec span in\n if is_valid t then Some t else None\n ;;\n\n let sub (t : t) (span : Span.t) =\n let t = t -. Span.to_sec span in\n if is_valid t then Some t else None\n ;;\n\n let next t =\n let candidate = Float.one_ulp `Up t in\n if is_valid candidate then Some candidate else None\n ;;\n\n let prev t =\n let candidate = Float.one_ulp `Down t in\n if is_valid candidate then Some candidate else None\n ;;\n\n let diff t1 t2 =\n Span.( - ) (to_span_since_start_of_day t1) (to_span_since_start_of_day t2)\n ;;\n end\n\n let approximate_end_of_day =\n Option.value_exn (T.sub T.start_of_next_day Span.microsecond)\n ;;\n\n (* [create] chops off any subsecond part when [sec = 60] to handle leap seconds. In\n particular it's trying to be generous about reading in times on things like fix\n messages that might include an extra unlikely second.\n\n Other ways of writing a time, like 1000ms, while mathematically valid, don't match\n ways that people actually write times down, so we didn't see the need to support\n them. That is, a clock might legitimately read 23:59:60 (or, with 60 seconds at\n times of day other than 23:59, depending on the time zone), but it doesn't seem\n reasonable for a clock to read \"23:59:59 and 1000ms\". *)\n let create ?hr ?min ?sec ?ms ?us ?ns () =\n let ms, us, ns =\n match sec with\n | Some 60 -> Some 0, Some 0, Some 0\n | _ -> ms, us, ns\n in\n T.of_span_since_start_of_day_exn (Span.create ?hr ?min ?sec ?ms ?us ?ns ())\n ;;\n\n let to_parts t = Span.to_parts (T.to_span_since_start_of_day t)\n\n let to_string_gen ~drop_ms ~drop_us ~trim t =\n let ( / ) = Int63.( / ) in\n let ( ! ) = Int63.of_int in\n let ( mod ) = Int63.rem in\n let i = Int63.to_int_exn in\n assert (if drop_ms then drop_us else true);\n let float_sec = Span.to_sec (T.to_span_since_start_of_day t) in\n let us = Float.int63_round_nearest_exn (float_sec *. 1e6) in\n let ms, us = us / !1000, us mod !1000 |> i in\n let sec, ms = ms / !1000, ms mod !1000 |> i in\n let min, sec = sec / !60, sec mod !60 |> i in\n let hr, min = min / !60, min mod !60 |> i in\n let hr = i hr in\n let dont_print_us = drop_us || (trim && us = 0) in\n let dont_print_ms = drop_ms || (trim && ms = 0 && dont_print_us) in\n let dont_print_s = trim && sec = 0 && dont_print_ms in\n let len =\n if dont_print_s\n then 5\n else if dont_print_ms\n then 8\n else if dont_print_us\n then 12\n else 15\n in\n let buf = Bytes.create len in\n write_2_digit_int buf ~pos:0 hr;\n Bytes.set buf 2 ':';\n write_2_digit_int buf ~pos:3 min;\n if dont_print_s\n then ()\n else (\n Bytes.set buf 5 ':';\n write_2_digit_int buf ~pos:6 sec;\n if dont_print_ms\n then ()\n else (\n Bytes.set buf 8 '.';\n write_3_digit_int buf ~pos:9 ms;\n if dont_print_us then () else write_3_digit_int buf ~pos:12 us));\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf\n ;;\n\n let to_string_trimmed t = to_string_gen ~drop_ms:false ~drop_us:false ~trim:true t\n let to_sec_string t = to_string_gen ~drop_ms:true ~drop_us:true ~trim:false t\n\n let to_millisecond_string t =\n to_string_gen ~drop_ms:false ~drop_us:true ~trim:false t\n ;;\n\n let small_diff =\n let hour = 3600. in\n fun ofday1 ofday2 ->\n let ofday1 = Span.to_sec (T.to_span_since_start_of_day ofday1) in\n let ofday2 = Span.to_sec (T.to_span_since_start_of_day ofday2) in\n let diff = ofday1 -. ofday2 in\n (* d1 is in (-hour; hour) *)\n let d1 = Float.mod_float diff hour in\n (* d2 is in (0;hour) *)\n let d2 = Float.mod_float (d1 +. hour) hour in\n let d = if Float.( > ) d2 (hour /. 2.) then d2 -. hour else d2 in\n Span.of_sec d\n ;;\n\n include T\n\n let to_string t = to_string_gen ~drop_ms:false ~drop_us:false ~trim:false t\n\n include Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Core_kernel.Time.Ofday\"\n end)\n\n let create_from_parsed string ~hr ~min ~sec ~subsec_pos ~subsec_len =\n let subsec =\n if Int.equal subsec_len 0\n then 0.\n else Float.of_string (String.sub string ~pos:subsec_pos ~len:subsec_len)\n in\n Float.of_int ((hr * 3600) + (min * 60) + sec) +. subsec\n |> Span.of_sec\n |> T.of_span_since_start_of_day_exn\n ;;\n\n let of_string s = Ofday_helpers.parse s ~f:create_from_parsed\n\n let t_of_sexp sexp =\n match sexp with\n | Sexp.Atom s ->\n (try of_string s with\n | Invalid_argument s -> of_sexp_error (\"Ofday.t_of_sexp: \" ^ s) sexp)\n | _ -> of_sexp_error \"Ofday.t_of_sexp\" sexp\n ;;\n\n let sexp_of_t span = Sexp.Atom (to_string span)\n\n let of_string_iso8601_extended ?pos ?len str =\n try Ofday_helpers.parse_iso8601_extended ?pos ?len str ~f:create_from_parsed with\n | exn ->\n invalid_argf\n \"Ofday.of_string_iso8601_extended(%s): %s\"\n (String.subo str ?pos ?len)\n (Exn.to_string exn)\n ()\n ;;\n end\nend\n\ninclude Stable.V1\n\nlet gen_incl lo hi =\n Span.gen_incl (to_span_since_start_of_day lo) (to_span_since_start_of_day hi)\n |> Quickcheck.Generator.map ~f:of_span_since_start_of_day_exn\n;;\n\nlet gen_uniform_incl lo hi =\n Span.gen_uniform_incl (to_span_since_start_of_day lo) (to_span_since_start_of_day hi)\n |> Quickcheck.Generator.map ~f:of_span_since_start_of_day_exn\n;;\n\nlet quickcheck_generator = gen_incl start_of_day start_of_next_day\n\nlet quickcheck_observer =\n Quickcheck.Observer.unmap Span.quickcheck_observer ~f:to_span_since_start_of_day\n;;\n\nlet quickcheck_shrinker = Quickcheck.Shrinker.empty ()\n\ninclude Hashable.Make_binable (struct\n type nonrec t = t [@@deriving bin_io, compare, hash, sexp_of]\n\n (* Previous versions rendered hash-based containers using float serialization rather\n than time serialization, so when reading hash-based containers in we accept either\n serialization. *)\n let t_of_sexp sexp =\n match Float.t_of_sexp sexp with\n | float -> of_float float\n | exception _ -> t_of_sexp sexp\n ;;\n end)\n\nmodule C = struct\n type t = T.t [@@deriving bin_io]\n type comparator_witness = T.comparator_witness\n\n let comparator = T.comparator\n\n (* In 108.06a and earlier, ofdays in sexps of Maps and Sets were raw floats. From\n 108.07 through 109.13, the output format remained raw as before, but both the raw and\n pretty format were accepted as input. From 109.14 on, the output format was changed\n from raw to pretty, while continuing to accept both formats. Once we believe most\n programs are beyond 109.14, we will switch the input format to no longer accept\n raw. *)\n let sexp_of_t = sexp_of_t\n\n let t_of_sexp sexp =\n match Option.try_with (fun () -> T.of_float (Float.t_of_sexp sexp)) with\n | Some t -> t\n | None -> t_of_sexp sexp\n ;;\nend\n\nmodule Map = Map.Make_binable_using_comparator (C)\nmodule Set = Set.Make_binable_using_comparator (C)\n\nlet of_span_since_start_of_day = of_span_since_start_of_day_exn\nlet to_millisec_string = to_millisecond_string\n","open! Import\nopen Std_internal\nopen! Int63.O\n\nlet module_name = \"Core_kernel.Time_ns.Span\"\n\ntype underlying = Int63.t\n\nlet arch_sixtyfour = Int.equal Sys.word_size 64\nlet round_nearest = Float.int63_round_nearest_exn\nlet float x = Int63.to_float x\n\n(* [Span] is basically a [Int63]. It even silently ignores overflow. *)\nmodule T = struct\n type t = Int63.t (* nanoseconds *) [@@deriving hash, bin_io, quickcheck, typerep]\n\n module Replace_polymorphic_compare = Int63.Replace_polymorphic_compare\n\n let zero = Int63.zero\nend\n\ninclude T\nopen Replace_polymorphic_compare\n\nmodule Parts = struct\n type t =\n { sign : Sign.t\n ; hr : int\n ; min : int\n ; sec : int\n ; ms : int\n ; us : int\n ; ns : int\n }\n [@@deriving compare, sexp]\nend\n\nlet next t = Int63.succ t\nlet prev t = Int63.pred t\nlet nanosecond = Int63.of_int 1\nlet microsecond = Int63.(of_int 1000 * nanosecond)\nlet millisecond = Int63.(of_int 1000 * microsecond)\nlet second = Int63.(of_int 1000 * millisecond)\nlet minute = Int63.(of_int 60 * second)\nlet hour = Int63.(of_int 60 * minute)\nlet day = Int63.(of_int 24 * hour)\n\n(* Beyond [min_value_for_1us_rounding..max_value_for_1us_rounding], not every microsecond\n can be represented as a [float] number of seconds. (In fact, it is around 135y, but we\n leave a small margin.)\n\n In the presence of silently ignored overflow, note that [t] is not actually bound to\n stay between these limits. *)\nlet max_value_for_1us_rounding = Int63.(of_int 135 * of_int 365 * day)\nlet min_value_for_1us_rounding = Int63.neg max_value_for_1us_rounding\n\nlet create\n ?sign:(sign_ = Sign.Pos (* rebind so not shadowed by [open Int63] below *))\n ?day:(days = 0)\n ?(hr = 0)\n ?min:(minutes = 0)\n ?(sec = 0)\n ?(ms = 0)\n ?(us = 0)\n ?(ns = 0)\n ()\n =\n let open Int63 in\n let t =\n (of_int days * day)\n + (of_int hr * hour)\n + (of_int minutes * minute)\n + (of_int sec * second)\n + (of_int ms * millisecond)\n + (of_int us * microsecond)\n + (of_int ns * nanosecond)\n in\n match sign_ with\n | Neg -> neg t\n | Pos | Zero -> t\n;;\n\nlet to_parts t =\n let open Int63 in\n let mag = abs t in\n { Parts.sign = (if t < zero then Neg else if t > zero then Pos else Zero)\n ; hr = to_int_exn (mag / hour)\n ; min = to_int_exn (rem mag hour / minute)\n ; sec = to_int_exn (rem mag minute / second)\n ; ms = to_int_exn (rem mag second / millisecond)\n ; us = to_int_exn (rem mag millisecond / microsecond)\n ; ns = to_int_exn (rem mag microsecond / nanosecond)\n }\n;;\n\nlet of_parts { Parts.sign; hr; min; sec; ms; us; ns } =\n create ~sign ~hr ~min ~sec ~ms ~us ~ns ()\n;;\n\nlet of_ns f = round_nearest f\nlet of_int63_ns i = i\nlet of_int_us i = Int63.(of_int i * microsecond)\nlet of_int_ms i = Int63.(of_int i * millisecond)\nlet of_int_sec i = Int63.(of_int i * second)\nlet of_us f = round_nearest (f *. float microsecond)\nlet of_ms f = round_nearest (f *. float millisecond)\nlet of_sec f = round_nearest (f *. float second)\nlet of_min f = round_nearest (f *. float minute)\nlet of_hr f = round_nearest (f *. float hour)\nlet of_day f = round_nearest (f *. float day)\n\nlet of_sec_with_microsecond_precision sec =\n let us = round_nearest (sec *. 1e6) in\n of_int63_ns Int63.(us * of_int 1000)\n;;\n\nlet of_int63_seconds x = x * second\nlet of_int32_seconds x = of_int63_seconds (Int63.of_int32 x)\n\nlet to_ns t = float t\nlet to_int63_ns t = t\nlet to_us t = float t /. float microsecond\nlet to_ms t = float t /. float millisecond\nlet to_sec t = float t /. float second\nlet to_min t = float t /. float minute\nlet to_hr t = float t /. float hour\nlet to_day t = float t /. float day\nlet to_int_us t = Int63.(to_int_exn (t / microsecond))\nlet to_int_ms t = Int63.(to_int_exn (t / millisecond))\nlet to_int_sec t = Int63.(to_int_exn (t / second))\nlet to_int63_seconds_round_down_exn t = t /% second\nlet of_int_ns i = of_int63_ns (Int63.of_int i)\n\nlet to_int_ns =\n if arch_sixtyfour\n then fun t -> Int63.to_int_exn (to_int63_ns t)\n else fun _ -> failwith \"Time_ns.Span.to_int_ns: unsupported on 32bit machines\"\n;;\n\nlet ( + ) t u = Int63.( + ) t u\nlet ( - ) t u = Int63.( - ) t u\nlet abs = Int63.abs\nlet neg = Int63.neg\nlet scale t f = round_nearest (float t *. f)\nlet scale_int63 t i = Int63.( * ) t i\nlet scale_int t i = scale_int63 t (Int63.of_int i)\nlet div = Int63.( /% )\nlet ( / ) t f = round_nearest (float t /. f)\nlet ( // ) = Int63.( // )\nlet to_proportional_float t = Int63.to_float t\n\nlet of_unit_of_time u =\n match (u : Unit_of_time.t) with\n | Nanosecond -> nanosecond\n | Microsecond -> microsecond\n | Millisecond -> millisecond\n | Second -> second\n | Minute -> minute\n | Hour -> hour\n | Day -> day\n;;\n\nlet to_unit_of_time t : Unit_of_time.t =\n let abs_t = abs t in\n if abs_t >= day\n then Day\n else if abs_t >= hour\n then Hour\n else if abs_t >= minute\n then Minute\n else if abs_t >= second\n then Second\n else if abs_t >= millisecond\n then Millisecond\n else if abs_t >= microsecond\n then Microsecond\n else Nanosecond\n;;\n\nmodule Stable = struct\n module V2 = struct\n module T = struct\n module T0 = struct\n type nonrec t = t [@@deriving bin_io, compare, hash]\n\n let of_int63_exn t = of_int63_ns t\n let to_int63 t = to_int63_ns t\n\n module To_string = struct\n let number_of_digits_to_write ~span_part_magnitude =\n let open Int.O in\n if span_part_magnitude = 0\n then 0\n else if span_part_magnitude < 10\n then 1\n else if span_part_magnitude < 100\n then 2\n else if span_part_magnitude < 1_000\n then 3\n else if span_part_magnitude < 10_000\n then 4\n else if span_part_magnitude < 100_000\n then 5\n else assert false\n ;;\n\n (* span part magnitudes are always < 100_000 *)\n\n let number_of_decimal_places_to_write ~billionths =\n let open Int.O in\n assert (billionths >= 0 && billionths <= 999_999_999);\n if billionths = 0\n then 0\n else if billionths % 10 <> 0\n then 9\n else if billionths % 100 <> 0\n then 8\n else if billionths % 1_000 <> 0\n then 7\n else if billionths % 10_000 <> 0\n then 6\n else if billionths % 100_000 <> 0\n then 5\n else if billionths % 1_000_000 <> 0\n then 4\n else if billionths % 10_000_000 <> 0\n then 3\n else if billionths % 100_000_000 <> 0\n then 2\n else 1\n ;;\n\n let write_char buf ~pos char =\n let open Int.O in\n Bytes.unsafe_set buf pos char;\n pos + 1\n ;;\n\n let write_2_chars buf ~pos char1 char2 =\n let open Int.O in\n Bytes.unsafe_set buf pos char1;\n Bytes.unsafe_set buf (pos + 1) char2;\n pos + 2\n ;;\n\n let write_digits buf ~pos ~digits int =\n let open Int.O in\n Digit_string_helpers.write_int63 buf ~pos ~digits (Int63.of_int int);\n pos + digits\n ;;\n\n let write_decimals buf ~pos ~decimals ~billionths =\n let open Int.O in\n Digit_string_helpers.write_int63\n buf\n ~pos\n ~digits:decimals\n (Int63.of_int (billionths / Int.pow 10 (9 - decimals)));\n pos + decimals\n ;;\n\n let write_if_non_empty buf ~pos ~digits int suffix =\n let open Int.O in\n if digits = 0\n then pos\n else (\n let pos = write_digits buf ~pos ~digits int in\n let pos = write_char buf ~pos suffix in\n pos)\n ;;\n\n let nanos_of_millisecond = to_int63_ns millisecond |> Int63.to_int_exn\n let nanos_of_microsecond = to_int63_ns microsecond |> Int63.to_int_exn\n let int63_60 = Int63.of_int 60\n let int63_24 = Int63.of_int 24\n\n (* Units of seconds and smaller can be written in decimal notation without\n worrying about non-power-of-ten factors. *)\n module Decimal_unit = struct\n type t =\n | Second\n | Millisecond\n | Microsecond\n | Nanosecond\n | None\n [@@deriving compare, sexp_of]\n\n let create ~s ~ns =\n let open Int.O in\n if s > 0\n then Second\n else if ns >= nanos_of_millisecond\n then Millisecond\n else if ns >= nanos_of_microsecond\n then Microsecond\n else if ns >= 1\n then Nanosecond\n else None\n ;;\n\n let integer t ~s ~ns =\n let open Int.O in\n match t with\n | Second -> s\n | Millisecond -> ns / nanos_of_millisecond\n | Microsecond -> ns / nanos_of_microsecond\n | Nanosecond -> ns\n | None -> 0\n ;;\n\n let billionths t ~ns =\n let open Int.O in\n match t with\n | Second -> ns\n | Millisecond -> ns % nanos_of_millisecond * 1_000\n | Microsecond -> ns % nanos_of_microsecond * 1_000_000\n | Nanosecond -> 0\n | None -> 0\n ;;\n\n let length t ~digits ~decimals =\n let open Int.O in\n let digits_len =\n match t with\n | Second -> digits + 1\n | Millisecond | Microsecond | Nanosecond -> digits + 2\n | None -> 0\n in\n let decimals_len = if decimals > 0 then decimals + 1 else 0 in\n digits_len + decimals_len\n ;;\n\n let write_suffix t buf ~pos =\n match t with\n | Second -> write_char buf ~pos 's'\n | Millisecond -> write_2_chars buf ~pos 'm' 's'\n | Microsecond -> write_2_chars buf ~pos 'u' 's'\n | Nanosecond -> write_2_chars buf ~pos 'n' 's'\n | None -> pos\n ;;\n\n let write t buf ~pos ~integer ~digits ~billionths ~decimals =\n let open Int.O in\n if digits = 0\n then pos\n else (\n let pos = write_digits buf ~pos integer ~digits in\n let pos =\n if decimals = 0\n then pos\n else (\n let pos = write_char buf ~pos '.' in\n write_decimals buf ~pos ~billionths ~decimals)\n in\n write_suffix t buf ~pos)\n ;;\n end\n\n let to_string t =\n if equal t zero\n then \"0s\"\n else (\n let is_negative = t < zero in\n let seconds = Int63.( / ) (to_int63_ns t) (to_int63_ns second) in\n let ns =\n Int63.rem (to_int63_ns t) (to_int63_ns second) |> Int63.to_int_exn\n in\n let seconds = Int63.abs seconds in\n let ns = Int.abs ns in\n let s = Int63.rem seconds int63_60 |> Int63.to_int_exn in\n let minutes = Int63.( / ) seconds int63_60 in\n let m = Int63.rem minutes int63_60 |> Int63.to_int_exn in\n let hours = Int63.( / ) minutes int63_60 in\n let h = Int63.rem hours int63_24 |> Int63.to_int_exn in\n let d = Int63.( / ) hours int63_24 |> Int63.to_int_exn in\n let open Int.O in\n let digits_of_d = number_of_digits_to_write ~span_part_magnitude:d in\n let digits_of_h = number_of_digits_to_write ~span_part_magnitude:h in\n let digits_of_m = number_of_digits_to_write ~span_part_magnitude:m in\n let decimal_unit = Decimal_unit.create ~s ~ns in\n let decimal_unit_integer = Decimal_unit.integer decimal_unit ~s ~ns in\n let decimal_unit_billionths = Decimal_unit.billionths decimal_unit ~ns in\n let digits_of_decimal_unit =\n number_of_digits_to_write ~span_part_magnitude:decimal_unit_integer\n in\n let decimals_of_decimal_unit =\n number_of_decimal_places_to_write ~billionths:decimal_unit_billionths\n in\n let string_length =\n let sign_len = if is_negative then 1 else 0 in\n let d_len = if digits_of_d > 0 then digits_of_d + 1 else 0 in\n let h_len = if digits_of_h > 0 then digits_of_h + 1 else 0 in\n let m_len = if digits_of_m > 0 then digits_of_m + 1 else 0 in\n let decimal_unit_len =\n Decimal_unit.length\n decimal_unit\n ~digits:digits_of_decimal_unit\n ~decimals:decimals_of_decimal_unit\n in\n sign_len + d_len + h_len + m_len + decimal_unit_len\n in\n assert (string_length > 0);\n let buf = Bytes.create string_length in\n let pos = 0 in\n let pos = if is_negative then write_char buf ~pos '-' else pos in\n let pos = write_if_non_empty buf ~pos ~digits:digits_of_d d 'd' in\n let pos = write_if_non_empty buf ~pos ~digits:digits_of_h h 'h' in\n let pos = write_if_non_empty buf ~pos ~digits:digits_of_m m 'm' in\n let pos =\n Decimal_unit.write\n decimal_unit\n buf\n ~pos\n ~integer:decimal_unit_integer\n ~digits:digits_of_decimal_unit\n ~billionths:decimal_unit_billionths\n ~decimals:decimals_of_decimal_unit\n in\n assert (pos = string_length);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf)\n ;;\n end\n\n let to_string = To_string.to_string\n\n module Of_string = struct\n (* We do computations using negative numbers everywhere and test against\n things related to [Int63.min_value] rather than using positive numbers\n and testing against things related to [Int63.max_value] because the\n negative integer range is one wider than the positive integer range\n (-2**63 vs 2**63-1), and we need that to be able to handle Int63.min_value\n nicely. *)\n\n let int63_10 = Int63.of_int 10\n let min_mult10_without_underflow = Int63.(min_value / int63_10)\n\n let[@cold] invalid_string string ~reason =\n raise_s\n [%message\n \"Time_ns.Span.of_string: invalid string\"\n (string : string)\n (reason : string)]\n ;;\n\n (* Assumes x and y are both nonpositive *)\n let add_without_underflow ~string x y =\n let open Int63.O in\n let sum = x + y in\n if sum > x\n then invalid_string string ~reason:\"span would be outside of int63 range\";\n sum\n ;;\n\n let add_neg_digit ~string int63 char =\n let open Int63.O in\n let digit = Int63.of_int (Char.get_digit_exn char) in\n if int63 < min_mult10_without_underflow\n then invalid_string string ~reason:\"span would be outside of int63 range\";\n add_without_underflow ~string (int63 * int63_10) (-digit)\n ;;\n\n let min_factor_of span = Int63.( / ) Int63.min_value (to_int63_ns span)\n let min_days_without_underflow = min_factor_of day\n let min_hours_without_underflow = min_factor_of hour\n let min_minutes_without_underflow = min_factor_of minute\n let min_seconds_without_underflow = min_factor_of second\n let min_milliseconds_without_underflow = min_factor_of millisecond\n let min_microseconds_without_underflow = min_factor_of microsecond\n let min_nanoseconds_without_underflow = min_factor_of nanosecond\n\n let min_without_underflow_of_unit_of_time unit_of_time =\n match (unit_of_time : Unit_of_time.t) with\n | Day -> min_days_without_underflow\n | Hour -> min_hours_without_underflow\n | Minute -> min_minutes_without_underflow\n | Second -> min_seconds_without_underflow\n | Millisecond -> min_milliseconds_without_underflow\n | Microsecond -> min_microseconds_without_underflow\n | Nanosecond -> min_nanoseconds_without_underflow\n ;;\n\n let negative_part\n string\n ~neg_integer\n ~decimal_pos\n ~end_pos\n ~unit_of_time\n ~round_ties_before_negating\n =\n let open Int.O in\n let scale = to_int63_ns (of_unit_of_time unit_of_time) in\n let min_without_underflow =\n min_without_underflow_of_unit_of_time unit_of_time\n in\n if Int63.( < ) neg_integer min_without_underflow\n then invalid_string string ~reason:\"span would be outside of int63 range\";\n let neg_integer_ns = Int63.( * ) neg_integer scale in\n let fraction_pos = decimal_pos + 1 in\n if fraction_pos >= end_pos\n then neg_integer_ns\n else (\n let decimal_ns =\n Digit_string_helpers.read_int63_decimal\n string\n ~pos:fraction_pos\n ~scale\n ~decimals:(end_pos - fraction_pos)\n ~allow_underscore:true\n ~round_ties:round_ties_before_negating\n in\n add_without_underflow ~string neg_integer_ns (Int63.( ~- ) decimal_ns))\n ;;\n\n let of_string string =\n let open Int.O in\n let neg_ns = ref Int63.zero in\n let pos = ref 0 in\n let len = String.length string in\n if len = 0 then invalid_string string ~reason:\"empty string\";\n let is_negative =\n match String.unsafe_get string !pos with\n | '-' ->\n incr pos;\n true\n | '+' ->\n incr pos;\n false\n | _ -> false\n in\n let round_ties_before_negating : Digit_string_helpers.Round.t =\n (* Ultimately, we always round parsed spans towards positive infinity when\n the nearest round ns are equidistant. For example, \"1.5ns\" is read as\n 2.0ns, and \"-1.5ns\" is read as -1ns. Since we read absolute values before\n applying the sign, we must choose our rounding direction based on the\n sign. Rounding decimal values happens before negating their magnitude. *)\n match is_negative with\n | false -> Toward_positive_infinity\n | true -> Toward_negative_infinity\n in\n (* Loop over parts, like \"5m\" in \"1h5m30s\" *)\n while !pos < len do\n let has_digit = ref false in\n let neg_integer =\n let i = ref Int63.zero in\n let end_of_digits = ref false in\n while !pos < len && not !end_of_digits do\n let c = String.unsafe_get string !pos in\n match c with\n | '0' .. '9' ->\n i := add_neg_digit ~string !i c;\n has_digit := true;\n incr pos\n | '_' -> incr pos\n | _ -> end_of_digits := true\n done;\n !i\n in\n let decimal_pos = !pos in\n if !pos < len && Char.equal '.' (String.unsafe_get string !pos)\n then (\n incr pos;\n let end_of_decimals = ref false in\n while !pos < len && not !end_of_decimals do\n match String.unsafe_get string !pos with\n | '0' .. '9' ->\n has_digit := true;\n incr pos\n | '_' -> incr pos\n | _ -> end_of_decimals := true\n done);\n let end_pos = !pos in\n if not !has_digit\n then invalid_string string ~reason:\"no digits before unit suffix\";\n let unit_of_time : Unit_of_time.t =\n if !pos + 1 < len && Char.equal 's' (String.unsafe_get string (!pos + 1))\n then (\n match String.unsafe_get string !pos with\n | 'm' ->\n pos := !pos + 2;\n Millisecond\n | 'u' ->\n pos := !pos + 2;\n Microsecond\n | 'n' ->\n pos := !pos + 2;\n Nanosecond\n | _ -> invalid_string string ~reason:\"unparseable unit suffix\")\n else if !pos < len\n then (\n match String.unsafe_get string !pos with\n | 'd' ->\n incr pos;\n Day\n | 'h' ->\n incr pos;\n Hour\n | 'm' ->\n incr pos;\n Minute\n | 's' ->\n incr pos;\n Second\n | _ -> invalid_string string ~reason:\"unparseable unit suffix\")\n else invalid_string string ~reason:\"no unit suffix after digits\"\n in\n let neg_nanos_of_part =\n negative_part\n string\n ~neg_integer\n ~decimal_pos\n ~end_pos\n ~unit_of_time\n ~round_ties_before_negating\n in\n neg_ns := add_without_underflow ~string !neg_ns neg_nanos_of_part\n done;\n let ns =\n if is_negative\n then !neg_ns\n else if Int63.( = ) !neg_ns Int63.min_value\n then invalid_string string ~reason:\"span would be outside of int63 range\"\n else Int63.( ~- ) !neg_ns\n in\n of_int63_ns ns\n ;;\n end\n\n let of_string = Of_string.of_string\n let sexp_of_t t = Sexp.Atom (to_string t)\n\n let t_of_sexp sexp =\n match sexp with\n | Sexp.Atom x ->\n (try of_string x with\n | exn -> of_sexp_error (Exn.to_string exn) sexp)\n | Sexp.List _ ->\n of_sexp_error \"Time_ns.Span.Stable.V2.t_of_sexp: sexp must be an Atom\" sexp\n ;;\n end\n\n include T0\n include Comparator.Stable.V1.Make (T0)\n end\n\n include T\n include Comparable.Stable.V1.Make (T)\n end\nend\n\nlet to_string = Stable.V2.to_string\nlet of_string = Stable.V2.of_string\nlet sexp_of_t = Stable.V2.sexp_of_t\nlet t_of_sexp = Stable.V2.t_of_sexp\n\nmodule Alternate_sexp = struct\n type nonrec t = t [@@deriving sexp]\nend\n\ninclude Comparable.Validate_with_zero (struct\n type nonrec t = t [@@deriving compare, sexp]\n\n let zero = zero\n end)\n\n(* Functions required by [Robustly_comparable]: allows for [robust_comparison_tolerance]\n granularity.\n\n A microsecond is a reasonable granularity because there is very little network\n activity that can be measured to sub-microsecond resolution. *)\nlet robust_comparison_tolerance = microsecond\nlet ( >=. ) t u = t >= Int63.(u - robust_comparison_tolerance)\nlet ( <=. ) t u = t <= Int63.(u + robust_comparison_tolerance)\nlet ( =. ) t u = Int63.(abs (t - u)) <= robust_comparison_tolerance\nlet ( >. ) t u = t > Int63.(u + robust_comparison_tolerance)\nlet ( <. ) t u = t < Int63.(u - robust_comparison_tolerance)\nlet ( <>. ) t u = Int63.(abs (t - u)) > robust_comparison_tolerance\nlet robustly_compare t u = if t <. u then -1 else if t >. u then 1 else 0\n\n(* We don't just convert to [Time.Span.t] and use the conversion there because our\n [to_span] conversion is limited to microsecond precision. *)\nlet to_string_hum\n ?(delimiter = '_')\n ?(decimals = 3)\n ?(align_decimal = false)\n ?unit_of_time\n t\n =\n let float, suffix =\n match Option.value unit_of_time ~default:(to_unit_of_time t) with\n | Day -> to_day t, \"d\"\n | Hour -> to_hr t, \"h\"\n | Minute -> to_min t, \"m\"\n | Second -> to_sec t, \"s\"\n | Millisecond -> to_ms t, \"ms\"\n | Microsecond -> to_us t, \"us\"\n | Nanosecond -> to_ns t, \"ns\"\n in\n let prefix =\n Float.to_string_hum float ~delimiter ~decimals ~strip_zero:(not align_decimal)\n in\n let suffix =\n if align_decimal && Int.( = ) (String.length suffix) 1 then suffix ^ \" \" else suffix\n in\n prefix ^ suffix\n;;\n\nlet since_unix_epoch () = Time_now.nanoseconds_since_unix_epoch () |> of_int63_ns\n\nlet random ?state () =\n Int63.random ?state (max_value_for_1us_rounding + Int63.one)\n - Int63.random ?state (neg min_value_for_1us_rounding + Int63.one)\n;;\n\nlet randomize t ~percent = Span_helpers.randomize t ~percent ~scale\n\nlet to_short_string t =\n let ({ sign; hr; min; sec; ms; us; ns } : Parts.t) = to_parts t in\n Span_helpers.short_string ~sign ~hr ~min ~sec ~ms ~us ~ns\n;;\n\nlet gen_incl = Int63.gen_incl\nlet gen_uniform_incl = Int63.gen_uniform_incl\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = module_name\n end)\n\ninclude Hashable.Make_binable (struct\n type nonrec t = t [@@deriving bin_io, compare, hash, sexp]\n end)\n\ntype comparator_witness = Stable.V2.comparator_witness\n\ninclude Comparable.Make_binable_using_comparator (struct\n type nonrec t = t [@@deriving bin_io, compare, sexp]\n type nonrec comparator_witness = comparator_witness\n\n let comparator = Stable.V2.comparator\n end)\n\n(* re-include [Replace_polymorphic_compare] and its comparisons to shadow the\n un-inlineable ones from [Comparable] *)\nmodule Replace_polymorphic_compare = T.Replace_polymorphic_compare\ninclude Replace_polymorphic_compare\n\nlet to_span_float_round_nearest t = Span_float.of_sec (to_sec t)\nlet of_span_float_round_nearest s = of_sec (Span_float.to_sec s)\nlet half_microsecond = Int63.of_int 500\nlet nearest_microsecond t = Int63.((to_int63_ns t + half_microsecond) /% of_int 1000)\n\nlet[@cold] invalid_range_for_1us_rounding t =\n raise_s\n [%message\n \"Span.t exceeds limits\"\n (t : t)\n (min_value_for_1us_rounding : t)\n (max_value_for_1us_rounding : t)]\n;;\n\nlet check_range_for_1us_rounding t =\n if t < min_value_for_1us_rounding || t > max_value_for_1us_rounding\n then invalid_range_for_1us_rounding t\n else t\n;;\n\nlet to_span_float_round_nearest_microsecond t =\n Span_float.of_us\n (Int63.to_float (nearest_microsecond (check_range_for_1us_rounding t)))\n;;\n\nlet min_span_float_value_for_1us_rounding =\n to_span_float_round_nearest min_value_for_1us_rounding\n;;\n\nlet max_span_float_value_for_1us_rounding =\n to_span_float_round_nearest max_value_for_1us_rounding\n;;\n\nlet of_span_float_round_nearest_microsecond s =\n if Span_float.( > ) s max_span_float_value_for_1us_rounding\n || Span_float.( < ) s min_span_float_value_for_1us_rounding\n then\n failwiths\n ~here:[%here]\n \"Time_ns.Span does not support this span\"\n s\n [%sexp_of: Span_float.t];\n (* Using [Time.Span.to_sec] (being the identity) so that\n we make don't apply too many conversion\n - Too many : `[Span.t] -> [a] -> [t]`\n - Only One : `[Span.t]==[a] -> [t]`. *)\n of_sec_with_microsecond_precision (Span_float.to_sec s)\n;;\n\nlet min_value_representable = of_int63_ns Int63.min_value\nlet max_value_representable = of_int63_ns Int63.max_value\n\nmodule Private = struct\n module Parts = Parts\n\n let of_parts = of_parts\n let to_parts = to_parts\nend\n\n(* Legacy definitions based on rounding to the nearest microsecond. *)\nlet min_value = min_value_for_1us_rounding\nlet max_value = max_value_for_1us_rounding\nlet of_span = of_span_float_round_nearest_microsecond\nlet to_span = to_span_float_round_nearest_microsecond\n","open! Import\nmodule Span = Span_ns\n\ntype underlying = Int63.t\n\ntype t = Span.t (* since wall-clock midnight *)\n[@@deriving bin_io, compare, hash, typerep]\n\ninclude (Span : Robustly_comparable.S with type t := t)\n\nlet to_parts t = Span.to_parts t\n\n\nlet start_of_day : t = Span.zero\nlet start_of_next_day : t = Span.day\nlet approximate_end_of_day = Span.( - ) start_of_next_day Span.nanosecond\nlet to_span_since_start_of_day t = t\n\nlet[@cold] input_out_of_bounds span =\n raise_s\n [%message\n \"Time_ns.Ofday.of_span_since_start_of_day_exn: input out of bounds\"\n ~_:(span : Span.t)]\n;;\n\nlet[@inline always] is_invalid span =\n (* Why we use [Span.( > )] rather than [( >= )] below:\n\n We allow to represent the end-of-day sentinel value ([24.000000000h]), which is not\n itself a valid clock face time. However, since valid clock face times readily\n round up to it, it's better to allow it to be represented. *)\n Span.( < ) span start_of_day || Span.( > ) span start_of_next_day\n;;\n\nlet span_since_start_of_day_is_valid span = not (is_invalid span)\nlet of_span_since_start_of_day_unchecked span = span\n\nlet of_span_since_start_of_day_exn span =\n if is_invalid span then input_out_of_bounds span else span\n;;\n\nlet of_span_since_start_of_day_opt span = if is_invalid span then None else Some span\nlet add_exn t span = of_span_since_start_of_day_exn (Span.( + ) t span)\nlet sub_exn t span = of_span_since_start_of_day_exn (Span.( - ) t span)\nlet add t span = of_span_since_start_of_day_opt (Span.( + ) t span)\nlet sub t span = of_span_since_start_of_day_opt (Span.( - ) t span)\nlet next t = of_span_since_start_of_day_opt (Span.next t)\nlet prev t = of_span_since_start_of_day_opt (Span.prev t)\nlet diff t u = Span.( - ) t u\n\nlet create ?hr ?min ?sec ?ms ?us ?ns () =\n (* Similar to [Time.Ofday.create], if we detect a leap second we strip off all\n sub-second elements so that HH:MM:60.XXXXXXXXX is all mapped to HH:MM:60. *)\n let ms, us, ns =\n match sec with\n | Some 60 -> Some 0, Some 0, Some 0\n | _ -> ms, us, ns\n in\n of_span_since_start_of_day_exn (Span.create ?hr ?min ?sec ?ms ?us ?ns ())\n;;\n\nmodule Stable = struct\n module V1 = struct\n module T = struct\n type nonrec t = t [@@deriving compare, bin_io]\n\n let to_string_with_unit =\n let ( / ) = Int63.( / ) in\n let ( mod ) = Int63.rem in\n let ( ! ) = Int63.of_int in\n let i = Int63.to_int_exn in\n fun t ~unit ->\n if Span.( < ) t start_of_day || Span.( < ) start_of_next_day t\n then \"Incorrect day\"\n else (\n let sixty = !60 in\n let thousand = !1000 in\n let ns = Span.to_int63_ns t in\n let us = ns / thousand in\n let ns = ns mod thousand |> i in\n let ms = us / thousand in\n let us = us mod thousand |> i in\n let s = ms / thousand in\n let ms = ms mod thousand |> i in\n let m = s / sixty in\n let s = s mod sixty |> i in\n let h = m / sixty |> i in\n let m = m mod sixty |> i in\n let unit =\n match unit with\n | (`Nanosecond | `Millisecond | `Second) as unit -> unit\n | `Minute_or_less ->\n if ns <> 0\n then `Nanosecond\n else if us <> 0\n then `Microsecond\n else if ms <> 0\n then `Millisecond\n else if s <> 0\n then `Second\n else `Minute\n in\n let len =\n match unit with\n | `Minute -> 5\n | `Second -> 8\n | `Millisecond -> 12\n | `Microsecond -> 15\n | `Nanosecond -> 18\n in\n let str = Bytes.create len in\n Digit_string_helpers.write_2_digit_int str ~pos:0 h;\n Bytes.set str 2 ':';\n Digit_string_helpers.write_2_digit_int str ~pos:3 m;\n (match unit with\n | `Minute -> ()\n | (`Second | `Millisecond | `Microsecond | `Nanosecond) as unit ->\n Bytes.set str 5 ':';\n Digit_string_helpers.write_2_digit_int str ~pos:6 s;\n (match unit with\n | `Second -> ()\n | (`Millisecond | `Microsecond | `Nanosecond) as unit ->\n Bytes.set str 8 '.';\n Digit_string_helpers.write_3_digit_int str ~pos:9 ms;\n (match unit with\n | `Millisecond -> ()\n | (`Microsecond | `Nanosecond) as unit ->\n Digit_string_helpers.write_3_digit_int str ~pos:12 us;\n (match unit with\n | `Microsecond -> ()\n | `Nanosecond -> Digit_string_helpers.write_3_digit_int str ~pos:15 ns))));\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:str)\n ;;\n\n let parse_nanoseconds string ~pos ~until =\n let open Int.O in\n let digits = ref 0 in\n let num_digits = ref 0 in\n let pos = ref pos in\n (* read up to 10 digits; store the first 9, use the 10th to round *)\n while !pos < until && !num_digits < 10 do\n let c = string.[!pos] in\n if Char.is_digit c\n then (\n incr num_digits;\n if !num_digits < 10\n then digits := (!digits * 10) + Char.get_digit_exn c\n else if Char.get_digit_exn c >= 5\n then incr digits\n else ());\n incr pos\n done;\n (* if there are missing digits, add zeroes *)\n if !num_digits < 9 then digits := !digits * Int.pow 10 (9 - !num_digits);\n !digits\n ;;\n\n let create_from_parsed string ~hr ~min ~sec ~subsec_pos ~subsec_len =\n let nanoseconds =\n if Int.equal subsec_len 0\n then 0\n else\n parse_nanoseconds\n string\n ~pos:(subsec_pos + 1)\n ~until:(subsec_pos + subsec_len)\n in\n Span.of_int63_ns (Int63.of_int nanoseconds)\n |> Span.( + ) (Span.scale_int Span.second sec)\n |> Span.( + ) (Span.scale_int Span.minute min)\n |> Span.( + ) (Span.scale_int Span.hour hr)\n |> of_span_since_start_of_day_exn\n ;;\n\n let of_string string = Ofday_helpers.parse string ~f:create_from_parsed\n\n let t_of_sexp sexp : t =\n match sexp with\n | Sexp.List _ -> of_sexp_error \"expected an atom\" sexp\n | Sexp.Atom s ->\n (try of_string s with\n | exn -> of_sexp_error_exn exn sexp)\n ;;\n\n let to_string (t : t) = to_string_with_unit t ~unit:`Nanosecond\n let sexp_of_t (t : t) = Sexp.Atom (to_string t)\n let to_int63 t = Span_ns.Stable.V2.to_int63 t\n\n let of_int63_exn t =\n of_span_since_start_of_day_exn (Span_ns.Stable.V2.of_int63_exn t)\n ;;\n end\n\n include T\n include Comparator.Stable.V1.Make (T)\n end\nend\n\nlet sexp_of_t = Stable.V1.sexp_of_t\nlet t_of_sexp = Stable.V1.t_of_sexp\nlet of_string = Stable.V1.of_string\nlet to_string = Stable.V1.to_string\nlet to_millisecond_string t = Stable.V1.to_string_with_unit t ~unit:`Millisecond\nlet to_sec_string t = Stable.V1.to_string_with_unit t ~unit:`Second\nlet to_string_trimmed t = Stable.V1.to_string_with_unit t ~unit:`Minute_or_less\n\nlet of_string_iso8601_extended ?pos ?len str =\n try\n Ofday_helpers.parse_iso8601_extended ?pos ?len str ~f:Stable.V1.create_from_parsed\n with\n | exn ->\n raise_s\n [%message\n \"Time_ns.Ofday.of_string_iso8601_extended: cannot parse string\"\n ~_:(String.subo str ?pos ?len : string)\n ~_:(exn : exn)]\n;;\n\nlet every =\n let rec every_valid_ofday_span span ~start ~stop ~acc =\n (* Assumes [span], [start], and [stop] are valid ofdays. Assumes [start < stop].\n Assumes [span > 0]. *)\n let acc = start :: acc in\n let start = Span.( + ) start span in\n if Span.( > ) start stop (* cannot overflow *)\n then List.rev acc\n else every_valid_ofday_span span ~start ~stop ~acc\n in\n (* internal [every] named to show up in stack traces *)\n let every span ~start ~stop =\n if Span.( > ) start stop\n then\n Or_error.error_s\n [%message\n \"[Time_ns.Ofday.every] called with [start] > [stop]\" (start : t) (stop : t)]\n else if Span.( <= ) span Span.zero\n then\n Or_error.error_s\n [%message \"[Time_ns.Ofday.every] called with negative span\" ~_:(span : Span.t)]\n else if is_invalid span\n then Ok [ start ]\n else Ok (every_valid_ofday_span span ~start ~stop ~acc:[])\n in\n every\n;;\n\nlet small_diff =\n let hour = Span.to_int63_ns Span.hour in\n fun ofday1 ofday2 ->\n let open Int63.O in\n let ofday1 = Span.to_int63_ns (to_span_since_start_of_day ofday1) in\n let ofday2 = Span.to_int63_ns (to_span_since_start_of_day ofday2) in\n let diff = ofday1 - ofday2 in\n (* d1 is in (-hour; hour) *)\n let d1 = Int63.rem diff hour in\n (* d2 is in (0;hour) *)\n let d2 = Int63.rem (d1 + hour) hour in\n let d = if d2 > hour / Int63.of_int 2 then d2 - hour else d2 in\n Span.of_int63_ns d\n;;\n\nlet%expect_test \"small_diff\" =\n let test x y =\n let diff = small_diff x y in\n printf !\"small_diff %s %s = %s\\n\" (to_string x) (to_string y) (Span.to_string diff)\n in\n let examples =\n List.map\n ~f:(fun (x, y) -> of_string x, of_string y)\n [ \"12:00\", \"12:05\"; \"12:58\", \"13:02\"; \"00:52\", \"23:19\"; \"00:00\", \"24:00\" ]\n in\n List.iter examples ~f:(fun (x, y) ->\n test x y;\n test y x);\n [%expect\n {|\n small_diff 12:00:00.000000000 12:05:00.000000000 = -5m\n small_diff 12:05:00.000000000 12:00:00.000000000 = 5m\n small_diff 12:58:00.000000000 13:02:00.000000000 = -4m\n small_diff 13:02:00.000000000 12:58:00.000000000 = 4m\n small_diff 00:52:00.000000000 23:19:00.000000000 = -27m\n small_diff 23:19:00.000000000 00:52:00.000000000 = 27m\n small_diff 00:00:00.000000000 24:00:00.000000000 = 0s\n small_diff 24:00:00.000000000 00:00:00.000000000 = 0s |}]\n;;\n\nlet gen_incl = Span.gen_incl\nlet gen_uniform_incl = Span.gen_uniform_incl\nlet quickcheck_generator = gen_incl start_of_day start_of_next_day\nlet quickcheck_observer = Span.quickcheck_observer\nlet quickcheck_shrinker = Quickcheck.Shrinker.empty ()\n\ninclude Identifiable.Make (struct\n type nonrec t = t [@@deriving bin_io, compare, hash, sexp]\n\n let module_name = \"Core.Time_ns.Ofday\"\n let hash = Span.hash\n let of_string, to_string = of_string, to_string\n end)\n\ninclude (Span : Comparisons.S with type t := t)\n\n(* deprecated bindings *)\nlet of_span_since_start_of_day = of_span_since_start_of_day_exn\nlet to_millisec_string = to_millisecond_string\n","open! Import\n\nmodule Stable = struct\n module Allocation_policy = struct\n module V1 = struct\n type t =\n | Next_fit\n | First_fit\n | Best_fit\n [@@deriving bin_io, compare, equal, hash, sexp]\n end\n end\nend\n\ninclude Caml.Gc\n\nmodule Stat = struct\n module T = struct\n [%%if ocaml_version >= (4, 12, 0)]\n\n type t = Caml.Gc.stat =\n { minor_words : float\n ; promoted_words : float\n ; major_words : float\n ; minor_collections : int\n ; major_collections : int\n ; heap_words : int\n ; heap_chunks : int\n ; live_words : int\n ; live_blocks : int\n ; free_words : int\n ; free_blocks : int\n ; largest_free : int\n ; fragments : int\n ; compactions : int\n ; top_heap_words : int\n ; stack_size : int\n ; forced_major_collections : int\n }\n [@@deriving compare, hash, bin_io, sexp, fields]\n\n [%%else]\n\n type t = Caml.Gc.stat =\n { minor_words : float\n ; promoted_words : float\n ; major_words : float\n ; minor_collections : int\n ; major_collections : int\n ; heap_words : int\n ; heap_chunks : int\n ; live_words : int\n ; live_blocks : int\n ; free_words : int\n ; free_blocks : int\n ; largest_free : int\n ; fragments : int\n ; compactions : int\n ; top_heap_words : int\n ; stack_size : int\n }\n [@@deriving compare, hash, bin_io, sexp, fields]\n\n [%%endif]\n end\n\n include T\n include Comparable.Make (T)\nend\n\nmodule Control = struct\n module T = struct\n [%%if\n ocaml_version < (4, 08, 0)]\n\n type t = Caml.Gc.control =\n { mutable minor_heap_size : int\n ; mutable major_heap_increment : int\n ; mutable space_overhead : int\n ; mutable verbose : int\n ; mutable max_overhead : int\n ; mutable stack_limit : int\n ; mutable allocation_policy : int\n ; window_size : int\n }\n [@@deriving compare, bin_io, sexp, fields]\n\n [%%else]\n\n [@@@ocaml.warning \"-3\"]\n\n type t = Caml.Gc.control =\n { mutable minor_heap_size : int\n ; mutable major_heap_increment : int\n ; mutable space_overhead : int\n ; mutable verbose : int\n ; mutable max_overhead : int\n ; mutable stack_limit : int\n ; mutable allocation_policy : int\n ; window_size : int\n ; custom_major_ratio : int\n ; custom_minor_ratio : int\n ; custom_minor_max_size : int\n }\n [@@deriving compare, bin_io, sexp, fields]\n\n [%%endif]\n end\n\n include T\n include Comparable.Make (T)\nend\n\nmodule Allocation_policy = struct\n include Stable.Allocation_policy.V1\n\n let to_int = function\n | Next_fit -> 0\n | First_fit -> 1\n | Best_fit -> 2\n ;;\nend\n\n[%%if\n ocaml_version < (4, 08, 0)]\n\nlet tune\n ?logger\n ?minor_heap_size\n ?major_heap_increment\n ?space_overhead\n ?verbose\n ?max_overhead\n ?stack_limit\n ?allocation_policy\n ?window_size\n ()\n =\n let old_control_params = get () in\n let f opt to_string field =\n let old_value = Field.get field old_control_params in\n match opt with\n | None -> old_value\n | Some new_value ->\n Option.iter logger ~f:(fun f ->\n Printf.ksprintf\n f\n \"Gc.Control.%s: %s -> %s\"\n (Field.name field)\n (to_string old_value)\n (to_string new_value));\n new_value\n in\n let allocation_policy = Option.map allocation_policy ~f:Allocation_policy.to_int in\n let new_control_params =\n Control.Fields.map\n ~minor_heap_size:(f minor_heap_size string_of_int)\n ~major_heap_increment:(f major_heap_increment string_of_int)\n ~space_overhead:(f space_overhead string_of_int)\n ~verbose:(f verbose string_of_int)\n ~max_overhead:(f max_overhead string_of_int)\n ~stack_limit:(f stack_limit string_of_int)\n ~allocation_policy:(f allocation_policy string_of_int)\n ~window_size:(f window_size string_of_int)\n in\n set new_control_params\n;;\n\n[%%else]\n\nlet tune\n ?logger\n ?minor_heap_size\n ?major_heap_increment\n ?space_overhead\n ?verbose\n ?max_overhead\n ?stack_limit\n ?allocation_policy\n ?window_size\n ?custom_major_ratio\n ?custom_minor_ratio\n ?custom_minor_max_size\n ()\n =\n let old_control_params = get () in\n let f opt to_string field =\n let old_value = Field.get field old_control_params in\n match opt with\n | None -> old_value\n | Some new_value ->\n Option.iter logger ~f:(fun f ->\n Printf.ksprintf\n f\n \"Gc.Control.%s: %s -> %s\"\n (Field.name field)\n (to_string old_value)\n (to_string new_value));\n new_value\n in\n let allocation_policy = Option.map allocation_policy ~f:Allocation_policy.to_int in\n let new_control_params =\n Control.Fields.map\n ~minor_heap_size:(f minor_heap_size string_of_int)\n ~major_heap_increment:(f major_heap_increment string_of_int)\n ~space_overhead:(f space_overhead string_of_int)\n ~verbose:(f verbose string_of_int)\n ~max_overhead:(f max_overhead string_of_int)\n ~stack_limit:(f stack_limit string_of_int)\n ~allocation_policy:(f allocation_policy string_of_int)\n ~window_size:(f window_size string_of_int)\n ~custom_major_ratio:(f custom_major_ratio string_of_int)\n ~custom_minor_ratio:(f custom_minor_ratio string_of_int)\n ~custom_minor_max_size:(f custom_minor_max_size string_of_int)\n in\n set new_control_params\n;;\n\n[%%endif]\n\nlet disable_compaction ?logger ~allocation_policy () =\n let allocation_policy =\n match allocation_policy with\n | `Don't_change -> None\n | `Set_to policy -> Some policy\n in\n (* The value 1_000_000, according to\n http://caml.inria.fr/pub/docs/manual-ocaml-4.02/libref/Gc.html\n will disable compactions.\n *)\n tune ?logger ?allocation_policy ~max_overhead:1_000_000 ()\n;;\n\nexternal minor_words : unit -> int = \"core_kernel_gc_minor_words\"\nexternal major_words : unit -> int = \"core_kernel_gc_major_words\" [@@noalloc]\nexternal promoted_words : unit -> int = \"core_kernel_gc_promoted_words\" [@@noalloc]\nexternal minor_collections : unit -> int = \"core_kernel_gc_minor_collections\" [@@noalloc]\nexternal major_collections : unit -> int = \"core_kernel_gc_major_collections\" [@@noalloc]\nexternal heap_words : unit -> int = \"core_kernel_gc_heap_words\" [@@noalloc]\nexternal heap_chunks : unit -> int = \"core_kernel_gc_heap_chunks\" [@@noalloc]\nexternal compactions : unit -> int = \"core_kernel_gc_compactions\" [@@noalloc]\nexternal top_heap_words : unit -> int = \"core_kernel_gc_top_heap_words\" [@@noalloc]\nexternal major_plus_minor_words : unit -> int = \"core_kernel_gc_major_plus_minor_words\"\nexternal allocated_words : unit -> int = \"core_kernel_gc_allocated_words\"\n\nlet zero = Sys.opaque_identity (int_of_string \"0\")\n\n(* The compiler won't optimize int_of_string away so it won't\n perform constant folding below. *)\nlet rec keep_alive o = if zero <> 0 then keep_alive (Sys.opaque_identity o)\n\nmodule For_testing = struct\n let prepare_heap_to_count_minor_allocation () =\n (* We call [minor] to empty the minor heap, so that our allocation is unlikely to\n trigger a minor gc. *)\n minor ();\n (* We allocate two words in case the [Gc.minor] finishes a major gc cycle, in which\n case it requests a minor gc to occur at the next minor allocation. We don't want\n the subsequent minor allocation to trigger a minor GC, because there is a bug\n (https://github.com/ocaml/ocaml/issues/7798) in the OCaml runtime that double\n counts [Gc.minor_words] in that case. *)\n ignore (Sys.opaque_identity (ref (Sys.opaque_identity 1)) : int ref)\n ;;\n\n (* We disable inlining for this function so the GC stats and the call to [f] are never\n rearranged. *)\n let[@cold] measure_internal ~on_result f =\n let minor_words_before = minor_words () in\n let major_words_before = major_words () in\n (* We wrap [f ()] with [Sys.opaque_identity] to prevent the return value from being\n optimized away. *)\n let x = Sys.opaque_identity (f ()) in\n let minor_words_after = minor_words () in\n let major_words_after = major_words () in\n let major_words_allocated = major_words_after - major_words_before in\n let minor_words_allocated = minor_words_after - minor_words_before in\n on_result ~major_words_allocated ~minor_words_allocated x\n ;;\n\n let is_zero_alloc (type a) (f : unit -> a) =\n (* Instead of using [Allocation_report.measure], and matching on the result, we use\n this construction, in order to have [is_zero_alloc] not allocate itself. This\n enables [is_zero_alloc] to be used in a nested way.\n\n This also means we cannot call [prepare_heap_to_count_minor_allocation]. This is\n okay, since we do not need a precise count, we only need to check if the count is\n zero or not. *)\n measure_internal\n f\n ~on_result:(fun ~major_words_allocated ~minor_words_allocated value ->\n ignore (Sys.opaque_identity value : a);\n major_words_allocated == 0 && minor_words_allocated == 0)\n ;;\n\n module Allocation_report = struct\n type t =\n { major_words_allocated : int\n ; minor_words_allocated : int\n }\n\n let create ~major_words_allocated ~minor_words_allocated =\n { major_words_allocated; minor_words_allocated }\n ;;\n end\n\n let measure_allocation f =\n prepare_heap_to_count_minor_allocation ();\n measure_internal f ~on_result:(fun ~major_words_allocated ~minor_words_allocated x ->\n x, Allocation_report.create ~major_words_allocated ~minor_words_allocated)\n ;;\nend\n\nmodule Expert = struct\n let add_finalizer x f =\n try Caml.Gc.finalise (fun x -> Exn.handle_uncaught_and_exit (fun () -> f x)) x with\n | Invalid_argument _ ->\n (* The type of add_finalizer ensures that the only possible failure\n is due to [x] being static data. In this case, we simply drop the\n finalizer since static data would never have been collected by the\n GC anyway. *)\n ()\n ;;\n\n (* [add_finalizer_exn] is the same as [add_finalizer]. However, their types in\n core_gc.mli are different, and the type of [add_finalizer] guarantees that it always\n receives a heap block, which ensures that it will not raise, while\n [add_finalizer_exn] accepts any type, and so may raise. *)\n let add_finalizer_exn x f =\n try Caml.Gc.finalise (fun x -> Exn.handle_uncaught_and_exit (fun () -> f x)) x with\n | Invalid_argument _ ->\n ignore (Heap_block.create x : _ Heap_block.t option);\n (* If [Heap_block.create] succeeds then [x] is static data and so\n we can simply drop the finaliser. *)\n ()\n ;;\n\n let add_finalizer_last x f =\n try Caml.Gc.finalise_last (fun () -> Exn.handle_uncaught_and_exit f) x with\n | Invalid_argument _ ->\n (* The type of add_finalizer_last ensures that the only possible failure\n is due to [x] being static data. In this case, we simply drop the\n finalizer since static data would never have been collected by the\n GC anyway. *)\n ()\n ;;\n\n let add_finalizer_last_exn x f =\n try Caml.Gc.finalise_last (fun () -> Exn.handle_uncaught_and_exit f) x with\n | Invalid_argument _ ->\n ignore (Heap_block.create x : _ Heap_block.t option);\n (* If [Heap_block.create] succeeds then [x] is static data and so\n we can simply drop the finaliser. *)\n ()\n ;;\n\n let finalize_release = Caml.Gc.finalise_release\n\n module Alarm = struct\n type t = alarm\n\n let sexp_of_t _ = \"\" |> [%sexp_of: string]\n let create f = create_alarm (fun () -> Exn.handle_uncaught_and_exit f)\n let delete = delete_alarm\n end\nend\n","open Format\n\nlet rev_split l =\n let rec inner xs ys = function\n | (x, y) :: xys ->\n inner (x::xs) (y::ys) xys\n | [] -> (xs, ys)\n in\n inner [] [] l\n\ntype wrap = [\n | `Wrap_atoms\n | `Always_wrap\n | `Never_wrap\n | `Force_breaks\n | `Force_breaks_rec\n | `No_breaks\n]\n\ntype label_break = [\n | `Auto\n | `Always\n | `Always_rec\n | `Never\n]\n\ntype style_name = string\ntype style = {\n tag_open : string;\n tag_close : string\n}\n\ntype atom_param = {\n atom_style : style_name option;\n}\n\nlet atom = {\n atom_style = None\n}\n\ntype list_param = {\n space_after_opening : bool;\n space_after_separator : bool;\n space_before_separator : bool;\n separators_stick_left : bool;\n space_before_closing : bool;\n stick_to_label : bool;\n align_closing : bool;\n wrap_body : wrap;\n indent_body : int;\n list_style : style_name option;\n opening_style : style_name option;\n body_style : style_name option;\n separator_style : style_name option;\n closing_style : style_name option;\n}\n\nlet list = {\n space_after_opening = true;\n space_after_separator = true;\n space_before_separator = false;\n separators_stick_left = true;\n space_before_closing = true;\n stick_to_label = true;\n align_closing = true;\n wrap_body = `Wrap_atoms;\n indent_body = 2;\n list_style = None;\n opening_style = None;\n body_style = None;\n separator_style = None;\n closing_style = None;\n}\n\ntype label_param = {\n label_break: label_break;\n space_after_label : bool;\n indent_after_label : int;\n label_style : style_name option;\n}\n\nlet label = {\n label_break = `Auto;\n space_after_label = true;\n indent_after_label = 2;\n label_style = None;\n}\n\ntype t =\n Atom of string * atom_param\n | List of (string * string * string * list_param) * t list\n | Label of (t * label_param) * t\n | Custom of (formatter -> unit)\n\ntype escape =\n [ `None\n | `Escape of\n ((string -> int -> int -> unit) -> string -> int -> int -> unit)\n | `Escape_string of (string -> string) ]\n\ntype styles = (style_name * style) list\n\n(*\n Transform a tree starting from the leaves, propagating and merging\n accumulators until reaching the root.\n*)\nlet propagate_from_leaf_to_root\n ~init_acc (* create initial accumulator for a leaf *)\n ~merge_acc (* merge two accumulators coming from child nodes *)\n ~map_node (* (node, acc) -> (node, acc) *)\n x =\n\n let rec aux x =\n match x with\n | Atom _ ->\n let acc = init_acc x in\n map_node x acc\n | List (param, children) ->\n let new_children, accs = rev_split (List.rev_map aux children) in\n let acc = List.fold_left merge_acc (init_acc x) accs in\n map_node (List (param, new_children)) acc\n | Label ((x1, param), x2) ->\n let acc0 = init_acc x in\n let new_x1, acc1 = aux x1 in\n let new_x2, acc2 = aux x2 in\n let acc = merge_acc (merge_acc acc0 acc1) acc2 in\n map_node (Label ((new_x1, param), new_x2)) acc\n | Custom _ ->\n let acc = init_acc x in\n map_node x acc\n in\n aux x\n\n(*\n Convert wrappable lists into vertical lists if any of their descendants\n has the attribute wrap_body = `Force_breaks_rec.\n*)\nlet propagate_forced_breaks x =\n (* acc = whether to force breaks in wrappable lists or labels *)\n let init_acc = function\n | List ((_, _, _, { wrap_body = `Force_breaks_rec; _ }), _)\n | Label ((_, { label_break = `Always_rec; _ }), _) -> true\n | Atom _\n | Label _\n | Custom _\n | List _ -> false\n in\n let merge_acc force_breaks1 force_breaks2 =\n force_breaks1 || force_breaks2\n in\n let map_node x force_breaks =\n match x with\n | List ((_, _, _, { wrap_body = `Force_breaks_rec; _ }), _) -> x, true\n | List ((_, _, _, { wrap_body = `Force_breaks; _ }), _) -> x, force_breaks\n\n | List ((op, sep, cl, ({ wrap_body = (`Wrap_atoms\n | `Never_wrap\n | `Always_wrap); _ } as p)),\n children) ->\n if force_breaks then\n let p = { p with wrap_body = `Force_breaks } in\n List ((op, sep, cl, p), children), true\n else\n x, false\n\n | Label ((a, ({ label_break = `Auto; _ } as lp)), b) ->\n if force_breaks then\n let lp = { lp with label_break = `Always } in\n Label ((a, lp), b), true\n else\n x, false\n\n | List ((_, _, _, { wrap_body = `No_breaks; _ }), _)\n | Label ((_, { label_break = (`Always | `Always_rec | `Never); _ }), _)\n | Atom _\n | Custom _ -> x, force_breaks\n in\n let new_x, _forced_breaks =\n propagate_from_leaf_to_root\n ~init_acc\n ~merge_acc\n ~map_node\n x\n in\n new_x\n\nmodule Pretty =\nstruct\n (*\n Rewrite the tree to be printed.\n Currently, this is used only to handle `Force_breaks_rec.\n *)\n let rewrite x = propagate_forced_breaks x\n\n (*\n Relies on the fact that mark_open_tag and mark_close_tag\n are called exactly once before calling pp_output_string once.\n It's a reasonable assumption although not guaranteed by the\n documentation of the Format module.\n *)\n let set_escape fmt escape =\n let print0, flush0 = pp_get_formatter_output_functions fmt () in\n let tagf0 = pp_get_formatter_tag_functions fmt () in\n\n let is_tag = ref false in\n\n let mot tag =\n is_tag := true;\n tagf0.mark_open_tag tag\n in\n\n let mct tag =\n is_tag := true;\n tagf0.mark_close_tag tag\n in\n\n let print s p n =\n if !is_tag then\n (print0 s p n;\n is_tag := false)\n else\n escape print0 s p n\n in\n\n let tagf = {\n tagf0 with\n mark_open_tag = mot;\n mark_close_tag = mct\n }\n in\n pp_set_formatter_output_functions fmt print flush0;\n pp_set_formatter_tag_functions fmt tagf\n\n\n let set_escape_string fmt esc =\n let escape print s p n =\n let s0 = String.sub s p n in\n let s1 = esc s0 in\n print s1 0 (String.length s1)\n in\n set_escape fmt escape\n\n\n let define_styles fmt escape l =\n if l <> [] then (\n pp_set_tags fmt true;\n let tbl1 = Hashtbl.create (2 * List.length l) in\n let tbl2 = Hashtbl.create (2 * List.length l) in\n List.iter (\n fun (style_name, style) ->\n Hashtbl.add tbl1 style_name style.tag_open;\n Hashtbl.add tbl2 style_name style.tag_close\n ) l;\n let mark_open_tag style_name =\n try Hashtbl.find tbl1 style_name\n with Not_found -> \"\"\n in\n let mark_close_tag style_name =\n try Hashtbl.find tbl2 style_name\n with Not_found -> \"\"\n in\n\n let tagf = {\n (pp_get_formatter_tag_functions fmt ()) with\n mark_open_tag = mark_open_tag;\n mark_close_tag = mark_close_tag\n }\n in\n pp_set_formatter_tag_functions fmt tagf\n );\n\n (match escape with\n `None -> ()\n | `Escape esc -> set_escape fmt esc\n | `Escape_string esc -> set_escape_string fmt esc)\n\n\n let pp_open_xbox fmt p indent =\n match p.wrap_body with\n `Always_wrap\n | `Never_wrap\n | `Wrap_atoms -> pp_open_hvbox fmt indent\n | `Force_breaks\n | `Force_breaks_rec -> pp_open_vbox fmt indent\n | `No_breaks -> pp_open_hbox fmt ()\n\n let extra_box p l =\n let wrap =\n match p.wrap_body with\n `Always_wrap -> true\n | `Never_wrap\n | `Force_breaks\n | `Force_breaks_rec\n | `No_breaks -> false\n | `Wrap_atoms ->\n List.for_all (function Atom _ -> true | _ -> false) l\n in\n if wrap then\n ((fun fmt -> pp_open_hovbox fmt 0),\n (fun fmt -> pp_close_box fmt ()))\n else\n ((fun _ -> ()),\n (fun _ -> ()))\n\n\n let pp_open_nonaligned_box fmt p indent l =\n match p.wrap_body with\n `Always_wrap -> pp_open_hovbox fmt indent\n | `Never_wrap -> pp_open_hvbox fmt indent\n | `Wrap_atoms ->\n if List.for_all (function Atom _ -> true | _ -> false) l then\n pp_open_hovbox fmt indent\n else\n pp_open_hvbox fmt indent\n | `Force_breaks\n | `Force_breaks_rec -> pp_open_vbox fmt indent\n | `No_breaks -> pp_open_hbox fmt ()\n\n\n let open_tag fmt = function\n None -> ()\n | Some s -> pp_open_tag fmt s\n\n let close_tag fmt = function\n None -> ()\n | Some _ -> pp_close_tag fmt ()\n\n let tag_string fmt o s =\n match o with\n None -> pp_print_string fmt s\n | Some tag ->\n pp_open_tag fmt tag;\n pp_print_string fmt s;\n pp_close_tag fmt ()\n\n let rec fprint_t fmt = function\n Atom (s, p) ->\n tag_string fmt p.atom_style s;\n\n | List ((_, _, _, p) as param, l) ->\n open_tag fmt p.list_style;\n if p.align_closing then\n fprint_list fmt None param l\n else\n fprint_list2 fmt param l;\n close_tag fmt p.list_style\n\n | Label (label, x) -> fprint_pair fmt label x\n | Custom f -> f fmt\n\n and fprint_list_body_stick_left fmt p sep hd tl =\n open_tag fmt p.body_style;\n fprint_t fmt hd;\n List.iter (\n fun x ->\n if p.space_before_separator then\n pp_print_string fmt \" \";\n tag_string fmt p.separator_style sep;\n if p.space_after_separator then\n pp_print_space fmt ()\n else\n pp_print_cut fmt ();\n fprint_t fmt x\n ) tl;\n close_tag fmt p.body_style\n\n and fprint_list_body_stick_right fmt p sep hd tl =\n open_tag fmt p.body_style;\n fprint_t fmt hd;\n List.iter (\n fun x ->\n if p.space_before_separator then\n pp_print_space fmt ()\n else\n pp_print_cut fmt ();\n tag_string fmt p.separator_style sep;\n if p.space_after_separator then\n pp_print_string fmt \" \";\n fprint_t fmt x\n ) tl;\n close_tag fmt p.body_style\n\n and fprint_opt_label fmt = function\n None -> ()\n | Some (lab, lp) ->\n open_tag fmt lp.label_style;\n fprint_t fmt lab;\n close_tag fmt lp.label_style;\n if lp.space_after_label then\n pp_print_string fmt \" \"\n\n (* Either horizontal or vertical list *)\n and fprint_list fmt label ((op, _sep, cl, p) as param) = function\n [] ->\n fprint_opt_label fmt label;\n tag_string fmt p.opening_style op;\n if p.space_after_opening || p.space_before_closing then\n pp_print_string fmt \" \";\n tag_string fmt p.closing_style cl\n\n | hd :: tl as l ->\n\n if tl = [] || p.separators_stick_left then\n fprint_list_stick_left fmt label param hd tl l\n else\n fprint_list_stick_right fmt label param hd tl l\n\n\n and fprint_list_stick_left fmt label (op, sep, cl, p) hd tl l =\n let indent = p.indent_body in\n pp_open_xbox fmt p indent;\n fprint_opt_label fmt label;\n\n tag_string fmt p.opening_style op;\n\n if p.space_after_opening then\n pp_print_space fmt ()\n else\n pp_print_cut fmt ();\n\n let open_extra, close_extra = extra_box p l in\n open_extra fmt;\n fprint_list_body_stick_left fmt p sep hd tl;\n close_extra fmt;\n\n if p.space_before_closing then\n pp_print_break fmt 1 (-indent)\n else\n pp_print_break fmt 0 (-indent);\n tag_string fmt p.closing_style cl;\n pp_close_box fmt ()\n\n and fprint_list_stick_right fmt label (op, sep, cl, p) hd tl l =\n let base_indent = p.indent_body in\n let sep_indent =\n String.length sep + (if p.space_after_separator then 1 else 0)\n in\n let indent = base_indent + sep_indent in\n\n pp_open_xbox fmt p indent;\n fprint_opt_label fmt label;\n\n tag_string fmt p.opening_style op;\n\n if p.space_after_opening then\n pp_print_space fmt ()\n else\n pp_print_cut fmt ();\n\n let open_extra, close_extra = extra_box p l in\n open_extra fmt;\n\n fprint_t fmt hd;\n List.iter (\n fun x ->\n if p.space_before_separator then\n pp_print_break fmt 1 (-sep_indent)\n else\n pp_print_break fmt 0 (-sep_indent);\n tag_string fmt p.separator_style sep;\n if p.space_after_separator then\n pp_print_string fmt \" \";\n fprint_t fmt x\n ) tl;\n\n close_extra fmt;\n\n if p.space_before_closing then\n pp_print_break fmt 1 (-indent)\n else\n pp_print_break fmt 0 (-indent);\n tag_string fmt p.closing_style cl;\n pp_close_box fmt ()\n\n\n\n (* align_closing = false *)\n and fprint_list2 fmt (op, sep, cl, p) = function\n [] ->\n tag_string fmt p.opening_style op;\n if p.space_after_opening || p.space_before_closing then\n pp_print_string fmt \" \";\n tag_string fmt p.closing_style cl\n\n | hd :: tl as l ->\n tag_string fmt p.opening_style op;\n if p.space_after_opening then\n pp_print_string fmt \" \";\n\n pp_open_nonaligned_box fmt p 0 l ;\n if p.separators_stick_left then\n fprint_list_body_stick_left fmt p sep hd tl\n else\n fprint_list_body_stick_right fmt p sep hd tl;\n pp_close_box fmt ();\n\n if p.space_before_closing then\n pp_print_string fmt \" \";\n tag_string fmt p.closing_style cl\n\n\n (* Printing a label:value pair.\n\n The opening bracket stays on the same line as the key, no matter what,\n and the closing bracket is either on the same line\n or vertically aligned with the beginning of the key.\n *)\n and fprint_pair fmt ((lab, lp) as label) x =\n match x with\n List ((op, sep, cl, p), l) when p.stick_to_label && p.align_closing ->\n fprint_list fmt (Some label) (op, sep, cl, p) l\n\n | _ ->\n let indent = lp.indent_after_label in\n pp_open_hvbox fmt 0;\n\n open_tag fmt lp.label_style;\n fprint_t fmt lab;\n close_tag fmt lp.label_style;\n\n (match lp.label_break with\n | `Auto ->\n if lp.space_after_label then\n pp_print_break fmt 1 indent\n else\n pp_print_break fmt 0 indent\n | `Always\n | `Always_rec ->\n pp_force_newline fmt ();\n pp_print_string fmt (String.make indent ' ')\n | `Never ->\n if lp.space_after_label then\n pp_print_char fmt ' '\n else\n ()\n );\n fprint_t fmt x;\n pp_close_box fmt ()\n\n let to_formatter fmt x =\n let x = rewrite x in\n fprint_t fmt x;\n pp_print_flush fmt ()\n\n let to_buffer ?(escape = `None) ?(styles = []) buf x =\n let fmt = Format.formatter_of_buffer buf in\n define_styles fmt escape styles;\n to_formatter fmt x\n\n let to_string ?escape ?styles x =\n let buf = Buffer.create 500 in\n to_buffer ?escape ?styles buf x;\n Buffer.contents buf\n\n let to_channel ?(escape = `None) ?(styles = []) oc x =\n let fmt = formatter_of_out_channel oc in\n define_styles fmt escape styles;\n to_formatter fmt x\n\n let to_stdout ?escape ?styles x = to_channel ?escape ?styles stdout x\n let to_stderr ?escape ?styles x = to_channel ?escape ?styles stderr x\n\nend\n\n\n\n\nmodule Compact =\nstruct\n open Printf\n\n let rec fprint_t buf = function\n Atom (s, _) -> Buffer.add_string buf s\n | List (param, l) -> fprint_list buf param l\n | Label (label, x) -> fprint_pair buf label x\n | Custom f ->\n (* Will most likely not be compact *)\n let fmt = formatter_of_buffer buf in\n f fmt;\n pp_print_flush fmt ()\n\n and fprint_list buf (op, sep, cl, _) = function\n [] -> bprintf buf \"%s%s\" op cl\n | x :: tl ->\n Buffer.add_string buf op;\n fprint_t buf x;\n List.iter (\n fun x ->\n Buffer.add_string buf sep;\n fprint_t buf x\n ) tl;\n Buffer.add_string buf cl\n\n and fprint_pair buf (label, _) x =\n fprint_t buf label;\n fprint_t buf x\n\n\n let to_buffer buf x = fprint_t buf x\n\n let to_string x =\n let buf = Buffer.create 500 in\n to_buffer buf x;\n Buffer.contents buf\n\n let to_formatter fmt x =\n let s = to_string x in\n Format.fprintf fmt \"%s\" s;\n pp_print_flush fmt ()\n\n let to_channel oc x =\n let buf = Buffer.create 500 in\n to_buffer buf x;\n Buffer.output_buffer oc buf\n\n let to_stdout x = to_channel stdout x\n let to_stderr x = to_channel stderr x\nend\n\n\n\n\n(* Obsolete *)\nmodule Param =\nstruct\n let list_true = {\n space_after_opening = true;\n space_after_separator = true;\n space_before_separator = true;\n separators_stick_left = true;\n space_before_closing = true;\n stick_to_label = true;\n align_closing = true;\n wrap_body = `Wrap_atoms;\n indent_body = 2;\n list_style = None;\n opening_style = None;\n body_style = None;\n separator_style = None;\n closing_style = None;\n }\n\n let list_false = {\n space_after_opening = false;\n space_after_separator = false;\n space_before_separator = false;\n separators_stick_left = false;\n space_before_closing = false;\n stick_to_label = false;\n align_closing = false;\n wrap_body = `Wrap_atoms;\n indent_body = 2;\n list_style = None;\n opening_style = None;\n body_style = None;\n separator_style = None;\n closing_style = None;\n }\n\n let label_true = {\n label_break = `Auto;\n space_after_label = true;\n indent_after_label = 2;\n label_style = None;\n }\n\n let label_false = {\n label_break = `Auto;\n space_after_label = false;\n indent_after_label = 2;\n label_style = None;\n }\nend\n","# 1 \"common.ml\"\nlet version = \"1.7.0\"\n\nexception Json_error of string\n\nlet json_error s = raise (Json_error s)\n\nexception End_of_array\nexception End_of_object\nexception End_of_tuple\nexception End_of_input\n\ntype in_param = {\n string_buf : Buffer.t\n}\n\nlet create_in_param ?(len = 256) () = {\n string_buf = Buffer.create len\n}\n\n\nlet utf8_of_code buf x =\n let add = Bi_outbuf.add_char in\n\n (* Straight <= doesn't work with signed 31-bit ints *)\n let maxbits n x = x lsr n = 0 in\n\n if maxbits 7 x then\n (* 7 *)\n add buf (Char.chr x)\n else if maxbits 11 x then (\n (* 5 + 6 *)\n add buf (Char.chr (0b11000000 lor ((x lsr 6) land 0b00011111)));\n add buf (Char.chr (0b10000000 lor (x land 0b00111111)))\n )\n else if maxbits 16 x then (\n (* 4 + 6 + 6 *)\n add buf (Char.chr (0b11100000 lor ((x lsr 12) land 0b00001111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 6) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor (x land 0b00111111)))\n )\n else if maxbits 21 x then (\n (* 3 + 6 + 6 + 6 *)\n add buf (Char.chr (0b11110000 lor ((x lsr 18) land 0b00000111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 12) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 6) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor (x land 0b00111111)));\n )\n else if maxbits 26 x then (\n (* 2 + 6 + 6 + 6 + 6 *)\n add buf (Char.chr (0b11111000 lor ((x lsr 24) land 0b00000011)));\n add buf (Char.chr (0b10000000 lor ((x lsr 18) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 12) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 6) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor (x land 0b00111111)));\n )\n else (\n assert (maxbits 31 x);\n (* 1 + 6 + 6 + 6 + 6 + 6 *)\n add buf (Char.chr (0b11111100 lor ((x lsr 30) land 0b00000001)));\n add buf (Char.chr (0b10000000 lor ((x lsr 24) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 18) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 12) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor ((x lsr 6) land 0b00111111)));\n add buf (Char.chr (0b10000000 lor (x land 0b00111111)));\n )\n\nlet code_of_surrogate_pair i j =\n let high10 = i - 0xD800 in\n let low10 = j - 0xDC00 in\n 0x10000 + ((high10 lsl 10) lor low10)\n\nlet utf8_of_surrogate_pair buf i j =\n utf8_of_code buf (code_of_surrogate_pair i j)\n\nlet is_object_or_array x =\n match x with\n `List _\n | `Assoc _ -> true\n | _ -> false\n\n\ntype lexer_state = {\n buf : Bi_outbuf.t;\n (* Buffer used to accumulate substrings *)\n\n mutable lnum : int;\n (* Current line number (starting from 1) *)\n\n mutable bol : int;\n (* Absolute position of the first character of the current line\n (starting from 0) *)\n\n mutable fname : string option;\n (* Name describing the input file *)\n}\n\nmodule Lexer_state =\nstruct\n type t = lexer_state = {\n buf : Bi_outbuf.t;\n mutable lnum : int;\n mutable bol : int;\n mutable fname : string option;\n }\nend\n\nlet init_lexer ?buf ?fname ?(lnum = 1) () =\n let buf =\n match buf with\n\tNone -> Bi_outbuf.create 256\n | Some buf -> buf\n in\n {\n buf = buf;\n lnum = lnum;\n bol = 0;\n fname = fname\n }\n\n# 1 \"type.ml\"\n(** {3 Type of the JSON tree} *)\n\ntype t =\n [\n | `Null\n | `Bool of bool\n \n# 8 \"type.ml\"\n | `Int of int\n \n# 11 \"type.ml\"\n | `Intlit of string\n \n# 14 \"type.ml\"\n | `Float of float\n \n# 17 \"type.ml\"\n | `Floatlit of string\n \n# 20 \"type.ml\"\n | `String of string\n \n# 23 \"type.ml\"\n | `Stringlit of string\n \n# 25 \"type.ml\"\n | `Assoc of (string * t) list\n | `List of t list\n \n# 28 \"type.ml\"\n | `Tuple of t list\n \n# 31 \"type.ml\"\n | `Variant of (string * t option)\n \n# 33 \"type.ml\"\n ]\n(**\nAll possible cases defined in Yojson:\n- `Null: JSON null\n- `Bool of bool: JSON boolean\n- `Int of int: JSON number without decimal point or exponent.\n- `Intlit of string: JSON number without decimal point or exponent,\n\t preserved as a string.\n- `Float of float: JSON number, Infinity, -Infinity or NaN.\n- `Floatlit of string: JSON number, Infinity, -Infinity or NaN,\n\t preserved as a string.\n- `String of string: JSON string. Bytes in the range 128-255 are preserved\n\t as-is without encoding validation for both reading\n\t and writing.\n- `Stringlit of string: JSON string literal including the double quotes.\n- `Assoc of (string * json) list: JSON object.\n- `List of json list: JSON array.\n- `Tuple of json list: Tuple (non-standard extension of JSON).\n\t Syntax: [(\"abc\", 123)].\n- `Variant of (string * json option): Variant (non-standard extension of JSON).\n\t Syntax: [<\"Foo\">] or [<\"Bar\":123>].\n*)\n\ntype json = t [@@deprecated \"json types are being renamed and will be removed in the next Yojson major version. Use type t instead\"]\n(**\n * Compatibility type alias for type `t`\n *)\n\n(*\n Note to adventurers: ocamldoc does not support inline comments\n on each polymorphic variant, and cppo doesn't allow to concatenate\n comments, so it would be complicated to document only the\n cases that are preserved by cppo in the type definition.\n*)\n# 12 \"yojson.cppo.ml\"\ntype json_max = t\n# 1 \"write.ml\"\n(* included: type.ml *)\n\nlet hex n =\n Char.chr (\n if n < 10 then n + 48\n else n + 87\n )\n\nlet write_special src start stop ob str =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n Bi_outbuf.add_string ob str;\n start := stop + 1\n\nlet write_control_char src start stop ob c =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n let i = Bi_outbuf.alloc ob 6 in\n let dst = ob.o_s in\n Bytes.blit_string \"\\\\u00\" 0 dst i 4;\n Bytes.set dst (i+4) (hex (Char.code c lsr 4));\n Bytes.set dst (i+5) (hex (Char.code c land 0xf));\n start := stop + 1\n\nlet finish_string src start ob =\n try\n Bi_outbuf.add_substring ob src !start (String.length src - !start)\n with exc ->\n Printf.eprintf \"src=%S start=%i len=%i\\n%!\"\n src !start (String.length src - !start);\n raise exc\n\nlet write_string_body ob s =\n let start = ref 0 in\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '\"' -> write_special s start i ob \"\\\\\\\"\"\n | '\\\\' -> write_special s start i ob \"\\\\\\\\\"\n | '\\b' -> write_special s start i ob \"\\\\b\"\n | '\\012' -> write_special s start i ob \"\\\\f\"\n | '\\n' -> write_special s start i ob \"\\\\n\"\n | '\\r' -> write_special s start i ob \"\\\\r\"\n | '\\t' -> write_special s start i ob \"\\\\t\"\n | '\\x00'..'\\x1F'\n | '\\x7F' as c -> write_control_char s start i ob c\n | _ -> ()\n done;\n finish_string s start ob\n\nlet write_string ob s =\n Bi_outbuf.add_char ob '\"';\n write_string_body ob s;\n Bi_outbuf.add_char ob '\"'\n\nlet json_string_of_string s =\n let ob = Bi_outbuf.create 10 in\n write_string ob s;\n Bi_outbuf.contents ob\n\nlet test_string () =\n let s = Bytes.create 256 in\n for i = 0 to 255 do\n Bytes.set s i (Char.chr i)\n done;\n json_string_of_string (Bytes.to_string s)\n\n\nlet write_null ob () =\n Bi_outbuf.add_string ob \"null\"\n\nlet write_bool ob x =\n Bi_outbuf.add_string ob (if x then \"true\" else \"false\")\n\n\nlet max_digits =\n max\n (String.length (string_of_int max_int))\n (String.length (string_of_int min_int))\n\nlet dec n =\n Char.chr (n + 48)\n\nlet rec write_digits s pos x =\n if x = 0 then pos\n else\n let d = x mod 10 in\n let pos = write_digits s pos (x / 10) in\n Bytes.set s pos (dec (abs d));\n pos + 1\n\nlet write_int ob x =\n Bi_outbuf.extend ob max_digits;\n if x > 0 then\n ob.o_len <- write_digits ob.o_s ob.o_len x\n else if x < 0 then (\n let s = ob.o_s in\n let pos = ob.o_len in\n Bytes.set s pos '-';\n ob.o_len <- write_digits s (pos + 1) x\n )\n else\n Bi_outbuf.add_char ob '0'\n\n\nlet json_string_of_int i =\n string_of_int i\n\n\n(*\n Ensure that the float is not printed as an int.\n This is not required by JSON, but useful in order to guarantee\n reversibility.\n*)\nlet float_needs_period s =\n try\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '0'..'9' | '-' -> ()\n | _ -> raise Exit\n done;\n true\n with Exit ->\n false\n\n(*\n Both write_float_fast and write_float guarantee\n that a sufficient number of digits are printed in order to\n allow reversibility.\n\n The _fast version is faster but often produces unnecessarily long numbers.\n*)\nlet write_float_fast ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_normal_float_prec significant_figures ob x =\n let open Printf in\n let s =\n match significant_figures with\n 1 -> sprintf \"%.1g\" x\n | 2 -> sprintf \"%.2g\" x\n | 3 -> sprintf \"%.3g\" x\n | 4 -> sprintf \"%.4g\" x\n | 5 -> sprintf \"%.5g\" x\n | 6 -> sprintf \"%.6g\" x\n | 7 -> sprintf \"%.7g\" x\n | 8 -> sprintf \"%.8g\" x\n | 9 -> sprintf \"%.9g\" x\n | 10 -> sprintf \"%.10g\" x\n | 11 -> sprintf \"%.11g\" x\n | 12 -> sprintf \"%.12g\" x\n | 13 -> sprintf \"%.13g\" x\n | 14 -> sprintf \"%.14g\" x\n | 15 -> sprintf \"%.15g\" x\n | 16 -> sprintf \"%.16g\" x\n | _ -> sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_float ob x;\n Bi_outbuf.contents ob\n\n\nlet write_std_float_fast ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet std_json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_std_float ob x;\n Bi_outbuf.contents ob\n\n\nlet test_float () =\n let l = [ 0.; 1.; -1. ] in\n let l = l @ List.map (fun x -> 2. *. x +. 1.) l in\n let l = l @ List.map (fun x -> x /. sqrt 2.) l in\n let l = l @ List.map (fun x -> x *. sqrt 3.) l in\n let l = l @ List.map cos l in\n let l = l @ List.map (fun x -> x *. 1.23e50) l in\n let l = l @ [ infinity; neg_infinity ] in\n List.iter (\n fun x ->\n let s = Printf.sprintf \"%.17g\" x in\n let y = float_of_string s in\n Printf.printf \"%g %g %S %B\\n\" x y s (x = y)\n )\n l\n\n(*\nlet () = test_float ()\n*)\n\nlet write_intlit = Bi_outbuf.add_string\nlet write_floatlit = Bi_outbuf.add_string\nlet write_stringlit = Bi_outbuf.add_string\n\nlet rec iter2_aux f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_sep x;\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet iter2 f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet f_sep ob =\n Bi_outbuf.add_char ob ','\n\nlet rec write_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 299 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 302 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 305 \"write.ml\"\n | `Float f -> write_float ob f\n \n# 308 \"write.ml\"\n | `Floatlit s -> Bi_outbuf.add_string ob s\n \n# 311 \"write.ml\"\n | `String s -> write_string ob s\n \n# 314 \"write.ml\"\n | `Stringlit s -> Bi_outbuf.add_string ob s\n \n# 316 \"write.ml\"\n | `Assoc l -> write_assoc ob l\n | `List l -> write_list ob l\n \n# 319 \"write.ml\"\n | `Tuple l -> write_tuple ob l\n \n# 322 \"write.ml\"\n | `Variant (s, o) -> write_variant ob s o\n\n# 325 \"write.ml\"\nand write_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 341 \"write.ml\"\nand write_tuple ob l =\n Bi_outbuf.add_char ob '(';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ')'\n\n# 348 \"write.ml\"\nand write_variant ob s o =\n Bi_outbuf.add_char ob '<';\n write_string ob s;\n (match o with\n None -> ()\n | Some x ->\n Bi_outbuf.add_char ob ':';\n write_json ob x\n );\n Bi_outbuf.add_char ob '>'\n\n# 360 \"write.ml\"\nlet write_t = write_json\n\nlet rec write_std_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 367 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 370 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 373 \"write.ml\"\n | `Float f -> write_std_float ob f\n \n# 376 \"write.ml\"\n | `Floatlit s -> Bi_outbuf.add_string ob s\n \n# 379 \"write.ml\"\n | `String s -> write_string ob s\n \n# 382 \"write.ml\"\n | `Stringlit s -> Bi_outbuf.add_string ob s\n \n# 384 \"write.ml\"\n | `Assoc l -> write_std_assoc ob l\n | `List l -> write_std_list ob l\n \n# 387 \"write.ml\"\n | `Tuple l -> write_std_tuple ob l\n \n# 390 \"write.ml\"\n | `Variant (s, o) -> write_std_variant ob s o\n\n# 393 \"write.ml\"\nand write_std_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_std_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_std_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\nand write_std_tuple ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 414 \"write.ml\"\nand write_std_variant ob s o =\n match o with\n None -> write_string ob s\n | Some x ->\n Bi_outbuf.add_char ob '[';\n write_string ob s;\n Bi_outbuf.add_char ob ',';\n write_std_json ob x;\n Bi_outbuf.add_char ob ']'\n\n\n# 426 \"write.ml\"\nlet to_outbuf ?(std = false) ob x =\n if std then (\n if not (is_object_or_array x) then\n json_error \"Root is not an object or array\"\n else\n write_std_json ob x\n )\n else\n write_json ob x\n\n\nlet to_string ?buf ?(len = 256) ?std x =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n to_outbuf ?std ob x;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet to_channel ?buf ?len ?std oc x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_channel_writer ob\n\nlet to_output ?buf ?len ?std out x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_output_writer ?len out\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_output_writer ob\n\nlet to_file ?len ?std file x =\n let oc = open_out file in\n try\n to_channel ?len ?std oc x;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\nlet stream_to_outbuf ?std ob st =\n Stream.iter (to_outbuf ?std ob) st\n\nlet stream_to_string ?buf ?(len = 256) ?std st =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n stream_to_outbuf ?std ob st;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet stream_to_channel ?buf ?len ?std oc st =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n stream_to_outbuf ?std ob st;\n Bi_outbuf.flush_channel_writer ob\n\nlet stream_to_file ?len ?std file st =\n let oc = open_out file in\n try\n stream_to_channel ?len ?std oc st;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\n\nlet rec sort = function\n | `Assoc l ->\n let l = List.rev (List.rev_map (fun (k, v) -> (k, sort v)) l) in\n `Assoc (List.stable_sort (fun (a, _) (b, _) -> String.compare a b) l)\n | `List l ->\n `List (List.rev (List.rev_map sort l))\n \n# 519 \"write.ml\"\n | `Tuple l ->\n `Tuple (List.rev (List.rev_map sort l))\n \n# 523 \"write.ml\"\n | `Variant (k, Some v) as x ->\n let v' = sort v in\n if v == v' then x\n else\n `Variant (k, Some v')\n \n# 529 \"write.ml\"\n | x -> x\n# 1 \"monomorphic.ml\"\nlet rec pp fmt =\n function\n | `Null -> Format.pp_print_string fmt \"`Null\"\n | `Bool x ->\n Format.fprintf fmt \"`Bool (@[\";\n Format.fprintf fmt \"%B\" x;\n Format.fprintf fmt \"@])\"\n \n# 9 \"monomorphic.ml\"\n | `Int x ->\n Format.fprintf fmt \"`Int (@[\";\n Format.fprintf fmt \"%d\" x;\n Format.fprintf fmt \"@])\"\n \n# 15 \"monomorphic.ml\"\n | `Intlit x ->\n Format.fprintf fmt \"`Intlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 21 \"monomorphic.ml\"\n | `Float x ->\n Format.fprintf fmt \"`Float (@[\";\n Format.fprintf fmt \"%F\" x;\n Format.fprintf fmt \"@])\"\n \n# 27 \"monomorphic.ml\"\n | `Floatlit x ->\n Format.fprintf fmt \"`Floatlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 33 \"monomorphic.ml\"\n | `String x ->\n Format.fprintf fmt \"`String (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 39 \"monomorphic.ml\"\n | `Stringlit x ->\n Format.fprintf fmt \"`Stringlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 44 \"monomorphic.ml\"\n | `Assoc xs ->\n Format.fprintf fmt \"`Assoc (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep (key, value) ->\n if sep then\n Format.fprintf fmt \";@ \";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" key;\n Format.fprintf fmt \",@ \";\n pp fmt value;\n Format.fprintf fmt \"@])\";\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n | `List xs ->\n Format.fprintf fmt \"`List (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep x ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt x;\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 71 \"monomorphic.ml\"\n | `Tuple tup ->\n Format.fprintf fmt \"`Tuple (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep e ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt e;\n true) false tup);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 84 \"monomorphic.ml\"\n | `Variant (name, value) ->\n Format.fprintf fmt \"`Variant (@[\";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" name;\n Format.fprintf fmt \",@ \";\n (match value with\n | None -> Format.pp_print_string fmt \"None\"\n | Some x ->\n Format.pp_print_string fmt \"(Some \";\n pp fmt x;\n Format.pp_print_string fmt \")\");\n Format.fprintf fmt \"@])\";\n Format.fprintf fmt \"@])\"\n\n# 99 \"monomorphic.ml\"\nlet show x =\n Format.asprintf \"%a\" pp x\n\nlet rec equal a b =\n match a, b with\n | `Null, `Null -> true\n | `Bool a, `Bool b -> a = b\n \n# 107 \"monomorphic.ml\"\n | `Int a, `Int b -> a = b\n \n# 110 \"monomorphic.ml\"\n | `Intlit a, `Intlit b -> a = b\n \n# 113 \"monomorphic.ml\"\n | `Float a, `Float b -> a = b\n \n# 116 \"monomorphic.ml\"\n | `Floatlit a, `Floatlit b -> a = b\n \n# 119 \"monomorphic.ml\"\n | `String a, `String b -> a = b\n \n# 122 \"monomorphic.ml\"\n | `Stringlit a, `Stringlit b -> a = b\n \n# 124 \"monomorphic.ml\"\n | `Assoc xs, `Assoc ys ->\n let compare_keys = fun (key, _) (key', _) -> String.compare key key' in\n let xs = List.stable_sort compare_keys xs in\n let ys = List.stable_sort compare_keys ys in\n (match List.for_all2 (fun (key, value) (key', value') ->\n match key = key' with\n | false -> false\n | true -> equal value value') xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 137 \"monomorphic.ml\"\n | `Tuple xs, `Tuple ys\n \n# 139 \"monomorphic.ml\"\n | `List xs, `List ys ->\n (match List.for_all2 equal xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 146 \"monomorphic.ml\"\n | `Variant (name, value), `Variant (name', value') ->\n (match name = name' with\n | false -> false\n | true ->\n match value, value' with\n | None, None -> true\n | Some x, Some y -> equal x y\n | _ -> false)\n \n# 155 \"monomorphic.ml\"\n | _ -> false\n# 15 \"yojson.cppo.ml\"\nmodule Pretty =\nstruct\n# 1 \"pretty.ml\"\nopen Printf\n\nlet array = Easy_format.list\nlet record = Easy_format.list\nlet tuple = { Easy_format.list with\n space_after_opening = false;\n space_before_closing = false;\n align_closing = false }\nlet variant = { Easy_format.list with\n space_before_closing = false; }\n\nlet rec format std (x : t) =\n match x with\n `Null -> Easy_format.Atom (\"null\", Easy_format.atom)\n | `Bool x -> Easy_format.Atom ((if x then \"true\" else \"false\"), Easy_format.atom)\n | `Int x -> Easy_format.Atom (json_string_of_int x, Easy_format.atom)\n | `Float x ->\n let s =\n if std then std_json_string_of_float x\n else json_string_of_float x\n in\n Easy_format.Atom (s, Easy_format.atom)\n | `String s -> Easy_format.Atom (json_string_of_string s, Easy_format.atom)\n | `Intlit s\n | `Floatlit s\n | `Stringlit s -> Easy_format.Atom (s, Easy_format.atom)\n | `List [] -> Easy_format.Atom (\"[]\", Easy_format.atom)\n | `List l -> Easy_format.List ((\"[\", \",\", \"]\", array), List.map (format std) l)\n | `Assoc [] -> Easy_format.Atom (\"{}\", Easy_format.atom)\n | `Assoc l -> Easy_format.List ((\"{\", \",\", \"}\", record), List.map (format_field std) l)\n | `Tuple l ->\n if std then\n format std (`List l)\n else\n if l = [] then\n Easy_format.Atom (\"()\", Easy_format.atom)\n else\n Easy_format.List ((\"(\", \",\", \")\", tuple), List.map (format std) l)\n\n | `Variant (s, None) ->\n if std then\n format std (`String s)\n else\n Easy_format.Atom (\"<\" ^ json_string_of_string s ^ \">\", Easy_format.atom)\n\n | `Variant (s, Some x) ->\n if std then\n format std (`List [ `String s; x ])\n else\n let op = \"<\" ^ json_string_of_string s ^ \":\" in\n Easy_format.List ((op, \"\", \">\", variant), [format std x])\n\nand format_field std (name, x) =\n let s = sprintf \"%s:\" (json_string_of_string name) in\n Easy_format.Label ((Easy_format.Atom (s, Easy_format.atom), Easy_format.label), format std x)\n\n\nlet format ?(std = false) x =\n if std && not (is_object_or_array x) then\n json_error\n \"Root is not an object or array as requested by the JSON standard\"\n else\n format std (x :> t)\n\nlet to_string ?std x =\n Easy_format.Pretty.to_string (format ?std x)\n\nlet to_channel ?std oc x =\n Easy_format.Pretty.to_channel oc (format ?std x)\n# 18 \"yojson.cppo.ml\"\nend\n# 1 \"write2.ml\"\nlet pretty_format ?std (x : t) =\n Pretty.format ?std (x :> json_max)\n\nlet pretty_print ?std out (x : t) =\n Easy_format.Pretty.to_formatter out (pretty_format ?std x)\n\nlet pretty_to_string ?std (x : t) =\n Pretty.to_string ?std (x :> json_max)\n\nlet pretty_to_channel ?std oc (x : t) =\n Pretty.to_channel ?std oc (x :> json_max)\n\n# 29 \"yojson.cppo.ml\"\nmodule Basic =\nstruct\n# 1 \"type.ml\"\n(** {3 Type of the JSON tree} *)\n\ntype t =\n [\n | `Null\n | `Bool of bool\n \n# 8 \"type.ml\"\n | `Int of int\n \n# 14 \"type.ml\"\n | `Float of float\n \n# 20 \"type.ml\"\n | `String of string\n \n# 25 \"type.ml\"\n | `Assoc of (string * t) list\n | `List of t list\n \n# 33 \"type.ml\"\n ]\n(**\nAll possible cases defined in Yojson:\n- `Null: JSON null\n- `Bool of bool: JSON boolean\n- `Int of int: JSON number without decimal point or exponent.\n- `Intlit of string: JSON number without decimal point or exponent,\n\t preserved as a string.\n- `Float of float: JSON number, Infinity, -Infinity or NaN.\n- `Floatlit of string: JSON number, Infinity, -Infinity or NaN,\n\t preserved as a string.\n- `String of string: JSON string. Bytes in the range 128-255 are preserved\n\t as-is without encoding validation for both reading\n\t and writing.\n- `Stringlit of string: JSON string literal including the double quotes.\n- `Assoc of (string * json) list: JSON object.\n- `List of json list: JSON array.\n- `Tuple of json list: Tuple (non-standard extension of JSON).\n\t Syntax: [(\"abc\", 123)].\n- `Variant of (string * json option): Variant (non-standard extension of JSON).\n\t Syntax: [<\"Foo\">] or [<\"Bar\":123>].\n*)\n\ntype json = t [@@deprecated \"json types are being renamed and will be removed in the next Yojson major version. Use type t instead\"]\n(**\n * Compatibility type alias for type `t`\n *)\n\n(*\n Note to adventurers: ocamldoc does not support inline comments\n on each polymorphic variant, and cppo doesn't allow to concatenate\n comments, so it would be complicated to document only the\n cases that are preserved by cppo in the type definition.\n*)\n# 1 \"write.ml\"\n(* included: type.ml *)\n\nlet hex n =\n Char.chr (\n if n < 10 then n + 48\n else n + 87\n )\n\nlet write_special src start stop ob str =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n Bi_outbuf.add_string ob str;\n start := stop + 1\n\nlet write_control_char src start stop ob c =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n let i = Bi_outbuf.alloc ob 6 in\n let dst = ob.o_s in\n Bytes.blit_string \"\\\\u00\" 0 dst i 4;\n Bytes.set dst (i+4) (hex (Char.code c lsr 4));\n Bytes.set dst (i+5) (hex (Char.code c land 0xf));\n start := stop + 1\n\nlet finish_string src start ob =\n try\n Bi_outbuf.add_substring ob src !start (String.length src - !start)\n with exc ->\n Printf.eprintf \"src=%S start=%i len=%i\\n%!\"\n src !start (String.length src - !start);\n raise exc\n\nlet write_string_body ob s =\n let start = ref 0 in\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '\"' -> write_special s start i ob \"\\\\\\\"\"\n | '\\\\' -> write_special s start i ob \"\\\\\\\\\"\n | '\\b' -> write_special s start i ob \"\\\\b\"\n | '\\012' -> write_special s start i ob \"\\\\f\"\n | '\\n' -> write_special s start i ob \"\\\\n\"\n | '\\r' -> write_special s start i ob \"\\\\r\"\n | '\\t' -> write_special s start i ob \"\\\\t\"\n | '\\x00'..'\\x1F'\n | '\\x7F' as c -> write_control_char s start i ob c\n | _ -> ()\n done;\n finish_string s start ob\n\nlet write_string ob s =\n Bi_outbuf.add_char ob '\"';\n write_string_body ob s;\n Bi_outbuf.add_char ob '\"'\n\nlet json_string_of_string s =\n let ob = Bi_outbuf.create 10 in\n write_string ob s;\n Bi_outbuf.contents ob\n\nlet test_string () =\n let s = Bytes.create 256 in\n for i = 0 to 255 do\n Bytes.set s i (Char.chr i)\n done;\n json_string_of_string (Bytes.to_string s)\n\n\nlet write_null ob () =\n Bi_outbuf.add_string ob \"null\"\n\nlet write_bool ob x =\n Bi_outbuf.add_string ob (if x then \"true\" else \"false\")\n\n\nlet max_digits =\n max\n (String.length (string_of_int max_int))\n (String.length (string_of_int min_int))\n\nlet dec n =\n Char.chr (n + 48)\n\nlet rec write_digits s pos x =\n if x = 0 then pos\n else\n let d = x mod 10 in\n let pos = write_digits s pos (x / 10) in\n Bytes.set s pos (dec (abs d));\n pos + 1\n\nlet write_int ob x =\n Bi_outbuf.extend ob max_digits;\n if x > 0 then\n ob.o_len <- write_digits ob.o_s ob.o_len x\n else if x < 0 then (\n let s = ob.o_s in\n let pos = ob.o_len in\n Bytes.set s pos '-';\n ob.o_len <- write_digits s (pos + 1) x\n )\n else\n Bi_outbuf.add_char ob '0'\n\n\nlet json_string_of_int i =\n string_of_int i\n\n\n(*\n Ensure that the float is not printed as an int.\n This is not required by JSON, but useful in order to guarantee\n reversibility.\n*)\nlet float_needs_period s =\n try\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '0'..'9' | '-' -> ()\n | _ -> raise Exit\n done;\n true\n with Exit ->\n false\n\n(*\n Both write_float_fast and write_float guarantee\n that a sufficient number of digits are printed in order to\n allow reversibility.\n\n The _fast version is faster but often produces unnecessarily long numbers.\n*)\nlet write_float_fast ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_normal_float_prec significant_figures ob x =\n let open Printf in\n let s =\n match significant_figures with\n 1 -> sprintf \"%.1g\" x\n | 2 -> sprintf \"%.2g\" x\n | 3 -> sprintf \"%.3g\" x\n | 4 -> sprintf \"%.4g\" x\n | 5 -> sprintf \"%.5g\" x\n | 6 -> sprintf \"%.6g\" x\n | 7 -> sprintf \"%.7g\" x\n | 8 -> sprintf \"%.8g\" x\n | 9 -> sprintf \"%.9g\" x\n | 10 -> sprintf \"%.10g\" x\n | 11 -> sprintf \"%.11g\" x\n | 12 -> sprintf \"%.12g\" x\n | 13 -> sprintf \"%.13g\" x\n | 14 -> sprintf \"%.14g\" x\n | 15 -> sprintf \"%.15g\" x\n | 16 -> sprintf \"%.16g\" x\n | _ -> sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_float ob x;\n Bi_outbuf.contents ob\n\n\nlet write_std_float_fast ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet std_json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_std_float ob x;\n Bi_outbuf.contents ob\n\n\nlet test_float () =\n let l = [ 0.; 1.; -1. ] in\n let l = l @ List.map (fun x -> 2. *. x +. 1.) l in\n let l = l @ List.map (fun x -> x /. sqrt 2.) l in\n let l = l @ List.map (fun x -> x *. sqrt 3.) l in\n let l = l @ List.map cos l in\n let l = l @ List.map (fun x -> x *. 1.23e50) l in\n let l = l @ [ infinity; neg_infinity ] in\n List.iter (\n fun x ->\n let s = Printf.sprintf \"%.17g\" x in\n let y = float_of_string s in\n Printf.printf \"%g %g %S %B\\n\" x y s (x = y)\n )\n l\n\n(*\nlet () = test_float ()\n*)\n\nlet write_intlit = Bi_outbuf.add_string\nlet write_floatlit = Bi_outbuf.add_string\nlet write_stringlit = Bi_outbuf.add_string\n\nlet rec iter2_aux f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_sep x;\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet iter2 f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet f_sep ob =\n Bi_outbuf.add_char ob ','\n\nlet rec write_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 299 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 305 \"write.ml\"\n | `Float f -> write_float ob f\n \n# 311 \"write.ml\"\n | `String s -> write_string ob s\n \n# 316 \"write.ml\"\n | `Assoc l -> write_assoc ob l\n | `List l -> write_list ob l\n\n# 325 \"write.ml\"\nand write_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n\n\n# 360 \"write.ml\"\nlet write_t = write_json\n\nlet rec write_std_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 367 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 373 \"write.ml\"\n | `Float f -> write_std_float ob f\n \n# 379 \"write.ml\"\n | `String s -> write_string ob s\n \n# 384 \"write.ml\"\n | `Assoc l -> write_std_assoc ob l\n | `List l -> write_std_list ob l\n\n# 393 \"write.ml\"\nand write_std_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_std_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_std_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\nand write_std_tuple ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n\n\n# 426 \"write.ml\"\nlet to_outbuf ?(std = false) ob x =\n if std then (\n if not (is_object_or_array x) then\n json_error \"Root is not an object or array\"\n else\n write_std_json ob x\n )\n else\n write_json ob x\n\n\nlet to_string ?buf ?(len = 256) ?std x =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n to_outbuf ?std ob x;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet to_channel ?buf ?len ?std oc x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_channel_writer ob\n\nlet to_output ?buf ?len ?std out x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_output_writer ?len out\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_output_writer ob\n\nlet to_file ?len ?std file x =\n let oc = open_out file in\n try\n to_channel ?len ?std oc x;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\nlet stream_to_outbuf ?std ob st =\n Stream.iter (to_outbuf ?std ob) st\n\nlet stream_to_string ?buf ?(len = 256) ?std st =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n stream_to_outbuf ?std ob st;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet stream_to_channel ?buf ?len ?std oc st =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n stream_to_outbuf ?std ob st;\n Bi_outbuf.flush_channel_writer ob\n\nlet stream_to_file ?len ?std file st =\n let oc = open_out file in\n try\n stream_to_channel ?len ?std oc st;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\n\nlet rec sort = function\n | `Assoc l ->\n let l = List.rev (List.rev_map (fun (k, v) -> (k, sort v)) l) in\n `Assoc (List.stable_sort (fun (a, _) (b, _) -> String.compare a b) l)\n | `List l ->\n `List (List.rev (List.rev_map sort l))\n \n# 529 \"write.ml\"\n | x -> x\n# 1 \"monomorphic.ml\"\nlet rec pp fmt =\n function\n | `Null -> Format.pp_print_string fmt \"`Null\"\n | `Bool x ->\n Format.fprintf fmt \"`Bool (@[\";\n Format.fprintf fmt \"%B\" x;\n Format.fprintf fmt \"@])\"\n \n# 9 \"monomorphic.ml\"\n | `Int x ->\n Format.fprintf fmt \"`Int (@[\";\n Format.fprintf fmt \"%d\" x;\n Format.fprintf fmt \"@])\"\n \n# 21 \"monomorphic.ml\"\n | `Float x ->\n Format.fprintf fmt \"`Float (@[\";\n Format.fprintf fmt \"%F\" x;\n Format.fprintf fmt \"@])\"\n \n# 33 \"monomorphic.ml\"\n | `String x ->\n Format.fprintf fmt \"`String (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 44 \"monomorphic.ml\"\n | `Assoc xs ->\n Format.fprintf fmt \"`Assoc (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep (key, value) ->\n if sep then\n Format.fprintf fmt \";@ \";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" key;\n Format.fprintf fmt \",@ \";\n pp fmt value;\n Format.fprintf fmt \"@])\";\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n | `List xs ->\n Format.fprintf fmt \"`List (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep x ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt x;\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n\n# 99 \"monomorphic.ml\"\nlet show x =\n Format.asprintf \"%a\" pp x\n\nlet rec equal a b =\n match a, b with\n | `Null, `Null -> true\n | `Bool a, `Bool b -> a = b\n \n# 107 \"monomorphic.ml\"\n | `Int a, `Int b -> a = b\n \n# 113 \"monomorphic.ml\"\n | `Float a, `Float b -> a = b\n \n# 119 \"monomorphic.ml\"\n | `String a, `String b -> a = b\n \n# 124 \"monomorphic.ml\"\n | `Assoc xs, `Assoc ys ->\n let compare_keys = fun (key, _) (key', _) -> String.compare key key' in\n let xs = List.stable_sort compare_keys xs in\n let ys = List.stable_sort compare_keys ys in\n (match List.for_all2 (fun (key, value) (key', value') ->\n match key = key' with\n | false -> false\n | true -> equal value value') xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 139 \"monomorphic.ml\"\n | `List xs, `List ys ->\n (match List.for_all2 equal xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 155 \"monomorphic.ml\"\n | _ -> false\n# 1 \"write2.ml\"\nlet pretty_format ?std (x : t) =\n Pretty.format ?std (x :> json_max)\n\nlet pretty_print ?std out (x : t) =\n Easy_format.Pretty.to_formatter out (pretty_format ?std x)\n\nlet pretty_to_string ?std (x : t) =\n Pretty.to_string ?std (x :> json_max)\n\nlet pretty_to_channel ?std oc (x : t) =\n Pretty.to_channel ?std oc (x :> json_max)\n\n# 1 \"lib/read.mll\"\n \n \n# 2 \"lib/read.mll\"\n module Lexing =\n (*\n We override Lexing.engine in order to avoid creating a new position\n record each time a rule is matched.\n This reduces total parsing time by about 31%.\n *)\n struct\n include Lexing\n\n external c_engine : lex_tables -> int -> lexbuf -> int = \"caml_lex_engine\"\n\n let engine tbl state buf =\n let result = c_engine tbl state buf in\n (*\n if result >= 0 then begin\n buf.lex_start_p <- buf.lex_curr_p;\n buf.lex_curr_p <- {buf.lex_curr_p\n with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n end;\n *)\n result\n end\n\n open Printf\n open Lexing\n\n (* see description in common.mli *)\n type lexer_state = Lexer_state.t = {\n buf : Bi_outbuf.t;\n mutable lnum : int;\n mutable bol : int;\n mutable fname : string option;\n }\n\n let dec c =\n Char.code c - 48\n\n let hex c =\n match c with\n '0'..'9' -> int_of_char c - int_of_char '0'\n | 'a'..'f' -> int_of_char c - int_of_char 'a' + 10\n | 'A'..'F' -> int_of_char c - int_of_char 'A' + 10\n | _ -> assert false\n\n let custom_error descr v lexbuf =\n let offs = lexbuf.lex_abs_pos - 1 in\n let bol = v.bol in\n let pos1 = offs + lexbuf.lex_start_pos - bol - 1 in\n let pos2 = max pos1 (offs + lexbuf.lex_curr_pos - bol) in\n let file_line =\n match v.fname with\n None -> \"Line\"\n | Some s ->\n sprintf \"File %s, line\" s\n in\n let bytes =\n if pos1 = pos2 then\n sprintf \"byte %i\" (pos1+1)\n else\n sprintf \"bytes %i-%i\" (pos1+1) (pos2+1)\n in\n let msg = sprintf \"%s %i, %s:\\n%s\" file_line v.lnum bytes descr in\n json_error msg\n\n\n let lexer_error descr v lexbuf =\n custom_error\n (sprintf \"%s '%s'\" descr (Lexing.lexeme lexbuf))\n v lexbuf\n\n let read_junk = ref (fun _ -> assert false)\n\n let long_error descr v lexbuf =\n let junk = Lexing.lexeme lexbuf in\n let extra_junk = !read_junk lexbuf in\n custom_error\n (sprintf \"%s '%s%s'\" descr junk extra_junk)\n v lexbuf\n\n let min10 = min_int / 10 - (if min_int mod 10 = 0 then 0 else 1)\n let max10 = max_int / 10 + (if max_int mod 10 = 0 then 0 else 1)\n\n exception Int_overflow\n\n let extract_positive_int lexbuf =\n let start = lexbuf.lex_start_pos in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n >= max10 then\n raise Int_overflow\n else\n n := 10 * !n + dec (Bytes.get s i)\n done;\n if !n < 0 then\n raise Int_overflow\n else\n !n\n\n let make_positive_int v lexbuf =\n \n# 104 \"lib/read.mll\"\n try `Int (extract_positive_int lexbuf)\n with Int_overflow ->\n \n# 110 \"lib/read.mll\"\n lexer_error \"Int overflow\" v lexbuf\n\n \n# 113 \"lib/read.mll\"\n let extract_negative_int lexbuf =\n let start = lexbuf.lex_start_pos + 1 in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n <= min10 then\n raise Int_overflow\n else\n n := 10 * !n - dec (Bytes.get s i)\n done;\n if !n > 0 then\n raise Int_overflow\n else\n !n\n\n let make_negative_int v lexbuf =\n \n# 131 \"lib/read.mll\"\n try `Int (extract_negative_int lexbuf)\n with Int_overflow ->\n \n# 137 \"lib/read.mll\"\n lexer_error \"Int overflow\" v lexbuf\n\n\n \n# 141 \"lib/read.mll\"\n let set_file_name v fname =\n v.fname <- fname\n\n let newline v lexbuf =\n v.lnum <- v.lnum + 1;\n v.bol <- lexbuf.lex_abs_pos + lexbuf.lex_curr_pos\n\n let add_lexeme buf lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n Bi_outbuf.add_subbytes buf lexbuf.lex_buffer lexbuf.lex_start_pos len\n\n let map_lexeme f lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n f (Bytes.to_string lexbuf.lex_buffer) lexbuf.lex_start_pos len\n\n type variant_kind = [ `Edgy_bracket | `Square_bracket | `Double_quote ]\n type tuple_kind = [ `Parenthesis | `Square_bracket ]\n\n\n# 161 \"lib/read.ml\"\n# 161 \"lib/read.ml\"\nlet __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\236\\255\\237\\255\\003\\000\\239\\255\\016\\000\\242\\255\\243\\255\\\n \\244\\255\\245\\255\\000\\000\\031\\000\\249\\255\\085\\000\\001\\000\\000\\000\\\n \\000\\000\\001\\000\\000\\000\\001\\000\\002\\000\\255\\255\\000\\000\\000\\000\\\n \\003\\000\\254\\255\\001\\000\\004\\000\\253\\255\\011\\000\\252\\255\\003\\000\\\n \\001\\000\\003\\000\\002\\000\\003\\000\\000\\000\\251\\255\\021\\000\\097\\000\\\n \\010\\000\\022\\000\\020\\000\\016\\000\\022\\000\\012\\000\\008\\000\\250\\255\\\n \\119\\000\\129\\000\\139\\000\\161\\000\\171\\000\\181\\000\\193\\000\\209\\000\\\n \\240\\255\\011\\000\\038\\000\\252\\255\\065\\000\\254\\255\\255\\255\\110\\000\\\n \\252\\255\\163\\000\\254\\255\\255\\255\\234\\000\\247\\255\\248\\255\\048\\001\\\n \\250\\255\\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\071\\001\\126\\001\\\n \\149\\001\\249\\255\\039\\000\\253\\255\\254\\255\\038\\000\\187\\001\\210\\001\\\n \\248\\001\\015\\002\\255\\255\\220\\000\\253\\255\\255\\255\\245\\000\\039\\002\\\n \\109\\002\\014\\001\\088\\002\\164\\002\\187\\002\\225\\002\\013\\000\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\014\\000\\253\\255\\254\\255\\255\\255\\030\\000\\\n \\253\\255\\254\\255\\255\\255\\015\\000\\253\\255\\254\\255\\255\\255\\017\\001\\\n \\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\019\\000\\252\\255\\253\\255\\\n \\254\\255\\015\\000\\255\\255\\016\\000\\255\\255\\008\\001\\005\\000\\253\\255\\\n \\023\\000\\254\\255\\020\\000\\255\\255\\046\\000\\253\\255\\254\\255\\042\\000\\\n \\052\\000\\053\\000\\255\\255\\053\\000\\048\\000\\091\\000\\092\\000\\255\\255\\\n \\027\\001\\250\\255\\251\\255\\137\\000\\104\\000\\089\\000\\088\\000\\106\\000\\\n \\255\\255\\143\\000\\137\\000\\177\\000\\254\\255\\183\\000\\168\\000\\166\\000\\\n \\183\\000\\002\\000\\253\\255\\177\\000\\172\\000\\187\\000\\004\\000\\252\\255\\\n \\053\\002\\251\\255\\252\\255\\253\\255\\103\\001\\255\\255\\248\\002\\254\\255\\\n \\006\\003\\030\\003\\252\\255\\253\\255\\254\\255\\255\\255\\040\\003\\050\\003\\\n \\074\\003\\252\\255\\253\\255\\254\\255\\255\\255\\061\\003\\084\\003\\108\\003\\\n \\249\\255\\250\\255\\251\\255\\244\\000\\120\\003\\142\\003\\179\\000\\194\\000\\\n \\015\\000\\255\\255\\190\\000\\188\\000\\187\\000\\193\\000\\183\\000\\179\\000\\\n \\254\\255\\191\\000\\201\\000\\200\\000\\196\\000\\203\\000\\193\\000\\189\\000\\\n \\253\\255\\157\\003\\095\\003\\174\\003\\196\\003\\206\\003\\216\\003\\228\\003\\\n \\239\\003\\060\\000\\253\\255\\254\\255\\255\\255\\012\\004\\252\\255\\253\\255\\\n \\087\\004\\255\\255\\145\\004\\252\\255\\253\\255\\221\\004\\255\\255\\229\\000\\\n \\253\\255\\254\\255\\255\\255\\231\\000\\253\\255\\254\\255\\255\\255\\002\\000\\\n \\255\\255\\018\\001\\252\\255\\253\\255\\254\\255\\255\\255\\034\\001\\253\\255\\\n \\254\\255\\255\\255\\000\\000\\255\\255\\003\\000\\254\\255\\255\\255\\038\\001\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\120\\001\\251\\255\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\208\\000\\253\\255\\254\\255\\255\\255\\211\\000\\253\\255\\\n \\254\\255\\255\\255\\189\\000\\255\\255\\143\\001\\252\\255\\253\\255\\254\\255\\\n \\255\\255\\013\\001\\253\\255\\254\\255\\255\\255\\095\\001\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\050\\001\\253\\255\\254\\255\\255\\255\\026\\001\\253\\255\\\n \\254\\255\\255\\255\\233\\000\\253\\255\\254\\255\\255\\255\\222\\000\\253\\255\\\n \\254\\255\\255\\255\\079\\005\\237\\255\\238\\255\\010\\000\\240\\255\\044\\001\\\n \\243\\255\\244\\255\\245\\255\\246\\255\\061\\001\\002\\004\\249\\255\\045\\005\\\n \\209\\000\\228\\000\\211\\000\\232\\000\\225\\000\\223\\000\\240\\000\\255\\255\\\n \\235\\000\\234\\000\\008\\001\\254\\255\\004\\001\\023\\001\\253\\255\\054\\001\\\n \\252\\255\\031\\001\\029\\001\\032\\001\\039\\001\\049\\001\\045\\001\\251\\255\\\n \\057\\001\\082\\001\\080\\001\\078\\001\\084\\001\\074\\001\\086\\001\\250\\255\\\n \\110\\005\\012\\004\\123\\005\\155\\005\\165\\005\\177\\005\\187\\005\\197\\005\\\n \\241\\255\\199\\001\\077\\002\\253\\255\\255\\255\\154\\002\\222\\005\\209\\005\\\n \\155\\002\\239\\005\\053\\006\\076\\006\\114\\006\\016\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\152\\006\\252\\255\\253\\255\\227\\006\\255\\255\\085\\007\\\n \\244\\255\\245\\255\\011\\000\\247\\255\\076\\002\\250\\255\\251\\255\\252\\255\\\n \\253\\255\\254\\255\\031\\002\\243\\005\\051\\007\\100\\001\\115\\001\\104\\001\\\n \\133\\001\\118\\001\\154\\001\\171\\001\\255\\255\\173\\001\\176\\001\\191\\001\\\n \\185\\001\\187\\001\\253\\001\\230\\001\\230\\001\\234\\001\\247\\001\\237\\001\\\n \\234\\001\\009\\002\\019\\002\\019\\002\\015\\002\\021\\002\\011\\002\\007\\002\\\n \\142\\006\\152\\006\\116\\007\\170\\007\\180\\007\\190\\007\\200\\007\\210\\007\\\n \\248\\255\\120\\002\\167\\002\\253\\255\\255\\255\\216\\002\\082\\007\\220\\007\\\n \\236\\002\\244\\007\\058\\008\\081\\008\\119\\008\\076\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\157\\008\\252\\255\\253\\255\\232\\008\\255\\255\\135\\002\\\n \\120\\002\\253\\255\\100\\002\\254\\255\\182\\002\\255\\255\\011\\002\\255\\255\\\n \\204\\002\\252\\255\\253\\255\\254\\255\\255\\255\\046\\002\\255\\255\\178\\002\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\023\\000\\255\\255\\183\\002\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\187\\002\\253\\255\\254\\255\\255\\255\\121\\002\\\n \\253\\255\\254\\255\\255\\255\\184\\002\\252\\255\\253\\255\\254\\255\\019\\000\\\n \\255\\255\\140\\001\\146\\001\\255\\255\\150\\001\\151\\001\\154\\001\\168\\001\\\n \\170\\001\\171\\001\\172\\001\\173\\001\\181\\001\\184\\001\\185\\001\\187\\001\\\n \\191\\001\\193\\001\\195\\001\\196\\001\\197\\001\\200\\001\\203\\001\\223\\001\\\n \\225\\001\\228\\001\\249\\001\\251\\001\\002\\002\\004\\002\\011\\002\\012\\002\\\n \\013\\002\\000\\000\";\n Lexing.lex_backtrk =\n \"\\255\\255\\255\\255\\255\\255\\017\\000\\255\\255\\019\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\008\\000\\008\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\\n \\255\\255\\014\\000\\255\\255\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\003\\000\\255\\255\\001\\000\\255\\255\\004\\000\\003\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\004\\000\\004\\000\\004\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\000\\000\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\003\\000\\005\\000\\005\\000\\005\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\003\\000\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\016\\000\\255\\255\\018\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\\n \\255\\255\\013\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\011\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\000\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\006\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\004\\000\\\n \\003\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\";\n Lexing.lex_default =\n \"\\001\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\057\\000\\060\\000\\000\\000\\060\\000\\000\\000\\000\\000\\065\\000\\\n \\000\\000\\065\\000\\000\\000\\000\\000\\070\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\084\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\094\\000\\000\\000\\000\\000\\097\\000\\255\\255\\\n \\255\\255\\097\\000\\255\\255\\255\\255\\255\\255\\255\\255\\104\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\109\\000\\000\\000\\000\\000\\000\\000\\113\\000\\\n \\000\\000\\000\\000\\000\\000\\117\\000\\000\\000\\000\\000\\000\\000\\121\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\126\\000\\000\\000\\000\\000\\\n \\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\000\\000\\138\\000\\000\\000\\142\\000\\000\\000\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\154\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\178\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\\n \\255\\255\\187\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\194\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\201\\000\\\n \\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\235\\000\\000\\000\\000\\000\\000\\000\\239\\000\\000\\000\\000\\000\\\n \\255\\255\\000\\000\\244\\000\\000\\000\\000\\000\\255\\255\\000\\000\\249\\000\\\n \\000\\000\\000\\000\\000\\000\\253\\000\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\003\\001\\000\\000\\000\\000\\000\\000\\000\\000\\008\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\017\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\022\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\028\\001\\000\\000\\000\\000\\000\\000\\032\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\038\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\043\\001\\000\\000\\000\\000\\000\\000\\047\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\052\\001\\000\\000\\000\\000\\000\\000\\056\\001\\000\\000\\\n \\000\\000\\000\\000\\060\\001\\000\\000\\000\\000\\000\\000\\064\\001\\000\\000\\\n \\000\\000\\000\\000\\067\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\121\\001\\125\\001\\000\\000\\000\\000\\128\\001\\255\\255\\255\\255\\\n \\128\\001\\255\\255\\255\\255\\255\\255\\255\\255\\135\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\140\\001\\000\\000\\000\\000\\255\\255\\000\\000\\144\\001\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\193\\001\\197\\001\\000\\000\\000\\000\\200\\001\\255\\255\\255\\255\\\n \\200\\001\\255\\255\\255\\255\\255\\255\\255\\255\\207\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\212\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\000\\000\\220\\001\\000\\000\\255\\255\\000\\000\\\n \\226\\001\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\233\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\240\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\245\\001\\000\\000\\000\\000\\000\\000\\249\\001\\\n \\000\\000\\000\\000\\000\\000\\252\\001\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\002\\002\\004\\002\\000\\000\\005\\002\\006\\002\\007\\002\\008\\002\\\n \\009\\002\\010\\002\\011\\002\\012\\002\\013\\002\\014\\002\\015\\002\\016\\002\\\n \\017\\002\\018\\002\\019\\002\\020\\002\\021\\002\\022\\002\\023\\002\\024\\002\\\n \\025\\002\\026\\002\\027\\002\\028\\002\\029\\002\\030\\002\\031\\002\\032\\002\\\n \\033\\002\\003\\002\";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\003\\000\\004\\000\\000\\000\\003\\000\\003\\000\\134\\000\\000\\000\\\n \\003\\000\\000\\000\\134\\000\\069\\001\\146\\001\\255\\255\\000\\000\\069\\001\\\n \\146\\001\\000\\000\\000\\000\\000\\000\\000\\000\\127\\000\\139\\000\\000\\000\\\n \\003\\000\\000\\000\\012\\000\\003\\000\\170\\000\\134\\000\\175\\000\\000\\000\\\n \\007\\000\\011\\001\\069\\001\\146\\001\\014\\001\\013\\000\\049\\000\\005\\000\\\n \\010\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\056\\000\\118\\000\\006\\000\\129\\000\\130\\000\\057\\000\\\n \\237\\001\\137\\000\\000\\002\\049\\000\\000\\000\\048\\000\\138\\000\\106\\000\\\n \\062\\000\\014\\000\\110\\000\\105\\000\\000\\000\\049\\000\\015\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\030\\000\\048\\000\\008\\000\\114\\000\\209\\000\\236\\000\\000\\001\\\n \\013\\001\\029\\000\\022\\000\\255\\255\\048\\000\\048\\000\\017\\000\\021\\000\\\n \\025\\000\\032\\000\\033\\000\\035\\000\\023\\000\\027\\000\\016\\000\\031\\000\\\n \\028\\000\\034\\000\\019\\000\\024\\000\\018\\000\\026\\000\\020\\000\\036\\000\\\n \\041\\000\\037\\000\\048\\000\\009\\000\\042\\000\\043\\000\\044\\000\\045\\000\\\n \\046\\000\\047\\000\\061\\000\\085\\000\\048\\000\\038\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\049\\000\\\n \\067\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\086\\000\\143\\000\\255\\255\\040\\000\\144\\000\\\n \\145\\000\\146\\000\\055\\000\\148\\000\\055\\000\\149\\000\\048\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\255\\255\\048\\000\\150\\000\\\n \\151\\000\\161\\000\\066\\000\\158\\000\\053\\000\\159\\000\\053\\000\\160\\000\\\n \\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\165\\000\\\n \\051\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\162\\000\\163\\000\\166\\000\\093\\000\\255\\255\\\n \\002\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\255\\255\\077\\000\\103\\000\\108\\000\\116\\000\\\n \\132\\000\\134\\000\\135\\000\\128\\000\\139\\000\\134\\000\\164\\000\\093\\000\\\n \\171\\000\\077\\000\\167\\000\\168\\000\\169\\000\\172\\000\\112\\000\\173\\000\\\n \\174\\000\\210\\000\\226\\000\\208\\000\\211\\000\\212\\000\\059\\000\\083\\000\\\n \\134\\000\\213\\000\\214\\000\\215\\000\\216\\000\\218\\000\\141\\000\\219\\000\\\n \\093\\000\\220\\000\\221\\000\\123\\000\\222\\000\\223\\000\\224\\000\\136\\000\\\n \\095\\000\\225\\000\\035\\001\\065\\001\\234\\000\\155\\000\\005\\001\\097\\001\\\n \\250\\000\\255\\255\\254\\000\\057\\001\\061\\001\\095\\001\\077\\000\\044\\001\\\n \\092\\001\\088\\001\\009\\001\\029\\001\\076\\000\\124\\000\\033\\001\\018\\001\\\n \\075\\000\\098\\000\\019\\001\\085\\001\\086\\001\\087\\001\\120\\001\\089\\001\\\n \\074\\000\\225\\000\\053\\001\\121\\001\\073\\000\\090\\001\\072\\000\\071\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\098\\000\\113\\001\\122\\000\\091\\001\\064\\000\\004\\001\\\n \\093\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\079\\000\\156\\000\\112\\001\\094\\001\\096\\001\\098\\001\\099\\001\\049\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\100\\001\\157\\000\\\n \\101\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\183\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\184\\000\\024\\001\\112\\001\\255\\255\\025\\001\\102\\001\\103\\001\\105\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\\n \\106\\001\\107\\001\\048\\001\\040\\001\\108\\001\\109\\001\\110\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\081\\000\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\111\\001\\\n \\027\\001\\255\\255\\171\\001\\031\\001\\170\\001\\023\\001\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\092\\000\\168\\001\\063\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\248\\000\\165\\001\\252\\000\\\n \\162\\001\\059\\001\\069\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\255\\255\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\039\\001\\042\\001\\255\\255\\163\\001\\\n \\164\\001\\120\\000\\002\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\166\\001\\055\\001\\153\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\007\\001\\167\\001\\164\\001\\169\\001\\016\\001\\164\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\089\\000\\051\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\090\\000\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\\n \\090\\000\\097\\000\\137\\001\\164\\001\\172\\001\\185\\001\\136\\001\\173\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\097\\000\\179\\000\\\n \\174\\001\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\046\\001\\\n \\175\\001\\176\\001\\180\\000\\164\\001\\184\\001\\181\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\124\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\192\\001\\178\\001\\\n \\021\\001\\179\\001\\097\\000\\193\\001\\180\\001\\181\\001\\182\\001\\183\\001\\\n \\164\\001\\216\\001\\255\\255\\097\\000\\184\\001\\216\\001\\209\\001\\097\\000\\\n \\223\\001\\097\\000\\208\\001\\230\\001\\003\\002\\097\\000\\219\\001\\037\\001\\\n \\216\\001\\217\\001\\003\\002\\220\\001\\216\\001\\097\\000\\003\\002\\003\\002\\\n \\216\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\216\\001\\\n \\003\\002\\126\\001\\003\\002\\003\\002\\003\\002\\003\\002\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\097\\000\\003\\002\\218\\001\\250\\001\\\n \\003\\002\\003\\002\\097\\000\\003\\002\\124\\001\\124\\001\\097\\000\\003\\002\\\n \\221\\001\\003\\002\\253\\001\\003\\002\\003\\002\\003\\002\\097\\000\\255\\255\\\n \\003\\002\\196\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\235\\001\\003\\002\\\n \\241\\001\\003\\002\\255\\001\\242\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\246\\001\\129\\001\\129\\001\\\n \\228\\001\\003\\002\\196\\001\\003\\002\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\003\\002\\198\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\003\\002\\003\\002\\003\\002\\196\\001\\234\\001\\\n \\134\\001\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\097\\000\\097\\000\\097\\000\\000\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\000\\000\\000\\000\\201\\001\\177\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\188\\000\\000\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\201\\001\\227\\001\\000\\000\\191\\000\\206\\001\\123\\001\\189\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\189\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\195\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\198\\000\\\n \\255\\255\\248\\001\\196\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\196\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\202\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\227\\000\\205\\000\\255\\255\\255\\255\\203\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\226\\000\\195\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\232\\001\\000\\000\\000\\000\\206\\000\\221\\001\\239\\001\\\n \\254\\001\\000\\000\\207\\000\\244\\001\\000\\000\\225\\000\\203\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\232\\000\\000\\000\\232\\000\\000\\000\\225\\001\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\217\\000\\\n \\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\225\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\000\\000\\230\\000\\\n \\000\\000\\230\\000\\000\\000\\228\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\000\\000\\228\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\186\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\241\\000\\000\\000\\\n \\113\\001\\000\\000\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\000\\000\\112\\001\\\n \\000\\000\\000\\000\\193\\000\\000\\000\\000\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\112\\001\\\n \\000\\000\\000\\000\\000\\000\\240\\000\\200\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\000\\000\\246\\000\\000\\000\\000\\000\\240\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\245\\000\\000\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\238\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\069\\001\\070\\001\\000\\000\\000\\000\\069\\001\\076\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\069\\001\\\n \\000\\000\\078\\001\\000\\000\\000\\000\\000\\000\\000\\000\\104\\001\\073\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\079\\001\\000\\000\\071\\001\\076\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\000\\000\\000\\000\\072\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\243\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\080\\001\\119\\001\\000\\000\\119\\001\\000\\000\\081\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\000\\000\\000\\000\\074\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\083\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\082\\001\\000\\000\\000\\000\\\n \\115\\001\\000\\000\\000\\000\\084\\001\\000\\000\\000\\000\\117\\001\\000\\000\\\n \\117\\001\\000\\000\\075\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\000\\000\\\n \\115\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\000\\000\\\n \\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\\n \\000\\000\\185\\001\\000\\000\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\184\\001\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\128\\001\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\128\\001\\128\\001\\000\\000\\000\\000\\068\\001\\\n \\128\\001\\128\\001\\128\\001\\127\\001\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\184\\001\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\000\\000\\128\\001\\127\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\128\\001\\128\\001\\128\\001\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\191\\001\\142\\001\\191\\001\\000\\000\\000\\000\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\\n \\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\141\\001\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\146\\001\\147\\001\\\n \\000\\000\\000\\000\\146\\001\\154\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\146\\001\\000\\000\\153\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\177\\001\\150\\001\\000\\000\\000\\000\\\n \\000\\000\\200\\001\\156\\001\\000\\000\\148\\001\\154\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\\n \\000\\000\\149\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\139\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\157\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\158\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\200\\001\\000\\000\\\n \\151\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\187\\001\\000\\000\\160\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\159\\001\\200\\001\\000\\000\\200\\001\\199\\001\\\n \\000\\000\\161\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\152\\001\\000\\000\\000\\000\\000\\000\\000\\000\\189\\001\\000\\000\\189\\001\\\n \\000\\000\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\145\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\\n \\200\\001\\199\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\\n \\200\\001\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\000\\000\\214\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\000\\000\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\211\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\000\\000\\255\\255\\003\\000\\000\\000\\134\\000\\255\\255\\\n \\003\\000\\255\\255\\134\\000\\069\\001\\146\\001\\057\\000\\255\\255\\069\\001\\\n \\146\\001\\255\\255\\255\\255\\255\\255\\255\\255\\125\\000\\138\\000\\255\\255\\\n \\000\\000\\255\\255\\000\\000\\003\\000\\169\\000\\134\\000\\174\\000\\255\\255\\\n \\000\\000\\010\\001\\069\\001\\146\\001\\012\\001\\000\\000\\010\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\005\\000\\115\\000\\000\\000\\125\\000\\129\\000\\005\\000\\\n \\236\\001\\136\\000\\255\\001\\038\\000\\255\\255\\010\\000\\136\\000\\102\\000\\\n \\058\\000\\000\\000\\107\\000\\102\\000\\255\\255\\011\\000\\000\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\029\\000\\038\\000\\000\\000\\111\\000\\208\\000\\233\\000\\255\\000\\\n \\012\\001\\015\\000\\017\\000\\060\\000\\011\\000\\010\\000\\000\\000\\020\\000\\\n \\024\\000\\031\\000\\032\\000\\034\\000\\022\\000\\026\\000\\000\\000\\014\\000\\\n \\027\\000\\033\\000\\018\\000\\023\\000\\000\\000\\016\\000\\019\\000\\035\\000\\\n \\040\\000\\036\\000\\038\\000\\000\\000\\041\\000\\042\\000\\043\\000\\044\\000\\\n \\045\\000\\046\\000\\058\\000\\082\\000\\011\\000\\013\\000\\013\\000\\013\\000\\\n \\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\039\\000\\\n \\063\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\085\\000\\140\\000\\060\\000\\013\\000\\143\\000\\\n \\144\\000\\145\\000\\048\\000\\147\\000\\048\\000\\148\\000\\039\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\065\\000\\039\\000\\149\\000\\\n \\150\\000\\156\\000\\063\\000\\157\\000\\051\\000\\158\\000\\051\\000\\159\\000\\\n \\050\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\155\\000\\\n \\050\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\161\\000\\162\\000\\155\\000\\091\\000\\065\\000\\\n \\000\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\057\\000\\068\\000\\102\\000\\107\\000\\115\\000\\\n \\131\\000\\133\\000\\133\\000\\125\\000\\138\\000\\133\\000\\163\\000\\094\\000\\\n \\165\\000\\068\\000\\166\\000\\167\\000\\168\\000\\171\\000\\111\\000\\172\\000\\\n \\173\\000\\206\\000\\203\\000\\207\\000\\210\\000\\211\\000\\058\\000\\082\\000\\\n \\133\\000\\212\\000\\213\\000\\214\\000\\215\\000\\217\\000\\140\\000\\218\\000\\\n \\097\\000\\219\\000\\220\\000\\119\\000\\221\\000\\222\\000\\223\\000\\133\\000\\\n \\091\\000\\203\\000\\034\\001\\062\\001\\233\\000\\152\\000\\001\\001\\080\\001\\\n \\247\\000\\060\\000\\251\\000\\054\\001\\058\\001\\081\\001\\068\\000\\041\\001\\\n \\082\\001\\083\\001\\006\\001\\026\\001\\068\\000\\119\\000\\030\\001\\015\\001\\\n \\068\\000\\094\\000\\015\\001\\084\\001\\085\\001\\086\\001\\071\\001\\088\\001\\\n \\068\\000\\203\\000\\050\\001\\071\\001\\068\\000\\089\\001\\068\\000\\068\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\097\\000\\076\\001\\119\\000\\090\\001\\063\\000\\001\\001\\\n \\092\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\152\\000\\076\\001\\093\\001\\095\\001\\097\\001\\098\\001\\045\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\099\\001\\152\\000\\\n \\100\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\180\\000\\\n \\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\\n \\180\\000\\020\\001\\076\\001\\065\\000\\020\\001\\101\\001\\102\\001\\104\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\105\\001\\106\\001\\045\\001\\036\\001\\107\\001\\108\\001\\109\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\110\\001\\\n \\026\\001\\121\\001\\157\\001\\030\\001\\158\\001\\020\\001\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\091\\000\\159\\001\\062\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\247\\000\\160\\001\\251\\000\\\n \\161\\001\\058\\001\\068\\000\\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\094\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\036\\001\\041\\001\\097\\000\\162\\001\\\n \\163\\001\\119\\000\\001\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\165\\001\\054\\001\\152\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\006\\001\\166\\001\\167\\001\\168\\001\\015\\001\\169\\001\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\050\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\089\\000\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\095\\000\\133\\001\\170\\001\\171\\001\\154\\001\\133\\001\\172\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\095\\000\\176\\000\\\n \\173\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\045\\001\\\n \\174\\001\\175\\001\\176\\000\\176\\001\\154\\001\\176\\000\\176\\000\\176\\000\\\n \\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\122\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\148\\001\\177\\001\\\n \\020\\001\\178\\001\\098\\000\\148\\001\\179\\001\\180\\001\\181\\001\\182\\001\\\n \\183\\001\\216\\001\\193\\001\\095\\000\\154\\001\\216\\001\\205\\001\\098\\000\\\n \\222\\001\\095\\000\\205\\001\\229\\001\\001\\002\\095\\000\\218\\001\\036\\001\\\n \\215\\001\\215\\001\\002\\002\\218\\001\\215\\001\\095\\000\\004\\002\\005\\002\\\n \\216\\001\\095\\000\\006\\002\\095\\000\\095\\000\\096\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\215\\001\\\n \\007\\002\\122\\001\\008\\002\\009\\002\\010\\002\\011\\002\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\098\\000\\012\\002\\215\\001\\247\\001\\\n \\013\\002\\014\\002\\098\\000\\015\\002\\125\\001\\128\\001\\098\\000\\016\\002\\\n \\220\\001\\017\\002\\251\\001\\018\\002\\019\\002\\020\\002\\098\\000\\121\\001\\\n \\021\\002\\194\\001\\098\\000\\022\\002\\098\\000\\098\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\099\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\231\\001\\023\\002\\\n \\238\\001\\024\\002\\251\\001\\238\\001\\025\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\243\\001\\125\\001\\128\\001\\\n \\224\\001\\026\\002\\197\\001\\027\\002\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\028\\002\\194\\001\\029\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\030\\002\\031\\002\\032\\002\\200\\001\\231\\001\\\n \\133\\001\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\255\\255\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\255\\255\\255\\255\\197\\001\\176\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\185\\000\\255\\255\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\200\\001\\224\\001\\255\\255\\185\\000\\205\\001\\122\\001\\185\\000\\185\\000\\\n \\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\\n \\191\\000\\191\\000\\191\\000\\191\\000\\192\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\192\\000\\\n \\193\\001\\247\\001\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\\n \\192\\000\\192\\000\\192\\000\\192\\000\\198\\000\\198\\000\\198\\000\\198\\000\\\n \\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\199\\000\\226\\000\\\n \\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\\n \\226\\000\\199\\000\\125\\001\\128\\001\\199\\000\\199\\000\\199\\000\\199\\000\\\n \\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\204\\000\\194\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\231\\001\\255\\255\\255\\255\\199\\000\\220\\001\\238\\001\\\n \\251\\001\\255\\255\\199\\000\\243\\001\\255\\255\\204\\000\\205\\000\\205\\000\\\n \\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\\n \\225\\000\\255\\255\\225\\000\\255\\255\\224\\001\\225\\000\\225\\000\\225\\000\\\n \\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\205\\000\\\n \\197\\001\\255\\255\\255\\255\\255\\255\\255\\255\\204\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\200\\001\\255\\255\\255\\255\\228\\000\\\n \\255\\255\\228\\000\\255\\255\\227\\000\\228\\000\\228\\000\\228\\000\\228\\000\\\n \\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\\n \\230\\000\\230\\000\\255\\255\\227\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\185\\000\\232\\000\\\n \\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\\n \\232\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\237\\000\\255\\255\\\n \\077\\001\\255\\255\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\113\\001\\113\\001\\113\\001\\113\\001\\\n \\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\255\\255\\077\\001\\\n \\255\\255\\255\\255\\192\\000\\255\\255\\255\\255\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\077\\001\\\n \\255\\255\\255\\255\\255\\255\\237\\000\\199\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\255\\255\\242\\000\\255\\255\\255\\255\\240\\000\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\242\\000\\255\\255\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\237\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\066\\001\\066\\001\\255\\255\\255\\255\\066\\001\\079\\001\\079\\001\\079\\001\\\n \\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\\n \\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\079\\001\\066\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\066\\001\\066\\001\\\n \\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\\n \\066\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\066\\001\\112\\001\\255\\255\\112\\001\\255\\255\\066\\001\\112\\001\\112\\001\\\n \\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\\n \\255\\255\\255\\255\\066\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\066\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\\n \\114\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\115\\001\\255\\255\\\n \\115\\001\\255\\255\\066\\001\\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\\n \\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\255\\255\\\n \\114\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\\n \\117\\001\\117\\001\\117\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\119\\001\\119\\001\\119\\001\\\n \\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\255\\255\\\n \\126\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\127\\001\\127\\001\\127\\001\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\\n \\255\\255\\155\\001\\255\\255\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\155\\001\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\126\\001\\255\\255\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\129\\001\\126\\001\\255\\255\\255\\255\\066\\001\\\n \\126\\001\\129\\001\\126\\001\\126\\001\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\155\\001\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\255\\255\\129\\001\\129\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\131\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\184\\001\\138\\001\\184\\001\\255\\255\\255\\255\\184\\001\\184\\001\\\n \\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\\n \\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\\n \\185\\001\\185\\001\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\138\\001\\\n \\255\\255\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\141\\001\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\143\\001\\143\\001\\\n \\255\\255\\255\\255\\143\\001\\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\\n \\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\156\\001\\143\\001\\255\\255\\255\\255\\\n \\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\143\\001\\143\\001\\143\\001\\\n \\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\255\\255\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\143\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\198\\001\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\198\\001\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\186\\001\\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\255\\255\\255\\255\\143\\001\\198\\001\\255\\255\\198\\001\\198\\001\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\187\\001\\255\\255\\187\\001\\\n \\255\\255\\186\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\\n \\187\\001\\187\\001\\187\\001\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\189\\001\\189\\001\\\n \\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\\n \\191\\001\\191\\001\\191\\001\\191\\001\\199\\001\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\201\\001\\255\\255\\\n \\201\\001\\201\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\255\\255\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\213\\001\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec read_json v lexbuf =\n __ocaml_lex_read_json_rec v lexbuf 0\nand __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 188 \"lib/read.mll\"\n \n# 188 \"lib/read.mll\"\n ( `Bool true )\n\n# 1032 \"lib/read.ml\"\n\n \n# 1033 \"lib/read.ml\"\n | 1 ->\n\n# 189 \"lib/read.mll\"\n \n# 189 \"lib/read.mll\"\n ( `Bool false )\n\n# 1037 \"lib/read.ml\"\n\n \n# 1038 \"lib/read.ml\"\n | 2 ->\n\n# 190 \"lib/read.mll\"\n \n# 190 \"lib/read.mll\"\n ( `Null )\n\n# 1042 \"lib/read.ml\"\n\n \n# 1043 \"lib/read.ml\"\n | 3 ->\n\n# 191 \"lib/read.mll\"\n \n# 191 \"lib/read.mll\"\n (\n \n# 193 \"lib/read.mll\"\n `Float nan\n \n# 197 \"lib/read.mll\"\n )\n\n# 1053 \"lib/read.ml\"\n\n \n# 1054 \"lib/read.ml\"\n | 4 ->\n\n# 198 \"lib/read.mll\"\n \n# 198 \"lib/read.mll\"\n (\n \n# 200 \"lib/read.mll\"\n `Float infinity\n \n# 204 \"lib/read.mll\"\n )\n\n# 1064 \"lib/read.ml\"\n\n \n# 1065 \"lib/read.ml\"\n | 5 ->\n\n# 205 \"lib/read.mll\"\n \n# 205 \"lib/read.mll\"\n (\n \n# 207 \"lib/read.mll\"\n `Float neg_infinity\n \n# 211 \"lib/read.mll\"\n )\n\n# 1075 \"lib/read.ml\"\n\n \n# 1076 \"lib/read.ml\"\n | 6 ->\n\n# 212 \"lib/read.mll\"\n \n# 212 \"lib/read.mll\"\n (\n \n# 214 \"lib/read.mll\"\n Bi_outbuf.clear v.buf;\n `String (finish_string v lexbuf)\n \n# 219 \"lib/read.mll\"\n )\n\n# 1087 \"lib/read.ml\"\n\n \n# 1088 \"lib/read.ml\"\n | 7 ->\n\n# 220 \"lib/read.mll\"\n \n# 220 \"lib/read.mll\"\n ( make_positive_int v lexbuf )\n\n# 1092 \"lib/read.ml\"\n\n \n# 1093 \"lib/read.ml\"\n | 8 ->\n\n# 221 \"lib/read.mll\"\n \n# 221 \"lib/read.mll\"\n ( make_negative_int v lexbuf )\n\n# 1097 \"lib/read.ml\"\n\n \n# 1098 \"lib/read.ml\"\n | 9 ->\n\n# 222 \"lib/read.mll\"\n \n# 222 \"lib/read.mll\"\n (\n \n# 224 \"lib/read.mll\"\n `Float (float_of_string (lexeme lexbuf))\n \n# 228 \"lib/read.mll\"\n )\n\n# 1108 \"lib/read.ml\"\n\n \n# 1109 \"lib/read.ml\"\n | 10 ->\n\n# 230 \"lib/read.mll\"\n \n# 230 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n done;\n assert false\n with End_of_object ->\n `Assoc (List.rev !acc)\n )\n\n# 1135 \"lib/read.ml\"\n\n \n# 1136 \"lib/read.ml\"\n | 11 ->\n\n# 254 \"lib/read.mll\"\n \n# 254 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_json v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_json v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n `List (List.rev !acc)\n )\n\n# 1154 \"lib/read.ml\"\n\n \n# 1155 \"lib/read.ml\"\n | 12 ->\n\n# 270 \"lib/read.mll\"\n \n# 270 \"lib/read.mll\"\n (\n \n# 287 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 289 \"lib/read.mll\"\n )\n\n# 1178 \"lib/read.ml\"\n\n \n# 1179 \"lib/read.ml\"\n | 13 ->\n\n# 291 \"lib/read.mll\"\n \n# 291 \"lib/read.mll\"\n (\n \n# 298 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 300 \"lib/read.mll\"\n )\n\n# 1192 \"lib/read.ml\"\n\n \n# 1193 \"lib/read.ml\"\n | 14 ->\n\n# 302 \"lib/read.mll\"\n \n# 302 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1197 \"lib/read.ml\"\n\n \n# 1198 \"lib/read.ml\"\n | 15 ->\n\n# 303 \"lib/read.mll\"\n \n# 303 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_json v lexbuf )\n\n# 1202 \"lib/read.ml\"\n\n \n# 1203 \"lib/read.ml\"\n | 16 ->\n\n# 304 \"lib/read.mll\"\n \n# 304 \"lib/read.mll\"\n ( newline v lexbuf; read_json v lexbuf )\n\n# 1207 \"lib/read.ml\"\n\n \n# 1208 \"lib/read.ml\"\n | 17 ->\n\n# 305 \"lib/read.mll\"\n \n# 305 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1212 \"lib/read.ml\"\n\n \n# 1213 \"lib/read.ml\"\n | 18 ->\n\n# 306 \"lib/read.mll\"\n \n# 306 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1217 \"lib/read.ml\"\n\n \n# 1218 \"lib/read.ml\"\n | 19 ->\n\n# 307 \"lib/read.mll\"\n \n# 307 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 1222 \"lib/read.ml\"\n\n \n# 1223 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state\n\nand finish_string v lexbuf =\n __ocaml_lex_finish_string_rec v lexbuf 58\nand __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 311 \"lib/read.mll\"\n \n# 311 \"lib/read.mll\"\n ( Bi_outbuf.contents v.buf )\n\n# 1234 \"lib/read.ml\"\n\n \n# 1235 \"lib/read.ml\"\n | 1 ->\n\n# 312 \"lib/read.mll\"\n \n# 312 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n finish_string v lexbuf )\n\n# 1240 \"lib/read.ml\"\n\n \n# 1241 \"lib/read.ml\"\n | 2 ->\n\n# 314 \"lib/read.mll\"\n \n# 314 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n finish_string v lexbuf )\n\n# 1246 \"lib/read.ml\"\n\n \n# 1247 \"lib/read.ml\"\n | 3 ->\n\n# 316 \"lib/read.mll\"\n \n# 316 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1251 \"lib/read.ml\"\n\n \n# 1252 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state\n\nand map_string v f lexbuf =\n __ocaml_lex_map_string_rec v f lexbuf 63\nand __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 319 \"lib/read.mll\"\n \n# 319 \"lib/read.mll\"\n ( let b = v.buf in\n f (Bytes.to_string b.Bi_outbuf.o_s) 0 b.Bi_outbuf.o_len )\n\n# 1264 \"lib/read.ml\"\n\n \n# 1265 \"lib/read.ml\"\n | 1 ->\n\n# 321 \"lib/read.mll\"\n \n# 321 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n map_string v f lexbuf )\n\n# 1270 \"lib/read.ml\"\n\n \n# 1271 \"lib/read.ml\"\n | 2 ->\n\n# 323 \"lib/read.mll\"\n \n# 323 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n map_string v f lexbuf )\n\n# 1276 \"lib/read.ml\"\n\n \n# 1277 \"lib/read.ml\"\n | 3 ->\n\n# 325 \"lib/read.mll\"\n \n# 325 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1281 \"lib/read.ml\"\n\n \n# 1282 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state\n\nand finish_escaped_char v lexbuf =\n __ocaml_lex_finish_escaped_char_rec v lexbuf 68\nand __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n c\n\n# 1294 \"lib/read.ml\"\n# 1294 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf lexbuf.Lexing.lex_start_pos in\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf c )\n\n# 1298 \"lib/read.ml\"\n\n \n# 1299 \"lib/read.ml\"\n | 1 ->\n\n# 331 \"lib/read.mll\"\n \n# 331 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\b' )\n\n# 1303 \"lib/read.ml\"\n\n \n# 1304 \"lib/read.ml\"\n | 2 ->\n\n# 332 \"lib/read.mll\"\n \n# 332 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\012' )\n\n# 1308 \"lib/read.ml\"\n\n \n# 1309 \"lib/read.ml\"\n | 3 ->\n\n# 333 \"lib/read.mll\"\n \n# 333 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n' )\n\n# 1313 \"lib/read.ml\"\n\n \n# 1314 \"lib/read.ml\"\n | 4 ->\n\n# 334 \"lib/read.mll\"\n \n# 334 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\r' )\n\n# 1318 \"lib/read.ml\"\n\n \n# 1319 \"lib/read.ml\"\n | 5 ->\n\n# 335 \"lib/read.mll\"\n \n# 335 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\t' )\n\n# 1323 \"lib/read.ml\"\n\n \n# 1324 \"lib/read.ml\"\n | 6 ->\nlet\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n a\n\n# 1329 \"lib/read.ml\"\n# 1329 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 1)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n b\n\n# 1334 \"lib/read.ml\"\n# 1334 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n c\n\n# 1339 \"lib/read.ml\"\n# 1339 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n d\n\n# 1344 \"lib/read.ml\"\n# 1344 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4) in\n\n# 337 \"lib/read.mll\"\n \n# 337 \"lib/read.mll\"\n ( let x =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if x >= 0xD800 && x <= 0xDBFF then\n finish_surrogate_pair v x lexbuf\n else\n utf8_of_code v.buf x\n )\n\n# 1355 \"lib/read.ml\"\n\n \n# 1356 \"lib/read.ml\"\n | 7 ->\n\n# 345 \"lib/read.mll\"\n \n# 345 \"lib/read.mll\"\n ( long_error \"Invalid escape sequence\" v lexbuf )\n\n# 1360 \"lib/read.ml\"\n\n \n# 1361 \"lib/read.ml\"\n | 8 ->\n\n# 346 \"lib/read.mll\"\n \n# 346 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1365 \"lib/read.ml\"\n\n \n# 1366 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state\n\nand finish_surrogate_pair v x lexbuf =\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf 82\nand __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n a\n\n# 1378 \"lib/read.ml\"\n# 1378 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n b\n\n# 1383 \"lib/read.ml\"\n# 1383 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n c\n\n# 1388 \"lib/read.ml\"\n# 1388 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n d\n\n# 1393 \"lib/read.ml\"\n# 1393 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 5) in\n\n# 350 \"lib/read.mll\"\n \n# 350 \"lib/read.mll\"\n ( let y =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if y >= 0xDC00 && y <= 0xDFFF then\n utf8_of_surrogate_pair v.buf x y\n else\n long_error \"Invalid low surrogate for code point beyond U+FFFF\"\n v lexbuf\n )\n\n# 1405 \"lib/read.ml\"\n\n \n# 1406 \"lib/read.ml\"\n | 1 ->\n\n# 359 \"lib/read.mll\"\n \n# 359 \"lib/read.mll\"\n ( long_error \"Missing escape sequence representing low surrogate \\\n for code point beyond U+FFFF\" v lexbuf )\n\n# 1411 \"lib/read.ml\"\n\n \n# 1412 \"lib/read.ml\"\n | 2 ->\n\n# 361 \"lib/read.mll\"\n \n# 361 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1416 \"lib/read.ml\"\n\n \n# 1417 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state\n\nand finish_stringlit v lexbuf =\n __ocaml_lex_finish_stringlit_rec v lexbuf 91\nand __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 366 \"lib/read.mll\"\n \n# 366 \"lib/read.mll\"\n ( let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n let s = Bytes.create (len+1) in\n Bytes.set s 0 '\"';\n Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos s 1 len;\n Bytes.to_string s\n )\n\n# 1433 \"lib/read.ml\"\n\n \n# 1434 \"lib/read.ml\"\n | 1 ->\n\n# 372 \"lib/read.mll\"\n \n# 372 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 1438 \"lib/read.ml\"\n\n \n# 1439 \"lib/read.ml\"\n | 2 ->\n\n# 373 \"lib/read.mll\"\n \n# 373 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1443 \"lib/read.ml\"\n\n \n# 1444 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_variant v lexbuf =\n __ocaml_lex_finish_variant_rec v lexbuf 102\nand __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 376 \"lib/read.mll\"\n \n# 376 \"lib/read.mll\"\n ( let x = read_json v lexbuf in\n read_space v lexbuf;\n read_gt v lexbuf;\n Some x )\n\n# 1458 \"lib/read.ml\"\n\n \n# 1459 \"lib/read.ml\"\n | 1 ->\n\n# 380 \"lib/read.mll\"\n \n# 380 \"lib/read.mll\"\n ( None )\n\n# 1463 \"lib/read.ml\"\n\n \n# 1464 \"lib/read.ml\"\n | 2 ->\n\n# 381 \"lib/read.mll\"\n \n# 381 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 1468 \"lib/read.ml\"\n\n \n# 1469 \"lib/read.ml\"\n | 3 ->\n\n# 382 \"lib/read.mll\"\n \n# 382 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1473 \"lib/read.ml\"\n\n \n# 1474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state\n\nand read_lt v lexbuf =\n __ocaml_lex_read_lt_rec v lexbuf 107\nand __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 385 \"lib/read.mll\"\n \n# 385 \"lib/read.mll\"\n ( () )\n\n# 1485 \"lib/read.ml\"\n\n \n# 1486 \"lib/read.ml\"\n | 1 ->\n\n# 386 \"lib/read.mll\"\n \n# 386 \"lib/read.mll\"\n ( long_error \"Expected '<' but found\" v lexbuf )\n\n# 1490 \"lib/read.ml\"\n\n \n# 1491 \"lib/read.ml\"\n | 2 ->\n\n# 387 \"lib/read.mll\"\n \n# 387 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1495 \"lib/read.ml\"\n\n \n# 1496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state\n\nand read_gt v lexbuf =\n __ocaml_lex_read_gt_rec v lexbuf 111\nand __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 390 \"lib/read.mll\"\n \n# 390 \"lib/read.mll\"\n ( () )\n\n# 1507 \"lib/read.ml\"\n\n \n# 1508 \"lib/read.ml\"\n | 1 ->\n\n# 391 \"lib/read.mll\"\n \n# 391 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 1512 \"lib/read.ml\"\n\n \n# 1513 \"lib/read.ml\"\n | 2 ->\n\n# 392 \"lib/read.mll\"\n \n# 392 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1517 \"lib/read.ml\"\n\n \n# 1518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state\n\nand read_comma v lexbuf =\n __ocaml_lex_read_comma_rec v lexbuf 115\nand __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 395 \"lib/read.mll\"\n \n# 395 \"lib/read.mll\"\n ( () )\n\n# 1529 \"lib/read.ml\"\n\n \n# 1530 \"lib/read.ml\"\n | 1 ->\n\n# 396 \"lib/read.mll\"\n \n# 396 \"lib/read.mll\"\n ( long_error \"Expected ',' but found\" v lexbuf )\n\n# 1534 \"lib/read.ml\"\n\n \n# 1535 \"lib/read.ml\"\n | 2 ->\n\n# 397 \"lib/read.mll\"\n \n# 397 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1539 \"lib/read.ml\"\n\n \n# 1540 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state\n\nand start_any_variant v lexbuf =\n __ocaml_lex_start_any_variant_rec v lexbuf 119\nand __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 400 \"lib/read.mll\"\n \n# 400 \"lib/read.mll\"\n ( `Edgy_bracket )\n\n# 1551 \"lib/read.ml\"\n\n \n# 1552 \"lib/read.ml\"\n | 1 ->\n\n# 401 \"lib/read.mll\"\n \n# 401 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n `Double_quote )\n\n# 1557 \"lib/read.ml\"\n\n \n# 1558 \"lib/read.ml\"\n | 2 ->\n\n# 403 \"lib/read.mll\"\n \n# 403 \"lib/read.mll\"\n ( `Square_bracket )\n\n# 1562 \"lib/read.ml\"\n\n \n# 1563 \"lib/read.ml\"\n | 3 ->\n\n# 404 \"lib/read.mll\"\n \n# 404 \"lib/read.mll\"\n ( long_error \"Expected '<', '\\\"' or '[' but found\" v lexbuf )\n\n# 1567 \"lib/read.ml\"\n\n \n# 1568 \"lib/read.ml\"\n | 4 ->\n\n# 405 \"lib/read.mll\"\n \n# 405 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1572 \"lib/read.ml\"\n\n \n# 1573 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state\n\nand finish_comment v lexbuf =\n __ocaml_lex_finish_comment_rec v lexbuf 125\nand __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 408 \"lib/read.mll\"\n \n# 408 \"lib/read.mll\"\n ( () )\n\n# 1584 \"lib/read.ml\"\n\n \n# 1585 \"lib/read.ml\"\n | 1 ->\n\n# 409 \"lib/read.mll\"\n \n# 409 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 1589 \"lib/read.ml\"\n\n \n# 1590 \"lib/read.ml\"\n | 2 ->\n\n# 410 \"lib/read.mll\"\n \n# 410 \"lib/read.mll\"\n ( newline v lexbuf; finish_comment v lexbuf )\n\n# 1594 \"lib/read.ml\"\n\n \n# 1595 \"lib/read.ml\"\n | 3 ->\n\n# 411 \"lib/read.mll\"\n \n# 411 \"lib/read.mll\"\n ( finish_comment v lexbuf )\n\n# 1599 \"lib/read.ml\"\n\n \n# 1600 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state\n\nand read_eof lexbuf =\n __ocaml_lex_read_eof_rec lexbuf 131\nand __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 419 \"lib/read.mll\"\n \n# 419 \"lib/read.mll\"\n ( true )\n\n# 1611 \"lib/read.ml\"\n\n \n# 1612 \"lib/read.ml\"\n | 1 ->\n\n# 420 \"lib/read.mll\"\n \n# 420 \"lib/read.mll\"\n ( false )\n\n# 1616 \"lib/read.ml\"\n\n \n# 1617 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state\n\nand read_space v lexbuf =\n __ocaml_lex_read_space_rec v lexbuf 133\nand __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 423 \"lib/read.mll\"\n \n# 423 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1628 \"lib/read.ml\"\n\n \n# 1629 \"lib/read.ml\"\n | 1 ->\n\n# 424 \"lib/read.mll\"\n \n# 424 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_space v lexbuf )\n\n# 1633 \"lib/read.ml\"\n\n \n# 1634 \"lib/read.ml\"\n | 2 ->\n\n# 425 \"lib/read.mll\"\n \n# 425 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1638 \"lib/read.ml\"\n\n \n# 1639 \"lib/read.ml\"\n | 3 ->\n\n# 426 \"lib/read.mll\"\n \n# 426 \"lib/read.mll\"\n ( read_space v lexbuf )\n\n# 1643 \"lib/read.ml\"\n\n \n# 1644 \"lib/read.ml\"\n | 4 ->\n\n# 427 \"lib/read.mll\"\n \n# 427 \"lib/read.mll\"\n ( () )\n\n# 1648 \"lib/read.ml\"\n\n \n# 1649 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state\n\nand read_null v lexbuf =\n __ocaml_lex_read_null_rec v lexbuf 140\nand __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 430 \"lib/read.mll\"\n \n# 430 \"lib/read.mll\"\n ( () )\n\n# 1660 \"lib/read.ml\"\n\n \n# 1661 \"lib/read.ml\"\n | 1 ->\n\n# 431 \"lib/read.mll\"\n \n# 431 \"lib/read.mll\"\n ( long_error \"Expected 'null' but found\" v lexbuf )\n\n# 1665 \"lib/read.ml\"\n\n \n# 1666 \"lib/read.ml\"\n | 2 ->\n\n# 432 \"lib/read.mll\"\n \n# 432 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1670 \"lib/read.ml\"\n\n \n# 1671 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state\n\nand read_null_if_possible v lexbuf =\n __ocaml_lex_read_null_if_possible_rec v lexbuf 147\nand __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 435 \"lib/read.mll\"\n \n# 435 \"lib/read.mll\"\n ( true )\n\n# 1682 \"lib/read.ml\"\n\n \n# 1683 \"lib/read.ml\"\n | 1 ->\n\n# 436 \"lib/read.mll\"\n \n# 436 \"lib/read.mll\"\n ( false )\n\n# 1687 \"lib/read.ml\"\n\n \n# 1688 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state\n\nand read_bool v lexbuf =\n __ocaml_lex_read_bool_rec v lexbuf 152\nand __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 439 \"lib/read.mll\"\n \n# 439 \"lib/read.mll\"\n ( true )\n\n# 1699 \"lib/read.ml\"\n\n \n# 1700 \"lib/read.ml\"\n | 1 ->\n\n# 440 \"lib/read.mll\"\n \n# 440 \"lib/read.mll\"\n ( false )\n\n# 1704 \"lib/read.ml\"\n\n \n# 1705 \"lib/read.ml\"\n | 2 ->\n\n# 443 \"lib/read.mll\"\n \n# 443 \"lib/read.mll\"\n ( true )\n\n# 1709 \"lib/read.ml\"\n\n \n# 1710 \"lib/read.ml\"\n | 3 ->\n\n# 444 \"lib/read.mll\"\n \n# 444 \"lib/read.mll\"\n ( false )\n\n# 1714 \"lib/read.ml\"\n\n \n# 1715 \"lib/read.ml\"\n | 4 ->\n\n# 446 \"lib/read.mll\"\n \n# 446 \"lib/read.mll\"\n ( long_error \"Expected 'true' or 'false' but found\" v lexbuf )\n\n# 1719 \"lib/read.ml\"\n\n \n# 1720 \"lib/read.ml\"\n | 5 ->\n\n# 447 \"lib/read.mll\"\n \n# 447 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1724 \"lib/read.ml\"\n\n \n# 1725 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state\n\nand read_int v lexbuf =\n __ocaml_lex_read_int_rec v lexbuf 176\nand __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 450 \"lib/read.mll\"\n \n# 450 \"lib/read.mll\"\n ( try extract_positive_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1738 \"lib/read.ml\"\n\n \n# 1739 \"lib/read.ml\"\n | 1 ->\n\n# 453 \"lib/read.mll\"\n \n# 453 \"lib/read.mll\"\n ( try extract_negative_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1745 \"lib/read.ml\"\n\n \n# 1746 \"lib/read.ml\"\n | 2 ->\n\n# 456 \"lib/read.mll\"\n \n# 456 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n int_of_string s\n with _ ->\n custom_error\n \"Expected an integer but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1763 \"lib/read.ml\"\n\n \n# 1764 \"lib/read.ml\"\n | 3 ->\n\n# 470 \"lib/read.mll\"\n \n# 470 \"lib/read.mll\"\n ( long_error \"Expected integer but found\" v lexbuf )\n\n# 1768 \"lib/read.ml\"\n\n \n# 1769 \"lib/read.ml\"\n | 4 ->\n\n# 471 \"lib/read.mll\"\n \n# 471 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1773 \"lib/read.ml\"\n\n \n# 1774 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state\n\nand read_int32 v lexbuf =\n __ocaml_lex_read_int32_rec v lexbuf 185\nand __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 474 \"lib/read.mll\"\n \n# 474 \"lib/read.mll\"\n ( try Int32.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1787 \"lib/read.ml\"\n\n \n# 1788 \"lib/read.ml\"\n | 1 ->\n\n# 477 \"lib/read.mll\"\n \n# 477 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int32.of_string s\n with _ ->\n custom_error\n \"Expected an int32 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1805 \"lib/read.ml\"\n\n \n# 1806 \"lib/read.ml\"\n | 2 ->\n\n# 491 \"lib/read.mll\"\n \n# 491 \"lib/read.mll\"\n ( long_error \"Expected int32 but found\" v lexbuf )\n\n# 1810 \"lib/read.ml\"\n\n \n# 1811 \"lib/read.ml\"\n | 3 ->\n\n# 492 \"lib/read.mll\"\n \n# 492 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1815 \"lib/read.ml\"\n\n \n# 1816 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state\n\nand read_int64 v lexbuf =\n __ocaml_lex_read_int64_rec v lexbuf 192\nand __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 495 \"lib/read.mll\"\n \n# 495 \"lib/read.mll\"\n ( try Int64.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1829 \"lib/read.ml\"\n\n \n# 1830 \"lib/read.ml\"\n | 1 ->\n\n# 498 \"lib/read.mll\"\n \n# 498 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int64.of_string s\n with _ ->\n custom_error\n \"Expected an int64 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1847 \"lib/read.ml\"\n\n \n# 1848 \"lib/read.ml\"\n | 2 ->\n\n# 512 \"lib/read.mll\"\n \n# 512 \"lib/read.mll\"\n ( long_error \"Expected int64 but found\" v lexbuf )\n\n# 1852 \"lib/read.ml\"\n\n \n# 1853 \"lib/read.ml\"\n | 3 ->\n\n# 513 \"lib/read.mll\"\n \n# 513 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1857 \"lib/read.ml\"\n\n \n# 1858 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state\n\nand read_number v lexbuf =\n __ocaml_lex_read_number_rec v lexbuf 199\nand __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 516 \"lib/read.mll\"\n \n# 516 \"lib/read.mll\"\n ( nan )\n\n# 1869 \"lib/read.ml\"\n\n \n# 1870 \"lib/read.ml\"\n | 1 ->\n\n# 517 \"lib/read.mll\"\n \n# 517 \"lib/read.mll\"\n ( infinity )\n\n# 1874 \"lib/read.ml\"\n\n \n# 1875 \"lib/read.ml\"\n | 2 ->\n\n# 518 \"lib/read.mll\"\n \n# 518 \"lib/read.mll\"\n ( neg_infinity )\n\n# 1879 \"lib/read.ml\"\n\n \n# 1880 \"lib/read.ml\"\n | 3 ->\n\n# 519 \"lib/read.mll\"\n \n# 519 \"lib/read.mll\"\n ( float_of_string (lexeme lexbuf) )\n\n# 1884 \"lib/read.ml\"\n\n \n# 1885 \"lib/read.ml\"\n | 4 ->\n\n# 520 \"lib/read.mll\"\n \n# 520 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant float will pass,\n including hexadecimal and octal notations,\n and embedded underscores. *)\n float_of_string s\n with _ ->\n match s with\n \"NaN\" -> nan\n | \"Infinity\" -> infinity\n | \"-Infinity\" -> neg_infinity\n | _ ->\n custom_error\n \"Expected a number but found a string that \\\n doesn't even represent a number\"\n v lexbuf\n )\n\n# 1906 \"lib/read.ml\"\n\n \n# 1907 \"lib/read.ml\"\n | 5 ->\n\n# 538 \"lib/read.mll\"\n \n# 538 \"lib/read.mll\"\n ( long_error \"Expected number but found\" v lexbuf )\n\n# 1911 \"lib/read.ml\"\n\n \n# 1912 \"lib/read.ml\"\n | 6 ->\n\n# 539 \"lib/read.mll\"\n \n# 539 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1916 \"lib/read.ml\"\n\n \n# 1917 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state\n\nand read_string v lexbuf =\n __ocaml_lex_read_string_rec v lexbuf 233\nand __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 542 \"lib/read.mll\"\n \n# 542 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1929 \"lib/read.ml\"\n\n \n# 1930 \"lib/read.ml\"\n | 1 ->\n\n# 544 \"lib/read.mll\"\n \n# 544 \"lib/read.mll\"\n ( long_error \"Expected '\\\"' but found\" v lexbuf )\n\n# 1934 \"lib/read.ml\"\n\n \n# 1935 \"lib/read.ml\"\n | 2 ->\n\n# 545 \"lib/read.mll\"\n \n# 545 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1939 \"lib/read.ml\"\n\n \n# 1940 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state\n\nand read_ident v lexbuf =\n __ocaml_lex_read_ident_rec v lexbuf 237\nand __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 548 \"lib/read.mll\"\n \n# 548 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1952 \"lib/read.ml\"\n\n \n# 1953 \"lib/read.ml\"\n | 1 ->\nlet\n\n# 550 \"lib/read.mll\"\n \n# 550 \"lib/read.mll\"\n s\n\n# 1958 \"lib/read.ml\"\n# 1958 \"lib/read.ml\"\n= Lexing.sub_lexeme lexbuf lexbuf.Lexing.lex_start_pos lexbuf.Lexing.lex_curr_pos in\n\n# 551 \"lib/read.mll\"\n \n# 551 \"lib/read.mll\"\n ( s )\n\n# 1962 \"lib/read.ml\"\n\n \n# 1963 \"lib/read.ml\"\n | 2 ->\n\n# 552 \"lib/read.mll\"\n \n# 552 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1967 \"lib/read.ml\"\n\n \n# 1968 \"lib/read.ml\"\n | 3 ->\n\n# 553 \"lib/read.mll\"\n \n# 553 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1972 \"lib/read.ml\"\n\n \n# 1973 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state\n\nand map_ident v f lexbuf =\n __ocaml_lex_map_ident_rec v f lexbuf 242\nand __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 556 \"lib/read.mll\"\n \n# 556 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n map_string v f lexbuf )\n\n# 1985 \"lib/read.ml\"\n\n \n# 1986 \"lib/read.ml\"\n | 1 ->\n\n# 559 \"lib/read.mll\"\n \n# 559 \"lib/read.mll\"\n ( map_lexeme f lexbuf )\n\n# 1990 \"lib/read.ml\"\n\n \n# 1991 \"lib/read.ml\"\n | 2 ->\n\n# 560 \"lib/read.mll\"\n \n# 560 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1995 \"lib/read.ml\"\n\n \n# 1996 \"lib/read.ml\"\n | 3 ->\n\n# 561 \"lib/read.mll\"\n \n# 561 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2000 \"lib/read.ml\"\n\n \n# 2001 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state\n\nand read_sequence read_cell init_acc v lexbuf =\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf 247\nand __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 564 \"lib/read.mll\"\n \n# 564 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell !acc v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell !acc v lexbuf;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2026 \"lib/read.ml\"\n\n \n# 2027 \"lib/read.ml\"\n | 1 ->\n\n# 579 \"lib/read.mll\"\n \n# 579 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2031 \"lib/read.ml\"\n\n \n# 2032 \"lib/read.ml\"\n | 2 ->\n\n# 580 \"lib/read.mll\"\n \n# 580 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2036 \"lib/read.ml\"\n\n \n# 2037 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_list_rev read_cell v lexbuf =\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf 251\nand __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 583 \"lib/read.mll\"\n \n# 583 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2062 \"lib/read.ml\"\n\n \n# 2063 \"lib/read.ml\"\n | 1 ->\n\n# 598 \"lib/read.mll\"\n \n# 598 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2067 \"lib/read.ml\"\n\n \n# 2068 \"lib/read.ml\"\n | 2 ->\n\n# 599 \"lib/read.mll\"\n \n# 599 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2072 \"lib/read.ml\"\n\n \n# 2073 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state\n\nand read_array_end lexbuf =\n __ocaml_lex_read_array_end_rec lexbuf 255\nand __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 602 \"lib/read.mll\"\n \n# 602 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2084 \"lib/read.ml\"\n\n \n# 2085 \"lib/read.ml\"\n | 1 ->\n\n# 603 \"lib/read.mll\"\n \n# 603 \"lib/read.mll\"\n ( () )\n\n# 2089 \"lib/read.ml\"\n\n \n# 2090 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state\n\nand read_array_sep v lexbuf =\n __ocaml_lex_read_array_sep_rec v lexbuf 257\nand __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 606 \"lib/read.mll\"\n \n# 606 \"lib/read.mll\"\n ( () )\n\n# 2101 \"lib/read.ml\"\n\n \n# 2102 \"lib/read.ml\"\n | 1 ->\n\n# 607 \"lib/read.mll\"\n \n# 607 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2106 \"lib/read.ml\"\n\n \n# 2107 \"lib/read.ml\"\n | 2 ->\n\n# 608 \"lib/read.mll\"\n \n# 608 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 2111 \"lib/read.ml\"\n\n \n# 2112 \"lib/read.ml\"\n | 3 ->\n\n# 609 \"lib/read.mll\"\n \n# 609 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2116 \"lib/read.ml\"\n\n \n# 2117 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple read_cell init_acc v lexbuf =\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf 262\nand __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 613 \"lib/read.mll\"\n \n# 613 \"lib/read.mll\"\n (\n \n# 633 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 635 \"lib/read.mll\"\n )\n\n# 2150 \"lib/read.ml\"\n\n \n# 2151 \"lib/read.ml\"\n | 1 ->\n\n# 636 \"lib/read.mll\"\n \n# 636 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2155 \"lib/read.ml\"\n\n \n# 2156 \"lib/read.ml\"\n | 2 ->\n\n# 637 \"lib/read.mll\"\n \n# 637 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2160 \"lib/read.ml\"\n\n \n# 2161 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_tuple_end lexbuf =\n __ocaml_lex_read_tuple_end_rec lexbuf 266\nand __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 640 \"lib/read.mll\"\n \n# 640 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2172 \"lib/read.ml\"\n\n \n# 2173 \"lib/read.ml\"\n | 1 ->\n\n# 641 \"lib/read.mll\"\n \n# 641 \"lib/read.mll\"\n ( () )\n\n# 2177 \"lib/read.ml\"\n\n \n# 2178 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state\n\nand read_tuple_end2 v std lexbuf =\n __ocaml_lex_read_tuple_end2_rec v std lexbuf 268\nand __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 644 \"lib/read.mll\"\n \n# 644 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ')' or '' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2192 \"lib/read.ml\"\n\n \n# 2193 \"lib/read.ml\"\n | 1 ->\n\n# 648 \"lib/read.mll\"\n \n# 648 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ']' or '' but found\" v lexbuf )\n\n# 2200 \"lib/read.ml\"\n\n \n# 2201 \"lib/read.ml\"\n | 2 ->\n\n# 652 \"lib/read.mll\"\n \n# 652 \"lib/read.mll\"\n ( () )\n\n# 2205 \"lib/read.ml\"\n\n \n# 2206 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state\n\nand read_tuple_sep v lexbuf =\n __ocaml_lex_read_tuple_sep_rec v lexbuf 271\nand __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 655 \"lib/read.mll\"\n \n# 655 \"lib/read.mll\"\n ( () )\n\n# 2217 \"lib/read.ml\"\n\n \n# 2218 \"lib/read.ml\"\n | 1 ->\n\n# 656 \"lib/read.mll\"\n \n# 656 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2222 \"lib/read.ml\"\n\n \n# 2223 \"lib/read.ml\"\n | 2 ->\n\n# 657 \"lib/read.mll\"\n \n# 657 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2227 \"lib/read.ml\"\n\n \n# 2228 \"lib/read.ml\"\n | 3 ->\n\n# 658 \"lib/read.mll\"\n \n# 658 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2232 \"lib/read.ml\"\n\n \n# 2233 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple_sep2 v std lexbuf =\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf 276\nand __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 661 \"lib/read.mll\"\n \n# 661 \"lib/read.mll\"\n ( () )\n\n# 2244 \"lib/read.ml\"\n\n \n# 2245 \"lib/read.ml\"\n | 1 ->\n\n# 662 \"lib/read.mll\"\n \n# 662 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ',' or ']' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2252 \"lib/read.ml\"\n\n \n# 2253 \"lib/read.ml\"\n | 2 ->\n\n# 666 \"lib/read.mll\"\n \n# 666 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2260 \"lib/read.ml\"\n\n \n# 2261 \"lib/read.ml\"\n | 3 ->\n\n# 670 \"lib/read.mll\"\n \n# 670 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2265 \"lib/read.ml\"\n\n \n# 2266 \"lib/read.ml\"\n | 4 ->\n\n# 671 \"lib/read.mll\"\n \n# 671 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2270 \"lib/read.ml\"\n\n \n# 2271 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state\n\nand read_abstract_fields read_key read_field init_acc v lexbuf =\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf 282\nand __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 675 \"lib/read.mll\"\n \n# 675 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n done;\n assert false\n with End_of_object ->\n !acc\n )\n\n# 2304 \"lib/read.ml\"\n\n \n# 2305 \"lib/read.ml\"\n | 1 ->\n\n# 698 \"lib/read.mll\"\n \n# 698 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2309 \"lib/read.ml\"\n\n \n# 2310 \"lib/read.ml\"\n | 2 ->\n\n# 699 \"lib/read.mll\"\n \n# 699 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2314 \"lib/read.ml\"\n\n \n# 2315 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state\n\nand read_lcurl v lexbuf =\n __ocaml_lex_read_lcurl_rec v lexbuf 286\nand __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 702 \"lib/read.mll\"\n \n# 702 \"lib/read.mll\"\n ( () )\n\n# 2326 \"lib/read.ml\"\n\n \n# 2327 \"lib/read.ml\"\n | 1 ->\n\n# 703 \"lib/read.mll\"\n \n# 703 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2331 \"lib/read.ml\"\n\n \n# 2332 \"lib/read.ml\"\n | 2 ->\n\n# 704 \"lib/read.mll\"\n \n# 704 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2336 \"lib/read.ml\"\n\n \n# 2337 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state\n\nand read_object_end lexbuf =\n __ocaml_lex_read_object_end_rec lexbuf 290\nand __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 707 \"lib/read.mll\"\n \n# 707 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2348 \"lib/read.ml\"\n\n \n# 2349 \"lib/read.ml\"\n | 1 ->\n\n# 708 \"lib/read.mll\"\n \n# 708 \"lib/read.mll\"\n ( () )\n\n# 2353 \"lib/read.ml\"\n\n \n# 2354 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state\n\nand read_object_sep v lexbuf =\n __ocaml_lex_read_object_sep_rec v lexbuf 292\nand __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 711 \"lib/read.mll\"\n \n# 711 \"lib/read.mll\"\n ( () )\n\n# 2365 \"lib/read.ml\"\n\n \n# 2366 \"lib/read.ml\"\n | 1 ->\n\n# 712 \"lib/read.mll\"\n \n# 712 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2370 \"lib/read.ml\"\n\n \n# 2371 \"lib/read.ml\"\n | 2 ->\n\n# 713 \"lib/read.mll\"\n \n# 713 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 2375 \"lib/read.ml\"\n\n \n# 2376 \"lib/read.ml\"\n | 3 ->\n\n# 714 \"lib/read.mll\"\n \n# 714 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2380 \"lib/read.ml\"\n\n \n# 2381 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state\n\nand read_colon v lexbuf =\n __ocaml_lex_read_colon_rec v lexbuf 297\nand __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 717 \"lib/read.mll\"\n \n# 717 \"lib/read.mll\"\n ( () )\n\n# 2392 \"lib/read.ml\"\n\n \n# 2393 \"lib/read.ml\"\n | 1 ->\n\n# 718 \"lib/read.mll\"\n \n# 718 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 2397 \"lib/read.ml\"\n\n \n# 2398 \"lib/read.ml\"\n | 2 ->\n\n# 719 \"lib/read.mll\"\n \n# 719 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2402 \"lib/read.ml\"\n\n \n# 2403 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state\n\nand start_any_tuple v lexbuf =\n __ocaml_lex_start_any_tuple_rec v lexbuf 301\nand __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 722 \"lib/read.mll\"\n \n# 722 \"lib/read.mll\"\n ( false )\n\n# 2414 \"lib/read.ml\"\n\n \n# 2415 \"lib/read.ml\"\n | 1 ->\n\n# 723 \"lib/read.mll\"\n \n# 723 \"lib/read.mll\"\n ( true )\n\n# 2419 \"lib/read.ml\"\n\n \n# 2420 \"lib/read.ml\"\n | 2 ->\n\n# 724 \"lib/read.mll\"\n \n# 724 \"lib/read.mll\"\n ( long_error \"Expected '(' or '[' but found\" v lexbuf )\n\n# 2424 \"lib/read.ml\"\n\n \n# 2425 \"lib/read.ml\"\n | 3 ->\n\n# 725 \"lib/read.mll\"\n \n# 725 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2429 \"lib/read.ml\"\n\n \n# 2430 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state\n\nand read_lpar v lexbuf =\n __ocaml_lex_read_lpar_rec v lexbuf 306\nand __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 728 \"lib/read.mll\"\n \n# 728 \"lib/read.mll\"\n ( () )\n\n# 2441 \"lib/read.ml\"\n\n \n# 2442 \"lib/read.ml\"\n | 1 ->\n\n# 729 \"lib/read.mll\"\n \n# 729 \"lib/read.mll\"\n ( long_error \"Expected '(' but found\" v lexbuf )\n\n# 2446 \"lib/read.ml\"\n\n \n# 2447 \"lib/read.ml\"\n | 2 ->\n\n# 730 \"lib/read.mll\"\n \n# 730 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2451 \"lib/read.ml\"\n\n \n# 2452 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state\n\nand read_rpar v lexbuf =\n __ocaml_lex_read_rpar_rec v lexbuf 310\nand __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 733 \"lib/read.mll\"\n \n# 733 \"lib/read.mll\"\n ( () )\n\n# 2463 \"lib/read.ml\"\n\n \n# 2464 \"lib/read.ml\"\n | 1 ->\n\n# 734 \"lib/read.mll\"\n \n# 734 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2468 \"lib/read.ml\"\n\n \n# 2469 \"lib/read.ml\"\n | 2 ->\n\n# 735 \"lib/read.mll\"\n \n# 735 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2473 \"lib/read.ml\"\n\n \n# 2474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state\n\nand read_lbr v lexbuf =\n __ocaml_lex_read_lbr_rec v lexbuf 314\nand __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 738 \"lib/read.mll\"\n \n# 738 \"lib/read.mll\"\n ( () )\n\n# 2485 \"lib/read.ml\"\n\n \n# 2486 \"lib/read.ml\"\n | 1 ->\n\n# 739 \"lib/read.mll\"\n \n# 739 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2490 \"lib/read.ml\"\n\n \n# 2491 \"lib/read.ml\"\n | 2 ->\n\n# 740 \"lib/read.mll\"\n \n# 740 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2495 \"lib/read.ml\"\n\n \n# 2496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state\n\nand read_rbr v lexbuf =\n __ocaml_lex_read_rbr_rec v lexbuf 318\nand __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 743 \"lib/read.mll\"\n \n# 743 \"lib/read.mll\"\n ( () )\n\n# 2507 \"lib/read.ml\"\n\n \n# 2508 \"lib/read.ml\"\n | 1 ->\n\n# 744 \"lib/read.mll\"\n \n# 744 \"lib/read.mll\"\n ( long_error \"Expected ']' but found\" v lexbuf )\n\n# 2512 \"lib/read.ml\"\n\n \n# 2513 \"lib/read.ml\"\n | 2 ->\n\n# 745 \"lib/read.mll\"\n \n# 745 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2517 \"lib/read.ml\"\n\n \n# 2518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state\n\nand skip_json v lexbuf =\n __ocaml_lex_skip_json_rec v lexbuf 322\nand __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 751 \"lib/read.mll\"\n \n# 751 \"lib/read.mll\"\n ( () )\n\n# 2529 \"lib/read.ml\"\n\n \n# 2530 \"lib/read.ml\"\n | 1 ->\n\n# 752 \"lib/read.mll\"\n \n# 752 \"lib/read.mll\"\n ( () )\n\n# 2534 \"lib/read.ml\"\n\n \n# 2535 \"lib/read.ml\"\n | 2 ->\n\n# 753 \"lib/read.mll\"\n \n# 753 \"lib/read.mll\"\n ( () )\n\n# 2539 \"lib/read.ml\"\n\n \n# 2540 \"lib/read.ml\"\n | 3 ->\n\n# 754 \"lib/read.mll\"\n \n# 754 \"lib/read.mll\"\n ( () )\n\n# 2544 \"lib/read.ml\"\n\n \n# 2545 \"lib/read.ml\"\n | 4 ->\n\n# 755 \"lib/read.mll\"\n \n# 755 \"lib/read.mll\"\n ( () )\n\n# 2549 \"lib/read.ml\"\n\n \n# 2550 \"lib/read.ml\"\n | 5 ->\n\n# 756 \"lib/read.mll\"\n \n# 756 \"lib/read.mll\"\n ( () )\n\n# 2554 \"lib/read.ml\"\n\n \n# 2555 \"lib/read.ml\"\n | 6 ->\n\n# 757 \"lib/read.mll\"\n \n# 757 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2559 \"lib/read.ml\"\n\n \n# 2560 \"lib/read.ml\"\n | 7 ->\n\n# 758 \"lib/read.mll\"\n \n# 758 \"lib/read.mll\"\n ( () )\n\n# 2564 \"lib/read.ml\"\n\n \n# 2565 \"lib/read.ml\"\n | 8 ->\n\n# 759 \"lib/read.mll\"\n \n# 759 \"lib/read.mll\"\n ( () )\n\n# 2569 \"lib/read.ml\"\n\n \n# 2570 \"lib/read.ml\"\n | 9 ->\n\n# 761 \"lib/read.mll\"\n \n# 761 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_object_end lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2595 \"lib/read.ml\"\n\n \n# 2596 \"lib/read.ml\"\n | 10 ->\n\n# 784 \"lib/read.mll\"\n \n# 784 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_array_end lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2613 \"lib/read.ml\"\n\n \n# 2614 \"lib/read.ml\"\n | 11 ->\n\n# 799 \"lib/read.mll\"\n \n# 799 \"lib/read.mll\"\n (\n \n# 815 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 817 \"lib/read.mll\"\n )\n\n# 2636 \"lib/read.ml\"\n\n \n# 2637 \"lib/read.ml\"\n | 12 ->\n\n# 819 \"lib/read.mll\"\n \n# 819 \"lib/read.mll\"\n (\n \n# 826 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 828 \"lib/read.mll\"\n )\n\n# 2650 \"lib/read.ml\"\n\n \n# 2651 \"lib/read.ml\"\n | 13 ->\n\n# 830 \"lib/read.mll\"\n \n# 830 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2655 \"lib/read.ml\"\n\n \n# 2656 \"lib/read.ml\"\n | 14 ->\n\n# 831 \"lib/read.mll\"\n \n# 831 \"lib/read.mll\"\n ( finish_comment v lexbuf; skip_json v lexbuf )\n\n# 2660 \"lib/read.ml\"\n\n \n# 2661 \"lib/read.ml\"\n | 15 ->\n\n# 832 \"lib/read.mll\"\n \n# 832 \"lib/read.mll\"\n ( newline v lexbuf; skip_json v lexbuf )\n\n# 2665 \"lib/read.ml\"\n\n \n# 2666 \"lib/read.ml\"\n | 16 ->\n\n# 833 \"lib/read.mll\"\n \n# 833 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2670 \"lib/read.ml\"\n\n \n# 2671 \"lib/read.ml\"\n | 17 ->\n\n# 834 \"lib/read.mll\"\n \n# 834 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2675 \"lib/read.ml\"\n\n \n# 2676 \"lib/read.ml\"\n | 18 ->\n\n# 835 \"lib/read.mll\"\n \n# 835 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2680 \"lib/read.ml\"\n\n \n# 2681 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_stringlit v lexbuf =\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf 378\nand __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 841 \"lib/read.mll\"\n \n# 841 \"lib/read.mll\"\n ( () )\n\n# 2692 \"lib/read.ml\"\n\n \n# 2693 \"lib/read.ml\"\n | 1 ->\n\n# 842 \"lib/read.mll\"\n \n# 842 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2697 \"lib/read.ml\"\n\n \n# 2698 \"lib/read.ml\"\n | 2 ->\n\n# 843 \"lib/read.mll\"\n \n# 843 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2702 \"lib/read.ml\"\n\n \n# 2703 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_variant v lexbuf =\n __ocaml_lex_finish_skip_variant_rec v lexbuf 389\nand __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 846 \"lib/read.mll\"\n \n# 846 \"lib/read.mll\"\n ( skip_json v lexbuf;\n read_space v lexbuf;\n read_gt v lexbuf )\n\n# 2716 \"lib/read.ml\"\n\n \n# 2717 \"lib/read.ml\"\n | 1 ->\n\n# 849 \"lib/read.mll\"\n \n# 849 \"lib/read.mll\"\n ( () )\n\n# 2721 \"lib/read.ml\"\n\n \n# 2722 \"lib/read.ml\"\n | 2 ->\n\n# 850 \"lib/read.mll\"\n \n# 850 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2726 \"lib/read.ml\"\n\n \n# 2727 \"lib/read.ml\"\n | 3 ->\n\n# 851 \"lib/read.mll\"\n \n# 851 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2731 \"lib/read.ml\"\n\n \n# 2732 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state\n\nand skip_ident v lexbuf =\n __ocaml_lex_skip_ident_rec v lexbuf 394\nand __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 854 \"lib/read.mll\"\n \n# 854 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2743 \"lib/read.ml\"\n\n \n# 2744 \"lib/read.ml\"\n | 1 ->\n\n# 855 \"lib/read.mll\"\n \n# 855 \"lib/read.mll\"\n ( () )\n\n# 2748 \"lib/read.ml\"\n\n \n# 2749 \"lib/read.ml\"\n | 2 ->\n\n# 856 \"lib/read.mll\"\n \n# 856 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2753 \"lib/read.ml\"\n\n \n# 2754 \"lib/read.ml\"\n | 3 ->\n\n# 857 \"lib/read.mll\"\n \n# 857 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2758 \"lib/read.ml\"\n\n \n# 2759 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_json v lexbuf =\n __ocaml_lex_buffer_json_rec v lexbuf 399\nand __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 870 \"lib/read.mll\"\n \n# 870 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2770 \"lib/read.ml\"\n\n \n# 2771 \"lib/read.ml\"\n | 1 ->\n\n# 872 \"lib/read.mll\"\n \n# 872 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2775 \"lib/read.ml\"\n\n \n# 2776 \"lib/read.ml\"\n | 2 ->\n\n# 873 \"lib/read.mll\"\n \n# 873 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '{';\n buffer_space v lexbuf;\n buffer_object_end v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_object_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2802 \"lib/read.ml\"\n\n \n# 2803 \"lib/read.ml\"\n | 3 ->\n\n# 897 \"lib/read.mll\"\n \n# 897 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '[';\n buffer_space v lexbuf;\n buffer_array_end v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_array_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2821 \"lib/read.ml\"\n\n \n# 2822 \"lib/read.ml\"\n | 4 ->\n\n# 913 \"lib/read.mll\"\n \n# 913 \"lib/read.mll\"\n (\n \n# 930 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 932 \"lib/read.mll\"\n )\n\n# 2845 \"lib/read.ml\"\n\n \n# 2846 \"lib/read.ml\"\n | 5 ->\n\n# 934 \"lib/read.mll\"\n \n# 934 \"lib/read.mll\"\n (\n \n# 942 \"lib/read.mll\"\n long_error \"Invalid token\" v lexbuf\n \n# 944 \"lib/read.mll\"\n )\n\n# 2860 \"lib/read.ml\"\n\n \n# 2861 \"lib/read.ml\"\n | 6 ->\n\n# 946 \"lib/read.mll\"\n \n# 946 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2865 \"lib/read.ml\"\n\n \n# 2866 \"lib/read.ml\"\n | 7 ->\n\n# 947 \"lib/read.mll\"\n \n# 947 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_json v lexbuf )\n\n# 2872 \"lib/read.ml\"\n\n \n# 2873 \"lib/read.ml\"\n | 8 ->\n\n# 950 \"lib/read.mll\"\n \n# 950 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_json v lexbuf )\n\n# 2879 \"lib/read.ml\"\n\n \n# 2880 \"lib/read.ml\"\n | 9 ->\n\n# 953 \"lib/read.mll\"\n \n# 953 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2884 \"lib/read.ml\"\n\n \n# 2885 \"lib/read.ml\"\n | 10 ->\n\n# 954 \"lib/read.mll\"\n \n# 954 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2889 \"lib/read.ml\"\n\n \n# 2890 \"lib/read.ml\"\n | 11 ->\n\n# 955 \"lib/read.mll\"\n \n# 955 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2894 \"lib/read.ml\"\n\n \n# 2895 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_stringlit v lexbuf =\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf 450\nand __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 961 \"lib/read.mll\"\n \n# 961 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\"';\n add_lexeme v.buf lexbuf\n )\n\n# 2908 \"lib/read.ml\"\n\n \n# 2909 \"lib/read.ml\"\n | 1 ->\n\n# 964 \"lib/read.mll\"\n \n# 964 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2913 \"lib/read.ml\"\n\n \n# 2914 \"lib/read.ml\"\n | 2 ->\n\n# 965 \"lib/read.mll\"\n \n# 965 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2918 \"lib/read.ml\"\n\n \n# 2919 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_variant v lexbuf =\n __ocaml_lex_finish_buffer_variant_rec v lexbuf 461\nand __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 968 \"lib/read.mll\"\n \n# 968 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':';\n buffer_json v lexbuf;\n buffer_space v lexbuf;\n buffer_gt v lexbuf )\n\n# 2933 \"lib/read.ml\"\n\n \n# 2934 \"lib/read.ml\"\n | 1 ->\n\n# 972 \"lib/read.mll\"\n \n# 972 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 2938 \"lib/read.ml\"\n\n \n# 2939 \"lib/read.ml\"\n | 2 ->\n\n# 973 \"lib/read.mll\"\n \n# 973 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2943 \"lib/read.ml\"\n\n \n# 2944 \"lib/read.ml\"\n | 3 ->\n\n# 974 \"lib/read.mll\"\n \n# 974 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2948 \"lib/read.ml\"\n\n \n# 2949 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state\n\nand buffer_ident v lexbuf =\n __ocaml_lex_buffer_ident_rec v lexbuf 466\nand __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 977 \"lib/read.mll\"\n \n# 977 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2960 \"lib/read.ml\"\n\n \n# 2961 \"lib/read.ml\"\n | 1 ->\n\n# 978 \"lib/read.mll\"\n \n# 978 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2965 \"lib/read.ml\"\n\n \n# 2966 \"lib/read.ml\"\n | 2 ->\n\n# 979 \"lib/read.mll\"\n \n# 979 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2970 \"lib/read.ml\"\n\n \n# 2971 \"lib/read.ml\"\n | 3 ->\n\n# 980 \"lib/read.mll\"\n \n# 980 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2975 \"lib/read.ml\"\n\n \n# 2976 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_space v lexbuf =\n __ocaml_lex_buffer_space_rec v lexbuf 471\nand __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 983 \"lib/read.mll\"\n \n# 983 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 2990 \"lib/read.ml\"\n\n \n# 2991 \"lib/read.ml\"\n | 1 ->\n\n# 987 \"lib/read.mll\"\n \n# 987 \"lib/read.mll\"\n (\n Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_space v lexbuf )\n\n# 2998 \"lib/read.ml\"\n\n \n# 2999 \"lib/read.ml\"\n | 2 ->\n\n# 991 \"lib/read.mll\"\n \n# 991 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 3006 \"lib/read.ml\"\n\n \n# 3007 \"lib/read.ml\"\n | 3 ->\n\n# 995 \"lib/read.mll\"\n \n# 995 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n buffer_space v lexbuf )\n\n# 3013 \"lib/read.ml\"\n\n \n# 3014 \"lib/read.ml\"\n | 4 ->\n\n# 998 \"lib/read.mll\"\n \n# 998 \"lib/read.mll\"\n ( () )\n\n# 3018 \"lib/read.ml\"\n\n \n# 3019 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_end v lexbuf =\n __ocaml_lex_buffer_object_end_rec v lexbuf 478\nand __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1001 \"lib/read.mll\"\n \n# 1001 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '}';\n raise End_of_object )\n\n# 3032 \"lib/read.ml\"\n\n \n# 3033 \"lib/read.ml\"\n | 1 ->\n\n# 1004 \"lib/read.mll\"\n \n# 1004 \"lib/read.mll\"\n ( () )\n\n# 3037 \"lib/read.ml\"\n\n \n# 3038 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_sep v lexbuf =\n __ocaml_lex_buffer_object_sep_rec v lexbuf 480\nand __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1007 \"lib/read.mll\"\n \n# 1007 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3049 \"lib/read.ml\"\n\n \n# 3050 \"lib/read.ml\"\n | 1 ->\n\n# 1008 \"lib/read.mll\"\n \n# 1008 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '}'; raise End_of_object )\n\n# 3054 \"lib/read.ml\"\n\n \n# 3055 \"lib/read.ml\"\n | 2 ->\n\n# 1009 \"lib/read.mll\"\n \n# 1009 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 3059 \"lib/read.ml\"\n\n \n# 3060 \"lib/read.ml\"\n | 3 ->\n\n# 1010 \"lib/read.mll\"\n \n# 1010 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3064 \"lib/read.ml\"\n\n \n# 3065 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_end v lexbuf =\n __ocaml_lex_buffer_array_end_rec v lexbuf 485\nand __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1013 \"lib/read.mll\"\n \n# 1013 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3076 \"lib/read.ml\"\n\n \n# 3077 \"lib/read.ml\"\n | 1 ->\n\n# 1014 \"lib/read.mll\"\n \n# 1014 \"lib/read.mll\"\n ( () )\n\n# 3081 \"lib/read.ml\"\n\n \n# 3082 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_sep v lexbuf =\n __ocaml_lex_buffer_array_sep_rec v lexbuf 487\nand __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1017 \"lib/read.mll\"\n \n# 1017 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3093 \"lib/read.ml\"\n\n \n# 3094 \"lib/read.ml\"\n | 1 ->\n\n# 1018 \"lib/read.mll\"\n \n# 1018 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3098 \"lib/read.ml\"\n\n \n# 3099 \"lib/read.ml\"\n | 2 ->\n\n# 1019 \"lib/read.mll\"\n \n# 1019 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 3103 \"lib/read.ml\"\n\n \n# 3104 \"lib/read.ml\"\n | 3 ->\n\n# 1020 \"lib/read.mll\"\n \n# 1020 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3108 \"lib/read.ml\"\n\n \n# 3109 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_end v lexbuf =\n __ocaml_lex_buffer_tuple_end_rec v lexbuf 492\nand __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1023 \"lib/read.mll\"\n \n# 1023 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf ')';\n raise End_of_tuple )\n\n# 3122 \"lib/read.ml\"\n\n \n# 3123 \"lib/read.ml\"\n | 1 ->\n\n# 1026 \"lib/read.mll\"\n \n# 1026 \"lib/read.mll\"\n ( () )\n\n# 3127 \"lib/read.ml\"\n\n \n# 3128 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_sep v lexbuf =\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf 494\nand __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1029 \"lib/read.mll\"\n \n# 1029 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3139 \"lib/read.ml\"\n\n \n# 3140 \"lib/read.ml\"\n | 1 ->\n\n# 1030 \"lib/read.mll\"\n \n# 1030 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ')'; raise End_of_tuple )\n\n# 3144 \"lib/read.ml\"\n\n \n# 3145 \"lib/read.ml\"\n | 2 ->\n\n# 1031 \"lib/read.mll\"\n \n# 1031 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 3149 \"lib/read.ml\"\n\n \n# 3150 \"lib/read.ml\"\n | 3 ->\n\n# 1032 \"lib/read.mll\"\n \n# 1032 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3154 \"lib/read.ml\"\n\n \n# 3155 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_colon v lexbuf =\n __ocaml_lex_buffer_colon_rec v lexbuf 499\nand __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1035 \"lib/read.mll\"\n \n# 1035 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':' )\n\n# 3166 \"lib/read.ml\"\n\n \n# 3167 \"lib/read.ml\"\n | 1 ->\n\n# 1036 \"lib/read.mll\"\n \n# 1036 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 3171 \"lib/read.ml\"\n\n \n# 3172 \"lib/read.ml\"\n | 2 ->\n\n# 1037 \"lib/read.mll\"\n \n# 1037 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3176 \"lib/read.ml\"\n\n \n# 3177 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state\n\nand buffer_gt v lexbuf =\n __ocaml_lex_buffer_gt_rec v lexbuf 503\nand __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1040 \"lib/read.mll\"\n \n# 1040 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 3188 \"lib/read.ml\"\n\n \n# 3189 \"lib/read.ml\"\n | 1 ->\n\n# 1041 \"lib/read.mll\"\n \n# 1041 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 3193 \"lib/read.ml\"\n\n \n# 3194 \"lib/read.ml\"\n | 2 ->\n\n# 1042 \"lib/read.mll\"\n \n# 1042 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3198 \"lib/read.ml\"\n\n \n# 3199 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_comment v lexbuf =\n __ocaml_lex_finish_buffer_comment_rec v lexbuf 507\nand __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1045 \"lib/read.mll\"\n \n# 1045 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"*/\" )\n\n# 3210 \"lib/read.ml\"\n\n \n# 3211 \"lib/read.ml\"\n | 1 ->\n\n# 1046 \"lib/read.mll\"\n \n# 1046 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 3215 \"lib/read.ml\"\n\n \n# 3216 \"lib/read.ml\"\n | 2 ->\n\n# 1047 \"lib/read.mll\"\n \n# 1047 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n finish_buffer_comment v lexbuf )\n\n# 3222 \"lib/read.ml\"\n\n \n# 3223 \"lib/read.ml\"\n | 3 ->\n\n# 1050 \"lib/read.mll\"\n \n# 1050 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; finish_buffer_comment v lexbuf )\n\n# 3227 \"lib/read.ml\"\n\n \n# 3228 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state\n\nand junk lexbuf =\n __ocaml_lex_junk_rec lexbuf 513\nand __ocaml_lex_junk_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1053 \"lib/read.mll\"\n \n# 1053 \"lib/read.mll\"\n ( Lexing.lexeme lexbuf )\n\n# 3239 \"lib/read.ml\"\n\n \n# 3240 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_junk_rec lexbuf __ocaml_lex_state\n\n;;\n\n\n# 1055 \"lib/read.mll\"\n \n \n# 1056 \"lib/read.mll\"\n let _ = (read_json : lexer_state -> Lexing.lexbuf -> t)\n\n let read_t = read_json\n\n let () =\n read_junk := junk\n\n let read_int8 v lexbuf =\n let n = read_int v lexbuf in\n if n < 0 || n > 255 then\n lexer_error \"Int8 overflow\" v lexbuf\n else\n char_of_int n\n\n let read_list read_cell v lexbuf =\n List.rev (read_list_rev read_cell v lexbuf)\n\n let array_of_rev_list l =\n match l with\n [] -> [| |]\n | x :: tl ->\n let len = List.length l in\n let a = Array.make len x in\n let r = ref tl in\n for i = len - 2 downto 0 do\n a.(i) <- List.hd !r;\n r := List.tl !r\n done;\n a\n\n let read_array read_cell v lexbuf =\n let l = read_list_rev read_cell v lexbuf in\n array_of_rev_list l\n\n (* Read a JSON object, reading the keys into OCaml strings\n (provided for backward compatibility) *)\n let read_fields read_field init_acc v =\n read_abstract_fields read_ident read_field init_acc v\n\n let finish v lexbuf =\n read_space v lexbuf;\n if not (read_eof lexbuf) then\n long_error \"Junk after end of JSON value:\" v lexbuf\n\n let init_lexer = init_lexer\n\n let from_lexbuf v ?(stream = false) lexbuf =\n read_space v lexbuf;\n\n let x =\n if read_eof lexbuf then\n raise End_of_input\n else\n read_json v lexbuf\n in\n\n if not stream then\n finish v lexbuf;\n\n x\n\n\n let from_string ?buf ?fname ?lnum s =\n try\n let lexbuf = Lexing.from_string s in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_channel ?buf ?fname ?lnum ic =\n try\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n try\n let x = from_channel ?buf ?fname ?lnum ic in\n close_in ic;\n x\n with e ->\n close_in_noerr ic;\n raise e\n\n exception Finally of exn * exn\n\n let stream_from_lexbuf v ?(fin = fun () -> ()) lexbuf =\n let stream = Some true in\n let f i =\n try Some (from_lexbuf v ?stream lexbuf)\n with\n End_of_input ->\n fin ();\n None\n | e ->\n (try fin () with fin_e -> raise (Finally (e, fin_e)));\n raise e\n in\n Stream.from f\n\n let stream_from_string ?buf ?fname ?lnum s =\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v (Lexing.from_string s)\n\n let stream_from_channel ?buf ?fin ?fname ?lnum ic =\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ?fin lexbuf\n\n let stream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ~fin lexbuf\n\n type json_line = [ `Json of t | `Exn of exn ]\n\n let linestream_from_channel\n ?buf ?(fin = fun () -> ()) ?fname ?lnum:(lnum0 = 1) ic =\n let buf =\n match buf with\n None -> Some (Bi_outbuf.create 256)\n | Some _ -> buf\n in\n let f i =\n try\n let line = input_line ic in\n let lnum = lnum0 + i in\n Some (`Json (from_string ?buf ?fname ~lnum line))\n with\n End_of_file -> fin (); None\n | e -> Some (`Exn e)\n in\n Stream.from f\n\n let linestream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n linestream_from_channel ?buf ~fin ?fname ?lnum ic\n\n let prettify ?std s =\n pretty_to_string ?std (from_string s)\n\n let compact ?std s =\n to_string (from_string s)\n\n let validate_json _path _value = None\n\n\n# 3411 \"lib/read.ml\"\n# 39 \"yojson.cppo.ml\"\nmodule Util =\nstruct\n# 1 \"util.ml\"\nexception Type_error of string * t\n\nlet typeof = function\n | `Assoc _ -> \"object\"\n | `Bool _ -> \"bool\"\n | `Float _ -> \"float\"\n | `Int _ -> \"int\"\n | `List _ -> \"array\"\n | `Null -> \"null\"\n | `String _ -> \"string\"\n | `Intlit _ -> \"intlit\"\n | `Tuple _ -> \"tuple\"\n | `Variant _ -> \"variant\"\n\nlet typerr msg js = raise (Type_error (msg ^ typeof js, js))\n\nexception Undefined of string * t\n\nlet ( |> ) = ( |> )\n\nlet assoc name obj =\n try List.assoc name obj\n with Not_found -> `Null\n\nlet member name = function\n | `Assoc obj -> assoc name obj\n | js -> typerr (\"Can't get member '\" ^ name ^ \"' of non-object type \") js\n\nlet index i = function\n | `List l as js ->\n let len = List.length l in\n let wrapped_index = if i < 0 then len + i else i in\n if wrapped_index < 0 || wrapped_index >= len then\n raise (Undefined (\"Index \" ^ string_of_int i ^ \" out of bounds\", js))\n else List.nth l wrapped_index\n | js -> typerr (\"Can't get index \" ^ string_of_int i\n ^ \" of non-array type \") js\n\nlet map f = function\n | `List l -> `List (List.map f l)\n | js -> typerr \"Can't map function over non-array type \" js\n\nlet to_assoc = function\n | `Assoc obj -> obj\n | js -> typerr \"Expected object, got \" js\n\nlet to_option f = function\n | `Null -> None\n | x -> Some (f x)\n\nlet to_bool = function\n | `Bool b -> b\n | js -> typerr \"Expected bool, got \" js\n\nlet to_bool_option = function\n | `Bool b -> Some b\n | `Null -> None\n | js -> typerr \"Expected bool or null, got \" js\n\nlet to_number = function\n | `Int i -> float i\n | `Float f -> f\n | js -> typerr \"Expected number, got \" js\n\nlet to_number_option = function\n | `Int i -> Some (float i)\n | `Float f -> Some f\n | `Null -> None\n | js -> typerr \"Expected number or null, got \" js\n\nlet to_float = function\n | `Float f -> f\n | js -> typerr \"Expected float, got \" js\n\nlet to_float_option = function\n | `Float f -> Some f\n | `Null -> None\n | js -> typerr \"Expected float or null, got \" js\n\nlet to_int = function\n | `Int i -> i\n | js -> typerr \"Expected int, got \" js\n\nlet to_int_option = function\n | `Int i -> Some i\n | `Null -> None\n | js -> typerr \"Expected int or null, got \" js\n\nlet to_list = function\n | `List l -> l\n | js -> typerr \"Expected array, got \" js\n\nlet to_string = function\n | `String s -> s\n | js -> typerr \"Expected string, got \" js\n\nlet to_string_option = function\n | `String s -> Some s\n | `Null -> None\n | js -> typerr \"Expected string or null, got \" js\n\nlet convert_each f = function\n | `List l -> List.map f l\n | js -> typerr \"Can't convert each element of non-array type \" js\n\n\nlet rec rev_filter_map f acc l =\n match l with\n [] -> acc\n | x :: tl ->\n match f x with\n None -> rev_filter_map f acc tl\n | Some y -> rev_filter_map f (y :: acc) tl\n\nlet filter_map f l =\n List.rev (rev_filter_map f [] l)\n\nlet rec rev_flatten acc l =\n match l with\n [] -> acc\n | x :: tl ->\n match x with\n `List l2 -> rev_flatten (List.rev_append l2 acc) tl\n | _ -> rev_flatten acc tl\n\nlet flatten l =\n List.rev (rev_flatten [] l)\n\nlet filter_index i l =\n filter_map (\n function\n `List l ->\n (try Some (List.nth l i)\n with _ -> None)\n | _ -> None\n ) l\n\nlet filter_list l =\n filter_map (\n function\n `List l -> Some l\n | _ -> None\n ) l\n\nlet filter_member k l =\n filter_map (\n function\n `Assoc l ->\n (try Some (List.assoc k l)\n with _ -> None)\n | _ -> None\n ) l\n\nlet filter_assoc l =\n filter_map (\n function\n `Assoc l -> Some l\n | _ -> None\n ) l\n\nlet filter_bool l =\n filter_map (\n function\n `Bool x -> Some x\n | _ -> None\n ) l\n\nlet filter_int l =\n filter_map (\n function\n `Int x -> Some x\n | _ -> None\n ) l\n\nlet filter_float l =\n filter_map (\n function\n `Float x -> Some x\n | _ -> None\n ) l\n\nlet filter_number l =\n filter_map (\n function\n `Int x -> Some (float x)\n | `Float x -> Some x\n | _ -> None\n ) l\n\nlet filter_string l =\n filter_map (\n function\n `String x -> Some x\n | _ -> None\n ) l\n\nlet keys o =\n to_assoc o |> List.map (fun (key, _) -> key)\n\nlet values o =\n to_assoc o |> List.map (fun (_, value) -> value)\n\nlet combine (first : t) (second : t) =\n match (first, second) with\n | (`Assoc a, `Assoc b) -> (`Assoc (a @ b) : t)\n | (a, b) -> raise (Invalid_argument \"Expected two objects, check inputs\")\n# 42 \"yojson.cppo.ml\"\nend\n# 46 \"yojson.cppo.ml\"\nend\n\nmodule Safe =\nstruct\n# 1 \"type.ml\"\n(** {3 Type of the JSON tree} *)\n\ntype t =\n [\n | `Null\n | `Bool of bool\n \n# 8 \"type.ml\"\n | `Int of int\n \n# 11 \"type.ml\"\n | `Intlit of string\n \n# 14 \"type.ml\"\n | `Float of float\n \n# 20 \"type.ml\"\n | `String of string\n \n# 25 \"type.ml\"\n | `Assoc of (string * t) list\n | `List of t list\n \n# 28 \"type.ml\"\n | `Tuple of t list\n \n# 31 \"type.ml\"\n | `Variant of (string * t option)\n \n# 33 \"type.ml\"\n ]\n(**\nAll possible cases defined in Yojson:\n- `Null: JSON null\n- `Bool of bool: JSON boolean\n- `Int of int: JSON number without decimal point or exponent.\n- `Intlit of string: JSON number without decimal point or exponent,\n\t preserved as a string.\n- `Float of float: JSON number, Infinity, -Infinity or NaN.\n- `Floatlit of string: JSON number, Infinity, -Infinity or NaN,\n\t preserved as a string.\n- `String of string: JSON string. Bytes in the range 128-255 are preserved\n\t as-is without encoding validation for both reading\n\t and writing.\n- `Stringlit of string: JSON string literal including the double quotes.\n- `Assoc of (string * json) list: JSON object.\n- `List of json list: JSON array.\n- `Tuple of json list: Tuple (non-standard extension of JSON).\n\t Syntax: [(\"abc\", 123)].\n- `Variant of (string * json option): Variant (non-standard extension of JSON).\n\t Syntax: [<\"Foo\">] or [<\"Bar\":123>].\n*)\n\ntype json = t [@@deprecated \"json types are being renamed and will be removed in the next Yojson major version. Use type t instead\"]\n(**\n * Compatibility type alias for type `t`\n *)\n\n(*\n Note to adventurers: ocamldoc does not support inline comments\n on each polymorphic variant, and cppo doesn't allow to concatenate\n comments, so it would be complicated to document only the\n cases that are preserved by cppo in the type definition.\n*)\n# 1 \"safe.ml\"\nlet rec to_basic : t -> Basic.t = function\n `Null\n | `Bool _\n | `Int _\n | `Float _\n | `String _ as x -> x\n | `Intlit s -> `String s\n | `List l\n | `Tuple l ->\n `List (List.rev (List.rev_map to_basic l))\n | `Assoc l ->\n `Assoc (List.rev (List.rev_map (fun (k, v) -> (k, to_basic v)) l))\n | `Variant (k, None) -> `String k\n | `Variant (k, Some v) -> `List [ `String k; to_basic v ]\n# 1 \"write.ml\"\n(* included: type.ml *)\n\nlet hex n =\n Char.chr (\n if n < 10 then n + 48\n else n + 87\n )\n\nlet write_special src start stop ob str =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n Bi_outbuf.add_string ob str;\n start := stop + 1\n\nlet write_control_char src start stop ob c =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n let i = Bi_outbuf.alloc ob 6 in\n let dst = ob.o_s in\n Bytes.blit_string \"\\\\u00\" 0 dst i 4;\n Bytes.set dst (i+4) (hex (Char.code c lsr 4));\n Bytes.set dst (i+5) (hex (Char.code c land 0xf));\n start := stop + 1\n\nlet finish_string src start ob =\n try\n Bi_outbuf.add_substring ob src !start (String.length src - !start)\n with exc ->\n Printf.eprintf \"src=%S start=%i len=%i\\n%!\"\n src !start (String.length src - !start);\n raise exc\n\nlet write_string_body ob s =\n let start = ref 0 in\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '\"' -> write_special s start i ob \"\\\\\\\"\"\n | '\\\\' -> write_special s start i ob \"\\\\\\\\\"\n | '\\b' -> write_special s start i ob \"\\\\b\"\n | '\\012' -> write_special s start i ob \"\\\\f\"\n | '\\n' -> write_special s start i ob \"\\\\n\"\n | '\\r' -> write_special s start i ob \"\\\\r\"\n | '\\t' -> write_special s start i ob \"\\\\t\"\n | '\\x00'..'\\x1F'\n | '\\x7F' as c -> write_control_char s start i ob c\n | _ -> ()\n done;\n finish_string s start ob\n\nlet write_string ob s =\n Bi_outbuf.add_char ob '\"';\n write_string_body ob s;\n Bi_outbuf.add_char ob '\"'\n\nlet json_string_of_string s =\n let ob = Bi_outbuf.create 10 in\n write_string ob s;\n Bi_outbuf.contents ob\n\nlet test_string () =\n let s = Bytes.create 256 in\n for i = 0 to 255 do\n Bytes.set s i (Char.chr i)\n done;\n json_string_of_string (Bytes.to_string s)\n\n\nlet write_null ob () =\n Bi_outbuf.add_string ob \"null\"\n\nlet write_bool ob x =\n Bi_outbuf.add_string ob (if x then \"true\" else \"false\")\n\n\nlet max_digits =\n max\n (String.length (string_of_int max_int))\n (String.length (string_of_int min_int))\n\nlet dec n =\n Char.chr (n + 48)\n\nlet rec write_digits s pos x =\n if x = 0 then pos\n else\n let d = x mod 10 in\n let pos = write_digits s pos (x / 10) in\n Bytes.set s pos (dec (abs d));\n pos + 1\n\nlet write_int ob x =\n Bi_outbuf.extend ob max_digits;\n if x > 0 then\n ob.o_len <- write_digits ob.o_s ob.o_len x\n else if x < 0 then (\n let s = ob.o_s in\n let pos = ob.o_len in\n Bytes.set s pos '-';\n ob.o_len <- write_digits s (pos + 1) x\n )\n else\n Bi_outbuf.add_char ob '0'\n\n\nlet json_string_of_int i =\n string_of_int i\n\n\n(*\n Ensure that the float is not printed as an int.\n This is not required by JSON, but useful in order to guarantee\n reversibility.\n*)\nlet float_needs_period s =\n try\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '0'..'9' | '-' -> ()\n | _ -> raise Exit\n done;\n true\n with Exit ->\n false\n\n(*\n Both write_float_fast and write_float guarantee\n that a sufficient number of digits are printed in order to\n allow reversibility.\n\n The _fast version is faster but often produces unnecessarily long numbers.\n*)\nlet write_float_fast ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_normal_float_prec significant_figures ob x =\n let open Printf in\n let s =\n match significant_figures with\n 1 -> sprintf \"%.1g\" x\n | 2 -> sprintf \"%.2g\" x\n | 3 -> sprintf \"%.3g\" x\n | 4 -> sprintf \"%.4g\" x\n | 5 -> sprintf \"%.5g\" x\n | 6 -> sprintf \"%.6g\" x\n | 7 -> sprintf \"%.7g\" x\n | 8 -> sprintf \"%.8g\" x\n | 9 -> sprintf \"%.9g\" x\n | 10 -> sprintf \"%.10g\" x\n | 11 -> sprintf \"%.11g\" x\n | 12 -> sprintf \"%.12g\" x\n | 13 -> sprintf \"%.13g\" x\n | 14 -> sprintf \"%.14g\" x\n | 15 -> sprintf \"%.15g\" x\n | 16 -> sprintf \"%.16g\" x\n | _ -> sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_float ob x;\n Bi_outbuf.contents ob\n\n\nlet write_std_float_fast ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet std_json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_std_float ob x;\n Bi_outbuf.contents ob\n\n\nlet test_float () =\n let l = [ 0.; 1.; -1. ] in\n let l = l @ List.map (fun x -> 2. *. x +. 1.) l in\n let l = l @ List.map (fun x -> x /. sqrt 2.) l in\n let l = l @ List.map (fun x -> x *. sqrt 3.) l in\n let l = l @ List.map cos l in\n let l = l @ List.map (fun x -> x *. 1.23e50) l in\n let l = l @ [ infinity; neg_infinity ] in\n List.iter (\n fun x ->\n let s = Printf.sprintf \"%.17g\" x in\n let y = float_of_string s in\n Printf.printf \"%g %g %S %B\\n\" x y s (x = y)\n )\n l\n\n(*\nlet () = test_float ()\n*)\n\nlet write_intlit = Bi_outbuf.add_string\nlet write_floatlit = Bi_outbuf.add_string\nlet write_stringlit = Bi_outbuf.add_string\n\nlet rec iter2_aux f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_sep x;\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet iter2 f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet f_sep ob =\n Bi_outbuf.add_char ob ','\n\nlet rec write_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 299 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 302 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 305 \"write.ml\"\n | `Float f -> write_float ob f\n \n# 311 \"write.ml\"\n | `String s -> write_string ob s\n \n# 316 \"write.ml\"\n | `Assoc l -> write_assoc ob l\n | `List l -> write_list ob l\n \n# 319 \"write.ml\"\n | `Tuple l -> write_tuple ob l\n \n# 322 \"write.ml\"\n | `Variant (s, o) -> write_variant ob s o\n\n# 325 \"write.ml\"\nand write_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 341 \"write.ml\"\nand write_tuple ob l =\n Bi_outbuf.add_char ob '(';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ')'\n\n# 348 \"write.ml\"\nand write_variant ob s o =\n Bi_outbuf.add_char ob '<';\n write_string ob s;\n (match o with\n None -> ()\n | Some x ->\n Bi_outbuf.add_char ob ':';\n write_json ob x\n );\n Bi_outbuf.add_char ob '>'\n\n# 360 \"write.ml\"\nlet write_t = write_json\n\nlet rec write_std_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 367 \"write.ml\"\n | `Int i -> write_int ob i\n \n# 370 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 373 \"write.ml\"\n | `Float f -> write_std_float ob f\n \n# 379 \"write.ml\"\n | `String s -> write_string ob s\n \n# 384 \"write.ml\"\n | `Assoc l -> write_std_assoc ob l\n | `List l -> write_std_list ob l\n \n# 387 \"write.ml\"\n | `Tuple l -> write_std_tuple ob l\n \n# 390 \"write.ml\"\n | `Variant (s, o) -> write_std_variant ob s o\n\n# 393 \"write.ml\"\nand write_std_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_std_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_std_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\nand write_std_tuple ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 414 \"write.ml\"\nand write_std_variant ob s o =\n match o with\n None -> write_string ob s\n | Some x ->\n Bi_outbuf.add_char ob '[';\n write_string ob s;\n Bi_outbuf.add_char ob ',';\n write_std_json ob x;\n Bi_outbuf.add_char ob ']'\n\n\n# 426 \"write.ml\"\nlet to_outbuf ?(std = false) ob x =\n if std then (\n if not (is_object_or_array x) then\n json_error \"Root is not an object or array\"\n else\n write_std_json ob x\n )\n else\n write_json ob x\n\n\nlet to_string ?buf ?(len = 256) ?std x =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n to_outbuf ?std ob x;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet to_channel ?buf ?len ?std oc x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_channel_writer ob\n\nlet to_output ?buf ?len ?std out x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_output_writer ?len out\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_output_writer ob\n\nlet to_file ?len ?std file x =\n let oc = open_out file in\n try\n to_channel ?len ?std oc x;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\nlet stream_to_outbuf ?std ob st =\n Stream.iter (to_outbuf ?std ob) st\n\nlet stream_to_string ?buf ?(len = 256) ?std st =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n stream_to_outbuf ?std ob st;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet stream_to_channel ?buf ?len ?std oc st =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n stream_to_outbuf ?std ob st;\n Bi_outbuf.flush_channel_writer ob\n\nlet stream_to_file ?len ?std file st =\n let oc = open_out file in\n try\n stream_to_channel ?len ?std oc st;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\n\nlet rec sort = function\n | `Assoc l ->\n let l = List.rev (List.rev_map (fun (k, v) -> (k, sort v)) l) in\n `Assoc (List.stable_sort (fun (a, _) (b, _) -> String.compare a b) l)\n | `List l ->\n `List (List.rev (List.rev_map sort l))\n \n# 519 \"write.ml\"\n | `Tuple l ->\n `Tuple (List.rev (List.rev_map sort l))\n \n# 523 \"write.ml\"\n | `Variant (k, Some v) as x ->\n let v' = sort v in\n if v == v' then x\n else\n `Variant (k, Some v')\n \n# 529 \"write.ml\"\n | x -> x\n# 1 \"monomorphic.ml\"\nlet rec pp fmt =\n function\n | `Null -> Format.pp_print_string fmt \"`Null\"\n | `Bool x ->\n Format.fprintf fmt \"`Bool (@[\";\n Format.fprintf fmt \"%B\" x;\n Format.fprintf fmt \"@])\"\n \n# 9 \"monomorphic.ml\"\n | `Int x ->\n Format.fprintf fmt \"`Int (@[\";\n Format.fprintf fmt \"%d\" x;\n Format.fprintf fmt \"@])\"\n \n# 15 \"monomorphic.ml\"\n | `Intlit x ->\n Format.fprintf fmt \"`Intlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 21 \"monomorphic.ml\"\n | `Float x ->\n Format.fprintf fmt \"`Float (@[\";\n Format.fprintf fmt \"%F\" x;\n Format.fprintf fmt \"@])\"\n \n# 33 \"monomorphic.ml\"\n | `String x ->\n Format.fprintf fmt \"`String (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 44 \"monomorphic.ml\"\n | `Assoc xs ->\n Format.fprintf fmt \"`Assoc (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep (key, value) ->\n if sep then\n Format.fprintf fmt \";@ \";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" key;\n Format.fprintf fmt \",@ \";\n pp fmt value;\n Format.fprintf fmt \"@])\";\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n | `List xs ->\n Format.fprintf fmt \"`List (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep x ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt x;\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 71 \"monomorphic.ml\"\n | `Tuple tup ->\n Format.fprintf fmt \"`Tuple (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep e ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt e;\n true) false tup);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 84 \"monomorphic.ml\"\n | `Variant (name, value) ->\n Format.fprintf fmt \"`Variant (@[\";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" name;\n Format.fprintf fmt \",@ \";\n (match value with\n | None -> Format.pp_print_string fmt \"None\"\n | Some x ->\n Format.pp_print_string fmt \"(Some \";\n pp fmt x;\n Format.pp_print_string fmt \")\");\n Format.fprintf fmt \"@])\";\n Format.fprintf fmt \"@])\"\n\n# 99 \"monomorphic.ml\"\nlet show x =\n Format.asprintf \"%a\" pp x\n\nlet rec equal a b =\n match a, b with\n | `Null, `Null -> true\n | `Bool a, `Bool b -> a = b\n \n# 107 \"monomorphic.ml\"\n | `Int a, `Int b -> a = b\n \n# 110 \"monomorphic.ml\"\n | `Intlit a, `Intlit b -> a = b\n \n# 113 \"monomorphic.ml\"\n | `Float a, `Float b -> a = b\n \n# 119 \"monomorphic.ml\"\n | `String a, `String b -> a = b\n \n# 124 \"monomorphic.ml\"\n | `Assoc xs, `Assoc ys ->\n let compare_keys = fun (key, _) (key', _) -> String.compare key key' in\n let xs = List.stable_sort compare_keys xs in\n let ys = List.stable_sort compare_keys ys in\n (match List.for_all2 (fun (key, value) (key', value') ->\n match key = key' with\n | false -> false\n | true -> equal value value') xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 137 \"monomorphic.ml\"\n | `Tuple xs, `Tuple ys\n \n# 139 \"monomorphic.ml\"\n | `List xs, `List ys ->\n (match List.for_all2 equal xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 146 \"monomorphic.ml\"\n | `Variant (name, value), `Variant (name', value') ->\n (match name = name' with\n | false -> false\n | true ->\n match value, value' with\n | None, None -> true\n | Some x, Some y -> equal x y\n | _ -> false)\n \n# 155 \"monomorphic.ml\"\n | _ -> false\n# 1 \"write2.ml\"\nlet pretty_format ?std (x : t) =\n Pretty.format ?std (x :> json_max)\n\nlet pretty_print ?std out (x : t) =\n Easy_format.Pretty.to_formatter out (pretty_format ?std x)\n\nlet pretty_to_string ?std (x : t) =\n Pretty.to_string ?std (x :> json_max)\n\nlet pretty_to_channel ?std oc (x : t) =\n Pretty.to_channel ?std oc (x :> json_max)\n\n# 1 \"lib/read.mll\"\n \n \n# 2 \"lib/read.mll\"\n module Lexing =\n (*\n We override Lexing.engine in order to avoid creating a new position\n record each time a rule is matched.\n This reduces total parsing time by about 31%.\n *)\n struct\n include Lexing\n\n external c_engine : lex_tables -> int -> lexbuf -> int = \"caml_lex_engine\"\n\n let engine tbl state buf =\n let result = c_engine tbl state buf in\n (*\n if result >= 0 then begin\n buf.lex_start_p <- buf.lex_curr_p;\n buf.lex_curr_p <- {buf.lex_curr_p\n with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n end;\n *)\n result\n end\n\n open Printf\n open Lexing\n\n (* see description in common.mli *)\n type lexer_state = Lexer_state.t = {\n buf : Bi_outbuf.t;\n mutable lnum : int;\n mutable bol : int;\n mutable fname : string option;\n }\n\n let dec c =\n Char.code c - 48\n\n let hex c =\n match c with\n '0'..'9' -> int_of_char c - int_of_char '0'\n | 'a'..'f' -> int_of_char c - int_of_char 'a' + 10\n | 'A'..'F' -> int_of_char c - int_of_char 'A' + 10\n | _ -> assert false\n\n let custom_error descr v lexbuf =\n let offs = lexbuf.lex_abs_pos - 1 in\n let bol = v.bol in\n let pos1 = offs + lexbuf.lex_start_pos - bol - 1 in\n let pos2 = max pos1 (offs + lexbuf.lex_curr_pos - bol) in\n let file_line =\n match v.fname with\n None -> \"Line\"\n | Some s ->\n sprintf \"File %s, line\" s\n in\n let bytes =\n if pos1 = pos2 then\n sprintf \"byte %i\" (pos1+1)\n else\n sprintf \"bytes %i-%i\" (pos1+1) (pos2+1)\n in\n let msg = sprintf \"%s %i, %s:\\n%s\" file_line v.lnum bytes descr in\n json_error msg\n\n\n let lexer_error descr v lexbuf =\n custom_error\n (sprintf \"%s '%s'\" descr (Lexing.lexeme lexbuf))\n v lexbuf\n\n let read_junk = ref (fun _ -> assert false)\n\n let long_error descr v lexbuf =\n let junk = Lexing.lexeme lexbuf in\n let extra_junk = !read_junk lexbuf in\n custom_error\n (sprintf \"%s '%s%s'\" descr junk extra_junk)\n v lexbuf\n\n let min10 = min_int / 10 - (if min_int mod 10 = 0 then 0 else 1)\n let max10 = max_int / 10 + (if max_int mod 10 = 0 then 0 else 1)\n\n exception Int_overflow\n\n let extract_positive_int lexbuf =\n let start = lexbuf.lex_start_pos in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n >= max10 then\n raise Int_overflow\n else\n n := 10 * !n + dec (Bytes.get s i)\n done;\n if !n < 0 then\n raise Int_overflow\n else\n !n\n\n let make_positive_int v lexbuf =\n \n# 104 \"lib/read.mll\"\n try `Int (extract_positive_int lexbuf)\n with Int_overflow ->\n \n# 108 \"lib/read.mll\"\n `Intlit (lexeme lexbuf)\n\n \n# 113 \"lib/read.mll\"\n let extract_negative_int lexbuf =\n let start = lexbuf.lex_start_pos + 1 in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n <= min10 then\n raise Int_overflow\n else\n n := 10 * !n - dec (Bytes.get s i)\n done;\n if !n > 0 then\n raise Int_overflow\n else\n !n\n\n let make_negative_int v lexbuf =\n \n# 131 \"lib/read.mll\"\n try `Int (extract_negative_int lexbuf)\n with Int_overflow ->\n \n# 135 \"lib/read.mll\"\n `Intlit (lexeme lexbuf)\n\n\n \n# 141 \"lib/read.mll\"\n let set_file_name v fname =\n v.fname <- fname\n\n let newline v lexbuf =\n v.lnum <- v.lnum + 1;\n v.bol <- lexbuf.lex_abs_pos + lexbuf.lex_curr_pos\n\n let add_lexeme buf lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n Bi_outbuf.add_subbytes buf lexbuf.lex_buffer lexbuf.lex_start_pos len\n\n let map_lexeme f lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n f (Bytes.to_string lexbuf.lex_buffer) lexbuf.lex_start_pos len\n\n type variant_kind = [ `Edgy_bracket | `Square_bracket | `Double_quote ]\n type tuple_kind = [ `Parenthesis | `Square_bracket ]\n\n\n# 161 \"lib/read.ml\"\n# 161 \"lib/read.ml\"\nlet __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\236\\255\\237\\255\\003\\000\\239\\255\\016\\000\\242\\255\\243\\255\\\n \\244\\255\\245\\255\\000\\000\\031\\000\\249\\255\\085\\000\\001\\000\\000\\000\\\n \\000\\000\\001\\000\\000\\000\\001\\000\\002\\000\\255\\255\\000\\000\\000\\000\\\n \\003\\000\\254\\255\\001\\000\\004\\000\\253\\255\\011\\000\\252\\255\\003\\000\\\n \\001\\000\\003\\000\\002\\000\\003\\000\\000\\000\\251\\255\\021\\000\\097\\000\\\n \\010\\000\\022\\000\\020\\000\\016\\000\\022\\000\\012\\000\\008\\000\\250\\255\\\n \\119\\000\\129\\000\\139\\000\\161\\000\\171\\000\\181\\000\\193\\000\\209\\000\\\n \\240\\255\\011\\000\\038\\000\\252\\255\\065\\000\\254\\255\\255\\255\\110\\000\\\n \\252\\255\\163\\000\\254\\255\\255\\255\\234\\000\\247\\255\\248\\255\\048\\001\\\n \\250\\255\\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\071\\001\\126\\001\\\n \\149\\001\\249\\255\\039\\000\\253\\255\\254\\255\\038\\000\\187\\001\\210\\001\\\n \\248\\001\\015\\002\\255\\255\\220\\000\\253\\255\\255\\255\\245\\000\\039\\002\\\n \\109\\002\\014\\001\\088\\002\\164\\002\\187\\002\\225\\002\\013\\000\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\014\\000\\253\\255\\254\\255\\255\\255\\030\\000\\\n \\253\\255\\254\\255\\255\\255\\015\\000\\253\\255\\254\\255\\255\\255\\017\\001\\\n \\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\019\\000\\252\\255\\253\\255\\\n \\254\\255\\015\\000\\255\\255\\016\\000\\255\\255\\008\\001\\005\\000\\253\\255\\\n \\023\\000\\254\\255\\020\\000\\255\\255\\046\\000\\253\\255\\254\\255\\042\\000\\\n \\052\\000\\053\\000\\255\\255\\053\\000\\048\\000\\091\\000\\092\\000\\255\\255\\\n \\027\\001\\250\\255\\251\\255\\137\\000\\104\\000\\089\\000\\088\\000\\106\\000\\\n \\255\\255\\143\\000\\137\\000\\177\\000\\254\\255\\183\\000\\168\\000\\166\\000\\\n \\183\\000\\002\\000\\253\\255\\177\\000\\172\\000\\187\\000\\004\\000\\252\\255\\\n \\053\\002\\251\\255\\252\\255\\253\\255\\103\\001\\255\\255\\248\\002\\254\\255\\\n \\006\\003\\030\\003\\252\\255\\253\\255\\254\\255\\255\\255\\040\\003\\050\\003\\\n \\074\\003\\252\\255\\253\\255\\254\\255\\255\\255\\061\\003\\084\\003\\108\\003\\\n \\249\\255\\250\\255\\251\\255\\244\\000\\120\\003\\142\\003\\179\\000\\194\\000\\\n \\015\\000\\255\\255\\190\\000\\188\\000\\187\\000\\193\\000\\183\\000\\179\\000\\\n \\254\\255\\191\\000\\201\\000\\200\\000\\196\\000\\203\\000\\193\\000\\189\\000\\\n \\253\\255\\157\\003\\095\\003\\174\\003\\196\\003\\206\\003\\216\\003\\228\\003\\\n \\239\\003\\060\\000\\253\\255\\254\\255\\255\\255\\012\\004\\252\\255\\253\\255\\\n \\087\\004\\255\\255\\145\\004\\252\\255\\253\\255\\221\\004\\255\\255\\229\\000\\\n \\253\\255\\254\\255\\255\\255\\231\\000\\253\\255\\254\\255\\255\\255\\002\\000\\\n \\255\\255\\018\\001\\252\\255\\253\\255\\254\\255\\255\\255\\034\\001\\253\\255\\\n \\254\\255\\255\\255\\000\\000\\255\\255\\003\\000\\254\\255\\255\\255\\038\\001\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\120\\001\\251\\255\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\208\\000\\253\\255\\254\\255\\255\\255\\211\\000\\253\\255\\\n \\254\\255\\255\\255\\189\\000\\255\\255\\143\\001\\252\\255\\253\\255\\254\\255\\\n \\255\\255\\013\\001\\253\\255\\254\\255\\255\\255\\095\\001\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\050\\001\\253\\255\\254\\255\\255\\255\\026\\001\\253\\255\\\n \\254\\255\\255\\255\\233\\000\\253\\255\\254\\255\\255\\255\\222\\000\\253\\255\\\n \\254\\255\\255\\255\\079\\005\\237\\255\\238\\255\\010\\000\\240\\255\\044\\001\\\n \\243\\255\\244\\255\\245\\255\\246\\255\\061\\001\\002\\004\\249\\255\\045\\005\\\n \\209\\000\\228\\000\\211\\000\\232\\000\\225\\000\\223\\000\\240\\000\\255\\255\\\n \\235\\000\\234\\000\\008\\001\\254\\255\\004\\001\\023\\001\\253\\255\\054\\001\\\n \\252\\255\\031\\001\\029\\001\\032\\001\\039\\001\\049\\001\\045\\001\\251\\255\\\n \\057\\001\\082\\001\\080\\001\\078\\001\\084\\001\\074\\001\\086\\001\\250\\255\\\n \\110\\005\\012\\004\\123\\005\\155\\005\\165\\005\\177\\005\\187\\005\\197\\005\\\n \\241\\255\\199\\001\\077\\002\\253\\255\\255\\255\\154\\002\\222\\005\\209\\005\\\n \\155\\002\\239\\005\\053\\006\\076\\006\\114\\006\\016\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\152\\006\\252\\255\\253\\255\\227\\006\\255\\255\\085\\007\\\n \\244\\255\\245\\255\\011\\000\\247\\255\\076\\002\\250\\255\\251\\255\\252\\255\\\n \\253\\255\\254\\255\\031\\002\\243\\005\\051\\007\\100\\001\\115\\001\\104\\001\\\n \\133\\001\\118\\001\\154\\001\\171\\001\\255\\255\\173\\001\\176\\001\\191\\001\\\n \\185\\001\\187\\001\\253\\001\\230\\001\\230\\001\\234\\001\\247\\001\\237\\001\\\n \\234\\001\\009\\002\\019\\002\\019\\002\\015\\002\\021\\002\\011\\002\\007\\002\\\n \\142\\006\\152\\006\\116\\007\\170\\007\\180\\007\\190\\007\\200\\007\\210\\007\\\n \\248\\255\\120\\002\\167\\002\\253\\255\\255\\255\\216\\002\\082\\007\\220\\007\\\n \\236\\002\\244\\007\\058\\008\\081\\008\\119\\008\\076\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\157\\008\\252\\255\\253\\255\\232\\008\\255\\255\\135\\002\\\n \\120\\002\\253\\255\\100\\002\\254\\255\\182\\002\\255\\255\\011\\002\\255\\255\\\n \\204\\002\\252\\255\\253\\255\\254\\255\\255\\255\\046\\002\\255\\255\\178\\002\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\023\\000\\255\\255\\183\\002\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\187\\002\\253\\255\\254\\255\\255\\255\\121\\002\\\n \\253\\255\\254\\255\\255\\255\\184\\002\\252\\255\\253\\255\\254\\255\\019\\000\\\n \\255\\255\\140\\001\\146\\001\\255\\255\\150\\001\\151\\001\\154\\001\\168\\001\\\n \\170\\001\\171\\001\\172\\001\\173\\001\\181\\001\\184\\001\\185\\001\\187\\001\\\n \\191\\001\\193\\001\\195\\001\\196\\001\\197\\001\\200\\001\\203\\001\\223\\001\\\n \\225\\001\\228\\001\\249\\001\\251\\001\\002\\002\\004\\002\\011\\002\\012\\002\\\n \\013\\002\\000\\000\";\n Lexing.lex_backtrk =\n \"\\255\\255\\255\\255\\255\\255\\017\\000\\255\\255\\019\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\008\\000\\008\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\\n \\255\\255\\014\\000\\255\\255\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\003\\000\\255\\255\\001\\000\\255\\255\\004\\000\\003\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\004\\000\\004\\000\\004\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\000\\000\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\003\\000\\005\\000\\005\\000\\005\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\003\\000\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\016\\000\\255\\255\\018\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\\n \\255\\255\\013\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\011\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\000\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\006\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\004\\000\\\n \\003\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\";\n Lexing.lex_default =\n \"\\001\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\057\\000\\060\\000\\000\\000\\060\\000\\000\\000\\000\\000\\065\\000\\\n \\000\\000\\065\\000\\000\\000\\000\\000\\070\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\084\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\094\\000\\000\\000\\000\\000\\097\\000\\255\\255\\\n \\255\\255\\097\\000\\255\\255\\255\\255\\255\\255\\255\\255\\104\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\109\\000\\000\\000\\000\\000\\000\\000\\113\\000\\\n \\000\\000\\000\\000\\000\\000\\117\\000\\000\\000\\000\\000\\000\\000\\121\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\126\\000\\000\\000\\000\\000\\\n \\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\000\\000\\138\\000\\000\\000\\142\\000\\000\\000\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\154\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\178\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\\n \\255\\255\\187\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\194\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\201\\000\\\n \\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\235\\000\\000\\000\\000\\000\\000\\000\\239\\000\\000\\000\\000\\000\\\n \\255\\255\\000\\000\\244\\000\\000\\000\\000\\000\\255\\255\\000\\000\\249\\000\\\n \\000\\000\\000\\000\\000\\000\\253\\000\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\003\\001\\000\\000\\000\\000\\000\\000\\000\\000\\008\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\017\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\022\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\028\\001\\000\\000\\000\\000\\000\\000\\032\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\038\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\043\\001\\000\\000\\000\\000\\000\\000\\047\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\052\\001\\000\\000\\000\\000\\000\\000\\056\\001\\000\\000\\\n \\000\\000\\000\\000\\060\\001\\000\\000\\000\\000\\000\\000\\064\\001\\000\\000\\\n \\000\\000\\000\\000\\067\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\121\\001\\125\\001\\000\\000\\000\\000\\128\\001\\255\\255\\255\\255\\\n \\128\\001\\255\\255\\255\\255\\255\\255\\255\\255\\135\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\140\\001\\000\\000\\000\\000\\255\\255\\000\\000\\144\\001\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\193\\001\\197\\001\\000\\000\\000\\000\\200\\001\\255\\255\\255\\255\\\n \\200\\001\\255\\255\\255\\255\\255\\255\\255\\255\\207\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\212\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\000\\000\\220\\001\\000\\000\\255\\255\\000\\000\\\n \\226\\001\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\233\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\240\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\245\\001\\000\\000\\000\\000\\000\\000\\249\\001\\\n \\000\\000\\000\\000\\000\\000\\252\\001\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\002\\002\\004\\002\\000\\000\\005\\002\\006\\002\\007\\002\\008\\002\\\n \\009\\002\\010\\002\\011\\002\\012\\002\\013\\002\\014\\002\\015\\002\\016\\002\\\n \\017\\002\\018\\002\\019\\002\\020\\002\\021\\002\\022\\002\\023\\002\\024\\002\\\n \\025\\002\\026\\002\\027\\002\\028\\002\\029\\002\\030\\002\\031\\002\\032\\002\\\n \\033\\002\\003\\002\";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\003\\000\\004\\000\\000\\000\\003\\000\\003\\000\\134\\000\\000\\000\\\n \\003\\000\\000\\000\\134\\000\\069\\001\\146\\001\\255\\255\\000\\000\\069\\001\\\n \\146\\001\\000\\000\\000\\000\\000\\000\\000\\000\\127\\000\\139\\000\\000\\000\\\n \\003\\000\\000\\000\\012\\000\\003\\000\\170\\000\\134\\000\\175\\000\\000\\000\\\n \\007\\000\\011\\001\\069\\001\\146\\001\\014\\001\\013\\000\\049\\000\\005\\000\\\n \\010\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\056\\000\\118\\000\\006\\000\\129\\000\\130\\000\\057\\000\\\n \\237\\001\\137\\000\\000\\002\\049\\000\\000\\000\\048\\000\\138\\000\\106\\000\\\n \\062\\000\\014\\000\\110\\000\\105\\000\\000\\000\\049\\000\\015\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\030\\000\\048\\000\\008\\000\\114\\000\\209\\000\\236\\000\\000\\001\\\n \\013\\001\\029\\000\\022\\000\\255\\255\\048\\000\\048\\000\\017\\000\\021\\000\\\n \\025\\000\\032\\000\\033\\000\\035\\000\\023\\000\\027\\000\\016\\000\\031\\000\\\n \\028\\000\\034\\000\\019\\000\\024\\000\\018\\000\\026\\000\\020\\000\\036\\000\\\n \\041\\000\\037\\000\\048\\000\\009\\000\\042\\000\\043\\000\\044\\000\\045\\000\\\n \\046\\000\\047\\000\\061\\000\\085\\000\\048\\000\\038\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\049\\000\\\n \\067\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\086\\000\\143\\000\\255\\255\\040\\000\\144\\000\\\n \\145\\000\\146\\000\\055\\000\\148\\000\\055\\000\\149\\000\\048\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\255\\255\\048\\000\\150\\000\\\n \\151\\000\\161\\000\\066\\000\\158\\000\\053\\000\\159\\000\\053\\000\\160\\000\\\n \\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\165\\000\\\n \\051\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\162\\000\\163\\000\\166\\000\\093\\000\\255\\255\\\n \\002\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\255\\255\\077\\000\\103\\000\\108\\000\\116\\000\\\n \\132\\000\\134\\000\\135\\000\\128\\000\\139\\000\\134\\000\\164\\000\\093\\000\\\n \\171\\000\\077\\000\\167\\000\\168\\000\\169\\000\\172\\000\\112\\000\\173\\000\\\n \\174\\000\\210\\000\\226\\000\\208\\000\\211\\000\\212\\000\\059\\000\\083\\000\\\n \\134\\000\\213\\000\\214\\000\\215\\000\\216\\000\\218\\000\\141\\000\\219\\000\\\n \\093\\000\\220\\000\\221\\000\\123\\000\\222\\000\\223\\000\\224\\000\\136\\000\\\n \\095\\000\\225\\000\\035\\001\\065\\001\\234\\000\\155\\000\\005\\001\\097\\001\\\n \\250\\000\\255\\255\\254\\000\\057\\001\\061\\001\\095\\001\\077\\000\\044\\001\\\n \\092\\001\\088\\001\\009\\001\\029\\001\\076\\000\\124\\000\\033\\001\\018\\001\\\n \\075\\000\\098\\000\\019\\001\\085\\001\\086\\001\\087\\001\\120\\001\\089\\001\\\n \\074\\000\\225\\000\\053\\001\\121\\001\\073\\000\\090\\001\\072\\000\\071\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\098\\000\\113\\001\\122\\000\\091\\001\\064\\000\\004\\001\\\n \\093\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\079\\000\\156\\000\\112\\001\\094\\001\\096\\001\\098\\001\\099\\001\\049\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\100\\001\\157\\000\\\n \\101\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\183\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\184\\000\\024\\001\\112\\001\\255\\255\\025\\001\\102\\001\\103\\001\\105\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\\n \\106\\001\\107\\001\\048\\001\\040\\001\\108\\001\\109\\001\\110\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\081\\000\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\111\\001\\\n \\027\\001\\255\\255\\171\\001\\031\\001\\170\\001\\023\\001\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\092\\000\\168\\001\\063\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\248\\000\\165\\001\\252\\000\\\n \\162\\001\\059\\001\\069\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\255\\255\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\039\\001\\042\\001\\255\\255\\163\\001\\\n \\164\\001\\120\\000\\002\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\166\\001\\055\\001\\153\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\007\\001\\167\\001\\164\\001\\169\\001\\016\\001\\164\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\089\\000\\051\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\090\\000\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\\n \\090\\000\\097\\000\\137\\001\\164\\001\\172\\001\\185\\001\\136\\001\\173\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\097\\000\\179\\000\\\n \\174\\001\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\046\\001\\\n \\175\\001\\176\\001\\180\\000\\164\\001\\184\\001\\181\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\124\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\192\\001\\178\\001\\\n \\021\\001\\179\\001\\097\\000\\193\\001\\180\\001\\181\\001\\182\\001\\183\\001\\\n \\164\\001\\216\\001\\255\\255\\097\\000\\184\\001\\216\\001\\209\\001\\097\\000\\\n \\223\\001\\097\\000\\208\\001\\230\\001\\003\\002\\097\\000\\219\\001\\037\\001\\\n \\216\\001\\217\\001\\003\\002\\220\\001\\216\\001\\097\\000\\003\\002\\003\\002\\\n \\216\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\216\\001\\\n \\003\\002\\126\\001\\003\\002\\003\\002\\003\\002\\003\\002\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\097\\000\\003\\002\\218\\001\\250\\001\\\n \\003\\002\\003\\002\\097\\000\\003\\002\\124\\001\\124\\001\\097\\000\\003\\002\\\n \\221\\001\\003\\002\\253\\001\\003\\002\\003\\002\\003\\002\\097\\000\\255\\255\\\n \\003\\002\\196\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\235\\001\\003\\002\\\n \\241\\001\\003\\002\\255\\001\\242\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\246\\001\\129\\001\\129\\001\\\n \\228\\001\\003\\002\\196\\001\\003\\002\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\003\\002\\198\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\003\\002\\003\\002\\003\\002\\196\\001\\234\\001\\\n \\134\\001\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\097\\000\\097\\000\\097\\000\\000\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\000\\000\\000\\000\\201\\001\\177\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\188\\000\\000\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\201\\001\\227\\001\\000\\000\\191\\000\\206\\001\\123\\001\\189\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\189\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\195\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\198\\000\\\n \\255\\255\\248\\001\\196\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\196\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\202\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\227\\000\\205\\000\\255\\255\\255\\255\\203\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\226\\000\\195\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\232\\001\\000\\000\\000\\000\\206\\000\\221\\001\\239\\001\\\n \\254\\001\\000\\000\\207\\000\\244\\001\\000\\000\\225\\000\\203\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\232\\000\\000\\000\\232\\000\\000\\000\\225\\001\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\217\\000\\\n \\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\225\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\000\\000\\230\\000\\\n \\000\\000\\230\\000\\000\\000\\228\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\000\\000\\228\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\186\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\241\\000\\000\\000\\\n \\113\\001\\000\\000\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\000\\000\\112\\001\\\n \\000\\000\\000\\000\\193\\000\\000\\000\\000\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\112\\001\\\n \\000\\000\\000\\000\\000\\000\\240\\000\\200\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\000\\000\\246\\000\\000\\000\\000\\000\\240\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\245\\000\\000\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\238\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\069\\001\\070\\001\\000\\000\\000\\000\\069\\001\\076\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\069\\001\\\n \\000\\000\\078\\001\\000\\000\\000\\000\\000\\000\\000\\000\\104\\001\\073\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\079\\001\\000\\000\\071\\001\\076\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\000\\000\\000\\000\\072\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\243\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\080\\001\\119\\001\\000\\000\\119\\001\\000\\000\\081\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\000\\000\\000\\000\\074\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\083\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\082\\001\\000\\000\\000\\000\\\n \\115\\001\\000\\000\\000\\000\\084\\001\\000\\000\\000\\000\\117\\001\\000\\000\\\n \\117\\001\\000\\000\\075\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\000\\000\\\n \\115\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\000\\000\\\n \\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\\n \\000\\000\\185\\001\\000\\000\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\184\\001\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\128\\001\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\128\\001\\128\\001\\000\\000\\000\\000\\068\\001\\\n \\128\\001\\128\\001\\128\\001\\127\\001\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\184\\001\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\000\\000\\128\\001\\127\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\128\\001\\128\\001\\128\\001\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\191\\001\\142\\001\\191\\001\\000\\000\\000\\000\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\\n \\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\141\\001\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\146\\001\\147\\001\\\n \\000\\000\\000\\000\\146\\001\\154\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\146\\001\\000\\000\\153\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\177\\001\\150\\001\\000\\000\\000\\000\\\n \\000\\000\\200\\001\\156\\001\\000\\000\\148\\001\\154\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\\n \\000\\000\\149\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\139\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\157\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\158\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\200\\001\\000\\000\\\n \\151\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\187\\001\\000\\000\\160\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\159\\001\\200\\001\\000\\000\\200\\001\\199\\001\\\n \\000\\000\\161\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\152\\001\\000\\000\\000\\000\\000\\000\\000\\000\\189\\001\\000\\000\\189\\001\\\n \\000\\000\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\145\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\\n \\200\\001\\199\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\\n \\200\\001\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\000\\000\\214\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\000\\000\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\211\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\000\\000\\255\\255\\003\\000\\000\\000\\134\\000\\255\\255\\\n \\003\\000\\255\\255\\134\\000\\069\\001\\146\\001\\057\\000\\255\\255\\069\\001\\\n \\146\\001\\255\\255\\255\\255\\255\\255\\255\\255\\125\\000\\138\\000\\255\\255\\\n \\000\\000\\255\\255\\000\\000\\003\\000\\169\\000\\134\\000\\174\\000\\255\\255\\\n \\000\\000\\010\\001\\069\\001\\146\\001\\012\\001\\000\\000\\010\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\005\\000\\115\\000\\000\\000\\125\\000\\129\\000\\005\\000\\\n \\236\\001\\136\\000\\255\\001\\038\\000\\255\\255\\010\\000\\136\\000\\102\\000\\\n \\058\\000\\000\\000\\107\\000\\102\\000\\255\\255\\011\\000\\000\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\029\\000\\038\\000\\000\\000\\111\\000\\208\\000\\233\\000\\255\\000\\\n \\012\\001\\015\\000\\017\\000\\060\\000\\011\\000\\010\\000\\000\\000\\020\\000\\\n \\024\\000\\031\\000\\032\\000\\034\\000\\022\\000\\026\\000\\000\\000\\014\\000\\\n \\027\\000\\033\\000\\018\\000\\023\\000\\000\\000\\016\\000\\019\\000\\035\\000\\\n \\040\\000\\036\\000\\038\\000\\000\\000\\041\\000\\042\\000\\043\\000\\044\\000\\\n \\045\\000\\046\\000\\058\\000\\082\\000\\011\\000\\013\\000\\013\\000\\013\\000\\\n \\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\039\\000\\\n \\063\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\085\\000\\140\\000\\060\\000\\013\\000\\143\\000\\\n \\144\\000\\145\\000\\048\\000\\147\\000\\048\\000\\148\\000\\039\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\065\\000\\039\\000\\149\\000\\\n \\150\\000\\156\\000\\063\\000\\157\\000\\051\\000\\158\\000\\051\\000\\159\\000\\\n \\050\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\155\\000\\\n \\050\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\161\\000\\162\\000\\155\\000\\091\\000\\065\\000\\\n \\000\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\057\\000\\068\\000\\102\\000\\107\\000\\115\\000\\\n \\131\\000\\133\\000\\133\\000\\125\\000\\138\\000\\133\\000\\163\\000\\094\\000\\\n \\165\\000\\068\\000\\166\\000\\167\\000\\168\\000\\171\\000\\111\\000\\172\\000\\\n \\173\\000\\206\\000\\203\\000\\207\\000\\210\\000\\211\\000\\058\\000\\082\\000\\\n \\133\\000\\212\\000\\213\\000\\214\\000\\215\\000\\217\\000\\140\\000\\218\\000\\\n \\097\\000\\219\\000\\220\\000\\119\\000\\221\\000\\222\\000\\223\\000\\133\\000\\\n \\091\\000\\203\\000\\034\\001\\062\\001\\233\\000\\152\\000\\001\\001\\080\\001\\\n \\247\\000\\060\\000\\251\\000\\054\\001\\058\\001\\081\\001\\068\\000\\041\\001\\\n \\082\\001\\083\\001\\006\\001\\026\\001\\068\\000\\119\\000\\030\\001\\015\\001\\\n \\068\\000\\094\\000\\015\\001\\084\\001\\085\\001\\086\\001\\071\\001\\088\\001\\\n \\068\\000\\203\\000\\050\\001\\071\\001\\068\\000\\089\\001\\068\\000\\068\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\097\\000\\076\\001\\119\\000\\090\\001\\063\\000\\001\\001\\\n \\092\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\152\\000\\076\\001\\093\\001\\095\\001\\097\\001\\098\\001\\045\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\099\\001\\152\\000\\\n \\100\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\180\\000\\\n \\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\\n \\180\\000\\020\\001\\076\\001\\065\\000\\020\\001\\101\\001\\102\\001\\104\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\105\\001\\106\\001\\045\\001\\036\\001\\107\\001\\108\\001\\109\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\110\\001\\\n \\026\\001\\121\\001\\157\\001\\030\\001\\158\\001\\020\\001\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\091\\000\\159\\001\\062\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\247\\000\\160\\001\\251\\000\\\n \\161\\001\\058\\001\\068\\000\\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\094\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\036\\001\\041\\001\\097\\000\\162\\001\\\n \\163\\001\\119\\000\\001\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\165\\001\\054\\001\\152\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\006\\001\\166\\001\\167\\001\\168\\001\\015\\001\\169\\001\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\050\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\089\\000\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\095\\000\\133\\001\\170\\001\\171\\001\\154\\001\\133\\001\\172\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\095\\000\\176\\000\\\n \\173\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\045\\001\\\n \\174\\001\\175\\001\\176\\000\\176\\001\\154\\001\\176\\000\\176\\000\\176\\000\\\n \\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\122\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\148\\001\\177\\001\\\n \\020\\001\\178\\001\\098\\000\\148\\001\\179\\001\\180\\001\\181\\001\\182\\001\\\n \\183\\001\\216\\001\\193\\001\\095\\000\\154\\001\\216\\001\\205\\001\\098\\000\\\n \\222\\001\\095\\000\\205\\001\\229\\001\\001\\002\\095\\000\\218\\001\\036\\001\\\n \\215\\001\\215\\001\\002\\002\\218\\001\\215\\001\\095\\000\\004\\002\\005\\002\\\n \\216\\001\\095\\000\\006\\002\\095\\000\\095\\000\\096\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\215\\001\\\n \\007\\002\\122\\001\\008\\002\\009\\002\\010\\002\\011\\002\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\098\\000\\012\\002\\215\\001\\247\\001\\\n \\013\\002\\014\\002\\098\\000\\015\\002\\125\\001\\128\\001\\098\\000\\016\\002\\\n \\220\\001\\017\\002\\251\\001\\018\\002\\019\\002\\020\\002\\098\\000\\121\\001\\\n \\021\\002\\194\\001\\098\\000\\022\\002\\098\\000\\098\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\099\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\231\\001\\023\\002\\\n \\238\\001\\024\\002\\251\\001\\238\\001\\025\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\243\\001\\125\\001\\128\\001\\\n \\224\\001\\026\\002\\197\\001\\027\\002\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\028\\002\\194\\001\\029\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\030\\002\\031\\002\\032\\002\\200\\001\\231\\001\\\n \\133\\001\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\255\\255\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\255\\255\\255\\255\\197\\001\\176\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\185\\000\\255\\255\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\200\\001\\224\\001\\255\\255\\185\\000\\205\\001\\122\\001\\185\\000\\185\\000\\\n \\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\\n \\191\\000\\191\\000\\191\\000\\191\\000\\192\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\192\\000\\\n \\193\\001\\247\\001\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\\n \\192\\000\\192\\000\\192\\000\\192\\000\\198\\000\\198\\000\\198\\000\\198\\000\\\n \\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\199\\000\\226\\000\\\n \\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\\n \\226\\000\\199\\000\\125\\001\\128\\001\\199\\000\\199\\000\\199\\000\\199\\000\\\n \\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\204\\000\\194\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\231\\001\\255\\255\\255\\255\\199\\000\\220\\001\\238\\001\\\n \\251\\001\\255\\255\\199\\000\\243\\001\\255\\255\\204\\000\\205\\000\\205\\000\\\n \\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\\n \\225\\000\\255\\255\\225\\000\\255\\255\\224\\001\\225\\000\\225\\000\\225\\000\\\n \\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\205\\000\\\n \\197\\001\\255\\255\\255\\255\\255\\255\\255\\255\\204\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\200\\001\\255\\255\\255\\255\\228\\000\\\n \\255\\255\\228\\000\\255\\255\\227\\000\\228\\000\\228\\000\\228\\000\\228\\000\\\n \\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\\n \\230\\000\\230\\000\\255\\255\\227\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\185\\000\\232\\000\\\n \\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\\n \\232\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\237\\000\\255\\255\\\n \\077\\001\\255\\255\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\113\\001\\113\\001\\113\\001\\113\\001\\\n \\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\255\\255\\077\\001\\\n \\255\\255\\255\\255\\192\\000\\255\\255\\255\\255\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\077\\001\\\n \\255\\255\\255\\255\\255\\255\\237\\000\\199\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\255\\255\\242\\000\\255\\255\\255\\255\\240\\000\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\242\\000\\255\\255\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\237\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\066\\001\\066\\001\\255\\255\\255\\255\\066\\001\\079\\001\\079\\001\\079\\001\\\n \\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\\n \\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\079\\001\\066\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\066\\001\\066\\001\\\n \\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\\n \\066\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\066\\001\\112\\001\\255\\255\\112\\001\\255\\255\\066\\001\\112\\001\\112\\001\\\n \\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\\n \\255\\255\\255\\255\\066\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\066\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\\n \\114\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\115\\001\\255\\255\\\n \\115\\001\\255\\255\\066\\001\\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\\n \\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\255\\255\\\n \\114\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\\n \\117\\001\\117\\001\\117\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\119\\001\\119\\001\\119\\001\\\n \\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\255\\255\\\n \\126\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\127\\001\\127\\001\\127\\001\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\\n \\255\\255\\155\\001\\255\\255\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\155\\001\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\126\\001\\255\\255\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\129\\001\\126\\001\\255\\255\\255\\255\\066\\001\\\n \\126\\001\\129\\001\\126\\001\\126\\001\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\155\\001\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\255\\255\\129\\001\\129\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\131\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\184\\001\\138\\001\\184\\001\\255\\255\\255\\255\\184\\001\\184\\001\\\n \\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\\n \\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\\n \\185\\001\\185\\001\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\138\\001\\\n \\255\\255\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\141\\001\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\143\\001\\143\\001\\\n \\255\\255\\255\\255\\143\\001\\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\\n \\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\156\\001\\143\\001\\255\\255\\255\\255\\\n \\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\143\\001\\143\\001\\143\\001\\\n \\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\255\\255\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\143\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\198\\001\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\198\\001\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\186\\001\\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\255\\255\\255\\255\\143\\001\\198\\001\\255\\255\\198\\001\\198\\001\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\187\\001\\255\\255\\187\\001\\\n \\255\\255\\186\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\\n \\187\\001\\187\\001\\187\\001\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\189\\001\\189\\001\\\n \\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\\n \\191\\001\\191\\001\\191\\001\\191\\001\\199\\001\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\201\\001\\255\\255\\\n \\201\\001\\201\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\255\\255\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\213\\001\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec read_json v lexbuf =\n __ocaml_lex_read_json_rec v lexbuf 0\nand __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 188 \"lib/read.mll\"\n \n# 188 \"lib/read.mll\"\n ( `Bool true )\n\n# 1032 \"lib/read.ml\"\n\n \n# 1033 \"lib/read.ml\"\n | 1 ->\n\n# 189 \"lib/read.mll\"\n \n# 189 \"lib/read.mll\"\n ( `Bool false )\n\n# 1037 \"lib/read.ml\"\n\n \n# 1038 \"lib/read.ml\"\n | 2 ->\n\n# 190 \"lib/read.mll\"\n \n# 190 \"lib/read.mll\"\n ( `Null )\n\n# 1042 \"lib/read.ml\"\n\n \n# 1043 \"lib/read.ml\"\n | 3 ->\n\n# 191 \"lib/read.mll\"\n \n# 191 \"lib/read.mll\"\n (\n \n# 193 \"lib/read.mll\"\n `Float nan\n \n# 197 \"lib/read.mll\"\n )\n\n# 1053 \"lib/read.ml\"\n\n \n# 1054 \"lib/read.ml\"\n | 4 ->\n\n# 198 \"lib/read.mll\"\n \n# 198 \"lib/read.mll\"\n (\n \n# 200 \"lib/read.mll\"\n `Float infinity\n \n# 204 \"lib/read.mll\"\n )\n\n# 1064 \"lib/read.ml\"\n\n \n# 1065 \"lib/read.ml\"\n | 5 ->\n\n# 205 \"lib/read.mll\"\n \n# 205 \"lib/read.mll\"\n (\n \n# 207 \"lib/read.mll\"\n `Float neg_infinity\n \n# 211 \"lib/read.mll\"\n )\n\n# 1075 \"lib/read.ml\"\n\n \n# 1076 \"lib/read.ml\"\n | 6 ->\n\n# 212 \"lib/read.mll\"\n \n# 212 \"lib/read.mll\"\n (\n \n# 214 \"lib/read.mll\"\n Bi_outbuf.clear v.buf;\n `String (finish_string v lexbuf)\n \n# 219 \"lib/read.mll\"\n )\n\n# 1087 \"lib/read.ml\"\n\n \n# 1088 \"lib/read.ml\"\n | 7 ->\n\n# 220 \"lib/read.mll\"\n \n# 220 \"lib/read.mll\"\n ( make_positive_int v lexbuf )\n\n# 1092 \"lib/read.ml\"\n\n \n# 1093 \"lib/read.ml\"\n | 8 ->\n\n# 221 \"lib/read.mll\"\n \n# 221 \"lib/read.mll\"\n ( make_negative_int v lexbuf )\n\n# 1097 \"lib/read.ml\"\n\n \n# 1098 \"lib/read.ml\"\n | 9 ->\n\n# 222 \"lib/read.mll\"\n \n# 222 \"lib/read.mll\"\n (\n \n# 224 \"lib/read.mll\"\n `Float (float_of_string (lexeme lexbuf))\n \n# 228 \"lib/read.mll\"\n )\n\n# 1108 \"lib/read.ml\"\n\n \n# 1109 \"lib/read.ml\"\n | 10 ->\n\n# 230 \"lib/read.mll\"\n \n# 230 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n done;\n assert false\n with End_of_object ->\n `Assoc (List.rev !acc)\n )\n\n# 1135 \"lib/read.ml\"\n\n \n# 1136 \"lib/read.ml\"\n | 11 ->\n\n# 254 \"lib/read.mll\"\n \n# 254 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_json v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_json v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n `List (List.rev !acc)\n )\n\n# 1154 \"lib/read.ml\"\n\n \n# 1155 \"lib/read.ml\"\n | 12 ->\n\n# 270 \"lib/read.mll\"\n \n# 270 \"lib/read.mll\"\n (\n \n# 272 \"lib/read.mll\"\n let acc = ref [] in\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n acc := read_json v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n acc := read_json v lexbuf :: !acc;\n done;\n assert false\n with End_of_tuple ->\n `Tuple (List.rev !acc)\n \n# 289 \"lib/read.mll\"\n )\n\n# 1178 \"lib/read.ml\"\n\n \n# 1179 \"lib/read.ml\"\n | 13 ->\n\n# 291 \"lib/read.mll\"\n \n# 291 \"lib/read.mll\"\n (\n \n# 293 \"lib/read.mll\"\n read_space v lexbuf;\n let cons = read_ident v lexbuf in\n read_space v lexbuf;\n `Variant (cons, finish_variant v lexbuf)\n \n# 300 \"lib/read.mll\"\n )\n\n# 1192 \"lib/read.ml\"\n\n \n# 1193 \"lib/read.ml\"\n | 14 ->\n\n# 302 \"lib/read.mll\"\n \n# 302 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1197 \"lib/read.ml\"\n\n \n# 1198 \"lib/read.ml\"\n | 15 ->\n\n# 303 \"lib/read.mll\"\n \n# 303 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_json v lexbuf )\n\n# 1202 \"lib/read.ml\"\n\n \n# 1203 \"lib/read.ml\"\n | 16 ->\n\n# 304 \"lib/read.mll\"\n \n# 304 \"lib/read.mll\"\n ( newline v lexbuf; read_json v lexbuf )\n\n# 1207 \"lib/read.ml\"\n\n \n# 1208 \"lib/read.ml\"\n | 17 ->\n\n# 305 \"lib/read.mll\"\n \n# 305 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1212 \"lib/read.ml\"\n\n \n# 1213 \"lib/read.ml\"\n | 18 ->\n\n# 306 \"lib/read.mll\"\n \n# 306 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1217 \"lib/read.ml\"\n\n \n# 1218 \"lib/read.ml\"\n | 19 ->\n\n# 307 \"lib/read.mll\"\n \n# 307 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 1222 \"lib/read.ml\"\n\n \n# 1223 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state\n\nand finish_string v lexbuf =\n __ocaml_lex_finish_string_rec v lexbuf 58\nand __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 311 \"lib/read.mll\"\n \n# 311 \"lib/read.mll\"\n ( Bi_outbuf.contents v.buf )\n\n# 1234 \"lib/read.ml\"\n\n \n# 1235 \"lib/read.ml\"\n | 1 ->\n\n# 312 \"lib/read.mll\"\n \n# 312 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n finish_string v lexbuf )\n\n# 1240 \"lib/read.ml\"\n\n \n# 1241 \"lib/read.ml\"\n | 2 ->\n\n# 314 \"lib/read.mll\"\n \n# 314 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n finish_string v lexbuf )\n\n# 1246 \"lib/read.ml\"\n\n \n# 1247 \"lib/read.ml\"\n | 3 ->\n\n# 316 \"lib/read.mll\"\n \n# 316 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1251 \"lib/read.ml\"\n\n \n# 1252 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state\n\nand map_string v f lexbuf =\n __ocaml_lex_map_string_rec v f lexbuf 63\nand __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 319 \"lib/read.mll\"\n \n# 319 \"lib/read.mll\"\n ( let b = v.buf in\n f (Bytes.to_string b.Bi_outbuf.o_s) 0 b.Bi_outbuf.o_len )\n\n# 1264 \"lib/read.ml\"\n\n \n# 1265 \"lib/read.ml\"\n | 1 ->\n\n# 321 \"lib/read.mll\"\n \n# 321 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n map_string v f lexbuf )\n\n# 1270 \"lib/read.ml\"\n\n \n# 1271 \"lib/read.ml\"\n | 2 ->\n\n# 323 \"lib/read.mll\"\n \n# 323 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n map_string v f lexbuf )\n\n# 1276 \"lib/read.ml\"\n\n \n# 1277 \"lib/read.ml\"\n | 3 ->\n\n# 325 \"lib/read.mll\"\n \n# 325 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1281 \"lib/read.ml\"\n\n \n# 1282 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state\n\nand finish_escaped_char v lexbuf =\n __ocaml_lex_finish_escaped_char_rec v lexbuf 68\nand __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n c\n\n# 1294 \"lib/read.ml\"\n# 1294 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf lexbuf.Lexing.lex_start_pos in\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf c )\n\n# 1298 \"lib/read.ml\"\n\n \n# 1299 \"lib/read.ml\"\n | 1 ->\n\n# 331 \"lib/read.mll\"\n \n# 331 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\b' )\n\n# 1303 \"lib/read.ml\"\n\n \n# 1304 \"lib/read.ml\"\n | 2 ->\n\n# 332 \"lib/read.mll\"\n \n# 332 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\012' )\n\n# 1308 \"lib/read.ml\"\n\n \n# 1309 \"lib/read.ml\"\n | 3 ->\n\n# 333 \"lib/read.mll\"\n \n# 333 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n' )\n\n# 1313 \"lib/read.ml\"\n\n \n# 1314 \"lib/read.ml\"\n | 4 ->\n\n# 334 \"lib/read.mll\"\n \n# 334 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\r' )\n\n# 1318 \"lib/read.ml\"\n\n \n# 1319 \"lib/read.ml\"\n | 5 ->\n\n# 335 \"lib/read.mll\"\n \n# 335 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\t' )\n\n# 1323 \"lib/read.ml\"\n\n \n# 1324 \"lib/read.ml\"\n | 6 ->\nlet\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n a\n\n# 1329 \"lib/read.ml\"\n# 1329 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 1)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n b\n\n# 1334 \"lib/read.ml\"\n# 1334 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n c\n\n# 1339 \"lib/read.ml\"\n# 1339 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n d\n\n# 1344 \"lib/read.ml\"\n# 1344 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4) in\n\n# 337 \"lib/read.mll\"\n \n# 337 \"lib/read.mll\"\n ( let x =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if x >= 0xD800 && x <= 0xDBFF then\n finish_surrogate_pair v x lexbuf\n else\n utf8_of_code v.buf x\n )\n\n# 1355 \"lib/read.ml\"\n\n \n# 1356 \"lib/read.ml\"\n | 7 ->\n\n# 345 \"lib/read.mll\"\n \n# 345 \"lib/read.mll\"\n ( long_error \"Invalid escape sequence\" v lexbuf )\n\n# 1360 \"lib/read.ml\"\n\n \n# 1361 \"lib/read.ml\"\n | 8 ->\n\n# 346 \"lib/read.mll\"\n \n# 346 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1365 \"lib/read.ml\"\n\n \n# 1366 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state\n\nand finish_surrogate_pair v x lexbuf =\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf 82\nand __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n a\n\n# 1378 \"lib/read.ml\"\n# 1378 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n b\n\n# 1383 \"lib/read.ml\"\n# 1383 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n c\n\n# 1388 \"lib/read.ml\"\n# 1388 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n d\n\n# 1393 \"lib/read.ml\"\n# 1393 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 5) in\n\n# 350 \"lib/read.mll\"\n \n# 350 \"lib/read.mll\"\n ( let y =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if y >= 0xDC00 && y <= 0xDFFF then\n utf8_of_surrogate_pair v.buf x y\n else\n long_error \"Invalid low surrogate for code point beyond U+FFFF\"\n v lexbuf\n )\n\n# 1405 \"lib/read.ml\"\n\n \n# 1406 \"lib/read.ml\"\n | 1 ->\n\n# 359 \"lib/read.mll\"\n \n# 359 \"lib/read.mll\"\n ( long_error \"Missing escape sequence representing low surrogate \\\n for code point beyond U+FFFF\" v lexbuf )\n\n# 1411 \"lib/read.ml\"\n\n \n# 1412 \"lib/read.ml\"\n | 2 ->\n\n# 361 \"lib/read.mll\"\n \n# 361 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1416 \"lib/read.ml\"\n\n \n# 1417 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state\n\nand finish_stringlit v lexbuf =\n __ocaml_lex_finish_stringlit_rec v lexbuf 91\nand __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 366 \"lib/read.mll\"\n \n# 366 \"lib/read.mll\"\n ( let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n let s = Bytes.create (len+1) in\n Bytes.set s 0 '\"';\n Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos s 1 len;\n Bytes.to_string s\n )\n\n# 1433 \"lib/read.ml\"\n\n \n# 1434 \"lib/read.ml\"\n | 1 ->\n\n# 372 \"lib/read.mll\"\n \n# 372 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 1438 \"lib/read.ml\"\n\n \n# 1439 \"lib/read.ml\"\n | 2 ->\n\n# 373 \"lib/read.mll\"\n \n# 373 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1443 \"lib/read.ml\"\n\n \n# 1444 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_variant v lexbuf =\n __ocaml_lex_finish_variant_rec v lexbuf 102\nand __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 376 \"lib/read.mll\"\n \n# 376 \"lib/read.mll\"\n ( let x = read_json v lexbuf in\n read_space v lexbuf;\n read_gt v lexbuf;\n Some x )\n\n# 1458 \"lib/read.ml\"\n\n \n# 1459 \"lib/read.ml\"\n | 1 ->\n\n# 380 \"lib/read.mll\"\n \n# 380 \"lib/read.mll\"\n ( None )\n\n# 1463 \"lib/read.ml\"\n\n \n# 1464 \"lib/read.ml\"\n | 2 ->\n\n# 381 \"lib/read.mll\"\n \n# 381 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 1468 \"lib/read.ml\"\n\n \n# 1469 \"lib/read.ml\"\n | 3 ->\n\n# 382 \"lib/read.mll\"\n \n# 382 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1473 \"lib/read.ml\"\n\n \n# 1474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state\n\nand read_lt v lexbuf =\n __ocaml_lex_read_lt_rec v lexbuf 107\nand __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 385 \"lib/read.mll\"\n \n# 385 \"lib/read.mll\"\n ( () )\n\n# 1485 \"lib/read.ml\"\n\n \n# 1486 \"lib/read.ml\"\n | 1 ->\n\n# 386 \"lib/read.mll\"\n \n# 386 \"lib/read.mll\"\n ( long_error \"Expected '<' but found\" v lexbuf )\n\n# 1490 \"lib/read.ml\"\n\n \n# 1491 \"lib/read.ml\"\n | 2 ->\n\n# 387 \"lib/read.mll\"\n \n# 387 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1495 \"lib/read.ml\"\n\n \n# 1496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state\n\nand read_gt v lexbuf =\n __ocaml_lex_read_gt_rec v lexbuf 111\nand __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 390 \"lib/read.mll\"\n \n# 390 \"lib/read.mll\"\n ( () )\n\n# 1507 \"lib/read.ml\"\n\n \n# 1508 \"lib/read.ml\"\n | 1 ->\n\n# 391 \"lib/read.mll\"\n \n# 391 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 1512 \"lib/read.ml\"\n\n \n# 1513 \"lib/read.ml\"\n | 2 ->\n\n# 392 \"lib/read.mll\"\n \n# 392 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1517 \"lib/read.ml\"\n\n \n# 1518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state\n\nand read_comma v lexbuf =\n __ocaml_lex_read_comma_rec v lexbuf 115\nand __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 395 \"lib/read.mll\"\n \n# 395 \"lib/read.mll\"\n ( () )\n\n# 1529 \"lib/read.ml\"\n\n \n# 1530 \"lib/read.ml\"\n | 1 ->\n\n# 396 \"lib/read.mll\"\n \n# 396 \"lib/read.mll\"\n ( long_error \"Expected ',' but found\" v lexbuf )\n\n# 1534 \"lib/read.ml\"\n\n \n# 1535 \"lib/read.ml\"\n | 2 ->\n\n# 397 \"lib/read.mll\"\n \n# 397 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1539 \"lib/read.ml\"\n\n \n# 1540 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state\n\nand start_any_variant v lexbuf =\n __ocaml_lex_start_any_variant_rec v lexbuf 119\nand __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 400 \"lib/read.mll\"\n \n# 400 \"lib/read.mll\"\n ( `Edgy_bracket )\n\n# 1551 \"lib/read.ml\"\n\n \n# 1552 \"lib/read.ml\"\n | 1 ->\n\n# 401 \"lib/read.mll\"\n \n# 401 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n `Double_quote )\n\n# 1557 \"lib/read.ml\"\n\n \n# 1558 \"lib/read.ml\"\n | 2 ->\n\n# 403 \"lib/read.mll\"\n \n# 403 \"lib/read.mll\"\n ( `Square_bracket )\n\n# 1562 \"lib/read.ml\"\n\n \n# 1563 \"lib/read.ml\"\n | 3 ->\n\n# 404 \"lib/read.mll\"\n \n# 404 \"lib/read.mll\"\n ( long_error \"Expected '<', '\\\"' or '[' but found\" v lexbuf )\n\n# 1567 \"lib/read.ml\"\n\n \n# 1568 \"lib/read.ml\"\n | 4 ->\n\n# 405 \"lib/read.mll\"\n \n# 405 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1572 \"lib/read.ml\"\n\n \n# 1573 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state\n\nand finish_comment v lexbuf =\n __ocaml_lex_finish_comment_rec v lexbuf 125\nand __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 408 \"lib/read.mll\"\n \n# 408 \"lib/read.mll\"\n ( () )\n\n# 1584 \"lib/read.ml\"\n\n \n# 1585 \"lib/read.ml\"\n | 1 ->\n\n# 409 \"lib/read.mll\"\n \n# 409 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 1589 \"lib/read.ml\"\n\n \n# 1590 \"lib/read.ml\"\n | 2 ->\n\n# 410 \"lib/read.mll\"\n \n# 410 \"lib/read.mll\"\n ( newline v lexbuf; finish_comment v lexbuf )\n\n# 1594 \"lib/read.ml\"\n\n \n# 1595 \"lib/read.ml\"\n | 3 ->\n\n# 411 \"lib/read.mll\"\n \n# 411 \"lib/read.mll\"\n ( finish_comment v lexbuf )\n\n# 1599 \"lib/read.ml\"\n\n \n# 1600 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state\n\nand read_eof lexbuf =\n __ocaml_lex_read_eof_rec lexbuf 131\nand __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 419 \"lib/read.mll\"\n \n# 419 \"lib/read.mll\"\n ( true )\n\n# 1611 \"lib/read.ml\"\n\n \n# 1612 \"lib/read.ml\"\n | 1 ->\n\n# 420 \"lib/read.mll\"\n \n# 420 \"lib/read.mll\"\n ( false )\n\n# 1616 \"lib/read.ml\"\n\n \n# 1617 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state\n\nand read_space v lexbuf =\n __ocaml_lex_read_space_rec v lexbuf 133\nand __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 423 \"lib/read.mll\"\n \n# 423 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1628 \"lib/read.ml\"\n\n \n# 1629 \"lib/read.ml\"\n | 1 ->\n\n# 424 \"lib/read.mll\"\n \n# 424 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_space v lexbuf )\n\n# 1633 \"lib/read.ml\"\n\n \n# 1634 \"lib/read.ml\"\n | 2 ->\n\n# 425 \"lib/read.mll\"\n \n# 425 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1638 \"lib/read.ml\"\n\n \n# 1639 \"lib/read.ml\"\n | 3 ->\n\n# 426 \"lib/read.mll\"\n \n# 426 \"lib/read.mll\"\n ( read_space v lexbuf )\n\n# 1643 \"lib/read.ml\"\n\n \n# 1644 \"lib/read.ml\"\n | 4 ->\n\n# 427 \"lib/read.mll\"\n \n# 427 \"lib/read.mll\"\n ( () )\n\n# 1648 \"lib/read.ml\"\n\n \n# 1649 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state\n\nand read_null v lexbuf =\n __ocaml_lex_read_null_rec v lexbuf 140\nand __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 430 \"lib/read.mll\"\n \n# 430 \"lib/read.mll\"\n ( () )\n\n# 1660 \"lib/read.ml\"\n\n \n# 1661 \"lib/read.ml\"\n | 1 ->\n\n# 431 \"lib/read.mll\"\n \n# 431 \"lib/read.mll\"\n ( long_error \"Expected 'null' but found\" v lexbuf )\n\n# 1665 \"lib/read.ml\"\n\n \n# 1666 \"lib/read.ml\"\n | 2 ->\n\n# 432 \"lib/read.mll\"\n \n# 432 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1670 \"lib/read.ml\"\n\n \n# 1671 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state\n\nand read_null_if_possible v lexbuf =\n __ocaml_lex_read_null_if_possible_rec v lexbuf 147\nand __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 435 \"lib/read.mll\"\n \n# 435 \"lib/read.mll\"\n ( true )\n\n# 1682 \"lib/read.ml\"\n\n \n# 1683 \"lib/read.ml\"\n | 1 ->\n\n# 436 \"lib/read.mll\"\n \n# 436 \"lib/read.mll\"\n ( false )\n\n# 1687 \"lib/read.ml\"\n\n \n# 1688 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state\n\nand read_bool v lexbuf =\n __ocaml_lex_read_bool_rec v lexbuf 152\nand __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 439 \"lib/read.mll\"\n \n# 439 \"lib/read.mll\"\n ( true )\n\n# 1699 \"lib/read.ml\"\n\n \n# 1700 \"lib/read.ml\"\n | 1 ->\n\n# 440 \"lib/read.mll\"\n \n# 440 \"lib/read.mll\"\n ( false )\n\n# 1704 \"lib/read.ml\"\n\n \n# 1705 \"lib/read.ml\"\n | 2 ->\n\n# 443 \"lib/read.mll\"\n \n# 443 \"lib/read.mll\"\n ( true )\n\n# 1709 \"lib/read.ml\"\n\n \n# 1710 \"lib/read.ml\"\n | 3 ->\n\n# 444 \"lib/read.mll\"\n \n# 444 \"lib/read.mll\"\n ( false )\n\n# 1714 \"lib/read.ml\"\n\n \n# 1715 \"lib/read.ml\"\n | 4 ->\n\n# 446 \"lib/read.mll\"\n \n# 446 \"lib/read.mll\"\n ( long_error \"Expected 'true' or 'false' but found\" v lexbuf )\n\n# 1719 \"lib/read.ml\"\n\n \n# 1720 \"lib/read.ml\"\n | 5 ->\n\n# 447 \"lib/read.mll\"\n \n# 447 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1724 \"lib/read.ml\"\n\n \n# 1725 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state\n\nand read_int v lexbuf =\n __ocaml_lex_read_int_rec v lexbuf 176\nand __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 450 \"lib/read.mll\"\n \n# 450 \"lib/read.mll\"\n ( try extract_positive_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1738 \"lib/read.ml\"\n\n \n# 1739 \"lib/read.ml\"\n | 1 ->\n\n# 453 \"lib/read.mll\"\n \n# 453 \"lib/read.mll\"\n ( try extract_negative_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1745 \"lib/read.ml\"\n\n \n# 1746 \"lib/read.ml\"\n | 2 ->\n\n# 456 \"lib/read.mll\"\n \n# 456 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n int_of_string s\n with _ ->\n custom_error\n \"Expected an integer but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1763 \"lib/read.ml\"\n\n \n# 1764 \"lib/read.ml\"\n | 3 ->\n\n# 470 \"lib/read.mll\"\n \n# 470 \"lib/read.mll\"\n ( long_error \"Expected integer but found\" v lexbuf )\n\n# 1768 \"lib/read.ml\"\n\n \n# 1769 \"lib/read.ml\"\n | 4 ->\n\n# 471 \"lib/read.mll\"\n \n# 471 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1773 \"lib/read.ml\"\n\n \n# 1774 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state\n\nand read_int32 v lexbuf =\n __ocaml_lex_read_int32_rec v lexbuf 185\nand __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 474 \"lib/read.mll\"\n \n# 474 \"lib/read.mll\"\n ( try Int32.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1787 \"lib/read.ml\"\n\n \n# 1788 \"lib/read.ml\"\n | 1 ->\n\n# 477 \"lib/read.mll\"\n \n# 477 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int32.of_string s\n with _ ->\n custom_error\n \"Expected an int32 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1805 \"lib/read.ml\"\n\n \n# 1806 \"lib/read.ml\"\n | 2 ->\n\n# 491 \"lib/read.mll\"\n \n# 491 \"lib/read.mll\"\n ( long_error \"Expected int32 but found\" v lexbuf )\n\n# 1810 \"lib/read.ml\"\n\n \n# 1811 \"lib/read.ml\"\n | 3 ->\n\n# 492 \"lib/read.mll\"\n \n# 492 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1815 \"lib/read.ml\"\n\n \n# 1816 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state\n\nand read_int64 v lexbuf =\n __ocaml_lex_read_int64_rec v lexbuf 192\nand __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 495 \"lib/read.mll\"\n \n# 495 \"lib/read.mll\"\n ( try Int64.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1829 \"lib/read.ml\"\n\n \n# 1830 \"lib/read.ml\"\n | 1 ->\n\n# 498 \"lib/read.mll\"\n \n# 498 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int64.of_string s\n with _ ->\n custom_error\n \"Expected an int64 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1847 \"lib/read.ml\"\n\n \n# 1848 \"lib/read.ml\"\n | 2 ->\n\n# 512 \"lib/read.mll\"\n \n# 512 \"lib/read.mll\"\n ( long_error \"Expected int64 but found\" v lexbuf )\n\n# 1852 \"lib/read.ml\"\n\n \n# 1853 \"lib/read.ml\"\n | 3 ->\n\n# 513 \"lib/read.mll\"\n \n# 513 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1857 \"lib/read.ml\"\n\n \n# 1858 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state\n\nand read_number v lexbuf =\n __ocaml_lex_read_number_rec v lexbuf 199\nand __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 516 \"lib/read.mll\"\n \n# 516 \"lib/read.mll\"\n ( nan )\n\n# 1869 \"lib/read.ml\"\n\n \n# 1870 \"lib/read.ml\"\n | 1 ->\n\n# 517 \"lib/read.mll\"\n \n# 517 \"lib/read.mll\"\n ( infinity )\n\n# 1874 \"lib/read.ml\"\n\n \n# 1875 \"lib/read.ml\"\n | 2 ->\n\n# 518 \"lib/read.mll\"\n \n# 518 \"lib/read.mll\"\n ( neg_infinity )\n\n# 1879 \"lib/read.ml\"\n\n \n# 1880 \"lib/read.ml\"\n | 3 ->\n\n# 519 \"lib/read.mll\"\n \n# 519 \"lib/read.mll\"\n ( float_of_string (lexeme lexbuf) )\n\n# 1884 \"lib/read.ml\"\n\n \n# 1885 \"lib/read.ml\"\n | 4 ->\n\n# 520 \"lib/read.mll\"\n \n# 520 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant float will pass,\n including hexadecimal and octal notations,\n and embedded underscores. *)\n float_of_string s\n with _ ->\n match s with\n \"NaN\" -> nan\n | \"Infinity\" -> infinity\n | \"-Infinity\" -> neg_infinity\n | _ ->\n custom_error\n \"Expected a number but found a string that \\\n doesn't even represent a number\"\n v lexbuf\n )\n\n# 1906 \"lib/read.ml\"\n\n \n# 1907 \"lib/read.ml\"\n | 5 ->\n\n# 538 \"lib/read.mll\"\n \n# 538 \"lib/read.mll\"\n ( long_error \"Expected number but found\" v lexbuf )\n\n# 1911 \"lib/read.ml\"\n\n \n# 1912 \"lib/read.ml\"\n | 6 ->\n\n# 539 \"lib/read.mll\"\n \n# 539 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1916 \"lib/read.ml\"\n\n \n# 1917 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state\n\nand read_string v lexbuf =\n __ocaml_lex_read_string_rec v lexbuf 233\nand __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 542 \"lib/read.mll\"\n \n# 542 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1929 \"lib/read.ml\"\n\n \n# 1930 \"lib/read.ml\"\n | 1 ->\n\n# 544 \"lib/read.mll\"\n \n# 544 \"lib/read.mll\"\n ( long_error \"Expected '\\\"' but found\" v lexbuf )\n\n# 1934 \"lib/read.ml\"\n\n \n# 1935 \"lib/read.ml\"\n | 2 ->\n\n# 545 \"lib/read.mll\"\n \n# 545 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1939 \"lib/read.ml\"\n\n \n# 1940 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state\n\nand read_ident v lexbuf =\n __ocaml_lex_read_ident_rec v lexbuf 237\nand __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 548 \"lib/read.mll\"\n \n# 548 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1952 \"lib/read.ml\"\n\n \n# 1953 \"lib/read.ml\"\n | 1 ->\nlet\n\n# 550 \"lib/read.mll\"\n \n# 550 \"lib/read.mll\"\n s\n\n# 1958 \"lib/read.ml\"\n# 1958 \"lib/read.ml\"\n= Lexing.sub_lexeme lexbuf lexbuf.Lexing.lex_start_pos lexbuf.Lexing.lex_curr_pos in\n\n# 551 \"lib/read.mll\"\n \n# 551 \"lib/read.mll\"\n ( s )\n\n# 1962 \"lib/read.ml\"\n\n \n# 1963 \"lib/read.ml\"\n | 2 ->\n\n# 552 \"lib/read.mll\"\n \n# 552 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1967 \"lib/read.ml\"\n\n \n# 1968 \"lib/read.ml\"\n | 3 ->\n\n# 553 \"lib/read.mll\"\n \n# 553 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1972 \"lib/read.ml\"\n\n \n# 1973 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state\n\nand map_ident v f lexbuf =\n __ocaml_lex_map_ident_rec v f lexbuf 242\nand __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 556 \"lib/read.mll\"\n \n# 556 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n map_string v f lexbuf )\n\n# 1985 \"lib/read.ml\"\n\n \n# 1986 \"lib/read.ml\"\n | 1 ->\n\n# 559 \"lib/read.mll\"\n \n# 559 \"lib/read.mll\"\n ( map_lexeme f lexbuf )\n\n# 1990 \"lib/read.ml\"\n\n \n# 1991 \"lib/read.ml\"\n | 2 ->\n\n# 560 \"lib/read.mll\"\n \n# 560 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1995 \"lib/read.ml\"\n\n \n# 1996 \"lib/read.ml\"\n | 3 ->\n\n# 561 \"lib/read.mll\"\n \n# 561 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2000 \"lib/read.ml\"\n\n \n# 2001 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state\n\nand read_sequence read_cell init_acc v lexbuf =\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf 247\nand __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 564 \"lib/read.mll\"\n \n# 564 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell !acc v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell !acc v lexbuf;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2026 \"lib/read.ml\"\n\n \n# 2027 \"lib/read.ml\"\n | 1 ->\n\n# 579 \"lib/read.mll\"\n \n# 579 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2031 \"lib/read.ml\"\n\n \n# 2032 \"lib/read.ml\"\n | 2 ->\n\n# 580 \"lib/read.mll\"\n \n# 580 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2036 \"lib/read.ml\"\n\n \n# 2037 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_list_rev read_cell v lexbuf =\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf 251\nand __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 583 \"lib/read.mll\"\n \n# 583 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2062 \"lib/read.ml\"\n\n \n# 2063 \"lib/read.ml\"\n | 1 ->\n\n# 598 \"lib/read.mll\"\n \n# 598 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2067 \"lib/read.ml\"\n\n \n# 2068 \"lib/read.ml\"\n | 2 ->\n\n# 599 \"lib/read.mll\"\n \n# 599 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2072 \"lib/read.ml\"\n\n \n# 2073 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state\n\nand read_array_end lexbuf =\n __ocaml_lex_read_array_end_rec lexbuf 255\nand __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 602 \"lib/read.mll\"\n \n# 602 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2084 \"lib/read.ml\"\n\n \n# 2085 \"lib/read.ml\"\n | 1 ->\n\n# 603 \"lib/read.mll\"\n \n# 603 \"lib/read.mll\"\n ( () )\n\n# 2089 \"lib/read.ml\"\n\n \n# 2090 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state\n\nand read_array_sep v lexbuf =\n __ocaml_lex_read_array_sep_rec v lexbuf 257\nand __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 606 \"lib/read.mll\"\n \n# 606 \"lib/read.mll\"\n ( () )\n\n# 2101 \"lib/read.ml\"\n\n \n# 2102 \"lib/read.ml\"\n | 1 ->\n\n# 607 \"lib/read.mll\"\n \n# 607 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2106 \"lib/read.ml\"\n\n \n# 2107 \"lib/read.ml\"\n | 2 ->\n\n# 608 \"lib/read.mll\"\n \n# 608 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 2111 \"lib/read.ml\"\n\n \n# 2112 \"lib/read.ml\"\n | 3 ->\n\n# 609 \"lib/read.mll\"\n \n# 609 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2116 \"lib/read.ml\"\n\n \n# 2117 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple read_cell init_acc v lexbuf =\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf 262\nand __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 613 \"lib/read.mll\"\n \n# 613 \"lib/read.mll\"\n (\n \n# 615 \"lib/read.mll\"\n let pos = ref 0 in\n let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n acc := read_cell !pos !acc v lexbuf;\n incr pos;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell !pos !acc v lexbuf;\n incr pos;\n done;\n assert false\n with End_of_tuple ->\n !acc\n \n# 635 \"lib/read.mll\"\n )\n\n# 2150 \"lib/read.ml\"\n\n \n# 2151 \"lib/read.ml\"\n | 1 ->\n\n# 636 \"lib/read.mll\"\n \n# 636 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2155 \"lib/read.ml\"\n\n \n# 2156 \"lib/read.ml\"\n | 2 ->\n\n# 637 \"lib/read.mll\"\n \n# 637 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2160 \"lib/read.ml\"\n\n \n# 2161 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_tuple_end lexbuf =\n __ocaml_lex_read_tuple_end_rec lexbuf 266\nand __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 640 \"lib/read.mll\"\n \n# 640 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2172 \"lib/read.ml\"\n\n \n# 2173 \"lib/read.ml\"\n | 1 ->\n\n# 641 \"lib/read.mll\"\n \n# 641 \"lib/read.mll\"\n ( () )\n\n# 2177 \"lib/read.ml\"\n\n \n# 2178 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state\n\nand read_tuple_end2 v std lexbuf =\n __ocaml_lex_read_tuple_end2_rec v std lexbuf 268\nand __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 644 \"lib/read.mll\"\n \n# 644 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ')' or '' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2192 \"lib/read.ml\"\n\n \n# 2193 \"lib/read.ml\"\n | 1 ->\n\n# 648 \"lib/read.mll\"\n \n# 648 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ']' or '' but found\" v lexbuf )\n\n# 2200 \"lib/read.ml\"\n\n \n# 2201 \"lib/read.ml\"\n | 2 ->\n\n# 652 \"lib/read.mll\"\n \n# 652 \"lib/read.mll\"\n ( () )\n\n# 2205 \"lib/read.ml\"\n\n \n# 2206 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state\n\nand read_tuple_sep v lexbuf =\n __ocaml_lex_read_tuple_sep_rec v lexbuf 271\nand __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 655 \"lib/read.mll\"\n \n# 655 \"lib/read.mll\"\n ( () )\n\n# 2217 \"lib/read.ml\"\n\n \n# 2218 \"lib/read.ml\"\n | 1 ->\n\n# 656 \"lib/read.mll\"\n \n# 656 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2222 \"lib/read.ml\"\n\n \n# 2223 \"lib/read.ml\"\n | 2 ->\n\n# 657 \"lib/read.mll\"\n \n# 657 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2227 \"lib/read.ml\"\n\n \n# 2228 \"lib/read.ml\"\n | 3 ->\n\n# 658 \"lib/read.mll\"\n \n# 658 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2232 \"lib/read.ml\"\n\n \n# 2233 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple_sep2 v std lexbuf =\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf 276\nand __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 661 \"lib/read.mll\"\n \n# 661 \"lib/read.mll\"\n ( () )\n\n# 2244 \"lib/read.ml\"\n\n \n# 2245 \"lib/read.ml\"\n | 1 ->\n\n# 662 \"lib/read.mll\"\n \n# 662 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ',' or ']' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2252 \"lib/read.ml\"\n\n \n# 2253 \"lib/read.ml\"\n | 2 ->\n\n# 666 \"lib/read.mll\"\n \n# 666 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2260 \"lib/read.ml\"\n\n \n# 2261 \"lib/read.ml\"\n | 3 ->\n\n# 670 \"lib/read.mll\"\n \n# 670 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2265 \"lib/read.ml\"\n\n \n# 2266 \"lib/read.ml\"\n | 4 ->\n\n# 671 \"lib/read.mll\"\n \n# 671 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2270 \"lib/read.ml\"\n\n \n# 2271 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state\n\nand read_abstract_fields read_key read_field init_acc v lexbuf =\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf 282\nand __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 675 \"lib/read.mll\"\n \n# 675 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n done;\n assert false\n with End_of_object ->\n !acc\n )\n\n# 2304 \"lib/read.ml\"\n\n \n# 2305 \"lib/read.ml\"\n | 1 ->\n\n# 698 \"lib/read.mll\"\n \n# 698 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2309 \"lib/read.ml\"\n\n \n# 2310 \"lib/read.ml\"\n | 2 ->\n\n# 699 \"lib/read.mll\"\n \n# 699 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2314 \"lib/read.ml\"\n\n \n# 2315 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state\n\nand read_lcurl v lexbuf =\n __ocaml_lex_read_lcurl_rec v lexbuf 286\nand __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 702 \"lib/read.mll\"\n \n# 702 \"lib/read.mll\"\n ( () )\n\n# 2326 \"lib/read.ml\"\n\n \n# 2327 \"lib/read.ml\"\n | 1 ->\n\n# 703 \"lib/read.mll\"\n \n# 703 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2331 \"lib/read.ml\"\n\n \n# 2332 \"lib/read.ml\"\n | 2 ->\n\n# 704 \"lib/read.mll\"\n \n# 704 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2336 \"lib/read.ml\"\n\n \n# 2337 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state\n\nand read_object_end lexbuf =\n __ocaml_lex_read_object_end_rec lexbuf 290\nand __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 707 \"lib/read.mll\"\n \n# 707 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2348 \"lib/read.ml\"\n\n \n# 2349 \"lib/read.ml\"\n | 1 ->\n\n# 708 \"lib/read.mll\"\n \n# 708 \"lib/read.mll\"\n ( () )\n\n# 2353 \"lib/read.ml\"\n\n \n# 2354 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state\n\nand read_object_sep v lexbuf =\n __ocaml_lex_read_object_sep_rec v lexbuf 292\nand __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 711 \"lib/read.mll\"\n \n# 711 \"lib/read.mll\"\n ( () )\n\n# 2365 \"lib/read.ml\"\n\n \n# 2366 \"lib/read.ml\"\n | 1 ->\n\n# 712 \"lib/read.mll\"\n \n# 712 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2370 \"lib/read.ml\"\n\n \n# 2371 \"lib/read.ml\"\n | 2 ->\n\n# 713 \"lib/read.mll\"\n \n# 713 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 2375 \"lib/read.ml\"\n\n \n# 2376 \"lib/read.ml\"\n | 3 ->\n\n# 714 \"lib/read.mll\"\n \n# 714 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2380 \"lib/read.ml\"\n\n \n# 2381 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state\n\nand read_colon v lexbuf =\n __ocaml_lex_read_colon_rec v lexbuf 297\nand __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 717 \"lib/read.mll\"\n \n# 717 \"lib/read.mll\"\n ( () )\n\n# 2392 \"lib/read.ml\"\n\n \n# 2393 \"lib/read.ml\"\n | 1 ->\n\n# 718 \"lib/read.mll\"\n \n# 718 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 2397 \"lib/read.ml\"\n\n \n# 2398 \"lib/read.ml\"\n | 2 ->\n\n# 719 \"lib/read.mll\"\n \n# 719 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2402 \"lib/read.ml\"\n\n \n# 2403 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state\n\nand start_any_tuple v lexbuf =\n __ocaml_lex_start_any_tuple_rec v lexbuf 301\nand __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 722 \"lib/read.mll\"\n \n# 722 \"lib/read.mll\"\n ( false )\n\n# 2414 \"lib/read.ml\"\n\n \n# 2415 \"lib/read.ml\"\n | 1 ->\n\n# 723 \"lib/read.mll\"\n \n# 723 \"lib/read.mll\"\n ( true )\n\n# 2419 \"lib/read.ml\"\n\n \n# 2420 \"lib/read.ml\"\n | 2 ->\n\n# 724 \"lib/read.mll\"\n \n# 724 \"lib/read.mll\"\n ( long_error \"Expected '(' or '[' but found\" v lexbuf )\n\n# 2424 \"lib/read.ml\"\n\n \n# 2425 \"lib/read.ml\"\n | 3 ->\n\n# 725 \"lib/read.mll\"\n \n# 725 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2429 \"lib/read.ml\"\n\n \n# 2430 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state\n\nand read_lpar v lexbuf =\n __ocaml_lex_read_lpar_rec v lexbuf 306\nand __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 728 \"lib/read.mll\"\n \n# 728 \"lib/read.mll\"\n ( () )\n\n# 2441 \"lib/read.ml\"\n\n \n# 2442 \"lib/read.ml\"\n | 1 ->\n\n# 729 \"lib/read.mll\"\n \n# 729 \"lib/read.mll\"\n ( long_error \"Expected '(' but found\" v lexbuf )\n\n# 2446 \"lib/read.ml\"\n\n \n# 2447 \"lib/read.ml\"\n | 2 ->\n\n# 730 \"lib/read.mll\"\n \n# 730 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2451 \"lib/read.ml\"\n\n \n# 2452 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state\n\nand read_rpar v lexbuf =\n __ocaml_lex_read_rpar_rec v lexbuf 310\nand __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 733 \"lib/read.mll\"\n \n# 733 \"lib/read.mll\"\n ( () )\n\n# 2463 \"lib/read.ml\"\n\n \n# 2464 \"lib/read.ml\"\n | 1 ->\n\n# 734 \"lib/read.mll\"\n \n# 734 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2468 \"lib/read.ml\"\n\n \n# 2469 \"lib/read.ml\"\n | 2 ->\n\n# 735 \"lib/read.mll\"\n \n# 735 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2473 \"lib/read.ml\"\n\n \n# 2474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state\n\nand read_lbr v lexbuf =\n __ocaml_lex_read_lbr_rec v lexbuf 314\nand __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 738 \"lib/read.mll\"\n \n# 738 \"lib/read.mll\"\n ( () )\n\n# 2485 \"lib/read.ml\"\n\n \n# 2486 \"lib/read.ml\"\n | 1 ->\n\n# 739 \"lib/read.mll\"\n \n# 739 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2490 \"lib/read.ml\"\n\n \n# 2491 \"lib/read.ml\"\n | 2 ->\n\n# 740 \"lib/read.mll\"\n \n# 740 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2495 \"lib/read.ml\"\n\n \n# 2496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state\n\nand read_rbr v lexbuf =\n __ocaml_lex_read_rbr_rec v lexbuf 318\nand __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 743 \"lib/read.mll\"\n \n# 743 \"lib/read.mll\"\n ( () )\n\n# 2507 \"lib/read.ml\"\n\n \n# 2508 \"lib/read.ml\"\n | 1 ->\n\n# 744 \"lib/read.mll\"\n \n# 744 \"lib/read.mll\"\n ( long_error \"Expected ']' but found\" v lexbuf )\n\n# 2512 \"lib/read.ml\"\n\n \n# 2513 \"lib/read.ml\"\n | 2 ->\n\n# 745 \"lib/read.mll\"\n \n# 745 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2517 \"lib/read.ml\"\n\n \n# 2518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state\n\nand skip_json v lexbuf =\n __ocaml_lex_skip_json_rec v lexbuf 322\nand __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 751 \"lib/read.mll\"\n \n# 751 \"lib/read.mll\"\n ( () )\n\n# 2529 \"lib/read.ml\"\n\n \n# 2530 \"lib/read.ml\"\n | 1 ->\n\n# 752 \"lib/read.mll\"\n \n# 752 \"lib/read.mll\"\n ( () )\n\n# 2534 \"lib/read.ml\"\n\n \n# 2535 \"lib/read.ml\"\n | 2 ->\n\n# 753 \"lib/read.mll\"\n \n# 753 \"lib/read.mll\"\n ( () )\n\n# 2539 \"lib/read.ml\"\n\n \n# 2540 \"lib/read.ml\"\n | 3 ->\n\n# 754 \"lib/read.mll\"\n \n# 754 \"lib/read.mll\"\n ( () )\n\n# 2544 \"lib/read.ml\"\n\n \n# 2545 \"lib/read.ml\"\n | 4 ->\n\n# 755 \"lib/read.mll\"\n \n# 755 \"lib/read.mll\"\n ( () )\n\n# 2549 \"lib/read.ml\"\n\n \n# 2550 \"lib/read.ml\"\n | 5 ->\n\n# 756 \"lib/read.mll\"\n \n# 756 \"lib/read.mll\"\n ( () )\n\n# 2554 \"lib/read.ml\"\n\n \n# 2555 \"lib/read.ml\"\n | 6 ->\n\n# 757 \"lib/read.mll\"\n \n# 757 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2559 \"lib/read.ml\"\n\n \n# 2560 \"lib/read.ml\"\n | 7 ->\n\n# 758 \"lib/read.mll\"\n \n# 758 \"lib/read.mll\"\n ( () )\n\n# 2564 \"lib/read.ml\"\n\n \n# 2565 \"lib/read.ml\"\n | 8 ->\n\n# 759 \"lib/read.mll\"\n \n# 759 \"lib/read.mll\"\n ( () )\n\n# 2569 \"lib/read.ml\"\n\n \n# 2570 \"lib/read.ml\"\n | 9 ->\n\n# 761 \"lib/read.mll\"\n \n# 761 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_object_end lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2595 \"lib/read.ml\"\n\n \n# 2596 \"lib/read.ml\"\n | 10 ->\n\n# 784 \"lib/read.mll\"\n \n# 784 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_array_end lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2613 \"lib/read.ml\"\n\n \n# 2614 \"lib/read.ml\"\n | 11 ->\n\n# 799 \"lib/read.mll\"\n \n# 799 \"lib/read.mll\"\n (\n \n# 801 \"lib/read.mll\"\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_tuple ->\n ()\n \n# 817 \"lib/read.mll\"\n )\n\n# 2636 \"lib/read.ml\"\n\n \n# 2637 \"lib/read.ml\"\n | 12 ->\n\n# 819 \"lib/read.mll\"\n \n# 819 \"lib/read.mll\"\n (\n \n# 821 \"lib/read.mll\"\n read_space v lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n finish_skip_variant v lexbuf\n \n# 828 \"lib/read.mll\"\n )\n\n# 2650 \"lib/read.ml\"\n\n \n# 2651 \"lib/read.ml\"\n | 13 ->\n\n# 830 \"lib/read.mll\"\n \n# 830 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2655 \"lib/read.ml\"\n\n \n# 2656 \"lib/read.ml\"\n | 14 ->\n\n# 831 \"lib/read.mll\"\n \n# 831 \"lib/read.mll\"\n ( finish_comment v lexbuf; skip_json v lexbuf )\n\n# 2660 \"lib/read.ml\"\n\n \n# 2661 \"lib/read.ml\"\n | 15 ->\n\n# 832 \"lib/read.mll\"\n \n# 832 \"lib/read.mll\"\n ( newline v lexbuf; skip_json v lexbuf )\n\n# 2665 \"lib/read.ml\"\n\n \n# 2666 \"lib/read.ml\"\n | 16 ->\n\n# 833 \"lib/read.mll\"\n \n# 833 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2670 \"lib/read.ml\"\n\n \n# 2671 \"lib/read.ml\"\n | 17 ->\n\n# 834 \"lib/read.mll\"\n \n# 834 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2675 \"lib/read.ml\"\n\n \n# 2676 \"lib/read.ml\"\n | 18 ->\n\n# 835 \"lib/read.mll\"\n \n# 835 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2680 \"lib/read.ml\"\n\n \n# 2681 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_stringlit v lexbuf =\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf 378\nand __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 841 \"lib/read.mll\"\n \n# 841 \"lib/read.mll\"\n ( () )\n\n# 2692 \"lib/read.ml\"\n\n \n# 2693 \"lib/read.ml\"\n | 1 ->\n\n# 842 \"lib/read.mll\"\n \n# 842 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2697 \"lib/read.ml\"\n\n \n# 2698 \"lib/read.ml\"\n | 2 ->\n\n# 843 \"lib/read.mll\"\n \n# 843 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2702 \"lib/read.ml\"\n\n \n# 2703 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_variant v lexbuf =\n __ocaml_lex_finish_skip_variant_rec v lexbuf 389\nand __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 846 \"lib/read.mll\"\n \n# 846 \"lib/read.mll\"\n ( skip_json v lexbuf;\n read_space v lexbuf;\n read_gt v lexbuf )\n\n# 2716 \"lib/read.ml\"\n\n \n# 2717 \"lib/read.ml\"\n | 1 ->\n\n# 849 \"lib/read.mll\"\n \n# 849 \"lib/read.mll\"\n ( () )\n\n# 2721 \"lib/read.ml\"\n\n \n# 2722 \"lib/read.ml\"\n | 2 ->\n\n# 850 \"lib/read.mll\"\n \n# 850 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2726 \"lib/read.ml\"\n\n \n# 2727 \"lib/read.ml\"\n | 3 ->\n\n# 851 \"lib/read.mll\"\n \n# 851 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2731 \"lib/read.ml\"\n\n \n# 2732 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state\n\nand skip_ident v lexbuf =\n __ocaml_lex_skip_ident_rec v lexbuf 394\nand __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 854 \"lib/read.mll\"\n \n# 854 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2743 \"lib/read.ml\"\n\n \n# 2744 \"lib/read.ml\"\n | 1 ->\n\n# 855 \"lib/read.mll\"\n \n# 855 \"lib/read.mll\"\n ( () )\n\n# 2748 \"lib/read.ml\"\n\n \n# 2749 \"lib/read.ml\"\n | 2 ->\n\n# 856 \"lib/read.mll\"\n \n# 856 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2753 \"lib/read.ml\"\n\n \n# 2754 \"lib/read.ml\"\n | 3 ->\n\n# 857 \"lib/read.mll\"\n \n# 857 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2758 \"lib/read.ml\"\n\n \n# 2759 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_json v lexbuf =\n __ocaml_lex_buffer_json_rec v lexbuf 399\nand __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 870 \"lib/read.mll\"\n \n# 870 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2770 \"lib/read.ml\"\n\n \n# 2771 \"lib/read.ml\"\n | 1 ->\n\n# 872 \"lib/read.mll\"\n \n# 872 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2775 \"lib/read.ml\"\n\n \n# 2776 \"lib/read.ml\"\n | 2 ->\n\n# 873 \"lib/read.mll\"\n \n# 873 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '{';\n buffer_space v lexbuf;\n buffer_object_end v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_object_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2802 \"lib/read.ml\"\n\n \n# 2803 \"lib/read.ml\"\n | 3 ->\n\n# 897 \"lib/read.mll\"\n \n# 897 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '[';\n buffer_space v lexbuf;\n buffer_array_end v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_array_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2821 \"lib/read.ml\"\n\n \n# 2822 \"lib/read.ml\"\n | 4 ->\n\n# 913 \"lib/read.mll\"\n \n# 913 \"lib/read.mll\"\n (\n \n# 915 \"lib/read.mll\"\n try\n Bi_outbuf.add_char v.buf '(';\n buffer_space v lexbuf;\n buffer_tuple_end v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_tuple_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_tuple ->\n ()\n \n# 932 \"lib/read.mll\"\n )\n\n# 2845 \"lib/read.ml\"\n\n \n# 2846 \"lib/read.ml\"\n | 5 ->\n\n# 934 \"lib/read.mll\"\n \n# 934 \"lib/read.mll\"\n (\n \n# 936 \"lib/read.mll\"\n Bi_outbuf.add_char v.buf '<';\n buffer_space v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n finish_buffer_variant v lexbuf\n \n# 944 \"lib/read.mll\"\n )\n\n# 2860 \"lib/read.ml\"\n\n \n# 2861 \"lib/read.ml\"\n | 6 ->\n\n# 946 \"lib/read.mll\"\n \n# 946 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2865 \"lib/read.ml\"\n\n \n# 2866 \"lib/read.ml\"\n | 7 ->\n\n# 947 \"lib/read.mll\"\n \n# 947 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_json v lexbuf )\n\n# 2872 \"lib/read.ml\"\n\n \n# 2873 \"lib/read.ml\"\n | 8 ->\n\n# 950 \"lib/read.mll\"\n \n# 950 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_json v lexbuf )\n\n# 2879 \"lib/read.ml\"\n\n \n# 2880 \"lib/read.ml\"\n | 9 ->\n\n# 953 \"lib/read.mll\"\n \n# 953 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2884 \"lib/read.ml\"\n\n \n# 2885 \"lib/read.ml\"\n | 10 ->\n\n# 954 \"lib/read.mll\"\n \n# 954 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2889 \"lib/read.ml\"\n\n \n# 2890 \"lib/read.ml\"\n | 11 ->\n\n# 955 \"lib/read.mll\"\n \n# 955 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2894 \"lib/read.ml\"\n\n \n# 2895 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_stringlit v lexbuf =\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf 450\nand __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 961 \"lib/read.mll\"\n \n# 961 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\"';\n add_lexeme v.buf lexbuf\n )\n\n# 2908 \"lib/read.ml\"\n\n \n# 2909 \"lib/read.ml\"\n | 1 ->\n\n# 964 \"lib/read.mll\"\n \n# 964 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2913 \"lib/read.ml\"\n\n \n# 2914 \"lib/read.ml\"\n | 2 ->\n\n# 965 \"lib/read.mll\"\n \n# 965 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2918 \"lib/read.ml\"\n\n \n# 2919 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_variant v lexbuf =\n __ocaml_lex_finish_buffer_variant_rec v lexbuf 461\nand __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 968 \"lib/read.mll\"\n \n# 968 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':';\n buffer_json v lexbuf;\n buffer_space v lexbuf;\n buffer_gt v lexbuf )\n\n# 2933 \"lib/read.ml\"\n\n \n# 2934 \"lib/read.ml\"\n | 1 ->\n\n# 972 \"lib/read.mll\"\n \n# 972 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 2938 \"lib/read.ml\"\n\n \n# 2939 \"lib/read.ml\"\n | 2 ->\n\n# 973 \"lib/read.mll\"\n \n# 973 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2943 \"lib/read.ml\"\n\n \n# 2944 \"lib/read.ml\"\n | 3 ->\n\n# 974 \"lib/read.mll\"\n \n# 974 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2948 \"lib/read.ml\"\n\n \n# 2949 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state\n\nand buffer_ident v lexbuf =\n __ocaml_lex_buffer_ident_rec v lexbuf 466\nand __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 977 \"lib/read.mll\"\n \n# 977 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2960 \"lib/read.ml\"\n\n \n# 2961 \"lib/read.ml\"\n | 1 ->\n\n# 978 \"lib/read.mll\"\n \n# 978 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2965 \"lib/read.ml\"\n\n \n# 2966 \"lib/read.ml\"\n | 2 ->\n\n# 979 \"lib/read.mll\"\n \n# 979 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2970 \"lib/read.ml\"\n\n \n# 2971 \"lib/read.ml\"\n | 3 ->\n\n# 980 \"lib/read.mll\"\n \n# 980 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2975 \"lib/read.ml\"\n\n \n# 2976 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_space v lexbuf =\n __ocaml_lex_buffer_space_rec v lexbuf 471\nand __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 983 \"lib/read.mll\"\n \n# 983 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 2990 \"lib/read.ml\"\n\n \n# 2991 \"lib/read.ml\"\n | 1 ->\n\n# 987 \"lib/read.mll\"\n \n# 987 \"lib/read.mll\"\n (\n Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_space v lexbuf )\n\n# 2998 \"lib/read.ml\"\n\n \n# 2999 \"lib/read.ml\"\n | 2 ->\n\n# 991 \"lib/read.mll\"\n \n# 991 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 3006 \"lib/read.ml\"\n\n \n# 3007 \"lib/read.ml\"\n | 3 ->\n\n# 995 \"lib/read.mll\"\n \n# 995 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n buffer_space v lexbuf )\n\n# 3013 \"lib/read.ml\"\n\n \n# 3014 \"lib/read.ml\"\n | 4 ->\n\n# 998 \"lib/read.mll\"\n \n# 998 \"lib/read.mll\"\n ( () )\n\n# 3018 \"lib/read.ml\"\n\n \n# 3019 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_end v lexbuf =\n __ocaml_lex_buffer_object_end_rec v lexbuf 478\nand __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1001 \"lib/read.mll\"\n \n# 1001 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '}';\n raise End_of_object )\n\n# 3032 \"lib/read.ml\"\n\n \n# 3033 \"lib/read.ml\"\n | 1 ->\n\n# 1004 \"lib/read.mll\"\n \n# 1004 \"lib/read.mll\"\n ( () )\n\n# 3037 \"lib/read.ml\"\n\n \n# 3038 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_sep v lexbuf =\n __ocaml_lex_buffer_object_sep_rec v lexbuf 480\nand __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1007 \"lib/read.mll\"\n \n# 1007 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3049 \"lib/read.ml\"\n\n \n# 3050 \"lib/read.ml\"\n | 1 ->\n\n# 1008 \"lib/read.mll\"\n \n# 1008 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '}'; raise End_of_object )\n\n# 3054 \"lib/read.ml\"\n\n \n# 3055 \"lib/read.ml\"\n | 2 ->\n\n# 1009 \"lib/read.mll\"\n \n# 1009 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 3059 \"lib/read.ml\"\n\n \n# 3060 \"lib/read.ml\"\n | 3 ->\n\n# 1010 \"lib/read.mll\"\n \n# 1010 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3064 \"lib/read.ml\"\n\n \n# 3065 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_end v lexbuf =\n __ocaml_lex_buffer_array_end_rec v lexbuf 485\nand __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1013 \"lib/read.mll\"\n \n# 1013 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3076 \"lib/read.ml\"\n\n \n# 3077 \"lib/read.ml\"\n | 1 ->\n\n# 1014 \"lib/read.mll\"\n \n# 1014 \"lib/read.mll\"\n ( () )\n\n# 3081 \"lib/read.ml\"\n\n \n# 3082 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_sep v lexbuf =\n __ocaml_lex_buffer_array_sep_rec v lexbuf 487\nand __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1017 \"lib/read.mll\"\n \n# 1017 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3093 \"lib/read.ml\"\n\n \n# 3094 \"lib/read.ml\"\n | 1 ->\n\n# 1018 \"lib/read.mll\"\n \n# 1018 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3098 \"lib/read.ml\"\n\n \n# 3099 \"lib/read.ml\"\n | 2 ->\n\n# 1019 \"lib/read.mll\"\n \n# 1019 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 3103 \"lib/read.ml\"\n\n \n# 3104 \"lib/read.ml\"\n | 3 ->\n\n# 1020 \"lib/read.mll\"\n \n# 1020 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3108 \"lib/read.ml\"\n\n \n# 3109 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_end v lexbuf =\n __ocaml_lex_buffer_tuple_end_rec v lexbuf 492\nand __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1023 \"lib/read.mll\"\n \n# 1023 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf ')';\n raise End_of_tuple )\n\n# 3122 \"lib/read.ml\"\n\n \n# 3123 \"lib/read.ml\"\n | 1 ->\n\n# 1026 \"lib/read.mll\"\n \n# 1026 \"lib/read.mll\"\n ( () )\n\n# 3127 \"lib/read.ml\"\n\n \n# 3128 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_sep v lexbuf =\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf 494\nand __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1029 \"lib/read.mll\"\n \n# 1029 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3139 \"lib/read.ml\"\n\n \n# 3140 \"lib/read.ml\"\n | 1 ->\n\n# 1030 \"lib/read.mll\"\n \n# 1030 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ')'; raise End_of_tuple )\n\n# 3144 \"lib/read.ml\"\n\n \n# 3145 \"lib/read.ml\"\n | 2 ->\n\n# 1031 \"lib/read.mll\"\n \n# 1031 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 3149 \"lib/read.ml\"\n\n \n# 3150 \"lib/read.ml\"\n | 3 ->\n\n# 1032 \"lib/read.mll\"\n \n# 1032 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3154 \"lib/read.ml\"\n\n \n# 3155 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_colon v lexbuf =\n __ocaml_lex_buffer_colon_rec v lexbuf 499\nand __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1035 \"lib/read.mll\"\n \n# 1035 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':' )\n\n# 3166 \"lib/read.ml\"\n\n \n# 3167 \"lib/read.ml\"\n | 1 ->\n\n# 1036 \"lib/read.mll\"\n \n# 1036 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 3171 \"lib/read.ml\"\n\n \n# 3172 \"lib/read.ml\"\n | 2 ->\n\n# 1037 \"lib/read.mll\"\n \n# 1037 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3176 \"lib/read.ml\"\n\n \n# 3177 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state\n\nand buffer_gt v lexbuf =\n __ocaml_lex_buffer_gt_rec v lexbuf 503\nand __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1040 \"lib/read.mll\"\n \n# 1040 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 3188 \"lib/read.ml\"\n\n \n# 3189 \"lib/read.ml\"\n | 1 ->\n\n# 1041 \"lib/read.mll\"\n \n# 1041 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 3193 \"lib/read.ml\"\n\n \n# 3194 \"lib/read.ml\"\n | 2 ->\n\n# 1042 \"lib/read.mll\"\n \n# 1042 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3198 \"lib/read.ml\"\n\n \n# 3199 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_comment v lexbuf =\n __ocaml_lex_finish_buffer_comment_rec v lexbuf 507\nand __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1045 \"lib/read.mll\"\n \n# 1045 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"*/\" )\n\n# 3210 \"lib/read.ml\"\n\n \n# 3211 \"lib/read.ml\"\n | 1 ->\n\n# 1046 \"lib/read.mll\"\n \n# 1046 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 3215 \"lib/read.ml\"\n\n \n# 3216 \"lib/read.ml\"\n | 2 ->\n\n# 1047 \"lib/read.mll\"\n \n# 1047 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n finish_buffer_comment v lexbuf )\n\n# 3222 \"lib/read.ml\"\n\n \n# 3223 \"lib/read.ml\"\n | 3 ->\n\n# 1050 \"lib/read.mll\"\n \n# 1050 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; finish_buffer_comment v lexbuf )\n\n# 3227 \"lib/read.ml\"\n\n \n# 3228 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state\n\nand junk lexbuf =\n __ocaml_lex_junk_rec lexbuf 513\nand __ocaml_lex_junk_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1053 \"lib/read.mll\"\n \n# 1053 \"lib/read.mll\"\n ( Lexing.lexeme lexbuf )\n\n# 3239 \"lib/read.ml\"\n\n \n# 3240 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_junk_rec lexbuf __ocaml_lex_state\n\n;;\n\n\n# 1055 \"lib/read.mll\"\n \n \n# 1056 \"lib/read.mll\"\n let _ = (read_json : lexer_state -> Lexing.lexbuf -> t)\n\n let read_t = read_json\n\n let () =\n read_junk := junk\n\n let read_int8 v lexbuf =\n let n = read_int v lexbuf in\n if n < 0 || n > 255 then\n lexer_error \"Int8 overflow\" v lexbuf\n else\n char_of_int n\n\n let read_list read_cell v lexbuf =\n List.rev (read_list_rev read_cell v lexbuf)\n\n let array_of_rev_list l =\n match l with\n [] -> [| |]\n | x :: tl ->\n let len = List.length l in\n let a = Array.make len x in\n let r = ref tl in\n for i = len - 2 downto 0 do\n a.(i) <- List.hd !r;\n r := List.tl !r\n done;\n a\n\n let read_array read_cell v lexbuf =\n let l = read_list_rev read_cell v lexbuf in\n array_of_rev_list l\n\n (* Read a JSON object, reading the keys into OCaml strings\n (provided for backward compatibility) *)\n let read_fields read_field init_acc v =\n read_abstract_fields read_ident read_field init_acc v\n\n let finish v lexbuf =\n read_space v lexbuf;\n if not (read_eof lexbuf) then\n long_error \"Junk after end of JSON value:\" v lexbuf\n\n let init_lexer = init_lexer\n\n let from_lexbuf v ?(stream = false) lexbuf =\n read_space v lexbuf;\n\n let x =\n if read_eof lexbuf then\n raise End_of_input\n else\n read_json v lexbuf\n in\n\n if not stream then\n finish v lexbuf;\n\n x\n\n\n let from_string ?buf ?fname ?lnum s =\n try\n let lexbuf = Lexing.from_string s in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_channel ?buf ?fname ?lnum ic =\n try\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n try\n let x = from_channel ?buf ?fname ?lnum ic in\n close_in ic;\n x\n with e ->\n close_in_noerr ic;\n raise e\n\n exception Finally of exn * exn\n\n let stream_from_lexbuf v ?(fin = fun () -> ()) lexbuf =\n let stream = Some true in\n let f i =\n try Some (from_lexbuf v ?stream lexbuf)\n with\n End_of_input ->\n fin ();\n None\n | e ->\n (try fin () with fin_e -> raise (Finally (e, fin_e)));\n raise e\n in\n Stream.from f\n\n let stream_from_string ?buf ?fname ?lnum s =\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v (Lexing.from_string s)\n\n let stream_from_channel ?buf ?fin ?fname ?lnum ic =\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ?fin lexbuf\n\n let stream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ~fin lexbuf\n\n type json_line = [ `Json of t | `Exn of exn ]\n\n let linestream_from_channel\n ?buf ?(fin = fun () -> ()) ?fname ?lnum:(lnum0 = 1) ic =\n let buf =\n match buf with\n None -> Some (Bi_outbuf.create 256)\n | Some _ -> buf\n in\n let f i =\n try\n let line = input_line ic in\n let lnum = lnum0 + i in\n Some (`Json (from_string ?buf ?fname ~lnum line))\n with\n End_of_file -> fin (); None\n | e -> Some (`Exn e)\n in\n Stream.from f\n\n let linestream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n linestream_from_channel ?buf ~fin ?fname ?lnum ic\n\n let prettify ?std s =\n pretty_to_string ?std (from_string s)\n\n let compact ?std s =\n to_string (from_string s)\n\n let validate_json _path _value = None\n\n\n# 3411 \"lib/read.ml\"\n# 62 \"yojson.cppo.ml\"\nmodule Util =\nstruct\n# 1 \"util.ml\"\nexception Type_error of string * t\n\nlet typeof = function\n | `Assoc _ -> \"object\"\n | `Bool _ -> \"bool\"\n | `Float _ -> \"float\"\n | `Int _ -> \"int\"\n | `List _ -> \"array\"\n | `Null -> \"null\"\n | `String _ -> \"string\"\n | `Intlit _ -> \"intlit\"\n | `Tuple _ -> \"tuple\"\n | `Variant _ -> \"variant\"\n\nlet typerr msg js = raise (Type_error (msg ^ typeof js, js))\n\nexception Undefined of string * t\n\nlet ( |> ) = ( |> )\n\nlet assoc name obj =\n try List.assoc name obj\n with Not_found -> `Null\n\nlet member name = function\n | `Assoc obj -> assoc name obj\n | js -> typerr (\"Can't get member '\" ^ name ^ \"' of non-object type \") js\n\nlet index i = function\n | `List l as js ->\n let len = List.length l in\n let wrapped_index = if i < 0 then len + i else i in\n if wrapped_index < 0 || wrapped_index >= len then\n raise (Undefined (\"Index \" ^ string_of_int i ^ \" out of bounds\", js))\n else List.nth l wrapped_index\n | js -> typerr (\"Can't get index \" ^ string_of_int i\n ^ \" of non-array type \") js\n\nlet map f = function\n | `List l -> `List (List.map f l)\n | js -> typerr \"Can't map function over non-array type \" js\n\nlet to_assoc = function\n | `Assoc obj -> obj\n | js -> typerr \"Expected object, got \" js\n\nlet to_option f = function\n | `Null -> None\n | x -> Some (f x)\n\nlet to_bool = function\n | `Bool b -> b\n | js -> typerr \"Expected bool, got \" js\n\nlet to_bool_option = function\n | `Bool b -> Some b\n | `Null -> None\n | js -> typerr \"Expected bool or null, got \" js\n\nlet to_number = function\n | `Int i -> float i\n | `Float f -> f\n | js -> typerr \"Expected number, got \" js\n\nlet to_number_option = function\n | `Int i -> Some (float i)\n | `Float f -> Some f\n | `Null -> None\n | js -> typerr \"Expected number or null, got \" js\n\nlet to_float = function\n | `Float f -> f\n | js -> typerr \"Expected float, got \" js\n\nlet to_float_option = function\n | `Float f -> Some f\n | `Null -> None\n | js -> typerr \"Expected float or null, got \" js\n\nlet to_int = function\n | `Int i -> i\n | js -> typerr \"Expected int, got \" js\n\nlet to_int_option = function\n | `Int i -> Some i\n | `Null -> None\n | js -> typerr \"Expected int or null, got \" js\n\nlet to_list = function\n | `List l -> l\n | js -> typerr \"Expected array, got \" js\n\nlet to_string = function\n | `String s -> s\n | js -> typerr \"Expected string, got \" js\n\nlet to_string_option = function\n | `String s -> Some s\n | `Null -> None\n | js -> typerr \"Expected string or null, got \" js\n\nlet convert_each f = function\n | `List l -> List.map f l\n | js -> typerr \"Can't convert each element of non-array type \" js\n\n\nlet rec rev_filter_map f acc l =\n match l with\n [] -> acc\n | x :: tl ->\n match f x with\n None -> rev_filter_map f acc tl\n | Some y -> rev_filter_map f (y :: acc) tl\n\nlet filter_map f l =\n List.rev (rev_filter_map f [] l)\n\nlet rec rev_flatten acc l =\n match l with\n [] -> acc\n | x :: tl ->\n match x with\n `List l2 -> rev_flatten (List.rev_append l2 acc) tl\n | _ -> rev_flatten acc tl\n\nlet flatten l =\n List.rev (rev_flatten [] l)\n\nlet filter_index i l =\n filter_map (\n function\n `List l ->\n (try Some (List.nth l i)\n with _ -> None)\n | _ -> None\n ) l\n\nlet filter_list l =\n filter_map (\n function\n `List l -> Some l\n | _ -> None\n ) l\n\nlet filter_member k l =\n filter_map (\n function\n `Assoc l ->\n (try Some (List.assoc k l)\n with _ -> None)\n | _ -> None\n ) l\n\nlet filter_assoc l =\n filter_map (\n function\n `Assoc l -> Some l\n | _ -> None\n ) l\n\nlet filter_bool l =\n filter_map (\n function\n `Bool x -> Some x\n | _ -> None\n ) l\n\nlet filter_int l =\n filter_map (\n function\n `Int x -> Some x\n | _ -> None\n ) l\n\nlet filter_float l =\n filter_map (\n function\n `Float x -> Some x\n | _ -> None\n ) l\n\nlet filter_number l =\n filter_map (\n function\n `Int x -> Some (float x)\n | `Float x -> Some x\n | _ -> None\n ) l\n\nlet filter_string l =\n filter_map (\n function\n `String x -> Some x\n | _ -> None\n ) l\n\nlet keys o =\n to_assoc o |> List.map (fun (key, _) -> key)\n\nlet values o =\n to_assoc o |> List.map (fun (_, value) -> value)\n\nlet combine (first : t) (second : t) =\n match (first, second) with\n | (`Assoc a, `Assoc b) -> (`Assoc (a @ b) : t)\n | (a, b) -> raise (Invalid_argument \"Expected two objects, check inputs\")\n# 65 \"yojson.cppo.ml\"\nend\n# 72 \"yojson.cppo.ml\"\nend\n\nmodule Raw =\nstruct\n# 1 \"type.ml\"\n(** {3 Type of the JSON tree} *)\n\ntype t =\n [\n | `Null\n | `Bool of bool\n \n# 11 \"type.ml\"\n | `Intlit of string\n \n# 17 \"type.ml\"\n | `Floatlit of string\n \n# 23 \"type.ml\"\n | `Stringlit of string\n \n# 25 \"type.ml\"\n | `Assoc of (string * t) list\n | `List of t list\n \n# 28 \"type.ml\"\n | `Tuple of t list\n \n# 31 \"type.ml\"\n | `Variant of (string * t option)\n \n# 33 \"type.ml\"\n ]\n(**\nAll possible cases defined in Yojson:\n- `Null: JSON null\n- `Bool of bool: JSON boolean\n- `Int of int: JSON number without decimal point or exponent.\n- `Intlit of string: JSON number without decimal point or exponent,\n\t preserved as a string.\n- `Float of float: JSON number, Infinity, -Infinity or NaN.\n- `Floatlit of string: JSON number, Infinity, -Infinity or NaN,\n\t preserved as a string.\n- `String of string: JSON string. Bytes in the range 128-255 are preserved\n\t as-is without encoding validation for both reading\n\t and writing.\n- `Stringlit of string: JSON string literal including the double quotes.\n- `Assoc of (string * json) list: JSON object.\n- `List of json list: JSON array.\n- `Tuple of json list: Tuple (non-standard extension of JSON).\n\t Syntax: [(\"abc\", 123)].\n- `Variant of (string * json option): Variant (non-standard extension of JSON).\n\t Syntax: [<\"Foo\">] or [<\"Bar\":123>].\n*)\n\ntype json = t [@@deprecated \"json types are being renamed and will be removed in the next Yojson major version. Use type t instead\"]\n(**\n * Compatibility type alias for type `t`\n *)\n\n(*\n Note to adventurers: ocamldoc does not support inline comments\n on each polymorphic variant, and cppo doesn't allow to concatenate\n comments, so it would be complicated to document only the\n cases that are preserved by cppo in the type definition.\n*)\n# 1 \"write.ml\"\n(* included: type.ml *)\n\nlet hex n =\n Char.chr (\n if n < 10 then n + 48\n else n + 87\n )\n\nlet write_special src start stop ob str =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n Bi_outbuf.add_string ob str;\n start := stop + 1\n\nlet write_control_char src start stop ob c =\n Bi_outbuf.add_substring ob src !start (stop - !start);\n let i = Bi_outbuf.alloc ob 6 in\n let dst = ob.o_s in\n Bytes.blit_string \"\\\\u00\" 0 dst i 4;\n Bytes.set dst (i+4) (hex (Char.code c lsr 4));\n Bytes.set dst (i+5) (hex (Char.code c land 0xf));\n start := stop + 1\n\nlet finish_string src start ob =\n try\n Bi_outbuf.add_substring ob src !start (String.length src - !start)\n with exc ->\n Printf.eprintf \"src=%S start=%i len=%i\\n%!\"\n src !start (String.length src - !start);\n raise exc\n\nlet write_string_body ob s =\n let start = ref 0 in\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '\"' -> write_special s start i ob \"\\\\\\\"\"\n | '\\\\' -> write_special s start i ob \"\\\\\\\\\"\n | '\\b' -> write_special s start i ob \"\\\\b\"\n | '\\012' -> write_special s start i ob \"\\\\f\"\n | '\\n' -> write_special s start i ob \"\\\\n\"\n | '\\r' -> write_special s start i ob \"\\\\r\"\n | '\\t' -> write_special s start i ob \"\\\\t\"\n | '\\x00'..'\\x1F'\n | '\\x7F' as c -> write_control_char s start i ob c\n | _ -> ()\n done;\n finish_string s start ob\n\nlet write_string ob s =\n Bi_outbuf.add_char ob '\"';\n write_string_body ob s;\n Bi_outbuf.add_char ob '\"'\n\nlet json_string_of_string s =\n let ob = Bi_outbuf.create 10 in\n write_string ob s;\n Bi_outbuf.contents ob\n\nlet test_string () =\n let s = Bytes.create 256 in\n for i = 0 to 255 do\n Bytes.set s i (Char.chr i)\n done;\n json_string_of_string (Bytes.to_string s)\n\n\nlet write_null ob () =\n Bi_outbuf.add_string ob \"null\"\n\nlet write_bool ob x =\n Bi_outbuf.add_string ob (if x then \"true\" else \"false\")\n\n\nlet max_digits =\n max\n (String.length (string_of_int max_int))\n (String.length (string_of_int min_int))\n\nlet dec n =\n Char.chr (n + 48)\n\nlet rec write_digits s pos x =\n if x = 0 then pos\n else\n let d = x mod 10 in\n let pos = write_digits s pos (x / 10) in\n Bytes.set s pos (dec (abs d));\n pos + 1\n\nlet write_int ob x =\n Bi_outbuf.extend ob max_digits;\n if x > 0 then\n ob.o_len <- write_digits ob.o_s ob.o_len x\n else if x < 0 then (\n let s = ob.o_s in\n let pos = ob.o_len in\n Bytes.set s pos '-';\n ob.o_len <- write_digits s (pos + 1) x\n )\n else\n Bi_outbuf.add_char ob '0'\n\n\nlet json_string_of_int i =\n string_of_int i\n\n\n(*\n Ensure that the float is not printed as an int.\n This is not required by JSON, but useful in order to guarantee\n reversibility.\n*)\nlet float_needs_period s =\n try\n for i = 0 to String.length s - 1 do\n match s.[i] with\n '0'..'9' | '-' -> ()\n | _ -> raise Exit\n done;\n true\n with Exit ->\n false\n\n(*\n Both write_float_fast and write_float guarantee\n that a sufficient number of digits are printed in order to\n allow reversibility.\n\n The _fast version is faster but often produces unnecessarily long numbers.\n*)\nlet write_float_fast ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_normal_float_prec significant_figures ob x =\n let open Printf in\n let s =\n match significant_figures with\n 1 -> sprintf \"%.1g\" x\n | 2 -> sprintf \"%.2g\" x\n | 3 -> sprintf \"%.3g\" x\n | 4 -> sprintf \"%.4g\" x\n | 5 -> sprintf \"%.5g\" x\n | 6 -> sprintf \"%.6g\" x\n | 7 -> sprintf \"%.7g\" x\n | 8 -> sprintf \"%.8g\" x\n | 9 -> sprintf \"%.9g\" x\n | 10 -> sprintf \"%.10g\" x\n | 11 -> sprintf \"%.11g\" x\n | 12 -> sprintf \"%.12g\" x\n | 13 -> sprintf \"%.13g\" x\n | 14 -> sprintf \"%.14g\" x\n | 15 -> sprintf \"%.15g\" x\n | 16 -> sprintf \"%.16g\" x\n | _ -> sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n Bi_outbuf.add_string ob \"NaN\"\n | FP_infinite ->\n Bi_outbuf.add_string ob (if x > 0. then \"Infinity\" else \"-Infinity\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_float ob x;\n Bi_outbuf.contents ob\n\n\nlet write_std_float_fast ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s = Printf.sprintf \"%.17g\" x in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n let s1 = Printf.sprintf \"%.16g\" x in\n let s =\n if float_of_string s1 = x then s1\n else Printf.sprintf \"%.17g\" x\n in\n Bi_outbuf.add_string ob s;\n if float_needs_period s then\n Bi_outbuf.add_string ob \".0\"\n\nlet write_std_float_prec significant_figures ob x =\n match classify_float x with\n FP_nan ->\n json_error \"NaN value not allowed in standard JSON\"\n | FP_infinite ->\n json_error\n (if x > 0. then\n \"Infinity value not allowed in standard JSON\"\n else\n \"-Infinity value not allowed in standard JSON\")\n | _ ->\n write_normal_float_prec significant_figures ob x\n\nlet std_json_string_of_float x =\n let ob = Bi_outbuf.create 20 in\n write_std_float ob x;\n Bi_outbuf.contents ob\n\n\nlet test_float () =\n let l = [ 0.; 1.; -1. ] in\n let l = l @ List.map (fun x -> 2. *. x +. 1.) l in\n let l = l @ List.map (fun x -> x /. sqrt 2.) l in\n let l = l @ List.map (fun x -> x *. sqrt 3.) l in\n let l = l @ List.map cos l in\n let l = l @ List.map (fun x -> x *. 1.23e50) l in\n let l = l @ [ infinity; neg_infinity ] in\n List.iter (\n fun x ->\n let s = Printf.sprintf \"%.17g\" x in\n let y = float_of_string s in\n Printf.printf \"%g %g %S %B\\n\" x y s (x = y)\n )\n l\n\n(*\nlet () = test_float ()\n*)\n\nlet write_intlit = Bi_outbuf.add_string\nlet write_floatlit = Bi_outbuf.add_string\nlet write_stringlit = Bi_outbuf.add_string\n\nlet rec iter2_aux f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_sep x;\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet iter2 f_elt f_sep x = function\n [] -> ()\n | y :: l ->\n f_elt x y;\n iter2_aux f_elt f_sep x l\n\nlet f_sep ob =\n Bi_outbuf.add_char ob ','\n\nlet rec write_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 302 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 308 \"write.ml\"\n | `Floatlit s -> Bi_outbuf.add_string ob s\n \n# 314 \"write.ml\"\n | `Stringlit s -> Bi_outbuf.add_string ob s\n \n# 316 \"write.ml\"\n | `Assoc l -> write_assoc ob l\n | `List l -> write_list ob l\n \n# 319 \"write.ml\"\n | `Tuple l -> write_tuple ob l\n \n# 322 \"write.ml\"\n | `Variant (s, o) -> write_variant ob s o\n\n# 325 \"write.ml\"\nand write_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 341 \"write.ml\"\nand write_tuple ob l =\n Bi_outbuf.add_char ob '(';\n iter2 write_json f_sep ob l;\n Bi_outbuf.add_char ob ')'\n\n# 348 \"write.ml\"\nand write_variant ob s o =\n Bi_outbuf.add_char ob '<';\n write_string ob s;\n (match o with\n None -> ()\n | Some x ->\n Bi_outbuf.add_char ob ':';\n write_json ob x\n );\n Bi_outbuf.add_char ob '>'\n\n# 360 \"write.ml\"\nlet write_t = write_json\n\nlet rec write_std_json ob (x : t) =\n match x with\n `Null -> write_null ob ()\n | `Bool b -> write_bool ob b\n \n# 370 \"write.ml\"\n | `Intlit s -> Bi_outbuf.add_string ob s\n \n# 376 \"write.ml\"\n | `Floatlit s -> Bi_outbuf.add_string ob s\n \n# 382 \"write.ml\"\n | `Stringlit s -> Bi_outbuf.add_string ob s\n \n# 384 \"write.ml\"\n | `Assoc l -> write_std_assoc ob l\n | `List l -> write_std_list ob l\n \n# 387 \"write.ml\"\n | `Tuple l -> write_std_tuple ob l\n \n# 390 \"write.ml\"\n | `Variant (s, o) -> write_std_variant ob s o\n\n# 393 \"write.ml\"\nand write_std_assoc ob l =\n let f_elt ob (s, x) =\n write_string ob s;\n Bi_outbuf.add_char ob ':';\n write_std_json ob x\n in\n Bi_outbuf.add_char ob '{';\n iter2 f_elt f_sep ob l;\n Bi_outbuf.add_char ob '}';\n\nand write_std_list ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\nand write_std_tuple ob l =\n Bi_outbuf.add_char ob '[';\n iter2 write_std_json f_sep ob l;\n Bi_outbuf.add_char ob ']'\n\n# 414 \"write.ml\"\nand write_std_variant ob s o =\n match o with\n None -> write_string ob s\n | Some x ->\n Bi_outbuf.add_char ob '[';\n write_string ob s;\n Bi_outbuf.add_char ob ',';\n write_std_json ob x;\n Bi_outbuf.add_char ob ']'\n\n\n# 426 \"write.ml\"\nlet to_outbuf ?(std = false) ob x =\n if std then (\n if not (is_object_or_array x) then\n json_error \"Root is not an object or array\"\n else\n write_std_json ob x\n )\n else\n write_json ob x\n\n\nlet to_string ?buf ?(len = 256) ?std x =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n to_outbuf ?std ob x;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet to_channel ?buf ?len ?std oc x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_channel_writer ob\n\nlet to_output ?buf ?len ?std out x =\n let ob =\n match buf with\n None -> Bi_outbuf.create_output_writer ?len out\n | Some ob -> ob\n in\n to_outbuf ?std ob x;\n Bi_outbuf.flush_output_writer ob\n\nlet to_file ?len ?std file x =\n let oc = open_out file in\n try\n to_channel ?len ?std oc x;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\nlet stream_to_outbuf ?std ob st =\n Stream.iter (to_outbuf ?std ob) st\n\nlet stream_to_string ?buf ?(len = 256) ?std st =\n let ob =\n match buf with\n None -> Bi_outbuf.create len\n | Some ob ->\n Bi_outbuf.clear ob;\n ob\n in\n stream_to_outbuf ?std ob st;\n let s = Bi_outbuf.contents ob in\n Bi_outbuf.clear ob;\n s\n\nlet stream_to_channel ?buf ?len ?std oc st =\n let ob =\n match buf with\n None -> Bi_outbuf.create_channel_writer ?len oc\n | Some ob -> ob\n in\n stream_to_outbuf ?std ob st;\n Bi_outbuf.flush_channel_writer ob\n\nlet stream_to_file ?len ?std file st =\n let oc = open_out file in\n try\n stream_to_channel ?len ?std oc st;\n close_out oc\n with e ->\n close_out_noerr oc;\n raise e\n\n\nlet rec sort = function\n | `Assoc l ->\n let l = List.rev (List.rev_map (fun (k, v) -> (k, sort v)) l) in\n `Assoc (List.stable_sort (fun (a, _) (b, _) -> String.compare a b) l)\n | `List l ->\n `List (List.rev (List.rev_map sort l))\n \n# 519 \"write.ml\"\n | `Tuple l ->\n `Tuple (List.rev (List.rev_map sort l))\n \n# 523 \"write.ml\"\n | `Variant (k, Some v) as x ->\n let v' = sort v in\n if v == v' then x\n else\n `Variant (k, Some v')\n \n# 529 \"write.ml\"\n | x -> x\n# 1 \"monomorphic.ml\"\nlet rec pp fmt =\n function\n | `Null -> Format.pp_print_string fmt \"`Null\"\n | `Bool x ->\n Format.fprintf fmt \"`Bool (@[\";\n Format.fprintf fmt \"%B\" x;\n Format.fprintf fmt \"@])\"\n \n# 15 \"monomorphic.ml\"\n | `Intlit x ->\n Format.fprintf fmt \"`Intlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 27 \"monomorphic.ml\"\n | `Floatlit x ->\n Format.fprintf fmt \"`Floatlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 39 \"monomorphic.ml\"\n | `Stringlit x ->\n Format.fprintf fmt \"`Stringlit (@[\";\n Format.fprintf fmt \"%S\" x;\n Format.fprintf fmt \"@])\"\n \n# 44 \"monomorphic.ml\"\n | `Assoc xs ->\n Format.fprintf fmt \"`Assoc (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep (key, value) ->\n if sep then\n Format.fprintf fmt \";@ \";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" key;\n Format.fprintf fmt \",@ \";\n pp fmt value;\n Format.fprintf fmt \"@])\";\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n | `List xs ->\n Format.fprintf fmt \"`List (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep x ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt x;\n true) false xs);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 71 \"monomorphic.ml\"\n | `Tuple tup ->\n Format.fprintf fmt \"`Tuple (@[\";\n Format.fprintf fmt \"@[<2>[\";\n ignore (List.fold_left\n (fun sep e ->\n if sep then\n Format.fprintf fmt \";@ \";\n pp fmt e;\n true) false tup);\n Format.fprintf fmt \"@,]@]\";\n Format.fprintf fmt \"@])\"\n \n# 84 \"monomorphic.ml\"\n | `Variant (name, value) ->\n Format.fprintf fmt \"`Variant (@[\";\n Format.fprintf fmt \"(@[\";\n Format.fprintf fmt \"%S\" name;\n Format.fprintf fmt \",@ \";\n (match value with\n | None -> Format.pp_print_string fmt \"None\"\n | Some x ->\n Format.pp_print_string fmt \"(Some \";\n pp fmt x;\n Format.pp_print_string fmt \")\");\n Format.fprintf fmt \"@])\";\n Format.fprintf fmt \"@])\"\n\n# 99 \"monomorphic.ml\"\nlet show x =\n Format.asprintf \"%a\" pp x\n\nlet rec equal a b =\n match a, b with\n | `Null, `Null -> true\n | `Bool a, `Bool b -> a = b\n \n# 110 \"monomorphic.ml\"\n | `Intlit a, `Intlit b -> a = b\n \n# 116 \"monomorphic.ml\"\n | `Floatlit a, `Floatlit b -> a = b\n \n# 122 \"monomorphic.ml\"\n | `Stringlit a, `Stringlit b -> a = b\n \n# 124 \"monomorphic.ml\"\n | `Assoc xs, `Assoc ys ->\n let compare_keys = fun (key, _) (key', _) -> String.compare key key' in\n let xs = List.stable_sort compare_keys xs in\n let ys = List.stable_sort compare_keys ys in\n (match List.for_all2 (fun (key, value) (key', value') ->\n match key = key' with\n | false -> false\n | true -> equal value value') xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 137 \"monomorphic.ml\"\n | `Tuple xs, `Tuple ys\n \n# 139 \"monomorphic.ml\"\n | `List xs, `List ys ->\n (match List.for_all2 equal xs ys with\n | result -> result\n | exception Invalid_argument _ ->\n (* the lists were of different lengths, thus unequal *)\n false)\n \n# 146 \"monomorphic.ml\"\n | `Variant (name, value), `Variant (name', value') ->\n (match name = name' with\n | false -> false\n | true ->\n match value, value' with\n | None, None -> true\n | Some x, Some y -> equal x y\n | _ -> false)\n \n# 155 \"monomorphic.ml\"\n | _ -> false\n# 1 \"write2.ml\"\nlet pretty_format ?std (x : t) =\n Pretty.format ?std (x :> json_max)\n\nlet pretty_print ?std out (x : t) =\n Easy_format.Pretty.to_formatter out (pretty_format ?std x)\n\nlet pretty_to_string ?std (x : t) =\n Pretty.to_string ?std (x :> json_max)\n\nlet pretty_to_channel ?std oc (x : t) =\n Pretty.to_channel ?std oc (x :> json_max)\n\n# 1 \"lib/read.mll\"\n \n \n# 2 \"lib/read.mll\"\n module Lexing =\n (*\n We override Lexing.engine in order to avoid creating a new position\n record each time a rule is matched.\n This reduces total parsing time by about 31%.\n *)\n struct\n include Lexing\n\n external c_engine : lex_tables -> int -> lexbuf -> int = \"caml_lex_engine\"\n\n let engine tbl state buf =\n let result = c_engine tbl state buf in\n (*\n if result >= 0 then begin\n buf.lex_start_p <- buf.lex_curr_p;\n buf.lex_curr_p <- {buf.lex_curr_p\n with pos_cnum = buf.lex_abs_pos + buf.lex_curr_pos};\n end;\n *)\n result\n end\n\n open Printf\n open Lexing\n\n (* see description in common.mli *)\n type lexer_state = Lexer_state.t = {\n buf : Bi_outbuf.t;\n mutable lnum : int;\n mutable bol : int;\n mutable fname : string option;\n }\n\n let dec c =\n Char.code c - 48\n\n let hex c =\n match c with\n '0'..'9' -> int_of_char c - int_of_char '0'\n | 'a'..'f' -> int_of_char c - int_of_char 'a' + 10\n | 'A'..'F' -> int_of_char c - int_of_char 'A' + 10\n | _ -> assert false\n\n let custom_error descr v lexbuf =\n let offs = lexbuf.lex_abs_pos - 1 in\n let bol = v.bol in\n let pos1 = offs + lexbuf.lex_start_pos - bol - 1 in\n let pos2 = max pos1 (offs + lexbuf.lex_curr_pos - bol) in\n let file_line =\n match v.fname with\n None -> \"Line\"\n | Some s ->\n sprintf \"File %s, line\" s\n in\n let bytes =\n if pos1 = pos2 then\n sprintf \"byte %i\" (pos1+1)\n else\n sprintf \"bytes %i-%i\" (pos1+1) (pos2+1)\n in\n let msg = sprintf \"%s %i, %s:\\n%s\" file_line v.lnum bytes descr in\n json_error msg\n\n\n let lexer_error descr v lexbuf =\n custom_error\n (sprintf \"%s '%s'\" descr (Lexing.lexeme lexbuf))\n v lexbuf\n\n let read_junk = ref (fun _ -> assert false)\n\n let long_error descr v lexbuf =\n let junk = Lexing.lexeme lexbuf in\n let extra_junk = !read_junk lexbuf in\n custom_error\n (sprintf \"%s '%s%s'\" descr junk extra_junk)\n v lexbuf\n\n let min10 = min_int / 10 - (if min_int mod 10 = 0 then 0 else 1)\n let max10 = max_int / 10 + (if max_int mod 10 = 0 then 0 else 1)\n\n exception Int_overflow\n\n let extract_positive_int lexbuf =\n let start = lexbuf.lex_start_pos in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n >= max10 then\n raise Int_overflow\n else\n n := 10 * !n + dec (Bytes.get s i)\n done;\n if !n < 0 then\n raise Int_overflow\n else\n !n\n\n let make_positive_int v lexbuf =\n \n# 108 \"lib/read.mll\"\n `Intlit (lexeme lexbuf)\n\n \n# 113 \"lib/read.mll\"\n let extract_negative_int lexbuf =\n let start = lexbuf.lex_start_pos + 1 in\n let stop = lexbuf.lex_curr_pos in\n let s = lexbuf.lex_buffer in\n let n = ref 0 in\n for i = start to stop - 1 do\n if !n <= min10 then\n raise Int_overflow\n else\n n := 10 * !n - dec (Bytes.get s i)\n done;\n if !n > 0 then\n raise Int_overflow\n else\n !n\n\n let make_negative_int v lexbuf =\n \n# 135 \"lib/read.mll\"\n `Intlit (lexeme lexbuf)\n\n\n \n# 141 \"lib/read.mll\"\n let set_file_name v fname =\n v.fname <- fname\n\n let newline v lexbuf =\n v.lnum <- v.lnum + 1;\n v.bol <- lexbuf.lex_abs_pos + lexbuf.lex_curr_pos\n\n let add_lexeme buf lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n Bi_outbuf.add_subbytes buf lexbuf.lex_buffer lexbuf.lex_start_pos len\n\n let map_lexeme f lexbuf =\n let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n f (Bytes.to_string lexbuf.lex_buffer) lexbuf.lex_start_pos len\n\n type variant_kind = [ `Edgy_bracket | `Square_bracket | `Double_quote ]\n type tuple_kind = [ `Parenthesis | `Square_bracket ]\n\n\n# 161 \"lib/read.ml\"\n# 161 \"lib/read.ml\"\nlet __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\236\\255\\237\\255\\003\\000\\239\\255\\016\\000\\242\\255\\243\\255\\\n \\244\\255\\245\\255\\000\\000\\031\\000\\249\\255\\085\\000\\001\\000\\000\\000\\\n \\000\\000\\001\\000\\000\\000\\001\\000\\002\\000\\255\\255\\000\\000\\000\\000\\\n \\003\\000\\254\\255\\001\\000\\004\\000\\253\\255\\011\\000\\252\\255\\003\\000\\\n \\001\\000\\003\\000\\002\\000\\003\\000\\000\\000\\251\\255\\021\\000\\097\\000\\\n \\010\\000\\022\\000\\020\\000\\016\\000\\022\\000\\012\\000\\008\\000\\250\\255\\\n \\119\\000\\129\\000\\139\\000\\161\\000\\171\\000\\181\\000\\193\\000\\209\\000\\\n \\240\\255\\011\\000\\038\\000\\252\\255\\065\\000\\254\\255\\255\\255\\110\\000\\\n \\252\\255\\163\\000\\254\\255\\255\\255\\234\\000\\247\\255\\248\\255\\048\\001\\\n \\250\\255\\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\071\\001\\126\\001\\\n \\149\\001\\249\\255\\039\\000\\253\\255\\254\\255\\038\\000\\187\\001\\210\\001\\\n \\248\\001\\015\\002\\255\\255\\220\\000\\253\\255\\255\\255\\245\\000\\039\\002\\\n \\109\\002\\014\\001\\088\\002\\164\\002\\187\\002\\225\\002\\013\\000\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\014\\000\\253\\255\\254\\255\\255\\255\\030\\000\\\n \\253\\255\\254\\255\\255\\255\\015\\000\\253\\255\\254\\255\\255\\255\\017\\001\\\n \\251\\255\\252\\255\\253\\255\\254\\255\\255\\255\\019\\000\\252\\255\\253\\255\\\n \\254\\255\\015\\000\\255\\255\\016\\000\\255\\255\\008\\001\\005\\000\\253\\255\\\n \\023\\000\\254\\255\\020\\000\\255\\255\\046\\000\\253\\255\\254\\255\\042\\000\\\n \\052\\000\\053\\000\\255\\255\\053\\000\\048\\000\\091\\000\\092\\000\\255\\255\\\n \\027\\001\\250\\255\\251\\255\\137\\000\\104\\000\\089\\000\\088\\000\\106\\000\\\n \\255\\255\\143\\000\\137\\000\\177\\000\\254\\255\\183\\000\\168\\000\\166\\000\\\n \\183\\000\\002\\000\\253\\255\\177\\000\\172\\000\\187\\000\\004\\000\\252\\255\\\n \\053\\002\\251\\255\\252\\255\\253\\255\\103\\001\\255\\255\\248\\002\\254\\255\\\n \\006\\003\\030\\003\\252\\255\\253\\255\\254\\255\\255\\255\\040\\003\\050\\003\\\n \\074\\003\\252\\255\\253\\255\\254\\255\\255\\255\\061\\003\\084\\003\\108\\003\\\n \\249\\255\\250\\255\\251\\255\\244\\000\\120\\003\\142\\003\\179\\000\\194\\000\\\n \\015\\000\\255\\255\\190\\000\\188\\000\\187\\000\\193\\000\\183\\000\\179\\000\\\n \\254\\255\\191\\000\\201\\000\\200\\000\\196\\000\\203\\000\\193\\000\\189\\000\\\n \\253\\255\\157\\003\\095\\003\\174\\003\\196\\003\\206\\003\\216\\003\\228\\003\\\n \\239\\003\\060\\000\\253\\255\\254\\255\\255\\255\\012\\004\\252\\255\\253\\255\\\n \\087\\004\\255\\255\\145\\004\\252\\255\\253\\255\\221\\004\\255\\255\\229\\000\\\n \\253\\255\\254\\255\\255\\255\\231\\000\\253\\255\\254\\255\\255\\255\\002\\000\\\n \\255\\255\\018\\001\\252\\255\\253\\255\\254\\255\\255\\255\\034\\001\\253\\255\\\n \\254\\255\\255\\255\\000\\000\\255\\255\\003\\000\\254\\255\\255\\255\\038\\001\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\120\\001\\251\\255\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\208\\000\\253\\255\\254\\255\\255\\255\\211\\000\\253\\255\\\n \\254\\255\\255\\255\\189\\000\\255\\255\\143\\001\\252\\255\\253\\255\\254\\255\\\n \\255\\255\\013\\001\\253\\255\\254\\255\\255\\255\\095\\001\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\050\\001\\253\\255\\254\\255\\255\\255\\026\\001\\253\\255\\\n \\254\\255\\255\\255\\233\\000\\253\\255\\254\\255\\255\\255\\222\\000\\253\\255\\\n \\254\\255\\255\\255\\079\\005\\237\\255\\238\\255\\010\\000\\240\\255\\044\\001\\\n \\243\\255\\244\\255\\245\\255\\246\\255\\061\\001\\002\\004\\249\\255\\045\\005\\\n \\209\\000\\228\\000\\211\\000\\232\\000\\225\\000\\223\\000\\240\\000\\255\\255\\\n \\235\\000\\234\\000\\008\\001\\254\\255\\004\\001\\023\\001\\253\\255\\054\\001\\\n \\252\\255\\031\\001\\029\\001\\032\\001\\039\\001\\049\\001\\045\\001\\251\\255\\\n \\057\\001\\082\\001\\080\\001\\078\\001\\084\\001\\074\\001\\086\\001\\250\\255\\\n \\110\\005\\012\\004\\123\\005\\155\\005\\165\\005\\177\\005\\187\\005\\197\\005\\\n \\241\\255\\199\\001\\077\\002\\253\\255\\255\\255\\154\\002\\222\\005\\209\\005\\\n \\155\\002\\239\\005\\053\\006\\076\\006\\114\\006\\016\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\152\\006\\252\\255\\253\\255\\227\\006\\255\\255\\085\\007\\\n \\244\\255\\245\\255\\011\\000\\247\\255\\076\\002\\250\\255\\251\\255\\252\\255\\\n \\253\\255\\254\\255\\031\\002\\243\\005\\051\\007\\100\\001\\115\\001\\104\\001\\\n \\133\\001\\118\\001\\154\\001\\171\\001\\255\\255\\173\\001\\176\\001\\191\\001\\\n \\185\\001\\187\\001\\253\\001\\230\\001\\230\\001\\234\\001\\247\\001\\237\\001\\\n \\234\\001\\009\\002\\019\\002\\019\\002\\015\\002\\021\\002\\011\\002\\007\\002\\\n \\142\\006\\152\\006\\116\\007\\170\\007\\180\\007\\190\\007\\200\\007\\210\\007\\\n \\248\\255\\120\\002\\167\\002\\253\\255\\255\\255\\216\\002\\082\\007\\220\\007\\\n \\236\\002\\244\\007\\058\\008\\081\\008\\119\\008\\076\\002\\252\\255\\253\\255\\\n \\254\\255\\255\\255\\157\\008\\252\\255\\253\\255\\232\\008\\255\\255\\135\\002\\\n \\120\\002\\253\\255\\100\\002\\254\\255\\182\\002\\255\\255\\011\\002\\255\\255\\\n \\204\\002\\252\\255\\253\\255\\254\\255\\255\\255\\046\\002\\255\\255\\178\\002\\\n \\252\\255\\253\\255\\254\\255\\255\\255\\023\\000\\255\\255\\183\\002\\252\\255\\\n \\253\\255\\254\\255\\255\\255\\187\\002\\253\\255\\254\\255\\255\\255\\121\\002\\\n \\253\\255\\254\\255\\255\\255\\184\\002\\252\\255\\253\\255\\254\\255\\019\\000\\\n \\255\\255\\140\\001\\146\\001\\255\\255\\150\\001\\151\\001\\154\\001\\168\\001\\\n \\170\\001\\171\\001\\172\\001\\173\\001\\181\\001\\184\\001\\185\\001\\187\\001\\\n \\191\\001\\193\\001\\195\\001\\196\\001\\197\\001\\200\\001\\203\\001\\223\\001\\\n \\225\\001\\228\\001\\249\\001\\251\\001\\002\\002\\004\\002\\011\\002\\012\\002\\\n \\013\\002\\000\\000\";\n Lexing.lex_backtrk =\n \"\\255\\255\\255\\255\\255\\255\\017\\000\\255\\255\\019\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\008\\000\\008\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\009\\000\\255\\255\\\n \\255\\255\\014\\000\\255\\255\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\003\\000\\255\\255\\001\\000\\255\\255\\004\\000\\003\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\004\\000\\004\\000\\004\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\000\\000\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\002\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\003\\000\\005\\000\\005\\000\\005\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\003\\000\\255\\255\\003\\000\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\002\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\016\\000\\255\\255\\018\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\007\\000\\007\\000\\255\\255\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\008\\000\\255\\255\\\n \\255\\255\\013\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\011\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\000\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\006\\000\\255\\255\\255\\255\\255\\255\\001\\000\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\004\\000\\\n \\003\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\001\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\003\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\";\n Lexing.lex_default =\n \"\\001\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\057\\000\\060\\000\\000\\000\\060\\000\\000\\000\\000\\000\\065\\000\\\n \\000\\000\\065\\000\\000\\000\\000\\000\\070\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\084\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\094\\000\\000\\000\\000\\000\\097\\000\\255\\255\\\n \\255\\255\\097\\000\\255\\255\\255\\255\\255\\255\\255\\255\\104\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\109\\000\\000\\000\\000\\000\\000\\000\\113\\000\\\n \\000\\000\\000\\000\\000\\000\\117\\000\\000\\000\\000\\000\\000\\000\\121\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\126\\000\\000\\000\\000\\000\\\n \\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\000\\000\\138\\000\\000\\000\\142\\000\\000\\000\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\154\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\178\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\\n \\255\\255\\187\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\\n \\194\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\201\\000\\\n \\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\235\\000\\000\\000\\000\\000\\000\\000\\239\\000\\000\\000\\000\\000\\\n \\255\\255\\000\\000\\244\\000\\000\\000\\000\\000\\255\\255\\000\\000\\249\\000\\\n \\000\\000\\000\\000\\000\\000\\253\\000\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\003\\001\\000\\000\\000\\000\\000\\000\\000\\000\\008\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\017\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\022\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\028\\001\\000\\000\\000\\000\\000\\000\\032\\001\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\038\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\043\\001\\000\\000\\000\\000\\000\\000\\047\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\052\\001\\000\\000\\000\\000\\000\\000\\056\\001\\000\\000\\\n \\000\\000\\000\\000\\060\\001\\000\\000\\000\\000\\000\\000\\064\\001\\000\\000\\\n \\000\\000\\000\\000\\067\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\000\\000\\255\\255\\\n \\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\121\\001\\125\\001\\000\\000\\000\\000\\128\\001\\255\\255\\255\\255\\\n \\128\\001\\255\\255\\255\\255\\255\\255\\255\\255\\135\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\140\\001\\000\\000\\000\\000\\255\\255\\000\\000\\144\\001\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\193\\001\\197\\001\\000\\000\\000\\000\\200\\001\\255\\255\\255\\255\\\n \\200\\001\\255\\255\\255\\255\\255\\255\\255\\255\\207\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\212\\001\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\\n \\255\\255\\000\\000\\255\\255\\000\\000\\220\\001\\000\\000\\255\\255\\000\\000\\\n \\226\\001\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\233\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\240\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\245\\001\\000\\000\\000\\000\\000\\000\\249\\001\\\n \\000\\000\\000\\000\\000\\000\\252\\001\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\002\\002\\004\\002\\000\\000\\005\\002\\006\\002\\007\\002\\008\\002\\\n \\009\\002\\010\\002\\011\\002\\012\\002\\013\\002\\014\\002\\015\\002\\016\\002\\\n \\017\\002\\018\\002\\019\\002\\020\\002\\021\\002\\022\\002\\023\\002\\024\\002\\\n \\025\\002\\026\\002\\027\\002\\028\\002\\029\\002\\030\\002\\031\\002\\032\\002\\\n \\033\\002\\003\\002\";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\003\\000\\004\\000\\000\\000\\003\\000\\003\\000\\134\\000\\000\\000\\\n \\003\\000\\000\\000\\134\\000\\069\\001\\146\\001\\255\\255\\000\\000\\069\\001\\\n \\146\\001\\000\\000\\000\\000\\000\\000\\000\\000\\127\\000\\139\\000\\000\\000\\\n \\003\\000\\000\\000\\012\\000\\003\\000\\170\\000\\134\\000\\175\\000\\000\\000\\\n \\007\\000\\011\\001\\069\\001\\146\\001\\014\\001\\013\\000\\049\\000\\005\\000\\\n \\010\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\011\\000\\056\\000\\118\\000\\006\\000\\129\\000\\130\\000\\057\\000\\\n \\237\\001\\137\\000\\000\\002\\049\\000\\000\\000\\048\\000\\138\\000\\106\\000\\\n \\062\\000\\014\\000\\110\\000\\105\\000\\000\\000\\049\\000\\015\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\030\\000\\048\\000\\008\\000\\114\\000\\209\\000\\236\\000\\000\\001\\\n \\013\\001\\029\\000\\022\\000\\255\\255\\048\\000\\048\\000\\017\\000\\021\\000\\\n \\025\\000\\032\\000\\033\\000\\035\\000\\023\\000\\027\\000\\016\\000\\031\\000\\\n \\028\\000\\034\\000\\019\\000\\024\\000\\018\\000\\026\\000\\020\\000\\036\\000\\\n \\041\\000\\037\\000\\048\\000\\009\\000\\042\\000\\043\\000\\044\\000\\045\\000\\\n \\046\\000\\047\\000\\061\\000\\085\\000\\048\\000\\038\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\049\\000\\\n \\067\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\086\\000\\143\\000\\255\\255\\040\\000\\144\\000\\\n \\145\\000\\146\\000\\055\\000\\148\\000\\055\\000\\149\\000\\048\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\255\\255\\048\\000\\150\\000\\\n \\151\\000\\161\\000\\066\\000\\158\\000\\053\\000\\159\\000\\053\\000\\160\\000\\\n \\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\165\\000\\\n \\051\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\162\\000\\163\\000\\166\\000\\093\\000\\255\\255\\\n \\002\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\255\\255\\077\\000\\103\\000\\108\\000\\116\\000\\\n \\132\\000\\134\\000\\135\\000\\128\\000\\139\\000\\134\\000\\164\\000\\093\\000\\\n \\171\\000\\077\\000\\167\\000\\168\\000\\169\\000\\172\\000\\112\\000\\173\\000\\\n \\174\\000\\210\\000\\226\\000\\208\\000\\211\\000\\212\\000\\059\\000\\083\\000\\\n \\134\\000\\213\\000\\214\\000\\215\\000\\216\\000\\218\\000\\141\\000\\219\\000\\\n \\093\\000\\220\\000\\221\\000\\123\\000\\222\\000\\223\\000\\224\\000\\136\\000\\\n \\095\\000\\225\\000\\035\\001\\065\\001\\234\\000\\155\\000\\005\\001\\097\\001\\\n \\250\\000\\255\\255\\254\\000\\057\\001\\061\\001\\095\\001\\077\\000\\044\\001\\\n \\092\\001\\088\\001\\009\\001\\029\\001\\076\\000\\124\\000\\033\\001\\018\\001\\\n \\075\\000\\098\\000\\019\\001\\085\\001\\086\\001\\087\\001\\120\\001\\089\\001\\\n \\074\\000\\225\\000\\053\\001\\121\\001\\073\\000\\090\\001\\072\\000\\071\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\098\\000\\113\\001\\122\\000\\091\\001\\064\\000\\004\\001\\\n \\093\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\079\\000\\156\\000\\112\\001\\094\\001\\096\\001\\098\\001\\099\\001\\049\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\100\\001\\157\\000\\\n \\101\\001\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\183\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\184\\000\\024\\001\\112\\001\\255\\255\\025\\001\\102\\001\\103\\001\\105\\001\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\\n \\106\\001\\107\\001\\048\\001\\040\\001\\108\\001\\109\\001\\110\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\081\\000\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\081\\000\\111\\001\\\n \\027\\001\\255\\255\\171\\001\\031\\001\\170\\001\\023\\001\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\092\\000\\168\\001\\063\\001\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\248\\000\\165\\001\\252\\000\\\n \\162\\001\\059\\001\\069\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\255\\255\\081\\000\\081\\000\\\n \\081\\000\\081\\000\\081\\000\\081\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\039\\001\\042\\001\\255\\255\\163\\001\\\n \\164\\001\\120\\000\\002\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\166\\001\\055\\001\\153\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\007\\001\\167\\001\\164\\001\\169\\001\\016\\001\\164\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\089\\000\\051\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\090\\000\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\\n \\090\\000\\097\\000\\137\\001\\164\\001\\172\\001\\185\\001\\136\\001\\173\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\097\\000\\179\\000\\\n \\174\\001\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\046\\001\\\n \\175\\001\\176\\001\\180\\000\\164\\001\\184\\001\\181\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\124\\001\\\n \\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\090\\000\\192\\001\\178\\001\\\n \\021\\001\\179\\001\\097\\000\\193\\001\\180\\001\\181\\001\\182\\001\\183\\001\\\n \\164\\001\\216\\001\\255\\255\\097\\000\\184\\001\\216\\001\\209\\001\\097\\000\\\n \\223\\001\\097\\000\\208\\001\\230\\001\\003\\002\\097\\000\\219\\001\\037\\001\\\n \\216\\001\\217\\001\\003\\002\\220\\001\\216\\001\\097\\000\\003\\002\\003\\002\\\n \\216\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\216\\001\\\n \\003\\002\\126\\001\\003\\002\\003\\002\\003\\002\\003\\002\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\097\\000\\003\\002\\218\\001\\250\\001\\\n \\003\\002\\003\\002\\097\\000\\003\\002\\124\\001\\124\\001\\097\\000\\003\\002\\\n \\221\\001\\003\\002\\253\\001\\003\\002\\003\\002\\003\\002\\097\\000\\255\\255\\\n \\003\\002\\196\\001\\097\\000\\003\\002\\097\\000\\096\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\235\\001\\003\\002\\\n \\241\\001\\003\\002\\255\\001\\242\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\246\\001\\129\\001\\129\\001\\\n \\228\\001\\003\\002\\196\\001\\003\\002\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\003\\002\\198\\001\\003\\002\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\003\\002\\003\\002\\003\\002\\196\\001\\234\\001\\\n \\134\\001\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\097\\000\\097\\000\\097\\000\\000\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\000\\000\\000\\000\\201\\001\\177\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\188\\000\\000\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\097\\000\\\n \\201\\001\\227\\001\\000\\000\\191\\000\\206\\001\\123\\001\\189\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\189\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\195\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\198\\000\\\n \\255\\255\\248\\001\\196\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\196\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\202\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\227\\000\\205\\000\\255\\255\\255\\255\\203\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\226\\000\\195\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\232\\001\\000\\000\\000\\000\\206\\000\\221\\001\\239\\001\\\n \\254\\001\\000\\000\\207\\000\\244\\001\\000\\000\\225\\000\\203\\000\\204\\000\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\232\\000\\000\\000\\232\\000\\000\\000\\225\\001\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\217\\000\\\n \\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\225\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\000\\000\\230\\000\\\n \\000\\000\\230\\000\\000\\000\\228\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\000\\000\\228\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\186\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\241\\000\\000\\000\\\n \\113\\001\\000\\000\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\000\\000\\112\\001\\\n \\000\\000\\000\\000\\193\\000\\000\\000\\000\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\112\\001\\\n \\000\\000\\000\\000\\000\\000\\240\\000\\200\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\000\\000\\246\\000\\000\\000\\000\\000\\240\\000\\000\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\245\\000\\000\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\238\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\245\\000\\000\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\069\\001\\070\\001\\000\\000\\000\\000\\069\\001\\076\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\069\\001\\\n \\000\\000\\078\\001\\000\\000\\000\\000\\000\\000\\000\\000\\104\\001\\073\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\079\\001\\000\\000\\071\\001\\076\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\000\\000\\000\\000\\072\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\243\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\080\\001\\119\\001\\000\\000\\119\\001\\000\\000\\081\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\000\\000\\000\\000\\074\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\083\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\082\\001\\000\\000\\000\\000\\\n \\115\\001\\000\\000\\000\\000\\084\\001\\000\\000\\000\\000\\117\\001\\000\\000\\\n \\117\\001\\000\\000\\075\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\000\\000\\\n \\115\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\000\\000\\\n \\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\\n \\000\\000\\185\\001\\000\\000\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\\n \\184\\001\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\128\\001\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\128\\001\\128\\001\\000\\000\\000\\000\\068\\001\\\n \\128\\001\\128\\001\\128\\001\\127\\001\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\184\\001\\000\\000\\000\\000\\000\\000\\000\\000\\128\\001\\000\\000\\000\\000\\\n \\000\\000\\128\\001\\000\\000\\128\\001\\127\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\000\\000\\000\\000\\000\\000\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\128\\001\\128\\001\\128\\001\\000\\000\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\191\\001\\142\\001\\191\\001\\000\\000\\000\\000\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\000\\000\\128\\001\\128\\001\\128\\001\\128\\001\\128\\001\\\n \\128\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\\n \\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\141\\001\\000\\000\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\146\\001\\147\\001\\\n \\000\\000\\000\\000\\146\\001\\154\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\146\\001\\000\\000\\153\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\177\\001\\150\\001\\000\\000\\000\\000\\\n \\000\\000\\200\\001\\156\\001\\000\\000\\148\\001\\154\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\000\\000\\\n \\000\\000\\149\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\139\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\157\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\158\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\200\\001\\000\\000\\\n \\151\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\187\\001\\000\\000\\160\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\159\\001\\200\\001\\000\\000\\200\\001\\199\\001\\\n \\000\\000\\161\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\152\\001\\000\\000\\000\\000\\000\\000\\000\\000\\189\\001\\000\\000\\189\\001\\\n \\000\\000\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\145\\001\\200\\001\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\200\\001\\000\\000\\000\\000\\000\\000\\200\\001\\000\\000\\\n \\200\\001\\199\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\000\\000\\000\\000\\000\\000\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\200\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\\n \\200\\001\\000\\000\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\000\\000\\214\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\200\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\000\\000\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\213\\001\\\n \\000\\000\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\211\\001\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\000\\000\\255\\255\\003\\000\\000\\000\\134\\000\\255\\255\\\n \\003\\000\\255\\255\\134\\000\\069\\001\\146\\001\\057\\000\\255\\255\\069\\001\\\n \\146\\001\\255\\255\\255\\255\\255\\255\\255\\255\\125\\000\\138\\000\\255\\255\\\n \\000\\000\\255\\255\\000\\000\\003\\000\\169\\000\\134\\000\\174\\000\\255\\255\\\n \\000\\000\\010\\001\\069\\001\\146\\001\\012\\001\\000\\000\\010\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\005\\000\\115\\000\\000\\000\\125\\000\\129\\000\\005\\000\\\n \\236\\001\\136\\000\\255\\001\\038\\000\\255\\255\\010\\000\\136\\000\\102\\000\\\n \\058\\000\\000\\000\\107\\000\\102\\000\\255\\255\\011\\000\\000\\000\\011\\000\\\n \\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\011\\000\\\n \\011\\000\\029\\000\\038\\000\\000\\000\\111\\000\\208\\000\\233\\000\\255\\000\\\n \\012\\001\\015\\000\\017\\000\\060\\000\\011\\000\\010\\000\\000\\000\\020\\000\\\n \\024\\000\\031\\000\\032\\000\\034\\000\\022\\000\\026\\000\\000\\000\\014\\000\\\n \\027\\000\\033\\000\\018\\000\\023\\000\\000\\000\\016\\000\\019\\000\\035\\000\\\n \\040\\000\\036\\000\\038\\000\\000\\000\\041\\000\\042\\000\\043\\000\\044\\000\\\n \\045\\000\\046\\000\\058\\000\\082\\000\\011\\000\\013\\000\\013\\000\\013\\000\\\n \\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\013\\000\\039\\000\\\n \\063\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\085\\000\\140\\000\\060\\000\\013\\000\\143\\000\\\n \\144\\000\\145\\000\\048\\000\\147\\000\\048\\000\\148\\000\\039\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\065\\000\\039\\000\\149\\000\\\n \\150\\000\\156\\000\\063\\000\\157\\000\\051\\000\\158\\000\\051\\000\\159\\000\\\n \\050\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\155\\000\\\n \\050\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\161\\000\\162\\000\\155\\000\\091\\000\\065\\000\\\n \\000\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\057\\000\\068\\000\\102\\000\\107\\000\\115\\000\\\n \\131\\000\\133\\000\\133\\000\\125\\000\\138\\000\\133\\000\\163\\000\\094\\000\\\n \\165\\000\\068\\000\\166\\000\\167\\000\\168\\000\\171\\000\\111\\000\\172\\000\\\n \\173\\000\\206\\000\\203\\000\\207\\000\\210\\000\\211\\000\\058\\000\\082\\000\\\n \\133\\000\\212\\000\\213\\000\\214\\000\\215\\000\\217\\000\\140\\000\\218\\000\\\n \\097\\000\\219\\000\\220\\000\\119\\000\\221\\000\\222\\000\\223\\000\\133\\000\\\n \\091\\000\\203\\000\\034\\001\\062\\001\\233\\000\\152\\000\\001\\001\\080\\001\\\n \\247\\000\\060\\000\\251\\000\\054\\001\\058\\001\\081\\001\\068\\000\\041\\001\\\n \\082\\001\\083\\001\\006\\001\\026\\001\\068\\000\\119\\000\\030\\001\\015\\001\\\n \\068\\000\\094\\000\\015\\001\\084\\001\\085\\001\\086\\001\\071\\001\\088\\001\\\n \\068\\000\\203\\000\\050\\001\\071\\001\\068\\000\\089\\001\\068\\000\\068\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\097\\000\\076\\001\\119\\000\\090\\001\\063\\000\\001\\001\\\n \\092\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\152\\000\\076\\001\\093\\001\\095\\001\\097\\001\\098\\001\\045\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\099\\001\\152\\000\\\n \\100\\001\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\180\\000\\\n \\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\180\\000\\\n \\180\\000\\020\\001\\076\\001\\065\\000\\020\\001\\101\\001\\102\\001\\104\\001\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\079\\000\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\\n \\105\\001\\106\\001\\045\\001\\036\\001\\107\\001\\108\\001\\109\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\080\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\080\\000\\110\\001\\\n \\026\\001\\121\\001\\157\\001\\030\\001\\158\\001\\020\\001\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\091\\000\\159\\001\\062\\001\\079\\000\\\n \\079\\000\\079\\000\\079\\000\\079\\000\\079\\000\\247\\000\\160\\001\\251\\000\\\n \\161\\001\\058\\001\\068\\000\\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\086\\000\\086\\000\\086\\000\\094\\000\\080\\000\\080\\000\\\n \\080\\000\\080\\000\\080\\000\\080\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\087\\000\\087\\000\\087\\000\\036\\001\\041\\001\\097\\000\\162\\001\\\n \\163\\001\\119\\000\\001\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\165\\001\\054\\001\\152\\000\\086\\000\\086\\000\\086\\000\\086\\000\\\n \\086\\000\\086\\000\\006\\001\\166\\001\\167\\001\\168\\001\\015\\001\\169\\001\\\n \\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\\n \\088\\000\\088\\000\\050\\001\\087\\000\\087\\000\\087\\000\\087\\000\\087\\000\\\n \\087\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\089\\000\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\\n \\089\\000\\095\\000\\133\\001\\170\\001\\171\\001\\154\\001\\133\\001\\172\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\095\\000\\176\\000\\\n \\173\\001\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\088\\000\\045\\001\\\n \\174\\001\\175\\001\\176\\000\\176\\001\\154\\001\\176\\000\\176\\000\\176\\000\\\n \\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\176\\000\\122\\001\\\n \\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\089\\000\\148\\001\\177\\001\\\n \\020\\001\\178\\001\\098\\000\\148\\001\\179\\001\\180\\001\\181\\001\\182\\001\\\n \\183\\001\\216\\001\\193\\001\\095\\000\\154\\001\\216\\001\\205\\001\\098\\000\\\n \\222\\001\\095\\000\\205\\001\\229\\001\\001\\002\\095\\000\\218\\001\\036\\001\\\n \\215\\001\\215\\001\\002\\002\\218\\001\\215\\001\\095\\000\\004\\002\\005\\002\\\n \\216\\001\\095\\000\\006\\002\\095\\000\\095\\000\\096\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\096\\000\\215\\001\\\n \\007\\002\\122\\001\\008\\002\\009\\002\\010\\002\\011\\002\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\098\\000\\012\\002\\215\\001\\247\\001\\\n \\013\\002\\014\\002\\098\\000\\015\\002\\125\\001\\128\\001\\098\\000\\016\\002\\\n \\220\\001\\017\\002\\251\\001\\018\\002\\019\\002\\020\\002\\098\\000\\121\\001\\\n \\021\\002\\194\\001\\098\\000\\022\\002\\098\\000\\098\\000\\096\\000\\096\\000\\\n \\096\\000\\096\\000\\096\\000\\096\\000\\099\\000\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\099\\000\\231\\001\\023\\002\\\n \\238\\001\\024\\002\\251\\001\\238\\001\\025\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\100\\000\\100\\000\\100\\000\\243\\001\\125\\001\\128\\001\\\n \\224\\001\\026\\002\\197\\001\\027\\002\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\028\\002\\194\\001\\029\\002\\099\\000\\099\\000\\099\\000\\\n \\099\\000\\099\\000\\099\\000\\030\\002\\031\\002\\032\\002\\200\\001\\231\\001\\\n \\133\\001\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\101\\000\\101\\000\\101\\000\\255\\255\\100\\000\\100\\000\\100\\000\\100\\000\\\n \\100\\000\\100\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\182\\000\\\n \\182\\000\\182\\000\\255\\255\\255\\255\\197\\001\\176\\000\\184\\000\\184\\000\\\n \\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\184\\000\\\n \\185\\000\\255\\255\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\101\\000\\\n \\200\\001\\224\\001\\255\\255\\185\\000\\205\\001\\122\\001\\185\\000\\185\\000\\\n \\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\185\\000\\\n \\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\190\\000\\\n \\190\\000\\190\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\191\\000\\\n \\191\\000\\191\\000\\191\\000\\191\\000\\192\\000\\197\\000\\197\\000\\197\\000\\\n \\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\197\\000\\192\\000\\\n \\193\\001\\247\\001\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\192\\000\\\n \\192\\000\\192\\000\\192\\000\\192\\000\\198\\000\\198\\000\\198\\000\\198\\000\\\n \\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\198\\000\\199\\000\\226\\000\\\n \\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\226\\000\\\n \\226\\000\\199\\000\\125\\001\\128\\001\\199\\000\\199\\000\\199\\000\\199\\000\\\n \\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\199\\000\\204\\000\\194\\001\\\n \\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\204\\000\\\n \\204\\000\\204\\000\\231\\001\\255\\255\\255\\255\\199\\000\\220\\001\\238\\001\\\n \\251\\001\\255\\255\\199\\000\\243\\001\\255\\255\\204\\000\\205\\000\\205\\000\\\n \\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\205\\000\\\n \\225\\000\\255\\255\\225\\000\\255\\255\\224\\001\\225\\000\\225\\000\\225\\000\\\n \\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\225\\000\\205\\000\\\n \\197\\001\\255\\255\\255\\255\\255\\255\\255\\255\\204\\000\\227\\000\\227\\000\\\n \\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\227\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\200\\001\\255\\255\\255\\255\\228\\000\\\n \\255\\255\\228\\000\\255\\255\\227\\000\\228\\000\\228\\000\\228\\000\\228\\000\\\n \\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\228\\000\\229\\000\\229\\000\\\n \\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\229\\000\\\n \\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\230\\000\\\n \\230\\000\\230\\000\\255\\255\\227\\000\\231\\000\\231\\000\\231\\000\\231\\000\\\n \\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\231\\000\\185\\000\\232\\000\\\n \\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\232\\000\\\n \\232\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\237\\000\\255\\255\\\n \\077\\001\\255\\255\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\077\\001\\\n \\077\\001\\077\\001\\077\\001\\077\\001\\113\\001\\113\\001\\113\\001\\113\\001\\\n \\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\113\\001\\255\\255\\077\\001\\\n \\255\\255\\255\\255\\192\\000\\255\\255\\255\\255\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\077\\001\\\n \\255\\255\\255\\255\\255\\255\\237\\000\\199\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\\n \\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\237\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\255\\255\\242\\000\\255\\255\\255\\255\\240\\000\\255\\255\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\240\\000\\\n \\240\\000\\240\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\242\\000\\255\\255\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\242\\000\\\n \\242\\000\\242\\000\\242\\000\\242\\000\\237\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\245\\000\\255\\255\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\245\\000\\\n \\066\\001\\066\\001\\255\\255\\255\\255\\066\\001\\079\\001\\079\\001\\079\\001\\\n \\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\079\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\\n \\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\079\\001\\066\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\066\\001\\066\\001\\\n \\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\066\\001\\\n \\066\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\242\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\066\\001\\112\\001\\255\\255\\112\\001\\255\\255\\066\\001\\112\\001\\112\\001\\\n \\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\112\\001\\\n \\255\\255\\255\\255\\066\\001\\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\\n \\114\\001\\114\\001\\114\\001\\114\\001\\114\\001\\066\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\\n \\114\\001\\255\\255\\255\\255\\066\\001\\255\\255\\255\\255\\115\\001\\255\\255\\\n \\115\\001\\255\\255\\066\\001\\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\\n \\115\\001\\115\\001\\115\\001\\115\\001\\115\\001\\116\\001\\116\\001\\116\\001\\\n \\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\116\\001\\255\\255\\\n \\114\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\117\\001\\\n \\117\\001\\117\\001\\117\\001\\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\\n \\118\\001\\118\\001\\118\\001\\118\\001\\118\\001\\119\\001\\119\\001\\119\\001\\\n \\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\119\\001\\255\\255\\\n \\126\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\127\\001\\127\\001\\127\\001\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\\n \\255\\255\\155\\001\\255\\255\\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\\n \\155\\001\\155\\001\\155\\001\\155\\001\\155\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\127\\001\\\n \\155\\001\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\126\\001\\255\\255\\255\\255\\255\\255\\126\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\129\\001\\126\\001\\255\\255\\255\\255\\066\\001\\\n \\126\\001\\129\\001\\126\\001\\126\\001\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\155\\001\\255\\255\\255\\255\\255\\255\\255\\255\\129\\001\\255\\255\\255\\255\\\n \\255\\255\\129\\001\\255\\255\\129\\001\\129\\001\\130\\001\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\131\\001\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\255\\255\\255\\255\\255\\255\\130\\001\\130\\001\\\n \\130\\001\\130\\001\\130\\001\\130\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\132\\001\\132\\001\\132\\001\\255\\255\\131\\001\\131\\001\\131\\001\\\n \\131\\001\\131\\001\\131\\001\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\184\\001\\138\\001\\184\\001\\255\\255\\255\\255\\184\\001\\184\\001\\\n \\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\184\\001\\\n \\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\185\\001\\\n \\185\\001\\185\\001\\255\\255\\132\\001\\132\\001\\132\\001\\132\\001\\132\\001\\\n \\132\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\138\\001\\\n \\255\\255\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\138\\001\\\n \\138\\001\\138\\001\\138\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\141\\001\\255\\255\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\\n \\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\141\\001\\143\\001\\143\\001\\\n \\255\\255\\255\\255\\143\\001\\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\\n \\156\\001\\156\\001\\156\\001\\156\\001\\156\\001\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\156\\001\\143\\001\\255\\255\\255\\255\\\n \\255\\255\\198\\001\\143\\001\\255\\255\\143\\001\\143\\001\\143\\001\\143\\001\\\n \\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\143\\001\\255\\255\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\138\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\143\\001\\186\\001\\186\\001\\186\\001\\186\\001\\\n \\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\186\\001\\198\\001\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\198\\001\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\186\\001\\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\198\\001\\255\\255\\255\\255\\143\\001\\198\\001\\255\\255\\198\\001\\198\\001\\\n \\255\\255\\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\143\\001\\255\\255\\255\\255\\255\\255\\255\\255\\187\\001\\255\\255\\187\\001\\\n \\255\\255\\186\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\187\\001\\\n \\187\\001\\187\\001\\187\\001\\187\\001\\188\\001\\188\\001\\188\\001\\188\\001\\\n \\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\188\\001\\189\\001\\189\\001\\\n \\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\189\\001\\\n \\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\190\\001\\\n \\190\\001\\190\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\191\\001\\\n \\191\\001\\191\\001\\191\\001\\191\\001\\199\\001\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\199\\001\\199\\001\\199\\001\\\n \\199\\001\\199\\001\\199\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\143\\001\\201\\001\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\201\\001\\255\\255\\255\\255\\255\\255\\201\\001\\255\\255\\\n \\201\\001\\201\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\202\\001\\202\\001\\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\203\\001\\203\\001\\203\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\255\\255\\255\\255\\255\\255\\202\\001\\202\\001\\202\\001\\202\\001\\202\\001\\\n \\202\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\204\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\\n \\204\\001\\255\\255\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\203\\001\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\255\\255\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\204\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\210\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\213\\001\\\n \\255\\255\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\213\\001\\\n \\213\\001\\213\\001\\213\\001\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\210\\001\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec read_json v lexbuf =\n __ocaml_lex_read_json_rec v lexbuf 0\nand __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 188 \"lib/read.mll\"\n \n# 188 \"lib/read.mll\"\n ( `Bool true )\n\n# 1032 \"lib/read.ml\"\n\n \n# 1033 \"lib/read.ml\"\n | 1 ->\n\n# 189 \"lib/read.mll\"\n \n# 189 \"lib/read.mll\"\n ( `Bool false )\n\n# 1037 \"lib/read.ml\"\n\n \n# 1038 \"lib/read.ml\"\n | 2 ->\n\n# 190 \"lib/read.mll\"\n \n# 190 \"lib/read.mll\"\n ( `Null )\n\n# 1042 \"lib/read.ml\"\n\n \n# 1043 \"lib/read.ml\"\n | 3 ->\n\n# 191 \"lib/read.mll\"\n \n# 191 \"lib/read.mll\"\n (\n \n# 195 \"lib/read.mll\"\n `Floatlit \"NaN\"\n \n# 197 \"lib/read.mll\"\n )\n\n# 1053 \"lib/read.ml\"\n\n \n# 1054 \"lib/read.ml\"\n | 4 ->\n\n# 198 \"lib/read.mll\"\n \n# 198 \"lib/read.mll\"\n (\n \n# 202 \"lib/read.mll\"\n `Floatlit \"Infinity\"\n \n# 204 \"lib/read.mll\"\n )\n\n# 1064 \"lib/read.ml\"\n\n \n# 1065 \"lib/read.ml\"\n | 5 ->\n\n# 205 \"lib/read.mll\"\n \n# 205 \"lib/read.mll\"\n (\n \n# 209 \"lib/read.mll\"\n `Floatlit \"-Infinity\"\n \n# 211 \"lib/read.mll\"\n )\n\n# 1075 \"lib/read.ml\"\n\n \n# 1076 \"lib/read.ml\"\n | 6 ->\n\n# 212 \"lib/read.mll\"\n \n# 212 \"lib/read.mll\"\n (\n \n# 217 \"lib/read.mll\"\n `Stringlit (finish_stringlit v lexbuf)\n \n# 219 \"lib/read.mll\"\n )\n\n# 1087 \"lib/read.ml\"\n\n \n# 1088 \"lib/read.ml\"\n | 7 ->\n\n# 220 \"lib/read.mll\"\n \n# 220 \"lib/read.mll\"\n ( make_positive_int v lexbuf )\n\n# 1092 \"lib/read.ml\"\n\n \n# 1093 \"lib/read.ml\"\n | 8 ->\n\n# 221 \"lib/read.mll\"\n \n# 221 \"lib/read.mll\"\n ( make_negative_int v lexbuf )\n\n# 1097 \"lib/read.ml\"\n\n \n# 1098 \"lib/read.ml\"\n | 9 ->\n\n# 222 \"lib/read.mll\"\n \n# 222 \"lib/read.mll\"\n (\n \n# 226 \"lib/read.mll\"\n `Floatlit (lexeme lexbuf)\n \n# 228 \"lib/read.mll\"\n )\n\n# 1108 \"lib/read.ml\"\n\n \n# 1109 \"lib/read.ml\"\n | 10 ->\n\n# 230 \"lib/read.mll\"\n \n# 230 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_ident v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := (field_name, read_json v lexbuf) :: !acc;\n done;\n assert false\n with End_of_object ->\n `Assoc (List.rev !acc)\n )\n\n# 1135 \"lib/read.ml\"\n\n \n# 1136 \"lib/read.ml\"\n | 11 ->\n\n# 254 \"lib/read.mll\"\n \n# 254 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_json v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_json v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n `List (List.rev !acc)\n )\n\n# 1154 \"lib/read.ml\"\n\n \n# 1155 \"lib/read.ml\"\n | 12 ->\n\n# 270 \"lib/read.mll\"\n \n# 270 \"lib/read.mll\"\n (\n \n# 272 \"lib/read.mll\"\n let acc = ref [] in\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n acc := read_json v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n acc := read_json v lexbuf :: !acc;\n done;\n assert false\n with End_of_tuple ->\n `Tuple (List.rev !acc)\n \n# 289 \"lib/read.mll\"\n )\n\n# 1178 \"lib/read.ml\"\n\n \n# 1179 \"lib/read.ml\"\n | 13 ->\n\n# 291 \"lib/read.mll\"\n \n# 291 \"lib/read.mll\"\n (\n \n# 293 \"lib/read.mll\"\n read_space v lexbuf;\n let cons = read_ident v lexbuf in\n read_space v lexbuf;\n `Variant (cons, finish_variant v lexbuf)\n \n# 300 \"lib/read.mll\"\n )\n\n# 1192 \"lib/read.ml\"\n\n \n# 1193 \"lib/read.ml\"\n | 14 ->\n\n# 302 \"lib/read.mll\"\n \n# 302 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1197 \"lib/read.ml\"\n\n \n# 1198 \"lib/read.ml\"\n | 15 ->\n\n# 303 \"lib/read.mll\"\n \n# 303 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_json v lexbuf )\n\n# 1202 \"lib/read.ml\"\n\n \n# 1203 \"lib/read.ml\"\n | 16 ->\n\n# 304 \"lib/read.mll\"\n \n# 304 \"lib/read.mll\"\n ( newline v lexbuf; read_json v lexbuf )\n\n# 1207 \"lib/read.ml\"\n\n \n# 1208 \"lib/read.ml\"\n | 17 ->\n\n# 305 \"lib/read.mll\"\n \n# 305 \"lib/read.mll\"\n ( read_json v lexbuf )\n\n# 1212 \"lib/read.ml\"\n\n \n# 1213 \"lib/read.ml\"\n | 18 ->\n\n# 306 \"lib/read.mll\"\n \n# 306 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1217 \"lib/read.ml\"\n\n \n# 1218 \"lib/read.ml\"\n | 19 ->\n\n# 307 \"lib/read.mll\"\n \n# 307 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 1222 \"lib/read.ml\"\n\n \n# 1223 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_json_rec v lexbuf __ocaml_lex_state\n\nand finish_string v lexbuf =\n __ocaml_lex_finish_string_rec v lexbuf 58\nand __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 311 \"lib/read.mll\"\n \n# 311 \"lib/read.mll\"\n ( Bi_outbuf.contents v.buf )\n\n# 1234 \"lib/read.ml\"\n\n \n# 1235 \"lib/read.ml\"\n | 1 ->\n\n# 312 \"lib/read.mll\"\n \n# 312 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n finish_string v lexbuf )\n\n# 1240 \"lib/read.ml\"\n\n \n# 1241 \"lib/read.ml\"\n | 2 ->\n\n# 314 \"lib/read.mll\"\n \n# 314 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n finish_string v lexbuf )\n\n# 1246 \"lib/read.ml\"\n\n \n# 1247 \"lib/read.ml\"\n | 3 ->\n\n# 316 \"lib/read.mll\"\n \n# 316 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1251 \"lib/read.ml\"\n\n \n# 1252 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_string_rec v lexbuf __ocaml_lex_state\n\nand map_string v f lexbuf =\n __ocaml_lex_map_string_rec v f lexbuf 63\nand __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 319 \"lib/read.mll\"\n \n# 319 \"lib/read.mll\"\n ( let b = v.buf in\n f (Bytes.to_string b.Bi_outbuf.o_s) 0 b.Bi_outbuf.o_len )\n\n# 1264 \"lib/read.ml\"\n\n \n# 1265 \"lib/read.ml\"\n | 1 ->\n\n# 321 \"lib/read.mll\"\n \n# 321 \"lib/read.mll\"\n ( finish_escaped_char v lexbuf;\n map_string v f lexbuf )\n\n# 1270 \"lib/read.ml\"\n\n \n# 1271 \"lib/read.ml\"\n | 2 ->\n\n# 323 \"lib/read.mll\"\n \n# 323 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf;\n map_string v f lexbuf )\n\n# 1276 \"lib/read.ml\"\n\n \n# 1277 \"lib/read.ml\"\n | 3 ->\n\n# 325 \"lib/read.mll\"\n \n# 325 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1281 \"lib/read.ml\"\n\n \n# 1282 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_string_rec v f lexbuf __ocaml_lex_state\n\nand finish_escaped_char v lexbuf =\n __ocaml_lex_finish_escaped_char_rec v lexbuf 68\nand __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n c\n\n# 1294 \"lib/read.ml\"\n# 1294 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf lexbuf.Lexing.lex_start_pos in\n\n# 330 \"lib/read.mll\"\n \n# 330 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf c )\n\n# 1298 \"lib/read.ml\"\n\n \n# 1299 \"lib/read.ml\"\n | 1 ->\n\n# 331 \"lib/read.mll\"\n \n# 331 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\b' )\n\n# 1303 \"lib/read.ml\"\n\n \n# 1304 \"lib/read.ml\"\n | 2 ->\n\n# 332 \"lib/read.mll\"\n \n# 332 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\012' )\n\n# 1308 \"lib/read.ml\"\n\n \n# 1309 \"lib/read.ml\"\n | 3 ->\n\n# 333 \"lib/read.mll\"\n \n# 333 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n' )\n\n# 1313 \"lib/read.ml\"\n\n \n# 1314 \"lib/read.ml\"\n | 4 ->\n\n# 334 \"lib/read.mll\"\n \n# 334 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\r' )\n\n# 1318 \"lib/read.ml\"\n\n \n# 1319 \"lib/read.ml\"\n | 5 ->\n\n# 335 \"lib/read.mll\"\n \n# 335 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\t' )\n\n# 1323 \"lib/read.ml\"\n\n \n# 1324 \"lib/read.ml\"\n | 6 ->\nlet\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n a\n\n# 1329 \"lib/read.ml\"\n# 1329 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 1)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n b\n\n# 1334 \"lib/read.ml\"\n# 1334 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n c\n\n# 1339 \"lib/read.ml\"\n# 1339 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 336 \"lib/read.mll\"\n \n# 336 \"lib/read.mll\"\n d\n\n# 1344 \"lib/read.ml\"\n# 1344 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4) in\n\n# 337 \"lib/read.mll\"\n \n# 337 \"lib/read.mll\"\n ( let x =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if x >= 0xD800 && x <= 0xDBFF then\n finish_surrogate_pair v x lexbuf\n else\n utf8_of_code v.buf x\n )\n\n# 1355 \"lib/read.ml\"\n\n \n# 1356 \"lib/read.ml\"\n | 7 ->\n\n# 345 \"lib/read.mll\"\n \n# 345 \"lib/read.mll\"\n ( long_error \"Invalid escape sequence\" v lexbuf )\n\n# 1360 \"lib/read.ml\"\n\n \n# 1361 \"lib/read.ml\"\n | 8 ->\n\n# 346 \"lib/read.mll\"\n \n# 346 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1365 \"lib/read.ml\"\n\n \n# 1366 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_escaped_char_rec v lexbuf __ocaml_lex_state\n\nand finish_surrogate_pair v x lexbuf =\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf 82\nand __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\nlet\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n a\n\n# 1378 \"lib/read.ml\"\n# 1378 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 2)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n b\n\n# 1383 \"lib/read.ml\"\n# 1383 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 3)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n c\n\n# 1388 \"lib/read.ml\"\n# 1388 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 4)\nand\n\n# 349 \"lib/read.mll\"\n \n# 349 \"lib/read.mll\"\n d\n\n# 1393 \"lib/read.ml\"\n# 1393 \"lib/read.ml\"\n= Lexing.sub_lexeme_char lexbuf (lexbuf.Lexing.lex_start_pos + 5) in\n\n# 350 \"lib/read.mll\"\n \n# 350 \"lib/read.mll\"\n ( let y =\n (hex a lsl 12) lor (hex b lsl 8) lor (hex c lsl 4) lor hex d\n in\n if y >= 0xDC00 && y <= 0xDFFF then\n utf8_of_surrogate_pair v.buf x y\n else\n long_error \"Invalid low surrogate for code point beyond U+FFFF\"\n v lexbuf\n )\n\n# 1405 \"lib/read.ml\"\n\n \n# 1406 \"lib/read.ml\"\n | 1 ->\n\n# 359 \"lib/read.mll\"\n \n# 359 \"lib/read.mll\"\n ( long_error \"Missing escape sequence representing low surrogate \\\n for code point beyond U+FFFF\" v lexbuf )\n\n# 1411 \"lib/read.ml\"\n\n \n# 1412 \"lib/read.ml\"\n | 2 ->\n\n# 361 \"lib/read.mll\"\n \n# 361 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1416 \"lib/read.ml\"\n\n \n# 1417 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_surrogate_pair_rec v x lexbuf __ocaml_lex_state\n\nand finish_stringlit v lexbuf =\n __ocaml_lex_finish_stringlit_rec v lexbuf 91\nand __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 366 \"lib/read.mll\"\n \n# 366 \"lib/read.mll\"\n ( let len = lexbuf.lex_curr_pos - lexbuf.lex_start_pos in\n let s = Bytes.create (len+1) in\n Bytes.set s 0 '\"';\n Bytes.blit lexbuf.lex_buffer lexbuf.lex_start_pos s 1 len;\n Bytes.to_string s\n )\n\n# 1433 \"lib/read.ml\"\n\n \n# 1434 \"lib/read.ml\"\n | 1 ->\n\n# 372 \"lib/read.mll\"\n \n# 372 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 1438 \"lib/read.ml\"\n\n \n# 1439 \"lib/read.ml\"\n | 2 ->\n\n# 373 \"lib/read.mll\"\n \n# 373 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1443 \"lib/read.ml\"\n\n \n# 1444 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_variant v lexbuf =\n __ocaml_lex_finish_variant_rec v lexbuf 102\nand __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 376 \"lib/read.mll\"\n \n# 376 \"lib/read.mll\"\n ( let x = read_json v lexbuf in\n read_space v lexbuf;\n read_gt v lexbuf;\n Some x )\n\n# 1458 \"lib/read.ml\"\n\n \n# 1459 \"lib/read.ml\"\n | 1 ->\n\n# 380 \"lib/read.mll\"\n \n# 380 \"lib/read.mll\"\n ( None )\n\n# 1463 \"lib/read.ml\"\n\n \n# 1464 \"lib/read.ml\"\n | 2 ->\n\n# 381 \"lib/read.mll\"\n \n# 381 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 1468 \"lib/read.ml\"\n\n \n# 1469 \"lib/read.ml\"\n | 3 ->\n\n# 382 \"lib/read.mll\"\n \n# 382 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1473 \"lib/read.ml\"\n\n \n# 1474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_variant_rec v lexbuf __ocaml_lex_state\n\nand read_lt v lexbuf =\n __ocaml_lex_read_lt_rec v lexbuf 107\nand __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 385 \"lib/read.mll\"\n \n# 385 \"lib/read.mll\"\n ( () )\n\n# 1485 \"lib/read.ml\"\n\n \n# 1486 \"lib/read.ml\"\n | 1 ->\n\n# 386 \"lib/read.mll\"\n \n# 386 \"lib/read.mll\"\n ( long_error \"Expected '<' but found\" v lexbuf )\n\n# 1490 \"lib/read.ml\"\n\n \n# 1491 \"lib/read.ml\"\n | 2 ->\n\n# 387 \"lib/read.mll\"\n \n# 387 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1495 \"lib/read.ml\"\n\n \n# 1496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lt_rec v lexbuf __ocaml_lex_state\n\nand read_gt v lexbuf =\n __ocaml_lex_read_gt_rec v lexbuf 111\nand __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 390 \"lib/read.mll\"\n \n# 390 \"lib/read.mll\"\n ( () )\n\n# 1507 \"lib/read.ml\"\n\n \n# 1508 \"lib/read.ml\"\n | 1 ->\n\n# 391 \"lib/read.mll\"\n \n# 391 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 1512 \"lib/read.ml\"\n\n \n# 1513 \"lib/read.ml\"\n | 2 ->\n\n# 392 \"lib/read.mll\"\n \n# 392 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1517 \"lib/read.ml\"\n\n \n# 1518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_gt_rec v lexbuf __ocaml_lex_state\n\nand read_comma v lexbuf =\n __ocaml_lex_read_comma_rec v lexbuf 115\nand __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 395 \"lib/read.mll\"\n \n# 395 \"lib/read.mll\"\n ( () )\n\n# 1529 \"lib/read.ml\"\n\n \n# 1530 \"lib/read.ml\"\n | 1 ->\n\n# 396 \"lib/read.mll\"\n \n# 396 \"lib/read.mll\"\n ( long_error \"Expected ',' but found\" v lexbuf )\n\n# 1534 \"lib/read.ml\"\n\n \n# 1535 \"lib/read.ml\"\n | 2 ->\n\n# 397 \"lib/read.mll\"\n \n# 397 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1539 \"lib/read.ml\"\n\n \n# 1540 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_comma_rec v lexbuf __ocaml_lex_state\n\nand start_any_variant v lexbuf =\n __ocaml_lex_start_any_variant_rec v lexbuf 119\nand __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 400 \"lib/read.mll\"\n \n# 400 \"lib/read.mll\"\n ( `Edgy_bracket )\n\n# 1551 \"lib/read.ml\"\n\n \n# 1552 \"lib/read.ml\"\n | 1 ->\n\n# 401 \"lib/read.mll\"\n \n# 401 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n `Double_quote )\n\n# 1557 \"lib/read.ml\"\n\n \n# 1558 \"lib/read.ml\"\n | 2 ->\n\n# 403 \"lib/read.mll\"\n \n# 403 \"lib/read.mll\"\n ( `Square_bracket )\n\n# 1562 \"lib/read.ml\"\n\n \n# 1563 \"lib/read.ml\"\n | 3 ->\n\n# 404 \"lib/read.mll\"\n \n# 404 \"lib/read.mll\"\n ( long_error \"Expected '<', '\\\"' or '[' but found\" v lexbuf )\n\n# 1567 \"lib/read.ml\"\n\n \n# 1568 \"lib/read.ml\"\n | 4 ->\n\n# 405 \"lib/read.mll\"\n \n# 405 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1572 \"lib/read.ml\"\n\n \n# 1573 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_variant_rec v lexbuf __ocaml_lex_state\n\nand finish_comment v lexbuf =\n __ocaml_lex_finish_comment_rec v lexbuf 125\nand __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 408 \"lib/read.mll\"\n \n# 408 \"lib/read.mll\"\n ( () )\n\n# 1584 \"lib/read.ml\"\n\n \n# 1585 \"lib/read.ml\"\n | 1 ->\n\n# 409 \"lib/read.mll\"\n \n# 409 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 1589 \"lib/read.ml\"\n\n \n# 1590 \"lib/read.ml\"\n | 2 ->\n\n# 410 \"lib/read.mll\"\n \n# 410 \"lib/read.mll\"\n ( newline v lexbuf; finish_comment v lexbuf )\n\n# 1594 \"lib/read.ml\"\n\n \n# 1595 \"lib/read.ml\"\n | 3 ->\n\n# 411 \"lib/read.mll\"\n \n# 411 \"lib/read.mll\"\n ( finish_comment v lexbuf )\n\n# 1599 \"lib/read.ml\"\n\n \n# 1600 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_comment_rec v lexbuf __ocaml_lex_state\n\nand read_eof lexbuf =\n __ocaml_lex_read_eof_rec lexbuf 131\nand __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 419 \"lib/read.mll\"\n \n# 419 \"lib/read.mll\"\n ( true )\n\n# 1611 \"lib/read.ml\"\n\n \n# 1612 \"lib/read.ml\"\n | 1 ->\n\n# 420 \"lib/read.mll\"\n \n# 420 \"lib/read.mll\"\n ( false )\n\n# 1616 \"lib/read.ml\"\n\n \n# 1617 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_eof_rec lexbuf __ocaml_lex_state\n\nand read_space v lexbuf =\n __ocaml_lex_read_space_rec v lexbuf 133\nand __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 423 \"lib/read.mll\"\n \n# 423 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1628 \"lib/read.ml\"\n\n \n# 1629 \"lib/read.ml\"\n | 1 ->\n\n# 424 \"lib/read.mll\"\n \n# 424 \"lib/read.mll\"\n ( finish_comment v lexbuf; read_space v lexbuf )\n\n# 1633 \"lib/read.ml\"\n\n \n# 1634 \"lib/read.ml\"\n | 2 ->\n\n# 425 \"lib/read.mll\"\n \n# 425 \"lib/read.mll\"\n ( newline v lexbuf; read_space v lexbuf )\n\n# 1638 \"lib/read.ml\"\n\n \n# 1639 \"lib/read.ml\"\n | 3 ->\n\n# 426 \"lib/read.mll\"\n \n# 426 \"lib/read.mll\"\n ( read_space v lexbuf )\n\n# 1643 \"lib/read.ml\"\n\n \n# 1644 \"lib/read.ml\"\n | 4 ->\n\n# 427 \"lib/read.mll\"\n \n# 427 \"lib/read.mll\"\n ( () )\n\n# 1648 \"lib/read.ml\"\n\n \n# 1649 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_space_rec v lexbuf __ocaml_lex_state\n\nand read_null v lexbuf =\n __ocaml_lex_read_null_rec v lexbuf 140\nand __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 430 \"lib/read.mll\"\n \n# 430 \"lib/read.mll\"\n ( () )\n\n# 1660 \"lib/read.ml\"\n\n \n# 1661 \"lib/read.ml\"\n | 1 ->\n\n# 431 \"lib/read.mll\"\n \n# 431 \"lib/read.mll\"\n ( long_error \"Expected 'null' but found\" v lexbuf )\n\n# 1665 \"lib/read.ml\"\n\n \n# 1666 \"lib/read.ml\"\n | 2 ->\n\n# 432 \"lib/read.mll\"\n \n# 432 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1670 \"lib/read.ml\"\n\n \n# 1671 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_rec v lexbuf __ocaml_lex_state\n\nand read_null_if_possible v lexbuf =\n __ocaml_lex_read_null_if_possible_rec v lexbuf 147\nand __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 435 \"lib/read.mll\"\n \n# 435 \"lib/read.mll\"\n ( true )\n\n# 1682 \"lib/read.ml\"\n\n \n# 1683 \"lib/read.ml\"\n | 1 ->\n\n# 436 \"lib/read.mll\"\n \n# 436 \"lib/read.mll\"\n ( false )\n\n# 1687 \"lib/read.ml\"\n\n \n# 1688 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_null_if_possible_rec v lexbuf __ocaml_lex_state\n\nand read_bool v lexbuf =\n __ocaml_lex_read_bool_rec v lexbuf 152\nand __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 439 \"lib/read.mll\"\n \n# 439 \"lib/read.mll\"\n ( true )\n\n# 1699 \"lib/read.ml\"\n\n \n# 1700 \"lib/read.ml\"\n | 1 ->\n\n# 440 \"lib/read.mll\"\n \n# 440 \"lib/read.mll\"\n ( false )\n\n# 1704 \"lib/read.ml\"\n\n \n# 1705 \"lib/read.ml\"\n | 2 ->\n\n# 443 \"lib/read.mll\"\n \n# 443 \"lib/read.mll\"\n ( true )\n\n# 1709 \"lib/read.ml\"\n\n \n# 1710 \"lib/read.ml\"\n | 3 ->\n\n# 444 \"lib/read.mll\"\n \n# 444 \"lib/read.mll\"\n ( false )\n\n# 1714 \"lib/read.ml\"\n\n \n# 1715 \"lib/read.ml\"\n | 4 ->\n\n# 446 \"lib/read.mll\"\n \n# 446 \"lib/read.mll\"\n ( long_error \"Expected 'true' or 'false' but found\" v lexbuf )\n\n# 1719 \"lib/read.ml\"\n\n \n# 1720 \"lib/read.ml\"\n | 5 ->\n\n# 447 \"lib/read.mll\"\n \n# 447 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1724 \"lib/read.ml\"\n\n \n# 1725 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_bool_rec v lexbuf __ocaml_lex_state\n\nand read_int v lexbuf =\n __ocaml_lex_read_int_rec v lexbuf 176\nand __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 450 \"lib/read.mll\"\n \n# 450 \"lib/read.mll\"\n ( try extract_positive_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1738 \"lib/read.ml\"\n\n \n# 1739 \"lib/read.ml\"\n | 1 ->\n\n# 453 \"lib/read.mll\"\n \n# 453 \"lib/read.mll\"\n ( try extract_negative_int lexbuf\n with Int_overflow ->\n lexer_error \"Int overflow\" v lexbuf )\n\n# 1745 \"lib/read.ml\"\n\n \n# 1746 \"lib/read.ml\"\n | 2 ->\n\n# 456 \"lib/read.mll\"\n \n# 456 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n int_of_string s\n with _ ->\n custom_error\n \"Expected an integer but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1763 \"lib/read.ml\"\n\n \n# 1764 \"lib/read.ml\"\n | 3 ->\n\n# 470 \"lib/read.mll\"\n \n# 470 \"lib/read.mll\"\n ( long_error \"Expected integer but found\" v lexbuf )\n\n# 1768 \"lib/read.ml\"\n\n \n# 1769 \"lib/read.ml\"\n | 4 ->\n\n# 471 \"lib/read.mll\"\n \n# 471 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1773 \"lib/read.ml\"\n\n \n# 1774 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int_rec v lexbuf __ocaml_lex_state\n\nand read_int32 v lexbuf =\n __ocaml_lex_read_int32_rec v lexbuf 185\nand __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 474 \"lib/read.mll\"\n \n# 474 \"lib/read.mll\"\n ( try Int32.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1787 \"lib/read.ml\"\n\n \n# 1788 \"lib/read.ml\"\n | 1 ->\n\n# 477 \"lib/read.mll\"\n \n# 477 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int32.of_string s\n with _ ->\n custom_error\n \"Expected an int32 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1805 \"lib/read.ml\"\n\n \n# 1806 \"lib/read.ml\"\n | 2 ->\n\n# 491 \"lib/read.mll\"\n \n# 491 \"lib/read.mll\"\n ( long_error \"Expected int32 but found\" v lexbuf )\n\n# 1810 \"lib/read.ml\"\n\n \n# 1811 \"lib/read.ml\"\n | 3 ->\n\n# 492 \"lib/read.mll\"\n \n# 492 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1815 \"lib/read.ml\"\n\n \n# 1816 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int32_rec v lexbuf __ocaml_lex_state\n\nand read_int64 v lexbuf =\n __ocaml_lex_read_int64_rec v lexbuf 192\nand __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 495 \"lib/read.mll\"\n \n# 495 \"lib/read.mll\"\n ( try Int64.of_string (Lexing.lexeme lexbuf)\n with _ ->\n lexer_error \"Int32 overflow\" v lexbuf )\n\n# 1829 \"lib/read.ml\"\n\n \n# 1830 \"lib/read.ml\"\n | 1 ->\n\n# 498 \"lib/read.mll\"\n \n# 498 \"lib/read.mll\"\n ( (* Support for double-quoted \"ints\" *)\n Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant int will pass,\n including hexadecimal and octal notations,\n and embedded underscores *)\n Int64.of_string s\n with _ ->\n custom_error\n \"Expected an int64 but found a string that \\\n doesn't even represent an integer\"\n v lexbuf\n )\n\n# 1847 \"lib/read.ml\"\n\n \n# 1848 \"lib/read.ml\"\n | 2 ->\n\n# 512 \"lib/read.mll\"\n \n# 512 \"lib/read.mll\"\n ( long_error \"Expected int64 but found\" v lexbuf )\n\n# 1852 \"lib/read.ml\"\n\n \n# 1853 \"lib/read.ml\"\n | 3 ->\n\n# 513 \"lib/read.mll\"\n \n# 513 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1857 \"lib/read.ml\"\n\n \n# 1858 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_int64_rec v lexbuf __ocaml_lex_state\n\nand read_number v lexbuf =\n __ocaml_lex_read_number_rec v lexbuf 199\nand __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 516 \"lib/read.mll\"\n \n# 516 \"lib/read.mll\"\n ( nan )\n\n# 1869 \"lib/read.ml\"\n\n \n# 1870 \"lib/read.ml\"\n | 1 ->\n\n# 517 \"lib/read.mll\"\n \n# 517 \"lib/read.mll\"\n ( infinity )\n\n# 1874 \"lib/read.ml\"\n\n \n# 1875 \"lib/read.ml\"\n | 2 ->\n\n# 518 \"lib/read.mll\"\n \n# 518 \"lib/read.mll\"\n ( neg_infinity )\n\n# 1879 \"lib/read.ml\"\n\n \n# 1880 \"lib/read.ml\"\n | 3 ->\n\n# 519 \"lib/read.mll\"\n \n# 519 \"lib/read.mll\"\n ( float_of_string (lexeme lexbuf) )\n\n# 1884 \"lib/read.ml\"\n\n \n# 1885 \"lib/read.ml\"\n | 4 ->\n\n# 520 \"lib/read.mll\"\n \n# 520 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n let s = finish_string v lexbuf in\n try\n (* Any OCaml-compliant float will pass,\n including hexadecimal and octal notations,\n and embedded underscores. *)\n float_of_string s\n with _ ->\n match s with\n \"NaN\" -> nan\n | \"Infinity\" -> infinity\n | \"-Infinity\" -> neg_infinity\n | _ ->\n custom_error\n \"Expected a number but found a string that \\\n doesn't even represent a number\"\n v lexbuf\n )\n\n# 1906 \"lib/read.ml\"\n\n \n# 1907 \"lib/read.ml\"\n | 5 ->\n\n# 538 \"lib/read.mll\"\n \n# 538 \"lib/read.mll\"\n ( long_error \"Expected number but found\" v lexbuf )\n\n# 1911 \"lib/read.ml\"\n\n \n# 1912 \"lib/read.ml\"\n | 6 ->\n\n# 539 \"lib/read.mll\"\n \n# 539 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1916 \"lib/read.ml\"\n\n \n# 1917 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_number_rec v lexbuf __ocaml_lex_state\n\nand read_string v lexbuf =\n __ocaml_lex_read_string_rec v lexbuf 233\nand __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 542 \"lib/read.mll\"\n \n# 542 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1929 \"lib/read.ml\"\n\n \n# 1930 \"lib/read.ml\"\n | 1 ->\n\n# 544 \"lib/read.mll\"\n \n# 544 \"lib/read.mll\"\n ( long_error \"Expected '\\\"' but found\" v lexbuf )\n\n# 1934 \"lib/read.ml\"\n\n \n# 1935 \"lib/read.ml\"\n | 2 ->\n\n# 545 \"lib/read.mll\"\n \n# 545 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1939 \"lib/read.ml\"\n\n \n# 1940 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_string_rec v lexbuf __ocaml_lex_state\n\nand read_ident v lexbuf =\n __ocaml_lex_read_ident_rec v lexbuf 237\nand __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 548 \"lib/read.mll\"\n \n# 548 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n finish_string v lexbuf )\n\n# 1952 \"lib/read.ml\"\n\n \n# 1953 \"lib/read.ml\"\n | 1 ->\nlet\n\n# 550 \"lib/read.mll\"\n \n# 550 \"lib/read.mll\"\n s\n\n# 1958 \"lib/read.ml\"\n# 1958 \"lib/read.ml\"\n= Lexing.sub_lexeme lexbuf lexbuf.Lexing.lex_start_pos lexbuf.Lexing.lex_curr_pos in\n\n# 551 \"lib/read.mll\"\n \n# 551 \"lib/read.mll\"\n ( s )\n\n# 1962 \"lib/read.ml\"\n\n \n# 1963 \"lib/read.ml\"\n | 2 ->\n\n# 552 \"lib/read.mll\"\n \n# 552 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1967 \"lib/read.ml\"\n\n \n# 1968 \"lib/read.ml\"\n | 3 ->\n\n# 553 \"lib/read.mll\"\n \n# 553 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 1972 \"lib/read.ml\"\n\n \n# 1973 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_ident_rec v lexbuf __ocaml_lex_state\n\nand map_ident v f lexbuf =\n __ocaml_lex_map_ident_rec v f lexbuf 242\nand __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 556 \"lib/read.mll\"\n \n# 556 \"lib/read.mll\"\n ( Bi_outbuf.clear v.buf;\n map_string v f lexbuf )\n\n# 1985 \"lib/read.ml\"\n\n \n# 1986 \"lib/read.ml\"\n | 1 ->\n\n# 559 \"lib/read.mll\"\n \n# 559 \"lib/read.mll\"\n ( map_lexeme f lexbuf )\n\n# 1990 \"lib/read.ml\"\n\n \n# 1991 \"lib/read.ml\"\n | 2 ->\n\n# 560 \"lib/read.mll\"\n \n# 560 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 1995 \"lib/read.ml\"\n\n \n# 1996 \"lib/read.ml\"\n | 3 ->\n\n# 561 \"lib/read.mll\"\n \n# 561 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2000 \"lib/read.ml\"\n\n \n# 2001 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_map_ident_rec v f lexbuf __ocaml_lex_state\n\nand read_sequence read_cell init_acc v lexbuf =\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf 247\nand __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 564 \"lib/read.mll\"\n \n# 564 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell !acc v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell !acc v lexbuf;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2026 \"lib/read.ml\"\n\n \n# 2027 \"lib/read.ml\"\n | 1 ->\n\n# 579 \"lib/read.mll\"\n \n# 579 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2031 \"lib/read.ml\"\n\n \n# 2032 \"lib/read.ml\"\n | 2 ->\n\n# 580 \"lib/read.mll\"\n \n# 580 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2036 \"lib/read.ml\"\n\n \n# 2037 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_sequence_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_list_rev read_cell v lexbuf =\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf 251\nand __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 583 \"lib/read.mll\"\n \n# 583 \"lib/read.mll\"\n ( let acc = ref [] in\n try\n read_space v lexbuf;\n read_array_end lexbuf;\n acc := read_cell v lexbuf :: !acc;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell v lexbuf :: !acc;\n done;\n assert false\n with End_of_array ->\n !acc\n )\n\n# 2062 \"lib/read.ml\"\n\n \n# 2063 \"lib/read.ml\"\n | 1 ->\n\n# 598 \"lib/read.mll\"\n \n# 598 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2067 \"lib/read.ml\"\n\n \n# 2068 \"lib/read.ml\"\n | 2 ->\n\n# 599 \"lib/read.mll\"\n \n# 599 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2072 \"lib/read.ml\"\n\n \n# 2073 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_list_rev_rec read_cell v lexbuf __ocaml_lex_state\n\nand read_array_end lexbuf =\n __ocaml_lex_read_array_end_rec lexbuf 255\nand __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 602 \"lib/read.mll\"\n \n# 602 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2084 \"lib/read.ml\"\n\n \n# 2085 \"lib/read.ml\"\n | 1 ->\n\n# 603 \"lib/read.mll\"\n \n# 603 \"lib/read.mll\"\n ( () )\n\n# 2089 \"lib/read.ml\"\n\n \n# 2090 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_end_rec lexbuf __ocaml_lex_state\n\nand read_array_sep v lexbuf =\n __ocaml_lex_read_array_sep_rec v lexbuf 257\nand __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 606 \"lib/read.mll\"\n \n# 606 \"lib/read.mll\"\n ( () )\n\n# 2101 \"lib/read.ml\"\n\n \n# 2102 \"lib/read.ml\"\n | 1 ->\n\n# 607 \"lib/read.mll\"\n \n# 607 \"lib/read.mll\"\n ( raise End_of_array )\n\n# 2106 \"lib/read.ml\"\n\n \n# 2107 \"lib/read.ml\"\n | 2 ->\n\n# 608 \"lib/read.mll\"\n \n# 608 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 2111 \"lib/read.ml\"\n\n \n# 2112 \"lib/read.ml\"\n | 3 ->\n\n# 609 \"lib/read.mll\"\n \n# 609 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2116 \"lib/read.ml\"\n\n \n# 2117 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_array_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple read_cell init_acc v lexbuf =\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf 262\nand __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 613 \"lib/read.mll\"\n \n# 613 \"lib/read.mll\"\n (\n \n# 615 \"lib/read.mll\"\n let pos = ref 0 in\n let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n acc := read_cell !pos !acc v lexbuf;\n incr pos;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n acc := read_cell !pos !acc v lexbuf;\n incr pos;\n done;\n assert false\n with End_of_tuple ->\n !acc\n \n# 635 \"lib/read.mll\"\n )\n\n# 2150 \"lib/read.ml\"\n\n \n# 2151 \"lib/read.ml\"\n | 1 ->\n\n# 636 \"lib/read.mll\"\n \n# 636 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2155 \"lib/read.ml\"\n\n \n# 2156 \"lib/read.ml\"\n | 2 ->\n\n# 637 \"lib/read.mll\"\n \n# 637 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2160 \"lib/read.ml\"\n\n \n# 2161 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_rec read_cell init_acc v lexbuf __ocaml_lex_state\n\nand read_tuple_end lexbuf =\n __ocaml_lex_read_tuple_end_rec lexbuf 266\nand __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 640 \"lib/read.mll\"\n \n# 640 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2172 \"lib/read.ml\"\n\n \n# 2173 \"lib/read.ml\"\n | 1 ->\n\n# 641 \"lib/read.mll\"\n \n# 641 \"lib/read.mll\"\n ( () )\n\n# 2177 \"lib/read.ml\"\n\n \n# 2178 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end_rec lexbuf __ocaml_lex_state\n\nand read_tuple_end2 v std lexbuf =\n __ocaml_lex_read_tuple_end2_rec v std lexbuf 268\nand __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 644 \"lib/read.mll\"\n \n# 644 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ')' or '' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2192 \"lib/read.ml\"\n\n \n# 2193 \"lib/read.ml\"\n | 1 ->\n\n# 648 \"lib/read.mll\"\n \n# 648 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ']' or '' but found\" v lexbuf )\n\n# 2200 \"lib/read.ml\"\n\n \n# 2201 \"lib/read.ml\"\n | 2 ->\n\n# 652 \"lib/read.mll\"\n \n# 652 \"lib/read.mll\"\n ( () )\n\n# 2205 \"lib/read.ml\"\n\n \n# 2206 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_end2_rec v std lexbuf __ocaml_lex_state\n\nand read_tuple_sep v lexbuf =\n __ocaml_lex_read_tuple_sep_rec v lexbuf 271\nand __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 655 \"lib/read.mll\"\n \n# 655 \"lib/read.mll\"\n ( () )\n\n# 2217 \"lib/read.ml\"\n\n \n# 2218 \"lib/read.ml\"\n | 1 ->\n\n# 656 \"lib/read.mll\"\n \n# 656 \"lib/read.mll\"\n ( raise End_of_tuple )\n\n# 2222 \"lib/read.ml\"\n\n \n# 2223 \"lib/read.ml\"\n | 2 ->\n\n# 657 \"lib/read.mll\"\n \n# 657 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2227 \"lib/read.ml\"\n\n \n# 2228 \"lib/read.ml\"\n | 3 ->\n\n# 658 \"lib/read.mll\"\n \n# 658 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2232 \"lib/read.ml\"\n\n \n# 2233 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand read_tuple_sep2 v std lexbuf =\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf 276\nand __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 661 \"lib/read.mll\"\n \n# 661 \"lib/read.mll\"\n ( () )\n\n# 2244 \"lib/read.ml\"\n\n \n# 2245 \"lib/read.ml\"\n | 1 ->\n\n# 662 \"lib/read.mll\"\n \n# 662 \"lib/read.mll\"\n ( if std then\n long_error \"Expected ',' or ']' but found\" v lexbuf\n else\n raise End_of_tuple )\n\n# 2252 \"lib/read.ml\"\n\n \n# 2253 \"lib/read.ml\"\n | 2 ->\n\n# 666 \"lib/read.mll\"\n \n# 666 \"lib/read.mll\"\n ( if std then\n raise End_of_tuple\n else\n long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2260 \"lib/read.ml\"\n\n \n# 2261 \"lib/read.ml\"\n | 3 ->\n\n# 670 \"lib/read.mll\"\n \n# 670 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 2265 \"lib/read.ml\"\n\n \n# 2266 \"lib/read.ml\"\n | 4 ->\n\n# 671 \"lib/read.mll\"\n \n# 671 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2270 \"lib/read.ml\"\n\n \n# 2271 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_tuple_sep2_rec v std lexbuf __ocaml_lex_state\n\nand read_abstract_fields read_key read_field init_acc v lexbuf =\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf 282\nand __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 675 \"lib/read.mll\"\n \n# 675 \"lib/read.mll\"\n ( let acc = ref init_acc in\n try\n read_space v lexbuf;\n read_object_end lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n let field_name = read_key v lexbuf in\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n acc := read_field !acc field_name v lexbuf;\n done;\n assert false\n with End_of_object ->\n !acc\n )\n\n# 2304 \"lib/read.ml\"\n\n \n# 2305 \"lib/read.ml\"\n | 1 ->\n\n# 698 \"lib/read.mll\"\n \n# 698 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2309 \"lib/read.ml\"\n\n \n# 2310 \"lib/read.ml\"\n | 2 ->\n\n# 699 \"lib/read.mll\"\n \n# 699 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2314 \"lib/read.ml\"\n\n \n# 2315 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_abstract_fields_rec read_key read_field init_acc v lexbuf __ocaml_lex_state\n\nand read_lcurl v lexbuf =\n __ocaml_lex_read_lcurl_rec v lexbuf 286\nand __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 702 \"lib/read.mll\"\n \n# 702 \"lib/read.mll\"\n ( () )\n\n# 2326 \"lib/read.ml\"\n\n \n# 2327 \"lib/read.ml\"\n | 1 ->\n\n# 703 \"lib/read.mll\"\n \n# 703 \"lib/read.mll\"\n ( long_error \"Expected '{' but found\" v lexbuf )\n\n# 2331 \"lib/read.ml\"\n\n \n# 2332 \"lib/read.ml\"\n | 2 ->\n\n# 704 \"lib/read.mll\"\n \n# 704 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2336 \"lib/read.ml\"\n\n \n# 2337 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lcurl_rec v lexbuf __ocaml_lex_state\n\nand read_object_end lexbuf =\n __ocaml_lex_read_object_end_rec lexbuf 290\nand __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 707 \"lib/read.mll\"\n \n# 707 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2348 \"lib/read.ml\"\n\n \n# 2349 \"lib/read.ml\"\n | 1 ->\n\n# 708 \"lib/read.mll\"\n \n# 708 \"lib/read.mll\"\n ( () )\n\n# 2353 \"lib/read.ml\"\n\n \n# 2354 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_end_rec lexbuf __ocaml_lex_state\n\nand read_object_sep v lexbuf =\n __ocaml_lex_read_object_sep_rec v lexbuf 292\nand __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 711 \"lib/read.mll\"\n \n# 711 \"lib/read.mll\"\n ( () )\n\n# 2365 \"lib/read.ml\"\n\n \n# 2366 \"lib/read.ml\"\n | 1 ->\n\n# 712 \"lib/read.mll\"\n \n# 712 \"lib/read.mll\"\n ( raise End_of_object )\n\n# 2370 \"lib/read.ml\"\n\n \n# 2371 \"lib/read.ml\"\n | 2 ->\n\n# 713 \"lib/read.mll\"\n \n# 713 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 2375 \"lib/read.ml\"\n\n \n# 2376 \"lib/read.ml\"\n | 3 ->\n\n# 714 \"lib/read.mll\"\n \n# 714 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2380 \"lib/read.ml\"\n\n \n# 2381 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_object_sep_rec v lexbuf __ocaml_lex_state\n\nand read_colon v lexbuf =\n __ocaml_lex_read_colon_rec v lexbuf 297\nand __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 717 \"lib/read.mll\"\n \n# 717 \"lib/read.mll\"\n ( () )\n\n# 2392 \"lib/read.ml\"\n\n \n# 2393 \"lib/read.ml\"\n | 1 ->\n\n# 718 \"lib/read.mll\"\n \n# 718 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 2397 \"lib/read.ml\"\n\n \n# 2398 \"lib/read.ml\"\n | 2 ->\n\n# 719 \"lib/read.mll\"\n \n# 719 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2402 \"lib/read.ml\"\n\n \n# 2403 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_colon_rec v lexbuf __ocaml_lex_state\n\nand start_any_tuple v lexbuf =\n __ocaml_lex_start_any_tuple_rec v lexbuf 301\nand __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 722 \"lib/read.mll\"\n \n# 722 \"lib/read.mll\"\n ( false )\n\n# 2414 \"lib/read.ml\"\n\n \n# 2415 \"lib/read.ml\"\n | 1 ->\n\n# 723 \"lib/read.mll\"\n \n# 723 \"lib/read.mll\"\n ( true )\n\n# 2419 \"lib/read.ml\"\n\n \n# 2420 \"lib/read.ml\"\n | 2 ->\n\n# 724 \"lib/read.mll\"\n \n# 724 \"lib/read.mll\"\n ( long_error \"Expected '(' or '[' but found\" v lexbuf )\n\n# 2424 \"lib/read.ml\"\n\n \n# 2425 \"lib/read.ml\"\n | 3 ->\n\n# 725 \"lib/read.mll\"\n \n# 725 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2429 \"lib/read.ml\"\n\n \n# 2430 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_start_any_tuple_rec v lexbuf __ocaml_lex_state\n\nand read_lpar v lexbuf =\n __ocaml_lex_read_lpar_rec v lexbuf 306\nand __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 728 \"lib/read.mll\"\n \n# 728 \"lib/read.mll\"\n ( () )\n\n# 2441 \"lib/read.ml\"\n\n \n# 2442 \"lib/read.ml\"\n | 1 ->\n\n# 729 \"lib/read.mll\"\n \n# 729 \"lib/read.mll\"\n ( long_error \"Expected '(' but found\" v lexbuf )\n\n# 2446 \"lib/read.ml\"\n\n \n# 2447 \"lib/read.ml\"\n | 2 ->\n\n# 730 \"lib/read.mll\"\n \n# 730 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2451 \"lib/read.ml\"\n\n \n# 2452 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lpar_rec v lexbuf __ocaml_lex_state\n\nand read_rpar v lexbuf =\n __ocaml_lex_read_rpar_rec v lexbuf 310\nand __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 733 \"lib/read.mll\"\n \n# 733 \"lib/read.mll\"\n ( () )\n\n# 2463 \"lib/read.ml\"\n\n \n# 2464 \"lib/read.ml\"\n | 1 ->\n\n# 734 \"lib/read.mll\"\n \n# 734 \"lib/read.mll\"\n ( long_error \"Expected ')' but found\" v lexbuf )\n\n# 2468 \"lib/read.ml\"\n\n \n# 2469 \"lib/read.ml\"\n | 2 ->\n\n# 735 \"lib/read.mll\"\n \n# 735 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2473 \"lib/read.ml\"\n\n \n# 2474 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rpar_rec v lexbuf __ocaml_lex_state\n\nand read_lbr v lexbuf =\n __ocaml_lex_read_lbr_rec v lexbuf 314\nand __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 738 \"lib/read.mll\"\n \n# 738 \"lib/read.mll\"\n ( () )\n\n# 2485 \"lib/read.ml\"\n\n \n# 2486 \"lib/read.ml\"\n | 1 ->\n\n# 739 \"lib/read.mll\"\n \n# 739 \"lib/read.mll\"\n ( long_error \"Expected '[' but found\" v lexbuf )\n\n# 2490 \"lib/read.ml\"\n\n \n# 2491 \"lib/read.ml\"\n | 2 ->\n\n# 740 \"lib/read.mll\"\n \n# 740 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2495 \"lib/read.ml\"\n\n \n# 2496 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_lbr_rec v lexbuf __ocaml_lex_state\n\nand read_rbr v lexbuf =\n __ocaml_lex_read_rbr_rec v lexbuf 318\nand __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 743 \"lib/read.mll\"\n \n# 743 \"lib/read.mll\"\n ( () )\n\n# 2507 \"lib/read.ml\"\n\n \n# 2508 \"lib/read.ml\"\n | 1 ->\n\n# 744 \"lib/read.mll\"\n \n# 744 \"lib/read.mll\"\n ( long_error \"Expected ']' but found\" v lexbuf )\n\n# 2512 \"lib/read.ml\"\n\n \n# 2513 \"lib/read.ml\"\n | 2 ->\n\n# 745 \"lib/read.mll\"\n \n# 745 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2517 \"lib/read.ml\"\n\n \n# 2518 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_rbr_rec v lexbuf __ocaml_lex_state\n\nand skip_json v lexbuf =\n __ocaml_lex_skip_json_rec v lexbuf 322\nand __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 751 \"lib/read.mll\"\n \n# 751 \"lib/read.mll\"\n ( () )\n\n# 2529 \"lib/read.ml\"\n\n \n# 2530 \"lib/read.ml\"\n | 1 ->\n\n# 752 \"lib/read.mll\"\n \n# 752 \"lib/read.mll\"\n ( () )\n\n# 2534 \"lib/read.ml\"\n\n \n# 2535 \"lib/read.ml\"\n | 2 ->\n\n# 753 \"lib/read.mll\"\n \n# 753 \"lib/read.mll\"\n ( () )\n\n# 2539 \"lib/read.ml\"\n\n \n# 2540 \"lib/read.ml\"\n | 3 ->\n\n# 754 \"lib/read.mll\"\n \n# 754 \"lib/read.mll\"\n ( () )\n\n# 2544 \"lib/read.ml\"\n\n \n# 2545 \"lib/read.ml\"\n | 4 ->\n\n# 755 \"lib/read.mll\"\n \n# 755 \"lib/read.mll\"\n ( () )\n\n# 2549 \"lib/read.ml\"\n\n \n# 2550 \"lib/read.ml\"\n | 5 ->\n\n# 756 \"lib/read.mll\"\n \n# 756 \"lib/read.mll\"\n ( () )\n\n# 2554 \"lib/read.ml\"\n\n \n# 2555 \"lib/read.ml\"\n | 6 ->\n\n# 757 \"lib/read.mll\"\n \n# 757 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2559 \"lib/read.ml\"\n\n \n# 2560 \"lib/read.ml\"\n | 7 ->\n\n# 758 \"lib/read.mll\"\n \n# 758 \"lib/read.mll\"\n ( () )\n\n# 2564 \"lib/read.ml\"\n\n \n# 2565 \"lib/read.ml\"\n | 8 ->\n\n# 759 \"lib/read.mll\"\n \n# 759 \"lib/read.mll\"\n ( () )\n\n# 2569 \"lib/read.ml\"\n\n \n# 2570 \"lib/read.ml\"\n | 9 ->\n\n# 761 \"lib/read.mll\"\n \n# 761 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_object_end lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_object_sep v lexbuf;\n read_space v lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n read_colon v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2595 \"lib/read.ml\"\n\n \n# 2596 \"lib/read.ml\"\n | 10 ->\n\n# 784 \"lib/read.mll\"\n \n# 784 \"lib/read.mll\"\n ( try\n read_space v lexbuf;\n read_array_end lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_array_sep v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2613 \"lib/read.ml\"\n\n \n# 2614 \"lib/read.ml\"\n | 11 ->\n\n# 799 \"lib/read.mll\"\n \n# 799 \"lib/read.mll\"\n (\n \n# 801 \"lib/read.mll\"\n try\n read_space v lexbuf;\n read_tuple_end lexbuf;\n skip_json v lexbuf;\n while true do\n read_space v lexbuf;\n read_tuple_sep v lexbuf;\n read_space v lexbuf;\n skip_json v lexbuf;\n done;\n assert false\n with End_of_tuple ->\n ()\n \n# 817 \"lib/read.mll\"\n )\n\n# 2636 \"lib/read.ml\"\n\n \n# 2637 \"lib/read.ml\"\n | 12 ->\n\n# 819 \"lib/read.mll\"\n \n# 819 \"lib/read.mll\"\n (\n \n# 821 \"lib/read.mll\"\n read_space v lexbuf;\n skip_ident v lexbuf;\n read_space v lexbuf;\n finish_skip_variant v lexbuf\n \n# 828 \"lib/read.mll\"\n )\n\n# 2650 \"lib/read.ml\"\n\n \n# 2651 \"lib/read.ml\"\n | 13 ->\n\n# 830 \"lib/read.mll\"\n \n# 830 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2655 \"lib/read.ml\"\n\n \n# 2656 \"lib/read.ml\"\n | 14 ->\n\n# 831 \"lib/read.mll\"\n \n# 831 \"lib/read.mll\"\n ( finish_comment v lexbuf; skip_json v lexbuf )\n\n# 2660 \"lib/read.ml\"\n\n \n# 2661 \"lib/read.ml\"\n | 15 ->\n\n# 832 \"lib/read.mll\"\n \n# 832 \"lib/read.mll\"\n ( newline v lexbuf; skip_json v lexbuf )\n\n# 2665 \"lib/read.ml\"\n\n \n# 2666 \"lib/read.ml\"\n | 16 ->\n\n# 833 \"lib/read.mll\"\n \n# 833 \"lib/read.mll\"\n ( skip_json v lexbuf )\n\n# 2670 \"lib/read.ml\"\n\n \n# 2671 \"lib/read.ml\"\n | 17 ->\n\n# 834 \"lib/read.mll\"\n \n# 834 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2675 \"lib/read.ml\"\n\n \n# 2676 \"lib/read.ml\"\n | 18 ->\n\n# 835 \"lib/read.mll\"\n \n# 835 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2680 \"lib/read.ml\"\n\n \n# 2681 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_json_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_stringlit v lexbuf =\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf 378\nand __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 841 \"lib/read.mll\"\n \n# 841 \"lib/read.mll\"\n ( () )\n\n# 2692 \"lib/read.ml\"\n\n \n# 2693 \"lib/read.ml\"\n | 1 ->\n\n# 842 \"lib/read.mll\"\n \n# 842 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2697 \"lib/read.ml\"\n\n \n# 2698 \"lib/read.ml\"\n | 2 ->\n\n# 843 \"lib/read.mll\"\n \n# 843 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2702 \"lib/read.ml\"\n\n \n# 2703 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_skip_variant v lexbuf =\n __ocaml_lex_finish_skip_variant_rec v lexbuf 389\nand __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 846 \"lib/read.mll\"\n \n# 846 \"lib/read.mll\"\n ( skip_json v lexbuf;\n read_space v lexbuf;\n read_gt v lexbuf )\n\n# 2716 \"lib/read.ml\"\n\n \n# 2717 \"lib/read.ml\"\n | 1 ->\n\n# 849 \"lib/read.mll\"\n \n# 849 \"lib/read.mll\"\n ( () )\n\n# 2721 \"lib/read.ml\"\n\n \n# 2722 \"lib/read.ml\"\n | 2 ->\n\n# 850 \"lib/read.mll\"\n \n# 850 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2726 \"lib/read.ml\"\n\n \n# 2727 \"lib/read.ml\"\n | 3 ->\n\n# 851 \"lib/read.mll\"\n \n# 851 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2731 \"lib/read.ml\"\n\n \n# 2732 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_skip_variant_rec v lexbuf __ocaml_lex_state\n\nand skip_ident v lexbuf =\n __ocaml_lex_skip_ident_rec v lexbuf 394\nand __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 854 \"lib/read.mll\"\n \n# 854 \"lib/read.mll\"\n ( finish_skip_stringlit v lexbuf )\n\n# 2743 \"lib/read.ml\"\n\n \n# 2744 \"lib/read.ml\"\n | 1 ->\n\n# 855 \"lib/read.mll\"\n \n# 855 \"lib/read.mll\"\n ( () )\n\n# 2748 \"lib/read.ml\"\n\n \n# 2749 \"lib/read.ml\"\n | 2 ->\n\n# 856 \"lib/read.mll\"\n \n# 856 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2753 \"lib/read.ml\"\n\n \n# 2754 \"lib/read.ml\"\n | 3 ->\n\n# 857 \"lib/read.mll\"\n \n# 857 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2758 \"lib/read.ml\"\n\n \n# 2759 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_skip_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_json v lexbuf =\n __ocaml_lex_buffer_json_rec v lexbuf 399\nand __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 870 \"lib/read.mll\"\n \n# 870 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2770 \"lib/read.ml\"\n\n \n# 2771 \"lib/read.ml\"\n | 1 ->\n\n# 872 \"lib/read.mll\"\n \n# 872 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2775 \"lib/read.ml\"\n\n \n# 2776 \"lib/read.ml\"\n | 2 ->\n\n# 873 \"lib/read.mll\"\n \n# 873 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '{';\n buffer_space v lexbuf;\n buffer_object_end v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_object_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n buffer_colon v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_object ->\n ()\n )\n\n# 2802 \"lib/read.ml\"\n\n \n# 2803 \"lib/read.ml\"\n | 3 ->\n\n# 897 \"lib/read.mll\"\n \n# 897 \"lib/read.mll\"\n ( try\n Bi_outbuf.add_char v.buf '[';\n buffer_space v lexbuf;\n buffer_array_end v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_array_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_array ->\n ()\n )\n\n# 2821 \"lib/read.ml\"\n\n \n# 2822 \"lib/read.ml\"\n | 4 ->\n\n# 913 \"lib/read.mll\"\n \n# 913 \"lib/read.mll\"\n (\n \n# 915 \"lib/read.mll\"\n try\n Bi_outbuf.add_char v.buf '(';\n buffer_space v lexbuf;\n buffer_tuple_end v lexbuf;\n buffer_json v lexbuf;\n while true do\n buffer_space v lexbuf;\n buffer_tuple_sep v lexbuf;\n buffer_space v lexbuf;\n buffer_json v lexbuf;\n done;\n assert false\n with End_of_tuple ->\n ()\n \n# 932 \"lib/read.mll\"\n )\n\n# 2845 \"lib/read.ml\"\n\n \n# 2846 \"lib/read.ml\"\n | 5 ->\n\n# 934 \"lib/read.mll\"\n \n# 934 \"lib/read.mll\"\n (\n \n# 936 \"lib/read.mll\"\n Bi_outbuf.add_char v.buf '<';\n buffer_space v lexbuf;\n buffer_ident v lexbuf;\n buffer_space v lexbuf;\n finish_buffer_variant v lexbuf\n \n# 944 \"lib/read.mll\"\n )\n\n# 2860 \"lib/read.ml\"\n\n \n# 2861 \"lib/read.ml\"\n | 6 ->\n\n# 946 \"lib/read.mll\"\n \n# 946 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2865 \"lib/read.ml\"\n\n \n# 2866 \"lib/read.ml\"\n | 7 ->\n\n# 947 \"lib/read.mll\"\n \n# 947 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_json v lexbuf )\n\n# 2872 \"lib/read.ml\"\n\n \n# 2873 \"lib/read.ml\"\n | 8 ->\n\n# 950 \"lib/read.mll\"\n \n# 950 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_json v lexbuf )\n\n# 2879 \"lib/read.ml\"\n\n \n# 2880 \"lib/read.ml\"\n | 9 ->\n\n# 953 \"lib/read.mll\"\n \n# 953 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; buffer_json v lexbuf )\n\n# 2884 \"lib/read.ml\"\n\n \n# 2885 \"lib/read.ml\"\n | 10 ->\n\n# 954 \"lib/read.mll\"\n \n# 954 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2889 \"lib/read.ml\"\n\n \n# 2890 \"lib/read.ml\"\n | 11 ->\n\n# 955 \"lib/read.mll\"\n \n# 955 \"lib/read.mll\"\n ( long_error \"Invalid token\" v lexbuf )\n\n# 2894 \"lib/read.ml\"\n\n \n# 2895 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_json_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_stringlit v lexbuf =\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf 450\nand __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 961 \"lib/read.mll\"\n \n# 961 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\"';\n add_lexeme v.buf lexbuf\n )\n\n# 2908 \"lib/read.ml\"\n\n \n# 2909 \"lib/read.ml\"\n | 1 ->\n\n# 964 \"lib/read.mll\"\n \n# 964 \"lib/read.mll\"\n ( long_error \"Invalid string literal\" v lexbuf )\n\n# 2913 \"lib/read.ml\"\n\n \n# 2914 \"lib/read.ml\"\n | 2 ->\n\n# 965 \"lib/read.mll\"\n \n# 965 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2918 \"lib/read.ml\"\n\n \n# 2919 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_stringlit_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_variant v lexbuf =\n __ocaml_lex_finish_buffer_variant_rec v lexbuf 461\nand __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 968 \"lib/read.mll\"\n \n# 968 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':';\n buffer_json v lexbuf;\n buffer_space v lexbuf;\n buffer_gt v lexbuf )\n\n# 2933 \"lib/read.ml\"\n\n \n# 2934 \"lib/read.ml\"\n | 1 ->\n\n# 972 \"lib/read.mll\"\n \n# 972 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 2938 \"lib/read.ml\"\n\n \n# 2939 \"lib/read.ml\"\n | 2 ->\n\n# 973 \"lib/read.mll\"\n \n# 973 \"lib/read.mll\"\n ( long_error \"Expected ':' or '>' but found\" v lexbuf )\n\n# 2943 \"lib/read.ml\"\n\n \n# 2944 \"lib/read.ml\"\n | 3 ->\n\n# 974 \"lib/read.mll\"\n \n# 974 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2948 \"lib/read.ml\"\n\n \n# 2949 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_variant_rec v lexbuf __ocaml_lex_state\n\nand buffer_ident v lexbuf =\n __ocaml_lex_buffer_ident_rec v lexbuf 466\nand __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 977 \"lib/read.mll\"\n \n# 977 \"lib/read.mll\"\n ( finish_buffer_stringlit v lexbuf )\n\n# 2960 \"lib/read.ml\"\n\n \n# 2961 \"lib/read.ml\"\n | 1 ->\n\n# 978 \"lib/read.mll\"\n \n# 978 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf )\n\n# 2965 \"lib/read.ml\"\n\n \n# 2966 \"lib/read.ml\"\n | 2 ->\n\n# 979 \"lib/read.mll\"\n \n# 979 \"lib/read.mll\"\n ( long_error \"Expected string or identifier but found\" v lexbuf )\n\n# 2970 \"lib/read.ml\"\n\n \n# 2971 \"lib/read.ml\"\n | 3 ->\n\n# 980 \"lib/read.mll\"\n \n# 980 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 2975 \"lib/read.ml\"\n\n \n# 2976 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_ident_rec v lexbuf __ocaml_lex_state\n\nand buffer_space v lexbuf =\n __ocaml_lex_buffer_space_rec v lexbuf 471\nand __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 983 \"lib/read.mll\"\n \n# 983 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 2990 \"lib/read.ml\"\n\n \n# 2991 \"lib/read.ml\"\n | 1 ->\n\n# 987 \"lib/read.mll\"\n \n# 987 \"lib/read.mll\"\n (\n Bi_outbuf.add_string v.buf \"/*\";\n finish_buffer_comment v lexbuf;\n buffer_space v lexbuf )\n\n# 2998 \"lib/read.ml\"\n\n \n# 2999 \"lib/read.ml\"\n | 2 ->\n\n# 991 \"lib/read.mll\"\n \n# 991 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n buffer_space v lexbuf )\n\n# 3006 \"lib/read.ml\"\n\n \n# 3007 \"lib/read.ml\"\n | 3 ->\n\n# 995 \"lib/read.mll\"\n \n# 995 \"lib/read.mll\"\n (\n add_lexeme v.buf lexbuf;\n buffer_space v lexbuf )\n\n# 3013 \"lib/read.ml\"\n\n \n# 3014 \"lib/read.ml\"\n | 4 ->\n\n# 998 \"lib/read.mll\"\n \n# 998 \"lib/read.mll\"\n ( () )\n\n# 3018 \"lib/read.ml\"\n\n \n# 3019 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_space_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_end v lexbuf =\n __ocaml_lex_buffer_object_end_rec v lexbuf 478\nand __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1001 \"lib/read.mll\"\n \n# 1001 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf '}';\n raise End_of_object )\n\n# 3032 \"lib/read.ml\"\n\n \n# 3033 \"lib/read.ml\"\n | 1 ->\n\n# 1004 \"lib/read.mll\"\n \n# 1004 \"lib/read.mll\"\n ( () )\n\n# 3037 \"lib/read.ml\"\n\n \n# 3038 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_object_sep v lexbuf =\n __ocaml_lex_buffer_object_sep_rec v lexbuf 480\nand __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1007 \"lib/read.mll\"\n \n# 1007 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3049 \"lib/read.ml\"\n\n \n# 3050 \"lib/read.ml\"\n | 1 ->\n\n# 1008 \"lib/read.mll\"\n \n# 1008 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '}'; raise End_of_object )\n\n# 3054 \"lib/read.ml\"\n\n \n# 3055 \"lib/read.ml\"\n | 2 ->\n\n# 1009 \"lib/read.mll\"\n \n# 1009 \"lib/read.mll\"\n ( long_error \"Expected ',' or '}' but found\" v lexbuf )\n\n# 3059 \"lib/read.ml\"\n\n \n# 3060 \"lib/read.ml\"\n | 3 ->\n\n# 1010 \"lib/read.mll\"\n \n# 1010 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3064 \"lib/read.ml\"\n\n \n# 3065 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_object_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_end v lexbuf =\n __ocaml_lex_buffer_array_end_rec v lexbuf 485\nand __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1013 \"lib/read.mll\"\n \n# 1013 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3076 \"lib/read.ml\"\n\n \n# 3077 \"lib/read.ml\"\n | 1 ->\n\n# 1014 \"lib/read.mll\"\n \n# 1014 \"lib/read.mll\"\n ( () )\n\n# 3081 \"lib/read.ml\"\n\n \n# 3082 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_array_sep v lexbuf =\n __ocaml_lex_buffer_array_sep_rec v lexbuf 487\nand __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1017 \"lib/read.mll\"\n \n# 1017 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3093 \"lib/read.ml\"\n\n \n# 3094 \"lib/read.ml\"\n | 1 ->\n\n# 1018 \"lib/read.mll\"\n \n# 1018 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ']'; raise End_of_array )\n\n# 3098 \"lib/read.ml\"\n\n \n# 3099 \"lib/read.ml\"\n | 2 ->\n\n# 1019 \"lib/read.mll\"\n \n# 1019 \"lib/read.mll\"\n ( long_error \"Expected ',' or ']' but found\" v lexbuf )\n\n# 3103 \"lib/read.ml\"\n\n \n# 3104 \"lib/read.ml\"\n | 3 ->\n\n# 1020 \"lib/read.mll\"\n \n# 1020 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3108 \"lib/read.ml\"\n\n \n# 3109 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_array_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_end v lexbuf =\n __ocaml_lex_buffer_tuple_end_rec v lexbuf 492\nand __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1023 \"lib/read.mll\"\n \n# 1023 \"lib/read.mll\"\n (\n Bi_outbuf.add_char v.buf ')';\n raise End_of_tuple )\n\n# 3122 \"lib/read.ml\"\n\n \n# 3123 \"lib/read.ml\"\n | 1 ->\n\n# 1026 \"lib/read.mll\"\n \n# 1026 \"lib/read.mll\"\n ( () )\n\n# 3127 \"lib/read.ml\"\n\n \n# 3128 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_end_rec v lexbuf __ocaml_lex_state\n\nand buffer_tuple_sep v lexbuf =\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf 494\nand __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1029 \"lib/read.mll\"\n \n# 1029 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ',' )\n\n# 3139 \"lib/read.ml\"\n\n \n# 3140 \"lib/read.ml\"\n | 1 ->\n\n# 1030 \"lib/read.mll\"\n \n# 1030 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ')'; raise End_of_tuple )\n\n# 3144 \"lib/read.ml\"\n\n \n# 3145 \"lib/read.ml\"\n | 2 ->\n\n# 1031 \"lib/read.mll\"\n \n# 1031 \"lib/read.mll\"\n ( long_error \"Expected ',' or ')' but found\" v lexbuf )\n\n# 3149 \"lib/read.ml\"\n\n \n# 3150 \"lib/read.ml\"\n | 3 ->\n\n# 1032 \"lib/read.mll\"\n \n# 1032 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3154 \"lib/read.ml\"\n\n \n# 3155 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_tuple_sep_rec v lexbuf __ocaml_lex_state\n\nand buffer_colon v lexbuf =\n __ocaml_lex_buffer_colon_rec v lexbuf 499\nand __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1035 \"lib/read.mll\"\n \n# 1035 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf ':' )\n\n# 3166 \"lib/read.ml\"\n\n \n# 3167 \"lib/read.ml\"\n | 1 ->\n\n# 1036 \"lib/read.mll\"\n \n# 1036 \"lib/read.mll\"\n ( long_error \"Expected ':' but found\" v lexbuf )\n\n# 3171 \"lib/read.ml\"\n\n \n# 3172 \"lib/read.ml\"\n | 2 ->\n\n# 1037 \"lib/read.mll\"\n \n# 1037 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3176 \"lib/read.ml\"\n\n \n# 3177 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_colon_rec v lexbuf __ocaml_lex_state\n\nand buffer_gt v lexbuf =\n __ocaml_lex_buffer_gt_rec v lexbuf 503\nand __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1040 \"lib/read.mll\"\n \n# 1040 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '>' )\n\n# 3188 \"lib/read.ml\"\n\n \n# 3189 \"lib/read.ml\"\n | 1 ->\n\n# 1041 \"lib/read.mll\"\n \n# 1041 \"lib/read.mll\"\n ( long_error \"Expected '>' but found\" v lexbuf )\n\n# 3193 \"lib/read.ml\"\n\n \n# 3194 \"lib/read.ml\"\n | 2 ->\n\n# 1042 \"lib/read.mll\"\n \n# 1042 \"lib/read.mll\"\n ( custom_error \"Unexpected end of input\" v lexbuf )\n\n# 3198 \"lib/read.ml\"\n\n \n# 3199 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_buffer_gt_rec v lexbuf __ocaml_lex_state\n\nand finish_buffer_comment v lexbuf =\n __ocaml_lex_finish_buffer_comment_rec v lexbuf 507\nand __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1045 \"lib/read.mll\"\n \n# 1045 \"lib/read.mll\"\n ( Bi_outbuf.add_string v.buf \"*/\" )\n\n# 3210 \"lib/read.ml\"\n\n \n# 3211 \"lib/read.ml\"\n | 1 ->\n\n# 1046 \"lib/read.mll\"\n \n# 1046 \"lib/read.mll\"\n ( long_error \"Unterminated comment\" v lexbuf )\n\n# 3215 \"lib/read.ml\"\n\n \n# 3216 \"lib/read.ml\"\n | 2 ->\n\n# 1047 \"lib/read.mll\"\n \n# 1047 \"lib/read.mll\"\n ( Bi_outbuf.add_char v.buf '\\n';\n newline v lexbuf;\n finish_buffer_comment v lexbuf )\n\n# 3222 \"lib/read.ml\"\n\n \n# 3223 \"lib/read.ml\"\n | 3 ->\n\n# 1050 \"lib/read.mll\"\n \n# 1050 \"lib/read.mll\"\n ( add_lexeme v.buf lexbuf; finish_buffer_comment v lexbuf )\n\n# 3227 \"lib/read.ml\"\n\n \n# 3228 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_finish_buffer_comment_rec v lexbuf __ocaml_lex_state\n\nand junk lexbuf =\n __ocaml_lex_junk_rec lexbuf 513\nand __ocaml_lex_junk_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n\n# 1053 \"lib/read.mll\"\n \n# 1053 \"lib/read.mll\"\n ( Lexing.lexeme lexbuf )\n\n# 3239 \"lib/read.ml\"\n\n \n# 3240 \"lib/read.ml\"\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_junk_rec lexbuf __ocaml_lex_state\n\n;;\n\n\n# 1055 \"lib/read.mll\"\n \n \n# 1056 \"lib/read.mll\"\n let _ = (read_json : lexer_state -> Lexing.lexbuf -> t)\n\n let read_t = read_json\n\n let () =\n read_junk := junk\n\n let read_int8 v lexbuf =\n let n = read_int v lexbuf in\n if n < 0 || n > 255 then\n lexer_error \"Int8 overflow\" v lexbuf\n else\n char_of_int n\n\n let read_list read_cell v lexbuf =\n List.rev (read_list_rev read_cell v lexbuf)\n\n let array_of_rev_list l =\n match l with\n [] -> [| |]\n | x :: tl ->\n let len = List.length l in\n let a = Array.make len x in\n let r = ref tl in\n for i = len - 2 downto 0 do\n a.(i) <- List.hd !r;\n r := List.tl !r\n done;\n a\n\n let read_array read_cell v lexbuf =\n let l = read_list_rev read_cell v lexbuf in\n array_of_rev_list l\n\n (* Read a JSON object, reading the keys into OCaml strings\n (provided for backward compatibility) *)\n let read_fields read_field init_acc v =\n read_abstract_fields read_ident read_field init_acc v\n\n let finish v lexbuf =\n read_space v lexbuf;\n if not (read_eof lexbuf) then\n long_error \"Junk after end of JSON value:\" v lexbuf\n\n let init_lexer = init_lexer\n\n let from_lexbuf v ?(stream = false) lexbuf =\n read_space v lexbuf;\n\n let x =\n if read_eof lexbuf then\n raise End_of_input\n else\n read_json v lexbuf\n in\n\n if not stream then\n finish v lexbuf;\n\n x\n\n\n let from_string ?buf ?fname ?lnum s =\n try\n let lexbuf = Lexing.from_string s in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_channel ?buf ?fname ?lnum ic =\n try\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n from_lexbuf v lexbuf\n with End_of_input ->\n json_error \"Blank input data\"\n\n let from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n try\n let x = from_channel ?buf ?fname ?lnum ic in\n close_in ic;\n x\n with e ->\n close_in_noerr ic;\n raise e\n\n exception Finally of exn * exn\n\n let stream_from_lexbuf v ?(fin = fun () -> ()) lexbuf =\n let stream = Some true in\n let f i =\n try Some (from_lexbuf v ?stream lexbuf)\n with\n End_of_input ->\n fin ();\n None\n | e ->\n (try fin () with fin_e -> raise (Finally (e, fin_e)));\n raise e\n in\n Stream.from f\n\n let stream_from_string ?buf ?fname ?lnum s =\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v (Lexing.from_string s)\n\n let stream_from_channel ?buf ?fin ?fname ?lnum ic =\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ?fin lexbuf\n\n let stream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n let lexbuf = Lexing.from_channel ic in\n let v = init_lexer ?buf ?fname ?lnum () in\n stream_from_lexbuf v ~fin lexbuf\n\n type json_line = [ `Json of t | `Exn of exn ]\n\n let linestream_from_channel\n ?buf ?(fin = fun () -> ()) ?fname ?lnum:(lnum0 = 1) ic =\n let buf =\n match buf with\n None -> Some (Bi_outbuf.create 256)\n | Some _ -> buf\n in\n let f i =\n try\n let line = input_line ic in\n let lnum = lnum0 + i in\n Some (`Json (from_string ?buf ?fname ~lnum line))\n with\n End_of_file -> fin (); None\n | e -> Some (`Exn e)\n in\n Stream.from f\n\n let linestream_from_file ?buf ?fname ?lnum file =\n let ic = open_in file in\n let fin () = close_in ic in\n let fname =\n match fname with\n None -> Some file\n | x -> x\n in\n linestream_from_channel ?buf ~fin ?fname ?lnum ic\n\n let prettify ?std s =\n pretty_to_string ?std (from_string s)\n\n let compact ?std s =\n to_string (from_string s)\n\n let validate_json _path _value = None\n\n\n# 3411 \"lib/read.ml\"\n# 91 \"yojson.cppo.ml\"\nend\n","open Core_kernel\nmodule Z = Zarith.Z\n\ntype t = Z.t [@@deriving typerep ~abstract]\n\nlet module_name = \"Bigint\"\nlet invariant (_ : t) = ()\n\nmodule Stringable_t = struct\n type nonrec t = t\n\n let to_string = Z.to_string\n\n let rec is_integer_suffix s i ~len ~char_is_digit =\n if i < len\n then (\n let c = s.[i] in\n if char_is_digit c || Char.equal c '_'\n then is_integer_suffix s (i + 1) ~len ~char_is_digit\n else false)\n else true\n ;;\n\n let is_integer_string s ~char_is_digit =\n let len = String.length s in\n if 0 < len\n then (\n let i = if Char.equal s.[0] '-' then 1 else 0 in\n if i < len\n then\n if char_is_digit s.[i]\n then is_integer_suffix s (i + 1) ~len ~char_is_digit\n else false\n else false)\n else false\n ;;\n\n let of_string_base str ~name ~of_string_no_underscores ~char_is_digit =\n try of_string_no_underscores str with\n | _ ->\n if is_integer_string str ~char_is_digit\n then of_string_no_underscores (String.filter str ~f:(fun c -> Char.( <> ) c '_'))\n else failwithf \"%s.%s: invalid argument %S\" name module_name str ()\n ;;\n\n let of_string str =\n of_string_base\n str\n ~name:\"of_string\"\n ~of_string_no_underscores:Z.of_string\n ~char_is_digit:Char.is_digit\n ;;\nend\n\nmodule Stable = struct\n module V1 = struct\n module Bin_rep = struct\n type t =\n | Zero\n | Pos of string\n | Neg of string\n [@@deriving bin_io]\n end\n\n module Bin_rep_conversion = struct\n type nonrec t = t\n\n let to_binable t =\n let s = Z.sign t in\n if s > 0\n then Bin_rep.Pos (Z.to_bits t)\n else if s < 0\n then Bin_rep.Neg (Z.to_bits t)\n else Bin_rep.Zero\n ;;\n\n let of_binable = function\n | Bin_rep.Zero -> Z.zero\n | Bin_rep.Pos bits -> Z.of_bits bits\n | Bin_rep.Neg bits -> Z.of_bits bits |> Z.neg\n ;;\n end\n\n type nonrec t = t\n\n let compare = Z.compare\n\n include Sexpable.Stable.Of_stringable.V1 (Stringable_t)\n\n include Binable.Stable.Of_binable.V1 [@alert \"-legacy\"]\n (Bin_rep)\n (Bin_rep_conversion)\n end\n\n module V2 = struct\n type nonrec t = t\n\n let compare = Z.compare\n\n include Sexpable.Stable.Of_stringable.V1 (Stringable_t)\n\n let compute_size_in_bytes x =\n let numbits = Z.numbits x in\n Int.round_up ~to_multiple_of:8 numbits / 8\n ;;\n\n let compute_tag ~size_in_bytes ~negative =\n let open Int63 in\n let sign_bit = if negative then one else zero in\n (* Can't overflow:\n size <= String.length bits < 2 * max_string_length < max_int63\n *)\n shift_left (of_int size_in_bytes) 1 + sign_bit\n ;;\n\n let bin_size_t : t Bin_prot.Size.sizer =\n fun x ->\n let size_in_bytes = compute_size_in_bytes x in\n if size_in_bytes = 0\n then Int63.bin_size_t Int63.zero\n else (\n let negative = Z.sign x = -1 in\n let tag = compute_tag ~size_in_bytes ~negative in\n Int63.bin_size_t tag + size_in_bytes)\n ;;\n\n let bin_write_t : t Bin_prot.Write.writer =\n fun buf ~pos x ->\n let size_in_bytes = compute_size_in_bytes x in\n if size_in_bytes = 0\n then Int63.bin_write_t buf ~pos Int63.zero\n else (\n let bits = Z.to_bits x in\n let negative = Z.sign x = -1 in\n let tag = compute_tag ~size_in_bytes ~negative in\n let pos = Int63.bin_write_t buf ~pos tag in\n Bin_prot.Common.blit_string_buf bits ~dst_pos:pos buf ~len:size_in_bytes;\n pos + size_in_bytes)\n ;;\n\n let bin_read_t : t Bin_prot.Read.reader =\n fun buf ~pos_ref ->\n let tag = Core_kernel.Int63.bin_read_t buf ~pos_ref in\n if Int63.equal tag Int63.zero\n then Z.zero\n else (\n let negative = Int63.(tag land one = one) in\n let size_in_bytes = Int63.(to_int_exn (shift_right tag 1)) in\n (* Even though we could cache a buffer for small sizes, the extra logic leads to\n a decrease in performance *)\n let bytes = Bytes.create size_in_bytes in\n Bin_prot.Common.blit_buf_bytes ~src_pos:!pos_ref buf bytes ~len:size_in_bytes;\n let abs =\n Z.of_bits (Bytes.unsafe_to_string ~no_mutation_while_string_reachable:bytes)\n in\n pos_ref := !pos_ref + size_in_bytes;\n if negative then Z.neg abs else abs)\n ;;\n\n let module_name = \"Bigint.Stable.V2.t\"\n\n let bin_writer_t : t Bin_prot.Type_class.writer =\n { size = bin_size_t; write = bin_write_t }\n ;;\n\n let __bin_read_t__ _buf ~pos_ref _vint =\n Bin_prot.Common.raise_variant_wrong_type module_name !pos_ref\n ;;\n\n let bin_reader_t : t Bin_prot.Type_class.reader =\n { read = bin_read_t; vtag_read = __bin_read_t__ }\n ;;\n\n let bin_shape_t : Bin_prot.Shape.t =\n Bin_prot.Shape.basetype\n (Bin_prot.Shape.Uuid.of_string \"7a8cceb2-f3a2-11e9-b7cb-aae95a547ff6\")\n []\n ;;\n\n let bin_t : t Bin_prot.Type_class.t =\n { shape = bin_shape_t; writer = bin_writer_t; reader = bin_reader_t }\n ;;\n end\nend\n\nmodule Unstable = struct\n include Stable.V1\n include Stringable_t\n\n let t_sexp_grammar = [%sexp_grammar: String.t]\n let of_zarith_bigint t = t\n let to_zarith_bigint t = t\n\n let ( /% ) x y =\n if Z.sign y >= 0\n then Z.ediv x y\n else\n failwithf\n \"%s.(%s /%% %s) : divisor must be positive\"\n module_name\n (to_string x)\n (to_string y)\n ()\n ;;\n\n let ( % ) x y =\n if Z.sign y >= 0\n then Z.erem x y\n else\n failwithf\n \"%s.(%s %% %s) : divisor must be positive\"\n module_name\n (to_string x)\n (to_string y)\n ()\n ;;\n\n let hash_fold_t state t = Int.hash_fold_t state (Z.hash t)\n let hash = Z.hash\n let compare = Z.compare\n let ( - ) = Z.( - )\n let ( + ) = Z.( + )\n let ( * ) = Z.( * )\n let ( / ) = Z.( / )\n let rem = Z.rem\n let ( ~- ) = Z.( ~- )\n let neg = Z.neg\n let abs = Z.abs\n let succ = Z.succ\n let pred = Z.pred\n let equal = Z.equal\n let ( = ) = Z.equal\n let ( < ) = Z.lt\n let ( > ) = Z.gt\n let ( <= ) = Z.leq\n let ( >= ) = Z.geq\n let max = Z.max\n let min = Z.min\n let ascending = compare\n let shift_right = Z.shift_right\n let shift_left = Z.shift_left\n let bit_not = Z.lognot\n let bit_xor = Z.logxor\n let bit_or = Z.logor\n let bit_and = Z.logand\n let ( land ) = bit_and\n let ( lor ) = bit_or\n let ( lxor ) = bit_xor\n let lnot = bit_not\n let ( lsl ) = shift_left\n let ( asr ) = shift_right\n let of_int = Z.of_int\n let of_int32 = Z.of_int32\n let of_int64 = Z.of_int64\n let of_nativeint = Z.of_nativeint\n let of_float_unchecked = Z.of_float\n let of_float = Z.of_float\n let of_int_exn = of_int\n let of_int32_exn = of_int32\n let of_int64_exn = of_int64\n let of_nativeint_exn = of_nativeint\n let to_int_exn = Z.to_int\n let to_int32_exn = Z.to_int32\n let to_int64_exn = Z.to_int64\n let to_nativeint_exn = Z.to_nativeint\n let to_float = Z.to_float\n let zero = Z.zero\n let one = Z.one\n let minus_one = Z.minus_one\n let to_int t = if Z.fits_int t then Some (Z.to_int t) else None\n let to_int32 t = if Z.fits_int32 t then Some (Z.to_int32 t) else None\n let to_int64 t = if Z.fits_int64 t then Some (Z.to_int64 t) else None\n let to_nativeint t = if Z.fits_nativeint t then Some (Z.to_nativeint t) else None\n let ( <> ) x y = not (equal x y)\n let incr cell = cell := succ !cell\n let decr cell = cell := pred !cell\n let pow x y = Z.pow x (to_int_exn y)\n let ( ** ) x y = pow x y\n let popcount x = Z.popcount x\nend\n\nmodule T_math = Int_math.Make (Unstable)\nmodule T_conversions = Int_conversions.Make (Unstable)\nmodule T_comparable_with_zero = Comparable.Validate_with_zero (Unstable)\n\nmodule T_identifiable = Identifiable.Make (struct\n let module_name = module_name\n\n include Unstable\n end)\n\n(* Including in opposite order to shadow functorized bindings with direct bindings. *)\nmodule O = struct\n include T_identifiable\n include T_comparable_with_zero\n include T_conversions\n include T_math\n include Unstable\nend\n\ninclude (O : module type of O with type t := t)\n\nmodule Make_random (State : sig\n type t\n\n val bits : t -> int\n val int : t -> int -> int\n end) : sig\n val random : state:State.t -> t -> t\nend = struct\n (* Uniform random generation of Bigint values.\n\n [random ~state range] chooses a [depth] and generates random values using\n [Random.State.bits state], called [1 lsl depth] times and concatenated. The\n preliminary result [n] therefore satisfies [0 <= n < 1 lsl (30 lsl depth)].\n\n In order for the random choice to be uniform between [0] and [range-1], there must\n exist [k > 0] such that [n < k * range <= 1 lsl (30 lsl depth)]. If so, [n % range]\n is returned. Otherwise the random choice process is repeated from scratch.\n\n The [depth] value is chosen so that repeating is uncommon (1 in 1,000 or less). *)\n\n let bits_at_depth ~depth = Int.shift_left 30 depth\n let range_at_depth ~depth = shift_left one (bits_at_depth ~depth)\n\n let rec choose_bit_depth_for_range_from ~range ~depth =\n if range_at_depth ~depth >= range\n then depth\n else choose_bit_depth_for_range_from ~range ~depth:(Int.succ depth)\n ;;\n\n let choose_bit_depth_for_range ~range = choose_bit_depth_for_range_from ~range ~depth:0\n\n let rec random_bigint_at_depth ~state ~depth =\n if Int.equal depth 0\n then of_int (State.bits state)\n else (\n let prev_depth = Int.pred depth in\n let prefix = random_bigint_at_depth ~state ~depth:prev_depth in\n let suffix = random_bigint_at_depth ~state ~depth:prev_depth in\n bit_or (shift_left prefix (bits_at_depth ~depth:prev_depth)) suffix)\n ;;\n\n let random_value_is_uniform_in_range ~range ~depth n =\n let k = range_at_depth ~depth / range in\n n < k * range\n ;;\n\n let rec large_random_at_depth ~state ~range ~depth =\n let result = random_bigint_at_depth ~state ~depth in\n if random_value_is_uniform_in_range ~range ~depth result\n then result % range\n else large_random_at_depth ~state ~range ~depth\n ;;\n\n let large_random ~state ~range =\n let tolerance_factor = of_int 1_000 in\n let depth = choose_bit_depth_for_range ~range:(range * tolerance_factor) in\n large_random_at_depth ~state ~range ~depth\n ;;\n\n let random ~state range =\n if range <= zero\n then\n failwithf \"Bigint.random: argument %s <= 0\" (to_string_hum range) ()\n (* Note that it's not safe to do [1 lsl 30] on a 32-bit machine (with 31-bit signed\n integers) *)\n else if range < shift_left one 30\n then of_int (State.int state (to_int_exn range))\n else large_random ~state ~range\n ;;\nend\n\nmodule Random_internal = Make_random (Random.State)\n\nlet random ?(state = Random.State.default) range = Random_internal.random ~state range\n\nmodule For_quickcheck : sig\n include Quickcheckable.S_int with type t := t\n\n val gen_negative : t Quickcheck.Generator.t\n val gen_positive : t Quickcheck.Generator.t\nend = struct\n module Generator = Quickcheck.Generator\n open Generator.Let_syntax\n\n module Uniform = Make_random (struct\n type t = Splittable_random.State.t\n\n let int t range = Splittable_random.int t ~lo:0 ~hi:(Int.pred range)\n let bits t = int t (Int.shift_left 1 30)\n end)\n\n let random_uniform ~state lo hi = lo + Uniform.random ~state (succ (hi - lo))\n\n let gen_uniform_incl lower_bound upper_bound =\n if lower_bound > upper_bound\n then\n raise_s\n [%message\n \"Bigint.gen_uniform_incl: bounds are crossed\"\n (lower_bound : t)\n (upper_bound : t)];\n Generator.create (fun ~size:_ ~random:state ->\n random_uniform ~state lower_bound upper_bound)\n ;;\n\n let gen_incl lower_bound upper_bound =\n Generator.weighted_union\n [ 0.05, Generator.return lower_bound\n ; 0.05, Generator.return upper_bound\n ; 0.9, gen_uniform_incl lower_bound upper_bound\n ]\n ;;\n\n let min_represented_by_n_bits n =\n if Int.equal n 0 then zero else shift_left one (Int.pred n)\n ;;\n\n let max_represented_by_n_bits n = pred (shift_left one n)\n\n let gen_log_uniform_incl lower_bound upper_bound =\n if lower_bound < zero || lower_bound > upper_bound\n then\n raise_s\n [%message\n \"Bigint.gen_log_incl: invalid bounds\" (lower_bound : t) (upper_bound : t)];\n let min_bits = Z.numbits lower_bound in\n let max_bits = Z.numbits upper_bound in\n let%bind bits = Int.gen_uniform_incl min_bits max_bits in\n gen_uniform_incl\n (max lower_bound (min_represented_by_n_bits bits))\n (min upper_bound (max_represented_by_n_bits bits))\n ;;\n\n let gen_log_incl lower_bound upper_bound =\n Generator.weighted_union\n [ 0.05, Generator.return lower_bound\n ; 0.05, Generator.return upper_bound\n ; 0.9, gen_log_uniform_incl lower_bound upper_bound\n ]\n ;;\n\n let gen_positive =\n let%bind extra_bytes = Generator.size in\n let num_bytes = Int.succ extra_bytes in\n let num_bits = Int.( * ) num_bytes 8 in\n gen_log_uniform_incl one (pred (shift_left one num_bits))\n ;;\n\n let gen_negative = Generator.map gen_positive ~f:neg\n\n let quickcheck_generator =\n Generator.weighted_union\n [ 0.45, gen_positive; 0.1, Generator.return zero; 0.45, gen_negative ]\n ;;\n\n let quickcheck_observer =\n Quickcheck.Observer.create (fun t ~size:_ ~hash -> hash_fold_t hash t)\n ;;\n\n let quickcheck_shrinker = Quickcheck.Shrinker.empty ()\nend\n\ninclude For_quickcheck\n\nmodule Hex = struct\n type nonrec t = t [@@deriving bin_io, typerep]\n\n module M = Base.Int_conversions.Make_hex (struct\n type nonrec t = t [@@deriving hash, compare]\n\n let to_string i = Z.format \"%x\" i\n\n let char_is_hex_digit = function\n | '0' .. '9' | 'a' .. 'f' | 'A' .. 'F' -> true\n | _ -> false\n ;;\n\n let of_hex_string_no_underscores str = Z.of_string_base 16 str\n\n let of_string str =\n of_string_base\n str\n ~name:\"Hex.of_string\"\n ~char_is_digit:char_is_hex_digit\n ~of_string_no_underscores:of_hex_string_no_underscores\n ;;\n\n let ( < ) = ( < )\n let neg = neg\n let zero = zero\n let module_name = module_name ^ \".Hex\"\n end)\n\n include (\n M.Hex :\n module type of struct\n include M.Hex\n end\n with type t := t)\nend\n","open Core_kernel\n\ntype 'f t =\n | Constant of 'f\n | Var of int\n | Add of 'f t * 'f t\n | Scale of 'f * 'f t\n[@@deriving sexp]\n\ntype 'f cvar = 'f t [@@deriving sexp]\n\nlet to_constant_and_terms ~equal ~add ~mul ~zero ~one =\n let rec go scale constant terms = function\n | Constant c ->\n (add constant (mul scale c), terms)\n | Var v ->\n (constant, (scale, v) :: terms)\n | Scale (s, t) ->\n go (mul s scale) constant terms t\n | Add (x1, x2) ->\n let c1, terms1 = go scale constant terms x1 in\n go scale c1 terms1 x2\n in\n fun t ->\n let c, ts = go one zero [] t in\n let c = if equal c zero then None else Some c in\n (c, ts)\n\nmodule Unsafe = struct\n let of_index v = Var v\nend\n\nmodule Make (Field : Snarky_intf.Field.Extended) = struct\n type t = Field.t cvar [@@deriving sexp]\n\n let length _ = failwith \"TODO\"\n\n module Unsafe = Unsafe\n\n let scratch = Field.of_int 0\n\n let eval (`Return_values_will_be_mutated context) t0 =\n let open Field in\n let rec go = function\n | Constant c, Some scale ->\n c * scale\n | Constant c, None ->\n c\n | Var v, Some scale ->\n context v * scale\n | Var v, None ->\n context v\n | Scale (s, t), Some scale ->\n go (t, Some (scale * s))\n | Scale (s, t), None ->\n go (t, Some s)\n | Add (t1, t2), Some scale ->\n (go (t1, None) + go (t2, None)) * scale\n | Add (t1, t2), None ->\n go (t1, None) + go (t2, None)\n in\n go (t0, None)\n\n let constant c = Constant c\n\n let to_constant_and_terms =\n let rec go scale constant terms = function\n | Constant c ->\n (Field.add constant (Field.mul scale c), terms)\n | Var v ->\n (constant, (scale, v) :: terms)\n | Scale (s, t) ->\n go (Field.mul s scale) constant terms t\n | Add (x1, x2) ->\n let c1, terms1 = go scale constant terms x1 in\n go scale c1 terms1 x2\n in\n fun t ->\n let c, ts = go Field.one Field.zero [] t in\n let c = if Field.equal c Field.zero then None else Some c in\n (c, ts)\n\n let add x y =\n match (x, y) with\n | Constant x, _ when Field.(equal x zero) ->\n y\n | _, Constant y when Field.(equal y zero) ->\n x\n | Constant x, Constant y ->\n Constant (Field.add x y)\n | _, _ ->\n Add (x, y)\n\n let scale x s =\n if Field.(equal s zero) then Constant Field.zero\n else if Field.(equal s one) then x\n else\n match x with\n | Constant x ->\n Constant (Field.mul x s)\n | Scale (sx, x) ->\n Scale (Field.mul sx s, x)\n | _ ->\n Scale (s, x)\n\n let neg_one = Field.(sub zero one)\n\n let sub t1 t2 =\n match (t1, t2) with\n | Constant x, Constant y ->\n Constant (Field.sub x y)\n | _ ->\n add t1 (scale t2 neg_one)\n\n let linear_combination (terms : (Field.t * t) list) : t =\n List.fold terms ~init:(constant Field.zero) ~f:(fun acc (c, t) ->\n add acc (scale t c) )\n\n let sum vs = linear_combination (List.map vs ~f:(fun v -> (Field.one, v)))\n\n let ( + ) = add\n\n let ( - ) = sub\n\n let ( * ) c x = scale x c\n\n let negate x = scale x neg_one\n\n let to_json x =\n let singleton = Map.singleton (module Int) in\n let join = Map.merge_skewed ~combine:(fun ~key:_ -> Field.add) in\n let rec go scale = function\n | Constant f ->\n singleton 0 (Field.mul scale f)\n | Var i ->\n singleton i scale\n | Add (x, y) ->\n join (go scale x) (go scale y)\n | Scale (s, x) ->\n go Field.(scale * s) x\n in\n let map = go Field.one x in\n `Assoc\n (List.filter_map (Map.to_alist map) ~f:(fun (i, f) ->\n if Field.(equal f zero) then None\n else Some (Int.to_string i, `String (Field.to_string f)) ) )\nend\n","open Base\n\ntype ('var, 'field) basic = ..\n\nmodule Conv (F : sig\n type (_, _) t\nend) =\nstruct\n type t =\n { to_basic : 'v 'f. ('v, 'f) F.t -> ('v, 'f) basic\n ; of_basic : 'v 'f. ('v, 'f) basic -> ('v, 'f) F.t\n }\nend\n\nmodule type S = sig\n type (_, _) t [@@deriving sexp]\n\n val map : ('a, 'f) t -> f:('a -> 'b) -> ('b, 'f) t\n\n (* TODO: Try making this a functor and seeing how it affects performance *)\n val eval :\n (module Snarky_intf.Field.S with type t = 'f)\n -> ('v -> 'f)\n -> ('v, 'f) t\n -> bool\nend\n\nmodule Basic = struct\n type ('v, 'f) t = ('v, 'f) basic\n\n module type S_with_conv = sig\n include S\n\n val to_basic : ('v, 'f) t -> ('v, 'f) basic\n\n val of_basic : ('v, 'f) basic -> ('v, 'f) t\n end\n\n module Entry = struct\n type t = (module S_with_conv)\n end\n\n let cases : Entry.t list ref = ref []\n\n let add_case m = cases := m :: !cases\n\n let case f =\n List.find_map_exn !cases ~f:(fun m -> Option.try_with (fun () -> f m))\n\n let sexp_of_t f1 f2 t =\n case (fun (module M) -> M.sexp_of_t f1 f2 (M.of_basic t))\n\n let t_of_sexp f1 f2 s =\n case (fun (module M) -> M.to_basic (M.t_of_sexp f1 f2 s))\n\n let eval (type f) (fm : (module Snarky_intf.Field.S with type t = f))\n (f : 'v -> f) (t : ('v, f) basic) : bool =\n case (fun (module M) -> M.eval fm f (M.of_basic t))\n\n let map t ~f = case (fun (module M) -> M.to_basic (M.map (M.of_basic t) ~f))\nend\n\nmodule Add_kind (C : S) : sig\n type ('v, 'f) basic += T of ('v, 'f) C.t\nend = struct\n type ('v, 'f) basic += T of ('v, 'f) C.t\n\n module M = struct\n include C\n\n let to_basic x = T x\n\n let of_basic = function T x -> x | _ -> failwith \"different constructor\"\n end\n\n let () = Basic.add_case (module M)\nend\n\n(* We special case these for compatibility with existing code. *)\ntype ('var, _) basic +=\n | Boolean of 'var\n | Equal of 'var * 'var\n | Square of 'var * 'var\n | R1CS of 'var * 'var * 'var\n\nlet basic_of_sexp = Basic.t_of_sexp\n\nlet sexp_of_basic = Basic.sexp_of_t\n\nlet () =\n let unhandled s = Core_kernel.failwithf \"%s: non-basic constraint\" s () in\n let module Essential = struct\n type 'var t =\n | Boolean of 'var\n | Equal of 'var * 'var\n | Square of 'var * 'var\n | R1CS of 'var * 'var * 'var\n [@@deriving sexp]\n\n let to_basic : 'v t -> ('v, _) basic = function\n | Boolean x ->\n Boolean x\n | Equal (x, y) ->\n Equal (x, y)\n | Square (x, y) ->\n Square (x, y)\n | R1CS (x, y, z) ->\n R1CS (x, y, z)\n\n let of_basic : ('v, _) basic -> 'v t = function\n | Boolean x ->\n Boolean x\n | Equal (x, y) ->\n Equal (x, y)\n | Square (x, y) ->\n Square (x, y)\n | R1CS (x, y, z) ->\n R1CS (x, y, z)\n | _ ->\n unhandled \"of_basic\"\n end in\n let module M = struct\n type ('v, 'f) t = ('v, 'f) basic\n\n let sexp_of_t f _ t = Essential.(sexp_of_t f (of_basic t))\n\n let t_of_sexp f _ s = Essential.(to_basic (t_of_sexp f s))\n\n let of_basic = Fn.id\n\n let to_basic = Fn.id\n\n let map t ~f =\n match t with\n | Boolean v ->\n Boolean (f v)\n | Equal (v1, v2) ->\n Equal (f v1, f v2)\n | R1CS (v1, v2, v3) ->\n R1CS (f v1, f v2, f v3)\n | Square (a, c) ->\n Square (f a, f c)\n | _ ->\n unhandled \"map\"\n\n let eval (type f v) (module Field : Snarky_intf.Field.S with type t = f)\n (get_value : v -> f) (t : (v, f) basic) : bool =\n match t with\n | Boolean v ->\n let x = get_value v in\n Field.(equal x zero || equal x one)\n | Equal (v1, v2) ->\n Field.equal (get_value v1) (get_value v2)\n | R1CS (v1, v2, v3) ->\n Field.(equal (mul (get_value v1) (get_value v2)) (get_value v3))\n | Square (a, c) ->\n Field.equal (Field.square (get_value a)) (get_value c)\n | _ ->\n unhandled \"eval\"\n end in\n Basic.add_case (module M)\n\ntype ('v, 'f) basic_with_annotation =\n { basic : ('v, 'f) basic; annotation : string option }\n[@@deriving sexp]\n\ntype ('v, 'f) t = ('v, 'f) basic_with_annotation [@@deriving sexp]\n\nmodule T = struct\n let create_basic ?label basic = { basic; annotation = label }\n\n let override_label { basic; annotation = a } label_opt =\n { basic\n ; annotation = (match label_opt with Some x -> Some x | None -> a)\n }\n\n let equal ?label x y = create_basic ?label (Equal (x, y))\n\n let boolean ?label x = create_basic ?label (Boolean x)\n\n let r1cs ?label a b c = create_basic ?label (R1CS (a, b, c))\n\n let square ?label a c = create_basic ?label (Square (a, c))\n\n let annotation (t : _ t) =\n match t.annotation with Some str -> str | None -> \"\"\nend\n\ninclude T\n","open Core_kernel\nmodule Bignum_bigint = Bigint\n\n(** Yojson-compatible JSON type. *)\ntype 'a json =\n [> `String of string\n | `Assoc of (string * 'a json) list\n | `List of 'a json list ]\n as\n 'a\n\nmodule type S = sig\n module Field : Snarky_intf.Field.Full\n\n module Bigint : sig\n include Snarky_intf.Bigint_intf.Extended with type field := Field.t\n\n val of_bignum_bigint : Bignum_bigint.t -> t\n\n val to_bignum_bigint : t -> Bignum_bigint.t\n end\n\n module Cvar : sig\n type t = Field.t Cvar.t [@@deriving sexp]\n\n val length : t -> int\n\n module Unsafe : sig\n val of_index : int -> t\n end\n\n val eval :\n [ `Return_values_will_be_mutated of int -> Field.t ] -> t -> Field.t\n\n val constant : Field.t -> t\n\n val to_constant_and_terms : t -> Field.t option * (Field.t * int) list\n\n val add : t -> t -> t\n\n val negate : t -> t\n\n val scale : t -> Field.t -> t\n\n val sub : t -> t -> t\n\n val linear_combination : (Field.t * t) list -> t\n\n val sum : t list -> t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val ( * ) : Field.t -> t -> t\n\n val var_indices : t -> int list\n\n val to_constant : t -> Field.t option\n end\n\n module R1CS_constraint_system :\n Backend_intf.Constraint_system_intf with module Field := Field\n\n module Constraint : sig\n type t = (Cvar.t, Field.t) Constraint.t [@@deriving sexp]\n\n type 'k with_constraint_args = ?label:string -> 'k\n\n val boolean : (Cvar.t -> t) with_constraint_args\n\n val equal : (Cvar.t -> Cvar.t -> t) with_constraint_args\n\n val r1cs : (Cvar.t -> Cvar.t -> Cvar.t -> t) with_constraint_args\n\n val square : (Cvar.t -> Cvar.t -> t) with_constraint_args\n\n val annotation : t -> string\n\n val eval :\n (Cvar.t, Field.t) Constraint.basic_with_annotation\n -> (Cvar.t -> Field.t)\n -> bool\n end\nend\n\nmodule Make (Backend : Backend_intf.S) :\n S\n with type Field.t = Backend.Field.t\n and type Field.Vector.t = Backend.Field.Vector.t\n and type Bigint.t = Backend.Bigint.t\n and type R1CS_constraint_system.t = Backend.R1CS_constraint_system.t =\nstruct\n open Backend\n\n module Bigint = struct\n include Bigint\n\n let of_bignum_bigint n = of_decimal_string (Bignum_bigint.to_string n)\n\n let to_bignum_bigint n =\n let rec go i two_to_the_i acc =\n if i = Field.size_in_bits then acc\n else\n let acc' =\n if test_bit n i then Bignum_bigint.(acc + two_to_the_i) else acc\n in\n go (i + 1) Bignum_bigint.(two_to_the_i + two_to_the_i) acc'\n in\n go 0 Bignum_bigint.one Bignum_bigint.zero\n end\n\n module Field = struct\n include Field\n\n let size = Bigint.to_bignum_bigint Backend.field_size\n\n let inv x = if equal x zero then failwith \"Field.inv: zero\" else inv x\n\n (* TODO: Optimize *)\n let div x y = mul x (inv y)\n\n let negate x = sub zero x\n\n let unpack x =\n let n = Bigint.of_field x in\n List.init size_in_bits ~f:(fun i -> Bigint.test_bit n i)\n\n let project_reference =\n let rec go x acc = function\n | [] ->\n acc\n | b :: bs ->\n go (Field.add x x) (if b then Field.add acc x else acc) bs\n in\n fun bs -> go Field.one Field.zero bs\n\n let _project bs =\n (* todo: 32-bit and ARM support. basically this code needs to always match the loop in the C++ of_data implementation. *)\n assert (Sys.word_size = 64 && not Sys.big_endian) ;\n let chunks_of n xs =\n List.groupi ~break:(fun i _ _ -> Int.equal (i mod n) 0) xs\n in\n let chunks64 = chunks_of 64 bs in\n let z = Char.of_int_exn 0 in\n let arr =\n Bigstring.init (8 * Backend.Bigint.length_in_bytes) ~f:(fun _ -> z)\n in\n List.(\n iteri ~f:(fun i elt ->\n Bigstring.set_int64_t_le arr ~pos:(i * 8)\n Int64.(\n foldi ~init:zero\n ~f:(fun i acc el ->\n acc + if el then shift_left one i else zero )\n elt) ))\n chunks64 ;\n Backend.Bigint.(of_data arr ~bitcount:(List.length bs) |> to_field)\n\n let project = project_reference\n\n let compare t1 t2 = Bigint.(compare (of_field t1) (of_field t2))\n\n let hash_fold_t s x =\n Bignum_bigint.hash_fold_t s Bigint.(to_bignum_bigint (of_field x))\n\n let hash = Hash.of_fold hash_fold_t\n\n let to_bignum_bigint = Fn.compose Bigint.to_bignum_bigint Bigint.of_field\n\n let of_bignum_bigint = Fn.compose Bigint.to_field Bigint.of_bignum_bigint\n\n let sexp_of_t = Fn.compose Bignum_bigint.sexp_of_t to_bignum_bigint\n\n let t_of_sexp = Fn.compose of_bignum_bigint Bignum_bigint.t_of_sexp\n\n let%test_unit \"project correctness\" =\n Quickcheck.test\n Quickcheck.Generator.(\n small_positive_int >>= fun x -> list_with_length x bool)\n ~f:(fun bs ->\n [%test_eq: string]\n (project bs |> to_string)\n (project_reference bs |> to_string) )\n\n let ( + ) = add\n\n let ( * ) = mul\n\n let ( - ) = sub\n\n let ( / ) = div\n end\n\n module Cvar = struct\n include Cvar.Make (Field)\n\n let var_indices t =\n let _, terms = to_constant_and_terms t in\n List.map ~f:(fun (_, v) -> v) terms\n\n let to_constant : t -> Field.t option = function\n | Constant x ->\n Some x\n | _ ->\n None\n end\n\n module Constraint = struct\n open Constraint\n include Constraint.T\n\n type 'k with_constraint_args = ?label:string -> 'k\n\n type t = (Cvar.t, Field.t) Constraint.t [@@deriving sexp]\n\n let m = (module Field : Snarky_intf.Field.S with type t = Field.t)\n\n let eval { basic; _ } get_value = Constraint.Basic.eval m get_value basic\n end\n\n module R1CS_constraint_system = R1CS_constraint_system\nend\n","open Core_kernel\nmodule Constraint0 = Constraint\n\nlet stack_to_string = String.concat ~sep:\"\\n\"\n\nlet eval_constraints = ref true\n\nlet eval_constraints_ref = eval_constraints\n\nmodule Simple = struct\n module Types = struct\n module Checked = struct\n type ('a, 'f) t =\n | Pure of 'a\n | Function of ('f Run_state.t -> 'f Run_state.t * 'a)\n end\n\n module Typ = struct\n include Types.Typ.T\n\n type ('var, 'value, 'f) t = ('var, 'value, 'f, (unit, 'f) Checked.t) typ\n end\n\n module Provider = struct\n include Types.Provider.T\n\n type ('a, 'f) t =\n (('a Request.t, 'f) As_prover0.t, ('a, 'f) As_prover0.t) provider\n end\n end\n\n type 'f field = 'f\n\n type ('a, 'f) t = ('a, 'f field) Types.Checked.t\n\n let eval (t : ('a, 'f) t) : 'f field Run_state.t -> 'f field Run_state.t * 'a\n =\n match t with Pure a -> fun s -> (s, a) | Function g -> g\n\n include Monad_let.Make2 (struct\n type ('a, 'f) t = ('a, 'f field) Types.Checked.t\n\n let return x : _ t = Pure x\n\n let map =\n `Custom\n (fun (x : _ t) ~f : _ t ->\n match x with\n | Pure a ->\n Pure (f a)\n | Function g ->\n Function\n (fun s ->\n let s, a = g s in\n (s, f a) ) )\n\n let bind (x : _ t) ~f : _ t =\n match x with\n | Pure a ->\n f a\n | Function g ->\n Function\n (fun s ->\n let s, a = g s in\n eval (f a) s )\n end)\nend\n\nmodule Make_checked\n (Backend : Backend_extended.S)\n (As_prover : As_prover_intf.Basic with type 'f field := Backend.Field.t) =\nstruct\n type run_state = Backend.Field.t Run_state.t\n\n module Types = struct\n module Checked = struct\n type ('a, 'f) t = ('a, Backend.Field.t) Simple.Types.Checked.t\n end\n\n module Typ = struct\n include Types.Typ.T\n\n type ('var, 'value, 'f) t = ('var, 'value, 'f, (unit, 'f) Checked.t) typ\n end\n\n module Provider = struct\n include Types.Provider.T\n\n type ('a, 'f) t =\n (('a Request.t, 'f) As_prover.t, ('a, 'f) As_prover.t) provider\n end\n end\n\n type 'f field = Backend.Field.t\n\n include Types.Checked\n\n let eval : ('a, 'f) t -> run_state -> run_state * 'a = Simple.eval\n\n include Monad_let.Make2 (struct\n include Types.Checked\n\n let map = `Custom Simple.map\n\n let bind = Simple.bind\n\n let return = Simple.return\n end)\n\n open Constraint\n open Backend\n\n let get_value (t : Field.t Run_state.t) : Cvar.t -> Field.t =\n let get_one i = Run_state.get_variable_value t i in\n Cvar.eval (`Return_values_will_be_mutated get_one)\n\n let run_as_prover x state =\n match (x, Run_state.has_witness state) with\n | Some x, true ->\n let old = Run_state.as_prover state in\n Run_state.set_as_prover state true ;\n let y = As_prover.run x (get_value state) in\n Run_state.set_as_prover state old ;\n (state, Some y)\n | _, _ ->\n (state, None)\n\n let as_prover x : _ Simple.t =\n Function\n (fun s ->\n let s', (_ : unit option) = run_as_prover (Some x) s in\n (s', ()) )\n\n let mk_lazy x : _ Simple.t =\n Function\n (fun s ->\n let old_stack = Run_state.stack s in\n ( s\n , Lazy.from_fun (fun () ->\n let stack = Run_state.stack s in\n\n (* Add a label to indicate that the new stack is the point at which\n this was forced. When printed for errors, this will split the\n stack into\n\n ...\n stack to lazy\n ...\n\n Lazy value forced at:\n ...\n stack to lazy forcing point\n ...\n *)\n let label = \"\\nLazy value forced at:\" in\n let _s', y =\n Simple.eval (x ())\n (Run_state.set_stack s (old_stack @ (label :: stack)))\n in\n y ) ) )\n\n let with_label lab t : _ Simple.t =\n Function\n (fun s ->\n let stack = Run_state.stack s in\n Option.iter (Run_state.log_constraint s) ~f:(fun f ->\n f ~at_label_boundary:(`Start, lab) None ) ;\n let s', y = Simple.eval (t ()) (Run_state.set_stack s (lab :: stack)) in\n Option.iter (Run_state.log_constraint s) ~f:(fun f ->\n f ~at_label_boundary:(`End, lab) None ) ;\n (Run_state.set_stack s' stack, y) )\n\n let log_constraint { basic; _ } s =\n match basic with\n | Boolean var ->\n Format.(asprintf \"Boolean %s\" (Field.to_string (get_value s var)))\n | Equal (var1, var2) ->\n Format.(\n asprintf \"Equal %s %s\"\n (Field.to_string (get_value s var1))\n (Field.to_string (get_value s var2)))\n | Square (var1, var2) ->\n Format.(\n asprintf \"Square %s %s\"\n (Field.to_string (get_value s var1))\n (Field.to_string (get_value s var2)))\n | R1CS (var1, var2, var3) ->\n Format.(\n asprintf \"R1CS %s %s %s\"\n (Field.to_string (get_value s var1))\n (Field.to_string (get_value s var2))\n (Field.to_string (get_value s var3)))\n | _ ->\n Format.asprintf\n !\"%{sexp:(Field.t, Field.t) Constraint0.basic}\"\n (Constraint0.Basic.map basic ~f:(get_value s))\n\n let add_constraint ~stack ({ basic; annotation } : Constraint.t)\n (Constraint_system.T ((module C), system) : Field.t Constraint_system.t) =\n let label = Option.value annotation ~default:\"\" in\n C.add_constraint system basic ~label:(stack_to_string (label :: stack))\n\n let add_constraint c : _ Simple.t =\n Function\n (fun s ->\n if Run_state.as_prover s then\n (* Don't add constraints as the prover, or the constraint system won't match! *)\n (s, ())\n else (\n Option.iter (Run_state.log_constraint s) ~f:(fun f -> f (Some c)) ;\n if\n Run_state.eval_constraints s\n && !eval_constraints\n && not (Constraint.eval c (get_value s))\n then\n failwithf\n \"Constraint unsatisfied (unreduced):\\n\\\n %s\\n\\\n %s\\n\\n\\\n Constraint:\\n\\\n %s\\n\\\n Data:\\n\\\n %s\"\n (Constraint.annotation c)\n (stack_to_string (Run_state.stack s))\n (Sexp.to_string (Constraint.sexp_of_t c))\n (log_constraint c s) () ;\n if not (Run_state.as_prover s) then\n Option.iter (Run_state.system s) ~f:(fun system ->\n add_constraint ~stack:(Run_state.stack s) c system ) ;\n (s, ()) ) )\n\n let with_handler h t : _ Simple.t =\n Function\n (fun s ->\n let handler = Run_state.handler s in\n let s', y =\n Simple.eval (t ())\n (Run_state.set_handler s (Request.Handler.push handler h))\n in\n (Run_state.set_handler s' handler, y) )\n\n let exists\n (Types.Typ.Typ\n { Types.Typ.var_of_fields\n ; value_to_fields\n ; size_in_field_elements\n ; check\n ; constraint_system_auxiliary\n ; _\n } :\n (_, _, _, _ Simple.t) Types.Typ.typ ) p : _ Simple.t =\n Function\n (fun s ->\n if Run_state.has_witness s then (\n let old = Run_state.as_prover s in\n Run_state.set_as_prover s true ;\n let value =\n As_prover.Provider.run p (Run_state.stack s) (get_value s)\n (Run_state.handler s)\n in\n Run_state.set_as_prover s old ;\n let var =\n let store_value =\n if Run_state.as_prover s then\n (* If we're nested in a prover block, create constants instead of\n storing.\n *)\n Cvar.constant\n else Run_state.store_field_elt s\n in\n let fields, aux = value_to_fields value in\n let field_vars = Array.map ~f:store_value fields in\n var_of_fields (field_vars, aux)\n in\n (* TODO: Push a label onto the stack here *)\n let s, () = Simple.eval (check var) s in\n (s, { Handle.var; value = Some value }) )\n else\n let var =\n var_of_fields\n ( Array.init size_in_field_elements ~f:(fun _ ->\n Run_state.alloc_var s () )\n , constraint_system_auxiliary () )\n in\n (* TODO: Push a label onto the stack here *)\n let s, () = Simple.eval (check var) s in\n (s, { Handle.var; value = None }) )\n\n let next_auxiliary () : _ Simple.t =\n Function (fun s -> (s, Run_state.next_auxiliary s))\n\n let direct f : _ Simple.t = Function f\n\n let constraint_count ?(weight = Fn.const 1)\n ?(log = fun ?start:_ _lab _pos -> ()) (t : unit -> _ Simple.t) =\n (* TODO: Integrate log with log_constraint *)\n let count = ref 0 in\n let log_constraint ?at_label_boundary c =\n ( match at_label_boundary with\n | None ->\n ()\n | Some (pos, lab) ->\n let start = match pos with `Start -> true | _ -> false in\n log ~start lab !count ) ;\n count := !count + Option.value_map ~default:0 ~f:weight c\n in\n let state =\n Run_state.make ~num_inputs:0 ~input:Run_state.Vector.null\n ~next_auxiliary:(ref 1) ~aux:Run_state.Vector.null\n ~eval_constraints:false ~log_constraint ~with_witness:false ()\n in\n let _ = Simple.eval (t ()) state in\n !count\nend\n\nmodule type Run_extras = sig\n type field\n\n type cvar\n\n module Types : Types.Types\n\n val get_value : field Run_state.t -> cvar -> field\n\n val run_as_prover :\n ('a, field) As_prover0.t option\n -> field Run_state.t\n -> field Run_state.t * 'a option\nend\n\nmodule Make (Backend : Backend_extended.S) = struct\n open Backend\n\n type 'f field = 'f\n\n let constraint_logger = ref None\n\n let set_constraint_logger f = constraint_logger := Some f\n\n let clear_constraint_logger () = constraint_logger := None\n\n module Checked_runner = Make_checked (Backend) (As_prover0)\n\n type run_state = Checked_runner.run_state\n\n type state = run_state\n\n type ('a, 't) run = 't -> run_state -> run_state * 'a\n\n include (\n Checked_runner :\n sig\n include\n Checked_intf.Basic\n with module Types := Checked_runner.Types\n with type 'f field := 'f Checked_runner.field\n\n include\n Run_extras\n with module Types := Checked_runner.Types\n with type field := Backend.Field.t\n and type cvar := Backend.Cvar.t\n end )\n\n module Types = Checked_runner.Types\n\n let run = Simple.eval\n\n let dummy_vector = Run_state.Vector.null\n\n let fake_state next_auxiliary stack =\n Run_state.make ~num_inputs:0 ~input:Run_state.Vector.null ~next_auxiliary\n ~aux:Run_state.Vector.null ~eval_constraints:false ~stack\n ~with_witness:false ()\n\n module State = struct\n let make ~num_inputs ~input ~next_auxiliary ~aux ?system\n ?(eval_constraints = !eval_constraints_ref) ?handler ~with_witness\n ?log_constraint () =\n let log_constraint =\n match log_constraint with\n | Some _ ->\n log_constraint\n | None ->\n !constraint_logger\n in\n (* We can't evaluate the constraints if we are not computing over a value. *)\n let eval_constraints = eval_constraints && with_witness in\n Option.iter\n (system : R1CS_constraint_system.t option)\n ~f:(fun system ->\n R1CS_constraint_system.set_primary_input_size system num_inputs ) ;\n let system =\n Option.map system ~f:(fun sys ->\n let module M = struct\n module Field = struct\n type nonrec t = Field.t\n end\n\n include R1CS_constraint_system\n end in\n Constraint_system.T ((module M), sys) )\n in\n Run_state.make ~num_inputs ~input ~next_auxiliary ~aux ?system\n ~eval_constraints ?log_constraint ?handler ~with_witness ()\n end\nend\n\nmodule type S = sig\n include Run_extras\n\n type constr\n\n type r1cs\n\n val set_constraint_logger :\n (?at_label_boundary:[ `Start | `End ] * string -> constr -> unit) -> unit\n\n val clear_constraint_logger : unit -> unit\n\n type run_state = field Run_state.t\n\n type state = run_state\n\n type ('a, 't) run = 't -> run_state -> run_state * 'a\n\n val run : ('a, field) Types.Checked.t -> run_state -> run_state * 'a\n\n module State : sig\n val make :\n num_inputs:int\n -> input:field Run_state.Vector.t\n -> next_auxiliary:int ref\n -> aux:field Run_state.Vector.t\n -> ?system:r1cs\n -> ?eval_constraints:bool\n -> ?handler:Request.Handler.t\n -> with_witness:bool\n -> ?log_constraint:\n ( ?at_label_boundary:[ `End | `Start ] * string\n -> (field Cvar.t, field) Constraint.t option\n -> unit )\n -> unit\n -> field Run_state.t\n end\nend\n","open Core_kernel\nmodule Cvar0 = Cvar\nmodule Runner = Checked_runner\n\nlet set_eval_constraints b = Runner.eval_constraints := b\n\nmodule Make\n (Backend : Backend_extended.S)\n (Checked : Checked_intf.Extended with type field = Backend.Field.t)\n (As_prover : As_prover0.Extended with type field := Backend.Field.t)\n (Runner : Runner.S\n with module Types := Checked.Types\n with type field := Backend.Field.t\n and type cvar := Backend.Cvar.t\n and type constr := Backend.Constraint.t option\n and type r1cs := Backend.R1CS_constraint_system.t) =\nstruct\n open Backend\n\n open Runners.Make (Backend) (Checked) (As_prover) (Runner)\n\n module Typ = struct\n include Types.Typ.T\n module T = Typ.Make (Checked_intf.Unextend (Checked))\n include T.T\n\n type ('var, 'value) t = ('var, 'value, Field.t) T.t\n\n let unit : (unit, unit) t = unit ()\n\n let field : (Cvar.t, Field.t) t = field ()\n end\n\n open (\n Checked :\n Checked_intf.Extended\n with module Types := Checked.Types\n with type field := field )\n\n (* [equal_constraints z z_inv r] asserts that\n if z = 0 then r = 1, or\n if z <> 0 then r = 0 and z * z_inv = 1\n *)\n let equal_constraints (z : Cvar.t) (z_inv : Cvar.t) (r : Cvar.t) =\n Checked.assert_all\n [ Constraint.r1cs ~label:\"equals_1\" z_inv z Cvar.(constant Field.one - r)\n ; Constraint.r1cs ~label:\"equals_2\" r z (Cvar.constant Field.zero)\n ]\n\n (* [equal_vars z] computes [(r, z_inv)] that satisfy the constraints in\n [equal_constraints z z_inv r].\n\n In particular, [r] is [1] if [z = 0] and [0] otherwise.\n *)\n let equal_vars (z : Cvar.t) : (Field.t * Field.t) As_prover.t =\n let open As_prover.Let_syntax in\n let%map z = As_prover.read_var z in\n if Field.equal z Field.zero then (Field.one, Field.zero)\n else (Field.zero, Field.inv z)\n\n let constant (Typ typ : _ Typ.t) x =\n let fields, aux = typ.value_to_fields x in\n let field_vars = Array.map fields ~f:(fun x -> Cvar0.Constant x) in\n typ.var_of_fields (field_vars, aux)\n\n let equal (x : Cvar.t) (y : Cvar.t) : Cvar.t Boolean.t Checked.t =\n match (x, y) with\n | Constant x, Constant y ->\n Checked.return\n (Boolean.Unsafe.create\n (Cvar.constant\n (if Field.equal x y then Field.one else Field.zero) ) )\n | _ ->\n let z = Cvar.(x - y) in\n let%bind r, inv =\n Checked.exists Typ.(tuple2 field field) ~compute:(equal_vars z)\n in\n let%map () = equal_constraints z inv r in\n Boolean.Unsafe.create r\n\n let mul ?(label = \"Checked.mul\") (x : Cvar.t) (y : Cvar.t) =\n match (x, y) with\n | Constant x, Constant y ->\n return (Cvar.constant (Field.mul x y))\n | Constant x, _ ->\n return (Cvar.scale y x)\n | _, Constant y ->\n return (Cvar.scale x y)\n | _, _ ->\n with_label label (fun () ->\n let open Let_syntax in\n let%bind z =\n Checked.exists Typ.field\n ~compute:As_prover.(map2 (read_var x) (read_var y) ~f:Field.mul)\n in\n let%map () = assert_r1cs x y z in\n z )\n\n let square ?(label = \"Checked.square\") (x : Cvar.t) =\n match x with\n | Constant x ->\n return (Cvar.constant (Field.square x))\n | _ ->\n with_label label (fun () ->\n let open Let_syntax in\n let%bind z =\n exists Typ.field\n ~compute:As_prover.(map (read_var x) ~f:Field.square)\n in\n let%map () = assert_square x z in\n z )\n\n (* We get a better stack trace by failing at the call to is_satisfied, so we\n put a bogus value for the inverse to make the constraint system unsat if\n x is zero. *)\n let inv ?(label = \"Checked.inv\") (x : Cvar.t) =\n match x with\n | Constant x ->\n return (Cvar.constant (Field.inv x))\n | _ ->\n with_label label (fun () ->\n let open Let_syntax in\n let%bind x_inv =\n exists Typ.field\n ~compute:\n As_prover.(\n map (read_var x) ~f:(fun x ->\n if Field.(equal zero x) then Field.zero\n else Backend.Field.inv x ))\n in\n let%map () =\n assert_r1cs ~label:\"field_inverse\" x x_inv\n (Cvar.constant Field.one)\n in\n x_inv )\n\n let div ?(label = \"Checked.div\") (x : Cvar.t) (y : Cvar.t) =\n match (x, y) with\n | Constant x, Constant y ->\n return (Cvar.constant (Field.( / ) x y))\n | _ ->\n with_label label (fun () ->\n let open Let_syntax in\n let%bind y_inv = inv y in\n mul x y_inv )\n\n let%snarkydef_ if_ (b : Cvar.t Boolean.t) ~(then_ : Cvar.t) ~(else_ : Cvar.t)\n =\n let open Let_syntax in\n (* r = e + b (t - e)\n r - e = b (t - e)\n *)\n let b = (b :> Cvar.t) in\n match b with\n | Constant b ->\n if Field.(equal b one) then return then_ else return else_\n | _ -> (\n match (then_, else_) with\n | Constant t, Constant e ->\n return Cvar.((t * b) + (e * (constant Field0.one - b)))\n | _, _ ->\n let%bind r =\n exists Typ.field\n ~compute:\n (let open As_prover in\n let open Let_syntax in\n let%bind b = read_var b in\n read Typ.field\n (if Field.equal b Field.one then then_ else else_))\n in\n let%map () = assert_r1cs b Cvar.(then_ - else_) Cvar.(r - else_) in\n r )\n\n let%snarkydef_ assert_non_zero (v : Cvar.t) =\n let open Let_syntax in\n let%map _ = inv v in\n ()\n\n module Boolean = struct\n open Boolean.Unsafe\n\n type var = Cvar.t Boolean.t\n\n type value = bool\n\n let true_ : var = create (Cvar.constant Field.one)\n\n let false_ : var = create (Cvar.constant Field.zero)\n\n let not (x : var) : var = create Cvar.((true_ :> Cvar.t) - (x :> Cvar.t))\n\n let if_ b ~(then_ : var) ~(else_ : var) =\n map ~f:create (if_ b ~then_:(then_ :> Cvar.t) ~else_:(else_ :> Cvar.t))\n\n (* This is unused for now as we are not using any square constraint system based\n backends. *)\n let _and_for_square_constraint_systems (x : var) (y : var) =\n (* (x + y)^2 = 2 z + x + y\n\n x^2 + 2 x*y + y^2 = 2 z + x + y\n x + 2 x*y + y = 2 z + x + y\n 2 x*y = 2 z\n x * y = z\n *)\n let x = (x :> Cvar.t) in\n let y = (y :> Cvar.t) in\n let open Let_syntax in\n let%bind z =\n exists Typ.field\n ~compute:\n (let open As_prover in\n let open Let_syntax in\n let%map x = read_var x and y = read_var y in\n if Field.(equal one x) && Field.(equal one y) then Field.one\n else Field.zero)\n in\n let%map () =\n let x_plus_y = Cvar.add x y in\n assert_square x_plus_y Cvar.((Field.of_int 2 * z) + x_plus_y)\n in\n create z\n\n let ( && ) (x : var) (y : var) : var Checked.t =\n Checked.map ~f:create (mul (x :> Cvar.t) (y :> Cvar.t))\n\n let ( &&& ) = ( && )\n\n let ( || ) x y =\n let open Let_syntax in\n let%map both_false = (not x) && not y in\n not both_false\n\n let ( ||| ) = ( || )\n\n let any = function\n | [] ->\n return false_\n | [ b1 ] ->\n return b1\n | [ b1; b2 ] ->\n b1 || b2\n | bs ->\n let open Let_syntax in\n let%map all_zero =\n equal (Cvar.sum (bs :> Cvar.t list)) (Cvar.constant Field.zero)\n in\n not all_zero\n\n let all = function\n | [] ->\n return true_\n | [ b1 ] ->\n return b1\n | [ b1; b2 ] ->\n b1 && b2\n | bs ->\n equal\n (Cvar.constant (Field.of_int (List.length bs)))\n (Cvar.sum (bs :> Cvar.t list))\n\n let to_constant (b : var) =\n Option.map (Cvar.to_constant (b :> Cvar.t)) ~f:Field.(equal one)\n\n let var_of_value b = if b then true_ else false_\n\n let typ : (var, value) Typ.t =\n let (Typ typ) =\n Typ.field\n |> Typ.transport\n ~there:(function true -> Field.one | false -> Field.zero)\n ~back:(fun x -> if Field.equal x Field.zero then false else true)\n |> Typ.transport_var\n ~there:(fun (b : var) -> (b :> Cvar.t))\n ~back:create\n in\n Typ\n { typ with\n check =\n (fun v ->\n Checked.assert_\n (Constraint.boolean ~label:\"boolean-alloc\" (v :> Cvar.t)) )\n }\n\n let typ_unchecked : (var, value) Typ.t =\n let (Typ typ) = typ in\n Typ { typ with check = (fun _ -> Checked.return ()) }\n\n let%test_unit \"all\" =\n let gen =\n let open Quickcheck.Generator in\n let open Let_syntax in\n let%bind length = small_positive_int in\n list_with_length length bool\n in\n Quickcheck.test gen ~sexp_of:[%sexp_of: bool list] ~f:(fun x ->\n let r =\n run_and_check\n (Checked.map ~f:(As_prover.read typ)\n (all (List.map ~f:(constant typ_unchecked) x)) )\n |> Or_error.ok_exn\n in\n [%test_eq: bool] r (List.for_all x ~f:Fn.id) )\n\n let ( lxor ) b1 b2 =\n match (to_constant b1, to_constant b2) with\n | Some b1, Some b2 ->\n return (constant typ (Caml.not (Bool.equal b1 b2)))\n | Some true, None ->\n return (not b2)\n | None, Some true ->\n return (not b1)\n | Some false, None ->\n return b2\n | None, Some false ->\n return b1\n | None, None ->\n (* (1 - 2 a) (1 - 2 b) = 1 - 2 c\n 1 - 2 (a + b) + 4 a b = 1 - 2 c\n - 2 (a + b) + 4 a b = - 2 c\n (a + b) - 2 a b = c\n 2 a b = a + b - c\n *)\n let open Let_syntax in\n let%bind res =\n exists typ_unchecked\n ~compute:\n As_prover.(\n map2 ~f:Bool.( <> ) (read typ_unchecked b1)\n (read typ_unchecked b2))\n in\n let%map () =\n let a = (b1 :> Cvar.t) in\n let b = (b2 :> Cvar.t) in\n let c = (res :> Cvar.t) in\n let open Cvar in\n assert_r1cs (a + a) b (a + b - c)\n in\n res\n\n module Array = struct\n let num_true (bs : var array) =\n Array.fold bs ~init:(Cvar.constant Field.zero) ~f:(fun x y ->\n Cvar.add x (y :> Cvar.t) )\n\n let any = function\n | [||] ->\n return false_\n | [| b1 |] ->\n return b1\n | [| b1; b2 |] ->\n b1 || b2\n | bs ->\n let open Let_syntax in\n let%map all_zero = equal (num_true bs) (Cvar.constant Field.zero) in\n not all_zero\n\n let all = function\n | [||] ->\n return true_\n | [| b1 |] ->\n return b1\n | [| b1; b2 |] ->\n b1 && b2\n | bs ->\n equal (Cvar.constant (Field.of_int (Array.length bs))) (num_true bs)\n\n module Assert = struct\n let any bs = assert_non_zero (num_true bs)\n\n let all bs =\n assert_equal (num_true bs)\n (Cvar.constant (Field.of_int (Array.length bs)))\n end\n end\n\n let equal (a : var) (b : var) = a lxor b >>| not\n\n let of_field x =\n let open Let_syntax in\n let%map () = assert_ (Constraint.boolean x) in\n create x\n\n module Unsafe = struct\n let of_cvar (t : Cvar.t) : var = create t\n end\n\n module Assert = struct\n let ( = ) (x : var) (y : var) = assert_equal (x :> Cvar.t) (y :> Cvar.t)\n\n let is_true (v : var) = v = true_\n\n let%snarkydef_ any (bs : var list) =\n assert_non_zero (Cvar.sum (bs :> Cvar.t list))\n\n let%snarkydef_ all (bs : var list) =\n assert_equal\n (Cvar.sum (bs :> Cvar.t list))\n (Cvar.constant (Field.of_int (List.length bs)))\n\n let%snarkydef_ exactly_one (bs : var list) =\n assert_equal (Cvar.sum (bs :> Cvar.t list)) (Cvar.constant Field.one)\n end\n\n module Expr = struct\n type t = Var of var | And of t list | Or of t list | Not of t\n\n let rec eval t =\n let open Let_syntax in\n match t with\n | Not t ->\n eval t >>| not\n | Var v ->\n return v\n | And ts ->\n Checked.all (List.map ~f:eval ts) >>= all\n | Or ts ->\n Checked.all (List.map ~f:eval ts) >>= any\n\n let assert_ t = eval t >>= Assert.is_true\n\n let ( ! ) v = Var v\n\n let ( && ) x y = And [ x; y ]\n\n let ( &&& ) = ( && )\n\n let ( || ) x y = Or [ x; y ]\n\n let ( ||| ) = ( || )\n\n let not t = Not t\n\n let any xs = Or xs\n\n let all xs = And xs\n end\n end\n\n module Typ2 = Typ\nend\n","open Core_kernel\n\nmodule Address = struct\n type t = int\nend\n\nmodule Free_hash = struct\n type 'a t = Hash_value of 'a | Hash_empty | Merge of 'a t * 'a t\n [@@deriving sexp]\n\n let diff t1 t2 =\n let module M = struct\n exception Done of bool list\n end in\n let rec go path t1 t2 =\n match (t1, t2) with\n | Hash_empty, Hash_empty ->\n None\n | Hash_value x, Hash_value y ->\n (* poly equality; we don't know type of x and y *)\n if Caml.( = ) x y then None else raise (M.Done path)\n | Merge (l1, r1), Merge (l2, r2) ->\n ignore (go (false :: path) l1 l2) ;\n ignore (go (true :: path) r1 r2) ;\n None\n | Hash_empty, Hash_value _\n | Hash_empty, Merge _\n | Hash_value _, Hash_empty\n | Hash_value _, Merge _\n | Merge _, Hash_empty\n | Merge _, Hash_value _ ->\n raise (M.Done path)\n in\n try go [] t1 t2 with M.Done addr -> Some addr\n\n let rec run t ~hash ~merge =\n match t with\n | Hash_value x ->\n hash (Some x)\n | Hash_empty ->\n hash None\n | Merge (l, r) ->\n merge (run ~hash ~merge l) (run ~hash ~merge r)\nend\n\ntype ('hash, 'a) non_empty_tree =\n | Node of 'hash * ('hash, 'a) tree * ('hash, 'a) tree\n | Leaf of 'hash * 'a\n\nand ('hash, 'a) tree = Non_empty of ('hash, 'a) non_empty_tree | Empty\n[@@deriving sexp]\n\ntype ('hash, 'a) t =\n { tree : ('hash, 'a) non_empty_tree\n ; depth : int\n ; count : int\n ; hash : 'a option -> 'hash\n ; merge : 'hash -> 'hash -> 'hash\n }\n[@@deriving sexp]\n\nlet check_exn { tree; hash; merge; _ } =\n let default = hash None in\n let rec check_hash = function\n | Non_empty t ->\n check_hash_non_empty t\n | Empty ->\n default\n and check_hash_non_empty = function\n | Leaf (h, x) ->\n (* poly equality; don't know the hash type *)\n assert (Caml.( = ) h (hash (Some x))) ;\n h\n | Node (h, l, r) ->\n (* poly equality *)\n assert (Caml.( = ) (merge (check_hash l) (check_hash r)) h) ;\n h\n in\n ignore (check_hash_non_empty tree)\n\nlet non_empty_hash = function Node (h, _, _) -> h | Leaf (h, _) -> h\n\nlet depth { depth; _ } = depth\n\nlet tree_hash ~default = function\n | Empty ->\n default\n | Non_empty t ->\n non_empty_hash t\n\nlet to_list : ('hash, 'a) t -> 'a list =\n let rec go acc = function\n | Empty ->\n acc\n | Non_empty (Leaf (_, x)) ->\n x :: acc\n | Non_empty (Node (_h, l, r)) ->\n let acc' = go acc r in\n go acc' l\n in\n fun t -> go [] (Non_empty t.tree)\n\nlet left_tree hash merge depth x =\n let empty_hash = hash None in\n let rec go i h acc =\n if i = depth then (h, acc)\n else\n let h' = merge h empty_hash in\n go (i + 1) h' (Node (h', Non_empty acc, Empty))\n in\n let h = hash (Some x) in\n go 0 h (Leaf (h, x))\n\nlet insert hash merge t0 mask0 address x =\n let default = hash None in\n let rec go mask t =\n if mask = 0 then\n match t with\n | Empty ->\n Leaf (hash (Some x), x)\n | Non_empty _ ->\n failwith \"Tree should be empty\"\n else\n let go_left = mask land address = 0 in\n let mask' = mask lsr 1 in\n match t with\n | Empty ->\n if go_left then\n let t_l' = go mask' Empty in\n Node (merge (non_empty_hash t_l') default, Non_empty t_l', Empty)\n else\n let t_r' = go mask' Empty in\n Node (merge default (non_empty_hash t_r'), Empty, Non_empty t_r')\n | Non_empty (Node (_h, t_l, t_r)) ->\n if go_left then\n let t_l' = go mask' t_l in\n Node\n ( merge (non_empty_hash t_l') (tree_hash ~default t_r)\n , Non_empty t_l'\n , t_r )\n else\n let t_r' = go mask' t_r in\n Node\n ( merge (tree_hash ~default t_l) (non_empty_hash t_r')\n , t_l\n , Non_empty t_r' )\n | Non_empty (Leaf _) ->\n failwith \"Cannot insert into leaf\"\n in\n go mask0 t0\n\nlet ith_bit n i = (n lsr i) land 1 = 1\n\nlet get { tree; depth; _ } addr0 =\n let rec get t i =\n match t with Empty -> None | Non_empty t -> get_non_empty t i\n and get_non_empty t i =\n match t with\n | Node (_, l, r) ->\n let go_right = ith_bit addr0 i in\n if go_right then get r (i - 1) else get l (i - 1)\n | Leaf (_, x) ->\n Some x\n in\n get_non_empty tree (depth - 1)\n\nlet get_exn t addr = Option.value_exn (get t addr)\n\nlet set_dirty default tree addr x =\n let rec go tree addr =\n match (tree, addr) with\n | Empty, go_right :: bs ->\n let t = Non_empty (go Empty bs) in\n let l, r = if go_right then (Empty, t) else (t, Empty) in\n Node (default, l, r)\n | Empty, [] ->\n Leaf (default, x)\n | Non_empty t, _ ->\n go_non_empty t addr\n and go_non_empty tree addr =\n match (tree, addr) with\n | Leaf _, [] ->\n Leaf (default, x)\n | Node (_, l, r), go_right :: bs ->\n let l', r' =\n if go_right then (l, Non_empty (go r bs)) else (Non_empty (go l bs), r)\n in\n Node (default, l', r')\n | Leaf _, _ :: _ | Node _, [] ->\n failwith \"Merkle_tree.set_dirty (go_non_empty): Mismatch\"\n in\n go_non_empty tree (List.rev addr)\n\nlet recompute_hashes { tree; hash; merge; _ } =\n let h =\n let default = hash None in\n fun t -> tree_hash ~default t\n in\n let rec go = function\n | Non_empty t ->\n Non_empty (go_non_empty t)\n | Empty ->\n Empty\n and go_non_empty = function\n | Leaf (_, x) ->\n Leaf (hash (Some x), x)\n | Node (_, l, r) ->\n let l' = go l in\n let r' = go r in\n Node (merge (h l') (h r'), l', r')\n in\n go_non_empty tree\n\nlet address_of_int ~depth n : bool list =\n List.init depth ~f:(fun i -> n land (1 lsl i) <> 0)\n\nlet add_many t xs =\n let default = t.hash None in\n let left_tree_dirty depth x =\n let rec go i acc =\n if i = depth then acc\n else go (i + 1) (Node (default, Non_empty acc, Empty))\n in\n go 0 (Leaf (default, x))\n in\n let add_one_dirty { tree; depth; count; hash; merge } x =\n if count = 1 lsl depth then\n let t_r = left_tree_dirty depth x in\n { tree = Node (default, Non_empty tree, Non_empty t_r)\n ; count = count + 1\n ; depth = depth + 1\n ; hash\n ; merge\n }\n else\n { tree = set_dirty default tree (address_of_int ~depth count) x\n ; count = count + 1\n ; depth\n ; hash\n ; merge\n }\n in\n let t = List.fold_left xs ~init:t ~f:add_one_dirty in\n { t with tree = recompute_hashes t }\n\nlet add { tree; depth; count; hash; merge } x =\n if count = 1 lsl depth then\n let h_r, t_r = left_tree hash merge depth x in\n let h_l = non_empty_hash tree in\n { tree = Node (merge h_l h_r, Non_empty tree, Non_empty t_r)\n ; count = count + 1\n ; depth = depth + 1\n ; hash\n ; merge\n }\n else\n { tree = insert hash merge (Non_empty tree) (1 lsl (depth - 1)) count x\n ; count = count + 1\n ; depth\n ; hash\n ; merge\n }\n\nlet root { tree; _ } = non_empty_hash tree\n\nlet create ~hash ~merge x =\n { tree = Leaf (hash (Some x), x); count = 1; depth = 0; hash; merge }\n\nlet get_path { tree; hash; depth; _ } addr0 =\n let default = hash None in\n let rec go acc t i =\n if i < 0 then acc\n else\n let go_right = ith_bit addr0 i in\n if go_right then\n match t with\n | Leaf _ ->\n failwith \"get_path\"\n | Node (_h, _t_l, Empty) ->\n failwith \"get_path\"\n | Node (_h, t_l, Non_empty t_r) ->\n go (tree_hash ~default t_l :: acc) t_r (i - 1)\n else\n match t with\n | Leaf _ ->\n failwith \"get_path\"\n | Node (_h, Empty, _t_r) ->\n failwith \"get_path\"\n | Node (_h, Non_empty t_l, t_r) ->\n go (tree_hash ~default t_r :: acc) t_l (i - 1)\n in\n go [] tree (depth - 1)\n\nlet implied_root ~merge addr0 entry_hash path0 =\n let rec go acc i path =\n match path with\n | [] ->\n acc\n | h :: hs ->\n go (if ith_bit addr0 i then merge h acc else merge acc h) (i + 1) hs\n in\n go entry_hash 0 path0\n\nlet rec free_tree_hash = function\n | Empty ->\n Free_hash.Hash_empty\n | Non_empty (Leaf (_, x)) ->\n Hash_value x\n | Non_empty (Node (_, l, r)) ->\n Merge (free_tree_hash l, free_tree_hash r)\n\nlet free_root { tree; _ } = free_tree_hash (Non_empty tree)\n\nlet get_free_path { tree; depth; _ } addr0 =\n let rec go acc t i =\n if i < 0 then acc\n else\n let go_right = ith_bit addr0 i in\n if go_right then\n match t with\n | Leaf _ ->\n failwith \"get_path\"\n | Node (_h, _t_l, Empty) ->\n failwith \"get_path\"\n | Node (_h, t_l, Non_empty t_r) ->\n go (free_tree_hash t_l :: acc) t_r (i - 1)\n else\n match t with\n | Leaf _ ->\n failwith \"get_path\"\n | Node (_h, Empty, _t_r) ->\n failwith \"get_path\"\n | Node (_h, Non_empty t_l, t_r) ->\n go (free_tree_hash t_r :: acc) t_l (i - 1)\n in\n go [] tree (depth - 1)\n\nlet implied_free_root addr0 x path0 =\n implied_root\n ~merge:(fun a b -> Free_hash.Merge (a, b))\n addr0 (Hash_value x) path0\n\ntype ('hash, 'a) merkle_tree = ('hash, 'a) t\n\nmodule Checked\n (Impl : Snark_intf.Basic) (Hash : sig\n type var\n\n type value\n\n val typ : (var, value) Impl.Typ.t\n\n val merge : height:int -> var -> var -> var Impl.Checked.t\n\n val if_ : Impl.Boolean.var -> then_:var -> else_:var -> var Impl.Checked.t\n\n val assert_equal : var -> var -> unit Impl.Checked.t\n end) (Elt : sig\n type var\n\n type value\n\n val typ : (var, value) Impl.Typ.t\n\n val hash : var -> Hash.var Impl.Checked.t\n end) =\nstruct\n open Impl\n\n module Address = struct\n type var = Boolean.var list\n\n type value = int\n\n let typ ~depth : (var, value) Typ.t =\n Typ.transport\n (Typ.list ~length:depth Boolean.typ)\n ~there:(address_of_int ~depth)\n ~back:\n (List.foldi ~init:0 ~f:(fun i acc b ->\n if b then acc lor (1 lsl i) else acc ) )\n end\n\n module Path = struct\n type value = Hash.value list\n\n type var = Hash.var list\n\n let typ ~depth : (var, value) Typ.t = Typ.(list ~length:depth Hash.typ)\n end\n\n let implied_root entry_hash addr0 path0 =\n let rec go height acc addr path =\n let open Let_syntax in\n match (addr, path) with\n | [], [] ->\n return acc\n | b :: bs, h :: hs ->\n let%bind l = Hash.if_ b ~then_:h ~else_:acc\n and r = Hash.if_ b ~then_:acc ~else_:h in\n let%bind acc' = Hash.merge ~height l r in\n go (height + 1) acc' bs hs\n | _, _ ->\n failwith\n \"Merkle_tree.Checked.implied_root: address, path length mismatch\"\n in\n go 0 entry_hash addr0 path0\n\n type _ Request.t +=\n | Get_element : Address.value -> (Elt.value * Path.value) Request.t\n | Get_path : Address.value -> Path.value Request.t\n | Set : Address.value * Elt.value -> unit Request.t\n\n (* addr0 should have least significant bit first *)\n let%snarkydef_ fetch_and_update_req ~(depth : int) root addr0 ~f :\n (Hash.var * [ `Old of Elt.var ] * [ `New of Elt.var ]) Checked.t =\n let open Let_syntax in\n let%bind prev, prev_path =\n request_witness\n Typ.(Elt.typ * Path.typ ~depth)\n As_prover.(\n read (Address.typ ~depth) addr0 >>| fun addr -> Get_element addr)\n in\n let%bind () =\n let%bind prev_entry_hash = Elt.hash prev in\n implied_root prev_entry_hash addr0 prev_path >>= Hash.assert_equal root\n in\n let%bind next = f prev in\n let%bind next_entry_hash = Elt.hash next in\n let%bind () =\n perform\n (let open As_prover in\n let open Let_syntax in\n let%map addr = read (Address.typ ~depth) addr0\n and next = read Elt.typ next in\n Set (addr, next))\n in\n let%map new_root = implied_root next_entry_hash addr0 prev_path in\n (new_root, `Old prev, `New next)\n\n (* addr0 should have least significant bit first *)\n let%snarkydef_ modify_req ~(depth : int) root addr0 ~f : Hash.var Checked.t =\n let%map root, _, _ = fetch_and_update_req ~depth root addr0 ~f in\n root\n\n (* addr0 should have least significant bit first *)\n let%snarkydef_ get_req ~(depth : int) root addr0 : Elt.var Checked.t =\n let open Let_syntax in\n let%bind prev, prev_path =\n request_witness\n Typ.(Elt.typ * Path.typ ~depth)\n As_prover.(\n map (read (Address.typ ~depth) addr0) ~f:(fun a -> Get_element a))\n in\n let%bind () =\n let%bind prev_entry_hash = Elt.hash prev in\n implied_root prev_entry_hash addr0 prev_path >>= Hash.assert_equal root\n in\n return prev\n\n (* addr0 should have least significant bit first *)\n let%snarkydef_ update_req ~(depth : int) ~root ~prev ~next addr0 :\n Hash.var Checked.t =\n let open Let_syntax in\n let%bind prev_entry_hash = Elt.hash prev\n and next_entry_hash = Elt.hash next\n and prev_path =\n request_witness (Path.typ ~depth)\n As_prover.(\n map (read (Address.typ ~depth) addr0) ~f:(fun a -> Get_path a))\n in\n let%bind () =\n implied_root prev_entry_hash addr0 prev_path >>= Hash.assert_equal root\n in\n let%bind () =\n perform\n (let open As_prover in\n let open Let_syntax in\n let%map addr = read (Address.typ ~depth) addr0\n and next = read Elt.typ next in\n Set (addr, next))\n in\n implied_root next_entry_hash addr0 prev_path\nend\n\nmodule Run = struct\n module Make\n (Impl : Snark_intf.Run_basic) (Hash : sig\n type var\n\n type value\n\n val typ : (var, value) Impl.Typ.t\n\n val merge : height:int -> var -> var -> var\n\n val if_ : Impl.Boolean.var -> then_:var -> else_:var -> var\n\n val assert_equal : var -> var -> unit\n end) (Elt : sig\n type var\n\n type value\n\n val typ : (var, value) Impl.Typ.t\n\n val hash : var -> Hash.var\n end) =\n struct\n open Impl\n\n include\n Checked\n (Impl.Internal_Basic)\n (struct\n include Hash\n\n let merge ~height x y = make_checked (fun () -> merge ~height x y)\n\n let if_ x ~then_ ~else_ = make_checked (fun () -> if_ x ~then_ ~else_)\n\n let assert_equal x y = make_checked (fun () -> assert_equal x y)\n end)\n (struct\n include Elt\n\n let hash var = make_checked (fun () -> hash var)\n end)\n\n let implied_root entry_hash addr0 path0 =\n run_checked (implied_root entry_hash addr0 path0)\n\n let modify_req ~depth root addr0 ~f =\n run_checked\n (modify_req ~depth root addr0 ~f:(fun x -> make_checked (fun () -> f x)))\n\n let get_req ~depth root addr0 = run_checked (get_req ~depth root addr0)\n\n let update_req ~depth ~root ~prev ~next addr0 =\n run_checked (update_req ~depth ~root ~prev ~next addr0)\n end\nend\n","open Core_kernel\nmodule Cvar0 = Cvar\nmodule Bignum_bigint = Bigint\n\nexception Runtime_error of string list * exn * string\n\nmodule Runner = Checked_runner\n\nlet set_eval_constraints b = Runner.eval_constraints := b\n\nmodule Make_basic\n (Backend : Backend_extended.S)\n (Checked : Checked_intf.Extended with type field = Backend.Field.t)\n (As_prover : As_prover0.Extended with type field := Backend.Field.t)\n (Ref : As_prover_ref.S\n with module Types := Checked.Types\n and type 'f field := Backend.Field.t\n and type ('a, 'f) checked := 'a Checked.t)\n (Runner : Runner.S\n with module Types := Checked.Types\n with type field := Backend.Field.t\n and type cvar := Backend.Cvar.t\n and type constr := Backend.Constraint.t option\n and type r1cs := Backend.R1CS_constraint_system.t) =\nstruct\n open Backend\n module Checked_S = Checked_intf.Unextend (Checked)\n include Runners.Make (Backend) (Checked) (As_prover) (Runner)\n module Bigint = Bigint\n module Field0 = Field\n module Cvar = Cvar\n module Constraint = Constraint\n\n module Handler = struct\n type t = Request.request -> Request.response\n end\n\n module Typ = struct\n include Types.Typ.T\n module T = Typ.Make (Checked_S)\n include T.T\n\n type ('var, 'value) t = ('var, 'value, Field.t) T.t\n\n let unit : (unit, unit) t = unit ()\n\n let field : (Cvar.t, Field.t) t = field ()\n end\n\n let constant (Typ typ : _ Typ.t) x =\n let fields, aux = typ.value_to_fields x in\n let field_vars = Array.map fields ~f:(fun x -> Cvar0.Constant x) in\n typ.var_of_fields (field_vars, aux)\n\n module As_prover = struct\n include As_prover\n\n type 'a as_prover = 'a t\n\n module Ref = Ref\n end\n\n module Handle = struct\n include Handle\n\n let value = As_prover.Handle.value\n end\n\n module Checked = struct\n include (\n Checked :\n Checked_intf.Extended\n with module Types := Checked.Types\n with type field := field )\n\n let perform req = request_witness Typ.unit req\n\n module Runner = Runner\n\n type run_state = Runner.run_state\n\n include Utils.Make (Backend) (Checked) (As_prover) (Runner)\n\n module Control = struct end\n\n let two_to_the n =\n let rec go acc i =\n if i = 0 then acc else go (Field0.add acc acc) (i - 1)\n in\n go Field0.one n\n\n type _ Request.t += Choose_preimage : Field.t * int -> bool list Request.t\n\n let choose_preimage_unchecked v ~length =\n exists\n (Typ.list Boolean.typ ~length)\n ~request:\n As_prover.(map (read_var v) ~f:(fun x -> Choose_preimage (x, length)))\n ~compute:\n (let open As_prover.Let_syntax in\n let%map x = As_prover.read_var v in\n let x = Bigint.of_field x in\n List.init length ~f:(fun i -> Bigint.test_bit x i))\n\n let packing_sum (bits : Boolean.var list) =\n let ts, _ =\n List.fold_left bits ~init:([], Field.one) ~f:(fun (acc, c) v ->\n ((c, (v :> Cvar.t)) :: acc, Field.add c c) )\n in\n Cvar.linear_combination ts\n\n let choose_preimage (v : Cvar.t) ~length : Boolean.var list t =\n let open Let_syntax in\n let%bind bits = choose_preimage_unchecked v ~length in\n let lc = packing_sum bits in\n let%map () =\n assert_r1cs ~label:\"Choose_preimage\" lc (Cvar.constant Field.one) v\n in\n bits\n\n let choose_preimage_flagged (v : Cvar.t) ~length =\n let open Let_syntax in\n let%bind bits = choose_preimage_unchecked v ~length in\n let lc = packing_sum bits in\n let%map success = equal lc v in\n (bits, `Success success)\n\n module List =\n Monad_sequence.List\n (Checked)\n (struct\n type t = Boolean.var\n\n include Boolean\n end)\n\n module Array =\n Monad_sequence.Array\n (Checked)\n (struct\n type t = Boolean.var\n\n let any = Boolean.Array.any\n\n let all = Boolean.Array.all\n end)\n end\n\n module Cvar1 = struct\n include Cvar\n\n let project =\n let two = Field.of_int 2 in\n fun (vars : Checked.Boolean.var list) ->\n let rec go res = function\n | [] ->\n res\n | v :: vs ->\n go Cvar0.(Add (v, Scale (two, res))) vs\n in\n match List.rev (vars :> Cvar.t list) with\n | [] ->\n Cvar0.Constant Field.zero\n | v :: vs ->\n go v vs\n\n let pack vars =\n assert (List.length vars < Field.size_in_bits) ;\n project vars\n\n let unpack v ~length =\n assert (length < Field.size_in_bits) ;\n Checked.choose_preimage v ~length\n\n let unpack_flagged v ~length =\n assert (length < Field.size_in_bits) ;\n Checked.choose_preimage_flagged v ~length\n end\n\n module Field = struct\n include Field0\n\n let gen =\n Quickcheck.Generator.map\n Bignum_bigint.(gen_incl zero (size - one))\n ~f:(fun x -> Bigint.(to_field (of_bignum_bigint x)))\n\n let gen_incl lo hi =\n let lo_bigint = Bigint.(to_bignum_bigint @@ of_field lo) in\n let hi_bigint = Bigint.(to_bignum_bigint @@ of_field hi) in\n Quickcheck.Generator.map\n Bignum_bigint.(gen_incl lo_bigint hi_bigint)\n ~f:(fun x -> Bigint.(to_field (of_bignum_bigint x)))\n\n let gen_uniform =\n Quickcheck.Generator.map\n Bignum_bigint.(gen_uniform_incl zero (size - one))\n ~f:(fun x -> Bigint.(to_field (of_bignum_bigint x)))\n\n let gen_uniform_incl lo hi =\n let lo_bigint = Bigint.(to_bignum_bigint @@ of_field lo) in\n let hi_bigint = Bigint.(to_bignum_bigint @@ of_field hi) in\n Quickcheck.Generator.map\n Bignum_bigint.(gen_uniform_incl lo_bigint hi_bigint)\n ~f:(fun x -> Bigint.(to_field (of_bignum_bigint x)))\n\n let typ = Typ.field\n\n module Var = Cvar1\n\n let parity x = Bigint.(test_bit (of_field x) 0)\n\n module Checked = struct\n include Cvar1\n\n let equal = Checked.equal\n\n let mul x y = Checked.mul ~label:\"Field.Checked.mul\" x y\n\n let square x = Checked.square ~label:\"Field.Checked.square\" x\n\n let div x y = Checked.div ~label:\"Field.Checked.div\" x y\n\n let inv x = Checked.inv ~label:\"Field.Checked.inv\" x\n\n let sqrt (x : Cvar.t) : Cvar.t Checked.t =\n match x with\n | Constant x ->\n Checked.return (Cvar.constant (Field.sqrt x))\n | _ ->\n let open Checked in\n let open Let_syntax in\n let%bind y =\n exists ~compute:As_prover.(map (read_var x) ~f:Field.sqrt) typ\n in\n let%map () = assert_square y x in\n y\n\n let quadratic_nonresidue =\n lazy\n (let rec go i =\n let x = Field.of_int i in\n if not (Field.is_square x) then x else go Int.(i + 1)\n in\n go 2 )\n\n (* The trick here is the following.\n\n Let beta be a known non-square.\n\n x is not a square iff beta*x is a square\n\n So we guess the result [is_square] and y a sqrt of one of {x, beta*x} and assert\n\n y * y = is_square * x + (1 - is_square) * (beta * x)\n\n which, letting B = beta*x holds iff\n\n y * y\n = is_square * x + B - is_square * B\n = is_square * (x - B) + B\n *)\n let sqrt_check x =\n let open Checked in\n let open Let_syntax in\n let%bind is_square =\n exists\n ~compute:As_prover.(map (read_var x) ~f:Field.is_square)\n Boolean.typ\n in\n let%bind y =\n exists typ\n ~compute:\n As_prover.(\n Let_syntax.(\n let%map is_square = read Boolean.typ is_square\n and x = read_var x in\n if is_square then Field.sqrt x\n else Field.(sqrt (Lazy.force quadratic_nonresidue * x))))\n in\n let b = scale x (Lazy.force quadratic_nonresidue) in\n let%bind t = mul (is_square :> Var.t) (x - b) in\n let%map () = assert_square y (t + b) in\n (y, is_square)\n\n let is_square x =\n let open Checked.Let_syntax in\n let%map _, b = sqrt_check x in\n b\n\n let%test_unit \"is_square\" =\n let x = Field.random () in\n let typf = Typ.field in\n let x2 = Field.square x in\n assert (Field.(equal (x * x) x2)) ;\n let run elt =\n let answer =\n run_and_check\n (Checked.map\n ~f:(As_prover.read Checked.Boolean.typ)\n Checked.(\n Let_syntax.(\n let%bind x = exists typf ~compute:(As_prover.return elt) in\n is_square x)) )\n |> Or_error.ok_exn\n in\n answer\n in\n assert (run x2) ;\n assert (not (run (Field.mul (Lazy.force quadratic_nonresidue) x2)))\n\n let choose_preimage_var = Checked.choose_preimage\n\n type comparison_result =\n { less : Checked.Boolean.var; less_or_equal : Checked.Boolean.var }\n\n let if_ = Checked.if_\n\n let compare ~bit_length a b =\n (* Overview of the logic:\n let n = bit_length\n We have 0 <= a < 2^n, 0 <= b < 2^n, and so\n -2^n < b - a < 2^n\n If (b - a) >= 0, then\n 2^n <= 2^n + b - a < 2^{n+1},\n and so the n-th bit must be set.\n If (b - a) < 0 then\n 0 < 2^n + b - a < 2^n\n and so the n-th bit must not be set.\n Thus, we can use the n-th bit of 2^n + b - a to determine whether\n (b - a) >= 0 <-> a <= b.\n\n We also need that the maximum value\n 2^n + (2^n - 1) - 0 = 2^{n+1} - 1\n fits inside the field, so for the max field element f,\n 2^{n+1} - 1 <= f -> n+1 <= log2(f) = size_in_bits - 1\n *)\n assert (Int.(bit_length <= size_in_bits - 2)) ;\n let open Checked in\n let open Let_syntax in\n [%with_label_ \"compare\"] (fun () ->\n let alpha_packed =\n Cvar.(constant (two_to_the bit_length) + b - a)\n in\n let%bind alpha = unpack alpha_packed ~length:Int.(bit_length + 1) in\n let prefix, less_or_equal =\n match Core_kernel.List.split_n alpha bit_length with\n | p, [ l ] ->\n (p, l)\n | _ ->\n failwith \"compare: Invalid alpha\"\n in\n let%bind not_all_zeros = Boolean.any prefix in\n let%map less = Boolean.(less_or_equal && not_all_zeros) in\n { less; less_or_equal } )\n\n module Assert = struct\n let lt ~bit_length (x : Cvar.t) (y : Cvar.t) =\n match (x, y) with\n | Constant x, Constant y ->\n assert (Field.compare x y < 0) ;\n Checked.return ()\n | _ ->\n let open Checked in\n let open Let_syntax in\n let%bind { less; _ } = compare ~bit_length x y in\n Boolean.Assert.is_true less\n\n let lte ~bit_length (x : Cvar.t) (y : Cvar.t) =\n match (x, y) with\n | Constant x, Constant y ->\n assert (Field.compare x y <= 0) ;\n Checked.return ()\n | _ ->\n let open Checked in\n let open Let_syntax in\n let%bind { less_or_equal; _ } = compare ~bit_length x y in\n Boolean.Assert.is_true less_or_equal\n\n let gt ~bit_length x y = lt ~bit_length y x\n\n let gte ~bit_length x y = lte ~bit_length y x\n\n let non_zero (v : Cvar.t) =\n match v with\n | Constant v ->\n if Field.(equal zero v) then\n failwithf \"assert_non_zero: failed on constant %s\"\n (Field.to_string v) () ;\n Checked.return ()\n | _ ->\n Checked.assert_non_zero v\n\n let equal x y = Checked.assert_equal ~label:\"Checked.Assert.equal\" x y\n\n let not_equal (x : t) (y : t) =\n match (x, y) with\n | Constant x, Constant y ->\n if Field.(equal x y) then\n failwithf \"not_equal: failed on constants %s and %s\"\n (Field.to_string x) (Field.to_string y) () ;\n Checked.return ()\n | _, _ ->\n Checked.with_label \"Checked.Assert.not_equal\" (fun () ->\n non_zero (sub x y) )\n end\n\n let lt_bitstring_value =\n let module Boolean = Checked.Boolean in\n let module Expr = struct\n module Binary = struct\n type 'a t = Lit of 'a | And of 'a * 'a t | Or of 'a * 'a t\n end\n\n module Nary = struct\n type 'a t = Lit of 'a | And of 'a t list | Or of 'a t list\n\n let rec of_binary : 'a Binary.t -> 'a t = function\n | Lit x ->\n Lit x\n | And (x, And (y, t)) ->\n And [ Lit x; Lit y; of_binary t ]\n | Or (x, Or (y, t)) ->\n Or [ Lit x; Lit y; of_binary t ]\n | And (x, t) ->\n And [ Lit x; of_binary t ]\n | Or (x, t) ->\n Or [ Lit x; of_binary t ]\n\n let rec eval =\n let open Checked.Let_syntax in\n function\n | Lit x ->\n return x\n | And xs ->\n Checked.List.map xs ~f:eval >>= Boolean.all\n | Or xs ->\n Checked.List.map xs ~f:eval >>= Boolean.any\n end\n end in\n let rec lt_binary xs ys : Boolean.var Expr.Binary.t =\n match (xs, ys) with\n | [], [] ->\n Lit Boolean.false_\n | [ _x ], [ false ] ->\n Lit Boolean.false_\n | [ x ], [ true ] ->\n Lit (Boolean.not x)\n | [ x1; _x2 ], [ true; false ] ->\n Lit (Boolean.not x1)\n | [ _x1; _x2 ], [ false; false ] ->\n Lit Boolean.false_\n | x :: xs, false :: ys ->\n And (Boolean.not x, lt_binary xs ys)\n | x :: xs, true :: ys ->\n Or (Boolean.not x, lt_binary xs ys)\n | _ :: _, [] | [], _ :: _ ->\n failwith \"lt_bitstring_value: Got unequal length strings\"\n in\n fun (xs : Boolean.var Bitstring_lib.Bitstring.Msb_first.t)\n (ys : bool Bitstring_lib.Bitstring.Msb_first.t) ->\n let open Expr.Nary in\n eval\n (of_binary (lt_binary (xs :> Boolean.var list) (ys :> bool list)))\n\n let field_size_bits =\n lazy\n ( List.init Field.size_in_bits ~f:(fun i ->\n Z.testbit\n (Bignum_bigint.to_zarith_bigint Field.size)\n Stdlib.(Field.size_in_bits - 1 - i) )\n |> Bitstring_lib.Bitstring.Msb_first.of_list )\n\n let unpack_full x =\n let module Bitstring = Bitstring_lib.Bitstring in\n let open Checked.Let_syntax in\n let%bind res =\n choose_preimage_var x ~length:Field.size_in_bits\n >>| Bitstring.Lsb_first.of_list\n in\n let%map () =\n lt_bitstring_value\n (Bitstring.Msb_first.of_lsb_first res)\n (Lazy.force field_size_bits)\n >>= Checked.Boolean.Assert.is_true\n in\n res\n\n let parity ?length x =\n let open Checked in\n let unpack =\n let unpack_full x =\n unpack_full x >>| Bitstring_lib.Bitstring.Lsb_first.to_list\n in\n match length with\n | None ->\n unpack_full\n | Some length ->\n let length = Int.min length Field.size_in_bits in\n if Int.equal length Field.size_in_bits then unpack_full\n else choose_preimage_var ~length\n in\n unpack x >>| Base.List.hd_exn\n end\n end\n\n module Bitstring_checked = struct\n type t = Checked.Boolean.var list\n\n let lt_value = Field.Checked.lt_bitstring_value\n\n let chunk_for_equality (t1 : t) (t2 : t) =\n let chunk_size = Field.size_in_bits - 1 in\n let rec go acc t1 t2 =\n match (t1, t2) with\n | [], [] ->\n acc\n | _, _ ->\n let t1_a, t1_b = List.split_n t1 chunk_size in\n let t2_a, t2_b = List.split_n t2 chunk_size in\n go ((t1_a, t2_a) :: acc) t1_b t2_b\n in\n go [] t1 t2\n\n let equal t1 t2 =\n let open Checked in\n all\n (Base.List.map (chunk_for_equality t1 t2) ~f:(fun (x1, x2) ->\n equal (Cvar1.pack x1) (Cvar1.pack x2) ) )\n >>= Boolean.all\n\n let equal_expect_true t1 t2 =\n let open Checked in\n all\n (Core_kernel.List.map (chunk_for_equality t1 t2) ~f:(fun (x1, x2) ->\n (* Inlined [Field.equal], but skip creating the field element for\n this chunk if possible.\n *)\n let z = Cvar1.(pack x1 - pack x2) in\n let%bind r, inv =\n exists\n Typ.(field * field)\n ~compute:\n As_prover.(\n match\n Core_kernel.List.map2 x1 x2 ~f:(fun x1 x2 ->\n let%map x1 = read_var (x1 :> Cvar.t)\n and x2 = read_var (x2 :> Cvar.t) in\n Field.equal x1 x2 )\n with\n | Ok res ->\n let%bind res = all res in\n if Core_kernel.List.for_all ~f:Fn.id res then\n return (Field.one, Field.zero)\n else equal_vars z\n | _ ->\n equal_vars z)\n in\n let%map () = equal_constraints z inv r in\n Boolean.Unsafe.of_cvar r ) )\n >>= Boolean.all\n\n module Assert = struct\n let equal t1 t2 =\n let open Checked in\n Base.List.map (chunk_for_equality t1 t2) ~f:(fun (x1, x2) ->\n Constraint.equal (Cvar1.pack x1) (Cvar1.pack x2) )\n |> assert_all ~label:\"Bitstring.Assert.equal\"\n end\n end\n\n let%test_unit \"lt_bitstring_value\" =\n let gen =\n let open Quickcheck.Generator in\n let open Let_syntax in\n let%bind length = small_positive_int in\n let%map x = list_with_length length bool\n and y = list_with_length length bool in\n (x, y)\n in\n Quickcheck.test gen ~f:(fun (x, y) ->\n let correct_answer = [%compare: bool list] x y < 0 in\n let lt =\n run_and_check\n (Checked.map\n ~f:(As_prover.read Checked.Boolean.typ)\n (Field.Checked.lt_bitstring_value\n (Bitstring_lib.Bitstring.Msb_first.of_list\n (List.map ~f:Checked.(constant Boolean.typ) x) )\n (Bitstring_lib.Bitstring.Msb_first.of_list y) ) )\n |> Or_error.ok_exn\n in\n assert (Bool.equal lt correct_answer) )\n\n include Checked\n\n let%snarkydef_ if_ (b : Boolean.var) ~typ:(Typ typ : ('var, _) Typ.t)\n ~(then_ : 'var) ~(else_ : 'var) =\n let then_, then_aux = typ.var_to_fields then_ in\n let else_, else_aux = typ.var_to_fields else_ in\n let%bind res =\n Array.all\n (Core_kernel.Array.map2_exn then_ else_ ~f:(fun then_ else_ ->\n if_ b ~then_ ~else_ ) )\n in\n let%map res_aux =\n (* Abstraction leak.. *)\n let res_aux = ref None in\n let%map () =\n as_prover\n As_prover.(\n if%map read Boolean.typ b then res_aux := Some then_aux\n else res_aux := Some else_aux)\n in\n match !res_aux with\n | Some res_aux ->\n res_aux\n | None ->\n typ.constraint_system_auxiliary ()\n in\n typ.var_of_fields (res, res_aux)\n\n module Test = struct\n let checked_to_unchecked typ1 typ2 checked input =\n let checked_result =\n run_and_check\n (let open Let_syntax in\n let%bind input = exists typ1 ~compute:(As_prover.return input) in\n let%map result = checked input in\n As_prover.read typ2 result)\n |> Or_error.ok_exn\n in\n checked_result\n\n let test_equal (type a) ?(sexp_of_t = sexp_of_opaque) ?(equal = Caml.( = ))\n typ1 typ2 checked unchecked input =\n let checked_result = checked_to_unchecked typ1 typ2 checked input in\n let sexp_of_a = sexp_of_t in\n let compare_a x y = if equal x y then 0 else 1 in\n [%test_eq: a] checked_result (unchecked input)\n end\n\n module R1CS_constraint_system = struct\n include R1CS_constraint_system\n end\nend\n\n(** The main functor for the monadic interface. \n See [Run.Make] for the same thing but for the imperative interface. *)\nmodule Make (Backend : Backend_intf.S) = struct\n module Backend_extended = Backend_extended.Make (Backend)\n module Runner0 = Runner.Make (Backend_extended)\n module Checked_runner = Runner0.Checked_runner\n module Checked1 = Checked.Make (Backend.Field) (Checked_runner) (As_prover0)\n\n module Field_T = struct\n type field = Backend_extended.Field.t\n end\n\n module As_prover_ext = As_prover0.Make_extended (Field_T) (As_prover0)\n\n module Ref :\n As_prover_ref.S\n with module Types = Checked1.Types\n and type ('a, 'f) checked := ('a, 'f) Checked1.t\n and type 'f field := Backend_extended.Field.t =\n As_prover_ref.Make (Checked1) (As_prover0)\n\n module Checked_for_basic = struct\n include (\n Checked1 :\n Checked_intf.S\n with module Types = Checked1.Types\n with type ('a, 'f) t := ('a, 'f) Checked1.t\n and type 'f field := Backend_extended.Field.t )\n\n type field = Backend_extended.Field.t\n\n type 'a t = ('a, field) Types.Checked.t\n\n let run = Runner0.run\n end\n\n module Basic =\n Make_basic (Backend_extended) (Checked_for_basic) (As_prover_ext) (Ref)\n (Runner0)\n include Basic\n module Number = Number.Make (Basic)\n module Enumerable = Enumerable.Make (Basic)\nend\n\nmodule Typ0 = Typ\n\nmodule Run = struct\n let functor_counter = ref 0\n\n let active_counters = ref []\n\n let is_active_functor_id num =\n match !active_counters with\n | [] ->\n (* Show the usual error, the functor isn't wrong as far as we can tell.\n *)\n true\n | active :: _ ->\n Int.equal active num\n\n let active_functor_id () = List.hd_exn !active_counters\n\n module Make_basic (Backend : Backend_intf.S) = struct\n module Snark = Make (Backend)\n open Run_state\n open Snark\n\n let set_constraint_logger = set_constraint_logger\n\n let clear_constraint_logger = clear_constraint_logger\n\n let this_functor_id = incr functor_counter ; !functor_counter\n\n let state =\n ref\n (Run_state.make ~input:(field_vec ()) ~aux:(field_vec ())\n ~eval_constraints:false ~num_inputs:0 ~next_auxiliary:(ref 0)\n ~with_witness:false ~stack:[] ~is_running:false () )\n\n let dump () = Run_state.dump !state\n\n let in_prover () : bool = Run_state.has_witness !state\n\n let in_checked_computation () : bool =\n is_active_functor_id this_functor_id && Run_state.is_running !state\n\n let run (checked : _ Checked.t) =\n match checked with\n | Pure a ->\n a\n | _ ->\n if not (is_active_functor_id this_functor_id) then\n failwithf\n \"Could not run this function.\\n\\n\\\n Hint: The module used to create this function had internal ID \\\n %i, but the module used to run it had internal ID %i. The same \\\n instance of Snarky.Snark.Run.Make must be used for both.\"\n this_functor_id (active_functor_id ()) ()\n else if not (Run_state.is_running !state) then\n failwith\n \"This function can't be run outside of a checked computation.\" ;\n let state', x = Runner.run checked !state in\n state := state' ;\n x\n\n let as_stateful x state' =\n state := state' ;\n let a = x () in\n (!state, a)\n\n let make_checked (type a) (f : unit -> a) : _ Checked.t =\n let g : run_state -> run_state * a = as_stateful f in\n Function g\n\n module R1CS_constraint_system = Snark.R1CS_constraint_system\n\n type field = Snark.field\n\n module Bigint = Snark.Bigint\n module Constraint = Snark.Constraint\n\n module Typ = struct\n open Snark.Typ\n\n type nonrec ('var, 'value) t = ('var, 'value) t\n\n let unit = unit\n\n let field = field\n\n let tuple2 = tuple2\n\n let ( * ) = ( * )\n\n let tuple3 = tuple3\n\n let list = list\n\n let array = array\n\n let hlist = hlist\n\n let transport = transport\n\n let transport_var = transport_var\n\n let of_hlistable = of_hlistable\n\n module Internal = Internal\n end\n\n let constant (Typ typ : _ Typ.t) x =\n let fields, aux = typ.value_to_fields x in\n let field_vars = Core_kernel.Array.map ~f:Cvar.constant fields in\n typ.var_of_fields (field_vars, aux)\n\n module Boolean = struct\n open Snark.Boolean\n\n type nonrec var = var\n\n type value = bool\n\n let true_ = true_\n\n let false_ = false_\n\n let if_ b ~then_ ~else_ = run (if_ b ~then_ ~else_)\n\n let not = not\n\n let ( && ) x y = run (x && y)\n\n let ( &&& ) = ( && )\n\n let ( || ) x y = run (x || y)\n\n let ( ||| ) = ( || )\n\n let ( lxor ) x y = run (x lxor y)\n\n let any l = run (any l)\n\n let all l = run (all l)\n\n let of_field x = run (of_field x)\n\n let var_of_value = var_of_value\n\n let typ = typ\n\n let typ_unchecked = typ_unchecked\n\n let equal x y = run (equal x y)\n\n module Expr = struct\n open Snark.Boolean.Expr\n\n type nonrec t = t\n\n let ( ! ) = ( ! )\n\n let ( && ) = ( && )\n\n let ( &&& ) = ( && )\n\n let ( || ) = ( || )\n\n let ( ||| ) = ( ||| )\n\n let any = any\n\n let all = all\n\n let not = not\n\n let eval x = run (eval x)\n\n let assert_ x = run (assert_ x)\n end\n\n module Unsafe = Unsafe\n\n module Assert = struct\n open Snark.Boolean.Assert\n\n let ( = ) x y = run (x = y)\n\n let is_true x = run (is_true x)\n\n let any l = run (any l)\n\n let all l = run (all l)\n\n let exactly_one l = run (exactly_one l)\n end\n\n module Array = struct\n open Snark.Boolean.Array\n\n let any x = run (any x)\n\n let all x = run (all x)\n\n module Assert = struct\n let any x = run (Assert.any x)\n\n let all x = run (Assert.all x)\n end\n end\n end\n\n module Field = struct\n open Snark.Field\n\n let size_in_bits = size_in_bits\n\n let size = size\n\n module Constant = struct\n type t = Snark.Field.t [@@deriving bin_io, sexp, hash, compare, eq]\n\n let gen = gen\n\n let gen_uniform = gen_uniform\n\n module T = struct\n let bin_shape_t = bin_shape_t\n\n let bin_writer_t = bin_writer_t\n\n let bin_write_t = bin_write_t\n\n let bin_size_t = bin_size_t\n\n let bin_reader_t = bin_reader_t\n\n let __bin_read_t__ = __bin_read_t__\n\n let bin_read_t = bin_read_t\n\n let bin_t = bin_t\n\n let sexp_of_t = sexp_of_t\n\n let t_of_sexp = t_of_sexp\n\n let of_int = of_int\n\n let one = one\n\n let zero = zero\n\n let add = add\n\n let sub = sub\n\n let mul = mul\n\n let inv = inv\n\n let square = square\n\n let sqrt = sqrt\n\n let is_square = is_square\n\n let equal = equal\n\n let size_in_bits = size_in_bits\n\n let print = print\n\n let to_string = to_string\n\n let random = random\n\n module Vector = Vector\n\n let negate = negate\n\n let ( + ) = ( + )\n\n let ( - ) = ( - )\n\n let ( * ) = ( * )\n\n let ( / ) = ( / )\n\n let of_string = of_string\n\n let to_string = to_string\n\n let unpack = unpack\n\n let project = project\n\n let parity = parity\n end\n\n include T\n end\n\n open Snark.Field.Var\n\n type nonrec t = t\n\n let length = length\n\n let var_indices = var_indices\n\n let to_constant_and_terms = to_constant_and_terms\n\n let constant = constant\n\n let to_constant = to_constant\n\n let linear_combination = linear_combination\n\n let sum = sum\n\n let add = add\n\n let negate = negate\n\n let sub = sub\n\n let scale = scale\n\n let project = project\n\n let pack = pack\n\n (* New definitions *)\n\n let of_int i = constant (Constant.of_int i)\n\n let one = constant Constant.one\n\n let zero = constant Constant.zero\n\n open Snark.Field.Checked\n\n let mul x y = run (mul x y)\n\n let square x = run (square x)\n\n let div x y = run (div x y)\n\n let inv x = run (inv x)\n\n let is_square x = run (is_square x)\n\n let sqrt x = run (sqrt x)\n\n let sqrt_check x = run (sqrt_check x)\n\n let equal x y = run (equal x y)\n\n let unpack x ~length = run (unpack x ~length)\n\n let unpack_flagged x ~length = run (unpack_flagged x ~length)\n\n let unpack_full x = run (unpack_full x)\n\n let parity ?length x = run (parity ?length x)\n\n let choose_preimage_var x ~length = run (choose_preimage_var x ~length)\n\n type nonrec comparison_result = comparison_result =\n { less : Boolean.var; less_or_equal : Boolean.var }\n\n let compare ~bit_length x y = run (compare ~bit_length x y)\n\n let if_ b ~then_ ~else_ = run (if_ b ~then_ ~else_)\n\n let ( + ) = add\n\n let ( - ) = sub\n\n let ( * ) = mul\n\n let ( / ) = div\n\n module Unsafe = Unsafe\n\n module Assert = struct\n open Snark.Field.Checked.Assert\n\n let lte ~bit_length x y = run (lte ~bit_length x y)\n\n let gte ~bit_length x y = run (gte ~bit_length x y)\n\n let lt ~bit_length x y = run (lt ~bit_length x y)\n\n let gt ~bit_length x y = run (gt ~bit_length x y)\n\n let not_equal x y = run (not_equal x y)\n\n let equal x y = run (equal x y)\n\n let non_zero x = run (non_zero x)\n end\n\n let typ = typ\n end\n\n module Proof_inputs = Proof_inputs\n\n module Bitstring_checked = struct\n open Snark.Bitstring_checked\n\n type nonrec t = t\n\n let equal x y = run (equal x y)\n\n let equal_expect_true x y = run (equal_expect_true x y)\n\n let lt_value x y = run (lt_value x y)\n\n module Assert = struct\n open Snark.Bitstring_checked.Assert\n\n let equal x y = run (equal x y)\n end\n end\n\n module As_prover = struct\n type 'a t = 'a\n\n type 'a as_prover = 'a t\n\n let eval_as_prover f =\n if Run_state.as_prover !state && Run_state.has_witness !state then\n let a = f (Runner.get_value !state) in\n a\n else failwith \"Can't evaluate prover code outside an as_prover block\"\n\n let in_prover_block () = Run_state.as_prover !state\n\n let read_var var = eval_as_prover (As_prover.read_var var)\n\n let read typ var = eval_as_prover (As_prover.read typ var)\n\n include Field.Constant.T\n\n module Ref = struct\n type 'a t = 'a As_prover_ref.t\n\n let create f = run As_prover.(Ref.create (map (return ()) ~f))\n\n let get r = eval_as_prover (As_prover.Ref.get r)\n\n let set r x = eval_as_prover (As_prover.Ref.set r x)\n end\n\n let run_prover f _tbl =\n (* Allow for nesting of prover blocks, by caching the current value and\n restoring it once we're done.\n *)\n let old = Run_state.as_prover !state in\n Run_state.set_as_prover !state true ;\n let a = f () in\n Run_state.set_as_prover !state old ;\n a\n end\n\n module Handle = struct\n type ('var, 'value) t = ('var, 'value) Handle.t\n\n let value handle () = As_prover.eval_as_prover (Handle.value handle)\n\n let var = Handle.var\n end\n\n let mark_active ~f =\n let counters = !active_counters in\n active_counters := this_functor_id :: counters ;\n try\n let ret = f () in\n active_counters := counters ;\n ret\n with exn ->\n active_counters := counters ;\n raise exn\n\n let mark_active_deferred (type a ma) ~(map : ma -> f:(a -> a) -> ma) ~f =\n let counters = !active_counters in\n active_counters := this_functor_id :: counters ;\n try\n map (f ()) ~f:(fun (ret : a) ->\n active_counters := counters ;\n ret )\n with exn ->\n active_counters := counters ;\n raise exn\n\n let assert_ ?label c = run (assert_ ?label c)\n\n let assert_all ?label c = run (assert_all ?label c)\n\n let assert_r1cs ?label a b c = run (assert_r1cs ?label a b c)\n\n let assert_square ?label x y = run (assert_square ?label x y)\n\n let as_prover p = run (as_prover (As_prover.run_prover p))\n\n let next_auxiliary () = run (next_auxiliary ())\n\n let request_witness typ p =\n run (request_witness typ (As_prover.run_prover p))\n\n let perform p = run (perform (As_prover.run_prover p))\n\n let request ?such_that typ r =\n match such_that with\n | None ->\n request_witness typ (fun () -> r)\n | Some such_that ->\n let x = request_witness typ (fun () -> r) in\n such_that x ; x\n\n let exists ?request ?compute typ =\n let request = Option.map request ~f:As_prover.run_prover in\n let compute = Option.map compute ~f:As_prover.run_prover in\n run (exists ?request ?compute typ)\n\n let exists_handle ?request ?compute typ =\n let request = Option.map request ~f:As_prover.run_prover in\n let compute = Option.map compute ~f:As_prover.run_prover in\n run (exists_handle ?request ?compute typ)\n\n type nonrec response = response\n\n let unhandled = unhandled\n\n type request = Request.request =\n | With :\n { request : 'a Request.t\n ; respond : 'a Request.Response.t -> response\n }\n -> request\n\n module Handler = Handler\n\n let handle x h =\n let h = Request.Handler.create_single h in\n let handler = Run_state.handler !state in\n state := Run_state.set_handler !state (Request.Handler.push handler h) ;\n let a = x () in\n state := Run_state.set_handler !state handler ;\n a\n\n let handle_as_prover x h =\n let h = h () in\n handle x h\n\n let if_ b ~typ ~then_ ~else_ = run (if_ b ~typ ~then_ ~else_)\n\n let with_label lbl x =\n let stack = Run_state.stack !state in\n let log_constraint = Run_state.log_constraint !state in\n state := Run_state.set_stack !state (lbl :: stack) ;\n Option.iter log_constraint ~f:(fun f ->\n f ~at_label_boundary:(`Start, lbl) None ) ;\n let a = x () in\n Option.iter log_constraint ~f:(fun f ->\n f ~at_label_boundary:(`End, lbl) None ) ;\n state := Run_state.set_stack !state stack ;\n a\n\n let inject_wrapper :\n type r_var input_var.\n f:(r_var -> r_var) -> (input_var -> r_var) -> input_var -> r_var =\n fun ~f x a ->\n let inject_wrapper ~f x = f x in\n inject_wrapper ~f (x a)\n\n (** Caches the global [state] before running [f]. \n It is expected that [f] will reset the global state for its own use only, \n hence why we need to reset it after running [f].*)\n let finalize_is_running f =\n let cached_state = !state in\n let x =\n match f () with\n | exception e ->\n (* Warning: it is important to clean the global state before reraising the exception.\n Imagine if a user of snarky catches exceptions instead of letting the program panic,\n then the next usage of snarky might be messed up. *)\n state := cached_state ;\n raise e\n | x ->\n x\n in\n state := cached_state ;\n x\n\n let constraint_system ~input_typ ~return_typ x : R1CS_constraint_system.t =\n finalize_is_running (fun () ->\n let x = inject_wrapper x ~f:(fun x () -> mark_active ~f:x) in\n Perform.constraint_system ~run:as_stateful ~input_typ ~return_typ x )\n\n let generate_public_input t x : As_prover.Vector.t =\n finalize_is_running (fun () -> generate_public_input t x)\n\n let generate_witness ~input_typ ~return_typ x a : Proof_inputs.t =\n finalize_is_running (fun () ->\n let x = inject_wrapper x ~f:(fun x () -> mark_active ~f:x) in\n Perform.generate_witness ~run:as_stateful ~input_typ ~return_typ x a )\n\n let generate_witness_conv (type out)\n ~(f : Proof_inputs.t -> 'r_value -> out) ~input_typ ~return_typ x input\n : out =\n finalize_is_running (fun () ->\n let x = inject_wrapper x ~f:(fun x () -> mark_active ~f:x) in\n Perform.generate_witness_conv ~run:as_stateful ~f ~input_typ\n ~return_typ x input )\n\n let run_unchecked x =\n finalize_is_running (fun () ->\n Perform.run_unchecked ~run:as_stateful (fun () -> mark_active ~f:x) )\n\n let run_and_check_exn (type a) (x : unit -> (unit -> a) As_prover.t) : a =\n finalize_is_running (fun () ->\n let res =\n Perform.run_and_check_exn ~run:as_stateful (fun () ->\n mark_active ~f:(fun () ->\n let prover_block = x () in\n Run_state.set_as_prover !state true ;\n As_prover.run_prover prover_block ) )\n in\n Run_state.set_as_prover !state true ;\n res )\n\n let run_and_check (type a) (x : unit -> (unit -> a) As_prover.t) :\n a Or_error.t =\n finalize_is_running (fun () ->\n let res =\n Perform.run_and_check ~run:as_stateful (fun () ->\n mark_active ~f:(fun () ->\n let prover_block = x () in\n Run_state.set_as_prover !state true ;\n As_prover.run_prover prover_block ) )\n in\n Run_state.set_as_prover !state true ;\n res )\n\n module Run_and_check_deferred (M : sig\n type _ t\n\n val return : 'a -> 'a t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n end) =\n struct\n open M\n\n let run_and_check_exn ~run t =\n map (run_and_check_deferred_exn' ~run t ~map) ~f:(fun (x, get_value) ->\n let x = Basic.As_prover.run x get_value in\n x )\n\n let run_and_check ~run t =\n map\n (run_and_check_deferred' ~run t ~map ~return)\n ~f:\n (Or_error.map ~f:(fun (x, get_value) ->\n let x = Basic.As_prover.run x get_value in\n x ) )\n\n let as_stateful x state' =\n state := state' ;\n map (x ()) ~f:(fun a -> (!state, a))\n\n let run_and_check_exn (type a) (x : unit -> (unit -> a) As_prover.t M.t) :\n a M.t =\n finalize_is_running (fun () ->\n let mark_active = mark_active_deferred ~map in\n let res =\n run_and_check_exn ~run:as_stateful (fun () ->\n mark_active ~f:(fun () ->\n map (x ()) ~f:(fun prover_block ->\n Run_state.set_as_prover !state true ;\n As_prover.run_prover prover_block ) ) )\n in\n Run_state.set_as_prover !state true ;\n res )\n\n let run_and_check (type a) (x : unit -> (unit -> a) As_prover.t M.t) :\n a Or_error.t M.t =\n finalize_is_running (fun () ->\n let mark_active = mark_active_deferred ~map in\n let res =\n run_and_check ~run:as_stateful (fun () ->\n mark_active ~f:(fun () ->\n map (x ()) ~f:(fun prover_block ->\n Run_state.set_as_prover !state true ;\n As_prover.run_prover prover_block ) ) )\n in\n Run_state.set_as_prover !state true ;\n res )\n end\n\n let check_exn x : unit =\n finalize_is_running (fun () -> Perform.check_exn ~run:as_stateful x)\n\n let check x : unit Or_error.t =\n finalize_is_running (fun () -> Perform.check ~run:as_stateful x)\n\n let constraint_count ?(weight = Fn.const 1) ?log x =\n let count = ref 0 in\n let log_constraint ?at_label_boundary c =\n ( match at_label_boundary with\n | None ->\n ()\n | Some (pos, lab) ->\n Option.iter log ~f:(fun f ->\n let start =\n Some (match pos with `Start -> true | _ -> false)\n in\n f ?start lab !count ) ) ;\n count := !count + Option.value_map ~default:0 ~f:weight c\n in\n (* TODO(mrmr1993): Enable label-level logging for the imperative API. *)\n let old = !state in\n state :=\n Runner.State.make ~num_inputs:0 ~input:Vector.null ~aux:Vector.null\n ~next_auxiliary:(ref 0) ~eval_constraints:false ~with_witness:false\n ~log_constraint () ;\n ignore (mark_active ~f:x) ;\n state := old ;\n !count\n\n module Internal_Basic = Snark\n\n let run_checked = run\n end\n\n module Make (Backend : Backend_intf.S) = struct\n module Basic = Make_basic (Backend)\n include Basic\n module Number = Number.Run.Make (Basic)\n module Enumerable = Enumerable.Run.Make (Basic)\n end\nend\n\ntype 'field m = (module Snark_intf.Run with type field = 'field)\n\nlet make (type field) (module Backend : Backend_intf.S with type Field.t = field)\n : field m =\n (module Run.Make (Backend))\n","type bigstring =\n (char, Bigarray.int8_unsigned_elt, Bigarray.c_layout) Bigarray.Array1.t\n\ntype t = bigstring\n\nlet create size = Bigarray.(Array1.create char c_layout size)\nlet empty = create 0\n\nmodule BA1 = Bigarray.Array1\n\nlet length t = BA1.dim t\n\nexternal get : t -> int -> char = \"%caml_ba_ref_1\"\nexternal set : t -> int -> char -> unit = \"%caml_ba_set_1\"\n\nexternal unsafe_get : t -> int -> char = \"%caml_ba_unsafe_ref_1\"\nexternal unsafe_set : t -> int -> char -> unit = \"%caml_ba_unsafe_set_1\"\n\nexternal unsafe_blit : t -> src_off:int -> t -> dst_off:int -> len:int -> unit =\n \"bigstringaf_blit_to_bigstring\" [@@noalloc]\n\nexternal unsafe_blit_to_bytes : t -> src_off:int -> Bytes.t -> dst_off:int -> len:int -> unit =\n \"bigstringaf_blit_to_bytes\" [@@noalloc]\n\nexternal unsafe_blit_from_bytes : Bytes.t -> src_off:int -> t -> dst_off:int -> len:int -> unit =\n \"bigstringaf_blit_from_bytes\" [@@noalloc]\n\nexternal unsafe_blit_from_string : string -> src_off:int -> t -> dst_off:int -> len:int -> unit =\n \"bigstringaf_blit_from_bytes\" [@@noalloc]\n\nexternal unsafe_memcmp : t -> int -> t -> int -> int -> int =\n \"bigstringaf_memcmp_bigstring\" [@@noalloc]\n\nexternal unsafe_memcmp_string : t -> int -> string -> int -> int -> int =\n \"bigstringaf_memcmp_string\" [@@noalloc]\n\nlet sub t ~off ~len =\n BA1.sub t off len\n\nlet[@inline never] invalid_bounds op buffer_len off len =\n let message =\n Printf.sprintf \"Bigstringaf.%s invalid range: { buffer_len: %d, off: %d, len: %d }\"\n op buffer_len off len\n in\n raise (Invalid_argument message)\n;;\n\nlet[@inline never] invalid_bounds_blit op src_len src_off dst_len dst_off len =\n let message =\n Printf.sprintf \"Bigstringaf.%s invalid range: { src_len: %d, src_off: %d, dst_len: %d, dst_off: %d, len: %d }\"\n op src_len src_off dst_len dst_off len\n in\n raise (Invalid_argument message)\n;;\n\nlet[@inline never] invalid_bounds_memcmp op buf1_len buf1_off buf2_len buf2_off len =\n let message =\n Printf.sprintf \"Bigstringaf.%s invalid range: { buf1_len: %d, buf1_off: %d, buf2_len: %d, buf2_off: %d, len: %d }\"\n op buf1_len buf1_off buf2_len buf2_off len\n in\n raise (Invalid_argument message)\n;;\n\n(* A note on bounds checking.\n *\n * The code should perform the following check to ensure that the blit doesn't\n * run off the end of the input buffer:\n *\n * {[off + len <= buffer_len]}\n *\n * However, this may lead to an interger overflow for large values of [off],\n * e.g., [max_int], which will cause the comparison to return [true] when it\n * should really return [false].\n *\n * An equivalent comparison that does not run into this integer overflow\n * problem is:\n *\n * {[buffer_len - off => len]}\n *\n * This is checking that the input buffer, less the offset, is sufficiently\n * long to perform the blit. Since the expression is subtracting [off] rather\n * than adding it, it doesn't suffer from the overflow that the previous\n * inequality did. As long as there is check to ensure that [off] is not\n * negative, it won't underflow either. *)\n\nlet copy t ~off ~len =\n let buffer_len = length t in\n if len < 0 || off < 0 || buffer_len - off < len\n then invalid_bounds \"copy\" buffer_len off len;\n let dst = create len in\n unsafe_blit t ~src_off:off dst ~dst_off:0 ~len;\n dst\n;;\n\nlet substring t ~off ~len =\n let buffer_len = length t in\n if len < 0 || off < 0 || buffer_len - off < len\n then invalid_bounds \"substring\" buffer_len off len;\n let b = Bytes.create len in\n unsafe_blit_to_bytes t ~src_off:off b ~dst_off:0 ~len;\n Bytes.unsafe_to_string b\n;;\n\nlet to_string t =\n let len = length t in\n let b = Bytes.create len in\n unsafe_blit_to_bytes t ~src_off:0 b ~dst_off:0 ~len;\n Bytes.unsafe_to_string b\n;;\n\nlet of_string ~off ~len s =\n let buffer_len = String.length s in\n if len < 0 || off < 0 || buffer_len - off < len\n then invalid_bounds \"of_string\" buffer_len off len;\n let b = create len in\n unsafe_blit_from_string s ~src_off:off b ~dst_off:0 ~len;\n b\n;;\n\nlet blit src ~src_off dst ~dst_off ~len =\n let src_len = length src in\n let dst_len = length dst in\n if len < 0\n then invalid_bounds_blit \"blit\" src_len src_off dst_len dst_off len;\n if src_off < 0 || src_len - src_off < len\n then invalid_bounds_blit \"blit\" src_len src_off dst_len dst_off len;\n if dst_off < 0 || dst_len - dst_off < len\n then invalid_bounds_blit \"blit\" src_len src_off dst_len dst_off len;\n unsafe_blit src ~src_off dst ~dst_off ~len\n;;\n\nlet blit_from_string src ~src_off dst ~dst_off ~len =\n let src_len = String.length src in\n let dst_len = length dst in\n if len < 0\n then invalid_bounds_blit \"blit_from_string\" src_len src_off dst_len dst_off len;\n if src_off < 0 || src_len - src_off < len\n then invalid_bounds_blit \"blit_from_string\" src_len src_off dst_len dst_off len;\n if dst_off < 0 || dst_len - dst_off < len\n then invalid_bounds_blit \"blit_from_string\" src_len src_off dst_len dst_off len;\n unsafe_blit_from_string src ~src_off dst ~dst_off ~len\n;;\n\nlet blit_from_bytes src ~src_off dst ~dst_off ~len =\n let src_len = Bytes.length src in\n let dst_len = length dst in\n if len < 0\n then invalid_bounds_blit \"blit_from_bytes\" src_len src_off dst_len dst_off len;\n if src_off < 0 || src_len - src_off < len\n then invalid_bounds_blit \"blit_from_bytes\" src_len src_off dst_len dst_off len;\n if dst_off < 0 || dst_len - dst_off < len\n then invalid_bounds_blit \"blit_from_bytes\" src_len src_off dst_len dst_off len;\n unsafe_blit_from_bytes src ~src_off dst ~dst_off ~len\n;;\n\nlet blit_to_bytes src ~src_off dst ~dst_off ~len =\n let src_len = length src in\n let dst_len = Bytes.length dst in\n if len < 0\n then invalid_bounds_blit \"blit_to_bytes\" src_len src_off dst_len dst_off len;\n if src_off < 0 || src_len - src_off < len\n then invalid_bounds_blit \"blit_to_bytes\" src_len src_off dst_len dst_off len;\n if dst_off < 0 || dst_len - dst_off < len\n then invalid_bounds_blit \"blit_to_bytes\" src_len src_off dst_len dst_off len;\n unsafe_blit_to_bytes src ~src_off dst ~dst_off ~len\n;;\n\nlet memcmp buf1 buf1_off buf2 buf2_off len =\n let buf1_len = length buf1 in\n let buf2_len = length buf2 in\n if len < 0\n then invalid_bounds_memcmp \"memcmp\" buf1_len buf1_off buf2_len buf2_off len;\n if buf1_off < 0 || buf1_len - buf1_off < len\n then invalid_bounds_memcmp \"memcmp\" buf1_len buf1_off buf2_len buf2_off len;\n if buf2_off < 0 || buf2_len - buf2_off < len\n then invalid_bounds_memcmp \"memcmp\" buf1_len buf1_off buf2_len buf2_off len;\n unsafe_memcmp buf1 buf1_off buf2 buf2_off len\n;;\n\nlet memcmp_string buf1 buf1_off buf2 buf2_off len =\n let buf1_len = length buf1 in\n let buf2_len = String.length buf2 in\n if len < 0\n then invalid_bounds_memcmp \"memcmp_string\" buf1_len buf1_off buf2_len buf2_off len;\n if buf1_off < 0 || buf1_len - buf1_off < len\n then invalid_bounds_memcmp \"memcmp_string\" buf1_len buf1_off buf2_len buf2_off len;\n if buf2_off < 0 || buf2_len - buf2_off < len\n then invalid_bounds_memcmp \"memcmp_string\" buf1_len buf1_off buf2_len buf2_off len;\n unsafe_memcmp_string buf1 buf1_off buf2 buf2_off len\n;;\n\n\n(* Safe operations *)\n\nexternal caml_bigstring_set_16 : bigstring -> int -> int -> unit = \"%caml_bigstring_set16\"\nexternal caml_bigstring_set_32 : bigstring -> int -> int32 -> unit = \"%caml_bigstring_set32\"\nexternal caml_bigstring_set_64 : bigstring -> int -> int64 -> unit = \"%caml_bigstring_set64\"\n\nexternal caml_bigstring_get_16 : bigstring -> int -> int = \"%caml_bigstring_get16\"\nexternal caml_bigstring_get_32 : bigstring -> int -> int32 = \"%caml_bigstring_get32\"\nexternal caml_bigstring_get_64 : bigstring -> int -> int64 = \"%caml_bigstring_get64\"\n\nmodule Swap = struct\n external bswap16 : int -> int = \"%bswap16\"\n external bswap_int32 : int32 -> int32 = \"%bswap_int32\"\n external bswap_int64 : int64 -> int64 = \"%bswap_int64\"\n\n let caml_bigstring_set_16 bs off i =\n caml_bigstring_set_16 bs off (bswap16 i)\n\n let caml_bigstring_set_32 bs off i =\n caml_bigstring_set_32 bs off (bswap_int32 i)\n\n let caml_bigstring_set_64 bs off i =\n caml_bigstring_set_64 bs off (bswap_int64 i)\n\n let caml_bigstring_get_16 bs off =\n bswap16 (caml_bigstring_get_16 bs off)\n\n let caml_bigstring_get_32 bs off =\n bswap_int32 (caml_bigstring_get_32 bs off)\n\n let caml_bigstring_get_64 bs off =\n bswap_int64 (caml_bigstring_get_64 bs off)\n\n let get_int16_sign_extended x off =\n ((caml_bigstring_get_16 x off) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\nend\n\nlet set_int16_le, set_int16_be =\n if Sys.big_endian\n then Swap.caml_bigstring_set_16, caml_bigstring_set_16\n else caml_bigstring_set_16 , Swap.caml_bigstring_set_16\n\nlet set_int32_le, set_int32_be =\n if Sys.big_endian\n then Swap.caml_bigstring_set_32, caml_bigstring_set_32\n else caml_bigstring_set_32 , Swap.caml_bigstring_set_32\n\nlet set_int64_le, set_int64_be =\n if Sys.big_endian\n then Swap.caml_bigstring_set_64, caml_bigstring_set_64\n else caml_bigstring_set_64 , Swap.caml_bigstring_set_64\n\nlet get_int16_le, get_int16_be =\n if Sys.big_endian\n then Swap.caml_bigstring_get_16, caml_bigstring_get_16\n else caml_bigstring_get_16 , Swap.caml_bigstring_get_16\n\nlet get_int16_sign_extended_noswap x off =\n ((caml_bigstring_get_16 x off) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int16_sign_extended_le, get_int16_sign_extended_be =\n if Sys.big_endian\n then Swap.get_int16_sign_extended , get_int16_sign_extended_noswap\n else get_int16_sign_extended_noswap, Swap.get_int16_sign_extended\n\nlet get_int32_le, get_int32_be =\n if Sys.big_endian\n then Swap.caml_bigstring_get_32, caml_bigstring_get_32\n else caml_bigstring_get_32 , Swap.caml_bigstring_get_32\n\nlet get_int64_le, get_int64_be =\n if Sys.big_endian\n then Swap.caml_bigstring_get_64, caml_bigstring_get_64\n else caml_bigstring_get_64 , Swap.caml_bigstring_get_64\n\n(* Unsafe operations *)\n\nexternal caml_bigstring_unsafe_set_16 : bigstring -> int -> int -> unit = \"%caml_bigstring_set16u\"\nexternal caml_bigstring_unsafe_set_32 : bigstring -> int -> int32 -> unit = \"%caml_bigstring_set32u\"\nexternal caml_bigstring_unsafe_set_64 : bigstring -> int -> int64 -> unit = \"%caml_bigstring_set64u\"\n\nexternal caml_bigstring_unsafe_get_16 : bigstring -> int -> int = \"%caml_bigstring_get16u\"\nexternal caml_bigstring_unsafe_get_32 : bigstring -> int -> int32 = \"%caml_bigstring_get32u\"\nexternal caml_bigstring_unsafe_get_64 : bigstring -> int -> int64 = \"%caml_bigstring_get64u\"\n\nmodule USwap = struct\n external bswap16 : int -> int = \"%bswap16\"\n external bswap_int32 : int32 -> int32 = \"%bswap_int32\"\n external bswap_int64 : int64 -> int64 = \"%bswap_int64\"\n\n let caml_bigstring_unsafe_set_16 bs off i =\n caml_bigstring_unsafe_set_16 bs off (bswap16 i)\n\n let caml_bigstring_unsafe_set_32 bs off i =\n caml_bigstring_unsafe_set_32 bs off (bswap_int32 i)\n\n let caml_bigstring_unsafe_set_64 bs off i =\n caml_bigstring_unsafe_set_64 bs off (bswap_int64 i)\n\n let caml_bigstring_unsafe_get_16 bs off =\n bswap16 (caml_bigstring_unsafe_get_16 bs off)\n\n let caml_bigstring_unsafe_get_32 bs off =\n bswap_int32 (caml_bigstring_unsafe_get_32 bs off)\n\n let caml_bigstring_unsafe_get_64 bs off =\n bswap_int64 (caml_bigstring_unsafe_get_64 bs off)\nend\n\nlet unsafe_set_int16_le, unsafe_set_int16_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_set_16, caml_bigstring_unsafe_set_16\n else caml_bigstring_unsafe_set_16 , USwap.caml_bigstring_unsafe_set_16\n\nlet unsafe_set_int32_le, unsafe_set_int32_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_set_32, caml_bigstring_unsafe_set_32\n else caml_bigstring_unsafe_set_32 , USwap.caml_bigstring_unsafe_set_32\n\nlet unsafe_set_int64_le, unsafe_set_int64_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_set_64, caml_bigstring_unsafe_set_64\n else caml_bigstring_unsafe_set_64 , USwap.caml_bigstring_unsafe_set_64\n\nlet unsafe_get_int16_le, unsafe_get_int16_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_get_16, caml_bigstring_unsafe_get_16\n else caml_bigstring_unsafe_get_16 , USwap.caml_bigstring_unsafe_get_16\n\nlet unsafe_get_int16_sign_extended_le x off =\n ((unsafe_get_int16_le x off) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet unsafe_get_int16_sign_extended_be x off =\n ((unsafe_get_int16_be x off ) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet unsafe_get_int32_le, unsafe_get_int32_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_get_32, caml_bigstring_unsafe_get_32\n else caml_bigstring_unsafe_get_32 , USwap.caml_bigstring_unsafe_get_32\n\nlet unsafe_get_int64_le, unsafe_get_int64_be =\n if Sys.big_endian\n then USwap.caml_bigstring_unsafe_get_64, caml_bigstring_unsafe_get_64\n else caml_bigstring_unsafe_get_64 , USwap.caml_bigstring_unsafe_get_64\n","open Core_kernel\n\nmodule type Field_intf = sig\n type t\n\n val size_in_bits : int\n\n val negate : t -> t\n\n val ( - ) : t -> t -> t\n\n val ( + ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n\n val ( / ) : t -> t -> t\n\n val inv : t -> t\n\n val zero : t\n\n val one : t\n\n val of_int : int -> t\nend\n\nlet two_to_the (type f) (module F : Field_intf with type t = f) =\n let rec two_to_the n =\n if n = 0 then F.one\n else\n let r = two_to_the (n - 1) in\n F.(r + r)\n in\n two_to_the\n\n(* Our custom constraints let us efficiently compute\n\n f = fun (g, t) -> (2 * t + 1 + 2^len(t)) g\n\n We want to compute\n\n f' = fun (g, s) -> s * g\n\n Let n be the field size in bits.\n\n For a scalar s, let t = (s - 2^n - 1)/2.\n t can be represented with an n bit string.\n\n Then\n\n f (g, t)\n = (2 t + 2^n + 1) * g\n = (2 (s - 2^n - 1)/2 + 2^n + 1) * g\n = (s - 2^n - 1 + 2^n + 1) * g\n = s * g\n = f' (g, s)\n\n as desired.\n*)\n\nmodule type S = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type 'f t [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n\n val typ :\n ('a, 'b, 'f) Snarky_backendless.Typ.t\n -> ('a t, 'b t, 'f) Snarky_backendless.Typ.t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n module Shift : sig\n type _ t\n\n val create : (module Field_intf with type t = 'f) -> 'f t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n end\n\n val of_field :\n (module Field_intf with type t = 'f) -> shift:'f Shift.t -> 'f -> 'f t\n\n val to_field :\n (module Field_intf with type t = 'f) -> shift:'f Shift.t -> 'f t -> 'f\n\n val equal : ('f, 'res) Sigs.rel2 -> ('f t, 'res) Sigs.rel2\nend\n\n[@@@warning \"-4\"]\n\nmodule Type1 = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'f t = Shifted_value of 'f\n [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n\n let typ f =\n let there (Shifted_value x) = x in\n let back x = Shifted_value x in\n Snarky_backendless.Typ.(\n transport_var (transport f ~there ~back) ~there ~back)\n\n let map (Shifted_value x) ~f = Shifted_value (f x)\n\n module Shift : sig\n type 'f t = private { c : 'f; scale : 'f }\n\n val create : (module Field_intf with type t = 'f) -> 'f t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n end = struct\n type 'f t = { c : 'f; scale : 'f }\n\n let map t ~f = { c = f t.c; scale = f t.scale }\n\n (* 2^{field size in bits} + 1 *)\n let create (type f) (module F : Field_intf with type t = f) : f t =\n { c = F.(two_to_the (module F) size_in_bits + one)\n ; scale = F.(inv (of_int 2))\n }\n end\n\n let of_field (type f) (module F : Field_intf with type t = f)\n ~(shift : f Shift.t) (s : f) : f t =\n Shifted_value F.((s - shift.c) * shift.scale)\n\n let to_field (type f) (module F : Field_intf with type t = f)\n ~(shift : f Shift.t) (Shifted_value t : f t) : f =\n F.(t + t + shift.c)\n\n let equal equal (Shifted_value t1) (Shifted_value t2) = equal t1 t2\nend\n\n(* When the scalar field is larger than the inner field of the circuit,\n we need to encode a scalar [s] as a pair ((s >> 1), s & 1). In other\n words, the high bits, and then the low bit separately.\n\n We can then efficiently compute the function\n\n f = fun (g, s) -> (2 * (s >> 1) + (s & 1) + 2^(5 * ceil(len(s >> 1) / 5))) g\n = fun (g, s) -> (s + 2^field_size_in_bits) g\n\n This is a different notion of shifted value, so we have a separate type for it.\n*)\n\nmodule Type2 = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'f t = Shifted_value of 'f\n [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n\n let typ f =\n let there (Shifted_value x) = x in\n let back x = Shifted_value x in\n Snarky_backendless.Typ.(\n transport_var (transport f ~there ~back) ~there ~back)\n\n let map (Shifted_value x) ~f = Shifted_value (f x)\n\n module Shift : sig\n type 'f t = private 'f\n\n val create : (module Field_intf with type t = 'f) -> 'f t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n end = struct\n type 'f t = 'f\n\n let map t ~f = f t\n\n (* 2^{field size in bits} *)\n let create (type f) (module F : Field_intf with type t = f) : f t =\n two_to_the (module F) F.size_in_bits\n end\n\n let of_field (type f) (module F : Field_intf with type t = f)\n ~(shift : f Shift.t) (s : f) : f t =\n Shifted_value F.(s - (shift :> t))\n\n let to_field (type f) (module F : Field_intf with type t = f)\n ~(shift : f Shift.t) (Shifted_value t : f t) : f =\n F.(t + (shift :> t))\n\n let equal equal (Shifted_value t1) (Shifted_value t2) = equal t1 t2\nend\n","open Core_kernel\n\nlet padded_array_typ ~length ~dummy elt =\n Snarky_backendless.Typ.array ~length elt\n |> Snarky_backendless.Typ.transport\n ~there:(fun a ->\n let n = Array.length a in\n if n > length then failwithf \"Expected %d <= %d\" n length () ;\n Array.append a (Array.create ~len:(length - n) dummy) )\n ~back:Fn.id\n\nlet hash_fold_array f s x = hash_fold_list f s (Array.to_list x)\n\nmodule Columns = Nat.N15\nmodule Columns_vec = Vector.Vector_15\nmodule Permuts_minus_1 = Nat.N6\nmodule Permuts_minus_1_vec = Vector.Vector_6\nmodule Permuts = Nat.N7\nmodule Permuts_vec = Vector.Vector_7\nmodule Lookup_sorted_minus_1 = Nat.N4\nmodule Lookup_sorted_minus_1_vec = Vector.Vector_4\nmodule Lookup_sorted = Nat.N5\nmodule Lookup_sorted_vec = Vector.Vector_5\n\nmodule Features = struct\n module Full = struct\n type 'bool t =\n { range_check0 : 'bool\n ; range_check1 : 'bool\n ; foreign_field_add : 'bool\n ; foreign_field_mul : 'bool\n ; xor : 'bool\n ; rot : 'bool\n ; lookup : 'bool\n ; runtime_tables : 'bool\n ; uses_lookups : 'bool\n ; table_width_at_least_1 : 'bool\n ; table_width_at_least_2 : 'bool\n ; table_width_3 : 'bool\n ; lookups_per_row_3 : 'bool\n ; lookups_per_row_4 : 'bool\n ; lookup_pattern_xor : 'bool\n ; lookup_pattern_range_check : 'bool\n }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n\n let get_feature_flag (feature_flags : _ t)\n (feature : Kimchi_types.feature_flag) =\n match feature with\n | RangeCheck0 ->\n Some feature_flags.range_check0\n | RangeCheck1 ->\n Some feature_flags.range_check1\n | ForeignFieldAdd ->\n Some feature_flags.foreign_field_add\n | ForeignFieldMul ->\n Some feature_flags.foreign_field_mul\n | Xor ->\n Some feature_flags.xor\n | Rot ->\n Some feature_flags.rot\n | LookupTables ->\n Some feature_flags.uses_lookups\n | RuntimeLookupTables ->\n Some feature_flags.runtime_tables\n | TableWidth 3 ->\n Some feature_flags.table_width_3\n | TableWidth 2 ->\n Some feature_flags.table_width_at_least_2\n | TableWidth i when i <= 1 ->\n Some feature_flags.table_width_at_least_1\n | TableWidth _ ->\n None\n | LookupsPerRow 4 ->\n Some feature_flags.lookups_per_row_4\n | LookupsPerRow i when i <= 3 ->\n Some feature_flags.lookups_per_row_3\n | LookupsPerRow _ ->\n None\n | LookupPattern Lookup ->\n Some feature_flags.lookup\n | LookupPattern Xor ->\n Some feature_flags.lookup_pattern_xor\n | LookupPattern RangeCheck ->\n Some feature_flags.lookup_pattern_range_check\n | LookupPattern ForeignFieldMul ->\n Some feature_flags.foreign_field_mul\n\n let map\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; rot\n ; xor\n ; lookup\n ; runtime_tables\n ; uses_lookups\n ; table_width_at_least_1\n ; table_width_at_least_2\n ; table_width_3\n ; lookups_per_row_3\n ; lookups_per_row_4\n ; lookup_pattern_xor\n ; lookup_pattern_range_check\n } ~f =\n { range_check0 = f range_check0\n ; range_check1 = f range_check1\n ; foreign_field_add = f foreign_field_add\n ; foreign_field_mul = f foreign_field_mul\n ; xor = f xor\n ; rot = f rot\n ; lookup = f lookup\n ; runtime_tables = f runtime_tables\n ; uses_lookups = f uses_lookups\n ; table_width_at_least_1 = f table_width_at_least_1\n ; table_width_at_least_2 = f table_width_at_least_2\n ; table_width_3 = f table_width_3\n ; lookups_per_row_3 = f lookups_per_row_3\n ; lookups_per_row_4 = f lookups_per_row_4\n ; lookup_pattern_xor = f lookup_pattern_xor\n ; lookup_pattern_range_check = f lookup_pattern_range_check\n }\n\n let map2 x1 x2 ~f =\n { range_check0 = f x1.range_check0 x2.range_check0\n ; range_check1 = f x1.range_check1 x2.range_check1\n ; foreign_field_add = f x1.foreign_field_add x2.foreign_field_add\n ; foreign_field_mul = f x1.foreign_field_mul x2.foreign_field_mul\n ; xor = f x1.xor x2.xor\n ; rot = f x1.rot x2.rot\n ; lookup = f x1.lookup x2.lookup\n ; runtime_tables = f x1.runtime_tables x2.runtime_tables\n ; uses_lookups = f x1.uses_lookups x2.uses_lookups\n ; table_width_at_least_1 =\n f x1.table_width_at_least_1 x2.table_width_at_least_1\n ; table_width_at_least_2 =\n f x1.table_width_at_least_2 x2.table_width_at_least_2\n ; table_width_3 = f x1.table_width_3 x2.table_width_3\n ; lookups_per_row_3 = f x1.lookups_per_row_3 x2.lookups_per_row_3\n ; lookups_per_row_4 = f x1.lookups_per_row_4 x2.lookups_per_row_4\n ; lookup_pattern_xor = f x1.lookup_pattern_xor x2.lookup_pattern_xor\n ; lookup_pattern_range_check =\n f x1.lookup_pattern_range_check x2.lookup_pattern_range_check\n }\n\n let none =\n { range_check0 = Opt.Flag.No\n ; range_check1 = Opt.Flag.No\n ; foreign_field_add = Opt.Flag.No\n ; foreign_field_mul = Opt.Flag.No\n ; xor = Opt.Flag.No\n ; rot = Opt.Flag.No\n ; lookup = Opt.Flag.No\n ; runtime_tables = Opt.Flag.No\n ; uses_lookups = Opt.Flag.No\n ; table_width_at_least_1 = Opt.Flag.No\n ; table_width_at_least_2 = Opt.Flag.No\n ; table_width_3 = Opt.Flag.No\n ; lookups_per_row_3 = Opt.Flag.No\n ; lookups_per_row_4 = Opt.Flag.No\n ; lookup_pattern_xor = Opt.Flag.No\n ; lookup_pattern_range_check = Opt.Flag.No\n }\n\n let maybe =\n { range_check0 = Opt.Flag.Maybe\n ; range_check1 = Opt.Flag.Maybe\n ; foreign_field_add = Opt.Flag.Maybe\n ; foreign_field_mul = Opt.Flag.Maybe\n ; xor = Opt.Flag.Maybe\n ; rot = Opt.Flag.Maybe\n ; lookup = Opt.Flag.Maybe\n ; runtime_tables = Opt.Flag.Maybe\n ; uses_lookups = Opt.Flag.Maybe\n ; table_width_at_least_1 = Opt.Flag.Maybe\n ; table_width_at_least_2 = Opt.Flag.Maybe\n ; table_width_3 = Opt.Flag.Maybe\n ; lookups_per_row_3 = Opt.Flag.Maybe\n ; lookups_per_row_4 = Opt.Flag.Maybe\n ; lookup_pattern_xor = Opt.Flag.Maybe\n ; lookup_pattern_range_check = Opt.Flag.Maybe\n }\n\n let none_bool =\n { range_check0 = false\n ; range_check1 = false\n ; foreign_field_add = false\n ; foreign_field_mul = false\n ; xor = false\n ; rot = false\n ; lookup = false\n ; runtime_tables = false\n ; uses_lookups = false\n ; table_width_at_least_1 = false\n ; table_width_at_least_2 = false\n ; table_width_3 = false\n ; lookups_per_row_3 = false\n ; lookups_per_row_4 = false\n ; lookup_pattern_xor = false\n ; lookup_pattern_range_check = false\n }\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'bool t =\n { range_check0 : 'bool\n ; range_check1 : 'bool\n ; foreign_field_add : 'bool\n ; foreign_field_mul : 'bool\n ; xor : 'bool\n ; rot : 'bool\n ; lookup : 'bool\n ; runtime_tables : 'bool\n }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n let of_full\n ({ range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n ; uses_lookups = _\n ; table_width_at_least_1 = _\n ; table_width_at_least_2 = _\n ; table_width_3 = _\n ; lookups_per_row_3 = _\n ; lookups_per_row_4 = _\n ; lookup_pattern_xor = _\n ; lookup_pattern_range_check = _\n } :\n 'bool Full.t ) =\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n }\n\n let to_full ~or_:( ||| )\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n } : _ Full.t =\n let lookup_pattern_range_check =\n (* RangeCheck, Rot gates use RangeCheck lookup pattern *)\n range_check0 ||| range_check1 ||| rot\n in\n let lookup_pattern_xor =\n (* Xor lookup pattern *)\n xor\n in\n (* Make sure these stay up-to-date with the layouts!! *)\n let table_width_3 =\n (* Xor have max_joint_size = 3 *)\n lookup_pattern_xor\n in\n let table_width_at_least_2 =\n (* Lookup has max_joint_size = 2 *)\n table_width_3 ||| lookup\n in\n let table_width_at_least_1 =\n (* RangeCheck, ForeignFieldMul have max_joint_size = 1 *)\n table_width_at_least_2 ||| lookup_pattern_range_check\n ||| foreign_field_mul\n in\n let lookups_per_row_4 =\n (* Xor, RangeCheckGate, ForeignFieldMul, have max_lookups_per_row = 4 *)\n lookup_pattern_xor ||| lookup_pattern_range_check ||| foreign_field_mul\n in\n let lookups_per_row_3 =\n (* Lookup has max_lookups_per_row = 3 *)\n lookups_per_row_4 ||| lookup\n in\n { uses_lookups = lookups_per_row_3\n ; table_width_at_least_1\n ; table_width_at_least_2\n ; table_width_3\n ; lookups_per_row_3\n ; lookups_per_row_4\n ; lookup_pattern_xor\n ; lookup_pattern_range_check\n ; range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n }\n\n type options = Opt.Flag.t t\n\n type flags = bool t\n\n let to_data\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n } : _ Hlist.HlistId.t =\n [ range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n ]\n\n let of_data\n ([ range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n ] :\n _ Hlist.HlistId.t ) =\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n }\n\n let typ bool\n ~feature_flags:\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n } =\n (* TODO: This should come from snarky. *)\n let constant (type var value)\n (typ : (var, value, _) Snarky_backendless.Typ.t) (x : value) : var =\n let (Typ typ) = typ in\n let fields, aux = typ.value_to_fields x in\n let fields =\n Array.map ~f:(fun x -> Snarky_backendless.Cvar.Constant x) fields\n in\n typ.var_of_fields (fields, aux)\n in\n let constant_typ ~there value =\n let open Snarky_backendless.Typ in\n unit ()\n |> transport ~there ~back:(fun () -> value)\n |> transport_var ~there:(fun _ -> ()) ~back:(fun () -> constant bool value)\n in\n let bool_typ_of_flag = function\n | Opt.Flag.Yes ->\n constant_typ\n ~there:(function true -> () | false -> assert false)\n true\n | Opt.Flag.No ->\n constant_typ\n ~there:(function false -> () | true -> assert false)\n false\n | Opt.Flag.Maybe ->\n bool\n in\n Snarky_backendless.Typ.of_hlistable\n [ bool_typ_of_flag range_check0\n ; bool_typ_of_flag range_check1\n ; bool_typ_of_flag foreign_field_add\n ; bool_typ_of_flag foreign_field_mul\n ; bool_typ_of_flag xor\n ; bool_typ_of_flag rot\n ; bool_typ_of_flag lookup\n ; bool_typ_of_flag runtime_tables\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n let none =\n { range_check0 = Opt.Flag.No\n ; range_check1 = Opt.Flag.No\n ; foreign_field_add = Opt.Flag.No\n ; foreign_field_mul = Opt.Flag.No\n ; xor = Opt.Flag.No\n ; rot = Opt.Flag.No\n ; lookup = Opt.Flag.No\n ; runtime_tables = Opt.Flag.No\n }\n\n let maybe =\n { range_check0 = Opt.Flag.Maybe\n ; range_check1 = Opt.Flag.Maybe\n ; foreign_field_add = Opt.Flag.Maybe\n ; foreign_field_mul = Opt.Flag.Maybe\n ; xor = Opt.Flag.Maybe\n ; rot = Opt.Flag.Maybe\n ; lookup = Opt.Flag.Maybe\n ; runtime_tables = Opt.Flag.Maybe\n }\n\n let none_bool =\n { range_check0 = false\n ; range_check1 = false\n ; foreign_field_add = false\n ; foreign_field_mul = false\n ; xor = false\n ; rot = false\n ; lookup = false\n ; runtime_tables = false\n }\n\n let map\n { range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; rot\n ; xor\n ; lookup\n ; runtime_tables\n } ~f =\n { range_check0 = f range_check0\n ; range_check1 = f range_check1\n ; foreign_field_add = f foreign_field_add\n ; foreign_field_mul = f foreign_field_mul\n ; xor = f xor\n ; rot = f rot\n ; lookup = f lookup\n ; runtime_tables = f runtime_tables\n }\n\n let map2 x1 x2 ~f =\n { range_check0 = f x1.range_check0 x2.range_check0\n ; range_check1 = f x1.range_check1 x2.range_check1\n ; foreign_field_add = f x1.foreign_field_add x2.foreign_field_add\n ; foreign_field_mul = f x1.foreign_field_mul x2.foreign_field_mul\n ; xor = f x1.xor x2.xor\n ; rot = f x1.rot x2.rot\n ; lookup = f x1.lookup x2.lookup\n ; runtime_tables = f x1.runtime_tables x2.runtime_tables\n }\nend\n\nmodule Evals = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type 'a t =\n { w : 'a Columns_vec.Stable.V1.t\n ; coefficients : 'a Columns_vec.Stable.V1.t\n ; z : 'a\n ; s : 'a Permuts_minus_1_vec.Stable.V1.t\n ; generic_selector : 'a\n ; poseidon_selector : 'a\n ; complete_add_selector : 'a\n ; mul_selector : 'a\n ; emul_selector : 'a\n ; endomul_scalar_selector : 'a\n ; range_check0_selector : 'a option\n ; range_check1_selector : 'a option\n ; foreign_field_add_selector : 'a option\n ; foreign_field_mul_selector : 'a option\n ; xor_selector : 'a option\n ; rot_selector : 'a option\n ; lookup_aggregation : 'a option\n ; lookup_table : 'a option\n ; lookup_sorted : 'a option Lookup_sorted_vec.Stable.V1.t\n ; runtime_lookup_table : 'a option\n ; runtime_lookup_table_selector : 'a option\n ; xor_lookup_selector : 'a option\n ; lookup_gate_lookup_selector : 'a option\n ; range_check_lookup_selector : 'a option\n ; foreign_field_mul_lookup_selector : 'a option\n }\n [@@deriving fields, sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n let validate_feature_flags ~feature_flags:(f : bool Features.t)\n { w = _\n ; coefficients = _\n ; z = _\n ; s = _\n ; generic_selector = _\n ; poseidon_selector = _\n ; complete_add_selector = _\n ; mul_selector = _\n ; emul_selector = _\n ; endomul_scalar_selector = _\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } =\n let enable_if x flag = Bool.(Option.is_some x = flag) in\n let range_check_lookup = f.range_check0 || f.range_check1 || f.rot in\n let lookups_per_row_4 =\n f.xor || range_check_lookup || f.foreign_field_mul\n in\n let lookups_per_row_3 = lookups_per_row_4 || f.lookup in\n let lookups_per_row_2 = lookups_per_row_3 in\n Array.reduce_exn ~f:( && )\n [| enable_if range_check0_selector f.range_check0\n ; enable_if range_check1_selector f.range_check1\n ; enable_if foreign_field_add_selector f.foreign_field_add\n ; enable_if foreign_field_mul_selector f.foreign_field_mul\n ; enable_if xor_selector f.xor\n ; enable_if rot_selector f.rot\n ; enable_if lookup_aggregation lookups_per_row_2\n ; enable_if lookup_table lookups_per_row_2\n ; Vector.foldi lookup_sorted ~init:true ~f:(fun i acc x ->\n let flag =\n (* NB: lookups_per_row + 1 in sorted, due to the lookup table. *)\n match i with\n | 0 | 1 | 2 ->\n lookups_per_row_2\n | 3 ->\n lookups_per_row_3\n | 4 ->\n lookups_per_row_4\n | _ ->\n assert false\n in\n acc && enable_if x flag )\n ; enable_if runtime_lookup_table f.runtime_tables\n ; enable_if runtime_lookup_table_selector f.runtime_tables\n ; enable_if xor_lookup_selector f.xor\n ; enable_if lookup_gate_lookup_selector f.lookup\n ; enable_if range_check_lookup_selector range_check_lookup\n ; enable_if foreign_field_mul_lookup_selector f.foreign_field_mul\n |]\n\n let to_absorption_sequence\n { w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } : _ list =\n let always_present =\n [ z\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ]\n @ Vector.to_list w\n @ Vector.to_list coefficients\n @ Vector.to_list s\n in\n let optional_gates =\n List.filter_map ~f:Fn.id\n [ range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ]\n in\n let lookup_final_terms =\n List.filter_map ~f:Fn.id\n [ runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n ]\n in\n always_present @ optional_gates\n @ List.filter_map ~f:Fn.id (Vector.to_list lookup_sorted)\n @ lookup_final_terms\n\n module In_circuit = struct\n type ('f, 'bool) t =\n { w : 'f Columns_vec.t\n ; coefficients : 'f Columns_vec.t\n ; z : 'f\n ; s : 'f Permuts_minus_1_vec.t\n ; generic_selector : 'f\n ; poseidon_selector : 'f\n ; complete_add_selector : 'f\n ; mul_selector : 'f\n ; emul_selector : 'f\n ; endomul_scalar_selector : 'f\n ; range_check0_selector : ('f, 'bool) Opt.t\n ; range_check1_selector : ('f, 'bool) Opt.t\n ; foreign_field_add_selector : ('f, 'bool) Opt.t\n ; foreign_field_mul_selector : ('f, 'bool) Opt.t\n ; xor_selector : ('f, 'bool) Opt.t\n ; rot_selector : ('f, 'bool) Opt.t\n ; lookup_aggregation : ('f, 'bool) Opt.t\n ; lookup_table : ('f, 'bool) Opt.t\n ; lookup_sorted : ('f, 'bool) Opt.t Lookup_sorted_vec.t\n ; runtime_lookup_table : ('f, 'bool) Opt.t\n ; runtime_lookup_table_selector : ('f, 'bool) Opt.t\n ; xor_lookup_selector : ('f, 'bool) Opt.t\n ; lookup_gate_lookup_selector : ('f, 'bool) Opt.t\n ; range_check_lookup_selector : ('f, 'bool) Opt.t\n ; foreign_field_mul_lookup_selector : ('f, 'bool) Opt.t\n }\n [@@deriving hlist, fields]\n\n let map (type bool a b)\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } :\n (a, bool) t ) ~(f : a -> b) : (b, bool) t =\n { w = Vector.map w ~f\n ; coefficients = Vector.map coefficients ~f\n ; z = f z\n ; s = Vector.map s ~f\n ; generic_selector = f generic_selector\n ; poseidon_selector = f poseidon_selector\n ; complete_add_selector = f complete_add_selector\n ; mul_selector = f mul_selector\n ; emul_selector = f emul_selector\n ; endomul_scalar_selector = f endomul_scalar_selector\n ; range_check0_selector = Opt.map ~f range_check0_selector\n ; range_check1_selector = Opt.map ~f range_check1_selector\n ; foreign_field_add_selector = Opt.map ~f foreign_field_add_selector\n ; foreign_field_mul_selector = Opt.map ~f foreign_field_mul_selector\n ; xor_selector = Opt.map ~f xor_selector\n ; rot_selector = Opt.map ~f rot_selector\n ; lookup_aggregation = Opt.map ~f lookup_aggregation\n ; lookup_table = Opt.map ~f lookup_table\n ; lookup_sorted = Vector.map ~f:(Opt.map ~f) lookup_sorted\n ; runtime_lookup_table = Opt.map ~f runtime_lookup_table\n ; runtime_lookup_table_selector = Opt.map ~f runtime_lookup_table_selector\n ; xor_lookup_selector = Opt.map ~f xor_lookup_selector\n ; lookup_gate_lookup_selector = Opt.map ~f lookup_gate_lookup_selector\n ; range_check_lookup_selector = Opt.map ~f range_check_lookup_selector\n ; foreign_field_mul_lookup_selector =\n Opt.map ~f foreign_field_mul_lookup_selector\n }\n\n let to_list\n { w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } =\n let always_present =\n List.map ~f:Opt.just\n ( [ z\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ]\n @ Vector.to_list w\n @ Vector.to_list coefficients\n @ Vector.to_list s )\n in\n let optional_gates =\n [ range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ]\n in\n always_present @ optional_gates\n @ Vector.to_list lookup_sorted\n @ [ lookup_aggregation\n ; lookup_table\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n ]\n\n let to_absorption_sequence\n { w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } : _ Opt.Early_stop_sequence.t =\n let always_present =\n [ z\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ]\n @ Vector.to_list w\n @ Vector.to_list coefficients\n @ Vector.to_list s\n in\n let optional_gates =\n [ range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ]\n in\n\n List.map ~f:Opt.just always_present\n @ optional_gates\n @ Vector.to_list lookup_sorted\n @ [ runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n ]\n end\n\n let to_in_circuit (type bool a)\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } :\n a t ) : (a, bool) In_circuit.t =\n { w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector = Opt.of_option range_check0_selector\n ; range_check1_selector = Opt.of_option range_check1_selector\n ; foreign_field_add_selector = Opt.of_option foreign_field_add_selector\n ; foreign_field_mul_selector = Opt.of_option foreign_field_mul_selector\n ; xor_selector = Opt.of_option xor_selector\n ; rot_selector = Opt.of_option rot_selector\n ; lookup_aggregation = Opt.of_option lookup_aggregation\n ; lookup_table = Opt.of_option lookup_table\n ; lookup_sorted = Vector.map ~f:Opt.of_option lookup_sorted\n ; runtime_lookup_table = Opt.of_option runtime_lookup_table\n ; runtime_lookup_table_selector =\n Opt.of_option runtime_lookup_table_selector\n ; xor_lookup_selector = Opt.of_option xor_lookup_selector\n ; lookup_gate_lookup_selector = Opt.of_option lookup_gate_lookup_selector\n ; range_check_lookup_selector = Opt.of_option range_check_lookup_selector\n ; foreign_field_mul_lookup_selector =\n Opt.of_option foreign_field_mul_lookup_selector\n }\n\n let map (type a b)\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } :\n a t ) ~(f : a -> b) : b t =\n { w = Vector.map w ~f\n ; coefficients = Vector.map coefficients ~f\n ; z = f z\n ; s = Vector.map s ~f\n ; generic_selector = f generic_selector\n ; poseidon_selector = f poseidon_selector\n ; complete_add_selector = f complete_add_selector\n ; mul_selector = f mul_selector\n ; emul_selector = f emul_selector\n ; endomul_scalar_selector = f endomul_scalar_selector\n ; range_check0_selector = Option.map ~f range_check0_selector\n ; range_check1_selector = Option.map ~f range_check1_selector\n ; foreign_field_add_selector = Option.map ~f foreign_field_add_selector\n ; foreign_field_mul_selector = Option.map ~f foreign_field_mul_selector\n ; xor_selector = Option.map ~f xor_selector\n ; rot_selector = Option.map ~f rot_selector\n ; lookup_aggregation = Option.map ~f lookup_aggregation\n ; lookup_table = Option.map ~f lookup_table\n ; lookup_sorted = Vector.map ~f:(Option.map ~f) lookup_sorted\n ; runtime_lookup_table = Option.map ~f runtime_lookup_table\n ; runtime_lookup_table_selector =\n Option.map ~f runtime_lookup_table_selector\n ; xor_lookup_selector = Option.map ~f xor_lookup_selector\n ; lookup_gate_lookup_selector = Option.map ~f lookup_gate_lookup_selector\n ; range_check_lookup_selector = Option.map ~f range_check_lookup_selector\n ; foreign_field_mul_lookup_selector =\n Option.map ~f foreign_field_mul_lookup_selector\n }\n\n let map2 (type a b c) (t1 : a t) (t2 : b t) ~(f : a -> b -> c) : c t =\n { w = Vector.map2 t1.w t2.w ~f\n ; coefficients = Vector.map2 t1.coefficients t2.coefficients ~f\n ; z = f t1.z t2.z\n ; s = Vector.map2 t1.s t2.s ~f\n ; generic_selector = f t1.generic_selector t2.generic_selector\n ; poseidon_selector = f t1.poseidon_selector t2.poseidon_selector\n ; complete_add_selector =\n f t1.complete_add_selector t2.complete_add_selector\n ; mul_selector = f t1.mul_selector t2.mul_selector\n ; emul_selector = f t1.emul_selector t2.emul_selector\n ; endomul_scalar_selector =\n f t1.endomul_scalar_selector t2.endomul_scalar_selector\n ; range_check0_selector =\n Option.map2 ~f t1.range_check0_selector t2.range_check0_selector\n ; range_check1_selector =\n Option.map2 ~f t1.range_check1_selector t2.range_check1_selector\n ; foreign_field_add_selector =\n Option.map2 ~f t1.foreign_field_add_selector\n t2.foreign_field_add_selector\n ; foreign_field_mul_selector =\n Option.map2 ~f t1.foreign_field_mul_selector\n t2.foreign_field_mul_selector\n ; xor_selector = Option.map2 ~f t1.xor_selector t2.xor_selector\n ; rot_selector = Option.map2 ~f t1.rot_selector t2.rot_selector\n ; lookup_aggregation =\n Option.map2 ~f t1.lookup_aggregation t2.lookup_aggregation\n ; lookup_table = Option.map2 ~f t1.lookup_table t2.lookup_table\n ; lookup_sorted =\n Vector.map2 ~f:(Option.map2 ~f) t1.lookup_sorted t2.lookup_sorted\n ; runtime_lookup_table =\n Option.map2 ~f t1.runtime_lookup_table t2.runtime_lookup_table\n ; runtime_lookup_table_selector =\n Option.map2 ~f t1.runtime_lookup_table_selector\n t2.runtime_lookup_table_selector\n ; xor_lookup_selector =\n Option.map2 ~f t1.xor_lookup_selector t2.xor_lookup_selector\n ; lookup_gate_lookup_selector =\n Option.map2 ~f t1.lookup_gate_lookup_selector\n t2.lookup_gate_lookup_selector\n ; range_check_lookup_selector =\n Option.map2 ~f t1.range_check_lookup_selector\n t2.range_check_lookup_selector\n ; foreign_field_mul_lookup_selector =\n Option.map2 ~f t1.foreign_field_mul_lookup_selector\n t2.foreign_field_mul_lookup_selector\n }\n\n (*\n This is in the same order as the evaluations in the opening proof:\n added later:\n - old sg polynomials\n - public input polynomial\n - ft\n here:\n - z\n - generic selector\n - poseidon selector\n - complete_add_selector\n - mul_selector\n - emul_selector\n - endomul_scalar_selector\n - w (witness columns)\n - coefficients\n - s (sigma columns)\n\n then optionally:\n - lookup sorted\n - lookup aggreg\n - lookup table\n - lookup runtime\n *)\n\n let to_list\n { w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } =\n let always_present =\n [ z\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ]\n @ Vector.to_list w\n @ Vector.to_list coefficients\n @ Vector.to_list s\n in\n let optional_gates =\n List.filter_map ~f:Fn.id\n [ range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ]\n in\n always_present @ optional_gates\n @ List.filter_map ~f:Fn.id (Vector.to_list lookup_sorted)\n @ List.filter_map ~f:Fn.id\n [ lookup_aggregation\n ; lookup_table\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n ]\n\n let typ (type f a_var a)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ~dummy e\n ({ uses_lookups; lookups_per_row_3; lookups_per_row_4; _ } as\n feature_flags :\n _ Features.Full.t ) :\n ((a_var, Impl.Boolean.var) In_circuit.t, a t, f) Snarky_backendless.Typ.t\n =\n let open Impl in\n let opt flag = Opt.typ Impl.Boolean.typ flag e ~dummy in\n let lookup_sorted =\n let lookups_per_row_3 = opt lookups_per_row_3 in\n let lookups_per_row_4 = opt lookups_per_row_4 in\n Vector.typ'\n [ lookups_per_row_3\n ; lookups_per_row_3\n ; lookups_per_row_3\n ; lookups_per_row_3\n ; lookups_per_row_4\n ]\n in\n Typ.of_hlistable\n [ Vector.typ e Columns.n\n ; Vector.typ e Columns.n\n ; e\n ; Vector.typ e Permuts_minus_1.n\n ; e\n ; e\n ; e\n ; e\n ; e\n ; e\n ; opt feature_flags.range_check0\n ; opt feature_flags.range_check1\n ; opt feature_flags.foreign_field_add\n ; opt feature_flags.foreign_field_mul\n ; opt feature_flags.xor\n ; opt feature_flags.rot\n ; opt uses_lookups\n ; opt uses_lookups\n ; lookup_sorted\n ; opt feature_flags.runtime_tables\n ; opt feature_flags.runtime_tables\n ; opt feature_flags.lookup_pattern_xor\n ; opt feature_flags.lookup\n ; opt feature_flags.lookup_pattern_range_check\n ; opt feature_flags.foreign_field_mul\n ]\n ~var_to_hlist:In_circuit.to_hlist ~var_of_hlist:In_circuit.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\nend\n\nmodule All_evals = struct\n module With_public_input = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('f, 'f_multi) t =\n { public_input : 'f; evals : 'f_multi Evals.Stable.V2.t }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n module In_circuit = struct\n type ('f, 'f_multi, 'bool) t =\n { public_input : 'f; evals : ('f_multi, 'bool) Evals.In_circuit.t }\n [@@deriving hlist]\n\n let factor (type f f_multi bool)\n ({ public_input = p1, p2; evals } : (f * f, f_multi * f_multi, bool) t)\n : (f, f_multi, bool) t Tuple_lib.Double.t =\n ( { evals = Evals.In_circuit.map ~f:fst evals; public_input = p1 }\n , { evals = Evals.In_circuit.map ~f:snd evals; public_input = p2 } )\n end\n\n let map (type a1 a2 b1 b2) (t : (a1, a2) t) ~(f1 : a1 -> b1) ~(f2 : a2 -> b2)\n : (b1, b2) t =\n { public_input = f1 t.public_input; evals = Evals.map ~f:f2 t.evals }\n\n let typ impl feature_flags f f_multi ~dummy =\n let evals = Evals.typ impl f_multi feature_flags ~dummy in\n let open Snarky_backendless.Typ in\n of_hlistable [ f; evals ] ~var_to_hlist:In_circuit.to_hlist\n ~var_of_hlist:In_circuit.of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n [@@@warning \"-4\"]\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('f, 'f_multi) t =\n { evals : ('f * 'f, 'f_multi * 'f_multi) With_public_input.Stable.V1.t\n ; ft_eval1 : 'f\n }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n module In_circuit = struct\n type ('f, 'f_multi, 'bool) t =\n { evals :\n ('f * 'f, 'f_multi * 'f_multi, 'bool) With_public_input.In_circuit.t\n ; ft_eval1 : 'f\n }\n [@@deriving hlist]\n end\n\n let map (type a1 a2 b1 b2) (t : (a1, a2) t) ~(f1 : a1 -> b1) ~(f2 : a2 -> b2)\n : (b1, b2) t =\n { evals =\n With_public_input.map t.evals\n ~f1:(Tuple_lib.Double.map ~f:f1)\n ~f2:(Tuple_lib.Double.map ~f:f2)\n ; ft_eval1 = f1 t.ft_eval1\n }\n\n let typ (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n feature_flags =\n let open Impl.Typ in\n let single = array ~length:1 field in\n let evals =\n With_public_input.typ\n (module Impl)\n feature_flags (tuple2 field field) (tuple2 single single)\n ~dummy:Impl.Field.Constant.([| zero |], [| zero |])\n in\n of_hlistable [ evals; Impl.Field.typ ] ~var_to_hlist:In_circuit.to_hlist\n ~var_of_hlist:In_circuit.of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\nend\n\nmodule Openings = struct\n [@@@warning \"-4\"] (* Deals with the 2 sexp-deriving types below *)\n\n module Bulletproof = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('g, 'fq) t =\n { lr : ('g * 'g) array\n ; z_1 : 'fq\n ; z_2 : 'fq\n ; delta : 'g\n ; challenge_polynomial_commitment : 'g\n }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n let typ fq g ~length =\n let open Snarky_backendless.Typ in\n of_hlistable\n [ array ~length (g * g); fq; fq; g; g ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('g, 'fq, 'fqv) t =\n { proof : ('g, 'fq) Bulletproof.Stable.V1.t\n ; evals : ('fqv * 'fqv) Evals.Stable.V2.t\n ; ft_eval1 : 'fq\n }\n [@@deriving sexp, compare, yojson, hash, equal, hlist]\n end\n end]\nend\n\nmodule Poly_comm = struct\n module With_degree_bound = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'g_opt t = { unshifted : 'g_opt array; shifted : 'g_opt }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n end\n end]\n\n let padded_array_typ0 = padded_array_typ\n\n let typ (type f g g_var bool_var)\n (g : (g_var, g, f) Snarky_backendless.Typ.t) ~length\n ~dummy_group_element\n ~(bool : (bool_var, bool, f) Snarky_backendless.Typ.t) :\n ((bool_var * g_var) t, g Or_infinity.t t, f) Snarky_backendless.Typ.t =\n let open Snarky_backendless.Typ in\n let g_inf =\n transport (tuple2 bool g)\n ~there:(function\n | Or_infinity.Infinity ->\n (false, dummy_group_element)\n | Finite x ->\n (true, x) )\n ~back:(fun (b, x) -> if b then Infinity else Finite x)\n in\n let arr = padded_array_typ0 ~length ~dummy:Or_infinity.Infinity g_inf in\n of_hlistable [ arr; g_inf ] ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n end\n\n module Without_degree_bound = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'g t = 'g array [@@deriving sexp, compare, yojson, hash, equal]\n end\n end]\n end\nend\n\nmodule Messages = struct\n open Poly_comm\n\n module Poly = struct\n type ('w, 'z, 't) t = { w : 'w; z : 'z; t : 't }\n [@@deriving sexp, compare, yojson, fields, hash, equal, hlist]\n end\n\n module Lookup = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'g t = { sorted : 'g array; aggreg : 'g; runtime : 'g option }\n [@@deriving fields, sexp, compare, yojson, hash, equal, hlist]\n end\n end]\n\n type 'g t =\n { sorted : 'g Lookup_sorted_minus_1_vec.t\n ; sorted_5th_column : 'g option\n ; aggreg : 'g\n ; runtime : 'g option\n }\n [@@deriving fields, sexp, compare, yojson, hash, equal, hlist]\n\n module In_circuit = struct\n type ('g, 'bool) t =\n { sorted : 'g Lookup_sorted_minus_1_vec.t\n ; sorted_5th_column : ('g, 'bool) Opt.t\n ; aggreg : 'g\n ; runtime : ('g, 'bool) Opt.t\n }\n [@@deriving hlist]\n end\n\n let dummy z =\n { aggreg = z\n ; sorted = Vector.init Lookup_sorted_minus_1.n ~f:(fun _ -> z)\n ; sorted_5th_column = None\n ; runtime = None\n }\n\n let typ bool_typ e ~lookups_per_row_4 ~runtime_tables ~dummy =\n Snarky_backendless.Typ.of_hlistable\n [ Vector.typ e Lookup_sorted_minus_1.n\n ; Opt.typ bool_typ lookups_per_row_4 e ~dummy\n ; e\n ; Opt.typ bool_typ runtime_tables e ~dummy\n ]\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n ~var_to_hlist:In_circuit.to_hlist ~var_of_hlist:In_circuit.of_hlist\n\n let opt_typ bool_typ ~(uses_lookup : Opt.Flag.t)\n ~(lookups_per_row_4 : Opt.Flag.t) ~(runtime_tables : Opt.Flag.t)\n ~dummy:z elt =\n Opt.typ bool_typ uses_lookup ~dummy:(dummy z)\n (typ bool_typ ~lookups_per_row_4 ~runtime_tables ~dummy:z elt)\n end\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type 'g t =\n { w_comm : 'g Without_degree_bound.Stable.V1.t Columns_vec.Stable.V1.t\n ; z_comm : 'g Without_degree_bound.Stable.V1.t\n ; t_comm : 'g Without_degree_bound.Stable.V1.t\n ; lookup : 'g Without_degree_bound.Stable.V1.t Lookup.Stable.V1.t option\n }\n [@@deriving sexp, compare, yojson, fields, hash, equal, hlist]\n end\n end]\n\n type 'g t =\n { w_comm : 'g Without_degree_bound.t Columns_vec.t\n ; z_comm : 'g Without_degree_bound.t\n ; t_comm : 'g Without_degree_bound.t\n ; lookup : 'g Without_degree_bound.t Lookup.t option\n }\n [@@deriving sexp, compare, yojson, fields, hash, equal, hlist]\n\n module In_circuit = struct\n type ('g, 'bool) t =\n { w_comm : 'g Without_degree_bound.t Columns_vec.t\n ; z_comm : 'g Without_degree_bound.t\n ; t_comm : 'g Without_degree_bound.t\n ; lookup :\n (('g Without_degree_bound.t, 'bool) Lookup.In_circuit.t, 'bool) Opt.t\n }\n [@@deriving hlist, fields]\n end\n\n let typ (type n f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) g\n ({ runtime_tables; uses_lookups; lookups_per_row_4; _ } :\n Opt.Flag.t Features.Full.t ) ~dummy\n ~(commitment_lengths : (((int, n) Vector.t as 'v), int, int) Poly.t) ~bool\n =\n let open Snarky_backendless.Typ in\n let { Poly.w = w_lens; z; t } = commitment_lengths in\n let array ~length elt = padded_array_typ ~dummy ~length elt in\n let wo n = array ~length:(Vector.reduce_exn n ~f:Int.max) g in\n let _w n =\n With_degree_bound.typ g\n ~length:(Vector.reduce_exn n ~f:Int.max)\n ~dummy_group_element:dummy ~bool\n in\n let lookup =\n Lookup.opt_typ Impl.Boolean.typ ~uses_lookup:uses_lookups\n ~lookups_per_row_4 ~runtime_tables ~dummy:[| dummy |]\n (wo [ 1 ])\n in\n of_hlistable\n [ Vector.typ (wo w_lens) Columns.n; wo [ z ]; wo [ t ]; lookup ]\n ~var_to_hlist:In_circuit.to_hlist ~var_of_hlist:In_circuit.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\nend\n\nmodule Proof = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type ('g, 'fq, 'fqv) t =\n { messages : 'g Messages.Stable.V2.t\n ; openings : ('g, 'fq, 'fqv) Openings.Stable.V2.t\n }\n [@@deriving sexp, compare, yojson, hash, equal]\n end\n end]\n\n type ('g, 'fq, 'fqv) t =\n { messages : 'g Messages.t; openings : ('g, 'fq, 'fqv) Openings.t }\n [@@deriving sexp, compare, yojson, hash, equal]\nend\n\nmodule Shifts = struct\n open Core_kernel\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type 'field t = 'field array [@@deriving sexp, compare, yojson, equal]\n end\n end]\nend\n","(** Pickles implementation *)\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Pickles\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Pickles_intf.S\n with type Side_loaded.Verification_key.Stable.V2.t =\n A.Side_loaded.Verification_key.V2.t\n and type ('a, 'b) Proof.t = ('a, 'b) A.Proof.t\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n module Endo = Endo\n module P = Proof\n\n module type Statement_intf = Intf.Statement\n\n module type Statement_var_intf = Intf.Statement_var\n\n module type Statement_value_intf = Intf.Statement_value\n\n module Common = Common\n module Scalar_challenge = Scalar_challenge\n module SC = Scalar_challenge\n open Core_kernel\n open Async_kernel\n open Import\n open Pickles_types\n open Hlist\n open Common\n open Backend\n module Backend = Backend\n module Sponge_inputs = Sponge_inputs\n module Util = Util\n module Tick_field_sponge = Tick_field_sponge\n module Impls = Impls\n module Inductive_rule = Inductive_rule\n module Tag = Tag\n module Types_map = Types_map\n module Dirty = Dirty\n module Cache_handle = Cache_handle\n module Step_main_inputs = Step_main_inputs\n module Step_verifier = Step_verifier\n module Proof_cache = Proof_cache\n\n exception Return_digest = Compile.Return_digest\n\n let verify_promise = Verify.verify\n\n let verify max_proofs_verified statement key proofs =\n verify_promise max_proofs_verified statement key proofs\n |> Promise.to_deferred\n\n (* This file (as you can see from the mli) defines a compiler which turns an inductive\n definition of a set into an inductive SNARK system for proving using those rules.\n\n The two ingredients we use are two SNARKs.\n - A step based SNARK for a field Fp, using the group G1/Fq (whose scalar field is Fp)\n - A DLOG based SNARK for a field Fq, using the group G/Fp (whose scalar field is Fq)\n\n For convenience in this discussion, let's define\n (F_0, G_0) := (Fp, G1)\n (F_1, G_1) := (Fq, G)\n So ScalarField(G_i) = F_i and G_i / F_{1-i}.\n\n An inductive set A is defined by a sequence of inductive rules.\n An inductive rule is intuitively described by something of the form\n\n a1 ∈ A1, ..., an ∈ An\n f [ a0, ... a1 ] a\n ----------------------\n a ∈ A\n\n where f is a snarky function defined over an Impl with Field.t = Fp\n and each Ai is itself an inductive rule (possibly equal to A itself).\n\n a1, ..., an can be seen as previous statements, i.e.\n\n prev_statement_1 ∈ A1, ..., prev_statement_n ∈ An\n f [ prev_statement_1; ...; prev_statement_n ] new_statement = true\n -------------------------------------------------------------------\n new_statement ∈ A\n\n In the case of a blockchain, the description of the sets A1, ..., An, A can\n be blockchain state, and f would be a function updating the state:\n\n prev_blockchain_state ∈ A\n update_blockchain_state [prev_blockchain_state] new_blockchain_state = true\n ---------------------------------------------------------------------------\n new_blockchain_state ∈ A\n\n We pursue the \"step\" then \"wrap\" approach for proof composition.\n\n The main source of complexity is that we must \"wrap\" proofs whose verifiers are\n slightly different.\n\n The main sources of complexity are twofold:\n 1. Each SNARK verifier includes group operations and scalar field operations.\n This is problematic because the group operations use the base field, which is\n not equal to the scalar field.\n\n Schematically, from the circuit point-of-view, we can say a proof is\n - a sequence of F_0 elements xs_0\n - a sequence of F_1 elements xs_1\n and a verifier is a pair of \"snarky functions\"\n - check_0 : F_0 list -> F_1 list -> unit which uses the Impl with Field.t = F_0\n - check_1 : F_0 list -> F_1 list -> unit which uses the Impl with Field.t = F_1\n - subset_00 : 'a list -> 'a list\n - subset_01 : 'a list -> 'a list\n - subset_10 : 'a list -> 'a list\n - subset_11 : 'a list -> 'a list\n and a proof verifies if\n ( check_0 (subset_00 xs_0) (subset_01 xs_1) ;\n check_1 (subset_10 xs_0) (subset_11 xs_1) )\n\n When verifying a proof, we perform the parts of the verifier involving group operations\n and expose as public input the scalar-field elements we need to perform the final checks.\n\n In the F_0 circuit, we witness xs_0 and xs_1,\n execute `check_0 (subset_00 xs_0) (subset_01 xs_1)` and\n expose `subset_10 xs_0` and `subset_11 xs_1` as public inputs.\n\n So the \"public inputs\" contain within them an \"unfinalized proof\".\n\n Then, the next time we verify that proof within an F_1 circuit we \"finalize\" those\n unfinalized proofs by running `check_1 xs_0_subset xs_1_subset`.\n\n I didn't implement it exactly this way (although in retrospect probably I should have) but\n that's the basic idea.\n\n **The complexity this causes:**\n When you prove a rule that includes k recursive verifications, you expose k unfinalized\n proofs. So, the shape of a statement depends on how many \"predecessor statements\" it has\n or in other words, how many verifications were performed within it.\n\n Say we have an inductive set given by inductive rules R_1, ... R_n such that\n each rule R_i has k_i predecessor statements.\n\n In the \"wrap\" circuit, we must be able to verify a proof coming from any of the R_i.\n So, we must pad the statement for the proof we're wrapping to have `max_i k_i`\n unfinalized proof components.\n\n 2. The verifier for each R_i looks a little different depending on the complexity of the \"step\"\n circuit corresponding to R_i has. Namely, it is dependent on the \"domains\" H and K for this\n circuit.\n\n So, when the \"wrap\" circuit proves the statement,\n \"there exists some index i in 1,...,n and a proof P such that verifies(P)\"\n \"verifies(P)\" must also take the index \"i\", compute the correct domain sizes correspond to rule \"i\"\n and use *that* in the \"verifies\" computation.\n *)\n open Kimchi_backend\n module Proof = P\n\n module Statement_with_proof = struct\n type ('s, 'max_width, _) t =\n (* TODO: use Max local max proofs verified instead of max_width *)\n ('max_width, 'max_width) Proof.t\n end\n\n module Verification_key = struct\n include Verification_key\n\n module Id = struct\n include Cache.Wrap.Key.Verification\n\n let dummy_id = Type_equal.Id.(uid (create ~name:\"dummy\" sexp_of_opaque))\n\n let dummy : unit -> t =\n let header =\n { Snark_keys_header.header_version = Snark_keys_header.header_version\n ; kind = { type_ = \"verification key\"; identifier = \"dummy\" }\n ; constraint_constants =\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ; commits = { mina = \"\"; marlin = \"\" }\n ; length = 0\n ; commit_date = \"\"\n ; constraint_system_hash = \"\"\n ; identifying_hash = \"\"\n }\n in\n let t = lazy (dummy_id, header, Md5.digest_string \"\") in\n fun () -> Lazy.force t\n end\n\n (* TODO: Make async *)\n let load ~cache id =\n Key_cache.Sync.read cache\n (Key_cache.Sync.Disk_storable.of_binable Id.to_string\n (module Verification_key.Stable.Latest) )\n id\n |> Deferred.return\n end\n\n module type Proof_intf = Compile.Proof_intf\n\n module Prover = Compile.Prover\n\n module Side_loaded = struct\n module V = Verification_key\n\n module Verification_key = struct\n include Side_loaded_verification_key\n\n let to_input (t : t) =\n to_input ~field_of_int:Impls.Step.Field.Constant.of_int t\n\n let of_compiled tag : t =\n let d = Types_map.lookup_compiled tag.Tag.id in\n let actual_wrap_domain_size =\n Common.actual_wrap_domain_size\n ~log_2_domain_size:(Lazy.force d.wrap_vk).domain.log_size_of_group\n in\n { wrap_vk = Some (Lazy.force d.wrap_vk)\n ; wrap_index = Lazy.force d.wrap_key\n ; max_proofs_verified =\n Pickles_base.Proofs_verified.of_nat\n (Nat.Add.n d.max_proofs_verified)\n ; actual_wrap_domain_size\n }\n\n module Max_width = Width.Max\n end\n\n let in_circuit tag vk =\n Types_map.set_ephemeral tag { index = `In_circuit vk }\n\n let in_prover tag vk = Types_map.set_ephemeral tag { index = `In_prover vk }\n\n let create ~name ~max_proofs_verified ~feature_flags ~typ =\n Types_map.add_side_loaded ~name\n { max_proofs_verified\n ; public_input = typ\n ; branches = Verification_key.Max_branches.n\n ; feature_flags =\n Plonk_types.(Features.to_full ~or_:Opt.Flag.( ||| ) feature_flags)\n }\n\n module Proof = struct\n include Proof.Proofs_verified_max\n\n let of_proof : _ Proof.t -> t = Wrap_hack.pad_proof\n end\n\n let verify_promise (type t) ~(typ : (_, t) Impls.Step.Typ.t)\n (ts : (Verification_key.t * t * Proof.t) list) =\n let m =\n ( module struct\n type nonrec t = t\n\n let to_field_elements =\n let (Typ typ) = typ in\n fun x -> fst (typ.value_to_fields x)\n end : Intf.Statement_value\n with type t = t )\n in\n (* TODO: This should be the actual max width on a per proof basis *)\n let max_proofs_verified =\n (module Verification_key.Max_width : Nat.Intf\n with type n = Verification_key.Max_width.n )\n in\n with_return (fun { return } ->\n List.map ts ~f:(fun (vk, x, p) ->\n let vk : V.t =\n { commitments = vk.wrap_index\n ; index =\n ( match vk.wrap_vk with\n | None ->\n return\n (Promise.return\n (Or_error.errorf\n \"Pickles.verify: wrap_vk not found\" ) )\n | Some x ->\n x )\n ; data =\n (* This isn't used in verify_heterogeneous, so we can leave this dummy *)\n { constraints = 0 }\n }\n in\n Verify.Instance.T (max_proofs_verified, m, vk, x, p) )\n |> Verify.verify_heterogenous )\n\n let verify ~typ ts = verify_promise ~typ ts |> Promise.to_deferred\n\n let srs_precomputation () : unit =\n let srs = Tock.Keypair.load_urs () in\n List.iter [ 0; 1; 2 ] ~f:(fun i ->\n Kimchi_bindings.Protocol.SRS.Fq.add_lagrange_basis srs\n (Domain.log2_size (Common.wrap_domains ~proofs_verified:i).h) )\n end\n\n let compile_with_wrap_main_override_promise =\n Compile.compile_with_wrap_main_override_promise\n\n let compile_promise ?self ?cache ?proof_cache ?disk_keys\n ?return_early_digest_exception ?override_wrap_domain ~public_input\n ~auxiliary_typ ~branches ~max_proofs_verified ~name ~constraint_constants\n ~choices () =\n compile_with_wrap_main_override_promise ?self ?cache ?proof_cache ?disk_keys\n ?return_early_digest_exception ?override_wrap_domain ~public_input\n ~auxiliary_typ ~branches ~max_proofs_verified ~name ~constraint_constants\n ~choices ()\n\n let compile ?self ?cache ?proof_cache ?disk_keys ?override_wrap_domain\n ~public_input ~auxiliary_typ ~branches ~max_proofs_verified ~name\n ~constraint_constants ~choices () =\n let self, cache_handle, proof_module, provers =\n compile_promise ?self ?cache ?proof_cache ?disk_keys ?override_wrap_domain\n ~public_input ~auxiliary_typ ~branches ~max_proofs_verified ~name\n ~constraint_constants ~choices ()\n in\n let rec adjust_provers :\n type a1 a2 a3 s1 s2_inner.\n (a1, a2, a3, s1, s2_inner Promise.t) H3_2.T(Prover).t\n -> (a1, a2, a3, s1, s2_inner Deferred.t) H3_2.T(Prover).t = function\n | [] ->\n []\n | prover :: tl ->\n (fun ?handler public_input ->\n Promise.to_deferred (prover ?handler public_input) )\n :: adjust_provers tl\n in\n (self, cache_handle, proof_module, adjust_provers provers)\n\n module Provers = H3_2.T (Prover)\n module Proof0 = Proof\n\n let%test_module \"test no side-loaded\" =\n ( module struct\n let () = Tock.Keypair.set_urs_info []\n\n let () = Tick.Keypair.set_urs_info []\n\n let () = Backtrace.elide := false\n\n open Impls.Step\n\n let () = Snarky_backendless.Snark0.set_eval_constraints true\n\n (* Currently, a circuit must have at least 1 of every type of constraint. *)\n let dummy_constraints () =\n Impl.(\n let x =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3)\n in\n let g =\n exists Step_main_inputs.Inner_curve.typ ~compute:(fun _ ->\n Tick.Inner_curve.(to_affine_exn one) )\n in\n ignore\n ( SC.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t ))\n\n module No_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let _example_input, _example_proof = example\n end\n\n module No_recursion_return = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Output Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun _ ->\n dummy_constraints () ;\n { previous_proof_statements = []\n ; public_output = Field.zero\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let res, (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step ()) )\n in\n assert (Field.Constant.(equal zero) res) ;\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (res, b0) ] ) ) ;\n (res, b0)\n\n let _example_input, _example_proof = example\n end\n\n [@@@warning \"-60\"]\n\n module Simple_chain = struct\n type _ Snarky_backendless.Request.t +=\n | Prev_input : Field.Constant.t Snarky_backendless.Request.t\n | Proof : (Nat.N1.n, Nat.N1.n) Proof.t Snarky_backendless.Request.t\n\n let handler (prev_input : Field.Constant.t) (proof : _ Proof.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Prev_input ->\n respond (Provide prev_input)\n | Proof ->\n respond (Provide proof)\n | _ ->\n respond Unhandled\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N1)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self ->\n [ { identifier = \"main\"\n ; prevs = [ self ]\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n let prev =\n exists Field.typ ~request:(fun () -> Prev_input)\n in\n let proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Proof )\n in\n let is_base_case = Field.equal Field.zero self in\n let proof_must_verify = Boolean.not is_base_case in\n let self_correct = Field.(equal (one + prev) self) in\n Boolean.Assert.any [ self_correct; is_base_case ] ;\n { previous_proof_statements =\n [ { public_input = prev\n ; proof\n ; proof_must_verify\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let s_neg_one = Field.Constant.(negate one) in\n let b_neg_one : (Nat.N1.n, Nat.N1.n) Proof0.t =\n Proof0.dummy Nat.N1.n Nat.N1.n Nat.N1.n ~domain_log2:14\n in\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:(handler s_neg_one b_neg_one)\n Field.Constant.zero ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n let (), (), b1 =\n Common.time \"b1\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:(handler Field.Constant.zero b0)\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b1) ] ) ) ;\n (Field.Constant.one, b1)\n\n let _example_input, _example_proof = example\n end\n\n module Tree_proof = struct\n type _ Snarky_backendless.Request.t +=\n | No_recursion_input : Field.Constant.t Snarky_backendless.Request.t\n | No_recursion_proof :\n (Nat.N0.n, Nat.N0.n) Proof.t Snarky_backendless.Request.t\n | Recursive_input : Field.Constant.t Snarky_backendless.Request.t\n | Recursive_proof :\n (Nat.N2.n, Nat.N2.n) Proof.t Snarky_backendless.Request.t\n\n let handler\n ((no_recursion_input, no_recursion_proof) :\n Field.Constant.t * _ Proof.t )\n ((recursion_input, recursion_proof) : Field.Constant.t * _ Proof.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | No_recursion_input ->\n respond (Provide no_recursion_input)\n | No_recursion_proof ->\n respond (Provide no_recursion_proof)\n | Recursive_input ->\n respond (Provide recursion_input)\n | Recursive_proof ->\n respond (Provide recursion_proof)\n | _ ->\n respond Unhandled\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~override_wrap_domain:Pickles_base.Proofs_verified.N1\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = [ No_recursion.tag; self ]\n ; main =\n (fun { public_input = self } ->\n let no_recursive_input =\n exists Field.typ ~request:(fun () ->\n No_recursion_input )\n in\n let no_recursive_proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n No_recursion_proof )\n in\n let prev =\n exists Field.typ ~request:(fun () ->\n Recursive_input )\n in\n let prev_proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Recursive_proof )\n in\n let is_base_case = Field.equal Field.zero self in\n let proof_must_verify = Boolean.not is_base_case in\n let self_correct = Field.(equal (one + prev) self) in\n Boolean.Assert.any [ self_correct; is_base_case ] ;\n { previous_proof_statements =\n [ { public_input = no_recursive_input\n ; proof = no_recursive_proof\n ; proof_must_verify = Boolean.true_\n }\n ; { public_input = prev\n ; proof = prev_proof\n ; proof_must_verify\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example1, example2 =\n let s_neg_one = Field.Constant.(negate one) in\n let b_neg_one : (Nat.N2.n, Nat.N2.n) Proof0.t =\n Proof0.dummy Nat.N2.n Nat.N2.n Nat.N2.n ~domain_log2:15\n in\n let (), (), b0 =\n Common.time \"tree b0\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler No_recursion.example (s_neg_one, b_neg_one))\n Field.Constant.zero ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n let (), (), b1 =\n Common.time \"tree b1\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler No_recursion.example (Field.Constant.zero, b0))\n Field.Constant.one ) )\n in\n ((Field.Constant.zero, b0), (Field.Constant.one, b1))\n\n let examples = [ example1; example2 ]\n\n let _example1_input, _example_proof = example1\n\n let _example2_input, _example2_proof = example2\n end\n\n let%test_unit \"verify\" =\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Tree_proof.Proof.verify_promise Tree_proof.examples ) )\n\n module Tree_proof_return = struct\n type _ Snarky_backendless.Request.t +=\n | Is_base_case : bool Snarky_backendless.Request.t\n | No_recursion_input : Field.Constant.t Snarky_backendless.Request.t\n | No_recursion_proof :\n (Nat.N0.n, Nat.N0.n) Proof.t Snarky_backendless.Request.t\n | Recursive_input : Field.Constant.t Snarky_backendless.Request.t\n | Recursive_proof :\n (Nat.N2.n, Nat.N2.n) Proof.t Snarky_backendless.Request.t\n\n let handler (is_base_case : bool)\n ((no_recursion_input, no_recursion_proof) :\n Field.Constant.t * _ Proof.t )\n ((recursion_input, recursion_proof) : Field.Constant.t * _ Proof.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Is_base_case ->\n respond (Provide is_base_case)\n | No_recursion_input ->\n respond (Provide no_recursion_input)\n | No_recursion_proof ->\n respond (Provide no_recursion_proof)\n | Recursive_input ->\n respond (Provide recursion_input)\n | Recursive_proof ->\n respond (Provide recursion_proof)\n | _ ->\n respond Unhandled\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Output Field.typ)\n ~override_wrap_domain:Pickles_base.Proofs_verified.N1\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = [ No_recursion_return.tag; self ]\n ; main =\n (fun { public_input = () } ->\n let no_recursive_input =\n exists Field.typ ~request:(fun () ->\n No_recursion_input )\n in\n let no_recursive_proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n No_recursion_proof )\n in\n let prev =\n exists Field.typ ~request:(fun () ->\n Recursive_input )\n in\n let prev_proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Recursive_proof )\n in\n let is_base_case =\n exists Boolean.typ ~request:(fun () -> Is_base_case)\n in\n let proof_must_verify = Boolean.not is_base_case in\n let self =\n Field.(\n if_ is_base_case ~then_:zero ~else_:(one + prev))\n in\n { previous_proof_statements =\n [ { public_input = no_recursive_input\n ; proof = no_recursive_proof\n ; proof_must_verify = Boolean.true_\n }\n ; { public_input = prev\n ; proof = prev_proof\n ; proof_must_verify\n }\n ]\n ; public_output = self\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example1, example2 =\n let s_neg_one = Field.Constant.(negate one) in\n let b_neg_one : (Nat.N2.n, Nat.N2.n) Proof0.t =\n Proof0.dummy Nat.N2.n Nat.N2.n Nat.N2.n ~domain_log2:15\n in\n let s0, (), b0 =\n Common.time \"tree b0\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler true No_recursion_return.example\n (s_neg_one, b_neg_one) )\n () ) )\n in\n assert (Field.Constant.(equal zero) s0) ;\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (s0, b0) ] ) ) ;\n let s1, (), b1 =\n Common.time \"tree b1\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler false No_recursion_return.example (s0, b0))\n () ) )\n in\n assert (Field.Constant.(equal one) s1) ;\n ((s0, b0), (s1, b1))\n\n let examples = [ example1; example2 ]\n\n let _example1_input, _example1_proof = example1\n\n let _example2_input, _example2_proof = example2\n end\n\n let%test_unit \"verify\" =\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Tree_proof_return.Proof.verify_promise Tree_proof_return.examples )\n )\n\n module Add_one_return = struct\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise ()\n ~public_input:(Input_and_output (Field.typ, Field.typ))\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = []\n ; main =\n (fun { public_input = x } ->\n dummy_constraints () ;\n { previous_proof_statements = []\n ; public_output = Field.(add one) x\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let input = Field.Constant.of_int 42 in\n let res, (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step input) )\n in\n assert (Field.Constant.(equal (of_int 43)) res) ;\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ ((input, res), b0) ] ) ) ;\n ((input, res), b0)\n\n let _example_input, _example_proof = example\n end\n\n module Auxiliary_return = struct\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise ()\n ~public_input:(Input_and_output (Field.typ, Field.typ))\n ~auxiliary_typ:Field.typ\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = []\n ; main =\n (fun { public_input = input } ->\n dummy_constraints () ;\n let sponge =\n Step_main_inputs.Sponge.create\n Step_main_inputs.sponge_params\n in\n let blinding_value =\n exists Field.typ ~compute:Field.Constant.random\n in\n Step_main_inputs.Sponge.absorb sponge (`Field input) ;\n Step_main_inputs.Sponge.absorb sponge\n (`Field blinding_value) ;\n let result = Step_main_inputs.Sponge.squeeze sponge in\n { previous_proof_statements = []\n ; public_output = result\n ; auxiliary_output = blinding_value\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let input = Field.Constant.of_int 42 in\n let result, blinding_value, b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step input) )\n in\n let sponge =\n Tick_field_sponge.Field.create Tick_field_sponge.params\n in\n Tick_field_sponge.Field.absorb sponge input ;\n Tick_field_sponge.Field.absorb sponge blinding_value ;\n let result' = Tick_field_sponge.Field.squeeze sponge in\n assert (Field.Constant.equal result result') ;\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ ((input, result), b0) ] ) ) ;\n ((input, result), b0)\n\n let _example_input, _example_proof = example\n end\n end )\n\n let%test_module \"test uncorrelated bulletproof_challenges\" =\n ( module struct\n let () = Backtrace.elide := false\n\n let () = Snarky_backendless.Snark0.set_eval_constraints true\n\n module Statement = struct\n type t = unit\n\n let to_field_elements () = [||]\n end\n\n module A = Statement\n module A_value = Statement\n\n let typ = Impls.Step.Typ.unit\n\n module Branches = Nat.N1\n module Max_proofs_verified = Nat.N2\n\n let constraint_constants : Snark_keys_header.Constraint_constants.t =\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n\n let tag =\n let tagname = \"\" in\n Tag.create ~kind:Compiled tagname\n\n let rule : _ Inductive_rule.t =\n let open Impls.Step in\n { identifier = \"main\"\n ; prevs = [ tag; tag ]\n ; main =\n (fun { public_input = () } ->\n let dummy_proof =\n As_prover.Ref.create (fun () ->\n Proof0.dummy Nat.N2.n Nat.N2.n Nat.N2.n ~domain_log2:15 )\n in\n { previous_proof_statements =\n [ { public_input = ()\n ; proof = dummy_proof\n ; proof_must_verify = Boolean.false_\n }\n ; { public_input = ()\n ; proof = dummy_proof\n ; proof_must_verify = Boolean.false_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n ; feature_flags = Plonk_types.Features.none_bool\n }\n\n module M = struct\n module IR = Inductive_rule.T (A) (A_value) (A) (A_value) (A) (A_value)\n\n let max_local_max_proofs_verifieds ~self (type n)\n (module Max_proofs_verified : Nat.Intf with type n = n) branches\n choices =\n let module Local_max_proofs_verifieds = struct\n type t = (int, Max_proofs_verified.n) Vector.t\n end in\n let module M =\n H4.Map (IR) (E04 (Local_max_proofs_verifieds))\n (struct\n module V = H4.To_vector (Int)\n module HT = H4.T (Tag)\n\n module M =\n H4.Map (Tag) (E04 (Int))\n (struct\n let f (type a b c d) (t : (a, b, c, d) Tag.t) : int =\n if Type_equal.Id.same t.id self then\n Nat.to_int Max_proofs_verified.n\n else\n let (module M) = Types_map.max_proofs_verified t in\n Nat.to_int M.n\n end)\n\n let f :\n type a b c d.\n (a, b, c, d) IR.t -> Local_max_proofs_verifieds.t =\n fun rule ->\n let (T (_, l)) = HT.length rule.prevs in\n Vector.extend_front_exn\n (V.f l (M.f rule.prevs))\n Max_proofs_verified.n 0\n end)\n in\n let module V = H4.To_vector (Local_max_proofs_verifieds) in\n let padded = V.f branches (M.f choices) |> Vector.transpose in\n (padded, Maxes.m padded)\n\n module Lazy_keys = struct\n type t =\n (Impls.Step.Keypair.t * Dirty.t) Lazy.t\n * (Kimchi_bindings.Protocol.VerifierIndex.Fp.t * Dirty.t) Lazy.t\n\n (* TODO Think this is right.. *)\n end\n\n let compile :\n ( unit\n -> (Max_proofs_verified.n, Max_proofs_verified.n) Proof.t Promise.t\n )\n * _\n * _ =\n let self = tag in\n let snark_keys_header kind constraint_system_hash =\n { Snark_keys_header.header_version =\n Snark_keys_header.header_version\n ; kind\n ; constraint_constants\n ; commits =\n { mina = Mina_version.commit_id\n ; marlin = Mina_version.marlin_commit_id\n }\n ; length = (* This is a dummy, it gets filled in on read/write. *) 0\n ; commit_date = Mina_version.commit_date\n ; constraint_system_hash\n ; identifying_hash =\n (* TODO: Proper identifying hash. *)\n constraint_system_hash\n }\n in\n let T = Max_proofs_verified.eq in\n let prev_varss_n = Branches.n in\n let prev_varss_length : _ Length.t = S Z in\n let T = Nat.eq_exn prev_varss_n Branches.n in\n let padded, (module Maxes) =\n max_local_max_proofs_verifieds\n (module Max_proofs_verified)\n prev_varss_length [ rule ] ~self:self.id\n in\n let full_signature =\n { Full_signature.padded; maxes = (module Maxes) }\n in\n let feature_flags = Plonk_types.Features.Full.none in\n let actual_feature_flags = Plonk_types.Features.none_bool in\n let wrap_domains =\n let module M =\n Wrap_domains.Make (A) (A_value) (A) (A_value) (A) (A_value)\n in\n M.f full_signature prev_varss_n prev_varss_length ~feature_flags\n ~max_proofs_verified:(module Max_proofs_verified)\n in\n let module Branch_data = struct\n type ('vars, 'vals, 'n, 'm) t =\n ( A.t\n , A_value.t\n , A.t\n , A_value.t\n , A.t\n , A_value.t\n , Max_proofs_verified.n\n , Branches.n\n , 'vars\n , 'vals\n , 'n\n , 'm )\n Step_branch_data.t\n end in\n let proofs_verifieds = Vector.singleton 2 in\n let (T inner_step_data as step_data) =\n Step_branch_data.create ~index:0 ~feature_flags\n ~actual_feature_flags ~max_proofs_verified:Max_proofs_verified.n\n ~branches:Branches.n ~self ~public_input:(Input typ)\n ~auxiliary_typ:typ A.to_field_elements A_value.to_field_elements\n rule ~wrap_domains ~proofs_verifieds\n in\n let step_domains = Vector.singleton inner_step_data.domains in\n let step_keypair =\n let etyp =\n Impls.Step.input ~proofs_verified:Max_proofs_verified.n\n ~wrap_rounds:Tock.Rounds.n\n in\n let (T (typ, _conv, conv_inv)) = etyp in\n let main () () =\n let res = inner_step_data.main ~step_domains () in\n Impls.Step.with_label \"conv_inv\" (fun () -> conv_inv res)\n in\n let open Impls.Step in\n let k_p =\n lazy\n (let cs =\n constraint_system ~input_typ:Typ.unit ~return_typ:typ main\n in\n let cs_hash = Md5.to_hex (R1CS_constraint_system.digest cs) in\n ( Type_equal.Id.uid self.id\n , snark_keys_header\n { type_ = \"step-proving-key\"\n ; identifier = inner_step_data.rule.identifier\n }\n cs_hash\n , inner_step_data.index\n , cs ) )\n in\n let k_v =\n lazy\n (let id, _header, index, cs = Lazy.force k_p in\n let digest = R1CS_constraint_system.digest cs in\n ( id\n , snark_keys_header\n { type_ = \"step-verification-key\"\n ; identifier = inner_step_data.rule.identifier\n }\n (Md5.to_hex digest)\n , index\n , digest ) )\n in\n Cache.Step.read_or_generate\n ~prev_challenges:\n (Nat.to_int (fst inner_step_data.proofs_verified))\n [] k_p k_v\n (Snarky_backendless.Typ.unit ())\n typ main\n in\n let step_vks =\n lazy\n (Vector.map [ step_keypair ] ~f:(fun (_, vk) ->\n Tick.Keypair.vk_commitments (fst (Lazy.force vk)) ) )\n in\n let wrap_main _ =\n let module SC' = SC in\n let open Impls.Wrap in\n let open Wrap_main_inputs in\n let x =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3)\n in\n let y =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 0)\n in\n let z =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 0)\n in\n let g = Inner_curve.one in\n let sponge = Sponge.create sponge_params in\n Sponge.absorb sponge x ;\n ignore (Sponge.squeeze_field sponge : Field.t) ;\n ignore\n ( SC'.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore\n (Ops.scale_fast g ~num_bits:5 (Shifted_value x) : Inner_curve.t) ;\n ignore\n ( Wrap_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t ) ;\n for _i = 0 to 64000 do\n assert_r1cs x y z\n done\n in\n let (wrap_pk, wrap_vk), disk_key =\n let open Impls.Wrap in\n let (T (typ, conv, _conv_inv)) = input ~feature_flags () in\n let main x () : unit = wrap_main (conv x) in\n let self_id = Type_equal.Id.uid self.id in\n let disk_key_prover =\n lazy\n (let cs =\n constraint_system ~input_typ:typ ~return_typ:Typ.unit main\n in\n let cs_hash = Md5.to_hex (R1CS_constraint_system.digest cs) in\n ( self_id\n , snark_keys_header\n { type_ = \"wrap-proving-key\"; identifier = \"\" }\n cs_hash\n , cs ) )\n in\n let disk_key_verifier =\n lazy\n (let id, _header, cs = Lazy.force disk_key_prover in\n let digest = R1CS_constraint_system.digest cs in\n ( id\n , snark_keys_header\n { type_ = \"wrap-verification-key\"; identifier = \"\" }\n (Md5.to_hex digest)\n , digest ) )\n in\n let r =\n Common.time \"wrap read or generate \" (fun () ->\n Cache.Wrap.read_or_generate ~prev_challenges:2 []\n disk_key_prover disk_key_verifier typ Typ.unit main )\n in\n (r, disk_key_verifier)\n in\n let wrap_vk = Lazy.map wrap_vk ~f:fst in\n let module S = Step.Make (A) (A_value) (Max_proofs_verified) in\n let prover =\n let f :\n ( unit * (unit * unit)\n , unit * (unit * unit)\n , Nat.N2.n * (Nat.N2.n * unit)\n , Nat.N1.n * (Nat.N1.n * unit) )\n Branch_data.t\n -> Lazy_keys.t\n -> unit\n -> (Max_proofs_verified.n, Max_proofs_verified.n) Proof.t\n Promise.t =\n fun (T b as branch_data) (step_pk, step_vk) () ->\n let (_ : (Max_proofs_verified.n, Maxes.ns) Requests.Wrap.t) =\n Requests.Wrap.create ()\n in\n let _, prev_vars_length = b.proofs_verified in\n let step =\n let wrap_vk = Lazy.force wrap_vk in\n S.f branch_data () ~feature_flags ~prevs_length:prev_vars_length\n ~self ~public_input:(Input typ)\n ~auxiliary_typ:Impls.Step.Typ.unit ~step_domains\n ~self_dlog_plonk_index:wrap_vk.commitments\n (Impls.Step.Keypair.pk (fst (Lazy.force step_pk)))\n wrap_vk.index\n in\n let pairing_vk = fst (Lazy.force step_vk) in\n let wrap =\n let wrap_vk = Lazy.force wrap_vk in\n let%bind.Promise proof, (), (), _ =\n step ~proof_cache:None ~maxes:(module Maxes)\n in\n let proof =\n { proof with\n statement =\n { proof.statement with\n messages_for_next_wrap_proof =\n Compile.pad_messages_for_next_wrap_proof\n (module Maxes)\n proof.statement.messages_for_next_wrap_proof\n }\n }\n in\n let%map.Promise proof =\n (* The prover for wrapping a proof *)\n let wrap (type actual_branching)\n ~(max_proofs_verified : Max_proofs_verified.n Nat.t)\n (module Max_local_max_proofs_verifieds : Hlist.Maxes.S\n with type ns = Maxes.ns\n and type length = Max_proofs_verified.n )\n ~dlog_plonk_index wrap_main to_field_elements ~pairing_vk\n ~step_domains:_ ~wrap_domains:_ ~pairing_plonk_indices:_\n pk\n ({ statement = prev_statement\n ; prev_evals = _\n ; proof\n ; index = _which_index\n } :\n ( _\n , _\n , (_, actual_branching) Vector.t\n , (_, actual_branching) Vector.t\n , Maxes.ns\n H1.T\n (P.Base.Messages_for_next_proof_over_same_field.Wrap)\n .t\n , ( ( Tock.Field.t\n , Tock.Field.t array )\n Plonk_types.All_evals.t\n , Max_proofs_verified.n )\n Vector.t )\n P.Base.Step.t ) =\n let prev_messages_for_next_wrap_proof =\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap)\n (P.Base.Messages_for_next_proof_over_same_field.Wrap\n .Prepared)\n (struct\n let f =\n P.Base.Messages_for_next_proof_over_same_field\n .Wrap\n .prepare\n end)\n in\n M.f prev_statement.messages_for_next_wrap_proof\n in\n let prev_statement_with_hashes : _ Types.Step.Statement.t =\n { proof_state =\n { prev_statement.proof_state with\n messages_for_next_step_proof =\n (* TODO: Careful here... the length of\n old_buletproof_challenges inside the messages_for_next_wrap_proof\n might not be correct *)\n Common.hash_messages_for_next_step_proof\n ~app_state:to_field_elements\n (P.Base.Messages_for_next_proof_over_same_field\n .Step\n .prepare ~dlog_plonk_index\n prev_statement.proof_state\n .messages_for_next_step_proof )\n }\n ; messages_for_next_wrap_proof =\n (let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field\n .Wrap\n .Prepared)\n (E01 (Digest.Constant))\n (struct\n let f (type n)\n (m :\n n\n P.Base\n .Messages_for_next_proof_over_same_field\n .Wrap\n .Prepared\n .t ) =\n let T =\n Nat.eq_exn max_proofs_verified\n (Vector.length\n m.old_bulletproof_challenges )\n in\n Wrap_hack.hash_messages_for_next_wrap_proof\n max_proofs_verified m\n end)\n in\n let module V = H1.To_vector (Digest.Constant) in\n V.f Max_local_max_proofs_verifieds.length\n (M.f prev_messages_for_next_wrap_proof) )\n }\n in\n let module O = Tick.Oracles in\n let public_input =\n tick_public_input_of_statement ~max_proofs_verified\n prev_statement_with_hashes\n in\n let prev_challenges =\n Vector.map ~f:Ipa.Step.compute_challenges\n prev_statement.proof_state.messages_for_next_step_proof\n .old_bulletproof_challenges\n in\n let actual_proofs_verified =\n Vector.length prev_challenges\n in\n let lte =\n Nat.lte_exn actual_proofs_verified\n (Length.to_nat Max_local_max_proofs_verifieds.length)\n in\n let o =\n let sgs =\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap\n .Prepared)\n (E01 (Tick.Curve.Affine))\n (struct\n let f :\n type n.\n n\n P.Base\n .Messages_for_next_proof_over_same_field\n .Wrap\n .Prepared\n .t\n -> _ =\n fun t -> t.challenge_polynomial_commitment\n end)\n in\n let module V = H1.To_vector (Tick.Curve.Affine) in\n V.f Max_local_max_proofs_verifieds.length\n (M.f prev_messages_for_next_wrap_proof)\n in\n O.create pairing_vk\n Vector.(\n map2 (Vector.trim_front sgs lte) prev_challenges\n ~f:(fun commitment cs ->\n { Tick.Proof.Challenge_polynomial.commitment\n ; challenges = Vector.to_array cs\n } )\n |> to_list)\n public_input proof\n in\n let x_hat = O.(p_eval_1 o, p_eval_2 o) in\n let step_vk, _ = Lazy.force step_vk in\n let next_statement : _ Types.Wrap.Statement.In_circuit.t =\n let scalar_chal f =\n Scalar_challenge.map ~f:Challenge.Constant.of_tick_field\n (f o)\n in\n let sponge_digest_before_evaluations =\n O.digest_before_evaluations o\n in\n let plonk0 =\n { Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal\n .alpha = scalar_chal O.alpha\n ; beta = O.beta o\n ; gamma = O.gamma o\n ; zeta = scalar_chal O.zeta\n ; joint_combiner =\n Option.map (O.joint_combiner_chal o)\n ~f:\n (Scalar_challenge.map\n ~f:Challenge.Constant.of_tick_field )\n ; feature_flags = Plonk_types.Features.none_bool\n }\n in\n let r = scalar_chal O.u in\n let xi = scalar_chal O.v in\n let to_field =\n SC.to_field_constant\n (module Tick.Field)\n ~endo:Endo.Wrap_inner_curve.scalar\n in\n let module As_field = struct\n let r = to_field r\n\n let xi = to_field xi\n\n let zeta = to_field plonk0.zeta\n\n let alpha = to_field plonk0.alpha\n\n let joint_combiner =\n Option.map ~f:to_field plonk0.joint_combiner\n end in\n let domain =\n Domain.Pow_2_roots_of_unity\n step_vk.domain.log_size_of_group\n in\n let w = step_vk.domain.group_gen in\n (* Debug *)\n [%test_eq: Tick.Field.t] w\n (Tick.Field.domain_generator\n ~log2_size:(Domain.log2_size domain) ) ;\n let zetaw = Tick.Field.mul As_field.zeta w in\n let tick_plonk_minimal =\n { plonk0 with\n zeta = As_field.zeta\n ; alpha = As_field.alpha\n ; joint_combiner = As_field.joint_combiner\n }\n in\n let tick_combined_evals =\n Plonk_checks.evals_of_split_evals\n (module Tick.Field)\n proof.openings.evals\n ~rounds:(Nat.to_int Tick.Rounds.n) ~zeta:As_field.zeta\n ~zetaw\n in\n let tick_domain =\n Plonk_checks.domain\n (module Tick.Field)\n domain ~shifts:Common.tick_shifts\n ~domain_generator:Backend.Tick.Field.domain_generator\n in\n let tick_combined_evals =\n Plonk_types.Evals.to_in_circuit tick_combined_evals\n in\n let tick_env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tick.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ =\n if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~endo:Endo.Step_inner_curve.base\n ~mds:Tick_field_sponge.params.mds\n ~srs_length_log2:Common.Max_degree.step_log2\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fp.of_bigint )\n ~domain:tick_domain tick_plonk_minimal\n tick_combined_evals\n in\n let combined_inner_product =\n let open As_field in\n Wrap.combined_inner_product\n (* Note: We do not pad here. *)\n ~actual_proofs_verified:\n (Nat.Add.create actual_proofs_verified)\n { evals = proof.openings.evals; public_input = x_hat }\n ~r ~xi ~zeta ~zetaw\n ~old_bulletproof_challenges:prev_challenges\n ~env:tick_env ~domain:tick_domain\n ~ft_eval1:proof.openings.ft_eval1\n ~plonk:tick_plonk_minimal\n in\n let chal = Challenge.Constant.of_tick_field in\n let sg_new, new_bulletproof_challenges, b =\n let prechals =\n Array.map (O.opening_prechallenges o) ~f:(fun x ->\n let x =\n Scalar_challenge.map\n ~f:Challenge.Constant.of_tick_field x\n in\n x )\n in\n let chals =\n Array.map prechals ~f:(fun x ->\n Ipa.Step.compute_challenge x )\n in\n let challenge_polynomial =\n unstage (Wrap.challenge_polynomial chals)\n in\n let open As_field in\n let b =\n let open Tick.Field in\n challenge_polynomial zeta\n + (r * challenge_polynomial zetaw)\n in\n let overwritten_prechals =\n Array.map prechals\n ~f:\n (Scalar_challenge.map ~f:(fun _ ->\n Challenge.Constant.of_tick_field\n (Impls.Step.Field.Constant.of_int 100) ) )\n in\n let chals =\n Array.map overwritten_prechals ~f:(fun x ->\n Ipa.Step.compute_challenge x )\n in\n let sg_new =\n let urs = Backend.Tick.Keypair.load_urs () in\n Kimchi_bindings.Protocol.SRS.Fp\n .batch_accumulator_generate urs 1 chals\n in\n let[@warning \"-4\"] sg_new =\n match sg_new with\n | [| Kimchi_types.Finite x |] ->\n x\n | _ ->\n assert false\n in\n let overwritten_prechals =\n Array.map overwritten_prechals\n ~f:Bulletproof_challenge.unpack\n in\n\n (sg_new, overwritten_prechals, b)\n in\n let plonk =\n let module Field = struct\n include Tick.Field\n end in\n Wrap.Type1.derive_plonk\n (module Field)\n ~shift:Shifts.tick1 ~env:tick_env tick_plonk_minimal\n tick_combined_evals\n in\n let shift_value =\n Shifted_value.Type1.of_field\n (module Tick.Field)\n ~shift:Shifts.tick1\n in\n let branch_data : Composition_types.Branch_data.t =\n { proofs_verified =\n ( match actual_proofs_verified with\n | Z ->\n Composition_types.Branch_data.Proofs_verified.N0\n | S Z ->\n N1\n | S (S Z) ->\n N2\n | S _ ->\n assert false )\n ; domain_log2 =\n Composition_types.Branch_data.Domain_log2.of_int_exn\n step_vk.domain.log_size_of_group\n }\n in\n let messages_for_next_wrap_proof :\n _\n P.Base.Messages_for_next_proof_over_same_field.Wrap.t\n =\n { challenge_polynomial_commitment = sg_new\n ; old_bulletproof_challenges =\n Vector.map\n prev_statement.proof_state.unfinalized_proofs\n ~f:(fun t ->\n t.deferred_values.bulletproof_challenges )\n }\n in\n { proof_state =\n { deferred_values =\n { xi\n ; b = shift_value b\n ; bulletproof_challenges =\n Vector.of_array_and_length_exn\n new_bulletproof_challenges Tick.Rounds.n\n ; combined_inner_product =\n shift_value combined_inner_product\n ; branch_data\n ; plonk =\n { plonk with\n zeta = plonk0.zeta\n ; alpha = plonk0.alpha\n ; beta = chal plonk0.beta\n ; gamma = chal plonk0.gamma\n ; joint_combiner = Opt.nothing\n }\n }\n ; sponge_digest_before_evaluations =\n Digest.Constant.of_tick_field\n sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n }\n ; messages_for_next_step_proof =\n prev_statement.proof_state\n .messages_for_next_step_proof\n }\n in\n let messages_for_next_wrap_proof_prepared =\n P.Base.Messages_for_next_proof_over_same_field.Wrap\n .prepare\n next_statement.proof_state.messages_for_next_wrap_proof\n in\n let%map.Promise next_proof =\n let (T (input, conv, _conv_inv)) =\n Impls.Wrap.input ~feature_flags ()\n in\n Common.time \"wrap proof\" (fun () ->\n Impls.Wrap.generate_witness_conv\n ~f:(fun { Impls.Wrap.Proof_inputs.auxiliary_inputs\n ; public_inputs\n } () ->\n Backend.Tock.Proof.create_async\n ~primary:public_inputs\n ~auxiliary:auxiliary_inputs pk\n ~message:\n ( Vector.map2\n (Vector.extend_front_exn\n prev_statement.proof_state\n .messages_for_next_step_proof\n .challenge_polynomial_commitments\n max_proofs_verified\n (Lazy.force Dummy.Ipa.Wrap.sg) )\n messages_for_next_wrap_proof_prepared\n .old_bulletproof_challenges\n ~f:(fun sg chals ->\n { Tock.Proof.Challenge_polynomial\n .commitment = sg\n ; challenges = Vector.to_array chals\n } )\n |> Wrap_hack.pad_accumulator ) )\n ~input_typ:input\n ~return_typ:(Snarky_backendless.Typ.unit ())\n (fun x () : unit -> wrap_main (conv x))\n { messages_for_next_step_proof =\n prev_statement_with_hashes.proof_state\n .messages_for_next_step_proof\n ; proof_state =\n { next_statement.proof_state with\n messages_for_next_wrap_proof =\n Wrap_hack.hash_messages_for_next_wrap_proof\n max_proofs_verified\n messages_for_next_wrap_proof_prepared\n ; deferred_values =\n { next_statement.proof_state.deferred_values with\n plonk =\n { next_statement.proof_state\n .deferred_values\n .plonk\n with\n joint_combiner = None\n }\n }\n }\n } )\n in\n ( { proof = Wrap_wire_proof.of_kimchi_proof next_proof.proof\n ; statement =\n Types.Wrap.Statement.to_minimal\n ~to_option:Opt.to_option next_statement\n ; prev_evals =\n { Plonk_types.All_evals.evals =\n { public_input = x_hat\n ; evals = proof.openings.evals\n }\n ; ft_eval1 = proof.openings.ft_eval1\n }\n }\n : _ P.Base.Wrap.t )\n in\n wrap ~max_proofs_verified:Max_proofs_verified.n\n full_signature.maxes ~dlog_plonk_index:wrap_vk.commitments\n wrap_main A_value.to_field_elements ~pairing_vk\n ~step_domains:b.domains\n ~pairing_plonk_indices:(Lazy.force step_vks) ~wrap_domains\n (Impls.Wrap.Keypair.pk (fst (Lazy.force wrap_pk)))\n proof\n in\n Proof.T\n { proof with\n statement =\n { proof.statement with\n messages_for_next_step_proof =\n { proof.statement.messages_for_next_step_proof with\n app_state = ()\n }\n }\n }\n in\n wrap\n in\n f step_data step_keypair\n in\n let data : _ Types_map.Compiled.t =\n { branches = Branches.n\n ; feature_flags\n ; proofs_verifieds\n ; max_proofs_verified = (module Max_proofs_verified)\n ; public_input = typ\n ; wrap_key = Lazy.map wrap_vk ~f:Verification_key.commitments\n ; wrap_vk = Lazy.map wrap_vk ~f:Verification_key.index\n ; wrap_domains\n ; step_domains\n }\n in\n Types_map.add_exn self data ;\n (prover, wrap_vk, disk_key)\n end\n\n let step, wrap_vk, wrap_disk_key = M.compile\n\n module Proof = struct\n module Max_local_max_proofs_verified = Max_proofs_verified\n include Proof.Make (Max_proofs_verified) (Max_local_max_proofs_verified)\n\n let _id = wrap_disk_key\n\n let verification_key = wrap_vk\n\n let verify ts =\n verify_promise\n (module Max_proofs_verified)\n (module A_value)\n (Lazy.force verification_key)\n ts\n\n let _statement (T p : t) =\n p.statement.messages_for_next_step_proof.app_state\n end\n\n let proof_with_stmt =\n let p = Promise.block_on_async_exn (fun () -> step ()) in\n ((), p)\n\n let%test \"should not be able to verify invalid proof\" =\n Or_error.is_error\n @@ Promise.block_on_async_exn (fun () ->\n Proof.verify [ proof_with_stmt ] )\n\n module Recurse_on_bad_proof = struct\n open Impls.Step\n\n let _dummy_proof =\n Proof0.dummy Nat.N2.n Nat.N2.n Nat.N2.n ~domain_log2:15\n\n type _ Snarky_backendless.Request.t +=\n | Proof : (Nat.N2.n, Nat.N2.n) Proof0.t Snarky_backendless.Request.t\n\n let handler (proof : _ Proof0.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Proof ->\n respond (Provide proof)\n | _ ->\n respond Unhandled\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Typ.unit)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"recurse-on-bad\" ~constraint_constants\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = [ tag; tag ]\n ; main =\n (fun { public_input = () } ->\n let proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Proof )\n in\n { previous_proof_statements =\n [ { public_input = ()\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ; { public_input = ()\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n end\n\n let%test \"should not be able to create a recursive proof from an invalid \\\n proof\" =\n try\n let (), (), proof =\n Promise.block_on_async_exn (fun () ->\n Recurse_on_bad_proof.step\n ~handler:(Recurse_on_bad_proof.handler (snd proof_with_stmt))\n () )\n in\n Or_error.is_error\n @@ Promise.block_on_async_exn (fun () ->\n Recurse_on_bad_proof.Proof.verify_promise [ ((), proof) ] )\n with _ -> true\n end )\n\n let%test_module \"adversarial_tests\" =\n ( module struct\n [@@@warning \"-60\"]\n\n let () = Backtrace.elide := false\n\n let () = Snarky_backendless.Snark0.set_eval_constraints true\n\n let%test_module \"test domain size too large\" =\n ( module Compile.Make_adversarial_test (struct\n let tweak_statement (stmt : _ Import.Types.Wrap.Statement.In_circuit.t)\n =\n (* Modify the statement to use an invalid domain size. *)\n { stmt with\n proof_state =\n { stmt.proof_state with\n deferred_values =\n { stmt.proof_state.deferred_values with\n branch_data =\n { stmt.proof_state.deferred_values.branch_data with\n Branch_data.domain_log2 =\n Branch_data.Domain_log2.of_int_exn\n (Nat.to_int Kimchi_pasta.Basic.Rounds.Step.n + 1)\n }\n }\n }\n }\n\n let check_verifier_error err =\n (* Convert to JSON to make it easy to parse. *)\n err |> Error_json.error_to_yojson\n |> Yojson.Safe.Util.member \"multiple\"\n |> Yojson.Safe.Util.to_list\n |> List.find_exn ~f:(fun json ->\n let error =\n json\n |> Yojson.Safe.Util.member \"string\"\n |> Yojson.Safe.Util.to_string\n in\n String.equal error \"domain size is small enough\" )\n |> fun _ -> ()\n end) )\n end )\n\n let%test_module \"domain too small\" =\n ( module struct\n open Impls.Step\n\n (* Currently, a circuit must have at least 1 of every type of constraint. *)\n let dummy_constraints () =\n Impl.(\n let x =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3)\n in\n let g =\n exists Step_main_inputs.Inner_curve.typ ~compute:(fun _ ->\n Tick.Inner_curve.(to_affine_exn one) )\n in\n ignore\n ( SC.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t ))\n\n module No_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n module Fake_1_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N1)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n module Fake_2_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~override_wrap_domain:Pickles_base.Proofs_verified.N1\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n [@@@warning \"-60\"]\n\n module Simple_chain = struct\n type _ Snarky_backendless.Request.t +=\n | Prev_input : Field.Constant.t Snarky_backendless.Request.t\n | Proof : Side_loaded.Proof.t Snarky_backendless.Request.t\n | Verifier_index :\n Side_loaded.Verification_key.t Snarky_backendless.Request.t\n\n let handler (prev_input : Field.Constant.t) (proof : _ Proof.t)\n (verifier_index : Side_loaded.Verification_key.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Prev_input ->\n respond (Provide prev_input)\n | Proof ->\n respond (Provide proof)\n | Verifier_index ->\n respond (Provide verifier_index)\n | _ ->\n respond Unhandled\n\n let side_loaded_tag =\n Side_loaded.create ~name:\"foo\"\n ~max_proofs_verified:(Nat.Add.create Nat.N2.n)\n ~feature_flags:Plonk_types.Features.none ~typ:Field.typ\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N1)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = [ side_loaded_tag ]\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n let prev =\n exists Field.typ ~request:(fun () -> Prev_input)\n in\n let proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Proof )\n in\n let vk =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Verifier_index )\n in\n as_prover (fun () ->\n let vk = As_prover.Ref.get vk in\n Side_loaded.in_prover side_loaded_tag vk ) ;\n let vk =\n exists Side_loaded_verification_key.typ\n ~compute:(fun () -> As_prover.Ref.get vk)\n in\n Side_loaded.in_circuit side_loaded_tag vk ;\n let is_base_case = Field.equal Field.zero self in\n let self_correct = Field.(equal (one + prev) self) in\n Boolean.Assert.any [ self_correct; is_base_case ] ;\n { previous_proof_statements =\n [ { public_input = prev\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let _example1 =\n let (), (), b1 =\n Common.time \"b1\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler No_recursion.example_input\n (Side_loaded.Proof.of_proof\n No_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n No_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b1) ] ) ) ;\n (Field.Constant.one, b1)\n\n let _example2 =\n let (), (), b2 =\n Common.time \"b2\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler Fake_1_recursion.example_input\n (Side_loaded.Proof.of_proof\n Fake_1_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n Fake_1_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b2) ] ) ) ;\n (Field.Constant.one, b2)\n\n let _example3 =\n let (), (), b3 =\n Common.time \"b3\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler Fake_2_recursion.example_input\n (Side_loaded.Proof.of_proof\n Fake_2_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n Fake_2_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b3) ] ) ) ;\n (Field.Constant.one, b3)\n end\n end )\n\n let%test_module \"side-loaded with feature flags\" =\n ( module struct\n open Impls.Step\n\n [@@@warning \"-60\"]\n\n module Statement = struct\n [@@@warning \"-32-34\"]\n\n type t = Field.t\n\n let to_field_elements x = [| x |]\n\n module Constant = struct\n type t = Field.Constant.t [@@deriving bin_io]\n\n [@@@warning \"-32\"]\n\n let to_field_elements x = [| x |]\n end\n end\n\n (* Currently, a circuit must have at least 1 of every type of constraint. *)\n let dummy_constraints () =\n Impl.(\n let x =\n exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3)\n in\n let g =\n exists Step_main_inputs.Inner_curve.typ ~compute:(fun _ ->\n Tick.Inner_curve.(to_affine_exn one) )\n in\n ignore\n ( SC.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Step_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t ))\n\n module No_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N0)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n module Fake_1_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N1)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n module Fake_2_recursion = struct\n let[@warning \"-45\"] tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~override_wrap_domain:Pickles_base.Proofs_verified.N1\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = []\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n dummy_constraints () ;\n Field.Assert.equal self Field.zero ;\n { previous_proof_statements = []\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let example =\n let (), (), b0 =\n Common.time \"b0\" (fun () ->\n Promise.block_on_async_exn (fun () -> step Field.Constant.zero) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.zero, b0) ] ) ) ;\n (Field.Constant.zero, b0)\n\n let example_input, example_proof = example\n end\n\n [@@@warning \"-60\"]\n\n module Simple_chain = struct\n type _ Snarky_backendless.Request.t +=\n | Prev_input : Field.Constant.t Snarky_backendless.Request.t\n | Proof : Side_loaded.Proof.t Snarky_backendless.Request.t\n | Verifier_index :\n Side_loaded.Verification_key.t Snarky_backendless.Request.t\n\n let handler (prev_input : Field.Constant.t) (proof : _ Proof.t)\n (verifier_index : Side_loaded.Verification_key.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Prev_input ->\n respond (Provide prev_input)\n | Proof ->\n respond (Provide proof)\n | Verifier_index ->\n respond (Provide verifier_index)\n | _ ->\n respond Unhandled\n\n let maybe_features =\n Plonk_types.Features.(map none ~f:(fun _ -> Opt.Flag.Maybe))\n\n let side_loaded_tag =\n Side_loaded.create ~name:\"foo\"\n ~max_proofs_verified:(Nat.Add.create Nat.N2.n)\n ~feature_flags:maybe_features ~typ:Field.typ\n\n let[@warning \"-45\"] _tag, _, p, Provers.[ step ] =\n Common.time \"compile\" (fun () ->\n compile_promise () ~public_input:(Input Field.typ)\n ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N1)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; prevs = [ side_loaded_tag ]\n ; feature_flags = Plonk_types.Features.none_bool\n ; main =\n (fun { public_input = self } ->\n let prev =\n exists Field.typ ~request:(fun () -> Prev_input)\n in\n let proof =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Proof )\n in\n let vk =\n exists (Typ.Internal.ref ()) ~request:(fun () ->\n Verifier_index )\n in\n as_prover (fun () ->\n let vk = As_prover.Ref.get vk in\n Side_loaded.in_prover side_loaded_tag vk ) ;\n let vk =\n exists Side_loaded_verification_key.typ\n ~compute:(fun () -> As_prover.Ref.get vk)\n in\n Side_loaded.in_circuit side_loaded_tag vk ;\n let is_base_case = Field.equal Field.zero self in\n let self_correct = Field.(equal (one + prev) self) in\n Boolean.Assert.any [ self_correct; is_base_case ] ;\n { previous_proof_statements =\n [ { public_input = prev\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n\n let _example1 =\n let (), (), b1 =\n Common.time \"b1\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler No_recursion.example_input\n (Side_loaded.Proof.of_proof\n No_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n No_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b1) ] ) ) ;\n (Field.Constant.one, b1)\n\n let _example2 =\n let (), (), b2 =\n Common.time \"b2\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler Fake_1_recursion.example_input\n (Side_loaded.Proof.of_proof\n Fake_1_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n Fake_1_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b2) ] ) ) ;\n (Field.Constant.one, b2)\n\n let _example3 =\n let (), (), b3 =\n Common.time \"b3\" (fun () ->\n Promise.block_on_async_exn (fun () ->\n step\n ~handler:\n (handler Fake_2_recursion.example_input\n (Side_loaded.Proof.of_proof\n Fake_2_recursion.example_proof )\n (Side_loaded.Verification_key.of_compiled\n Fake_2_recursion.tag ) )\n Field.Constant.one ) )\n in\n Or_error.ok_exn\n (Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ (Field.Constant.one, b3) ] ) ) ;\n (Field.Constant.one, b3)\n end\n end )\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nmodule H_list = Snarky_backendless.H_list\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'comm t =\n { sigma_comm : 'comm Plonk_types.Permuts_vec.Stable.V1.t\n ; coefficients_comm : 'comm Plonk_types.Columns_vec.Stable.V1.t\n ; generic_comm : 'comm\n ; psm_comm : 'comm\n ; complete_add_comm : 'comm\n ; mul_comm : 'comm\n ; emul_comm : 'comm\n ; endomul_scalar_comm : 'comm\n }\n [@@deriving sexp, equal, compare, hash, yojson, hlist, fields]\n (* TODO: Remove unused annotations *)\n end\nend]\n\n(* TODO: Remove unused functions *)\n\nlet map\n { sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n } ~f =\n { sigma_comm = Vector.map ~f sigma_comm\n ; coefficients_comm = Vector.map ~f coefficients_comm\n ; generic_comm = f generic_comm\n ; psm_comm = f psm_comm\n ; complete_add_comm = f complete_add_comm\n ; mul_comm = f mul_comm\n ; emul_comm = f emul_comm\n ; endomul_scalar_comm = f endomul_scalar_comm\n }\n\nlet map2 t1 t2 ~f =\n { sigma_comm = Vector.map2 ~f t1.sigma_comm t2.sigma_comm\n ; coefficients_comm = Vector.map2 ~f t1.coefficients_comm t2.coefficients_comm\n ; generic_comm = f t1.generic_comm t2.generic_comm\n ; psm_comm = f t1.psm_comm t2.psm_comm\n ; complete_add_comm = f t1.complete_add_comm t2.complete_add_comm\n ; mul_comm = f t1.mul_comm t2.mul_comm\n ; emul_comm = f t1.emul_comm t2.emul_comm\n ; endomul_scalar_comm = f t1.endomul_scalar_comm t2.endomul_scalar_comm\n }\n\nlet typ g =\n Snarky_backendless.Typ.of_hlistable\n [ Vector.typ g Plonk_types.Permuts.n\n ; Vector.typ g Plonk_types.Columns.n\n ; g\n ; g\n ; g\n ; g\n ; g\n ; g\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\nmodule Step = struct\n type ('comm, 'opt_comm) t =\n { sigma_comm : 'comm Plonk_types.Permuts_vec.t\n ; coefficients_comm : 'comm Plonk_types.Columns_vec.t\n ; generic_comm : 'comm\n ; psm_comm : 'comm\n ; complete_add_comm : 'comm\n ; mul_comm : 'comm\n ; emul_comm : 'comm\n ; endomul_scalar_comm : 'comm\n ; xor_comm : 'opt_comm\n ; range_check0_comm : 'opt_comm\n ; range_check1_comm : 'opt_comm\n ; foreign_field_add_comm : 'opt_comm\n ; foreign_field_mul_comm : 'opt_comm\n ; rot_comm : 'opt_comm\n ; lookup_table_comm : 'opt_comm Plonk_types.Lookup_sorted_minus_1_vec.t\n ; lookup_table_ids : 'opt_comm\n ; runtime_tables_selector : 'opt_comm\n ; lookup_selector_lookup : 'opt_comm\n ; lookup_selector_xor : 'opt_comm\n ; lookup_selector_range_check : 'opt_comm\n ; lookup_selector_ffmul : 'opt_comm\n }\n [@@deriving sexp, equal, compare, hash, yojson, hlist, fields]\n\n let map\n { sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n ; xor_comm\n ; range_check0_comm\n ; range_check1_comm\n ; foreign_field_add_comm\n ; foreign_field_mul_comm\n ; rot_comm\n ; lookup_table_comm\n ; lookup_table_ids\n ; runtime_tables_selector\n ; lookup_selector_lookup\n ; lookup_selector_xor\n ; lookup_selector_range_check\n ; lookup_selector_ffmul\n } ~f ~f_opt =\n { sigma_comm = Vector.map ~f sigma_comm\n ; coefficients_comm = Vector.map ~f coefficients_comm\n ; generic_comm = f generic_comm\n ; psm_comm = f psm_comm\n ; complete_add_comm = f complete_add_comm\n ; mul_comm = f mul_comm\n ; emul_comm = f emul_comm\n ; endomul_scalar_comm = f endomul_scalar_comm\n ; xor_comm = f_opt xor_comm\n ; range_check0_comm = f_opt range_check0_comm\n ; range_check1_comm = f_opt range_check1_comm\n ; foreign_field_add_comm = f_opt foreign_field_add_comm\n ; foreign_field_mul_comm = f_opt foreign_field_mul_comm\n ; rot_comm = f_opt rot_comm\n ; lookup_table_comm = Vector.map ~f:f_opt lookup_table_comm\n ; lookup_table_ids = f_opt lookup_table_ids\n ; runtime_tables_selector = f_opt runtime_tables_selector\n ; lookup_selector_lookup = f_opt lookup_selector_lookup\n ; lookup_selector_xor = f_opt lookup_selector_xor\n ; lookup_selector_range_check = f_opt lookup_selector_range_check\n ; lookup_selector_ffmul = f_opt lookup_selector_ffmul\n }\n\n let map2 t1 t2 ~f ~f_opt =\n { sigma_comm = Vector.map2 ~f t1.sigma_comm t2.sigma_comm\n ; coefficients_comm =\n Vector.map2 ~f t1.coefficients_comm t2.coefficients_comm\n ; generic_comm = f t1.generic_comm t2.generic_comm\n ; psm_comm = f t1.psm_comm t2.psm_comm\n ; complete_add_comm = f t1.complete_add_comm t2.complete_add_comm\n ; mul_comm = f t1.mul_comm t2.mul_comm\n ; emul_comm = f t1.emul_comm t2.emul_comm\n ; endomul_scalar_comm = f t1.endomul_scalar_comm t2.endomul_scalar_comm\n ; xor_comm = f_opt t1.xor_comm t2.xor_comm\n ; range_check0_comm = f_opt t1.range_check0_comm t2.range_check0_comm\n ; range_check1_comm = f_opt t1.range_check1_comm t2.range_check1_comm\n ; foreign_field_add_comm =\n f_opt t1.foreign_field_add_comm t2.foreign_field_add_comm\n ; foreign_field_mul_comm =\n f_opt t1.foreign_field_mul_comm t2.foreign_field_mul_comm\n ; rot_comm = f_opt t1.rot_comm t2.rot_comm\n ; lookup_table_comm =\n Vector.map2 ~f:f_opt t1.lookup_table_comm t2.lookup_table_comm\n ; lookup_table_ids = f_opt t1.lookup_table_ids t2.lookup_table_ids\n ; runtime_tables_selector =\n f_opt t1.runtime_tables_selector t2.runtime_tables_selector\n ; lookup_selector_lookup =\n f_opt t1.lookup_selector_lookup t2.lookup_selector_lookup\n ; lookup_selector_xor = f_opt t1.lookup_selector_xor t2.lookup_selector_xor\n ; lookup_selector_range_check =\n f_opt t1.lookup_selector_range_check t2.lookup_selector_range_check\n ; lookup_selector_ffmul =\n f_opt t1.lookup_selector_ffmul t2.lookup_selector_ffmul\n }\n\n let typ g g_opt =\n Snarky_backendless.Typ.of_hlistable\n [ Vector.typ g Plonk_types.Permuts.n\n ; Vector.typ g Plonk_types.Columns.n\n ; g\n ; g\n ; g\n ; g\n ; g\n ; g\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ; Vector.typ g_opt Plonk_types.Lookup_sorted_minus_1.n\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ; g_opt\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n let forget_optional_commitments\n { sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n ; xor_comm = _\n ; range_check0_comm = _\n ; range_check1_comm = _\n ; foreign_field_add_comm = _\n ; foreign_field_mul_comm = _\n ; rot_comm = _\n ; lookup_table_comm = _\n ; lookup_table_ids = _\n ; runtime_tables_selector = _\n ; lookup_selector_lookup = _\n ; lookup_selector_xor = _\n ; lookup_selector_range_check = _\n ; lookup_selector_ffmul = _\n } : _ Stable.Latest.t =\n { sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n }\nend\n","open Core_kernel\nmodule Intf = Intf\n\nmodule Params = struct\n include Params\n\n let bn128 = Constants.params_Bn128\n\n let mnt4_298 = Constants.params_Mnt4_298\n\n let mnt4_753 = Constants.params_Mnt4_753\n\n let bn382_p = Constants.params_Bn382_p\n\n let bn382_q = Constants.params_Bn382_q\n\n let tweedle_p = Constants.params_Tweedle_p\n\n let tweedle_q = Constants.params_Tweedle_q\n\n let pasta_p_legacy = Constants.params_Pasta_p_legacy\n\n let pasta_q_legacy = Constants.params_Pasta_q_legacy\n\n let pasta_p_kimchi = Constants.params_Pasta_p_kimchi\n\n let pasta_q_kimchi = Constants.params_Pasta_q_kimchi\nend\n\nmodule State = Array\n\nlet for_ n ~init ~f =\n let rec go i acc = if Int.(i = n) then acc else go (i + 1) (f i acc) in\n go 0 init\n\nmodule Make_operations (Field : Intf.Field) = struct\n let add_assign ~state i x = state.(i) <- Field.( + ) state.(i) x\n\n let apply_affine_map (matrix, constants) v =\n let dotv row =\n Array.reduce_exn (Array.map2_exn row v ~f:Field.( * )) ~f:Field.( + )\n in\n let res = Array.map matrix ~f:dotv in\n for i = 0 to Array.length res - 1 do\n res.(i) <- Field.( + ) res.(i) constants.(i)\n done ;\n res\n\n let copy = Array.copy\nend\n\nlet m = 3\n\nmodule Bn382_inputs (Field : Intf.Field_mutable) = struct\n let rounds_full = 8\n\n let initial_ark = true\n\n let rounds_partial = 30\n\n module Field = Field\n\n let alpha = 17\n\n (* alpha = 17 *)\n let to_the_alpha x =\n let open Field in\n let res = square x in\n Mutable.square res ;\n (* x^4 *)\n Mutable.square res ;\n (* x^8 *)\n Mutable.square res ;\n (* x^16 *)\n res *= x ;\n res\n\n module Operations = struct\n let add_assign ~state i x = Field.(state.(i) += x)\n\n (* Sparse pseudo-MDS matrix *)\n let apply_affine_map (_rows, c) v =\n let open Field in\n let res = [| v.(0) + v.(2); v.(0) + v.(1); v.(1) + v.(2) |] in\n Array.iteri res ~f:(fun i ri -> ri += c.(i)) ;\n res\n\n let copy a = Array.map a ~f:(fun x -> Field.(x + zero))\n end\nend\n\nmodule Rescue (Inputs : Intf.Inputs.Rescue) = struct\n (*\n We refer below to this paper: https://eprint.iacr.org/2019/426.pdf.\n\nI arrived at this value for the number of rounds in the following way.\nAs mentioned on page 34, the cost of performing the Grobner basis attack is estimated as\n\n( (n + d) choose d ) ^ omega\nwhere\n\n- omega is some number which is known to be >= 2\n- n = 1 + m*N is the number of variables in the system of equations on page 3\n- d is a quantity which they estimate as ((alpha - 1)(m*N + 1) + 1) / 2\n- m is the state size, which we can choose\n- N is the number of rounds which we can choose\n\nFor the MNT curves, `alpha = 11`, and I took `m = 3` which is optimal for binary Merkle trees.\nEvaluating the above formula with these values and `N = 11` and `omega = 2` yields an attack complexity\nof a little over 2^257, which if we take the same factor of 2 security margin as they use in the paper,\ngives us a security level of 257/2 ~= 128.\n\nNB: As you can see from the analysis this is really specialized to alpha = 11 and the number of rounds\nshould be higher for smaller alpha.\n*)\n\n open Inputs\n include Operations\n module Field = Field\n\n let sbox0, sbox1 = (alphath_root, to_the_alpha)\n\n let add_block ~state block = Array.iteri block ~f:(add_assign ~state)\n\n let block_cipher { Params.round_constants; mds } state =\n add_block ~state round_constants.(0) ;\n for_ (2 * rounds) ~init:state ~f:(fun r state ->\n let sbox = if Int.(r mod 2 = 0) then sbox0 else sbox1 in\n Array.map_inplace state ~f:sbox ;\n apply_affine_map (mds, round_constants.(r + 1)) state )\nend\n\nmodule Poseidon (Inputs : Intf.Inputs.Poseidon) = struct\n open Inputs\n include Operations\n module Field = Field\n\n let first_half_rounds_full = rounds_full / 2\n\n let add_block ~state block = Array.iteri block ~f:(add_assign ~state)\n\n (* Poseidon goes\n\n ARK_0 -> SBOX -> MDS\n -> ARK_1 -> SBOX -> MDS\n -> ...\n -> ARK_{half_rounds_full - 1} -> SBOX -> MDS\n -> ARK_{half_rounds_full} -> SBOX0 -> MDS\n -> ...\n -> ARK_{half_rounds_full + rounds_partial - 1} -> SBOX0 -> MDS\n -> ARK_{half_rounds_full + rounds_partial} -> SBOX -> MDS\n -> ...\n -> ARK_{half_rounds_full + rounds_partial + half_rounds_full - 1} -> SBOX -> MDS\n\n It is best to apply the matrix and add the round constants at the same\n time for Marlin constraint efficiency, so that is how this implementation does it.\n Like,\n\n ARK_0\n -> SBOX -> (MDS -> ARK_1)\n -> SBOX -> (MDS -> ARK_2)\n -> ...\n -> SBOX -> (MDS -> ARK_{half_rounds_full - 1})\n -> SBOX -> (MDS -> ARK_{half_rounds_full})\n -> SBOX0 -> (MDS -> ARK_{half_rounds_full + 1})\n -> ...\n -> SBOX0 -> (MDS -> ARK_{half_rounds_full + rounds_partial - 1})\n -> SBOX0 -> (MDS -> ARK_{half_rounds_full + rounds_partial})\n -> SBOX -> (MDS -> ARK_{half_rounds_full + rounds_partial + 1})\n -> ...\n -> SBOX -> (MDS -> ARK_{half_rounds_full + rounds_partial + half_rounds_full - 1})\n -> SBOX -> MDS ->* ARK_{half_rounds_full + rounds_partial + half_rounds_full}\n\n *this last round is a deviation from standard poseidon made for efficiency reasons.\n clearly it does not impact security to add round constants\n *)\n let block_cipher { Params.round_constants; mds } state =\n let sbox = to_the_alpha in\n let state = ref state in\n let constant_offset =\n if initial_ark then (\n add_block ~state:!state round_constants.(0) ;\n 1 )\n else 0\n in\n let range =\n (constant_offset, constant_offset + first_half_rounds_full - 1)\n in\n for i = fst range to snd range do\n (* SBOX -> MDS -> ARK *)\n Array.map_inplace !state ~f:sbox ;\n state := apply_affine_map (mds, round_constants.(i)) !state\n done ;\n let range = (snd range + 1, snd range + rounds_partial) in\n for i = fst range to snd range do\n !state.(0) <- sbox !state.(0) ;\n state := apply_affine_map (mds, round_constants.(i)) !state\n done ;\n let second_half_rounds_full = rounds_full - first_half_rounds_full in\n let range = (snd range + 1, snd range + second_half_rounds_full) in\n for i = fst range to snd range do\n Array.map_inplace !state ~f:sbox ;\n state := apply_affine_map (mds, round_constants.(i)) !state\n done ;\n !state\nend\n\nmodule Make_hash (P : Intf.Permutation) = struct\n open P\n\n let state_size = m\n\n let rate = state_size - 1\n\n let add_block ~state block = Array.iteri block ~f:(add_assign ~state)\n\n let sponge perm blocks ~state =\n Array.fold ~init:state blocks ~f:(fun state block ->\n add_block ~state block ; perm state )\n\n (* takes an array of field elements, and spread them into blocks/arrays that can contain [rate] fied elements *)\n let to_blocks rate field_elems =\n let n = Array.length field_elems in\n let num_blocks = if n = 0 then 1 else (n + rate - 1) / rate in\n let fill_block block_idx pos =\n let global_pos = (rate * block_idx) + pos in\n if global_pos < n then field_elems.(global_pos)\n else (* padding *) Field.zero\n in\n let create_block idx = Array.init rate ~f:(fill_block idx) in\n Array.init num_blocks ~f:create_block\n\n let%test_unit \"empty field_elems to_blocks\" =\n let blocks = to_blocks 2 [||] in\n assert (Array.length blocks = 1) ;\n [%test_eq: unit array array]\n (Array.map blocks ~f:(Array.map ~f:ignore))\n [| [| (); () |] |]\n\n let%test_unit \"block\" =\n let z = Field.zero in\n [%test_eq: unit array array]\n (Array.map (to_blocks 2 [| z; z; z |]) ~f:(Array.map ~f:ignore))\n [| [| (); () |]; [| (); () |] |]\n\n let update params ~state inputs =\n let state = copy state in\n sponge (block_cipher params) (to_blocks rate inputs) ~state\n\n let digest state = state.(0)\n\n let initial_state = Array.init state_size ~f:(fun _ -> Field.zero)\n\n let hash ?(init = initial_state) params inputs =\n update params ~state:init inputs |> digest\nend\n\ntype sponge_state = Absorbed of int | Squeezed of int [@@deriving sexp]\n\ntype 'f t =\n { mutable state : 'f State.t\n ; params : 'f Params.t\n ; mutable sponge_state : sponge_state\n ; id : int\n }\n\nlet id = ref (-1)\n\nlet make ~state ~params ~sponge_state =\n incr id ;\n { state; params; sponge_state; id = !id }\n\nmodule Make_sponge (P : Intf.Permutation) = struct\n open P\n\n let make = make\n\n let capacity = 1\n\n type sponge_state = Absorbed of int | Squeezed of int [@@deriving sexp]\n\n type nonrec t = Field.t t\n\n let state { state; _ } = copy state\n\n let initial_state = Array.init m ~f:(fun _ -> Field.zero)\n\n let create ?(init = initial_state) params =\n make ~state:(copy init) ~sponge_state:(Absorbed 0) ~params\n\n let copy { state; params; sponge_state; id } =\n { state = copy state; params; sponge_state; id }\n\n let rate = m - capacity\n\n let absorb t x =\n match t.sponge_state with\n | Absorbed n ->\n if n = rate then (\n t.state <- block_cipher t.params t.state ;\n add_assign ~state:t.state 0 x ;\n t.sponge_state <- Absorbed 1 )\n else (\n add_assign ~state:t.state n x ;\n t.sponge_state <- Absorbed (n + 1) )\n | Squeezed _ ->\n add_assign ~state:t.state 0 x ;\n t.sponge_state <- Absorbed 1\n\n let squeeze t =\n (* to prevent giving a reference to the internal state *)\n let copy x = (P.copy [| x |]).(0) in\n match t.sponge_state with\n | Squeezed n ->\n if n = rate then (\n t.state <- block_cipher t.params t.state ;\n t.sponge_state <- Squeezed 1 ;\n copy t.state.(0) )\n else (\n t.sponge_state <- Squeezed (n + 1) ;\n copy t.state.(n) )\n | Absorbed _ ->\n t.state <- block_cipher t.params t.state ;\n t.sponge_state <- Squeezed 1 ;\n copy t.state.(0)\nend\n\nmodule Make_debug_sponge (P : sig\n include Intf.Permutation\n\n module Circuit : Snarky_backendless.Snark_intf.Run\n\n val sponge_name : string\n\n val debug_helper_fn : Field.t -> string\nend) =\nstruct\n include Make_sponge (P)\n\n (* In sponge debug mode, prints a standard sponge debug line, otherwise does nothing.\n Note: standard sponge debug line must match the output of Kimchi's sponge debug mode *)\n let debug (operation : string) (sponge : t) (input : P.Field.t option) =\n match Sys.getenv_opt P.sponge_name with\n | Some s -> (\n match String.lowercase s with\n | \"t\" | \"1\" | \"true\" ->\n P.Circuit.as_prover (fun () ->\n (* Convert sponge_state to match Rust style debug string *)\n let sponge_state =\n match sponge.sponge_state with\n | Absorbed n ->\n Printf.sprintf \"Absorbed(%d)\" n\n | Squeezed n ->\n Printf.sprintf \"Squeezed(%d)\" n\n in\n (* Print debug header, operation and sponge_state *)\n Format.eprintf \"debug_sponge: %s%d %s state %s\" P.sponge_name\n sponge.id operation sponge_state ;\n (* Print sponge's state array *)\n Array.iter sponge.state ~f:(fun fe ->\n Format.eprintf \" %s\" (P.debug_helper_fn fe) ) ;\n Format.eprintf \"@.\" ;\n (* Print optional input *)\n match input with\n | Some input ->\n Format.eprintf \"debug_sponge: %s%d %s input %s@.\"\n P.sponge_name sponge.id operation\n (P.debug_helper_fn input)\n | None ->\n () )\n | _ ->\n () )\n | None ->\n ()\n\n let make ~state ~params ~sponge_state =\n let t = make ~state ~params ~sponge_state in\n debug \"make\" t None ; t\n\n let absorb t x = debug \"absorb\" t (Some x) ; absorb t x\n\n let squeeze t = debug \"squeeze\" t None ; squeeze t\nend\n\nmodule Bit_sponge = struct\n type ('s, 'bool) t =\n { underlying : 's\n (* TODO: Have to be careful about these bits. They aren't perfectly uniform. *)\n ; mutable last_squeezed : 'bool list\n }\n\n let map (type a b) t ~(f : a -> b) : (b, _) t =\n { t with underlying = f t.underlying }\n\n let make ?(last_squeezed = []) underlying = { underlying; last_squeezed }\n\n let underlying { underlying; last_squeezed = _ } = underlying\n\n module Make\n (Bool : Intf.T) (Field : sig\n type t\n\n val to_bits : t -> Bool.t list\n\n val finalize_discarded : Bool.t list -> unit\n\n val high_entropy_bits : int\n end)\n (Input : Intf.T)\n (S : Intf.Sponge\n with module State := State\n and module Field := Field\n and type digest := Field.t\n and type input := Input.t) =\n struct\n type nonrec t = (S.t, Bool.t) t\n\n let state t = S.state t.underlying\n\n let high_entropy_bits = Field.high_entropy_bits\n\n let create ?init params =\n { underlying = S.create ?init params; last_squeezed = [] }\n\n let copy { underlying; last_squeezed } =\n { underlying = S.copy underlying; last_squeezed }\n\n let absorb t x =\n S.absorb t.underlying x ;\n t.last_squeezed <- []\n\n let rec squeeze t ~length =\n if List.length t.last_squeezed >= length then (\n let digest, remaining = List.split_n t.last_squeezed length in\n t.last_squeezed <- remaining ;\n digest )\n else\n let x = S.squeeze t.underlying in\n let hi =\n let hi, lo = List.split_n (Field.to_bits x) high_entropy_bits in\n Field.finalize_discarded lo ;\n hi\n in\n t.last_squeezed <- t.last_squeezed @ hi ;\n squeeze ~length t\n\n let squeeze_field t =\n t.last_squeezed <- [] ;\n S.squeeze t.underlying\n end\nend\n","open! Core_kernel\nopen! Import\nopen Tuple_pool_intf\nmodule Tuple_type = Tuple_type\n\nlet failwiths = Error.failwiths\nlet phys_equal = Caml.( == )\nlet arch_sixtyfour = Sys.word_size = 64\n\nmodule Int = struct\n let num_bits = Int.num_bits\n let max_value = Caml.max_int\n let to_string = string_of_int\nend\n\nlet sprintf = Printf.sprintf\nlet concat l = Base.String.concat ~sep:\"\" l\n\nmodule type S = S\n\nmodule Pool = struct\n let grow_capacity ~capacity ~old_capacity =\n match capacity with\n | None -> if old_capacity = 0 then 1 else old_capacity * 2\n | Some capacity ->\n if capacity <= old_capacity\n then\n failwiths\n ~here:[%here]\n \"Pool.grow got too small capacity\"\n (`capacity capacity, `old_capacity old_capacity)\n [%sexp_of: [ `capacity of int ] * [ `old_capacity of int ]];\n capacity\n ;;\n\n module Slots = Tuple_type.Slots\n\n let max_slot = 14\n\n (* The pool is represented as a single [Uniform_array.t], where index zero has the\n metadata about the pool and the remaining indices are the tuples layed out one after\n the other. Each tuple takes [1 + slots_per_tuple] indices in the pool, where the\n first index holds a header and the remaining indices hold the tuple's slots:\n\n {v\n | header | s0 | s1 | ... | s |\n v}\n\n A [Pointer.t] to a tuple contains the integer index where its header is, as well as\n (a mask of) the tuple's unique id.\n\n The free tuples are singly linked via the headers.\n\n When a tuple is in use, its header is marked to indicate so, and also to include the\n tuple's unique id. This allows us to check in constant time whether a pointer is\n valid, by comparing the id in the pointer with the id in the header.\n\n When a tuple is not in use, its header is part of the free list, and its tuple slots\n have dummy values of the appropriate types, from the [dummy] tuple supplied to\n [create]. We must have dummy values of the correct type to prevent a segfault in\n code that (mistakenly) uses a pointer to a free tuple.\n\n For [Pool.Unsafe], a slot in a free object is guaranteed to be an int; it must not be\n pointer to prevent a space leak. However, the int in the slot may not represent a\n valid value of the type.\n *)\n\n module Slot = struct\n type ('slots, 'a) t = int [@@deriving sexp_of]\n\n let equal (t1 : (_, _) t) t2 = t1 = t2\n let t0 = 1\n let t1 = 2\n let t2 = 3\n let t3 = 4\n let t4 = 5\n let t5 = 6\n let t6 = 7\n let t7 = 8\n let t8 = 9\n let t9 = 10\n let t10 = 11\n let t11 = 12\n let t12 = 13\n let t13 = 14\n\n let%test _ = t13 = max_slot\n end\n\n (* We only have [Int.num_bits] bits available for pool pointers. The bits of a pool\n pointer encode two things:\n\n - the tuple's array index in the pool\n - the tuple's identifier (not necessarily unique)\n\n We choose [array_index_num_bits] as large as needed for the maximum pool capacity\n that we want to support, and use the remaining [masked_tuple_id_num_bits] bits for\n the identifier. 64-bit and 32-bit architectures typically have very different\n address-space sizes, so we choose [array_index_num_bits] differently. *)\n\n let array_index_num_bits =\n if arch_sixtyfour\n then (\n assert (Int.num_bits = 63);\n 30)\n else (\n assert (Int.num_bits = 31 || Int.num_bits = 32);\n 22)\n ;;\n\n let masked_tuple_id_num_bits = Int.num_bits - array_index_num_bits\n\n let%test _ = array_index_num_bits > 0\n let%test _ = masked_tuple_id_num_bits > 0\n let%test _ = array_index_num_bits + masked_tuple_id_num_bits <= Int.num_bits\n\n let max_array_length = 1 lsl array_index_num_bits\n\n module Tuple_id : sig\n type t = private int [@@deriving sexp_of]\n\n include Invariant.S with type t := t\n\n val to_string : t -> string\n val equal : t -> t -> bool\n val init : t\n val next : t -> t\n val of_int : int -> t\n val to_int : t -> int\n val examples : t list\n end = struct\n type t = int [@@deriving sexp_of]\n\n (* We guarantee that tuple ids are nonnegative so that they can be encoded in\n headers. *)\n let invariant t = assert (t >= 0)\n let to_string = Int.to_string\n let equal (t1 : t) t2 = t1 = t2\n let init = 0\n let next t = if arch_sixtyfour then t + 1 else if t = Int.max_value then 0 else t + 1\n let to_int t = t\n\n let of_int i =\n if i < 0\n then failwiths ~here:[%here] \"Tuple_id.of_int got negative int\" i [%sexp_of: int];\n i\n ;;\n\n let examples = [ 0; 1; 0x1FFF_FFFF; Int.max_value ]\n end\n\n let tuple_id_mask = (1 lsl masked_tuple_id_num_bits) - 1\n\n module Pointer : sig\n (* [Pointer.t] is an encoding as an [int] of the following sum type:\n\n {[\n | Null\n | Normal of { header_index : int; masked_tuple_id : int }\n ]}\n\n The encoding is chosen to optimize the most common operation, namely tuple-slot\n access, the [slot_index] function. The encoding is designed so that [slot_index]\n produces a negative number for [Null], which will cause the subsequent array bounds\n check to fail. *)\n\n type 'slots t = private int [@@deriving sexp_of, typerep]\n\n include Invariant.S1 with type 'a t := 'a t\n\n val phys_compare : 'a t -> 'a t -> int\n val phys_equal : 'a t -> 'a t -> bool\n\n (* The null pointer. [null] is a function due to issues with the value restriction. *)\n\n val null : unit -> _ t\n val is_null : _ t -> bool\n\n (* Normal pointers. *)\n\n val create : header_index:int -> Tuple_id.t -> _ t\n val header_index : _ t -> int\n val masked_tuple_id : _ t -> int\n val slot_index : _ t -> (_, _) Slot.t -> int\n val first_slot_index : _ t -> int\n\n module Id : sig\n type t [@@deriving bin_io, sexp]\n\n val to_int63 : t -> Int63.t\n val of_int63 : Int63.t -> t\n end\n\n val to_id : _ t -> Id.t\n val of_id_exn : Id.t -> _ t\n end = struct\n (* A pointer is either [null] or the (positive) index in the pool of the next-free\n field preceeding the tuple's slots. *)\n type 'slots t = int [@@deriving typerep]\n\n let sexp_of_t _ t = Sexp.Atom (sprintf \"\" t)\n let phys_equal (t1 : _ t) t2 = phys_equal t1 t2\n let phys_compare = compare\n let null () = -max_slot - 1\n let is_null t = phys_equal t (null ())\n\n (* [null] must be such that [null + slot] is an invalid array index for all slots.\n Otherwise get/set on the null pointer may lead to a segfault. *)\n let%test _ = null () + max_slot < 0\n\n let create ~header_index (tuple_id : Tuple_id.t) =\n header_index\n lor ((Tuple_id.to_int tuple_id land tuple_id_mask) lsl array_index_num_bits)\n ;;\n\n let header_index_mask = (1 lsl array_index_num_bits) - 1\n let masked_tuple_id t = t lsr array_index_num_bits\n let header_index t = t land header_index_mask\n let invariant _ t = if not (is_null t) then assert (header_index t > 0)\n\n let%test_unit _ = invariant ignore (null ())\n\n let%test_unit _ =\n List.iter Tuple_id.examples ~f:(fun tuple_id ->\n invariant ignore (create ~header_index:1 tuple_id))\n ;;\n\n let slot_index t slot = header_index t + slot\n let first_slot_index t = slot_index t Slot.t0\n\n module Id = struct\n include Int63\n\n let to_int63 t = t\n let of_int63 i = i\n end\n\n let to_id t = Id.of_int t\n\n let of_id_exn id =\n try\n let t = Id.to_int_exn id in\n if is_null t\n then t\n else (\n let should_equal =\n create ~header_index:(header_index t) (Tuple_id.of_int (masked_tuple_id t))\n in\n if phys_equal t should_equal\n then t\n else failwiths ~here:[%here] \"should equal\" should_equal [%sexp_of: _ t])\n with\n | exn ->\n failwiths\n ~here:[%here]\n \"Pointer.of_id_exn got strange id\"\n (id, exn)\n [%sexp_of: Id.t * exn]\n ;;\n end\n\n module Header : sig\n (* A [Header.t] is an encoding as an [int] of the following type:\n\n {[\n | Null\n | Free of { next_free_header_index : int }\n | Used of { tuple_id : int }\n ]}\n\n If a tuple is free, its header is set to either [Null] or [Free] with\n [next_free_header_index] indicating the header of the next tuple on the free list.\n If a tuple is in use, it header is set to [Used]. *)\n\n type t = private int [@@deriving sexp_of]\n\n val null : t\n val is_null : t -> bool\n val free : next_free_header_index:int -> t\n val is_free : t -> bool\n val next_free_header_index : t -> int\n\n (* only valid if [is_free t] *)\n\n val used : Tuple_id.t -> t\n val is_used : t -> bool\n val tuple_id : t -> Tuple_id.t\n\n (* only valid if [is_used t] *)\n end = struct\n type t = int\n\n let null = 0\n let is_null t = t = 0\n\n (* We know that header indices are [> 0], because index [0] holds the metadata. *)\n let free ~next_free_header_index = next_free_header_index\n let is_free t = t > 0\n let next_free_header_index t = t\n let used (tuple_id : Tuple_id.t) = -1 - (tuple_id :> int)\n let is_used t = t < 0\n let tuple_id t = Tuple_id.of_int (-(t + 1))\n\n let%test_unit _ =\n List.iter Tuple_id.examples ~f:(fun id ->\n let t = used id in\n assert (is_used t);\n assert (Tuple_id.equal (tuple_id t) id))\n ;;\n\n let sexp_of_t t =\n if is_null t\n then Sexp.Atom \"null\"\n else if is_free t\n then Sexp.(List [ Atom \"Free\"; Atom (Int.to_string (next_free_header_index t)) ])\n else Sexp.(List [ Atom \"Used\"; Atom (Tuple_id.to_string (tuple_id t)) ])\n ;;\n end\n\n let metadata_index = 0\n let start_of_tuples_index = 1\n\n let max_capacity ~slots_per_tuple =\n (max_array_length - start_of_tuples_index) / (1 + slots_per_tuple)\n ;;\n\n let%test_unit _ =\n for slots_per_tuple = 1 to max_slot do\n assert (\n start_of_tuples_index + ((1 + slots_per_tuple) * max_capacity ~slots_per_tuple)\n <= max_array_length)\n done\n ;;\n\n module Metadata = struct\n type 'slots t =\n { (* [slots_per_tuple] is number of slots in a tuple as seen by the user; i.e. not\n counting the next-free pointer. *)\n slots_per_tuple : int\n ; capacity : int\n ; mutable length : int\n ; mutable next_id : Tuple_id.t\n ; mutable first_free : Header.t\n (* [dummy] is [None] in an unsafe pool. In a safe pool, [dummy] is [Some a], with\n [Uniform_array.length a = slots_per_tuple]. [dummy] is actually a tuple value\n with the correct type (corresponding to ['slots]), but we make the type of\n [dummy] be [Obj.t Uniform_array.t] because we can't write that type here. Also,\n the purpose of [dummy] is to initialize a pool element, making [dummy] an [Obj.t\n Uniform_array.t] lets us initialize a pool element using [Uniform_array.blit]\n from [dummy] to the pool, which is an [Obj.t Uniform_array.t]. *)\n ; dummy : (Obj.t Uniform_array.t[@sexp.opaque]) option\n }\n [@@deriving fields, sexp_of]\n\n let array_indices_per_tuple t = 1 + t.slots_per_tuple\n let array_length t = start_of_tuples_index + (t.capacity * array_indices_per_tuple t)\n\n let header_index_to_tuple_num t ~header_index =\n (header_index - start_of_tuples_index) / array_indices_per_tuple t\n ;;\n\n let tuple_num_to_header_index t tuple_num =\n start_of_tuples_index + (tuple_num * array_indices_per_tuple t)\n ;;\n\n let tuple_num_to_first_slot_index t tuple_num =\n tuple_num_to_header_index t tuple_num + 1\n ;;\n\n let is_full t = t.length = t.capacity\n end\n\n open Metadata\n\n (* We use type [Obj.t] because the array holds a mix of integers as well as OCaml values\n of arbitrary type. *)\n type 'slots t = Obj.t Uniform_array.t\n\n let metadata (type slots) (t : slots t) =\n Uniform_array.unsafe_get t metadata_index |> (Obj.obj : _ -> slots Metadata.t)\n ;;\n\n let length t = (metadata t).length\n let sexp_of_t sexp_of_ty t = Metadata.sexp_of_t sexp_of_ty (metadata t)\n\n (* Because [unsafe_header] and [unsafe_set_header] do not do a bounds check, one must be\n sure that one has a valid [header_index] before calling them. *)\n let unsafe_header t ~header_index =\n Uniform_array.unsafe_get t header_index |> (Obj.obj : _ -> Header.t)\n ;;\n\n let unsafe_set_header t ~header_index (header : Header.t) =\n Uniform_array.unsafe_set_int_assuming_currently_int t header_index (header :> int)\n ;;\n\n let header_index_is_in_bounds t ~header_index =\n header_index >= start_of_tuples_index && header_index < Uniform_array.length t\n ;;\n\n let unsafe_pointer_is_live t pointer =\n let header_index = Pointer.header_index pointer in\n let header = unsafe_header t ~header_index in\n Header.is_used header\n && Tuple_id.to_int (Header.tuple_id header) land tuple_id_mask\n = Pointer.masked_tuple_id pointer\n ;;\n\n let pointer_is_valid t pointer =\n header_index_is_in_bounds t ~header_index:(Pointer.header_index pointer)\n (* At this point, we know the pointer isn't [null] and is in bounds, so we know it is\n the index of a header, since we maintain the invariant that all pointers other than\n [null] are. *)\n && unsafe_pointer_is_live t pointer\n ;;\n\n let id_of_pointer _t pointer = Pointer.to_id pointer\n\n let is_valid_header_index t ~header_index =\n let metadata = metadata t in\n header_index_is_in_bounds t ~header_index\n && 0\n = (header_index - start_of_tuples_index)\n mod Metadata.array_indices_per_tuple metadata\n ;;\n\n let pointer_of_id_exn t id =\n try\n let pointer = Pointer.of_id_exn id in\n if not (Pointer.is_null pointer)\n then (\n let header_index = Pointer.header_index pointer in\n if not (is_valid_header_index t ~header_index)\n then failwiths ~here:[%here] \"invalid header index\" header_index [%sexp_of: int];\n if not (unsafe_pointer_is_live t pointer) then failwith \"pointer not live\");\n pointer\n with\n | exn ->\n failwiths\n ~here:[%here]\n \"Pool.pointer_of_id_exn got invalid id\"\n (id, t, exn)\n [%sexp_of: Pointer.Id.t * _ t * exn]\n ;;\n\n let invariant _invariant_a t : unit =\n try\n let metadata = metadata t in\n let check f field = f (Field.get field metadata) in\n Metadata.Fields.iter\n ~slots_per_tuple:(check (fun slots_per_tuple -> assert (slots_per_tuple > 0)))\n ~capacity:\n (check (fun capacity ->\n assert (capacity >= 0);\n assert (Uniform_array.length t = Metadata.array_length metadata)))\n ~length:\n (check (fun length ->\n assert (length >= 0);\n assert (length <= metadata.capacity)))\n ~next_id:(check Tuple_id.invariant)\n ~first_free:\n (check (fun first_free ->\n let free = Array.create ~len:metadata.capacity false in\n let r = ref first_free in\n while not (Header.is_null !r) do\n let header = !r in\n assert (Header.is_free header);\n let header_index = Header.next_free_header_index header in\n assert (is_valid_header_index t ~header_index);\n let tuple_num = header_index_to_tuple_num metadata ~header_index in\n if free.(tuple_num)\n then\n failwiths ~here:[%here] \"cycle in free list\" tuple_num [%sexp_of: int];\n free.(tuple_num) <- true;\n r := unsafe_header t ~header_index\n done))\n ~dummy:\n (check (function\n | Some dummy ->\n assert (Uniform_array.length dummy = metadata.slots_per_tuple)\n | None ->\n for tuple_num = 0 to metadata.capacity - 1 do\n let header_index = tuple_num_to_header_index metadata tuple_num in\n let header = unsafe_header t ~header_index in\n if Header.is_free header\n then (\n let first_slot = tuple_num_to_first_slot_index metadata tuple_num in\n for slot = 0 to metadata.slots_per_tuple - 1 do\n assert (Obj.is_int (Uniform_array.get t (first_slot + slot)))\n done)\n done))\n with\n | exn ->\n failwiths ~here:[%here] \"Pool.invariant failed\" (exn, t) [%sexp_of: exn * _ t]\n ;;\n\n let capacity t = (metadata t).capacity\n let is_full t = Metadata.is_full (metadata t)\n\n let unsafe_add_to_free_list t metadata ~header_index =\n unsafe_set_header t ~header_index metadata.first_free;\n metadata.first_free <- Header.free ~next_free_header_index:header_index\n ;;\n\n let set_metadata (type slots) (t : slots t) metadata =\n Uniform_array.set t metadata_index (Obj.repr (metadata : slots Metadata.t))\n ;;\n\n let create_array (type slots) (metadata : slots Metadata.t) : slots t =\n let t = Uniform_array.create_obj_array ~len:(Metadata.array_length metadata) in\n set_metadata t metadata;\n t\n ;;\n\n (* Initialize tuples numbered from [lo] (inclusive) up to [hi] (exclusive). For each\n tuple, this puts dummy values in the tuple's slots and adds the tuple to the free\n list. *)\n let unsafe_init_range t metadata ~lo ~hi =\n (match metadata.dummy with\n | None -> ()\n | Some dummy ->\n for tuple_num = lo to hi - 1 do\n Uniform_array.blit\n ~src:dummy\n ~src_pos:0\n ~dst:t\n ~dst_pos:(tuple_num_to_first_slot_index metadata tuple_num)\n ~len:metadata.slots_per_tuple\n done);\n for tuple_num = hi - 1 downto lo do\n unsafe_add_to_free_list\n t\n metadata\n ~header_index:(tuple_num_to_header_index metadata tuple_num)\n done\n ;;\n\n let create_with_dummy slots ~capacity ~dummy =\n if capacity < 0\n then\n failwiths ~here:[%here] \"Pool.create got invalid capacity\" capacity [%sexp_of: int];\n let slots_per_tuple = Slots.slots_per_tuple slots in\n let max_capacity = max_capacity ~slots_per_tuple in\n if capacity > max_capacity\n then\n failwiths\n ~here:[%here]\n \"Pool.create got too large capacity\"\n (capacity, `max max_capacity)\n [%sexp_of: int * [ `max of int ]];\n let metadata =\n { Metadata.slots_per_tuple\n ; capacity\n ; length = 0\n ; next_id = Tuple_id.init\n ; first_free = Header.null\n ; dummy\n }\n in\n let t = create_array metadata in\n unsafe_init_range t metadata ~lo:0 ~hi:capacity;\n t\n ;;\n\n let create (type tuple) (slots : (tuple, _) Slots.t) ~capacity ~dummy =\n let dummy =\n if Slots.slots_per_tuple slots = 1\n then Uniform_array.singleton (Obj.repr (dummy : tuple))\n else (Obj.magic (dummy : tuple) : Obj.t Uniform_array.t)\n in\n create_with_dummy slots ~capacity ~dummy:(Some dummy)\n ;;\n\n (* Purge a pool and make it unusable. *)\n let destroy t =\n let metadata = metadata t in\n (* We clear out all the pool's entries, which causes all pointers to be invalid. This\n also prevents the destroyed pool from unnecessarily keeping heap blocks alive.\n This is similar to [free]ing all the entries with the difference that we make the\n free list empty as well. *)\n (match metadata.dummy with\n | None ->\n for i = start_of_tuples_index to Uniform_array.length t - 1 do\n Uniform_array.unsafe_set t i (Obj.repr 0)\n done\n | Some dummy ->\n for tuple_num = 0 to metadata.capacity - 1 do\n let header_index = tuple_num_to_header_index metadata tuple_num in\n unsafe_set_header t ~header_index Header.null;\n Uniform_array.blit\n ~src:dummy\n ~src_pos:0\n ~dst:t\n ~dst_pos:(header_index + 1)\n ~len:metadata.slots_per_tuple\n done);\n let metadata =\n { Metadata.slots_per_tuple = metadata.slots_per_tuple\n ; capacity = 0\n ; length = 0\n ; next_id = metadata.next_id\n ; first_free = Header.null\n ; dummy = metadata.dummy\n }\n in\n set_metadata t metadata\n ;;\n\n let[@cold] grow ?capacity t =\n let { Metadata.slots_per_tuple\n ; capacity = old_capacity\n ; length\n ; next_id\n ; first_free = _\n ; dummy\n }\n =\n metadata t\n in\n let capacity =\n min (max_capacity ~slots_per_tuple) (grow_capacity ~capacity ~old_capacity)\n in\n if capacity = old_capacity\n then\n failwiths\n ~here:[%here]\n \"Pool.grow cannot grow pool; capacity already at maximum\"\n capacity\n [%sexp_of: int];\n let metadata =\n { Metadata.slots_per_tuple\n ; capacity\n ; length\n ; next_id\n ; first_free = Header.null\n ; dummy\n }\n in\n let t' = create_array metadata in\n Uniform_array.blit\n ~src:t\n ~src_pos:start_of_tuples_index\n ~dst:t'\n ~dst_pos:start_of_tuples_index\n ~len:(old_capacity * Metadata.array_indices_per_tuple metadata);\n destroy t;\n unsafe_init_range t' metadata ~lo:old_capacity ~hi:capacity;\n for tuple_num = old_capacity - 1 downto 0 do\n let header_index = tuple_num_to_header_index metadata tuple_num in\n let header = unsafe_header t' ~header_index in\n if not (Header.is_used header)\n then unsafe_add_to_free_list t' metadata ~header_index\n done;\n t'\n ;;\n\n let[@cold] raise_malloc_full t =\n failwiths ~here:[%here] \"Pool.malloc of full pool\" t [%sexp_of: _ t]\n ;;\n\n let malloc (type slots) (t : slots t) : slots Pointer.t =\n let metadata = metadata t in\n let first_free = metadata.first_free in\n if Header.is_null first_free then raise_malloc_full t;\n let header_index = Header.next_free_header_index first_free in\n metadata.first_free <- unsafe_header t ~header_index;\n metadata.length <- metadata.length + 1;\n let tuple_id = metadata.next_id in\n unsafe_set_header t ~header_index (Header.used tuple_id);\n metadata.next_id <- Tuple_id.next tuple_id;\n Pointer.create ~header_index tuple_id\n ;;\n\n let unsafe_free (type slots) (t : slots t) (pointer : slots Pointer.t) =\n let metadata = metadata t in\n metadata.length <- metadata.length - 1;\n unsafe_add_to_free_list t metadata ~header_index:(Pointer.header_index pointer);\n match metadata.dummy with\n | None ->\n let pos = Pointer.first_slot_index pointer in\n for i = 0 to metadata.slots_per_tuple - 1 do\n Uniform_array.unsafe_clear_if_pointer t (pos + i)\n done\n | Some dummy ->\n Uniform_array.unsafe_blit\n ~src:dummy\n ~src_pos:0\n ~len:metadata.slots_per_tuple\n ~dst:t\n ~dst_pos:(Pointer.first_slot_index pointer)\n ;;\n\n let free (type slots) (t : slots t) (pointer : slots Pointer.t) =\n (* Check [pointer_is_valid] to:\n - avoid freeing a null pointer\n - avoid freeing a free pointer (this would lead to a pool inconsistency)\n - be able to use unsafe functions after. *)\n if not (pointer_is_valid t pointer)\n then\n failwiths\n ~here:[%here]\n \"Pool.free of invalid pointer\"\n (pointer, t)\n [%sexp_of: _ Pointer.t * _ t];\n unsafe_free t pointer\n ;;\n\n let new1 t a0 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n pointer\n ;;\n\n let new2 t a0 a1 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n pointer\n ;;\n\n let new3 t a0 a1 a2 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n pointer\n ;;\n\n let new4 t a0 a1 a2 a3 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n pointer\n ;;\n\n let new5 t a0 a1 a2 a3 a4 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n pointer\n ;;\n\n let new6 t a0 a1 a2 a3 a4 a5 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n pointer\n ;;\n\n let new7 t a0 a1 a2 a3 a4 a5 a6 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n pointer\n ;;\n\n let new8 t a0 a1 a2 a3 a4 a5 a6 a7 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n pointer\n ;;\n\n let new9 t a0 a1 a2 a3 a4 a5 a6 a7 a8 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n pointer\n ;;\n\n let new10 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n Uniform_array.unsafe_set t (offset + 10) (Obj.repr a9);\n pointer\n ;;\n\n let new11 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n Uniform_array.unsafe_set t (offset + 10) (Obj.repr a9);\n Uniform_array.unsafe_set t (offset + 11) (Obj.repr a10);\n pointer\n ;;\n\n let new12 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n Uniform_array.unsafe_set t (offset + 10) (Obj.repr a9);\n Uniform_array.unsafe_set t (offset + 11) (Obj.repr a10);\n Uniform_array.unsafe_set t (offset + 12) (Obj.repr a11);\n pointer\n ;;\n\n let new13 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n Uniform_array.unsafe_set t (offset + 10) (Obj.repr a9);\n Uniform_array.unsafe_set t (offset + 11) (Obj.repr a10);\n Uniform_array.unsafe_set t (offset + 12) (Obj.repr a11);\n Uniform_array.unsafe_set t (offset + 13) (Obj.repr a12);\n pointer\n ;;\n\n let new14 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13 =\n let pointer = malloc t in\n let offset = Pointer.header_index pointer in\n Uniform_array.unsafe_set t (offset + 1) (Obj.repr a0);\n Uniform_array.unsafe_set t (offset + 2) (Obj.repr a1);\n Uniform_array.unsafe_set t (offset + 3) (Obj.repr a2);\n Uniform_array.unsafe_set t (offset + 4) (Obj.repr a3);\n Uniform_array.unsafe_set t (offset + 5) (Obj.repr a4);\n Uniform_array.unsafe_set t (offset + 6) (Obj.repr a5);\n Uniform_array.unsafe_set t (offset + 7) (Obj.repr a6);\n Uniform_array.unsafe_set t (offset + 8) (Obj.repr a7);\n Uniform_array.unsafe_set t (offset + 9) (Obj.repr a8);\n Uniform_array.unsafe_set t (offset + 10) (Obj.repr a9);\n Uniform_array.unsafe_set t (offset + 11) (Obj.repr a10);\n Uniform_array.unsafe_set t (offset + 12) (Obj.repr a11);\n Uniform_array.unsafe_set t (offset + 13) (Obj.repr a12);\n Uniform_array.unsafe_set t (offset + 14) (Obj.repr a13);\n pointer\n ;;\n\n let get t p slot = Obj.obj (Uniform_array.get t (Pointer.slot_index p slot))\n\n let unsafe_get t p slot =\n Obj.obj (Uniform_array.unsafe_get t (Pointer.slot_index p slot))\n ;;\n\n let set t p slot x = Uniform_array.set t (Pointer.slot_index p slot) (Obj.repr x)\n\n let unsafe_set t p slot x =\n Uniform_array.unsafe_set t (Pointer.slot_index p slot) (Obj.repr x)\n ;;\n\n let get_tuple (type tuple) (t : (tuple, _) Slots.t t) pointer =\n let metadata = metadata t in\n let len = metadata.slots_per_tuple in\n if len = 1\n then get t pointer Slot.t0\n else\n (Obj.magic\n (Uniform_array.sub t ~pos:(Pointer.first_slot_index pointer) ~len\n : Obj.t Uniform_array.t)\n : tuple)\n ;;\nend\n\ninclude Pool\n\nmodule Unsafe = struct\n include Pool\n\n let create slots ~capacity = create_with_dummy slots ~capacity ~dummy:None\nend\n\nmodule Debug (Pool : S) = struct\n open Pool\n\n let check_invariant = ref true\n let show_messages = ref true\n\n let debug name ts arg sexp_of_arg sexp_of_result f =\n let prefix = \"Pool.\" in\n if !check_invariant then List.iter ts ~f:(invariant ignore);\n if !show_messages then Debug.eprints (concat [ prefix; name ]) arg sexp_of_arg;\n let result_or_exn = Result.try_with f in\n if !show_messages\n then\n Debug.eprints\n (concat [ prefix; name; \" result\" ])\n result_or_exn\n [%sexp_of: (result, exn) Result.t];\n Result.ok_exn result_or_exn\n ;;\n\n module Slots = Slots\n module Slot = Slot\n\n module Pointer = struct\n open Pointer\n\n type nonrec 'slots t = 'slots t [@@deriving sexp_of, typerep]\n\n let phys_compare t1 t2 =\n debug\n \"Pointer.phys_compare\"\n []\n (t1, t2)\n [%sexp_of: _ t * _ t]\n [%sexp_of: int]\n (fun () -> phys_compare t1 t2)\n ;;\n\n let phys_equal t1 t2 =\n debug\n \"Pointer.phys_equal\"\n []\n (t1, t2)\n [%sexp_of: _ t * _ t]\n [%sexp_of: bool]\n (fun () -> phys_equal t1 t2)\n ;;\n\n let is_null t =\n debug \"Pointer.is_null\" [] t [%sexp_of: _ t] [%sexp_of: bool] (fun () -> is_null t)\n ;;\n\n let null = null\n\n module Id = struct\n open Id\n\n type nonrec t = t [@@deriving bin_io, sexp]\n\n let of_int63 i =\n debug \"Pointer.Id.of_int63\" [] i [%sexp_of: Int63.t] [%sexp_of: t] (fun () ->\n of_int63 i)\n ;;\n\n let to_int63 t =\n debug \"Pointer.Id.to_int63\" [] t [%sexp_of: t] [%sexp_of: Int63.t] (fun () ->\n to_int63 t)\n ;;\n end\n end\n\n type nonrec 'slots t = 'slots t [@@deriving sexp_of]\n\n let invariant = invariant\n let length = length\n\n let id_of_pointer t pointer =\n debug\n \"id_of_pointer\"\n [ t ]\n pointer\n [%sexp_of: _ Pointer.t]\n [%sexp_of: Pointer.Id.t]\n (fun () -> id_of_pointer t pointer)\n ;;\n\n let pointer_of_id_exn t id =\n debug\n \"pointer_of_id_exn\"\n [ t ]\n id\n [%sexp_of: Pointer.Id.t]\n [%sexp_of: _ Pointer.t]\n (fun () -> pointer_of_id_exn t id)\n ;;\n\n let pointer_is_valid t pointer =\n debug\n \"pointer_is_valid\"\n [ t ]\n pointer\n [%sexp_of: _ Pointer.t]\n [%sexp_of: bool]\n (fun () -> pointer_is_valid t pointer)\n ;;\n\n let create slots ~capacity ~dummy =\n debug \"create\" [] capacity [%sexp_of: int] [%sexp_of: _ t] (fun () ->\n create slots ~capacity ~dummy)\n ;;\n\n let max_capacity ~slots_per_tuple =\n debug \"max_capacity\" [] slots_per_tuple [%sexp_of: int] [%sexp_of: int] (fun () ->\n max_capacity ~slots_per_tuple)\n ;;\n\n let capacity t =\n debug \"capacity\" [ t ] t [%sexp_of: _ t] [%sexp_of: int] (fun () -> capacity t)\n ;;\n\n let grow ?capacity t =\n debug\n \"grow\"\n [ t ]\n (`capacity capacity)\n [%sexp_of: [ `capacity of int option ]]\n [%sexp_of: _ t]\n (fun () -> grow ?capacity t)\n ;;\n\n let is_full t =\n debug \"is_full\" [ t ] t [%sexp_of: _ t] [%sexp_of: bool] (fun () -> is_full t)\n ;;\n\n let unsafe_free t p =\n debug \"unsafe_free\" [ t ] p [%sexp_of: _ Pointer.t] [%sexp_of: unit] (fun () ->\n unsafe_free t p)\n ;;\n\n let free t p =\n debug \"free\" [ t ] p [%sexp_of: _ Pointer.t] [%sexp_of: unit] (fun () -> free t p)\n ;;\n\n let debug_new t f = debug \"new\" [ t ] () [%sexp_of: unit] [%sexp_of: _ Pointer.t] f\n let new1 t a0 = debug_new t (fun () -> new1 t a0)\n let new2 t a0 a1 = debug_new t (fun () -> new2 t a0 a1)\n let new3 t a0 a1 a2 = debug_new t (fun () -> new3 t a0 a1 a2)\n let new4 t a0 a1 a2 a3 = debug_new t (fun () -> new4 t a0 a1 a2 a3)\n let new5 t a0 a1 a2 a3 a4 = debug_new t (fun () -> new5 t a0 a1 a2 a3 a4)\n let new6 t a0 a1 a2 a3 a4 a5 = debug_new t (fun () -> new6 t a0 a1 a2 a3 a4 a5)\n let new7 t a0 a1 a2 a3 a4 a5 a6 = debug_new t (fun () -> new7 t a0 a1 a2 a3 a4 a5 a6)\n\n let new8 t a0 a1 a2 a3 a4 a5 a6 a7 =\n debug_new t (fun () -> new8 t a0 a1 a2 a3 a4 a5 a6 a7)\n ;;\n\n let new9 t a0 a1 a2 a3 a4 a5 a6 a7 a8 =\n debug_new t (fun () -> new9 t a0 a1 a2 a3 a4 a5 a6 a7 a8)\n ;;\n\n let new10 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 =\n debug_new t (fun () -> new10 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9)\n ;;\n\n let new11 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 =\n debug_new t (fun () -> new11 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10)\n ;;\n\n let new12 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 =\n debug_new t (fun () -> new12 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11)\n ;;\n\n let new13 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 =\n debug_new t (fun () -> new13 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12)\n ;;\n\n let new14 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13 =\n debug_new t (fun () -> new14 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13)\n ;;\n\n let get_tuple t pointer =\n debug \"get_tuple\" [ t ] pointer [%sexp_of: _ Pointer.t] [%sexp_of: _] (fun () ->\n get_tuple t pointer)\n ;;\n\n let debug_get name f t pointer =\n debug name [ t ] pointer [%sexp_of: _ Pointer.t] [%sexp_of: _] (fun () ->\n f t pointer)\n ;;\n\n let get t pointer slot = debug_get \"get\" get t pointer slot\n let unsafe_get t pointer slot = debug_get \"unsafe_get\" unsafe_get t pointer slot\n\n let debug_set name f t pointer slot a =\n debug name [ t ] pointer [%sexp_of: _ Pointer.t] [%sexp_of: unit] (fun () ->\n f t pointer slot a)\n ;;\n\n let set t pointer slot a = debug_set \"set\" set t pointer slot a\n let unsafe_set t pointer slot a = debug_set \"unsafe_set\" unsafe_set t pointer slot a\nend\n\nmodule Error_check (Pool : S) = struct\n open Pool\n module Slots = Slots\n module Slot = Slot\n\n module Pointer = struct\n type 'slots t =\n { mutable is_valid : bool\n ; pointer : 'slots Pointer.t\n }\n [@@deriving sexp_of, typerep]\n\n let create pointer = { is_valid = true; pointer }\n let null () = { is_valid = false; pointer = Pointer.null () }\n let phys_compare t1 t2 = Pointer.phys_compare t1.pointer t2.pointer\n let phys_equal t1 t2 = Pointer.phys_equal t1.pointer t2.pointer\n let is_null t = Pointer.is_null t.pointer\n\n let follow t =\n if not t.is_valid\n then failwiths ~here:[%here] \"attempt to use invalid pointer\" t [%sexp_of: _ t];\n t.pointer\n ;;\n\n let invalidate t = t.is_valid <- false\n\n module Id = Pointer.Id\n end\n\n type 'slots t = 'slots Pool.t [@@deriving sexp_of]\n\n let invariant = invariant\n let length = length\n\n let pointer_is_valid t { Pointer.is_valid; pointer } =\n is_valid && pointer_is_valid t pointer\n ;;\n\n (* We don't do [Pointer.follow pointer], because that would disallow [id_of_pointer t\n (Pointer.null ())]. *)\n let id_of_pointer t pointer = id_of_pointer t pointer.Pointer.pointer\n\n let pointer_of_id_exn t id =\n let pointer = pointer_of_id_exn t id in\n let is_valid = Pool.pointer_is_valid t pointer in\n { Pointer.is_valid; pointer }\n ;;\n\n let create = create\n let capacity = capacity\n let max_capacity = max_capacity\n let grow = grow\n let is_full = is_full\n let get_tuple t p = get_tuple t (Pointer.follow p)\n let get t p = get t (Pointer.follow p)\n let unsafe_get t p = unsafe_get t (Pointer.follow p)\n let set t p slot v = set t (Pointer.follow p) slot v\n let unsafe_set t p slot v = unsafe_set t (Pointer.follow p) slot v\n\n let unsafe_free t p =\n unsafe_free t (Pointer.follow p);\n Pointer.invalidate p\n ;;\n\n let free t p =\n free t (Pointer.follow p);\n Pointer.invalidate p\n ;;\n\n let new1 t a0 = Pointer.create (Pool.new1 t a0)\n let new2 t a0 a1 = Pointer.create (Pool.new2 t a0 a1)\n let new3 t a0 a1 a2 = Pointer.create (Pool.new3 t a0 a1 a2)\n let new4 t a0 a1 a2 a3 = Pointer.create (Pool.new4 t a0 a1 a2 a3)\n let new5 t a0 a1 a2 a3 a4 = Pointer.create (Pool.new5 t a0 a1 a2 a3 a4)\n let new6 t a0 a1 a2 a3 a4 a5 = Pointer.create (Pool.new6 t a0 a1 a2 a3 a4 a5)\n let new7 t a0 a1 a2 a3 a4 a5 a6 = Pointer.create (Pool.new7 t a0 a1 a2 a3 a4 a5 a6)\n\n let new8 t a0 a1 a2 a3 a4 a5 a6 a7 =\n Pointer.create (Pool.new8 t a0 a1 a2 a3 a4 a5 a6 a7)\n ;;\n\n let new9 t a0 a1 a2 a3 a4 a5 a6 a7 a8 =\n Pointer.create (Pool.new9 t a0 a1 a2 a3 a4 a5 a6 a7 a8)\n ;;\n\n let new10 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 =\n Pointer.create (Pool.new10 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9)\n ;;\n\n let new11 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 =\n Pointer.create (Pool.new11 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10)\n ;;\n\n let new12 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 =\n Pointer.create (Pool.new12 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11)\n ;;\n\n let new13 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 =\n Pointer.create (Pool.new13 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12)\n ;;\n\n let new14 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13 =\n Pointer.create (Pool.new14 t a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12 a13)\n ;;\nend\n","open! Import\nmodule Int = Int0\nmodule String = String0\n\n(** Each single_error is a path indicating the location within the datastructure in\n question that is being validated, along with an error message. *)\ntype single_error =\n { path : string list\n ; error : Error.t\n }\n\ntype t = single_error list\ntype 'a check = 'a -> t\n\nlet pass : t = []\n\nlet fails message a sexp_of_a =\n [ { path = []; error = Error.create message a sexp_of_a } ]\n;;\n\nlet fail message = [ { path = []; error = Error.of_string message } ]\nlet failf format = Printf.ksprintf fail format\nlet fail_s sexp = [ { path = []; error = Error.create_s sexp } ]\nlet combine t1 t2 = t1 @ t2\nlet of_list = List.concat\n\nlet name name t =\n match t with\n | [] -> [] (* when successful, avoid the allocation of a closure for [~f], below *)\n | _ -> List.map t ~f:(fun { path; error } -> { path = name :: path; error })\n;;\n\nlet name_list n l = name n (of_list l)\nlet fail_fn message _ = fail message\nlet pass_bool (_ : bool) = pass\nlet pass_unit (_ : unit) = pass\n\nlet protect f v =\n try f v with\n | exn ->\n fail_s (Sexp.message \"Exception raised during validation\" [ \"\", sexp_of_exn exn ])\n;;\n\nlet try_with f =\n protect\n (fun () ->\n f ();\n pass)\n ()\n;;\n\nlet path_string path = String.concat ~sep:\".\" path\n\nlet errors t =\n List.map t ~f:(fun { path; error } ->\n Error.to_string_hum (Error.tag error ~tag:(path_string path)))\n;;\n\nlet result_fail t =\n Or_error.error\n \"validation errors\"\n (List.map t ~f:(fun { path; error } -> path_string path, error))\n (sexp_of_list (sexp_of_pair sexp_of_string Error.sexp_of_t))\n[@@cold] [@@inline never] [@@local never] [@@specialise never]\n;;\n\n(** [result] is carefully implemented so that it can be inlined -- calling [result_fail],\n which is not inlineable, is key to this. *)\nlet result t = if List.is_empty t then Ok () else result_fail t\n\nlet maybe_raise t = Or_error.ok_exn (result t)\nlet valid_or_error x check = Or_error.map (result (protect check x)) ~f:(fun () -> x)\n\nlet field record fld f =\n let v = Field.get fld record in\n let result = protect f v in\n name (Field.name fld) result\n;;\n\nlet field_folder record check =\n ();\n fun acc fld -> field record fld check :: acc\n;;\n\nlet field_direct_folder check =\n Staged.stage (fun acc fld _record v ->\n match protect check v with\n | [] -> acc\n | result -> name (Field.name fld) result :: acc)\n;;\n\nlet all checks v =\n let rec loop checks v errs =\n match checks with\n | [] -> errs\n | check :: checks ->\n (match protect check v with\n | [] -> loop checks v errs\n | err -> loop checks v (err :: errs))\n in\n of_list (List.rev (loop checks v []))\n;;\n\nlet of_result f =\n protect (fun v ->\n match f v with\n | Ok () -> pass\n | Error error -> fail error)\n;;\n\nlet of_error f =\n protect (fun v ->\n match f v with\n | Ok () -> pass\n | Error error -> [ { path = []; error } ])\n;;\n\nlet booltest f ~if_false = protect (fun v -> if f v then pass else fail if_false)\n\nlet pair ~fst ~snd (fst_value, snd_value) =\n of_list [ name \"fst\" (protect fst fst_value); name \"snd\" (protect snd snd_value) ]\n;;\n\nlet list_indexed check list =\n List.mapi list ~f:(fun i el -> name (Int.to_string (i + 1)) (protect check el))\n |> of_list\n;;\n\nlet list ~name:extract_name check list =\n List.map list ~f:(fun el ->\n match protect check el with\n | [] -> []\n | t ->\n (* extra level of protection in case extract_name throws an exception *)\n protect (fun t -> name (extract_name el) t) t)\n |> of_list\n;;\n\nlet alist ~name f list' = list (fun (_, x) -> f x) list' ~name:(fun (key, _) -> name key)\nlet first_failure t1 t2 = if List.is_empty t1 then t2 else t1\n\nlet of_error_opt = function\n | None -> pass\n | Some error -> fail error\n;;\n\nlet bounded ~name ~lower ~upper ~compare x =\n match Maybe_bound.compare_to_interval_exn ~lower ~upper ~compare x with\n | In_range -> pass\n | Below_lower_bound ->\n (match lower with\n | Unbounded -> assert false\n | Incl incl -> fail (Printf.sprintf \"value %s < bound %s\" (name x) (name incl))\n | Excl excl -> fail (Printf.sprintf \"value %s <= bound %s\" (name x) (name excl)))\n | Above_upper_bound ->\n (match upper with\n | Unbounded -> assert false\n | Incl incl -> fail (Printf.sprintf \"value %s > bound %s\" (name x) (name incl))\n | Excl excl -> fail (Printf.sprintf \"value %s >= bound %s\" (name x) (name excl)))\n;;\n\nmodule Infix = struct\n let ( ++ ) t1 t2 = combine t1 t2\nend\n","open! Core_kernel\nopen! Import\n\nmodule Cpuset = struct\n include Validated.Make (struct\n type t = Int.Set.t [@@deriving sexp]\n\n let here = [%here]\n\n let validate t =\n Validate.first_failure\n (Int.validate_lbound ~min:(Incl 1) (Int.Set.length t))\n (Int.Set.to_list t\n |> List.map ~f:Int.validate_non_negative\n |> Validate.name_list \"Thread_pool_cpuset\")\n ;;\n end)\n\n let equal t1 t2 = Int.Set.equal (t1 |> raw) (t2 |> raw)\nend\n\ntype t =\n | Inherit\n | Cpuset of Cpuset.t\n[@@deriving sexp]\n","open Core_kernel\n\ntype 'a t = 'a\n\n(* This [Obj.magic] is OK because we never allow user code access to [none] (except via\n [unsafe_value]. We disallow [_ Uopt.t Uopt.t], so there is no chance of confusing\n [none] with [some none]. And [float Uopt.t array] is similarly disallowed. *)\nlet none = \"Uopt.none\" |> (Obj.magic : string -> _ t)\nlet is_none t = phys_equal t none\nlet is_some t = not (is_none t)\nlet invariant invariant_a t = if is_some t then invariant_a t\nlet sexp_of_t sexp_of_a t = if is_none t then [%sexp None] else [%sexp Some (t : a)]\nlet some a = a\nlet value_exn t = if is_none t then failwith \"Uopt.value_exn\" else t\nlet unsafe_value t = t\nlet to_option t = if is_none t then None else Some t\n\nlet of_option = function\n | None -> none\n | Some a -> some a\n;;\n\nmodule Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n let unsafe_value = unsafe_value\n end\nend\n","(* Be sure and first read the implementation overview in timing_wheel_intf.ml.\n\n A timing wheel is represented as an array of \"levels\", where each level is an array of\n \"slots\". Each slot represents a range of keys, and holds elements associated with\n those keys. Each level is determined by two parameters: [bits], the number of key bits\n that that level is responsible for distinguishing, and [bits_per_slot], the size of the\n range of keys that correspond to a single slot in the array. Conceptually, each level\n breaks up all possible keys into ranges of size [2^bits_per_slot]. The length of a\n level array is [2^bits], and the array is used like a circular buffer to traverse the\n ranges as the timing wheel's [min_allowed_key] increases. A key [k], if stored in the\n level, is stored at index [(k / 2^bits_per_slot) mod 2^bits].\n\n The settings of the [bits] values are configurable by user code using [Level_bits],\n although there is a reasonable default setting. Given the [bits] values, the\n [bits_per_slot] are chosen so that [bits_per_slot] at level [i] is the sum of the\n [bits] at all lower levels. Thus, a slot's range at level [i] is as large as the\n entire range of the array at level [i - 1].\n\n Each level has a [min_allowed_key] and a [max_allowed_key] that determine the range of\n keys that it currently represents. The crucial invariant of the timing wheel data\n structure is that the [min_allowed_key] at level [i] is no more than the\n [max_allowed_key + 1] of level [i - 1]. This ensures that the levels can represent all\n keys from the [min_allowed_key] of the lowest level to the [max_allowed_key] of the\n highest level. The [increase_min_allowed_key] function is responsible for restoring\n this invariant.\n\n At level 0, [bits_per_slot = 0], and so the size of each slot is [1]. That is, level 0\n precisely distinguishes all the keys between its [min_allowed_key] (which is the same\n as the [min_allowed_key] of the entire timing wheel) and [max_allowed_key]. As the\n levels increase, the [min_allowed_key] increases, the [bits_per_slot] increases, and\n the range of keys stored in the level increases (dramatically).\n\n The idea of the implementation is similar to the hierarchical approach described in:\n\n {v\n Hashed and Hierarchical Timing Wheels:\n Efficient Data Structures for Implementing a Timer Facility\n\n Varghese & Lauck, 1996\n v}\n\n However, the code is completely new. *)\n\nopen! Core_kernel\nopen! Import\nopen! Timing_wheel_intf\nmodule Pool = Tuple_pool\nmodule Time_ns = Core_kernel_private.Time_ns_alternate_sexp\n\nlet sexp_of_t_style : [ `Pretty | `Internal ] ref = ref `Pretty\n\n(* [{max,min}_time] are bounds on the times supported by a timing wheel. *)\n\nlet max_time = Time_ns.max_value_representable\nlet min_time = Time_ns.epoch\n\nmodule Num_key_bits : sig\n type t = private int [@@deriving compare, sexp]\n\n include Comparable with type t := t\n include Invariant.S with type t := t\n\n val zero : t\n\n (* val min_value : t *)\n\n val max_value : t\n val to_int : t -> int\n val of_int : int -> t\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val pow2 : t -> Int63.t\nend = struct\n include Int\n\n let min_value = 0\n\n (** We support all non-negative [Time_ns.t] values. *)\n let max_value = Int63.num_bits - 1\n\n let invariant t =\n assert (t >= min_value);\n assert (t <= max_value)\n ;;\n\n let of_int i =\n invariant i;\n i\n ;;\n\n let ( + ) t1 t2 =\n let t = t1 + t2 in\n invariant t;\n t\n ;;\n\n let ( - ) t1 t2 =\n let t = t1 - t2 in\n invariant t;\n t\n ;;\n\n let pow2 t = Int63.shift_left Int63.one t\nend\n\nmodule Level_bits = struct\n type t = Num_key_bits.t list [@@deriving compare, sexp]\n\n let max_num_bits = (Num_key_bits.max_value :> int)\n let num_bits_internal t = List.fold t ~init:Num_key_bits.zero ~f:Num_key_bits.( + )\n let num_bits t = (num_bits_internal t :> int)\n\n let invariant t =\n assert (not (List.is_empty t));\n List.iter t ~f:(fun num_key_bits ->\n Num_key_bits.invariant num_key_bits;\n assert (Num_key_bits.( > ) num_key_bits Num_key_bits.zero));\n Num_key_bits.invariant (num_bits_internal t)\n ;;\n\n let t_of_sexp sexp =\n let t = sexp |> [%of_sexp: t] in\n invariant t;\n t\n ;;\n\n let create_exn ?(extend_to_max_num_bits = false) ints =\n if List.is_empty ints then failwith \"Level_bits.create_exn requires a nonempty list\";\n if List.exists ints ~f:(fun bits -> bits <= 0)\n then\n raise_s\n [%message \"Level_bits.create_exn got nonpositive num bits\" ~_:(ints : int list)];\n let num_bits = List.fold ints ~init:0 ~f:( + ) in\n if num_bits > max_num_bits\n then\n raise_s\n [%message\n \"Level_bits.create_exn got too many bits\"\n ~_:(ints : int list)\n ~got:(num_bits : int)\n (max_num_bits : int)];\n let ints =\n if extend_to_max_num_bits\n then ints @ List.init (max_num_bits - num_bits) ~f:(const 1)\n else ints\n in\n List.map ints ~f:Num_key_bits.of_int\n ;;\n\n let default = create_exn [ 11; 10; 10; 10; 10; 10; 1 ]\n\n let trim t ~max_num_bits =\n if Num_key_bits.( <= ) (num_bits_internal t) max_num_bits\n then t\n else (\n let rec loop t ~remaining =\n match t with\n | [] -> []\n | b :: t ->\n if Num_key_bits.( >= ) b remaining\n then [ remaining ]\n else b :: loop t ~remaining:(Num_key_bits.( - ) remaining b)\n in\n loop t ~remaining:max_num_bits)\n ;;\nend\n\nmodule Alarm_precision : sig\n include Alarm_precision\n\n val num_key_bits : t -> Num_key_bits.t\n val interval_num : t -> Time_ns.t -> Int63.t\n val interval_num_start : t -> Int63.t -> Time_ns.t\nend = struct\n (** [t] is represented as the log2 of a number of nanoseconds. *)\n type t = int [@@deriving compare, hash]\n\n let equal = [%compare.equal: t]\n let num_key_bits t = t |> Num_key_bits.of_int\n\n let to_span t =\n if t < 0\n then\n raise_s\n [%message\n \"[Alarm_precision.to_span] of negative power of two nanoseconds\" ~_:(t : int)];\n Int63.(shift_left one) t |> Time_ns.Span.of_int63_ns\n ;;\n\n let sexp_of_t t = [%sexp (t |> to_span : Time_ns.Span.t)]\n let one_nanosecond = 0\n let about_one_microsecond = 10\n let about_one_millisecond = 20\n let about_one_second = 30\n let about_one_day = 46\n let mul t ~pow2 = t + pow2\n let div t ~pow2 = t - pow2\n let interval_num t time = Int63.shift_right (time |> Time_ns.to_int63_ns_since_epoch) t\n\n let interval_num_start t interval_num =\n Int63.shift_left interval_num t |> Time_ns.of_int63_ns_since_epoch\n ;;\n\n let of_span_floor_pow2_ns span =\n if Time_ns.Span.( <= ) span Time_ns.Span.zero\n then\n raise_s\n [%message\n \"[Alarm_precision.of_span_floor_pow2_ns] got non-positive span\"\n (span : Time_ns.Span.t)];\n span |> Time_ns.Span.to_int63_ns |> Int63.floor_log2\n ;;\n\n let of_span = of_span_floor_pow2_ns\n\n module Unstable = struct\n module T = struct\n type nonrec t = t [@@deriving compare]\n\n let of_binable = of_span_floor_pow2_ns\n let to_binable = to_span\n let of_sexpable = of_span_floor_pow2_ns\n let to_sexpable = to_span\n end\n\n include T\n include Binable.Of_binable_without_uuid [@alert \"-legacy\"] (Time_ns.Span) (T)\n include Sexpable.Of_sexpable (Time_ns.Span) (T)\n end\nend\n\nmodule Config = struct\n let level_bits_default = Level_bits.default\n\n type t =\n { alarm_precision : Alarm_precision.Unstable.t\n ; level_bits : Level_bits.t [@default level_bits_default]\n ; capacity : int option [@sexp.option]\n }\n [@@deriving fields, sexp]\n\n let alarm_precision t = Alarm_precision.to_span t.alarm_precision\n\n (* [max_num_level_bits alarm_precision] returns the number of level bits needed for a\n timing wheel with the specified [alarm_precision] to be able to represent all\n possible times from [Time_ns.epoch] onward. Since non-negative times have 62 bits,\n we require [L <= 62 - A], where [A] is the number of alarm bits and [L] is the\n number of level bits. *)\n let max_num_level_bits alarm_precision =\n Num_key_bits.( - )\n Num_key_bits.max_value\n (Alarm_precision.num_key_bits alarm_precision)\n ;;\n\n let invariant t =\n Invariant.invariant [%here] t [%sexp_of: t] (fun () ->\n assert (\n Num_key_bits.( <= )\n (Level_bits.num_bits_internal t.level_bits)\n (max_num_level_bits t.alarm_precision));\n let check f = Invariant.check_field t f in\n Fields.iter\n ~alarm_precision:ignore\n ~capacity:ignore\n ~level_bits:(check Level_bits.invariant))\n ;;\n\n let create ?capacity ?(level_bits = level_bits_default) ~alarm_precision () =\n let level_bits =\n Level_bits.trim level_bits ~max_num_bits:(max_num_level_bits alarm_precision)\n in\n { alarm_precision; level_bits; capacity }\n ;;\n\n let microsecond_precision () =\n create\n ()\n ~alarm_precision:Alarm_precision.about_one_microsecond\n ~level_bits:(Level_bits.create_exn [ 10; 10; 6; 6; 5 ])\n ;;\n\n let durations t =\n List.folding_map\n t.level_bits\n ~init:(Alarm_precision.num_key_bits t.alarm_precision |> Num_key_bits.to_int)\n ~f:(fun num_bits_accum level_num_bits ->\n let num_bits_accum = num_bits_accum + (level_num_bits |> Num_key_bits.to_int) in\n let duration =\n Time_ns.Span.of_int63_ns\n (if num_bits_accum = Int63.num_bits - 1\n then Int63.max_value\n else Int63.shift_left Int63.one num_bits_accum)\n in\n num_bits_accum, duration)\n ;;\nend\n\n\n(** Timing wheel is implemented as a priority queue in which the keys are\n non-negative integers corresponding to the intervals of time. The priority queue is\n unlike a typical priority queue in that rather than having a \"delete min\" operation,\n it has a nondecreasing minimum allowed key, which corresponds to the current time,\n and an [increase_min_allowed_key] operation, which implements [advance_clock].\n [increase_min_allowed_key] as a side effect removes all elements from the timing\n wheel whose key is smaller than the new minimum, which implements firing the alarms\n whose time has expired.\n\n Adding elements to and removing elements from a timing wheel takes constant time,\n unlike a heap-based priority queue which takes log(N), where N is the number of\n elements in the heap. [increase_min_allowed_key] takes time proportional to the\n amount of increase in the min-allowed key, as compared to log(N) for a heap. It is\n these performance differences that motivate the existence of timing wheels and make\n them a good choice for maintaing a set of alarms. With a timing wheel, one can\n support any number of alarms paying constant overhead per alarm, while paying a\n small constant overhead per unit of time passed.\n\n As the minimum allowed key increases, the timing wheel does a lazy radix sort of the\n element keys, with level 0 handling the least significant [b_0] bits in a key, and\n each subsequent level [i] handling the next most significant [b_i] bits. The levels\n hold increasingly larger ranges of keys, where the union of all the levels can hold\n any key from [min_allowed_key t] to [max_allowed_key t]. When a key is added to the\n timing wheel, it is added at the lowest possible level that can store the key. As\n the minimum allowed key increases, timing-wheel elements move down levels until they\n reach level 0, and then are eventually removed. *)\nmodule Priority_queue : sig\n type 'a t [@@deriving sexp_of]\n type 'a priority_queue = 'a t\n\n module Key : Interval_num\n\n module Elt : sig\n (** An [Elt.t] represents an element that was added to a timing wheel. *)\n type 'a t [@@deriving sexp_of]\n\n val at : 'a priority_queue -> 'a t -> Time_ns.t\n val key : 'a priority_queue -> 'a t -> Key.t\n val value : 'a priority_queue -> 'a t -> 'a\n val null : unit -> 'a t\n end\n\n module Internal_elt : sig\n module Pool : sig\n type 'a t\n end\n\n type 'a t\n\n val key : 'a Pool.t -> 'a t -> Key.t\n val max_alarm_time : 'a Pool.t -> 'a t -> with_key:Key.t -> Time_ns.t\n val is_null : _ t -> bool\n val to_external : 'a t -> 'a Elt.t\n end\n\n val pool : 'a t -> 'a Internal_elt.Pool.t\n\n include Invariant.S1 with type 'a t := 'a t\n\n (** [create ?level_bits ()] creates a new empty timing wheel, [t], with [length t = 0]\n and [min_allowed_key t = 0]. *)\n val create : ?capacity:int -> ?level_bits:Level_bits.t -> unit -> 'a t\n\n (** [length t] returns the number of elements in the timing wheel. *)\n val length : _ t -> int\n\n (** [min_allowed_key t] is the minimum key that can be stored in [t]. This only\n indicates the possibility; there need not be an element [elt] in [t] with [Elt.key\n elt = min_allowed_key t]. This is not the same as the \"min_key\" operation in a\n typical priority queue.\n\n [min_allowed_key t] can increase over time, via calls to\n [increase_min_allowed_key]. *)\n val min_allowed_key : _ t -> Key.t\n\n (** [max_allowed_key t] is the maximum allowed key that can be stored in [t]. As\n [min_allowed_key] increases, so does [max_allowed_key]; however it is not the case\n that [max_allowed_key t - min_allowed_key t] is a constant. It is guaranteed that\n [max_allowed_key t >= min_allowed_key t + 2^B - 1],\n where [B] is the sum of the b_i in [level_bits]. *)\n val max_allowed_key : _ t -> Key.t\n\n val min_elt_ : 'a t -> 'a Internal_elt.t\n val internal_add : 'a t -> key:Key.t -> at:Time_ns.t -> 'a -> 'a Internal_elt.t\n\n (** [remove t elt] removes [elt] from [t]. It is an error if [elt] is not currently\n in [t], and this error may or may not be detected. *)\n val remove : 'a t -> 'a Elt.t -> unit\n\n val change : 'a t -> 'a Elt.t -> key:Key.t -> at:Time_ns.t -> unit\n\n (** [clear t] removes all elts from [t]. *)\n val clear : _ t -> unit\n\n val mem : 'a t -> 'a Elt.t -> bool\n\n (** [increase_min_allowed_key t ~key ~handle_removed] increases the minimum allowed\n key in [t] to [key], and removes all elements with keys less than [key], applying\n [handle_removed] to each element that is removed. If [key <= min_allowed_key t],\n then [increase_min_allowed_key] does nothing. Otherwise, if\n [increase_min_allowed_key] returns successfully, [min_allowed_key t = key].\n\n [increase_min_allowed_key] takes time proportional to [key - min_allowed_key t],\n although possibly less time.\n\n Behavior is unspecified if [handle_removed] accesses [t] in any way other than\n [Elt] functions. *)\n val increase_min_allowed_key\n : 'a t\n -> key:Key.t\n -> handle_removed:('a Elt.t -> unit)\n -> unit\n\n val iter : 'a t -> f:('a Elt.t -> unit) -> unit\n\n val fire_past_alarms\n : 'a t\n -> handle_fired:('a Elt.t -> unit)\n -> key:Key.t\n -> now:Time_ns.t\n -> unit\nend = struct\n (** Each slot in a level is a (possibly null) pointer to a circular doubly-linked list\n of elements. We pool the elements so that we can reuse them after they are removed\n from the timing wheel (either via [remove] or [increase_min_allowed_key]). In\n addition to storing the [key], [at], and [value] in the element, we store the\n [level_index] so that we can quickly get to the level holding an element when we\n [remove] it.\n\n We distinguish between [External_elt] and [Internal_elt], which are the same\n underneath. We maintain the invariant that an [Internal_elt] is either [null] or a\n valid pointer. On the other hand, [External_elt]s are returned to user code, so\n there is no guarantee of validity -- we always validate an [External_elt] before\n doing anything with it.\n\n It is therefore OK to use [Pool.Unsafe], because we will never attempt to access a\n slot of an invalid pointer. *)\n module Pool = Pool.Unsafe\n\n module Pointer = Pool.Pointer\n\n module Key : sig\n (** [Interval_num] is the public API. Everything following in the signature is\n for internal use. *)\n include\n Timing_wheel_intf.Interval_num\n\n (** [add_clamp_to_max] doesn't work at all with negative spans *)\n val add_clamp_to_max : t -> Span.t -> t\n\n val succ_clamp_to_max : t -> t\n\n (** [Slots_mask] is used to quickly determine a key's slot in a given level. *)\n module Slots_mask : sig\n type t = private Int63.t [@@deriving compare, sexp_of]\n\n val create : level_bits:Num_key_bits.t -> t\n val next_slot : t -> int -> int\n end\n\n (** [Min_key_in_same_slot_mask] is used to quickly determine the minimum key in the\n same slot as a given key. *)\n module Min_key_in_same_slot_mask : sig\n type t = private Int63.t [@@deriving compare, sexp_of]\n\n include Equal.S with type t := t\n\n val create : bits_per_slot:Num_key_bits.t -> t\n end\n\n val num_keys : Num_key_bits.t -> Span.t\n val min_key_in_same_slot : t -> Min_key_in_same_slot_mask.t -> t\n val slot : t -> bits_per_slot:Num_key_bits.t -> slots_mask:Slots_mask.t -> int\n end = struct\n module Slots_mask = struct\n type t = Int63.t [@@deriving compare, sexp_of]\n\n let create ~level_bits = Int63.( - ) (Num_key_bits.pow2 level_bits) Int63.one\n let next_slot t slot = (slot + 1) land Int63.to_int_exn t\n end\n\n let num_keys num_bits = Num_key_bits.pow2 num_bits\n\n module Min_key_in_same_slot_mask = struct\n include Int63\n\n let create ~bits_per_slot = bit_not (Num_key_bits.pow2 bits_per_slot - one)\n end\n\n module Span = struct\n include Int63\n\n let to_int63 t = t\n let of_int63 i = i\n let scale_int t i = t * of_int i\n end\n\n include Int63\n\n let of_int63 i = i\n let to_int63 t = t\n let add t i = t + i\n let add_clamp_to_max t i = if t > max_value - i then max_value else t + i\n let succ_clamp_to_max t = if t = max_value then max_value else succ t\n let sub t i = t - i\n let diff t1 t2 = t1 - t2\n\n let slot t ~(bits_per_slot : Num_key_bits.t) ~slots_mask =\n to_int_exn (bit_and (shift_right t (bits_per_slot :> int)) slots_mask)\n ;;\n\n let min_key_in_same_slot t min_key_in_same_slot_mask =\n bit_and t min_key_in_same_slot_mask\n ;;\n end\n\n module Min_key_in_same_slot_mask = Key.Min_key_in_same_slot_mask\n module Slots_mask = Key.Slots_mask\n\n module External_elt = struct\n\n (** The [pool_slots] here has nothing to do with the slots in a level array. This is\n for the slots in the pool tuple representing a level element. *)\n type 'a pool_slots =\n ( Key.t\n , Time_ns.t\n , 'a\n , int\n , 'a pool_slots Pointer.t\n , 'a pool_slots Pointer.t )\n Pool.Slots.t6\n [@@deriving sexp_of]\n\n type 'a t = 'a pool_slots Pointer.t [@@deriving sexp_of]\n\n let null = Pointer.null\n end\n\n module Internal_elt : sig\n module Pool : sig\n type 'a t [@@deriving sexp_of]\n\n include Invariant.S1 with type 'a t := 'a t\n\n val create : ?capacity:int -> unit -> _ t\n val is_full : _ t -> bool\n val grow : ?capacity:int -> 'a t -> 'a t\n end\n\n type 'a t = private 'a External_elt.t [@@deriving sexp_of]\n\n val null : unit -> _ t\n val is_null : _ t -> bool\n val is_valid : 'a Pool.t -> 'a t -> bool\n\n (** Dealing with [External_elt]s. *)\n\n val external_is_valid : 'a Pool.t -> 'a External_elt.t -> bool\n val to_external : 'a t -> 'a External_elt.t\n val of_external_exn : 'a Pool.t -> 'a External_elt.t -> 'a t\n val equal : 'a t -> 'a t -> bool\n val invariant : 'a Pool.t -> ('a -> unit) -> 'a t -> unit\n\n (** [create] returns an element whose [next] and [prev] are [null]. *)\n val create\n : 'a Pool.t\n -> key:Key.t\n (** [at] is used when the priority queue is used to implement a timing wheel. If\n unused, it will be [Time_ns.epoch]. *)\n -> at:Time_ns.t\n -> value:'a\n -> level_index:int\n -> 'a t\n\n val free : 'a Pool.t -> 'a t -> unit\n\n (** accessors *)\n\n val key : 'a Pool.t -> 'a t -> Key.t\n val at : 'a Pool.t -> 'a t -> Time_ns.t\n val level_index : 'a Pool.t -> 'a t -> int\n val next : 'a Pool.t -> 'a t -> 'a t\n val value : 'a Pool.t -> 'a t -> 'a\n\n (** mutators *)\n\n val set_key : 'a Pool.t -> 'a t -> Key.t -> unit\n val set_at : 'a Pool.t -> 'a t -> Time_ns.t -> unit\n val set_level_index : 'a Pool.t -> 'a t -> int -> unit\n\n (** [insert_at_end pool t ~to_add] treats [t] as the head of the list and adds [to_add]\n to the end of it. *)\n val insert_at_end : 'a Pool.t -> 'a t -> to_add:'a t -> unit\n\n (** [link_to_self pool t] makes [t] be a singleton circular doubly-linked list. *)\n val link_to_self : 'a Pool.t -> 'a t -> unit\n\n (** [unlink p t] unlinks [t] from the circularly doubly-linked list that it is in. It\n changes the pointers of [t]'s [prev] and [next] elts, but not [t]'s [prev] and\n [next] pointers. [unlink] is meaningless if [t] is a singleton. *)\n val unlink : 'a Pool.t -> 'a t -> unit\n\n (** Iterators. [iter p t ~init ~f] visits each element in the doubly-linked list\n containing [t], starting at [t], and following [next] pointers. [length] counts\n by visiting each element in the list. *)\n val iter : 'a Pool.t -> 'a t -> f:('a t -> unit) -> unit\n\n val length : 'a Pool.t -> 'a t -> int\n\n (** [max_alarm_time t elt ~with_key] finds the max [at] in [elt]'s list among the elts\n whose key is [with_key], returning [Time_ns.epoch] if the list is empty. *)\n val max_alarm_time : 'a Pool.t -> 'a t -> with_key:Key.t -> Time_ns.t\n end = struct\n type 'a pool_slots = 'a External_elt.pool_slots [@@deriving sexp_of]\n type 'a t = 'a External_elt.t [@@deriving sexp_of]\n\n let null = Pointer.null\n let is_null = Pointer.is_null\n let equal t1 t2 = Pointer.phys_equal t1 t2\n\n let create pool ~key ~at ~value ~level_index =\n Pool.new6 pool key at value level_index (null ()) (null ())\n ;;\n\n let free = Pool.free\n let key p t = Pool.get p t Pool.Slot.t0\n let set_key p t k = Pool.set p t Pool.Slot.t0 k\n let at p t = Pool.get p t Pool.Slot.t1\n let set_at p t x = Pool.set p t Pool.Slot.t1 x\n let value p t = Pool.get p t Pool.Slot.t2\n let level_index p t = Pool.get p t Pool.Slot.t3\n let set_level_index p t i = Pool.set p t Pool.Slot.t3 i\n let prev p t = Pool.get p t Pool.Slot.t4\n let set_prev p t x = Pool.set p t Pool.Slot.t4 x\n let next p t = Pool.get p t Pool.Slot.t5\n let set_next p t x = Pool.set p t Pool.Slot.t5 x\n let is_valid p t = Pool.pointer_is_valid p t\n let external_is_valid = is_valid\n\n let invariant pool invariant_a t =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n assert (is_valid pool t);\n invariant_a (value pool t);\n let n = next pool t in\n assert (is_null n || Pointer.phys_equal t (prev pool n));\n let p = prev pool t in\n assert (is_null p || Pointer.phys_equal t (next pool p)))\n ;;\n\n module Pool = struct\n type 'a t = 'a pool_slots Pool.t [@@deriving sexp_of]\n\n let invariant _invariant_a t = Pool.invariant ignore t\n let create ?(capacity = 1) () = Pool.create Pool.Slots.t6 ~capacity\n let grow = Pool.grow\n let is_full = Pool.is_full\n end\n\n let to_external t = t\n\n let of_external_exn pool t =\n if is_valid pool t then t else raise_s [%message \"Timing_wheel got invalid alarm\"]\n ;;\n\n let unlink pool t =\n set_next pool (prev pool t) (next pool t);\n set_prev pool (next pool t) (prev pool t)\n ;;\n\n let link pool prev next =\n set_next pool prev next;\n set_prev pool next prev\n ;;\n\n let link_to_self pool t = link pool t t\n\n let insert_at_end pool t ~to_add =\n let prev = prev pool t in\n link pool prev to_add;\n link pool to_add t\n ;;\n\n let iter pool first ~f =\n let current = ref first in\n let continue = ref true in\n while !continue do\n (* We get [next] before calling [f] so that [f] can modify or [free] [!current]. *)\n let next = next pool !current in\n f !current;\n if phys_equal next first then continue := false else current := next\n done\n ;;\n\n let length pool first =\n let r = ref 0 in\n let current = ref first in\n let continue = ref true in\n while !continue do\n incr r;\n let next = next pool !current in\n if phys_equal next first then continue := false else current := next\n done;\n !r\n ;;\n\n let max_alarm_time pool first ~with_key =\n let max_alarm_time = ref Time_ns.epoch in\n let current = ref first in\n let continue = ref true in\n while !continue do\n let next = next pool !current in\n if Key.equal (key pool !current) with_key\n then max_alarm_time := Time_ns.max (at pool !current) !max_alarm_time;\n if phys_equal next first then continue := false else current := next\n done;\n !max_alarm_time\n ;;\n end\n\n module Level = struct\n (** For given level, one can break the bits into a key into three regions:\n\n {v\n | higher levels | this level | lower levels |\n v}\n\n \"Lower levels\" is [bits_per_slot] bits wide. \"This level\" is [bits] wide. *)\n type 'a t =\n { (* The [index] in the timing wheel's array of levels where this level is. *)\n index : int\n ; (* How many [bits] this level is responsible for. *)\n bits : Num_key_bits.t\n ; (* [slots_mask = Slots_mask.create ~level_bits:t.bits]. *)\n slots_mask : Slots_mask.t\n ; (* [bits_per_slot] is how many bits each slot distinguishes, and is the sum of of\n the [bits] of all the lower levels. *)\n bits_per_slot : Num_key_bits.t\n ; keys_per_slot : Key.Span.t\n ; min_key_in_same_slot_mask : Min_key_in_same_slot_mask.t\n ; (* [diff_max_min_allowed_key = keys_per_slot * Array.length slots - 1] *)\n diff_max_min_allowed_key : Key.Span.t\n ; (* [length] is the number of elts currently in this level. *)\n mutable length : int\n ; (* All elements at this level have their [key] satisfy [min_allowed_key <= key <=\n max_allowed_key]. Also, [min_allowed_key] is a multiple of [keys_per_slot]. *)\n mutable min_allowed_key : Key.t\n ; mutable max_allowed_key : Key.t\n ; (* [slots] holds the (possibly null) pointers to the circular doubly-linked lists\n of elts. [Array.length slots = 1 lsl bits]. *)\n slots : ('a Internal_elt.t array[@sexp.opaque])\n }\n [@@deriving fields, sexp_of]\n\n let slot t ~key =\n Key.slot key ~bits_per_slot:t.bits_per_slot ~slots_mask:t.slots_mask\n ;;\n\n let next_slot t slot = Slots_mask.next_slot t.slots_mask slot\n\n let min_key_in_same_slot t ~key =\n Key.min_key_in_same_slot key t.min_key_in_same_slot_mask\n ;;\n\n let compute_min_allowed_key t ~prev_level_max_allowed_key =\n (* This computation ensures that [t]'s [min_allowed_key] is as large as possible\n subject to the constraint that there is no inter-level gap. *)\n if Key.equal prev_level_max_allowed_key Key.max_value\n then Key.max_value\n else min_key_in_same_slot t ~key:(Key.succ prev_level_max_allowed_key)\n ;;\n end\n\n type 'a t =\n { mutable length : int\n ; mutable pool : 'a Internal_elt.Pool.t\n ; (* [min_elt] is either null or an element whose key is [elt_key_lower_bound]. *)\n mutable min_elt : 'a Internal_elt.t\n ; (* All elements in the priority queue have their key [>= elt_key_lower_bound]. *)\n mutable elt_key_lower_bound : Key.t\n ; levels : 'a Level.t array\n }\n [@@deriving fields, sexp_of]\n\n type 'a priority_queue = 'a t\n\n module Elt = struct\n type 'a t = 'a External_elt.t [@@deriving sexp_of]\n\n let null = External_elt.null\n let at p t = Internal_elt.at p.pool (Internal_elt.of_external_exn p.pool t)\n let key p t = Internal_elt.key p.pool (Internal_elt.of_external_exn p.pool t)\n let value p t = Internal_elt.value p.pool (Internal_elt.of_external_exn p.pool t)\n end\n\n let sexp_of_t_internal = sexp_of_t\n let is_empty t = length t = 0\n let num_levels t = Array.length t.levels\n let min_allowed_key t = Level.min_allowed_key t.levels.(0)\n let max_allowed_key t = Level.max_allowed_key t.levels.(num_levels t - 1)\n\n let internal_iter t ~f =\n if t.length > 0\n then (\n let pool = t.pool in\n let levels = t.levels in\n for level_index = 0 to Array.length levels - 1 do\n let level = levels.(level_index) in\n if level.length > 0\n then (\n let slots = level.slots in\n for slot_index = 0 to Array.length slots - 1 do\n let elt = slots.(slot_index) in\n if not (Internal_elt.is_null elt) then Internal_elt.iter pool elt ~f\n done)\n done)\n ;;\n\n let iter t ~f = internal_iter t ~f:(f : _ Elt.t -> unit :> _ Internal_elt.t -> unit)\n\n module Pretty = struct\n module Elt = struct\n type 'a t =\n { key : Key.t\n ; value : 'a\n }\n [@@deriving sexp_of]\n end\n\n type 'a t =\n { min_allowed_key : Key.t\n ; max_allowed_key : Key.t\n ; elts : 'a Elt.t list\n }\n [@@deriving sexp_of]\n end\n\n let pretty t =\n let pool = t.pool in\n { Pretty.min_allowed_key = min_allowed_key t\n ; max_allowed_key = max_allowed_key t\n ; elts =\n (let r = ref [] in\n internal_iter t ~f:(fun elt ->\n r\n := { Pretty.Elt.key = Internal_elt.key pool elt\n ; value = Internal_elt.value pool elt\n }\n :: !r);\n List.rev !r)\n }\n ;;\n\n let sexp_of_t sexp_of_a t =\n match !sexp_of_t_style with\n | `Internal -> [%sexp (t : a t_internal)]\n | `Pretty -> [%sexp (pretty t : a Pretty.t)]\n ;;\n\n let compute_diff_max_min_allowed_key ~level_bits ~bits_per_slot =\n let bits = Num_key_bits.( + ) level_bits bits_per_slot in\n if Num_key_bits.equal bits Num_key_bits.max_value\n then Key.Span.max_value\n else Key.Span.pred (Key.num_keys bits)\n ;;\n\n let invariant invariant_a t : unit =\n let pool = t.pool in\n let level_invariant level =\n Invariant.invariant [%here] level [%sexp_of: _ Level.t] (fun () ->\n let check f = Invariant.check_field level f in\n Level.Fields.iter\n ~index:(check (fun index -> assert (index >= 0)))\n ~bits:\n (check (fun bits -> assert (Num_key_bits.( > ) bits Num_key_bits.zero)))\n ~slots_mask:\n (check\n ([%test_result: Slots_mask.t]\n ~expect:(Slots_mask.create ~level_bits:level.bits)))\n ~bits_per_slot:\n (check (fun bits_per_slot ->\n assert (Num_key_bits.( >= ) bits_per_slot Num_key_bits.zero)))\n ~keys_per_slot:\n (check (fun keys_per_slot ->\n [%test_result: Key.Span.t]\n keys_per_slot\n ~expect:(Key.num_keys level.bits_per_slot)))\n ~min_key_in_same_slot_mask:\n (check (fun min_key_in_same_slot_mask ->\n assert (\n Min_key_in_same_slot_mask.equal\n min_key_in_same_slot_mask\n (Min_key_in_same_slot_mask.create\n ~bits_per_slot:level.bits_per_slot))))\n ~diff_max_min_allowed_key:\n (check\n ([%test_result: Key.Span.t]\n ~expect:\n (compute_diff_max_min_allowed_key\n ~level_bits:level.bits\n ~bits_per_slot:level.bits_per_slot)))\n ~length:\n (check (fun length ->\n assert (\n length\n = Array.fold level.slots ~init:0 ~f:(fun n elt ->\n if Internal_elt.is_null elt\n then n\n else n + Internal_elt.length pool elt))))\n ~min_allowed_key:\n (check (fun min_allowed_key ->\n assert (Key.( >= ) min_allowed_key Key.zero);\n if Key.( < ) min_allowed_key Key.max_value\n then\n [%test_result: Key.Span.t]\n (Key.rem min_allowed_key level.keys_per_slot)\n ~expect:Key.Span.zero))\n ~max_allowed_key:\n (check (fun max_allowed_key ->\n [%test_result: Key.t]\n max_allowed_key\n ~expect:\n (Key.add_clamp_to_max\n level.min_allowed_key\n level.diff_max_min_allowed_key)))\n ~slots:\n (check (fun slots ->\n Array.iter slots ~f:(fun elt ->\n if not (Internal_elt.is_null elt)\n then (\n Internal_elt.invariant pool invariant_a elt;\n Internal_elt.iter pool elt ~f:(fun elt ->\n assert (\n Key.( >= )\n (Internal_elt.key pool elt)\n level.min_allowed_key);\n assert (\n Key.( <= )\n (Internal_elt.key pool elt)\n level.max_allowed_key);\n assert (\n Key.( >= )\n (Internal_elt.key pool elt)\n t.elt_key_lower_bound);\n assert (Internal_elt.level_index pool elt = level.index);\n invariant_a (Internal_elt.value pool elt)))))))\n in\n Invariant.invariant [%here] t [%sexp_of: _ t_internal] (fun () ->\n let check f = Invariant.check_field t f in\n assert (Key.( >= ) (min_allowed_key t) Key.zero);\n assert (Key.( >= ) (max_allowed_key t) (min_allowed_key t));\n Fields.iter\n ~length:(check (fun length -> assert (length >= 0)))\n ~pool:(check (Internal_elt.Pool.invariant ignore))\n ~min_elt:\n (check (fun elt_ ->\n if not (Internal_elt.is_null elt_)\n then (\n assert (Internal_elt.is_valid t.pool elt_);\n assert (Key.equal t.elt_key_lower_bound (Internal_elt.key t.pool elt_)))))\n ~elt_key_lower_bound:\n (check (fun elt_key_lower_bound ->\n assert (Key.( >= ) elt_key_lower_bound (min_allowed_key t));\n assert (Key.( <= ) elt_key_lower_bound (max_allowed_key t));\n if not (Internal_elt.is_null t.min_elt)\n then\n assert (\n Key.equal elt_key_lower_bound (Internal_elt.key t.pool t.min_elt))))\n ~levels:\n (check (fun levels ->\n assert (num_levels t > 0);\n Array.iteri levels ~f:(fun level_index level ->\n assert (level_index = Level.index level);\n level_invariant level;\n if level_index > 0\n then (\n let prev_level = levels.(level_index - 1) in\n let module L = Level in\n [%test_result: Key.Span.t]\n (L.keys_per_slot level)\n ~expect:(Key.Span.succ prev_level.diff_max_min_allowed_key);\n [%test_result: Key.t]\n level.min_allowed_key\n ~expect:\n (Level.compute_min_allowed_key\n level\n ~prev_level_max_allowed_key:prev_level.max_allowed_key))))))\n ;;\n\n (** [min_elt_] returns [null] if it can't find the desired element. We wrap it up\n afterwards to return an [option]. *)\n let min_elt_ t =\n if is_empty t\n then Internal_elt.null ()\n else if not (Internal_elt.is_null t.min_elt)\n then t.min_elt\n else (\n let pool = t.pool in\n let min_elt_already_found = ref (Internal_elt.null ()) in\n let min_key_already_found = ref Key.max_value in\n let level_index = ref 0 in\n let num_levels = num_levels t in\n while !level_index < num_levels do\n let level = t.levels.(!level_index) in\n if Key.( > ) (Level.min_allowed_key level) !min_key_already_found\n then\n (* We don't need to consider any more levels. Quit the loop. *)\n level_index := num_levels\n else if level.length = 0\n then incr level_index\n else (\n (* Look in [level]. *)\n let slots = level.slots in\n let slot_min_key =\n ref\n (Level.min_key_in_same_slot\n level\n ~key:(Key.max level.min_allowed_key t.elt_key_lower_bound))\n in\n let slot = ref (Level.slot level ~key:!slot_min_key) in\n (* Find the first nonempty slot with a small enough [slot_min_key]. *)\n while\n Internal_elt.is_null slots.(!slot)\n && Key.( < ) !slot_min_key !min_key_already_found\n do\n slot := Level.next_slot level !slot;\n slot_min_key := Key.add !slot_min_key level.keys_per_slot\n done;\n let first = slots.(!slot) in\n if not (Internal_elt.is_null first)\n then (\n (* Visit all of the elts in this slot and find one with minimum key. *)\n let continue = ref true in\n let current = ref first in\n while !continue do\n let current_key = Internal_elt.key pool !current in\n if Key.( <= ) current_key !min_key_already_found\n then (\n min_elt_already_found := !current;\n min_key_already_found := current_key);\n let next = Internal_elt.next pool !current in\n (* If [!level_index = 0] then all elts in this slot have the same [key],\n i.e. [!slot_min_key]. So, we don't have to check any elements after\n [first]. This is a useful short cut in the common case that there are\n multiple elements in the same min slot in level 0. *)\n if phys_equal next first || !level_index = 0\n then continue := false\n else current := next\n done);\n (* Finished looking in [level]. Move up to the next level. *)\n incr level_index)\n done;\n t.min_elt <- !min_elt_already_found;\n t.elt_key_lower_bound <- !min_key_already_found;\n t.min_elt)\n ;;\n\n let[@cold] raise_add_elt_key_out_of_bounds t key =\n raise_s\n [%message\n \"Priority_queue.add_elt key out of bounds\"\n (key : Key.t)\n (min_allowed_key t : Key.t)\n (max_allowed_key t : Key.t)\n ~priority_queue:(t : _ t)]\n ;;\n\n let[@cold] raise_add_elt_key_out_of_level_bounds key level =\n raise_s\n [%message\n \"Priority_queue.add_elt key out of level bounds\"\n (key : Key.t)\n (level : _ Level.t)]\n ;;\n\n let add_elt t elt =\n let pool = t.pool in\n let key = Internal_elt.key pool elt in\n if not (Key.( >= ) key (min_allowed_key t) && Key.( <= ) key (max_allowed_key t))\n then raise_add_elt_key_out_of_bounds t key;\n (* Find the lowest level that will hold [elt]. *)\n let level_index =\n let level_index = ref 0 in\n while Key.( > ) key (Level.max_allowed_key t.levels.(!level_index)) do\n incr level_index\n done;\n !level_index\n in\n let level = t.levels.(level_index) in\n if not (Key.( >= ) key level.min_allowed_key && Key.( <= ) key level.max_allowed_key)\n then raise_add_elt_key_out_of_level_bounds key level;\n level.length <- level.length + 1;\n Internal_elt.set_level_index pool elt level_index;\n let slot = Level.slot level ~key in\n let slots = level.slots in\n let first = slots.(slot) in\n if not (Internal_elt.is_null first)\n then Internal_elt.insert_at_end pool first ~to_add:elt\n else (\n slots.(slot) <- elt;\n Internal_elt.link_to_self pool elt)\n ;;\n\n let internal_add_elt t elt =\n let key = Internal_elt.key t.pool elt in\n if Key.( < ) key t.elt_key_lower_bound\n then (\n t.min_elt <- elt;\n t.elt_key_lower_bound <- key);\n add_elt t elt;\n t.length <- t.length + 1\n ;;\n\n let[@cold] raise_got_invalid_key t key =\n raise_s\n [%message\n \"Timing_wheel.add_at_interval_num got invalid interval num\"\n ~interval_num:(key : Key.t)\n ~min_allowed_alarm_interval_num:(min_allowed_key t : Key.t)\n ~max_allowed_alarm_interval_num:(max_allowed_key t : Key.t)]\n ;;\n\n let ensure_valid_key t ~key =\n if Key.( < ) key (min_allowed_key t) || Key.( > ) key (max_allowed_key t)\n then raise_got_invalid_key t key\n ;;\n\n let internal_add t ~key ~at value =\n ensure_valid_key t ~key;\n if Internal_elt.Pool.is_full t.pool then t.pool <- Internal_elt.Pool.grow t.pool;\n let elt = Internal_elt.create t.pool ~key ~at ~value ~level_index:(-1) in\n internal_add_elt t elt;\n elt\n ;;\n\n (** [remove_or_re_add_elts] visits each element in the circular doubly-linked list\n [first]. If the element's key is [>= t_min_allowed_key], then it adds the element\n back at a lower level. If not, then it calls [handle_removed] and [free]s the\n element. *)\n let remove_or_re_add_elts\n t\n (level : _ Level.t)\n first\n ~t_min_allowed_key\n ~handle_removed\n =\n let pool = t.pool in\n let current = ref first in\n let continue = ref true in\n while !continue do\n (* We extract [next] from [current] first, because we will modify or [free]\n [current] before continuing the loop. *)\n let next = Internal_elt.next pool !current in\n level.length <- level.length - 1;\n if Key.( >= ) (Internal_elt.key pool !current) t_min_allowed_key\n then add_elt t !current\n else (\n t.length <- t.length - 1;\n handle_removed (Internal_elt.to_external !current);\n Internal_elt.free pool !current);\n if phys_equal next first then continue := false else current := next\n done\n ;;\n\n (** [increase_level_min_allowed_key] increases the [min_allowed_key] of [level] to as\n large a value as possible, but no more than [max_level_min_allowed_key].\n [t_min_allowed_key] is the minimum allowed key for the entire timing wheel. As\n elements are encountered, they are removed from the timing wheel if their key is\n smaller than [t_min_allowed_key], or added at a lower level if not. *)\n let increase_level_min_allowed_key\n t\n (level : _ Level.t)\n ~prev_level_max_allowed_key\n ~t_min_allowed_key\n ~handle_removed\n =\n let desired_min_allowed_key =\n Level.compute_min_allowed_key level ~prev_level_max_allowed_key\n in\n (* We require that [mod level.min_allowed_key level.keys_per_slot = 0]. So,\n we start [level_min_allowed_key] where that is true, and then increase it by\n [keys_per_slot] each iteration of the loop. *)\n let level_min_allowed_key =\n Level.min_key_in_same_slot\n level\n ~key:\n (Key.min\n desired_min_allowed_key\n (Key.max level.min_allowed_key t.elt_key_lower_bound))\n in\n let level_min_allowed_key = ref level_min_allowed_key in\n let slot = ref (Level.slot level ~key:!level_min_allowed_key) in\n let keys_per_slot = level.keys_per_slot in\n let slots = level.slots in\n while Key.( < ) !level_min_allowed_key desired_min_allowed_key do\n if level.length = 0\n then\n (* If no elements remain at this level, we can just set [min_allowed_key] to the\n desired value. *)\n level_min_allowed_key := desired_min_allowed_key\n else (\n let first = slots.(!slot) in\n if not (Internal_elt.is_null first)\n then (\n slots.(!slot) <- Internal_elt.null ();\n remove_or_re_add_elts t level first ~t_min_allowed_key ~handle_removed);\n slot := Level.next_slot level !slot;\n level_min_allowed_key\n := Key.add_clamp_to_max !level_min_allowed_key keys_per_slot)\n done;\n level.min_allowed_key <- desired_min_allowed_key;\n level.max_allowed_key\n <- Key.add_clamp_to_max desired_min_allowed_key level.diff_max_min_allowed_key\n ;;\n\n let increase_min_allowed_key t ~key ~handle_removed =\n if Key.( > ) key (min_allowed_key t)\n then (\n (* We increase the [min_allowed_key] of levels in order to restore the invariant\n that they have as large as possible a [min_allowed_key], while leaving no gaps\n in keys. *)\n let level_index = ref 0 in\n let prev_level_max_allowed_key = ref (Key.pred key) in\n let levels = t.levels in\n let num_levels = num_levels t in\n while !level_index < num_levels do\n let level = levels.(!level_index) in\n let min_allowed_key_before = level.min_allowed_key in\n increase_level_min_allowed_key\n t\n level\n ~prev_level_max_allowed_key:!prev_level_max_allowed_key\n ~t_min_allowed_key:key\n ~handle_removed;\n if Key.equal (Level.min_allowed_key level) min_allowed_key_before\n then\n (* This level did not shift. Don't shift any higher levels. *)\n level_index := num_levels\n else (\n (* Level [level_index] shifted. Consider shifting higher levels. *)\n level_index := !level_index + 1;\n prev_level_max_allowed_key := Level.max_allowed_key level)\n done;\n if Key.( > ) key t.elt_key_lower_bound\n then (\n (* We have removed [t.min_elt] or it was already null, so just set it to\n null. *)\n t.min_elt <- Internal_elt.null ();\n t.elt_key_lower_bound <- min_allowed_key t))\n ;;\n\n let create ?capacity ?level_bits () =\n let level_bits =\n match level_bits with\n | Some l -> l\n | None -> Level_bits.default\n in\n let _, _, levels =\n List.foldi\n level_bits\n ~init:(Num_key_bits.zero, Key.zero, [])\n ~f:(fun index\n (bits_per_slot, max_level_min_allowed_key, levels)\n (level_bits : Num_key_bits.t)\n ->\n let keys_per_slot = Key.num_keys bits_per_slot in\n let diff_max_min_allowed_key =\n compute_diff_max_min_allowed_key ~level_bits ~bits_per_slot\n in\n let min_key_in_same_slot_mask =\n Min_key_in_same_slot_mask.create ~bits_per_slot\n in\n let min_allowed_key =\n Key.min_key_in_same_slot max_level_min_allowed_key min_key_in_same_slot_mask\n in\n let max_allowed_key =\n Key.add_clamp_to_max min_allowed_key diff_max_min_allowed_key\n in\n let level =\n { Level.index\n ; bits = level_bits\n ; slots_mask = Slots_mask.create ~level_bits\n ; bits_per_slot\n ; keys_per_slot\n ; min_key_in_same_slot_mask\n ; diff_max_min_allowed_key\n ; length = 0\n ; min_allowed_key\n ; max_allowed_key\n ; slots =\n Array.create\n ~len:(Int63.to_int_exn (Num_key_bits.pow2 level_bits))\n (Internal_elt.null ())\n }\n in\n ( Num_key_bits.( + ) level_bits bits_per_slot\n , Key.succ_clamp_to_max max_allowed_key\n , level :: levels ))\n in\n { length = 0\n ; pool = Internal_elt.Pool.create ?capacity ()\n ; min_elt = Internal_elt.null ()\n ; elt_key_lower_bound = Key.zero\n ; levels = Array.of_list_rev levels\n }\n ;;\n\n let mem t elt = Internal_elt.external_is_valid t.pool elt\n\n let internal_remove t elt =\n let pool = t.pool in\n if Internal_elt.equal elt t.min_elt\n then\n t.min_elt <- Internal_elt.null ()\n (* We keep [t.elt_lower_bound] since it is valid even though [t.min_elt] is being\n removed. *);\n t.length <- t.length - 1;\n let level = t.levels.(Internal_elt.level_index pool elt) in\n level.length <- level.length - 1;\n let slots = level.slots in\n let slot = Level.slot level ~key:(Internal_elt.key pool elt) in\n let first = slots.(slot) in\n if phys_equal elt (Internal_elt.next pool elt)\n then (* [elt] is the only element in the slot *)\n slots.(slot) <- Internal_elt.null ()\n else (\n if phys_equal elt first then slots.(slot) <- Internal_elt.next pool elt;\n Internal_elt.unlink pool elt)\n ;;\n\n let remove t elt =\n let pool = t.pool in\n let elt = Internal_elt.of_external_exn pool elt in\n internal_remove t elt;\n Internal_elt.free pool elt\n ;;\n\n let fire_past_alarms t ~handle_fired ~key ~now =\n let level = t.levels.(0) in\n if level.length > 0\n then (\n let slot = Level.slot level ~key in\n let slots = level.slots in\n let pool = t.pool in\n let first = ref slots.(slot) in\n if not (Internal_elt.is_null !first)\n then (\n let current = ref !first in\n let continue = ref true in\n while !continue do\n let elt = !current in\n let next = Internal_elt.next pool elt in\n if phys_equal next !first then continue := false else current := next;\n if Time_ns.( <= ) (Internal_elt.at pool elt) now\n then (\n handle_fired (Internal_elt.to_external elt);\n internal_remove t elt;\n Internal_elt.free pool elt;\n (* We recompute [first] because [internal_remove] may have changed it. *)\n first := slots.(slot))\n done))\n ;;\n\n let change t elt ~key ~at =\n ensure_valid_key t ~key;\n let pool = t.pool in\n let elt = Internal_elt.of_external_exn pool elt in\n internal_remove t elt;\n Internal_elt.set_key pool elt key;\n Internal_elt.set_at pool elt at;\n internal_add_elt t elt\n ;;\n\n let clear t =\n if not (is_empty t)\n then (\n t.length <- 0;\n let pool = t.pool in\n let free_elt elt = Internal_elt.free pool elt in\n let levels = t.levels in\n for level_index = 0 to Array.length levels - 1 do\n let level = levels.(level_index) in\n if level.length > 0\n then (\n level.length <- 0;\n let slots = level.slots in\n for slot_index = 0 to Array.length slots - 1 do\n let elt = slots.(slot_index) in\n if not (Internal_elt.is_null elt)\n then (\n Internal_elt.iter pool elt ~f:free_elt;\n slots.(slot_index) <- Internal_elt.null ())\n done)\n done)\n ;;\nend\n\nmodule Internal_elt = Priority_queue.Internal_elt\nmodule Key = Priority_queue.Key\nmodule Interval_num = Key\n\nlet min_interval_num = Interval_num.zero\n\n(* All time from the epoch onwards is broken into half-open intervals of size\n [Config.alarm_precision config]. The intervals are numbered starting at zero, and a\n time's interval number serves as its key in [priority_queue]. *)\ntype 'a t =\n { config : Config.t\n ; start : Time_ns.t\n ; (* [max_interval_num] is the interval number of [max_time]. *)\n max_interval_num : Interval_num.t\n ; mutable now : Time_ns.t\n ; mutable now_interval_num_start : Time_ns.t\n ; mutable max_allowed_alarm_time : Time_ns.t\n ; priority_queue : 'a Priority_queue.t\n }\n[@@deriving fields, sexp_of]\n\ntype 'a timing_wheel = 'a t\ntype 'a t_now = 'a t\n\nlet sexp_of_t_now _ t = [%sexp (t.now : Time_ns.t)]\nlet alarm_precision t = Config.alarm_precision t.config\n\nmodule Alarm = struct\n type 'a t = 'a Priority_queue.Elt.t [@@deriving sexp_of]\n\n let null = Priority_queue.Elt.null\n let at tw t = Priority_queue.Elt.at tw.priority_queue t\n let value tw t = Priority_queue.Elt.value tw.priority_queue t\n let interval_num tw t = Priority_queue.Elt.key tw.priority_queue t\nend\n\nlet sexp_of_t_internal = sexp_of_t\nlet iter t ~f = Priority_queue.iter t.priority_queue ~f\n\nmodule Pretty = struct\n module Alarm = struct\n type 'a t =\n { at : Time_ns.t\n ; value : 'a\n }\n [@@deriving fields, sexp_of]\n\n let create t alarm = { at = Alarm.at t alarm; value = Alarm.value t alarm }\n let compare t1 t2 = Time_ns.compare (at t1) (at t2)\n end\n\n type 'a t =\n { config : Config.t\n ; start : Time_ns.t\n ; max_interval_num : Interval_num.t\n ; now : Time_ns.t\n ; alarms : 'a Alarm.t list\n }\n [@@deriving sexp_of]\nend\n\nlet pretty\n ({ config\n ; start\n ; max_interval_num\n ; now\n ; now_interval_num_start = _\n ; max_allowed_alarm_time = _\n ; priority_queue = _\n } as t)\n =\n let r = ref [] in\n iter t ~f:(fun a -> r := Pretty.Alarm.create t a :: !r);\n let alarms = List.sort !r ~compare:Pretty.Alarm.compare in\n { Pretty.config; start; max_interval_num; now; alarms }\n;;\n\nlet sexp_of_t sexp_of_a t =\n match !sexp_of_t_style with\n | `Internal -> sexp_of_t_internal sexp_of_a t\n | `Pretty -> [%sexp (pretty t : a Pretty.t)]\n;;\n\nlet length t = Priority_queue.length t.priority_queue\nlet is_empty t = length t = 0\n\nlet interval_num_internal ~time ~alarm_precision =\n Interval_num.of_int63 (Alarm_precision.interval_num alarm_precision time)\n;;\n\nlet interval_num_unchecked t time =\n interval_num_internal ~time ~alarm_precision:t.config.alarm_precision\n;;\n\nlet interval_num t time =\n if Time_ns.( < ) time min_time\n then\n raise_s\n [%message\n \"Timing_wheel.interval_num got time too far in the past\" (time : Time_ns.t)];\n interval_num_unchecked t time\n;;\n\nlet interval_num_start_unchecked t interval_num =\n Alarm_precision.interval_num_start\n t.config.alarm_precision\n (interval_num |> Interval_num.to_int63)\n;;\n\nlet[@cold] raise_interval_num_start_got_too_small interval_num =\n raise_s\n [%message\n \"Timing_wheel.interval_num_start got too small interval_num\"\n (interval_num : Interval_num.t)\n (min_interval_num : Interval_num.t)]\n;;\n\nlet[@cold] raise_interval_num_start_got_too_large t interval_num =\n raise_s\n [%message\n \"Timing_wheel.interval_num_start got too large interval_num\"\n (interval_num : Interval_num.t)\n (t.max_interval_num : Interval_num.t)]\n;;\n\nlet interval_num_start t interval_num =\n if Interval_num.( < ) interval_num min_interval_num\n then raise_interval_num_start_got_too_small interval_num;\n if Interval_num.( > ) interval_num t.max_interval_num\n then raise_interval_num_start_got_too_large t interval_num;\n interval_num_start_unchecked t interval_num\n;;\n\nlet compute_max_allowed_alarm_time t =\n let max_allowed_key = Priority_queue.max_allowed_key t.priority_queue in\n if Interval_num.( >= ) max_allowed_key t.max_interval_num\n then max_time\n else\n Time_ns.add\n (interval_num_start_unchecked t max_allowed_key)\n (Time_ns.Span.( - ) (alarm_precision t) Time_ns.Span.nanosecond)\n;;\n\nlet now_interval_num t = Priority_queue.min_allowed_key t.priority_queue\nlet min_allowed_alarm_interval_num = now_interval_num\nlet max_allowed_alarm_interval_num t = interval_num t (max_allowed_alarm_time t)\nlet interval_start t time = interval_num_start_unchecked t (interval_num t time)\n\nlet invariant invariant_a t =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~config:(check Config.invariant)\n ~start:\n (check (fun start ->\n assert (Time_ns.( >= ) start min_time);\n assert (Time_ns.( <= ) start max_time)))\n ~max_interval_num:\n (check (fun max_interval_num ->\n [%test_result: Interval_num.t]\n ~expect:max_interval_num\n (interval_num t max_time);\n [%test_result: Interval_num.t]\n ~expect:max_interval_num\n (interval_num t (interval_num_start t max_interval_num))))\n ~now:\n (check (fun now ->\n assert (Time_ns.( >= ) now t.start);\n assert (Time_ns.( <= ) now max_time);\n assert (\n Interval_num.equal\n (interval_num t t.now)\n (Priority_queue.min_allowed_key t.priority_queue))))\n ~now_interval_num_start:\n (check (fun now_interval_num_start ->\n [%test_result: Time_ns.t]\n now_interval_num_start\n ~expect:(interval_num_start t (now_interval_num t))))\n ~max_allowed_alarm_time:\n (check (fun max_allowed_alarm_time ->\n [%test_result: Time_ns.t]\n max_allowed_alarm_time\n ~expect:(compute_max_allowed_alarm_time t)))\n ~priority_queue:(check (Priority_queue.invariant invariant_a));\n iter t ~f:(fun alarm ->\n assert (\n Interval_num.equal\n (Alarm.interval_num t alarm)\n (interval_num t (Alarm.at t alarm)));\n assert (\n Time_ns.( >= )\n (interval_start t (Alarm.at t alarm))\n (interval_start t (now t)));\n assert (\n Time_ns.( > ) (Alarm.at t alarm) (Time_ns.sub (now t) (alarm_precision t)))))\n;;\n\nlet advance_clock t ~to_ ~handle_fired =\n if Time_ns.( > ) to_ (now t)\n then (\n t.now <- to_;\n let key = interval_num_unchecked t to_ in\n t.now_interval_num_start <- interval_num_start_unchecked t key;\n Priority_queue.increase_min_allowed_key\n t.priority_queue\n ~key\n ~handle_removed:handle_fired;\n t.max_allowed_alarm_time <- compute_max_allowed_alarm_time t)\n;;\n\nlet create ~config ~start =\n if Time_ns.( < ) start Time_ns.epoch\n then\n raise_s\n [%message \"Timing_wheel.create got start before the epoch\" (start : Time_ns.t)];\n let t =\n { config\n ; start\n ; max_interval_num =\n interval_num_internal ~time:max_time ~alarm_precision:config.alarm_precision\n ; now = Time_ns.min_value_for_1us_rounding (* set by [advance_clock] below *)\n ; now_interval_num_start =\n Time_ns.min_value_for_1us_rounding (* set by [advance_clock] below *)\n ; max_allowed_alarm_time = max_time (* set by [advance_clock] below *)\n ; priority_queue =\n Priority_queue.create ?capacity:config.capacity ~level_bits:config.level_bits ()\n }\n in\n advance_clock t ~to_:start ~handle_fired:(fun _ -> assert false);\n t\n;;\n\nlet add_at_interval_num t ~at value =\n Internal_elt.to_external\n (Priority_queue.internal_add\n t.priority_queue\n ~key:at\n ~at:(interval_num_start t at)\n value)\n;;\n\nlet[@cold] raise_that_far_in_the_future t at =\n raise_s\n [%message\n \"Timing_wheel cannot schedule alarm that far in the future\"\n (at : Time_ns.t)\n ~max_allowed_alarm_time:(t.max_allowed_alarm_time : Time_ns.t)]\n;;\n\nlet[@cold] raise_before_start_of_current_interval t at =\n raise_s\n [%message\n \"Timing_wheel cannot schedule alarm before start of current interval\"\n (at : Time_ns.t)\n ~now_interval_num_start:(t.now_interval_num_start : Time_ns.t)]\n;;\n\nlet ensure_can_schedule_alarm t ~at =\n if Time_ns.( > ) at t.max_allowed_alarm_time then raise_that_far_in_the_future t at;\n if Time_ns.( < ) at t.now_interval_num_start\n then raise_before_start_of_current_interval t at\n;;\n\nlet add t ~at value =\n ensure_can_schedule_alarm t ~at;\n Internal_elt.to_external\n (Priority_queue.internal_add\n t.priority_queue\n ~key:(interval_num_unchecked t at)\n ~at\n value)\n;;\n\nlet remove t alarm = Priority_queue.remove t.priority_queue alarm\nlet clear t = Priority_queue.clear t.priority_queue\nlet mem t alarm = Priority_queue.mem t.priority_queue alarm\n\nlet reschedule_gen t alarm ~key ~at =\n if not (mem t alarm)\n then failwith \"Timing_wheel cannot reschedule alarm not in timing wheel\";\n ensure_can_schedule_alarm t ~at;\n Priority_queue.change t.priority_queue alarm ~key ~at\n;;\n\nlet reschedule t alarm ~at =\n reschedule_gen t alarm ~key:(interval_num_unchecked t at) ~at\n;;\n\nlet reschedule_at_interval_num t alarm ~at =\n reschedule_gen t alarm ~key:at ~at:(interval_num_start t at)\n;;\n\nlet pool t = Priority_queue.pool t.priority_queue\n\nlet min_alarm_interval_num t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt then None else Some (Internal_elt.key (pool t) elt)\n;;\n\nlet min_alarm_interval_num_exn t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt\n then\n raise_s\n [%message\n \"Timing_wheel.min_alarm_interval_num_exn of empty timing_wheel\"\n ~timing_wheel:(t : _ t)]\n else Internal_elt.key (pool t) elt\n;;\n\nlet max_alarm_time_in_list t elt =\n let pool = pool t in\n Internal_elt.max_alarm_time pool elt ~with_key:(Internal_elt.key pool elt)\n;;\n\nlet max_alarm_time_in_min_interval t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt then None else Some (max_alarm_time_in_list t elt)\n;;\n\nlet max_alarm_time_in_min_interval_exn t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt\n then\n raise_s\n [%message\n \"Timing_wheel.max_alarm_time_in_min_interval_exn of empty timing wheel\"\n ~timing_wheel:(t : _ t)];\n max_alarm_time_in_list t elt\n;;\n\nlet next_alarm_fires_at_internal t key =\n (* [interval_num_start t key] is the key corresponding to the start of the time interval\n holding the first alarm in [t]. Advancing to that would not be enough, since the\n alarms in that interval don't fire until the clock is advanced to the start of the\n next interval. So, we use [succ key] to advance to the start of the next\n interval. *)\n interval_num_start t (Key.succ key)\n;;\n\nlet next_alarm_fires_at t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt\n then None\n else (\n let key = Internal_elt.key (pool t) elt in\n if Interval_num.equal key t.max_interval_num\n then None\n else Some (next_alarm_fires_at_internal t key))\n;;\n\nlet[@cold] raise_next_alarm_fires_at_exn_of_empty_timing_wheel t =\n raise_s\n [%message\n \"Timing_wheel.next_alarm_fires_at_exn of empty timing wheel\"\n ~timing_wheel:(t : _ t)]\n;;\n\nlet[@cold] raise_next_alarm_fires_at_with_all_alarms_in_max_interval t =\n raise_s\n [%message\n \"Timing_wheel.next_alarm_fires_at_exn with all alarms in max interval\"\n ~timing_wheel:(t : _ t)]\n;;\n\nlet next_alarm_fires_at_exn t =\n let elt = Priority_queue.min_elt_ t.priority_queue in\n if Internal_elt.is_null elt then raise_next_alarm_fires_at_exn_of_empty_timing_wheel t;\n let key = Internal_elt.key (pool t) elt in\n if Interval_num.equal key t.max_interval_num\n then raise_next_alarm_fires_at_with_all_alarms_in_max_interval t;\n next_alarm_fires_at_internal t key\n;;\n\nlet fire_past_alarms t ~handle_fired =\n Priority_queue.fire_past_alarms\n t.priority_queue\n ~handle_fired\n ~key:(now_interval_num t)\n ~now:t.now\n;;\n\nmodule Private = struct\n module Num_key_bits = Num_key_bits\n\n let interval_num_internal = interval_num_internal\n let max_time = max_time\nend\n","module Inria_sys = Sys\nmodule Time_ns_in_this_directory = Time_ns\nopen Core_kernel\nopen Poly\nmodule Time_ns = Time_ns_in_this_directory\n\nlet sec = Time_ns.Span.of_sec\nlet concat = String.concat\n\nmodule Epoll_max_ready_events = Validated.Make (struct\n include Int\n\n let here = [%here]\n let validate = Int.validate_positive\n end)\n\nmodule Max_inter_cycle_timeout = Validated.Make (struct\n include Time_ns.Span\n\n let here = [%here]\n let validate = Time_ns.Span.validate_non_negative\n end)\n\nmodule Min_inter_cycle_timeout = Validated.Make (struct\n include Time_ns.Span\n\n let here = [%here]\n let validate = Time_ns.Span.validate_non_negative\n end)\n\nmodule Max_num_open_file_descrs = struct\n include Validated.Make (struct\n include Int\n\n let here = [%here]\n let validate = Int.validate_positive\n end)\n\n let default = create_exn (1 lsl 16)\n let equal (t1 : t) t2 = t1 = t2\nend\n\nmodule Max_num_threads = Validated.Make (struct\n include Int\n\n let here = [%here]\n let validate = Int.validate_positive\n end)\n\nmodule Max_num_jobs_per_priority_per_cycle = Validated.Make (struct\n include Int\n\n let here = [%here]\n let validate = Int.validate_positive\n end)\n\nmodule Dump_core_on_job_delay = struct\n module How_to_dump = struct\n type t =\n | Default\n | Call_abort\n | Call_gcore\n [@@deriving sexp]\n end\n\n type watch =\n { dump_if_delayed_by : Time_ns.Span.t\n ; how_to_dump : How_to_dump.t\n }\n [@@deriving sexp]\n\n type t =\n | Watch of watch\n | Do_not_watch\n [@@deriving sexp]\nend\n\nmodule Debug_tag = struct\n module T = struct\n type t =\n | All\n | Clock\n | Fd\n | File_descr_watcher\n | Finalizers\n | Interruptor\n | Monitor\n | Monitor_send_exn\n | Parallel\n | Reader\n | Scheduler\n | Shutdown\n | Thread_pool\n | Thread_safe\n | Writer\n [@@deriving compare, sexp]\n\n let equal = [%compare.equal: t]\n end\n\n include T\n include Sexpable.To_stringable (T)\n\n let list =\n [ All\n ; Clock\n ; Fd\n ; File_descr_watcher\n ; Finalizers\n ; Interruptor\n ; Monitor\n ; Monitor_send_exn\n ; Parallel\n ; Reader\n ; Scheduler\n ; Shutdown\n ; Thread_pool\n ; Thread_safe\n ; Writer\n ]\n ;;\nend\n\nmodule File_descr_watcher = struct\n module T = struct\n type t =\n | Epoll_if_timerfd\n | Epoll\n | Select\n [@@deriving sexp]\n end\n\n include T\n include Sexpable.To_stringable (T)\n\n let list = [ Epoll_if_timerfd; Epoll; Select ]\nend\n\ntype t =\n { abort_after_thread_pool_stuck_for : Time_ns.Span.t option [@sexp.option]\n ; check_invariants : bool option [@sexp.option]\n ; detect_invalid_access_from_thread : bool option [@sexp.option]\n ; dump_core_on_job_delay : Dump_core_on_job_delay.t option [@sexp.option]\n ; epoll_max_ready_events : Epoll_max_ready_events.t option [@sexp.option]\n ; file_descr_watcher : File_descr_watcher.t option [@sexp.option]\n ; max_inter_cycle_timeout : Max_inter_cycle_timeout.t option [@sexp.option]\n ; max_num_open_file_descrs : Max_num_open_file_descrs.t option [@sexp.option]\n ; max_num_threads : Max_num_threads.t option [@sexp.option]\n ; max_num_jobs_per_priority_per_cycle : Max_num_jobs_per_priority_per_cycle.t option\n [@sexp.option]\n ; min_inter_cycle_timeout : Min_inter_cycle_timeout.t option [@sexp.option]\n ; print_debug_messages_for : Debug_tag.t list option [@sexp.option]\n ; record_backtraces : bool option [@sexp.option]\n ; report_thread_pool_stuck_for : Time_ns.Span.t option [@sexp.option]\n ; thread_pool_cpu_affinity : Thread_pool_cpu_affinity.t option [@sexp.option]\n ; timing_wheel_config : Timing_wheel.Config.t option [@sexp.option]\n }\n[@@deriving fields, sexp]\n\nlet empty =\n { abort_after_thread_pool_stuck_for = None\n ; check_invariants = None\n ; detect_invalid_access_from_thread = None\n ; dump_core_on_job_delay = None\n ; epoll_max_ready_events = None\n ; file_descr_watcher = None\n ; max_inter_cycle_timeout = None\n ; max_num_open_file_descrs = None\n ; max_num_threads = None\n ; max_num_jobs_per_priority_per_cycle = None\n ; min_inter_cycle_timeout = None\n ; print_debug_messages_for = None\n ; record_backtraces = None\n ; report_thread_pool_stuck_for = None\n ; thread_pool_cpu_affinity = None\n ; timing_wheel_config = None\n }\n;;\n\nlet default_timing_wheel_config_for_word_size (word_size : Word_size.t) =\n let module Alarm_precision = Timing_wheel.Alarm_precision in\n let alarm_precision, level_bits =\n match word_size with\n | W32 -> Alarm_precision.about_one_millisecond, [ 10; 10; 9 ]\n | W64 -> Alarm_precision.(div about_one_millisecond ~pow2:3), [ 14; 15; 9; 6 ]\n in\n Timing_wheel.Config.create\n ~alarm_precision\n ~level_bits:(Timing_wheel.Level_bits.create_exn level_bits)\n ()\n;;\n\nlet default_timing_wheel_config =\n default_timing_wheel_config_for_word_size Word_size.word_size\n;;\n\nlet default =\n (* For [file_descr_watcher] and [max_num_open_file_descrs] we choose the default for the\n common case that [epoll] is available. There is some additional code in\n [Async_unix.Config] that checks whether [epoll] is actually available, and if not,\n uses [select] and a smaller number of file descriptors. *)\n { abort_after_thread_pool_stuck_for = Some (sec 60.)\n ; check_invariants = Some false\n ; detect_invalid_access_from_thread = Some false\n ; dump_core_on_job_delay = Some Do_not_watch\n ; epoll_max_ready_events = Some (Epoll_max_ready_events.create_exn 256)\n ; file_descr_watcher = Some Epoll_if_timerfd\n ; max_inter_cycle_timeout = Some (Max_inter_cycle_timeout.create_exn (sec 0.05))\n ; max_num_open_file_descrs = Some Max_num_open_file_descrs.default\n ; max_num_threads = Some (Max_num_threads.create_exn 50)\n ; max_num_jobs_per_priority_per_cycle =\n Some (Max_num_jobs_per_priority_per_cycle.create_exn 500)\n ; min_inter_cycle_timeout = Some (Min_inter_cycle_timeout.create_exn (sec 0.))\n ; print_debug_messages_for = Some []\n ; record_backtraces = Some false\n ; report_thread_pool_stuck_for = Some (sec 1.)\n ; thread_pool_cpu_affinity = Some Inherit\n ; timing_wheel_config = Some default_timing_wheel_config\n }\n;;\n\nlet example =\n { default with\n print_debug_messages_for = Some Debug_tag.[ Fd; Scheduler ]\n ; thread_pool_cpu_affinity =\n Some\n (Cpuset\n ([ 0; 1; 2 ] |> Int.Set.of_list |> Thread_pool_cpu_affinity.Cpuset.create_exn))\n }\n;;\n\nlet environment_variable = \"ASYNC_CONFIG\"\n\nlet field_descriptions () : string =\n let field to_sexp description ac field =\n (Field.name field, to_sexp (Option.value_exn (Field.get field default)), description)\n :: ac\n in\n let fields =\n Fields.fold\n ~init:[]\n ~abort_after_thread_pool_stuck_for:\n (field\n [%sexp_of: Time_ns.Span.t]\n [ {|\n By default, Async will send an exception to the toplevel monitor\n if it detects that the thread pool is stuck for longer than this.\n|}\n ])\n ~check_invariants:\n (field\n [%sexp_of: bool]\n [ {|\n If true, causes Async to regularly check invariants of its internal\n data structures. This can substantially slow down your program.\n|}\n ])\n ~detect_invalid_access_from_thread:\n (field\n [%sexp_of: bool]\n [ {|\n If true, causes Async routines to check if they are being accessed\n from some thread other than the thread currently holding the Async\n lock, which is not allowed and can lead to very confusing behavior.\n|}\n ])\n ~dump_core_on_job_delay:\n (field\n [%sexp_of: Dump_core_on_job_delay.t]\n [ {|\n Can be set to [Do_not_watch] or:\n\n (Watch ((dump_if_delayed_by SPAN) (how_to_dump HOW)))\n\n If set to [Watch], then on program start this will start a regular\n Async job that increments a counter, and a C thread that will\n detect if that job is delayed by [dump_if_delayed_by], and if so,\n will core dump the program. If available, [/usr/bin/gcore] is\n used by default to dump the core, which should allow the program\n to continue running. Otherwise, [abort] will be called from C,\n which will kill the program while causing a core dump. One can\n force [abort] or [gcore] via [how_to_dump], which should be one of:\n [Call_abort], [Call_gcore], or [Default].\n|}\n ])\n ~epoll_max_ready_events:\n (field\n [%sexp_of: Epoll_max_ready_events.t]\n [ {|\n The maximum number of ready events that Async's call to [Epoll.wait]\n will handle.\n|}\n ])\n ~file_descr_watcher:\n (field\n [%sexp_of: File_descr_watcher.t]\n [ {|\n This determines what OS subsystem Async uses to watch file descriptors for being ready.\n The default is to use [epoll] if timerfd's are supported and if not, use [select].\n\n Allowed values are:|}\n ; concat\n ~sep:\", \"\n (List.map File_descr_watcher.list ~f:File_descr_watcher.to_string)\n ; {|.\n|}\n ])\n ~max_num_open_file_descrs:\n (field\n (fun default ->\n [%message\n \"\"\n ~_:\n (concat\n [ \"min \"\n ; default |> Max_num_open_file_descrs.raw |> Int.to_string_hum\n ; \" [ulimit -n -H]\"\n ]\n : string)])\n [ {|\n The maximum number of open file descriptors allowed at any one time.|} ])\n ~max_num_threads:\n (field\n [%sexp_of: Max_num_threads.t]\n [ {|\n The maximum number of threads that Async will create to do blocking\n system calls and handle calls to [In_thread.run].\n|}\n ])\n ~max_inter_cycle_timeout:\n (field\n [%sexp_of: Max_inter_cycle_timeout.t]\n [ {|\n The maximum amount of time the scheduler will pause between cycles\n when it has no jobs and is going to wait for I/O. In principle one\n doesn't need this, and we could use an infinite timeout. We instead\n use a small timeout (by default), to be more robust to bugs that\n could prevent Async from waking up and servicing events. For\n example, as of 2013-01, the OCaml runtime has a bug that causes it\n to not necessarily run an OCaml signal handler in a timely manner.\n This in turn can cause a simple Async program that is waiting on a\n signal to hang, when in fact it should handle the signal.\n\n We use 50ms as the default timeout, because it is infrequent enough\n to have a negligible performance impact, and frequent enough that\n the latency would typically be not noticeable. Also, 50ms is what\n the OCaml ticker thread uses.\n|}\n ])\n ~max_num_jobs_per_priority_per_cycle:\n (field\n [%sexp_of: Max_num_jobs_per_priority_per_cycle.t]\n [ {|\n The maximum number of jobs that will be done at each priority within\n each Async cycle. This limits how many jobs the scheduler will run\n before pausing to check for I/O.\n|}\n ])\n ~min_inter_cycle_timeout:\n (field\n [%sexp_of: Min_inter_cycle_timeout.t]\n [ {|\n The minimum timeout the scheduler will pass to the OS when it checks\n for I/O between cycles. This is zero by default. Setting it to a\n nonzero value is used to increase thread fairness between the scheduler\n and other threads. A plausible setting is 1us. This is also\n configurable in OCaml via [Scheduler.set_min_inter_cycle_timeout].\n|}\n ])\n ~print_debug_messages_for:\n (field\n [%sexp_of: Debug_tag.t list]\n [ {|\n A list of tags specifying which Async functions should print debug\n messages to stderr. Each tag identifies a group of related Async\n functions. The tag [all] means to print debug messages for all\n functions. Allowed values are:\n\n|}\n ; concat\n (List.map Debug_tag.list ~f:(fun d ->\n concat [ \" \"; Debug_tag.to_string d; \"\\n\" ]))\n ; {|\n Turning on debug messages will substantially slow down most programs.\n|}\n ])\n ~record_backtraces:\n (field\n [%sexp_of: bool]\n [ {|\n If true, this will cause Async to keep in the execution context the\n history of stack backtraces (obtained via [Backtrace.get]) that led\n to the current job. If an Async job has an unhandled exception,\n this backtrace history will be recorded in the exception. In\n particular the history will appear in an unhandled exception that\n reaches the main monitor. This can have a substantial performance\n impact, both in running time and space usage.\n|}\n ])\n ~report_thread_pool_stuck_for:\n (field\n [%sexp_of: Time_ns.Span.t]\n [ {|\n By default, Async will print a message to stderr every second if\n the thread pool is stuck for longer than this.\n|}\n ])\n ~thread_pool_cpu_affinity:\n (field\n [%sexp_of: Thread_pool_cpu_affinity.t]\n [ {|\n Whether and how threads in the thread pool should be affinitized to CPUs.\n|}\n ])\n ~timing_wheel_config:\n (field\n [%sexp_of: Timing_wheel.Config.t]\n [ {|\n This is used to adjust the time/space tradeoff in the timing wheel\n used to implement Async's clock. Time is split into intervals of\n size [alarm_precision], and alarms with times in the same interval\n fire in the same cycle. Level [i] in the timing wheel has an\n array of size [2^b], where [b] is the [i]'th entry in [level_bits].\n|}\n ])\n in\n concat\n (List.map\n (List.sort fields ~compare:(fun (name1, _, _) (name2, _, _) ->\n String.compare name1 name2))\n ~f:(fun (name, default, description) ->\n concat\n (\"\\n\" :: name :: \" (default \" :: Sexp.to_string default :: \")\" :: description)))\n;;\n\nlet help_message () =\n concat\n [ \"The \"\n ; environment_variable\n ; {| environment variable affects Async\nin various ways. Its value should be a sexp of the following form,\nwhere all fields are optional:\n\n|}\n ; Sexp.to_string_hum (sexp_of_t example)\n ; {|\n\nHere is an explanation of each field.\n|}\n ; field_descriptions ()\n ]\n;;\n\nlet usage () =\n eprintf \"%s%!\" (help_message ());\n exit 1\n;;\n\nlet t =\n match Option.try_with (fun () -> Inria_sys.getenv environment_variable) with\n | None -> empty\n | Some \"\" -> usage ()\n | Some string ->\n (match Result.try_with (fun () -> t_of_sexp (Sexp.of_string string)) with\n | Ok t -> t\n | Error exn ->\n eprintf\n \"%s\\n\\n\"\n (Sexp.to_string_hum\n (Error.sexp_of_t\n (Error.create\n (sprintf\n \"invalid value for %s environment variable\"\n environment_variable)\n exn\n [%sexp_of: exn])));\n usage ())\n;;\n\nmodule Print_debug_messages_for = struct\n let print_debug_messages_for tag =\n match t.print_debug_messages_for with\n | None -> false\n | Some l -> List.mem l tag ~equal:Debug_tag.equal\n ;;\n\n let all = print_debug_messages_for All\n let debug tag = all || print_debug_messages_for tag\n let clock = debug Clock\n let fd = debug Fd\n let file_descr_watcher = debug File_descr_watcher\n let finalizers = debug Finalizers\n let interruptor = debug Interruptor\n let monitor = debug Monitor\n let monitor_send_exn = debug Monitor_send_exn\n let parallel = debug Parallel\n let reader = debug Reader\n let scheduler = debug Scheduler\n let shutdown = debug Shutdown\n let thread_pool = debug Thread_pool\n let thread_safe = debug Thread_safe\n let writer = debug Writer\nend\n\nlet ( !! ) field =\n Option.value (Field.get field t) ~default:(Option.value_exn (Field.get field default))\n;;\n\nlet abort_after_thread_pool_stuck_for = !!Fields.abort_after_thread_pool_stuck_for\nlet check_invariants = !!Fields.check_invariants\nlet detect_invalid_access_from_thread = !!Fields.detect_invalid_access_from_thread\nlet epoll_max_ready_events = !!Fields.epoll_max_ready_events\nlet thread_pool_cpu_affinity = !!Fields.thread_pool_cpu_affinity\nlet file_descr_watcher = !!Fields.file_descr_watcher\nlet max_inter_cycle_timeout = !!Fields.max_inter_cycle_timeout\nlet max_num_open_file_descrs = !!Fields.max_num_open_file_descrs\nlet max_num_threads = !!Fields.max_num_threads\nlet max_num_jobs_per_priority_per_cycle = !!Fields.max_num_jobs_per_priority_per_cycle\nlet min_inter_cycle_timeout = !!Fields.min_inter_cycle_timeout\nlet record_backtraces = !!Fields.record_backtraces\nlet report_thread_pool_stuck_for = !!Fields.report_thread_pool_stuck_for\nlet timing_wheel_config = !!Fields.timing_wheel_config\nlet dump_core_on_job_delay = !!Fields.dump_core_on_job_delay\n\nlet t =\n { abort_after_thread_pool_stuck_for = Some abort_after_thread_pool_stuck_for\n ; check_invariants = Some check_invariants\n ; detect_invalid_access_from_thread = Some detect_invalid_access_from_thread\n ; dump_core_on_job_delay = Some dump_core_on_job_delay\n ; thread_pool_cpu_affinity = Some thread_pool_cpu_affinity\n ; epoll_max_ready_events = Some epoll_max_ready_events\n ; file_descr_watcher = Some file_descr_watcher\n ; max_inter_cycle_timeout = Some max_inter_cycle_timeout\n ; max_num_open_file_descrs = Some max_num_open_file_descrs\n ; max_num_threads = Some max_num_threads\n ; max_num_jobs_per_priority_per_cycle = Some max_num_jobs_per_priority_per_cycle\n ; min_inter_cycle_timeout = Some min_inter_cycle_timeout\n ; print_debug_messages_for = t.print_debug_messages_for\n ; record_backtraces = Some record_backtraces\n ; report_thread_pool_stuck_for = Some report_thread_pool_stuck_for\n ; timing_wheel_config = Some timing_wheel_config\n }\n;;\n\nlet task_id = ref (fun () -> Sexp.Atom \"\")\n","open Core_kernel\nopen Import\nopen Deferred_std\nmodule Deferred = Deferred1\nmodule Scheduler = Scheduler1\nmodule Stream = Tail.Stream\nmodule Monitor = Monitor0\ninclude Monitor\n\ntype monitor = t [@@deriving sexp_of]\n\nlet invariant t =\n Invariant.invariant [%here] t [%sexp_of: t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~name:ignore\n ~here:ignore\n ~id:ignore\n ~parent:ignore\n ~next_error:(check (fun next_error -> assert (Ivar.is_empty next_error)))\n ~handlers_for_all_errors:ignore\n ~tails_for_all_errors:ignore\n ~has_seen_error:ignore\n ~is_detached:ignore)\n;;\n\nlet current_execution_context () = Scheduler.(current_execution_context (t ()))\nlet current () = Execution_context.monitor (current_execution_context ())\n\nlet depth t =\n let rec loop t n =\n match t.parent with\n | None -> n\n | Some t -> loop t (n + 1)\n in\n loop t 0\n;;\n\ntype 'a with_optional_monitor_name =\n ?here:Source_code_position.t -> ?info:Info.t -> ?name:string -> 'a\n\nlet detach t = t.is_detached <- true\n\ntype handler_state =\n | Uninitialized\n | Running of (Execution_context.t * (exn -> unit)) Bag.Elt.t\n | Terminated\n\nlet detach_and_iter_errors t ~f =\n detach t;\n let scheduler = Scheduler.t () in\n let execution_context = Scheduler.current_execution_context scheduler in\n let handler_state_ref = ref Uninitialized in\n let run_f exn =\n match !handler_state_ref with\n | Uninitialized -> assert false\n | Terminated -> ()\n | Running bag_elt ->\n (try f exn with\n | inner_exn ->\n handler_state_ref := Terminated;\n Bag.remove t.handlers_for_all_errors bag_elt;\n (* [run_f] always runs in [execution_context]. Hence, [raise inner_exn] sends\n [inner_exn] to [execution_context]'s monitor, i.e. the monitor in effect when\n [detach_and_iter_errors] was called. *)\n raise inner_exn)\n in\n handler_state_ref\n := Running (Bag.add t.handlers_for_all_errors (execution_context, run_f))\n;;\n\nlet detach_and_get_error_stream t =\n detach t;\n let tail = Tail.create () in\n t.tails_for_all_errors <- tail :: t.tails_for_all_errors;\n Tail.collect tail\n;;\n\nlet get_next_error t = Ivar.read t.next_error\n\nlet detach_and_get_next_error t =\n detach t;\n get_next_error t\n;;\n\nlet create ?here ?info ?name () =\n let parent = current () in\n create_with_parent ?here ?info ?name (Some parent)\n;;\n\nmodule Exn_for_monitor = struct\n type t =\n { exn : exn\n ; backtrace : Backtrace.t option\n ; backtrace_history : Backtrace.t list\n ; monitor : Monitor.t\n }\n\n let backtrace_truncation_heuristics =\n let job_queue = \"Called from file \\\"job_queue.ml\\\"\" in\n let deferred0 = \"Called from file \\\"deferred0.ml\\\"\" in\n let deferred1 = \"Called from file \\\"deferred1.ml\\\"\" in\n let monitor = \"Called from file \\\"monitor.ml\\\"\" in\n let import0 = \"Raised at file \\\"import0.ml\\\"\" in\n let error = \"Called from file \\\"error.ml\\\"\" in\n fun traces ->\n (* ../test/test_try_with_error_display.ml makes sure this stays up-to-date. *)\n let traces =\n match traces with\n | t1 :: rest when String.is_prefix t1 ~prefix:import0 ->\n (match rest with\n | t2 :: rest when String.is_prefix t2 ~prefix:error ->\n (match rest with\n | t3 :: rest when String.is_prefix t3 ~prefix:error -> rest\n | _ -> rest)\n | _ -> rest)\n | _ -> traces\n in\n match List.rev traces with\n | t1 :: rest when String.is_prefix t1 ~prefix:job_queue ->\n (match rest with\n | t2 :: rest when String.is_prefix t2 ~prefix:job_queue ->\n (match rest with\n | t2 :: rest\n when String.is_prefix t2 ~prefix:deferred0\n (* bind *)\n || String.is_prefix t2 ~prefix:deferred1\n (* map *)\n || String.is_prefix t2 ~prefix:monitor\n (* try_with *) -> List.rev rest\n | _ -> List.rev rest)\n | _ -> List.rev rest)\n | _ -> traces\n ;;\n\n let sexp_of_t { exn; backtrace; backtrace_history; monitor } =\n let monitor =\n let name =\n match Info.to_string_hum monitor.name with\n | \"\" -> None\n | s -> Some s\n in\n let pos =\n match monitor.here with\n | None -> None\n | Some here ->\n (* We display the full filename, whereas backtraces only have basenames, but\n perhaps that's what should change. *)\n let column = here.pos_cnum - here.pos_bol in\n Some\n (sprintf\n \"file %S, line %d, characters %d-%d\"\n here.pos_fname\n here.pos_lnum\n column\n column)\n in\n match pos, name with\n | None, None -> []\n | Some pos, None -> [ sprintf \"Caught by monitor at %s\" pos ]\n | None, Some name -> [ sprintf \"Caught by monitor %s\" name ]\n | Some pos, Some name -> [ sprintf \"Caught by monitor %s at %s\" name pos ]\n in\n let backtrace =\n let backtrace =\n match backtrace with\n | None -> []\n | Some backtrace -> Backtrace.to_string_list backtrace\n in\n backtrace_truncation_heuristics backtrace @ monitor\n in\n let list_if_not_empty = function\n | [] -> None\n | _ :: _ as l -> Some l\n in\n [%sexp\n (exn : exn)\n , (list_if_not_empty backtrace : (string list option[@sexp.option]))\n , `backtrace_history\n (list_if_not_empty backtrace_history : (Backtrace.t list option[@sexp.option]))]\n ;;\nend\n\nexception Error_ of Exn_for_monitor.t\n\nlet () =\n Sexplib.Conv.Exn_converter.add [%extension_constructor Error_] (function\n | Error_ t -> [%sexp \"monitor.ml.Error\" :: (t : Exn_for_monitor.t)]\n | _ ->\n (* Reaching this branch indicates a bug in sexplib. *)\n assert false)\n;;\n\nlet extract_exn exn =\n match exn with\n | Error_ error -> error.exn\n | exn -> exn\n;;\n\nlet send_exn t ?backtrace exn =\n let exn =\n match exn with\n | Error_ _ -> exn\n | _ ->\n let backtrace =\n match backtrace with\n | None -> None\n | Some `Get -> Some (Backtrace.Exn.most_recent ())\n | Some (`This b) -> Some b\n in\n let backtrace_history = (current_execution_context ()).backtrace_history in\n Error_ { Exn_for_monitor.exn; backtrace; backtrace_history; monitor = t }\n in\n if Debug.monitor_send_exn\n then Debug.log \"Monitor.send_exn\" (t, exn) [%sexp_of: t * exn];\n t.has_seen_error <- true;\n let scheduler = Scheduler.t () in\n let rec loop t =\n Ivar.fill t.next_error exn;\n t.next_error <- Ivar.create ();\n if t.is_detached\n then (\n if Debug.monitor_send_exn\n then\n Debug.log \"Monitor.send_exn found listening monitor\" (t, exn) [%sexp_of: t * exn];\n Bag.iter t.handlers_for_all_errors ~f:(fun (execution_context, f) ->\n Scheduler.enqueue scheduler execution_context f exn);\n List.iter t.tails_for_all_errors ~f:(fun tail -> Tail.extend tail exn))\n else (\n match t.parent with\n | Some t' -> loop t'\n | None ->\n (* Do not change this branch to print the exception or to exit. Having the\n scheduler raise an uncaught exception is the necessary behavior for programs\n that call [Scheduler.go] and want to handle it. *)\n Scheduler.(got_uncaught_exn (t ())) exn (!Async_kernel_config.task_id ()))\n in\n loop t\n;;\n\nmodule Exported_for_scheduler = struct\n let within_context context f =\n Scheduler.(with_execution_context (t ())) context ~f:(fun () ->\n match Result.try_with f with\n | Ok x -> Ok x\n | Error exn ->\n send_exn (Execution_context.monitor context) exn ~backtrace:`Get;\n Error ())\n ;;\n\n type 'a with_options = ?monitor:t -> ?priority:Priority.t -> 'a\n\n let within_gen ?monitor ?priority f =\n let tmp_context =\n Execution_context.create_like (current_execution_context ()) ?monitor ?priority\n in\n within_context tmp_context f\n ;;\n\n let within' ?monitor ?priority f =\n match within_gen ?monitor ?priority f with\n | Error () -> Deferred.never ()\n | Ok d -> d\n ;;\n\n let within_v ?monitor ?priority f =\n match within_gen ?monitor ?priority f with\n | Error () -> None\n | Ok x -> Some x\n ;;\n\n let within ?monitor ?priority f =\n match within_gen ?monitor ?priority f with\n | Error () -> ()\n | Ok () -> ()\n ;;\n\n let schedule_with_data ?monitor ?priority work x =\n let scheduler = Scheduler.t () in\n Scheduler.enqueue\n scheduler\n (Execution_context.create_like\n (Scheduler.current_execution_context scheduler)\n ?monitor\n ?priority)\n work\n x\n ;;\n\n let schedule ?monitor ?priority work = schedule_with_data ?monitor ?priority work ()\n\n let schedule' =\n (* For performance, we use [schedule_with_data] with a closed function, and inline\n [Deferred.create]. *)\n let upon_work_fill_i (work, i) = upon (work ()) (fun a -> Ivar.fill i a) in\n fun ?monitor ?priority work ->\n let i = Ivar.create () in\n schedule_with_data ?monitor ?priority upon_work_fill_i (work, i);\n Ivar.read i\n ;;\n\n let preserve_execution_context f =\n let scheduler = Scheduler.t () in\n let execution_context = Scheduler.current_execution_context scheduler in\n stage (fun a -> Scheduler.enqueue scheduler execution_context f a)\n ;;\n\n let preserve_execution_context' f =\n let scheduler = Scheduler.t () in\n let execution_context = Scheduler.current_execution_context scheduler in\n let call_and_fill (f, a, i) = upon (f a) (fun r -> Ivar.fill i r) in\n stage (fun a ->\n Deferred.create (fun i ->\n Scheduler.enqueue scheduler execution_context call_and_fill (f, a, i)))\n ;;\nend\n\nopen Exported_for_scheduler\n\nlet stream_iter stream ~f =\n let rec loop stream =\n Stream.next stream\n >>> function\n | Nil -> ()\n | Cons (v, stream) ->\n loop stream;\n f v\n in\n loop stream\n;;\n\n(* An ['a Ok_and_exns.t] represents the output of a computation running in a detached\n monitor. *)\nmodule Ok_and_exns = struct\n type 'a t =\n { ok : 'a Deferred.t\n ; exns : exn Stream.t\n }\n [@@deriving fields, sexp_of]\n\n let create ?here ?info ?name ~run f =\n (* We call [create_with_parent None] because [monitor] does not need a parent. It\n does not because we call [detach_and_get_error_stream monitor] and deal with the\n errors explicitly, thus [send_exn] would never propagate an exn past [monitor]. *)\n let monitor = create_with_parent ?here ?info ?name None in\n let exns = detach_and_get_error_stream monitor in\n let ok =\n match run with\n | `Now -> within' ~monitor f\n | `Schedule -> schedule' ~monitor f\n in\n { ok; exns }\n ;;\nend\n\nlet fill_result_and_handle_background_errors\n result_filler\n result\n exns\n handle_exns_after_result\n =\n if Ivar_filler.is_empty result_filler\n then (\n Ivar_filler.fill result_filler result;\n handle_exns_after_result exns)\n;;\n\nmodule Expert = struct\n let try_with_log_exn : (exn -> unit) ref =\n ref (fun exn ->\n raise_s\n [%message \"failed to set [Monitor.Expert.try_with_log_exn]\" (exn : Exn.t)])\n ;;\nend\n\nlet make_handle_exn rest =\n match rest with\n | `Log ->\n (* We are careful to not close over current context, which is not needed. *)\n !Expert.try_with_log_exn\n | `Raise ->\n let parent = current () in\n fun exn -> send_exn parent exn ?backtrace:None\n | `Call f ->\n let parent = current () in\n fun exn -> within ~monitor:parent (fun () -> f exn)\n;;\n\nlet try_with\n ?here\n ?info\n ?(name = \"\")\n ?extract_exn:(do_extract_exn = false)\n ?(run = `Schedule)\n ?(rest = `Log)\n f\n =\n let { Ok_and_exns.ok; exns } = Ok_and_exns.create ?here ?info ~name ~run f in\n let handle_exn = make_handle_exn rest in\n let handle_exns_after_result exns = stream_iter exns ~f:handle_exn in\n (* We run [within' ~monitor:main] to avoid holding on to references to the evaluation\n context in which [try_with] was called. This avoids a space leak when a chain of\n [try_with]'s are run each nested within the previous one. Without the [within'], the\n error handling for the innermost [try_with] would keep alive the entire chain. *)\n within' ~monitor:main (fun () ->\n if Deferred.is_determined ok\n then (\n handle_exns_after_result exns;\n return (Ok (Deferred.value_exn ok)))\n else (\n let result_filler, result = Ivar_filler.create () in\n upon ok (fun res ->\n fill_result_and_handle_background_errors\n result_filler\n (Ok res)\n exns\n handle_exns_after_result);\n upon (Stream.next exns) (function\n | Nil -> assert false\n | Cons (exn, exns) ->\n let exn = if do_extract_exn then extract_exn exn else exn in\n fill_result_and_handle_background_errors\n result_filler\n (Error exn)\n exns\n handle_exns_after_result);\n result))\n;;\n\nlet try_with_or_error ?here ?info ?(name = \"try_with_or_error\") ?extract_exn f =\n try_with f ?here ?info ~name ?extract_exn ~run:`Now ~rest:`Log\n >>| Or_error.of_exn_result\n;;\n\nlet try_with_join_or_error ?here ?info ?(name = \"try_with_join_or_error\") ?extract_exn f =\n try_with_or_error f ?here ?info ~name ?extract_exn >>| Or_error.join\n;;\n\nlet protect ?here ?info ?(name = \"Monitor.protect\") ?extract_exn ?run f ~finally =\n let%bind r = try_with ?extract_exn ?here ?info ?run ~name f in\n let%map fr = try_with ~extract_exn:false ?here ?info ~name:\"finally\" finally in\n match r, fr with\n | Error exn, Error finally_exn ->\n raise_s [%message \"Async finally\" (exn : exn) (finally_exn : exn)]\n | Error e, Ok () | Ok _, Error e -> raise e\n | Ok r, Ok () -> r\n;;\n\nlet handle_errors ?here ?info ?name f handler =\n let { Ok_and_exns.ok; exns } = Ok_and_exns.create ?here ?info ?name ~run:`Now f in\n stream_iter exns ~f:handler;\n ok\n;;\n\nlet catch_stream ?here ?info ?name f =\n let { Ok_and_exns.exns; _ } =\n Ok_and_exns.create ?here ?info ?name ~run:`Now (fun () ->\n f ();\n return ())\n in\n exns\n;;\n\nlet catch ?here ?info ?name f =\n match%map Stream.next (catch_stream ?here ?info ?name f) with\n | Cons (x, _) -> x\n | Nil -> raise_s [%message \"Monitor.catch got unexpected empty stream\"]\n;;\n\nlet catch_error ?here ?info ?name f = catch ?here ?info ?name f >>| Error.of_exn\n","(** Contains Async's core data structures, like {{!Async_kernel.Deferred}[Deferred]},\n {{!Async_kernel.Ivar}[Ivar]}, and {{!Async_kernel.Clock_intf.Clock}[Clock]}.\n\n [Async_kernel] is designed to depend only on {{!Core_kernel}[Core_kernel]} (as opposed\n to {{!Core}[Core]}), and so is more platform-independent. *)\n\nopen! Core_kernel\nopen! Import\nmodule Async_kernel_config = Async_kernel_config\nmodule Async_kernel_require_explicit_time_source = Require_explicit_time_source\nmodule Async_kernel_scheduler = Async_kernel_scheduler\nmodule Bvar = Bvar\nmodule Clock_ns = Clock_ns\nmodule Condition = Async_condition\nmodule Deferred = Deferred\nmodule Execution_context = Execution_context\nmodule Gc = Async_gc\nmodule Invariant = Async_invariant\nmodule Ivar = Ivar\nmodule Lazy_deferred = Lazy_deferred\nmodule Monad_sequence = Monad_sequence\nmodule Monitor = Monitor\nmodule Mvar = Mvar\nmodule Pipe = Pipe\nmodule Priority = Priority\nmodule Sequencer = Throttle.Sequencer\nmodule Stream = Async_stream\nmodule Synchronous_time_source = Synchronous_time_source\nmodule Tail = Tail\nmodule Throttle = Throttle\nmodule Time_source = Time_source\nmodule Tracing = Tracing\n\n(** {2 Toplevel functions }\n\n The functions below are broadly useful when writing Async programs, and so are made\n available at the toplevel. *)\n\nlet after = Clock_ns.after\nlet at = Clock_ns.at\nlet catch = Monitor.catch\nlet choice = Deferred.choice\nlet choose = Deferred.choose\nlet don't_wait_for = Deferred.don't_wait_for\nlet every = Clock_ns.every\nlet never = Deferred.never\nlet schedule = Scheduler.schedule\nlet schedule' = Scheduler.schedule'\nlet try_with = Monitor.try_with\nlet upon = Deferred.upon\nlet with_timeout = Clock_ns.with_timeout\nlet within = Scheduler.within\nlet within' = Scheduler.within'\n\n(** {2 Infix operators and [Let_syntax] support} *)\n\ninclude (Deferred : Monad.Infix with type 'a t := 'a Deferred.t)\n\n(** equivalent to {!Deferred.upon}. *)\nlet ( >>> ) = Deferred.Infix.( >>> )\n\n(** equivalent to {!Deferred.Result.bind}. *)\nlet ( >>=? ) = Deferred.Result.( >>= )\n\n(** equivalent to {!Deferred.Result.map}. *)\nlet ( >>|? ) = Deferred.Result.( >>| )\n\ninclude Deferred.Let_syntax\n\n(**/**)\n\n(** The modules in [Async_kernel_private] are used for constructing and testing Async, and\n should not otherwise be used. *)\nmodule Async_kernel_private = struct\n module Debug = Debug\n module Ivar0 = Ivar0\n module Ivar_filler = Ivar_filler\n module Job = Job\n module Stack_or_counter = Stack_or_counter\nend\n\n(**/**)\n\n(* This test must be in this library, because it requires [return] to be inlined. Moving\n it to another library will cause it to break with [X_LIBRARY_INLINING=false]. *)\nlet%test_unit \"[return ()] does not allocate\" =\n let w1 = Gc.minor_words () in\n ignore (Sys.opaque_identity (return ()) : _ Deferred.t);\n ignore (Sys.opaque_identity (Deferred.return ()) : _ Deferred.t);\n ignore (Sys.opaque_identity (Deferred.Let_syntax.return ()) : _ Deferred.t);\n ignore (Sys.opaque_identity (Deferred.Let_syntax.Let_syntax.return ()) : _ Deferred.t);\n let w2 = Gc.minor_words () in\n [%test_result: int] w2 ~expect:w1\n;;\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nlet failwith fmt = Format.kasprintf failwith fmt\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let lnot = Int32.lognot\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\n\n let ror32 a n = (a lsr n) lor (a lsl (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\n\n let ( lsr ) = Int64.shift_right_logical\n\n let ( lor ) = Int64.logor\n\n let ( asr ) = Int64.shift_right\n\n let ( lxor ) = Int64.logxor\n\n let ( + ) = Int64.add\n\n let rol64 a n = (a lsl n) lor (a lsr (64 - n))\n\n let ror64 a n = (a lsr n) lor (a lsl (64 - n))\nend\n\nmodule type S = sig\n type ctx\n\n type kind = [ `BLAKE2B ]\n\n val init : unit -> ctx\n\n val with_outlen_and_bytes_key : int -> By.t -> int -> int -> ctx\n\n val with_outlen_and_bigstring_key : int -> Bi.t -> int -> int -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\n\n val max_outlen : int\nend\n\nmodule Unsafe : S = struct\n type kind = [ `BLAKE2B ]\n\n type param = {\n digest_length : int;\n key_length : int;\n fanout : int;\n depth : int;\n leaf_length : int32;\n node_offset : int32;\n xof_length : int32;\n node_depth : int;\n inner_length : int;\n reserved : int array;\n salt : int array;\n personal : int array;\n }\n\n type ctx = {\n mutable buflen : int;\n outlen : int;\n mutable last_node : int;\n buf : Bytes.t;\n h : int64 array;\n t : int64 array;\n f : int64 array;\n }\n\n let dup ctx =\n {\n buflen = ctx.buflen;\n outlen = ctx.outlen;\n last_node = ctx.last_node;\n buf = By.copy ctx.buf;\n h = Array.copy ctx.h;\n t = Array.copy ctx.t;\n f = Array.copy ctx.f;\n }\n\n let param_to_bytes param =\n let arr =\n [|\n param.digest_length land 0xFF;\n param.key_length land 0xFF;\n param.fanout land 0xFF;\n param.depth land 0xFF (* store to little-endian *);\n Int32.(to_int ((param.leaf_length lsr 0) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 8) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 16) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 24) land 0xFFl))\n (* store to little-endian *);\n Int32.(to_int ((param.node_offset lsr 0) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 8) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 16) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 24) land 0xFFl))\n (* store to little-endian *);\n Int32.(to_int ((param.xof_length lsr 0) land 0xFFl));\n Int32.(to_int ((param.xof_length lsr 8) land 0xFFl));\n Int32.(to_int ((param.xof_length lsr 16) land 0xFFl));\n Int32.(to_int ((param.xof_length lsr 24) land 0xFFl));\n param.node_depth land 0xFF;\n param.inner_length land 0xFF;\n param.reserved.(0) land 0xFF;\n param.reserved.(1) land 0xFF;\n param.reserved.(2) land 0xFF;\n param.reserved.(3) land 0xFF;\n param.reserved.(4) land 0xFF;\n param.reserved.(5) land 0xFF;\n param.reserved.(6) land 0xFF;\n param.reserved.(7) land 0xFF;\n param.reserved.(8) land 0xFF;\n param.reserved.(9) land 0xFF;\n param.reserved.(10) land 0xFF;\n param.reserved.(11) land 0xFF;\n param.reserved.(12) land 0xFF;\n param.reserved.(13) land 0xFF;\n param.salt.(0) land 0xFF;\n param.salt.(1) land 0xFF;\n param.salt.(2) land 0xFF;\n param.salt.(3) land 0xFF;\n param.salt.(4) land 0xFF;\n param.salt.(5) land 0xFF;\n param.salt.(6) land 0xFF;\n param.salt.(7) land 0xFF;\n param.salt.(8) land 0xFF;\n param.salt.(9) land 0xFF;\n param.salt.(10) land 0xFF;\n param.salt.(11) land 0xFF;\n param.salt.(12) land 0xFF;\n param.salt.(13) land 0xFF;\n param.salt.(14) land 0xFF;\n param.salt.(15) land 0xFF;\n param.personal.(0) land 0xFF;\n param.personal.(1) land 0xFF;\n param.personal.(2) land 0xFF;\n param.personal.(3) land 0xFF;\n param.personal.(4) land 0xFF;\n param.personal.(5) land 0xFF;\n param.personal.(6) land 0xFF;\n param.personal.(7) land 0xFF;\n param.personal.(8) land 0xFF;\n param.personal.(9) land 0xFF;\n param.personal.(10) land 0xFF;\n param.personal.(11) land 0xFF;\n param.personal.(12) land 0xFF;\n param.personal.(13) land 0xFF;\n param.personal.(14) land 0xFF;\n param.personal.(15) land 0xFF;\n |] in\n By.init 64 (fun i -> Char.unsafe_chr arr.(i))\n\n let max_outlen = 64\n\n let default_param =\n {\n digest_length = max_outlen;\n key_length = 0;\n fanout = 1;\n depth = 1;\n leaf_length = 0l;\n node_offset = 0l;\n xof_length = 0l;\n node_depth = 0;\n inner_length = 0;\n reserved = [| 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0 |];\n salt = [| 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0 |];\n personal = [| 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0; 0 |];\n }\n\n let iv =\n [|\n 0x6a09e667f3bcc908L;\n 0xbb67ae8584caa73bL;\n 0x3c6ef372fe94f82bL;\n 0xa54ff53a5f1d36f1L;\n 0x510e527fade682d1L;\n 0x9b05688c2b3e6c1fL;\n 0x1f83d9abfb41bd6bL;\n 0x5be0cd19137e2179L;\n |]\n\n let increment_counter ctx inc =\n let open Int64 in\n ctx.t.(0) <- ctx.t.(0) + inc ;\n ctx.t.(1) <- (ctx.t.(1) + if ctx.t.(0) < inc then 1L else 0L)\n\n let set_lastnode ctx = ctx.f.(1) <- Int64.minus_one\n\n let set_lastblock ctx =\n if ctx.last_node <> 0 then set_lastnode ctx ;\n ctx.f.(0) <- Int64.minus_one\n\n let init () =\n let buf = By.make 128 '\\x00' in\n By.fill buf 0 128 '\\x00' ;\n let ctx =\n {\n buflen = 0;\n outlen = default_param.digest_length;\n last_node = 0;\n buf;\n h = Array.make 8 0L;\n t = Array.make 2 0L;\n f = Array.make 2 0L;\n } in\n let param_bytes = param_to_bytes default_param in\n for i = 0 to 7 do\n ctx.h.(i) <- Int64.(iv.(i) lxor By.le64_to_cpu param_bytes (i * 8))\n done ;\n ctx\n\n let sigma =\n [|\n [| 0; 1; 2; 3; 4; 5; 6; 7; 8; 9; 10; 11; 12; 13; 14; 15 |];\n [| 14; 10; 4; 8; 9; 15; 13; 6; 1; 12; 0; 2; 11; 7; 5; 3 |];\n [| 11; 8; 12; 0; 5; 2; 15; 13; 10; 14; 3; 6; 7; 1; 9; 4 |];\n [| 7; 9; 3; 1; 13; 12; 11; 14; 2; 6; 5; 10; 4; 0; 15; 8 |];\n [| 9; 0; 5; 7; 2; 4; 10; 15; 14; 1; 11; 12; 6; 8; 3; 13 |];\n [| 2; 12; 6; 10; 0; 11; 8; 3; 4; 13; 7; 5; 15; 14; 1; 9 |];\n [| 12; 5; 1; 15; 14; 13; 4; 10; 0; 7; 6; 3; 9; 2; 8; 11 |];\n [| 13; 11; 7; 14; 12; 1; 3; 9; 5; 0; 15; 4; 8; 6; 2; 10 |];\n [| 6; 15; 14; 9; 11; 3; 0; 8; 12; 2; 13; 7; 1; 4; 10; 5 |];\n [| 10; 2; 8; 4; 7; 6; 1; 5; 15; 11; 9; 14; 3; 12; 13; 0 |];\n [| 0; 1; 2; 3; 4; 5; 6; 7; 8; 9; 10; 11; 12; 13; 14; 15 |];\n [| 14; 10; 4; 8; 9; 15; 13; 6; 1; 12; 0; 2; 11; 7; 5; 3 |];\n |]\n\n let compress :\n type a. le64_to_cpu:(a -> int -> int64) -> ctx -> a -> int -> unit =\n fun ~le64_to_cpu ctx block off ->\n let v = Array.make 16 0L in\n let m = Array.make 16 0L in\n let g r i a_idx b_idx c_idx d_idx =\n let ( ++ ) = ( + ) in\n let open Int64 in\n v.(a_idx) <- v.(a_idx) + v.(b_idx) + m.(sigma.(r).((2 * i) ++ 0)) ;\n v.(d_idx) <- ror64 (v.(d_idx) lxor v.(a_idx)) 32 ;\n v.(c_idx) <- v.(c_idx) + v.(d_idx) ;\n v.(b_idx) <- ror64 (v.(b_idx) lxor v.(c_idx)) 24 ;\n v.(a_idx) <- v.(a_idx) + v.(b_idx) + m.(sigma.(r).((2 * i) ++ 1)) ;\n v.(d_idx) <- ror64 (v.(d_idx) lxor v.(a_idx)) 16 ;\n v.(c_idx) <- v.(c_idx) + v.(d_idx) ;\n v.(b_idx) <- ror64 (v.(b_idx) lxor v.(c_idx)) 63 in\n let r r =\n g r 0 0 4 8 12 ;\n g r 1 1 5 9 13 ;\n g r 2 2 6 10 14 ;\n g r 3 3 7 11 15 ;\n g r 4 0 5 10 15 ;\n g r 5 1 6 11 12 ;\n g r 6 2 7 8 13 ;\n g r 7 3 4 9 14 in\n for i = 0 to 15 do\n m.(i) <- le64_to_cpu block (off + (i * 8))\n done ;\n for i = 0 to 7 do\n v.(i) <- ctx.h.(i)\n done ;\n v.(8) <- iv.(0) ;\n v.(9) <- iv.(1) ;\n v.(10) <- iv.(2) ;\n v.(11) <- iv.(3) ;\n v.(12) <- Int64.(iv.(4) lxor ctx.t.(0)) ;\n v.(13) <- Int64.(iv.(5) lxor ctx.t.(1)) ;\n v.(14) <- Int64.(iv.(6) lxor ctx.f.(0)) ;\n v.(15) <- Int64.(iv.(7) lxor ctx.f.(1)) ;\n r 0 ;\n r 1 ;\n r 2 ;\n r 3 ;\n r 4 ;\n r 5 ;\n r 6 ;\n r 7 ;\n r 8 ;\n r 9 ;\n r 10 ;\n r 11 ;\n let ( ++ ) = ( + ) in\n for i = 0 to 7 do\n ctx.h.(i) <- Int64.(ctx.h.(i) lxor v.(i) lxor v.(i ++ 8))\n done ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n le64_to_cpu:(a -> int -> int64) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~le64_to_cpu ctx buf off len ->\n let in_off = ref off in\n let in_len = ref len in\n if !in_len > 0\n then (\n let left = ctx.buflen in\n let fill = 128 - left in\n if !in_len > fill\n then (\n ctx.buflen <- 0 ;\n blit buf !in_off ctx.buf left fill ;\n increment_counter ctx 128L ;\n compress ~le64_to_cpu:By.le64_to_cpu ctx ctx.buf 0 ;\n in_off := !in_off + fill ;\n in_len := !in_len - fill ;\n while !in_len > 128 do\n increment_counter ctx 128L ;\n compress ~le64_to_cpu ctx buf !in_off ;\n in_off := !in_off + 128 ;\n in_len := !in_len - 128\n done) ;\n blit buf !in_off ctx.buf ctx.buflen !in_len ;\n ctx.buflen <- ctx.buflen + !in_len) ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~le64_to_cpu:By.le64_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~le64_to_cpu:Bi.le64_to_cpu\n\n let with_outlen_and_key ~blit outlen key off len =\n if outlen > max_outlen\n then\n failwith \"out length can not be upper than %d (out length: %d)\" max_outlen\n outlen ;\n let buf = By.make 128 '\\x00' in\n let ctx =\n {\n buflen = 0;\n outlen;\n last_node = 0;\n buf;\n h = Array.make 8 0L;\n t = Array.make 2 0L;\n f = Array.make 2 0L;\n } in\n let param_bytes =\n param_to_bytes\n { default_param with digest_length = outlen; key_length = len } in\n for i = 0 to 7 do\n ctx.h.(i) <- Int64.(iv.(i) lxor By.le64_to_cpu param_bytes (i * 8))\n done ;\n if len > 0\n then (\n let block = By.make 128 '\\x00' in\n blit key off block 0 len ;\n unsafe_feed_bytes ctx block 0 128) ;\n ctx\n\n let with_outlen_and_bytes_key outlen key off len =\n with_outlen_and_key ~blit:By.blit outlen key off len\n\n let with_outlen_and_bigstring_key outlen key off len =\n with_outlen_and_key ~blit:By.blit_from_bigstring outlen key off len\n\n let unsafe_get ctx =\n let res = By.make default_param.digest_length '\\x00' in\n increment_counter ctx (Int64.of_int ctx.buflen) ;\n set_lastblock ctx ;\n By.fill ctx.buf ctx.buflen (128 - ctx.buflen) '\\x00' ;\n compress ~le64_to_cpu:By.le64_to_cpu ctx ctx.buf 0 ;\n for i = 0 to 7 do\n By.cpu_to_le64 res (i * 8) ctx.h.(i)\n done ;\n if ctx.outlen < default_param.digest_length\n then By.sub res 0 ctx.outlen\n else if ctx.outlen > default_param.digest_length\n then\n assert false\n (* XXX(dinosaure): [ctx] can not be initialized with [outlen > digest_length = max_outlen]. *)\n else res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nlet failwith fmt = Format.kasprintf failwith fmt\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let lnot = Int32.lognot\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\n\n let ror32 a n = (a lsr n) lor (a lsl (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\n\n let ( lsr ) = Int64.shift_right_logical\n\n let ( lor ) = Int64.logor\n\n let ( asr ) = Int64.shift_right\n\n let ( lxor ) = Int64.logxor\n\n let ( + ) = Int64.add\n\n let rol64 a n = (a lsl n) lor (a lsr (64 - n))\n\n let ror64 a n = (a lsr n) lor (a lsl (64 - n))\nend\n\nmodule type S = sig\n type ctx\n\n type kind = [ `BLAKE2S ]\n\n val init : unit -> ctx\n\n val with_outlen_and_bytes_key : int -> By.t -> int -> int -> ctx\n\n val with_outlen_and_bigstring_key : int -> Bi.t -> int -> int -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\n\n val max_outlen : int\nend\n\nmodule Unsafe : S = struct\n type kind = [ `BLAKE2S ]\n\n type param = {\n digest_length : int;\n key_length : int;\n fanout : int;\n depth : int;\n leaf_length : int32;\n node_offset : int32;\n xof_length : int;\n node_depth : int;\n inner_length : int;\n salt : int array;\n personal : int array;\n }\n\n type ctx = {\n mutable buflen : int;\n outlen : int;\n mutable last_node : int;\n buf : Bytes.t;\n h : int32 array;\n t : int32 array;\n f : int32 array;\n }\n\n let dup ctx =\n {\n buflen = ctx.buflen;\n outlen = ctx.outlen;\n last_node = ctx.last_node;\n buf = By.copy ctx.buf;\n h = Array.copy ctx.h;\n t = Array.copy ctx.t;\n f = Array.copy ctx.f;\n }\n\n let param_to_bytes param =\n let arr =\n [|\n param.digest_length land 0xFF;\n param.key_length land 0xFF;\n param.fanout land 0xFF;\n param.depth land 0xFF (* store to little-endian *);\n Int32.(to_int ((param.leaf_length lsr 0) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 8) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 16) land 0xFFl));\n Int32.(to_int ((param.leaf_length lsr 24) land 0xFFl))\n (* store to little-endian *);\n Int32.(to_int ((param.node_offset lsr 0) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 8) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 16) land 0xFFl));\n Int32.(to_int ((param.node_offset lsr 24) land 0xFFl))\n (* store to little-endian *);\n (param.xof_length lsr 0) land 0xFF;\n (param.xof_length lsr 8) land 0xFF;\n param.node_depth land 0xFF;\n param.inner_length land 0xFF;\n param.salt.(0) land 0xFF;\n param.salt.(1) land 0xFF;\n param.salt.(2) land 0xFF;\n param.salt.(3) land 0xFF;\n param.salt.(4) land 0xFF;\n param.salt.(5) land 0xFF;\n param.salt.(6) land 0xFF;\n param.salt.(7) land 0xFF;\n param.personal.(0) land 0xFF;\n param.personal.(1) land 0xFF;\n param.personal.(2) land 0xFF;\n param.personal.(3) land 0xFF;\n param.personal.(4) land 0xFF;\n param.personal.(5) land 0xFF;\n param.personal.(6) land 0xFF;\n param.personal.(7) land 0xFF;\n |] in\n By.init 32 (fun i -> Char.unsafe_chr arr.(i))\n\n let max_outlen = 32\n\n let default_param =\n {\n digest_length = max_outlen;\n key_length = 0;\n fanout = 1;\n depth = 1;\n leaf_length = 0l;\n node_offset = 0l;\n xof_length = 0;\n node_depth = 0;\n inner_length = 0;\n salt = [| 0; 0; 0; 0; 0; 0; 0; 0 |];\n personal = [| 0; 0; 0; 0; 0; 0; 0; 0 |];\n }\n\n let iv =\n [|\n 0x6A09E667l;\n 0xBB67AE85l;\n 0x3C6EF372l;\n 0xA54FF53Al;\n 0x510E527Fl;\n 0x9B05688Cl;\n 0x1F83D9ABl;\n 0x5BE0CD19l;\n |]\n\n let increment_counter ctx inc =\n let open Int32 in\n ctx.t.(0) <- ctx.t.(0) + inc ;\n ctx.t.(1) <- (ctx.t.(1) + if ctx.t.(0) < inc then 1l else 0l)\n\n let set_lastnode ctx = ctx.f.(1) <- Int32.minus_one\n\n let set_lastblock ctx =\n if ctx.last_node <> 0 then set_lastnode ctx ;\n ctx.f.(0) <- Int32.minus_one\n\n let init () =\n let buf = By.make 64 '\\x00' in\n let ctx =\n {\n buflen = 0;\n outlen = default_param.digest_length;\n last_node = 0;\n buf;\n h = Array.make 8 0l;\n t = Array.make 2 0l;\n f = Array.make 2 0l;\n } in\n let param_bytes = param_to_bytes default_param in\n for i = 0 to 7 do\n ctx.h.(i) <- Int32.(iv.(i) lxor By.le32_to_cpu param_bytes (i * 4))\n done ;\n ctx\n\n let sigma =\n [|\n [| 0; 1; 2; 3; 4; 5; 6; 7; 8; 9; 10; 11; 12; 13; 14; 15 |];\n [| 14; 10; 4; 8; 9; 15; 13; 6; 1; 12; 0; 2; 11; 7; 5; 3 |];\n [| 11; 8; 12; 0; 5; 2; 15; 13; 10; 14; 3; 6; 7; 1; 9; 4 |];\n [| 7; 9; 3; 1; 13; 12; 11; 14; 2; 6; 5; 10; 4; 0; 15; 8 |];\n [| 9; 0; 5; 7; 2; 4; 10; 15; 14; 1; 11; 12; 6; 8; 3; 13 |];\n [| 2; 12; 6; 10; 0; 11; 8; 3; 4; 13; 7; 5; 15; 14; 1; 9 |];\n [| 12; 5; 1; 15; 14; 13; 4; 10; 0; 7; 6; 3; 9; 2; 8; 11 |];\n [| 13; 11; 7; 14; 12; 1; 3; 9; 5; 0; 15; 4; 8; 6; 2; 10 |];\n [| 6; 15; 14; 9; 11; 3; 0; 8; 12; 2; 13; 7; 1; 4; 10; 5 |];\n [| 10; 2; 8; 4; 7; 6; 1; 5; 15; 11; 9; 14; 3; 12; 13; 0 |];\n |]\n\n let compress :\n type a. le32_to_cpu:(a -> int -> int32) -> ctx -> a -> int -> unit =\n fun ~le32_to_cpu ctx block off ->\n let v = Array.make 16 0l in\n let m = Array.make 16 0l in\n let g r i a_idx b_idx c_idx d_idx =\n let ( ++ ) = ( + ) in\n let open Int32 in\n v.(a_idx) <- v.(a_idx) + v.(b_idx) + m.(sigma.(r).((2 * i) ++ 0)) ;\n v.(d_idx) <- ror32 (v.(d_idx) lxor v.(a_idx)) 16 ;\n v.(c_idx) <- v.(c_idx) + v.(d_idx) ;\n v.(b_idx) <- ror32 (v.(b_idx) lxor v.(c_idx)) 12 ;\n v.(a_idx) <- v.(a_idx) + v.(b_idx) + m.(sigma.(r).((2 * i) ++ 1)) ;\n v.(d_idx) <- ror32 (v.(d_idx) lxor v.(a_idx)) 8 ;\n v.(c_idx) <- v.(c_idx) + v.(d_idx) ;\n v.(b_idx) <- ror32 (v.(b_idx) lxor v.(c_idx)) 7 in\n let r r =\n g r 0 0 4 8 12 ;\n g r 1 1 5 9 13 ;\n g r 2 2 6 10 14 ;\n g r 3 3 7 11 15 ;\n g r 4 0 5 10 15 ;\n g r 5 1 6 11 12 ;\n g r 6 2 7 8 13 ;\n g r 7 3 4 9 14 in\n for i = 0 to 15 do\n m.(i) <- le32_to_cpu block (off + (i * 4))\n done ;\n for i = 0 to 7 do\n v.(i) <- ctx.h.(i)\n done ;\n v.(8) <- iv.(0) ;\n v.(9) <- iv.(1) ;\n v.(10) <- iv.(2) ;\n v.(11) <- iv.(3) ;\n v.(12) <- Int32.(iv.(4) lxor ctx.t.(0)) ;\n v.(13) <- Int32.(iv.(5) lxor ctx.t.(1)) ;\n v.(14) <- Int32.(iv.(6) lxor ctx.f.(0)) ;\n v.(15) <- Int32.(iv.(7) lxor ctx.f.(1)) ;\n r 0 ;\n r 1 ;\n r 2 ;\n r 3 ;\n r 4 ;\n r 5 ;\n r 6 ;\n r 7 ;\n r 8 ;\n r 9 ;\n let ( ++ ) = ( + ) in\n for i = 0 to 7 do\n ctx.h.(i) <- Int32.(ctx.h.(i) lxor v.(i) lxor v.(i ++ 8))\n done ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n le32_to_cpu:(a -> int -> int32) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~le32_to_cpu ctx buf off len ->\n let in_off = ref off in\n let in_len = ref len in\n if !in_len > 0\n then (\n let left = ctx.buflen in\n let fill = 64 - left in\n if !in_len > fill\n then (\n ctx.buflen <- 0 ;\n blit buf !in_off ctx.buf left fill ;\n increment_counter ctx 64l ;\n compress ~le32_to_cpu:By.le32_to_cpu ctx ctx.buf 0 ;\n in_off := !in_off + fill ;\n in_len := !in_len - fill ;\n while !in_len > 64 do\n increment_counter ctx 64l ;\n compress ~le32_to_cpu ctx buf !in_off ;\n in_off := !in_off + 64 ;\n in_len := !in_len - 64\n done) ;\n blit buf !in_off ctx.buf ctx.buflen !in_len ;\n ctx.buflen <- ctx.buflen + !in_len) ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~le32_to_cpu:By.le32_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~le32_to_cpu:Bi.le32_to_cpu\n\n let with_outlen_and_key ~blit outlen key off len =\n if outlen > max_outlen\n then\n failwith \"out length can not be upper than %d (out length: %d)\" max_outlen\n outlen ;\n let buf = By.make 64 '\\x00' in\n let ctx =\n {\n buflen = 0;\n outlen;\n last_node = 0;\n buf;\n h = Array.make 8 0l;\n t = Array.make 2 0l;\n f = Array.make 2 0l;\n } in\n let param_bytes =\n param_to_bytes\n { default_param with key_length = len; digest_length = outlen } in\n for i = 0 to 7 do\n ctx.h.(i) <- Int32.(iv.(i) lxor By.le32_to_cpu param_bytes (i * 4))\n done ;\n if len > 0\n then (\n let block = By.make 64 '\\x00' in\n blit key off block 0 len ;\n unsafe_feed_bytes ctx block 0 64) ;\n ctx\n\n let with_outlen_and_bytes_key outlen key off len =\n with_outlen_and_key ~blit:By.blit outlen key off len\n\n let with_outlen_and_bigstring_key outlen key off len =\n with_outlen_and_key ~blit:By.blit_from_bigstring outlen key off len\n\n let unsafe_get ctx =\n let res = By.make default_param.digest_length '\\x00' in\n increment_counter ctx (Int32.of_int ctx.buflen) ;\n set_lastblock ctx ;\n By.fill ctx.buf ctx.buflen (64 - ctx.buflen) '\\x00' ;\n compress ~le32_to_cpu:By.le32_to_cpu ctx ctx.buf 0 ;\n for i = 0 to 7 do\n By.cpu_to_le32 res (i * 4) ctx.h.(i)\n done ;\n if ctx.outlen < default_param.digest_length\n then By.sub res 0 ctx.outlen\n else if ctx.outlen > default_param.digest_length\n then\n assert false\n (* XXX(dinosaure): [ctx] can not be initialized with [outlen > digest_length = max_outlen]. *)\n else res\nend\n","type bigstring =\n ( char,\n Bigarray_compat.int8_unsigned_elt,\n Bigarray_compat.c_layout )\n Bigarray_compat.Array1.t\n\ntype 'a iter = ('a -> unit) -> unit\n\ntype 'a compare = 'a -> 'a -> int\n\ntype 'a equal = 'a -> 'a -> bool\n\ntype 'a pp = Format.formatter -> 'a -> unit\n\nmodule By = Digestif_by\nmodule Bi = Digestif_bi\nmodule Eq = Digestif_eq\nmodule Hash = Digestif_hash\nmodule Conv = Digestif_conv\n\nlet failwith fmt = Format.ksprintf failwith fmt\n\nmodule type S = sig\n val digest_size : int\n\n type ctx\n\n type kind\n\n type t\n\n val kind : kind\n\n val empty : ctx\n\n val init : unit -> ctx\n\n val feed_bytes : ctx -> ?off:int -> ?len:int -> Bytes.t -> ctx\n\n val feed_string : ctx -> ?off:int -> ?len:int -> String.t -> ctx\n\n val feed_bigstring : ctx -> ?off:int -> ?len:int -> bigstring -> ctx\n\n val feedi_bytes : ctx -> Bytes.t iter -> ctx\n\n val feedi_string : ctx -> String.t iter -> ctx\n\n val feedi_bigstring : ctx -> bigstring iter -> ctx\n\n val get : ctx -> t\n\n val digest_bytes : ?off:int -> ?len:int -> Bytes.t -> t\n\n val digest_string : ?off:int -> ?len:int -> String.t -> t\n\n val digest_bigstring : ?off:int -> ?len:int -> bigstring -> t\n\n val digesti_bytes : Bytes.t iter -> t\n\n val digesti_string : String.t iter -> t\n\n val digesti_bigstring : bigstring iter -> t\n\n val digestv_bytes : Bytes.t list -> t\n\n val digestv_string : String.t list -> t\n\n val digestv_bigstring : bigstring list -> t\n\n val hmac_bytes : key:Bytes.t -> ?off:int -> ?len:int -> Bytes.t -> t\n\n val hmac_string : key:String.t -> ?off:int -> ?len:int -> String.t -> t\n\n val hmac_bigstring : key:bigstring -> ?off:int -> ?len:int -> bigstring -> t\n\n val hmaci_bytes : key:Bytes.t -> Bytes.t iter -> t\n\n val hmaci_string : key:String.t -> String.t iter -> t\n\n val hmaci_bigstring : key:bigstring -> bigstring iter -> t\n\n val hmacv_bytes : key:Bytes.t -> Bytes.t list -> t\n\n val hmacv_string : key:String.t -> String.t list -> t\n\n val hmacv_bigstring : key:bigstring -> bigstring list -> t\n\n val unsafe_compare : t compare\n\n val equal : t equal\n\n val pp : t pp\n\n val of_hex : string -> t\n\n val of_hex_opt : string -> t option\n\n val consistent_of_hex : string -> t\n\n val consistent_of_hex_opt : string -> t option\n\n val to_hex : t -> string\n\n val of_raw_string : string -> t\n\n val of_raw_string_opt : string -> t option\n\n val to_raw_string : t -> string\nend\n\nmodule type MAC = sig\n type t\n\n val mac_bytes : key:Bytes.t -> ?off:int -> ?len:int -> Bytes.t -> t\n\n val mac_string : key:String.t -> ?off:int -> ?len:int -> String.t -> t\n\n val mac_bigstring : key:bigstring -> ?off:int -> ?len:int -> bigstring -> t\n\n val maci_bytes : key:Bytes.t -> Bytes.t iter -> t\n\n val maci_string : key:String.t -> String.t iter -> t\n\n val maci_bigstring : key:bigstring -> bigstring iter -> t\n\n val macv_bytes : key:Bytes.t -> Bytes.t list -> t\n\n val macv_string : key:String.t -> String.t list -> t\n\n val macv_bigstring : key:bigstring -> bigstring list -> t\nend\n\nmodule type Desc = sig\n type kind\n\n val digest_size : int\n\n val block_size : int\n\n val kind : kind\nend\n\nmodule type Hash = sig\n type ctx\n\n type kind\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe (Hash : Hash) (D : Desc) = struct\n open Hash\n\n let digest_size = D.digest_size\n\n let block_size = D.block_size\n\n let empty = init ()\n\n let init = init\n\n let unsafe_feed_bytes ctx ?off ?len buf =\n let off, len =\n match (off, len) with\n | Some off, Some len -> (off, len)\n | Some off, None -> (off, By.length buf - off)\n | None, Some len -> (0, len)\n | None, None -> (0, By.length buf) in\n if off < 0 || len < 0 || off > By.length buf - len\n then invalid_arg \"offset out of bounds\"\n else unsafe_feed_bytes ctx buf off len\n\n let unsafe_feed_string ctx ?off ?len buf =\n unsafe_feed_bytes ctx ?off ?len (By.unsafe_of_string buf)\n\n let unsafe_feed_bigstring ctx ?off ?len buf =\n let off, len =\n match (off, len) with\n | Some off, Some len -> (off, len)\n | Some off, None -> (off, Bi.length buf - off)\n | None, Some len -> (0, len)\n | None, None -> (0, Bi.length buf) in\n if off < 0 || len < 0 || off > Bi.length buf - len\n then invalid_arg \"offset out of bounds\"\n else unsafe_feed_bigstring ctx buf off len\n\n let unsafe_get = unsafe_get\nend\n\nmodule Core (Hash : Hash) (D : Desc) = struct\n type t = string\n\n type ctx = Hash.ctx\n\n type kind = Hash.kind\n\n include Unsafe (Hash) (D)\n include Conv.Make (D)\n include Eq.Make (D)\n\n let kind = D.kind\n\n let get t =\n let t = Hash.dup t in\n unsafe_get t |> By.unsafe_to_string\n\n let feed_bytes t ?off ?len buf =\n let t = Hash.dup t in\n unsafe_feed_bytes t ?off ?len buf ;\n t\n\n let feed_string t ?off ?len buf =\n let t = Hash.dup t in\n unsafe_feed_string t ?off ?len buf ;\n t\n\n let feed_bigstring t ?off ?len buf =\n let t = Hash.dup t in\n unsafe_feed_bigstring t ?off ?len buf ;\n t\n\n let feedi_bytes t iter =\n let t = Hash.dup t in\n let feed buf = unsafe_feed_bytes t buf in\n iter feed ;\n t\n\n let feedi_string t iter =\n let t = Hash.dup t in\n let feed buf = unsafe_feed_string t buf in\n iter feed ;\n t\n\n let feedi_bigstring t iter =\n let t = Hash.dup t in\n let feed buf = unsafe_feed_bigstring t buf in\n iter feed ;\n t\n\n let digest_bytes ?off ?len buf = feed_bytes empty ?off ?len buf |> get\n\n let digest_string ?off ?len buf = feed_string empty ?off ?len buf |> get\n\n let digest_bigstring ?off ?len buf = feed_bigstring empty ?off ?len buf |> get\n\n let digesti_bytes iter = feedi_bytes empty iter |> get\n\n let digesti_string iter = feedi_string empty iter |> get\n\n let digesti_bigstring iter = feedi_bigstring empty iter |> get\n\n let digestv_bytes lst = digesti_bytes (fun f -> List.iter f lst)\n\n let digestv_string lst = digesti_string (fun f -> List.iter f lst)\n\n let digestv_bigstring lst = digesti_bigstring (fun f -> List.iter f lst)\nend\n\nmodule Make (H : Hash) (D : Desc) = struct\n include Core (H) (D)\n\n let bytes_opad = By.init block_size (fun _ -> '\\x5c')\n\n let bytes_ipad = By.init block_size (fun _ -> '\\x36')\n\n let rec norm_bytes key =\n match Stdlib.compare (By.length key) block_size with\n | 1 -> norm_bytes (By.unsafe_of_string (digest_bytes key))\n | -1 -> By.rpad key block_size '\\000'\n | _ -> key\n\n let bigstring_opad = Bi.init block_size (fun _ -> '\\x5c')\n\n let bigstring_ipad = Bi.init block_size (fun _ -> '\\x36')\n\n let norm_bigstring key =\n let key = Bi.to_string key in\n let res0 = norm_bytes (By.unsafe_of_string key) in\n let res1 = Bi.create (By.length res0) in\n Bi.blit_from_bytes res0 0 res1 0 (By.length res0) ;\n res1\n\n let hmaci_bytes ~key iter =\n let key = norm_bytes key in\n let outer = Xor.Bytes.xor key bytes_opad in\n let inner = Xor.Bytes.xor key bytes_ipad in\n let res =\n digesti_bytes (fun f ->\n f inner ;\n iter f) in\n digesti_bytes (fun f ->\n f outer ;\n f (By.unsafe_of_string res))\n\n let hmaci_string ~key iter =\n let key = norm_bytes (By.unsafe_of_string key) in\n (* XXX(dinosaure): safe, [rpad] and [digest] have a read-only access. *)\n let outer = Xor.Bytes.xor key bytes_opad in\n let inner = Xor.Bytes.xor key bytes_ipad in\n let ctx = feed_bytes empty inner in\n let res = feedi_string ctx iter |> get in\n let ctx = feed_bytes empty outer in\n feed_string ctx (res :> string) |> get\n\n let hmaci_bigstring ~key iter =\n let key = norm_bigstring key in\n let outer = Xor.Bigstring.xor key bigstring_opad in\n let inner = Xor.Bigstring.xor key bigstring_ipad in\n let res =\n digesti_bigstring (fun f ->\n f inner ;\n iter f) in\n let ctx = feed_bigstring empty outer in\n feed_string ctx (res :> string) |> get\n\n let hmac_bytes ~key ?off ?len buf =\n let buf =\n match (off, len) with\n | Some off, Some len -> By.sub buf off len\n | Some off, None -> By.sub buf off (By.length buf - off)\n | None, Some len -> By.sub buf 0 len\n | None, None -> buf in\n hmaci_bytes ~key (fun f -> f buf)\n\n let hmac_string ~key ?off ?len buf =\n let buf =\n match (off, len) with\n | Some off, Some len -> String.sub buf off len\n | Some off, None -> String.sub buf off (String.length buf - off)\n | None, Some len -> String.sub buf 0 len\n | None, None -> buf in\n hmaci_string ~key (fun f -> f buf)\n\n let hmac_bigstring ~key ?off ?len buf =\n let buf =\n match (off, len) with\n | Some off, Some len -> Bi.sub buf off len\n | Some off, None -> Bi.sub buf off (Bi.length buf - off)\n | None, Some len -> Bi.sub buf 0 len\n | None, None -> buf in\n hmaci_bigstring ~key (fun f -> f buf)\n\n let hmacv_bytes ~key bufs = hmaci_bytes ~key (fun f -> List.iter f bufs)\n\n let hmacv_string ~key bufs = hmaci_string ~key (fun f -> List.iter f bufs)\n\n let hmacv_bigstring ~key bufs =\n hmaci_bigstring ~key (fun f -> List.iter f bufs)\nend\n\nmodule type Hash_BLAKE2 = sig\n type ctx\n\n type kind\n\n val with_outlen_and_bytes_key : int -> By.t -> int -> int -> ctx\n\n val with_outlen_and_bigstring_key : int -> Bi.t -> int -> int -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\n\n val max_outlen : int\nend\n\nmodule Make_BLAKE2 (H : Hash_BLAKE2) (D : Desc) = struct\n let () =\n if D.digest_size > H.max_outlen\n then\n failwith \"Invalid digest_size:%d to make a BLAKE2{S,B} implementation\"\n D.digest_size\n\n include Make\n (struct\n type ctx = H.ctx\n\n type kind = H.kind\n\n let init () =\n H.with_outlen_and_bytes_key D.digest_size By.empty 0 0\n\n let unsafe_feed_bytes = H.unsafe_feed_bytes\n\n let unsafe_feed_bigstring = H.unsafe_feed_bigstring\n\n let unsafe_get = H.unsafe_get\n\n let dup = H.dup\n end)\n (D)\n\n type outer = t\n\n module Keyed = struct\n type t = outer\n\n let maci_bytes ~key iter =\n let ctx = H.with_outlen_and_bytes_key digest_size key 0 (By.length key) in\n feedi_bytes ctx iter |> get\n\n let maci_string ~key iter =\n let ctx =\n H.with_outlen_and_bytes_key digest_size (By.unsafe_of_string key) 0\n (String.length key) in\n feedi_string ctx iter |> get\n\n let maci_bigstring ~key iter =\n let ctx =\n H.with_outlen_and_bigstring_key digest_size key 0 (Bi.length key) in\n feedi_bigstring ctx iter |> get\n\n let mac_bytes ~key ?off ?len buf : t =\n let buf =\n match (off, len) with\n | Some off, Some len -> By.sub buf off len\n | Some off, None -> By.sub buf off (By.length buf - off)\n | None, Some len -> By.sub buf 0 len\n | None, None -> buf in\n maci_bytes ~key (fun f -> f buf)\n\n let mac_string ~key ?off ?len buf =\n let buf =\n match (off, len) with\n | Some off, Some len -> String.sub buf off len\n | Some off, None -> String.sub buf off (String.length buf - off)\n | None, Some len -> String.sub buf 0 len\n | None, None -> buf in\n maci_string ~key (fun f -> f buf)\n\n let mac_bigstring ~key ?off ?len buf =\n let buf =\n match (off, len) with\n | Some off, Some len -> Bi.sub buf off len\n | Some off, None -> Bi.sub buf off (Bi.length buf - off)\n | None, Some len -> Bi.sub buf 0 len\n | None, None -> buf in\n maci_bigstring ~key (fun f -> f buf)\n\n let macv_bytes ~key bufs = maci_bytes ~key (fun f -> List.iter f bufs)\n\n let macv_string ~key bufs = maci_string ~key (fun f -> List.iter f bufs)\n\n let macv_bigstring ~key bufs =\n maci_bigstring ~key (fun f -> List.iter f bufs)\n end\nend\n\nmodule MD5 : S with type kind = [ `MD5 ] =\n Make\n (Baijiu_md5.Unsafe)\n (struct\n let digest_size, block_size = (16, 64)\n\n type kind = [ `MD5 ]\n\n let kind = `MD5\n end)\n\nmodule SHA1 : S with type kind = [ `SHA1 ] =\n Make\n (Baijiu_sha1.Unsafe)\n (struct\n let digest_size, block_size = (20, 64)\n\n type kind = [ `SHA1 ]\n\n let kind = `SHA1\n end)\n\nmodule SHA224 : S with type kind = [ `SHA224 ] =\n Make\n (Baijiu_sha224.Unsafe)\n (struct\n let digest_size, block_size = (28, 64)\n\n type kind = [ `SHA224 ]\n\n let kind = `SHA224\n end)\n\nmodule SHA256 : S with type kind = [ `SHA256 ] =\n Make\n (Baijiu_sha256.Unsafe)\n (struct\n let digest_size, block_size = (32, 64)\n\n type kind = [ `SHA256 ]\n\n let kind = `SHA256\n end)\n\nmodule SHA384 : S with type kind = [ `SHA384 ] =\n Make\n (Baijiu_sha384.Unsafe)\n (struct\n let digest_size, block_size = (48, 128)\n\n type kind = [ `SHA384 ]\n\n let kind = `SHA384\n end)\n\nmodule SHA512 : S with type kind = [ `SHA512 ] =\n Make\n (Baijiu_sha512.Unsafe)\n (struct\n let digest_size, block_size = (64, 128)\n\n type kind = [ `SHA512 ]\n\n let kind = `SHA512\n end)\n\nmodule SHA3_224 : S with type kind = [ `SHA3_224 ] =\n Make\n (Baijiu_sha3_224.Unsafe)\n (struct\n let digest_size, block_size = (28, 144)\n\n type kind = [ `SHA3_224 ]\n\n let kind = `SHA3_224\n end)\n\nmodule SHA3_256 : S with type kind = [ `SHA3_256 ] =\n Make\n (Baijiu_sha3_256.Unsafe)\n (struct\n let digest_size, block_size = (32, 136)\n\n type kind = [ `SHA3_256 ]\n\n let kind = `SHA3_256\n end)\n\nmodule SHA3_384 : S with type kind = [ `SHA3_384 ] =\n Make\n (Baijiu_sha3_384.Unsafe)\n (struct\n let digest_size, block_size = (48, 104)\n\n type kind = [ `SHA3_384 ]\n\n let kind = `SHA3_384\n end)\n\nmodule SHA3_512 : S with type kind = [ `SHA3_512 ] =\n Make\n (Baijiu_sha3_512.Unsafe)\n (struct\n let digest_size, block_size = (64, 72)\n\n type kind = [ `SHA3_512 ]\n\n let kind = `SHA3_512\n end)\n\nmodule WHIRLPOOL : S with type kind = [ `WHIRLPOOL ] =\n Make\n (Baijiu_whirlpool.Unsafe)\n (struct\n let digest_size, block_size = (64, 64)\n\n type kind = [ `WHIRLPOOL ]\n\n let kind = `WHIRLPOOL\n end)\n\nmodule BLAKE2B : sig\n include S with type kind = [ `BLAKE2B ]\n\n module Keyed : MAC with type t = t\nend =\n Make_BLAKE2\n (Baijiu_blake2b.Unsafe)\n (struct\n let digest_size, block_size = (64, 128)\n\n type kind = [ `BLAKE2B ]\n\n let kind = `BLAKE2B\n end)\n\nmodule BLAKE2S : sig\n include S with type kind = [ `BLAKE2S ]\n\n module Keyed : MAC with type t = t\nend =\n Make_BLAKE2\n (Baijiu_blake2s.Unsafe)\n (struct\n let digest_size, block_size = (32, 64)\n\n type kind = [ `BLAKE2S ]\n\n let kind = `BLAKE2S\n end)\n\nmodule RMD160 : S with type kind = [ `RMD160 ] =\n Make\n (Baijiu_rmd160.Unsafe)\n (struct\n let digest_size, block_size = (20, 64)\n\n type kind = [ `RMD160 ]\n\n let kind = `RMD160\n end)\n\nmodule Make_BLAKE2B (D : sig\n val digest_size : int\nend) : S with type kind = [ `BLAKE2B ] = struct\n include Make_BLAKE2\n (Baijiu_blake2b.Unsafe)\n (struct\n let digest_size, block_size = (D.digest_size, 128)\n\n type kind = [ `BLAKE2B ]\n\n let kind = `BLAKE2B\n end)\nend\n\nmodule Make_BLAKE2S (D : sig\n val digest_size : int\nend) : S with type kind = [ `BLAKE2S ] = struct\n include Make_BLAKE2\n (Baijiu_blake2s.Unsafe)\n (struct\n let digest_size, block_size = (D.digest_size, 64)\n\n type kind = [ `BLAKE2S ]\n\n let kind = `BLAKE2S\n end)\nend\n\ninclude Hash\n\ntype blake2b = (module S with type kind = [ `BLAKE2B ])\n\ntype blake2s = (module S with type kind = [ `BLAKE2S ])\n\nlet module_of : type k. k hash -> (module S with type kind = k) =\n fun hash ->\n let b2b : (int, blake2b) Hashtbl.t = Hashtbl.create 13 in\n let b2s : (int, blake2s) Hashtbl.t = Hashtbl.create 13 in\n match hash with\n | MD5 -> (module MD5)\n | SHA1 -> (module SHA1)\n | RMD160 -> (module RMD160)\n | SHA224 -> (module SHA224)\n | SHA256 -> (module SHA256)\n | SHA384 -> (module SHA384)\n | SHA512 -> (module SHA512)\n | SHA3_224 -> (module SHA3_224)\n | SHA3_256 -> (module SHA3_256)\n | SHA3_384 -> (module SHA3_384)\n | SHA3_512 -> (module SHA3_512)\n | WHIRLPOOL -> (module WHIRLPOOL)\n | BLAKE2B digest_size -> (\n match Hashtbl.find b2b digest_size with\n | exception Not_found ->\n let m : (module S with type kind = [ `BLAKE2B ]) =\n (module Make_BLAKE2B (struct\n let digest_size = digest_size\n end) : S\n with type kind = [ `BLAKE2B ]) in\n Hashtbl.replace b2b digest_size m ;\n m\n | m -> m)\n | BLAKE2S digest_size ->\n match Hashtbl.find b2s digest_size with\n | exception Not_found ->\n let m =\n (module Make_BLAKE2S (struct\n let digest_size = digest_size\n end) : S\n with type kind = [ `BLAKE2S ]) in\n Hashtbl.replace b2s digest_size m ;\n m\n | m -> m\n\ntype 'kind t = string\n\nlet digest_bytes : type k. k hash -> Bytes.t -> k t =\n fun hash buf ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digest_bytes buf) : H.kind t)\n\nlet digest_string : type k. k hash -> String.t -> k t =\n fun hash buf ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digest_string buf) : H.kind t)\n\nlet digest_bigstring : type k. k hash -> bigstring -> k t =\n fun hash buf ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digest_bigstring buf) : H.kind t)\n\nlet digesti_bytes : type k. k hash -> Bytes.t iter -> k t =\n fun hash iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digesti_bytes iter) : H.kind t)\n\nlet digesti_string : type k. k hash -> String.t iter -> k t =\n fun hash iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digesti_string iter) : H.kind t)\n\nlet digesti_bigstring : type k. k hash -> bigstring iter -> k t =\n fun hash iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.digesti_bigstring iter) : H.kind t)\n\nlet hmaci_bytes : type k. k hash -> key:Bytes.t -> Bytes.t iter -> k t =\n fun hash ~key iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.hmaci_bytes ~key iter) : H.kind t)\n\nlet hmaci_string : type k. k hash -> key:String.t -> String.t iter -> k t =\n fun hash ~key iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.hmaci_string ~key iter) : H.kind t)\n\nlet hmaci_bigstring : type k. k hash -> key:bigstring -> bigstring iter -> k t =\n fun hash ~key iter ->\n let module H = (val module_of hash) in\n (H.to_raw_string (H.hmaci_bigstring ~key iter) : H.kind t)\n\n(* XXX(dinosaure): unsafe part to avoid overhead. *)\n\nlet unsafe_compare : type k. k hash -> k t -> k t -> int =\n fun hash a b ->\n let module H = (val module_of hash) in\n let unsafe : 'k t -> H.t = H.of_raw_string in\n H.unsafe_compare (unsafe a) (unsafe b)\n\nlet equal : type k. k hash -> k t equal =\n fun hash a b ->\n let module H = (val module_of hash) in\n let unsafe : 'k t -> H.t = H.of_raw_string in\n H.equal (unsafe a) (unsafe b)\n\nlet pp : type k. k hash -> k t pp =\n fun hash ppf t ->\n let module H = (val module_of hash) in\n let unsafe : 'k t -> H.t = H.of_raw_string in\n H.pp ppf (unsafe t)\n\nlet of_hex : type k. k hash -> string -> k t =\n fun hash hex ->\n let module H = (val module_of hash) in\n H.to_raw_string (H.of_hex hex)\n\nlet of_hex_opt : type k. k hash -> string -> k t option =\n fun hash hex ->\n let module H = (val module_of hash) in\n match H.of_hex_opt hex with\n | None -> None\n | Some digest -> Some (H.to_raw_string digest)\n\nlet consistent_of_hex : type k. k hash -> string -> k t =\n fun hash hex ->\n let module H = (val module_of hash) in\n H.to_raw_string (H.consistent_of_hex hex)\n\nlet consistent_of_hex_opt : type k. k hash -> string -> k t option =\n fun hash hex ->\n let module H = (val module_of hash) in\n match H.consistent_of_hex_opt hex with\n | None -> None\n | Some digest -> Some (H.to_raw_string digest)\n\nlet to_hex : type k. k hash -> k t -> string =\n fun hash t ->\n let module H = (val module_of hash) in\n let unsafe : 'k t -> H.t = H.of_raw_string in\n H.to_hex (unsafe t)\n\nlet of_raw_string : type k. k hash -> string -> k t =\n fun hash s ->\n let module H = (val module_of hash) in\n let unsafe : H.t -> 'k t = H.to_raw_string in\n unsafe (H.of_raw_string s)\n\nlet of_raw_string_opt : type k. k hash -> string -> k t option =\n fun hash s ->\n let module H = (val module_of hash) in\n let unsafe : H.t -> 'k t = H.to_raw_string in\n match H.of_raw_string_opt s with\n | None -> None\n | Some digest -> Some (unsafe digest)\n\nlet to_raw_string : type k. k hash -> k t -> string = fun _ t -> t\n\nlet of_digest (type hash kind)\n (module H : S with type t = hash and type kind = kind) (hash : H.t) : kind t\n =\n H.to_raw_string hash\n\nlet of_md5 hash = of_raw_string md5 (MD5.to_raw_string hash)\n\nlet of_sha1 hash = of_raw_string sha1 (SHA1.to_raw_string hash)\n\nlet of_rmd160 hash = of_raw_string rmd160 (RMD160.to_raw_string hash)\n\nlet of_sha224 hash = of_raw_string sha224 (SHA224.to_raw_string hash)\n\nlet of_sha256 hash = of_raw_string sha256 (SHA256.to_raw_string hash)\n\nlet of_sha384 hash = of_raw_string sha384 (SHA384.to_raw_string hash)\n\nlet of_sha512 hash = of_raw_string sha512 (SHA512.to_raw_string hash)\n\nlet of_sha3_224 hash = of_raw_string sha3_224 (SHA3_224.to_raw_string hash)\n\nlet of_sha3_256 hash = of_raw_string sha3_256 (SHA3_256.to_raw_string hash)\n\nlet of_sha3_384 hash = of_raw_string sha3_384 (SHA3_384.to_raw_string hash)\n\nlet of_sha3_512 hash = of_raw_string sha3_512 (SHA3_512.to_raw_string hash)\n\nlet of_whirlpool hash = of_raw_string whirlpool (WHIRLPOOL.to_raw_string hash)\n\nlet of_blake2b hash =\n of_raw_string (blake2b BLAKE2B.digest_size) (BLAKE2B.to_raw_string hash)\n\nlet of_blake2s hash =\n of_raw_string (blake2s BLAKE2S.digest_size) (BLAKE2S.to_raw_string hash)\n","open Core_kernel\n\nmodule Digit = struct\n (* A number between 0 and 15 *)\n type t =\n | H0\n | H1\n | H2\n | H3\n | H4\n | H5\n | H6\n | H7\n | H8\n | H9\n | H10\n | H11\n | H12\n | H13\n | H14\n | H15\n\n let of_char_exn c =\n match Char.lowercase c with\n | '0' ->\n H0\n | '1' ->\n H1\n | '2' ->\n H2\n | '3' ->\n H3\n | '4' ->\n H4\n | '5' ->\n H5\n | '6' ->\n H6\n | '7' ->\n H7\n | '8' ->\n H8\n | '9' ->\n H9\n | 'a' ->\n H10\n | 'b' ->\n H11\n | 'c' ->\n H12\n | 'd' ->\n H13\n | 'e' ->\n H14\n | 'f' ->\n H15\n | _ ->\n failwithf \"bad hex digit %c\" c ()\n\n let to_int = function\n | H0 ->\n 0\n | H1 ->\n 1\n | H2 ->\n 2\n | H3 ->\n 3\n | H4 ->\n 4\n | H5 ->\n 5\n | H6 ->\n 6\n | H7 ->\n 7\n | H8 ->\n 8\n | H9 ->\n 9\n | H10 ->\n 10\n | H11 ->\n 11\n | H12 ->\n 12\n | H13 ->\n 13\n | H14 ->\n 14\n | H15 ->\n 15\nend\n\nlet hex_char_of_int_exn = function\n | 0 ->\n '0'\n | 1 ->\n '1'\n | 2 ->\n '2'\n | 3 ->\n '3'\n | 4 ->\n '4'\n | 5 ->\n '5'\n | 6 ->\n '6'\n | 7 ->\n '7'\n | 8 ->\n '8'\n | 9 ->\n '9'\n | 10 ->\n 'a'\n | 11 ->\n 'b'\n | 12 ->\n 'c'\n | 13 ->\n 'd'\n | 14 ->\n 'e'\n | 15 ->\n 'f'\n | d ->\n failwithf \"bad hex digit %d\" d ()\n\nmodule Sequence_be = struct\n type t = Digit.t array\n\n let decode ?(pos = 0) s =\n let n = String.length s - pos in\n Array.init n ~f:(fun i -> Digit.of_char_exn s.[pos + i])\n\n let to_bytes_like ~init (t : t) =\n let n = Array.length t in\n let k = n / 2 in\n assert (n = k + k) ;\n init k ~f:(fun i ->\n Char.of_int_exn\n ((16 * Digit.to_int t.(2 * i)) + Digit.to_int t.((2 * i) + 1)) )\n\n let to_string = to_bytes_like ~init:String.init\n\n let to_bytes = to_bytes_like ~init:Bytes.init\n\n let to_bigstring = to_bytes_like ~init:Bigstring.init\nend\n\nlet decode ?(reverse = false) ?(pos = 0) ~init t =\n let n = String.length t - pos in\n let k = n / 2 in\n assert (n = k + k) ;\n let h j = Digit.(to_int (of_char_exn t.[pos + j])) in\n init k ~f:(fun i ->\n let i = if reverse then k - 1 - i else i in\n Char.of_int_exn ((16 * h (2 * i)) + h ((2 * i) + 1)) )\n\nlet encode ?(reverse = false) t =\n let n = String.length t in\n String.init (2 * n) ~f:(fun i ->\n let c =\n let byte = i / 2 in\n Char.to_int t.[if reverse then n - 1 - byte else byte]\n in\n let c = if i mod 2 = 0 then (* hi *)\n c lsr 4 else (* lo *)\n c in\n hex_char_of_int_exn (c land 15) )\n\nlet%test_unit \"decode\" =\n let t = String.init 100 ~f:(fun _ -> Char.of_int_exn (Random.int 256)) in\n let h = encode t in\n assert (String.equal t (decode ~init:String.init h)) ;\n assert (\n String.equal t\n (decode ~reverse:true ~init:String.init (encode ~reverse:true t)) ) ;\n assert (String.equal t Sequence_be.(to_string (decode h)))\n\n(* TODO: Better deduplicate the hex coding between these two implementations #5711 *)\nmodule Safe = struct\n (** to_hex : {0x0-0xff}* -> [A-F0-9]* *)\n let to_hex (data : string) : string =\n String.to_list data\n |> List.map ~f:(fun c ->\n let charify u4 =\n match u4 with\n | x when x <= 9 && x >= 0 ->\n Char.(of_int_exn @@ (x + to_int '0'))\n | x when x <= 15 && x >= 10 ->\n Char.(of_int_exn @@ (x - 10 + to_int 'A'))\n | _ ->\n failwith \"Unexpected u4 has only 4bits of information\"\n in\n let high = charify @@ ((Char.to_int c land 0xF0) lsr 4) in\n let lo = charify (Char.to_int c land 0x0F) in\n String.of_char_list [ high; lo ] )\n |> String.concat\n\n let%test_unit \"to_hex sane\" =\n let start = \"a\" in\n let hexified = to_hex start in\n let expected = \"61\" in\n if String.equal expected hexified then ()\n else\n failwithf \"start: %s ; hexified : %s ; expected: %s\" start hexified\n expected ()\n\n (** of_hex : [a-fA-F0-9]* -> {0x0-0xff}* option *)\n let of_hex (hex : string) : string option =\n let to_u4 c =\n let open Char in\n assert (is_alphanum c) ;\n match c with\n | _ when is_digit c ->\n to_int c - to_int '0'\n | _ when is_uppercase c ->\n to_int c - to_int 'A' + 10\n | _ (* when is_alpha *) ->\n to_int c - to_int 'a' + 10\n in\n String.to_list hex |> List.chunks_of ~length:2\n |> List.fold_result ~init:[] ~f:(fun acc chunk ->\n match chunk with\n | [ a; b ] when Char.is_alphanum a && Char.is_alphanum b ->\n Or_error.return\n @@ (Char.((to_u4 a lsl 4) lor to_u4 b |> of_int_exn) :: acc)\n | _ ->\n Or_error.error_string \"invalid hex\" )\n |> Or_error.ok\n |> Option.map ~f:(Fn.compose String.of_char_list List.rev)\n\n let%test_unit \"partial isomorphism\" =\n Quickcheck.test ~sexp_of:[%sexp_of: string] ~examples:[ \"\\243\"; \"abc\" ]\n Quickcheck.Generator.(map (list char) ~f:String.of_char_list)\n ~f:(fun s ->\n let hexified = to_hex s in\n let actual = Option.value_exn (of_hex hexified) in\n let expected = s in\n if String.equal actual expected then ()\n else\n failwithf\n !\"expected: %s ; hexified: %s ; actual: %s\"\n expected hexified actual () )\nend\n","(* logger.ml : the fake one *)\n\nopen Core_kernel\n\nlet not_implemented () = failwith \"Not implemented\"\n\nmodule Level = struct\n type t =\n | Internal\n | Spam\n | Trace\n | Debug\n | Info\n | Warn\n | Error\n | Faulty_peer\n | Fatal\n [@@deriving sexp, equal, compare, show { with_path = false }, enumerate]\n\n let of_string _ = not_implemented ()\n\n let to_yojson _ = not_implemented ()\n\n let of_yojson _ = not_implemented ()\nend\n\n(* Core modules extended with Yojson converters *)\nmodule Time = struct\n include Time\n\n let to_yojson _ = not_implemented ()\n\n let of_yojson _ = not_implemented ()\n\n let pp _ _ = not_implemented ()\n\n let set_pretty_to_string _ = not_implemented ()\n\n let pretty_to_string _ = not_implemented ()\nend\n\nmodule Source = struct\n type t = { module_ : string [@key \"module\"]; location : string }\n [@@deriving yojson]\n\n let create ~module_:_ ~location:_ = not_implemented ()\nend\n\nmodule Metadata = struct\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n type t = Yojson.Safe.t String.Map.t\n\n let to_latest = Fn.id\n\n let to_yojson _ = not_implemented ()\n\n let of_yojson _ = not_implemented ()\n\n include\n Binable.Of_binable_without_uuid\n (Core_kernel.String.Stable.V1)\n (struct\n type nonrec t = t\n\n let to_binable _ = not_implemented ()\n\n let of_binable _ = not_implemented ()\n end)\n end\n end]\n\n [%%define_locally Stable.Latest.(to_yojson, of_yojson)]\n\n let empty = String.Map.empty\nend\n\nlet append_to_global_metadata _ = not_implemented ()\n\nmodule Message = struct\n type t =\n { timestamp : Time.t\n ; level : Level.t\n ; source : Source.t option [@default None]\n ; message : string\n ; metadata : Metadata.t\n ; event_id : Structured_log_events.id option [@default None]\n }\n [@@deriving yojson]\nend\n\nmodule Processor = struct\n module type S = sig\n type t\n\n val process : t -> Message.t -> string option\n end\n\n type t\n\n let create _ _ = not_implemented ()\n\n let raw ?log_level:_ () = not_implemented ()\n\n let raw_structured_log_events _ = not_implemented ()\n\n let pretty ~log_level:_ ~config:_ = not_implemented ()\nend\n\nmodule Transport = struct\n module type S = sig\n type t\n\n val transport : t -> string -> unit\n end\n\n type t\n\n let create _ _ = not_implemented ()\n\n let raw _ = not_implemented ()\n\n let stdout () = not_implemented ()\nend\n\nmodule Consumer_registry = struct\n type id = string\n\n let register ~id:_ ~processor:_ ~transport:_ = not_implemented ()\nend\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = { null : bool; metadata : Metadata.Stable.V1.t; id : string }\n\n let to_latest = Fn.id\n end\nend]\n\nlet metadata t = t.metadata\n\nlet create ?metadata:_ ?(id = \"default\") () =\n { null = false; metadata = Metadata.empty; id }\n\nlet null () = { null = true; metadata = Metadata.empty; id = \"default\" }\n\nlet extend t _ = t\n\nlet change_id { null; metadata; id = _ } ~id = { null; metadata; id }\n\nlet raw _ _ = not_implemented ()\n\nlet log _t ~level:_ ~module_:_ ~location:_ ?metadata:_ ?event_id:_ fmt =\n let f _message = () in\n ksprintf f fmt\n\ntype 'a log_function =\n t\n -> module_:string\n -> location:string\n -> ?metadata:(string, Yojson.Safe.t) List.Assoc.t\n -> ?event_id:Structured_log_events.id\n -> ('a, unit, string, unit) format4\n -> 'a\n\nlet trace = log ~level:Level.Trace\n\nlet internal = log ~level:Level.Internal\n\nlet debug = log ~level:Level.Debug\n\nlet info = log ~level:Level.Info\n\nlet warn = log ~level:Level.Warn\n\nlet error = log ~level:Level.Error\n\nlet fatal = log ~level:Level.Fatal\n\nlet faulty_peer_without_punishment = log ~level:Level.Faulty_peer\n\nlet spam = log ~level:Level.Spam ~module_:\"\" ~location:\"\" ?event_id:None\n\n(* deprecated, use Trust_system.record instead *)\nlet faulty_peer = faulty_peer_without_punishment\n\nmodule Structured = struct\n type log_function =\n t\n -> module_:string\n -> location:string\n -> ?metadata:(string, Yojson.Safe.t) List.Assoc.t\n -> Structured_log_events.t\n -> unit\n\n let log _t ~level:_ ~module_:_ ~location:_ ?metadata:_ _event = ()\n\n let trace : log_function = log ~level:Level.Trace\n\n let debug = log ~level:Level.Debug\n\n let info = log ~level:Level.Info\n\n let warn = log ~level:Level.Warn\n\n let error = log ~level:Level.Error\n\n let fatal = log ~level:Level.Fatal\n\n let faulty_peer_without_punishment = log ~level:Level.Faulty_peer\n\n let best_tip_diff = log ~level:Level.Spam ~module_:\"\" ~location:\"\"\nend\n\nmodule Str = Structured\n\nmodule Logger_id = struct\n let invalid = \"fake\"\n\n let mina = invalid\n\n let best_tip_diff = invalid\n\n let rejected_blocks = invalid\n\n let snark_worker = invalid\n\n let oversized_logs = invalid\nend\n","open Core_kernel\n\n(** immutable, serializable statistics derived from allocation data *)\nmodule Allocation_statistics = struct\n (* times represented in ms *)\n type quartiles = { q1 : float; q2 : float; q3 : float; q4 : float }\n [@@deriving yojson]\n\n let make_quartiles n = { q1 = n; q2 = n; q3 = n; q4 = n }\n\n let empty_quartiles = make_quartiles 0.0\n\n type t = { count : int; lifetimes : quartiles } [@@deriving yojson]\n\n let write_metrics { count; lifetimes } object_id =\n let open Mina_metrics in\n let open Mina_metrics.Object_lifetime_statistics in\n let { q1; q2; q3; q4 } = lifetimes in\n let q x = lifetime_quartile_ms ~name:object_id ~quartile:x in\n Gauge.set (live_count ~name:object_id) (Int.to_float count) ;\n Gauge.set (q `Q1) q1 ;\n Gauge.set (q `Q2) q2 ;\n Gauge.set (q `Q3) q3 ;\n Gauge.set (q `Q4) q4\nend\n\n(** mutable data for an object we track allocations of (one exists per object type) *)\nmodule Allocation_data = struct\n (* stops being unique after 2^{30,62} values; perhaps we should use guids instead *)\n type allocation_id = int\n\n let initial_allocation_id = Int.min_value\n\n (* indexed queue data structure would be more effecient here, but keeping this simple for now *)\n type t =\n { allocation_times : (allocation_id * Time.t) Queue.t\n ; mutable next_allocation_id : allocation_id\n }\n\n let create () =\n { allocation_times = Queue.create ()\n ; next_allocation_id = initial_allocation_id\n }\n\n let register_allocation data =\n let id = data.next_allocation_id in\n Queue.enqueue data.allocation_times (id, Time.now ()) ;\n data.next_allocation_id <- data.next_allocation_id + 1 ;\n id\n\n (* currently O(n) wrt queue size *)\n let unregister_allocation data id =\n Queue.filter_inplace data.allocation_times ~f:(fun (id', _) -> id = id')\n\n let compute_statistics { allocation_times; _ } =\n let now = Time.now () in\n let count = Queue.length allocation_times in\n let lifetime_ms_of_time time = Time.Span.to_ms (Time.diff now time) in\n let get_lifetime_ms i =\n lifetime_ms_of_time (snd @@ Queue.get allocation_times i)\n in\n let mean_indices max_len =\n let m = max_len - 1 in\n if m mod 2 = 0 then [ m / 2 ] else [ m / 2; (m / 2) + 1 ]\n in\n let mean offset length =\n let indices =\n mean_indices length |> List.filter ~f:(fun x -> x < count)\n in\n let sum =\n List.fold_left indices ~init:0.0 ~f:(fun acc i ->\n acc +. get_lifetime_ms (count - 1 - (i + offset)) )\n in\n sum /. Int.to_float (List.length indices)\n in\n let lifetimes =\n match count with\n | 0 ->\n Allocation_statistics.empty_quartiles\n | 1 ->\n Allocation_statistics.make_quartiles (get_lifetime_ms 0)\n | _ ->\n let q1 = mean 0 (count / 2) in\n let q2 = mean 0 count in\n let q3_offset = if count mod 2 = 0 then 0 else 1 in\n let q3 = mean ((count / 2) + q3_offset) (count / 2) in\n let q4 = get_lifetime_ms 0 in\n Allocation_statistics.{ q1; q2; q3; q4 }\n in\n Allocation_statistics.{ count; lifetimes }\n\n let compute_statistics t =\n try compute_statistics t\n with _ ->\n Allocation_statistics.\n { count = 0; lifetimes = Allocation_statistics.make_quartiles 0. }\n\n let%test_module \"Allocation_data unit tests\" =\n ( module struct\n open Allocation_statistics\n\n module Float_compare = Float.Robust_compare.Make (struct\n let robust_comparison_tolerance = 0.04\n end)\n\n type robust_float = float [@@deriving sexp]\n\n let compare_robust_float = Float_compare.robustly_compare\n\n (* time_offsets passed in here should be ordered monotonically (to match real world behavior) *)\n let run_test time_offsets expected_quartiles =\n let now = Time.now () in\n (* ids do not need to be unique in this test *)\n let data =\n { allocation_times =\n Queue.of_list\n @@ List.map (List.rev time_offsets) ~f:(fun offset ->\n (0, Time.sub now (Time.Span.of_ms offset)) )\n ; next_allocation_id = 0\n }\n in\n let stats = compute_statistics data in\n [%test_eq: int] stats.count (List.length time_offsets) ;\n [%test_eq: robust_float] stats.lifetimes.q1 expected_quartiles.q1 ;\n [%test_eq: robust_float] stats.lifetimes.q2 expected_quartiles.q2 ;\n [%test_eq: robust_float] stats.lifetimes.q3 expected_quartiles.q3 ;\n [%test_eq: robust_float] stats.lifetimes.q4 expected_quartiles.q4\n\n let%test_unit \"quartiles of empty list\" =\n run_test [] { q1 = 0.0; q2 = 0.0; q3 = 0.0; q4 = 0.0 }\n\n let%test_unit \"quartiles of singleton list\" =\n run_test [ 1.0 ] { q1 = 1.0; q2 = 1.0; q3 = 1.0; q4 = 1.0 }\n\n let%test_unit \"quartiles of 2 element list\" =\n run_test [ 1.0; 2.0 ] { q1 = 1.0; q2 = 1.5; q3 = 2.0; q4 = 2.0 }\n\n let%test_unit \"quartiles of 3 element list\" =\n run_test [ 1.0; 2.0; 3.0 ] { q1 = 1.0; q2 = 2.0; q3 = 3.0; q4 = 3.0 }\n\n let%test_unit \"quartiles of even list (> 3)\" =\n run_test\n [ 1.0; 2.0; 3.0; 4.0; 5.0; 6.0 ]\n { q1 = 2.0; q2 = 3.5; q3 = 5.0; q4 = 6.0 }\n\n let%test_unit \"quartiles of odd list with even split (> 3)\" =\n run_test\n [ 1.0; 2.0; 3.0; 4.0; 5.0; 6.0; 7.0 ]\n { q1 = 2.0; q2 = 4.0; q3 = 6.0; q4 = 7.0 }\n\n let%test_unit \"quartiles of odd list with odd split (> 3)\" =\n run_test\n [ 1.0; 2.0; 3.0; 4.0; 5.0; 6.0; 7.0; 8.0; 9.0 ]\n { q1 = 2.5; q2 = 5.0; q3 = 7.5; q4 = 9.0 }\n end )\nend\n\n(** correlation of allocation data and derived statistics *)\nmodule Allocation_info = struct\n type t = { statistics : Allocation_statistics.t; data : Allocation_data.t }\nend\n\nlet table = String.Table.create ()\n\nlet capture object_id =\n let open Allocation_info in\n let info_opt = String.Table.find table object_id in\n let data_opt = Option.map info_opt ~f:(fun { data; _ } -> data) in\n let data =\n Lazy.(\n force\n @@ Option.value_map data_opt\n ~default:(lazy (Allocation_data.create ()))\n ~f:Lazy.return)\n in\n let allocation_id = Allocation_data.register_allocation data in\n let statistics = Allocation_data.compute_statistics data in\n String.Table.set table ~key:object_id ~data:{ data; statistics } ;\n Allocation_statistics.write_metrics statistics object_id ;\n Mina_metrics.(\n Counter.inc_one (Object_lifetime_statistics.allocated_count ~name:object_id)) ;\n allocation_id\n\n(* release is currently O(n), where n = number of active allocations for this object type; this can be improved by implementing indexed queues (with decent random delete computational complexity) in ocaml *)\nlet release ~object_id ~allocation_id =\n let open Allocation_info in\n let info = String.Table.find_exn table object_id in\n Allocation_data.unregister_allocation info.data allocation_id ;\n let statistics = Allocation_data.compute_statistics info.data in\n String.Table.set table ~key:object_id ~data:{ info with statistics } ;\n Allocation_statistics.write_metrics statistics object_id ;\n Mina_metrics.(\n Counter.inc_one (Object_lifetime_statistics.collected_count ~name:object_id))\n\nlet attach_finalizer object_id obj =\n let allocation_id = capture object_id in\n Gc.Expert.add_finalizer_exn obj (fun _ -> release ~object_id ~allocation_id) ;\n obj\n\nlet dump () =\n let open Allocation_info in\n let entries =\n String.Table.to_alist table\n |> List.Assoc.map ~f:(fun { statistics; _ } ->\n Allocation_statistics.to_yojson statistics )\n in\n `Assoc entries\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'a t =\n { accs : ('a * 'a) array\n ; bits : 'a array\n ; ss : 'a array\n ; base : 'a * 'a\n ; n_prev : 'a\n ; n_next : 'a\n }\n [@@deriving sexp, fields, hlist]\n end\nend]\n\nlet map { accs; bits; ss; base; n_prev; n_next } ~f =\n { accs = Array.map accs ~f:(fun (x, y) -> (f x, f y))\n ; bits = Array.map bits ~f\n ; ss = Array.map ss ~f\n ; base = (f (fst base), f (snd base))\n ; n_prev = f n_prev\n ; n_next = f n_next\n }\n\nlet map2 t1 t2 ~f =\n { accs =\n Array.map (Array.zip_exn t1.accs t2.accs) ~f:(fun ((x1, y1), (x2, y2)) ->\n (f x1 x2, f y1 y2) )\n ; bits =\n Array.map (Array.zip_exn t1.bits t2.bits) ~f:(fun (x1, x2) -> f x1 x2)\n ; ss = Array.map (Array.zip_exn t1.ss t2.ss) ~f:(fun (x1, x2) -> f x1 x2)\n ; base = (f (fst t1.base) (fst t2.base), f (snd t1.base) (snd t2.base))\n ; n_prev = f t1.n_prev t2.n_prev\n ; n_next = f t1.n_next t2.n_next\n }\n\nlet fold { accs; bits; ss; base; n_prev; n_next } ~f ~init =\n let t = Array.fold accs ~init ~f:(fun acc (x, y) -> f [ x; y ] acc) in\n let t = Array.fold bits ~init:t ~f:(fun acc x -> f [ x ] acc) in\n let t = Array.fold ss ~init:t ~f:(fun acc x -> f [ x ] acc) in\n let t = f [ fst base; snd base ] t in\n let t = f [ n_prev ] t in\n let t = f [ n_next ] t in\n t\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'f t = 'f Kimchi_types.scalar_challenge = { inner : 'f }\n [@@deriving sexp, compare, equal, yojson, hash]\n end\nend]\n\nlet create t = { inner = t }\n\nlet typ f =\n let there { inner = x } = x in\n let back x = create x in\n Snarky_backendless.Typ.(transport_var (transport f ~there ~back) ~there ~back)\n\nlet map { inner = x } ~f = create (f x)\n","open Intf\nopen Core_kernel\n\nmodule type Input_intf = sig\n module BaseField : sig\n type t\n end\n\n module ScalarField : sig\n type t\n end\n\n module Affine : sig\n type t = BaseField.t Kimchi_types.or_infinity\n end\n\n type t\n\n val to_affine : t -> Affine.t\n\n val of_affine_coordinates : BaseField.t -> BaseField.t -> t\n\n val add : t -> t -> t\n\n val double : t -> t\n\n val scale : t -> ScalarField.t -> t\n\n val sub : t -> t -> t\n\n val negate : t -> t\n\n val random : unit -> t\n\n val one : unit -> t\nend\n\nmodule type Field_intf = sig\n module Stable : sig\n module Latest : sig\n type t [@@deriving bin_io, equal, sexp, compare, yojson, hash]\n end\n end\n\n type t = Stable.Latest.t\n\n val ( + ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n\n val one : t\n\n val square : t -> t\n\n val is_square : t -> bool\n\n val sqrt : t -> t\n\n val random : unit -> t\nend\n\nmodule Make\n (BaseField : Field_intf) (ScalarField : sig\n type t\n end) (Params : sig\n val a : BaseField.t\n\n val b : BaseField.t\n end)\n (C : Input_intf\n with module BaseField := BaseField\n and module ScalarField := ScalarField) =\nstruct\n include (C : module type of C with type t = C.t with module Affine := C.Affine)\n\n module Base_field = BaseField\n\n let one = one ()\n\n (* TODO: wouldn't be easier if Input_intf exposed a `zero`? *)\n let zero = sub one one\n\n let y_squared x =\n let open BaseField in\n Params.b + (x * (Params.a + square x))\n\n module Affine = struct\n module Backend = struct\n include C.Affine\n\n let zero () = Kimchi_types.Infinity\n\n let create x y = Kimchi_types.Finite (x, y)\n end\n\n module Stable = struct\n module V1 = struct\n module T = struct\n type t = BaseField.Stable.Latest.t * BaseField.Stable.Latest.t\n [@@deriving equal, bin_io, sexp, compare, yojson, hash]\n end\n\n (* asserts the versioned-ness of V1\n to do this properly, we'd move the Stable module outside the functor\n *)\n let __versioned__ = ()\n\n include T\n\n exception Invalid_curve_point of t\n\n include\n Binable.Of_binable\n (T)\n (struct\n let on_curve (x, y) =\n BaseField.Stable.Latest.equal (y_squared x) (BaseField.square y)\n\n type t = T.t\n\n let to_binable = Fn.id\n\n let of_binable t =\n if not (on_curve t) then raise (Invalid_curve_point t) ;\n t\n end)\n end\n\n module Latest = V1\n end\n\n let%test \"cannot deserialize invalid points\" =\n (* y^2 = x^3 + a x + b\n\n pick c at random\n let (x, y) = (c^2, c^3)\n\n Then the above equation becomes\n c^6 = c^6 + (a c^2 + b)\n\n a c^3 + b is almost certainly nonzero (and for our curves, with a = 0, it always is)\n so this point is almost certainly (and for our curves, always) invalid\n *)\n let invalid =\n let open BaseField in\n let c = random () in\n let c2 = square c in\n (c2, c2 * c)\n in\n match\n Binable.to_string (module Stable.Latest) invalid\n |> Binable.of_string (module Stable.Latest)\n with\n | exception Stable.V1.Invalid_curve_point _ ->\n true\n | _ ->\n false\n\n include Stable.Latest\n\n let to_backend :\n (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t -> Backend.t =\n function\n | Infinity ->\n Infinity\n | Finite (x, y) ->\n Finite (x, y)\n\n let of_backend :\n Backend.t -> (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t =\n function\n | Infinity ->\n Infinity\n | Finite (x, y) ->\n Finite (x, y)\n end\n\n let to_affine_or_infinity = C.to_affine\n\n let to_affine_exn t =\n match C.to_affine t with\n | Infinity ->\n failwith \"to_affine_exn: Got identity\"\n | Finite (x, y) ->\n (x, y)\n\n let of_affine (x, y) = C.of_affine_coordinates x y\n\n include\n Binable.Of_binable\n (Affine)\n (struct\n type nonrec t = t\n\n let to_binable = to_affine_exn\n\n let of_binable = of_affine\n end)\n\n let ( + ) = add\n\n let ( * ) s t = scale t s\n\n let find_y x =\n let open BaseField in\n let y2 = y_squared x in\n if is_square y2 then Some (sqrt y2) else None\n\n let point_near_x (x : BaseField.t) =\n let rec go x = function\n | Some y ->\n of_affine (x, y)\n | None ->\n let x' = BaseField.(one + x) in\n go x' (find_y x')\n in\n go x (find_y x)\nend\n","open Core_kernel\nopen Async_kernel\nopen Pickles_types\n\nlet tuple15_to_vec\n (w0, w1, w2, w3, w4, w5, w6, w7, w8, w9, w10, w11, w12, w13, w14) =\n Vector.[ w0; w1; w2; w3; w4; w5; w6; w7; w8; w9; w10; w11; w12; w13; w14 ]\n\nlet tuple15_of_vec\n Vector.[ w0; w1; w2; w3; w4; w5; w6; w7; w8; w9; w10; w11; w12; w13; w14 ] =\n (w0, w1, w2, w3, w4, w5, w6, w7, w8, w9, w10, w11, w12, w13, w14)\n\nlet tuple6_to_vec (w0, w1, w2, w3, w4, w5) = Vector.[ w0; w1; w2; w3; w4; w5 ]\n\nlet tuple6_of_vec Vector.[ w0; w1; w2; w3; w4; w5 ] = (w0, w1, w2, w3, w4, w5)\n\nmodule type Stable_v1 = sig\n module Stable : sig\n module V1 : sig\n type t [@@deriving version, bin_io, sexp, compare, yojson, hash, equal]\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t [@@deriving sexp, compare, yojson, hash, equal]\nend\n\nmodule type Inputs_intf = sig\n open Intf\n\n val id : string\n\n module Scalar_field : sig\n include Stable_v1\n\n val one : t\n\n module Vector : Snarky_intf.Vector.S with type elt = t\n end\n\n module Base_field : sig\n type t\n end\n\n module Curve : sig\n module Affine : sig\n include Stable_v1 with type Stable.V1.t = Base_field.t * Base_field.t\n\n module Backend : sig\n type t = Base_field.t Kimchi_types.or_infinity\n end\n\n val of_backend :\n Backend.t -> (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t\n\n val to_backend :\n (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t -> Backend.t\n end\n end\n\n module Poly_comm : sig\n type t = Base_field.t Poly_comm.t\n\n module Backend : sig\n type t = Curve.Affine.Backend.t Kimchi_types.poly_comm\n end\n\n val of_backend_with_degree_bound : Backend.t -> t\n\n val of_backend_without_degree_bound : Backend.t -> t\n\n val to_backend : t -> Backend.t\n end\n\n module Opening_proof_backend : sig\n type t = (Curve.Affine.Backend.t, Scalar_field.t) Kimchi_types.opening_proof\n end\n\n module Evaluations_backend : sig\n type t = Scalar_field.t Kimchi_types.proof_evaluations\n end\n\n module Index : sig\n type t\n end\n\n module Verifier_index : sig\n type t\n end\n\n module Backend : sig\n type with_public_evals =\n (Curve.Affine.Backend.t, Scalar_field.t) Kimchi_types.proof_with_public\n\n type t = (Curve.Affine.Backend.t, Scalar_field.t) Kimchi_types.prover_proof\n\n val create :\n Index.t\n -> primary:Scalar_field.Vector.t\n -> auxiliary:Scalar_field.Vector.t\n -> prev_chals:Scalar_field.t array\n -> prev_comms:Curve.Affine.Backend.t array\n -> with_public_evals\n\n val create_async :\n Index.t\n -> primary:Scalar_field.Vector.t\n -> auxiliary:Scalar_field.Vector.t\n -> prev_chals:Scalar_field.t array\n -> prev_comms:Curve.Affine.Backend.t array\n -> with_public_evals Promise.t\n\n val verify : Verifier_index.t -> with_public_evals -> bool\n\n val batch_verify :\n Verifier_index.t array -> with_public_evals array -> bool Promise.t\n end\nend\n\nmodule Challenge_polynomial = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('g, 'fq) t = { challenges : 'fq array; commitment : 'g }\n [@@deriving version, bin_io, sexp, compare, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Make (Inputs : Inputs_intf) = struct\n open Inputs\n module Backend = Backend\n module Fq = Scalar_field\n module G = Curve\n\n module Challenge_polynomial = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( G.Affine.Stable.V1.t\n , Fq.Stable.V1.t )\n Challenge_polynomial.Stable.V1.t\n [@@deriving sexp, compare, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n type ('g, 'fq) t_ = ('g, 'fq) Challenge_polynomial.t =\n { challenges : 'fq array; commitment : 'g }\n end\n\n type message = Challenge_polynomial.t list\n\n let hash_fold_array f s x = hash_fold_list f s (Array.to_list x)\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n module T = struct\n type t =\n ( G.Affine.Stable.V1.t\n , Fq.Stable.V1.t\n , Fq.Stable.V1.t array )\n Pickles_types.Plonk_types.Proof.Stable.V2.t\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let id = \"plong_dlog_proof_\" ^ Inputs.id\n\n type 'a creator =\n messages:G.Affine.t Pickles_types.Plonk_types.Messages.Stable.V2.t\n -> openings:\n ( G.Affine.t\n , Fq.t\n , Fq.t array )\n Pickles_types.Plonk_types.Openings.Stable.V2.t\n -> 'a\n\n let map_creator c ~f ~messages ~openings = f (c ~messages ~openings)\n\n let create ~messages ~openings =\n let open Pickles_types.Plonk_types.Proof.Stable.Latest in\n { messages; openings }\n end\n\n include T\n\n include (\n Allocation_functor.Make.Full\n (T) :\n Allocation_functor.Intf.Output.Full_intf\n with type t := t\n and type 'a creator := 'a creator )\n\n let to_latest = Fn.id\n end\n end]\n\n module T = struct\n type t = (G.Affine.t, Fq.t, Fq.t array) Pickles_types.Plonk_types.Proof.t\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let id = \"plong_dlog_proof_\" ^ Inputs.id\n\n type 'a creator =\n messages:G.Affine.t Pickles_types.Plonk_types.Messages.t\n -> openings:\n (G.Affine.t, Fq.t, Fq.t array) Pickles_types.Plonk_types.Openings.t\n -> 'a\n\n let map_creator c ~f ~messages ~openings = f (c ~messages ~openings)\n\n let create ~messages ~openings =\n let open Pickles_types.Plonk_types.Proof in\n { messages; openings }\n end\n\n include T\n\n include (\n struct\n include Allocation_functor.Make.Basic (T)\n include Allocation_functor.Make.Partial.Sexp (T)\n include Allocation_functor.Make.Partial.Yojson (T)\n end :\n sig\n include\n Allocation_functor.Intf.Output.Basic_intf\n with type t := t\n and type 'a creator := 'a creator\n\n include\n Allocation_functor.Intf.Output.Sexp_intf\n with type t := t\n and type 'a creator := 'a creator\n\n include\n Allocation_functor.Intf.Output.Yojson_intf\n with type t := t\n and type 'a creator := 'a creator\n end )\n\n type with_public_evals =\n { proof : t\n ; public_evals : (Scalar_field.t array * Scalar_field.t array) option\n }\n\n let g t f = G.Affine.of_backend (f t)\n\n let fq_array_to_vec arr =\n let vec = Fq.Vector.create () in\n Array.iter arr ~f:(fun fe -> Fq.Vector.emplace_back vec fe) ;\n vec\n\n (** Note that this function will panic if any of the points are points at\n infinity *)\n let opening_proof_of_backend_exn (t : Opening_proof_backend.t) =\n let g (x : G.Affine.Backend.t) : G.Affine.t =\n G.Affine.of_backend x |> Pickles_types.Or_infinity.finite_exn\n in\n let gpair ((g1, g2) : G.Affine.Backend.t * G.Affine.Backend.t) :\n G.Affine.t * G.Affine.t =\n (g g1, g g2)\n in\n { Pickles_types.Plonk_types.Openings.Bulletproof.lr =\n Array.map ~f:gpair t.lr\n ; z_1 = t.z1\n ; z_2 = t.z2\n ; delta = g t.delta\n ; challenge_polynomial_commitment = g t.sg\n }\n\n let eval_of_backend\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } :\n Evaluations_backend.t ) : _ Pickles_types.Plonk_types.Evals.t =\n { w = tuple15_to_vec w\n ; coefficients = tuple15_to_vec coefficients\n ; z\n ; s = tuple6_to_vec s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted =\n Vector.init Nat.N5.n ~f:(fun i ->\n Option.try_with_join (fun () -> lookup_sorted.(i)) )\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n }\n\n let evals_to_tuple ({ zeta; zeta_omega } : _ Kimchi_types.point_evaluations) =\n (zeta, zeta_omega)\n\n let of_backend (t : Backend.t) : t =\n let proof = opening_proof_of_backend_exn t.proof in\n let evals =\n Plonk_types.Evals.map ~f:evals_to_tuple (eval_of_backend t.evals)\n in\n let wo x : Inputs.Curve.Affine.t array =\n match Poly_comm.of_backend_without_degree_bound x with\n | `Without_degree_bound gs ->\n gs\n | _ ->\n assert false\n in\n let w_comm =\n tuple15_to_vec t.commitments.w_comm |> Pickles_types.Vector.map ~f:wo\n in\n create\n ~messages:\n { w_comm\n ; z_comm = wo t.commitments.z_comm\n ; t_comm = wo t.commitments.t_comm\n ; lookup =\n Option.map t.commitments.lookup\n ~f:(fun l : _ Pickles_types.Plonk_types.Messages.Lookup.t ->\n { sorted =\n Vector.init\n Pickles_types.Plonk_types.Lookup_sorted_minus_1.n\n ~f:(fun i -> wo l.sorted.(i))\n ; sorted_5th_column =\n (* TODO: This is ugly and error-prone *)\n Option.try_with (fun () ->\n wo\n l.sorted.(Nat.to_int\n Pickles_types.Plonk_types\n .Lookup_sorted_minus_1\n .n) )\n ; aggreg = wo l.aggreg\n ; runtime = Option.map ~f:wo l.runtime\n } )\n }\n ~openings:{ proof; evals; ft_eval1 = t.ft_eval1 }\n\n let of_backend_with_public_evals (t : Backend.with_public_evals) :\n with_public_evals =\n { proof = of_backend t.proof\n ; public_evals = Option.map ~f:evals_to_tuple t.public_evals\n }\n\n let eval_to_backend\n { Pickles_types.Plonk_types.Evals.w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n } : Evaluations_backend.t =\n { w = tuple15_of_vec w\n ; coefficients = tuple15_of_vec coefficients\n ; z\n ; s = tuple6_of_vec s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector\n ; range_check1_selector\n ; foreign_field_add_selector\n ; foreign_field_mul_selector\n ; xor_selector\n ; rot_selector\n ; lookup_aggregation\n ; lookup_table\n ; lookup_sorted = Vector.to_array lookup_sorted\n ; runtime_lookup_table\n ; runtime_lookup_table_selector\n ; xor_lookup_selector\n ; lookup_gate_lookup_selector\n ; range_check_lookup_selector\n ; foreign_field_mul_lookup_selector\n }\n\n let vec_to_array (type t elt)\n (module V : Snarky_intf.Vector.S with type t = t and type elt = elt)\n (v : t) =\n Array.init (V.length v) ~f:(V.get v)\n\n let evals_of_tuple (zeta, zeta_omega) : _ Kimchi_types.point_evaluations =\n { zeta; zeta_omega }\n\n let to_backend' (chal_polys : Challenge_polynomial.t list) primary_input\n ({ messages = { w_comm; z_comm; t_comm; lookup }\n ; openings =\n { proof = { lr; z_1; z_2; delta; challenge_polynomial_commitment }\n ; evals\n ; ft_eval1\n }\n } :\n t ) : Backend.t =\n let g x = G.Affine.to_backend (Pickles_types.Or_infinity.Finite x) in\n let pcwo t = Poly_comm.to_backend (`Without_degree_bound t) in\n let lr = Array.map lr ~f:(fun (x, y) -> (g x, g y)) in\n { commitments =\n { w_comm = tuple15_of_vec (Pickles_types.Vector.map ~f:pcwo w_comm)\n ; z_comm = pcwo z_comm\n ; t_comm = pcwo t_comm\n ; lookup =\n Option.map lookup ~f:(fun t : _ Kimchi_types.lookup_commitments ->\n { sorted =\n Array.map ~f:pcwo\n (Array.append (Vector.to_array t.sorted)\n (Option.to_array t.sorted_5th_column) )\n ; aggreg = pcwo t.aggreg\n ; runtime = Option.map ~f:pcwo t.runtime\n } )\n }\n ; proof =\n { lr\n ; delta = g delta\n ; z1 = z_1\n ; z2 = z_2\n ; sg = g challenge_polynomial_commitment\n }\n ; evals = eval_to_backend (Plonk_types.Evals.map ~f:evals_of_tuple evals)\n ; ft_eval1\n ; public = primary_input\n ; prev_challenges =\n Array.of_list_map chal_polys\n ~f:(fun { Challenge_polynomial.commitment = x, y; challenges } ->\n { Kimchi_types.chals = challenges\n ; comm =\n { Kimchi_types.shifted = None\n ; unshifted = [| Kimchi_types.Finite (x, y) |]\n }\n } )\n }\n\n let to_backend chal_polys primary_input t =\n to_backend' chal_polys (List.to_array primary_input) t\n\n let to_backend_with_public_evals' (chal_polys : Challenge_polynomial.t list)\n primary_input ({ proof; public_evals } : with_public_evals) :\n Backend.with_public_evals =\n { proof = to_backend' chal_polys primary_input proof\n ; public_evals = Option.map ~f:evals_of_tuple public_evals\n }\n\n let to_backend_with_public_evals chal_polys primary_input t =\n to_backend_with_public_evals' chal_polys (List.to_array primary_input) t\n\n let create ?message pk ~primary ~auxiliary =\n let chal_polys =\n match (message : message option) with Some s -> s | None -> []\n in\n let challenges =\n List.map chal_polys ~f:(fun { Challenge_polynomial.challenges; _ } ->\n challenges )\n |> Array.concat\n in\n let commitments =\n Array.of_list_map chal_polys\n ~f:(fun { Challenge_polynomial.commitment; _ } ->\n G.Affine.to_backend (Finite commitment) )\n in\n let res =\n Backend.create pk ~primary ~auxiliary ~prev_chals:challenges\n ~prev_comms:commitments\n in\n of_backend_with_public_evals res\n\n let create_async ?message pk ~primary ~auxiliary =\n let chal_polys =\n match (message : message option) with Some s -> s | None -> []\n in\n let challenges =\n List.map chal_polys ~f:(fun { Challenge_polynomial.challenges; _ } ->\n challenges )\n |> Array.concat\n in\n let commitments =\n Array.of_list_map chal_polys\n ~f:(fun { Challenge_polynomial.commitment; _ } ->\n G.Affine.to_backend (Finite commitment) )\n in\n let%map.Promise res =\n Backend.create_async pk ~primary ~auxiliary ~prev_chals:challenges\n ~prev_comms:commitments\n in\n of_backend_with_public_evals res\n\n let batch_verify' (conv : 'a -> Fq.t array)\n (ts : (Verifier_index.t * with_public_evals * 'a * message option) list) =\n let logger = Internal_tracing_context_logger.get () in\n [%log internal] \"Batch_verify_backend_convert_inputs\" ;\n let vks_and_v =\n Array.of_list_map ts ~f:(fun (vk, t, xs, m) ->\n let p =\n to_backend_with_public_evals'\n (Option.value ~default:[] m)\n (conv xs) t\n in\n (vk, p) )\n in\n [%log internal] \"Batch_verify_backend_convert_inputs_done\" ;\n [%log internal] \"Batch_verify_backend\" ;\n let%map.Promise result =\n Backend.batch_verify\n (Array.map ~f:fst vks_and_v)\n (Array.map ~f:snd vks_and_v)\n in\n [%log internal] \"Batch_verify_backend_done\" ;\n result\n\n let batch_verify = batch_verify' (fun xs -> List.to_array xs)\n\n let verify ?message t vk xs : bool =\n Backend.verify vk\n (to_backend_with_public_evals'\n (Option.value ~default:[] message)\n (vec_to_array (module Scalar_field.Vector) xs)\n t )\nend\n","open Core_kernel\n\nmodule type Bindings = sig\n type t\n\n val num_limbs : unit -> int\n\n val bytes_per_limb : unit -> int\n\n val compare : t -> t -> int\n\n val div : t -> t -> t\n\n val test_bit : t -> int -> bool\n\n val print : t -> unit\n\n val to_string : t -> string\n\n val of_numeral : string -> int -> int -> t\n\n val of_decimal_string : string -> t\n\n val to_bytes : t -> Bytes.t\n\n val of_bytes : Bytes.t -> t\nend\n\nmodule type Intf = sig\n type t [@@deriving bin_io, sexp, compare]\n\n include Bindings with type t := t\n\n val num_limbs : int\n\n val bytes_per_limb : int\n\n val length_in_bytes : int\n\n val to_hex : t -> string\n\n val to_hex_string : t -> string\n\n val of_hex_string : ?reverse:bool -> string -> t\n\n val of_numeral : string -> base:int -> t\nend\n\nmodule Make\n (B : Bindings) (M : sig\n val length_in_bytes : int\n end) : Intf with type t = B.t = struct\n include B\n\n let num_limbs = num_limbs ()\n\n let bytes_per_limb = bytes_per_limb ()\n\n let length_in_bytes = num_limbs * bytes_per_limb\n\n let to_hex t =\n let data = to_bytes t in\n String.uppercase (Hex.encode ~reverse:true (Bytes.to_string data))\n\n let to_hex_string t = \"0x\" ^ to_hex t\n\n let sexp_of_t t = to_hex_string t |> Sexp.of_string\n\n let of_hex_string ?(reverse = true) s =\n assert (Char.equal s.[0] '0' && Char.equal s.[1] 'x') ;\n let s = String.drop_prefix s 2 in\n Option.try_with (fun () -> Hex.decode ~init:Bytes.init ~reverse s)\n |> Option.value_exn ~here:[%here]\n |> of_bytes\n\n let%test_unit \"hex test\" =\n let bytes =\n String.init length_in_bytes ~f:(fun _ -> Char.of_int_exn (Random.int 255))\n in\n let h = \"0x\" ^ Hex.encode bytes in\n [%test_eq: string] h (String.lowercase (to_hex_string (of_hex_string h)))\n\n let t_of_sexp s = of_hex_string (String.t_of_sexp s)\n\n include Bin_prot.Utils.Of_minimal (struct\n type nonrec t = t\n\n (* increment if serialization changes *)\n let version = 1\n\n let bin_shape_t =\n Bin_prot.Shape.basetype\n (Bin_prot.Shape.Uuid.of_string\n (sprintf \"kimchi_backend_bigint_%d_V%d\" M.length_in_bytes version) )\n []\n\n let __bin_read_t__ _buf ~pos_ref _vint =\n Bin_prot.Common.raise_variant_wrong_type \"Bigint.t\" !pos_ref\n\n let bin_size_t _ = length_in_bytes\n\n let bin_write_t buf ~pos t =\n let bytes = to_bytes t in\n let len = length_in_bytes in\n Bigstring.From_bytes.blit ~src:bytes ~src_pos:0 ~len:length_in_bytes\n ~dst:buf ~dst_pos:pos ;\n pos + len\n\n let bin_read_t buf ~pos_ref =\n let remaining_bytes = Bigstring.length buf - !pos_ref in\n let len = length_in_bytes in\n if remaining_bytes < len then\n failwithf \"Bigint.bin_read_t: Expected %d bytes, got %d\"\n M.length_in_bytes remaining_bytes () ;\n let bytes = Bigstring.To_bytes.sub ~pos:!pos_ref ~len buf in\n pos_ref := len + !pos_ref ;\n of_bytes bytes\n end)\n\n let of_numeral s ~base = of_numeral s (String.length s) base\nend\n","open Core_kernel\nmodule H_list = Snarky_backendless.H_list\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'a t =\n { xt : 'a\n ; yt : 'a\n ; xp : 'a\n ; yp : 'a\n ; n_acc : 'a\n ; xr : 'a\n ; yr : 'a\n ; s1 : 'a\n ; s3 : 'a\n ; b1 : 'a\n ; b2 : 'a\n ; b3 : 'a\n ; b4 : 'a\n }\n [@@deriving sexp, fields, hlist]\n end\nend]\n\nlet map { xt; yt; xp; yp; n_acc; xr; yr; s1; s3; b1; b2; b3; b4 } ~f =\n { xt = f xt\n ; yt = f yt\n ; xp = f xp\n ; yp = f yp\n ; n_acc = f n_acc\n ; xr = f xr\n ; yr = f yr\n ; s1 = f s1\n ; s3 = f s3\n ; b1 = f b1\n ; b2 = f b2\n ; b3 = f b3\n ; b4 = f b4\n }\n\nlet map2 t1 t2 ~f =\n { xt = f t1.xt t2.xt\n ; yt = f t1.yt t2.yt\n ; xp = f t1.xp t2.xp\n ; yp = f t1.yp t2.yp\n ; n_acc = f t1.n_acc t2.n_acc\n ; xr = f t1.xr t2.xr\n ; yr = f t1.yr t2.yr\n ; s1 = f t1.s1 t2.s1\n ; s3 = f t1.s3 t2.s3\n ; b1 = f t1.b1 t2.b1\n ; b2 = f t1.b2 t2.b2\n ; b3 = f t1.b3 t2.b3\n ; b4 = f t1.b4 t2.b4\n }\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'a t =\n { n0 : 'a\n ; n8 : 'a\n ; a0 : 'a\n ; b0 : 'a\n ; a8 : 'a\n ; b8 : 'a\n ; x0 : 'a\n ; x1 : 'a\n ; x2 : 'a\n ; x3 : 'a\n ; x4 : 'a\n ; x5 : 'a\n ; x6 : 'a\n ; x7 : 'a\n }\n [@@deriving sexp, fields, hlist]\n end\nend]\n\nlet map { n0; n8; a0; b0; a8; b8; x0; x1; x2; x3; x4; x5; x6; x7 } ~f =\n { n0 = f n0\n ; n8 = f n8\n ; a0 = f a0\n ; b0 = f b0\n ; a8 = f a8\n ; b8 = f b8\n ; x0 = f x0\n ; x1 = f x1\n ; x2 = f x2\n ; x3 = f x3\n ; x4 = f x4\n ; x5 = f x5\n ; x6 = f x6\n ; x7 = f x7\n }\n\nlet map2 t1 t2 ~f =\n { n0 = f t1.n0 t2.n0\n ; n8 = f t1.n8 t2.n8\n ; a0 = f t1.a0 t2.a0\n ; b0 = f t1.b0 t2.b0\n ; a8 = f t1.a8 t2.a8\n ; b8 = f t1.b8 t2.b8\n ; x0 = f t1.x0 t2.x0\n ; x1 = f t1.x1 t2.x1\n ; x2 = f t1.x2 t2.x2\n ; x3 = f t1.x3 t2.x3\n ; x4 = f t1.x4 t2.x4\n ; x5 = f t1.x5 t2.x5\n ; x6 = f t1.x6 t2.x6\n ; x7 = f t1.x7 t2.x7\n }\n","open Intf\nopen Core_kernel\nmodule Bignum_bigint = Snarky_backendless.Backend_extended.Bignum_bigint\n\nmodule type Input_intf = sig\n type t\n\n module Bigint : Bigint.Intf\n\n val size : unit -> Bigint.t\n\n val size_in_bits : unit -> int\n\n val to_bigint : t -> Bigint.t\n\n val of_bigint : Bigint.t -> t\n\n val of_int : int -> t\n\n val domain_generator : int -> t\n\n val add : t -> t -> t\n\n val sub : t -> t -> t\n\n val mul : t -> t -> t\n\n val div : t -> t -> t\n\n val inv : t -> t option\n\n val negate : t -> t\n\n val square : t -> t\n\n val sqrt : t -> t option\n\n val is_square : t -> bool\n\n val equal : t -> t -> bool\n\n val print : t -> unit\n\n val to_string : t -> string\n\n val of_string : string -> t\n\n val random : unit -> t\n\n val rng : int -> t\n\n val two_adic_root_of_unity : unit -> t\n\n val mut_add : t -> t -> unit\n\n val mut_mul : t -> t -> unit\n\n val mut_square : t -> unit\n\n val mut_sub : t -> t -> unit\n\n val copy : t -> t -> unit\n\n val to_bytes : t -> bytes\n\n val of_bytes : bytes -> t\n\n val domain_generator : int -> t\n\n module Vector : Snarky_intf.Vector.S with type elt = t\nend\n\nmodule type S = sig\n type t [@@deriving sexp, compare, yojson, bin_io, hash]\n\n include Input_intf with type t := t\n\n val size : Bigint.t\n\n val domain_generator : log2_size:int -> t\n\n val one : t\n\n val zero : t\n\n val inv : t -> t\n\n val sqrt : t -> t\n\n val size_in_bits : int\n\n val to_bits : t -> bool list\n\n val of_bits : bool list -> t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n\n val ( / ) : t -> t -> t\n\n module Mutable : sig\n val add : t -> other:t -> unit\n\n val mul : t -> other:t -> unit\n\n val square : t -> unit\n\n val sub : t -> other:t -> unit\n\n val copy : over:t -> t -> unit\n end\n\n val ( += ) : t -> t -> unit\n\n val ( *= ) : t -> t -> unit\n\n val ( -= ) : t -> t -> unit\nend\n\nmodule type S_with_version = sig\n [%%versioned:\n module Stable : sig\n [@@@no_toplevel_latest_type]\n\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t [@@deriving version, sexp, bin_io, compare, yojson, hash, equal]\n end\n end]\n\n include S with type t = Stable.Latest.t\nend\n\nmodule Make (F : Input_intf) :\n S_with_version\n with type Stable.V1.t = F.t\n and module Bigint = F.Bigint\n and module Vector = F.Vector = struct\n include F\n\n let size = size ()\n\n let size_in_bits = size_in_bits ()\n\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = (F.t[@version_asserted]) [@@deriving version]\n\n let to_latest = Fn.id\n\n include\n Binable.Of_binable\n (Bigint)\n (struct\n type nonrec t = t\n\n let to_binable = to_bigint\n\n let of_binable = of_bigint\n end)\n\n include\n Sexpable.Of_sexpable\n (Bigint)\n (struct\n type nonrec t = t\n\n let to_sexpable = to_bigint\n\n let of_sexpable = of_bigint\n end)\n\n let to_bignum_bigint n =\n let rec go i two_to_the_i acc =\n if Int.equal i size_in_bits then acc\n else\n let acc' =\n if Bigint.test_bit n i then Bignum_bigint.(acc + two_to_the_i)\n else acc\n in\n go (i + 1) Bignum_bigint.(two_to_the_i + two_to_the_i) acc'\n in\n go 0 Bignum_bigint.one Bignum_bigint.zero\n\n let hash_fold_t s x =\n Bignum_bigint.hash_fold_t s (to_bignum_bigint (to_bigint x))\n\n let hash = Hash.of_fold hash_fold_t\n\n let compare t1 t2 = Bigint.compare (to_bigint t1) (to_bigint t2)\n\n let equal = equal\n\n let to_yojson t : Yojson.Safe.t =\n `String (Bigint.to_hex_string (to_bigint t))\n\n let of_yojson j =\n match j with\n | `String h ->\n Ok (of_bigint (Bigint.of_hex_string h))\n | _ ->\n Error \"expected hex string\"\n end\n end]\n\n include (\n Stable.Latest : module type of Stable.Latest with type t := Stable.Latest.t )\n\n let domain_generator ~log2_size = domain_generator log2_size\n\n let one = of_int 1\n\n let zero = of_int 0\n\n (* TODO: Improve snarky interface so these aren't necessary.. *)\n let inv x = Option.value (inv x) ~default:zero\n\n let sqrt x = Option.value (sqrt x) ~default:zero\n\n let to_bits t =\n (* Avoids allocation *)\n let n = F.to_bigint t in\n List.init size_in_bits ~f:(Bigint.test_bit n)\n\n let of_bits bs =\n List.fold (List.rev bs) ~init:zero ~f:(fun acc b ->\n let acc = add acc acc in\n if b then add acc one else acc )\n\n let%test_unit \"sexp round trip\" =\n let t = random () in\n assert (equal t (t_of_sexp (sexp_of_t t)))\n\n let%test_unit \"bin_io round trip\" =\n let t = random () in\n [%test_eq: Stable.Latest.t] t\n (Binable.of_string\n (module Stable.Latest)\n (Binable.to_string (module Stable.Latest) t) )\n\n let ( + ) = add\n\n let ( - ) = sub\n\n let ( * ) = mul\n\n let ( / ) = div\n\n module Mutable = struct\n let add t ~other = mut_add t other\n\n let mul t ~other = mut_mul t other\n\n let square = mut_square\n\n let sub t ~other = mut_sub t other\n\n let copy ~over t = copy over t\n end\n\n let op f t other = f t ~other\n\n let ( += ) = op Mutable.add\n\n let ( *= ) = op Mutable.mul\n\n let ( -= ) = op Mutable.sub\n\n let%test \"of_bits to_bits\" =\n let x = random () in\n equal x (of_bits (to_bits x))\n\n let%test_unit \"to_bits of_bits\" =\n Quickcheck.test\n (Quickcheck.Generator.list_with_length\n Int.(size_in_bits - 1)\n Bool.quickcheck_generator )\n ~f:(fun bs ->\n [%test_eq: bool list] (bs @ [ false ]) (to_bits (of_bits bs)) )\nend\n","(* TODO: remove these openings *)\nopen Sponge\nopen Unsigned.Size_t\n\n(* TODO: open Core here instead of opening it multiple times below *)\n\nmodule Kimchi_gate_type = struct\n (* Alias to allow deriving sexp *)\n type t = Kimchi_types.gate_type =\n | Zero\n | Generic\n | Poseidon\n | CompleteAdd\n | VarBaseMul\n | EndoMul\n | EndoMulScalar\n | Lookup\n | CairoClaim\n | CairoInstruction\n | CairoFlags\n | CairoTransition\n | RangeCheck0\n | RangeCheck1\n | ForeignFieldAdd\n | ForeignFieldMul\n | Xor16\n | Rot64\n [@@deriving sexp]\nend\n\n(** A gate interface, parameterized by a field. *)\nmodule type Gate_vector_intf = sig\n open Unsigned\n\n type field\n\n type t\n\n val create : unit -> t\n\n val add : t -> field Kimchi_types.circuit_gate -> unit\n\n val get : t -> int -> field Kimchi_types.circuit_gate\n\n val len : t -> int\n\n val digest : int -> t -> bytes\n\n val to_json : int -> t -> string\nend\n\n(** A row indexing in a constraint system. *)\nmodule Row = struct\n open Core_kernel\n\n (** Either a public input row,\n or a non-public input row that starts at index 0.\n *)\n type t = Public_input of int | After_public_input of int\n [@@deriving hash, sexp, compare]\n\n let to_absolute ~public_input_size = function\n | Public_input i ->\n i\n | After_public_input i ->\n (* the first i rows are public-input rows *)\n i + public_input_size\nend\n\n(* TODO: rename module Position to Permutation/Wiring? *)\n\n(** A position represents the position of a cell in the constraint system. *)\nmodule Position = struct\n open Core_kernel\n\n (** A position is a row and a column. *)\n type 'row t = { row : 'row; col : int } [@@deriving hash, sexp, compare]\n\n (** Generates a full row of positions that each points to itself. *)\n let create_cols (row : 'row) : _ t array =\n Array.init Constants.permutation_cols ~f:(fun i -> { row; col = i })\n\n (** Given a number of columns,\n append enough column wires to get an entire row.\n The wire appended will simply point to themselves,\n so as to not take part in the permutation argument.\n *)\n let append_cols (row : 'row) (cols : _ t array) : _ t array =\n let padding_offset = Array.length cols in\n assert (padding_offset <= Constants.permutation_cols) ;\n let padding_len = Constants.permutation_cols - padding_offset in\n let padding =\n Array.init padding_len ~f:(fun i -> { row; col = i + padding_offset })\n in\n Array.append cols padding\n\n (** Converts an array of [Constants.columns] to [Constants.permutation_cols].\n This is useful to truncate arrays of cells to the ones that only matter for the permutation argument.\n *)\n let cols_to_perms cols = Array.slice cols 0 Constants.permutation_cols\n\n (** Converts a [Position.t] into the Rust-compatible type [Kimchi_types.wire].\n *)\n let to_rust_wire { row; col } : Kimchi_types.wire = { row; col }\nend\n\n(** A gate. *)\nmodule Gate_spec = struct\n open Core_kernel\n\n (* TODO: split kind/coeffs from row/wired_to *)\n\n (** A gate/row/constraint consists of a type (kind), a row, the other cells its columns/cells are connected to (wired_to), and the selector polynomial associated with the gate. *)\n type ('row, 'f) t =\n { kind : Kimchi_gate_type.t\n ; wired_to : 'row Position.t array\n ; coeffs : 'f array\n }\n [@@deriving sexp_of]\n\n (** Applies a function [f] to the [row] of [t] and all the rows of its [wired_to]. *)\n let map_rows (t : (_, _) t) ~f : (_, _) t =\n (* { wire with row = f row } *)\n let wired_to =\n Array.map\n ~f:(fun (pos : _ Position.t) -> { pos with row = f pos.row })\n t.wired_to\n in\n { t with wired_to }\n\n (* TODO: just send the array to Rust directly *)\n let to_rust_gate { kind; wired_to; coeffs } : _ Kimchi_types.circuit_gate =\n let typ = kind in\n let wired_to = Array.map ~f:Position.to_rust_wire wired_to in\n let wires =\n ( wired_to.(0)\n , wired_to.(1)\n , wired_to.(2)\n , wired_to.(3)\n , wired_to.(4)\n , wired_to.(5)\n , wired_to.(6) )\n in\n { typ; wires; coeffs }\nend\n\n(** The PLONK constraints. *)\nmodule Plonk_constraint = struct\n open Core_kernel\n\n (** A PLONK constraint (or gate) can be [Basic], [Poseidon], [EC_add_complete], [EC_scale], [EC_endoscale], [EC_endoscalar], [RangeCheck0], [RangeCheck1], [Xor] *)\n module T = struct\n type ('v, 'f) t =\n | Basic of { l : 'f * 'v; r : 'f * 'v; o : 'f * 'v; m : 'f; c : 'f }\n (** the Poseidon state is an array of states (and states are arrays of size 3). *)\n | Poseidon of { state : 'v array array }\n | EC_add_complete of\n { p1 : 'v * 'v\n ; p2 : 'v * 'v\n ; p3 : 'v * 'v\n ; inf : 'v\n ; same_x : 'v\n ; slope : 'v\n ; inf_z : 'v\n ; x21_inv : 'v\n }\n | EC_scale of { state : 'v Scale_round.t array }\n | EC_endoscale of\n { state : 'v Endoscale_round.t array; xs : 'v; ys : 'v; n_acc : 'v }\n | EC_endoscalar of { state : 'v Endoscale_scalar_round.t array }\n | Lookup of\n { w0 : 'v; w1 : 'v; w2 : 'v; w3 : 'v; w4 : 'v; w5 : 'v; w6 : 'v }\n | RangeCheck0 of\n { v0 : 'v (* Value to constrain to 88-bits *)\n ; v0p0 : 'v (* MSBs *)\n ; v0p1 : 'v (* vpX are 12-bit plookup chunks *)\n ; v0p2 : 'v\n ; v0p3 : 'v\n ; v0p4 : 'v\n ; v0p5 : 'v\n ; v0c0 : 'v (* vcX are 2-bit crumbs *)\n ; v0c1 : 'v\n ; v0c2 : 'v\n ; v0c3 : 'v\n ; v0c4 : 'v\n ; v0c5 : 'v\n ; v0c6 : 'v\n ; v0c7 : 'v (* LSBs *)\n ; (* Coefficients *)\n compact : 'f\n (* Limbs mode coefficient: 0 (standard 3-limb) or 1 (compact 2-limb) *)\n }\n | RangeCheck1 of\n { (* Current row *)\n v2 : 'v (* Value to constrain to 88-bits *)\n ; v12 : 'v (* Optional value used in compact 2-limb mode *)\n ; v2c0 : 'v (* MSBs, 2-bit crumb *)\n ; v2p0 : 'v (* vpX are 12-bit plookup chunks *)\n ; v2p1 : 'v\n ; v2p2 : 'v\n ; v2p3 : 'v\n ; v2c1 : 'v (* vcX are 2-bit crumbs *)\n ; v2c2 : 'v\n ; v2c3 : 'v\n ; v2c4 : 'v\n ; v2c5 : 'v\n ; v2c6 : 'v\n ; v2c7 : 'v\n ; v2c8 : 'v (* LSBs *)\n ; (* Next row *) v2c9 : 'v\n ; v2c10 : 'v\n ; v2c11 : 'v\n ; v0p0 : 'v\n ; v0p1 : 'v\n ; v1p0 : 'v\n ; v1p1 : 'v\n ; v2c12 : 'v\n ; v2c13 : 'v\n ; v2c14 : 'v\n ; v2c15 : 'v\n ; v2c16 : 'v\n ; v2c17 : 'v\n ; v2c18 : 'v\n ; v2c19 : 'v\n }\n | Xor of\n { in1 : 'v\n ; in2 : 'v\n ; out : 'v\n ; in1_0 : 'v\n ; in1_1 : 'v\n ; in1_2 : 'v\n ; in1_3 : 'v\n ; in2_0 : 'v\n ; in2_1 : 'v\n ; in2_2 : 'v\n ; in2_3 : 'v\n ; out_0 : 'v\n ; out_1 : 'v\n ; out_2 : 'v\n ; out_3 : 'v\n }\n | ForeignFieldAdd of\n { left_input_lo : 'v\n ; left_input_mi : 'v\n ; left_input_hi : 'v\n ; right_input_lo : 'v\n ; right_input_mi : 'v\n ; right_input_hi : 'v\n ; field_overflow : 'v\n ; carry : 'v\n ; (* Coefficients *) foreign_field_modulus0 : 'f\n ; foreign_field_modulus1 : 'f\n ; foreign_field_modulus2 : 'f\n ; sign : 'f\n }\n | ForeignFieldMul of\n { left_input0 : 'v\n ; left_input1 : 'v\n ; left_input2 : 'v\n ; right_input0 : 'v\n ; right_input1 : 'v\n ; right_input2 : 'v\n ; remainder01 : 'v\n ; remainder2 : 'v\n ; quotient0 : 'v\n ; quotient1 : 'v\n ; quotient2 : 'v\n ; quotient_hi_bound : 'v\n ; product1_lo : 'v\n ; product1_hi_0 : 'v\n ; product1_hi_1 : 'v\n ; carry0 : 'v\n ; carry1_0 : 'v\n ; carry1_12 : 'v\n ; carry1_24 : 'v\n ; carry1_36 : 'v\n ; carry1_48 : 'v\n ; carry1_60 : 'v\n ; carry1_72 : 'v\n ; carry1_84 : 'v\n ; carry1_86 : 'v\n ; carry1_88 : 'v\n ; carry1_90 : 'v\n ; (* Coefficients *) foreign_field_modulus2 : 'f\n ; neg_foreign_field_modulus0 : 'f\n ; neg_foreign_field_modulus1 : 'f\n ; neg_foreign_field_modulus2 : 'f\n }\n | Rot64 of\n { (* Current row *)\n word : 'v\n ; rotated : 'v\n ; excess : 'v\n ; bound_limb0 : 'v\n ; bound_limb1 : 'v\n ; bound_limb2 : 'v\n ; bound_limb3 : 'v\n ; bound_crumb0 : 'v\n ; bound_crumb1 : 'v\n ; bound_crumb2 : 'v\n ; bound_crumb3 : 'v\n ; bound_crumb4 : 'v\n ; bound_crumb5 : 'v\n ; bound_crumb6 : 'v\n ; bound_crumb7 : 'v\n ; (* Coefficients *) two_to_rot : 'f (* Rotation scalar 2^rot *)\n }\n | AddFixedLookupTable of { id : int32; data : 'f array array }\n | AddRuntimeTableCfg of { id : int32; first_column : 'f array }\n | Raw of\n { kind : Kimchi_gate_type.t; values : 'v array; coeffs : 'f array }\n [@@deriving sexp]\n\n (** map t *)\n let map (type a b f) (t : (a, f) t) ~(f : a -> b) =\n let fp (x, y) = (f x, f y) in\n match t with\n | Basic { l; r; o; m; c } ->\n let p (x, y) = (x, f y) in\n Basic { l = p l; r = p r; o = p o; m; c }\n | Poseidon { state } ->\n Poseidon { state = Array.map ~f:(fun x -> Array.map ~f x) state }\n | EC_add_complete { p1; p2; p3; inf; same_x; slope; inf_z; x21_inv } ->\n EC_add_complete\n { p1 = fp p1\n ; p2 = fp p2\n ; p3 = fp p3\n ; inf = f inf\n ; same_x = f same_x\n ; slope = f slope\n ; inf_z = f inf_z\n ; x21_inv = f x21_inv\n }\n | EC_scale { state } ->\n EC_scale\n { state = Array.map ~f:(fun x -> Scale_round.map ~f x) state }\n | EC_endoscale { state; xs; ys; n_acc } ->\n EC_endoscale\n { state = Array.map ~f:(fun x -> Endoscale_round.map ~f x) state\n ; xs = f xs\n ; ys = f ys\n ; n_acc = f n_acc\n }\n | EC_endoscalar { state } ->\n EC_endoscalar\n { state =\n Array.map ~f:(fun x -> Endoscale_scalar_round.map ~f x) state\n }\n | Lookup { w0; w1; w2; w3; w4; w5; w6 } ->\n Lookup\n { w0 = f w0\n ; w1 = f w1\n ; w2 = f w2\n ; w3 = f w3\n ; w4 = f w4\n ; w5 = f w5\n ; w6 = f w6\n }\n | RangeCheck0\n { v0\n ; v0p0\n ; v0p1\n ; v0p2\n ; v0p3\n ; v0p4\n ; v0p5\n ; v0c0\n ; v0c1\n ; v0c2\n ; v0c3\n ; v0c4\n ; v0c5\n ; v0c6\n ; v0c7\n ; compact\n } ->\n RangeCheck0\n { v0 = f v0\n ; v0p0 = f v0p0\n ; v0p1 = f v0p1\n ; v0p2 = f v0p2\n ; v0p3 = f v0p3\n ; v0p4 = f v0p4\n ; v0p5 = f v0p5\n ; v0c0 = f v0c0\n ; v0c1 = f v0c1\n ; v0c2 = f v0c2\n ; v0c3 = f v0c3\n ; v0c4 = f v0c4\n ; v0c5 = f v0c5\n ; v0c6 = f v0c6\n ; v0c7 = f v0c7\n ; compact\n }\n | RangeCheck1\n { (* Current row *) v2\n ; v12\n ; v2c0\n ; v2p0\n ; v2p1\n ; v2p2\n ; v2p3\n ; v2c1\n ; v2c2\n ; v2c3\n ; v2c4\n ; v2c5\n ; v2c6\n ; v2c7\n ; v2c8\n ; (* Next row *) v2c9\n ; v2c10\n ; v2c11\n ; v0p0\n ; v0p1\n ; v1p0\n ; v1p1\n ; v2c12\n ; v2c13\n ; v2c14\n ; v2c15\n ; v2c16\n ; v2c17\n ; v2c18\n ; v2c19\n } ->\n RangeCheck1\n { (* Current row *) v2 = f v2\n ; v12 = f v12\n ; v2c0 = f v2c0\n ; v2p0 = f v2p0\n ; v2p1 = f v2p1\n ; v2p2 = f v2p2\n ; v2p3 = f v2p3\n ; v2c1 = f v2c1\n ; v2c2 = f v2c2\n ; v2c3 = f v2c3\n ; v2c4 = f v2c4\n ; v2c5 = f v2c5\n ; v2c6 = f v2c6\n ; v2c7 = f v2c7\n ; v2c8 = f v2c8\n ; (* Next row *) v2c9 = f v2c9\n ; v2c10 = f v2c10\n ; v2c11 = f v2c11\n ; v0p0 = f v0p0\n ; v0p1 = f v0p1\n ; v1p0 = f v1p0\n ; v1p1 = f v1p1\n ; v2c12 = f v2c12\n ; v2c13 = f v2c13\n ; v2c14 = f v2c14\n ; v2c15 = f v2c15\n ; v2c16 = f v2c16\n ; v2c17 = f v2c17\n ; v2c18 = f v2c18\n ; v2c19 = f v2c19\n }\n | Xor\n { in1\n ; in2\n ; out\n ; in1_0\n ; in1_1\n ; in1_2\n ; in1_3\n ; in2_0\n ; in2_1\n ; in2_2\n ; in2_3\n ; out_0\n ; out_1\n ; out_2\n ; out_3\n } ->\n Xor\n { in1 = f in1\n ; in2 = f in2\n ; out = f out\n ; in1_0 = f in1_0\n ; in1_1 = f in1_1\n ; in1_2 = f in1_2\n ; in1_3 = f in1_3\n ; in2_0 = f in2_0\n ; in2_1 = f in2_1\n ; in2_2 = f in2_2\n ; in2_3 = f in2_3\n ; out_0 = f out_0\n ; out_1 = f out_1\n ; out_2 = f out_2\n ; out_3 = f out_3\n }\n | ForeignFieldAdd\n { left_input_lo\n ; left_input_mi\n ; left_input_hi\n ; right_input_lo\n ; right_input_mi\n ; right_input_hi\n ; field_overflow\n ; carry\n ; (* Coefficients *) foreign_field_modulus0\n ; foreign_field_modulus1\n ; foreign_field_modulus2\n ; sign\n } ->\n ForeignFieldAdd\n { left_input_lo = f left_input_lo\n ; left_input_mi = f left_input_mi\n ; left_input_hi = f left_input_hi\n ; right_input_lo = f right_input_lo\n ; right_input_mi = f right_input_mi\n ; right_input_hi = f right_input_hi\n ; field_overflow = f field_overflow\n ; carry = f carry\n ; (* Coefficients *) foreign_field_modulus0\n ; foreign_field_modulus1\n ; foreign_field_modulus2\n ; sign\n }\n | ForeignFieldMul\n { left_input0\n ; left_input1\n ; left_input2\n ; right_input0\n ; right_input1\n ; right_input2\n ; remainder01\n ; remainder2\n ; quotient0\n ; quotient1\n ; quotient2\n ; quotient_hi_bound\n ; product1_lo\n ; product1_hi_0\n ; product1_hi_1\n ; carry0\n ; carry1_0\n ; carry1_12\n ; carry1_24\n ; carry1_36\n ; carry1_48\n ; carry1_60\n ; carry1_72\n ; carry1_84\n ; carry1_86\n ; carry1_88\n ; carry1_90\n ; (* Coefficients *) foreign_field_modulus2\n ; neg_foreign_field_modulus0\n ; neg_foreign_field_modulus1\n ; neg_foreign_field_modulus2\n } ->\n ForeignFieldMul\n { left_input0 = f left_input0\n ; left_input1 = f left_input1\n ; left_input2 = f left_input2\n ; right_input0 = f right_input0\n ; right_input1 = f right_input1\n ; right_input2 = f right_input2\n ; remainder01 = f remainder01\n ; remainder2 = f remainder2\n ; quotient0 = f quotient0\n ; quotient1 = f quotient1\n ; quotient2 = f quotient2\n ; quotient_hi_bound = f quotient_hi_bound\n ; product1_lo = f product1_lo\n ; product1_hi_0 = f product1_hi_0\n ; product1_hi_1 = f product1_hi_1\n ; carry0 = f carry0\n ; carry1_0 = f carry1_0\n ; carry1_12 = f carry1_12\n ; carry1_24 = f carry1_24\n ; carry1_36 = f carry1_36\n ; carry1_48 = f carry1_48\n ; carry1_60 = f carry1_60\n ; carry1_72 = f carry1_72\n ; carry1_84 = f carry1_84\n ; carry1_86 = f carry1_86\n ; carry1_88 = f carry1_88\n ; carry1_90 = f carry1_90\n ; (* Coefficients *) foreign_field_modulus2\n ; neg_foreign_field_modulus0\n ; neg_foreign_field_modulus1\n ; neg_foreign_field_modulus2\n }\n | Rot64\n { (* Current row *) word\n ; rotated\n ; excess\n ; bound_limb0\n ; bound_limb1\n ; bound_limb2\n ; bound_limb3\n ; bound_crumb0\n ; bound_crumb1\n ; bound_crumb2\n ; bound_crumb3\n ; bound_crumb4\n ; bound_crumb5\n ; bound_crumb6\n ; bound_crumb7\n ; (* Coefficients *) two_to_rot\n } ->\n Rot64\n { word = f word\n ; rotated = f rotated\n ; excess = f excess\n ; bound_limb0 = f bound_limb0\n ; bound_limb1 = f bound_limb1\n ; bound_limb2 = f bound_limb2\n ; bound_limb3 = f bound_limb3\n ; bound_crumb0 = f bound_crumb0\n ; bound_crumb1 = f bound_crumb1\n ; bound_crumb2 = f bound_crumb2\n ; bound_crumb3 = f bound_crumb3\n ; bound_crumb4 = f bound_crumb4\n ; bound_crumb5 = f bound_crumb5\n ; bound_crumb6 = f bound_crumb6\n ; bound_crumb7 = f bound_crumb7\n ; (* Coefficients *) two_to_rot\n }\n | AddFixedLookupTable { id; data } ->\n (* TODO: see a possible better API -\n https://github.com/MinaProtocol/mina/issues/13984 *)\n AddFixedLookupTable { id; data }\n | AddRuntimeTableCfg { id; first_column } ->\n AddRuntimeTableCfg { id; first_column }\n | Raw { kind; values; coeffs } ->\n Raw { kind; values = Array.map ~f values; coeffs }\n\n (** [eval (module F) get_variable gate] checks that [gate]'s polynomial is\n satisfied by the assignments given by [get_variable].\n Warning: currently only implemented for the [Basic] gate.\n *)\n let eval (type v f)\n (module F : Snarky_backendless.Field_intf.S with type t = f)\n (eval_one : v -> f) (t : (v, f) t) =\n match t with\n (* cl * vl + cr * vr + co * vo + m * vl*vr + c = 0 *)\n | Basic { l = cl, vl; r = cr, vr; o = co, vo; m; c } ->\n let vl = eval_one vl in\n let vr = eval_one vr in\n let vo = eval_one vo in\n let open F in\n let res =\n List.reduce_exn ~f:add\n [ mul cl vl; mul cr vr; mul co vo; mul m (mul vl vr); c ]\n in\n if not (equal zero res) then (\n eprintf\n !\"%{sexp:t} * %{sexp:t}\\n\\\n + %{sexp:t} * %{sexp:t}\\n\\\n + %{sexp:t} * %{sexp:t}\\n\\\n + %{sexp:t} * %{sexp:t}\\n\\\n + %{sexp:t}\\n\\\n = %{sexp:t}%!\"\n cl vl cr vr co vo m (mul vl vr) c res ;\n false )\n else true\n | _ ->\n true\n end\n\n include T\n\n (* Adds our constraint enum to the list of constraints handled by Snarky. *)\n include Snarky_backendless.Constraint.Add_kind (T)\nend\n\nmodule Internal_var = Core_kernel.Unique_id.Int ()\n\nmodule V = struct\n open Core_kernel\n\n module T = struct\n (** Variables linking uses of the same data between different gates.\n\n Every internal variable is computable from a finite list of external\n variables and internal variables.\n Currently, in fact, every internal variable is a linear combination of\n external variables and previously generated internal variables.\n *)\n type t =\n | External of int\n (** An external variable (generated by snarky, via [exists]). *)\n | Internal of Internal_var.t\n (** An internal variable is generated to hold an intermediate value\n (e.g., in reducing linear combinations to single PLONK positions).\n *)\n [@@deriving compare, hash, sexp]\n end\n\n include T\n include Comparable.Make (T)\n include Hashable.Make (T)\nend\n\n(** Keeps track of a circuit (which is a list of gates)\n while it is being written.\n *)\ntype ('f, 'rust_gates) circuit =\n | Unfinalized_rev of (unit, 'f) Gate_spec.t list\n (** A circuit still being written. *)\n | Compiled of Core_kernel.Md5.t * 'rust_gates\n (** Once finalized, a circuit is represented as a digest\n and a list of gates that corresponds to the circuit.\n *)\n\ntype 'f fixed_lookup_tables =\n | Unfinalized_fixed_lookup_tables_rev of 'f Kimchi_types.lookup_table list\n | Compiled_fixed_lookup_tables of 'f Kimchi_types.lookup_table array\n\ntype 'f runtime_tables_cfg =\n | Unfinalized_runtime_tables_cfg_rev of 'f Kimchi_types.runtime_table_cfg list\n | Compiled_runtime_tables_cfg of 'f Kimchi_types.runtime_table_cfg array\n\n(** The constraint system. *)\ntype ('f, 'rust_gates) t =\n { (* Map of cells that share the same value (enforced by to the permutation). *)\n equivalence_classes : Row.t Position.t list V.Table.t\n ; (* How to compute each internal variable (as a linear combination of other variables). *)\n internal_vars : (('f * V.t) list * 'f option) Internal_var.Table.t\n ; (* The variables that hold each witness value for each row, in reverse order. *)\n mutable rows_rev : V.t option array list\n ; (* A circuit is described by a series of gates.\n A gate is finalized once [finalize_and_get_gates] is called.\n The finalized tag contains the digest of the circuit.\n *)\n mutable gates : ('f, 'rust_gates) circuit\n (* Witnesses values corresponding to each runtime lookups *)\n ; mutable runtime_lookups_rev : (V.t * (V.t * V.t)) list\n (* The user-provided lookup tables associated with this circuit. *)\n ; mutable fixed_lookup_tables : 'f fixed_lookup_tables\n (* The user-provided runtime table configurations associated with this\n circuit. *)\n ; mutable runtime_tables_cfg : 'f runtime_tables_cfg\n ; (* The row to use the next time we add a constraint. *)\n mutable next_row : int\n ; (* The size of the public input (which fills the first rows of our constraint system. *)\n public_input_size : int Core_kernel.Set_once.t\n ; (* The number of previous recursion challenges. *)\n prev_challenges : int Core_kernel.Set_once.t\n ; (* Whatever is not public input. *)\n mutable auxiliary_input_size : int\n ; (* Queue (of size 1) of generic gate. *)\n mutable pending_generic_gate :\n (V.t option * V.t option * V.t option * 'f array) option\n ; (* V.t's corresponding to constant values. We reuse them so we don't need to\n use a fresh generic constraint each time to create a constant.\n *)\n cached_constants : ('f, V.t) Core_kernel.Hashtbl.t\n (* The [equivalence_classes] field keeps track of the positions which must be\n enforced to be equivalent due to the fact that they correspond to the same V.t value.\n I.e., positions that are different usages of the same [V.t].\n\n We use a union-find data structure to track equalities that a constraint system wants\n enforced *between* [V.t] values. Then, at the end, for all [V.t]s that have been unioned\n together, we combine their equivalence classes in the [equivalence_classes] table into\n a single equivalence class, so that the permutation argument enforces these desired equalities\n as well.\n *)\n ; union_finds : V.t Core_kernel.Union_find.t V.Table.t\n }\n\nlet get_public_input_size sys = sys.public_input_size\n\nlet get_rows_len sys = List.length sys.rows_rev\n\nlet get_prev_challenges sys = sys.prev_challenges\n\nlet set_prev_challenges sys challenges =\n Core_kernel.Set_once.set_exn sys.prev_challenges [%here] challenges\n\nlet get_concatenated_fixed_lookup_table_size sys =\n match sys.fixed_lookup_tables with\n | Unfinalized_fixed_lookup_tables_rev _ ->\n failwith\n \"Cannot get the fixed lookup tables before finalizing the constraint \\\n system\"\n | Compiled_fixed_lookup_tables flts ->\n let get_table_size (flt : _ Kimchi_types.lookup_table) =\n if Array.length flt.data = 0 then 0\n else Array.length (Array.get flt.data 0)\n in\n Array.fold_left (fun acc flt -> acc + get_table_size flt) 0 flts\n\nlet get_concatenated_runtime_lookup_table_size sys =\n match sys.runtime_tables_cfg with\n | Unfinalized_runtime_tables_cfg_rev _ ->\n failwith\n \"Cannot get the runtime table configurations before finalizing the \\\n constraint system\"\n | Compiled_runtime_tables_cfg rt_cfgs ->\n Array.fold_left\n (fun acc (rt_cfg : _ Kimchi_types.runtime_table_cfg) ->\n acc + Array.length rt_cfg.first_column )\n 0 rt_cfgs\n\nlet finalize_fixed_lookup_tables sys =\n match sys.fixed_lookup_tables with\n | Unfinalized_fixed_lookup_tables_rev fixed_lt_rev ->\n sys.fixed_lookup_tables <-\n Compiled_fixed_lookup_tables\n (Core_kernel.Array.of_list_rev fixed_lt_rev)\n | Compiled_fixed_lookup_tables _ ->\n failwith \"Fixed lookup tables have already been finalized\"\n\nlet finalize_runtime_lookup_tables sys =\n match sys.runtime_tables_cfg with\n | Unfinalized_runtime_tables_cfg_rev rt_cfgs_rev ->\n sys.runtime_tables_cfg <-\n Compiled_runtime_tables_cfg (Core_kernel.Array.of_list_rev rt_cfgs_rev)\n | Compiled_runtime_tables_cfg _ ->\n failwith \"Runtime table configurations have already been finalized\"\n\n(* TODO: shouldn't that Make create something bounded by a signature? As we know what a back end should be? Check where this is used *)\n\n(* TODO: glossary of terms in this file (terms, reducing, feeding) + module doc *)\n\n(* TODO: rename Fp to F or Field *)\n\n(** ? *)\nmodule Make\n (Fp : Field.S)\n (* We create a type for gate vector, instead of using `Gate.t list`. If we did, we would have to convert it to a `Gate.t array` to pass it across the FFI boundary, where then it gets converted to a `Vec`; it's more efficient to just create the `Vec` directly.\n *)\n (Gates : Gate_vector_intf with type field := Fp.t)\n (Params : sig\n val params : Fp.t Params.t\n end) : sig\n open Core_kernel\n\n type nonrec t = (Fp.t, Gates.t) t\n\n val create : unit -> t\n\n val get_public_input_size : t -> int Set_once.t\n\n val get_primary_input_size : t -> int\n\n val set_primary_input_size : t -> int -> unit\n\n val get_auxiliary_input_size : t -> int\n\n val set_auxiliary_input_size : t -> int -> unit\n\n val get_prev_challenges : t -> int option\n\n val set_prev_challenges : t -> int -> unit\n\n val get_rows_len : t -> int\n\n val next_row : t -> int\n\n val get_concatenated_fixed_lookup_table_size : t -> int\n\n val get_concatenated_runtime_lookup_table_size : t -> int\n\n (** Finalize the fixed lookup tables. The function can not be called twice *)\n val finalize_fixed_lookup_tables : t -> unit\n\n (** Finalize the runtime lookup table configurations. The function can not be\n called twice. *)\n val finalize_runtime_lookup_tables : t -> unit\n\n val add_constraint :\n ?label:string\n -> t\n -> ( Fp.t Snarky_backendless.Cvar.t\n , Fp.t )\n Snarky_backendless.Constraint.basic\n -> unit\n\n val compute_witness :\n t\n -> (int -> Fp.t)\n -> Fp.t array array * Fp.t Kimchi_types.runtime_table array\n\n val finalize : t -> unit\n\n val finalize_and_get_gates :\n t\n -> Gates.t\n * Fp.t Kimchi_types.lookup_table array\n * Fp.t Kimchi_types.runtime_table_cfg array\n\n val num_constraints : t -> int\n\n val digest : t -> Md5.t\n\n val to_json : t -> string\nend = struct\n open Core_kernel\n open Pickles_types\n\n (* Used by compute_witness to build the runtime tables from the Lookup\n constraint *)\n module MapRuntimeTable = struct\n module T = struct\n type t = int32 * Fp.t [@@deriving hash, sexp, compare]\n end\n\n include T\n include Core_kernel.Hashable.Make (T)\n end\n\n type nonrec t = (Fp.t, Gates.t) t\n\n (** Converts the set of permutations (equivalence_classes) to\n a hash table that maps each position to the next one.\n For example, if one of the equivalence class is [pos1, pos3, pos7],\n the function will return a hashtable that maps pos1 to pos3,\n pos3 to pos7, and pos7 to pos1.\n *)\n let equivalence_classes_to_hashtbl sys =\n let module Relative_position = struct\n module T = struct\n type t = Row.t Position.t [@@deriving hash, sexp, compare]\n end\n\n include T\n include Core_kernel.Hashable.Make (T)\n end in\n let equivalence_classes = V.Table.create () in\n Hashtbl.iteri sys.equivalence_classes ~f:(fun ~key ~data ->\n let u = Hashtbl.find_exn sys.union_finds key in\n Hashtbl.update equivalence_classes (Union_find.get u) ~f:(function\n | None ->\n Relative_position.Hash_set.of_list data\n | Some ps ->\n List.iter ~f:(Hash_set.add ps) data ;\n ps ) ) ;\n let res = Relative_position.Table.create () in\n Hashtbl.iter equivalence_classes ~f:(fun ps ->\n let rotate_left = function [] -> [] | x :: xs -> xs @ [ x ] in\n let ps =\n Hash_set.to_list ps |> List.sort ~compare:[%compare: Row.t Position.t]\n in\n List.iter2_exn ps (rotate_left ps) ~f:(fun input output ->\n Hashtbl.add_exn res ~key:input ~data:output ) ) ;\n res\n\n (** Compute the witness, given the constraint system `sys`\n and a function that converts the indexed secret inputs to their concrete values.\n *)\n let compute_witness (sys : t) (external_values : int -> Fp.t) :\n Fp.t array array * Fp.t Kimchi_types.runtime_table array =\n let internal_values : Fp.t Internal_var.Table.t =\n Internal_var.Table.create ()\n in\n let public_input_size = Set_once.get_exn sys.public_input_size [%here] in\n let num_rows = public_input_size + sys.next_row in\n let res =\n Array.init Constants.columns ~f:(fun _ ->\n Array.create ~len:num_rows Fp.zero )\n in\n (* Public input *)\n for i = 0 to public_input_size - 1 do\n res.(0).(i) <- external_values i\n done ;\n let find t k =\n match Hashtbl.find t k with\n | None ->\n failwithf !\"Could not find %{sexp:Internal_var.t}\\n%!\" k ()\n | Some x ->\n x\n in\n (* Compute an internal variable associated value. *)\n let compute ((lc, c) : (Fp.t * V.t) list * Fp.t option) =\n List.fold lc ~init:(Option.value c ~default:Fp.zero) ~f:(fun acc (s, x) ->\n let x =\n match x with\n | External x ->\n external_values x\n | Internal x ->\n find internal_values x\n in\n Fp.(acc + (s * x)) )\n in\n (* Update the witness table with the value of the variables from each row. *)\n List.iteri (List.rev sys.rows_rev) ~f:(fun i_after_input cols ->\n let row_idx = i_after_input + public_input_size in\n Array.iteri cols ~f:(fun col_idx var ->\n match var with\n | None ->\n ()\n | Some (External var) ->\n res.(col_idx).(row_idx) <- external_values var\n | Some (Internal var) ->\n let lc = find sys.internal_vars var in\n let value = compute lc in\n res.(col_idx).(row_idx) <- value ;\n Hashtbl.set internal_values ~key:var ~data:value ) ) ;\n\n let map_runtime_tables = MapRuntimeTable.Table.create () in\n let runtime_tables : Fp.t Kimchi_types.runtime_table array =\n match sys.runtime_tables_cfg with\n | Unfinalized_runtime_tables_cfg_rev _ ->\n failwith\n \"Attempted to generate a witness for an unfinalized constraint \\\n system\"\n | Compiled_runtime_tables_cfg cfgs ->\n Array.mapi cfgs ~f:(fun rt_idx { Kimchi_types.id; first_column } ->\n let data =\n Array.mapi first_column ~f:(fun i v ->\n ignore\n (* `add` leaves the value unchanged if the index has been\n already used. Therefore, it keeps the first value.\n This handles the case that the first column has\n duplicated index values.\n *)\n @@ MapRuntimeTable.Table.add map_runtime_tables ~key:(id, v)\n ~data:(i, rt_idx) ;\n (* default padding value for lookup *)\n Fp.zero )\n in\n let rt : Fp.t Kimchi_types.runtime_table = { id; data } in\n rt )\n in\n\n (* Fill in the used entries of the runtime lookup tables. *)\n List.iter (List.rev sys.runtime_lookups_rev) ~f:(fun (id, (idx, v)) ->\n let compute_value x = compute ([ (Fp.one, x) ], None) in\n let vid = compute_value id in\n let vidx = compute_value idx in\n let vv = compute_value v in\n (* FIXME: we should have a int32 here. We are not sure the ID will be a\n int32. We should enforce that.\n See https://github.com/MinaProtocol/mina/issues/13955\n *)\n let id_int32 = Int32.of_string @@ Fp.to_string vid in\n (* Using find allows to handle fixed lookup tables\n As the map has been built from the runtime table configurations,\n except in the case that a runtime table and a fixed table shares the\n same ID, the lookups in fixed lookup tables will return None.\n See https://github.com/MinaProtocol/mina/issues/14016\n *)\n let v =\n MapRuntimeTable.Table.find map_runtime_tables (id_int32, vidx)\n in\n if Option.is_some v then\n let i, rt_idx = Option.value_exn v in\n let rt = runtime_tables.(rt_idx) in\n (* Important note: we do not check if the value has been set before.\n Therefore, it will always use the latest value *)\n rt.data.(i) <- vv ) ;\n (* Return the witness. *)\n (res, runtime_tables)\n\n let union_find sys v =\n Hashtbl.find_or_add sys.union_finds v ~default:(fun () ->\n Union_find.create v )\n\n (** Creates an internal variable and assigns it the value lc and constant. *)\n let create_internal ?constant sys lc : V.t =\n let v = Internal_var.create () in\n ignore (union_find sys (Internal v) : _ Union_find.t) ;\n Hashtbl.add_exn sys.internal_vars ~key:v ~data:(lc, constant) ;\n V.Internal v\n\n (* Initializes a constraint system. *)\n let create () : t =\n { public_input_size = Set_once.create ()\n ; prev_challenges = Set_once.create ()\n ; internal_vars = Internal_var.Table.create ()\n ; gates = Unfinalized_rev [] (* Gates.create () *)\n ; runtime_lookups_rev = []\n ; fixed_lookup_tables = Unfinalized_fixed_lookup_tables_rev []\n ; runtime_tables_cfg = Unfinalized_runtime_tables_cfg_rev []\n ; rows_rev = []\n ; next_row = 0\n ; equivalence_classes = V.Table.create ()\n ; auxiliary_input_size = 0\n ; pending_generic_gate = None\n ; cached_constants = Hashtbl.create (module Fp)\n ; union_finds = V.Table.create ()\n }\n\n (** Returns the number of auxiliary inputs. *)\n let get_auxiliary_input_size t = t.auxiliary_input_size\n\n (** Returns the number of public inputs. *)\n let get_primary_input_size t = Set_once.get_exn t.public_input_size [%here]\n\n (** Returns the number of previous challenges. *)\n let get_prev_challenges t = Set_once.get t.prev_challenges\n\n (* Non-public part of the witness. *)\n let set_auxiliary_input_size t x = t.auxiliary_input_size <- x\n\n (** Sets the number of public-input. It must and can only be called once. *)\n let set_primary_input_size (sys : t) num_pub_inputs =\n Set_once.set_exn sys.public_input_size [%here] num_pub_inputs\n\n (** Sets the number of previous challenges. It must and can only be called once. *)\n let set_prev_challenges (sys : t) num_prev_challenges =\n Set_once.set_exn sys.prev_challenges [%here] num_prev_challenges\n\n let get_public_input_size (sys : t) = get_public_input_size sys\n\n let get_rows_len (sys : t) = get_rows_len sys\n\n let next_row (sys : t) = sys.next_row\n\n let get_concatenated_fixed_lookup_table_size (sys : t) =\n get_concatenated_fixed_lookup_table_size sys\n\n let get_concatenated_runtime_lookup_table_size (sys : t) =\n get_concatenated_runtime_lookup_table_size sys\n\n let finalize_fixed_lookup_tables = finalize_fixed_lookup_tables\n\n let finalize_runtime_lookup_tables = finalize_runtime_lookup_tables\n\n (** Adds {row; col} to the system's wiring under a specific key.\n A key is an external or internal variable.\n The row must be given relative to the start of the circuit\n (so at the start of the public-input rows). *)\n let wire' sys key row (col : int) =\n ignore (union_find sys key : V.t Union_find.t) ;\n V.Table.add_multi sys.equivalence_classes ~key ~data:{ row; col }\n\n (* TODO: rename to wire_abs and wire_rel? or wire_public and wire_after_public? or force a single use function that takes a Row.t? *)\n\n (** Same as wire', except that the row must be given relatively to the end of the public-input rows. *)\n let wire sys key row col = wire' sys key (Row.After_public_input row) col\n\n (** Adds a row/gate/constraint to a constraint system `sys`. *)\n let add_row sys (vars : V.t option array) kind coeffs =\n match sys.gates with\n | Compiled _ ->\n failwith \"add_row called on finalized constraint system\"\n | Unfinalized_rev gates ->\n (* As we're adding a row, we're adding new cells.\n If these cells (the first 7) contain variables,\n make sure that they are wired\n *)\n let num_vars = min Constants.permutation_cols (Array.length vars) in\n let vars_for_perm = Array.slice vars 0 num_vars in\n Array.iteri vars_for_perm ~f:(fun col x ->\n Option.iter x ~f:(fun x -> wire sys x sys.next_row col) ) ;\n (* Add to gates. *)\n let open Position in\n sys.gates <- Unfinalized_rev ({ kind; wired_to = [||]; coeffs } :: gates) ;\n (* Increment row. *)\n sys.next_row <- sys.next_row + 1 ;\n (* Add to row. *)\n sys.rows_rev <- vars :: sys.rows_rev\n\n (** Adds zero-knowledgeness to the gates/rows,\n and convert into Rust type [Gates.t].\n This can only be called once.\n *)\n let rec finalize_and_get_gates sys =\n match sys with\n | { gates = Compiled (_, gates)\n ; fixed_lookup_tables = Compiled_fixed_lookup_tables fixed_lookup_tables\n ; runtime_tables_cfg = Compiled_runtime_tables_cfg runtime_tables_cfg\n ; _\n } ->\n (gates, fixed_lookup_tables, runtime_tables_cfg)\n (* Finalizing lookup tables and runtime table cfgs first *)\n | { fixed_lookup_tables = Unfinalized_fixed_lookup_tables_rev _; _ } ->\n finalize_fixed_lookup_tables sys ;\n finalize_and_get_gates sys\n | { runtime_tables_cfg = Unfinalized_runtime_tables_cfg_rev _; _ } ->\n finalize_runtime_lookup_tables sys ;\n finalize_and_get_gates sys\n | { pending_generic_gate = Some (l, r, o, coeffs); _ } ->\n (* Finalize any pending generic constraint first. *)\n add_row sys [| l; r; o |] Generic coeffs ;\n sys.pending_generic_gate <- None ;\n finalize_and_get_gates sys\n | { gates = Unfinalized_rev gates_rev\n ; fixed_lookup_tables = Compiled_fixed_lookup_tables fixed_lookup_tables\n ; runtime_tables_cfg = Compiled_runtime_tables_cfg runtime_tables_cfg\n ; _\n } ->\n let rust_gates = Gates.create () in\n\n (* Create rows for public input. *)\n let public_input_size =\n Set_once.get_exn sys.public_input_size [%here]\n in\n let pub_selectors = [| Fp.one; Fp.zero; Fp.zero; Fp.zero; Fp.zero |] in\n let pub_input_gate_specs_rev = ref [] in\n for row = 0 to public_input_size - 1 do\n let public_var = V.External row in\n wire' sys public_var (Row.Public_input row) 0 ;\n pub_input_gate_specs_rev :=\n { Gate_spec.kind = Generic\n ; wired_to = [||]\n ; coeffs = pub_selectors\n }\n :: !pub_input_gate_specs_rev\n done ;\n\n (* Construct permutation hashmap. *)\n let pos_map = equivalence_classes_to_hashtbl sys in\n let permutation (pos : Row.t Position.t) : Row.t Position.t =\n Option.value (Hashtbl.find pos_map pos) ~default:pos\n in\n\n let update_gate_with_permutation_info (row : Row.t)\n (gate : (unit, _) Gate_spec.t) : (Row.t, _) Gate_spec.t =\n { gate with\n wired_to =\n Array.init Constants.permutation_cols ~f:(fun col ->\n permutation { row; col } )\n }\n in\n\n (* Process public gates. *)\n let public_gates = List.rev !pub_input_gate_specs_rev in\n let public_gates =\n List.mapi public_gates ~f:(fun absolute_row gate ->\n update_gate_with_permutation_info (Row.Public_input absolute_row)\n gate )\n in\n\n (* construct all the other gates (except zero-knowledge rows) *)\n let gates = List.rev gates_rev in\n let gates =\n List.mapi gates ~f:(fun relative_row gate ->\n update_gate_with_permutation_info\n (Row.After_public_input relative_row) gate )\n in\n\n (* concatenate and convert to absolute rows *)\n let to_absolute_row =\n Gate_spec.map_rows ~f:(Row.to_absolute ~public_input_size)\n in\n\n (* convert all the gates into our Gates.t Rust vector type *)\n let add_gates gates =\n List.iter gates ~f:(fun g ->\n let g = to_absolute_row g in\n Gates.add rust_gates (Gate_spec.to_rust_gate g) )\n in\n add_gates public_gates ;\n add_gates gates ;\n\n (* compute the circuit's digest *)\n let digest = Gates.digest public_input_size rust_gates in\n let md5_digest = Md5.digest_bytes digest in\n\n (* drop the gates, we don't need them anymore *)\n sys.gates <- Compiled (md5_digest, rust_gates) ;\n\n (* return the gates *)\n (rust_gates, fixed_lookup_tables, runtime_tables_cfg)\n\n (** Calls [finalize_and_get_gates] and ignores the result. *)\n let finalize t =\n ignore\n ( finalize_and_get_gates t\n : Gates.t\n * Fp.t Kimchi_types.lookup_table array\n * Fp.t Kimchi_types.runtime_table_cfg array )\n\n let num_constraints sys =\n let gates, _, _ = finalize_and_get_gates sys in\n Gates.len gates\n\n let to_json (sys : t) : string =\n (* TODO: add lookup tables and runtime table cfgs *)\n (* https://github.com/MinaProtocol/mina/issues/13886 *)\n let gates, _, _ = finalize_and_get_gates sys in\n let public_input_size = Set_once.get_exn sys.public_input_size [%here] in\n Gates.to_json public_input_size gates\n\n (* Returns a hash of the circuit. *)\n let rec digest (sys : t) =\n match sys.gates with\n | Unfinalized_rev _ ->\n finalize sys ; digest sys\n | Compiled (digest, _) ->\n digest\n\n (** Regroup terms that share the same variable.\n For example, (3, i2) ; (2, i2) can be simplified to (5, i2).\n It assumes that the list of given terms is sorted,\n and that i0 is the smallest one.\n For example, `i0 = 1` and `terms = [(_, 2); (_, 2); (_; 4); ...]`\n\n Returns `(last_scalar, last_variable, terms, terms_length)`\n where terms does not contain the last scalar and last variable observed.\n *)\n let accumulate_terms terms =\n List.fold terms ~init:Int.Map.empty ~f:(fun acc (x, i) ->\n Map.change acc i ~f:(fun y ->\n let res = match y with None -> x | Some y -> Fp.add x y in\n if Fp.(equal zero res) then None else Some res ) )\n\n (** Converts a [Cvar.t] to a `(terms, terms_length, has_constant)`.\n if `has_constant` is set, then terms start with a constant term in the form of (c, 0).\n *)\n let canonicalize x =\n let c, terms =\n Fp.(\n Snarky_backendless.Cvar.to_constant_and_terms ~add ~mul ~zero:(of_int 0)\n ~equal ~one:(of_int 1))\n x\n in\n (* Note: [(c, 0)] represents the field element [c] multiplied by the 0th\n variable, which is held constant as [Field.one].\n *)\n let terms = match c with None -> terms | Some c -> (c, 0) :: terms in\n let has_constant_term = Option.is_some c in\n let terms = accumulate_terms terms in\n let terms_list =\n Map.fold_right ~init:[] terms ~f:(fun ~key ~data acc ->\n (data, key) :: acc )\n in\n Some (terms_list, Map.length terms, has_constant_term)\n\n (** Adds a generic constraint to the constraint system.\n As there are two generic gates per row, we queue\n every other generic gate.\n *)\n let add_generic_constraint ?l ?r ?o coeffs sys : unit =\n match sys.pending_generic_gate with\n (* if the queue of generic gate is empty, queue this *)\n | None ->\n sys.pending_generic_gate <- Some (l, r, o, coeffs)\n (* otherwise empty the queue and create the row *)\n | Some (l2, r2, o2, coeffs2) ->\n let coeffs = Array.append coeffs coeffs2 in\n add_row sys [| l; r; o; l2; r2; o2 |] Generic coeffs ;\n sys.pending_generic_gate <- None\n\n (** Converts a number of scaled additions \\sum s_i * x_i\n to as many constraints as needed,\n creating temporary variables for each new row/constraint,\n and returning the output variable.\n\n For example, [(s1, x1), (s2, x2)] is transformed into:\n - internal_var_1 = s1 * x1 + s2 * x2\n - return (1, internal_var_1)\n\n and [(s1, x1), (s2, x2), (s3, x3)] is transformed into:\n - internal_var_1 = s1 * x1 + s2 * x2\n - internal_var_2 = 1 * internal_var_1 + s3 * x3\n - return (1, internal_var_2)\n\n It assumes that the list of terms is not empty. *)\n let completely_reduce sys (terms : (Fp.t * int) list) =\n (* just adding constrained variables without values *)\n let rec go = function\n | [] ->\n assert false\n | [ (s, x) ] ->\n (s, V.External x)\n | (ls, lx) :: t ->\n let lx = V.External lx in\n (* TODO: this should be rewritten to be tail-optimized *)\n let rs, rx = go t in\n let s1x1_plus_s2x2 = create_internal sys [ (ls, lx); (rs, rx) ] in\n add_generic_constraint ~l:lx ~r:rx ~o:s1x1_plus_s2x2\n [| ls; rs; Fp.(negate one); Fp.zero; Fp.zero |]\n sys ;\n (Fp.one, s1x1_plus_s2x2)\n in\n go terms\n\n (** Converts a linear combination of variables into a set of constraints.\n It returns the output variable as (1, `Var res),\n unless the output is a constant, in which case it returns (c, `Constant).\n *)\n let reduce_lincom sys (x : Fp.t Snarky_backendless.Cvar.t) =\n let constant, terms =\n Fp.(\n Snarky_backendless.Cvar.to_constant_and_terms ~add ~mul ~zero:(of_int 0)\n ~equal ~one:(of_int 1))\n x\n in\n let terms = accumulate_terms terms in\n let terms_list =\n Map.fold_right ~init:[] terms ~f:(fun ~key ~data acc ->\n (data, key) :: acc )\n in\n match (constant, Map.is_empty terms) with\n | Some c, true ->\n (c, `Constant)\n | None, true ->\n (Fp.zero, `Constant)\n | _ -> (\n match terms_list with\n | [] ->\n assert false\n | [ (ls, lx) ] -> (\n match constant with\n | None ->\n (ls, `Var (V.External lx))\n | Some c ->\n (* res = ls * lx + c *)\n let res =\n create_internal ~constant:c sys [ (ls, External lx) ]\n in\n add_generic_constraint ~l:(External lx) ~o:res\n [| ls; Fp.zero; Fp.(negate one); Fp.zero; c |]\n (* Could be here *)\n sys ;\n (Fp.one, `Var res) )\n | (ls, lx) :: tl ->\n (* reduce the terms, then add the constant *)\n let rs, rx = completely_reduce sys tl in\n let res =\n create_internal ?constant sys [ (ls, External lx); (rs, rx) ]\n in\n (* res = ls * lx + rs * rx + c *)\n add_generic_constraint ~l:(External lx) ~r:rx ~o:res\n [| ls\n ; rs\n ; Fp.(negate one)\n ; Fp.zero\n ; (match constant with Some x -> x | None -> Fp.zero)\n |]\n (* Could be here *)\n sys ;\n (Fp.one, `Var res) )\n\n (** Adds a constraint to the constraint system. *)\n let add_constraint ?label:_ sys\n (constr :\n ( Fp.t Snarky_backendless.Cvar.t\n , Fp.t )\n Snarky_backendless.Constraint.basic ) =\n let red = reduce_lincom sys in\n (* reduce any [Cvar.t] to a single internal variable *)\n let reduce_to_v (x : Fp.t Snarky_backendless.Cvar.t) : V.t =\n match red x with\n | s, `Var x ->\n if Fp.equal s Fp.one then x\n else\n let sx = create_internal sys [ (s, x) ] in\n (* s * x - sx = 0 *)\n add_generic_constraint ~l:x ~o:sx\n [| s; Fp.zero; Fp.(negate one); Fp.zero; Fp.zero |]\n sys ;\n sx\n | s, `Constant -> (\n match Hashtbl.find sys.cached_constants s with\n | Some x ->\n x\n | None ->\n let x = create_internal sys ~constant:s [] in\n add_generic_constraint ~l:x\n [| Fp.one; Fp.zero; Fp.zero; Fp.zero; Fp.negate s |]\n sys ;\n Hashtbl.set sys.cached_constants ~key:s ~data:x ;\n x )\n in\n match constr with\n | Snarky_backendless.Constraint.Square (v1, v2) -> (\n match (red v1, red v2) with\n | (sl, `Var xl), (so, `Var xo) ->\n (* (sl * xl)^2 = so * xo\n sl^2 * xl * xl - so * xo = 0\n *)\n add_generic_constraint ~l:xl ~r:xl ~o:xo\n [| Fp.zero; Fp.zero; Fp.negate so; Fp.(sl * sl); Fp.zero |]\n sys\n | (sl, `Var xl), (so, `Constant) ->\n (* TODO: it's hard to read the array of selector values, name them! *)\n add_generic_constraint ~l:xl ~r:xl\n [| Fp.zero; Fp.zero; Fp.zero; Fp.(sl * sl); Fp.negate so |]\n sys\n | (sl, `Constant), (so, `Var xo) ->\n (* sl^2 = so * xo *)\n add_generic_constraint ~o:xo\n [| Fp.zero; Fp.zero; so; Fp.zero; Fp.negate (Fp.square sl) |]\n sys\n | (sl, `Constant), (so, `Constant) ->\n assert (Fp.(equal (square sl) so)) )\n | Snarky_backendless.Constraint.R1CS (v1, v2, v3) -> (\n match (red v1, red v2, red v3) with\n | (s1, `Var x1), (s2, `Var x2), (s3, `Var x3) ->\n (* s1 x1 * s2 x2 = s3 x3\n - s1 s2 (x1 x2) + s3 x3 = 0\n *)\n add_generic_constraint ~l:x1 ~r:x2 ~o:x3\n [| Fp.zero; Fp.zero; s3; Fp.(negate s1 * s2); Fp.zero |]\n sys\n | (s1, `Var x1), (s2, `Var x2), (s3, `Constant) ->\n add_generic_constraint ~l:x1 ~r:x2\n [| Fp.zero; Fp.zero; Fp.zero; Fp.(s1 * s2); Fp.negate s3 |]\n sys\n | (s1, `Var x1), (s2, `Constant), (s3, `Var x3) ->\n (* s1 x1 * s2 = s3 x3\n *)\n add_generic_constraint ~l:x1 ~o:x3\n [| Fp.(s1 * s2); Fp.zero; Fp.negate s3; Fp.zero; Fp.zero |]\n sys\n | (s1, `Constant), (s2, `Var x2), (s3, `Var x3) ->\n add_generic_constraint ~r:x2 ~o:x3\n [| Fp.zero; Fp.(s1 * s2); Fp.negate s3; Fp.zero; Fp.zero |]\n sys\n | (s1, `Var x1), (s2, `Constant), (s3, `Constant) ->\n add_generic_constraint ~l:x1\n [| Fp.(s1 * s2); Fp.zero; Fp.zero; Fp.zero; Fp.negate s3 |]\n sys\n | (s1, `Constant), (s2, `Var x2), (s3, `Constant) ->\n add_generic_constraint ~r:x2\n [| Fp.zero; Fp.(s1 * s2); Fp.zero; Fp.zero; Fp.negate s3 |]\n sys\n | (s1, `Constant), (s2, `Constant), (s3, `Var x3) ->\n add_generic_constraint ~o:x3\n [| Fp.zero; Fp.zero; s3; Fp.zero; Fp.(negate s1 * s2) |]\n sys\n | (s1, `Constant), (s2, `Constant), (s3, `Constant) ->\n assert (Fp.(equal s3 Fp.(s1 * s2))) )\n | Snarky_backendless.Constraint.Boolean v -> (\n let s, x = red v in\n match x with\n | `Var x ->\n (* -x + x * x = 0 *)\n add_generic_constraint ~l:x ~r:x\n [| Fp.(negate one); Fp.zero; Fp.zero; Fp.one; Fp.zero |]\n sys\n | `Constant ->\n assert (Fp.(equal s (s * s))) )\n | Snarky_backendless.Constraint.Equal (v1, v2) -> (\n let (s1, x1), (s2, x2) = (red v1, red v2) in\n match (x1, x2) with\n | `Var x1, `Var x2 ->\n if Fp.equal s1 s2 then (\n if not (Fp.equal s1 Fp.zero) then\n Union_find.union (union_find sys x1) (union_find sys x2) )\n else if (* s1 x1 - s2 x2 = 0\n *)\n not (Fp.equal s1 s2) then\n add_generic_constraint ~l:x1 ~r:x2\n [| s1; Fp.(negate s2); Fp.zero; Fp.zero; Fp.zero |]\n sys\n else\n add_generic_constraint ~l:x1 ~r:x2\n [| s1; Fp.(negate s2); Fp.zero; Fp.zero; Fp.zero |]\n sys\n | `Var x1, `Constant -> (\n (* s1 * x1 = s2\n x1 = s2 / s1\n *)\n let ratio = Fp.(s2 / s1) in\n match Hashtbl.find sys.cached_constants ratio with\n | Some x2 ->\n Union_find.union (union_find sys x1) (union_find sys x2)\n | None ->\n add_generic_constraint ~l:x1\n [| s1; Fp.zero; Fp.zero; Fp.zero; Fp.negate s2 |]\n sys ;\n Hashtbl.set sys.cached_constants ~key:ratio ~data:x1 )\n | `Constant, `Var x2 -> (\n (* s1 = s2 * x2\n x2 = s1 / s2\n *)\n let ratio = Fp.(s1 / s2) in\n match Hashtbl.find sys.cached_constants ratio with\n | Some x1 ->\n Union_find.union (union_find sys x1) (union_find sys x2)\n | None ->\n add_generic_constraint ~r:x2\n [| Fp.zero; s2; Fp.zero; Fp.zero; Fp.negate s1 |]\n sys ;\n Hashtbl.set sys.cached_constants ~key:ratio ~data:x2 )\n | `Constant, `Constant ->\n assert (Fp.(equal s1 s2)) )\n | Plonk_constraint.T (Basic { l; r; o; m; c }) ->\n (* 0\n = l.s * l.x\n + r.s * r.x\n + o.s * o.x\n + m * (l.x * r.x)\n + c\n =\n l.s * l.s' * l.x'\n + r.s * r.s' * r.x'\n + o.s * o.s' * o.x'\n + m * (l.s' * l.x' * r.s' * r.x')\n + c\n =\n (l.s * l.s') * l.x'\n + (r.s * r.s') * r.x'\n + (o.s * o.s') * o.x'\n + (m * l.s' * r.s') * l.x' r.x'\n + c\n *)\n (* TODO: This is sub-optimal *)\n let c = ref c in\n let red_pr (s, x) =\n match red x with\n | s', `Constant ->\n c := Fp.add !c Fp.(s * s') ;\n (* No need to have a real term. *)\n (s', None)\n | s', `Var x ->\n (s', Some (Fp.(s * s'), x))\n in\n (* l.s * l.x\n + r.s * r.x\n + o.s * o.x\n + m * (l.x * r.x)\n + c\n =\n l.s * l.s' * l.x'\n + r.s * r.x\n + o.s * o.x\n + m * (l.x * r.x)\n + c\n =\n *)\n let l_s', l = red_pr l in\n let r_s', r = red_pr r in\n let _, o = red_pr o in\n let var = Option.map ~f:snd in\n let coeff = Option.value_map ~default:Fp.zero ~f:fst in\n let m =\n match (l, r) with\n | Some _, Some _ ->\n Fp.(l_s' * r_s' * m)\n | _ ->\n (* TODO: Figure this out later. *)\n failwith \"Must use non-constant cvar in plonk constraints\"\n in\n add_generic_constraint ?l:(var l) ?r:(var r) ?o:(var o)\n [| coeff l; coeff r; coeff o; m; !c |]\n sys\n (* | w0 | w1 | w2 | w3 | w4 | w5\n state = [ x , x , x ], [ y, y, y ], ... ]\n i=0, perm^ i=1, perm^\n *)\n | Plonk_constraint.T (Poseidon { state }) ->\n (* reduce the state *)\n let reduce_state sys (s : Fp.t Snarky_backendless.Cvar.t array array) :\n V.t array array =\n Array.map ~f:(Array.map ~f:reduce_to_v) s\n in\n let state = reduce_state sys state in\n (* add_round_state adds a row that contains 5 rounds of permutation *)\n let add_round_state ~round (s1, s2, s3, s4, s5) =\n let vars =\n [| Some s1.(0)\n ; Some s1.(1)\n ; Some s1.(2)\n ; Some s5.(0) (* the last state is in 2nd position *)\n ; Some s5.(1)\n ; Some s5.(2)\n ; Some s2.(0)\n ; Some s2.(1)\n ; Some s2.(2)\n ; Some s3.(0)\n ; Some s3.(1)\n ; Some s3.(2)\n ; Some s4.(0)\n ; Some s4.(1)\n ; Some s4.(2)\n |]\n in\n let coeffs =\n [| Params.params.round_constants.(round).(0)\n ; Params.params.round_constants.(round).(1)\n ; Params.params.round_constants.(round).(2)\n ; Params.params.round_constants.(round + 1).(0)\n ; Params.params.round_constants.(round + 1).(1)\n ; Params.params.round_constants.(round + 1).(2)\n ; Params.params.round_constants.(round + 2).(0)\n ; Params.params.round_constants.(round + 2).(1)\n ; Params.params.round_constants.(round + 2).(2)\n ; Params.params.round_constants.(round + 3).(0)\n ; Params.params.round_constants.(round + 3).(1)\n ; Params.params.round_constants.(round + 3).(2)\n ; Params.params.round_constants.(round + 4).(0)\n ; Params.params.round_constants.(round + 4).(1)\n ; Params.params.round_constants.(round + 4).(2)\n |]\n in\n add_row sys vars Poseidon coeffs\n in\n (* add_last_row adds the last row containing the output *)\n let add_last_row state =\n let vars =\n [| Some state.(0)\n ; Some state.(1)\n ; Some state.(2)\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n |]\n in\n add_row sys vars Zero [||]\n in\n (* go through the states row by row (a row contains 5 states) *)\n let rec process_5_states_at_a_time ~round = function\n | [ s1; s2; s3; s4; s5; last ] ->\n add_round_state ~round (s1, s2, s3, s4, s5) ;\n add_last_row last\n | s1 :: s2 :: s3 :: s4 :: s5 :: tl ->\n add_round_state ~round (s1, s2, s3, s4, s5) ;\n process_5_states_at_a_time ~round:(round + 5) tl\n | _ ->\n failwith \"incorrect number of states given\"\n in\n process_5_states_at_a_time ~round:0 (Array.to_list state)\n | Plonk_constraint.T\n (EC_add_complete { p1; p2; p3; inf; same_x; slope; inf_z; x21_inv }) ->\n let reduce_curve_point (x, y) = (reduce_to_v x, reduce_to_v y) in\n\n (*\n //! 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14\n //! x1 y1 x2 y2 x3 y3 inf same_x s inf_z x21_inv\n *)\n let x1, y1 = reduce_curve_point p1 in\n let x2, y2 = reduce_curve_point p2 in\n let x3, y3 = reduce_curve_point p3 in\n let vars =\n [| Some x1\n ; Some y1\n ; Some x2\n ; Some y2\n ; Some x3\n ; Some y3\n ; Some (reduce_to_v inf)\n ; Some (reduce_to_v same_x)\n ; Some (reduce_to_v slope)\n ; Some (reduce_to_v inf_z)\n ; Some (reduce_to_v x21_inv)\n ; None\n ; None\n ; None\n ; None\n |]\n in\n add_row sys vars CompleteAdd [||]\n | Plonk_constraint.T (EC_scale { state }) ->\n let i = ref 0 in\n (*\n 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14\n xT yT x0 y0 n n' x1 y1 x2 y2 x3 y3 x4 y4\n x5 y5 b0 b1 b2 b3 b4 s0 s1 s2 s3 s4\n *)\n let add_ecscale_round\n Scale_round.{ accs; bits; ss; base = xt, yt; n_prev; n_next } =\n let curr_row =\n [| Some xt\n ; Some yt\n ; Some (fst accs.(0))\n ; Some (snd accs.(0))\n ; Some n_prev\n ; Some n_next\n ; None\n ; Some (fst accs.(1))\n ; Some (snd accs.(1))\n ; Some (fst accs.(2))\n ; Some (snd accs.(2))\n ; Some (fst accs.(3))\n ; Some (snd accs.(3))\n ; Some (fst accs.(4))\n ; Some (snd accs.(4))\n |]\n in\n let next_row =\n [| Some (fst accs.(5))\n ; Some (snd accs.(5))\n ; Some bits.(0)\n ; Some bits.(1)\n ; Some bits.(2)\n ; Some bits.(3)\n ; Some bits.(4)\n ; Some ss.(0)\n ; Some ss.(1)\n ; Some ss.(2)\n ; Some ss.(3)\n ; Some ss.(4)\n ; None\n ; None\n ; None\n |]\n in\n add_row sys curr_row VarBaseMul [||] ;\n add_row sys next_row Zero [||]\n in\n\n Array.iter\n ~f:(fun round -> add_ecscale_round round ; incr i)\n (Array.map state ~f:(Scale_round.map ~f:reduce_to_v)) ;\n ()\n | Plonk_constraint.T (EC_endoscale { state; xs; ys; n_acc }) ->\n (* Reduce state. *)\n let state = Array.map state ~f:(Endoscale_round.map ~f:reduce_to_v) in\n (* Add round function. *)\n let add_endoscale_round (round : V.t Endoscale_round.t) =\n let row =\n [| Some round.xt\n ; Some round.yt\n ; None\n ; None\n ; Some round.xp\n ; Some round.yp\n ; Some round.n_acc\n ; Some round.xr\n ; Some round.yr\n ; Some round.s1\n ; Some round.s3\n ; Some round.b1\n ; Some round.b2\n ; Some round.b3\n ; Some round.b4\n |]\n in\n add_row sys row Kimchi_types.EndoMul [||]\n in\n Array.iter state ~f:add_endoscale_round ;\n (* Last row. *)\n let vars =\n [| None\n ; None\n ; None\n ; None\n ; Some (reduce_to_v xs)\n ; Some (reduce_to_v ys)\n ; Some (reduce_to_v n_acc)\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n |]\n in\n add_row sys vars Zero [||]\n | Plonk_constraint.T\n (EC_endoscalar { state : 'v Endoscale_scalar_round.t array }) ->\n (* Add round function. *)\n let add_endoscale_scalar_round (round : V.t Endoscale_scalar_round.t) =\n let row =\n [| Some round.n0\n ; Some round.n8\n ; Some round.a0\n ; Some round.b0\n ; Some round.a8\n ; Some round.b8\n ; Some round.x0\n ; Some round.x1\n ; Some round.x2\n ; Some round.x3\n ; Some round.x4\n ; Some round.x5\n ; Some round.x6\n ; Some round.x7\n ; None\n |]\n in\n add_row sys row Kimchi_types.EndoMulScalar [||]\n in\n Array.iter state\n ~f:\n (Fn.compose add_endoscale_scalar_round\n (Endoscale_scalar_round.map ~f:reduce_to_v) )\n | Plonk_constraint.T (Lookup { w0; w1; w2; w3; w4; w5; w6 }) ->\n (* table ID *)\n let red_w0 = reduce_to_v w0 in\n (* idx1 *)\n let red_w1 = reduce_to_v w1 in\n (* v1 *)\n let red_w2 = reduce_to_v w2 in\n (* idx2 *)\n let red_w3 = reduce_to_v w3 in\n (* v2 *)\n let red_w4 = reduce_to_v w4 in\n (* idx3 *)\n let red_w5 = reduce_to_v w5 in\n (* v3 *)\n let red_w6 = reduce_to_v w6 in\n let vars =\n [| Some red_w0\n ; Some red_w1\n ; Some red_w2\n ; Some red_w3\n ; Some red_w4\n ; Some red_w5\n ; Some red_w6\n |]\n in\n let lookup1 = (red_w0, (red_w1, red_w2)) in\n let lookup2 = (red_w0, (red_w3, red_w4)) in\n let lookup3 = (red_w0, (red_w5, red_w6)) in\n (* We populate with the first lookup. In the case the user uses the same\n index multiple times, the last value will be used *)\n sys.runtime_lookups_rev <-\n lookup3 :: lookup2 :: lookup1 :: sys.runtime_lookups_rev ;\n add_row sys vars Lookup [||]\n | Plonk_constraint.T\n (RangeCheck0\n { v0\n ; v0p0\n ; v0p1\n ; v0p2\n ; v0p3\n ; v0p4\n ; v0p5\n ; v0c0\n ; v0c1\n ; v0c2\n ; v0c3\n ; v0c4\n ; v0c5\n ; v0c6\n ; v0c7\n ; compact\n } ) ->\n (*\n //! 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14\n //! v vp0 vp1 vp2 vp3 vp4 vp5 vc0 vc1 vc2 vc3 vc4 vc5 vc6 vc7\n *)\n let vars =\n [| Some (reduce_to_v v0)\n ; Some (reduce_to_v v0p0) (* MSBs *)\n ; Some (reduce_to_v v0p1)\n ; Some (reduce_to_v v0p2)\n ; Some (reduce_to_v v0p3)\n ; Some (reduce_to_v v0p4)\n ; Some (reduce_to_v v0p5)\n ; Some (reduce_to_v v0c0)\n ; Some (reduce_to_v v0c1)\n ; Some (reduce_to_v v0c2)\n ; Some (reduce_to_v v0c3)\n ; Some (reduce_to_v v0c4)\n ; Some (reduce_to_v v0c5)\n ; Some (reduce_to_v v0c6)\n ; Some (reduce_to_v v0c7) (* LSBs *)\n |]\n in\n let coeff = if Fp.equal compact Fp.one then Fp.one else Fp.zero in\n add_row sys vars RangeCheck0 [| coeff |]\n | Plonk_constraint.T\n (RangeCheck1\n { (* Current row *) v2\n ; v12\n ; v2c0\n ; v2p0\n ; v2p1\n ; v2p2\n ; v2p3\n ; v2c1\n ; v2c2\n ; v2c3\n ; v2c4\n ; v2c5\n ; v2c6\n ; v2c7\n ; v2c8\n ; (* Next row *) v2c9\n ; v2c10\n ; v2c11\n ; v0p0\n ; v0p1\n ; v1p0\n ; v1p1\n ; v2c12\n ; v2c13\n ; v2c14\n ; v2c15\n ; v2c16\n ; v2c17\n ; v2c18\n ; v2c19\n } ) ->\n (*\n //! 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14\n //! Curr: v2 v12 v2c0 v2p0 v2p1 v2p2 v2p3 v2c1 v2c2 v2c3 v2c4 v2c5 v2c6 v2c7 v2c8\n //! Next: v2c9 v2c10 v2c11 v0p0 v0p1 v1p0 v1p1 v2c12 v2c13 v2c14 v2c15 v2c16 v2c17 v2c18 v2c19\n *)\n let vars_curr =\n [| (* Current row *) Some (reduce_to_v v2)\n ; Some (reduce_to_v v12)\n ; Some (reduce_to_v v2c0) (* MSBs *)\n ; Some (reduce_to_v v2p0)\n ; Some (reduce_to_v v2p1)\n ; Some (reduce_to_v v2p2)\n ; Some (reduce_to_v v2p3)\n ; Some (reduce_to_v v2c1)\n ; Some (reduce_to_v v2c2)\n ; Some (reduce_to_v v2c3)\n ; Some (reduce_to_v v2c4)\n ; Some (reduce_to_v v2c5)\n ; Some (reduce_to_v v2c6)\n ; Some (reduce_to_v v2c7)\n ; Some (reduce_to_v v2c8) (* LSBs *)\n |]\n in\n let vars_next =\n [| (* Next row *) Some (reduce_to_v v2c9)\n ; Some (reduce_to_v v2c10)\n ; Some (reduce_to_v v2c11)\n ; Some (reduce_to_v v0p0)\n ; Some (reduce_to_v v0p1)\n ; Some (reduce_to_v v1p0)\n ; Some (reduce_to_v v1p1)\n ; Some (reduce_to_v v2c12)\n ; Some (reduce_to_v v2c13)\n ; Some (reduce_to_v v2c14)\n ; Some (reduce_to_v v2c15)\n ; Some (reduce_to_v v2c16)\n ; Some (reduce_to_v v2c17)\n ; Some (reduce_to_v v2c18)\n ; Some (reduce_to_v v2c19)\n |]\n in\n add_row sys vars_curr RangeCheck1 [||] ;\n add_row sys vars_next Zero [||]\n | Plonk_constraint.T\n (Xor\n { in1\n ; in2\n ; out\n ; in1_0\n ; in1_1\n ; in1_2\n ; in1_3\n ; in2_0\n ; in2_1\n ; in2_2\n ; in2_3\n ; out_0\n ; out_1\n ; out_2\n ; out_3\n } ) ->\n (* | Column | Curr | Next (gadget responsibility) |\n | ------ | ---------------- | ---------------------------- |\n | 0 | copy `in1` | copy `in1'` |\n | 1 | copy `in2` | copy `in2'` |\n | 2 | copy `out` | copy `out'` |\n | 3 | plookup0 `in1_0` | |\n | 4 | plookup1 `in1_1` | |\n | 5 | plookup2 `in1_2` | |\n | 6 | plookup3 `in1_3` | |\n | 7 | plookup0 `in2_0` | |\n | 8 | plookup1 `in2_1` | |\n | 9 | plookup2 `in2_2` | |\n | 10 | plookup3 `in2_3` | |\n | 11 | plookup0 `out_0` | |\n | 12 | plookup1 `out_1` | |\n | 13 | plookup2 `out_2` | |\n | 14 | plookup3 `out_3` | |\n *)\n let curr_row =\n [| Some (reduce_to_v in1)\n ; Some (reduce_to_v in2)\n ; Some (reduce_to_v out)\n ; Some (reduce_to_v in1_0)\n ; Some (reduce_to_v in1_1)\n ; Some (reduce_to_v in1_2)\n ; Some (reduce_to_v in1_3)\n ; Some (reduce_to_v in2_0)\n ; Some (reduce_to_v in2_1)\n ; Some (reduce_to_v in2_2)\n ; Some (reduce_to_v in2_3)\n ; Some (reduce_to_v out_0)\n ; Some (reduce_to_v out_1)\n ; Some (reduce_to_v out_2)\n ; Some (reduce_to_v out_3)\n |]\n in\n (* The raw gate after a Xor16 gate is a Const to check that all values are zero.\n For that, the first coefficient is 1 and the rest will be zero.\n This will be included in the gadget for a chain of Xors, not here.*)\n add_row sys curr_row Xor16 [||]\n | Plonk_constraint.T\n (ForeignFieldAdd\n { left_input_lo\n ; left_input_mi\n ; left_input_hi\n ; right_input_lo\n ; right_input_mi\n ; right_input_hi\n ; field_overflow\n ; carry\n ; (* Coefficients *) foreign_field_modulus0\n ; foreign_field_modulus1\n ; foreign_field_modulus2\n ; sign\n } ) ->\n (*\n //! | Gate | `ForeignFieldAdd` | Circuit/gadget responsibility |\n //! | ------ | ------------------------ | ------------------------------ |\n //! | Column | `Curr` | `Next` |\n //! | ------ | ------------------------ | ------------------------------ |\n //! | 0 | `left_input_lo` (copy) | `result_lo` (copy) |\n //! | 1 | `left_input_mi` (copy) | `result_mi` (copy) |\n //! | 2 | `left_input_hi` (copy) | `result_hi` (copy) |\n //! | 3 | `right_input_lo` (copy) | |\n //! | 4 | `right_input_mi` (copy) | |\n //! | 5 | `right_input_hi` (copy) | |\n //! | 6 | `field_overflow` (copy?) | |\n //! | 7 | `carry` | |\n //! | 8 | | |\n //! | 9 | | |\n //! | 10 | | |\n //! | 11 | | |\n //! | 12 | | |\n //! | 13 | | |\n //! | 14 | | |\n *)\n let vars =\n [| (* Current row *) Some (reduce_to_v left_input_lo)\n ; Some (reduce_to_v left_input_mi)\n ; Some (reduce_to_v left_input_hi)\n ; Some (reduce_to_v right_input_lo)\n ; Some (reduce_to_v right_input_mi)\n ; Some (reduce_to_v right_input_hi)\n ; Some (reduce_to_v field_overflow)\n ; Some (reduce_to_v carry)\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n ; None\n |]\n in\n add_row sys vars ForeignFieldAdd\n [| foreign_field_modulus0\n ; foreign_field_modulus1\n ; foreign_field_modulus2\n ; sign\n |]\n | Plonk_constraint.T\n (ForeignFieldMul\n { left_input0\n ; left_input1\n ; left_input2\n ; right_input0\n ; right_input1\n ; right_input2\n ; remainder01\n ; remainder2\n ; quotient0\n ; quotient1\n ; quotient2\n ; quotient_hi_bound\n ; product1_lo\n ; product1_hi_0\n ; product1_hi_1\n ; carry0\n ; carry1_0\n ; carry1_12\n ; carry1_24\n ; carry1_36\n ; carry1_48\n ; carry1_60\n ; carry1_72\n ; carry1_84\n ; carry1_86\n ; carry1_88\n ; carry1_90\n ; (* Coefficients *) foreign_field_modulus2\n ; neg_foreign_field_modulus0\n ; neg_foreign_field_modulus1\n ; neg_foreign_field_modulus2\n } ) ->\n (*\n | col | `ForeignFieldMul` | `Zero` |\n | --- | ----------------------- | -------------------------- |\n | 0 | `left_input0` (copy) | `remainder01` (copy) |\n | 1 | `left_input1` (copy) | `remainder2` (copy) |\n | 2 | `left_input2` (copy) | `quotient0` (copy) |\n | 3 | `right_input0` (copy) | `quotient1` (copy) |\n | 4 | `right_input1` (copy) | `quotient2` (copy) |\n | 5 | `right_input2` (copy) | `quotient_hi_bound` (copy) |\n | 6 | `product1_lo` (copy) | `product1_hi_0` (copy) |\n | 7 | `carry1_0` (plookup) | `product1_hi_1` (dummy) |\n | 8 | `carry1_12 (plookup) | `carry1_48` (plookup) |\n | 9 | `carry1_24` (plookup) | `carry1_60` (plookup) |\n | 10 | `carry1_36` (plookup) | `carry1_72` (plookup) |\n | 11 | `carry1_84` | `carry0` |\n | 12 | `carry1_86` | |\n | 13 | `carry1_88` | |\n | 14 | `carry1_90` | |\n *)\n (* Current row *)\n let vars_curr =\n [| Some (reduce_to_v left_input0)\n ; Some (reduce_to_v left_input1)\n ; Some (reduce_to_v left_input2)\n ; Some (reduce_to_v right_input0)\n ; Some (reduce_to_v right_input1)\n ; Some (reduce_to_v right_input2)\n ; Some (reduce_to_v product1_lo)\n ; Some (reduce_to_v carry1_0)\n ; Some (reduce_to_v carry1_12)\n ; Some (reduce_to_v carry1_24)\n ; Some (reduce_to_v carry1_36)\n ; Some (reduce_to_v carry1_84)\n ; Some (reduce_to_v carry1_86)\n ; Some (reduce_to_v carry1_88)\n ; Some (reduce_to_v carry1_90)\n |]\n in\n (* Next row *)\n let vars_next =\n [| Some (reduce_to_v remainder01)\n ; Some (reduce_to_v remainder2)\n ; Some (reduce_to_v quotient0)\n ; Some (reduce_to_v quotient1)\n ; Some (reduce_to_v quotient2)\n ; Some (reduce_to_v quotient_hi_bound)\n ; Some (reduce_to_v product1_hi_0)\n ; Some (reduce_to_v product1_hi_1)\n ; Some (reduce_to_v carry1_48)\n ; Some (reduce_to_v carry1_60)\n ; Some (reduce_to_v carry1_72)\n ; Some (reduce_to_v carry0)\n ; None\n ; None\n ; None\n |]\n in\n add_row sys vars_curr ForeignFieldMul\n [| foreign_field_modulus2\n ; neg_foreign_field_modulus0\n ; neg_foreign_field_modulus1\n ; neg_foreign_field_modulus2\n |] ;\n add_row sys vars_next Zero [||]\n | Plonk_constraint.T\n (Rot64\n { word\n ; rotated\n ; excess\n ; bound_limb0\n ; bound_limb1\n ; bound_limb2\n ; bound_limb3\n ; bound_crumb0\n ; bound_crumb1\n ; bound_crumb2\n ; bound_crumb3\n ; bound_crumb4\n ; bound_crumb5\n ; bound_crumb6\n ; bound_crumb7\n ; (* Coefficients *) two_to_rot\n } ) ->\n (*\n //! | Gate | `Rot64` | `RangeCheck0` gadgets (designer's duty) |\n //! | ------ | ------------------- | --------------------------------------------------------- |\n //! | Column | `Curr` | `Next` | `Next` + 1 | `Next`+ 2, if needed |\n //! | ------ | ------------------- | ---------------- | --------------- | -------------------- |\n //! | 0 | copy `word` |`shifted` | copy `excess` | copy `word` |\n //! | 1 | copy `rotated` | 0 | 0 | 0 |\n //! | 2 | `excess` | 0 | 0 | 0 |\n //! | 3 | `bound_limb0` | `shifted_limb0` | `excess_limb0` | `word_limb0` |\n //! | 4 | `bound_limb1` | `shifted_limb1` | `excess_limb1` | `word_limb1` |\n //! | 5 | `bound_limb2` | `shifted_limb2` | `excess_limb2` | `word_limb2` |\n //! | 6 | `bound_limb3` | `shifted_limb3` | `excess_limb3` | `word_limb3` |\n //! | 7 | `bound_crumb0` | `shifted_crumb0` | `excess_crumb0` | `word_crumb0` |\n //! | 8 | `bound_crumb1` | `shifted_crumb1` | `excess_crumb1` | `word_crumb1` |\n //! | 9 | `bound_crumb2` | `shifted_crumb2` | `excess_crumb2` | `word_crumb2` |\n //! | 10 | `bound_crumb3` | `shifted_crumb3` | `excess_crumb3` | `word_crumb3` |\n //! | 11 | `bound_crumb4` | `shifted_crumb4` | `excess_crumb4` | `word_crumb4` |\n //! | 12 | `bound_crumb5` | `shifted_crumb5` | `excess_crumb5` | `word_crumb5` |\n //! | 13 | `bound_crumb6` | `shifted_crumb6` | `excess_crumb6` | `word_crumb6` |\n //! | 14 | `bound_crumb7` | `shifted_crumb7` | `excess_crumb7` | `word_crumb7` |\n *)\n let vars_curr =\n [| (* Current row *) Some (reduce_to_v word)\n ; Some (reduce_to_v rotated)\n ; Some (reduce_to_v excess)\n ; Some (reduce_to_v bound_limb0)\n ; Some (reduce_to_v bound_limb1)\n ; Some (reduce_to_v bound_limb2)\n ; Some (reduce_to_v bound_limb3)\n ; Some (reduce_to_v bound_crumb0)\n ; Some (reduce_to_v bound_crumb1)\n ; Some (reduce_to_v bound_crumb2)\n ; Some (reduce_to_v bound_crumb3)\n ; Some (reduce_to_v bound_crumb4)\n ; Some (reduce_to_v bound_crumb5)\n ; Some (reduce_to_v bound_crumb6)\n ; Some (reduce_to_v bound_crumb7)\n |]\n in\n add_row sys vars_curr Rot64 [| two_to_rot |]\n | Plonk_constraint.T (AddFixedLookupTable { id; data }) -> (\n match sys.fixed_lookup_tables with\n | Unfinalized_fixed_lookup_tables_rev fixed_lookup_tables ->\n let lt : Fp.t Kimchi_types.lookup_table list =\n { id; data } :: fixed_lookup_tables\n in\n sys.fixed_lookup_tables <- Unfinalized_fixed_lookup_tables_rev lt\n | Compiled_fixed_lookup_tables _ ->\n failwith\n \"Trying to add a fixed lookup tables when it has been already \\\n finalized\" )\n | Plonk_constraint.T (AddRuntimeTableCfg { id; first_column }) -> (\n match sys.runtime_tables_cfg with\n | Unfinalized_runtime_tables_cfg_rev runtime_tables_cfg ->\n let rt_cfg : Fp.t Kimchi_types.runtime_table_cfg list =\n { id; first_column } :: runtime_tables_cfg\n in\n sys.runtime_tables_cfg <- Unfinalized_runtime_tables_cfg_rev rt_cfg\n | Compiled_runtime_tables_cfg _ ->\n failwith\n \"Trying to add a runtime table configuration it has been \\\n already finalized\" )\n | Plonk_constraint.T (Raw { kind; values; coeffs }) ->\n let values =\n Array.init 15 ~f:(fun i ->\n (* Insert [None] if the index is beyond the end of the [values]\n array.\n *)\n Option.try_with (fun () -> reduce_to_v values.(i)) )\n in\n add_row sys values kind coeffs\n | constr ->\n failwithf \"Unhandled constraint %s\"\n Obj.(Extension_constructor.name (Extension_constructor.of_val constr))\n ()\nend\n","open Core_kernel\n\ntype ('a, 's) fold = init:'s -> f:('s -> 'a -> 's) -> 's\n\ntype 'a t = { fold : 's. ('a, 's) fold }\n\nlet map (t : 'a t) ~(f : 'a -> 'b) : 'b t =\n { fold =\n (fun ~init ~f:update -> t.fold ~init ~f:(fun acc x -> update acc (f x)))\n }\n\nlet concat (t : 'a t t) : 'a t =\n { fold =\n (fun ~init ~f ->\n t.fold ~init ~f:(fun acc inner -> inner.fold ~init:acc ~f) )\n }\n\nlet concat_map (t : 'a t) ~(f : 'a -> 'b t) : 'b t =\n { fold =\n (fun ~init ~f:update ->\n t.fold ~init ~f:(fun acc x -> (f x).fold ~init:acc ~f:update) )\n }\n\nlet init n ~f:ith_elt =\n { fold =\n (fun ~init ~f ->\n let rec go i acc =\n if i = n then acc else go (i + 1) (f acc (ith_elt i))\n in\n go 0 init )\n }\n\ninclude Monad.Make (struct\n type nonrec 'a t = 'a t\n\n let map = `Custom map\n\n let return x = { fold = (fun ~init ~f -> f init x) }\n\n let bind = concat_map\nend)\n\nlet to_list (t : 'a t) : 'a list =\n List.rev (t.fold ~init:[] ~f:(Fn.flip List.cons))\n\nlet of_list (xs : 'a list) : 'a t =\n { fold = (fun ~init ~f -> List.fold xs ~init ~f) }\n\nlet of_array (xs : 'a array) : 'a t =\n { fold = (fun ~init ~f -> Array.fold xs ~init ~f) }\n\nlet%test_unit \"fold-to-list\" =\n Quickcheck.test (Quickcheck.Generator.list Int.quickcheck_generator)\n ~f:(fun xs -> assert ([%equal: Int.t list] xs (to_list (of_list xs))))\n\nlet sexp_of_t f t = List.sexp_of_t f (to_list t)\n\nlet compose (t1 : 'a t) (t2 : 'a t) : 'a t =\n { fold = (fun ~init ~f -> t2.fold ~init:(t1.fold ~init ~f) ~f) }\n\nlet ( +> ) = compose\n\nlet group3 ~default (t : 'a t) : ('a * 'a * 'a) t =\n { fold =\n (fun ~init ~f ->\n let pt, bs =\n t.fold ~init:(init, []) ~f:(fun (pt, bs) b ->\n match bs with\n | [ b2; b1; b0 ] ->\n let pt' = f pt (b0, b1, b2) in\n (pt', [ b ])\n | _ ->\n (pt, b :: bs) )\n in\n match bs with\n | [ b2; b1; b0 ] ->\n f pt (b0, b1, b2)\n | [ b1; b0 ] ->\n f pt (b0, b1, default)\n | [ b0 ] ->\n f pt (b0, default, default)\n | [] ->\n pt\n | _x1 :: _x2 :: _x3 :: _x4 :: _ ->\n assert false )\n }\n\nlet%test_unit \"group3\" =\n Quickcheck.test (Quickcheck.Generator.list Int.quickcheck_generator)\n ~f:(fun xs ->\n let default = 0 in\n let n = List.length xs in\n let tuples = to_list (group3 ~default (of_list xs)) in\n let k = List.length tuples in\n let r = n mod 3 in\n (let padded =\n xs @ if r = 0 then [] else List.init (3 - r) ~f:(fun _ -> default)\n in\n let concated =\n List.concat_map ~f:(fun (b1, b2, b3) -> [ b1; b2; b3 ]) tuples\n in\n [%test_eq: int list] padded concated ) ;\n assert ((n + 2) / 3 = k) )\n\nlet string_bits s =\n let ith_bit_int n i = (n lsr i) land 1 = 1 in\n { fold =\n (fun ~init ~f ->\n String.fold s ~init ~f:(fun acc c ->\n let c = Char.to_int c in\n let update i acc = f acc (ith_bit_int c i) in\n update 0 acc |> update 1 |> update 2 |> update 3 |> update 4\n |> update 5 |> update 6 |> update 7 ) )\n }\n\nlet bool_t_to_string =\n let module State = struct\n type t = { curr : int; acc : char list; i : int }\n end in\n let open State in\n fun t ->\n let { curr; i; acc } =\n t.fold ~init:{ curr = 0; acc = []; i = 0 } ~f:(fun { curr; acc; i } b ->\n let curr = if b then curr lor (1 lsl i) else curr in\n if i = 7 then { i = 0; acc = Char.of_int_exn curr :: acc; curr = 0 }\n else { i = i + 1; acc; curr } )\n in\n let cs = if i = 0 then acc else Char.of_int_exn curr :: acc in\n String.of_char_list cs\n\nlet string_triples s = group3 ~default:false (string_bits s)\n","open Core_kernel\nopen Fold_lib\nopen Tuple_lib\n\nlet ( = ) = `Don't_use_polymorphic_equality\n\nmodule type Basic_intf = sig\n module Nat : Nat_intf.S\n\n type t [@@deriving eq]\n\n val order : Nat.t\n\n val one : t\n\n val zero : t\n\n val ( + ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val ( / ) : t -> t -> t\n\n val square : t -> t\nend\n\nmodule type Intf = sig\n type t [@@deriving bin_io, sexp, yojson, compare, hash]\n\n include Basic_intf with type t := t\n\n val gen : t Quickcheck.Generator.t\n\n val gen_incl : t -> t -> t Quickcheck.Generator.t\n\n val gen_uniform : t Quickcheck.Generator.t\n\n val gen_uniform_incl : t -> t -> t Quickcheck.Generator.t\n\n val random : unit -> t\n\n val negate : t -> t\n\n val inv : t -> t\n\n val parity : t -> bool\nend\n\nmodule type Sqrt_field_intf = sig\n include Intf\n\n val is_square : t -> bool\n\n val sqrt : t -> t\nend\n\nmodule type Extended_intf = sig\n include Sqrt_field_intf\n\n val ( ** ) : t -> Nat.t -> t\nend\n\nmodule type Fp_intf = sig\n include Intf\n\n include Stringable.S with type t := t\n\n include Stringable.S with type t := t\n\n val of_int : int -> t\n\n val of_bits : bool list -> t option\n\n val to_bigint : t -> Nat.t\n\n val of_bigint : Nat.t -> t\n\n val fold_bits : t -> bool Fold.t\n\n val fold : t -> bool Triple.t Fold.t\n\n val to_bits : t -> bool list\n\n val length_in_bits : int\n\n val is_square : t -> bool\n\n val sqrt : t -> t\nend\n\nmodule type Extension_intf = sig\n type base\n\n include Extended_intf\n\n val scale : t -> base -> t\n\n val of_base : base -> t\n\n val project_to_base : t -> base\n\n val to_list : t -> base list\nend\n\nmodule Extend (F : Basic_intf) = struct\n open F\n\n let ( ** ) x n =\n let k = Nat.num_bits n in\n let rec go acc i =\n if Int.(i < 0) then acc\n else\n let acc = square acc in\n let acc = if Nat.test_bit n i then acc * x else acc in\n go acc Int.(i - 1)\n in\n go one Int.(k - 1)\n\n let is_square =\n let euler = Nat.((order - of_int 1) // of_int 2) in\n fun x -> equal (x ** euler) one\n\n module Sqrt_params = struct\n let two_adicity n =\n let rec go i = if Nat.test_bit n i then i else go Int.(i + 1) in\n go 0\n\n type nonrec t =\n { two_adicity : int\n ; quadratic_non_residue_to_t : t\n ; t_minus_1_over_2 : Nat.t\n }\n\n let first f =\n let rec go i = match f i with Some x -> x | None -> go (i + one) in\n go one\n\n let create () =\n let p_minus_one = Nat.(order - of_int 1) in\n let s = two_adicity p_minus_one in\n let t = Nat.shift_right p_minus_one s in\n let quadratic_non_residue =\n first (fun i -> Option.some_if (not (is_square i)) i)\n in\n { two_adicity = s\n ; quadratic_non_residue_to_t = quadratic_non_residue ** t\n ; t_minus_1_over_2 = Nat.((t - of_int 1) // of_int 2)\n }\n\n let t = lazy (create ())\n end\n\n let rec loop ~while_ ~init f =\n if while_ init then loop ~while_ ~init:(f init) f else init\n\n let rec pow2 b n = if n > 0 then pow2 (square b) Int.(n - 1) else b\n\n let sqrt =\n let pow2_order b =\n loop\n ~while_:(fun (b2m, _) -> not (equal b2m one))\n ~init:(b, 0)\n (fun (b2m, m) -> (square b2m, Int.succ m))\n |> snd\n in\n let module Loop_params = struct\n type nonrec t = { z : t; b : t; x : t; v : int }\n end in\n let open Loop_params in\n fun a ->\n let { Sqrt_params.two_adicity = v\n ; quadratic_non_residue_to_t = z\n ; t_minus_1_over_2\n } =\n Lazy.force Sqrt_params.t\n in\n let w = a ** t_minus_1_over_2 in\n let x = a * w in\n let b = x * w in\n let { x; _ } =\n loop\n ~while_:(fun p -> not (equal p.b one))\n ~init:{ z; b; x; v }\n (fun { z; b; x; v } ->\n let m = pow2_order b in\n let w = pow2 z Int.(v - m - 1) in\n let z = square w in\n { z; b = b * z; x = x * w; v = m } )\n in\n x\nend\n\nmodule Make_fp\n (N : Nat_intf.S) (Info : sig\n val order : N.t\n end) : Fp_intf with module Nat = N and type t = private N.t = struct\n include Info\n\n module T = struct\n let zero = N.of_int 0\n\n let one = N.of_int 1\n\n let length_in_bits = N.num_bits N.(Info.order - one)\n\n module Nat = N\n open Nat\n\n let order = Info.order\n\n (* TODO version *)\n type t = N.t [@@deriving eq, sexp, yojson, compare, hash]\n\n let length_in_bytes = Int.((length_in_bits + 7) / 8)\n\n (** serialization meant to be identical to field serializations in snarky *)\n include Bin_prot.Utils.Of_minimal (struct\n type nonrec t = t\n\n (* increment if serialization changes *)\n let version = 1\n\n let bin_shape_t =\n Bin_prot.Shape.basetype\n (Bin_prot.Shape.Uuid.of_string\n (sprintf \"snarkette_field_%d_V%d\" length_in_bytes version) )\n []\n\n let __bin_read_t__ _buf ~pos_ref _vint =\n Bin_prot.Common.raise_variant_wrong_type \"Fp.t\" !pos_ref\n\n let bin_size_t _ = length_in_bytes\n\n let bin_write_t buf ~pos t =\n let bs = Bigstring.of_string (N.to_bytes t) in\n let n = Bigstring.length bs in\n Bigstring.blit ~src:bs ~dst:buf ~src_pos:0 ~dst_pos:pos ~len:n ;\n if Int.(n < length_in_bytes) then\n for i = n to Int.(length_in_bytes - 1) do\n Bigstring.set buf Int.(pos + i) '\\000'\n done ;\n Int.(pos + length_in_bytes)\n\n let bin_read_t buf ~pos_ref =\n let open Int in\n let remaining_bytes = Bigstring.length buf - !pos_ref in\n if remaining_bytes < length_in_bytes then\n failwithf \"Field.bin_read_t: Expected %d bytes, got %d\"\n length_in_bytes remaining_bytes () ;\n let t =\n N.of_bytes\n (Bigstring.to_string buf ~pos:!pos_ref ~len:length_in_bytes)\n in\n pos_ref := length_in_bytes + !pos_ref ;\n t\n end)\n\n let ( + ) x y = (x + y) % Info.order\n\n let ( - ) x y = (x - y) % Info.order\n\n let ( * ) x y = x * y % Info.order\n\n let square x = x * x\n\n let rec extended_euclidean a b =\n if equal b zero then (a, one, zero)\n else\n match extended_euclidean b (a % b) with\n | d, x, y ->\n (d, y, x - (a // b * y))\n\n let inv_no_mod x =\n let _, a, _b = extended_euclidean x Info.order in\n a\n\n let inv x = inv_no_mod x % Info.order\n\n let ( / ) x y = x * inv_no_mod y\n end\n\n include Extend (T)\n include T\n\n let of_bigint x = N.(x % Info.order)\n\n let to_bigint = Fn.id\n\n let parity t = N.test_bit (to_bigint t) 0\n\n let make_gen gen lo hi =\n let t_of_bignum_bigint n = Bigint.to_string n |> N.of_string in\n Quickcheck.Generator.map (gen lo hi) ~f:t_of_bignum_bigint\n\n (* fix zero, size - 1 bounds *)\n let make_gen_full gen =\n let size = order |> N.to_string |> Bigint.of_string in\n make_gen gen Bigint.zero Bigint.(size - one)\n\n let gen = make_gen_full Bigint.gen_incl\n\n let gen_incl lo hi =\n let bignum_bigint_of_t t = N.to_string t |> Bigint.of_string in\n make_gen Bigint.gen_incl (bignum_bigint_of_t lo) (bignum_bigint_of_t hi)\n\n let gen_uniform = make_gen_full Bigint.gen_uniform_incl\n\n let gen_uniform_incl lo hi =\n let bignum_bigint_of_t t = N.to_string t |> Bigint.of_string in\n make_gen Bigint.gen_uniform_incl (bignum_bigint_of_t lo)\n (bignum_bigint_of_t hi)\n\n let random () = Quickcheck.random_value gen_uniform\n\n let fold_bits n : bool Fold_lib.Fold.t =\n { fold =\n (fun ~init ~f ->\n let rec go acc i =\n if Int.(i = length_in_bits) then acc\n else go (f acc (N.test_bit n i)) Int.(i + 1)\n in\n go init 0 )\n }\n\n let to_bits = Fn.compose Fold_lib.Fold.to_list fold_bits\n\n let fold n = Fold_lib.Fold.group3 ~default:false (fold_bits n)\n\n let of_bits bits =\n let rec go acc i = function\n | [] ->\n acc\n | b :: bs ->\n let acc = if b then N.log_or acc (N.shift_left one i) else acc in\n go acc Int.(i + 1) bs\n in\n let r = go zero 0 bits in\n if N.( < ) r Info.order then Some r else None\n\n open N\n\n let of_int = N.of_int\n\n let of_string = N.of_string\n\n let to_string = N.to_string\n\n let negate x = N.( - ) Info.order x\n\n let%test_unit \"exp test\" = [%test_eq: t] (of_int 8) (of_int 2 ** of_int 3)\n\n let%test_unit \"pow2\" =\n let b = 7 in\n if N.(of_int Int.(7 ** 8) < order) then\n [%test_eq: t] (pow2 (of_int b) 3) (of_int Int.(7 ** 8))\n else ()\n\n let%test_unit \"sqrt agrees with integer square root on small values\" =\n let rec mem a = function\n | [] ->\n ()\n | x :: xs -> (\n try [%test_eq: t] a x with _ -> mem a xs )\n in\n let gen = Int.gen_incl 1 Int.max_value_30_bits in\n Quickcheck.test ~trials:10 gen ~f:(fun n ->\n let n = abs n in\n let n2 = Int.(n * n) in\n mem (sqrt (of_int n2)) [ of_int n; Info.order - of_int n ] )\nend\n\nmodule type Degree_2_extension_intf = sig\n type base\n\n include Extension_intf with type base := base and type t = base * base\nend\n\nmodule type Degree_3_extension_intf = sig\n type base\n\n include Extension_intf with type base := base and type t = base * base * base\nend\n\nlet ( % ) x n =\n let r = x mod n in\n if r < 0 then r + n else r\n\nlet find_wnaf (type t) (module N : Nat_intf.S with type t = t) window_size\n scalar =\n let one = N.of_int 1 in\n let first_k_bits c k =\n let k_bits = N.(shift_left one k - one) in\n N.to_int_exn (N.log_and k_bits c)\n in\n let length = N.num_bits scalar in\n let res = Array.init (length + 1) ~f:(fun _ -> 0) in\n let zero = N.of_int 0 in\n let rec go c j =\n if N.equal zero c then ()\n else\n let u, c =\n if N.test_bit c 0 then\n let u =\n let u = first_k_bits c (window_size + 1) in\n if u > 1 lsl window_size then u - (1 lsl (window_size + 1)) else u\n in\n let c = N.(c - of_int u) in\n (u, c)\n else (0, c)\n in\n res.(j) <- u ;\n go (N.shift_right c 1) (j + 1)\n in\n go scalar 0 ; res\n\nmodule Make_fp3\n (Fp : Intf) (Info : sig\n val non_residue : Fp.t\n\n val frobenius_coeffs_c1 : Fp.t array\n\n val frobenius_coeffs_c2 : Fp.t array\n end) : sig\n include Degree_3_extension_intf with type base = Fp.t and module Nat = Fp.Nat\n\n val non_residue : Fp.t\n\n val frobenius : t -> int -> t\nend = struct\n include Info\n\n type base = Fp.t\n\n let componentwise f (x1, x2, x3) (y1, y2, y3) = (f x1 y1, f x2 y2, f x3 y3)\n\n let of_base x = (x, Fp.zero, Fp.zero)\n\n module T = struct\n module Nat = Fp.Nat\n\n let order = Nat.(Fp.order * Fp.order * Fp.order)\n\n type t = Fp.t * Fp.t * Fp.t\n [@@deriving eq, bin_io, sexp, yojson, compare, hash]\n\n let ( + ) = componentwise Fp.( + )\n\n let ( - ) = componentwise Fp.( - )\n\n let ( * ) (a1, b1, c1) (a2, b2, c2) =\n let a = Fp.(a1 * a2) in\n let b = Fp.(b1 * b2) in\n let c = Fp.(c1 * c2) in\n let open Fp in\n ( a + (non_residue * (((b1 + c1) * (b2 + c2)) - b - c))\n , ((a1 + b1) * (a2 + b2)) - a - b + (non_residue * c)\n , ((a1 + c1) * (a2 + c2)) - a + b - c )\n\n let square (a, b, c) =\n let s0 = Fp.square a in\n let ab = Fp.(a * b) in\n let s1 = Fp.(ab + ab) in\n let s2 = Fp.(square (a - b + c)) in\n let bc = Fp.(b * c) in\n let s3 = Fp.(bc + bc) in\n let s4 = Fp.square c in\n let open Fp in\n (s0 + (non_residue * s3), s1 + (non_residue * s4), s1 + s2 + s3 - s0 - s4)\n\n let inv (a, b, c) =\n let open Fp in\n let t0 = square a in\n let t1 = square b in\n let t2 = square c in\n let t3 = a * b in\n let t4 = a * c in\n let t5 = b * c in\n let c0 = t0 - (non_residue * t5) in\n let c1 = (non_residue * t2) - t3 in\n let c2 = t1 - t4 in\n let t6 = (a * c0) + (non_residue * ((c * c1) + (b * c2))) |> inv in\n (t6 * c0, t6 * c1, t6 * c2)\n\n let ( / ) x y = x * inv y\n\n let one = of_base Fp.one\n\n let zero = of_base Fp.zero\n end\n\n include T\n include Extend (T)\n\n let gen = Quickcheck.Generator.tuple3 Fp.gen Fp.gen Fp.gen\n\n let gen_incl (lo1, lo2, lo3) (hi1, hi2, hi3) =\n Quickcheck.Generator.tuple3 (Fp.gen_incl lo1 hi1) (Fp.gen_incl lo2 hi2)\n (Fp.gen_incl lo3 hi3)\n\n let gen_uniform =\n Quickcheck.Generator.tuple3 Fp.gen_uniform Fp.gen_uniform Fp.gen_uniform\n\n let gen_uniform_incl (lo1, lo2, lo3) (hi1, hi2, hi3) =\n Quickcheck.Generator.tuple3\n (Fp.gen_uniform_incl lo1 hi1)\n (Fp.gen_uniform_incl lo2 hi2)\n (Fp.gen_uniform_incl lo3 hi3)\n\n let random () = Quickcheck.random_value gen_uniform\n\n let to_list (x, y, z) = [ x; y; z ]\n\n let project_to_base (x, _, _) = x\n\n let parity = Fn.compose Fp.parity project_to_base\n\n let scale (x1, x2, x3) s = Fp.(s * x1, s * x2, s * x3)\n\n let negate (x1, x2, x3) = Fp.(negate x1, negate x2, negate x3)\n\n let frobenius (c0, c1, c2) power =\n let open Fp in\n let open Info in\n let i = power mod 3 in\n (c0, frobenius_coeffs_c1.(i) * c1, frobenius_coeffs_c2.(i) * c2)\nend\n\nmodule Make_fp2\n (Fp : Intf) (Info : sig\n val non_residue : Fp.t\n end) : sig\n include Degree_2_extension_intf with type base = Fp.t and module Nat = Fp.Nat\nend = struct\n type base = Fp.t\n\n let of_base x = (x, Fp.zero)\n\n let componentwise f (x1, x2) (y1, y2) = (f x1 y1, f x2 y2)\n\n module T = struct\n type t = Fp.t * Fp.t [@@deriving eq, yojson, bin_io, sexp, compare, hash]\n\n module Nat = Fp.Nat\n\n let order = Nat.(Fp.order * Fp.order)\n\n let one = of_base Fp.one\n\n let zero = of_base Fp.zero\n\n let ( + ) = componentwise Fp.( + )\n\n let ( - ) = componentwise Fp.( - )\n\n let square (a, b) =\n let open Info in\n let ab = Fp.(a * b) in\n Fp.(((a + b) * (a + (non_residue * b))) - ab - (non_residue * ab), ab + ab)\n\n let ( * ) (a1, b1) (a2, b2) =\n let open Fp in\n let a = a1 * a2 in\n let b = b1 * b2 in\n (a + (Info.non_residue * b), ((a1 + b1) * (a2 + b2)) - a - b)\n\n let inv (a, b) =\n let open Fp in\n let t0 = square a in\n let t1 = square b in\n let t2 = t0 - (Info.non_residue * t1) in\n let t3 = inv t2 in\n let c0 = a * t3 in\n let c1 = negate (b * t3) in\n (c0, c1)\n\n let ( / ) x y = x * inv y\n end\n\n include T\n include Extend (T)\n\n let gen = Quickcheck.Generator.tuple2 Fp.gen Fp.gen\n\n let gen_incl (lo1, lo2) (hi1, hi2) =\n Quickcheck.Generator.tuple2 (Fp.gen_incl lo1 hi1) (Fp.gen_incl lo2 hi2)\n\n let gen_uniform = Quickcheck.Generator.tuple2 Fp.gen_uniform Fp.gen_uniform\n\n let gen_uniform_incl (lo1, lo2) (hi1, hi2) =\n Quickcheck.Generator.tuple2\n (Fp.gen_uniform_incl lo1 hi1)\n (Fp.gen_uniform_incl lo2 hi2)\n\n let random () = Quickcheck.random_value gen_uniform\n\n let to_list (x, y) = [ x; y ]\n\n let project_to_base (x, _) = x\n\n let parity = Fn.compose Fp.parity project_to_base\n\n let scale (x1, x2) s = Fp.(s * x1, s * x2)\n\n let negate (a, b) = Fp.(negate a, negate b)\nend\n\nmodule Make_fp6\n (N : Nat_intf.S)\n (Fp : Intf)\n (Fp2 : Degree_2_extension_intf with type base = Fp.t) (Fp3 : sig\n include Degree_3_extension_intf with type base = Fp.t\n\n val frobenius : t -> int -> t\n\n val non_residue : Fp.t\n end) (Info : sig\n val non_residue : Fp.t\n\n val frobenius_coeffs_c1 : Fp.t array\n end) : sig\n include Degree_2_extension_intf with type base = Fp3.t and module Nat = Fp.Nat\n\n val mul_by_2345 : t -> t -> t\n\n val frobenius : t -> int -> t\n\n val cyclotomic_exp : t -> N.t -> t\n\n val unitary_inverse : t -> t\nend = struct\n module T = struct\n module Nat = Fp.Nat\n\n let of_base x = (x, Fp3.zero)\n\n let componentwise f (x1, x2) (y1, y2) = (f x1 y1, f x2 y2)\n\n type t = Fp3.t * Fp3.t [@@deriving eq, yojson, bin_io, sexp, compare, hash]\n\n let order =\n let open Nat in\n let square x = x * x in\n let p = Fp.order in\n square (p * square p)\n\n let zero = of_base Fp3.zero\n\n let one = of_base Fp3.one\n\n let ( + ) = componentwise Fp3.( + )\n\n let ( - ) = componentwise Fp3.( - )\n\n let mul_by_non_residue ((c0, c1, c2) : Fp3.t) =\n Fp.(Info.non_residue * c2, c0, c1)\n\n let square (a, b) =\n let ab = Fp3.(a * b) in\n let open Fp3 in\n ( ((a + b) * (a + mul_by_non_residue b)) - ab - mul_by_non_residue ab\n , ab + ab )\n\n let ( * ) (a1, b1) (a2, b2) =\n let a = Fp3.(a1 * a2) in\n let b = Fp3.(b1 * b2) in\n let beta_b = mul_by_non_residue b in\n Fp3.(a + beta_b, ((a1 + b1) * (a2 + b2)) - a - b)\n\n let inv (a, b) =\n let t1 = Fp3.square b in\n let t0 = Fp3.(square a - mul_by_non_residue t1) in\n let new_t1 = Fp3.inv t0 in\n Fp3.(a * new_t1, negate (b * new_t1))\n\n let ( / ) x y = x * inv y\n end\n\n include T\n include Extend (T)\n\n type base = Fp3.t\n\n let gen = Quickcheck.Generator.tuple2 Fp3.gen Fp3.gen\n\n let gen_incl (lo1, lo2) (hi1, hi2) =\n Quickcheck.Generator.tuple2 (Fp3.gen_incl lo1 hi1) (Fp3.gen_incl lo2 hi2)\n\n let gen_uniform = Quickcheck.Generator.tuple2 Fp3.gen_uniform Fp3.gen_uniform\n\n let gen_uniform_incl (lo1, lo2) (hi1, hi2) =\n Quickcheck.Generator.tuple2\n (Fp3.gen_uniform_incl lo1 hi1)\n (Fp3.gen_uniform_incl lo2 hi2)\n\n let random () = Quickcheck.random_value gen_uniform\n\n let to_list (x, y) = [ x; y ]\n\n let project_to_base (x, _) = x\n\n let parity = Fn.compose Fp3.parity project_to_base\n\n let scale (x1, x2) s = Fp3.(s * x1, s * x2)\n\n let mul_by_2345 (a1, b1) (a2, b2) =\n let open Info in\n let a1_0, a1_1, a1_2 = a1 in\n let _, _, a2_2 = a2 in\n (let a2_0, a2_1, _ = a2 in\n assert (Fp.(equal a2_0 zero)) ;\n assert (Fp.(equal a2_1 zero)) ) ;\n let a =\n Fp.(a1_1 * a2_2 * non_residue, a1_2 * a2_2 * non_residue, a1_0 * a2_2)\n in\n let b = Fp3.(b1 * b2) in\n let beta_b = mul_by_non_residue b in\n Fp3.(a + beta_b, ((a1 + b2) * (a2 + b2)) - a - b)\n\n let negate (a, b) = Fp3.(negate a, negate b)\n\n let unitary_inverse (x, y) = (x, Fp3.negate y)\n\n let cyclotomic_square ((c00, c01, c02), (c10, c11, c12)) =\n let a : Fp2.t = (c00, c11) in\n let b : Fp2.t = (c10, c02) in\n let c : Fp2.t = (c01, c12) in\n let asq = Fp2.square a in\n let bsq = Fp2.square b in\n let csq = Fp2.square c in\n let a_a =\n let open Fp in\n let a_a = fst asq - fst a in\n a_a + a_a + fst asq\n in\n let a_b =\n let open Fp in\n let a_b = snd asq + snd a in\n a_b + a_b + snd asq\n in\n let b_a =\n let open Fp in\n let b_tmp = Fp3.non_residue * snd csq in\n let b_a = b_tmp + fst b in\n b_a + b_a + b_tmp\n in\n let b_b =\n let open Fp in\n let b_b = fst csq - snd b in\n b_b + b_b + fst csq\n in\n let c_a =\n let open Fp in\n let c_a = fst bsq - fst c in\n c_a + c_a + fst bsq\n in\n let c_b =\n let open Fp in\n let c_b = snd bsq + snd c in\n c_b + c_b + snd bsq\n in\n ((a_a, c_a, b_b), (b_a, a_b, c_b))\n\n let cyclotomic_exp x exponent =\n let x_inv = inv x in\n let naf = find_wnaf (module N) 1 exponent in\n let rec go found_nonzero res i =\n if i < 0 then res\n else\n let res = if found_nonzero then cyclotomic_square res else res in\n if naf.(i) <> 0 then\n let found_nonzero = true in\n let res = if naf.(i) > 0 then res * x else res * x_inv in\n go found_nonzero res Int.(i - 1)\n else go found_nonzero res Int.(i - 1)\n in\n go false one Int.(Array.length naf - 1)\n\n let frobenius (c0, c1) power =\n ( Fp3.frobenius c0 power\n , Fp3.(scale (frobenius c1 power) Info.frobenius_coeffs_c1.(power mod 6)) )\nend\n","open Core_kernel\nopen Kimchi_backend_common\nopen Kimchi_pasta_basic\nmodule Field = Fp\nmodule Curve = Vesta\n\nmodule Bigint = struct\n include Field.Bigint\n\n let of_data _ = failwith __LOC__\n\n let to_field = Field.of_bigint\n\n let of_field = Field.to_bigint\nend\n\nlet field_size : Bigint.t = Field.size\n\nmodule Verification_key = struct\n type t =\n ( Pasta_bindings.Fp.t\n , Kimchi_bindings.Protocol.SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm )\n Kimchi_types.VerifierIndex.verifier_index\n\n let to_string _ = failwith __LOC__\n\n let of_string _ = failwith __LOC__\n\n let shifts (t : t) = t.shifts\nend\n\nmodule R1CS_constraint_system =\n Kimchi_pasta_constraint_system.Vesta_constraint_system\n\nlet lagrange srs domain_log2 : _ Kimchi_types.poly_comm array =\n let domain_size = Int.pow 2 domain_log2 in\n Array.init domain_size ~f:(fun i ->\n Kimchi_bindings.Protocol.SRS.Fp.lagrange_commitment srs domain_size i )\n\nlet with_lagrange f (vk : Verification_key.t) =\n f (lagrange vk.srs vk.domain.log_size_of_group) vk\n\nlet with_lagranges f (vks : Verification_key.t array) =\n let lgrs =\n Array.map vks ~f:(fun vk -> lagrange vk.srs vk.domain.log_size_of_group)\n in\n f lgrs vks\n\nmodule Rounds_vector = Rounds.Step_vector\nmodule Rounds = Rounds.Step\n\nmodule Keypair = Dlog_plonk_based_keypair.Make (struct\n let name = \"vesta\"\n\n module Rounds = Rounds\n module Urs = Kimchi_bindings.Protocol.SRS.Fp\n module Index = Kimchi_bindings.Protocol.Index.Fp\n module Curve = Curve\n module Poly_comm = Fp_poly_comm\n module Scalar_field = Field\n module Verifier_index = Kimchi_bindings.Protocol.VerifierIndex.Fp\n module Gate_vector = Kimchi_bindings.Protocol.Gates.Vector.Fp\n module Constraint_system = R1CS_constraint_system\nend)\n\nmodule Proof = Plonk_dlog_proof.Make (struct\n let id = \"pasta_vesta\"\n\n module Scalar_field = Field\n module Base_field = Fq\n\n module Backend = struct\n type t =\n ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.prover_proof\n\n type with_public_evals =\n ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n\n include Kimchi_bindings.Protocol.Proof.Fp\n\n let batch_verify vks ts =\n Promise.run_in_thread (fun () -> batch_verify vks ts)\n\n let create_aux ~f:create (pk : Keypair.t) primary auxiliary prev_chals\n prev_comms =\n (* external values contains [1, primary..., auxiliary ] *)\n let external_values i =\n let open Field.Vector in\n if i < length primary then get primary i\n else get auxiliary (i - length primary)\n in\n\n (* compute witness *)\n let computed_witness, runtime_tables =\n R1CS_constraint_system.compute_witness pk.cs external_values\n in\n let num_rows = Array.length computed_witness.(0) in\n\n (* convert to Rust vector *)\n let witness_cols =\n Array.init Kimchi_backend_common.Constants.columns ~f:(fun col ->\n let witness = Field.Vector.create () in\n for row = 0 to num_rows - 1 do\n Field.Vector.emplace_back witness computed_witness.(col).(row)\n done ;\n witness )\n in\n create pk.index witness_cols runtime_tables prev_chals prev_comms\n\n let create_async (pk : Keypair.t) ~primary ~auxiliary ~prev_chals\n ~prev_comms =\n create_aux pk primary auxiliary prev_chals prev_comms\n ~f:(fun pk auxiliary_input runtime_tables prev_challenges prev_sgs ->\n Promise.run_in_thread (fun () ->\n create pk auxiliary_input runtime_tables prev_challenges prev_sgs ) )\n\n let create (pk : Keypair.t) ~primary ~auxiliary ~prev_chals ~prev_comms =\n create_aux pk primary auxiliary prev_chals prev_comms ~f:create\n end\n\n module Verifier_index = Kimchi_bindings.Protocol.VerifierIndex.Fp\n module Index = Keypair\n\n module Evaluations_backend = struct\n type t = Scalar_field.t Kimchi_types.proof_evaluations\n end\n\n module Opening_proof_backend = struct\n type t = (Curve.Affine.Backend.t, Scalar_field.t) Kimchi_types.opening_proof\n end\n\n module Poly_comm = Fp_poly_comm\n module Curve = Curve\nend)\n\nmodule Proving_key = struct\n type t = Keypair.t\n\n include\n Core_kernel.Binable.Of_binable\n (Core_kernel.Unit)\n (struct\n type nonrec t = t\n\n let to_binable _ = ()\n\n let of_binable () = failwith \"TODO\"\n end)\n\n let is_initialized _ = `Yes\n\n let set_constraint_system _ _ = ()\n\n let to_string _ = failwith \"TODO\"\n\n let of_string _ = failwith \"TODO\"\nend\n\nmodule Oracles = Plonk_dlog_oracles.Make (struct\n module Verifier_index = Verification_key\n module Field = Field\n module Proof = Proof\n\n module Backend = struct\n include Kimchi_bindings.Protocol.Oracles.Fp\n\n let create = with_lagrange create\n\n let create_with_public_evals = with_lagrange create_with_public_evals\n end\nend)\n","open Core_kernel\nopen Kimchi_backend_common\nopen Kimchi_pasta_basic\nmodule Field = Fq\nmodule Curve = Pallas\n\nmodule Bigint = struct\n include Field.Bigint\n\n let of_data _ = failwith __LOC__\n\n let to_field = Field.of_bigint\n\n let of_field = Field.to_bigint\nend\n\nlet field_size : Bigint.t = Field.size\n\nmodule Verification_key = struct\n type t =\n ( Pasta_bindings.Fq.t\n , Kimchi_bindings.Protocol.SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm )\n Kimchi_types.VerifierIndex.verifier_index\n\n let to_string _ = failwith __LOC__\n\n let of_string _ = failwith __LOC__\n\n let shifts (t : t) : Field.t array = t.shifts\nend\n\n(* TODO: change name *)\nmodule R1CS_constraint_system =\n Kimchi_pasta_constraint_system.Pallas_constraint_system\n\nlet lagrange srs domain_log2 : _ Kimchi_types.poly_comm array =\n let domain_size = Int.pow 2 domain_log2 in\n Array.init domain_size ~f:(fun i ->\n Kimchi_bindings.Protocol.SRS.Fq.lagrange_commitment srs domain_size i )\n\nlet with_lagrange f (vk : Verification_key.t) =\n f (lagrange vk.srs vk.domain.log_size_of_group) vk\n\nlet with_lagranges f (vks : Verification_key.t array) =\n let lgrs =\n Array.map vks ~f:(fun vk -> lagrange vk.srs vk.domain.log_size_of_group)\n in\n f lgrs vks\n\nmodule Rounds_vector = Rounds.Wrap_vector\nmodule Rounds = Rounds.Wrap\n\nmodule Keypair = Dlog_plonk_based_keypair.Make (struct\n let name = \"pallas\"\n\n module Rounds = Rounds\n module Urs = Kimchi_bindings.Protocol.SRS.Fq\n module Index = Kimchi_bindings.Protocol.Index.Fq\n module Curve = Curve\n module Poly_comm = Fq_poly_comm\n module Scalar_field = Field\n module Verifier_index = Kimchi_bindings.Protocol.VerifierIndex.Fq\n module Gate_vector = Kimchi_bindings.Protocol.Gates.Vector.Fq\n module Constraint_system = R1CS_constraint_system\nend)\n\nmodule Proof = Plonk_dlog_proof.Make (struct\n let id = \"pasta_pallas\"\n\n module Scalar_field = Field\n module Base_field = Fp\n\n module Backend = struct\n type t =\n ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.prover_proof\n\n type with_public_evals =\n ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n\n include Kimchi_bindings.Protocol.Proof.Fq\n\n let batch_verify vks ts =\n Promise.run_in_thread (fun () -> batch_verify vks ts)\n\n let create_aux ~f:create (pk : Keypair.t) ~primary ~auxiliary ~prev_chals\n ~prev_comms =\n (* external values contains [1, primary..., auxiliary ] *)\n let external_values i =\n let open Field.Vector in\n if i < length primary then get primary i\n else get auxiliary (i - length primary)\n in\n\n (* compute witness *)\n let computed_witness, runtime_tables =\n R1CS_constraint_system.compute_witness pk.cs external_values\n in\n let num_rows = Array.length computed_witness.(0) in\n\n (* convert to Rust vector *)\n let witness_cols =\n Array.init Kimchi_backend_common.Constants.columns ~f:(fun col ->\n let witness = Field.Vector.create () in\n for row = 0 to num_rows - 1 do\n Field.Vector.emplace_back witness computed_witness.(col).(row)\n done ;\n witness )\n in\n create pk.index witness_cols runtime_tables prev_chals prev_comms\n\n let create_async (pk : Keypair.t) ~primary ~auxiliary ~prev_chals\n ~prev_comms =\n create_aux pk ~primary ~auxiliary ~prev_chals ~prev_comms\n ~f:(fun pk auxiliary_input runtime_tables prev_challenges prev_sgs ->\n Promise.run_in_thread (fun () ->\n create pk auxiliary_input runtime_tables prev_challenges prev_sgs ) )\n\n let create (pk : Keypair.t) ~primary ~auxiliary ~prev_chals ~prev_comms =\n create_aux pk ~primary ~auxiliary ~prev_chals ~prev_comms ~f:create\n end\n\n module Verifier_index = Kimchi_bindings.Protocol.VerifierIndex.Fq\n module Index = Keypair\n\n module Evaluations_backend = struct\n type t = Scalar_field.t Kimchi_types.proof_evaluations\n end\n\n module Opening_proof_backend = struct\n type t = (Curve.Affine.Backend.t, Scalar_field.t) Kimchi_types.opening_proof\n end\n\n module Poly_comm = Fq_poly_comm\n module Curve = Curve\nend)\n\nmodule Proving_key = struct\n type t = Keypair.t\n\n include\n Core_kernel.Binable.Of_binable\n (Core_kernel.Unit)\n (struct\n type nonrec t = t\n\n let to_binable _ = ()\n\n let of_binable () = failwith \"TODO\"\n end)\n\n let is_initialized _ = `Yes\n\n let set_constraint_system _ _ = ()\n\n let to_string _ = failwith \"TODO\"\n\n let of_string _ = failwith \"TODO\"\nend\n\nmodule Oracles = Plonk_dlog_oracles.Make (struct\n module Verifier_index = Verification_key\n module Field = Field\n module Proof = Proof\n\n module Backend = struct\n include Kimchi_bindings.Protocol.Oracles.Fq\n\n let create = with_lagrange create\n\n let create_with_public_evals = with_lagrange create_with_public_evals\n end\nend)\n","open Core_kernel\n\nmodule Make () = struct\n let digest_size_in_bits = 256\n\n let digest_size_in_bytes = digest_size_in_bits / 8\n\n module T0 = struct\n include Digestif.Make_BLAKE2B (struct\n let digest_size = digest_size_in_bytes\n end)\n\n let hash = Fn.compose String.hash to_raw_string\n\n let hash_fold_t state t = Hash.fold_string state (to_raw_string t)\n\n let compare = unsafe_compare\n\n let of_string = of_raw_string\n\n let to_string = to_raw_string\n\n let gen =\n let char_generator =\n Base_quickcheck.Generator.of_list\n [ '0'\n ; '1'\n ; '2'\n ; '3'\n ; '4'\n ; '5'\n ; '6'\n ; '7'\n ; '8'\n ; '9'\n ; 'A'\n ; 'B'\n ; 'C'\n ; 'D'\n ; 'E'\n ; 'F'\n ]\n in\n String.gen_with_length (digest_size_in_bytes * 2) char_generator\n |> Quickcheck.Generator.map ~f:of_hex\n end\n\n module T1 = struct\n include T0\n include Sexpable.Of_stringable (T0)\n end\n\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n type t = T1.t [@@deriving hash, sexp, compare, equal]\n\n let to_latest = Fn.id\n\n let to_yojson t : Yojson.Safe.t = `String (T1.to_hex t)\n\n let of_yojson (v : Yojson.Safe.t) =\n let open Ppx_deriving_yojson_runtime in\n match v with\n | `String s ->\n Option.value_map ~default:(Result.Error \"not a hex string\")\n ~f:(fun x -> Result.Ok x)\n (T1.of_hex_opt s)\n | _ ->\n Result.Error \"not a string\"\n\n module Arg = struct\n type nonrec t = t\n\n [%%define_locally T1.(to_string, of_string)]\n end\n\n include Binable.Of_stringable_without_uuid (Arg)\n end\n end]\n\n [%%define_locally Stable.Latest.(to_yojson, of_yojson)]\n\n [%%define_locally\n T1.\n ( of_raw_string\n , to_raw_string\n , digest_string\n , digest_bigstring\n , to_hex\n , of_hex\n , gen )]\n\n (* do not create bin_io serialization *)\n include Hashable.Make (T1)\n include Comparable.Make (T1)\n\n (* Little endian *)\n let bits_to_string bits =\n let n = Array.length bits in\n let rec make_byte offset acc (i : int) =\n let finished = Int.(i = 8 || offset + i >= n) in\n if finished then Char.of_int_exn acc\n else\n let acc = if bits.(offset + i) then acc lor (1 lsl i) else acc in\n make_byte offset acc (i + 1)\n in\n let len = (n + 7) / 8 in\n String.init len ~f:(fun i -> make_byte (8 * i) 0 0)\n\n let string_to_bits s =\n Array.init\n (8 * String.length s)\n ~f:(fun i ->\n let c = Char.to_int s.[i / 8] in\n let j = i mod 8 in\n Int.((c lsr j) land 1 = 1) )\nend\n\ninclude Make ()\n\nlet%test_unit \"bits_to_string\" =\n [%test_eq: string]\n (bits_to_string [| true; false |])\n (String.of_char_list [ Char.of_int_exn 1 ])\n\nlet%test_unit \"string to bits\" =\n Quickcheck.test ~trials:5 String.quickcheck_generator ~f:(fun s ->\n [%test_eq: string] s (bits_to_string (string_to_bits s)) )\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * Location.t * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | NoVariance\n\n type injectivity (*IF_CURRENT = Asttypes.injectivity *) =\n | Injective\n | NoInjectivity\nend\n\nmodule Parsetree = struct\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * Location.t * string option\n (* \"constant\"\n {delim|other constant|delim}\n\n The location span the content of the string, without the delimiters.\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n type location_stack = Location.t list\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: location_stack;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: location_stack;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P) Some \"P\"\n (module _) None\n\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: location_stack;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * (variance * injectivity)) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * (variance * injectivity)) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n*)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * (variance * injectivity)) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and functor_parameter (*IF_CURRENT = Parsetree.functor_parameter *) =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n (* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string option loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string option loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M029\"\n let ast_intf_magic_number = \"Caml1999N029\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Thomas Gazagnaire, OCamlPro *)\n(* Fabrice Le Fessant, INRIA Saclay *)\n(* Hongbo Zhang, University of Pennsylvania *)\n(* *)\n(* Copyright 2007 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Original Code from Ber-metaocaml, modified for 3.12.0 and fixed *)\n(* Printing code expressions *)\n(* Authors: Ed Pizzi, Fabrice Le Fessant *)\n(* Extensive Rewrite: Hongbo Zhang: University of Pennsylvania *)\n(* TODO more fine-grained precedence pretty-printing *)\n\nopen Ast_412\nopen Asttypes\nopen Format\nopen Location\nopen Longident\nopen Parsetree\n\nlet varify_type_constructors var_names t =\n let check_variable vl loc v =\n if List.mem v vl then\n Location.raise_errorf ~loc \"variable in scope syntax error: %s\" v\n in\n let var_names = List.map (fun v -> v.txt) var_names in\n let rec loop t =\n let desc =\n match t.ptyp_desc with\n | Ptyp_any -> Ptyp_any\n | Ptyp_var x ->\n check_variable var_names t.ptyp_loc x;\n Ptyp_var x\n | Ptyp_arrow (label, core_type, core_type') ->\n Ptyp_arrow (label, loop core_type, loop core_type')\n | Ptyp_tuple lst -> Ptyp_tuple (List.map loop lst)\n | Ptyp_constr ({ txt = Longident.Lident s }, []) when List.mem s var_names\n ->\n Ptyp_var s\n | Ptyp_constr (longident, lst) ->\n Ptyp_constr (longident, List.map loop lst)\n | Ptyp_object (lst, o) -> Ptyp_object (List.map loop_object_field lst, o)\n | Ptyp_class (longident, lst) -> Ptyp_class (longident, List.map loop lst)\n | Ptyp_alias (core_type, string) ->\n check_variable var_names t.ptyp_loc string;\n Ptyp_alias (loop core_type, string)\n | Ptyp_variant (row_field_list, flag, lbl_lst_option) ->\n Ptyp_variant\n (List.map loop_row_field row_field_list, flag, lbl_lst_option)\n | Ptyp_poly (string_lst, core_type) ->\n List.iter\n (fun v -> check_variable var_names t.ptyp_loc v.txt)\n string_lst;\n Ptyp_poly (string_lst, loop core_type)\n | Ptyp_package (longident, lst) ->\n Ptyp_package (longident, List.map (fun (n, typ) -> (n, loop typ)) lst)\n | Ptyp_extension (s, arg) -> Ptyp_extension (s, arg)\n in\n { t with ptyp_desc = desc }\n and loop_row_field field =\n let prf_desc =\n match field.prf_desc with\n | Rtag (label, flag, lst) -> Rtag (label, flag, List.map loop lst)\n | Rinherit t -> Rinherit (loop t)\n in\n { field with prf_desc }\n and loop_object_field field =\n let pof_desc =\n match field.pof_desc with\n | Otag (label, t) -> Otag (label, loop t)\n | Oinherit t -> Oinherit (loop t)\n in\n { field with pof_desc }\n in\n loop t\n\nlet prefix_symbols = [ '!'; '?'; '~' ]\n\nlet infix_symbols =\n [ '='; '<'; '>'; '@'; '^'; '|'; '&'; '+'; '-'; '*'; '/'; '$'; '%'; '#' ]\n\n(* type fixity = Infix| Prefix *)\nlet special_infix_strings =\n [ \"asr\"; \"land\"; \"lor\"; \"lsl\"; \"lsr\"; \"lxor\"; \"mod\"; \"or\"; \":=\"; \"!=\"; \"::\" ]\n\nlet letop s =\n String.length s > 3\n && s.[0] = 'l'\n && s.[1] = 'e'\n && s.[2] = 't'\n && List.mem s.[3] infix_symbols\n\nlet andop s =\n String.length s > 3\n && s.[0] = 'a'\n && s.[1] = 'n'\n && s.[2] = 'd'\n && List.mem s.[3] infix_symbols\n\n(* determines if the string is an infix string.\n checks backwards, first allowing a renaming postfix (\"_102\") which\n may have resulted from Pexp -> Texp -> Pexp translation, then checking\n if all the characters in the beginning of the string are valid infix\n characters. *)\nlet fixity_of_string = function\n | \"\" -> `Normal\n | s when List.mem s special_infix_strings -> `Infix s\n | s when List.mem s.[0] infix_symbols -> `Infix s\n | s when List.mem s.[0] prefix_symbols -> `Prefix s\n | s when s.[0] = '.' -> `Mixfix s\n | s when letop s -> `Letop s\n | s when andop s -> `Andop s\n | _ -> `Normal\n\nlet view_fixity_of_exp = function\n | { pexp_desc = Pexp_ident { txt = Lident l; _ }; pexp_attributes = [] } ->\n fixity_of_string l\n | _ -> `Normal\n\nlet is_infix = function `Infix _ -> true | _ -> false\nlet is_mixfix = function `Mixfix _ -> true | _ -> false\nlet is_kwdop = function `Letop _ | `Andop _ -> true | _ -> false\nlet first_is c str = str <> \"\" && str.[0] = c\nlet last_is c str = str <> \"\" && str.[String.length str - 1] = c\nlet first_is_in cs str = str <> \"\" && List.mem str.[0] cs\n\n(* which identifiers are in fact operators needing parentheses *)\nlet needs_parens txt =\n let fix = fixity_of_string txt in\n is_infix fix || is_mixfix fix || is_kwdop fix\n || first_is_in prefix_symbols txt\n\n(* some infixes need spaces around parens to avoid clashes with comment\n syntax *)\nlet needs_spaces txt = first_is '*' txt || last_is '*' txt\n\n(* add parentheses to binders when they are in fact infix or prefix operators *)\nlet protect_ident ppf txt =\n let format : (_, _, _) format =\n if not (needs_parens txt) then \"%s\"\n else if needs_spaces txt then \"(@;%s@;)\"\n else \"(%s)\"\n in\n fprintf ppf format txt\n\nlet protect_longident ppf print_longident longprefix txt =\n let format : (_, _, _) format =\n if not (needs_parens txt) then \"%a.%s\"\n else if needs_spaces txt then \"%a.(@;%s@;)\"\n else \"%a.(%s)\"\n in\n fprintf ppf format print_longident longprefix txt\n\ntype space_formatter = (unit, Format.formatter, unit) format\n\nlet override = function Override -> \"!\" | Fresh -> \"\"\n\n(* variance encoding: need to sync up with the [parser.mly] *)\nlet type_variance = function\n | NoVariance -> \"\"\n | Covariant -> \"+\"\n | Contravariant -> \"-\"\n\nlet type_injectivity = function NoInjectivity -> \"\" | Injective -> \"!\"\n\ntype construct =\n [ `cons of expression list\n | `list of expression list\n | `nil\n | `normal\n | `simple of Longident.t\n | `tuple ]\n\nlet view_expr x =\n match x.pexp_desc with\n | Pexp_construct ({ txt = Lident \"()\"; _ }, _) -> `tuple\n | Pexp_construct ({ txt = Lident \"[]\"; _ }, _) -> `nil\n | Pexp_construct ({ txt = Lident \"::\"; _ }, Some _) ->\n let rec loop exp acc =\n match exp with\n | {\n pexp_desc = Pexp_construct ({ txt = Lident \"[]\"; _ }, _);\n pexp_attributes = [];\n } ->\n (List.rev acc, true)\n | {\n pexp_desc =\n Pexp_construct\n ( { txt = Lident \"::\"; _ },\n Some { pexp_desc = Pexp_tuple [ e1; e2 ]; pexp_attributes = [] }\n );\n pexp_attributes = [];\n } ->\n loop e2 (e1 :: acc)\n | e -> (List.rev (e :: acc), false)\n in\n let ls, b = loop x [] in\n if b then `list ls else `cons ls\n | Pexp_construct (x, None) -> `simple x.txt\n | _ -> `normal\n\nlet is_simple_construct : construct -> bool = function\n | `nil | `tuple | `list _ | `simple _ -> true\n | `cons _ | `normal -> false\n\nlet pp = fprintf\n\ntype ctxt = { pipe : bool; semi : bool; ifthenelse : bool }\n\nlet reset_ctxt = { pipe = false; semi = false; ifthenelse = false }\nlet under_pipe ctxt = { ctxt with pipe = true }\nlet under_semi ctxt = { ctxt with semi = true }\nlet under_ifthenelse ctxt = { ctxt with ifthenelse = true }\n(*\nlet reset_semi ctxt = { ctxt with semi=false }\nlet reset_ifthenelse ctxt = { ctxt with ifthenelse=false }\nlet reset_pipe ctxt = { ctxt with pipe=false }\n*)\n\nlet list :\n 'a.\n ?sep:space_formatter ->\n ?first:space_formatter ->\n ?last:space_formatter ->\n (Format.formatter -> 'a -> unit) ->\n Format.formatter ->\n 'a list ->\n unit =\n fun ?sep ?first ?last fu f xs ->\n let first = match first with Some x -> x | None -> (\"\" : _ format6)\n and last = match last with Some x -> x | None -> (\"\" : _ format6)\n and sep = match sep with Some x -> x | None -> (\"@ \" : _ format6) in\n let aux f = function\n | [] -> ()\n | [ x ] -> fu f x\n | xs ->\n let rec loop f = function\n | [ x ] -> fu f x\n | x :: xs ->\n fu f x;\n pp f sep;\n loop f xs\n | _ -> assert false\n in\n pp f first;\n loop f xs;\n pp f last\n in\n aux f xs\n\nlet option :\n 'a.\n ?first:space_formatter ->\n ?last:space_formatter ->\n (Format.formatter -> 'a -> unit) ->\n Format.formatter ->\n 'a option ->\n unit =\n fun ?first ?last fu f a ->\n let first = match first with Some x -> x | None -> (\"\" : _ format6)\n and last = match last with Some x -> x | None -> (\"\" : _ format6) in\n match a with\n | None -> ()\n | Some x ->\n pp f first;\n fu f x;\n pp f last\n\nlet paren :\n 'a.\n ?first:space_formatter ->\n ?last:space_formatter ->\n bool ->\n (Format.formatter -> 'a -> unit) ->\n Format.formatter ->\n 'a ->\n unit =\n fun ?(first = (\"\" : _ format6)) ?(last = (\"\" : _ format6)) b fu f x ->\n if b then (\n pp f \"(\";\n pp f first;\n fu f x;\n pp f last;\n pp f \")\")\n else fu f x\n\nlet rec longident f = function\n | Lident s -> protect_ident f s\n | Ldot (y, s) -> protect_longident f longident y s\n | Lapply (y, s) -> pp f \"%a(%a)\" longident y longident s\n\nlet longident_loc f x = pp f \"%a\" longident x.txt\n\nlet constant f = function\n | Pconst_char i -> pp f \"%C\" i\n | Pconst_string (i, _, None) -> pp f \"%S\" i\n | Pconst_string (i, _, Some delim) -> pp f \"{%s|%s|%s}\" delim i delim\n | Pconst_integer (i, None) -> paren (first_is '-' i) (fun f -> pp f \"%s\") f i\n | Pconst_integer (i, Some m) ->\n paren (first_is '-' i) (fun f (i, m) -> pp f \"%s%c\" i m) f (i, m)\n | Pconst_float (i, None) -> paren (first_is '-' i) (fun f -> pp f \"%s\") f i\n | Pconst_float (i, Some m) ->\n paren (first_is '-' i) (fun f (i, m) -> pp f \"%s%c\" i m) f (i, m)\n\n(* trailing space*)\nlet mutable_flag f = function Immutable -> () | Mutable -> pp f \"mutable@;\"\nlet virtual_flag f = function Concrete -> () | Virtual -> pp f \"virtual@;\"\n\n(* trailing space added *)\nlet rec_flag f rf =\n match rf with Nonrecursive -> () | Recursive -> pp f \"rec \"\n\nlet nonrec_flag f rf =\n match rf with Nonrecursive -> pp f \"nonrec \" | Recursive -> ()\n\nlet direction_flag f = function\n | Upto -> pp f \"to@ \"\n | Downto -> pp f \"downto@ \"\n\nlet private_flag f = function Public -> () | Private -> pp f \"private@ \"\nlet iter_loc f ctxt { txt; loc = _ } = f ctxt txt\nlet constant_string f s = pp f \"%S\" s\n\nlet tyvar ppf s =\n if String.length s >= 2 && s.[1] = '\\'' then\n (* without the space, this would be parsed as\n a character literal *)\n Format.fprintf ppf \"' %s\" s\n else Format.fprintf ppf \"'%s\" s\n\nlet tyvar_loc f str = tyvar f str.txt\nlet string_quot f x = pp f \"`%s\" x\n\n(* c ['a,'b] *)\nlet rec class_params_def ctxt f = function\n | [] -> ()\n | l -> pp f \"[%a] \" (* space *) (list (type_param ctxt) ~sep:\",\") l\n\nand type_with_label ctxt f (label, c) =\n match label with\n | Nolabel -> core_type1 ctxt f c (* otherwise parenthesize *)\n | Labelled s -> pp f \"%s:%a\" s (core_type1 ctxt) c\n | Optional s -> pp f \"?%s:%a\" s (core_type1 ctxt) c\n\nand core_type ctxt f x =\n if x.ptyp_attributes <> [] then\n pp f \"((%a)%a)\" (core_type ctxt)\n { x with ptyp_attributes = [] }\n (attributes ctxt) x.ptyp_attributes\n else\n match x.ptyp_desc with\n | Ptyp_arrow (l, ct1, ct2) ->\n pp f \"@[<2>%a@;->@;%a@]\" (* FIXME remove parens later *)\n (type_with_label ctxt) (l, ct1) (core_type ctxt) ct2\n | Ptyp_alias (ct, s) ->\n pp f \"@[<2>%a@;as@;%a@]\" (core_type1 ctxt) ct tyvar s\n | Ptyp_poly ([], ct) -> core_type ctxt f ct\n | Ptyp_poly (sl, ct) ->\n pp f \"@[<2>%a%a@]\"\n (fun f l ->\n pp f \"%a\"\n (fun f l ->\n match l with\n | [] -> ()\n | _ -> pp f \"%a@;.@;\" (list tyvar_loc ~sep:\"@;\") l)\n l)\n sl (core_type ctxt) ct\n | _ -> pp f \"@[<2>%a@]\" (core_type1 ctxt) x\n\nand core_type1 ctxt f x =\n if x.ptyp_attributes <> [] then core_type ctxt f x\n else\n match x.ptyp_desc with\n | Ptyp_any -> pp f \"_\"\n | Ptyp_var s -> tyvar f s\n | Ptyp_tuple l -> pp f \"(%a)\" (list (core_type1 ctxt) ~sep:\"@;*@;\") l\n | Ptyp_constr (li, l) ->\n pp f (* \"%a%a@;\" *) \"%a%a\"\n (fun f l ->\n match l with\n | [] -> ()\n | [ x ] -> pp f \"%a@;\" (core_type1 ctxt) x\n | _ -> list ~first:\"(\" ~last:\")@;\" (core_type ctxt) ~sep:\",@;\" f l)\n l longident_loc li\n | Ptyp_variant (l, closed, low) ->\n let first_is_inherit =\n match l with\n | { Parsetree.prf_desc = Rinherit _ } :: _ -> true\n | _ -> false\n in\n let type_variant_helper f x =\n match x.prf_desc with\n | Rtag (l, _, ctl) ->\n pp f \"@[<2>%a%a@;%a@]\" (iter_loc string_quot) l\n (fun f l ->\n match l with\n | [] -> ()\n | _ -> pp f \"@;of@;%a\" (list (core_type ctxt) ~sep:\"&\") ctl)\n ctl (attributes ctxt) x.prf_attributes\n | Rinherit ct -> core_type ctxt f ct\n in\n pp f \"@[<2>[%a%a]@]\"\n (fun f l ->\n match (l, closed) with\n | [], Closed -> ()\n | [], Open -> pp f \">\" (* Cf #7200: print [>] correctly *)\n | _ ->\n pp f \"%s@;%a\"\n (match (closed, low) with\n | Closed, None -> if first_is_inherit then \" |\" else \"\"\n | Closed, Some _ -> \"<\" (* FIXME desugar the syntax sugar*)\n | Open, _ -> \">\")\n (list type_variant_helper ~sep:\"@;<1 -2>| \")\n l)\n l\n (fun f low ->\n match low with\n | Some [] | None -> ()\n | Some xs -> pp f \">@ %a\" (list string_quot) xs)\n low\n | Ptyp_object (l, o) ->\n let core_field_type f x =\n match x.pof_desc with\n | Otag (l, ct) ->\n (* Cf #7200 *)\n pp f \"@[%s: %a@ %a@ @]\" l.txt (core_type ctxt) ct\n (attributes ctxt) x.pof_attributes\n | Oinherit ct -> pp f \"@[%a@ @]\" (core_type ctxt) ct\n in\n let field_var f = function\n | Asttypes.Closed -> ()\n | Asttypes.Open -> (\n match l with [] -> pp f \"..\" | _ -> pp f \" ;..\")\n in\n pp f \"@[<@ %a%a@ > @]\"\n (list core_field_type ~sep:\";\")\n l field_var o\n (* Cf #7200 *)\n | Ptyp_class (li, l) ->\n (*FIXME*)\n pp f \"@[%a#%a@]\"\n (list (core_type ctxt) ~sep:\",\" ~first:\"(\" ~last:\")\")\n l longident_loc li\n | Ptyp_package (lid, cstrs) -> (\n let aux f (s, ct) =\n pp f \"type %a@ =@ %a\" longident_loc s (core_type ctxt) ct\n in\n match cstrs with\n | [] -> pp f \"@[(module@ %a)@]\" longident_loc lid\n | _ ->\n pp f \"@[(module@ %a@ with@ %a)@]\" longident_loc lid\n (list aux ~sep:\"@ and@ \") cstrs)\n | Ptyp_extension e -> extension ctxt f e\n | _ -> paren true (core_type ctxt) f x\n\n(********************pattern********************)\n(* be cautious when use [pattern], [pattern1] is preferred *)\nand pattern ctxt f x =\n let rec list_of_pattern acc = function\n (* only consider ((A|B)|C)*)\n | { ppat_desc = Ppat_or (p1, p2); ppat_attributes = [] } ->\n list_of_pattern (p2 :: acc) p1\n | x -> x :: acc\n in\n if x.ppat_attributes <> [] then\n pp f \"((%a)%a)\" (pattern ctxt)\n { x with ppat_attributes = [] }\n (attributes ctxt) x.ppat_attributes\n else\n match x.ppat_desc with\n | Ppat_alias (p, s) ->\n pp f \"@[<2>%a@;as@;%a@]\" (pattern ctxt) p protect_ident s.txt (* RA*)\n | Ppat_or _ ->\n (* *)\n pp f \"@[%a@]\"\n (list ~sep:\"@,|\" (pattern ctxt))\n (list_of_pattern [] x)\n | _ -> pattern1 ctxt f x\n\nand pattern1 ctxt (f : Format.formatter) (x : pattern) : unit =\n let rec pattern_list_helper f = function\n | {\n ppat_desc =\n Ppat_construct\n ( { txt = Lident \"::\"; _ },\n Some { ppat_desc = Ppat_tuple [ pat1; pat2 ]; _ } );\n ppat_attributes = [];\n } ->\n pp f \"%a::%a\" (simple_pattern ctxt) pat1 pattern_list_helper pat2 (*RA*)\n | p -> pattern1 ctxt f p\n in\n if x.ppat_attributes <> [] then pattern ctxt f x\n else\n match x.ppat_desc with\n | Ppat_variant (l, Some p) ->\n pp f \"@[<2>`%s@;%a@]\" l (simple_pattern ctxt) p\n | Ppat_construct ({ txt = Lident (\"()\" | \"[]\"); _ }, _) ->\n simple_pattern ctxt f x\n | Ppat_construct (({ txt; _ } as li), po) -> (\n if (* FIXME The third field always false *)\n txt = Lident \"::\" then pp f \"%a\" pattern_list_helper x\n else\n match po with\n | Some x -> pp f \"%a@;%a\" longident_loc li (simple_pattern ctxt) x\n | None -> pp f \"%a\" longident_loc li)\n | _ -> simple_pattern ctxt f x\n\nand simple_pattern ctxt (f : Format.formatter) (x : pattern) : unit =\n if x.ppat_attributes <> [] then pattern ctxt f x\n else\n match x.ppat_desc with\n | Ppat_construct ({ txt = Lident ((\"()\" | \"[]\") as x); _ }, _) ->\n pp f \"%s\" x\n | Ppat_any -> pp f \"_\"\n | Ppat_var { txt; _ } -> protect_ident f txt\n | Ppat_array l -> pp f \"@[<2>[|%a|]@]\" (list (pattern1 ctxt) ~sep:\";\") l\n | Ppat_unpack { txt = None } -> pp f \"(module@ _)@ \"\n | Ppat_unpack { txt = Some s } -> pp f \"(module@ %s)@ \" s\n | Ppat_type li -> pp f \"#%a\" longident_loc li\n | Ppat_record (l, closed) -> (\n let longident_x_pattern f (li, p) =\n match (li, p) with\n | ( { txt = Lident s; _ },\n { ppat_desc = Ppat_var { txt; _ }; ppat_attributes = []; _ } )\n when s = txt ->\n pp f \"@[<2>%a@]\" longident_loc li\n | _ -> pp f \"@[<2>%a@;=@;%a@]\" longident_loc li (pattern1 ctxt) p\n in\n match closed with\n | Closed ->\n pp f \"@[<2>{@;%a@;}@]\" (list longident_x_pattern ~sep:\";@;\") l\n | _ -> pp f \"@[<2>{@;%a;_}@]\" (list longident_x_pattern ~sep:\";@;\") l)\n | Ppat_tuple l ->\n pp f \"@[<1>(%a)@]\" (list ~sep:\",@;\" (pattern1 ctxt)) l (* level1*)\n | Ppat_constant c -> pp f \"%a\" constant c\n | Ppat_interval (c1, c2) -> pp f \"%a..%a\" constant c1 constant c2\n | Ppat_variant (l, None) -> pp f \"`%s\" l\n | Ppat_constraint (p, ct) ->\n pp f \"@[<2>(%a@;:@;%a)@]\" (pattern1 ctxt) p (core_type ctxt) ct\n | Ppat_lazy p -> pp f \"@[<2>(lazy@;%a)@]\" (pattern1 ctxt) p\n | Ppat_exception p -> pp f \"@[<2>exception@;%a@]\" (pattern1 ctxt) p\n | Ppat_extension e -> extension ctxt f e\n | Ppat_open (lid, p) ->\n let with_paren =\n match p.ppat_desc with\n | Ppat_array _ | Ppat_record _\n | Ppat_construct ({ txt = Lident (\"()\" | \"[]\"); _ }, _) ->\n false\n | _ -> true\n in\n pp f \"@[<2>%a.%a @]\" longident_loc lid\n (paren with_paren @@ pattern1 ctxt)\n p\n | _ -> paren true (pattern ctxt) f x\n\nand label_exp ctxt f (l, opt, p) =\n match l with\n | Nolabel ->\n (* single case pattern parens needed here *)\n pp f \"%a@ \" (simple_pattern ctxt) p\n | Optional rest -> (\n match p with\n | { ppat_desc = Ppat_var { txt; _ }; ppat_attributes = [] }\n when txt = rest -> (\n match opt with\n | Some o -> pp f \"?(%s=@;%a)@;\" rest (expression ctxt) o\n | None -> pp f \"?%s@ \" rest)\n | _ -> (\n match opt with\n | Some o ->\n pp f \"?%s:(%a=@;%a)@;\" rest (pattern1 ctxt) p (expression ctxt) o\n | None -> pp f \"?%s:%a@;\" rest (simple_pattern ctxt) p))\n | Labelled l -> (\n match p with\n | { ppat_desc = Ppat_var { txt; _ }; ppat_attributes = [] } when txt = l\n ->\n pp f \"~%s@;\" l\n | _ -> pp f \"~%s:%a@;\" l (simple_pattern ctxt) p)\n\nand sugar_expr ctxt f e =\n if e.pexp_attributes <> [] then false\n else\n match e.pexp_desc with\n | Pexp_apply\n ( { pexp_desc = Pexp_ident { txt = id; _ }; pexp_attributes = []; _ },\n args )\n when List.for_all (fun (lab, _) -> lab = Nolabel) args -> (\n let print_indexop a path_prefix assign left right print_index indices\n rem_args =\n let print_path ppf = function\n | None -> ()\n | Some m -> pp ppf \".%a\" longident m\n in\n match (assign, rem_args) with\n | false, [] ->\n pp f \"@[%a%a%s%a%s@]\" (simple_expr ctxt) a print_path path_prefix\n left\n (list ~sep:\",\" print_index)\n indices right;\n true\n | true, [ v ] ->\n pp f \"@[%a%a%s%a%s@ <-@;<1 2>%a@]\" (simple_expr ctxt) a print_path\n path_prefix left\n (list ~sep:\",\" print_index)\n indices right (simple_expr ctxt) v;\n true\n | _ -> false\n in\n match (id, List.map snd args) with\n | Lident \"!\", [ e ] ->\n pp f \"@[!%a@]\" (simple_expr ctxt) e;\n true\n | Ldot (path, ((\"get\" | \"set\") as func)), a :: other_args -> (\n let assign = func = \"set\" in\n let print = print_indexop a None assign in\n match (path, other_args) with\n | Lident \"Array\", i :: rest ->\n print \".(\" \")\" (expression ctxt) [ i ] rest\n | Lident \"String\", i :: rest ->\n print \".[\" \"]\" (expression ctxt) [ i ] rest\n | Ldot (Lident \"Bigarray\", \"Array1\"), i1 :: rest ->\n print \".{\" \"}\" (simple_expr ctxt) [ i1 ] rest\n | Ldot (Lident \"Bigarray\", \"Array2\"), i1 :: i2 :: rest ->\n print \".{\" \"}\" (simple_expr ctxt) [ i1; i2 ] rest\n | Ldot (Lident \"Bigarray\", \"Array3\"), i1 :: i2 :: i3 :: rest ->\n print \".{\" \"}\" (simple_expr ctxt) [ i1; i2; i3 ] rest\n | ( Ldot (Lident \"Bigarray\", \"Genarray\"),\n { pexp_desc = Pexp_array indexes; pexp_attributes = [] } :: rest\n ) ->\n print \".{\" \"}\" (simple_expr ctxt) indexes rest\n | _ -> false)\n | (Lident s | Ldot (_, s)), a :: i :: rest when first_is '.' s ->\n (* extract operator:\n assignment operators end with [right_bracket ^ \"<-\"],\n access operators end with [right_bracket] directly\n *)\n let assign = last_is '-' s in\n let kind =\n (* extract the right end bracket *)\n let n = String.length s in\n if assign then s.[n - 3] else s.[n - 1]\n in\n let left, right =\n match kind with\n | ')' -> ('(', \")\")\n | ']' -> ('[', \"]\")\n | '}' -> ('{', \"}\")\n | _ -> assert false\n in\n let path_prefix =\n match id with Ldot (m, _) -> Some m | _ -> None\n in\n let left = String.sub s 0 (1 + String.index s left) in\n print_indexop a path_prefix assign left right (expression ctxt)\n [ i ] rest\n | _ -> false)\n | _ -> false\n\nand expression ctxt f x =\n if x.pexp_attributes <> [] then\n pp f \"((%a)@,%a)\" (expression ctxt)\n { x with pexp_attributes = [] }\n (attributes ctxt) x.pexp_attributes\n else\n match x.pexp_desc with\n | Pexp_function _ | Pexp_fun _ | Pexp_match _ | Pexp_try _ | Pexp_sequence _\n when ctxt.pipe || ctxt.semi ->\n paren true (expression reset_ctxt) f x\n | (Pexp_ifthenelse _ | Pexp_sequence _) when ctxt.ifthenelse ->\n paren true (expression reset_ctxt) f x\n | Pexp_let _ | Pexp_letmodule _ | Pexp_open _ | Pexp_letexception _\n | Pexp_letop _\n when ctxt.semi ->\n paren true (expression reset_ctxt) f x\n | Pexp_fun (l, e0, p, e) ->\n pp f \"@[<2>fun@;%a->@;%a@]\" (label_exp ctxt) (l, e0, p)\n (expression ctxt) e\n | Pexp_function l -> pp f \"@[function%a@]\" (case_list ctxt) l\n | Pexp_match (e, l) ->\n pp f \"@[@[@[<2>match %a@]@ with@]%a@]\" (expression reset_ctxt)\n e (case_list ctxt) l\n | Pexp_try (e, l) ->\n pp f \"@[<0>@[try@ %a@]@ @[<0>with%a@]@]\"\n (* \"try@;@[<2>%a@]@\\nwith@\\n%a\"*)\n (expression reset_ctxt)\n e (case_list ctxt) l\n | Pexp_let (rf, l, e) ->\n (* pp f \"@[<2>let %a%a in@;<1 -2>%a@]\"\n (*no indentation here, a new line*) *)\n (* rec_flag rf *)\n pp f \"@[<2>%a in@;<1 -2>%a@]\" (bindings reset_ctxt) (rf, l)\n (expression ctxt) e\n | Pexp_apply (e, l) -> (\n if not (sugar_expr ctxt f x) then\n match view_fixity_of_exp e with\n | `Infix s -> (\n match l with\n | [ ((Nolabel, _) as arg1); ((Nolabel, _) as arg2) ] ->\n (* FIXME associativity label_x_expression_param *)\n pp f \"@[<2>%a@;%s@;%a@]\"\n (label_x_expression_param reset_ctxt)\n arg1 s\n (label_x_expression_param ctxt)\n arg2\n | _ ->\n pp f \"@[<2>%a %a@]\" (simple_expr ctxt) e\n (list (label_x_expression_param ctxt))\n l)\n | `Prefix s -> (\n let s =\n if\n List.mem s [ \"~+\"; \"~-\"; \"~+.\"; \"~-.\" ]\n &&\n match l with\n (* See #7200: avoid turning (~- 1) into (- 1) which is\n parsed as an int literal *)\n | [ (_, { pexp_desc = Pexp_constant _ }) ] -> false\n | _ -> true\n then String.sub s 1 (String.length s - 1)\n else s\n in\n match l with\n | [ (Nolabel, x) ] -> pp f \"@[<2>%s@;%a@]\" s (simple_expr ctxt) x\n | _ ->\n pp f \"@[<2>%a %a@]\" (simple_expr ctxt) e\n (list (label_x_expression_param ctxt))\n l)\n | _ ->\n pp f \"@[%a@]\"\n (fun f (e, l) ->\n pp f \"%a@ %a\" (expression2 ctxt) e\n (list (label_x_expression_param reset_ctxt))\n l\n (* reset here only because [function,match,try,sequence]\n are lower priority *))\n (e, l))\n | Pexp_construct (li, Some eo) when not (is_simple_construct (view_expr x))\n -> (\n (* Not efficient FIXME*)\n match view_expr x with\n | `cons ls -> list (simple_expr ctxt) f ls ~sep:\"@;::@;\"\n | `normal -> pp f \"@[<2>%a@;%a@]\" longident_loc li (simple_expr ctxt) eo\n | _ -> assert false)\n | Pexp_setfield (e1, li, e2) ->\n pp f \"@[<2>%a.%a@ <-@ %a@]\" (simple_expr ctxt) e1 longident_loc li\n (simple_expr ctxt) e2\n | Pexp_ifthenelse (e1, e2, eo) ->\n (* @;@[<2>else@ %a@]@] *)\n let fmt : (_, _, _) format =\n \"@[@[<2>if@ %a@]@;@[<2>then@ %a@]%a@]\"\n in\n let expression_under_ifthenelse = expression (under_ifthenelse ctxt) in\n pp f fmt expression_under_ifthenelse e1 expression_under_ifthenelse e2\n (fun f eo ->\n match eo with\n | Some x ->\n pp f \"@;@[<2>else@;%a@]\" (expression (under_semi ctxt)) x\n | None -> ()\n (* pp f \"()\" *))\n eo\n | Pexp_sequence _ ->\n let rec sequence_helper acc = function\n | { pexp_desc = Pexp_sequence (e1, e2); pexp_attributes = [] } ->\n sequence_helper (e1 :: acc) e2\n | v -> List.rev (v :: acc)\n in\n let lst = sequence_helper [] x in\n pp f \"@[%a@]\" (list (expression (under_semi ctxt)) ~sep:\";@;\") lst\n | Pexp_new li -> pp f \"@[new@ %a@]\" longident_loc li\n | Pexp_setinstvar (s, e) ->\n pp f \"@[%s@ <-@ %a@]\" s.txt (expression ctxt) e\n | Pexp_override l ->\n (* FIXME *)\n let string_x_expression f (s, e) =\n pp f \"@[%s@ =@ %a@]\" s.txt (expression ctxt) e\n in\n pp f \"@[{<%a>}@]\" (list string_x_expression ~sep:\";\") l\n | Pexp_letmodule (s, me, e) ->\n pp f \"@[let@ module@ %s@ =@ %a@ in@ %a@]\"\n (match s.txt with None -> \"_\" | Some s -> s)\n (module_expr reset_ctxt) me (expression ctxt) e\n | Pexp_letexception (cd, e) ->\n pp f \"@[let@ exception@ %a@ in@ %a@]\"\n (extension_constructor ctxt)\n cd (expression ctxt) e\n | Pexp_assert e -> pp f \"@[assert@ %a@]\" (simple_expr ctxt) e\n | Pexp_lazy e -> pp f \"@[lazy@ %a@]\" (simple_expr ctxt) e\n (* Pexp_poly: impossible but we should print it anyway, rather than\n assert false *)\n | Pexp_poly (e, None) -> pp f \"@[!poly!@ %a@]\" (simple_expr ctxt) e\n | Pexp_poly (e, Some ct) ->\n pp f \"@[(!poly!@ %a@ : %a)@]\" (simple_expr ctxt) e\n (core_type ctxt) ct\n | Pexp_open (o, e) ->\n pp f \"@[<2>let open%s %a in@;%a@]\"\n (override o.popen_override)\n (module_expr ctxt) o.popen_expr (expression ctxt) e\n | Pexp_variant (l, Some eo) -> pp f \"@[<2>`%s@;%a@]\" l (simple_expr ctxt) eo\n | Pexp_letop { let_; ands; body } ->\n pp f \"@[<2>@[%a@,%a@] in@;<1 -2>%a@]\" (binding_op ctxt) let_\n (list ~sep:\"@,\" (binding_op ctxt))\n ands (expression ctxt) body\n | Pexp_extension e -> extension ctxt f e\n | Pexp_unreachable -> pp f \".\"\n | _ -> expression1 ctxt f x\n\nand expression1 ctxt f x =\n if x.pexp_attributes <> [] then expression ctxt f x\n else\n match x.pexp_desc with\n | Pexp_object cs -> pp f \"%a\" (class_structure ctxt) cs\n | _ -> expression2 ctxt f x\n(* used in [Pexp_apply] *)\n\nand expression2 ctxt f x =\n if x.pexp_attributes <> [] then expression ctxt f x\n else\n match x.pexp_desc with\n | Pexp_field (e, li) ->\n pp f \"@[%a.%a@]\" (simple_expr ctxt) e longident_loc li\n | Pexp_send (e, s) -> pp f \"@[%a#%s@]\" (simple_expr ctxt) e s.txt\n | _ -> simple_expr ctxt f x\n\nand simple_expr ctxt f x =\n if x.pexp_attributes <> [] then expression ctxt f x\n else\n match x.pexp_desc with\n | Pexp_construct _ when is_simple_construct (view_expr x) -> (\n match view_expr x with\n | `nil -> pp f \"[]\"\n | `tuple -> pp f \"()\"\n | `list xs ->\n pp f \"@[[%a]@]\"\n (list (expression (under_semi ctxt)) ~sep:\";@;\")\n xs\n | `simple x -> longident f x\n | _ -> assert false)\n | Pexp_ident li -> longident_loc f li\n (* (match view_fixity_of_exp x with *)\n (* |`Normal -> longident_loc f li *)\n (* | `Prefix _ | `Infix _ -> pp f \"( %a )\" longident_loc li) *)\n | Pexp_constant c -> constant f c\n | Pexp_pack me -> pp f \"(module@;%a)\" (module_expr ctxt) me\n | Pexp_newtype (lid, e) ->\n pp f \"fun@;(type@;%s)@;->@;%a\" lid.txt (expression ctxt) e\n | Pexp_tuple l ->\n pp f \"@[(%a)@]\" (list (simple_expr ctxt) ~sep:\",@;\") l\n | Pexp_constraint (e, ct) ->\n pp f \"(%a : %a)\" (expression ctxt) e (core_type ctxt) ct\n | Pexp_coerce (e, cto1, ct) ->\n pp f \"(%a%a :> %a)\" (expression ctxt) e\n (option (core_type ctxt) ~first:\" : \" ~last:\" \")\n cto1\n (* no sep hint*) (core_type ctxt)\n ct\n | Pexp_variant (l, None) -> pp f \"`%s\" l\n | Pexp_record (l, eo) ->\n let longident_x_expression f (li, e) =\n match e with\n | { pexp_desc = Pexp_ident { txt; _ }; pexp_attributes = []; _ }\n when li.txt = txt ->\n pp f \"@[%a@]\" longident_loc li\n | _ ->\n pp f \"@[%a@;=@;%a@]\" longident_loc li (simple_expr ctxt) e\n in\n pp f \"@[@[{@;%a%a@]@;}@]\" (* \"@[{%a%a}@]\" *)\n (option ~last:\" with@;\" (simple_expr ctxt))\n eo\n (list longident_x_expression ~sep:\";@;\")\n l\n | Pexp_array l ->\n pp f \"@[<0>@[<2>[|%a|]@]@]\"\n (list (simple_expr (under_semi ctxt)) ~sep:\";\")\n l\n | Pexp_while (e1, e2) ->\n let fmt : (_, _, _) format = \"@[<2>while@;%a@;do@;%a@;done@]\" in\n pp f fmt (expression ctxt) e1 (expression ctxt) e2\n | Pexp_for (s, e1, e2, df, e3) ->\n let fmt : (_, _, _) format =\n \"@[@[@[<2>for %a =@;%a@;%a%a@;do@]@;%a@]@;done@]\"\n in\n let expression = expression ctxt in\n pp f fmt (pattern ctxt) s expression e1 direction_flag df expression e2\n expression e3\n | _ -> paren true (expression ctxt) f x\n\nand attributes ctxt f l = List.iter (attribute ctxt f) l\nand item_attributes ctxt f l = List.iter (item_attribute ctxt f) l\n\nand attribute ctxt f a =\n pp f \"@[<2>[@@%s@ %a]@]\" a.attr_name.txt (payload ctxt) a.attr_payload\n\nand item_attribute ctxt f a =\n pp f \"@[<2>[@@@@%s@ %a]@]\" a.attr_name.txt (payload ctxt) a.attr_payload\n\nand floating_attribute ctxt f a =\n pp f \"@[<2>[@@@@@@%s@ %a]@]\" a.attr_name.txt (payload ctxt) a.attr_payload\n\nand value_description ctxt f x =\n (* note: value_description has an attribute field,\n but they're already printed by the callers this method *)\n pp f \"@[%a%a@]\" (core_type ctxt) x.pval_type\n (fun f x ->\n if x.pval_prim <> [] then\n pp f \"@ =@ %a\" (list constant_string) x.pval_prim)\n x\n\nand extension ctxt f (s, e) = pp f \"@[<2>[%%%s@ %a]@]\" s.txt (payload ctxt) e\n\nand item_extension ctxt f (s, e) =\n pp f \"@[<2>[%%%%%s@ %a]@]\" s.txt (payload ctxt) e\n\nand exception_declaration ctxt f x =\n pp f \"@[exception@ %a@]%a\"\n (extension_constructor ctxt)\n x.ptyexn_constructor (item_attributes ctxt) x.ptyexn_attributes\n\nand class_type_field ctxt f x =\n match x.pctf_desc with\n | Pctf_inherit ct ->\n pp f \"@[<2>inherit@ %a@]%a\" (class_type ctxt) ct (item_attributes ctxt)\n x.pctf_attributes\n | Pctf_val (s, mf, vf, ct) ->\n pp f \"@[<2>val @ %a%a%s@ :@ %a@]%a\" mutable_flag mf virtual_flag vf s.txt\n (core_type ctxt) ct (item_attributes ctxt) x.pctf_attributes\n | Pctf_method (s, pf, vf, ct) ->\n pp f \"@[<2>method %a %a%s :@;%a@]%a\" private_flag pf virtual_flag vf s.txt\n (core_type ctxt) ct (item_attributes ctxt) x.pctf_attributes\n | Pctf_constraint (ct1, ct2) ->\n pp f \"@[<2>constraint@ %a@ =@ %a@]%a\" (core_type ctxt) ct1\n (core_type ctxt) ct2 (item_attributes ctxt) x.pctf_attributes\n | Pctf_attribute a -> floating_attribute ctxt f a\n | Pctf_extension e ->\n item_extension ctxt f e;\n item_attributes ctxt f x.pctf_attributes\n\nand class_signature ctxt f { pcsig_self = ct; pcsig_fields = l; _ } =\n pp f \"@[@[object@[<1>%a@]@ %a@]@ end@]\"\n (fun f -> function\n | { ptyp_desc = Ptyp_any; ptyp_attributes = []; _ } -> ()\n | ct -> pp f \" (%a)\" (core_type ctxt) ct)\n ct\n (list (class_type_field ctxt) ~sep:\"@;\")\n l\n\n(* call [class_signature] called by [class_signature] *)\nand class_type ctxt f x =\n match x.pcty_desc with\n | Pcty_signature cs ->\n class_signature ctxt f cs;\n attributes ctxt f x.pcty_attributes\n | Pcty_constr (li, l) ->\n pp f \"%a%a%a\"\n (fun f l ->\n match l with\n | [] -> ()\n | _ -> pp f \"[%a]@ \" (list (core_type ctxt) ~sep:\",\") l)\n l longident_loc li (attributes ctxt) x.pcty_attributes\n | Pcty_arrow (l, co, cl) ->\n pp f \"@[<2>%a@;->@;%a@]\" (* FIXME remove parens later *)\n (type_with_label ctxt) (l, co) (class_type ctxt) cl\n | Pcty_extension e ->\n extension ctxt f e;\n attributes ctxt f x.pcty_attributes\n | Pcty_open (o, e) ->\n pp f \"@[<2>let open%s %a in@;%a@]\"\n (override o.popen_override)\n longident_loc o.popen_expr (class_type ctxt) e\n\n(* [class type a = object end] *)\nand class_type_declaration_list ctxt f l =\n let class_type_declaration kwd f x =\n let { pci_params = ls; pci_name = { txt; _ }; _ } = x in\n pp f \"@[<2>%s %a%a%s@ =@ %a@]%a\" kwd virtual_flag x.pci_virt\n (class_params_def ctxt) ls txt (class_type ctxt) x.pci_expr\n (item_attributes ctxt) x.pci_attributes\n in\n match l with\n | [] -> ()\n | [ x ] -> class_type_declaration \"class type\" f x\n | x :: xs ->\n pp f \"@[%a@,%a@]\"\n (class_type_declaration \"class type\")\n x\n (list ~sep:\"@,\" (class_type_declaration \"and\"))\n xs\n\nand class_field ctxt f x =\n match x.pcf_desc with\n | Pcf_inherit (ovf, ce, so) ->\n pp f \"@[<2>inherit@ %s@ %a%a@]%a\" (override ovf) (class_expr ctxt) ce\n (fun f so ->\n match so with None -> () | Some s -> pp f \"@ as %s\" s.txt)\n so (item_attributes ctxt) x.pcf_attributes\n | Pcf_val (s, mf, Cfk_concrete (ovf, e)) ->\n pp f \"@[<2>val%s %a%s =@;%a@]%a\" (override ovf) mutable_flag mf s.txt\n (expression ctxt) e (item_attributes ctxt) x.pcf_attributes\n | Pcf_method (s, pf, Cfk_virtual ct) ->\n pp f \"@[<2>method virtual %a %s :@;%a@]%a\" private_flag pf s.txt\n (core_type ctxt) ct (item_attributes ctxt) x.pcf_attributes\n | Pcf_val (s, mf, Cfk_virtual ct) ->\n pp f \"@[<2>val virtual %a%s :@ %a@]%a\" mutable_flag mf s.txt\n (core_type ctxt) ct (item_attributes ctxt) x.pcf_attributes\n | Pcf_method (s, pf, Cfk_concrete (ovf, e)) ->\n let bind e =\n binding ctxt f\n {\n pvb_pat =\n {\n ppat_desc = Ppat_var s;\n ppat_loc = Location.none;\n ppat_loc_stack = [];\n ppat_attributes = [];\n };\n pvb_expr = e;\n pvb_attributes = [];\n pvb_loc = Location.none;\n }\n in\n pp f \"@[<2>method%s %a%a@]%a\" (override ovf) private_flag pf\n (fun f -> function\n | { pexp_desc = Pexp_poly (e, Some ct); pexp_attributes = []; _ } ->\n pp f \"%s :@;%a=@;%a\" s.txt (core_type ctxt) ct (expression ctxt) e\n | { pexp_desc = Pexp_poly (e, None); pexp_attributes = []; _ } ->\n bind e\n | _ -> bind e)\n e (item_attributes ctxt) x.pcf_attributes\n | Pcf_constraint (ct1, ct2) ->\n pp f \"@[<2>constraint %a =@;%a@]%a\" (core_type ctxt) ct1 (core_type ctxt)\n ct2 (item_attributes ctxt) x.pcf_attributes\n | Pcf_initializer e ->\n pp f \"@[<2>initializer@ %a@]%a\" (expression ctxt) e (item_attributes ctxt)\n x.pcf_attributes\n | Pcf_attribute a -> floating_attribute ctxt f a\n | Pcf_extension e ->\n item_extension ctxt f e;\n item_attributes ctxt f x.pcf_attributes\n\nand class_structure ctxt f { pcstr_self = p; pcstr_fields = l } =\n pp f \"@[@[object%a@;%a@]@;end@]\"\n (fun f p ->\n match p.ppat_desc with\n | Ppat_any -> ()\n | Ppat_constraint _ -> pp f \" %a\" (pattern ctxt) p\n | _ -> pp f \" (%a)\" (pattern ctxt) p)\n p\n (list (class_field ctxt))\n l\n\nand class_expr ctxt f x =\n if x.pcl_attributes <> [] then\n pp f \"((%a)%a)\" (class_expr ctxt)\n { x with pcl_attributes = [] }\n (attributes ctxt) x.pcl_attributes\n else\n match x.pcl_desc with\n | Pcl_structure cs -> class_structure ctxt f cs\n | Pcl_fun (l, eo, p, e) ->\n pp f \"fun@ %a@ ->@ %a\" (label_exp ctxt) (l, eo, p) (class_expr ctxt) e\n | Pcl_let (rf, l, ce) ->\n pp f \"%a@ in@ %a\" (bindings ctxt) (rf, l) (class_expr ctxt) ce\n | Pcl_apply (ce, l) ->\n pp f \"((%a)@ %a)\"\n (* Cf: #7200 *) (class_expr ctxt)\n ce\n (list (label_x_expression_param ctxt))\n l\n | Pcl_constr (li, l) ->\n pp f \"%a%a\"\n (fun f l ->\n if l <> [] then pp f \"[%a]@ \" (list (core_type ctxt) ~sep:\",\") l)\n l longident_loc li\n | Pcl_constraint (ce, ct) ->\n pp f \"(%a@ :@ %a)\" (class_expr ctxt) ce (class_type ctxt) ct\n | Pcl_extension e -> extension ctxt f e\n | Pcl_open (o, e) ->\n pp f \"@[<2>let open%s %a in@;%a@]\"\n (override o.popen_override)\n longident_loc o.popen_expr (class_expr ctxt) e\n\nand module_type ctxt f x =\n if x.pmty_attributes <> [] then\n pp f \"((%a)%a)\" (module_type ctxt)\n { x with pmty_attributes = [] }\n (attributes ctxt) x.pmty_attributes\n else\n match x.pmty_desc with\n | Pmty_functor (Unit, mt2) ->\n pp f \"@[functor () ->@ %a@]\" (module_type ctxt) mt2\n | Pmty_functor (Named (s, mt1), mt2) -> (\n match s.txt with\n | None ->\n pp f \"@[%a@ ->@ %a@]\" (module_type1 ctxt) mt1\n (module_type ctxt) mt2\n | Some name ->\n pp f \"@[functor@ (%s@ :@ %a)@ ->@ %a@]\" name\n (module_type ctxt) mt1 (module_type ctxt) mt2)\n | Pmty_with (mt, []) -> module_type ctxt f mt\n | Pmty_with (mt, l) ->\n let with_constraint f = function\n | Pwith_type (li, ({ ptype_params = ls; _ } as td)) ->\n let ls = List.map fst ls in\n pp f \"type@ %a %a =@ %a\"\n (list (core_type ctxt) ~sep:\",\" ~first:\"(\" ~last:\")\")\n ls longident_loc li (type_declaration ctxt) td\n | Pwith_module (li, li2) ->\n pp f \"module %a =@ %a\" longident_loc li longident_loc li2\n | Pwith_typesubst (li, ({ ptype_params = ls; _ } as td)) ->\n let ls = List.map fst ls in\n pp f \"type@ %a %a :=@ %a\"\n (list (core_type ctxt) ~sep:\",\" ~first:\"(\" ~last:\")\")\n ls longident_loc li (type_declaration ctxt) td\n | Pwith_modsubst (li, li2) ->\n pp f \"module %a :=@ %a\" longident_loc li longident_loc li2\n in\n pp f \"@[%a@ with@ %a@]\" (module_type1 ctxt) mt\n (list with_constraint ~sep:\"@ and@ \")\n l\n | _ -> module_type1 ctxt f x\n\nand module_type1 ctxt f x =\n if x.pmty_attributes <> [] then module_type ctxt f x\n else\n match x.pmty_desc with\n | Pmty_ident li -> pp f \"%a\" longident_loc li\n | Pmty_alias li -> pp f \"(module %a)\" longident_loc li\n | Pmty_signature s ->\n pp f \"@[@[sig@ %a@]@ end@]\" (* \"@[sig@ %a@ end@]\" *)\n (list (signature_item ctxt))\n s\n (* FIXME wrong indentation*)\n | Pmty_typeof me ->\n pp f \"@[module@ type@ of@ %a@]\" (module_expr ctxt) me\n | Pmty_extension e -> extension ctxt f e\n | _ -> paren true (module_type ctxt) f x\n\nand signature ctxt f x = list ~sep:\"@\\n\" (signature_item ctxt) f x\n\nand signature_item ctxt f x : unit =\n match x.psig_desc with\n | Psig_type (rf, l) -> type_def_list ctxt f (rf, true, l)\n | Psig_typesubst l ->\n (* Psig_typesubst is never recursive, but we specify [Recursive] here to\n avoid printing a [nonrec] flag, which would be rejected by the parser.\n *)\n type_def_list ctxt f (Recursive, false, l)\n | Psig_value vd ->\n let intro = if vd.pval_prim = [] then \"val\" else \"external\" in\n pp f \"@[<2>%s@ %a@ :@ %a@]%a\" intro protect_ident vd.pval_name.txt\n (value_description ctxt) vd (item_attributes ctxt) vd.pval_attributes\n | Psig_typext te -> type_extension ctxt f te\n | Psig_exception ed -> exception_declaration ctxt f ed\n | Psig_class l -> (\n let class_description kwd f\n ({ pci_params = ls; pci_name = { txt; _ }; _ } as x) =\n pp f \"@[<2>%s %a%a%s@;:@;%a@]%a\" kwd virtual_flag x.pci_virt\n (class_params_def ctxt) ls txt (class_type ctxt) x.pci_expr\n (item_attributes ctxt) x.pci_attributes\n in\n match l with\n | [] -> ()\n | [ x ] -> class_description \"class\" f x\n | x :: xs ->\n pp f \"@[%a@,%a@]\"\n (class_description \"class\")\n x\n (list ~sep:\"@,\" (class_description \"and\"))\n xs)\n | Psig_module\n ({\n pmd_type = { pmty_desc = Pmty_alias alias; pmty_attributes = []; _ };\n _;\n } as pmd) ->\n pp f \"@[module@ %s@ =@ %a@]%a\"\n (match pmd.pmd_name.txt with None -> \"_\" | Some s -> s)\n longident_loc alias (item_attributes ctxt) pmd.pmd_attributes\n | Psig_module pmd ->\n pp f \"@[module@ %s@ :@ %a@]%a\"\n (match pmd.pmd_name.txt with None -> \"_\" | Some s -> s)\n (module_type ctxt) pmd.pmd_type (item_attributes ctxt)\n pmd.pmd_attributes\n | Psig_modsubst pms ->\n pp f \"@[module@ %s@ :=@ %a@]%a\" pms.pms_name.txt longident_loc\n pms.pms_manifest (item_attributes ctxt) pms.pms_attributes\n | Psig_open od ->\n pp f \"@[open%s@ %a@]%a\"\n (override od.popen_override)\n longident_loc od.popen_expr (item_attributes ctxt) od.popen_attributes\n | Psig_include incl ->\n pp f \"@[include@ %a@]%a\" (module_type ctxt) incl.pincl_mod\n (item_attributes ctxt) incl.pincl_attributes\n | Psig_modtype { pmtd_name = s; pmtd_type = md; pmtd_attributes = attrs } ->\n pp f \"@[module@ type@ %s%a@]%a\" s.txt\n (fun f md ->\n match md with\n | None -> ()\n | Some mt ->\n pp_print_space f ();\n pp f \"@ =@ %a\" (module_type ctxt) mt)\n md (item_attributes ctxt) attrs\n | Psig_class_type l -> class_type_declaration_list ctxt f l\n | Psig_recmodule decls ->\n let rec string_x_module_type_list f ?(first = true) l =\n match l with\n | [] -> ()\n | pmd :: tl ->\n if not first then\n pp f \"@ @[and@ %s:@ %a@]%a\"\n (match pmd.pmd_name.txt with None -> \"_\" | Some s -> s)\n (module_type1 ctxt) pmd.pmd_type (item_attributes ctxt)\n pmd.pmd_attributes\n else\n pp f \"@[module@ rec@ %s:@ %a@]%a\"\n (match pmd.pmd_name.txt with None -> \"_\" | Some s -> s)\n (module_type1 ctxt) pmd.pmd_type (item_attributes ctxt)\n pmd.pmd_attributes;\n string_x_module_type_list f ~first:false tl\n in\n string_x_module_type_list f decls\n | Psig_attribute a -> floating_attribute ctxt f a\n | Psig_extension (e, a) ->\n item_extension ctxt f e;\n item_attributes ctxt f a\n\nand module_expr ctxt f x =\n if x.pmod_attributes <> [] then\n pp f \"((%a)%a)\" (module_expr ctxt)\n { x with pmod_attributes = [] }\n (attributes ctxt) x.pmod_attributes\n else\n match x.pmod_desc with\n | Pmod_structure s ->\n pp f \"@[struct@;@[<0>%a@]@;<1 -2>end@]\"\n (list (structure_item ctxt) ~sep:\"@\\n\")\n s\n | Pmod_constraint (me, mt) ->\n pp f \"@[(%a@ :@ %a)@]\" (module_expr ctxt) me (module_type ctxt) mt\n | Pmod_ident li -> pp f \"%a\" longident_loc li\n | Pmod_functor (Unit, me) -> pp f \"functor ()@;->@;%a\" (module_expr ctxt) me\n | Pmod_functor (Named (s, mt), me) ->\n pp f \"functor@ (%s@ :@ %a)@;->@;%a\"\n (match s.txt with None -> \"_\" | Some s -> s)\n (module_type ctxt) mt (module_expr ctxt) me\n | Pmod_apply (me1, me2) ->\n pp f \"(%a)(%a)\" (module_expr ctxt) me1 (module_expr ctxt) me2\n (* Cf: #7200 *)\n | Pmod_unpack e -> pp f \"(val@ %a)\" (expression ctxt) e\n | Pmod_extension e -> extension ctxt f e\n\nand structure ctxt f x = list ~sep:\"@\\n\" (structure_item ctxt) f x\n\nand payload ctxt f = function\n | PStr [ { pstr_desc = Pstr_eval (e, attrs) } ] ->\n pp f \"@[<2>%a@]%a\" (expression ctxt) e (item_attributes ctxt) attrs\n | PStr x -> structure ctxt f x\n | PTyp x ->\n pp f \":@ \";\n core_type ctxt f x\n | PSig x ->\n pp f \":@ \";\n signature ctxt f x\n | PPat (x, None) ->\n pp f \"?@ \";\n pattern ctxt f x\n | PPat (x, Some e) ->\n pp f \"?@ \";\n pattern ctxt f x;\n pp f \" when \";\n expression ctxt f e\n\n(* transform [f = fun g h -> ..] to [f g h = ... ] could be improved *)\nand binding ctxt f { pvb_pat = p; pvb_expr = x; _ } =\n (* .pvb_attributes have already been printed by the caller, #bindings *)\n let rec pp_print_pexp_function f x =\n if x.pexp_attributes <> [] then pp f \"=@;%a\" (expression ctxt) x\n else\n match x.pexp_desc with\n | Pexp_fun (label, eo, p, e) ->\n if label = Nolabel then\n pp f \"%a@ %a\" (simple_pattern ctxt) p pp_print_pexp_function e\n else\n pp f \"%a@ %a\" (label_exp ctxt) (label, eo, p) pp_print_pexp_function\n e\n | Pexp_newtype (str, e) ->\n pp f \"(type@ %s)@ %a\" str.txt pp_print_pexp_function e\n | _ -> pp f \"=@;%a\" (expression ctxt) x\n in\n let tyvars_str tyvars = List.map (fun v -> v.txt) tyvars in\n let is_desugared_gadt p e =\n let gadt_pattern =\n match p with\n | {\n ppat_desc =\n Ppat_constraint\n ( ({ ppat_desc = Ppat_var _ } as pat),\n { ptyp_desc = Ptyp_poly (args_tyvars, rt) } );\n ppat_attributes = [];\n } ->\n Some (pat, args_tyvars, rt)\n | _ -> None\n in\n let rec gadt_exp tyvars e =\n match e with\n | { pexp_desc = Pexp_newtype (tyvar, e); pexp_attributes = [] } ->\n gadt_exp (tyvar :: tyvars) e\n | { pexp_desc = Pexp_constraint (e, ct); pexp_attributes = [] } ->\n Some (List.rev tyvars, e, ct)\n | _ -> None\n in\n let gadt_exp = gadt_exp [] e in\n match (gadt_pattern, gadt_exp) with\n | Some (p, pt_tyvars, pt_ct), Some (e_tyvars, e, e_ct)\n when tyvars_str pt_tyvars = tyvars_str e_tyvars ->\n let ety = varify_type_constructors e_tyvars e_ct in\n if ety = pt_ct then Some (p, pt_tyvars, e_ct, e) else None\n | _ -> None\n in\n if x.pexp_attributes <> [] then\n match p with\n | {\n ppat_desc =\n Ppat_constraint\n ( ({ ppat_desc = Ppat_var _; _ } as pat),\n ({ ptyp_desc = Ptyp_poly _; _ } as typ) );\n ppat_attributes = [];\n _;\n } ->\n pp f \"%a@;: %a@;=@;%a\" (simple_pattern ctxt) pat (core_type ctxt) typ\n (expression ctxt) x\n | _ -> pp f \"%a@;=@;%a\" (pattern ctxt) p (expression ctxt) x\n else\n match is_desugared_gadt p x with\n | Some (p, [], ct, e) ->\n pp f \"%a@;: %a@;=@;%a\" (simple_pattern ctxt) p (core_type ctxt) ct\n (expression ctxt) e\n | Some (p, tyvars, ct, e) ->\n pp f \"%a@;: type@;%a.@;%a@;=@;%a\" (simple_pattern ctxt) p\n (list pp_print_string ~sep:\"@;\")\n (tyvars_str tyvars) (core_type ctxt) ct (expression ctxt) e\n | None -> (\n match p with\n | { ppat_desc = Ppat_constraint (p, ty); ppat_attributes = [] } -> (\n (* special case for the first*)\n match ty with\n | { ptyp_desc = Ptyp_poly _; ptyp_attributes = [] } ->\n pp f \"%a@;:@;%a@;=@;%a\" (simple_pattern ctxt) p (core_type ctxt)\n ty (expression ctxt) x\n | _ ->\n pp f \"(%a@;:@;%a)@;=@;%a\" (simple_pattern ctxt) p\n (core_type ctxt) ty (expression ctxt) x)\n | { ppat_desc = Ppat_var _; ppat_attributes = [] } ->\n pp f \"%a@ %a\" (simple_pattern ctxt) p pp_print_pexp_function x\n | _ -> pp f \"%a@;=@;%a\" (pattern ctxt) p (expression ctxt) x)\n\n(* [in] is not printed *)\nand bindings ctxt f (rf, l) =\n let binding kwd rf f x =\n pp f \"@[<2>%s %a%a@]%a\" kwd rec_flag rf (binding ctxt) x\n (item_attributes ctxt) x.pvb_attributes\n in\n match l with\n | [] -> ()\n | [ x ] -> binding \"let\" rf f x\n | x :: xs ->\n pp f \"@[%a@,%a@]\" (binding \"let\" rf) x\n (list ~sep:\"@,\" (binding \"and\" Nonrecursive))\n xs\n\nand binding_op ctxt f x =\n pp f \"@[<2>%s %a@;=@;%a@]\" x.pbop_op.txt (pattern ctxt) x.pbop_pat\n (expression ctxt) x.pbop_exp\n\nand structure_item ctxt f x =\n match x.pstr_desc with\n | Pstr_eval (e, attrs) ->\n pp f \"@[;;%a@]%a\" (expression ctxt) e (item_attributes ctxt) attrs\n | Pstr_type (_, []) -> assert false\n | Pstr_type (rf, l) -> type_def_list ctxt f (rf, true, l)\n | Pstr_value (rf, l) ->\n (* pp f \"@[let %a%a@]\" rec_flag rf bindings l *)\n pp f \"@[<2>%a@]\" (bindings ctxt) (rf, l)\n | Pstr_typext te -> type_extension ctxt f te\n | Pstr_exception ed -> exception_declaration ctxt f ed\n | Pstr_module x ->\n let rec module_helper = function\n | { pmod_desc = Pmod_functor (arg_opt, me'); pmod_attributes = [] } ->\n (match arg_opt with\n | Unit -> pp f \"()\"\n | Named (s, mt) ->\n pp f \"(%s:%a)\"\n (match s.txt with None -> \"_\" | Some s -> s)\n (module_type ctxt) mt);\n module_helper me'\n | me -> me\n in\n pp f \"@[module %s%a@]%a\"\n (match x.pmb_name.txt with None -> \"_\" | Some s -> s)\n (fun f me ->\n let me = module_helper me in\n match me with\n | {\n pmod_desc =\n Pmod_constraint\n (me', ({ pmty_desc = Pmty_ident _ | Pmty_signature _; _ } as mt));\n pmod_attributes = [];\n } ->\n pp f \" :@;%a@;=@;%a@;\" (module_type ctxt) mt (module_expr ctxt)\n me'\n | _ -> pp f \" =@ %a\" (module_expr ctxt) me)\n x.pmb_expr (item_attributes ctxt) x.pmb_attributes\n | Pstr_open od ->\n pp f \"@[<2>open%s@;%a@]%a\"\n (override od.popen_override)\n (module_expr ctxt) od.popen_expr (item_attributes ctxt)\n od.popen_attributes\n | Pstr_modtype { pmtd_name = s; pmtd_type = md; pmtd_attributes = attrs } ->\n pp f \"@[module@ type@ %s%a@]%a\" s.txt\n (fun f md ->\n match md with\n | None -> ()\n | Some mt ->\n pp_print_space f ();\n pp f \"@ =@ %a\" (module_type ctxt) mt)\n md (item_attributes ctxt) attrs\n | Pstr_class l -> (\n let extract_class_args cl =\n let rec loop acc = function\n | { pcl_desc = Pcl_fun (l, eo, p, cl'); pcl_attributes = [] } ->\n loop ((l, eo, p) :: acc) cl'\n | cl -> (List.rev acc, cl)\n in\n let args, cl = loop [] cl in\n let constr, cl =\n match cl with\n | { pcl_desc = Pcl_constraint (cl', ct); pcl_attributes = [] } ->\n (Some ct, cl')\n | _ -> (None, cl)\n in\n (args, constr, cl)\n in\n let class_constraint f ct = pp f \": @[%a@] \" (class_type ctxt) ct in\n let class_declaration kwd f\n ({ pci_params = ls; pci_name = { txt; _ }; _ } as x) =\n let args, constr, cl = extract_class_args x.pci_expr in\n pp f \"@[<2>%s %a%a%s %a%a=@;%a@]%a\" kwd virtual_flag x.pci_virt\n (class_params_def ctxt) ls txt\n (list (label_exp ctxt))\n args (option class_constraint) constr (class_expr ctxt) cl\n (item_attributes ctxt) x.pci_attributes\n in\n match l with\n | [] -> ()\n | [ x ] -> class_declaration \"class\" f x\n | x :: xs ->\n pp f \"@[%a@,%a@]\"\n (class_declaration \"class\")\n x\n (list ~sep:\"@,\" (class_declaration \"and\"))\n xs)\n | Pstr_class_type l -> class_type_declaration_list ctxt f l\n | Pstr_primitive vd ->\n pp f \"@[external@ %a@ :@ %a@]%a\" protect_ident vd.pval_name.txt\n (value_description ctxt) vd (item_attributes ctxt) vd.pval_attributes\n | Pstr_include incl ->\n pp f \"@[include@ %a@]%a\" (module_expr ctxt) incl.pincl_mod\n (item_attributes ctxt) incl.pincl_attributes\n | Pstr_recmodule decls -> (\n (* 3.07 *)\n let aux f = function\n | { pmb_expr = { pmod_desc = Pmod_constraint (expr, typ) } } as pmb ->\n pp f \"@[@ and@ %s:%a@ =@ %a@]%a\"\n (match pmb.pmb_name.txt with None -> \"_\" | Some s -> s)\n (module_type ctxt) typ (module_expr ctxt) expr\n (item_attributes ctxt) pmb.pmb_attributes\n | pmb ->\n pp f \"@[@ and@ %s@ =@ %a@]%a\"\n (match pmb.pmb_name.txt with None -> \"_\" | Some s -> s)\n (module_expr ctxt) pmb.pmb_expr (item_attributes ctxt)\n pmb.pmb_attributes\n in\n match decls with\n | ({ pmb_expr = { pmod_desc = Pmod_constraint (expr, typ) } } as pmb)\n :: l2 ->\n pp f \"@[@[module@ rec@ %s:%a@ =@ %a@]%a@ %a@]\"\n (match pmb.pmb_name.txt with None -> \"_\" | Some s -> s)\n (module_type ctxt) typ (module_expr ctxt) expr\n (item_attributes ctxt) pmb.pmb_attributes\n (fun f l2 -> List.iter (aux f) l2)\n l2\n | pmb :: l2 ->\n pp f \"@[@[module@ rec@ %s@ =@ %a@]%a@ %a@]\"\n (match pmb.pmb_name.txt with None -> \"_\" | Some s -> s)\n (module_expr ctxt) pmb.pmb_expr (item_attributes ctxt)\n pmb.pmb_attributes\n (fun f l2 -> List.iter (aux f) l2)\n l2\n | _ -> assert false)\n | Pstr_attribute a -> floating_attribute ctxt f a\n | Pstr_extension (e, a) ->\n item_extension ctxt f e;\n item_attributes ctxt f a\n\nand type_param ctxt f (ct, (a, b)) =\n pp f \"%s%s%a\" (type_variance a) (type_injectivity b) (core_type ctxt) ct\n\nand type_params ctxt f = function\n | [] -> ()\n | l -> pp f \"%a \" (list (type_param ctxt) ~first:\"(\" ~last:\")\" ~sep:\",@;\") l\n\nand type_def_list ctxt f (rf, exported, l) =\n let type_decl kwd rf f x =\n let eq =\n if x.ptype_kind = Ptype_abstract && x.ptype_manifest = None then \"\"\n else if exported then \" =\"\n else \" :=\"\n in\n pp f \"@[<2>%s %a%a%s%s%a@]%a\" kwd nonrec_flag rf (type_params ctxt)\n x.ptype_params x.ptype_name.txt eq (type_declaration ctxt) x\n (item_attributes ctxt) x.ptype_attributes\n in\n match l with\n | [] -> assert false\n | [ x ] -> type_decl \"type\" rf f x\n | x :: xs ->\n pp f \"@[%a@,%a@]\" (type_decl \"type\" rf) x\n (list ~sep:\"@,\" (type_decl \"and\" Recursive))\n xs\n\nand record_declaration ctxt f lbls =\n let type_record_field f pld =\n pp f \"@[<2>%a%s:@;%a@;%a@]\" mutable_flag pld.pld_mutable pld.pld_name.txt\n (core_type ctxt) pld.pld_type (attributes ctxt) pld.pld_attributes\n in\n pp f \"{@\\n%a}\" (list type_record_field ~sep:\";@\\n\") lbls\n\nand type_declaration ctxt f x =\n (* type_declaration has an attribute field,\n but it's been printed by the caller of this method *)\n let priv f =\n match x.ptype_private with Public -> () | Private -> pp f \"@;private\"\n in\n let manifest f =\n match x.ptype_manifest with\n | None -> ()\n | Some y ->\n if x.ptype_kind = Ptype_abstract then\n pp f \"%t@;%a\" priv (core_type ctxt) y\n else pp f \"@;%a\" (core_type ctxt) y\n in\n let constructor_declaration f pcd =\n pp f \"|@;\";\n constructor_declaration ctxt f\n (pcd.pcd_name.txt, pcd.pcd_args, pcd.pcd_res, pcd.pcd_attributes)\n in\n let repr f =\n let intro f = if x.ptype_manifest = None then () else pp f \"@;=\" in\n match x.ptype_kind with\n | Ptype_variant xs ->\n let variants fmt xs =\n if xs = [] then pp fmt \" |\"\n else pp fmt \"@\\n%a\" (list ~sep:\"@\\n\" constructor_declaration) xs\n in\n pp f \"%t%t%a\" intro priv variants xs\n | Ptype_abstract -> ()\n | Ptype_record l -> pp f \"%t%t@;%a\" intro priv (record_declaration ctxt) l\n | Ptype_open -> pp f \"%t%t@;..\" intro priv\n in\n let constraints f =\n List.iter\n (fun (ct1, ct2, _) ->\n pp f \"@[@ constraint@ %a@ =@ %a@]\" (core_type ctxt) ct1\n (core_type ctxt) ct2)\n x.ptype_cstrs\n in\n pp f \"%t%t%t\" manifest repr constraints\n\nand type_extension ctxt f x =\n let extension_constructor f x =\n pp f \"@\\n|@;%a\" (extension_constructor ctxt) x\n in\n pp f \"@[<2>type %a%a += %a@ %a@]%a\"\n (fun f -> function\n | [] -> ()\n | l ->\n pp f \"%a@;\" (list (type_param ctxt) ~first:\"(\" ~last:\")\" ~sep:\",\") l)\n x.ptyext_params longident_loc x.ptyext_path private_flag\n x.ptyext_private (* Cf: #7200 *)\n (list ~sep:\"\" extension_constructor)\n x.ptyext_constructors (item_attributes ctxt) x.ptyext_attributes\n\nand constructor_declaration ctxt f (name, args, res, attrs) =\n let name = match name with \"::\" -> \"(::)\" | s -> s in\n match res with\n | None ->\n pp f \"%s%a@;%a\" name\n (fun f -> function\n | Pcstr_tuple [] -> ()\n | Pcstr_tuple l ->\n pp f \"@;of@;%a\" (list (core_type1 ctxt) ~sep:\"@;*@;\") l\n | Pcstr_record l -> pp f \"@;of@;%a\" (record_declaration ctxt) l)\n args (attributes ctxt) attrs\n | Some r ->\n pp f \"%s:@;%a@;%a\" name\n (fun f -> function\n | Pcstr_tuple [] -> core_type1 ctxt f r\n | Pcstr_tuple l ->\n pp f \"%a@;->@;%a\"\n (list (core_type1 ctxt) ~sep:\"@;*@;\")\n l (core_type1 ctxt) r\n | Pcstr_record l ->\n pp f \"%a@;->@;%a\" (record_declaration ctxt) l (core_type1 ctxt) r)\n args (attributes ctxt) attrs\n\nand extension_constructor ctxt f x =\n (* Cf: #7200 *)\n match x.pext_kind with\n | Pext_decl (l, r) ->\n constructor_declaration ctxt f (x.pext_name.txt, l, r, x.pext_attributes)\n | Pext_rebind li ->\n pp f \"%s@;=@;%a%a\" x.pext_name.txt longident_loc li (attributes ctxt)\n x.pext_attributes\n\nand case_list ctxt f l : unit =\n let aux f { pc_lhs; pc_guard; pc_rhs } =\n pp f \"@;| @[<2>%a%a@;->@;%a@]\" (pattern ctxt) pc_lhs\n (option (expression ctxt) ~first:\"@;when@;\")\n pc_guard\n (expression (under_pipe ctxt))\n pc_rhs\n in\n list aux f l ~sep:\"\"\n\nand label_x_expression_param ctxt f (l, e) =\n let simple_name =\n match e with\n | { pexp_desc = Pexp_ident { txt = Lident l; _ }; pexp_attributes = [] } ->\n Some l\n | _ -> None\n in\n match l with\n | Nolabel -> expression2 ctxt f e (* level 2*)\n | Optional str ->\n if Some str = simple_name then pp f \"?%s\" str\n else pp f \"?%s:%a\" str (simple_expr ctxt) e\n | Labelled lbl ->\n if Some lbl = simple_name then pp f \"~%s\" lbl\n else pp f \"~%s:%a\" lbl (simple_expr ctxt) e\n\nand directive_argument f x =\n match x.pdira_desc with\n | Pdir_string s -> pp f \"@ %S\" s\n | Pdir_int (n, None) -> pp f \"@ %s\" n\n | Pdir_int (n, Some m) -> pp f \"@ %s%c\" n m\n | Pdir_ident li -> pp f \"@ %a\" longident li\n | Pdir_bool b -> pp f \"@ %s\" (string_of_bool b)\n\nlet toplevel_phrase f x =\n match x with\n | Ptop_def s -> pp f \"@[%a@]\" (list (structure_item reset_ctxt)) s\n (* pp_open_hvbox f 0; *)\n (* pp_print_list structure_item f s ; *)\n (* pp_close_box f (); *)\n | Ptop_dir { pdir_name; pdir_arg = None; _ } ->\n pp f \"@[#%s@]\" pdir_name.txt\n | Ptop_dir { pdir_name; pdir_arg = Some pdir_arg; _ } ->\n pp f \"@[#%s@ %a@]\" pdir_name.txt directive_argument pdir_arg\n\nlet expression f x = pp f \"@[%a@]\" (expression reset_ctxt) x\n\nlet string_of_expression x =\n ignore (flush_str_formatter ());\n let f = str_formatter in\n expression f x;\n flush_str_formatter ()\n\nlet string_of_structure x =\n ignore (flush_str_formatter ());\n let f = str_formatter in\n structure reset_ctxt f x;\n flush_str_formatter ()\n\nlet top_phrase f x =\n pp_print_newline f ();\n toplevel_phrase f x;\n pp f \";;\";\n pp_print_newline f ()\n\nlet core_type = core_type reset_ctxt\nlet pattern = pattern reset_ctxt\nlet signature = signature reset_ctxt\nlet structure = structure reset_ctxt\nlet class_expr = class_expr reset_ctxt\nlet class_field = class_field reset_ctxt\nlet class_type = class_type reset_ctxt\nlet class_signature = class_signature reset_ctxt\nlet class_type_field = class_type_field reset_ctxt\nlet module_expr = module_expr reset_ctxt\nlet module_type = module_type reset_ctxt\nlet signature_item = signature_item reset_ctxt\nlet structure_item = structure_item reset_ctxt\nlet type_declaration = type_declaration reset_ctxt\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * Location.t * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | NoVariance\n\n type injectivity (*IF_CURRENT = Asttypes.injectivity *) =\n | Injective\n | NoInjectivity\nend\n\nmodule Parsetree = struct\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * Location.t * string option\n (* \"constant\"\n {delim|other constant|delim}\n\n The location span the content of the string, without the delimiters.\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n type location_stack = Location.t list\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: location_stack;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: location_stack;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * (string loc list * pattern) option\n (* C None\n C P Some ([], P)\n C (P1, ..., Pn) Some ([], Ppat_tuple [P1; ...; Pn])\n C (type a b) P Some ([a; b], P)\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P) Some \"P\"\n (module _) None\n\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: location_stack;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * (variance * injectivity)) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * (variance * injectivity)) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n*)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * (variance * injectivity)) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and functor_parameter (*IF_CURRENT = Parsetree.functor_parameter *) =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n (* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_modtypesubst of module_type_declaration\n (* module type S := ... *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string option loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_modtype of Longident.t loc * module_type\n (* with module type X.Y = Z *)\n | Pwith_modtypesubst of Longident.t loc * module_type\n (* with module type X.Y := sig end *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string option loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M030\"\n let ast_intf_magic_number = \"Caml1999N030\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * Location.t * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | NoVariance\n\n type injectivity (*IF_CURRENT = Asttypes.injectivity *) =\n | Injective\n | NoInjectivity\nend\n\nmodule Parsetree = struct\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * Location.t * string option\n (* \"constant\"\n {delim|other constant|delim}\n\n The location span the content of the string, without the delimiters.\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n type location_stack = Location.t list\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: location_stack;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n\n - As the pval_type field of a value_description.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ | t ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: location_stack;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * (string loc list * pattern) option\n (* C None\n C P Some ([], P)\n C (P1, ..., Pn) Some ([], Ppat_tuple [P1; ...; Pn])\n C (type a b) P Some ([a; b], P)\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P) Some \"P\"\n (module _) None\n\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: location_stack;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * (variance * injectivity)) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_vars: string loc list;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * (variance * injectivity)) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n*)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of string loc list * constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([], [T1; ...; Tn], None)\n | C: T0 ([], [], Some T0)\n | C: T1 * ... * Tn -> T0 ([], [T1; ...; Tn], Some T0)\n | C: 'a... . T1... -> T0 (['a;...]; [T1;...], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * (variance * injectivity)) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and functor_parameter (*IF_CURRENT = Parsetree.functor_parameter *) =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n (* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_modtypesubst of module_type_declaration\n (* module type S := ... *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string option loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_modtype of Longident.t loc * module_type\n (* with module type X.Y = Z *)\n | Pwith_modtypesubst of Longident.t loc * module_type\n (* with module type X.Y := sig end *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string option loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M031\"\n let ast_intf_magic_number = \"Caml1999N031\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * Location.t * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * Location.t * string option\n (* \"constant\"\n {delim|other constant|delim}\n\n The location span the content of the string, without the delimiters.\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n type location_stack = Location.t list\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: location_stack;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: location_stack;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P) Some \"P\"\n (module _) None\n\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: location_stack;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n*)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and functor_parameter (*IF_CURRENT = Parsetree.functor_parameter *) =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n (* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string option loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string option loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M028\"\n let ast_intf_magic_number = \"Caml1999N028\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n type location_stack = Location.t list\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: location_stack;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: location_stack;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P) Some \"P\"\n (module _) None\n\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: location_stack;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n*)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and functor_parameter (*IF_CURRENT = Parsetree.functor_parameter *) =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n (* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string option loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string option loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M027\"\n let ast_intf_magic_number = \"Caml1999N027\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\n\nend\n\nmodule Parsetree = struct\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: Location.t list;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and typ = core_type\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: Location.t list;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pat = pattern\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: Location.t list;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expr = expression\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of cases\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * cases\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * cases\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and cases = case list\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M026\"\n let ast_intf_magic_number = \"Caml1999N026\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Ast ported on Thu Mar 21 09:50:42 GMT 2019\n OCaml was:\n commit 55c9ba466362f303eb4d5ed511f6fda142879137 (HEAD -> 4.08, origin/4.08)\n Author: Nicolás Ojeda Bär \n Date: Tue Mar 19 08:11:02 2019 +0100\n\n Merge pull request #8521 from nojb/fix_unix_tests_408\n\n Actually run all lib-unix tests [4.08]\n*)\n\nmodule Asttypes = struct\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\n\nend\n\nmodule Parsetree = struct\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {1 Extension points} *)\n\n type attribute (*IF_CURRENT = Parsetree.attribute *) = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : Location.t;\n }\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_loc_stack: Location.t list;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and typ = core_type\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) = {\n prf_desc : row_field_desc;\n prf_loc : Location.t;\n prf_attributes : attributes;\n }\n\n and row_field_desc (*IF_CURRENT = Parsetree.row_field_desc *) =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 'bool' field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) = {\n pof_desc : object_field_desc;\n pof_loc : Location.t;\n pof_attributes : attributes;\n }\n\n and object_field_desc (*IF_CURRENT = Parsetree.object_field_desc *) =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_loc_stack: Location.t list;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pat = pattern\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_loc_stack: Location.t list;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expr = expression\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of cases\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * cases\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * cases\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n and cases = case list\n\n and letop (*IF_CURRENT = Parsetree.letop *) =\n {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n }\n\n and binding_op (*IF_CURRENT = Parsetree.binding_op *) =\n {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : Location.t;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_loc: Location.t;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n(*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n (* exception E *)\n and type_exception (*IF_CURRENT = Parsetree.type_exception *) =\n {\n ptyexn_constructor: extension_constructor;\n ptyexn_loc: Location.t;\n ptyexn_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X = M\n module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_substitution (*IF_CURRENT = Parsetree.module_substitution *) =\n {\n pms_name: string loc;\n pms_manifest: Longident.t loc;\n pms_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pms_loc: Location.t;\n }\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and 'a open_infos (*IF_CURRENT = 'a Parsetree.open_infos *) =\n {\n popen_expr: 'a;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and open_description = Longident.t loc open_infos\n (* open M.N\n open M(N).O *)\n\n and open_declaration = module_expr open_infos\n (* open M.N\n open M(N).O\n open struct ... end *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n (* #use, #load ... *)\n\n and toplevel_directive (*IF_CURRENT = Parsetree.toplevel_directive *) =\n {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : Location.t;\n }\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n {\n pdira_desc : directive_argument_desc;\n pdira_loc : Location.t;\n }\n\n and directive_argument_desc (*IF_CURRENT = Parsetree.directive_argument_desc *) =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M025\"\n let ast_intf_magic_number = \"Caml1999N025\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour, Facebook *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Ast ported on Wed Apr 18 10:33:29 BST 2018\n OCaml trunk was:\n commit c0bd6a27e138911560f43dc75d5fde2ade4d6cfe (HEAD, tag: 4.07.0+beta2)\n Author: Damien Doligez \n Date: Tue Apr 10 14:50:48 2018 +0200\n\n change VERSION for 4.07.0+beta2\n*)\n\nmodule Asttypes = struct\n (** Auxiliary AST types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {1 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {1 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label loc * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) =\n | Otag of label loc * attributes * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n (*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {1 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of override_flag * Longident.t loc * class_type\n (* let open M in CT *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of override_flag * Longident.t loc * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {1 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {1 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M023\"\n let ast_intf_magic_number = \"Caml1999N023\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Ast ported on Mon Oct 2 11:25:57 CEST 2017\n OCaml trunk was:\n commit 65940a2c6be43c42f75c6c6b255974f7e6de03ca (HEAD -> 4.06, origin/4.06)\n Author: Christophe Raffalli \n Date: Sun Oct 1 18:27:07 2017 +0200\n\n fixed position of last optional last semicolumn in sequence (#1387)\n*)\n\nmodule Asttypes = struct\n (** Auxiliary AST types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {2 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {2 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label loc * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n and object_field (*IF_CURRENT = Parsetree.object_field *) =\n | Otag of label loc * attributes * core_type\n | Oinherit of core_type\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n (* Invariant: non-empty list *)\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l : T [@id1] [@id2] *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n (*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C of ... [@id1] [@id2] *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {2 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of override_flag * Longident.t loc * class_type\n (* let open M in CT *)\n\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of override_flag * Longident.t loc * class_expr\n (* let open M in CE *)\n\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {2 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of Longident.t loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of Longident.t loc * Longident.t loc\n (* with module X.Y := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {2 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M022\"\n let ast_intf_magic_number = \"Caml1999N022\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n (** Auxiliary AST types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {2 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {2 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Otional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of (string loc * attributes * core_type) list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n (* M.(P) *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * string loc\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of string loc * expression\n (* x <- 2 *)\n | Pexp_override of (string loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n (* Invariant: non-empty list *)\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l [@id1] [@id2] : T *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n (*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {2 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (string loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (string loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (string loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (string loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {2 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of type_declaration\n (* with type t := ... *)\n | Pwith_modsubst of string loc * Longident.t loc\n (* with module X := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {2 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\n\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M020\"\n let ast_intf_magic_number = \"Caml1999N018\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n (** Auxiliary AST types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {2 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {2 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Otional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of (string * attributes * core_type) list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of Longident.t loc * pattern\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * string\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of string loc * expression\n (* x <- 2 *)\n | Pexp_override of (string loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* let open M in E\n let! open M in E\n *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n (* Invariant: non-empty list *)\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l [@id1] [@id2] : T *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n (*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {2 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (string * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (string * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (string loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (string loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {2 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of type_declaration\n (* with type t := ... *)\n | Pwith_modsubst of string loc * Longident.t loc\n (* with module X := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {2 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M020\"\n let ast_intf_magic_number = \"Caml1999N018\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n (* Auxiliary a.s.t. types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n (* Order matters, used in polymorphic comparison *)\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type arg_label (*IF_CURRENT = Asttypes.arg_label *) =\n Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string (* ?label:T -> ... *)\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n type constant (*IF_CURRENT = Parsetree.constant *) =\n Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * string option\n (* \"constant\"\n {delim|other constant|delim}\n *)\n | Pconst_float of string * char option\n (* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n *)\n\n (** {2 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {2 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Otional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of (string * attributes * core_type) list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * string\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of string loc * expression\n (* x <- 2 *)\n | Pexp_override of (string loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* let open M in E\n let! open M in E\n *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n (* . *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n (* Invariant: non-empty list *)\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l [@id1] [@id2] : T *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: constructor_arguments;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and constructor_arguments (*IF_CURRENT = Parsetree.constructor_arguments *) =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n (*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {2 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (string * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (string * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (string loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (string loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {2 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of type_declaration\n (* with type t := ... *)\n | Pwith_modsubst of string loc * Longident.t loc\n (* with module X := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {2 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M019\"\n let ast_intf_magic_number = \"Caml1999N018\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino and Leo White, Jane Street Europe *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* Alain Frisch, LexiFi *)\n(* Daniel de Rauglaudre, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule Asttypes = struct\n (* Auxiliary a.s.t. types used by parsetree and typedtree. *)\n\n type constant (*IF_CURRENT = Asttypes.constant *) =\n Const_int of int\n | Const_char of char\n | Const_string of string * string option\n | Const_float of string\n | Const_int32 of int32\n | Const_int64 of int64\n | Const_nativeint of nativeint\n\n type rec_flag (*IF_CURRENT = Asttypes.rec_flag *) = Nonrecursive | Recursive\n\n type direction_flag (*IF_CURRENT = Asttypes.direction_flag *) = Upto | Downto\n\n type private_flag (*IF_CURRENT = Asttypes.private_flag *) = Private | Public\n\n type mutable_flag (*IF_CURRENT = Asttypes.mutable_flag *) = Immutable | Mutable\n\n type virtual_flag (*IF_CURRENT = Asttypes.virtual_flag *) = Virtual | Concrete\n\n type override_flag (*IF_CURRENT = Asttypes.override_flag *) = Override | Fresh\n\n type closed_flag (*IF_CURRENT = Asttypes.closed_flag *) = Closed | Open\n\n type label = string\n\n type 'a loc = 'a Location.loc = {\n txt : 'a;\n loc : Location.t;\n }\n\n\n type variance (*IF_CURRENT = Asttypes.variance *) =\n | Covariant\n | Contravariant\n | Invariant\nend\n\nmodule Parsetree = struct\n (** Abstract syntax tree produced by parsing *)\n\n open Asttypes\n\n (** {2 Extension points} *)\n\n type attribute = string loc * payload\n (* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n *)\n\n and extension = string loc * payload\n (* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n *)\n\n and attributes = attribute list\n\n and payload (*IF_CURRENT = Parsetree.payload *) =\n | PStr of structure\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option (* ? P or ? P when E *)\n\n (** {2 Core language} *)\n\n (* Type expressions *)\n\n and core_type (*IF_CURRENT = Parsetree.core_type *) =\n {\n ptyp_desc: core_type_desc;\n ptyp_loc: Location.t;\n ptyp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and core_type_desc (*IF_CURRENT = Parsetree.core_type_desc *) =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of label * core_type * core_type\n (* T1 -> T2 (label = \"\")\n ~l:T1 -> T2 (label = \"l\")\n ?l:T1 -> T2 (label = \"?l\")\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of Longident.t loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of (string * attributes * core_type) list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of Longident.t loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string list * core_type\n (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n (* [%id] *)\n\n and package_type = Longident.t loc * (Longident.t loc * core_type) list\n (*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n *)\n\n and row_field (*IF_CURRENT = Parsetree.row_field *) =\n | Rtag of label * attributes * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n (* [ T ] *)\n\n (* Patterns *)\n\n and pattern (*IF_CURRENT = Parsetree.pattern *) =\n {\n ppat_desc: pattern_desc;\n ppat_loc: Location.t;\n ppat_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and pattern_desc (*IF_CURRENT = Parsetree.pattern_desc *) =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of Longident.t loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (Longident.t loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of Longident.t loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n\n (* Value expressions *)\n\n and expression (*IF_CURRENT = Parsetree.expression *) =\n {\n pexp_desc: expression_desc;\n pexp_loc: Location.t;\n pexp_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and expression_desc (*IF_CURRENT = Parsetree.expression_desc *) =\n | Pexp_ident of Longident.t loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of case list\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of label * expression option * pattern * expression\n (* fun P -> E1 (lab = \"\", None)\n fun ~l:P -> E1 (lab = \"l\", None)\n fun ?l:P -> E1 (lab = \"?l\", None)\n fun ?l:(P = E0) -> E1 (lab = \"?l\", Some E0)\n\n Notes:\n - If E0 is provided, lab must start with '?'.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * case list\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * case list\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of Longident.t loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (Longident.t loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * Longident.t loc\n (* E.l *)\n | Pexp_setfield of expression * Longident.t loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of\n pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * string\n (* E # m *)\n | Pexp_new of Longident.t loc\n (* new M.c *)\n | Pexp_setinstvar of string loc * expression\n (* x <- 2 *)\n | Pexp_override of (string loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of override_flag * Longident.t loc * expression\n (* let open M in E\n let! open M in E\n *)\n | Pexp_extension of extension\n (* [%id] *)\n\n and case (*IF_CURRENT = Parsetree.case *) = (* (P -> E) or (P when E0 -> E) *)\n {\n pc_lhs: pattern;\n pc_guard: expression option;\n pc_rhs: expression;\n }\n\n (* Value descriptions *)\n\n and value_description (*IF_CURRENT = Parsetree.value_description *) =\n {\n pval_name: string loc;\n pval_type: core_type;\n pval_prim: string list;\n pval_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pval_loc: Location.t;\n }\n\n (*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n\n Note: when used under Pstr_primitive, prim cannot be empty\n *)\n\n (* Type declarations *)\n\n and type_declaration (*IF_CURRENT = Parsetree.type_declaration *) =\n {\n ptype_name: string loc;\n ptype_params: (core_type * variance) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs: (core_type * core_type * Location.t) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind: type_kind;\n ptype_private: private_flag; (* = private ... *)\n ptype_manifest: core_type option; (* = T *)\n ptype_attributes: attributes; (* ... [@@id1] [@@id2] *)\n ptype_loc: Location.t;\n }\n\n (*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n *)\n\n and type_kind (*IF_CURRENT = Parsetree.type_kind *) =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n (* Invariant: non-empty list *)\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\n and label_declaration (*IF_CURRENT = Parsetree.label_declaration *) =\n {\n pld_name: string loc;\n pld_mutable: mutable_flag;\n pld_type: core_type;\n pld_loc: Location.t;\n pld_attributes: attributes; (* l [@id1] [@id2] : T *)\n }\n\n (* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n *)\n\n and constructor_declaration (*IF_CURRENT = Parsetree.constructor_declaration *) =\n {\n pcd_name: string loc;\n pcd_args: core_type list;\n pcd_res: core_type option;\n pcd_loc: Location.t;\n pcd_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n (*\n | C of T1 * ... * Tn (res = None)\n | C: T0 (args = [], res = Some T0)\n | C: T1 * ... * Tn -> T0 (res = Some T0)\n *)\n\n and type_extension (*IF_CURRENT = Parsetree.type_extension *) =\n {\n ptyext_path: Longident.t loc;\n ptyext_params: (core_type * variance) list;\n ptyext_constructors: extension_constructor list;\n ptyext_private: private_flag;\n ptyext_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (*\n type t += ...\n *)\n\n and extension_constructor (*IF_CURRENT = Parsetree.extension_constructor *) =\n {\n pext_name: string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : Location.t;\n pext_attributes: attributes; (* C [@id1] [@id2] of ... *)\n }\n\n and extension_constructor_kind (*IF_CURRENT = Parsetree.extension_constructor_kind *) =\n Pext_decl of core_type list * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of Longident.t loc\n (*\n | C = D\n *)\n\n (** {2 Class language} *)\n\n (* Type expressions for the class language *)\n\n and class_type (*IF_CURRENT = Parsetree.class_type *) =\n {\n pcty_desc: class_type_desc;\n pcty_loc: Location.t;\n pcty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_type_desc (*IF_CURRENT = Parsetree.class_type_desc *) =\n | Pcty_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of label * core_type * class_type\n (* T -> CT (label = \"\")\n ~l:T -> CT (label = \"l\")\n ?l:T -> CT (label = \"?l\")\n *)\n | Pcty_extension of extension\n (* [%id] *)\n\n and class_signature (*IF_CURRENT = Parsetree.class_signature *) =\n {\n pcsig_self: core_type;\n pcsig_fields: class_type_field list;\n }\n (* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n *)\n\n and class_type_field (*IF_CURRENT = Parsetree.class_type_field *) =\n {\n pctf_desc: class_type_field_desc;\n pctf_loc: Location.t;\n pctf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_type_field_desc (*IF_CURRENT = Parsetree.class_type_field_desc *) =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (string * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (string * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n (* [%%id] *)\n\n and 'a class_infos (*IF_CURRENT = 'a Parsetree.class_infos *) =\n {\n pci_virt: virtual_flag;\n pci_params: (core_type * variance) list;\n pci_name: string loc;\n pci_expr: 'a;\n pci_loc: Location.t;\n pci_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n (* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n *)\n\n and class_description = class_type class_infos\n\n and class_type_declaration = class_type class_infos\n\n (* Value expressions for the class language *)\n\n and class_expr (*IF_CURRENT = Parsetree.class_expr *) =\n {\n pcl_desc: class_expr_desc;\n pcl_loc: Location.t;\n pcl_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and class_expr_desc (*IF_CURRENT = Parsetree.class_expr_desc *) =\n | Pcl_constr of Longident.t loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of label * expression option * pattern * class_expr\n (* fun P -> CE (lab = \"\", None)\n fun ~l:P -> CE (lab = \"l\", None)\n fun ?l:P -> CE (lab = \"?l\", None)\n fun ?l:(P = E0) -> CE (lab = \"?l\", Some E0)\n *)\n | Pcl_apply of class_expr * (label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n\n and class_structure (*IF_CURRENT = Parsetree.class_structure *) =\n {\n pcstr_self: pattern;\n pcstr_fields: class_field list;\n }\n (* object(selfpat) ... end\n object ... end (self = Ppat_any)\n *)\n\n and class_field (*IF_CURRENT = Parsetree.class_field *) =\n {\n pcf_desc: class_field_desc;\n pcf_loc: Location.t;\n pcf_attributes: attributes; (* ... [@@id1] [@@id2] *)\n }\n\n and class_field_desc (*IF_CURRENT = Parsetree.class_field_desc *) =\n | Pcf_inherit of override_flag * class_expr * string option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (string loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (string loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n (* [%%id] *)\n\n and class_field_kind (*IF_CURRENT = Parsetree.class_field_kind *) =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\n and class_declaration = class_expr class_infos\n\n (** {2 Module language} *)\n\n (* Type expressions for the module language *)\n\n and module_type (*IF_CURRENT = Parsetree.module_type *) =\n {\n pmty_desc: module_type_desc;\n pmty_loc: Location.t;\n pmty_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_type_desc (*IF_CURRENT = Parsetree.module_type_desc *) =\n | Pmty_ident of Longident.t loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of string loc * module_type option * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of Longident.t loc\n (* (module M) *)\n\n and signature = signature_item list\n\n and signature_item (*IF_CURRENT = Parsetree.signature_item *) =\n {\n psig_desc: signature_item_desc;\n psig_loc: Location.t;\n }\n\n and signature_item_desc (*IF_CURRENT = Parsetree.signature_item_desc *) =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of extension_constructor\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n (* [%%id] *)\n\n and module_declaration (*IF_CURRENT = Parsetree.module_declaration *) =\n {\n pmd_name: string loc;\n pmd_type: module_type;\n pmd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmd_loc: Location.t;\n }\n (* S : MT *)\n\n and module_type_declaration (*IF_CURRENT = Parsetree.module_type_declaration *) =\n {\n pmtd_name: string loc;\n pmtd_type: module_type option;\n pmtd_attributes: attributes; (* ... [@@id1] [@@id2] *)\n pmtd_loc: Location.t;\n }\n (* S = MT\n S (abstract module type declaration, pmtd_type = None)\n *)\n\n and open_description (*IF_CURRENT = Parsetree.open_description *) =\n {\n popen_lid: Longident.t loc;\n popen_override: override_flag;\n popen_loc: Location.t;\n popen_attributes: attributes;\n }\n (* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n *)\n\n and 'a include_infos (*IF_CURRENT = 'a Parsetree.include_infos *) =\n {\n pincl_mod: 'a;\n pincl_loc: Location.t;\n pincl_attributes: attributes;\n }\n\n and include_description = module_type include_infos\n (* include MT *)\n\n and include_declaration = module_expr include_infos\n (* include ME *)\n\n and with_constraint (*IF_CURRENT = Parsetree.with_constraint *) =\n | Pwith_type of Longident.t loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of Longident.t loc * Longident.t loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of type_declaration\n (* with type t := ... *)\n | Pwith_modsubst of string loc * Longident.t loc\n (* with module X := Z *)\n\n (* Value expressions for the module language *)\n\n and module_expr (*IF_CURRENT = Parsetree.module_expr *) =\n {\n pmod_desc: module_expr_desc;\n pmod_loc: Location.t;\n pmod_attributes: attributes; (* ... [@id1] [@id2] *)\n }\n\n and module_expr_desc (*IF_CURRENT = Parsetree.module_expr_desc *) =\n | Pmod_ident of Longident.t loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of string loc * module_type option * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n (* [%id] *)\n\n and structure = structure_item list\n\n and structure_item (*IF_CURRENT = Parsetree.structure_item *) =\n {\n pstr_desc: structure_item_desc;\n pstr_loc: Location.t;\n }\n\n and structure_item_desc (*IF_CURRENT = Parsetree.structure_item_desc *) =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of extension_constructor\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_description\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n (* [%%id] *)\n\n and value_binding (*IF_CURRENT = Parsetree.value_binding *) =\n {\n pvb_pat: pattern;\n pvb_expr: expression;\n pvb_attributes: attributes;\n pvb_loc: Location.t;\n }\n\n and module_binding (*IF_CURRENT = Parsetree.module_binding *) =\n {\n pmb_name: string loc;\n pmb_expr: module_expr;\n pmb_attributes: attributes;\n pmb_loc: Location.t;\n }\n (* X = ME *)\n\n (** {2 Toplevel} *)\n\n (* Toplevel phrases *)\n\n type toplevel_phrase (*IF_CURRENT = Parsetree.toplevel_phrase *) =\n | Ptop_def of structure\n | Ptop_dir of string * directive_argument\n (* #use, #load ... *)\n\n and directive_argument (*IF_CURRENT = Parsetree.directive_argument *) =\n | Pdir_none\n | Pdir_string of string\n | Pdir_int of int\n | Pdir_ident of Longident.t\n | Pdir_bool of bool\nend\n\nmodule Config = struct\n let ast_impl_magic_number = \"Caml1999M016\"\n let ast_intf_magic_number = \"Caml1999N015\"\nend\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_403\nmodule To = Ast_402\n\nlet inject_predef_option label d =\n let open To in\n let open Parsetree in\n match label with\n | From.Asttypes.Optional _ ->\n let loc = { d.ptyp_loc with Location.loc_ghost = true } in\n let txt = Longident.Ldot (Longident.Lident \"*predef*\", \"option\") in\n let ident = { Location.txt; loc } in\n {\n ptyp_desc = Ptyp_constr (ident, [ d ]);\n ptyp_loc = loc;\n ptyp_attributes = [];\n }\n | _ -> d\n\nlet from_loc { Location.txt = _; loc } = loc\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.03\" missing_feature\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_loc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc loc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant loc x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable ->\n migration_error loc \"unreachable patterns\"\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_loc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc loc :\n From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant loc x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant loc x0, copy_constant loc x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n ( copy_arg_label x0,\n inject_predef_option x0 (copy_core_type x1),\n copy_core_type x2 )\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly (List.map (fun x -> x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload (from_loc x0) x1)\n\nand copy_payload loc : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig _x0 -> migration_error loc \"signatures in attribute\"\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type (type_declarations x0 x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n (copy_override_flag x0, copy_class_expr x1, copy_option (fun x -> x) x2)\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type (type_declarations x0 x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n ( copy_arg_label x0,\n inject_predef_option x0 (copy_core_type x1),\n copy_class_type x2 )\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_mutable_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_private_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload (from_loc x0) x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind =\n copy_extension_constructor_kind (from_loc pext_name) pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind loc :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments loc x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args =\n copy_constructor_arguments (from_loc pcd_name) pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments loc :\n From.Parsetree.constructor_arguments -> To.Parsetree.core_type list =\n function\n | From.Parsetree.Pcstr_tuple x0 -> List.map copy_core_type x0\n | From.Parsetree.Pcstr_record _x0 -> migration_error loc \"inline records\"\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> string = function\n | From.Asttypes.Nolabel -> \"\"\n | From.Asttypes.Labelled x0 -> x0\n | From.Asttypes.Optional x0 -> \"?\" ^ x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant loc : From.Parsetree.constant -> To.Asttypes.constant =\n function\n | From.Parsetree.Pconst_integer (x0, x1) -> (\n match x1 with\n | None -> To.Asttypes.Const_int (int_of_string x0)\n | Some 'l' -> To.Asttypes.Const_int32 (Int32.of_string x0)\n | Some 'L' -> To.Asttypes.Const_int64 (Int64.of_string x0)\n | Some 'n' -> To.Asttypes.Const_nativeint (Nativeint.of_string x0)\n | Some _ -> migration_error loc \"custom integer literals\")\n | From.Parsetree.Pconst_char x0 -> To.Asttypes.Const_char x0\n | From.Parsetree.Pconst_string (x0, x1) -> To.Asttypes.Const_string (x0, x1)\n | From.Parsetree.Pconst_float (x0, x1) -> (\n match x1 with\n | None -> To.Asttypes.Const_float x0\n | Some _ -> migration_error loc \"custom float literals\")\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nand type_declarations recflag types =\n match (recflag, List.map copy_type_declaration types) with\n | From.Asttypes.Recursive, types -> types\n | From.Asttypes.Nonrecursive, [] -> []\n | From.Asttypes.Nonrecursive, x :: xs ->\n let pos =\n {\n Lexing.pos_fname = \"_none_\";\n pos_lnum = 1;\n pos_bol = 0;\n pos_cnum = -1;\n }\n in\n let loc = { Location.loc_start = pos; loc_end = pos; loc_ghost = true } in\n let ptype_attributes =\n ({ To.Asttypes.txt = \"nonrec\"; loc }, To.Parsetree.PStr [])\n :: x.To.Parsetree.ptype_attributes\n in\n { x with To.Parsetree.ptype_attributes } :: xs\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, _x1) ->\n To.Parsetree.Pdir_int (int_of_string x0)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Jérémie Dimino, Jane Street Europe *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* BEGIN of BLACK MAGIC *)\n(*$ open Ast_cinaps_helpers $*)\n\ntype _ witnesses = ..\n\ntype _ migration = ..\ntype _ migration += Undefined : _ migration\n\ntype 'a migration_info = {\n mutable next_version : 'a migration;\n mutable previous_version : 'a migration;\n}\n\n(** Abstract view of a version of an OCaml Ast *)\nmodule type Ast = sig\n (*$ foreach_module (fun m types ->\n printf \" module %s : sig\\n\" m;\n List.iter types ~f:(printf \" type %s\\n\");\n printf \" end\\n\"\n )\n *)\n module Parsetree : sig\n type structure\n type signature\n type toplevel_phrase\n type core_type\n type expression\n type pattern\n type case\n type type_declaration\n type type_extension\n type extension_constructor\n end\n(*$*)\n module Config : sig\n val ast_impl_magic_number : string\n val ast_intf_magic_number : string\n end\nend\n\n(* Shortcuts for talking about ast types outside of the module language *)\n\ntype 'a _types = 'a constraint 'a\n = <\n (*$ foreach_type (fun _ s -> printf \" %-21s : _;\\n\" s) *)\n structure : _;\n signature : _;\n toplevel_phrase : _;\n core_type : _;\n expression : _;\n pattern : _;\n case : _;\n type_declaration : _;\n type_extension : _;\n extension_constructor : _;\n(*$*)\n >\n;;\n\n(*$ foreach_type (fun _ s ->\n printf \"type 'a get_%s =\\n\" s;\n printf \" 'x constraint 'a _types = < %s : 'x; .. >\\n\" s\n ) *)\ntype 'a get_structure =\n 'x constraint 'a _types = < structure : 'x; .. >\ntype 'a get_signature =\n 'x constraint 'a _types = < signature : 'x; .. >\ntype 'a get_toplevel_phrase =\n 'x constraint 'a _types = < toplevel_phrase : 'x; .. >\ntype 'a get_core_type =\n 'x constraint 'a _types = < core_type : 'x; .. >\ntype 'a get_expression =\n 'x constraint 'a _types = < expression : 'x; .. >\ntype 'a get_pattern =\n 'x constraint 'a _types = < pattern : 'x; .. >\ntype 'a get_case =\n 'x constraint 'a _types = < case : 'x; .. >\ntype 'a get_type_declaration =\n 'x constraint 'a _types = < type_declaration : 'x; .. >\ntype 'a get_type_extension =\n 'x constraint 'a _types = < type_extension : 'x; .. >\ntype 'a get_extension_constructor =\n 'x constraint 'a _types = < extension_constructor : 'x; .. >\n(*$*)\n\nmodule type OCaml_version = sig\n module Ast : Ast\n val version : int\n val string_version : string\n type types = <\n (*$ foreach_type (fun m s -> printf \" %-21s : Ast.%s.%s;\\n\" s m s)*)\n structure : Ast.Parsetree.structure;\n signature : Ast.Parsetree.signature;\n toplevel_phrase : Ast.Parsetree.toplevel_phrase;\n core_type : Ast.Parsetree.core_type;\n expression : Ast.Parsetree.expression;\n pattern : Ast.Parsetree.pattern;\n case : Ast.Parsetree.case;\n type_declaration : Ast.Parsetree.type_declaration;\n type_extension : Ast.Parsetree.type_extension;\n extension_constructor : Ast.Parsetree.extension_constructor;\n(*$*)\n > _types\n type _ witnesses += Version : types witnesses\n val migration_info : types migration_info\nend\n\nmodule Make_witness(Ast : Ast) =\nstruct\n type types = <\n (*$ foreach_type (fun m s -> printf \" %-21s : Ast.%s.%s;\\n\" s m s)*)\n structure : Ast.Parsetree.structure;\n signature : Ast.Parsetree.signature;\n toplevel_phrase : Ast.Parsetree.toplevel_phrase;\n core_type : Ast.Parsetree.core_type;\n expression : Ast.Parsetree.expression;\n pattern : Ast.Parsetree.pattern;\n case : Ast.Parsetree.case;\n type_declaration : Ast.Parsetree.type_declaration;\n type_extension : Ast.Parsetree.type_extension;\n extension_constructor : Ast.Parsetree.extension_constructor;\n(*$*)\n > _types\n type _ witnesses += Version : types witnesses\n let migration_info : types migration_info =\n { next_version = Undefined; previous_version = Undefined }\nend\n\ntype 'types ocaml_version =\n (module OCaml_version\n (*$ let sep = with_then_and () in\n foreach_type (fun m s ->\n printf \" %t type Ast.%s.%s = 'types get_%s\\n\" sep m s s) *)\n with type Ast.Parsetree.structure = 'types get_structure\n and type Ast.Parsetree.signature = 'types get_signature\n and type Ast.Parsetree.toplevel_phrase = 'types get_toplevel_phrase\n and type Ast.Parsetree.core_type = 'types get_core_type\n and type Ast.Parsetree.expression = 'types get_expression\n and type Ast.Parsetree.pattern = 'types get_pattern\n and type Ast.Parsetree.case = 'types get_case\n and type Ast.Parsetree.type_declaration = 'types get_type_declaration\n and type Ast.Parsetree.type_extension = 'types get_type_extension\n and type Ast.Parsetree.extension_constructor = 'types get_extension_constructor\n(*$*)\n )\n\ntype ('from, 'to_) migration_functions = {\n (*$ foreach_type (fun _ s ->\n printf \" copy_%s: 'from get_%s -> 'to_ get_%s;\\n\" s s s) *)\n copy_structure: 'from get_structure -> 'to_ get_structure;\n copy_signature: 'from get_signature -> 'to_ get_signature;\n copy_toplevel_phrase: 'from get_toplevel_phrase -> 'to_ get_toplevel_phrase;\n copy_core_type: 'from get_core_type -> 'to_ get_core_type;\n copy_expression: 'from get_expression -> 'to_ get_expression;\n copy_pattern: 'from get_pattern -> 'to_ get_pattern;\n copy_case: 'from get_case -> 'to_ get_case;\n copy_type_declaration: 'from get_type_declaration -> 'to_ get_type_declaration;\n copy_type_extension: 'from get_type_extension -> 'to_ get_type_extension;\n copy_extension_constructor: 'from get_extension_constructor -> 'to_ get_extension_constructor;\n(*$*)\n}\n\nlet id x = x\nlet migration_identity : ('a, 'a) migration_functions = {\n (*$ foreach_type (fun _ s -> printf \" copy_%s = id;\\n\" s) *)\n copy_structure = id;\n copy_signature = id;\n copy_toplevel_phrase = id;\n copy_core_type = id;\n copy_expression = id;\n copy_pattern = id;\n copy_case = id;\n copy_type_declaration = id;\n copy_type_extension = id;\n copy_extension_constructor = id;\n(*$*)\n}\n\nlet compose f g x = f (g x)\nlet migration_compose (ab : ('a, 'b) migration_functions) (bc : ('b, 'c) migration_functions) : ('a, 'c) migration_functions = {\n (*$ foreach_type (fun _ s ->\n printf \" copy_%-21s = compose bc.copy_%-21s ab.copy_%s;\\n\" s s s) *)\n copy_structure = compose bc.copy_structure ab.copy_structure;\n copy_signature = compose bc.copy_signature ab.copy_signature;\n copy_toplevel_phrase = compose bc.copy_toplevel_phrase ab.copy_toplevel_phrase;\n copy_core_type = compose bc.copy_core_type ab.copy_core_type;\n copy_expression = compose bc.copy_expression ab.copy_expression;\n copy_pattern = compose bc.copy_pattern ab.copy_pattern;\n copy_case = compose bc.copy_case ab.copy_case;\n copy_type_declaration = compose bc.copy_type_declaration ab.copy_type_declaration;\n copy_type_extension = compose bc.copy_type_extension ab.copy_type_extension;\n copy_extension_constructor = compose bc.copy_extension_constructor ab.copy_extension_constructor;\n(*$*)\n}\n\ntype _ migration += Migration : 'from ocaml_version * ('from, 'to_) migration_functions * 'to_ ocaml_version -> 'from migration\n\nmodule type Migrate_module = sig\n module From : Ast\n module To : Ast\n (*$ foreach_type (fun m s ->\n printf \" val copy_%-21s: From.%s.%s -> To.%s.%s\\n\" s m s m s) *)\n val copy_structure : From.Parsetree.structure -> To.Parsetree.structure\n val copy_signature : From.Parsetree.signature -> To.Parsetree.signature\n val copy_toplevel_phrase : From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase\n val copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type\n val copy_expression : From.Parsetree.expression -> To.Parsetree.expression\n val copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern\n val copy_case : From.Parsetree.case -> To.Parsetree.case\n val copy_type_declaration : From.Parsetree.type_declaration -> To.Parsetree.type_declaration\n val copy_type_extension : From.Parsetree.type_extension -> To.Parsetree.type_extension\n val copy_extension_constructor: From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor\n(*$*)\nend\n\nmodule Migration_functions\n (A : OCaml_version) (B : OCaml_version)\n (A_to_B : Migrate_module with module From = A.Ast and module To = B.Ast)\n=\nstruct\n let migration_functions : (A.types, B.types) migration_functions =\n let open A_to_B in\n {\n (*$ foreach_type (fun _ s -> printf \" copy_%s;\\n\" s) *)\n copy_structure;\n copy_signature;\n copy_toplevel_phrase;\n copy_core_type;\n copy_expression;\n copy_pattern;\n copy_case;\n copy_type_declaration;\n copy_type_extension;\n copy_extension_constructor;\n(*$*)\n }\nend\n\nmodule Register_migration (A : OCaml_version) (B : OCaml_version)\n (A_to_B : Migrate_module with module From = A.Ast and module To = B.Ast)\n (B_to_A : Migrate_module with module From = B.Ast and module To = A.Ast)\n=\nstruct\n let () = (\n let is_undefined : type a. a migration -> bool = function\n | Undefined -> true\n | _ -> false\n in\n assert (A.version < B.version);\n assert (is_undefined A.migration_info.next_version);\n assert (is_undefined B.migration_info.previous_version);\n let module A_to_B_fun = Migration_functions(A)(B)(A_to_B) in\n let module B_to_A_fun = Migration_functions(B)(A)(B_to_A) in\n A.migration_info.next_version <-\n Migration ((module A), A_to_B_fun.migration_functions, (module B));\n B.migration_info.previous_version <-\n Migration ((module B), B_to_A_fun.migration_functions, (module A));\n )\nend\n\ntype 'from immediate_migration =\n | No_migration : 'from immediate_migration\n | Immediate_migration\n : ('from, 'to_) migration_functions * 'to_ ocaml_version\n -> 'from immediate_migration\n\nlet immediate_migration\n (*$ foreach_type (fun _ s -> printf \" (type %s)\\n\" s) *)\n (type structure)\n (type signature)\n (type toplevel_phrase)\n (type core_type)\n (type expression)\n (type pattern)\n (type case)\n (type type_declaration)\n (type type_extension)\n (type extension_constructor)\n(*$*)\n ((module A) : <\n (*$ foreach_type (fun _ s -> printf \" %-21s : %s;\\n\" s s) *)\n structure : structure;\n signature : signature;\n toplevel_phrase : toplevel_phrase;\n core_type : core_type;\n expression : expression;\n pattern : pattern;\n case : case;\n type_declaration : type_declaration;\n type_extension : type_extension;\n extension_constructor : extension_constructor;\n(*$*)\n > ocaml_version)\n direction\n =\n let version = match direction with\n | `Next -> A.migration_info.next_version\n | `Previous -> A.migration_info.previous_version\n in\n match version with\n | Undefined -> No_migration\n | Migration (_, funs, to_) -> Immediate_migration (funs, to_)\n | _ -> assert false\n\nlet migrate\n (*$ foreach_type (fun _ s -> printf \" (type %s1) (type %s2)\\n\" s s) *)\n (type structure1) (type structure2)\n (type signature1) (type signature2)\n (type toplevel_phrase1) (type toplevel_phrase2)\n (type core_type1) (type core_type2)\n (type expression1) (type expression2)\n (type pattern1) (type pattern2)\n (type case1) (type case2)\n (type type_declaration1) (type type_declaration2)\n (type type_extension1) (type type_extension2)\n (type extension_constructor1) (type extension_constructor2)\n(*$*)\n ((module A) : <\n (*$ foreach_type (fun _ s -> printf \" %-21s : %s1;\\n\" s s) *)\n structure : structure1;\n signature : signature1;\n toplevel_phrase : toplevel_phrase1;\n core_type : core_type1;\n expression : expression1;\n pattern : pattern1;\n case : case1;\n type_declaration : type_declaration1;\n type_extension : type_extension1;\n extension_constructor : extension_constructor1;\n(*$*)\n > ocaml_version)\n ((module B) : <\n (*$ foreach_type (fun _ s -> printf \" %-21s : %s2;\\n\" s s) *)\n structure : structure2;\n signature : signature2;\n toplevel_phrase : toplevel_phrase2;\n core_type : core_type2;\n expression : expression2;\n pattern : pattern2;\n case : case2;\n type_declaration : type_declaration2;\n type_extension : type_extension2;\n extension_constructor : extension_constructor2;\n(*$*)\n > ocaml_version)\n : (A.types, B.types) migration_functions\n =\n match A.Version with\n | B.Version -> migration_identity\n | _ ->\n let direction = if A.version < B.version then `Next else `Previous in\n let rec migrate (m : A.types immediate_migration) : (A.types, B.types) migration_functions =\n match m with\n | No_migration -> assert false\n | Immediate_migration (f, (module To)) ->\n match To.Version with\n | B.Version -> f\n | _ ->\n match immediate_migration (module To) direction with\n | No_migration -> assert false\n | Immediate_migration (g, to2) ->\n migrate (Immediate_migration (migration_compose f g, to2))\n in\n migrate (immediate_migration (module A) direction)\n\nmodule Convert (A : OCaml_version) (B : OCaml_version) = struct\n let {\n (*$ foreach_type (fun _ s -> printf \" copy_%s;\\n\" s) *)\n copy_structure;\n copy_signature;\n copy_toplevel_phrase;\n copy_core_type;\n copy_expression;\n copy_pattern;\n copy_case;\n copy_type_declaration;\n copy_type_extension;\n copy_extension_constructor;\n(*$*)\n } : (A.types, B.types) migration_functions =\n migrate (module A) (module B)\nend\n\n(*$ foreach_version (fun n version ->\n printf \"module OCaml_%d = struct\\n\" n;\n printf \" module Ast = Astlib.Ast_%d\\n\" n;\n printf \" include Make_witness(Astlib.Ast_%d)\\n\" n;\n printf \" let version = %d\\n\" n;\n printf \" let string_version = %S\\n\" version;\n printf \"end\\n\";\n printf \"let ocaml_%d : OCaml_%d.types ocaml_version = (module OCaml_%d)\\n\"\n n n n;\n )\n*)\nmodule OCaml_402 = struct\n module Ast = Astlib.Ast_402\n include Make_witness(Astlib.Ast_402)\n let version = 402\n let string_version = \"4.02\"\nend\nlet ocaml_402 : OCaml_402.types ocaml_version = (module OCaml_402)\nmodule OCaml_403 = struct\n module Ast = Astlib.Ast_403\n include Make_witness(Astlib.Ast_403)\n let version = 403\n let string_version = \"4.03\"\nend\nlet ocaml_403 : OCaml_403.types ocaml_version = (module OCaml_403)\nmodule OCaml_404 = struct\n module Ast = Astlib.Ast_404\n include Make_witness(Astlib.Ast_404)\n let version = 404\n let string_version = \"4.04\"\nend\nlet ocaml_404 : OCaml_404.types ocaml_version = (module OCaml_404)\nmodule OCaml_405 = struct\n module Ast = Astlib.Ast_405\n include Make_witness(Astlib.Ast_405)\n let version = 405\n let string_version = \"4.05\"\nend\nlet ocaml_405 : OCaml_405.types ocaml_version = (module OCaml_405)\nmodule OCaml_406 = struct\n module Ast = Astlib.Ast_406\n include Make_witness(Astlib.Ast_406)\n let version = 406\n let string_version = \"4.06\"\nend\nlet ocaml_406 : OCaml_406.types ocaml_version = (module OCaml_406)\nmodule OCaml_407 = struct\n module Ast = Astlib.Ast_407\n include Make_witness(Astlib.Ast_407)\n let version = 407\n let string_version = \"4.07\"\nend\nlet ocaml_407 : OCaml_407.types ocaml_version = (module OCaml_407)\nmodule OCaml_408 = struct\n module Ast = Astlib.Ast_408\n include Make_witness(Astlib.Ast_408)\n let version = 408\n let string_version = \"4.08\"\nend\nlet ocaml_408 : OCaml_408.types ocaml_version = (module OCaml_408)\nmodule OCaml_409 = struct\n module Ast = Astlib.Ast_409\n include Make_witness(Astlib.Ast_409)\n let version = 409\n let string_version = \"4.09\"\nend\nlet ocaml_409 : OCaml_409.types ocaml_version = (module OCaml_409)\nmodule OCaml_410 = struct\n module Ast = Astlib.Ast_410\n include Make_witness(Astlib.Ast_410)\n let version = 410\n let string_version = \"4.10\"\nend\nlet ocaml_410 : OCaml_410.types ocaml_version = (module OCaml_410)\nmodule OCaml_411 = struct\n module Ast = Astlib.Ast_411\n include Make_witness(Astlib.Ast_411)\n let version = 411\n let string_version = \"4.11\"\nend\nlet ocaml_411 : OCaml_411.types ocaml_version = (module OCaml_411)\nmodule OCaml_412 = struct\n module Ast = Astlib.Ast_412\n include Make_witness(Astlib.Ast_412)\n let version = 412\n let string_version = \"4.12\"\nend\nlet ocaml_412 : OCaml_412.types ocaml_version = (module OCaml_412)\nmodule OCaml_413 = struct\n module Ast = Astlib.Ast_413\n include Make_witness(Astlib.Ast_413)\n let version = 413\n let string_version = \"4.13\"\nend\nlet ocaml_413 : OCaml_413.types ocaml_version = (module OCaml_413)\nmodule OCaml_414 = struct\n module Ast = Astlib.Ast_414\n include Make_witness(Astlib.Ast_414)\n let version = 414\n let string_version = \"4.14\"\nend\nlet ocaml_414 : OCaml_414.types ocaml_version = (module OCaml_414)\n(*$*)\n\nlet all_versions : (module OCaml_version) list = [\n (*$foreach_version (fun n _ ->\n printf \"(module OCaml_%d : OCaml_version);\\n\" n)*)\n(module OCaml_402 : OCaml_version);\n(module OCaml_403 : OCaml_version);\n(module OCaml_404 : OCaml_version);\n(module OCaml_405 : OCaml_version);\n(module OCaml_406 : OCaml_version);\n(module OCaml_407 : OCaml_version);\n(module OCaml_408 : OCaml_version);\n(module OCaml_409 : OCaml_version);\n(module OCaml_410 : OCaml_version);\n(module OCaml_411 : OCaml_version);\n(module OCaml_412 : OCaml_version);\n(module OCaml_413 : OCaml_version);\n(module OCaml_414 : OCaml_version);\n(*$*)\n]\n\n(*$foreach_version_pair (fun a b ->\n printf \"include Register_migration(OCaml_%d)(OCaml_%d)\\n\" a b;\n printf \" (Astlib.Migrate_%d_%d)(Astlib.Migrate_%d_%d)\\n\" a b b a\n )\n*)\ninclude Register_migration(OCaml_402)(OCaml_403)\n (Astlib.Migrate_402_403)(Astlib.Migrate_403_402)\ninclude Register_migration(OCaml_403)(OCaml_404)\n (Astlib.Migrate_403_404)(Astlib.Migrate_404_403)\ninclude Register_migration(OCaml_404)(OCaml_405)\n (Astlib.Migrate_404_405)(Astlib.Migrate_405_404)\ninclude Register_migration(OCaml_405)(OCaml_406)\n (Astlib.Migrate_405_406)(Astlib.Migrate_406_405)\ninclude Register_migration(OCaml_406)(OCaml_407)\n (Astlib.Migrate_406_407)(Astlib.Migrate_407_406)\ninclude Register_migration(OCaml_407)(OCaml_408)\n (Astlib.Migrate_407_408)(Astlib.Migrate_408_407)\ninclude Register_migration(OCaml_408)(OCaml_409)\n (Astlib.Migrate_408_409)(Astlib.Migrate_409_408)\ninclude Register_migration(OCaml_409)(OCaml_410)\n (Astlib.Migrate_409_410)(Astlib.Migrate_410_409)\ninclude Register_migration(OCaml_410)(OCaml_411)\n (Astlib.Migrate_410_411)(Astlib.Migrate_411_410)\ninclude Register_migration(OCaml_411)(OCaml_412)\n (Astlib.Migrate_411_412)(Astlib.Migrate_412_411)\ninclude Register_migration(OCaml_412)(OCaml_413)\n (Astlib.Migrate_412_413)(Astlib.Migrate_413_412)\ninclude Register_migration(OCaml_413)(OCaml_414)\n (Astlib.Migrate_413_414)(Astlib.Migrate_414_413)\n(*$*)\n\nmodule OCaml_current = OCaml_OCAML_VERSION\n\nmodule Find_version = struct\n type t = Impl of (module OCaml_version) | Intf of (module OCaml_version) | Unknown\n\n let from_magic magic =\n let rec loop = function\n | [] -> Unknown\n | (module Version : OCaml_version) :: tail ->\n if Version.Ast.Config.ast_impl_magic_number = magic then\n Impl (module Version)\n else if Version.Ast.Config.ast_intf_magic_number = magic then\n Intf (module Version)\n else\n loop tail\n in\n loop all_versions\nend\n","module Caml = Stdlib\nopen Caml\nopen StdLabels\nmodule Sexp = Sexplib0.Sexp\nmodule Sexpable = Sexplib0.Sexpable\ninclude Sexplib0.Sexp_conv\n\nmodule type Comparisons = sig\n type t\n\n val compare : t -> t -> int\n val equal : t -> t -> bool\n val ( = ) : t -> t -> bool\n val ( < ) : t -> t -> bool\n val ( > ) : t -> t -> bool\n val ( <> ) : t -> t -> bool\n val ( <= ) : t -> t -> bool\n val ( >= ) : t -> t -> bool\n val min : t -> t -> t\n val max : t -> t -> t\nend\n\nmodule Poly = struct\n let compare = compare\n let equal = ( = )\n let ( = ) = ( = )\n let ( < ) = ( < )\n let ( > ) = ( > )\n let ( <> ) = ( <> )\n let ( <= ) = ( <= )\n let ( >= ) = ( >= )\n let min = min\n let max = max\nend\n\ninclude (Poly : Comparisons with type t := int)\nmodule Array = Array\n\nmodule Bool = struct\n let to_string = string_of_bool\n\n include (Poly : Comparisons with type t := bool)\nend\n\nmodule Bytes = struct\n include Bytes\n\n let sub_string t ~pos ~len = Stdlib.Bytes.sub_string t pos len\n\n let blit_string ~src ~src_pos ~dst ~dst_pos ~len =\n Stdlib.Bytes.blit_string src src_pos dst dst_pos len\nend\n\nmodule Char = struct\n include Char\n include (Poly : Comparisons with type t := char)\nend\n\nmodule Exn = struct\n let protectx x ~f ~finally =\n match f x with\n | y ->\n finally x;\n y\n | exception exn ->\n finally x;\n raise exn\nend\n\nmodule Float = struct\n let to_string = string_of_float\n\n include (Poly : Comparisons with type t := float)\nend\n\nmodule Fn = struct\n let id x = x\nend\n\nmodule Hashtbl = struct\n include Hashtbl\n\n let set t ~key ~data =\n while mem t key do\n remove t key\n done;\n add t key data\n\n let add t ~key ~data =\n if mem t key then Error (Invalid_argument \"Hashtbl.add_exn\")\n else (\n add t key data;\n Ok ())\n\n let add_exn t ~key ~data =\n match add t ~key ~data with Ok () -> () | Error exn -> raise exn\n\n let find_opt t key =\n match find t key with data -> Some data | exception Not_found -> None\n\n let find_or_add t key ~default =\n match find_opt t key with\n | Some data -> data\n | None ->\n let data = default () in\n add_exn t ~key ~data;\n data\n\n let rec add_alist t alist =\n match alist with\n | [] -> Ok ()\n | (key, data) :: tail -> (\n match add t ~key ~data with\n | Ok () -> add_alist t tail\n | Error (_ : exn) -> Error key)\n\n let of_alist ?size alist =\n let size =\n match size with Some size -> size | None -> List.length alist\n in\n let t = create size in\n match add_alist t alist with Ok () -> Ok t | Error _ as error -> error\n\n let of_alist_exn ?size alist =\n match of_alist ?size alist with\n | Ok t -> t\n | Error _ -> raise (Invalid_argument \"Hashtbl.of_alist_exn\")\nend\n\nmodule In_channel = struct\n let create ?(binary = true) file =\n let flags = [ Open_rdonly ] in\n let flags = if binary then Open_binary :: flags else flags in\n open_in_gen flags 0o000 file\n\n let with_file ?binary filename ~f =\n let t = create ?binary filename in\n Exn.protectx t ~f ~finally:close_in\n\n let input_all t =\n let rec read_all_into t buf =\n match input_char t with\n | char ->\n Buffer.add_char buf char;\n read_all_into t buf\n | exception End_of_file -> ()\n in\n let buf = Buffer.create 64 in\n read_all_into t buf;\n Buffer.contents buf\n\n let read_all filename = with_file filename ~f:input_all\nend\n\nmodule Int = struct\n let max_int = max_int\n let to_string = string_of_int\n\n include (Poly : Comparisons with type t := int)\nend\n\nmodule List = struct\n include List\n\n include struct\n (* shadow non-tail-recursive functions *)\n let merge = `not_tail_recursive\n let remove_assoc = `not_tail_recursive\n let remove_assq = `not_tail_recursive\n\n let rev_mapi list ~f =\n let rec rev_mapi_at list i ~f ~acc =\n match list with\n | [] -> acc\n | head :: tail -> rev_mapi_at tail (i + 1) ~f ~acc:(f i head :: acc)\n in\n rev_mapi_at list 0 ~f ~acc:[]\n\n let fold_right2 list1 list2 ~init ~f =\n fold_left2 (rev list1) (rev list2) ~init ~f:(fun acc x y -> f x y acc)\n\n let map list ~f = rev (rev_map list ~f)\n let mapi list ~f = rev (rev_mapi list ~f)\n\n let fold_right list ~init ~f =\n fold_left (List.rev list) ~init ~f:(fun acc x -> f x acc)\n\n let append x y = rev_append (rev x) y\n let concat list = fold_right list ~init:[] ~f:append\n\n let rev_combine list1 list2 =\n fold_left2 list1 list2 ~init:[] ~f:(fun acc x y -> (x, y) :: acc)\n\n let combine list1 list2 = rev (rev_combine list1 list2)\n\n let split list =\n fold_right list ~init:([], []) ~f:(fun (x, y) (xs, ys) ->\n (x :: xs, y :: ys))\n\n let map2 list1 list2 ~f =\n rev (fold_left2 list1 list2 ~init:[] ~f:(fun acc x y -> f x y :: acc))\n end\n\n let init ~len ~f =\n let rec loop ~len ~pos ~f ~acc =\n if pos >= len then List.rev acc\n else loop ~len ~pos:(pos + 1) ~f ~acc:(f pos :: acc)\n in\n loop ~len ~pos:0 ~f ~acc:[]\n\n let is_empty = function [] -> true | _ :: _ -> false\n\n let rev_filter_opt list =\n fold_left list ~init:[] ~f:(fun tail option ->\n match option with None -> tail | Some head -> head :: tail)\n\n let filter_opt list = rev (rev_filter_opt list)\n let filter_map list ~f = rev_filter_opt (rev_map list ~f)\n let concat_map list ~f = concat (map list ~f)\n\n let rec find_map list ~f =\n match list with\n | [] -> None\n | head :: tail -> (\n match f head with Some _ as some -> some | None -> find_map tail ~f)\n\n let find_map_exn list ~f =\n match find_map list ~f with Some x -> x | None -> raise Not_found\n\n let rec last = function\n | [] -> None\n | [ x ] -> Some x\n | _ :: (_ :: _ as rest) -> last rest\n\n let split_while list ~f =\n let rec split_while_into list ~f ~acc =\n match list with\n | head :: tail when f head -> split_while_into tail ~f ~acc:(head :: acc)\n | _ :: _ | [] -> (List.rev acc, list)\n in\n split_while_into list ~f ~acc:[]\n\n let find_a_dup (type elt) list ~compare =\n let module Elt = struct\n type t = elt\n\n let compare = compare\n end in\n let module Elt_set = Set.Make (Elt) in\n let rec find_a_dup_in list ~set =\n match list with\n | [] -> None\n | head :: tail ->\n if Elt_set.mem head set then Some head\n else find_a_dup_in tail ~set:(Elt_set.add head set)\n in\n find_a_dup_in list ~set:Elt_set.empty\n\n let assoc_opt key alist =\n match assoc key alist with x -> Some x | exception Not_found -> None\n\n (* reorders arguments to improve type inference *)\n let iter list ~f = iter list ~f\nend\n\nmodule Option = struct\n let is_some = function None -> false | Some _ -> true\n let iter t ~f = match t with None -> () | Some x -> f x\n let map t ~f = match t with None -> None | Some x -> Some (f x)\n let value t ~default = match t with None -> default | Some x -> x\nend\n\nmodule Out_channel = struct\n let create ?(binary = true) ?(append = false) ?(fail_if_exists = false)\n ?(perm = 0o666) file =\n let flags = [ Open_wronly; Open_creat ] in\n let flags = (if binary then Open_binary else Open_text) :: flags in\n let flags = (if append then Open_append else Open_trunc) :: flags in\n let flags = if fail_if_exists then Open_excl :: flags else flags in\n open_out_gen flags perm file\n\n let with_file ?binary ?append ?fail_if_exists ?perm file ~f =\n let t = create ?binary ?append ?fail_if_exists ?perm file in\n Exn.protectx t ~f ~finally:close_out\n\n let write_all filename ~data =\n with_file filename ~f:(fun t -> output_string t data)\nend\n\nmodule String = struct\n include String\n\n let is_empty (t : t) = length t = 0\n let prefix t len = sub t ~pos:0 ~len\n let suffix t len = sub t ~pos:(length t - len) ~len\n let drop_prefix t len = sub t ~pos:len ~len:(length t - len)\n let drop_suffix t len = sub t ~pos:0 ~len:(length t - len)\n\n let is_prefix t ~prefix =\n let rec is_prefix_from t ~prefix ~pos ~len =\n pos >= len\n || Char.equal (get t pos) (get prefix pos)\n && is_prefix_from t ~prefix ~pos:(pos + 1) ~len\n in\n length t >= length prefix\n && is_prefix_from t ~prefix ~pos:0 ~len:(length prefix)\n\n let is_suffix t ~suffix =\n let rec is_suffix_up_to t ~suffix ~pos ~suffix_offset =\n pos < 0\n || Char.equal (get t (suffix_offset + pos)) (get suffix pos)\n && is_suffix_up_to t ~suffix ~pos:(pos - 1) ~suffix_offset\n in\n length t >= length suffix\n && is_suffix_up_to t ~suffix\n ~pos:(length suffix - 1)\n ~suffix_offset:(length t - length suffix)\n\n let exists t ~f =\n let rec exists_at t ~f ~pos ~len =\n pos < len && (f (get t pos) || exists_at t ~f ~pos:(pos + 1) ~len)\n in\n exists_at t ~f ~pos:0 ~len:(length t)\n\n let for_all t ~f =\n let rec for_all_at t ~f ~pos ~len =\n pos >= len || (f (get t pos) && for_all_at t ~f ~pos:(pos + 1) ~len)\n in\n for_all_at t ~f ~pos:0 ~len:(length t)\n\n let index_opt t char =\n match index t char with i -> Some i | exception Not_found -> None\n\n let rindex_opt t char =\n match rindex t char with i -> Some i | exception Not_found -> None\n\n let index_from_opt t char pos =\n match index_from t char pos with i -> Some i | exception Not_found -> None\n\n let rindex_from_opt t char pos =\n match rindex_from t char pos with\n | i -> Some i\n | exception Not_found -> None\n\n let lsplit2 t ~on =\n match index_opt t on with\n | None -> None\n | Some i ->\n Some (sub t ~pos:0 ~len:i, sub t ~pos:(i + 1) ~len:(length t - i - 1))\n\n let capitalize_ascii = Stdlib.String.capitalize_ascii\n let lowercase_ascii = Stdlib.String.lowercase_ascii\n let uncapitalize_ascii = Stdlib.String.uncapitalize_ascii\n let split_on_char t ~sep = Stdlib.String.split_on_char sep t\n\n include (Poly : Comparisons with type t := string)\n\n module Map = struct\n include Map.Make (String)\n\n let find_opt key t =\n match find key t with x -> Some x | exception Not_found -> None\n end\n\n module Set = Set.Make (String)\nend\n\nlet ( @ ) = List.append\nlet output oc bytes ~pos ~len = output oc bytes pos len\nlet output_substring oc string ~pos ~len = output_substring oc string pos len\n","open! Import\nmodule Format = Caml.Format\n\nlet fold_dot_suffixes name ~init:acc ~f =\n let rec collapse_after_at = function\n | [] -> []\n | part :: parts ->\n if (not (String.is_empty part)) && Char.equal part.[0] '@' then\n [ String.concat (String.drop_prefix part 1 :: parts) ~sep:\".\" ]\n else part :: collapse_after_at parts\n in\n let rec loop acc parts =\n match parts with\n | [] -> acc\n | part :: parts ->\n loop (f (String.concat (part :: parts) ~sep:\".\") acc) parts\n in\n String.split_on_char name ~sep:'.' |> collapse_after_at |> loop acc\n\nlet dot_suffixes name =\n fold_dot_suffixes name ~init:[] ~f:(fun x acc -> x :: acc)\n\nlet split_path =\n let rec loop s i =\n if i = String.length s then (s, None)\n else match s.[i] with '.' -> after_dot s (i + 1) | _ -> loop s (i + 1)\n and after_dot s i =\n if i = String.length s then (s, None)\n else\n match s.[i] with\n | 'A' .. 'Z' -> (String.prefix s (i - 1), Some (String.drop_prefix s i))\n | '.' -> after_dot s (i + 1)\n | _ -> loop s (i + 1)\n in\n fun s -> loop s 0\n\nmodule Pattern = struct\n type t = { name : string; dot_suffixes : String.Set.t }\n\n let make name =\n { name; dot_suffixes = String.Set.of_list (dot_suffixes name) }\n\n let name t = t.name\n let matches t matched = String.Set.mem matched t.dot_suffixes\nend\n\nlet get_outer_namespace name =\n match String.index_opt name '.' with\n | None -> None\n | Some i -> Some (String.sub name ~pos:0 ~len:i)\n\nmodule Whitelisted = struct\n (* White list the following attributes, as well as all their dot suffixes.\n\n Since these attributes are interpreted by the compiler itself, we cannot check\n at the level of a ppx rewriter that they have been properly interpreted, so\n we just accept them anywhere.\n\n Sadly, the compiler silently ignores them if they are misplaced...\n *)\n let create_set fully_qualified_names =\n List.fold_left\n ~f:(fun acc name ->\n fold_dot_suffixes name ~init:acc ~f:(fun x acc -> String.Set.add x acc))\n ~init:String.Set.empty fully_qualified_names\n\n let attributes =\n create_set\n [\n \"ocaml.alert\";\n \"ocaml.boxed\";\n \"ocaml.deprecated\";\n \"ocaml.deprecated_mutable\";\n \"ocaml.doc\";\n \"ocaml.extension_constructor\";\n \"ocaml.immediate\";\n \"ocaml.immediate64\";\n \"ocaml.inline\";\n \"ocaml.inlined\";\n \"ocaml.local\";\n \"ocaml.noalloc\";\n \"ocaml.ppwarning\";\n \"ocaml.remove_aliases\";\n \"ocaml.specialise\";\n \"ocaml.specialised\";\n \"ocaml.tailcall\";\n \"ocaml.text\";\n \"ocaml.unboxed\";\n \"ocaml.unroll\";\n \"ocaml.unrolled\";\n \"ocaml.untagged\";\n \"ocaml.warn_on_literal_pattern\";\n \"ocaml.warnerror\";\n \"ocaml.warning\";\n ]\n\n (* White list the following extensions.\n\n Since these extensions are interpreted by the compiler itself, we cannot check\n at the level of a ppx rewriter that they have been properly interpreted, so\n we just accept them anywhere.\n *)\n let extensions = create_set [ \"ocaml.error\"; \"ocaml.extension_constructor\" ]\n\n let is_whitelisted ~kind name =\n match kind with\n | `Attribute -> String.Set.mem name attributes\n | `Extension -> String.Set.mem name extensions\n\n let get_attribute_list () = String.Set.elements attributes\n let get_extension_list () = String.Set.elements extensions\nend\n\nmodule Reserved_namespaces = struct\n let tbl : (string, unit) Hashtbl.t = Hashtbl.create 16\n let reserve ns = Hashtbl.add_exn tbl ~key:ns ~data:()\n let () = reserve \"merlin\"\n let () = reserve \"reason\"\n let () = reserve \"refmt\"\n let () = reserve \"metaocaml\"\n let () = reserve \"ocamlformat\"\n\n let is_in_reserved_namespaces name =\n match get_outer_namespace name with\n | Some ns -> Hashtbl.mem tbl ns\n | None -> Hashtbl.mem tbl name\n\n let check_not_reserved ~kind name =\n let kind, list =\n match kind with\n | `Attribute -> (\"attribute\", Whitelisted.attributes)\n | `Extension -> (\"extension\", Whitelisted.extensions)\n in\n if String.Set.mem name list then\n Printf.ksprintf failwith\n \"Cannot register %s with name '%s' as it matches an %s reserved by the \\\n compiler\"\n kind name kind\n else if is_in_reserved_namespaces name then\n Printf.ksprintf failwith\n \"Cannot register %s with name '%s' as its namespace is marked as \\\n reserved\"\n kind name\nend\n\nlet ignore_checks name =\n Reserved_namespaces.is_in_reserved_namespaces name\n || String.is_prefix name ~prefix:\"_\"\n\nmodule Registrar = struct\n type element = { fully_qualified_name : string; declared_at : Caller_id.t }\n type all_for_context = { mutable all : element String.Map.t }\n\n type 'a t = {\n all_by_context : ('a, all_for_context) Hashtbl.t;\n skip : string list;\n kind : string;\n string_of_context : 'a -> string option;\n }\n\n let create ~kind ~current_file ~string_of_context =\n {\n all_by_context = Hashtbl.create 16;\n skip = [ current_file; __FILE__ ];\n kind;\n string_of_context;\n }\n\n let get_all_for_context t context =\n Hashtbl.find_or_add t.all_by_context context ~default:(fun () ->\n { all = String.Map.empty })\n\n let check_collisions_local ~caller ~all_for_context t context name =\n match String.Map.find_opt name all_for_context.all with\n | None -> ()\n | Some e ->\n let declared_at = function\n | None -> \"\"\n | Some (loc : Caml.Printexc.location) ->\n Printf.sprintf \" declared at %s:%d\" loc.filename loc.line_number\n in\n let context =\n match t.string_of_context context with\n | None -> \"\"\n | Some s -> \" on \" ^ s ^ \"s\"\n in\n Printf.ksprintf failwith\n \"Some ppx-es tried to register conflicting transformations: %s \\\n '%s'%s%s matches %s '%s'%s\"\n (String.capitalize_ascii t.kind)\n name context (declared_at caller) t.kind e.fully_qualified_name\n (declared_at e.declared_at)\n\n let check_collisions t context name =\n let caller = Caller_id.get ~skip:t.skip in\n let all_for_context = get_all_for_context t context in\n check_collisions_local ~caller ~all_for_context t context name\n\n let register ~kind t context name =\n Reserved_namespaces.check_not_reserved ~kind name;\n let caller = Caller_id.get ~skip:t.skip in\n let all = get_all_for_context t context in\n check_collisions_local ~caller ~all_for_context:all t context name;\n let t = { fully_qualified_name = name; declared_at = caller } in\n all.all <-\n fold_dot_suffixes name ~init:all.all ~f:(fun name acc ->\n String.Map.add name t acc)\n\n let spellcheck t context ?(white_list = []) name =\n let all =\n let all = get_all_for_context t context in\n String.Map.fold (fun key _ acc -> key :: acc) all.all []\n in\n match Spellcheck.spellcheck (all @ white_list) name with\n | Some _ as x -> x\n | None -> (\n let other_contexts =\n Hashtbl.fold\n (fun ctx { all } acc ->\n if Poly.( <> ) context ctx && String.Map.mem name all then\n match t.string_of_context ctx with\n | None -> acc\n | Some s -> (s ^ \"s\") :: acc\n else acc)\n t.all_by_context []\n in\n let pp_text = Format.pp_print_text in\n let current_context ppf =\n match t.string_of_context context with\n | None | Some \"\" -> ()\n | Some s ->\n let a_or_an =\n match s.[0] with\n | 'a' | 'e' | 'i' | 'o' | 'u' | 'y' -> \"an\"\n | _ -> \"a\"\n in\n Format.fprintf ppf\n \"@ but@ is@ used@ here@ in@ the@ context@ of@ %s@ %a\" a_or_an\n pp_text s\n in\n match\n List.sort ~cmp:(fun x y -> -String.compare x y) other_contexts\n with\n | [] -> None\n | [ c ] ->\n Some\n (Format.asprintf\n \"@[Hint:@ `%s'@ is@ available@ for@ %a%t.@]@\\n\\\n Did you put it at the wrong level?\" name pp_text c\n current_context)\n | last :: rev_others ->\n let others = List.rev rev_others in\n Some\n (Format.asprintf\n \"@[Hint:@ `%s'@ is@ available@ for@ %a@ and@ %a%t.@]@\\n\\\n Did you put it at the wrong level?\" name\n (Format.pp_print_list pp_text ~pp_sep:(fun ppf () ->\n Format.fprintf ppf \",@ \"))\n others pp_text last current_context))\n\n (* TODO: hint spelling errors regarding reserved namespaces names and white\n listed names instead of taking an optional [white_list] parameter. *)\n let raise_errorf t context ?white_list fmt (name : string Loc.t) =\n Printf.ksprintf\n (fun msg ->\n match spellcheck t context name.txt ?white_list with\n | None -> Location.raise_errorf ~loc:name.loc \"%s\" msg\n | Some s -> Location.raise_errorf ~loc:name.loc \"%s.\\n%s\" msg s)\n fmt name.txt\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Jerome Vouillon, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2002 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nopen Obj\n\n(**** Object representation ****)\n\nexternal set_id: 'a -> 'a = \"caml_set_oo_id\" [@@noalloc]\n\n(**** Object copy ****)\n\nlet copy o =\n let o = (Obj.obj (Obj.dup (Obj.repr o))) in\n set_id o\n\n(**** Compression options ****)\n(* Parameters *)\ntype params = {\n mutable compact_table : bool;\n mutable copy_parent : bool;\n mutable clean_when_copying : bool;\n mutable retry_count : int;\n mutable bucket_small_size : int\n }\n\nlet params = {\n compact_table = true;\n copy_parent = true;\n clean_when_copying = true;\n retry_count = 3;\n bucket_small_size = 16\n}\n\n(**** Parameters ****)\n\nlet initial_object_size = 2\n\n(**** Items ****)\n\ntype item = DummyA | DummyB | DummyC of int\nlet _ = [DummyA; DummyB; DummyC 0] (* to avoid warnings *)\n\nlet dummy_item = (magic () : item)\n\n(**** Types ****)\n\ntype tag\ntype label = int\ntype closure = item\ntype t = DummyA | DummyB | DummyC of int\nlet _ = [DummyA; DummyB; DummyC 0] (* to avoid warnings *)\n\ntype obj = t array\nexternal ret : (obj -> 'a) -> closure = \"%identity\"\n\n(**** Labels ****)\n\nlet public_method_label s : tag =\n let accu = ref 0 in\n for i = 0 to String.length s - 1 do\n accu := 223 * !accu + Char.code s.[i]\n done;\n (* reduce to 31 bits *)\n accu := !accu land (1 lsl 31 - 1);\n (* make it signed for 64 bits architectures *)\n let tag = if !accu > 0x3FFFFFFF then !accu - (1 lsl 31) else !accu in\n (* Printf.eprintf \"%s = %d\\n\" s tag; flush stderr; *)\n magic tag\n\n(**** Sparse array ****)\n\nmodule Vars =\n Map.Make(struct type t = string let compare (x:t) y = compare x y end)\ntype vars = int Vars.t\n\nmodule Meths =\n Map.Make(struct type t = string let compare (x:t) y = compare x y end)\ntype meths = label Meths.t\nmodule Labs =\n Map.Make(struct type t = label let compare (x:t) y = compare x y end)\ntype labs = bool Labs.t\n\n(* The compiler assumes that the first field of this structure is [size]. *)\ntype table =\n { mutable size: int;\n mutable methods: closure array;\n mutable methods_by_name: meths;\n mutable methods_by_label: labs;\n mutable previous_states:\n (meths * labs * (label * item) list * vars *\n label list * string list) list;\n mutable hidden_meths: (label * item) list;\n mutable vars: vars;\n mutable initializers: (obj -> unit) list }\n\nlet dummy_table =\n { methods = [| dummy_item |];\n methods_by_name = Meths.empty;\n methods_by_label = Labs.empty;\n previous_states = [];\n hidden_meths = [];\n vars = Vars.empty;\n initializers = [];\n size = 0 }\n\nlet table_count = ref 0\n\n(* dummy_met should be a pointer, so use an atom *)\nlet dummy_met : item = obj (Obj.new_block 0 0)\n(* if debugging is needed, this could be a good idea: *)\n(* let dummy_met () = failwith \"Undefined method\" *)\n\nlet rec fit_size n =\n if n <= 2 then n else\n fit_size ((n+1)/2) * 2\n\nlet new_table pub_labels =\n incr table_count;\n let len = Array.length pub_labels in\n let methods = Array.make (len*2+2) dummy_met in\n methods.(0) <- magic len;\n methods.(1) <- magic (fit_size len * Sys.word_size / 8 - 1);\n for i = 0 to len - 1 do methods.(i*2+3) <- magic pub_labels.(i) done;\n { methods = methods;\n methods_by_name = Meths.empty;\n methods_by_label = Labs.empty;\n previous_states = [];\n hidden_meths = [];\n vars = Vars.empty;\n initializers = [];\n size = initial_object_size }\n\nlet resize array new_size =\n let old_size = Array.length array.methods in\n if new_size > old_size then begin\n let new_buck = Array.make new_size dummy_met in\n Array.blit array.methods 0 new_buck 0 old_size;\n array.methods <- new_buck\n end\n\nlet put array label element =\n resize array (label + 1);\n array.methods.(label) <- element\n\n(**** Classes ****)\n\nlet method_count = ref 0\nlet inst_var_count = ref 0\n\n(* type t *)\ntype meth = item\n\nlet new_method table =\n let index = Array.length table.methods in\n resize table (index + 1);\n index\n\nlet get_method_label table name =\n try\n Meths.find name table.methods_by_name\n with Not_found ->\n let label = new_method table in\n table.methods_by_name <- Meths.add name label table.methods_by_name;\n table.methods_by_label <- Labs.add label true table.methods_by_label;\n label\n\nlet get_method_labels table names =\n Array.map (get_method_label table) names\n\nlet set_method table label element =\n incr method_count;\n if Labs.find label table.methods_by_label then\n put table label element\n else\n table.hidden_meths <- (label, element) :: table.hidden_meths\n\nlet get_method table label =\n try List.assoc label table.hidden_meths\n with Not_found -> table.methods.(label)\n\nlet to_list arr =\n if arr == magic 0 then [] else Array.to_list arr\n\nlet narrow table vars virt_meths concr_meths =\n let vars = to_list vars\n and virt_meths = to_list virt_meths\n and concr_meths = to_list concr_meths in\n let virt_meth_labs = List.map (get_method_label table) virt_meths in\n let concr_meth_labs = List.map (get_method_label table) concr_meths in\n table.previous_states <-\n (table.methods_by_name, table.methods_by_label, table.hidden_meths,\n table.vars, virt_meth_labs, vars)\n :: table.previous_states;\n table.vars <-\n Vars.fold\n (fun lab info tvars ->\n if List.mem lab vars then Vars.add lab info tvars else tvars)\n table.vars Vars.empty;\n let by_name = ref Meths.empty in\n let by_label = ref Labs.empty in\n List.iter2\n (fun met label ->\n by_name := Meths.add met label !by_name;\n by_label :=\n Labs.add label\n (try Labs.find label table.methods_by_label with Not_found -> true)\n !by_label)\n concr_meths concr_meth_labs;\n List.iter2\n (fun met label ->\n by_name := Meths.add met label !by_name;\n by_label := Labs.add label false !by_label)\n virt_meths virt_meth_labs;\n table.methods_by_name <- !by_name;\n table.methods_by_label <- !by_label;\n table.hidden_meths <-\n List.fold_right\n (fun ((lab, _) as met) hm ->\n if List.mem lab virt_meth_labs then hm else met::hm)\n table.hidden_meths\n []\n\nlet widen table =\n let (by_name, by_label, saved_hidden_meths, saved_vars, virt_meths, vars) =\n List.hd table.previous_states\n in\n table.previous_states <- List.tl table.previous_states;\n table.vars <-\n List.fold_left\n (fun s v -> Vars.add v (Vars.find v table.vars) s)\n saved_vars vars;\n table.methods_by_name <- by_name;\n table.methods_by_label <- by_label;\n table.hidden_meths <-\n List.fold_right\n (fun ((lab, _) as met) hm ->\n if List.mem lab virt_meths then hm else met::hm)\n table.hidden_meths\n saved_hidden_meths\n\nlet new_slot table =\n let index = table.size in\n table.size <- index + 1;\n index\n\nlet new_variable table name =\n try Vars.find name table.vars\n with Not_found ->\n let index = new_slot table in\n if name <> \"\" then table.vars <- Vars.add name index table.vars;\n index\n\nlet to_array arr =\n if arr = Obj.magic 0 then [||] else arr\n\nlet new_methods_variables table meths vals =\n let meths = to_array meths in\n let nmeths = Array.length meths and nvals = Array.length vals in\n let res = Array.make (nmeths + nvals) 0 in\n for i = 0 to nmeths - 1 do\n res.(i) <- get_method_label table meths.(i)\n done;\n for i = 0 to nvals - 1 do\n res.(i+nmeths) <- new_variable table vals.(i)\n done;\n res\n\nlet get_variable table name =\n try Vars.find name table.vars with Not_found -> assert false\n\nlet get_variables table names =\n Array.map (get_variable table) names\n\nlet add_initializer table f =\n table.initializers <- f::table.initializers\n\n(*\nmodule Keys =\n Map.Make(struct type t = tag array let compare (x:t) y = compare x y end)\nlet key_map = ref Keys.empty\nlet get_key tags : item =\n try magic (Keys.find tags !key_map : tag array)\n with Not_found ->\n key_map := Keys.add tags tags !key_map;\n magic tags\n*)\n\nlet create_table public_methods =\n if public_methods == magic 0 then new_table [||] else\n (* [public_methods] must be in ascending order for bytecode *)\n let tags = Array.map public_method_label public_methods in\n let table = new_table tags in\n Array.iteri\n (fun i met ->\n let lab = i*2+2 in\n table.methods_by_name <- Meths.add met lab table.methods_by_name;\n table.methods_by_label <- Labs.add lab true table.methods_by_label)\n public_methods;\n table\n\nlet init_class table =\n inst_var_count := !inst_var_count + table.size - 1;\n table.initializers <- List.rev table.initializers;\n resize table (3 + magic table.methods.(1) * 16 / Sys.word_size)\n\nlet inherits cla vals virt_meths concr_meths (_, super, _, env) top =\n narrow cla vals virt_meths concr_meths;\n let init =\n if top then super cla env else Obj.repr (super cla) in\n widen cla;\n Array.concat\n [[| repr init |];\n magic (Array.map (get_variable cla) (to_array vals) : int array);\n Array.map\n (fun nm -> repr (get_method cla (get_method_label cla nm) : closure))\n (to_array concr_meths) ]\n\nlet make_class pub_meths class_init =\n let table = create_table pub_meths in\n let env_init = class_init table in\n init_class table;\n (env_init (Obj.repr 0), class_init, env_init, Obj.repr 0)\n\ntype init_table = { mutable env_init: t; mutable class_init: table -> t }\n[@@warning \"-unused-field\"]\n\nlet make_class_store pub_meths class_init init_table =\n let table = create_table pub_meths in\n let env_init = class_init table in\n init_class table;\n init_table.class_init <- class_init;\n init_table.env_init <- env_init\n\nlet dummy_class loc =\n let undef = fun _ -> raise (Undefined_recursive_module loc) in\n (Obj.magic undef, undef, undef, Obj.repr 0)\n\n(**** Objects ****)\n\nlet create_object table =\n (* XXX Appel de [obj_block] | Call to [obj_block] *)\n let obj = Obj.new_block Obj.object_tag table.size in\n (* XXX Appel de [caml_modify] | Call to [caml_modify] *)\n Obj.set_field obj 0 (Obj.repr table.methods);\n Obj.obj (set_id obj)\n\nlet create_object_opt obj_0 table =\n if (Obj.magic obj_0 : bool) then obj_0 else begin\n (* XXX Appel de [obj_block] | Call to [obj_block] *)\n let obj = Obj.new_block Obj.object_tag table.size in\n (* XXX Appel de [caml_modify] | Call to [caml_modify] *)\n Obj.set_field obj 0 (Obj.repr table.methods);\n Obj.obj (set_id obj)\n end\n\nlet rec iter_f obj =\n function\n [] -> ()\n | f::l -> f obj; iter_f obj l\n\nlet run_initializers obj table =\n let inits = table.initializers in\n if inits <> [] then\n iter_f obj inits\n\nlet run_initializers_opt obj_0 obj table =\n if (Obj.magic obj_0 : bool) then obj else begin\n let inits = table.initializers in\n if inits <> [] then iter_f obj inits;\n obj\n end\n\nlet create_object_and_run_initializers obj_0 table =\n if (Obj.magic obj_0 : bool) then obj_0 else begin\n let obj = create_object table in\n run_initializers obj table;\n obj\n end\n\n(* Equivalent primitive below\nlet sendself obj lab =\n (magic obj : (obj -> t) array array).(0).(lab) obj\n*)\nexternal send : obj -> tag -> 'a = \"%send\"\nexternal sendcache : obj -> tag -> t -> int -> 'a = \"%sendcache\"\nexternal sendself : obj -> label -> 'a = \"%sendself\"\nexternal get_public_method : obj -> tag -> closure\n = \"caml_get_public_method\" [@@noalloc]\n\n(**** table collection access ****)\n\ntype tables =\n | Empty\n | Cons of {key : closure; mutable data: tables; mutable next: tables}\n\nlet set_data tables v = match tables with\n | Empty -> assert false\n | Cons tables -> tables.data <- v\nlet set_next tables v = match tables with\n | Empty -> assert false\n | Cons tables -> tables.next <- v\nlet get_key = function\n | Empty -> assert false\n | Cons tables -> tables.key\nlet get_data = function\n | Empty -> assert false\n | Cons tables -> tables.data\nlet get_next = function\n | Empty -> assert false\n | Cons tables -> tables.next\n\nlet build_path n keys tables =\n let res = Cons {key = Obj.magic 0; data = Empty; next = Empty} in\n let r = ref res in\n for i = 0 to n do\n r := Cons {key = keys.(i); data = !r; next = Empty}\n done;\n set_data tables !r;\n res\n\nlet rec lookup_keys i keys tables =\n if i < 0 then tables else\n let key = keys.(i) in\n let rec lookup_key (tables:tables) =\n if get_key tables == key then\n match get_data tables with\n | Empty -> assert false\n | Cons _ as tables_data ->\n lookup_keys (i-1) keys tables_data\n else\n match get_next tables with\n | Cons _ as next -> lookup_key next\n | Empty ->\n let next : tables = Cons {key; data = Empty; next = Empty} in\n set_next tables next;\n build_path (i-1) keys next\n in\n lookup_key tables\n\nlet lookup_tables root keys =\n match get_data root with\n | Cons _ as root_data ->\n lookup_keys (Array.length keys - 1) keys root_data\n | Empty ->\n build_path (Array.length keys - 1) keys root\n\n(**** builtin methods ****)\n\nlet get_const x = ret (fun _obj -> x)\nlet get_var n = ret (fun obj -> Array.unsafe_get obj n)\nlet get_env e n =\n ret (fun obj ->\n Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n)\nlet get_meth n = ret (fun obj -> sendself obj n)\nlet set_var n = ret (fun obj x -> Array.unsafe_set obj n x)\nlet app_const f x = ret (fun _obj -> f x)\nlet app_var f n = ret (fun obj -> f (Array.unsafe_get obj n))\nlet app_env f e n =\n ret (fun obj ->\n f (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n))\nlet app_meth f n = ret (fun obj -> f (sendself obj n))\nlet app_const_const f x y = ret (fun _obj -> f x y)\nlet app_const_var f x n = ret (fun obj -> f x (Array.unsafe_get obj n))\nlet app_const_meth f x n = ret (fun obj -> f x (sendself obj n))\nlet app_var_const f n x = ret (fun obj -> f (Array.unsafe_get obj n) x)\nlet app_meth_const f n x = ret (fun obj -> f (sendself obj n) x)\nlet app_const_env f x e n =\n ret (fun obj ->\n f x (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n))\nlet app_env_const f e n x =\n ret (fun obj ->\n f (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) n) x)\nlet meth_app_const n x = ret (fun obj -> (sendself obj n : _ -> _) x)\nlet meth_app_var n m =\n ret (fun obj -> (sendself obj n : _ -> _) (Array.unsafe_get obj m))\nlet meth_app_env n e m =\n ret (fun obj -> (sendself obj n : _ -> _)\n (Array.unsafe_get (Obj.magic (Array.unsafe_get obj e) : obj) m))\nlet meth_app_meth n m =\n ret (fun obj -> (sendself obj n : _ -> _) (sendself obj m))\nlet send_const m x c =\n ret (fun obj -> sendcache x m (Array.unsafe_get obj 0) c)\nlet send_var m n c =\n ret (fun obj ->\n sendcache (Obj.magic (Array.unsafe_get obj n) : obj) m\n (Array.unsafe_get obj 0) c)\nlet send_env m e n c =\n ret (fun obj ->\n sendcache\n (Obj.magic (Array.unsafe_get\n (Obj.magic (Array.unsafe_get obj e) : obj) n) : obj)\n m (Array.unsafe_get obj 0) c)\nlet send_meth m n c =\n ret (fun obj ->\n sendcache (sendself obj n) m (Array.unsafe_get obj 0) c)\nlet new_cache table =\n let n = new_method table in\n let n =\n if n mod 2 = 0 || n > 2 + magic table.methods.(1) * 16 / Sys.word_size\n then n else new_method table\n in\n table.methods.(n) <- Obj.magic 0;\n n\n\ntype impl =\n GetConst\n | GetVar\n | GetEnv\n | GetMeth\n | SetVar\n | AppConst\n | AppVar\n | AppEnv\n | AppMeth\n | AppConstConst\n | AppConstVar\n | AppConstEnv\n | AppConstMeth\n | AppVarConst\n | AppEnvConst\n | AppMethConst\n | MethAppConst\n | MethAppVar\n | MethAppEnv\n | MethAppMeth\n | SendConst\n | SendVar\n | SendEnv\n | SendMeth\n | Closure of closure\n\nlet method_impl table i arr =\n let next () = incr i; magic arr.(!i) in\n match next() with\n GetConst -> let x : t = next() in get_const x\n | GetVar -> let n = next() in get_var n\n | GetEnv -> let e = next() in let n = next() in get_env e n\n | GetMeth -> let n = next() in get_meth n\n | SetVar -> let n = next() in set_var n\n | AppConst -> let f = next() in let x = next() in app_const f x\n | AppVar -> let f = next() in let n = next () in app_var f n\n | AppEnv ->\n let f = next() in let e = next() in let n = next() in\n app_env f e n\n | AppMeth -> let f = next() in let n = next () in app_meth f n\n | AppConstConst ->\n let f = next() in let x = next() in let y = next() in\n app_const_const f x y\n | AppConstVar ->\n let f = next() in let x = next() in let n = next() in\n app_const_var f x n\n | AppConstEnv ->\n let f = next() in let x = next() in let e = next () in let n = next() in\n app_const_env f x e n\n | AppConstMeth ->\n let f = next() in let x = next() in let n = next() in\n app_const_meth f x n\n | AppVarConst ->\n let f = next() in let n = next() in let x = next() in\n app_var_const f n x\n | AppEnvConst ->\n let f = next() in let e = next () in let n = next() in let x = next() in\n app_env_const f e n x\n | AppMethConst ->\n let f = next() in let n = next() in let x = next() in\n app_meth_const f n x\n | MethAppConst ->\n let n = next() in let x = next() in meth_app_const n x\n | MethAppVar ->\n let n = next() in let m = next() in meth_app_var n m\n | MethAppEnv ->\n let n = next() in let e = next() in let m = next() in\n meth_app_env n e m\n | MethAppMeth ->\n let n = next() in let m = next() in meth_app_meth n m\n | SendConst ->\n let m = next() in let x = next() in send_const m x (new_cache table)\n | SendVar ->\n let m = next() in let n = next () in send_var m n (new_cache table)\n | SendEnv ->\n let m = next() in let e = next() in let n = next() in\n send_env m e n (new_cache table)\n | SendMeth ->\n let m = next() in let n = next () in send_meth m n (new_cache table)\n | Closure _ as clo -> magic clo\n\nlet set_methods table methods =\n let len = Array.length methods in let i = ref 0 in\n while !i < len do\n let label = methods.(!i) in let clo = method_impl table i methods in\n set_method table label clo;\n incr i\n done\n\n(**** Statistics ****)\n\ntype stats =\n { classes: int; methods: int; inst_vars: int; }\n\nlet stats () =\n { classes = !table_count;\n methods = !method_count; inst_vars = !inst_var_count; }\n","open Import\nopen Ast_builder.Default\n\n(* [do_insert_unused_warning_attribute] -- If true, generated code\n contains compiler attribute to disable unused warnings, instead of\n inserting [let _ = ... ]. *)\nlet do_insert_unused_warning_attribute = ref false\nlet keep_w32_impl = ref false\nlet keep_w32_intf = ref false\n\nlet () =\n let keep_w32_spec =\n Caml.Arg.Symbol\n ( [ \"impl\"; \"intf\"; \"both\" ],\n function\n | \"impl\" -> keep_w32_impl := true\n | \"intf\" -> keep_w32_intf := true\n | \"both\" ->\n keep_w32_impl := true;\n keep_w32_intf := true\n | _ -> assert false )\n in\n let conv_w32_spec =\n Caml.Arg.Symbol\n ( [ \"code\"; \"attribute\" ],\n function\n | \"code\" -> do_insert_unused_warning_attribute := false\n | \"attribute\" -> do_insert_unused_warning_attribute := true\n | _ -> assert false )\n in\n Driver.add_arg \"-deriving-keep-w32\" keep_w32_spec\n ~doc:\" Do not try to disable warning 32 for the generated code\";\n Driver.add_arg \"-deriving-disable-w32-method\" conv_w32_spec\n ~doc:\" How to disable warning 32 for the generated code\";\n Driver.add_arg \"-type-conv-keep-w32\" keep_w32_spec\n ~doc:\" Deprecated, use -deriving-keep-w32\";\n Driver.add_arg \"-type-conv-w32\" conv_w32_spec\n ~doc:\" Deprecated, use -deriving-disable-w32-method\"\n\nlet keep_w32_impl () = !keep_w32_impl || Driver.pretty ()\nlet keep_w32_intf () = !keep_w32_intf || Driver.pretty ()\nlet keep_w60_impl = ref false\nlet keep_w60_intf = ref false\n\nlet () =\n let keep_w60_spec =\n Caml.Arg.Symbol\n ( [ \"impl\"; \"intf\"; \"both\" ],\n function\n | \"impl\" -> keep_w60_impl := true\n | \"intf\" -> keep_w60_intf := true\n | \"both\" ->\n keep_w60_impl := true;\n keep_w60_intf := true\n | _ -> assert false )\n in\n Driver.add_arg \"-deriving-keep-w60\" keep_w60_spec\n ~doc:\" Do not try to disable warning 60 for the generated code\"\n\nlet keep_w60_impl () = !keep_w60_impl || Driver.pretty ()\nlet keep_w60_intf () = !keep_w60_intf || Driver.pretty ()\n\nmodule Args = struct\n include (\n Ast_pattern :\n module type of struct\n include Ast_pattern\n end\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) Ast_pattern.t)\n\n type 'a param = {\n name : string;\n pattern : (expression, 'a) Ast_pattern.Packed.t;\n default : 'a;\n }\n\n let arg name pattern =\n {\n name;\n default = None;\n pattern = Ast_pattern.Packed.create pattern (fun x -> Some x);\n }\n\n let flag name =\n let pattern = pexp_ident (lident (string name)) in\n { name; default = false; pattern = Ast_pattern.Packed.create pattern true }\n\n type (_, _) t =\n | Nil : ('m, 'm) t\n | Cons : ('m1, 'a -> 'm2) t * 'a param -> ('m1, 'm2) t\n\n let empty = Nil\n let ( +> ) a b = Cons (a, b)\n\n let rec names : type a b. (a, b) t -> string list = function\n | Nil -> []\n | Cons (t, p) -> p.name :: names t\n\n module Instance = struct\n type (_, _) instance =\n | I_nil : ('m, 'm) instance\n | I_cons : ('m1, 'a -> 'm2) instance * 'a -> ('m1, 'm2) instance\n\n let rec create :\n type a b. (a, b) t -> (string * expression) list -> (a, b) instance =\n fun spec args ->\n match spec with\n | Nil -> I_nil\n | Cons (t, p) ->\n let value =\n match List.assoc_opt p.name args with\n | None -> p.default\n | Some expr -> Ast_pattern.Packed.parse p.pattern expr.pexp_loc expr\n in\n I_cons (create t args, value)\n\n let rec apply : type a b. (a, b) instance -> a -> b =\n fun t f -> match t with I_nil -> f | I_cons (t, x) -> apply t f x\n end\n\n let apply t args f = Instance.apply (Instance.create t args) f\nend\n\n(* +-----------------------------------------------------------------+\n | Generators |\n +-----------------------------------------------------------------+ *)\n\ntype t = string\n\nlet ignore (_ : t) = ()\n\ntype parsed_args =\n | Args of (string * expression) list\n | Unknown_syntax of Location.t * string\n\nmodule Generator = struct\n type deriver = t\n\n type ('a, 'b) t =\n | T : {\n spec : ('c, 'a) Args.t;\n gen : ctxt:Expansion_context.Deriver.t -> 'b -> 'c;\n arg_names : String.Set.t;\n attributes : Attribute.packed list;\n deps : deriver list;\n }\n -> ('a, 'b) t\n\n let deps (T t) = t.deps\n\n module V2 = struct\n let make ?(attributes = []) ?(deps = []) spec gen =\n let arg_names = String.Set.of_list (Args.names spec) in\n T { spec; gen; arg_names; attributes; deps }\n\n let make_noarg ?attributes ?deps gen = make ?attributes ?deps Args.empty gen\n end\n\n let make ?attributes ?deps spec gen =\n V2.make ?attributes ?deps spec\n (Expansion_context.Deriver.with_loc_and_path gen)\n\n let make_noarg ?attributes ?deps gen = make ?attributes ?deps Args.empty gen\n\n let merge_accepted_args l =\n let rec loop acc = function\n | [] -> acc\n | T t :: rest -> loop (String.Set.union acc t.arg_names) rest\n in\n loop String.Set.empty l\n\n let check_arguments name generators (args : (string * expression) list) =\n List.iter args ~f:(fun (label, e) ->\n if String.is_empty label then\n Location.raise_errorf ~loc:e.pexp_loc\n \"Ppxlib.Deriving: generator arguments must be labelled\");\n Option.iter\n (List.find_a_dup args ~compare:(fun (a, _) (b, _) -> String.compare a b))\n ~f:(fun (label, e) ->\n Location.raise_errorf ~loc:e.pexp_loc\n \"Ppxlib.Deriving: argument labelled '%s' appears more than once\" label);\n let accepted_args = merge_accepted_args generators in\n List.iter args ~f:(fun (label, e) ->\n if not (String.Set.mem label accepted_args) then\n let spellcheck_msg =\n match\n Spellcheck.spellcheck (String.Set.elements accepted_args) label\n with\n | None -> \"\"\n | Some s -> \".\\n\" ^ s\n in\n Location.raise_errorf ~loc:e.pexp_loc\n \"Ppxlib.Deriving: generator '%s' doesn't accept argument '%s'%s\"\n name label spellcheck_msg)\n\n let apply (T t) ~name:_ ~ctxt x args = Args.apply t.spec args (t.gen ~ctxt x)\n\n let apply_all ~ctxt entry (name, generators, args) =\n check_arguments name.txt generators args;\n List.concat_map generators ~f:(fun t ->\n apply t ~name:name.txt ~ctxt entry args)\n\n let apply_all ~ctxt entry generators =\n List.concat_map generators ~f:(apply_all ~ctxt entry)\nend\n\nmodule Deriver = struct\n module Actual_deriver = struct\n type t = {\n name : string;\n str_type_decl :\n (structure, rec_flag * type_declaration list) Generator.t option;\n str_type_ext : (structure, type_extension) Generator.t option;\n str_exception : (structure, type_exception) Generator.t option;\n str_module_type_decl :\n (structure, module_type_declaration) Generator.t option;\n sig_type_decl :\n (signature, rec_flag * type_declaration list) Generator.t option;\n sig_type_ext : (signature, type_extension) Generator.t option;\n sig_exception : (signature, type_exception) Generator.t option;\n sig_module_type_decl :\n (signature, module_type_declaration) Generator.t option;\n extension :\n (loc:Location.t -> path:string -> core_type -> expression) option;\n }\n end\n\n module Alias = struct\n type t = {\n str_type_decl : string list;\n str_type_ext : string list;\n str_exception : string list;\n str_module_type_decl : string list;\n sig_type_decl : string list;\n sig_type_ext : string list;\n sig_exception : string list;\n sig_module_type_decl : string list;\n }\n end\n\n module Field = struct\n type kind = Str | Sig\n\n type ('a, 'b) t = {\n name : string;\n kind : kind;\n get : Actual_deriver.t -> ('a, 'b) Generator.t option;\n get_set : Alias.t -> string list;\n }\n\n let str_type_decl =\n {\n kind = Str;\n name = \"type\";\n get = (fun t -> t.str_type_decl);\n get_set = (fun t -> t.str_type_decl);\n }\n\n let str_type_ext =\n {\n kind = Str;\n name = \"type extension\";\n get = (fun t -> t.str_type_ext);\n get_set = (fun t -> t.str_type_ext);\n }\n\n let str_exception =\n {\n kind = Str;\n name = \"exception\";\n get = (fun t -> t.str_exception);\n get_set = (fun t -> t.str_exception);\n }\n\n let str_module_type_decl =\n {\n kind = Str;\n name = \"module type\";\n get = (fun t -> t.str_module_type_decl);\n get_set = (fun t -> t.str_module_type_decl);\n }\n\n let sig_type_decl =\n {\n kind = Sig;\n name = \"signature type\";\n get = (fun t -> t.sig_type_decl);\n get_set = (fun t -> t.sig_type_decl);\n }\n\n let sig_type_ext =\n {\n kind = Sig;\n name = \"signature type extension\";\n get = (fun t -> t.sig_type_ext);\n get_set = (fun t -> t.sig_type_ext);\n }\n\n let sig_exception =\n {\n kind = Sig;\n name = \"signature exception\";\n get = (fun t -> t.sig_exception);\n get_set = (fun t -> t.sig_exception);\n }\n\n let sig_module_type_decl =\n {\n kind = Sig;\n name = \"signature module type\";\n get = (fun t -> t.sig_module_type_decl);\n get_set = (fun t -> t.sig_module_type_decl);\n }\n end\n\n type t = Actual_deriver of Actual_deriver.t | Alias of Alias.t\n type Ppx_derivers.deriver += T of t\n\n let derivers () =\n List.filter_map (Ppx_derivers.derivers ()) ~f:(function\n | name, T t -> Some (name, t)\n | _ -> None)\n\n exception Not_supported of string\n\n let resolve_actual_derivers (field : (_, _) Field.t) name =\n let rec loop name collected =\n if\n List.exists collected ~f:(fun (d : Actual_deriver.t) ->\n String.equal d.name name)\n then collected\n else\n match Ppx_derivers.lookup name with\n | Some (T (Actual_deriver drv)) -> drv :: collected\n | Some (T (Alias alias)) ->\n let set = field.get_set alias in\n List.fold_right set ~init:collected ~f:loop\n | _ -> raise (Not_supported name)\n in\n List.rev (loop name [])\n\n let resolve_internal (field : (_, _) Field.t) name =\n List.map (resolve_actual_derivers field name) ~f:(fun drv ->\n match field.get drv with\n | None -> raise (Not_supported name)\n | Some g -> (drv.name, g))\n\n let supported_for field =\n List.fold_left (derivers ()) ~init:String.Set.empty ~f:(fun acc (name, _) ->\n match resolve_internal field name with\n | _ -> String.Set.add name acc\n | exception Not_supported _ -> acc)\n |> String.Set.elements\n\n let not_supported (field : (_, _) Field.t) ?(spellcheck = true) name =\n let spellcheck_msg =\n if spellcheck then\n match Spellcheck.spellcheck (supported_for field) name.txt with\n | None -> \"\"\n | Some s -> \".\\n\" ^ s\n else \"\"\n in\n Location.raise_errorf ~loc:name.loc\n \"Ppxlib.Deriving: '%s' is not a supported %s deriving generator%s\"\n name.txt field.name spellcheck_msg\n\n let resolve field name =\n try resolve_internal field name.txt\n with Not_supported name' ->\n not_supported field ~spellcheck:(String.equal name.txt name') name\n\n let resolve_all field derivers =\n let derivers_and_args =\n List.filter_map derivers ~f:(fun (name, args) ->\n match Ppx_derivers.lookup name.txt with\n | None -> not_supported field name\n | Some (T _) ->\n (* It's one of ours, parse the arguments now. We can't do it before since\n ppx_deriving uses a different syntax for arguments. *)\n Some\n ( name,\n match args with\n | Args l -> l\n | Unknown_syntax (loc, msg) ->\n Location.raise_errorf ~loc \"Ppxlib.Deriving: %s\" msg )\n | Some _ ->\n (* It's not one of ours, ignore it. *)\n None)\n in\n (* Set of actual deriver names *)\n let seen = Hashtbl.create 16 in\n List.map derivers_and_args ~f:(fun (name, args) ->\n let named_generators = resolve field name in\n List.iter named_generators ~f:(fun (actual_deriver_name, gen) ->\n if\n Options.fail_on_duplicate_derivers\n && Hashtbl.mem seen actual_deriver_name\n then\n Location.raise_errorf ~loc:name.loc \"Deriver %s appears twice\"\n actual_deriver_name;\n List.iter (Generator.deps gen) ~f:(fun dep ->\n List.iter (resolve_actual_derivers field dep) ~f:(fun drv ->\n let dep_name = drv.name in\n if not (Hashtbl.mem seen dep_name) then\n Location.raise_errorf ~loc:name.loc\n \"Deriver %s is needed for %s, you need to add it \\\n before in the list\"\n dep_name name.txt));\n Hashtbl.set seen ~key:actual_deriver_name ~data:());\n (name, List.map named_generators ~f:snd, args))\n\n let add ?str_type_decl ?str_type_ext ?str_exception ?str_module_type_decl\n ?sig_type_decl ?sig_type_ext ?sig_exception ?sig_module_type_decl\n ?extension name =\n let actual_deriver : Actual_deriver.t =\n {\n name;\n str_type_decl;\n str_type_ext;\n str_exception;\n str_module_type_decl;\n sig_type_decl;\n sig_type_ext;\n sig_exception;\n sig_module_type_decl;\n extension;\n }\n in\n Ppx_derivers.register name (T (Actual_deriver actual_deriver));\n (match extension with\n | None -> ()\n | Some f ->\n let extension =\n Extension.declare name Expression Ast_pattern.(ptyp __) f\n in\n Driver.register_transformation\n (\"Ppxlib.Deriving.\" ^ name)\n ~rules:[ Context_free.Rule.extension extension ]);\n name\n\n let add_alias name ?str_type_decl ?str_type_ext ?str_exception\n ?str_module_type_decl ?sig_type_decl ?sig_type_ext ?sig_exception\n ?sig_module_type_decl set =\n let alias : Alias.t =\n let get = function None -> set | Some set -> set in\n {\n str_type_decl = get str_type_decl;\n str_type_ext = get str_type_ext;\n str_exception = get str_exception;\n str_module_type_decl = get str_module_type_decl;\n sig_type_decl = get sig_type_decl;\n sig_type_ext = get sig_type_ext;\n sig_exception = get sig_exception;\n sig_module_type_decl = get sig_module_type_decl;\n }\n in\n Ppx_derivers.register name (T (Alias alias));\n name\nend\n\nlet add = Deriver.add\nlet add_alias = Deriver.add_alias\n\n(* +-----------------------------------------------------------------+\n | [@@deriving ] parsing |\n +-----------------------------------------------------------------+ *)\n\nlet invalid_with ~loc =\n Location.raise_errorf ~loc \"invalid [@@deriving ] attribute syntax\"\n\nlet generator_name_of_id loc id =\n match Longident.flatten_exn id with\n | l -> { loc; txt = String.concat ~sep:\".\" l }\n | exception _ -> invalid_with ~loc\n\nexception Unknown_syntax of Location.t * string\n\nlet parse_arguments l =\n try\n Args\n (match l with\n | [ (Nolabel, e) ] -> (\n match e.pexp_desc with\n | Pexp_record (fields, None) ->\n List.map fields ~f:(fun (id, expr) ->\n let name =\n match id.txt with\n | Lident s -> s\n | _ ->\n raise_notrace\n (Unknown_syntax (id.loc, \"simple identifier expected\"))\n in\n (name, expr))\n | _ ->\n raise_notrace\n (Unknown_syntax\n ( e.pexp_loc,\n \"non-optional labelled argument or record expected\" )))\n | l ->\n List.map l ~f:(fun (label, expr) ->\n match label with\n | Labelled s -> (s, expr)\n | _ ->\n raise_notrace\n (Unknown_syntax\n (expr.pexp_loc, \"non-optional labelled argument expected\"))))\n with Unknown_syntax (loc, msg) -> Unknown_syntax (loc, msg)\n\nlet mk_deriving_attr context ~prefix ~suffix =\n Attribute.declare\n (prefix ^ \"deriving\" ^ suffix)\n context\n Ast_pattern.(\n let generator_name () =\n map' (pexp_ident __) ~f:(fun loc f id ->\n f (generator_name_of_id loc id))\n in\n let generator () =\n map (generator_name ()) ~f:(fun f x -> f (x, Args []))\n ||| pack2\n (pexp_apply (generator_name ())\n (map1 (many __) ~f:parse_arguments))\n in\n let generators =\n pexp_tuple (many (generator ()))\n ||| map (generator ()) ~f:(fun f x -> f [ x ])\n in\n pstr (pstr_eval generators nil ^:: nil))\n (fun x -> x)\n\n(* +-----------------------------------------------------------------+\n | Unused warning stuff + locations check silencing |\n +-----------------------------------------------------------------+ *)\n\nlet disable_warnings_attribute warnings =\n let loc = Location.none in\n let string =\n List.sort warnings ~cmp:Int.compare\n |> List.map ~f:(fun warning -> \"-\" ^ Int.to_string warning)\n |> String.concat ~sep:\"\"\n in\n {\n attr_name = { txt = \"ocaml.warning\"; loc };\n attr_payload = PStr [ pstr_eval ~loc (estring ~loc string) [] ];\n attr_loc = loc;\n }\n\nlet inline_doc_attr =\n let loc = Location.none in\n {\n attr_name = { txt = \"ocaml.doc\"; loc };\n attr_payload = PStr [ pstr_eval ~loc (estring ~loc \"@inline\") [] ];\n attr_loc = loc;\n }\n\nlet wrap_str ~loc ~hide st =\n let include_infos = include_infos ~loc (pmod_structure ~loc st) in\n let pincl_attributes =\n if hide then [ inline_doc_attr; Merlin_helpers.hide_attribute ]\n else [ inline_doc_attr ]\n in\n [ pstr_include ~loc { include_infos with pincl_attributes } ]\n\nlet wrap_str ~loc ~hide st =\n let loc = { loc with loc_ghost = true } in\n let warnings, st =\n if keep_w32_impl () then ([], st)\n else if not !do_insert_unused_warning_attribute then\n ([], Ignore_unused_warning.add_dummy_user_for_values#structure st)\n else ([ 32 ], st)\n in\n let warnings, st =\n if\n keep_w60_impl ()\n || not (Ignore_unused_warning.binds_module_names#structure st false)\n then (warnings, st)\n else (60 :: warnings, st)\n in\n let wrap, st =\n if List.is_empty warnings then (hide, st)\n else (true, pstr_attribute ~loc (disable_warnings_attribute warnings) :: st)\n in\n if wrap then wrap_str ~loc ~hide st else st\n\nlet wrap_sig ~loc ~hide st =\n let include_infos = include_infos ~loc (pmty_signature ~loc st) in\n let pincl_attributes =\n if hide then [ inline_doc_attr; Merlin_helpers.hide_attribute ]\n else [ inline_doc_attr ]\n in\n [ psig_include ~loc { include_infos with pincl_attributes } ]\n\nlet wrap_sig ~loc ~hide sg =\n let loc = { loc with loc_ghost = true } in\n let warnings = if keep_w32_intf () then [] else [ 32 ] in\n let warnings =\n if\n keep_w60_intf ()\n || not (Ignore_unused_warning.binds_module_names#signature sg false)\n then warnings\n else 60 :: warnings\n in\n let wrap, sg =\n if List.is_empty warnings then (hide, sg)\n else (true, psig_attribute ~loc (disable_warnings_attribute warnings) :: sg)\n in\n if wrap then wrap_sig ~loc ~hide sg else sg\n\n(* +-----------------------------------------------------------------+\n | Remove attributes used by syntax extensions |\n +-----------------------------------------------------------------+ *)\n(*\nlet remove generators =\n let attributes =\n List.concat_map generators ~f:(fun (_, actual_generators, _) ->\n List.concat_map actual_generators ~f:(fun (Generator.T g) -> g.attributes))\n in\n object\n inherit Ast_traverse.map\n\n (* Don't recurse through attributes and extensions *)\n method! attribute x = x\n method! extension x = x\n\n method! label_declaration ld =\n Attribute.remove_seen Attribute.Context.label_declaration attributes ld\n\n method! constructor_declaration cd =\n Attribute.remove_seen Attribute.Context.constructor_declaration attributes cd\n end\n*)\n(* +-----------------------------------------------------------------+\n | Main expansion |\n +-----------------------------------------------------------------+ *)\n\nlet types_used_by_deriving (tds : type_declaration list) : structure_item list =\n if keep_w32_impl () then []\n else\n List.map tds ~f:(fun td ->\n let typ = Common.core_type_of_type_declaration td in\n let loc = td.ptype_loc in\n pstr_value ~loc Nonrecursive\n [\n value_binding ~loc ~pat:(ppat_any ~loc)\n ~expr:\n (pexp_fun ~loc Nolabel None\n (ppat_constraint ~loc (ppat_any ~loc) typ)\n (eunit ~loc));\n ])\n\nlet merge_generators field l =\n List.filter_map l ~f:(fun x -> x) |> List.concat |> Deriver.resolve_all field\n\nlet expand_str_type_decls ~ctxt rec_flag tds values =\n let generators = merge_generators Deriver.Field.str_type_decl values in\n (* TODO: instead of disabling the unused warning for types themselves, we\n should add a tag [@@unused]. *)\n let generated =\n types_used_by_deriving tds\n @ Generator.apply_all ~ctxt (rec_flag, tds) generators\n in\n wrap_str\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_sig_type_decls ~ctxt rec_flag tds values =\n let generators = merge_generators Deriver.Field.sig_type_decl values in\n let generated = Generator.apply_all ~ctxt (rec_flag, tds) generators in\n wrap_sig\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_str_module_type_decl ~ctxt mtd generators =\n let generators =\n Deriver.resolve_all Deriver.Field.str_module_type_decl generators\n in\n let generated = Generator.apply_all ~ctxt mtd generators in\n wrap_str\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_sig_module_type_decl ~ctxt mtd generators =\n let generators =\n Deriver.resolve_all Deriver.Field.sig_module_type_decl generators\n in\n let generated = Generator.apply_all ~ctxt mtd generators in\n wrap_sig\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_str_exception ~ctxt ec generators =\n let generators = Deriver.resolve_all Deriver.Field.str_exception generators in\n let generated = Generator.apply_all ~ctxt ec generators in\n wrap_str\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_sig_exception ~ctxt ec generators =\n let generators = Deriver.resolve_all Deriver.Field.sig_exception generators in\n let generated = Generator.apply_all ~ctxt ec generators in\n wrap_sig\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_str_type_ext ~ctxt te generators =\n let generators = Deriver.resolve_all Deriver.Field.str_type_ext generators in\n let generated = Generator.apply_all ~ctxt te generators in\n wrap_str\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet expand_sig_type_ext ~ctxt te generators =\n let generators = Deriver.resolve_all Deriver.Field.sig_type_ext generators in\n let generated = Generator.apply_all ~ctxt te generators in\n wrap_sig\n ~loc:(Expansion_context.Deriver.derived_item_loc ctxt)\n ~hide:(not @@ Expansion_context.Deriver.inline ctxt)\n generated\n\nlet rules ~typ ~expand_sig ~expand_str ~rule_str ~rule_sig ~rule_str_expect\n ~rule_sig_expect =\n let prefix = \"ppxlib.\" in\n let deriving_attr = mk_deriving_attr ~suffix:\"\" ~prefix typ in\n let deriving_attr_expect = mk_deriving_attr ~suffix:\"_inline\" ~prefix typ in\n [\n rule_sig deriving_attr expand_sig;\n rule_str deriving_attr expand_str;\n rule_str_expect deriving_attr_expect expand_str;\n rule_sig_expect deriving_attr_expect expand_sig;\n ]\n\nlet rules_type_decl =\n rules ~typ:Type_declaration ~expand_str:expand_str_type_decls\n ~expand_sig:expand_sig_type_decls\n ~rule_str:Context_free.Rule.attr_str_type_decl\n ~rule_sig:Context_free.Rule.attr_sig_type_decl\n ~rule_str_expect:Context_free.Rule.attr_str_type_decl_expect\n ~rule_sig_expect:Context_free.Rule.attr_sig_type_decl_expect\n\nlet rules_type_ext =\n rules ~typ:Type_extension ~expand_str:expand_str_type_ext\n ~expand_sig:expand_sig_type_ext\n ~rule_str:Context_free.Rule.attr_str_type_ext\n ~rule_sig:Context_free.Rule.attr_sig_type_ext\n ~rule_str_expect:Context_free.Rule.attr_str_type_ext_expect\n ~rule_sig_expect:Context_free.Rule.attr_sig_type_ext_expect\n\nlet rules_exception =\n rules ~typ:Type_exception ~expand_str:expand_str_exception\n ~expand_sig:expand_sig_exception\n ~rule_str:Context_free.Rule.attr_str_exception\n ~rule_sig:Context_free.Rule.attr_sig_exception\n ~rule_str_expect:Context_free.Rule.attr_str_exception_expect\n ~rule_sig_expect:Context_free.Rule.attr_sig_exception_expect\n\nlet rules_module_type_decl =\n rules ~typ:Module_type_declaration ~expand_str:expand_str_module_type_decl\n ~expand_sig:expand_sig_module_type_decl\n ~rule_str:Context_free.Rule.attr_str_module_type_decl\n ~rule_sig:Context_free.Rule.attr_sig_module_type_decl\n ~rule_str_expect:Context_free.Rule.attr_str_module_type_decl_expect\n ~rule_sig_expect:Context_free.Rule.attr_sig_module_type_decl_expect\n\nlet () =\n let rules =\n [ rules_type_decl; rules_type_ext; rules_exception; rules_module_type_decl ]\n |> List.concat\n in\n Driver.register_transformation \"deriving\" ~aliases:[ \"type_conv\" ] ~rules\n","open! Import\n\ntype 'a or_raise =\n | Ok of 'a\n | Error of { fail : 'a. loc:location -> 'a }\n\ntype t = (string, expression or_raise, String.comparator_witness) Map.t\n\nlet empty = Map.empty (module String)\n\nlet lookup t ~loc ~tyvar =\n match Map.find t tyvar with\n | Some (Ok expr) -> expr\n | Some (Error { fail }) -> fail ~loc\n | None -> invalid ~loc \"unbound type variable: '%s\" tyvar\n;;\n\nlet of_alist ~loc alist =\n match Map.of_alist (module String) alist with\n | `Ok t -> t\n | `Duplicate_key name -> invalid ~loc \"duplicate type parameter: '%s\" name\n;;\n\nlet create ~loc ~prefix param_list =\n let pat_list, alist =\n List.map param_list ~f:(fun ((core_type, _) as param) ->\n let loc = core_type.ptyp_loc in\n let name = get_type_param_name param in\n let pat, expr = gensym prefix loc in\n pat, (name.txt, Ok expr))\n |> List.unzip\n in\n let t = of_alist ~loc alist in\n pat_list, t\n;;\n\nlet variance_error ~loc ~tyvar ~actual ~expect =\n invalid\n ~loc\n \"misuse of type variable '%s: would confuse %s with %s in generated code; could be \\\n due to a missing or incorrect covariance/contravariance annotation\"\n tyvar\n actual\n expect\n;;\n\nlet create_with_variance ~loc ~covariant ~contravariant param_list =\n let pat_list, by_variance_list =\n List.map param_list ~f:(fun ((core_type, (variance, injectivity)) as param) ->\n let loc = core_type.ptyp_loc in\n let name = get_type_param_name param in\n match (variance, injectivity) with\n | ((NoVariance | Covariant), NoInjectivity) ->\n let pat, expr = gensym covariant loc in\n pat, `Covariant (name.txt, expr)\n | (Contravariant, NoInjectivity) ->\n let pat, expr = gensym contravariant loc in\n pat, `Contravariant (name.txt, expr)\n | (_, Injective) -> Location.raise_errorf ~loc \"Injective type parameters aren't supported.\")\n |> List.unzip\n in\n let covariant_t =\n List.map by_variance_list ~f:(function\n | `Covariant (tyvar, expr) -> tyvar, Ok expr\n | `Contravariant (tyvar, _) ->\n let fail ~loc =\n variance_error ~loc ~tyvar ~expect:covariant ~actual:contravariant\n in\n tyvar, Error { fail })\n |> of_alist ~loc\n in\n let contravariant_t =\n List.map by_variance_list ~f:(function\n | `Contravariant (tyvar, expr) -> tyvar, Ok expr\n | `Covariant (tyvar, _) ->\n let fail ~loc =\n variance_error ~loc ~tyvar ~expect:contravariant ~actual:covariant\n in\n tyvar, Error { fail })\n |> of_alist ~loc\n in\n pat_list, `Covariant covariant_t, `Contravariant contravariant_t\n;;\n","open Core_kernel\n\nmodule Chunked = struct\n (** The input for a random oracle, formed of full field elements and 'chunks'\n of fields that can be combined together into one or more field elements.\n\n The chunks are represented as [(field, length)], where\n [0 <= field < 2^length]. This allows us to efficiently combine values in\n a known range. For example,\n{[\n { field_elements= [||]; packeds= [|(x, 64); (y, 32); (z, 16)|] }\n]}\n results in the chunks being combined as [x * 2^(32+16) + y * 2^(64) + z].\n When the chunks do not fit within a single field element, they are\n greedily concatenated to form field elements, from left to right.\n This packing is performed by the [pack_to_fields] helper function.\n *)\n type 'field t =\n { field_elements : 'field array; packeds : ('field * int) array }\n [@@deriving sexp, compare]\n\n let append (t1 : _ t) (t2 : _ t) =\n { field_elements = Array.append t1.field_elements t2.field_elements\n ; packeds = Array.append t1.packeds t2.packeds\n }\n\n let field_elements (a : 'f array) : 'f t =\n { field_elements = a; packeds = [||] }\n\n let field x : _ t = field_elements [| x |]\n\n (** An input [[|(x_1, l_1); (x_2, l_2); ...|]] includes the values\n [[|x_1; x_2; ...|]] in the input, assuming that `0 <= x_1 < 2^l_1`,\n `0 <= x_2 < 2^l_2`, etc. so that multiple [x_i]s can be combined into a\n single field element when the sum of their [l_i]s are less than the size\n of the field modulus (in bits).\n *)\n let packeds a = { field_elements = [||]; packeds = a }\n\n (** [packed x = packeds [| x |]] *)\n let packed xn : _ t = packeds [| xn |]\n\n module type Field_intf = sig\n type t\n\n val size_in_bits : int\n\n val zero : t\n\n val ( + ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n end\n\n (** Convert the input into a series of field elements, by concatenating\n any chunks of input that fit into a single field element.\n The concatenation is greedy, operating from left to right.\n *)\n let pack_to_fields (type t) (module F : Field_intf with type t = t)\n ~(pow2 : int -> t) { field_elements; packeds } =\n let shift_left acc n = F.( * ) acc (pow2 n) in\n let open F in\n let packed_bits =\n let xs, acc, acc_n =\n Array.fold packeds ~init:([], zero, 0)\n ~f:(fun (xs, acc, acc_n) (x, n) ->\n let n' = Int.(n + acc_n) in\n if Int.(n' < size_in_bits) then (xs, shift_left acc n + x, n')\n else (acc :: xs, x, n) )\n in\n (* if acc_n = 0, packeds was empty (or acc holds 0 bits) and we don't want to append 0 *)\n let xs = if acc_n > 0 then acc :: xs else xs in\n Array.of_list_rev xs\n in\n Array.append field_elements packed_bits\nend\n\nmodule Legacy = struct\n type ('field, 'bool) t =\n { field_elements : 'field array; bitstrings : 'bool list array }\n [@@deriving sexp, compare]\n\n let append t1 t2 =\n { field_elements = Array.append t1.field_elements t2.field_elements\n ; bitstrings = Array.append t1.bitstrings t2.bitstrings\n }\n\n let field_elements x = { field_elements = x; bitstrings = [||] }\n\n let field x = { field_elements = [| x |]; bitstrings = [||] }\n\n let bitstring x = { field_elements = [||]; bitstrings = [| x |] }\n\n let bitstrings x = { field_elements = [||]; bitstrings = x }\n\n let pack_bits ~max_size ~pack { field_elements = _; bitstrings } =\n let rec pack_full_fields rev_fields bits length =\n if length >= max_size then\n let field_bits, bits = List.split_n bits max_size in\n pack_full_fields (pack field_bits :: rev_fields) bits (length - max_size)\n else (rev_fields, bits, length)\n in\n let packed_field_elements, remaining_bits, remaining_length =\n Array.fold bitstrings ~init:([], [], 0)\n ~f:(fun (acc, bits, n) bitstring ->\n let n = n + List.length bitstring in\n let bits = bits @ bitstring in\n let acc, bits, n = pack_full_fields acc bits n in\n (acc, bits, n) )\n in\n if remaining_length = 0 then packed_field_elements\n else pack remaining_bits :: packed_field_elements\n\n let pack_to_fields ~size_in_bits ~pack { field_elements; bitstrings } =\n let max_size = size_in_bits - 1 in\n let packed_bits =\n pack_bits ~max_size ~pack { field_elements; bitstrings }\n in\n Array.append field_elements (Array.of_list_rev packed_bits)\n\n let to_bits ~unpack { field_elements; bitstrings } =\n let field_bits = Array.map ~f:unpack field_elements in\n List.concat @@ Array.to_list @@ Array.append field_bits bitstrings\n\n module Coding = struct\n (** See https://github.com/CodaProtocol/coda/blob/develop/rfcs/0038-rosetta-construction-api.md for details on schema *)\n\n (** Serialize a random oracle input with 32byte fields into bytes according to the RFC0038 specification *)\n let serialize ~string_of_field ~to_bool ~of_bool t =\n let len_to_string x =\n String.of_char_list\n Char.\n [ of_int_exn @@ ((x lsr 24) land 0xff)\n ; of_int_exn @@ ((x lsr 16) land 0xff)\n ; of_int_exn @@ ((x lsr 8) land 0xff)\n ; of_int_exn @@ (x land 0xff)\n ]\n in\n let len1 = len_to_string @@ Array.length t.field_elements in\n let fields =\n (* We only support 32byte fields *)\n let () =\n if Array.length t.field_elements > 0 then\n assert (String.length (string_of_field t.field_elements.(0)) = 32)\n else ()\n in\n Array.map t.field_elements ~f:string_of_field |> String.concat_array\n in\n let len2 =\n len_to_string\n @@ Array.sum (module Int) t.bitstrings ~f:(fun x -> List.length x)\n in\n let packed =\n pack_bits t ~max_size:8 ~pack:(fun bs ->\n let rec go i acc = function\n | [] ->\n acc\n | b :: bs ->\n go (i + 1) ((acc * 2) + if to_bool b then 1 else 0) bs\n in\n let pad =\n List.init (8 - List.length bs) ~f:(Fn.const (of_bool false))\n in\n let combined = bs @ pad in\n assert (List.length combined = 8) ;\n go 0 0 combined )\n |> List.map ~f:Char.of_int_exn\n |> List.rev |> String.of_char_list\n in\n len1 ^ fields ^ len2 ^ packed\n\n module Parser = struct\n (* TODO: Before using this too much; use a solid parser library instead or beef this one up with more debugging info *)\n\n (* The parser is a function over this monad-fail *)\n module M = Result\n\n module T = struct\n type ('a, 'e) t = char list -> ('a * char list, 'e) M.t\n\n let return a cs = M.return (a, cs)\n\n let bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t =\n fun t ~f cs ->\n let open M.Let_syntax in\n let%bind a, rest = t cs in\n f a rest\n\n let map = `Define_using_bind\n end\n\n include Monad.Make2 (T)\n\n let run p cs =\n p cs\n |> M.bind ~f:(fun (a, cs') ->\n match cs' with [] -> M.return a | _ -> M.fail `Expected_eof )\n\n let fail why _ = M.fail why\n\n let char c = function\n | c' :: cs when Char.equal c c' ->\n M.return (c', cs)\n | c' :: _ ->\n M.fail (`Unexpected_char c')\n | [] ->\n M.fail `Unexpected_eof\n\n let u8 = function\n | c :: cs ->\n M.return (c, cs)\n | [] ->\n M.fail `Unexpected_eof\n\n let u32 =\n let open Let_syntax in\n let open Char in\n let%map a = u8 and b = u8 and c = u8 and d = u8 in\n (to_int a lsl 24)\n lor (to_int b lsl 16)\n lor (to_int c lsl 8)\n lor to_int d\n\n let eof = function [] -> M.return ((), []) | _ -> M.fail `Expected_eof\n\n let take n cs =\n if List.length cs < n then M.fail `Unexpected_eof\n else M.return (List.split_n cs n)\n\n (** p zero or more times, never fails *)\n let many p =\n (fun cs ->\n let rec go xs acc =\n match p xs with\n | Ok (a, xs) ->\n go xs (a :: acc)\n | Error _ ->\n (acc, xs)\n in\n M.return @@ go cs [] )\n |> map ~f:List.rev\n\n let%test_unit \"many\" =\n [%test_eq: (char list, [ `Expected_eof ]) Result.t]\n (run (many u8) [ 'a'; 'b'; 'c' ])\n (Result.return [ 'a'; 'b'; 'c' ])\n\n (** p exactly n times *)\n let exactly n p =\n (fun cs ->\n let rec go xs acc = function\n | 0 ->\n M.return (acc, xs)\n | i ->\n let open M.Let_syntax in\n let%bind a, xs = p xs in\n go xs (a :: acc) (i - 1)\n in\n go cs [] n )\n |> map ~f:List.rev\n\n let%test_unit \"exactly\" =\n [%test_eq:\n (char list * char list, [ `Expected_eof | `Unexpected_eof ]) Result.t]\n ((exactly 3 u8) [ 'a'; 'b'; 'c'; 'd' ])\n (Result.return ([ 'a'; 'b'; 'c' ], [ 'd' ]))\n\n let return_res r cs = r |> Result.map ~f:(fun x -> (x, cs))\n end\n\n let bits_of_byte ~of_bool b =\n let b = Char.to_int b in\n let f x =\n of_bool\n ( match x with\n | 0 ->\n false\n | 1 ->\n true\n | _ ->\n failwith \"Unexpected boolean integer\" )\n in\n [ (b land (0x1 lsl 7)) lsr 7\n ; (b land (0x1 lsl 6)) lsr 6\n ; (b land (0x1 lsl 5)) lsr 5\n ; (b land (0x1 lsl 4)) lsr 4\n ; (b land (0x1 lsl 3)) lsr 3\n ; (b land (0x1 lsl 2)) lsr 2\n ; (b land (0x1 lsl 1)) lsr 1\n ; b land 0x1\n ]\n |> List.map ~f\n\n (** Deserialize bytes into a random oracle input with 32byte fields according to the RFC0038 specification *)\n let deserialize ~field_of_string ~of_bool s =\n let field =\n let open Parser.Let_syntax in\n let%bind u8x32 = Parser.take 32 in\n let s = String.of_char_list u8x32 in\n Parser.return_res (field_of_string s)\n in\n let parser =\n let open Parser.Let_syntax in\n let%bind len1 = Parser.u32 in\n let%bind fields = Parser.exactly len1 field in\n let%bind len2 = Parser.u32 in\n let%map bytes = Parser.(many u8) in\n let bits = List.concat_map ~f:(bits_of_byte ~of_bool) bytes in\n let bitstring = List.take bits len2 in\n { field_elements = Array.of_list fields; bitstrings = [| bitstring |] }\n in\n Parser.run parser s\n\n (** String of field as bits *)\n let string_of_field xs =\n List.chunks_of xs ~length:8\n |> List.map ~f:(fun xs ->\n let rec go i acc = function\n | [] ->\n acc\n | b :: bs ->\n go (i + 1) ((acc * 2) + if b then 1 else 0) bs\n in\n let pad = List.init (8 - List.length xs) ~f:(Fn.const false) in\n let combined = xs @ pad in\n assert (List.length combined = 8) ;\n go 0 0 combined )\n |> List.map ~f:Char.of_int_exn\n |> String.of_char_list\n\n (** Field of string as bits *)\n let field_of_string s ~size_in_bits =\n List.concat_map (String.to_list s) ~f:(bits_of_byte ~of_bool:Fn.id)\n |> Fn.flip List.take size_in_bits\n |> Result.return\n end\n\n (** Coding2 is an alternate binary coding setup where we pass two arrays of\n * field elements instead of a single structure to simplify manipulation\n * outside of the Mina construction API\n *\n * This is described as the second mechanism for coding Random_oracle_input in\n * RFC0038\n *\n*)\n module Coding2 = struct\n module Rendered = struct\n (* as bytes, you must hex this later *)\n type 'field t_ = { prefix : 'field array; suffix : 'field array }\n [@@deriving yojson]\n\n type t = string t_ [@@deriving yojson]\n\n let map ~f { prefix; suffix } =\n { prefix = Array.map ~f prefix; suffix = Array.map ~f suffix }\n end\n\n let string_of_field : bool list -> string = Coding.string_of_field\n\n let field_of_string = Coding.field_of_string\n\n let serialize' t ~pack =\n { Rendered.prefix = t.field_elements\n ; suffix = pack_bits ~max_size:254 ~pack t |> Array.of_list_rev\n }\n\n let serialize t ~string_of_field ~pack =\n let () =\n if Array.length t.field_elements > 0 then\n assert (String.length (string_of_field t.field_elements.(0)) = 32)\n else ()\n in\n serialize' t ~pack |> Rendered.map ~f:string_of_field\n end\n\n let%test_module \"random_oracle input\" =\n ( module struct\n let gen_field ~size_in_bits =\n let open Quickcheck.Generator in\n list_with_length size_in_bits bool\n\n let gen_input ?size_in_bits () =\n let open Quickcheck.Generator in\n let open Let_syntax in\n let%bind size_in_bits =\n size_in_bits |> Option.map ~f:return\n |> Option.value ~default:(Int.gen_incl 2 3000)\n in\n let%bind field_elements =\n (* Treat a field as a list of bools of length [size_in_bits]. *)\n list (gen_field ~size_in_bits)\n in\n let%map bitstrings = list (list bool) in\n ( size_in_bits\n , { field_elements = Array.of_list field_elements\n ; bitstrings = Array.of_list bitstrings\n } )\n\n let%test_unit \"coding2 equiv to hash directly\" =\n let size_in_bits = 255 in\n let field = gen_field ~size_in_bits in\n Quickcheck.test ~trials:300\n Quickcheck.Generator.(\n tuple2 (gen_input ~size_in_bits ()) (tuple2 field field))\n ~f:(fun ((_, input), (x, y)) ->\n let middle = [| x; y |] in\n let expected =\n append input (field_elements middle)\n |> pack_to_fields ~size_in_bits ~pack:Fn.id\n in\n let { Coding2.Rendered.prefix; suffix } =\n Coding2.serialize' input ~pack:Fn.id\n in\n let actual = Array.(concat [ prefix; middle; suffix ]) in\n [%test_eq: bool list array] expected actual )\n\n let%test_unit \"field/string partial isomorphism bitstrings\" =\n Quickcheck.test ~trials:300\n Quickcheck.Generator.(list_with_length 255 bool)\n ~f:(fun input ->\n let serialized = Coding.string_of_field input in\n let deserialized =\n Coding.field_of_string serialized ~size_in_bits:255\n in\n [%test_eq: (bool list, unit) Result.t] (input |> Result.return)\n deserialized )\n\n let%test_unit \"serialize/deserialize partial isomorphism 32byte fields\" =\n let size_in_bits = 255 in\n Quickcheck.test ~trials:3000 (gen_input ~size_in_bits ())\n ~f:(fun (_, input) ->\n let serialized =\n Coding.(\n serialize ~string_of_field ~to_bool:Fn.id ~of_bool:Fn.id input)\n in\n let deserialized =\n Coding.(\n deserialize\n (String.to_list serialized)\n ~field_of_string:(field_of_string ~size_in_bits)\n ~of_bool:Fn.id)\n in\n let normalized t =\n { t with\n bitstrings =\n ( t.bitstrings |> Array.to_list |> List.concat\n |> fun xs -> [| xs |] )\n }\n in\n assert (\n Array.for_all input.field_elements ~f:(fun el ->\n List.length el = size_in_bits ) ) ;\n Result.iter deserialized ~f:(fun x ->\n assert (\n Array.for_all x.field_elements ~f:(fun el ->\n List.length el = size_in_bits ) ) ) ;\n [%test_eq:\n ( (bool list, bool) t\n , [ `Expected_eof | `Unexpected_eof ] )\n Result.t]\n (normalized input |> Result.return)\n (deserialized |> Result.map ~f:normalized) )\n\n let%test_unit \"data is preserved by to_bits\" =\n Quickcheck.test ~trials:300 (gen_input ())\n ~f:(fun (size_in_bits, input) ->\n let bits = to_bits ~unpack:Fn.id input in\n let bools_equal = [%equal: bool list] in\n (* Fields are accumulated at the front, check them first. *)\n let bitstring_bits =\n Array.fold ~init:bits input.field_elements ~f:(fun bits field ->\n (* The next chunk of [size_in_bits] bits is for the field\n element.\n *)\n let field_bits, rest = List.split_n bits size_in_bits in\n assert (bools_equal field_bits field) ;\n rest )\n in\n (* Bits come after. *)\n let remaining_bits =\n Array.fold ~init:bitstring_bits input.bitstrings\n ~f:(fun bits bitstring ->\n (* The next bits match the bitstring. *)\n let bitstring_bits, rest =\n List.split_n bits (List.length bitstring)\n in\n assert (bools_equal bitstring_bits bitstring) ;\n rest )\n in\n (* All bits should have been consumed. *)\n assert (List.is_empty remaining_bits) )\n\n let%test_unit \"data is preserved by pack_to_fields\" =\n Quickcheck.test ~trials:300 (gen_input ())\n ~f:(fun (size_in_bits, input) ->\n let fields = pack_to_fields ~size_in_bits ~pack:Fn.id input in\n (* Fields are accumulated at the front, check them first. *)\n let fields = Array.to_list fields in\n let bitstring_fields =\n Array.fold ~init:fields input.field_elements\n ~f:(fun fields input_field ->\n (* The next field element should be the literal field element\n passed in.\n *)\n match fields with\n | [] ->\n failwith \"Too few field elements\"\n | field :: rest ->\n assert ([%equal: bool list] field input_field) ;\n rest )\n in\n (* Check that the remaining fields have the correct size. *)\n let final_field_idx = List.length bitstring_fields - 1 in\n List.iteri bitstring_fields ~f:(fun i field_bits ->\n if i < final_field_idx then\n (* This field should be densely packed, but should contain\n fewer bits than the maximum field element to ensure that it\n doesn't overflow, so we expect [size_in_bits - 1] bits for\n maximum safe density.\n *)\n assert (List.length field_bits = size_in_bits - 1)\n else (\n (* This field will be comprised of the remaining bits, up to a\n maximum of [size_in_bits - 1]. It should not be empty.\n *)\n assert (not (List.is_empty field_bits)) ;\n assert (List.length field_bits < size_in_bits) ) ) ;\n let rec go input_bitstrings packed_fields =\n match (input_bitstrings, packed_fields) with\n | [], [] ->\n (* We have consumed all bitstrings and fields in parallel, with\n no bits left over. Success.\n *)\n ()\n | [] :: input_bitstrings, packed_fields\n | input_bitstrings, [] :: packed_fields ->\n (* We have consumed the whole of an input bitstring or the whole\n of a packed field, move onto the next one.\n *)\n go input_bitstrings packed_fields\n | ( (bi :: input_bitstring) :: input_bitstrings\n , (bp :: packed_field) :: packed_fields ) ->\n (* Consume the next bit from the next input bitstring, and the\n next bit from the next packed field. They must match.\n *)\n assert (Bool.equal bi bp) ;\n go\n (input_bitstring :: input_bitstrings)\n (packed_field :: packed_fields)\n | [], _ ->\n failwith \"Packed fields contain more bits than were provided\"\n | _, [] ->\n failwith\n \"There are input bits that were not present in the packed \\\n fields\"\n in\n (* Check that the bits match between the input bitstring and the\n remaining fields.\n *)\n go (Array.to_list input.bitstrings) bitstring_fields )\n end )\nend\n","open Core_kernel\n\n[@@@warning \"-4\"] (* sexp-related fragile pattern-matching warning *)\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Pickles_base.Proofs_verified.V1.t = N0 | N1 | N2\n [@@deriving sexp, compare, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\nend]\n\n[@@@warning \"+4\"]\n\nlet to_int : t -> int = function N0 -> 0 | N1 -> 1 | N2 -> 2\n\n(** Inside the circuit, we use two different representations for this type,\n depending on what we need it for.\n\n Sometimes, we use it for masking out a list of 2 points by taking the\n a prefix of length 0, 1, or 2. In this setting, we we will represent a value\n of this type as a sequence of 2 bits like so:\n 00: N0\n 10: N1\n 11: N2\n\n We call this a **prefix mask**.\n\n Sometimes, we use it to select something from a list of 3 values. In this\n case, we will represent a value of this type as a sequence of 3 bits like so:\n\n 100: N0\n 010: N1\n 001: N2\n\n We call this a **one-hot vector** as elsewhere.\n*)\n\ntype proofs_verified = t\n\nlet of_nat (type n) (n : n Pickles_types.Nat.t) : t =\n let open Pickles_types.Nat in\n match n with\n | Z ->\n N0\n | S Z ->\n N1\n | S (S Z) ->\n N2\n | S _ ->\n failwithf \"Proofs_verified.of_nat: got %d\" (to_int n) ()\n\nlet of_int (n : int) : t =\n match n with\n | 0 ->\n N0\n | 1 ->\n N1\n | 2 ->\n N2\n | _ ->\n failwithf \"Proofs_verified.of_int: got %d\" n ()\n\ntype 'f boolean = 'f Snarky_backendless.Cvar.t Snarky_backendless.Boolean.t\n\ntype 'a vec2 = ('a, Pickles_types.Nat.N2.n) Pickles_types.Vector.t\n\nmodule Prefix_mask = struct\n module Checked = struct\n type 'f t = 'f boolean vec2\n end\n\n let[@warning \"-40-42\"] there : proofs_verified -> bool vec2 = function\n | N0 ->\n [ false; false ]\n | N1 ->\n [ false; true ]\n | N2 ->\n [ true; true ]\n\n let[@warning \"-40-42\"] back : bool vec2 -> proofs_verified = function\n | [ false; false ] ->\n N0\n | [ false; true ] ->\n N1\n | [ true; true ] ->\n N2\n | [ true; false ] ->\n invalid_arg \"Prefix_mask.back: invalid mask [false; true]\"\n\n let typ (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) :\n (f Checked.t, proofs_verified) Impl.Typ.t =\n let open Impl in\n Typ.transport\n (Pickles_types.Vector.typ Boolean.typ Pickles_types.Nat.N2.n)\n ~there ~back\nend\n\nmodule One_hot = struct\n module Checked = struct\n type 'f t = ('f, Pickles_types.Nat.N3.n) One_hot_vector.t\n\n let to_input (type f) (t : f t) =\n Random_oracle_input.Chunked.packeds\n (Array.map\n Pickles_types.(Vector.to_array (t :> (f boolean, Nat.N3.n) Vector.t))\n ~f:(fun b -> ((b :> f Snarky_backendless.Cvar.t), 1)) )\n end\n\n let there : proofs_verified -> int = function N0 -> 0 | N1 -> 1 | N2 -> 2\n\n let back : int -> proofs_verified = function\n | 0 ->\n N0\n | 1 ->\n N1\n | 2 ->\n N2\n | _ ->\n failwith \"Invalid mask\"\n\n let to_input ~zero ~one (t : t) =\n let one_hot =\n match t with\n | N0 ->\n [| one; zero; zero |]\n | N1 ->\n [| zero; one; zero |]\n | N2 ->\n [| zero; zero; one |]\n in\n Random_oracle_input.Chunked.packeds (Array.map one_hot ~f:(fun b -> (b, 1)))\n\n let typ (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) :\n (f Checked.t, proofs_verified) Impl.Typ.t =\n let module M = One_hot_vector.Make (Impl) in\n let open Impl in\n Typ.transport (M.typ Pickles_types.Nat.N3.n) ~there ~back\nend\n","open Core_kernel\nopen Pickles_types\n\nlet bits ~len n = List.init len ~f:(fun i -> (n lsr i) land 1 = 1)\n\nlet max_log2_degree = 32\n\nmodule Width : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n val of_int_exn : int -> t\n\n val to_int : t -> int\n\n val to_bits : t -> bool list\n\n val zero : t\n\n module Max = Nat.N2\n\n module Max_vector : Vector.With_version(Max).S\n\n module Max_at_most : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type 'a t = ('a, Max.n) At_most.t\n [@@deriving compare, sexp, yojson, hash, equal]\n end\n end]\n end\n\n module Length : Nat.Add.Intf_transparent\nend = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = char [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let zero = Char.of_int_exn 0\n\n module Max = Nat.N2\n\n (* Think about versioning here! These vector types *will* change\n serialization if the numbers above change, and so will require a new\n version number. Thus, it's important that these are modules with new\n versioned types, and not just module aliases to the corresponding vector\n implementation.\n *)\n module Max_vector = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = 'a Vector.Vector_2.Stable.V1.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n type 'a t = 'a Vector.Vector_2.t\n [@@deriving compare, yojson, sexp, hash, equal]\n\n let map = Vector.map\n\n let of_list_exn = Vector.Vector_2.of_list_exn\n\n let to_list = Vector.to_list\n end\n\n module Max_at_most = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = 'a At_most.At_most_2.Stable.V1.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n type 'a t = 'a At_most.At_most_2.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n\n module Length = Nat.N4\n\n let to_int = Char.to_int\n\n let to_bits = Fn.compose (bits ~len:(Nat.to_int Length.n)) to_int\n\n let of_int_exn : int -> t =\n let m = Nat.to_int Max.n in\n fun n ->\n assert (n <= m) ;\n Char.of_int_exn n\nend\n\nmodule Max_branches = struct\n include Nat.N8\n module Log2 = Nat.N3\nend\n\n(* TODO: remove since it looks very much like the Domains module in the same directory *)\nmodule Domains = struct\n [@@@warning \"-40-42\"]\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = { h : 'a }\n [@@deriving sexp, equal, compare, hash, yojson, hlist, fields]\n end\n end]\nend\n\nmodule Repr = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type 'g t =\n { max_proofs_verified : Proofs_verified.Stable.V1.t\n ; actual_wrap_domain_size : Proofs_verified.Stable.V1.t\n ; wrap_index : 'g Plonk_verification_key_evals.Stable.V2.t\n }\n [@@deriving sexp, equal, compare, yojson]\n end\n end]\nend\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('g, 'proofs_verified, 'vk) t =\n ( 'g\n , 'proofs_verified\n , 'vk )\n Mina_wire_types.Pickles_base.Side_loaded_verification_key.Poly.V2.t =\n { max_proofs_verified : 'proofs_verified\n ; actual_wrap_domain_size : 'proofs_verified\n ; wrap_index : 'g Plonk_verification_key_evals.Stable.V2.t\n ; wrap_vk : 'vk option\n }\n [@@deriving hash]\n end\n end]\nend\n\nlet index_to_field_elements (k : 'a Plonk_verification_key_evals.t) ~g =\n let Plonk_verification_key_evals.\n { sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n } =\n k\n in\n List.map\n ( Vector.to_list sigma_comm\n @ Vector.to_list coefficients_comm\n @ [ generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n ] )\n ~f:g\n |> Array.concat\n\nlet wrap_index_to_input (type gs f) (g : gs -> f array) t =\n Random_oracle_input.Chunked.field_elements (index_to_field_elements t ~g)\n\nlet to_input (type a) ~(field_of_int : int -> a) :\n (a * a, _, _) Poly.t -> a Random_oracle_input.Chunked.t =\n let open Random_oracle_input.Chunked in\n fun Poly.\n { max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index\n ; wrap_vk = _\n } : _ Random_oracle_input.Chunked.t ->\n List.reduce_exn ~f:append\n [ Proofs_verified.One_hot.to_input ~zero:(field_of_int 0)\n ~one:(field_of_int 1) max_proofs_verified\n ; Proofs_verified.One_hot.to_input ~zero:(field_of_int 0)\n ~one:(field_of_int 1) actual_wrap_domain_size\n ; wrap_index_to_input\n (Fn.compose Array.of_list (fun (x, y) -> [ x; y ]))\n wrap_index\n ]\n","open Core_kernel\n\n[@@@warning \"-4\"] (* sexp-related fragile pattern-matching warning *)\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = Pow_2_roots_of_unity of int\n [@@unboxed] [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\n[@@@warning \"+4\"]\n\ninclude Hashable.Make (Stable.Latest)\n\nlet log2_size (Pow_2_roots_of_unity k) = k\n\nlet size t = 1 lsl log2_size t\n","(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Pickles_composition_types.Branch_data\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Branch_data_intf.S\n with type Domain_log2.Stable.V1.t = A.Domain_log2.V1.t\n and type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n (** Data specific to a branch of a proof-system that's necessary for\n finalizing the deferred-values in a wrap proof of that branch. *)\n\n module Proofs_verified = Pickles_base.Proofs_verified\n\n module Domain_log2 = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = char [@@deriving compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n let of_int_exn : int -> t = Char.of_int_exn\n\n let of_bits_msb (bs : bool list) : t =\n List.fold bs ~init:0 ~f:(fun acc b ->\n let acc = acc lsl 1 in\n if b then acc + 1 else acc )\n |> of_int_exn\n\n let of_field_exn (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n (x : f) : t =\n Impl.Field.Constant.unpack x\n |> Fn.flip List.take 8 |> List.rev |> of_bits_msb\n end\n\n (* We pack this into a single field element as follows:\n First 2 bits: proofs_verified\n Next 8 bits: domain_log2 *)\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = A.V1.t =\n { proofs_verified : Proofs_verified.Stable.V1.t\n ; domain_log2 : Domain_log2.Stable.V1.t\n }\n [@@deriving hlist, compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n let length_in_bits = 10\n\n let pack (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ({ proofs_verified; domain_log2 } : t) : f =\n let open Impl.Field.Constant in\n let double x = x + x in\n let times4 x = double (double x) in\n let domain_log2 = of_int (Char.to_int domain_log2) in\n (* shift domain_log2 over by 2 bits (multiply by 4) *)\n times4 domain_log2\n + project\n (Pickles_types.Vector.to_list\n (Proofs_verified.Prefix_mask.there proofs_verified) )\n\n let unpack (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n (x : f) : t =\n match Impl.Field.Constant.unpack x with\n | x0 :: x1 :: y0 :: y1 :: y2 :: y3 :: y4 :: y5 :: y6 :: y7 :: _ ->\n { proofs_verified = Proofs_verified.Prefix_mask.back [ x0; x1 ]\n ; domain_log2 =\n Domain_log2.of_bits_msb [ y7; y6; y5; y4; y3; y2; y1; y0 ]\n }\n | _ ->\n assert false\n\n module Checked = struct\n type 'f t =\n { proofs_verified_mask : 'f Proofs_verified.Prefix_mask.Checked.t\n ; domain_log2 : 'f Snarky_backendless.Cvar.t\n }\n [@@deriving hlist]\n\n let pack (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ({ proofs_verified_mask; domain_log2 } : f t) : Impl.Field.t =\n let open Impl.Field in\n let four = of_int 4 in\n (four * domain_log2)\n + pack (Pickles_types.Vector.to_list proofs_verified_mask)\n end\n\n let packed_typ (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) =\n Impl.Typ.transport Impl.Typ.field\n ~there:(pack (module Impl))\n ~back:(unpack (module Impl))\n\n let typ (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ~(* We actually only need it to be less than 252 bits in order to pack\n the whole branch_data struct safely, but it's cheapest to check that it's\n under 16 bits *)\n (assert_16_bits : Impl.Field.t -> unit) : (f Checked.t, t) Impl.Typ.t =\n let open Impl in\n let proofs_verified_mask :\n (f Proofs_verified.Prefix_mask.Checked.t, Proofs_verified.t) Typ.t =\n Proofs_verified.Prefix_mask.typ (module Impl)\n in\n let domain_log2 : (Field.t, Domain_log2.t) Typ.t =\n let (Typ t) =\n Typ.transport Field.typ\n ~there:(fun (x : char) -> Field.Constant.of_int (Char.to_int x))\n ~back:(Domain_log2.of_field_exn (module Impl))\n in\n let check (x : Field.t) = make_checked (fun () -> assert_16_bits x) in\n Typ { t with check }\n in\n Typ.of_hlistable\n [ proofs_verified_mask; domain_log2 ]\n ~value_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n\n let domain { domain_log2; _ } =\n Pickles_base.Domain.Pow_2_roots_of_unity (Char.to_int domain_log2)\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","[%%versioned\nmodule Stable = struct\n module V1 = struct\n type 'challenge t =\n 'challenge Mina_wire_types.Pickles_bulletproof_challenge.V1.t =\n { prechallenge : 'challenge }\n [@@deriving sexp, compare, yojson, hash, equal]\n end\nend]\n\nlet pack { prechallenge } = prechallenge\n\nlet unpack prechallenge = { prechallenge }\n\nlet map { prechallenge } ~f = { prechallenge = f prechallenge }\n\nlet typ chal =\n let there = pack in\n let back = unpack in\n let open Snarky_backendless in\n Typ.transport ~there ~back (Kimchi_backend_common.Scalar_challenge.typ chal)\n |> Typ.transport_var ~there ~back\n","open Pickles_types\nmodule Scalar_challenge = Kimchi_backend_common.Scalar_challenge\nmodule Bulletproof_challenge = Bulletproof_challenge\nmodule Branch_data = Branch_data\nmodule Digest = Digest\nmodule Spec = Spec\nmodule Opt = Opt\nopen Core_kernel\n\ntype 'f impl = 'f Spec.impl\n\nlet index_to_field_elements =\n Pickles_base.Side_loaded_verification_key.index_to_field_elements\n\nmodule Zero_values = struct\n type ('chal, 'fp) single = { challenge : 'chal; scalar : 'fp }\n\n type ('chal, 'chal_var, 'fp, 'fp_var) t =\n { value : ('chal, 'fp) single; var : ('chal_var, 'fp_var) single }\nend\n\nmodule Wrap = struct\n module Proof_state = struct\n (** This module contains structures which contain the scalar-field elements that\n are required to finalize the verification of a proof that is partially verified inside\n a circuit.\n\n Each verifier circuit starts by verifying the parts of a proof involving group operations.\n At the end, there is a sequence of scalar-field computations it must perform. Instead of\n performing them directly, it exposes the values needed for those computations as a part of\n its own public-input, so that the next circuit can do them (since it will use the other curve on the cycle,\n and hence can efficiently perform computations in that scalar field). *)\n module Deferred_values = struct\n module Plonk = struct\n module Minimal = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n (** Challenges from the PLONK IOP. These, plus the evaluations that are already in the proof, are\n all that's needed to derive all the values in the [In_circuit] version below.\n\n See src/lib/pickles/plonk_checks/plonk_checks.ml for the computation of the [In_circuit] value\n from the [Minimal] value.\n *)\n type ('challenge, 'scalar_challenge, 'bool) t =\n ( 'challenge\n , 'scalar_challenge\n , 'bool )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state\n .Deferred_values\n .Plonk\n .Minimal\n .V1\n .t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n ; joint_combiner : 'scalar_challenge option\n ; feature_flags : 'bool Plonk_types.Features.Stable.V1.t\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n let map_challenges t ~f ~scalar =\n { t with\n alpha = scalar t.alpha\n ; beta = f t.beta\n ; gamma = f t.gamma\n ; zeta = scalar t.zeta\n ; joint_combiner = Option.map ~f:scalar t.joint_combiner\n }\n\n module In_circuit = struct\n type ('challenge, 'scalar_challenge, 'bool) t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n ; joint_combiner : ('scalar_challenge, 'bool) Opt.t\n ; feature_flags : 'bool Plonk_types.Features.t\n }\n end\n end\n\n open Pickles_types\n\n module In_circuit = struct\n (** All scalar values deferred by a verifier circuit.\n We expose them so the next guy (who can do scalar arithmetic) can check that they\n were computed correctly from the evaluations in the proof and the challenges.\n *)\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'scalar_challenge_opt\n , 'bool )\n t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n (* TODO: zeta_to_srs_length is kind of unnecessary.\n Try to get rid of it when you can.\n *)\n ; zeta_to_srs_length : 'fp\n ; zeta_to_domain_size : 'fp\n ; perm : 'fp\n (** scalar used on one of the permutation polynomial commitments. *)\n ; feature_flags : 'bool Plonk_types.Features.t\n ; joint_combiner : 'scalar_challenge_opt\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal, fields]\n\n let map_challenges t ~f ~scalar =\n { t with\n alpha = scalar t.alpha\n ; beta = f t.beta\n ; gamma = f t.gamma\n ; joint_combiner = Opt.map ~f:scalar t.joint_combiner\n ; zeta = scalar t.zeta\n }\n\n let map_fields t ~f =\n { t with\n zeta_to_srs_length = f t.zeta_to_srs_length\n ; zeta_to_domain_size = f t.zeta_to_domain_size\n ; perm = f t.perm\n }\n\n let typ (type f fp)\n (module Impl : Snarky_backendless.Snark_intf.Run\n with type field = f ) ~dummy_scalar_challenge ~challenge\n ~scalar_challenge ~bool\n ~feature_flags:\n ({ Plonk_types.Features.Full.uses_lookups; _ } as feature_flags)\n (fp : (fp, _, f) Snarky_backendless.Typ.t) =\n Snarky_backendless.Typ.of_hlistable\n [ Scalar_challenge.typ scalar_challenge\n ; challenge\n ; challenge\n ; Scalar_challenge.typ scalar_challenge\n ; fp\n ; fp\n ; fp\n ; Plonk_types.Features.typ\n ~feature_flags:(Plonk_types.Features.of_full feature_flags)\n bool\n ; Opt.typ Impl.Boolean.typ uses_lookups\n ~dummy:dummy_scalar_challenge\n (Scalar_challenge.typ scalar_challenge)\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n end\n\n let to_minimal (type challenge scalar_challenge fp fp_opt lookup_opt)\n (t :\n ( challenge\n , scalar_challenge\n , fp\n , fp_opt\n , lookup_opt\n , 'bool )\n In_circuit.t ) ~(to_option : lookup_opt -> scalar_challenge option)\n : (challenge, scalar_challenge, 'bool) Minimal.t =\n { alpha = t.alpha\n ; beta = t.beta\n ; zeta = t.zeta\n ; gamma = t.gamma\n ; joint_combiner = to_option t.joint_combiner\n ; feature_flags = t.feature_flags\n }\n end\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n (** All the deferred values needed, comprising values from the PLONK IOP verification,\n values from the inner-product argument, and [which_branch] which is needed to know\n the proper domain to use. *)\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n t =\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state\n .Deferred_values\n .V1\n .t =\n { plonk : 'plonk\n ; combined_inner_product : 'fp\n (** combined_inner_product = sum_{i < num_evaluation_points} sum_{j < num_polys} r^i xi^j f_j(pt_i) *)\n ; b : 'fp\n (** b = challenge_poly plonk.zeta + r * challenge_poly (domain_generrator * plonk.zeta)\n where challenge_poly(x) = \\prod_i (1 + bulletproof_challenges.(i) * x^{2^{k - 1 - i}})\n *)\n ; xi : 'scalar_challenge\n (** The challenge used for combining polynomials *)\n ; bulletproof_challenges : 'bulletproof_challenges\n (** The challenges from the inner-product argument that was partially verified. *)\n ; branch_data : 'branch_data\n (** Data specific to which step branch of the proof-system was verified *)\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n t =\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n Stable.Latest.t =\n { plonk : 'plonk\n ; combined_inner_product : 'fp\n ; b : 'fp\n ; xi : 'scalar_challenge\n ; bulletproof_challenges : 'bulletproof_challenges\n ; branch_data : 'branch_data\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n\n module Minimal = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'bulletproof_challenges\n , 'branch_data )\n t =\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'bulletproof_challenges\n , 'branch_data )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state\n .Deferred_values\n .Minimal\n .V1\n .t =\n { plonk :\n ( 'challenge\n , 'scalar_challenge\n , 'bool )\n Plonk.Minimal.Stable.V1.t\n ; bulletproof_challenges : 'bulletproof_challenges\n ; branch_data : 'branch_data\n }\n [@@deriving sexp, compare, yojson, hash, equal]\n end\n end]\n\n let map_challenges { plonk; bulletproof_challenges; branch_data } ~f\n ~scalar =\n { plonk = Plonk.Minimal.map_challenges ~f ~scalar plonk\n ; bulletproof_challenges\n ; branch_data\n }\n end\n\n let map_challenges\n { plonk\n ; combined_inner_product\n ; b : 'fp\n ; xi\n ; bulletproof_challenges\n ; branch_data\n } ~f:_ ~scalar =\n { xi = scalar xi\n ; combined_inner_product\n ; b\n ; plonk\n ; bulletproof_challenges\n ; branch_data\n }\n\n module In_circuit = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bulletproof_challenges\n , 'branch_data\n , 'bool )\n t =\n ( ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bool )\n Plonk.In_circuit.t\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n Stable.Latest.t\n [@@deriving sexp, compare, yojson, hash, equal]\n\n let to_hlist, of_hlist = (to_hlist, of_hlist)\n\n let typ (type f fp)\n ((module Impl) as impl :\n (module Snarky_backendless.Snark_intf.Run with type field = f) )\n ~dummy_scalar_challenge ~challenge ~scalar_challenge ~feature_flags\n (fp : (fp, _, f) Snarky_backendless.Typ.t) index =\n Snarky_backendless.Typ.of_hlistable\n [ Plonk.In_circuit.typ impl ~dummy_scalar_challenge ~challenge\n ~scalar_challenge ~bool:Impl.Boolean.typ ~feature_flags fp\n ; fp\n ; fp\n ; Scalar_challenge.typ scalar_challenge\n ; Vector.typ\n (Bulletproof_challenge.typ scalar_challenge)\n Backend.Tick.Rounds.n\n ; index\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n end\n\n let to_minimal\n ({ plonk\n ; combined_inner_product = _\n ; b = _\n ; xi = _\n ; bulletproof_challenges\n ; branch_data\n } :\n _ In_circuit.t ) ~to_option : _ Minimal.t =\n { plonk = Plonk.to_minimal ~to_option plonk\n ; bulletproof_challenges\n ; branch_data\n }\n end\n\n (** The component of the proof accumulation state that is only computed on by the\n \"wrapping\" proof system, and that can be handled opaquely by any \"step\" circuits. *)\n module Messages_for_next_wrap_proof = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('g1, 'bulletproof_challenges) t =\n ( 'g1\n , 'bulletproof_challenges )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state\n .Messages_for_next_wrap_proof\n .V1\n .t =\n { challenge_polynomial_commitment : 'g1\n ; old_bulletproof_challenges : 'bulletproof_challenges\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n end\n end]\n\n let to_field_elements (type g f)\n { challenge_polynomial_commitment; old_bulletproof_challenges }\n ~g1:(g1_to_field_elements : g -> f list) =\n Array.concat\n [ Vector.to_array old_bulletproof_challenges\n |> Array.concat_map ~f:Vector.to_array\n ; Array.of_list (g1_to_field_elements challenge_polynomial_commitment)\n ]\n\n let typ g1 chal ~length =\n Snarky_backendless.Typ.of_hlistable\n [ g1; Vector.typ chal length ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n t =\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state.V1.t =\n { deferred_values :\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bp_chals\n , 'index )\n Deferred_values.Stable.V1.t\n ; sponge_digest_before_evaluations : 'digest\n ; messages_for_next_wrap_proof : 'messages_for_next_wrap_proof\n (** Parts of the statement not needed by the other circuit. Represented as a hash inside the\n circuit which is then \"unhashed\". *)\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n end\n end]\n\n module Minimal = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n t =\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Mina_wire_types.Pickles_composition_types.Wrap.Proof_state\n .Minimal\n .V1\n .t =\n { deferred_values :\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'bp_chals\n , 'index )\n Deferred_values.Minimal.Stable.V1.t\n ; sponge_digest_before_evaluations : 'digest\n ; messages_for_next_wrap_proof : 'messages_for_next_wrap_proof\n (** Parts of the statement not needed by the other circuit. Represented as a hash inside the\n circuit which is then \"unhashed\". *)\n }\n [@@deriving sexp, compare, yojson, hash, equal]\n end\n end]\n end\n\n module In_circuit = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n t =\n ( ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bool )\n Deferred_values.Plonk.In_circuit.t\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Stable.Latest.t\n [@@deriving sexp, compare, yojson, hash, equal]\n\n let to_hlist, of_hlist = (to_hlist, of_hlist)\n\n let typ (type f fp)\n (impl : (module Snarky_backendless.Snark_intf.Run with type field = f))\n ~dummy_scalar_challenge ~challenge ~scalar_challenge ~feature_flags\n (fp : (fp, _, f) Snarky_backendless.Typ.t)\n messages_for_next_wrap_proof digest index =\n Snarky_backendless.Typ.of_hlistable\n [ Deferred_values.In_circuit.typ impl ~dummy_scalar_challenge\n ~challenge ~scalar_challenge ~feature_flags fp index\n ; digest\n ; messages_for_next_wrap_proof\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n let to_minimal\n ({ deferred_values\n ; sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n } :\n _ In_circuit.t ) ~to_option : _ Minimal.t =\n { deferred_values = Deferred_values.to_minimal ~to_option deferred_values\n ; sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n }\n end\n\n (** The component of the proof accumulation state that is only computed on by the\n \"stepping\" proof system, and that can be handled opaquely by any \"wrap\" circuits. *)\n module Messages_for_next_step_proof = struct\n type ('g, 's, 'challenge_polynomial_commitments, 'bulletproof_challenges) t =\n { app_state : 's\n (** The actual application-level state (e.g., for Mina, this is the protocol state which contains the\n merkle root of the ledger, state related to consensus, etc.) *)\n ; dlog_plonk_index : 'g Plonk_verification_key_evals.t\n (** The verification key corresponding to the wrap-circuit for this recursive proof system.\n It gets threaded through all the circuits so that the step circuits can verify proofs against\n it.\n *)\n ; challenge_polynomial_commitments : 'challenge_polynomial_commitments\n ; old_bulletproof_challenges : 'bulletproof_challenges\n }\n [@@deriving sexp]\n\n let to_field_elements (type g f)\n { app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n } ~app_state:app_state_to_field_elements ~comm ~(g : g -> f list) =\n Array.concat\n [ index_to_field_elements ~g:comm dlog_plonk_index\n ; app_state_to_field_elements app_state\n ; Vector.map2 challenge_polynomial_commitments\n old_bulletproof_challenges ~f:(fun comm chals ->\n Array.append (Array.of_list (g comm)) (Vector.to_array chals) )\n |> Vector.to_list |> Array.concat\n ]\n\n let to_field_elements_without_index (type g f)\n { app_state\n ; dlog_plonk_index = _\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n } ~app_state:app_state_to_field_elements ~(g : g -> f list) =\n Array.concat\n [ app_state_to_field_elements app_state\n ; Vector.map2 challenge_polynomial_commitments\n old_bulletproof_challenges ~f:(fun comm chals ->\n Array.append (Array.of_list (g comm)) (Vector.to_array chals) )\n |> Vector.to_list |> Array.concat\n ]\n\n open Snarky_backendless.H_list\n\n let[@warning \"-45\"] to_hlist\n { app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n } =\n [ app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n ]\n\n let[@warning \"-45\"] of_hlist\n ([ app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n ] :\n (unit, _) t ) =\n { app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n }\n\n let typ comm g s chal proofs_verified =\n Snarky_backendless.Typ.of_hlistable\n [ s\n ; Plonk_verification_key_evals.typ comm\n ; Vector.typ g proofs_verified\n ; chal\n ]\n (* TODO: Should this really just be a vector typ of length Rounds.n ?*)\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n module Lookup_parameters = struct\n (* Values needed for computing lookup parts of the verifier circuit. *)\n type ('chal, 'chal_var, 'fp, 'fp_var) t =\n { zero : ('chal, 'chal_var, 'fp, 'fp_var) Zero_values.t\n ; use : Opt.Flag.t\n }\n\n let opt_spec (type f) ((module Impl) : f impl)\n { zero = { value; var }; use } =\n Spec.T.Opt\n { inner = Struct [ Scalar Challenge ]\n ; flag = use\n ; dummy1 =\n [ Kimchi_backend_common.Scalar_challenge.create value.challenge ]\n ; dummy2 =\n [ Kimchi_backend_common.Scalar_challenge.create var.challenge ]\n ; bool = (module Impl.Boolean)\n }\n end\n\n (** This is the full statement for \"wrap\" proofs which contains\n - the application-level statement (app_state)\n - data needed to perform the final verification of the proof, which correspond\n to parts of incompletely verified proofs.\n *)\n module Statement = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n t =\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n Mina_wire_types.Pickles_composition_types.Wrap.Statement.V1.t =\n { proof_state :\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Proof_state.Stable.V1.t\n ; messages_for_next_step_proof : 'messages_for_next_step_proof\n }\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n module Minimal = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n t =\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n Mina_wire_types.Pickles_composition_types.Wrap.Statement.Minimal\n .V1\n .t =\n { proof_state :\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Proof_state.Minimal.Stable.V1.t\n ; messages_for_next_step_proof : 'messages_for_next_step_proof\n }\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n end\n\n module In_circuit = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n t =\n ( ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'fp_opt\n , 'lookup_opt\n , 'bool )\n Proof_state.Deferred_values.Plonk.In_circuit.t\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n Stable.Latest.t\n [@@deriving compare, yojson, sexp, hash, equal]\n\n (** A layout of the raw data in a statement, which is needed for\n representing it inside the circuit. *)\n let spec impl lookup feature_flags =\n let feature_flags_spec =\n let [ f1; f2; f3; f4; f5; f6; f7; f8 ] =\n (* Ensure that layout is the same *)\n Plonk_types.Features.to_data feature_flags\n in\n let constant x =\n Spec.T.Constant (x, (fun x y -> assert (Bool.equal x y)), B Bool)\n in\n let maybe_constant flag =\n match flag with\n | Opt.Flag.Yes ->\n constant true\n | Opt.Flag.No ->\n constant false\n | Opt.Flag.Maybe ->\n Spec.T.B Bool\n in\n Spec.T.Struct\n [ maybe_constant f1\n ; maybe_constant f2\n ; maybe_constant f3\n ; maybe_constant f4\n ; maybe_constant f5\n ; maybe_constant f6\n ; maybe_constant f7\n ; maybe_constant f8\n ]\n in\n Spec.T.Struct\n [ Vector (B Field, Nat.N5.n)\n ; Vector (B Challenge, Nat.N2.n)\n ; Vector (Scalar Challenge, Nat.N3.n)\n ; Vector (B Digest, Nat.N3.n)\n ; Vector (B Bulletproof_challenge, Backend.Tick.Rounds.n)\n ; Vector (B Branch_data, Nat.N1.n)\n ; feature_flags_spec\n ; Lookup_parameters.opt_spec impl lookup\n ]\n\n (** Convert a statement (as structured data) into the flat data-based representation. *)\n let[@warning \"-45\"] to_data\n ({ proof_state =\n { deferred_values =\n { xi\n ; combined_inner_product\n ; b\n ; branch_data\n ; bulletproof_challenges\n ; plonk =\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ; feature_flags\n ; joint_combiner\n }\n }\n ; sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n (* messages_for_next_wrap_proof is represented as a digest (and then unhashed) inside the circuit *)\n }\n ; messages_for_next_step_proof\n (* messages_for_next_step_proof is represented as a digest inside the circuit *)\n } :\n _ t ) ~option_map =\n let open Vector in\n let fp =\n [ combined_inner_product\n ; b\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ]\n in\n let challenge = [ beta; gamma ] in\n let scalar_challenge = [ alpha; zeta; xi ] in\n let digest =\n [ sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n ; messages_for_next_step_proof\n ]\n in\n let index = [ branch_data ] in\n Hlist.HlistId.\n [ fp\n ; challenge\n ; scalar_challenge\n ; digest\n ; bulletproof_challenges\n ; index\n ; Plonk_types.Features.to_data feature_flags\n ; option_map joint_combiner ~f:(fun x -> Hlist.HlistId.[ x ])\n ]\n\n (** Construct a statement (as structured data) from the flat data-based representation. *)\n let[@warning \"-45\"] of_data\n Hlist.HlistId.\n [ fp\n ; challenge\n ; scalar_challenge\n ; digest\n ; bulletproof_challenges\n ; index\n ; feature_flags\n ; joint_combiner\n ] ~option_map : _ t =\n let open Vector in\n let [ combined_inner_product\n ; b\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ] =\n fp\n in\n let [ beta; gamma ] = challenge in\n let [ alpha; zeta; xi ] = scalar_challenge in\n let [ sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n ; messages_for_next_step_proof\n ] =\n digest\n in\n let [ branch_data ] = index in\n let feature_flags = Plonk_types.Features.of_data feature_flags in\n { proof_state =\n { deferred_values =\n { xi\n ; combined_inner_product\n ; b\n ; branch_data\n ; bulletproof_challenges\n ; plonk =\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ; feature_flags\n ; joint_combiner =\n option_map joint_combiner ~f:(fun Hlist.HlistId.[ x ] ->\n x )\n }\n }\n ; sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n }\n ; messages_for_next_step_proof\n }\n end\n\n let to_minimal\n ({ proof_state; messages_for_next_step_proof } : _ In_circuit.t)\n ~to_option : _ Minimal.t =\n { proof_state = Proof_state.to_minimal ~to_option proof_state\n ; messages_for_next_step_proof\n }\n end\nend\n\nmodule Step = struct\n module Plonk_polys = Nat.N10\n\n module Bulletproof = struct\n include Plonk_types.Openings.Bulletproof\n\n module Advice = struct\n (** This is data that can be computed in linear time from the proof + statement.\n\n It doesn't need to be sent on the wire, but it does need to be provided to the verifier\n *)\n type 'fq t =\n { b : 'fq\n ; combined_inner_product : 'fq (* sum_i r^i sum_j xi^j f_j(pt_i) *)\n }\n [@@deriving hlist]\n end\n end\n\n module Proof_state = struct\n module Deferred_values = struct\n module Plonk = struct\n module Minimal = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n (** Challenges from the PLONK IOP. These, plus the evaluations that are already in the proof, are\n all that's needed to derive all the values in the [In_circuit] version below.\n\n See src/lib/pickles/plonk_checks/plonk_checks.ml for the computation of the [In_circuit] value\n from the [Minimal] value.\n *)\n type ('challenge, 'scalar_challenge) t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal]\n end\n end]\n\n let to_wrap ~feature_flags { alpha; beta; gamma; zeta } :\n _ Wrap.Proof_state.Deferred_values.Plonk.Minimal.t =\n { alpha; beta; gamma; zeta; joint_combiner = None; feature_flags }\n\n let of_wrap\n ({ alpha\n ; beta\n ; gamma\n ; zeta\n ; joint_combiner = _\n ; feature_flags = _\n } :\n _ Wrap.Proof_state.Deferred_values.Plonk.Minimal.t ) =\n { alpha; beta; gamma; zeta }\n end\n\n open Pickles_types\n\n module In_circuit = struct\n (** All scalar values deferred by a verifier circuit.\n The values in [vbmul], [complete_add], [endomul], [endomul_scalar], and [perm]\n are all scalars which will have been used to scale selector polynomials during the\n computation of the linearized polynomial commitment.\n\n Then, we expose them so the next guy (who can do scalar arithmetic) can check that they\n were computed correctly from the evaluations in the proof and the challenges.\n *)\n type ('challenge, 'scalar_challenge, 'fp) t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n (* TODO: zeta_to_srs_length is kind of unnecessary.\n Try to get rid of it when you can.\n *)\n ; zeta_to_srs_length : 'fp\n ; zeta_to_domain_size : 'fp\n ; perm : 'fp\n (** scalar used on one of the permutation polynomial commitments. *)\n }\n [@@deriving sexp, compare, yojson, hlist, hash, equal, fields]\n\n let to_wrap ~opt_none ~false_\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n } : _ Wrap.Proof_state.Deferred_values.Plonk.In_circuit.t =\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ; feature_flags =\n { range_check0 = false_\n ; range_check1 = false_\n ; foreign_field_add = false_\n ; foreign_field_mul = false_\n ; xor = false_\n ; rot = false_\n ; lookup = false_\n ; runtime_tables = false_\n }\n ; joint_combiner = opt_none\n }\n\n let of_wrap ~assert_none ~assert_false\n ({ alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ; feature_flags\n ; joint_combiner\n } :\n _ Wrap.Proof_state.Deferred_values.Plonk.In_circuit.t ) =\n let () =\n let { Plonk_types.Features.range_check0\n ; range_check1\n ; foreign_field_add\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n } =\n feature_flags\n in\n assert_false range_check0 ;\n assert_false range_check1 ;\n assert_false foreign_field_add ;\n assert_false foreign_field_mul ;\n assert_false xor ;\n assert_false rot ;\n assert_false lookup ;\n assert_false runtime_tables\n in\n assert_none joint_combiner ;\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n }\n\n let map_challenges t ~f ~scalar =\n { t with\n alpha = scalar t.alpha\n ; beta = f t.beta\n ; gamma = f t.gamma\n ; zeta = scalar t.zeta\n }\n\n let map_fields t ~f =\n { t with\n zeta_to_srs_length = f t.zeta_to_srs_length\n ; zeta_to_domain_size = f t.zeta_to_domain_size\n ; perm = f t.perm\n }\n\n let typ (type f fp) _ ~challenge ~scalar_challenge\n (fp : (fp, _, f) Snarky_backendless.Typ.t) =\n Snarky_backendless.Typ.of_hlistable\n [ Scalar_challenge.typ scalar_challenge\n ; challenge\n ; challenge\n ; Scalar_challenge.typ scalar_challenge\n ; fp\n ; fp\n ; fp\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n end\n\n let to_minimal (type challenge scalar_challenge fp)\n (t : (challenge, scalar_challenge, fp) In_circuit.t) :\n (challenge, scalar_challenge) Minimal.t =\n { alpha = t.alpha; beta = t.beta; zeta = t.zeta; gamma = t.gamma }\n end\n\n (** All the scalar-field values needed to finalize the verification of a proof\n by checking that the correct values were used in the \"group operations\" part of the\n verifier.\n\n Consists of some evaluations of PLONK polynomials (columns, permutation aggregation, etc.)\n and the remainder are things related to the inner product argument.\n*)\n type ('plonk, 'scalar_challenge, 'fq, 'bulletproof_challenges) t_ =\n { plonk : 'plonk\n ; combined_inner_product : 'fq\n (** combined_inner_product = sum_{i < num_evaluation_points} sum_{j < num_polys} r^i xi^j f_j(pt_i) *)\n ; xi : 'scalar_challenge\n (** The challenge used for combining polynomials *)\n ; bulletproof_challenges : 'bulletproof_challenges\n (** The challenges from the inner-product argument that was partially verified. *)\n ; b : 'fq\n (** b = challenge_poly plonk.zeta + r * challenge_poly (domain_generrator * plonk.zeta)\n where challenge_poly(x) = \\prod_i (1 + bulletproof_challenges.(i) * x^{2^{k - 1 - i}})\n *)\n }\n [@@deriving sexp, compare, yojson]\n\n module Minimal = struct\n type ('challenge, 'scalar_challenge, 'fq, 'bulletproof_challenges) t =\n ( ('challenge, 'scalar_challenge) Plonk.Minimal.t\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges )\n t_\n [@@deriving sexp, compare, yojson]\n end\n\n module In_circuit = struct\n type ('challenge, 'scalar_challenge, 'fq, 'bulletproof_challenges) t =\n ( ('challenge, 'scalar_challenge, 'fq) Plonk.In_circuit.t\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges )\n t_\n [@@deriving sexp, compare, yojson]\n end\n end\n\n module Messages_for_next_wrap_proof =\n Wrap.Proof_state.Messages_for_next_wrap_proof\n module Messages_for_next_step_proof = Wrap.Messages_for_next_step_proof\n\n module Per_proof = struct\n (** For each proof that a step circuit verifies, we do not verify the whole proof.\n Specifically,\n - we defer calculations involving the \"other field\" (i.e., the scalar-field of the group\n elements involved in the proof.\n - we do not fully verify the inner-product argument as that would be O(n) and instead\n do the accumulator trick.\n\n As a result, for each proof that a step circuit verifies, we must expose some data\n related to it as part of the step circuit's statement, in order to allow those proofs\n to be fully verified eventually.\n\n This is that data. *)\n type ( 'plonk\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges\n , 'digest\n , 'bool )\n t_ =\n { deferred_values :\n ( 'plonk\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges )\n Deferred_values.t_\n (** Scalar values related to the proof *)\n ; should_finalize : 'bool\n (** We allow circuits in pickles proof systems to decide if it's OK that a proof did\n not recursively verify. In that case, when we expose the unfinalized bits, we need\n to communicate that it's OK if those bits do not \"finalize\". That's what this boolean\n is for. *)\n ; sponge_digest_before_evaluations : 'digest\n }\n [@@deriving sexp, compare, yojson]\n\n module Minimal = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges\n , 'digest\n , 'bool )\n t =\n ( ('challenge, 'scalar_challenge) Deferred_values.Plonk.Minimal.t\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges\n , 'digest\n , 'bool )\n t_\n [@@deriving sexp, compare, yojson]\n end\n\n module In_circuit = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges\n , 'digest\n , 'bool )\n t =\n ( ( 'challenge\n , 'scalar_challenge\n , 'fq )\n Deferred_values.Plonk.In_circuit.t\n , 'scalar_challenge\n , 'fq\n , 'bulletproof_challenges\n , 'digest\n , 'bool )\n t_\n [@@deriving sexp, compare, yojson]\n\n (** A layout of the raw data in this value, which is needed for\n representing it inside the circuit. *)\n let spec bp_log2 =\n Spec.T.Struct\n [ Vector (B Field, Nat.N5.n)\n ; Vector (B Digest, Nat.N1.n)\n ; Vector (B Challenge, Nat.N2.n)\n ; Vector (Scalar Challenge, Nat.N3.n)\n ; Vector (B Bulletproof_challenge, bp_log2)\n ; Vector (B Bool, Nat.N1.n)\n ]\n\n let[@warning \"-45\"] to_data\n ({ deferred_values =\n { xi\n ; bulletproof_challenges\n ; b\n ; combined_inner_product\n ; plonk =\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n }\n }\n ; should_finalize\n ; sponge_digest_before_evaluations\n } :\n _ t ) =\n let open Vector in\n let fq =\n [ combined_inner_product\n ; b\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ]\n in\n let challenge = [ beta; gamma ] in\n let scalar_challenge = [ alpha; zeta; xi ] in\n let digest = [ sponge_digest_before_evaluations ] in\n let bool = [ should_finalize ] in\n let open Hlist.HlistId in\n [ fq\n ; digest\n ; challenge\n ; scalar_challenge\n ; bulletproof_challenges\n ; bool\n ]\n\n let[@warning \"-45\"] of_data\n Hlist.HlistId.\n [ Vector.\n [ combined_inner_product\n ; b\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n ]\n ; Vector.[ sponge_digest_before_evaluations ]\n ; Vector.[ beta; gamma ]\n ; Vector.[ alpha; zeta; xi ]\n ; bulletproof_challenges\n ; Vector.[ should_finalize ]\n ] : _ t =\n { deferred_values =\n { xi\n ; bulletproof_challenges\n ; b\n ; combined_inner_product\n ; plonk =\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_srs_length\n ; zeta_to_domain_size\n ; perm\n }\n }\n ; should_finalize\n ; sponge_digest_before_evaluations\n }\n end\n\n let typ impl fq ~assert_16_bits =\n let open In_circuit in\n Spec.typ impl fq ~assert_16_bits (spec Backend.Tock.Rounds.n)\n |> Snarky_backendless.Typ.transport ~there:to_data ~back:of_data\n |> Snarky_backendless.Typ.transport_var ~there:to_data ~back:of_data\n end\n\n type ('unfinalized_proofs, 'messages_for_next_step_proof) t =\n { unfinalized_proofs : 'unfinalized_proofs\n (** A vector of the \"per-proof\" structures defined above, one for each proof\n that the step-circuit partially verifies. *)\n ; messages_for_next_step_proof : 'messages_for_next_step_proof\n (** The component of the proof accumulation state that is only computed on by the\n \"stepping\" proof system, and that can be handled opaquely by any \"wrap\" circuits. *)\n }\n [@@deriving sexp, compare, yojson, hlist]\n\n let spec unfinalized_proofs messages_for_next_step_proof =\n Spec.T.Struct [ unfinalized_proofs; messages_for_next_step_proof ]\n\n include struct\n open Hlist.HlistId\n\n let _to_data { unfinalized_proofs; messages_for_next_step_proof } =\n [ Vector.map unfinalized_proofs ~f:Per_proof.In_circuit.to_data\n ; messages_for_next_step_proof\n ]\n\n let _of_data [ unfinalized_proofs; messages_for_next_step_proof ] =\n { unfinalized_proofs =\n Vector.map unfinalized_proofs ~f:Per_proof.In_circuit.of_data\n ; messages_for_next_step_proof\n }\n end [@@warning \"-45\"]\n\n let[@warning \"-60\"] typ (type n f)\n ( (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n as impl ) ~assert_16_bits\n (proofs_verified : (Opt.Flag.t Plonk_types.Features.t, n) Vector.t) fq :\n ( ((_, _) Vector.t, _) t\n , ((_, _) Vector.t, _) t\n , _ )\n Snarky_backendless.Typ.t =\n let per_proof _ = Per_proof.typ impl fq ~assert_16_bits in\n let unfinalized_proofs =\n Vector.typ' (Vector.map proofs_verified ~f:per_proof)\n in\n let messages_for_next_step_proof =\n Spec.typ impl fq ~assert_16_bits (B Spec.Digest)\n in\n Snarky_backendless.Typ.of_hlistable\n [ unfinalized_proofs; messages_for_next_step_proof ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n end\n\n module Statement = struct\n type ( 'unfinalized_proofs\n , 'messages_for_next_step_proof\n , 'messages_for_next_wrap_proof )\n t =\n { proof_state :\n ('unfinalized_proofs, 'messages_for_next_step_proof) Proof_state.t\n ; messages_for_next_wrap_proof : 'messages_for_next_wrap_proof\n (** The component of the proof accumulation state that is only computed on by the\n \"wrapping\" proof system, and that can be handled opaquely by any \"step\" circuits. *)\n }\n [@@deriving sexp, compare, yojson]\n\n let[@warning \"-45\"] to_data\n { proof_state = { unfinalized_proofs; messages_for_next_step_proof }\n ; messages_for_next_wrap_proof\n } =\n let open Hlist.HlistId in\n [ Vector.map unfinalized_proofs\n ~f:Proof_state.Per_proof.In_circuit.to_data\n ; messages_for_next_step_proof\n ; messages_for_next_wrap_proof\n ]\n\n let[@warning \"-45\"] of_data\n Hlist.HlistId.\n [ unfinalized_proofs\n ; messages_for_next_step_proof\n ; messages_for_next_wrap_proof\n ] =\n { proof_state =\n { unfinalized_proofs =\n Vector.map unfinalized_proofs\n ~f:Proof_state.Per_proof.In_circuit.of_data\n ; messages_for_next_step_proof\n }\n ; messages_for_next_wrap_proof\n }\n\n let spec proofs_verified bp_log2 =\n let per_proof = Proof_state.Per_proof.In_circuit.spec bp_log2 in\n Spec.T.Struct\n [ Vector (per_proof, proofs_verified)\n ; B Digest\n ; Vector (B Digest, proofs_verified)\n ]\n end\nend\n\nmodule Nvector = Vector.With_length\nmodule Wrap_bp_vec = Backend.Tock.Rounds_vector\nmodule Step_bp_vec = Backend.Tick.Rounds_vector\n\nmodule Challenges_vector = struct\n type 'n t =\n (Backend.Tock.Field.t Snarky_backendless.Cvar.t Wrap_bp_vec.t, 'n) Vector.t\n\n module Constant = struct\n type 'n t = (Backend.Tock.Field.t Wrap_bp_vec.t, 'n) Vector.t\n end\nend\n","(* This file is generated by gen_scalars/gen_scalars.exe. *)\n\n(* turn off fragile pattern-matching warning from sexp ppx *)\n[@@@warning \"-4\"]\n\ntype curr_or_next = Curr | Next [@@deriving hash, eq, compare, sexp]\n\nmodule Gate_type = struct\n module T = struct\n type t = Kimchi_types.gate_type =\n | Zero\n | Generic\n | Poseidon\n | CompleteAdd\n | VarBaseMul\n | EndoMul\n | EndoMulScalar\n | Lookup\n | CairoClaim\n | CairoInstruction\n | CairoFlags\n | CairoTransition\n | RangeCheck0\n | RangeCheck1\n | ForeignFieldAdd\n | ForeignFieldMul\n | Xor16\n | Rot64\n [@@deriving hash, eq, compare, sexp]\n end\n\n include Core_kernel.Hashable.Make (T)\n include T\nend\n\nmodule Lookup_pattern = struct\n module T = struct\n type t = Kimchi_types.lookup_pattern =\n | Xor\n | Lookup\n | RangeCheck\n | ForeignFieldMul\n [@@deriving hash, eq, compare, sexp]\n end\n\n include Core_kernel.Hashable.Make (T)\n include T\nend\n\nmodule Column = struct\n open Core_kernel\n\n module T = struct\n type t =\n | Witness of int\n | Index of Gate_type.t\n | Coefficient of int\n | LookupTable\n | LookupSorted of int\n | LookupAggreg\n | LookupKindIndex of Lookup_pattern.t\n | LookupRuntimeSelector\n | LookupRuntimeTable\n [@@deriving hash, eq, compare, sexp]\n end\n\n include Hashable.Make (T)\n include T\nend\n\nopen Gate_type\nopen Column\n\nmodule Env = struct\n type 'a t =\n { add : 'a -> 'a -> 'a\n ; sub : 'a -> 'a -> 'a\n ; mul : 'a -> 'a -> 'a\n ; pow : 'a * int -> 'a\n ; square : 'a -> 'a\n ; zk_polynomial : 'a\n ; omega_to_minus_3 : 'a\n ; zeta_to_n_minus_1 : 'a\n ; var : Column.t * curr_or_next -> 'a\n ; field : string -> 'a\n ; cell : 'a -> 'a\n ; alpha_pow : int -> 'a\n ; double : 'a -> 'a\n ; endo_coefficient : 'a\n ; mds : int * int -> 'a\n ; srs_length_log2 : int\n ; vanishes_on_zero_knowledge_and_previous_rows : 'a\n ; joint_combiner : 'a\n ; beta : 'a\n ; gamma : 'a\n ; unnormalized_lagrange_basis : int -> 'a\n ; if_feature : Kimchi_types.feature_flag * (unit -> 'a) * (unit -> 'a) -> 'a\n }\nend\n\nmodule type S = sig\n val constant_term : 'a Env.t -> 'a\n\n val index_terms : 'a Env.t -> 'a Lazy.t Column.Table.t\nend\n\n(* The constraints are basically the same, but the literals in them differ. *)\nmodule Tick : S = struct\n let constant_term (type a)\n ({ add = ( + )\n ; sub = ( - )\n ; mul = ( * )\n ; square\n ; mds\n ; endo_coefficient\n ; pow\n ; var\n ; field\n ; cell\n ; alpha_pow\n ; double\n ; zk_polynomial = _\n ; omega_to_minus_3 = _\n ; zeta_to_n_minus_1 = _\n ; srs_length_log2 = _\n ; vanishes_on_zero_knowledge_and_previous_rows\n ; joint_combiner\n ; beta\n ; gamma\n ; unnormalized_lagrange_basis\n ; if_feature\n } :\n a Env.t ) =\n let x_0 = pow (cell (var (Witness 0, Curr)), 7) in\n let x_1 = pow (cell (var (Witness 1, Curr)), 7) in\n let x_2 = pow (cell (var (Witness 2, Curr)), 7) in\n let x_3 = pow (cell (var (Witness 6, Curr)), 7) in\n let x_4 = pow (cell (var (Witness 7, Curr)), 7) in\n let x_5 = pow (cell (var (Witness 8, Curr)), 7) in\n let x_6 = pow (cell (var (Witness 9, Curr)), 7) in\n let x_7 = pow (cell (var (Witness 10, Curr)), 7) in\n let x_8 = pow (cell (var (Witness 11, Curr)), 7) in\n let x_9 = pow (cell (var (Witness 12, Curr)), 7) in\n let x_10 = pow (cell (var (Witness 13, Curr)), 7) in\n let x_11 = pow (cell (var (Witness 14, Curr)), 7) in\n let x_12 = pow (cell (var (Witness 3, Curr)), 7) in\n let x_13 = pow (cell (var (Witness 4, Curr)), 7) in\n let x_14 = pow (cell (var (Witness 5, Curr)), 7) in\n let x_15 = cell (var (Witness 7, Next)) * cell (var (Witness 7, Next)) in\n let x_16 =\n let x_15 = cell (var (Witness 7, Next)) * cell (var (Witness 7, Next)) in\n cell (var (Witness 2, Curr))\n - (x_15 - cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_17 =\n let x_16 =\n let x_15 =\n cell (var (Witness 7, Next)) * cell (var (Witness 7, Next))\n in\n cell (var (Witness 2, Curr))\n - (x_15 - cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 3, Curr)))\n - (x_16 * cell (var (Witness 7, Next)))\n in\n let x_18 = cell (var (Witness 8, Next)) * cell (var (Witness 8, Next)) in\n let x_19 =\n let x_18 = cell (var (Witness 8, Next)) * cell (var (Witness 8, Next)) in\n cell (var (Witness 7, Curr))\n - (x_18 - cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_20 =\n let x_19 =\n let x_18 =\n cell (var (Witness 8, Next)) * cell (var (Witness 8, Next))\n in\n cell (var (Witness 7, Curr))\n - (x_18 - cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 8, Curr)))\n - (x_19 * cell (var (Witness 8, Next)))\n in\n let x_21 = cell (var (Witness 9, Next)) * cell (var (Witness 9, Next)) in\n let x_22 =\n let x_21 = cell (var (Witness 9, Next)) * cell (var (Witness 9, Next)) in\n cell (var (Witness 9, Curr))\n - (x_21 - cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_23 =\n let x_22 =\n let x_21 =\n cell (var (Witness 9, Next)) * cell (var (Witness 9, Next))\n in\n cell (var (Witness 9, Curr))\n - (x_21 - cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 10, Curr)))\n - (x_22 * cell (var (Witness 9, Next)))\n in\n let x_24 = cell (var (Witness 10, Next)) * cell (var (Witness 10, Next)) in\n let x_25 =\n let x_24 =\n cell (var (Witness 10, Next)) * cell (var (Witness 10, Next))\n in\n cell (var (Witness 11, Curr))\n - (x_24 - cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_26 =\n let x_25 =\n let x_24 =\n cell (var (Witness 10, Next)) * cell (var (Witness 10, Next))\n in\n cell (var (Witness 11, Curr))\n - (x_24 - cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 12, Curr)))\n - (x_25 * cell (var (Witness 10, Next)))\n in\n let x_27 = cell (var (Witness 11, Next)) * cell (var (Witness 11, Next)) in\n let x_28 =\n let x_27 =\n cell (var (Witness 11, Next)) * cell (var (Witness 11, Next))\n in\n cell (var (Witness 13, Curr))\n - (x_27 - cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_29 =\n let x_28 =\n let x_27 =\n cell (var (Witness 11, Next)) * cell (var (Witness 11, Next))\n in\n cell (var (Witness 13, Curr))\n - (x_27 - cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 14, Curr)))\n - (x_28 * cell (var (Witness 11, Next)))\n in\n let x_30 = cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)) in\n let x_31 = cell (var (Witness 3, Curr)) - cell (var (Witness 1, Curr)) in\n let x_32 = cell (var (Witness 0, Curr)) * cell (var (Witness 0, Curr)) in\n let x_33 =\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + cell (var (Witness 11, Curr))\n * ( endo_coefficient\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n * cell (var (Witness 0, Curr))\n in\n let x_34 =\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + cell (var (Witness 13, Curr))\n * ( endo_coefficient\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n * cell (var (Witness 0, Curr))\n in\n let x_35 = square (cell (var (Witness 9, Curr))) in\n let x_36 = square (cell (var (Witness 10, Curr))) in\n let x_37 = cell (var (Witness 4, Curr)) - cell (var (Witness 7, Curr)) in\n let x_38 = cell (var (Witness 7, Curr)) - cell (var (Witness 4, Next)) in\n let x_39 = cell (var (Witness 5, Next)) + cell (var (Witness 8, Curr)) in\n let x_40 = cell (var (Witness 8, Curr)) + cell (var (Witness 5, Curr)) in\n let x_41 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 6, Curr))\n in\n let x_42 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 7, Curr))\n in\n let x_43 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 8, Curr))\n in\n let x_44 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 9, Curr))\n in\n let x_45 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 10, Curr))\n in\n let x_46 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 11, Curr))\n in\n let x_47 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 12, Curr))\n in\n let x_48 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADC45309330F104F00000001\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04A67C8DCC9698767FFFFFFE\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56E229849987882780000002\"\n )\n * cell (var (Witness 13, Curr))\n in\n cell (var (Index Poseidon, Curr))\n * ( cell (var (Witness 6, Curr))\n - ( cell (var (Coefficient 0, Curr))\n + (mds (0, 0) * x_0)\n + (mds (0, 1) * x_1)\n + (mds (0, 2) * x_2) )\n + alpha_pow 1\n * ( cell (var (Witness 7, Curr))\n - ( cell (var (Coefficient 1, Curr))\n + (mds (1, 0) * x_0)\n + (mds (1, 1) * x_1)\n + (mds (1, 2) * x_2) ) )\n + alpha_pow 2\n * ( cell (var (Witness 8, Curr))\n - ( cell (var (Coefficient 2, Curr))\n + (mds (2, 0) * x_0)\n + (mds (2, 1) * x_1)\n + (mds (2, 2) * x_2) ) )\n + alpha_pow 3\n * ( cell (var (Witness 9, Curr))\n - ( cell (var (Coefficient 3, Curr))\n + (mds (0, 0) * x_3)\n + (mds (0, 1) * x_4)\n + (mds (0, 2) * x_5) ) )\n + alpha_pow 4\n * ( cell (var (Witness 10, Curr))\n - ( cell (var (Coefficient 4, Curr))\n + (mds (1, 0) * x_3)\n + (mds (1, 1) * x_4)\n + (mds (1, 2) * x_5) ) )\n + alpha_pow 5\n * ( cell (var (Witness 11, Curr))\n - ( cell (var (Coefficient 5, Curr))\n + (mds (2, 0) * x_3)\n + (mds (2, 1) * x_4)\n + (mds (2, 2) * x_5) ) )\n + alpha_pow 6\n * ( cell (var (Witness 12, Curr))\n - ( cell (var (Coefficient 6, Curr))\n + (mds (0, 0) * x_6)\n + (mds (0, 1) * x_7)\n + (mds (0, 2) * x_8) ) )\n + alpha_pow 7\n * ( cell (var (Witness 13, Curr))\n - ( cell (var (Coefficient 7, Curr))\n + (mds (1, 0) * x_6)\n + (mds (1, 1) * x_7)\n + (mds (1, 2) * x_8) ) )\n + alpha_pow 8\n * ( cell (var (Witness 14, Curr))\n - ( cell (var (Coefficient 8, Curr))\n + (mds (2, 0) * x_6)\n + (mds (2, 1) * x_7)\n + (mds (2, 2) * x_8) ) )\n + alpha_pow 9\n * ( cell (var (Witness 3, Curr))\n - ( cell (var (Coefficient 9, Curr))\n + (mds (0, 0) * x_9)\n + (mds (0, 1) * x_10)\n + (mds (0, 2) * x_11) ) )\n + alpha_pow 10\n * ( cell (var (Witness 4, Curr))\n - ( cell (var (Coefficient 10, Curr))\n + (mds (1, 0) * x_9)\n + (mds (1, 1) * x_10)\n + (mds (1, 2) * x_11) ) )\n + alpha_pow 11\n * ( cell (var (Witness 5, Curr))\n - ( cell (var (Coefficient 11, Curr))\n + (mds (2, 0) * x_9)\n + (mds (2, 1) * x_10)\n + (mds (2, 2) * x_11) ) )\n + alpha_pow 12\n * ( cell (var (Witness 0, Next))\n - ( cell (var (Coefficient 12, Curr))\n + (mds (0, 0) * x_12)\n + (mds (0, 1) * x_13)\n + (mds (0, 2) * x_14) ) )\n + alpha_pow 13\n * ( cell (var (Witness 1, Next))\n - ( cell (var (Coefficient 13, Curr))\n + (mds (1, 0) * x_12)\n + (mds (1, 1) * x_13)\n + (mds (1, 2) * x_14) ) )\n + alpha_pow 14\n * ( cell (var (Witness 2, Next))\n - ( cell (var (Coefficient 14, Curr))\n + (mds (2, 0) * x_12)\n + (mds (2, 1) * x_13)\n + (mds (2, 2) * x_14) ) ) )\n + cell (var (Index VarBaseMul, Curr))\n * ( cell (var (Witness 5, Curr))\n - ( cell (var (Witness 6, Next))\n + double\n ( cell (var (Witness 5, Next))\n + double\n ( cell (var (Witness 4, Next))\n + double\n ( cell (var (Witness 3, Next))\n + double\n ( cell (var (Witness 2, Next))\n + double (cell (var (Witness 4, Curr))) ) ) ) ) )\n + alpha_pow 1\n * ( square (cell (var (Witness 2, Next)))\n - cell (var (Witness 2, Next)) )\n + alpha_pow 2\n * ( (cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 7, Next))\n - ( cell (var (Witness 3, Curr))\n - ( double (cell (var (Witness 2, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 3\n * ( (x_17 * x_17)\n - x_16 * x_16\n * ( cell (var (Witness 7, Curr))\n - cell (var (Witness 0, Curr))\n + x_15 ) )\n + alpha_pow 4\n * ( (cell (var (Witness 8, Curr)) + cell (var (Witness 3, Curr)))\n * x_16\n - (cell (var (Witness 2, Curr)) - cell (var (Witness 7, Curr)))\n * x_17 )\n + alpha_pow 5\n * ( square (cell (var (Witness 3, Next)))\n - cell (var (Witness 3, Next)) )\n + alpha_pow 6\n * ( (cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 8, Next))\n - ( cell (var (Witness 8, Curr))\n - ( double (cell (var (Witness 3, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 7\n * ( (x_20 * x_20)\n - x_19 * x_19\n * ( cell (var (Witness 9, Curr))\n - cell (var (Witness 0, Curr))\n + x_18 ) )\n + alpha_pow 8\n * ( (cell (var (Witness 10, Curr)) + cell (var (Witness 8, Curr)))\n * x_19\n - (cell (var (Witness 7, Curr)) - cell (var (Witness 9, Curr)))\n * x_20 )\n + alpha_pow 9\n * ( square (cell (var (Witness 4, Next)))\n - cell (var (Witness 4, Next)) )\n + alpha_pow 10\n * ( (cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 9, Next))\n - ( cell (var (Witness 10, Curr))\n - ( double (cell (var (Witness 4, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 11\n * ( (x_23 * x_23)\n - x_22 * x_22\n * ( cell (var (Witness 11, Curr))\n - cell (var (Witness 0, Curr))\n + x_21 ) )\n + alpha_pow 12\n * ( (cell (var (Witness 12, Curr)) + cell (var (Witness 10, Curr)))\n * x_22\n - (cell (var (Witness 9, Curr)) - cell (var (Witness 11, Curr)))\n * x_23 )\n + alpha_pow 13\n * ( square (cell (var (Witness 5, Next)))\n - cell (var (Witness 5, Next)) )\n + alpha_pow 14\n * ( (cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 10, Next))\n - ( cell (var (Witness 12, Curr))\n - ( double (cell (var (Witness 5, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 15\n * ( (x_26 * x_26)\n - x_25 * x_25\n * ( cell (var (Witness 13, Curr))\n - cell (var (Witness 0, Curr))\n + x_24 ) )\n + alpha_pow 16\n * ( (cell (var (Witness 14, Curr)) + cell (var (Witness 12, Curr)))\n * x_25\n - (cell (var (Witness 11, Curr)) - cell (var (Witness 13, Curr)))\n * x_26 )\n + alpha_pow 17\n * ( square (cell (var (Witness 6, Next)))\n - cell (var (Witness 6, Next)) )\n + alpha_pow 18\n * ( (cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 11, Next))\n - ( cell (var (Witness 14, Curr))\n - ( double (cell (var (Witness 6, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 19\n * ( (x_29 * x_29)\n - x_28 * x_28\n * ( cell (var (Witness 0, Next))\n - cell (var (Witness 0, Curr))\n + x_27 ) )\n + alpha_pow 20\n * ( (cell (var (Witness 1, Next)) + cell (var (Witness 14, Curr)))\n * x_28\n - (cell (var (Witness 13, Curr)) - cell (var (Witness 0, Next)))\n * x_29 ) )\n + cell (var (Index CompleteAdd, Curr))\n * ( (cell (var (Witness 10, Curr)) * x_30)\n - ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n - cell (var (Witness 7, Curr)) )\n + (alpha_pow 1 * (cell (var (Witness 7, Curr)) * x_30))\n + alpha_pow 2\n * ( cell (var (Witness 7, Curr))\n * ( double (cell (var (Witness 8, Curr)))\n * cell (var (Witness 1, Curr))\n - double x_32 - x_32 )\n + ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n - cell (var (Witness 7, Curr)) )\n * ((x_30 * cell (var (Witness 8, Curr))) - x_31) )\n + alpha_pow 3\n * ( cell (var (Witness 0, Curr))\n + cell (var (Witness 2, Curr))\n + cell (var (Witness 4, Curr))\n - (cell (var (Witness 8, Curr)) * cell (var (Witness 8, Curr))) )\n + alpha_pow 4\n * ( cell (var (Witness 8, Curr))\n * (cell (var (Witness 0, Curr)) - cell (var (Witness 4, Curr)))\n - cell (var (Witness 1, Curr))\n - cell (var (Witness 5, Curr)) )\n + alpha_pow 5\n * ( x_31\n * (cell (var (Witness 7, Curr)) - cell (var (Witness 6, Curr))) )\n + alpha_pow 6\n * ( (x_31 * cell (var (Witness 9, Curr)))\n - cell (var (Witness 6, Curr)) ) )\n + cell (var (Index EndoMul, Curr))\n * ( square (cell (var (Witness 11, Curr)))\n - cell (var (Witness 11, Curr))\n + alpha_pow 1\n * ( square (cell (var (Witness 12, Curr)))\n - cell (var (Witness 12, Curr)) )\n + alpha_pow 2\n * ( square (cell (var (Witness 13, Curr)))\n - cell (var (Witness 13, Curr)) )\n + alpha_pow 3\n * ( square (cell (var (Witness 14, Curr)))\n - cell (var (Witness 14, Curr)) )\n + alpha_pow 4\n * ( (x_33 - cell (var (Witness 4, Curr)))\n * cell (var (Witness 9, Curr))\n - ( ( double (cell (var (Witness 12, Curr)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr))\n - cell (var (Witness 5, Curr)) ) )\n + alpha_pow 5\n * ( (double (cell (var (Witness 4, Curr))) - x_35 + x_33)\n * ((x_37 * cell (var (Witness 9, Curr))) + x_40)\n - (double (cell (var (Witness 5, Curr))) * x_37) )\n + alpha_pow 6\n * ( square x_40\n - (square x_37 * (x_35 - x_33 + cell (var (Witness 7, Curr)))) )\n + alpha_pow 7\n * ( (x_34 - cell (var (Witness 7, Curr)))\n * cell (var (Witness 10, Curr))\n - ( ( double (cell (var (Witness 14, Curr)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr))\n - cell (var (Witness 8, Curr)) ) )\n + alpha_pow 8\n * ( (double (cell (var (Witness 7, Curr))) - x_36 + x_34)\n * ((x_38 * cell (var (Witness 10, Curr))) + x_39)\n - (double (cell (var (Witness 8, Curr))) * x_38) )\n + alpha_pow 9\n * ( square x_39\n - (square x_38 * (x_36 - x_34 + cell (var (Witness 4, Next)))) )\n + alpha_pow 10\n * ( double\n ( double\n ( double\n ( double (cell (var (Witness 6, Curr)))\n + cell (var (Witness 11, Curr)) )\n + cell (var (Witness 12, Curr)) )\n + cell (var (Witness 13, Curr)) )\n + cell (var (Witness 14, Curr))\n - cell (var (Witness 6, Next)) ) )\n + cell (var (Index EndoMulScalar, Curr))\n * ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n (cell\n (var\n ( Witness 0\n , Curr ) ) ) )\n + cell\n (var\n (Witness 6, Curr) )\n ) )\n + cell (var (Witness 7, Curr))\n ) )\n + cell (var (Witness 8, Curr)) ) )\n + cell (var (Witness 9, Curr)) ) )\n + cell (var (Witness 10, Curr)) ) )\n + cell (var (Witness 11, Curr)) ) )\n + cell (var (Witness 12, Curr)) ) )\n + cell (var (Witness 13, Curr))\n - cell (var (Witness 1, Curr))\n + alpha_pow 1\n * ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double (cell (var (Witness 2, Curr)))\n + x_41 )\n + x_42 )\n + x_43 )\n + x_44 )\n + x_45 )\n + x_46 )\n + x_47 )\n + x_48\n - cell (var (Witness 4, Curr)) )\n + alpha_pow 2\n * ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double (cell (var (Witness 3, Curr)))\n + ( x_41\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_42\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_43\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_44\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_45\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_46\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_47\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) ) )\n + ( x_48\n + ( ( field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ED00000000\"\n ) )\n - cell (var (Witness 5, Curr)) )\n + alpha_pow 3\n * ( ( ( ( cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 6, Curr)) )\n + alpha_pow 4\n * ( ( ( ( cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 7, Curr)) )\n + alpha_pow 5\n * ( ( ( ( cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 8, Curr)) )\n + alpha_pow 6\n * ( ( ( ( cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 9, Curr)) )\n + alpha_pow 7\n * ( ( ( ( cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 10, Curr)) )\n + alpha_pow 8\n * ( ( ( ( cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 11, Curr)) )\n + alpha_pow 9\n * ( ( ( ( cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 12, Curr)) )\n + alpha_pow 10\n * ( ( ( ( cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC094CF91B992D30ECFFFFFFFB\"\n )\n * cell (var (Witness 13, Curr)) ) )\n + if_feature\n ( RangeCheck0\n , (fun () ->\n cell (var (Index RangeCheck0, Curr))\n * ( cell (var (Witness 7, Curr))\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n + alpha_pow 1\n * ( cell (var (Witness 8, Curr))\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 2\n * ( cell (var (Witness 9, Curr))\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 3\n * ( cell (var (Witness 10, Curr))\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 4\n * ( cell (var (Witness 11, Curr))\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 5\n * ( cell (var (Witness 12, Curr))\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 6\n * ( cell (var (Witness 13, Curr))\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 7\n * ( cell (var (Witness 14, Curr))\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 8\n * ( cell (var (Witness 14, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 5, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 4, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 3, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 2, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 1, Curr))\n - cell (var (Witness 0, Curr)) )\n + alpha_pow 9\n * ( cell (var (Coefficient 0, Curr))\n * ( cell (var (Witness 1, Next))\n - ( cell (var (Witness 0, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 0, Next)) ) ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( RangeCheck1\n , (fun () ->\n cell (var (Index RangeCheck1, Curr))\n * ( cell (var (Witness 2, Curr))\n * ( cell (var (Witness 2, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 2, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 2, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n + alpha_pow 1\n * ( cell (var (Witness 7, Curr))\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 2\n * ( cell (var (Witness 8, Curr))\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 3\n * ( cell (var (Witness 9, Curr))\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 4\n * ( cell (var (Witness 10, Curr))\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 5\n * ( cell (var (Witness 11, Curr))\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 6\n * ( cell (var (Witness 12, Curr))\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 7\n * ( cell (var (Witness 13, Curr))\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 8\n * ( cell (var (Witness 14, Curr))\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 9\n * ( cell (var (Witness 0, Next))\n * ( cell (var (Witness 0, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 0, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 0, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 10\n * ( cell (var (Witness 1, Next))\n * ( cell (var (Witness 1, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 1, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 1, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 11\n * ( cell (var (Witness 2, Next))\n * ( cell (var (Witness 2, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 2, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 2, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 12\n * ( cell (var (Witness 7, Next))\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 13\n * ( cell (var (Witness 8, Next))\n * ( cell (var (Witness 8, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 8, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 8, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 14\n * ( cell (var (Witness 9, Next))\n * ( cell (var (Witness 9, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 9, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 9, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 15\n * ( cell (var (Witness 10, Next))\n * ( cell (var (Witness 10, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 10, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 10, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 16\n * ( cell (var (Witness 11, Next))\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 17\n * ( cell (var (Witness 12, Next))\n * ( cell (var (Witness 12, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 12, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 12, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 18\n * ( cell (var (Witness 13, Next))\n * ( cell (var (Witness 13, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 13, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 13, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 19\n * ( cell (var (Witness 14, Next))\n * ( cell (var (Witness 14, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 14, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 14, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 20\n * ( cell (var (Witness 14, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 13, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 12, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 11, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 10, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 9, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 8, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 7, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 2, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 1, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 0, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 14, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 5, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 4, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 3, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 2, Curr))\n - cell (var (Witness 0, Curr)) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( ForeignFieldAdd\n , (fun () ->\n cell (var (Index ForeignFieldAdd, Curr))\n * ( cell (var (Witness 6, Curr))\n * ( cell (var (Witness 6, Curr))\n - cell (var (Coefficient 3, Curr)) )\n + alpha_pow 1\n * ( cell (var (Witness 7, Curr))\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n + alpha_pow 2\n * ( cell (var (Witness 0, Curr))\n + cell (var (Witness 1, Curr))\n * field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n + cell (var (Coefficient 3, Curr))\n * ( cell (var (Witness 3, Curr))\n + cell (var (Witness 4, Curr))\n * field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n )\n - cell (var (Witness 6, Curr))\n * ( cell (var (Coefficient 0, Curr))\n + cell (var (Coefficient 1, Curr))\n * field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n )\n - cell (var (Witness 7, Curr))\n * field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n - ( cell (var (Witness 0, Next))\n + cell (var (Witness 1, Next))\n * field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n ) )\n + alpha_pow 3\n * ( cell (var (Witness 2, Curr))\n + cell (var (Coefficient 3, Curr))\n * cell (var (Witness 5, Curr))\n - cell (var (Witness 6, Curr))\n * cell (var (Coefficient 2, Curr))\n + cell (var (Witness 7, Curr))\n - cell (var (Witness 2, Next)) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( ForeignFieldMul\n , (fun () ->\n cell (var (Index ForeignFieldMul, Curr))\n * ( cell (var (Witness 7, Next))\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 7, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n + alpha_pow 1\n * ( cell (var (Witness 11, Next))\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Next))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 2\n * ( (cell (var (Witness 0, Curr)) * cell (var (Witness 4, Curr)))\n + (cell (var (Witness 1, Curr)) * cell (var (Witness 3, Curr)))\n + cell (var (Witness 2, Next))\n * cell (var (Coefficient 2, Curr))\n + cell (var (Witness 3, Next))\n * cell (var (Coefficient 1, Curr))\n - ( field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * ( field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 7, Next))\n + cell (var (Witness 6, Next)) )\n + cell (var (Witness 6, Curr)) ) )\n + alpha_pow 3\n * ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 11, Next))\n - ( cell (var (Witness 0, Curr))\n * cell (var (Witness 3, Curr))\n + cell (var (Witness 2, Next))\n * cell (var (Coefficient 1, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 6, Curr))\n - cell (var (Witness 0, Next)) ) )\n + alpha_pow 4\n * ( ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 2, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 1, Curr))\n + cell (var (Witness 0, Curr)) )\n * ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 5, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 4, Curr))\n + cell (var (Witness 3, Curr)) )\n + ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 4, Next))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 3, Next))\n + cell (var (Witness 2, Next)) )\n * ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Coefficient 3, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Coefficient 2, Curr))\n + cell (var (Coefficient 1, Curr)) )\n - ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 1, Next))\n + cell (var (Witness 0, Next)) )\n - ( field\n \"0x0000000000000000000100000000000000000000000000000000000000000000\"\n * cell (var (Witness 4, Next))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 3, Next))\n + cell (var (Witness 2, Next)) )\n * field\n \"0x3FFFFFFFFFFFFFFFFFFFFFFFFFFFFF7707E2A8D6D5688AB6E4697CECFFFFFC01\"\n )\n + alpha_pow 5\n * ( cell (var (Witness 11, Curr))\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 6\n * ( cell (var (Witness 12, Curr))\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 7\n * ( cell (var (Witness 13, Curr))\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 8\n * ( square (cell (var (Witness 14, Curr)))\n - cell (var (Witness 14, Curr)) )\n + alpha_pow 9\n * ( field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * ( cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000001000000\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000001000000000\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000001000000000000\"\n * cell (var (Witness 8, Next))\n + field\n \"0x0000000000000000000000000000000000000000000000001000000000000000\"\n * cell (var (Witness 9, Next))\n + field\n \"0x0000000000000000000000000000000000000000000001000000000000000000\"\n * cell (var (Witness 10, Next))\n + field\n \"0x0000000000000000000000000000000000000000001000000000000000000000\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000004000000000000000000000\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000040000000000000000000000\"\n * cell (var (Witness 14, Curr)) )\n - ( cell (var (Witness 0, Curr))\n * cell (var (Witness 5, Curr))\n + cell (var (Witness 2, Curr))\n * cell (var (Witness 3, Curr))\n + cell (var (Witness 1, Curr))\n * cell (var (Witness 4, Curr))\n + cell (var (Witness 2, Next))\n * cell (var (Coefficient 3, Curr))\n + cell (var (Witness 4, Next))\n * cell (var (Coefficient 1, Curr))\n + cell (var (Witness 3, Next))\n * cell (var (Coefficient 2, Curr))\n + ( field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n * cell (var (Witness 7, Next))\n + cell (var (Witness 6, Next)) )\n + cell (var (Witness 11, Next))\n - cell (var (Witness 1, Next)) ) )\n + alpha_pow 10\n * ( cell (var (Witness 5, Next))\n - ( cell (var (Witness 4, Next))\n + field\n \"0x0000000000000000000000000000000000000000010000000000000000000000\"\n - cell (var (Coefficient 0, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( Xor\n , (fun () ->\n cell (var (Index Xor16, Curr))\n * ( cell (var (Witness 3, Curr))\n + cell (var (Witness 4, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 4 )\n + cell (var (Witness 5, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 8 )\n + cell (var (Witness 6, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 12 )\n + pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 16 )\n * cell (var (Witness 0, Next))\n - cell (var (Witness 0, Curr))\n + alpha_pow 1\n * ( cell (var (Witness 7, Curr))\n + cell (var (Witness 8, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 4 )\n + cell (var (Witness 9, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 8 )\n + cell (var (Witness 10, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 12 )\n + pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 16 )\n * cell (var (Witness 1, Next))\n - cell (var (Witness 1, Curr)) )\n + alpha_pow 2\n * ( cell (var (Witness 11, Curr))\n + cell (var (Witness 12, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 4 )\n + cell (var (Witness 13, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 8 )\n + cell (var (Witness 14, Curr))\n * pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 12 )\n + pow\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n , 16 )\n * cell (var (Witness 2, Next))\n - cell (var (Witness 2, Curr)) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( Rot\n , (fun () ->\n cell (var (Index Rot64, Curr))\n * ( cell (var (Witness 7, Curr))\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 7, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n + alpha_pow 1\n * ( cell (var (Witness 8, Curr))\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 8, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 2\n * ( cell (var (Witness 9, Curr))\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 9, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 3\n * ( cell (var (Witness 10, Curr))\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 10, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 4\n * ( cell (var (Witness 11, Curr))\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 11, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 5\n * ( cell (var (Witness 12, Curr))\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 12, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 6\n * ( cell (var (Witness 13, Curr))\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 13, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 7\n * ( cell (var (Witness 14, Curr))\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000002\"\n )\n * ( cell (var (Witness 14, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n ) )\n + alpha_pow 8\n * ( cell (var (Witness 0, Curr))\n * cell (var (Coefficient 0, Curr))\n - ( cell (var (Witness 2, Curr))\n * field\n \"0x0000000000000000000000000000000000000000000000010000000000000000\"\n + cell (var (Witness 0, Next)) ) )\n + alpha_pow 9\n * ( cell (var (Witness 1, Curr))\n - (cell (var (Witness 0, Next)) + cell (var (Witness 2, Curr)))\n )\n + alpha_pow 10\n * ( cell (var (Witness 14, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 5, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 4, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000000004\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * field\n \"0x0000000000000000000000000000000000000000000000000000000000001000\"\n * cell (var (Witness 3, Curr))\n - ( cell (var (Witness 2, Curr))\n - cell (var (Coefficient 0, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000010000000000000000\"\n ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + cell (var (Index Generic, Curr))\n * ( (cell (var (Coefficient 0, Curr)) * cell (var (Witness 0, Curr)))\n + (cell (var (Coefficient 1, Curr)) * cell (var (Witness 1, Curr)))\n + (cell (var (Coefficient 2, Curr)) * cell (var (Witness 2, Curr)))\n + cell (var (Coefficient 3, Curr))\n * cell (var (Witness 0, Curr))\n * cell (var (Witness 1, Curr))\n + cell (var (Coefficient 4, Curr))\n + alpha_pow 1\n * ( (cell (var (Coefficient 5, Curr)) * cell (var (Witness 3, Curr)))\n + (cell (var (Coefficient 6, Curr)) * cell (var (Witness 4, Curr)))\n + (cell (var (Coefficient 7, Curr)) * cell (var (Witness 5, Curr)))\n + cell (var (Coefficient 8, Curr))\n * cell (var (Witness 3, Curr))\n * cell (var (Witness 4, Curr))\n + cell (var (Coefficient 9, Curr)) ) )\n + if_feature\n ( LookupTables\n , (fun () ->\n alpha_pow 24\n * ( vanishes_on_zero_knowledge_and_previous_rows\n * ( cell (var (LookupAggreg, Next))\n * ( if_feature\n ( LookupsPerRow 0\n , (fun () ->\n gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupSorted 0, Curr))\n + (beta * cell (var (LookupSorted 0, Next))) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 1\n , (fun () ->\n gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupSorted 1, Next))\n + (beta * cell (var (LookupSorted 1, Curr))) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupSorted 2, Curr))\n + (beta * cell (var (LookupSorted 2, Next))) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupSorted 3, Next))\n + (beta * cell (var (LookupSorted 3, Curr))) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupSorted 4, Curr))\n + (beta * cell (var (LookupSorted 4, Next))) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n - cell (var (LookupAggreg, Curr))\n * ( ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n - ( if_feature\n ( LookupPattern Xor\n , (fun () ->\n cell (var (LookupKindIndex Xor, Curr)) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern Lookup\n , (fun () ->\n cell (var (LookupKindIndex Lookup, Curr)) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern RangeCheck\n , (fun () ->\n cell (var (LookupKindIndex RangeCheck, Curr))\n )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern ForeignFieldMul\n , (fun () ->\n cell\n (var\n (LookupKindIndex ForeignFieldMul, Curr) )\n )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n ) ) )\n * ( if_feature\n ( LookupsPerRow 1\n , (fun () -> gamma)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 2\n , (fun () -> gamma)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () -> gamma)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () -> gamma)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n + if_feature\n ( LookupPattern Xor\n , (fun () ->\n cell (var (LookupKindIndex Xor, Curr))\n * ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( gamma\n + ( joint_combiner\n * ( joint_combiner\n * cell (var (Witness 11, Curr))\n + cell (var (Witness 7, Curr)) )\n + cell (var (Witness 3, Curr)) ) )\n * ( gamma\n + ( joint_combiner\n * ( joint_combiner\n * cell (var (Witness 12, Curr))\n + cell (var (Witness 8, Curr)) )\n + cell (var (Witness 4, Curr)) ) )\n * ( gamma\n + ( joint_combiner\n * ( joint_combiner\n * cell (var (Witness 13, Curr))\n + cell (var (Witness 9, Curr)) )\n + cell (var (Witness 5, Curr)) ) )\n * ( gamma\n + ( joint_combiner\n * ( joint_combiner\n * cell (var (Witness 14, Curr))\n + cell (var (Witness 10, Curr)) )\n + cell (var (Witness 6, Curr)) ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern Lookup\n , (fun () ->\n cell (var (LookupKindIndex Lookup, Curr))\n * ( if_feature\n ( LookupsPerRow 4\n , (fun () -> gamma)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n * ( gamma\n + ( joint_combiner\n * cell (var (Witness 2, Curr))\n + cell (var (Witness 1, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 0, Curr)) ) )\n * ( gamma\n + ( joint_combiner\n * cell (var (Witness 4, Curr))\n + cell (var (Witness 3, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 0, Curr)) ) )\n * ( gamma\n + ( joint_combiner\n * cell (var (Witness 6, Curr))\n + cell (var (Witness 5, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 0, Curr)) ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern RangeCheck\n , (fun () ->\n cell (var (LookupKindIndex RangeCheck, Curr))\n * ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( gamma\n + ( cell (var (Witness 3, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 4, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 5, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 6, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + if_feature\n ( LookupPattern ForeignFieldMul\n , (fun () ->\n cell (var (LookupKindIndex ForeignFieldMul, Curr))\n * ( ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + beta )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * ( gamma\n + ( cell (var (Witness 7, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 8, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 9, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) )\n * ( gamma\n + ( cell (var (Witness 10, Curr))\n + joint_combiner\n * if_feature\n ( TableWidth 2\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * if_feature\n ( TableWidth 3\n , (fun () -> joint_combiner)\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) ) ) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n ) )\n * ( gamma\n * ( beta\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n + cell (var (LookupTable, Curr))\n + (beta * cell (var (LookupTable, Next))) ) ) ) )\n + alpha_pow 25\n * ( unnormalized_lagrange_basis 0\n * ( cell (var (LookupAggreg, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n + alpha_pow 26\n * ( unnormalized_lagrange_basis (-4)\n * ( cell (var (LookupAggreg, Curr))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n + alpha_pow 27\n * if_feature\n ( LookupsPerRow 1\n , (fun () ->\n unnormalized_lagrange_basis (-4)\n * ( cell (var (LookupSorted 0, Curr))\n - cell (var (LookupSorted 1, Curr)) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + alpha_pow 28\n * if_feature\n ( LookupsPerRow 2\n , (fun () ->\n unnormalized_lagrange_basis 0\n * ( cell (var (LookupSorted 1, Curr))\n - cell (var (LookupSorted 2, Curr)) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + alpha_pow 29\n * if_feature\n ( LookupsPerRow 3\n , (fun () ->\n unnormalized_lagrange_basis (-4)\n * ( cell (var (LookupSorted 2, Curr))\n - cell (var (LookupSorted 3, Curr)) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + alpha_pow 30\n * if_feature\n ( LookupsPerRow 4\n , (fun () ->\n unnormalized_lagrange_basis 0\n * ( cell (var (LookupSorted 3, Curr))\n - cell (var (LookupSorted 4, Curr)) ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n + alpha_pow 31\n * if_feature\n ( RuntimeLookupTables\n , (fun () ->\n cell (var (LookupRuntimeTable, Curr))\n * cell (var (LookupRuntimeSelector, Curr)) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n ) )\n , fun () ->\n field\n \"0x0000000000000000000000000000000000000000000000000000000000000000\"\n )\n\n let index_terms (type a) (_ : a Env.t) = Column.Table.of_alist_exn []\nend\n\nmodule Tock : S = struct\n let constant_term (type a)\n ({ add = ( + )\n ; sub = ( - )\n ; mul = ( * )\n ; square\n ; mds\n ; endo_coefficient\n ; pow\n ; var\n ; field\n ; cell\n ; alpha_pow\n ; double\n ; zk_polynomial = _\n ; omega_to_minus_3 = _\n ; zeta_to_n_minus_1 = _\n ; srs_length_log2 = _\n ; vanishes_on_zero_knowledge_and_previous_rows = _\n ; joint_combiner = _\n ; beta = _\n ; gamma = _\n ; unnormalized_lagrange_basis = _\n ; if_feature = _\n } :\n a Env.t ) =\n let x_0 = pow (cell (var (Witness 0, Curr)), 7) in\n let x_1 = pow (cell (var (Witness 1, Curr)), 7) in\n let x_2 = pow (cell (var (Witness 2, Curr)), 7) in\n let x_3 = pow (cell (var (Witness 6, Curr)), 7) in\n let x_4 = pow (cell (var (Witness 7, Curr)), 7) in\n let x_5 = pow (cell (var (Witness 8, Curr)), 7) in\n let x_6 = pow (cell (var (Witness 9, Curr)), 7) in\n let x_7 = pow (cell (var (Witness 10, Curr)), 7) in\n let x_8 = pow (cell (var (Witness 11, Curr)), 7) in\n let x_9 = pow (cell (var (Witness 12, Curr)), 7) in\n let x_10 = pow (cell (var (Witness 13, Curr)), 7) in\n let x_11 = pow (cell (var (Witness 14, Curr)), 7) in\n let x_12 = pow (cell (var (Witness 3, Curr)), 7) in\n let x_13 = pow (cell (var (Witness 4, Curr)), 7) in\n let x_14 = pow (cell (var (Witness 5, Curr)), 7) in\n let x_15 = cell (var (Witness 7, Next)) * cell (var (Witness 7, Next)) in\n let x_16 =\n let x_15 = cell (var (Witness 7, Next)) * cell (var (Witness 7, Next)) in\n cell (var (Witness 2, Curr))\n - (x_15 - cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_17 =\n let x_16 =\n let x_15 =\n cell (var (Witness 7, Next)) * cell (var (Witness 7, Next))\n in\n cell (var (Witness 2, Curr))\n - (x_15 - cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 3, Curr)))\n - (x_16 * cell (var (Witness 7, Next)))\n in\n let x_18 = cell (var (Witness 8, Next)) * cell (var (Witness 8, Next)) in\n let x_19 =\n let x_18 = cell (var (Witness 8, Next)) * cell (var (Witness 8, Next)) in\n cell (var (Witness 7, Curr))\n - (x_18 - cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_20 =\n let x_19 =\n let x_18 =\n cell (var (Witness 8, Next)) * cell (var (Witness 8, Next))\n in\n cell (var (Witness 7, Curr))\n - (x_18 - cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 8, Curr)))\n - (x_19 * cell (var (Witness 8, Next)))\n in\n let x_21 = cell (var (Witness 9, Next)) * cell (var (Witness 9, Next)) in\n let x_22 =\n let x_21 = cell (var (Witness 9, Next)) * cell (var (Witness 9, Next)) in\n cell (var (Witness 9, Curr))\n - (x_21 - cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_23 =\n let x_22 =\n let x_21 =\n cell (var (Witness 9, Next)) * cell (var (Witness 9, Next))\n in\n cell (var (Witness 9, Curr))\n - (x_21 - cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 10, Curr)))\n - (x_22 * cell (var (Witness 9, Next)))\n in\n let x_24 = cell (var (Witness 10, Next)) * cell (var (Witness 10, Next)) in\n let x_25 =\n let x_24 =\n cell (var (Witness 10, Next)) * cell (var (Witness 10, Next))\n in\n cell (var (Witness 11, Curr))\n - (x_24 - cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_26 =\n let x_25 =\n let x_24 =\n cell (var (Witness 10, Next)) * cell (var (Witness 10, Next))\n in\n cell (var (Witness 11, Curr))\n - (x_24 - cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 12, Curr)))\n - (x_25 * cell (var (Witness 10, Next)))\n in\n let x_27 = cell (var (Witness 11, Next)) * cell (var (Witness 11, Next)) in\n let x_28 =\n let x_27 =\n cell (var (Witness 11, Next)) * cell (var (Witness 11, Next))\n in\n cell (var (Witness 13, Curr))\n - (x_27 - cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n in\n let x_29 =\n let x_28 =\n let x_27 =\n cell (var (Witness 11, Next)) * cell (var (Witness 11, Next))\n in\n cell (var (Witness 13, Curr))\n - (x_27 - cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n in\n double (cell (var (Witness 14, Curr)))\n - (x_28 * cell (var (Witness 11, Next)))\n in\n let x_30 = cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)) in\n let x_31 = cell (var (Witness 3, Curr)) - cell (var (Witness 1, Curr)) in\n let x_32 = cell (var (Witness 0, Curr)) * cell (var (Witness 0, Curr)) in\n let x_33 =\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + cell (var (Witness 11, Curr))\n * ( endo_coefficient\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n * cell (var (Witness 0, Curr))\n in\n let x_34 =\n ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n + cell (var (Witness 13, Curr))\n * ( endo_coefficient\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n ) )\n * cell (var (Witness 0, Curr))\n in\n let x_35 = square (cell (var (Witness 9, Curr))) in\n let x_36 = square (cell (var (Witness 10, Curr))) in\n let x_37 = cell (var (Witness 4, Curr)) - cell (var (Witness 7, Curr)) in\n let x_38 = cell (var (Witness 7, Curr)) - cell (var (Witness 4, Next)) in\n let x_39 = cell (var (Witness 5, Next)) + cell (var (Witness 8, Curr)) in\n let x_40 = cell (var (Witness 8, Curr)) + cell (var (Witness 5, Curr)) in\n let x_41 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 6, Curr))\n in\n let x_42 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 7, Curr))\n in\n let x_43 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 8, Curr))\n in\n let x_44 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 9, Curr))\n in\n let x_45 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 10, Curr))\n in\n let x_46 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 11, Curr))\n in\n let x_47 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 12, Curr))\n in\n let x_48 =\n ( ( field\n \"0x1555555555555555555555555555555560C232FEADDC3849D96CF90B00000001\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x2000000000000000000000000000000011234C7E04CA546EC62375907FFFFFFE\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x0AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB061197F56EE1C24ECB67C8580000002\"\n )\n * cell (var (Witness 13, Curr))\n in\n cell (var (Index Poseidon, Curr))\n * ( cell (var (Witness 6, Curr))\n - ( cell (var (Coefficient 0, Curr))\n + (mds (0, 0) * x_0)\n + (mds (0, 1) * x_1)\n + (mds (0, 2) * x_2) )\n + alpha_pow 1\n * ( cell (var (Witness 7, Curr))\n - ( cell (var (Coefficient 1, Curr))\n + (mds (1, 0) * x_0)\n + (mds (1, 1) * x_1)\n + (mds (1, 2) * x_2) ) )\n + alpha_pow 2\n * ( cell (var (Witness 8, Curr))\n - ( cell (var (Coefficient 2, Curr))\n + (mds (2, 0) * x_0)\n + (mds (2, 1) * x_1)\n + (mds (2, 2) * x_2) ) )\n + alpha_pow 3\n * ( cell (var (Witness 9, Curr))\n - ( cell (var (Coefficient 3, Curr))\n + (mds (0, 0) * x_3)\n + (mds (0, 1) * x_4)\n + (mds (0, 2) * x_5) ) )\n + alpha_pow 4\n * ( cell (var (Witness 10, Curr))\n - ( cell (var (Coefficient 4, Curr))\n + (mds (1, 0) * x_3)\n + (mds (1, 1) * x_4)\n + (mds (1, 2) * x_5) ) )\n + alpha_pow 5\n * ( cell (var (Witness 11, Curr))\n - ( cell (var (Coefficient 5, Curr))\n + (mds (2, 0) * x_3)\n + (mds (2, 1) * x_4)\n + (mds (2, 2) * x_5) ) )\n + alpha_pow 6\n * ( cell (var (Witness 12, Curr))\n - ( cell (var (Coefficient 6, Curr))\n + (mds (0, 0) * x_6)\n + (mds (0, 1) * x_7)\n + (mds (0, 2) * x_8) ) )\n + alpha_pow 7\n * ( cell (var (Witness 13, Curr))\n - ( cell (var (Coefficient 7, Curr))\n + (mds (1, 0) * x_6)\n + (mds (1, 1) * x_7)\n + (mds (1, 2) * x_8) ) )\n + alpha_pow 8\n * ( cell (var (Witness 14, Curr))\n - ( cell (var (Coefficient 8, Curr))\n + (mds (2, 0) * x_6)\n + (mds (2, 1) * x_7)\n + (mds (2, 2) * x_8) ) )\n + alpha_pow 9\n * ( cell (var (Witness 3, Curr))\n - ( cell (var (Coefficient 9, Curr))\n + (mds (0, 0) * x_9)\n + (mds (0, 1) * x_10)\n + (mds (0, 2) * x_11) ) )\n + alpha_pow 10\n * ( cell (var (Witness 4, Curr))\n - ( cell (var (Coefficient 10, Curr))\n + (mds (1, 0) * x_9)\n + (mds (1, 1) * x_10)\n + (mds (1, 2) * x_11) ) )\n + alpha_pow 11\n * ( cell (var (Witness 5, Curr))\n - ( cell (var (Coefficient 11, Curr))\n + (mds (2, 0) * x_9)\n + (mds (2, 1) * x_10)\n + (mds (2, 2) * x_11) ) )\n + alpha_pow 12\n * ( cell (var (Witness 0, Next))\n - ( cell (var (Coefficient 12, Curr))\n + (mds (0, 0) * x_12)\n + (mds (0, 1) * x_13)\n + (mds (0, 2) * x_14) ) )\n + alpha_pow 13\n * ( cell (var (Witness 1, Next))\n - ( cell (var (Coefficient 13, Curr))\n + (mds (1, 0) * x_12)\n + (mds (1, 1) * x_13)\n + (mds (1, 2) * x_14) ) )\n + alpha_pow 14\n * ( cell (var (Witness 2, Next))\n - ( cell (var (Coefficient 14, Curr))\n + (mds (2, 0) * x_12)\n + (mds (2, 1) * x_13)\n + (mds (2, 2) * x_14) ) ) )\n + cell (var (Index VarBaseMul, Curr))\n * ( cell (var (Witness 5, Curr))\n - ( cell (var (Witness 6, Next))\n + double\n ( cell (var (Witness 5, Next))\n + double\n ( cell (var (Witness 4, Next))\n + double\n ( cell (var (Witness 3, Next))\n + double\n ( cell (var (Witness 2, Next))\n + double (cell (var (Witness 4, Curr))) ) ) ) ) )\n + alpha_pow 1\n * ( square (cell (var (Witness 2, Next)))\n - cell (var (Witness 2, Next)) )\n + alpha_pow 2\n * ( (cell (var (Witness 2, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 7, Next))\n - ( cell (var (Witness 3, Curr))\n - ( double (cell (var (Witness 2, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 3\n * ( (x_17 * x_17)\n - x_16 * x_16\n * ( cell (var (Witness 7, Curr))\n - cell (var (Witness 0, Curr))\n + x_15 ) )\n + alpha_pow 4\n * ( (cell (var (Witness 8, Curr)) + cell (var (Witness 3, Curr)))\n * x_16\n - (cell (var (Witness 2, Curr)) - cell (var (Witness 7, Curr)))\n * x_17 )\n + alpha_pow 5\n * ( square (cell (var (Witness 3, Next)))\n - cell (var (Witness 3, Next)) )\n + alpha_pow 6\n * ( (cell (var (Witness 7, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 8, Next))\n - ( cell (var (Witness 8, Curr))\n - ( double (cell (var (Witness 3, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 7\n * ( (x_20 * x_20)\n - x_19 * x_19\n * ( cell (var (Witness 9, Curr))\n - cell (var (Witness 0, Curr))\n + x_18 ) )\n + alpha_pow 8\n * ( (cell (var (Witness 10, Curr)) + cell (var (Witness 8, Curr)))\n * x_19\n - (cell (var (Witness 7, Curr)) - cell (var (Witness 9, Curr)))\n * x_20 )\n + alpha_pow 9\n * ( square (cell (var (Witness 4, Next)))\n - cell (var (Witness 4, Next)) )\n + alpha_pow 10\n * ( (cell (var (Witness 9, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 9, Next))\n - ( cell (var (Witness 10, Curr))\n - ( double (cell (var (Witness 4, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 11\n * ( (x_23 * x_23)\n - x_22 * x_22\n * ( cell (var (Witness 11, Curr))\n - cell (var (Witness 0, Curr))\n + x_21 ) )\n + alpha_pow 12\n * ( (cell (var (Witness 12, Curr)) + cell (var (Witness 10, Curr)))\n * x_22\n - (cell (var (Witness 9, Curr)) - cell (var (Witness 11, Curr)))\n * x_23 )\n + alpha_pow 13\n * ( square (cell (var (Witness 5, Next)))\n - cell (var (Witness 5, Next)) )\n + alpha_pow 14\n * ( (cell (var (Witness 11, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 10, Next))\n - ( cell (var (Witness 12, Curr))\n - ( double (cell (var (Witness 5, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 15\n * ( (x_26 * x_26)\n - x_25 * x_25\n * ( cell (var (Witness 13, Curr))\n - cell (var (Witness 0, Curr))\n + x_24 ) )\n + alpha_pow 16\n * ( (cell (var (Witness 14, Curr)) + cell (var (Witness 12, Curr)))\n * x_25\n - (cell (var (Witness 11, Curr)) - cell (var (Witness 13, Curr)))\n * x_26 )\n + alpha_pow 17\n * ( square (cell (var (Witness 6, Next)))\n - cell (var (Witness 6, Next)) )\n + alpha_pow 18\n * ( (cell (var (Witness 13, Curr)) - cell (var (Witness 0, Curr)))\n * cell (var (Witness 11, Next))\n - ( cell (var (Witness 14, Curr))\n - ( double (cell (var (Witness 6, Next)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr)) ) )\n + alpha_pow 19\n * ( (x_29 * x_29)\n - x_28 * x_28\n * ( cell (var (Witness 0, Next))\n - cell (var (Witness 0, Curr))\n + x_27 ) )\n + alpha_pow 20\n * ( (cell (var (Witness 1, Next)) + cell (var (Witness 14, Curr)))\n * x_28\n - (cell (var (Witness 13, Curr)) - cell (var (Witness 0, Next)))\n * x_29 ) )\n + cell (var (Index CompleteAdd, Curr))\n * ( (cell (var (Witness 10, Curr)) * x_30)\n - ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n - cell (var (Witness 7, Curr)) )\n + (alpha_pow 1 * (cell (var (Witness 7, Curr)) * x_30))\n + alpha_pow 2\n * ( cell (var (Witness 7, Curr))\n * ( double (cell (var (Witness 8, Curr)))\n * cell (var (Witness 1, Curr))\n - double x_32 - x_32 )\n + ( field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n - cell (var (Witness 7, Curr)) )\n * ((x_30 * cell (var (Witness 8, Curr))) - x_31) )\n + alpha_pow 3\n * ( cell (var (Witness 0, Curr))\n + cell (var (Witness 2, Curr))\n + cell (var (Witness 4, Curr))\n - (cell (var (Witness 8, Curr)) * cell (var (Witness 8, Curr))) )\n + alpha_pow 4\n * ( cell (var (Witness 8, Curr))\n * (cell (var (Witness 0, Curr)) - cell (var (Witness 4, Curr)))\n - cell (var (Witness 1, Curr))\n - cell (var (Witness 5, Curr)) )\n + alpha_pow 5\n * ( x_31\n * (cell (var (Witness 7, Curr)) - cell (var (Witness 6, Curr))) )\n + alpha_pow 6\n * ( (x_31 * cell (var (Witness 9, Curr)))\n - cell (var (Witness 6, Curr)) ) )\n + cell (var (Index EndoMul, Curr))\n * ( square (cell (var (Witness 11, Curr)))\n - cell (var (Witness 11, Curr))\n + alpha_pow 1\n * ( square (cell (var (Witness 12, Curr)))\n - cell (var (Witness 12, Curr)) )\n + alpha_pow 2\n * ( square (cell (var (Witness 13, Curr)))\n - cell (var (Witness 13, Curr)) )\n + alpha_pow 3\n * ( square (cell (var (Witness 14, Curr)))\n - cell (var (Witness 14, Curr)) )\n + alpha_pow 4\n * ( (x_33 - cell (var (Witness 4, Curr)))\n * cell (var (Witness 9, Curr))\n - ( ( double (cell (var (Witness 12, Curr)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr))\n - cell (var (Witness 5, Curr)) ) )\n + alpha_pow 5\n * ( (double (cell (var (Witness 4, Curr))) - x_35 + x_33)\n * ((x_37 * cell (var (Witness 9, Curr))) + x_40)\n - (double (cell (var (Witness 5, Curr))) * x_37) )\n + alpha_pow 6\n * ( square x_40\n - (square x_37 * (x_35 - x_33 + cell (var (Witness 7, Curr)))) )\n + alpha_pow 7\n * ( (x_34 - cell (var (Witness 7, Curr)))\n * cell (var (Witness 10, Curr))\n - ( ( double (cell (var (Witness 14, Curr)))\n - field\n \"0x0000000000000000000000000000000000000000000000000000000000000001\"\n )\n * cell (var (Witness 1, Curr))\n - cell (var (Witness 8, Curr)) ) )\n + alpha_pow 8\n * ( (double (cell (var (Witness 7, Curr))) - x_36 + x_34)\n * ((x_38 * cell (var (Witness 10, Curr))) + x_39)\n - (double (cell (var (Witness 8, Curr))) * x_38) )\n + alpha_pow 9\n * ( square x_39\n - (square x_38 * (x_36 - x_34 + cell (var (Witness 4, Next)))) )\n + alpha_pow 10\n * ( double\n ( double\n ( double\n ( double (cell (var (Witness 6, Curr)))\n + cell (var (Witness 11, Curr)) )\n + cell (var (Witness 12, Curr)) )\n + cell (var (Witness 13, Curr)) )\n + cell (var (Witness 14, Curr))\n - cell (var (Witness 6, Next)) ) )\n + cell (var (Index EndoMulScalar, Curr))\n * ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n ( double\n (double\n (cell\n (var\n ( Witness 0\n , Curr ) ) ) )\n + cell\n (var\n (Witness 6, Curr) )\n ) )\n + cell (var (Witness 7, Curr))\n ) )\n + cell (var (Witness 8, Curr)) ) )\n + cell (var (Witness 9, Curr)) ) )\n + cell (var (Witness 10, Curr)) ) )\n + cell (var (Witness 11, Curr)) ) )\n + cell (var (Witness 12, Curr)) ) )\n + cell (var (Witness 13, Curr))\n - cell (var (Witness 1, Curr))\n + alpha_pow 1\n * ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double (cell (var (Witness 2, Curr)))\n + x_41 )\n + x_42 )\n + x_43 )\n + x_44 )\n + x_45 )\n + x_46 )\n + x_47 )\n + x_48\n - cell (var (Witness 4, Curr)) )\n + alpha_pow 2\n * ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double\n ( double (cell (var (Witness 3, Curr)))\n + ( x_41\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 6, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_42\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 7, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_43\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 8, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_44\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 9, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_45\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 10, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_46\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 11, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_47\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 12, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) ) )\n + ( x_48\n + ( ( field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n * cell (var (Witness 13, Curr))\n + field\n \"0x0000000000000000000000000000000000000000000000000000000000000003\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB2100000000\"\n ) )\n - cell (var (Witness 5, Curr)) )\n + alpha_pow 3\n * ( ( ( ( cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 6, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 6, Curr)) )\n + alpha_pow 4\n * ( ( ( ( cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 7, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 7, Curr)) )\n + alpha_pow 5\n * ( ( ( ( cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 8, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 8, Curr)) )\n + alpha_pow 6\n * ( ( ( ( cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 9, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 9, Curr)) )\n + alpha_pow 7\n * ( ( ( ( cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 10, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 10, Curr)) )\n + alpha_pow 8\n * ( ( ( ( cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 11, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 11, Curr)) )\n + alpha_pow 9\n * ( ( ( ( cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 12, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 12, Curr)) )\n + alpha_pow 10\n * ( ( ( ( cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x000000000000000000000000000000000000000000000000000000000000000B\"\n )\n * cell (var (Witness 13, Curr))\n + field\n \"0x40000000000000000000000000000000224698FC0994A8DD8C46EB20FFFFFFFB\"\n )\n * cell (var (Witness 13, Curr)) ) )\n + cell (var (Index Generic, Curr))\n * ( (cell (var (Coefficient 0, Curr)) * cell (var (Witness 0, Curr)))\n + (cell (var (Coefficient 1, Curr)) * cell (var (Witness 1, Curr)))\n + (cell (var (Coefficient 2, Curr)) * cell (var (Witness 2, Curr)))\n + cell (var (Coefficient 3, Curr))\n * cell (var (Witness 0, Curr))\n * cell (var (Witness 1, Curr))\n + cell (var (Coefficient 4, Curr))\n + alpha_pow 1\n * ( (cell (var (Coefficient 5, Curr)) * cell (var (Witness 3, Curr)))\n + (cell (var (Coefficient 6, Curr)) * cell (var (Witness 4, Curr)))\n + (cell (var (Coefficient 7, Curr)) * cell (var (Witness 5, Curr)))\n + cell (var (Coefficient 8, Curr))\n * cell (var (Witness 3, Curr))\n * cell (var (Witness 4, Curr))\n + cell (var (Coefficient 9, Curr)) ) )\n\n let index_terms (type a) (_ : a Env.t) = Column.Table.of_alist_exn []\nend\n","let commit_id = \"[DIRTY]135a53e79bf45642d46cbda07cbc5e29ebc460a9\"\nlet commit_id_short = \"135a53e7\"\nlet branch = \"develop-20230927-temporary\"\nlet commit_date = \"2023-10-03T21:12:09+02:00\"\nlet marlin_commit_id = \"e54a121ad7eff0c510d38cde99425e3649cddc89\"\nlet marlin_commit_id_short = \"e54a121a\"\nlet marlin_commit_date = \"2023-09-27T17:29:38+02:00\"\nlet print_version () = Core_kernel.printf \"Commit %s on branch %s\\n%!\" commit_id branch\n","module Field_intf = struct\n module type Basic = sig\n type t\n\n val ( * ) : t -> t -> t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val inv_exn : t -> t\n\n val negate : t -> t\n\n val square : t -> t\n end\n\n module type Constant = sig\n include Basic\n end\n\n module type Checked = sig\n type field\n\n type bool\n\n include Basic\n\n val if_ : bool -> then_:t -> else_:t -> t\n\n val scale : t -> field -> t\n end\nend\n\nmodule type Constant_intf = sig\n type field\n\n type t\n\n val random : unit -> t\n\n val to_affine_exn : t -> field * field\n\n val of_affine : field * field -> t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\nend\n\nmodule type Inputs_intf = sig\n module Impl : Snarky_backendless.Snark_intf.Run\n\n module F : sig\n include\n Field_intf.Checked\n with type bool := Impl.Boolean.var\n and type field := Impl.field\n\n module Constant : Field_intf.Constant\n\n val assert_square : t -> t -> unit\n\n val assert_r1cs : t -> t -> t -> unit\n\n val typ : (t, Constant.t) Impl.Typ.t\n\n val constant : Constant.t -> t\n end\n\n module Constant : Constant_intf with type field := F.Constant.t\n\n module Params : sig\n val one : F.Constant.t * F.Constant.t\n\n val group_size_in_bits : int\n\n val a : F.Constant.t\n\n val b : F.Constant.t\n end\nend\n\nmodule Make_checked (Inputs : Inputs_intf) = struct\n open Inputs\n open Impl\n\n type t = F.t * F.t\n\n let double ((ax, ay) : t) : t =\n let open F in\n (* A: 1\n B: 1\n C: 1 *)\n let x_squared = square ax in\n let lambda =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n let x_squared = read typ x_squared in\n let ay = read typ ay in\n let open F.Constant in\n (x_squared + x_squared + x_squared + Params.a) * inv_exn (ay + ay))\n in\n let bx =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n let lambda = read typ lambda in\n let ax = read typ ax in\n let open F.Constant in\n square lambda - (ax + ax))\n in\n let by =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n let lambda = read typ lambda\n and ax = read typ ax\n and ay = read typ ay\n and bx = read typ bx in\n F.Constant.((lambda * (ax - bx)) - ay))\n in\n let two = Field.Constant.of_int 2 in\n (* A: 1\n B: 1\n C: 2 *)\n assert_r1cs (F.scale lambda two) ay\n (F.scale x_squared (Field.Constant.of_int 3) + F.constant Params.a) ;\n (* A: 1\n B: 1\n C: 2\n *)\n assert_square lambda (bx + F.scale ax two) ;\n (* A: 1\n B: 2\n C: 2\n *)\n assert_r1cs lambda (ax - bx) (by + ay) ;\n (* Overall:\n A: 4\n B: 5\n C: 7 *)\n (bx, by)\n\n let add' ~div (ax, ay) (bx, by) : t =\n let open F in\n (*\n lambda * (bx - ax) = (by - ay)\n\n A: 1\n B: 2\n C: 2\n *)\n let lambda = div (by - ay) (bx - ax) in\n let cx =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n let ax = read typ ax\n and bx = read typ bx\n and lambda = read typ lambda in\n Constant.(square lambda - (ax + bx)))\n in\n\n (* lambda^2 = cx + ax + bx\n\n A: 1\n B: 1\n C: 3\n *)\n assert_square lambda F.(cx + ax + bx) ;\n let cy =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n let ax = read typ ax\n and ay = read typ ay\n and cx = read typ cx\n and lambda = read typ lambda in\n Constant.((lambda * (ax - cx)) - ay))\n in\n (* A: 1\n B: 2\n C: 2 *)\n assert_r1cs lambda (ax - cx) (cy + ay) ;\n (* Overall\n A: 2\n B: 5\n C: 7 *)\n (cx, cy)\n\n let add_exn p q = add' ~div:(fun x y -> F.(inv_exn y * x)) p q\n\n let to_affine_exn x = x\n\n let constant t =\n let x, y = Constant.to_affine_exn t in\n (F.constant x, F.constant y)\n\n let negate (x, y) = (x, F.negate y)\n\n let one =\n let x, y = Params.one in\n F.(constant x, constant y)\n\n let assert_on_curve (x, y) =\n let open F in\n let x2 = square x in\n let x3 = x2 * x in\n let ax = constant Params.a * x in\n assert_square y (x3 + ax + constant Params.b)\n\n let typ_unchecked : (t, Constant.t) Typ.t =\n Typ.transport\n Typ.(tuple2 F.typ F.typ)\n ~there:Constant.to_affine_exn ~back:Constant.of_affine\n\n let typ : (t, Constant.t) Typ.t =\n let (Typ typ_unchecked) = typ_unchecked in\n Typ\n { typ_unchecked with\n check = (fun t -> Impl.make_checked (fun () -> assert_on_curve t))\n }\n\n let if_ c ~then_:(tx, ty) ~else_:(ex, ey) =\n (F.if_ c ~then_:tx ~else_:ex, F.if_ c ~then_:ty ~else_:ey)\n\n open Bitstring_lib.Bitstring\n\n module Scalar = struct\n type t = Boolean.var Lsb_first.t\n\n let of_field = Field.unpack_full\n\n let to_field t = Field.project (Lsb_first.to_list t)\n end\n\n module type Shifted_intf = sig\n type t\n\n val zero : t\n\n val unshift_nonzero : t -> F.t * F.t\n\n val add : t -> F.t * F.t -> t\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t\n end\n\n module Shifted (M : sig\n val shift : t\n end)\n () : Shifted_intf = struct\n type t = F.t * F.t\n\n let zero = M.shift\n\n let unshift_nonzero t = add_exn t (negate M.shift)\n\n let add t pt = add_exn t pt\n\n let if_ = if_\n end\n\n let shifted () =\n let shift = exists typ ~compute:(fun () -> Constant.random ()) in\n let module S =\n Shifted\n (struct\n let shift = shift\n end)\n ()\n in\n (module S : Shifted_intf)\n\n (* This doesn't have great performance because it uses add_exn. Should be optimized *)\n let scale ?init t (c : Boolean.var Bitstring_lib.Bitstring.Lsb_first.t) =\n let (module S) = shifted () in\n let c = Bitstring_lib.Bitstring.Lsb_first.to_list c in\n let rec go i bs0 acc pt =\n match bs0 with\n | [] ->\n acc\n | b :: bs ->\n let acc' =\n let add_pt = S.add acc pt in\n let don't_add_pt = acc in\n S.if_ b ~then_:add_pt ~else_:don't_add_pt\n and pt' = double pt in\n go (i + 1) bs acc' pt'\n in\n let init =\n match init with None -> S.zero | Some init -> S.(add zero init)\n in\n S.unshift_nonzero (go 0 c init t)\nend\n\nmodule type Native_base_field_inputs = sig\n (** Snarky instance to use. *)\n module Impl : Snarky_backendless.Snark_intf.Run\n\n include\n Inputs_intf\n with module Impl := Impl\n and type F.t = Impl.Field.t\n and type F.Constant.t = Impl.field\nend\n\nmodule For_native_base_field (Inputs : Native_base_field_inputs) = struct\n open Core_kernel\n open Inputs\n open Impl\n include Make_checked (Inputs)\n\n module Window_table = struct\n open Tuple_lib\n\n type t = Constant.t Quadruple.t array\n\n let window_size = 2\n\n let windows = (Params.group_size_in_bits + window_size - 1) / window_size\n\n let shift_left_by_window_size =\n let rec go i acc =\n if i = 0 then acc else go (i - 1) Constant.(acc + acc)\n in\n go window_size\n\n (* (create g).(i) = ( unrelated_base^i + 2^{window_size*i} 0 g, unrelated_base^i + 2^{window_size*i} g, unrelated_base^i + 2^{window_size*i} (2 g), unrelated_base^i + 2^{window_size*i} (3 g) ) *)\n let create ~shifts g =\n let pure_windows =\n (* pure_windows.(i) = 2^{window_size * i} ( g, 2 g, 3 g) *)\n let w0 =\n let g2 = Constant.(g + g) in\n let g3 = Constant.(g2 + g) in\n (g, g2, g3)\n in\n let a = Array.init windows ~f:(fun _ -> w0) in\n for i = 1 to windows - 1 do\n a.(i) <- Triple.map ~f:shift_left_by_window_size a.(i - 1)\n done ;\n a\n in\n Array.mapi pure_windows ~f:(fun i (a, b, c) ->\n let shift = shifts.(i) in\n Constant.(shift, shift + a, shift + b, shift + c) )\n end\n\n let pow2s g =\n let n = Window_table.windows + 1 in\n assert (n < Params.group_size_in_bits) ;\n let a = Array.init n ~f:(fun _ -> g) in\n for i = 1 to n - 1 do\n let x = a.(i - 1) in\n a.(i) <- Constant.(x + x)\n done ;\n a\n\n module Scaling_precomputation = struct\n type t =\n { base : Constant.t; shifts : Constant.t array; table : Window_table.t }\n\n let group_map =\n lazy\n (let params =\n Group_map.Params.create (module Field.Constant) Params.{ a; b }\n in\n Group_map.to_group (module Field.Constant) ~params )\n\n let string_to_bits s =\n List.concat_map (String.to_list s) ~f:(fun c ->\n let c = Char.to_int c in\n List.init 8 ~f:(fun i -> (c lsr i) land 1 = 1) )\n\n let create base =\n let unrelated_base =\n let x, y = Constant.to_affine_exn base in\n Digestif.BLAKE2S.digest_string\n Field.Constant.(to_string x ^ \",\" ^ to_string y)\n |> Digestif.BLAKE2S.to_raw_string |> string_to_bits\n |> Field.Constant.project |> Lazy.force group_map |> Constant.of_affine\n in\n let shifts = pow2s unrelated_base in\n { base; shifts; table = Window_table.create ~shifts base }\n end\n\n let add_unsafe =\n let div_unsafe x y =\n let z =\n exists Field.typ\n ~compute:\n As_prover.(fun () -> Field.Constant.( / ) (read_var x) (read_var y))\n in\n (* z = x / y <=> z * y = x *)\n assert_r1cs z y x ; z\n in\n add' ~div:div_unsafe\n\n let lookup_point (b0, b1) (t1, t2, t3, t4) =\n let b0_and_b1 = Boolean.( && ) b0 b1 in\n let lookup_one (a1, a2, a3, a4) =\n let open Field.Constant in\n let ( * ) x b = F.scale b x in\n let ( +^ ) = Field.( + ) in\n F.constant a1\n +^ ((a2 - a1) * (b0 :> Field.t))\n +^ ((a3 - a1) * (b1 :> Field.t))\n +^ ((a4 + a1 - a2 - a3) * (b0_and_b1 :> Field.t))\n in\n let x1, y1 = Constant.to_affine_exn t1\n and x2, y2 = Constant.to_affine_exn t2\n and x3, y3 = Constant.to_affine_exn t3\n and x4, y4 = Constant.to_affine_exn t4 in\n (* This is optimized for Marlin-style constraints. *)\n let seal a =\n let a' = exists Field.typ ~compute:(fun () -> As_prover.read_var a) in\n Field.Assert.equal a a' ; a'\n in\n (seal (lookup_one (x1, x2, x3, x4)), seal (lookup_one (y1, y2, y3, y4)))\n\n let rec pairs = function\n | [] ->\n []\n | x :: y :: xs ->\n (x, y) :: pairs xs\n | [ x ] ->\n [ (x, Boolean.false_) ]\n\n type shifted = { value : t; shift : Constant.t }\n\n let scale_known (pc : Scaling_precomputation.t) bs =\n let bs =\n let bs = Array.of_list bs in\n let num_bits = Array.length bs in\n Array.init\n ((Array.length bs + 1) / 2)\n ~f:(fun i ->\n let get j = if j < num_bits then bs.(j) else Boolean.false_ in\n (get (2 * i), get ((2 * i) + 1)) )\n in\n let windows_required = Array.length bs in\n let terms =\n Array.mapi bs ~f:(fun i bit_pair -> lookup_point bit_pair pc.table.(i))\n in\n let with_shifts = Array.reduce_exn terms ~f:add_unsafe in\n let shift =\n let unrelated_base = pc.shifts.(0) in\n\n (*\n 0b1111... * unrelated_base = (2^windows_required - 1) * unrelated_base\n\n is what we added and need to take away for the final result. *)\n Constant.(pc.shifts.(windows_required) + negate unrelated_base)\n in\n { value = with_shifts; shift }\n\n let unshift { value; shift } =\n add_exn value (constant (Constant.negate shift))\n\n let multiscale_known pairs =\n Array.map pairs ~f:(fun (s, g) -> scale_known g s)\n |> Array.reduce_exn ~f:(fun t1 t2 ->\n { value = add_exn t1.value t2.value\n ; shift = Constant.(t1.shift + t2.shift)\n } )\n |> unshift\n\n let scale_known pc bs = unshift (scale_known pc bs)\n\n (* b ? t : -t *)\n let conditional_negation (b : Boolean.var) (x, y) =\n let y' =\n exists Field.typ\n ~compute:\n As_prover.(\n fun () ->\n if read Boolean.typ b then read Field.typ y\n else Field.Constant.negate (read Field.typ y))\n in\n assert_r1cs y Field.((of_int 2 * (b :> Field.t)) - of_int 1) y' ;\n (x, y')\n\n let p_plus_q_plus_p ((x1, y1) : t) ((x2, y2) : t) =\n let open Field in\n let ( ! ) = As_prover.read typ in\n let lambda_1 =\n exists typ ~compute:Constant.(fun () -> (!y2 - !y1) / (!x2 - !x1))\n in\n let x3 =\n exists typ\n ~compute:Constant.(fun () -> (!lambda_1 * !lambda_1) - !x1 - !x2)\n in\n let lambda_2 =\n exists typ\n ~compute:Constant.(fun () -> (of_int 2 * !y1 / (!x1 - !x3)) - !lambda_1)\n in\n let x4 =\n exists typ\n ~compute:Constant.(fun () -> (!lambda_2 * !lambda_2) - !x3 - !x1)\n in\n let y4 =\n exists typ ~compute:Constant.(fun () -> ((!x1 - !x4) * !lambda_2) - !y1)\n in\n (* Determines lambda_1 *)\n assert_r1cs (x2 - x1) lambda_1 (y2 - y1) ;\n (* Determines x_3 *)\n assert_square lambda_1 (x1 + x2 + x3) ;\n (* Determines lambda_2 *)\n assert_r1cs (x1 - x3) (lambda_1 + lambda_2) (of_int 2 * y1) ;\n (* Determines x4 *)\n assert_square lambda_2 (x3 + x1 + x4) ;\n (* Determines y4 *)\n assert_r1cs (x1 - x4) lambda_2 (y4 + y1) ;\n (x4, y4)\n\n (* Input:\n t, r (LSB)\n\n Output:\n (2*r + 1 + 2^len(r)) t\n *)\n let scale_fast (t : Field.t * Field.t) (`Times_two_plus_1_plus_2_to_len r) :\n Field.t * Field.t =\n let n = Array.length r in\n let acc = ref (double t) in\n let () =\n for i = 0 to n - 1 do\n let q = conditional_negation r.(i) t in\n acc := p_plus_q_plus_p !acc q\n done\n in\n !acc\n\n (* Input:\n t, k (LSB)\n\n Output:\n (k + 2^{len(k) - 1}) t\n\n Based on [Daira's algorithm](https://github.com/zcash/zcash/issues/3924)\n *)\n let scale_fast t (`Plus_two_to_len_minus_1 k) =\n let m = Array.length k - 1 in\n let r = Array.init m ~f:(fun i -> k.(i + 1)) in\n let two_r_plus_1_plus_two_to_m =\n scale_fast t (`Times_two_plus_1_plus_2_to_len r)\n in\n if_ k.(0) ~then_:two_r_plus_1_plus_two_to_m\n ~else_:(add_exn two_r_plus_1_plus_two_to_m (negate t))\n\n let%test_unit \"scale_fast\" =\n let scale_constant (t, bs) =\n let rec go acc bs =\n match bs with\n | [] ->\n acc\n | b :: bs ->\n let acc = Constant.(acc + acc) in\n let acc = if b then Constant.(acc + t) else acc in\n go acc bs\n in\n let k = Array.length bs in\n go Constant.(t + negate t) (List.init k ~f:(fun i -> bs.(k - 1 - i)))\n in\n let module A = struct\n type t = Impl.Field.Constant.t * Impl.Field.Constant.t\n [@@deriving sexp, compare]\n end in\n let one = Constant.of_affine Params.one in\n [%test_eq: A.t]\n (Constant.to_affine_exn Constant.(one + negate one + one))\n Constant.(to_affine_exn one) ;\n [%test_eq: A.t]\n (Constant.to_affine_exn (scale_constant (one, [| true |])))\n Constant.(to_affine_exn one) ;\n [%test_eq: A.t]\n (Constant.to_affine_exn (scale_constant (one, [| false; true |])))\n Constant.(to_affine_exn (one + one)) ;\n [%test_eq: A.t]\n (Constant.to_affine_exn (scale_constant (one, [| true; true |])))\n Constant.(to_affine_exn (one + one + one)) ;\n [%test_eq: A.t]\n (Constant.to_affine_exn (scale_constant (one, [| false; false; true |])))\n Constant.(to_affine_exn (one + one + one + one)) ;\n [%test_eq: A.t]\n (Constant.to_affine_exn (scale_constant (one, [| true; false; true |])))\n Constant.(to_affine_exn (one + one + one + one + one)) ;\n let g = Typ.tuple2 Field.typ Field.typ in\n let two_to_the m =\n scale_constant (one, Array.init (m + 1) ~f:(fun i -> i = m))\n in\n [%test_eq: A.t]\n (Constant.to_affine_exn (two_to_the 2))\n Constant.(to_affine_exn (one + one + one + one)) ;\n let n = 4 in\n let bits = Array.init n ~f:(fun _ -> Random.bool ()) in\n Internal_Basic.Test.test_equal\n ~equal:[%eq: Field.Constant.t * Field.Constant.t]\n ~sexp_of_t:[%sexp_of: Field.Constant.t * Field.Constant.t]\n (Typ.tuple2 g (Typ.array ~length:n Boolean.typ))\n g\n (fun (t, bs) ->\n make_checked (fun () -> scale_fast t (`Plus_two_to_len_minus_1 bs)) )\n (fun (t, bs) ->\n let open Constant in\n let t = of_affine t in\n to_affine_exn (scale_constant (t, bs) + two_to_the (n - 1)) )\n (Params.one, bits)\nend\n","open Core_kernel\n\n(** The string that preceeds the JSON header, to identify the file kind before\n attempting to parse it.\n*)\nlet header_string = \"MINA_SNARK_KEYS\\n\"\n\nmodule UInt64 = struct\n (* [Unsigned_extended] depends on pickles, manually include what we need here\n to break a dependency cycle\n\n TODO: Separate [Unsigned_extended] into snark and non-snark parts.\n *)\n type t = Unsigned.UInt64.t [@@deriving ord, equal]\n\n let to_yojson x = `String (Unsigned.UInt64.to_string x)\n\n let of_yojson = function\n | `String x ->\n Or_error.try_with (fun () -> Unsigned.UInt64.of_string x)\n |> Result.map_error ~f:(fun err ->\n sprintf\n \"Snark_keys_header.UInt64.of_yojson: Could not parse string \\\n as UInt64: %s\"\n (Error.to_string_hum err) )\n | _ ->\n Error \"Snark_keys_header.UInt64.of_yojson: Expected a string\"\n\n let sexp_of_t x = Sexp.Atom (Unsigned.UInt64.to_string x)\n\n let t_of_sexp = function\n | Sexp.Atom x ->\n Unsigned.UInt64.of_string x\n | _ ->\n failwith \"Snark_keys_header.UInt64.t_of_sexp: Expected an atom\"\nend\n\nmodule Kind = struct\n (** The 'kind' of data in the file.\n For example, a step proving key for the base transaction snark may have the\n kind:\n{[\n {type_= \"step_proving_key\"; identifier= \"transaction_snark_base\"}\n|}\n *)\n type t =\n { type_ : string [@key \"type\"]\n (** Identifies the type of data that the file contains *)\n ; identifier : string\n (** Identifies the specific purpose of the file's data, in a\n human-readable format\n *)\n }\n [@@deriving yojson, sexp, ord, equal]\nend\n\nmodule Constraint_constants = struct\n module Transaction_capacity = struct\n (** Transaction pool capacity *)\n type t = Log_2 of int | Txns_per_second_x10 of int\n [@@deriving sexp, ord, equal]\n\n let to_yojson t : Yojson.Safe.t =\n match t with\n | Log_2 i ->\n `Assoc [ (\"two_to_the\", `Int i) ]\n | Txns_per_second_x10 i ->\n `Assoc [ (\"txns_per_second_x10\", `Int i) ]\n\n let of_yojson (json : Yojson.Safe.t) =\n match json with\n | `Assoc [ (\"two_to_the\", `Int i) ] ->\n Ok (Log_2 i)\n | `Assoc [ (\"txns_per_second_x10\", `Int i) ] ->\n Ok (Txns_per_second_x10 i)\n | `Assoc _ ->\n Error\n \"Snark_keys_header.Constraint_constants.Transaction_capacity.of_yojson: \\\n Expected a JSON object containing the field 'two_to_the' or \\\n 'txns_per_second_x10'\"\n | _ ->\n Error\n \"Snark_keys_header.Constraint_constants.Transaction_capacity.of_yojson: \\\n Expected a JSON object\"\n end\n\n module Fork_config = struct\n (** Fork data *)\n type t =\n { previous_state_hash : string\n ; previous_length : int\n ; genesis_slot : int\n }\n [@@deriving yojson, sexp, ord, equal]\n\n let opt_to_yojson t : Yojson.Safe.t =\n match t with Some t -> to_yojson t | None -> `Assoc []\n\n let opt_of_yojson (json : Yojson.Safe.t) =\n match json with\n | `Assoc [] ->\n Ok None\n | _ ->\n Result.map (of_yojson json) ~f:(fun t -> Some t)\n end\n\n (** The constants used in the constraint system. *)\n type t =\n { sub_windows_per_window : int\n ; ledger_depth : int\n ; work_delay : int\n ; block_window_duration_ms : int\n ; transaction_capacity : Transaction_capacity.t\n ; pending_coinbase_depth : int\n ; coinbase_amount : UInt64.t\n ; supercharged_coinbase_factor : int\n ; account_creation_fee : UInt64.t\n ; fork :\n (Fork_config.t option\n [@to_yojson Fork_config.opt_to_yojson]\n [@of_yojson Fork_config.opt_of_yojson] )\n }\n [@@deriving yojson, sexp, ord, equal]\nend\n\nmodule Commits = struct\n (** Commit identifiers *)\n type t = { mina : string; marlin : string }\n [@@deriving yojson, sexp, ord, equal]\nend\n\nlet header_version = 1\n\n(** Header contents *)\ntype t =\n { header_version : int\n ; kind : Kind.t\n ; constraint_constants : Constraint_constants.t\n ; commits : Commits.t\n ; length : int\n ; commit_date : string\n ; constraint_system_hash : string\n ; identifying_hash : string\n }\n[@@deriving yojson, sexp, ord, equal]\n\nlet prefix = \"MINA_SNARK_KEYS\\n\"\n\nlet prefix_len = String.length prefix\n\nlet parse_prefix (lexbuf : Lexing.lexbuf) =\n let open Or_error.Let_syntax in\n Result.map_error ~f:(fun err ->\n Error.tag_arg err \"Could not read prefix\" (\"prefix\", prefix)\n [%sexp_of: string * string] )\n @@ Or_error.try_with_join (fun () ->\n (* This roughly mirrors the behavior of [Yojson.Safe.read_ident],\n except that we have a known fixed length to parse, and that it is a\n failure to read any string except the prefix. We manually update\n the lexbuf to be consistent with the output of this function.\n *)\n (* Manually step the lexbuffer forward to the [lex_curr_pos], so that\n [refill_buf] will know that we're only interested in buffer\n contents from that position onwards.\n *)\n lexbuf.lex_start_pos <- lexbuf.lex_curr_pos ;\n lexbuf.lex_last_pos <- lexbuf.lex_curr_pos ;\n lexbuf.lex_start_p <- lexbuf.lex_curr_p ;\n let%bind () =\n (* Read more if the buffer doesn't contain the whole prefix. *)\n if lexbuf.lex_buffer_len - lexbuf.lex_curr_pos >= prefix_len then\n return ()\n else if lexbuf.lex_eof_reached then\n Or_error.error_string \"Unexpected end-of-file\"\n else (\n lexbuf.refill_buff lexbuf ;\n if lexbuf.lex_buffer_len - lexbuf.lex_curr_pos >= prefix_len then\n return ()\n else if lexbuf.lex_eof_reached then\n Or_error.error_string \"Unexpected end-of-file\"\n else\n Or_error.error_string\n \"Unexpected short read: broken lexbuffer or end-of-file\" )\n in\n let read_prefix =\n Lexing.sub_lexeme lexbuf lexbuf.lex_curr_pos\n (lexbuf.lex_curr_pos + prefix_len)\n in\n let%map () =\n if String.equal prefix read_prefix then return ()\n else\n Or_error.error \"Incorrect prefix\"\n (\"read prefix\", read_prefix)\n [%sexp_of: string * string]\n in\n (* Update the positions to match our end state *)\n lexbuf.lex_curr_pos <- lexbuf.lex_curr_pos + prefix_len ;\n lexbuf.lex_last_pos <- lexbuf.lex_last_pos ;\n lexbuf.lex_curr_p <-\n { lexbuf.lex_curr_p with\n pos_bol = lexbuf.lex_curr_p.pos_bol + prefix_len\n ; pos_cnum = lexbuf.lex_curr_p.pos_cnum + prefix_len\n } ;\n (* This matches the action given by [Yojson.Safe.read_ident]. *)\n lexbuf.lex_last_action <- 1 )\n\nlet parse_lexbuf (lexbuf : Lexing.lexbuf) =\n let open Or_error.Let_syntax in\n Result.map_error ~f:(Error.tag ~tag:\"Failed to read snark key header\")\n @@ let%bind () = parse_prefix lexbuf in\n Or_error.try_with (fun () ->\n let yojson_parsebuffer = Yojson.init_lexer () in\n (* We use [read_t] here rather than one of the alternatives to avoid\n 'greedy' parsing that will attempt to continue and read the file's\n contents beyond the header.\n *)\n Yojson.Safe.read_t yojson_parsebuffer lexbuf )\n\nlet%test_module \"Check parsing of header\" =\n ( module struct\n let valid_header =\n { header_version = 1\n ; kind = { type_ = \"type\"; identifier = \"identifier\" }\n ; constraint_constants =\n { sub_windows_per_window = 4\n ; ledger_depth = 8\n ; work_delay = 1000\n ; block_window_duration_ms = 1000\n ; transaction_capacity = Log_2 3\n ; pending_coinbase_depth = 12\n ; coinbase_amount = Unsigned.UInt64.of_int 1\n ; supercharged_coinbase_factor = 1\n ; account_creation_fee = Unsigned.UInt64.of_int 1\n ; fork = None\n }\n ; commits =\n { mina = \"7e1fb2cd9138af1d0f24e78477efd40a2a0fcd07\"\n ; marlin = \"75836c41fc4947acce9c938da1b2f506843e90ed\"\n }\n ; length = 4096\n ; commit_date = \"2020-01-01 00:00:00.000000Z\"\n ; constraint_system_hash = \"ABCDEF1234567890\"\n ; identifying_hash = \"ABCDEF1234567890\"\n }\n\n let valid_header_string = Yojson.Safe.to_string (to_yojson valid_header)\n\n let valid_header_with_prefix = prefix ^ valid_header_string\n\n module Tests (Lexing : sig\n val from_string : ?with_positions:bool -> string -> Lexing.lexbuf\n end) =\n struct\n let%test \"doesn't parse without prefix\" =\n parse_lexbuf (Lexing.from_string valid_header_string)\n |> Or_error.is_error\n\n let%test \"doesn't parse with incorrect prefix\" =\n parse_lexbuf (Lexing.from_string (\"BLAH\" ^ valid_header_string))\n |> Or_error.is_error\n\n let%test \"doesn't parse with matching-length prefix\" =\n let fake_prefix = String.init prefix_len ~f:(fun _ -> 'a') in\n parse_lexbuf (Lexing.from_string (fake_prefix ^ valid_header_string))\n |> Or_error.is_error\n\n let%test \"doesn't parse with partial matching prefix\" =\n let partial_prefix =\n String.sub prefix ~pos:0 ~len:(prefix_len - 1) ^ \" \"\n in\n parse_lexbuf (Lexing.from_string (partial_prefix ^ valid_header_string))\n |> Or_error.is_error\n\n let%test \"doesn't parse with short file\" =\n parse_lexbuf (Lexing.from_string \"BLAH\") |> Or_error.is_error\n\n let%test \"doesn't parse with prefix only\" =\n parse_lexbuf (Lexing.from_string prefix) |> Or_error.is_error\n\n let%test_unit \"parses valid header with prefix\" =\n parse_lexbuf (Lexing.from_string valid_header_with_prefix)\n |> Or_error.ok_exn |> ignore\n\n let%test_unit \"parses valid header with prefix and data\" =\n parse_lexbuf\n (Lexing.from_string (valid_header_with_prefix ^ \"DATADATADATA\"))\n |> Or_error.ok_exn |> ignore\n end\n\n let%test_module \"Parsing from the start of the lexbuf\" =\n (module Tests (Lexing))\n\n let%test_module \"Parsing from part-way through a lexbuf\" =\n ( module struct\n include Tests (struct\n let from_string ?with_positions:_ str =\n let prefix = \"AAAAAAAAAA\" in\n let prefix_len = String.length prefix in\n let lexbuf = Lexing.from_string (prefix ^ str) in\n lexbuf.lex_start_pos <- 0 ;\n lexbuf.lex_curr_pos <- prefix_len ;\n lexbuf.lex_last_pos <- prefix_len ;\n lexbuf\n end)\n end )\n\n let%test_module \"Parsing with refill\" =\n ( module struct\n include Tests (struct\n let from_string ?with_positions:_ str =\n let init = ref true in\n let initial_prefix = \"AAAAAAAAAA\" in\n let initial_prefix_len = String.length initial_prefix in\n let offset = ref 0 in\n let str_len = String.length str in\n let lexbuf =\n Lexing.from_function (fun buffer length ->\n match !init with\n | true ->\n init := false ;\n (* Initial read: fill with junk up to the first character\n of the actual prefix\n *)\n Bytes.From_string.blit ~src:initial_prefix ~src_pos:0\n ~dst:buffer ~dst_pos:0 ~len:initial_prefix_len ;\n Bytes.set buffer initial_prefix_len str.[0] ;\n offset := 1 ;\n initial_prefix_len + 1\n | false ->\n (* Subsequent read: fill the rest of the buffer. *)\n let len = Int.min length (str_len - !offset) in\n if len = 0 then 0\n else (\n Bytes.From_string.blit ~src:str ~src_pos:!offset\n ~dst:buffer ~dst_pos:0 ~len ;\n offset := !offset + len ;\n len ) )\n in\n (* Load the initial content into the buffer *)\n lexbuf.refill_buff lexbuf ;\n lexbuf.lex_start_pos <- 0 ;\n lexbuf.lex_curr_pos <- initial_prefix_len ;\n lexbuf.lex_last_pos <- initial_prefix_len ;\n lexbuf\n end)\n end )\n end )\n\nlet write_with_header ~expected_max_size_log2 ~append_data header filename =\n (* In order to write the correct length here, we provide the maximum expected\n size and store that in the initial header. Once the data has been written,\n we record the length and then modify the 'length' field to hold the\n correct data.\n Happily, since the header is JSON-encoded, we can pad the calculated\n length with spaces and the header will still form a valid JSON-encoded\n object.\n This intuitively feels hacky, but the only way this can fail are if we are\n not able to write all of our data to the filesystem, or if the file is\n modified during the writing process. In either of these cases, we would\n have the same issue even if we were to pre-compute the length and do the\n write atomically.\n *)\n let length = 1 lsl expected_max_size_log2 in\n if length <= 0 then\n failwith\n \"Snark_keys_header.write_header: expected_max_size_log2 is too large, \\\n the resulting length underflows\" ;\n let header_string =\n Yojson.Safe.to_string (to_yojson { header with length })\n in\n (* We look for the \"length\" field first, to ensure that we find our length\n and not some other data that happens to match it. Due to the\n JSON-encoding, we will only find the first field named \"length\", which is\n the one that we want to modify.\n *)\n let length_offset =\n String.substr_index_exn header_string ~pattern:\"\\\"length\\\":\"\n in\n let length_string = string_of_int length in\n let length_data_offset =\n prefix_len\n + String.substr_index_exn ~pos:length_offset header_string\n ~pattern:length_string\n in\n (* We use [binary=true] to ensure that line endings aren't converted, so that\n files can be used regardless of the operating system that generated them.\n *)\n Out_channel.with_file ~binary:true filename ~f:(fun out_channel ->\n Out_channel.output_string out_channel prefix ;\n Out_channel.output_string out_channel header_string ;\n (* Newline, to allow [head -n 2 path/to/file | tail -n 1] to easily\n extract the header.\n *)\n Out_channel.output_char out_channel '\\n' ) ;\n append_data filename ;\n (* Core doesn't let us open a file without appending or truncating, so we use\n stdlib instead.\n *)\n let out_channel =\n Stdlib.open_out_gen [ Open_wronly; Open_binary ] 0 filename\n in\n let true_length = Out_channel.length out_channel |> Int.of_int64_exn in\n if true_length > length then\n failwith\n \"Snark_keys_header.write_header: 2^expected_max_size_log2 is less than \\\n the true length of the file\" ;\n let true_length_string = string_of_int true_length in\n let true_length_padding =\n String.init\n (String.length length_string - String.length true_length_string)\n ~f:(fun _ -> ' ')\n in\n (* Go to where we wrote the data *)\n Out_channel.seek out_channel (Int64.of_int length_data_offset) ;\n (* Pad with spaces *)\n Out_channel.output_string out_channel true_length_padding ;\n (* Output the true length *)\n Out_channel.output_string out_channel true_length_string ;\n Out_channel.close out_channel\n\nlet read_with_header ~read_data filename =\n let open Or_error.Let_syntax in\n Or_error.try_with_join (fun () ->\n (* We use [binary=true] to ensure that line endings aren't converted. *)\n let in_channel = In_channel.create ~binary:true filename in\n let file_length = In_channel.length in_channel |> Int.of_int64_exn in\n let lexbuf = Lexing.from_channel in_channel in\n let%bind header_json = parse_lexbuf lexbuf in\n let%bind header =\n of_yojson header_json |> Result.map_error ~f:Error.of_string\n in\n let offset = lexbuf.lex_curr_pos in\n let%bind () =\n In_channel.seek in_channel (Int64.of_int offset) ;\n match In_channel.input_char in_channel with\n | Some '\\n' ->\n Ok ()\n | None ->\n Or_error.error_string\n \"Incomplete header: the newline terminator is missing\"\n | Some c ->\n Or_error.error \"Header was not terminated by a newline character\"\n (\"character\", c) [%sexp_of: string * char]\n in\n (* Bump offset for the newline terminator *)\n let offset = offset + 1 in\n In_channel.close in_channel ;\n let%bind () =\n if header.length = file_length then Ok ()\n else\n Or_error.error\n \"Header length didn't match file length. Was the file only \\\n partially downloaded?\"\n ((\"header length\", header.length), (\"file length\", file_length))\n [%sexp_of: (string * int) * (string * int)]\n in\n let%map data = Or_error.try_with (fun () -> read_data ~offset filename) in\n (header, data) )\n","open Base\n\nlet rec sexp_to_yojson (sexp : Sexp.t) : Yojson.Safe.t =\n match sexp with\n | Atom str ->\n `String str\n | List sexps ->\n `List (List.map ~f:sexp_to_yojson sexps)\n\nlet sexp_record_to_yojson (sexp : Sexp.t) : Yojson.Safe.t =\n let fail () =\n failwith\n (Printf.sprintf\n \"sexp_record_to_yojson called on an s-expression with a non-record \\\n structure %s\"\n (Sexp.to_string_hum sexp) )\n in\n match sexp with\n | List fields ->\n `Assoc\n (List.map fields ~f:(function\n | List [ Atom label; value ] ->\n (label, sexp_to_yojson value)\n | _ ->\n fail () ) )\n | _ ->\n fail ()\n\nlet rec sexp_of_yojson (json : Yojson.Safe.t) : (Sexp.t, string) Result.t =\n match json with\n | `String str ->\n Ok (Sexp.Atom str)\n | `List jsons ->\n let rev_sexps =\n List.fold_until ~init:[] jsons ~finish:Result.return\n ~f:(fun sexps json ->\n match sexp_of_yojson json with\n | Ok sexp ->\n Continue (sexp :: sexps)\n | Error str ->\n Stop (Error str) )\n in\n Result.map ~f:(fun l -> Sexp.List (List.rev l)) rev_sexps\n | _ ->\n Error \"Error_json.sexp_of_yojson: Expected a string or a list\"\n\ntype info_data =\n | Sexp of Sexp.t\n | String of string\n | Exn of exn\n | Of_list of int option * int * Yojson.Safe.t\n\n(* Used to encode sub-lists of infos *)\n\ntype info_tag =\n { tag : string; data : Sexp.t option; loc : Source_code_position.t option }\n\ntype 'a info_repr =\n { base : 'a; rev_tags : info_tag list; backtrace : string option }\n\nlet info_repr_to_yojson (info : info_data info_repr) : Yojson.Safe.t =\n let base_pairs =\n match info.base with\n | Sexp sexp ->\n [ (\"sexp\", sexp_to_yojson sexp) ]\n | String str ->\n [ (\"string\", `String str) ]\n | Exn exn ->\n [ ( \"exn_name\"\n , `String Stdlib.Obj.Extension_constructor.(name @@ of_val exn) )\n ; (\"exn\", sexp_to_yojson (Sexplib.Conv.sexp_of_exn exn))\n ]\n | Of_list (Some trunc_after, length, json) ->\n [ (\"multiple\", json)\n ; (\"length\", `Int length)\n ; (\"truncated_after\", `Int trunc_after)\n ]\n | Of_list (None, length, json) ->\n [ (\"multiple\", json); (\"length\", `Int length) ]\n in\n let tags =\n let tag_to_json { tag; data; loc } =\n let jsons =\n match loc with\n | None ->\n []\n | Some loc ->\n [ (\"loc\", `String (Source_code_position.to_string loc)) ]\n in\n let jsons =\n match data with\n | None ->\n jsons\n | Some data ->\n (\"sexp\", sexp_to_yojson data) :: jsons\n in\n `Assoc ((\"tag\", `String tag) :: jsons)\n in\n match info.rev_tags with\n | [] ->\n []\n | _ :: _ ->\n [ (\"tags\", `List (List.rev_map ~f:tag_to_json info.rev_tags)) ]\n in\n let backtrace =\n match info.backtrace with\n | None ->\n []\n | Some backtrace ->\n (* Split backtrace at lines so that it prints nicely in errors *)\n [ ( \"backtrace\"\n , `List\n (List.map ~f:(fun s -> `String s) (String.split_lines backtrace))\n )\n ]\n in\n `Assoc (base_pairs @ tags @ backtrace)\n\n(* NOTE: Could also add a [of_yojson] version for everything except [Exn]\n (which could be converted to [String]), but it's not clear that it would\n ever be useful.\n*)\n\nlet rec info_internal_repr_to_yojson_aux (info : Info.Internal_repr.t)\n (acc : unit info_repr) : info_data info_repr =\n match info with\n | Could_not_construct sexp ->\n { acc with base = Sexp (List [ Atom \"Could_not_construct\"; sexp ]) }\n | Sexp sexp ->\n { acc with base = Sexp sexp }\n | String str ->\n { acc with base = String str }\n | Exn exn ->\n { acc with base = Exn exn }\n | Tag_sexp (tag, sexp, loc) ->\n { acc with\n base = Sexp sexp\n ; rev_tags = { tag; data = None; loc } :: acc.rev_tags\n }\n | Tag_t (tag, info) ->\n info_internal_repr_to_yojson_aux info\n { acc with rev_tags = { tag; data = None; loc = None } :: acc.rev_tags }\n | Tag_arg (tag, data, info) ->\n info_internal_repr_to_yojson_aux info\n { acc with\n rev_tags = { tag; data = Some data; loc = None } :: acc.rev_tags\n }\n | Of_list (trunc_after, infos) ->\n let rec rev_take i acc_len infos acc_infos =\n match (i, infos) with\n | _, [] ->\n (None, acc_len, acc_infos)\n | None, info :: infos ->\n let json_info = info_internal_repr_to_yojson info in\n rev_take i (acc_len + 1) infos (json_info :: acc_infos)\n | Some i, info :: infos ->\n if i > 0 then\n let json_info = info_internal_repr_to_yojson info in\n rev_take\n (Some (i - 1))\n (acc_len + 1) infos (json_info :: acc_infos)\n else (Some acc_len, acc_len + 1 + List.length infos, acc_infos)\n in\n let trunc_after, length, rev_json_infos =\n rev_take trunc_after 0 infos []\n in\n let json_infos = `List (List.rev rev_json_infos) in\n { acc with base = Of_list (trunc_after, length, json_infos) }\n | With_backtrace (info, backtrace) ->\n info_internal_repr_to_yojson_aux info\n { acc with backtrace = Some backtrace }\n\nand info_internal_repr_to_yojson (info : Info.Internal_repr.t) : Yojson.Safe.t =\n info_internal_repr_to_yojson_aux info\n { base = (); rev_tags = []; backtrace = None }\n |> info_repr_to_yojson\n\nlet info_to_yojson (info : Info.t) : Yojson.Safe.t =\n info_internal_repr_to_yojson (Info.Internal_repr.of_info info)\n\nlet error_to_yojson (err : Error.t) : Yojson.Safe.t =\n match info_to_yojson (err :> Info.t) with\n | `Assoc assocs ->\n `Assoc ((\"commit_id\", `String Mina_version.commit_id) :: assocs)\n | json ->\n `Assoc [ (\"commit_id\", `String Mina_version.commit_id); (\"error\", json) ]\n","open Core_kernel\nopen Pickles_types\nmodule Columns = Nat.N15\nmodule Columns_vec = Vector.Vector_15\nmodule Coefficients = Nat.N15\nmodule Coefficients_vec = Vector.Vector_15\nmodule Quotient_polynomial = Nat.N7\nmodule Quotient_polynomial_vec = Vector.Vector_7\nmodule Permuts_minus_1 = Nat.N6\nmodule Permuts_minus_1_vec = Vector.Vector_6\n\n[@@@warning \"-4\"]\n\nmodule Commitments = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n Mina_wire_types.Pickles.Concrete_.Wrap_wire_proof.Commitments.V1.t =\n { w_comm :\n (Backend.Tick.Field.Stable.V1.t * Backend.Tick.Field.Stable.V1.t)\n Columns_vec.Stable.V1.t\n ; z_comm :\n Backend.Tick.Field.Stable.V1.t * Backend.Tick.Field.Stable.V1.t\n ; t_comm :\n (Backend.Tick.Field.Stable.V1.t * Backend.Tick.Field.Stable.V1.t)\n Quotient_polynomial_vec.Stable.V1.t\n }\n [@@deriving compare, sexp, yojson, hash, equal]\n\n [@@@warning \"+4\"]\n\n let to_latest = Fn.id\n end\n end]\n\n let to_kimchi ({ w_comm; z_comm; t_comm } : t) :\n Backend.Tock.Curve.Affine.t Plonk_types.Messages.t =\n { w_comm = Vector.map ~f:(fun x -> [| x |]) w_comm\n ; z_comm = [| z_comm |]\n ; t_comm = Array.map ~f:(fun x -> x) (Vector.to_array t_comm)\n ; lookup = None\n }\n\n let of_kimchi\n ({ w_comm; z_comm; t_comm; lookup = _ } :\n Backend.Tock.Curve.Affine.t Plonk_types.Messages.t ) : t =\n { w_comm = Vector.map ~f:(fun x -> x.(0)) w_comm\n ; z_comm = z_comm.(0)\n ; t_comm = Vector.of_array_and_length_exn t_comm Quotient_polynomial.n\n }\nend\n\n[@@@warning \"-4\"]\n\nmodule Evaluations = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n Mina_wire_types.Pickles.Concrete_.Wrap_wire_proof.Evaluations.V1.t =\n { w :\n (Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t)\n Columns_vec.Stable.V1.t\n ; coefficients :\n (Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t)\n Columns_vec.Stable.V1.t\n ; z : Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; s :\n (Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t)\n Permuts_minus_1_vec.Stable.V1.t\n ; generic_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; poseidon_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; complete_add_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; mul_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; emul_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n ; endomul_scalar_selector :\n Backend.Tock.Field.Stable.V1.t * Backend.Tock.Field.Stable.V1.t\n }\n [@@deriving compare, sexp, yojson, hash, equal]\n\n [@@@warning \"+4\"]\n\n let to_latest = Fn.id\n end\n end]\n\n let to_kimchi\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n } :\n t ) :\n (Backend.Tock.Field.t array * Backend.Tock.Field.t array)\n Plonk_types.Evals.t =\n let conv (x, y) = ([| x |], [| y |]) in\n { w = Vector.map ~f:conv w\n ; coefficients = Vector.map ~f:conv coefficients\n ; z = conv z\n ; s = Vector.map ~f:conv s\n ; generic_selector = conv generic_selector\n ; poseidon_selector = conv poseidon_selector\n ; complete_add_selector = conv complete_add_selector\n ; mul_selector = conv mul_selector\n ; emul_selector = conv emul_selector\n ; endomul_scalar_selector = conv endomul_scalar_selector\n ; range_check0_selector = None\n ; range_check1_selector = None\n ; foreign_field_add_selector = None\n ; foreign_field_mul_selector = None\n ; xor_selector = None\n ; rot_selector = None\n ; lookup_aggregation = None\n ; lookup_table = None\n ; lookup_sorted = [ None; None; None; None; None ]\n ; runtime_lookup_table = None\n ; runtime_lookup_table_selector = None\n ; xor_lookup_selector = None\n ; lookup_gate_lookup_selector = None\n ; range_check_lookup_selector = None\n ; foreign_field_mul_lookup_selector = None\n }\n\n let of_kimchi\n ({ w\n ; coefficients\n ; z\n ; s\n ; generic_selector\n ; poseidon_selector\n ; complete_add_selector\n ; mul_selector\n ; emul_selector\n ; endomul_scalar_selector\n ; range_check0_selector = _\n ; range_check1_selector = _\n ; foreign_field_add_selector = _\n ; foreign_field_mul_selector = _\n ; xor_selector = _\n ; rot_selector = _\n ; lookup_aggregation = _\n ; lookup_table = _\n ; lookup_sorted = _\n ; runtime_lookup_table = _\n ; runtime_lookup_table_selector = _\n ; xor_lookup_selector = _\n ; lookup_gate_lookup_selector = _\n ; range_check_lookup_selector = _\n ; foreign_field_mul_lookup_selector = _\n } :\n (Backend.Tock.Field.t array * Backend.Tock.Field.t array)\n Plonk_types.Evals.t ) : t =\n let conv (x, y) = (x.(0), y.(0)) in\n { w = Vector.map ~f:conv w\n ; coefficients = Vector.map ~f:conv coefficients\n ; z = conv z\n ; s = Vector.map ~f:conv s\n ; generic_selector = conv generic_selector\n ; poseidon_selector = conv poseidon_selector\n ; complete_add_selector = conv complete_add_selector\n ; mul_selector = conv mul_selector\n ; emul_selector = conv emul_selector\n ; endomul_scalar_selector = conv endomul_scalar_selector\n }\nend\n\n[@@@warning \"-4\"]\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Pickles.Concrete_.Wrap_wire_proof.V1.t =\n { commitments : Commitments.Stable.V1.t\n ; evaluations : Evaluations.Stable.V1.t\n ; ft_eval1 : Backend.Tock.Field.Stable.V1.t\n ; bulletproof :\n ( Backend.Tick.Field.Stable.V1.t * Backend.Tick.Field.Stable.V1.t\n , Backend.Tock.Field.Stable.V1.t )\n Plonk_types.Openings.Bulletproof.Stable.V1.t\n (* TODO-URGENT: Validate bulletproof length on the rust side *)\n }\n [@@deriving compare, sexp, yojson, hash, equal]\n\n [@@@warning \"+4\"]\n\n let to_latest = Fn.id\n end\nend]\n\nlet to_kimchi_proof ({ commitments; bulletproof; evaluations; ft_eval1 } : t) :\n Backend.Tock.Proof.t =\n { messages = Commitments.to_kimchi commitments\n ; openings =\n { proof = bulletproof\n ; evals = Evaluations.to_kimchi evaluations\n ; ft_eval1\n }\n }\n\nlet of_kimchi_proof\n ({ messages; openings = { proof; evals; ft_eval1 } } : Backend.Tock.Proof.t)\n : t =\n { commitments = Commitments.of_kimchi messages\n ; bulletproof = proof\n ; evaluations = Evaluations.of_kimchi evals\n ; ft_eval1\n }\n","open Core_kernel\nopen Import\nmodule SC = Scalar_challenge\n\n(* Implementation of the algorithm described on page 29 of the Halo paper\n https://eprint.iacr.org/2019/1021.pdf\n*)\n\nlet num_bits = 128\n\n(* Has the side effect of checking that [scalar] fits in 128 bits. *)\nlet to_field_checked' (type f) ?(num_bits = num_bits)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n { SC.inner = (scalar : Impl.Field.t) } =\n let open Impl in\n let neg_one = Field.Constant.(negate one) in\n let a_func = function\n | 0 ->\n Field.Constant.zero\n | 1 ->\n Field.Constant.zero\n | 2 ->\n neg_one\n | 3 ->\n Field.Constant.one\n | _ ->\n raise (Invalid_argument \"a_func\")\n in\n let b_func = function\n | 0 ->\n neg_one\n | 1 ->\n Field.Constant.one\n | 2 ->\n Field.Constant.zero\n | 3 ->\n Field.Constant.zero\n | _ ->\n raise (Invalid_argument \"a_func\")\n in\n let ( !! ) = As_prover.read_var in\n (* MSB bits *)\n let bits_msb =\n lazy\n (let open Field.Constant in\n unpack !!scalar |> Fn.flip List.take num_bits |> Array.of_list_rev\n (*\n |> Array.of_list_rev_map ~f:(fun b -> if b then one else zero) *))\n in\n let nybbles_per_row = 8 in\n let bits_per_row = 2 * nybbles_per_row in\n [%test_eq: int] (num_bits mod bits_per_row) 0 ;\n let rows = num_bits / bits_per_row in\n let nybbles_by_row =\n lazy\n (Array.init rows ~f:(fun i ->\n Array.init nybbles_per_row ~f:(fun j ->\n let bit = (bits_per_row * i) + (2 * j) in\n let b0 = (Lazy.force bits_msb).(bit + 1) in\n let b1 = (Lazy.force bits_msb).(bit) in\n Bool.to_int b0 + (2 * Bool.to_int b1) ) ) )\n in\n let two = Field.of_int 2 in\n let a = ref two in\n let b = ref two in\n let n = ref Field.zero in\n let mk f = exists Field.typ ~compute:f in\n let state = ref [] in\n for i = 0 to rows - 1 do\n let n0 = !n in\n let a0 = !a in\n let b0 = !b in\n let xs =\n Array.init nybbles_per_row ~f:(fun j ->\n mk (fun () ->\n Field.Constant.of_int (Lazy.force nybbles_by_row).(i).(j) ) )\n in\n let open Field.Constant in\n let double x = x + x in\n let n8 =\n mk (fun () ->\n Array.fold xs ~init:!!n0 ~f:(fun acc x ->\n (acc |> double |> double) + !!x ) )\n in\n let a8 =\n mk (fun () ->\n Array.fold\n (Lazy.force nybbles_by_row).(i)\n ~init:!!a0\n ~f:(fun acc x -> (acc |> double) + a_func x) )\n in\n let b8 =\n mk (fun () ->\n Array.fold\n (Lazy.force nybbles_by_row).(i)\n ~init:!!b0\n ~f:(fun acc x -> (acc |> double) + b_func x) )\n in\n state :=\n { Kimchi_backend_common.Endoscale_scalar_round.a0\n ; a8\n ; b0\n ; b8\n ; n0\n ; n8\n ; x0 = xs.(0)\n ; x1 = xs.(1)\n ; x2 = xs.(2)\n ; x3 = xs.(3)\n ; x4 = xs.(4)\n ; x5 = xs.(5)\n ; x6 = xs.(6)\n ; x7 = xs.(7)\n }\n :: !state ;\n n := n8 ;\n a := a8 ;\n b := b8 ;\n ()\n done ;\n with_label __LOC__ (fun () ->\n assert_\n Snarky_backendless.Constraint.\n { annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.(\n T (EC_endoscalar { state = Array.of_list_rev !state }))\n } ) ;\n (!a, !b, !n)\n\nlet to_field_checked (type f) ?num_bits\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) ~endo\n ({ SC.inner = (scalar : Impl.Field.t) } as s) =\n let open Impl in\n let a, b, n = to_field_checked' ?num_bits (module Impl) s in\n Field.Assert.equal n scalar ;\n Field.(scale a endo + b)\n\nlet to_field_constant (type f) ~endo\n (module F : Plonk_checks.Field_intf with type t = f) { SC.inner = c } =\n let bits = Array.of_list (Challenge.Constant.to_bits c) in\n let a = ref (F.of_int 2) in\n let b = ref (F.of_int 2) in\n let one = F.of_int 1 in\n let neg_one = F.(of_int 0 - one) in\n for i = (128 / 2) - 1 downto 0 do\n let s = if bits.(2 * i) then one else neg_one in\n (a := F.(!a + !a)) ;\n (b := F.(!b + !b)) ;\n let r_2i1 = bits.((2 * i) + 1) in\n if r_2i1 then a := F.(!a + s) else b := F.(!b + s)\n done ;\n F.((!a * endo) + !b)\n\nlet test (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ~(endo : f) =\n let open Impl in\n let module T = Internal_Basic in\n let n = 128 in\n let module Field_constant = struct\n include Field.Constant\n\n let _if_ b ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Quickcheck.test ~trials:10\n (Quickcheck.Generator.list_with_length n Bool.quickcheck_generator)\n ~f:(fun xs ->\n try\n T.Test.test_equal ~equal:Field.Constant.equal\n ~sexp_of_t:Field.Constant.sexp_of_t\n (Typ.list ~length:n Boolean.typ)\n Field.typ\n (fun s ->\n make_checked (fun () ->\n to_field_checked\n (module Impl)\n ~endo\n (SC.create (Impl.Field.pack s)) ) )\n (fun s ->\n to_field_constant\n (module Field_constant)\n ~endo\n (SC.create (Challenge.Constant.of_bits s)) )\n xs\n with e ->\n eprintf !\"Input %{sexp: bool list}\\n%!\" xs ;\n raise e )\n\nmodule Make\n (Impl : Snarky_backendless.Snark_intf.Run)\n (G : Intf.Group(Impl).S with type t = Impl.Field.t * Impl.Field.t)\n (Challenge : Challenge.S with module Impl := Impl) (Endo : sig\n val base : Impl.Field.Constant.t\n\n val scalar : G.Constant.Scalar.t\n end) =\nstruct\n open Impl\n module Scalar = G.Constant.Scalar\n\n type t = Challenge.t SC.t\n\n module Constant = struct\n type t = Challenge.Constant.t SC.t\n\n let to_field = to_field_constant ~endo:Endo.scalar (module Scalar)\n end\n\n let typ : (t, Constant.t) Typ.t = SC.typ Challenge.typ\n\n let num_bits = 128\n\n let seal = Util.seal (module Impl)\n\n let endo ?(num_bits = num_bits) t { SC.inner = (scalar : Field.t) } =\n let ( !! ) = As_prover.read_var in\n (* MSB bits *)\n let bits =\n lazy\n (let open Field.Constant in\n unpack !!scalar |> Fn.flip List.take num_bits\n |> Array.of_list_rev_map ~f:(fun b -> if b then one else zero))\n in\n let bits () = Lazy.force bits in\n let xt, yt = Tuple_lib.Double.map t ~f:seal in\n let bits_per_row = 4 in\n let rows = num_bits / bits_per_row in\n let acc =\n with_label __LOC__ (fun () ->\n let p = G.( + ) t (seal (Field.scale xt Endo.base), yt) in\n ref G.(p + p) )\n in\n let n_acc = ref Field.zero in\n let mk f = exists Field.typ ~compute:f in\n let rounds_rev = ref [] in\n for i = 0 to rows - 1 do\n let n_acc_prev = !n_acc in\n let b1 = mk (fun () -> (bits ()).(i * bits_per_row)) in\n let b2 = mk (fun () -> (bits ()).((i * bits_per_row) + 1)) in\n let b3 = mk (fun () -> (bits ()).((i * bits_per_row) + 2)) in\n let b4 = mk (fun () -> (bits ()).((i * bits_per_row) + 3)) in\n let open Field.Constant in\n let double x = x + x in\n let xp, yp = !acc in\n let xq1 = mk (fun () -> (one + ((Endo.base - one) * !!b1)) * !!xt) in\n let yq1 = mk (fun () -> (double !!b2 - one) * !!yt) in\n\n let s1 = mk (fun () -> (!!yq1 - !!yp) / (!!xq1 - !!xp)) in\n let s1_squared = mk (fun () -> square !!s1) in\n let s2 =\n mk (fun () ->\n (double !!yp / (double !!xp + !!xq1 - !!s1_squared)) - !!s1 )\n in\n\n let xr = mk (fun () -> !!xq1 + square !!s2 - !!s1_squared) in\n let yr = mk (fun () -> ((!!xp - !!xr) * !!s2) - !!yp) in\n\n let xq2 = mk (fun () -> (one + ((Endo.base - one) * !!b3)) * !!xt) in\n let yq2 = mk (fun () -> (double !!b4 - one) * !!yt) in\n let s3 = mk (fun () -> (!!yq2 - !!yr) / (!!xq2 - !!xr)) in\n let s3_squared = mk (fun () -> square !!s3) in\n let s4 =\n mk (fun () ->\n (double !!yr / (double !!xr + !!xq2 - !!s3_squared)) - !!s3 )\n in\n\n let xs = mk (fun () -> !!xq2 + square !!s4 - !!s3_squared) in\n let ys = mk (fun () -> ((!!xr - !!xs) * !!s4) - !!yr) in\n acc := (xs, ys) ;\n n_acc :=\n mk (fun () ->\n !!n_acc_prev |> double |> ( + ) !!b1 |> double |> ( + ) !!b2\n |> double |> ( + ) !!b3 |> double |> ( + ) !!b4 ) ;\n rounds_rev :=\n { Kimchi_backend_common.Endoscale_round.xt\n ; yt\n ; xp\n ; yp\n ; n_acc = n_acc_prev\n ; xr\n ; yr\n ; s1\n ; s3\n ; b1\n ; b2\n ; b3\n ; b4\n }\n :: !rounds_rev\n done ;\n let xs, ys = !acc in\n with_label __LOC__ (fun () ->\n assert_\n { annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.(\n T\n (EC_endoscale\n { xs\n ; ys\n ; n_acc = !n_acc\n ; state = Array.of_list_rev !rounds_rev\n } ))\n } ) ;\n with_label __LOC__ (fun () -> Field.Assert.equal !n_acc scalar) ;\n !acc\n\n let endo ?num_bits t s = with_label \"endo\" (fun () -> endo ?num_bits t s)\n\n let%test_unit \"endo\" =\n let module T = Internal_Basic in\n let random_point =\n let rec pt x =\n let y2 = G.Params.(T.Field.(b + (x * (a + (x * x))))) in\n if T.Field.is_square y2 then (x, T.Field.sqrt y2)\n else pt T.Field.(x + one)\n in\n G.Constant.of_affine (pt (T.Field.random ()))\n in\n let n = 128 in\n Quickcheck.test ~trials:10\n (Quickcheck.Generator.list_with_length n Bool.quickcheck_generator)\n ~f:(fun xs ->\n try\n T.Test.test_equal ~equal:G.Constant.equal\n ~sexp_of_t:G.Constant.sexp_of_t\n (Typ.tuple2 G.typ (Typ.list ~length:n Boolean.typ))\n G.typ\n (fun (g, s) ->\n make_checked (fun () -> endo g (SC.create (Field.pack s))) )\n (fun (g, s) ->\n let x =\n Constant.to_field (SC.create (Challenge.Constant.of_bits s))\n in\n G.Constant.scale g x )\n (random_point, xs)\n with e ->\n eprintf !\"Input %{sexp: bool list}\\n%!\" xs ;\n raise e )\n\n let endo_inv ((gx, gy) as g) chal =\n let res =\n exists G.typ\n ~compute:\n As_prover.(\n fun () ->\n let x = Constant.to_field (read typ chal) in\n G.Constant.scale (read G.typ g) Scalar.(one / x))\n in\n let x, y = endo res chal in\n Field.Assert.(equal gx x ; equal gy y) ;\n res\nend\n","open Pickles_types\nopen Core_kernel\nopen Import\nopen Backend\nmodule Wrap_impl = Snarky_backendless.Snark.Run.Make (Tock)\n\n(** returns [true] if the [i]th bit of [x] is set to 1 *)\nlet test_bit x i = B.(shift_right x i land one = one)\n\n(* TODO: I think there are other forbidden values as well. *)\n\n(** returns all the values that can fit in [~size_in_bits] bits and that are\n * either congruent with -2^[~size_in_bits] mod [~modulus] \n * or congruent with -2^[~size_in_bits] - 1 mod [~modulus] \n *)\nlet forbidden_shifted_values ~modulus:r ~size_in_bits =\n let two_to_n = B.(pow (of_int 2) (of_int size_in_bits)) in\n (* this function doesn't make sense if the modulus is smaller *)\n assert (B.(r < two_to_n)) ;\n let neg_two_to_n = B.(neg two_to_n) in\n let representatives x =\n let open Sequence in\n (* All values equivalent to x mod r that fit in [size_in_bits]\n many bits. *)\n let fits_in_n_bits x = B.(x < two_to_n) in\n unfold ~init:B.(x % r) ~f:(fun x -> Some (x, B.(x + r)))\n |> take_while ~f:fits_in_n_bits\n |> to_list\n in\n List.concat_map [ neg_two_to_n; B.(neg_two_to_n - one) ] ~f:representatives\n |> List.dedup_and_sort ~compare:B.compare\n\nmodule Step = struct\n module Impl = Snarky_backendless.Snark.Run.Make (Tick)\n include Impl\n module Verification_key = Tick.Verification_key\n module Proving_key = Tick.Proving_key\n\n module Keypair = struct\n type t = { pk : Proving_key.t; vk : Verification_key.t } [@@deriving fields]\n\n let create = Fields.create\n\n let generate ~prev_challenges cs =\n let open Tick.Keypair in\n let keypair = create ~prev_challenges cs in\n { pk = pk keypair; vk = vk keypair }\n end\n\n module Other_field = struct\n (* Tick.Field.t = p < q = Tock.Field.t *)\n\n module Constant = Tock.Field\n\n type t = (* Low bits, high bit *)\n Field.t * Boolean.var\n\n let forbidden_shifted_values =\n lazy\n (let size_in_bits = Constant.size_in_bits in\n let other_mod = Wrap_impl.Bigint.to_bignum_bigint Constant.size in\n let values =\n forbidden_shifted_values ~size_in_bits ~modulus:other_mod\n in\n let f x =\n let open Option.Let_syntax in\n let hi = test_bit x (Field.size_in_bits - 1) in\n let lo = B.shift_right x 1 in\n let%map lo =\n let modulus = Impl.Field.size in\n if B.compare modulus lo <= 0 then None\n else Some Impl.Bigint.(to_field (of_bignum_bigint lo))\n in\n (lo, hi)\n in\n values |> List.filter_map ~f )\n\n let%test_unit \"preserve circuit behavior for Step\" =\n let expected_list =\n [ (\"45560315531506369815346746415080538112\", false)\n ; (\"45560315531506369815346746415080538113\", false)\n ; ( \"14474011154664524427946373126085988481727088556502330059655218120611762012161\"\n , true )\n ; ( \"14474011154664524427946373126085988481727088556502330059655218120611762012161\"\n , true )\n ]\n in\n let str_list =\n List.map (Lazy.force forbidden_shifted_values) ~f:(fun (a, b) ->\n (Tick.Field.to_string a, b) )\n in\n assert ([%equal: (string * bool) list] str_list expected_list)\n\n let typ_unchecked : (t, Constant.t) Typ.t =\n Typ.transport\n (Typ.tuple2 Field.typ Boolean.typ)\n ~there:(fun x ->\n match Tock.Field.to_bits x with\n | [] ->\n assert false\n | low :: high ->\n (Field.Constant.project high, low) )\n ~back:(fun (high, low) ->\n let high = Field.Constant.unpack high in\n Tock.Field.of_bits (low :: high) )\n\n let check t =\n let open Internal_Basic in\n let open Let_syntax in\n let equal (x1, b1) (x2, b2) =\n let%bind x_eq = Field.Checked.equal x1 (Field.Var.constant x2) in\n let b_eq = match b2 with true -> b1 | false -> Boolean.not b1 in\n Boolean.( && ) x_eq b_eq\n in\n let (Typ typ_unchecked) = typ_unchecked in\n let%bind () = typ_unchecked.check t in\n Checked.List.map (Lazy.force forbidden_shifted_values) ~f:(equal t)\n >>= Boolean.any >>| Boolean.not >>= Boolean.Assert.is_true\n\n let typ : _ Snarky_backendless.Typ.t =\n let (Typ typ_unchecked) = typ_unchecked in\n Typ { typ_unchecked with check }\n\n let _to_bits (x, b) =\n Field.unpack x ~length:(Field.size_in_bits - 1) @ [ b ]\n end\n\n module Digest = Digest.Make (Impl)\n module Challenge = Challenge.Make (Impl)\n\n let input ~proofs_verified ~wrap_rounds =\n let open Types.Step.Statement in\n let spec = spec proofs_verified wrap_rounds in\n let (T (typ, f, f_inv)) =\n Spec.packed_typ\n (module Impl)\n (T\n ( Shifted_value.Type2.typ Other_field.typ_unchecked\n , (fun (Shifted_value.Type2.Shifted_value x as t) ->\n Impl.run_checked (Other_field.check x) ;\n t )\n , Fn.id ) )\n spec\n in\n let typ = Typ.transport typ ~there:to_data ~back:of_data in\n Spec.ETyp.T (typ, (fun x -> of_data (f x)), fun x -> f_inv (to_data x))\nend\n\nmodule Wrap = struct\n module Impl = Wrap_impl\n include Impl\n module Challenge = Challenge.Make (Impl)\n module Digest = Digest.Make (Impl)\n module Wrap_field = Tock.Field\n module Step_field = Tick.Field\n module Verification_key = Tock.Verification_key\n module Proving_key = Tock.Proving_key\n\n module Keypair = struct\n type t = { pk : Proving_key.t; vk : Verification_key.t } [@@deriving fields]\n\n let create = Fields.create\n\n let generate ~prev_challenges cs =\n let open Tock.Keypair in\n let keypair = create ~prev_challenges cs in\n { pk = pk keypair; vk = vk keypair }\n end\n\n module Other_field = struct\n module Constant = Tick.Field\n open Impl\n\n type t = Field.t\n\n let forbidden_shifted_values =\n lazy\n (let other_mod = Step.Impl.Bigint.to_bignum_bigint Constant.size in\n let size_in_bits = Constant.size_in_bits in\n let values =\n forbidden_shifted_values ~size_in_bits ~modulus:other_mod\n in\n let f x =\n let modulus = Impl.Field.size in\n if B.compare modulus x <= 0 then None\n else Some Impl.Bigint.(to_field (of_bignum_bigint x))\n in\n values |> List.filter_map ~f )\n\n let%test_unit \"preserve circuit behavior for Wrap\" =\n let expected_list =\n [ \"91120631062839412180561524743370440705\"\n ; \"91120631062839412180561524743370440706\"\n ]\n in\n let str_list =\n List.map (Lazy.force forbidden_shifted_values) ~f:Wrap_field.to_string\n in\n assert ([%equal: string list] str_list expected_list)\n\n let typ_unchecked, check =\n (* Tick -> Tock *)\n let (Typ t0 as typ_unchecked) =\n Typ.transport Field.typ\n ~there:(Fn.compose Tock.Field.of_bits Tick.Field.to_bits)\n ~back:(Fn.compose Tick.Field.of_bits Tock.Field.to_bits)\n in\n let check t =\n let open Internal_Basic in\n let open Let_syntax in\n let equal x1 x2 = Field.Checked.equal x1 (Field.Var.constant x2) in\n let%bind () = t0.check t in\n Checked.List.map (Lazy.force forbidden_shifted_values) ~f:(equal t)\n >>= Boolean.any >>| Boolean.not >>= Boolean.Assert.is_true\n in\n (typ_unchecked, check)\n\n let typ : _ Snarky_backendless.Typ.t =\n let (Typ typ_unchecked) = typ_unchecked in\n Typ { typ_unchecked with check }\n\n let _to_bits x = Field.unpack x ~length:Field.size_in_bits\n end\n\n let input\n ~feature_flags:\n ({ Plonk_types.Features.Full.uses_lookups; _ } as feature_flags) () =\n let feature_flags = Plonk_types.Features.of_full feature_flags in\n let lookup =\n { Types.Wrap.Lookup_parameters.use = uses_lookups\n ; zero =\n { value =\n { challenge = Limb_vector.Challenge.Constant.zero\n ; scalar =\n Shifted_value.Type1.Shifted_value Other_field.Constant.zero\n }\n ; var =\n { challenge = Impl.Field.zero\n ; scalar = Shifted_value.Type1.Shifted_value Impl.Field.zero\n }\n }\n }\n in\n let fp : (Impl.Field.t, Other_field.Constant.t) Typ.t =\n Other_field.typ_unchecked\n in\n let open Types.Wrap.Statement in\n let (T (typ, f, f_inv)) =\n Spec.packed_typ\n (module Impl)\n (T\n ( Shifted_value.Type1.typ fp\n , (fun (Shifted_value x as t) ->\n Impl.run_checked (Other_field.check x) ;\n t )\n , Fn.id ) )\n (In_circuit.spec (module Impl) lookup feature_flags)\n in\n let typ =\n Typ.transport typ\n ~there:(In_circuit.to_data ~option_map:Option.map)\n ~back:(In_circuit.of_data ~option_map:Option.map)\n in\n Spec.ETyp.T\n ( typ\n , (fun x -> In_circuit.of_data ~option_map:Opt.map (f x))\n , fun x -> f_inv (In_circuit.to_data ~option_map:Opt.map x) )\nend\n","open Core_kernel\n\nopen Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint\n\nlet seal i = Tuple_lib.Double.map ~f:(Util.seal i)\n\nlet add_fast (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ?(check_finite = true) ((x1, y1) as p1) ((x2, y2) as p2) :\n Impl.Field.t * Impl.Field.t =\n let p1 = seal (module Impl) p1 in\n let p2 = seal (module Impl) p2 in\n let open Impl in\n let open Field.Constant in\n let bool b = if b then one else zero in\n let eq a b = As_prover.(equal (read_var a) (read_var b)) in\n let same_x_bool = lazy (eq x1 x2) in\n let ( ! ) = Lazy.force in\n let ( !! ) = As_prover.read_var in\n let mk f = exists Field.typ ~compute:f in\n let same_x = mk (fun () -> bool !same_x_bool) in\n let inf =\n if check_finite then Field.zero\n else mk (fun () -> bool (!same_x_bool && not (eq y1 y2)))\n in\n let inf_z =\n mk (fun () ->\n if eq y1 y2 then zero\n else if !same_x_bool then inv (!!y2 - !!y1)\n else zero )\n in\n let x21_inv =\n mk (fun () -> if !same_x_bool then zero else inv (!!x2 - !!x1))\n in\n let s =\n mk (fun () ->\n if !same_x_bool then\n let x1_squared = square !!x1 in\n let y1 = !!y1 in\n (x1_squared + x1_squared + x1_squared) / (y1 + y1)\n else (!!y2 - !!y1) / (!!x2 - !!x1) )\n in\n let x3 = mk (fun () -> square !!s - (!!x1 + !!x2)) in\n let y3 = mk (fun () -> (!!s * (!!x1 - !!x3)) - !!y1) in\n let p3 = (x3, y3) in\n with_label \"add_fast\" (fun () ->\n assert_\n { Snarky_backendless.Constraint.annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.T\n (EC_add_complete\n { p1; p2; p3; inf; same_x; slope = s; inf_z; x21_inv } )\n } ;\n p3 )\n\nmodule Make\n (Impl : Snarky_backendless.Snark_intf.Run)\n (G : Intf.Group(Impl).S with type t = Impl.Field.t * Impl.Field.t) =\nstruct\n open Impl\n\n let seal = seal (module Impl)\n\n let add_fast = add_fast (module Impl)\n\n let bits_per_chunk = 5\n\n (* Number of chunks needed to cover the given number of bits. *)\n let chunks_needed ~num_bits =\n (num_bits + (bits_per_chunk - 1)) / bits_per_chunk\n\n let scale_fast_msb_bits base\n (Pickles_types.Shifted_value.Type1.Shifted_value\n (bits_msb : Boolean.var array) ) : Field.t * Field.t =\n let ((x_base, y_base) as base) = seal base in\n let ( !! ) = As_prover.read_var in\n let mk f = exists Field.typ ~compute:f in\n (* MSB bits *)\n let num_bits = Array.length bits_msb in\n let chunks = num_bits / bits_per_chunk in\n [%test_eq: int] (num_bits mod bits_per_chunk) 0 ;\n let acc = ref (add_fast base base) in\n let n_acc = ref Field.zero in\n let rounds_rev = ref [] in\n for chunk = 0 to chunks - 1 do\n let open Field.Constant in\n let double x = x + x in\n let bs =\n Array.init bits_per_chunk ~f:(fun i ->\n (bits_msb.(Int.((chunk * bits_per_chunk) + i)) :> Field.t) )\n in\n let n_acc_prev = !n_acc in\n n_acc :=\n mk (fun () ->\n Array.fold bs ~init:!!n_acc_prev ~f:(fun acc b -> double acc + !!b) ) ;\n let accs, slopes =\n Array.fold_map bs ~init:!acc ~f:(fun (x_acc, y_acc) b ->\n let s1 =\n mk (fun () ->\n (!!y_acc - (!!y_base * (double !!b - one)))\n / (!!x_acc - !!x_base) )\n in\n let s1_squared = mk (fun () -> square !!s1) in\n let s2 =\n mk (fun () ->\n (double !!y_acc / (double !!x_acc + !!x_base - !!s1_squared))\n - !!s1 )\n in\n let x_res = mk (fun () -> !!x_base + square !!s2 - !!s1_squared) in\n let y_res = mk (fun () -> ((!!x_acc - !!x_res) * !!s2) - !!y_acc) in\n let acc' = (x_res, y_res) in\n (acc', (acc', s1)) )\n |> snd |> Array.unzip\n in\n let accs = Array.append [| !acc |] accs in\n acc := Array.last accs ;\n rounds_rev :=\n { Kimchi_backend_common.Scale_round.accs\n ; bits = bs\n ; ss = slopes\n ; n_prev = n_acc_prev\n ; n_next = !n_acc\n ; base\n }\n :: !rounds_rev\n done ;\n assert_\n { Snarky_backendless.Constraint.annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.T\n (EC_scale { state = Array.of_list_rev !rounds_rev })\n } ;\n (* TODO: Return n_acc ? *)\n !acc\n\n (*\n Computes\n\n fun (g, t) -> (2 * t + 1 + 2^len(t)) g *)\n let scale_fast_unpack base\n (Pickles_types.Shifted_value.Type1.Shifted_value (scalar : Field.t))\n ~num_bits : (Field.t * Field.t) * Boolean.var array =\n let ((x_base, y_base) as base) = seal base in\n let ( !! ) = As_prover.read_var in\n let mk f = exists Field.typ ~compute:f in\n (* MSB bits *)\n (*\n let num_bits = Field.size_in_bits in *)\n let chunks = num_bits / bits_per_chunk in\n [%test_eq: int] (num_bits mod bits_per_chunk) 0 ;\n let bits_msb =\n exists (Typ.array ~length:num_bits Field.typ) ~compute:(fun () ->\n let open Field.Constant in\n unpack !!scalar |> Fn.flip List.take num_bits\n |> Array.of_list_rev_map ~f:(fun b -> if b then one else zero) )\n in\n let acc = ref (add_fast base base) in\n let n_acc = ref Field.zero in\n let rounds_rev = ref [] in\n for chunk = 0 to chunks - 1 do\n let open Field.Constant in\n let double x = x + x in\n let bs =\n Array.init bits_per_chunk ~f:(fun i ->\n bits_msb.(Int.((chunk * bits_per_chunk) + i)) )\n in\n let n_acc_prev = !n_acc in\n n_acc :=\n mk (fun () ->\n Array.fold bs ~init:!!n_acc_prev ~f:(fun acc b -> double acc + !!b) ) ;\n let accs, slopes =\n Array.fold_map bs ~init:!acc ~f:(fun (x_acc, y_acc) b ->\n let s1 =\n mk (fun () ->\n (!!y_acc - (!!y_base * (double !!b - one)))\n / (!!x_acc - !!x_base) )\n in\n let s1_squared = mk (fun () -> square !!s1) in\n let s2 =\n mk (fun () ->\n (double !!y_acc / (double !!x_acc + !!x_base - !!s1_squared))\n - !!s1 )\n in\n let x_res = mk (fun () -> !!x_base + square !!s2 - !!s1_squared) in\n let y_res = mk (fun () -> ((!!x_acc - !!x_res) * !!s2) - !!y_acc) in\n let acc' = (x_res, y_res) in\n (acc', (acc', s1)) )\n |> snd |> Array.unzip\n in\n let accs = Array.append [| !acc |] accs in\n acc := Array.last accs ;\n rounds_rev :=\n { Kimchi_backend_common.Scale_round.accs\n ; bits = bs\n ; ss = slopes\n ; n_prev = n_acc_prev\n ; n_next = !n_acc\n ; base\n }\n :: !rounds_rev\n done ;\n assert_\n { Snarky_backendless.Constraint.annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.T\n (EC_scale { state = Array.of_list_rev !rounds_rev })\n } ;\n Field.Assert.equal !n_acc scalar ;\n let bits_lsb =\n let bs = Array.map bits_msb ~f:Boolean.Unsafe.of_cvar in\n Array.rev_inplace bs ; bs\n in\n (!acc, bits_lsb)\n\n let scale_fast_unpack base scalar ~num_bits :\n (Field.t * Field.t) * Boolean.var array =\n with_label \"scale_fast_unpack\" (fun () ->\n scale_fast_unpack base scalar ~num_bits )\n\n let scale_fast base s ~num_bits =\n let r, _bits = scale_fast_unpack base s ~num_bits in\n r\n\n module type Scalar_field_intf = sig\n module Constant : sig\n include Plonk_checks.Field_intf\n\n val to_bigint : t -> Impl.Bigint.t\n end\n\n type t = Field.t\n\n val typ : (t, Constant.t) Typ.t\n end\n\n (* Computes\n\n (g, s) -> (s + 2^{len(s) - 1})\n\n as\n\n let h = scale_fast g (s >> 1) in\n if s is odd then h else h - g\n ==\n let h = [ 2 * (s >> 1) + 1 + 2^{len(s) - 1} ] * g in\n if s is odd then h else h - g\n\n since if s is odd, then s = 2 * (s >> 1) + 1, and otherwise,\n s = 2 * (s >> 1) + 1 - 1.\n *)\n let scale_fast2 (g : G.t)\n (Pickles_types.Shifted_value.Type2.Shifted_value\n ((s_div_2 : Field.t), (s_odd : Boolean.var)) ) ~(num_bits : int) : G.t =\n let s_div_2_bits = num_bits - 1 in\n (* The number of chunks need for scaling by s_div_2. *)\n let chunks_needed = chunks_needed ~num_bits:s_div_2_bits in\n let actual_bits_used = chunks_needed * bits_per_chunk in\n let h, bits_lsb =\n scale_fast_unpack g (Shifted_value s_div_2) ~num_bits:actual_bits_used\n in\n (* Constrain the top bits of s_div_2 to be 0. *)\n with_label __LOC__ (fun () ->\n for i = s_div_2_bits to Array.length bits_lsb - 1 do\n Field.Assert.equal Field.zero (bits_lsb.(i) :> Field.t)\n done ) ;\n with_label __LOC__ (fun () ->\n G.if_ s_odd ~then_:h ~else_:(add_fast h (G.negate g)) )\n\n let scale_fast2' (type scalar_field)\n (module Scalar_field : Scalar_field_intf\n with type Constant.t = scalar_field ) g (s : Scalar_field.t) ~num_bits =\n let ((s_div_2, s_odd) as s_parts) =\n with_label __LOC__ (fun () ->\n exists\n Typ.(Scalar_field.typ * Boolean.typ)\n ~compute:\n As_prover.(\n fun () ->\n let s = read Scalar_field.typ s in\n let open Scalar_field.Constant in\n let s_odd = Bigint.test_bit (to_bigint s) 0 in\n ((if s_odd then s - one else s) / of_int 2, s_odd)) )\n in\n\n (* In this case, it's safe to use this field to compute\n\n 2 s_div_2 + b\n\n in the other field. *)\n with_label __LOC__ (fun () ->\n Field.Assert.equal Field.((of_int 2 * s_div_2) + (s_odd :> Field.t)) s ) ;\n scale_fast2 g (Pickles_types.Shifted_value.Type2.Shifted_value s_parts)\n ~num_bits\n\n let scale_fast a b = with_label __LOC__ (fun () -> scale_fast a b)\n\n let%test_module \"curve_ops\" =\n ( module struct\n module T = Internal_Basic\n\n let random_point =\n let rec pt x =\n let y2 = G.Params.(T.Field.(b + (x * (a + (x * x))))) in\n if T.Field.is_square y2 then (x, T.Field.sqrt y2)\n else pt T.Field.(x + one)\n in\n G.Constant.of_affine (pt (T.Field.of_int 0))\n\n let n = Field.size_in_bits\n\n let%test_unit \"scale fast 2\" =\n Quickcheck.test ~trials:5 Field.Constant.gen ~f:(fun s ->\n let input =\n let s_odd = T.Bigint.test_bit (T.Bigint.of_field s) 0 in\n Field.Constant.((if s_odd then s - one else s) / of_int 2, s_odd)\n in\n T.Test.test_equal ~equal:G.Constant.equal\n ~sexp_of_t:G.Constant.sexp_of_t\n (Typ.tuple2 G.typ (Typ.tuple2 Field.typ Boolean.typ))\n G.typ\n (fun (g, s) ->\n make_checked (fun () ->\n scale_fast2 ~num_bits:n g\n (Pickles_types.Shifted_value.Type2.Shifted_value s) ) )\n (fun (g, _) ->\n let x =\n let chunks_needed = chunks_needed ~num_bits:(n - 1) in\n let actual_bits_used = chunks_needed * bits_per_chunk in\n Pickles_types.Pcs_batch.pow ~one:G.Constant.Scalar.one\n ~mul:G.Constant.Scalar.( * )\n G.Constant.Scalar.(of_int 2)\n actual_bits_used\n |> G.Constant.Scalar.( + )\n (G.Constant.Scalar.project (Field.Constant.unpack s))\n in\n G.Constant.scale g x )\n (random_point, input) )\n\n let%test_unit \"scale fast\" =\n let open Pickles_types in\n let shift =\n Shifted_value.Type1.Shift.create (module G.Constant.Scalar)\n in\n Quickcheck.test ~trials:10\n Quickcheck.Generator.(\n map (list_with_length n Bool.quickcheck_generator) ~f:(fun bs ->\n Field.Constant.project bs |> Field.Constant.unpack ))\n ~f:(fun xs ->\n try\n T.Test.test_equal ~equal:G.Constant.equal\n ~sexp_of_t:G.Constant.sexp_of_t\n (Typ.tuple2 G.typ (Typ.list ~length:n Boolean.typ))\n G.typ\n (fun (g, s) ->\n make_checked (fun () ->\n scale_fast ~num_bits:n g\n (Pickles_types.Shifted_value.Type1.Shifted_value\n (Field.project s) ) ) )\n (fun (g, s) ->\n let open G.Constant.Scalar in\n let s = project s in\n let x =\n Shifted_value.Type1.to_field\n (module G.Constant.Scalar)\n ~shift (Pickles_types.Shifted_value.Type1.Shifted_value s)\n in\n G.Constant.scale g x )\n (random_point, xs)\n with e ->\n eprintf !\"Input %{sexp: bool list}\\n%!\" xs ;\n raise e )\n end )\nend\n","open Core_kernel\nopen Import\nopen Pickles_types\nopen Common\nopen Backend\n\n(* The step-proof \"reduced\" me-only contains the data of the standard me-only\n but without the wrap verification key. The purpose of this type is for sending\n step me-onlys on the wire. There is no need to send the wrap-key since everyone\n knows it. *)\nmodule Step = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('s, 'challenge_polynomial_commitments, 'bpcs) t =\n ( 's\n , 'challenge_polynomial_commitments\n , 'bpcs )\n Mina_wire_types\n .Pickles_reduced_messages_for_next_proof_over_same_field\n .Step\n .V1\n .t =\n { app_state : 's\n ; challenge_polynomial_commitments : 'challenge_polynomial_commitments\n ; old_bulletproof_challenges : 'bpcs\n }\n [@@deriving sexp, yojson, sexp, compare, hash, equal]\n end\n end]\n\n let prepare ~dlog_plonk_index\n { app_state\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges\n } =\n { Types.Step.Proof_state.Messages_for_next_step_proof.app_state\n ; challenge_polynomial_commitments\n ; dlog_plonk_index\n ; old_bulletproof_challenges =\n Vector.map ~f:Ipa.Step.compute_challenges old_bulletproof_challenges\n }\nend\n\nmodule Wrap = struct\n module Challenges_vector = struct\n module Vector = Pickles_types.Vector\n module Wrap_bp_vec = Import.Types.Wrap_bp_vec\n open Import\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t =\n Limb_vector.Constant.Hex64.Stable.V1.t Vector.Vector_2.Stable.V1.t\n Scalar_challenge.Stable.V2.t\n Bulletproof_challenge.Stable.V1.t\n Wrap_bp_vec.Stable.V1.t\n [@@deriving sexp, compare, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n type t =\n Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Wrap_bp_vec.t\n [@@deriving sexp, compare, yojson, hash, equal]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n module Prepared = struct\n type t = (Tock.Field.t, Tock.Rounds.n) Vector.t\n end\n end\n\n type 'max_local_max_proofs_verified t =\n ( Tock.Inner_curve.Affine.t\n , (Challenges_vector.t, 'max_local_max_proofs_verified) Vector.t )\n Types.Wrap.Proof_state.Messages_for_next_wrap_proof.t\n\n module Prepared = struct\n type 'max_local_max_proofs_verified t =\n ( Tock.Inner_curve.Affine.t\n , (Challenges_vector.Prepared.t, 'max_local_max_proofs_verified) Vector.t\n )\n Types.Wrap.Proof_state.Messages_for_next_wrap_proof.t\n end\n\n let prepare\n ({ challenge_polynomial_commitment; old_bulletproof_challenges } : _ t) =\n { Types.Wrap.Proof_state.Messages_for_next_wrap_proof\n .challenge_polynomial_commitment\n ; old_bulletproof_challenges =\n Vector.map ~f:Ipa.Wrap.compute_challenges old_bulletproof_challenges\n }\nend\n","open Core_kernel\nopen Common\nopen Backend\nmodule Impl = Impls.Step\n\nlet _high_entropy_bits = 128\n\nlet sponge_params_constant = Kimchi_pasta_basic.poseidon_params_fp\n\nlet tick_field_random_oracle ?(length = Tick.Field.size_in_bits - 1) s =\n Tick.Field.of_bits (Ro.bits_random_oracle ~length s)\n\nlet _unrelated_g =\n let group_map =\n unstage\n (group_map\n (module Tick.Field)\n ~a:Tick.Inner_curve.Params.a ~b:Tick.Inner_curve.Params.b )\n and str = Fn.compose bits_to_bytes Tick.Field.to_bits in\n fun (x, y) -> group_map (tick_field_random_oracle (str x ^ str y))\n\nopen Impl\n\n(* Debug helper to convert step circuit field element to a hex string *)\nlet read_step_circuit_field_element_as_hex fe =\n let prover_fe = As_prover.read Field.typ fe in\n Kimchi_backend.Pasta.Vesta_based_plonk.(\n Bigint.to_hex (Field.to_bigint prover_fe))\n\nmodule Other_field = struct\n type t = Tock.Field.t [@@deriving sexp]\n\n include (Tock.Field : module type of Tock.Field with type t := t)\n\n let size = Impls.Wrap.Bigint.to_bignum_bigint size\nend\n\nlet sponge_params =\n Sponge.Params.(map sponge_params_constant ~f:Impl.Field.constant)\n\n(* module Unsafe = struct\n let _unpack_unboolean ?(length = Field.size_in_bits) x =\n let res =\n exists\n (Typ.list Boolean.typ_unchecked ~length)\n ~compute:\n As_prover.(\n fun () -> List.take (Field.Constant.unpack (read_var x)) length)\n in\n Field.Assert.equal x (Field.project res) ;\n res\n end *)\n\nmodule Sponge = struct\n module Permutation =\n Sponge_inputs.Make\n (Impl)\n (struct\n include Tick_field_sponge.Inputs\n\n let params = Tick_field_sponge.params\n end)\n\n module S = Sponge.Make_debug_sponge (struct\n include Permutation\n module Circuit = Impls.Step\n\n (* Optional sponge name used in debug mode *)\n let sponge_name = \"step\"\n\n (* To enable debug mode, set environment variable [sponge_name] to \"t\", \"1\" or \"true\". *)\n let debug_helper_fn = read_step_circuit_field_element_as_hex\n end)\n\n include S\n\n let squeeze_field t = squeeze t\n\n let squeeze t = squeeze t\n\n let absorb t input =\n match input with\n | `Field x ->\n absorb t x\n | `Bits bs ->\n absorb t (Field.pack bs)\nend\n\nlet%test_unit \"sponge\" =\n let module T = Make_sponge.Test (Impl) (Tick_field_sponge.Field) (Sponge.S) in\n T.test Tick_field_sponge.params\n\n(* module Input_domain = struct\n let domain = Import.Domain.Pow_2_roots_of_unity 6\n\n let _lagrange_commitments =\n lazy\n (let domain_size = Import.Domain.size domain in\n Common.time \"lagrange\" (fun () ->\n Array.init domain_size ~f:(fun i ->\n let v =\n (Kimchi_bindings.Protocol.SRS.Fq.lagrange_commitment\n (Backend.Tock.Keypair.load_urs ())\n domain_size i )\n .unshifted\n in\n assert (Array.length v = 1) ;\n v.(0) |> Common.finite_exn ) ) )\n end *)\n\nmodule Inner_curve = struct\n module C = Kimchi_pasta.Pasta.Pallas\n\n module Inputs = struct\n module Impl = Impl\n\n module Params = struct\n include C.Params\n\n let one = C.to_affine_exn C.one\n\n let group_size_in_bits = Field.size_in_bits\n end\n\n module F = struct\n include struct\n open Impl.Field\n\n type nonrec t = t\n\n let ( * ), ( + ), ( - ), inv_exn, square, scale, if_, typ, constant =\n (( * ), ( + ), ( - ), inv, square, scale, if_, typ, constant)\n\n let negate x = scale x Constant.(negate one)\n end\n\n module Constant = struct\n open Impl.Field.Constant\n\n type nonrec t = t\n\n let ( * ), ( + ), ( - ), inv_exn, square, negate =\n (( * ), ( + ), ( - ), inv, square, negate)\n end\n\n let assert_square x y = Impl.assert_square x y\n\n let assert_r1cs x y z = Impl.assert_r1cs x y z\n end\n\n module Constant = struct\n include C.Affine\n module Scalar = Impls.Wrap.Field.Constant\n\n let scale (t : t) x : t = C.(to_affine_exn (scale (of_affine t) x))\n\n let random () = C.(to_affine_exn (random ()))\n\n let zero = Impl.Field.Constant.(zero, zero)\n\n let ( + ) t1 t2 =\n let is_zero (x, _) = Impl.Field.Constant.(equal zero x) in\n if is_zero t1 then t2\n else if is_zero t2 then t1\n else\n let r = C.(of_affine t1 + of_affine t2) in\n try C.to_affine_exn r with _ -> zero\n\n let negate x = C.(to_affine_exn (negate (of_affine x)))\n\n let to_affine_exn = Fn.id\n\n let of_affine = Fn.id\n end\n end\n\n module Params = Inputs.Params\n module Constant = Inputs.Constant\n module T = Snarky_curve.For_native_base_field (Inputs)\n\n include (\n T :\n module type of T\n with module Scaling_precomputation := T.Scaling_precomputation )\n\n module Scaling_precomputation = T.Scaling_precomputation\n\n let ( + ) t1 t2 = Plonk_curve_ops.add_fast (module Impl) t1 t2\n\n let double t = t + t\n\n let scale t bs =\n with_label __LOC__ (fun () ->\n T.scale t (Bitstring_lib.Bitstring.Lsb_first.of_list bs) )\n\n let to_field_elements (x, y) = [ x; y ]\n\n let assert_equal (x1, y1) (x2, y2) =\n Field.Assert.equal x1 x2 ; Field.Assert.equal y1 y2\n\n let scale_inv t bs =\n let res =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n C.scale\n (C.of_affine (read typ t))\n (Tock.Field.inv\n (Tock.Field.of_bits (List.map ~f:(read Boolean.typ) bs)) )\n |> C.to_affine_exn)\n in\n assert_equal t (scale res bs) ;\n res\n\n let negate = T.negate\n\n let one = T.one\n\n let if_ = T.if_\nend\n\nmodule Ops = Plonk_curve_ops.Make (Impl) (Inner_curve)\n\nlet%test_unit \"scale fast 2'\" =\n let open Impl in\n let module T = Internal_Basic in\n let module G = Inner_curve in\n let n = Field.size_in_bits in\n let module F = struct\n type t = Field.t\n\n let typ = Field.typ\n\n module Constant = struct\n include Field.Constant\n\n let to_bigint = Impl.Bigint.of_field\n end\n end in\n Quickcheck.test ~trials:5 Field.Constant.gen ~f:(fun s ->\n T.Test.test_equal ~equal:G.Constant.equal ~sexp_of_t:G.Constant.sexp_of_t\n (Typ.tuple2 G.typ Field.typ)\n G.typ\n (fun (g, s) ->\n make_checked (fun () -> Ops.scale_fast2' ~num_bits:n (module F) g s)\n )\n (fun (g, _) ->\n let x =\n let chunks_needed = Ops.chunks_needed ~num_bits:(n - 1) in\n let actual_bits_used = chunks_needed * Ops.bits_per_chunk in\n Pickles_types.Pcs_batch.pow ~one:G.Constant.Scalar.one\n ~mul:G.Constant.Scalar.( * )\n G.Constant.Scalar.(of_int 2)\n actual_bits_used\n |> G.Constant.Scalar.( + )\n (G.Constant.Scalar.project (Field.Constant.unpack s))\n in\n G.Constant.scale g x )\n (G.Constant.random (), s) )\n\nlet%test_unit \"scale fast 2 small\" =\n let open Impl in\n let module T = Internal_Basic in\n let module G = Inner_curve in\n let n = 8 in\n let module F = struct\n type t = Field.t\n\n let typ = Field.typ\n\n module Constant = struct\n include Field.Constant\n\n let to_bigint = Impl.Bigint.of_field\n end\n end in\n Quickcheck.test ~trials:5 Field.Constant.gen ~f:(fun s ->\n let s =\n Field.Constant.unpack s |> Fn.flip List.take n |> Field.Constant.project\n in\n T.Test.test_equal ~equal:G.Constant.equal ~sexp_of_t:G.Constant.sexp_of_t\n (Typ.tuple2 G.typ Field.typ)\n G.typ\n (fun (g, s) ->\n make_checked (fun () -> Ops.scale_fast2' ~num_bits:n (module F) g s)\n )\n (fun (g, _) ->\n let x =\n let chunks_needed = Ops.chunks_needed ~num_bits:(n - 1) in\n let actual_bits_used = chunks_needed * Ops.bits_per_chunk in\n Pickles_types.Pcs_batch.pow ~one:G.Constant.Scalar.one\n ~mul:G.Constant.Scalar.( * )\n G.Constant.Scalar.(of_int 2)\n actual_bits_used\n |> G.Constant.Scalar.( + )\n (G.Constant.Scalar.project (Field.Constant.unpack s))\n in\n G.Constant.scale g x )\n (G.Constant.random (), s) )\n\nmodule Generators = struct\n let h =\n lazy\n ( Kimchi_bindings.Protocol.SRS.Fq.urs_h (Backend.Tock.Keypair.load_urs ())\n |> Common.finite_exn )\nend\n","(** A verification key for a pickles proof, whose contents are not fixed within\n the verifier circuit.\n This is used to verify a proof where the verification key is determined by\n some other constraint, for example to use a verification key provided as\n input to the circuit, or loaded from an account that was chosen based upon\n the circuit inputs.\n\n Here and elsewhere, we use the terms\n * **width**:\n - the number of proofs that a proof has verified itself;\n - (equivalently) the maximum number of proofs that a proof depends upon\n directly.\n - NB: This does not include recursively-verified proofs, this only refers\n to proofs that were provided directly to pickles when the proof was\n being generated.\n * **branch**:\n - a single 'rule' or 'circuit' for which a proof can be generated, where\n a verification key verifies a proof for any of these branches.\n - It is common to have a 'base' branch and a 'recursion' branch. For\n example, the transaction snark has a 'transaction' proof that evaluates\n a single transaction and a 'merge' proof that combines two transaction\n snark proofs that prove sequential updates, each of which may be either\n a 'transaction' or a 'merge'.\n*)\n\nopen Core_kernel\nopen Pickles_types\nopen Import\nmodule V = Pickles_base.Side_loaded_verification_key\n\ninclude (\n V :\n module type of V\n with module Width := V.Width\n and module Domains := V.Domains )\n\nlet bits = V.bits\n\nlet input_size ~of_int ~add ~mul w =\n (* This should be an affine function in [a]. *)\n let size a =\n let (T (Typ typ, _conv, _conv_inv)) =\n Impls.Step.input ~proofs_verified:a ~wrap_rounds:Backend.Tock.Rounds.n\n in\n\n typ.size_in_field_elements\n in\n let f0 = size Nat.N0.n in\n let slope = size Nat.N1.n - f0 in\n add (of_int f0) (mul (of_int slope) w)\n\nmodule Width : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t = V.Width.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n open Impls.Step\n\n module Checked : sig\n type t\n\n val to_field : t -> Field.t\n\n val to_bits : t -> Boolean.var list\n end\n\n val typ : (Checked.t, t) Typ.t\n\n module Max = Nat.N2\n\n module Max_vector : Vector.With_version(Max).S\n\n module Max_at_most : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type 'a t = ('a, Max.n) At_most.t\n [@@deriving compare, sexp, yojson, hash, equal]\n end\n end]\n end\n\n module Length : Nat.Add.Intf_transparent\nend = struct\n include V.Width\n open Impls.Step\n\n module Checked = struct\n (* A \"width\" is represented by a 4 bit integer. *)\n type t = (Boolean.var, Length.n) Vector.t\n\n let to_field : t -> Field.t = Fn.compose Field.project Vector.to_list\n\n let to_bits = Vector.to_list\n end\n\n let typ : (Checked.t, t) Typ.t =\n Typ.transport\n (Vector.typ Boolean.typ Length.n)\n ~there:(fun x ->\n let x = to_int x in\n Vector.init Length.n ~f:(fun i -> (x lsr i) land 1 = 1) )\n ~back:(fun v ->\n Vector.foldi v ~init:0 ~f:(fun i acc b ->\n if b then acc lor (1 lsl i) else acc )\n |> of_int_exn )\nend\n\nmodule Domain = struct\n type 'a t = Pow_2_roots_of_unity of 'a [@@deriving sexp]\n\n let log2_size (Pow_2_roots_of_unity x) = x\nend\n[@@warning \"-4\"]\n\nmodule Domains = struct\n include V.Domains\n\n let _typ =\n let open Impls.Step in\n let dom =\n Typ.transport Typ.field\n ~there:(fun (Plonk_checks.Domain.Pow_2_roots_of_unity n) ->\n Field.Constant.of_int n )\n ~back:(fun _ -> assert false)\n |> Typ.transport_var\n ~there:(fun (Domain.Pow_2_roots_of_unity n) -> n)\n ~back:(fun n -> Domain.Pow_2_roots_of_unity n)\n in\n Typ.of_hlistable [ dom ] ~var_to_hlist:to_hlist ~value_to_hlist:to_hlist\n ~var_of_hlist:of_hlist ~value_of_hlist:of_hlist\nend\n\nlet max_domains =\n { Domains.h = Domain.Pow_2_roots_of_unity (Nat.to_int Backend.Tick.Rounds.n) }\n\nmodule Vk = struct\n type t = (Impls.Wrap.Verification_key.t[@sexp.opaque]) [@@deriving sexp]\n\n let hash_fold_t s _ = Unit.hash_fold_t s ()\nend\n\nmodule R = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Backend.Tock.Curve.Affine.Stable.V1.t Repr.Stable.V2.t\n [@@deriving sexp, equal, compare, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\n[%%versioned_binable\nmodule Stable = struct\n module V2 = struct\n module T = struct\n type t =\n ( Backend.Tock.Curve.Affine.t\n , Pickles_base.Proofs_verified.Stable.V1.t\n , Vk.t )\n Poly.Stable.V2.t\n [@@deriving hash]\n\n let to_latest = Fn.id\n\n let description = \"Verification key\"\n\n let version_byte = Base58_check.Version_bytes.verification_key\n\n let to_repr\n { Poly.max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index\n ; wrap_vk = _\n } =\n { Repr.Stable.V2.max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index\n }\n\n let of_repr\n ({ Repr.Stable.V2.max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index = c\n } :\n R.Stable.V2.t ) : t =\n let d =\n (Common.wrap_domains\n ~proofs_verified:\n (Pickles_base.Proofs_verified.to_int actual_wrap_domain_size) )\n .h\n in\n let log2_size = Import.Domain.log2_size d in\n let public =\n let (T (input, _conv, _conv_inv)) =\n Impls.Wrap.input ~feature_flags:Plonk_types.Features.Full.maybe ()\n in\n let (Typ typ) = input in\n typ.size_in_field_elements\n in\n (* we only compute the wrap_vk if the srs can be loaded *)\n let srs =\n try Some (Backend.Tock.Keypair.load_urs ()) with _ -> None\n in\n let wrap_vk =\n Option.map srs ~f:(fun srs : Impls.Wrap.Verification_key.t ->\n { domain =\n { log_size_of_group = log2_size\n ; group_gen = Backend.Tock.Field.domain_generator ~log2_size\n }\n ; max_poly_size = 1 lsl Nat.to_int Backend.Tock.Rounds.n\n ; public\n ; prev_challenges = 2 (* Due to Wrap_hack *)\n ; srs\n ; evals =\n (let g (x, y) =\n { Kimchi_types.unshifted = [| Kimchi_types.Finite (x, y) |]\n ; shifted = None\n }\n in\n { sigma_comm = Array.map ~f:g (Vector.to_array c.sigma_comm)\n ; coefficients_comm =\n Array.map ~f:g (Vector.to_array c.coefficients_comm)\n ; generic_comm = g c.generic_comm\n ; mul_comm = g c.mul_comm\n ; psm_comm = g c.psm_comm\n ; emul_comm = g c.emul_comm\n ; complete_add_comm = g c.complete_add_comm\n ; endomul_scalar_comm = g c.endomul_scalar_comm\n ; xor_comm = None\n ; range_check0_comm = None\n ; range_check1_comm = None\n ; foreign_field_add_comm = None\n ; foreign_field_mul_comm = None\n ; rot_comm = None\n } )\n ; shifts = Common.tock_shifts ~log2_size\n ; lookup_index = None\n } )\n in\n { Poly.max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index = c\n ; wrap_vk\n }\n\n (* Proxy derivers to [R.t]'s, ignoring [wrap_vk] *)\n\n let sexp_of_t t = R.sexp_of_t (to_repr t)\n\n let t_of_sexp sexp = of_repr (R.t_of_sexp sexp)\n\n let _to_yojson t = R.to_yojson (to_repr t)\n\n let _of_yojson json = Result.map ~f:of_repr (R.of_yojson json)\n\n let equal x y = R.equal (to_repr x) (to_repr y)\n\n let compare x y = R.compare (to_repr x) (to_repr y)\n\n include\n Binable.Of_binable\n (R.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable r = to_repr r\n\n let of_binable r = of_repr r\n end)\n end\n\n include T\n include Codable.Make_base58_check (T)\n include Codable.Make_base64 (T)\n end\nend]\n\n[%%define_locally\nStable.Latest.\n ( to_base58_check\n , of_base58_check\n , of_base58_check_exn\n , to_base64\n , of_base64\n , sexp_of_t\n , t_of_sexp\n , to_yojson\n , of_yojson\n , equal\n , compare )]\n\nlet dummy : t =\n { max_proofs_verified = N2\n ; actual_wrap_domain_size = N2\n ; wrap_index =\n (let g = Backend.Tock.Curve.(to_affine_exn one) in\n { sigma_comm = Vector.init Plonk_types.Permuts.n ~f:(fun _ -> g)\n ; coefficients_comm = Vector.init Plonk_types.Columns.n ~f:(fun _ -> g)\n ; generic_comm = g\n ; psm_comm = g\n ; complete_add_comm = g\n ; mul_comm = g\n ; emul_comm = g\n ; endomul_scalar_comm = g\n } )\n ; wrap_vk = None\n }\n\nmodule Checked = struct\n open Step_main_inputs\n open Impl\n\n type t =\n { max_proofs_verified :\n Impl.field Pickles_base.Proofs_verified.One_hot.Checked.t\n (** The maximum of all of the [step_widths]. *)\n ; actual_wrap_domain_size :\n Impl.field Pickles_base.Proofs_verified.One_hot.Checked.t\n (** The actual domain size used by the wrap circuit. *)\n ; wrap_index : Inner_curve.t Plonk_verification_key_evals.t\n (** The plonk verification key for the 'wrapping' proof that this key\n is used to verify.\n *)\n }\n [@@deriving hlist, fields]\n\n (** [log_2] of the width. *)\n let _width_size = Nat.to_int Width.Length.n\n\n let to_input =\n let open Random_oracle_input.Chunked in\n fun { max_proofs_verified; actual_wrap_domain_size; wrap_index } :\n _ Random_oracle_input.Chunked.t ->\n let max_proofs_verified =\n Pickles_base.Proofs_verified.One_hot.Checked.to_input\n max_proofs_verified\n in\n let actual_wrap_domain_size =\n Pickles_base.Proofs_verified.One_hot.Checked.to_input\n actual_wrap_domain_size\n in\n List.reduce_exn ~f:append\n [ max_proofs_verified\n ; actual_wrap_domain_size\n ; wrap_index_to_input\n (Fn.compose Array.of_list Inner_curve.to_field_elements)\n wrap_index\n ]\nend\n\nlet%test_unit \"input_size\" =\n List.iter\n (List.range 0 (Nat.to_int Width.Max.n) ~stop:`inclusive ~start:`inclusive)\n ~f:(fun n ->\n [%test_eq: int]\n (input_size ~of_int:Fn.id ~add:( + ) ~mul:( * ) n)\n (let (T a) = Nat.of_int n in\n let (T (Typ typ, _conv, _conv_inv)) =\n Impls.Step.input ~proofs_verified:a\n ~wrap_rounds:Backend.Tock.Rounds.n\n in\n typ.size_in_field_elements ) )\n\nlet typ : (Checked.t, t) Impls.Step.Typ.t =\n let open Step_main_inputs in\n let open Impl in\n Typ.of_hlistable\n [ Pickles_base.Proofs_verified.One_hot.typ (module Impls.Step)\n ; Pickles_base.Proofs_verified.One_hot.typ (module Impls.Step)\n ; Plonk_verification_key_evals.typ Inner_curve.typ\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_of_hlist:(fun _ ->\n failwith \"Side_loaded_verification_key: value_of_hlist\" )\n ~value_to_hlist:(fun { Poly.wrap_index\n ; actual_wrap_domain_size\n ; max_proofs_verified\n ; _\n } ->\n [ max_proofs_verified; actual_wrap_domain_size; wrap_index ] )\n","open Core_kernel\nopen Pickles_types\nopen Import\nopen Backend\n\nlet hash_fold_array = Pickles_types.Plonk_types.hash_fold_array\n\nmodule Base = struct\n module Messages_for_next_proof_over_same_field =\n Reduced_messages_for_next_proof_over_same_field\n\n module Step = struct\n type ( 's\n , 'unfinalized_proofs\n , 'sgs\n , 'bp_chals\n , 'messages_for_next_wrap_proof\n , 'prev_evals )\n t =\n { statement :\n ( 'unfinalized_proofs\n , ('s, 'sgs, 'bp_chals) Messages_for_next_proof_over_same_field.Step.t\n , 'messages_for_next_wrap_proof )\n Types.Step.Statement.t\n ; index : int\n ; prev_evals : 'prev_evals\n ; proof : Tick.Proof.t\n }\n end\n\n module Wrap = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type ('messages_for_next_wrap_proof, 'messages_for_next_step_proof) t =\n ( 'messages_for_next_wrap_proof\n , 'messages_for_next_step_proof )\n Mina_wire_types.Pickles.Concrete_.Proof.Base.Wrap.V2.t =\n { statement :\n ( Limb_vector.Constant.Hex64.Stable.V1.t\n Vector.Vector_2.Stable.V1.t\n , Limb_vector.Constant.Hex64.Stable.V1.t\n Vector.Vector_2.Stable.V1.t\n Scalar_challenge.Stable.V2.t\n , Tick.Field.Stable.V1.t Shifted_value.Type1.Stable.V1.t\n , bool\n , 'messages_for_next_wrap_proof\n , Digest.Constant.Stable.V1.t\n , 'messages_for_next_step_proof\n , Limb_vector.Constant.Hex64.Stable.V1.t\n Vector.Vector_2.Stable.V1.t\n Scalar_challenge.Stable.V2.t\n Bulletproof_challenge.Stable.V1.t\n Step_bp_vec.Stable.V1.t\n , Branch_data.Stable.V1.t )\n Types.Wrap.Statement.Minimal.Stable.V1.t\n ; prev_evals :\n ( Tick.Field.Stable.V1.t\n , Tick.Field.Stable.V1.t array )\n Plonk_types.All_evals.Stable.V1.t\n ; proof : Wrap_wire_proof.Stable.V1.t\n }\n [@@deriving compare, sexp, yojson, hash, equal]\n end\n end]\n\n type ('messages_for_next_wrap_proof, 'messages_for_next_step_proof) t =\n ( 'messages_for_next_wrap_proof\n , 'messages_for_next_step_proof )\n Stable.Latest.t =\n { statement :\n ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Tick.Field.t Shifted_value.Type1.t\n , bool\n , 'messages_for_next_wrap_proof\n , Digest.Constant.t\n , 'messages_for_next_step_proof\n , Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n , Branch_data.t )\n Types.Wrap.Statement.Minimal.t\n ; prev_evals : (Tick.Field.t, Tick.Field.t array) Plonk_types.All_evals.t\n ; proof : Wrap_wire_proof.t\n }\n [@@deriving compare, sexp, yojson, hash, equal]\n end\nend\n\ntype ('s, 'mlmb, 'c) with_data =\n ('s, 'mlmb, 'c) Mina_wire_types.Pickles.Concrete_.Proof.with_data =\n | T :\n ( 'mlmb Base.Messages_for_next_proof_over_same_field.Wrap.t\n , ( 's\n , (Tock.Curve.Affine.t, 'most_recent_width) Vector.t\n , ( Challenge.Constant.t Scalar_challenge.Stable.Latest.t\n Bulletproof_challenge.t\n Step_bp_vec.t\n , 'most_recent_width )\n Vector.t )\n Base.Messages_for_next_proof_over_same_field.Step.t )\n Base.Wrap.t\n -> ('s, 'mlmb, _) with_data\n\nmodule With_data = struct\n type ('s, 'mlmb, 'w) t = ('s, 'mlmb, 'w) with_data\nend\n\ntype ('max_width, 'mlmb) t = (unit, 'mlmb, 'max_width) With_data.t\n\nlet dummy (type w h r) (_w : w Nat.t) (h : h Nat.t)\n (most_recent_width : r Nat.t) ~domain_log2 : (w, h) t =\n let open Ro in\n let g0 = Tock.Curve.(to_affine_exn one) in\n let g len = Array.create ~len g0 in\n let tick_arr len = Array.init len ~f:(fun _ -> tick ()) in\n let lengths = Commitment_lengths.default in\n T\n { statement =\n { proof_state =\n { deferred_values =\n { branch_data =\n { proofs_verified =\n ( match most_recent_width with\n | Z ->\n N0\n | S Z ->\n N1\n | S (S Z) ->\n N2\n | S _ ->\n assert false )\n ; domain_log2 =\n Branch_data.Domain_log2.of_int_exn domain_log2\n }\n ; bulletproof_challenges = Dummy.Ipa.Step.challenges\n ; plonk =\n { alpha = scalar_chal ()\n ; beta = chal ()\n ; gamma = chal ()\n ; zeta = scalar_chal ()\n ; joint_combiner = None\n ; feature_flags = Plonk_types.Features.none_bool\n }\n }\n ; sponge_digest_before_evaluations =\n Digest.Constant.of_tock_field Tock.Field.zero\n ; messages_for_next_wrap_proof =\n { challenge_polynomial_commitment = Lazy.force Dummy.Ipa.Step.sg\n ; old_bulletproof_challenges =\n Vector.init h ~f:(fun _ -> Dummy.Ipa.Wrap.challenges)\n }\n }\n ; messages_for_next_step_proof =\n { app_state = ()\n ; old_bulletproof_challenges =\n (* Not sure if this should be w or h honestly ...*)\n Vector.init most_recent_width ~f:(fun _ ->\n Dummy.Ipa.Step.challenges )\n (* TODO: Should this be wrap? *)\n ; challenge_polynomial_commitments =\n Vector.init most_recent_width ~f:(fun _ ->\n Lazy.force Dummy.Ipa.Wrap.sg )\n }\n }\n ; proof =\n Wrap_wire_proof.of_kimchi_proof\n { messages =\n { w_comm = Vector.map lengths.w ~f:g\n ; z_comm = g lengths.z\n ; t_comm = g lengths.t\n ; lookup = None\n }\n ; openings =\n (let evals = Lazy.force Dummy.evals in\n { proof =\n { lr =\n Array.init (Nat.to_int Tock.Rounds.n) ~f:(fun _ ->\n (g0, g0) )\n ; z_1 = Ro.tock ()\n ; z_2 = Ro.tock ()\n ; delta = g0\n ; challenge_polynomial_commitment = g0\n }\n ; evals = evals.evals.evals\n ; ft_eval1 = evals.ft_eval1\n } )\n }\n ; prev_evals =\n (let e =\n Plonk_types.Evals.map Evaluation_lengths.default ~f:(fun n ->\n (tick_arr n, tick_arr n) )\n in\n let ex =\n { Plonk_types.All_evals.With_public_input.public_input =\n (tick (), tick ())\n ; evals = e\n }\n in\n { ft_eval1 = tick (); evals = ex } )\n }\n\nmodule Make (W : Nat.Intf) (MLMB : Nat.Intf) = struct\n module Max_proofs_verified_at_most = At_most.With_length (W)\n module MLMB_vec = Nvector (MLMB)\n\n module Repr = struct\n type t =\n ( ( Tock.Inner_curve.Affine.t\n , Reduced_messages_for_next_proof_over_same_field.Wrap.Challenges_vector\n .t\n MLMB_vec.t )\n Types.Wrap.Proof_state.Messages_for_next_wrap_proof.t\n , ( unit\n , Tock.Curve.Affine.t Max_proofs_verified_at_most.t\n , Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n Max_proofs_verified_at_most.t )\n Base.Messages_for_next_proof_over_same_field.Step.t )\n Base.Wrap.t\n [@@deriving compare, sexp, yojson, hash, equal]\n end\n\n type nonrec t = (W.n, MLMB.n) t\n\n let to_repr (T t) : Repr.t =\n let lte =\n Nat.lte_exn\n (Vector.length\n t.statement.messages_for_next_step_proof\n .challenge_polynomial_commitments )\n W.n\n in\n { t with\n statement =\n { t.statement with\n messages_for_next_step_proof =\n { t.statement.messages_for_next_step_proof with\n challenge_polynomial_commitments =\n At_most.of_vector\n t.statement.messages_for_next_step_proof\n .challenge_polynomial_commitments lte\n ; old_bulletproof_challenges =\n At_most.of_vector\n t.statement.messages_for_next_step_proof\n .old_bulletproof_challenges lte\n }\n }\n }\n\n let of_repr (r : Repr.t) : t =\n let (Vector.T challenge_polynomial_commitments) =\n At_most.to_vector\n r.statement.messages_for_next_step_proof\n .challenge_polynomial_commitments\n in\n let (Vector.T old_bulletproof_challenges) =\n At_most.to_vector\n r.statement.messages_for_next_step_proof.old_bulletproof_challenges\n in\n let T =\n Nat.eq_exn\n (Vector.length challenge_polynomial_commitments)\n (Vector.length old_bulletproof_challenges)\n in\n T\n { r with\n statement =\n { r.statement with\n messages_for_next_step_proof =\n { r.statement.messages_for_next_step_proof with\n challenge_polynomial_commitments\n ; old_bulletproof_challenges\n }\n }\n }\n\n let compare t1 t2 = Repr.compare (to_repr t1) (to_repr t2)\n\n let equal t1 t2 = Repr.equal (to_repr t1) (to_repr t2)\n\n let hash_fold_t s t = Repr.hash_fold_t s (to_repr t)\n\n let hash t = Repr.hash (to_repr t)\n\n include\n Sexpable.Of_sexpable\n (Repr)\n (struct\n type nonrec t = t\n\n let to_sexpable = to_repr\n\n let of_sexpable = of_repr\n end)\n\n let to_base64 t =\n (* assume call to Nat.lte_exn does not raise with a valid instance of t *)\n let sexp = sexp_of_t t in\n (* raises only on invalid optional arguments *)\n Base64.encode_exn (Sexp.to_string sexp)\n\n let of_base64 b64 =\n match Base64.decode b64 with\n | Ok t -> (\n try Ok (t_of_sexp (Sexp.of_string t))\n with exn -> Error (Exn.to_string exn) )\n | Error (`Msg s) ->\n Error s\n\n let to_yojson_full x = Repr.to_yojson (to_repr x)\n\n let to_yojson x = `String (to_base64 x)\n\n let of_yojson = function\n | `String x ->\n of_base64 x\n | _ ->\n Error \"Invalid json for proof. Expecting base64 encoded string\"\nend\n\nmodule Proofs_verified_2 = struct\n module T = Make (Nat.N2) (Nat.N2)\n\n module Repr = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t =\n ( ( Tock.Inner_curve.Affine.Stable.V1.t\n , Reduced_messages_for_next_proof_over_same_field.Wrap\n .Challenges_vector\n .Stable\n .V2\n .t\n Vector.Vector_2.Stable.V1.t )\n Types.Wrap.Proof_state.Messages_for_next_wrap_proof.Stable.V1.t\n , ( unit\n , Tock.Curve.Affine.t At_most.At_most_2.Stable.V1.t\n , Limb_vector.Constant.Hex64.Stable.V1.t Vector.Vector_2.Stable.V1.t\n Scalar_challenge.Stable.V2.t\n Bulletproof_challenge.Stable.V1.t\n Step_bp_vec.Stable.V1.t\n At_most.At_most_2.Stable.V1.t )\n Base.Messages_for_next_proof_over_same_field.Step.Stable.V1.t )\n Base.Wrap.Stable.V2.t\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n include T.Repr\n\n (* Force the typechecker to verify that these types are equal. *)\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n end\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t = T.t\n\n let to_latest = Fn.id\n\n include (T : module type of T with type t := t with module Repr := T.Repr)\n\n include\n Binable.Of_binable\n (Repr.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable = to_repr\n\n let of_binable = of_repr\n end)\n end\n end]\n\n include (T : module type of T with module Repr := T.Repr)\nend\n\nmodule Proofs_verified_max = struct\n module T =\n Make\n (Side_loaded_verification_key.Width.Max)\n (Side_loaded_verification_key.Width.Max)\n\n module Repr = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t =\n ( ( Tock.Inner_curve.Affine.Stable.V1.t\n , Reduced_messages_for_next_proof_over_same_field.Wrap\n .Challenges_vector\n .Stable\n .V2\n .t\n Side_loaded_verification_key.Width.Max_vector.Stable.V1.t )\n Types.Wrap.Proof_state.Messages_for_next_wrap_proof.Stable.V1.t\n , ( unit\n , Tock.Curve.Affine.t\n Side_loaded_verification_key.Width.Max_at_most.Stable.V1.t\n , Limb_vector.Constant.Hex64.Stable.V1.t Vector.Vector_2.Stable.V1.t\n Scalar_challenge.Stable.V2.t\n Bulletproof_challenge.Stable.V1.t\n Step_bp_vec.Stable.V1.t\n Side_loaded_verification_key.Width.Max_at_most.Stable.V1.t )\n Base.Messages_for_next_proof_over_same_field.Step.Stable.V1.t )\n Base.Wrap.Stable.V2.t\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n include T.Repr\n\n (* Force the typechecker to verify that these types are equal. *)\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n end\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t = T.t\n\n let to_latest = Fn.id\n\n include (T : module type of T with type t := t with module Repr := T.Repr)\n\n include\n Binable.Of_binable\n (Repr.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable = to_repr\n\n let of_binable = of_repr\n end)\n end\n end]\n\n include (T : module type of T with module Repr := T.Repr)\nend\n","open Core_kernel\nopen Backend\nmodule Me = Tock\nmodule Other = Tick\nmodule Impl = Impls.Wrap\n\nlet _high_entropy_bits = 128\n\nlet sponge_params_constant = Kimchi_pasta_basic.poseidon_params_fq\n\nlet field_random_oracle ?(length = Me.Field.size_in_bits - 1) s =\n Me.Field.of_bits (Ro.bits_random_oracle ~length s)\n\nlet _unrelated_g =\n let open Common in\n let group_map =\n unstage\n (group_map\n (module Me.Field)\n ~a:Me.Inner_curve.Params.a ~b:Me.Inner_curve.Params.b )\n and str = Fn.compose bits_to_bytes Me.Field.to_bits in\n fun (x, y) -> group_map (field_random_oracle (str x ^ str y))\n\nopen Impl\n\n(* Debug helper to convert wrap circuit field element to a hex string *)\nlet read_wrap_circuit_field_element_as_hex fe =\n let prover_fe = As_prover.read Field.typ fe in\n Kimchi_backend.Pasta.Pallas_based_plonk.(\n Bigint.to_hex (Field.to_bigint prover_fe))\n\nmodule Other_field = struct\n type t = Impls.Step.Field.Constant.t [@@deriving sexp]\n\n include (Tick.Field : module type of Tick.Field with type t := t)\n\n let size = Impls.Step.Bigint.to_bignum_bigint size\nend\n\nlet sponge_params =\n Sponge.Params.(map sponge_params_constant ~f:Impl.Field.constant)\n\nmodule Unsafe = struct\n let unpack_unboolean ?(length = Field.size_in_bits) x =\n let res =\n exists\n (Typ.list Boolean.typ_unchecked ~length)\n ~compute:\n As_prover.(\n fun () -> List.take (Field.Constant.unpack (read_var x)) length)\n in\n Field.Assert.equal x (Field.project res) ;\n res\nend\n\nmodule Sponge = struct\n module Permutation =\n Sponge_inputs.Make\n (Impl)\n (struct\n include Tock_field_sponge.Inputs\n\n let params = Tock_field_sponge.params\n end)\n\n module S = Sponge.Make_debug_sponge (struct\n include Permutation\n module Circuit = Impls.Wrap\n\n (* Optional sponge name used in debug mode *)\n let sponge_name = \"wrap\"\n\n (* To enable debug mode, set environment variable [sponge_name] to \"t\", \"1\" or \"true\". *)\n let debug_helper_fn = read_wrap_circuit_field_element_as_hex\n end)\n\n include S\n\n let squeeze_field = squeeze\n\n let squeeze = squeeze\nend\n\nlet%test_unit \"sponge\" =\n let module T = Make_sponge.Test (Impl) (Tock_field_sponge.Field) (Sponge.S) in\n T.test Tock_field_sponge.params\n\n(* module Input_domain = struct\n let _lagrange_commitments domain : Backend.Tock.Inner_curve.Affine.t array =\n let domain_size = Import.Domain.size domain in\n Common.time \"lagrange\" (fun () ->\n Array.init domain_size ~f:(fun i ->\n (Kimchi_bindings.Protocol.SRS.Fp.lagrange_commitment\n (Backend.Tick.Keypair.load_urs ())\n domain_size i )\n .unshifted.(0)\n |> Common.finite_exn ) )\n\n let _domain = Import.Domain.Pow_2_roots_of_unity 7\n end *)\n\nmodule Inner_curve = struct\n module C = Kimchi_pasta.Pasta.Vesta\n\n module Inputs = struct\n module Impl = Impl\n\n module Params = struct\n include C.Params\n\n let one = C.to_affine_exn C.one\n\n let group_size_in_bits = Field.size_in_bits\n end\n\n module F = struct\n include struct\n open Impl.Field\n\n type nonrec t = t\n\n let ( * ), ( + ), ( - ), inv_exn, square, scale, if_, typ, constant =\n (( * ), ( + ), ( - ), inv, square, scale, if_, typ, constant)\n\n let negate x = scale x Constant.(negate one)\n end\n\n module Constant = struct\n open Impl.Field.Constant\n\n type nonrec t = t\n\n let ( * ), ( + ), ( - ), inv_exn, square, negate =\n (( * ), ( + ), ( - ), inv, square, negate)\n end\n\n let assert_square x y = Impl.assert_square x y\n\n let assert_r1cs x y z = Impl.assert_r1cs x y z\n end\n\n module Constant = struct\n include C.Affine\n module Scalar = Impls.Step.Field.Constant\n\n let scale (t : t) (x : Scalar.t) : t =\n C.(to_affine_exn (scale (of_affine t) x))\n\n let random () : t = C.(to_affine_exn (random ()))\n\n let zero = Impl.Field.Constant.(zero, zero)\n\n let ( + ) t1 t2 : t =\n let is_zero (x, _) = Impl.Field.Constant.(equal zero x) in\n if is_zero t1 then t2\n else if is_zero t2 then t1\n else\n let r = C.(of_affine t1 + of_affine t2) in\n try C.to_affine_exn r with _ -> zero\n\n let negate x : t = C.(to_affine_exn (negate (of_affine x)))\n\n let to_affine_exn = Fn.id\n\n let of_affine = Fn.id\n end\n end\n\n module Params = Inputs.Params\n module Constant = Inputs.Constant\n module T = Snarky_curve.For_native_base_field (Inputs)\n\n include (\n T :\n module type of T\n with module Scaling_precomputation := T.Scaling_precomputation )\n\n module Scaling_precomputation = T.Scaling_precomputation\n\n let ( + ) t1 t2 = Plonk_curve_ops.add_fast (module Impl) t1 t2\n\n let double t = t + t\n\n let scale t bs =\n with_label __LOC__ (fun () ->\n T.scale t (Bitstring_lib.Bitstring.Lsb_first.of_list bs) )\n\n let to_field_elements (x, y) = [ x; y ]\n\n let assert_equal (x1, y1) (x2, y2) =\n Field.Assert.equal x1 x2 ; Field.Assert.equal y1 y2\n\n let scale_inv t bs =\n let res =\n exists typ\n ~compute:\n As_prover.(\n fun () ->\n C.scale\n (C.of_affine (read typ t))\n (Other.Field.inv\n (Other.Field.of_bits (List.map ~f:(read Boolean.typ) bs)) )\n |> C.to_affine_exn)\n in\n assert_equal t (scale res bs) ;\n res\n\n let negate = T.negate\n\n let one = T.one\n\n let if_ = T.if_\nend\n\nmodule Ops = Plonk_curve_ops.Make (Impl) (Inner_curve)\n\nmodule Generators = struct\n let h =\n lazy\n ( Kimchi_bindings.Protocol.SRS.Fp.urs_h (Backend.Tick.Keypair.load_urs ())\n |> Common.finite_exn )\nend\n","module S = Sponge\nopen Core_kernel\nopen Util\nmodule SC = Scalar_challenge\nopen Pickles_types\nopen Plonk_types\nopen Tuple_lib\nopen Import\n\n(* G is for Generic. This module is just to protect {!val:challenge_polynomial}\n below from being hidden by the included functor application at the end of\n the module, so that we can re-export it in the end. *)\nmodule G = struct\n (* given [chals], compute\n \\prod_i (1 + chals.(i) * x^{2^{k - 1 - i}}) *)\n let challenge_polynomial (type a)\n (module M : Pickles_types.Shifted_value.Field_intf with type t = a) chals\n : (a -> a) Staged.t =\n stage (fun pt ->\n let k = Array.length chals in\n let pow_two_pows =\n let res = Array.init k ~f:(fun _ -> pt) in\n for i = 1 to k - 1 do\n let y = res.(i - 1) in\n res.(i) <- M.(y * y)\n done ;\n res\n in\n let prod f =\n let r = ref (f 0) in\n for i = 1 to k - 1 do\n r := M.(f i * !r)\n done ;\n !r\n in\n prod (fun i ->\n let idx = k - 1 - i in\n M.(one + (chals.(i) * pow_two_pows.(idx))) ) )\n\n let num_possible_domains = Nat.S Wrap_hack.Padded_length.n\n\n let all_possible_domains =\n Memo.unit (fun () ->\n Vector.init num_possible_domains ~f:(fun proofs_verified ->\n (Common.wrap_domains ~proofs_verified).h ) )\nend\n\nmodule Make\n (Inputs : Intf.Wrap_main_inputs.S\n with type Impl.field = Backend.Tock.Field.t\n and type Impl.Bigint.t = Backend.Tock.Bigint.t\n and type Inner_curve.Constant.Scalar.t = Backend.Tick.Field.t) =\nstruct\n open Inputs\n open Impl\n\n module Other_field = struct\n module Packed = struct\n module Constant = Other_field\n\n type t = Impls.Wrap.Other_field.t\n\n let typ = Impls.Wrap.Other_field.typ\n\n let _to_bits_unsafe (x : t) = Wrap_main_inputs.Unsafe.unpack_unboolean x\n\n let absorb_shifted sponge (x : t Shifted_value.Type1.t) =\n match x with Shifted_value x -> Sponge.absorb sponge x\n end\n\n module With_top_bit0 = struct\n (* When the top bit is 0, there is no need to check that this is not\n equal to one of the forbidden values. The scaling is safe. *)\n module Constant = Other_field\n\n type t = Impls.Wrap.Other_field.t\n\n let typ = Impls.Wrap.Other_field.typ_unchecked\n\n let _absorb_shifted sponge (x : t Pickles_types.Shifted_value.Type1.t) =\n match x with Shifted_value x -> Sponge.absorb sponge x\n end\n end\n\n let num_possible_domains = G.num_possible_domains\n\n let all_possible_domains = G.all_possible_domains\n\n let print_g lab (x, y) =\n if debug then\n as_prover\n As_prover.(\n fun () ->\n printf\n !\"%s: %{sexp:Backend.Tock.Field.t}, %{sexp:Backend.Tock.Field.t}\\n\\\n %!\"\n lab (read_var x) (read_var y))\n\n let _print_w lab gs =\n if Import.debug then\n Array.iteri gs ~f:(fun i (fin, g) ->\n as_prover\n As_prover.(fun () -> printf \"fin=%b %!\" (read Boolean.typ fin)) ;\n ksprintf print_g \"%s[%d]\" lab i g )\n\n let _print_chal lab x =\n if Import.debug then\n as_prover\n As_prover.(\n fun () ->\n printf \"in-snark %s:%!\" lab ;\n Field.Constant.print\n (Field.Constant.project (List.map ~f:(read Boolean.typ) x)) ;\n printf \"\\n%!\")\n\n let print_bool lab x =\n if debug then\n as_prover (fun () ->\n printf \"%s: %b\\n%!\" lab (As_prover.read Boolean.typ x) )\n\n module Challenge = Challenge.Make (Impl)\n module Digest = Digest.Make (Impl)\n module Scalar_challenge =\n SC.Make (Impl) (Inner_curve) (Challenge) (Endo.Wrap_inner_curve)\n module Ops = Plonk_curve_ops.Make (Impl) (Inner_curve)\n\n let _product m f =\n Core_kernel.List.reduce_exn (Core_kernel.List.init m ~f) ~f:Field.( * )\n\n let absorb sponge ty t =\n absorb\n ~mask_g1_opt:(fun () -> assert false)\n ~absorb_field:(Sponge.absorb sponge)\n ~g1_to_field_elements:Inner_curve.to_field_elements\n ~absorb_scalar:(Sponge.absorb sponge) ty t\n\n let scalar_to_field s =\n SC.to_field_checked (module Impl) s ~endo:Endo.Step_inner_curve.scalar\n\n let assert_n_bits ~n a =\n (* Scalar_challenge.to_field_checked has the side effect of\n checking that the input fits in n bits. *)\n ignore\n ( SC.to_field_checked\n (module Impl)\n (Import.Scalar_challenge.create a)\n ~endo:Endo.Step_inner_curve.scalar ~num_bits:n\n : Field.t )\n\n let lowest_128_bits ~constrain_low_bits x =\n let assert_128_bits = assert_n_bits ~n:128 in\n Util.lowest_128_bits ~constrain_low_bits ~assert_128_bits (module Impl) x\n\n let squeeze_challenge sponge : Field.t =\n lowest_128_bits (* I think you may not have to constrain these actually *)\n ~constrain_low_bits:true (Sponge.squeeze sponge)\n\n let squeeze_scalar sponge : Field.t Import.Scalar_challenge.t =\n (* No need to boolean constrain scalar challenges. *)\n Import.Scalar_challenge.create\n (lowest_128_bits ~constrain_low_bits:false (Sponge.squeeze sponge))\n\n let bullet_reduce sponge gammas =\n let absorb t = absorb sponge t in\n let prechallenges =\n Array.map gammas ~f:(fun gammas_i ->\n absorb (PC :: PC) gammas_i ;\n squeeze_scalar sponge )\n in\n let term_and_challenge (l, r) pre =\n let left_term = Scalar_challenge.endo_inv l pre in\n let right_term = Scalar_challenge.endo r pre in\n (Ops.add_fast left_term right_term, Bulletproof_challenge.unpack pre)\n in\n let terms, challenges =\n Array.map2_exn gammas prechallenges ~f:term_and_challenge |> Array.unzip\n in\n\n (Array.reduce_exn terms ~f:(Ops.add_fast ?check_finite:None), challenges)\n\n let equal_g g1 g2 =\n List.map2_exn ~f:Field.equal\n (Inner_curve.to_field_elements g1)\n (Inner_curve.to_field_elements g2)\n |> Boolean.all\n\n module One_hot_vector = One_hot_vector.Make (Impl)\n\n type ('a, 'a_opt) index' = ('a, 'a_opt) Plonk_verification_key_evals.Step.t\n\n (* Mask out the given vector of indices with the given one-hot vector *)\n let choose_key :\n type n.\n n One_hot_vector.t\n -> ( (Inner_curve.t, (Inner_curve.t, Boolean.var) Opt.t) index'\n , n )\n Vector.t\n -> (Inner_curve.t, (Inner_curve.t, Boolean.var) Opt.t) index' =\n let open Tuple_lib in\n fun bs keys ->\n let open Field in\n Vector.map2\n (bs :> (Boolean.var, n) Vector.t)\n keys\n ~f:(fun b key ->\n Plonk_verification_key_evals.Step.map key\n ~f:(fun g -> Double.map g ~f:(( * ) (b :> t)))\n ~f_opt:(function\n (* Here, we split the 3 variants into 3 separate accumulators. This\n allows us to only compute the 'maybe' flag when we need to, and\n allows us to fall back to the basically-free `None` when a\n feature is entirely unused, or to the less expensive `Some` if\n it is used for every circuit.\n In particular, it is important that we generate exactly `None`\n when none of the optional gates are used, otherwise we will\n change the serialization of the protocol circuits.\n *)\n | Opt.Nothing ->\n ([], [], [ b ])\n | Opt.Maybe (b_x, x) ->\n ([], [ (b, b_x, x) ], [])\n | Opt.Just x ->\n ([ (b, x) ], [], []) ) )\n |> Vector.reduce_exn\n ~f:\n (Plonk_verification_key_evals.Step.map2 ~f:(Double.map2 ~f:( + ))\n ~f_opt:(fun (yes_1, maybe_1, no_1) (yes_2, maybe_2, no_2) ->\n (yes_1 @ yes_2, maybe_1 @ maybe_2, no_1 @ no_2) ) )\n |> Plonk_verification_key_evals.Step.map ~f:Fn.id ~f_opt:(function\n | [], [], _nones ->\n (* We only have `None`s, so we can emit exactly `None` without\n further computation.\n *)\n Opt.Nothing\n | somes, [], [] ->\n (* Special case: we don't need to compute the 'maybe' bool\n because we know statically that all entries are `Some`.\n *)\n let sum =\n somes\n |> List.map ~f:(fun ((b : Boolean.var), g) ->\n Double.map g ~f:(( * ) (b :> t)) )\n |> List.reduce_exn ~f:(Double.map2 ~f:( + ))\n in\n Opt.just sum\n | somes, maybes, nones ->\n let is_none =\n List.reduce nones\n ~f:(fun (b1 : Boolean.var) (b2 : Boolean.var) ->\n Boolean.Unsafe.of_cvar Field.(add (b1 :> t) (b2 :> t)) )\n in\n let none_sum =\n Option.map is_none ~f:(fun (b : Boolean.var) ->\n Double.map Inner_curve.one ~f:(( * ) (b :> t)) )\n in\n let some_is_yes, some_sum =\n somes\n |> List.map ~f:(fun ((b : Boolean.var), g) ->\n (b, Double.map g ~f:(( * ) (b :> t))) )\n |> List.reduce\n ~f:(fun ((b1 : Boolean.var), g1) ((b2 : Boolean.var), g2)\n ->\n ( Boolean.Unsafe.of_cvar Field.(add (b1 :> t) (b2 :> t))\n , Double.map2 ~f:( + ) g1 g2 ) )\n |> fun x -> (Option.map ~f:fst x, Option.map ~f:snd x)\n in\n let maybe_is_yes, maybe_sum =\n maybes\n |> List.map\n ~f:(fun ((b : Boolean.var), (b_g : Boolean.var), g) ->\n ( Boolean.Unsafe.of_cvar Field.(mul (b :> t) (b_g :> t))\n , Double.map g ~f:(( * ) (b :> t)) ) )\n |> List.reduce\n ~f:(fun ((b1 : Boolean.var), g1) ((b2 : Boolean.var), g2)\n ->\n ( Boolean.Unsafe.of_cvar Field.(add (b1 :> t) (b2 :> t))\n , Double.map2 ~f:( + ) g1 g2 ) )\n |> fun x -> (Option.map ~f:fst x, Option.map ~f:snd x)\n in\n let is_yes =\n [| some_is_yes; maybe_is_yes |]\n |> Array.filter_map ~f:Fn.id\n |> Array.reduce_exn\n ~f:(fun (b1 : Boolean.var) (b2 : Boolean.var) ->\n Boolean.Unsafe.of_cvar ((b1 :> t) + (b2 :> t)) )\n in\n let sum =\n [| none_sum; maybe_sum; some_sum |]\n |> Array.filter_map ~f:Fn.id\n |> Array.reduce_exn ~f:(Double.map2 ~f:( + ))\n in\n Opt.Maybe (is_yes, sum) )\n\n (* TODO: Unify with the code in step_verifier *)\n let lagrange (type n)\n ~domain:\n ( (which_branch : n One_hot_vector.t)\n , (domains : (Domains.t, n) Vector.t) ) srs i =\n Vector.map domains ~f:(fun d ->\n let d = Int.pow 2 (Domain.log2_size d.h) in\n match[@warning \"-4\"]\n (Kimchi_bindings.Protocol.SRS.Fp.lagrange_commitment srs d i)\n .unshifted\n with\n | [| Finite g |] ->\n let g = Inner_curve.Constant.of_affine g in\n Inner_curve.constant g\n | _ ->\n assert false )\n |> Vector.map2\n (which_branch :> (Boolean.var, n) Vector.t)\n ~f:(fun b (x, y) -> Field.((b :> t) * x, (b :> t) * y))\n |> Vector.reduce_exn ~f:(Double.map2 ~f:Field.( + ))\n\n let scaled_lagrange (type n) c\n ~domain:\n ( (which_branch : n One_hot_vector.t)\n , (domains : (Domains.t, n) Vector.t) ) srs i =\n Vector.map domains ~f:(fun d ->\n let d = Int.pow 2 (Domain.log2_size d.h) in\n match[@warning \"-4\"]\n (Kimchi_bindings.Protocol.SRS.Fp.lagrange_commitment srs d i)\n .unshifted\n with\n | [| Finite g |] ->\n let g = Inner_curve.Constant.of_affine g in\n Inner_curve.Constant.scale g c |> Inner_curve.constant\n | _ ->\n assert false )\n |> Vector.map2\n (which_branch :> (Boolean.var, n) Vector.t)\n ~f:(fun b (x, y) -> Field.((b :> t) * x, (b :> t) * y))\n |> Vector.reduce_exn ~f:(Double.map2 ~f:Field.( + ))\n\n let lagrange_with_correction (type n) ~input_length\n ~domain:\n ( (which_branch : n One_hot_vector.t)\n , (domains : (Domains.t, n) Vector.t) ) srs i : Inner_curve.t Double.t =\n with_label __LOC__ (fun () ->\n let actual_shift =\n (* TODO: num_bits should maybe be input_length - 1. *)\n Ops.bits_per_chunk * Ops.chunks_needed ~num_bits:input_length\n in\n let rec pow2pow x i =\n if i = 0 then x else pow2pow Inner_curve.Constant.(x + x) (i - 1)\n in\n let base_and_correction (h : Domain.t) =\n let d = Int.pow 2 (Domain.log2_size h) in\n match[@warning \"-4\"]\n (Kimchi_bindings.Protocol.SRS.Fp.lagrange_commitment srs d i)\n .unshifted\n with\n | [| Finite g |] ->\n let open Inner_curve.Constant in\n let g = of_affine g in\n ( Inner_curve.constant g\n , Inner_curve.constant (negate (pow2pow g actual_shift)) )\n | xs ->\n failwithf \"expected commitment to have length 1. got %d\"\n (Array.length xs) ()\n in\n match domains with\n | [] ->\n assert false\n | d :: ds ->\n if Vector.for_all ds ~f:(fun d' -> Domain.equal d.h d'.h) then\n base_and_correction d.h\n else\n Vector.map domains ~f:(fun (ds : Domains.t) ->\n base_and_correction ds.h )\n |> Vector.map2\n (which_branch :> (Boolean.var, n) Vector.t)\n ~f:(fun b pr ->\n Double.map pr ~f:(fun (x, y) ->\n Field.((b :> t) * x, (b :> t) * y) ) )\n |> Vector.reduce_exn\n ~f:(Double.map2 ~f:(Double.map2 ~f:Field.( + )))\n |> Double.map ~f:(Double.map ~f:(Util.seal (module Impl))) )\n\n let _h_precomp =\n Lazy.map ~f:Inner_curve.Scaling_precomputation.create Generators.h\n\n let group_map =\n let f =\n lazy\n (let module M =\n Group_map.Bw19.Make (Field.Constant) (Field)\n (struct\n let params =\n Group_map.Bw19.Params.create\n (module Field.Constant)\n { b = Inner_curve.Params.b }\n end)\n in\n let open M in\n Snarky_group_map.Checked.wrap\n (module Impl)\n ~potential_xs\n ~y_squared:(fun ~x ->\n Field.(\n (x * x * x)\n + (constant Inner_curve.Params.a * x)\n + constant Inner_curve.Params.b) )\n |> unstage )\n in\n fun x -> Lazy.force f x\n\n module Split_commitments = struct\n module Point = struct\n type t =\n [ `Finite of Inner_curve.t\n | `Maybe_finite of Boolean.var * Inner_curve.t ]\n\n let finite : t -> Boolean.var = function\n | `Finite _ ->\n Boolean.true_\n | `Maybe_finite (b, _) ->\n b\n\n let add (p : t) (q : Inner_curve.t) =\n match p with\n | `Finite p ->\n Ops.add_fast p q\n | `Maybe_finite (finite, p) ->\n Inner_curve.if_ finite ~then_:(Ops.add_fast p q) ~else_:q\n\n let underlying = function `Finite p -> p | `Maybe_finite (_, p) -> p\n end\n\n module Curve_opt = struct\n type t = { point : Inner_curve.t; non_zero : Boolean.var }\n end\n\n let combine batch ~xi without_bound with_bound =\n let { Curve_opt.non_zero; point } =\n Pcs_batch.combine_split_commitments batch\n ~scale_and_add:(fun ~(acc : Curve_opt.t) ~xi\n (p : (Point.t, Boolean.var) Opt.t) ->\n (* match acc.non_zero, keep with\n | false, false -> acc\n | true, false -> acc\n | false, true -> { point= p; non_zero= true }\n | true, true -> { point= p + xi * acc; non_zero= true }\n *)\n let point keep p =\n let point =\n Inner_curve.(\n if_ keep\n ~then_:\n (if_ acc.non_zero\n ~then_:\n (Point.add p (Scalar_challenge.endo acc.point xi))\n ~else_:\n ((* In this branch, the accumulator was zero, so there is no harm in\n putting the potentially junk underlying point here. *)\n Point.underlying p ) )\n ~else_:acc.point)\n in\n let non_zero =\n Boolean.(keep &&& Point.finite p ||| acc.non_zero)\n in\n { Curve_opt.non_zero; point }\n in\n match p with\n | Opt.Nothing ->\n acc\n | Opt.Maybe (keep, p) ->\n point keep p\n | Opt.Just p ->\n point Boolean.true_ p )\n ~xi\n ~init:(function\n | Opt.Nothing ->\n None\n | Opt.Maybe (keep, p) ->\n Some\n { non_zero = Boolean.(keep &&& Point.finite p)\n ; point = Point.underlying p\n }\n | Opt.Just p ->\n Some\n { non_zero = Boolean.(true_ &&& Point.finite p)\n ; point = Point.underlying p\n } )\n without_bound with_bound\n in\n Boolean.Assert.is_true non_zero ;\n point\n end\n\n let scale_fast = Ops.scale_fast\n\n let check_bulletproof ~pcs_batch ~(sponge : Sponge.t)\n ~(xi : Scalar_challenge.t)\n ~(advice :\n Other_field.Packed.t Shifted_value.Type1.t\n Types.Step.Bulletproof.Advice.t )\n ~polynomials:(without_degree_bound, with_degree_bound)\n ~openings_proof:\n ({ lr; delta; z_1; z_2; challenge_polynomial_commitment } :\n ( Inner_curve.t\n , Other_field.Packed.t Shifted_value.Type1.t )\n Openings.Bulletproof.t ) =\n with_label __LOC__ (fun () ->\n Other_field.Packed.absorb_shifted sponge advice.combined_inner_product ;\n (* combined_inner_product should be equal to\n sum_i < t, r^i pows(beta_i) >\n = sum_i r^i < t, pows(beta_i) >\n\n That is checked later.\n *)\n let u =\n let t = Sponge.squeeze_field sponge in\n group_map t\n in\n let open Inner_curve in\n let combined_polynomial (* Corresponds to xi in figure 7 of WTS *) =\n Split_commitments.combine pcs_batch ~xi without_degree_bound\n with_degree_bound\n in\n let scale_fast =\n scale_fast ~num_bits:Other_field.Packed.Constant.size_in_bits\n in\n let lr_prod, challenges = bullet_reduce sponge lr in\n let p_prime =\n let uc = scale_fast u advice.combined_inner_product in\n combined_polynomial + uc\n in\n let q = p_prime + lr_prod in\n absorb sponge PC delta ;\n let c = squeeze_scalar sponge in\n (* c Q + delta = z1 (G + b U) + z2 H *)\n let lhs =\n let cq = Scalar_challenge.endo q c in\n cq + delta\n in\n let rhs =\n let b_u = scale_fast u advice.b in\n let z_1_g_plus_b_u =\n scale_fast (challenge_polynomial_commitment + b_u) z_1\n in\n let z2_h =\n scale_fast (Inner_curve.constant (Lazy.force Generators.h)) z_2\n in\n z_1_g_plus_b_u + z2_h\n in\n (`Success (equal_g lhs rhs), challenges) )\n\n module Opt = struct\n include Opt_sponge.Make (Impl) (Wrap_main_inputs.Sponge.Permutation)\n\n let challenge (s : t) : Field.t =\n lowest_128_bits (squeeze s) ~constrain_low_bits:true\n\n (* No need to boolean constrain scalar challenges. *)\n let scalar_challenge (s : t) : Scalar_challenge.t =\n Import.Scalar_challenge.create\n (lowest_128_bits (squeeze s) ~constrain_low_bits:false)\n end\n\n (* TODO: This doesn't need to be an opt sponge *)\n let absorb sponge ty t =\n Util.absorb ~absorb_field:(Opt.absorb sponge)\n ~g1_to_field_elements:(fun (b, (x, y)) -> [ (b, x); (b, y) ])\n ~absorb_scalar:(fun x -> Opt.absorb sponge (Boolean.true_, x))\n ~mask_g1_opt:(fun ((finite : Boolean.var), (x, y)) ->\n (Boolean.true_, Field.((finite :> t) * x, (finite :> t) * y)) )\n ty t\n\n module Pseudo = Pseudo.Make (Impl)\n\n let mask (type n) (lengths : (int, n) Vector.t) (choice : n One_hot_vector.t)\n : Boolean.var array =\n let max =\n Option.value_exn\n (List.max_elt ~compare:Int.compare (Vector.to_list lengths))\n in\n let length = Pseudo.choose (choice, lengths) ~f:Field.of_int in\n let (T max) = Nat.of_int max in\n Vector.to_array (ones_vector (module Impl) ~first_zero:length max)\n\n module Plonk = Types.Wrap.Proof_state.Deferred_values.Plonk\n\n (* Just for exhaustiveness over fields *)\n let iter2 ~chal ~scalar_chal\n { Plonk.Minimal.In_circuit.alpha = alpha_0\n ; beta = beta_0\n ; gamma = gamma_0\n ; zeta = zeta_0\n ; joint_combiner = joint_combiner_0\n ; feature_flags = _\n }\n { Plonk.Minimal.In_circuit.alpha = alpha_1\n ; beta = beta_1\n ; gamma = gamma_1\n ; zeta = zeta_1\n ; joint_combiner = joint_combiner_1\n ; feature_flags = _\n } =\n with_label __LOC__ (fun () ->\n match[@warning \"-4\"] (joint_combiner_0, joint_combiner_1) with\n | Nothing, Nothing ->\n ()\n | Maybe (b0, j0), Maybe (b1, j1) ->\n Boolean.Assert.(b0 = b1) ;\n let (Typ { var_to_fields; _ }) = Scalar_challenge.typ in\n Array.iter2_exn ~f:Field.Assert.equal\n (fst @@ var_to_fields j0)\n (fst @@ var_to_fields j1)\n | Just j0, Just j1 ->\n let (Typ { var_to_fields; _ }) = Scalar_challenge.typ in\n Array.iter2_exn ~f:Field.Assert.equal\n (fst @@ var_to_fields j0)\n (fst @@ var_to_fields j1)\n | ( ((Pickles_types.Opt.Just _ | Maybe _ | Nothing) as j0)\n , ((Pickles_types.Opt.Just _ | Maybe _ | Nothing) as j1) ) ->\n let sexp_of t =\n Sexp.to_string\n @@ Types.Opt.sexp_of_t\n (fun _ -> Sexp.Atom \"\")\n (fun _ -> Sexp.Atom \"\")\n t\n in\n failwithf\n \"incompatible optional states for joint_combiners: %s vs %s\"\n (sexp_of j0) (sexp_of j1) () ) ;\n with_label __LOC__ (fun () -> chal beta_0 beta_1) ;\n with_label __LOC__ (fun () -> chal gamma_0 gamma_1) ;\n with_label __LOC__ (fun () -> scalar_chal alpha_0 alpha_1) ;\n with_label __LOC__ (fun () -> scalar_chal zeta_0 zeta_1)\n\n let assert_eq_plonk\n (m1 : (_, Field.t Import.Scalar_challenge.t, _) Plonk.Minimal.In_circuit.t)\n (m2 : (_, Scalar_challenge.t, _) Plonk.Minimal.In_circuit.t) =\n iter2 m1 m2\n ~chal:(fun c1 c2 -> Field.Assert.equal c1 c2)\n ~scalar_chal:(fun ({ inner = t1 } : _ Import.Scalar_challenge.t)\n ({ inner = t2 } : Scalar_challenge.t) ->\n Field.Assert.equal t1 t2 )\n\n let index_to_field_elements ~g (m : _ Plonk_verification_key_evals.Step.t) =\n let { Plonk_verification_key_evals.Step.sigma_comm\n ; coefficients_comm\n ; generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n ; range_check0_comm\n ; range_check1_comm\n ; foreign_field_mul_comm\n ; foreign_field_add_comm\n ; xor_comm\n ; rot_comm\n ; lookup_table_comm\n ; lookup_table_ids\n ; runtime_tables_selector\n ; lookup_selector_xor\n ; lookup_selector_lookup\n ; lookup_selector_range_check\n ; lookup_selector_ffmul\n } =\n m\n in\n let open Pickles_types in\n let g_opt = Opt.map ~f:g in\n List.map\n ( Vector.to_list sigma_comm\n @ Vector.to_list coefficients_comm\n @ [ generic_comm\n ; psm_comm\n ; complete_add_comm\n ; mul_comm\n ; emul_comm\n ; endomul_scalar_comm\n ] )\n ~f:(fun x -> Opt.just (g x))\n @ [ g_opt range_check0_comm\n ; g_opt range_check1_comm\n ; g_opt foreign_field_mul_comm\n ; g_opt foreign_field_add_comm\n ; g_opt xor_comm\n ; g_opt rot_comm\n ]\n @ List.map ~f:g_opt (Vector.to_list lookup_table_comm)\n @ [ g_opt lookup_table_ids\n ; g_opt runtime_tables_selector\n ; g_opt lookup_selector_xor\n ; g_opt lookup_selector_lookup\n ; g_opt lookup_selector_range_check\n ; g_opt lookup_selector_ffmul\n ]\n\n (** Simulate an [Opt_sponge.t] locally in a block, but without running the\n expensive optional logic that is otherwise required.\n\n Invariant: This requires that the sponge 'state' (i.e. the state after\n absorbing or squeezing) is consistent between the initial state and the\n final state when using the sponge.\n *)\n let simulate_optional_sponge_with_alignment (sponge : Sponge.t) ~f = function\n | Pickles_types.Opt.Nothing ->\n Pickles_types.Opt.Nothing\n | Pickles_types.Opt.Maybe (b, x) ->\n (* Cache the sponge state before *)\n let sponge_state_before = sponge.sponge_state in\n let state_before = Array.copy sponge.state in\n (* Use the sponge *)\n let res = f sponge x in\n (* Check that the sponge ends in a compatible state. *)\n ( match (sponge_state_before, sponge.sponge_state) with\n | Absorbed x, Absorbed y ->\n [%test_eq: int] x y\n | Squeezed x, Squeezed y ->\n [%test_eq: int] x y\n | Absorbed _, Squeezed _ ->\n [%test_eq: string] \"absorbed\" \"squeezed\"\n | Squeezed _, Absorbed _ ->\n [%test_eq: string] \"squeezed\" \"absorbed\" ) ;\n let state =\n Array.map2_exn sponge.state state_before ~f:(fun then_ else_ ->\n Field.if_ b ~then_ ~else_ )\n in\n sponge.state <- state ;\n Pickles_types.Opt.Maybe (b, res)\n | Pickles_types.Opt.Just x ->\n Pickles_types.Opt.Just (f sponge x)\n\n let incrementally_verify_proof (type b)\n (module Max_proofs_verified : Nat.Add.Intf with type n = b)\n ~actual_proofs_verified_mask ~step_domains ~srs\n ~verification_key:(m : _ Plonk_verification_key_evals.Step.t) ~xi ~sponge\n ~(public_input :\n [ `Field of Field.t * Boolean.var | `Packed_bits of Field.t * int ]\n array ) ~(sg_old : (_, Max_proofs_verified.n) Vector.t) ~advice\n ~(messages : _ Messages.In_circuit.t) ~which_branch ~openings_proof\n ~(plonk : _ Types.Wrap.Proof_state.Deferred_values.Plonk.In_circuit.t) =\n let T = Max_proofs_verified.eq in\n let sg_old =\n with_label __LOC__ (fun () ->\n Vector.map2 actual_proofs_verified_mask sg_old ~f:(fun keep sg ->\n [| (keep, sg) |] ) )\n in\n with_label __LOC__ (fun () ->\n let sample () = Opt.challenge sponge in\n let sample_scalar () : Scalar_challenge.t =\n Opt.scalar_challenge sponge\n in\n let index_digest =\n with_label \"absorb verifier index\" (fun () ->\n let index_sponge = Sponge.create sponge_params in\n List.iter\n (index_to_field_elements\n ~g:(fun (z : Inputs.Inner_curve.t) ->\n List.to_array (Inner_curve.to_field_elements z) )\n m )\n ~f:(fun x ->\n let (_ : (unit, _) Pickles_types.Opt.t) =\n simulate_optional_sponge_with_alignment index_sponge x\n ~f:(fun sponge x ->\n Array.iter ~f:(Sponge.absorb sponge) x )\n in\n () ) ;\n Sponge.squeeze_field index_sponge )\n in\n let without = Type.Without_degree_bound in\n let absorb_g gs =\n absorb sponge without (Array.map gs ~f:(fun g -> (Boolean.true_, g)))\n in\n absorb sponge Field (Boolean.true_, index_digest) ;\n Vector.iter ~f:(Array.iter ~f:(absorb sponge PC)) sg_old ;\n let x_hat =\n let domain = (which_branch, step_domains) in\n let public_input =\n Array.concat_map public_input ~f:(function\n | `Field (x, b) ->\n [| `Field (x, Field.size_in_bits)\n ; `Field ((b :> Field.t), 1)\n |]\n | `Packed_bits (x, n) ->\n [| `Field (x, n) |] )\n in\n let constant_part, non_constant_part =\n List.partition_map\n Array.(to_list (mapi public_input ~f:(fun i t -> (i, t))))\n ~f:(fun (i, t) ->\n match[@warning \"-4\"] t with\n | `Field (Constant c, _) ->\n First\n ( if Field.Constant.(equal zero) c then None\n else if Field.Constant.(equal one) c then\n Some (lagrange ~domain srs i)\n else\n Some\n (scaled_lagrange ~domain\n (Inner_curve.Constant.Scalar.project\n (Field.Constant.unpack c) )\n srs i ) )\n | `Field x ->\n Second (i, x) )\n in\n with_label __LOC__ (fun () ->\n let terms =\n List.map non_constant_part ~f:(fun (i, x) ->\n match x with\n | b, 1 ->\n assert_ (Constraint.boolean (b :> Field.t)) ;\n `Cond_add\n (Boolean.Unsafe.of_cvar b, lagrange ~domain srs i)\n | x, n ->\n `Add_with_correction\n ( (x, n)\n , lagrange_with_correction ~input_length:n ~domain srs\n i ) )\n in\n let correction =\n with_label __LOC__ (fun () ->\n List.reduce_exn\n (List.filter_map terms ~f:(function\n | `Cond_add _ ->\n None\n | `Add_with_correction (_, (_, corr)) ->\n Some corr ) )\n ~f:(Ops.add_fast ?check_finite:None) )\n in\n with_label __LOC__ (fun () ->\n let init =\n List.fold\n (List.filter_map ~f:Fn.id constant_part)\n ~init:correction\n ~f:(Ops.add_fast ?check_finite:None)\n in\n List.fold terms ~init ~f:(fun acc term ->\n match term with\n | `Cond_add (b, g) ->\n with_label __LOC__ (fun () ->\n Inner_curve.if_ b ~then_:(Ops.add_fast g acc)\n ~else_:acc )\n | `Add_with_correction ((x, num_bits), (g, _)) ->\n Ops.add_fast acc\n (Ops.scale_fast2'\n (module Other_field.With_top_bit0)\n g x ~num_bits ) ) ) )\n |> Inner_curve.negate\n in\n let x_hat =\n with_label \"x_hat blinding\" (fun () ->\n Ops.add_fast x_hat\n (Inner_curve.constant (Lazy.force Generators.h)) )\n in\n absorb sponge PC (Boolean.true_, x_hat) ;\n let w_comm = messages.w_comm in\n Vector.iter ~f:absorb_g w_comm ;\n let joint_combiner =\n let compute_joint_combiner (l : _ Messages.Lookup.In_circuit.t) =\n let absorb_sorted_1 sponge =\n let (first :: _) = l.sorted in\n let z = Array.map first ~f:(fun z -> (Boolean.true_, z)) in\n absorb sponge Without_degree_bound z\n in\n let absorb_sorted_2_to_4 () =\n let (_ :: rest) = l.sorted in\n Vector.iter rest ~f:(fun z ->\n let z = Array.map z ~f:(fun z -> (Boolean.true_, z)) in\n absorb sponge Without_degree_bound z )\n in\n let absorb_sorted_5 () =\n match l.sorted_5th_column with\n | Nothing ->\n ()\n | Maybe (b, z) ->\n let z = Array.map z ~f:(fun z -> (b, z)) in\n absorb sponge Without_degree_bound z\n | Just z ->\n let z = Array.map z ~f:(fun z -> (Boolean.true_, z)) in\n absorb sponge Without_degree_bound z\n in\n match[@warning \"-4\"]\n (m.lookup_table_comm, m.runtime_tables_selector)\n with\n | _ :: Just _ :: _, _ | _, Just _ ->\n let joint_combiner = sample_scalar () in\n absorb_sorted_1 sponge ;\n absorb_sorted_2_to_4 () ;\n absorb_sorted_5 () ;\n joint_combiner\n | _ :: Nothing :: _, Nothing ->\n absorb_sorted_1 sponge ;\n absorb_sorted_2_to_4 () ;\n absorb_sorted_5 () ;\n { inner = Field.zero }\n | _ :: Maybe (b1, _) :: _, Maybe (b2, _) ->\n let b = Boolean.(b1 ||| b2) in\n let sponge2 = Opt.copy sponge in\n let joint_combiner_if_true =\n let joint_combiner = sample_scalar () in\n absorb_sorted_1 sponge ; joint_combiner\n in\n let joint_combiner_if_false : Scalar_challenge.t =\n absorb_sorted_1 sponge2 ; { inner = Field.zero }\n in\n Opt.recombine b ~original_sponge:sponge2 sponge ;\n absorb_sorted_2_to_4 () ;\n absorb_sorted_5 () ;\n { inner =\n Field.if_ b ~then_:joint_combiner_if_true.inner\n ~else_:joint_combiner_if_false.inner\n }\n | _ :: Maybe (b, _) :: _, _ | _, Maybe (b, _) ->\n let sponge2 = Opt.copy sponge in\n let joint_combiner_if_true =\n let joint_combiner = sample_scalar () in\n absorb_sorted_1 sponge ; joint_combiner\n in\n let joint_combiner_if_false : Scalar_challenge.t =\n absorb_sorted_1 sponge2 ; { inner = Field.zero }\n in\n Opt.recombine b ~original_sponge:sponge2 sponge ;\n absorb_sorted_2_to_4 () ;\n absorb_sorted_5 () ;\n { inner =\n Field.if_ b ~then_:joint_combiner_if_true.inner\n ~else_:joint_combiner_if_false.inner\n }\n in\n match messages.lookup with\n | Nothing ->\n Types.Opt.Nothing\n | Maybe (b, l) ->\n Opt.consume_all_pending sponge ;\n let sponge2 = Opt.copy sponge in\n let joint_combiner = compute_joint_combiner l in\n Opt.consume_all_pending sponge ;\n Opt.recombine b ~original_sponge:sponge2 sponge ;\n (* We explicitly set this, because when we squeeze for [beta], we\n there will be no pending values *but* we don't want to add a\n dedicated permutation.\n *)\n sponge.needs_final_permute_if_empty <- false ;\n Types.Opt.Maybe (b, joint_combiner)\n | Just l ->\n Opt.consume_all_pending sponge ;\n Types.Opt.just (compute_joint_combiner l)\n in\n let lookup_table_comm =\n let compute_lookup_table_comm (l : _ Messages.Lookup.In_circuit.t)\n joint_combiner =\n let (first_column :: second_column :: rest) =\n Vector.map\n ~f:(Types.Opt.map ~f:(fun x -> [| x |]))\n m.lookup_table_comm\n in\n let second_column_with_runtime =\n match (second_column, l.runtime) with\n | Types.Opt.Nothing, comm | comm, Types.Opt.Nothing ->\n comm\n | ( Types.Opt.Maybe (has_second_column, second_column)\n , Types.Opt.Maybe (has_runtime, runtime) ) ->\n let second_with_runtime =\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) second_column runtime\n in\n Array.map2_exn second_column sum\n ~f:(fun second_column sum ->\n Inner_curve.if_ has_runtime ~then_:sum\n ~else_:second_column )\n in\n let res =\n Array.map2_exn second_with_runtime runtime\n ~f:(fun second_with_runtime runtime ->\n Inner_curve.if_ has_second_column\n ~then_:second_with_runtime ~else_:runtime )\n in\n let b = Boolean.(has_second_column ||| has_runtime) in\n Types.Opt.maybe b res\n | ( Types.Opt.Maybe (has_second_column, second_column)\n , Types.Opt.Just runtime ) ->\n let res =\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) second_column runtime\n in\n Array.map2_exn runtime sum ~f:(fun runtime sum ->\n Inner_curve.if_ has_second_column ~then_:sum\n ~else_:runtime )\n in\n Types.Opt.just res\n | ( Types.Opt.Just second_column\n , Types.Opt.Maybe (has_runtime, runtime) ) ->\n let res =\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) second_column runtime\n in\n Array.map2_exn second_column sum\n ~f:(fun second_column sum ->\n Inner_curve.if_ has_runtime ~then_:sum\n ~else_:second_column )\n in\n Types.Opt.just res\n | Types.Opt.Just second_column, Types.Opt.Just runtime ->\n Types.Opt.just\n (Array.map2_exn ~f:Inner_curve.( + ) second_column runtime)\n in\n let rest_rev =\n Vector.rev (first_column :: second_column_with_runtime :: rest)\n in\n let table_ids =\n Types.Opt.map m.lookup_table_ids ~f:(fun x -> [| x |])\n in\n Vector.fold ~init:table_ids rest_rev ~f:(fun acc comm ->\n match acc with\n | Types.Opt.Nothing ->\n comm\n | Types.Opt.Maybe (has_acc, acc) -> (\n match comm with\n | Types.Opt.Nothing ->\n Types.Opt.maybe has_acc acc\n | Types.Opt.Maybe (has_comm, comm) ->\n let scaled_acc =\n Array.map acc ~f:(fun acc ->\n Scalar_challenge.endo acc joint_combiner )\n in\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) scaled_acc comm\n in\n let acc_with_comm =\n Array.map2_exn sum comm ~f:(fun sum comm ->\n Inner_curve.if_ has_acc ~then_:sum ~else_:comm )\n in\n let res =\n Array.map2_exn acc acc_with_comm\n ~f:(fun acc acc_with_comm ->\n Inner_curve.if_ has_comm ~then_:acc_with_comm\n ~else_:acc )\n in\n let b = Boolean.(has_acc ||| has_comm) in\n Types.Opt.maybe b res\n | Types.Opt.Just comm ->\n let scaled_acc =\n Array.map acc ~f:(fun acc ->\n Scalar_challenge.endo acc joint_combiner )\n in\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) scaled_acc comm\n in\n let res =\n Array.map2_exn sum comm ~f:(fun sum comm ->\n Inner_curve.if_ has_acc ~then_:sum ~else_:comm )\n in\n Types.Opt.just res )\n | Types.Opt.Just acc -> (\n match comm with\n | Types.Opt.Nothing ->\n Types.Opt.just acc\n | Types.Opt.Maybe (has_comm, comm) ->\n let scaled_acc =\n Array.map acc ~f:(fun acc ->\n Scalar_challenge.endo acc joint_combiner )\n in\n let sum =\n Array.map2_exn ~f:Inner_curve.( + ) scaled_acc comm\n in\n let res =\n Array.map2_exn sum acc ~f:(fun sum acc ->\n Inner_curve.if_ has_comm ~then_:sum ~else_:acc )\n in\n Types.Opt.just res\n | Types.Opt.Just comm ->\n let scaled_acc =\n Array.map acc ~f:(fun acc ->\n Scalar_challenge.endo acc joint_combiner )\n in\n Types.Opt.Just\n (Array.map2_exn ~f:Inner_curve.( + ) scaled_acc comm)\n ) )\n in\n match (messages.lookup, joint_combiner) with\n | Types.Opt.Nothing, Types.Opt.Nothing ->\n Types.Opt.Nothing\n | ( Types.Opt.Maybe (b_l, l)\n , Types.Opt.Maybe (_b_joint_combiner, joint_combiner) ) -> (\n (* NB: b_l = _b_joint_combiner by construction *)\n match compute_lookup_table_comm l joint_combiner with\n | Types.Opt.Nothing ->\n Types.Opt.Nothing\n | Types.Opt.Maybe (b_lookup_table_comm, lookup_table_comm) ->\n Types.Opt.Maybe\n (Boolean.(b_l &&& b_lookup_table_comm), lookup_table_comm)\n | Types.Opt.Just lookup_table_comm ->\n Types.Opt.Maybe (b_l, lookup_table_comm) )\n | Types.Opt.Just l, Types.Opt.Just joint_combiner ->\n compute_lookup_table_comm l joint_combiner\n | ( (Types.Opt.Nothing | Maybe _ | Just _)\n , (Types.Opt.Nothing | Maybe _ | Just _) ) ->\n assert false\n in\n let lookup_sorted =\n let lookup_sorted_minus_1 =\n Nat.to_int Plonk_types.Lookup_sorted_minus_1.n\n in\n Vector.init Plonk_types.Lookup_sorted.n ~f:(fun i ->\n match messages.lookup with\n | Types.Opt.Nothing ->\n Types.Opt.Nothing\n | Types.Opt.Maybe (b, l) ->\n if i = lookup_sorted_minus_1 then l.sorted_5th_column\n else\n Types.Opt.Maybe (b, Option.value_exn (Vector.nth l.sorted i))\n | Types.Opt.Just l ->\n if i = lookup_sorted_minus_1 then l.sorted_5th_column\n else Types.Opt.Just (Option.value_exn (Vector.nth l.sorted i)) )\n in\n let beta = sample () in\n let gamma = sample () in\n let () =\n match messages.lookup with\n | Nothing ->\n ()\n | Maybe (b, l) ->\n let aggreg = Array.map l.aggreg ~f:(fun z -> (b, z)) in\n absorb sponge Without_degree_bound aggreg\n | Just l ->\n let aggreg =\n Array.map l.aggreg ~f:(fun z -> (Boolean.true_, z))\n in\n absorb sponge Without_degree_bound aggreg\n in\n let z_comm = messages.z_comm in\n absorb_g z_comm ;\n let alpha = sample_scalar () in\n let t_comm :\n (Inputs.Impl.Field.t * Inputs.Impl.Field.t)\n Pickles_types__Plonk_types.Poly_comm.Without_degree_bound.t =\n messages.t_comm\n in\n absorb_g t_comm ;\n let zeta = sample_scalar () in\n (* At this point, we should use the previous \"bulletproof_challenges\" to\n compute to compute f(beta_1) outside the snark\n where f is the polynomial corresponding to sg_old\n *)\n let sponge =\n match sponge with\n | { state\n ; sponge_state = Squeezed n\n ; params\n ; needs_final_permute_if_empty = _\n } ->\n S.make ~state ~sponge_state:(Squeezed n) ~params\n | { sponge_state = Absorbing _; _ } ->\n assert false\n in\n let sponge_before_evaluations = Sponge.copy sponge in\n let sponge_digest_before_evaluations = Sponge.squeeze_field sponge in\n\n (* xi, r are sampled here using the other sponge. *)\n (* No need to expose the polynomial evaluations as deferred values as they're\n not needed here for the incremental verification. All we need is a_hat and\n \"combined_inner_product\".\n\n Then, in the other proof, we can witness the evaluations and check their correctness\n against \"combined_inner_product\" *)\n let sigma_comm_init, [ _ ] =\n Vector.split m.sigma_comm (snd (Permuts_minus_1.add Nat.N1.n))\n in\n let scale_fast =\n scale_fast ~num_bits:Other_field.Packed.Constant.size_in_bits\n in\n let ft_comm =\n with_label __LOC__ (fun () ->\n Common.ft_comm\n ~add:(Ops.add_fast ?check_finite:None)\n ~scale:scale_fast ~negate:Inner_curve.negate\n ~endoscale:(Scalar_challenge.endo ?num_bits:None)\n ~verification_key:\n (Plonk_verification_key_evals.Step.forget_optional_commitments\n m )\n ~plonk ~alpha ~t_comm )\n in\n let bulletproof_challenges =\n (* This sponge needs to be initialized with (some derivative of)\n 1. The polynomial commitments\n 2. The combined inner product\n 3. The challenge points.\n\n It should be sufficient to fork the sponge after squeezing beta_3 and then to absorb\n the combined inner product.\n *)\n let len_1, len_1_add = Plonk_types.(Columns.add Permuts_minus_1.n) in\n let len_2, len_2_add = Plonk_types.(Columns.add len_1) in\n let _len_3, len_3_add = Nat.N9.add len_2 in\n let _len_4, len_4_add = Nat.N6.add Plonk_types.Lookup_sorted.n in\n let len_5, len_5_add =\n (* NB: Using explicit 11 because we can't get add on len_4 *)\n Nat.N11.add Nat.N7.n\n in\n let len_6, len_6_add = Nat.N45.add len_5 in\n let num_commitments_without_degree_bound = len_6 in\n let without_degree_bound =\n let append_chain len second first =\n Vector.append first second len\n in\n let undo_chunking =\n Types.Opt.map ~f:(fun x ->\n assert (Array.length x = 1) ;\n x.(0) )\n in\n (* sg_old\n x_hat\n ft_comm\n z_comm\n generic selector\n poseidon selector\n w_comms\n all but last sigma_comm\n *)\n Vector.map sg_old\n ~f:\n (Array.map ~f:(fun (keep, p) ->\n Pickles_types.Opt.Maybe (keep, p) ) )\n |> append_chain\n (snd (Max_proofs_verified.add len_6))\n ( [ [| x_hat |]\n ; [| ft_comm |]\n ; z_comm\n ; [| m.generic_comm |]\n ; [| m.psm_comm |]\n ; [| m.complete_add_comm |]\n ; [| m.mul_comm |]\n ; [| m.emul_comm |]\n ; [| m.endomul_scalar_comm |]\n ]\n |> append_chain len_3_add\n (Vector.append w_comm\n (Vector.append\n (Vector.map m.coefficients_comm ~f:(fun g ->\n [| g |] ) )\n (Vector.map sigma_comm_init ~f:(fun g -> [| g |]))\n len_1_add )\n len_2_add )\n |> Vector.map ~f:(Array.map ~f:Pickles_types.Opt.just)\n |> append_chain len_6_add\n ( [ m.range_check0_comm\n ; m.range_check1_comm\n ; m.foreign_field_add_comm\n ; m.foreign_field_mul_comm\n ; m.xor_comm\n ; m.rot_comm\n ]\n |> append_chain len_4_add\n (Vector.map ~f:undo_chunking lookup_sorted)\n |> append_chain len_5_add\n [ undo_chunking\n @@ Pickles_types.Opt.map messages.lookup\n ~f:(fun l -> l.aggreg)\n ; undo_chunking lookup_table_comm\n ; m.runtime_tables_selector\n ; m.lookup_selector_xor\n ; m.lookup_selector_lookup\n ; m.lookup_selector_range_check\n ; m.lookup_selector_ffmul\n ]\n |> Vector.map ~f:(fun x -> [| x |]) ) )\n in\n check_bulletproof\n ~pcs_batch:\n (Common.dlog_pcs_batch\n (Max_proofs_verified.add num_commitments_without_degree_bound) )\n ~sponge:sponge_before_evaluations ~xi ~advice ~openings_proof\n ~polynomials:\n ( Vector.map without_degree_bound\n ~f:\n (Array.map\n ~f:(Pickles_types.Opt.map ~f:(fun x -> `Finite x)) )\n , [] )\n in\n assert_eq_plonk\n { alpha = plonk.alpha\n ; beta = plonk.beta\n ; gamma = plonk.gamma\n ; zeta = plonk.zeta\n ; joint_combiner = plonk.joint_combiner\n ; feature_flags = plonk.feature_flags\n }\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; joint_combiner\n ; feature_flags = plonk.feature_flags\n } ;\n (sponge_digest_before_evaluations, bulletproof_challenges) )\n\n let _mask_evals (type n)\n ~(lengths :\n (int, n) Pickles_types.Vector.t Pickles_types.Plonk_types.Evals.t )\n (choice : n One_hot_vector.t)\n (e : Field.t array Pickles_types.Plonk_types.Evals.t) :\n (Boolean.var * Field.t) array Pickles_types.Plonk_types.Evals.t =\n Pickles_types.Plonk_types.Evals.map2 lengths e ~f:(fun lengths e ->\n Array.zip_exn (mask lengths choice) e )\n\n let compute_challenges ~scalar chals =\n Vector.map chals ~f:(fun prechallenge ->\n scalar @@ Bulletproof_challenge.pack prechallenge )\n\n let challenge_polynomial = G.challenge_polynomial (module Field)\n\n let pow2pow (pt : Field.t) (n : int) : Field.t =\n with_label __LOC__ (fun () ->\n let rec go acc i =\n if i = 0 then acc else go (Field.square acc) (i - 1)\n in\n go pt n )\n\n let actual_evaluation (e : Field.t array) ~(pt_to_n : Field.t) : Field.t =\n with_label __LOC__ (fun () ->\n match List.rev (Array.to_list e) with\n | e :: es ->\n List.fold ~init:e es ~f:(fun acc y ->\n let acc' =\n exists Field.typ ~compute:(fun () ->\n As_prover.read_var Field.(y + (pt_to_n * acc)) )\n in\n (* acc' = y + pt_n * acc *)\n let pt_n_acc = Field.(pt_to_n * acc) in\n let open\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint in\n (* 0 = - acc' + y + pt_n_acc *)\n let open Field.Constant in\n assert_\n { annotation = None\n ; basic =\n T\n (Basic\n { l = (one, y)\n ; r = (one, pt_n_acc)\n ; o = (negate one, acc')\n ; m = zero\n ; c = zero\n } )\n } ;\n acc' )\n | [] ->\n failwith \"empty list\" )\n\n let _shift1 =\n Pickles_types.Shifted_value.Type1.Shift.(\n map ~f:Field.constant (create (module Field.Constant)))\n\n let shift2 =\n Shifted_value.Type2.Shift.(\n map ~f:Field.constant (create (module Field.Constant)))\n\n let%test_unit \"endo scalar\" =\n SC.test (module Impl) ~endo:Endo.Step_inner_curve.scalar\n\n let map_plonk_to_field plonk =\n Types.Step.Proof_state.Deferred_values.Plonk.In_circuit.map_challenges\n ~f:(Util.seal (module Impl))\n ~scalar:scalar_to_field plonk\n |> Types.Step.Proof_state.Deferred_values.Plonk.In_circuit.map_fields\n ~f:(Shifted_value.Type2.map ~f:(Util.seal (module Impl)))\n\n module Plonk_checks = struct\n include Plonk_checks\n include Plonk_checks.Make (Shifted_value.Type2) (Plonk_checks.Scalars.Tock)\n end\n\n (* This finalizes the \"deferred values\" coming from a previous proof over the same field.\n It\n 1. Checks that [xi] and [r] where sampled correctly. I.e., by absorbing all the\n evaluation openings and then squeezing.\n 2. Checks that the \"combined inner product\" value used in the elliptic curve part of\n the opening proof was computed correctly, in terms of the evaluation openings and the\n evaluation points.\n 3. Check that the \"b\" value was computed correctly.\n 4. Perform the arithmetic checks from marlin. *)\n let finalize_other_proof (type b)\n (module Proofs_verified : Nat.Add.Intf with type n = b) ~domain ~sponge\n ~(old_bulletproof_challenges : (_, b) Vector.t)\n ({ xi; combined_inner_product; bulletproof_challenges; b; plonk } :\n ( _\n , _\n , _ Shifted_value.Type2.t\n , _ )\n Types.Step.Proof_state.Deferred_values.In_circuit.t )\n { Plonk_types.All_evals.In_circuit.ft_eval1; evals } =\n let module Plonk = Types.Step.Proof_state.Deferred_values.Plonk in\n let T = Proofs_verified.eq in\n (* You use the NEW bulletproof challenges to check b. Not the old ones. *)\n let open Field in\n let plonk = map_plonk_to_field plonk in\n let zetaw = Field.mul domain#generator plonk.zeta in\n let sg_evals1, sg_evals2 =\n let sg_olds =\n Vector.map old_bulletproof_challenges ~f:(fun chals ->\n unstage (challenge_polynomial (Vector.to_array chals)) )\n in\n let sg_evals pt = Vector.map sg_olds ~f:(fun f -> f pt) in\n (sg_evals plonk.zeta, sg_evals zetaw)\n in\n let sponge_state =\n (* Absorb bulletproof challenges *)\n let challenge_digest =\n let sponge = Sponge.create sponge_params in\n Vector.iter old_bulletproof_challenges\n ~f:(Vector.iter ~f:(Sponge.absorb sponge)) ;\n Sponge.squeeze sponge\n in\n Sponge.absorb sponge challenge_digest ;\n Sponge.absorb sponge ft_eval1 ;\n Sponge.absorb sponge (fst evals.public_input) ;\n Sponge.absorb sponge (snd evals.public_input) ;\n let xs = Evals.In_circuit.to_absorption_sequence evals.evals in\n (* This is a hacky, but much more efficient, version of the opt sponge.\n This uses the assumption that the sponge 'absorption state' will align\n after each optional absorption, letting us skip the expensive tracking\n that this would otherwise require.\n To future-proof this, we assert that the states are indeed compatible.\n *)\n List.iter xs ~f:(fun opt ->\n let absorb = Array.iter ~f:(fun x -> Sponge.absorb sponge x) in\n match opt with\n | Nothing ->\n ()\n | Just (x1, x2) ->\n absorb x1 ; absorb x2\n | Maybe (b, (x1, x2)) ->\n (* Cache the sponge state before *)\n let sponge_state_before = sponge.sponge_state in\n let state_before = Array.copy sponge.state in\n (* Absorb the points *)\n absorb x1 ;\n absorb x2 ;\n (* Check that the sponge ends in a compatible state. *)\n ( match (sponge_state_before, sponge.sponge_state) with\n | Absorbed x, Absorbed y ->\n [%test_eq: int] x y\n | Squeezed x, Squeezed y ->\n [%test_eq: int] x y\n | Absorbed _, Squeezed _ ->\n [%test_eq: string] \"absorbed\" \"squeezed\"\n | Squeezed _, Absorbed _ ->\n [%test_eq: string] \"squeezed\" \"absorbed\" ) ;\n let state =\n Array.map2_exn sponge.state state_before ~f:(fun then_ else_ ->\n Field.if_ b ~then_ ~else_ )\n in\n sponge.state <- state ) ;\n Array.copy sponge.state\n in\n sponge.state <- sponge_state ;\n let xi_actual = squeeze_scalar sponge in\n let r_actual = squeeze_challenge sponge in\n let xi_correct =\n with_label __LOC__ (fun () ->\n let { Import.Scalar_challenge.inner = xi_actual } = xi_actual in\n let { Import.Scalar_challenge.inner = xi } = xi in\n (* Sample new sg challenge point here *)\n Field.equal xi_actual xi )\n in\n let xi = scalar_to_field xi in\n (* TODO: r actually does not need to be a scalar challenge. *)\n let r = scalar_to_field (Import.Scalar_challenge.create r_actual) in\n let plonk_minimal =\n plonk |> Plonk.to_minimal\n |> Plonk.Minimal.to_wrap\n ~feature_flags:Features.(map ~f:Boolean.var_of_value none_bool)\n in\n let combined_evals =\n let n = Common.Max_degree.wrap_log2 in\n (* TODO: zeta_n is recomputed in [env] below *)\n let zeta_n = pow2pow plonk.zeta n in\n let zetaw_n = pow2pow zetaw n in\n Evals.In_circuit.map evals.evals ~f:(fun (x0, x1) ->\n ( actual_evaluation ~pt_to_n:zeta_n x0\n , actual_evaluation ~pt_to_n:zetaw_n x1 ) )\n in\n let env =\n let module Env_bool = struct\n include Boolean\n\n type t = Boolean.var\n end in\n let module Env_field = struct\n include Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ =\n match Impl.Field.to_constant (b :> t) with\n | Some x ->\n (* We have a constant, only compute the branch we care about. *)\n if Impl.Field.Constant.(equal one) x then then_ () else else_ ()\n | None ->\n if_ b ~then_:(then_ ()) ~else_:(else_ ())\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~srs_length_log2:Common.Max_degree.wrap_log2\n ~endo:(Impl.Field.constant Endo.Wrap_inner_curve.base)\n ~mds:sponge_params.mds\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fq.of_bigint |> Field.constant )\n ~domain plonk_minimal combined_evals\n in\n let combined_inner_product_correct =\n let evals1, evals2 =\n All_evals.With_public_input.In_circuit.factor evals\n in\n with_label __LOC__ (fun () ->\n let ft_eval0 : Field.t =\n with_label __LOC__ (fun () ->\n Plonk_checks.ft_eval0\n (module Field)\n ~env ~domain plonk_minimal combined_evals evals1.public_input )\n in\n (* sum_i r^i sum_j xi^j f_j(beta_i) *)\n let actual_combined_inner_product =\n let combine ~ft ~sg_evals x_hat\n (e : (Field.t array, _) Evals.In_circuit.t) =\n let a =\n Evals.In_circuit.to_list e\n |> List.map ~f:(function\n | Nothing ->\n [||]\n | Just a ->\n Array.map a ~f:Pickles_types.Opt.just\n | Maybe (b, a) ->\n Array.map a ~f:(Pickles_types.Opt.maybe b) )\n in\n let sg_evals =\n Vector.map sg_evals ~f:(fun x -> [| Pickles_types.Opt.just x |])\n |> Vector.to_list\n (* TODO: This was the code before the wrap hack was put in\n match actual_proofs_verified with\n | None ->\n Vector.map sg_olds ~f:(fun f -> [| f pt |])\n | Some proofs_verified ->\n let mask =\n ones_vector\n (module Impl)\n ~first_zero:proofs_verified (Vector.length sg_olds)\n in\n with_label __LOC__ (fun () ->\n Vector.map2 mask sg_olds ~f:(fun b f ->\n [| Field.((b :> t) * f pt) |] ) ) *)\n in\n let v =\n List.append sg_evals\n ( [| Pickles_types.Opt.just x_hat |]\n :: [| Pickles_types.Opt.just ft |]\n :: a )\n in\n Common.combined_evaluation (module Impl) ~xi v\n in\n combine ~ft:ft_eval0 ~sg_evals:sg_evals1 evals1.public_input\n evals1.evals\n + r\n * combine ~ft:ft_eval1 ~sg_evals:sg_evals2 evals2.public_input\n evals2.evals\n in\n with_label __LOC__ (fun () ->\n equal\n (Shifted_value.Type2.to_field\n (module Field)\n ~shift:shift2 combined_inner_product )\n actual_combined_inner_product ) )\n in\n let bulletproof_challenges =\n with_label __LOC__ (fun () ->\n compute_challenges ~scalar:scalar_to_field bulletproof_challenges )\n in\n let b_correct =\n with_label __LOC__ (fun () ->\n let challenge_poly =\n unstage\n (challenge_polynomial (Vector.to_array bulletproof_challenges))\n in\n let b_actual =\n challenge_poly plonk.zeta + (r * challenge_poly zetaw)\n in\n equal\n (Shifted_value.Type2.to_field (module Field) ~shift:shift2 b)\n b_actual )\n in\n let plonk_checks_passed =\n with_label __LOC__ (fun () ->\n (* This proof is a wrap proof; no need to consider features. *)\n Plonk_checks.checked\n (module Impl)\n ~env ~shift:shift2\n (Composition_types.Step.Proof_state.Deferred_values.Plonk.In_circuit\n .to_wrap ~opt_none:Pickles_types.Opt.nothing ~false_:Boolean.false_\n plonk )\n combined_evals )\n in\n print_bool \"xi_correct\" xi_correct ;\n print_bool \"combined_inner_product_correct\" combined_inner_product_correct ;\n print_bool \"plonk_checks_passed\" plonk_checks_passed ;\n print_bool \"b_correct\" b_correct ;\n ( Boolean.all\n [ xi_correct\n ; b_correct\n ; combined_inner_product_correct\n ; plonk_checks_passed\n ]\n , bulletproof_challenges )\n\n let _map_challenges\n { Import.Types.Step.Proof_state.Deferred_values.plonk\n ; combined_inner_product\n ; xi\n ; bulletproof_challenges\n ; b\n } ~f ~scalar =\n { Types.Step.Proof_state.Deferred_values.plonk =\n Types.Step.Proof_state.Deferred_values.Plonk.In_circuit.map_challenges\n plonk ~f ~scalar\n ; combined_inner_product\n ; bulletproof_challenges =\n Vector.map bulletproof_challenges\n ~f:(fun (r : _ Bulletproof_challenge.t) ->\n Bulletproof_challenge.map ~f:scalar r )\n ; xi = scalar xi\n ; b\n }\nend\n\ninclude Make (Wrap_main_inputs)\n\nlet challenge_polynomial = G.challenge_polynomial\n","open Core_kernel\n\n[@@@warning \"-4\"]\n\ntype ('a, 'bool) t = Just of 'a | Nothing | Maybe of 'bool * 'a\n[@@deriving sexp, compare, yojson, hash, equal]\n\nlet just a = Just a\n\nlet nothing = Nothing\n\nlet maybe b x = Maybe (b, x)\n\nlet to_option : ('a, bool) t -> 'a option = function\n | Just x ->\n Some x\n | Maybe (true, x) ->\n Some x\n | Maybe (false, _x) ->\n None\n | Nothing ->\n None\n\nlet to_option_unsafe : ('a, 'bool) t -> 'a option = function\n | Just x ->\n Some x\n | Maybe (_, x) ->\n Some x\n | Nothing ->\n None\n\nlet value_exn = function\n | Just x ->\n x\n | Maybe (_, x) ->\n x\n | Nothing ->\n invalid_arg \"Opt.value_exn\"\n\nlet of_option (t : 'a option) : ('a, 'bool) t =\n match t with None -> Nothing | Some x -> Just x\n\nlet lift ?on_maybe ~nothing f = function\n | Nothing ->\n nothing\n | Just v ->\n f v\n | Maybe (b, v) -> (\n match on_maybe with None -> f v | Some g -> g b v )\n\nmodule Flag = struct\n type t = Yes | No | Maybe [@@deriving sexp, compare, yojson, hash, equal]\n\n let ( ||| ) x y =\n match (x, y) with\n | Yes, _ | _, Yes ->\n Yes\n | Maybe, _ | _, Maybe ->\n Maybe\n | No, No ->\n No\nend\n\nlet map t ~f =\n match t with\n | Nothing ->\n Nothing\n | Just x ->\n Just (f x)\n | Maybe (b, x) ->\n Maybe (b, f x)\n\nlet iter t ~f =\n match t with Nothing -> () | Just x -> f x | Maybe (_, x) -> f x\n\nopen Snarky_backendless\n\nlet some_typ (type a a_var f bool_var) (t : (a_var, a, f) Typ.t) :\n ((a_var, bool_var) t, a option, f) Typ.t =\n Typ.transport t ~there:(fun x -> Option.value_exn x) ~back:Option.return\n |> Typ.transport_var\n ~there:(function\n | Just x ->\n x\n | Maybe _ | Nothing ->\n failwith \"Opt.some_typ: expected Just\" )\n ~back:(fun x -> Just x)\n\nlet none_typ (type a a_var f bool) () : ((a_var, bool) t, a option, f) Typ.t =\n Typ.transport (Typ.unit ())\n ~there:(fun _ -> ())\n ~back:(fun () : _ Option.t -> None)\n |> Typ.transport_var\n ~there:(function\n | Nothing ->\n ()\n | Maybe _ | Just _ ->\n failwith \"Opt.none_typ: expected Nothing\" )\n ~back:(fun () : _ t -> Nothing)\n\nlet maybe_typ (type a a_var bool_var f)\n (bool_typ : (bool_var, bool, f) Snarky_backendless.Typ.t) ~(dummy : a)\n (a_typ : (a_var, a, f) Typ.t) : ((a_var, bool_var) t, a option, f) Typ.t =\n Typ.transport\n (Typ.tuple2 bool_typ a_typ)\n ~there:(fun (t : a option) ->\n match t with None -> (false, dummy) | Some x -> (true, x) )\n ~back:(fun (b, x) -> if b then Some x else None)\n |> Typ.transport_var\n ~there:(fun (t : (a_var, _) t) ->\n match t with\n | Maybe (b, x) ->\n (b, x)\n | Nothing | Just _ ->\n failwith \"Opt.maybe_typ: expected Maybe\" )\n ~back:(fun (b, x) -> Maybe (b, x))\n\nlet constant_layout_typ (type a a_var f) (bool_typ : _ Typ.t) ~true_ ~false_\n (flag : Flag.t) (a_typ : (a_var, a, f) Typ.t) ~(dummy : a)\n ~(dummy_var : a_var) =\n let (Typ bool_typ) = bool_typ in\n let bool_typ : _ Typ.t =\n let check =\n (* No need to boolean constrain in the No or Yes case *)\n match flag with\n | No | Yes ->\n fun _ -> Checked_runner.Simple.return ()\n | Maybe ->\n bool_typ.check\n in\n Typ { bool_typ with check }\n in\n Typ.transport\n (Typ.tuple2 bool_typ a_typ)\n ~there:(fun (t : a option) ->\n match t with None -> (false, dummy) | Some x -> (true, x) )\n ~back:(fun (b, x) -> if b then Some x else None)\n |> Typ.transport_var\n ~there:(fun (t : (a_var, _) t) ->\n match t with\n | Maybe (b, x) ->\n (b, x)\n | Nothing ->\n (false_, dummy_var)\n | Just x ->\n (true_, x) )\n ~back:(fun (b, x) ->\n match flag with No -> Nothing | Yes -> Just x | Maybe -> Maybe (b, x)\n )\n\nlet typ (type a a_var f) bool_typ (flag : Flag.t) (a_typ : (a_var, a, f) Typ.t)\n ~(dummy : a) =\n match flag with\n | Yes ->\n some_typ a_typ\n | No ->\n none_typ ()\n | Maybe ->\n maybe_typ bool_typ ~dummy a_typ\n\nmodule Early_stop_sequence = struct\n (* A sequence that should be considered to have stopped at\n the first No flag *)\n (* TODO: The documentation above makes it sound like the type below is too\n generic: we're not guaranteed to have flags in there *)\n type nonrec ('a, 'bool) t = ('a, 'bool) t list\n\n let fold (type a bool acc res)\n (if_res : bool -> then_:res -> else_:res -> res) (t : (a, bool) t)\n ~(init : acc) ~(f : acc -> a -> acc) ~(finish : acc -> res) =\n let rec go acc = function\n | [] ->\n finish acc\n | Nothing :: xs ->\n go acc xs\n | Just x :: xs ->\n go (f acc x) xs\n | Maybe (b, x) :: xs ->\n (* Computing this first makes mutation in f OK. *)\n let stop_res = finish acc in\n let continue_res = go (f acc x) xs in\n if_res b ~then_:continue_res ~else_:stop_res\n in\n go init t\nend\n","(* q > p *)\nopen Core_kernel\nmodule SC = Scalar_challenge\nopen Import\nopen Common\nopen Util\nopen Types.Step\nopen Pickles_types\n\nmodule Make\n (Inputs : Intf.Step_main_inputs.S\n with type Impl.field = Backend.Tick.Field.t\n and type Impl.Bigint.t = Backend.Tick.Bigint.t\n and type Inner_curve.Constant.Scalar.t = Backend.Tock.Field.t) =\nstruct\n open Inputs\n open Impl\n module Challenge = Challenge.Make (Impl)\n module Digest = Digest.Make (Impl)\n\n (* Other_field.size > Field.size *)\n module Other_field = struct\n let size_in_bits = Field.size_in_bits\n\n type t = Impls.Step.Other_field.t\n\n let typ = Impls.Step.Other_field.typ\n end\n\n let print_fp lab x =\n if debug then\n as_prover\n As_prover.(\n fun () ->\n printf !\"%s: %{sexp:Backend.Tick.Field.t}\\n%!\" lab (read_var x))\n\n let print_bool lab x =\n if debug then\n as_prover (fun () ->\n printf \"%s: %b\\n%!\" lab (As_prover.read Boolean.typ x) )\n\n let equal_g g1 g2 =\n List.map2_exn ~f:Field.equal\n (Inner_curve.to_field_elements g1)\n (Inner_curve.to_field_elements g2)\n |> Boolean.all\n\n let absorb sponge ty t =\n absorb\n ~absorb_field:(fun x -> Sponge.absorb sponge (`Field x))\n ~g1_to_field_elements:Inner_curve.to_field_elements\n ~absorb_scalar:(fun (x, (b : Boolean.var)) ->\n Sponge.absorb sponge (`Field x) ;\n Sponge.absorb sponge (`Bits [ b ]) )\n ~mask_g1_opt:(fun ((b : Boolean.var), (x, y)) ->\n Field.((b :> t) * x, (b :> t) * y) )\n ty t\n\n let _scalar_to_field s =\n SC.to_field_checked (module Impl) s ~endo:Endo.Wrap_inner_curve.scalar\n\n let assert_n_bits ~n a =\n (* Scalar_challenge.to_field_checked has the side effect of\n checking that the input fits in n bits. *)\n ignore\n ( SC.to_field_checked\n (module Impl)\n (Import.Scalar_challenge.create a)\n ~endo:Endo.Wrap_inner_curve.scalar ~num_bits:n\n : Field.t )\n\n let lowest_128_bits ~constrain_low_bits x =\n let assert_128_bits = assert_n_bits ~n:128 in\n Util.lowest_128_bits ~constrain_low_bits ~assert_128_bits (module Impl) x\n\n module Scalar_challenge =\n SC.Make (Impl) (Inner_curve) (Challenge) (Endo.Step_inner_curve)\n module Ops = Step_main_inputs.Ops\n\n module Inner_curve = struct\n include Inner_curve\n\n let ( + ) = Ops.add_fast\n end\n\n module Public_input_scalar = struct\n type t = Field.t\n\n let typ = Field.typ\n\n module Constant = struct\n include Field.Constant\n\n let to_bigint = Impl.Bigint.of_field\n end\n end\n\n let multiscale_known\n (ts :\n ( [ `Field of Field.t | `Packed_bits of Field.t * int ]\n * Inner_curve.Constant.t )\n array ) =\n let module F = Public_input_scalar in\n let rec pow2pow x i =\n if i = 0 then x else pow2pow Inner_curve.Constant.(x + x) (i - 1)\n in\n with_label __LOC__ (fun () ->\n let constant_part, non_constant_part =\n List.partition_map (Array.to_list ts) ~f:(fun (t, g) ->\n match[@warning \"-4\"] t with\n | `Field (Constant c) | `Packed_bits (Constant c, _) ->\n First\n ( if Field.Constant.(equal zero) c then None\n else if Field.Constant.(equal one) c then Some g\n else\n Some\n (Inner_curve.Constant.scale g\n (Inner_curve.Constant.Scalar.project\n (Field.Constant.unpack c) ) ) )\n | `Field x ->\n Second (`Field x, g)\n | `Packed_bits (x, n) ->\n Second (`Packed_bits (x, n), g) )\n in\n let add_opt xo y =\n Option.value_map xo ~default:y ~f:(fun x ->\n Inner_curve.Constant.( + ) x y )\n in\n let constant_part =\n List.filter_map constant_part ~f:Fn.id\n |> List.fold ~init:None ~f:(fun acc x -> Some (add_opt acc x))\n in\n let correction, acc =\n List.map non_constant_part ~f:(fun (s, x) ->\n let rr, n =\n match s with\n | `Packed_bits (s, n) ->\n ( Ops.scale_fast2'\n (module F)\n (Inner_curve.constant x) s ~num_bits:n\n , n )\n | `Field s ->\n ( Ops.scale_fast2'\n (module F)\n (Inner_curve.constant x) s ~num_bits:Field.size_in_bits\n , Field.size_in_bits )\n in\n let n =\n Ops.bits_per_chunk * Ops.chunks_needed ~num_bits:(n - 1)\n in\n let cc = pow2pow x n in\n (cc, rr) )\n |> List.reduce_exn ~f:(fun (a1, b1) (a2, b2) ->\n (Inner_curve.Constant.( + ) a1 a2, Inner_curve.( + ) b1 b2) )\n in\n Inner_curve.(\n acc + constant (Constant.negate correction |> add_opt constant_part)) )\n\n let squeeze_challenge sponge : Field.t =\n lowest_128_bits (Sponge.squeeze sponge) ~constrain_low_bits:true\n\n let squeeze_scalar sponge : Field.t Import.Scalar_challenge.t =\n (* No need to boolean constrain scalar challenges. *)\n Import.Scalar_challenge.create\n (lowest_128_bits ~constrain_low_bits:false (Sponge.squeeze sponge))\n\n let bullet_reduce sponge gammas =\n with_label __LOC__ (fun () ->\n let absorb t = absorb sponge t in\n let prechallenges =\n Array.map gammas ~f:(fun gammas_i ->\n absorb (PC :: PC) gammas_i ;\n squeeze_scalar sponge )\n in\n let term_and_challenge (l, r) pre =\n let left_term = Scalar_challenge.endo_inv l pre in\n let right_term = Scalar_challenge.endo r pre in\n ( Inner_curve.(left_term + right_term)\n , Bulletproof_challenge.unpack pre )\n in\n let terms, challenges =\n Array.map2_exn gammas prechallenges ~f:term_and_challenge\n |> Array.unzip\n in\n (Array.reduce_exn terms ~f:(fun x y -> Inner_curve.(x + y)), challenges) )\n\n let group_map =\n let f =\n lazy\n (let module M =\n Group_map.Bw19.Make (Field.Constant) (Field)\n (struct\n let params =\n Group_map.Bw19.Params.create\n (module Field.Constant)\n { b = Inner_curve.Params.b }\n end)\n in\n let open M in\n Snarky_group_map.Checked.wrap\n (module Impl)\n ~potential_xs\n ~y_squared:(fun ~x ->\n Field.(\n (x * x * x)\n + (constant Inner_curve.Params.a * x)\n + constant Inner_curve.Params.b) )\n |> unstage )\n in\n fun x -> Lazy.force f x\n\n let _scale_fast p s =\n with_label __LOC__ (fun () ->\n Ops.scale_fast p s ~num_bits:Field.size_in_bits )\n\n let scale_fast2 p (s : Other_field.t Shifted_value.Type2.t) =\n with_label __LOC__ (fun () ->\n Ops.scale_fast2 p s ~num_bits:Field.size_in_bits )\n\n let check_bulletproof ~pcs_batch ~(sponge : Sponge.t) ~xi\n ~(* Corresponds to y in figure 7 of WTS *)\n (* sum_i r^i sum_j xi^j f_j(beta_i) *)\n (advice : _ Bulletproof.Advice.t)\n ~polynomials:(without_degree_bound, with_degree_bound)\n ~opening:\n ({ lr; delta; z_1; z_2; challenge_polynomial_commitment } :\n (Inner_curve.t, Other_field.t Shifted_value.Type2.t) Bulletproof.t ) =\n with_label \"check_bulletproof\" (fun () ->\n absorb sponge Scalar\n ( match advice.combined_inner_product with\n | Shifted_value.Type2.Shifted_value x ->\n x ) ;\n (* a_hat should be equal to\n sum_i < t, r^i pows(beta_i) >\n = sum_i r^i < t, pows(beta_i) > *)\n let u =\n let t = Sponge.squeeze_field sponge in\n group_map t\n in\n let open Inner_curve in\n let combined_polynomial (* Corresponds to xi in figure 7 of WTS *) =\n with_label \"combined_polynomial\" (fun () ->\n Pcs_batch.combine_split_commitments pcs_batch\n ~scale_and_add:(fun ~(acc :\n [ `Maybe_finite of\n Boolean.var * Inner_curve.t\n | `Finite of Inner_curve.t ] ) ~xi p ->\n match acc with\n | `Maybe_finite (acc_is_finite, (acc : Inner_curve.t)) -> (\n match p with\n | `Maybe_finite (p_is_finite, p) ->\n let is_finite =\n Boolean.(p_is_finite ||| acc_is_finite)\n in\n let xi_acc = Scalar_challenge.endo acc xi in\n `Maybe_finite\n ( is_finite\n , if_ acc_is_finite ~then_:(p + xi_acc) ~else_:p )\n | `Finite p ->\n let xi_acc = Scalar_challenge.endo acc xi in\n `Finite\n (if_ acc_is_finite ~then_:(p + xi_acc) ~else_:p) )\n | `Finite acc ->\n let xi_acc = Scalar_challenge.endo acc xi in\n `Finite\n ( match p with\n | `Finite p ->\n p + xi_acc\n | `Maybe_finite (p_is_finite, p) ->\n if_ p_is_finite ~then_:(p + xi_acc) ~else_:xi_acc )\n )\n ~xi\n ~init:(function\n | `Finite x ->\n Some (`Finite x)\n | `Maybe_finite x ->\n Some (`Maybe_finite x) )\n (Vector.map without_degree_bound\n ~f:(Array.map ~f:(fun x -> `Finite x)) )\n (Vector.map with_degree_bound\n ~f:\n (let open Plonk_types.Poly_comm.With_degree_bound in\n fun { shifted; unshifted } ->\n let f x = `Maybe_finite x in\n { unshifted = Array.map ~f unshifted\n ; shifted = f shifted\n }) ) )\n |> function `Finite x -> x | `Maybe_finite _ -> assert false\n in\n let lr_prod, challenges = bullet_reduce sponge lr in\n let p_prime =\n let uc = scale_fast2 u advice.combined_inner_product in\n combined_polynomial + uc\n in\n let q = p_prime + lr_prod in\n absorb sponge PC delta ;\n let c = squeeze_scalar sponge in\n print_fp \"c\" c.inner ;\n (* c Q + delta = z1 (G + b U) + z2 H *)\n let lhs =\n let cq = Scalar_challenge.endo q c in\n cq + delta\n in\n let rhs =\n with_label __LOC__ (fun () ->\n let b_u = scale_fast2 u advice.b in\n let z_1_g_plus_b_u =\n scale_fast2 (challenge_polynomial_commitment + b_u) z_1\n in\n let z2_h =\n scale_fast2 (Inner_curve.constant (Lazy.force Generators.h)) z_2\n in\n z_1_g_plus_b_u + z2_h )\n in\n (`Success (equal_g lhs rhs), challenges) )\n\n let assert_eq_deferred_values\n (m1 :\n ( 'a\n , Inputs.Impl.Field.t Import.Scalar_challenge.t\n , _ )\n Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.t )\n (m2 :\n ( Inputs.Impl.Field.t\n , Inputs.Impl.Field.t Import.Scalar_challenge.t\n , _ )\n Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.t ) =\n let open Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal in\n let chal c1 c2 = Field.Assert.equal c1 c2 in\n let scalar_chal\n ({ Import.Scalar_challenge.inner = t1 } : _ Import.Scalar_challenge.t)\n ({ Import.Scalar_challenge.inner = t2 } : _ Import.Scalar_challenge.t) =\n Field.Assert.equal t1 t2\n in\n with_label __LOC__ (fun () -> chal m1.beta m2.beta) ;\n with_label __LOC__ (fun () -> chal m1.gamma m2.gamma) ;\n with_label __LOC__ (fun () -> scalar_chal m1.alpha m2.alpha) ;\n with_label __LOC__ (fun () -> scalar_chal m1.zeta m2.zeta)\n\n let lagrange_commitment ~domain srs i =\n let d = Int.pow 2 (Domain.log2_size domain) in\n match[@warning \"-4\"]\n (Kimchi_bindings.Protocol.SRS.Fq.lagrange_commitment srs d i).unshifted\n with\n | [| Finite g |] ->\n Inner_curve.Constant.of_affine g\n | _ ->\n assert false\n\n module O = One_hot_vector.Make (Impl)\n open Tuple_lib\n\n let public_input_commitment_dynamic (type n) ~srs (which : n O.t)\n (domains : (Domains.t, n) Vector.t)\n ~(public_input :\n [ `Field of Field.t | `Packed_bits of Field.t * int ] array ) =\n (*\n let domains : (Domains.t, Nat.N3.n) Vector.t =\n Vector.map ~f:(fun proofs_verified -> Common.wrap_domains ~proofs_verified)\n [ 0; 1 ; 2 ]\n in *)\n let lagrange_commitment (d : Domains.t) (i : int) : Inner_curve.Constant.t =\n lagrange_commitment ~domain:d.h srs i\n in\n let select_curve_points (type k)\n ~(points_for_domain : Domains.t -> (Inner_curve.Constant.t, k) Vector.t)\n : (Inner_curve.t, k) Vector.t =\n match domains with\n | [] ->\n assert false\n | d :: ds ->\n if Vector.for_all ds ~f:(fun d' -> Domain.equal d.h d'.h) then\n Vector.map ~f:Inner_curve.constant (points_for_domain d)\n else\n Vector.map2\n (which :> (Boolean.var, n) Vector.t)\n domains\n ~f:(fun b d ->\n let points = points_for_domain d in\n Vector.map points ~f:(fun g ->\n let x, y = Inner_curve.constant g in\n Field.((b :> t) * x, (b :> t) * y) ) )\n |> Vector.reduce_exn\n ~f:(Vector.map2 ~f:(Double.map2 ~f:Field.( + )))\n |> Vector.map ~f:(Double.map ~f:(Util.seal (module Impl)))\n in\n let lagrange i =\n select_curve_points ~points_for_domain:(fun d ->\n [ lagrange_commitment d i ] )\n |> Vector.unsingleton\n in\n let lagrange_with_correction ~input_length i :\n (Inner_curve.t, Nat.N2.n) Vector.t =\n let actual_shift =\n (* TODO: num_bits should maybe be input_length - 1. *)\n Ops.bits_per_chunk * Ops.chunks_needed ~num_bits:input_length\n in\n let rec pow2pow x i =\n if i = 0 then x else pow2pow Inner_curve.Constant.(x + x) (i - 1)\n in\n select_curve_points ~points_for_domain:(fun d ->\n let g = lagrange_commitment d i in\n let open Inner_curve.Constant in\n [ g; negate (pow2pow g actual_shift) ] )\n in\n let x_hat =\n let constant_part, non_constant_part =\n List.partition_map\n (Array.to_list (Array.mapi ~f:(fun i t -> (i, t)) public_input))\n ~f:(fun (i, t) ->\n match[@warning \"-4\"] t with\n | `Field (Constant c) | `Packed_bits (Constant c, _) ->\n First\n ( if Field.Constant.(equal zero) c then None\n else if Field.Constant.(equal one) c then Some (lagrange i)\n else\n Some\n ( select_curve_points ~points_for_domain:(fun d ->\n [ Inner_curve.Constant.scale\n (lagrange_commitment d i)\n (Inner_curve.Constant.Scalar.project\n (Field.Constant.unpack c) )\n ] )\n |> Vector.unsingleton ) )\n | `Field x ->\n Second (i, (x, Public_input_scalar.Constant.size_in_bits))\n | `Packed_bits (x, n) ->\n Second (i, (x, n)) )\n in\n let terms =\n List.map non_constant_part ~f:(fun (i, x) ->\n match x with\n | b, 1 ->\n assert_ (Constraint.boolean (b :> Field.t)) ;\n `Cond_add (Boolean.Unsafe.of_cvar b, lagrange i)\n | x, n ->\n `Add_with_correction\n ((x, n), lagrange_with_correction ~input_length:n i) )\n in\n let f = Ops.add_fast ?check_finite:None in\n let correction =\n List.reduce_exn\n (List.filter_map terms ~f:(function\n | `Cond_add _ ->\n None\n | `Add_with_correction (_, [ _; corr ]) ->\n Some corr ) )\n ~f\n in\n let init =\n List.fold (List.filter_map constant_part ~f:Fn.id) ~init:correction ~f\n in\n List.fold terms ~init ~f:(fun acc term ->\n match term with\n | `Cond_add (b, g) ->\n with_label __LOC__ (fun () ->\n Inner_curve.if_ b ~then_:(Ops.add_fast g acc) ~else_:acc )\n | `Add_with_correction ((x, num_bits), [ g; _ ]) ->\n Ops.add_fast acc\n (Ops.scale_fast2' (module Public_input_scalar) g x ~num_bits) )\n |> Inner_curve.negate\n in\n x_hat\n\n let incrementally_verify_proof (type b)\n (module Proofs_verified : Nat.Add.Intf with type n = b) ~srs:_\n ~(domain :\n [ `Known of Domain.t\n | `Side_loaded of\n _ Composition_types.Branch_data.Proofs_verified.One_hot.Checked.t ]\n ) ~srs ~verification_key:(m : _ Plonk_verification_key_evals.t) ~xi\n ~sponge ~sponge_after_index\n ~(public_input :\n [ `Field of Field.t | `Packed_bits of Field.t * int ] array )\n ~(sg_old : (_, Proofs_verified.n) Vector.t) ~advice\n ~proof:({ messages; opening } : Wrap_proof.Checked.t)\n ~(plonk :\n ( _\n , _\n , _ Shifted_value.Type2.t\n , _\n , _\n , _ )\n Types.Wrap.Proof_state.Deferred_values.Plonk.In_circuit.t ) =\n with_label \"incrementally_verify_proof\" (fun () ->\n let receive ty f =\n with_label \"receive\" (fun () ->\n let x = f messages in\n absorb sponge ty x ; x )\n in\n let sample () = squeeze_challenge sponge in\n let sample_scalar () = squeeze_scalar sponge in\n let open Plonk_types.Messages.In_circuit in\n let without = Type.Without_degree_bound in\n let absorb_g gs = absorb sponge without gs in\n let index_digest =\n with_label \"absorb verifier index\" (fun () ->\n let index_sponge = Sponge.copy sponge_after_index in\n Sponge.squeeze_field index_sponge )\n in\n absorb sponge Field index_digest ;\n let sg_old : (_, Wrap_hack.Padded_length.n) Vector.t =\n Wrap_hack.Checked.pad_commitments sg_old\n in\n Vector.iter ~f:(absorb sponge PC) sg_old ;\n let x_hat =\n with_label \"x_hat\" (fun () ->\n match domain with\n | `Known domain ->\n multiscale_known\n (Array.mapi public_input ~f:(fun i x ->\n (x, lagrange_commitment ~domain srs i) ) )\n |> Inner_curve.negate\n | `Side_loaded which ->\n public_input_commitment_dynamic ~srs which\n (Vector.map\n ~f:(fun proofs_verified ->\n Common.wrap_domains ~proofs_verified )\n [ 0; 1; 2 ] )\n ~public_input )\n in\n let x_hat =\n with_label \"x_hat blinding\" (fun () ->\n Ops.add_fast x_hat\n (Inner_curve.constant (Lazy.force Generators.h)) )\n in\n absorb sponge PC x_hat ;\n let w_comm = messages.w_comm in\n Vector.iter ~f:absorb_g w_comm ;\n let beta = sample () in\n let gamma = sample () in\n let z_comm = receive without z_comm in\n let alpha = sample_scalar () in\n let t_comm = receive without t_comm in\n let zeta = sample_scalar () in\n (* At this point, we should use the previous \"bulletproof_challenges\" to\n compute to compute f(beta_1) outside the snark\n where f is the polynomial corresponding to sg_old\n *)\n let sponge_before_evaluations = Sponge.copy sponge in\n let sponge_digest_before_evaluations = Sponge.squeeze_field sponge in\n\n (* xi, r are sampled here using the other sponge. *)\n (* No need to expose the polynomial evaluations as deferred values as they're\n not needed here for the incremental verification. All we need is a_hat and\n \"combined_inner_product\".\n\n Then, in the other proof, we can witness the evaluations and check their correctness\n against \"combined_inner_product\" *)\n let sigma_comm_init, [ _ ] =\n Vector.split m.sigma_comm\n (snd (Plonk_types.Permuts_minus_1.add Nat.N1.n))\n in\n let ft_comm =\n with_label __LOC__ (fun () ->\n Common.ft_comm\n ~add:(Ops.add_fast ?check_finite:None)\n ~scale:scale_fast2 ~negate:Inner_curve.negate\n ~endoscale:(Scalar_challenge.endo ?num_bits:None)\n ~verification_key:m ~plonk ~alpha ~t_comm )\n in\n let bulletproof_challenges =\n (* This sponge needs to be initialized with (some derivative of)\n 1. The polynomial commitments\n 2. The combined inner product\n 3. The challenge points.\n\n It should be sufficient to fork the sponge after squeezing beta_3 and then to absorb\n the combined inner product.\n *)\n let num_commitments_without_degree_bound = Nat.N45.n in\n let without_degree_bound =\n Vector.append\n (Vector.map sg_old ~f:(fun g -> [| g |]))\n ( [| x_hat |] :: [| ft_comm |] :: z_comm :: [| m.generic_comm |]\n :: [| m.psm_comm |] :: [| m.complete_add_comm |]\n :: [| m.mul_comm |] :: [| m.emul_comm |]\n :: [| m.endomul_scalar_comm |]\n :: Vector.append w_comm\n (Vector.append\n (Vector.map m.coefficients_comm ~f:(fun g -> [| g |]))\n (Vector.map sigma_comm_init ~f:(fun g -> [| g |]))\n (snd Plonk_types.(Columns.add Permuts_minus_1.n)) )\n (snd\n Plonk_types.(\n Columns.add (fst (Columns.add Permuts_minus_1.n))) ) )\n (snd\n (Wrap_hack.Padded_length.add\n num_commitments_without_degree_bound ) )\n in\n with_label \"check_bulletproof\" (fun () ->\n check_bulletproof\n ~pcs_batch:\n (Common.dlog_pcs_batch\n (Wrap_hack.Padded_length.add\n num_commitments_without_degree_bound ) )\n ~sponge:sponge_before_evaluations ~xi ~advice ~opening\n ~polynomials:(without_degree_bound, []) )\n in\n let joint_combiner = None in\n assert_eq_deferred_values\n { alpha = plonk.alpha\n ; beta = plonk.beta\n ; gamma = plonk.gamma\n ; zeta = plonk.zeta\n ; joint_combiner\n ; feature_flags = plonk.feature_flags\n }\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; joint_combiner\n ; feature_flags = plonk.feature_flags\n } ;\n (sponge_digest_before_evaluations, bulletproof_challenges) )\n\n let compute_challenges ~scalar chals =\n with_label \"compute_challenges\" (fun () ->\n Vector.map chals ~f:(fun b -> Bulletproof_challenge.pack b |> scalar) )\n\n let challenge_polynomial = Wrap_verifier.challenge_polynomial (module Field)\n\n module Pseudo = Pseudo.Make (Impl)\n\n (* module Bounded = struct\n type t = { max : int; actual : Field.t }\n\n let _of_pseudo ((_, ns) as p : _ Pseudo.t) =\n { max = Vector.reduce_exn ~f:Int.max ns\n ; actual = Pseudo.choose p ~f:Field.of_int\n }\n end *)\n\n let vanishing_polynomial mask =\n with_label \"vanishing_polynomial\" (fun () ->\n let mask = Vector.to_array mask in\n let max = Array.length mask in\n fun x ->\n let rec go acc i =\n if i >= max then acc\n else\n let should_square = mask.(i) in\n let acc =\n Field.if_ should_square ~then_:(Field.square acc) ~else_:acc\n in\n go acc (i + 1)\n in\n Field.sub (go x 0) Field.one )\n\n let shifts ~log2_size = Common.tick_shifts ~log2_size\n\n let domain_generator ~log2_size =\n Backend.Tick.Field.domain_generator ~log2_size |> Impl.Field.constant\n\n let side_loaded_domain =\n let open Side_loaded_verification_key in\n fun ~(log2_size : Field.t) ->\n let domain ~max =\n let (T max_n) = Nat.of_int max in\n let mask = ones_vector (module Impl) max_n ~first_zero:log2_size in\n let log2_sizes =\n ( O.of_index log2_size ~length:(S max_n)\n , Vector.init (S max_n) ~f:Fn.id )\n in\n let shifts = Pseudo.Domain.shifts log2_sizes ~shifts in\n let generator = Pseudo.Domain.generator log2_sizes ~domain_generator in\n let vanishing_polynomial = vanishing_polynomial mask in\n object\n method log2_size = log2_size\n\n method vanishing_polynomial x = vanishing_polynomial x\n\n method shifts = shifts\n\n method generator = generator\n end\n in\n domain ~max:(Domain.log2_size max_domains.h)\n\n let%test_module \"side loaded domains\" =\n ( module struct\n let run k =\n let y =\n run_and_check (fun () ->\n let y = k () in\n fun () -> As_prover.read_var y )\n |> Or_error.ok_exn\n in\n y\n\n let%test_unit \"side loaded domains\" =\n let open Side_loaded_verification_key in\n let domains = [ { Domains.h = 10 }; { h = 15 } ] in\n let pt = Field.Constant.random () in\n List.iter domains ~f:(fun ds ->\n let d_unchecked =\n Plonk_checks.domain\n (module Field.Constant)\n (Pow_2_roots_of_unity ds.h) ~shifts:Common.tick_shifts\n ~domain_generator:Backend.Tick.Field.domain_generator\n in\n let checked_domain () =\n side_loaded_domain ~log2_size:(Field.of_int ds.h)\n in\n [%test_eq: Field.Constant.t]\n (d_unchecked#vanishing_polynomial pt)\n (run (fun () ->\n (checked_domain ())#vanishing_polynomial (Field.constant pt) )\n ) )\n end )\n\n (* module Split_evaluations = struct\n open Plonk_types\n\n let mask' { Bounded.max; actual } : Boolean.var array =\n let (T max) = Nat.of_int max in\n Vector.to_array (ones_vector (module Impl) ~first_zero:actual max)\n\n let mask (type n) ~(lengths : (int, n) Vector.t)\n (choice : n One_hot_vector.T(Impl).t) : Boolean.var array =\n let max =\n Option.value_exn\n (List.max_elt ~compare:Int.compare (Vector.to_list lengths))\n in\n let actual = Pseudo.choose (choice, lengths) ~f:Field.of_int in\n mask' { max; actual }\n\n let _last =\n Array.reduce_exn ~f:(fun (b_acc, x_acc) (b, x) ->\n (Boolean.(b_acc ||| b), Field.if_ b ~then_:x ~else_:x_acc) )\n\n let pow x bits_lsb =\n with_label \"pow\" (fun () ->\n let rec go acc bs =\n match bs with\n | [] ->\n acc\n | b :: bs ->\n let acc = Field.square acc in\n let acc = Field.if_ b ~then_:Field.(x * acc) ~else_:acc in\n go acc bs\n in\n go Field.one (List.rev bits_lsb) )\n\n let _mod_max_degree =\n let k = Nat.to_int Backend.Tick.Rounds.n in\n fun d ->\n let d =\n Number.of_bits\n (Field.unpack\n ~length:Pickles_base.Side_loaded_verification_key.max_log2_degree\n d )\n in\n Number.mod_pow_2 d (`Two_to_the k)\n\n let _mask_evals (type n) ~(lengths : (int, n) Vector.t Evals.t)\n (choice : n One_hot_vector.T(Impl).t) (e : Field.t array Evals.t) :\n (Boolean.var * Field.t) array Evals.t =\n Evals.map2 lengths e ~f:(fun lengths e ->\n Array.zip_exn (mask ~lengths choice) e )\n end *)\n\n let _absorb_field sponge x = Sponge.absorb sponge (`Field x)\n\n (* pt^{2^n} *)\n let pow2_pow (pt : Field.t) (n : int) : Field.t =\n with_label \"pow2_pow\" (fun () ->\n let rec go acc i =\n if i = 0 then acc else go (Field.square acc) (i - 1)\n in\n go pt n )\n\n let actual_evaluation (e : Field.t array) ~(pt_to_n : Field.t) : Field.t =\n with_label \"actual_evaluation\" (fun () ->\n match List.rev (Array.to_list e) with\n | e :: es ->\n List.fold ~init:e es ~f:(fun acc fx -> Field.(fx + (pt_to_n * acc)))\n | [] ->\n Field.zero )\n\n open Plonk_types\n\n module Opt_sponge = struct\n include Opt_sponge.Make (Impl) (Step_main_inputs.Sponge.Permutation)\n\n let _squeeze_challenge sponge : Field.t =\n lowest_128_bits (squeeze sponge) ~constrain_low_bits:true\n end\n\n let shift1 =\n Shifted_value.Type1.Shift.(\n map ~f:Field.constant (create (module Field.Constant)))\n\n let _shift2 =\n Shifted_value.Type2.Shift.(\n map ~f:Field.constant (create (module Field.Constant)))\n\n let%test_unit \"endo scalar\" =\n SC.test (module Impl) ~endo:Endo.Wrap_inner_curve.scalar\n\n module Plonk = Types.Wrap.Proof_state.Deferred_values.Plonk\n\n module Plonk_checks = struct\n include Plonk_checks\n\n include\n Plonk_checks.Make\n (Shifted_value.Type1)\n (struct\n let constant_term = Plonk_checks.Scalars.Tick.constant_term\n\n let index_terms = Plonk_checks.Scalars.Tick.index_terms\n end)\n end\n\n let domain_for_compiled (type branches)\n (domains : (Domains.t, branches) Vector.t)\n (branch_data : Impl.field Branch_data.Checked.t) :\n Field.t Plonk_checks.plonk_domain =\n let (T unique_domains) =\n List.map (Vector.to_list domains) ~f:Domains.h\n |> List.dedup_and_sort ~compare:(fun d1 d2 ->\n Int.compare (Domain.log2_size d1) (Domain.log2_size d2) )\n |> Vector.of_list\n in\n let which_log2 =\n Vector.map unique_domains ~f:(fun d ->\n Field.equal\n (Field.of_int (Domain.log2_size d))\n branch_data.domain_log2 )\n |> O.of_vector_unsafe\n (* This should be ok... think it through a little more *)\n in\n Pseudo.Domain.to_domain\n (which_log2, unique_domains)\n ~shifts ~domain_generator\n\n (* This finalizes the \"deferred values\" coming from a previous proof over the same field.\n It\n 1. Checks that [xi] and [r] where sampled correctly. I.e., by absorbing all the\n evaluation openings and then squeezing.\n 2. Checks that the \"combined inner product\" value used in the elliptic curve part of\n the opening proof was computed correctly, in terms of the evaluation openings and the\n evaluation points.\n 3. Check that the \"b\" value was computed correctly.\n 4. Perform the arithmetic checks from marlin. *)\n (* TODO: This needs to handle the fact of variable length evaluations.\n Meaning it needs opt sponge. *)\n let finalize_other_proof (type b branches)\n (module Proofs_verified : Nat.Add.Intf with type n = b)\n ~(step_domains :\n [ `Known of (Domains.t, branches) Vector.t | `Side_loaded ] )\n ~(* TODO: Add \"actual proofs verified\" so that proofs don't\n carry around dummy \"old bulletproof challenges\" *)\n sponge ~(prev_challenges : (_, b) Vector.t)\n ({ xi\n ; combined_inner_product\n ; bulletproof_challenges\n ; branch_data\n ; b\n ; plonk\n } :\n ( Field.t\n , _\n , Field.t Shifted_value.Type1.t\n , _\n , _\n , _\n , Field.Constant.t Branch_data.Checked.t\n , _ )\n Types.Wrap.Proof_state.Deferred_values.In_circuit.t )\n { Plonk_types.All_evals.In_circuit.ft_eval1; evals } =\n let actual_width_mask = branch_data.proofs_verified_mask in\n let T = Proofs_verified.eq in\n (* You use the NEW bulletproof challenges to check b. Not the old ones. *)\n let scalar =\n SC.to_field_checked (module Impl) ~endo:Endo.Wrap_inner_curve.scalar\n in\n let plonk =\n Types.Wrap.Proof_state.Deferred_values.Plonk.In_circuit.map_challenges\n ~f:Fn.id ~scalar plonk\n in\n let domain =\n match step_domains with\n | `Known ds ->\n domain_for_compiled ds branch_data\n | `Side_loaded ->\n ( side_loaded_domain ~log2_size:branch_data.domain_log2\n :> _ Plonk_checks.plonk_domain )\n in\n let zetaw = Field.mul domain#generator plonk.zeta in\n let sg_olds =\n with_label \"sg_olds\" (fun () ->\n Vector.map prev_challenges ~f:(fun chals ->\n unstage (challenge_polynomial (Vector.to_array chals)) ) )\n in\n let sg_evals1, sg_evals2 =\n let sg_evals pt =\n Vector.map2\n ~f:(fun keep f -> (keep, f pt))\n (Vector.trim_front actual_width_mask\n (Nat.lte_exn Proofs_verified.n Nat.N2.n) )\n sg_olds\n in\n (sg_evals plonk.zeta, sg_evals zetaw)\n in\n let sponge_state =\n let challenge_digest =\n let opt_sponge = Opt_sponge.create sponge_params in\n Vector.iter2\n (Vector.trim_front actual_width_mask\n (Nat.lte_exn Proofs_verified.n Nat.N2.n) )\n prev_challenges\n ~f:(fun keep chals ->\n Vector.iter chals ~f:(fun chal ->\n Opt_sponge.absorb opt_sponge (keep, chal) ) ) ;\n Opt_sponge.squeeze opt_sponge\n in\n Sponge.absorb sponge (`Field challenge_digest) ;\n Sponge.absorb sponge (`Field ft_eval1) ;\n Sponge.absorb sponge (`Field (fst evals.public_input)) ;\n Sponge.absorb sponge (`Field (snd evals.public_input)) ;\n let xs = Evals.In_circuit.to_absorption_sequence evals.evals in\n (* This is a hacky, but much more efficient, version of the opt sponge.\n This uses the assumption that the sponge 'absorption state' will align\n after each optional absorption, letting us skip the expensive tracking\n that this would otherwise require.\n To future-proof this, we assert that the states are indeed compatible.\n *)\n List.iter xs ~f:(fun opt ->\n let absorb =\n Array.iter ~f:(fun x -> Sponge.absorb sponge (`Field x))\n in\n match opt with\n | Nothing ->\n ()\n | Just (x1, x2) ->\n absorb x1 ; absorb x2\n | Maybe (b, (x1, x2)) ->\n (* Cache the sponge state before *)\n let sponge_state_before = sponge.sponge_state in\n let state_before = Array.copy sponge.state in\n (* Absorb the points *)\n absorb x1 ;\n absorb x2 ;\n (* Check that the sponge ends in a compatible state. *)\n ( match (sponge_state_before, sponge.sponge_state) with\n | Absorbed x, Absorbed y ->\n [%test_eq: int] x y\n | Squeezed x, Squeezed y ->\n [%test_eq: int] x y\n | Absorbed _, Squeezed _ ->\n [%test_eq: string] \"absorbed\" \"squeezed\"\n | Squeezed _, Absorbed _ ->\n [%test_eq: string] \"squeezed\" \"absorbed\" ) ;\n let state =\n Array.map2_exn sponge.state state_before ~f:(fun then_ else_ ->\n Field.if_ b ~then_ ~else_ )\n in\n sponge.state <- state ) ;\n Array.copy sponge.state\n in\n sponge.state <- sponge_state ;\n let squeeze () = squeeze_challenge sponge in\n let xi_actual = squeeze () in\n let r_actual = squeeze () in\n let xi_correct =\n Field.equal xi_actual\n (match xi with { Import.Scalar_challenge.inner = xi } -> xi)\n in\n let xi = scalar xi in\n let r = scalar (Import.Scalar_challenge.create r_actual) in\n let plonk_minimal =\n Plonk.to_minimal plonk ~to_option:Opt.to_option_unsafe\n in\n let combined_evals =\n let n = Int.ceil_log2 Max_degree.step in\n let zeta_n : Field.t = pow2_pow plonk.zeta n in\n let zetaw_n : Field.t = pow2_pow zetaw n in\n Evals.In_circuit.map\n ~f:(fun (x0, x1) ->\n ( actual_evaluation ~pt_to_n:zeta_n x0\n , actual_evaluation ~pt_to_n:zetaw_n x1 ) )\n evals.evals\n in\n let env =\n with_label \"scalars_env\" (fun () ->\n let module Env_bool = struct\n include Boolean\n\n type t = Boolean.var\n end in\n let module Env_field = struct\n include Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ =\n match Impl.Field.to_constant (b :> t) with\n | Some x ->\n (* We have a constant, only compute the branch we care about. *)\n if Impl.Field.Constant.(equal one) x then then_ ()\n else else_ ()\n | None ->\n if_ b ~then_:(then_ ()) ~else_:(else_ ())\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~srs_length_log2:Common.Max_degree.step_log2\n ~endo:(Impl.Field.constant Endo.Step_inner_curve.base)\n ~mds:sponge_params.mds\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fp.of_bigint |> Field.constant )\n ~domain plonk_minimal combined_evals )\n in\n let open Field in\n let combined_inner_product_correct =\n let evals1, evals2 =\n All_evals.With_public_input.In_circuit.factor evals\n in\n let ft_eval0 : Field.t =\n with_label \"ft_eval0\" (fun () ->\n Plonk_checks.ft_eval0\n (module Field)\n ~env ~domain plonk_minimal combined_evals evals1.public_input )\n in\n print_fp \"ft_eval0\" ft_eval0 ;\n print_fp \"ft_eval1\" ft_eval1 ;\n (* sum_i r^i sum_j xi^j f_j(beta_i) *)\n let actual_combined_inner_product =\n let combine ~ft ~sg_evals x_hat\n (e : (Field.t array, _) Evals.In_circuit.t) =\n let sg_evals =\n sg_evals |> Vector.to_list\n |> List.map ~f:(fun (keep, eval) -> [| Opt.Maybe (keep, eval) |])\n in\n let a =\n Evals.In_circuit.to_list e\n |> List.map ~f:(function\n | Nothing ->\n [||]\n | Just a ->\n Array.map a ~f:Opt.just\n | Maybe (b, a) ->\n Array.map a ~f:(Opt.maybe b) )\n in\n let v =\n List.append sg_evals ([| Opt.just x_hat |] :: [| Opt.just ft |] :: a)\n in\n Common.combined_evaluation (module Impl) ~xi v\n in\n with_label \"combine\" (fun () ->\n combine ~ft:ft_eval0 ~sg_evals:sg_evals1 evals1.public_input\n evals1.evals\n + r\n * combine ~ft:ft_eval1 ~sg_evals:sg_evals2 evals2.public_input\n evals2.evals )\n in\n let expected =\n Shifted_value.Type1.to_field\n (module Field)\n ~shift:shift1 combined_inner_product\n in\n print_fp \"step_main cip expected\" expected ;\n print_fp \"step_main cip actual\" actual_combined_inner_product ;\n equal expected actual_combined_inner_product\n in\n let bulletproof_challenges =\n compute_challenges ~scalar bulletproof_challenges\n in\n let b_correct =\n with_label \"b_correct\" (fun () ->\n let challenge_poly =\n unstage\n (challenge_polynomial (Vector.to_array bulletproof_challenges))\n in\n let b_actual =\n challenge_poly plonk.zeta + (r * challenge_poly zetaw)\n in\n let b_used =\n Shifted_value.Type1.to_field (module Field) ~shift:shift1 b\n in\n equal b_used b_actual )\n in\n let plonk_checks_passed =\n with_label \"plonk_checks_passed\" (fun () ->\n Plonk_checks.checked\n (module Impl)\n ~env ~shift:shift1 plonk combined_evals )\n in\n print_bool \"xi_correct\" xi_correct ;\n print_bool \"combined_inner_product_correct\" combined_inner_product_correct ;\n print_bool \"plonk_checks_passed\" plonk_checks_passed ;\n print_bool \"b_correct\" b_correct ;\n ( Boolean.all\n [ xi_correct\n ; b_correct\n ; combined_inner_product_correct\n ; plonk_checks_passed\n ]\n , bulletproof_challenges )\n\n let sponge_after_index index =\n let sponge = Sponge.create sponge_params in\n Array.iter\n (Types.index_to_field_elements\n ~g:(fun (z : Inputs.Inner_curve.t) ->\n List.to_array (Inner_curve.to_field_elements z) )\n index )\n ~f:(fun x -> Sponge.absorb sponge (`Field x)) ;\n sponge\n\n let hash_messages_for_next_step_proof (type s) ~index\n (state_to_field_elements : s -> Field.t array) =\n let open Types.Step.Proof_state.Messages_for_next_step_proof in\n let after_index = sponge_after_index index in\n stage (fun (t : _ Types.Step.Proof_state.Messages_for_next_step_proof.t) ->\n let sponge = Sponge.copy after_index in\n Array.iter\n ~f:(fun x -> Sponge.absorb sponge (`Field x))\n (to_field_elements_without_index t ~app_state:state_to_field_elements\n ~g:Inner_curve.to_field_elements ) ;\n Sponge.squeeze_field sponge )\n\n let hash_messages_for_next_step_proof_opt (type s) ~index\n (state_to_field_elements : s -> Field.t array) =\n let open Types.Step.Proof_state.Messages_for_next_step_proof in\n let after_index = sponge_after_index index in\n ( after_index\n , (* TODO: Just get rid of the proofs verified mask and always absorb in full *)\n stage (fun t ~widths:_ ~max_width:_ ~proofs_verified_mask ->\n let sponge = Sponge.copy after_index in\n let t =\n { t with\n old_bulletproof_challenges =\n Vector.map2 proofs_verified_mask t.old_bulletproof_challenges\n ~f:(fun b v -> Vector.map v ~f:(fun x -> `Opt (b, x)))\n ; challenge_polynomial_commitments =\n Vector.map2 proofs_verified_mask\n t.challenge_polynomial_commitments ~f:(fun b g -> (b, g))\n }\n in\n let not_opt x = `Not_opt x in\n let hash_inputs =\n to_field_elements_without_index t\n ~app_state:\n (Fn.compose (Array.map ~f:not_opt) state_to_field_elements)\n ~g:(fun (b, g) ->\n List.map\n ~f:(fun x -> `Opt (b, x))\n (Inner_curve.to_field_elements g) )\n in\n match\n Array.fold hash_inputs ~init:(`Not_opt sponge) ~f:(fun acc t ->\n match (acc, t) with\n | `Not_opt sponge, `Not_opt t ->\n Sponge.absorb sponge (`Field t) ;\n acc\n | `Not_opt sponge, `Opt t ->\n let sponge = Opt_sponge.of_sponge sponge in\n Opt_sponge.absorb sponge t ; `Opt sponge\n | `Opt sponge, `Opt t ->\n Opt_sponge.absorb sponge t ; acc\n | `Opt _, `Not_opt _ ->\n assert false )\n with\n | `Not_opt sponge ->\n (* This means there were no optional inputs. *)\n Sponge.squeeze_field sponge\n | `Opt sponge ->\n Opt_sponge.squeeze sponge ) )\n\n let _accumulation_verifier\n (_accumulator_verification_key : _ Types_map.For_step.t)\n _prev_accumulators _proof _new_accumulator : Boolean.var =\n Boolean.false_\n\n let verify ~proofs_verified ~is_base_case ~sg_old ~sponge_after_index\n ~lookup_parameters ~feature_flags ~(proof : Wrap_proof.Checked.t) ~srs\n ~wrap_domain ~wrap_verification_key statement\n (unfinalized :\n ( _\n , _\n , _ Shifted_value.Type2.t\n , _\n , _\n , _ )\n Types.Step.Proof_state.Per_proof.In_circuit.t ) =\n let public_input :\n [ `Field of Field.t | `Packed_bits of Field.t * int ] array =\n with_label \"pack_statement\" (fun () ->\n Spec.pack\n (module Impl)\n (Types.Wrap.Statement.In_circuit.spec\n (module Impl)\n lookup_parameters feature_flags )\n (Types.Wrap.Statement.In_circuit.to_data ~option_map:Opt.map\n statement ) )\n |> Array.map ~f:(function\n | `Field (Shifted_value.Type1.Shifted_value x) ->\n `Field x\n | `Packed_bits (x, n) ->\n `Packed_bits (x, n) )\n in\n let sponge = Sponge.create sponge_params in\n let { Types.Step.Proof_state.Deferred_values.xi\n ; combined_inner_product\n ; b\n ; _\n } =\n unfinalized.deferred_values\n in\n let ( sponge_digest_before_evaluations_actual\n , (`Success bulletproof_success, bulletproof_challenges_actual) ) =\n incrementally_verify_proof ~srs proofs_verified ~srs ~domain:wrap_domain\n ~xi ~verification_key:wrap_verification_key ~sponge ~sponge_after_index\n ~public_input ~sg_old\n ~advice:{ b; combined_inner_product }\n ~proof\n ~plonk:\n (Composition_types.Step.Proof_state.Deferred_values.Plonk.In_circuit\n .to_wrap ~opt_none:Opt.nothing ~false_:Boolean.false_\n unfinalized.deferred_values.plonk )\n in\n with_label __LOC__ (fun () ->\n with_label __LOC__ (fun () ->\n Field.Assert.equal unfinalized.sponge_digest_before_evaluations\n sponge_digest_before_evaluations_actual ) ;\n Array.iteri\n (Vector.to_array unfinalized.deferred_values.bulletproof_challenges)\n ~f:(fun i c1 ->\n let c2 = bulletproof_challenges_actual.(i) in\n let { Import.Scalar_challenge.inner = c1 } =\n Bulletproof_challenge.pack c1\n in\n let c2 =\n Field.if_ is_base_case ~then_:c1\n ~else_:(match c2.prechallenge with { inner = c2 } -> c2)\n in\n with_label (sprintf \"%s:%d\" __LOC__ i) (fun () ->\n Field.Assert.equal c1 c2 ) ) ) ;\n bulletproof_success\nend\n\ninclude Make (Step_main_inputs)\n","open Core_kernel\n\n[@@@warning \"-4-27\"]\n\nmodule Yojson_map = Map.Make (struct\n type t =\n [ `Null\n | `Bool of bool\n | `Int of int\n | `Intlit of string\n | `Float of float\n | `String of string\n | `Assoc of (string * t) list\n | `List of t list\n | `Tuple of t list\n | `Variant of string * t option ]\n [@@deriving compare, sexp]\nend)\n\n[@@@warning \"+4+27\"]\n\ntype t = Yojson.Safe.t Yojson_map.t Yojson_map.t ref\n\n(* We use a slightly more verbose format here, so that it's easy to debug.\n There are some overheads to handling this, but the amount of computation we\n save by caching the proofs is orders of magnitude higher, so it's not really\n an issue.\n*)\nlet to_yojson t =\n `List\n (Map.fold ~init:[] !t ~f:(fun ~key ~data xs ->\n let proofs =\n Map.fold ~init:[] data ~f:(fun ~key ~data xs ->\n `Assoc [ (\"public_input\", key); (\"proof\", data) ] :: xs )\n in\n `Assoc [ (\"verification_key\", key); (\"proofs\", `List proofs) ] :: xs )\n )\n\n(* This mirrors the format of [to_yojson], carefully ensuring that we can\n decode what we encode, and reporting an error when the format differs from\n what we expect.\n\n Note that, since this is a cache, it should always be possible to regenerate\n proofs for the cache by starting with the empty cache and calling\n [to_yojson] on the result.\n*)\nlet of_yojson t =\n Result.try_with (fun () ->\n match t with\n | `List xs ->\n let for_vks =\n List.map xs ~f:(function\n | `Assoc [ (\"verification_key\", key); (\"proofs\", `List proofs) ]\n ->\n let proofs =\n List.map proofs ~f:(function\n | `Assoc [ (\"public_input\", key); (\"proof\", data) ] ->\n (key, data)\n | _ ->\n failwith\n \"Expected fields `public_input`, `proof` as a \\\n record in that order; received something \\\n different\" )\n in\n (key, Yojson_map.of_alist_exn proofs)\n | _ ->\n failwith\n \"Expected fields `verification_key`, `proofs` as a record \\\n in that order, where `proofs` is a list; received \\\n something different\" )\n in\n ref (Yojson_map.of_alist_exn for_vks)\n | _ ->\n failwith \"Expected a list, got something different\" )\n |> Result.map_error ~f:Exn.to_string\n\n(* Alias types with a [deriving to_yojson] annotation, so that we don't have to\n spell out the serialization explicitly.\n*)\nmodule Json = struct\n type 'f or_infinity = 'f Kimchi_types.or_infinity =\n | Infinity\n | Finite of ('f * 'f)\n [@@deriving to_yojson]\n\n type 'caml_g poly_comm = 'caml_g Kimchi_types.poly_comm =\n { unshifted : 'caml_g array; shifted : 'caml_g option }\n [@@deriving to_yojson]\n\n type lookup_patterns = Kimchi_types.lookup_patterns =\n { xor : bool; lookup : bool; range_check : bool; foreign_field_mul : bool }\n [@@deriving to_yojson]\n\n type lookup_features = Kimchi_types.lookup_features =\n { patterns : lookup_patterns\n ; joint_lookup_used : bool\n ; uses_runtime_tables : bool\n }\n [@@deriving to_yojson]\n\n type lookups_used = Kimchi_types.VerifierIndex.Lookup.lookups_used =\n | Single\n | Joint\n [@@deriving to_yojson]\n\n type lookup_info = Kimchi_types.VerifierIndex.Lookup.lookup_info =\n { max_per_row : int; max_joint_size : int; features : lookup_features }\n [@@deriving to_yojson]\n\n type 't lookup_selectors =\n 't Kimchi_types.VerifierIndex.Lookup.lookup_selectors =\n { lookup : 't option\n ; xor : 't option\n ; range_check : 't option\n ; ffmul : 't option\n }\n [@@deriving to_yojson]\n\n type 'poly_comm lookup = 'poly_comm Kimchi_types.VerifierIndex.Lookup.t =\n { joint_lookup_used : bool\n ; lookup_table : 'poly_comm array\n ; lookup_selectors : 'poly_comm lookup_selectors\n ; table_ids : 'poly_comm option\n ; lookup_info : lookup_info\n ; runtime_tables_selector : 'poly_comm option\n }\n [@@deriving to_yojson]\n\n type 'fr domain = 'fr Kimchi_types.VerifierIndex.domain =\n { log_size_of_group : int; group_gen : 'fr }\n [@@deriving to_yojson]\n\n type 'poly_comm verification_evals =\n 'poly_comm Kimchi_types.VerifierIndex.verification_evals =\n { sigma_comm : 'poly_comm array\n ; coefficients_comm : 'poly_comm array\n ; generic_comm : 'poly_comm\n ; psm_comm : 'poly_comm\n ; complete_add_comm : 'poly_comm\n ; mul_comm : 'poly_comm\n ; emul_comm : 'poly_comm\n ; endomul_scalar_comm : 'poly_comm\n ; xor_comm : 'poly_comm option [@default None]\n ; range_check0_comm : 'poly_comm option [@default None]\n ; range_check1_comm : 'poly_comm option [@default None]\n ; foreign_field_add_comm : 'poly_comm option [@default None]\n ; foreign_field_mul_comm : 'poly_comm option [@default None]\n ; rot_comm : 'poly_comm option [@default None]\n }\n [@@deriving to_yojson]\n\n type ('fr, 'srs, 'poly_comm) verifier_index =\n ('fr, 'srs, 'poly_comm) Kimchi_types.VerifierIndex.verifier_index =\n { domain : 'fr domain\n ; max_poly_size : int\n ; public : int\n ; prev_challenges : int\n ; srs : 'srs\n ; evals : 'poly_comm verification_evals\n ; shifts : 'fr array\n ; lookup_index : 'poly_comm lookup option\n }\n [@@deriving to_yojson]\n\n let srs_to_yojson _ = `Null\n\n let step_verification_key_to_yojson =\n [%to_yojson:\n ( Backend.Tick.Field.t\n , srs\n , Backend.Tock.Field.t or_infinity poly_comm )\n verifier_index]\n\n let wrap_verification_key_to_yojson =\n [%to_yojson:\n ( Backend.Tock.Field.t\n , srs\n , Backend.Tick.Field.t or_infinity poly_comm )\n verifier_index]\nend\n\nlet empty () = ref Yojson_map.empty\n\nlet get_proof t ~verification_key ~public_input =\n let open Option.Let_syntax in\n let%bind for_vk = Map.find !t verification_key in\n Map.find for_vk public_input\n\nlet get_step_proof t ~keypair ~public_input =\n let open Option.Let_syntax in\n let public_input =\n let len = Kimchi_bindings.FieldVectors.Fp.length public_input in\n Array.init len ~f:(fun i ->\n Kimchi_bindings.FieldVectors.Fp.get public_input i )\n |> [%to_yojson: Backend.Tick.Field.t array]\n in\n let verification_key =\n Backend.Tick.Keypair.vk keypair |> Json.step_verification_key_to_yojson\n in\n let%bind proof_json = get_proof t ~verification_key ~public_input in\n Option.try_with (fun () ->\n Result.ok_or_failwith @@ Backend.Tick.Proof.of_yojson proof_json )\n\nlet get_wrap_proof t ~keypair ~public_input =\n let open Option.Let_syntax in\n let public_input =\n let len = Kimchi_bindings.FieldVectors.Fq.length public_input in\n Array.init len ~f:(fun i ->\n Kimchi_bindings.FieldVectors.Fq.get public_input i )\n |> [%to_yojson: Backend.Tock.Field.t array]\n in\n let verification_key =\n Backend.Tock.Keypair.vk keypair |> Json.wrap_verification_key_to_yojson\n in\n let%bind proof_json = get_proof t ~verification_key ~public_input in\n Option.try_with (fun () ->\n Result.ok_or_failwith @@ Backend.Tock.Proof.of_yojson proof_json )\n\nlet set_proof t ~verification_key ~public_input proof =\n t :=\n Map.update !t verification_key ~f:(function\n | None ->\n Yojson_map.singleton public_input proof\n | Some for_vk ->\n Map.set for_vk ~key:public_input ~data:proof )\n\nlet set_step_proof t ~keypair ~public_input proof =\n let public_input =\n let len = Kimchi_bindings.FieldVectors.Fp.length public_input in\n Array.init len ~f:(fun i ->\n Kimchi_bindings.FieldVectors.Fp.get public_input i )\n |> [%to_yojson: Backend.Tick.Field.t array]\n in\n let verification_key =\n Backend.Tick.Keypair.vk keypair |> Json.step_verification_key_to_yojson\n in\n let proof_json = Backend.Tick.Proof.to_yojson proof in\n set_proof t ~verification_key ~public_input proof_json\n\nlet set_wrap_proof t ~keypair ~public_input proof =\n let public_input =\n let len = Kimchi_bindings.FieldVectors.Fq.length public_input in\n Array.init len ~f:(fun i ->\n Kimchi_bindings.FieldVectors.Fq.get public_input i )\n |> [%to_yojson: Backend.Tock.Field.t array]\n in\n let verification_key =\n Backend.Tock.Keypair.vk keypair |> Json.wrap_verification_key_to_yojson\n in\n let proof_json = Backend.Tock.Proof.to_yojson proof in\n set_proof t ~verification_key ~public_input proof_json\n","open Core_kernel\n\nmodule Step = struct\n module Key = struct\n module Proving = struct\n type t =\n Type_equal.Id.Uid.t\n * Snark_keys_header.t\n * int\n * Backend.Tick.R1CS_constraint_system.t\n\n let to_string : t -> _ = function\n | _id, header, n, _h ->\n sprintf !\"step-%s-%s-%d-%s\" header.kind.type_ header.kind.identifier\n n header.identifying_hash\n end\n\n module Verification = struct\n type t = Type_equal.Id.Uid.t * Snark_keys_header.t * int * Md5.t\n [@@deriving sexp]\n\n let to_string : t -> _ = function\n | _id, header, n, _h ->\n sprintf !\"vk-step-%s-%s-%d-%s\" header.kind.type_\n header.kind.identifier n header.identifying_hash\n end\n [@@warning \"-4\"]\n end\n\n let storable =\n Key_cache.Sync.Disk_storable.simple Key.Proving.to_string\n (fun (_, header, _, cs) ~path ->\n Or_error.try_with_join (fun () ->\n let open Or_error.Let_syntax in\n let%map header_read, index =\n Snark_keys_header.read_with_header\n ~read_data:(fun ~offset ->\n Kimchi_bindings.Protocol.Index.Fp.read (Some offset)\n (Backend.Tick.Keypair.load_urs ()) )\n path\n in\n [%test_eq: int] header.header_version header_read.header_version ;\n [%test_eq: Snark_keys_header.Kind.t] header.kind header_read.kind ;\n [%test_eq: Snark_keys_header.Constraint_constants.t]\n header.constraint_constants header_read.constraint_constants ;\n [%test_eq: string] header.constraint_system_hash\n header_read.constraint_system_hash ;\n { Backend.Tick.Keypair.index; cs } ) )\n (fun (_, header, _, _) t path ->\n Or_error.try_with (fun () ->\n Snark_keys_header.write_with_header\n ~expected_max_size_log2:33 (* 8 GB should be enough *)\n ~append_data:\n (Kimchi_bindings.Protocol.Index.Fp.write (Some true)\n t.Backend.Tick.Keypair.index )\n header path ) )\n\n let vk_storable =\n Key_cache.Sync.Disk_storable.simple Key.Verification.to_string\n (fun (_, header, _, _) ~path ->\n Or_error.try_with_join (fun () ->\n let open Or_error.Let_syntax in\n let%map header_read, index =\n Snark_keys_header.read_with_header\n ~read_data:(fun ~offset path ->\n Kimchi_bindings.Protocol.VerifierIndex.Fp.read (Some offset)\n (Backend.Tick.Keypair.load_urs ())\n path )\n path\n in\n [%test_eq: int] header.header_version header_read.header_version ;\n [%test_eq: Snark_keys_header.Kind.t] header.kind header_read.kind ;\n [%test_eq: Snark_keys_header.Constraint_constants.t]\n header.constraint_constants header_read.constraint_constants ;\n [%test_eq: string] header.constraint_system_hash\n header_read.constraint_system_hash ;\n index ) )\n (fun (_, header, _, _) x path ->\n Or_error.try_with (fun () ->\n Snark_keys_header.write_with_header\n ~expected_max_size_log2:33 (* 8 GB should be enough *)\n ~append_data:\n (Kimchi_bindings.Protocol.VerifierIndex.Fp.write (Some true) x)\n header path ) )\n\n let read_or_generate ~prev_challenges cache k_p k_v typ return_typ main =\n let s_p = storable in\n let s_v = vk_storable in\n let open Impls.Step in\n let pk =\n lazy\n ( match\n Common.time \"step keypair read\" (fun () ->\n Key_cache.Sync.read cache s_p (Lazy.force k_p) )\n with\n | Ok (pk, dirty) ->\n Common.time \"step keypair create\" (fun () ->\n (Keypair.create ~pk ~vk:(Backend.Tick.Keypair.vk pk), dirty) )\n | Error _e ->\n let r =\n Common.time \"stepkeygen\" (fun () ->\n constraint_system ~input_typ:typ ~return_typ main\n |> Keypair.generate ~prev_challenges )\n in\n Timer.clock __LOC__ ;\n ignore\n ( Key_cache.Sync.write cache s_p (Lazy.force k_p) (Keypair.pk r)\n : unit Or_error.t ) ;\n (r, `Generated_something) )\n in\n let vk =\n lazy\n (let k_v = Lazy.force k_v in\n match\n Common.time \"step vk read\" (fun () ->\n Key_cache.Sync.read cache s_v k_v )\n with\n | Ok (vk, _) ->\n (vk, `Cache_hit)\n | Error _e ->\n let pk, c = Lazy.force pk in\n let vk = Keypair.vk pk in\n ignore (Key_cache.Sync.write cache s_v k_v vk : unit Or_error.t) ;\n (vk, c) )\n in\n (pk, vk)\nend\n\nmodule Wrap = struct\n module Key = struct\n module Verification = struct\n type t = Type_equal.Id.Uid.t * Snark_keys_header.t * Md5.t\n [@@deriving sexp]\n\n let equal ((_, x1, y1) : t) ((_, x2, y2) : t) =\n [%equal: unit * Md5.t] ((* TODO: *) ignore x1, y1) (ignore x2, y2)\n\n let to_string : t -> _ = function\n | _id, header, _h ->\n sprintf !\"vk-wrap-%s-%s-%s\" header.kind.type_ header.kind.identifier\n header.identifying_hash\n end\n [@@warning \"-4\"]\n\n module Proving = struct\n type t =\n Type_equal.Id.Uid.t\n * Snark_keys_header.t\n * Backend.Tock.R1CS_constraint_system.t\n\n let to_string : t -> _ = function\n | _id, header, _h ->\n sprintf !\"wrap-%s-%s-%s\" header.kind.type_ header.kind.identifier\n header.identifying_hash\n end\n end\n\n let storable =\n Key_cache.Sync.Disk_storable.simple Key.Proving.to_string\n (fun (_, header, cs) ~path ->\n Or_error.try_with_join (fun () ->\n let open Or_error.Let_syntax in\n let%map header_read, index =\n Snark_keys_header.read_with_header\n ~read_data:(fun ~offset ->\n Kimchi_bindings.Protocol.Index.Fq.read (Some offset)\n (Backend.Tock.Keypair.load_urs ()) )\n path\n in\n [%test_eq: int] header.header_version header_read.header_version ;\n [%test_eq: Snark_keys_header.Kind.t] header.kind header_read.kind ;\n [%test_eq: Snark_keys_header.Constraint_constants.t]\n header.constraint_constants header_read.constraint_constants ;\n [%test_eq: string] header.constraint_system_hash\n header_read.constraint_system_hash ;\n { Backend.Tock.Keypair.index; cs } ) )\n (fun (_, header, _) t path ->\n Or_error.try_with (fun () ->\n Snark_keys_header.write_with_header\n ~expected_max_size_log2:33 (* 8 GB should be enough *)\n ~append_data:\n (Kimchi_bindings.Protocol.Index.Fq.write (Some true) t.index)\n header path ) )\n\n let read_or_generate ~prev_challenges cache k_p k_v typ return_typ main =\n let module Vk = Verification_key in\n let open Impls.Wrap in\n let s_p = storable in\n let pk =\n lazy\n (let k = Lazy.force k_p in\n match\n Common.time \"wrap key read\" (fun () ->\n Key_cache.Sync.read cache s_p k )\n with\n | Ok (pk, d) ->\n (Keypair.create ~pk ~vk:(Backend.Tock.Keypair.vk pk), d)\n | Error _e ->\n let r =\n Common.time \"wrapkeygen\" (fun () ->\n constraint_system ~input_typ:typ ~return_typ main\n |> Keypair.generate ~prev_challenges )\n in\n ignore\n ( Key_cache.Sync.write cache s_p k (Keypair.pk r)\n : unit Or_error.t ) ;\n (r, `Generated_something) )\n in\n let vk =\n lazy\n (let k_v = Lazy.force k_v in\n let s_v =\n Key_cache.Sync.Disk_storable.simple Key.Verification.to_string\n (fun (_, header, _cs) ~path ->\n Or_error.try_with_join (fun () ->\n let open Or_error.Let_syntax in\n let%map header_read, index =\n Snark_keys_header.read_with_header\n ~read_data:(fun ~offset:_ path ->\n Binable.of_string\n (module Vk.Stable.Latest)\n (In_channel.read_all path) )\n path\n in\n [%test_eq: int] header.header_version\n header_read.header_version ;\n [%test_eq: Snark_keys_header.Kind.t] header.kind\n header_read.kind ;\n [%test_eq: Snark_keys_header.Constraint_constants.t]\n header.constraint_constants\n header_read.constraint_constants ;\n [%test_eq: string] header.constraint_system_hash\n header_read.constraint_system_hash ;\n index ) )\n (fun (_, header, _) t path ->\n Or_error.try_with (fun () ->\n Snark_keys_header.write_with_header\n ~expected_max_size_log2:33 (* 8 GB should be enough *)\n ~append_data:(fun path ->\n Out_channel.with_file ~append:true path ~f:(fun file ->\n Out_channel.output_string file\n (Binable.to_string (module Vk.Stable.Latest) t) )\n )\n header path ) )\n in\n match Key_cache.Sync.read cache s_v k_v with\n | Ok (vk, d) ->\n (vk, d)\n | Error _e ->\n let kp, _dirty = Lazy.force pk in\n let vk = Keypair.vk kp in\n let pk = Keypair.pk kp in\n let vk : Vk.t =\n { index = vk\n ; commitments =\n Kimchi_pasta.Pallas_based_plonk.Keypair.vk_commitments vk\n ; data =\n (let open Kimchi_bindings.Protocol.Index.Fq in\n { constraints = domain_d1_size pk.index })\n }\n in\n ignore (Key_cache.Sync.write cache s_v k_v vk : unit Or_error.t) ;\n let _vk = Key_cache.Sync.read cache s_v k_v in\n (vk, `Generated_something) )\n in\n (pk, vk)\nend\n","open Core_kernel\nopen Bitstring_lib\nopen Snark_bits\n\nmodule Make_snarkable (Impl : Snarky_backendless.Snark_intf.S) = struct\n open Impl\n\n module type S = sig\n type var\n\n type value\n\n val typ : (var, value) Typ.t\n end\n\n module Bits = struct\n module type Lossy =\n Bits_intf.Snarkable.Lossy\n with type ('a, 'b) typ := ('a, 'b) Typ.t\n and type 'a checked := 'a Checked.t\n and type boolean_var := Boolean.var\n\n module type Faithful =\n Bits_intf.Snarkable.Faithful\n with type ('a, 'b) typ := ('a, 'b) Typ.t\n and type 'a checked := 'a Checked.t\n and type boolean_var := Boolean.var\n\n module type Small =\n Bits_intf.Snarkable.Small\n with type ('a, 'b) typ := ('a, 'b) Typ.t\n and type 'a checked := 'a Checked.t\n and type boolean_var := Boolean.var\n and type comparison_result := Field.Checked.comparison_result\n and type field_var := Field.Var.t\n end\nend\n\nmodule Tock0 = struct\n include Crypto_params.Tock\n module Snarkable = Make_snarkable (Crypto_params.Tock)\nend\n\nmodule Tick0 = struct\n include Crypto_params.Tick\n module Snarkable = Make_snarkable (Crypto_params.Tick)\nend\n\nlet%test_unit \"group-map test\" =\n let params = Crypto_params.Tock.group_map_params () in\n let module M = Crypto_params.Tick.Run in\n Quickcheck.test ~trials:3 Tick0.Field.gen ~f:(fun t ->\n let checked_output =\n M.run_and_check (fun () ->\n let x, y =\n Snarky_group_map.Checked.to_group\n (module M)\n ~params (M.Field.constant t)\n in\n fun () -> M.As_prover.(read_var x, read_var y) )\n |> Or_error.ok_exn\n in\n let ((x, y) as actual) =\n Group_map.to_group (module Tick0.Field) ~params t\n in\n [%test_eq: Tick0.Field.t]\n Tick0.Field.(\n (x * x * x)\n + (Tick0.Inner_curve.Params.a * x)\n + Tick0.Inner_curve.Params.b)\n Tick0.Field.(y * y) ;\n [%test_eq: Tick0.Field.t * Tick0.Field.t] checked_output actual )\n\nmodule Make_inner_curve_scalar (Impl : Snark_intf.S) (Other_impl : Snark_intf.S) =\nstruct\n module T = Other_impl.Field\n\n include (\n T :\n module type of T with module Var := T.Var and module Checked := T.Checked )\n\n let of_bits = Other_impl.Field.project\n\n let length_in_bits = size_in_bits\n\n open Impl\n\n type var = Boolean.var Bitstring.Lsb_first.t\n\n let typ : (var, t) Typ.t =\n Typ.transport_var\n (Typ.transport\n (Typ.list ~length:size_in_bits Boolean.typ)\n ~there:unpack ~back:project )\n ~there:Bitstring.Lsb_first.to_list ~back:Bitstring.Lsb_first.of_list\n\n let gen : t Quickcheck.Generator.t =\n Quickcheck.Generator.map\n (Bignum_bigint.gen_incl Bignum_bigint.one\n Bignum_bigint.(Other_impl.Field.size - one) )\n ~f:(fun x -> Other_impl.Bigint.(to_field (of_bignum_bigint x)))\n\n let test_bit x i = Other_impl.Bigint.(test_bit (of_field x) i)\n\n module Checked = struct\n let equal a b =\n Bitstring_checked.equal\n (Bitstring.Lsb_first.to_list a)\n (Bitstring.Lsb_first.to_list b)\n\n let to_bits = Fn.id\n\n module Assert = struct\n let equal : var -> var -> unit Checked.t =\n fun a b ->\n Bitstring_checked.Assert.equal\n (Bitstring.Lsb_first.to_list a)\n (Bitstring.Lsb_first.to_list b)\n end\n end\nend\n\nmodule Make_inner_curve_aux (Impl : Snark_intf.S) (Other_impl : Snark_intf.S) =\nstruct\n open Impl\n\n type var = Field.Var.t * Field.Var.t\n\n module Scalar = Make_inner_curve_scalar (Impl) (Other_impl)\nend\n\nmodule Tock = struct\n include (\n Tock0 : module type of Tock0 with module Inner_curve := Tock0.Inner_curve )\n\n module Fq = Snarky_field_extensions.Field_extensions.F (Tock0)\n\n module Inner_curve = struct\n include Tock0.Inner_curve\n\n include\n Sexpable.Of_sexpable\n (struct\n type t = Field.t * Field.t [@@deriving sexp]\n end)\n (struct\n type nonrec t = t\n\n let to_sexpable = to_affine_exn\n\n let of_sexpable = of_affine\n end)\n\n include Make_inner_curve_aux (Tock0) (Tick0)\n\n module Checked = struct\n include\n Snarky_curves.Make_weierstrass_checked (Fq) (Scalar)\n (struct\n include Tock0.Inner_curve\n end)\n (Params)\n (struct\n let add = None\n end)\n\n let add_known_unsafe t x = add_unsafe t (constant x)\n end\n\n let typ = Checked.typ\n end\nend\n\nmodule Tick = struct\n include (\n Tick0 :\n module type of Tick0\n with module Field := Tick0.Field\n and module Inner_curve := Tick0.Inner_curve )\n\n module Field = struct\n include Hashable.Make (Tick0.Field)\n include Tick0.Field\n module Bits = Bits.Make_field (Tick0.Field) (Tick0.Bigint)\n\n let size_in_triples = Int.((size_in_bits + 2) / 3)\n end\n\n module Fq = Snarky_field_extensions.Field_extensions.F (Tick0)\n\n module Inner_curve = struct\n include Crypto_params.Tick.Inner_curve\n\n include\n Sexpable.Of_sexpable\n (struct\n type t = Field.t * Field.t [@@deriving sexp]\n end)\n (struct\n type nonrec t = t\n\n let to_sexpable = to_affine_exn\n\n let of_sexpable = of_affine\n end)\n\n include Make_inner_curve_aux (Tick0) (Tock0)\n\n module Checked = struct\n include\n Snarky_curves.Make_weierstrass_checked (Fq) (Scalar)\n (Crypto_params.Tick.Inner_curve)\n (Params)\n (struct\n let add =\n Some\n (fun p1 p2 ->\n Run.make_checked (fun () ->\n Pickles.Step_main_inputs.Ops.add_fast p1 p2 ) )\n end)\n\n let add_known_unsafe t x = add_unsafe t (constant x)\n end\n\n let typ = Checked.typ\n end\n\n module Util = Snark_util.Make (Tick0)\n\n let m : Run.field Snarky_backendless.Snark.m = (module Run)\n\n let make_checked c = Run.make_checked c\nend\n\n(* Let n = Tick.Field.size_in_bits.\n Let k = n - 3.\n The reason k = n - 3 is as follows. Inside [meets_target], we compare\n a value against 2^k. 2^k requires k + 1 bits. The comparison then unpacks\n a (k + 1) + 1 bit number. This number cannot overflow so it is important that\n k + 1 + 1 < n. Thus k < n - 2.\n\n However, instead of using `Field.size_in_bits - 3` we choose `Field.size_in_bits - 8`\n to clamp the easiness. To something not-to-quick on a personal laptop from mid 2010s.\n*)\nlet target_bit_length = Tick.Field.size_in_bits - 8\n\nmodule type Snark_intf = Snark_intf.S\n\nmodule Group_map = struct\n let to_group x =\n Group_map.to_group (module Tick.Field) ~params:(Tock.group_map_params ()) x\n\n module Checked = struct\n let to_group x =\n Snarky_group_map.Checked.to_group\n (module Tick.Run)\n ~params:(Tock.group_map_params ()) x\n end\nend\n","open Core_kernel\nmodule Inputs = Pickles.Tick_field_sponge.Inputs\nmodule Ocaml_permutation = Sponge.Poseidon (Inputs)\nmodule Field = Kimchi_backend.Pasta.Basic.Fp\n\nlet add_assign = Ocaml_permutation.add_assign\n\nlet copy = Ocaml_permutation.copy\n\nlet params = Kimchi_pasta_fp_poseidon.create ()\n\nlet block_cipher _params (s : Field.t array) =\n let v = Kimchi_bindings.FieldVectors.Fp.create () in\n Array.iter s ~f:(Kimchi_bindings.FieldVectors.Fp.emplace_back v) ;\n Kimchi_pasta_fp_poseidon.block_cipher params v ;\n Array.init (Array.length s) ~f:(Kimchi_bindings.FieldVectors.Fp.get v)\n\nlet%test_unit \"check rust implementation of block-cipher\" =\n let params' : Field.t Sponge.Params.t =\n Kimchi_pasta_basic.poseidon_params_fp\n in\n let open Pickles.Impls.Step in\n let module T = Internal_Basic in\n Quickcheck.test (Quickcheck.Generator.list_with_length 3 T.Field.gen)\n ~f:(fun s ->\n let s () = Array.of_list s in\n [%test_eq: T.Field.t array]\n (Ocaml_permutation.block_cipher params' (s ()))\n (block_cipher params' (s ())) )\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n[%%ifdef consensus_mechanism]\n\nopen Pickles.Impls.Step.Internal_Basic\n\n[%%else]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nmodule State = struct\n include Array\n\n let map2 = map2_exn\n\n let to_array t = t\n\n let of_array t = t\nend\n\nmodule Input = Random_oracle_input\n\nlet params : Field.t Sponge.Params.t = Kimchi_pasta_basic.poseidon_params_fp\n\nmodule Operations = struct\n let add_assign ~state i x = Field.(state.(i) <- state.(i) + x)\n\n let apply_affine_map (matrix, constants) v =\n let dotv row =\n Array.reduce_exn (Array.map2_exn row v ~f:Field.( * )) ~f:Field.( + )\n in\n let res = Array.map matrix ~f:dotv in\n Array.map2_exn res constants ~f:Field.( + )\n\n let copy a = Array.map a ~f:Fn.id\nend\n\nmodule Digest = struct\n type t = Field.t\n\n let to_bits ?length x =\n match length with\n | None ->\n Field.unpack x\n | Some length ->\n List.take (Field.unpack x) length\nend\n\ninclude Sponge.Make_hash (Random_oracle_permutation)\n\nlet update ~state = update ~state params\n\nlet hash ?init = hash ?init params\n\nlet pow2 =\n let rec pow2 acc n = if n = 0 then acc else pow2 Field.(acc + acc) (n - 1) in\n Memo.general ~hashable:Int.hashable (fun n -> pow2 Field.one n)\n\n[%%ifdef consensus_mechanism]\n\nmodule Checked = struct\n module Inputs = Pickles.Step_main_inputs.Sponge.Permutation\n\n module Digest = struct\n open Pickles.Impls.Step.Field\n\n type nonrec t = t\n\n let to_bits ?(length = Field.size_in_bits) (x : t) =\n List.take (choose_preimage_var ~length:Field.size_in_bits x) length\n end\n\n include Sponge.Make_hash (Inputs)\n\n let params = Sponge.Params.map ~f:Inputs.Field.constant params\n\n open Inputs.Field\n\n let update ~state xs = update params ~state xs\n\n let hash ?init xs =\n hash ?init:(Option.map init ~f:(State.map ~f:constant)) params xs\n\n let pack_input =\n Input.Chunked.pack_to_fields\n ~pow2:(Fn.compose Field.Var.constant pow2)\n (module Pickles.Impls.Step.Field)\n\n let digest xs = xs.(0)\nend\n\nlet read_typ ({ field_elements; packeds } : _ Input.Chunked.t) =\n let open Pickles.Impls.Step in\n let open As_prover in\n { Input.Chunked.field_elements = Array.map ~f:(read Field.typ) field_elements\n ; packeds = Array.map packeds ~f:(fun (x, i) -> (read Field.typ x, i))\n }\n\nlet read_typ' input : _ Pickles.Impls.Step.Internal_Basic.As_prover.t =\n fun _ -> read_typ input\n\n[%%endif]\n\nlet pack_input = Input.Chunked.pack_to_fields ~pow2 (module Field)\n\nlet prefix_to_field (s : string) =\n let bits_per_character = 8 in\n assert (bits_per_character * String.length s < Field.size_in_bits) ;\n Field.project Fold_lib.Fold.(to_list (string_bits (s :> string)))\n\nlet salt (s : string) = update ~state:initial_state [| prefix_to_field s |]\n\nlet%test_unit \"iterativeness\" =\n let x1 = Field.random () in\n let x2 = Field.random () in\n let x3 = Field.random () in\n let x4 = Field.random () in\n let s_full = update ~state:initial_state [| x1; x2; x3; x4 |] in\n let s_it =\n update ~state:(update ~state:initial_state [| x1; x2 |]) [| x3; x4 |]\n in\n [%test_eq: Field.t array] s_full s_it\n\n[%%ifdef consensus_mechanism]\n\nlet%test_unit \"sponge checked-unchecked\" =\n let open Pickles.Impls.Step in\n let module T = Internal_Basic in\n let x = T.Field.random () in\n let y = T.Field.random () in\n T.Test.test_equal ~equal:T.Field.equal ~sexp_of_t:T.Field.sexp_of_t\n T.Typ.(field * field)\n T.Typ.field\n (fun (x, y) -> make_checked (fun () -> Checked.hash [| x; y |]))\n (fun (x, y) -> hash [| x; y |])\n (x, y)\n\n[%%endif]\n\nmodule Legacy = struct\n module Input = Random_oracle_input.Legacy\n module State = State\n\n let params : Field.t Sponge.Params.t =\n Sponge.Params.(map pasta_p_legacy ~f:Kimchi_pasta_basic.Fp.of_string)\n\n module Rounds = struct\n let rounds_full = 63\n\n let initial_ark = true\n\n let rounds_partial = 0\n end\n\n module Inputs = struct\n module Field = Field\n include Rounds\n\n let alpha = 5\n\n (* Computes x^5 *)\n let to_the_alpha x =\n let open Field in\n let res = x in\n let res = res * res in\n (* x^2 *)\n let res = res * res in\n (* x^4 *)\n res * x\n\n module Operations = Operations\n end\n\n include Sponge.Make_hash (Sponge.Poseidon (Inputs))\n\n let hash ?init = hash ?init params\n\n let update ~state = update ~state params\n\n let salt (s : string) = update ~state:initial_state [| prefix_to_field s |]\n\n let pack_input =\n Input.pack_to_fields ~size_in_bits:Field.size_in_bits ~pack:Field.project\n\n module Digest = Digest\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n let pack_input =\n Input.pack_to_fields ~size_in_bits:Field.size_in_bits ~pack:Field.Var.pack\n\n module Digest = Checked.Digest\n\n module Inputs = struct\n include Rounds\n module Impl = Pickles.Impls.Step\n open Impl\n module Field = Field\n\n let alpha = 5\n\n (* Computes x^5 *)\n let to_the_alpha x =\n let open Field in\n let res = x in\n let res = res * res in\n (* x^2 *)\n let res = res * res in\n (* x^4 *)\n res * x\n\n module Operations = struct\n open Field\n\n let seal = Pickles.Util.seal (module Impl)\n\n let add_assign ~state i x = state.(i) <- seal (state.(i) + x)\n\n let apply_affine_map (matrix, constants) v =\n let dotv row =\n Array.reduce_exn (Array.map2_exn row v ~f:( * )) ~f:( + )\n in\n let res = Array.map matrix ~f:dotv in\n Array.map2_exn res constants ~f:(fun x c -> seal (x + c))\n\n let copy a = Array.map a ~f:Fn.id\n end\n end\n\n include Sponge.Make_hash (Sponge.Poseidon (Inputs))\n\n let params = Sponge.Params.map ~f:Inputs.Field.constant params\n\n open Inputs.Field\n\n let update ~state xs = update params ~state xs\n\n let hash ?init xs =\n hash ?init:(Option.map init ~f:(State.map ~f:constant)) params xs\n end\n\n [%%endif]\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\n[%%ifdef consensus_mechanism]\n\nlet parity y = Bigint.(test_bit (of_field y) 0)\n\n[%%else]\n\nlet parity y = Field.parity y\n\n[%%endif]\n\nlet gen_uncompressed =\n Quickcheck.Generator.filter_map Field.gen_uniform ~f:(fun x ->\n let open Option.Let_syntax in\n let%map y = Inner_curve.find_y x in\n (x, y) )\n\nmodule Compressed = struct\n open Compressed_poly\n\n module Arg = struct\n (* module with same type t as Stable below, to build functor argument *)\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = ((Field.t[@version_asserted]), bool) Poly.Stable.V1.t\n\n let to_latest = Fn.id\n end\n end]\n end\n\n let compress (x, y) = { Poly.x; is_odd = parity y }\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n module T = struct\n type t = ((Field.t[@version_asserted]), bool) Poly.Stable.V1.t\n [@@deriving equal, compare, hash]\n\n let to_latest = Fn.id\n\n module M = struct\n (* for compatibility with legacy Base58Check serialization *)\n include Arg.Stable.V1.With_all_version_tags\n\n let description = \"Non zero curve point compressed\"\n\n let version_byte =\n Base58_check.Version_bytes.non_zero_curve_point_compressed\n end\n\n module Base58 = Codable.Make_base58_check (M)\n include Base58\n\n (* sexp representation is a Base58Check string, like the yojson representation *)\n let sexp_of_t t = to_base58_check t |> Sexp.of_string\n\n let t_of_sexp sexp = Sexp.to_string sexp |> of_base58_check_exn\n end\n\n include T\n include Hashable.Make_binable (T)\n\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%map uncompressed = gen_uncompressed in\n compress uncompressed\n end\n end]\n\n module Poly = Poly\n include Comparable.Make_binable (Stable.Latest)\n include Hashable.Make_binable (Stable.Latest)\n include Stable.Latest.Base58\n\n let to_string = to_base58_check\n\n [%%define_locally Stable.Latest.(sexp_of_t, t_of_sexp, gen)]\n\n let compress (x, y) = { Poly.x; is_odd = parity y }\n\n let empty = Poly.{ x = Field.zero; is_odd = false }\n\n let to_input { Poly.x; is_odd } =\n { Random_oracle.Input.Chunked.field_elements = [| x |]\n ; packeds = [| (Field.project [ is_odd ], 1) |]\n }\n\n let to_input_legacy { Poly.x; is_odd } =\n { Random_oracle.Input.Legacy.field_elements = [| x |]\n ; bitstrings = [| [ is_odd ] |]\n }\n\n [%%ifdef consensus_mechanism]\n\n (* snarky-dependent *)\n\n type var = (Field.Var.t, Boolean.var) Poly.t\n\n let typ : (var, t) Typ.t =\n Typ.of_hlistable [ Field.typ; Boolean.typ ] ~var_to_hlist:Poly.to_hlist\n ~var_of_hlist:Poly.of_hlist ~value_to_hlist:Poly.to_hlist\n ~value_of_hlist:Poly.of_hlist\n\n let var_of_t ({ x; is_odd } : t) : var =\n { x = Field.Var.constant x; is_odd = Boolean.var_of_value is_odd }\n\n let assert_equal (t1 : var) (t2 : var) =\n let%map () = Field.Checked.Assert.equal t1.x t2.x\n and () = Boolean.Assert.(t1.is_odd = t2.is_odd) in\n ()\n\n module Checked = struct\n let equal t1 t2 =\n let%bind x_eq = Field.Checked.equal t1.Poly.x t2.Poly.x in\n let%bind odd_eq = Boolean.equal t1.is_odd t2.is_odd in\n Boolean.(x_eq && odd_eq)\n\n let to_input ({ x; is_odd } : var) =\n { Random_oracle.Input.Chunked.field_elements = [| x |]\n ; packeds = [| ((is_odd :> Field.Var.t), 1) |]\n }\n\n let to_input_legacy = to_input_legacy\n\n let if_ cond ~then_:t1 ~else_:t2 =\n let%map x = Field.Checked.if_ cond ~then_:t1.Poly.x ~else_:t2.Poly.x\n and is_odd = Boolean.if_ cond ~then_:t1.is_odd ~else_:t2.is_odd in\n Poly.{ x; is_odd }\n\n module Assert = struct\n let equal t1 t2 =\n let%map () = Field.Checked.Assert.equal t1.Poly.x t2.Poly.x\n and () = Boolean.Assert.(t1.is_odd = t2.is_odd) in\n ()\n end\n end\n\n (* end snarky-dependent *)\n [%%endif]\nend\n\nmodule Uncompressed = struct\n let decompress ({ x; is_odd } : Compressed.t) =\n Option.map (Inner_curve.find_y x) ~f:(fun y ->\n let y_parity = parity y in\n let y = if Bool.(is_odd = y_parity) then y else Field.negate y in\n (x, y) )\n\n let decompress_exn t =\n match decompress t with\n | Some d ->\n d\n | None ->\n failwith\n (sprintf \"Compressed public key %s could not be decompressed\"\n (Yojson.Safe.to_string @@ Compressed.to_yojson t) )\n\n let of_base58_check_decompress_exn pk_str =\n let pk = Compressed.of_base58_check_exn pk_str in\n decompress_exn pk |> ignore ;\n pk\n\n let compress = Compressed.compress\n\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Field.t * Field.t [@@deriving compare, equal, hash]\n\n let to_latest = Fn.id\n\n include\n Binable.Of_binable_without_uuid\n (Compressed.Stable.V1)\n (struct\n type nonrec t = t\n\n let of_binable = decompress_exn\n\n let to_binable = compress\n end)\n\n let gen : t Quickcheck.Generator.t = gen_uncompressed\n\n let of_bigstring bs =\n let open Or_error.Let_syntax in\n let%map elem, _ = Bigstring.read_bin_prot bs bin_reader_t in\n elem\n\n let to_bigstring elem =\n let bs =\n Bigstring.create (bin_size_t elem + Bin_prot.Utils.size_header_length)\n in\n let _ = Bigstring.write_bin_prot bs bin_writer_t elem in\n bs\n\n (* We reuse the Base58check-based yojson (de)serialization from the\n compressed representation. *)\n\n let of_yojson json =\n let open Result in\n Compressed.of_yojson json\n >>= fun compressed ->\n Result.of_option ~error:\"couldn't decompress, curve point invalid\"\n (decompress compressed)\n\n let to_yojson t = Compressed.to_yojson @@ compress t\n\n (* as for yojson, use the Base58check-based sexps from the compressed representation *)\n let sexp_of_t t = Compressed.sexp_of_t @@ compress t\n\n let t_of_sexp sexp =\n Option.value_exn (decompress @@ Compressed.t_of_sexp sexp)\n end\n end]\n\n (* so we can make sets of public keys *)\n include Comparable.Make_binable (Stable.Latest)\n\n [%%define_locally\n Stable.Latest.\n (of_bigstring, to_bigstring, sexp_of_t, t_of_sexp, to_yojson, of_yojson)]\n\n let gen : t Quickcheck.Generator.t = gen_uncompressed\n\n let ( = ) = equal\n\n let of_inner_curve_exn = Inner_curve.to_affine_exn\n\n let to_inner_curve = Inner_curve.of_affine\n\n let%test_unit \"point-compression: decompress . compress = id\" =\n Quickcheck.test gen ~f:(fun pk ->\n assert (equal (decompress_exn (compress pk)) pk) )\n\n [%%ifdef consensus_mechanism]\n\n (* snarky-dependent *)\n\n type var = Field.Var.t * Field.Var.t\n\n let assert_equal var1 var2 =\n let open Field.Checked.Assert in\n let v1_f1, v1_f2 = var1 in\n let v2_f1, v2_f2 = var2 in\n let%bind () = equal v1_f1 v2_f1 in\n let%map () = equal v1_f2 v2_f2 in\n ()\n\n let var_of_t (x, y) = (Field.Var.constant x, Field.Var.constant y)\n\n let typ : (var, t) Typ.t = Typ.(field * field)\n\n let parity_var y =\n let%map bs = Field.Checked.unpack_full y in\n List.hd_exn (Bitstring_lib.Bitstring.Lsb_first.to_list bs)\n\n let decompress_var ({ x; is_odd } as c : Compressed.var) =\n let open Let_syntax in\n let%bind y =\n exists Typ.field\n ~compute:\n As_prover.(\n map (read Compressed.typ c) ~f:(fun c -> snd (decompress_exn c)))\n in\n let%map () = Inner_curve.Checked.Assert.on_curve (x, y)\n and () = parity_var y >>= Boolean.Assert.(( = ) is_odd) in\n (x, y)\n\n let%snarkydef_ compress_var ((x, y) : var) : Compressed.var Checked.t =\n let open Compressed_poly in\n let%map is_odd = parity_var y in\n { Poly.x; is_odd }\n\n (* end snarky-dependent *)\n [%%endif]\nend\n\ninclude Uncompressed\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = (Inner_curve.Scalar.t[@version_asserted])\n [@@deriving compare, sexp]\n\n (* deriver not working, apparently *)\n let sexp_of_t = [%sexp_of: Inner_curve.Scalar.t]\n\n let t_of_sexp = [%of_sexp: Inner_curve.Scalar.t]\n\n let to_latest = Fn.id\n\n [%%ifdef consensus_mechanism]\n\n let gen =\n let open Snark_params.Tick.Inner_curve.Scalar in\n let upperbound = Bignum_bigint.(pred size |> to_string) |> of_string in\n gen_uniform_incl one upperbound\n\n [%%else]\n\n let gen = Inner_curve.Scalar.(gen_uniform_incl one (zero - one))\n\n [%%endif]\n end\nend]\n\n[%%define_locally Stable.Latest.(gen)]\n\n[%%ifdef consensus_mechanism]\n\nlet create () =\n (* This calls into libsnark which uses /dev/urandom *)\n Inner_curve.Scalar.random ()\n\n[%%else]\n\nlet create () : t =\n let open Js_of_ocaml in\n let random_bytes_32 =\n Js.Unsafe.js_expr\n {js|(function() {\n var topLevel = (typeof self === 'object' && self.self === self && self) ||\n (typeof global === 'object' && global.global === global && global) ||\n this;\n var b;\n\n if (topLevel.crypto && topLevel.crypto.getRandomValues) {\n b = new Uint8Array(32);\n topLevel.crypto.getRandomValues(b);\n } else {\n if (typeof require === 'function') {\n var crypto = require('crypto');\n if (!crypto) {\n throw 'random values not available'\n }\n b = crypto.randomBytes(32);\n } else {\n throw 'random values not available'\n }\n }\n var res = [];\n for (var i = 0; i < 32; ++i) {\n res.push(b[i]);\n }\n res[31] &= 0x3f;\n return res;\n })|js}\n in\n let x : int Js.js_array Js.t = Js.Unsafe.fun_call random_bytes_32 [||] in\n let byte_undefined () = failwith \"byte undefined\" in\n Snarkette.Pasta.Fq.of_bigint\n (Snarkette.Nat.of_bytes\n (String.init 32 ~f:(fun i ->\n Char.of_int_exn (Js.Optdef.get (Js.array_get x i) byte_undefined) )\n ) )\n\n[%%endif]\n\ninclude Comparable.Make_binable (Stable.Latest)\n\n(* for compatibility with existing private key serializations *)\nlet of_bigstring_exn =\n Binable.of_bigstring (module Stable.Latest.With_all_version_tags)\n\nlet to_bigstring =\n Binable.to_bigstring (module Stable.Latest.With_all_version_tags)\n\nmodule Base58_check = Base58_check.Make (struct\n let description = \"Private key\"\n\n let version_byte = Base58_check.Version_bytes.private_key\nend)\n\nlet to_base58_check t =\n Base58_check.encode (to_bigstring t |> Bigstring.to_string)\n\nlet of_base58_check_exn s =\n let decoded = Base58_check.decode_exn s in\n decoded |> Bigstring.of_string |> of_bigstring_exn\n\nlet sexp_of_t t = to_base58_check t |> Sexp.of_string\n\nlet t_of_sexp sexp = Sexp.to_string sexp |> of_base58_check_exn\n\nlet to_yojson t = `String (to_base58_check t)\n\nlet of_yojson = function\n | `String x -> (\n try Ok (of_base58_check_exn x) with\n | Failure str ->\n Error str\n | exn ->\n Error (\"Signature_lib.Private_key.of_yojson: \" ^ Exn.to_string exn) )\n | _ ->\n Error \"Signature_lib.Private_key.of_yojson: Expected a string\"\n","[%%import \"/src/config.mlh\"]\n\nmodule Bignum_bigint = Bigint\nopen Core_kernel\n\nmodule type Message_intf = sig\n type field\n\n type t\n\n type curve\n\n type curve_scalar\n\n val derive :\n ?signature_kind:Mina_signature_kind.t\n -> t\n -> private_key:curve_scalar\n -> public_key:curve\n -> curve_scalar\n\n val derive_for_mainnet :\n t -> private_key:curve_scalar -> public_key:curve -> curve_scalar\n\n val derive_for_testnet :\n t -> private_key:curve_scalar -> public_key:curve -> curve_scalar\n\n val hash :\n ?signature_kind:Mina_signature_kind.t\n -> t\n -> public_key:curve\n -> r:field\n -> curve_scalar\n\n val hash_for_mainnet : t -> public_key:curve -> r:field -> curve_scalar\n\n val hash_for_testnet : t -> public_key:curve -> r:field -> curve_scalar\n\n [%%ifdef consensus_mechanism]\n\n type field_var\n\n type boolean_var\n\n type var\n\n type curve_var\n\n type curve_scalar_var\n\n type _ checked\n\n val hash_checked :\n var -> public_key:curve_var -> r:field_var -> curve_scalar_var checked\n\n [%%endif]\nend\n\n[%%ifdef consensus_mechanism]\n\nmodule type S = sig\n module Impl : Snarky_backendless.Snark_intf.S\n\n open Impl\n\n type curve\n\n type curve_var\n\n type curve_scalar\n\n type curve_scalar_var\n\n module Shifted : sig\n module type S =\n Snarky_curves.Shifted_intf\n with type curve_var := curve_var\n and type boolean_var := Boolean.var\n and type 'a checked := 'a Checked.t\n end\n\n module Message :\n Message_intf\n with type boolean_var := Boolean.var\n and type curve_scalar := curve_scalar\n and type curve_scalar_var := curve_scalar_var\n and type 'a checked := 'a Checked.t\n and type curve := curve\n and type curve_var := curve_var\n and type field := Field.t\n and type field_var := Field.Var.t\n\n module Signature : sig\n type t = field * curve_scalar [@@deriving sexp]\n\n type var = Field.Var.t * curve_scalar_var\n\n val typ : (var, t) Typ.t\n end\n\n module Private_key : sig\n type t = curve_scalar [@@deriving sexp]\n end\n\n module Public_key : sig\n type t = curve [@@deriving sexp]\n\n type var = curve_var\n end\n\n module Checked : sig\n val compress : curve_var -> Boolean.var list Checked.t\n\n val verifies :\n (module Shifted.S with type t = 't)\n -> Signature.var\n -> Public_key.var\n -> Message.var\n -> Boolean.var Checked.t\n\n val assert_verifies :\n (module Shifted.S with type t = 't)\n -> Signature.var\n -> Public_key.var\n -> Message.var\n -> unit Checked.t\n end\n\n val compress : curve -> bool list\n\n val sign :\n ?signature_kind:Mina_signature_kind.t\n -> Private_key.t\n -> Message.t\n -> Signature.t\n\n val verify :\n ?signature_kind:Mina_signature_kind.t\n -> Signature.t\n -> Public_key.t\n -> Message.t\n -> bool\nend\n\nmodule Make\n (Impl : Snarky_backendless.Snark_intf.S) (Curve : sig\n open Impl\n\n module Scalar : sig\n type t [@@deriving sexp, equal]\n\n type var\n\n val typ : (var, t) Typ.t\n\n val zero : t\n\n val ( * ) : t -> t -> t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\n\n module Checked : sig\n val to_bits : var -> Boolean.var Bitstring_lib.Bitstring.Lsb_first.t\n end\n end\n\n type t [@@deriving sexp]\n\n type var = Field.Var.t * Field.Var.t\n\n module Checked :\n Snarky_curves.Weierstrass_checked_intf\n with module Impl := Impl\n and type t = var\n and type unchecked := t\n\n val one : t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\n\n val scale : t -> Scalar.t -> t\n\n val to_affine_exn : t -> Field.t * Field.t\n end)\n (Message : Message_intf\n with type boolean_var := Impl.Boolean.var\n and type curve_scalar_var := Curve.Scalar.var\n and type curve_scalar := Curve.Scalar.t\n and type curve := Curve.t\n and type curve_var := Curve.var\n and type field := Impl.Field.t\n and type field_var := Impl.Field.Var.t\n and type 'a checked := 'a Impl.Checked.t) :\n S\n with module Impl := Impl\n and type curve := Curve.t\n and type curve_var := Curve.var\n and type curve_scalar := Curve.Scalar.t\n and type curve_scalar_var := Curve.Scalar.var\n and module Shifted := Curve.Checked.Shifted\n and module Message := Message = struct\n open Impl\n\n module Signature = struct\n type t = Field.t * Curve.Scalar.t [@@deriving sexp]\n\n type var = Field.Var.t * Curve.Scalar.var\n\n let typ : (var, t) Typ.t = Typ.tuple2 Field.typ Curve.Scalar.typ\n end\n\n module Private_key = struct\n type t = Curve.Scalar.t [@@deriving sexp]\n end\n\n module Public_key : sig\n type t = Curve.t [@@deriving sexp]\n\n type var = Curve.var\n end =\n Curve\n\n let compress (t : Curve.t) =\n let x, _ = Curve.to_affine_exn t in\n Field.unpack x\n\n let is_even (t : Field.t) = not (Bigint.test_bit (Bigint.of_field t) 0)\n\n let sign ?signature_kind (d_prime : Private_key.t) (m : Message.t) =\n let public_key =\n (* TODO: Don't recompute this. *) Curve.scale Curve.one d_prime\n in\n (* TODO: Once we switch to implicit sign-bit we'll have to conditionally negate d_prime. *)\n let d = d_prime in\n let derive = Message.derive ?signature_kind in\n let k_prime = derive m ~public_key ~private_key:d in\n assert (not Curve.Scalar.(equal k_prime zero)) ;\n let r, ry = Curve.(to_affine_exn (scale Curve.one k_prime)) in\n let k = if is_even ry then k_prime else Curve.Scalar.negate k_prime in\n let hash = Message.hash ?signature_kind in\n let e = hash m ~public_key ~r in\n let s = Curve.Scalar.(k + (e * d)) in\n (r, s)\n\n let verify ?signature_kind ((r, s) : Signature.t) (pk : Public_key.t)\n (m : Message.t) =\n let hash = Message.hash ?signature_kind in\n let e = hash ~public_key:pk ~r m in\n let r_pt = Curve.(scale one s + negate (scale pk e)) in\n match Curve.to_affine_exn r_pt with\n | rx, ry ->\n is_even ry && Field.equal rx r\n | exception _ ->\n false\n\n [%%if call_logger]\n\n let verify s pk m =\n Mina_debug.Call_logger.record_call \"Signature_lib.Schnorr.verify\" ;\n if Random.int 1000 = 0 then (\n print_endline \"SCHNORR BACKTRACE:\" ;\n Printexc.print_backtrace stdout ) ;\n verify s pk m\n\n [%%endif]\n\n module Checked = struct\n let to_bits x =\n Field.Checked.choose_preimage_var x ~length:Field.size_in_bits\n\n let compress ((x, _) : Curve.var) = to_bits x\n\n let is_even y =\n let%map bs = Field.Checked.unpack_full y in\n Bitstring_lib.Bitstring.Lsb_first.to_list bs |> List.hd_exn |> Boolean.not\n\n (* returning r_point as a representable point ensures it is nonzero so the nonzero\n * check does not have to explicitly be performed *)\n\n let%snarkydef_ verifier (type s) ~equal ~final_check\n ((module Shifted) as shifted :\n (module Curve.Checked.Shifted.S with type t = s) )\n ((r, s) : Signature.var) (public_key : Public_key.var) (m : Message.var)\n =\n let%bind e = Message.hash_checked m ~public_key ~r in\n (* s * g - e * public_key *)\n let%bind e_pk =\n Curve.Checked.scale shifted\n (Curve.Checked.negate public_key)\n (Curve.Scalar.Checked.to_bits e)\n ~init:Shifted.zero\n in\n let%bind s_g_e_pk =\n Curve.Checked.scale_known shifted Curve.one\n (Curve.Scalar.Checked.to_bits s)\n ~init:e_pk\n in\n let%bind rx, ry = Shifted.unshift_nonzero s_g_e_pk in\n let%bind y_even = is_even ry in\n let%bind r_correct = equal r rx in\n final_check r_correct y_even\n\n let verifies s =\n verifier ~equal:Field.Checked.equal ~final_check:Boolean.( && ) s\n\n let assert_verifies s =\n verifier ~equal:Field.Checked.Assert.equal\n ~final_check:(fun () ry_even -> Boolean.Assert.is_true ry_even)\n s\n end\nend\n\n[%%else]\n\n(* nonconsensus version of the functor; yes, there's some repeated code,\n but seems difficult to abstract over the functors and signatures\n*)\n\nmodule type S = sig\n open Snark_params.Tick\n\n type curve\n\n type curve_scalar\n\n module Message :\n Message_intf\n with type curve_scalar := curve_scalar\n and type curve := curve\n and type field := Field.t\n\n module Signature : sig\n type t = Field.t * curve_scalar [@@deriving sexp]\n end\n\n module Private_key : sig\n type t = curve_scalar [@@deriving sexp]\n end\n\n module Public_key : sig\n type t = curve [@@deriving sexp]\n end\n\n val sign :\n ?signature_kind:Mina_signature_kind.t\n -> Private_key.t\n -> Message.t\n -> Signature.t\n\n val verify :\n ?signature_kind:Mina_signature_kind.t\n -> Signature.t\n -> Public_key.t\n -> Message.t\n -> bool\nend\n\nmodule Make\n (Impl : module type of Snark_params.Tick) (Curve : sig\n open Impl\n\n module Scalar : sig\n type t [@@deriving sexp, equal]\n\n val zero : t\n\n val ( * ) : t -> t -> t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\n end\n\n type t [@@deriving sexp]\n\n val one : t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\n\n val scale : t -> Scalar.t -> t\n\n val to_affine_exn : t -> Field.t * Field.t\n end)\n (Message : Message_intf\n with type curve := Curve.t\n and type curve_scalar := Curve.Scalar.t\n and type field := Impl.Field.t) :\n S\n with type curve := Curve.t\n and type curve_scalar := Curve.Scalar.t\n and module Message := Message = struct\n module Private_key = struct\n type t = Curve.Scalar.t [@@deriving sexp]\n end\n\n module Signature = struct\n type t = Impl.Field.t * Curve.Scalar.t [@@deriving sexp]\n end\n\n module Public_key : sig\n type t = Curve.t [@@deriving sexp]\n end =\n Curve\n\n let is_even (t : Impl.Field.t) = not @@ Impl.Field.parity t\n\n let sign ?signature_kind (d_prime : Private_key.t) m =\n let public_key =\n (* TODO: Don't recompute this. *)\n Curve.scale Curve.one d_prime\n in\n (* TODO: Once we switch to implicit sign-bit we'll have to conditionally negate d_prime. *)\n let d = d_prime in\n let derive = Message.derive ?signature_kind in\n let k_prime = derive m ~public_key ~private_key:d in\n assert (not Curve.Scalar.(equal k_prime zero)) ;\n let r, (ry : Impl.Field.t) =\n Curve.(to_affine_exn (scale Curve.one k_prime))\n in\n let k = if is_even ry then k_prime else Curve.Scalar.negate k_prime in\n let hash = Message.hash ?signature_kind in\n let e = hash m ~public_key ~r in\n let s = Curve.Scalar.(k + (e * d)) in\n (r, s)\n\n let verify ?signature_kind ((r, s) : Signature.t) (pk : Public_key.t)\n (m : Message.t) =\n let hash = Message.hash ?signature_kind in\n let e = hash ~public_key:pk ~r m in\n let r_pt = Curve.(scale one s + negate (scale pk e)) in\n match Curve.to_affine_exn r_pt with\n | rx, ry ->\n is_even ry && Impl.Field.(equal rx r)\n | exception _ ->\n false\nend\n\n[%%endif]\n\nopen Snark_params\n\nmodule Message = struct\n let network_id_mainnet = String.of_char @@ Char.of_int_exn 1\n\n let network_id_testnet = String.of_char @@ Char.of_int_exn 0\n\n let network_id_other chain_name = chain_name\n\n let network_id =\n match Mina_signature_kind.t with\n | Mainnet ->\n network_id_mainnet\n | Testnet ->\n network_id_testnet\n | Other_network chain_name ->\n network_id_other chain_name\n\n module Legacy = struct\n open Tick\n\n type t = (Field.t, bool) Random_oracle.Input.Legacy.t [@@deriving sexp]\n\n let make_derive ~network_id t ~private_key ~public_key =\n let input =\n let x, y = Tick.Inner_curve.to_affine_exn public_key in\n Random_oracle.Input.Legacy.append t\n { field_elements = [| x; y |]\n ; bitstrings =\n [| Tock.Field.unpack private_key\n ; Fold_lib.Fold.(to_list (string_bits network_id))\n |]\n }\n in\n Random_oracle.Input.Legacy.to_bits ~unpack:Field.unpack input\n |> Array.of_list |> Blake2.bits_to_string |> Blake2.digest_string\n |> Blake2.to_raw_string |> Blake2.string_to_bits |> Array.to_list\n |> Fn.flip List.take (Int.min 256 (Tock.Field.size_in_bits - 1))\n |> Tock.Field.project\n\n let derive ?(signature_kind = Mina_signature_kind.t) =\n make_derive\n ~network_id:\n ( match signature_kind with\n | Mainnet ->\n network_id_mainnet\n | Testnet ->\n network_id_testnet\n | Other_network chain_name ->\n network_id_other chain_name )\n\n let derive_for_mainnet = make_derive ~network_id:network_id_mainnet\n\n let derive_for_testnet = make_derive ~network_id:network_id_testnet\n\n let make_hash ~init t ~public_key ~r =\n let input =\n let px, py = Inner_curve.to_affine_exn public_key in\n Random_oracle.Input.Legacy.append t\n { field_elements = [| px; py; r |]; bitstrings = [||] }\n in\n let open Random_oracle.Legacy in\n hash ~init (pack_input input)\n |> Digest.to_bits ~length:Field.size_in_bits\n |> Inner_curve.Scalar.of_bits\n\n let hash ?signature_kind =\n make_hash ~init:(Hash_prefix_states.signature_legacy ?signature_kind)\n\n let hash_for_mainnet =\n make_hash ~init:Hash_prefix_states.signature_for_mainnet_legacy\n\n let hash_for_testnet =\n make_hash ~init:Hash_prefix_states.signature_for_testnet_legacy\n\n [%%ifdef consensus_mechanism]\n\n type var = (Field.Var.t, Boolean.var) Random_oracle.Input.Legacy.t\n\n let%snarkydef_ hash_checked t ~public_key ~r =\n let input =\n let px, py = public_key in\n Random_oracle.Input.Legacy.append t\n { field_elements = [| px; py; r |]; bitstrings = [||] }\n in\n make_checked (fun () ->\n let open Random_oracle.Legacy.Checked in\n hash\n ~init:(Hash_prefix_states.signature_legacy ?signature_kind:None)\n (pack_input input)\n |> Digest.to_bits ~length:Field.size_in_bits\n |> Bitstring_lib.Bitstring.Lsb_first.of_list )\n\n [%%endif]\n end\n\n module Chunked = struct\n open Tick\n\n type t = Field.t Random_oracle.Input.Chunked.t [@@deriving sexp]\n\n let make_derive ~network_id t ~private_key ~public_key =\n let input =\n let x, y = Tick.Inner_curve.to_affine_exn public_key in\n let id = Fold_lib.Fold.(to_list (string_bits network_id)) in\n Random_oracle.Input.Chunked.append t\n { field_elements =\n [| x; y; Field.project (Tock.Field.unpack private_key) |]\n ; packeds = [| (Field.project id, List.length id) |]\n }\n in\n Array.map (Random_oracle.pack_input input) ~f:Tick.Field.unpack\n |> Array.to_list |> List.concat |> Array.of_list |> Blake2.bits_to_string\n |> Blake2.digest_string |> Blake2.to_raw_string |> Blake2.string_to_bits\n |> Array.to_list\n |> Fn.flip List.take (Int.min 256 (Tock.Field.size_in_bits - 1))\n |> Tock.Field.project\n\n let derive ?(signature_kind = Mina_signature_kind.t) =\n make_derive\n ~network_id:\n ( match signature_kind with\n | Mainnet ->\n network_id_mainnet\n | Testnet ->\n network_id_testnet\n | Other_network chain_name ->\n network_id_other chain_name )\n\n let derive_for_mainnet = make_derive ~network_id:network_id_mainnet\n\n let derive_for_testnet = make_derive ~network_id:network_id_testnet\n\n let make_hash ~init t ~public_key ~r =\n let input =\n let px, py = Inner_curve.to_affine_exn public_key in\n Random_oracle.Input.Chunked.append t\n { field_elements = [| px; py; r |]; packeds = [||] }\n in\n let open Random_oracle in\n hash ~init (pack_input input)\n |> Digest.to_bits ~length:Field.size_in_bits\n |> Inner_curve.Scalar.of_bits\n\n let hash ?signature_kind =\n make_hash ~init:(Hash_prefix_states.signature ?signature_kind)\n\n let hash_for_mainnet =\n make_hash ~init:Hash_prefix_states.signature_for_mainnet\n\n let hash_for_testnet =\n make_hash ~init:Hash_prefix_states.signature_for_testnet\n\n [%%ifdef consensus_mechanism]\n\n type var = Field.Var.t Random_oracle.Input.Chunked.t\n\n let%snarkydef_ hash_checked t ~public_key ~r =\n let input =\n let px, py = public_key in\n Random_oracle.Input.Chunked.append t\n { field_elements = [| px; py; r |]; packeds = [||] }\n in\n make_checked (fun () ->\n let open Random_oracle.Checked in\n hash\n ~init:(Hash_prefix_states.signature ?signature_kind:None)\n (pack_input input)\n |> Digest.to_bits ~length:Field.size_in_bits\n |> Bitstring_lib.Bitstring.Lsb_first.of_list )\n\n [%%endif]\n end\nend\n\nmodule Legacy = Make (Tick) (Tick.Inner_curve) (Message.Legacy)\nmodule Chunked = Make (Tick) (Tick.Inner_curve) (Message.Chunked)\n\n[%%ifdef consensus_mechanism]\n\nlet gen_legacy =\n let open Quickcheck.Let_syntax in\n let%map pk = Private_key.gen and msg = Tick.Field.gen in\n (pk, Random_oracle.Input.Legacy.field_elements [| msg |])\n\nlet gen_chunked =\n let open Quickcheck.Let_syntax in\n let%map pk = Private_key.gen and msg = Tick.Field.gen in\n (pk, Random_oracle.Input.Chunked.field_elements [| msg |])\n\n(* Use for reading only. *)\nlet legacy_message_typ () : (Message.Legacy.var, Message.Legacy.t) Tick.Typ.t =\n let to_hlist { Random_oracle.Input.Legacy.field_elements; bitstrings } =\n H_list.[ field_elements; bitstrings ]\n in\n let of_hlist ([ field_elements; bitstrings ] : (unit, _) H_list.t) =\n { Random_oracle.Input.Legacy.field_elements; bitstrings }\n in\n let open Tick.Typ in\n of_hlistable\n [ array ~length:0 Tick.Field.typ\n ; array ~length:0 (list ~length:0 Tick.Boolean.typ)\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n(* Use for reading only. *)\nlet chunked_message_typ () : (Message.Chunked.var, Message.Chunked.t) Tick.Typ.t\n =\n let open Tick.Typ in\n let const_typ =\n Typ\n { check = (fun _ -> Tick.Checked.return ())\n ; var_to_fields = (fun t -> ([||], t))\n ; var_of_fields = (fun (_, t) -> t)\n ; value_to_fields = (fun t -> ([||], t))\n ; value_of_fields = (fun (_, t) -> t)\n ; size_in_field_elements = 0\n ; constraint_system_auxiliary =\n (fun () -> failwith \"Cannot create constant in constraint-system mode\")\n }\n in\n let to_hlist { Random_oracle.Input.Chunked.field_elements; packeds } =\n H_list.[ field_elements; packeds ]\n in\n let of_hlist ([ field_elements; packeds ] : (unit, _) H_list.t) =\n { Random_oracle.Input.Chunked.field_elements; packeds }\n in\n of_hlistable\n [ array ~length:0 Tick.Field.typ\n ; array ~length:0 (Tick.Field.typ * const_typ)\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\nlet%test_unit \"schnorr checked + unchecked\" =\n Quickcheck.test ~trials:5 gen_legacy ~f:(fun (pk, msg) ->\n let s = Legacy.sign pk msg in\n let pubkey = Tick.Inner_curve.(scale one pk) in\n assert (Legacy.verify s pubkey msg) ;\n (Tick.Test.test_equal ~sexp_of_t:[%sexp_of: bool] ~equal:Bool.equal\n Tick.Typ.(\n tuple3 Tick.Inner_curve.typ (legacy_message_typ ())\n Legacy.Signature.typ)\n Tick.Boolean.typ\n (fun (public_key, msg, s) ->\n let open Tick.Checked in\n let%bind (module Shifted) =\n Tick.Inner_curve.Checked.Shifted.create ()\n in\n Legacy.Checked.verifies (module Shifted) s public_key msg )\n (fun _ -> true) )\n (pubkey, msg, s) )\n\nlet%test_unit \"schnorr checked + unchecked\" =\n Quickcheck.test ~trials:5 gen_chunked ~f:(fun (pk, msg) ->\n let s = Chunked.sign pk msg in\n let pubkey = Tick.Inner_curve.(scale one pk) in\n assert (Chunked.verify s pubkey msg) ;\n (Tick.Test.test_equal ~sexp_of_t:[%sexp_of: bool] ~equal:Bool.equal\n Tick.Typ.(\n tuple3 Tick.Inner_curve.typ (chunked_message_typ ())\n Chunked.Signature.typ)\n Tick.Boolean.typ\n (fun (public_key, msg, s) ->\n let open Tick.Checked in\n let%bind (module Shifted) =\n Tick.Inner_curve.Checked.Shifted.create ()\n in\n Chunked.Checked.verifies (module Shifted) s public_key msg )\n (fun _ -> true) )\n (pubkey, msg, s) )\n\n[%%endif]\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t =\n { public_key : Public_key.Stable.V1.t\n ; private_key : (Private_key.Stable.V1.t[@sexp.opaque])\n }\n [@@deriving sexp]\n\n let to_latest = Fn.id\n\n let to_yojson t = Public_key.Stable.V1.to_yojson t.public_key\n end\nend]\n\nmodule T = struct\n type t = Stable.Latest.t =\n { public_key : Public_key.t; private_key : (Private_key.t[@sexp.opaque]) }\n [@@deriving sexp]\n\n let compare { public_key = pk1; private_key = _ }\n { public_key = pk2; private_key = _ } =\n Public_key.compare pk1 pk2\n\n let to_yojson = Stable.Latest.to_yojson\nend\n\ninclude T\ninclude Comparable.Make (T)\n\nlet of_private_key_exn private_key =\n let public_key = Public_key.of_private_key_exn private_key in\n { public_key; private_key }\n\nlet create () = of_private_key_exn (Private_key.create ())\n\nlet gen = Quickcheck.Generator.(map ~f:of_private_key_exn Private_key.gen)\n\nmodule And_compressed_pk = struct\n module T = struct\n type t = T.t * Public_key.Compressed.t [@@deriving sexp]\n\n let compare ({ public_key = pk1; private_key = _ }, _)\n ({ public_key = pk2; private_key = _ }, _) =\n Public_key.compare pk1 pk2\n end\n\n include T\n include Comparable.Make (T)\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = Sgn_type.Sgn.Stable.V1.t = Pos | Neg\n [@@deriving sexp, hash, compare, equal, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\nlet gen =\n Quickcheck.Generator.map Bool.quickcheck_generator ~f:(fun b ->\n if b then Pos else Neg )\n\nlet negate = function Pos -> Neg | Neg -> Pos\n\nlet neg_one = Field.(negate one)\n\nlet to_field = function Pos -> Field.one | Neg -> neg_one\n\nlet of_field_exn x =\n if Field.equal x Field.one then Pos\n else if Field.equal x neg_one then Neg\n else failwith \"Sgn.of_field: Expected positive or negative 1\"\n\n[%%ifdef consensus_mechanism]\n\ntype var = Field.Var.t\n\nlet typ : (var, t) Typ.t =\n let open Typ in\n Typ\n { check = (fun x -> assert_r1cs x x (Field.Var.constant Field.one))\n ; var_to_fields = (fun t -> ([| t |], ()))\n ; var_of_fields = (fun (ts, ()) -> ts.(0))\n ; value_to_fields = (fun t -> ([| to_field t |], ()))\n ; value_of_fields = (fun (ts, ()) -> of_field_exn ts.(0))\n ; size_in_field_elements = 1\n ; constraint_system_auxiliary = (fun () -> ())\n }\n\nmodule Checked = struct\n let two = Field.of_int 2\n\n let neg_two = Field.negate two\n\n let one_half = Field.inv two\n\n let neg_one_half = Field.negate one_half\n\n let is_pos (v : var) =\n Boolean.Unsafe.of_cvar\n (let open Field.Checked in\n one_half * (v + Field.Var.constant Field.one))\n\n let is_neg (v : var) =\n Boolean.Unsafe.of_cvar\n (let open Field.Checked in\n neg_one_half * (v - Field.Var.constant Field.one))\n\n let pos_if_true (b : Boolean.var) =\n let open Field.Checked in\n (two * (b :> Field.Var.t)) - Field.Var.constant Field.one\n\n let neg_if_true (b : Boolean.var) =\n let open Field.Checked in\n (neg_two * (b :> Field.Var.t)) + Field.Var.constant Field.one\n\n let negate t = Field.Var.scale t neg_one\n\n let constant = Fn.compose Field.Var.constant to_field\n\n let neg = constant Neg\n\n let pos = constant Pos\n\n let if_ = Field.Checked.if_\nend\n\n[%%endif]\n","open Core_kernel\n\nmodule Tree = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type ('hash, 'account) t =\n | Account of 'account\n | Hash of 'hash\n | Node of 'hash * ('hash, 'account) t * ('hash, 'account) t\n [@@deriving equal, sexp, yojson]\n\n let rec to_latest acct_to_latest = function\n | Account acct ->\n Account (acct_to_latest acct)\n | Hash hash ->\n Hash hash\n | Node (hash, l, r) ->\n Node (hash, to_latest acct_to_latest l, to_latest acct_to_latest r)\n end\n end]\n\n type ('hash, 'account) t = ('hash, 'account) Stable.Latest.t =\n | Account of 'account\n | Hash of 'hash\n | Node of 'hash * ('hash, 'account) t * ('hash, 'account) t\n [@@deriving equal, sexp, yojson]\nend\n\nmodule T = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type ('hash, 'key, 'account) t =\n { indexes : ('key * int) list\n ; depth : int\n ; tree : ('hash, 'account) Tree.Stable.V1.t\n }\n [@@deriving sexp, yojson]\n end\n end]\n\n type ('hash, 'key, 'account) t = ('hash, 'key, 'account) Stable.Latest.t =\n { indexes : ('key * int) list\n ; depth : int\n ; tree : ('hash, 'account) Tree.t\n }\n [@@deriving sexp, yojson]\nend\n\nmodule type S = sig\n type hash\n\n type account_id\n\n type account\n\n type t = (hash, account_id, account) T.t [@@deriving sexp, yojson]\n\n val of_hash : depth:int -> hash -> t\n\n val get_exn : t -> int -> account\n\n val path_exn : t -> int -> [ `Left of hash | `Right of hash ] list\n\n val set_exn : t -> int -> account -> t\n\n val find_index_exn : t -> account_id -> int\n\n val add_path :\n t -> [ `Left of hash | `Right of hash ] list -> account_id -> account -> t\n\n val iteri : t -> f:(int -> account -> unit) -> unit\n\n val merkle_root : t -> hash\n\n val depth : t -> int\nend\n\nlet tree { T.tree; _ } = tree\n\nlet of_hash ~depth h = { T.indexes = []; depth; tree = Hash h }\n\nmodule Make (Hash : sig\n type t [@@deriving equal, sexp, yojson, compare]\n\n val merge : height:int -> t -> t -> t\nend) (Account_id : sig\n type t [@@deriving equal, sexp, yojson]\nend) (Account : sig\n type t [@@deriving equal, sexp, yojson]\n\n val data_hash : t -> Hash.t\nend) : sig\n include\n S\n with type hash := Hash.t\n and type account_id := Account_id.t\n and type account := Account.t\n\n val hash : (Hash.t, Account.t) Tree.t -> Hash.t\nend = struct\n type t = (Hash.t, Account_id.t, Account.t) T.t [@@deriving sexp, yojson]\n\n let of_hash ~depth (hash : Hash.t) = of_hash ~depth hash\n\n let hash : (Hash.t, Account.t) Tree.t -> Hash.t = function\n | Account a ->\n Account.data_hash a\n | Hash h ->\n h\n | Node (h, _, _) ->\n h\n\n type index = int [@@deriving sexp, yojson]\n\n let depth { T.depth; _ } = depth\n\n let merkle_root { T.tree; _ } = hash tree\n\n let add_path depth0 tree0 path0 account =\n let rec build_tree height p =\n match p with\n | `Left h_r :: path ->\n let l = build_tree (height - 1) path in\n Tree.Node (Hash.merge ~height (hash l) h_r, l, Hash h_r)\n | `Right h_l :: path ->\n let r = build_tree (height - 1) path in\n Node (Hash.merge ~height h_l (hash r), Hash h_l, r)\n | [] ->\n assert (height = -1) ;\n Account account\n in\n let rec union height tree path =\n match (tree, path) with\n | Tree.Hash h, path ->\n let t = build_tree height path in\n [%test_result: Hash.t]\n ~message:\n \"Hashes in union are not equal, something is wrong with your \\\n ledger\"\n ~expect:h (hash t) ;\n t\n | Node (h, l, r), `Left h_r :: path ->\n assert (Hash.equal h_r (hash r)) ;\n let l = union (height - 1) l path in\n Node (h, l, r)\n | Node (h, l, r), `Right h_l :: path ->\n assert (Hash.equal h_l (hash l)) ;\n let r = union (height - 1) r path in\n Node (h, l, r)\n | Node _, [] ->\n failwith \"Path too short\"\n | Account _, _ :: _ ->\n failwith \"Path too long\"\n | Account a, [] ->\n assert (Account.equal a account) ;\n tree\n in\n union (depth0 - 1) tree0 (List.rev path0)\n\n let add_path (t : t) path account_id account =\n let index =\n List.foldi path ~init:0 ~f:(fun i acc x ->\n match x with `Right _ -> acc + (1 lsl i) | `Left _ -> acc )\n in\n { t with\n tree = add_path t.depth t.tree path account\n ; indexes = (account_id, index) :: t.indexes\n }\n\n let iteri (t : t) ~f =\n let rec go acc i tree ~f =\n match tree with\n | Tree.Account a ->\n f acc a\n | Hash _ ->\n ()\n | Node (_, l, r) ->\n go acc (i - 1) l ~f ;\n go (acc + (1 lsl i)) (i - 1) r ~f\n in\n go 0 (t.depth - 1) t.tree ~f\n\n let ith_bit idx i = (idx lsr i) land 1 = 1\n\n let find_index_exn (t : t) aid =\n match List.Assoc.find t.indexes ~equal:Account_id.equal aid with\n | Some x ->\n x\n | None ->\n failwithf\n !\"Sparse_ledger.find_index_exn: %{sexp:Account_id.t} not in %{sexp: \\\n Account_id.t list}\"\n aid\n (List.map t.indexes ~f:fst)\n ()\n\n let get_exn ({ T.tree; depth; _ } as t) idx =\n let rec go i tree =\n match (i < 0, tree) with\n | true, Tree.Account acct ->\n acct\n | false, Node (_, l, r) ->\n let go_right = ith_bit idx i in\n if go_right then go (i - 1) r else go (i - 1) l\n | _ ->\n let expected_kind = if i < 0 then \"n account\" else \" node\" in\n let kind =\n match tree with\n | Account _ ->\n \"n account\"\n | Hash _ ->\n \" hash\"\n | Node _ ->\n \" node\"\n in\n failwithf\n !\"Sparse_ledger.get: Bad index %i. Expected a%s, but got a%s at \\\n depth %i. Tree = %{sexp:t}, tree_depth = %d\"\n idx expected_kind kind (depth - i) t depth ()\n in\n go (depth - 1) tree\n\n let set_exn (t : t) idx acct =\n let rec go i tree =\n match (i < 0, tree) with\n | true, Tree.Account _ ->\n Tree.Account acct\n | false, Node (_, l, r) ->\n let l, r =\n let go_right = ith_bit idx i in\n if go_right then (l, go (i - 1) r) else (go (i - 1) l, r)\n in\n Node (Hash.merge ~height:i (hash l) (hash r), l, r)\n | _ ->\n let expected_kind = if i < 0 then \"n account\" else \" node\" in\n let kind =\n match tree with\n | Account _ ->\n \"n account\"\n | Hash _ ->\n \" hash\"\n | Node _ ->\n \" node\"\n in\n failwithf\n \"Sparse_ledger.set: Bad index %i. Expected a%s, but got a%s at \\\n depth %i.\"\n idx expected_kind kind (t.depth - i) ()\n in\n { t with tree = go (t.depth - 1) t.tree }\n\n let path_exn { T.tree; depth; _ } idx =\n let rec go acc i tree =\n if i < 0 then acc\n else\n match tree with\n | Tree.Account _ ->\n failwithf \"Sparse_ledger.path: Bad depth at index %i.\" idx ()\n | Hash _ ->\n failwithf \"Sparse_ledger.path: Dead end at index %i.\" idx ()\n | Node (_, l, r) ->\n let go_right = ith_bit idx i in\n if go_right then go (`Right (hash l) :: acc) (i - 1) r\n else go (`Left (hash r) :: acc) (i - 1) l\n in\n go [] (depth - 1) tree\nend\n\ntype ('hash, 'key, 'account) t = ('hash, 'key, 'account) T.t [@@deriving yojson]\n\nlet%test_module \"sparse-ledger-test\" =\n ( module struct\n module Hash = struct\n type t = Core_kernel.Md5.t [@@deriving sexp, compare]\n\n let equal h1 h2 = Int.equal (compare h1 h2) 0\n\n let to_yojson md5 = `String (Core_kernel.Md5.to_hex md5)\n\n let of_yojson = function\n | `String x ->\n Or_error.try_with (fun () -> Core_kernel.Md5.of_hex_exn x)\n |> Result.map_error ~f:Error.to_string_hum\n | _ ->\n Error \"Expected a hex-encoded MD5 hash\"\n\n let merge ~height x y =\n let open Md5 in\n digest_string\n (sprintf \"sparse-ledger_%03d\" height ^ to_binary x ^ to_binary y)\n\n let gen =\n Quickcheck.Generator.map String.quickcheck_generator\n ~f:Md5.digest_string\n end\n\n module Account = struct\n module T = struct\n type t = { name : string; favorite_number : int }\n [@@deriving bin_io, equal, sexp, yojson]\n end\n\n include T\n\n let key { name; _ } = name\n\n let data_hash t = Md5.digest_string (Binable.to_string (module T) t)\n\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%map name = String.quickcheck_generator\n and favorite_number = Int.quickcheck_generator in\n { name; favorite_number }\n end\n\n module Account_id = struct\n type t = string [@@deriving sexp, equal, yojson]\n end\n\n include Make (Hash) (Account_id) (Account)\n\n let gen =\n let open Quickcheck.Generator in\n let open Let_syntax in\n let indexes max_depth t =\n let rec go addr d = function\n | Tree.Account a ->\n [ (Account.key a, addr) ]\n | Hash _ ->\n []\n | Node (_, l, r) ->\n go addr (d - 1) l @ go (addr lor (1 lsl d)) (d - 1) r\n in\n go 0 (max_depth - 1) t\n in\n let rec prune_hash_branches = function\n | Tree.Hash h ->\n Tree.Hash h\n | Account a ->\n Account a\n | Node (h, l, r) -> (\n match (prune_hash_branches l, prune_hash_branches r) with\n | Hash _, Hash _ ->\n Hash h\n | l, r ->\n Node (h, l, r) )\n in\n let rec gen depth =\n if depth = 0 then Account.gen >>| fun a -> Tree.Account a\n else\n let t =\n let sub = gen (depth - 1) in\n let%map l = sub and r = sub in\n Tree.Node (Hash.merge ~height:(depth - 1) (hash l) (hash r), l, r)\n in\n weighted_union\n [ (1. /. 3., Hash.gen >>| fun h -> Tree.Hash h); (2. /. 3., t) ]\n in\n let%bind depth = Int.gen_incl 0 16 in\n let%map tree = gen depth >>| prune_hash_branches in\n { T.tree; depth; indexes = indexes depth tree }\n\n let%test_unit \"iteri consistent indices with t.indexes\" =\n Quickcheck.test gen ~f:(fun t ->\n let indexes = Int.Set.of_list (t.indexes |> List.map ~f:snd) in\n iteri t ~f:(fun i _ ->\n [%test_result: bool]\n ~message:\n \"Iteri index should be contained in the indexes auxillary \\\n structure\"\n ~expect:true (Int.Set.mem indexes i) ) )\n\n let%test_unit \"path_test\" =\n Quickcheck.test gen ~f:(fun t ->\n let root = { t with indexes = []; tree = Hash (merkle_root t) } in\n let t' =\n List.fold t.indexes ~init:root ~f:(fun acc (_, index) ->\n let account = get_exn t index in\n add_path acc (path_exn t index) (Account.key account) account )\n in\n assert (Tree.equal Hash.equal Account.equal t'.tree t.tree) )\n end )\n","(* coding.ml -- hex encoding/decoding for Rosetta *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nmodule Field = Snark_params.Tick.Field\nmodule Scalar = Snark_params.Tick.Inner_curve.Scalar\nopen Signature_lib\n\n(* see RFC 0038, section \"marshal-keys\" for a specification *)\n\nlet hex_char_to_bits4 = function\n | '0' ->\n [ false; false; false; false ]\n | '1' ->\n [ false; false; false; true ]\n | '2' ->\n [ false; false; true; false ]\n | '3' ->\n [ false; false; true; true ]\n | '4' ->\n [ false; true; false; false ]\n | '5' ->\n [ false; true; false; true ]\n | '6' ->\n [ false; true; true; false ]\n | '7' ->\n [ false; true; true; true ]\n | '8' ->\n [ true; false; false; false ]\n | '9' ->\n [ true; false; false; true ]\n | 'A' | 'a' ->\n [ true; false; true; false ]\n | 'B' | 'b' ->\n [ true; false; true; true ]\n | 'C' | 'c' ->\n [ true; true; false; false ]\n | 'D' | 'd' ->\n [ true; true; false; true ]\n | 'E' | 'e' ->\n [ true; true; true; false ]\n | 'F' | 'f' ->\n [ true; true; true; true ]\n | _ ->\n failwith \"Expected hex character\"\n\nlet bits4_to_hex_char bits =\n List.mapi bits ~f:(fun i bit -> if bit then Int.pow 2 (3 - i) else 0)\n |> List.fold ~init:0 ~f:( + )\n |> fun n ->\n let s = sprintf \"%0X\" n in\n s.[0]\n\nmodule type Packed = sig\n type t\n\n val unpack : t -> bool list\nend\n\n(* break of the bits byte by byte *)\nlet bits_by_n n bits =\n let rec go bits acc =\n if List.is_empty bits then List.rev acc\n else\n let bitsn, rest = List.split_n bits n in\n go rest (bitsn :: acc)\n in\n go bits []\n\nlet bits_by_4s = bits_by_n 4\n\nlet bits_by_8s = bits_by_n 8\n\nlet of_unpackable (type t) (module M : Packed with type t = t)\n ?(padding_bit = false) (packed : t) =\n let bits0 = M.unpack packed |> List.rev in\n assert (Mina_stdlib.List.Length.Compare.(bits0 = 255)) ;\n (* field elements, scalars are 255 bits, left-pad to get 32 bytes *)\n let bits = padding_bit :: bits0 in\n (* break of the bits byte by byte *)\n (* In our encoding, we want highest bytes at the end and lowest at the\n beginning. *)\n let bytes = bits_by_8s bits in\n let bytes' = List.rev bytes in\n let bits' = List.concat bytes' in\n let cs = List.map (bits_by_4s bits') ~f:bits4_to_hex_char in\n String.of_char_list cs\n\nlet of_field = of_unpackable (module Field)\n\nlet of_scalar = of_unpackable (module Scalar)\n\nmodule type Unpacked = sig\n type t\n\n val project : bool list -> t\nend\n\nlet pack (type t) (module M : Unpacked with type t = t) (raw : string) :\n bool * t =\n (* 256 bits = 64 hex chars *)\n assert (Int.equal (String.length raw) 64) ;\n let bits =\n String.to_list raw |> List.map ~f:hex_char_to_bits4 |> List.concat\n in\n (* In our encoding, we have highest bytes at the end and lowest at the\n beginning. *)\n let bytes = bits_by_8s bits in\n let bytes_rev = List.rev bytes in\n let bits' = List.concat bytes_rev in\n\n let padding_bit = List.hd_exn bits' in\n (* remove padding bit *)\n let bits'' = List.tl_exn bits' |> List.rev in\n (padding_bit, M.project bits'')\n\nlet to_field hex = pack (module Field) hex |> snd\n\nlet to_scalar hex = pack (module Scalar) hex |> snd\n\nlet of_public_key_compressed pk =\n let { Public_key.Compressed.Poly.x; is_odd } = pk in\n of_field ~padding_bit:is_odd x\n\nlet of_public_key pk = of_public_key_compressed (Public_key.compress pk)\n\nlet to_public_key_compressed raw =\n let is_odd, x = pack (module Field) raw in\n { Public_key.Compressed.Poly.x; is_odd }\n\nlet to_public_key raw =\n to_public_key_compressed raw |> Public_key.decompress_exn\n\n(* inline tests hard-to-impossible to setup with JS *)\n\nlet field_hex_roundtrip_test () =\n let field0 = Field.of_int 123123 in\n let hex = of_field field0 in\n let field1 = to_field hex in\n Field.equal field0 field1\n\nlet pk_roundtrip_test () =\n let pk =\n { Public_key.Compressed.Poly.x = Field.of_int 123123; is_odd = true }\n in\n let hex = of_public_key_compressed pk in\n let pk' = to_public_key_compressed hex in\n Public_key.Compressed.equal pk pk'\n\nlet hex_key_odd =\n \"fad1d3e31aede102793fb2cce62b4f1e71a214c94ce18ad5756eba67ef398390\"\n\nlet hex_key_even =\n \"7e406ca640115a8c44ece6ef5d0c56af343b1a993d8c871648ab7980ecaf8230\"\n\nlet pk_compressed_roundtrip_test hex_key () =\n let pk = to_public_key hex_key in\n let hex' = of_public_key pk in\n String.equal (String.lowercase hex_key) (String.lowercase hex')\n\nlet%test \"field_hex round-trip\" = field_hex_roundtrip_test ()\n\nlet%test \"public key round-trip\" = pk_roundtrip_test ()\n\nlet%test \"public key compressed roundtrip odd\" =\n pk_compressed_roundtrip_test hex_key_odd ()\n\nlet%test \"public key compressed roundtrip even\" =\n pk_compressed_roundtrip_test hex_key_even ()\n\n(* for running tests from JS *)\n\nlet unit_tests =\n [ (\"field-hex round-trip\", field_hex_roundtrip_test)\n ; (\"public key round-trip\", pk_roundtrip_test)\n ; ( \"public key compressed round-trip odd\"\n , pk_compressed_roundtrip_test hex_key_odd )\n ; ( \"public key compressed round-trip even\"\n , pk_compressed_roundtrip_test hex_key_even )\n ]\n\nlet run_unit_tests () =\n List.iter unit_tests ~f:(fun (name, test) ->\n printf \"Running %s test\\n%!\" name ;\n assert (test ()) )\n","(* deriving.ml -- deriving ppx for Dhall types *)\n\n(* TODO:\n deriver for signatures\n default values in records\n*)\n\nopen Core_kernel\nopen Ppxlib\n\nlet deriver = \"dhall_type\"\n\nlet field_key_attr =\n Attribute.declare (deriver ^ \".key\") Attribute.Context.Label_declaration\n Ast_pattern.(single_expr_payload (estring __))\n Fn.id\n\nlet make_lident_cmp items lident =\n List.mem items (Longident.name lident.txt) ~equal:String.equal\n\nlet is_bool_lident = make_lident_cmp [ \"bool\"; \"Bool.t\" ]\n\nlet is_int_lident = make_lident_cmp [ \"int\"; \"Int.t\" ]\n\nlet is_float_lident = make_lident_cmp [ \"float\"; \"Float.t\" ]\n\nlet is_string_lident = make_lident_cmp [ \"string\"; \"String.t\" ]\n\nlet is_option_lident = make_lident_cmp [ \"option\"; \"Option.t\" ]\n\nlet is_list_lident = make_lident_cmp [ \"list\"; \"List.t\" ]\n\nlet rec dhall_type_of_core_type core_type =\n let (module Ast_builder) = Ast_builder.make core_type.ptyp_loc in\n let open Ast_builder in\n match core_type.ptyp_desc with\n | Ptyp_constr (lident, []) when is_bool_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.Bool]\n | Ptyp_constr (lident, []) when is_int_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.Integer]\n | Ptyp_constr (lident, []) when is_float_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.Double]\n | Ptyp_constr (lident, []) when is_string_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.Text]\n | Ptyp_constr (lident, [ ty ]) when is_option_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.Optional [%e dhall_type_of_core_type ty]]\n | Ptyp_constr (lident, [ ty ]) when is_list_lident lident ->\n [%expr Ppx_dhall_type.Dhall_type.List [%e dhall_type_of_core_type ty]]\n | Ptyp_constr ({ txt = Lident id; _ }, []) ->\n evar (id ^ \"_dhall_type\")\n | Ptyp_constr ({ txt = Lident id; _ }, params) ->\n let dhall_type_fun = evar (id ^ \"_dhall_type\") in\n let args = List.map params ~f:dhall_type_of_core_type in\n eapply dhall_type_fun args\n | Ptyp_constr ({ txt = Ldot (prefix, nm); _ }, []) ->\n let mod_path = Longident.name prefix in\n if String.equal nm \"t\" then evar (mod_path ^ \".dhall_type\")\n else evar (mod_path ^ \".\" ^ nm ^ \"_dhall_type\")\n | Ptyp_constr ({ txt = Ldot (prefix, nm); _ }, params) ->\n let mod_path = Longident.name prefix in\n let dhall_type_fun =\n if String.equal nm \"t\" then evar (mod_path ^ \".dhall_type\")\n else evar (mod_path ^ \".\" ^ nm ^ \"_dhall_type\")\n in\n let args = List.map params ~f:dhall_type_of_core_type in\n eapply dhall_type_fun args\n | Ptyp_var a ->\n evar a\n | _ ->\n Location.raise_errorf ~loc:core_type.ptyp_loc \"Unsupported type\"\n\nlet dhall_variant_from_constructor_declaration ctor_decl =\n let (module Ast_builder) = Ast_builder.make ctor_decl.pcd_name.loc in\n let open Ast_builder in\n let name = estring @@ String.lowercase ctor_decl.pcd_name.txt in\n match ctor_decl.pcd_args with\n | Pcstr_tuple [] ->\n [%expr [%e name], None]\n | Pcstr_tuple [ ty ] ->\n [%expr [%e name], Some [%e dhall_type_of_core_type ty]]\n | Pcstr_tuple tys ->\n let tys_expr = elist (List.map tys ~f:dhall_type_of_core_type) in\n [%expr [%e name], Some (List [%e tys_expr])]\n | Pcstr_record _ ->\n Location.raise_errorf ~loc:ctor_decl.pcd_name.loc\n \"Records not yet supported\"\n\nlet dhall_field_from_label_declaration label_decl =\n let (module Ast_builder) = Ast_builder.make label_decl.pld_name.loc in\n let open Ast_builder in\n let name =\n match Attribute.get field_key_attr label_decl with\n | Some name ->\n estring name\n | None ->\n estring label_decl.pld_name.txt\n in\n let ty = dhall_type_of_core_type label_decl.pld_type in\n [%expr [%e name], [%e ty]]\n\nlet generate_dhall_type type_decl =\n let (module Ast_builder) = Ast_builder.make type_decl.ptype_loc in\n let open Ast_builder in\n let dhall_type =\n match type_decl.ptype_kind with\n | Ptype_abstract -> (\n match type_decl.ptype_manifest with\n | None ->\n Location.raise_errorf ~loc:type_decl.ptype_loc\n \"Abstract type declaration has no manifest (right-hand side)\"\n | Some core_type ->\n dhall_type_of_core_type core_type )\n | Ptype_variant ctor_decls ->\n [%expr\n Ppx_dhall_type.Dhall_type.Union\n [%e\n elist\n (List.map ctor_decls\n ~f:dhall_variant_from_constructor_declaration )]]\n | Ptype_record label_decls ->\n [%expr\n Ppx_dhall_type.Dhall_type.Record\n [%e\n elist (List.map label_decls ~f:dhall_field_from_label_declaration)]]\n | Ptype_open ->\n Location.raise_errorf ~loc:type_decl.ptype_loc\n \"Open types not supported\"\n in\n let ty_name =\n match type_decl.ptype_name.txt with\n | \"t\" ->\n pvar \"dhall_type\"\n | nm ->\n pvar (nm ^ \"_dhall_type\")\n in\n match type_decl.ptype_params with\n | [] ->\n [%stri let [%p ty_name] = [%e dhall_type]]\n | params ->\n let args =\n List.map params ~f:(fun (core_type, _variance) ->\n match core_type.ptyp_desc with\n | Ptyp_var a ->\n pvar a\n | _ ->\n Location.raise_errorf ~loc:type_decl.ptype_loc\n \"Type parameter not a type variable\" )\n in\n let abs = eabstract args dhall_type in\n [%stri let [%p ty_name] = [%e abs]]\n\nlet generate_dhall_types ~loc:_ ~path:_ (_rec_flag, type_decls) =\n List.map type_decls ~f:generate_dhall_type\n\nlet attributes = [ Attribute.T field_key_attr ]\n\nlet str_type_decl =\n Deriving.Generator.make_noarg ~attributes generate_dhall_types\n\nlet () = Deriving.add deriver ~str_type_decl |> Ppxlib.Deriving.ignore\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type ('magnitude, 'sgn) t =\n ('magnitude, 'sgn) Mina_wire_types.Signed_poly.V1.t =\n { magnitude : 'magnitude; sgn : 'sgn }\n [@@deriving annot, sexp, hash, compare, equal, yojson, fields]\n end\nend]\n\nlet map ~f { magnitude; sgn } = { magnitude = f magnitude; sgn }\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_bits\nopen Snark_params\nopen Tick\n\n[%%ifdef consensus_mechanism]\n\nopen Bitstring_lib\nopen Let_syntax\n\n[%%endif]\n\nopen Intf\n\n(** [Currency_oveflow] is being thrown to signal an overflow\n or underflow during conversions from [int] to currency.\n The exception contains the [int] value that caused the\n misbehaviour. *)\nexception Currency_overflow of int\n\ntype uint64 = Unsigned.uint64\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Currency\n\n(** Define the expected full signature of the module, based on the types defined\n in {!Mina_wire_types} *)\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Intf.Full\n (* full interface defined in a separate file, as it would appear\n in the MLI *)\n with type Fee.Stable.V1.t = A.Fee.V1.t\n (* with added type equalities *)\n and type Amount.Stable.V1.t = A.Amount.V1.t\n and type Balance.Stable.V1.t = A.Balance.V1.t\nend\n\n(** Then we make the real module, which has to have a signature of type\n {!Make_sig(A)}. Here, since all types are simple type aliases, we don't need\n to use [A] in the implementation. Otherwise, we would need to add type\n equalities to the corresponding type in [A] in each type definition. *)\nmodule Make_str (A : Wire_types.Concrete) = struct\n module Signed_poly = Signed_poly\n\n [%%ifdef consensus_mechanism]\n\n module Signed_var = struct\n type 'mag repr = ('mag, Sgn.var) Signed_poly.t\n\n (* Invariant: At least one of these is Some *)\n type nonrec 'mag t =\n { repr : 'mag repr; mutable value : Field.Var.t option }\n end\n\n [%%endif]\n\n module Make (Unsigned : sig\n include Unsigned_extended.S\n\n val to_uint64 : t -> uint64\n\n val of_uint64 : uint64 -> t\n end) (M : sig\n val length : int\n end) : sig\n [%%ifdef consensus_mechanism]\n\n include\n S\n with type t = Unsigned.t\n and type var = Field.Var.t\n and type Signed.var = Field.Var.t Signed_var.t\n and type Signed.signed_fee = (Unsigned.t, Sgn.t) Signed_poly.t\n and type Signed.Checked.signed_fee_var = Field.Var.t Signed_var.t\n\n val pack_var : var -> Field.Var.t\n\n [%%else]\n\n include\n S\n with type t = Unsigned.t\n and type Signed.signed_fee := (Unsigned.t, Sgn.t) Signed_poly.t\n\n [%%endif]\n\n val scale : t -> int -> t option\n end = struct\n let max_int = Unsigned.max_int\n\n let length_in_bits = M.length\n\n type t = Unsigned.t [@@deriving sexp, compare, hash]\n\n (* can't be automatically derived *)\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n\n [%%define_locally\n Unsigned.(to_uint64, of_uint64, of_int, to_int, of_string, to_string)]\n\n let precision = 9\n\n let precision_exp = Unsigned.of_int @@ Int.pow 10 precision\n\n let to_mina_string amount =\n let rec go num_stripped_zeros num =\n let open Int in\n if num mod 10 = 0 && num <> 0 then go (num_stripped_zeros + 1) (num / 10)\n else (num_stripped_zeros, num)\n in\n\n let whole = Unsigned.div amount precision_exp in\n let remainder = Unsigned.to_int (Unsigned.rem amount precision_exp) in\n if Int.(remainder = 0) then to_string whole\n else\n let num_stripped_zeros, num = go 0 remainder in\n Printf.sprintf \"%s.%0*d\" (to_string whole)\n Int.(precision - num_stripped_zeros)\n num\n\n let of_mina_string_exn input =\n let parts = String.split ~on:'.' input in\n match parts with\n | [ whole ] ->\n of_string (whole ^ String.make precision '0')\n | [ whole; decimal ] ->\n let decimal_length = String.length decimal in\n if Int.(decimal_length > precision) then\n of_string (whole ^ String.sub decimal ~pos:0 ~len:precision)\n else\n of_string\n ( whole ^ decimal\n ^ String.make Int.(precision - decimal_length) '0' )\n | _ ->\n failwith \"Currency.of_mina_string_exn: Invalid currency input\"\n\n module Arg = struct\n type typ = t [@@deriving sexp, hash, compare]\n\n type t = typ [@@deriving sexp, hash, compare]\n\n let to_string = to_mina_string\n\n let of_string = of_mina_string_exn\n end\n\n include Codable.Make_of_string (Arg)\n include Hashable.Make (Arg)\n include Comparable.Make (Arg)\n\n let gen_incl a b : t Quickcheck.Generator.t =\n let a = Bignum_bigint.of_string Unsigned.(to_string a) in\n let b = Bignum_bigint.of_string Unsigned.(to_string b) in\n Quickcheck.Generator.map\n Bignum_bigint.(gen_incl a b)\n ~f:(fun n -> of_string (Bignum_bigint.to_string n))\n\n let gen : t Quickcheck.Generator.t =\n let m = Bignum_bigint.of_string Unsigned.(to_string max_int) in\n Quickcheck.Generator.map\n Bignum_bigint.(gen_incl zero m)\n ~f:(fun n -> of_string (Bignum_bigint.to_string n))\n\n module Vector = struct\n include M\n include Unsigned\n\n let empty = zero\n\n let get t i = Infix.((t lsr i) land one = one)\n\n let set v i b =\n if b then Infix.(v lor (one lsl i))\n else Infix.(v land lognot (one lsl i))\n end\n\n module B = Bits.Vector.Make (Vector)\n\n include (B : Bits_intf.Convertible_bits with type t := t)\n\n [%%ifdef consensus_mechanism]\n\n type var = Field.Var.t\n\n let pack_var = Fn.id\n\n let equal_var = Field.Checked.equal\n\n let m = Snark_params.Tick.m\n\n let make_checked = Snark_params.Tick.make_checked\n\n let var_to_bits_ (t : var) = Field.Checked.unpack ~length:length_in_bits t\n\n let var_to_bits t = var_to_bits_ t >>| Bitstring.Lsb_first.of_list\n\n let var_to_input (t : var) =\n Random_oracle.Input.Chunked.packed (t, length_in_bits)\n\n let var_to_input_legacy (t : var) =\n var_to_bits_ t >>| Random_oracle.Input.Legacy.bitstring\n\n let var_of_t (t : t) : var = Field.Var.constant (Field.project (to_bits t))\n\n let if_ cond ~then_ ~else_ : var Checked.t =\n Field.Checked.if_ cond ~then_ ~else_\n\n let () = assert (Int.(length_in_bits mod 16 = 0))\n\n (** UNSAFE. Take the field element formed by the final [length_in_bits] bits\n of the argument.\n\n WARNING: The returned value may be chosen arbitrarily by a malicious\n prover, and this is really only useful for the more-efficient bit\n projection. Users of this function must manually assert the relationship\n between the argument and the return value, or the circuit will be\n underconstrained.\n *)\n let image_from_bits_unsafe (t : var) =\n make_checked (fun () ->\n let _, _, actual_packed =\n Pickles.Scalar_challenge.to_field_checked' ~num_bits:length_in_bits\n m\n (Kimchi_backend_common.Scalar_challenge.create t)\n in\n actual_packed )\n\n (** [range_check t] asserts that [0 <= t < 2^length_in_bits].\n\n Any value consumed or returned by functions in this module must satisfy\n this assertion.\n *)\n let range_check t =\n let%bind actual = image_from_bits_unsafe t in\n with_label \"range_check\" (fun () -> Field.Checked.Assert.equal actual t)\n\n let seal x = make_checked (fun () -> Pickles.Util.seal Tick.m x)\n\n let modulus_as_field =\n lazy (Fn.apply_n_times ~n:length_in_bits Field.(mul (of_int 2)) Field.one)\n\n let double_modulus_as_field =\n lazy (Field.(mul (of_int 2)) (Lazy.force modulus_as_field))\n\n (** [range_check_flagged kind t] returns [t'] that fits in [length_in_bits]\n bits, and satisfies [t' = t + k * 2^length_in_bits] for some [k].\n The [`Overflow b] return value is false iff [t' = t].\n\n This function should be used when [t] was computed via addition or\n subtraction, to calculate the equivalent value that would be returned by\n overflowing or underflowing an integer with [length_in_bits] bits.\n\n The [`Add] and [`Sub] values for [kind] are specializations that use\n fewer constraints and perform fewer calculations. Any inputs that satisfy\n the invariants for [`Add] or [`Sub] will return the same value if\n [`Add_or_sub] is used instead.\n\n Invariants:\n * if [kind] is [`Add], [0 <= t < 2 * 2^length_in_bits - 1];\n * if [kind] is [`Sub], [- 2^length_in_bits < t < 2^length_in_bits];\n * if [kind] is [`Add_or_sub],\n [- 2^length_in_bits < t < 2 * 2^length_in_bits - 1].\n *)\n let range_check_flagged (kind : [ `Add | `Sub | `Add_or_sub ]) t =\n let%bind adjustment_factor =\n exists Field.typ\n ~compute:\n As_prover.(\n let%map t = read Field.typ t in\n match kind with\n | `Add ->\n if Int.(Field.compare t (Lazy.force modulus_as_field) < 0)\n then (* Within range. *)\n Field.zero\n else\n (* Overflowed. We compensate by subtracting [modulus_as_field]. *)\n Field.(negate one)\n | `Sub ->\n if Int.(Field.compare t (Lazy.force modulus_as_field) < 0)\n then (* Within range. *)\n Field.zero\n else\n (* Underflowed, but appears as an overflow because of wrapping in\n the field (that is, -1 is the largest field element, -2 is the\n second largest, etc.). Compensate by adding [modulus_as_field].\n *)\n Field.one\n | `Add_or_sub ->\n (* This case is a little more nuanced: -modulus_as_field < t <\n 2*modulus_as_field, and we need to detect which 'side of 0' we\n are. Thus, we have 3 cases:\n *)\n if Int.(Field.compare t (Lazy.force modulus_as_field) < 0)\n then\n (* 1. we are already in the desired range, no adjustment; *)\n Field.zero\n else if\n Int.(\n Field.compare t (Lazy.force double_modulus_as_field) < 0)\n then\n (* 2. we are in the range\n [modulus_as_field <= t < 2 * modulus_as_field],\n so this was an addition that overflowed, and we should\n compensate by subtracting [modulus_as_field];\n *)\n Field.(negate one)\n else\n (* 3. we are outside of either range, so this must be the\n underflow of a subtraction, and we should compensate by\n adding [modulus_as_field].\n *)\n Field.one)\n in\n let%bind out_of_range =\n match kind with\n | `Add ->\n (* 0 or -1 => 0 or 1 *)\n Boolean.of_field (Field.Var.negate adjustment_factor)\n | `Sub ->\n (* Already 0 or 1 *)\n Boolean.of_field adjustment_factor\n | `Add_or_sub ->\n (* The return flag [out_of_range] is a boolean represented by either 0\n when [t] is in range or 1 when [t] is out-of-range.\n Notice that [out_of_range = adjustment_factor^2] gives us exactly\n the desired values, and moreover we can ensure that\n [adjustment_factor] is exactly one of -1, 0 or 1 by checking that\n [out_of_range] is boolean.\n *)\n Field.Checked.mul adjustment_factor adjustment_factor\n >>= Boolean.of_field\n in\n (* [t_adjusted = t + adjustment_factor * modulus_as_field] *)\n let t_adjusted =\n let open Field.Var in\n add t (scale adjustment_factor (Lazy.force modulus_as_field))\n in\n let%bind t_adjusted = seal t_adjusted in\n let%map () = range_check t_adjusted in\n (t_adjusted, `Overflow out_of_range)\n\n let of_field (x : Field.t) : t =\n of_bits (List.take (Field.unpack x) length_in_bits)\n\n let to_field (x : t) : Field.t = Field.project (to_bits x)\n\n let typ : (var, t) Typ.t =\n let (Typ typ) = Field.typ in\n Typ.transport\n (Typ { typ with check = range_check })\n ~there:to_field ~back:of_field\n\n [%%endif]\n\n let zero = Unsigned.zero\n\n let one = Unsigned.one\n\n (* The number of nanounits in a unit. User for unit transformations. *)\n let unit_to_nano = 1_000_000_000\n\n let to_nanomina_int = to_int\n\n let to_mina_int m = to_int m / unit_to_nano\n\n let sub x y = if x < y then None else Some (Unsigned.sub x y)\n\n let sub_flagged x y =\n let z = Unsigned.sub x y in\n (z, `Underflow (x < y))\n\n let add x y =\n let z = Unsigned.add x y in\n if z < x then None else Some z\n\n let add_flagged x y =\n let z = Unsigned.add x y in\n (z, `Overflow (z < x))\n\n let add_signed_flagged x y =\n match y.Signed_poly.sgn with\n | Sgn.Pos ->\n let z, `Overflow b = add_flagged x y.Signed_poly.magnitude in\n (z, `Overflow b)\n | Sgn.Neg ->\n let z, `Underflow b = sub_flagged x y.Signed_poly.magnitude in\n (z, `Overflow b)\n\n let scale u64 i =\n if Int.(i = 0) then Some zero\n else\n let i = Unsigned.of_int i in\n let max_val = Unsigned.(div max_int i) in\n if max_val >= u64 then Some (Unsigned.mul u64 i) else None\n\n let ( + ) = add\n\n let ( - ) = sub\n\n (* The functions below are unsafe, because they could overflow or\n underflow. They perform appropriate checks to guard against this\n and either raise Currency_overflow exception or return None\n depending on the error-handling strategy.\n\n It is advisable to use nanomina and mina wherever possible and\n limit the use of _exn veriants to places where a fixed value is\n being converted and hence overflow cannot happen. *)\n let of_nanomina_int i = if Int.(i >= 0) then Some (of_int i) else None\n\n let of_mina_int i =\n Option.(of_nanomina_int i >>= Fn.flip scale unit_to_nano)\n\n let of_nanomina_int_exn i =\n match of_nanomina_int i with\n | None ->\n raise (Currency_overflow i)\n | Some m ->\n m\n\n let of_mina_int_exn i =\n match of_mina_int i with\n | None ->\n raise (Currency_overflow i)\n | Some m ->\n m\n\n type magnitude = t [@@deriving sexp, hash, compare, yojson]\n\n let to_input (t : t) =\n Random_oracle.Input.Chunked.packed\n (Field.project (to_bits t), length_in_bits)\n\n let to_input_legacy t = Random_oracle.Input.Legacy.bitstring @@ to_bits t\n\n module Signed = struct\n type ('magnitude, 'sgn) typ = ('magnitude, 'sgn) Signed_poly.t =\n { magnitude : 'magnitude; sgn : 'sgn }\n [@@deriving sexp, hash, compare, yojson, hlist]\n\n type t = (Unsigned.t, Sgn.t) Signed_poly.t [@@deriving sexp, hash, yojson]\n\n let compare : t -> t -> int =\n let cmp = [%compare: (Unsigned.t, Sgn.t) Signed_poly.t] in\n fun t1 t2 ->\n if Unsigned.(equal t1.magnitude zero && equal t2.magnitude zero) then\n 0\n else cmp t1 t2\n\n let equal : t -> t -> bool =\n let eq = [%equal: (Unsigned.t, Sgn.t) Signed_poly.t] in\n fun t1 t2 ->\n if Unsigned.(equal t1.magnitude zero && equal t2.magnitude zero) then\n true\n else eq t1 t2\n\n let is_zero (t : t) : bool = Unsigned.(equal t.magnitude zero)\n\n let is_positive (t : t) : bool =\n match t.sgn with\n | Pos ->\n not Unsigned.(equal zero t.magnitude)\n | Neg ->\n false\n\n let is_negative (t : t) : bool =\n match t.sgn with\n | Neg ->\n not Unsigned.(equal zero t.magnitude)\n | Pos ->\n false\n\n type magnitude = Unsigned.t [@@deriving sexp, compare]\n\n let create ~magnitude ~sgn =\n { magnitude\n ; sgn = (if Unsigned.(equal magnitude zero) then Sgn.Pos else sgn)\n }\n\n let sgn { sgn; _ } = sgn\n\n let magnitude { magnitude; _ } = magnitude\n\n let zero : t = { magnitude = zero; sgn = Sgn.Pos }\n\n let gen =\n Quickcheck.Generator.map2 gen Sgn.gen ~f:(fun magnitude sgn ->\n create ~magnitude ~sgn )\n\n let sgn_to_bool = function Sgn.Pos -> true | Neg -> false\n\n let to_bits ({ sgn; magnitude } : t) =\n sgn_to_bool sgn :: to_bits magnitude\n\n let to_input { sgn; magnitude } =\n Random_oracle.Input.Chunked.(\n append (to_input magnitude)\n (packed (Field.project [ sgn_to_bool sgn ], 1)))\n\n let to_input_legacy t = Random_oracle.Input.Legacy.bitstring (to_bits t)\n\n let add (x : t) (y : t) : t option =\n match (x.sgn, y.sgn) with\n | Neg, (Neg as sgn) | Pos, (Pos as sgn) ->\n let open Option.Let_syntax in\n let%map magnitude = add x.magnitude y.magnitude in\n create ~sgn ~magnitude\n | Pos, Neg | Neg, Pos ->\n let c = compare_magnitude x.magnitude y.magnitude in\n Some\n ( if Int.( < ) c 0 then\n create ~sgn:y.sgn\n ~magnitude:Unsigned.Infix.(y.magnitude - x.magnitude)\n else if Int.( > ) c 0 then\n create ~sgn:x.sgn\n ~magnitude:Unsigned.Infix.(x.magnitude - y.magnitude)\n else zero )\n\n let add_flagged (x : t) (y : t) : t * [ `Overflow of bool ] =\n match (x.sgn, y.sgn) with\n | Neg, (Neg as sgn) | Pos, (Pos as sgn) ->\n let magnitude, `Overflow b = add_flagged x.magnitude y.magnitude in\n (create ~sgn ~magnitude, `Overflow b)\n | Pos, Neg | Neg, Pos ->\n let c = compare_magnitude x.magnitude y.magnitude in\n ( ( if Int.( < ) c 0 then\n create ~sgn:y.sgn\n ~magnitude:Unsigned.Infix.(y.magnitude - x.magnitude)\n else if Int.( > ) c 0 then\n create ~sgn:x.sgn\n ~magnitude:Unsigned.Infix.(x.magnitude - y.magnitude)\n else zero )\n , `Overflow false )\n\n let negate t =\n if Unsigned.(equal zero t.magnitude) then zero\n else { t with sgn = Sgn.negate t.sgn }\n\n let of_unsigned magnitude : t = create ~magnitude ~sgn:Sgn.Pos\n\n let ( + ) = add\n\n let to_fee = Fn.id\n\n let of_fee = Fn.id\n\n [%%ifdef consensus_mechanism]\n\n type signed_fee = t\n\n let magnitude_to_field = to_field\n\n let to_field (t : t) : Field.t =\n Field.mul (Sgn.to_field t.sgn) (magnitude_to_field t.magnitude)\n\n type repr = var Signed_var.repr\n\n type nonrec var = var Signed_var.t\n\n let repr_typ : (repr, t) Typ.t =\n Typ.of_hlistable [ typ; Sgn.typ ] ~var_to_hlist:typ_to_hlist\n ~var_of_hlist:typ_of_hlist ~value_to_hlist:typ_to_hlist\n ~value_of_hlist:typ_of_hlist\n\n let typ : (var, t) Typ.t =\n Typ.transport_var repr_typ\n ~back:(fun repr -> { Signed_var.value = None; repr })\n ~there:(fun { Signed_var.repr; _ } -> repr)\n\n let create_var ~magnitude ~sgn : var =\n { repr = { magnitude; sgn }; value = None }\n\n module Checked = struct\n type t = var\n\n type signed_fee_var = t\n\n let repr (t : var) = Checked.return t.repr\n\n let value (t : var) =\n match t.value with\n | Some x ->\n Checked.return x\n | None ->\n let r = t.repr in\n let%map x =\n Field.Checked.mul (r.sgn :> Field.Var.t) r.magnitude\n in\n t.value <- Some x ;\n x\n\n let to_field_var = value\n\n let to_input t =\n let%map { magnitude; sgn } = repr t in\n let mag = var_to_input magnitude in\n Random_oracle.Input.Chunked.(\n append mag (packed ((Sgn.Checked.is_pos sgn :> Field.Var.t), 1)))\n\n let to_input_legacy t =\n let to_bits { magnitude; sgn } =\n let%map magnitude = var_to_bits_ magnitude in\n Sgn.Checked.is_pos sgn :: magnitude\n in\n repr t >>= to_bits >>| Random_oracle.Input.Legacy.bitstring\n\n let constant ({ magnitude; sgn } as t) =\n { Signed_var.repr =\n { magnitude = var_of_t magnitude; sgn = Sgn.Checked.constant sgn }\n ; value = Some (Field.Var.constant (to_field t))\n }\n\n let of_unsigned magnitude : var =\n { repr = { magnitude; sgn = Sgn.Checked.pos }\n ; value = Some magnitude\n }\n\n let negate (t : var) : var =\n { value = Option.map t.value ~f:Field.Var.negate\n ; repr =\n (let { magnitude; sgn } = t.repr in\n { magnitude; sgn = Sgn.Checked.negate sgn } )\n }\n\n let if_repr cond ~then_ ~else_ =\n let%map sgn = Sgn.Checked.if_ cond ~then_:then_.sgn ~else_:else_.sgn\n and magnitude =\n if_ cond ~then_:then_.magnitude ~else_:else_.magnitude\n in\n { sgn; magnitude }\n\n let if_ cond ~(then_ : var) ~(else_ : var) : var Checked.t =\n let%bind repr = if_repr cond ~then_:then_.repr ~else_:else_.repr in\n let%map value =\n match (then_.value, else_.value) with\n | Some v1, Some v2 ->\n Field.Checked.if_ cond ~then_:v1 ~else_:v2 >>| Option.return\n | _ ->\n return None\n in\n { Signed_var.value; repr }\n\n let sgn (t : var) =\n let%map r = repr t in\n r.sgn\n\n let magnitude (t : var) =\n let%map r = repr t in\n r.magnitude\n\n let add_flagged (x : var) (y : var) =\n let%bind xv = value x and yv = value y in\n let%bind sgn =\n exists Sgn.typ\n ~compute:\n (let open As_prover in\n let%map x = read typ x and y = read typ y in\n match add x y with\n | Some r ->\n r.sgn\n | None -> (\n match (x.sgn, y.sgn) with\n | Sgn.Neg, Sgn.Neg ->\n (* Ensure that we provide a value in the range\n [-modulus_as_field < magnitude < 2*modulus_as_field]\n for [range_check_flagged].\n *)\n Sgn.Neg\n | _ ->\n Sgn.Pos ))\n in\n let value = Field.Var.add xv yv in\n let%bind magnitude =\n Tick.Field.Checked.mul (sgn :> Field.Var.t) value\n in\n let%bind res_magnitude, `Overflow overflow =\n range_check_flagged `Add_or_sub magnitude\n in\n (* Recompute the result from [res_magnitude], since it may have been\n adjusted.\n *)\n let%map res_value =\n Field.Checked.mul (sgn :> Field.Var.t) magnitude\n in\n ( { Signed_var.repr = { magnitude = res_magnitude; sgn }\n ; value = Some res_value\n }\n , `Overflow overflow )\n\n let add (x : var) (y : var) =\n let%bind xv = value x and yv = value y in\n let%bind sgn =\n exists Sgn.typ\n ~compute:\n (let open As_prover in\n let%map x = read typ x and y = read typ y in\n Option.value_map (add x y) ~default:Sgn.Pos ~f:(fun r -> r.sgn))\n in\n let%bind res_value = seal (Field.Var.add xv yv) in\n let%bind magnitude =\n Tick.Field.Checked.mul (sgn :> Field.Var.t) res_value\n in\n let%map () = range_check magnitude in\n { Signed_var.repr = { magnitude; sgn }; value = Some res_value }\n\n let ( + ) = add\n\n let equal (t1 : var) (t2 : var) =\n let%bind t1 = value t1 and t2 = value t2 in\n Field.Checked.equal t1 t2\n\n let assert_equal (t1 : var) (t2 : var) =\n let%bind t1 = value t1 and t2 = value t2 in\n Field.Checked.Assert.equal t1 t2\n\n let to_fee = Fn.id\n\n let of_fee = Fn.id\n end\n\n [%%endif]\n end\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n module N = Mina_numbers.Nat.Make_checked (Unsigned) (B)\n\n type t = var\n\n let if_ = if_\n\n (* Unpacking protects against underflow *)\n let sub (x : var) (y : var) =\n let%bind res = seal (Field.Var.sub x y) in\n let%map () = range_check res in\n res\n\n let sub_flagged x y =\n let%bind z = seal (Field.Var.sub x y) in\n let%map z, `Overflow underflow = range_check_flagged `Sub z in\n (z, `Underflow underflow)\n\n let sub_or_zero x y =\n let%bind res, `Underflow underflow = sub_flagged x y in\n Field.Checked.if_ underflow ~then_:Field.(Var.constant zero) ~else_:res\n\n let assert_equal x y = Field.Checked.Assert.equal x y\n\n let equal x y = Field.Checked.equal x y\n\n let ( = ) = equal\n\n let ( < ) x y =\n let%bind diff = seal (Field.Var.sub x y) in\n (* [lt] is true iff [x - y < 0], ie. [x < y] *)\n let%map _res, `Overflow lt = range_check_flagged `Sub diff in\n lt\n\n (* x <= y iff not (y < x) *)\n let ( <= ) x y =\n let%map y_lt_x = y < x in\n Boolean.not y_lt_x\n\n (* x >= y iff y <= x *)\n let ( >= ) x y = y <= x\n\n let ( > ) x y = y < x\n\n (* Unpacking protects against overflow *)\n let add (x : var) (y : var) =\n let%bind res = seal (Field.Var.add x y) in\n let%map () = range_check res in\n res\n\n let add_flagged x y =\n let%bind z = seal (Field.Var.add x y) in\n let%map z, `Overflow overflow = range_check_flagged `Add z in\n (z, `Overflow overflow)\n\n let ( - ) = sub\n\n let ( + ) = add\n\n let add_signed (t : var) (d : Signed.var) =\n let%bind d = Signed.Checked.to_field_var d in\n let%bind res = seal (Field.Var.add t d) in\n let%map () = range_check res in\n res\n\n let add_signed_flagged (t : var) (d : Signed.var) =\n let%bind d = Signed.Checked.to_field_var d in\n let%bind res = seal (Field.Var.add t d) in\n let%map res, `Overflow overflow = range_check_flagged `Add_or_sub res in\n (res, `Overflow overflow)\n\n let scale (f : Field.Var.t) (t : var) =\n let%bind res = Field.Checked.mul t f in\n let%map () = range_check res in\n res\n\n let%test_module \"currency_test\" =\n ( module struct\n let expect_failure err c =\n if Or_error.is_ok (check c) then failwith err\n\n let expect_success err c =\n match check c with\n | Ok () ->\n ()\n | Error e ->\n Error.(raise (tag ~tag:err e))\n\n let to_bigint x = Bignum_bigint.of_string (Unsigned.to_string x)\n\n let of_bigint x = Unsigned.of_string (Bignum_bigint.to_string x)\n\n let gen_incl x y =\n Quickcheck.Generator.map ~f:of_bigint\n (Bignum_bigint.gen_incl (to_bigint x) (to_bigint y))\n\n let shrinker =\n Quickcheck.Shrinker.create (fun i ->\n Sequence.unfold ~init:i ~f:(fun i ->\n if Unsigned.equal i Unsigned.zero then None\n else\n let n = Unsigned.div i (Unsigned.of_int 10) in\n Some (n, n) ) )\n\n (* TODO: When we do something to make snarks run fast for tests, increase the trials *)\n let qc_test_fast = Quickcheck.test ~trials:100\n\n let%test_unit \"subtraction_completeness\" =\n let generator =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = gen_incl Unsigned.zero Unsigned.max_int in\n let%map y = gen_incl Unsigned.zero x in\n (x, y)\n in\n qc_test_fast generator ~f:(fun (lo, hi) ->\n expect_success\n (sprintf !\"subtraction: lo=%{Unsigned} hi=%{Unsigned}\" lo hi)\n (var_of_t lo - var_of_t hi) )\n\n let%test_unit \"subtraction_soundness\" =\n let generator =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = gen_incl Unsigned.zero Unsigned.(sub max_int one) in\n let%map y = gen_incl Unsigned.(add x one) Unsigned.max_int in\n (x, y)\n in\n qc_test_fast generator ~f:(fun (lo, hi) ->\n expect_failure\n (sprintf !\"underflow: lo=%{Unsigned} hi=%{Unsigned}\" lo hi)\n (var_of_t lo - var_of_t hi) )\n\n let%test_unit \"addition_completeness\" =\n let generator =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = gen_incl Unsigned.zero Unsigned.max_int in\n let%map y = gen_incl Unsigned.zero Unsigned.(sub max_int x) in\n (x, y)\n in\n qc_test_fast generator ~f:(fun (x, y) ->\n expect_success\n (sprintf !\"overflow: x=%{Unsigned} y=%{Unsigned}\" x y)\n (var_of_t x + var_of_t y) )\n\n let%test_unit \"addition_soundness\" =\n let generator =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = gen_incl Unsigned.one Unsigned.max_int in\n let%map y =\n gen_incl Unsigned.(add (sub max_int x) one) Unsigned.max_int\n in\n (x, y)\n in\n qc_test_fast generator ~f:(fun (x, y) ->\n expect_failure\n (sprintf !\"overflow: x=%{Unsigned} y=%{Unsigned}\" x y)\n (var_of_t x + var_of_t y) )\n\n let%test_unit \"formatting_roundtrip\" =\n let generator = gen_incl Unsigned.zero Unsigned.max_int in\n qc_test_fast generator ~shrinker ~f:(fun num ->\n match of_mina_string_exn (to_mina_string num) with\n | after_format ->\n if Unsigned.equal after_format num then ()\n else\n Error.(\n raise\n (of_string\n (sprintf\n !\"formatting: num=%{Unsigned} middle=%{String} \\\n after=%{Unsigned}\"\n num (to_mina_string num) after_format ) ))\n | exception e ->\n let err = Error.of_exn e in\n Error.(\n raise\n (tag\n ~tag:(sprintf !\"formatting: num=%{Unsigned}\" num)\n err )) )\n\n let%test_unit \"formatting_trailing_zeros\" =\n let generator = gen_incl Unsigned.zero Unsigned.max_int in\n qc_test_fast generator ~shrinker ~f:(fun num ->\n let formatted = to_mina_string num in\n let has_decimal = String.contains formatted '.' in\n let trailing_zero = String.is_suffix formatted ~suffix:\"0\" in\n if has_decimal && trailing_zero then\n Error.(\n raise\n (of_string\n (sprintf\n !\"formatting: num=%{Unsigned} formatted=%{String}\"\n num (to_mina_string num) ) )) )\n end )\n end\n\n [%%endif]\n end\n\n let currency_length = 64\n\n module Fee = struct\n module T =\n Make\n (Unsigned_extended.UInt64)\n (struct\n let length = currency_length\n end)\n\n include T\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Unsigned_extended.UInt64.Stable.V1.t\n [@@deriving sexp, compare, hash, equal]\n\n [%%define_from_scope to_yojson, of_yojson, dhall_type]\n\n let to_latest = Fn.id\n end\n end]\n\n let (_ : (Signed.t, (t, Sgn.t) Signed_poly.t) Type_equal.t) = Type_equal.T\n\n let minimum_user_command_fee =\n of_mina_string_exn Mina_compile_config.minimum_user_command_fee_string\n\n let default_transaction_fee =\n of_mina_string_exn Mina_compile_config.default_transaction_fee_string\n\n let default_snark_worker_fee =\n of_mina_string_exn Mina_compile_config.default_snark_worker_fee_string\n end\n\n module Amount = struct\n (* See documentation for {!module:Mina_wire_types} *)\n module Make_sig (A : sig\n type t\n end) =\n struct\n module type S = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t = A.t [@@deriving sexp, compare, hash, equal, yojson]\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n end\n end]\n\n [%%ifdef consensus_mechanism]\n\n (* Give a definition to var, it will be hidden at the interface level *)\n include\n Basic\n with type t := Stable.Latest.t\n and type var =\n Pickles.Impls.Step.Impl.Internal_Basic.field\n Snarky_backendless.Cvar.t\n\n [%%else]\n\n include Basic with type t := Stable.Latest.t\n\n [%%endif]\n\n include Arithmetic_intf with type t := t\n\n include Codable.S with type t := t\n\n [%%ifdef consensus_mechanism]\n\n module Signed :\n Signed_intf\n with type magnitude := t\n and type magnitude_var := var\n and type signed_fee := Fee.Signed.t\n and type Checked.signed_fee_var := Fee.Signed.Checked.t\n\n [%%else]\n\n module Signed :\n Signed_intf\n with type magnitude := t\n and type signed_fee := Fee.Signed.t\n\n [%%endif]\n\n (* TODO: Delete these functions *)\n\n val of_fee : Fee.t -> t\n\n val to_fee : t -> Fee.t\n\n val add_fee : t -> Fee.t -> t option\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n include\n Checked_arithmetic_intf\n with type var := var\n and type signed_var := Signed.var\n and type value := t\n\n val add_signed : var -> Signed.var -> var Checked.t\n\n val of_fee : Fee.var -> var\n\n val to_fee : var -> Fee.var\n\n val to_field : var -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> t\n end\n end\n\n [%%endif]\n\n val add_signed_flagged : t -> Signed.t -> t * [ `Overflow of bool ]\n end\n end\n [@@warning \"-32\"]\n\n module Make_str (A : sig\n type t = Unsigned_extended.UInt64.Stable.V1.t\n end) : Make_sig(A).S = struct\n module T =\n Make\n (Unsigned_extended.UInt64)\n (struct\n let length = currency_length\n end)\n\n [%%ifdef consensus_mechanism]\n\n include (\n T :\n module type of T\n with type var = T.var\n and module Signed = T.Signed\n and module Checked := T.Checked )\n\n [%%else]\n\n include (T : module type of T with module Signed = T.Signed)\n\n [%%endif]\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Unsigned_extended.UInt64.Stable.V1.t\n [@@deriving sexp, compare, hash, equal, yojson]\n\n [%%define_from_scope to_yojson, of_yojson, dhall_type]\n\n let to_latest = Fn.id\n end\n end]\n\n let of_fee (fee : Fee.t) : t = fee\n\n let to_fee (fee : t) : Fee.t = fee\n\n let add_fee (t : t) (fee : Fee.t) = add t (of_fee fee)\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n include T.Checked\n\n let of_fee (fee : Fee.var) : var = fee\n\n let to_fee (t : var) : Fee.var = t\n\n let to_field = Fn.id\n\n module Unsafe = struct\n let of_field : Field.Var.t -> var = Fn.id\n end\n end\n\n [%%endif]\n end\n\n include Make_str (struct\n type t = Unsigned_extended.UInt64.Stable.V1.t\n end)\n (*include Wire_types.Make.Amount (Make_sig) (Make_str)*)\n end\n\n module Balance = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Amount.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n\n (* can't be automatically derived *)\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n end\n end]\n\n [%%ifdef consensus_mechanism]\n\n include (Amount : Basic with type t := t with type var = Amount.var)\n\n [%%else]\n\n include (Amount : Basic with type t := t)\n\n [%%endif]\n\n let to_amount = Fn.id\n\n let add_amount = Amount.add\n\n let add_amount_flagged = Amount.add_flagged\n\n let sub_amount = Amount.sub\n\n let sub_amount_flagged = Amount.sub_flagged\n\n let add_signed_amount_flagged = Amount.add_signed_flagged\n\n let ( + ) = add_amount\n\n let ( - ) = sub_amount\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n include Amount.Checked\n\n let to_field = Fn.id\n\n module Unsafe = struct\n let of_field (x : Field.Var.t) : var = x\n end\n\n let to_amount = Fn.id\n\n let add_signed_amount = add_signed\n\n let add_amount = add\n\n let sub_amount = sub\n\n let sub_amount_or_zero = sub_or_zero\n\n let add_amount_flagged = add_flagged\n\n let add_signed_amount_flagged = add_signed_flagged\n\n let sub_amount_flagged = sub_flagged\n\n let ( + ) = add_amount\n\n let ( - ) = sub_amount\n end\n\n [%%endif]\n end\n\n module Fee_rate = struct\n type t = Q.t\n\n let uint64_to_z u64 = Z.of_string @@ Unsigned.UInt64.to_string u64\n\n let uint64_of_z z = Unsigned.UInt64.of_string @@ Z.to_string z\n\n let max_uint64_z = uint64_to_z Unsigned.UInt64.max_int\n\n let fits_uint64 z =\n let open Z in\n leq zero z && leq z max_uint64_z\n\n (** check if a Q.t is in range *)\n let check_q Q.{ num; den } : bool =\n let open Z in\n fits_uint64 num && fits_int32 den\n && if equal zero den then equal zero num else true\n\n let of_q q = if check_q q then Some q else None\n\n let of_q_exn q = Option.value_exn (of_q q)\n\n let to_q = ident\n\n let make fee weight = of_q @@ Q.make (uint64_to_z fee) (Z.of_int weight)\n\n let make_exn fee weight = Option.value_exn (make fee weight)\n\n let to_uint64 Q.{ num; den } =\n if Z.(equal den Z.one) then Some (uint64_of_z num) else None\n\n let to_uint64_exn fr = Option.value_exn (to_uint64 fr)\n\n let add x y = of_q @@ Q.add x y\n\n let add_flagged x y =\n let z = Q.add x y in\n (z, `Overflow (check_q z))\n\n let sub x y = of_q @@ Q.sub x y\n\n let sub_flagged x y =\n let z = Q.sub x y in\n (z, `Underflow (check_q z))\n\n let mul x y = of_q @@ Q.mul x y\n\n let div x y = of_q @@ Q.div x y\n\n let ( + ) = add\n\n let ( - ) = sub\n\n let ( * ) = mul\n\n let scale fr s = fr * Q.of_int s\n\n let scale_exn fr s = Option.value_exn (scale fr s)\n\n let compare = Q.compare\n\n let t_of_sexp sexp =\n let open Ppx_sexp_conv_lib.Conv in\n pair_of_sexp Fee.t_of_sexp int_of_sexp sexp\n |> fun (fee, weight) -> make_exn fee weight\n\n let sexp_of_t Q.{ num = fee; den = weight } =\n let sexp_of_fee fee = Fee.sexp_of_t @@ uint64_of_z fee in\n let sexp_of_weight weight = sexp_of_int @@ Z.to_int weight in\n sexp_of_pair sexp_of_fee sexp_of_weight (fee, weight)\n\n include Comparable.Make (struct\n type nonrec t = t\n\n let compare = compare\n\n let t_of_sexp = t_of_sexp\n\n let sexp_of_t = sexp_of_t\n end)\n end\n\n let%test_module \"sub_flagged module\" =\n ( module struct\n [%%ifdef consensus_mechanism]\n\n open Tick\n\n module type Sub_flagged_S = sig\n type t\n\n type magnitude = t [@@deriving sexp, compare]\n\n type var\n\n (* TODO =\n field Snarky_backendless.Cvar.t Snarky_backendless.Boolean.t list *)\n\n val zero : t\n\n val ( - ) : t -> t -> t option\n\n val typ : (var, t) Typ.t\n\n val gen : t Quickcheck.Generator.t\n\n module Checked : sig\n val sub_flagged :\n var -> var -> (var * [ `Underflow of Boolean.var ]) Tick.Checked.t\n end\n end\n\n let run_test (module M : Sub_flagged_S) =\n let open M in\n let sub_flagged_unchecked (x, y) =\n if compare_magnitude x y < 0 then (zero, true)\n else (Option.value_exn (x - y), false)\n in\n let sub_flagged_checked =\n let f (x, y) =\n Tick.Checked.map (M.Checked.sub_flagged x y)\n ~f:(fun (r, `Underflow u) -> (r, u))\n in\n Test_util.checked_to_unchecked (Typ.tuple2 typ typ)\n (Typ.tuple2 typ Boolean.typ)\n f\n in\n Quickcheck.test ~trials:100 (Quickcheck.Generator.tuple2 gen gen)\n ~f:(fun p ->\n let m, u = sub_flagged_unchecked p in\n let m_checked, u_checked = sub_flagged_checked p in\n assert (Bool.equal u u_checked) ;\n if not u then [%test_eq: M.magnitude] m m_checked )\n\n let%test_unit \"fee sub_flagged\" = run_test (module Fee)\n\n let%test_unit \"amount sub_flagged\" = run_test (module Amount)\n\n [%%endif]\n end )\nend\n\n(** Finally, we use [Make] to create the full module where the types defined\n here and in {!Mina_wire_types} are fully unified. *)\ninclude Wire_types.Make (Make_sig) (Make_str)\n","(*\n RE - A regular expression library\n\n Copyright (C) 2001 Jerome Vouillon\n email: Jerome.Vouillon@pps.jussieu.fr\n\n This library is free software; you can redistribute it and/or\n modify it under the terms of the GNU Lesser General Public\n License as published by the Free Software Foundation, with\n linking exception; either version 2.1 of the License, or (at\n your option) any later version.\n\n This library is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\n Lesser General Public License for more details.\n\n You should have received a copy of the GNU Lesser General Public\n License along with this library; if not, write to the Free Software\n Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA\n*)\n\ntype c = int\ntype t = (c * c) list\n\nlet rec union l l' =\n match l, l' with\n _, [] -> l\n | [], _ -> l'\n | (c1, c2)::r, (c1', c2')::r' ->\n if c2 + 1 < c1' then\n (c1, c2)::union r l'\n else if c2' + 1 < c1 then\n (c1', c2')::union l r'\n else if c2 < c2' then\n union r ((min c1 c1', c2')::r')\n else\n union ((min c1 c1', c2)::r) r'\n\nlet rec inter l l' =\n match l, l' with\n _, [] -> []\n | [], _ -> []\n | (c1, c2)::r, (c1', c2')::r' ->\n if c2 < c1' then\n inter r l'\n else if c2' < c1 then\n inter l r'\n else if c2 < c2' then\n (max c1 c1', c2)::inter r l'\n else\n (max c1 c1', c2')::inter l r'\n\nlet rec diff l l' =\n match l, l' with\n _, [] -> l\n | [], _ -> []\n | (c1, c2)::r, (c1', c2')::r' ->\n if c2 < c1' then\n (c1, c2)::diff r l'\n else if c2' < c1 then\n diff l r'\n else\n let r'' = if c2' < c2 then (c2' + 1, c2) :: r else r in\n if c1 < c1' then\n (c1, c1' - 1)::diff r'' r'\n else\n diff r'' r'\n\nlet single c = [c, c]\n\nlet add c l = union (single c) l\n\nlet seq c c' = if c <= c' then [c, c'] else [c', c]\n\nlet rec offset o l =\n match l with\n [] -> []\n | (c1, c2) :: r -> (c1 + o, c2 + o) :: offset o r\n\nlet empty = []\n\nlet rec mem (c : int) s =\n match s with\n [] -> false\n | (c1, c2) :: rem -> if c <= c2 then c >= c1 else mem c rem\n\n(****)\n\ntype hash = int\n\nlet rec hash_rec = function\n | [] -> 0\n | (i, j)::r -> i + 13 * j + 257 * hash_rec r\nlet hash l = (hash_rec l) land 0x3FFFFFFF\n\n(****)\n\nlet print_one ch (c1, c2) =\n if c1 = c2 then\n Format.fprintf ch \"%d\" c1\n else\n Format.fprintf ch \"%d-%d\" c1 c2\n\nlet pp = Fmt.list print_one\n\nlet rec iter t ~f =\n match t with\n | [] -> ()\n | (x, y)::xs ->\n f x y;\n iter xs ~f\n\nlet one_char = function\n | [i, j] when i = j -> Some i\n | _ -> None\n\n\nmodule CSetMap = Map.Make (struct\n type t = int * (int * int) list\n let compare (i, u) (j, v) =\n let c = compare i j in\n if c <> 0\n then c\n else compare u v\n end)\n\nlet fold_right t ~init ~f = List.fold_right f t init\n\nlet csingle c = single (Char.code c)\n\nlet cany = [0, 255]\n\nlet is_empty = function\n | [] -> true\n | _ -> false\n\nlet rec prepend s x l =\n match s, l with\n | [], _ -> l\n | _r, [] -> []\n | (_c, c') :: r, ([d, _d'], _x') :: _r' when c' < d -> prepend r x l\n | (c, c') :: r, ([d, d'], x') :: r' ->\n if c <= d then begin\n if c' < d'\n then ([d, c'], x @ x') :: prepend r x (([c' + 1, d'], x') :: r')\n else ([d, d'], x @ x') :: prepend s x r'\n end else begin\n if c > d'\n then ([d, d'], x') :: prepend s x r'\n else ([d, c - 1], x') :: prepend s x (([c, d'], x') :: r')\n end\n | _ -> assert false\n\nlet pick = function\n | [] -> invalid_arg \"Re_cset.pick\"\n | (x, _)::_ -> x\n","\nmodule MenhirBasics = struct\n \n exception Error\n \n type token = \n | SUBSCRIPTION\n | STRING of (\n# 8 \"graphql_parser/src/parser.mly\"\n (string)\n# 12 \"graphql_parser/src/parser.ml\"\n )\n | RPAREN\n | RBRACK\n | RBRACE\n | QUERY\n | ON\n | NULL\n | NAME of (\n# 5 \"graphql_parser/src/parser.mly\"\n (string)\n# 23 \"graphql_parser/src/parser.ml\"\n )\n | MUTATION\n | LPAREN\n | LBRACK\n | LBRACE\n | INT of (\n# 6 \"graphql_parser/src/parser.mly\"\n (int)\n# 32 \"graphql_parser/src/parser.ml\"\n )\n | FRAGMENT\n | FLOAT of (\n# 7 \"graphql_parser/src/parser.mly\"\n (float)\n# 38 \"graphql_parser/src/parser.ml\"\n )\n | EQUAL\n | EOF\n | ELLIPSIS\n | DOLLAR\n | COLON\n | BOOL of (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 48 \"graphql_parser/src/parser.ml\"\n )\n | BANG\n | AT\n \nend\n\ninclude MenhirBasics\n\nlet _eRR =\n MenhirBasics.Error\n\ntype _menhir_env = {\n _menhir_lexer: Lexing.lexbuf -> token;\n _menhir_lexbuf: Lexing.lexbuf;\n _menhir_token: token;\n mutable _menhir_error: bool\n}\n\nand _menhir_state = \n | MenhirState133\n | MenhirState125\n | MenhirState124\n | MenhirState119\n | MenhirState114\n | MenhirState108\n | MenhirState102\n | MenhirState100\n | MenhirState99\n | MenhirState96\n | MenhirState90\n | MenhirState89\n | MenhirState87\n | MenhirState86\n | MenhirState84\n | MenhirState81\n | MenhirState80\n | MenhirState79\n | MenhirState78\n | MenhirState71\n | MenhirState70\n | MenhirState67\n | MenhirState66\n | MenhirState65\n | MenhirState64\n | MenhirState63\n | MenhirState61\n | MenhirState59\n | MenhirState57\n | MenhirState55\n | MenhirState51\n | MenhirState44\n | MenhirState38\n | MenhirState34\n | MenhirState31\n | MenhirState29\n | MenhirState28\n | MenhirState24\n | MenhirState22\n | MenhirState21\n | MenhirState20\n | MenhirState19\n | MenhirState13\n | MenhirState12\n | MenhirState4\n | MenhirState0\n\n# 1 \"graphql_parser/src/parser.mly\"\n \nopen Ast\n\n# 119 \"graphql_parser/src/parser.ml\"\n\nlet rec _menhir_goto_nonempty_list_definition_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.document) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState0 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | EOF ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (_1 : (Ast.document))) = _menhir_stack in\n let _v : (Ast.document) = \n# 37 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 137 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.document)) = _v in\n Obj.magic _1\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState133 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.definition))), _, (xs : (Ast.document))) = _menhir_stack in\n let _v : (Ast.document) = \n# 223 \"\"\n ( x :: xs )\n# 156 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_nonempty_list_definition_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_field : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.selection) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.selection)) = _v in\n let _v : (Ast.selection) = \n# 87 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 170 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_selection _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_operation : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.definition) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.definition)) = _v in\n let _v : (Ast.definition) = \n# 41 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 182 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_definition _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_definition : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.definition) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | FRAGMENT ->\n _menhir_run78 _menhir_env (Obj.magic _menhir_stack) MenhirState133\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState133\n | MUTATION ->\n _menhir_run3 _menhir_env (Obj.magic _menhir_stack) MenhirState133\n | QUERY ->\n _menhir_run2 _menhir_env (Obj.magic _menhir_stack) MenhirState133\n | SUBSCRIPTION ->\n _menhir_run1 _menhir_env (Obj.magic _menhir_stack) MenhirState133\n | EOF ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (x : (Ast.definition))) = _menhir_stack in\n let _v : (Ast.document) = \n# 221 \"\"\n ( [ x ] )\n# 209 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_nonempty_list_definition_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState133\n\nand _menhir_goto_loption_selection_set_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.selection list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n match _menhir_s with\n | MenhirState67 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_6 : (Ast.selection list)) = _v in\n let (((((_menhir_stack, _menhir_s, (_1 : (string))), _), _, (_3 : (string))), _, (_4 : ((string * Ast.value) list))), _, (_5 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.selection) = \n# 91 \"graphql_parser/src/parser.mly\"\n (\n Field {\n alias = Some _1;\n name = _3;\n arguments = _4;\n directives = _5;\n selection_set = _6;\n }\n )\n# 236 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_field _menhir_env _menhir_stack _menhir_s _v\n | MenhirState71 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_4 : (Ast.selection list)) = _v in\n let (((_menhir_stack, _menhir_s, (_1 : (string))), _, (_2 : ((string * Ast.value) list))), _, (_3 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.selection) = \n# 101 \"graphql_parser/src/parser.mly\"\n (\n Field {\n alias = None;\n name = _1;\n arguments = _2;\n directives = _3;\n selection_set = _4;\n }\n )\n# 255 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_field _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_nonempty_list_selection_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.selection list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState61 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.selection))), _, (xs : (Ast.selection list))) = _menhir_stack in\n let _v : (Ast.selection list) = \n# 223 \"\"\n ( x :: xs )\n# 272 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_nonempty_list_selection_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState4 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (Ast.selection list))) = _menhir_stack in\n let _v : (Ast.selection list) = \n# 82 \"graphql_parser/src/parser.mly\"\n ( _2 )\n# 288 \"graphql_parser/src/parser.ml\"\n in\n (match _menhir_s with\n | MenhirState55 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_4 : (Ast.selection list)) = _v in\n let (((_menhir_stack, _menhir_s), _, (_2 : (string option))), _, (_3 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.selection) = \n# 125 \"graphql_parser/src/parser.mly\"\n (\n InlineFragment {\n type_condition = _2;\n directives = _3;\n selection_set = _4;\n }\n )\n# 305 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.selection)) = _v in\n let _v : (Ast.selection) = \n# 87 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 313 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_selection _menhir_env _menhir_stack _menhir_s _v\n | MenhirState71 | MenhirState67 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (x : (Ast.selection list)) = _v in\n let _v : (Ast.selection list) = \n# 144 \"\"\n ( x )\n# 323 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_selection_set_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState81 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_5 : (Ast.selection list)) = _v in\n let ((((_menhir_stack, _menhir_s), _, (_2 : (string))), _, (_3 : (string))), _, (_4 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.definition) = \n# 45 \"graphql_parser/src/parser.mly\"\n (\n Fragment {\n name = _2;\n type_condition = _3;\n directives = _4;\n selection_set = _5;\n }\n )\n# 341 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.definition)) = _v in\n let _v : (Ast.definition) = \n# 41 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 349 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_definition _menhir_env _menhir_stack _menhir_s _v\n | MenhirState133 | MenhirState0 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.selection list)) = _v in\n let _v : (Ast.definition) = \n# 56 \"graphql_parser/src/parser.mly\"\n (\n Operation {\n optype = Query;\n name = None;\n variable_definitions = [];\n directives = [];\n selection_set = _1;\n }\n )\n# 367 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_operation _menhir_env _menhir_stack _menhir_s _v\n | MenhirState125 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_5 : (Ast.selection list)) = _v in\n let ((((_menhir_stack, _menhir_s, (_1 : (Ast.optype))), _, (_2 : (string option))), (_3 : (Ast.variable_definition list))), _, (_4 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.definition) = \n# 66 \"graphql_parser/src/parser.mly\"\n (\n Operation {\n optype = _1;\n name = _2;\n variable_definitions = _3;\n directives = _4;\n selection_set = _5;\n }\n )\n# 386 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_operation _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ())\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_list_const_value_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.const_value list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState99 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RBRACK ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (Ast.const_value list))) = _menhir_stack in\n let _v : (Ast.const_value) = \n# 175 \"graphql_parser/src/parser.mly\"\n ( `List _2 )\n# 417 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState114 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.const_value))), _, (xs : (Ast.const_value list))) = _menhir_stack in\n let _v : (Ast.const_value list) = \n# 213 \"\"\n ( x :: xs )\n# 433 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_const_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_list___anonymous_0_const_value__ : _menhir_env -> 'ttv_tail -> _menhir_state -> ((string * Ast.const_value) list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState108 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (((_menhir_stack, _menhir_s, (_1 : (string))), _, (_3 : (Ast.const_value))), _, (xs : ((string * Ast.const_value) list))) = _menhir_stack in\n let _v : ((string * Ast.const_value) list) = let x = \n# 176 \"graphql_parser/src/parser.mly\"\n ( _1, _3 )\n# 450 \"graphql_parser/src/parser.ml\"\n in\n \n# 213 \"\"\n ( x :: xs )\n# 455 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list___anonymous_0_const_value__ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState100 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : ((string * Ast.const_value) list))) = _menhir_stack in\n let _v : (Ast.const_value) = \n# 176 \"graphql_parser/src/parser.mly\"\n ( `Assoc _2 )\n# 471 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_list_value_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.value list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState44 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.value))), _, (xs : (Ast.value list))) = _menhir_stack in\n let _v : (Ast.value list) = \n# 213 \"\"\n ( x :: xs )\n# 494 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_value_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState28 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RBRACK ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (Ast.value list))) = _menhir_stack in\n let _v : (Ast.value) = \n# 175 \"graphql_parser/src/parser.mly\"\n ( `List _2 )\n# 510 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_list___anonymous_0_value__ : _menhir_env -> 'ttv_tail -> _menhir_state -> ((string * Ast.value) list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState38 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (((_menhir_stack, _menhir_s, (_1 : (string))), _, (_3 : (Ast.value))), _, (xs : ((string * Ast.value) list))) = _menhir_stack in\n let _v : ((string * Ast.value) list) = let x = \n# 176 \"graphql_parser/src/parser.mly\"\n ( _1, _3 )\n# 533 \"graphql_parser/src/parser.ml\"\n in\n \n# 213 \"\"\n ( x :: xs )\n# 538 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list___anonymous_0_value__ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState29 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : ((string * Ast.value) list))) = _menhir_stack in\n let _v : (Ast.value) = \n# 176 \"graphql_parser/src/parser.mly\"\n ( `Assoc _2 )\n# 554 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_list_argument_ : _menhir_env -> 'ttv_tail -> _menhir_state -> ((string * Ast.value) list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState22 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RPAREN ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : ((string * Ast.value) list))) = _menhir_stack in\n let _v : ((string * Ast.value) list) = \n# 163 \"graphql_parser/src/parser.mly\"\n ( _2 )\n# 583 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (x : ((string * Ast.value) list)) = _v in\n let _v : ((string * Ast.value) list) = \n# 144 \"\"\n ( x )\n# 591 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_arguments_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState51 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (string * Ast.value))), _, (xs : ((string * Ast.value) list))) = _menhir_stack in\n let _v : ((string * Ast.value) list) = \n# 213 \"\"\n ( x :: xs )\n# 607 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_argument_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_reduce40 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : (Ast.selection list) = \n# 142 \"\"\n ( [] )\n# 618 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_selection_set_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_selection : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.selection) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState61 _v\n | ELLIPSIS ->\n _menhir_run12 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState61 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState61\n | RBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (x : (Ast.selection))) = _menhir_stack in\n let _v : (Ast.selection list) = \n# 221 \"\"\n ( [ x ] )\n# 653 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_nonempty_list_selection_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState61\n\nand _menhir_goto_list_variable_definition_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.variable_definition list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState119 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.variable_definition))), _, (xs : (Ast.variable_definition list))) = _menhir_stack in\n let _v : (Ast.variable_definition list) = \n# 213 \"\"\n ( x :: xs )\n# 672 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_variable_definition_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState86 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | RPAREN ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _, (_2 : (Ast.variable_definition list))) = _menhir_stack in\n let _v : (Ast.variable_definition list) = \n# 134 \"graphql_parser/src/parser.mly\"\n ( _2 )\n# 688 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (x : (Ast.variable_definition list)) = _v in\n let _v : (Ast.variable_definition list) = \n# 144 \"\"\n ( x )\n# 696 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_variable_definitions_ _menhir_env _menhir_stack _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_reduce30 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : (Ast.const_value list) = \n# 211 \"\"\n ( [] )\n# 713 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_reduce24 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : ((string * Ast.const_value) list) = \n# 211 \"\"\n ( [] )\n# 722 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list___anonymous_0_const_value__ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_option_default_value_ : _menhir_env -> 'ttv_tail -> (Ast.const_value option) -> 'ttv_return =\n fun _menhir_env _menhir_stack _v ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_5 : (Ast.const_value option)) = _v in\n let (((_menhir_stack, _menhir_s), _, (_2 : (string))), _, (_4 : (Ast.typ))) = _menhir_stack in\n let _v : (Ast.variable_definition) = \n# 140 \"graphql_parser/src/parser.mly\"\n (\n {\n name = _2;\n typ = _4;\n default_value = _5;\n }\n )\n# 741 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | DOLLAR ->\n _menhir_run87 _menhir_env (Obj.magic _menhir_stack) MenhirState119\n | RPAREN ->\n _menhir_reduce36 _menhir_env (Obj.magic _menhir_stack) MenhirState119\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState119\n\nand _menhir_run93 : _menhir_env -> 'ttv_tail * _menhir_state * (Ast.typ) -> 'ttv_return =\n fun _menhir_env _menhir_stack ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (_1 : (Ast.typ))) = _menhir_stack in\n let _v : (Ast.typ) = \n# 151 \"graphql_parser/src/parser.mly\"\n ( NonNullType _1 )\n# 765 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_typ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_reduce34 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : (Ast.value list) = \n# 211 \"\"\n ( [] )\n# 774 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_reduce26 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : ((string * Ast.value) list) = \n# 211 \"\"\n ( [] )\n# 783 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list___anonymous_0_value__ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_loption_arguments_ : _menhir_env -> 'ttv_tail -> _menhir_state -> ((string * Ast.value) list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState21 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (((_menhir_stack, _menhir_s), _, (_2 : (string))), _, (_3 : ((string * Ast.value) list))) = _menhir_stack in\n let _v : (Ast.directive) = \n# 155 \"graphql_parser/src/parser.mly\"\n (\n {\n name = _2;\n arguments = _3;\n }\n )\n# 803 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState57\n | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState57\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState57)\n | MenhirState65 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState66\n | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState66\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState66)\n | MenhirState63 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState70\n | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState70\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState70)\n | _ ->\n _menhir_fail ()\n\nand _menhir_reduce28 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : ((string * Ast.value) list) = \n# 211 \"\"\n ( [] )\n# 852 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_argument_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_value_parser_const_value_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.const_value) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.const_value)) = _v in\n let _v : (Ast.const_value) = \n# 183 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 864 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState102 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState108 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState108 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | RBRACE ->\n _menhir_reduce24 _menhir_env (Obj.magic _menhir_stack) MenhirState108\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState108)\n | MenhirState114 | MenhirState99 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run105 _menhir_env (Obj.magic _menhir_stack) MenhirState114 _v\n | FLOAT _v ->\n _menhir_run104 _menhir_env (Obj.magic _menhir_stack) MenhirState114 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | INT _v ->\n _menhir_run103 _menhir_env (Obj.magic _menhir_stack) MenhirState114 _v\n | LBRACE ->\n _menhir_run100 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | LBRACK ->\n _menhir_run99 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState114 _v\n | NULL ->\n _menhir_run98 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | STRING _v ->\n _menhir_run97 _menhir_env (Obj.magic _menhir_stack) MenhirState114 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | RBRACK ->\n _menhir_reduce30 _menhir_env (Obj.magic _menhir_stack) MenhirState114\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState114)\n | MenhirState96 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _, (_2 : (Ast.const_value))) = _menhir_stack in\n let _v : (Ast.const_value) = \n# 137 \"graphql_parser/src/parser.mly\"\n ( _2 )\n# 937 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (x : (Ast.const_value)) = _v in\n let _v : (Ast.const_value option) = \n# 116 \"\"\n ( Some x )\n# 945 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_default_value_ _menhir_env _menhir_stack _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_value_parser_value_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.value) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.value)) = _v in\n let _v : (Ast.value) = \n# 180 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 959 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_list_directive_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.directive list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState19 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState55\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState55)\n | MenhirState57 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (x : (Ast.directive))), _, (xs : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.directive list) = \n# 213 \"\"\n ( x :: xs )\n# 985 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_directive_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState59 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (((_menhir_stack, _menhir_s), _, (_2 : (string))), _, (_3 : (Ast.directive list))) = _menhir_stack in\n let _v : (Ast.selection) = \n# 113 \"graphql_parser/src/parser.mly\"\n (\n FragmentSpread {\n name = _2;\n directives = _3;\n }\n )\n# 1000 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (Ast.selection)) = _v in\n let _v : (Ast.selection) = \n# 87 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 1008 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_selection _menhir_env _menhir_stack _menhir_s _v\n | MenhirState66 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState67\n | BOOL _ | ELLIPSIS | FRAGMENT | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce40 _menhir_env (Obj.magic _menhir_stack) MenhirState67\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState67)\n | MenhirState70 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState71\n | BOOL _ | ELLIPSIS | FRAGMENT | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce40 _menhir_env (Obj.magic _menhir_stack) MenhirState71\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState71)\n | MenhirState80 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState81\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState81)\n | MenhirState124 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState125\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState125)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_loption_variable_definitions_ : _menhir_env -> 'ttv_tail -> (Ast.variable_definition list) -> 'ttv_return =\n fun _menhir_env _menhir_stack _v ->\n let _menhir_stack = (_menhir_stack, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState124\n | LBRACE ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState124\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState124\n\nand _menhir_reduce36 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : (Ast.variable_definition list) = \n# 211 \"\"\n ( [] )\n# 1083 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_variable_definition_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run87 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState87 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState87 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState87\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState87\n\nand _menhir_run97 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 8 \"graphql_parser/src/parser.mly\"\n (string)\n# 1117 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 8 \"graphql_parser/src/parser.mly\"\n (string)\n# 1125 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.const_value) = \n# 172 \"graphql_parser/src/parser.mly\"\n ( `String _1 )\n# 1130 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run98 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.const_value) = \n# 169 \"graphql_parser/src/parser.mly\"\n ( `Null )\n# 1141 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run99 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run105 _menhir_env (Obj.magic _menhir_stack) MenhirState99 _v\n | FLOAT _v ->\n _menhir_run104 _menhir_env (Obj.magic _menhir_stack) MenhirState99 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | INT _v ->\n _menhir_run103 _menhir_env (Obj.magic _menhir_stack) MenhirState99 _v\n | LBRACE ->\n _menhir_run100 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | LBRACK ->\n _menhir_run99 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState99 _v\n | NULL ->\n _menhir_run98 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | STRING _v ->\n _menhir_run97 _menhir_env (Obj.magic _menhir_stack) MenhirState99 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | RBRACK ->\n _menhir_reduce30 _menhir_env (Obj.magic _menhir_stack) MenhirState99\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState99\n\nand _menhir_run100 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState100 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState100 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | RBRACE ->\n _menhir_reduce24 _menhir_env (Obj.magic _menhir_stack) MenhirState100\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState100\n\nand _menhir_run103 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 6 \"graphql_parser/src/parser.mly\"\n (int)\n# 1214 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 6 \"graphql_parser/src/parser.mly\"\n (int)\n# 1222 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.const_value) = \n# 170 \"graphql_parser/src/parser.mly\"\n ( `Int _1 )\n# 1227 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run104 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 7 \"graphql_parser/src/parser.mly\"\n (float)\n# 1234 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 7 \"graphql_parser/src/parser.mly\"\n (float)\n# 1242 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.const_value) = \n# 171 \"graphql_parser/src/parser.mly\"\n ( `Float _1 )\n# 1247 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run105 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 1254 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 1262 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.const_value) = \n# 173 \"graphql_parser/src/parser.mly\"\n ( `Bool _1 )\n# 1267 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_goto_typ : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.typ) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState90 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BANG ->\n _menhir_run93 _menhir_env (Obj.magic _menhir_stack)\n | RBRACK ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (Ast.typ))) = _menhir_stack in\n let _v : (Ast.typ) = \n# 150 \"graphql_parser/src/parser.mly\"\n ( ListType _2 )\n# 1290 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_typ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState89 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BANG ->\n _menhir_run93 _menhir_env (Obj.magic _menhir_stack)\n | EQUAL ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run105 _menhir_env (Obj.magic _menhir_stack) MenhirState96 _v\n | FLOAT _v ->\n _menhir_run104 _menhir_env (Obj.magic _menhir_stack) MenhirState96 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | INT _v ->\n _menhir_run103 _menhir_env (Obj.magic _menhir_stack) MenhirState96 _v\n | LBRACE ->\n _menhir_run100 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | LBRACK ->\n _menhir_run99 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState96 _v\n | NULL ->\n _menhir_run98 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | STRING _v ->\n _menhir_run97 _menhir_env (Obj.magic _menhir_stack) MenhirState96 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState96\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState96)\n | DOLLAR | RPAREN ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.const_value option) = \n# 114 \"\"\n ( None )\n# 1344 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_default_value_ _menhir_env _menhir_stack _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | _ ->\n _menhir_fail ()\n\nand _menhir_run90 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState90 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | LBRACK ->\n _menhir_run90 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState90 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState90\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState90\n\nand _menhir_goto_value : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.value) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState31 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState38 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState38 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | RBRACE ->\n _menhir_reduce26 _menhir_env (Obj.magic _menhir_stack) MenhirState38\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState38)\n | MenhirState44 | MenhirState28 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run36 _menhir_env (Obj.magic _menhir_stack) MenhirState44 _v\n | DOLLAR ->\n _menhir_run34 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | FLOAT _v ->\n _menhir_run33 _menhir_env (Obj.magic _menhir_stack) MenhirState44 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | INT _v ->\n _menhir_run32 _menhir_env (Obj.magic _menhir_stack) MenhirState44 _v\n | LBRACE ->\n _menhir_run29 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | LBRACK ->\n _menhir_run28 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState44 _v\n | NULL ->\n _menhir_run26 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | STRING _v ->\n _menhir_run25 _menhir_env (Obj.magic _menhir_stack) MenhirState44 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | RBRACK ->\n _menhir_reduce34 _menhir_env (Obj.magic _menhir_stack) MenhirState44\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState44)\n | MenhirState24 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, (_1 : (string))), _, (_3 : (Ast.value))) = _menhir_stack in\n let _v : (string * Ast.value) = \n# 166 \"graphql_parser/src/parser.mly\"\n ( _1, _3 )\n# 1460 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState51 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState51 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | RPAREN ->\n _menhir_reduce28 _menhir_env (Obj.magic _menhir_stack) MenhirState51\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState51)\n | _ ->\n _menhir_fail ()\n\nand _menhir_run25 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 8 \"graphql_parser/src/parser.mly\"\n (string)\n# 1495 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 8 \"graphql_parser/src/parser.mly\"\n (string)\n# 1503 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.value) = \n# 172 \"graphql_parser/src/parser.mly\"\n ( `String _1 )\n# 1508 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run26 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.value) = \n# 169 \"graphql_parser/src/parser.mly\"\n ( `Null )\n# 1519 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run27 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 5 \"graphql_parser/src/parser.mly\"\n (string)\n# 1526 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 5 \"graphql_parser/src/parser.mly\"\n (string)\n# 1534 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (string) = \n# 193 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 1539 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_enum_value _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run28 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run36 _menhir_env (Obj.magic _menhir_stack) MenhirState28 _v\n | DOLLAR ->\n _menhir_run34 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | FLOAT _v ->\n _menhir_run33 _menhir_env (Obj.magic _menhir_stack) MenhirState28 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | INT _v ->\n _menhir_run32 _menhir_env (Obj.magic _menhir_stack) MenhirState28 _v\n | LBRACE ->\n _menhir_run29 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | LBRACK ->\n _menhir_run28 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState28 _v\n | NULL ->\n _menhir_run26 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | STRING _v ->\n _menhir_run25 _menhir_env (Obj.magic _menhir_stack) MenhirState28 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | RBRACK ->\n _menhir_reduce34 _menhir_env (Obj.magic _menhir_stack) MenhirState28\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState28\n\nand _menhir_run29 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState29 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState29 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | RBRACE ->\n _menhir_reduce26 _menhir_env (Obj.magic _menhir_stack) MenhirState29\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState29\n\nand _menhir_run32 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 6 \"graphql_parser/src/parser.mly\"\n (int)\n# 1614 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 6 \"graphql_parser/src/parser.mly\"\n (int)\n# 1622 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.value) = \n# 170 \"graphql_parser/src/parser.mly\"\n ( `Int _1 )\n# 1627 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run33 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 7 \"graphql_parser/src/parser.mly\"\n (float)\n# 1634 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 7 \"graphql_parser/src/parser.mly\"\n (float)\n# 1642 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.value) = \n# 171 \"graphql_parser/src/parser.mly\"\n ( `Float _1 )\n# 1647 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run34 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState34 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState34 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState34\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState34\n\nand _menhir_run36 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 1681 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 1689 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (Ast.value) = \n# 173 \"graphql_parser/src/parser.mly\"\n ( `Bool _1 )\n# 1694 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_reduce38 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : ((string * Ast.value) list) = \n# 142 \"\"\n ( [] )\n# 1703 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_arguments_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run22 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState22 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState22 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | RPAREN ->\n _menhir_reduce28 _menhir_env (Obj.magic _menhir_stack) MenhirState22\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState22\n\nand _menhir_goto_enum_value : _menhir_env -> 'ttv_tail -> _menhir_state -> (string) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n match _menhir_s with\n | MenhirState24 | MenhirState28 | MenhirState44 | MenhirState31 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (string)) = _v in\n let _v : (Ast.value) = \n# 174 \"graphql_parser/src/parser.mly\"\n ( `Enum _1 )\n# 1746 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_value_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState96 | MenhirState114 | MenhirState99 | MenhirState102 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (string)) = _v in\n let _v : (Ast.const_value) = \n# 174 \"graphql_parser/src/parser.mly\"\n ( `Enum _1 )\n# 1756 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value_parser_const_value_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_fail : unit -> 'a =\n fun () ->\n Printf.fprintf stderr \"Internal failure -- please contact the parser generator's developers.\\n%!\";\n assert false\n\nand _menhir_reduce32 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _v : (Ast.directive list) = \n# 211 \"\"\n ( [] )\n# 1772 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_list_directive_ _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run20 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState20 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState20 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState20\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState20\n\nand _menhir_goto_option_name_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (string option) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | LPAREN ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | DOLLAR ->\n _menhir_run87 _menhir_env (Obj.magic _menhir_stack) MenhirState86\n | RPAREN ->\n _menhir_reduce36 _menhir_env (Obj.magic _menhir_stack) MenhirState86\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState86)\n | AT | LBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.variable_definition list) = \n# 142 \"\"\n ( [] )\n# 1828 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_loption_variable_definitions_ _menhir_env _menhir_stack _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n\nand _menhir_goto_name : _menhir_env -> 'ttv_tail -> _menhir_state -> (string) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState13 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (string))) = _menhir_stack in\n let _v : (string) = \n# 121 \"graphql_parser/src/parser.mly\"\n ( _2 )\n# 1849 \"graphql_parser/src/parser.ml\"\n in\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n (match _menhir_s with\n | MenhirState12 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (x : (string))) = _menhir_stack in\n let _v : (string option) = \n# 116 \"\"\n ( Some x )\n# 1860 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_type_condition_ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState79 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState80\n | LBRACE ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState80\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState80)\n | _ ->\n _menhir_fail ())\n | MenhirState20 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LPAREN ->\n _menhir_run22 _menhir_env (Obj.magic _menhir_stack) MenhirState21\n | AT | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce38 _menhir_env (Obj.magic _menhir_stack) MenhirState21\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState21)\n | MenhirState51 | MenhirState22 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | COLON ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run36 _menhir_env (Obj.magic _menhir_stack) MenhirState24 _v\n | DOLLAR ->\n _menhir_run34 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | FLOAT _v ->\n _menhir_run33 _menhir_env (Obj.magic _menhir_stack) MenhirState24 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | INT _v ->\n _menhir_run32 _menhir_env (Obj.magic _menhir_stack) MenhirState24 _v\n | LBRACE ->\n _menhir_run29 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | LBRACK ->\n _menhir_run28 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState24 _v\n | NULL ->\n _menhir_run26 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | STRING _v ->\n _menhir_run25 _menhir_env (Obj.magic _menhir_stack) MenhirState24 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState24\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState24)\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState38 | MenhirState29 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | COLON ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run36 _menhir_env (Obj.magic _menhir_stack) MenhirState31 _v\n | DOLLAR ->\n _menhir_run34 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | FLOAT _v ->\n _menhir_run33 _menhir_env (Obj.magic _menhir_stack) MenhirState31 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | INT _v ->\n _menhir_run32 _menhir_env (Obj.magic _menhir_stack) MenhirState31 _v\n | LBRACE ->\n _menhir_run29 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | LBRACK ->\n _menhir_run28 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState31 _v\n | NULL ->\n _menhir_run26 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | STRING _v ->\n _menhir_run25 _menhir_env (Obj.magic _menhir_stack) MenhirState31 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState31\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState31)\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState34 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s), _, (_2 : (string))) = _menhir_stack in\n let _v : (Ast.value) = \n# 179 \"graphql_parser/src/parser.mly\"\n ( `Variable _2 )\n# 1990 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_value _menhir_env _menhir_stack _menhir_s _v\n | MenhirState4 | MenhirState61 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | COLON ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_s = MenhirState63 in\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState64 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState64 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState64\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState64)\n | LPAREN ->\n _menhir_run22 _menhir_env (Obj.magic _menhir_stack) MenhirState63\n | AT | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce38 _menhir_env (Obj.magic _menhir_stack) MenhirState63\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState63)\n | MenhirState64 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | LPAREN ->\n _menhir_run22 _menhir_env (Obj.magic _menhir_stack) MenhirState65\n | AT | BOOL _ | ELLIPSIS | FRAGMENT | LBRACE | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce38 _menhir_env (Obj.magic _menhir_stack) MenhirState65\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState65)\n | MenhirState87 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | COLON ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState89 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | LBRACK ->\n _menhir_run90 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState89 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState89\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState89)\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState89 | MenhirState90 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (_1 : (string))) = _menhir_stack in\n let _v : (Ast.typ) = \n# 149 \"graphql_parser/src/parser.mly\"\n ( NamedType _1 )\n# 2091 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_typ _menhir_env _menhir_stack _menhir_s _v\n | MenhirState108 | MenhirState100 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | COLON ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | BOOL _v ->\n _menhir_run105 _menhir_env (Obj.magic _menhir_stack) MenhirState102 _v\n | FLOAT _v ->\n _menhir_run104 _menhir_env (Obj.magic _menhir_stack) MenhirState102 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | INT _v ->\n _menhir_run103 _menhir_env (Obj.magic _menhir_stack) MenhirState102 _v\n | LBRACE ->\n _menhir_run100 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | LBRACK ->\n _menhir_run99 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | NAME _v ->\n _menhir_run27 _menhir_env (Obj.magic _menhir_stack) MenhirState102 _v\n | NULL ->\n _menhir_run98 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | STRING _v ->\n _menhir_run97 _menhir_env (Obj.magic _menhir_stack) MenhirState102 _v\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState102\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState102)\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s)\n | MenhirState84 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (x : (string))) = _menhir_stack in\n let _v : (string option) = \n# 116 \"\"\n ( Some x )\n# 2145 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_name_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_option_type_condition_ : _menhir_env -> 'ttv_tail -> _menhir_state -> (string option) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState19\n | LBRACE ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState19\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState19\n\nand _menhir_run13 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState13 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState13 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState13\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState13\n\nand _menhir_goto_keyword_name : _menhir_env -> 'ttv_tail -> _menhir_state -> (string) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n match _menhir_s with\n | MenhirState84 | MenhirState87 | MenhirState89 | MenhirState100 | MenhirState108 | MenhirState90 | MenhirState78 | MenhirState4 | MenhirState61 | MenhirState64 | MenhirState12 | MenhirState20 | MenhirState51 | MenhirState22 | MenhirState29 | MenhirState38 | MenhirState34 | MenhirState13 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (string)) = _v in\n let _v : (string) = \n# 199 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 2204 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_fragment_name _menhir_env _menhir_stack _menhir_s _v\n | MenhirState96 | MenhirState114 | MenhirState99 | MenhirState102 | MenhirState24 | MenhirState28 | MenhirState44 | MenhirState31 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (string)) = _v in\n let _v : (string) = \n# 193 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 2214 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_enum_value _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_fragment_name : _menhir_env -> 'ttv_tail -> _menhir_state -> (string) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n match _menhir_s with\n | MenhirState84 | MenhirState87 | MenhirState89 | MenhirState100 | MenhirState108 | MenhirState90 | MenhirState4 | MenhirState61 | MenhirState64 | MenhirState20 | MenhirState51 | MenhirState22 | MenhirState29 | MenhirState38 | MenhirState34 | MenhirState13 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, (_1 : (string))) = _menhir_stack in\n let _v : (string) = \n# 202 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 2231 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_name _menhir_env _menhir_stack _menhir_s _v\n | MenhirState12 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | AT ->\n _menhir_run20 _menhir_env (Obj.magic _menhir_stack) MenhirState59\n | BOOL _ | ELLIPSIS | FRAGMENT | MUTATION | NAME _ | NULL | ON | QUERY | RBRACE | SUBSCRIPTION ->\n _menhir_reduce32 _menhir_env (Obj.magic _menhir_stack) MenhirState59\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState59)\n | MenhirState78 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n (match _tok with\n | ON ->\n _menhir_run13 _menhir_env (Obj.magic _menhir_stack) MenhirState79\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState79)\n | _ ->\n _menhir_fail ()\n\nand _menhir_goto_optype : _menhir_env -> 'ttv_tail -> _menhir_state -> (Ast.optype) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_stack = (_menhir_stack, _menhir_s, _v) in\n let _menhir_stack = Obj.magic _menhir_stack in\n assert (not _menhir_env._menhir_error);\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState84 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState84 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState84\n | AT | LBRACE | LPAREN ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_s = MenhirState84 in\n let _v : (string option) = \n# 114 \"\"\n ( None )\n# 2290 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_name_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState84\n\nand _menhir_run7 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 203 \"graphql_parser/src/parser.mly\"\n ( \"on\" )\n# 2305 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run12 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState12 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState12 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | ON ->\n _menhir_run13 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState12\n | AT | LBRACE ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let _menhir_s = MenhirState12 in\n let _v : (string option) = \n# 114 \"\"\n ( None )\n# 2337 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_option_type_condition_ _menhir_env _menhir_stack _menhir_s _v\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState12\n\nand _menhir_run5 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 188 \"graphql_parser/src/parser.mly\"\n ( \"subscription\" )\n# 2352 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_keyword_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run6 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 186 \"graphql_parser/src/parser.mly\"\n ( \"query\" )\n# 2363 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_keyword_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run8 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 196 \"graphql_parser/src/parser.mly\"\n ( \"null\" )\n# 2374 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_fragment_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run9 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 5 \"graphql_parser/src/parser.mly\"\n (string)\n# 2381 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 5 \"graphql_parser/src/parser.mly\"\n (string)\n# 2389 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (string) = \n# 199 \"graphql_parser/src/parser.mly\"\n ( _1 )\n# 2394 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_fragment_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run10 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 187 \"graphql_parser/src/parser.mly\"\n ( \"mutation\" )\n# 2405 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_keyword_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run11 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (string) = \n# 189 \"graphql_parser/src/parser.mly\"\n ( \"fragment\" )\n# 2416 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_keyword_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run14 : _menhir_env -> 'ttv_tail -> _menhir_state -> (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 2423 \"graphql_parser/src/parser.ml\"\n) -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s _v ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_1 : (\n# 9 \"graphql_parser/src/parser.mly\"\n (bool)\n# 2431 \"graphql_parser/src/parser.ml\"\n )) = _v in\n let _v : (string) = \n# 197 \"graphql_parser/src/parser.mly\"\n ( string_of_bool _1 )\n# 2436 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_fragment_name _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_errorcase : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n match _menhir_s with\n | MenhirState133 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState125 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState124 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let ((_menhir_stack, _menhir_s, _), _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState119 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState114 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState108 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState102 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState100 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState99 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState96 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n raise _eRR\n | MenhirState90 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState89 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState87 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState86 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n raise _eRR\n | MenhirState84 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState81 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState80 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState79 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState78 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState71 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState70 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState67 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState66 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState65 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState64 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState63 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState61 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState59 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState57 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState55 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState51 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState44 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState38 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState34 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState31 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState29 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState28 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState24 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState22 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState21 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState20 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState19 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s, _) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState13 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState12 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState4 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n let (_menhir_stack, _menhir_s) = _menhir_stack in\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) _menhir_s\n | MenhirState0 ->\n let _menhir_stack = Obj.magic _menhir_stack in\n raise _eRR\n\nand _menhir_run1 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.optype) = \n# 79 \"graphql_parser/src/parser.mly\"\n ( Subscription )\n# 2632 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_optype _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run2 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.optype) = \n# 77 \"graphql_parser/src/parser.mly\"\n ( Query )\n# 2643 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_optype _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run3 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_env = _menhir_discard _menhir_env in\n let _menhir_stack = Obj.magic _menhir_stack in\n let _v : (Ast.optype) = \n# 78 \"graphql_parser/src/parser.mly\"\n ( Mutation )\n# 2654 \"graphql_parser/src/parser.ml\"\n in\n _menhir_goto_optype _menhir_env _menhir_stack _menhir_s _v\n\nand _menhir_run4 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState4 _v\n | ELLIPSIS ->\n _menhir_run12 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState4 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | ON ->\n _menhir_run7 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState4\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState4\n\nand _menhir_run78 : _menhir_env -> 'ttv_tail -> _menhir_state -> 'ttv_return =\n fun _menhir_env _menhir_stack _menhir_s ->\n let _menhir_stack = (_menhir_stack, _menhir_s) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | BOOL _v ->\n _menhir_run14 _menhir_env (Obj.magic _menhir_stack) MenhirState78 _v\n | FRAGMENT ->\n _menhir_run11 _menhir_env (Obj.magic _menhir_stack) MenhirState78\n | MUTATION ->\n _menhir_run10 _menhir_env (Obj.magic _menhir_stack) MenhirState78\n | NAME _v ->\n _menhir_run9 _menhir_env (Obj.magic _menhir_stack) MenhirState78 _v\n | NULL ->\n _menhir_run8 _menhir_env (Obj.magic _menhir_stack) MenhirState78\n | QUERY ->\n _menhir_run6 _menhir_env (Obj.magic _menhir_stack) MenhirState78\n | SUBSCRIPTION ->\n _menhir_run5 _menhir_env (Obj.magic _menhir_stack) MenhirState78\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState78\n\nand _menhir_discard : _menhir_env -> _menhir_env =\n fun _menhir_env ->\n let lexer = _menhir_env._menhir_lexer in\n let lexbuf = _menhir_env._menhir_lexbuf in\n let _tok = lexer lexbuf in\n {\n _menhir_lexer = lexer;\n _menhir_lexbuf = lexbuf;\n _menhir_token = _tok;\n _menhir_error = false;\n }\n\nand doc : (Lexing.lexbuf -> token) -> Lexing.lexbuf -> (Ast.document) =\n fun lexer lexbuf ->\n let _menhir_env = {\n _menhir_lexer = lexer;\n _menhir_lexbuf = lexbuf;\n _menhir_token = Obj.magic ();\n _menhir_error = false;\n } in\n Obj.magic (let _menhir_stack = ((), _menhir_env._menhir_lexbuf.Lexing.lex_curr_p) in\n let _menhir_env = _menhir_discard _menhir_env in\n let _tok = _menhir_env._menhir_token in\n match _tok with\n | FRAGMENT ->\n _menhir_run78 _menhir_env (Obj.magic _menhir_stack) MenhirState0\n | LBRACE ->\n _menhir_run4 _menhir_env (Obj.magic _menhir_stack) MenhirState0\n | MUTATION ->\n _menhir_run3 _menhir_env (Obj.magic _menhir_stack) MenhirState0\n | QUERY ->\n _menhir_run2 _menhir_env (Obj.magic _menhir_stack) MenhirState0\n | SUBSCRIPTION ->\n _menhir_run1 _menhir_env (Obj.magic _menhir_stack) MenhirState0\n | _ ->\n assert (not _menhir_env._menhir_error);\n _menhir_env._menhir_error <- true;\n _menhir_errorcase _menhir_env (Obj.magic _menhir_stack) MenhirState0)\n\n# 269 \"\"\n \n\n# 2754 \"graphql_parser/src/parser.ml\"\n","# 1 \"graphql_parser/src/lexer.mll\"\n \nopen Lexing\nopen Parser\n\nexception Error of string\n\n# 9 \"graphql_parser/src/lexer.ml\"\nlet __ocaml_lex_tables = {\n Lexing.lex_base =\n \"\\000\\000\\227\\255\\228\\255\\229\\255\\230\\255\\231\\255\\232\\255\\233\\255\\\n \\234\\255\\235\\255\\001\\000\\237\\255\\238\\255\\239\\255\\240\\255\\078\\000\\\n \\160\\000\\235\\000\\054\\001\\129\\001\\204\\001\\023\\002\\098\\002\\250\\255\\\n \\175\\002\\176\\002\\185\\002\\253\\255\\001\\000\\191\\000\\234\\002\\203\\002\\\n \\231\\002\\241\\002\\007\\003\\017\\003\\027\\003\\039\\003\\049\\003\\059\\003\\\n \\134\\003\\209\\003\\028\\004\\103\\004\\178\\004\\253\\004\\072\\005\\147\\005\\\n \\222\\005\\041\\006\\116\\006\\191\\006\\010\\007\\085\\007\\160\\007\\235\\007\\\n \\054\\008\\129\\008\\204\\008\\023\\009\\098\\009\\173\\009\\248\\009\\067\\010\\\n \\142\\010\\217\\010\\036\\011\\111\\011\\186\\011\\005\\012\\080\\012\\155\\012\\\n \\230\\012\\049\\013\\124\\013\\199\\013\\018\\014\\093\\014\\168\\014\\013\\000\\\n \\236\\255\\025\\015\\026\\015\\006\\015\\255\\255\\247\\255\\248\\255\\249\\255\\\n \\250\\255\\251\\255\\252\\255\\253\\255\\254\\255\";\n Lexing.lex_backtrk =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\027\\000\\255\\255\\255\\255\\255\\255\\255\\255\\014\\000\\\n \\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\255\\255\\\n \\003\\000\\003\\000\\027\\000\\255\\255\\002\\000\\001\\000\\000\\000\\255\\255\\\n \\255\\255\\004\\000\\255\\255\\004\\000\\255\\255\\004\\000\\255\\255\\014\\000\\\n \\014\\000\\014\\000\\014\\000\\006\\000\\014\\000\\014\\000\\014\\000\\014\\000\\\n \\014\\000\\007\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\\n \\008\\000\\014\\000\\014\\000\\009\\000\\010\\000\\014\\000\\014\\000\\014\\000\\\n \\011\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\014\\000\\\n \\014\\000\\014\\000\\014\\000\\012\\000\\014\\000\\014\\000\\013\\000\\255\\255\\\n \\255\\255\\255\\255\\009\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\";\n Lexing.lex_default =\n \"\\002\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\000\\000\\\n \\255\\255\\255\\255\\255\\255\\000\\000\\255\\255\\029\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\082\\000\\082\\000\\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\";\n Lexing.lex_trans =\n \"\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\030\\000\\027\\000\\027\\000\\000\\000\\028\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\030\\000\\014\\000\\023\\000\\029\\000\\013\\000\\000\\000\\000\\000\\000\\000\\\n \\012\\000\\011\\000\\000\\000\\000\\000\\030\\000\\026\\000\\010\\000\\079\\000\\\n \\025\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\\n \\024\\000\\024\\000\\009\\000\\080\\000\\000\\000\\008\\000\\000\\000\\000\\000\\\n \\007\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\006\\000\\000\\000\\005\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\022\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\021\\000\\020\\000\\019\\000\\\n \\015\\000\\018\\000\\015\\000\\017\\000\\016\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\004\\000\\000\\000\\003\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\255\\255\\000\\000\\000\\000\\255\\255\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\001\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\076\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\065\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\061\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\060\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\057\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\050\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\040\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\039\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\032\\000\\032\\000\\024\\000\\\n \\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\\n \\024\\000\\025\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\\n \\024\\000\\024\\000\\024\\000\\030\\000\\031\\000\\031\\000\\038\\000\\000\\000\\\n \\038\\000\\000\\000\\000\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\\n \\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\030\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\031\\000\\031\\000\\030\\000\\033\\000\\\n \\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\\n \\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\\n \\033\\000\\033\\000\\033\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\036\\000\\000\\000\\036\\000\\000\\000\\034\\000\\035\\000\\\n \\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\\n \\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\\n \\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\\n \\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\000\\000\\034\\000\\037\\000\\\n \\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\\n \\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\\n \\037\\000\\037\\000\\037\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\044\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\041\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\042\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\043\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\045\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\046\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\047\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\048\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\049\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\051\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\052\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\053\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\054\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\055\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\056\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\058\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\059\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\062\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\063\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\064\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\066\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\067\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\015\\000\\015\\000\\068\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\069\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\070\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\071\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\072\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\073\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\074\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\075\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\077\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\078\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\000\\000\\000\\000\\000\\000\\000\\000\\015\\000\\\n \\000\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\255\\255\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\092\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\090\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\084\\000\\255\\255\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\091\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\089\\000\\000\\000\\000\\000\\000\\000\\088\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\087\\000\\083\\000\\255\\255\\000\\000\\\n \\086\\000\\000\\000\\085\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\255\\255\\255\\255\";\n Lexing.lex_check =\n \"\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\000\\000\\000\\000\\028\\000\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\255\\255\\255\\255\\\n \\000\\000\\000\\000\\255\\255\\255\\255\\000\\000\\000\\000\\000\\000\\010\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\079\\000\\255\\255\\000\\000\\255\\255\\255\\255\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\255\\255\\000\\000\\\n \\255\\255\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\\n \\000\\000\\000\\000\\000\\000\\000\\000\\255\\255\\000\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\255\\255\\255\\255\\255\\255\\255\\255\\015\\000\\255\\255\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\015\\000\\\n \\015\\000\\029\\000\\255\\255\\255\\255\\029\\000\\255\\255\\255\\255\\255\\255\\\n \\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\255\\255\\255\\255\\255\\255\\255\\255\\016\\000\\\n \\000\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\016\\000\\\n \\016\\000\\016\\000\\016\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\017\\000\\255\\255\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\\n \\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\017\\000\\018\\000\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\255\\255\\255\\255\\255\\255\\255\\255\\018\\000\\255\\255\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\018\\000\\\n \\018\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\255\\255\\255\\255\\255\\255\\255\\255\\029\\000\\\n \\255\\255\\255\\255\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\019\\000\\255\\255\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\019\\000\\\n \\019\\000\\019\\000\\019\\000\\019\\000\\020\\000\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\020\\000\\255\\255\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\\n \\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\020\\000\\021\\000\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\255\\255\\255\\255\\255\\255\\255\\255\\021\\000\\255\\255\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\021\\000\\\n \\021\\000\\021\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\022\\000\\255\\255\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\\n \\022\\000\\022\\000\\022\\000\\022\\000\\022\\000\\024\\000\\025\\000\\024\\000\\\n \\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\024\\000\\\n \\024\\000\\026\\000\\026\\000\\026\\000\\026\\000\\026\\000\\026\\000\\026\\000\\\n \\026\\000\\026\\000\\026\\000\\030\\000\\024\\000\\025\\000\\031\\000\\255\\255\\\n \\031\\000\\255\\255\\255\\255\\031\\000\\031\\000\\031\\000\\031\\000\\031\\000\\\n \\031\\000\\031\\000\\031\\000\\031\\000\\031\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\030\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\024\\000\\025\\000\\030\\000\\032\\000\\\n \\032\\000\\032\\000\\032\\000\\032\\000\\032\\000\\032\\000\\032\\000\\032\\000\\\n \\032\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\033\\000\\\n \\033\\000\\033\\000\\033\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\034\\000\\255\\255\\034\\000\\255\\255\\033\\000\\034\\000\\\n \\034\\000\\034\\000\\034\\000\\034\\000\\034\\000\\034\\000\\034\\000\\034\\000\\\n \\034\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\035\\000\\\n \\035\\000\\035\\000\\035\\000\\036\\000\\036\\000\\036\\000\\036\\000\\036\\000\\\n \\036\\000\\036\\000\\036\\000\\036\\000\\036\\000\\255\\255\\033\\000\\037\\000\\\n \\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\037\\000\\\n \\037\\000\\038\\000\\038\\000\\038\\000\\038\\000\\038\\000\\038\\000\\038\\000\\\n \\038\\000\\038\\000\\038\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\039\\000\\255\\255\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\\n \\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\039\\000\\040\\000\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\255\\255\\255\\255\\255\\255\\255\\255\\040\\000\\255\\255\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\040\\000\\\n \\040\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\041\\000\\255\\255\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\041\\000\\\n \\041\\000\\041\\000\\041\\000\\041\\000\\042\\000\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\042\\000\\255\\255\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\\n \\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\042\\000\\043\\000\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\255\\255\\255\\255\\255\\255\\255\\255\\043\\000\\255\\255\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\043\\000\\\n \\043\\000\\043\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\044\\000\\255\\255\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\\n \\044\\000\\044\\000\\044\\000\\044\\000\\044\\000\\045\\000\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\045\\000\\255\\255\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\045\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\255\\255\\255\\255\\255\\255\\255\\255\\046\\000\\\n \\255\\255\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\046\\000\\\n \\046\\000\\046\\000\\046\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\047\\000\\255\\255\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\\n \\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\047\\000\\048\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\255\\255\\255\\255\\255\\255\\255\\255\\048\\000\\255\\255\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\048\\000\\\n \\048\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\049\\000\\255\\255\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\049\\000\\\n \\049\\000\\049\\000\\049\\000\\049\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\050\\000\\255\\255\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\\n \\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\050\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\255\\255\\255\\255\\255\\255\\255\\255\\051\\000\\255\\255\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\051\\000\\\n \\051\\000\\051\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\052\\000\\255\\255\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\\n \\052\\000\\052\\000\\052\\000\\052\\000\\052\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\053\\000\\255\\255\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\053\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\255\\255\\255\\255\\255\\255\\255\\255\\054\\000\\\n \\255\\255\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\054\\000\\\n \\054\\000\\054\\000\\054\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\055\\000\\255\\255\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\\n \\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\055\\000\\056\\000\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\255\\255\\255\\255\\255\\255\\255\\255\\056\\000\\255\\255\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\056\\000\\\n \\056\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\057\\000\\255\\255\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\057\\000\\\n \\057\\000\\057\\000\\057\\000\\057\\000\\058\\000\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\058\\000\\255\\255\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\\n \\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\058\\000\\059\\000\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\255\\255\\255\\255\\255\\255\\255\\255\\059\\000\\255\\255\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\059\\000\\\n \\059\\000\\059\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\060\\000\\255\\255\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\\n \\060\\000\\060\\000\\060\\000\\060\\000\\060\\000\\061\\000\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\061\\000\\255\\255\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\061\\000\\\n \\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\255\\255\\255\\255\\255\\255\\255\\255\\062\\000\\\n \\255\\255\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\062\\000\\\n \\062\\000\\062\\000\\062\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\063\\000\\255\\255\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\\n \\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\063\\000\\064\\000\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\255\\255\\255\\255\\255\\255\\255\\255\\064\\000\\255\\255\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\064\\000\\\n \\064\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\065\\000\\255\\255\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\065\\000\\\n \\065\\000\\065\\000\\065\\000\\065\\000\\066\\000\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\066\\000\\255\\255\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\\n \\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\066\\000\\067\\000\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\255\\255\\255\\255\\255\\255\\255\\255\\067\\000\\255\\255\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\067\\000\\\n \\067\\000\\067\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\068\\000\\255\\255\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\\n \\068\\000\\068\\000\\068\\000\\068\\000\\068\\000\\069\\000\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\069\\000\\255\\255\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\069\\000\\\n \\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\255\\255\\255\\255\\255\\255\\255\\255\\070\\000\\\n \\255\\255\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\070\\000\\\n \\070\\000\\070\\000\\070\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\071\\000\\255\\255\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\\n \\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\071\\000\\072\\000\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\255\\255\\255\\255\\255\\255\\255\\255\\072\\000\\255\\255\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\072\\000\\\n \\072\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\073\\000\\255\\255\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\073\\000\\\n \\073\\000\\073\\000\\073\\000\\073\\000\\074\\000\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\074\\000\\255\\255\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\\n \\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\074\\000\\075\\000\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\255\\255\\255\\255\\255\\255\\255\\255\\075\\000\\255\\255\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\075\\000\\\n \\075\\000\\075\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\076\\000\\255\\255\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\\n \\076\\000\\076\\000\\076\\000\\076\\000\\076\\000\\077\\000\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\077\\000\\255\\255\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\077\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\255\\255\\255\\255\\255\\255\\255\\255\\078\\000\\\n \\255\\255\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\078\\000\\\n \\078\\000\\078\\000\\078\\000\\081\\000\\082\\000\\255\\255\\081\\000\\082\\000\\\n \\083\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\083\\000\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\081\\000\\082\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\083\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\083\\000\\255\\255\\255\\255\\255\\255\\083\\000\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\083\\000\\081\\000\\082\\000\\255\\255\\\n \\083\\000\\255\\255\\083\\000\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\255\\\n \\255\\255\\081\\000\\082\\000\";\n Lexing.lex_base_code =\n \"\";\n Lexing.lex_backtrk_code =\n \"\";\n Lexing.lex_default_code =\n \"\";\n Lexing.lex_trans_code =\n \"\";\n Lexing.lex_check_code =\n \"\";\n Lexing.lex_code =\n \"\";\n}\n\nlet rec token lexbuf =\n __ocaml_lex_token_rec lexbuf 0\nand __ocaml_lex_token_rec lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n# 21 \"graphql_parser/src/lexer.mll\"\n ( token lexbuf )\n# 1105 \"graphql_parser/src/lexer.ml\"\n\n | 1 ->\n# 22 \"graphql_parser/src/lexer.mll\"\n ( token lexbuf )\n# 1110 \"graphql_parser/src/lexer.ml\"\n\n | 2 ->\n# 23 \"graphql_parser/src/lexer.mll\"\n ( new_line lexbuf; token lexbuf )\n# 1115 \"graphql_parser/src/lexer.ml\"\n\n | 3 ->\n# 25 \"graphql_parser/src/lexer.mll\"\n ( INT (int_of_string (lexeme lexbuf)) )\n# 1120 \"graphql_parser/src/lexer.ml\"\n\n | 4 ->\n# 26 \"graphql_parser/src/lexer.mll\"\n ( FLOAT (float_of_string (lexeme lexbuf)) )\n# 1125 \"graphql_parser/src/lexer.ml\"\n\n | 5 ->\n# 27 \"graphql_parser/src/lexer.mll\"\n ( read_string (Buffer.create 17) lexbuf )\n# 1130 \"graphql_parser/src/lexer.ml\"\n\n | 6 ->\n# 29 \"graphql_parser/src/lexer.mll\"\n ( BOOL false )\n# 1135 \"graphql_parser/src/lexer.ml\"\n\n | 7 ->\n# 30 \"graphql_parser/src/lexer.mll\"\n ( FRAGMENT )\n# 1140 \"graphql_parser/src/lexer.ml\"\n\n | 8 ->\n# 31 \"graphql_parser/src/lexer.mll\"\n ( MUTATION )\n# 1145 \"graphql_parser/src/lexer.ml\"\n\n | 9 ->\n# 32 \"graphql_parser/src/lexer.mll\"\n ( NULL )\n# 1150 \"graphql_parser/src/lexer.ml\"\n\n | 10 ->\n# 33 \"graphql_parser/src/lexer.mll\"\n ( ON )\n# 1155 \"graphql_parser/src/lexer.ml\"\n\n | 11 ->\n# 34 \"graphql_parser/src/lexer.mll\"\n ( QUERY )\n# 1160 \"graphql_parser/src/lexer.ml\"\n\n | 12 ->\n# 35 \"graphql_parser/src/lexer.mll\"\n ( SUBSCRIPTION )\n# 1165 \"graphql_parser/src/lexer.ml\"\n\n | 13 ->\n# 36 \"graphql_parser/src/lexer.mll\"\n ( BOOL true )\n# 1170 \"graphql_parser/src/lexer.ml\"\n\n | 14 ->\n# 37 \"graphql_parser/src/lexer.mll\"\n ( NAME (lexeme lexbuf) )\n# 1175 \"graphql_parser/src/lexer.ml\"\n\n | 15 ->\n# 39 \"graphql_parser/src/lexer.mll\"\n ( BANG )\n# 1180 \"graphql_parser/src/lexer.ml\"\n\n | 16 ->\n# 40 \"graphql_parser/src/lexer.mll\"\n ( DOLLAR )\n# 1185 \"graphql_parser/src/lexer.ml\"\n\n | 17 ->\n# 41 \"graphql_parser/src/lexer.mll\"\n ( LPAREN )\n# 1190 \"graphql_parser/src/lexer.ml\"\n\n | 18 ->\n# 42 \"graphql_parser/src/lexer.mll\"\n ( RPAREN )\n# 1195 \"graphql_parser/src/lexer.ml\"\n\n | 19 ->\n# 43 \"graphql_parser/src/lexer.mll\"\n ( ELLIPSIS )\n# 1200 \"graphql_parser/src/lexer.ml\"\n\n | 20 ->\n# 44 \"graphql_parser/src/lexer.mll\"\n ( COLON )\n# 1205 \"graphql_parser/src/lexer.ml\"\n\n | 21 ->\n# 45 \"graphql_parser/src/lexer.mll\"\n ( EQUAL )\n# 1210 \"graphql_parser/src/lexer.ml\"\n\n | 22 ->\n# 46 \"graphql_parser/src/lexer.mll\"\n ( AT )\n# 1215 \"graphql_parser/src/lexer.ml\"\n\n | 23 ->\n# 47 \"graphql_parser/src/lexer.mll\"\n ( LBRACK )\n# 1220 \"graphql_parser/src/lexer.ml\"\n\n | 24 ->\n# 48 \"graphql_parser/src/lexer.mll\"\n ( RBRACK )\n# 1225 \"graphql_parser/src/lexer.ml\"\n\n | 25 ->\n# 49 \"graphql_parser/src/lexer.mll\"\n ( LBRACE )\n# 1230 \"graphql_parser/src/lexer.ml\"\n\n | 26 ->\n# 50 \"graphql_parser/src/lexer.mll\"\n ( RBRACE )\n# 1235 \"graphql_parser/src/lexer.ml\"\n\n | 27 ->\n# 51 \"graphql_parser/src/lexer.mll\"\n ( raise (Error (\"Unexpected char: \" ^ Lexing.lexeme lexbuf)) )\n# 1240 \"graphql_parser/src/lexer.ml\"\n\n | 28 ->\n# 52 \"graphql_parser/src/lexer.mll\"\n ( EOF )\n# 1245 \"graphql_parser/src/lexer.ml\"\n\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_token_rec lexbuf __ocaml_lex_state\n\nand read_string buf lexbuf =\n __ocaml_lex_read_string_rec buf lexbuf 81\nand __ocaml_lex_read_string_rec buf lexbuf __ocaml_lex_state =\n match Lexing.engine __ocaml_lex_tables __ocaml_lex_state lexbuf with\n | 0 ->\n# 55 \"graphql_parser/src/lexer.mll\"\n ( STRING (Buffer.contents buf) )\n# 1257 \"graphql_parser/src/lexer.ml\"\n\n | 1 ->\n# 56 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\"'; read_string buf lexbuf )\n# 1262 \"graphql_parser/src/lexer.ml\"\n\n | 2 ->\n# 57 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\\\'; read_string buf lexbuf )\n# 1267 \"graphql_parser/src/lexer.ml\"\n\n | 3 ->\n# 58 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '/'; read_string buf lexbuf )\n# 1272 \"graphql_parser/src/lexer.ml\"\n\n | 4 ->\n# 59 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\b'; read_string buf lexbuf )\n# 1277 \"graphql_parser/src/lexer.ml\"\n\n | 5 ->\n# 60 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\012'; read_string buf lexbuf )\n# 1282 \"graphql_parser/src/lexer.ml\"\n\n | 6 ->\n# 61 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\n'; read_string buf lexbuf )\n# 1287 \"graphql_parser/src/lexer.ml\"\n\n | 7 ->\n# 62 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\r'; read_string buf lexbuf )\n# 1292 \"graphql_parser/src/lexer.ml\"\n\n | 8 ->\n# 63 \"graphql_parser/src/lexer.mll\"\n ( Buffer.add_char buf '\\t'; read_string buf lexbuf )\n# 1297 \"graphql_parser/src/lexer.ml\"\n\n | 9 ->\n# 65 \"graphql_parser/src/lexer.mll\"\n (\n Buffer.add_string buf (lexeme lexbuf);\n read_string buf lexbuf\n )\n# 1305 \"graphql_parser/src/lexer.ml\"\n\n | __ocaml_lex_state -> lexbuf.Lexing.refill_buff lexbuf;\n __ocaml_lex_read_string_rec buf lexbuf __ocaml_lex_state\n\n;;\n\n","(* Helper modules *)\nmodule List = struct\n include List\n let assoc_exn = assoc\n let assoc x ys = try Some (assoc_exn x ys) with Not_found -> None\n\n let find_exn = find\n let find cond xs = try Some (find_exn cond xs) with Not_found -> None\n\n module Result = struct\n let rec join ?(memo=[]) = function\n | [] -> Ok (List.rev memo)\n | (Error _ as err)::_ -> err\n | (Ok x)::xs -> join ~memo:(x::memo) xs\n\n let all f xs =\n List.map f xs |> join\n end\nend\n\nmodule Option = struct\n let map x ~f = match x with None -> None | Some y -> Some (f y)\nend\n\n(* IO *)\nmodule type IO = sig\n type +'a t\n\n val return : 'a -> 'a t\n val bind : 'a t -> ('a -> 'b t) -> 'b t\n\n module Stream : sig\n type +'a io\n type 'a t\n\n val map : 'a t -> ('a -> 'b io) -> 'b t\n val iter : 'a t -> ('a -> unit io) -> unit io\n val close : 'a t -> unit\n end with type 'a io := 'a t\nend\n\n(* Field_error *)\nmodule type Field_error = sig\n type t\n val message_of_field_error : t -> string\n val extensions_of_field_error : t -> (string * Yojson.Basic.json [@warning \"-3\"]) list option\nend\n\n(* Schema *)\nmodule Make (Io : IO) (Field_error: Field_error) = struct\n module Io = struct\n include Io\n\n let map x ~f = bind x (fun x' -> return (f x'))\n let ok x = Io.return (Ok x)\n let error x = Io.return (Error x)\n\n let rec all = function\n | [] -> Io.return []\n | x::xs ->\n bind (all xs) (fun xs' ->\n map x ~f:(fun x' -> x'::xs')\n )\n\n module Result = struct\n let bind x f = bind x (function Ok x' -> f x' | Error _ as err -> Io.return err)\n let map_error x ~f = map x ~f:(function Ok _ as ok -> ok | Error err -> Error (f err))\n let map x ~f = map x ~f:(function Ok x' -> Ok (f x') | Error _ as err -> err)\n end\n\n let rec map_s ?(memo=[]) f = function\n | [] -> Io.return (List.rev memo)\n | x::xs ->\n bind (f x) (fun x' -> map_s ~memo:(x'::memo) f xs)\n\n let map_p f xs = List.map f xs |> all\n\n module Infix = struct\n let (>>|) x f = map x ~f\n let (>>=?) = Result.bind\n end\n end\n\n module StringMap = struct\n include Map.Make(String)\n exception Missing_key of string\n let find_exn key t = try find key t with Not_found -> raise (Missing_key key)\n let find k t = try Some (find_exn k t) with Missing_key _ -> None\n end\n\n module StringSet = Set.Make(String)\n\n type field_error = Field_error.t\n\n type variable_map = Graphql_parser.const_value StringMap.t\n\n type deprecated =\n | NotDeprecated\n | Deprecated of string option\n\n type 'a enum_value = {\n name : string;\n doc : string option;\n deprecated : deprecated;\n value : 'a;\n }\n\n type json = Yojson.Basic.json [@warning \"-3\"]\n\n let enum_value ?doc ?(deprecated=NotDeprecated) name ~value =\n { name; doc; deprecated; value; }\n\n let id : 'a. 'a -> 'a = fun x -> x\n\n module Arg = struct\n open Rresult\n\n type _ arg_typ =\n | Scalar : {\n name : string;\n doc : string option;\n coerce : Graphql_parser.const_value -> ('a, string) result;\n } -> 'a option arg_typ\n | Object : {\n name : string;\n doc : string option;\n fields : ('a, 'b) arg_list;\n coerce : 'b;\n } -> 'a option arg_typ\n | Enum : {\n name : string;\n doc : string option;\n values : 'a enum_value list;\n } -> 'a option arg_typ\n | List : 'a arg_typ -> 'a list option arg_typ\n | NonNullable : 'a option arg_typ -> 'a arg_typ\n and _ arg =\n | Arg : {\n name : string;\n doc : string option;\n typ : 'a arg_typ;\n } -> 'a arg\n | DefaultArg : {\n name : string;\n doc : string option;\n typ : 'a option arg_typ;\n default : 'a;\n } -> 'a arg\n and (_, _) arg_list =\n | [] : ('a, 'a) arg_list\n | (::) : 'a arg * ('b, 'c) arg_list -> ('b, 'a -> 'c) arg_list\n\n let arg ?doc name ~typ =\n Arg { name; doc; typ }\n\n let arg' ?doc name ~typ ~default =\n DefaultArg { name; doc; typ; default }\n\n let scalar ?doc name ~coerce =\n Scalar { name; doc; coerce }\n\n let enum ?doc name ~values =\n Enum { name; doc; values }\n\n let obj ?doc name ~fields ~coerce =\n Object { name; doc; fields; coerce }\n\n let rec string_of_const_value : Graphql_parser.const_value -> string = function\n | `Null -> \"null\"\n | `Int i -> string_of_int i\n | `Float f -> string_of_float f\n | `String s -> Printf.sprintf \"\\\"%s\\\"\" s\n | `Bool b -> string_of_bool b\n | `Enum e -> e\n | `List l ->\n let values = List.map (fun i -> string_of_const_value i) l in\n Printf.sprintf \"[%s]\" (String.concat \", \" values)\n | `Assoc a ->\n let values =\n List.map\n (fun (k, v) ->\n Printf.sprintf \"%s: %s\" k (string_of_const_value v) )\n a\n in\n Printf.sprintf \"{%s}\" (String.concat \", \" values)\n\n let rec string_of_arg_typ : type a. a arg_typ -> string = function\n | Scalar a -> a.name\n | Object a -> a.name\n | Enum a -> a.name\n | List a -> Printf.sprintf \"[%s]\" (string_of_arg_typ a)\n | NonNullable a -> Printf.sprintf \"%s!\" (string_of_arg_typ a)\n\n let eval_arg_error ?(field_type=\"field\") ~field_name ~arg_name arg_typ value =\n let found_str =\n match value with\n | Some v -> Printf.sprintf \"found %s\" (string_of_const_value v)\n | None -> \"but not provided\"\n in\n Printf.sprintf \"Argument `%s` of type `%s` expected on %s `%s`, %s.\"\n arg_name\n (string_of_arg_typ arg_typ)\n field_type\n field_name\n found_str\n\n (* Built-in argument types *)\n let int = Scalar {\n name = \"Int\";\n doc = None;\n coerce = function\n | `Int n -> Ok n\n | _ -> Error \"Invalid int\"\n }\n\n let string = Scalar {\n name = \"String\";\n doc = None;\n coerce = function\n | `String s -> Ok s\n | _ -> Error \"Invalid string\"\n }\n\n let float = Scalar {\n name = \"Float\";\n doc = None;\n coerce = function\n | `Float f -> Ok f\n | `Int n -> Ok (float_of_int n)\n | _ -> Error \"Invalid float\"\n }\n\n let bool = Scalar {\n name = \"Boolean\";\n doc = None;\n coerce = function\n | `Bool b -> Ok b\n | _ -> Error \"Invalid boolean\"\n }\n\n let guid = Scalar {\n name = \"ID\";\n doc = None;\n coerce = function\n | `String s -> Ok s\n | `Int n -> Ok (string_of_int n)\n | _ -> Error \"Invalid ID\"\n }\n\n let non_null typ = NonNullable typ\n let list typ = List typ\n\n let rec value_to_const_value variable_map = function\n | `Null -> `Null\n | `Int _ as i -> i\n | `Float _ as f -> f\n | `String _ as s -> s\n | `Bool _ as b -> b\n | `Enum _ as e -> e\n | `Variable v -> StringMap.find_exn v variable_map\n | `List xs -> `List (List.map (value_to_const_value variable_map) xs)\n | `Assoc props ->\n let props' = List.map (fun (name, value) -> name, value_to_const_value variable_map value) props in\n `Assoc props'\n\n let rec eval_arglist\n : type a b. variable_map\n -> ?field_type:string\n -> field_name:string\n -> (a, b) arg_list\n -> (string * Graphql_parser.value) list\n -> b\n -> (a, string) result =\n fun variable_map ?field_type ~field_name arglist key_values f ->\n match arglist with\n | [] -> Ok f\n | (DefaultArg arg)::arglist' ->\n let arglist'' = (Arg { name = arg.name; doc = arg.doc; typ = arg.typ })::arglist' in\n eval_arglist variable_map ?field_type ~field_name arglist'' key_values (function\n | None -> f arg.default\n | Some value -> f value\n )\n | (Arg arg)::arglist' ->\n try\n let value = List.assoc arg.name key_values in\n let const_value = Option.map value ~f:(value_to_const_value variable_map) in\n eval_arg variable_map ?field_type ~field_name ~arg_name:arg.name arg.typ const_value >>= fun coerced ->\n eval_arglist variable_map ?field_type ~field_name arglist' key_values (f coerced)\n with StringMap.Missing_key key -> Error (Format.sprintf \"Missing variable `%s`\" key)\n\n and eval_arg\n : type a. variable_map\n -> ?field_type:string\n -> field_name:string\n -> arg_name:string\n -> a arg_typ\n -> Graphql_parser.const_value option\n -> (a, string) result =\n fun variable_map ?field_type ~field_name ~arg_name typ value ->\n match (typ, value) with\n | NonNullable _, None -> Error (eval_arg_error ?field_type ~field_name ~arg_name typ value)\n | NonNullable _, Some `Null -> Error (eval_arg_error ?field_type ~field_name ~arg_name typ value)\n | Scalar _, None -> Ok None\n | Scalar _, Some `Null -> Ok None\n | Object _, None -> Ok None\n | Object _, Some `Null -> Ok None\n | List _, None -> Ok None\n | List _, Some `Null -> Ok None\n | Enum _, None -> Ok None\n | Enum _, Some `Null -> Ok None\n | Scalar s, Some value ->\n begin match (s.coerce value) with\n | Ok coerced -> Ok (Some coerced)\n | Error _ -> Error (eval_arg_error ?field_type ~field_name ~arg_name typ (Some value))\n end\n | Object o, Some value ->\n begin match value with\n | `Assoc props ->\n let props' = (props :> (string * Graphql_parser.value) list) in\n eval_arglist variable_map ?field_type ~field_name o.fields props' o.coerce >>| fun coerced ->\n Some coerced\n | _ -> Error (eval_arg_error ?field_type ~field_name ~arg_name typ (Some value))\n end\n | List typ, Some value ->\n begin match value with\n | `List values ->\n let option_values = List.map (fun x -> Some x) values in\n List.Result.all (eval_arg variable_map ?field_type ~field_name ~arg_name typ) option_values >>| fun coerced ->\n Some coerced\n | value -> eval_arg variable_map ?field_type ~field_name ~arg_name typ (Some value) >>| fun coerced ->\n (Some [coerced] : a)\n end\n | NonNullable typ, value ->\n eval_arg variable_map ?field_type ~field_name ~arg_name typ value >>= (function\n | Some value -> Ok value\n | None -> Error (eval_arg_error ?field_type ~field_name ~arg_name typ None))\n | Enum e, Some value ->\n begin match value with\n | `Enum v\n | `String v ->\n begin match List.find (fun enum_value -> enum_value.name = v) e.values with\n | Some enum_value -> Ok (Some enum_value.value)\n | None -> Error (Printf.sprintf \"Invalid enum value for argument `%s` on field `%s`\" arg_name field_name)\n end\n | _ -> Error (Printf.sprintf \"Expected enum for argument `%s` on field `%s`\" arg_name field_name)\n end\n end\n\n (* Schema data types *)\n type 'a scalar = {\n name : string;\n doc : string option;\n coerce : 'a -> json;\n }\n\n type 'a enum = {\n name : string;\n doc : string option;\n values : 'a enum_value list;\n }\n\n type fragment_map = Graphql_parser.fragment StringMap.t\n type 'ctx resolve_info = {\n ctx : 'ctx;\n field : Graphql_parser.field;\n fragments : fragment_map;\n variables : variable_map;\n }\n\n type ('ctx, 'src) obj = {\n name : string;\n doc : string option;\n fields : ('ctx, 'src) field list Lazy.t;\n abstracts : abstract list ref;\n }\n and (_, _) field =\n Field : {\n name : string;\n doc : string option;\n deprecated : deprecated;\n typ : ('ctx, 'out) typ;\n args : ('a, 'args) Arg.arg_list;\n resolve : 'ctx resolve_info -> 'src -> 'args;\n lift : 'a -> ('out, field_error) result Io.t;\n } -> ('ctx, 'src) field\n and (_, _) typ =\n | Object : ('ctx, 'src) obj -> ('ctx, 'src option) typ\n | List : ('ctx, 'src) typ -> ('ctx, 'src list option) typ\n | NonNullable : ('ctx, 'src option) typ -> ('ctx, 'src) typ\n | Scalar : 'src scalar -> ('ctx, 'src option) typ\n | Enum : 'src enum -> ('ctx, 'src option) typ\n | Abstract : abstract -> ('ctx, ('ctx, 'a) abstract_value option) typ\n and any_typ =\n | AnyTyp : (_, _) typ -> any_typ\n | AnyArgTyp : _ Arg.arg_typ -> any_typ\n and abstract = {\n name : string;\n doc : string option;\n kind : [`Union | `Interface of abstract_field list Lazy.t];\n mutable types : any_typ list;\n }\n and abstract_field =\n AbstractField : (_, _) field -> abstract_field\n and ('ctx, 'a) abstract_value =\n AbstractValue : ('ctx, 'src option) typ * 'src -> ('ctx, 'a) abstract_value\n\n type 'ctx subscription_field =\n SubscriptionField : {\n name : string;\n doc : string option;\n deprecated : deprecated;\n typ : ('ctx, 'out) typ;\n args : (('out Io.Stream.t, field_error) result Io.t, 'args) Arg.arg_list;\n resolve : 'ctx resolve_info -> 'args;\n } -> 'ctx subscription_field\n\n type 'ctx subscription_obj = {\n name : string;\n doc : string option;\n fields : 'ctx subscription_field list;\n }\n\n type ('ctx, 'a) abstract_typ = ('ctx, ('ctx, 'a) abstract_value option) typ\n\n type directive_location = [\n | `Query\n | `Mutation\n | `Subscription\n | `Field\n | `Fragment_definition\n | `Fragment_spread\n | `Inline_fragment\n | `Variable_definition\n ]\n\n type directive =\n Directive : {\n name : string;\n doc : string option;\n locations : directive_location list;\n args : ([ `Skip | `Include ], 'args) Arg.arg_list;\n resolve : 'args;\n } -> directive\n\n type 'ctx schema = {\n query : ('ctx, unit) obj;\n mutation : ('ctx, unit) obj option;\n subscription : 'ctx subscription_obj option;\n }\n\n let schema ?(mutation_name=\"mutation\")\n ?mutations\n ?(subscription_name=\"subscription\")\n ?subscriptions\n ?(query_name=\"query\")\n fields = {\n query = {\n name = query_name;\n doc = None;\n abstracts = ref [];\n fields = lazy fields;\n };\n mutation = Option.map mutations ~f:(fun fields ->\n {\n name = mutation_name;\n doc = None;\n abstracts = ref [];\n fields = lazy fields;\n }\n );\n subscription = Option.map subscriptions ~f:(fun fields ->\n {\n name = subscription_name;\n doc = None;\n fields;\n }\n )\n }\n\n (* Constructor functions *)\n let obj ?doc name ~fields =\n let rec o = Object { name; doc; fields = lazy (fields o); abstracts = ref []} in\n o\n\n let field ?doc ?(deprecated=NotDeprecated) name ~typ ~args ~resolve =\n Field { name; doc; deprecated; typ; args; resolve; lift = Io.ok }\n\n let io_field ?doc ?(deprecated=NotDeprecated) name ~typ ~args ~resolve =\n Field { name; doc; deprecated; typ; args; resolve; lift = id }\n\n let abstract_field ?doc ?(deprecated=NotDeprecated) name ~typ ~args =\n AbstractField (Field { lift = Io.ok; name; doc; deprecated; typ; args; resolve = Obj.magic () })\n\n let subscription_field ?doc ?(deprecated=NotDeprecated) name ~typ ~args ~resolve =\n SubscriptionField { name; doc; deprecated; typ; args; resolve }\n\n let enum ?doc name ~values =\n Enum { name; doc; values }\n\n let scalar ?doc name ~coerce =\n Scalar { name; doc; coerce }\n\n let list typ =\n List typ\n\n let non_null typ =\n NonNullable typ\n\n let union ?doc name =\n Abstract { name; doc; types = []; kind = `Union }\n\n let interface ?doc name ~fields =\n let rec i = Abstract { name; doc; types = []; kind = `Interface (lazy (fields i)) } in\n i\n\n let add_type abstract_typ typ =\n match (abstract_typ, typ) with\n | Abstract a, Object o ->\n (* TODO add subtype check here *)\n a.types <- (AnyTyp typ)::a.types;\n o.abstracts := a :: !(o.abstracts);\n fun src -> AbstractValue (typ, src)\n | _ ->\n invalid_arg \"Arguments must be Interface/Union and Object\"\n\n let obj_of_subscription_obj {name; doc; fields} =\n let fields = List.map\n (fun (SubscriptionField {name; doc; deprecated; typ; args; resolve}) ->\n Field { lift = Obj.magic (); name; doc; deprecated; typ; args; resolve = (fun ctx () -> resolve ctx) })\n fields\n in\n { name; doc; abstracts = ref []; fields = lazy fields }\n\n (* Built-in scalars *)\n let int : 'ctx. ('ctx, int option) typ = Scalar {\n name = \"Int\";\n doc = None;\n coerce = fun i -> `Int i;\n }\n\n let string : 'ctx. ('ctx, string option) typ = Scalar {\n name = \"String\";\n doc = None;\n coerce = fun s ->`String s;\n }\n\n let bool : 'ctx. ('ctx, bool option) typ = Scalar {\n name = \"Boolean\";\n doc = None;\n coerce = fun b -> `Bool b;\n }\n\n let float : 'ctx. ('ctx, float option) typ = Scalar {\n name = \"Float\";\n doc = None;\n coerce = fun f -> `Float f;\n }\n\n let guid : 'ctx. ('ctx, string option) typ = Scalar {\n name = \"ID\";\n doc = None;\n coerce = fun x -> `String x;\n }\n\n (* Mandatory directives: skip and include *)\n let skip_directive = Directive {\n name = \"skip\";\n doc = Some \"Directs the executor to skip this field or fragment when the `if` argument is true.\";\n locations = [`Field; `Fragment_spread; `Inline_fragment];\n args = Arg.[\n arg \"if\" ~doc:\"Skipped when true.\" ~typ:(non_null bool)\n ];\n resolve = function\n | true -> `Skip\n | false -> `Include\n }\n\n let include_directive = Directive {\n name = \"include\";\n doc = Some \"Directs the executor to include this field or fragment only when the `if` argument is true.\";\n locations = [`Field; `Fragment_spread; `Inline_fragment];\n args = Arg.[\n arg \"if\" ~doc:\"Included when true.\" ~typ:(non_null bool)\n ];\n resolve = function\n | true -> `Include\n | false -> `Skip\n }\n\nmodule Introspection = struct\n (* any_typ, any_field and any_arg hide type parameters to avoid scope escaping errors *)\n type any_field =\n | AnyField : (_, _) field -> any_field\n | AnyArgField : _ Arg.arg -> any_field\n type any_arg = AnyArg : _ Arg.arg -> any_arg\n type any_enum_value = AnyEnumValue : _ enum_value -> any_enum_value\n\n let unless_visited (result, visited) name f =\n if StringSet.mem name visited then\n result, visited\n else\n f (result, visited)\n\n (* Extracts all types contained in a single type *)\n let rec types : type ctx src. ?memo:(any_typ list * StringSet.t) -> (ctx, src) typ -> (any_typ list * StringSet.t) = fun ?(memo=([], StringSet.empty)) typ ->\n match typ with\n | List typ -> types ~memo typ\n | NonNullable typ -> types ~memo typ\n | Scalar s as scalar ->\n unless_visited memo s.name (fun (result, visited) ->\n (AnyTyp scalar)::result, StringSet.add s.name visited\n )\n | Enum e as enum ->\n unless_visited memo e.name (fun (result, visited) ->\n (AnyTyp enum)::result, StringSet.add e.name visited\n )\n | Object o as obj ->\n unless_visited memo o.name (fun (result, visited) ->\n let result' = (AnyTyp obj)::result in\n let visited' = StringSet.add o.name visited in\n let reducer = fun memo (Field f) ->\n let memo' = types ~memo f.typ in\n arg_list_types memo' f.args\n in\n List.fold_left reducer (result', visited') (Lazy.force o.fields)\n )\n | Abstract a as abstract ->\n unless_visited memo a.name (fun (result, visited) ->\n let result' = (AnyTyp abstract)::result in\n let visited' = StringSet.add a.name visited in\n List.fold_left (fun memo typ -> match typ with\n | AnyTyp typ -> types ~memo typ\n | AnyArgTyp _ -> failwith \"Abstracts can't have argument types\")\n (result', visited') a.types\n )\n\n and arg_types : type a. (any_typ list * StringSet.t) -> a Arg.arg_typ -> (any_typ list * StringSet.t) = fun memo argtyp ->\n match argtyp with\n | Arg.List typ -> arg_types memo typ\n | Arg.NonNullable typ -> arg_types memo typ\n | Arg.Scalar s as scalar ->\n unless_visited memo s.name (fun (result, visited) ->\n (AnyArgTyp scalar)::result, StringSet.add s.name visited\n )\n | Arg.Enum e as enum ->\n unless_visited memo e.name (fun (result, visited) ->\n (AnyArgTyp enum)::result, StringSet.add e.name visited\n )\n | Arg.Object o as obj ->\n unless_visited memo o.name (fun (result, visited) ->\n let memo' = (AnyArgTyp obj)::result, StringSet.add o.name visited in\n arg_list_types memo' o.fields\n )\n and arg_list_types : type a b. (any_typ list * StringSet.t) -> (a, b) Arg.arg_list -> (any_typ list * StringSet.t) = fun memo arglist ->\n let open Arg in\n match arglist with\n | [] -> memo\n | arg::args ->\n let memo' = match arg with\n | Arg a -> arg_types memo a.typ\n | DefaultArg a -> arg_types memo a.typ\n in arg_list_types memo' args\n\n let types_of_schema s =\n let types, _ =\n List.fold_left\n (fun memo op ->\n match op with\n | None -> memo\n | Some op -> types ~memo (Object op))\n ([], StringSet.empty)\n [Some s.query; s.mutation; Option.map s.subscription ~f:obj_of_subscription_obj]\n in\n types\n\n let rec args_to_list : type a b. ?memo:any_arg list -> (a, b) Arg.arg_list -> any_arg list = fun ?memo:(memo=[]) arglist ->\n let open Arg in\n match arglist with\n | [] ->\n memo\n | arg::args ->\n let memo' = List.cons (AnyArg arg) memo in\n args_to_list ~memo:memo' args\n\n let no_abstracts = ref []\n\n let __type_kind = Enum {\n name = \"__TypeKind\";\n doc = None;\n values = [\n {\n name=\"SCALAR\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Scalar;\n };\n {\n name=\"OBJECT\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Object;\n };\n {\n name=\"INTERFACE\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Interface;\n };\n {\n name=\"UNION\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Union;\n };\n {\n name=\"ENUM\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Enum;\n };\n {\n name=\"INPUT_OBJECT\";\n doc=None;\n deprecated=NotDeprecated;\n value=`InputObject;\n };\n {\n name=\"LIST\";\n doc=None;\n deprecated=NotDeprecated;\n value=`List;\n };\n {\n name=\"NON_NULL\";\n doc=None;\n deprecated=NotDeprecated;\n value=`NonNull;\n };\n ]\n }\n\n let __enum_value : 'ctx. ('ctx, any_enum_value option) typ = Object {\n name = \"__EnumValue\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"name\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyEnumValue enum_value) -> enum_value.name;\n };\n Field {\n name = \"description\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyEnumValue enum_value) -> enum_value.doc;\n };\n Field {\n name = \"isDeprecated\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable bool;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyEnumValue enum_value) -> enum_value.deprecated <> NotDeprecated;\n };\n Field {\n name = \"deprecationReason\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyEnumValue enum_value) ->\n match enum_value.deprecated with\n | Deprecated reason -> reason\n | NotDeprecated -> None\n }\n ]\n }\n\n let rec __input_value : 'ctx. ('ctx, any_arg option) typ = Object {\n name = \"__InputValue\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"name\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyArg arg) -> match arg with\n | Arg.DefaultArg a -> a.name\n | Arg.Arg a -> a.name\n };\n Field {\n name = \"description\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyArg arg) -> match arg with\n | Arg.DefaultArg a -> a.doc\n | Arg.Arg a -> a.doc\n };\n Field {\n name = \"type\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyArg arg) -> match arg with\n | Arg.DefaultArg a -> AnyArgTyp a.typ\n | Arg.Arg a -> AnyArgTyp a.typ\n };\n Field {\n name = \"defaultValue\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (AnyArg _) -> None\n }\n ]\n }\n\n and __type : 'ctx . ('ctx, any_typ option) typ = Object {\n name = \"__Type\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"kind\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable __type_kind;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Object _) -> `Object\n | AnyTyp (Abstract { kind = `Union; _ }) -> `Union\n | AnyTyp (Abstract { kind = `Interface _; _ }) -> `Interface\n | AnyTyp (List _) -> `List\n | AnyTyp (Scalar _) -> `Scalar\n | AnyTyp (Enum _) -> `Enum\n | AnyTyp (NonNullable _) -> `NonNull\n | AnyArgTyp (Arg.Object _) -> `InputObject\n | AnyArgTyp (Arg.List _) -> `List\n | AnyArgTyp (Arg.Scalar _) -> `Scalar\n | AnyArgTyp (Arg.Enum _) -> `Enum\n | AnyArgTyp (Arg.NonNullable _) -> `NonNull\n };\n Field {\n name = \"name\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Object o) -> Some o.name\n | AnyTyp (Scalar s) -> Some s.name\n | AnyTyp (Enum e) -> Some e.name\n | AnyTyp (Abstract a) -> Some a.name\n | AnyArgTyp (Arg.Object o) -> Some o.name\n | AnyArgTyp (Arg.Scalar s) -> Some s.name\n | AnyArgTyp (Arg.Enum e) -> Some e.name\n | _ -> None;\n };\n Field {\n name = \"description\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Object o) -> o.doc\n | AnyTyp (Scalar s) -> s.doc\n | AnyTyp (Enum e) -> e.doc\n | AnyTyp (Abstract a) -> a.doc\n | AnyArgTyp (Arg.Object o) -> o.doc\n | AnyArgTyp (Arg.Scalar s) -> s.doc\n | AnyArgTyp (Arg.Enum e) -> e.doc\n | _ -> None\n };\n Field {\n name = \"fields\";\n doc = None;\n deprecated = NotDeprecated;\n typ = List (NonNullable __field);\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Object o) ->\n Some (List.map (fun f -> AnyField f) (Lazy.force o.fields))\n | AnyTyp (Abstract { kind = `Interface fields; _ }) ->\n Some (List.map (fun (AbstractField f) -> AnyField f) (Lazy.force fields))\n | AnyArgTyp (Arg.Object o) ->\n let arg_list = args_to_list o.fields in\n Some (List.map (fun (AnyArg f) -> AnyArgField f) arg_list)\n | _ -> None\n };\n Field {\n name = \"interfaces\";\n doc = None;\n deprecated = NotDeprecated;\n typ = List (NonNullable __type);\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Object o) ->\n let interfaces = List.filter (function | { kind = `Interface _; _} -> true | _ -> false) !(o.abstracts) in\n Some (List.map (fun i -> AnyTyp (Abstract i)) interfaces)\n | _ -> None\n };\n Field {\n name = \"possibleTypes\";\n doc = None;\n deprecated = NotDeprecated;\n typ = List (NonNullable __type);\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Abstract a) ->\n Some a.types\n | _ -> None\n };\n Field {\n name = \"ofType\";\n doc = None;\n deprecated = NotDeprecated;\n typ = __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (NonNullable typ) -> Some (AnyTyp typ)\n | AnyTyp (List typ) -> Some (AnyTyp typ)\n | AnyArgTyp (Arg.NonNullable typ) -> Some (AnyArgTyp typ)\n | AnyArgTyp (Arg.List typ) -> Some (AnyArgTyp typ)\n | _ -> None\n };\n Field {\n name = \"inputFields\";\n doc = None;\n deprecated = NotDeprecated;\n typ = List (NonNullable __input_value);\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyArgTyp (Arg.Object o) ->\n Some (args_to_list o.fields)\n | _ -> None\n };\n Field {\n name = \"enumValues\";\n doc = None;\n deprecated = NotDeprecated;\n typ = List (NonNullable __enum_value);\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ t -> match t with\n | AnyTyp (Enum e) -> Some (List.map (fun x -> AnyEnumValue x) e.values)\n | AnyArgTyp (Arg.Enum e) -> Some (List.map (fun x -> AnyEnumValue x) e.values)\n | _ -> None\n }\n ]\n }\n\n and __field : 'ctx. ('ctx, any_field option) typ = Object {\n name = \"__Field\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"name\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field f) -> f.name\n | AnyArgField (Arg.Arg a) -> a.name\n | AnyArgField (Arg.DefaultArg a) -> a.name\n };\n Field {\n name = \"description\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field f) -> f.doc\n | AnyArgField (Arg.Arg a) -> a.doc\n | AnyArgField (Arg.DefaultArg a) -> a.doc\n };\n Field {\n name = \"args\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable (List (NonNullable __input_value));\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field f) -> args_to_list f.args\n | AnyArgField _ -> []\n };\n Field {\n name = \"type\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field f) -> AnyTyp f.typ\n | AnyArgField (Arg.Arg a) -> AnyArgTyp a.typ\n | AnyArgField (Arg.DefaultArg a) -> AnyArgTyp a.typ\n };\n Field {\n name = \"isDeprecated\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable bool;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field { deprecated = Deprecated _; _ }) -> true\n | _ -> false\n };\n Field {\n name = \"deprecationReason\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ f -> match f with\n | AnyField (Field { deprecated = Deprecated reason; _ }) -> reason\n | _ -> None\n }\n ]\n }\n\n let __directive_location = Enum {\n name = \"__DirectiveLocation\";\n doc = None;\n values = [\n {\n name=\"QUERY\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Query;\n };\n {\n name=\"MUTATION\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Mutation;\n };\n {\n name=\"SUBSCRIPTION\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Subscription;\n };\n {\n name=\"FIELD\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Field;\n };\n {\n name=\"FRAGMENT_DEFINITION\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Fragment_definition;\n };\n {\n name=\"FRAGMENT_SPREAD\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Fragment_spread;\n };\n {\n name=\"INLINE_FRAGMENT\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Inline_fragment;\n };\n {\n name=\"VARIABLE_DEFINITION\";\n doc=None;\n deprecated=NotDeprecated;\n value=`Variable_definition;\n };\n ]\n }\n\n let __directive = Object {\n name = \"__Directive\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"name\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (Directive d) -> d.name\n };\n Field {\n name = \"description\";\n doc = None;\n deprecated = NotDeprecated;\n typ = string;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (Directive d) -> d.doc\n };\n Field {\n name = \"locations\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable (List (NonNullable __directive_location));\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (Directive d) -> d.locations\n };\n Field {\n name = \"args\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable (List (NonNullable __input_value));\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (Directive d) -> args_to_list d.args\n }\n ]\n }\n\n let __schema : 'ctx. ('ctx, ('ctx schema * any_typ list) option) typ = Object {\n name = \"__Schema\";\n doc = None;\n abstracts = no_abstracts;\n fields = lazy [\n Field {\n name = \"types\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable (List (NonNullable __type));\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (_schema, types) -> types\n };\n Field {\n name = \"queryType\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (schema, _types) -> AnyTyp (Object schema.query)\n };\n Field {\n name = \"mutationType\";\n doc = None;\n deprecated = NotDeprecated;\n typ = __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (schema, _types) -> Option.map schema.mutation ~f:(fun mut -> AnyTyp (Object mut))\n };\n Field {\n name = \"subscriptionType\";\n doc = None;\n deprecated = NotDeprecated;\n typ = __type;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ (schema, _types) ->\n Option.map schema.subscription ~f:(fun subs -> AnyTyp (Object (obj_of_subscription_obj subs)))\n };\n Field {\n name = \"directives\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable (List (NonNullable __directive));\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ _ -> []\n }\n ]\n }\n\n let add_built_in_fields schema =\n let types = types_of_schema schema in\n let schema_field = Field {\n name = \"__schema\";\n doc = None;\n deprecated = NotDeprecated;\n typ = NonNullable __schema;\n args = Arg.[];\n lift = Io.ok;\n resolve = fun _ _ -> (schema, types)\n } in\n let type_field = Field {\n name = \"__type\";\n doc = None;\n deprecated = NotDeprecated;\n typ = __type;\n args = Arg.[arg \"name\" ~typ:(non_null string)];\n lift = Io.ok;\n resolve = fun _ _ name ->\n List.find (fun typ ->\n match typ with\n | AnyTyp (Object o) -> o.name = name\n | AnyTyp (Scalar s) -> s.name = name\n | AnyTyp (Enum e) -> e.name = name\n | AnyTyp (Abstract a) -> a.name = name\n | AnyTyp (List _) -> false\n | AnyTyp (NonNullable _) -> false\n | AnyArgTyp (Arg.Object o) -> o.name = name\n | AnyArgTyp (Arg.Scalar s) -> s.name = name\n | AnyArgTyp (Arg.Enum e) -> e.name = name\n | AnyArgTyp (Arg.List _) -> false\n | AnyArgTyp (Arg.NonNullable _) -> false\n ) types\n } in\n let fields = lazy (schema_field::type_field::(Lazy.force schema.query.fields)) in\n { schema with query = { schema.query with fields } }\nend\n\n (* Execution *)\n type variables = (string * Graphql_parser.const_value) list\n type execution_order = Serial | Parallel\n type 'ctx execution_context = {\n variables : variable_map;\n fragments : fragment_map;\n ctx : 'ctx;\n }\n\n type path = [`String of string | `Int of int] list\n type error = field_error * path\n\n type resolve_error = [\n | `Resolve_error of error\n | `Argument_error of string\n | `Validation_error of string\n ]\n\n type execute_error = [\n resolve_error\n | `Mutations_not_configured\n | `Subscriptions_not_configured\n | `No_operation_found\n | `Operation_name_required\n | `Operation_not_found\n ]\n\n type 'a response = ('a, json) result\n\n let matches_type_condition type_condition (obj : ('ctx, 'src) obj) =\n obj.name = type_condition ||\n List.exists (fun (abstract : abstract) -> abstract.name = type_condition) !(obj.abstracts)\n\n let rec should_include_field ctx (directives : Graphql_parser.directive list) =\n match directives with\n | [] -> Ok true\n | { name = \"skip\"; arguments }::rest ->\n eval_directive ctx skip_directive arguments rest\n | { name = \"include\"; arguments }::rest ->\n eval_directive ctx include_directive arguments rest\n | { name; _ }::_ ->\n let err = Format.sprintf \"Unknown directive: %s\" name in\n Error err\n\n and eval_directive ctx (Directive { name; args; resolve; _ }) arguments rest =\n let open Rresult in\n Arg.eval_arglist ctx.variables ~field_type:\"directive\" ~field_name:name args arguments resolve >>= function\n | `Skip -> Ok false\n | `Include -> should_include_field ctx rest\n\n let alias_or_name : Graphql_parser.field -> string = fun field ->\n match field.alias with\n | Some alias -> alias\n | None -> field.name\n\n let rec merge_selections ?(memo=[]) = function\n | [] -> List.rev memo\n | field::fields ->\n let id = alias_or_name field in\n let matching, rest = List.partition (fun field' -> id = (alias_or_name field')) fields in\n let selection_sets = List.map (fun (field : Graphql_parser.field) -> field.selection_set) (field::matching) in\n let selection_set = List.concat selection_sets in\n merge_selections ~memo:({field with selection_set}::memo) rest\n\n let rec collect_fields : 'ctx execution_context -> ('ctx, 'src) obj -> Graphql_parser.selection list -> (Graphql_parser.field list, string) result =\n fun ctx obj fields ->\n let open Rresult in\n List.map (function\n | Graphql_parser.Field field ->\n should_include_field ctx field.directives >>| fun include_field ->\n if include_field then [field] else []\n | Graphql_parser.FragmentSpread spread ->\n begin match StringMap.find spread.name ctx.fragments with\n | Some { directives; type_condition; selection_set; _ }\n when matches_type_condition type_condition obj ->\n should_include_field ctx directives >>= fun include_field ->\n if include_field then\n collect_fields ctx obj selection_set\n else Ok []\n | _ -> Ok []\n end\n | Graphql_parser.InlineFragment fragment ->\n let matches_type_condition = match fragment.type_condition with\n | None -> true\n | Some condition -> matches_type_condition condition obj\n in\n if matches_type_condition then\n should_include_field ctx fragment.directives >>= fun include_field ->\n if include_field then\n collect_fields ctx obj fragment.selection_set\n else Ok []\n else\n Ok []\n ) fields\n |> List.Result.join\n |> Rresult.R.map List.concat\n |> Rresult.R.map merge_selections\n\n let field_from_object : ('ctx, 'src) obj -> string -> ('ctx, 'src) field option = fun obj field_name ->\n List.find (fun (Field field) -> field.name = field_name) (Lazy.force obj.fields)\n\n let field_from_subscription_object = fun obj field_name ->\n List.find (fun (SubscriptionField field) -> field.name = field_name) obj.fields\n\n let coerce_or_null : 'a option -> ('a -> (json * error list, 'b) result Io.t) -> (json * error list, 'b) result Io.t =\n fun src f ->\n match src with\n | None -> Io.ok (`Null, [])\n | Some src' -> f src'\n\n let map_fields_with_order = function\n | Serial -> Io.map_s ~memo:[]\n | Parallel -> Io.map_p\n\n let error_to_json ?path ?extensions msg =\n let props = match path with\n | Some path -> [\"path\", `List (List.rev path :> json list)]\n | None -> []\n in\n let extension_props = match extensions with\n | None\n | Some [] -> []\n | Some extensions -> [\"extensions\", `Assoc extensions]\n in\n (`Assoc ((\"message\", `String msg)::(List.append props extension_props)) : json)\n\n let error_response ?data ?path ?extensions msg =\n let errors = \"errors\", `List [\n error_to_json ?path ?extensions msg\n ]\n in\n let data = match data with\n | None -> []\n | Some data -> [\"data\", data]\n in\n `Assoc (errors :: data)\n\n let rec present : type ctx src. ctx execution_context -> src -> Graphql_parser.field -> (ctx, src) typ -> path -> (json * error list, [> resolve_error]) result Io.t =\n fun ctx src query_field typ path ->\n match typ with\n | Scalar s -> coerce_or_null src (fun x -> Io.ok (s.coerce x, []))\n | List t ->\n coerce_or_null src (fun src' ->\n List.mapi (fun i x -> present ctx x query_field t ((`Int i)::path)) src'\n |> Io.all\n |> Io.map ~f:List.Result.join\n |> Io.Result.map ~f:(fun xs -> (`List (List.map fst xs), List.map snd xs |> List.concat))\n )\n | NonNullable t -> present ctx (Some src) query_field t path\n | Object o ->\n coerce_or_null src (fun src' ->\n match collect_fields ctx o query_field.selection_set with\n | Ok fields -> resolve_fields ctx src' o fields path\n | Error e -> Io.error (`Argument_error e))\n | Enum e ->\n coerce_or_null src (fun src' ->\n match List.find (fun enum_value -> src' == enum_value.value) e.values with\n | Some enum_value -> Io.ok (`String enum_value.name, [])\n | None -> Io.ok (`Null, [])\n )\n | Abstract _ ->\n coerce_or_null src (fun (AbstractValue (typ', src')) ->\n present ctx (Some src') query_field typ' path\n )\n\n and resolve_field : type ctx src. ctx execution_context -> src -> Graphql_parser.field -> (ctx, src) field -> path -> ((string * json) * error list, [> resolve_error]) result Io.t =\n fun ctx src query_field (Field field) path ->\n let open Io.Infix in\n let name = alias_or_name query_field in\n let path' = (`String name)::path in\n let resolve_info = {\n ctx = ctx.ctx;\n field = query_field;\n fragments = ctx.fragments;\n variables = ctx.variables;\n } in\n let resolver = field.resolve resolve_info src in\n match Arg.eval_arglist ctx.variables ~field_name:field.name field.args query_field.arguments resolver with\n | Ok unlifted_value ->\n let lifted_value =\n field.lift unlifted_value\n |> Io.Result.map_error ~f:(fun err -> `Resolve_error (err, path')) >>=? fun resolved ->\n present ctx resolved query_field field.typ path'\n in\n lifted_value >>| (function\n | Ok (value, errors) ->\n Ok ((name, value), errors)\n | Error (`Argument_error _)\n | Error (`Validation_error _) as error ->\n error\n | Error (`Resolve_error err) as error ->\n match field.typ with\n | NonNullable _ ->\n error\n | _ ->\n Ok ((name, `Null), [err])\n )\n | Error err ->\n Io.error (`Argument_error err)\n\n and resolve_fields : type ctx src. ctx execution_context -> ?execution_order:execution_order -> src -> (ctx, src) obj -> Graphql_parser.field list -> path -> (json * error list, [> resolve_error]) result Io.t =\n fun ctx ?execution_order:(execution_order=Parallel) src obj fields path ->\n map_fields_with_order execution_order (fun (query_field : Graphql_parser.field) ->\n let name = alias_or_name query_field in\n if query_field.name = \"__typename\" then\n Io.ok ((name, `String obj.name), [])\n else\n match field_from_object obj query_field.name with\n | Some field ->\n resolve_field ctx src query_field field path\n | None ->\n let err = Printf.sprintf \"Field '%s' is not defined on type '%s'\" query_field.name obj.name in\n Io.error (`Validation_error err)\n ) fields\n |> Io.map ~f:List.Result.join\n |> Io.Result.map ~f:(fun xs -> (`Assoc (List.map fst xs), List.map snd xs |> List.concat))\n\n let data_to_json = function\n | data, [] -> `Assoc [\"data\", data]\n | data, errors ->\n let errors = List.map\n (fun (field_error, path) ->\n let extensions = Field_error.extensions_of_field_error field_error in\n let msg = Field_error.message_of_field_error field_error in\n error_to_json ~path ?extensions msg)\n errors\n in\n `Assoc [\n \"errors\", `List errors;\n \"data\", data;\n ]\n\n let to_response = function\n | Ok _ as res -> res\n | Error `No_operation_found ->\n Error (error_response \"No operation found\")\n | Error `Operation_not_found ->\n Error (error_response \"Operation not found\")\n | Error `Operation_name_required ->\n Error (error_response \"Operation name required\")\n | Error `Subscriptions_not_configured ->\n Error (error_response \"Subscriptions not configured\")\n | Error `Mutations_not_configured ->\n Error (error_response \"Mutations not configured\")\n | Error (`Validation_error msg) ->\n Error (error_response msg)\n | Error (`Argument_error msg) ->\n Error (error_response ~data:`Null msg)\n | Error (`Resolve_error (field_error, path)) ->\n let extensions = Field_error.extensions_of_field_error field_error in\n let msg = Field_error.message_of_field_error field_error in\n Error (error_response ~data:`Null ~path ?extensions msg)\n\n let subscribe : type ctx. ctx execution_context -> ctx subscription_field -> Graphql_parser.field -> (json response Io.Stream.t, [> resolve_error]) result Io.t\n =\n fun ctx (SubscriptionField subs_field) field ->\n let open Io.Infix in\n let name = alias_or_name field in\n let path = [`String name] in\n let resolve_info = {\n ctx = ctx.ctx;\n field;\n fragments = ctx.fragments;\n variables = ctx.variables\n } in\n let resolver = subs_field.resolve resolve_info in\n match Arg.eval_arglist ctx.variables ~field_name:subs_field.name subs_field.args field.arguments resolver with\n | Ok result ->\n result\n |> Io.Result.map ~f:(fun source_stream ->\n Io.Stream.map source_stream (fun value ->\n present ctx value field subs_field.typ path\n |> Io.Result.map ~f:(fun (data, errors) ->\n data_to_json (`Assoc [name, data], errors)\n )\n >>| to_response\n )\n )\n |> Io.Result.map_error ~f:(fun err ->\n `Resolve_error (err, path)\n )\n | Error err -> Io.error (`Argument_error err)\n\n let execute_operation : 'ctx schema -> 'ctx execution_context -> Graphql_parser.operation -> ([ `Response of json | `Stream of json response Io.Stream.t], [> execute_error]) result Io.t =\n fun schema ctx operation ->\n let open Io.Infix in\n match operation.optype with\n | Graphql_parser.Query ->\n let query = schema.query in\n Io.return (collect_fields ctx query operation.selection_set)\n |> Io.Result.map_error ~f:(fun e -> `Argument_error e) >>=? fun fields ->\n (resolve_fields ctx () query fields [] : (json * error list, resolve_error) result Io.t :> (json * error list, [> execute_error]) result Io.t)\n |> Io.Result.map ~f:(fun data_errs -> `Response (data_to_json data_errs))\n | Graphql_parser.Mutation ->\n begin match schema.mutation with\n | None -> Io.error `Mutations_not_configured\n | Some mut ->\n Io.return (collect_fields ctx mut operation.selection_set)\n |> Io.Result.map_error ~f:(fun e -> `Argument_error e) >>=? fun fields ->\n (resolve_fields ~execution_order:Serial ctx () mut fields [] : (json * error list, resolve_error) result Io.t :> (json * error list, [> execute_error]) result Io.t)\n |> Io.Result.map ~f:(fun data_errs -> `Response (data_to_json data_errs))\n end\n | Graphql_parser.Subscription ->\n begin match schema.subscription with\n | None -> Io.error `Subscriptions_not_configured\n | Some subs ->\n Io.return (collect_fields ctx (obj_of_subscription_obj subs) operation.selection_set)\n |> Io.Result.map_error ~f:(fun e -> `Argument_error e) >>=? fun fields ->\n begin match fields with\n | [field] ->\n (match field_from_subscription_object subs field.name with\n | Some subscription_field ->\n (subscribe ctx subscription_field field : ((json, json) result Io.Stream.t, resolve_error) result Io.t :> ((json, json) result Io.Stream.t, [> execute_error]) result Io.t)\n |> Io.Result.map ~f:(fun stream -> `Stream stream)\n | None -> Io.ok (`Response (`Assoc [(alias_or_name field, `Null)])))\n (* see http://facebook.github.io/graphql/June2018/#sec-Response-root-field *)\n | _ -> Io.error (`Validation_error \"Subscriptions only allow exactly one selection for the operation.\")\n end\n end\n\n let collect_fragments doc =\n List.fold_left (fun memo -> function\n | Graphql_parser.Operation _ -> memo\n | Graphql_parser.Fragment f -> StringMap.add f.name f memo\n ) StringMap.empty doc\n\n exception FragmentCycle of string list\n let rec validate_fragments fragment_map =\n try\n StringMap.iter (fun name _ ->\n validate_fragment fragment_map StringSet.empty name\n ) fragment_map;\n Ok fragment_map\n with FragmentCycle fragment_names ->\n let cycle = String.concat \", \" fragment_names in\n let err = Format.sprintf \"Fragment cycle detected: %s\" cycle in\n Error (`Validation_error err)\n\n and validate_fragment (fragment_map : fragment_map) visited name =\n match StringMap.find name fragment_map with\n | None -> ()\n | Some fragment when StringSet.mem fragment.name visited ->\n raise (FragmentCycle (StringSet.elements visited))\n | Some fragment ->\n let visited' = StringSet.add fragment.name visited in\n List.iter (validate_fragment_selection fragment_map visited') fragment.selection_set\n\n and validate_fragment_selection fragment_map visited selection =\n match selection with\n | Graphql_parser.Field field ->\n List.iter (validate_fragment_selection fragment_map visited) field.selection_set\n | InlineFragment inline_fragment ->\n List.iter (validate_fragment_selection fragment_map visited) inline_fragment.selection_set\n | FragmentSpread fragment_spread ->\n validate_fragment fragment_map visited fragment_spread.name\n\n let collect_and_validate_fragments doc =\n let fragments = collect_fragments doc in\n validate_fragments fragments\n\n let collect_operations doc =\n List.fold_left (fun memo -> function\n | Graphql_parser.Operation op -> op::memo\n | Graphql_parser.Fragment _ -> memo\n ) [] doc\n\n let select_operation ?operation_name doc =\n let operations = collect_operations doc in\n match operation_name, operations with\n | _, [] -> Error `No_operation_found\n | None, [op] -> Ok op\n | None, _::_ -> Error `Operation_name_required\n | Some name, ops ->\n try\n Ok (List.find_exn (fun op -> op.Graphql_parser.name = Some name) ops)\n with Not_found ->\n Error `Operation_not_found\n\n let execute schema ctx ?variables:(variables=[]) ?operation_name doc =\n let open Io.Infix in\n let execute' schema ctx doc =\n Io.return (collect_and_validate_fragments doc) >>=? fun fragments ->\n let schema' = Introspection.add_built_in_fields schema in\n Io.return (select_operation ?operation_name doc) >>=? fun op ->\n let default_variables = List.fold_left (fun memo { Graphql_parser.name; default_value; _ } ->\n match default_value with\n | None -> memo\n | Some value -> StringMap.add name value memo\n ) StringMap.empty op.variable_definitions in\n let variables = List.fold_left (fun memo (name, value) -> StringMap.add name value memo) default_variables variables in\n let execution_ctx = { fragments; ctx; variables } in\n execute_operation schema' execution_ctx op\n in\n execute' schema ctx doc >>| to_response\nend\n","open Core_kernel\n\nmodule Annotations = struct\n module Utils = struct\n let find xs key =\n List.find ~f:(fun (k', _) -> String.equal key k') xs |> Option.map ~f:snd\n\n let find_string xs key =\n find xs key |> Option.join |> Option.map ~f:(fun s -> String.strip s)\n\n let find_bool xs key =\n find xs key\n |> Option.map ~f:(fun _ -> true)\n |> Option.value ~default:false\n end\n\n module Top = struct\n (** Top comment *)\n type t = { name : string; doc : string option }\n [@@deriving annot, sexp, compare, equal]\n\n open Utils\n\n let of_annots ~name t_toplevel_annots =\n let xs = t_toplevel_annots () in\n { name; doc = find_string xs \"ocaml.doc\" }\n\n let%test_unit \"top annots parse\" =\n let t = of_annots ~name:\"Top\" t_toplevel_annots in\n [%test_eq: t] t { name = \"Top\"; doc = Some \"Top comment\" }\n end\n\n module Fields = struct\n module T = struct\n type t =\n { name : string option\n ; doc : string option [@name \"document\"]\n ; skip : bool [@skip]\n ; deprecated : string option [@depr \"foo\"] (** this is deprecated *)\n }\n [@@deriving annot, sexp, compare, equal]\n end\n\n type t = string -> T.t\n\n open Utils\n\n let of_annots t_fields_annots field =\n let xs = t_fields_annots field in\n let s = find_string xs in\n let b = find_bool xs in\n { T.name = s \"name\"\n ; doc = s \"ocaml.doc\"\n ; skip = b \"skip\"\n ; deprecated = s \"depr\"\n }\n\n let%test_unit \"field annots parse\" =\n let annots = of_annots T.t_fields_annots in\n [%test_eq: T.t] (annots \"doc\")\n { name = Some \"document\"; doc = None; skip = false; deprecated = None } ;\n [%test_eq: T.t] (annots \"skip\")\n { name = None; doc = None; skip = true; deprecated = None } ;\n [%test_eq: T.t] (annots \"deprecated\")\n { name = None\n ; doc = Some \"this is deprecated\"\n ; skip = false\n ; deprecated = Some \"foo\"\n }\n end\nend\n\n(** Rewrites underscore_case to camelCase. Note: Keeps leading underscores. *)\nlet under_to_camel s =\n (* take all the underscores *)\n let prefix_us =\n String.take_while s ~f:(function '_' -> true | _ -> false)\n in\n (* remove them from the original *)\n let rest = String.substr_replace_first ~pattern:prefix_us ~with_:\"\" s in\n let ws = String.split rest ~on:'_' in\n let result =\n match ws with\n | [] ->\n \"\"\n | w :: ws ->\n (* capitalize each word separated by underscores *)\n w :: (ws |> List.map ~f:String.capitalize) |> String.concat ?sep:None\n in\n (* add the leading underscoes back *)\n String.concat [ prefix_us; result ]\n\nlet%test_unit \"under_to_camel works as expected\" =\n let open Core_kernel in\n [%test_eq: string] \"fooHello\" (under_to_camel \"foo_hello\") ;\n [%test_eq: string] \"fooHello\" (under_to_camel \"foo_hello___\") ;\n [%test_eq: string] \"_fooHello\" (under_to_camel \"_foo_hello__\")\n\n(** Like Field.name but rewrites underscore_case to camelCase. *)\nlet name_under_to_camel f = Fieldslib.Field.name f |> under_to_camel\n\nlet introspection_query_raw =\n {graphql|\n query IntrospectionQuery {\n __schema {\n queryType { name }\n mutationType { name }\n subscriptionType { name }\n types {\n ...FullType\n }\n directives {\n name\n description\n locations\n args {\n ...InputValue\n }\n }\n }\n }\n fragment FullType on __Type {\n kind\n name\n description\n fields(includeDeprecated: true) {\n name\n description\n args {\n ...InputValue\n }\n type {\n ...TypeRef\n }\n isDeprecated\n deprecationReason\n }\n inputFields {\n ...InputValue\n }\n interfaces {\n ...TypeRef\n }\n enumValues(includeDeprecated: true) {\n name\n description\n isDeprecated\n deprecationReason\n }\n possibleTypes {\n ...TypeRef\n }\n }\n fragment InputValue on __InputValue {\n name\n description\n type { ...TypeRef }\n defaultValue\n }\n fragment TypeRef on __Type {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n ofType {\n kind\n name\n }\n }\n }\n }\n }\n }\n }\n }\n |graphql}\n","open Core_kernel\nopen Fieldslib\n\nmodule Graphql_raw = struct\n module Make (Schema : Graphql_intf.Schema) = struct\n module Args = struct\n module Input = struct\n type ('row, 'result, 'ty, 'nullable) t =\n < graphql_arg : (unit -> 'ty Schema.Arg.arg_typ) ref\n ; nullable_graphql_arg : (unit -> 'nullable Schema.Arg.arg_typ) ref\n ; map : ('ty -> 'result) ref\n ; skip : bool ref\n ; .. >\n as\n 'row\n end\n\n module Acc = struct\n module T = struct\n type ('ty, 'fields) t_inner =\n { graphql_arg_fields : ('ty, 'fields) Schema.Arg.arg_list\n ; graphql_arg_coerce : 'fields\n }\n\n type 'ty t = Init | Acc : ('ty, 'fields) t_inner -> 'ty t\n end\n\n type ('row, 'result, 'ty, 'nullable) t =\n < graphql_arg_accumulator : 'result T.t ref ; .. > as 'row\n constraint\n ('row, 'c, 'ty, 'nullable) t =\n ('row, 'c, 'ty, 'nullable) Input.t\n end\n\n module Creator = struct\n type ('row, 'c, 'ty, 'nullable) t = < .. > as 'row\n constraint\n ('row, 'c, 'ty, 'nullable) t =\n ('row, 'c, 'ty, 'nullable) Input.t\n end\n\n module Output = struct\n type ('row, 'c, 'ty, 'nullable) t = < .. > as 'row\n constraint\n ('row, 'c, 'ty, 'nullable) t =\n ('row, 'c, 'ty, 'nullable) Input.t\n end\n\n let add_field (type f f' ty ty' nullable1 nullable2) ?skip_data\n ~t_fields_annots :\n ('f_row, f', f, nullable1) Input.t\n -> ([< `Read | `Set_and_create ], _, _) Field.t_with_perm\n -> ('row, ty', ty, nullable2) Acc.t\n -> (('row, ty', ty, nullable2) Creator.t -> f')\n * ('row_after, ty', ty, nullable2) Acc.t =\n fun f_input field acc ->\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let ref_as_pipe = ref None in\n let name =\n Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field)\n in\n let () =\n let inner_acc = acc#graphql_arg_accumulator in\n if annotations.skip || !(f_input#skip) then ()\n else\n let arg =\n Schema.Arg.arg name ?doc:annotations.doc\n ~typ:(!(f_input#graphql_arg) ())\n in\n match !inner_acc with\n | Init ->\n inner_acc :=\n Acc\n { graphql_arg_coerce =\n (fun x ->\n ref_as_pipe := Some x ;\n !(acc#graphql_creator) acc )\n ; graphql_arg_fields = [ arg ]\n }\n | Acc { graphql_arg_fields; graphql_arg_coerce } -> (\n match graphql_arg_fields with\n | [] ->\n inner_acc :=\n Acc\n { graphql_arg_coerce =\n (fun x ->\n ref_as_pipe := Some x ;\n !(acc#graphql_creator) acc )\n ; graphql_arg_fields = [ arg ]\n }\n | _ ->\n inner_acc :=\n Acc\n { graphql_arg_coerce =\n (fun x ->\n ref_as_pipe := Some x ;\n graphql_arg_coerce )\n ; graphql_arg_fields = arg :: graphql_arg_fields\n } )\n in\n ( (fun _creator_input ->\n !(f_input#map)\n @@\n if annotations.skip || !(f_input#skip) then\n match skip_data with\n | Some data ->\n data\n | None ->\n failwith\n \"If you are skipping a field but intend on building this \\\n field, you must provide skip_data to add_field!\"\n else Option.value_exn !ref_as_pipe )\n , acc )\n\n let finish name ~t_toplevel_annots (type ty result nullable) :\n (('row, result, ty, nullable) Input.t -> result)\n * ('row, result, ty, nullable) Acc.t\n -> _ Output.t =\n fun (creator, acc) ->\n let annotations =\n Fields_derivers.Annotations.Top.of_annots ~name t_toplevel_annots\n in\n acc#graphql_creator := creator ;\n (acc#graphql_arg :=\n fun () ->\n match !(acc#graphql_arg_accumulator) with\n | Init ->\n failwith \"Graphql args need at least one field\"\n | Acc { graphql_arg_fields; graphql_arg_coerce } ->\n (* TODO: Figure out why the typechecker doesn't like this\n * expression and remove Obj.magic. *)\n Obj.magic\n @@ Schema.Arg.(\n obj ?doc:annotations.doc\n (annotations.name ^ \"Input\")\n ~fields:graphql_arg_fields ~coerce:graphql_arg_coerce\n |> non_null) ) ;\n (acc#nullable_graphql_arg :=\n fun () ->\n match !(acc#graphql_arg_accumulator) with\n | Init ->\n failwith \"Graphql args need at least one field\"\n | Acc { graphql_arg_fields; graphql_arg_coerce } ->\n (* TODO: See above *)\n Obj.magic\n @@ Schema.Arg.(\n obj ?doc:annotations.doc\n (annotations.name ^ \"Input\")\n ~fields:graphql_arg_fields ~coerce:graphql_arg_coerce)\n ) ;\n acc\n\n let skip obj =\n obj#skip := true ;\n (obj#graphql_arg :=\n fun () ->\n failwith \"Unexpected: This obj#graphql_arg should be skipped\" ) ;\n obj#map := Fn.id ;\n obj#graphql_arg_accumulator := !(obj#graphql_arg_accumulator) ;\n (obj#nullable_graphql_arg :=\n fun () ->\n failwith \"Unexpected: This obj#graphql_arg should be skipped\" ) ;\n obj\n\n let int obj =\n (obj#graphql_arg := fun () -> Schema.Arg.(non_null int)) ;\n obj#map := Fn.id ;\n obj#graphql_arg_accumulator := !(obj#graphql_arg_accumulator) ;\n (obj#nullable_graphql_arg := fun () -> Schema.Arg.int) ;\n obj\n\n let string obj =\n (obj#graphql_arg := fun () -> Schema.Arg.(non_null string)) ;\n obj#map := Fn.id ;\n obj#graphql_arg_accumulator := !(obj#graphql_arg_accumulator) ;\n (obj#nullable_graphql_arg := fun () -> Schema.Arg.string) ;\n obj\n\n let bool obj =\n (obj#graphql_arg := fun () -> Schema.Arg.(non_null bool)) ;\n obj#map := Fn.id ;\n obj#graphql_arg_accumulator := !(obj#graphql_arg_accumulator) ;\n (obj#nullable_graphql_arg := fun () -> Schema.Arg.bool) ;\n obj\n\n let list x obj : (_, 'result list, 'input_type list, _) Input.t =\n (obj#graphql_arg :=\n fun () -> Schema.Arg.(non_null (list (!(x#graphql_arg) ()))) ) ;\n obj#map := List.map ~f:!(x#map) ;\n obj#graphql_arg_accumulator := !(x#graphql_arg_accumulator) ;\n (obj#nullable_graphql_arg :=\n fun () -> Schema.Arg.(list (!(x#graphql_arg) ())) ) ;\n obj\n\n let option (x : (_, 'result, 'input_type, _) Input.t) obj =\n obj#graphql_arg := !(x#nullable_graphql_arg) ;\n obj#nullable_graphql_arg := !(x#nullable_graphql_arg) ;\n obj#map := Option.map ~f:!(x#map) ;\n obj#graphql_arg_accumulator := !(x#graphql_arg_accumulator) ;\n obj\n\n let map ~(f : 'c -> 'd) (x : (_, 'c, 'input_type, _) Input.t) obj :\n (_, 'd, 'input_type, _) Input.t =\n obj#graphql_arg := !(x#graphql_arg) ;\n (obj#map := fun a -> f (!(x#map) a)) ;\n obj#nullable_graphql_arg := !(x#nullable_graphql_arg) ;\n obj#graphql_arg_accumulator := !(x#graphql_arg_accumulator) ;\n obj\n end\n\n module Fields = struct\n module Input = struct\n module T = struct\n type 'input_type t =\n { run : 'ctx. unit -> ('ctx, 'input_type) Schema.typ }\n end\n\n type ('input_type, 'a, 'c, 'nullable) t =\n < graphql_fields : 'input_type T.t ref\n ; contramap : ('c -> 'input_type) ref\n ; nullable_graphql_fields : 'nullable T.t ref\n ; .. >\n as\n 'a\n end\n\n module Accumulator = struct\n module T = struct\n type 'input_type t =\n { run : 'ctx. unit -> ('ctx, 'input_type) Schema.field option }\n end\n\n (** thunks generating the schema in reverse *)\n type ('input_type, 'a, 'c, 'nullable) t =\n < graphql_fields_accumulator : 'c T.t list ref ; .. > as 'a\n constraint\n ('input_type, 'a, 'c, 'nullable) t =\n ('input_type, 'a, 'c, 'nullable) Input.t\n end\n\n let add_field (type f input_type orig nullable c' nullable')\n ~t_fields_annots :\n (orig, 'a, f, nullable) Input.t\n -> ([< `Read | `Set_and_create ], c', f) Fieldslib.Field.t_with_perm\n -> (input_type, 'row2, c', nullable') Accumulator.t\n -> (_ -> f) * (input_type, 'row2, c', nullable') Accumulator.t =\n fun t_field field acc ->\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let rest = !(acc#graphql_fields_accumulator) in\n acc#graphql_fields_accumulator :=\n { Accumulator.T.run =\n (fun () ->\n if annotations.skip || !(t_field#skip) then None\n else\n Schema.field\n (Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field) )\n ~args:Schema.Arg.[]\n ?doc:annotations.doc\n ~deprecated:\n ( Option.map annotations.deprecated ~f:(fun msg ->\n Schema.Deprecated (Some msg) )\n |> Option.value ~default:Schema.NotDeprecated )\n ~typ:(!(t_field#graphql_fields).Input.T.run ())\n ~resolve:(fun _ x ->\n !(t_field#contramap) (Field.get field x) )\n |> Option.return )\n }\n :: rest ;\n ((fun _ -> failwith \"Unused\"), acc)\n\n let finish name ~t_toplevel_annots ((_creator, obj) : 'u * _ Accumulator.t)\n : _ Input.t =\n let annotations =\n Fields_derivers.Annotations.Top.of_annots ~name t_toplevel_annots\n in\n let graphql_fields_accumulator = !(obj#graphql_fields_accumulator) in\n let graphql_fields =\n { Input.T.run =\n (fun () ->\n Schema.obj annotations.name ?doc:annotations.doc\n ~fields:(fun _ ->\n List.rev\n @@ List.filter_map graphql_fields_accumulator ~f:(fun g ->\n g.Accumulator.T.run () ) )\n |> Schema.non_null )\n }\n in\n let nullable_graphql_fields =\n { Input.T.run =\n (fun () ->\n Schema.obj annotations.name ?doc:annotations.doc\n ~fields:(fun _ ->\n List.rev\n @@ List.filter_map graphql_fields_accumulator ~f:(fun g ->\n g.Accumulator.T.run () ) ) )\n }\n in\n obj#graphql_fields := graphql_fields ;\n obj#nullable_graphql_fields := nullable_graphql_fields ;\n obj#contramap := Fn.id ;\n obj\n\n let skip obj =\n (obj#graphql_fields :=\n Input.T.\n { run =\n (fun () ->\n failwith\n \"Unexpected: This obj#graphql_fields should be skipped\" )\n } ) ;\n obj#contramap := Fn.id ;\n obj#graphql_fields_accumulator := !(obj#graphql_fields_accumulator) ;\n (obj#nullable_graphql_fields :=\n Input.T.\n { run =\n (fun () ->\n failwith\n \"Unexpected: This obj#nullable_graphql_fields should be \\\n skipped\" )\n } ) ;\n obj\n\n let int obj =\n (obj#graphql_fields :=\n Input.T.{ run = (fun () -> Schema.(non_null int)) } ) ;\n obj#contramap := Fn.id ;\n obj#graphql_fields_accumulator := !(obj#graphql_fields_accumulator) ;\n (obj#nullable_graphql_fields := Input.T.{ run = (fun () -> Schema.int) }) ;\n obj\n\n let string obj =\n (obj#graphql_fields :=\n Input.T.{ run = (fun () -> Schema.(non_null string)) } ) ;\n obj#contramap := Fn.id ;\n obj#graphql_fields_accumulator := !(obj#graphql_fields_accumulator) ;\n (obj#nullable_graphql_fields :=\n Input.T.{ run = (fun () -> Schema.string) } ) ;\n obj\n\n let bool obj =\n (obj#graphql_fields :=\n Input.T.{ run = (fun () -> Schema.(non_null bool)) } ) ;\n obj#contramap := Fn.id ;\n obj#graphql_fields_accumulator := !(obj#graphql_fields_accumulator) ;\n (obj#nullable_graphql_fields :=\n Input.T.{ run = (fun () -> Schema.bool) } ) ;\n obj\n\n let list x obj : ('input_type list, _, _, _) Input.t =\n (obj#graphql_fields :=\n Input.T.\n { run =\n (fun () ->\n Schema.(non_null (list (!(x#graphql_fields).run ()))) )\n } ) ;\n obj#contramap := List.map ~f:!(x#contramap) ;\n obj#graphql_fields_accumulator := !(x#graphql_fields_accumulator) ;\n (obj#nullable_graphql_fields :=\n Input.T.\n { run = (fun () -> Schema.(list (!(x#graphql_fields).run ()))) } ) ;\n obj\n\n let option (x : ('input_type, 'b, 'c, 'nullable) Input.t) obj :\n ('input_type option, _, 'c option, _) Input.t =\n obj#graphql_fields := !(x#nullable_graphql_fields) ;\n obj#nullable_graphql_fields := !(x#nullable_graphql_fields) ;\n obj#contramap := Option.map ~f:!(x#contramap) ;\n obj#graphql_fields_accumulator := !(x#graphql_fields_accumulator) ;\n obj\n\n let contramap ~(f : 'd -> 'c)\n (x : ('input_type, 'b, 'c, 'nullable) Input.t) obj :\n ('input_type, _, 'd, _) Input.t =\n obj#graphql_fields := !(x#graphql_fields) ;\n (obj#contramap := fun a -> !(x#contramap) (f a)) ;\n obj#nullable_graphql_fields := !(x#nullable_graphql_fields) ;\n obj#graphql_fields_accumulator := !(x#graphql_fields_accumulator) ;\n obj\n end\n\n let rec arg_to_yojson_rec (arg : Graphql_parser.const_value) : Yojson.Safe.t\n =\n match arg with\n | `Null ->\n `Null\n | `Int x ->\n `Int x\n | `Float x ->\n `Float x\n | `String x ->\n `String x\n | `Bool x ->\n `Bool x\n | `Enum x ->\n `String x\n | `List x ->\n `List (List.map x ~f:arg_to_yojson_rec)\n | `Assoc x ->\n `Assoc\n (List.map x ~f:(fun (key, value) -> (key, arg_to_yojson_rec value)))\n\n let arg_to_yojson arg : (Yojson.Safe.t, string) result =\n Ok (arg_to_yojson_rec arg)\n end\nend\n\nmodule Graphql_query = struct\n module Input = struct\n type 'a t = < graphql_query : string option ref ; .. > as 'a\n end\n\n module Accumulator = struct\n type 'a t =\n < graphql_query_accumulator : (string * string option) option list ref\n ; .. >\n as\n 'a\n constraint 'a t = 'a Input.t\n end\n\n let add_field ~t_fields_annots :\n 'a Input.t -> 'field -> 'obj -> 'creator * 'obj =\n fun t_field field acc_obj ->\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let rest = !(acc_obj#graphql_query_accumulator) in\n acc_obj#graphql_query_accumulator :=\n ( if annotations.skip || !(t_field#skip) then None\n else\n Some\n ( Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field)\n , !(t_field#graphql_query) ) )\n :: rest ;\n ((fun _ -> failwith \"unused\"), acc_obj)\n\n let finish (_creator, obj) =\n let graphql_query_accumulator = !(obj#graphql_query_accumulator) in\n obj#graphql_query :=\n Some\n (sprintf \"{\\n%s\\n}\"\n ( List.filter_map graphql_query_accumulator\n ~f:\n (Option.map ~f:(fun (k, v) ->\n match v with None -> k | Some v -> sprintf \"%s %s\" k v )\n )\n |> List.rev |> String.concat ~sep:\"\\n\" ) ) ;\n obj\n\n let scalar obj =\n obj#graphql_query := None ;\n obj\n\n let skip obj = scalar obj\n\n let int obj = scalar obj\n\n let string obj = scalar obj\n\n let bool obj = scalar obj\n\n (* nullable and lists of things are projected to the inner thing ONLY IF inner\n * projectable. *)\n let wrapped x obj =\n obj#graphql_query := !(x#graphql_query) ;\n obj\n\n let option x obj = wrapped x obj\n\n let list x obj = wrapped x obj\n\n let inner_query obj = !(obj#graphql_query)\nend\n\nmodule IO = struct\n include Async_kernel.Deferred\n\n let bind x f = bind x ~f\n\n module Stream = struct\n type 'a t = 'a Async_kernel.Pipe.Reader.t\n\n let map t f =\n Async_kernel.Pipe.map' t ~f:(fun q ->\n Async_kernel.Deferred.Queue.map q ~f )\n\n let iter t f = Async_kernel.Pipe.iter t ~f\n\n let close = Async_kernel.Pipe.close_read\n end\nend\n\nmodule Field_error = struct\n type t = string\n\n let message_of_field_error t = t\n\n let extensions_of_field_error _t = None\nend\n\nmodule Schema = Graphql_schema.Make (IO) (Field_error)\nmodule Graphql = Graphql_raw.Make (Schema)\n\nmodule Test = struct\n let parse_query str =\n match Graphql_parser.parse str with\n | Ok res ->\n res\n | Error err ->\n failwith err\n\n let introspection_query () =\n parse_query Fields_derivers.introspection_query_raw\nend\n\nlet%test_module \"Test\" =\n ( module struct\n (* Pure -- just like Graphql libraries functor application *)\n module IO = struct\n type +'a t = 'a\n\n let bind t f = f t\n\n let return t = t\n\n module Stream = struct\n type 'a t = 'a Seq.t\n\n let map t f = Seq.map f t\n\n let iter t f = Seq.iter f t\n\n let close _t = ()\n end\n end\n\n module Schema = Graphql_schema.Make (IO) (Field_error)\n module Graphql = Graphql_raw.Make (Schema)\n module Graphql_fields = Graphql.Fields\n module Graphql_args = Graphql.Args\n\n let deriver (type a b c d) () :\n < contramap : (a -> b) ref\n ; graphql_fields : c Graphql_fields.Input.T.t ref\n ; nullable_graphql_fields : d Graphql_fields.Input.T.t ref\n ; .. >\n as\n 'row =\n (* We have to declare these outside of the object, otherwise the method\n * will create a new ref each time it is called. *)\n let open Graphql_fields in\n let graphql_fields =\n ref Input.T.{ run = (fun () -> failwith \"unimplemented1\") }\n in\n let graphql_arg = ref (fun () -> failwith \"unimplemented2\") in\n let contramap = ref (fun _ -> failwith \"unimplemented3\") in\n let map = ref (fun _ -> failwith \"unimplemented4\") in\n let nullable_graphql_fields =\n ref Input.T.{ run = (fun () -> failwith \"unimplemented5\") }\n in\n let nullable_graphql_arg = ref (fun () -> failwith \"unimplemented6\") in\n let graphql_fields_accumulator = ref [] in\n let graphql_arg_accumulator = ref Graphql_args.Acc.T.Init in\n let graphql_creator = ref (fun _ -> failwith \"unimplemented7\") in\n let graphql_query = ref None in\n let graphql_query_accumulator = ref [] in\n let skip = ref false in\n object\n method skip = skip\n\n method graphql_fields = graphql_fields\n\n method graphql_arg = graphql_arg\n\n method contramap = contramap\n\n method map = map\n\n method nullable_graphql_fields = nullable_graphql_fields\n\n method nullable_graphql_arg = nullable_graphql_arg\n\n method graphql_fields_accumulator = graphql_fields_accumulator\n\n method graphql_arg_accumulator = graphql_arg_accumulator\n\n method graphql_creator = graphql_creator\n\n method graphql_query = graphql_query\n\n method graphql_query_accumulator = graphql_query_accumulator\n end\n\n let o () = deriver ()\n\n let raw_server ?(print = false) q c =\n let schema = Schema.(schema [ q ] ~mutations:[] ~subscriptions:[]) in\n let res = Schema.execute schema () c in\n match res with\n | Ok (`Response data) ->\n if print then Yojson.Basic.pretty_print Format.std_formatter data ;\n data |> Yojson.Basic.to_string\n | Error err ->\n failwithf \"Unexpected error: %s\" (Yojson.Basic.to_string err) ()\n | _ ->\n failwith \"Unexpected response\"\n\n let query_schema typ v =\n Schema.(\n field \"query\" ~typ:(non_null typ)\n ~args:Arg.[]\n ~doc:\"sample query\"\n ~resolve:(fun _ _ -> v))\n\n let query_for_all typ v str =\n raw_server (query_schema typ v) (Test.parse_query str)\n\n let hit_server ?print q = raw_server ?print q (Test.introspection_query ())\n\n let hit_server_query (typ : _ Schema.typ) v =\n hit_server (query_schema typ v)\n\n let hit_server_args (arg_typ : 'a Schema.Arg.arg_typ) =\n hit_server\n Schema.(\n field \"args\" ~typ:(non_null int)\n ~args:Arg.[ arg \"input\" ~typ:arg_typ ]\n ~doc:\"sample args query\"\n ~resolve:(fun _ _ _ -> 0))\n\n module T1 = struct\n (** T1 is foo *)\n type t =\n { foo_hello : int option\n ; skipped : int [@skip]\n ; bar : string list [@name \"bar1\"]\n }\n [@@deriving annot, fields]\n\n let _v = { foo_hello = Some 1; skipped = 0; bar = [ \"baz1\"; \"baz2\" ] }\n\n let doc = \"T1 is foo\"\n\n let manual_typ =\n Schema.(\n obj \"T1\" ~doc ~fields:(fun _ ->\n [ field \"fooHello\"\n ~args:Arg.[]\n ~typ:int\n ~resolve:(fun _ t -> t.foo_hello)\n ; field \"bar1\"\n ~args:Arg.[]\n ~typ:(non_null (list (non_null string)))\n ~resolve:(fun _ t -> t.bar)\n ] ))\n\n let derived init =\n let open Graphql_fields in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x (o ())) fd acc in\n Fields.make_creator init\n ~foo_hello:!.(option @@ int @@ o ())\n ~skipped:!.skip\n ~bar:!.(list @@ string @@ o ())\n |> finish \"T1\" ~t_toplevel_annots\n\n module Args = struct\n let manual_typ =\n Schema.Arg.(\n obj \"T1Input\" ~doc\n ~fields:\n [ arg \"bar1\" ~typ:(non_null (list (non_null string)))\n ; arg \"fooHello\" ~typ:int\n ]\n ~coerce:(fun bar foo_hello -> { bar; skipped = 0; foo_hello }))\n\n let derived init =\n let open Graphql_args in\n let ( !. ) ?skip_data x fd acc =\n add_field ?skip_data ~t_fields_annots (x (o ())) fd acc\n in\n Fields.make_creator init\n ~foo_hello:!.(option @@ int @@ o ())\n ~skipped:(( !. ) ~skip_data:0 skip)\n ~bar:!.(list @@ string @@ o ())\n |> finish \"T1\" ~t_toplevel_annots\n end\n\n module Query = struct\n let derived init =\n let open Graphql_query in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x (o ())) fd acc in\n Fields.make_creator init\n ~foo_hello:!.(option @@ int @@ o ())\n ~skipped:!.skip\n ~bar:!.(list @@ string @@ o ())\n |> finish\n end\n end\n\n module Or_ignore_test = struct\n type 'a t = Check of 'a | Ignore\n\n let of_option = function None -> Ignore | Some x -> Check x\n\n let to_option = function Ignore -> None | Check x -> Some x\n\n let derived (x : ('input_type, 'b, 'c, _) Graphql_fields.Input.t) init :\n (_, _, 'c t, _) Graphql_fields.Input.t =\n let open Graphql_fields in\n let opt = option x (o ()) in\n contramap ~f:to_option opt init\n\n module Args = struct\n let derived (x : ('row1, 'c, 'input_type, _) Graphql_args.Input.t) init\n : ('row2, 'c t, 'input_type option, _) Graphql_args.Input.t =\n let open Graphql_args in\n let opt = option x (o ()) in\n map ~f:of_option opt init\n end\n\n module Query = struct\n let derived x init =\n let open Graphql_query in\n option x init\n end\n end\n\n module T2 = struct\n type t = { foo : T1.t Or_ignore_test.t } [@@deriving annot, fields]\n\n let v1 =\n { foo =\n Check\n { T1.foo_hello = Some 1; skipped = 0; bar = [ \"baz1\"; \"baz2\" ] }\n }\n\n let v2 = { foo = Ignore }\n\n let manual_typ =\n Schema.(\n obj \"T2\" ?doc:None ~fields:(fun _ ->\n [ field \"foo\"\n ~args:Arg.[]\n ~typ:T1.manual_typ\n ~resolve:(fun _ t -> Or_ignore_test.to_option t.foo)\n ] ))\n\n let derived init =\n let open Graphql_fields in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x (o ())) fd acc in\n Fields.make_creator init\n ~foo:!.(Or_ignore_test.derived @@ T1.derived @@ o ())\n |> finish \"T2\" ~t_toplevel_annots\n\n module Args = struct\n let manual_typ =\n Schema.Arg.(\n obj \"T2Input\" ?doc:None\n ~fields:[ arg \"foo\" ~typ:T1.Args.manual_typ ]\n ~coerce:(fun foo -> Or_ignore_test.of_option foo))\n\n let derived init =\n let open Graphql_args in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x (o ())) fd acc in\n Fields.make_creator init\n ~foo:!.(Or_ignore_test.Args.derived @@ T1.Args.derived @@ o ())\n |> finish \"T2\" ~t_toplevel_annots\n end\n\n module Query = struct\n let manual =\n {|\n {\n foo {\n fooHello\n bar1\n }\n }\n |}\n\n let derived init =\n let open Graphql_query in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x (o ())) fd acc in\n Fields.make_creator init\n ~foo:!.(Or_ignore_test.Query.derived @@ T1.Query.derived @@ o ())\n |> finish\n end\n end\n\n let%test_unit \"T2 fold\" =\n let open Graphql_fields in\n let generated_typ =\n let typ_input = T2.(option @@ derived @@ o ()) (o ()) in\n !(typ_input#graphql_fields).run ()\n in\n [%test_eq: string]\n (hit_server_query generated_typ T2.v1)\n (hit_server_query T2.manual_typ T2.v1) ;\n [%test_eq: string]\n (hit_server_query generated_typ T2.v2)\n (hit_server_query T2.manual_typ T2.v2)\n\n let%test_unit \"T2 unfold\" =\n let open Graphql_args in\n let generated_arg_typ =\n let obj = T2.(option @@ Args.derived @@ o ()) (o ()) in\n !(obj#graphql_arg) ()\n in\n [%test_eq: string]\n (hit_server_args generated_arg_typ)\n (hit_server_args T2.Args.manual_typ)\n\n let%test_unit \"T2 query expected & parses\" =\n let open Graphql_fields in\n let generated_typ =\n let typ_input = T2.(option @@ derived @@ o ()) (o ()) in\n !(typ_input#graphql_fields).run ()\n in\n let open Graphql_query in\n let generated_query =\n T2.Query.(option @@ derived @@ o ()) (o ())\n |> inner_query |> Option.value_exn\n in\n let prefix = \"query TestQuery { query\" in\n let suffix = \"}\" in\n [%test_eq: string]\n (query_for_all generated_typ T2.v1 (prefix ^ generated_query ^ suffix))\n (query_for_all generated_typ T2.v1 (prefix ^ T2.Query.manual ^ suffix))\n end )\n","open Core_kernel\nopen Fieldslib\n\nmodule To_yojson = struct\n module Input = struct\n type ('input_type, 'a, 'c) t =\n < to_json : ('input_type -> Yojson.Safe.t) ref\n ; contramap : ('c -> 'input_type) ref\n ; skip : bool ref\n ; .. >\n as\n 'a\n end\n\n module Accumulator = struct\n type ('input_type, 'a, 'c) t =\n < to_json_accumulator :\n (string * ('input_type -> Yojson.Safe.t)) option list ref\n ; .. >\n as\n 'a\n constraint ('input_type, 'a, 'c) t = ('input_type, 'a, 'c) Input.t\n end\n\n let add_field ~t_fields_annots t_field field acc =\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let rest = !(acc#to_json_accumulator) in\n acc#to_json_accumulator :=\n ( if annotations.skip || !(t_field#skip) then None\n else\n ( Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field)\n , fun x -> !(t_field#to_json) (!(t_field#contramap) (Field.get field x))\n )\n |> Option.return )\n :: rest ;\n ((fun _ -> failwith \"Unused\"), acc)\n\n let finish (_creator, obj) =\n let to_json_accumulator = !(obj#to_json_accumulator) in\n obj#contramap := Fn.id ;\n (obj#to_json :=\n fun t ->\n `Assoc\n ( List.filter_map to_json_accumulator\n ~f:(Option.map ~f:(fun (name, f) -> (name, f t)))\n |> List.rev ) ) ;\n obj\n\n let skip obj =\n obj#skip := true ;\n obj#contramap := Fn.id ;\n (obj#to_json :=\n fun _ -> failwith \"Unexpected: This obj#to_json should be skipped\" ) ;\n obj\n\n let int obj =\n obj#contramap := Fn.id ;\n (obj#to_json := fun x -> `Int x) ;\n obj\n\n let string obj =\n obj#contramap := Fn.id ;\n (obj#to_json := fun x -> `String x) ;\n obj\n\n let bool obj =\n obj#contramap := Fn.id ;\n (obj#to_json := fun x -> `Bool x) ;\n obj\n\n let list x obj =\n obj#contramap := List.map ~f:!(x#contramap) ;\n (obj#to_json := fun a -> `List (List.map ~f:!(x#to_json) a)) ;\n obj\n\n let option x obj =\n obj#contramap := Option.map ~f:!(x#contramap) ;\n (obj#to_json :=\n fun a_opt -> match a_opt with Some a -> !(x#to_json) a | None -> `Null ) ;\n obj\n\n let contramap ~f x obj =\n (obj#contramap := fun a -> !(x#contramap) (f a)) ;\n obj#to_json := !(x#to_json) ;\n obj\nend\n\nmodule Of_yojson = struct\n module Input = struct\n type ('input_type, 'a, 'c) t =\n < of_json : (Yojson.Safe.t -> 'input_type) ref\n ; map : ('input_type -> 'c) ref\n ; skip : bool ref\n ; .. >\n as\n 'a\n end\n\n module Creator = struct\n type ('input_type, 'a, 'c) t =\n < of_json_creator : Yojson.Safe.t String.Map.t ref ; .. > as 'a\n constraint ('input_type, 'a, 'c) t = ('input_type, 'a, 'c) Input.t\n end\n\n exception Field_not_found of string\n\n let add_field ?skip_data ~t_fields_annots :\n ('t, 'a, 'c) Input.t -> 'field -> 'obj -> 'creator * 'obj =\n fun t_field field acc_obj ->\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let creator finished_obj =\n let map = !(finished_obj#of_json_creator) in\n !(t_field#map)\n ( if annotations.skip || !(t_field#skip) then\n match skip_data with\n | Some x ->\n x\n | None ->\n failwith\n \"If you are skipping a field in of_json but intend on building \\\n this field, you must provide skip_data to add_field!\"\n else\n !(t_field#of_json)\n (let name =\n Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field)\n in\n match Map.find map name with\n | None ->\n raise (Field_not_found name)\n | Some x ->\n x ) )\n in\n (creator, acc_obj)\n\n exception Json_not_object\n\n let finish (creator, obj) =\n let of_json json =\n match json with\n | `Assoc pairs ->\n obj#of_json_creator := String.Map.of_alist_exn pairs ;\n creator obj\n | _ ->\n raise Json_not_object\n in\n obj#map := Fn.id ;\n obj#of_json := of_json ;\n obj\n\n exception Invalid_json_scalar of [ `Int | `String | `Bool | `List ]\n\n let skip obj =\n obj#contramap := Fn.id ;\n (obj#of_json :=\n fun _ -> failwith \"Unexpected: This obj#of_json should be skipped\" ) ;\n obj\n\n let int obj =\n (obj#of_json :=\n function `Int x -> x | _ -> raise (Invalid_json_scalar `Int) ) ;\n obj#map := Fn.id ;\n obj\n\n let string obj =\n (obj#of_json :=\n function `String x -> x | _ -> raise (Invalid_json_scalar `String) ) ;\n obj#map := Fn.id ;\n obj\n\n let bool obj =\n (obj#of_json :=\n function `Bool x -> x | _ -> raise (Invalid_json_scalar `Bool) ) ;\n obj#map := Fn.id ;\n obj\n\n let list x obj =\n (obj#of_json :=\n function\n | `List xs ->\n List.map xs ~f:!(x#of_json)\n | _ ->\n raise (Invalid_json_scalar `List) ) ;\n obj#map := List.map ~f:!(x#map) ;\n obj\n\n let option x obj =\n (obj#of_json :=\n function `Null -> None | other -> Some (!(x#of_json) other) ) ;\n obj#map := Option.map ~f:!(x#map) ;\n obj\n\n let map ~f x obj =\n (obj#map := fun a -> f (!(x#map) a)) ;\n obj#of_json := !(x#of_json) ;\n obj\nend\n\nlet%test_module \"Test\" =\n ( module struct\n type t = { foo_hello : int; skipped : int [@skip]; bar : string list }\n [@@deriving annot, fields]\n\n let v = { foo_hello = 1; skipped = 0; bar = [ \"baz1\"; \"baz2\" ] }\n\n let m =\n {json|{ fooHello: 1, bar: [\"baz1\", \"baz2\"] }|json}\n |> Yojson.Safe.from_string\n\n module Yojson_version = struct\n type t = { foo_hello : int [@key \"fooHello\"]; bar : string list }\n [@@deriving yojson]\n\n let v = { foo_hello = 1; bar = [ \"baz1\"; \"baz2\" ] }\n end\n\n let deriver () =\n let to_json = ref (fun _ -> failwith \"unimplemented\") in\n let of_json = ref (fun _ -> failwith \"unimplemented\") in\n let to_json_accumulator = ref [] in\n let of_json_creator = ref String.Map.empty in\n let map = ref Fn.id in\n let contramap = ref Fn.id in\n let skip = ref false in\n object\n method skip = skip\n\n method to_json = to_json\n\n method map = map\n\n method contramap = contramap\n\n method of_json = of_json\n\n method to_json_accumulator = to_json_accumulator\n\n method of_json_creator = of_json_creator\n end\n\n let o () = deriver ()\n\n (* Explanation: Fields.make_creator roughly executes the following code:\n\n let make_creator ~foo_hello ~bar obj =\n (* Fieldslib.Field is actually a little more complicated *)\n let field_foo = Field { name = \"foo_hello\" ; getter = (fun o -> o.foo_hello) } in\n let field_bar = Field { name = \"bar\"; getter = (fun o -> o.bar) } in\n let creator_foo, obj = foo_hello field_foo obj in\n let creator_bar, obj = bar field_bar obj in\n let creator finished_obj =\n { foo_hello = creator_foo finished_obj ; bar = creator_bar finished_obj }\n in\n (creator, obj)\n *)\n\n let to_json obj =\n let open To_yojson in\n let ( !. ) x fd acc = add_field ~t_fields_annots (x @@ o ()) fd acc in\n Fields.make_creator obj ~foo_hello:!.int ~skipped:!.skip\n ~bar:!.(list @@ string @@ o ())\n |> finish\n\n let of_json obj =\n let open Of_yojson in\n let ( !. ) ?skip_data x fd acc =\n add_field ?skip_data ~t_fields_annots (x @@ o ()) fd acc\n in\n Fields.make_creator obj ~foo_hello:!.int\n ~skipped:(( !. ) ~skip_data:0 skip)\n ~bar:!.(list @@ string @@ o ())\n |> finish\n\n let both_json obj =\n let _a = to_json obj in\n let _b = of_json obj in\n obj\n\n let full_derivers = both_json @@ o ()\n\n let%test_unit \"folding creates a yojson object we expect (modulo camel \\\n casing)\" =\n [%test_eq: string]\n (Yojson_version.to_yojson Yojson_version.v |> Yojson.Safe.to_string)\n (!(full_derivers#to_json) v |> Yojson.Safe.to_string)\n\n let%test_unit \"unfolding creates a yojson object we expect\" =\n let expected =\n Yojson_version.of_yojson m |> Result.ok |> Option.value_exn\n in\n let actual = !(full_derivers#of_json) m in\n [%test_eq: string list] expected.bar actual.bar ;\n [%test_eq: int] expected.foo_hello actual.foo_hello\n\n let%test_unit \"round trip\" =\n [%test_eq: string]\n ( !(full_derivers#to_json) (!(full_derivers#of_json) m)\n |> Yojson.Safe.to_string )\n (m |> Yojson.Safe.to_string)\n end )\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type ('a, 'h) t = ('a, 'h) Mina_wire_types.With_hash.V1.t =\n { data : 'a; hash : 'h }\n [@@deriving annot, sexp, equal, compare, hash, yojson, fields]\n\n let to_latest data_latest hash_latest { data; hash } =\n { data = data_latest data; hash = hash_latest hash }\n end\nend]\n\ntype ('a, 'h) t = ('a, 'h) Stable.Latest.t = { data : 'a; hash : 'h }\n[@@deriving annot, sexp, equal, compare, hash, yojson]\n\nlet data { data; _ } = data\n\nlet hash { hash; _ } = hash\n\nlet map t ~f = { t with data = f t.data }\n\nlet map_hash t ~f = { t with hash = f t.hash }\n\nlet of_data data ~hash_data = { data; hash = hash_data data }\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nmodule Field = Snark_params.Tick.Field\n\nmodule Make (Schema : Graphql_intf.Schema) = struct\n module Graphql = Fields_derivers_graphql.Graphql_raw.Make (Schema)\n\n let derivers () =\n let graphql_fields =\n ref Graphql.Fields.Input.T.{ run = (fun () -> failwith \"unimplemented\") }\n in\n let nullable_graphql_fields =\n ref Graphql.Fields.Input.T.{ run = (fun () -> failwith \"unimplemented\") }\n in\n let graphql_fields_accumulator = ref [] in\n let graphql_arg = ref (fun () -> failwith \"unimplemented\") in\n let nullable_graphql_arg = ref (fun () -> failwith \"unimplemented\") in\n let graphql_arg_accumulator = ref Graphql.Args.Acc.T.Init in\n let graphql_creator = ref (fun _ -> failwith \"unimplemented\") in\n let graphql_query = ref None in\n let graphql_query_accumulator = ref [] in\n\n let to_json = ref (fun _ -> failwith \"unimplemented\") in\n let of_json = ref (fun _ -> failwith \"unimplemented\") in\n let to_json_accumulator = ref [] in\n let of_json_creator = ref String.Map.empty in\n\n let js_layout = ref (`Assoc []) in\n let js_layout_accumulator = ref [] in\n\n let contramap = ref (fun _ -> failwith \"unimplemented\") in\n let map = ref (fun _ -> failwith \"unimplemented\") in\n\n let skip = ref false in\n\n object\n method skip = skip\n\n method graphql_fields = graphql_fields\n\n method nullable_graphql_fields = nullable_graphql_fields\n\n method graphql_fields_accumulator = graphql_fields_accumulator\n\n method graphql_arg = graphql_arg\n\n method nullable_graphql_arg = nullable_graphql_arg\n\n method graphql_arg_accumulator = graphql_arg_accumulator\n\n method graphql_creator = graphql_creator\n\n method graphql_query = graphql_query\n\n method graphql_query_accumulator = graphql_query_accumulator\n\n method to_json = to_json\n\n method of_json = of_json\n\n method to_json_accumulator = to_json_accumulator\n\n method of_json_creator = of_json_creator\n\n method js_layout = js_layout\n\n method js_layout_accumulator = js_layout_accumulator\n\n method contramap = contramap\n\n method map = map\n end\n\n let o () = derivers ()\n\n module Unified_input = struct\n type 'a t = < .. > as 'a\n constraint 'a = _ Fields_derivers_json.To_yojson.Input.t\n constraint 'a = _ Fields_derivers_json.Of_yojson.Input.t\n constraint 'a = _ Graphql.Fields.Input.t\n constraint 'a = _ Graphql.Args.Input.t\n constraint 'a = _ Fields_derivers_graphql.Graphql_query.Input.t\n constraint 'a = _ Fields_derivers_js.Js_layout.Input.t\n end\n\n let yojson obj ?doc ~name ~js_type ~map ~contramap : _ Unified_input.t =\n (obj#graphql_fields :=\n let open Schema in\n Graphql.Fields.Input.T.\n { run =\n (fun () ->\n scalar name ?doc ~coerce:Yojson.Safe.to_basic |> non_null )\n } ) ;\n\n (obj#nullable_graphql_fields :=\n let open Schema in\n Graphql.Fields.Input.T.\n { run = (fun () -> scalar name ?doc ~coerce:Yojson.Safe.to_basic) } ) ;\n\n (obj#graphql_arg :=\n fun () ->\n Schema.Arg.scalar name ?doc ~coerce:Graphql.arg_to_yojson\n |> Schema.Arg.non_null ) ;\n\n (obj#nullable_graphql_arg :=\n fun () -> Schema.Arg.scalar name ?doc ~coerce:Graphql.arg_to_yojson ) ;\n\n obj#to_json := Fn.id ;\n\n obj#of_json := Fn.id ;\n\n obj#contramap := contramap ;\n\n obj#map := map ;\n\n obj#js_layout := Fields_derivers_js.Js_layout.leaf_type js_type ;\n\n Fields_derivers_graphql.Graphql_query.scalar obj\n\n let invalid_scalar_to_string = function\n | `Uint ->\n \"Uint\"\n | `Field ->\n \"Field\"\n | `Token_id ->\n \"Token_id\"\n | `Public_key ->\n \"Public_key\"\n | `Amount ->\n \"Amount\"\n | `Balance ->\n \"Balance\"\n | `Unit ->\n \"Unit\"\n | `Proof ->\n \"Proof\"\n | `Verification_key ->\n \"Verification_key\"\n | `Signature ->\n \"Signature\"\n\n let raise_invalid_scalar t s =\n failwith (\"Invalid rich scalar: \" ^ invalid_scalar_to_string t ^ \" \" ^ s)\n\n let except ~f v (x : string) = try f x with _ -> raise_invalid_scalar v x\n\n let iso_string ?doc ~name ~js_type obj ~(to_string : 'a -> string)\n ~(of_string : string -> 'a) =\n yojson obj ?doc ~name ~js_type\n ~map:(function\n | `String x ->\n of_string x\n | _ ->\n raise (Fields_derivers_json.Of_yojson.Invalid_json_scalar `String)\n )\n ~contramap:(fun x -> `String (to_string x))\n\n let uint64 obj : _ Unified_input.t =\n iso_string obj\n ~doc:\"Unsigned 64-bit integer represented as a string in base10\"\n ~name:\"UInt64\" ~js_type:UInt64 ~to_string:Unsigned.UInt64.to_string\n ~of_string:(except ~f:Unsigned.UInt64.of_string `Uint)\n\n let uint32 obj : _ Unified_input.t =\n iso_string obj\n ~doc:\"Unsigned 32-bit integer represented as a string in base10\"\n ~name:\"UInt32\" ~js_type:UInt32 ~to_string:Unsigned.UInt32.to_string\n ~of_string:(except ~f:Unsigned.UInt32.of_string `Uint)\n\n let field obj : _ Unified_input.t =\n iso_string obj ~name:\"Field\" ~js_type:Field\n ~doc:\"String representing an Fp Field element\" ~to_string:Field.to_string\n ~of_string:(except ~f:Field.of_string `Field)\n\n let public_key obj : _ Unified_input.t =\n iso_string obj ~name:\"PublicKey\" ~js_type:PublicKey\n ~doc:\"String representing a public key in base58\"\n ~to_string:Signature_lib.Public_key.Compressed.to_string\n ~of_string:\n (except ~f:Signature_lib.Public_key.Compressed.of_base58_check_exn\n `Public_key )\n\n let skip obj : _ Unified_input.t =\n let _a = Graphql.Fields.skip obj in\n let _b = Graphql.Args.skip obj in\n let _c = Fields_derivers_json.To_yojson.skip obj in\n let _d = Fields_derivers_graphql.Graphql_query.skip obj in\n let _e = Fields_derivers_js.Js_layout.skip obj in\n Fields_derivers_json.Of_yojson.skip obj\n\n let js_only (js_layout : _ Fields_derivers_js.Js_layout.Input.t -> 'a) obj :\n _ Unified_input.t =\n let _a = Graphql.Fields.skip obj in\n let _b = Graphql.Args.skip obj in\n let _c = Fields_derivers_json.To_yojson.skip obj in\n let _d = Fields_derivers_graphql.Graphql_query.skip obj in\n let _e = js_layout obj in\n Fields_derivers_json.Of_yojson.skip obj\n\n let js_leaf leaf obj =\n js_only Fields_derivers_js.Js_layout.(of_layout @@ leaf_type leaf) obj\n\n let js_record entries obj =\n js_only (Fields_derivers_js.Js_layout.record entries) obj\n\n let int obj : _ Unified_input.t =\n let _a = Graphql.Fields.int obj in\n let _b = Graphql.Args.int obj in\n let _c = Fields_derivers_json.To_yojson.int obj in\n let _d = Fields_derivers_graphql.Graphql_query.int obj in\n let _e = Fields_derivers_js.Js_layout.int obj in\n Fields_derivers_json.Of_yojson.int obj\n\n let string obj : _ Unified_input.t =\n let _a = Graphql.Fields.string obj in\n let _b = Graphql.Args.string obj in\n let _c = Fields_derivers_json.To_yojson.string obj in\n let _d = Fields_derivers_graphql.Graphql_query.string obj in\n let _e = Fields_derivers_js.Js_layout.string obj in\n Fields_derivers_json.Of_yojson.string obj\n\n let bool obj : _ Unified_input.t =\n let _a = Graphql.Fields.bool obj in\n let _b = Graphql.Args.bool obj in\n let _c = Fields_derivers_json.To_yojson.bool obj in\n let _d = Fields_derivers_graphql.Graphql_query.bool obj in\n let _e = Fields_derivers_js.Js_layout.bool obj in\n Fields_derivers_json.Of_yojson.bool obj\n\n let global_slot_since_genesis obj =\n iso_string obj ~name:\"GlobalSlotSinceGenesis\" ~js_type:UInt32\n ~to_string:Mina_numbers.Global_slot_since_genesis.to_string\n ~of_string:\n (except ~f:Mina_numbers.Global_slot_since_genesis.of_string `Uint)\n\n let global_slot_since_hard_fork obj =\n iso_string obj ~name:\"GlobalSlotSinceHardFork\" ~js_type:UInt32\n ~to_string:Mina_numbers.Global_slot_since_hard_fork.to_string\n ~of_string:\n (except ~f:Mina_numbers.Global_slot_since_hard_fork.of_string `Uint)\n\n let global_slot_span obj =\n iso_string obj ~name:\"GlobalSlotSpan\" ~js_type:UInt32\n ~to_string:Mina_numbers.Global_slot_span.to_string\n ~of_string:(except ~f:Mina_numbers.Global_slot_span.of_string `Uint)\n\n let amount obj =\n iso_string obj ~name:\"CurrencyAmount\" ~js_type:UInt64\n ~to_string:Currency.Amount.to_string\n ~of_string:(except ~f:Currency.Amount.of_string `Amount)\n\n let balance obj =\n iso_string obj ~name:\"Balance\" ~js_type:UInt64\n ~to_string:Currency.Balance.to_string\n ~of_string:(except ~f:Currency.Balance.of_string `Balance)\n\n let option (x : _ Unified_input.t) ~js_type obj : _ Unified_input.t =\n let _a = Graphql.Fields.option x obj in\n let _b = Graphql.Args.option x obj in\n let _c = Fields_derivers_json.To_yojson.option x obj in\n let _d = Fields_derivers_graphql.Graphql_query.option x obj in\n let _e = Fields_derivers_js.Js_layout.option ~js_type x obj in\n Fields_derivers_json.Of_yojson.option x obj\n\n let list ?(static_length : int option) (x : _ Unified_input.t) obj :\n _ Unified_input.t =\n let _a = Graphql.Fields.list x obj in\n let _b = Graphql.Args.list x obj in\n let _c = Fields_derivers_json.To_yojson.list x obj in\n let _d = Fields_derivers_graphql.Graphql_query.list x obj in\n let _e = Fields_derivers_js.Js_layout.list ?static_length x obj in\n Fields_derivers_json.Of_yojson.list x obj\n\n let iso ~map ~contramap (x : _ Unified_input.t) obj : _ Unified_input.t =\n let _a = Graphql.Fields.contramap ~f:contramap x obj in\n let _b = Graphql.Args.map ~f:map x obj in\n let _c = Fields_derivers_json.To_yojson.contramap ~f:contramap x obj in\n let _d = Fields_derivers_graphql.Graphql_query.wrapped x obj in\n let _e = Fields_derivers_js.Js_layout.wrapped x obj in\n Fields_derivers_json.Of_yojson.map ~f:map x obj\n\n let iso_record ~of_record ~to_record record_deriver obj =\n iso ~map:of_record ~contramap:to_record (record_deriver @@ o ()) obj\n\n let array inner obj : _ Unified_input.t =\n iso ~map:Array.of_list ~contramap:Array.to_list\n ((list @@ inner @@ o ()) (o ()))\n obj\n\n let add_field ?skip_data ~t_fields_annots (x : _ Unified_input.t) fd acc =\n let _, acc' = Graphql.Fields.add_field ~t_fields_annots x fd acc in\n let c1, acc'' =\n Graphql.Args.add_field ?skip_data ~t_fields_annots x fd acc'\n in\n let _, acc''' =\n Fields_derivers_json.To_yojson.add_field ~t_fields_annots x fd acc''\n in\n let c2, acc'''' =\n Fields_derivers_json.Of_yojson.add_field ?skip_data ~t_fields_annots x fd\n acc'''\n in\n let _, acc''''' =\n Fields_derivers_graphql.Graphql_query.add_field ~t_fields_annots x fd\n acc''''\n in\n let _, acc'''''' =\n Fields_derivers_js.Js_layout.add_field ~t_fields_annots x fd acc'''''\n in\n ((function `Left x -> c1 x | `Right x -> c2 x), acc'''''')\n\n let ( !. ) ?skip_data x fd acc = add_field ?skip_data (x @@ o ()) fd acc\n\n let finish name ~t_toplevel_annots (f, acc) =\n let _a =\n Graphql.Fields.finish name ~t_toplevel_annots ((fun x -> f (`Left x)), acc)\n in\n let _b =\n Graphql.Args.finish name ~t_toplevel_annots ((fun x -> f (`Left x)), acc)\n in\n let _c =\n Fields_derivers_json.To_yojson.finish ((fun x -> f (`Right x)), acc)\n in\n let _d =\n Fields_derivers_graphql.Graphql_query.finish ((fun x -> f (`Left x)), acc)\n in\n let _e =\n Fields_derivers_js.Js_layout.finish name ~t_toplevel_annots\n ((fun x -> f (`Left x)), acc)\n in\n Fields_derivers_json.Of_yojson.finish ((fun x -> f (`Right x)), acc)\n\n let needs_custom_js ~js_type ~name deriver obj =\n Fields_derivers_js.Js_layout.needs_custom_js ~name\n (js_type @@ o ())\n (deriver obj)\n\n let balance_change obj =\n let sign_to_string = function\n | Sgn.Pos ->\n \"Positive\"\n | Sgn.Neg ->\n \"Negative\"\n in\n let sign_of_string = function\n | \"Positive\" ->\n Sgn.Pos\n | \"Negative\" ->\n Sgn.Neg\n | _ ->\n failwith \"impossible\"\n in\n let sign_deriver =\n iso_string ~name:\"Sign\" ~js_type:Sign ~to_string:sign_to_string\n ~of_string:sign_of_string\n in\n let ( !. ) = ( !. ) ~t_fields_annots:Currency.Signed_poly.t_fields_annots in\n Currency.Signed_poly.Fields.make_creator obj ~magnitude:!.amount\n ~sgn:!.sign_deriver\n |> finish \"BalanceChange\"\n ~t_toplevel_annots:Currency.Signed_poly.t_toplevel_annots\n\n let to_json obj x = !(obj#to_json) @@ !(obj#contramap) x\n\n let of_json obj x = !(obj#map) @@ !(obj#of_json) x\n\n let js_layout deriver = !((deriver @@ o ())#js_layout)\n\n let typ obj = !(obj#graphql_fields).Graphql.Fields.Input.T.run ()\n\n let arg_typ obj = !(obj#graphql_arg) ()\n\n let inner_query obj = Fields_derivers_graphql.Graphql_query.inner_query obj\n\n let rec json_to_safe : Yojson.Basic.t -> Yojson.Safe.t = function\n | `Assoc kv ->\n `Assoc (List.map kv ~f:(fun (k, v) -> (k, json_to_safe v)))\n | `Bool b ->\n `Bool b\n | `Float f ->\n `Float f\n | `Int i ->\n `Int i\n | `List xs ->\n `List (List.map xs ~f:json_to_safe)\n | `Null ->\n `Null\n | `String s ->\n `String s\n\n (* TODO: remove this or move to a %test_module once the deriver code is stable *)\n (* Can be used to print the graphql schema, like this:\n Fields_derivers_zkapps.Test.print_schema full ;\n *)\n module Test = struct\n module M = struct\n let ( let* ) = Schema.Io.bind\n\n let return = Schema.Io.return\n end\n\n let print_schema (full : _ Unified_input.t) =\n let typ = !(full#graphql_fields).run () in\n let query_top_level =\n Schema.(\n field \"query\" ~typ:(non_null typ)\n ~args:Arg.[]\n ~doc:\"sample query\"\n ~resolve:(fun _ _ -> ()))\n in\n let schema =\n Schema.(schema [ query_top_level ] ~mutations:[] ~subscriptions:[])\n in\n let res : 'a Schema.Io.t =\n Schema.execute schema ()\n (Fields_derivers_graphql.Test.introspection_query ())\n in\n let open Schema.Io in\n bind res (function\n | Ok (`Response data) ->\n data |> Yojson.Basic.to_string |> printf \"%s\" |> return\n | _ ->\n failwith \"Unexpected response\" )\n\n module Loop = struct\n let rec json_to_string_gql : Yojson.Safe.t -> string = function\n | `Assoc kv ->\n sprintf \"{\\n%s\\n}\"\n ( List.map kv ~f:(fun (k, v) ->\n sprintf \"%s: %s\"\n (Fields_derivers.under_to_camel k)\n (json_to_string_gql v) )\n |> String.concat ~sep:\",\\n\" )\n | `List xs ->\n sprintf \"[\\n%s\\n]\"\n (List.map xs ~f:json_to_string_gql |> String.concat ~sep:\",\\n\")\n | x ->\n Yojson.Safe.to_string x\n\n let arg_query json =\n Printf.sprintf\n {graphql|query LoopIn {\n arg(\n input : %s\n )\n }|graphql}\n (json_to_string_gql json)\n\n let out_query keys =\n Printf.sprintf\n {graphql|\n query LoopOut {\n out %s\n }\n |graphql}\n keys\n\n let run deriver (a : 'a) =\n let schema =\n let in_schema : ('a option ref, unit) Schema.field =\n Schema.(\n field \"arg\" ~typ:(non_null int)\n ~args:Arg.[ arg \"input\" ~typ:(arg_typ deriver) ]\n ~doc:\"sample args query\"\n ~resolve:(fun { ctx; _ } () (input : 'a) ->\n ctx := Some input ;\n 0 ))\n in\n let out_schema : ('a option ref, unit) Schema.field =\n Schema.(\n field \"out\" ~typ:(typ deriver)\n ~args:Arg.[]\n ~doc:\"sample query\"\n ~resolve:(fun { ctx; _ } () -> Option.value_exn !ctx))\n in\n Schema.(\n schema [ in_schema; out_schema ] ~mutations:[] ~subscriptions:[])\n in\n let ctx = ref None in\n let open M in\n let run_query q =\n let x = Graphql_parser.parse q in\n match x with\n | Ok res ->\n Schema.execute schema ctx res\n | Error err ->\n failwithf \"Failed to parse query: %s %s\" q err ()\n in\n (* send json in *)\n let* () =\n let json = to_json deriver a in\n let q = arg_query json in\n let* res = run_query q in\n match res with\n | Ok (`Response _) ->\n return @@ ()\n | Error e ->\n failwithf \"Unexpected response in: %s\"\n (e |> Yojson.Basic.to_string)\n ()\n | _ ->\n failwith \"Unexpected stream in\"\n in\n (* get query *)\n let inner_query =\n Option.value_exn\n (Fields_derivers_graphql.Graphql_query.inner_query deriver)\n in\n (* read json out *)\n let* a' =\n let* res = run_query (out_query inner_query) in\n match res with\n | Ok (`Response json) ->\n let unwrap k json =\n match json with\n | `Assoc kv ->\n List.Assoc.find_exn kv ~equal:String.equal k\n | _ ->\n failwithf \"Expected wrapping %s\" k ()\n in\n let inner = json |> unwrap \"data\" |> unwrap \"out\" in\n of_json deriver (json_to_safe inner) |> return\n | Error e ->\n failwithf \"Unexpected response out: %s\"\n (e |> Yojson.Basic.to_string)\n ()\n | _ ->\n failwith \"Unexpected stream out\"\n in\n [%test_eq: string]\n (Yojson.Safe.to_string (to_json deriver a))\n (Yojson.Safe.to_string (to_json deriver a')) ;\n return ()\n end\n end\nend\n\nmodule Derivers = Make (Fields_derivers_graphql.Schema)\ninclude Derivers\nmodule Js_layout = Fields_derivers_js.Js_layout\n\n[%%ifdef consensus_mechanism]\n\nlet proof obj : _ Unified_input.t =\n let of_string s =\n match Pickles.Side_loaded.Proof.of_base64 s with\n | Ok proof ->\n proof\n | Error _err ->\n raise_invalid_scalar `Proof s\n in\n iso_string obj ~name:\"ZkappProof\" ~js_type:String\n ~to_string:Pickles.Side_loaded.Proof.to_base64 ~of_string\n\nlet verification_key_with_hash obj =\n let verification_key obj =\n let of_string s =\n match Pickles.Side_loaded.Verification_key.of_base64 s with\n | Ok vk ->\n vk\n | Error _err ->\n raise_invalid_scalar `Verification_key s\n in\n Pickles.Side_loaded.Verification_key.(\n iso_string obj ~name:\"VerificationKey\" ~js_type:String\n ~to_string:to_base64 ~of_string ~doc:\"Verification key in Base64 format\")\n in\n let ( !. ) =\n ( !. ) ~t_fields_annots:With_hash.Stable.Latest.t_fields_annots\n in\n With_hash.Stable.Latest.Fields.make_creator ~data:!.verification_key\n ~hash:!.field obj\n |> finish \"VerificationKeyWithHash\"\n ~t_toplevel_annots:With_hash.Stable.Latest.t_toplevel_annots\n\nlet%test_unit \"verification key with hash, roundtrip json\" =\n let open Pickles.Side_loaded.Verification_key in\n (* we do this because the dummy doesn't have a wrap_vk on it *)\n let data = dummy |> to_base58_check |> of_base58_check_exn in\n let v = { With_hash.data; hash = Field.one } in\n let o = verification_key_with_hash @@ o () in\n [%test_eq: (t, Field.t) With_hash.t] v (of_json o (to_json o v))\n\n[%%endif]\n\nlet%test_module \"Test\" =\n ( module struct\n module IO = struct\n type +'a t = 'a\n\n let bind t f = f t\n\n let return t = t\n\n module Stream = struct\n type 'a t = 'a Seq.t\n\n let map t f = Seq.map f t\n\n let iter t f = Seq.iter f t\n\n let close _t = ()\n end\n end\n\n module Field_error = struct\n type t = string\n\n let message_of_field_error t = t\n\n let extensions_of_field_error _t = None\n end\n\n module Schema = Graphql_schema.Make (IO) (Field_error)\n module Derivers = Make (Schema)\n include Derivers\n module Public_key = Signature_lib.Public_key.Compressed\n\n module Or_ignore_test = struct\n type 'a t = Check of 'a | Ignore [@@deriving compare, sexp, equal]\n\n let of_option = function None -> Ignore | Some x -> Check x\n\n let to_option = function Ignore -> None | Check x -> Some x\n\n let to_yojson a x = [%to_yojson: 'a option] a (to_option x)\n\n let of_yojson a x = Result.map ~f:of_option ([%of_yojson: 'a option] a x)\n\n let derived inner init =\n iso ~map:of_option ~contramap:to_option\n ((option ~js_type:Flagged_option @@ inner @@ o ()) (o ()))\n init\n end\n\n module V = struct\n type t =\n { foo : int\n ; foo1 : Unsigned_extended.UInt64.t\n ; bar : Unsigned_extended.UInt64.t Or_ignore_test.t\n ; baz : Unsigned_extended.UInt32.t list\n }\n [@@deriving annot, compare, sexp, equal, fields, yojson]\n\n let v =\n { foo = 1\n ; foo1 = Unsigned.UInt64.of_int 10\n ; bar = Or_ignore_test.Check (Unsigned.UInt64.of_int 10)\n ; baz = Unsigned.UInt32.[ of_int 11; of_int 12 ]\n }\n\n let ( !. ) = ( !. ) ~t_fields_annots\n\n let derivers obj =\n Fields.make_creator obj ~foo:!.int ~foo1:!.uint64\n ~bar:!.(Or_ignore_test.derived uint64)\n ~baz:!.(list @@ uint32 @@ o ())\n |> finish \"V\" ~t_toplevel_annots\n end\n\n let v1 = V.derivers @@ o ()\n\n let%test_unit \"full roundtrips\" = Test.Loop.run v1 V.v\n\n module V2 = struct\n type t = { field : Field.t; nothing : unit [@skip] }\n [@@deriving annot, compare, sexp, equal, fields]\n\n let v = { field = Field.of_int 10; nothing = () }\n\n let derivers obj =\n let open Derivers in\n let ( !. ) ?skip_data = ( !. ) ?skip_data ~t_fields_annots in\n Fields.make_creator obj ~field:!.field\n ~nothing:(( !. ) ~skip_data:() skip)\n |> finish \"V2\" ~t_toplevel_annots\n end\n\n let v2 = V2.derivers @@ Derivers.o ()\n\n let%test_unit \"to_json'\" =\n let open Derivers in\n [%test_eq: string]\n (Yojson.Safe.to_string (to_json v2 V2.v))\n {|{\"field\":\"10\"}|}\n\n let%test_unit \"roundtrip json'\" =\n let open Derivers in\n [%test_eq: V2.t] (of_json v2 (to_json v2 V2.v)) V2.v\n\n module V3 = struct\n type t = { public_key : Public_key.t }\n [@@deriving annot, compare, sexp, equal, fields]\n\n let v =\n { public_key =\n Public_key.of_base58_check_exn\n \"B62qoTqMG41DFgkyQmY2Pos1x671Gfzs9k8NKqUdSg7wQasEV6qnXQP\"\n }\n\n let derivers obj =\n let open Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~public_key:!.public_key\n |> finish \"V3\" ~t_toplevel_annots\n end\n\n let v3 = V3.derivers @@ Derivers.o ()\n\n let%test_unit \"to_json'\" =\n let open Derivers in\n [%test_eq: string]\n (Yojson.Safe.to_string (to_json v3 V3.v))\n {|{\"publicKey\":\"B62qoTqMG41DFgkyQmY2Pos1x671Gfzs9k8NKqUdSg7wQasEV6qnXQP\"}|}\n\n let%test_unit \"roundtrip json'\" =\n let open Derivers in\n [%test_eq: V3.t] (of_json v3 (to_json v3 V3.v)) V3.v\n end )\n","(* state_hash.ml -- defines the type for the protocol state hash *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\ninclude Data_hash.Make_full_size (struct\n let version_byte = Base58_check.Version_bytes.state_hash\n\n let description = \"State hash\"\nend)\n\nlet dummy = of_hash Outside_hash_image.t\n\n[%%ifdef consensus_mechanism]\n\nlet zero = dummy\n\n[%%else]\n\n(* in the nonconsensus world, we don't have the Pedersen machinery available,\n so just inline the value for zero\n*)\nlet zero = Field.of_string \"0\"\n\n[%%endif]\n\nlet raw_hash_bytes = to_bytes\n\nlet to_bytes = `Use_to_base58_check_or_raw_hash_bytes\n\nlet to_decimal_string = to_decimal_string\n\nlet of_decimal_string = of_decimal_string\n\n(* Data hash versioned boilerplate below *)\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\nend]\n\nlet (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\nlet deriver obj =\n Fields_derivers_zkapps.(\n iso_string ~name:\"StateHash\" ~js_type:Field ~to_string:to_base58_check\n ~of_string:of_base58_check_exn\n |> needs_custom_js ~name:\"StateHash\" ~js_type:field)\n obj\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nmodule Proof_level = struct\n type t = Full | Check | None [@@deriving bin_io_unversioned, equal]\n\n let to_string = function Full -> \"full\" | Check -> \"check\" | None -> \"none\"\n\n let of_string = function\n | \"full\" ->\n Full\n | \"check\" ->\n Check\n | \"none\" ->\n None\n | s ->\n failwithf \"unrecognised proof level %s\" s ()\n\n [%%inject \"compiled\", proof_level]\n\n let compiled = of_string compiled\n\n let for_unit_tests = Check\nend\n\nmodule Fork_constants = struct\n type t =\n { previous_state_hash : Pickles.Backend.Tick.Field.Stable.Latest.t\n ; previous_length : Mina_numbers.Length.Stable.Latest.t\n ; genesis_slot : Mina_numbers.Global_slot_since_genesis.Stable.Latest.t\n }\n [@@deriving bin_io_unversioned, sexp, equal, compare, yojson]\nend\n\n(** Constants that affect the constraint systems for proofs (and thus also key\n generation).\n\n Care must be taken to ensure that these match against the proving/\n verification keys when [proof_level=Full], otherwise generated proofs will\n be invalid.\n*)\nmodule Constraint_constants = struct\n type t =\n { sub_windows_per_window : int\n ; ledger_depth : int\n ; work_delay : int\n ; block_window_duration_ms : int\n ; transaction_capacity_log_2 : int\n ; pending_coinbase_depth : int\n ; coinbase_amount : Currency.Amount.Stable.Latest.t\n ; supercharged_coinbase_factor : int\n ; account_creation_fee : Currency.Fee.Stable.Latest.t\n ; fork : Fork_constants.t option\n }\n [@@deriving bin_io_unversioned, sexp, equal, compare, yojson]\n\n let to_snark_keys_header (t : t) : Snark_keys_header.Constraint_constants.t =\n { sub_windows_per_window = t.sub_windows_per_window\n ; ledger_depth = t.ledger_depth\n ; work_delay = t.work_delay\n ; block_window_duration_ms = t.block_window_duration_ms\n ; transaction_capacity = Log_2 t.transaction_capacity_log_2\n ; pending_coinbase_depth = t.pending_coinbase_depth\n ; coinbase_amount = Currency.Amount.to_uint64 t.coinbase_amount\n ; supercharged_coinbase_factor = t.supercharged_coinbase_factor\n ; account_creation_fee = Currency.Fee.to_uint64 t.account_creation_fee\n ; fork =\n ( match t.fork with\n | Some { previous_length; previous_state_hash; genesis_slot } ->\n Some\n { previous_length = Unsigned.UInt32.to_int previous_length\n ; previous_state_hash =\n Pickles.Backend.Tick.Field.to_string previous_state_hash\n ; genesis_slot =\n Unsigned.UInt32.to_int\n (Mina_numbers.Global_slot_since_genesis.to_uint32\n genesis_slot )\n }\n | None ->\n None )\n }\n\n (* Generate the compile-time constraint constants, using a signature to hide\n the optcomp constants that we import.\n *)\n include (\n struct\n [%%ifdef consensus_mechanism]\n\n [%%inject \"sub_windows_per_window\", sub_windows_per_window]\n\n [%%else]\n\n (* Invalid value, this should not be used by nonconsensus nodes. *)\n let sub_windows_per_window = -1\n\n [%%endif]\n\n [%%inject \"ledger_depth\", ledger_depth]\n\n [%%inject \"coinbase_amount_string\", coinbase]\n\n [%%inject \"account_creation_fee_string\", account_creation_fee_int]\n\n (** All the proofs before the last [work_delay] blocks must be\n completed to add transactions. [work_delay] is the minimum number\n of blocks and will increase if the throughput is less.\n - If [work_delay = 0], all the work that was added to the scan\n state in the previous block is expected to be completed and\n included in the current block if any transactions/coinbase are to\n be included.\n - [work_delay >= 1] means that there's at least two block times for\n completing the proofs.\n *)\n\n [%%inject \"work_delay\", scan_state_work_delay]\n\n [%%inject \"block_window_duration_ms\", block_window_duration]\n\n [%%if scan_state_with_tps_goal]\n\n [%%inject \"tps_goal_x10\", scan_state_tps_goal_x10]\n\n let max_coinbases = 2\n\n (* block_window_duration is in milliseconds, so divide by 1000 divide\n by 10 again because we have tps * 10\n *)\n let max_user_commands_per_block =\n tps_goal_x10 * block_window_duration_ms / (1000 * 10)\n\n (** Log of the capacity of transactions per transition.\n - 1 will only work if we don't have prover fees.\n - 2 will work with prover fees, but not if we want a transaction\n included in every block.\n - At least 3 ensures a transaction per block and the staged-ledger\n unit tests pass.\n *)\n let transaction_capacity_log_2 =\n 1\n + Core_kernel.Int.ceil_log2 (max_user_commands_per_block + max_coinbases)\n\n [%%else]\n\n [%%inject\n \"transaction_capacity_log_2\", scan_state_transaction_capacity_log_2]\n\n [%%endif]\n\n [%%inject \"supercharged_coinbase_factor\", supercharged_coinbase_factor]\n\n let pending_coinbase_depth =\n Core_kernel.Int.ceil_log2\n (((transaction_capacity_log_2 + 1) * (work_delay + 1)) + 1)\n\n [%%ifndef fork_previous_length]\n\n let fork = None\n\n [%%else]\n\n [%%inject \"fork_previous_length\", fork_previous_length]\n\n [%%inject \"fork_previous_state_hash\", fork_previous_state_hash]\n\n [%%inject \"fork_genesis_slot\", fork_genesis_slot]\n\n let fork =\n Some\n { Fork_constants.previous_state_hash =\n Data_hash_lib.State_hash.of_base58_check_exn\n fork_previous_state_hash\n ; previous_length = Mina_numbers.Length.of_int fork_previous_length\n ; genesis_slot =\n Mina_numbers.Global_slot_since_genesis.of_int fork_genesis_slot\n }\n\n [%%endif]\n\n let compiled =\n { sub_windows_per_window\n ; ledger_depth\n ; work_delay\n ; block_window_duration_ms\n ; transaction_capacity_log_2\n ; pending_coinbase_depth\n ; coinbase_amount =\n Currency.Amount.of_mina_string_exn coinbase_amount_string\n ; supercharged_coinbase_factor\n ; account_creation_fee =\n Currency.Fee.of_mina_string_exn account_creation_fee_string\n ; fork\n }\n end :\n sig\n val compiled : t\n end )\n\n let for_unit_tests = compiled\nend\n\n(*Constants that can be specified for generating the base proof (that are not required for key-generation) in runtime_genesis_ledger.exe and that can be configured at runtime.\n The types are defined such that this module doesn't depend on any of the coda libraries (except blake2 and module_version) to avoid dependency cycles.\n TODO: #4659 move key generation to runtime_genesis_ledger.exe to include scan_state constants, consensus constants (c and block_window_duration) and ledger depth here*)\n\nlet genesis_timestamp_of_string str =\n let default_zone = Time.Zone.of_utc_offset ~hours:(-8) in\n Time.of_string_gen\n ~find_zone:(fun _ -> assert false)\n ~default_zone:(fun () -> default_zone)\n str\n\nlet of_time t = Time.to_span_since_epoch t |> Time.Span.to_ms |> Int64.of_float\n\nlet validate_time time_str =\n match\n Result.try_with (fun () ->\n Option.value_map ~default:(Time.now ()) ~f:genesis_timestamp_of_string\n time_str )\n with\n | Ok time ->\n Ok (of_time time)\n | Error _ ->\n Error\n \"Invalid timestamp. Please specify timestamp in \\\"%Y-%m-%d \\\n %H:%M:%S%z\\\". For example, \\\"2019-01-30 12:00:00-0800\\\" for UTC-08:00 \\\n timezone\"\n\nlet genesis_timestamp_to_string time =\n Int64.to_float time |> Time.Span.of_ms |> Time.of_span_since_epoch\n |> Time.to_string_iso8601_basic ~zone:(Time.Zone.of_utc_offset ~hours:(-8))\n\n(*Protocol constants required for consensus and snarks. Consensus constants is generated using these*)\nmodule Protocol = struct\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('length, 'delta, 'genesis_state_timestamp) t =\n ( 'length\n , 'delta\n , 'genesis_state_timestamp )\n Mina_wire_types.Genesis_constants.Protocol.Poly.V1.t =\n { k : 'length\n ; slots_per_epoch : 'length\n ; slots_per_sub_window : 'length\n ; delta : 'delta\n ; genesis_state_timestamp : 'genesis_state_timestamp\n }\n [@@deriving equal, ord, hash, sexp, yojson, hlist, fields]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = (int, int, (Int64.t[@version_asserted])) Poly.Stable.V1.t\n [@@deriving equal, ord, hash]\n\n let to_latest = Fn.id\n\n let to_yojson (t : t) =\n `Assoc\n [ (\"k\", `Int t.k)\n ; (\"slots_per_epoch\", `Int t.slots_per_epoch)\n ; (\"slots_per_sub_window\", `Int t.slots_per_sub_window)\n ; (\"delta\", `Int t.delta)\n ; ( \"genesis_state_timestamp\"\n , `String\n (Time.to_string_abs\n (Time.of_span_since_epoch\n (Time.Span.of_ms\n (Int64.to_float t.genesis_state_timestamp) ) )\n ~zone:Time.Zone.utc ) )\n ]\n\n let of_yojson = function\n | `Assoc\n [ (\"k\", `Int k)\n ; (\"slots_per_epoch\", `Int slots_per_epoch)\n ; (\"slots_per_sub_window\", `Int slots_per_sub_window)\n ; (\"delta\", `Int delta)\n ; (\"genesis_state_timestamp\", `String time_str)\n ] -> (\n match validate_time time_str with\n | Ok genesis_state_timestamp ->\n Ok\n { Poly.k\n ; slots_per_epoch\n ; slots_per_sub_window\n ; delta\n ; genesis_state_timestamp\n }\n | Error e ->\n Error (sprintf !\"Genesis_constants.Protocol.of_yojson: %s\" e) )\n | _ ->\n Error \"Genesis_constants.Protocol.of_yojson: unexpected JSON\"\n\n let t_of_sexp _ = failwith \"t_of_sexp: not implemented\"\n\n let sexp_of_t (t : t) =\n let module T = struct\n type t = (int, int, string) Poly.Stable.V1.t [@@deriving sexp]\n end in\n let t' : T.t =\n { k = t.k\n ; delta = t.delta\n ; slots_per_epoch = t.slots_per_epoch\n ; slots_per_sub_window = t.slots_per_sub_window\n ; genesis_state_timestamp =\n Time.to_string_abs\n (Time.of_span_since_epoch\n (Time.Span.of_ms (Int64.to_float t.genesis_state_timestamp)) )\n ~zone:Time.Zone.utc\n }\n in\n T.sexp_of_t t'\n end\n end]\n\n [%%define_locally Stable.Latest.(to_yojson)]\nend\n\nmodule T = struct\n (* bin_io is for printing chain id inputs *)\n type t =\n { protocol : Protocol.Stable.Latest.t\n ; txpool_max_size : int\n ; num_accounts : int option\n ; zkapp_proof_update_cost : float\n ; zkapp_signed_single_update_cost : float\n ; zkapp_signed_pair_update_cost : float\n ; zkapp_transaction_cost_limit : float\n ; max_event_elements : int\n ; max_action_elements : int\n }\n [@@deriving to_yojson, sexp_of, bin_io_unversioned]\n\n let hash (t : t) =\n let str =\n ( List.map\n (* TODO: *)\n [ t.protocol.k\n ; t.protocol.slots_per_epoch\n ; t.protocol.slots_per_sub_window\n ; t.protocol.delta\n ; t.txpool_max_size\n ]\n ~f:Int.to_string\n |> String.concat ~sep:\"\" )\n ^ Time.to_string_abs ~zone:Time.Zone.utc\n (Time.of_span_since_epoch\n (Time.Span.of_ms\n (Int64.to_float t.protocol.genesis_state_timestamp) ) )\n in\n Blake2.digest_string str |> Blake2.to_hex\nend\n\ninclude T\n\n[%%inject \"genesis_state_timestamp_string\", genesis_state_timestamp]\n\n[%%inject \"k\", k]\n\n[%%inject \"slots_per_epoch\", slots_per_epoch]\n\n[%%inject \"slots_per_sub_window\", slots_per_sub_window]\n\n[%%inject \"delta\", delta]\n\n[%%inject \"pool_max_size\", pool_max_size]\n\nlet compiled : t =\n { protocol =\n { k\n ; slots_per_epoch\n ; slots_per_sub_window\n ; delta\n ; genesis_state_timestamp =\n genesis_timestamp_of_string genesis_state_timestamp_string |> of_time\n }\n ; txpool_max_size = pool_max_size\n ; num_accounts = None\n ; zkapp_proof_update_cost = Mina_compile_config.zkapp_proof_update_cost\n ; zkapp_signed_single_update_cost =\n Mina_compile_config.zkapp_signed_single_update_cost\n ; zkapp_signed_pair_update_cost =\n Mina_compile_config.zkapp_signed_pair_update_cost\n ; zkapp_transaction_cost_limit =\n Mina_compile_config.zkapp_transaction_cost_limit\n ; max_event_elements = Mina_compile_config.max_event_elements\n ; max_action_elements = Mina_compile_config.max_action_elements\n }\n\nlet for_unit_tests = compiled\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params\nopen Tick\nopen Unsigned_extended\nopen Snark_bits\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Block_time\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Intf.S with type Time.t = A.V1.t\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n module Time = struct\n (* Milliseconds since epoch *)\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = UInt64.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n\n module T = struct\n type typ = t [@@deriving sexp, compare, hash]\n\n type t = typ [@@deriving sexp, compare, hash]\n end\n\n include Hashable.Make (T)\n end\n end]\n\n let max_value = UInt64.max_int\n\n let zero = UInt64.zero\n\n module Controller = struct\n [%%if time_offsets]\n\n type t = unit -> Time.Span.t [@@deriving sexp]\n\n (* NB: All instances are identical by construction (see basic below). *)\n let equal _ _ = true\n\n (* NB: All instances are identical by construction (see basic below). *)\n let compare _ _ = 0\n\n let time_offset = ref None\n\n let setting_enabled = ref None\n\n let disable_setting_offset () = setting_enabled := Some false\n\n let enable_setting_offset () =\n match !setting_enabled with\n | None ->\n setting_enabled := Some true\n | Some true ->\n ()\n | Some false ->\n failwith\n \"Cannot enable time offset mutations; it has been explicitly \\\n disabled\"\n\n let set_time_offset offset =\n match !setting_enabled with\n | Some true ->\n time_offset := Some offset\n | None | Some false ->\n failwith \"Cannot mutate the time offset\"\n\n let create offset = offset\n\n let basic ~logger:_ () =\n match !time_offset with\n | Some offset ->\n offset\n | None ->\n let offset =\n let env = \"MINA_TIME_OFFSET\" in\n let env_offset =\n match Core_kernel.Sys.getenv_opt env with\n | Some tm ->\n Int.of_string tm\n | None ->\n let default = 0 in\n eprintf\n \"Environment variable %s not found, using default of %d\\n\\\n %!\"\n env default ;\n default\n in\n Core_kernel.Time.Span.of_int_sec env_offset\n in\n time_offset := Some offset ;\n offset\n\n let get_time_offset ~logger = basic ~logger ()\n\n [%%else]\n\n type t = unit [@@deriving sexp, equal, compare]\n\n let create () = ()\n\n let basic ~logger:_ = ()\n\n let disable_setting_offset () = ()\n\n let enable_setting_offset () = ()\n\n let set_time_offset _ = failwith \"Cannot mutate the time offset\"\n\n let get_time_offset _ = Core_kernel.Time.Span.of_int_sec 0\n\n [%%endif]\n end\n\n module B = Bits\n module Bits = Bits.UInt64\n include B.Snarkable.UInt64 (Tick)\n module N = Mina_numbers.Nat.Make_checked (UInt64) (Bits)\n\n let to_input (t : t) =\n Random_oracle_input.Chunked.packed\n (Tick.Field.project (Bits.to_bits t), 64)\n\n module Checked = struct\n type t = N.var\n\n module Unsafe = N.Unsafe\n\n let to_input (t : t) = N.to_input t\n\n let to_field = N.to_field\n\n [%%define_locally N.(typ, ( = ), ( <= ), ( >= ), ( < ), ( > ))]\n end\n\n module Span = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = UInt64.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n module Bits = B.UInt64\n include B.Snarkable.UInt64 (Tick)\n\n let of_time_span s = UInt64.of_int64 (Int64.of_float (Time.Span.to_ms s))\n\n let to_time_span s = Time.Span.of_ms (Int64.to_float (UInt64.to_int64 s))\n\n let to_time_ns_span s =\n Time_ns.Span.of_ms (Int64.to_float (UInt64.to_int64 s))\n\n let of_time_ns_span ns : t =\n let int64_ns = ns |> Time_ns.Span.to_int63_ns |> Int63.to_int64 in\n (* convert to milliseconds *)\n Int64.(int64_ns / 1_000_000L) |> UInt64.of_int64\n\n let to_string_hum s = to_time_ns_span s |> Time_ns.Span.to_string_hum\n\n let to_ms = UInt64.to_int64\n\n let of_ms = UInt64.of_int64\n\n [%%define_locally UInt64.Infix.(( + ), ( - ), ( * ))]\n\n [%%define_locally UInt64.(( < ), ( > ), ( = ), ( <= ), ( >= ), min, zero)]\n\n let to_input = to_input\n\n module Checked = Checked\n end\n\n include Comparable.Make (Stable.Latest)\n include Hashable.Make (Stable.Latest)\n\n let of_time t =\n UInt64.of_int64\n (Int64.of_float (Time.Span.to_ms (Time.to_span_since_epoch t)))\n\n (* TODO: Time.t can't hold the full uint64 range, so this can fail for large t *)\n let to_time_exn t =\n let t_int64 = UInt64.to_int64 t in\n if Int64.(t_int64 < zero) then failwith \"converting to negative timestamp\" ;\n Time.of_span_since_epoch (Time.Span.of_ms (Int64.to_float t_int64))\n\n [%%if time_offsets]\n\n let now offset = of_time (Time.sub (Time.now ()) (offset ()))\n\n [%%else]\n\n let now _ = of_time (Time.now ())\n\n [%%endif]\n\n let field_var_to_unpacked (x : Tick.Field.Var.t) =\n Tick.Field.Checked.unpack ~length:64 x\n\n let epoch = of_time Time.epoch\n\n let add x y = UInt64.add x y\n\n let diff x y = UInt64.sub x y\n\n let sub x y = UInt64.sub x y\n\n let to_span_since_epoch t = diff t epoch\n\n let of_span_since_epoch s = UInt64.add s epoch\n\n let diff_checked x y =\n let pack = Tick.Field.Var.project in\n Span.unpack_var Tick.Field.Checked.(pack x - pack y)\n\n let modulus t span = UInt64.rem t span\n\n let unpacked_to_number var =\n let bits = Span.Unpacked.var_to_bits var in\n Number.of_bits (bits :> Boolean.var list)\n\n let to_int64 = Fn.compose Span.to_ms to_span_since_epoch\n\n let of_int64 = Fn.compose of_span_since_epoch Span.of_ms\n\n let of_uint64 : UInt64.t -> t = of_span_since_epoch\n\n let to_uint64 : t -> UInt64.t = to_span_since_epoch\n\n (* TODO: this can fail if the input has more than 63 bits, because it would be serialized to a negative number string *)\n let to_string_exn t =\n let t_int64 = UInt64.to_int64 t in\n if Int64.(t_int64 < zero) then failwith \"converting to negative timestamp\" ;\n Int64.to_string t_int64\n\n let of_time_ns ns : t =\n let int64_ns = ns |> Time_ns.to_int63_ns_since_epoch |> Int63.to_int64 in\n (* convert to milliseconds *)\n Int64.(int64_ns / 1_000_000L) |> UInt64.of_int64\n\n [%%if time_offsets]\n\n let to_system_time (offset : Controller.t) (t : t) =\n of_span_since_epoch\n Span.(to_span_since_epoch t + of_time_span (offset ()))\n\n [%%else]\n\n let to_system_time (_offset : Controller.t) (t : t) = t\n\n [%%endif]\n\n let to_string_system_time_exn (offset : Controller.t) (t : t) : string =\n to_system_time offset t |> to_string_exn\n\n let of_string_exn string =\n Int64.of_string string |> Span.of_ms |> of_span_since_epoch\n\n let gen_incl time_beginning time_end =\n let open Quickcheck.Let_syntax in\n let time_beginning_int64 = to_int64 time_beginning in\n let time_end_int64 = to_int64 time_end in\n let%map int64_time_span =\n Int64.(gen_incl time_beginning_int64 time_end_int64)\n in\n of_span_since_epoch @@ Span.of_ms int64_time_span\n\n let gen =\n let open Quickcheck.Let_syntax in\n let%map int64_time_span = Int64.(gen_incl zero max_value) in\n of_span_since_epoch @@ Span.of_ms int64_time_span\n end\n\n include Time\n module Timeout = Timeout_lib.Make (Time)\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nopen Async_kernel\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type 'a t = [ `One of 'a | `Two of 'a * 'a ]\n [@@deriving equal, compare, hash, sexp, yojson]\n\n let to_latest a_latest = function\n | `One x ->\n `One (a_latest x)\n | `Two (x, y) ->\n `Two (a_latest x, a_latest y)\n\n let of_latest a_latest = function\n | `One x ->\n let open Result.Let_syntax in\n let%map x = a_latest x in\n `One x\n | `Two (x, y) ->\n let open Result.Let_syntax in\n let%map x = a_latest x and y = a_latest y in\n `Two (x, y)\n end\nend]\n\nlet length = function `One _ -> 1 | `Two _ -> 2\n\nlet to_list = function `One a -> [ a ] | `Two (a, b) -> [ a; b ]\n\nlet to_numbered_list = function\n | `One a ->\n [ (0, a) ]\n | `Two (a, b) ->\n [ (0, a); (1, b) ]\n\nlet group_sequence : 'a Sequence.t -> 'a t Sequence.t =\n fun to_group ->\n Sequence.unfold ~init:to_group ~f:(fun acc ->\n match Sequence.next acc with\n | None ->\n None\n | Some (a, rest_1) -> (\n match Sequence.next rest_1 with\n | None ->\n Some (`One a, Sequence.empty)\n | Some (b, rest_2) ->\n Some (`Two (a, b), rest_2) ) )\n\nlet group_list : 'a list -> 'a t list =\n fun xs -> xs |> Sequence.of_list |> group_sequence |> Sequence.to_list\n\nlet zip : 'a t -> 'b t -> ('a * 'b) t Or_error.t =\n fun a b ->\n match (a, b) with\n | `One a1, `One b1 ->\n Ok (`One (a1, b1))\n | `Two (a1, a2), `Two (b1, b2) ->\n Ok (`Two ((a1, b1), (a2, b2)))\n | _ ->\n Or_error.error_string \"One_or_two.zip mismatched\"\n\nlet zip_exn : 'a t -> 'b t -> ('a * 'b) t =\n fun a b -> Or_error.ok_exn @@ zip a b\n\nmodule Monadic2 (M : Monad.S2) :\n Intfs.Monadic2 with type ('a, 'e) m := ('a, 'e) M.t = struct\n let sequence : ('a, 'e) M.t t -> ('a t, 'e) M.t = function\n | `One def ->\n M.map def ~f:(fun x -> `One x)\n | `Two (def1, def2) ->\n let open M.Let_syntax in\n let%bind a = def1 in\n let%map b = def2 in\n `Two (a, b)\n\n let map : 'a t -> f:('a -> ('b, 'e) M.t) -> ('b t, 'e) M.t =\n fun t ~f ->\n (* We could use sequence here, but this approach saves us computation in the\n Result and option monads when the first component of a `Two fails. *)\n match t with\n | `One a ->\n M.map ~f:(fun x -> `One x) (f a)\n | `Two (a, b) ->\n let open M.Let_syntax in\n let%bind a' = f a in\n let%map b' = f b in\n `Two (a', b')\n\n let fold :\n 'a t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'e) M.t)\n -> ('accum, 'e) M.t =\n fun t ~init ~f ->\n match t with\n | `One a ->\n f init a\n | `Two (a, b) ->\n M.bind (f init a) ~f:(fun x -> f x b)\nend\n\nmodule Monadic (M : Monad.S) : Intfs.Monadic with type 'a m := 'a M.t =\n Monadic2 (Base__.Monad_intf.S_to_S2 (M))\n\nmodule Deferred_result = Monadic2 (Deferred.Result)\nmodule Ident = Monadic (Monad.Ident)\nmodule Deferred = Monadic (Deferred)\nmodule Option = Monadic (Option)\nmodule Or_error = Monadic (Or_error)\n\nlet map = Ident.map\n\nlet fold = Ident.fold\n\nlet iter t ~f = match t with `One a -> f a | `Two (a, b) -> f a ; f b\n\nlet fold_until ~init ~f ~finish t =\n Container.fold_until ~fold ~init ~f ~finish t\n\nlet gen inner_gen =\n Quickcheck.Generator.(\n union\n [ map inner_gen ~f:(fun x -> `One x)\n ; map (tuple2 inner_gen inner_gen) ~f:(fun pair -> `Two pair)\n ])\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_import\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Account_id\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Account_id_intf.S\n with type Digest.Stable.V1.t = A.Digest.V1.t\n and type Stable.V2.t = A.V2.t\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n let invalid = (Public_key.Compressed.empty, Pickles.Backend.Tick.Field.zero)\n\n module Digest = struct\n [%%ifdef consensus_mechanism]\n\n let of_bigstring_exn =\n Binable.of_bigstring (module Pickles.Backend.Tick.Field.Stable.Latest)\n\n let to_bigstring =\n Binable.to_bigstring (module Pickles.Backend.Tick.Field.Stable.Latest)\n\n [%%else]\n\n let of_bigstring_exn =\n Binable.of_bigstring (module Snark_params.Tick.Field.Stable.Latest)\n\n let to_bigstring =\n Binable.to_bigstring (module Snark_params.Tick.Field.Stable.Latest)\n\n [%%endif]\n\n module Base58_check = Base58_check.Make (struct\n let description = \"Token ID\"\n\n let version_byte = Base58_check.Version_bytes.token_id_key\n end)\n\n let to_base58_check t : string =\n Base58_check.encode (to_bigstring t |> Bigstring.to_string)\n\n let of_base58_check_exn (s : string) =\n let decoded = Base58_check.decode_exn s in\n decoded |> Bigstring.of_string |> of_bigstring_exn\n\n let to_string = to_base58_check\n\n let of_string = of_base58_check_exn\n\n let of_field = Fn.id\n\n let to_field_unsafe = Fn.id\n\n [%%ifdef consensus_mechanism]\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Pickles.Backend.Tick.Field.Stable.V1.t\n [@@deriving sexp, equal, compare, hash]\n\n let to_yojson (t : t) : Yojson.Safe.t = `String (to_string t)\n\n let of_yojson (j : Yojson.Safe.t) : (t, string) result =\n try Ok (of_string (Yojson.Safe.Util.to_string j))\n with e -> Error (Exn.to_string e)\n\n let to_latest = Fn.id\n end\n end]\n\n [%%else]\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Snark_params.Tick.Field.Stable.V1.t\n [@@deriving sexp, equal, compare, hash]\n\n let to_yojson (t : t) : Yojson.Safe.t = `String (to_string t)\n\n let of_yojson (j : Yojson.Safe.t) : (t, string) result =\n try Ok (of_string (Yojson.Safe.Util.to_string j))\n with e -> Error (Exn.to_string e)\n\n let to_latest = Fn.id\n end\n end]\n\n [%%endif]\n\n [%%define_locally Stable.Latest.(of_yojson, to_yojson)]\n\n module Binables = struct\n include Comparable.Make_binable (Stable.Latest)\n include Hashable.Make_binable (Stable.Latest)\n end\n\n include Binables\n\n let to_input : t -> _ Random_oracle_input.Chunked.t =\n Random_oracle_input.Chunked.field\n\n (* Just matters that this no one can find a preimage to this with poseidon.\n Chose 1 for consistency for the old uint64 based token IDs *)\n let default : t = Snark_params.Tick.Field.one\n\n let gen : t Quickcheck.Generator.t = Snark_params.Tick.Field.gen\n\n let gen_non_default =\n Quickcheck.Generator.filter gen ~f:(fun x -> not (equal x default))\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n open Pickles.Impls.Step\n\n type t = Field.t\n\n let to_input : t -> _ Random_oracle_input.Chunked.t =\n Random_oracle_input.Chunked.field\n\n let constant : Stable.Latest.t -> t = Field.constant\n\n let equal : t -> t -> Boolean.var = Field.equal\n\n let if_ = Field.if_\n\n let of_field = Fn.id\n\n let to_field_unsafe = Fn.id\n\n module Assert = struct\n let equal : t -> t -> unit = Field.Assert.equal\n end\n end\n\n let typ = Snark_params.Tick.Field.typ\n\n [%%endif]\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Public_key.Compressed.Stable.V1.t * Digest.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let create key tid = (key, tid)\n\n let empty : t = (Public_key.Compressed.empty, Digest.default)\n\n let public_key (key, _tid) = key\n\n let of_public_key (pk : Public_key.t) =\n create (Public_key.compress pk) Digest.default\n\n let token_id (_key, id) = id\n\n let to_input ((key, tid) : t) =\n Random_oracle_input.Chunked.(\n append (Public_key.Compressed.to_input key) (field tid))\n\n let derive_token_id ~(owner : t) : Digest.t =\n Random_oracle.hash ~init:Hash_prefix.derive_token_id\n (Random_oracle.pack_input (to_input owner))\n\n let gen =\n let open Quickcheck.Let_syntax in\n let%map key = Public_key.Compressed.gen and tid = Digest.gen in\n (key, tid)\n\n include Comparable.Make_binable (Stable.Latest)\n include Hashable.Make_binable (Stable.Latest)\n\n let to_input ((key, tid) : t) =\n Random_oracle.Input.Chunked.append\n (Public_key.Compressed.to_input key)\n (Digest.to_input tid)\n\n [%%ifdef consensus_mechanism]\n\n type var = Public_key.Compressed.var * Digest.Checked.t\n\n let typ = Snarky_backendless.Typ.(Public_key.Compressed.typ * Digest.typ)\n\n let var_of_t ((key, tid) : t) =\n ( Public_key.Compressed.var_of_t key\n , Snark_params.Tick.Field.Var.constant tid )\n\n module Checked = struct\n open Snark_params\n open Tick\n\n let create key tid = (key, tid)\n\n let public_key (key, _tid) = key\n\n let token_id (_key, tid) = tid\n\n let to_input ((key, tid) : var) =\n let tid = Digest.Checked.to_input tid in\n Random_oracle.Input.Chunked.append\n (Public_key.Compressed.Checked.to_input key)\n tid\n\n let derive_token_id ~(owner : var) : Digest.Checked.t =\n Random_oracle.Checked.hash ~init:Hash_prefix.derive_token_id\n (Random_oracle.Checked.pack_input (to_input owner))\n\n let equal (pk1, tid1) (pk2, tid2) =\n let%bind pk_equal = Public_key.Compressed.Checked.equal pk1 pk2 in\n let%bind tid_equal = Snark_params.Tick.Field.Checked.equal tid1 tid2 in\n Tick.Boolean.(pk_equal && tid_equal)\n\n let if_ b ~then_:(pk_then, tid_then) ~else_:(pk_else, tid_else) =\n let%bind pk =\n Public_key.Compressed.Checked.if_ b ~then_:pk_then ~else_:pk_else\n in\n let%map tid =\n Snark_params.Tick.Field.Checked.if_ b ~then_:tid_then ~else_:tid_else\n in\n (pk, tid)\n end\n\n [%%endif]\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params\nopen Tick\nopen Currency\nopen Mina_numbers\n\n(* A timed account is an account, which releases its balance to be spent\n gradually. The process of releasing frozen funds is defined as follows.\n Until the cliff_time global slot is reached, the initial_minimum_balance\n of mina is frozen and cannot be spent. At the cliff slot, cliff_amount\n is released and initial_minimum_balance is effectively lowered by that\n amount. Next, every vesting_period number of slots, vesting_increment\n is released, further decreasing the current minimum balance. At some\n point minimum balance drops to 0, and after that the account behaves\n like an untimed one. *)\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('slot, 'slot_span, 'balance, 'amount) t =\n | Untimed\n | Timed of\n { initial_minimum_balance : 'balance\n ; cliff_time : 'slot\n ; cliff_amount : 'amount\n ; vesting_period : 'slot_span\n ; vesting_increment : 'amount\n }\n [@@deriving sexp, equal, hash, compare, yojson]\n end\n end]\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n ( Global_slot_since_genesis.Stable.V1.t\n , Global_slot_span.Stable.V1.t\n , Balance.Stable.V1.t\n , Amount.Stable.V1.t )\n Poly.Stable.V2.t\n [@@deriving sexp, equal, hash, compare, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\ntype ('slot, 'slot_span, 'balance, 'amount) tt =\n ('slot, 'slot_span, 'balance, 'amount) Poly.t =\n | Untimed\n | Timed of\n { initial_minimum_balance : 'balance\n ; cliff_time : 'slot\n ; cliff_amount : 'amount\n ; vesting_period : 'slot_span\n ; vesting_increment : 'amount\n }\n[@@deriving sexp, equal, hash, compare, yojson]\n\nmodule As_record = struct\n type ('bool, 'slot, 'slot_span, 'balance, 'amount) t =\n { is_timed : 'bool\n ; initial_minimum_balance : 'balance\n ; cliff_time : 'slot\n ; cliff_amount : 'amount\n ; vesting_period : 'slot_span\n ; vesting_increment : 'amount\n }\n [@@deriving equal, hlist, fields, annot]\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~is_timed:!.bool ~initial_minimum_balance:!.balance\n ~cliff_time:!.global_slot_since_genesis\n ~cliff_amount:!.amount ~vesting_period:!.global_slot_span\n ~vesting_increment:!.amount\n |> finish \"AccountTiming\" ~t_toplevel_annots\nend\n\ntype as_record =\n ( bool\n , Global_slot_since_genesis.Stable.V1.t\n , Global_slot_span.Stable.V1.t\n , Balance.Stable.V1.t\n , Amount.Stable.V1.t )\n As_record.t\n\n(* convert sum type to record format, useful for to_bits and typ *)\nlet to_record t =\n match t with\n | Untimed ->\n let slot_unused = Global_slot_since_genesis.zero in\n let slot_span_one = Global_slot_span.(succ zero) in\n let balance_unused = Balance.zero in\n let amount_unused = Amount.zero in\n { As_record.is_timed = false\n ; initial_minimum_balance = balance_unused\n ; cliff_time = slot_unused\n ; cliff_amount = amount_unused\n ; vesting_period = slot_span_one (* avoid division by zero *)\n ; vesting_increment = amount_unused\n }\n | Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } ->\n { is_timed = true\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n\nlet of_record\n { As_record.is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } : t =\n if is_timed then\n Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n else Untimed\n\nlet of_record (r : as_record) : t =\n if r.is_timed then\n Timed\n { initial_minimum_balance = r.initial_minimum_balance\n ; cliff_time = r.cliff_time\n ; cliff_amount = r.cliff_amount\n ; vesting_period = r.vesting_period\n ; vesting_increment = r.vesting_increment\n }\n else Untimed\n\nlet to_input t =\n let As_record.\n { is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } =\n to_record t\n in\n let open Random_oracle_input.Chunked in\n Array.reduce_exn ~f:append\n [| packed ((if is_timed then Field.one else Field.zero), 1)\n ; Balance.to_input initial_minimum_balance\n ; Global_slot_since_genesis.to_input cliff_time\n ; Amount.to_input cliff_amount\n ; Global_slot_span.to_input vesting_period\n ; Amount.to_input vesting_increment\n |]\n\n[%%ifdef consensus_mechanism]\n\ntype var =\n ( Boolean.var\n , Global_slot_since_genesis.Checked.var\n , Global_slot_span.Checked.var\n , Balance.var\n , Amount.var )\n As_record.t\n\nlet var_to_input\n As_record.\n { is_timed : Boolean.var\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } =\n let open Random_oracle_input.Chunked in\n Array.reduce_exn ~f:append\n [| packed ((is_timed :> Field.Var.t), 1)\n ; Balance.var_to_input initial_minimum_balance\n ; Global_slot_since_genesis.Checked.to_input cliff_time\n ; Amount.var_to_input cliff_amount\n ; Global_slot_span.Checked.to_input vesting_period\n ; Amount.var_to_input vesting_increment\n |]\n\nlet var_of_t (t : t) : var =\n let { As_record.is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } =\n to_record t\n in\n { is_timed = Boolean.var_of_value is_timed\n ; initial_minimum_balance = Balance.var_of_t initial_minimum_balance\n ; cliff_time = Global_slot_since_genesis.Checked.constant cliff_time\n ; cliff_amount = Amount.var_of_t cliff_amount\n ; vesting_period = Global_slot_span.Checked.constant vesting_period\n ; vesting_increment = Amount.var_of_t vesting_increment\n }\n\nlet untimed_var = var_of_t Untimed\n\nlet typ : (var, t) Typ.t =\n (* because we represent the types t (a sum type) and var (a record) differently,\n we can't use the trick, used elsewhere, of polymorphic to_hlist and of_hlist\n functions to handle both types\n *)\n let value_of_hlist :\n ( unit\n , Boolean.value\n -> Balance.t\n -> Global_slot_since_genesis.t\n -> Amount.t\n -> Global_slot_span.t\n -> Amount.t\n -> unit )\n H_list.t\n -> t =\n let open H_list in\n fun [ is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n ] ->\n if is_timed then\n Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n else Untimed\n in\n let value_to_hlist (t : t) =\n let As_record.\n { is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } =\n to_record t\n in\n H_list.\n [ is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n ]\n in\n let var_of_hlist = As_record.of_hlist in\n let var_to_hlist = As_record.to_hlist in\n Typ.of_hlistable\n [ Boolean.typ\n ; Balance.typ\n ; Global_slot_since_genesis.typ\n ; Amount.typ\n ; Global_slot_span.typ\n ; Amount.typ\n ]\n ~var_to_hlist ~var_of_hlist ~value_to_hlist ~value_of_hlist\n\n(* we can't use the generic if_ with the above typ, because Global_slot_since_genesis.typ doesn't work correctly with it\n so we define a custom if_\n*)\nlet if_ b ~(then_ : var) ~(else_ : var) =\n let%bind is_timed =\n Boolean.if_ b ~then_:then_.is_timed ~else_:else_.is_timed\n in\n let%bind initial_minimum_balance =\n Balance.Checked.if_ b ~then_:then_.initial_minimum_balance\n ~else_:else_.initial_minimum_balance\n in\n let%bind cliff_time =\n Global_slot_since_genesis.Checked.if_ b ~then_:then_.cliff_time\n ~else_:else_.cliff_time\n in\n let%bind cliff_amount =\n Amount.Checked.if_ b ~then_:then_.cliff_amount ~else_:else_.cliff_amount\n in\n let%bind vesting_period =\n Global_slot_span.Checked.if_ b ~then_:then_.vesting_period\n ~else_:else_.vesting_period\n in\n let%map vesting_increment =\n Amount.Checked.if_ b ~then_:then_.vesting_increment\n ~else_:else_.vesting_increment\n in\n { As_record.is_timed\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n\nlet deriver obj =\n let open Fields_derivers_zkapps in\n iso_record ~to_record ~of_record As_record.deriver obj\n\n[%%endif]\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('field, 'scalar) t = 'field * 'scalar\n [@@deriving sexp, compare, equal, hash]\n end\n end]\nend\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t =\n ( (Field.t[@version_asserted])\n , (Inner_curve.Scalar.t[@version_asserted]) )\n Poly.Stable.V1.t\n [@@deriving sexp, compare, equal, hash]\n\n module Codable_arg = struct\n (* version tag for compatibility with pre-Berkeley hard fork\n Base58Check-serialized signatures\n *)\n type t =\n (Field.t, Inner_curve.Scalar.t) Poly.Stable.V1.With_all_version_tags.t\n [@@deriving bin_io_unversioned]\n\n let description = \"Signature\"\n\n let version_byte = Base58_check.Version_bytes.signature\n end\n\n (* Base58Check encodes t *)\n let (_ : (t, Codable_arg.t) Type_equal.t) = Type_equal.T\n\n include Codable.Make_base58_check (Codable_arg)\n\n let to_latest = Fn.id\n\n let gen = Quickcheck.Generator.tuple2 Field.gen Inner_curve.Scalar.gen\n end\nend]\n\nlet dummy = (Field.one, Inner_curve.Scalar.one)\n\nlet gen = Stable.Latest.gen\n\nmodule Raw = struct\n open Rosetta_coding.Coding\n\n let encode (field, scalar) = of_field field ^ of_scalar scalar\n\n let decode raw =\n let len = String.length raw in\n let field_len = len / 2 in\n let field_enc = String.sub raw ~pos:0 ~len:field_len in\n let scalar_enc = String.sub raw ~pos:field_len ~len:field_len in\n try Some (to_field field_enc, to_scalar scalar_enc) with _ -> None\nend\n\n[%%ifdef consensus_mechanism]\n\ntype var = Field.Var.t * Inner_curve.Scalar.var\n\n[%%endif]\n\n[%%define_locally\nStable.Latest.\n (of_base58_check_exn, of_base58_check, of_yojson, to_yojson, to_base58_check)]\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n(* TODO: temporary hack *)\n[%%ifdef consensus_mechanism]\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Control.V2.t =\n | Proof of Pickles.Side_loaded.Proof.Stable.V2.t\n | Signature of Signature.Stable.V1.t\n | None_given\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\nend]\n\n(* lazy, to prevent spawning Rust threads at startup, which prevents daemonization *)\nlet gen_with_dummies : t Quickcheck.Generator.t =\n let gen =\n lazy\n (Quickcheck.Generator.of_list\n (let dummy_proof =\n let n2 = Pickles_types.Nat.N2.n in\n let proof = Pickles.Proof.dummy n2 n2 n2 ~domain_log2:15 in\n Proof proof\n in\n let dummy_signature = Signature Signature.dummy in\n [ dummy_proof; dummy_signature; None_given ] ) )\n in\n Quickcheck.Generator.create (fun ~size ~random ->\n Quickcheck.Generator.generate (Lazy.force gen) ~size ~random )\n\n[%%else]\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Proof of unit | Signature of Signature.Stable.V1.t | None_given\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n type t =\n | Proof of unit\n | Signature of Signature.Stable.V1.t\n | Both of { signature : Signature.Stable.V1.t; proof : unit }\n | None_given\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest : t -> V2.t = function\n | Proof proof ->\n Proof proof\n | Signature signature ->\n Signature signature\n | None_given ->\n None_given\n | Both _ ->\n failwith\n \"Control.Stable.V1.to_latest: Both variant is no longer supported\"\n end\nend]\n\n[%%endif]\n\nmodule Tag = struct\n type t = Signature | Proof | None_given [@@deriving equal, compare, sexp]\n\n let gen = Quickcheck.Generator.of_list [ Proof; Signature; None_given ]\n\n let to_string = function\n | Signature ->\n \"Signature\"\n | Proof ->\n \"Proof\"\n | None_given ->\n \"None_given\"\n\n let of_string_exn = function\n | \"Signature\" ->\n Signature\n | \"Proof\" ->\n Proof\n | \"None_given\" ->\n None_given\n | s ->\n failwithf \"String %s does not denote a control tag\" s ()\nend\n\nlet tag : t -> Tag.t = function\n | Proof _ ->\n Proof\n | Signature _ ->\n Signature\n | None_given ->\n None_given\n\n[%%ifdef consensus_mechanism]\n\nlet dummy_of_tag : Tag.t -> t = function\n | Proof ->\n let n2 = Pickles_types.Nat.N2.n in\n let proof = Pickles.Proof.dummy n2 n2 n2 ~domain_log2:15 in\n Proof proof\n | Signature ->\n Signature Signature.dummy\n | None_given ->\n None_given\n\nlet signature_deriver obj =\n Fields_derivers_zkapps.Derivers.iso_string obj ~name:\"Signature\"\n ~js_type:String ~to_string:Signature.to_base58_check\n ~of_string:\n (Fields_derivers_zkapps.except ~f:Signature.of_base58_check_exn `Signature)\n\nmodule As_record = struct\n type t =\n { proof : Pickles.Side_loaded.Proof.t option\n ; signature : Signature.t option\n }\n [@@deriving annot, fields]\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj\n ~proof:!.(option ~js_type:Or_undefined @@ proof @@ o ())\n ~signature:!.(option ~js_type:Or_undefined @@ signature_deriver @@ o ())\n |> finish \"Control\" ~t_toplevel_annots\nend\n\nlet to_record = function\n | Proof p ->\n { As_record.proof = Some p; signature = None }\n | Signature s ->\n { proof = None; signature = Some s }\n | None_given ->\n { proof = None; signature = None }\n\nlet of_record = function\n | { As_record.proof = Some p; _ } ->\n Proof p\n | { signature = Some s; _ } ->\n Signature s\n | _ ->\n None_given\n\nlet deriver obj =\n Fields_derivers_zkapps.Derivers.iso_record ~of_record ~to_record\n As_record.deriver obj\n\nlet%test_unit \"json rountrip\" =\n let module Fd = Fields_derivers_zkapps.Derivers in\n let full = deriver (Fd.o ()) in\n let control = dummy_of_tag Proof in\n [%test_eq: t] control (control |> Fd.to_json full |> Fd.of_json full)\n\n[%%endif]\n","(* payment_payload.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Signature_lib\nmodule Amount = Currency.Amount\nmodule Fee = Currency.Fee\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('public_key, 'amount) t =\n ( 'public_key\n , 'amount )\n Mina_wire_types.Mina_base.Payment_payload.Poly.V2.t =\n { receiver_pk : 'public_key; amount : 'amount }\n [@@deriving equal, sexp, hash, yojson, compare, hlist]\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('public_key, 'token_id, 'amount) t =\n { source_pk : 'public_key\n ; receiver_pk : 'public_key\n ; token_id : 'token_id\n ; amount : 'amount\n }\n [@@deriving equal, sexp, hash, yojson, compare, hlist]\n end\n end]\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n (Public_key.Compressed.Stable.V1.t, Amount.Stable.V1.t) Poly.Stable.V2.t\n [@@deriving equal, sexp, hash, compare, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t =\n ( Public_key.Compressed.Stable.V1.t\n , Token_id.Stable.V1.t\n , Amount.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving equal, sexp, hash, compare, yojson]\n\n (* don't need to coerce old payments to new ones *)\n let to_latest _ = failwith \"Not implemented\"\n end\nend]\n\nlet dummy =\n Poly.{ receiver_pk = Public_key.Compressed.empty; amount = Amount.zero }\n\n[%%ifdef consensus_mechanism]\n\ntype var = (Public_key.Compressed.var, Amount.var) Poly.t\n\nlet var_of_t ({ receiver_pk; amount } : t) : var =\n { receiver_pk = Public_key.Compressed.var_of_t receiver_pk\n ; amount = Amount.var_of_t amount\n }\n\n[%%endif]\n\nlet gen_aux max_amount =\n let open Quickcheck.Generator.Let_syntax in\n let%bind receiver_pk = Public_key.Compressed.gen in\n let%map amount = Amount.gen_incl Amount.zero max_amount in\n Poly.{ receiver_pk; amount }\n\nlet gen max_amount = gen_aux max_amount\n\nlet gen_default_token max_amount = gen_aux max_amount\n","open Core_kernel\nopen Snark_params.Tick\n\ninclude Data_hash.Make_full_size (struct\n let description = \"Ledger hash\"\n\n let version_byte = Base58_check.Version_bytes.ledger_hash\nend)\n\n(* Data hash versioned boilerplate below *)\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\nend]\n\nlet (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_util\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nmodule Frozen_ledger_hash = Frozen_ledger_hash0\nmodule Ledger_hash = Ledger_hash0\n\n(* Semantically this type represents a function\n { has_valid_signature: bool; has_valid_proof: bool } -> bool\n\n These are all of them:\n 00 01 10 11 | intuitive definition | Make sense\n 0 0 0 0 | Impossible | yes\n 0 0 0 1 | Both | yes\n 0 0 1 0 | Proof and not signature | no\n 0 0 1 1 | Proof | yes\n 0 1 0 0 | Signature and not proof | no\n 0 1 0 1 | Signature | yes\n 0 1 1 0 | Exactly one | no\n 0 1 1 1 | Either | yes\n 1 0 0 0 | Neither | no\n 1 0 0 1 | Neither or both | no\n 1 0 1 0 | Neither or proof, not both | no\n ...\n 1 1 1 1 | None | yes\n\n The ones marked as \"not making sense\" don't make sense because it is pointless\n to demand a signature failed to verify since you can always make a failing signature\n or proof.\n\n The ones that make sense are\n 0 0 0 0 | Impossible | yes\n 0 0 0 1 | Both | yes\n 0 0 1 1 | Proof | yes\n 0 1 0 1 | Signature | yes\n 0 1 1 1 | Either | yes\n 1 1 1 1 | None | yes\n\n \"Making sense\" can be captured by the idea that these are the *increasing*\n boolean functions on the type { has_valid_signature: bool; has_valid_proof: bool }.\n*)\nmodule Auth_required = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Permissions.Auth_required.V2.t =\n | None\n | Either\n | Proof\n | Signature\n | Impossible (* Both and either can both be subsumed in verification key.\n It is good to have \"Either\" as a separate thing to spare the owner from\n having to make a proof instead of a signature. Both, I'm not sure if there's\n a good justification for. *)\n [@@deriving sexp, equal, compare, hash, yojson, enum]\n\n let to_latest = Fn.id\n end\n end]\n\n let from ~auth_tag : t =\n match auth_tag with\n | Control.Tag.Proof ->\n Proof\n | Signature ->\n Signature\n | None_given ->\n None\n\n (* permissions such that [check permission (Proof _)] is true *)\n let gen_for_proof_authorization : t Quickcheck.Generator.t =\n Quickcheck.Generator.of_list [ None; Either; Proof ]\n\n (* permissions such that [check permission (Signature _)] is true *)\n let gen_for_signature_authorization : t Quickcheck.Generator.t =\n Quickcheck.Generator.of_list [ None; Either; Signature ]\n\n (* permissions such that [check permission None_given] is true *)\n let gen_for_none_given_authorization : t Quickcheck.Generator.t =\n Quickcheck.Generator.return None\n\n let to_string = function\n | None ->\n \"None\"\n | Either ->\n \"Either\"\n | Proof ->\n \"Proof\"\n | Signature ->\n \"Signature\"\n | Impossible ->\n \"Impossible\"\n\n let of_string = function\n | \"None\" ->\n Stable.Latest.None\n | \"Either\" ->\n Either\n | \"Proof\" ->\n Proof\n | \"Signature\" ->\n Signature\n | \"Impossible\" ->\n Impossible\n | _ ->\n failwith \"auth_required_of_string: unknown variant\"\n\n (* The encoding is chosen so that it is easy to write this function\n\n let spec_eval t ~signature_verifies =\n let impossible = (constant t && not (signature_sufficient t)) in\n let result =\n not impossible &&\n ( (signature_verifies && signature_sufficient t)\n || not (signature_necessary t) )\n in\n { result; proof_must_verify= not (signature_sufficient t) } *)\n\n (* Here is the mapping between our type and the bits\n { constant: bool\n ; signature_necessary: bool\n ; signature_sufficient: bool\n }\n\n Not constant\n Signature not necessary\n Signature not sufficient\n Proof\n Signature sufficient\n Either\n Signature necessary\n Signature not sufficient\n Both\n Signature sufficient\n Signature\n\n Constant\n Signature not sufficient\n Impossible\n Signature sufficient\n None\n *)\n module Encoding = struct\n type 'bool t =\n { constant : 'bool\n ; signature_necessary : 'bool\n ; signature_sufficient : 'bool\n }\n [@@deriving hlist, fields]\n\n let to_input ~field_of_bool t =\n let [ x; y; z ] = to_hlist t in\n let bs = [| x; y; z |] in\n Random_oracle.Input.Chunked.packeds\n (Array.map bs ~f:(fun b -> (field_of_bool b, 1)))\n\n let map t ~f =\n { constant = f t.constant\n ; signature_necessary = f t.signature_necessary\n ; signature_sufficient = f t.signature_sufficient\n }\n\n let _ = map\n\n [%%ifdef consensus_mechanism]\n\n let if_ b ~then_:t ~else_:e =\n let open Pickles.Impls.Step in\n { constant = Boolean.if_ b ~then_:t.constant ~else_:e.constant\n ; signature_necessary =\n Boolean.if_ b ~then_:t.signature_necessary\n ~else_:e.signature_necessary\n ; signature_sufficient =\n Boolean.if_ b ~then_:t.signature_sufficient\n ~else_:e.signature_sufficient\n }\n\n [%%endif]\n end\n\n let encode : t -> bool Encoding.t = function\n | Impossible ->\n { constant = true\n ; signature_necessary = true\n ; signature_sufficient = false\n }\n | None ->\n { constant = true\n ; signature_necessary = false\n ; signature_sufficient = true\n }\n | Proof ->\n { constant = false\n ; signature_necessary = false\n ; signature_sufficient = false\n }\n | Signature ->\n { constant = false\n ; signature_necessary = true\n ; signature_sufficient = true\n }\n | Either ->\n { constant = false\n ; signature_necessary = false\n ; signature_sufficient = true\n }\n\n let decode : bool Encoding.t -> t = function\n | { constant = true; signature_necessary = _; signature_sufficient = false }\n ->\n Impossible\n | { constant = true; signature_necessary = _; signature_sufficient = true }\n ->\n None\n | { constant = false\n ; signature_necessary = false\n ; signature_sufficient = false\n } ->\n Proof\n | { constant = false\n ; signature_necessary = true\n ; signature_sufficient = true\n } ->\n Signature\n | { constant = false\n ; signature_necessary = false\n ; signature_sufficient = true\n } ->\n Either\n | { constant = false\n ; signature_necessary = true\n ; signature_sufficient = false\n } ->\n failwith\n \"Permissions.decode: Found encoding of Both, but Both is not an \\\n exposed option\"\n\n let%test_unit \"decode encode\" =\n List.iter [ Impossible; Proof; Signature; Either ] ~f:(fun t ->\n [%test_eq: t] t (decode (encode t)) )\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n type t = Boolean.var Encoding.t\n\n let if_ = Encoding.if_\n\n let to_input : t -> _ =\n Encoding.to_input ~field_of_bool:(fun (b : Boolean.var) ->\n (b :> Field.Var.t) )\n\n let constant t = Encoding.map (encode t) ~f:Boolean.var_of_value\n\n let eval_no_proof\n ({ constant; signature_necessary = _; signature_sufficient } : t)\n ~signature_verifies =\n (* ways authorization can succeed when no proof is present:\n - None\n {constant= true; signature_necessary= _; signature_sufficient= true}\n - Either && signature_verifies\n {constant= false; signature_necessary= false; signature_sufficient= true}\n - Signature && signature_verifies\n {constant= false; signature_necessary= true; signature_sufficient= true}\n *)\n let open Pickles.Impls.Step.Boolean in\n signature_sufficient\n &&& (constant ||| ((not constant) &&& signature_verifies))\n\n let eval_proof ({ constant; signature_necessary; signature_sufficient } : t)\n =\n (* ways authorization can succeed if a proof is present:\n - None\n {constant= true; signature_necessary= _; signature_sufficient= true}\n - Either\n {constant= false; signature_necessary= false; signature_sufficient= true}\n - Proof\n {constant= false; signature_necessary= false; signature_sufficient= false}\n *)\n let open Pickles.Impls.Step.Boolean in\n let impossible = constant &&& not signature_sufficient in\n (not signature_necessary) &&& not impossible\n\n let spec_eval ({ constant; signature_necessary; signature_sufficient } : t)\n ~signature_verifies =\n let open Pickles.Impls.Step.Boolean in\n let impossible = constant &&& not signature_sufficient in\n let result =\n (not impossible)\n &&& ( signature_verifies &&& signature_sufficient\n ||| not signature_necessary )\n in\n let didn't_fail_yet = result in\n (* If the transaction already failed to verify, we don't need to assert\n that the proof should verify. *)\n (result, `proof_must_verify (didn't_fail_yet &&& not signature_sufficient))\n end\n\n let typ =\n let t =\n let open Encoding in\n Typ.of_hlistable\n [ Boolean.typ; Boolean.typ; Boolean.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n in\n Typ.transport t ~there:encode ~back:decode\n\n [%%endif]\n\n let to_input x = Encoding.to_input (encode x) ~field_of_bool\n\n let check (t : t) (c : Control.Tag.t) =\n match (t, c) with\n | Impossible, _ ->\n false\n | None, _ ->\n true\n | Proof, Proof ->\n true\n | Signature, Signature ->\n true\n (* The signatures and proofs have already been checked by this point. *)\n | Either, (Proof | Signature) ->\n true\n | Signature, Proof ->\n false\n | Proof, Signature ->\n false\n | (Proof | Signature | Either), None_given ->\n false\nend\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type 'controller t =\n 'controller Mina_wire_types.Mina_base.Permissions.Poly.V2.t =\n { edit_state : 'controller\n ; access : 'controller\n ; send : 'controller\n ; receive : 'controller\n ; set_delegate : 'controller\n ; set_permissions : 'controller\n ; set_verification_key : 'controller\n ; set_zkapp_uri : 'controller\n ; edit_action_state : 'controller\n ; set_token_symbol : 'controller\n ; increment_nonce : 'controller\n ; set_voting_for : 'controller\n ; set_timing : 'controller\n }\n [@@deriving annot, sexp, equal, compare, hash, yojson, hlist, fields]\n end\n end]\n\n let to_input controller t =\n let f mk acc field = mk (Core_kernel.Field.get field t) :: acc in\n Stable.Latest.Fields.fold ~init:[] ~edit_state:(f controller)\n ~send:(f controller) ~set_delegate:(f controller)\n ~set_permissions:(f controller) ~set_verification_key:(f controller)\n ~receive:(f controller) ~set_zkapp_uri:(f controller)\n ~edit_action_state:(f controller) ~set_token_symbol:(f controller)\n ~increment_nonce:(f controller) ~set_voting_for:(f controller)\n ~set_timing:(f controller) ~access:(f controller)\n |> List.rev\n |> List.reduce_exn ~f:Random_oracle.Input.Chunked.append\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Auth_required.Stable.V2.t Poly.Stable.V2.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\nlet gen ~auth_tag : t Quickcheck.Generator.t =\n let auth_required_gen =\n (* for Auth_required permissions p, choose such that [check p authorization] is true *)\n match auth_tag with\n | Control.Tag.Proof ->\n Auth_required.gen_for_proof_authorization\n | Signature ->\n Auth_required.gen_for_signature_authorization\n | None_given ->\n Auth_required.gen_for_none_given_authorization\n in\n let open Quickcheck.Generator.Let_syntax in\n let%bind edit_state = auth_required_gen in\n let%bind send = auth_required_gen in\n let%bind receive = auth_required_gen in\n let%bind set_delegate = auth_required_gen in\n let%bind set_permissions = auth_required_gen in\n let%bind set_verification_key = auth_required_gen in\n let%bind set_zkapp_uri = auth_required_gen in\n let%bind edit_action_state = auth_required_gen in\n let%bind set_token_symbol = auth_required_gen in\n let%bind increment_nonce = auth_required_gen in\n let%bind set_voting_for = auth_required_gen in\n let%bind set_timing = auth_required_gen in\n let%bind access =\n (* Access permission is significantly more restrictive, do not arbitrarily\n set it when tests may not be intending to exercise it.\n *)\n Auth_required.gen_for_none_given_authorization\n in\n return\n { Poly.edit_state\n ; send\n ; receive\n ; set_delegate\n ; set_permissions\n ; set_verification_key\n ; set_zkapp_uri\n ; edit_action_state\n ; set_token_symbol\n ; increment_nonce\n ; set_voting_for\n ; set_timing\n ; access\n }\n\n[%%ifdef consensus_mechanism]\n\nmodule Checked = struct\n type t = Auth_required.Checked.t Poly.Stable.Latest.t\n\n let to_input (x : t) = Poly.to_input Auth_required.Checked.to_input x\n\n let if_ b ~then_ ~else_ =\n let g cond f =\n cond b\n ~then_:(Core_kernel.Field.get f then_)\n ~else_:(Core_kernel.Field.get f else_)\n in\n let c = g Auth_required.Checked.if_ in\n Poly.Fields.map ~edit_state:c ~send:c ~receive:c ~set_delegate:c\n ~set_permissions:c ~set_verification_key:c ~set_zkapp_uri:c\n ~edit_action_state:c ~set_token_symbol:c ~increment_nonce:c\n ~set_voting_for:c ~set_timing:c ~access:c\n\n let constant (t : Stable.Latest.t) : t =\n let open Core_kernel.Field in\n let a f = Auth_required.Checked.constant (get f t) in\n Poly.Fields.map ~edit_state:a ~send:a ~receive:a ~set_delegate:a\n ~set_permissions:a ~set_verification_key:a ~set_zkapp_uri:a\n ~edit_action_state:a ~set_token_symbol:a ~increment_nonce:a\n ~set_voting_for:a ~set_timing:a ~access:a\nend\n\nlet typ =\n let open Poly.Stable.Latest in\n Typ.of_hlistable\n [ Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ; Auth_required.typ\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n[%%endif]\n\nlet to_input (x : t) = Poly.to_input Auth_required.to_input x\n\nlet user_default : t =\n { edit_state = Signature\n ; send = Signature\n ; receive = None\n ; set_delegate = Signature\n ; set_permissions = Signature\n ; set_verification_key = Signature\n ; set_zkapp_uri = Signature\n ; edit_action_state = Signature\n ; set_token_symbol = Signature\n ; increment_nonce = Signature\n ; set_voting_for = Signature\n ; set_timing = Signature\n ; access = None\n }\n\nlet empty : t =\n { edit_state = None\n ; send = None\n ; receive = None\n ; access = None\n ; set_delegate = None\n ; set_permissions = None\n ; set_verification_key = None\n ; set_zkapp_uri = None\n ; edit_action_state = None\n ; set_token_symbol = None\n ; increment_nonce = None\n ; set_voting_for = None\n ; set_timing = None\n }\n\n(* deriving-fields-related stuff *)\n\nlet auth_required =\n Fields_derivers_zkapps.Derivers.iso_string ~name:\"AuthRequired\"\n ~js_type:(Custom \"AuthRequired\") ~doc:\"Kind of authorization required\"\n ~to_string:Auth_required.to_string ~of_string:Auth_required.of_string\n\nlet deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots:Poly.t_fields_annots in\n Poly.Fields.make_creator obj ~edit_state:!.auth_required ~send:!.auth_required\n ~receive:!.auth_required ~set_delegate:!.auth_required\n ~set_permissions:!.auth_required ~set_verification_key:!.auth_required\n ~set_zkapp_uri:!.auth_required ~edit_action_state:!.auth_required\n ~set_token_symbol:!.auth_required ~increment_nonce:!.auth_required\n ~set_voting_for:!.auth_required ~set_timing:!.auth_required\n ~access:!.auth_required\n |> finish \"Permissions\" ~t_toplevel_annots:Poly.t_toplevel_annots\n\nlet%test_unit \"json roundtrip\" =\n let open Fields_derivers_zkapps.Derivers in\n let full = o () in\n let _a = deriver full in\n [%test_eq: t] user_default (user_default |> to_json full |> of_json full)\n\nlet%test_unit \"json value\" =\n let open Fields_derivers_zkapps.Derivers in\n let full = o () in\n let _a = deriver full in\n [%test_eq: string]\n (user_default |> to_json full |> Yojson.Safe.to_string)\n ( {json|{\n editState: \"Signature\",\n access: \"None\",\n send: \"Signature\",\n receive: \"None\",\n setDelegate: \"Signature\",\n setPermissions: \"Signature\",\n setVerificationKey: \"Signature\",\n setZkappUri: \"Signature\",\n editActionState: \"Signature\",\n setTokenSymbol: \"Signature\",\n incrementNonce: \"Signature\",\n setVotingFor: \"Signature\",\n setTiming: \"Signature\"\n }|json}\n |> Yojson.Safe.from_string |> Yojson.Safe.to_string )\n","(* signed_command_memo.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Signed_command_memo\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Signed_command_memo_intf.S with type t = A.V1.t\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = string [@@deriving sexp, equal, compare, hash]\n\n let to_latest = Fn.id\n\n module Base58_check = Base58_check.Make (struct\n let description = \"User command memo\"\n\n let version_byte = Base58_check.Version_bytes.user_command_memo\n end)\n\n let to_base58_check (memo : t) : string = Base58_check.encode memo\n\n let of_base58_check (s : string) : t Or_error.t = Base58_check.decode s\n\n let of_base58_check_exn (s : string) : t = Base58_check.decode_exn s\n\n module T = struct\n type nonrec t = t\n\n let to_string = to_base58_check\n\n let of_string = of_base58_check_exn\n end\n\n include Codable.Make_of_string (T)\n end\n end]\n\n [%%define_locally\n Stable.Latest.\n (to_yojson, of_yojson, to_base58_check, of_base58_check, of_base58_check_exn)]\n\n exception Too_long_user_memo_input\n\n exception Too_long_digestible_string\n\n let max_digestible_string_length = 1000\n\n (* 0th byte is a tag to distinguish digests from other data\n 1st byte is length, always 32 for digests\n bytes 2 to 33 are data, 0-right-padded if length is less than 32\n *)\n\n let digest_tag = '\\x00'\n\n let bytes_tag = '\\x01'\n\n let tag_index = 0\n\n let length_index = 1\n\n let digest_length = Blake2.digest_size_in_bytes\n\n let digest_length_byte = Char.of_int_exn digest_length\n\n (* +2 for tag and length bytes *)\n let memo_length = digest_length + 2\n\n let max_input_length = digest_length\n\n let tag (memo : t) = memo.[tag_index]\n\n let length memo = Char.to_int memo.[length_index]\n\n let is_bytes memo = Char.equal (tag memo) bytes_tag\n\n let is_digest memo = Char.equal (tag memo) digest_tag\n\n let is_valid memo =\n Int.(String.length memo = memo_length)\n &&\n let length = length memo in\n if is_digest memo then Int.(length = digest_length)\n else\n Char.equal (tag memo) bytes_tag\n && Int.(length <= digest_length)\n &&\n let padded =\n String.sub memo ~pos:(length + 2) ~len:(digest_length - length)\n in\n String.for_all padded ~f:(Char.equal '\\x00')\n\n let create_by_digesting_string_exn s =\n if Int.(String.length s > max_digestible_string_length) then\n raise Too_long_digestible_string ;\n let digest = Blake2.(to_raw_string (digest_string s)) in\n String.init memo_length ~f:(fun ndx ->\n if Int.(ndx = tag_index) then digest_tag\n else if Int.(ndx = length_index) then digest_length_byte\n else digest.[ndx - 2] )\n\n let create_by_digesting_string (s : string) =\n try Ok (create_by_digesting_string_exn s)\n with Too_long_digestible_string ->\n Or_error.error_string \"create_by_digesting_string: string too long\"\n\n module type Memoable = sig\n type t\n\n val length : t -> int\n\n val get : t -> int -> char\n end\n\n let create_from_value_exn (type t) (module M : Memoable with type t = t)\n (value : t) =\n let len = M.length value in\n if Int.(len > max_input_length) then raise Too_long_user_memo_input ;\n String.init memo_length ~f:(fun ndx ->\n if Int.(ndx = tag_index) then bytes_tag\n else if Int.(ndx = length_index) then Char.of_int_exn len\n else if Int.(ndx < len + 2) then M.get value (ndx - 2)\n else '\\x00' )\n\n let create_from_bytes_exn bytes = create_from_value_exn (module Bytes) bytes\n\n let create_from_bytes bytes =\n try Ok (create_from_bytes_exn bytes)\n with Too_long_user_memo_input ->\n Or_error.error_string\n (sprintf \"create_from_bytes: length exceeds %d\" max_input_length)\n\n let create_from_string_exn s = create_from_value_exn (module String) s\n\n let create_from_string s =\n try Ok (create_from_string_exn s)\n with Too_long_user_memo_input ->\n Or_error.error_string\n (sprintf \"create_from_string: length exceeds %d\" max_input_length)\n\n let dummy = (create_by_digesting_string_exn \"\" :> t)\n\n let empty = create_from_string_exn \"\"\n\n type raw = Digest of string | Bytes of string\n\n let to_raw_exn memo =\n let tag = tag memo in\n if Char.equal tag digest_tag then Digest (to_base58_check memo)\n else if Char.equal tag bytes_tag then\n let len = length memo in\n Bytes (String.init len ~f:(fun idx -> memo.[idx - 2]))\n else failwithf \"Unknown memo tag %c\" tag ()\n\n let to_raw_bytes_exn memo =\n match to_raw_exn memo with\n | Digest _ ->\n failwith \"Cannot convert a digest to raw bytes\"\n | Bytes str ->\n str\n\n let of_raw_exn = function\n | Digest base58_check ->\n of_base58_check_exn base58_check\n | Bytes str ->\n of_base58_check_exn str\n\n let fold_bits t =\n { Fold_lib.Fold.fold =\n (fun ~init ~f ->\n let n = 8 * String.length t in\n let rec go acc i =\n if i = n then acc\n else\n let b = (Char.to_int t.[i / 8] lsr (i mod 8)) land 1 = 1 in\n go (f acc b) (i + 1)\n in\n go init 0 )\n }\n\n let to_bits t = Fold_lib.Fold.to_list (fold_bits t)\n\n let gen =\n Quickcheck.Generator.map String.quickcheck_generator\n ~f:create_by_digesting_string_exn\n\n let hash memo =\n Random_oracle.hash ~init:Hash_prefix.zkapp_memo\n (Random_oracle.Legacy.pack_input\n (Random_oracle_input.Legacy.bitstring (to_bits memo)) )\n\n let to_plaintext (memo : t) : string Or_error.t =\n if is_bytes memo then Ok (String.sub memo ~pos:2 ~len:(length memo))\n else Error (Error.of_string \"Memo does not contain text bytes\")\n\n let to_digest (memo : t) : string Or_error.t =\n if is_digest memo then Ok (String.sub memo ~pos:2 ~len:digest_length)\n else Error (Error.of_string \"Memo does not contain a digest\")\n\n let to_string_hum (memo : t) =\n match to_plaintext memo with\n | Ok text ->\n text\n | Error _ -> (\n match to_digest memo with\n | Ok digest ->\n sprintf \"0x%s\" (Hex.encode digest)\n | Error _ ->\n \"(Invalid memo, neither text nor a digest)\" )\n\n [%%ifdef consensus_mechanism]\n\n module Boolean = Tick.Boolean\n module Typ = Tick.Typ\n\n (* the code below is much the same as in Random_oracle.Digest; tag and length bytes\n make it a little different\n *)\n\n module Checked = struct\n type unchecked = t\n\n type t = Boolean.var array\n\n let constant unchecked =\n assert (Int.(String.length (unchecked :> string) = memo_length)) ;\n Array.map\n (Blake2.string_to_bits (unchecked :> string))\n ~f:Boolean.var_of_value\n end\n\n let length_in_bits = 8 * memo_length\n\n let typ : (Checked.t, t) Typ.t =\n Typ.transport\n (Typ.array ~length:length_in_bits Boolean.typ)\n ~there:(fun (t : t) -> Blake2.string_to_bits (t :> string))\n ~back:(fun bs -> (Blake2.bits_to_string bs :> t))\n\n [%%endif]\n\n let deriver obj =\n Fields_derivers_zkapps.iso_string obj ~name:\"Memo\" ~js_type:String\n ~to_string:to_base58_check ~of_string:of_base58_check_exn\n\n let%test_module \"user_command_memo\" =\n ( module struct\n let data memo = String.sub memo ~pos:(length_index + 1) ~len:(length memo)\n\n let%test \"digest string\" =\n let s = \"this is a string\" in\n let memo = create_by_digesting_string_exn s in\n is_valid memo\n\n let%test \"digest too-long string\" =\n let s =\n String.init (max_digestible_string_length + 1) ~f:(fun _ -> '\\xFF')\n in\n try\n let (_ : t) = create_by_digesting_string_exn s in\n false\n with Too_long_digestible_string -> true\n\n let%test \"memo from string\" =\n let s = \"time and tide wait for no one\" in\n let memo = create_from_string_exn s in\n is_valid memo && String.equal s (data memo)\n\n let%test \"memo from too-long string\" =\n let s = String.init (max_input_length + 1) ~f:(fun _ -> '\\xFF') in\n try\n let (_ : t) = create_from_string_exn s in\n false\n with Too_long_user_memo_input -> true\n\n [%%ifdef consensus_mechanism]\n\n let%test_unit \"typ is identity\" =\n let s = \"this is a string\" in\n let memo = create_by_digesting_string_exn s in\n let read_constant = function\n | Snarky_backendless.Cvar.Constant x ->\n x\n | _ ->\n assert false\n in\n let (Typ typ) = typ in\n let memo_var =\n memo |> typ.value_to_fields\n |> (fun (arr, aux) ->\n ( Array.map arr ~f:(fun x -> Snarky_backendless.Cvar.Constant x)\n , aux ) )\n |> typ.var_of_fields\n in\n let memo_read =\n memo_var |> typ.var_to_fields\n |> (fun (arr, aux) ->\n (Array.map arr ~f:(fun x -> read_constant x), aux) )\n |> typ.value_of_fields\n in\n [%test_eq: string] memo memo_read\n\n [%%endif]\n end )\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","(* stake_delegation.ml *)\n\nopen Core_kernel\nopen Signature_lib\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n [@@@with_all_version_tags]\n\n type t = Mina_wire_types.Mina_base.Stake_delegation.V2.t =\n | Set_delegate of { new_delegate : Public_key.Compressed.Stable.V1.t }\n [@@deriving compare, equal, sexp, hash, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Mina_wire_types.Mina_base.Stake_delegation.V1.t =\n | Set_delegate of\n { delegator : Public_key.Compressed.Stable.V1.t\n ; new_delegate : Public_key.Compressed.Stable.V1.t\n }\n [@@deriving compare, equal, sexp, hash, yojson]\n\n let to_latest (Set_delegate { delegator = _; new_delegate }) =\n V2.Set_delegate { new_delegate }\n end\nend]\n\nlet receiver_pk = function Set_delegate { new_delegate } -> new_delegate\n\nlet receiver = function\n | Set_delegate { new_delegate } ->\n Account_id.create new_delegate Token_id.default\n\nlet gen =\n Quickcheck.Generator.map Public_key.Compressed.gen ~f:(fun k ->\n Set_delegate { new_delegate = k } )\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nmodule Failure = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Transaction_status.Failure.V2.t =\n | Predicate [@value 1]\n | Source_not_present\n | Receiver_not_present\n | Amount_insufficient_to_create_account\n | Cannot_pay_creation_fee_in_token\n | Source_insufficient_balance\n | Source_minimum_balance_violation\n | Receiver_already_exists\n | Token_owner_not_caller\n | Overflow\n | Global_excess_overflow\n | Local_excess_overflow\n | Local_supply_increase_overflow\n | Global_supply_increase_overflow\n | Signed_command_on_zkapp_account\n | Zkapp_account_not_present\n | Update_not_permitted_balance\n | Update_not_permitted_access\n | Update_not_permitted_timing\n | Update_not_permitted_delegate\n | Update_not_permitted_app_state\n | Update_not_permitted_verification_key\n | Update_not_permitted_action_state\n | Update_not_permitted_zkapp_uri\n | Update_not_permitted_token_symbol\n | Update_not_permitted_permissions\n | Update_not_permitted_nonce\n | Update_not_permitted_voting_for\n | Zkapp_command_replay_check_failed\n | Fee_payer_nonce_must_increase\n | Fee_payer_must_be_signed\n | Account_balance_precondition_unsatisfied\n | Account_nonce_precondition_unsatisfied\n | Account_receipt_chain_hash_precondition_unsatisfied\n | Account_delegate_precondition_unsatisfied\n | Account_action_state_precondition_unsatisfied\n | Account_app_state_precondition_unsatisfied of int\n | Account_proved_state_precondition_unsatisfied\n | Account_is_new_precondition_unsatisfied\n | Protocol_state_precondition_unsatisfied\n | Unexpected_verification_key_hash\n | Valid_while_precondition_unsatisfied\n | Incorrect_nonce\n | Invalid_fee_excess\n | Cancelled\n [@@deriving sexp, yojson, equal, compare, variants, hash]\n\n let to_latest = Fn.id\n end\n end]\n\n module Collection = struct\n module Display = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = (int * Stable.V2.t list) list\n [@@deriving equal, compare, yojson, sexp, hash]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Stable.V2.t list list\n [@@deriving equal, compare, yojson, sexp, hash]\n\n let to_latest = Fn.id\n end\n end]\n\n let to_display t : Display.t =\n let _, display =\n List.fold_left t ~init:(0, []) ~f:(fun (index, acc) bucket ->\n if List.is_empty bucket then (index + 1, acc)\n else (index + 1, (index, bucket) :: acc) )\n in\n display\n\n let empty = []\n\n let of_single_failure f : t = [ [ f ] ]\n\n let is_empty : t -> bool = Fn.compose List.is_empty List.concat\n end\n\n type failure = t\n\n let failure_min = min\n\n let failure_max = max\n\n let all =\n let add acc var = var.Variantslib.Variant.constructor :: acc in\n Variants.fold ~init:[] ~predicate:add ~source_not_present:add\n ~receiver_not_present:add ~amount_insufficient_to_create_account:add\n ~cannot_pay_creation_fee_in_token:add ~source_insufficient_balance:add\n ~source_minimum_balance_violation:add ~receiver_already_exists:add\n ~token_owner_not_caller:add ~overflow:add ~global_excess_overflow:add\n ~local_excess_overflow:add ~local_supply_increase_overflow:add\n ~global_supply_increase_overflow:add ~signed_command_on_zkapp_account:add\n ~zkapp_account_not_present:add ~update_not_permitted_balance:add\n ~update_not_permitted_timing:add ~update_not_permitted_access:add\n ~update_not_permitted_delegate:add ~update_not_permitted_app_state:add\n ~update_not_permitted_verification_key:add\n ~update_not_permitted_action_state:add ~update_not_permitted_zkapp_uri:add\n ~update_not_permitted_token_symbol:add\n ~update_not_permitted_permissions:add ~update_not_permitted_nonce:add\n ~update_not_permitted_voting_for:add\n ~zkapp_command_replay_check_failed:add ~fee_payer_nonce_must_increase:add\n ~fee_payer_must_be_signed:add\n ~account_balance_precondition_unsatisfied:add\n ~account_nonce_precondition_unsatisfied:add\n ~account_receipt_chain_hash_precondition_unsatisfied:add\n ~account_delegate_precondition_unsatisfied:add\n ~account_action_state_precondition_unsatisfied:add\n ~account_app_state_precondition_unsatisfied:(fun acc var ->\n List.init 8 ~f:var.constructor @ acc )\n ~account_proved_state_precondition_unsatisfied:add\n ~account_is_new_precondition_unsatisfied:add\n ~protocol_state_precondition_unsatisfied:add\n ~valid_while_precondition_unsatisfied:add\n ~unexpected_verification_key_hash:add ~incorrect_nonce:add\n ~invalid_fee_excess:add ~cancelled:add\n\n let gen = Quickcheck.Generator.of_list all\n\n let to_string = function\n | Predicate ->\n \"Predicate\"\n | Source_not_present ->\n \"Source_not_present\"\n | Receiver_not_present ->\n \"Receiver_not_present\"\n | Amount_insufficient_to_create_account ->\n \"Amount_insufficient_to_create_account\"\n | Cannot_pay_creation_fee_in_token ->\n \"Cannot_pay_creation_fee_in_token\"\n | Source_insufficient_balance ->\n \"Source_insufficient_balance\"\n | Source_minimum_balance_violation ->\n \"Source_minimum_balance_violation\"\n | Receiver_already_exists ->\n \"Receiver_already_exists\"\n | Token_owner_not_caller ->\n \"Token_owner_not_caller\"\n | Overflow ->\n \"Overflow\"\n | Global_excess_overflow ->\n \"Global_excess_overflow\"\n | Local_excess_overflow ->\n \"Local_excess_overflow\"\n | Local_supply_increase_overflow ->\n \"Local_supply_increase_overflow\"\n | Global_supply_increase_overflow ->\n \"Global_supply_increase_overflow\"\n | Signed_command_on_zkapp_account ->\n \"Signed_command_on_zkapp_account\"\n | Zkapp_account_not_present ->\n \"Zkapp_account_not_present\"\n | Update_not_permitted_balance ->\n \"Update_not_permitted_balance\"\n | Update_not_permitted_access ->\n \"Update_not_permitted_access\"\n | Update_not_permitted_timing ->\n \"Update_not_permitted_timing\"\n | Update_not_permitted_delegate ->\n \"update_not_permitted_delegate\"\n | Update_not_permitted_app_state ->\n \"Update_not_permitted_app_state\"\n | Update_not_permitted_verification_key ->\n \"Update_not_permitted_verification_key\"\n | Update_not_permitted_action_state ->\n \"Update_not_permitted_action_state\"\n | Update_not_permitted_zkapp_uri ->\n \"Update_not_permitted_zkapp_uri\"\n | Update_not_permitted_token_symbol ->\n \"Update_not_permitted_token_symbol\"\n | Update_not_permitted_permissions ->\n \"Update_not_permitted_permissions\"\n | Update_not_permitted_nonce ->\n \"Update_not_permitted_nonce\"\n | Update_not_permitted_voting_for ->\n \"Update_not_permitted_voting_for\"\n | Zkapp_command_replay_check_failed ->\n \"Zkapp_command_replay_check_failed\"\n | Fee_payer_nonce_must_increase ->\n \"Fee_payer_nonce_must_increase\"\n | Fee_payer_must_be_signed ->\n \"Fee_payer_must_be_signed\"\n | Account_balance_precondition_unsatisfied ->\n \"Account_balance_precondition_unsatisfied\"\n | Account_nonce_precondition_unsatisfied ->\n \"Account_nonce_precondition_unsatisfied\"\n | Account_receipt_chain_hash_precondition_unsatisfied ->\n \"Account_receipt_chain_hash_precondition_unsatisfied\"\n | Account_delegate_precondition_unsatisfied ->\n \"Account_delegate_precondition_unsatisfied\"\n | Account_action_state_precondition_unsatisfied ->\n \"Account_action_state_precondition_unsatisfied\"\n | Account_app_state_precondition_unsatisfied i ->\n sprintf \"Account_app_state_%i_precondition_unsatisfied\" i\n | Account_proved_state_precondition_unsatisfied ->\n \"Account_proved_state_precondition_unsatisfied\"\n | Account_is_new_precondition_unsatisfied ->\n \"Account_is_new_precondition_unsatisfied\"\n | Protocol_state_precondition_unsatisfied ->\n \"Protocol_state_precondition_unsatisfied\"\n | Valid_while_precondition_unsatisfied ->\n \"Valid_while_precondition_unsatisfied\"\n | Unexpected_verification_key_hash ->\n \"Unexpected_verification_key_hash\"\n | Incorrect_nonce ->\n \"Incorrect_nonce\"\n | Invalid_fee_excess ->\n \"Invalid_fee_excess\"\n | Cancelled ->\n \"Cancelled\"\n\n let of_string = function\n | \"Predicate\" ->\n Ok Predicate\n | \"Source_not_present\" ->\n Ok Source_not_present\n | \"Receiver_not_present\" ->\n Ok Receiver_not_present\n | \"Amount_insufficient_to_create_account\" ->\n Ok Amount_insufficient_to_create_account\n | \"Cannot_pay_creation_fee_in_token\" ->\n Ok Cannot_pay_creation_fee_in_token\n | \"Source_insufficient_balance\" ->\n Ok Source_insufficient_balance\n | \"Source_minimum_balance_violation\" ->\n Ok Source_minimum_balance_violation\n | \"Receiver_already_exists\" ->\n Ok Receiver_already_exists\n | \"Token_owner_not_caller\" ->\n Ok Token_owner_not_caller\n | \"Overflow\" ->\n Ok Overflow\n | \"Global_excess_overflow\" ->\n Ok Global_excess_overflow\n | \"Local_excess_overflow\" ->\n Ok Local_excess_overflow\n | \"Local_supply_increase_overflow\" ->\n Ok Local_supply_increase_overflow\n | \"Global_supply_increase_overflow\" ->\n Ok Global_supply_increase_overflow\n | \"Signed_command_on_zkapp_account\" ->\n Ok Signed_command_on_zkapp_account\n | \"Zkapp_account_not_present\" ->\n Ok Zkapp_account_not_present\n | \"Update_not_permitted_balance\" ->\n Ok Update_not_permitted_balance\n | \"Update_not_permitted_access\" ->\n Ok Update_not_permitted_access\n | \"Update_not_permitted_timing\" ->\n Ok Update_not_permitted_timing\n | \"update_not_permitted_delegate\" ->\n Ok Update_not_permitted_delegate\n | \"Update_not_permitted_app_state\" ->\n Ok Update_not_permitted_app_state\n | \"Update_not_permitted_verification_key\" ->\n Ok Update_not_permitted_verification_key\n | \"Update_not_permitted_action_state\" ->\n Ok Update_not_permitted_action_state\n | \"Update_not_permitted_zkapp_uri\" ->\n Ok Update_not_permitted_zkapp_uri\n | \"Update_not_permitted_token_symbol\" ->\n Ok Update_not_permitted_token_symbol\n | \"Update_not_permitted_permissions\" ->\n Ok Update_not_permitted_permissions\n | \"Update_not_permitted_nonce\" ->\n Ok Update_not_permitted_nonce\n | \"Update_not_permitted_voting_for\" ->\n Ok Update_not_permitted_voting_for\n | \"Zkapp_command_replay_check_failed\" ->\n Ok Zkapp_command_replay_check_failed\n | \"Fee_payer_nonce_must_increase\" ->\n Ok Fee_payer_nonce_must_increase\n | \"Fee_payer_must_be_signed\" ->\n Ok Fee_payer_must_be_signed\n | \"Account_balance_precondition_unsatisfied\" ->\n Ok Account_balance_precondition_unsatisfied\n | \"Account_nonce_precondition_unsatisfied\" ->\n Ok Account_nonce_precondition_unsatisfied\n | \"Account_receipt_chain_hash_precondition_unsatisfied\" ->\n Ok Account_receipt_chain_hash_precondition_unsatisfied\n | \"Account_delegate_precondition_unsatisfied\" ->\n Ok Account_delegate_precondition_unsatisfied\n | \"Account_action_state_precondition_unsatisfied\" ->\n Ok Account_action_state_precondition_unsatisfied\n | \"Account_proved_state_precondition_unsatisfied\" ->\n Ok Account_proved_state_precondition_unsatisfied\n | \"Account_is_new_precondition_unsatisfied\" ->\n Ok Account_is_new_precondition_unsatisfied\n | \"Protocol_state_precondition_unsatisfied\" ->\n Ok Protocol_state_precondition_unsatisfied\n | \"Valid_while_precondition_unsatisfied\" ->\n Ok Valid_while_precondition_unsatisfied\n | \"Unexpected_verification_key_hash\" ->\n Ok Unexpected_verification_key_hash\n | \"Incorrect_nonce\" ->\n Ok Incorrect_nonce\n | \"Invalid_fee_excess\" ->\n Ok Invalid_fee_excess\n | \"Cancelled\" ->\n Ok Cancelled\n | str -> (\n let res =\n List.find_map\n ~f:(fun (prefix, suffix, parse) ->\n Option.try_with (fun () ->\n assert (\n String.length str\n >= String.length prefix + String.length suffix ) ;\n for i = 0 to String.length prefix - 1 do\n assert (Char.equal prefix.[i] str.[i])\n done ;\n let offset = String.length str - String.length suffix in\n for i = 0 to String.length suffix - 1 do\n assert (Char.equal suffix.[i] str.[offset + i])\n done ;\n parse\n (String.sub str ~pos:(String.length prefix)\n ~len:(offset - String.length prefix) ) ) )\n [ ( \"Account_app_state_\"\n , \"_precondition_unsatisfied\"\n , fun str ->\n Account_app_state_precondition_unsatisfied (int_of_string str)\n )\n ]\n in\n match res with\n | Some res ->\n Ok res\n | None ->\n Error \"Transaction_status.Failure.of_string: Unknown value\" )\n\n let%test_unit \"of_string(to_string) roundtrip\" =\n List.iter all ~f:(fun failure ->\n [%test_eq: (t, string) Result.t]\n (of_string (to_string failure))\n (Ok failure) )\n\n let describe = function\n | Predicate ->\n \"A predicate failed\"\n | Source_not_present ->\n \"The source account does not exist\"\n | Receiver_not_present ->\n \"The receiver account does not exist\"\n | Amount_insufficient_to_create_account ->\n \"Cannot create account: transaction amount is smaller than the account \\\n creation fee\"\n | Cannot_pay_creation_fee_in_token ->\n \"Cannot create account: account creation fees cannot be paid in \\\n non-default tokens\"\n | Source_insufficient_balance ->\n \"The source account has an insufficient balance\"\n | Source_minimum_balance_violation ->\n \"The source account requires a minimum balance\"\n | Receiver_already_exists ->\n \"Attempted to create an account that already exists\"\n | Token_owner_not_caller ->\n \"An account update used a non-default token but its caller was not the \\\n token owner\"\n | Overflow ->\n \"The resulting balance is too large to store\"\n | Global_excess_overflow ->\n \"The resulting global fee excess is too large to store\"\n | Local_excess_overflow ->\n \"The resulting local fee excess is too large to store\"\n | Local_supply_increase_overflow ->\n \"The resulting local supply increase is too large to store\"\n | Global_supply_increase_overflow ->\n \"The resulting global supply increase is too large to store\"\n | Signed_command_on_zkapp_account ->\n \"The source of a signed command cannot be a snapp account\"\n | Zkapp_account_not_present ->\n \"A zkApp account does not exist\"\n | Update_not_permitted_balance ->\n \"The authentication for an account didn't allow the requested update \\\n to its balance\"\n | Update_not_permitted_access ->\n \"The authentication for an account didn't allow it to be accessed\"\n | Update_not_permitted_timing ->\n \"The authentication for an account didn't allow the requested update \\\n to its timing\"\n | Update_not_permitted_delegate ->\n \"The authentication for an account didn't allow the requested update \\\n to its delegate\"\n | Update_not_permitted_app_state ->\n \"The authentication for an account didn't allow the requested update \\\n to its app state\"\n | Update_not_permitted_verification_key ->\n \"The authentication for an account didn't allow the requested update \\\n to its verification key\"\n | Update_not_permitted_action_state ->\n \"The authentication for an account didn't allow the requested update \\\n to its action state\"\n | Update_not_permitted_zkapp_uri ->\n \"The authentication for an account didn't allow the requested update \\\n to its snapp URI\"\n | Update_not_permitted_token_symbol ->\n \"The authentication for an account didn't allow the requested update \\\n to its token symbol\"\n | Update_not_permitted_permissions ->\n \"The authentication for an account didn't allow the requested update \\\n to its permissions\"\n | Update_not_permitted_nonce ->\n \"The authentication for an account didn't allow the requested update \\\n to its nonce\"\n | Update_not_permitted_voting_for ->\n \"The authentication for an account didn't allow the requested update \\\n to its voted-for state hash\"\n | Zkapp_command_replay_check_failed ->\n \"Check to avoid replays failed. The account update must increment \\\n nonce or use full commitment if the authorization is a signature\"\n | Fee_payer_nonce_must_increase ->\n \"Fee payer account update must increment its nonce\"\n | Fee_payer_must_be_signed ->\n \"Fee payer account update must have a valid signature\"\n | Account_balance_precondition_unsatisfied ->\n \"The account update's account balance precondition was unsatisfied\"\n | Account_nonce_precondition_unsatisfied ->\n \"The account update's account nonce precondition was unsatisfied\"\n | Account_receipt_chain_hash_precondition_unsatisfied ->\n \"The account update's account receipt-chain hash precondition was \\\n unsatisfied\"\n | Account_delegate_precondition_unsatisfied ->\n \"The account update's account delegate precondition was unsatisfied\"\n | Account_action_state_precondition_unsatisfied ->\n \"The account update's account action state precondition was unsatisfied\"\n | Account_app_state_precondition_unsatisfied i ->\n sprintf\n \"The account update's account app state (%i) precondition was \\\n unsatisfied\"\n i\n | Account_proved_state_precondition_unsatisfied ->\n \"The account update's account proved state precondition was unsatisfied\"\n | Account_is_new_precondition_unsatisfied ->\n \"The account update's account is-new state precondition was unsatisfied\"\n | Protocol_state_precondition_unsatisfied ->\n \"The account update's protocol state precondition unsatisfied\"\n | Valid_while_precondition_unsatisfied ->\n \"The account update's valid-until precondition was unsatisfied\"\n | Unexpected_verification_key_hash ->\n \"The account update's verification key hash does not match the \\\n verification key in the ledger account\"\n | Incorrect_nonce ->\n \"Incorrect nonce\"\n | Invalid_fee_excess ->\n \"Fee excess from zkapp_command transaction more than the transaction \\\n fees\"\n | Cancelled ->\n \"The account update is cancelled because there's a failure in the \\\n zkApp transaction\"\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Transaction_status.V2.t =\n | Applied\n | Failed of Failure.Collection.Stable.V1.t\n [@@deriving sexp, yojson, equal, compare]\n\n let to_latest = Fn.id\n end\nend]\n","(* transaction_union_tag.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%else]\n\nopen Mina_base_import\n\n[%%endif]\n\ntype t = Payment | Stake_delegation | Fee_transfer | Coinbase\n[@@deriving enum, equal, sexp]\n\nlet to_string = function\n | Payment ->\n \"payment\"\n | Stake_delegation ->\n \"delegation\"\n | Fee_transfer ->\n \"fee-transfer\"\n | Coinbase ->\n \"coinbase\"\n\nlet gen =\n Quickcheck.Generator.map (Int.gen_incl min max) ~f:(fun i ->\n Option.value_exn (of_enum i) )\n\nmodule Bits = struct\n type t = bool * bool * bool [@@deriving equal]\n\n let of_int i : t =\n let test_mask mask = i land mask = mask in\n (test_mask 0b100, test_mask 0b10, test_mask 0b1)\n\n let of_t x = of_int (to_enum x)\n\n let payment = of_t Payment\n\n let stake_delegation = of_t Stake_delegation\n\n let fee_transfer = of_t Fee_transfer\n\n let coinbase = of_t Coinbase\n\n let to_bits (b1, b2, b3) = [ b1; b2; b3 ]\n\n let to_input_legacy t = Random_oracle.Input.Legacy.bitstring (to_bits t)\n\n [%%ifdef consensus_mechanism]\n\n type var = Boolean.var * Boolean.var * Boolean.var\n\n let typ = Typ.tuple3 Boolean.typ Boolean.typ Boolean.typ\n\n let constant (b1, b2, b3) =\n Boolean.(var_of_value b1, var_of_value b2, var_of_value b3)\n\n [%%endif]\nend\n\nmodule Unpacked = struct\n (* Invariant: exactly one of the tag identifiers must be true. *)\n module Poly = struct\n type 'bool t =\n { is_payment : 'bool\n ; is_stake_delegation : 'bool\n ; is_fee_transfer : 'bool\n ; is_coinbase : 'bool\n ; is_user_command : 'bool\n }\n [@@deriving equal, hlist]\n\n [%%ifdef consensus_mechanism]\n\n let typ (bool : ('bool_var, 'bool) Typ.t) : ('bool_var t, 'bool t) Typ.t =\n Typ.of_hlistable\n [ bool; bool; bool; bool; bool ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n [%%endif]\n end\n\n type t = bool Poly.t [@@deriving equal]\n\n (* An invalid value with all types empty. Do not use directly. *)\n let empty : t =\n { is_payment = false\n ; is_stake_delegation = false\n ; is_fee_transfer = false\n ; is_coinbase = false\n ; is_user_command = false\n }\n\n let payment = { empty with is_payment = true; is_user_command = true }\n\n let stake_delegation =\n { empty with is_stake_delegation = true; is_user_command = true }\n\n let fee_transfer =\n { empty with is_fee_transfer = true; is_user_command = false }\n\n let coinbase = { empty with is_coinbase = true; is_user_command = false }\n\n let of_bits_t (bits : Bits.t) : t =\n match\n List.Assoc.find ~equal:Bits.equal\n [ (Bits.payment, payment)\n ; (Bits.stake_delegation, stake_delegation)\n ; (Bits.fee_transfer, fee_transfer)\n ; (Bits.coinbase, coinbase)\n ]\n bits\n with\n | Some t ->\n t\n | None ->\n raise (Invalid_argument \"Transaction_union_tag.Unpacked.of_bits_t\")\n\n let to_bits_t (t : t) : Bits.t =\n match\n List.Assoc.find ~equal\n [ (payment, Bits.payment)\n ; (stake_delegation, Bits.stake_delegation)\n ; (fee_transfer, Bits.fee_transfer)\n ; (coinbase, Bits.coinbase)\n ]\n t\n with\n | Some bits ->\n bits\n | None ->\n raise (Invalid_argument \"Transaction_union_tag.Unpacked.to_bits_t\")\n\n [%%ifdef consensus_mechanism]\n\n type var = Boolean.var Poly.t\n\n let to_bits_var\n ({ is_payment\n ; is_stake_delegation\n ; is_fee_transfer\n ; is_coinbase\n ; is_user_command = _\n } :\n var ) =\n (* For each bit, compute the sum of all the tags for which that bit is true\n in its bit representation.\n\n Since we have the invariant that exactly one tag identifier is true,\n exactly the bits in that tag's bit representation will be true in the\n resulting bits.\n *)\n let b1, b2, b3 =\n List.fold\n ~init:Field.(Var.(constant zero, constant zero, constant zero))\n [ (Bits.payment, is_payment)\n ; (Bits.stake_delegation, is_stake_delegation)\n ; (Bits.fee_transfer, is_fee_transfer)\n ; (Bits.coinbase, is_coinbase)\n ]\n ~f:(fun (acc1, acc2, acc3) ((bit1, bit2, bit3), bool_var) ->\n let add_if_true bit acc =\n if bit then Field.Var.add acc (bool_var :> Field.Var.t) else acc\n in\n (add_if_true bit1 acc1, add_if_true bit2 acc2, add_if_true bit3 acc3)\n )\n in\n Boolean.Unsafe.(of_cvar b1, of_cvar b2, of_cvar b3)\n\n let typ : (var, t) Typ.t =\n let (Typ base_typ) = Poly.typ Boolean.typ in\n Typ\n { base_typ with\n check =\n (fun ( { is_payment\n ; is_stake_delegation\n ; is_fee_transfer\n ; is_coinbase\n ; is_user_command\n } as t ) ->\n let open Checked.Let_syntax in\n let%bind () = base_typ.check t in\n let%bind () =\n [%with_label_ \"Only one tag is set\"] (fun () ->\n Boolean.Assert.exactly_one\n [ is_payment\n ; is_stake_delegation\n ; is_fee_transfer\n ; is_coinbase\n ] )\n in\n [%with_label_ \"User command flag is correctly set\"] (fun () ->\n Boolean.Assert.exactly_one\n [ is_user_command; is_fee_transfer; is_coinbase ] ) )\n }\n\n let constant\n ({ is_payment\n ; is_stake_delegation\n ; is_fee_transfer\n ; is_coinbase\n ; is_user_command\n } :\n t ) : var =\n { is_payment = Boolean.var_of_value is_payment\n ; is_stake_delegation = Boolean.var_of_value is_stake_delegation\n ; is_fee_transfer = Boolean.var_of_value is_fee_transfer\n ; is_coinbase = Boolean.var_of_value is_coinbase\n ; is_user_command = Boolean.var_of_value is_user_command\n }\n\n let is_payment ({ is_payment; _ } : var) = is_payment\n\n let is_stake_delegation ({ is_stake_delegation; _ } : var) =\n is_stake_delegation\n\n let is_fee_transfer ({ is_fee_transfer; _ } : var) = is_fee_transfer\n\n let is_coinbase ({ is_coinbase; _ } : var) = is_coinbase\n\n let is_user_command ({ is_user_command; _ } : var) = is_user_command\n\n let to_bits t = Bits.to_bits (to_bits_var t)\n\n let to_input_legacy t = Random_oracle.Input.Legacy.bitstring (to_bits t)\n\n [%%endif]\nend\n\nlet unpacked_t_of_t = function\n | Payment ->\n Unpacked.payment\n | Stake_delegation ->\n Unpacked.stake_delegation\n | Fee_transfer ->\n Unpacked.fee_transfer\n | Coinbase ->\n Unpacked.coinbase\n\nlet to_bits tag = Bits.to_bits (Unpacked.to_bits_t (unpacked_t_of_t tag))\n\nlet to_input_legacy tag = Random_oracle.Input.Legacy.bitstring (to_bits tag)\n\n[%%ifdef consensus_mechanism]\n\nlet t_of_unpacked_t (unpacked : Unpacked.t) : t =\n match\n List.Assoc.find ~equal:Unpacked.equal\n [ (Unpacked.payment, Payment)\n ; (Unpacked.stake_delegation, Stake_delegation)\n ; (Unpacked.fee_transfer, Fee_transfer)\n ; (Unpacked.coinbase, Coinbase)\n ]\n unpacked\n with\n | Some t ->\n t\n | None ->\n raise (Invalid_argument \"Transaction_union_tag.t_of_unpacked_t\")\n\nlet bits_t_of_t tag = Unpacked.to_bits_t (unpacked_t_of_t tag)\n\nlet t_of_bits_t tag = t_of_unpacked_t (Unpacked.of_bits_t tag)\n\nlet unpacked_of_t tag = Unpacked.constant (unpacked_t_of_t tag)\n\nlet bits_of_t tag = Bits.constant (bits_t_of_t tag)\n\nlet unpacked_typ =\n Typ.transport Unpacked.typ ~there:unpacked_t_of_t ~back:t_of_unpacked_t\n\nlet bits_typ = Typ.transport Bits.typ ~there:bits_t_of_t ~back:t_of_bits_t\n\nlet%test_module \"predicates\" =\n ( module struct\n let test_predicate checked unchecked =\n let checked x = Checked.return (checked x) in\n for i = min to max do\n Test_util.test_equal unpacked_typ Boolean.typ checked unchecked\n (Option.value_exn (of_enum i))\n done\n\n let one_of xs t = List.mem xs ~equal t\n\n let%test_unit \"is_payment\" =\n test_predicate Unpacked.is_payment (equal Payment)\n\n let%test_unit \"is_stake_delegation\" =\n test_predicate Unpacked.is_stake_delegation (equal Stake_delegation)\n\n let%test_unit \"is_fee_transfer\" =\n test_predicate Unpacked.is_fee_transfer (equal Fee_transfer)\n\n let%test_unit \"is_coinbase\" =\n test_predicate Unpacked.is_coinbase (equal Coinbase)\n\n let%test_unit \"is_user_command\" =\n test_predicate Unpacked.is_user_command\n (one_of [ Payment; Stake_delegation ])\n\n let%test_unit \"not_user_command\" =\n test_predicate\n (fun x -> Boolean.not (Unpacked.is_user_command x))\n (one_of [ Fee_transfer; Coinbase ])\n\n let%test_unit \"bit_representation\" =\n for i = min to max do\n Test_util.test_equal unpacked_typ Bits.typ\n (Fn.compose Checked.return Unpacked.to_bits_var)\n bits_t_of_t\n (Option.value_exn (of_enum i))\n done\n end )\n\n[%%endif]\n","(* user_command_payload.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\nopen Signature_lib\nmodule Memo = Signed_command_memo\nmodule Account_nonce = Mina_numbers.Account_nonce\nmodule Global_slot_since_genesis = Mina_numbers.Global_slot_since_genesis\nmodule Global_slot_legacy = Mina_numbers.Global_slot_legacy\n\n(* This represents the random oracle input corresponding to the old form of the token\n ID, which was a 64-bit integer. The default token id was the number 1.\n\n The corresponding random oracle input is still needed for signing non-snapp\n transactions to maintain compatibility with the old transaction format.\n*)\nmodule Legacy_token_id = struct\n let default : (Field.t, bool) Random_oracle_input.Legacy.t =\n let one = true :: List.init 63 ~f:(fun _ -> false) in\n Random_oracle_input.Legacy.bitstring one\n\n [%%ifdef consensus_mechanism]\n\n let default_checked : (Field.Var.t, Boolean.var) Random_oracle_input.Legacy.t\n =\n { field_elements = Array.map default.field_elements ~f:Field.Var.constant\n ; bitstrings =\n Array.map default.bitstrings ~f:(List.map ~f:Boolean.var_of_value)\n }\n\n [%%endif]\nend\n\nmodule Common = struct\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('fee, 'public_key, 'nonce, 'global_slot, 'memo) t =\n ( 'fee\n , 'public_key\n , 'nonce\n , 'global_slot\n , 'memo )\n Mina_wire_types.Mina_base.Signed_command_payload.Common.Poly.V2.t =\n { fee : 'fee\n ; fee_payer_pk : 'public_key\n ; nonce : 'nonce\n ; valid_until : 'global_slot\n ; memo : 'memo\n }\n [@@deriving compare, equal, sexp, hash, yojson, hlist]\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('fee, 'public_key, 'token_id, 'nonce, 'global_slot, 'memo) t =\n { fee : 'fee\n ; fee_token : 'token_id\n ; fee_payer_pk : 'public_key\n ; nonce : 'nonce\n ; valid_until : 'global_slot\n ; memo : 'memo\n }\n [@@deriving compare, equal, sexp, hash, yojson, hlist]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Currency.Fee.Stable.V1.t\n , Public_key.Compressed.Stable.V1.t\n , Account_nonce.Stable.V1.t\n , Global_slot_since_genesis.Stable.V1.t\n , Memo.Stable.V1.t )\n Poly.Stable.V2.t\n [@@deriving compare, equal, sexp, hash, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t =\n ( Currency.Fee.Stable.V1.t\n , Public_key.Compressed.Stable.V1.t\n , Token_id.Stable.V1.t\n , Account_nonce.Stable.V1.t\n , Global_slot_legacy.Stable.V1.t\n , Memo.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving compare, equal, sexp, hash, yojson]\n\n let to_latest _ = failwith \"Not implemented\"\n end\n end]\n\n let to_input_legacy ({ fee; fee_payer_pk; nonce; valid_until; memo } : t) =\n let bitstring = Random_oracle.Input.Legacy.bitstring in\n Array.reduce_exn ~f:Random_oracle.Input.Legacy.append\n [| Currency.Fee.to_input_legacy fee\n ; Legacy_token_id.default\n ; Public_key.Compressed.to_input_legacy fee_payer_pk\n ; Account_nonce.to_input_legacy nonce\n ; Global_slot_since_genesis.to_input_legacy valid_until\n ; bitstring (Memo.to_bits memo)\n |]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map fee = Currency.Fee.gen\n and fee_payer_pk = Public_key.Compressed.gen\n and nonce = Account_nonce.gen\n and valid_until = Global_slot_since_genesis.gen\n and memo =\n let%bind is_digest = Bool.quickcheck_generator in\n if is_digest then\n String.gen_with_length Memo.max_digestible_string_length\n Char.quickcheck_generator\n >>| Memo.create_by_digesting_string_exn\n else\n String.gen_with_length Memo.max_input_length Char.quickcheck_generator\n >>| Memo.create_from_string_exn\n in\n Poly.{ fee; fee_payer_pk; nonce; valid_until; memo }\n\n [%%ifdef consensus_mechanism]\n\n type var =\n ( Currency.Fee.var\n , Public_key.Compressed.var\n , Account_nonce.Checked.t\n , Global_slot_since_genesis.Checked.t\n , Memo.Checked.t )\n Poly.t\n\n let typ =\n Typ.of_hlistable\n [ Currency.Fee.typ\n ; Public_key.Compressed.typ\n ; Account_nonce.typ\n ; Global_slot_since_genesis.typ\n ; Memo.typ\n ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\n module Checked = struct\n let constant ({ fee; fee_payer_pk; nonce; valid_until; memo } : t) : var =\n { fee = Currency.Fee.var_of_t fee\n ; fee_payer_pk = Public_key.Compressed.var_of_t fee_payer_pk\n ; nonce = Account_nonce.Checked.constant nonce\n ; memo = Memo.Checked.constant memo\n ; valid_until = Global_slot_since_genesis.Checked.constant valid_until\n }\n\n let to_input_legacy ({ fee; fee_payer_pk; nonce; valid_until; memo } : var)\n =\n let%map nonce = Account_nonce.Checked.to_input_legacy nonce\n and valid_until =\n Global_slot_since_genesis.Checked.to_input_legacy valid_until\n and fee = Currency.Fee.var_to_input_legacy fee in\n let fee_token = Legacy_token_id.default_checked in\n Array.reduce_exn ~f:Random_oracle.Input.Legacy.append\n [| fee\n ; fee_token\n ; Public_key.Compressed.Checked.to_input_legacy fee_payer_pk\n ; nonce\n ; valid_until\n ; Random_oracle.Input.Legacy.bitstring\n (Array.to_list (memo :> Boolean.var array))\n |]\n end\n\n [%%endif]\nend\n\nmodule Body = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Signed_command_payload.Body.V2.t =\n | Payment of Payment_payload.Stable.V2.t\n | Stake_delegation of Stake_delegation.Stable.V2.t\n [@@deriving sexp, compare, equal, sexp, hash, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t =\n | Payment of Payment_payload.Stable.V1.t\n | Stake_delegation of Stake_delegation.Stable.V1.t\n (* omitting token commands, none were ever created\n such omission doesn't affect serialization/Base58Check of payments, delegations\n *)\n [@@deriving sexp, compare, equal, sexp, hash, yojson]\n\n let to_latest _ = failwith \"Not implemented\"\n end\n end]\n\n module Tag = Transaction_union_tag\n\n let gen max_amount =\n let open Quickcheck.Generator in\n map\n (variant2 (Payment_payload.gen max_amount) Stake_delegation.gen)\n ~f:(function `A p -> Payment p | `B d -> Stake_delegation d)\n\n let receiver_pk (t : t) =\n match t with\n | Payment payload ->\n payload.receiver_pk\n | Stake_delegation payload ->\n Stake_delegation.receiver_pk payload\n\n let token (_ : t) = Token_id.default\n\n let receiver t =\n match t with\n | Payment payload ->\n Account_id.create payload.receiver_pk Token_id.default\n | Stake_delegation payload ->\n Stake_delegation.receiver payload\n\n let tag = function\n | Payment _ ->\n Transaction_union_tag.Payment\n | Stake_delegation _ ->\n Transaction_union_tag.Stake_delegation\nend\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('common, 'body) t =\n ( 'common\n , 'body )\n Mina_wire_types.Mina_base.Signed_command_payload.Poly.V1.t =\n { common : 'common; body : 'body }\n [@@deriving equal, sexp, hash, yojson, compare, hlist]\n\n let of_latest common_latest body_latest { common; body } =\n let open Result.Let_syntax in\n let%map common = common_latest common and body = body_latest body in\n { common; body }\n end\n end]\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = (Common.Stable.V2.t, Body.Stable.V2.t) Poly.Stable.V1.t\n [@@deriving compare, equal, sexp, hash, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = (Common.Stable.V1.t, Body.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving compare, equal, sexp, hash, yojson]\n\n (* don't need to coerce old transactions to newer version *)\n let to_latest _ = failwith \"Not implemented\"\n end\nend]\n\nlet create ~fee ~fee_payer_pk ~nonce ~valid_until ~memo ~body : t =\n { common =\n { fee\n ; fee_payer_pk\n ; nonce\n ; valid_until =\n Option.value valid_until ~default:Global_slot_since_genesis.max_value\n ; memo\n }\n ; body\n }\n\nlet fee (t : t) = t.common.fee\n\nlet fee_token (_ : t) = Token_id.default\n\nlet fee_payer_pk (t : t) = t.common.fee_payer_pk\n\nlet fee_payer (t : t) = Account_id.create t.common.fee_payer_pk Token_id.default\n\nlet nonce (t : t) = t.common.nonce\n\nlet valid_until (t : t) = t.common.valid_until\n\nlet memo (t : t) = t.common.memo\n\nlet body (t : t) = t.body\n\nlet receiver_pk (t : t) = Body.receiver_pk t.body\n\nlet receiver (t : t) = Body.receiver t.body\n\nlet token (t : t) = Body.token t.body\n\nlet tag (t : t) = Body.tag t.body\n\nlet amount (t : t) =\n match t.body with\n | Payment payload ->\n Some payload.Payment_payload.Poly.amount\n | Stake_delegation _ ->\n None\n\nlet fee_excess (t : t) =\n Fee_excess.of_single (fee_token t, Currency.Fee.Signed.of_unsigned (fee t))\n\nlet account_access_statuses (t : t) (status : Transaction_status.t) =\n match status with\n | Applied ->\n List.map\n [ fee_payer t; receiver t ]\n ~f:(fun acct_id -> (acct_id, `Accessed))\n | Failed _ ->\n (fee_payer t, `Accessed)\n :: List.map [ receiver t ] ~f:(fun acct_id -> (acct_id, `Not_accessed))\n\nlet dummy : t =\n { common =\n { fee = Currency.Fee.zero\n ; fee_payer_pk = Public_key.Compressed.empty\n ; nonce = Account_nonce.zero\n ; valid_until = Global_slot_since_genesis.max_value\n ; memo = Memo.dummy\n }\n ; body = Payment Payment_payload.dummy\n }\n\nlet gen =\n let open Quickcheck.Generator.Let_syntax in\n let%bind common = Common.gen in\n let max_amount =\n Currency.Amount.(sub max_int (of_fee common.fee))\n |> Option.value_exn ?here:None ?error:None ?message:None\n in\n let%map body = Body.gen max_amount in\n Poly.{ common; body }\n\n(** This module defines a weight for each payload component *)\nmodule Weight = struct\n let payment (_payment_payload : Payment_payload.t) : int = 1\n\n let stake_delegation (_stake_delegation : Stake_delegation.t) : int = 1\n\n let of_body : Body.t -> int = function\n | Payment payment_payload ->\n payment payment_payload\n | Stake_delegation stake_delegation_payload ->\n stake_delegation stake_delegation_payload\nend\n\nlet weight (signed_command_payload : t) : int =\n body signed_command_payload |> Weight.of_body\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_import\nopen Mina_numbers\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Signed_command\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Signed_command_intf.Full\n with type With_valid_signature.Stable.Latest.t =\n A.With_valid_signature.V2.t\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n module Fee = Currency.Fee\n module Payload = Signed_command_payload\n\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('payload, 'pk, 'signature) t =\n ( 'payload\n , 'pk\n , 'signature )\n Mina_wire_types.Mina_base.Signed_command.Poly.V1.t =\n { payload : 'payload; signer : 'pk; signature : 'signature }\n [@@deriving compare, sexp, hash, yojson, equal]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n [@@@with_top_version_tag]\n\n (* DO NOT DELETE VERSIONS!\n so we can always get transaction hashes from old transaction ids\n the version linter should be checking this\n\n IF YOU CREATE A NEW VERSION:\n update Transaction_hash.hash_of_transaction_id to handle it\n add hash_signed_command_vn for that version\n *)\n\n module V2 = struct\n type t =\n ( Payload.Stable.V2.t\n , Public_key.Stable.V1.t\n , Signature.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving compare, sexp, hash, yojson]\n\n let to_latest = Fn.id\n\n module T = struct\n (* can't use nonrec + deriving *)\n type typ = t [@@deriving compare, sexp, hash]\n\n type t = typ [@@deriving compare, sexp, hash]\n end\n\n include Comparable.Make (T)\n include Hashable.Make (T)\n\n let account_access_statuses ({ payload; _ } : t) status =\n Payload.account_access_statuses payload status\n\n let accounts_referenced (t : t) =\n List.map (account_access_statuses t Applied)\n ~f:(fun (acct_id, _status) -> acct_id)\n end\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t =\n ( Payload.Stable.V1.t\n , Public_key.Stable.V1.t\n , Signature.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving compare, sexp, hash, yojson]\n\n let to_latest ({ payload; signer; signature } : t) : Latest.t =\n let payload : Signed_command_payload.t =\n let valid_until =\n Global_slot_legacy.to_uint32 payload.common.valid_until\n |> Global_slot_since_genesis.of_uint32\n in\n let common : Signed_command_payload.Common.t =\n { fee = payload.common.fee\n ; fee_payer_pk = payload.common.fee_payer_pk\n ; nonce = payload.common.nonce\n ; valid_until\n ; memo = payload.common.memo\n }\n in\n let body : Signed_command_payload.Body.t =\n match payload.body with\n | Payment payment_payload ->\n let payload' : Payment_payload.t =\n { receiver_pk = payment_payload.receiver_pk\n ; amount = payment_payload.amount\n }\n in\n Payment payload'\n | Stake_delegation stake_delegation_payload ->\n Stake_delegation\n (Stake_delegation.Stable.V1.to_latest stake_delegation_payload)\n in\n { common; body }\n in\n { payload; signer; signature }\n end\n end]\n\n (* type of signed commands, pre-Berkeley hard fork *)\n type t_v1 = Stable.V1.t\n\n let (_ : (t, (Payload.t, Public_key.t, Signature.t) Poly.t) Type_equal.t) =\n Type_equal.T\n\n include (Stable.Latest : module type of Stable.Latest with type t := t)\n\n let signature Poly.{ signature; _ } = signature\n\n let payload Poly.{ payload; _ } = payload\n\n let fee = Fn.compose Payload.fee payload\n\n let nonce = Fn.compose Payload.nonce payload\n\n (* for filtering *)\n let minimum_fee = Currency.Fee.minimum_user_command_fee\n\n let has_insufficient_fee t = Currency.Fee.(fee t < minimum_fee)\n\n let signer { Poly.signer; _ } = signer\n\n let fee_token (_ : t) = Token_id.default\n\n let fee_payer_pk ({ payload; _ } : t) = Payload.fee_payer_pk payload\n\n let fee_payer ({ payload; _ } : t) = Payload.fee_payer payload\n\n let fee_excess ({ payload; _ } : t) = Payload.fee_excess payload\n\n let token ({ payload; _ } : t) = Payload.token payload\n\n let receiver_pk ({ payload; _ } : t) = Payload.receiver_pk payload\n\n let receiver ({ payload; _ } : t) = Payload.receiver payload\n\n let amount = Fn.compose Payload.amount payload\n\n let memo = Fn.compose Payload.memo payload\n\n let valid_until = Fn.compose Payload.valid_until payload\n\n let tag ({ payload; _ } : t) = Payload.tag payload\n\n let tag_string (t : t) =\n match t.payload.body with\n | Payment _ ->\n \"payment\"\n | Stake_delegation _ ->\n \"delegation\"\n\n let to_input_legacy (payload : Payload.t) =\n Transaction_union_payload.(\n to_input_legacy (of_user_command_payload payload))\n\n let sign_payload ?signature_kind (private_key : Signature_lib.Private_key.t)\n (payload : Payload.t) : Signature.t =\n Signature_lib.Schnorr.Legacy.sign ?signature_kind private_key\n (to_input_legacy payload)\n\n let sign ?signature_kind (kp : Signature_keypair.t) (payload : Payload.t) : t\n =\n { payload\n ; signer = kp.public_key\n ; signature = sign_payload ?signature_kind kp.private_key payload\n }\n\n module For_tests = struct\n (* Pretend to sign a command. Much faster than actually signing. *)\n let fake_sign ?signature_kind:_ (kp : Signature_keypair.t)\n (payload : Payload.t) : t =\n { payload; signer = kp.public_key; signature = Signature.dummy }\n end\n\n module Gen = struct\n let gen_inner (sign' : Signature_lib.Keypair.t -> Payload.t -> t) ~key_gen\n ?(nonce = Account_nonce.zero) ~fee_range create_body =\n let open Quickcheck.Generator.Let_syntax in\n let min_fee = Fee.to_nanomina_int Currency.Fee.minimum_user_command_fee in\n let max_fee = min_fee + fee_range in\n let%bind (signer : Signature_keypair.t), (receiver : Signature_keypair.t)\n =\n key_gen\n and fee =\n Int.gen_incl min_fee max_fee >>| Currency.Fee.of_nanomina_int_exn\n and memo = String.quickcheck_generator in\n let%map body = create_body signer receiver in\n let payload : Payload.t =\n Payload.create ~fee\n ~fee_payer_pk:(Public_key.compress signer.public_key)\n ~nonce ~valid_until:None\n ~memo:(Signed_command_memo.create_by_digesting_string_exn memo)\n ~body\n in\n sign' signer payload\n\n let with_random_participants ~keys ~gen =\n let key_gen = Quickcheck_lib.gen_pair @@ Quickcheck_lib.of_array keys in\n gen ~key_gen\n\n module Payment = struct\n let gen_inner (sign' : Signature_lib.Keypair.t -> Payload.t -> t) ~key_gen\n ?nonce ?(min_amount = 1) ~max_amount ~fee_range () =\n gen_inner sign' ~key_gen ?nonce ~fee_range\n @@ fun { public_key = signer; _ } { public_key = receiver; _ } ->\n let open Quickcheck.Generator.Let_syntax in\n let%map amount =\n Int.gen_incl min_amount max_amount\n >>| Currency.Amount.of_nanomina_int_exn\n in\n Signed_command_payload.Body.Payment\n { receiver_pk = Public_key.compress receiver; amount }\n\n let gen ?(sign_type = `Fake) =\n match sign_type with\n | `Fake ->\n gen_inner For_tests.fake_sign\n | `Real ->\n gen_inner sign\n\n let gen_with_random_participants ?sign_type ~keys ?nonce ?min_amount\n ~max_amount ~fee_range =\n with_random_participants ~keys ~gen:(fun ~key_gen ->\n gen ?sign_type ~key_gen ?nonce ?min_amount ~max_amount ~fee_range )\n end\n\n module Stake_delegation = struct\n let gen ~key_gen ?nonce ~fee_range () =\n gen_inner For_tests.fake_sign ~key_gen ?nonce ~fee_range\n (fun { public_key = signer; _ } { public_key = new_delegate; _ } ->\n Quickcheck.Generator.return\n @@ Signed_command_payload.Body.Stake_delegation\n (Set_delegate\n { new_delegate = Public_key.compress new_delegate } ) )\n\n let gen_with_random_participants ~keys ?nonce ~fee_range =\n with_random_participants ~keys ~gen:(gen ?nonce ~fee_range)\n end\n\n let payment = Payment.gen\n\n let payment_with_random_participants = Payment.gen_with_random_participants\n\n let stake_delegation = Stake_delegation.gen\n\n let stake_delegation_with_random_participants =\n Stake_delegation.gen_with_random_participants\n\n let sequence :\n ?length:int\n -> ?sign_type:[ `Fake | `Real ]\n -> ( Signature_lib.Keypair.t\n * Currency.Amount.t\n * Mina_numbers.Account_nonce.t\n * Account_timing.t )\n array\n -> t list Quickcheck.Generator.t =\n fun ?length ?(sign_type = `Fake) account_info ->\n let open Quickcheck.Generator in\n let open Quickcheck.Generator.Let_syntax in\n let%bind n_commands =\n Option.value_map length ~default:small_non_negative_int ~f:return\n in\n if Int.(n_commands = 0) then return []\n else\n let n_accounts = Array.length account_info in\n let%bind command_senders, currency_splits =\n (* How many commands will be issued from each account? *)\n (let%bind command_splits =\n Quickcheck_lib.gen_division n_commands n_accounts\n in\n let command_splits' = Array.of_list command_splits in\n (* List of payment senders in the final order. *)\n let%bind command_senders =\n Quickcheck_lib.shuffle\n @@ List.concat_mapi command_splits ~f:(fun idx cmds ->\n List.init cmds ~f:(Fn.const idx) )\n in\n (* within the accounts, how will the currency be split into separate\n payments? *)\n let%bind currency_splits =\n Quickcheck_lib.init_gen_array\n ~f:(fun i ->\n let%bind spend_all = bool in\n let _, balance, _, _ = account_info.(i) in\n let amount_to_spend =\n if spend_all then balance\n else\n Currency.Amount.of_nanomina_int_exn\n (Currency.Amount.to_nanomina_int balance / 2)\n in\n Quickcheck_lib.gen_division_currency amount_to_spend\n command_splits'.(i) )\n n_accounts\n in\n return (command_senders, currency_splits) )\n |> (* We need to ensure each command has enough currency for a fee of 2\n or more, so it'll be enough to buy the requisite transaction\n snarks. It's important that the backtracking from filter goes and\n redraws command_splits as well as currency_splits, so we don't get\n stuck in a situation where it's very unlikely for the predicate to\n pass. *)\n Quickcheck.Generator.filter ~f:(fun (_, splits) ->\n Array.for_all splits ~f:(fun split ->\n List.for_all split ~f:(fun amt ->\n Currency.Amount.(amt >= of_mina_int_exn 2) ) ) )\n in\n let account_nonces =\n Array.map ~f:(fun (_, _, nonce, _) -> nonce) account_info\n in\n let uncons_exn = function\n | [] ->\n failwith \"uncons_exn\"\n | x :: xs ->\n (x, xs)\n in\n Quickcheck_lib.map_gens command_senders ~f:(fun sender ->\n let this_split, rest_splits = uncons_exn currency_splits.(sender) in\n let sender_pk, _, _, _ = account_info.(sender) in\n currency_splits.(sender) <- rest_splits ;\n let nonce = account_nonces.(sender) in\n account_nonces.(sender) <- Account_nonce.succ nonce ;\n let%bind fee =\n (* use of_string here because json_of_ocaml won't handle\n equivalent integer constants\n *)\n Currency.Fee.(\n gen_incl (of_string \"6000000000\")\n (min (of_string \"10000000000\")\n (Currency.Amount.to_fee this_split) ))\n in\n let amount =\n Option.value_exn Currency.Amount.(this_split - of_fee fee)\n in\n let%bind receiver =\n map ~f:(fun idx ->\n let kp, _, _, _ = account_info.(idx) in\n Public_key.compress kp.public_key )\n @@ Int.gen_uniform_incl 0 (n_accounts - 1)\n in\n let memo = Signed_command_memo.dummy in\n let payload =\n let sender_pk = Public_key.compress sender_pk.public_key in\n Payload.create ~fee ~fee_payer_pk:sender_pk ~valid_until:None\n ~nonce ~memo\n ~body:(Payment { receiver_pk = receiver; amount })\n in\n let sign' =\n match sign_type with\n | `Fake ->\n For_tests.fake_sign\n | `Real ->\n sign\n in\n return @@ sign' sender_pk payload )\n end\n\n module With_valid_signature = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Stable.V2.t [@@deriving sexp, equal, yojson, hash]\n\n let to_latest = Stable.V2.to_latest\n\n let compare = Stable.V2.compare\n\n let equal = Stable.V2.equal\n\n module Gen = Gen\n end\n end]\n\n module Gen = Stable.Latest.Gen\n include Comparable.Make (Stable.Latest)\n end\n\n let to_valid_unsafe t =\n `If_this_is_used_it_should_have_a_comment_justifying_it t\n\n (* so we can deserialize Base58Check transaction ids created before Berkeley hard fork *)\n module V1_all_tagged = struct\n include Stable.V1.With_all_version_tags\n\n let description = \"Signed command\"\n\n let version_byte = Base58_check.Version_bytes.signed_command_v1\n end\n\n let of_base58_check_exn_v1, to_base58_check_v1 =\n let module Base58_check_v1 = Codable.Make_base58_check (V1_all_tagged) in\n Base58_check_v1.(of_base58_check, to_base58_check)\n\n (* give transaction ids have version tag *)\n include Codable.Make_base64 (Stable.Latest.With_top_version_tag)\n\n let check_signature ?signature_kind ({ payload; signer; signature } : t) =\n Signature_lib.Schnorr.Legacy.verify ?signature_kind signature\n (Snark_params.Tick.Inner_curve.of_affine signer)\n (to_input_legacy payload)\n\n let public_keys t =\n let fee_payer = fee_payer_pk t in\n let receiver = receiver_pk t in\n [ fee_payer; receiver ]\n\n let check_valid_keys t =\n List.for_all (public_keys t) ~f:(fun pk ->\n Option.is_some (Public_key.decompress pk) )\n\n let create_with_signature_checked ?signature_kind signature signer payload =\n let open Option.Let_syntax in\n let%bind signer = Public_key.decompress signer in\n let t = Poly.{ payload; signature; signer } in\n Option.some_if (check_signature ?signature_kind t && check_valid_keys t) t\n\n let gen_test =\n let open Quickcheck.Let_syntax in\n let%bind keys =\n Quickcheck.Generator.list_with_length 2 Signature_keypair.gen\n in\n Gen.payment_with_random_participants ~sign_type:`Real\n ~keys:(Array.of_list keys) ~max_amount:10000 ~fee_range:1000 ()\n\n let%test_unit \"completeness\" =\n Quickcheck.test ~trials:20 gen_test ~f:(fun t -> assert (check_signature t))\n\n let%test_unit \"json\" =\n Quickcheck.test ~trials:20 ~sexp_of:sexp_of_t gen_test ~f:(fun t ->\n assert (Codable.For_tests.check_encoding (module Stable.Latest) ~equal t) )\n\n (* return type is `t option` here, interface coerces that to `With_valid_signature.t option` *)\n let check t = Option.some_if (check_signature t && check_valid_keys t) t\n\n (* return type is `t option` here, interface coerces that to `With_valid_signature.t option` *)\n let check_only_for_signature t = Option.some_if (check_signature t) t\n\n let forget_check t = t\n\n let filter_by_participant user_commands public_key =\n List.filter user_commands ~f:(fun user_command ->\n Core_kernel.List.exists\n (accounts_referenced user_command)\n ~f:\n (Fn.compose\n (Public_key.Compressed.equal public_key)\n Account_id.public_key ) )\n\n let%test \"latest signed command version\" =\n (* if this test fails, update `Transaction_hash.hash_of_transaction_id`\n for latest version, then update this test\n *)\n Int.equal Stable.Latest.version 2\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","(* receipt.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nmodule B58_lib = Base58_check\nopen Snark_params.Tick\n\nmodule Signed_command_elt = struct\n type t = Signed_command_payload of Signed_command.Payload.t\nend\n\nmodule Zkapp_command_elt = struct\n type t = Zkapp_command_commitment of Random_oracle.Digest.t\nend\n\nmodule Chain_hash = struct\n include Data_hash.Make_full_size (struct\n let description = \"Receipt chain hash\"\n\n let version_byte = Base58_check.Version_bytes.receipt_chain_hash\n end)\n\n (* Data hash versioned boilerplate below *)\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\n end]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n let equal = Stable.Latest.equal\n\n let empty =\n of_hash (Hash_prefix_create.salt \"CodaReceiptEmpty\" |> Random_oracle.digest)\n\n let cons_signed_command_payload (e : Signed_command_elt.t) (t : t) =\n let open Random_oracle.Legacy in\n let x =\n match e with\n | Signed_command_payload payload ->\n Transaction_union_payload.(\n to_input_legacy (of_user_command_payload payload))\n in\n Input.(append x (field (t :> Field.t)))\n |> pack_input\n |> hash ~init:Hash_prefix.receipt_chain_signed_command\n |> of_hash\n\n (* prepend account_update index computed by Zkapp_command_logic.apply *)\n let cons_zkapp_command_commitment (index : Mina_numbers.Index.t)\n (e : Zkapp_command_elt.t) (t : t) =\n let open Random_oracle in\n let x =\n match e with Zkapp_command_commitment s -> Input.Chunked.field s\n in\n let index_input = Mina_numbers.Index.to_input index in\n Input.Chunked.(append index_input (append x (field (t :> Field.t))))\n |> pack_input\n |> hash ~init:Hash_prefix.receipt_chain_zkapp_command\n |> of_hash\n\n [%%if defined consensus_mechanism]\n\n module Checked = struct\n module Signed_command_elt = struct\n type t = Signed_command_payload of Transaction_union_payload.var\n end\n\n module Zkapp_command_elt = struct\n type t = Zkapp_command_commitment of Random_oracle.Checked.Digest.t\n end\n\n let constant (t : t) =\n var_of_hash_packed (Field.Var.constant (t :> Field.t))\n\n type t = var\n\n let equal t1 t2 = equal_var t1 t2\n\n let if_ = if_\n\n let cons_signed_command_payload (e : Signed_command_elt.t) t =\n let open Random_oracle.Legacy in\n let%bind x =\n match e with\n | Signed_command_payload payload ->\n let%map payload =\n Transaction_union_payload.Checked.to_input_legacy payload\n in\n payload\n in\n make_checked (fun () ->\n Checked.hash ~init:Hash_prefix.receipt_chain_signed_command\n (Checked.pack_input Input.(append x (field (var_to_hash_packed t))))\n |> var_of_hash_packed )\n\n (* prepend account_update index *)\n let cons_zkapp_command_commitment (index : Mina_numbers.Index.Checked.t)\n (e : Zkapp_command_elt.t) (t : t) =\n let open Random_oracle in\n let%bind x =\n match e with\n | Zkapp_command_commitment s ->\n Let_syntax.return (Input.Chunked.field s)\n in\n let index_input = Mina_numbers.Index.Checked.to_input index in\n make_checked (fun () ->\n Checked.hash ~init:Hash_prefix.receipt_chain_zkapp_command\n (Checked.pack_input\n Input.Chunked.(\n append index_input (append x (field (var_to_hash_packed t)))) )\n |> var_of_hash_packed )\n end\n\n [%%endif]\nend\n","open Core_kernel\nopen Snark_params.Tick\n\ninclude Data_hash.Make_full_size (struct\n let description = \"State body hash\"\n\n let version_byte = Base58_check.Version_bytes.state_body_hash\nend)\n\nlet dummy = of_hash Outside_hash_image.t\n\n(* Data hash versioned boilerplate below *)\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\nend]\n\nlet (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nlet field_of_bool = Mina_base_util.field_of_bool\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\nopen Signature_lib\n\n[%%endif]\n\nlet int_to_bits ~length x = List.init length ~f:(fun i -> (x lsr i) land 1 = 1)\n\nlet int_of_bits =\n List.foldi ~init:0 ~f:(fun i acc b -> if b then acc lor (1 lsl i) else acc)\n\nmodule Transition = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = { prev : 'a; next : 'a }\n [@@deriving hlist, sexp, equal, yojson, hash, compare]\n end\n end]\n\n let to_input { prev; next } ~f =\n Random_oracle_input.Chunked.append (f prev) (f next)\n\n [%%ifdef consensus_mechanism]\n\n let typ t =\n Typ.of_hlistable [ t; t ] ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n [%%endif]\nend\n\nmodule Flagged_data = struct\n type ('flag, 'a) t = { flag : 'flag; data : 'a } [@@deriving hlist, fields]\n\n [%%ifdef consensus_mechanism]\n\n let typ flag t =\n Typ.of_hlistable [ flag; t ] ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n [%%endif]\n\n let to_input' { flag; data } ~flag:f ~data:d =\n Random_oracle_input.Chunked.(append (f flag) (d data))\nend\n\nmodule Flagged_option = struct\n type ('bool, 'a) t = { is_some : 'bool; data : 'a } [@@deriving hlist, fields]\n\n let to_input' ~field_of_bool { is_some; data } ~f =\n Random_oracle_input.Chunked.(\n append (packed (field_of_bool is_some, 1)) (f data))\n\n let to_input { is_some; data } ~default ~f =\n let data = if is_some then data else default in\n to_input' { is_some; data } ~f\n\n let of_option t ~default =\n match t with\n | None ->\n { is_some = false; data = default }\n | Some data ->\n { is_some = true; data }\n\n let to_option { is_some; data } = Option.some_if is_some data\n\n let map ~f { is_some; data } = { is_some; data = f data }\n\n [%%ifdef consensus_mechanism]\n\n let if_ ~(if_ : 'b -> then_:'var -> else_:'var -> 'var) b ~then_ ~else_ =\n { is_some =\n Run.run_checked\n (Boolean.if_ b ~then_:then_.is_some ~else_:else_.is_some)\n ; data = if_ b ~then_:then_.data ~else_:else_.data\n }\n\n let typ t =\n Typ.of_hlistable [ Boolean.typ; t ] ~var_to_hlist:to_hlist\n ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let option_typ ~default t =\n Typ.transport (typ t) ~there:(of_option ~default) ~back:to_option\n\n let lazy_option_typ ~default t =\n Typ.transport (typ t)\n ~there:(fun t -> of_option t ~default:(Lazy.force default))\n ~back:to_option\n\n [%%endif]\nend\n\nmodule Set_or_keep = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = 'a Mina_wire_types.Mina_base.Zkapp_basic.Set_or_keep.V1.t =\n | Set of 'a\n | Keep\n [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n let map t ~f = match t with Keep -> Keep | Set x -> Set (f x)\n\n let to_option = function Set x -> Some x | Keep -> None\n\n let of_option = function Some x -> Set x | None -> Keep\n\n let set_or_keep t x = match t with Keep -> x | Set y -> y\n\n let is_set = function Set _ -> true | _ -> false\n\n let is_keep = function Keep -> true | _ -> false\n\n let deriver inner obj =\n let open Fields_derivers_zkapps.Derivers in\n iso ~map:of_option ~contramap:to_option\n ((option ~js_type:Flagged_option @@ inner @@ o ()) (o ()))\n obj\n\n let gen gen_a =\n let open Quickcheck.Let_syntax in\n (* with equal probability, return a Set or a Keep *)\n let%bind b = Quickcheck.Generator.bool in\n if b then\n let%bind a = gen_a in\n return (Set a)\n else return Keep\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n type 'a t\n\n val is_keep : _ t -> Boolean.var\n\n val is_set : _ t -> Boolean.var\n\n val set_or_keep :\n if_:(Boolean.var -> then_:'a -> else_:'a -> 'a) -> 'a t -> 'a -> 'a\n\n val data : 'a t -> 'a\n\n val typ :\n dummy:'a -> ('a_var, 'a) Typ.t -> ('a_var t, 'a Stable.Latest.t) Typ.t\n\n val optional_typ :\n to_option:('new_value -> 'value option)\n -> of_option:('value option -> 'new_value)\n -> ('var, 'new_value) Typ.t\n -> ('var t, 'value Stable.Latest.t) Typ.t\n\n val map : f:('a -> 'b) -> 'a t -> 'b t\n\n val to_input :\n 'a t\n -> f:('a -> Field.Var.t Random_oracle_input.Chunked.t)\n -> Field.Var.t Random_oracle_input.Chunked.t\n\n val set : 'a -> 'a t\n\n val keep : dummy:'a -> 'a t\n\n val make_unsafe : Boolean.var -> 'a -> 'a t\n end = struct\n type 'a t = (Boolean.var, 'a) Flagged_option.t\n\n let set_or_keep ~if_ ({ is_some; data } : _ t) x =\n if_ is_some ~then_:data ~else_:x\n\n let data = Flagged_option.data\n\n let is_set = Flagged_option.is_some\n\n let is_keep x = Boolean.not (Flagged_option.is_some x)\n\n let map = Flagged_option.map\n\n let typ ~dummy t =\n Typ.transport\n (Flagged_option.option_typ ~default:dummy t)\n ~there:to_option ~back:of_option\n\n let optional_typ (type new_value value var) :\n to_option:(new_value -> value option)\n -> of_option:(value option -> new_value)\n -> (var, new_value) Typ.t\n -> (var t, value Stable.Latest.t) Typ.t =\n fun ~to_option ~of_option t ->\n Typ.transport (Flagged_option.typ t)\n ~there:(function\n | Set x ->\n { Flagged_option.is_some = true; data = of_option (Some x) }\n | Keep ->\n { Flagged_option.is_some = false; data = of_option None } )\n ~back:(function\n | { Flagged_option.is_some = true; data = x } ->\n Set (Option.value_exn (to_option x))\n | { Flagged_option.is_some = false; data = _ } ->\n Keep )\n\n let to_input (t : _ t) ~f =\n Flagged_option.to_input' t ~f ~field_of_bool:(fun (b : Boolean.var) ->\n (b :> Field.Var.t) )\n\n let make_unsafe is_keep data = { Flagged_option.is_some = is_keep; data }\n\n let set data = { Flagged_option.is_some = Boolean.true_; data }\n\n let keep ~dummy = { Flagged_option.is_some = Boolean.false_; data = dummy }\n end\n\n let typ = Checked.typ\n\n let optional_typ = Checked.optional_typ\n\n [%%endif]\n\n let to_input t ~dummy:default ~f =\n Flagged_option.to_input ~default ~f ~field_of_bool\n (Flagged_option.of_option ~default (to_option t))\nend\n\nmodule Or_ignore = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = 'a Mina_wire_types.Mina_base.Zkapp_basic.Or_ignore.V1.t =\n | Check of 'a\n | Ignore\n [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n let gen gen_a =\n let open Quickcheck.Let_syntax in\n (* choose constructor *)\n let%bind b = Quickcheck.Generator.bool in\n if b then\n let%map a = gen_a in\n Check a\n else return Ignore\n\n let to_option = function Ignore -> None | Check x -> Some x\n\n let of_option = function None -> Ignore | Some x -> Check x\n\n let deriver_base ~js_type inner obj =\n let open Fields_derivers_zkapps.Derivers in\n iso ~map:of_option ~contramap:to_option\n ((option ~js_type @@ inner @@ o ()) (o ()))\n obj\n\n let deriver inner obj = deriver_base ~js_type:Flagged_option inner obj\n\n let deriver_interval inner obj ~range_max =\n deriver_base ~js_type:(Closed_interval range_max) inner obj\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n type 'a t\n\n val typ :\n ignore:'a -> ('a_var, 'a) Typ.t -> ('a_var t, 'a Stable.Latest.t) Typ.t\n\n val to_input :\n 'a t\n -> f:('a -> Field.Var.t Random_oracle_input.Chunked.t)\n -> Field.Var.t Random_oracle_input.Chunked.t\n\n val check : 'a t -> f:('a -> Boolean.var) -> Boolean.var\n\n val map : f:('a -> 'b) -> 'a t -> 'b t\n\n val data : 'a t -> 'a\n\n val is_check : 'a t -> Boolean.var\n\n val make_unsafe : Boolean.var -> 'a -> 'a t\n end = struct\n type 'a t = (Boolean.var, 'a) Flagged_option.t\n\n let to_input t ~f =\n Flagged_option.to_input' t ~f ~field_of_bool:(fun (b : Boolean.var) ->\n (b :> Field.Var.t) )\n\n let check { Flagged_option.is_some; data } ~f =\n Pickles.Impls.Step.Boolean.(any [ not is_some; f data ])\n\n let map = Flagged_option.map\n\n let data = Flagged_option.data\n\n let is_check = Flagged_option.is_some\n\n let typ (type a_var a) ~ignore (t : (a_var, a) Typ.t) =\n Typ.transport\n (Flagged_option.option_typ ~default:ignore t)\n ~there:to_option ~back:of_option\n\n let make_unsafe is_ignore data =\n { Flagged_option.is_some = is_ignore; data }\n end\n\n let typ = Checked.typ\n\n [%%endif]\nend\n\nmodule Account_state = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Empty | Non_empty | Any\n [@@deriving sexp, equal, yojson, hash, compare, enum]\n\n let to_latest = Fn.id\n end\n end]\n\n module Encoding = struct\n type 'b t = { any : 'b; empty : 'b } [@@deriving hlist]\n\n let to_input ~field_of_bool { any; empty } =\n Random_oracle_input.Chunked.packeds\n [| (field_of_bool any, 1); (field_of_bool empty, 1) |]\n end\n\n let encode : t -> bool Encoding.t = function\n | Empty ->\n { any = false; empty = true }\n | Non_empty ->\n { any = false; empty = false }\n | Any ->\n { any = true; empty = false }\n\n let decode : bool Encoding.t -> t = function\n | { any = false; empty = true } ->\n Empty\n | { any = false; empty = false } ->\n Non_empty\n | { any = true; empty = false } | { any = true; empty = true } ->\n Any\n\n let to_input (x : t) = Encoding.to_input ~field_of_bool (encode x)\n\n let check (t : t) (x : [ `Empty | `Non_empty ]) =\n match (t, x) with\n | Any, _ | Non_empty, `Non_empty | Empty, `Empty ->\n Ok ()\n | _ ->\n Or_error.error_string \"Bad account_type\"\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n open Pickles.Impls.Step\n\n type t = Boolean.var Encoding.t\n\n let to_input (t : t) =\n Encoding.to_input t ~field_of_bool:(fun (b : Boolean.var) ->\n (b :> Field.t) )\n\n let check (t : t) ~is_empty =\n Boolean.(\n any [ t.any; t.empty && is_empty; (not t.empty) && not is_empty ])\n end\n\n let typ : (Checked.t, t) Typ.t =\n let open Encoding in\n Typ.of_hlistable\n [ Boolean.typ; Boolean.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n |> Typ.transport ~there:encode ~back:decode\n\n [%%endif]\nend\n\n[%%ifdef consensus_mechanism]\n\nmodule F = Pickles.Backend.Tick.Field\n\n[%%else]\n\nmodule F = Snark_params.Tick.Field\n\n[%%endif]\n\nmodule F_map = struct\n include Hashable.Make (F)\n include Comparable.Make (F)\nend\n\nlet invalid_public_key : Public_key.Compressed.t =\n { x = F.zero; is_odd = false }\n\nlet%test \"invalid_public_key is invalid\" =\n Option.is_none (Public_key.decompress invalid_public_key)\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\nopen Zkapp_basic\n\nmodule Event = struct\n (* Arbitrary hash input, encoding determined by the zkApp's developer. *)\n type t = Field.t array [@@deriving compare, sexp]\n\n let hash (x : t) = Random_oracle.hash ~init:Hash_prefix_states.zkapp_event x\n\n [%%ifdef consensus_mechanism]\n\n type var = Field.Var.t array\n\n let hash_var (x : Field.Var.t array) =\n Random_oracle.Checked.hash ~init:Hash_prefix_states.zkapp_event x\n\n [%%endif]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck in\n Generator.map ~f:Array.of_list @@ Generator.list Field.gen\nend\n\nmodule Make_events (Inputs : sig\n val salt_phrase : string\n\n val hash_prefix : field Random_oracle.State.t\n\n val deriver_name : string\nend) =\nstruct\n type t = Event.t list [@@deriving compare, sexp]\n\n let empty_hash =\n Hash_prefix_create.salt Inputs.salt_phrase |> Random_oracle.digest\n\n let push_hash acc hash =\n Random_oracle.hash ~init:Inputs.hash_prefix [| acc; hash |]\n\n let push_event acc event = push_hash acc (Event.hash event)\n\n let hash (x : t) =\n (* fold_right so the empty hash is used at the end of the events *)\n List.fold_right ~init:empty_hash ~f:(Fn.flip push_event) x\n\n [%%ifdef consensus_mechanism]\n\n type var = t Data_as_hash.t\n\n let typ = Data_as_hash.typ ~hash\n\n let var_to_input (x : var) = Data_as_hash.to_input x\n\n let to_input (x : t) = Random_oracle_input.Chunked.field (hash x)\n\n let push_to_data_as_hash (events : var) (e : Event.var) : var =\n let open Run in\n let res =\n exists typ ~compute:(fun () ->\n let tl = As_prover.read typ events in\n let hd =\n As_prover.read (Typ.array ~length:(Array.length e) Field.typ) e\n in\n hd :: tl )\n in\n Field.Assert.equal\n (Random_oracle.Checked.hash ~init:Inputs.hash_prefix\n [| Data_as_hash.hash events; Event.hash_var e |] )\n (Data_as_hash.hash res) ;\n res\n\n let empty_stack_msg = \"Attempted to pop an empty stack\"\n\n let pop_from_data_as_hash (events : var) : Event.t Data_as_hash.t * var =\n let open Run in\n let hd, tl =\n exists\n Typ.(Data_as_hash.typ ~hash:Event.hash * typ)\n ~compute:(fun () ->\n match As_prover.read typ events with\n | [] ->\n failwith empty_stack_msg\n | event :: events ->\n (event, events) )\n in\n Field.Assert.equal\n (Random_oracle.Checked.hash ~init:Inputs.hash_prefix\n [| Data_as_hash.hash tl; Data_as_hash.hash hd |] )\n (Data_as_hash.hash events) ;\n (hd, tl)\n\n [%%endif]\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let events = list @@ array field (o ()) in\n needs_custom_js\n ~js_type:(Data_as_hash.deriver events)\n ~name:Inputs.deriver_name events obj\nend\n\nmodule Events = struct\n include Make_events (struct\n let salt_phrase = \"MinaZkappEventsEmpty\"\n\n let hash_prefix = Hash_prefix_states.zkapp_events\n\n let deriver_name = \"Events\"\n end)\nend\n\nmodule Actions = struct\n include Make_events (struct\n let salt_phrase = \"MinaZkappActionsEmpty\"\n\n let hash_prefix = Hash_prefix_states.zkapp_actions\n\n let deriver_name = \"Actions\"\n end)\n\n let is_empty_var (e : var) =\n Snark_params.Tick.Field.(\n Checked.equal (Data_as_hash.hash e) (Var.constant empty_hash))\n\n let empty_state_element =\n let salt_phrase = \"MinaZkappActionStateEmptyElt\" in\n Hash_prefix_create.salt salt_phrase |> Random_oracle.digest\n\n let push_events (acc : Field.t) (events : t) : Field.t =\n push_hash acc (hash events)\n\n [%%ifdef consensus_mechanism]\n\n let push_events_checked (x : Field.Var.t) (e : var) : Field.Var.t =\n Random_oracle.Checked.hash ~init:Hash_prefix_states.zkapp_actions\n [| x; Data_as_hash.hash e |]\n\n [%%endif]\nend\n\nmodule Zkapp_uri = struct\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n module T = struct\n type t = string [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n\n let max_length = 255\n\n let check (x : t) = assert (String.length x <= max_length)\n\n let t_of_sexp sexp =\n let res = t_of_sexp sexp in\n check res ; res\n\n let of_yojson json =\n let res = of_yojson json in\n Result.bind res ~f:(fun res ->\n Result.try_with (fun () -> check res)\n |> Result.map ~f:(Fn.const res)\n |> Result.map_error\n ~f:(Fn.const \"Zkapp_uri.of_yojson: symbol is too long\") )\n end\n\n include T\n\n include\n Binable.Of_binable_without_uuid\n (Core_kernel.String.Stable.V1)\n (struct\n type t = string\n\n let to_binable = Fn.id\n\n let of_binable x = check x ; x\n end)\n end\n end]\n\n [%%define_locally\n Stable.Latest.\n (sexp_of_t, t_of_sexp, equal, to_yojson, of_yojson, max_length, check)]\nend\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('app_state, 'vk, 'zkapp_version, 'field, 'slot, 'bool, 'zkapp_uri) t =\n { app_state : 'app_state\n ; verification_key : 'vk\n ; zkapp_version : 'zkapp_version\n ; action_state : 'field Pickles_types.Vector.Vector_5.Stable.V1.t\n ; last_action_slot : 'slot\n ; proved_state : 'bool\n ; zkapp_uri : 'zkapp_uri\n }\n [@@deriving sexp, equal, compare, hash, yojson, hlist, fields, annot]\n end\n end]\nend\n\ntype ('app_state, 'vk, 'zkapp_version, 'field, 'slot, 'bool, 'zkapp_uri) t_ =\n ('app_state, 'vk, 'zkapp_version, 'field, 'slot, 'bool, 'zkapp_uri) Poly.t =\n { app_state : 'app_state\n ; verification_key : 'vk\n ; zkapp_version : 'zkapp_version\n ; action_state : 'field Pickles_types.Vector.Vector_5.t\n ; last_action_slot : 'slot\n ; proved_state : 'bool\n ; zkapp_uri : 'zkapp_uri\n }\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t =\n ( Zkapp_state.Value.Stable.V1.t\n , Verification_key_wire.Stable.V1.t option\n , Mina_numbers.Zkapp_version.Stable.V1.t\n , F.Stable.V1.t\n , Mina_numbers.Global_slot_since_genesis.Stable.V1.t\n , bool\n , Zkapp_uri.Stable.V1.t )\n Poly.Stable.V2.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\ntype t =\n ( Zkapp_state.Value.t\n , Verification_key_wire.t option\n , Mina_numbers.Zkapp_version.t\n , F.t\n , Mina_numbers.Global_slot_since_genesis.t\n , bool\n , Zkapp_uri.t )\n Poly.t\n[@@deriving sexp, equal, compare, hash, yojson]\n\nlet (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n[%%ifdef consensus_mechanism]\n\nmodule Checked = struct\n type t =\n ( Pickles.Impls.Step.Field.t Zkapp_state.V.t\n , ( Boolean.var\n , (Side_loaded_verification_key.t option, Field.t) With_hash.t\n Data_as_hash.t )\n Flagged_option.t\n , Mina_numbers.Zkapp_version.Checked.t\n , Pickles.Impls.Step.Field.t\n , Mina_numbers.Global_slot_since_genesis.Checked.t\n , Boolean.var\n , string Data_as_hash.t )\n Poly.t\n\n open Pickles_types\n\n let to_input' (t : _ Poly.t) :\n Snark_params.Tick.Field.Var.t Random_oracle.Input.Chunked.t =\n let open Random_oracle.Input.Chunked in\n let f mk acc field = mk (Core_kernel.Field.get field t) :: acc in\n let app_state v =\n Random_oracle.Input.Chunked.field_elements (Vector.to_array v)\n in\n Poly.Fields.fold ~init:[] ~app_state:(f app_state)\n ~verification_key:(f field)\n ~zkapp_version:(f Mina_numbers.Zkapp_version.Checked.to_input)\n ~action_state:(f app_state)\n ~last_action_slot:\n (f Mina_numbers.Global_slot_since_genesis.Checked.to_input)\n ~proved_state:\n (f (fun (b : Boolean.var) ->\n Random_oracle.Input.Chunked.packed ((b :> Field.Var.t), 1) ) )\n ~zkapp_uri:(f field)\n |> List.reduce_exn ~f:append\n\n let to_input (t : t) =\n to_input'\n { t with\n verification_key = Data_as_hash.hash t.verification_key.data\n ; zkapp_uri = Data_as_hash.hash t.zkapp_uri\n }\n\n let digest_vk t =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix_states.side_loaded_vk\n (pack_input (Pickles.Side_loaded.Verification_key.Checked.to_input t)))\n\n let digest t =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix_states.zkapp_account (pack_input (to_input t)))\n\n let digest' t =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix_states.zkapp_account (pack_input (to_input' t)))\nend\n\n[%%define_locally Verification_key_wire.(digest_vk, dummy_vk_hash)]\n\n(* This preimage cannot be attained by any string, due to the trailing [true]\n added below.\n*)\nlet zkapp_uri_non_preimage =\n lazy (Random_oracle_input.Chunked.field_elements [| Field.zero; Field.zero |])\n\nlet hash_zkapp_uri_opt (zkapp_uri_opt : string option) =\n let input =\n match zkapp_uri_opt with\n | Some zkapp_uri ->\n (* We use [length*8 + 1] to pass a final [true] after the end of the\n string, to ensure that trailing null bytes don't alias in the hash\n preimage.\n *)\n let bits = Array.create ~len:((String.length zkapp_uri * 8) + 1) true in\n String.foldi zkapp_uri ~init:() ~f:(fun i () c ->\n let c = Char.to_int c in\n (* Insert the bits into [bits], LSB order. *)\n for j = 0 to 7 do\n (* [Int.test_bit c j] *)\n bits.((i * 8) + j) <- Int.bit_and c (1 lsl j) <> 0\n done ) ;\n Random_oracle_input.Chunked.packeds\n (Array.map ~f:(fun b -> (field_of_bool b, 1)) bits)\n | None ->\n Lazy.force zkapp_uri_non_preimage\n in\n Random_oracle.pack_input input\n |> Random_oracle.hash ~init:Hash_prefix_states.zkapp_uri\n\nlet hash_zkapp_uri (zkapp_uri : string) = hash_zkapp_uri_opt (Some zkapp_uri)\n\nlet typ : (Checked.t, t) Typ.t =\n let open Poly in\n Typ.of_hlistable\n [ Zkapp_state.typ Field.typ\n ; Flagged_option.lazy_option_typ\n ~default:(lazy { With_hash.data = None; hash = dummy_vk_hash () })\n (Data_as_hash.typ ~hash:With_hash.hash)\n |> Typ.transport\n ~there:(Option.map ~f:(With_hash.map ~f:Option.some))\n ~back:\n (Option.map ~f:(With_hash.map ~f:(fun x -> Option.value_exn x)))\n ; Mina_numbers.Zkapp_version.typ\n ; Pickles_types.Vector.typ Field.typ Pickles_types.Nat.N5.n\n ; Mina_numbers.Global_slot_since_genesis.typ\n ; Boolean.typ\n ; Data_as_hash.typ ~hash:hash_zkapp_uri\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n[%%endif]\n\nlet zkapp_uri_to_input zkapp_uri =\n Random_oracle.Input.Chunked.field @@ hash_zkapp_uri zkapp_uri\n\nlet to_input (t : t) : _ Random_oracle.Input.Chunked.t =\n let open Random_oracle.Input.Chunked in\n let f mk acc field = mk (Core_kernel.Field.get field t) :: acc in\n let app_state v =\n Random_oracle.Input.Chunked.field_elements (Pickles_types.Vector.to_array v)\n in\n Poly.Fields.fold ~init:[] ~app_state:(f app_state)\n ~verification_key:\n (f\n (Fn.compose field\n (Option.value_map ~default:(dummy_vk_hash ()) ~f:With_hash.hash) ) )\n ~zkapp_version:(f Mina_numbers.Zkapp_version.to_input)\n ~action_state:(f app_state)\n ~last_action_slot:(f Mina_numbers.Global_slot_since_genesis.to_input)\n ~proved_state:\n (f (fun b -> Random_oracle.Input.Chunked.packed (field_of_bool b, 1)))\n ~zkapp_uri:(f zkapp_uri_to_input)\n |> List.reduce_exn ~f:append\n\nlet default : _ Poly.t =\n (* These are the permissions of a \"user\"/\"non zkapp\" account. *)\n { app_state =\n Pickles_types.Vector.init Zkapp_state.Max_state_size.n ~f:(fun _ ->\n F.zero )\n ; verification_key = None\n ; zkapp_version = Mina_numbers.Zkapp_version.zero\n ; action_state =\n (let empty = Actions.empty_state_element in\n [ empty; empty; empty; empty; empty ] )\n ; last_action_slot = Mina_numbers.Global_slot_since_genesis.zero\n ; proved_state = false\n ; zkapp_uri = \"\"\n }\n\nlet digest (t : t) =\n Random_oracle.(\n hash ~init:Hash_prefix_states.zkapp_account (pack_input (to_input t)))\n\nlet default_digest = lazy (digest default)\n\nlet hash_zkapp_account_opt' = function\n | None ->\n Lazy.force default_digest\n | Some (a : t) ->\n digest a\n\nlet action_state_deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let list_5 = list ~static_length:5 (field @@ o ()) in\n let open Pickles_types.Vector.Vector_5 in\n iso ~map:of_list_exn ~contramap:to_list (list_5 (o ())) obj\n\nlet deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots:Poly.t_fields_annots in\n finish \"ZkappAccount\" ~t_toplevel_annots:Poly.t_toplevel_annots\n @@ Poly.Fields.make_creator\n ~app_state:!.(Zkapp_state.deriver field)\n ~verification_key:\n !.(option ~js_type:Or_undefined (verification_key_with_hash @@ o ()))\n ~zkapp_version:!.uint32 ~action_state:!.action_state_deriver\n ~last_action_slot:!.global_slot_since_genesis\n ~proved_state:!.bool ~zkapp_uri:!.string obj\n\nlet gen_uri =\n let open Quickcheck in\n let open Generator.Let_syntax in\n let%bind parts =\n String.gen_with_length 8 Char.gen_alphanum |> Generator.list_with_length 3\n in\n let%map domain = Generator.of_list [ \"com\"; \"org\"; \"net\"; \"info\" ] in\n Printf.sprintf \"https://%s.%s\" (String.concat ~sep:\".\" parts) domain\n\nlet gen : t Quickcheck.Generator.t =\n let open Quickcheck in\n let open Generator.Let_syntax in\n let app_state =\n Pickles_types.Vector.init Zkapp_state.Max_state_size.n ~f:(fun _ ->\n F.random () )\n in\n let%bind zkapp_version = Mina_numbers.Zkapp_version.gen in\n let%bind seq_state = Generator.list_with_length 5 Field.gen in\n let%bind last_sequence_slot = Mina_numbers.Global_slot_since_genesis.gen in\n let%map zkapp_uri = gen_uri in\n let five = Pickles_types.Nat.(S (S (S (S (S Z))))) in\n { app_state\n ; verification_key = None\n ; zkapp_version\n ; action_state = Pickles_types.(Vector.of_list_and_length_exn seq_state five)\n ; last_action_slot = Mina_numbers.Global_slot_since_genesis.zero\n ; proved_state = false\n ; zkapp_uri\n }\n","(* account.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_util\nopen Snark_params\nopen Tick\nopen Currency\nopen Mina_numbers\nopen Fold_lib\nopen Mina_base_import\n\nmodule Index = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n module T = struct\n type t = int [@@deriving to_yojson, sexp, hash, compare]\n end\n\n include T\n\n let to_latest = Fn.id\n\n include Hashable.Make_binable (T)\n end\n end]\n\n include Hashable.Make_binable (Stable.Latest)\n\n let to_int = Int.to_int\n\n let gen ~ledger_depth = Int.gen_incl 0 ((1 lsl ledger_depth) - 1)\n\n module Vector = struct\n include Int\n\n let empty = zero\n\n let get t i = (t lsr i) land 1 = 1\n\n let set v i b = if b then v lor (one lsl i) else v land lnot (one lsl i)\n end\n\n let to_bits ~ledger_depth t = List.init ledger_depth ~f:(Vector.get t)\n\n let of_bits = List.foldi ~init:Vector.empty ~f:(fun i t b -> Vector.set t i b)\n\n let to_input ~ledger_depth x =\n List.map (to_bits ~ledger_depth x) ~f:(fun b -> (field_of_bool b, 1))\n |> List.to_array |> Random_oracle.Input.Chunked.packeds\n\n let fold_bits ~ledger_depth t =\n { Fold.fold =\n (fun ~init ~f ->\n let rec go acc i =\n if i = ledger_depth then acc else go (f acc (Vector.get t i)) (i + 1)\n in\n go init 0 )\n }\n\n let fold ~ledger_depth t =\n Fold.group3 ~default:false (fold_bits ~ledger_depth t)\n\n [%%ifdef consensus_mechanism]\n\n module Unpacked = struct\n type var = Tick.Boolean.var list\n\n type value = Vector.t\n\n let to_input x =\n List.map x ~f:(fun (b : Boolean.var) -> ((b :> Field.Var.t), 1))\n |> List.to_array |> Random_oracle.Input.Chunked.packeds\n\n let typ ~ledger_depth : (var, value) Tick.Typ.t =\n Typ.transport\n (Typ.list ~length:ledger_depth Boolean.typ)\n ~there:(to_bits ~ledger_depth) ~back:of_bits\n end\n\n [%%endif]\nend\n\nmodule Nonce = Account_nonce\n\nmodule Token_symbol = struct\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n module T = struct\n type t = string [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n\n let max_length = 6\n\n let check (x : t) = assert (String.length x <= max_length)\n\n let t_of_sexp sexp =\n let res = t_of_sexp sexp in\n check res ; res\n\n let of_yojson json =\n let res = of_yojson json in\n Result.bind res ~f:(fun res ->\n Result.try_with (fun () -> check res)\n |> Result.map ~f:(Fn.const res)\n |> Result.map_error\n ~f:(Fn.const \"Token_symbol.of_yojson: symbol is too long\") )\n end\n\n include T\n\n include\n Binable.Of_binable_without_uuid\n (Core_kernel.String.Stable.V1)\n (struct\n type t = string\n\n let to_binable = Fn.id\n\n let of_binable x = check x ; x\n end)\n end\n end]\n\n [%%define_locally\n Stable.Latest.\n (sexp_of_t, t_of_sexp, equal, to_yojson, of_yojson, max_length, check)]\n\n let default = \"\"\n\n (* 48 = max_length * 8 *)\n module Num_bits = Pickles_types.Nat.N48\n\n let num_bits = Pickles_types.Nat.to_int Num_bits.n\n\n let to_bits (x : t) =\n Pickles_types.Vector.init Num_bits.n ~f:(fun i ->\n let byte_index = i / 8 in\n if byte_index < String.length x then\n let c = x.[byte_index] |> Char.to_int in\n c land (1 lsl (i mod 8)) <> 0\n else false )\n\n let of_bits x : t =\n let c, j, chars =\n Pickles_types.Vector.fold x ~init:(0, 0, []) ~f:(fun (c, j, chars) x ->\n let c = c lor ((if x then 1 else 0) lsl j) in\n if j = 7 then (0, 0, Char.of_int_exn c :: chars) else (c, j + 1, chars) )\n in\n assert (c = 0) ;\n assert (j = 0) ;\n let chars = List.drop_while ~f:(fun c -> Char.to_int c = 0) chars in\n String.of_char_list (List.rev chars)\n\n let to_field (x : t) : Field.t =\n Field.project (Pickles_types.Vector.to_list (to_bits x))\n\n let to_input (x : t) =\n Random_oracle_input.Chunked.packed (to_field x, num_bits)\n\n [%%ifdef consensus_mechanism]\n\n type var = Field.Var.t\n\n let range_check (t : var) =\n let%bind actual =\n make_checked (fun () ->\n let _, _, actual_packed =\n Pickles.Scalar_challenge.to_field_checked' ~num_bits m\n (Kimchi_backend_common.Scalar_challenge.create t)\n in\n actual_packed )\n in\n Field.Checked.Assert.equal t actual\n\n let var_of_value x =\n Pickles_types.Vector.map ~f:Boolean.var_of_value (to_bits x)\n\n let of_field (x : Field.t) : t =\n of_bits\n (Pickles_types.Vector.of_list_and_length_exn\n (List.take (Field.unpack x) num_bits)\n Num_bits.n )\n\n let typ : (var, t) Typ.t =\n let (Typ typ) = Field.typ in\n Typ.transport\n (Typ { typ with check = range_check })\n ~there:to_field ~back:of_field\n\n let var_to_input (x : var) = Random_oracle_input.Chunked.packed (x, num_bits)\n\n let if_ = Tick.Run.Field.if_\n\n [%%endif]\nend\n\n(* the `token_symbol` describes a token id owned by the account id\n from this account, not the token id used by this account\n*)\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ( 'pk\n , 'id\n , 'token_symbol\n , 'amount\n , 'nonce\n , 'receipt_chain_hash\n , 'delegate\n , 'state_hash\n , 'timing\n , 'permissions\n , 'zkapp_opt )\n t =\n { public_key : 'pk\n ; token_id : 'id\n ; token_symbol : 'token_symbol\n ; balance : 'amount\n ; nonce : 'nonce\n ; receipt_chain_hash : 'receipt_chain_hash\n ; delegate : 'delegate\n ; voting_for : 'state_hash\n ; timing : 'timing\n ; permissions : 'permissions\n ; zkapp : 'zkapp_opt\n }\n [@@deriving sexp, equal, compare, hash, yojson, fields, hlist, annot]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nlet token = Poly.token_id\n\nmodule Key = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Public_key.Compressed.Stable.V1.t\n [@@deriving sexp, equal, hash, compare, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Identifier = Account_id\n\ntype key = Key.t [@@deriving sexp, equal, hash, compare, yojson]\n\nmodule Timing = Account_timing\n\nmodule Binable_arg = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Public_key.Compressed.Stable.V1.t\n , Token_id.Stable.V2.t\n , Token_symbol.Stable.V1.t\n , Balance.Stable.V1.t\n , Nonce.Stable.V1.t\n , Receipt.Chain_hash.Stable.V1.t\n , Public_key.Compressed.Stable.V1.t option\n , State_hash.Stable.V1.t\n , Timing.Stable.V2.t\n , Permissions.Stable.V2.t\n , Zkapp_account.Stable.V2.t option )\n (* TODO: Cache the digest of this? *)\n Poly.Stable.V2.t\n [@@deriving sexp, equal, hash, compare, yojson]\n\n let to_latest = Fn.id\n\n let public_key (t : t) : key = t.public_key\n end\n end]\nend\n\nlet check = Fn.id\n\n[%%versioned_binable\nmodule Stable = struct\n module V2 = struct\n type t = Binable_arg.Stable.V2.t\n [@@deriving sexp, equal, hash, compare, yojson]\n\n include\n Binable.Of_binable_without_uuid\n (Binable_arg.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable = check\n\n let of_binable = check\n end)\n\n let to_latest = Fn.id\n\n let public_key (t : t) : key = t.public_key\n end\nend]\n\n[%%define_locally Stable.Latest.(public_key)]\n\nlet identifier ({ public_key; token_id; _ } : t) =\n Account_id.create public_key token_id\n\ntype value =\n ( Public_key.Compressed.t\n , Token_id.t\n , Token_symbol.t\n , Balance.t\n , Nonce.t\n , Receipt.Chain_hash.t\n , Public_key.Compressed.t option\n , State_hash.t\n , Timing.t\n , Permissions.t\n , Zkapp_account.t option )\n Poly.t\n[@@deriving sexp]\n\nlet key_gen = Public_key.Compressed.gen\n\nlet initialize account_id : t =\n let public_key = Account_id.public_key account_id in\n let token_id = Account_id.token_id account_id in\n let delegate =\n (* Only allow delegation if this account is for the default token. *)\n if Token_id.(equal default token_id) then Some public_key else None\n in\n { public_key\n ; token_id\n ; token_symbol = \"\"\n ; balance = Balance.zero\n ; nonce = Nonce.zero\n ; receipt_chain_hash = Receipt.Chain_hash.empty\n ; delegate\n ; voting_for = State_hash.dummy\n ; timing = Timing.Untimed\n ; permissions = Permissions.user_default\n ; zkapp = None\n }\n\nlet hash_zkapp_account_opt = function\n | None ->\n Lazy.force Zkapp_account.default_digest\n | Some (a : Zkapp_account.t) ->\n Zkapp_account.digest a\n\nlet delegate_opt = Option.value ~default:Public_key.Compressed.empty\n\nlet to_input (t : t) =\n let open Random_oracle.Input.Chunked in\n let f mk acc field = mk (Core_kernel.Field.get field t) :: acc in\n Poly.Fields.fold ~init:[]\n ~public_key:(f Public_key.Compressed.to_input)\n ~token_id:(f Token_id.to_input) ~balance:(f Balance.to_input)\n ~token_symbol:(f Token_symbol.to_input) ~nonce:(f Nonce.to_input)\n ~receipt_chain_hash:(f Receipt.Chain_hash.to_input)\n ~delegate:(f (Fn.compose Public_key.Compressed.to_input delegate_opt))\n ~voting_for:(f State_hash.to_input) ~timing:(f Timing.to_input)\n ~zkapp:(f (Fn.compose field hash_zkapp_account_opt))\n ~permissions:(f Permissions.to_input)\n |> List.reduce_exn ~f:append\n\nlet crypto_hash_prefix = Hash_prefix.account\n\nlet crypto_hash t =\n Random_oracle.hash ~init:crypto_hash_prefix\n (Random_oracle.pack_input (to_input t))\n\n[%%ifdef consensus_mechanism]\n\ntype var =\n ( Public_key.Compressed.var\n , Token_id.Checked.t\n , Token_symbol.var\n , Balance.var\n , Nonce.Checked.t\n , Receipt.Chain_hash.var\n , Public_key.Compressed.var\n , State_hash.var\n , Timing.var\n , Permissions.Checked.t\n (* TODO: This is a hack that lets us avoid unhashing zkApp accounts when we don't need to *)\n , Field.Var.t * Zkapp_account.t option As_prover.Ref.t )\n Poly.t\n\nlet identifier_of_var ({ public_key; token_id; _ } : var) =\n Account_id.Checked.create public_key token_id\n\nlet typ' zkapp =\n Typ.of_hlistable\n [ Public_key.Compressed.typ\n ; Token_id.typ\n ; Token_symbol.typ\n ; Balance.typ\n ; Nonce.typ\n ; Receipt.Chain_hash.typ\n ; Typ.transport Public_key.Compressed.typ ~there:delegate_opt\n ~back:(fun delegate ->\n if Public_key.Compressed.(equal empty) delegate then None\n else Some delegate )\n ; State_hash.typ\n ; Timing.typ\n ; Permissions.typ\n ; zkapp\n ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\nlet typ : (var, value) Typ.t =\n let zkapp :\n ( Field.Var.t * Zkapp_account.t option As_prover.Ref.t\n , Zkapp_account.t option )\n Typ.t =\n let account :\n (Zkapp_account.t option As_prover.Ref.t, Zkapp_account.t option) Typ.t =\n Typ.Internal.ref ()\n in\n Typ.(Field.typ * account)\n |> Typ.transport ~there:(fun x -> (hash_zkapp_account_opt x, x)) ~back:snd\n in\n typ' zkapp\n\nlet var_of_t\n ({ public_key\n ; token_id\n ; token_symbol\n ; balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; voting_for\n ; timing\n ; permissions\n ; zkapp\n } :\n value ) =\n { Poly.public_key = Public_key.Compressed.var_of_t public_key\n ; token_id = Token_id.Checked.constant token_id\n ; token_symbol = Token_symbol.var_of_value token_symbol\n ; balance = Balance.var_of_t balance\n ; nonce = Nonce.Checked.constant nonce\n ; receipt_chain_hash = Receipt.Chain_hash.var_of_t receipt_chain_hash\n ; delegate = Public_key.Compressed.var_of_t (delegate_opt delegate)\n ; voting_for = State_hash.var_of_t voting_for\n ; timing = Timing.var_of_t timing\n ; permissions = Permissions.Checked.constant permissions\n ; zkapp = Field.Var.constant (hash_zkapp_account_opt zkapp)\n }\n\nmodule Checked = struct\n module Unhashed = struct\n type t =\n ( Public_key.Compressed.var\n , Token_id.Checked.t\n , Token_symbol.var\n , Balance.var\n , Nonce.Checked.t\n , Receipt.Chain_hash.var\n , Public_key.Compressed.var\n , State_hash.var\n , Timing.var\n , Permissions.Checked.t\n , Zkapp_account.Checked.t )\n Poly.t\n\n let typ : (t, Stable.Latest.t) Typ.t =\n typ'\n (Typ.transport Zkapp_account.typ\n ~there:(fun t -> Option.value t ~default:Zkapp_account.default)\n ~back:(fun t -> Some t) )\n end\n\n let to_input (t : var) =\n let f mk acc field = mk (Core_kernel.Field.get field t) :: acc in\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n (Poly.Fields.fold ~init:[]\n ~zkapp:(f (fun (x, _) -> field x))\n ~permissions:(f Permissions.Checked.to_input)\n ~public_key:(f Public_key.Compressed.Checked.to_input)\n ~token_id:(f Token_id.Checked.to_input)\n ~token_symbol:(f Token_symbol.var_to_input)\n ~balance:(f Balance.var_to_input) ~nonce:(f Nonce.Checked.to_input)\n ~receipt_chain_hash:(f Receipt.Chain_hash.var_to_input)\n ~delegate:(f Public_key.Compressed.Checked.to_input)\n ~voting_for:(f State_hash.var_to_input)\n ~timing:(f Timing.var_to_input) )\n\n let digest t =\n make_checked (fun () ->\n Random_oracle.Checked.(\n hash ~init:crypto_hash_prefix (pack_input (to_input t))) )\n\n let balance_upper_bound = Bignum_bigint.(one lsl Balance.length_in_bits)\n\n let amount_upper_bound = Bignum_bigint.(one lsl Amount.length_in_bits)\n\n let min_balance_at_slot ~global_slot ~cliff_time ~cliff_amount\n ~(vesting_period : Mina_numbers.Global_slot_span.Checked.var)\n ~vesting_increment ~initial_minimum_balance =\n let%bind before_cliff =\n Global_slot_since_genesis.Checked.(global_slot < cliff_time)\n in\n let%bind else_branch =\n make_checked (fun () ->\n let _, (slot_diff : Mina_numbers.Global_slot_span.Checked.var) =\n Tick.Run.run_checked\n (Global_slot_since_genesis.Checked.diff_or_zero global_slot\n cliff_time )\n in\n let cliff_decrement = cliff_amount in\n let min_balance_less_cliff_decrement =\n Tick.Run.run_checked\n (Balance.Checked.sub_amount_or_zero initial_minimum_balance\n cliff_decrement )\n in\n let (num_periods : Mina_numbers.Global_slot_span.Checked.var), _ =\n Tick.Run.run_checked\n (Global_slot_span.Checked.div_mod slot_diff vesting_period)\n in\n let vesting_decrement =\n Tick.Run.Field.mul\n (Global_slot_span.Checked.to_field num_periods)\n (Amount.pack_var vesting_increment)\n in\n let min_balance_less_cliff_and_vesting_decrements =\n Tick.Run.run_checked\n (Balance.Checked.sub_amount_or_zero\n min_balance_less_cliff_decrement\n Amount.(Checked.Unsafe.of_field vesting_decrement) )\n in\n min_balance_less_cliff_and_vesting_decrements )\n in\n Balance.Checked.if_ before_cliff ~then_:initial_minimum_balance\n ~else_:else_branch\n\n let has_locked_tokens ~global_slot (t : var) =\n let open Timing.As_record in\n let { is_timed = _\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } =\n t.timing\n in\n let%bind cur_min_balance =\n min_balance_at_slot ~global_slot ~initial_minimum_balance ~cliff_time\n ~cliff_amount ~vesting_period ~vesting_increment\n in\n let%map zero_min_balance =\n Balance.equal_var Balance.(var_of_t zero) cur_min_balance\n in\n (*Note: Untimed accounts will always have zero min balance*)\n Boolean.not zero_min_balance\n\n let has_permission ?signature_verifies ~to_ (account : var) =\n let signature_verifies =\n match signature_verifies with\n | Some signature_verifies ->\n signature_verifies\n | None -> (\n match to_ with\n | `Send ->\n Boolean.true_\n | `Receive ->\n Boolean.false_\n | `Set_delegate ->\n Boolean.true_\n | `Increment_nonce ->\n Boolean.true_\n | `Access ->\n failwith\n \"Account.Checked.has_permission: signature_verifies argument \\\n must be given for access permission\" )\n in\n match to_ with\n | `Send ->\n Permissions.Auth_required.Checked.eval_no_proof account.permissions.send\n ~signature_verifies\n | `Receive ->\n Permissions.Auth_required.Checked.eval_no_proof\n account.permissions.receive ~signature_verifies\n | `Set_delegate ->\n Permissions.Auth_required.Checked.eval_no_proof\n account.permissions.set_delegate ~signature_verifies\n | `Increment_nonce ->\n Permissions.Auth_required.Checked.eval_no_proof\n account.permissions.increment_nonce ~signature_verifies\n | `Access ->\n Permissions.Auth_required.Checked.eval_no_proof\n account.permissions.access ~signature_verifies\nend\n\n[%%endif]\n\nlet digest = crypto_hash\n\nlet empty =\n { Poly.public_key = Public_key.Compressed.empty\n ; token_id = Token_id.default\n ; token_symbol = Token_symbol.default\n ; balance = Balance.zero\n ; nonce = Nonce.zero\n ; receipt_chain_hash = Receipt.Chain_hash.empty\n ; delegate = None\n ; voting_for = State_hash.dummy\n ; timing = Timing.Untimed\n ; permissions =\n Permissions.user_default\n (* TODO: This should maybe be Permissions.empty *)\n ; zkapp = None\n }\n\nlet empty_digest = lazy (digest empty)\n\nlet create account_id balance =\n let public_key = Account_id.public_key account_id in\n let token_id = Account_id.token_id account_id in\n let delegate =\n (* Only allow delegation if this account is for the default token. *)\n if Token_id.(equal default) token_id then Some public_key else None\n in\n { Poly.public_key\n ; token_id\n ; token_symbol = Token_symbol.default\n ; balance\n ; nonce = Nonce.zero\n ; receipt_chain_hash = Receipt.Chain_hash.empty\n ; delegate\n ; voting_for = State_hash.dummy\n ; timing = Timing.Untimed\n ; permissions = Permissions.user_default\n ; zkapp = None\n }\n\nlet create_timed account_id balance ~initial_minimum_balance ~cliff_time\n ~cliff_amount ~vesting_period ~vesting_increment =\n if Global_slot_span.(equal vesting_period zero) then\n Or_error.errorf\n !\"Error creating timed account for account id %{sexp: Account_id.t}: \\\n vesting period must be greater than zero\"\n account_id\n else\n let public_key = Account_id.public_key account_id in\n let token_id = Account_id.token_id account_id in\n let delegate =\n (* Only allow delegation if this account is for the default token. *)\n if Token_id.(equal default) token_id then Some public_key else None\n in\n Or_error.return\n { Poly.public_key\n ; token_id\n ; token_symbol = Token_symbol.default\n ; balance\n ; nonce = Nonce.zero\n ; receipt_chain_hash = Receipt.Chain_hash.empty\n ; delegate\n ; voting_for = State_hash.dummy\n ; zkapp = None\n ; permissions = Permissions.user_default\n ; timing =\n Timing.Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n }\n\n(* no vesting after cliff time + 1 slot *)\nlet create_time_locked public_key balance ~initial_minimum_balance ~cliff_time =\n create_timed public_key balance ~initial_minimum_balance ~cliff_time\n ~vesting_period:Global_slot_span.(succ zero)\n ~vesting_increment:initial_minimum_balance\n\nlet initial_minimum_balance Poly.{ timing; _ } =\n match timing with\n | Timing.Untimed ->\n None\n | Timed t ->\n Some t.initial_minimum_balance\n\nlet cliff_time Poly.{ timing; _ } =\n match timing with Timing.Untimed -> None | Timed t -> Some t.cliff_time\n\nlet cliff_amount Poly.{ timing; _ } =\n match timing with Timing.Untimed -> None | Timed t -> Some t.cliff_amount\n\nlet vesting_increment Poly.{ timing } =\n match timing with\n | Timing.Untimed ->\n None\n | Timed t ->\n Some t.vesting_increment\n\nlet vesting_period Poly.{ timing; _ } =\n match timing with Timing.Untimed -> None | Timed t -> Some t.vesting_period\n\nlet min_balance_at_slot ~global_slot ~cliff_time ~cliff_amount ~vesting_period\n ~vesting_increment ~initial_minimum_balance =\n let open Unsigned in\n if Global_slot_since_genesis.(global_slot < cliff_time) then\n initial_minimum_balance\n (* If vesting period is zero then everything vests immediately at the cliff *)\n else if Global_slot_span.(equal vesting_period zero) then Balance.zero\n else\n match Balance.(initial_minimum_balance - cliff_amount) with\n | None ->\n Balance.zero\n | Some min_balance_past_cliff -> (\n (* take advantage of fact that global slots are uint32's *)\n let num_periods =\n UInt32.(\n let global_slot_u32 =\n Global_slot_since_genesis.to_uint32 global_slot\n in\n let cliff_time_u32 =\n Global_slot_since_genesis.to_uint32 cliff_time\n in\n let vesting_period_u32 =\n Global_slot_span.to_uint32 vesting_period\n in\n Infix.((global_slot_u32 - cliff_time_u32) / vesting_period_u32)\n |> to_int64 |> UInt64.of_int64)\n in\n let vesting_decrement =\n let vesting_increment = Amount.to_uint64 vesting_increment in\n if\n try\n UInt64.(compare Infix.(max_int / num_periods) vesting_increment)\n < 0\n with Division_by_zero -> false\n then\n (* The vesting decrement will overflow, use [max_int] instead. *)\n UInt64.max_int |> Amount.of_uint64\n else\n UInt64.Infix.(num_periods * vesting_increment) |> Amount.of_uint64\n in\n match Balance.(min_balance_past_cliff - vesting_decrement) with\n | None ->\n Balance.zero\n | Some amt ->\n amt )\n\nlet incremental_balance_between_slots ~start_slot ~end_slot ~cliff_time\n ~cliff_amount ~vesting_period ~vesting_increment ~initial_minimum_balance :\n Unsigned.UInt64.t =\n let open Unsigned in\n if Global_slot_since_genesis.(end_slot <= start_slot) then UInt64.zero\n else\n let min_balance_at_start_slot =\n min_balance_at_slot ~global_slot:start_slot ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment ~initial_minimum_balance\n |> Balance.to_amount |> Amount.to_uint64\n in\n let min_balance_at_end_slot =\n min_balance_at_slot ~global_slot:end_slot ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment ~initial_minimum_balance\n |> Balance.to_amount |> Amount.to_uint64\n in\n UInt64.Infix.(min_balance_at_start_slot - min_balance_at_end_slot)\n\nlet has_locked_tokens ~global_slot (account : t) =\n match account.timing with\n | Untimed ->\n false\n | Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } ->\n let curr_min_balance =\n min_balance_at_slot ~global_slot ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment ~initial_minimum_balance\n in\n Balance.(curr_min_balance > zero)\n\nlet final_vesting_slot ~initial_minimum_balance ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment =\n let open Unsigned in\n let to_vest =\n Balance.(initial_minimum_balance - cliff_amount)\n |> Option.value_map ~default:UInt64.zero ~f:Balance.to_uint64\n in\n let vest_incr = Amount.to_uint64 vesting_increment in\n let periods =\n let open UInt64 in\n let open Infix in\n (to_vest / vest_incr)\n + if equal (rem to_vest vest_incr) zero then zero else one\n in\n let open UInt32 in\n let open Infix in\n Global_slot_since_genesis.of_uint32\n @@ Global_slot_since_genesis.to_uint32 cliff_time\n + (UInt64.to_uint32 periods * Global_slot_span.to_uint32 vesting_period)\n\nlet timing_final_vesting_slot = function\n | Timing.Untimed ->\n Global_slot_since_genesis.zero\n | Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } ->\n final_vesting_slot ~initial_minimum_balance ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment\n\nlet has_permission ~control ~to_ (account : t) =\n match to_ with\n | `Access ->\n Permissions.Auth_required.check account.permissions.access control\n | `Send ->\n Permissions.Auth_required.check account.permissions.send control\n | `Receive ->\n Permissions.Auth_required.check account.permissions.receive control\n | `Set_delegate ->\n Permissions.Auth_required.check account.permissions.set_delegate control\n | `Increment_nonce ->\n Permissions.Auth_required.check account.permissions.increment_nonce\n control\n\n(** [true] iff account has permissions set that enable them to transfer Mina (assuming the command is signed) *)\nlet has_permission_to_send account =\n has_permission ~control:Control.Tag.Signature ~to_:`Access account\n && has_permission ~control:Control.Tag.Signature ~to_:`Send account\n\n(** [true] iff account has permissions set that enable them to receive Mina *)\nlet has_permission_to_receive account =\n has_permission ~control:Control.Tag.None_given ~to_:`Access account\n && has_permission ~control:Control.Tag.None_given ~to_:`Receive account\n\n(** [true] iff account has permissions set that enable them to set their delegate (assuming the command is signed) *)\nlet has_permission_to_set_delegate account =\n has_permission ~control:Control.Tag.Signature ~to_:`Access account\n && has_permission ~control:Control.Tag.Signature ~to_:`Set_delegate account\n\n(** [true] iff account has permissions set that enable them to increment their nonce (assuming the command is signed) *)\nlet has_permission_to_increment_nonce account =\n has_permission ~control:Control.Tag.Signature ~to_:`Access account\n && has_permission ~control:Control.Tag.Signature ~to_:`Increment_nonce account\n\nlet liquid_balance_at_slot ~global_slot (account : t) =\n match account.timing with\n | Untimed ->\n account.balance\n | Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } ->\n Balance.sub_amount account.balance\n (Balance.to_amount\n (min_balance_at_slot ~global_slot ~cliff_time ~cliff_amount\n ~vesting_period ~vesting_increment ~initial_minimum_balance ) )\n |> Option.value_exn\n\nlet gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind public_key = Public_key.Compressed.gen in\n let%bind token_id = Token_id.gen in\n let%map balance = Currency.Balance.gen in\n create (Account_id.create public_key token_id) balance\n\nlet gen_with_constrained_balance ~low ~high : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind public_key = Public_key.Compressed.gen in\n let%bind token_id = Token_id.gen in\n let%map balance = Currency.Balance.gen_incl low high in\n create (Account_id.create public_key token_id) balance\n\nlet gen_any_vesting_range =\n let open Quickcheck.Generator.Let_syntax in\n let open Global_slot_since_genesis in\n (* vesting period must be at least one to avoid division by zero *)\n let%bind vesting_period = Int.gen_incl 1 1000 >>| Global_slot_span.of_int in\n let%bind vesting_end = gen_incl (of_int 1) max_value in\n let%map cliff_time = gen_incl (of_int 1) vesting_end in\n (cliff_time, vesting_end, vesting_period)\n\nlet gen_with_vesting_period vesting_period =\n let open Quickcheck.Generator.Let_syntax in\n let open Global_slot_since_genesis in\n let min_vesting_end =\n Global_slot_span.(succ vesting_period |> to_uint32)\n |> Global_slot_since_genesis.of_uint32\n in\n let%bind vesting_end = gen_incl min_vesting_end max_value in\n let max_cliff_time = Option.value_exn @@ sub vesting_end vesting_period in\n let%map cliff_time = gen_incl (of_int 1) max_cliff_time in\n (cliff_time, vesting_end, vesting_period)\n\nlet gen_vesting_details ~(cliff_time : Global_slot_since_genesis.t)\n ~(vesting_end : Global_slot_since_genesis.t)\n ~(vesting_period : Global_slot_span.t) (initial_minimum_balance : Balance.t)\n : Timing.as_record Quickcheck.Generator.t =\n let open Unsigned in\n let open Quickcheck in\n let open Generator.Let_syntax in\n let vesting_slots =\n let open Global_slot_since_genesis in\n let open UInt32.Infix in\n to_uint32 vesting_end - to_uint32 cliff_time\n in\n (* We need to arrange vesting schedule so that all funds are vested before the\n maximum global slot, which is 2 ^ 32. *)\n let vesting_periods_count =\n Unsigned.UInt32.div vesting_slots\n (Global_slot_span.to_uint32 vesting_period)\n |> UInt64.of_uint32\n in\n let max_cliff_amt =\n Balance.(initial_minimum_balance - Amount.of_uint64 vesting_periods_count)\n |> Option.value_map ~f:Balance.to_amount ~default:Amount.zero\n in\n let%map cliff_amount =\n if UInt64.(compare vesting_periods_count zero) > 0 then\n Amount.(gen_incl zero max_cliff_amt)\n else return @@ Balance.to_amount initial_minimum_balance\n in\n let to_vest =\n Balance.(initial_minimum_balance - cliff_amount)\n |> Option.value_map ~default:Unsigned.UInt64.zero ~f:Balance.to_uint64\n in\n let vesting_increment =\n if Unsigned.UInt64.(equal vesting_periods_count zero) then Amount.one\n (* This value does not matter anyway. *)\n else\n let vi = UInt64.Infix.(to_vest / vesting_periods_count) in\n let rnd = UInt64.Infix.(to_vest mod vesting_periods_count) in\n (if UInt64.(compare rnd zero) > 0 then UInt64.succ vi else vi)\n |> Amount.of_uint64\n in\n { Timing.As_record.is_timed = true\n ; initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n\nlet gen_timing (account_balance : Balance.t) =\n let open Quickcheck.Generator.Let_syntax in\n let%bind initial_minimum_balance = Balance.(gen_incl one account_balance)\n and cliff_time, vesting_end, vesting_period = gen_any_vesting_range in\n gen_vesting_details ~vesting_period ~cliff_time ~vesting_end\n initial_minimum_balance\n\nlet gen_timing_at_least_one_vesting_period (account_balance : Balance.t) =\n let open Quickcheck.Generator.Let_syntax in\n let%bind initial_minimum_balance = Balance.(gen_incl one account_balance)\n (* vesting period must be at least one to avoid division by zero *)\n and cliff_time, vesting_end, vesting_period =\n gen_with_vesting_period @@ Global_slot_span.of_int 2\n in\n gen_vesting_details ~vesting_period ~cliff_time ~vesting_end\n initial_minimum_balance\n\nlet gen_timed : t Quickcheck.Generator.t =\n let open Quickcheck in\n let open Generator.Let_syntax in\n let%bind account =\n gen_with_constrained_balance ~low:Balance.one ~high:Balance.max_int\n in\n let%map timing = gen_timing account.balance in\n { account with timing = Timing.of_record timing }\n\nlet deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots:Poly.t_fields_annots in\n let receipt_chain_hash =\n needs_custom_js ~js_type:field ~name:\"ReceiptChainHash\" field\n in\n finish \"Account\" ~t_toplevel_annots:Poly.t_toplevel_annots\n @@ Poly.Fields.make_creator ~public_key:!.public_key\n ~token_id:!.Token_id.deriver ~token_symbol:!.string ~balance:!.balance\n ~nonce:!.uint32 ~receipt_chain_hash:!.receipt_chain_hash\n ~delegate:!.(option ~js_type:Or_undefined (public_key @@ o ()))\n ~voting_for:!.field ~timing:!.Timing.deriver\n ~permissions:!.Permissions.deriver\n ~zkapp:!.(option ~js_type:Or_undefined (Zkapp_account.deriver @@ o ()))\n obj\n","open Core_kernel\nopen Currency\nopen Snark_params.Tick\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('ledger_hash, 'amount) t =\n ( 'ledger_hash\n , 'amount )\n Mina_wire_types.Mina_base.Epoch_ledger.Poly.V1.t =\n { hash : 'ledger_hash; total_currency : 'amount }\n [@@deriving annot, sexp, equal, compare, hash, yojson, hlist, fields]\n end\n end]\nend\n\nmodule Value = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n (Frozen_ledger_hash0.Stable.V1.t, Amount.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nlet to_input ({ hash; total_currency } : Value.t) =\n Random_oracle_input.Chunked.(\n append (field (hash :> Field.t)) (Amount.to_input total_currency))\n\ntype var = (Frozen_ledger_hash0.var, Amount.var) Poly.t\n\nlet typ : (var, Value.t) Typ.t =\n Typ.of_hlistable\n [ Frozen_ledger_hash0.typ; Amount.typ ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\nlet var_to_input ({ Poly.hash; total_currency } : var) =\n let total_currency = Amount.var_to_input total_currency in\n Random_oracle_input.Chunked.(\n append (field (Frozen_ledger_hash0.var_to_hash_packed hash)) total_currency)\n\nlet if_ cond ~(then_ : (Frozen_ledger_hash0.var, Amount.var) Poly.t)\n ~(else_ : (Frozen_ledger_hash0.var, Amount.var) Poly.t) =\n let open Checked.Let_syntax in\n let%map hash =\n Frozen_ledger_hash0.if_ cond ~then_:then_.hash ~else_:else_.hash\n and total_currency =\n Amount.Checked.if_ cond ~then_:then_.total_currency\n ~else_:else_.total_currency\n in\n { Poly.hash; total_currency }\n","open Core_kernel\n\ninclude Data_hash.Make_full_size (struct\n let version_byte = Base58_check.Version_bytes.epoch_seed\n\n let description = \"Epoch Seed\"\nend)\n\n[%%versioned\nmodule Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Snark_params.Tick.Field.t[@version_asserted])\n [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\nend]\n\nlet _f () : (Stable.Latest.t, t) Type_equal.t = Type_equal.T\n","open Core_kernel\nopen Mina_numbers\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'epoch_ledger\n , 'epoch_seed\n , 'start_checkpoint\n , 'lock_checkpoint\n , 'length )\n t =\n ( 'epoch_ledger\n , 'epoch_seed\n , 'start_checkpoint\n , 'lock_checkpoint\n , 'length )\n Mina_wire_types.Mina_base.Epoch_data.Poly.V1.t =\n { ledger : 'epoch_ledger\n ; seed : 'epoch_seed\n ; start_checkpoint : 'start_checkpoint\n (* The lock checkpoint is the hash of the latest state in the seed update range, not including\n the current state. *)\n ; lock_checkpoint : 'lock_checkpoint\n ; epoch_length : 'length\n }\n [@@deriving annot, hlist, sexp, equal, compare, hash, yojson, fields]\n end\n end]\nend\n\ntype var =\n ( Epoch_ledger.var\n , Epoch_seed.var\n , State_hash.var\n , State_hash.var\n , Length.Checked.t )\n Poly.t\n\nlet if_ cond ~(then_ : var) ~(else_ : var) =\n let open Snark_params.Tick.Checked.Let_syntax in\n let%map ledger = Epoch_ledger.if_ cond ~then_:then_.ledger ~else_:else_.ledger\n and seed = Epoch_seed.if_ cond ~then_:then_.seed ~else_:else_.seed\n and start_checkpoint =\n State_hash.if_ cond ~then_:then_.start_checkpoint\n ~else_:else_.start_checkpoint\n and lock_checkpoint =\n State_hash.if_ cond ~then_:then_.lock_checkpoint\n ~else_:else_.lock_checkpoint\n and epoch_length =\n Length.Checked.if_ cond ~then_:then_.epoch_length ~else_:else_.epoch_length\n in\n { Poly.ledger; seed; start_checkpoint; lock_checkpoint; epoch_length }\n\nmodule Value = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( Epoch_ledger.Value.Stable.V1.t\n , Epoch_seed.Stable.V1.t\n , State_hash.Stable.V1.t\n , State_hash.Stable.V1.t\n , Length.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nopen Signature_lib\nmodule A = Account\nopen Mina_numbers\nopen Currency\nopen Zkapp_basic\nopen Pickles_types\nmodule Impl = Pickles.Impls.Step\n\nmodule Closed_interval = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t =\n 'a Mina_wire_types.Mina_base.Zkapp_precondition.Closed_interval.V1.t =\n { lower : 'a; upper : 'a }\n [@@deriving annot, sexp, equal, compare, hash, yojson, hlist, fields]\n end\n end]\n\n let gen gen_a compare_a =\n let open Quickcheck.Let_syntax in\n let%bind a1 = gen_a in\n let%map a2 = gen_a in\n if compare_a a1 a2 <= 0 then { lower = a1; upper = a2 }\n else { lower = a2; upper = a1 }\n\n let to_input { lower; upper } ~f =\n Random_oracle_input.Chunked.append (f lower) (f upper)\n\n let typ x =\n Typ.of_hlistable [ x; x ] ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let deriver ~name inner obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~lower:!.inner ~upper:!.inner\n |> finish (name ^ \"Interval\") ~t_toplevel_annots\n\n let%test_module \"ClosedInterval\" =\n ( module struct\n module IntClosedInterval = struct\n type t_ = int t [@@deriving sexp, equal, compare]\n\n (* Note: nonrec doesn't work with ppx-deriving *)\n type t = t_ [@@deriving sexp, equal, compare]\n\n let v = { lower = 10; upper = 100 }\n end\n\n let%test_unit \"roundtrip json\" =\n let open Fields_derivers_zkapps.Derivers in\n let full = o () in\n let _a : _ Unified_input.t = deriver ~name:\"Int\" int full in\n [%test_eq: IntClosedInterval.t]\n (!(full#of_json) (!(full#to_json) IntClosedInterval.v))\n IntClosedInterval.v\n end )\nend\n\nlet assert_ b e = if b then Ok () else Or_error.error_string e\n\n(* Proofs are produced against a predicate on the protocol state. For the\n transaction to go through, the predicate must be satisfied of the protocol\n state at the time of transaction application. *)\nmodule Numeric = struct\n module Tc = struct\n type ('var, 'a) t =\n { zero : 'a\n ; max_value : 'a\n ; compare : 'a -> 'a -> int\n ; equal : 'a -> 'a -> bool\n ; typ : ('var, 'a) Typ.t\n ; to_input : 'a -> F.t Random_oracle_input.Chunked.t\n ; to_input_checked : 'var -> Field.Var.t Random_oracle_input.Chunked.t\n ; lte_checked : 'var -> 'var -> Boolean.var\n ; eq_checked : 'var -> 'var -> Boolean.var\n }\n\n let run f x y = Impl.run_checked (f x y)\n\n let ( !! ) f = Fn.compose Impl.run_checked f\n\n let length =\n Length.\n { zero\n ; max_value\n ; compare\n ; lte_checked = run Checked.( <= )\n ; eq_checked = run Checked.( = )\n ; equal\n ; typ\n ; to_input\n ; to_input_checked = Checked.to_input\n }\n\n let amount =\n Currency.Amount.\n { zero\n ; max_value = max_int\n ; compare\n ; lte_checked = run Checked.( <= )\n ; eq_checked = run Checked.( = )\n ; equal\n ; typ\n ; to_input\n ; to_input_checked = var_to_input\n }\n\n let balance =\n Currency.Balance.\n { zero\n ; max_value = max_int\n ; compare\n ; lte_checked = run Checked.( <= )\n ; eq_checked = run Checked.( = )\n ; equal\n ; typ\n ; to_input\n ; to_input_checked = var_to_input\n }\n\n let nonce =\n Account_nonce.\n { zero\n ; max_value\n ; compare\n ; lte_checked = run Checked.( <= )\n ; eq_checked = run Checked.( = )\n ; equal\n ; typ\n ; to_input\n ; to_input_checked = Checked.to_input\n }\n\n let global_slot =\n Global_slot_since_genesis.\n { zero\n ; max_value\n ; compare\n ; lte_checked = run Checked.( <= )\n ; eq_checked = run Checked.( = )\n ; equal\n ; typ\n ; to_input\n ; to_input_checked = Checked.to_input\n }\n end\n\n open Tc\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = 'a Closed_interval.Stable.V1.t Or_ignore.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n end\n end]\n\n let deriver name inner range_max obj =\n let closed_interval obj' = Closed_interval.deriver ~name inner obj' in\n Or_ignore.deriver_interval ~range_max closed_interval obj\n\n module Derivers = struct\n open Fields_derivers_zkapps.Derivers\n\n let range_uint32 =\n Unsigned_extended.UInt32.(to_string zero, to_string max_int)\n\n let range_uint64 =\n Unsigned_extended.UInt64.(to_string zero, to_string max_int)\n\n let block_time_inner obj =\n let ( ^^ ) = Fn.compose in\n iso_string ~name:\"BlockTime\" ~js_type:UInt64\n ~of_string:(Block_time.of_uint64 ^^ Unsigned_extended.UInt64.of_string)\n ~to_string:(Unsigned_extended.UInt64.to_string ^^ Block_time.to_uint64)\n obj\n\n let nonce obj = deriver \"Nonce\" uint32 range_uint32 obj\n\n let balance obj = deriver \"Balance\" balance range_uint64 obj\n\n let amount obj = deriver \"CurrencyAmount\" amount range_uint64 obj\n\n let length obj = deriver \"Length\" uint32 range_uint32 obj\n\n let global_slot_since_genesis obj =\n deriver \"GlobalSlotSinceGenesis\" global_slot_since_genesis range_uint32\n obj\n\n let block_time obj = deriver \"BlockTime\" block_time_inner range_uint64 obj\n end\n\n let%test_module \"Numeric\" =\n ( module struct\n module Int_numeric = struct\n type t_ = int t [@@deriving sexp, equal, compare]\n\n (* Note: nonrec doesn't work with ppx-deriving *)\n type t = t_ [@@deriving sexp, equal, compare]\n end\n\n module T = struct\n type t = { foo : Int_numeric.t }\n [@@deriving annot, sexp, equal, compare, fields]\n\n let v : t =\n { foo = Or_ignore.Check { Closed_interval.lower = 10; upper = 100 } }\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~foo:!.(deriver \"Int\" int (\"0\", \"1000\"))\n |> finish \"T\" ~t_toplevel_annots\n end\n\n let%test_unit \"roundtrip json\" =\n let open Fields_derivers_zkapps.Derivers in\n let full = o () in\n let _a : _ Unified_input.t = T.deriver full in\n [%test_eq: T.t] (of_json full (to_json full T.v)) T.v\n end )\n\n let gen gen_a compare_a = Or_ignore.gen (Closed_interval.gen gen_a compare_a)\n\n let to_input { zero; max_value; to_input; _ } (t : 'a t) =\n Flagged_option.to_input'\n ~f:(Closed_interval.to_input ~f:to_input)\n ~field_of_bool\n ( match t with\n | Ignore ->\n { is_some = false\n ; data = { Closed_interval.lower = zero; upper = max_value }\n }\n | Check x ->\n { is_some = true; data = x } )\n\n module Checked = struct\n type 'a t = 'a Closed_interval.t Or_ignore.Checked.t\n\n let to_input { to_input_checked; _ } (t : 'a t) =\n Or_ignore.Checked.to_input t\n ~f:(Closed_interval.to_input ~f:to_input_checked)\n\n open Impl\n\n let check { lte_checked = ( <= ); _ } (t : 'a t) (x : 'a) =\n Or_ignore.Checked.check t ~f:(fun { lower; upper } ->\n Boolean.all [ lower <= x; x <= upper ] )\n\n let is_constant { eq_checked = ( = ); _ } (t : 'a t) =\n let is_constant ({ lower; upper } : _ Closed_interval.t) =\n lower = upper\n in\n Boolean.( &&& )\n (Or_ignore.Checked.is_check t)\n (is_constant (Or_ignore.Checked.data t))\n end\n\n let typ { zero; max_value; typ; _ } =\n Or_ignore.typ (Closed_interval.typ typ)\n ~ignore:{ Closed_interval.lower = zero; upper = max_value }\n\n let check ~label { compare; _ } (t : 'a t) (x : 'a) =\n match t with\n | Ignore ->\n Ok ()\n | Check { lower; upper } ->\n if compare lower x <= 0 && compare x upper <= 0 then Ok ()\n else Or_error.errorf \"Bounds check failed: %s\" label\n\n let is_constant { equal = ( = ); _ } (t : 'a t) =\n match t with Ignore -> false | Check { lower; upper } -> lower = upper\nend\n\nmodule Eq_data = struct\n include Or_ignore\n\n module Tc = struct\n type ('var, 'a) t =\n { equal : 'a -> 'a -> bool\n ; equal_checked : 'var -> 'var -> Boolean.var\n ; default : 'a\n ; typ : ('var, 'a) Typ.t\n ; to_input : 'a -> F.t Random_oracle_input.Chunked.t\n ; to_input_checked : 'var -> Field.Var.t Random_oracle_input.Chunked.t\n }\n\n let run f x y = Impl.run_checked (f x y)\n\n let field =\n let open Random_oracle_input.Chunked in\n Field.\n { typ\n ; equal\n ; equal_checked = run Checked.equal\n ; default = zero\n ; to_input = field\n ; to_input_checked = field\n }\n\n let action_state =\n let open Random_oracle_input.Chunked in\n lazy\n Field.\n { typ\n ; equal\n ; equal_checked = run Checked.equal\n ; default = Zkapp_account.Actions.empty_state_element\n ; to_input = field\n ; to_input_checked = field\n }\n\n let boolean =\n let open Random_oracle_input.Chunked in\n Boolean.\n { typ\n ; equal = Bool.equal\n ; equal_checked = run equal\n ; default = false\n ; to_input = (fun b -> packed (field_of_bool b, 1))\n ; to_input_checked =\n (fun (b : Boolean.var) -> packed ((b :> Field.Var.t), 1))\n }\n\n let receipt_chain_hash =\n Receipt.Chain_hash.\n { field with\n to_input_checked = var_to_input\n ; typ\n ; equal\n ; equal_checked = run equal_var\n }\n\n let ledger_hash =\n Ledger_hash.\n { field with\n to_input_checked = var_to_input\n ; typ\n ; equal\n ; equal_checked = run equal_var\n }\n\n let frozen_ledger_hash =\n Frozen_ledger_hash.\n { field with\n to_input_checked = var_to_input\n ; typ\n ; equal\n ; equal_checked = run equal_var\n }\n\n let state_hash =\n State_hash.\n { field with\n to_input_checked = var_to_input\n ; typ\n ; equal\n ; equal_checked = run equal_var\n }\n\n let token_id =\n Token_id.\n { default\n ; to_input_checked = Checked.to_input\n ; to_input\n ; typ\n ; equal\n ; equal_checked = Checked.equal\n }\n\n let epoch_seed =\n Epoch_seed.\n { field with\n to_input_checked = var_to_input\n ; typ\n ; equal\n ; equal_checked = run equal_var\n }\n\n let public_key () =\n Public_key.Compressed.\n { default = invalid_public_key\n ; to_input\n ; to_input_checked = Checked.to_input\n ; equal_checked = run Checked.equal\n ; typ\n ; equal\n }\n end\n\n let to_input { Tc.default; to_input; _ } (t : _ t) =\n Flagged_option.to_input' ~f:to_input ~field_of_bool\n ( match t with\n | Ignore ->\n { is_some = false; data = default }\n | Check data ->\n { is_some = true; data } )\n\n let to_input_checked { Tc.to_input_checked; _ } (t : _ Checked.t) =\n Checked.to_input t ~f:to_input_checked\n\n let check_checked { Tc.equal_checked; _ } (t : 'a Checked.t) (x : 'a) =\n Checked.check t ~f:(equal_checked x)\n\n let check ?(label = \"\") { Tc.equal; _ } (t : 'a t) (x : 'a) =\n match t with\n | Ignore ->\n Ok ()\n | Check y ->\n if equal x y then Ok ()\n else Or_error.errorf \"Equality check failed: %s\" label\n\n let typ { Tc.default = ignore; typ = t; _ } = typ ~ignore t\nend\n\nmodule Hash = Eq_data\n\nmodule Leaf_typs = struct\n let public_key () =\n Public_key.Compressed.(Or_ignore.typ ~ignore:invalid_public_key typ)\n\n open Eq_data.Tc\n\n let field = Eq_data.typ field\n\n let receipt_chain_hash = Hash.typ receipt_chain_hash\n\n let ledger_hash = Hash.typ ledger_hash\n\n let frozen_ledger_hash = Hash.typ frozen_ledger_hash\n\n let state_hash = Hash.typ state_hash\n\n open Numeric.Tc\n\n let length = Numeric.typ length\n\n let amount = Numeric.typ amount\n\n let balance = Numeric.typ balance\n\n let nonce = Numeric.typ nonce\n\n let global_slot = Numeric.typ global_slot\n\n let token_id = Hash.typ token_id\nend\n\nmodule Account = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Mina_wire_types.Mina_base.Zkapp_precondition.Account.V2.t =\n { balance : Balance.Stable.V1.t Numeric.Stable.V1.t\n ; nonce : Account_nonce.Stable.V1.t Numeric.Stable.V1.t\n ; receipt_chain_hash : Receipt.Chain_hash.Stable.V1.t Hash.Stable.V1.t\n ; delegate : Public_key.Compressed.Stable.V1.t Eq_data.Stable.V1.t\n ; state : F.Stable.V1.t Eq_data.Stable.V1.t Zkapp_state.V.Stable.V1.t\n ; action_state : F.Stable.V1.t Eq_data.Stable.V1.t\n ; proved_state : bool Eq_data.Stable.V1.t\n ; is_new : bool Eq_data.Stable.V1.t\n }\n [@@deriving annot, hlist, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind balance = Numeric.gen Balance.gen Balance.compare in\n let%bind nonce = Numeric.gen Account_nonce.gen Account_nonce.compare in\n let%bind receipt_chain_hash = Or_ignore.gen Receipt.Chain_hash.gen in\n let%bind delegate = Eq_data.gen Public_key.Compressed.gen in\n let%bind state =\n let%bind fields =\n let field_gen = Snark_params.Tick.Field.gen in\n Quickcheck.Generator.list_with_length 8 (Or_ignore.gen field_gen)\n in\n (* won't raise because length is correct *)\n Quickcheck.Generator.return (Zkapp_state.V.of_list_exn fields)\n in\n let%bind action_state =\n let%bind n = Int.gen_uniform_incl Int.min_value Int.max_value in\n let field_gen = Quickcheck.Generator.return (F.of_int n) in\n Or_ignore.gen field_gen\n in\n let%bind proved_state = Or_ignore.gen Quickcheck.Generator.bool in\n let%map is_new = Or_ignore.gen Quickcheck.Generator.bool in\n { balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; state\n ; action_state\n ; proved_state\n ; is_new\n }\n\n let accept : t =\n { balance = Ignore\n ; nonce = Ignore\n ; receipt_chain_hash = Ignore\n ; delegate = Ignore\n ; state =\n Vector.init Zkapp_state.Max_state_size.n ~f:(fun _ -> Or_ignore.Ignore)\n ; action_state = Ignore\n ; proved_state = Ignore\n ; is_new = Ignore\n }\n\n let is_accept : t -> bool = equal accept\n\n let nonce (n : Account.Nonce.t) =\n let nonce : _ Numeric.t = Check { lower = n; upper = n } in\n { accept with nonce }\n\n let is_nonce (t : t) =\n match t.nonce with\n | Ignore ->\n false\n | Check { lower; upper } ->\n (* nonce is exact, all other fields are Ignore *)\n Mina_numbers.Account_nonce.equal lower upper\n && is_accept { t with nonce = Ignore }\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots in\n let action_state =\n needs_custom_js ~js_type:field ~name:\"ActionState\" field\n in\n Fields.make_creator obj ~balance:!.Numeric.Derivers.balance\n ~nonce:!.Numeric.Derivers.nonce\n ~receipt_chain_hash:!.(Or_ignore.deriver field)\n ~delegate:!.(Or_ignore.deriver public_key)\n ~state:!.(Zkapp_state.deriver @@ Or_ignore.deriver field)\n ~action_state:!.(Or_ignore.deriver action_state)\n ~proved_state:!.(Or_ignore.deriver bool)\n ~is_new:!.(Or_ignore.deriver bool)\n |> finish \"AccountPrecondition\" ~t_toplevel_annots\n\n let%test_unit \"json roundtrip\" =\n let b = Balance.of_nanomina_int_exn 1000 in\n let predicate : t =\n { accept with\n balance = Or_ignore.Check { Closed_interval.lower = b; upper = b }\n ; action_state = Or_ignore.Check (Field.of_int 99)\n ; proved_state = Or_ignore.Check true\n }\n in\n let module Fd = Fields_derivers_zkapps.Derivers in\n let full = deriver (Fd.o ()) in\n [%test_eq: t] predicate (predicate |> Fd.to_json full |> Fd.of_json full)\n\n let to_input\n ({ balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; state\n ; action_state\n ; proved_state\n ; is_new\n } :\n t ) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Numeric.(to_input Tc.balance balance)\n ; Numeric.(to_input Tc.nonce nonce)\n ; Hash.(to_input Tc.receipt_chain_hash receipt_chain_hash)\n ; Eq_data.(to_input (Tc.public_key ()) delegate)\n ; Vector.reduce_exn ~f:append\n (Vector.map state ~f:Eq_data.(to_input Tc.field))\n ; Eq_data.(to_input (Lazy.force Tc.action_state)) action_state\n ; Eq_data.(to_input Tc.boolean) proved_state\n ; Eq_data.(to_input Tc.boolean) is_new\n ]\n\n let digest t =\n Random_oracle.(\n hash ~init:Hash_prefix.zkapp_precondition_account\n (pack_input (to_input t)))\n\n module Checked = struct\n type t =\n { balance : Balance.var Numeric.Checked.t\n ; nonce : Account_nonce.Checked.t Numeric.Checked.t\n ; receipt_chain_hash : Receipt.Chain_hash.var Hash.Checked.t\n ; delegate : Public_key.Compressed.var Eq_data.Checked.t\n ; state : Field.Var.t Eq_data.Checked.t Zkapp_state.V.t\n ; action_state : Field.Var.t Eq_data.Checked.t\n ; proved_state : Boolean.var Eq_data.Checked.t\n ; is_new : Boolean.var Eq_data.Checked.t\n }\n [@@deriving hlist]\n\n let to_input\n ({ balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; state\n ; action_state\n ; proved_state\n ; is_new\n } :\n t ) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Numeric.(Checked.to_input Tc.balance balance)\n ; Numeric.(Checked.to_input Tc.nonce nonce)\n ; Hash.(to_input_checked Tc.receipt_chain_hash receipt_chain_hash)\n ; Eq_data.(to_input_checked (Tc.public_key ()) delegate)\n ; Vector.reduce_exn ~f:append\n (Vector.map state ~f:Eq_data.(to_input_checked Tc.field))\n ; Eq_data.(to_input_checked (Lazy.force Tc.action_state)) action_state\n ; Eq_data.(to_input_checked Tc.boolean) proved_state\n ; Eq_data.(to_input_checked Tc.boolean) is_new\n ]\n\n open Impl\n\n let checks ~new_account\n { balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; state\n ; action_state\n ; proved_state\n ; is_new\n } (a : Account.Checked.Unhashed.t) =\n [ ( Transaction_status.Failure.Account_balance_precondition_unsatisfied\n , Numeric.(Checked.check Tc.balance balance a.balance) )\n ; ( Transaction_status.Failure.Account_nonce_precondition_unsatisfied\n , Numeric.(Checked.check Tc.nonce nonce a.nonce) )\n ; ( Transaction_status.Failure\n .Account_receipt_chain_hash_precondition_unsatisfied\n , Eq_data.(\n check_checked Tc.receipt_chain_hash receipt_chain_hash\n a.receipt_chain_hash) )\n ; ( Transaction_status.Failure.Account_delegate_precondition_unsatisfied\n , Eq_data.(check_checked (Tc.public_key ()) delegate a.delegate) )\n ]\n @ [ ( Transaction_status.Failure\n .Account_action_state_precondition_unsatisfied\n , Boolean.any\n Vector.(\n to_list\n (map a.zkapp.action_state\n ~f:\n Eq_data.(\n check_checked (Lazy.force Tc.action_state) action_state) ))\n )\n ]\n @ ( Vector.(\n to_list\n (map2 state a.zkapp.app_state ~f:Eq_data.(check_checked Tc.field)))\n |> List.mapi ~f:(fun i check ->\n let failure =\n Transaction_status.Failure\n .Account_app_state_precondition_unsatisfied\n i\n in\n (failure, check) ) )\n @ [ ( Transaction_status.Failure\n .Account_proved_state_precondition_unsatisfied\n , Eq_data.(check_checked Tc.boolean proved_state a.zkapp.proved_state)\n )\n ]\n @ [ ( Transaction_status.Failure.Account_is_new_precondition_unsatisfied\n , Eq_data.(check_checked Tc.boolean is_new new_account) )\n ]\n\n let check ~new_account ~check t a =\n List.iter\n ~f:(fun (failure, passed) -> check failure passed)\n (checks ~new_account t a)\n\n let digest (t : t) =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix.zkapp_precondition_account\n (pack_input (to_input t)))\n end\n\n let typ () : (Checked.t, t) Typ.t =\n let open Leaf_typs in\n Typ.of_hlistable\n [ balance\n ; nonce\n ; receipt_chain_hash\n ; public_key ()\n ; Zkapp_state.typ (Or_ignore.typ Field.typ ~ignore:Field.zero)\n ; Or_ignore.typ Field.typ\n ~ignore:Zkapp_account.Actions.empty_state_element\n ; Or_ignore.typ Boolean.typ ~ignore:false\n ; Or_ignore.typ Boolean.typ ~ignore:false\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let checks ~new_account\n { balance\n ; nonce\n ; receipt_chain_hash\n ; delegate\n ; state\n ; action_state\n ; proved_state\n ; is_new\n } (a : Account.t) =\n [ ( Transaction_status.Failure.Account_balance_precondition_unsatisfied\n , Numeric.(check ~label:\"balance\" Tc.balance balance a.balance) )\n ; ( Transaction_status.Failure.Account_nonce_precondition_unsatisfied\n , Numeric.(check ~label:\"nonce\" Tc.nonce nonce a.nonce) )\n ; ( Transaction_status.Failure\n .Account_receipt_chain_hash_precondition_unsatisfied\n , Eq_data.(\n check ~label:\"receipt_chain_hash\" Tc.receipt_chain_hash\n receipt_chain_hash a.receipt_chain_hash) )\n ; ( Transaction_status.Failure.Account_delegate_precondition_unsatisfied\n , let tc = Eq_data.Tc.public_key () in\n Eq_data.(\n check ~label:\"delegate\" tc delegate\n (Option.value ~default:tc.default a.delegate)) )\n ]\n @\n let zkapp = Option.value ~default:Zkapp_account.default a.zkapp in\n [ ( Transaction_status.Failure.Account_action_state_precondition_unsatisfied\n , match\n List.find (Vector.to_list zkapp.action_state) ~f:(fun state ->\n Eq_data.(\n check (Lazy.force Tc.action_state) ~label:\"\" action_state state)\n |> Or_error.is_ok )\n with\n | None ->\n Error (Error.createf \"Action state mismatch\")\n | Some _ ->\n Ok () )\n ]\n @ List.mapi\n Vector.(to_list (zip state zkapp.app_state))\n ~f:(fun i (c, v) ->\n let failure =\n Transaction_status.Failure\n .Account_app_state_precondition_unsatisfied\n i\n in\n (failure, Eq_data.(check Tc.field ~label:(sprintf \"state[%d]\" i) c v))\n )\n @ [ ( Transaction_status.Failure\n .Account_proved_state_precondition_unsatisfied\n , Eq_data.(\n check ~label:\"proved_state\" Tc.boolean proved_state\n zkapp.proved_state) )\n ]\n @ [ ( Transaction_status.Failure.Account_is_new_precondition_unsatisfied\n , Eq_data.(check ~label:\"is_new\" Tc.boolean is_new new_account) )\n ]\n\n let check ~new_account ~check t a =\n List.iter\n ~f:(fun (failure, res) -> check failure (Result.is_ok res))\n (checks ~new_account t a)\nend\n\nmodule Protocol_state = struct\n (* On each numeric field, you may assert a range\n On each hash field, you may assert an equality\n *)\n\n module Epoch_data = struct\n module Poly = Epoch_data.Poly\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n (* TODO: Not sure if this should be frozen ledger hash or not *)\n type t =\n ( ( Frozen_ledger_hash.Stable.V1.t Hash.Stable.V1.t\n , Currency.Amount.Stable.V1.t Numeric.Stable.V1.t )\n Epoch_ledger.Poly.Stable.V1.t\n , Epoch_seed.Stable.V1.t Hash.Stable.V1.t\n , State_hash.Stable.V1.t Hash.Stable.V1.t\n , State_hash.Stable.V1.t Hash.Stable.V1.t\n , Length.Stable.V1.t Numeric.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ledger obj' =\n let ( !. ) =\n ( !. ) ~t_fields_annots:Epoch_ledger.Poly.t_fields_annots\n in\n Epoch_ledger.Poly.Fields.make_creator obj'\n ~hash:!.(Or_ignore.deriver field)\n ~total_currency:!.Numeric.Derivers.amount\n |> finish \"EpochLedgerPrecondition\"\n ~t_toplevel_annots:Epoch_ledger.Poly.t_toplevel_annots\n in\n let ( !. ) = ( !. ) ~t_fields_annots:Poly.t_fields_annots in\n Poly.Fields.make_creator obj ~ledger:!.ledger\n ~seed:!.(Or_ignore.deriver field)\n ~start_checkpoint:!.(Or_ignore.deriver field)\n ~lock_checkpoint:!.(Or_ignore.deriver field)\n ~epoch_length:!.Numeric.Derivers.length\n |> finish \"EpochDataPrecondition\"\n ~t_toplevel_annots:Poly.t_toplevel_annots\n\n let%test_unit \"json roundtrip\" =\n let f = Or_ignore.Check Field.one in\n let u = Length.zero in\n let a = Amount.zero in\n let predicate : t =\n { Poly.ledger =\n { Epoch_ledger.Poly.hash = f\n ; total_currency =\n Or_ignore.Check { Closed_interval.lower = a; upper = a }\n }\n ; seed = f\n ; start_checkpoint = f\n ; lock_checkpoint = f\n ; epoch_length =\n Or_ignore.Check { Closed_interval.lower = u; upper = u }\n }\n in\n let module Fd = Fields_derivers_zkapps.Derivers in\n let full = deriver (Fd.o ()) in\n [%test_eq: t] predicate (predicate |> Fd.to_json full |> Fd.of_json full)\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind ledger =\n let%bind hash = Hash.gen Frozen_ledger_hash0.gen in\n let%map total_currency = Numeric.gen Amount.gen Amount.compare in\n { Epoch_ledger.Poly.hash; total_currency }\n in\n let%bind seed = Hash.gen Epoch_seed.gen in\n let%bind start_checkpoint = Hash.gen State_hash.gen in\n let%bind lock_checkpoint = Hash.gen State_hash.gen in\n let min_epoch_length = 8 in\n let max_epoch_length = Genesis_constants.slots_per_epoch in\n let%map epoch_length =\n Numeric.gen\n (Length.gen_incl\n (Length.of_int min_epoch_length)\n (Length.of_int max_epoch_length) )\n Length.compare\n in\n { Poly.ledger; seed; start_checkpoint; lock_checkpoint; epoch_length }\n\n let to_input\n ({ ledger = { hash; total_currency }\n ; seed\n ; start_checkpoint\n ; lock_checkpoint\n ; epoch_length\n } :\n t ) =\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n [ Hash.(to_input Tc.frozen_ledger_hash hash)\n ; Numeric.(to_input Tc.amount total_currency)\n ; Hash.(to_input Tc.epoch_seed seed)\n ; Hash.(to_input Tc.state_hash start_checkpoint)\n ; Hash.(to_input Tc.state_hash lock_checkpoint)\n ; Numeric.(to_input Tc.length epoch_length)\n ]\n\n module Checked = struct\n type t =\n ( ( Frozen_ledger_hash.var Hash.Checked.t\n , Currency.Amount.var Numeric.Checked.t )\n Epoch_ledger.Poly.t\n , Epoch_seed.var Hash.Checked.t\n , State_hash.var Hash.Checked.t\n , State_hash.var Hash.Checked.t\n , Length.Checked.t Numeric.Checked.t )\n Poly.t\n\n let to_input\n ({ ledger = { hash; total_currency }\n ; seed\n ; start_checkpoint\n ; lock_checkpoint\n ; epoch_length\n } :\n t ) =\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n [ Hash.(to_input_checked Tc.frozen_ledger_hash hash)\n ; Numeric.(Checked.to_input Tc.amount total_currency)\n ; Hash.(to_input_checked Tc.epoch_seed seed)\n ; Hash.(to_input_checked Tc.state_hash start_checkpoint)\n ; Hash.(to_input_checked Tc.state_hash lock_checkpoint)\n ; Numeric.(Checked.to_input Tc.length epoch_length)\n ]\n end\n end\n\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'snarked_ledger_hash\n , 'length\n , 'global_slot\n , 'amount\n , 'epoch_data )\n t =\n ( 'snarked_ledger_hash\n , 'length\n , 'global_slot\n , 'amount\n , 'epoch_data )\n Mina_wire_types.Mina_base.Zkapp_precondition.Protocol_state.Poly\n .V1\n .t =\n { (* TODO:\n We should include staged ledger hash again! It only changes once per\n block. *)\n snarked_ledger_hash : 'snarked_ledger_hash\n ; blockchain_length : 'length\n (* TODO: This previously had epoch_count but I removed it as I believe it is redundant\n with global_slot_since_hard_fork.\n\n epoch_count in [a, b]\n\n should be equivalent to\n\n global_slot_since_hard_fork in [slots_per_epoch * a, slots_per_epoch * b]\n\n TODO: Now that we removed global_slot_since_hard_fork, maybe we want to add epoch_count back\n *)\n ; min_window_density : 'length\n ; total_currency : 'amount\n ; global_slot_since_genesis : 'global_slot\n ; staking_epoch_data : 'epoch_data\n ; next_epoch_data : 'epoch_data\n }\n [@@deriving annot, hlist, sexp, equal, yojson, hash, compare, fields]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( Frozen_ledger_hash.Stable.V1.t Hash.Stable.V1.t\n , Length.Stable.V1.t Numeric.Stable.V1.t\n , Global_slot_since_genesis.Stable.V1.t Numeric.Stable.V1.t\n , Currency.Amount.Stable.V1.t Numeric.Stable.V1.t\n , Epoch_data.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) ?skip_data =\n ( !. ) ?skip_data ~t_fields_annots:Poly.t_fields_annots\n in\n Poly.Fields.make_creator obj\n ~snarked_ledger_hash:!.(Or_ignore.deriver field)\n ~blockchain_length:!.Numeric.Derivers.length\n ~min_window_density:!.Numeric.Derivers.length\n ~total_currency:!.Numeric.Derivers.amount\n ~global_slot_since_genesis:!.Numeric.Derivers.global_slot_since_genesis\n ~staking_epoch_data:!.Epoch_data.deriver\n ~next_epoch_data:!.Epoch_data.deriver\n |> finish \"NetworkPrecondition\" ~t_toplevel_annots:Poly.t_toplevel_annots\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n (* TODO: pass in ledger hash, next available token *)\n let snarked_ledger_hash = Zkapp_basic.Or_ignore.Ignore in\n let%bind blockchain_length = Numeric.gen Length.gen Length.compare in\n let max_min_window_density =\n Genesis_constants.for_unit_tests.protocol.slots_per_sub_window\n * Genesis_constants.Constraint_constants.compiled.sub_windows_per_window\n - 1\n |> Length.of_int\n in\n let%bind min_window_density =\n Numeric.gen\n (Length.gen_incl Length.zero max_min_window_density)\n Length.compare\n in\n let%bind total_currency =\n Numeric.gen Currency.Amount.gen Currency.Amount.compare\n in\n let%bind global_slot_since_genesis =\n Numeric.gen Global_slot_since_genesis.gen\n Global_slot_since_genesis.compare\n in\n let%bind staking_epoch_data = Epoch_data.gen in\n let%map next_epoch_data = Epoch_data.gen in\n { Poly.snarked_ledger_hash\n ; blockchain_length\n ; min_window_density\n ; total_currency\n ; global_slot_since_genesis\n ; staking_epoch_data\n ; next_epoch_data\n }\n\n let to_input\n ({ snarked_ledger_hash\n ; blockchain_length\n ; min_window_density\n ; total_currency\n ; global_slot_since_genesis\n ; staking_epoch_data\n ; next_epoch_data\n } :\n t ) =\n let open Random_oracle.Input.Chunked in\n let length = Numeric.(to_input Tc.length) in\n List.reduce_exn ~f:append\n [ Hash.(to_input Tc.field snarked_ledger_hash)\n ; length blockchain_length\n ; length min_window_density\n ; Numeric.(to_input Tc.amount total_currency)\n ; Numeric.(to_input Tc.global_slot global_slot_since_genesis)\n ; Epoch_data.to_input staking_epoch_data\n ; Epoch_data.to_input next_epoch_data\n ]\n\n let digest t =\n Random_oracle.(\n hash ~init:Hash_prefix.zkapp_precondition_protocol_state\n (pack_input (to_input t)))\n\n module View = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( Frozen_ledger_hash.Stable.V1.t\n , Length.Stable.V1.t\n , Global_slot_since_genesis.Stable.V1.t\n , Currency.Amount.Stable.V1.t\n , ( ( Frozen_ledger_hash.Stable.V1.t\n , Currency.Amount.Stable.V1.t )\n Epoch_ledger.Poly.Stable.V1.t\n , Epoch_seed.Stable.V1.t\n , State_hash.Stable.V1.t\n , State_hash.Stable.V1.t\n , Length.Stable.V1.t )\n Epoch_data.Poly.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n module Checked = struct\n type t =\n ( Frozen_ledger_hash.var\n , Length.Checked.t\n , Global_slot_since_genesis.Checked.t\n , Currency.Amount.var\n , ( (Frozen_ledger_hash.var, Currency.Amount.var) Epoch_ledger.Poly.t\n , Epoch_seed.var\n , State_hash.var\n , State_hash.var\n , Length.Checked.t )\n Epoch_data.Poly.t )\n Poly.t\n end\n\n let epoch_data_deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ledger obj' =\n let ( !. ) =\n ( !. ) ~t_fields_annots:Epoch_ledger.Poly.t_fields_annots\n in\n Epoch_ledger.Poly.Fields.make_creator obj' ~hash:!.field\n ~total_currency:!.amount\n |> finish \"EpochLedger\"\n ~t_toplevel_annots:Epoch_ledger.Poly.t_toplevel_annots\n in\n let ( !. ) = ( !. ) ~t_fields_annots:Epoch_data.Poly.t_fields_annots in\n Epoch_data.Poly.Fields.make_creator obj ~ledger:!.ledger ~seed:!.field\n ~start_checkpoint:!.field ~lock_checkpoint:!.field\n ~epoch_length:!.uint32\n |> finish \"EpochData\" ~t_toplevel_annots:Epoch_data.Poly.t_toplevel_annots\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) ?skip_data =\n ( !. ) ?skip_data ~t_fields_annots:Poly.t_fields_annots\n in\n Poly.Fields.make_creator obj ~snarked_ledger_hash:!.field\n ~blockchain_length:!.uint32 ~min_window_density:!.uint32\n ~total_currency:!.amount\n ~global_slot_since_genesis:!.global_slot_since_genesis\n ~staking_epoch_data:!.epoch_data_deriver\n ~next_epoch_data:!.epoch_data_deriver\n |> finish \"NetworkView\" ~t_toplevel_annots:Poly.t_toplevel_annots\n end\n\n module Checked = struct\n type t =\n ( Frozen_ledger_hash.var Hash.Checked.t\n , Length.Checked.t Numeric.Checked.t\n , Global_slot_since_genesis.Checked.t Numeric.Checked.t\n , Currency.Amount.var Numeric.Checked.t\n , Epoch_data.Checked.t )\n Poly.Stable.Latest.t\n\n let to_input\n ({ snarked_ledger_hash\n ; blockchain_length\n ; min_window_density\n ; total_currency\n ; global_slot_since_genesis\n ; staking_epoch_data\n ; next_epoch_data\n } :\n t ) =\n let open Random_oracle.Input.Chunked in\n let length = Numeric.(Checked.to_input Tc.length) in\n List.reduce_exn ~f:append\n [ Hash.(to_input_checked Tc.frozen_ledger_hash snarked_ledger_hash)\n ; length blockchain_length\n ; length min_window_density\n ; Numeric.(Checked.to_input Tc.amount total_currency)\n ; Numeric.(Checked.to_input Tc.global_slot global_slot_since_genesis)\n ; Epoch_data.Checked.to_input staking_epoch_data\n ; Epoch_data.Checked.to_input next_epoch_data\n ]\n\n let digest t =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix.zkapp_precondition_protocol_state\n (pack_input (to_input t)))\n\n let check\n (* Bind all the fields explicity so we make sure they are all used. *)\n ({ snarked_ledger_hash\n ; blockchain_length\n ; min_window_density\n ; total_currency\n ; global_slot_since_genesis\n ; staking_epoch_data\n ; next_epoch_data\n } :\n t ) (s : View.Checked.t) =\n let open Impl in\n let epoch_ledger ({ hash; total_currency } : _ Epoch_ledger.Poly.t)\n (t : Epoch_ledger.var) =\n [ Hash.(check_checked Tc.frozen_ledger_hash) hash t.hash\n ; Numeric.(Checked.check Tc.amount) total_currency t.total_currency\n ]\n in\n let epoch_data\n ({ ledger; seed; start_checkpoint; lock_checkpoint; epoch_length } :\n _ Epoch_data.Poly.t ) (t : _ Epoch_data.Poly.t) =\n ignore seed ;\n epoch_ledger ledger t.ledger\n @ [ Hash.(check_checked Tc.state_hash)\n start_checkpoint t.start_checkpoint\n ; Hash.(check_checked Tc.state_hash) lock_checkpoint t.lock_checkpoint\n ; Numeric.(Checked.check Tc.length) epoch_length t.epoch_length\n ]\n in\n Boolean.all\n ( [ Hash.(check_checked Tc.ledger_hash)\n snarked_ledger_hash s.snarked_ledger_hash\n ; Numeric.(Checked.check Tc.length)\n blockchain_length s.blockchain_length\n ; Numeric.(Checked.check Tc.length)\n min_window_density s.min_window_density\n ; Numeric.(Checked.check Tc.amount) total_currency s.total_currency\n ; Numeric.(Checked.check Tc.global_slot)\n global_slot_since_genesis s.global_slot_since_genesis\n ]\n @ epoch_data staking_epoch_data s.staking_epoch_data\n @ epoch_data next_epoch_data s.next_epoch_data )\n end\n\n let typ : (Checked.t, Stable.Latest.t) Typ.t =\n let open Poly.Stable.Latest in\n let frozen_ledger_hash = Hash.(typ Tc.frozen_ledger_hash) in\n let state_hash = Hash.(typ Tc.state_hash) in\n let epoch_seed = Hash.(typ Tc.epoch_seed) in\n let length = Numeric.(typ Tc.length) in\n let amount = Numeric.(typ Tc.amount) in\n let global_slot = Numeric.(typ Tc.global_slot) in\n let epoch_data =\n let epoch_ledger =\n let open Epoch_ledger.Poly in\n Typ.of_hlistable\n [ frozen_ledger_hash; amount ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n in\n let open Epoch_data.Poly in\n Typ.of_hlistable\n [ epoch_ledger; epoch_seed; state_hash; state_hash; length ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n in\n Typ.of_hlistable\n [ frozen_ledger_hash\n ; length\n ; length\n ; amount\n ; global_slot\n ; epoch_data\n ; epoch_data\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n let epoch_data : Epoch_data.t =\n { ledger = { hash = Ignore; total_currency = Ignore }\n ; seed = Ignore\n ; start_checkpoint = Ignore\n ; lock_checkpoint = Ignore\n ; epoch_length = Ignore\n }\n\n let accept : t =\n { snarked_ledger_hash = Ignore\n ; blockchain_length = Ignore\n ; min_window_density = Ignore\n ; total_currency = Ignore\n ; global_slot_since_genesis = Ignore\n ; staking_epoch_data = epoch_data\n ; next_epoch_data = epoch_data\n }\n\n let valid_until time : t =\n { snarked_ledger_hash = Ignore\n ; blockchain_length = Ignore\n ; min_window_density = Ignore\n ; total_currency = Ignore\n ; global_slot_since_genesis = Check time\n ; staking_epoch_data = epoch_data\n ; next_epoch_data = epoch_data\n }\n\n let%test_unit \"json roundtrip\" =\n let predicate : t = accept in\n let module Fd = Fields_derivers_zkapps.Derivers in\n let full = deriver (Fd.o ()) in\n [%test_eq: t] predicate (predicate |> Fd.to_json full |> Fd.of_json full)\n\n let check\n (* Bind all the fields explicity so we make sure they are all used. *)\n ({ snarked_ledger_hash\n ; blockchain_length\n ; min_window_density\n ; total_currency\n ; global_slot_since_genesis\n ; staking_epoch_data\n ; next_epoch_data\n } :\n t ) (s : View.t) =\n let open Or_error.Let_syntax in\n let epoch_ledger ({ hash; total_currency } : _ Epoch_ledger.Poly.t)\n (t : Epoch_ledger.Value.t) =\n let%bind () =\n Hash.(check ~label:\"epoch_ledger_hash\" Tc.frozen_ledger_hash)\n hash t.hash\n in\n let%map () =\n Numeric.(check ~label:\"epoch_ledger_total_currency\" Tc.amount)\n total_currency t.total_currency\n in\n ()\n in\n let epoch_data label\n ({ ledger; seed; start_checkpoint; lock_checkpoint; epoch_length } :\n _ Epoch_data.Poly.t ) (t : _ Epoch_data.Poly.t) =\n let l s = sprintf \"%s_%s\" label s in\n let%bind () = epoch_ledger ledger t.ledger in\n ignore seed ;\n let%bind () =\n Hash.(check ~label:(l \"start_check_point\") Tc.state_hash)\n start_checkpoint t.start_checkpoint\n in\n let%bind () =\n Hash.(check ~label:(l \"lock_check_point\") Tc.state_hash)\n lock_checkpoint t.lock_checkpoint\n in\n let%map () =\n Numeric.(check ~label:\"epoch_length\" Tc.length)\n epoch_length t.epoch_length\n in\n ()\n in\n let%bind () =\n Hash.(check ~label:\"snarked_ledger_hash\" Tc.ledger_hash)\n snarked_ledger_hash s.snarked_ledger_hash\n in\n let%bind () =\n Numeric.(check ~label:\"blockchain_length\" Tc.length)\n blockchain_length s.blockchain_length\n in\n let%bind () =\n Numeric.(check ~label:\"min_window_density\" Tc.length)\n min_window_density s.min_window_density\n in\n (* TODO: Decide whether to expose this *)\n let%bind () =\n Numeric.(check ~label:\"total_currency\" Tc.amount)\n total_currency s.total_currency\n in\n let%bind () =\n Numeric.(check ~label:\"global_slot_since_genesis\" Tc.global_slot)\n global_slot_since_genesis s.global_slot_since_genesis\n in\n let%bind () =\n epoch_data \"staking_epoch_data\" staking_epoch_data s.staking_epoch_data\n in\n let%map () =\n epoch_data \"next_epoch_data\" next_epoch_data s.next_epoch_data\n in\n ()\nend\n\nmodule Valid_while = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Global_slot_since_genesis.Stable.V1.t Numeric.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver = Numeric.Derivers.global_slot_since_genesis\n\n let gen =\n Numeric.gen Global_slot_since_genesis.gen Global_slot_since_genesis.compare\n\n let typ = Numeric.(typ Tc.global_slot)\n\n let to_input valid_while = Numeric.(to_input Tc.global_slot valid_while)\n\n let check (valid_while : t) global_slot =\n Numeric.(check ~label:\"valid_while_precondition\" Tc.global_slot)\n valid_while global_slot\n\n module Checked = struct\n type t = Global_slot_since_genesis.Checked.t Numeric.Checked.t\n\n let check (valid_while : t) global_slot =\n Numeric.(Checked.check Tc.global_slot) valid_while global_slot\n\n let to_input valid_while =\n Numeric.(Checked.to_input Tc.global_slot valid_while)\n end\nend\n\nmodule Account_type = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = User | Zkapp | None | Any\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let check (t : t) (a : A.t option) =\n match (a, t) with\n | _, Any ->\n Ok ()\n | None, None ->\n Ok ()\n | None, _ ->\n Or_error.error_string \"expected account_type = None\"\n | Some a, User ->\n assert_ (Option.is_none a.zkapp) \"expected account_type = User\"\n | Some a, Zkapp ->\n assert_ (Option.is_some a.zkapp) \"expected account_type = Zkapp\"\n | Some _, None ->\n Or_error.error_string \"no second account allowed\"\n\n let to_bits = function\n | User ->\n [ true; false ]\n | Zkapp ->\n [ false; true ]\n | None ->\n [ false; false ]\n | Any ->\n [ true; true ]\n\n let of_bits = function\n | [ user; zkapp ] -> (\n match (user, zkapp) with\n | true, false ->\n User\n | false, true ->\n Zkapp\n | false, false ->\n None\n | true, true ->\n Any )\n | _ ->\n assert false\n\n let to_input x =\n let open Random_oracle_input.Chunked in\n Array.reduce_exn ~f:append\n (Array.of_list_map (to_bits x) ~f:(fun b -> packed (field_of_bool b, 1)))\n\n module Checked = struct\n type t = { user : Boolean.var; zkapp : Boolean.var } [@@deriving hlist]\n\n let to_input { user; zkapp } =\n let open Random_oracle_input.Chunked in\n Array.reduce_exn ~f:append\n (Array.map [| user; zkapp |] ~f:(fun b ->\n packed ((b :> Field.Var.t), 1) ) )\n\n let constant =\n let open Boolean in\n function\n | User ->\n { user = true_; zkapp = false_ }\n | Zkapp ->\n { user = false_; zkapp = true_ }\n | None ->\n { user = false_; zkapp = false_ }\n | Any ->\n { user = true_; zkapp = true_ }\n\n (* TODO: Write a unit test for these. *)\n let snapp_allowed t = t.zkapp\n\n let user_allowed t = t.user\n end\n\n let typ =\n let open Checked in\n Typ.of_hlistable\n [ Boolean.typ; Boolean.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:(function\n | User ->\n [ true; false ]\n | Zkapp ->\n [ false; true ]\n | None ->\n [ false; false ]\n | Any ->\n [ true; true ] )\n ~value_of_hlist:(fun [ user; zkapp ] ->\n match (user, zkapp) with\n | true, false ->\n User\n | false, true ->\n Zkapp\n | false, false ->\n None\n | true, true ->\n Any )\nend\n\nmodule Other = struct\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('account, 'account_transition, 'vk) t =\n { predicate : 'account\n ; account_transition : 'account_transition\n ; account_vk : 'vk\n }\n [@@deriving hlist, sexp, equal, yojson, hash, compare]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Account.Stable.V2.t\n , Account_state.Stable.V1.t Transition.Stable.V1.t\n , F.Stable.V1.t Hash.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n module Checked = struct\n type t =\n ( Account.Checked.t\n , Account_state.Checked.t Transition.t\n , Field.Var.t Or_ignore.Checked.t )\n Poly.Stable.Latest.t\n\n let to_input ({ predicate; account_transition; account_vk } : t) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Account.Checked.to_input predicate\n ; Transition.to_input ~f:Account_state.Checked.to_input\n account_transition\n ; Hash.(to_input_checked Tc.field) account_vk\n ]\n end\n\n let to_input ({ predicate; account_transition; account_vk } : t) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Account.to_input predicate\n ; Transition.to_input ~f:Account_state.to_input account_transition\n ; Hash.(to_input Tc.field) account_vk\n ]\n\n let typ () =\n let open Poly in\n Typ.of_hlistable\n [ Account.typ (); Transition.typ Account_state.typ; Hash.(typ Tc.field) ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n let accept : t =\n { predicate = Account.accept\n ; account_transition = { prev = Any; next = Any }\n ; account_vk = Ignore\n }\nend\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('account, 'protocol_state, 'other, 'pk) t =\n { self_predicate : 'account\n ; other : 'other\n ; fee_payer : 'pk\n ; protocol_state_predicate : 'protocol_state\n }\n [@@deriving hlist, sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let typ spec =\n let open Stable.Latest in\n Typ.of_hlistable spec ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n ( Account.Stable.V2.t\n , Protocol_state.Stable.V1.t\n , Other.Stable.V2.t\n , Public_key.Compressed.Stable.V1.t Eq_data.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\nend]\n\nmodule Digested = F\n\nlet to_input ({ self_predicate; other; fee_payer; protocol_state_predicate } : t)\n =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Account.to_input self_predicate\n ; Other.to_input other\n ; Eq_data.(to_input (Tc.public_key ())) fee_payer\n ; Protocol_state.to_input protocol_state_predicate\n ]\n\nlet digest t =\n Random_oracle.(\n hash ~init:Hash_prefix.zkapp_precondition (pack_input (to_input t)))\n\nlet accept : t =\n { self_predicate = Account.accept\n ; other = Other.accept\n ; fee_payer = Ignore\n ; protocol_state_predicate = Protocol_state.accept\n }\n\nmodule Checked = struct\n type t =\n ( Account.Checked.t\n , Protocol_state.Checked.t\n , Other.Checked.t\n , Public_key.Compressed.var Or_ignore.Checked.t )\n Poly.Stable.Latest.t\n\n let to_input\n ({ self_predicate; other; fee_payer; protocol_state_predicate } : t) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Account.Checked.to_input self_predicate\n ; Other.Checked.to_input other\n ; Eq_data.(to_input_checked (Tc.public_key ())) fee_payer\n ; Protocol_state.Checked.to_input protocol_state_predicate\n ]\n\n let digest t =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix.zkapp_precondition (pack_input (to_input t)))\nend\n\nlet typ () : (Checked.t, Stable.Latest.t) Typ.t =\n Poly.typ\n [ Account.typ ()\n ; Other.typ ()\n ; Eq_data.(typ (Tc.public_key ()))\n ; Protocol_state.typ\n ]\n","open Snark_params\nopen Tick\n\ntype 'a t = Field.Var.t * 'a As_prover.Ref.t\n\nlet hash (x, _) = x\n\nlet ref (_, x) = x\n\nlet typ ~hash =\n Typ.transport\n Typ.(Field.typ * Internal.ref ())\n ~there:(fun s -> (hash s, s))\n ~back:(fun (_, s) -> s)\n\nlet optional_typ ~hash ~non_preimage ~dummy_value =\n Typ.transport\n Typ.(Field.typ * Internal.ref ())\n ~there:(function\n | None -> (non_preimage, dummy_value) | Some s -> (hash s, s) )\n ~back:(fun (_, s) -> Some s)\n\nlet lazy_optional_typ ~hash ~non_preimage ~dummy_value =\n Typ.transport\n Typ.(Field.typ * Internal.ref ())\n ~there:(function\n | None -> (Lazy.force non_preimage, dummy_value) | Some s -> (hash s, s)\n )\n ~back:(fun (_, s) -> Some s)\n\nlet to_input (x, _) = Random_oracle_input.Chunked.field x\n\nlet if_ b ~then_ ~else_ =\n let open Run in\n let hash = Field.if_ b ~then_:(fst then_) ~else_:(fst else_) in\n let ref =\n As_prover.Ref.create\n As_prover.(\n fun () ->\n let ref = if read Boolean.typ b then snd then_ else snd else_ in\n As_prover.Ref.get ref)\n in\n (hash, ref)\n\nlet make_unsafe hash ref : 'a t = (hash, ref)\n\nmodule As_record = struct\n (* it's OK that hash is a Field.t (not a var), bc this is just annotation for the deriver *)\n type 'a t = { data : 'a; hash : Field.t } [@@deriving annot, fields]\nend\n\nlet deriver inner obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots:As_record.t_fields_annots in\n As_record.Fields.make_creator obj ~data:!.inner ~hash:!.field\n |> finish \"Events\" ~t_toplevel_annots:As_record.t_toplevel_annots\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_util\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nopen Signature_lib\nmodule Impl = Pickles.Impls.Step\nopen Mina_numbers\nopen Currency\nopen Pickles_types\nmodule Digest = Random_oracle.Digest\n\nmodule type Type = sig\n type t\nend\n\nmodule Authorization_kind = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n (* TODO: yojson for Field.t in snarky (#12591) *)\n type t =\n Mina_wire_types.Mina_base.Account_update.Authorization_kind.V1.t =\n | Signature\n | Proof of\n (Field.t\n [@version_asserted]\n [@to_yojson fun t -> `String (Snark_params.Tick.Field.to_string t)]\n [@of_yojson\n function\n | `String s ->\n let field = Snark_params.Tick.Field.of_string s in\n let s' = Snark_params.Tick.Field.to_string field in\n if String.equal s s' then Ok field\n else Error \"Invalid JSON for field\"\n | _ ->\n Error \"expected JSON string\"] )\n | None_given\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n module Structured = struct\n type t =\n { is_signed : bool\n ; is_proved : bool\n ; verification_key_hash : Snark_params.Tick.Field.t\n }\n [@@deriving hlist, annot, fields]\n\n let to_input ({ is_signed; is_proved; verification_key_hash } : t) =\n let f x = if x then Field.one else Field.zero in\n Random_oracle_input.Chunked.append\n (Random_oracle_input.Chunked.packeds\n [| (f is_signed, 1); (f is_proved, 1) |] )\n (Random_oracle_input.Chunked.field verification_key_hash)\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n type t =\n { is_signed : Boolean.var\n ; is_proved : Boolean.var\n ; verification_key_hash : Snark_params.Tick.Field.Var.t\n }\n [@@deriving hlist]\n\n let to_input { is_signed; is_proved; verification_key_hash } =\n let f (x : Boolean.var) = (x :> Field.Var.t) in\n Random_oracle_input.Chunked.append\n (Random_oracle_input.Chunked.packeds\n [| (f is_signed, 1); (f is_proved, 1) |] )\n (Random_oracle_input.Chunked.field verification_key_hash)\n end\n\n let typ =\n Typ.of_hlistable ~var_to_hlist:Checked.to_hlist\n ~var_of_hlist:Checked.of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n [ Boolean.typ; Boolean.typ; Field.typ ]\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let open Fields in\n let ( !. ) = ( !. ) ~t_fields_annots in\n let verification_key_hash =\n needs_custom_js ~js_type:field ~name:\"VerificationKeyHash\" field\n in\n Fields.make_creator obj ~is_signed:!.bool ~is_proved:!.bool\n ~verification_key_hash:!.verification_key_hash\n |> finish \"AuthorizationKindStructured\" ~t_toplevel_annots\n\n [%%endif]\n end\n\n let to_control_tag : t -> Control.Tag.t = function\n | None_given ->\n None_given\n | Signature ->\n Signature\n | Proof _ ->\n Proof\n\n let to_structured : t -> Structured.t = function\n | None_given ->\n { is_signed = false\n ; is_proved = false\n ; verification_key_hash = Zkapp_account.dummy_vk_hash ()\n }\n | Signature ->\n { is_signed = true\n ; is_proved = false\n ; verification_key_hash = Zkapp_account.dummy_vk_hash ()\n }\n | Proof verification_key_hash ->\n { is_signed = false; is_proved = true; verification_key_hash }\n\n let of_structured_exn : Structured.t -> t = function\n | { is_signed = false; is_proved = false; _ } ->\n None_given\n | { is_signed = true; is_proved = false; _ } ->\n Signature\n | { is_signed = false; is_proved = true; verification_key_hash } ->\n Proof verification_key_hash\n | { is_signed = true; is_proved = true; _ } ->\n failwith \"Invalid authorization kind\"\n\n let gen =\n let%bind.Quickcheck vk_hash = Field.gen in\n Quickcheck.Generator.of_list [ None_given; Signature; Proof vk_hash ]\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n iso_record ~to_record:to_structured ~of_record:of_structured_exn\n Structured.deriver obj\n\n let to_input x = Structured.to_input (to_structured x)\n\n [%%ifdef consensus_mechanism]\n\n module Checked = Structured.Checked\n\n let typ =\n Structured.typ |> Typ.transport ~there:to_structured ~back:of_structured_exn\n\n [%%endif]\nend\n\nmodule May_use_token = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Account_update.May_use_token.V1.t =\n | No\n (** No permission to use any token other than the default Mina\n token.\n *)\n | Parents_own_token\n (** Has permission to use the token owned by the direct parent of\n this account update, which may be inherited by child account\n updates.\n *)\n | Inherit_from_parent\n (** Inherit the token permission available to the parent. *)\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen =\n Quickcheck.Generator.of_list [ No; Parents_own_token; Inherit_from_parent ]\n\n let to_string = function\n | No ->\n \"No\"\n | Parents_own_token ->\n \"ParentsOwnToken\"\n | Inherit_from_parent ->\n \"InheritFromParent\"\n\n let of_string = function\n | \"No\" ->\n No\n | \"ParentsOwnToken\" ->\n Parents_own_token\n | \"InheritFromParent\" ->\n Inherit_from_parent\n | s ->\n failwithf \"Invalid call type: %s\" s ()\n\n let parents_own_token = function Parents_own_token -> true | _ -> false\n\n let inherit_from_parent = function Inherit_from_parent -> true | _ -> false\n\n module As_record : sig\n type variant = t\n\n type 'bool t\n\n val parents_own_token : 'bool t -> 'bool\n\n val inherit_from_parent : 'bool t -> 'bool\n\n val map : f:('a -> 'b) -> 'a t -> 'b t\n\n val to_hlist : 'bool t -> (unit, 'bool -> 'bool -> unit) H_list.t\n\n val of_hlist : (unit, 'bool -> 'bool -> unit) H_list.t -> 'bool t\n\n val to_input :\n field_of_bool:('a -> 'b) -> 'a t -> 'b Random_oracle_input.Chunked.t\n\n val typ : (Snark_params.Tick.Boolean.var t, bool t) Snark_params.Tick.Typ.t\n\n val equal :\n and_:('bool -> 'bool -> 'bool)\n -> equal:('a -> 'a -> 'bool)\n -> 'a t\n -> 'a t\n -> 'bool\n\n val to_variant : bool t -> variant\n\n val of_variant : variant -> bool t\n\n (* TODO: Create an alias for this type *)\n val deriver :\n ( bool t\n , ( ( ( bool t\n , ( bool t\n , ( bool t\n , ( ( bool t\n , ( bool t\n , ( bool t\n , ( (< contramap : (bool t -> bool t) Core_kernel.ref\n ; graphql_arg :\n ( unit\n -> bool t\n Fields_derivers_graphql.Schema.Arg\n .arg_typ )\n Core_kernel.ref\n ; graphql_arg_accumulator :\n bool t\n Fields_derivers_zkapps.Derivers.Graphql.Args\n .Acc\n .T\n .t\n Core_kernel.ref\n ; graphql_creator :\n ( ( ( 'a\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers\n .Graphql\n .Args\n .Output\n .t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql\n .Args\n .Input\n .t\n -> bool t )\n Core_kernel.ref\n ; graphql_fields :\n bool t\n Fields_derivers_zkapps.Derivers.Graphql\n .Fields\n .Input\n .T\n .t\n Core_kernel.ref\n ; graphql_fields_accumulator :\n bool t\n Fields_derivers_zkapps.Derivers.Graphql\n .Fields\n .Accumulator\n .T\n .t\n list\n Core_kernel.ref\n ; graphql_query : string option Core_kernel.ref\n ; graphql_query_accumulator :\n (Core_kernel.String.t * string option)\n option\n list\n Core_kernel.ref\n ; js_layout :\n [> `Assoc of (string * Yojson.Safe.t) list ]\n Core_kernel.ref\n ; js_layout_accumulator :\n Fields_derivers_zkapps__.Fields_derivers_js\n .Js_layout\n .Accumulator\n .field\n option\n list\n Core_kernel.ref\n ; map : (bool t -> bool t) Core_kernel.ref\n ; nullable_graphql_arg :\n ( unit\n -> 'b\n Fields_derivers_graphql.Schema.Arg\n .arg_typ )\n Core_kernel.ref\n ; nullable_graphql_fields :\n bool t option\n Fields_derivers_zkapps.Derivers.Graphql\n .Fields\n .Input\n .T\n .t\n Core_kernel.ref\n ; of_json :\n (Yojson.Safe.t -> bool t) Core_kernel.ref\n ; of_json_creator :\n Yojson.Safe.t Core_kernel.String.Map.t\n Core_kernel.ref\n ; skip : bool Core_kernel.ref\n ; to_json :\n (bool t -> Yojson.Safe.t) Core_kernel.ref\n ; to_json_accumulator :\n ( Core_kernel.String.t\n * (bool t -> Yojson.Safe.t) )\n option\n list\n Core_kernel.ref\n ; .. >\n as\n 'a )\n Fields_derivers_zkapps__.Fields_derivers_js\n .Js_layout\n .Input\n .t\n Fields_derivers_graphql.Graphql_query.Input.t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql.Args.Input\n .t\n , bool t\n , bool t option )\n Fields_derivers_zkapps.Derivers.Graphql.Fields.Input\n .t\n , bool t )\n Fields_derivers_json.Of_yojson.Input.t\n , bool t )\n Fields_derivers_json.To_yojson.Input.t\n Fields_derivers_zkapps.Unified_input.t\n Fields_derivers_zkapps__.Fields_derivers_js.Js_layout\n .Input\n .t\n Fields_derivers_graphql.Graphql_query.Input.t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql.Args.Input.t\n , bool t\n , bool t option )\n Fields_derivers_zkapps.Derivers.Graphql.Fields.Input.t\n , bool t )\n Fields_derivers_json.Of_yojson.Input.t\n , bool t )\n Fields_derivers_json.To_yojson.Input.t\n Fields_derivers_zkapps.Unified_input.t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql.Args.Input.t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql.Args.Acc.t\n , bool t\n , bool t option )\n Fields_derivers_zkapps.Derivers.Graphql.Fields.Accumulator.t\n -> ( bool t\n , ( bool t\n , ( bool t\n , ( 'a Fields_derivers_zkapps__.Fields_derivers_js.Js_layout.Input.t\n Fields_derivers_graphql.Graphql_query.Input.t\n , bool t\n , bool t\n , 'b )\n Fields_derivers_zkapps.Derivers.Graphql.Args.Input.t\n , bool t\n , bool t option )\n Fields_derivers_zkapps.Derivers.Graphql.Fields.Input.t\n , bool t )\n Fields_derivers_json.Of_yojson.Input.t\n , bool t )\n Fields_derivers_json.To_yojson.Input.t\n Fields_derivers_zkapps.Unified_input.t\n end = struct\n type variant = t\n\n type 'bool t =\n { (* NB: call is implicit. *)\n parents_own_token : 'bool\n ; inherit_from_parent : 'bool\n }\n [@@deriving annot, hlist, fields]\n\n let map ~f { parents_own_token; inherit_from_parent } =\n { parents_own_token = f parents_own_token\n ; inherit_from_parent = f inherit_from_parent\n }\n\n let typ : _ Typ.t =\n let open Snark_params.Tick in\n let (Typ typ) =\n Typ.of_hlistable\n [ Boolean.typ; Boolean.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n in\n Typ\n { typ with\n check =\n (fun ({ parents_own_token; inherit_from_parent } as x) ->\n let open Checked in\n let%bind () = typ.check x in\n let sum =\n Field.Var.(\n add (parents_own_token :> t) (inherit_from_parent :> t))\n in\n (* Assert boolean; we should really have a helper for this\n somewhere.\n *)\n let%bind sum_squared = Field.Checked.mul sum sum in\n Field.Checked.Assert.equal sum sum_squared )\n }\n\n let to_input ~field_of_bool { parents_own_token; inherit_from_parent } =\n Array.reduce_exn ~f:Random_oracle_input.Chunked.append\n [| Random_oracle_input.Chunked.packed\n (field_of_bool parents_own_token, 1)\n ; Random_oracle_input.Chunked.packed\n (field_of_bool inherit_from_parent, 1)\n |]\n\n let equal ~and_ ~equal\n { parents_own_token = parents_own_token1\n ; inherit_from_parent = inherit_from_parent1\n }\n { parents_own_token = parents_own_token2\n ; inherit_from_parent = inherit_from_parent2\n } =\n and_\n (equal parents_own_token1 parents_own_token2)\n (equal inherit_from_parent1 inherit_from_parent2)\n\n let to_variant = function\n | { parents_own_token = false; inherit_from_parent = false } ->\n No\n | { parents_own_token = true; inherit_from_parent = false } ->\n Parents_own_token\n | { parents_own_token = false; inherit_from_parent = true } ->\n Inherit_from_parent\n | _ ->\n failwith \"May_use_token.to_variant: More than one boolean flag is set\"\n\n let of_variant = function\n | No ->\n { parents_own_token = false; inherit_from_parent = false }\n | Parents_own_token ->\n { parents_own_token = true; inherit_from_parent = false }\n | Inherit_from_parent ->\n { parents_own_token = false; inherit_from_parent = true }\n\n let deriver obj : _ Fields_derivers_zkapps.Unified_input.t =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~parents_own_token:!.bool\n ~inherit_from_parent:!.bool\n |> finish \"MayUseToken\" ~t_toplevel_annots\n end\n\n let quickcheck_generator = gen\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n iso_record ~of_record:As_record.to_variant ~to_record:As_record.of_variant\n As_record.deriver obj\n\n module Checked = struct\n type t = Boolean.var As_record.t\n\n let parents_own_token = As_record.parents_own_token\n\n let inherit_from_parent = As_record.inherit_from_parent\n\n let constant x =\n As_record.map ~f:Boolean.var_of_value @@ As_record.of_variant x\n\n let to_input (x : t) =\n As_record.to_input\n ~field_of_bool:(fun (x : Boolean.var) -> (x :> Field.Var.t))\n x\n\n let equal x y =\n As_record.equal ~equal:Run.Boolean.equal ~and_:Run.Boolean.( &&& ) x y\n\n let assert_equal x y =\n As_record.equal ~equal:Run.Boolean.Assert.( = ) ~and_:(fun _ _ -> ()) x y\n end\n\n let to_input x = As_record.to_input ~field_of_bool (As_record.of_variant x)\n\n let typ : (Checked.t, t) Typ.t =\n As_record.typ\n |> Typ.transport ~there:As_record.of_variant ~back:As_record.to_variant\nend\n\nmodule Update = struct\n module Timing_info = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n Mina_wire_types.Mina_base.Account_update.Update.Timing_info.V1.t =\n { initial_minimum_balance : Balance.Stable.V1.t\n ; cliff_time : Global_slot_since_genesis.Stable.V1.t\n ; cliff_amount : Amount.Stable.V1.t\n ; vesting_period : Global_slot_span.Stable.V1.t\n ; vesting_increment : Amount.Stable.V1.t\n }\n [@@deriving annot, compare, equal, sexp, hash, yojson, hlist, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n type value = t\n\n let gen =\n let open Quickcheck.Let_syntax in\n let%bind initial_minimum_balance = Balance.gen in\n let%bind cliff_time = Global_slot_since_genesis.gen in\n let%bind cliff_amount =\n Amount.gen_incl Amount.zero (Balance.to_amount initial_minimum_balance)\n in\n let%bind vesting_period =\n Global_slot_span.gen_incl\n Global_slot_span.(succ zero)\n (Global_slot_span.of_int 10)\n in\n let%map vesting_increment =\n Amount.gen_incl Amount.one (Amount.of_nanomina_int_exn 100)\n in\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n }\n\n let to_input (t : t) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Balance.to_input t.initial_minimum_balance\n ; Global_slot_since_genesis.to_input t.cliff_time\n ; Amount.to_input t.cliff_amount\n ; Global_slot_span.to_input t.vesting_period\n ; Amount.to_input t.vesting_increment\n ]\n\n let dummy =\n let slot_unused = Global_slot_since_genesis.zero in\n let slot_span_unused = Global_slot_span.zero in\n let balance_unused = Balance.zero in\n let amount_unused = Amount.zero in\n { initial_minimum_balance = balance_unused\n ; cliff_time = slot_unused\n ; cliff_amount = amount_unused\n ; vesting_period = slot_span_unused\n ; vesting_increment = amount_unused\n }\n\n let to_account_timing (t : t) : Account_timing.t =\n Timed\n { initial_minimum_balance = t.initial_minimum_balance\n ; cliff_time = t.cliff_time\n ; cliff_amount = t.cliff_amount\n ; vesting_period = t.vesting_period\n ; vesting_increment = t.vesting_increment\n }\n\n let of_account_timing (t : Account_timing.t) : t option =\n match t with\n | Untimed ->\n None\n | Timed t ->\n Some\n { initial_minimum_balance = t.initial_minimum_balance\n ; cliff_time = t.cliff_time\n ; cliff_amount = t.cliff_amount\n ; vesting_period = t.vesting_period\n ; vesting_increment = t.vesting_increment\n }\n\n module Checked = struct\n type t =\n { initial_minimum_balance : Balance.Checked.t\n ; cliff_time : Global_slot_since_genesis.Checked.t\n ; cliff_amount : Amount.Checked.t\n ; vesting_period : Global_slot_span.Checked.t\n ; vesting_increment : Amount.Checked.t\n }\n [@@deriving hlist]\n\n let constant (t : value) : t =\n { initial_minimum_balance = Balance.var_of_t t.initial_minimum_balance\n ; cliff_time = Global_slot_since_genesis.Checked.constant t.cliff_time\n ; cliff_amount = Amount.var_of_t t.cliff_amount\n ; vesting_period = Global_slot_span.Checked.constant t.vesting_period\n ; vesting_increment = Amount.var_of_t t.vesting_increment\n }\n\n let to_input\n ({ initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } :\n t ) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Balance.var_to_input initial_minimum_balance\n ; Global_slot_since_genesis.Checked.to_input cliff_time\n ; Amount.var_to_input cliff_amount\n ; Global_slot_span.Checked.to_input vesting_period\n ; Amount.var_to_input vesting_increment\n ]\n\n let to_account_timing (t : t) : Account_timing.var =\n { is_timed = Boolean.true_\n ; initial_minimum_balance = t.initial_minimum_balance\n ; cliff_time = t.cliff_time\n ; cliff_amount = t.cliff_amount\n ; vesting_period = t.vesting_period\n ; vesting_increment = t.vesting_increment\n }\n\n let of_account_timing (t : Account_timing.var) : t =\n { initial_minimum_balance = t.initial_minimum_balance\n ; cliff_time = t.cliff_time\n ; cliff_amount = t.cliff_amount\n ; vesting_period = t.vesting_period\n ; vesting_increment = t.vesting_increment\n }\n end\n\n let typ : (Checked.t, t) Typ.t =\n Typ.of_hlistable\n [ Balance.typ\n ; Global_slot_since_genesis.typ\n ; Amount.typ\n ; Global_slot_span.typ\n ; Amount.typ\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~initial_minimum_balance:!.balance\n ~cliff_time:!.global_slot_since_genesis\n ~cliff_amount:!.amount ~vesting_period:!.global_slot_span\n ~vesting_increment:!.amount\n |> finish \"Timing\" ~t_toplevel_annots\n end\n\n open Zkapp_basic\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n (* TODO: Have to check that the public key is not = Public_key.Compressed.empty here. *)\n type t = Mina_wire_types.Mina_base.Account_update.Update.V1.t =\n { app_state :\n F.Stable.V1.t Set_or_keep.Stable.V1.t Zkapp_state.V.Stable.V1.t\n ; delegate : Public_key.Compressed.Stable.V1.t Set_or_keep.Stable.V1.t\n ; verification_key :\n Verification_key_wire.Stable.V1.t Set_or_keep.Stable.V1.t\n ; permissions : Permissions.Stable.V2.t Set_or_keep.Stable.V1.t\n ; zkapp_uri : string Set_or_keep.Stable.V1.t\n ; token_symbol :\n Account.Token_symbol.Stable.V1.t Set_or_keep.Stable.V1.t\n ; timing : Timing_info.Stable.V1.t Set_or_keep.Stable.V1.t\n ; voting_for : State_hash.Stable.V1.t Set_or_keep.Stable.V1.t\n }\n [@@deriving annot, compare, equal, sexp, hash, yojson, fields, hlist]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen ?(token_account = false) ?(zkapp_account = false) ?vk\n ?permissions_auth () : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind app_state =\n let%bind fields =\n let field_gen = Snark_params.Tick.Field.gen in\n Quickcheck.Generator.list_with_length 8 (Set_or_keep.gen field_gen)\n in\n (* won't raise because length is correct *)\n Quickcheck.Generator.return (Zkapp_state.V.of_list_exn fields)\n in\n let%bind delegate =\n if not token_account then Set_or_keep.gen Public_key.Compressed.gen\n else return Set_or_keep.Keep\n in\n let%bind verification_key =\n if zkapp_account then\n Set_or_keep.gen\n (Quickcheck.Generator.return\n ( match vk with\n | None ->\n let data = Pickles.Side_loaded.Verification_key.dummy in\n let hash = Zkapp_account.digest_vk data in\n { With_hash.data; hash }\n | Some vk ->\n vk ) )\n else return Set_or_keep.Keep\n in\n let%bind permissions =\n match permissions_auth with\n | None ->\n return Set_or_keep.Keep\n | Some auth_tag ->\n let%map permissions = Permissions.gen ~auth_tag in\n Set_or_keep.Set permissions\n in\n let%bind zkapp_uri =\n let uri_gen =\n Quickcheck.Generator.of_list\n [ \"https://www.example.com\"\n ; \"https://www.minaprotocol.com\"\n ; \"https://www.gurgle.com\"\n ; \"https://faceplant.com\"\n ]\n in\n Set_or_keep.gen uri_gen\n in\n let%bind token_symbol =\n let token_gen =\n Quickcheck.Generator.of_list\n [ \"MINA\"; \"TOKEN1\"; \"TOKEN2\"; \"TOKEN3\"; \"TOKEN4\"; \"TOKEN5\" ]\n in\n Set_or_keep.gen token_gen\n in\n let%bind voting_for = Set_or_keep.gen Field.gen in\n (* a new account for the Account_update.t is in the ledger when we use\n this generated update in tests, so the timing must be Keep\n *)\n let timing = Set_or_keep.Keep in\n return\n ( { app_state\n ; delegate\n ; verification_key\n ; permissions\n ; zkapp_uri\n ; token_symbol\n ; timing\n ; voting_for\n }\n : t )\n\n module Checked = struct\n open Pickles.Impls.Step\n\n type t =\n { app_state : Field.t Set_or_keep.Checked.t Zkapp_state.V.t\n ; delegate : Public_key.Compressed.var Set_or_keep.Checked.t\n ; verification_key :\n ( Boolean.var\n , ( Side_loaded_verification_key.t option\n , Field.Constant.t )\n With_hash.t\n Data_as_hash.t )\n Zkapp_basic.Flagged_option.t\n Set_or_keep.Checked.t\n ; permissions : Permissions.Checked.t Set_or_keep.Checked.t\n ; zkapp_uri : string Data_as_hash.t Set_or_keep.Checked.t\n ; token_symbol : Account.Token_symbol.var Set_or_keep.Checked.t\n ; timing : Timing_info.Checked.t Set_or_keep.Checked.t\n ; voting_for : State_hash.var Set_or_keep.Checked.t\n }\n [@@deriving hlist]\n\n let to_input\n ({ app_state\n ; delegate\n ; verification_key\n ; permissions\n ; zkapp_uri\n ; token_symbol\n ; timing\n ; voting_for\n } :\n t ) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Zkapp_state.to_input app_state\n ~f:(Set_or_keep.Checked.to_input ~f:field)\n ; Set_or_keep.Checked.to_input delegate\n ~f:Public_key.Compressed.Checked.to_input\n ; Set_or_keep.Checked.to_input verification_key ~f:(fun x ->\n field (Data_as_hash.hash x.data) )\n ; Set_or_keep.Checked.to_input permissions\n ~f:Permissions.Checked.to_input\n ; Set_or_keep.Checked.to_input zkapp_uri ~f:Data_as_hash.to_input\n ; Set_or_keep.Checked.to_input token_symbol\n ~f:Account.Token_symbol.var_to_input\n ; Set_or_keep.Checked.to_input timing ~f:Timing_info.Checked.to_input\n ; Set_or_keep.Checked.to_input voting_for ~f:State_hash.var_to_input\n ]\n end\n\n let noop : t =\n { app_state =\n Vector.init Zkapp_state.Max_state_size.n ~f:(fun _ -> Set_or_keep.Keep)\n ; delegate = Keep\n ; verification_key = Keep\n ; permissions = Keep\n ; zkapp_uri = Keep\n ; token_symbol = Keep\n ; timing = Keep\n ; voting_for = Keep\n }\n\n let dummy = noop\n\n let to_input\n ({ app_state\n ; delegate\n ; verification_key\n ; permissions\n ; zkapp_uri\n ; token_symbol\n ; timing\n ; voting_for\n } :\n t ) =\n let open Random_oracle_input.Chunked in\n List.reduce_exn ~f:append\n [ Zkapp_state.to_input app_state\n ~f:(Set_or_keep.to_input ~dummy:Field.zero ~f:field)\n ; Set_or_keep.to_input delegate\n ~dummy:(Zkapp_precondition.Eq_data.Tc.public_key ()).default\n ~f:Public_key.Compressed.to_input\n ; Set_or_keep.to_input\n (Set_or_keep.map verification_key ~f:With_hash.hash)\n ~dummy:Field.zero ~f:field\n ; Set_or_keep.to_input permissions ~dummy:Permissions.empty\n ~f:Permissions.to_input\n ; Set_or_keep.to_input\n (Set_or_keep.map ~f:Zkapp_account.hash_zkapp_uri zkapp_uri)\n ~dummy:(Zkapp_account.hash_zkapp_uri_opt None)\n ~f:field\n ; Set_or_keep.to_input token_symbol ~dummy:Account.Token_symbol.default\n ~f:Account.Token_symbol.to_input\n ; Set_or_keep.to_input timing ~dummy:Timing_info.dummy\n ~f:Timing_info.to_input\n ; Set_or_keep.to_input voting_for ~dummy:State_hash.dummy\n ~f:State_hash.to_input\n ]\n\n let typ () : (Checked.t, t) Typ.t =\n let open Pickles.Impls.Step in\n Typ.of_hlistable\n [ Zkapp_state.typ (Set_or_keep.typ ~dummy:Field.Constant.zero Field.typ)\n ; Set_or_keep.typ ~dummy:Public_key.Compressed.empty\n Public_key.Compressed.typ\n ; Set_or_keep.optional_typ\n (Data_as_hash.typ ~hash:With_hash.hash)\n ~to_option:(function\n | { With_hash.data = Some data; hash } ->\n Some { With_hash.data; hash }\n | { With_hash.data = None; _ } ->\n None )\n ~of_option:(function\n | Some { With_hash.data; hash } ->\n { With_hash.data = Some data; hash }\n | None ->\n { With_hash.data = None; hash = Field.Constant.zero } )\n |> Typ.transport_var\n ~there:\n (Set_or_keep.Checked.map\n ~f:(fun { Zkapp_basic.Flagged_option.data; _ } -> data) )\n ~back:(fun x ->\n Set_or_keep.Checked.map x ~f:(fun data ->\n { Zkapp_basic.Flagged_option.data\n ; is_some = Set_or_keep.Checked.is_set x\n } ) )\n ; Set_or_keep.typ ~dummy:Permissions.empty Permissions.typ\n ; Set_or_keep.optional_typ\n (Data_as_hash.lazy_optional_typ ~hash:Zkapp_account.hash_zkapp_uri\n ~non_preimage:(lazy (Zkapp_account.hash_zkapp_uri_opt None))\n ~dummy_value:\"\" )\n ~to_option:Fn.id ~of_option:Fn.id\n ; Set_or_keep.typ ~dummy:Account.Token_symbol.default\n Account.Token_symbol.typ\n ; Set_or_keep.typ ~dummy:Timing_info.dummy Timing_info.typ\n ; Set_or_keep.typ ~dummy:State_hash.dummy State_hash.typ\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots in\n let zkapp_uri =\n needs_custom_js\n ~js_type:(Data_as_hash.deriver string)\n ~name:\"ZkappUri\" string\n in\n let token_symbol =\n needs_custom_js\n ~js_type:\n (js_record\n [ (\"symbol\", js_layout string); (\"field\", js_layout field) ] )\n ~name:\"TokenSymbol\" string\n in\n finish \"AccountUpdateModification\" ~t_toplevel_annots\n @@ Fields.make_creator\n ~app_state:!.(Zkapp_state.deriver @@ Set_or_keep.deriver field)\n ~delegate:!.(Set_or_keep.deriver public_key)\n ~verification_key:!.(Set_or_keep.deriver verification_key_with_hash)\n ~permissions:!.(Set_or_keep.deriver Permissions.deriver)\n ~zkapp_uri:!.(Set_or_keep.deriver zkapp_uri)\n ~token_symbol:!.(Set_or_keep.deriver token_symbol)\n ~timing:!.(Set_or_keep.deriver Timing_info.deriver)\n ~voting_for:!.(Set_or_keep.deriver State_hash.deriver)\n obj\nend\n\nmodule Events = Zkapp_account.Events\nmodule Actions = Zkapp_account.Actions\n\nmodule Account_precondition = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Zkapp_precondition.Account.Stable.V2.t\n [@@deriving sexp, yojson, hash]\n\n let (_ :\n ( t\n , Mina_wire_types.Mina_base.Account_update.Account_precondition.V1.t\n )\n Type_equal.t ) =\n Type_equal.T\n\n let to_latest = Fn.id\n\n [%%define_locally Zkapp_precondition.Account.(equal, compare)]\n end\n end]\n\n [%%define_locally Stable.Latest.(equal, compare)]\n\n let gen : t Quickcheck.Generator.t =\n (* we used to have 3 constructors, Full, Nonce, and Accept for the type t\n nowadays, the generator creates these 3 different kinds of values, but all mapped to t\n *)\n let open Zkapp_basic in\n Quickcheck.Generator.variant3 Zkapp_precondition.Account.gen\n Account.Nonce.gen Unit.quickcheck_generator\n |> Quickcheck.Generator.map ~f:(function\n | `A precondition ->\n precondition\n | `B n ->\n Zkapp_precondition.Account.nonce n\n | `C () ->\n Zkapp_precondition.Account.accept )\n\n module Tag = struct\n type t = Full | Nonce | Accept [@@deriving equal, compare, sexp, yojson]\n end\n\n let deriver obj = Zkapp_precondition.Account.deriver obj\n\n let digest (t : t) =\n let digest x =\n Random_oracle.(\n hash ~init:Hash_prefix_states.account_update_account_precondition\n (pack_input x))\n in\n t |> Zkapp_precondition.Account.to_input |> digest\n\n module Checked = struct\n type t = Zkapp_precondition.Account.Checked.t\n\n let digest (t : t) =\n let digest x =\n Random_oracle.Checked.(\n hash ~init:Hash_prefix_states.account_update_account_precondition\n (pack_input x))\n in\n Zkapp_precondition.Account.Checked.to_input t |> digest\n\n let nonce (t : t) = t.nonce\n end\n\n let typ () : (Zkapp_precondition.Account.Checked.t, t) Typ.t =\n Zkapp_precondition.Account.typ ()\n\n let nonce ({ nonce; _ } : t) = nonce\nend\n\nmodule Preconditions = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Account_update.Preconditions.V1.t =\n { network : Zkapp_precondition.Protocol_state.Stable.V1.t\n ; account : Account_precondition.Stable.V1.t\n ; valid_while :\n Mina_numbers.Global_slot_since_genesis.Stable.V1.t\n Zkapp_precondition.Numeric.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, hlist, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj\n ~network:!.Zkapp_precondition.Protocol_state.deriver\n ~account:!.Account_precondition.deriver\n ~valid_while:!.Zkapp_precondition.Valid_while.deriver\n |> finish \"Preconditions\" ~t_toplevel_annots\n\n let to_input ({ network; account; valid_while } : t) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Zkapp_precondition.Protocol_state.to_input network\n ; Zkapp_precondition.Account.to_input account\n ; Zkapp_precondition.Valid_while.to_input valid_while\n ]\n\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%map network = Zkapp_precondition.Protocol_state.gen\n and account = Account_precondition.gen\n and valid_while = Zkapp_precondition.Valid_while.gen in\n { network; account; valid_while }\n\n module Checked = struct\n module Type_of_var (V : sig\n type var\n end) =\n struct\n type t = V.var\n end\n\n module Int_as_prover_ref = struct\n type t = int As_prover.Ref.t\n end\n\n type t =\n { network : Zkapp_precondition.Protocol_state.Checked.t\n ; account : Account_precondition.Checked.t\n ; valid_while : Zkapp_precondition.Valid_while.Checked.t\n }\n [@@deriving annot, hlist, fields]\n\n let to_input ({ network; account; valid_while } : t) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Zkapp_precondition.Protocol_state.Checked.to_input network\n ; Zkapp_precondition.Account.Checked.to_input account\n ; Zkapp_precondition.Valid_while.Checked.to_input valid_while\n ]\n end\n\n let typ () : (Checked.t, t) Typ.t =\n Typ.of_hlistable\n [ Zkapp_precondition.Protocol_state.typ\n ; Account_precondition.typ ()\n ; Zkapp_precondition.Valid_while.typ\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let accept =\n { network = Zkapp_precondition.Protocol_state.accept\n ; account = Zkapp_precondition.Account.accept\n ; valid_while = Ignore\n }\nend\n\nmodule Body = struct\n (* Why isn't this derived automatically? *)\n let hash_fold_array f init x = Array.fold ~init ~f x\n\n module Events' = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Pickles.Backend.Tick.Field.Stable.V1.t array list\n [@@deriving sexp, equal, hash, compare, yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Graphql_repr = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { public_key : Public_key.Compressed.Stable.V1.t\n ; token_id : Token_id.Stable.V2.t\n ; update : Update.Stable.V1.t\n ; balance_change :\n (Amount.Stable.V1.t, Sgn.Stable.V1.t) Signed_poly.Stable.V1.t\n ; increment_nonce : bool\n ; events : Events'.Stable.V1.t\n ; actions : Events'.Stable.V1.t\n ; call_data : Pickles.Backend.Tick.Field.Stable.V1.t\n ; call_depth : int\n ; preconditions : Preconditions.Stable.V1.t\n ; use_full_commitment : bool\n ; implicit_account_creation_fee : bool\n ; may_use_token : May_use_token.Stable.V1.t\n ; authorization_kind : Authorization_kind.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~public_key:!.public_key ~update:!.Update.deriver\n ~token_id:!.Token_id.deriver ~balance_change:!.balance_change\n ~increment_nonce:!.bool ~events:!.Events.deriver\n ~actions:!.Actions.deriver ~call_data:!.field\n ~preconditions:!.Preconditions.deriver ~use_full_commitment:!.bool\n ~implicit_account_creation_fee:!.bool\n ~may_use_token:!.May_use_token.deriver ~call_depth:!.int\n ~authorization_kind:!.Authorization_kind.deriver\n |> finish \"AccountUpdateBody\" ~t_toplevel_annots\n\n let dummy : t =\n { public_key = Public_key.Compressed.empty\n ; update = Update.dummy\n ; token_id = Token_id.default\n ; balance_change = Amount.Signed.zero\n ; increment_nonce = false\n ; events = []\n ; actions = []\n ; call_data = Field.zero\n ; call_depth = 0\n ; preconditions = Preconditions.accept\n ; use_full_commitment = false\n ; implicit_account_creation_fee = false\n ; may_use_token = No\n ; authorization_kind = None_given\n }\n end\n\n module Simple = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { public_key : Public_key.Compressed.Stable.V1.t\n ; token_id : Token_id.Stable.V2.t\n ; update : Update.Stable.V1.t\n ; balance_change :\n (Amount.Stable.V1.t, Sgn.Stable.V1.t) Signed_poly.Stable.V1.t\n ; increment_nonce : bool\n ; events : Events'.Stable.V1.t\n ; actions : Events'.Stable.V1.t\n ; call_data : Pickles.Backend.Tick.Field.Stable.V1.t\n ; call_depth : int\n ; preconditions : Preconditions.Stable.V1.t\n ; use_full_commitment : bool\n ; implicit_account_creation_fee : bool\n ; may_use_token : May_use_token.Stable.V1.t\n ; authorization_kind : Authorization_kind.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Account_update.Body.V1.t =\n { public_key : Public_key.Compressed.Stable.V1.t\n ; token_id : Token_id.Stable.V2.t\n ; update : Update.Stable.V1.t\n ; balance_change :\n (Amount.Stable.V1.t, Sgn.Stable.V1.t) Signed_poly.Stable.V1.t\n ; increment_nonce : bool\n ; events : Events'.Stable.V1.t\n ; actions : Events'.Stable.V1.t\n ; call_data : Pickles.Backend.Tick.Field.Stable.V1.t\n ; preconditions : Preconditions.Stable.V1.t\n ; use_full_commitment : bool\n ; implicit_account_creation_fee : bool\n ; may_use_token : May_use_token.Stable.V1.t\n ; authorization_kind : Authorization_kind.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, hlist, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let of_simple (p : Simple.t) : t =\n { public_key = p.public_key\n ; token_id = p.token_id\n ; update = p.update\n ; balance_change = p.balance_change\n ; increment_nonce = p.increment_nonce\n ; events = p.events\n ; actions = p.actions\n ; call_data = p.call_data\n ; preconditions = p.preconditions\n ; use_full_commitment = p.use_full_commitment\n ; implicit_account_creation_fee = p.implicit_account_creation_fee\n ; may_use_token = p.may_use_token\n ; authorization_kind = p.authorization_kind\n }\n\n let of_graphql_repr\n ({ public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; call_depth = _\n ; authorization_kind\n } :\n Graphql_repr.t ) : t =\n { public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n }\n\n let to_graphql_repr\n ({ public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n } :\n t ) ~call_depth : Graphql_repr.t =\n { Graphql_repr.public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; call_depth\n ; authorization_kind\n }\n\n module Fee_payer = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Account_update.Body.Fee_payer.V1.t =\n { public_key : Public_key.Compressed.Stable.V1.t\n ; fee : Fee.Stable.V1.t\n ; valid_until : Global_slot_since_genesis.Stable.V1.t option\n [@name \"validUntil\"]\n ; nonce : Account_nonce.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, hlist, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map public_key = Public_key.Compressed.gen\n and fee = Currency.Fee.gen\n and valid_until =\n Option.quickcheck_generator Global_slot_since_genesis.gen\n and nonce = Account.Nonce.gen in\n { public_key; fee; valid_until; nonce }\n\n let dummy : t =\n { public_key = Public_key.Compressed.empty\n ; fee = Fee.zero\n ; valid_until = None\n ; nonce = Account_nonce.zero\n }\n\n let deriver obj =\n let open Fields_derivers_zkapps in\n let fee obj =\n iso_string obj ~name:\"Fee\" ~js_type:UInt64 ~to_string:Fee.to_string\n ~of_string:Fee.of_string\n in\n let ( !. ) ?skip_data = ( !. ) ?skip_data ~t_fields_annots in\n Fields.make_creator obj ~public_key:!.public_key ~fee:!.fee\n ~valid_until:\n !.Fields_derivers_zkapps.Derivers.(\n option ~js_type:Or_undefined @@ global_slot_since_genesis @@ o ())\n ~nonce:!.uint32\n |> finish \"FeePayerBody\" ~t_toplevel_annots\n end\n\n let of_fee_payer (t : Fee_payer.t) : t =\n { public_key = t.public_key\n ; token_id = Token_id.default\n ; update = Update.noop\n ; balance_change =\n { Signed_poly.sgn = Sgn.Neg; magnitude = Amount.of_fee t.fee }\n ; increment_nonce = true\n ; events = []\n ; actions = []\n ; call_data = Field.zero\n ; preconditions =\n { Preconditions.network =\n (let valid_until =\n Option.value ~default:Global_slot_since_genesis.max_value\n t.valid_until\n in\n { Zkapp_precondition.Protocol_state.accept with\n global_slot_since_genesis =\n Check\n { lower = Global_slot_since_genesis.zero\n ; upper = valid_until\n }\n } )\n ; account = Zkapp_precondition.Account.nonce t.nonce\n ; valid_while = Ignore\n }\n ; use_full_commitment = true\n ; implicit_account_creation_fee = true\n ; may_use_token = No\n ; authorization_kind = Signature\n }\n\n let to_simple_fee_payer (t : Fee_payer.t) : Simple.t =\n { public_key = t.public_key\n ; token_id = Token_id.default\n ; update = Update.noop\n ; balance_change =\n { Signed_poly.sgn = Sgn.Neg; magnitude = Amount.of_fee t.fee }\n ; increment_nonce = true\n ; events = []\n ; actions = []\n ; call_data = Field.zero\n ; preconditions =\n { Preconditions.network =\n (let valid_until =\n Option.value ~default:Global_slot_since_genesis.max_value\n t.valid_until\n in\n { Zkapp_precondition.Protocol_state.accept with\n global_slot_since_genesis =\n Check\n { lower = Global_slot_since_genesis.zero\n ; upper = valid_until\n }\n } )\n ; account = Zkapp_precondition.Account.nonce t.nonce\n ; valid_while = Ignore\n }\n ; use_full_commitment = true\n ; implicit_account_creation_fee = true\n ; may_use_token = No\n ; call_depth = 0\n ; authorization_kind = Signature\n }\n\n let to_fee_payer_exn (t : t) : Fee_payer.t =\n let { public_key\n ; token_id = _\n ; update = _\n ; balance_change\n ; increment_nonce = _\n ; events = _\n ; actions = _\n ; call_data = _\n ; preconditions\n ; use_full_commitment = _\n ; may_use_token = _\n ; authorization_kind = _\n } =\n t\n in\n let fee =\n Currency.Fee.of_uint64\n (balance_change.magnitude |> Currency.Amount.to_uint64)\n in\n let nonce =\n if Zkapp_precondition.Account.is_nonce preconditions.account then\n match preconditions.account.nonce with\n | Check { lower; upper = _ } ->\n lower\n | Ignore ->\n failwith \"Unexpected Ignore for fee payer precondition nonce\"\n else failwith \"Expected a nonce for fee payer account precondition\"\n in\n let valid_until =\n match preconditions.network.global_slot_since_genesis with\n | Ignore ->\n None\n | Check { upper; _ } ->\n Some upper\n in\n { public_key; fee; valid_until; nonce }\n\n module Checked = struct\n module Type_of_var (V : sig\n type var\n end) =\n struct\n type t = V.var\n end\n\n module Int_as_prover_ref = struct\n type t = int As_prover.Ref.t\n end\n\n type t =\n { public_key : Public_key.Compressed.var\n ; token_id : Token_id.Checked.t\n ; update : Update.Checked.t\n ; balance_change : Amount.Signed.var\n ; increment_nonce : Boolean.var\n ; events : Events.var\n ; actions : Actions.var\n ; call_data : Field.Var.t\n ; preconditions : Preconditions.Checked.t\n ; use_full_commitment : Boolean.var\n ; implicit_account_creation_fee : Boolean.var\n ; may_use_token : May_use_token.Checked.t\n ; authorization_kind : Authorization_kind.Checked.t\n }\n [@@deriving annot, hlist, fields]\n\n let to_input\n ({ public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n } :\n t ) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Public_key.Compressed.Checked.to_input public_key\n ; Token_id.Checked.to_input token_id\n ; Update.Checked.to_input update\n ; Snark_params.Tick.Run.run_checked\n (Amount.Signed.Checked.to_input balance_change)\n ; Random_oracle_input.Chunked.packed\n ((increment_nonce :> Field.Var.t), 1)\n ; Events.var_to_input events\n ; Actions.var_to_input actions\n ; Random_oracle_input.Chunked.field call_data\n ; Preconditions.Checked.to_input preconditions\n ; Random_oracle_input.Chunked.packed\n ((use_full_commitment :> Field.Var.t), 1)\n ; Random_oracle_input.Chunked.packed\n ((implicit_account_creation_fee :> Field.Var.t), 1)\n ; May_use_token.Checked.to_input may_use_token\n ; Authorization_kind.Checked.to_input authorization_kind\n ]\n\n let digest ?chain (t : t) =\n Random_oracle.Checked.(\n hash ~init:(Hash_prefix.zkapp_body ?chain) (pack_input (to_input t)))\n end\n\n let typ () : (Checked.t, t) Typ.t =\n Typ.of_hlistable\n [ Public_key.Compressed.typ\n ; Token_id.typ\n ; Update.typ ()\n ; Amount.Signed.typ\n ; Boolean.typ\n ; Events.typ\n ; Actions.typ\n ; Field.typ\n ; Preconditions.typ ()\n ; Impl.Boolean.typ\n ; Impl.Boolean.typ\n ; May_use_token.typ\n ; Authorization_kind.typ\n ]\n ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n\n let dummy : t =\n { public_key = Public_key.Compressed.empty\n ; update = Update.dummy\n ; token_id = Token_id.default\n ; balance_change = Amount.Signed.zero\n ; increment_nonce = false\n ; events = []\n ; actions = []\n ; call_data = Field.zero\n ; preconditions = Preconditions.accept\n ; use_full_commitment = false\n ; implicit_account_creation_fee = true\n ; may_use_token = No\n ; authorization_kind = None_given\n }\n\n let to_input\n ({ public_key\n ; update\n ; token_id\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n } :\n t ) =\n List.reduce_exn ~f:Random_oracle_input.Chunked.append\n [ Public_key.Compressed.to_input public_key\n ; Token_id.to_input token_id\n ; Update.to_input update\n ; Amount.Signed.to_input balance_change\n ; Random_oracle_input.Chunked.packed (field_of_bool increment_nonce, 1)\n ; Events.to_input events\n ; Actions.to_input actions\n ; Random_oracle_input.Chunked.field call_data\n ; Preconditions.to_input preconditions\n ; Random_oracle_input.Chunked.packed (field_of_bool use_full_commitment, 1)\n ; Random_oracle_input.Chunked.packed\n (field_of_bool implicit_account_creation_fee, 1)\n ; May_use_token.to_input may_use_token\n ; Authorization_kind.to_input authorization_kind\n ]\n\n let digest ?chain (t : t) =\n Random_oracle.(\n hash ~init:(Hash_prefix.zkapp_body ?chain) (pack_input (to_input t)))\n\n module Digested = struct\n type t = Random_oracle.Digest.t\n\n module Checked = struct\n type t = Random_oracle.Checked.Digest.t\n end\n end\n\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%map public_key = Public_key.Compressed.gen\n and token_id = Token_id.gen\n and update = Update.gen ()\n and balance_change = Currency.Amount.Signed.gen\n and increment_nonce = Quickcheck.Generator.bool\n and events = return []\n and actions = return []\n and call_data = Field.gen\n and preconditions = Preconditions.gen\n and use_full_commitment = Quickcheck.Generator.bool\n and implicit_account_creation_fee = Quickcheck.Generator.bool\n and may_use_token = May_use_token.gen\n and authorization_kind = Authorization_kind.gen in\n { public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n }\n\n let gen_with_events_and_actions =\n let open Quickcheck.Generator.Let_syntax in\n let%map public_key = Public_key.Compressed.gen\n and token_id = Token_id.gen\n and update = Update.gen ()\n and balance_change = Currency.Amount.Signed.gen\n and increment_nonce = Quickcheck.Generator.bool\n and events = return [ [| Field.zero |]; [| Field.zero |] ]\n and actions = return [ [| Field.zero |]; [| Field.zero |] ]\n and call_data = Field.gen\n and preconditions = Preconditions.gen\n and use_full_commitment = Quickcheck.Generator.bool\n and implicit_account_creation_fee = Quickcheck.Generator.bool\n and may_use_token = May_use_token.gen\n and authorization_kind = Authorization_kind.gen in\n { public_key\n ; token_id\n ; update\n ; balance_change\n ; increment_nonce\n ; events\n ; actions\n ; call_data\n ; preconditions\n ; use_full_commitment\n ; implicit_account_creation_fee\n ; may_use_token\n ; authorization_kind\n }\nend\n\nmodule T = struct\n module Graphql_repr = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n (** An account update in a zkApp transaction *)\n type t =\n { body : Body.Graphql_repr.Stable.V1.t\n ; authorization : Control.Stable.V2.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj\n ~body:!.Body.Graphql_repr.deriver\n ~authorization:!.Control.deriver\n |> finish \"ZkappAccountUpdate\" ~t_toplevel_annots\n end\n\n module Simple = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { body : Body.Simple.Stable.V1.t\n ; authorization : Control.Stable.V2.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n (** A account_update to a zkApp transaction *)\n type t = Mina_wire_types.Mina_base.Account_update.V1.t =\n { body : Body.Stable.V1.t; authorization : Control.Stable.V2.t }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let of_graphql_repr ({ body; authorization } : Graphql_repr.t) : t =\n { authorization; body = Body.of_graphql_repr body }\n\n let to_graphql_repr ({ body; authorization } : t) ~call_depth : Graphql_repr.t\n =\n { authorization; body = Body.to_graphql_repr ~call_depth body }\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map body = Body.gen and authorization = Control.gen_with_dummies in\n { body; authorization }\n\n let gen_with_events_and_actions : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map body = Body.gen_with_events_and_actions\n and authorization = Control.gen_with_dummies in\n { body; authorization }\n\n let quickcheck_generator : t Quickcheck.Generator.t = gen\n\n let quickcheck_observer : t Quickcheck.Observer.t =\n Quickcheck.Observer.of_hash (module Stable.Latest)\n\n let quickcheck_shrinker : t Quickcheck.Shrinker.t =\n Quickcheck.Shrinker.empty ()\n\n let of_simple (p : Simple.t) : t =\n { body = Body.of_simple p.body; authorization = p.authorization }\n\n let digest ?chain (t : t) = Body.digest ?chain t.body\n\n module Checked = struct\n type t = Body.Checked.t\n\n let digest ?chain (t : t) = Body.Checked.digest ?chain t\n end\nend\n\nmodule Fee_payer = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Account_update.Fee_payer.V1.t =\n { body : Body.Fee_payer.Stable.V1.t\n ; authorization : Signature.Stable.V1.t\n }\n [@@deriving annot, sexp, equal, yojson, hash, compare, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%map body = Body.Fee_payer.gen in\n let authorization = Signature.dummy in\n { body; authorization }\n\n let quickcheck_generator : t Quickcheck.Generator.t = gen\n\n let quickcheck_observer : t Quickcheck.Observer.t =\n Quickcheck.Observer.of_hash (module Stable.Latest)\n\n let quickcheck_shrinker : t Quickcheck.Shrinker.t =\n Quickcheck.Shrinker.empty ()\n\n let account_id (t : t) : Account_id.t =\n Account_id.create t.body.public_key Token_id.default\n\n let to_account_update (t : t) : T.t =\n { authorization = Control.Signature t.authorization\n ; body = Body.of_fee_payer t.body\n }\n\n let deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj ~body:!.Body.Fee_payer.deriver\n ~authorization:!.Control.signature_deriver\n |> finish \"ZkappFeePayer\" ~t_toplevel_annots\nend\n\ninclude T\n\nlet account_id (t : t) : Account_id.t =\n Account_id.create t.body.public_key t.body.token_id\n\nlet verification_key_update_to_option (t : t) :\n Verification_key_wire.t option Zkapp_basic.Set_or_keep.t =\n Zkapp_basic.Set_or_keep.map ~f:Option.some t.body.update.verification_key\n\nlet of_fee_payer ({ body; authorization } : Fee_payer.t) : t =\n { authorization = Signature authorization; body = Body.of_fee_payer body }\n\n(** The change in balance to apply to the target account of this account_update.\n When this is negative, the amount will be withdrawn from the account and\n made available to later zkapp_command in the same transaction.\n When this is positive, the amount will be deposited into the account from\n the funds made available by previous zkapp_command in the same transaction.\n*)\nlet balance_change (t : t) : Amount.Signed.t = t.body.balance_change\n\nlet protocol_state_precondition (t : t) : Zkapp_precondition.Protocol_state.t =\n t.body.preconditions.network\n\nlet valid_while_precondition (t : t) :\n Mina_numbers.Global_slot_since_genesis.t Zkapp_precondition.Numeric.t =\n t.body.preconditions.valid_while\n\nlet public_key (t : t) : Public_key.Compressed.t = t.body.public_key\n\nlet token_id (t : t) : Token_id.t = t.body.token_id\n\nlet use_full_commitment (t : t) : bool = t.body.use_full_commitment\n\nlet implicit_account_creation_fee (t : t) : bool =\n t.body.implicit_account_creation_fee\n\nlet increment_nonce (t : t) : bool = t.body.increment_nonce\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type ('a, 'field) t =\n ('a, 'field) Mina_wire_types.Mina_base.With_stack_hash.V1.t =\n { elt : 'a; stack_hash : 'field }\n [@@deriving sexp, compare, equal, hash, yojson, fields, quickcheck]\n end\nend]\n\nlet map t ~f = { t with elt = f t.elt }\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type 'a t = 'a Mina_wire_types.Mina_base.With_status.V2.t =\n { data : 'a; status : Transaction_status.Stable.V2.t }\n [@@deriving sexp, yojson, equal, compare, fields]\n\n let to_latest data_latest (t : _ t) =\n { data = data_latest t.data; status = t.status }\n end\nend]\n\nlet map ~f { data; status } = { data = f data; status }\n\nlet map_opt ~f { data; status } =\n Option.map (f data) ~f:(fun data -> { data; status })\n\nlet map_result ~f { data; status } =\n Result.map (f data) ~f:(fun data -> { data; status })\n","open Core_kernel\nopen Signature_lib\n\nmodule Call_forest = struct\n let empty = Outside_hash_image.t\n\n module Tree = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('account_update, 'account_update_digest, 'digest) t =\n ( 'account_update\n , 'account_update_digest\n , 'digest )\n Mina_wire_types.Mina_base.Zkapp_command.Call_forest.Tree.V1.t =\n { account_update : 'account_update\n ; account_update_digest : 'account_update_digest\n ; calls :\n ( ('account_update, 'account_update_digest, 'digest) t\n , 'digest )\n With_stack_hash.Stable.V1.t\n list\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let rec fold_forest (ts : (_ t, _) With_stack_hash.t list) ~f ~init =\n List.fold ts ~init ~f:(fun acc { elt; stack_hash = _ } ->\n fold elt ~init:acc ~f )\n\n and fold { account_update; calls; account_update_digest = _ } ~f ~init =\n fold_forest calls ~f ~init:(f init account_update)\n\n let rec fold_forest2_exn (ts1 : (_ t, _) With_stack_hash.t list)\n (ts2 : (_ t, _) With_stack_hash.t list) ~f ~init =\n List.fold2_exn ts1 ts2 ~init\n ~f:(fun\n acc\n { elt = elt1; stack_hash = _ }\n { elt = elt2; stack_hash = _ }\n -> fold2_exn elt1 elt2 ~init:acc ~f )\n\n and fold2_exn\n { account_update = account_update1\n ; calls = calls1\n ; account_update_digest = _\n }\n { account_update = account_update2\n ; calls = calls2\n ; account_update_digest = _\n } ~f ~init =\n fold_forest2_exn calls1 calls2 ~f\n ~init:(f init account_update1 account_update2)\n\n let iter_forest2_exn ts1 ts2 ~f =\n fold_forest2_exn ts1 ts2 ~init:() ~f:(fun () p1 p2 -> f p1 p2)\n\n let iter2_exn ts1 ts2 ~f =\n fold2_exn ts1 ts2 ~init:() ~f:(fun () p1 p2 -> f p1 p2)\n\n let rec mapi_with_trees' ~i (t : _ t) ~f =\n let account_update = f i t.account_update t in\n let l, calls = mapi_forest_with_trees' ~i:(i + 1) t.calls ~f in\n ( l\n , { calls\n ; account_update\n ; account_update_digest = t.account_update_digest\n } )\n\n and mapi_forest_with_trees' ~i x ~f =\n let rec go i acc = function\n | [] ->\n (i, List.rev acc)\n | t :: ts ->\n let l, elt' = mapi_with_trees' ~i ~f (With_stack_hash.elt t) in\n go l (With_stack_hash.map t ~f:(fun _ -> elt') :: acc) ts\n in\n go i [] x\n\n let mapi_with_trees t ~f = mapi_with_trees' ~i:0 t ~f |> snd\n\n let mapi_forest_with_trees t ~f = mapi_forest_with_trees' ~i:0 t ~f |> snd\n\n let mapi' ~i t ~f =\n mapi_with_trees' ~i t ~f:(fun i account_update _ -> f i account_update)\n\n let mapi_forest' ~i t ~f =\n mapi_forest_with_trees' ~i t ~f:(fun i account_update _ ->\n f i account_update )\n\n let rec deferred_mapi_with_trees' ~i (t : _ t) ~f =\n let open Async_kernel.Deferred.Let_syntax in\n let%bind l, calls =\n deferred_mapi_forest_with_trees' ~i:(i + 1) t.calls ~f\n in\n let%map account_update = f i t.account_update t in\n ( l\n , { calls\n ; account_update\n ; account_update_digest = t.account_update_digest\n } )\n\n and deferred_mapi_forest_with_trees' ~i x ~f =\n let open Async_kernel.Deferred.Let_syntax in\n let rec go i acc = function\n | [] ->\n return (i, List.rev acc)\n | t :: ts ->\n let%bind l, elt' =\n deferred_mapi_with_trees' ~i ~f (With_stack_hash.elt t)\n in\n go l (With_stack_hash.map t ~f:(fun _ -> elt') :: acc) ts\n in\n go i [] x\n\n let map_forest ~f t = mapi_forest' ~i:0 ~f:(fun _ x -> f x) t |> snd\n\n let mapi_forest ~f t = mapi_forest' ~i:0 ~f t |> snd\n\n let deferred_map_forest ~f t =\n let open Async_kernel.Deferred in\n deferred_mapi_forest_with_trees' ~i:0 ~f:(fun _ x -> f x) t >>| snd\n\n let deferred_mapi_forest ~f t =\n let open Async_kernel.Deferred in\n deferred_mapi_forest_with_trees' ~i:0 ~f t >>| snd\n\n let hash { account_update = _; calls; account_update_digest } =\n let stack_hash =\n match calls with [] -> empty | e :: _ -> e.stack_hash\n in\n Random_oracle.hash ~init:Hash_prefix_states.account_update_node\n [| account_update_digest; stack_hash |]\n end\n\n type ('a, 'b, 'c) tree = ('a, 'b, 'c) Tree.t\n\n module type Digest_intf = sig\n module Account_update : sig\n include Digest_intf.S\n\n module Checked : sig\n include Digest_intf.S_checked\n\n val create :\n ?chain:Mina_signature_kind.t -> Account_update.Checked.t -> t\n\n val create_body :\n ?chain:Mina_signature_kind.t -> Account_update.Body.Checked.t -> t\n end\n\n include Digest_intf.S_aux with type t := t and type checked := Checked.t\n\n val create : ?chain:Mina_signature_kind.t -> Account_update.t -> t\n\n val create_body :\n ?chain:Mina_signature_kind.t -> Account_update.Body.t -> t\n end\n\n module rec Forest : sig\n include Digest_intf.S\n\n module Checked : sig\n include Digest_intf.S_checked\n\n val empty : t\n\n val cons : Tree.Checked.t -> t -> t\n end\n\n include Digest_intf.S_aux with type t := t and type checked := Checked.t\n\n val empty : t\n\n val cons : Tree.t -> Forest.t -> Forest.t\n end\n\n and Tree : sig\n include Digest_intf.S\n\n module Checked : sig\n include Digest_intf.S_checked\n\n val create :\n account_update:Account_update.Checked.t\n -> calls:Forest.Checked.t\n -> Tree.Checked.t\n end\n\n include Digest_intf.S_aux with type t := t and type checked := Checked.t\n\n val create : (_, Account_update.t, Forest.t) tree -> Tree.t\n end\n end\n\n module Make_digest_sig\n (T : Mina_wire_types.Mina_base.Zkapp_command.Digest_types.S) =\n struct\n module type S =\n Digest_intf\n with type Account_update.Stable.V1.t = T.Account_update.V1.t\n and type Forest.Stable.V1.t = T.Forest.V1.t\n end\n\n module Make_digest_str\n (T : Mina_wire_types.Mina_base.Zkapp_command.Digest_concrete) :\n Make_digest_sig(T).S = struct\n module M = struct\n open Pickles.Impls.Step.Field\n module Checked = Pickles.Impls.Step.Field\n\n let typ = typ\n\n let constant = constant\n end\n\n module Account_update = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Kimchi_backend.Pasta.Basic.Fp.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include M\n\n module Checked = struct\n include Checked\n\n let create = Account_update.Checked.digest\n\n let create_body = Account_update.Body.Checked.digest\n end\n\n let create : ?chain:Mina_signature_kind.t -> Account_update.t -> t =\n Account_update.digest\n\n let create_body :\n ?chain:Mina_signature_kind.t -> Account_update.Body.t -> t =\n Account_update.Body.digest\n end\n\n module Forest = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Kimchi_backend.Pasta.Basic.Fp.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include M\n\n module Checked = struct\n include Checked\n\n let empty = constant empty\n\n let cons hash h_tl =\n Random_oracle.Checked.hash\n ~init:Hash_prefix_states.account_update_cons [| hash; h_tl |]\n end\n\n let empty = empty\n\n let cons hash h_tl =\n Random_oracle.hash ~init:Hash_prefix_states.account_update_cons\n [| hash; h_tl |]\n end\n\n module Tree = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Kimchi_backend.Pasta.Basic.Fp.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include M\n\n module Checked = struct\n include Checked\n\n let create ~(account_update : Account_update.Checked.t)\n ~(calls : Forest.Checked.t) =\n Random_oracle.Checked.hash\n ~init:Hash_prefix_states.account_update_node\n [| (account_update :> t); (calls :> t) |]\n end\n\n let create ({ account_update = _; calls; account_update_digest } : _ tree)\n =\n let stack_hash =\n match calls with [] -> empty | e :: _ -> e.stack_hash\n in\n Random_oracle.hash ~init:Hash_prefix_states.account_update_node\n [| account_update_digest; stack_hash |]\n end\n end\n\n module Digest =\n Mina_wire_types.Mina_base.Zkapp_command.Digest_make\n (Make_digest_sig)\n (Make_digest_str)\n\n let fold = Tree.fold_forest\n\n let iteri t ~(f : int -> 'a -> unit) : unit =\n let (_ : int) = fold t ~init:0 ~f:(fun acc x -> f acc x ; acc + 1) in\n ()\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('account_update, 'account_update_digest, 'digest) t =\n ( ('account_update, 'account_update_digest, 'digest) Tree.Stable.V1.t\n , 'digest )\n With_stack_hash.Stable.V1.t\n list\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n module Shape = struct\n module I = struct\n type t = int\n\n let quickcheck_shrinker = Quickcheck.Shrinker.empty ()\n\n let quickcheck_generator = [%quickcheck.generator: int]\n\n let quickcheck_observer = [%quickcheck.observer: int]\n end\n\n type t = Node of (I.t * t) list [@@deriving quickcheck]\n end\n\n let rec shape (t : _ t) : Shape.t =\n Node (List.mapi t ~f:(fun i { elt; stack_hash = _ } -> (i, shape elt.calls)))\n\n let match_up (type a b) (xs : a list) (ys : (int * b) list) : (a * b) list =\n let rec go i_curr xs ys =\n match (xs, ys) with\n | [], [] ->\n []\n | x :: xs', (i, y) :: ys' ->\n if i_curr = i then (x, y) :: go (i_curr + 1) xs' ys'\n else if i_curr < i then go (i_curr + 1) xs' ys'\n else assert false\n | [], _ :: _ ->\n assert false\n | _ :: _, [] ->\n []\n in\n go 0 xs ys\n\n let rec mask (t : ('p, 'h1, unit) t) (Node shape : Shape.t) :\n ('p, 'h1, unit) t =\n List.map (match_up t shape)\n ~f:(fun ({ With_stack_hash.elt = t_sub; stack_hash = () }, shape_sub) ->\n { With_stack_hash.elt =\n { t_sub with calls = mask t_sub.calls shape_sub }\n ; stack_hash = ()\n } )\n\n let rec of_account_updates_map ~(f : 'p1 -> 'p2)\n ~(account_update_depth : 'p1 -> int) (account_updates : 'p1 list) :\n ('p2, unit, unit) t =\n match account_updates with\n | [] ->\n []\n | p :: ps ->\n let depth = account_update_depth p in\n let children, siblings =\n List.split_while ps ~f:(fun p' -> account_update_depth p' > depth)\n in\n { With_stack_hash.elt =\n { Tree.account_update = f p\n ; account_update_digest = ()\n ; calls = of_account_updates_map ~f ~account_update_depth children\n }\n ; stack_hash = ()\n }\n :: of_account_updates_map ~f ~account_update_depth siblings\n\n let of_account_updates ~account_update_depth account_updates =\n of_account_updates_map ~f:Fn.id ~account_update_depth account_updates\n\n let to_account_updates_map ~f (xs : _ t) =\n let rec collect depth (xs : _ t) acc =\n match xs with\n | [] ->\n acc\n | { elt = { account_update; calls; account_update_digest = _ }\n ; stack_hash = _\n }\n :: xs ->\n f ~depth account_update :: acc\n |> collect (depth + 1) calls\n |> collect depth xs\n in\n List.rev (collect 0 xs [])\n\n let to_account_updates xs =\n to_account_updates_map ~f:(fun ~depth:_ account_update -> account_update) xs\n\n let hd_account_update (xs : _ t) =\n match xs with\n | [] ->\n None\n | { elt = { account_update; calls = _; account_update_digest = _ }\n ; stack_hash = _\n }\n :: _ ->\n Some account_update\n\n let map = Tree.map_forest\n\n let mapi = Tree.mapi_forest\n\n let mapi_with_trees = Tree.mapi_forest_with_trees\n\n let deferred_mapi = Tree.deferred_mapi_forest\n\n let to_zkapp_command_with_hashes_list (xs : _ t) =\n let rec collect (xs : _ t) acc =\n match xs with\n | [] ->\n acc\n | { elt = { account_update; calls; account_update_digest = _ }\n ; stack_hash\n }\n :: xs ->\n (account_update, stack_hash) :: acc |> collect calls |> collect xs\n in\n List.rev (collect xs [])\n\n let hash_cons hash h_tl =\n Random_oracle.hash ~init:Hash_prefix_states.account_update_cons\n [| hash; h_tl |]\n\n let hash = function\n | [] ->\n Digest.Forest.empty\n | x :: _ ->\n With_stack_hash.stack_hash x\n\n let cons_tree tree (forest : _ t) : _ t =\n { elt = tree\n ; stack_hash = Digest.Forest.cons (Digest.Tree.create tree) (hash forest)\n }\n :: forest\n\n let cons_aux (type p) ~(digest_account_update : p -> _) ?(calls = [])\n (account_update : p) (xs : _ t) : _ t =\n let account_update_digest = digest_account_update account_update in\n let tree : _ Tree.t = { account_update; account_update_digest; calls } in\n cons_tree tree xs\n\n let cons ?calls (account_update : Account_update.t) xs =\n cons_aux ~digest_account_update:Digest.Account_update.create ?calls\n account_update xs\n\n let rec accumulate_hashes ~hash_account_update (xs : _ t) =\n let go = accumulate_hashes ~hash_account_update in\n match xs with\n | [] ->\n []\n | { elt = { account_update; calls; account_update_digest = _ }\n ; stack_hash = _\n }\n :: xs ->\n let calls = go calls in\n let xs = go xs in\n let node =\n { Tree.account_update\n ; calls\n ; account_update_digest = hash_account_update account_update\n }\n in\n let node_hash = Digest.Tree.create node in\n { elt = node; stack_hash = Digest.Forest.cons node_hash (hash xs) }\n :: xs\n\n let accumulate_hashes' (type a b) (xs : (Account_update.t, a, b) t) :\n (Account_update.t, Digest.Account_update.t, Digest.Forest.t) t =\n let hash_account_update (p : Account_update.t) =\n Digest.Account_update.create p\n in\n accumulate_hashes ~hash_account_update xs\n\n let accumulate_hashes_predicated xs =\n accumulate_hashes ~hash_account_update:Digest.Account_update.create xs\n\n module With_hashes_and_data = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'data t =\n ( Account_update.Stable.V1.t * 'data\n , Digest.Account_update.Stable.V1.t\n , Digest.Forest.Stable.V1.t )\n Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let empty = Digest.Forest.empty\n\n let hash_account_update ((p : Account_update.t), _) =\n Digest.Account_update.create p\n\n let accumulate_hashes xs : _ t = accumulate_hashes ~hash_account_update xs\n\n let of_zkapp_command_simple_list (xs : (Account_update.Simple.t * 'a) list)\n : _ t =\n of_account_updates xs\n ~account_update_depth:(fun ((p : Account_update.Simple.t), _) ->\n p.body.call_depth )\n |> map ~f:(fun (p, x) -> (Account_update.of_simple p, x))\n |> accumulate_hashes\n\n let of_account_updates (xs : (Account_update.Graphql_repr.t * 'a) list) :\n _ t =\n of_account_updates_map\n ~account_update_depth:(fun ((p : Account_update.Graphql_repr.t), _) ->\n p.body.call_depth )\n ~f:(fun (p, x) -> (Account_update.of_graphql_repr p, x))\n xs\n |> accumulate_hashes\n\n let to_account_updates (x : _ t) = to_account_updates x\n\n let to_zkapp_command_with_hashes_list (x : _ t) =\n to_zkapp_command_with_hashes_list x\n\n let account_updates_hash' xs = of_account_updates xs |> hash\n\n let account_updates_hash xs =\n List.map ~f:(fun x -> (x, ())) xs |> account_updates_hash'\n end\n\n module With_hashes = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( Account_update.Stable.V1.t\n , Digest.Account_update.Stable.V1.t\n , Digest.Forest.Stable.V1.t )\n Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let empty = Digest.Forest.empty\n\n let hash_account_update (p : Account_update.t) =\n Digest.Account_update.create p\n\n let accumulate_hashes xs : t = accumulate_hashes ~hash_account_update xs\n\n let of_zkapp_command_simple_list (xs : Account_update.Simple.t list) : t =\n of_account_updates xs\n ~account_update_depth:(fun (p : Account_update.Simple.t) ->\n p.body.call_depth )\n |> map ~f:Account_update.of_simple\n |> accumulate_hashes\n\n let of_account_updates (xs : Account_update.Graphql_repr.t list) : t =\n of_account_updates_map\n ~account_update_depth:(fun (p : Account_update.Graphql_repr.t) ->\n p.body.call_depth )\n ~f:(fun p -> Account_update.of_graphql_repr p)\n xs\n |> accumulate_hashes\n\n let to_account_updates (x : t) = to_account_updates x\n\n let to_zkapp_command_with_hashes_list (x : t) =\n to_zkapp_command_with_hashes_list x\n\n let account_updates_hash' xs = of_account_updates xs |> hash\n\n let account_updates_hash xs =\n List.map ~f:(fun x -> x) xs |> account_updates_hash'\n end\n\n let is_empty : _ t -> bool = List.is_empty\n\n let to_list (type p) (t : (p, _, _) t) : p list =\n List.rev @@ fold t ~init:[] ~f:(fun acc p -> p :: acc)\n\n let exists (type p) (t : (p, _, _) t) ~(f : p -> bool) : bool =\n with_return (fun { return } ->\n fold t ~init:() ~f:(fun () p -> if f p then return true else ()) ;\n false )\nend\n\nmodule Graphql_repr = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates : Account_update.Graphql_repr.Stable.V1.t list\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Simple = struct\n (* For easily constructing values *)\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates : Account_update.Simple.Stable.V1.t list\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Digest = Call_forest.Digest\n\nmodule T = struct\n [%%versioned_binable\n module Stable = struct\n [@@@with_top_version_tag]\n\n (* DO NOT DELETE VERSIONS!\n so we can always get transaction hashes from old transaction ids\n the version linter should be checking this\n\n IF YOU CREATE A NEW VERSION:\n update Transaction_hash.hash_of_transaction_id to handle it\n add hash_zkapp_command_vn for that version\n *)\n\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Zkapp_command.V1.t =\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates :\n ( Account_update.Stable.V1.t\n , Digest.Account_update.Stable.V1.t\n , Digest.Forest.Stable.V1.t )\n Call_forest.Stable.V1.t\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving annot, sexp, compare, equal, hash, yojson, fields]\n\n let to_latest = Fn.id\n\n module Wire = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates :\n ( Account_update.Stable.V1.t\n , unit\n , unit )\n Call_forest.Stable.V1.t\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let check (t : t) : unit =\n List.iter t.account_updates ~f:(fun p ->\n assert (\n Account_update.May_use_token.equal\n p.elt.account_update.body.may_use_token No ) )\n\n let of_graphql_repr (t : Graphql_repr.t) : t =\n { fee_payer = t.fee_payer\n ; memo = t.memo\n ; account_updates =\n Call_forest.of_account_updates_map t.account_updates\n ~f:Account_update.of_graphql_repr\n ~account_update_depth:(fun (p : Account_update.Graphql_repr.t)\n -> p.body.call_depth )\n }\n\n let to_graphql_repr (t : t) : Graphql_repr.t =\n { fee_payer = t.fee_payer\n ; memo = t.memo\n ; account_updates =\n t.account_updates\n |> Call_forest.to_account_updates_map\n ~f:(fun ~depth account_update ->\n Account_update.to_graphql_repr account_update\n ~call_depth:depth )\n }\n\n let gen =\n let open Quickcheck.Generator in\n let open Let_syntax in\n let gen_call_forest =\n fixed_point (fun self ->\n let%bind calls_length = small_non_negative_int in\n list_with_length calls_length\n (let%map account_update = Account_update.gen\n and calls = self in\n { With_stack_hash.stack_hash = ()\n ; elt =\n { Call_forest.Tree.account_update\n ; account_update_digest = ()\n ; calls\n }\n } ) )\n in\n let open Quickcheck.Let_syntax in\n let%map fee_payer = Account_update.Fee_payer.gen\n and account_updates = gen_call_forest\n and memo = Signed_command_memo.gen in\n { fee_payer; account_updates; memo }\n\n let shrinker : t Quickcheck.Shrinker.t =\n Quickcheck.Shrinker.create (fun t ->\n let shape = Call_forest.shape t.account_updates in\n Sequence.map\n (Quickcheck.Shrinker.shrink\n Call_forest.Shape.quickcheck_shrinker shape )\n ~f:(fun shape' ->\n { t with\n account_updates = Call_forest.mask t.account_updates shape'\n } ) )\n end\n\n let of_wire (w : Wire.t) : t =\n { fee_payer = w.fee_payer\n ; memo = w.memo\n ; account_updates =\n w.account_updates\n |> Call_forest.accumulate_hashes\n ~hash_account_update:(fun (p : Account_update.t) ->\n Digest.Account_update.create p )\n }\n\n let to_wire (t : t) : Wire.t =\n let rec forget_hashes = List.map ~f:forget_hash\n and forget_hash = function\n | { With_stack_hash.stack_hash = _\n ; elt =\n { Call_forest.Tree.account_update\n ; account_update_digest = _\n ; calls\n }\n } ->\n { With_stack_hash.stack_hash = ()\n ; elt =\n { Call_forest.Tree.account_update\n ; account_update_digest = ()\n ; calls = forget_hashes calls\n }\n }\n in\n { fee_payer = t.fee_payer\n ; memo = t.memo\n ; account_updates = forget_hashes t.account_updates\n }\n\n include\n Binable.Of_binable_without_uuid\n (Wire.Stable.V1)\n (struct\n type nonrec t = t\n\n let of_binable t = Wire.check t ; of_wire t\n\n let to_binable = to_wire\n end)\n end\n end]\nend\n\ninclude T\n\n[%%define_locally Stable.Latest.(of_wire, to_wire)]\n\n[%%define_locally Stable.Latest.Wire.(gen)]\n\nlet of_simple (w : Simple.t) : t =\n { fee_payer = w.fee_payer\n ; memo = w.memo\n ; account_updates =\n Call_forest.of_account_updates w.account_updates\n ~account_update_depth:(fun (p : Account_update.Simple.t) ->\n p.body.call_depth )\n |> Call_forest.map ~f:Account_update.of_simple\n |> Call_forest.accumulate_hashes\n ~hash_account_update:(fun (p : Account_update.t) ->\n Digest.Account_update.create p )\n }\n\nlet to_simple (t : t) : Simple.t =\n { fee_payer = t.fee_payer\n ; memo = t.memo\n ; account_updates =\n t.account_updates\n |> Call_forest.to_account_updates_map\n ~f:(fun ~depth { Account_update.body = b; authorization } ->\n { Account_update.Simple.authorization\n ; body =\n { public_key = b.public_key\n ; token_id = b.token_id\n ; update = b.update\n ; balance_change = b.balance_change\n ; increment_nonce = b.increment_nonce\n ; events = b.events\n ; actions = b.actions\n ; call_data = b.call_data\n ; preconditions = b.preconditions\n ; use_full_commitment = b.use_full_commitment\n ; implicit_account_creation_fee =\n b.implicit_account_creation_fee\n ; may_use_token = b.may_use_token\n ; call_depth = depth\n ; authorization_kind = b.authorization_kind\n }\n } )\n }\n\nlet all_account_updates (t : t) : _ Call_forest.t =\n let p = t.fee_payer in\n let body = Account_update.Body.of_fee_payer p.body in\n let fee_payer : Account_update.t =\n let p = t.fee_payer in\n { authorization = Control.Signature p.authorization; body }\n in\n Call_forest.cons fee_payer t.account_updates\n\nlet fee (t : t) : Currency.Fee.t = t.fee_payer.body.fee\n\nlet fee_payer_account_update ({ fee_payer; _ } : t) = fee_payer\n\nlet applicable_at_nonce (t : t) : Account.Nonce.t =\n (fee_payer_account_update t).body.nonce\n\nlet target_nonce_on_success (t : t) : Account.Nonce.t =\n let base_nonce = Account.Nonce.succ (applicable_at_nonce t) in\n let fee_payer_pubkey = t.fee_payer.body.public_key in\n let fee_payer_account_update_increments =\n List.count (Call_forest.to_list t.account_updates) ~f:(fun p ->\n Public_key.Compressed.equal p.body.public_key fee_payer_pubkey\n && p.body.increment_nonce )\n in\n Account.Nonce.add base_nonce\n (Account.Nonce.of_int fee_payer_account_update_increments)\n\nlet nonce_increments (t : t) : int Public_key.Compressed.Map.t =\n let base_increments =\n Public_key.Compressed.Map.of_alist_exn [ (t.fee_payer.body.public_key, 1) ]\n in\n List.fold_left (Call_forest.to_list t.account_updates) ~init:base_increments\n ~f:(fun incr_map account_update ->\n if account_update.body.increment_nonce then\n Map.update incr_map account_update.body.public_key\n ~f:(Option.value_map ~default:1 ~f:(( + ) 1))\n else incr_map )\n\nlet fee_token (_t : t) = Token_id.default\n\nlet fee_payer (t : t) =\n Account_id.create t.fee_payer.body.public_key (fee_token t)\n\nlet extract_vks (t : t) : Verification_key_wire.t List.t =\n account_updates t\n |> Call_forest.fold ~init:[] ~f:(fun acc (p : Account_update.t) ->\n match Account_update.verification_key_update_to_option p with\n | Zkapp_basic.Set_or_keep.Set (Some vk) ->\n vk :: acc\n | _ ->\n acc )\n\nlet account_updates_list (t : t) : Account_update.t list =\n Call_forest.fold t.account_updates ~init:[] ~f:(Fn.flip List.cons) |> List.rev\n\nlet all_account_updates_list (t : t) : Account_update.t list =\n Call_forest.fold t.account_updates\n ~init:[ Account_update.of_fee_payer (fee_payer_account_update t) ]\n ~f:(Fn.flip List.cons)\n |> List.rev\n\nlet fee_excess (t : t) =\n Fee_excess.of_single (fee_token t, Currency.Fee.Signed.of_unsigned (fee t))\n\n(* always `Accessed` for fee payer *)\nlet account_access_statuses (t : t) (status : Transaction_status.t) =\n let init = [ (fee_payer t, `Accessed) ] in\n let status_sym =\n match status with Applied -> `Accessed | Failed _ -> `Not_accessed\n in\n Call_forest.fold t.account_updates ~init ~f:(fun acc p ->\n (Account_update.account_id p, status_sym) :: acc )\n |> List.rev |> List.stable_dedup\n\nlet accounts_referenced (t : t) =\n List.map (account_access_statuses t Applied) ~f:(fun (acct_id, _status) ->\n acct_id )\n\nlet fee_payer_pk (t : t) = t.fee_payer.body.public_key\n\nlet value_if b ~then_ ~else_ = if b then then_ else else_\n\nmodule Virtual = struct\n module Bool = struct\n type t = bool\n\n let true_ = true\n\n let assert_ _ = ()\n\n let equal = Bool.equal\n\n let not = not\n\n let ( || ) = ( || )\n\n let ( && ) = ( && )\n end\n\n module Unit = struct\n type t = unit\n\n let if_ = value_if\n end\n\n module Ledger = Unit\n module Account = Unit\n\n module Amount = struct\n open Currency.Amount\n\n type nonrec t = t\n\n let if_ = value_if\n\n module Signed = Signed\n\n let zero = zero\n\n let ( - ) (x1 : t) (x2 : t) : Signed.t =\n Option.value_exn Signed.(of_unsigned x1 + negate (of_unsigned x2))\n\n let ( + ) (x1 : t) (x2 : t) : t = Option.value_exn (add x1 x2)\n\n let add_signed (x1 : t) (x2 : Signed.t) : t =\n let y = Option.value_exn Signed.(of_unsigned x1 + x2) in\n match y.sgn with Pos -> y.magnitude | Neg -> failwith \"add_signed\"\n end\n\n module Token_id = struct\n include Token_id\n\n let if_ = value_if\n end\n\n module Zkapp_command = struct\n type t = Account_update.t list\n\n let if_ = value_if\n\n type account_update = Account_update.t\n\n let empty = []\n\n let is_empty = List.is_empty\n\n let pop (t : t) = match t with [] -> failwith \"pop\" | p :: t -> (p, t)\n end\nend\n\nlet check_authorization (p : Account_update.t) : unit Or_error.t =\n match (p.authorization, p.body.authorization_kind) with\n | None_given, None_given | Proof _, Proof _ | Signature _, Signature ->\n Ok ()\n | _ ->\n let err =\n let expected =\n Account_update.Authorization_kind.to_control_tag\n p.body.authorization_kind\n in\n let got = Control.tag p.authorization in\n Error.create \"Authorization kind does not match the authorization\"\n [ (\"expected\", expected); (\"got\", got) ]\n [%sexp_of: (string * Control.Tag.t) list]\n in\n Error err\n\nmodule Verifiable : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t = private\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates :\n ( Side_loaded_verification_key.Stable.V2.t\n , Zkapp_basic.F.Stable.V1.t )\n With_hash.Stable.V1.t\n option\n Call_forest.With_hashes_and_data.Stable.V1.t\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n val to_latest : t -> t\n end\n end]\n\n val find_vk_via_ledger :\n ledger:'a\n -> get:('a -> 'b -> Account.t option)\n -> location_of_account:('a -> Account_id.t -> 'b option)\n -> Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t\n\n val create :\n T.t\n -> status:Transaction_status.t\n -> find_vk:\n ( Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t )\n -> t Or_error.t\n\n module Any : sig\n (** creates verifiables from a list of commands that caches verification\n keys and permits _any_ vks that have been seen earlier in the list. *)\n val create_all :\n T.t With_status.t list\n -> find_vk:\n ( Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t )\n -> t With_status.t list Or_error.t\n end\n\n module Last : sig\n (** creates verifiables from a list of commands that caches verification\n keys and permits only the _last_ vk that has been seen earlier in the\n list. *)\n val create_all :\n T.t With_status.t list\n -> find_vk:\n ( Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t )\n -> t With_status.t list Or_error.t\n end\nend = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { fee_payer : Account_update.Fee_payer.Stable.V1.t\n ; account_updates :\n ( Side_loaded_verification_key.Stable.V2.t\n , Zkapp_basic.F.Stable.V1.t )\n With_hash.Stable.V1.t\n option\n Call_forest.With_hashes_and_data.Stable.V1.t\n ; memo : Signed_command_memo.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let ok_if_vk_hash_expected ~got ~expected =\n if not @@ Zkapp_basic.F.equal (With_hash.hash got) expected then\n Error\n (Error.create \"Expected vk hash doesn't match hash in vk we received\"\n [ (\"expected_vk_hash\", expected)\n ; (\"got_vk_hash\", With_hash.hash got)\n ]\n [%sexp_of: (string * Zkapp_basic.F.t) list] )\n else Ok got\n\n let find_vk_via_ledger ~ledger ~get ~location_of_account expected_vk_hash\n account_id =\n match\n let open Option.Let_syntax in\n let%bind location = location_of_account ledger account_id in\n let%bind (account : Account.t) = get ledger location in\n let%bind zkapp = account.zkapp in\n zkapp.verification_key\n with\n | Some vk ->\n ok_if_vk_hash_expected ~got:vk ~expected:expected_vk_hash\n | None ->\n let err =\n Error.create \"No verification key found for proved account update\"\n (\"account_id\", account_id) [%sexp_of: string * Account_id.t]\n in\n Error err\n\n (* Ensures that there's a verification_key available for all account_updates\n * and creates a valid command associating the correct keys with each\n * account_id.\n *\n * If an account_update replaces the verification_key (or deletes it),\n * subsequent account_updates use the replaced key instead of looking in the\n * ledger for the key (ie set by a previous transaction).\n *)\n let create ({ fee_payer; account_updates; memo } : T.t)\n ~(status : Transaction_status.t) ~find_vk : t Or_error.t =\n With_return.with_return (fun { return } ->\n let tbl = Account_id.Table.create () in\n let vks_overridden =\n (* Keep track of the verification keys that have been set so far\n during this transaction.\n *)\n ref Account_id.Map.empty\n in\n let account_updates =\n Call_forest.map account_updates ~f:(fun p ->\n let account_id = Account_update.account_id p in\n let vks_overriden' =\n match Account_update.verification_key_update_to_option p with\n | Zkapp_basic.Set_or_keep.Set vk_next ->\n Account_id.Map.set !vks_overridden ~key:account_id\n ~data:vk_next\n | Zkapp_basic.Set_or_keep.Keep ->\n !vks_overridden\n in\n let () =\n match check_authorization p with\n | Ok () ->\n ()\n | Error _ as err ->\n return err\n in\n match\n ( p.body.authorization_kind\n , phys_equal status Transaction_status.Applied )\n with\n | Proof vk_hash, true -> (\n let prioritized_vk =\n (* only lookup _past_ vk setting, ie exclude the new one we\n * potentially set in this account_update (use the non-'\n * vks_overrided) . *)\n match Account_id.Map.find !vks_overridden account_id with\n | Some (Some vk) -> (\n match\n ok_if_vk_hash_expected ~got:vk ~expected:vk_hash\n with\n | Ok vk ->\n Some vk\n | Error err ->\n return (Error err) )\n | Some None ->\n (* we explicitly have erased the key *)\n let err =\n Error.create\n \"No verification key found for proved account \\\n update: the verification key was removed by a \\\n previous account update\"\n (\"account_id\", account_id)\n [%sexp_of: string * Account_id.t]\n in\n return (Error err)\n | None -> (\n (* we haven't set anything; lookup the vk in the fallback *)\n match find_vk vk_hash account_id with\n | Error e ->\n return (Error e)\n | Ok vk ->\n Some vk )\n in\n match prioritized_vk with\n | Some prioritized_vk ->\n Account_id.Table.update tbl account_id ~f:(fun _ ->\n With_hash.hash prioritized_vk ) ;\n (* return the updated overrides *)\n vks_overridden := vks_overriden' ;\n (p, Some prioritized_vk)\n | None ->\n (* The transaction failed, so we allow the vk to be missing. *)\n (p, None) )\n | _ ->\n vks_overridden := vks_overriden' ;\n (p, None) )\n in\n Ok { fee_payer; account_updates; memo } )\n\n module Map_cache = struct\n type 'a t = 'a Zkapp_basic.F_map.Map.t\n\n let empty = Zkapp_basic.F_map.Map.empty\n\n let find = Zkapp_basic.F_map.Map.find\n\n let set = Zkapp_basic.F_map.Map.set\n end\n\n module Singleton_cache = struct\n type 'a t = (Zkapp_basic.F.t * 'a) option\n\n let empty = None\n\n let find t key =\n match t with\n | None ->\n None\n | Some (k, v) ->\n if Zkapp_basic.F.equal key k then Some v else None\n\n let set _ ~key ~data = Some (key, data)\n end\n\n module Make_create_all (Cache : sig\n type 'a t\n\n val empty : 'a t\n\n val find : 'a t -> Zkapp_basic.F.t -> 'a option\n\n val set : 'a t -> key:Zkapp_basic.F.t -> data:'a -> 'a t\n end) =\n struct\n let create_all (cmds : T.t With_status.t list)\n ~(find_vk :\n Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t ) :\n t With_status.t list Or_error.t =\n Or_error.try_with (fun () ->\n snd (* remove the helper cache we folded with *)\n (List.fold_map cmds ~init:Cache.empty\n ~f:(fun\n (running_cache : Verification_key_wire.t Cache.t)\n { data = cmd; status }\n ->\n let verified_cmd : t =\n create cmd ~status ~find_vk:(fun vk_hash account_id ->\n (* first we check if there's anything in the running\n cache within this chunk so far *)\n match Cache.find running_cache vk_hash with\n | None ->\n (* before falling back to the find_vk *)\n find_vk vk_hash account_id\n | Some vk ->\n Ok vk )\n |> Or_error.ok_exn\n in\n let running_cache' =\n List.fold (extract_vks cmd) ~init:running_cache\n ~f:(fun acc vk ->\n Cache.set acc ~key:(With_hash.hash vk) ~data:vk )\n in\n (running_cache', { With_status.data = verified_cmd; status }) )\n ) )\n end\n\n module Any = struct\n include Make_create_all (Map_cache)\n end\n\n module Last = struct\n include Make_create_all (Singleton_cache)\n end\nend\n\nlet of_verifiable (t : Verifiable.t) : t =\n { fee_payer = t.fee_payer\n ; account_updates = Call_forest.map t.account_updates ~f:fst\n ; memo = t.memo\n }\n\nmodule Transaction_commitment = struct\n module Stable = Kimchi_backend.Pasta.Basic.Fp.Stable\n\n type t = (Stable.Latest.t[@deriving sexp])\n\n let sexp_of_t = Stable.Latest.sexp_of_t\n\n let t_of_sexp = Stable.Latest.t_of_sexp\n\n let empty = Outside_hash_image.t\n\n let typ = Snark_params.Tick.Field.typ\n\n let create ~(account_updates_hash : Digest.Forest.t) : t =\n (account_updates_hash :> t)\n\n let create_complete (t : t) ~memo_hash\n ~(fee_payer_hash : Digest.Account_update.t) =\n Random_oracle.hash ~init:Hash_prefix.account_update_cons\n [| memo_hash; (fee_payer_hash :> t); t |]\n\n module Checked = struct\n type t = Pickles.Impls.Step.Field.t\n\n let create ~(account_updates_hash : Digest.Forest.Checked.t) =\n (account_updates_hash :> t)\n\n let create_complete (t : t) ~memo_hash\n ~(fee_payer_hash : Digest.Account_update.Checked.t) =\n Random_oracle.Checked.hash ~init:Hash_prefix.account_update_cons\n [| memo_hash; (fee_payer_hash :> t); t |]\n end\nend\n\nlet account_updates_hash (t : t) = Call_forest.hash t.account_updates\n\nlet commitment (t : t) : Transaction_commitment.t =\n Transaction_commitment.create ~account_updates_hash:(account_updates_hash t)\n\n(** This module defines weights for each component of a `Zkapp_command.t` element. *)\nmodule Weight = struct\n let account_update : Account_update.t -> int = fun _ -> 1\n\n let fee_payer (_fp : Account_update.Fee_payer.t) : int = 1\n\n let account_updates : (Account_update.t, _, _) Call_forest.t -> int =\n Call_forest.fold ~init:0 ~f:(fun acc p -> acc + account_update p)\n\n let memo : Signed_command_memo.t -> int = fun _ -> 0\nend\n\nlet weight (zkapp_command : t) : int =\n let { fee_payer; account_updates; memo } = zkapp_command in\n List.sum\n (module Int)\n ~f:Fn.id\n [ Weight.fee_payer fee_payer\n ; Weight.account_updates account_updates\n ; Weight.memo memo\n ]\n\nmodule type Valid_intf = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t = private { zkapp_command : T.Stable.V1.t }\n [@@deriving sexp, compare, equal, hash, yojson]\n end\n end]\n\n val to_valid_unsafe :\n T.t -> [> `If_this_is_used_it_should_have_a_comment_justifying_it of t ]\n\n val to_valid :\n T.t\n -> status:Transaction_status.t\n -> find_vk:\n ( Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t )\n -> t Or_error.t\n\n val of_verifiable : Verifiable.t -> t\n\n val forget : t -> T.t\nend\n\nmodule Valid :\n Valid_intf\n with type Stable.V1.t = Mina_wire_types.Mina_base.Zkapp_command.Valid.V1.t =\nstruct\n module S = Stable\n\n module Verification_key_hash = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Zkapp_basic.F.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Zkapp_command.Valid.V1.t =\n { zkapp_command : S.V1.t }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let create zkapp_command : t = { zkapp_command }\n\n let of_verifiable (t : Verifiable.t) : t = { zkapp_command = of_verifiable t }\n\n let to_valid_unsafe (t : T.t) :\n [> `If_this_is_used_it_should_have_a_comment_justifying_it of t ] =\n `If_this_is_used_it_should_have_a_comment_justifying_it (create t)\n\n let forget (t : t) : T.t = t.zkapp_command\n\n let to_valid (t : T.t) ~status ~find_vk : t Or_error.t =\n Verifiable.create t ~status ~find_vk |> Or_error.map ~f:of_verifiable\nend\n\n[%%define_locally Stable.Latest.(of_yojson, to_yojson)]\n\n(* so transaction ids have a version tag *)\ninclude Codable.Make_base64 (Stable.Latest.With_top_version_tag)\n\ntype account_updates =\n (Account_update.t, Digest.Account_update.t, Digest.Forest.t) Call_forest.t\n\nlet account_updates_deriver obj =\n let of_zkapp_command_with_depth (ps : Account_update.Graphql_repr.t list) :\n account_updates =\n Call_forest.of_account_updates ps\n ~account_update_depth:(fun (p : Account_update.Graphql_repr.t) ->\n p.body.call_depth )\n |> Call_forest.map ~f:Account_update.of_graphql_repr\n |> Call_forest.accumulate_hashes'\n and to_zkapp_command_with_depth (ps : account_updates) :\n Account_update.Graphql_repr.t list =\n ps\n |> Call_forest.to_account_updates_map ~f:(fun ~depth p ->\n Account_update.to_graphql_repr ~call_depth:depth p )\n in\n let open Fields_derivers_zkapps.Derivers in\n let inner = (list @@ Account_update.Graphql_repr.deriver @@ o ()) @@ o () in\n iso ~map:of_zkapp_command_with_depth ~contramap:to_zkapp_command_with_depth\n inner obj\n\nlet deriver obj =\n let open Fields_derivers_zkapps.Derivers in\n let ( !. ) = ( !. ) ~t_fields_annots in\n Fields.make_creator obj\n ~fee_payer:!.Account_update.Fee_payer.deriver\n ~account_updates:!.account_updates_deriver\n ~memo:!.Signed_command_memo.deriver\n |> finish \"ZkappCommand\" ~t_toplevel_annots\n\nlet arg_typ () = Fields_derivers_zkapps.(arg_typ (deriver @@ Derivers.o ()))\n\nlet typ () = Fields_derivers_zkapps.(typ (deriver @@ Derivers.o ()))\n\nlet to_json x = Fields_derivers_zkapps.(to_json (deriver @@ Derivers.o ())) x\n\nlet of_json x = Fields_derivers_zkapps.(of_json (deriver @@ Derivers.o ())) x\n\nlet account_updates_of_json x =\n Fields_derivers_zkapps.(\n of_json\n ((list @@ Account_update.Graphql_repr.deriver @@ o ()) @@ derivers ()))\n x\n\nlet zkapp_command_to_json x =\n Fields_derivers_zkapps.(to_json (deriver @@ derivers ())) x\n\nlet arg_query_string x =\n Fields_derivers_zkapps.Test.Loop.json_to_string_gql @@ to_json x\n\nlet dummy =\n lazy\n (let account_update : Account_update.t =\n { body = Account_update.Body.dummy\n ; authorization = Control.dummy_of_tag Signature\n }\n in\n let fee_payer : Account_update.Fee_payer.t =\n { body = Account_update.Body.Fee_payer.dummy\n ; authorization = Signature.dummy\n }\n in\n { fee_payer\n ; account_updates = Call_forest.cons account_update []\n ; memo = Signed_command_memo.empty\n } )\n\nmodule Make_update_group (Input : sig\n type global_state\n\n type local_state\n\n type spec\n\n type connecting_ledger_hash\n\n val zkapp_segment_of_controls : Control.t list -> spec\nend) : sig\n module Zkapp_command_intermediate_state : sig\n type state = { global : Input.global_state; local : Input.local_state }\n\n type t =\n { kind : [ `Same | `New | `Two_new ]\n ; spec : Input.spec\n ; state_before : state\n ; state_after : state\n ; connecting_ledger : Input.connecting_ledger_hash\n }\n end\n\n val group_by_zkapp_command_rev :\n t list\n -> (Input.global_state * Input.local_state * Input.connecting_ledger_hash)\n list\n list\n -> Zkapp_command_intermediate_state.t list\nend = struct\n open Input\n\n module Zkapp_command_intermediate_state = struct\n type state = { global : global_state; local : local_state }\n\n type t =\n { kind : [ `Same | `New | `Two_new ]\n ; spec : spec\n ; state_before : state\n ; state_after : state\n ; connecting_ledger : connecting_ledger_hash\n }\n end\n\n (** [group_by_zkapp_command_rev zkapp_commands stmtss] identifies before/after pairs of\n statements, corresponding to account updates for each zkapp_command in [zkapp_commands] which minimize the\n number of snark proofs needed to prove all of the zkapp_command.\n\n This function is intended to take multiple zkapp transactions as\n its input, which is then converted to a [Account_update.t list list] using\n [List.map ~f:Zkapp_command.zkapp_command]. The [stmtss] argument should\n be a list of the same length, with 1 more state than the number of\n zkapp_command for each transaction.\n\n For example, two transactions made up of zkapp_command [[p1; p2; p3]] and\n [[p4; p5]] should have the statements [[[s0; s1; s2; s3]; [s3; s4; s5]]],\n where each [s_n] is the state after applying [p_n] on top of [s_{n-1}], and\n where [s0] is the initial state before any of the transactions have been\n applied.\n\n Each pair is also identified with one of [`Same], [`New], or [`Two_new],\n indicating that the next one ([`New]) or next two ([`Two_new]) [Zkapp_command.t]s\n will need to be passed as part of the snark witness while applying that\n pair.\n *)\n let group_by_zkapp_command_rev (zkapp_commands : t list)\n (stmtss : (global_state * local_state * connecting_ledger_hash) list list)\n : Zkapp_command_intermediate_state.t list =\n let intermediate_state ~kind ~spec ~before ~after =\n let global_before, local_before, _ = before in\n let global_after, local_after, connecting_ledger = after in\n { Zkapp_command_intermediate_state.kind\n ; spec\n ; state_before = { global = global_before; local = local_before }\n ; state_after = { global = global_after; local = local_after }\n ; connecting_ledger\n }\n in\n let zkapp_account_updatess =\n []\n :: List.map zkapp_commands ~f:(fun (zkapp_command : t) ->\n all_account_updates_list zkapp_command )\n in\n let rec group_by_zkapp_command_rev\n (zkapp_commands : Account_update.t list list) stmtss acc =\n match (zkapp_commands, stmtss) with\n | ([] | [ [] ]), [ _ ] ->\n (* We've associated statements with all given zkapp_command. *)\n acc\n | [ [ { authorization = a1; _ } ] ], [ [ before; after ] ] ->\n (* There are no later zkapp_command to pair this one with. Prove it on its\n own.\n *)\n intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc\n | [ []; [ { authorization = a1; _ } ] ], [ [ _ ]; [ before; after ] ] ->\n (* This account_update is part of a new transaction, and there are no later\n zkapp_command to pair it with. Prove it on its own.\n *)\n intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc\n | ( ({ authorization = Proof _ as a1; _ } :: zkapp_command)\n :: zkapp_commands\n , (before :: (after :: _ as stmts)) :: stmtss ) ->\n (* This account_update contains a proof, don't pair it with other account updates. *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( []\n :: ({ authorization = Proof _ as a1; _ } :: zkapp_command)\n :: zkapp_commands\n , [ _ ] :: (before :: (after :: _ as stmts)) :: stmtss ) ->\n (* This account_update is part of a new transaction, and contains a proof, don't\n pair it with other account updates.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( ({ authorization = a1; _ }\n :: ({ authorization = Proof _; _ } :: _ as zkapp_command) )\n :: zkapp_commands\n , (before :: (after :: _ as stmts)) :: stmtss ) ->\n (* The next account_update contains a proof, don't pair it with this account_update. *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( ({ authorization = a1; _ } :: ([] as zkapp_command))\n :: (({ authorization = Proof _; _ } :: _) :: _ as zkapp_commands)\n , (before :: (after :: _ as stmts)) :: stmtss ) ->\n (* The next account_update is in the next transaction and contains a proof,\n don't pair it with this account_update.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( ({ authorization = (Signature _ | None_given) as a1; _ }\n :: { authorization = (Signature _ | None_given) as a2; _ }\n :: zkapp_command )\n :: zkapp_commands\n , (before :: _ :: (after :: _ as stmts)) :: stmtss ) ->\n (* The next two zkapp_command do not contain proofs, and are within the same\n transaction. Pair them.\n Ok to get \"use_full_commitment\" of [a1] because neither of them\n contain a proof.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1; a2 ])\n ~before ~after\n :: acc )\n | ( []\n :: ({ authorization = a1; _ }\n :: ({ authorization = Proof _; _ } :: _ as zkapp_command) )\n :: zkapp_commands\n , [ _ ] :: (before :: (after :: _ as stmts)) :: stmtss ) ->\n (* This account_update is in the next transaction, and the next account_update contains a\n proof, don't pair it with this account_update.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( []\n :: ({ authorization = (Signature _ | None_given) as a1; _ }\n :: { authorization = (Signature _ | None_given) as a2; _ }\n :: zkapp_command )\n :: zkapp_commands\n , [ _ ] :: (before :: _ :: (after :: _ as stmts)) :: stmtss ) ->\n (* The next two zkapp_command do not contain proofs, and are within the same\n new transaction. Pair them.\n Ok to get \"use_full_commitment\" of [a1] because neither of them\n contain a proof.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1; a2 ])\n ~before ~after\n :: acc )\n | ( [ { authorization = (Signature _ | None_given) as a1; _ } ]\n :: ({ authorization = (Signature _ | None_given) as a2; _ }\n :: zkapp_command )\n :: zkapp_commands\n , (before :: _after1) :: (_before2 :: (after :: _ as stmts)) :: stmtss )\n ->\n (* The next two zkapp_command do not contain proofs, and the second is within\n a new transaction. Pair them.\n Ok to get \"use_full_commitment\" of [a1] because neither of them\n contain a proof.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1; a2 ])\n ~before ~after\n :: acc )\n | ( []\n :: ({ authorization = a1; _ } :: zkapp_command)\n :: (({ authorization = Proof _; _ } :: _) :: _ as zkapp_commands)\n , [ _ ] :: (before :: ([ after ] as stmts)) :: (_ :: _ as stmtss) ) ->\n (* The next transaction contains a proof, and this account_update is in a new\n transaction, don't pair it with the next account_update.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc )\n | ( []\n :: [ { authorization = (Signature _ | None_given) as a1; _ } ]\n :: ({ authorization = (Signature _ | None_given) as a2; _ }\n :: zkapp_command )\n :: zkapp_commands\n , [ _ ]\n :: [ before; _after1 ]\n :: (_before2 :: (after :: _ as stmts)) :: stmtss ) ->\n (* The next two zkapp_command do not contain proofs, the first is within a\n new transaction, and the second is within another new transaction.\n Pair them.\n Ok to get \"use_full_commitment\" of [a1] because neither of them\n contain a proof.\n *)\n group_by_zkapp_command_rev\n (zkapp_command :: zkapp_commands)\n (stmts :: stmtss)\n ( intermediate_state ~kind:`Two_new\n ~spec:(zkapp_segment_of_controls [ a1; a2 ])\n ~before ~after\n :: acc )\n | [ [ { authorization = a1; _ } ] ], (before :: after :: _) :: _ ->\n (* This account_update is the final account_update given. Prove it on its own. *)\n intermediate_state ~kind:`Same\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc\n | ( [] :: [ { authorization = a1; _ } ] :: [] :: _\n , [ _ ] :: (before :: after :: _) :: _ ) ->\n (* This account_update is the final account_update given, in a new transaction. Prove it\n on its own.\n *)\n intermediate_state ~kind:`New\n ~spec:(zkapp_segment_of_controls [ a1 ])\n ~before ~after\n :: acc\n | _, [] ->\n failwith \"group_by_zkapp_command_rev: No statements remaining\"\n | ([] | [ [] ]), _ ->\n failwith \"group_by_zkapp_command_rev: Unmatched statements remaining\"\n | [] :: _, [] :: _ ->\n failwith\n \"group_by_zkapp_command_rev: No final statement for current \\\n transaction\"\n | [] :: _, (_ :: _ :: _) :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Unmatched statements for current \\\n transaction\"\n | [] :: [ _ ] :: _, [ _ ] :: (_ :: _ :: _ :: _) :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Unmatched statements for next \\\n transaction\"\n | [ []; [ _ ] ], [ _ ] :: [ _; _ ] :: _ :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Unmatched statements after next \\\n transaction\"\n | (_ :: _) :: _, ([] | [ _ ]) :: _ | (_ :: _ :: _) :: _, [ _; _ ] :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Too few statements remaining for the \\\n current transaction\"\n | ([] | [ _ ]) :: [] :: _, _ ->\n failwith\n \"group_by_zkapp_command_rev: The next transaction has no \\\n zkapp_command\"\n | [] :: (_ :: _) :: _, _ :: ([] | [ _ ]) :: _\n | [] :: (_ :: _ :: _) :: _, _ :: [ _; _ ] :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Too few statements remaining for the \\\n next transaction\"\n | [ _ ] :: (_ :: _) :: _, _ :: ([] | [ _ ]) :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Too few statements remaining for the \\\n next transaction\"\n | [] :: [ _ ] :: (_ :: _) :: _, _ :: _ :: ([] | [ _ ]) :: _ ->\n failwith\n \"group_by_zkapp_command_rev: Too few statements remaining for the \\\n transaction after next\"\n | ([] | [ _ ]) :: (_ :: _) :: _, [ _ ] ->\n failwith\n \"group_by_zkapp_command_rev: No statements given for the next \\\n transaction\"\n | [] :: [ _ ] :: (_ :: _) :: _, [ _; _ :: _ :: _ ] ->\n failwith\n \"group_by_zkapp_command_rev: No statements given for transaction \\\n after next\"\n in\n group_by_zkapp_command_rev zkapp_account_updatess stmtss []\nend\n\n(*Transaction_snark.Zkapp_command_segment.Basic.t*)\ntype possible_segments = Proved | Signed_single | Signed_pair\n\nmodule Update_group = Make_update_group (struct\n type local_state = unit\n\n type global_state = unit\n\n type connecting_ledger_hash = unit\n\n type spec = possible_segments\n\n let zkapp_segment_of_controls controls : spec =\n match controls with\n | [ Control.Proof _ ] ->\n Proved\n | [ (Control.Signature _ | Control.None_given) ] ->\n Signed_single\n | [ Control.(Signature _ | None_given); Control.(Signature _ | None_given) ]\n ->\n Signed_pair\n | _ ->\n failwith \"zkapp_segment_of_controls: Unsupported combination\"\nend)\n\nlet zkapp_cost ~proof_segments ~signed_single_segments ~signed_pair_segments\n ~(genesis_constants : Genesis_constants.t) () =\n (*10.26*np + 10.08*n2 + 9.14*n1 < 69.45*)\n let proof_cost = genesis_constants.zkapp_proof_update_cost in\n let signed_pair_cost = genesis_constants.zkapp_signed_pair_update_cost in\n let signed_single_cost = genesis_constants.zkapp_signed_single_update_cost in\n Float.(\n (proof_cost * of_int proof_segments)\n + (signed_pair_cost * of_int signed_pair_segments)\n + (signed_single_cost * of_int signed_single_segments))\n\n(* Zkapp_command transactions are filtered using this predicate\n - when adding to the transaction pool\n - in incoming blocks\n*)\nlet valid_size ~(genesis_constants : Genesis_constants.t) (t : t) :\n unit Or_error.t =\n let events_elements events =\n List.fold events ~init:0 ~f:(fun acc event -> acc + Array.length event)\n in\n let all_updates, num_event_elements, num_action_elements =\n Call_forest.fold t.account_updates\n ~init:([ Account_update.of_fee_payer (fee_payer_account_update t) ], 0, 0)\n ~f:(fun (acc, num_event_elements, num_action_elements)\n (account_update : Account_update.t) ->\n let account_update_evs_elements =\n events_elements account_update.body.events\n in\n let account_update_seq_evs_elements =\n events_elements account_update.body.actions\n in\n ( account_update :: acc\n , num_event_elements + account_update_evs_elements\n , num_action_elements + account_update_seq_evs_elements ) )\n |> fun (updates, ev, sev) -> (List.rev updates, ev, sev)\n in\n let groups =\n Update_group.group_by_zkapp_command_rev [ t ]\n ( [ ((), (), ()) ]\n :: [ ((), (), ()) :: List.map all_updates ~f:(fun _ -> ((), (), ())) ] )\n in\n let proof_segments, signed_single_segments, signed_pair_segments =\n List.fold ~init:(0, 0, 0) groups\n ~f:(fun (proof_segments, signed_singles, signed_pairs) { spec; _ } ->\n match spec with\n | Proved ->\n (proof_segments + 1, signed_singles, signed_pairs)\n | Signed_single ->\n (proof_segments, signed_singles + 1, signed_pairs)\n | Signed_pair ->\n (proof_segments, signed_singles, signed_pairs + 1) )\n in\n let cost_limit = genesis_constants.zkapp_transaction_cost_limit in\n let max_event_elements = genesis_constants.max_event_elements in\n let max_action_elements = genesis_constants.max_action_elements in\n let zkapp_cost_within_limit =\n Float.(\n zkapp_cost ~proof_segments ~signed_single_segments ~signed_pair_segments\n ~genesis_constants ()\n < cost_limit)\n in\n let valid_event_elements = num_event_elements <= max_event_elements in\n let valid_action_elements = num_action_elements <= max_action_elements in\n if zkapp_cost_within_limit && valid_event_elements && valid_action_elements\n then Ok ()\n else\n let proof_zkapp_command_err =\n if zkapp_cost_within_limit then None\n else Some (sprintf \"zkapp transaction too expensive\")\n in\n let events_err =\n if valid_event_elements then None\n else\n Some\n (sprintf \"too many event elements (%d, max allowed is %d)\"\n num_event_elements max_event_elements )\n in\n let actions_err =\n if valid_action_elements then None\n else\n Some\n (sprintf \"too many sequence event elements (%d, max allowed is %d)\"\n num_action_elements max_action_elements )\n in\n let err_msg =\n List.filter\n [ proof_zkapp_command_err; events_err; actions_err ]\n ~f:Option.is_some\n |> List.map ~f:(fun opt -> Option.value_exn opt)\n |> String.concat ~sep:\"; \"\n in\n Error (Error.of_string err_msg)\n\nlet has_zero_vesting_period t =\n Call_forest.exists t.account_updates ~f:(fun p ->\n match p.body.update.timing with\n | Keep ->\n false\n | Set { vesting_period; _ } ->\n Mina_numbers.Global_slot_span.(equal zero) vesting_period )\n\nlet get_transaction_commitments (zkapp_command : t) =\n let memo_hash = Signed_command_memo.hash zkapp_command.memo in\n let fee_payer_hash =\n Account_update.of_fee_payer zkapp_command.fee_payer\n |> Digest.Account_update.create\n in\n let account_updates_hash = account_updates_hash zkapp_command in\n let txn_commitment = Transaction_commitment.create ~account_updates_hash in\n let full_txn_commitment =\n Transaction_commitment.create_complete txn_commitment ~memo_hash\n ~fee_payer_hash\n in\n (txn_commitment, full_txn_commitment)\n\nlet inner_query =\n lazy\n (Option.value_exn ~message:\"Invariant: All projectable derivers are Some\"\n Fields_derivers_zkapps.(inner_query (deriver @@ Derivers.o ())) )\n\nmodule For_tests = struct\n let replace_vks t vk =\n { t with\n account_updates =\n Call_forest.map t.account_updates ~f:(fun (p : Account_update.t) ->\n { p with\n body =\n { p.body with\n update =\n { p.body.update with\n verification_key =\n (* replace dummy vks in vk Setting *)\n ( match p.body.update.verification_key with\n | Set _vk ->\n Set vk\n | Keep ->\n Keep )\n }\n ; authorization_kind =\n (* replace dummy vk hashes in authorization kind *)\n ( match p.body.authorization_kind with\n | Proof _vk_hash ->\n Proof (With_hash.hash vk)\n | ak ->\n ak )\n }\n } )\n }\nend\n\nlet%test \"latest zkApp version\" =\n (* if this test fails, update `Transaction_hash.hash_of_transaction_id`\n for latest version, then update this test\n *)\n Stable.Latest.version = 1\n","open Core_kernel\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type ('u, 's) t =\n ('u, 's) Mina_wire_types.Mina_base.User_command.Poly.V2.t =\n | Signed_command of 'u\n | Zkapp_command of 's\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n\n module V1 = struct\n type ('u, 's) t = Signed_command of 'u | Snapp_command of 's\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest : _ t -> _ V2.t = function\n | Signed_command x ->\n Signed_command x\n | Snapp_command _ ->\n failwith \"Snapp_command\"\n end\n end]\nend\n\ntype ('u, 's) t_ = ('u, 's) Poly.Stable.Latest.t =\n | Signed_command of 'u\n | Zkapp_command of 's\n\nmodule Gen_make (C : Signed_command_intf.Gen_intf) = struct\n let to_signed_command f =\n Quickcheck.Generator.map f ~f:(fun c -> Signed_command c)\n\n open C.Gen\n\n let payment ?sign_type ~key_gen ?nonce ~max_amount ~fee_range () =\n to_signed_command\n (payment ?sign_type ~key_gen ?nonce ~max_amount ~fee_range ())\n\n let payment_with_random_participants ?sign_type ~keys ?nonce ~max_amount\n ~fee_range () =\n to_signed_command\n (payment_with_random_participants ?sign_type ~keys ?nonce ~max_amount\n ~fee_range () )\n\n let stake_delegation ~key_gen ?nonce ~fee_range () =\n to_signed_command (stake_delegation ~key_gen ?nonce ~fee_range ())\n\n let stake_delegation_with_random_participants ~keys ?nonce ~fee_range () =\n to_signed_command\n (stake_delegation_with_random_participants ~keys ?nonce ~fee_range ())\n\n let sequence ?length ?sign_type a =\n Quickcheck.Generator.map\n (sequence ?length ?sign_type a)\n ~f:(List.map ~f:(fun c -> Signed_command c))\nend\n\nmodule Gen = Gen_make (Signed_command)\n\nlet gen_signed =\n let module G = Signed_command.Gen in\n let open Quickcheck.Let_syntax in\n let%bind keys =\n Quickcheck.Generator.list_with_length 2\n Mina_base_import.Signature_keypair.gen\n in\n G.payment_with_random_participants ~sign_type:`Real ~keys:(Array.of_list keys)\n ~max_amount:10000 ~fee_range:1000 ()\n\nlet gen = Gen.to_signed_command gen_signed\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n (Signed_command.Stable.V2.t, Zkapp_command.Stable.V1.t) Poly.Stable.V2.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\nlet to_base64 : t -> string = function\n | Signed_command sc ->\n Signed_command.to_base64 sc\n | Zkapp_command zc ->\n Zkapp_command.to_base64 zc\n\nlet of_base64 s : t Or_error.t =\n match Signed_command.of_base64 s with\n | Ok sc ->\n Ok (Signed_command sc)\n | Error err1 -> (\n match Zkapp_command.of_base64 s with\n | Ok zc ->\n Ok (Zkapp_command zc)\n | Error err2 ->\n Error\n (Error.of_string\n (sprintf\n \"Could decode Base64 neither to signed command (%s), nor to \\\n zkApp (%s)\"\n (Error.to_string_hum err1) (Error.to_string_hum err2) ) ) )\n\n(*\ninclude Allocation_functor.Make.Versioned_v1.Full_compare_eq_hash (struct\n let id = \"user_command\"\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n (Signed_command.Stable.V1.t, Snapp_command.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n\n type 'a creator : Signed_command.t -> Snapp_command.t -> 'a\n\n let create cmd1 cmd2 = (cmd1, cmd2)\n end\n end]\nend)\n*)\n\nmodule Zero_one_or_two = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'a t = [ `Zero | `One of 'a | `Two of 'a * 'a ]\n [@@deriving sexp, compare, equal, hash, yojson]\n end\n end]\nend\n\nmodule Verifiable = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Signed_command.Stable.V2.t\n , Zkapp_command.Verifiable.Stable.V1.t )\n Poly.Stable.V2.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let fee_payer (t : t) =\n match t with\n | Signed_command x ->\n Signed_command.fee_payer x\n | Zkapp_command p ->\n Account_update.Fee_payer.account_id p.fee_payer\nend\n\nlet to_verifiable (t : t) ~status ~find_vk : Verifiable.t Or_error.t =\n match t with\n | Signed_command c ->\n Ok (Signed_command c)\n | Zkapp_command cmd ->\n Zkapp_command.Verifiable.create ~status ~find_vk cmd\n |> Or_error.map ~f:(fun cmd -> Zkapp_command cmd)\n\nmodule Make_to_all_verifiable (Strategy : sig\n val create_all :\n Zkapp_command.t With_status.t list\n -> find_vk:\n ( Zkapp_basic.F.t\n -> Account_id.t\n -> (Verification_key_wire.t, Error.t) Result.t )\n -> Zkapp_command.Verifiable.t With_status.t list Or_error.t\nend) =\nstruct\n let to_all_verifiable (ts : t With_status.t list) ~find_vk :\n Verifiable.t With_status.t list Or_error.t =\n let open Or_error.Let_syntax in\n (* First we tag everything with its index *)\n let its = List.mapi ts ~f:(fun i x -> (i, x)) in\n (* then we partition out the zkapp commands *)\n let izk_cmds, is_cmds =\n List.partition_map its ~f:(fun (i, cmd) ->\n match cmd.data with\n | Zkapp_command c ->\n First (i, { cmd with data = c })\n | Signed_command c ->\n Second (i, { cmd with data = c }) )\n in\n (* then unzip the indices *)\n let ixs, zk_cmds = List.unzip izk_cmds in\n (* then we verify the zkapp commands *)\n let%map vzk_cmds = Strategy.create_all ~find_vk zk_cmds in\n (* rezip indices *)\n let ivzk_cmds = List.zip_exn ixs vzk_cmds in\n (* Put them back in with a sort by index (un-partition) *)\n let ivs =\n List.map is_cmds ~f:(fun (i, cmd) ->\n (i, { cmd with data = Signed_command cmd.data }) )\n @ List.map ivzk_cmds ~f:(fun (i, cmd) ->\n (i, { cmd with data = Zkapp_command cmd.data }) )\n |> List.sort ~compare:(fun (i, _) (j, _) -> i - j)\n in\n (* Drop the indices *)\n List.unzip ivs |> snd\nend\n\nmodule Any = struct\n include Make_to_all_verifiable (Zkapp_command.Verifiable.Any)\nend\n\nmodule Last = struct\n include Make_to_all_verifiable (Zkapp_command.Verifiable.Last)\nend\n\nlet of_verifiable (t : Verifiable.t) : t =\n match t with\n | Signed_command x ->\n Signed_command x\n | Zkapp_command p ->\n Zkapp_command (Zkapp_command.of_verifiable p)\n\nlet fee : t -> Currency.Fee.t = function\n | Signed_command x ->\n Signed_command.fee x\n | Zkapp_command p ->\n Zkapp_command.fee p\n\n(* for filtering *)\nlet minimum_fee = Currency.Fee.minimum_user_command_fee\n\nlet has_insufficient_fee t = Currency.Fee.(fee t < minimum_fee)\n\n(* always `Accessed` for fee payer *)\nlet accounts_accessed (t : t) (status : Transaction_status.t) :\n (Account_id.t * [ `Accessed | `Not_accessed ]) list =\n match t with\n | Signed_command x ->\n Signed_command.account_access_statuses x status\n | Zkapp_command ps ->\n Zkapp_command.account_access_statuses ps status\n\nlet accounts_referenced (t : t) =\n List.map (accounts_accessed t Applied) ~f:(fun (acct_id, _status) -> acct_id)\n\nlet fee_payer (t : t) =\n match t with\n | Signed_command x ->\n Signed_command.fee_payer x\n | Zkapp_command p ->\n Zkapp_command.fee_payer p\n\n(** The application nonce is the nonce of the fee payer at which a user command can be applied. *)\nlet applicable_at_nonce (t : t) =\n match t with\n | Signed_command x ->\n Signed_command.nonce x\n | Zkapp_command p ->\n Zkapp_command.applicable_at_nonce p\n\nlet expected_target_nonce t = Account.Nonce.succ (applicable_at_nonce t)\n\nlet extract_vks : t -> Verification_key_wire.t List.t = function\n | Signed_command _ ->\n []\n | Zkapp_command cmd ->\n Zkapp_command.extract_vks cmd\n\n(** The target nonce is what the nonce of the fee payer will be after a user command is successfully applied. *)\nlet target_nonce_on_success (t : t) =\n match t with\n | Signed_command x ->\n Account.Nonce.succ (Signed_command.nonce x)\n | Zkapp_command p ->\n Zkapp_command.target_nonce_on_success p\n\nlet fee_token (t : t) =\n match t with\n | Signed_command x ->\n Signed_command.fee_token x\n | Zkapp_command x ->\n Zkapp_command.fee_token x\n\nlet valid_until (t : t) =\n match t with\n | Signed_command x ->\n Signed_command.valid_until x\n | Zkapp_command { fee_payer; _ } -> (\n match fee_payer.Account_update.Fee_payer.body.valid_until with\n | Some valid_until ->\n valid_until\n | None ->\n Mina_numbers.Global_slot_since_genesis.max_value )\n\nmodule Valid = struct\n type t_ = t\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Signed_command.With_valid_signature.Stable.V2.t\n , Zkapp_command.Valid.Stable.V1.t )\n Poly.Stable.V2.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n module Gen = Gen_make (Signed_command.With_valid_signature)\nend\n\nlet check_verifiable (t : Verifiable.t) : Valid.t Or_error.t =\n match t with\n | Signed_command x -> (\n match Signed_command.check x with\n | Some c ->\n Ok (Signed_command c)\n | None ->\n Or_error.error_string \"Invalid signature\" )\n | Zkapp_command p ->\n Ok (Zkapp_command (Zkapp_command.Valid.of_verifiable p))\n\nlet check ~status ~find_vk (t : t) : Valid.t Or_error.t =\n to_verifiable ~status ~find_vk t |> Or_error.bind ~f:check_verifiable\n\nlet forget_check (t : Valid.t) : t =\n match t with\n | Zkapp_command x ->\n Zkapp_command (Zkapp_command.Valid.forget x)\n | Signed_command c ->\n Signed_command (c :> Signed_command.t)\n\nlet to_valid_unsafe (t : t) =\n `If_this_is_used_it_should_have_a_comment_justifying_it\n ( match t with\n | Zkapp_command x ->\n let (`If_this_is_used_it_should_have_a_comment_justifying_it x) =\n Zkapp_command.Valid.to_valid_unsafe x\n in\n Zkapp_command x\n | Signed_command x ->\n (* This is safe due to being immediately wrapped again. *)\n let (`If_this_is_used_it_should_have_a_comment_justifying_it x) =\n Signed_command.to_valid_unsafe x\n in\n Signed_command x )\n\nlet filter_by_participant (commands : t list) public_key =\n List.filter commands ~f:(fun user_command ->\n Core_kernel.List.exists\n (accounts_referenced user_command)\n ~f:\n (Fn.compose\n (Signature_lib.Public_key.Compressed.equal public_key)\n Account_id.public_key ) )\n\n(* A metric on user commands that should correspond roughly to resource costs\n for validation/application *)\nlet weight : t -> int = function\n | Signed_command signed_command ->\n Signed_command.payload signed_command |> Signed_command_payload.weight\n | Zkapp_command zkapp_command ->\n Zkapp_command.weight zkapp_command\n\n(* Fee per weight unit *)\nlet fee_per_wu (user_command : Stable.Latest.t) : Currency.Fee_rate.t =\n (*TODO: return Or_error*)\n Currency.Fee_rate.make_exn (fee user_command) (weight user_command)\n\nlet valid_size ~genesis_constants = function\n | Signed_command _ ->\n Ok ()\n | Zkapp_command zkapp_command ->\n Zkapp_command.valid_size ~genesis_constants zkapp_command\n\nlet has_zero_vesting_period = function\n | Signed_command _ ->\n false\n | Zkapp_command p ->\n Zkapp_command.has_zero_vesting_period p\n\nmodule Well_formedness_error = struct\n (* syntactically-evident errors such that a user command can never succeed *)\n type t =\n | Insufficient_fee\n | Zero_vesting_period\n | Zkapp_too_big of (Error.t[@to_yojson Error_json.error_to_yojson])\n [@@deriving compare, to_yojson]\n\n let to_string = function\n | Insufficient_fee ->\n \"Insufficient fee\"\n | Zero_vesting_period ->\n \"Zero vesting period\"\n | Zkapp_too_big err ->\n sprintf \"Zkapp too big (%s)\" (Error.to_string_hum err)\nend\n\nlet check_well_formedness ~genesis_constants t :\n (unit, Well_formedness_error.t list) result =\n let preds =\n let open Well_formedness_error in\n [ (has_insufficient_fee, Insufficient_fee)\n ; (has_zero_vesting_period, Zero_vesting_period)\n ]\n in\n let errs0 =\n List.fold preds ~init:[] ~f:(fun acc (f, err) ->\n if f t then err :: acc else acc )\n in\n let errs =\n match valid_size ~genesis_constants t with\n | Ok () ->\n errs0\n | Error err ->\n Zkapp_too_big err :: errs0\n in\n if List.is_empty errs then Ok () else Error errs\n\ntype fee_payer_summary_t = Signature.t * Account.key * int\n[@@deriving yojson, hash]\n\nlet fee_payer_summary : t -> fee_payer_summary_t = function\n | Zkapp_command cmd ->\n let fp = Zkapp_command.fee_payer_account_update cmd in\n let open Account_update in\n let body = Fee_payer.body fp in\n ( Fee_payer.authorization fp\n , Body.Fee_payer.public_key body\n , Body.Fee_payer.nonce body |> Unsigned.UInt32.to_int )\n | Signed_command cmd ->\n Signed_command.\n (signature cmd, fee_payer_pk cmd, nonce cmd |> Unsigned.UInt32.to_int)\n\nlet fee_payer_summary_json =\n Fn.compose fee_payer_summary_t_to_yojson fee_payer_summary\n\nlet fee_payer_summary_string =\n let to_string (signature, pk, nonce) =\n sprintf \"%s (%s %d)\"\n (Signature.to_base58_check signature)\n (Signature_lib.Public_key.Compressed.to_base58_check pk)\n nonce\n in\n Fn.compose to_string fee_payer_summary\n","open Core_kernel\nopen Mina_base_import\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Fee_transfer\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Fee_transfer_intf.Full\n with type Single.Stable.V2.t = A.Single.V2.t\n and type Stable.V2.t = A.V2.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n module Single = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = A.Single.V2.t =\n { receiver_pk : Public_key.Compressed.Stable.V1.t\n ; fee : Currency.Fee.Stable.V1.t\n ; fee_token : Token_id.Stable.V2.t\n }\n [@@deriving sexp, compare, equal, yojson, hash]\n\n let to_latest = Fn.id\n\n let description = \"Fee transfer Single\"\n\n let version_byte = Base58_check.Version_bytes.fee_transfer_single\n end\n end]\n\n include Comparable.Make (Stable.Latest)\n module Base58_check = Codable.Make_base58_check (Stable.Latest)\n\n [%%define_locally\n Base58_check.(to_base58_check, of_base58_check, of_base58_check_exn)]\n\n let create ~receiver_pk ~fee ~fee_token = { receiver_pk; fee; fee_token }\n\n let receiver_pk { receiver_pk; _ } = receiver_pk\n\n let receiver { receiver_pk; fee_token; _ } =\n Account_id.create receiver_pk fee_token\n\n let fee { fee; _ } = fee\n\n let fee_token { fee_token; _ } = fee_token\n\n module Gen = struct\n let with_random_receivers ?(min_fee = 0) ~max_fee ~token keys :\n t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map receiver_pk =\n let open Signature_lib in\n Quickcheck_lib.of_array keys\n >>| fun keypair -> Public_key.compress keypair.Keypair.public_key\n and fee =\n Int.gen_incl min_fee max_fee >>| Currency.Fee.of_nanomina_int_exn\n and fee_token = token in\n { receiver_pk; fee; fee_token }\n end\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = Single.Stable.V2.t One_or_two.Stable.V1.t\n [@@deriving sexp, compare, equal, yojson, hash]\n\n let to_latest = Fn.id\n end\n end]\n\n type single = Single.t =\n { receiver_pk : Public_key.Compressed.t\n ; fee : Currency.Fee.t\n ; fee_token : Token_id.t\n }\n [@@deriving sexp, compare, yojson, hash]\n\n let to_singles = Fn.id\n\n let of_singles = function\n | `One _ as t ->\n Or_error.return t\n | `Two (one, two) as t ->\n if Token_id.equal one.fee_token two.fee_token then Or_error.return t\n else\n (* Necessary invariant for the transaction snark: we should never have\n fee excesses in multiple tokens simultaneously.\n *)\n Or_error.errorf\n !\"Cannot combine single fee transfers with incompatible tokens: \\\n %{sexp: Token_id.t} <> %{sexp: Token_id.t}\"\n one.fee_token two.fee_token\n\n let create one two =\n let singles =\n match two with None -> `One one | Some two -> `Two (one, two)\n in\n of_singles singles\n\n let create_single ~receiver_pk ~fee ~fee_token =\n `One (Single.create ~receiver_pk ~fee ~fee_token)\n\n include Comparable.Make (Stable.Latest)\n\n let fee_excess ft =\n ft\n |> One_or_two.map ~f:(fun { fee_token; fee; _ } ->\n (fee_token, Currency.Fee.Signed.(negate (of_unsigned fee))) )\n |> Fee_excess.of_one_or_two\n\n let receiver_pks t =\n One_or_two.to_list (One_or_two.map ~f:Single.receiver_pk t)\n\n let receivers t = One_or_two.to_list (One_or_two.map ~f:Single.receiver t)\n\n (* This must match [Transaction_union].\n TODO: enforce this.\n *)\n let fee_payer_pk ft =\n match ft with\n | `One ft ->\n Single.receiver_pk ft\n | `Two (_, ft) ->\n Single.receiver_pk ft\n\n let fee_token = Single.fee_token\n\n let fee_tokens = One_or_two.map ~f:Single.fee_token\n\n let map = One_or_two.map\n\n let fold = One_or_two.fold\n\n let to_list = One_or_two.to_list\n\n let to_numbered_list = One_or_two.to_numbered_list\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nopen Mina_base_import\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Coinbase_fee_transfer\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Coinbase_fee_transfer_intf.Full with type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = A.V1.t =\n { receiver_pk : Public_key.Compressed.Stable.V1.t\n ; fee : Currency.Fee.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, yojson, hash]\n\n let to_latest = Fn.id\n\n let description = \"Coinbase fee transfer\"\n\n let version_byte = Base58_check.Version_bytes.fee_transfer_single\n end\n end]\n\n let create ~receiver_pk ~fee = { receiver_pk; fee }\n\n include Comparable.Make (Stable.Latest)\n module Base58_check = Codable.Make_base58_check (Stable.Latest)\n\n [%%define_locally\n Base58_check.(to_base58_check, of_base58_check, of_base58_check_exn)]\n\n let receiver_pk { receiver_pk; _ } = receiver_pk\n\n let receiver { receiver_pk; _ } =\n Account_id.create receiver_pk Token_id.default\n\n let fee { fee; _ } = fee\n\n let to_fee_transfer { receiver_pk; fee } =\n Fee_transfer.Single.create ~receiver_pk ~fee ~fee_token:Token_id.default\n\n module Gen = struct\n let gen ?(min_fee = Currency.Fee.zero) max_fee : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%bind receiver_pk = Public_key.Compressed.gen in\n let%map fee = Currency.Fee.gen_incl min_fee max_fee in\n { receiver_pk; fee }\n\n let with_random_receivers ~keys ?(min_fee = Currency.Fee.zero)\n coinbase_amount : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let max_fee = Currency.Amount.to_fee coinbase_amount in\n let%map receiver_pk =\n let open Signature_lib in\n Quickcheck_lib.of_array keys\n >>| fun keypair -> Public_key.compress keypair.Keypair.public_key\n and fee = Currency.Fee.gen_incl min_fee max_fee in\n { receiver_pk; fee }\n end\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nopen Mina_base_import\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_base.Coinbase\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Coinbase_intf.Full with type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n module Fee_transfer = Coinbase_fee_transfer\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = A.V1.t =\n { receiver : Public_key.Compressed.Stable.V1.t\n ; amount : Currency.Amount.Stable.V1.t\n ; fee_transfer : Fee_transfer.Stable.V1.t option\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n\n let description = \"Coinbase\"\n\n let version_byte = Base58_check.Version_bytes.coinbase\n end\n end]\n\n module Base58_check = Codable.Make_base58_check (Stable.Latest)\n\n [%%define_locally\n Base58_check.(to_base58_check, of_base58_check, of_base58_check_exn)]\n\n let receiver_pk t = t.receiver\n\n let receiver t = Account_id.create t.receiver Token_id.default\n\n (* This must match [Transaction_union].\n TODO: enforce this.\n *)\n let fee_payer_pk cb =\n match cb.fee_transfer with None -> cb.receiver | Some ft -> ft.receiver_pk\n\n let amount t = t.amount\n\n let fee_transfer t = t.fee_transfer\n\n let account_access_statuses t (status : Transaction_status.t) =\n let access_status =\n match status with Applied -> `Accessed | Failed _ -> `Not_accessed\n in\n let account_ids =\n receiver t\n :: List.map ~f:Fee_transfer.receiver (Option.to_list t.fee_transfer)\n in\n List.map account_ids ~f:(fun acct_id -> (acct_id, access_status))\n\n let accounts_referenced t =\n List.map (account_access_statuses t Transaction_status.Applied)\n ~f:(fun (acct_id, _status) -> acct_id)\n\n let is_valid { amount; fee_transfer; _ } =\n match fee_transfer with\n | None ->\n true\n | Some { fee; _ } ->\n Currency.Amount.(of_fee fee <= amount)\n\n let create ~amount ~receiver ~fee_transfer =\n let t = { receiver; amount; fee_transfer } in\n if is_valid t then\n let adjusted_fee_transfer =\n Option.bind fee_transfer ~f:(fun fee_transfer ->\n Option.some_if\n (not\n (Public_key.Compressed.equal receiver\n (Fee_transfer.receiver_pk fee_transfer) ) )\n fee_transfer )\n in\n Ok { t with fee_transfer = adjusted_fee_transfer }\n else Or_error.error_string \"Coinbase.create: invalid coinbase\"\n\n let expected_supply_increase { receiver = _; amount; fee_transfer } =\n match fee_transfer with\n | None ->\n Ok amount\n | Some { fee; _ } ->\n Currency.Amount.sub amount (Currency.Amount.of_fee fee)\n |> Option.value_map\n ~f:(fun _ -> Ok amount)\n ~default:(Or_error.error_string \"Coinbase underflow\")\n\n let fee_excess t =\n Or_error.map (expected_supply_increase t) ~f:(fun _increase ->\n Fee_excess.empty )\n\n module Gen = struct\n let gen ~(constraint_constants : Genesis_constants.Constraint_constants.t) =\n let open Quickcheck.Let_syntax in\n let%bind receiver = Public_key.Compressed.gen in\n let%bind supercharged_coinbase = Quickcheck.Generator.bool in\n let%bind amount =\n let max_amount = constraint_constants.coinbase_amount in\n (* amount should be at least the account creation fee to pay for the creation of coinbase receiver and the fee transfer receiver below *)\n let min_amount =\n Option.value_exn\n (Currency.Fee.scale constraint_constants.account_creation_fee 2)\n |> Currency.Amount.of_fee\n in\n let%map amount = Currency.Amount.(gen_incl min_amount max_amount) in\n if supercharged_coinbase then\n Option.value_exn\n (Currency.Amount.scale amount\n constraint_constants.supercharged_coinbase_factor )\n else amount\n in\n (* keep account-creation fee for the coinbase-receiver *)\n let max_fee =\n Option.value_exn\n (Currency.Fee.sub\n (Currency.Amount.to_fee amount)\n constraint_constants.account_creation_fee )\n in\n let min_fee = constraint_constants.account_creation_fee in\n let%map fee_transfer =\n Option.quickcheck_generator (Fee_transfer.Gen.gen ~min_fee max_fee)\n in\n let fee_transfer =\n match fee_transfer with\n | Some { Fee_transfer.receiver_pk; _ }\n when Public_key.Compressed.equal receiver receiver_pk ->\n (* Erase fee transfer, to mirror [create]. *)\n None\n | _ ->\n fee_transfer\n in\n ( { receiver; amount; fee_transfer }\n , `Supercharged_coinbase supercharged_coinbase )\n\n let with_random_receivers ~keys ~min_amount ~max_amount ~fee_transfer =\n let open Quickcheck.Let_syntax in\n let%bind receiver =\n let open Signature_lib in\n Quickcheck_lib.of_array keys\n >>| fun keypair -> Public_key.compress keypair.Keypair.public_key\n and amount =\n Int.gen_incl min_amount max_amount\n >>| Currency.Amount.of_nanomina_int_exn\n in\n let%map fee_transfer =\n Option.quickcheck_generator (fee_transfer ~coinbase_amount:amount)\n in\n let fee_transfer =\n match fee_transfer with\n | Some { Fee_transfer.receiver_pk; _ }\n when Public_key.Compressed.equal receiver receiver_pk ->\n (* Erase fee transfer, to mirror [create]. *)\n None\n | _ ->\n fee_transfer\n in\n { receiver; amount; fee_transfer }\n end\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nopen Mina_base_import\nopen Snarky_backendless\nopen Snark_params\nopen Snark_params.Tick\nopen Let_syntax\nopen Currency\n\n(* A pending coinbase is basically a Merkle tree of \"stacks\", each of which contains two hashes. The first hash\n is computed from the components in the coinbase via a \"push\" operation. The second hash, a protocol\n state hash, is computed from the state *body* hash in the coinbase.\n The \"add_coinbase\" operation takes a coinbase, retrieves the latest stack, or creates a new one, and does\n a push.\n\n A pending coinbase also contains a stack id, used to determine the chronology of stacks, so we can know\n which is the oldest, and which is the newest stack.\n\n The name \"stack\" here is a misnomer: see issue #3226\n*)\nmodule Wire_types = Mina_wire_types.Mina_base.Pending_coinbase\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Pending_coinbase_intf.S\n with type State_stack.Stable.V1.t = A.State_stack.V1.t\n and type Stack_versioned.Stable.V1.t = A.Stack_versioned.V1.t\n and type Hash.t = A.Hash_builder.V1.t\n and type Hash_versioned.Stable.V1.t = A.Hash_versioned.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n module Coinbase_data = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Public_key.Compressed.Stable.V1.t * Amount.Stable.V1.t\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let of_coinbase (cb : Coinbase.t) : t = (cb.receiver, cb.amount)\n\n type var = Public_key.Compressed.var * Amount.var\n\n let var_of_t ((public_key, amount) : t) =\n (Public_key.Compressed.var_of_t public_key, Amount.var_of_t amount)\n\n let to_input (pk, amount) =\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n [ Public_key.Compressed.to_input pk; Amount.to_input amount ]\n\n module Checked = struct\n let to_input (public_key, amount) =\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n [ Public_key.Compressed.Checked.to_input public_key\n ; Amount.var_to_input amount\n ]\n end\n\n let typ : (var, t) Typ.t =\n let of_hlist\n : 'public_key 'amount.\n (unit, 'public_key -> 'amount -> unit) H_list.t\n -> 'public_key * 'amount =\n let open H_list in\n fun [ public_key; amount ] -> (public_key, amount)\n in\n let to_hlist (public_key, amount) = H_list.[ public_key; amount ] in\n Typ.of_hlistable\n [ Public_key.Compressed.typ; Amount.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n let empty = (Public_key.Compressed.empty, Amount.zero)\n\n let genesis = empty\n end\n\n module Stack_id : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving sexp, yojson, compare, equal]\n end\n end]\n\n val of_int : int -> t\n\n val to_int : t -> int\n\n val zero : t\n\n val incr_by_one : t -> t Or_error.t\n\n val to_string : t -> string\n\n val ( > ) : t -> t -> bool\n end = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = int [@@deriving sexp, yojson, compare, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n [%%define_locally Int.(( > ), to_string, zero, to_int, of_int, equal)]\n\n let incr_by_one t1 =\n let t2 = t1 + 1 in\n if t2 < t1 then Or_error.error_string \"Stack_id overflow\" else Ok t2\n end\n\n module type Data_hash_intf = sig\n type t = private Field.t [@@deriving sexp, compare, equal, yojson, hash]\n\n type var\n\n val var_of_t : t -> var\n\n val typ : (var, t) Typ.t\n\n val var_to_hash_packed : var -> Field.Var.t\n\n val equal_var : var -> var -> Boolean.var Tick.Checked.t\n\n val to_bytes : t -> string\n\n val to_bits : t -> bool list\n\n val to_base58_check : t -> string\n\n val of_base58_check_exn : string -> t\n\n val gen : t Quickcheck.Generator.t\n end\n\n (* a coinbase stack has two components, data and a state_hash\n we create modules for each component\n *)\n\n module Coinbase_stack = struct\n include Data_hash.Make_full_size (struct\n let description = \"Coinbase stack data\"\n\n let version_byte = Base58_check.Version_bytes.coinbase_stack_data\n end)\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\n end]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n let push (h : t) cb =\n let coinbase = Coinbase_data.of_coinbase cb in\n let open Random_oracle in\n hash ~init:Hash_prefix.coinbase_stack\n (pack_input\n (Input.Chunked.append (Coinbase_data.to_input coinbase) (to_input h)) )\n |> of_hash\n\n let empty = Hash_prefix_create.salt \"CoinbaseStack\" |> Random_oracle.digest\n\n module Checked = struct\n type t = var\n\n let push (h : t) (cb : Coinbase_data.var) =\n let open Random_oracle.Checked in\n make_checked (fun () ->\n hash ~init:Hash_prefix.coinbase_stack\n (pack_input\n (Random_oracle.Input.Chunked.append\n (Coinbase_data.Checked.to_input cb)\n (var_to_input h) ) )\n |> var_of_hash_packed )\n\n let check_merge (_, t1) (s2, _) = equal_var t1 s2\n\n let if_ = if_\n end\n end\n\n module Stack_hash = struct\n include Data_hash.Make_full_size (struct\n let description = \"Coinbase stack hash\"\n\n let version_byte = Base58_check.Version_bytes.coinbase_stack_hash\n end)\n\n (* Data hash versioned boilerplate below *)\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\n end]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n let dummy = of_hash Outside_hash_image.t\n end\n\n (*Stack of protocol state body hashes*)\n module State_stack = struct\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'stack_hash t = 'stack_hash A.State_stack.Poly.V1.t =\n { init : 'stack_hash; curr : 'stack_hash }\n [@@deriving sexp, compare, hash, yojson, equal, hlist]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Stack_hash.Stable.V1.t Poly.Stable.V1.t\n [@@deriving sexp, compare, hash, equal, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n type var = Stack_hash.var Poly.t\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map init, curr =\n Quickcheck.Generator.tuple2 Stack_hash.gen Stack_hash.gen\n in\n { Poly.init; curr }\n\n let to_input (t : t) =\n Random_oracle.Input.Chunked.append\n (Stack_hash.to_input t.init)\n (Stack_hash.to_input t.curr)\n\n let var_to_input (t : var) =\n Random_oracle.Input.Chunked.append\n (Stack_hash.var_to_input t.init)\n (Stack_hash.var_to_input t.curr)\n\n let var_of_t (t : t) =\n { Poly.init = Stack_hash.var_of_t t.init\n ; curr = Stack_hash.var_of_t t.curr\n }\n\n let typ : (var, t) Typ.t =\n Snark_params.Tick.Typ.of_hlistable\n [ Stack_hash.typ; Stack_hash.typ ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\n let to_bits (t : t) = Stack_hash.to_bits t.init @ Stack_hash.to_bits t.curr\n\n let to_bytes (t : t) =\n Stack_hash.to_bytes t.init ^ Stack_hash.to_bytes t.curr\n\n let equal_var (v1 : var) (v2 : var) =\n let open Tick.Checked.Let_syntax in\n let%bind b1 = Stack_hash.equal_var v1.init v2.init in\n let%bind b2 = Stack_hash.equal_var v1.curr v2.curr in\n Boolean.(b1 && b2)\n\n let if_ (cond : Tick0.Boolean.var) ~(then_ : var) ~(else_ : var) :\n var Tick0.Checked.t =\n let%bind init = Stack_hash.if_ cond ~then_:then_.init ~else_:else_.init in\n let%map curr = Stack_hash.if_ cond ~then_:then_.curr ~else_:else_.curr in\n { Poly.init; curr }\n\n let push (t : t) (state_body_hash : State_body_hash.t)\n (global_slot : Mina_numbers.Global_slot_since_genesis.t) : t =\n (* this is the same computation for combining state hashes and state body hashes as\n `Protocol_state.hash_abstract', not available here because it would create\n a module dependency cycle\n *)\n { t with\n curr =\n Random_oracle.hash ~init:Hash_prefix.protocol_state\n [| (t.curr :> Field.t)\n ; (state_body_hash :> Field.t)\n ; Mina_numbers.Global_slot_since_genesis.to_field global_slot\n |]\n |> Stack_hash.of_hash\n }\n\n let empty : t = { Poly.init = Stack_hash.dummy; curr = Stack_hash.dummy }\n\n let create ~init = { Poly.init; curr = init }\n\n module Checked = struct\n type t = var\n\n let push (t : t) (state_body_hash : State_body_hash.var)\n (global_slot : Mina_numbers.Global_slot_since_genesis.Checked.var) =\n make_checked (fun () ->\n let curr =\n Random_oracle.Checked.hash ~init:Hash_prefix.protocol_state\n [| Stack_hash.var_to_hash_packed t.curr\n ; State_body_hash.var_to_hash_packed state_body_hash\n ; Mina_numbers.Global_slot_since_genesis.Checked.to_field\n global_slot\n |]\n |> Stack_hash.var_of_hash_packed\n in\n { t with curr } )\n\n let check_merge (s1, t1) (s2, t2) =\n (*state stacks are updated for every transaction in transaction snark but\n only once for every blockchain snark. Therefore, source stacks (and\n target stacks) will be equal for transactions in the same block*)\n let%bind eq_src = equal_var s1 s2\n and eq_target = equal_var t1 t2\n and correct_transition = equal_var t1 s2 in\n let%bind same_update = Boolean.(eq_src &&& eq_target) in\n Boolean.any [ same_update; correct_transition ]\n end\n end\n\n (* Pending coinbase hash *)\n module Hash_builder = struct\n include Data_hash.Make_full_size (struct\n let description = \"Pending coinbase hash builder\"\n\n let version_byte = Base58_check.Version_bytes.receipt_chain_hash\n end)\n\n (* Data hash versioned boilerplate below *)\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n module T = struct\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n [%%define_from_scope to_yojson, of_yojson]\n\n include Comparable.Make (T)\n include Hashable.Make_binable (T)\n end\n end]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n let merge ~height (h1 : t) (h2 : t) =\n Random_oracle.hash\n ~init:(Hash_prefix.coinbase_merkle_tree height)\n [| (h1 :> field); (h2 :> field) |]\n |> of_hash\n\n let empty_hash =\n Hash_prefix_create.salt \"PendingCoinbaseMerkleTree\"\n |> Random_oracle.digest |> of_hash\n\n let of_digest = Fn.compose Fn.id of_hash\n end\n\n module Update = struct\n module Action = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n | Update_none\n | Update_one\n | Update_two_coinbase_in_first\n | Update_two_coinbase_in_second\n [@@deriving equal, sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n type var = Boolean.var * Boolean.var\n\n let to_bits = function\n | Update_none ->\n (false, false)\n | Update_one ->\n (true, false)\n | Update_two_coinbase_in_first ->\n (false, true)\n | Update_two_coinbase_in_second ->\n (true, true)\n\n let of_bits = function\n | false, false ->\n Update_none\n | true, false ->\n Update_one\n | false, true ->\n Update_two_coinbase_in_first\n | true, true ->\n Update_two_coinbase_in_second\n\n let var_of_t t =\n let x, y = to_bits t in\n Boolean.(var_of_value x, var_of_value y)\n\n let typ =\n Typ.transport\n Typ.(Boolean.typ * Boolean.typ)\n ~there:to_bits ~back:of_bits\n\n module Checked = struct\n let no_update (b0, b1) = Boolean.((not b0) &&& not b1)\n\n let update_two_stacks_coinbase_in_first (b0, b1) =\n Boolean.((not b0) &&& b1)\n\n let update_two_stacks_coinbase_in_second (b0, b1) = Boolean.(b0 &&& b1)\n end\n end\n\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('action, 'coinbase_amount) t =\n { action : 'action; coinbase_amount : 'coinbase_amount }\n [@@deriving sexp, to_yojson, hlist]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = (Action.Stable.V1.t, Amount.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n [%%define_locally Poly.(to_hlist, of_hlist)]\n\n type var = (Action.var, Amount.var) Poly.t\n\n let typ =\n let open Snark_params.Tick.Typ in\n of_hlistable ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_to_hlist:to_hlist ~value_of_hlist:of_hlist\n [ Action.typ; Amount.typ ]\n\n let genesis : t =\n { coinbase_amount = Currency.Amount.zero; action = Action.Update_none }\n\n let var_of_t (t : t) : var =\n { action = Action.var_of_t t.action\n ; coinbase_amount = Amount.var_of_t t.coinbase_amount\n }\n end\n\n (* Sparse_ledger.Make is applied more than once in the code, so\n it can't make assumptions about the internal structure of its module\n arguments. Therefore, for modules with a bin_io type passed to the functor,\n that type cannot be in a version module hierarchy. We build the required\n modules for Hash and Stack.\n *)\n\n module Stack_versioned = struct\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('data_stack, 'state_stack) t =\n ('data_stack, 'state_stack) A.Stack_versioned.Poly.V1.t =\n { data : 'data_stack; state : 'state_stack }\n [@@deriving yojson, hash, sexp, equal, compare]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n (Coinbase_stack.Stable.V1.t, State_stack.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving equal, yojson, hash, sexp, compare]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Hash_versioned = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Hash_builder.Stable.V1.t\n [@@deriving equal, compare, sexp, yojson, hash]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Merkle_tree_versioned = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( Hash_versioned.Stable.V1.t\n , Stack_id.Stable.V1.t\n , Stack_versioned.Stable.V1.t )\n Sparse_ledger_lib.Sparse_ledger.T.Stable.V2.t\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let (_ :\n ( t\n , ( Hash_versioned.t\n , Stack_id.t\n , Stack_versioned.t )\n Sparse_ledger_lib.Sparse_ledger.T.t )\n Type_equal.t ) =\n Type_equal.T\n end\n\n module T = struct\n (* Total number of stacks *)\n let max_coinbase_stack_count ~depth = Int.pow 2 depth\n\n let chain if_ b ~then_ ~else_ =\n let%bind then_ = then_ and else_ = else_ in\n if_ b ~then_ ~else_\n\n (*pair of coinbase and state stacks*)\n module Stack = struct\n module Poly = struct\n type ('data_stack, 'state_stack) t =\n ('data_stack, 'state_stack) Stack_versioned.Poly.t =\n { data : 'data_stack; state : 'state_stack }\n [@@deriving yojson, hash, sexp, compare, hlist]\n end\n\n type t = Stack_versioned.t [@@deriving yojson, equal, compare, sexp, hash]\n\n let (_ : (t, (Coinbase_stack.t, State_stack.t) Poly.t) Type_equal.t) =\n Type_equal.T\n\n type var = (Coinbase_stack.var, State_stack.var) Poly.t\n\n let to_input ({ data; state } : t) =\n Random_oracle.Input.Chunked.append\n (Coinbase_stack.to_input data)\n (State_stack.to_input state)\n\n let data_hash t =\n Random_oracle.(\n hash ~init:Hash_prefix_states.coinbase_stack (pack_input (to_input t)))\n |> Hash_builder.of_digest\n\n let var_to_input ({ data; state } : var) =\n Random_oracle.Input.Chunked.append\n (Coinbase_stack.var_to_input data)\n (State_stack.var_to_input state)\n\n let hash_var (t : var) =\n make_checked (fun () ->\n Random_oracle.Checked.(\n hash ~init:Hash_prefix_states.coinbase_stack\n (pack_input (var_to_input t))) )\n\n let var_of_t t =\n { Poly.data = Coinbase_stack.var_of_t t.Poly.data\n ; state = State_stack.var_of_t t.state\n }\n\n let gen =\n let open Base_quickcheck.Generator.Let_syntax in\n let%bind data = Coinbase_stack.gen in\n let%map state = State_stack.gen in\n { Poly.data; state }\n\n let typ : (var, t) Typ.t =\n Snark_params.Tick.Typ.of_hlistable\n [ Coinbase_stack.typ; State_stack.typ ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\n let num_pad_bits =\n let len = List.length Coinbase_stack.(to_bits empty) in\n (3 - (len mod 3)) mod 3\n\n (* pad to match the triple representation *)\n let pad_bits = List.init num_pad_bits ~f:(fun _ -> false)\n\n let to_bits t =\n Coinbase_stack.to_bits t.Poly.data\n @ pad_bits\n @ State_stack.to_bits t.Poly.state\n\n let to_bytes t =\n Coinbase_stack.to_bytes t.Poly.data ^ State_stack.to_bytes t.Poly.state\n\n let equal_var var1 var2 =\n let open Tick.Checked.Let_syntax in\n let%bind b1 = Coinbase_stack.equal_var var1.Poly.data var2.Poly.data in\n let%bind b2 = State_stack.equal_var var1.Poly.state var2.Poly.state in\n let open Tick0.Boolean in\n b1 &&& b2\n\n let empty =\n { Poly.data = Coinbase_stack.empty; state = State_stack.empty }\n\n let create_with (t : t) =\n { empty with state = State_stack.create ~init:t.state.curr }\n\n let equal_state_hash t1 t2 = State_stack.equal t1.Poly.state t2.Poly.state\n\n let equal_data t1 t2 = Coinbase_stack.equal t1.Poly.data t2.Poly.data\n\n let connected ?(prev : t option = None) ~first ~second () =\n let coinbase_stack_connected =\n (*same as old stack or second could be a new stack with empty data*)\n equal_data first second\n || Coinbase_stack.(equal empty second.Poly.data)\n in\n let state_stack_connected =\n (*1. same as old stack or\n 2. new stack initialized with the stack state of last block. Not possible to know this unless we track all the stack states because they are updated once per block (init=curr)\n 3. [second] could be a new stack initialized with the latest state of [first] or\n 4. [second] starts from the previous state of [first]. This is not available in either [first] or [second] *)\n equal_state_hash first second\n || Stack_hash.equal second.state.init second.state.curr\n || Stack_hash.equal first.state.curr second.state.curr\n || Option.value_map prev ~default:true ~f:(fun prev ->\n Stack_hash.equal prev.state.curr second.state.curr )\n in\n coinbase_stack_connected && state_stack_connected\n\n let push_coinbase (cb : Coinbase.t) t =\n let data = Coinbase_stack.push t.Poly.data cb in\n { t with data }\n\n let push_state (state_body_hash : State_body_hash.t)\n (global_slot : Mina_numbers.Global_slot_since_genesis.t) (t : t) =\n { t with state = State_stack.push t.state state_body_hash global_slot }\n\n let if_ (cond : Tick0.Boolean.var) ~(then_ : var) ~(else_ : var) :\n var Tick0.Checked.t =\n let%bind data =\n Coinbase_stack.Checked.if_ cond ~then_:then_.data ~else_:else_.data\n in\n let%map state =\n State_stack.if_ cond ~then_:then_.state ~else_:else_.state\n in\n { Poly.data; state }\n\n module Checked = struct\n type t = var\n\n let push_coinbase (coinbase : Coinbase_data.var) (t : t) :\n t Tick0.Checked.t =\n let%map data = Coinbase_stack.Checked.push t.data coinbase in\n { t with data }\n\n let push_state (state_body_hash : State_body_hash.var)\n (global_slot : Mina_numbers.Global_slot_since_genesis.Checked.var)\n (t : t) =\n let%map state =\n State_stack.Checked.push t.state state_body_hash global_slot\n in\n { t with state }\n\n let check_merge ~transition1:((s, t) : t * t)\n ~transition2:((s', t') : t * t) : Boolean.var Tick0.Checked.t =\n let%bind valid_coinbase_stacks =\n Coinbase_stack.Checked.check_merge (s.data, t.data)\n (s'.data, t'.data)\n in\n let%bind valid_state_stacks =\n State_stack.Checked.check_merge (s.state, t.state)\n (s'.state, t'.state)\n in\n Boolean.(valid_coinbase_stacks && valid_state_stacks)\n\n let empty = var_of_t empty\n\n let create_with (t : var) =\n { empty with state = State_stack.create ~init:t.state.init }\n\n let if_ = if_\n end\n end\n\n module Hash = struct\n type t = Hash_builder.t constraint t = Hash_versioned.t\n [@@deriving equal, compare, sexp, yojson, hash]\n\n type var = Hash_builder.var\n\n [%%define_locally\n Hash_builder.\n ( of_digest\n , merge\n , empty_hash\n , gen\n , to_bits\n , to_bytes\n , equal_var\n , var_of_t\n , var_of_hash_packed\n , var_to_hash_packed\n , to_base58_check\n , of_base58_check_exn\n , typ )]\n end\n\n module Merkle_tree = struct\n type t = Merkle_tree_versioned.t [@@deriving sexp, to_yojson]\n\n let (_ :\n ( t\n , (Hash.t, Stack_id.t, Stack.t) Sparse_ledger_lib.Sparse_ledger.T.t\n )\n Type_equal.t ) =\n Type_equal.T\n\n module M = Sparse_ledger_lib.Sparse_ledger.Make (Hash) (Stack_id) (Stack)\n\n [%%define_locally\n M.\n ( of_hash\n , get_exn\n , path_exn\n , set_exn\n , find_index_exn\n , add_path\n , merkle_root )]\n end\n\n module Checked = struct\n type var = Hash.var\n\n module Merkle_tree =\n Snarky_backendless.Merkle_tree.Checked\n (Tick)\n (struct\n type value = Field.t\n\n type var = Field.Var.t\n\n let typ = Field.typ\n\n let merge ~height h1 h2 =\n Tick.make_checked (fun () ->\n Random_oracle.Checked.hash\n ~init:(Hash_prefix.coinbase_merkle_tree height)\n [| h1; h2 |] )\n\n let assert_equal h1 h2 = Field.Checked.Assert.equal h1 h2\n\n let if_ = Field.Checked.if_\n end)\n (struct\n include Stack\n\n type value = t [@@deriving sexp]\n\n let hash var = hash_var var\n end)\n\n module Path = Merkle_tree.Path\n\n type path = Path.value\n\n module Address = struct\n include Merkle_tree.Address\n end\n\n type _ Request.t +=\n | Coinbase_stack_path : Address.value -> path Request.t\n | Get_coinbase_stack : Address.value -> (Stack.t * path) Request.t\n | Set_coinbase_stack : Address.value * Stack.t -> unit Request.t\n | Set_oldest_coinbase_stack : Address.value * Stack.t -> unit Request.t\n | Find_index_of_newest_stacks :\n Update.Action.t\n -> (Address.value * Address.value) Request.t\n | Find_index_of_oldest_stack : Address.value Request.t\n | Get_previous_stack : State_stack.t Request.t\n\n let reraise_merkle_requests (With { request; respond }) =\n match request with\n | Merkle_tree.Get_path addr ->\n respond (Delegate (Coinbase_stack_path addr))\n | Merkle_tree.Set (addr, stack) ->\n respond (Delegate (Set_coinbase_stack (addr, stack)))\n | Merkle_tree.Get_element addr ->\n respond (Delegate (Get_coinbase_stack addr))\n | _ ->\n unhandled\n\n let get ~depth t addr =\n handle\n (fun () -> Merkle_tree.get_req ~depth (Hash.var_to_hash_packed t) addr)\n reraise_merkle_requests\n\n let%snarkydef_ add_coinbase\n ~(constraint_constants : Genesis_constants.Constraint_constants.t) t\n ({ action; coinbase_amount = amount } : Update.var) ~coinbase_receiver\n ~supercharge_coinbase state_body_hash global_slot =\n let depth = constraint_constants.pending_coinbase_depth in\n let%bind addr1, addr2 =\n request_witness\n Typ.(Address.typ ~depth * Address.typ ~depth)\n As_prover.(\n map (read Update.Action.typ action) ~f:(fun act ->\n Find_index_of_newest_stacks act ))\n in\n let equal_to_zero x = Amount.(equal_var x (var_of_t zero)) in\n let%bind no_update = Update.Action.Checked.no_update action in\n let update_state_stack (stack : Stack.var) =\n (*get previous stack to carry-forward the stack of state body hashes*)\n let%bind previous_state_stack =\n request_witness State_stack.typ\n As_prover.(map (return ()) ~f:(fun () -> Get_previous_stack))\n in\n let stack_initialized = { stack with state = previous_state_stack } in\n let%bind stack_with_state_hash =\n Stack.Checked.push_state state_body_hash global_slot\n stack_initialized\n in\n (*Always update the state body hash unless there are no transactions in this block*)\n Stack.Checked.if_ no_update ~then_:stack ~else_:stack_with_state_hash\n in\n let update_stack1 stack =\n let%bind stack = update_state_stack stack in\n let%bind total_coinbase_amount =\n let coinbase_amount =\n Currency.Amount.var_of_t constraint_constants.coinbase_amount\n in\n let supercharged_coinbase =\n let amt =\n Option.value_exn\n (Currency.Amount.scale constraint_constants.coinbase_amount\n constraint_constants.supercharged_coinbase_factor )\n in\n Currency.Amount.var_of_t amt\n in\n Currency.Amount.Checked.if_ supercharge_coinbase\n ~then_:supercharged_coinbase ~else_:coinbase_amount\n in\n let%bind rem_amount =\n Currency.Amount.Checked.sub total_coinbase_amount amount\n in\n let%bind no_coinbase_in_this_stack =\n Update.Action.Checked.update_two_stacks_coinbase_in_second action\n in\n let%bind amount1_equal_to_zero = equal_to_zero amount in\n let%bind amount2_equal_to_zero = equal_to_zero rem_amount in\n (*if no update then coinbase amount has to be zero*)\n let%bind () =\n with_label __LOC__ (fun () ->\n let%bind check =\n Boolean.equal no_update amount1_equal_to_zero\n in\n Boolean.Assert.is_true check )\n in\n let%bind no_coinbase =\n Boolean.(no_update ||| no_coinbase_in_this_stack)\n in\n (* TODO: Optimize here since we are pushing twice to the same stack *)\n let%bind stack_with_amount1 =\n Stack.Checked.push_coinbase (coinbase_receiver, amount) stack\n in\n let%bind stack_with_amount2 =\n Stack.Checked.push_coinbase\n (coinbase_receiver, rem_amount)\n stack_with_amount1\n in\n chain Stack.if_ no_coinbase ~then_:(return stack)\n ~else_:\n (Stack.if_ amount2_equal_to_zero ~then_:stack_with_amount1\n ~else_:stack_with_amount2 )\n in\n (*This is for the second stack for when transactions in a block occupy\n two trees of the scan state; the second tree will carry-forward the state\n stack from the previous block, push the new state, and may or may not have a coinbase*)\n let update_stack2 (init_stack : Stack.var) (stack0 : Stack.var) =\n let%bind add_coinbase =\n Update.Action.Checked.update_two_stacks_coinbase_in_second action\n in\n let%bind update_state =\n let%bind update_second_stack =\n Update.Action.Checked.update_two_stacks_coinbase_in_first action\n in\n Boolean.(update_second_stack ||| add_coinbase)\n in\n let%bind stack =\n let%bind stack_with_state =\n Stack.Checked.push_state state_body_hash global_slot\n { stack0 with\n state =\n State_stack.create ~init:init_stack.Stack.Poly.state.curr\n }\n in\n Stack.if_ update_state ~then_:stack_with_state ~else_:stack0\n in\n let%bind stack_with_coinbase =\n Stack.Checked.push_coinbase (coinbase_receiver, amount) stack\n in\n Stack.if_ add_coinbase ~then_:stack_with_coinbase ~else_:stack\n in\n (*update the first stack*)\n let%bind root', `Old prev, `New _updated_stack1 =\n handle\n (fun () ->\n Merkle_tree.fetch_and_update_req ~depth\n (Hash.var_to_hash_packed t)\n addr1 ~f:update_stack1 )\n reraise_merkle_requests\n in\n (*update the second stack*)\n let%map root, _, _ =\n handle\n (fun () ->\n Merkle_tree.fetch_and_update_req ~depth root' addr2\n ~f:(update_stack2 prev) )\n reraise_merkle_requests\n in\n Hash.var_of_hash_packed root\n\n let%snarkydef_ pop_coinbases\n ~(constraint_constants : Genesis_constants.Constraint_constants.t) t\n ~proof_emitted =\n let depth = constraint_constants.pending_coinbase_depth in\n let%bind addr =\n request_witness (Address.typ ~depth)\n As_prover.(map (return ()) ~f:(fun _ -> Find_index_of_oldest_stack))\n in\n let%bind prev, prev_path =\n request_witness\n Typ.(Stack.typ * Path.typ ~depth)\n As_prover.(\n map\n (read (Address.typ ~depth) addr)\n ~f:(fun a -> Get_coinbase_stack a))\n in\n let stack_hash = Stack.hash_var in\n let%bind prev_entry_hash = stack_hash prev in\n let%bind () =\n Merkle_tree.implied_root prev_entry_hash addr prev_path\n >>= Field.Checked.Assert.equal (Hash.var_to_hash_packed t)\n in\n let%bind next =\n Stack.if_ proof_emitted ~then_:Stack.Checked.empty ~else_:prev\n in\n let%bind next_entry_hash = stack_hash next in\n let%bind () =\n perform\n (let open As_prover in\n let open Let_syntax in\n let%map addr = read (Address.typ ~depth) addr\n and next = read Stack.typ next in\n Set_oldest_coinbase_stack (addr, next))\n in\n let%map new_root =\n Merkle_tree.implied_root next_entry_hash addr prev_path\n in\n (Hash.var_of_hash_packed new_root, prev)\n end\n\n module Poly = struct\n type ('tree, 'stack_id) t = ('tree, 'stack_id) A.Poly.t =\n { tree : 'tree; pos_list : 'stack_id list; new_pos : 'stack_id }\n [@@deriving sexp, to_yojson]\n end\n\n type t = (Merkle_tree.t, Stack_id.t) Poly.t [@@deriving sexp, to_yojson]\n\n let hash_at_level =\n let cached = ref [||] in\n fun i ->\n let len = Array.length !cached in\n let len =\n if len = 0 then (\n cached := [| Stack.data_hash Stack.empty |] ;\n 1 )\n else len\n in\n ( if i >= len then\n let cur_hash = ref (Array.last !cached) in\n cached :=\n Array.append !cached\n (Array.init\n (i + 1 - len)\n ~f:(fun i ->\n cur_hash :=\n Hash.merge ~height:(i + len - 1) !cur_hash !cur_hash ;\n !cur_hash ) ) ) ;\n !cached.(i)\n\n let create_exn' ~depth () =\n let rec create_path height path key =\n if height < 0 then path\n else\n let hash = hash_at_level height in\n create_path (height - 1)\n ((if key mod 2 = 0 then `Left hash else `Right hash) :: path)\n (key / 2)\n in\n let rec make_tree t key =\n if Stack_id.( > ) key (Stack_id.of_int @@ (Int.pow 2 depth - 1)) then t\n else\n let path = create_path (depth - 1) [] (Stack_id.to_int key) in\n make_tree\n (Merkle_tree.add_path t path key Stack.empty)\n (Or_error.ok_exn (Stack_id.incr_by_one key))\n in\n let root_hash = hash_at_level depth in\n { Poly.tree =\n make_tree (Merkle_tree.of_hash ~depth root_hash) Stack_id.zero\n ; pos_list = []\n ; new_pos = Stack_id.zero\n }\n\n [%%define_locally Or_error.(try_with)]\n\n let create ~depth () = try_with (fun () -> create_exn' ~depth ())\n\n let merkle_root (t : t) = Merkle_tree.merkle_root t.tree\n\n let get_stack (t : t) index =\n try_with (fun () -> Merkle_tree.get_exn t.tree index)\n\n let path (t : t) index =\n try_with (fun () -> Merkle_tree.path_exn t.tree index)\n\n let find_index (t : t) key =\n try_with (fun () -> Merkle_tree.find_index_exn t.tree key)\n\n let next_index ~depth (t : t) =\n if\n Stack_id.equal t.new_pos\n (Stack_id.of_int (max_coinbase_stack_count ~depth - 1))\n then Ok Stack_id.zero\n else Stack_id.incr_by_one t.new_pos\n\n let next_stack_id ~depth t ~is_new_stack =\n if is_new_stack then next_index ~depth t else Ok t.new_pos\n\n let incr_index ~depth (t : t) ~is_new_stack =\n let open Or_error.Let_syntax in\n if is_new_stack then\n let%map new_pos = next_index ~depth t in\n { t with pos_list = t.new_pos :: t.pos_list; new_pos }\n else Ok t\n\n let set_stack ~depth (t : t) index stack ~is_new_stack =\n let open Or_error.Let_syntax in\n let%bind tree =\n try_with (fun () -> Merkle_tree.set_exn t.tree index stack)\n in\n incr_index ~depth { t with tree } ~is_new_stack\n\n let latest_stack_id (t : t) ~is_new_stack =\n if is_new_stack then t.new_pos\n else match List.hd t.pos_list with Some x -> x | None -> Stack_id.zero\n\n let curr_stack_id (t : t) = List.hd t.pos_list\n\n let current_stack t =\n let prev_stack_id =\n Option.value ~default:Stack_id.zero (curr_stack_id t)\n in\n Or_error.try_with (fun () ->\n let index = Merkle_tree.find_index_exn t.tree prev_stack_id in\n Merkle_tree.get_exn t.tree index )\n\n let latest_stack (t : t) ~is_new_stack =\n let open Or_error.Let_syntax in\n let key = latest_stack_id t ~is_new_stack in\n let%bind res =\n Or_error.try_with (fun () ->\n let index = Merkle_tree.find_index_exn t.tree key in\n Merkle_tree.get_exn t.tree index )\n in\n if is_new_stack then\n let%map prev_stack = current_stack t in\n { res with state = State_stack.create ~init:prev_stack.state.curr }\n else Ok res\n\n let oldest_stack_id (t : t) = List.last t.pos_list\n\n let remove_oldest_stack_id t =\n match List.rev t with\n | [] ->\n Or_error.error_string \"No coinbase stack-with-state-hash to pop\"\n | x :: xs ->\n Ok (x, List.rev xs)\n\n let oldest_stack t =\n let open Or_error.Let_syntax in\n let key = Option.value ~default:Stack_id.zero (oldest_stack_id t) in\n let%bind index = find_index t key in\n get_stack t index\n\n let update_stack' ~depth t ~(f : Stack.t -> Stack.t) ~is_new_stack =\n let open Or_error.Let_syntax in\n let key = latest_stack_id t ~is_new_stack in\n let%bind stack_index = find_index t key in\n let%bind stack_before = get_stack t stack_index in\n let stack_after = f stack_before in\n (* state hash in \"after\" stack becomes previous state hash at top level *)\n set_stack ~depth t stack_index stack_after ~is_new_stack\n\n let add_coinbase ~depth t ~coinbase ~is_new_stack =\n update_stack' ~depth t ~f:(Stack.push_coinbase coinbase) ~is_new_stack\n\n let add_state ~depth t state_body_hash global_slot ~is_new_stack =\n update_stack' ~depth t\n ~f:(Stack.push_state state_body_hash global_slot)\n ~is_new_stack\n\n let update_coinbase_stack ~depth (t : t) stack ~is_new_stack =\n update_stack' ~depth t ~f:(fun _ -> stack) ~is_new_stack\n\n let remove_coinbase_stack ~depth (t : t) =\n let open Or_error.Let_syntax in\n let%bind oldest_stack, remaining = remove_oldest_stack_id t.pos_list in\n let%bind stack_index = find_index t oldest_stack in\n let%bind stack = get_stack t stack_index in\n let%map t' =\n set_stack ~depth t stack_index Stack.empty ~is_new_stack:false\n in\n (stack, { t' with pos_list = remaining })\n\n let hash_extra ({ pos_list; new_pos; _ } : t) =\n let h = Digestif.SHA256.init () in\n let h =\n Digestif.SHA256.feed_string h\n (List.fold pos_list ~init:\"\" ~f:(fun s a -> s ^ Stack_id.to_string a))\n in\n let h = Digestif.SHA256.feed_string h (Stack_id.to_string new_pos) in\n Digestif.SHA256.(get h |> to_raw_string)\n\n let handler ~depth (t : t) ~is_new_stack =\n let pending_coinbase = ref t in\n let coinbase_stack_path_exn idx =\n List.map\n (path !pending_coinbase idx |> Or_error.ok_exn)\n ~f:(function `Left h -> h | `Right h -> h)\n in\n stage (fun (With { request; respond }) ->\n match request with\n | Checked.Coinbase_stack_path idx ->\n let path =\n (coinbase_stack_path_exn idx :> Random_oracle.Digest.t list)\n in\n respond (Provide path)\n | Checked.Find_index_of_oldest_stack ->\n let stack_id =\n Option.value ~default:Stack_id.zero\n (oldest_stack_id !pending_coinbase)\n in\n let index =\n find_index !pending_coinbase stack_id |> Or_error.ok_exn\n in\n respond (Provide index)\n | Checked.Find_index_of_newest_stacks _action ->\n let index1 =\n let stack_id =\n latest_stack_id !pending_coinbase ~is_new_stack\n in\n find_index !pending_coinbase stack_id |> Or_error.ok_exn\n in\n let index2 =\n let stack_id =\n match\n next_stack_id ~depth !pending_coinbase ~is_new_stack\n with\n | Ok id ->\n id\n | _ ->\n Stack_id.zero\n in\n find_index !pending_coinbase stack_id |> Or_error.ok_exn\n in\n respond @@ Provide (index1, index2)\n | Checked.Get_coinbase_stack idx ->\n let elt = get_stack !pending_coinbase idx |> Or_error.ok_exn in\n let path =\n (coinbase_stack_path_exn idx :> Random_oracle.Digest.t list)\n in\n respond (Provide (elt, path))\n | Checked.Set_coinbase_stack (idx, stack) ->\n pending_coinbase :=\n set_stack ~depth !pending_coinbase idx stack ~is_new_stack\n |> Or_error.ok_exn ;\n respond (Provide ())\n | Checked.Set_oldest_coinbase_stack (idx, stack) ->\n pending_coinbase :=\n set_stack ~depth !pending_coinbase idx stack ~is_new_stack:false\n |> Or_error.ok_exn ;\n respond (Provide ())\n | Checked.Get_previous_stack ->\n let prev_state =\n if is_new_stack then\n let stack =\n current_stack !pending_coinbase |> Or_error.ok_exn\n in\n { State_stack.Poly.init = stack.state.curr\n ; curr = stack.state.curr\n }\n else\n let stack =\n latest_stack !pending_coinbase ~is_new_stack\n |> Or_error.ok_exn\n in\n stack.state\n in\n respond (Provide prev_state)\n | _ ->\n unhandled )\n end\n\n include T\n\n module Poly_versioned = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('tree, 'stack_id) t = ('tree, 'stack_id) T.Poly.t =\n { tree : 'tree; pos_list : 'stack_id list; new_pos : 'stack_id }\n [@@deriving sexp, to_yojson]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V2 = struct\n type t =\n ( Merkle_tree_versioned.Stable.V2.t\n , Stack_id.Stable.V1.t )\n Poly_versioned.Stable.V1.t\n [@@deriving sexp, to_yojson]\n\n let (_ : (t, T.t) Type_equal.t) = Type_equal.T\n\n let to_latest = Fn.id\n end\n end]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n let%test_unit \"add stack + remove stack = initial tree \" =\n let constraint_constants =\n Genesis_constants.Constraint_constants.for_unit_tests\n in\n let depth = constraint_constants.pending_coinbase_depth in\n let coinbases_gen =\n Quickcheck.Generator.list_non_empty\n (Coinbase.Gen.gen ~constraint_constants)\n in\n let pending_coinbases = ref (create ~depth () |> Or_error.ok_exn) in\n Quickcheck.test coinbases_gen ~trials:50 ~f:(fun cbs ->\n Run_in_thread.block_on_async_exn (fun () ->\n let is_new_stack = ref true in\n let init = merkle_root !pending_coinbases in\n let after_adding =\n List.fold cbs ~init:!pending_coinbases\n ~f:(fun acc (coinbase, _) ->\n let t =\n add_coinbase ~depth acc ~coinbase\n ~is_new_stack:!is_new_stack\n |> Or_error.ok_exn\n in\n is_new_stack := false ;\n t )\n in\n let _, after_del =\n remove_coinbase_stack ~depth after_adding |> Or_error.ok_exn\n in\n pending_coinbases := after_del ;\n assert (Hash.equal (merkle_root after_del) init) ;\n Async_kernel.Deferred.return () ) )\n\n module type Pending_coinbase_intf = sig\n type t [@@deriving sexp]\n\n val add_coinbase :\n depth:int -> t -> coinbase:Coinbase.t -> is_new_stack:bool -> t Or_error.t\n\n val add_state :\n depth:int\n -> t\n -> State_body_hash.t\n -> Mina_numbers.Global_slot_since_genesis.t\n -> is_new_stack:bool\n -> t Or_error.t\n end\n\n let add_coinbase_with_zero_checks (type t)\n (module T : Pending_coinbase_intf with type t = t) (t : t)\n ~(constraint_constants : Genesis_constants.Constraint_constants.t)\n ~coinbase ~supercharged_coinbase ~state_body_hash ~global_slot\n ~is_new_stack =\n let depth = constraint_constants.pending_coinbase_depth in\n if Amount.equal coinbase.Coinbase.amount Amount.zero then t\n else\n let max_coinbase_amount =\n if supercharged_coinbase then\n Option.value_exn\n (Currency.Amount.scale constraint_constants.coinbase_amount\n constraint_constants.supercharged_coinbase_factor )\n else constraint_constants.coinbase_amount\n in\n let coinbase' =\n Coinbase.create\n ~amount:\n (Option.value_exn (Amount.sub max_coinbase_amount coinbase.amount))\n ~receiver:coinbase.receiver ~fee_transfer:None\n |> Or_error.ok_exn\n in\n let t_with_state =\n T.add_state ~depth t state_body_hash global_slot ~is_new_stack\n |> Or_error.ok_exn\n in\n (*add coinbase to the same stack*)\n let interim_tree =\n T.add_coinbase ~depth t_with_state ~coinbase ~is_new_stack:false\n |> Or_error.ok_exn\n in\n if Amount.equal coinbase'.amount Amount.zero then interim_tree\n else\n T.add_coinbase ~depth interim_tree ~coinbase:coinbase'\n ~is_new_stack:false\n |> Or_error.ok_exn\n\n let%test_unit \"Checked_stack = Unchecked_stack\" =\n let open Quickcheck in\n let constraint_constants =\n Genesis_constants.Constraint_constants.for_unit_tests\n in\n test ~trials:20\n (Generator.tuple2 Stack.gen (Coinbase.Gen.gen ~constraint_constants))\n ~f:(fun (base, (cb, _supercharged_coinbase)) ->\n let coinbase_data = Coinbase_data.of_coinbase cb in\n let unchecked = Stack.push_coinbase cb base in\n let checked =\n let comp =\n let open Snark_params.Tick in\n let cb_var = Coinbase_data.(var_of_t coinbase_data) in\n let%map res =\n Stack.Checked.push_coinbase cb_var (Stack.var_of_t base)\n in\n As_prover.read Stack.typ res\n in\n Or_error.ok_exn (run_and_check comp)\n in\n assert (Stack.equal unchecked checked) )\n\n let%test_unit \"Checked_tree = Unchecked_tree\" =\n let open Quickcheck in\n let constraint_constants =\n Genesis_constants.Constraint_constants.for_unit_tests\n in\n let depth = constraint_constants.pending_coinbase_depth in\n let pending_coinbases = create ~depth () |> Or_error.ok_exn in\n test ~trials:20\n (Generator.tuple3\n (Coinbase.Gen.gen ~constraint_constants)\n State_body_hash.gen Mina_numbers.Global_slot_since_genesis.gen )\n ~f:(fun ( (coinbase, `Supercharged_coinbase supercharged_coinbase)\n , state_body_hash\n , global_slot ) ->\n let amount = coinbase.amount in\n let is_new_stack, action =\n Currency.Amount.(\n if equal coinbase.amount zero then (true, Update.Action.Update_none)\n else (true, Update_one))\n in\n let unchecked =\n add_coinbase_with_zero_checks ~constraint_constants\n (module T)\n pending_coinbases ~coinbase ~is_new_stack ~state_body_hash\n ~global_slot ~supercharged_coinbase\n in\n (* inside the `open' below, Checked means something else, so define this function *)\n let f_add_coinbase = Checked.add_coinbase ~constraint_constants in\n let checked_merkle_root =\n let comp =\n let open Snark_params.Tick in\n let amount_var = Amount.var_of_t amount in\n let action_var = Update.Action.var_of_t action in\n let coinbase_receiver_var =\n Public_key.Compressed.var_of_t coinbase.receiver\n in\n let supercharge_coinbase_var =\n Boolean.var_of_value supercharged_coinbase\n in\n let state_body_hash_var =\n State_body_hash.var_of_t state_body_hash\n in\n let global_slot_var =\n Mina_numbers.Global_slot_since_genesis.Checked.constant\n global_slot\n in\n let%map result =\n handle\n (fun () ->\n f_add_coinbase\n (Hash.var_of_t (merkle_root pending_coinbases))\n { Update.Poly.action = action_var\n ; coinbase_amount = amount_var\n }\n ~coinbase_receiver:coinbase_receiver_var\n ~supercharge_coinbase:supercharge_coinbase_var\n state_body_hash_var global_slot_var )\n (unstage (handler ~depth pending_coinbases ~is_new_stack))\n in\n As_prover.read Hash.typ result\n in\n Or_error.ok_exn (run_and_check comp)\n in\n assert (Hash.equal (merkle_root unchecked) checked_merkle_root) )\n\n let%test_unit \"Checked_tree = Unchecked_tree after pop\" =\n let open Quickcheck in\n let constraint_constants =\n Genesis_constants.Constraint_constants.for_unit_tests\n in\n let depth = constraint_constants.pending_coinbase_depth in\n test ~trials:20\n (Generator.tuple3\n (Coinbase.Gen.gen ~constraint_constants)\n State_body_hash.gen Mina_numbers.Global_slot_since_genesis.gen )\n ~f:(fun ( (coinbase, `Supercharged_coinbase supercharged_coinbase)\n , state_body_hash\n , global_slot ) ->\n let pending_coinbases = create ~depth () |> Or_error.ok_exn in\n let amount = coinbase.amount in\n let action =\n Currency.Amount.(\n if equal coinbase.amount zero then Update.Action.Update_none\n else Update_one)\n in\n let unchecked =\n add_coinbase_with_zero_checks ~constraint_constants\n (module T)\n pending_coinbases ~coinbase ~is_new_stack:true ~state_body_hash\n ~global_slot ~supercharged_coinbase\n in\n (* inside the `open' below, Checked means something else, so define these functions *)\n let f_add_coinbase = Checked.add_coinbase ~constraint_constants in\n let f_pop_coinbase = Checked.pop_coinbases ~constraint_constants in\n let checked_merkle_root =\n let comp =\n let open Snark_params.Tick in\n let amount_var = Amount.var_of_t amount in\n let action_var = Update.Action.(var_of_t action) in\n let coinbase_receiver_var =\n Public_key.Compressed.var_of_t coinbase.receiver\n in\n let supercharge_coinbase_var =\n Boolean.var_of_value supercharged_coinbase\n in\n let state_body_hash_var =\n State_body_hash.var_of_t state_body_hash\n in\n let global_slot_var =\n Mina_numbers.Global_slot_since_genesis.Checked.constant\n global_slot\n in\n let%map result =\n handle\n (fun () ->\n f_add_coinbase\n (Hash.var_of_t (merkle_root pending_coinbases))\n { Update.Poly.action = action_var\n ; coinbase_amount = amount_var\n }\n ~coinbase_receiver:coinbase_receiver_var\n ~supercharge_coinbase:supercharge_coinbase_var\n state_body_hash_var global_slot_var )\n (unstage (handler ~depth pending_coinbases ~is_new_stack:true))\n in\n As_prover.read Hash.typ result\n in\n Or_error.ok_exn (run_and_check comp)\n in\n assert (Hash.equal (merkle_root unchecked) checked_merkle_root) ;\n (*deleting the coinbase stack we just created. therefore if there was no update then don't try to delete*)\n let proof_emitted = not Update.Action.(equal action Update_none) in\n let unchecked_after_pop =\n if proof_emitted then\n remove_coinbase_stack ~depth unchecked |> Or_error.ok_exn |> snd\n else unchecked\n in\n let checked_merkle_root_after_pop =\n let comp =\n let open Snark_params.Tick in\n let%map current, _previous =\n handle\n (fun () ->\n f_pop_coinbase ~proof_emitted:Boolean.true_\n (Hash.var_of_t checked_merkle_root) )\n (unstage (handler ~depth unchecked ~is_new_stack:false))\n in\n As_prover.read Hash.typ current\n in\n Or_error.ok_exn (run_and_check comp)\n in\n assert (\n Hash.equal\n (merkle_root unchecked_after_pop)\n checked_merkle_root_after_pop ) )\n\n let%test_unit \"push and pop multiple stacks\" =\n let open Quickcheck in\n let module Pending_coinbase = T in\n let constraint_constants =\n { Genesis_constants.Constraint_constants.for_unit_tests with\n pending_coinbase_depth = 3\n }\n in\n let depth = constraint_constants.pending_coinbase_depth in\n let t_of_coinbases t = function\n | [] ->\n let t' =\n Pending_coinbase.incr_index ~depth t ~is_new_stack:true\n |> Or_error.ok_exn\n in\n (Pending_coinbase.Stack.empty, t')\n | ( (initial_coinbase, _supercharged_coinbase)\n , state_body_hash\n , global_slot )\n :: coinbases ->\n let t' =\n Pending_coinbase.add_state ~depth t state_body_hash global_slot\n ~is_new_stack:true\n |> Or_error.ok_exn\n |> Pending_coinbase.add_coinbase ~depth ~coinbase:initial_coinbase\n ~is_new_stack:false\n |> Or_error.ok_exn\n in\n let updated =\n List.fold coinbases ~init:t'\n ~f:(fun\n pending_coinbases\n ( (coinbase, `Supercharged_coinbase supercharged_coinbase)\n , state_body_hash\n , global_slot )\n ->\n add_coinbase_with_zero_checks ~constraint_constants\n (module Pending_coinbase)\n pending_coinbases ~coinbase ~is_new_stack:false\n ~state_body_hash ~global_slot ~supercharged_coinbase )\n in\n let new_stack =\n Or_error.ok_exn\n @@ Pending_coinbase.latest_stack updated ~is_new_stack:false\n in\n (new_stack, updated)\n in\n (* Create pending coinbase stacks from coinbase lists and add it to the pending coinbase merkle tree *)\n let add coinbase_lists pending_coinbases =\n List.fold ~init:([], pending_coinbases) coinbase_lists\n ~f:(fun (stacks, pc) coinbases ->\n let new_stack, pc = t_of_coinbases pc coinbases in\n (new_stack :: stacks, pc) )\n in\n (* remove the oldest stack and check if that's the expected one *)\n let remove_check t expected_stack =\n let popped_stack, updated_pending_coinbases =\n Pending_coinbase.remove_coinbase_stack ~depth t |> Or_error.ok_exn\n in\n assert (Pending_coinbase.Stack.equal_data popped_stack expected_stack) ;\n updated_pending_coinbases\n in\n let add_remove_check coinbase_lists =\n let max_coinbase_stack_count =\n Pending_coinbase.max_coinbase_stack_count ~depth\n in\n let pending_coinbases = Pending_coinbase.create_exn' ~depth () in\n let rec go coinbase_lists pc =\n if List.is_empty coinbase_lists then ()\n else\n let coinbase_lists' =\n List.take coinbase_lists max_coinbase_stack_count\n in\n let added_stacks, pending_coinbases_updated =\n add coinbase_lists' pc\n in\n let pending_coinbases' =\n List.fold ~init:pending_coinbases_updated (List.rev added_stacks)\n ~f:(fun pc expected_stack -> remove_check pc expected_stack)\n in\n let remaining_lists =\n List.drop coinbase_lists max_coinbase_stack_count\n in\n go remaining_lists pending_coinbases'\n in\n go coinbase_lists pending_coinbases\n in\n let coinbase_lists_gen =\n Quickcheck.Generator.(\n list\n (list\n (Generator.tuple3\n (Coinbase.Gen.gen ~constraint_constants)\n State_body_hash.gen Mina_numbers.Global_slot_since_genesis.gen ) ))\n in\n test ~trials:100 coinbase_lists_gen ~f:add_remove_check\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_util\nopen Fold_lib\nopen Snark_params.Tick\nmodule Wire_types = Mina_wire_types.Mina_base.Staged_ledger_hash\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S =\n Staged_ledger_hash_intf.Full\n with type Aux_hash.t = A.Aux_hash.t\n and type Pending_coinbase_aux.t = A.Pending_coinbase_aux.V1.t\n and type t = A.V1.t\n and type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n module Aux_hash = struct\n let length_in_bits = 256\n\n let length_in_bytes = length_in_bits / 8\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = string [@@deriving sexp, equal, compare, hash]\n\n let to_latest = Fn.id\n\n module Base58_check = Base58_check.Make (struct\n let description = \"Aux hash\"\n\n let version_byte =\n Base58_check.Version_bytes.staged_ledger_hash_aux_hash\n end)\n\n let to_base58_check s = Base58_check.encode s\n\n let of_base58_check_exn s = Base58_check.decode_exn s\n\n let to_yojson s = `String (to_base58_check s)\n\n let of_yojson = function\n | `String s -> (\n match Base58_check.decode s with\n | Error e ->\n Error\n (sprintf \"Aux_hash.of_yojson, bad Base58Check:%s\"\n (Error.to_string_hum e) )\n | Ok x ->\n Ok x )\n | _ ->\n Error \"Aux_hash.of_yojson expected `String\"\n end\n end]\n\n [%%define_locally\n Stable.Latest.\n ( to_yojson\n , of_yojson\n , to_base58_check\n , of_base58_check_exn\n , compare\n , sexp_of_t )]\n\n let of_bytes = Fn.id\n\n let to_bytes = Fn.id\n\n let dummy : t = String.init length_in_bytes ~f:(fun _ -> '\\000')\n\n let of_sha256 : Digestif.SHA256.t -> t =\n Fn.compose of_bytes Digestif.SHA256.to_raw_string\n\n let gen : t Quickcheck.Generator.t =\n let char_generator =\n Base_quickcheck.Generator.of_list\n [ '0'\n ; '1'\n ; '2'\n ; '3'\n ; '4'\n ; '5'\n ; '6'\n ; '7'\n ; '8'\n ; '9'\n ; 'A'\n ; 'B'\n ; 'C'\n ; 'D'\n ; 'E'\n ; 'F'\n ]\n in\n String.gen_with_length (length_in_bytes * 2) char_generator\n |> Quickcheck.Generator.map\n ~f:(Fn.compose of_sha256 Digestif.SHA256.of_hex)\n end\n\n module Pending_coinbase_aux = struct\n let length_in_bits = 256\n\n let length_in_bytes = length_in_bits / 8\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = string [@@deriving sexp, equal, compare, hash]\n\n let to_latest = Fn.id\n\n module Base58_check = Base58_check.Make (struct\n let description = \"Pending coinbase aux\"\n\n let version_byte =\n Base58_check.Version_bytes.staged_ledger_hash_pending_coinbase_aux\n end)\n\n let to_base58_check s = Base58_check.encode s\n\n let of_base58_check_exn s = Base58_check.decode_exn s\n\n let to_yojson s = `String (to_base58_check s)\n\n let of_yojson = function\n | `String s -> (\n match Base58_check.decode s with\n | Ok x ->\n Ok x\n | Error e ->\n Error\n (sprintf\n \"Pending_coinbase_aux.of_yojson, bad Base58Check:%s\"\n (Error.to_string_hum e) ) )\n | _ ->\n Error \"Pending_coinbase_aux.of_yojson expected `String\"\n end\n end]\n\n [%%define_locally\n Stable.Latest.(to_yojson, of_yojson, to_base58_check, of_base58_check_exn)]\n\n let dummy : t = String.init length_in_bytes ~f:(fun _ -> '\\000')\n end\n\n module Non_snark = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = A.Non_snark.V1.t =\n { ledger_hash : Ledger_hash.Stable.V1.t\n ; aux_hash : Aux_hash.Stable.V1.t\n ; pending_coinbase_aux : Pending_coinbase_aux.Stable.V1.t\n }\n [@@deriving sexp, equal, compare, hash, yojson, fields]\n\n let to_latest = Fn.id\n end\n end]\n\n type value = t [@@deriving sexp, compare, hash, yojson]\n\n let dummy : t Lazy.t =\n lazy\n { ledger_hash = Ledger_hash.empty_hash\n ; aux_hash = Aux_hash.dummy\n ; pending_coinbase_aux = Pending_coinbase_aux.dummy\n }\n\n let genesis ~genesis_ledger_hash : t =\n { ledger_hash = genesis_ledger_hash\n ; aux_hash = Aux_hash.dummy\n ; pending_coinbase_aux = Pending_coinbase_aux.dummy\n }\n\n type var = Boolean.var list\n\n let length_in_bits = 256\n\n let digest ({ ledger_hash; aux_hash; pending_coinbase_aux } : t) =\n let h = Digestif.SHA256.init () in\n let h =\n Digestif.SHA256.feed_string h (Ledger_hash.to_bytes ledger_hash)\n in\n let h = Digestif.SHA256.feed_string h aux_hash in\n let h = Digestif.SHA256.feed_string h pending_coinbase_aux in\n Digestif.SHA256.(get h |> to_raw_string)\n\n let fold t = Fold.string_bits (digest t)\n\n let to_input t =\n let open Random_oracle.Input.Chunked in\n Array.reduce_exn ~f:append\n (Array.of_list_map\n (Fold.to_list (fold t))\n ~f:(fun b -> packed (field_of_bool b, 1)) )\n\n let ledger_hash ({ ledger_hash; _ } : t) = ledger_hash\n\n let aux_hash ({ aux_hash; _ } : t) = aux_hash\n\n let of_ledger_aux_coinbase_hash aux_hash ledger_hash pending_coinbase_aux :\n t =\n { aux_hash; ledger_hash; pending_coinbase_aux }\n\n let var_to_input (t : var) =\n let open Random_oracle.Input.Chunked in\n Array.reduce_exn ~f:append\n (Array.of_list_map t ~f:(fun b -> packed ((b :> Field.Var.t), 1)))\n\n let var_of_t t : var =\n List.map (Fold.to_list @@ fold t) ~f:Boolean.var_of_value\n\n [%%if proof_level = \"check\"]\n\n let warn_improper_transport () = ()\n\n [%%else]\n\n let warn_improper_transport () =\n printf \"WARNING: improperly transporting staged-ledger-hash\\n\"\n\n [%%endif]\n\n let typ : (var, value) Typ.t =\n Typ.transport (Typ.list ~length:length_in_bits Boolean.typ)\n ~there:(Fn.compose Fold.to_list fold) ~back:(fun _ ->\n (* If we put a failwith here, we lose the ability to printf-inspect\n * anything that uses staged-ledger-hashes from within Checked\n * computations. It's useful when debugging to dump the protocol state\n * and so we can just lie here instead. *)\n warn_improper_transport () ; Lazy.force dummy )\n end\n\n module Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('non_snark, 'pending_coinbase_hash) t =\n ('non_snark, 'pending_coinbase_hash) A.Poly.V1.t =\n { non_snark : 'non_snark\n ; pending_coinbase_hash : 'pending_coinbase_hash\n }\n [@@deriving sexp, equal, compare, hash, yojson, hlist]\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n (** Staged ledger hash has two parts\n 1) merkle root of the pending coinbases\n 2) ledger hash, aux hash, and the FIFO order of the coinbase stacks(Non snark).\n Only part 1 is required for blockchain snark computation and therefore the remaining fields of the staged ledger are grouped together as \"Non_snark\"\n *)\n type t =\n ( Non_snark.Stable.V1.t\n , Pending_coinbase.Hash_versioned.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n type ('a, 'b) t_ = ('a, 'b) Poly.t\n\n type value = t [@@deriving sexp, equal, compare, hash]\n\n type var = (Non_snark.var, Pending_coinbase.Hash.var) t_\n\n include Hashable.Make (Stable.Latest)\n\n let ledger_hash ({ non_snark; _ } : t) = Non_snark.ledger_hash non_snark\n\n let aux_hash ({ non_snark; _ } : t) = Non_snark.aux_hash non_snark\n\n let pending_coinbase_aux ({ non_snark; _ } : t) =\n Non_snark.pending_coinbase_aux non_snark\n\n let pending_coinbase_hash ({ pending_coinbase_hash; _ } : t) =\n pending_coinbase_hash\n\n let pending_coinbase_hash_var ({ pending_coinbase_hash; _ } : var) =\n pending_coinbase_hash\n\n let of_aux_ledger_and_coinbase_hash aux_hash ledger_hash pending_coinbase : t\n =\n { non_snark =\n Non_snark.of_ledger_aux_coinbase_hash aux_hash ledger_hash\n (Pending_coinbase.hash_extra pending_coinbase)\n ; pending_coinbase_hash = Pending_coinbase.merkle_root pending_coinbase\n }\n\n let genesis ~(constraint_constants : Genesis_constants.Constraint_constants.t)\n ~genesis_ledger_hash : t =\n let pending_coinbase =\n Pending_coinbase.create ~depth:constraint_constants.pending_coinbase_depth\n ()\n |> Or_error.ok_exn\n in\n { non_snark = Non_snark.genesis ~genesis_ledger_hash\n ; pending_coinbase_hash = Pending_coinbase.merkle_root pending_coinbase\n }\n\n let var_of_t ({ pending_coinbase_hash; non_snark } : t) : var =\n let non_snark = Non_snark.var_of_t non_snark in\n let pending_coinbase_hash =\n Pending_coinbase.Hash.var_of_t pending_coinbase_hash\n in\n { non_snark; pending_coinbase_hash }\n\n let to_input ({ non_snark; pending_coinbase_hash } : t) =\n Random_oracle.Input.Chunked.(\n append\n (Non_snark.to_input non_snark)\n (field (pending_coinbase_hash :> Field.t)))\n\n let var_to_input ({ non_snark; pending_coinbase_hash } : var) =\n Random_oracle.Input.Chunked.(\n append\n (Non_snark.var_to_input non_snark)\n (field (Pending_coinbase.Hash.var_to_hash_packed pending_coinbase_hash)))\n\n let typ : (var, t) Typ.t =\n Typ.of_hlistable\n [ Non_snark.typ; Pending_coinbase.Hash.typ ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\nopen Mina_base_util\nopen Mina_base_import\nmodule Wire_types = Mina_wire_types.Mina_base.Sok_message\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Sok_message_intf.Full with type Digest.t = A.Digest.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { fee : Currency.Fee.Stable.V1.t\n ; prover : Public_key.Compressed.Stable.V1.t\n }\n [@@deriving sexp, yojson, equal, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n let create ~fee ~prover = Stable.Latest.{ fee; prover }\n\n module Digest = struct\n let length_in_bytes = Blake2.digest_size_in_bytes\n\n [%%versioned_binable\n module Stable = struct\n module V1 = struct\n type t = string [@@deriving sexp, hash, compare, equal, yojson]\n\n let to_latest = Fn.id\n\n include\n Binable.Of_binable_without_uuid\n (Core_kernel.String.Stable.V1)\n (struct\n type nonrec t = t\n\n let to_binable = Fn.id\n\n let of_binable s =\n assert (String.length s = length_in_bytes) ;\n s\n end)\n\n open Snark_params.Tick\n\n let to_input t =\n Random_oracle.Input.Chunked.packeds\n (Array.of_list_map\n Fold_lib.Fold.(to_list (string_bits t))\n ~f:(fun b -> (field_of_bool b, 1)) )\n\n let typ =\n Typ.array ~length:Blake2.digest_size_in_bits Boolean.typ\n |> Typ.transport ~there:Blake2.string_to_bits\n ~back:Blake2.bits_to_string\n end\n end]\n\n module Checked = struct\n open Snark_params.Tick\n\n type t = Boolean.var array\n\n let to_input (t : t) =\n Random_oracle.Input.Chunked.packeds\n (Array.map t ~f:(fun b -> ((b :> Field.Var.t), 1)))\n end\n\n [%%define_locally Stable.Latest.(to_input, typ)]\n\n let default = String.init length_in_bytes ~f:(fun _ -> '\\000')\n end\n\n let digest t =\n Blake2.to_raw_string\n (Blake2.digest_string (Binable.to_string (module Stable.Latest) t))\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\nmodule T = Mina_numbers.Length\n\n(*constants actually required for blockchain snark*)\n(* k\n ,c\n ,slots_per_epoch\n ,slots_per_sub_window\n ,sub_windows_per_window\n ,checkpoint_window_size_in_slots\n ,block_window_duration_ms*)\n\nmodule Poly = Genesis_constants.Protocol.Poly\n\nmodule Value = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n (T.Stable.V1.t, T.Stable.V1.t, Block_time.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving equal, ord, hash, sexp, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let gen : t Quickcheck.Generator.t =\n let open Quickcheck.Let_syntax in\n let%bind k = Int.gen_incl 1 5000 in\n let%bind delta = Int.gen_incl 0 5000 in\n let%bind slots_per_epoch = Int.gen_incl k (8 * k) >>| ( * ) 3 >>| T.of_int\n and slots_per_sub_window = Int.gen_incl 1 ((k + 9) / 9) in\n (*TODO: Bug -> Block_time.(to_time x |> of_time) != x for certain values.\n Eg: 34702788243129 <--> 34702788243128, 8094 <--> 8093*)\n let%bind ms = Int64.(gen_log_uniform_incl 0L 9999999999999L) in\n let end_time = Block_time.of_int64 999999999999999L in\n let%map genesis_state_timestamp =\n Block_time.(gen_incl (of_int64 ms) end_time)\n in\n { Poly.k = T.of_int k\n ; delta = T.of_int delta\n ; slots_per_epoch\n ; slots_per_sub_window = T.of_int slots_per_sub_window\n ; genesis_state_timestamp\n }\nend\n\ntype value = Value.t\n\nlet value_of_t (t : Genesis_constants.Protocol.t) : value =\n { k = T.of_int t.k\n ; delta = T.of_int t.delta\n ; slots_per_epoch = T.of_int t.slots_per_epoch\n ; slots_per_sub_window = T.of_int t.slots_per_sub_window\n ; genesis_state_timestamp = Block_time.of_int64 t.genesis_state_timestamp\n }\n\nlet t_of_value (v : value) : Genesis_constants.Protocol.t =\n { k = T.to_int v.k\n ; delta = T.to_int v.delta\n ; slots_per_epoch = T.to_int v.slots_per_epoch\n ; slots_per_sub_window = T.to_int v.slots_per_sub_window\n ; genesis_state_timestamp = Block_time.to_int64 v.genesis_state_timestamp\n }\n\nlet to_input (t : value) =\n Array.reduce_exn ~f:Random_oracle.Input.Chunked.append\n [| T.to_input t.k\n ; T.to_input t.delta\n ; T.to_input t.slots_per_epoch\n ; T.to_input t.slots_per_sub_window\n ; Block_time.to_input t.genesis_state_timestamp\n |]\n\n[%%if defined consensus_mechanism]\n\ntype var = (T.Checked.t, T.Checked.t, Block_time.Checked.t) Poly.t\n\nlet typ =\n Typ.of_hlistable\n [ T.Checked.typ\n ; T.Checked.typ\n ; T.Checked.typ\n ; T.Checked.typ\n ; Block_time.Checked.typ\n ]\n ~var_to_hlist:Poly.to_hlist ~var_of_hlist:Poly.of_hlist\n ~value_to_hlist:Poly.to_hlist ~value_of_hlist:Poly.of_hlist\n\nlet var_to_input (var : var) =\n let k = T.Checked.to_input var.k\n and delta = T.Checked.to_input var.delta\n and slots_per_epoch = T.Checked.to_input var.slots_per_epoch\n and slots_per_sub_window = T.Checked.to_input var.slots_per_sub_window in\n let genesis_state_timestamp =\n Block_time.Checked.to_input var.genesis_state_timestamp\n in\n Array.reduce_exn ~f:Random_oracle.Input.Chunked.append\n [| k\n ; delta\n ; slots_per_epoch\n ; slots_per_sub_window\n ; genesis_state_timestamp\n |]\n\nlet%test_unit \"value = var\" =\n let compiled = Genesis_constants.for_unit_tests.protocol in\n let test protocol_constants =\n let open Snarky_backendless in\n let p_var =\n let%map p = exists typ ~compute:(As_prover0.return protocol_constants) in\n As_prover0.read typ p\n in\n let res = Or_error.ok_exn (run_and_check p_var) in\n [%test_eq: Value.t] res protocol_constants ;\n [%test_eq: Value.t] protocol_constants\n (t_of_value protocol_constants |> value_of_t)\n in\n Quickcheck.test ~trials:100 Value.gen\n ~examples:[ value_of_t compiled ]\n ~f:test\n\n[%%endif]\n","open Core_kernel\nopen Signature_lib\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t = Mina_wire_types.Mina_base.Fee_with_prover.V1.t =\n { fee : Currency.Fee.Stable.V1.t\n ; prover : Public_key.Compressed.Stable.V1.t\n }\n [@@deriving sexp, yojson, hash]\n\n let to_latest = Fn.id\n\n module T = struct\n type typ = t [@@deriving sexp]\n\n type t = typ [@@deriving sexp]\n\n (* TODO: Compare in a better way than with public key, like in transaction pool *)\n let compare t1 t2 =\n let r = Currency.Fee.compare t1.fee t2.fee in\n if Int.( <> ) r 0 then r\n else Public_key.Compressed.compare t1.prover t2.prover\n end\n\n include Comparable.Make (T)\n end\nend]\n\ninclude Comparable.Make (Stable.V1.T)\n\nlet gen =\n Quickcheck.Generator.map2 Currency.Fee.gen Public_key.Compressed.gen\n ~f:(fun fee prover -> { fee; prover })\n","open Core_kernel\nopen Mina_base\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type 'command t = 'command Mina_wire_types.Mina_transaction.Poly.V2.t =\n | Command of 'command\n | Fee_transfer of Fee_transfer.Stable.V2.t\n | Coinbase of Coinbase.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n\n let map t ~f =\n match t with\n | Command x ->\n Command (f x)\n | Fee_transfer x ->\n Fee_transfer x\n | Coinbase x ->\n Coinbase x\n end\n end]\nend\n\nmodule Valid = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = User_command.Valid.Stable.V2.t Poly.Stable.V2.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include Hashable.Make (Stable.Latest)\n include Comparable.Make (Stable.Latest)\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = User_command.Stable.V2.t Poly.Stable.V2.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\ninclude Hashable.Make (Stable.Latest)\ninclude Comparable.Make (Stable.Latest)\n\ntype 'command t_ = 'command Poly.t =\n | Command of 'command\n | Fee_transfer of Fee_transfer.t\n | Coinbase of Coinbase.t\n\nlet to_valid_unsafe :\n t -> [ `If_this_is_used_it_should_have_a_comment_justifying_it of Valid.t ]\n = function\n | Command t ->\n let (`If_this_is_used_it_should_have_a_comment_justifying_it t') =\n User_command.to_valid_unsafe t\n in\n `If_this_is_used_it_should_have_a_comment_justifying_it (Command t')\n | Fee_transfer t ->\n `If_this_is_used_it_should_have_a_comment_justifying_it (Fee_transfer t)\n | Coinbase t ->\n `If_this_is_used_it_should_have_a_comment_justifying_it (Coinbase t)\n\nlet forget : Valid.t -> t = function\n | Command t ->\n Command (User_command.forget_check t)\n | Fee_transfer t ->\n Fee_transfer t\n | Coinbase t ->\n Coinbase t\n\nlet fee_excess : t -> Fee_excess.t Or_error.t = function\n | Command (Signed_command t) ->\n Ok (Signed_command.fee_excess t)\n | Command (Zkapp_command ps) ->\n Ok (Zkapp_command.fee_excess ps)\n | Fee_transfer t ->\n Fee_transfer.fee_excess t\n | Coinbase t ->\n Coinbase.fee_excess t\n\nlet expected_supply_increase = function\n | Command _ | Fee_transfer _ ->\n Ok Currency.Amount.zero\n | Coinbase t ->\n Coinbase.expected_supply_increase t\n\nlet public_keys (t : t) =\n let account_ids =\n match t with\n | Command (Signed_command cmd) ->\n Signed_command.accounts_referenced cmd\n | Command (Zkapp_command t) ->\n Zkapp_command.accounts_referenced t\n | Fee_transfer ft ->\n Fee_transfer.receivers ft\n | Coinbase cb ->\n Coinbase.accounts_referenced cb\n in\n List.map account_ids ~f:Account_id.public_key\n\nlet account_access_statuses (t : t) (status : Transaction_status.t) =\n match t with\n | Command (Signed_command cmd) ->\n Signed_command.account_access_statuses cmd status\n | Command (Zkapp_command t) ->\n Zkapp_command.account_access_statuses t status\n | Fee_transfer ft ->\n assert (Transaction_status.equal Applied status) ;\n List.map (Fee_transfer.receivers ft) ~f:(fun acct_id ->\n (acct_id, `Accessed) )\n | Coinbase cb ->\n Coinbase.account_access_statuses cb status\n\nlet accounts_referenced (t : t) =\n List.map (account_access_statuses t Applied) ~f:(fun (acct_id, _status) ->\n acct_id )\n\nlet fee_payer_pk (t : t) =\n match t with\n | Command (Signed_command cmd) ->\n Signed_command.fee_payer_pk cmd\n | Command (Zkapp_command t) ->\n Zkapp_command.fee_payer_pk t\n | Fee_transfer ft ->\n Fee_transfer.fee_payer_pk ft\n | Coinbase cb ->\n Coinbase.fee_payer_pk cb\n\nlet valid_size ~genesis_constants (t : t) =\n match t with\n | Command cmd ->\n User_command.valid_size ~genesis_constants cmd\n | Fee_transfer _ | Coinbase _ ->\n Ok ()\n\nlet check_well_formedness ~genesis_constants (t : t) =\n match t with\n | Command cmd ->\n User_command.check_well_formedness ~genesis_constants cmd\n | Fee_transfer _ | Coinbase _ ->\n Ok ()\n\nlet yojson_summary_of_command =\n let mk_record type_ memo signature =\n `List\n [ `String type_\n ; `String (Signature.to_base58_check signature)\n ; `String (Signed_command_memo.to_string_hum memo)\n ]\n in\n function\n | User_command.Zkapp_command cmd ->\n mk_record \"zkapp\" (Zkapp_command.memo cmd)\n ( Zkapp_command.fee_payer_account_update cmd\n |> Account_update.Fee_payer.authorization )\n | Signed_command cmd ->\n mk_record \"payment\" (Signed_command.memo cmd)\n (Signed_command.signature cmd)\n\nlet yojson_summary = function\n | Command cmd ->\n yojson_summary_of_command cmd\n | Fee_transfer _ ->\n `List [ `String \"fee_transfer\" ]\n | Coinbase cb ->\n let amount = Currency.Amount.to_yojson @@ Coinbase.amount cb in\n `List [ `String \"coinbase\"; amount ]\n\nlet yojson_summary_with_status cmd_with_status =\n let status =\n Transaction_status.to_yojson (With_status.status cmd_with_status)\n in\n match yojson_summary (With_status.data cmd_with_status) with\n | `List lst ->\n `List (lst @ [ status ])\n","open Core_kernel\nopen Mina_base\n\n[%%import \"/src/config.mlh\"]\n\nmodule T = struct\n include Blake2.Make ()\nend\n\ninclude T\n\nmodule Base58_check = Codable.Make_base58_check (struct\n type t = Stable.Latest.t [@@deriving bin_io_unversioned]\n\n let version_byte = Base58_check.Version_bytes.transaction_hash\n\n let description = \"Transaction hash\"\nend)\n\n[%%define_locally\nBase58_check.(of_base58_check, of_base58_check_exn, to_base58_check)]\n\nlet to_yojson t = `String (to_base58_check t)\n\nlet of_yojson = function\n | `String str ->\n Result.map_error (of_base58_check str) ~f:(fun _ ->\n \"Transaction_hash.of_yojson: Error decoding string from base58_check \\\n format\" )\n | _ ->\n Error \"Transaction_hash.of_yojson: Expected a string\"\n\nlet ( hash_signed_command_v1\n , hash_signed_command\n , hash_zkapp_command\n , hash_coinbase\n , hash_fee_transfer ) =\n let mk_hasher (type a) (module M : Bin_prot.Binable.S with type t = a)\n (cmd : a) =\n cmd |> Binable.to_string (module M) |> digest_string\n in\n let signed_cmd_hasher_v1 =\n mk_hasher\n ( module struct\n include Signed_command.Stable.V1\n end )\n in\n let signed_cmd_hasher = mk_hasher (module Signed_command.Stable.Latest) in\n let zkapp_cmd_hasher = mk_hasher (module Zkapp_command.Stable.Latest) in\n (* replace actual signatures, proofs with dummies for hashing, so we can\n reproduce the transaction hashes if signatures, proofs omitted in\n archive db\n *)\n let hash_signed_command_v1 (cmd : Signed_command.Stable.V1.t) =\n let cmd_dummy_signature = { cmd with signature = Signature.dummy } in\n signed_cmd_hasher_v1 cmd_dummy_signature\n in\n let hash_signed_command (cmd : Signed_command.t) =\n let cmd_dummy_signature = { cmd with signature = Signature.dummy } in\n signed_cmd_hasher cmd_dummy_signature\n in\n let hash_zkapp_command (cmd : Zkapp_command.t) =\n let cmd_dummy_signatures_and_proofs =\n { cmd with\n fee_payer = { cmd.fee_payer with authorization = Signature.dummy }\n ; account_updates =\n Zkapp_command.Call_forest.map cmd.account_updates\n ~f:(fun (acct_update : Account_update.t) ->\n let dummy_auth =\n match acct_update.authorization with\n | Control.Proof _ ->\n Control.Proof (Lazy.force Proof.transaction_dummy)\n | Control.Signature _ ->\n Control.Signature Signature.dummy\n | Control.None_given ->\n Control.None_given\n in\n { acct_update with authorization = dummy_auth } )\n }\n in\n zkapp_cmd_hasher cmd_dummy_signatures_and_proofs\n in\n (* no signatures to replace for internal commands *)\n let hash_coinbase = mk_hasher (module Mina_base.Coinbase.Stable.Latest) in\n let hash_fee_transfer =\n mk_hasher (module Fee_transfer.Single.Stable.Latest)\n in\n ( hash_signed_command_v1\n , hash_signed_command\n , hash_zkapp_command\n , hash_coinbase\n , hash_fee_transfer )\n\n[%%ifdef consensus_mechanism]\n\nlet hash_command cmd =\n match cmd with\n | User_command.Signed_command s ->\n hash_signed_command s\n | User_command.Zkapp_command p ->\n hash_zkapp_command p\n\nlet hash_signed_command_v2 = hash_signed_command\n\nlet hash_of_transaction_id (transaction_id : string) : t Or_error.t =\n (* A transaction id might be:\n - original Base58Check transaction ids of signed commands (Signed_command.V1.t), or\n - a Base64 encoding of signed commands and zkApps (Signed_command.Vn.t, for n >= 2,\n or Zkapp_command.Vm.t, for m >= 1)\n\n For the Base64 case, the Bin_prot serialization leads with a version tag\n *)\n match Signed_command.of_base58_check_exn_v1 transaction_id with\n | Ok cmd_v1 ->\n Ok (hash_signed_command_v1 cmd_v1)\n | Error _ -> (\n match Base64.decode transaction_id with\n | Ok s -> (\n let len = String.length s in\n let buf = Bin_prot.Common.create_buf len in\n Bin_prot.Common.blit_string_buf s buf ~len ;\n let pos_ref = ref 0 in\n let version = Bin_prot.Std.bin_read_int ~pos_ref buf in\n match version with\n | 1 -> (\n (* must be a zkApp command *)\n try\n let cmd = Zkapp_command.Stable.Latest.bin_read_t ~pos_ref buf in\n Ok (hash_zkapp_command cmd)\n with _ ->\n Or_error.error_string\n \"Could not decode serialized zkApp command (version 1)\" )\n | 2 -> (\n (* must be a signed command, until there's a V2 for zkApp commands *)\n try\n let cmd = Signed_command.Stable.V2.bin_read_t ~pos_ref buf in\n Ok (hash_signed_command_v2 cmd)\n with _ ->\n Or_error.error_string\n \"Could not decode serialized signed command (version 2)\" )\n | _ ->\n Or_error.error_string\n (sprintf\n \"Transaction hashing not implemented for command with \\\n version %d\"\n version ) )\n | Error _ ->\n Or_error.error_string\n \"Could not decode transaction id as either Base58Check or Base64\" )\n\nmodule User_command_with_valid_signature = struct\n type hash = T.t [@@deriving sexp, compare, hash]\n\n let hash_to_yojson = to_yojson\n\n let hash_of_yojson = of_yojson\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( (User_command.Valid.Stable.V2.t[@hash.ignore])\n , (T.Stable.V1.t[@to_yojson hash_to_yojson]) )\n With_hash.Stable.V1.t\n [@@deriving sexp, hash, to_yojson]\n\n let to_latest = Fn.id\n\n (* Compare only on hashes, comparing on the data too would be slower and\n add no value.\n *)\n let compare (x : t) (y : t) = T.compare x.hash y.hash\n end\n end]\n\n let create (c : User_command.Valid.t) : t =\n { data = c; hash = hash_command (User_command.forget_check c) }\n\n let data ({ data; _ } : t) = data\n\n let command ({ data; _ } : t) = User_command.forget_check data\n\n let hash ({ hash; _ } : t) = hash\n\n let forget_check ({ data; hash } : t) =\n { With_hash.data = User_command.forget_check data; hash }\n\n include Comparable.Make (Stable.Latest)\n\n let make data hash : t = { data; hash }\nend\n\nmodule User_command = struct\n type hash = T.t [@@deriving sexp, compare, hash]\n\n let hash_to_yojson = to_yojson\n\n let hash_of_yojson = of_yojson\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n ( (User_command.Stable.V2.t[@hash.ignore])\n , (T.Stable.V1.t[@to_yojson hash_to_yojson]) )\n With_hash.Stable.V1.t\n [@@deriving sexp, hash, to_yojson]\n\n let to_latest = Fn.id\n\n (* Compare only on hashes, comparing on the data too would be slower and\n add no value.\n *)\n let compare (x : t) (y : t) = T.compare x.hash y.hash\n end\n end]\n\n let create (c : User_command.t) : t = { data = c; hash = hash_command c }\n\n let data ({ data; _ } : t) = data\n\n let command ({ data; _ } : t) = data\n\n let hash ({ hash; _ } : t) = hash\n\n let of_checked ({ data; hash } : User_command_with_valid_signature.t) : t =\n { With_hash.data = User_command.forget_check data; hash }\n\n include Comparable.Make (Stable.Latest)\nend\n\nlet%test_module \"Transaction hashes\" =\n ( module struct\n let run_test ~transaction_id ~expected_hash =\n let hash =\n match hash_of_transaction_id transaction_id with\n | Ok hash ->\n to_base58_check hash\n | Error err ->\n failwithf \"Error getting hash: %s\" (Error.to_string_hum err) ()\n in\n String.equal hash expected_hash\n\n let%test \"signed command v1 hash from transaction id\" =\n let transaction_id =\n \"BD421DxjdoLimeUh4RA4FEvHdDn6bfxyMVWiWUwbYzQkqhNUv8B5M4gCSREpu9mVueBYoHYWkwB8BMf6iS2jjV8FffvPGkuNeczBfY7YRwLuUGBRCQJ3ktFBrNuu4abqgkYhXmcS2xyzoSGxHbXkJRAokTwjQ9HP6TLSeXz9qa92nJaTeccMnkoZBmEitsZWWnTCMqDc6rhN4Z9UMpg4wzdPMwNJvLRuJBD14Dd5pR84KBoY9rrnv66rHPc4m2hH9QSEt4aEJC76BQ446pHN9ZLmyhrk28f5xZdBmYxp3hV13fJEJ3Gv1XqJMBqFxRhzCVGoKDbLAaNRb5F1u1WxTzJu5n4cMMDEYydGEpNirY2PKQqHkR8gEqjXRTkpZzP8G19qT\"\n in\n let expected_hash =\n \"5JuV53FPXad1QLC46z7wsou9JjjYP87qaUeryscZqLUMmLSg8j2n\"\n in\n run_test ~transaction_id ~expected_hash\n\n let%test \"signed command v2 hash from transaction id\" =\n let transaction_id =\n \"Av0IlDV3VklWpVXVRQr7cidImXn8E9nqCAxPjuyUNZ2pu3pJJxkBAAD//yIAIKTVOZ2q1qG1KT11p6844pWJ3fQug1XGnzv2S3N73azIABXhN3d+nO04Y7YqBul1CY5CEq9o34KWvfcB8IWep3kkAf60JFZJVqVV1UUK+3InSJl5/BPZ6ggMT47slDWdqbt6SScZAQEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=\"\n in\n let expected_hash =\n \"5JvBt4173K3t7gQSpFoMGtbtZuYWPSg29cWad5pnnRd9BnAowoqY\"\n in\n run_test ~transaction_id ~expected_hash\n\n (* To regenerate:\n * Run dune in this library's directory\n dune utop src/lib/transaction\n * Generate a zkapp transaction:\n let txn = let txn = (Lazy.force Mina_base.Zkapp_command.dummy) in {txn with account_updates = Mina_base.Zkapp_command.Call_forest.map txn.account_updates ~f:(fun x -> {x with Mina_base.Account_update.authorization= Proof (Lazy.force Mina_base.Proof.blockchain_dummy)})};;\n * Print the transaction:\n Core_kernel.Out_channel.with_file \"txn_id\" ~f:(fun file -> Out_channel.output_string file (Core_kernel.Binable.to_string (module Mina_base.User_command.Stable.V2) (Zkapp_command txn) |> Base64.encode |> (function Ok x -> x | Error _ -> \"\")));;\n * Get the hash:\n Mina_transaction.Transaction_hash.(hash_command (Zkapp_command txn) |> to_base58_check);;\n *)\n\n let%test \"zkApp v1 hash from transaction id\" =\n let transaction_id =\n \"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\"\n in\n let expected_hash =\n \"5JtWZqwvKEgSMSHbDhYXg6s76GhfBNscQtxLKXnT6YYTsUKQkcpV\"\n in\n run_test ~transaction_id ~expected_hash\n end )\n\n[%%endif]\n","open Core_kernel\nopen Mina_base\nopen Currency\nopen Signature_lib\nopen Mina_transaction\nmodule Zkapp_command_logic = Zkapp_command_logic\nmodule Global_slot_since_genesis = Mina_numbers.Global_slot_since_genesis\n\nmodule Transaction_applied = struct\n module UC = Signed_command\n\n module Signed_command_applied = struct\n module Common = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n { user_command : Signed_command.Stable.V2.t With_status.Stable.V2.t\n }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Body = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n | Payment of { new_accounts : Account_id.Stable.V2.t list }\n | Stake_delegation of\n { previous_delegate : Public_key.Compressed.Stable.V1.t option }\n | Failed\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t = { common : Common.Stable.V2.t; body : Body.Stable.V2.t }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let new_accounts (t : t) =\n match t.body with\n | Payment { new_accounts; _ } ->\n new_accounts\n | Stake_delegation _ | Failed ->\n []\n end\n\n module Zkapp_command_applied = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { accounts :\n (Account_id.Stable.V2.t * Account.Stable.V2.t option) list\n ; command : Zkapp_command.Stable.V1.t With_status.Stable.V2.t\n ; new_accounts : Account_id.Stable.V2.t list\n }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Command_applied = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n | Signed_command of Signed_command_applied.Stable.V2.t\n | Zkapp_command of Zkapp_command_applied.Stable.V1.t\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Fee_transfer_applied = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n { fee_transfer : Fee_transfer.Stable.V2.t With_status.Stable.V2.t\n ; new_accounts : Account_id.Stable.V2.t list\n ; burned_tokens : Currency.Amount.Stable.V1.t\n }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Coinbase_applied = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n { coinbase : Coinbase.Stable.V1.t With_status.Stable.V2.t\n ; new_accounts : Account_id.Stable.V2.t list\n ; burned_tokens : Currency.Amount.Stable.V1.t\n }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Varying = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n | Command of Command_applied.Stable.V2.t\n | Fee_transfer of Fee_transfer_applied.Stable.V2.t\n | Coinbase of Coinbase_applied.Stable.V2.t\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n { previous_hash : Ledger_hash.Stable.V1.t\n ; varying : Varying.Stable.V2.t\n }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let burned_tokens : t -> Currency.Amount.t =\n fun { varying; _ } ->\n match varying with\n | Command _ ->\n Currency.Amount.zero\n | Fee_transfer f ->\n f.burned_tokens\n | Coinbase c ->\n c.burned_tokens\n\n let new_accounts : t -> Account_id.t list =\n fun { varying; _ } ->\n match varying with\n | Command c -> (\n match c with\n | Signed_command sc ->\n Signed_command_applied.new_accounts sc\n | Zkapp_command zc ->\n zc.new_accounts )\n | Fee_transfer f ->\n f.new_accounts\n | Coinbase c ->\n c.new_accounts\n\n let supply_increase : t -> Currency.Amount.Signed.t Or_error.t =\n fun t ->\n let open Or_error.Let_syntax in\n let burned_tokens = Currency.Amount.Signed.of_unsigned (burned_tokens t) in\n let account_creation_fees =\n let account_creation_fee_int =\n Genesis_constants.Constraint_constants.compiled.account_creation_fee\n |> Currency.Fee.to_nanomina_int\n in\n let num_accounts_created = List.length @@ new_accounts t in\n (* int type is OK, no danger of overflow *)\n Currency.Amount.(\n Signed.of_unsigned\n @@ of_nanomina_int_exn (account_creation_fee_int * num_accounts_created))\n in\n let txn : Transaction.t =\n match t.varying with\n | Command\n (Signed_command { common = { user_command = { data; _ }; _ }; _ }) ->\n Command (Signed_command data)\n | Command (Zkapp_command c) ->\n Command (Zkapp_command c.command.data)\n | Fee_transfer f ->\n Fee_transfer f.fee_transfer.data\n | Coinbase c ->\n Coinbase c.coinbase.data\n in\n let%bind expected_supply_increase =\n Transaction.expected_supply_increase txn\n in\n let rec process_decreases total = function\n | [] ->\n Some total\n | amt :: amts ->\n let%bind.Option sum =\n Currency.Amount.Signed.(add @@ negate amt) total\n in\n process_decreases sum amts\n in\n let total =\n process_decreases\n (Currency.Amount.Signed.of_unsigned expected_supply_increase)\n [ burned_tokens; account_creation_fees ]\n in\n Option.value_map total ~default:(Or_error.error_string \"overflow\")\n ~f:(fun v -> Ok v)\n\n let transaction_with_status : t -> Transaction.t With_status.t =\n fun { varying; _ } ->\n match varying with\n | Command (Signed_command uc) ->\n With_status.map uc.common.user_command ~f:(fun cmd ->\n Transaction.Command (User_command.Signed_command cmd) )\n | Command (Zkapp_command s) ->\n With_status.map s.command ~f:(fun c ->\n Transaction.Command (User_command.Zkapp_command c) )\n | Fee_transfer f ->\n With_status.map f.fee_transfer ~f:(fun f -> Transaction.Fee_transfer f)\n | Coinbase c ->\n With_status.map c.coinbase ~f:(fun c -> Transaction.Coinbase c)\n\n let transaction_status : t -> Transaction_status.t =\n fun { varying; _ } ->\n match varying with\n | Command\n (Signed_command { common = { user_command = { status; _ }; _ }; _ }) ->\n status\n | Command (Zkapp_command c) ->\n c.command.status\n | Fee_transfer f ->\n f.fee_transfer.status\n | Coinbase c ->\n c.coinbase.status\nend\n\nmodule type S = sig\n type ledger\n\n type location\n\n module Transaction_applied : sig\n module Signed_command_applied : sig\n module Common : sig\n type t = Transaction_applied.Signed_command_applied.Common.t =\n { user_command : Signed_command.t With_status.t }\n [@@deriving sexp]\n end\n\n module Body : sig\n type t = Transaction_applied.Signed_command_applied.Body.t =\n | Payment of { new_accounts : Account_id.t list }\n | Stake_delegation of\n { previous_delegate : Public_key.Compressed.t option }\n | Failed\n [@@deriving sexp]\n end\n\n type t = Transaction_applied.Signed_command_applied.t =\n { common : Common.t; body : Body.t }\n [@@deriving sexp]\n end\n\n module Zkapp_command_applied : sig\n type t = Transaction_applied.Zkapp_command_applied.t =\n { accounts : (Account_id.t * Account.t option) list\n ; command : Zkapp_command.t With_status.t\n ; new_accounts : Account_id.t list\n }\n [@@deriving sexp]\n end\n\n module Command_applied : sig\n type t = Transaction_applied.Command_applied.t =\n | Signed_command of Signed_command_applied.t\n | Zkapp_command of Zkapp_command_applied.t\n [@@deriving sexp]\n end\n\n module Fee_transfer_applied : sig\n type t = Transaction_applied.Fee_transfer_applied.t =\n { fee_transfer : Fee_transfer.t With_status.t\n ; new_accounts : Account_id.t list\n ; burned_tokens : Currency.Amount.t\n }\n [@@deriving sexp]\n end\n\n module Coinbase_applied : sig\n type t = Transaction_applied.Coinbase_applied.t =\n { coinbase : Coinbase.t With_status.t\n ; new_accounts : Account_id.t list\n ; burned_tokens : Currency.Amount.t\n }\n [@@deriving sexp]\n end\n\n module Varying : sig\n type t = Transaction_applied.Varying.t =\n | Command of Command_applied.t\n | Fee_transfer of Fee_transfer_applied.t\n | Coinbase of Coinbase_applied.t\n [@@deriving sexp]\n end\n\n type t = Transaction_applied.t =\n { previous_hash : Ledger_hash.t; varying : Varying.t }\n [@@deriving sexp]\n\n val burned_tokens : t -> Currency.Amount.t\n\n val supply_increase : t -> Currency.Amount.Signed.t Or_error.t\n\n val transaction : t -> Transaction.t With_status.t\n\n val transaction_status : t -> Transaction_status.t\n end\n\n module Global_state : sig\n type t =\n { first_pass_ledger : ledger\n ; second_pass_ledger : ledger\n ; fee_excess : Amount.Signed.t\n ; supply_increase : Amount.Signed.t\n ; protocol_state : Zkapp_precondition.Protocol_state.View.t\n ; block_global_slot : Mina_numbers.Global_slot_since_genesis.t\n (* Slot of block when the transaction is applied. NOTE: This is at least 1 slot after the protocol_state's view, which is for the *previous* slot. *)\n }\n end\n\n module Transaction_partially_applied : sig\n module Zkapp_command_partially_applied : sig\n type t =\n { command : Zkapp_command.t\n ; previous_hash : Ledger_hash.t\n ; original_first_pass_account_states :\n (Account_id.t * (location * Account.t) option) list\n ; constraint_constants : Genesis_constants.Constraint_constants.t\n ; state_view : Zkapp_precondition.Protocol_state.View.t\n ; global_state : Global_state.t\n ; local_state :\n ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , ledger\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n }\n end\n\n type 'applied fully_applied =\n { previous_hash : Ledger_hash.t; applied : 'applied }\n\n type t =\n | Signed_command of\n Transaction_applied.Signed_command_applied.t fully_applied\n | Zkapp_command of Zkapp_command_partially_applied.t\n | Fee_transfer of Transaction_applied.Fee_transfer_applied.t fully_applied\n | Coinbase of Transaction_applied.Coinbase_applied.t fully_applied\n\n val command : t -> Transaction.t\n end\n\n val apply_user_command :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> ledger\n -> Signed_command.With_valid_signature.t\n -> Transaction_applied.Signed_command_applied.t Or_error.t\n\n val apply_user_command_unchecked :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> ledger\n -> Signed_command.t\n -> Transaction_applied.Signed_command_applied.t Or_error.t\n\n val update_action_state :\n Snark_params.Tick.Field.t Pickles_types.Vector.Vector_5.t\n -> Zkapp_account.Actions.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> last_action_slot:Global_slot_since_genesis.t\n -> Snark_params.Tick.Field.t Pickles_types.Vector.Vector_5.t\n * Global_slot_since_genesis.t\n\n val apply_zkapp_command_unchecked :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> global_slot:Mina_numbers.Global_slot_since_genesis.t\n -> state_view:Zkapp_precondition.Protocol_state.View.t\n -> ledger\n -> Zkapp_command.t\n -> ( Transaction_applied.Zkapp_command_applied.t\n * ( ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , ledger\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n * Amount.Signed.t ) )\n Or_error.t\n\n (** Apply all zkapp_command within a zkapp_command transaction. This behaves as\n [apply_zkapp_command_unchecked], except that the [~init] and [~f] arguments\n are provided to allow for the accumulation of the intermediate states.\n\n Invariant: [f] is always applied at least once, so it is valid to use an\n [_ option] as the initial state and call [Option.value_exn] on the\n accumulated result.\n\n This can be used to collect the intermediate states to make them\n available for snark work. In particular, since the transaction snark has\n a cap on the number of zkapp_command of each kind that may be included, we can\n use this to retrieve the (source, target) pairs for each batch of\n zkapp_command to include in the snark work spec / transaction snark witness.\n *)\n val apply_zkapp_command_unchecked_aux :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> global_slot:Mina_numbers.Global_slot_since_genesis.t\n -> state_view:Zkapp_precondition.Protocol_state.View.t\n -> init:'acc\n -> f:\n ( 'acc\n -> Global_state.t\n * ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , ledger\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n -> 'acc )\n -> ?fee_excess:Amount.Signed.t\n -> ?supply_increase:Amount.Signed.t\n -> ledger\n -> Zkapp_command.t\n -> (Transaction_applied.Zkapp_command_applied.t * 'acc) Or_error.t\n\n val apply_zkapp_command_first_pass_aux :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> global_slot:Mina_numbers.Global_slot_since_genesis.t\n -> state_view:Zkapp_precondition.Protocol_state.View.t\n -> init:'acc\n -> f:\n ( 'acc\n -> Global_state.t\n * ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , ledger\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n -> 'acc )\n -> ?fee_excess:Amount.Signed.t\n -> ?supply_increase:Amount.Signed.t\n -> ledger\n -> Zkapp_command.t\n -> (Transaction_partially_applied.Zkapp_command_partially_applied.t * 'acc)\n Or_error.t\n\n val apply_zkapp_command_second_pass_aux :\n init:'acc\n -> f:\n ( 'acc\n -> Global_state.t\n * ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , ledger\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n -> 'acc )\n -> ledger\n -> Transaction_partially_applied.Zkapp_command_partially_applied.t\n -> (Transaction_applied.Zkapp_command_applied.t * 'acc) Or_error.t\n\n val apply_fee_transfer :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> ledger\n -> Fee_transfer.t\n -> Transaction_applied.Fee_transfer_applied.t Or_error.t\n\n val apply_coinbase :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> ledger\n -> Coinbase.t\n -> Transaction_applied.Coinbase_applied.t Or_error.t\n\n val apply_transaction_first_pass :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> global_slot:Global_slot_since_genesis.t\n -> txn_state_view:Zkapp_precondition.Protocol_state.View.t\n -> ledger\n -> Transaction.t\n -> Transaction_partially_applied.t Or_error.t\n\n val apply_transaction_second_pass :\n ledger\n -> Transaction_partially_applied.t\n -> Transaction_applied.t Or_error.t\n\n val apply_transactions :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> global_slot:Mina_numbers.Global_slot_since_genesis.t\n -> txn_state_view:Zkapp_precondition.Protocol_state.View.t\n -> ledger\n -> Transaction.t list\n -> Transaction_applied.t list Or_error.t\n\n val has_locked_tokens :\n global_slot:Global_slot_since_genesis.t\n -> account_id:Account_id.t\n -> ledger\n -> bool Or_error.t\n\n module For_tests : sig\n val validate_timing_with_min_balance :\n account:Account.t\n -> txn_amount:Amount.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> (Account.Timing.t * [> `Min_balance of Balance.t ]) Or_error.t\n\n val validate_timing :\n account:Account.t\n -> txn_amount:Amount.t\n -> txn_global_slot:Global_slot_since_genesis.t\n -> Account.Timing.t Or_error.t\n end\nend\n\n(* tags for timing validation errors *)\nlet nsf_tag = \"nsf\"\n\nlet min_balance_tag = \"minbal\"\n\nlet timing_error_to_user_command_status err =\n match Error.Internal_repr.of_info err with\n | Tag_t (tag, _) when String.equal tag nsf_tag ->\n Transaction_status.Failure.Source_insufficient_balance\n | Tag_t (tag, _) when String.equal tag min_balance_tag ->\n Transaction_status.Failure.Source_minimum_balance_violation\n | _ ->\n failwith \"Unexpected timed account validation error\"\n\n(** [validate_timing_with_min_balance' ~account ~txn_amount ~txn_global_slot]\n returns a tuple of 3 values:\n * [[`Insufficient_balance of bool | `Invalid_timing of bool]] encodes\n possible errors, with the invariant that the return value is always\n [`Invalid_timing false] if there was no error.\n - [`Insufficient_balance true] results if [txn_amount] is larger than the\n balance held in [account].\n - [`Invalid_timing true] results if [txn_amount] is larger than the\n balance available in [account] at global slot [txn_global_slot].\n * [Timing.t], the new timing for [account] calculated at [txn_global_slot].\n * [[`Min_balance of Balance.t]] returns the computed available balance at\n [txn_global_slot].\n - NOTE: We skip this calculation if the error is\n [`Insufficient_balance true]. In this scenario, this value MUST NOT be\n used, as it contains an incorrect placeholder value.\n*)\nlet validate_timing_with_min_balance' ~account ~txn_amount ~txn_global_slot =\n let open Account.Poly in\n let open Account.Timing.Poly in\n match account.timing with\n | Untimed -> (\n (* no time restrictions *)\n match Balance.(account.balance - txn_amount) with\n | None ->\n (`Insufficient_balance true, Untimed, `Min_balance Balance.zero)\n | _ ->\n (`Invalid_timing false, Untimed, `Min_balance Balance.zero) )\n | Timed\n { initial_minimum_balance\n ; cliff_time\n ; cliff_amount\n ; vesting_period\n ; vesting_increment\n } ->\n let invalid_balance, invalid_timing, curr_min_balance =\n let account_balance = account.balance in\n match Balance.(account_balance - txn_amount) with\n | None ->\n (* NB: The [initial_minimum_balance] here is the incorrect value,\n but:\n * we don't use it anywhere in this error case; and\n * we don't want to waste time computing it if it will be unused.\n *)\n (true, false, initial_minimum_balance)\n | Some proposed_new_balance ->\n let curr_min_balance =\n Account.min_balance_at_slot ~global_slot:txn_global_slot\n ~cliff_time ~cliff_amount ~vesting_period ~vesting_increment\n ~initial_minimum_balance\n in\n if Balance.(proposed_new_balance < curr_min_balance) then\n (false, true, curr_min_balance)\n else (false, false, curr_min_balance)\n in\n (* once the calculated minimum balance becomes zero, the account becomes untimed *)\n let possibly_error =\n if invalid_balance then `Insufficient_balance invalid_balance\n else `Invalid_timing invalid_timing\n in\n if Balance.(curr_min_balance > zero) then\n (possibly_error, account.timing, `Min_balance curr_min_balance)\n else (possibly_error, Untimed, `Min_balance Balance.zero)\n\nlet validate_timing_with_min_balance ~account ~txn_amount ~txn_global_slot =\n let open Or_error.Let_syntax in\n let nsf_error kind =\n Or_error.errorf\n !\"For %s account, the requested transaction for amount %{sexp: Amount.t} \\\n at global slot %{sexp: Global_slot_since_genesis.t}, the balance \\\n %{sexp: Balance.t} is insufficient\"\n kind txn_amount txn_global_slot account.Account.Poly.balance\n |> Or_error.tag ~tag:nsf_tag\n in\n let min_balance_error min_balance =\n Or_error.errorf\n !\"For timed account, the requested transaction for amount %{sexp: \\\n Amount.t} at global slot %{sexp: Global_slot_since_genesis.t}, \\\n applying the transaction would put the balance below the calculated \\\n minimum balance of %{sexp: Balance.t}\"\n txn_amount txn_global_slot min_balance\n |> Or_error.tag ~tag:min_balance_tag\n in\n let possibly_error, timing, (`Min_balance curr_min_balance as min_balance) =\n validate_timing_with_min_balance' ~account ~txn_amount ~txn_global_slot\n in\n match possibly_error with\n | `Insufficient_balance true ->\n nsf_error \"timed\"\n | `Invalid_timing true ->\n min_balance_error curr_min_balance\n | `Insufficient_balance false ->\n failwith \"Broken invariant in validate_timing_with_min_balance'\"\n | `Invalid_timing false ->\n return (timing, min_balance)\n\nlet validate_timing ~account ~txn_amount ~txn_global_slot =\n let open Result.Let_syntax in\n let%map timing, `Min_balance _ =\n validate_timing_with_min_balance ~account ~txn_amount ~txn_global_slot\n in\n timing\n\nmodule Make (L : Ledger_intf.S) :\n S with type ledger := L.t and type location := L.location = struct\n open L\n\n let error s = Or_error.errorf \"Ledger.apply_transaction: %s\" s\n\n let error_opt e = Option.value_map ~default:(error e) ~f:Or_error.return\n\n let get_with_location ledger account_id =\n match location_of_account ledger account_id with\n | Some location -> (\n match get ledger location with\n | Some account ->\n Ok (`Existing location, account)\n | None ->\n failwith \"Ledger location with no account\" )\n | None ->\n Ok (`New, Account.create account_id Balance.zero)\n\n let set_with_location ledger location account =\n match location with\n | `Existing location ->\n Ok (set ledger location account)\n | `New ->\n create_new_account ledger (Account.identifier account) account\n\n let add_amount balance amount =\n error_opt \"overflow\" (Balance.add_amount balance amount)\n\n let sub_amount balance amount =\n error_opt \"insufficient funds\" (Balance.sub_amount balance amount)\n\n let sub_account_creation_fee\n ~(constraint_constants : Genesis_constants.Constraint_constants.t) action\n amount =\n let fee = constraint_constants.account_creation_fee in\n if Ledger_intf.equal_account_state action `Added then\n error_opt\n (sprintf\n !\"Error subtracting account creation fee %{sexp: Currency.Fee.t}; \\\n transaction amount %{sexp: Currency.Amount.t} insufficient\"\n fee amount )\n Amount.(sub amount (of_fee fee))\n else Ok amount\n\n let check b = ksprintf (fun s -> if b then Ok () else Or_error.error_string s)\n\n let validate_nonces txn_nonce account_nonce =\n check\n (Account.Nonce.equal account_nonce txn_nonce)\n !\"Nonce in account %{sexp: Account.Nonce.t} different from nonce in \\\n transaction %{sexp: Account.Nonce.t}\"\n account_nonce txn_nonce\n\n let validate_time ~valid_until ~current_global_slot =\n check\n Global_slot_since_genesis.(current_global_slot <= valid_until)\n !\"Current global slot %{sexp: Global_slot_since_genesis.t} greater than \\\n transaction expiry slot %{sexp: Global_slot_since_genesis.t}\"\n current_global_slot valid_until\n\n module Transaction_applied = struct\n include Transaction_applied\n\n let transaction : t -> Transaction.t With_status.t =\n fun { varying; _ } ->\n match varying with\n | Command (Signed_command uc) ->\n With_status.map uc.common.user_command ~f:(fun cmd ->\n Transaction.Command (User_command.Signed_command cmd) )\n | Command (Zkapp_command s) ->\n With_status.map s.command ~f:(fun c ->\n Transaction.Command (User_command.Zkapp_command c) )\n | Fee_transfer f ->\n With_status.map f.fee_transfer ~f:(fun f ->\n Transaction.Fee_transfer f )\n | Coinbase c ->\n With_status.map c.coinbase ~f:(fun c -> Transaction.Coinbase c)\n\n let transaction_status : t -> Transaction_status.t =\n fun { varying; _ } ->\n match varying with\n | Command\n (Signed_command { common = { user_command = { status; _ }; _ }; _ })\n ->\n status\n | Command (Zkapp_command c) ->\n c.command.status\n | Fee_transfer f ->\n f.fee_transfer.status\n | Coinbase c ->\n c.coinbase.status\n end\n\n let get_new_accounts action pk =\n if Ledger_intf.equal_account_state action `Added then [ pk ] else []\n\n let has_locked_tokens ~global_slot ~account_id ledger =\n let open Or_error.Let_syntax in\n let%map _, account = get_with_location ledger account_id in\n Account.has_locked_tokens ~global_slot account\n\n let failure (e : Transaction_status.Failure.t) = e\n\n let incr_balance (acct : Account.t) amt =\n match add_amount acct.balance amt with\n | Ok balance ->\n Ok { acct with balance }\n | Error _ ->\n Result.fail (failure Overflow)\n\n (* Helper function for [apply_user_command_unchecked] *)\n let pay_fee' ~command ~nonce ~fee_payer ~fee ~ledger ~current_global_slot =\n let open Or_error.Let_syntax in\n (* Fee-payer information *)\n let%bind location, account = get_with_location ledger fee_payer in\n let%bind () =\n match location with\n | `Existing _ ->\n return ()\n | `New ->\n Or_error.errorf \"The fee-payer account does not exist\"\n in\n let fee = Amount.of_fee fee in\n let%bind balance = sub_amount account.balance fee in\n let%bind () = validate_nonces nonce account.nonce in\n let%map timing =\n validate_timing ~txn_amount:fee ~txn_global_slot:current_global_slot\n ~account\n in\n ( location\n , { account with\n balance\n ; nonce = Account.Nonce.succ account.nonce\n ; receipt_chain_hash =\n Receipt.Chain_hash.cons_signed_command_payload command\n account.receipt_chain_hash\n ; timing\n } )\n\n (* Helper function for [apply_user_command_unchecked] *)\n let pay_fee ~user_command ~signer_pk ~ledger ~current_global_slot =\n let open Or_error.Let_syntax in\n (* Fee-payer information *)\n let nonce = Signed_command.nonce user_command in\n let fee_payer = Signed_command.fee_payer user_command in\n let%bind () =\n let fee_token = Signed_command.fee_token user_command in\n let%bind () =\n (* TODO: Enable multi-sig. *)\n if\n Public_key.Compressed.equal\n (Account_id.public_key fee_payer)\n signer_pk\n then return ()\n else\n Or_error.errorf\n \"Cannot pay fees from a public key that did not sign the \\\n transaction\"\n in\n let%map () =\n (* TODO: Remove this check and update the transaction snark once we have\n an exchange rate mechanism. See issue #4447.\n *)\n if Token_id.equal fee_token Token_id.default then return ()\n else\n Or_error.errorf\n \"Cannot create transactions with fee_token different from the \\\n default\"\n in\n ()\n in\n let%map loc, account' =\n pay_fee' ~command:(Signed_command_payload user_command.payload) ~nonce\n ~fee_payer\n ~fee:(Signed_command.fee user_command)\n ~ledger ~current_global_slot\n in\n (loc, account')\n\n (* someday: It would probably be better if we didn't modify the receipt chain hash\n in the case that the sender is equal to the receiver, but it complicates the SNARK, so\n we don't for now. *)\n let apply_user_command_unchecked\n ~(constraint_constants : Genesis_constants.Constraint_constants.t)\n ~txn_global_slot ledger\n ({ payload; signer; signature = _ } as user_command : Signed_command.t) =\n let open Or_error.Let_syntax in\n let signer_pk = Public_key.compress signer in\n let current_global_slot = txn_global_slot in\n let%bind () =\n validate_time\n ~valid_until:(Signed_command.valid_until user_command)\n ~current_global_slot\n in\n (* Fee-payer information *)\n let fee_payer = Signed_command.fee_payer user_command in\n let%bind fee_payer_location, fee_payer_account =\n pay_fee ~user_command ~signer_pk ~ledger ~current_global_slot\n in\n let%bind () =\n if Account.has_permission_to_send fee_payer_account then Ok ()\n else\n Or_error.error_string\n Transaction_status.Failure.(describe Update_not_permitted_balance)\n in\n let%bind () =\n if Account.has_permission_to_increment_nonce fee_payer_account then Ok ()\n else\n Or_error.error_string\n Transaction_status.Failure.(describe Update_not_permitted_nonce)\n in\n (* Charge the fee. This must happen, whether or not the command itself\n succeeds, to ensure that the network is compensated for processing this\n command.\n *)\n let%bind () =\n set_with_location ledger fee_payer_location fee_payer_account\n in\n let receiver = Signed_command.receiver user_command in\n let exception Reject of Error.t in\n let ok_or_reject = function Ok x -> x | Error err -> raise (Reject err) in\n let compute_updates () =\n let open Result.Let_syntax in\n (* Compute the necessary changes to apply the command, failing if any of\n the conditions are not met.\n *)\n match payload.body with\n | Stake_delegation _ ->\n let receiver_location, _receiver_account =\n (* Check that receiver account exists. *)\n get_with_location ledger receiver |> ok_or_reject\n in\n let%bind () =\n match receiver_location with\n | `Existing _ ->\n return ()\n | `New ->\n Result.fail Transaction_status.Failure.Receiver_not_present\n in\n let%bind () =\n Result.ok_if_true\n (Account.has_permission_to_set_delegate fee_payer_account)\n ~error:Transaction_status.Failure.Update_not_permitted_delegate\n in\n let previous_delegate = fee_payer_account.delegate in\n (* Timing is always valid, but we need to record any switch from\n timed to untimed here to stay in sync with the snark.\n *)\n let%map fee_payer_account =\n let%map timing =\n validate_timing ~txn_amount:Amount.zero\n ~txn_global_slot:current_global_slot ~account:fee_payer_account\n |> Result.map_error ~f:timing_error_to_user_command_status\n in\n { fee_payer_account with\n delegate = Some (Account_id.public_key receiver)\n ; timing\n }\n in\n ( [ (fee_payer_location, fee_payer_account) ]\n , Transaction_applied.Signed_command_applied.Body.Stake_delegation\n { previous_delegate } )\n | Payment { amount; _ } ->\n let%bind fee_payer_account =\n let ret =\n let%bind balance =\n Result.map_error (sub_amount fee_payer_account.balance amount)\n ~f:(fun _ ->\n Transaction_status.Failure.Source_insufficient_balance )\n in\n let%map timing =\n validate_timing ~txn_amount:amount\n ~txn_global_slot:current_global_slot\n ~account:fee_payer_account\n |> Result.map_error ~f:timing_error_to_user_command_status\n in\n { fee_payer_account with balance; timing }\n in\n (* Don't accept transactions with insufficient balance from the fee-payer.\n TODO: eliminate this condition and accept transaction with failed status\n *)\n match ret with\n | Ok x ->\n Ok x\n | Error failure ->\n raise\n (Reject\n (Error.createf \"%s\"\n (Transaction_status.Failure.describe failure) ) )\n in\n let receiver_location, receiver_account =\n if Account_id.equal fee_payer receiver then\n (fee_payer_location, fee_payer_account)\n else get_with_location ledger receiver |> ok_or_reject\n in\n let%bind () =\n Result.ok_if_true\n (Account.has_permission_to_send fee_payer_account)\n ~error:Transaction_status.Failure.Update_not_permitted_balance\n in\n let%bind () =\n Result.ok_if_true\n (Account.has_permission_to_receive receiver_account)\n ~error:Transaction_status.Failure.Update_not_permitted_balance\n in\n (* Charge the account creation fee. *)\n let%bind receiver_amount =\n match receiver_location with\n | `Existing _ ->\n return amount\n | `New ->\n (* Subtract the creation fee from the transaction amount. *)\n sub_account_creation_fee ~constraint_constants `Added amount\n |> Result.map_error ~f:(fun _ ->\n Transaction_status.Failure\n .Amount_insufficient_to_create_account )\n in\n let%map receiver_account =\n incr_balance receiver_account receiver_amount\n in\n let new_accounts =\n match receiver_location with\n | `Existing _ ->\n []\n | `New ->\n [ receiver ]\n in\n let updated_accounts =\n if Account_id.equal fee_payer receiver then\n (* [receiver_account] at this point has all the updates*)\n [ (receiver_location, receiver_account) ]\n else\n [ (receiver_location, receiver_account)\n ; (fee_payer_location, fee_payer_account)\n ]\n in\n ( updated_accounts\n , Transaction_applied.Signed_command_applied.Body.Payment\n { new_accounts } )\n in\n match compute_updates () with\n | Ok (located_accounts, applied_body) ->\n (* Update the ledger. *)\n let%bind () =\n List.fold located_accounts ~init:(Ok ())\n ~f:(fun acc (location, account) ->\n let%bind () = acc in\n set_with_location ledger location account )\n in\n let applied_common : Transaction_applied.Signed_command_applied.Common.t\n =\n { user_command = { data = user_command; status = Applied } }\n in\n return\n ( { common = applied_common; body = applied_body }\n : Transaction_applied.Signed_command_applied.t )\n | Error failure ->\n (* Do not update the ledger. Except for the fee payer which is already updated *)\n let applied_common : Transaction_applied.Signed_command_applied.Common.t\n =\n { user_command =\n { data = user_command\n ; status =\n Failed\n (Transaction_status.Failure.Collection.of_single_failure\n failure )\n }\n }\n in\n return\n ( { common = applied_common; body = Failed }\n : Transaction_applied.Signed_command_applied.t )\n | exception Reject err ->\n (* TODO: These transactions should never reach this stage, this error\n should be fatal.\n *)\n Error err\n\n let apply_user_command ~constraint_constants ~txn_global_slot ledger\n (user_command : Signed_command.With_valid_signature.t) =\n apply_user_command_unchecked ~constraint_constants ~txn_global_slot ledger\n (Signed_command.forget_check user_command)\n\n module Global_state = struct\n type t =\n { first_pass_ledger : L.t\n ; second_pass_ledger : L.t\n ; fee_excess : Amount.Signed.t\n ; supply_increase : Amount.Signed.t\n ; protocol_state : Zkapp_precondition.Protocol_state.View.t\n ; block_global_slot : Global_slot_since_genesis.t\n }\n\n let first_pass_ledger { first_pass_ledger; _ } =\n L.create_masked first_pass_ledger\n\n let set_first_pass_ledger ~should_update t ledger =\n if should_update then L.apply_mask t.first_pass_ledger ~masked:ledger ;\n t\n\n let second_pass_ledger { second_pass_ledger; _ } =\n L.create_masked second_pass_ledger\n\n let set_second_pass_ledger ~should_update t ledger =\n if should_update then L.apply_mask t.second_pass_ledger ~masked:ledger ;\n t\n\n let fee_excess { fee_excess; _ } = fee_excess\n\n let set_fee_excess t fee_excess = { t with fee_excess }\n\n let supply_increase { supply_increase; _ } = supply_increase\n\n let set_supply_increase t supply_increase = { t with supply_increase }\n\n let block_global_slot { block_global_slot; _ } = block_global_slot\n end\n\n module Transaction_partially_applied = struct\n module Zkapp_command_partially_applied = struct\n type t =\n { command : Zkapp_command.t\n ; previous_hash : Ledger_hash.t\n ; original_first_pass_account_states :\n (Account_id.t * (location * Account.t) option) list\n ; constraint_constants : Genesis_constants.Constraint_constants.t\n ; state_view : Zkapp_precondition.Protocol_state.View.t\n ; global_state : Global_state.t\n ; local_state :\n ( Stack_frame.value\n , Stack_frame.value list\n , Amount.Signed.t\n , L.t\n , bool\n , Zkapp_command.Transaction_commitment.t\n , Mina_numbers.Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n }\n end\n\n type 'applied fully_applied =\n { previous_hash : Ledger_hash.t; applied : 'applied }\n\n (* TODO: lift previous_hash up in the types *)\n type t =\n | Signed_command of\n Transaction_applied.Signed_command_applied.t fully_applied\n | Zkapp_command of Zkapp_command_partially_applied.t\n | Fee_transfer of Transaction_applied.Fee_transfer_applied.t fully_applied\n | Coinbase of Transaction_applied.Coinbase_applied.t fully_applied\n\n let command (t : t) : Transaction.t =\n match t with\n | Signed_command s ->\n Transaction.Command\n (User_command.Signed_command s.applied.common.user_command.data)\n | Zkapp_command z ->\n Command (User_command.Zkapp_command z.command)\n | Fee_transfer f ->\n Fee_transfer f.applied.fee_transfer.data\n | Coinbase c ->\n Coinbase c.applied.coinbase.data\n end\n\n module Inputs = struct\n let with_label ~label:_ f = f ()\n\n let value_if b ~then_ ~else_ = if b then then_ else else_\n\n module Global_state = Global_state\n\n module Field = struct\n type t = Snark_params.Tick.Field.t\n\n let if_ = value_if\n\n let equal = Snark_params.Tick.Field.equal\n end\n\n module Bool = struct\n type t = bool\n\n module Assert = struct\n let is_true ~pos b =\n try assert b\n with Assert_failure _ ->\n let file, line, col, _ecol = pos in\n raise (Assert_failure (file, line, col))\n\n let any ~pos bs = List.exists ~f:Fn.id bs |> is_true ~pos\n end\n\n let if_ = value_if\n\n let true_ = true\n\n let false_ = false\n\n let equal = Bool.equal\n\n let not = not\n\n let ( ||| ) = ( || )\n\n let ( &&& ) = ( && )\n\n let display b ~label = sprintf \"%s: %b\" label b\n\n let all = List.for_all ~f:Fn.id\n\n type failure_status = Transaction_status.Failure.t option\n\n type failure_status_tbl = Transaction_status.Failure.Collection.t\n\n let is_empty t = List.join t |> List.is_empty\n\n let assert_with_failure_status_tbl ~pos b failure_status_tbl =\n let file, line, col, ecol = pos in\n if (not b) && not (is_empty failure_status_tbl) then\n (* Raise a more useful error message if we have a failure\n description. *)\n let failure_msg =\n Yojson.Safe.to_string\n @@ Transaction_status.Failure.Collection.Display.to_yojson\n @@ Transaction_status.Failure.Collection.to_display\n failure_status_tbl\n in\n Error.raise @@ Error.of_string\n @@ sprintf \"File %S, line %d, characters %d-%d: %s\" file line col ecol\n failure_msg\n else\n try assert b\n with Assert_failure _ -> raise (Assert_failure (file, line, col))\n end\n\n module Account_id = struct\n include Account_id\n\n let if_ = value_if\n end\n\n module Ledger = struct\n type t = L.t\n\n let if_ = value_if\n\n let empty = L.empty\n\n type inclusion_proof = [ `Existing of location | `New ]\n\n let get_account p l =\n let loc, acct =\n Or_error.ok_exn (get_with_location l (Account_update.account_id p))\n in\n (acct, loc)\n\n let set_account l (a, loc) =\n Or_error.ok_exn (set_with_location l loc a) ;\n l\n\n let check_inclusion _ledger (_account, _loc) = ()\n\n let check_account public_key token_id\n ((account, loc) : Account.t * inclusion_proof) =\n assert (Public_key.Compressed.equal public_key account.public_key) ;\n assert (Token_id.equal token_id account.token_id) ;\n match loc with `Existing _ -> `Is_new false | `New -> `Is_new true\n end\n\n module Transaction_commitment = struct\n type t = Field.t\n\n let empty = Zkapp_command.Transaction_commitment.empty\n\n let commitment ~account_updates =\n let account_updates_hash =\n Mina_base.Zkapp_command.Call_forest.hash account_updates\n in\n Zkapp_command.Transaction_commitment.create ~account_updates_hash\n\n let full_commitment ~account_update ~memo_hash ~commitment =\n (* when called from Zkapp_command_logic.apply, the account_update is the fee payer *)\n let fee_payer_hash =\n Zkapp_command.Digest.Account_update.create account_update\n in\n Zkapp_command.Transaction_commitment.create_complete commitment\n ~memo_hash ~fee_payer_hash\n\n let if_ = value_if\n end\n\n module Index = struct\n type t = Mina_numbers.Index.t\n\n let zero, succ = Mina_numbers.Index.(zero, succ)\n\n let if_ = value_if\n end\n\n module Public_key = struct\n type t = Public_key.Compressed.t\n\n let if_ = value_if\n end\n\n module Controller = struct\n type t = Permissions.Auth_required.t\n\n let if_ = value_if\n\n let check ~proof_verifies ~signature_verifies perm =\n (* Invariant: We either have a proof, a signature, or neither. *)\n assert (not (proof_verifies && signature_verifies)) ;\n let tag =\n if proof_verifies then Control.Tag.Proof\n else if signature_verifies then Control.Tag.Signature\n else Control.Tag.None_given\n in\n Permissions.Auth_required.check perm tag\n end\n\n module Global_slot_since_genesis = struct\n include Mina_numbers.Global_slot_since_genesis\n\n let if_ = value_if\n end\n\n module Global_slot_span = struct\n include Mina_numbers.Global_slot_span\n\n let if_ = value_if\n end\n\n module Nonce = struct\n type t = Account.Nonce.t\n\n let if_ = value_if\n\n let succ = Account.Nonce.succ\n end\n\n module Receipt_chain_hash = struct\n type t = Receipt.Chain_hash.t\n\n module Elt = struct\n type t = Receipt.Zkapp_command_elt.t\n\n let of_transaction_commitment tc =\n Receipt.Zkapp_command_elt.Zkapp_command_commitment tc\n end\n\n let cons_zkapp_command_commitment =\n Receipt.Chain_hash.cons_zkapp_command_commitment\n\n let if_ = value_if\n end\n\n module State_hash = struct\n include State_hash\n\n let if_ = value_if\n end\n\n module Timing = struct\n type t = Account_update.Update.Timing_info.t option\n\n let if_ = value_if\n\n let vesting_period (t : t) =\n match t with\n | Some t ->\n t.vesting_period\n | None ->\n (Account_timing.to_record Untimed).vesting_period\n end\n\n module Balance = struct\n include Balance\n\n let if_ = value_if\n end\n\n module Verification_key = struct\n type t = (Side_loaded_verification_key.t, Field.t) With_hash.t option\n\n let if_ = value_if\n end\n\n module Verification_key_hash = struct\n type t = Field.t option\n\n let equal vk1 vk2 = Option.equal Field.equal vk1 vk2\n end\n\n module Actions = struct\n type t = Zkapp_account.Actions.t\n\n let is_empty = List.is_empty\n\n let push_events = Account_update.Actions.push_events\n end\n\n module Zkapp_uri = struct\n type t = string\n\n let if_ = value_if\n end\n\n module Token_symbol = struct\n type t = Account.Token_symbol.t\n\n let if_ = value_if\n end\n\n module Account = struct\n include Account\n\n module Permissions = struct\n let access : t -> Controller.t = fun a -> a.permissions.access\n\n let edit_state : t -> Controller.t = fun a -> a.permissions.edit_state\n\n let send : t -> Controller.t = fun a -> a.permissions.send\n\n let receive : t -> Controller.t = fun a -> a.permissions.receive\n\n let set_delegate : t -> Controller.t =\n fun a -> a.permissions.set_delegate\n\n let set_permissions : t -> Controller.t =\n fun a -> a.permissions.set_permissions\n\n let set_verification_key : t -> Controller.t =\n fun a -> a.permissions.set_verification_key\n\n let set_zkapp_uri : t -> Controller.t =\n fun a -> a.permissions.set_zkapp_uri\n\n let edit_action_state : t -> Controller.t =\n fun a -> a.permissions.edit_action_state\n\n let set_token_symbol : t -> Controller.t =\n fun a -> a.permissions.set_token_symbol\n\n let increment_nonce : t -> Controller.t =\n fun a -> a.permissions.increment_nonce\n\n let set_voting_for : t -> Controller.t =\n fun a -> a.permissions.set_voting_for\n\n let set_timing : t -> Controller.t = fun a -> a.permissions.set_timing\n\n type t = Permissions.t\n\n let if_ = value_if\n end\n\n type timing = Account_update.Update.Timing_info.t option\n\n let timing (a : t) : timing =\n Account_update.Update.Timing_info.of_account_timing a.timing\n\n let set_timing (a : t) (timing : timing) : t =\n { a with\n timing =\n Option.value_map ~default:Account_timing.Untimed\n ~f:Account_update.Update.Timing_info.to_account_timing timing\n }\n\n let is_timed (a : t) =\n match a.timing with Account_timing.Untimed -> false | _ -> true\n\n let set_token_id (a : t) (id : Token_id.t) : t = { a with token_id = id }\n\n let balance (a : t) : Balance.t = a.balance\n\n let set_balance (balance : Balance.t) (a : t) : t = { a with balance }\n\n let check_timing ~txn_global_slot account =\n let invalid_timing, timing, _ =\n validate_timing_with_min_balance' ~txn_amount:Amount.zero\n ~txn_global_slot ~account\n in\n ( invalid_timing\n , Account_update.Update.Timing_info.of_account_timing timing )\n\n let receipt_chain_hash (a : t) : Receipt.Chain_hash.t =\n a.receipt_chain_hash\n\n let set_receipt_chain_hash (a : t) hash =\n { a with receipt_chain_hash = hash }\n\n let make_zkapp (a : t) =\n let zkapp =\n match a.zkapp with\n | None ->\n Some Zkapp_account.default\n | Some _ as zkapp ->\n zkapp\n in\n { a with zkapp }\n\n let unmake_zkapp (a : t) : t =\n let zkapp =\n match a.zkapp with\n | None ->\n None\n | Some zkapp ->\n if Zkapp_account.(equal default zkapp) then None else Some zkapp\n in\n { a with zkapp }\n\n let get_zkapp (a : t) = Option.value_exn a.zkapp\n\n let set_zkapp (a : t) ~f : t = { a with zkapp = Option.map a.zkapp ~f }\n\n let proved_state (a : t) = (get_zkapp a).proved_state\n\n let set_proved_state proved_state (a : t) =\n set_zkapp a ~f:(fun zkapp -> { zkapp with proved_state })\n\n let app_state (a : t) = (get_zkapp a).app_state\n\n let set_app_state app_state (a : t) =\n set_zkapp a ~f:(fun zkapp -> { zkapp with app_state })\n\n let register_verification_key (_ : t) = ()\n\n let verification_key (a : t) = (get_zkapp a).verification_key\n\n let set_verification_key verification_key (a : t) =\n set_zkapp a ~f:(fun zkapp -> { zkapp with verification_key })\n\n let verification_key_hash (a : t) =\n match a.zkapp with\n | None ->\n None\n | Some zkapp ->\n Option.map zkapp.verification_key ~f:With_hash.hash\n\n let last_action_slot (a : t) = (get_zkapp a).last_action_slot\n\n let set_last_action_slot last_action_slot (a : t) =\n set_zkapp a ~f:(fun zkapp -> { zkapp with last_action_slot })\n\n let action_state (a : t) = (get_zkapp a).action_state\n\n let set_action_state action_state (a : t) =\n set_zkapp a ~f:(fun zkapp -> { zkapp with action_state })\n\n let zkapp_uri (a : t) =\n Option.value_map a.zkapp ~default:\"\" ~f:(fun zkapp -> zkapp.zkapp_uri)\n\n let set_zkapp_uri zkapp_uri (a : t) : t =\n { a with\n zkapp = Option.map a.zkapp ~f:(fun zkapp -> { zkapp with zkapp_uri })\n }\n\n let token_symbol (a : t) = a.token_symbol\n\n let set_token_symbol token_symbol (a : t) = { a with token_symbol }\n\n let public_key (a : t) = a.public_key\n\n let set_public_key public_key (a : t) = { a with public_key }\n\n let delegate (a : t) = Account.delegate_opt a.delegate\n\n let set_delegate delegate (a : t) =\n let delegate =\n if Signature_lib.Public_key.Compressed.(equal empty) delegate then\n None\n else Some delegate\n in\n { a with delegate }\n\n let nonce (a : t) = a.nonce\n\n let set_nonce nonce (a : t) = { a with nonce }\n\n let voting_for (a : t) = a.voting_for\n\n let set_voting_for voting_for (a : t) = { a with voting_for }\n\n let permissions (a : t) = a.permissions\n\n let set_permissions permissions (a : t) = { a with permissions }\n end\n\n module Amount = struct\n open Currency.Amount\n\n type unsigned = t\n\n type t = unsigned\n\n let if_ = value_if\n\n module Signed = struct\n include Signed\n\n let if_ = value_if\n\n (* Correctness of these functions hinges on the fact that zero is\n only ever expressed as {sgn = Pos; magnitude = zero}. Sadly, this\n is not guaranteed by the module's signature, as it's internal\n structure is exposed. Create function never produces this unwanted\n value, but the type's internal structure is still exposed, so it's\n possible theoretically to obtain it.\n\n For the moment, however, there is some consolation in the fact that\n addition never produces negative zero, even if it was one of its\n arguments. For that reason the risk of this function misbehaving is\n minimal and can probably be safely ignored. *)\n let is_non_neg (t : t) = Sgn.equal t.sgn Pos\n\n let is_neg (t : t) = Sgn.equal t.sgn Neg\n end\n\n let zero = zero\n\n let equal = equal\n\n let add_flagged = add_flagged\n\n let add_signed_flagged (x1 : t) (x2 : Signed.t) : t * [ `Overflow of bool ]\n =\n let y, `Overflow b = Signed.(add_flagged (of_unsigned x1) x2) in\n match y.sgn with\n | Pos ->\n (y.magnitude, `Overflow b)\n | Neg ->\n (* We want to capture the accurate value so that this will match\n with the values in the snarked logic.\n *)\n let magnitude =\n Amount.to_uint64 y.magnitude\n |> Unsigned.UInt64.(mul (sub zero one))\n |> Amount.of_uint64\n in\n (magnitude, `Overflow true)\n\n let of_constant_fee = of_fee\n end\n\n module Token_id = struct\n include Token_id\n\n let if_ = value_if\n end\n\n module Protocol_state_precondition = struct\n include Zkapp_precondition.Protocol_state\n end\n\n module Valid_while_precondition = struct\n include Zkapp_precondition.Valid_while\n end\n\n module Account_update = struct\n include Account_update\n\n module Account_precondition = struct\n include Account_update.Account_precondition\n\n let nonce (t : Account_update.t) = nonce t.body.preconditions.account\n end\n\n type 'a or_ignore = 'a Zkapp_basic.Or_ignore.t\n\n type call_forest = Zkapp_call_forest.t\n\n type transaction_commitment = Transaction_commitment.t\n\n let may_use_parents_own_token (p : t) =\n May_use_token.parents_own_token p.body.may_use_token\n\n let may_use_token_inherited_from_parent (p : t) =\n May_use_token.inherit_from_parent p.body.may_use_token\n\n let check_authorization ~will_succeed:_ ~commitment:_ ~calls:_\n (account_update : t) =\n (* The transaction's validity should already have been checked before\n this point.\n *)\n match account_update.authorization with\n | Signature _ ->\n (`Proof_verifies false, `Signature_verifies true)\n | Proof _ ->\n (`Proof_verifies true, `Signature_verifies false)\n | None_given ->\n (`Proof_verifies false, `Signature_verifies false)\n\n let is_proved (account_update : t) =\n match account_update.body.authorization_kind with\n | Proof _ ->\n true\n | Signature | None_given ->\n false\n\n let is_signed (account_update : t) =\n match account_update.body.authorization_kind with\n | Signature ->\n true\n | Proof _ | None_given ->\n false\n\n let verification_key_hash (p : t) =\n match p.body.authorization_kind with\n | Proof vk_hash ->\n Some vk_hash\n | _ ->\n None\n\n module Update = struct\n open Zkapp_basic\n\n type 'a set_or_keep = 'a Zkapp_basic.Set_or_keep.t\n\n let timing (account_update : t) : Account.timing set_or_keep =\n Set_or_keep.map ~f:Option.some account_update.body.update.timing\n\n let app_state (account_update : t) =\n account_update.body.update.app_state\n\n let verification_key (account_update : t) =\n Zkapp_basic.Set_or_keep.map ~f:Option.some\n account_update.body.update.verification_key\n\n let actions (account_update : t) = account_update.body.actions\n\n let zkapp_uri (account_update : t) =\n account_update.body.update.zkapp_uri\n\n let token_symbol (account_update : t) =\n account_update.body.update.token_symbol\n\n let delegate (account_update : t) = account_update.body.update.delegate\n\n let voting_for (account_update : t) =\n account_update.body.update.voting_for\n\n let permissions (account_update : t) =\n account_update.body.update.permissions\n end\n end\n\n module Set_or_keep = struct\n include Zkapp_basic.Set_or_keep\n\n let set_or_keep ~if_:_ t x = set_or_keep t x\n end\n\n module Opt = struct\n type 'a t = 'a option\n\n let is_some = Option.is_some\n\n let map = Option.map\n\n let or_default ~if_ x ~default =\n if_ (is_some x) ~then_:(Option.value ~default x) ~else_:default\n\n let or_exn x = Option.value_exn x\n end\n\n module Stack (Elt : sig\n type t\n end) =\n struct\n type t = Elt.t list\n\n let if_ = value_if\n\n let empty () = []\n\n let is_empty = List.is_empty\n\n let pop_exn : t -> Elt.t * t = function\n | [] ->\n failwith \"pop_exn\"\n | x :: xs ->\n (x, xs)\n\n let pop : t -> (Elt.t * t) option = function\n | x :: xs ->\n Some (x, xs)\n | _ ->\n None\n\n let push x ~onto : t = x :: onto\n end\n\n module Call_forest = Zkapp_call_forest\n\n module Stack_frame = struct\n include Stack_frame\n\n type t = value\n\n let if_ = Zkapp_command.value_if\n\n let make = Stack_frame.make\n end\n\n module Call_stack = Stack (Stack_frame)\n\n module Local_state = struct\n type t =\n ( Stack_frame.t\n , Call_stack.t\n , Amount.Signed.t\n , Ledger.t\n , Bool.t\n , Transaction_commitment.t\n , Index.t\n , Bool.failure_status_tbl )\n Zkapp_command_logic.Local_state.t\n\n let add_check (t : t) failure b =\n let failure_status_tbl =\n match t.failure_status_tbl with\n | hd :: tl when not b ->\n (failure :: hd) :: tl\n | old_failure_status_tbl ->\n old_failure_status_tbl\n in\n { t with failure_status_tbl; success = t.success && b }\n\n let update_failure_status_tbl (t : t) failure_status b =\n match failure_status with\n | None ->\n { t with success = t.success && b }\n | Some failure ->\n add_check t failure b\n\n let add_new_failure_status_bucket (t : t) =\n { t with failure_status_tbl = [] :: t.failure_status_tbl }\n end\n\n module Nonce_precondition = struct\n let is_constant =\n Zkapp_precondition.Numeric.is_constant\n Zkapp_precondition.Numeric.Tc.nonce\n end\n end\n\n module Env = struct\n open Inputs\n\n type t =\n < account_update : Account_update.t\n ; zkapp_command : Zkapp_command.t\n ; account : Account.t\n ; ledger : Ledger.t\n ; amount : Amount.t\n ; signed_amount : Amount.Signed.t\n ; bool : Bool.t\n ; token_id : Token_id.t\n ; global_state : Global_state.t\n ; inclusion_proof : [ `Existing of location | `New ]\n ; local_state :\n ( Stack_frame.t\n , Call_stack.t\n , Amount.Signed.t\n , L.t\n , bool\n , Transaction_commitment.t\n , Index.t\n , Transaction_status.Failure.Collection.t )\n Zkapp_command_logic.Local_state.t\n ; protocol_state_precondition : Zkapp_precondition.Protocol_state.t\n ; valid_while_precondition : Zkapp_precondition.Valid_while.t\n ; transaction_commitment : Transaction_commitment.t\n ; full_transaction_commitment : Transaction_commitment.t\n ; field : Snark_params.Tick.Field.t\n ; failure : Transaction_status.Failure.t option >\n\n let perform ~constraint_constants:_ (type r)\n (eff : (r, t) Zkapp_command_logic.Eff.t) : r =\n match eff with\n | Check_valid_while_precondition (valid_while, global_state) ->\n Zkapp_precondition.Valid_while.check valid_while\n global_state.block_global_slot\n |> Or_error.is_ok\n | Check_protocol_state_precondition (pred, global_state) -> (\n Zkapp_precondition.Protocol_state.check pred\n global_state.protocol_state\n |> fun or_err -> match or_err with Ok () -> true | Error _ -> false )\n | Check_account_precondition\n (account_update, account, new_account, local_state) ->\n let local_state = ref local_state in\n let check failure b =\n local_state := Inputs.Local_state.add_check !local_state failure b\n in\n Zkapp_precondition.Account.check ~new_account ~check\n account_update.body.preconditions.account account ;\n !local_state\n | Init_account { account_update = _; account = a } ->\n a\n end\n\n module M = Zkapp_command_logic.Make (Inputs)\n\n let update_action_state action_state actions ~txn_global_slot\n ~last_action_slot =\n let action_state', last_action_slot' =\n M.update_action_state action_state actions ~txn_global_slot\n ~last_action_slot\n in\n (action_state', last_action_slot')\n\n (* apply zkapp command fee payer's while stubbing out the second pass ledger\n CAUTION: If you use the intermediate local states, you MUST update the\n [will_succeed] field to [false] if the [status] is [Failed].*)\n let apply_zkapp_command_first_pass_aux (type user_acc) ~constraint_constants\n ~global_slot ~(state_view : Zkapp_precondition.Protocol_state.View.t)\n ~(init : user_acc) ~f\n ?((* TODO: can this be ripped out from here? *)\n fee_excess = Amount.Signed.zero)\n ?((* TODO: is the right? is it never used for zkapps? *)\n supply_increase = Amount.Signed.zero) (ledger : L.t)\n (command : Zkapp_command.t) :\n ( Transaction_partially_applied.Zkapp_command_partially_applied.t\n * user_acc )\n Or_error.t =\n let open Or_error.Let_syntax in\n let previous_hash = merkle_root ledger in\n let original_first_pass_account_states =\n let id = Zkapp_command.fee_payer command in\n [ ( id\n , Option.Let_syntax.(\n let%bind loc = L.location_of_account ledger id in\n let%map a = L.get ledger loc in\n (loc, a)) )\n ]\n in\n let perform eff = Env.perform ~constraint_constants eff in\n let initial_state :\n Inputs.Global_state.t * _ Zkapp_command_logic.Local_state.t =\n ( { protocol_state = state_view\n ; first_pass_ledger = ledger\n ; second_pass_ledger =\n (* We stub out the second_pass_ledger initially, and then poke the\n correct value in place after the first pass is finished.\n *)\n L.empty ~depth:0 ()\n ; fee_excess\n ; supply_increase\n ; block_global_slot = global_slot\n }\n , { stack_frame =\n ({ calls = []\n ; caller = Token_id.default\n ; caller_caller = Token_id.default\n } : Inputs.Stack_frame.t)\n ; call_stack = []\n ; transaction_commitment = Inputs.Transaction_commitment.empty\n ; full_transaction_commitment = Inputs.Transaction_commitment.empty\n ; excess = Currency.Amount.(Signed.of_unsigned zero)\n ; supply_increase = Currency.Amount.(Signed.of_unsigned zero)\n ; ledger = L.empty ~depth:0 ()\n ; success = true\n ; account_update_index = Inputs.Index.zero\n ; failure_status_tbl = []\n ; will_succeed = true\n } )\n in\n let user_acc = f init initial_state in\n let account_updates = Zkapp_command.all_account_updates command in\n let%map global_state, local_state =\n Or_error.try_with (fun () ->\n M.start ~constraint_constants\n { account_updates\n ; memo_hash = Signed_command_memo.hash command.memo\n ; will_succeed =\n (* It's always valid to set this value to true, and it will\n have no effect outside of the snark.\n *)\n true\n }\n { perform } initial_state )\n in\n ( { Transaction_partially_applied.Zkapp_command_partially_applied.command\n ; previous_hash\n ; original_first_pass_account_states\n ; constraint_constants\n ; state_view\n ; global_state\n ; local_state\n }\n , user_acc )\n\n let apply_zkapp_command_first_pass ~constraint_constants ~global_slot\n ~(state_view : Zkapp_precondition.Protocol_state.View.t)\n ?((* TODO: can this be ripped out from here? *)\n fee_excess = Amount.Signed.zero)\n ?((* TODO: is the right? is it never used for zkapps? *)\n supply_increase = Amount.Signed.zero) (ledger : L.t)\n (command : Zkapp_command.t) :\n Transaction_partially_applied.Zkapp_command_partially_applied.t Or_error.t\n =\n let open Or_error.Let_syntax in\n let%map partial_stmt, _user_acc =\n apply_zkapp_command_first_pass_aux ~constraint_constants ~global_slot\n ~state_view ~fee_excess ~supply_increase ledger command ~init:None\n ~f:(fun _acc state -> Some state)\n in\n partial_stmt\n\n let apply_zkapp_command_second_pass_aux (type user_acc) ~(init : user_acc) ~f\n ledger\n (c : Transaction_partially_applied.Zkapp_command_partially_applied.t) :\n (Transaction_applied.Zkapp_command_applied.t * user_acc) Or_error.t =\n let open Or_error.Let_syntax in\n let perform eff =\n Env.perform ~constraint_constants:c.constraint_constants eff\n in\n let original_account_states =\n (*get the original states of all the accounts in each pass.\n If an account updated in the first pass is referenced in account\n updates, then retain the value before first pass application*)\n (* IMPORTANT: this account list must be sorted by Account_id in increasing order,\n if this ordering changes the scan state hash will be affected and made\n incompatible. *)\n Account_id.Map.to_alist ~key_order:`Increasing\n @@ List.fold ~init:Account_id.Map.empty\n ~f:(fun account_states (id, acc_opt) ->\n Account_id.Map.update account_states id\n ~f:(Option.value ~default:acc_opt) )\n ( c.original_first_pass_account_states\n @ List.map (Zkapp_command.accounts_referenced c.command)\n ~f:(fun id ->\n ( id\n , Option.Let_syntax.(\n let%bind loc = L.location_of_account ledger id in\n let%map a = L.get ledger loc in\n (loc, a)) ) ) )\n in\n let rec step_all (user_acc : user_acc)\n ( (g_state : Inputs.Global_state.t)\n , (l_state : _ Zkapp_command_logic.Local_state.t) ) :\n (user_acc * Transaction_status.Failure.Collection.t) Or_error.t =\n if List.is_empty l_state.stack_frame.Stack_frame.calls then\n Ok (user_acc, l_state.failure_status_tbl)\n else\n let%bind states =\n Or_error.try_with (fun () ->\n M.step ~constraint_constants:c.constraint_constants { perform }\n (g_state, l_state) )\n in\n step_all (f user_acc states) states\n in\n let account_states_after_fee_payer =\n (*To check if the accounts remain unchanged in the event the transaction\n fails. First pass updates will remain even if the transaction fails to\n apply zkapp account updates*)\n List.map (Zkapp_command.accounts_referenced c.command) ~f:(fun id ->\n ( id\n , Option.Let_syntax.(\n let%bind loc = L.location_of_account ledger id in\n let%map a = L.get ledger loc in\n (loc, a)) ) )\n in\n let accounts () =\n List.map original_account_states\n ~f:(Tuple2.map_snd ~f:(Option.map ~f:snd))\n in\n (* Warning: This is an abstraction leak / hack.\n Here, we update global second pass ledger to be the input ledger, and\n then update the local ledger to be the input ledger *IF AND ONLY IF*\n there are more transaction segments to be processed in this pass.\n\n TODO: Remove this, and uplift the logic into the call in staged ledger.\n *)\n let global_state = { c.global_state with second_pass_ledger = ledger } in\n let local_state =\n if List.is_empty c.local_state.stack_frame.Stack_frame.calls then\n (* Don't mess with the local state; we've already finished the\n transaction after the fee payer.\n *)\n c.local_state\n else\n (* Install the ledger that should already be in the local state, but\n may not be in some situations depending on who the caller is.\n *)\n { c.local_state with\n ledger = Global_state.second_pass_ledger global_state\n }\n in\n let start = (global_state, local_state) in\n match step_all (f init start) start with\n | Error e ->\n Error e\n | Ok (user_acc, reversed_failure_status_tbl) ->\n let failure_status_tbl = List.rev reversed_failure_status_tbl in\n let account_ids_originally_not_in_ledger =\n List.filter_map original_account_states\n ~f:(fun (acct_id, loc_and_acct) ->\n if Option.is_none loc_and_acct then Some acct_id else None )\n in\n let successfully_applied =\n Transaction_status.Failure.Collection.is_empty failure_status_tbl\n in\n (* if the zkapp command fails in at least 1 account update,\n then all the account updates would be cancelled except\n the fee payer one\n *)\n let failure_status_tbl =\n if successfully_applied then failure_status_tbl\n else\n List.mapi failure_status_tbl ~f:(fun idx fs ->\n if idx > 0 && List.is_empty fs then\n [ Transaction_status.Failure.Cancelled ]\n else fs )\n in\n (* accounts not originally in ledger, now present in ledger *)\n let new_accounts =\n List.filter account_ids_originally_not_in_ledger ~f:(fun acct_id ->\n Option.is_some @@ L.location_of_account ledger acct_id )\n in\n let valid_result =\n Ok\n ( { Transaction_applied.Zkapp_command_applied.accounts = accounts ()\n ; command =\n { With_status.data = c.command\n ; status =\n ( if successfully_applied then Applied\n else Failed failure_status_tbl )\n }\n ; new_accounts\n }\n , user_acc )\n in\n if successfully_applied then valid_result\n else\n let other_account_update_accounts_unchanged =\n List.fold_until account_states_after_fee_payer ~init:true\n ~f:(fun acc (_, loc_opt) ->\n match\n let open Option.Let_syntax in\n let%bind loc, a = loc_opt in\n let%bind a' = L.get ledger loc in\n Option.some_if (not (Account.equal a a')) ()\n with\n | None ->\n Continue acc\n | Some _ ->\n Stop false )\n ~finish:Fn.id\n in\n (* Other zkapp_command failed, therefore, updates in those should not get applied *)\n if\n List.is_empty new_accounts\n && other_account_update_accounts_unchanged\n then valid_result\n else\n Or_error.error_string\n \"Zkapp_command application failed but new accounts created or \\\n some of the other account_update updates applied\"\n\n let apply_zkapp_command_second_pass ledger c :\n Transaction_applied.Zkapp_command_applied.t Or_error.t =\n let open Or_error.Let_syntax in\n let%map x, () =\n apply_zkapp_command_second_pass_aux ~init:() ~f:Fn.const ledger c\n in\n x\n\n let apply_zkapp_command_unchecked_aux ~constraint_constants ~global_slot\n ~state_view ~init ~f ?fee_excess ?supply_increase ledger command =\n let open Or_error.Let_syntax in\n apply_zkapp_command_first_pass_aux ~constraint_constants ~global_slot\n ~state_view ?fee_excess ?supply_increase ledger command ~init ~f\n >>= fun (partial_stmt, user_acc) ->\n apply_zkapp_command_second_pass_aux ~init:user_acc ~f ledger partial_stmt\n\n let apply_zkapp_command_unchecked ~constraint_constants ~global_slot\n ~state_view ledger command =\n let open Or_error.Let_syntax in\n apply_zkapp_command_first_pass ~constraint_constants ~global_slot\n ~state_view ledger command\n >>= apply_zkapp_command_second_pass_aux ledger ~init:None\n ~f:(fun _acc (global_state, local_state) ->\n Some (local_state, global_state.fee_excess) )\n |> Result.map ~f:(fun (account_update_applied, state_res) ->\n (account_update_applied, Option.value_exn state_res) )\n\n let update_timing_when_no_deduction ~txn_global_slot account =\n validate_timing ~txn_amount:Amount.zero ~txn_global_slot ~account\n\n let has_permission_to_receive ~ledger receiver_account_id :\n Account.t\n * Ledger_intf.account_state\n * [> `Has_permission_to_receive of bool ] =\n let init_account = Account.initialize receiver_account_id in\n match location_of_account ledger receiver_account_id with\n | None ->\n (* new account, check that default permissions allow receiving *)\n ( init_account\n , `Added\n , `Has_permission_to_receive\n (Account.has_permission_to_receive init_account) )\n | Some loc -> (\n match get ledger loc with\n | None ->\n failwith \"Ledger location with no account\"\n | Some receiver_account ->\n ( receiver_account\n , `Existed\n , `Has_permission_to_receive\n (Account.has_permission_to_receive receiver_account) ) )\n\n let no_failure = []\n\n let update_failed =\n [ Transaction_status.Failure.Update_not_permitted_balance ]\n\n let empty = Transaction_status.Failure.Collection.empty\n\n let single_failure =\n Transaction_status.Failure.Collection.of_single_failure\n Update_not_permitted_balance\n\n let append_entry f (s : Transaction_status.Failure.Collection.t) :\n Transaction_status.Failure.Collection.t =\n match s with [] -> [ f ] | h :: t -> h :: f :: t\n\n (*Structure of the failure status:\n I. Only one fee transfer in the transaction (`One) and it fails:\n [[failure]]\n II. Two fee transfers in the transaction (`Two)-\n Both fee transfers fail:\n [[failure-of-first-fee-transfer]; [failure-of-second-fee-transfer]]\n First succeeds and second one fails:\n [[];[failure-of-second-fee-transfer]]\n First fails and second succeeds:\n [[failure-of-first-fee-transfer];[]]\n *)\n let process_fee_transfer t (transfer : Fee_transfer.t) ~modify_balance\n ~modify_timing =\n let open Or_error.Let_syntax in\n (* TODO(#4555): Allow token_id to vary from default. *)\n let%bind () =\n if\n List.for_all\n ~f:Token_id.(equal default)\n (One_or_two.to_list (Fee_transfer.fee_tokens transfer))\n then return ()\n else Or_error.errorf \"Cannot pay fees in non-default tokens.\"\n in\n match Fee_transfer.to_singles transfer with\n | `One ft ->\n let account_id = Fee_transfer.Single.receiver ft in\n let a, action, `Has_permission_to_receive can_receive =\n has_permission_to_receive ~ledger:t account_id\n in\n let%bind timing = modify_timing a in\n let%bind balance = modify_balance action account_id a.balance ft.fee in\n if can_receive then (\n let%map _action, a, loc = get_or_create t account_id in\n let new_accounts = get_new_accounts action account_id in\n set t loc { a with balance; timing } ;\n (new_accounts, empty, Currency.Amount.zero) )\n else Ok ([], single_failure, Currency.Amount.of_fee ft.fee)\n | `Two (ft1, ft2) ->\n let account_id1 = Fee_transfer.Single.receiver ft1 in\n let a1, action1, `Has_permission_to_receive can_receive1 =\n has_permission_to_receive ~ledger:t account_id1\n in\n let account_id2 = Fee_transfer.Single.receiver ft2 in\n if Account_id.equal account_id1 account_id2 then\n let%bind fee = error_opt \"overflow\" (Fee.add ft1.fee ft2.fee) in\n let%bind timing = modify_timing a1 in\n let%bind balance =\n modify_balance action1 account_id1 a1.balance fee\n in\n if can_receive1 then (\n let%map _action1, a1, l1 = get_or_create t account_id1 in\n let new_accounts1 = get_new_accounts action1 account_id1 in\n set t l1 { a1 with balance; timing } ;\n (new_accounts1, empty, Currency.Amount.zero) )\n else\n (*failure for each fee transfer single*)\n Ok\n ( []\n , append_entry update_failed single_failure\n , Currency.Amount.of_fee fee )\n else\n let a2, action2, `Has_permission_to_receive can_receive2 =\n has_permission_to_receive ~ledger:t account_id2\n in\n let%bind balance1 =\n modify_balance action1 account_id1 a1.balance ft1.fee\n in\n (*Note: Not updating the timing field of a1 to avoid additional check in transactions snark (check_timing for \"receiver\"). This is OK because timing rules will not be violated when balance increases and will be checked whenever an amount is deducted from the account. (#5973)*)\n let%bind timing2 = modify_timing a2 in\n let%bind balance2 =\n modify_balance action2 account_id2 a2.balance ft2.fee\n in\n let%bind new_accounts1, failures, burned_tokens1 =\n if can_receive1 then (\n let%map _action1, a1, l1 = get_or_create t account_id1 in\n let new_accounts1 = get_new_accounts action1 account_id1 in\n set t l1 { a1 with balance = balance1 } ;\n ( new_accounts1\n , append_entry no_failure empty\n , Currency.Amount.zero ) )\n else Ok ([], single_failure, Currency.Amount.of_fee ft1.fee)\n in\n let%bind new_accounts2, failures', burned_tokens2 =\n if can_receive2 then (\n let%map _action2, a2, l2 = get_or_create t account_id2 in\n let new_accounts2 = get_new_accounts action2 account_id2 in\n set t l2 { a2 with balance = balance2; timing = timing2 } ;\n ( new_accounts2\n , append_entry no_failure failures\n , Currency.Amount.zero ) )\n else\n Ok\n ( []\n , append_entry update_failed failures\n , Currency.Amount.of_fee ft2.fee )\n in\n let%map burned_tokens =\n error_opt \"burned tokens overflow\"\n (Currency.Amount.add burned_tokens1 burned_tokens2)\n in\n (new_accounts1 @ new_accounts2, failures', burned_tokens)\n\n let apply_fee_transfer ~constraint_constants ~txn_global_slot t transfer =\n let open Or_error.Let_syntax in\n let%map new_accounts, failures, burned_tokens =\n process_fee_transfer t transfer\n ~modify_balance:(fun action _ b f ->\n let%bind amount =\n let amount = Amount.of_fee f in\n sub_account_creation_fee ~constraint_constants action amount\n in\n add_amount b amount )\n ~modify_timing:(fun acc ->\n update_timing_when_no_deduction ~txn_global_slot acc )\n in\n let ft_with_status =\n if Transaction_status.Failure.Collection.is_empty failures then\n { With_status.data = transfer; status = Applied }\n else { data = transfer; status = Failed failures }\n in\n Transaction_applied.Fee_transfer_applied.\n { fee_transfer = ft_with_status; new_accounts; burned_tokens }\n\n (*Structure of the failure status:\n I. No fee transfer and coinbase transfer fails: [[failure]]\n II. With fee transfer-\n Both fee transfer and coinbase fails:\n [[failure-of-fee-transfer]; [failure-of-coinbase]]\n Fee transfer succeeds and coinbase fails:\n [[];[failure-of-coinbase]]\n Fee transfer fails and coinbase succeeds:\n [[failure-of-fee-transfer];[]]\n *)\n let apply_coinbase ~constraint_constants ~txn_global_slot t\n (* TODO: Better system needed for making atomic changes. Could use a monad. *)\n ({ receiver; fee_transfer; amount = coinbase_amount } as cb : Coinbase.t)\n =\n let open Or_error.Let_syntax in\n let%bind ( receiver_reward\n , new_accounts1\n , transferee_update\n , transferee_timing_prev\n , failures1\n , burned_tokens1 ) =\n match fee_transfer with\n | None ->\n return (coinbase_amount, [], None, None, empty, Currency.Amount.zero)\n | Some ({ receiver_pk = transferee; fee } as ft) ->\n assert (not @@ Public_key.Compressed.equal transferee receiver) ;\n let transferee_id = Coinbase.Fee_transfer.receiver ft in\n let fee = Amount.of_fee fee in\n let%bind receiver_reward =\n error_opt \"Coinbase fee transfer too large\"\n (Amount.sub coinbase_amount fee)\n in\n let transferee_account, action, `Has_permission_to_receive can_receive\n =\n has_permission_to_receive ~ledger:t transferee_id\n in\n let new_accounts = get_new_accounts action transferee_id in\n let%bind timing =\n update_timing_when_no_deduction ~txn_global_slot transferee_account\n in\n let%bind balance =\n let%bind amount =\n sub_account_creation_fee ~constraint_constants action fee\n in\n add_amount transferee_account.balance amount\n in\n if can_receive then\n let%map _action, transferee_account, transferee_location =\n get_or_create t transferee_id\n in\n ( receiver_reward\n , new_accounts\n , Some\n ( transferee_location\n , { transferee_account with balance; timing } )\n , Some transferee_account.timing\n , append_entry no_failure empty\n , Currency.Amount.zero )\n else return (receiver_reward, [], None, None, single_failure, fee)\n in\n let receiver_id = Account_id.create receiver Token_id.default in\n let receiver_account, action2, `Has_permission_to_receive can_receive =\n has_permission_to_receive ~ledger:t receiver_id\n in\n let new_accounts2 = get_new_accounts action2 receiver_id in\n (* Note: Updating coinbase receiver timing only if there is no fee transfer.\n This is so as to not add any extra constraints in transaction snark for checking\n \"receiver\" timings. This is OK because timing rules will not be violated when\n balance increases and will be checked whenever an amount is deducted from the\n account (#5973)\n *)\n let%bind coinbase_receiver_timing =\n match transferee_timing_prev with\n | None ->\n let%map new_receiver_timing =\n update_timing_when_no_deduction ~txn_global_slot receiver_account\n in\n new_receiver_timing\n | Some _timing ->\n Ok receiver_account.timing\n in\n let%bind receiver_balance =\n let%bind amount =\n sub_account_creation_fee ~constraint_constants action2 receiver_reward\n in\n add_amount receiver_account.balance amount\n in\n let%bind failures, burned_tokens2 =\n if can_receive then (\n let%map _action2, receiver_account, receiver_location =\n get_or_create t receiver_id\n in\n set t receiver_location\n { receiver_account with\n balance = receiver_balance\n ; timing = coinbase_receiver_timing\n } ;\n (append_entry no_failure failures1, Currency.Amount.zero) )\n else return (append_entry update_failed failures1, receiver_reward)\n in\n Option.iter transferee_update ~f:(fun (l, a) -> set t l a) ;\n let%map burned_tokens =\n error_opt \"burned tokens overflow\"\n (Amount.add burned_tokens1 burned_tokens2)\n in\n let coinbase_with_status =\n if Transaction_status.Failure.Collection.is_empty failures then\n { With_status.data = cb; status = Applied }\n else { With_status.data = cb; status = Failed failures }\n in\n Transaction_applied.Coinbase_applied.\n { coinbase = coinbase_with_status\n ; new_accounts = new_accounts1 @ new_accounts2\n ; burned_tokens\n }\n\n let apply_transaction_first_pass ~constraint_constants ~global_slot\n ~(txn_state_view : Zkapp_precondition.Protocol_state.View.t) ledger\n (t : Transaction.t) : Transaction_partially_applied.t Or_error.t =\n let open Or_error.Let_syntax in\n let previous_hash = merkle_root ledger in\n let txn_global_slot = global_slot in\n match t with\n | Command (Signed_command txn) ->\n let%map applied =\n apply_user_command_unchecked ~constraint_constants ~txn_global_slot\n ledger txn\n in\n Transaction_partially_applied.Signed_command { previous_hash; applied }\n | Command (Zkapp_command txn) ->\n let%map partially_applied =\n apply_zkapp_command_first_pass ~global_slot ~state_view:txn_state_view\n ~constraint_constants ledger txn\n in\n Transaction_partially_applied.Zkapp_command partially_applied\n | Fee_transfer t ->\n let%map applied =\n apply_fee_transfer ~constraint_constants ~txn_global_slot ledger t\n in\n Transaction_partially_applied.Fee_transfer { previous_hash; applied }\n | Coinbase t ->\n let%map applied =\n apply_coinbase ~constraint_constants ~txn_global_slot ledger t\n in\n Transaction_partially_applied.Coinbase { previous_hash; applied }\n\n let apply_transaction_second_pass ledger (t : Transaction_partially_applied.t)\n : Transaction_applied.t Or_error.t =\n let open Or_error.Let_syntax in\n let open Transaction_applied in\n match t with\n | Signed_command { previous_hash; applied } ->\n return\n { previous_hash; varying = Varying.Command (Signed_command applied) }\n | Zkapp_command partially_applied ->\n (* TODO: either here or in second phase of apply, need to update the prior global state statement for the fee payer segment to add the second phase ledger at the end *)\n let%map applied =\n apply_zkapp_command_second_pass ledger partially_applied\n in\n { previous_hash = partially_applied.previous_hash\n ; varying = Varying.Command (Zkapp_command applied)\n }\n | Fee_transfer { previous_hash; applied } ->\n return { previous_hash; varying = Varying.Fee_transfer applied }\n | Coinbase { previous_hash; applied } ->\n return { previous_hash; varying = Varying.Coinbase applied }\n\n let apply_transactions ~constraint_constants ~global_slot ~txn_state_view\n ledger txns =\n let open Or_error in\n Mina_stdlib.Result.List.map txns\n ~f:\n (apply_transaction_first_pass ~constraint_constants ~global_slot\n ~txn_state_view ledger )\n >>= Mina_stdlib.Result.List.map ~f:(apply_transaction_second_pass ledger)\n\n module For_tests = struct\n let validate_timing_with_min_balance = validate_timing_with_min_balance\n\n let validate_timing = validate_timing\n end\nend\n\nmodule For_tests = struct\n open Mina_numbers\n open Currency\n\n module Account_without_receipt_chain_hash = struct\n type t =\n ( Public_key.Compressed.t\n , Token_id.t\n , Account.Token_symbol.t\n , Balance.t\n , Account_nonce.t\n , unit\n , Public_key.Compressed.t option\n , State_hash.t\n , Account_timing.t\n , Permissions.t\n , Zkapp_account.t option )\n Account.Poly.t\n [@@deriving sexp, compare]\n end\n\n let min_init_balance = Int64.of_string \"8000000000\"\n\n let max_init_balance = Int64.of_string \"8000000000000\"\n\n let num_accounts = 10\n\n let num_transactions = 10\n\n let depth = Int.ceil_log2 (num_accounts + num_transactions)\n\n module Init_ledger = struct\n type t = (Keypair.t * int64) array [@@deriving sexp]\n\n let init ?(zkapp = true) (type l) (module L : Ledger_intf.S with type t = l)\n (init_ledger : t) (l : L.t) =\n Array.iter init_ledger ~f:(fun (kp, amount) ->\n let _tag, account, loc =\n L.get_or_create l\n (Account_id.create\n (Public_key.compress kp.public_key)\n Token_id.default )\n |> Or_error.ok_exn\n in\n let permissions : Permissions.t =\n { edit_state = Either\n ; send = Either\n ; receive = None\n ; set_delegate = Either\n ; set_permissions = Either\n ; set_verification_key = Either\n ; set_zkapp_uri = Either\n ; edit_action_state = Either\n ; set_token_symbol = Either\n ; increment_nonce = Either\n ; set_voting_for = Either\n ; access = None\n ; set_timing = Either\n }\n in\n let zkapp =\n if zkapp then\n Some\n { Zkapp_account.default with\n verification_key =\n Some\n { With_hash.hash = Zkapp_basic.F.zero\n ; data = Side_loaded_verification_key.dummy\n }\n }\n else None\n in\n L.set l loc\n { account with\n balance =\n Currency.Balance.of_uint64 (Unsigned.UInt64.of_int64 amount)\n ; permissions\n ; zkapp\n } )\n\n let gen () : t Quickcheck.Generator.t =\n let tbl = Public_key.Compressed.Hash_set.create () in\n let open Quickcheck.Generator in\n let open Let_syntax in\n let rec go acc n =\n if n = 0 then return (Array.of_list acc)\n else\n let%bind kp =\n filter Keypair.gen ~f:(fun kp ->\n not (Hash_set.mem tbl (Public_key.compress kp.public_key)) )\n and amount = Int64.gen_incl min_init_balance max_init_balance in\n Hash_set.add tbl (Public_key.compress kp.public_key) ;\n go ((kp, amount) :: acc) (n - 1)\n in\n go [] num_accounts\n end\n\n module Transaction_spec = struct\n type t =\n { fee : Currency.Fee.t\n ; sender : Keypair.t * Account_nonce.t\n ; receiver : Public_key.Compressed.t\n ; amount : Currency.Amount.t\n }\n [@@deriving sexp]\n\n let gen ~(init_ledger : Init_ledger.t) ~nonces =\n let pk ((kp : Keypair.t), _) = Public_key.compress kp.public_key in\n let open Quickcheck.Let_syntax in\n let%bind receiver_is_new = Bool.quickcheck_generator in\n let gen_index () = Int.gen_incl 0 (Array.length init_ledger - 1) in\n let%bind receiver_index =\n if receiver_is_new then return None else gen_index () >>| Option.return\n in\n let%bind receiver =\n match receiver_index with\n | None ->\n Public_key.Compressed.gen\n | Some i ->\n return (pk init_ledger.(i))\n in\n let%bind sender =\n let%map i =\n match receiver_index with\n | None ->\n gen_index ()\n | Some j ->\n Quickcheck.Generator.filter (gen_index ()) ~f:(( <> ) j)\n in\n fst init_ledger.(i)\n in\n let gen_amount () =\n Currency.Amount.(\n gen_incl\n (of_nanomina_int_exn 1_000_000)\n (of_nanomina_int_exn 100_000_000))\n in\n let gen_fee () =\n Currency.Fee.(\n gen_incl\n (of_nanomina_int_exn 1_000_000)\n (of_nanomina_int_exn 100_000_000))\n in\n let nonce : Account_nonce.t = Map.find_exn nonces sender in\n let%bind fee = gen_fee () in\n let%bind amount = gen_amount () in\n let nonces =\n Map.set nonces ~key:sender ~data:(Account_nonce.succ nonce)\n in\n let spec = { fee; amount; receiver; sender = (sender, nonce) } in\n return (spec, nonces)\n end\n\n module Test_spec = struct\n type t = { init_ledger : Init_ledger.t; specs : Transaction_spec.t list }\n [@@deriving sexp]\n\n let mk_gen ?(num_transactions = num_transactions) () =\n let open Quickcheck.Let_syntax in\n let%bind init_ledger = Init_ledger.gen () in\n let%bind specs =\n let rec go acc n nonces =\n if n = 0 then return (List.rev acc)\n else\n let%bind spec, nonces = Transaction_spec.gen ~init_ledger ~nonces in\n go (spec :: acc) (n - 1) nonces\n in\n go [] num_transactions\n (Keypair.Map.of_alist_exn\n (List.map (Array.to_list init_ledger) ~f:(fun (pk, _) ->\n (pk, Account_nonce.zero) ) ) )\n in\n return { init_ledger; specs }\n\n let gen = mk_gen ~num_transactions ()\n end\n\n let command_send\n { Transaction_spec.fee; sender = sender, sender_nonce; receiver; amount }\n : Signed_command.t =\n let sender_pk = Public_key.compress sender.public_key in\n Signed_command.sign sender\n { common =\n { fee\n ; fee_payer_pk = sender_pk\n ; nonce = sender_nonce\n ; valid_until = Global_slot_since_genesis.max_value\n ; memo = Signed_command_memo.dummy\n }\n ; body = Payment { receiver_pk = receiver; amount }\n }\n |> Signed_command.forget_check\n\n let account_update_send ?(use_full_commitment = true)\n ?(double_sender_nonce = true)\n { Transaction_spec.fee; sender = sender, sender_nonce; receiver; amount }\n : Zkapp_command.t =\n let sender_pk = Public_key.compress sender.public_key in\n let actual_nonce =\n (* Here, we double the spec'd nonce, because we bump the nonce a second\n time for the 'sender' part of the payment.\n *)\n (* TODO: We should make bumping the nonce for signed zkapp_command optional,\n flagged by a field in the account_update (but always true for the fee payer).\n\n This would also allow us to prevent replays of snapp proofs, by\n allowing them to bump their nonce.\n *)\n if double_sender_nonce then\n sender_nonce |> Account.Nonce.to_uint32\n |> Unsigned.UInt32.(mul (of_int 2))\n |> Account.Nonce.to_uint32\n else sender_nonce\n in\n let zkapp_command : Zkapp_command.Simple.t =\n { fee_payer =\n { Account_update.Fee_payer.body =\n { public_key = sender_pk\n ; fee\n ; valid_until = None\n ; nonce = actual_nonce\n }\n (* Real signature added in below *)\n ; authorization = Signature.dummy\n }\n ; account_updates =\n [ { body =\n { public_key = sender_pk\n ; update = Account_update.Update.noop\n ; token_id = Token_id.default\n ; balance_change = Amount.Signed.(negate (of_unsigned amount))\n ; increment_nonce = double_sender_nonce\n ; events = []\n ; actions = []\n ; call_data = Snark_params.Tick.Field.zero\n ; call_depth = 0\n ; preconditions =\n { Account_update.Preconditions.network =\n Zkapp_precondition.Protocol_state.accept\n ; account = Zkapp_precondition.Account.accept\n ; valid_while = Ignore\n }\n ; may_use_token = No\n ; use_full_commitment\n ; implicit_account_creation_fee = true\n ; authorization_kind =\n ( if use_full_commitment then Signature\n else Proof Zkapp_basic.F.zero )\n }\n ; authorization =\n ( if use_full_commitment then Signature Signature.dummy\n else Proof (Lazy.force Mina_base.Proof.transaction_dummy) )\n }\n ; { body =\n { public_key = receiver\n ; update = Account_update.Update.noop\n ; token_id = Token_id.default\n ; balance_change = Amount.Signed.of_unsigned amount\n ; increment_nonce = false\n ; events = []\n ; actions = []\n ; call_data = Snark_params.Tick.Field.zero\n ; call_depth = 0\n ; preconditions =\n { Account_update.Preconditions.network =\n Zkapp_precondition.Protocol_state.accept\n ; account = Zkapp_precondition.Account.accept\n ; valid_while = Ignore\n }\n ; may_use_token = No\n ; use_full_commitment = false\n ; implicit_account_creation_fee = true\n ; authorization_kind = None_given\n }\n ; authorization = None_given\n }\n ]\n ; memo = Signed_command_memo.empty\n }\n in\n let zkapp_command = Zkapp_command.of_simple zkapp_command in\n let commitment = Zkapp_command.commitment zkapp_command in\n let full_commitment =\n Zkapp_command.Transaction_commitment.create_complete commitment\n ~memo_hash:(Signed_command_memo.hash zkapp_command.memo)\n ~fee_payer_hash:\n (Zkapp_command.Digest.Account_update.create\n (Account_update.of_fee_payer zkapp_command.fee_payer) )\n in\n let account_updates_signature =\n let c = if use_full_commitment then full_commitment else commitment in\n Schnorr.Chunked.sign sender.private_key\n (Random_oracle.Input.Chunked.field c)\n in\n let account_updates =\n Zkapp_command.Call_forest.map zkapp_command.account_updates\n ~f:(fun (account_update : Account_update.t) ->\n match account_update.body.authorization_kind with\n | Signature ->\n { account_update with\n authorization = Control.Signature account_updates_signature\n }\n | _ ->\n account_update )\n in\n let signature =\n Schnorr.Chunked.sign sender.private_key\n (Random_oracle.Input.Chunked.field full_commitment)\n in\n { zkapp_command with\n fee_payer = { zkapp_command.fee_payer with authorization = signature }\n ; account_updates\n }\n\n let test_eq (type l) (module L : Ledger_intf.S with type t = l) accounts\n (l1 : L.t) (l2 : L.t) =\n List.map accounts ~f:(fun a ->\n Or_error.try_with (fun () ->\n let mismatch () =\n failwithf\n !\"One ledger had the account %{sexp:Account_id.t} but the \\\n other did not\"\n a ()\n in\n let hide_rc (a : _ Account.Poly.t) =\n { a with receipt_chain_hash = () }\n in\n match L.(location_of_account l1 a, location_of_account l2 a) with\n | None, None ->\n ()\n | Some _, None | None, Some _ ->\n mismatch ()\n | Some x1, Some x2 -> (\n match L.(get l1 x1, get l2 x2) with\n | None, None ->\n ()\n | Some _, None | None, Some _ ->\n mismatch ()\n | Some a1, Some a2 ->\n [%test_eq: Account_without_receipt_chain_hash.t]\n (hide_rc a1) (hide_rc a2) ) ) )\n |> Or_error.combine_errors_unit\n\n let txn_global_slot = Global_slot_since_genesis.zero\n\n let iter_err ts ~f =\n List.fold_until ts\n ~finish:(fun () -> Ok ())\n ~init:()\n ~f:(fun () t ->\n match f t with Error e -> Stop (Error e) | Ok _ -> Continue () )\n\n let view : Zkapp_precondition.Protocol_state.View.t =\n let h = Frozen_ledger_hash.empty_hash in\n let len = Length.zero in\n let a = Currency.Amount.zero in\n let epoch_data =\n { Epoch_data.Poly.ledger =\n { Epoch_ledger.Poly.hash = h; total_currency = a }\n ; seed = h\n ; start_checkpoint = h\n ; lock_checkpoint = h\n ; epoch_length = len\n }\n in\n { snarked_ledger_hash = h\n ; blockchain_length = len\n ; min_window_density = len\n ; total_currency = a\n ; global_slot_since_genesis = txn_global_slot\n ; staking_epoch_data = epoch_data\n ; next_epoch_data = epoch_data\n }\n\n (* Quickcheck generator for Zkapp_command.t, derived from Test_spec generator *)\n let gen_zkapp_command_from_test_spec =\n let open Quickcheck.Let_syntax in\n let%bind use_full_commitment = Bool.quickcheck_generator in\n match%map Test_spec.mk_gen ~num_transactions:1 () with\n | { specs = [ spec ]; _ } ->\n account_update_send ~use_full_commitment spec\n | { specs; _ } ->\n failwithf \"gen_zkapp_command_from_test_spec: expected one spec, got %d\"\n (List.length specs) ()\nend\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\nmodule Impl = Pickles.Impls.Step\nmodule Other_impl = Pickles.Impls.Wrap\nmodule Field = Impl.Field\nmodule Account_update = Mina_base.Account_update\nmodule Zkapp_command = Mina_base.Zkapp_command\n\n(* Test - functions that have a ts implementation, exposed for ts-ml consistency tests *)\n\nmodule Encoding = struct\n (* arbitrary base58_check encoding *)\n let binary_string_to_base58_check bin_string (version_byte : int) :\n Js.js_string Js.t =\n let module T = struct\n let version_byte = Char.of_int_exn version_byte\n\n let description = \"any\"\n end in\n let module B58 = Base58_check.Make (T) in\n bin_string |> B58.encode |> Js.string\n\n let binary_string_of_base58_check (base58 : Js.js_string Js.t)\n (version_byte : int) =\n let module T = struct\n let version_byte = Char.of_int_exn version_byte\n\n let description = \"any\"\n end in\n let module B58 = Base58_check.Make (T) in\n base58 |> Js.to_string |> B58.decode_exn\n\n (* base58 encoding of some transaction types *)\n let public_key_to_base58 (pk : Signature_lib.Public_key.Compressed.t) :\n Js.js_string Js.t =\n pk |> Signature_lib.Public_key.Compressed.to_base58_check |> Js.string\n\n let public_key_of_base58 (pk_base58 : Js.js_string Js.t) :\n Signature_lib.Public_key.Compressed.t =\n pk_base58 |> Js.to_string\n |> Signature_lib.Public_key.Compressed.of_base58_check_exn\n\n let private_key_to_base58 (sk : Other_impl.field) : Js.js_string Js.t =\n sk |> Signature_lib.Private_key.to_base58_check |> Js.string\n\n let private_key_of_base58 (sk_base58 : Js.js_string Js.t) : Other_impl.field =\n sk_base58 |> Js.to_string |> Signature_lib.Private_key.of_base58_check_exn\n\n let token_id_to_base58 (field : Impl.field) : Js.js_string Js.t =\n field |> Mina_base.Account_id.Digest.of_field\n |> Mina_base.Account_id.Digest.to_string |> Js.string\n\n let token_id_of_base58 (field : Js.js_string Js.t) : Impl.field =\n Mina_base.Account_id.Digest.to_field_unsafe\n @@ Mina_base.Account_id.Digest.of_string @@ Js.to_string field\n\n let memo_to_base58 (memo : Js.js_string Js.t) : Js.js_string Js.t =\n Js.string @@ Mina_base.Signed_command_memo.to_base58_check\n @@ Mina_base.Signed_command_memo.create_from_string_exn @@ Js.to_string memo\n\n let memo_hash_base58 (memo_base58 : Js.js_string Js.t) : Impl.field =\n memo_base58 |> Js.to_string\n |> Mina_base.Signed_command_memo.of_base58_check_exn\n |> Mina_base.Signed_command_memo.hash\nend\n\nmodule Token_id = struct\n let derive pk token =\n let account_id =\n Mina_base.Account_id.create pk (Mina_base.Token_id.of_field token)\n in\n Mina_base.Account_id.derive_token_id ~owner:account_id\n |> Mina_base.Token_id.to_field_unsafe\n\n let derive_checked pk token =\n let account_id =\n Mina_base.Account_id.Checked.create pk\n (Mina_base.Token_id.Checked.of_field token)\n in\n Mina_base.Account_id.Checked.derive_token_id ~owner:account_id\n |> Mina_base.Account_id.Digest.Checked.to_field_unsafe\nend\n\n(* deriver *)\nlet account_update_of_json, _account_update_to_json =\n let deriver =\n lazy\n ( Account_update.Graphql_repr.deriver\n @@ Fields_derivers_zkapps.Derivers.o () )\n in\n let account_update_of_json (account_update : Js.js_string Js.t) :\n Account_update.t =\n Fields_derivers_zkapps.of_json (Lazy.force deriver)\n (account_update |> Js.to_string |> Yojson.Safe.from_string)\n |> Account_update.of_graphql_repr\n in\n let account_update_to_json (account_update : Account_update.t) :\n Js.js_string Js.t =\n Fields_derivers_zkapps.to_json (Lazy.force deriver)\n (Account_update.to_graphql_repr account_update ~call_depth:0)\n |> Yojson.Safe.to_string |> Js.string\n in\n (account_update_of_json, account_update_to_json)\n\nlet body_of_json =\n let body_deriver =\n lazy\n ( Mina_base.Account_update.Body.Graphql_repr.deriver\n @@ Fields_derivers_zkapps.o () )\n in\n let body_of_json json =\n json\n |> Fields_derivers_zkapps.of_json (Lazy.force body_deriver)\n |> Account_update.Body.of_graphql_repr\n in\n body_of_json\n\nmodule Poseidon = struct\n let hash_to_group (xs : Impl.field array) =\n let input = Random_oracle.hash xs in\n Snark_params.Group_map.to_group input\nend\n\nmodule Signature = struct\n let sign_field_element (x : Impl.field) (key : Other_impl.field)\n (is_mainnet : bool Js.t) =\n let network_id =\n Mina_signature_kind.(if Js.to_bool is_mainnet then Mainnet else Testnet)\n in\n Signature_lib.Schnorr.Chunked.sign ~signature_kind:network_id key\n (Random_oracle.Input.Chunked.field x)\n |> Mina_base.Signature.to_base58_check |> Js.string\n\n let dummy_signature () =\n Mina_base.Signature.(dummy |> to_base58_check) |> Js.string\nend\n\nmodule To_fields = struct\n (* helper function to check whether the fields we produce from JS are correct *)\n let fields_of_json\n (typ : ('var, 'value, Field.Constant.t, 'tmp) Impl.Internal_Basic.Typ.typ)\n of_json (json : Js.js_string Js.t) : Impl.field array =\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = of_json json in\n let (Typ typ) = typ in\n let fields, _ = typ.value_to_fields value in\n fields\n\n let account_update =\n fields_of_json (Mina_base.Account_update.Body.typ ()) body_of_json\nend\n\nmodule Hash_from_json = struct\n let account_update (p : Js.js_string Js.t) =\n p |> account_update_of_json |> Account_update.digest\n\n let transaction_commitments (tx_json : Js.js_string Js.t) =\n let tx =\n Zkapp_command.of_json @@ Yojson.Safe.from_string @@ Js.to_string tx_json\n in\n let commitment = Zkapp_command.commitment tx in\n let fee_payer = Account_update.of_fee_payer tx.fee_payer in\n let fee_payer_hash = Zkapp_command.Digest.Account_update.create fee_payer in\n let full_commitment =\n Zkapp_command.Transaction_commitment.create_complete commitment\n ~memo_hash:(Mina_base.Signed_command_memo.hash tx.memo)\n ~fee_payer_hash\n in\n object%js\n val commitment = commitment\n\n val fullCommitment = full_commitment\n\n val feePayerHash = (fee_payer_hash :> Impl.field)\n end\n\n let zkapp_public_input (tx_json : Js.js_string Js.t)\n (account_update_index : int) =\n let tx =\n Zkapp_command.of_json @@ Yojson.Safe.from_string @@ Js.to_string tx_json\n in\n let account_update = List.nth_exn tx.account_updates account_update_index in\n object%js\n val accountUpdate =\n (account_update.elt.account_update_digest :> Impl.field)\n\n val calls =\n (Zkapp_command.Call_forest.hash account_update.elt.calls :> Impl.field)\n end\nend\n\nmodule Hash_input = struct\n type random_oracle_input = Impl.field Random_oracle_input.Chunked.t\n\n let pack_input (input : random_oracle_input) : Impl.field array =\n Random_oracle.pack_input input\n\n (* hash inputs for various account_update subtypes *)\n let timing_input (json : Js.js_string Js.t) : random_oracle_input =\n let deriver = Account_update.Update.Timing_info.deriver in\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = Fields_derivers_zkapps.(of_json (deriver @@ o ()) json) in\n let input = Account_update.Update.Timing_info.to_input value in\n input\n\n let permissions_input (json : Js.js_string Js.t) : random_oracle_input =\n let deriver = Mina_base.Permissions.deriver in\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = Fields_derivers_zkapps.(of_json (deriver @@ o ()) json) in\n let input = Mina_base.Permissions.to_input value in\n input\n\n let update_input (json : Js.js_string Js.t) : random_oracle_input =\n let deriver = Account_update.Update.deriver in\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = Fields_derivers_zkapps.(of_json (deriver @@ o ()) json) in\n let input = Account_update.Update.to_input value in\n input\n\n let account_precondition_input (json : Js.js_string Js.t) :\n random_oracle_input =\n let deriver = Mina_base.Zkapp_precondition.Account.deriver in\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = Fields_derivers_zkapps.(of_json (deriver @@ o ()) json) in\n let input = Mina_base.Zkapp_precondition.Account.to_input value in\n input\n\n let network_precondition_input (json : Js.js_string Js.t) :\n random_oracle_input =\n let deriver = Mina_base.Zkapp_precondition.Protocol_state.deriver in\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = Fields_derivers_zkapps.(of_json (deriver @@ o ()) json) in\n let input = Mina_base.Zkapp_precondition.Protocol_state.to_input value in\n input\n\n let body_input (json : Js.js_string Js.t) : random_oracle_input =\n let json = json |> Js.to_string |> Yojson.Safe.from_string in\n let value = body_of_json json in\n let input = Account_update.Body.to_input value in\n input\nend\n\nmodule Transaction_hash = struct\n module Signed_command = Mina_base.Signed_command\n module Signed_command_payload = Mina_base.Signed_command_payload\n\n let ok_exn result =\n let open Ppx_deriving_yojson_runtime.Result in\n match result with Ok c -> c | Error e -> failwith (\"not ok: \" ^ e)\n\n let keypair () = Signature_lib.Keypair.create ()\n\n let hash_payment (command : Js.js_string Js.t) =\n let command : Signed_command.t =\n command |> Js.to_string |> Yojson.Safe.from_string\n |> Signed_command.of_yojson |> ok_exn\n in\n Mina_transaction.Transaction_hash.(\n command |> hash_signed_command |> to_base58_check |> Js.string)\n\n let hash_payment_v1 (command : Js.js_string Js.t) =\n let command : Signed_command.t_v1 =\n command |> Js.to_string |> Yojson.Safe.from_string\n |> Signed_command.Stable.V1.of_yojson |> ok_exn\n in\n let b58 = Signed_command.to_base58_check_v1 command in\n Mina_transaction.Transaction_hash.(b58 |> digest_string |> to_base58_check)\n |> Js.string\n\n let serialize_common (command : Js.js_string Js.t) =\n let command : Signed_command_payload.Common.t =\n command |> Js.to_string |> Yojson.Safe.from_string\n |> Signed_command_payload.Common.of_yojson |> ok_exn\n in\n Binable.to_bigstring\n (module Signed_command_payload.Common.Stable.Latest)\n command\n\n let serialize_payment (command : Js.js_string Js.t) =\n let command : Signed_command.t =\n command |> Js.to_string |> Yojson.Safe.from_string\n |> Signed_command.of_yojson |> ok_exn\n in\n Binable.to_bigstring (module Signed_command.Stable.Latest) command\n\n let serialize_payment_v1 (command : Js.js_string Js.t) =\n let command : Signed_command.t_v1 =\n command |> Js.to_string |> Yojson.Safe.from_string\n |> Signed_command.Stable.V1.of_yojson |> ok_exn\n in\n Signed_command.to_base58_check_v1 command |> Js.string\n\n let example_payment () =\n let kp = keypair () in\n let payload : Signed_command_payload.t =\n { Signed_command_payload.dummy with\n common =\n { Signed_command_payload.dummy.common with\n fee_payer_pk = Signature_lib.Public_key.compress kp.public_key\n }\n }\n in\n let payment = Signed_command.sign kp payload in\n (payment :> Signed_command.t)\n |> Signed_command.to_yojson |> Yojson.Safe.to_string |> Js.string\nend\n\nlet test =\n object%js\n val encoding =\n let open Encoding in\n object%js\n val toBase58 = binary_string_to_base58_check\n\n val ofBase58 = binary_string_of_base58_check\n\n method publicKeyToBase58 = public_key_to_base58\n\n method publicKeyOfBase58 = public_key_of_base58\n\n method privateKeyToBase58 = private_key_to_base58\n\n method privateKeyOfBase58 = private_key_of_base58\n\n method tokenIdToBase58 = token_id_to_base58\n\n method tokenIdOfBase58 = token_id_of_base58\n\n method memoToBase58 = memo_to_base58\n\n method memoHashBase58 = memo_hash_base58\n end\n\n val tokenId =\n object%js\n method derive = Token_id.derive\n\n method deriveChecked = Token_id.derive_checked\n end\n\n val poseidon =\n object%js\n val hashToGroup = Poseidon.hash_to_group\n end\n\n val signature =\n object%js\n method signFieldElement = Signature.sign_field_element\n\n val dummySignature = Signature.dummy_signature\n end\n\n val fieldsFromJson =\n object%js\n method accountUpdate = To_fields.account_update\n end\n\n val hashFromJson =\n object%js\n method accountUpdate = Hash_from_json.account_update\n\n method transactionCommitments = Hash_from_json.transaction_commitments\n\n method zkappPublicInput = Hash_from_json.zkapp_public_input\n end\n\n val hashInputFromJson =\n let open Hash_input in\n object%js\n val packInput = pack_input\n\n val timing = timing_input\n\n val permissions = permissions_input\n\n val accountPrecondition = account_precondition_input\n\n val networkPrecondition = network_precondition_input\n\n val update = update_input\n\n val body = body_input\n end\n\n val transactionHash =\n let open Transaction_hash in\n object%js\n method hashPayment = hash_payment\n\n method hashPaymentV1 = hash_payment_v1\n\n method serializeCommon = serialize_common\n\n method serializePayment = serialize_payment\n\n method serializePaymentV1 = serialize_payment_v1\n\n val examplePayment = example_payment\n end\n end\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\nmodule Impl = Pickles.Impls.Step\nmodule Field = Impl.Field\nmodule Boolean = Impl.Boolean\nmodule Typ = Impl.Typ\n\nmodule Public_input = struct\n type t = Field.t array\n\n module Constant = struct\n type t = Field.Constant.t array\n end\nend\n\ntype 'a statement = 'a array * 'a array\n\nmodule Statement = struct\n type t = Field.t statement\n\n module Constant = struct\n type t = Field.Constant.t statement\n end\nend\n\nlet public_input_typ (i : int) = Typ.array ~length:i Field.typ\n\nlet statement_typ (input_size : int) (output_size : int) =\n Typ.(array ~length:input_size Field.typ * array ~length:output_size Field.typ)\n\ntype ('prev_proof, 'proof) js_prover =\n Public_input.Constant.t\n -> 'prev_proof array\n -> (Public_input.Constant.t * 'proof) Promise_js_helpers.js_promise\n\nlet dummy_constraints =\n let module Inner_curve = Kimchi_pasta.Pasta.Pallas in\n let module Step_main_inputs = Pickles.Step_main_inputs in\n let inner_curve_typ : (Field.t * Field.t, Inner_curve.t) Typ.t =\n Typ.transport Step_main_inputs.Inner_curve.typ\n ~there:Inner_curve.to_affine_exn ~back:Inner_curve.of_affine\n in\n fun () ->\n let x =\n Impl.exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3)\n in\n let g = Impl.exists inner_curve_typ ~compute:(fun _ -> Inner_curve.one) in\n ignore\n ( Pickles.Scalar_challenge.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore\n ( Step_main_inputs.Ops.scale_fast g ~num_bits:5 (Shifted_value x)\n : Step_main_inputs.Inner_curve.t ) ;\n ignore\n ( Pickles.Step_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t )\n\ntype pickles_rule_js =\n < identifier : Js.js_string Js.t Js.prop\n ; main :\n ( Public_input.t\n -> < publicOutput : Public_input.t Js.prop\n ; previousStatements : Statement.t array Js.prop\n ; shouldVerify : Boolean.var array Js.prop >\n Js.t )\n Js.prop\n ; proofsToVerify :\n < isSelf : bool Js.t Js.prop ; tag : Js.Unsafe.any Js.t Js.prop > Js.t\n array\n Js.prop >\n Js.t\n\nmodule Choices = struct\n open Pickles_types\n open Hlist\n\n module Prevs = struct\n type ('var, 'value, 'width, 'height) t =\n | Prevs :\n ( self:('var, 'value, 'width, 'height) Pickles.Tag.t\n -> ('prev_var, 'prev_values, 'widths, 'heights) H4.T(Pickles.Tag).t\n )\n -> ('var, 'value, 'width, 'height) t\n\n let of_rule (rule : pickles_rule_js) =\n let js_prevs = rule##.proofsToVerify in\n let rec get_tags (Prevs prevs) index =\n if index < 0 then Prevs prevs\n else\n let js_tag = Array.get js_prevs index in\n (* We introduce new opaque types to make sure that the type in the tag\n doesn't escape into the environment or have other ill effects.\n *)\n let module Types = struct\n type var\n\n type value\n\n type width\n\n type height\n end in\n let open Types in\n let to_tag ~self tag : (var, value, width, height) Pickles.Tag.t =\n (* The magic here isn't ideal, but it's safe enough if we immediately\n hide it behind [Types].\n *)\n if Js.to_bool tag##.isSelf then Obj.magic self\n else Obj.magic tag##.tag\n in\n let tag = to_tag js_tag in\n let prevs ~self : _ H4.T(Pickles.Tag).t = tag ~self :: prevs ~self in\n get_tags (Prevs prevs) (index - 1)\n in\n get_tags (Prevs (fun ~self:_ -> [])) (Array.length js_prevs - 1)\n end\n\n module Inductive_rule = struct\n type ( 'var\n , 'value\n , 'width\n , 'height\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n t =\n | Rule :\n ( self:('var, 'value, 'width, 'height) Pickles.Tag.t\n -> ( 'prev_vars\n , 'prev_values\n , 'widths\n , 'heights\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n Pickles.Inductive_rule.t )\n -> ( 'var\n , 'value\n , 'width\n , 'height\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n t\n\n let rec should_verifys :\n type prev_vars prev_values widths heights.\n int\n -> (prev_vars, prev_values, widths, heights) H4.T(Pickles.Tag).t\n -> Boolean.var array\n -> prev_vars H1.T(E01(Pickles.Inductive_rule.B)).t =\n fun index tags should_verifys_js ->\n match tags with\n | [] ->\n []\n | _ :: tags ->\n let js_bool = Array.get should_verifys_js index in\n let should_verifys =\n should_verifys (index + 1) tags should_verifys_js\n in\n js_bool :: should_verifys\n\n let should_verifys tags should_verifys_js =\n should_verifys 0 tags should_verifys_js\n\n let get_typ ~public_input_size ~public_output_size\n (type a1 a2 a3 a4 width height) (tag : (a1, a2, a3, a4) Pickles.Tag.t)\n (self :\n ( Public_input.t * Public_input.t\n , Public_input.Constant.t * Public_input.Constant.t\n , width\n , height )\n Pickles.Tag.t ) =\n match Type_equal.Id.same_witness tag.id self.id with\n | None ->\n Pickles.Types_map.public_input tag\n | Some T ->\n statement_typ public_input_size public_output_size\n\n let rec prev_statements :\n type prev_vars prev_values widths heights width height.\n public_input_size:int\n -> public_output_size:int\n -> self:\n ( Public_input.t * Public_input.t\n , Public_input.Constant.t * Public_input.Constant.t\n , width\n , height )\n Pickles.Tag.t\n -> int\n -> (prev_vars, prev_values, widths, heights) H4.T(Pickles.Tag).t\n -> Statement.t array\n -> prev_vars H1.T(Id).t =\n fun ~public_input_size ~public_output_size ~self i tags statements ->\n match tags with\n | [] ->\n []\n | tag :: tags ->\n let (Typ typ) =\n get_typ ~public_input_size ~public_output_size tag self\n in\n let input, output = Array.get statements i in\n let fields = Array.concat [ input; output ] in\n let aux = typ.constraint_system_auxiliary () in\n let statement = typ.var_of_fields (fields, aux) in\n statement\n :: prev_statements ~public_input_size ~public_output_size ~self\n (i + 1) tags statements\n\n let prev_statements ~public_input_size ~public_output_size ~self tags\n statements =\n prev_statements ~public_input_size ~public_output_size ~self 0 tags\n statements\n\n type _ Snarky_backendless.Request.t +=\n | Get_prev_proof : int -> _ Pickles.Proof.t Snarky_backendless.Request.t\n\n let create ~public_input_size ~public_output_size (rule : pickles_rule_js) :\n ( _\n , _\n , _\n , _\n , Public_input.t\n , Public_input.Constant.t\n , Public_input.t\n , Public_input.Constant.t\n , unit\n , unit )\n t =\n let (Prevs prevs) = Prevs.of_rule rule in\n Rule\n (fun ~(self :\n ( Field.t array * Field.t array\n , Impl.field array * Impl.field array\n , 'b3\n , 'b4 )\n Pickles.Tag.t ) ->\n let prevs = prevs ~self in\n { Pickles.Inductive_rule.identifier = Js.to_string rule##.identifier\n ; feature_flags = Pickles_types.Plonk_types.Features.none_bool\n ; prevs\n ; main =\n (fun { public_input } ->\n dummy_constraints () ;\n let result = rule##.main public_input in\n let public_output = result##.publicOutput in\n let previous_proofs_should_verify =\n should_verifys prevs result##.shouldVerify\n in\n let previous_public_inputs =\n prev_statements ~public_input_size ~public_output_size ~self\n prevs\n result##.previousStatements\n in\n let previous_proof_statements =\n let rec go :\n type prev_vars prev_values widths heights.\n int\n -> prev_vars H1.T(Id).t\n -> prev_vars H1.T(E01(Pickles.Inductive_rule.B)).t\n -> ( prev_vars\n , prev_values\n , widths\n , heights )\n H4.T(Pickles.Tag).t\n -> ( prev_vars\n , widths )\n H2.T(Pickles.Inductive_rule.Previous_proof_statement).t\n =\n fun i public_inputs should_verifys tags ->\n match (public_inputs, should_verifys, tags) with\n | [], [], [] ->\n []\n | ( public_input :: public_inputs\n , proof_must_verify :: should_verifys\n , _tag :: tags ) ->\n let proof =\n Impl.exists (Impl.Typ.Internal.ref ())\n ~request:(fun () -> Get_prev_proof i)\n in\n { public_input; proof; proof_must_verify }\n :: go (i + 1) public_inputs should_verifys tags\n in\n go 0 previous_public_inputs previous_proofs_should_verify\n prevs\n in\n { previous_proof_statements\n ; public_output\n ; auxiliary_output = ()\n } )\n } )\n end\n\n type ( 'var\n , 'value\n , 'width\n , 'height\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n t =\n | Choices :\n ( self:('var, 'value, 'width, 'height) Pickles.Tag.t\n -> ( 'prev_vars\n , 'prev_values\n , 'widths\n , 'heights\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n H4_6.T(Pickles.Inductive_rule).t )\n -> ( 'var\n , 'value\n , 'width\n , 'height\n , 'arg_var\n , 'arg_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n t\n\n let of_js ~public_input_size ~public_output_size js_rules =\n let rec get_rules (Choices rules) index :\n ( _\n , _\n , _\n , _\n , Public_input.t\n , Public_input.Constant.t\n , Public_input.t\n , Public_input.Constant.t\n , unit\n , unit )\n t =\n if index < 0 then Choices rules\n else\n let (Rule rule) =\n Inductive_rule.create ~public_input_size ~public_output_size\n (Array.get js_rules index)\n in\n let rules ~self : _ H4_6.T(Pickles.Inductive_rule).t =\n rule ~self :: rules ~self\n in\n get_rules (Choices rules) (index - 1)\n in\n get_rules (Choices (fun ~self:_ -> [])) (Array.length js_rules - 1)\nend\n\ntype proof = (Pickles_types.Nat.N0.n, Pickles_types.Nat.N0.n) Pickles.Proof.t\n\nmodule Public_inputs_with_proofs =\n Pickles_types.Hlist.H3.T (Pickles.Statement_with_proof)\n\nlet nat_modules_list : (module Pickles_types.Nat.Intf) list =\n let open Pickles_types.Nat in\n [ (module N0)\n ; (module N1)\n ; (module N2)\n ; (module N3)\n ; (module N4)\n ; (module N5)\n ; (module N6)\n ; (module N7)\n ; (module N8)\n ; (module N9)\n ; (module N10)\n ; (module N11)\n ; (module N12)\n ; (module N13)\n ; (module N14)\n ; (module N15)\n ; (module N16)\n ; (module N17)\n ; (module N18)\n ; (module N19)\n ; (module N20)\n ]\n\nlet nat_add_modules_list : (module Pickles_types.Nat.Add.Intf) list =\n let open Pickles_types.Nat in\n [ (module N0)\n ; (module N1)\n ; (module N2)\n ; (module N3)\n ; (module N4)\n ; (module N5)\n ; (module N6)\n ; (module N7)\n ; (module N8)\n ; (module N9)\n ; (module N10)\n ; (module N11)\n ; (module N12)\n ; (module N13)\n ; (module N14)\n ; (module N15)\n ; (module N16)\n ; (module N17)\n ; (module N18)\n ; (module N19)\n ; (module N20)\n ]\n\nlet nat_module (i : int) : (module Pickles_types.Nat.Intf) =\n List.nth_exn nat_modules_list i\n\nlet nat_add_module (i : int) : (module Pickles_types.Nat.Add.Intf) =\n List.nth_exn nat_add_modules_list i\n\nlet name = \"smart-contract\"\n\nlet constraint_constants =\n (* TODO these are dummy values *)\n { Snark_keys_header.Constraint_constants.sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n\nlet pickles_compile (choices : pickles_rule_js array)\n (signature :\n < publicInputSize : int Js.prop\n ; publicOutputSize : int Js.prop\n ; overrideWrapDomain : int Js.optdef_prop >\n Js.t ) =\n (* translate number of branches and recursively verified proofs from JS *)\n let branches = Array.length choices in\n let max_proofs =\n let choices = choices |> Array.to_list in\n List.map choices ~f:(fun c -> c##.proofsToVerify |> Array.length)\n |> List.max_elt ~compare |> Option.value ~default:0\n in\n let (module Branches) = nat_module branches in\n let (module Max_proofs_verified) = nat_add_module max_proofs in\n\n (* translate method circuits from JS *)\n let public_input_size = signature##.publicInputSize in\n let public_output_size = signature##.publicOutputSize in\n let override_wrap_domain =\n Js.Optdef.to_option signature##.overrideWrapDomain\n |> Option.map ~f:Pickles_base.Proofs_verified.of_int\n in\n let (Choices choices) =\n Choices.of_js ~public_input_size ~public_output_size choices\n in\n\n (* call into Pickles *)\n let tag, _cache, p, provers =\n Pickles.compile_promise () ?override_wrap_domain ~choices\n ~public_input:\n (Input_and_output\n ( public_input_typ public_input_size\n , public_input_typ public_output_size ) )\n ~auxiliary_typ:Typ.unit\n ~branches:(module Branches)\n ~max_proofs_verified:(module Max_proofs_verified)\n ~name ~constraint_constants\n in\n\n (* translate returned prover and verify functions to JS *)\n let module Proof = (val p) in\n let to_js_prover prover : ('prev_proof, Proof.t) js_prover =\n let prove (public_input : Public_input.Constant.t)\n (prevs : 'prev_proof array) =\n let handler (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Choices.Inductive_rule.Get_prev_proof i ->\n respond (Provide (Obj.magic (Array.get prevs i)))\n | _ ->\n respond Unhandled\n in\n prover ?handler:(Some handler) public_input\n |> Promise.map ~f:(fun (output, _, proof) -> (output, proof))\n |> Promise_js_helpers.to_js\n in\n prove\n in\n let rec to_js_provers :\n type a b c.\n ( a\n , b\n , c\n , Public_input.Constant.t\n , (Public_input.Constant.t * unit * Proof.t) Promise.t )\n Pickles.Provers.t\n -> ('prev_proof, Proof.t) js_prover list = function\n | [] ->\n []\n | p :: ps ->\n to_js_prover p :: to_js_provers ps\n in\n let provers : (_, Proof.t) js_prover array =\n provers |> to_js_provers |> Array.of_list\n in\n let verify (statement : Statement.Constant.t) (proof : _ Pickles.Proof.t) =\n Proof.verify_promise [ (statement, proof) ]\n |> Promise.map ~f:(fun x -> Js.bool (Or_error.is_ok x))\n |> Promise_js_helpers.to_js\n in\n object%js\n val provers = Obj.magic provers\n\n val verify = Obj.magic verify\n\n val tag = Obj.magic tag\n\n method getVerificationKey =\n let vk = Pickles.Side_loaded.Verification_key.of_compiled tag in\n let data = Pickles.Side_loaded.Verification_key.to_base64 vk in\n let hash = Mina_base.Zkapp_account.digest_vk vk in\n (data |> Js.string, hash)\n end\n\nmodule Proof0 = Pickles.Proof.Make (Pickles_types.Nat.N0) (Pickles_types.Nat.N0)\nmodule Proof1 = Pickles.Proof.Make (Pickles_types.Nat.N1) (Pickles_types.Nat.N1)\nmodule Proof2 = Pickles.Proof.Make (Pickles_types.Nat.N2) (Pickles_types.Nat.N2)\n\ntype some_proof = Proof0 of Proof0.t | Proof1 of Proof1.t | Proof2 of Proof2.t\n\nlet proof_to_base64 = function\n | Proof0 proof ->\n Proof0.to_base64 proof |> Js.string\n | Proof1 proof ->\n Proof1.to_base64 proof |> Js.string\n | Proof2 proof ->\n Proof2.to_base64 proof |> Js.string\n\nlet proof_of_base64 str i : some_proof =\n let str = Js.to_string str in\n match i with\n | 0 ->\n Proof0 (Proof0.of_base64 str |> Result.ok_or_failwith)\n | 1 ->\n Proof1 (Proof1.of_base64 str |> Result.ok_or_failwith)\n | 2 ->\n Proof2 (Proof2.of_base64 str |> Result.ok_or_failwith)\n | _ ->\n failwith \"invalid proof index\"\n\nlet verify (statement : Statement.Constant.t) (proof : proof)\n (vk : Js.js_string Js.t) =\n let i, o = statement in\n let typ = statement_typ (Array.length i) (Array.length o) in\n let proof = Pickles.Side_loaded.Proof.of_proof proof in\n let vk =\n match Pickles.Side_loaded.Verification_key.of_base64 (Js.to_string vk) with\n | Ok vk_ ->\n vk_\n | Error err ->\n failwithf \"Could not decode base64 verification key: %s\"\n (Error.to_string_hum err) ()\n in\n Pickles.Side_loaded.verify_promise ~typ [ (vk, statement, proof) ]\n |> Promise.map ~f:(fun x -> Js.bool (Or_error.is_ok x))\n |> Promise_js_helpers.to_js\n\nlet dummy_base64_proof () =\n let n2 = Pickles_types.Nat.N2.n in\n let proof = Pickles.Proof.dummy n2 n2 n2 ~domain_log2:15 in\n Proof2.to_base64 proof |> Js.string\n\nlet dummy_verification_key () =\n let vk = Pickles.Side_loaded.Verification_key.dummy in\n let data = Pickles.Side_loaded.Verification_key.to_base64 vk in\n let hash = Mina_base.Zkapp_account.digest_vk vk in\n (data |> Js.string, hash)\n\nlet pickles =\n object%js\n val compile = pickles_compile\n\n val verify = verify\n\n val dummyBase64Proof = dummy_base64_proof\n\n val dummyVerificationKey = dummy_verification_key\n\n val proofToBase64 = proof_to_base64\n\n val proofOfBase64 = proof_of_base64\n\n val proofToBase64Transaction =\n fun (proof : proof) ->\n proof |> Pickles.Side_loaded.Proof.of_proof\n |> Pickles.Side_loaded.Proof.to_base64 |> Js.string\n end\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Benoit Vaugon, ENSTA *)\n(* *)\n(* Copyright 2014 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Padding position. *)\ntype padty =\n | Left (* Text is left justified ('-' option). *)\n | Right (* Text is right justified (no '-' option). *)\n | Zeros (* Text is right justified by zeros (see '0' option). *)\n\n(***)\n\n(* Integer conversion. *)\ntype int_conv =\n | Int_d | Int_pd | Int_sd (* %d | %+d | % d *)\n | Int_i | Int_pi | Int_si (* %i | %+i | % i *)\n | Int_x | Int_Cx (* %x | %#x *)\n | Int_X | Int_CX (* %X | %#X *)\n | Int_o | Int_Co (* %o | %#o *)\n | Int_u (* %u *)\n | Int_Cd | Int_Ci | Int_Cu (* %#d | %#i | %#u *)\n\n(* Float conversion. *)\ntype float_flag_conv =\n | Float_flag_ (* %[feEgGFhH] *)\n | Float_flag_p (* %+[feEgGFhH] *)\n | Float_flag_s (* % [feEgGFhH] *)\ntype float_kind_conv =\n | Float_f (* %f | %+f | % f *)\n | Float_e (* %e | %+e | % e *)\n | Float_E (* %E | %+E | % E *)\n | Float_g (* %g | %+g | % g *)\n | Float_G (* %G | %+G | % G *)\n | Float_F (* %F | %+F | % F *)\n | Float_h (* %h | %+h | % h *)\n | Float_H (* %H | %+H | % H *)\n | Float_CF (* %#F| %+#F| % #F *)\ntype float_conv = float_flag_conv * float_kind_conv\n\n(***)\n\n(* Char sets (see %[...]) are bitmaps implemented as 32-char strings. *)\ntype char_set = string\n\n(***)\n\n(* Counter used in Scanf. *)\ntype counter =\n | Line_counter (* %l *)\n | Char_counter (* %n *)\n | Token_counter (* %N, %L *)\n\n(***)\n\n(* Padding of strings and numbers. *)\ntype ('a, 'b) padding =\n (* No padding (ex: \"%d\") *)\n | No_padding : ('a, 'a) padding\n (* Literal padding (ex: \"%8d\") *)\n | Lit_padding : padty * int -> ('a, 'a) padding\n (* Padding as extra argument (ex: \"%*d\") *)\n | Arg_padding : padty -> (int -> 'a, 'a) padding\n\n(* Some formats, such as %_d,\n only accept an optional number as padding option (no extra argument) *)\ntype pad_option = int option\n\n(* Precision of floats and '0'-padding of integers. *)\ntype ('a, 'b) precision =\n (* No precision (ex: \"%f\") *)\n | No_precision : ('a, 'a) precision\n (* Literal precision (ex: \"%.3f\") *)\n | Lit_precision : int -> ('a, 'a) precision\n (* Precision as extra argument (ex: \"%.*f\") *)\n | Arg_precision : (int -> 'a, 'a) precision\n\n(* Some formats, such as %_f,\n only accept an optional number as precision option (no extra argument) *)\ntype prec_option = int option\n\n(* see the Custom format combinator *)\ntype ('a, 'b, 'c) custom_arity =\n | Custom_zero : ('a, string, 'a) custom_arity\n | Custom_succ : ('a, 'b, 'c) custom_arity ->\n ('a, 'x -> 'b, 'x -> 'c) custom_arity\n\n(***)\n\n(* Relational format types\n\nIn the first format+gadts implementation, the type for %(..%) in the\nfmt GADT was as follows:\n\n| Format_subst : (* %(...%) *)\n pad_option * ('d1, 'q1, 'd2, 'q2) reader_nb_unifier *\n ('x, 'b, 'c, 'd1, 'q1, 'u) fmtty *\n ('u, 'b, 'c, 'q1, 'e1, 'f) fmt ->\n (('x, 'b, 'c, 'd2, 'q2, 'u) format6 -> 'x, 'b, 'c, 'd1, 'e1, 'f) fmt\n\nNotice that the 'u parameter in 'f position in the format argument\n(('x, .., 'u) format6 -> ..) is equal to the 'u parameter in 'a\nposition in the format tail (('u, .., 'f) fmt). This means that the\ntype of the expected format parameter depends of where the %(...%)\nare in the format string:\n\n # Printf.printf \"%(%)\"\n - : (unit, out_channel, unit, '_a, '_a, unit)\n CamlinternalFormatBasics.format6 -> unit\n = \n # Printf.printf \"%(%)%d\"\n - : (int -> unit, out_channel, unit, '_a, '_a, int -> unit)\n CamlinternalFormatBasics.format6 -> int -> unit\n = \n\nOn the contrary, the legacy typer gives a clever type that does not\ndepend on the position of %(..%) in the format string. For example,\n%(%) will have the polymorphic type ('a, 'b, 'c, 'd, 'd, 'a): it can\nbe concatenated to any format type, and only enforces the constraint\nthat its 'a and 'f parameters are equal (no format arguments) and 'd\nand 'e are equal (no reader argument).\n\nThe weakening of this parameter type in the GADT version broke user\ncode (in fact it essentially made %(...%) unusable except at the last\nposition of a format). In particular, the following would not work\nanymore:\n\n fun sep ->\n Format.printf \"foo%(%)bar%(%)baz\" sep sep\n\nAs the type-checker would require two *incompatible* types for the %(%)\nin different positions.\n\nThe solution to regain a general type for %(..%) is to generalize this\ntechnique, not only on the 'd, 'e parameters, but on all six\nparameters of a format: we introduce a \"relational\" type\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\nwhose values are proofs that ('a1, .., 'f1) and ('a2, .., 'f2) morally\ncorrespond to the same format type: 'a1 is obtained from 'f1,'b1,'c1\nin the exact same way that 'a2 is obtained from 'f2,'b2,'c2, etc.\n\nFor example, the relation between two format types beginning with a Char\nparameter is as follows:\n\n| Char_ty : (* %c *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (char -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n char -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n\nIn the general case, the term structure of fmtty_rel is (almost[1])\nisomorphic to the fmtty of the previous implementation: every\nconstructor is re-read with a binary, relational type, instead of the\nprevious unary typing. fmtty can then be re-defined as the diagonal of\nfmtty_rel:\n\n type ('a, 'b, 'c, 'd, 'e, 'f) fmtty =\n ('a, 'b, 'c, 'd, 'e, 'f,\n 'a, 'b, 'c, 'd, 'e, 'f) fmtty_rel\n\nOnce we have this fmtty_rel type in place, we can give the more\ngeneral type to %(...%):\n\n| Format_subst : (* %(...%) *)\n pad_option *\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g2, 'b, 'c, 'j2, 'd, 'a) fmtty_rel *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b, 'c, 'j2, 'e, 'f) fmt\n\nWe accept any format (('g, 'h, 'i, 'j, 'k, 'l) format6) (this is\ncompletely unrelated to the type of the current format), but also\nrequire a proof that this format is in relation to another format that\nis concatenable to the format tail. When executing a %(...%) format\n(in camlinternalFormat.ml:make_printf or scanf.ml:make_scanf), we\ntranstype the format along this relation using the 'recast' function\nto transpose between related format types.\n\n val recast :\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1) fmt\n -> ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n -> ('a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmt\n\nNOTE [1]: the typing of Format_subst_ty requires not one format type, but\ntwo, one to establish the link between the format argument and the\nfirst six parameters, and the other for the link between the format\nargument and the last six parameters.\n\n| Format_subst_ty : (* %(...%) *)\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g1, 'b1, 'c1, 'j1, 'd1, 'a1) fmtty_rel *\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g2, 'b2, 'c2, 'j2, 'd2, 'a2) fmtty_rel *\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g1, 'b1, 'c1, 'j1, 'e1, 'f1,\n ('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b2, 'c2, 'j2, 'e2, 'f2) fmtty_rel\n\nWhen we generate a format AST, we generate exactly the same witness\nfor both relations, and the witness-conversion functions in\ncamlinternalFormat do rely on this invariant. For example, the\nfunction that proves that the relation is transitive\n\n val trans :\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n -> ('a2, 'b2, 'c2, 'd2, 'e2, 'f2,\n 'a3, 'b3, 'c3, 'd3, 'e3, 'f3) fmtty_rel\n -> ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a3, 'b3, 'c3, 'd3, 'e3, 'f3) fmtty_rel\n\ndoes assume that the two inputs have exactly the same term structure\n(and is only every used for argument witnesses of the\nFormat_subst_ty constructor).\n*)\n\n(* Type of a block used by the Format pretty-printer. *)\ntype block_type =\n | Pp_hbox (* Horizontal block no line breaking *)\n | Pp_vbox (* Vertical block each break leads to a new line *)\n | Pp_hvbox (* Horizontal-vertical block: same as vbox, except if this block\n is small enough to fit on a single line *)\n | Pp_hovbox (* Horizontal or Vertical block: breaks lead to new line\n only when necessary to print the content of the block *)\n | Pp_box (* Horizontal or Indent block: breaks lead to new line\n only when necessary to print the content of the block, or\n when it leads to a new indentation of the current line *)\n | Pp_fits (* Internal usage: when a block fits on a single line *)\n\n(* Formatting element used by the Format pretty-printer. *)\ntype formatting_lit =\n | Close_box (* @] *)\n | Close_tag (* @} *)\n | Break of string * int * int (* @, | @ | @; | @;<> *)\n | FFlush (* @? *)\n | Force_newline (* @\\n *)\n | Flush_newline (* @. *)\n | Magic_size of string * int (* @ *)\n | Escaped_at (* @@ *)\n | Escaped_percent (* @%% *)\n | Scan_indic of char (* @X *)\n\n(* Formatting element used by the Format pretty-printer. *)\ntype ('a, 'b, 'c, 'd, 'e, 'f) formatting_gen =\n | Open_tag : ('a, 'b, 'c, 'd, 'e, 'f) format6 -> (* @{ *)\n ('a, 'b, 'c, 'd, 'e, 'f) formatting_gen\n | Open_box : ('a, 'b, 'c, 'd, 'e, 'f) format6 -> (* @[ *)\n ('a, 'b, 'c, 'd, 'e, 'f) formatting_gen\n\n(***)\n\n(* List of format type elements. *)\n(* In particular used to represent %(...%) and %{...%} contents. *)\nand ('a, 'b, 'c, 'd, 'e, 'f) fmtty =\n ('a, 'b, 'c, 'd, 'e, 'f,\n 'a, 'b, 'c, 'd, 'e, 'f) fmtty_rel\nand ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel =\n | Char_ty : (* %c *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (char -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n char -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | String_ty : (* %s *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (string -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n string -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Int_ty : (* %d *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (int -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n int -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Int32_ty : (* %ld *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (int32 -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n int32 -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Nativeint_ty : (* %nd *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (nativeint -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n nativeint -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Int64_ty : (* %Ld *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (int64 -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n int64 -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Float_ty : (* %f *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (float -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n float -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Bool_ty : (* %B *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (bool -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n bool -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n\n | Format_arg_ty : (* %{...%} *)\n ('g, 'h, 'i, 'j, 'k, 'l) fmtty *\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n ('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2)\n fmtty_rel\n | Format_subst_ty : (* %(...%) *)\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g1, 'b1, 'c1, 'j1, 'd1, 'a1) fmtty_rel *\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g2, 'b2, 'c2, 'j2, 'd2, 'a2) fmtty_rel *\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g1, 'b1, 'c1, 'j1, 'e1, 'f1,\n ('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b2, 'c2, 'j2, 'e2, 'f2)\n fmtty_rel\n\n (* Printf and Format specific constructors. *)\n | Alpha_ty : (* %a *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (('b1 -> 'x -> 'c1) -> 'x -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n ('b2 -> 'x -> 'c2) -> 'x -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Theta_ty : (* %t *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n (('b1 -> 'c1) -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n ('b2 -> 'c2) -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n | Any_ty : (* Used for custom formats *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n ('x -> 'a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'x -> 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel\n\n (* Scanf specific constructor. *)\n | Reader_ty : (* %r *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n ('x -> 'a1, 'b1, 'c1, ('b1 -> 'x) -> 'd1, 'e1, 'f1,\n 'x -> 'a2, 'b2, 'c2, ('b2 -> 'x) -> 'd2, 'e2, 'f2) fmtty_rel\n | Ignored_reader_ty : (* %_r *)\n ('a1, 'b1, 'c1, 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, 'd2, 'e2, 'f2) fmtty_rel ->\n ('a1, 'b1, 'c1, ('b1 -> 'x) -> 'd1, 'e1, 'f1,\n 'a2, 'b2, 'c2, ('b2 -> 'x) -> 'd2, 'e2, 'f2) fmtty_rel\n\n | End_of_fmtty :\n ('f1, 'b1, 'c1, 'd1, 'd1, 'f1,\n 'f2, 'b2, 'c2, 'd2, 'd2, 'f2) fmtty_rel\n\n(***)\n\n(* List of format elements. *)\nand ('a, 'b, 'c, 'd, 'e, 'f) fmt =\n | Char : (* %c *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (char -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Caml_char : (* %C *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (char -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | String : (* %s *)\n ('x, string -> 'a) padding * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Caml_string : (* %S *)\n ('x, string -> 'a) padding * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Int : (* %[dixXuo] *)\n int_conv * ('x, 'y) padding * ('y, int -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Int32 : (* %l[dixXuo] *)\n int_conv * ('x, 'y) padding * ('y, int32 -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Nativeint : (* %n[dixXuo] *)\n int_conv * ('x, 'y) padding * ('y, nativeint -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Int64 : (* %L[dixXuo] *)\n int_conv * ('x, 'y) padding * ('y, int64 -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Float : (* %[feEgGFhH] *)\n float_conv * ('x, 'y) padding * ('y, float -> 'a) precision *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Bool : (* %[bB] *)\n ('x, bool -> 'a) padding * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x, 'b, 'c, 'd, 'e, 'f) fmt\n | Flush : (* %! *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt\n\n | String_literal : (* abc *)\n string * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt\n | Char_literal : (* x *)\n char * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt\n\n | Format_arg : (* %{...%} *)\n pad_option * ('g, 'h, 'i, 'j, 'k, 'l) fmtty *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Format_subst : (* %(...%) *)\n pad_option *\n ('g, 'h, 'i, 'j, 'k, 'l,\n 'g2, 'b, 'c, 'j2, 'd, 'a) fmtty_rel *\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (('g, 'h, 'i, 'j, 'k, 'l) format6 -> 'g2, 'b, 'c, 'j2, 'e, 'f) fmt\n\n (* Printf and Format specific constructor. *)\n | Alpha : (* %a *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (('b -> 'x -> 'c) -> 'x -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Theta : (* %t *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (('b -> 'c) -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n\n (* Format specific constructor: *)\n | Formatting_lit : (* @_ *)\n formatting_lit * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt\n | Formatting_gen : (* @_ *)\n ('a1, 'b, 'c, 'd1, 'e1, 'f1) formatting_gen *\n ('f1, 'b, 'c, 'e1, 'e2, 'f2) fmt -> ('a1, 'b, 'c, 'd1, 'e2, 'f2) fmt\n\n (* Scanf specific constructors: *)\n | Reader : (* %r *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('x -> 'a, 'b, 'c, ('b -> 'x) -> 'd, 'e, 'f) fmt\n | Scan_char_set : (* %[...] *)\n pad_option * char_set * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (string -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Scan_get_counter : (* %[nlNL] *)\n counter * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (int -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Scan_next_char : (* %0c *)\n ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n (char -> 'a, 'b, 'c, 'd, 'e, 'f) fmt\n | Ignored_param : (* %_ *)\n ('a, 'b, 'c, 'd, 'y, 'x) ignored * ('x, 'b, 'c, 'y, 'e, 'f) fmt ->\n ('a, 'b, 'c, 'd, 'e, 'f) fmt\n\n (* Custom printing format (PR#6452, GPR#140)\n\n We include a type Custom of \"custom converters\", where an\n arbitrary function can be used to convert one or more\n arguments. There is no syntax for custom converters, it is only\n intended for custom processors that wish to rely on the\n stdlib-defined format GADTs.\n\n For instance a pre-processor could choose to interpret strings\n prefixed with [\"!\"] as format strings where [%{{ ... }}] is\n a special form to pass a to_string function, so that one could\n write:\n\n {[\n type t = { x : int; y : int }\n\n let string_of_t t = Printf.sprintf \"{ x = %d; y = %d }\" t.x t.y\n\n Printf.printf !\"t = %{{string_of_t}}\" { x = 42; y = 42 }\n ]}\n *)\n | Custom :\n ('a, 'x, 'y) custom_arity * (unit -> 'x) * ('a, 'b, 'c, 'd, 'e, 'f) fmt ->\n ('y, 'b, 'c, 'd, 'e, 'f) fmt\n\n (* end of a format specification *)\n | End_of_format :\n ('f, 'b, 'c, 'e, 'e, 'f) fmt\n\n(***)\n\n(* Type for ignored parameters (see \"%_\"). *)\nand ('a, 'b, 'c, 'd, 'e, 'f) ignored =\n | Ignored_char : (* %_c *)\n ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_caml_char : (* %_C *)\n ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_string : (* %_s *)\n pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_caml_string : (* %_S *)\n pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_int : (* %_d *)\n int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_int32 : (* %_ld *)\n int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_nativeint : (* %_nd *)\n int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_int64 : (* %_Ld *)\n int_conv * pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_float : (* %_f *)\n pad_option * prec_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_bool : (* %_B *)\n pad_option -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_format_arg : (* %_{...%} *)\n pad_option * ('g, 'h, 'i, 'j, 'k, 'l) fmtty ->\n ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_format_subst : (* %_(...%) *)\n pad_option * ('a, 'b, 'c, 'd, 'e, 'f) fmtty ->\n ('a, 'b, 'c, 'd, 'e, 'f) ignored\n | Ignored_reader : (* %_r *)\n ('a, 'b, 'c, ('b -> 'x) -> 'd, 'd, 'a) ignored\n | Ignored_scan_char_set : (* %_[...] *)\n pad_option * char_set -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_scan_get_counter : (* %_[nlNL] *)\n counter -> ('a, 'b, 'c, 'd, 'd, 'a) ignored\n | Ignored_scan_next_char : (* %_0c *)\n ('a, 'b, 'c, 'd, 'd, 'a) ignored\n\nand ('a, 'b, 'c, 'd, 'e, 'f) format6 =\n Format of ('a, 'b, 'c, 'd, 'e, 'f) fmt * string\n\nlet rec erase_rel : type a b c d e f g h i j k l .\n (a, b, c, d, e, f,\n g, h, i, j, k, l) fmtty_rel -> (a, b, c, d, e, f) fmtty\n= function\n | Char_ty rest ->\n Char_ty (erase_rel rest)\n | String_ty rest ->\n String_ty (erase_rel rest)\n | Int_ty rest ->\n Int_ty (erase_rel rest)\n | Int32_ty rest ->\n Int32_ty (erase_rel rest)\n | Int64_ty rest ->\n Int64_ty (erase_rel rest)\n | Nativeint_ty rest ->\n Nativeint_ty (erase_rel rest)\n | Float_ty rest ->\n Float_ty (erase_rel rest)\n | Bool_ty rest ->\n Bool_ty (erase_rel rest)\n | Format_arg_ty (ty, rest) ->\n Format_arg_ty (ty, erase_rel rest)\n | Format_subst_ty (ty1, _ty2, rest) ->\n Format_subst_ty (ty1, ty1, erase_rel rest)\n | Alpha_ty rest ->\n Alpha_ty (erase_rel rest)\n | Theta_ty rest ->\n Theta_ty (erase_rel rest)\n | Any_ty rest ->\n Any_ty (erase_rel rest)\n | Reader_ty rest ->\n Reader_ty (erase_rel rest)\n | Ignored_reader_ty rest ->\n Ignored_reader_ty (erase_rel rest)\n | End_of_fmtty -> End_of_fmtty\n\n(******************************************************************************)\n (* Format type concatenation *)\n\n(* Concatenate two format types. *)\n(* Used by:\n * reader_nb_unifier_of_fmtty to count readers in an fmtty,\n * Scanf.take_fmtty_format_readers to extract readers inside %(...%),\n * CamlinternalFormat.fmtty_of_ignored_format to extract format type. *)\n\n(*\nlet rec concat_fmtty : type a b c d e f g h .\n (a, b, c, d, e, f) fmtty ->\n (f, b, c, e, g, h) fmtty ->\n (a, b, c, d, g, h) fmtty =\n*)\nlet rec concat_fmtty :\n type a1 b1 c1 d1 e1 f1\n a2 b2 c2 d2 e2 f2\n g1 j1 g2 j2\n .\n (g1, b1, c1, j1, d1, a1,\n g2, b2, c2, j2, d2, a2) fmtty_rel ->\n (a1, b1, c1, d1, e1, f1,\n a2, b2, c2, d2, e2, f2) fmtty_rel ->\n (g1, b1, c1, j1, e1, f1,\n g2, b2, c2, j2, e2, f2) fmtty_rel =\nfun fmtty1 fmtty2 -> match fmtty1 with\n | Char_ty rest ->\n Char_ty (concat_fmtty rest fmtty2)\n | String_ty rest ->\n String_ty (concat_fmtty rest fmtty2)\n | Int_ty rest ->\n Int_ty (concat_fmtty rest fmtty2)\n | Int32_ty rest ->\n Int32_ty (concat_fmtty rest fmtty2)\n | Nativeint_ty rest ->\n Nativeint_ty (concat_fmtty rest fmtty2)\n | Int64_ty rest ->\n Int64_ty (concat_fmtty rest fmtty2)\n | Float_ty rest ->\n Float_ty (concat_fmtty rest fmtty2)\n | Bool_ty rest ->\n Bool_ty (concat_fmtty rest fmtty2)\n | Alpha_ty rest ->\n Alpha_ty (concat_fmtty rest fmtty2)\n | Theta_ty rest ->\n Theta_ty (concat_fmtty rest fmtty2)\n | Any_ty rest ->\n Any_ty (concat_fmtty rest fmtty2)\n | Reader_ty rest ->\n Reader_ty (concat_fmtty rest fmtty2)\n | Ignored_reader_ty rest ->\n Ignored_reader_ty (concat_fmtty rest fmtty2)\n | Format_arg_ty (ty, rest) ->\n Format_arg_ty (ty, concat_fmtty rest fmtty2)\n | Format_subst_ty (ty1, ty2, rest) ->\n Format_subst_ty (ty1, ty2, concat_fmtty rest fmtty2)\n | End_of_fmtty -> fmtty2\n\n(******************************************************************************)\n (* Format concatenation *)\n\n(* Concatenate two formats. *)\nlet rec concat_fmt : type a b c d e f g h .\n (a, b, c, d, e, f) fmt ->\n (f, b, c, e, g, h) fmt ->\n (a, b, c, d, g, h) fmt =\nfun fmt1 fmt2 -> match fmt1 with\n | String (pad, rest) ->\n String (pad, concat_fmt rest fmt2)\n | Caml_string (pad, rest) ->\n Caml_string (pad, concat_fmt rest fmt2)\n\n | Int (iconv, pad, prec, rest) ->\n Int (iconv, pad, prec, concat_fmt rest fmt2)\n | Int32 (iconv, pad, prec, rest) ->\n Int32 (iconv, pad, prec, concat_fmt rest fmt2)\n | Nativeint (iconv, pad, prec, rest) ->\n Nativeint (iconv, pad, prec, concat_fmt rest fmt2)\n | Int64 (iconv, pad, prec, rest) ->\n Int64 (iconv, pad, prec, concat_fmt rest fmt2)\n | Float (fconv, pad, prec, rest) ->\n Float (fconv, pad, prec, concat_fmt rest fmt2)\n\n | Char (rest) ->\n Char (concat_fmt rest fmt2)\n | Caml_char rest ->\n Caml_char (concat_fmt rest fmt2)\n | Bool (pad, rest) ->\n Bool (pad, concat_fmt rest fmt2)\n | Alpha rest ->\n Alpha (concat_fmt rest fmt2)\n | Theta rest ->\n Theta (concat_fmt rest fmt2)\n | Custom (arity, f, rest) ->\n Custom (arity, f, concat_fmt rest fmt2)\n | Reader rest ->\n Reader (concat_fmt rest fmt2)\n | Flush rest ->\n Flush (concat_fmt rest fmt2)\n\n | String_literal (str, rest) ->\n String_literal (str, concat_fmt rest fmt2)\n | Char_literal (chr, rest) ->\n Char_literal (chr, concat_fmt rest fmt2)\n\n | Format_arg (pad, fmtty, rest) ->\n Format_arg (pad, fmtty, concat_fmt rest fmt2)\n | Format_subst (pad, fmtty, rest) ->\n Format_subst (pad, fmtty, concat_fmt rest fmt2)\n\n | Scan_char_set (width_opt, char_set, rest) ->\n Scan_char_set (width_opt, char_set, concat_fmt rest fmt2)\n | Scan_get_counter (counter, rest) ->\n Scan_get_counter (counter, concat_fmt rest fmt2)\n | Scan_next_char (rest) ->\n Scan_next_char (concat_fmt rest fmt2)\n | Ignored_param (ign, rest) ->\n Ignored_param (ign, concat_fmt rest fmt2)\n\n | Formatting_lit (fmting_lit, rest) ->\n Formatting_lit (fmting_lit, concat_fmt rest fmt2)\n | Formatting_gen (fmting_gen, rest) ->\n Formatting_gen (fmting_gen, concat_fmt rest fmt2)\n\n | End_of_format ->\n fmt2\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Gabriel Scherer, projet Partout, INRIA Paris-Saclay *)\n(* *)\n(* Copyright 2020 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* CamlinternalAtomic is a dependency of Stdlib, so it is compiled with\n -nopervasives. *)\nexternal ( == ) : 'a -> 'a -> bool = \"%eq\"\nexternal ( + ) : int -> int -> int = \"%addint\"\nexternal ignore : 'a -> unit = \"%ignore\"\n\n(* We are not reusing ('a ref) directly to make it easier to reason\n about atomicity if we wish to: even in a sequential implementation,\n signals and other asynchronous callbacks might break atomicity. *)\ntype 'a t = {mutable v: 'a}\n\nlet make v = {v}\nlet get r = r.v\nlet set r v = r.v <- v\n\n(* The following functions are set to never be inlined: Flambda is\n allowed to move surrounding code inside the critical section,\n including allocations. *)\n\nlet[@inline never] exchange r v =\n (* BEGIN ATOMIC *)\n let cur = r.v in\n r.v <- v;\n (* END ATOMIC *)\n cur\n\nlet[@inline never] compare_and_set r seen v =\n (* BEGIN ATOMIC *)\n let cur = r.v in\n if cur == seen then (\n r.v <- v;\n (* END ATOMIC *)\n true\n ) else\n false\n\nlet[@inline never] fetch_and_add r n =\n (* BEGIN ATOMIC *)\n let cur = r.v in\n r.v <- (cur + n);\n (* END ATOMIC *)\n cur\n\nlet incr r = ignore (fetch_and_add r 1)\nlet decr r = ignore (fetch_and_add r (-1))\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Exceptions *)\n\nexternal register_named_value : string -> 'a -> unit\n = \"caml_register_named_value\"\n\nlet () =\n (* for runtime/fail_nat.c *)\n register_named_value \"Pervasives.array_bound_error\"\n (Invalid_argument \"index out of bounds\")\n\nexternal raise : exn -> 'a = \"%raise\"\nexternal raise_notrace : exn -> 'a = \"%raise_notrace\"\n\nlet failwith s = raise(Failure s)\nlet invalid_arg s = raise(Invalid_argument s)\n\nexception Exit\nexception Match_failure = Match_failure\nexception Assert_failure = Assert_failure\nexception Invalid_argument = Invalid_argument\nexception Failure = Failure\nexception Not_found = Not_found\nexception Out_of_memory = Out_of_memory\nexception Stack_overflow = Stack_overflow\nexception Sys_error = Sys_error\nexception End_of_file = End_of_file\nexception Division_by_zero = Division_by_zero\nexception Sys_blocked_io = Sys_blocked_io\nexception Undefined_recursive_module = Undefined_recursive_module\n\n(* Composition operators *)\n\nexternal ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\nexternal ( @@ ) : ('a -> 'b) -> 'a -> 'b = \"%apply\"\n\n(* Debugging *)\n\nexternal __LOC__ : string = \"%loc_LOC\"\nexternal __FILE__ : string = \"%loc_FILE\"\nexternal __LINE__ : int = \"%loc_LINE\"\nexternal __MODULE__ : string = \"%loc_MODULE\"\nexternal __POS__ : string * int * int * int = \"%loc_POS\"\nexternal __FUNCTION__ : string = \"%loc_FUNCTION\"\n\nexternal __LOC_OF__ : 'a -> string * 'a = \"%loc_LOC\"\nexternal __LINE_OF__ : 'a -> int * 'a = \"%loc_LINE\"\nexternal __POS_OF__ : 'a -> (string * int * int * int) * 'a = \"%loc_POS\"\n\n(* Comparisons *)\n\nexternal ( = ) : 'a -> 'a -> bool = \"%equal\"\nexternal ( <> ) : 'a -> 'a -> bool = \"%notequal\"\nexternal ( < ) : 'a -> 'a -> bool = \"%lessthan\"\nexternal ( > ) : 'a -> 'a -> bool = \"%greaterthan\"\nexternal ( <= ) : 'a -> 'a -> bool = \"%lessequal\"\nexternal ( >= ) : 'a -> 'a -> bool = \"%greaterequal\"\nexternal compare : 'a -> 'a -> int = \"%compare\"\n\nlet min x y = if x <= y then x else y\nlet max x y = if x >= y then x else y\n\nexternal ( == ) : 'a -> 'a -> bool = \"%eq\"\nexternal ( != ) : 'a -> 'a -> bool = \"%noteq\"\n\n(* Boolean operations *)\n\nexternal not : bool -> bool = \"%boolnot\"\nexternal ( & ) : bool -> bool -> bool = \"%sequand\"\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\nexternal ( or ) : bool -> bool -> bool = \"%sequor\"\nexternal ( || ) : bool -> bool -> bool = \"%sequor\"\n\n(* Integer operations *)\n\nexternal ( ~- ) : int -> int = \"%negint\"\nexternal ( ~+ ) : int -> int = \"%identity\"\nexternal succ : int -> int = \"%succint\"\nexternal pred : int -> int = \"%predint\"\nexternal ( + ) : int -> int -> int = \"%addint\"\nexternal ( - ) : int -> int -> int = \"%subint\"\nexternal ( * ) : int -> int -> int = \"%mulint\"\nexternal ( / ) : int -> int -> int = \"%divint\"\nexternal ( mod ) : int -> int -> int = \"%modint\"\n\nlet abs x = if x >= 0 then x else -x\n\nexternal ( land ) : int -> int -> int = \"%andint\"\nexternal ( lor ) : int -> int -> int = \"%orint\"\nexternal ( lxor ) : int -> int -> int = \"%xorint\"\n\nlet lnot x = x lxor (-1)\n\nexternal ( lsl ) : int -> int -> int = \"%lslint\"\nexternal ( lsr ) : int -> int -> int = \"%lsrint\"\nexternal ( asr ) : int -> int -> int = \"%asrint\"\n\nlet max_int = (-1) lsr 1\nlet min_int = max_int + 1\n\n(* Floating-point operations *)\n\nexternal ( ~-. ) : float -> float = \"%negfloat\"\nexternal ( ~+. ) : float -> float = \"%identity\"\nexternal ( +. ) : float -> float -> float = \"%addfloat\"\nexternal ( -. ) : float -> float -> float = \"%subfloat\"\nexternal ( *. ) : float -> float -> float = \"%mulfloat\"\nexternal ( /. ) : float -> float -> float = \"%divfloat\"\nexternal ( ** ) : float -> float -> float = \"caml_power_float\" \"pow\"\n [@@unboxed] [@@noalloc]\nexternal exp : float -> float = \"caml_exp_float\" \"exp\" [@@unboxed] [@@noalloc]\nexternal expm1 : float -> float = \"caml_expm1_float\" \"caml_expm1\"\n [@@unboxed] [@@noalloc]\nexternal acos : float -> float = \"caml_acos_float\" \"acos\"\n [@@unboxed] [@@noalloc]\nexternal asin : float -> float = \"caml_asin_float\" \"asin\"\n [@@unboxed] [@@noalloc]\nexternal atan : float -> float = \"caml_atan_float\" \"atan\"\n [@@unboxed] [@@noalloc]\nexternal atan2 : float -> float -> float = \"caml_atan2_float\" \"atan2\"\n [@@unboxed] [@@noalloc]\nexternal hypot : float -> float -> float\n = \"caml_hypot_float\" \"caml_hypot\" [@@unboxed] [@@noalloc]\nexternal cos : float -> float = \"caml_cos_float\" \"cos\" [@@unboxed] [@@noalloc]\nexternal cosh : float -> float = \"caml_cosh_float\" \"cosh\"\n [@@unboxed] [@@noalloc]\nexternal acosh : float -> float = \"caml_acosh_float\" \"caml_acosh\"\n [@@unboxed] [@@noalloc]\nexternal log : float -> float = \"caml_log_float\" \"log\" [@@unboxed] [@@noalloc]\nexternal log10 : float -> float = \"caml_log10_float\" \"log10\"\n [@@unboxed] [@@noalloc]\nexternal log1p : float -> float = \"caml_log1p_float\" \"caml_log1p\"\n [@@unboxed] [@@noalloc]\nexternal sin : float -> float = \"caml_sin_float\" \"sin\" [@@unboxed] [@@noalloc]\nexternal sinh : float -> float = \"caml_sinh_float\" \"sinh\"\n [@@unboxed] [@@noalloc]\nexternal asinh : float -> float = \"caml_asinh_float\" \"caml_asinh\"\n [@@unboxed] [@@noalloc]\nexternal sqrt : float -> float = \"caml_sqrt_float\" \"sqrt\"\n [@@unboxed] [@@noalloc]\nexternal tan : float -> float = \"caml_tan_float\" \"tan\" [@@unboxed] [@@noalloc]\nexternal tanh : float -> float = \"caml_tanh_float\" \"tanh\"\n [@@unboxed] [@@noalloc]\nexternal atanh : float -> float = \"caml_atanh_float\" \"caml_atanh\"\n [@@unboxed] [@@noalloc]\nexternal ceil : float -> float = \"caml_ceil_float\" \"ceil\"\n [@@unboxed] [@@noalloc]\nexternal floor : float -> float = \"caml_floor_float\" \"floor\"\n [@@unboxed] [@@noalloc]\nexternal abs_float : float -> float = \"%absfloat\"\nexternal copysign : float -> float -> float\n = \"caml_copysign_float\" \"caml_copysign\"\n [@@unboxed] [@@noalloc]\nexternal mod_float : float -> float -> float = \"caml_fmod_float\" \"fmod\"\n [@@unboxed] [@@noalloc]\nexternal frexp : float -> float * int = \"caml_frexp_float\"\nexternal ldexp : (float [@unboxed]) -> (int [@untagged]) -> (float [@unboxed]) =\n \"caml_ldexp_float\" \"caml_ldexp_float_unboxed\" [@@noalloc]\nexternal modf : float -> float * float = \"caml_modf_float\"\nexternal float : int -> float = \"%floatofint\"\nexternal float_of_int : int -> float = \"%floatofint\"\nexternal truncate : float -> int = \"%intoffloat\"\nexternal int_of_float : float -> int = \"%intoffloat\"\nexternal float_of_bits : int64 -> float\n = \"caml_int64_float_of_bits\" \"caml_int64_float_of_bits_unboxed\"\n [@@unboxed] [@@noalloc]\nlet infinity =\n float_of_bits 0x7F_F0_00_00_00_00_00_00L\nlet neg_infinity =\n float_of_bits 0xFF_F0_00_00_00_00_00_00L\nlet nan =\n float_of_bits 0x7F_F0_00_00_00_00_00_01L\nlet max_float =\n float_of_bits 0x7F_EF_FF_FF_FF_FF_FF_FFL\nlet min_float =\n float_of_bits 0x00_10_00_00_00_00_00_00L\nlet epsilon_float =\n float_of_bits 0x3C_B0_00_00_00_00_00_00L\n\ntype fpclass =\n FP_normal\n | FP_subnormal\n | FP_zero\n | FP_infinite\n | FP_nan\nexternal classify_float : (float [@unboxed]) -> fpclass =\n \"caml_classify_float\" \"caml_classify_float_unboxed\" [@@noalloc]\n\n(* String and byte sequence operations -- more in modules String and Bytes *)\n\nexternal string_length : string -> int = \"%string_length\"\nexternal bytes_length : bytes -> int = \"%bytes_length\"\nexternal bytes_create : int -> bytes = \"caml_create_bytes\"\nexternal string_blit : string -> int -> bytes -> int -> int -> unit\n = \"caml_blit_string\" [@@noalloc]\nexternal bytes_blit : bytes -> int -> bytes -> int -> int -> unit\n = \"caml_blit_bytes\" [@@noalloc]\nexternal bytes_unsafe_to_string : bytes -> string = \"%bytes_to_string\"\n\nlet ( ^ ) s1 s2 =\n let l1 = string_length s1 and l2 = string_length s2 in\n let s = bytes_create (l1 + l2) in\n string_blit s1 0 s 0 l1;\n string_blit s2 0 s l1 l2;\n bytes_unsafe_to_string s\n\n(* Character operations -- more in module Char *)\n\nexternal int_of_char : char -> int = \"%identity\"\nexternal unsafe_char_of_int : int -> char = \"%identity\"\nlet char_of_int n =\n if n < 0 || n > 255 then invalid_arg \"char_of_int\" else unsafe_char_of_int n\n\n(* Unit operations *)\n\nexternal ignore : 'a -> unit = \"%ignore\"\n\n(* Pair operations *)\n\nexternal fst : 'a * 'b -> 'a = \"%field0\"\nexternal snd : 'a * 'b -> 'b = \"%field1\"\n\n(* References *)\n\ntype 'a ref = { mutable contents : 'a }\nexternal ref : 'a -> 'a ref = \"%makemutable\"\nexternal ( ! ) : 'a ref -> 'a = \"%field0\"\nexternal ( := ) : 'a ref -> 'a -> unit = \"%setfield0\"\nexternal incr : int ref -> unit = \"%incr\"\nexternal decr : int ref -> unit = \"%decr\"\n\n(* Result type *)\n\ntype ('a,'b) result = Ok of 'a | Error of 'b\n\n(* String conversion functions *)\n\nexternal format_int : string -> int -> string = \"caml_format_int\"\nexternal format_float : string -> float -> string = \"caml_format_float\"\n\nlet string_of_bool b =\n if b then \"true\" else \"false\"\nlet bool_of_string = function\n | \"true\" -> true\n | \"false\" -> false\n | _ -> invalid_arg \"bool_of_string\"\n\nlet bool_of_string_opt = function\n | \"true\" -> Some true\n | \"false\" -> Some false\n | _ -> None\n\nlet string_of_int n =\n format_int \"%d\" n\n\nexternal int_of_string : string -> int = \"caml_int_of_string\"\n\nlet int_of_string_opt s =\n (* TODO: provide this directly as a non-raising primitive. *)\n try Some (int_of_string s)\n with Failure _ -> None\n\nexternal string_get : string -> int -> char = \"%string_safe_get\"\n\nlet valid_float_lexem s =\n let l = string_length s in\n let rec loop i =\n if i >= l then s ^ \".\" else\n match string_get s i with\n | '0' .. '9' | '-' -> loop (i + 1)\n | _ -> s\n in\n loop 0\n\nlet string_of_float f = valid_float_lexem (format_float \"%.12g\" f)\n\nexternal float_of_string : string -> float = \"caml_float_of_string\"\n\nlet float_of_string_opt s =\n (* TODO: provide this directly as a non-raising primitive. *)\n try Some (float_of_string s)\n with Failure _ -> None\n\n(* List operations -- more in module List *)\n\nlet rec ( @ ) l1 l2 =\n match l1 with\n [] -> l2\n | hd :: tl -> hd :: (tl @ l2)\n\n(* I/O operations *)\n\ntype in_channel\ntype out_channel\n\nexternal open_descriptor_out : int -> out_channel\n = \"caml_ml_open_descriptor_out\"\nexternal open_descriptor_in : int -> in_channel = \"caml_ml_open_descriptor_in\"\n\nlet stdin = open_descriptor_in 0\nlet stdout = open_descriptor_out 1\nlet stderr = open_descriptor_out 2\n\n(* General output functions *)\n\ntype open_flag =\n Open_rdonly | Open_wronly | Open_append\n | Open_creat | Open_trunc | Open_excl\n | Open_binary | Open_text | Open_nonblock\n\nexternal open_desc : string -> open_flag list -> int -> int = \"caml_sys_open\"\n\nexternal set_out_channel_name: out_channel -> string -> unit =\n \"caml_ml_set_channel_name\"\n\nlet open_out_gen mode perm name =\n let c = open_descriptor_out(open_desc name mode perm) in\n set_out_channel_name c name;\n c\n\nlet open_out name =\n open_out_gen [Open_wronly; Open_creat; Open_trunc; Open_text] 0o666 name\n\nlet open_out_bin name =\n open_out_gen [Open_wronly; Open_creat; Open_trunc; Open_binary] 0o666 name\n\nexternal flush : out_channel -> unit = \"caml_ml_flush\"\n\nexternal out_channels_list : unit -> out_channel list\n = \"caml_ml_out_channels_list\"\n\nlet flush_all () =\n let rec iter = function\n [] -> ()\n | a::l ->\n begin try\n flush a\n with Sys_error _ ->\n () (* ignore channels closed during a preceding flush. *)\n end;\n iter l\n in iter (out_channels_list ())\n\nexternal unsafe_output : out_channel -> bytes -> int -> int -> unit\n = \"caml_ml_output_bytes\"\nexternal unsafe_output_string : out_channel -> string -> int -> int -> unit\n = \"caml_ml_output\"\n\nexternal output_char : out_channel -> char -> unit = \"caml_ml_output_char\"\n\nlet output_bytes oc s =\n unsafe_output oc s 0 (bytes_length s)\n\nlet output_string oc s =\n unsafe_output_string oc s 0 (string_length s)\n\nlet output oc s ofs len =\n if ofs < 0 || len < 0 || ofs > bytes_length s - len\n then invalid_arg \"output\"\n else unsafe_output oc s ofs len\n\nlet output_substring oc s ofs len =\n if ofs < 0 || len < 0 || ofs > string_length s - len\n then invalid_arg \"output_substring\"\n else unsafe_output_string oc s ofs len\n\nexternal output_byte : out_channel -> int -> unit = \"caml_ml_output_char\"\nexternal output_binary_int : out_channel -> int -> unit = \"caml_ml_output_int\"\n\nexternal marshal_to_channel : out_channel -> 'a -> unit list -> unit\n = \"caml_output_value\"\nlet output_value chan v = marshal_to_channel chan v []\n\nexternal seek_out : out_channel -> int -> unit = \"caml_ml_seek_out\"\nexternal pos_out : out_channel -> int = \"caml_ml_pos_out\"\nexternal out_channel_length : out_channel -> int = \"caml_ml_channel_size\"\nexternal close_out_channel : out_channel -> unit = \"caml_ml_close_channel\"\nlet close_out oc = flush oc; close_out_channel oc\nlet close_out_noerr oc =\n (try flush oc with _ -> ());\n (try close_out_channel oc with _ -> ())\nexternal set_binary_mode_out : out_channel -> bool -> unit\n = \"caml_ml_set_binary_mode\"\n\n(* General input functions *)\n\nexternal set_in_channel_name: in_channel -> string -> unit =\n \"caml_ml_set_channel_name\"\n\nlet open_in_gen mode perm name =\n let c = open_descriptor_in(open_desc name mode perm) in\n set_in_channel_name c name;\n c\n\nlet open_in name =\n open_in_gen [Open_rdonly; Open_text] 0 name\n\nlet open_in_bin name =\n open_in_gen [Open_rdonly; Open_binary] 0 name\n\nexternal input_char : in_channel -> char = \"caml_ml_input_char\"\n\nexternal unsafe_input : in_channel -> bytes -> int -> int -> int\n = \"caml_ml_input\"\n\nlet input ic s ofs len =\n if ofs < 0 || len < 0 || ofs > bytes_length s - len\n then invalid_arg \"input\"\n else unsafe_input ic s ofs len\n\nlet rec unsafe_really_input ic s ofs len =\n if len <= 0 then () else begin\n let r = unsafe_input ic s ofs len in\n if r = 0\n then raise End_of_file\n else unsafe_really_input ic s (ofs + r) (len - r)\n end\n\nlet really_input ic s ofs len =\n if ofs < 0 || len < 0 || ofs > bytes_length s - len\n then invalid_arg \"really_input\"\n else unsafe_really_input ic s ofs len\n\nlet really_input_string ic len =\n let s = bytes_create len in\n really_input ic s 0 len;\n bytes_unsafe_to_string s\n\nexternal input_scan_line : in_channel -> int = \"caml_ml_input_scan_line\"\n\nlet input_line chan =\n let rec build_result buf pos = function\n [] -> buf\n | hd :: tl ->\n let len = bytes_length hd in\n bytes_blit hd 0 buf (pos - len) len;\n build_result buf (pos - len) tl in\n let rec scan accu len =\n let n = input_scan_line chan in\n if n = 0 then begin (* n = 0: we are at EOF *)\n match accu with\n [] -> raise End_of_file\n | _ -> build_result (bytes_create len) len accu\n end else if n > 0 then begin (* n > 0: newline found in buffer *)\n let res = bytes_create (n - 1) in\n ignore (unsafe_input chan res 0 (n - 1));\n ignore (input_char chan); (* skip the newline *)\n match accu with\n [] -> res\n | _ -> let len = len + n - 1 in\n build_result (bytes_create len) len (res :: accu)\n end else begin (* n < 0: newline not found *)\n let beg = bytes_create (-n) in\n ignore(unsafe_input chan beg 0 (-n));\n scan (beg :: accu) (len - n)\n end\n in bytes_unsafe_to_string (scan [] 0)\n\nexternal input_byte : in_channel -> int = \"caml_ml_input_char\"\nexternal input_binary_int : in_channel -> int = \"caml_ml_input_int\"\nexternal input_value : in_channel -> 'a = \"caml_input_value\"\nexternal seek_in : in_channel -> int -> unit = \"caml_ml_seek_in\"\nexternal pos_in : in_channel -> int = \"caml_ml_pos_in\"\nexternal in_channel_length : in_channel -> int = \"caml_ml_channel_size\"\nexternal close_in : in_channel -> unit = \"caml_ml_close_channel\"\nlet close_in_noerr ic = (try close_in ic with _ -> ())\nexternal set_binary_mode_in : in_channel -> bool -> unit\n = \"caml_ml_set_binary_mode\"\n\n(* Output functions on standard output *)\n\nlet print_char c = output_char stdout c\nlet print_string s = output_string stdout s\nlet print_bytes s = output_bytes stdout s\nlet print_int i = output_string stdout (string_of_int i)\nlet print_float f = output_string stdout (string_of_float f)\nlet print_endline s =\n output_string stdout s; output_char stdout '\\n'; flush stdout\nlet print_newline () = output_char stdout '\\n'; flush stdout\n\n(* Output functions on standard error *)\n\nlet prerr_char c = output_char stderr c\nlet prerr_string s = output_string stderr s\nlet prerr_bytes s = output_bytes stderr s\nlet prerr_int i = output_string stderr (string_of_int i)\nlet prerr_float f = output_string stderr (string_of_float f)\nlet prerr_endline s =\n output_string stderr s; output_char stderr '\\n'; flush stderr\nlet prerr_newline () = output_char stderr '\\n'; flush stderr\n\n(* Input functions on standard input *)\n\nlet read_line () = flush stdout; input_line stdin\nlet read_int () = int_of_string(read_line())\nlet read_int_opt () = int_of_string_opt(read_line())\nlet read_float () = float_of_string(read_line())\nlet read_float_opt () = float_of_string_opt(read_line())\n\n(* Operations on large files *)\n\nmodule LargeFile =\n struct\n external seek_out : out_channel -> int64 -> unit = \"caml_ml_seek_out_64\"\n external pos_out : out_channel -> int64 = \"caml_ml_pos_out_64\"\n external out_channel_length : out_channel -> int64\n = \"caml_ml_channel_size_64\"\n external seek_in : in_channel -> int64 -> unit = \"caml_ml_seek_in_64\"\n external pos_in : in_channel -> int64 = \"caml_ml_pos_in_64\"\n external in_channel_length : in_channel -> int64 = \"caml_ml_channel_size_64\"\n end\n\n(* Formats *)\n\ntype ('a, 'b, 'c, 'd, 'e, 'f) format6\n = ('a, 'b, 'c, 'd, 'e, 'f) CamlinternalFormatBasics.format6\n = Format of ('a, 'b, 'c, 'd, 'e, 'f) CamlinternalFormatBasics.fmt\n * string\n\ntype ('a, 'b, 'c, 'd) format4 = ('a, 'b, 'c, 'c, 'c, 'd) format6\n\ntype ('a, 'b, 'c) format = ('a, 'b, 'c, 'c) format4\n\nlet string_of_format (Format (_fmt, str)) = str\n\nexternal format_of_string :\n ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n ('a, 'b, 'c, 'd, 'e, 'f) format6 = \"%identity\"\n\nlet ( ^^ ) (Format (fmt1, str1)) (Format (fmt2, str2)) =\n Format (CamlinternalFormatBasics.concat_fmt fmt1 fmt2,\n str1 ^ \"%,\" ^ str2)\n\n(* Miscellaneous *)\n\nexternal sys_exit : int -> 'a = \"caml_sys_exit\"\n\nlet exit_function = CamlinternalAtomic.make flush_all\n\nlet rec at_exit f =\n let module Atomic = CamlinternalAtomic in\n (* MPR#7253, MPR#7796: make sure \"f\" is executed only once *)\n let f_yet_to_run = Atomic.make true in\n let old_exit = Atomic.get exit_function in\n let new_exit () =\n if Atomic.compare_and_set f_yet_to_run true false then f () ;\n old_exit ()\n in\n let success = Atomic.compare_and_set exit_function old_exit new_exit in\n if not success then at_exit f\n\nlet do_at_exit () = (CamlinternalAtomic.get exit_function) ()\n\nlet exit retcode =\n do_at_exit ();\n sys_exit retcode\n\nlet _ = register_named_value \"Pervasives.do_at_exit\" do_at_exit\n\nexternal major : unit -> unit = \"caml_gc_major\"\nexternal naked_pointers_checked : unit -> bool\n = \"caml_sys_const_naked_pointers_checked\"\nlet () = if naked_pointers_checked () then at_exit major\n\n(*MODULE_ALIASES*)\nmodule Arg = Arg\nmodule Array = Array\nmodule ArrayLabels = ArrayLabels\nmodule Atomic = Atomic\nmodule Bigarray = Bigarray\nmodule Bool = Bool\nmodule Buffer = Buffer\nmodule Bytes = Bytes\nmodule BytesLabels = BytesLabels\nmodule Callback = Callback\nmodule Char = Char\nmodule Complex = Complex\nmodule Digest = Digest\nmodule Either = Either\nmodule Ephemeron = Ephemeron\nmodule Filename = Filename\nmodule Float = Float\nmodule Format = Format\nmodule Fun = Fun\nmodule Gc = Gc\nmodule Genlex = Genlex\nmodule Hashtbl = Hashtbl\nmodule In_channel = In_channel\nmodule Int = Int\nmodule Int32 = Int32\nmodule Int64 = Int64\nmodule Lazy = Lazy\nmodule Lexing = Lexing\nmodule List = List\nmodule ListLabels = ListLabels\nmodule Map = Map\nmodule Marshal = Marshal\nmodule MoreLabels = MoreLabels\nmodule Nativeint = Nativeint\nmodule Obj = Obj\nmodule Oo = Oo\nmodule Option = Option\nmodule Out_channel = Out_channel\nmodule Parsing = Parsing\nmodule Pervasives = Pervasives\nmodule Printexc = Printexc\nmodule Printf = Printf\nmodule Queue = Queue\nmodule Random = Random\nmodule Result = Result\nmodule Scanf = Scanf\nmodule Seq = Seq\nmodule Set = Set\nmodule Stack = Stack\nmodule StdLabels = StdLabels\nmodule Stream = Stream\nmodule String = String\nmodule StringLabels = StringLabels\nmodule Sys = Sys\nmodule Uchar = Uchar\nmodule Unit = Unit\nmodule Weak = Weak\n","(** This module is the toplevel of the Base library; it's what you get when you write\n [open Base].\n\n\n The goal of Base is both to be a more complete standard library, with richer APIs,\n and to be more consistent in its design. For instance, in the standard library\n some things have modules and others don't; in Base, everything is a module.\n\n Base extends some modules and data structures from the standard library, like [Array],\n [Buffer], [Bytes], [Char], [Hashtbl], [Int32], [Int64], [Lazy], [List], [Map],\n [Nativeint], [Printf], [Random], [Set], [String], [Sys], and [Uchar]. One key\n difference is that Base doesn't use exceptions as much as the standard library and\n instead makes heavy use of the [Result] type, as in:\n\n {[ type ('a,'b) result = Ok of 'a | Error of 'b ]}\n\n Base also adds entirely new modules, most notably:\n\n - [Comparable], [Comparator], and [Comparisons] in lieu of polymorphic compare.\n - [Container], which provides a consistent interface across container-like data\n structures (arrays, lists, strings).\n - [Result], [Error], and [Or_error], supporting the or-error pattern.\n\n The recommended way to use Base is to build with [-open Base]. Files compiled this\n way will have the environment described in this file as their initial environment.\n*)\n\n(*_ We hide this from the web docs because the line wrapping is bad, making it\n pretty much inscrutable. *)\n(**/**)\n\n(* The intent is to shadow all of INRIA's standard library. Modules below would cause\n compilation errors without being removed from [Shadow_stdlib] before inclusion. *)\n\ninclude (\n Shadow_stdlib :\n module type of struct\n include Shadow_stdlib\n end\n (* Modules defined in Base *)\n with module Array := Shadow_stdlib.Array\n with module Atomic := Shadow_stdlib.Atomic\n with module Bool := Shadow_stdlib.Bool\n with module Buffer := Shadow_stdlib.Buffer\n with module Bytes := Shadow_stdlib.Bytes\n with module Char := Shadow_stdlib.Char\n with module Either := Shadow_stdlib.Either\n with module Float := Shadow_stdlib.Float\n with module Hashtbl := Shadow_stdlib.Hashtbl\n with module In_channel := Shadow_stdlib.In_channel\n with module Int := Shadow_stdlib.Int\n with module Int32 := Shadow_stdlib.Int32\n with module Int64 := Shadow_stdlib.Int64\n with module Lazy := Shadow_stdlib.Lazy\n with module List := Shadow_stdlib.List\n with module Map := Shadow_stdlib.Map\n with module Nativeint := Shadow_stdlib.Nativeint\n with module Option := Shadow_stdlib.Option\n with module Out_channel := Shadow_stdlib.Out_channel\n with module Printf := Shadow_stdlib.Printf\n with module Queue := Shadow_stdlib.Queue\n with module Random := Shadow_stdlib.Random\n with module Result := Shadow_stdlib.Result\n with module Set := Shadow_stdlib.Set\n with module Stack := Shadow_stdlib.Stack\n with module String := Shadow_stdlib.String\n with module Sys := Shadow_stdlib.Sys\n with module Uchar := Shadow_stdlib.Uchar\n with module Unit := Shadow_stdlib.Unit\n (* Support for generated lexers *)\n with module Lexing := Shadow_stdlib.Lexing\n with type ('a, 'b, 'c) format := ('a, 'b, 'c) format\n with type ('a, 'b, 'c, 'd) format4 := ('a, 'b, 'c, 'd) format4\n with type ('a, 'b, 'c, 'd, 'e, 'f) format6 := ('a, 'b, 'c, 'd, 'e, 'f) format6\n with type 'a ref := 'a ref) [@ocaml.warning \"-3\"]\n\n(**/**)\n\nopen! Import\nmodule Applicative = Applicative\nmodule Array = Array\nmodule Avltree = Avltree\nmodule Backtrace = Backtrace\nmodule Binary_search = Binary_search\nmodule Binary_searchable = Binary_searchable\nmodule Blit = Blit\nmodule Bool = Bool\nmodule Buffer = Buffer\nmodule Bytes = Bytes\nmodule Char = Char\nmodule Comparable = Comparable\nmodule Comparator = Comparator\nmodule Comparisons = Comparisons\nmodule Container = Container\nmodule Either = Either\nmodule Equal = Equal\nmodule Error = Error\nmodule Exn = Exn\nmodule Field = Field\nmodule Float = Float\nmodule Floatable = Floatable\nmodule Fn = Fn\nmodule Formatter = Formatter\nmodule Hash = Hash\nmodule Hash_set = Hash_set\nmodule Hashable = Hashable\nmodule Hasher = Hasher\nmodule Hashtbl = Hashtbl\nmodule Identifiable = Identifiable\nmodule Indexed_container = Indexed_container\nmodule Info = Info\nmodule Int = Int\nmodule Int_conversions = Int_conversions\nmodule Int32 = Int32\nmodule Int63 = Int63\nmodule Int64 = Int64\nmodule Intable = Intable\nmodule Int_math = Int_math\nmodule Invariant = Invariant\nmodule Lazy = Lazy\nmodule List = List\nmodule Map = Map\nmodule Maybe_bound = Maybe_bound\nmodule Monad = Monad\nmodule Nativeint = Nativeint\nmodule Nothing = Nothing\nmodule Option = Option\nmodule Option_array = Option_array\nmodule Or_error = Or_error\nmodule Ordered_collection_common = Ordered_collection_common\nmodule Ordering = Ordering\nmodule Poly = Poly\nmodule Polymorphic_compare = Poly [@@deprecated \"[since 2018-11] use [Poly] instead\"]\n\nmodule Popcount = Popcount\n[@@deprecated \"[since 2018-10] use [popcount] functions in the individual int modules\"]\n\nmodule Pretty_printer = Pretty_printer\nmodule Printf = Printf\nmodule Linked_queue = Linked_queue\nmodule Queue = Queue\nmodule Random = Random\nmodule Ref = Ref\nmodule Result = Result\nmodule Sequence = Sequence\nmodule Set = Set\nmodule Sexpable = Sexpable\nmodule Sign = Sign\nmodule Sign_or_nan = Sign_or_nan\nmodule Source_code_position = Source_code_position\nmodule Stack = Stack\nmodule Staged = Staged\nmodule String = String\nmodule Stringable = Stringable\nmodule Sys = Sys\nmodule T = T\nmodule Type_equal = Type_equal\nmodule Uniform_array = Uniform_array\nmodule Unit = Unit\nmodule Uchar = Uchar\nmodule Validate = Validate\nmodule Variant = Variant\nmodule With_return = With_return\nmodule Word_size = Word_size\n\n(* Avoid a level of indirection for uses of the signatures defined in [T]. *)\ninclude T\n\n(* This is a hack so that odoc creates better documentation. *)\nmodule Sexp = struct\n include Sexp_with_comparable (** @inline *)\nend\n\n(**/**)\n\nmodule Exported_for_specific_uses = struct\n module Fieldslib = Fieldslib\n module Ppx_hash_lib = Ppx_hash_lib\n module Sexplib = Sexplib\n module Variantslib = Variantslib\n module Ppx_compare_lib = Ppx_compare_lib\n module Ppx_sexp_conv_lib = Ppx_sexp_conv_lib\n\n let am_testing = am_testing\nend\n\n(**/**)\n\nmodule Export = struct\n include Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.Builtin\n\n (* [deriving hash] is missing for [array] and [ref] since these types are mutable. *)\n type 'a array = 'a Array.t [@@deriving_inline compare, equal, sexp, sexp_grammar]\n\n let compare_array : 'a. ('a -> 'a -> int) -> 'a array -> 'a array -> int =\n Array.compare\n ;;\n\n let equal_array : 'a. ('a -> 'a -> bool) -> 'a array -> 'a array -> bool = Array.equal\n\n let array_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a array\n =\n Array.t_of_sexp\n ;;\n\n let sexp_of_array :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a array -> Ppx_sexp_conv_lib.Sexp.t\n =\n Array.sexp_of_t\n ;;\n\n let (array_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Array.t\" ]\n ; ggid = \"r\\177A\\255~\\129%\\178\\226\\196g\\165\\t\\232\\204\\001\"\n ; types =\n [ \"array\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ])) ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Array.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (array_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"array\", _the_group)\n in\n array_sexp_grammar\n ;;\n\n [@@@end]\n\n type bool = Bool.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_bool = (Bool.compare : bool -> bool -> int)\n let equal_bool = (Bool.equal : bool -> bool -> bool)\n\n let (hash_fold_bool :\n Ppx_hash_lib.Std.Hash.state -> bool -> Ppx_hash_lib.Std.Hash.state)\n =\n Bool.hash_fold_t\n\n and (hash_bool : bool -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Bool.hash in\n fun x -> func x\n ;;\n\n let bool_of_sexp = (Bool.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> bool)\n let sexp_of_bool = (Bool.sexp_of_t : bool -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (bool_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Bool.t\" ]\n ; ggid = \"{\\171\\239\\166\\219\\128\\005\\201\\192$\\149\\202\\251?\\186\\164\"\n ; types = [ \"bool\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Bool.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (bool_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"bool\", _the_group)\n in\n bool_sexp_grammar\n ;;\n\n [@@@end]\n\n type char = Char.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_char = (Char.compare : char -> char -> int)\n let equal_char = (Char.equal : char -> char -> bool)\n\n let (hash_fold_char :\n Ppx_hash_lib.Std.Hash.state -> char -> Ppx_hash_lib.Std.Hash.state)\n =\n Char.hash_fold_t\n\n and (hash_char : char -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Char.hash in\n fun x -> func x\n ;;\n\n let char_of_sexp = (Char.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> char)\n let sexp_of_char = (Char.sexp_of_t : char -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (char_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Char.t\" ]\n ; ggid = \"H\\140\\243\\204Y\\222\\191d\\000@\\024Md\\028\\147>\"\n ; types = [ \"char\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Char.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (char_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"char\", _the_group)\n in\n char_sexp_grammar\n ;;\n\n [@@@end]\n\n type exn = Exn.t [@@deriving_inline sexp_of]\n\n let sexp_of_exn = (Exn.sexp_of_t : exn -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n\n type float = Float.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_float = (Float.compare : float -> float -> int)\n let equal_float = (Float.equal : float -> float -> bool)\n\n let (hash_fold_float :\n Ppx_hash_lib.Std.Hash.state -> float -> Ppx_hash_lib.Std.Hash.state)\n =\n Float.hash_fold_t\n\n and (hash_float : float -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Float.hash in\n fun x -> func x\n ;;\n\n let float_of_sexp = (Float.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> float)\n let sexp_of_float = (Float.sexp_of_t : float -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (float_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Float.t\" ]\n ; ggid = \"\\190E\\020\\242\\249\\135C\\240+\\214\\226\\143Ip\\217\\223\"\n ; types = [ \"float\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Float.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (float_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"float\", _the_group)\n in\n float_sexp_grammar\n ;;\n\n [@@@end]\n\n type int = Int.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_int = (Int.compare : int -> int -> int)\n let equal_int = (Int.equal : int -> int -> bool)\n\n let (hash_fold_int : Ppx_hash_lib.Std.Hash.state -> int -> Ppx_hash_lib.Std.Hash.state)\n =\n Int.hash_fold_t\n\n and (hash_int : int -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Int.hash in\n fun x -> func x\n ;;\n\n let int_of_sexp = (Int.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> int)\n let sexp_of_int = (Int.sexp_of_t : int -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (int_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Int.t\" ]\n ; ggid = \"\\159\\159\\197^\\165]\\236\\165\\229\\165R8\\169\\225H\\020\"\n ; types = [ \"int\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Int.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (int_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"int\", _the_group)\n in\n int_sexp_grammar\n ;;\n\n [@@@end]\n\n type int32 = Int32.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_int32 = (Int32.compare : int32 -> int32 -> int)\n let equal_int32 = (Int32.equal : int32 -> int32 -> bool)\n\n let (hash_fold_int32 :\n Ppx_hash_lib.Std.Hash.state -> int32 -> Ppx_hash_lib.Std.Hash.state)\n =\n Int32.hash_fold_t\n\n and (hash_int32 : int32 -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Int32.hash in\n fun x -> func x\n ;;\n\n let int32_of_sexp = (Int32.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> int32)\n let sexp_of_int32 = (Int32.sexp_of_t : int32 -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (int32_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Int32.t\" ]\n ; ggid = \"9\\153\\000*L5O+l\\018\\179b\\198\\248\\026\\177\"\n ; types = [ \"int32\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Int32.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (int32_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"int32\", _the_group)\n in\n int32_sexp_grammar\n ;;\n\n [@@@end]\n\n type int64 = Int64.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_int64 = (Int64.compare : int64 -> int64 -> int)\n let equal_int64 = (Int64.equal : int64 -> int64 -> bool)\n\n let (hash_fold_int64 :\n Ppx_hash_lib.Std.Hash.state -> int64 -> Ppx_hash_lib.Std.Hash.state)\n =\n Int64.hash_fold_t\n\n and (hash_int64 : int64 -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Int64.hash in\n fun x -> func x\n ;;\n\n let int64_of_sexp = (Int64.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> int64)\n let sexp_of_int64 = (Int64.sexp_of_t : int64 -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (int64_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Int64.t\" ]\n ; ggid = \"r\\153\\022\\135\\131L\\155\\236\\235CKa\\197o\\248^\"\n ; types = [ \"int64\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Int64.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (int64_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"int64\", _the_group)\n in\n int64_sexp_grammar\n ;;\n\n [@@@end]\n\n type 'a list = 'a List.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_list : 'a. ('a -> 'a -> int) -> 'a list -> 'a list -> int = List.compare\n let equal_list : 'a. ('a -> 'a -> bool) -> 'a list -> 'a list -> bool = List.equal\n\n let hash_fold_list :\n 'a. (Ppx_hash_lib.Std.Hash.state -> 'a -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state -> 'a list -> Ppx_hash_lib.Std.Hash.state\n =\n List.hash_fold_t\n ;;\n\n let list_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a list\n =\n List.t_of_sexp\n ;;\n\n let sexp_of_list :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a list -> Ppx_sexp_conv_lib.Sexp.t\n =\n List.sexp_of_t\n ;;\n\n let (list_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"List.t\" ]\n ; ggid = \"\\144\\022 nativeint -> int)\n let equal_nativeint = (Nativeint.equal : nativeint -> nativeint -> bool)\n\n let (hash_fold_nativeint :\n Ppx_hash_lib.Std.Hash.state -> nativeint -> Ppx_hash_lib.Std.Hash.state)\n =\n Nativeint.hash_fold_t\n\n and (hash_nativeint : nativeint -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Nativeint.hash in\n fun x -> func x\n ;;\n\n let nativeint_of_sexp = (Nativeint.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> nativeint)\n let sexp_of_nativeint = (Nativeint.sexp_of_t : nativeint -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (nativeint_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Nativeint.t\" ]\n ; ggid = \"\\019\\184AE\\023\\\\->1fcm\\002\\254\\196\\129\"\n ; types = [ \"nativeint\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Nativeint.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (nativeint_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"nativeint\", _the_group)\n in\n nativeint_sexp_grammar\n ;;\n\n [@@@end]\n\n type 'a option = 'a Option.t\n [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_option : 'a. ('a -> 'a -> int) -> 'a option -> 'a option -> int =\n Option.compare\n ;;\n\n let equal_option : 'a. ('a -> 'a -> bool) -> 'a option -> 'a option -> bool =\n Option.equal\n ;;\n\n let hash_fold_option :\n 'a. (Ppx_hash_lib.Std.Hash.state -> 'a -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state -> 'a option -> Ppx_hash_lib.Std.Hash.state\n =\n Option.hash_fold_t\n ;;\n\n let option_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a option\n =\n Option.t_of_sexp\n ;;\n\n let sexp_of_option :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a option -> Ppx_sexp_conv_lib.Sexp.t\n =\n Option.sexp_of_t\n ;;\n\n let (option_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Option.t\" ]\n ; ggid = \"\\242@\\255j`*d\\203\\161\\182\\021\\175\\236\\146x\\217\"\n ; types =\n [ \"option\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ]))\n ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Option.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (option_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"option\", _the_group)\n in\n option_sexp_grammar\n ;;\n\n [@@@end]\n\n type 'a ref = 'a Ref.t [@@deriving_inline compare, equal, sexp, sexp_grammar]\n\n let compare_ref : 'a. ('a -> 'a -> int) -> 'a ref -> 'a ref -> int = Ref.compare\n let equal_ref : 'a. ('a -> 'a -> bool) -> 'a ref -> 'a ref -> bool = Ref.equal\n\n let ref_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a ref\n =\n Ref.t_of_sexp\n ;;\n\n let sexp_of_ref :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a ref -> Ppx_sexp_conv_lib.Sexp.t\n =\n Ref.sexp_of_t\n ;;\n\n let (ref_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Ref.t\" ]\n ; ggid = \"\\185\\246\\012[\\001\\197\\230\\192y=\\b\\199\\141\\248\\020\\012\"\n ; types =\n [ \"ref\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ])) ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Ref.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (ref_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"ref\", _the_group)\n in\n ref_sexp_grammar\n ;;\n\n [@@@end]\n\n type string = String.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_string = (String.compare : string -> string -> int)\n let equal_string = (String.equal : string -> string -> bool)\n\n let (hash_fold_string :\n Ppx_hash_lib.Std.Hash.state -> string -> Ppx_hash_lib.Std.Hash.state)\n =\n String.hash_fold_t\n\n and (hash_string : string -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = String.hash in\n fun x -> func x\n ;;\n\n let string_of_sexp = (String.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> string)\n let sexp_of_string = (String.sexp_of_t : string -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (string_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"String.t\" ]\n ; ggid = \"\\141\\195]\\143\\139/M\\t\\159\\t\\152\\214g\\198\\023\\176\"\n ; types = [ \"string\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ String.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (string_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"string\", _the_group)\n in\n string_sexp_grammar\n ;;\n\n [@@@end]\n\n type bytes = Bytes.t [@@deriving_inline compare, equal, sexp, sexp_grammar]\n\n let compare_bytes = (Bytes.compare : bytes -> bytes -> int)\n let equal_bytes = (Bytes.equal : bytes -> bytes -> bool)\n let bytes_of_sexp = (Bytes.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> bytes)\n let sexp_of_bytes = (Bytes.sexp_of_t : bytes -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (bytes_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Bytes.t\" ]\n ; ggid = \"\\015\\153L1\\012\\241\\015\\252\\150\\000\\191\\127Jb#3\"\n ; types = [ \"bytes\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Bytes.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (bytes_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"bytes\", _the_group)\n in\n bytes_sexp_grammar\n ;;\n\n [@@@end]\n\n type unit = Unit.t [@@deriving_inline compare, equal, hash, sexp, sexp_grammar]\n\n let compare_unit = (Unit.compare : unit -> unit -> int)\n let equal_unit = (Unit.equal : unit -> unit -> bool)\n\n let (hash_fold_unit :\n Ppx_hash_lib.Std.Hash.state -> unit -> Ppx_hash_lib.Std.Hash.state)\n =\n Unit.hash_fold_t\n\n and (hash_unit : unit -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = Unit.hash in\n fun x -> func x\n ;;\n\n let unit_of_sexp = (Unit.t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> unit)\n let sexp_of_unit = (Unit.sexp_of_t : unit -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (unit_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"Unit.t\" ]\n ; ggid = \"=\\005 \\134\\187\\\"64\\197S\\19256,\\031l\"\n ; types = [ \"unit\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ Unit.t_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"base.ml.Export\"\n }\n in\n let (unit_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"unit\", _the_group)\n in\n unit_sexp_grammar\n ;;\n\n [@@@end]\n\n (** Format stuff *)\n\n type nonrec ('a, 'b, 'c) format = ('a, 'b, 'c) format\n type nonrec ('a, 'b, 'c, 'd) format4 = ('a, 'b, 'c, 'd) format4\n type nonrec ('a, 'b, 'c, 'd, 'e, 'f) format6 = ('a, 'b, 'c, 'd, 'e, 'f) format6\n\n (** {2 Sexp}\n\n Exporting the ad-hoc types that are recognized by [ppx_sexp_*] converters.\n [sexp_array], [sexp_list], and [sexp_option] allow a record field to be absent when\n converting from a sexp, and if absent, the field will take a default value of the\n appropriate type:\n\n {v\n sexp_array [||]\n sexp_bool false\n sexp_list []\n sexp_option None\n v}\n\n [sexp_opaque] causes the conversion to sexp to produce the atom [].\n\n For more documentation, see sexplib/README.md. *)\n\n type 'a sexp_array = 'a array\n [@@deprecated \"[since 2019-03] use [@sexp.array] instead\"]\n\n type 'a sexp_list = 'a list [@@deprecated \"[since 2019-03] use [@sexp.list] instead\"]\n type 'a sexp_opaque = 'a [@@deprecated \"[since 2019-03] use [@sexp.opaque] instead\"]\n\n type 'a sexp_option = 'a option\n [@@deprecated \"[since 2019-03] use [@sexp.option] instead\"]\n\n (** List operators *)\n\n include List.Infix\n\n (** Int operators and comparisons *)\n\n include Int.O\n include Int_replace_polymorphic_compare\n\n (** Float operators *)\n\n include Float.O_dot\n\n (* This is declared as an external to be optimized away in more contexts. *)\n\n (** Reverse application operator. [x |> g |> f] is equivalent to [f (g (x))]. *)\n external ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\n\n (** Application operator. [g @@ f @@ x] is equivalent to [g (f (x))]. *)\n external ( @@ ) : ('a -> 'b) -> 'a -> 'b = \"%apply\"\n\n (** Boolean operations *)\n\n (* These need to be declared as an external to get the lazy behavior *)\n external ( && ) : bool -> bool -> bool = \"%sequand\"\n external ( || ) : bool -> bool -> bool = \"%sequor\"\n external not : bool -> bool = \"%boolnot\"\n\n (* This must be declared as an external for the warnings to work properly. *)\n external ignore : _ -> unit = \"%ignore\"\n\n (** Common string operations *)\n let ( ^ ) = String.( ^ )\n\n (** Reference operations *)\n\n (* Declared as an externals so that the compiler skips the caml_modify when possible and\n to keep reference unboxing working *)\n external ( ! ) : 'a ref -> 'a = \"%field0\"\n external ref : 'a -> 'a ref = \"%makemutable\"\n external ( := ) : 'a ref -> 'a -> unit = \"%setfield0\"\n\n (** Pair operations *)\n\n let fst = fst\n let snd = snd\n\n (** Exceptions stuff *)\n\n (* Declared as an external so that the compiler may rewrite '%raise' as '%reraise'. *)\n external raise : exn -> _ = \"%raise\"\n\n let failwith = failwith\n let invalid_arg = invalid_arg\n let raise_s = Error.raise_s\n\n (** Misc *)\n\n let phys_equal = phys_equal\n\n external force : 'a Lazy.t -> 'a = \"%lazy_force\"\nend\n\ninclude Export\n\ninclude Container_intf.Export (** @inline *)\n\nexception Not_found_s = Not_found_s\n\n(* We perform these side effects here because we want them to run for any code that uses\n [Base]. If this were in another module in [Base] that was not used in some program,\n then the side effects might not be run in that program. This will run as long as the\n program refers to at least one value directly in [Base]; referring to values in\n [Base.Bool], for example, is not sufficient. *)\nlet () = Backtrace.initialize_module ()\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(** The OCaml Standard library.\n\n This module is automatically opened at the beginning of each\n compilation. All components of this module can therefore be\n referred by their short name, without prefixing them by [Stdlib].\n\n It particular, it provides the basic operations over the built-in\n types (numbers, booleans, byte sequences, strings, exceptions,\n references, lists, arrays, input-output channels, ...) and the\n {{!modules}standard library modules}.\n*)\n\n(** {1 Exceptions} *)\n\nexternal raise : exn -> 'a = \"%raise\"\n(** Raise the given exception value *)\n\nexternal raise_notrace : exn -> 'a = \"%raise_notrace\"\n(** A faster version [raise] which does not record the backtrace.\n @since 4.02.0\n*)\n\nval invalid_arg : string -> 'a\n(** Raise exception [Invalid_argument] with the given string. *)\n\nval failwith : string -> 'a\n(** Raise exception [Failure] with the given string. *)\n\nexception Exit\n(** The [Exit] exception is not raised by any library function. It is\n provided for use in your programs. *)\n\nexception Match_failure of (string * int * int)\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised when none of the cases of a pattern-matching\n apply. The arguments are the location of the match keyword in the\n source code (file name, line number, column number). *)\n\nexception Assert_failure of (string * int * int)\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised when an assertion fails. The arguments are the\n location of the assert keyword in the source code (file name, line\n number, column number). *)\n\nexception Invalid_argument of string\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised by library functions to signal that the given\n arguments do not make sense. The string gives some information to\n the programmer. As a general rule, this exception should not be\n caught, it denotes a programming error and the code should be\n modified not to trigger it. *)\n\nexception Failure of string\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised by library functions to signal that they are\n undefined on the given arguments. The string is meant to give some\n information to the programmer; you must not pattern match on the\n string literal because it may change in future versions (use\n Failure _ instead). *)\n\nexception Not_found\n(** Exception raised by search functions when the desired object could\n not be found. *)\n\nexception Out_of_memory\n(** Exception raised by the garbage collector when there is\n insufficient memory to complete the computation. (Not reliable for\n allocations on the minor heap.) *)\n\nexception Stack_overflow\n(** Exception raised by the bytecode interpreter when the evaluation\n stack reaches its maximal size. This often indicates infinite or\n excessively deep recursion in the user's program.\n\n Before 4.10, it was not fully implemented by the native-code\n compiler. *)\n\nexception Sys_error of string\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised by the input/output functions to report an\n operating system error. The string is meant to give some\n information to the programmer; you must not pattern match on the\n string literal because it may change in future versions (use\n Sys_error _ instead). *)\n\nexception End_of_file\n(** Exception raised by input functions to signal that the end of file\n has been reached. *)\n\nexception Division_by_zero\n(** Exception raised by integer division and remainder operations when\n their second argument is zero. *)\n\nexception Sys_blocked_io\n(** A special case of Sys_error raised when no I/O is possible on a\n non-blocking I/O channel. *)\n\nexception Undefined_recursive_module of (string * int * int)\n [@ocaml.warn_on_literal_pattern]\n(** Exception raised when an ill-founded recursive module definition\n is evaluated. The arguments are the location of the definition in\n the source code (file name, line number, column number). *)\n\n(** {1 Comparisons} *)\n\nexternal ( = ) : 'a -> 'a -> bool = \"%equal\"\n(** [e1 = e2] tests for structural equality of [e1] and [e2].\n Mutable structures (e.g. references and arrays) are equal\n if and only if their current contents are structurally equal,\n even if the two mutable objects are not the same physical object.\n Equality between functional values raises [Invalid_argument].\n Equality between cyclic data structures may not terminate.\n Left-associative operator, see {!Ocaml_operators} for more information. *)\n\nexternal ( <> ) : 'a -> 'a -> bool = \"%notequal\"\n(** Negation of {!Stdlib.( = )}.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( < ) : 'a -> 'a -> bool = \"%lessthan\"\n(** See {!Stdlib.( >= )}.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( > ) : 'a -> 'a -> bool = \"%greaterthan\"\n(** See {!Stdlib.( >= )}.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( <= ) : 'a -> 'a -> bool = \"%lessequal\"\n(** See {!Stdlib.( >= )}.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( >= ) : 'a -> 'a -> bool = \"%greaterequal\"\n(** Structural ordering functions. These functions coincide with\n the usual orderings over integers, characters, strings, byte sequences\n and floating-point numbers, and extend them to a\n total ordering over all types.\n The ordering is compatible with [( = )]. As in the case\n of [( = )], mutable structures are compared by contents.\n Comparison between functional values raises [Invalid_argument].\n Comparison between cyclic structures may not terminate.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal compare : 'a -> 'a -> int = \"%compare\"\n(** [compare x y] returns [0] if [x] is equal to [y],\n a negative integer if [x] is less than [y], and a positive integer\n if [x] is greater than [y]. The ordering implemented by [compare]\n is compatible with the comparison predicates [=], [<] and [>]\n defined above, with one difference on the treatment of the float value\n {!Stdlib.nan}. Namely, the comparison predicates treat [nan]\n as different from any other float value, including itself;\n while [compare] treats [nan] as equal to itself and less than any\n other float value. This treatment of [nan] ensures that [compare]\n defines a total ordering relation.\n\n [compare] applied to functional values may raise [Invalid_argument].\n [compare] applied to cyclic structures may not terminate.\n\n The [compare] function can be used as the comparison function\n required by the {!Set.Make} and {!Map.Make} functors, as well as\n the {!List.sort} and {!Array.sort} functions. *)\n\nval min : 'a -> 'a -> 'a\n(** Return the smaller of the two arguments.\n The result is unspecified if one of the arguments contains\n the float value [nan]. *)\n\nval max : 'a -> 'a -> 'a\n(** Return the greater of the two arguments.\n The result is unspecified if one of the arguments contains\n the float value [nan]. *)\n\nexternal ( == ) : 'a -> 'a -> bool = \"%eq\"\n(** [e1 == e2] tests for physical equality of [e1] and [e2].\n On mutable types such as references, arrays, byte sequences, records with\n mutable fields and objects with mutable instance variables,\n [e1 == e2] is true if and only if physical modification of [e1]\n also affects [e2].\n On non-mutable types, the behavior of [( == )] is\n implementation-dependent; however, it is guaranteed that\n [e1 == e2] implies [compare e1 e2 = 0].\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( != ) : 'a -> 'a -> bool = \"%noteq\"\n(** Negation of {!Stdlib.( == )}.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\n\n(** {1 Boolean operations} *)\n\nexternal not : bool -> bool = \"%boolnot\"\n(** The boolean negation. *)\n\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\n(** The boolean 'and'. Evaluation is sequential, left-to-right:\n in [e1 && e2], [e1] is evaluated first, and if it returns [false],\n [e2] is not evaluated at all.\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( & ) : bool -> bool -> bool = \"%sequand\"\n [@@ocaml.deprecated \"Use (&&) instead.\"]\n(** @deprecated {!Stdlib.( && )} should be used instead.\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( || ) : bool -> bool -> bool = \"%sequor\"\n(** The boolean 'or'. Evaluation is sequential, left-to-right:\n in [e1 || e2], [e1] is evaluated first, and if it returns [true],\n [e2] is not evaluated at all.\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( or ) : bool -> bool -> bool = \"%sequor\"\n [@@ocaml.deprecated \"Use (||) instead.\"]\n(** @deprecated {!Stdlib.( || )} should be used instead.\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\n(** {1 Debugging} *)\n\nexternal __LOC__ : string = \"%loc_LOC\"\n(** [__LOC__] returns the location at which this expression appears in\n the file currently being parsed by the compiler, with the standard\n error format of OCaml: \"File %S, line %d, characters %d-%d\".\n @since 4.02.0\n*)\n\nexternal __FILE__ : string = \"%loc_FILE\"\n(** [__FILE__] returns the name of the file currently being\n parsed by the compiler.\n @since 4.02.0\n*)\n\nexternal __LINE__ : int = \"%loc_LINE\"\n(** [__LINE__] returns the line number at which this expression\n appears in the file currently being parsed by the compiler.\n @since 4.02.0\n*)\n\nexternal __MODULE__ : string = \"%loc_MODULE\"\n(** [__MODULE__] returns the module name of the file being\n parsed by the compiler.\n @since 4.02.0\n*)\n\nexternal __POS__ : string * int * int * int = \"%loc_POS\"\n(** [__POS__] returns a tuple [(file,lnum,cnum,enum)], corresponding\n to the location at which this expression appears in the file\n currently being parsed by the compiler. [file] is the current\n filename, [lnum] the line number, [cnum] the character position in\n the line and [enum] the last character position in the line.\n @since 4.02.0\n *)\n\nexternal __FUNCTION__ : string = \"%loc_FUNCTION\"\n(** [__FUNCTION__] returns the name of the current function or method, including\n any enclosing modules or classes.\n\n @since 4.12.0 *)\n\nexternal __LOC_OF__ : 'a -> string * 'a = \"%loc_LOC\"\n(** [__LOC_OF__ expr] returns a pair [(loc, expr)] where [loc] is the\n location of [expr] in the file currently being parsed by the\n compiler, with the standard error format of OCaml: \"File %S, line\n %d, characters %d-%d\".\n @since 4.02.0\n*)\n\nexternal __LINE_OF__ : 'a -> int * 'a = \"%loc_LINE\"\n(** [__LINE_OF__ expr] returns a pair [(line, expr)], where [line] is the\n line number at which the expression [expr] appears in the file\n currently being parsed by the compiler.\n @since 4.02.0\n *)\n\nexternal __POS_OF__ : 'a -> (string * int * int * int) * 'a = \"%loc_POS\"\n(** [__POS_OF__ expr] returns a pair [(loc,expr)], where [loc] is a\n tuple [(file,lnum,cnum,enum)] corresponding to the location at\n which the expression [expr] appears in the file currently being\n parsed by the compiler. [file] is the current filename, [lnum] the\n line number, [cnum] the character position in the line and [enum]\n the last character position in the line.\n @since 4.02.0\n *)\n\n(** {1 Composition operators} *)\n\nexternal ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\n(** Reverse-application operator: [x |> f |> g] is exactly equivalent\n to [g (f (x))].\n Left-associative operator, see {!Ocaml_operators} for more information.\n @since 4.01\n*)\n\nexternal ( @@ ) : ('a -> 'b) -> 'a -> 'b = \"%apply\"\n(** Application operator: [g @@ f @@ x] is exactly equivalent to\n [g (f (x))].\n Right-associative operator, see {!Ocaml_operators} for more information.\n @since 4.01\n*)\n\n(** {1 Integer arithmetic} *)\n\n(** Integers are [Sys.int_size] bits wide.\n All operations are taken modulo 2{^[Sys.int_size]}.\n They do not fail on overflow. *)\n\nexternal ( ~- ) : int -> int = \"%negint\"\n(** Unary negation. You can also write [- e] instead of [~- e].\n Unary operator, see {!Ocaml_operators} for more information.\n*)\n\n\nexternal ( ~+ ) : int -> int = \"%identity\"\n(** Unary addition. You can also write [+ e] instead of [~+ e].\n Unary operator, see {!Ocaml_operators} for more information.\n @since 3.12.0\n*)\n\nexternal succ : int -> int = \"%succint\"\n(** [succ x] is [x + 1]. *)\n\nexternal pred : int -> int = \"%predint\"\n(** [pred x] is [x - 1]. *)\n\nexternal ( + ) : int -> int -> int = \"%addint\"\n(** Integer addition.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( - ) : int -> int -> int = \"%subint\"\n(** Integer subtraction.\n Left-associative operator, , see {!Ocaml_operators} for more information.\n*)\n\nexternal ( * ) : int -> int -> int = \"%mulint\"\n(** Integer multiplication.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( / ) : int -> int -> int = \"%divint\"\n(** Integer division.\n Integer division rounds the real quotient of its arguments towards zero.\n More precisely, if [x >= 0] and [y > 0], [x / y] is the greatest integer\n less than or equal to the real quotient of [x] by [y]. Moreover,\n [(- x) / y = x / (- y) = - (x / y)].\n Left-associative operator, see {!Ocaml_operators} for more information.\n\n @raise Division_by_zero if the second argument is 0.\n*)\n\nexternal ( mod ) : int -> int -> int = \"%modint\"\n(** Integer remainder. If [y] is not zero, the result\n of [x mod y] satisfies the following properties:\n [x = (x / y) * y + x mod y] and\n [abs(x mod y) <= abs(y) - 1].\n If [y = 0], [x mod y] raises [Division_by_zero].\n Note that [x mod y] is negative only if [x < 0].\n Left-associative operator, see {!Ocaml_operators} for more information.\n\n @raise Division_by_zero if [y] is zero.\n*)\n\nval abs : int -> int\n(** Return the absolute value of the argument. Note that this may be\n negative if the argument is [min_int]. *)\n\nval max_int : int\n(** The greatest representable integer. *)\n\nval min_int : int\n(** The smallest representable integer. *)\n\n\n(** {2 Bitwise operations} *)\n\nexternal ( land ) : int -> int -> int = \"%andint\"\n(** Bitwise logical and.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( lor ) : int -> int -> int = \"%orint\"\n(** Bitwise logical or.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( lxor ) : int -> int -> int = \"%xorint\"\n(** Bitwise logical exclusive or.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nval lnot : int -> int\n(** Bitwise logical negation. *)\n\nexternal ( lsl ) : int -> int -> int = \"%lslint\"\n(** [n lsl m] shifts [n] to the left by [m] bits.\n The result is unspecified if [m < 0] or [m > Sys.int_size].\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( lsr ) : int -> int -> int = \"%lsrint\"\n(** [n lsr m] shifts [n] to the right by [m] bits.\n This is a logical shift: zeroes are inserted regardless of\n the sign of [n].\n The result is unspecified if [m < 0] or [m > Sys.int_size].\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( asr ) : int -> int -> int = \"%asrint\"\n(** [n asr m] shifts [n] to the right by [m] bits.\n This is an arithmetic shift: the sign bit of [n] is replicated.\n The result is unspecified if [m < 0] or [m > Sys.int_size].\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\n(** {1 Floating-point arithmetic}\n\n OCaml's floating-point numbers follow the\n IEEE 754 standard, using double precision (64 bits) numbers.\n Floating-point operations never raise an exception on overflow,\n underflow, division by zero, etc. Instead, special IEEE numbers\n are returned as appropriate, such as [infinity] for [1.0 /. 0.0],\n [neg_infinity] for [-1.0 /. 0.0], and [nan] ('not a number')\n for [0.0 /. 0.0]. These special numbers then propagate through\n floating-point computations as expected: for instance,\n [1.0 /. infinity] is [0.0], basic arithmetic operations\n ([+.], [-.], [*.], [/.]) with [nan] as an argument return [nan], ...\n*)\n\nexternal ( ~-. ) : float -> float = \"%negfloat\"\n(** Unary negation. You can also write [-. e] instead of [~-. e].\n Unary operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( ~+. ) : float -> float = \"%identity\"\n(** Unary addition. You can also write [+. e] instead of [~+. e].\n Unary operator, see {!Ocaml_operators} for more information.\n @since 3.12.0\n*)\n\nexternal ( +. ) : float -> float -> float = \"%addfloat\"\n(** Floating-point addition.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( -. ) : float -> float -> float = \"%subfloat\"\n(** Floating-point subtraction.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( *. ) : float -> float -> float = \"%mulfloat\"\n(** Floating-point multiplication.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( /. ) : float -> float -> float = \"%divfloat\"\n(** Floating-point division.\n Left-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( ** ) : float -> float -> float = \"caml_power_float\" \"pow\"\n [@@unboxed] [@@noalloc]\n(** Exponentiation.\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal sqrt : float -> float = \"caml_sqrt_float\" \"sqrt\"\n [@@unboxed] [@@noalloc]\n(** Square root. *)\n\nexternal exp : float -> float = \"caml_exp_float\" \"exp\" [@@unboxed] [@@noalloc]\n(** Exponential. *)\n\nexternal log : float -> float = \"caml_log_float\" \"log\" [@@unboxed] [@@noalloc]\n(** Natural logarithm. *)\n\nexternal log10 : float -> float = \"caml_log10_float\" \"log10\"\n [@@unboxed] [@@noalloc]\n(** Base 10 logarithm. *)\n\nexternal expm1 : float -> float = \"caml_expm1_float\" \"caml_expm1\"\n [@@unboxed] [@@noalloc]\n(** [expm1 x] computes [exp x -. 1.0], giving numerically-accurate results\n even if [x] is close to [0.0].\n @since 3.12.0\n*)\n\nexternal log1p : float -> float = \"caml_log1p_float\" \"caml_log1p\"\n [@@unboxed] [@@noalloc]\n(** [log1p x] computes [log(1.0 +. x)] (natural logarithm),\n giving numerically-accurate results even if [x] is close to [0.0].\n @since 3.12.0\n*)\n\nexternal cos : float -> float = \"caml_cos_float\" \"cos\" [@@unboxed] [@@noalloc]\n(** Cosine. Argument is in radians. *)\n\nexternal sin : float -> float = \"caml_sin_float\" \"sin\" [@@unboxed] [@@noalloc]\n(** Sine. Argument is in radians. *)\n\nexternal tan : float -> float = \"caml_tan_float\" \"tan\" [@@unboxed] [@@noalloc]\n(** Tangent. Argument is in radians. *)\n\nexternal acos : float -> float = \"caml_acos_float\" \"acos\"\n [@@unboxed] [@@noalloc]\n(** Arc cosine. The argument must fall within the range [[-1.0, 1.0]].\n Result is in radians and is between [0.0] and [pi]. *)\n\nexternal asin : float -> float = \"caml_asin_float\" \"asin\"\n [@@unboxed] [@@noalloc]\n(** Arc sine. The argument must fall within the range [[-1.0, 1.0]].\n Result is in radians and is between [-pi/2] and [pi/2]. *)\n\nexternal atan : float -> float = \"caml_atan_float\" \"atan\"\n [@@unboxed] [@@noalloc]\n(** Arc tangent.\n Result is in radians and is between [-pi/2] and [pi/2]. *)\n\nexternal atan2 : float -> float -> float = \"caml_atan2_float\" \"atan2\"\n [@@unboxed] [@@noalloc]\n(** [atan2 y x] returns the arc tangent of [y /. x]. The signs of [x]\n and [y] are used to determine the quadrant of the result.\n Result is in radians and is between [-pi] and [pi]. *)\n\nexternal hypot : float -> float -> float = \"caml_hypot_float\" \"caml_hypot\"\n [@@unboxed] [@@noalloc]\n(** [hypot x y] returns [sqrt(x *. x + y *. y)], that is, the length\n of the hypotenuse of a right-angled triangle with sides of length\n [x] and [y], or, equivalently, the distance of the point [(x,y)]\n to origin. If one of [x] or [y] is infinite, returns [infinity]\n even if the other is [nan].\n @since 4.00.0 *)\n\nexternal cosh : float -> float = \"caml_cosh_float\" \"cosh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic cosine. Argument is in radians. *)\n\nexternal sinh : float -> float = \"caml_sinh_float\" \"sinh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic sine. Argument is in radians. *)\n\nexternal tanh : float -> float = \"caml_tanh_float\" \"tanh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic tangent. Argument is in radians. *)\n\nexternal acosh : float -> float = \"caml_acosh_float\" \"caml_acosh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic arc cosine. The argument must fall within the range\n [[1.0, inf]].\n Result is in radians and is between [0.0] and [inf].\n\n @since 4.13.0\n*)\n\nexternal asinh : float -> float = \"caml_asinh_float\" \"caml_asinh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic arc sine. The argument and result range over the entire\n real line.\n Result is in radians.\n\n @since 4.13.0\n*)\n\nexternal atanh : float -> float = \"caml_atanh_float\" \"caml_atanh\"\n [@@unboxed] [@@noalloc]\n(** Hyperbolic arc tangent. The argument must fall within the range\n [[-1.0, 1.0]].\n Result is in radians and ranges over the entire real line.\n\n @since 4.13.0\n*)\n\nexternal ceil : float -> float = \"caml_ceil_float\" \"ceil\"\n [@@unboxed] [@@noalloc]\n(** Round above to an integer value.\n [ceil f] returns the least integer value greater than or equal to [f].\n The result is returned as a float. *)\n\nexternal floor : float -> float = \"caml_floor_float\" \"floor\"\n [@@unboxed] [@@noalloc]\n(** Round below to an integer value.\n [floor f] returns the greatest integer value less than or\n equal to [f].\n The result is returned as a float. *)\n\nexternal abs_float : float -> float = \"%absfloat\"\n(** [abs_float f] returns the absolute value of [f]. *)\n\nexternal copysign : float -> float -> float\n = \"caml_copysign_float\" \"caml_copysign\"\n [@@unboxed] [@@noalloc]\n(** [copysign x y] returns a float whose absolute value is that of [x]\n and whose sign is that of [y]. If [x] is [nan], returns [nan].\n If [y] is [nan], returns either [x] or [-. x], but it is not\n specified which.\n @since 4.00.0 *)\n\nexternal mod_float : float -> float -> float = \"caml_fmod_float\" \"fmod\"\n [@@unboxed] [@@noalloc]\n(** [mod_float a b] returns the remainder of [a] with respect to\n [b]. The returned value is [a -. n *. b], where [n]\n is the quotient [a /. b] rounded towards zero to an integer. *)\n\nexternal frexp : float -> float * int = \"caml_frexp_float\"\n(** [frexp f] returns the pair of the significant\n and the exponent of [f]. When [f] is zero, the\n significant [x] and the exponent [n] of [f] are equal to\n zero. When [f] is non-zero, they are defined by\n [f = x *. 2 ** n] and [0.5 <= x < 1.0]. *)\n\n\nexternal ldexp : (float [@unboxed]) -> (int [@untagged]) -> (float [@unboxed]) =\n \"caml_ldexp_float\" \"caml_ldexp_float_unboxed\" [@@noalloc]\n(** [ldexp x n] returns [x *. 2 ** n]. *)\n\nexternal modf : float -> float * float = \"caml_modf_float\"\n(** [modf f] returns the pair of the fractional and integral\n part of [f]. *)\n\nexternal float : int -> float = \"%floatofint\"\n(** Same as {!Stdlib.float_of_int}. *)\n\nexternal float_of_int : int -> float = \"%floatofint\"\n(** Convert an integer to floating-point. *)\n\nexternal truncate : float -> int = \"%intoffloat\"\n(** Same as {!Stdlib.int_of_float}. *)\n\nexternal int_of_float : float -> int = \"%intoffloat\"\n(** Truncate the given floating-point number to an integer.\n The result is unspecified if the argument is [nan] or falls outside the\n range of representable integers. *)\n\nval infinity : float\n(** Positive infinity. *)\n\nval neg_infinity : float\n(** Negative infinity. *)\n\nval nan : float\n(** A special floating-point value denoting the result of an\n undefined operation such as [0.0 /. 0.0]. Stands for\n 'not a number'. Any floating-point operation with [nan] as\n argument returns [nan] as result. As for floating-point comparisons,\n [=], [<], [<=], [>] and [>=] return [false] and [<>] returns [true]\n if one or both of their arguments is [nan]. *)\n\nval max_float : float\n(** The largest positive finite value of type [float]. *)\n\nval min_float : float\n(** The smallest positive, non-zero, non-denormalized value of type [float]. *)\n\nval epsilon_float : float\n(** The difference between [1.0] and the smallest exactly representable\n floating-point number greater than [1.0]. *)\n\ntype fpclass =\n FP_normal (** Normal number, none of the below *)\n | FP_subnormal (** Number very close to 0.0, has reduced precision *)\n | FP_zero (** Number is 0.0 or -0.0 *)\n | FP_infinite (** Number is positive or negative infinity *)\n | FP_nan (** Not a number: result of an undefined operation *)\n(** The five classes of floating-point numbers, as determined by\n the {!Stdlib.classify_float} function. *)\n\nexternal classify_float : (float [@unboxed]) -> fpclass =\n \"caml_classify_float\" \"caml_classify_float_unboxed\" [@@noalloc]\n(** Return the class of the given floating-point number:\n normal, subnormal, zero, infinite, or not a number. *)\n\n\n(** {1 String operations}\n\n More string operations are provided in module {!String}.\n*)\n\nval ( ^ ) : string -> string -> string\n(** String concatenation.\n Right-associative operator, see {!Ocaml_operators} for more information.\n\n @raise Invalid_argument if the result is longer then\n than {!Sys.max_string_length} bytes.\n*)\n\n(** {1 Character operations}\n\n More character operations are provided in module {!Char}.\n*)\n\nexternal int_of_char : char -> int = \"%identity\"\n(** Return the ASCII code of the argument. *)\n\nval char_of_int : int -> char\n(** Return the character with the given ASCII code.\n @raise Invalid_argument if the argument is\n outside the range 0--255. *)\n\n\n(** {1 Unit operations} *)\n\nexternal ignore : 'a -> unit = \"%ignore\"\n(** Discard the value of its argument and return [()].\n For instance, [ignore(f x)] discards the result of\n the side-effecting function [f]. It is equivalent to\n [f x; ()], except that the latter may generate a\n compiler warning; writing [ignore(f x)] instead\n avoids the warning. *)\n\n\n(** {1 String conversion functions} *)\n\nval string_of_bool : bool -> string\n(** Return the string representation of a boolean. As the returned values\n may be shared, the user should not modify them directly.\n*)\n\nval bool_of_string_opt: string -> bool option\n(** Convert the given string to a boolean.\n\n Return [None] if the string is not [\"true\"] or [\"false\"].\n @since 4.05\n*)\n\nval bool_of_string : string -> bool\n(** Same as {!Stdlib.bool_of_string_opt}, but raise\n [Invalid_argument \"bool_of_string\"] instead of returning [None]. *)\n\nval string_of_int : int -> string\n(** Return the string representation of an integer, in decimal. *)\n\nval int_of_string_opt: string -> int option\n(** Convert the given string to an integer.\n The string is read in decimal (by default, or if the string\n begins with [0u]), in hexadecimal (if it begins with [0x] or\n [0X]), in octal (if it begins with [0o] or [0O]), or in binary\n (if it begins with [0b] or [0B]).\n\n The [0u] prefix reads the input as an unsigned integer in the range\n [[0, 2*max_int+1]]. If the input exceeds {!max_int}\n it is converted to the signed integer\n [min_int + input - max_int - 1].\n\n The [_] (underscore) character can appear anywhere in the string\n and is ignored.\n\n Return [None] if the given string is not a valid representation of an\n integer, or if the integer represented exceeds the range of integers\n representable in type [int].\n @since 4.05\n*)\n\nexternal int_of_string : string -> int = \"caml_int_of_string\"\n(** Same as {!Stdlib.int_of_string_opt}, but raise\n [Failure \"int_of_string\"] instead of returning [None]. *)\n\nval string_of_float : float -> string\n(** Return the string representation of a floating-point number. *)\n\nval float_of_string_opt: string -> float option\n(** Convert the given string to a float. The string is read in decimal\n (by default) or in hexadecimal (marked by [0x] or [0X]).\n\n The format of decimal floating-point numbers is\n [ [-] dd.ddd (e|E) [+|-] dd ], where [d] stands for a decimal digit.\n\n The format of hexadecimal floating-point numbers is\n [ [-] 0(x|X) hh.hhh (p|P) [+|-] dd ], where [h] stands for an\n hexadecimal digit and [d] for a decimal digit.\n\n In both cases, at least one of the integer and fractional parts must be\n given; the exponent part is optional.\n\n The [_] (underscore) character can appear anywhere in the string\n and is ignored.\n\n Depending on the execution platforms, other representations of\n floating-point numbers can be accepted, but should not be relied upon.\n\n Return [None] if the given string is not a valid representation of a float.\n @since 4.05\n*)\n\nexternal float_of_string : string -> float = \"caml_float_of_string\"\n(** Same as {!Stdlib.float_of_string_opt}, but raise\n [Failure \"float_of_string\"] instead of returning [None]. *)\n\n(** {1 Pair operations} *)\n\nexternal fst : 'a * 'b -> 'a = \"%field0\"\n(** Return the first component of a pair. *)\n\nexternal snd : 'a * 'b -> 'b = \"%field1\"\n(** Return the second component of a pair. *)\n\n\n(** {1 List operations}\n\n More list operations are provided in module {!List}.\n*)\n\nval ( @ ) : 'a list -> 'a list -> 'a list\n(** List concatenation. Not tail-recursive (length of the first argument).\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\n(** {1 Input/output}\n Note: all input/output functions can raise [Sys_error] when the system\n calls they invoke fail. *)\n\ntype in_channel\n(** The type of input channel. *)\n\ntype out_channel\n(** The type of output channel. *)\n\nval stdin : in_channel\n(** The standard input for the process. *)\n\nval stdout : out_channel\n(** The standard output for the process. *)\n\nval stderr : out_channel\n(** The standard error output for the process. *)\n\n\n(** {2 Output functions on standard output} *)\n\nval print_char : char -> unit\n(** Print a character on standard output. *)\n\nval print_string : string -> unit\n(** Print a string on standard output. *)\n\nval print_bytes : bytes -> unit\n(** Print a byte sequence on standard output.\n @since 4.02.0 *)\n\nval print_int : int -> unit\n(** Print an integer, in decimal, on standard output. *)\n\nval print_float : float -> unit\n(** Print a floating-point number, in decimal, on standard output. *)\n\nval print_endline : string -> unit\n(** Print a string, followed by a newline character, on\n standard output and flush standard output. *)\n\nval print_newline : unit -> unit\n(** Print a newline character on standard output, and flush\n standard output. This can be used to simulate line\n buffering of standard output. *)\n\n\n(** {2 Output functions on standard error} *)\n\nval prerr_char : char -> unit\n(** Print a character on standard error. *)\n\nval prerr_string : string -> unit\n(** Print a string on standard error. *)\n\nval prerr_bytes : bytes -> unit\n(** Print a byte sequence on standard error.\n @since 4.02.0 *)\n\nval prerr_int : int -> unit\n(** Print an integer, in decimal, on standard error. *)\n\nval prerr_float : float -> unit\n(** Print a floating-point number, in decimal, on standard error. *)\n\nval prerr_endline : string -> unit\n(** Print a string, followed by a newline character on standard\n error and flush standard error. *)\n\nval prerr_newline : unit -> unit\n(** Print a newline character on standard error, and flush\n standard error. *)\n\n\n(** {2 Input functions on standard input} *)\n\nval read_line : unit -> string\n(** Flush standard output, then read characters from standard input\n until a newline character is encountered.\n\n Return the string of all characters read, without the newline character\n at the end.\n\n @raise End_of_file if the end of the file is reached at the beginning of\n line.\n*)\n\nval read_int_opt: unit -> int option\n(** Flush standard output, then read one line from standard input\n and convert it to an integer.\n\n Return [None] if the line read is not a valid representation of an integer.\n @since 4.05\n*)\n\nval read_int : unit -> int\n(** Same as {!Stdlib.read_int_opt}, but raise [Failure \"int_of_string\"]\n instead of returning [None]. *)\n\nval read_float_opt: unit -> float option\n(** Flush standard output, then read one line from standard input\n and convert it to a floating-point number.\n\n Return [None] if the line read is not a valid representation of a\n floating-point number.\n @since 4.05.0\n*)\n\nval read_float : unit -> float\n(** Same as {!Stdlib.read_float_opt}, but raise [Failure \"float_of_string\"]\n instead of returning [None]. *)\n\n\n(** {2 General output functions} *)\n\ntype open_flag =\n Open_rdonly (** open for reading. *)\n | Open_wronly (** open for writing. *)\n | Open_append (** open for appending: always write at end of file. *)\n | Open_creat (** create the file if it does not exist. *)\n | Open_trunc (** empty the file if it already exists. *)\n | Open_excl (** fail if Open_creat and the file already exists. *)\n | Open_binary (** open in binary mode (no conversion). *)\n | Open_text (** open in text mode (may perform conversions). *)\n | Open_nonblock (** open in non-blocking mode. *)\n(** Opening modes for {!Stdlib.open_out_gen} and\n {!Stdlib.open_in_gen}. *)\n\nval open_out : string -> out_channel\n(** Open the named file for writing, and return a new output channel\n on that file, positioned at the beginning of the file. The\n file is truncated to zero length if it already exists. It\n is created if it does not already exists. *)\n\nval open_out_bin : string -> out_channel\n(** Same as {!Stdlib.open_out}, but the file is opened in binary mode,\n so that no translation takes place during writes. On operating\n systems that do not distinguish between text mode and binary\n mode, this function behaves like {!Stdlib.open_out}. *)\n\nval open_out_gen : open_flag list -> int -> string -> out_channel\n(** [open_out_gen mode perm filename] opens the named file for writing,\n as described above. The extra argument [mode]\n specifies the opening mode. The extra argument [perm] specifies\n the file permissions, in case the file must be created.\n {!Stdlib.open_out} and {!Stdlib.open_out_bin} are special\n cases of this function. *)\n\nval flush : out_channel -> unit\n(** Flush the buffer associated with the given output channel,\n performing all pending writes on that channel.\n Interactive programs must be careful about flushing standard\n output and standard error at the right time. *)\n\nval flush_all : unit -> unit\n(** Flush all open output channels; ignore errors. *)\n\nval output_char : out_channel -> char -> unit\n(** Write the character on the given output channel. *)\n\nval output_string : out_channel -> string -> unit\n(** Write the string on the given output channel. *)\n\nval output_bytes : out_channel -> bytes -> unit\n(** Write the byte sequence on the given output channel.\n @since 4.02.0 *)\n\nval output : out_channel -> bytes -> int -> int -> unit\n(** [output oc buf pos len] writes [len] characters from byte sequence [buf],\n starting at offset [pos], to the given output channel [oc].\n @raise Invalid_argument if [pos] and [len] do not\n designate a valid range of [buf]. *)\n\nval output_substring : out_channel -> string -> int -> int -> unit\n(** Same as [output] but take a string as argument instead of\n a byte sequence.\n @since 4.02.0 *)\n\nval output_byte : out_channel -> int -> unit\n(** Write one 8-bit integer (as the single character with that code)\n on the given output channel. The given integer is taken modulo\n 256. *)\n\nval output_binary_int : out_channel -> int -> unit\n(** Write one integer in binary format (4 bytes, big-endian)\n on the given output channel.\n The given integer is taken modulo 2{^32}.\n The only reliable way to read it back is through the\n {!Stdlib.input_binary_int} function. The format is compatible across\n all machines for a given version of OCaml. *)\n\nval output_value : out_channel -> 'a -> unit\n(** Write the representation of a structured value of any type\n to a channel. Circularities and sharing inside the value\n are detected and preserved. The object can be read back,\n by the function {!Stdlib.input_value}. See the description of module\n {!Marshal} for more information. {!Stdlib.output_value} is equivalent\n to {!Marshal.to_channel} with an empty list of flags. *)\n\nval seek_out : out_channel -> int -> unit\n(** [seek_out chan pos] sets the current writing position to [pos]\n for channel [chan]. This works only for regular files. On\n files of other kinds (such as terminals, pipes and sockets),\n the behavior is unspecified. *)\n\nval pos_out : out_channel -> int\n(** Return the current writing position for the given channel. Does\n not work on channels opened with the [Open_append] flag (returns\n unspecified results).\n For files opened in text mode under Windows, the returned position\n is approximate (owing to end-of-line conversion); in particular,\n saving the current position with [pos_out], then going back to\n this position using [seek_out] will not work. For this\n programming idiom to work reliably and portably, the file must be\n opened in binary mode. *)\n\nval out_channel_length : out_channel -> int\n(** Return the size (number of characters) of the regular file\n on which the given channel is opened. If the channel is opened\n on a file that is not a regular file, the result is meaningless. *)\n\nval close_out : out_channel -> unit\n(** Close the given channel, flushing all buffered write operations.\n Output functions raise a [Sys_error] exception when they are\n applied to a closed output channel, except [close_out] and [flush],\n which do nothing when applied to an already closed channel.\n Note that [close_out] may raise [Sys_error] if the operating\n system signals an error when flushing or closing. *)\n\nval close_out_noerr : out_channel -> unit\n(** Same as [close_out], but ignore all errors. *)\n\nval set_binary_mode_out : out_channel -> bool -> unit\n(** [set_binary_mode_out oc true] sets the channel [oc] to binary\n mode: no translations take place during output.\n [set_binary_mode_out oc false] sets the channel [oc] to text\n mode: depending on the operating system, some translations\n may take place during output. For instance, under Windows,\n end-of-lines will be translated from [\\n] to [\\r\\n].\n This function has no effect under operating systems that\n do not distinguish between text mode and binary mode. *)\n\n\n(** {2 General input functions} *)\n\nval open_in : string -> in_channel\n(** Open the named file for reading, and return a new input channel\n on that file, positioned at the beginning of the file. *)\n\nval open_in_bin : string -> in_channel\n(** Same as {!Stdlib.open_in}, but the file is opened in binary mode,\n so that no translation takes place during reads. On operating\n systems that do not distinguish between text mode and binary\n mode, this function behaves like {!Stdlib.open_in}. *)\n\nval open_in_gen : open_flag list -> int -> string -> in_channel\n(** [open_in_gen mode perm filename] opens the named file for reading,\n as described above. The extra arguments\n [mode] and [perm] specify the opening mode and file permissions.\n {!Stdlib.open_in} and {!Stdlib.open_in_bin} are special\n cases of this function. *)\n\nval input_char : in_channel -> char\n(** Read one character from the given input channel.\n @raise End_of_file if there are no more characters to read. *)\n\nval input_line : in_channel -> string\n(** Read characters from the given input channel, until a\n newline character is encountered. Return the string of\n all characters read, without the newline character at the end.\n @raise End_of_file if the end of the file is reached\n at the beginning of line. *)\n\nval input : in_channel -> bytes -> int -> int -> int\n(** [input ic buf pos len] reads up to [len] characters from\n the given channel [ic], storing them in byte sequence [buf], starting at\n character number [pos].\n It returns the actual number of characters read, between 0 and\n [len] (inclusive).\n A return value of 0 means that the end of file was reached.\n A return value between 0 and [len] exclusive means that\n not all requested [len] characters were read, either because\n no more characters were available at that time, or because\n the implementation found it convenient to do a partial read;\n [input] must be called again to read the remaining characters,\n if desired. (See also {!Stdlib.really_input} for reading\n exactly [len] characters.)\n Exception [Invalid_argument \"input\"] is raised if [pos] and [len]\n do not designate a valid range of [buf]. *)\n\nval really_input : in_channel -> bytes -> int -> int -> unit\n(** [really_input ic buf pos len] reads [len] characters from channel [ic],\n storing them in byte sequence [buf], starting at character number [pos].\n @raise End_of_file if the end of file is reached before [len]\n characters have been read.\n @raise Invalid_argument if\n [pos] and [len] do not designate a valid range of [buf]. *)\n\nval really_input_string : in_channel -> int -> string\n(** [really_input_string ic len] reads [len] characters from channel [ic]\n and returns them in a new string.\n @raise End_of_file if the end of file is reached before [len]\n characters have been read.\n @since 4.02.0 *)\n\nval input_byte : in_channel -> int\n(** Same as {!Stdlib.input_char}, but return the 8-bit integer representing\n the character.\n @raise End_of_file if the end of file was reached. *)\n\nval input_binary_int : in_channel -> int\n(** Read an integer encoded in binary format (4 bytes, big-endian)\n from the given input channel. See {!Stdlib.output_binary_int}.\n @raise End_of_file if the end of file was reached while reading the\n integer. *)\n\nval input_value : in_channel -> 'a\n(** Read the representation of a structured value, as produced\n by {!Stdlib.output_value}, and return the corresponding value.\n This function is identical to {!Marshal.from_channel};\n see the description of module {!Marshal} for more information,\n in particular concerning the lack of type safety. *)\n\nval seek_in : in_channel -> int -> unit\n(** [seek_in chan pos] sets the current reading position to [pos]\n for channel [chan]. This works only for regular files. On\n files of other kinds, the behavior is unspecified. *)\n\nval pos_in : in_channel -> int\n(** Return the current reading position for the given channel. For\n files opened in text mode under Windows, the returned position is\n approximate (owing to end-of-line conversion); in particular,\n saving the current position with [pos_in], then going back to this\n position using [seek_in] will not work. For this programming\n idiom to work reliably and portably, the file must be opened in\n binary mode. *)\n\nval in_channel_length : in_channel -> int\n(** Return the size (number of characters) of the regular file\n on which the given channel is opened. If the channel is opened\n on a file that is not a regular file, the result is meaningless.\n The returned size does not take into account the end-of-line\n translations that can be performed when reading from a channel\n opened in text mode. *)\n\nval close_in : in_channel -> unit\n(** Close the given channel. Input functions raise a [Sys_error]\n exception when they are applied to a closed input channel,\n except [close_in], which does nothing when applied to an already\n closed channel. *)\n\nval close_in_noerr : in_channel -> unit\n(** Same as [close_in], but ignore all errors. *)\n\nval set_binary_mode_in : in_channel -> bool -> unit\n(** [set_binary_mode_in ic true] sets the channel [ic] to binary\n mode: no translations take place during input.\n [set_binary_mode_out ic false] sets the channel [ic] to text\n mode: depending on the operating system, some translations\n may take place during input. For instance, under Windows,\n end-of-lines will be translated from [\\r\\n] to [\\n].\n This function has no effect under operating systems that\n do not distinguish between text mode and binary mode. *)\n\n\n(** {2 Operations on large files} *)\n\nmodule LargeFile :\n sig\n val seek_out : out_channel -> int64 -> unit\n val pos_out : out_channel -> int64\n val out_channel_length : out_channel -> int64\n val seek_in : in_channel -> int64 -> unit\n val pos_in : in_channel -> int64\n val in_channel_length : in_channel -> int64\n end\n(** Operations on large files.\n This sub-module provides 64-bit variants of the channel functions\n that manipulate file positions and file sizes. By representing\n positions and sizes by 64-bit integers (type [int64]) instead of\n regular integers (type [int]), these alternate functions allow\n operating on files whose sizes are greater than [max_int]. *)\n\n(** {1 References} *)\n\ntype 'a ref = { mutable contents : 'a }\n(** The type of references (mutable indirection cells) containing\n a value of type ['a]. *)\n\nexternal ref : 'a -> 'a ref = \"%makemutable\"\n(** Return a fresh reference containing the given value. *)\n\nexternal ( ! ) : 'a ref -> 'a = \"%field0\"\n(** [!r] returns the current contents of reference [r].\n Equivalent to [fun r -> r.contents].\n Unary operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal ( := ) : 'a ref -> 'a -> unit = \"%setfield0\"\n(** [r := a] stores the value of [a] in reference [r].\n Equivalent to [fun r v -> r.contents <- v].\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\nexternal incr : int ref -> unit = \"%incr\"\n(** Increment the integer contained in the given reference.\n Equivalent to [fun r -> r := succ !r]. *)\n\nexternal decr : int ref -> unit = \"%decr\"\n(** Decrement the integer contained in the given reference.\n Equivalent to [fun r -> r := pred !r]. *)\n\n(** {1 Result type} *)\n\n(** @since 4.03.0 *)\ntype ('a,'b) result = Ok of 'a | Error of 'b\n\n(** {1 Operations on format strings} *)\n\n(** Format strings are character strings with special lexical conventions\n that defines the functionality of formatted input/output functions. Format\n strings are used to read data with formatted input functions from module\n {!Scanf} and to print data with formatted output functions from modules\n {!Printf} and {!Format}.\n\n Format strings are made of three kinds of entities:\n - {e conversions specifications}, introduced by the special character ['%']\n followed by one or more characters specifying what kind of argument to\n read or print,\n - {e formatting indications}, introduced by the special character ['@']\n followed by one or more characters specifying how to read or print the\n argument,\n - {e plain characters} that are regular characters with usual lexical\n conventions. Plain characters specify string literals to be read in the\n input or printed in the output.\n\n There is an additional lexical rule to escape the special characters ['%']\n and ['@'] in format strings: if a special character follows a ['%']\n character, it is treated as a plain character. In other words, [\"%%\"] is\n considered as a plain ['%'] and [\"%@\"] as a plain ['@'].\n\n For more information about conversion specifications and formatting\n indications available, read the documentation of modules {!Scanf},\n {!Printf} and {!Format}.\n*)\n\n(** Format strings have a general and highly polymorphic type\n [('a, 'b, 'c, 'd, 'e, 'f) format6].\n The two simplified types, [format] and [format4] below are\n included for backward compatibility with earlier releases of\n OCaml.\n\n The meaning of format string type parameters is as follows:\n\n - ['a] is the type of the parameters of the format for formatted output\n functions ([printf]-style functions);\n ['a] is the type of the values read by the format for formatted input\n functions ([scanf]-style functions).\n\n - ['b] is the type of input source for formatted input functions and the\n type of output target for formatted output functions.\n For [printf]-style functions from module {!Printf}, ['b] is typically\n [out_channel];\n for [printf]-style functions from module {!Format}, ['b] is typically\n {!type:Format.formatter};\n for [scanf]-style functions from module {!Scanf}, ['b] is typically\n {!Scanf.Scanning.in_channel}.\n\n Type argument ['b] is also the type of the first argument given to\n user's defined printing functions for [%a] and [%t] conversions,\n and user's defined reading functions for [%r] conversion.\n\n - ['c] is the type of the result of the [%a] and [%t] printing\n functions, and also the type of the argument transmitted to the\n first argument of [kprintf]-style functions or to the\n [kscanf]-style functions.\n\n - ['d] is the type of parameters for the [scanf]-style functions.\n\n - ['e] is the type of the receiver function for the [scanf]-style functions.\n\n - ['f] is the final result type of a formatted input/output function\n invocation: for the [printf]-style functions, it is typically [unit];\n for the [scanf]-style functions, it is typically the result type of the\n receiver function.\n*)\n\ntype ('a, 'b, 'c, 'd, 'e, 'f) format6 =\n ('a, 'b, 'c, 'd, 'e, 'f) CamlinternalFormatBasics.format6\n\ntype ('a, 'b, 'c, 'd) format4 = ('a, 'b, 'c, 'c, 'c, 'd) format6\n\ntype ('a, 'b, 'c) format = ('a, 'b, 'c, 'c) format4\n\nval string_of_format : ('a, 'b, 'c, 'd, 'e, 'f) format6 -> string\n(** Converts a format string into a string. *)\n\nexternal format_of_string :\n ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n ('a, 'b, 'c, 'd, 'e, 'f) format6 = \"%identity\"\n(** [format_of_string s] returns a format string read from the string\n literal [s].\n Note: [format_of_string] can not convert a string argument that is not a\n literal. If you need this functionality, use the more general\n {!Scanf.format_from_string} function.\n*)\n\nval ( ^^ ) :\n ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n ('f, 'b, 'c, 'e, 'g, 'h) format6 ->\n ('a, 'b, 'c, 'd, 'g, 'h) format6\n(** [f1 ^^ f2] catenates format strings [f1] and [f2]. The result is a\n format string that behaves as the concatenation of format strings [f1] and\n [f2]: in case of formatted output, it accepts arguments from [f1], then\n arguments from [f2]; in case of formatted input, it returns results from\n [f1], then results from [f2].\n Right-associative operator, see {!Ocaml_operators} for more information.\n*)\n\n(** {1 Program termination} *)\n\nval exit : int -> 'a\n(** Terminate the process, returning the given status code\n to the operating system: usually 0 to indicate no errors,\n and a small positive integer to indicate failure.\n All open output channels are flushed with [flush_all].\n An implicit [exit 0] is performed each time a program\n terminates normally. An implicit [exit 2] is performed if the program\n terminates early because of an uncaught exception. *)\n\nval at_exit : (unit -> unit) -> unit\n(** Register the given function to be called at program termination\n time. The functions registered with [at_exit] will be called when\n the program does any of the following:\n - executes {!Stdlib.exit}\n - terminates, either normally or because of an uncaught\n exception\n - executes the C function [caml_shutdown].\n The functions are called in 'last in, first out' order: the\n function most recently added with [at_exit] is called first. *)\n\n(**/**)\n\n(* The following is for system use only. Do not call directly. *)\n\nval valid_float_lexem : string -> string\n\nval unsafe_really_input : in_channel -> bytes -> int -> int -> unit\n\nval do_at_exit : unit -> unit\n\n(**/**)\n\n(** {1:modules Standard library modules } *)\n\n(*MODULE_ALIASES*)\nmodule Arg = Arg\nmodule Array = Array\nmodule ArrayLabels = ArrayLabels\nmodule Atomic = Atomic\nmodule Bigarray = Bigarray\nmodule Bool = Bool\nmodule Buffer = Buffer\nmodule Bytes = Bytes\nmodule BytesLabels = BytesLabels\nmodule Callback = Callback\nmodule Char = Char\nmodule Complex = Complex\nmodule Digest = Digest\nmodule Either = Either\nmodule Ephemeron = Ephemeron\nmodule Filename = Filename\nmodule Float = Float\nmodule Format = Format\nmodule Fun = Fun\nmodule Gc = Gc\nmodule Genlex = Genlex\n[@@deprecated \"Use the camlp-streams library instead.\"]\nmodule Hashtbl = Hashtbl\nmodule In_channel = In_channel\nmodule Int = Int\nmodule Int32 = Int32\nmodule Int64 = Int64\nmodule Lazy = Lazy\nmodule Lexing = Lexing\nmodule List = List\nmodule ListLabels = ListLabels\nmodule Map = Map\nmodule Marshal = Marshal\nmodule MoreLabels = MoreLabels\nmodule Nativeint = Nativeint\nmodule Obj = Obj\nmodule Oo = Oo\nmodule Option = Option\nmodule Out_channel = Out_channel\nmodule Parsing = Parsing\nmodule Pervasives = Pervasives\n[@@deprecated \"Use Stdlib instead.\\n\\\n\\n\\\nIf you need to stay compatible with OCaml < 4.07, you can use the \\n\\\nstdlib-shims library: https://github.com/ocaml/stdlib-shims\"]\nmodule Printexc = Printexc\nmodule Printf = Printf\nmodule Queue = Queue\nmodule Random = Random\nmodule Result = Result\nmodule Scanf = Scanf\nmodule Seq = Seq\nmodule Set = Set\nmodule Stack = Stack\nmodule StdLabels = StdLabels\nmodule Stream = Stream\n[@@deprecated \"Use the camlp-streams library instead.\"]\nmodule String = String\nmodule StringLabels = StringLabels\nmodule Sys = Sys\nmodule Uchar = Uchar\nmodule Unit = Unit\nmodule Weak = Weak\n","(** An interface to use for int-like types, e.g., {{!Base.Int}[Int]} and\n {{!Base.Int64}[Int64]}. *)\n\nopen! Import\n\nmodule type Round = sig\n type t\n\n (** [round] rounds an int to a multiple of a given [to_multiple_of] argument, according\n to a direction [dir], with default [dir] being [`Nearest]. [round] will raise if\n [to_multiple_of <= 0]. If the result overflows (too far positive or too far\n negative), [round] returns an incorrect result.\n\n {v\n | `Down | rounds toward Int.neg_infinity |\n | `Up | rounds toward Int.infinity |\n | `Nearest | rounds to the nearest multiple, or `Up in case of a tie |\n | `Zero | rounds toward zero |\n v}\n\n Here are some examples for [round ~to_multiple_of:10] for each direction:\n\n {v\n | `Down | {10 .. 19} --> 10 | { 0 ... 9} --> 0 | {-10 ... -1} --> -10 |\n | `Up | { 1 .. 10} --> 10 | {-9 ... 0} --> 0 | {-19 .. -10} --> -10 |\n | `Zero | {10 .. 19} --> 10 | {-9 ... 9} --> 0 | {-19 .. -10} --> -10 |\n | `Nearest | { 5 .. 14} --> 10 | {-5 ... 4} --> 0 | {-15 ... -6} --> -10 |\n v}\n\n For convenience and performance, there are variants of [round] with [dir]\n hard-coded. If you are writing performance-critical code you should use these. *)\n\n val round : ?dir:[ `Zero | `Nearest | `Up | `Down ] -> t -> to_multiple_of:t -> t\n val round_towards_zero : t -> to_multiple_of:t -> t\n val round_down : t -> to_multiple_of:t -> t\n val round_up : t -> to_multiple_of:t -> t\n val round_nearest : t -> to_multiple_of:t -> t\nend\n\nmodule type Hexable = sig\n type t\n\n module Hex : sig\n type nonrec t = t [@@deriving_inline sexp, compare, hash]\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n val compare : t -> t -> int\n val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state\n val hash : t -> Ppx_hash_lib.Std.Hash.hash_value\n\n [@@@end]\n\n include Stringable.S with type t := t\n\n val to_string_hum : ?delimiter:char -> t -> string\n end\nend\n\nmodule type S_common = sig\n type t [@@deriving_inline sexp, sexp_grammar]\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n val t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t\n\n [@@@end]\n\n include Floatable.S with type t := t\n include Intable.S with type t := t\n include Identifiable.S with type t := t\n include Comparable.With_zero with type t := t\n include Invariant.S with type t := t\n include Hexable with type t := t\n\n (** [delimiter] is an underscore by default. *)\n val to_string_hum : ?delimiter:char -> t -> string\n\n (** {2 Infix operators and constants} *)\n\n val zero : t\n val one : t\n val minus_one : t\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val ( * ) : t -> t -> t\n\n (** Integer exponentiation *)\n val ( ** ) : t -> t -> t\n\n (** Negation *)\n\n val neg : t -> t\n val ( ~- ) : t -> t\n\n (** There are two pairs of integer division and remainder functions, [/%] and [%], and\n [/] and [rem]. They both satisfy the same equation relating the quotient and the\n remainder:\n\n {[\n x = (x /% y) * y + (x % y);\n x = (x / y) * y + (rem x y);\n ]}\n\n The functions return the same values if [x] and [y] are positive. They all raise\n if [y = 0].\n\n The functions differ if [x < 0] or [y < 0].\n\n If [y < 0], then [%] and [/%] raise, whereas [/] and [rem] do not.\n\n [x % y] always returns a value between 0 and [y - 1], even when [x < 0]. On the\n other hand, [rem x y] returns a negative value if and only if [x < 0]; that value\n satisfies [abs (rem x y) <= abs y - 1]. *)\n\n val ( /% ) : t -> t -> t\n val ( % ) : t -> t -> t\n val ( / ) : t -> t -> t\n val rem : t -> t -> t\n\n (** Float division of integers. *)\n val ( // ) : t -> t -> float\n\n (** Same as [bit_and]. *)\n val ( land ) : t -> t -> t\n\n (** Same as [bit_or]. *)\n val ( lor ) : t -> t -> t\n\n (** Same as [bit_xor]. *)\n val ( lxor ) : t -> t -> t\n\n (** Same as [bit_not]. *)\n val lnot : t -> t\n\n (** Same as [shift_left]. *)\n val ( lsl ) : t -> int -> t\n\n (** Same as [shift_right]. *)\n val ( asr ) : t -> int -> t\n\n (** {2 Other common functions} *)\n\n include Round with type t := t\n\n (** Returns the absolute value of the argument. May be negative if the input is\n [min_value]. *)\n val abs : t -> t\n\n (** {2 Successor and predecessor functions} *)\n\n val succ : t -> t\n val pred : t -> t\n\n (** {2 Exponentiation} *)\n\n (** [pow base exponent] returns [base] raised to the power of [exponent]. It is OK if\n [base <= 0]. [pow] raises if [exponent < 0], or an integer overflow would occur. *)\n val pow : t -> t -> t\n\n (** {2 Bit-wise logical operations } *)\n\n (** These are identical to [land], [lor], etc. except they're not infix and have\n different names. *)\n val bit_and : t -> t -> t\n\n val bit_or : t -> t -> t\n val bit_xor : t -> t -> t\n val bit_not : t -> t\n\n (** Returns the number of 1 bits in the binary representation of the input. *)\n val popcount : t -> int\n\n (** {2 Bit-shifting operations }\n\n The results are unspecified for negative shifts and shifts [>= num_bits]. *)\n\n (** Shifts left, filling in with zeroes. *)\n val shift_left : t -> int -> t\n\n (** Shifts right, preserving the sign of the input. *)\n val shift_right : t -> int -> t\n\n (** {2 Increment and decrement functions for integer references } *)\n\n val decr : t ref -> unit\n val incr : t ref -> unit\n\n (** {2 Conversion functions to related integer types} *)\n\n val of_int32_exn : int32 -> t\n val to_int32_exn : t -> int32\n val of_int64_exn : int64 -> t\n val to_int64 : t -> int64\n val of_nativeint_exn : nativeint -> t\n val to_nativeint_exn : t -> nativeint\n\n (** [of_float_unchecked] truncates the given floating point number to an integer,\n rounding towards zero.\n The result is unspecified if the argument is nan or falls outside the range\n of representable integers. *)\n val of_float_unchecked : float -> t\nend\n\nmodule type Operators_unbounded = sig\n type t\n\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val ( * ) : t -> t -> t\n val ( / ) : t -> t -> t\n val ( ~- ) : t -> t\n val ( ** ) : t -> t -> t\n\n include Comparisons.Infix with type t := t\n\n val abs : t -> t\n val neg : t -> t\n val zero : t\n val ( % ) : t -> t -> t\n val ( /% ) : t -> t -> t\n val ( // ) : t -> t -> float\n val ( land ) : t -> t -> t\n val ( lor ) : t -> t -> t\n val ( lxor ) : t -> t -> t\n val lnot : t -> t\n val ( lsl ) : t -> int -> t\n val ( asr ) : t -> int -> t\nend\n\nmodule type Operators = sig\n include Operators_unbounded\n\n val ( lsr ) : t -> int -> t\nend\n\n(** [S_unbounded] is a generic interface for unbounded integers, e.g. [Bignum.Bigint].\n [S_unbounded] is a restriction of [S] (below) that omits values that depend on\n fixed-size integers. *)\nmodule type S_unbounded = sig\n include S_common (** @inline *)\n\n (** A sub-module designed to be opened to make working with ints more convenient. *)\n module O : Operators_unbounded with type t := t\nend\n\n(** [S] is a generic interface for fixed-size integers. *)\nmodule type S = sig\n include S_common (** @inline *)\n\n (** The number of bits available in this integer type. Note that the integer\n representations are signed. *)\n val num_bits : int\n\n (** The largest representable integer. *)\n val max_value : t\n\n (** The smallest representable integer. *)\n val min_value : t\n\n (** Same as [shift_right_logical]. *)\n val ( lsr ) : t -> int -> t\n\n (** Shifts right, filling in with zeroes, which will not preserve the sign of the\n input. *)\n val shift_right_logical : t -> int -> t\n\n (** [ceil_pow2 x] returns the smallest power of 2 that is greater than or equal to [x].\n The implementation may only be called for [x > 0]. Example: [ceil_pow2 17 = 32] *)\n val ceil_pow2 : t -> t\n\n (** [floor_pow2 x] returns the largest power of 2 that is less than or equal to [x]. The\n implementation may only be called for [x > 0]. Example: [floor_pow2 17 = 16] *)\n val floor_pow2 : t -> t\n\n (** [ceil_log2 x] returns the ceiling of log-base-2 of [x], and raises if [x <= 0]. *)\n val ceil_log2 : t -> int\n\n (** [floor_log2 x] returns the floor of log-base-2 of [x], and raises if [x <= 0]. *)\n val floor_log2 : t -> int\n\n (** [is_pow2 x] returns true iff [x] is a power of 2. [is_pow2] raises if [x <= 0]. *)\n val is_pow2 : t -> bool\n\n (** Returns the number of leading zeros in the binary representation of the input, as an\n integer between 0 and one less than [num_bits].\n\n The results are unspecified for [t = 0]. *)\n val clz : t -> int\n\n (** Returns the number of trailing zeros in the binary representation of the input, as\n an integer between 0 and one less than [num_bits].\n\n The results are unspecified for [t = 0]. *)\n val ctz : t -> int\n\n (** A sub-module designed to be opened to make working with ints more convenient. *)\n module O : Operators with type t := t\nend\n\ninclude (\nstruct\n (** Various functors whose type-correctness ensures desired relationships between\n interfaces. *)\n\n module Check_O_contained_in_S (M : S) : module type of M.O = M\n module Check_O_contained_in_S_unbounded (M : S_unbounded) : module type of M.O = M\n module Check_S_unbounded_in_S (M : S) : S_unbounded = M\nend :\nsig end)\n\nmodule type Int_without_module_types = sig\n include S with type t = int\n\n (** [max_value_30_bits = 2^30 - 1]. It is useful for writing tests that work on both\n 64-bit and 32-bit platforms. *)\n val max_value_30_bits : t\n\n (** {2 Conversion functions} *)\n\n val of_int : int -> t\n val to_int : t -> int\n val of_int32 : int32 -> t option\n val to_int32 : t -> int32 option\n val of_int64 : int64 -> t option\n val of_nativeint : nativeint -> t option\n val to_nativeint : t -> nativeint\n\n (** {3 Truncating conversions}\n\n These functions return the least-significant bits of the input. In cases\n where optional conversions return [Some x], truncating conversions return [x]. *)\n\n val of_int32_trunc : int32 -> t\n val to_int32_trunc : t -> int32\n val of_int64_trunc : int64 -> t\n val of_nativeint_trunc : nativeint -> t\n\n (** {2 Byte swap operations}\n\n Byte swap operations reverse the order of bytes in an integer. For\n example, {!Int32.bswap32} reorders the bottom 32 bits (or 4 bytes),\n turning [0x1122_3344] to [0x4433_2211]. Byte swap functions exposed by\n Base use OCaml primitives to generate assembly instructions to perform\n the relevant byte swaps.\n\n For a more extensive list of byteswap functions, see {!Int32} and\n {!Int64}.\n *)\n\n (** Byte swaps bottom 16 bits (2 bytes). The values of the remaining bytes\n are undefined. *)\n val bswap16 : t -> t\n\n (**/**)\n\n (*_ See the Jane Street Style Guide for an explanation of [Private] submodules:\n\n https://opensource.janestreet.com/standards/#private-submodules *)\n module Private : sig\n (*_ For ../bench/bench_int.ml *)\n module O_F : sig\n val ( % ) : int -> int -> int\n val ( /% ) : int -> int -> int\n val ( // ) : int -> int -> float\n end\n end\nend\n\n(** OCaml's native integer type.\n\n The number of bits in an integer is platform dependent, being 31-bits on a 32-bit\n platform, and 63-bits on a 64-bit platform. [int] is a signed integer type. [int]s\n are also subject to overflow, meaning that [Int.max_value + 1 = Int.min_value].\n\n [int]s always fit in a machine word. *)\nmodule type Int = sig\n include Int_without_module_types\n\n (** {2 Module types specifying integer operations.} *)\n module type Hexable = Hexable\n\n module type Int_without_module_types = Int_without_module_types\n module type Operators = Operators\n module type Operators_unbounded = Operators_unbounded\n module type Round = Round\n module type S = S\n module type S_common = S_common\n module type S_unbounded = S_unbounded\nend\n","open! Import\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! Float_replace_polymorphic_compare\n\nlet ceil = Caml.ceil\nlet floor = Caml.floor\nlet mod_float = Caml.mod_float\nlet modf = Caml.modf\nlet float_of_string = Caml.float_of_string\nlet nan = Caml.nan\nlet infinity = Caml.infinity\nlet neg_infinity = Caml.neg_infinity\nlet max_finite_value = Caml.max_float\nlet epsilon_float = Caml.epsilon_float\nlet classify_float = Caml.classify_float\nlet abs_float = Caml.abs_float\nlet ( ** ) = Caml.( ** )\n\n(* The bits of INRIA's [Pervasives] that we just want to expose in [Float]. Most are\n already deprecated in [Pervasives], and eventually all of them should be. *)\ninclude (\n Caml :\n sig\n external frexp : float -> float * int = \"caml_frexp_float\"\n\n external ldexp\n : (float[@unboxed])\n -> (int[@untagged])\n -> (float[@unboxed])\n = \"caml_ldexp_float\" \"caml_ldexp_float_unboxed\"\n [@@noalloc]\n\n external log10 : float -> float = \"caml_log10_float\" \"log10\"\n [@@unboxed] [@@noalloc]\n\n external expm1 : float -> float = \"caml_expm1_float\" \"caml_expm1\"\n [@@unboxed] [@@noalloc]\n\n external log1p : float -> float = \"caml_log1p_float\" \"caml_log1p\"\n [@@unboxed] [@@noalloc]\n\n external copysign : float -> float -> float = \"caml_copysign_float\" \"caml_copysign\"\n [@@unboxed] [@@noalloc]\n\n external cos : float -> float = \"caml_cos_float\" \"cos\" [@@unboxed] [@@noalloc]\n external sin : float -> float = \"caml_sin_float\" \"sin\" [@@unboxed] [@@noalloc]\n external tan : float -> float = \"caml_tan_float\" \"tan\" [@@unboxed] [@@noalloc]\n external acos : float -> float = \"caml_acos_float\" \"acos\" [@@unboxed] [@@noalloc]\n external asin : float -> float = \"caml_asin_float\" \"asin\" [@@unboxed] [@@noalloc]\n external atan : float -> float = \"caml_atan_float\" \"atan\" [@@unboxed] [@@noalloc]\n\n external atan2 : float -> float -> float = \"caml_atan2_float\" \"atan2\"\n [@@unboxed] [@@noalloc]\n\n external hypot : float -> float -> float = \"caml_hypot_float\" \"caml_hypot\"\n [@@unboxed] [@@noalloc]\n\n external cosh : float -> float = \"caml_cosh_float\" \"cosh\" [@@unboxed] [@@noalloc]\n external sinh : float -> float = \"caml_sinh_float\" \"sinh\" [@@unboxed] [@@noalloc]\n external tanh : float -> float = \"caml_tanh_float\" \"tanh\" [@@unboxed] [@@noalloc]\n external sqrt : float -> float = \"caml_sqrt_float\" \"sqrt\" [@@unboxed] [@@noalloc]\n external exp : float -> float = \"caml_exp_float\" \"exp\" [@@unboxed] [@@noalloc]\n external log : float -> float = \"caml_log_float\" \"log\" [@@unboxed] [@@noalloc]\n end)\n\n(* We need this indirection because these are exposed as \"val\" instead of \"external\" *)\nlet frexp = frexp\nlet ldexp = ldexp\nlet is_nan x = (x : float) <> x\n\n(* An order-preserving bijection between all floats except for NaNs, and 99.95% of\n int64s.\n\n Note we don't distinguish 0. and -0. as separate values here, they both map to 0L, which\n maps back to 0.\n\n This should work both on little-endian and high-endian CPUs. Wikipedia says: \"on\n modern standard computers (i.e., implementing IEEE 754), one may in practice safely\n assume that the endianness is the same for floating point numbers as for integers\"\n (http://en.wikipedia.org/wiki/Endianness#Floating-point_and_endianness).\n*)\nlet to_int64_preserve_order t =\n if is_nan t\n then None\n else if t = 0.\n then (* also includes -0. *)\n Some 0L\n else if t > 0.\n then Some (Caml.Int64.bits_of_float t)\n else Some (Caml.Int64.neg (Caml.Int64.bits_of_float (-.t)))\n;;\n\nlet to_int64_preserve_order_exn x = Option.value_exn (to_int64_preserve_order x)\n\nlet of_int64_preserve_order x =\n if Int64_replace_polymorphic_compare.( >= ) x 0L\n then Caml.Int64.float_of_bits x\n else ~-.(Caml.Int64.float_of_bits (Caml.Int64.neg x))\n;;\n\nlet one_ulp dir t =\n match to_int64_preserve_order t with\n | None -> Caml.nan\n | Some x ->\n of_int64_preserve_order\n (Caml.Int64.add\n x\n (match dir with\n | `Up -> 1L\n | `Down -> -1L))\n;;\n\n(* [upper_bound_for_int] and [lower_bound_for_int] are for calculating the max/min float\n that fits in a given-size integer when rounded towards 0 (using [int_of_float]).\n\n max_int/min_int depend on [num_bits], e.g. +/- 2^30, +/- 2^62 if 31-bit, 63-bit\n (respectively) while float is IEEE standard for double (52 significant bits).\n\n In all cases, we want to guarantee that\n [lower_bound_for_int <= x <= upper_bound_for_int]\n iff [int_of_float x] fits in an int with [num_bits] bits.\n\n [2 ** (num_bits - 1)] is the first float greater that max_int, we use the preceding\n float as upper bound.\n\n [- (2 ** (num_bits - 1))] is equal to min_int.\n For lower bound we look for the smallest float [f] satisfying [f > min_int - 1] so that\n [f] rounds toward zero to [min_int]\n\n So in particular we will have:\n [lower_bound_for_int x <= - (2 ** (1-x))]\n [upper_bound_for_int x < 2 ** (1-x) ]\n*)\nlet upper_bound_for_int num_bits =\n let exp = Caml.float_of_int (num_bits - 1) in\n one_ulp `Down (2. ** exp)\n;;\n\nlet is_x_minus_one_exact x =\n (* [x = x -. 1.] does not work with x87 floating point arithmetic backend (which is used\n on 32-bit ocaml) because of 80-bit register precision of intermediate computations.\n\n An alternative way of computing this: [x -. one_ulp `Down x <= 1.] is also prone to\n the same precision issues: you need to make sure [x] is 64-bit.\n *)\n let open Int64_replace_polymorphic_compare in\n not (Caml.Int64.bits_of_float x = Caml.Int64.bits_of_float (x -. 1.))\n;;\n\nlet lower_bound_for_int num_bits =\n let exp = Caml.float_of_int (num_bits - 1) in\n let min_int_as_float = ~-.(2. ** exp) in\n let open Int_replace_polymorphic_compare in\n if num_bits - 1 < 53 (* 53 = #bits in the float's mantissa with sign included *)\n then (\n (* The smallest float that rounds towards zero to [min_int] is\n [min_int - 1 + epsilon] *)\n assert (is_x_minus_one_exact min_int_as_float);\n one_ulp `Up (min_int_as_float -. 1.))\n else (\n (* [min_int_as_float] is already the smallest float [f] satisfying [f > min_int - 1]. *)\n assert (not (is_x_minus_one_exact min_int_as_float));\n min_int_as_float)\n;;\n\n(* Float clamping is structured slightly differently than clamping for other types, so\n that we get the behavior of [clamp_unchecked nan ~min ~max = nan] (for any [min] and\n [max]) for free.\n*)\nlet clamp_unchecked (t : float) ~min ~max =\n if t < min then min else if max < t then max else t\n;;\n\nlet box =\n (* Prevent potential constant folding of [+. 0.] in the near ocamlopt future. *)\n let x = Sys0.opaque_identity 0. in\n fun f -> f +. x\n;;\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Float_replace_polymorphic_compare\n","open Core_kernel\nopen Import\nopen Deferred_std\nmodule Stream = Async_stream\n\nlet show_debug_messages = ref false\nlet check_invariant = ref false\n\nmodule Flushed_result = struct\n type t =\n [ `Ok\n | `Reader_closed\n ]\n [@@deriving compare, sexp_of]\n\n let equal = [%compare.equal: t]\n\n let combine (l : t Deferred.t list) =\n let%map l = Deferred.all l in\n match List.mem l `Reader_closed ~equal with\n | true -> `Reader_closed\n | false -> `Ok\n ;;\nend\n\n(* A [Consumer.t] acts as the monitor of some process that reads values from a pipe and\n processes them, allowing that process:\n - to communicate that it has taken responsibility for the values\n - to signal when it has finished with the values to interested parties (via\n [downstream_flushed])\n\n It is used in two steps:\n\n 1. calling [Consumer.start] at the point where the consumer takes values out of the\n Pipe via [read] or [read'].\n\n 2. calling [Consumer.values_sent_downstream].\n\n By calling [values_sent_downstream] one asserts that the [downstream_flushed] function\n supplied to [create] will now wait for this value.\n\n If no [Consumer.t] is supplied when a value is read then the value is defined to be\n flushed at that time. *)\nmodule Consumer : sig\n type t [@@deriving sexp_of]\n\n include Invariant.S with type t := t\n\n val create\n : pipe_id:int\n -> downstream_flushed:(unit -> Flushed_result.t Deferred.t)\n -> t\n\n val pipe_id : t -> int\n val start : t -> unit\n val values_sent_downstream : t -> unit\n val values_sent_downstream_and_flushed : t -> Flushed_result.t Deferred.t\nend = struct\n type t =\n { pipe_id : int\n ; (* [values_read] reflects whether values the consumer has read from the pipe have been\n sent downstream or if not, holds an ivar that is to be filled when they are. *)\n mutable values_read :\n [ `Have_been_sent_downstream | `Have_not_been_sent_downstream of unit Ivar.t ]\n ; (* [downstream_flushed ()] returns when all prior values that the consumer has\n passed downstream have been flushed all the way down the chain of pipes. *)\n downstream_flushed : unit -> Flushed_result.t Deferred.t\n }\n [@@deriving fields, sexp_of]\n\n let invariant t : unit =\n try\n let check f field = f (Field.get field t) in\n Fields.iter\n ~pipe_id:ignore\n ~values_read:\n (check (function\n | `Have_been_sent_downstream -> ()\n | `Have_not_been_sent_downstream ivar -> assert (Ivar.is_empty ivar)))\n ~downstream_flushed:ignore\n with\n | exn ->\n raise_s [%message \"Pipe.Consumer.invariant failed\" (exn : exn) ~pipe:(t : t)]\n ;;\n\n let create ~pipe_id ~downstream_flushed =\n { pipe_id; values_read = `Have_been_sent_downstream; downstream_flushed }\n ;;\n\n let start t =\n match t.values_read with\n | `Have_not_been_sent_downstream _ -> ()\n | `Have_been_sent_downstream ->\n t.values_read <- `Have_not_been_sent_downstream (Ivar.create ())\n ;;\n\n let values_sent_downstream t =\n match t.values_read with\n | `Have_been_sent_downstream -> ()\n | `Have_not_been_sent_downstream ivar ->\n Ivar.fill ivar ();\n t.values_read <- `Have_been_sent_downstream\n ;;\n\n let values_sent_downstream_and_flushed t =\n match t.values_read with\n | `Have_been_sent_downstream -> t.downstream_flushed ()\n | `Have_not_been_sent_downstream when_sent_downstream ->\n let%bind () = Ivar.read when_sent_downstream in\n t.downstream_flushed ()\n ;;\nend\n\nmodule Blocked_read = struct\n (* A [Blocked_read.t] represents a blocked read attempt. If someone reads from an empty\n pipe, they enqueue a [Blocked_read.t] in the queue of [blocked_reads]. Later, when\n values are written to a pipe, that will cause some number of blocked reads to be\n filled, first come first serve. The blocked-read constructor specifies how many\n values a read should consume from the pipe when it gets its turn.\n\n If a pipe is closed, then all blocked reads will be filled with [`Eof]. *)\n type 'a wants =\n | Zero of [ `Eof | `Ok ] Ivar.t\n | One of [ `Eof | `Ok of 'a ] Ivar.t\n | At_most of int * [ `Eof | `Ok of 'a Queue.t ] Ivar.t\n [@@deriving sexp_of]\n\n type 'a t =\n { wants : 'a wants\n ; consumer : Consumer.t option\n }\n [@@deriving fields, sexp_of]\n\n let invariant t : unit =\n try\n let check f field = f (Field.get field t) in\n Fields.iter\n ~wants:\n (check (function\n | Zero _ | One _ -> ()\n | At_most (i, _) -> assert (i > 0)))\n ~consumer:\n (check (function\n | None -> ()\n | Some consumer -> Consumer.invariant consumer))\n with\n | exn ->\n raise_s [%message \"Pipe.Blocked_read.invariant failed\" (exn : exn) ~pipe:(t : _ t)]\n ;;\n\n let create wants consumer = { wants; consumer }\n\n let is_empty t =\n match t.wants with\n | Zero i -> Ivar.is_empty i\n | One i -> Ivar.is_empty i\n | At_most (_, i) -> Ivar.is_empty i\n ;;\n\n let fill_with_eof t =\n match t.wants with\n | Zero i -> Ivar.fill i `Eof\n | One i -> Ivar.fill i `Eof\n | At_most (_, i) -> Ivar.fill i `Eof\n ;;\nend\n\nmodule Blocked_flush = struct\n (* A [Blocked_flush.t] represents a blocked flush operation, which can be enabled by a\n future read. If someone does [flushed p] on a pipe, that blocks until everything\n that's currently in the pipe at that point has drained out of the pipe. When we call\n [flushed], it records the total amount of data that has been written so far in\n [fill_when_num_values_read]. We fill the [Flush.t] with [`Ok] when this amount of\n data has been read from the pipe.\n\n A [Blocked_flush.t] can also be filled with [`Reader_closed], which happens when the\n reader end of the pipe is closed, and we are thus sure that the unread elements\n preceding the flush will never be read. *)\n type t =\n { fill_when_num_values_read : int\n ; ready : [ `Ok | `Reader_closed ] Ivar.t\n }\n [@@deriving fields, sexp_of]\n\n let fill t v = Ivar.fill t.ready v\nend\n\ntype ('a, 'phantom) t =\n { (* [id] is an integer used to distinguish pipes when debugging. *)\n id : int Sexp_hidden_in_test.t\n ; (* [info] is user-provided arbitrary sexp, for debugging purposes. *)\n mutable info : Sexp.t option [@sexp.option]\n ; (* [buffer] holds values written to the pipe that have not yet been read. *)\n mutable buffer : 'a Queue.t\n ; (* [size_budget] governs pushback on writers to the pipe.\n\n There is *no* invariant that [Queue.length buffer <= size_budget]. There is no\n hard upper bound on the number of elements that can be stuffed into the [buffer].\n This is due to the way we handle writes. When we do a write, all of the values\n written are immediately enqueued into [buffer]. After the write, if [Queue.length\n buffer <= t.size_budget], then the writer will be notified to continue writing.\n After the write, if [length t > t.size_budget], then the write will block until the\n pipe is under budget. *)\n mutable size_budget : int\n ; (* [pushback] is used to give feedback to writers about whether they should write to\n the pipe. [pushback] is full iff [length t <= t.size_budget || is_closed t]. *)\n mutable pushback : unit Ivar.t\n ; (* [num_values_read] keeps track of the total number of values that have been read\n from the pipe. We do not have to worry about overflow in [num_values_read]. You'd\n need to write 2^62 elements to the pipe, which would take about 146 years, at a\n flow rate of 1 size-unit/nanosecond. *)\n mutable num_values_read : int\n ; (* [blocked_flushes] holds flushes whose preceding elements have not been completely\n read. For each blocked flush, the number of elements that need to be read from the\n pipe in order to fill the flush is :\n\n fill_when_num_values_read - num_values_read\n\n Keeping the data in this form allows us to change a single field(num_values_read)\n when we consume values instead of having to iterate over the whole queue of\n flushes. *)\n blocked_flushes : Blocked_flush.t Queue.t\n ; (* [blocked_reads] holds reads that are waiting on data to be written to the pipe. *)\n blocked_reads : 'a Blocked_read.t Queue.t\n ; (* [closed] is filled when we close the write end of the pipe. *)\n closed : unit Ivar.t\n ; (* [read_closed] is filled when we close the read end of the pipe. *)\n read_closed : unit Ivar.t\n ; (* [consumers] is a list of all consumers that may be handling values read from the\n pipe. *)\n mutable consumers : Consumer.t list\n ; (* [upstream_flusheds] has a function for each pipe immediately upstream of this one.\n That function walks to the head(s) of the upstream pipe, and calls\n [downstream_flushed] on the head(s). See the definition of [upstream_flushed]\n below. *)\n upstream_flusheds : (unit -> Flushed_result.t Deferred.t) Bag.t\n }\n[@@deriving fields, sexp_of]\n\ntype ('a, 'phantom) pipe = ('a, 'phantom) t [@@deriving sexp_of]\n\nlet hash t = Hashtbl.hash t.id\nlet equal (t1 : (_, _) t) t2 = phys_equal t1 t2\nlet compare t1 t2 = Int.compare t1.id t2.id\nlet is_closed t = Ivar.is_full t.closed\nlet is_read_closed t = Ivar.is_full t.read_closed\nlet closed t = Ivar.read t.closed\nlet pushback t = Ivar.read t.pushback\nlet length t = Queue.length t.buffer\nlet is_empty t = length t = 0\n\nlet invariant t : unit =\n try\n let check f field = f (Field.get field t) in\n Fields.iter\n ~id:ignore\n ~info:ignore\n ~buffer:ignore\n ~size_budget:(check (fun size_budget -> assert (size_budget >= 0)))\n ~pushback:\n (check (fun pushback ->\n assert (\n Bool.equal\n (Ivar.is_full pushback)\n (length t <= t.size_budget || is_closed t))))\n ~num_values_read:ignore\n ~blocked_flushes:\n (check (fun blocked_flushes ->\n Queue.iter blocked_flushes ~f:(fun (f : Blocked_flush.t) ->\n assert (f.fill_when_num_values_read > t.num_values_read));\n assert (\n List.is_sorted\n ~compare:Int.compare\n (List.map\n (Queue.to_list blocked_flushes)\n ~f:Blocked_flush.fill_when_num_values_read));\n if is_empty t then assert (Queue.is_empty blocked_flushes)))\n ~blocked_reads:\n (check (fun blocked_reads ->\n (* If data is available, no one is waiting for it. This would need to change if\n we ever implement [read_exactly] as an atomic operation. *)\n if not (is_empty t) then assert (Queue.is_empty blocked_reads);\n Queue.iter blocked_reads ~f:(fun read ->\n Blocked_read.invariant read;\n assert (Blocked_read.is_empty read));\n (* You never block trying to read a closed pipe. *)\n if is_closed t then assert (Queue.is_empty blocked_reads)))\n ~closed:ignore\n ~read_closed:ignore\n ~consumers:\n (check (fun l ->\n List.iter l ~f:(fun consumer ->\n Consumer.invariant consumer;\n assert (Consumer.pipe_id consumer = t.id))))\n ~upstream_flusheds:ignore\n with\n | exn -> raise_s [%message \"Pipe.invariant failed\" (exn : exn) ~pipe:(t : (_, _) t)]\n;;\n\nmodule Reader = struct\n type phantom [@@deriving sexp_of]\n type 'a t = ('a, phantom) pipe [@@deriving sexp_of]\n\n let invariant = invariant\nend\n\nmodule Writer = struct\n type phantom [@@deriving sexp_of]\n type 'a t = ('a, phantom) pipe [@@deriving sexp_of]\n\n let invariant = invariant\nend\n\nlet id_ref = ref 0\n\nlet create_internal ~info ~initial_buffer =\n incr id_ref;\n let t =\n { id = !id_ref\n ; info\n ; closed = Ivar.create ()\n ; read_closed = Ivar.create ()\n ;\n size_budget = 0\n ; pushback = Ivar.create ()\n ; buffer = initial_buffer\n ; num_values_read = 0\n ; blocked_flushes = Queue.create ()\n ; blocked_reads = Queue.create ()\n ; consumers = []\n ; upstream_flusheds = Bag.create ()\n }\n in\n t\n;;\n\nlet create ?info () =\n let t = create_internal ~info ~initial_buffer:(Queue.create ()) in\n (* initially, the pipe does not pushback *)\n Ivar.fill t.pushback ();\n if !check_invariant then invariant t;\n t, t\n;;\n\nlet update_pushback t =\n if length t <= t.size_budget || is_closed t\n then Ivar.fill_if_empty t.pushback ()\n else if Ivar.is_full t.pushback\n then t.pushback <- Ivar.create ()\n;;\n\nlet close t =\n if !show_debug_messages then eprints \"close\" t [%sexp_of: (_, _) t];\n if !check_invariant then invariant t;\n if not (is_closed t)\n then (\n Ivar.fill t.closed ();\n if is_empty t\n then (\n Queue.iter t.blocked_reads ~f:Blocked_read.fill_with_eof;\n Queue.clear t.blocked_reads);\n update_pushback t)\n;;\n\nlet close_read t =\n if !show_debug_messages then eprints \"close_read\" t [%sexp_of: (_, _) t];\n if !check_invariant then invariant t;\n if not (is_read_closed t)\n then (\n Ivar.fill t.read_closed ();\n Queue.iter t.blocked_flushes ~f:(fun flush ->\n Blocked_flush.fill flush `Reader_closed);\n Queue.clear t.blocked_flushes;\n Queue.clear t.buffer;\n update_pushback t;\n (* we just cleared the buffer, so may need to fill [t.pushback] *)\n close t)\n;;\n\nlet create_reader_not_close_on_exception f =\n let r, w = create () in\n upon (f w) (fun () -> close w);\n r\n;;\n\nlet create_reader ~close_on_exception f =\n if not close_on_exception\n then create_reader_not_close_on_exception f\n else (\n let r, w = create () in\n don't_wait_for\n (Monitor.protect\n (fun () -> f w)\n ~finally:(fun () ->\n close w;\n return ()));\n r)\n;;\n\nlet create_writer f =\n let r, w = create () in\n don't_wait_for\n (Monitor.protect\n (fun () -> f r)\n ~finally:(fun () ->\n close_read r;\n return ()));\n w\n;;\n\nlet values_were_read t consumer =\n Option.iter consumer ~f:Consumer.start;\n let rec loop () =\n match Queue.peek t.blocked_flushes with\n | None -> ()\n | Some flush ->\n if t.num_values_read >= flush.fill_when_num_values_read\n then (\n ignore (Queue.dequeue_exn t.blocked_flushes : Blocked_flush.t);\n (match consumer with\n | None -> Blocked_flush.fill flush `Ok\n | Some consumer ->\n upon\n (Consumer.values_sent_downstream_and_flushed consumer)\n (fun flush_result -> Blocked_flush.fill flush flush_result));\n loop ())\n in\n loop ()\n;;\n\n(* [consume_all t] reads all the elements in [t]. *)\nlet consume_all t consumer =\n let result = t.buffer in\n t.buffer <- Queue.create ();\n t.num_values_read <- t.num_values_read + Queue.length result;\n values_were_read t consumer;\n update_pushback t;\n result\n;;\n\nlet consume_one t consumer =\n assert (length t >= 1);\n let result = Queue.dequeue_exn t.buffer in\n t.num_values_read <- t.num_values_read + 1;\n values_were_read t consumer;\n update_pushback t;\n result\n;;\n\nlet consume t ~max_queue_length consumer =\n assert (max_queue_length >= 0);\n if max_queue_length >= length t\n then consume_all t consumer\n else (\n t.num_values_read <- t.num_values_read + max_queue_length;\n values_were_read t consumer;\n let result = Queue.create ~capacity:max_queue_length () in\n Queue.blit_transfer ~src:t.buffer ~dst:result ~len:max_queue_length ();\n update_pushback t;\n result)\n;;\n\nlet set_size_budget t size_budget =\n if size_budget < 0 then raise_s [%message \"negative size_budget\" (size_budget : int)];\n t.size_budget <- size_budget;\n update_pushback t\n;;\n\nlet fill_blocked_reads t =\n while (not (Queue.is_empty t.blocked_reads)) && not (is_empty t) do\n let blocked_read = Queue.dequeue_exn t.blocked_reads in\n let consumer = blocked_read.consumer in\n match blocked_read.wants with\n | Zero ivar -> Ivar.fill ivar `Ok\n | One ivar -> Ivar.fill ivar (`Ok (consume_one t consumer))\n | At_most (max_queue_length, ivar) ->\n Ivar.fill ivar (`Ok (consume t ~max_queue_length consumer))\n done\n;;\n\n(* checks all invariants, calls a passed in f to handle a write, then updates reads and\n pushback *)\nlet start_write t =\n if !show_debug_messages then eprints \"write\" t [%sexp_of: (_, _) t];\n if !check_invariant then invariant t;\n if is_closed t then raise_s [%message \"write to closed pipe\" ~pipe:(t : (_, _) t)]\n;;\n\nlet finish_write t =\n fill_blocked_reads t;\n update_pushback t\n;;\n\nlet transfer_in_without_pushback t ~from =\n start_write t;\n Queue.blit_transfer ~src:from ~dst:t.buffer ();\n finish_write t\n;;\n\nlet transfer_in t ~from =\n transfer_in_without_pushback t ~from;\n pushback t\n;;\n\nlet copy_in_without_pushback t ~from =\n start_write t;\n Queue.iter from ~f:(fun x -> Queue.enqueue t.buffer x);\n finish_write t\n;;\n\n(* [write'] is used internally *)\nlet write' t q = transfer_in t ~from:q\n\nlet write_without_pushback t value =\n start_write t;\n Queue.enqueue t.buffer value;\n finish_write t\n;;\n\nlet write t value =\n write_without_pushback t value;\n pushback t\n;;\n\nlet write_when_ready t ~f =\n let%map () = pushback t in\n if is_closed t then `Closed else `Ok (f (fun x -> write_without_pushback t x))\n;;\n\nlet write_if_open t x = if not (is_closed t) then write t x else return ()\n\nlet write_without_pushback_if_open t x =\n if not (is_closed t) then write_without_pushback t x\n;;\n\nlet ensure_consumer_matches ?consumer t =\n match consumer with\n | None -> ()\n | Some consumer ->\n if t.id <> Consumer.pipe_id consumer\n then\n raise_s\n [%message\n \"Attempt to use consumer with wrong pipe\"\n (consumer : Consumer.t)\n ~pipe:(t : _ Reader.t)]\n;;\n\nlet start_read ?consumer t label =\n if !show_debug_messages then eprints label t [%sexp_of: (_, _) t];\n if !check_invariant then invariant t;\n ensure_consumer_matches t ?consumer\n;;\n\nlet gen_read_now ?consumer t consume =\n start_read t \"read_now\" ?consumer;\n if is_empty t\n then if is_closed t then `Eof else `Nothing_available\n else (\n assert (Queue.is_empty t.blocked_reads);\n (* from [invariant] and [not (is_empty t)] *)\n `Ok (consume t consumer))\n;;\n\nlet get_max_queue_length ~max_queue_length =\n match max_queue_length with\n | None -> Int.max_value\n | Some max_queue_length ->\n if max_queue_length <= 0\n then raise_s [%message \"max_queue_length <= 0\" (max_queue_length : int)];\n max_queue_length\n;;\n\nlet read_now' ?consumer ?max_queue_length t =\n let max_queue_length = get_max_queue_length ~max_queue_length in\n gen_read_now t ?consumer (fun t consumer -> consume t ~max_queue_length consumer)\n;;\n\nlet read_now ?consumer t = gen_read_now t ?consumer consume_one\nlet peek t = Queue.peek t.buffer\n\nlet clear t =\n match read_now' t with\n | `Eof | `Nothing_available | `Ok _ -> ()\n;;\n\nlet read' ?consumer ?max_queue_length t =\n let max_queue_length = get_max_queue_length ~max_queue_length in\n start_read t \"read'\" ?consumer;\n match read_now' t ?consumer ~max_queue_length with\n | (`Ok _ | `Eof) as r -> return r\n | `Nothing_available ->\n Deferred.create (fun ivar ->\n Queue.enqueue\n t.blocked_reads\n (Blocked_read.create (At_most (max_queue_length, ivar)) consumer))\n;;\n\nlet read ?consumer t =\n start_read t \"read\" ?consumer;\n if is_empty t\n then\n if is_closed t\n then return `Eof\n else\n Deferred.create (fun ivar ->\n Queue.enqueue t.blocked_reads (Blocked_read.(create (One ivar)) consumer))\n else (\n assert (Queue.is_empty t.blocked_reads);\n return (`Ok (consume_one t consumer)))\n;;\n\nlet values_available t =\n start_read t \"values_available\";\n if not (is_empty t)\n then return `Ok\n else if is_closed t\n then return `Eof\n else (\n match Queue.last t.blocked_reads with\n | Some { consumer = None; wants = Zero ivar } ->\n (* This case is an optimization for multiple calls to [values_available] in\n sequence. It causes them to all share the same ivar, rather than allocate\n an ivar per call. *)\n Ivar.read ivar\n | _ ->\n Deferred.create (fun ivar ->\n Queue.enqueue t.blocked_reads (Blocked_read.(create (Zero ivar)) None)))\n;;\n\nlet read_choice t = choice (values_available t) (fun (_ : [ `Ok | `Eof ]) -> read_now t)\n\nlet read_choice_single_consumer_exn t here =\n Deferred.Choice.map (read_choice t) ~f:(function\n | (`Ok _ | `Eof) as x -> x\n | `Nothing_available ->\n raise_s\n [%message\n \"Pipe.read_choice_single_consumer_exn: choice was enabled but pipe is \\\n empty; this is likely due to a race condition with one or more other \\\n consumers\"\n (here : Source_code_position.t)])\n;;\n\n(* [read_exactly t ~num_values] loops, getting you all [num_values] items, up\n to EOF. *)\nlet read_exactly ?consumer t ~num_values =\n start_read t \"read_exactly\" ?consumer;\n if num_values <= 0\n then raise_s [%message \"Pipe.read_exactly got num_values <= 0\" (num_values : int)];\n Deferred.create (fun finish ->\n let result = Queue.create () in\n let rec loop () =\n let already_read = Queue.length result in\n assert (already_read <= num_values);\n if already_read = num_values\n then Ivar.fill finish (`Exactly result)\n else\n read' ?consumer t ~max_queue_length:(num_values - already_read)\n >>> function\n | `Eof -> Ivar.fill finish (if already_read = 0 then `Eof else `Fewer result)\n | `Ok q ->\n Queue.blit_transfer ~src:q ~dst:result ();\n loop ()\n in\n loop ())\n;;\n\nlet downstream_flushed t =\n if is_empty t\n then\n if List.is_empty t.consumers\n then return `Ok\n else\n Flushed_result.combine\n (List.map t.consumers ~f:Consumer.values_sent_downstream_and_flushed)\n else\n (* [t] might be closed. But the read end can't be closed, because if it were, then\n [t] would be empty. If the write end is closed but not the read end, then we want\n to enqueue a blocked flush because the enqueued values may get read. *)\n Deferred.create (fun ready ->\n Queue.enqueue\n t.blocked_flushes\n { fill_when_num_values_read = t.num_values_read + length t; ready })\n;;\n\n(* In practice, along with [Link.create] and [add_upstream_flushed], [upstream_flushed]\n traverses the graph of linked pipes up to the heads and then calls [downstream_flushed]\n on them. *)\nlet upstream_flushed t =\n if Bag.is_empty t.upstream_flusheds\n then downstream_flushed t\n else\n Bag.to_list t.upstream_flusheds\n |> List.map ~f:(fun f -> f ())\n |> Flushed_result.combine\n;;\n\nlet add_upstream_flushed t upstream_flushed =\n Bag.add t.upstream_flusheds upstream_flushed\n;;\n\nlet add_consumer t ~downstream_flushed =\n let consumer = Consumer.create ~pipe_id:t.id ~downstream_flushed in\n t.consumers <- consumer :: t.consumers;\n consumer\n;;\n\n(* A [Link.t] links flushing of two pipes together. *)\nmodule Link : sig\n type t\n\n val create : upstream:(_, _) pipe -> downstream:(_, _) pipe -> t\n val consumer : t -> Consumer.t\n\n (* [unlink_upstream] removes downstream's reference to upstream. *)\n\n val unlink_upstream : t -> unit\nend = struct\n type ('a, 'b) unpacked =\n { downstream : ('a, 'b) t\n ; consumer : Consumer.t\n ; upstream_flusheds_bag_elt : (unit -> Flushed_result.t Deferred.t) Bag.Elt.t\n }\n\n type t = T : (_, _) unpacked -> t\n\n let consumer (T t) = t.consumer\n\n let create ~upstream ~downstream =\n T\n { downstream\n ; consumer =\n add_consumer upstream ~downstream_flushed:(fun () ->\n downstream_flushed downstream)\n ; upstream_flusheds_bag_elt =\n add_upstream_flushed downstream (fun () -> upstream_flushed upstream)\n }\n ;;\n\n let unlink_upstream (T t) =\n Bag.remove t.downstream.upstream_flusheds t.upstream_flusheds_bag_elt\n ;;\nend\n\nmodule Flushed = struct\n type t =\n | Consumer of Consumer.t\n | When_value_processed\n | When_value_read\n [@@deriving sexp_of]\nend\n\nlet fold_gen\n (read_now : ?consumer:Consumer.t -> _ Reader.t -> _)\n ?(flushed = Flushed.When_value_read)\n t\n ~init\n ~f\n =\n let consumer =\n match flushed with\n | When_value_read -> None\n | Consumer consumer -> Some consumer\n | When_value_processed ->\n (* The fact that \"no consumer\" behaves different from \"trivial consumer\" is weird,\n but that's how the consumer machinery works. *)\n Some (add_consumer t ~downstream_flushed:(fun () -> return `Ok))\n in\n if !check_invariant then invariant t;\n ensure_consumer_matches t ?consumer;\n Deferred.create (fun finished ->\n (* We do [return () >>>] to ensure that [f] is only called asynchronously. *)\n return ()\n >>> fun () ->\n let rec loop b =\n match read_now t ?consumer with\n | `Eof -> Ivar.fill finished b\n | `Ok v -> f b v continue\n | `Nothing_available -> values_available t >>> fun _ -> loop b\n and continue b =\n Option.iter consumer ~f:Consumer.values_sent_downstream;\n loop b\n in\n loop init)\n;;\n\nlet fold' ?flushed ?max_queue_length t ~init ~f =\n fold_gen (read_now' ?max_queue_length) ?flushed t ~init ~f:(fun b q loop ->\n f b q >>> loop)\n;;\n\nlet fold ?flushed t ~init ~f =\n fold_gen read_now ?flushed t ~init ~f:(fun b a loop -> f b a >>> loop)\n;;\n\nlet fold_without_pushback ?consumer t ~init ~f =\n fold_gen\n read_now\n t\n ~init\n ~f:(fun b a loop -> loop (f b a))\n ?flushed:\n (match consumer with\n | None -> None\n | Some c -> Some (Consumer c))\n;;\n\nlet with_error_to_current_monitor ?(continue_on_error = false) f a =\n if not continue_on_error\n then f a\n else (\n match%map Monitor.try_with (fun () -> f a) with\n | Ok () -> ()\n | Error exn -> Monitor.send_exn (Monitor.current ()) (Monitor.extract_exn exn))\n;;\n\nlet iter' ?continue_on_error ?flushed ?max_queue_length t ~f =\n fold' ?max_queue_length ?flushed t ~init:() ~f:(fun () q ->\n with_error_to_current_monitor ?continue_on_error f q)\n;;\n\nlet iter ?continue_on_error ?flushed t ~f =\n fold_gen read_now ?flushed t ~init:() ~f:(fun () a loop ->\n with_error_to_current_monitor ?continue_on_error f a >>> fun () -> loop ())\n;;\n\n(* [iter_without_pushback] is a common case, so we implement it in an optimized manner,\n rather than via [iter]. The implementation reads only one element at a time, so that\n if [f] closes [t] or raises, no more elements will be read. *)\nlet iter_without_pushback\n ?consumer\n ?(continue_on_error = false)\n ?max_iterations_per_job\n t\n ~f\n =\n ensure_consumer_matches t ?consumer;\n let max_iterations_per_job =\n match max_iterations_per_job with\n | None -> Int.max_value\n | Some max_iterations_per_job ->\n if max_iterations_per_job <= 0\n then\n raise_s\n [%message\n \"iter_without_pushback got non-positive max_iterations_per_job\"\n (max_iterations_per_job : int)];\n max_iterations_per_job\n in\n let f =\n if not continue_on_error\n then f\n else\n fun a ->\n try f a with\n | exn -> Monitor.send_exn (Monitor.current ()) exn\n in\n Deferred.create (fun finished ->\n (* We do [return () >>>] to ensure that [f] is only called asynchronously. *)\n return ()\n >>> fun () ->\n let rec start () = loop ~remaining:max_iterations_per_job\n and loop ~remaining =\n if remaining = 0\n then return () >>> fun () -> start ()\n else (\n match read_now t ?consumer with\n | `Eof -> Ivar.fill finished ()\n | `Ok a ->\n f a;\n loop ~remaining:(remaining - 1)\n | `Nothing_available -> values_available t >>> fun _ -> start ())\n in\n start ())\n;;\n\nlet drain t = iter' t ~f:(fun _ -> return ())\nlet drain_and_count t = fold' t ~init:0 ~f:(fun sum q -> return (sum + Queue.length q))\n\nlet read_all input =\n let result = Queue.create () in\n let%map () =\n iter' input ~f:(fun q ->\n Queue.blit_transfer ~src:q ~dst:result ();\n return ())\n in\n result\n;;\n\nlet to_list r = read_all r >>| Queue.to_list\n\nlet to_stream_deprecated t =\n Stream.create (fun tail ->\n iter_without_pushback t ~f:(fun x -> Tail.extend tail x)\n >>> fun () -> Tail.close_exn tail)\n;;\n\n(* The implementation of [of_stream_deprecated] does as much batching as possible. It\n grabs as many items as are available into an internal queue. Once it has grabbed\n everything, it writes it to the pipe and then blocks waiting for the next element from\n the stream.\n\n There's no possibility that we'll starve the pipe reading an endless stream, just\n accumulating the elements into our private queue forever without ever writing them\n downstream to the pipe. Why? because while we're running, the stream-producer *isn't*\n running -- there are no Async block points in the queue-accumulator loop. So the\n queue-accumulator loop will eventually catch up to the current stream tail, at which\n point we'll do the pipe-write and then block on the stream... thus giving the\n stream-producer a chance to make more elements.\n\n One can't implement [of_stream] using [Stream.iter] or [Stream.iter'] because you\n need to be able to stop early when the consumer closes the pipe. Also, using either\n of those would entail significantly more deferred overhead, whereas the below\n implementation uses a deferred only when it needs to wait for data from the stream. *)\nlet of_stream_deprecated s =\n let r, w = create () in\n let q = Queue.create () in\n let transfer () =\n if not (Queue.is_empty q)\n then\n (* Can not pushback on the stream, so ignore the pushback on the pipe. *)\n don't_wait_for (write' w q)\n in\n let rec loop s =\n assert (not (is_closed w));\n let next_deferred = Stream.next s in\n match Deferred.peek next_deferred with\n | Some next -> loop_next next\n | None ->\n transfer ();\n upon next_deferred check_closed_loop_next\n and check_closed_loop_next next = if not (is_closed w) then loop_next next\n and loop_next = function\n | Nil ->\n transfer ();\n close w\n | Cons (x, s) ->\n Queue.enqueue q x;\n loop s\n in\n loop s;\n r\n;;\n\nlet transfer_gen\n (read_now : ?consumer:Consumer.t -> _ Reader.t -> _)\n write\n input\n output\n ~f\n =\n if !check_invariant\n then (\n invariant input;\n invariant output);\n let link = Link.create ~upstream:input ~downstream:output in\n let consumer = Link.consumer link in\n (* When we're done with [input], we unlink to remove pointers from\n [output] to [input], which would cause a space leak if we had single long-lived\n output into which we transfer lots of short-lived inputs. *)\n let unlink () = Link.unlink_upstream link in\n Deferred.create (fun result ->\n (* We do [return () >>>] to ensure that [f] is only called asynchronously. *)\n return ()\n >>> fun () ->\n let output_closed () =\n close_read input;\n unlink ();\n Ivar.fill result ()\n in\n let rec loop () =\n if is_closed output\n then output_closed ()\n else (\n match read_now input ~consumer with\n | `Eof ->\n unlink ();\n Ivar.fill result ()\n | `Ok x -> f x continue\n | `Nothing_available ->\n choose\n [ choice (values_available input) ignore; choice (closed output) ignore ]\n >>> fun () -> loop ())\n and continue y =\n if is_closed output\n then output_closed ()\n else (\n let pushback = write output y in\n Consumer.values_sent_downstream consumer;\n pushback >>> fun () -> loop ())\n in\n loop ())\n;;\n\nlet transfer' ?max_queue_length input output ~f =\n transfer_gen (read_now' ?max_queue_length) write' input output ~f:(fun q k ->\n f q >>> k)\n;;\n\nlet transfer input output ~f =\n transfer_gen read_now write input output ~f:(fun a k -> k (f a))\n;;\n\nlet transfer_id ?max_queue_length input output =\n transfer_gen (read_now' ?max_queue_length) write' input output ~f:(fun q k -> k q)\n;;\n\nlet map_gen read write input ~f =\n let info = Option.map input.info ~f:(fun info -> [%sexp Mapped (info : Sexp.t)]) in\n let result, output = create ?info () in\n upon (transfer_gen read write input output ~f) (fun () -> close output);\n result\n;;\n\nlet map' ?max_queue_length input ~f =\n map_gen (read_now' ?max_queue_length) write' input ~f:(fun q k -> f q >>> k)\n;;\n\nlet map input ~f = map_gen read_now write input ~f:(fun a k -> k (f a))\n\nlet filter_map' ?max_queue_length input ~f =\n map' ?max_queue_length input ~f:(fun q -> Deferred.Queue.filter_map q ~f)\n;;\n\nlet filter_map ?max_queue_length input ~f =\n map_gen (read_now' ?max_queue_length) write' input ~f:(fun q k ->\n k (Queue.filter_map q ~f:(fun x -> if is_read_closed input then None else f x)))\n;;\n\nlet folding_filter_map' ?max_queue_length input ~init ~f =\n let accum = ref init in\n filter_map' ?max_queue_length input ~f:(fun x ->\n let%map a, x = f !accum x in\n accum := a;\n x)\n;;\n\nlet folding_filter_map ?max_queue_length input ~init ~f =\n let accum = ref init in\n filter_map ?max_queue_length input ~f:(fun x ->\n let a, x = f !accum x in\n accum := a;\n x)\n;;\n\nlet folding_map ?max_queue_length input ~init ~f =\n folding_filter_map ?max_queue_length input ~init ~f:(fun accum a ->\n let accum, b = f accum a in\n accum, Some b)\n;;\n\nlet filter input ~f = filter_map input ~f:(fun x -> if f x then Some x else None)\n\nlet of_list l =\n let t = create_internal ~info:None ~initial_buffer:(Queue.of_list l) in\n Ivar.fill t.closed ();\n update_pushback t;\n t\n;;\n\nlet empty () = of_list []\n\nlet singleton x =\n let reader, writer = create () in\n write_without_pushback writer x;\n close writer;\n reader\n;;\n\nlet unfold ~init:s ~f =\n (* To get some batching, we run the continuation immediately if the deferred is\n determined. However, we always check for pushback. Because size budget can't be\n infinite, the below loop is guaranteed to eventually yield to the scheduler. *)\n let ( >>=~ ) d f =\n match Deferred.peek d with\n | None -> d >>= f\n | Some x -> f x\n in\n create_reader ~close_on_exception:false (fun writer ->\n let rec loop s =\n f s\n >>=~ function\n | None -> return ()\n | Some (a, s) ->\n if is_closed writer then return () else write writer a >>=~ fun () -> loop s\n in\n loop s)\n;;\n\nlet of_sequence sequence =\n create_reader ~close_on_exception:false (fun writer ->\n let rec enqueue_n sequence i =\n if i <= 0\n then sequence\n else (\n match Sequence.next sequence with\n | None -> sequence\n | Some (a, sequence) ->\n Queue.enqueue writer.buffer a;\n enqueue_n sequence (i - 1))\n in\n let rec loop sequence =\n if is_closed writer || Sequence.is_empty sequence\n then return ()\n else (\n start_write writer;\n let sequence = enqueue_n sequence (1 + writer.size_budget - length writer) in\n finish_write writer;\n let%bind () = pushback writer in\n loop sequence)\n in\n loop sequence)\n;;\n\ntype 'a to_sequence_elt =\n | Value of 'a\n | Wait_for : _ Deferred.t -> _ to_sequence_elt\n\nlet to_sequence t =\n Sequence.unfold ~init:() ~f:(fun () ->\n match read_now t with\n | `Eof -> None\n | `Ok a -> Some (Value a, ())\n | `Nothing_available -> Some (Wait_for (values_available t), ()))\n;;\n\nlet interleave_pipe inputs =\n let output, output_writer = create ~info:[%sexp \"Pipe.interleave\"] () in\n (* We keep a reference count of all the pipes that [interleave_pipe] is managing;\n [inputs] counts as one. When the reference count drops to zero, we know that all\n pipes are closed and we can close [output_writer]. *)\n let num_pipes_remaining = ref 1 in\n let decr_num_pipes_remaining () =\n decr num_pipes_remaining;\n if !num_pipes_remaining = 0 then close output_writer\n in\n don't_wait_for\n (let%map () =\n iter_without_pushback inputs ~f:(fun input ->\n incr num_pipes_remaining;\n don't_wait_for\n (let%map () = transfer_id input output_writer in\n decr_num_pipes_remaining ()))\n in\n decr_num_pipes_remaining ());\n (* for [inputs] *)\n output\n;;\n\nlet interleave inputs =\n if !check_invariant then List.iter inputs ~f:invariant;\n interleave_pipe (of_list inputs)\n;;\n\nlet merge inputs ~compare =\n match inputs with\n | [] -> empty ()\n | [ input ] -> input\n | inputs ->\n let module Heap = Pairing_heap in\n let r, w = create () in\n upon (closed w) (fun () -> List.iter inputs ~f:close_read);\n let heap = Heap.create ~cmp:(fun (a1, _) (a2, _) -> compare a1 a2) () in\n let handle_read input eof_or_ok =\n match eof_or_ok with\n | `Eof -> ()\n | `Ok v -> Heap.add heap (v, input)\n in\n let rec pop_heap_and_loop () =\n (* At this point, all inputs not at Eof occur in [heap] exactly once, so we know\n what the next output element is. [pop_heap_and_loop] repeatedly takes elements\n from the inputs as long as it has one from each input. This is done\n synchronously to avoid the cost of a deferred for each element of the output --\n there's no need to pushback since that is only moving elements from one pipe to\n another. As soon as [pop_heap_and_loop] can't get an element from some input, it\n waits on pushback from the output, since it has to wait on the input anyway.\n This also prevents [merge] from consuming inputs at a rate faster than its output\n is consumed. *)\n match Heap.pop heap with\n | None -> close w\n | Some (v, input) ->\n if not (is_closed w)\n then (\n write_without_pushback w v;\n if Heap.length heap = 0\n then upon (transfer_id input w) (fun () -> close w)\n else (\n match read_now input with\n | (`Eof | `Ok _) as x ->\n handle_read input x;\n pop_heap_and_loop ()\n | `Nothing_available ->\n pushback w\n >>> fun () ->\n read input\n >>> fun x ->\n handle_read input x;\n pop_heap_and_loop ()))\n in\n let initial_push =\n Deferred.List.iter inputs ~f:(fun input ->\n let%map x = read input in\n handle_read input x)\n in\n upon initial_push pop_heap_and_loop;\n r\n;;\n\nlet concat_pipe inputs =\n let r =\n create_reader_not_close_on_exception (fun w ->\n let link = Link.create ~upstream:inputs ~downstream:w in\n let consumer = Link.consumer link in\n iter ~flushed:(Consumer consumer) inputs ~f:(fun input -> transfer_id input w))\n in\n upon (closed r) (fun () -> close inputs);\n r\n;;\n\nlet concat inputs =\n create_reader_not_close_on_exception (fun w ->\n Deferred.List.iter inputs ~f:(fun input -> transfer_id input w))\n;;\n\nlet fork t ~pushback_uses =\n let reader0, writer0 = create () in\n let reader1, writer1 = create () in\n let some_reader_was_closed = ref false in\n let consumer =\n add_consumer t ~downstream_flushed:(fun () ->\n let some_reader_was_closed = !some_reader_was_closed in\n match%map\n Flushed_result.combine\n [ downstream_flushed writer0; downstream_flushed writer1 ]\n with\n | `Reader_closed -> `Reader_closed\n | `Ok ->\n (* In this case, there could have been no pending items in [writer0] nor in\n [writer1], in which case we could have had a closed pipe that missed some\n writes, but [Flushed_result.combine] would still have returned [`Ok] *)\n if some_reader_was_closed then `Reader_closed else `Ok)\n in\n don't_wait_for\n (let still_open = [ writer0; writer1 ] in\n let filter_open still_open =\n (* Only call [filter] and reallocate list if something will get filtered *)\n if not (List.exists still_open ~f:is_closed)\n then still_open\n else (\n some_reader_was_closed := true;\n let still_open = List.filter still_open ~f:(fun w -> not (is_closed w)) in\n if List.is_empty still_open then close t;\n still_open)\n in\n let%bind still_open =\n fold' t ~flushed:(Consumer consumer) ~init:still_open ~f:(fun still_open queue ->\n let still_open = filter_open still_open in\n if List.is_empty still_open\n then return []\n else (\n let%map () =\n match pushback_uses with\n | `Fast_consumer_only -> Deferred.any (List.map still_open ~f:pushback)\n | `Both_consumers -> Deferred.all_unit (List.map still_open ~f:pushback)\n in\n let still_open = filter_open still_open in\n List.iter still_open ~f:(fun w -> copy_in_without_pushback w ~from:queue);\n still_open))\n in\n List.iter still_open ~f:close;\n return ());\n reader0, reader1\n;;\n\nlet set_info t info = set_info t (Some info)\n","open! Import\nmodule Int = Int0\nmodule Sys = Sys0\n\nlet convert_failure x a b to_string =\n Printf.failwithf\n \"conversion from %s to %s failed: %s is out of range\"\n a\n b\n (to_string x)\n ()\n[@@cold] [@@inline never] [@@local never] [@@specialise never]\n;;\n\nlet num_bits_int = Sys.int_size_in_bits\nlet num_bits_int32 = 32\nlet num_bits_int64 = 64\nlet num_bits_nativeint = Word_size.num_bits Word_size.word_size\nlet () = assert (num_bits_int = 63 || num_bits_int = 31 || num_bits_int = 32)\nlet min_int32 = Caml.Int32.min_int\nlet max_int32 = Caml.Int32.max_int\nlet min_int64 = Caml.Int64.min_int\nlet max_int64 = Caml.Int64.max_int\nlet min_nativeint = Caml.Nativeint.min_int\nlet max_nativeint = Caml.Nativeint.max_int\nlet int_to_string = Caml.string_of_int\nlet int32_to_string = Caml.Int32.to_string\nlet int64_to_string = Caml.Int64.to_string\nlet nativeint_to_string = Caml.Nativeint.to_string\n\n(* int <-> int32 *)\n\nlet int_to_int32_failure x = convert_failure x \"int\" \"int32\" int_to_string\nlet int32_to_int_failure x = convert_failure x \"int32\" \"int\" int32_to_string\nlet int32_to_int_trunc = Caml.Int32.to_int\nlet int_to_int32_trunc = Caml.Int32.of_int\n\nlet int_is_representable_as_int32 =\n if num_bits_int <= num_bits_int32\n then fun _ -> true\n else (\n let min = int32_to_int_trunc min_int32 in\n let max = int32_to_int_trunc max_int32 in\n fun x -> compare_int min x <= 0 && compare_int x max <= 0)\n;;\n\nlet int32_is_representable_as_int =\n if num_bits_int32 <= num_bits_int\n then fun _ -> true\n else (\n let min = int_to_int32_trunc Int.min_value in\n let max = int_to_int32_trunc Int.max_value in\n fun x -> compare_int32 min x <= 0 && compare_int32 x max <= 0)\n;;\n\nlet int_to_int32 x =\n if int_is_representable_as_int32 x then Some (int_to_int32_trunc x) else None\n;;\n\nlet int32_to_int x =\n if int32_is_representable_as_int x then Some (int32_to_int_trunc x) else None\n;;\n\nlet int_to_int32_exn x =\n if int_is_representable_as_int32 x\n then int_to_int32_trunc x\n else int_to_int32_failure x\n;;\n\nlet int32_to_int_exn x =\n if int32_is_representable_as_int x\n then int32_to_int_trunc x\n else int32_to_int_failure x\n;;\n\n(* int <-> int64 *)\n\nlet int64_to_int_failure x = convert_failure x \"int64\" \"int\" int64_to_string\nlet () = assert (num_bits_int < num_bits_int64)\nlet int_to_int64 = Caml.Int64.of_int\nlet int64_to_int_trunc = Caml.Int64.to_int\n\nlet int64_is_representable_as_int =\n let min = int_to_int64 Int.min_value in\n let max = int_to_int64 Int.max_value in\n fun x -> compare_int64 min x <= 0 && compare_int64 x max <= 0\n;;\n\nlet int64_to_int x =\n if int64_is_representable_as_int x then Some (int64_to_int_trunc x) else None\n;;\n\nlet int64_to_int_exn x =\n if int64_is_representable_as_int x\n then int64_to_int_trunc x\n else int64_to_int_failure x\n;;\n\n(* int <-> nativeint *)\n\nlet nativeint_to_int_failure x = convert_failure x \"nativeint\" \"int\" nativeint_to_string\nlet () = assert (num_bits_int <= num_bits_nativeint)\nlet int_to_nativeint = Caml.Nativeint.of_int\nlet nativeint_to_int_trunc = Caml.Nativeint.to_int\n\nlet nativeint_is_representable_as_int =\n if num_bits_nativeint <= num_bits_int\n then fun _ -> true\n else (\n let min = int_to_nativeint Int.min_value in\n let max = int_to_nativeint Int.max_value in\n fun x -> compare_nativeint min x <= 0 && compare_nativeint x max <= 0)\n;;\n\nlet nativeint_to_int x =\n if nativeint_is_representable_as_int x then Some (nativeint_to_int_trunc x) else None\n;;\n\nlet nativeint_to_int_exn x =\n if nativeint_is_representable_as_int x\n then nativeint_to_int_trunc x\n else nativeint_to_int_failure x\n;;\n\n(* int32 <-> int64 *)\n\nlet int64_to_int32_failure x = convert_failure x \"int64\" \"int32\" int64_to_string\nlet () = assert (num_bits_int32 < num_bits_int64)\nlet int32_to_int64 = Caml.Int64.of_int32\nlet int64_to_int32_trunc = Caml.Int64.to_int32\n\nlet int64_is_representable_as_int32 =\n let min = int32_to_int64 min_int32 in\n let max = int32_to_int64 max_int32 in\n fun x -> compare_int64 min x <= 0 && compare_int64 x max <= 0\n;;\n\nlet int64_to_int32 x =\n if int64_is_representable_as_int32 x then Some (int64_to_int32_trunc x) else None\n;;\n\nlet int64_to_int32_exn x =\n if int64_is_representable_as_int32 x\n then int64_to_int32_trunc x\n else int64_to_int32_failure x\n;;\n\n(* int32 <-> nativeint *)\n\nlet nativeint_to_int32_failure x =\n convert_failure x \"nativeint\" \"int32\" nativeint_to_string\n;;\n\nlet () = assert (num_bits_int32 <= num_bits_nativeint)\nlet int32_to_nativeint = Caml.Nativeint.of_int32\nlet nativeint_to_int32_trunc = Caml.Nativeint.to_int32\n\nlet nativeint_is_representable_as_int32 =\n if num_bits_nativeint <= num_bits_int32\n then fun _ -> true\n else (\n let min = int32_to_nativeint min_int32 in\n let max = int32_to_nativeint max_int32 in\n fun x -> compare_nativeint min x <= 0 && compare_nativeint x max <= 0)\n;;\n\nlet nativeint_to_int32 x =\n if nativeint_is_representable_as_int32 x\n then Some (nativeint_to_int32_trunc x)\n else None\n;;\n\nlet nativeint_to_int32_exn x =\n if nativeint_is_representable_as_int32 x\n then nativeint_to_int32_trunc x\n else nativeint_to_int32_failure x\n;;\n\n(* int64 <-> nativeint *)\n\nlet int64_to_nativeint_failure x = convert_failure x \"int64\" \"nativeint\" int64_to_string\nlet () = assert (num_bits_int64 >= num_bits_nativeint)\nlet int64_to_nativeint_trunc = Caml.Int64.to_nativeint\nlet nativeint_to_int64 = Caml.Int64.of_nativeint\n\nlet int64_is_representable_as_nativeint =\n if num_bits_int64 <= num_bits_nativeint\n then fun _ -> true\n else (\n let min = nativeint_to_int64 min_nativeint in\n let max = nativeint_to_int64 max_nativeint in\n fun x -> compare_int64 min x <= 0 && compare_int64 x max <= 0)\n;;\n\nlet int64_to_nativeint x =\n if int64_is_representable_as_nativeint x\n then Some (int64_to_nativeint_trunc x)\n else None\n;;\n\nlet int64_to_nativeint_exn x =\n if int64_is_representable_as_nativeint x\n then int64_to_nativeint_trunc x\n else int64_to_nativeint_failure x\n;;\n\n(* int64 <-> int63 *)\n\nlet int64_to_int63_failure x = convert_failure x \"int64\" \"int63\" int64_to_string\n\nlet int64_is_representable_as_int63 =\n let min = Caml.Int64.shift_right min_int64 1 in\n let max = Caml.Int64.shift_right max_int64 1 in\n fun x -> compare_int64 min x <= 0 && compare_int64 x max <= 0\n;;\n\nlet int64_fit_on_int63_exn x =\n if int64_is_representable_as_int63 x then () else int64_to_int63_failure x\n;;\n\n(* string conversions *)\n\nlet insert_delimiter_every input ~delimiter ~chars_per_delimiter =\n let input_length = String.length input in\n if input_length <= chars_per_delimiter\n then input\n else (\n let has_sign =\n match input.[0] with\n | '+' | '-' -> true\n | _ -> false\n in\n let num_digits = if has_sign then input_length - 1 else input_length in\n let num_delimiters = (num_digits - 1) / chars_per_delimiter in\n let output_length = input_length + num_delimiters in\n let output = Bytes.create output_length in\n let input_pos = ref (input_length - 1) in\n let output_pos = ref (output_length - 1) in\n let num_chars_until_delimiter = ref chars_per_delimiter in\n let first_digit_pos = if has_sign then 1 else 0 in\n while !input_pos >= first_digit_pos do\n if !num_chars_until_delimiter = 0\n then (\n Bytes.set output !output_pos delimiter;\n decr output_pos;\n num_chars_until_delimiter := chars_per_delimiter);\n Bytes.set output !output_pos input.[!input_pos];\n decr input_pos;\n decr output_pos;\n decr num_chars_until_delimiter\n done;\n if has_sign then Bytes.set output 0 input.[0];\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:output)\n;;\n\nlet insert_delimiter input ~delimiter =\n insert_delimiter_every input ~delimiter ~chars_per_delimiter:3\n;;\n\nlet insert_underscores input = insert_delimiter input ~delimiter:'_'\nlet sexp_of_int_style = Sexp.of_int_style\n\nmodule Make (I : sig\n type t\n\n val to_string : t -> string\n end) =\nstruct\n open I\n\n let chars_per_delimiter = 3\n\n let to_string_hum ?(delimiter = '_') t =\n insert_delimiter_every (to_string t) ~delimiter ~chars_per_delimiter\n ;;\n\n let sexp_of_t t =\n let s = to_string t in\n Sexp.Atom\n (match !sexp_of_int_style with\n | `Underscores -> insert_delimiter_every s ~chars_per_delimiter ~delimiter:'_'\n | `No_underscores -> s)\n ;;\nend\n\nmodule Make_hex (I : sig\n type t [@@deriving_inline compare, hash]\n\n val compare : t -> t -> int\n val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state\n val hash : t -> Ppx_hash_lib.Std.Hash.hash_value\n\n [@@@end]\n\n val to_string : t -> string\n val of_string : string -> t\n val zero : t\n val ( < ) : t -> t -> bool\n val neg : t -> t\n val module_name : string\n end) =\nstruct\n module T_hex = struct\n type t = I.t [@@deriving_inline compare, hash]\n\n let compare = (I.compare : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n I.hash_fold_t\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = I.hash in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let chars_per_delimiter = 4\n\n let to_string' ?delimiter t =\n let make_suffix =\n match delimiter with\n | None -> I.to_string\n | Some delimiter ->\n fun t -> insert_delimiter_every (I.to_string t) ~delimiter ~chars_per_delimiter\n in\n if I.( < ) t I.zero then \"-0x\" ^ make_suffix (I.neg t) else \"0x\" ^ make_suffix t\n ;;\n\n let to_string t = to_string' t ?delimiter:None\n let to_string_hum ?(delimiter = '_') t = to_string' t ~delimiter\n\n let invalid str =\n Printf.failwithf \"%s.of_string: invalid input %S\" I.module_name str ()\n ;;\n\n let of_string_with_delimiter str =\n I.of_string (String.filter str ~f:(fun c -> Char.( <> ) c '_'))\n ;;\n\n let of_string str =\n let module L = Hex_lexer in\n let lex = Caml.Lexing.from_string str in\n let result = Option.try_with (fun () -> L.parse_hex lex) in\n if lex.lex_curr_pos = lex.lex_buffer_len\n then (\n match result with\n | None -> invalid str\n | Some (Neg body) -> I.neg (of_string_with_delimiter body)\n | Some (Pos body) -> of_string_with_delimiter body)\n else invalid str\n ;;\n end\n\n module Hex = struct\n include T_hex\n include Sexpable.Of_stringable (T_hex)\n end\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* An alias for the type of lists. *)\ntype 'a t = 'a list = [] | (::) of 'a * 'a list\n\n(* List operations *)\n\nlet rec length_aux len = function\n [] -> len\n | _::l -> length_aux (len + 1) l\n\nlet length l = length_aux 0 l\n\nlet cons a l = a::l\n\nlet hd = function\n [] -> failwith \"hd\"\n | a::_ -> a\n\nlet tl = function\n [] -> failwith \"tl\"\n | _::l -> l\n\nlet nth l n =\n if n < 0 then invalid_arg \"List.nth\" else\n let rec nth_aux l n =\n match l with\n | [] -> failwith \"nth\"\n | a::l -> if n = 0 then a else nth_aux l (n-1)\n in nth_aux l n\n\nlet nth_opt l n =\n if n < 0 then invalid_arg \"List.nth\" else\n let rec nth_aux l n =\n match l with\n | [] -> None\n | a::l -> if n = 0 then Some a else nth_aux l (n-1)\n in nth_aux l n\n\nlet append = (@)\n\nlet rec rev_append l1 l2 =\n match l1 with\n [] -> l2\n | a :: l -> rev_append l (a :: l2)\n\nlet rev l = rev_append l []\n\nlet rec init_tailrec_aux acc i n f =\n if i >= n then acc\n else init_tailrec_aux (f i :: acc) (i+1) n f\n\nlet rec init_aux i n f =\n if i >= n then []\n else\n let r = f i in\n r :: init_aux (i+1) n f\n\nlet rev_init_threshold =\n match Sys.backend_type with\n | Sys.Native | Sys.Bytecode -> 10_000\n (* We don't know the size of the stack, better be safe and assume it's\n small. *)\n | Sys.Other _ -> 50\n\nlet init len f =\n if len < 0 then invalid_arg \"List.init\" else\n if len > rev_init_threshold then rev (init_tailrec_aux [] 0 len f)\n else init_aux 0 len f\n\nlet rec flatten = function\n [] -> []\n | l::r -> l @ flatten r\n\nlet concat = flatten\n\nlet rec map f = function\n [] -> []\n | a::l -> let r = f a in r :: map f l\n\nlet rec mapi i f = function\n [] -> []\n | a::l -> let r = f i a in r :: mapi (i + 1) f l\n\nlet mapi f l = mapi 0 f l\n\nlet rev_map f l =\n let rec rmap_f accu = function\n | [] -> accu\n | a::l -> rmap_f (f a :: accu) l\n in\n rmap_f [] l\n\n\nlet rec iter f = function\n [] -> ()\n | a::l -> f a; iter f l\n\nlet rec iteri i f = function\n [] -> ()\n | a::l -> f i a; iteri (i + 1) f l\n\nlet iteri f l = iteri 0 f l\n\nlet rec fold_left f accu l =\n match l with\n [] -> accu\n | a::l -> fold_left f (f accu a) l\n\nlet rec fold_right f l accu =\n match l with\n [] -> accu\n | a::l -> f a (fold_right f l accu)\n\nlet rec map2 f l1 l2 =\n match (l1, l2) with\n ([], []) -> []\n | (a1::l1, a2::l2) -> let r = f a1 a2 in r :: map2 f l1 l2\n | (_, _) -> invalid_arg \"List.map2\"\n\nlet rev_map2 f l1 l2 =\n let rec rmap2_f accu l1 l2 =\n match (l1, l2) with\n | ([], []) -> accu\n | (a1::l1, a2::l2) -> rmap2_f (f a1 a2 :: accu) l1 l2\n | (_, _) -> invalid_arg \"List.rev_map2\"\n in\n rmap2_f [] l1 l2\n\n\nlet rec iter2 f l1 l2 =\n match (l1, l2) with\n ([], []) -> ()\n | (a1::l1, a2::l2) -> f a1 a2; iter2 f l1 l2\n | (_, _) -> invalid_arg \"List.iter2\"\n\nlet rec fold_left2 f accu l1 l2 =\n match (l1, l2) with\n ([], []) -> accu\n | (a1::l1, a2::l2) -> fold_left2 f (f accu a1 a2) l1 l2\n | (_, _) -> invalid_arg \"List.fold_left2\"\n\nlet rec fold_right2 f l1 l2 accu =\n match (l1, l2) with\n ([], []) -> accu\n | (a1::l1, a2::l2) -> f a1 a2 (fold_right2 f l1 l2 accu)\n | (_, _) -> invalid_arg \"List.fold_right2\"\n\nlet rec for_all p = function\n [] -> true\n | a::l -> p a && for_all p l\n\nlet rec exists p = function\n [] -> false\n | a::l -> p a || exists p l\n\nlet rec for_all2 p l1 l2 =\n match (l1, l2) with\n ([], []) -> true\n | (a1::l1, a2::l2) -> p a1 a2 && for_all2 p l1 l2\n | (_, _) -> invalid_arg \"List.for_all2\"\n\nlet rec exists2 p l1 l2 =\n match (l1, l2) with\n ([], []) -> false\n | (a1::l1, a2::l2) -> p a1 a2 || exists2 p l1 l2\n | (_, _) -> invalid_arg \"List.exists2\"\n\nlet rec mem x = function\n [] -> false\n | a::l -> compare a x = 0 || mem x l\n\nlet rec memq x = function\n [] -> false\n | a::l -> a == x || memq x l\n\nlet rec assoc x = function\n [] -> raise Not_found\n | (a,b)::l -> if compare a x = 0 then b else assoc x l\n\nlet rec assoc_opt x = function\n [] -> None\n | (a,b)::l -> if compare a x = 0 then Some b else assoc_opt x l\n\nlet rec assq x = function\n [] -> raise Not_found\n | (a,b)::l -> if a == x then b else assq x l\n\nlet rec assq_opt x = function\n [] -> None\n | (a,b)::l -> if a == x then Some b else assq_opt x l\n\nlet rec mem_assoc x = function\n | [] -> false\n | (a, _) :: l -> compare a x = 0 || mem_assoc x l\n\nlet rec mem_assq x = function\n | [] -> false\n | (a, _) :: l -> a == x || mem_assq x l\n\nlet rec remove_assoc x = function\n | [] -> []\n | (a, _ as pair) :: l ->\n if compare a x = 0 then l else pair :: remove_assoc x l\n\nlet rec remove_assq x = function\n | [] -> []\n | (a, _ as pair) :: l -> if a == x then l else pair :: remove_assq x l\n\nlet rec find p = function\n | [] -> raise Not_found\n | x :: l -> if p x then x else find p l\n\nlet rec find_opt p = function\n | [] -> None\n | x :: l -> if p x then Some x else find_opt p l\n\nlet rec find_map f = function\n | [] -> None\n | x :: l ->\n begin match f x with\n | Some _ as result -> result\n | None -> find_map f l\n end\n\nlet find_all p =\n let rec find accu = function\n | [] -> rev accu\n | x :: l -> if p x then find (x :: accu) l else find accu l in\n find []\n\nlet filter = find_all\n\nlet filteri p l =\n let rec aux i acc = function\n | [] -> rev acc\n | x::l -> aux (i + 1) (if p i x then x::acc else acc) l\n in\n aux 0 [] l\n\nlet filter_map f =\n let rec aux accu = function\n | [] -> rev accu\n | x :: l ->\n match f x with\n | None -> aux accu l\n | Some v -> aux (v :: accu) l\n in\n aux []\n\nlet concat_map f l =\n let rec aux f acc = function\n | [] -> rev acc\n | x :: l ->\n let xs = f x in\n aux f (rev_append xs acc) l\n in aux f [] l\n\nlet fold_left_map f accu l =\n let rec aux accu l_accu = function\n | [] -> accu, rev l_accu\n | x :: l ->\n let accu, x = f accu x in\n aux accu (x :: l_accu) l in\n aux accu [] l\n\nlet partition p l =\n let rec part yes no = function\n | [] -> (rev yes, rev no)\n | x :: l -> if p x then part (x :: yes) no l else part yes (x :: no) l in\n part [] [] l\n\nlet partition_map p l =\n let rec part left right = function\n | [] -> (rev left, rev right)\n | x :: l ->\n begin match p x with\n | Either.Left v -> part (v :: left) right l\n | Either.Right v -> part left (v :: right) l\n end\n in\n part [] [] l\n\nlet rec split = function\n [] -> ([], [])\n | (x,y)::l ->\n let (rx, ry) = split l in (x::rx, y::ry)\n\nlet rec combine l1 l2 =\n match (l1, l2) with\n ([], []) -> []\n | (a1::l1, a2::l2) -> (a1, a2) :: combine l1 l2\n | (_, _) -> invalid_arg \"List.combine\"\n\n(** sorting *)\n\nlet rec merge cmp l1 l2 =\n match l1, l2 with\n | [], l2 -> l2\n | l1, [] -> l1\n | h1 :: t1, h2 :: t2 ->\n if cmp h1 h2 <= 0\n then h1 :: merge cmp t1 l2\n else h2 :: merge cmp l1 t2\n\n\nlet stable_sort cmp l =\n let rec rev_merge l1 l2 accu =\n match l1, l2 with\n | [], l2 -> rev_append l2 accu\n | l1, [] -> rev_append l1 accu\n | h1::t1, h2::t2 ->\n if cmp h1 h2 <= 0\n then rev_merge t1 l2 (h1::accu)\n else rev_merge l1 t2 (h2::accu)\n in\n let rec rev_merge_rev l1 l2 accu =\n match l1, l2 with\n | [], l2 -> rev_append l2 accu\n | l1, [] -> rev_append l1 accu\n | h1::t1, h2::t2 ->\n if cmp h1 h2 > 0\n then rev_merge_rev t1 l2 (h1::accu)\n else rev_merge_rev l1 t2 (h2::accu)\n in\n let rec sort n l =\n match n, l with\n | 2, x1 :: x2 :: tl ->\n let s = if cmp x1 x2 <= 0 then [x1; x2] else [x2; x1] in\n (s, tl)\n | 3, x1 :: x2 :: x3 :: tl ->\n let s =\n if cmp x1 x2 <= 0 then\n if cmp x2 x3 <= 0 then [x1; x2; x3]\n else if cmp x1 x3 <= 0 then [x1; x3; x2]\n else [x3; x1; x2]\n else if cmp x1 x3 <= 0 then [x2; x1; x3]\n else if cmp x2 x3 <= 0 then [x2; x3; x1]\n else [x3; x2; x1]\n in\n (s, tl)\n | n, l ->\n let n1 = n asr 1 in\n let n2 = n - n1 in\n let s1, l2 = rev_sort n1 l in\n let s2, tl = rev_sort n2 l2 in\n (rev_merge_rev s1 s2 [], tl)\n and rev_sort n l =\n match n, l with\n | 2, x1 :: x2 :: tl ->\n let s = if cmp x1 x2 > 0 then [x1; x2] else [x2; x1] in\n (s, tl)\n | 3, x1 :: x2 :: x3 :: tl ->\n let s =\n if cmp x1 x2 > 0 then\n if cmp x2 x3 > 0 then [x1; x2; x3]\n else if cmp x1 x3 > 0 then [x1; x3; x2]\n else [x3; x1; x2]\n else if cmp x1 x3 > 0 then [x2; x1; x3]\n else if cmp x2 x3 > 0 then [x2; x3; x1]\n else [x3; x2; x1]\n in\n (s, tl)\n | n, l ->\n let n1 = n asr 1 in\n let n2 = n - n1 in\n let s1, l2 = sort n1 l in\n let s2, tl = sort n2 l2 in\n (rev_merge s1 s2 [], tl)\n in\n let len = length l in\n if len < 2 then l else fst (sort len l)\n\n\nlet sort = stable_sort\nlet fast_sort = stable_sort\n\n(* Note: on a list of length between about 100000 (depending on the minor\n heap size and the type of the list) and Sys.max_array_size, it is\n actually faster to use the following, but it might also use more memory\n because the argument list cannot be deallocated incrementally.\n\n Also, there seems to be a bug in this code or in the\n implementation of obj_truncate.\n\nexternal obj_truncate : 'a array -> int -> unit = \"caml_obj_truncate\"\n\nlet array_to_list_in_place a =\n let l = Array.length a in\n let rec loop accu n p =\n if p <= 0 then accu else begin\n if p = n then begin\n obj_truncate a p;\n loop (a.(p-1) :: accu) (n-1000) (p-1)\n end else begin\n loop (a.(p-1) :: accu) n (p-1)\n end\n end\n in\n loop [] (l-1000) l\n\n\nlet stable_sort cmp l =\n let a = Array.of_list l in\n Array.stable_sort cmp a;\n array_to_list_in_place a\n\n*)\n\n\n(** sorting + removing duplicates *)\n\nlet sort_uniq cmp l =\n let rec rev_merge l1 l2 accu =\n match l1, l2 with\n | [], l2 -> rev_append l2 accu\n | l1, [] -> rev_append l1 accu\n | h1::t1, h2::t2 ->\n let c = cmp h1 h2 in\n if c = 0 then rev_merge t1 t2 (h1::accu)\n else if c < 0\n then rev_merge t1 l2 (h1::accu)\n else rev_merge l1 t2 (h2::accu)\n in\n let rec rev_merge_rev l1 l2 accu =\n match l1, l2 with\n | [], l2 -> rev_append l2 accu\n | l1, [] -> rev_append l1 accu\n | h1::t1, h2::t2 ->\n let c = cmp h1 h2 in\n if c = 0 then rev_merge_rev t1 t2 (h1::accu)\n else if c > 0\n then rev_merge_rev t1 l2 (h1::accu)\n else rev_merge_rev l1 t2 (h2::accu)\n in\n let rec sort n l =\n match n, l with\n | 2, x1 :: x2 :: tl ->\n let s =\n let c = cmp x1 x2 in\n if c = 0 then [x1] else if c < 0 then [x1; x2] else [x2; x1]\n in\n (s, tl)\n | 3, x1 :: x2 :: x3 :: tl ->\n let s =\n let c = cmp x1 x2 in\n if c = 0 then\n let c = cmp x2 x3 in\n if c = 0 then [x2] else if c < 0 then [x2; x3] else [x3; x2]\n else if c < 0 then\n let c = cmp x2 x3 in\n if c = 0 then [x1; x2]\n else if c < 0 then [x1; x2; x3]\n else\n let c = cmp x1 x3 in\n if c = 0 then [x1; x2]\n else if c < 0 then [x1; x3; x2]\n else [x3; x1; x2]\n else\n let c = cmp x1 x3 in\n if c = 0 then [x2; x1]\n else if c < 0 then [x2; x1; x3]\n else\n let c = cmp x2 x3 in\n if c = 0 then [x2; x1]\n else if c < 0 then [x2; x3; x1]\n else [x3; x2; x1]\n in\n (s, tl)\n | n, l ->\n let n1 = n asr 1 in\n let n2 = n - n1 in\n let s1, l2 = rev_sort n1 l in\n let s2, tl = rev_sort n2 l2 in\n (rev_merge_rev s1 s2 [], tl)\n and rev_sort n l =\n match n, l with\n | 2, x1 :: x2 :: tl ->\n let s =\n let c = cmp x1 x2 in\n if c = 0 then [x1] else if c > 0 then [x1; x2] else [x2; x1]\n in\n (s, tl)\n | 3, x1 :: x2 :: x3 :: tl ->\n let s =\n let c = cmp x1 x2 in\n if c = 0 then\n let c = cmp x2 x3 in\n if c = 0 then [x2] else if c > 0 then [x2; x3] else [x3; x2]\n else if c > 0 then\n let c = cmp x2 x3 in\n if c = 0 then [x1; x2]\n else if c > 0 then [x1; x2; x3]\n else\n let c = cmp x1 x3 in\n if c = 0 then [x1; x2]\n else if c > 0 then [x1; x3; x2]\n else [x3; x1; x2]\n else\n let c = cmp x1 x3 in\n if c = 0 then [x2; x1]\n else if c > 0 then [x2; x1; x3]\n else\n let c = cmp x2 x3 in\n if c = 0 then [x2; x1]\n else if c > 0 then [x2; x3; x1]\n else [x3; x2; x1]\n in\n (s, tl)\n | n, l ->\n let n1 = n asr 1 in\n let n2 = n - n1 in\n let s1, l2 = sort n1 l in\n let s2, tl = sort n2 l2 in\n (rev_merge s1 s2 [], tl)\n in\n let len = length l in\n if len < 2 then l else fst (sort len l)\n\n\nlet rec compare_lengths l1 l2 =\n match l1, l2 with\n | [], [] -> 0\n | [], _ -> -1\n | _, [] -> 1\n | _ :: l1, _ :: l2 -> compare_lengths l1 l2\n;;\n\nlet rec compare_length_with l n =\n match l with\n | [] ->\n if n = 0 then 0 else\n if n > 0 then -1 else 1\n | _ :: l ->\n if n <= 0 then 1 else\n compare_length_with l (n-1)\n;;\n\n(** {1 Comparison} *)\n\n(* Note: we are *not* shortcutting the list by using\n [List.compare_lengths] first; this may be slower on long lists\n immediately start with distinct elements. It is also incorrect for\n [compare] below, and it is better (principle of least surprise) to\n use the same approach for both functions. *)\nlet rec equal eq l1 l2 =\n match l1, l2 with\n | [], [] -> true\n | [], _::_ | _::_, [] -> false\n | a1::l1, a2::l2 -> eq a1 a2 && equal eq l1 l2\n\nlet rec compare cmp l1 l2 =\n match l1, l2 with\n | [], [] -> 0\n | [], _::_ -> -1\n | _::_, [] -> 1\n | a1::l1, a2::l2 ->\n let c = cmp a1 a2 in\n if c <> 0 then c\n else compare cmp l1 l2\n\n(** {1 Iterators} *)\n\nlet to_seq l =\n let rec aux l () = match l with\n | [] -> Seq.Nil\n | x :: tail -> Seq.Cons (x, aux tail)\n in\n aux l\n\nlet of_seq seq =\n let rec direct depth seq : _ list =\n if depth=0\n then\n Seq.fold_left (fun acc x -> x::acc) [] seq\n |> rev (* tailrec *)\n else match seq() with\n | Seq.Nil -> []\n | Seq.Cons (x, next) -> x :: direct (depth-1) next\n in\n direct 500 seq\n","include Base\ninclude Ppxlib\ninclude Ast_builder.Default\n\n(* errors and error messages *)\n\nlet ( ^^ ) = Caml.( ^^ )\nlet error ~loc fmt = Location.raise_errorf ~loc (\"ppx_quickcheck: \" ^^ fmt)\nlet invalid ~loc fmt = error ~loc (\"invalid syntax: \" ^^ fmt)\nlet unsupported ~loc fmt = error ~loc (\"unsupported: \" ^^ fmt)\nlet internal_error ~loc fmt = error ~loc (\"internal error: \" ^^ fmt)\n\nlet short_string_of_core_type core_type =\n match core_type.ptyp_desc with\n | Ptyp_any -> \"wildcard type\"\n | Ptyp_var _ -> \"type variable\"\n | Ptyp_arrow _ -> \"function type\"\n | Ptyp_tuple _ -> \"tuple type\"\n | Ptyp_constr _ -> \"type name\"\n | Ptyp_object _ -> \"object type\"\n | Ptyp_class _ -> \"class type\"\n | Ptyp_alias _ -> \"type variable alias\"\n | Ptyp_variant _ -> \"polymorphic variant\"\n | Ptyp_poly _ -> \"explicit polymorphic type\"\n | Ptyp_package _ -> \"first-class module type\"\n | Ptyp_extension _ -> \"ppx extension type\"\n;;\n\n(* little syntax helpers *)\n\nlet loc_map { loc; txt } ~f = { loc; txt = f txt }\nlet lident_loc = loc_map ~f:lident\n\nlet prefixed_type_name prefix type_name =\n match type_name with\n | \"t\" -> prefix\n | _ -> prefix ^ \"_\" ^ type_name\n;;\n\nlet generator_name type_name = prefixed_type_name \"quickcheck_generator\" type_name\nlet observer_name type_name = prefixed_type_name \"quickcheck_observer\" type_name\nlet shrinker_name type_name = prefixed_type_name \"quickcheck_shrinker\" type_name\nlet pname { loc; txt } ~f = pvar ~loc (f txt)\nlet ename { loc; txt } ~f = evar ~loc (f txt)\nlet pgenerator = pname ~f:generator_name\nlet pobserver = pname ~f:observer_name\nlet pshrinker = pname ~f:shrinker_name\nlet egenerator = ename ~f:generator_name\nlet eobserver = ename ~f:observer_name\nlet eshrinker = ename ~f:shrinker_name\n\nlet ptuple ~loc list =\n match list with\n | [] -> [%pat? ()]\n | [ pat ] -> pat\n | _ -> ppat_tuple ~loc list\n;;\n\n(* creating (probably-)unique symbols for generated code *)\n\nlet gensym prefix loc =\n let loc = { loc with loc_ghost = true } in\n let sym = gen_symbol ~prefix:(\"_\" ^ prefix) () in\n pvar ~loc sym, evar ~loc sym\n;;\n\nlet gensyms prefix loc_list = List.map loc_list ~f:(gensym prefix) |> List.unzip\n\nlet gensymss prefix loc_list_list =\n List.map loc_list_list ~f:(gensyms prefix) |> List.unzip\n;;\n\n(* expression to create a higher order function that maps from function with one kind of\n argument label to another *)\n\nlet fn_map_label ~loc ~from ~to_ =\n let f_pat, f_expr = gensym \"f\" loc in\n let x_pat, x_expr = gensym \"x\" loc in\n pexp_fun\n ~loc\n Nolabel\n None\n f_pat\n (pexp_fun ~loc to_ None x_pat (pexp_apply ~loc f_expr [ from, x_expr ]))\n;;\n","(* [Sys0] defines functions that are primitives or can be simply defined in\n terms of [Caml.Sys]. [Sys0] is intended to completely express the part of\n [Caml.Sys] that [Base] uses -- no other file in Base other than sys.ml\n should use [Caml.Sys]. [Sys0] has few dependencies, and so is available\n early in Base's build order. All Base files that need to use these\n functions and come before [Base.Sys] in build order should do\n [module Sys = Sys0]. Defining [module Sys = Sys0] is also necessary because\n it prevents ocamldep from mistakenly causing a file to depend on [Base.Sys]. *)\n\nopen! Import0\n\ntype backend_type = Caml.Sys.backend_type =\n | Native\n | Bytecode\n | Other of string\n\nlet backend_type = Caml.Sys.backend_type\nlet interactive = Caml.Sys.interactive\nlet os_type = Caml.Sys.os_type\nlet unix = Caml.Sys.unix\nlet win32 = Caml.Sys.win32\nlet cygwin = Caml.Sys.cygwin\nlet word_size_in_bits = Caml.Sys.word_size\nlet int_size_in_bits = Caml.Sys.int_size\nlet big_endian = Caml.Sys.big_endian\nlet max_string_length = Caml.Sys.max_string_length\nlet max_array_length = Caml.Sys.max_array_length\nlet runtime_variant = Caml.Sys.runtime_variant\nlet runtime_parameters = Caml.Sys.runtime_parameters\nlet argv = Caml.Sys.argv\nlet get_argv () = Caml.Sys.argv\nlet ocaml_version = Caml.Sys.ocaml_version\nlet enable_runtime_warnings = Caml.Sys.enable_runtime_warnings\nlet runtime_warnings_enabled = Caml.Sys.runtime_warnings_enabled\n\nlet getenv_exn var =\n try Caml.Sys.getenv var with\n | Caml.Not_found ->\n Printf.failwithf \"Sys.getenv_exn: environment variable %s is not set\" var ()\n;;\n\nlet getenv var =\n match Caml.Sys.getenv var with\n | x -> Some x\n | exception Caml.Not_found -> None\n;;\n\nexternal opaque_identity : 'a -> 'a = \"%opaque\"\n\nexception Break = Caml.Sys.Break\n","(* Write_ml: writing values to the binary protocol using (mostly) OCaml. *)\n\n(* Note: the code is this file is carefully written to avoid unnecessary allocations. When\n touching this code, be sure to run the benchmarks to check for regressions. *)\n\nopen Bigarray\nopen Common\n\ntype 'a writer = buf -> pos:pos -> 'a -> pos\ntype ('a, 'b) writer1 = 'a writer -> 'b writer\ntype ('a, 'b, 'c) writer2 = 'a writer -> ('b, 'c) writer1\ntype ('a, 'b, 'c, 'd) writer3 = 'a writer -> ('b, 'c, 'd) writer2\n\nexternal unsafe_set : buf -> int -> char -> unit = \"%caml_ba_unsafe_set_1\"\nexternal unsafe_set8 : buf -> int -> int -> unit = \"%caml_ba_unsafe_set_1\"\nexternal unsafe_set16 : buf -> int -> int -> unit = \"%caml_bigstring_set16u\"\nexternal unsafe_set32 : buf -> int -> int32 -> unit = \"%caml_bigstring_set32u\"\nexternal unsafe_set64 : buf -> int -> int64 -> unit = \"%caml_bigstring_set64u\"\nexternal bswap16 : int -> int = \"%bswap16\"\nexternal bswap32 : int32 -> int32 = \"%bswap_int32\"\nexternal bswap64 : int64 -> int64 = \"%bswap_int64\"\n\n(*$ open Bin_prot_cinaps $*)\n\nlet code_NEG_INT8 = (*$ Code.char NEG_INT8 *) '\\xff' (*$*)\n\nlet code_INT16 = (*$ Code.char INT16 *) '\\xfe' (*$*)\n\nlet code_INT32 = (*$ Code.char INT32 *) '\\xfd' (*$*)\n\nlet code_INT64 = (*$ Code.char INT64 *) '\\xfc' (*$*)\n\nlet arch_sixtyfour = Sys.word_size = 64\nlet arch_big_endian = Sys.big_endian\n\nlet unsafe_set16be =\n if arch_big_endian\n then unsafe_set16\n else fun buf pos x -> unsafe_set16 buf pos (bswap16 x)\n;;\n\nlet unsafe_set32be =\n if arch_big_endian\n then unsafe_set32\n else fun buf pos x -> unsafe_set32 buf pos (bswap32 x)\n;;\n\nlet unsafe_set64be =\n if arch_big_endian\n then unsafe_set64\n else fun buf pos x -> unsafe_set64 buf pos (bswap64 x)\n;;\n\nlet unsafe_set16le =\n if arch_big_endian\n then fun buf pos x -> unsafe_set16 buf pos (bswap16 x)\n else unsafe_set16\n;;\n\nlet unsafe_set32le =\n if arch_big_endian\n then fun buf pos x -> unsafe_set32 buf pos (bswap32 x)\n else unsafe_set32\n;;\n\nlet unsafe_set64le =\n if arch_big_endian\n then fun buf pos x -> unsafe_set64 buf pos (bswap64 x)\n else unsafe_set64\n;;\n\nlet bin_write_unit buf ~pos () =\n assert_pos pos;\n check_pos buf pos;\n unsafe_set buf pos '\\000';\n pos + 1\n;;\n\nlet bin_write_bool buf ~pos b =\n assert_pos pos;\n check_pos buf pos;\n unsafe_set buf pos (if b then '\\001' else '\\000');\n pos + 1\n;;\n\nlet all_bin_write_small_int buf pos n =\n check_pos buf pos;\n unsafe_set8 buf pos n;\n pos + 1\n;;\n\nlet all_bin_write_neg_int8 buf pos n =\n let next = pos + 2 in\n check_next buf next;\n unsafe_set buf pos code_NEG_INT8;\n unsafe_set8 buf (pos + 1) n;\n next\n;;\n\nlet all_bin_write_int16 buf pos n =\n let next = pos + 3 in\n check_next buf next;\n unsafe_set buf pos code_INT16;\n unsafe_set16le buf (pos + 1) n;\n next\n;;\n\nlet all_bin_write_int32 buf pos n =\n let next = pos + 5 in\n check_next buf next;\n unsafe_set buf pos code_INT32;\n unsafe_set32le buf (pos + 1) n;\n next\n[@@inline]\n;;\n\nlet all_bin_write_int64 buf pos n =\n let next = pos + 9 in\n check_next buf next;\n unsafe_set buf pos code_INT64;\n unsafe_set64le buf (pos + 1) n;\n next\n[@@inline]\n;;\n\nlet bin_write_char buf ~pos c =\n assert_pos pos;\n check_pos buf pos;\n unsafe_set buf pos c;\n pos + 1\n;;\n\nlet bin_write_int buf ~pos n =\n assert_pos pos;\n if n >= 0\n then\n if n < 0x00000080\n then all_bin_write_small_int buf pos n\n else if n < 0x00008000\n then all_bin_write_int16 buf pos n\n else if arch_sixtyfour && n >= 1 lsl 31\n then all_bin_write_int64 buf pos (Int64.of_int n)\n else all_bin_write_int32 buf pos (Int32.of_int n)\n else if n >= -0x00000080\n then all_bin_write_neg_int8 buf pos n\n else if n >= -0x00008000\n then all_bin_write_int16 buf pos n\n else if arch_sixtyfour && n < -(1 lsl 31)\n then all_bin_write_int64 buf pos (Int64.of_int n)\n else all_bin_write_int32 buf pos (Int32.of_int n)\n;;\n\nlet bin_write_nat0 buf ~pos nat0 =\n assert_pos pos;\n let n = (nat0 : Nat0.t :> int) in\n if n < 0x00000080\n then all_bin_write_small_int buf pos n\n else if n < 0x00010000\n then all_bin_write_int16 buf pos n\n else if arch_sixtyfour && n >= 1 lsl 32\n then all_bin_write_int64 buf pos (Int64.of_int n)\n else all_bin_write_int32 buf pos (Int32.of_int n)\n;;\n\nlet bin_write_string buf ~pos str =\n let len = String.length str in\n let plen = Nat0.unsafe_of_int len in\n let new_pos = bin_write_nat0 buf ~pos plen in\n let next = new_pos + len in\n check_next buf next;\n (* TODO: optimize for small strings *)\n unsafe_blit_string_buf ~src_pos:0 str ~dst_pos:new_pos buf ~len;\n next\n;;\n\nlet bin_write_bytes buf ~pos str =\n let len = Bytes.length str in\n let plen = Nat0.unsafe_of_int len in\n let new_pos = bin_write_nat0 buf ~pos plen in\n let next = new_pos + len in\n check_next buf next;\n (* TODO: optimize for small bytes *)\n unsafe_blit_bytes_buf ~src_pos:0 str ~dst_pos:new_pos buf ~len;\n next\n;;\n\nlet bin_write_float buf ~pos x =\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n unsafe_set64le buf pos (Int64.bits_of_float x);\n next\n[@@inline]\n;;\n\nlet bin_write_int32 =\n if arch_sixtyfour\n then fun [@inline] buf ~pos n -> bin_write_int buf ~pos (Int32.to_int n)\n else\n fun [@inline] buf ~pos n ->\n if n >= 0x00008000l || n < -0x00008000l\n then (\n assert_pos pos;\n all_bin_write_int32 buf pos n)\n else bin_write_int buf ~pos (Int32.to_int n)\n;;\n\nlet bin_write_int64 buf ~pos n =\n if n >= 0x80000000L || n < -0x80000000L\n then (\n assert_pos pos;\n all_bin_write_int64 buf pos n)\n else if arch_sixtyfour\n then bin_write_int buf ~pos (Int64.to_int n)\n else if n >= 0x00008000L || n < -0x00008000L\n then (\n assert_pos pos;\n all_bin_write_int32 buf pos (Int64.to_int32 n))\n else bin_write_int buf ~pos (Int64.to_int n)\n[@@inline]\n;;\n\nlet bin_write_nativeint buf ~pos n =\n if arch_sixtyfour\n && (n >= (* 0x80000000n *) Nativeint.shift_left 1n 31\n || n < (* -0x80000000n *) Nativeint.neg (Nativeint.shift_left 1n 31))\n then (\n assert_pos pos;\n all_bin_write_int64 buf pos (Int64.of_nativeint n))\n else if ((not arch_sixtyfour) && n >= 0x8000n) || n < -0x8000n\n then (\n assert_pos pos;\n all_bin_write_int32 buf pos (Nativeint.to_int32 n))\n else bin_write_int buf ~pos (Nativeint.to_int n)\n[@@inline]\n;;\n\nlet bin_write_ref bin_write_el buf ~pos r = bin_write_el buf ~pos !r\n\nlet bin_write_lazy bin_write_el buf ~pos lv =\n let v = Lazy.force lv in\n bin_write_el buf ~pos v\n;;\n\nlet bin_write_option bin_write_el buf ~pos = function\n | None -> bin_write_bool buf ~pos false\n | Some v ->\n let next = bin_write_bool buf ~pos true in\n bin_write_el buf ~pos:next v\n;;\n\nlet bin_write_pair bin_write_a bin_write_b buf ~pos (a, b) =\n let next = bin_write_a buf ~pos a in\n bin_write_b buf ~pos:next b\n;;\n\nlet bin_write_triple bin_write_a bin_write_b bin_write_c buf ~pos (a, b, c) =\n let next1 = bin_write_a buf ~pos a in\n let next2 = bin_write_b buf ~pos:next1 b in\n bin_write_c buf ~pos:next2 c\n;;\n\nlet bin_write_list bin_write_el buf ~pos lst =\n let rec loop els_pos = function\n | [] -> els_pos\n | h :: t ->\n let new_els_pos = bin_write_el buf ~pos:els_pos h in\n loop new_els_pos t\n in\n let len = Nat0.unsafe_of_int (List.length lst) in\n let els_pos = bin_write_nat0 buf ~pos len in\n loop els_pos lst\n;;\n\nlet bin_write_float_array buf ~pos a =\n let len = Array.length a in\n let plen = Nat0.unsafe_of_int len in\n let pos = bin_write_nat0 buf ~pos plen in\n let size = len * 8 in\n let next = pos + size in\n check_next buf next;\n unsafe_blit_float_array_buf a buf ~src_pos:0 ~dst_pos:pos ~len;\n next\n;;\n\nlet bin_write_array_loop bin_write_el buf ~els_pos ~n ar =\n let els_pos_ref = ref els_pos in\n for i = 0 to n - 1 do\n els_pos_ref := bin_write_el buf ~pos:!els_pos_ref (Array.unsafe_get ar i)\n done;\n !els_pos_ref\n;;\n\nlet bin_write_array (type a) bin_write_el buf ~pos ar =\n if (Obj.magic (bin_write_el : a writer) : float writer) == bin_write_float\n then bin_write_float_array buf ~pos (Obj.magic (ar : a array) : float array)\n else (\n let n = Array.length ar in\n let pn = Nat0.unsafe_of_int n in\n let els_pos = bin_write_nat0 buf ~pos pn in\n bin_write_array_loop bin_write_el buf ~els_pos ~n ar)\n;;\n\nlet bin_write_hashtbl bin_write_key bin_write_val buf ~pos htbl =\n let len = Hashtbl.length htbl in\n let plen = Nat0.unsafe_of_int len in\n let els_pos = bin_write_nat0 buf ~pos plen in\n let cnt_ref = ref 0 in\n let coll_htbl k v els_pos =\n incr cnt_ref;\n let new_els_pos = bin_write_key buf ~pos:els_pos k in\n bin_write_val buf ~pos:new_els_pos v\n in\n let res_pos = Hashtbl.fold coll_htbl htbl els_pos in\n if !cnt_ref <> len then raise_concurrent_modification \"bin_write_hashtbl\";\n res_pos\n;;\n\nexternal buf_of_vec32 : vec32 -> buf = \"%identity\"\nexternal buf_of_vec64 : vec64 -> buf = \"%identity\"\nexternal buf_of_mat32 : mat32 -> buf = \"%identity\"\nexternal buf_of_mat64 : mat64 -> buf = \"%identity\"\n\nlet bin_write_float32_vec buf ~pos v =\n let len = Array1.dim v in\n let plen = Nat0.unsafe_of_int len in\n let pos = bin_write_nat0 buf ~pos plen in\n let size = len * 4 in\n let next = pos + size in\n check_next buf next;\n unsafe_blit_buf ~src:(buf_of_vec32 v) ~src_pos:0 ~dst:buf ~dst_pos:pos ~len:size;\n next\n;;\n\nlet bin_write_float64_vec buf ~pos v =\n let len = Array1.dim v in\n let plen = Nat0.unsafe_of_int len in\n let pos = bin_write_nat0 buf ~pos plen in\n let size = len * 8 in\n let next = pos + size in\n check_next buf next;\n unsafe_blit_buf ~src:(buf_of_vec64 v) ~src_pos:0 ~dst:buf ~dst_pos:pos ~len:size;\n next\n;;\n\nlet bin_write_vec = bin_write_float64_vec\n\nlet bin_write_float32_mat buf ~pos m =\n let len1 = Array2.dim1 m in\n let len2 = Array2.dim2 m in\n let pos = bin_write_nat0 buf ~pos (Nat0.unsafe_of_int len1) in\n let pos = bin_write_nat0 buf ~pos (Nat0.unsafe_of_int len2) in\n let size = len1 * len2 * 4 in\n let next = pos + size in\n check_next buf next;\n unsafe_blit_buf ~src:(buf_of_mat32 m) ~src_pos:0 ~dst:buf ~dst_pos:pos ~len:size;\n next\n;;\n\nlet bin_write_float64_mat buf ~pos m =\n let len1 = Array2.dim1 m in\n let len2 = Array2.dim2 m in\n let pos = bin_write_nat0 buf ~pos (Nat0.unsafe_of_int len1) in\n let pos = bin_write_nat0 buf ~pos (Nat0.unsafe_of_int len2) in\n let size = len1 * len2 * 8 in\n let next = pos + size in\n check_next buf next;\n unsafe_blit_buf ~src:(buf_of_mat64 m) ~src_pos:0 ~dst:buf ~dst_pos:pos ~len:size;\n next\n;;\n\nlet bin_write_mat = bin_write_float64_mat\n\nlet bin_write_bigstring buf ~pos s =\n let len = Array1.dim s in\n let plen = Nat0.unsafe_of_int len in\n let pos = bin_write_nat0 buf ~pos plen in\n let next = pos + len in\n check_next buf next;\n unsafe_blit_buf ~src:s ~src_pos:0 ~dst:buf ~dst_pos:pos ~len;\n next\n;;\n\nlet bin_write_variant_int buf ~pos x =\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n unsafe_set32le buf pos (Int32.logor (Int32.shift_left (Int32.of_int x) 1) 1l);\n next\n;;\n\nlet bin_write_int_8bit buf ~pos n =\n assert_pos pos;\n check_pos buf pos;\n unsafe_set8 buf pos n;\n pos + 1\n;;\n\nlet bin_write_int_16bit buf ~pos n =\n assert_pos pos;\n let next = pos + 2 in\n check_next buf next;\n unsafe_set16le buf pos n;\n next\n;;\n\nlet bin_write_int_32bit buf ~pos n =\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n unsafe_set32le buf pos (Int32.of_int n);\n next\n;;\n\nlet bin_write_int_64bit buf ~pos n =\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n unsafe_set64le buf pos (Int64.of_int n);\n next\n;;\n\nlet bin_write_int64_bits buf ~pos n =\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n unsafe_set64le buf pos n;\n next\n;;\n\nlet bin_write_network16_int buf ~pos n =\n assert_pos pos;\n let next = pos + 2 in\n check_next buf next;\n unsafe_set16be buf pos n;\n next\n;;\n\nlet bin_write_network32_int buf ~pos n =\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n unsafe_set32be buf pos (Int32.of_int n);\n next\n;;\n\nlet bin_write_network32_int32 buf ~pos n =\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n unsafe_set32be buf pos n;\n next\n;;\n\nlet bin_write_network64_int buf ~pos n =\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n unsafe_set64be buf pos (Int64.of_int n);\n next\n;;\n\nlet bin_write_network64_int64 buf ~pos n =\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n unsafe_set64be buf pos n;\n next\n;;\n\nlet bin_write_array_no_length bin_write_el buf ~pos ar =\n bin_write_array_loop bin_write_el buf ~els_pos:pos ~n:(Array.length ar) ar\n;;\n\nexternal unsafe_string_get32 : string -> int -> int32 = \"%caml_string_get32u\"\nexternal unsafe_string_get64 : string -> int -> int64 = \"%caml_string_get64u\"\n\nlet bin_write_md5 buf ~pos x =\n let x = Md5_lib.to_binary x in\n assert (String.length x = 16);\n assert_pos pos;\n let next = pos + 16 in\n check_next buf next;\n if arch_sixtyfour\n then (\n let a = unsafe_string_get64 x 0 in\n let b = unsafe_string_get64 x 8 in\n unsafe_set64 buf pos a;\n unsafe_set64 buf (pos + 8) b)\n else (\n let a = unsafe_string_get32 x 0 in\n let b = unsafe_string_get32 x 4 in\n let c = unsafe_string_get32 x 8 in\n let d = unsafe_string_get32 x 12 in\n unsafe_set32 buf pos a;\n unsafe_set32 buf (pos + 4) b;\n unsafe_set32 buf (pos + 8) c;\n unsafe_set32 buf (pos + 12) d);\n next\n;;\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Para, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1997 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Internals of forcing lazy values. *)\n\ntype 'a t = 'a lazy_t\n\nexception Undefined\n\nlet raise_undefined = Obj.repr (fun () -> raise Undefined)\n\nexternal make_forward : Obj.t -> Obj.t -> unit = \"caml_obj_make_forward\"\n\n(* Assume [blk] is a block with tag lazy *)\nlet force_lazy_block (blk : 'arg lazy_t) =\n let closure = (Obj.obj (Obj.field (Obj.repr blk) 0) : unit -> 'arg) in\n Obj.set_field (Obj.repr blk) 0 raise_undefined;\n try\n let result = closure () in\n make_forward (Obj.repr blk) (Obj.repr result);\n result\n with e ->\n Obj.set_field (Obj.repr blk) 0 (Obj.repr (fun () -> raise e));\n raise e\n\n\n(* Assume [blk] is a block with tag lazy *)\nlet force_val_lazy_block (blk : 'arg lazy_t) =\n let closure = (Obj.obj (Obj.field (Obj.repr blk) 0) : unit -> 'arg) in\n Obj.set_field (Obj.repr blk) 0 raise_undefined;\n let result = closure () in\n make_forward (Obj.repr blk) (Obj.repr result);\n result\n\n\n(* [force] is not used, since [Lazy.force] is declared as a primitive\n whose code inlines the tag tests of its argument, except when afl\n instrumentation is turned on. *)\n\nlet force (lzv : 'arg lazy_t) =\n (* Using [Sys.opaque_identity] prevents two potential problems:\n - If the value is known to have Forward_tag, then its tag could have\n changed during GC, so that information must be forgotten (see GPR#713\n and issue #7301)\n - If the value is known to be immutable, then if the compiler\n cannot prove that the last branch is not taken it will issue a\n warning 59 (modification of an immutable value) *)\n let lzv = Sys.opaque_identity lzv in\n let x = Obj.repr lzv in\n let t = Obj.tag x in\n if t = Obj.forward_tag then (Obj.obj (Obj.field x 0) : 'arg) else\n if t <> Obj.lazy_tag then (Obj.obj x : 'arg)\n else force_lazy_block lzv\n\n\nlet force_val (lzv : 'arg lazy_t) =\n let x = Obj.repr lzv in\n let t = Obj.tag x in\n if t = Obj.forward_tag then (Obj.obj (Obj.field x 0) : 'arg) else\n if t <> Obj.lazy_tag then (Obj.obj x : 'arg)\n else force_val_lazy_block lzv\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Para, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1997 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Lazy]: deferred computations *)\n\n\n(*\n WARNING: some purple magic is going on here. Do not take this file\n as an example of how to program in OCaml.\n*)\n\n\n(* We make use of two special tags provided by the runtime:\n [lazy_tag] and [forward_tag].\n\n A value of type ['a Lazy.t] can be one of three things:\n 1. A block of size 1 with tag [lazy_tag]. Its field is a closure of\n type [unit -> 'a] that computes the value.\n 2. A block of size 1 with tag [forward_tag]. Its field is the value\n of type ['a] that was computed.\n 3. Anything else except a float. This has type ['a] and is the value\n that was computed.\n Exceptions are stored in format (1).\n The GC will magically change things from (2) to (3) according to its\n fancy.\n\n If OCaml was configured with the -flat-float-array option (which is\n currently the default), the following is also true:\n We cannot use representation (3) for a [float Lazy.t] because\n [caml_make_array] assumes that only a [float] value can have tag\n [Double_tag].\n\n We have to use the built-in type constructor [lazy_t] to\n let the compiler implement the special typing and compilation\n rules for the [lazy] keyword.\n*)\n\ntype 'a t = 'a CamlinternalLazy.t\n\nexception Undefined = CamlinternalLazy.Undefined\n\nexternal make_forward : 'a -> 'a lazy_t = \"caml_lazy_make_forward\"\n\nexternal force : 'a t -> 'a = \"%lazy_force\"\n\n\nlet force_val = CamlinternalLazy.force_val\n\nlet from_fun (f : unit -> 'arg) =\n let x = Obj.new_block Obj.lazy_tag 1 in\n Obj.set_field x 0 (Obj.repr f);\n (Obj.obj x : 'arg t)\n\nlet from_val (v : 'arg) =\n let t = Obj.tag (Obj.repr v) in\n if t = Obj.forward_tag || t = Obj.lazy_tag || t = Obj.double_tag then begin\n make_forward v\n end else begin\n (Obj.magic v : 'arg t)\n end\n\n\nlet is_val (l : 'arg t) = Obj.tag (Obj.repr l) <> Obj.lazy_tag\n\nlet lazy_from_fun = from_fun\n\nlet lazy_from_val = from_val\n\nlet lazy_is_val = is_val\n\n\nlet map f x =\n lazy (f (force x))\n\nlet map_val f x =\n if is_val x\n then lazy_from_val (f (force x))\n else lazy (f (force x))\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Simon Cruanes *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Seq]: functional iterators *)\n\ntype +'a node =\n | Nil\n | Cons of 'a * 'a t\n\nand 'a t = unit -> 'a node\n\nlet empty () = Nil\n\nlet return x () = Cons (x, empty)\n\nlet cons x next () = Cons (x, next)\n\nlet rec append seq1 seq2 () =\n match seq1() with\n | Nil -> seq2()\n | Cons (x, next) -> Cons (x, append next seq2)\n\nlet rec map f seq () = match seq() with\n | Nil -> Nil\n | Cons (x, next) -> Cons (f x, map f next)\n\nlet rec filter_map f seq () = match seq() with\n | Nil -> Nil\n | Cons (x, next) ->\n match f x with\n | None -> filter_map f next ()\n | Some y -> Cons (y, filter_map f next)\n\nlet rec filter f seq () = match seq() with\n | Nil -> Nil\n | Cons (x, next) ->\n if f x\n then Cons (x, filter f next)\n else filter f next ()\n\nlet rec concat seq () = match seq () with\n | Nil -> Nil\n | Cons (x, next) ->\n append x (concat next) ()\n\nlet rec flat_map f seq () = match seq () with\n | Nil -> Nil\n | Cons (x, next) ->\n append (f x) (flat_map f next) ()\n\nlet concat_map = flat_map\n\nlet rec fold_left f acc seq =\n match seq () with\n | Nil -> acc\n | Cons (x, next) ->\n let acc = f acc x in\n fold_left f acc next\n\nlet rec iter f seq =\n match seq () with\n | Nil -> ()\n | Cons (x, next) ->\n f x;\n iter f next\n\nlet rec unfold f u () =\n match f u with\n | None -> Nil\n | Some (x, u') -> Cons (x, unfold f u')\n\nlet is_empty xs =\n match xs() with\n | Nil ->\n true\n | Cons (_, _) ->\n false\n\nlet uncons xs =\n match xs() with\n | Cons (x, xs) ->\n Some (x, xs)\n | Nil ->\n None\n\n\n\nlet rec length_aux accu xs =\n match xs() with\n | Nil ->\n accu\n | Cons (_, xs) ->\n length_aux (accu + 1) xs\n\nlet[@inline] length xs =\n length_aux 0 xs\n\nlet rec iteri_aux f i xs =\n match xs() with\n | Nil ->\n ()\n | Cons (x, xs) ->\n f i x;\n iteri_aux f (i+1) xs\n\nlet[@inline] iteri f xs =\n iteri_aux f 0 xs\n\nlet rec fold_lefti_aux f accu i xs =\n match xs() with\n | Nil ->\n accu\n | Cons (x, xs) ->\n let accu = f accu i x in\n fold_lefti_aux f accu (i+1) xs\n\nlet[@inline] fold_lefti f accu xs =\n fold_lefti_aux f accu 0 xs\n\nlet rec for_all p xs =\n match xs() with\n | Nil ->\n true\n | Cons (x, xs) ->\n p x && for_all p xs\n\nlet rec exists p xs =\n match xs() with\n | Nil ->\n false\n | Cons (x, xs) ->\n p x || exists p xs\n\nlet rec find p xs =\n match xs() with\n | Nil ->\n None\n | Cons (x, xs) ->\n if p x then Some x else find p xs\n\nlet rec find_map f xs =\n match xs() with\n | Nil ->\n None\n | Cons (x, xs) ->\n match f x with\n | None ->\n find_map f xs\n | Some _ as result ->\n result\n\n(* [iter2], [fold_left2], [for_all2], [exists2], [map2], [zip] work also in\n the case where the two sequences have different lengths. They stop as soon\n as one sequence is exhausted. Their behavior is slightly asymmetric: when\n [xs] is empty, they do not force [ys]; however, when [ys] is empty, [xs] is\n forced, even though the result of the function application [xs()] turns out\n to be useless. *)\n\nlet rec iter2 f xs ys =\n match xs() with\n | Nil ->\n ()\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n ()\n | Cons (y, ys) ->\n f x y;\n iter2 f xs ys\n\nlet rec fold_left2 f accu xs ys =\n match xs() with\n | Nil ->\n accu\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n accu\n | Cons (y, ys) ->\n let accu = f accu x y in\n fold_left2 f accu xs ys\n\nlet rec for_all2 f xs ys =\n match xs() with\n | Nil ->\n true\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n true\n | Cons (y, ys) ->\n f x y && for_all2 f xs ys\n\nlet rec exists2 f xs ys =\n match xs() with\n | Nil ->\n false\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n false\n | Cons (y, ys) ->\n f x y || exists2 f xs ys\n\nlet rec equal eq xs ys =\n match xs(), ys() with\n | Nil, Nil ->\n true\n | Cons (x, xs), Cons (y, ys) ->\n eq x y && equal eq xs ys\n | Nil, Cons (_, _)\n | Cons (_, _), Nil ->\n false\n\nlet rec compare cmp xs ys =\n match xs(), ys() with\n | Nil, Nil ->\n 0\n | Cons (x, xs), Cons (y, ys) ->\n let c = cmp x y in\n if c <> 0 then c else compare cmp xs ys\n | Nil, Cons (_, _) ->\n -1\n | Cons (_, _), Nil ->\n +1\n\n\n\n(* [init_aux f i j] is the sequence [f i, ..., f (j-1)]. *)\n\nlet rec init_aux f i j () =\n if i < j then begin\n Cons (f i, init_aux f (i + 1) j)\n end\n else\n Nil\n\nlet init n f =\n if n < 0 then\n invalid_arg \"Seq.init\"\n else\n init_aux f 0 n\n\nlet rec repeat x () =\n Cons (x, repeat x)\n\nlet rec forever f () =\n Cons (f(), forever f)\n\n(* This preliminary definition of [cycle] requires the sequence [xs]\n to be nonempty. Applying it to an empty sequence would produce a\n sequence that diverges when it is forced. *)\n\nlet rec cycle_nonempty xs () =\n append xs (cycle_nonempty xs) ()\n\n(* [cycle xs] checks whether [xs] is empty and, if so, returns an empty\n sequence. Otherwise, [cycle xs] produces one copy of [xs] followed\n with the infinite sequence [cycle_nonempty xs]. Thus, the nonemptiness\n check is performed just once. *)\n\nlet cycle xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs') ->\n Cons (x, append xs' (cycle_nonempty xs))\n\n(* [iterate1 f x] is the sequence [f x, f (f x), ...].\n It is equivalent to [tail (iterate f x)].\n [iterate1] is used as a building block in the definition of [iterate]. *)\n\nlet rec iterate1 f x () =\n let y = f x in\n Cons (y, iterate1 f y)\n\n(* [iterate f x] is the sequence [x, f x, ...]. *)\n\n(* The reason why we give this slightly indirect definition of [iterate],\n as opposed to the more naive definition that may come to mind, is that\n we are careful to avoid evaluating [f x] until this function call is\n actually necessary. The naive definition (not shown here) computes the\n second argument of the sequence, [f x], when the first argument is\n requested by the user. *)\n\nlet iterate f x =\n cons x (iterate1 f x)\n\n\n\nlet rec mapi_aux f i xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n Cons (f i x, mapi_aux f (i+1) xs)\n\nlet[@inline] mapi f xs =\n mapi_aux f 0 xs\n\n(* [tail_scan f s xs] is equivalent to [tail (scan f s xs)].\n [tail_scan] is used as a building block in the definition of [scan]. *)\n\n(* This slightly indirect definition of [scan] is meant to avoid computing\n elements too early; see the above comment about [iterate1] and [iterate]. *)\n\nlet rec tail_scan f s xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n let s = f s x in\n Cons (s, tail_scan f s xs)\n\nlet scan f s xs =\n cons s (tail_scan f s xs)\n\n(* [take] is defined in such a way that [take 0 xs] returns [empty]\n immediately, without allocating any memory. *)\n\nlet rec take_aux n xs =\n if n = 0 then\n empty\n else\n fun () ->\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n Cons (x, take_aux (n-1) xs)\n\nlet take n xs =\n if n < 0 then invalid_arg \"Seq.take\";\n take_aux n xs\n\n(* [force_drop n xs] is equivalent to [drop n xs ()].\n [force_drop n xs] requires [n > 0].\n [force_drop] is used as a building block in the definition of [drop]. *)\n\nlet rec force_drop n xs =\n match xs() with\n | Nil ->\n Nil\n | Cons (_, xs) ->\n let n = n - 1 in\n if n = 0 then\n xs()\n else\n force_drop n xs\n\n(* [drop] is defined in such a way that [drop 0 xs] returns [xs] immediately,\n without allocating any memory. *)\n\nlet drop n xs =\n if n < 0 then invalid_arg \"Seq.drop\"\n else if n = 0 then\n xs\n else\n fun () ->\n force_drop n xs\n\nlet rec take_while p xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n if p x then Cons (x, take_while p xs) else Nil\n\nlet rec drop_while p xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) as node ->\n if p x then drop_while p xs () else node\n\nlet rec group eq xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n Cons (cons x (take_while (eq x) xs), group eq (drop_while (eq x) xs))\n\nexception Forced_twice\n\nmodule Suspension = struct\n\n type 'a suspension =\n unit -> 'a\n\n (* Conversions. *)\n\n let to_lazy : 'a suspension -> 'a Lazy.t =\n Lazy.from_fun\n (* fun s -> lazy (s()) *)\n\n let from_lazy (s : 'a Lazy.t) : 'a suspension =\n fun () -> Lazy.force s\n\n (* [memoize] turns an arbitrary suspension into a persistent suspension. *)\n\n let memoize (s : 'a suspension) : 'a suspension =\n from_lazy (to_lazy s)\n\n (* [failure] is a suspension that fails when forced. *)\n\n let failure : _ suspension =\n fun () ->\n (* A suspension created by [once] has been forced twice. *)\n raise Forced_twice\n\n (* If [f] is a suspension, then [once f] is a suspension that can be forced\n at most once. If it is forced more than once, then [Forced_twice] is\n raised. *)\n\n let once (f : 'a suspension) : 'a suspension =\n let action = CamlinternalAtomic.make f in\n fun () ->\n (* Get the function currently stored in [action], and write the\n function [failure] in its place, so the next access will result\n in a call to [failure()]. *)\n let f = CamlinternalAtomic.exchange action failure in\n f()\n\nend (* Suspension *)\n\nlet rec memoize xs =\n Suspension.memoize (fun () ->\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n Cons (x, memoize xs)\n )\n\nlet rec once xs =\n Suspension.once (fun () ->\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n Cons (x, once xs)\n )\n\n\nlet rec zip xs ys () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n Nil\n | Cons (y, ys) ->\n Cons ((x, y), zip xs ys)\n\nlet rec map2 f xs ys () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n match ys() with\n | Nil ->\n Nil\n | Cons (y, ys) ->\n Cons (f x y, map2 f xs ys)\n\nlet rec interleave xs ys () =\n match xs() with\n | Nil ->\n ys()\n | Cons (x, xs) ->\n Cons (x, interleave ys xs)\n\n(* [sorted_merge1l cmp x xs ys] is equivalent to\n [sorted_merge cmp (cons x xs) ys].\n\n [sorted_merge1r cmp xs y ys] is equivalent to\n [sorted_merge cmp xs (cons y ys)].\n\n [sorted_merge1 cmp x xs y ys] is equivalent to\n [sorted_merge cmp (cons x xs) (cons y ys)].\n\n These three functions are used as building blocks in the definition\n of [sorted_merge]. *)\n\nlet rec sorted_merge1l cmp x xs ys () =\n match ys() with\n | Nil ->\n Cons (x, xs)\n | Cons (y, ys) ->\n sorted_merge1 cmp x xs y ys\n\nand sorted_merge1r cmp xs y ys () =\n match xs() with\n | Nil ->\n Cons (y, ys)\n | Cons (x, xs) ->\n sorted_merge1 cmp x xs y ys\n\nand sorted_merge1 cmp x xs y ys =\n if cmp x y <= 0 then\n Cons (x, sorted_merge1r cmp xs y ys)\n else\n Cons (y, sorted_merge1l cmp x xs ys)\n\nlet sorted_merge cmp xs ys () =\n match xs(), ys() with\n | Nil, Nil ->\n Nil\n | Nil, c\n | c, Nil ->\n c\n | Cons (x, xs), Cons (y, ys) ->\n sorted_merge1 cmp x xs y ys\n\n\nlet rec map_fst xys () =\n match xys() with\n | Nil ->\n Nil\n | Cons ((x, _), xys) ->\n Cons (x, map_fst xys)\n\nlet rec map_snd xys () =\n match xys() with\n | Nil ->\n Nil\n | Cons ((_, y), xys) ->\n Cons (y, map_snd xys)\n\nlet unzip xys =\n map_fst xys, map_snd xys\n\nlet split =\n unzip\n\n(* [filter_map_find_left_map f xs] is equivalent to\n [filter_map Either.find_left (map f xs)]. *)\n\nlet rec filter_map_find_left_map f xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n match f x with\n | Either.Left y ->\n Cons (y, filter_map_find_left_map f xs)\n | Either.Right _ ->\n filter_map_find_left_map f xs ()\n\nlet rec filter_map_find_right_map f xs () =\n match xs() with\n | Nil ->\n Nil\n | Cons (x, xs) ->\n match f x with\n | Either.Left _ ->\n filter_map_find_right_map f xs ()\n | Either.Right z ->\n Cons (z, filter_map_find_right_map f xs)\n\nlet partition_map f xs =\n filter_map_find_left_map f xs,\n filter_map_find_right_map f xs\n\nlet partition p xs =\n filter p xs, filter (fun x -> not (p x)) xs\n\n(* If [xss] is a matrix (a sequence of rows), then [peel xss] is a pair of\n the first column (a sequence of elements) and of the remainder of the\n matrix (a sequence of shorter rows). These two sequences have the same\n length. The rows of the matrix [xss] are not required to have the same\n length. An empty row is ignored. *)\n\n(* Because [peel] uses [unzip], its argument must be persistent. The same\n remark applies to [transpose], [diagonals], [product], etc. *)\n\nlet peel xss =\n unzip (filter_map uncons xss)\n\nlet rec transpose xss () =\n let heads, tails = peel xss in\n if is_empty heads then begin\n assert (is_empty tails);\n Nil\n end\n else\n Cons (heads, transpose tails)\n\n(* The internal function [diagonals] takes an extra argument, [remainders],\n which contains the remainders of the rows that have already been\n discovered. *)\n\nlet rec diagonals remainders xss () =\n match xss() with\n | Cons (xs, xss) ->\n begin match xs() with\n | Cons (x, xs) ->\n (* We discover a new nonempty row [x :: xs]. Thus, the next diagonal\n is [x :: heads]: this diagonal begins with [x] and continues with\n the first element of every row in [remainders]. In the recursive\n call, the argument [remainders] is instantiated with [xs ::\n tails], which means that we have one more remaining row, [xs],\n and that we keep the tails of the pre-existing remaining rows. *)\n let heads, tails = peel remainders in\n Cons (cons x heads, diagonals (cons xs tails) xss)\n | Nil ->\n (* We discover a new empty row. In this case, the new diagonal is\n just [heads], and [remainders] is instantiated with just [tails],\n as we do not have one more remaining row. *)\n let heads, tails = peel remainders in\n Cons (heads, diagonals tails xss)\n end\n | Nil ->\n (* There are no more rows to be discovered. There remains to exhaust\n the remaining rows. *)\n transpose remainders ()\n\n(* If [xss] is a matrix (a sequence of rows), then [diagonals xss] is\n the sequence of its diagonals.\n\n The first diagonal contains just the first element of the\n first row. The second diagonal contains the first element of the\n second row and the second element of the first row; and so on.\n This kind of diagonal is in fact sometimes known as an antidiagonal.\n\n - Every diagonal is a finite sequence.\n - The rows of the matrix [xss] are not required to have the same length.\n - The matrix [xss] is not required to be finite (in either direction).\n - The matrix [xss] must be persistent. *)\n\nlet diagonals xss =\n diagonals empty xss\n\nlet map_product f xs ys =\n concat (diagonals (\n map (fun x ->\n map (fun y ->\n f x y\n ) ys\n ) xs\n ))\n\nlet product xs ys =\n map_product (fun x y -> (x, y)) xs ys\n\nlet of_dispenser it =\n let rec c () =\n match it() with\n | None ->\n Nil\n | Some x ->\n Cons (x, c)\n in\n c\n\nlet to_dispenser xs =\n let s = ref xs in\n fun () ->\n match (!s)() with\n | Nil ->\n None\n | Cons (x, xs) ->\n s := xs;\n Some x\n\n\n\nlet rec ints i () =\n Cons (i, ints (i + 1))\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* The OCaml programmers *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype 'a t = 'a option = None | Some of 'a\n\nlet none = None\nlet some v = Some v\nlet value o ~default = match o with Some v -> v | None -> default\nlet get = function Some v -> v | None -> invalid_arg \"option is None\"\nlet bind o f = match o with None -> None | Some v -> f v\nlet join = function Some o -> o | None -> None\nlet map f o = match o with None -> None | Some v -> Some (f v)\nlet fold ~none ~some = function Some v -> some v | None -> none\nlet iter f = function Some v -> f v | None -> ()\nlet is_none = function None -> true | Some _ -> false\nlet is_some = function None -> false | Some _ -> true\n\nlet equal eq o0 o1 = match o0, o1 with\n| Some v0, Some v1 -> eq v0 v1\n| None, None -> true\n| _ -> false\n\nlet compare cmp o0 o1 = match o0, o1 with\n| Some v0, Some v1 -> cmp v0 v1\n| None, None -> 0\n| None, Some _ -> -1\n| Some _, None -> 1\n\nlet to_result ~none = function None -> Error none | Some v -> Ok v\nlet to_list = function None -> [] | Some v -> [v]\nlet to_seq = function None -> Seq.empty | Some v -> Seq.return v\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* The OCaml programmers *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype ('a, 'e) t = ('a, 'e) result = Ok of 'a | Error of 'e\n\nlet ok v = Ok v\nlet error e = Error e\nlet value r ~default = match r with Ok v -> v | Error _ -> default\nlet get_ok = function Ok v -> v | Error _ -> invalid_arg \"result is Error _\"\nlet get_error = function Error e -> e | Ok _ -> invalid_arg \"result is Ok _\"\nlet bind r f = match r with Ok v -> f v | Error _ as e -> e\nlet join = function Ok r -> r | Error _ as e -> e\nlet map f = function Ok v -> Ok (f v) | Error _ as e -> e\nlet map_error f = function Error e -> Error (f e) | Ok _ as v -> v\nlet fold ~ok ~error = function Ok v -> ok v | Error e -> error e\nlet iter f = function Ok v -> f v | Error _ -> ()\nlet iter_error f = function Error e -> f e | Ok _ -> ()\nlet is_ok = function Ok _ -> true | Error _ -> false\nlet is_error = function Error _ -> true | Ok _ -> false\n\nlet equal ~ok ~error r0 r1 = match r0, r1 with\n| Ok v0, Ok v1 -> ok v0 v1\n| Error e0, Error e1 -> error e0 e1\n| _, _ -> false\n\nlet compare ~ok ~error r0 r1 = match r0, r1 with\n| Ok v0, Ok v1 -> ok v0 v1\n| Error e0, Error e1 -> error e0 e1\n| Ok _, Error _ -> -1\n| Error _, Ok _ -> 1\n\nlet to_option = function Ok v -> Some v | Error _ -> None\nlet to_list = function Ok v -> [v] | Error _ -> []\nlet to_seq = function Ok v -> Seq.return v | Error _ -> Seq.empty\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Character operations *)\n\nexternal code: char -> int = \"%identity\"\nexternal unsafe_chr: int -> char = \"%identity\"\n\nlet chr n =\n if n < 0 || n > 255 then invalid_arg \"Char.chr\" else unsafe_chr n\n\nexternal bytes_create: int -> bytes = \"caml_create_bytes\"\nexternal bytes_unsafe_set : bytes -> int -> char -> unit\n = \"%bytes_unsafe_set\"\nexternal unsafe_to_string : bytes -> string = \"%bytes_to_string\"\n\nlet escaped = function\n | '\\'' -> \"\\\\'\"\n | '\\\\' -> \"\\\\\\\\\"\n | '\\n' -> \"\\\\n\"\n | '\\t' -> \"\\\\t\"\n | '\\r' -> \"\\\\r\"\n | '\\b' -> \"\\\\b\"\n | ' ' .. '~' as c ->\n let s = bytes_create 1 in\n bytes_unsafe_set s 0 c;\n unsafe_to_string s\n | c ->\n let n = code c in\n let s = bytes_create 4 in\n bytes_unsafe_set s 0 '\\\\';\n bytes_unsafe_set s 1 (unsafe_chr (48 + n / 100));\n bytes_unsafe_set s 2 (unsafe_chr (48 + (n / 10) mod 10));\n bytes_unsafe_set s 3 (unsafe_chr (48 + n mod 10));\n unsafe_to_string s\n\nlet lowercase = function\n | 'A' .. 'Z'\n | '\\192' .. '\\214'\n | '\\216' .. '\\222' as c ->\n unsafe_chr(code c + 32)\n | c -> c\n\nlet uppercase = function\n | 'a' .. 'z'\n | '\\224' .. '\\246'\n | '\\248' .. '\\254' as c ->\n unsafe_chr(code c - 32)\n | c -> c\n\nlet lowercase_ascii = function\n | 'A' .. 'Z' as c -> unsafe_chr(code c + 32)\n | c -> c\n\nlet uppercase_ascii = function\n | 'a' .. 'z' as c -> unsafe_chr(code c - 32)\n | c -> c\n\ntype t = char\n\nlet compare c1 c2 = code c1 - code c2\nlet equal (c1: t) (c2: t) = compare c1 c2 = 0\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* The OCaml programmers *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype t = int\n\nlet zero = 0\nlet one = 1\nlet minus_one = -1\nexternal neg : int -> int = \"%negint\"\nexternal add : int -> int -> int = \"%addint\"\nexternal sub : int -> int -> int = \"%subint\"\nexternal mul : int -> int -> int = \"%mulint\"\nexternal div : int -> int -> int = \"%divint\"\nexternal rem : int -> int -> int = \"%modint\"\nexternal succ : int -> int = \"%succint\"\nexternal pred : int -> int = \"%predint\"\nlet abs x = if x >= 0 then x else -x\nlet max_int = (-1) lsr 1\nlet min_int = max_int + 1\nexternal logand : int -> int -> int = \"%andint\"\nexternal logor : int -> int -> int = \"%orint\"\nexternal logxor : int -> int -> int = \"%xorint\"\nlet lognot x = logxor x (-1)\nexternal shift_left : int -> int -> int = \"%lslint\"\nexternal shift_right : int -> int -> int = \"%asrint\"\nexternal shift_right_logical : int -> int -> int = \"%lsrint\"\nlet equal : int -> int -> bool = ( = )\nlet compare : int -> int -> int = Stdlib.compare\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\nexternal to_float : int -> float = \"%floatofint\"\nexternal of_float : float -> int = \"%intoffloat\"\n\n(*\nexternal int_of_string : string -> int = \"caml_int_of_string\"\nlet of_string s = try Some (int_of_string s) with Failure _ -> None\n*)\n\nexternal format_int : string -> int -> string = \"caml_format_int\"\nlet to_string x = format_int \"%d\" x\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Byte sequence operations *)\n\n(* WARNING: Some functions in this file are duplicated in string.ml for\n efficiency reasons. When you modify the one in this file you need to\n modify its duplicate in string.ml.\n These functions have a \"duplicated\" comment above their definition.\n*)\n\nexternal length : bytes -> int = \"%bytes_length\"\nexternal string_length : string -> int = \"%string_length\"\nexternal get : bytes -> int -> char = \"%bytes_safe_get\"\nexternal set : bytes -> int -> char -> unit = \"%bytes_safe_set\"\nexternal create : int -> bytes = \"caml_create_bytes\"\nexternal unsafe_get : bytes -> int -> char = \"%bytes_unsafe_get\"\nexternal unsafe_set : bytes -> int -> char -> unit = \"%bytes_unsafe_set\"\nexternal unsafe_fill : bytes -> int -> int -> char -> unit\n = \"caml_fill_bytes\" [@@noalloc]\nexternal unsafe_to_string : bytes -> string = \"%bytes_to_string\"\nexternal unsafe_of_string : string -> bytes = \"%bytes_of_string\"\n\nexternal unsafe_blit : bytes -> int -> bytes -> int -> int -> unit\n = \"caml_blit_bytes\" [@@noalloc]\nexternal unsafe_blit_string : string -> int -> bytes -> int -> int -> unit\n = \"caml_blit_string\" [@@noalloc]\n\nlet make n c =\n let s = create n in\n unsafe_fill s 0 n c;\n s\n\nlet init n f =\n let s = create n in\n for i = 0 to n - 1 do\n unsafe_set s i (f i)\n done;\n s\n\nlet empty = create 0\n\nlet copy s =\n let len = length s in\n let r = create len in\n unsafe_blit s 0 r 0 len;\n r\n\nlet to_string b = unsafe_to_string (copy b)\nlet of_string s = copy (unsafe_of_string s)\n\nlet sub s ofs len =\n if ofs < 0 || len < 0 || ofs > length s - len\n then invalid_arg \"String.sub / Bytes.sub\"\n else begin\n let r = create len in\n unsafe_blit s ofs r 0 len;\n r\n end\n\nlet sub_string b ofs len = unsafe_to_string (sub b ofs len)\n\n(* addition with an overflow check *)\nlet (++) a b =\n let c = a + b in\n match a < 0, b < 0, c < 0 with\n | true , true , false\n | false, false, true -> invalid_arg \"Bytes.extend\" (* overflow *)\n | _ -> c\n\nlet extend s left right =\n let len = length s ++ left ++ right in\n let r = create len in\n let (srcoff, dstoff) = if left < 0 then -left, 0 else 0, left in\n let cpylen = Int.min (length s - srcoff) (len - dstoff) in\n if cpylen > 0 then unsafe_blit s srcoff r dstoff cpylen;\n r\n\nlet fill s ofs len c =\n if ofs < 0 || len < 0 || ofs > length s - len\n then invalid_arg \"String.fill / Bytes.fill\"\n else unsafe_fill s ofs len c\n\nlet blit s1 ofs1 s2 ofs2 len =\n if len < 0 || ofs1 < 0 || ofs1 > length s1 - len\n || ofs2 < 0 || ofs2 > length s2 - len\n then invalid_arg \"Bytes.blit\"\n else unsafe_blit s1 ofs1 s2 ofs2 len\n\nlet blit_string s1 ofs1 s2 ofs2 len =\n if len < 0 || ofs1 < 0 || ofs1 > string_length s1 - len\n || ofs2 < 0 || ofs2 > length s2 - len\n then invalid_arg \"String.blit / Bytes.blit_string\"\n else unsafe_blit_string s1 ofs1 s2 ofs2 len\n\n(* duplicated in string.ml *)\nlet iter f a =\n for i = 0 to length a - 1 do f(unsafe_get a i) done\n\n(* duplicated in string.ml *)\nlet iteri f a =\n for i = 0 to length a - 1 do f i (unsafe_get a i) done\n\nlet ensure_ge (x:int) y = if x >= y then x else invalid_arg \"Bytes.concat\"\n\nlet rec sum_lengths acc seplen = function\n | [] -> acc\n | hd :: [] -> length hd + acc\n | hd :: tl -> sum_lengths (ensure_ge (length hd + seplen + acc) acc) seplen tl\n\nlet rec unsafe_blits dst pos sep seplen = function\n [] -> dst\n | hd :: [] ->\n unsafe_blit hd 0 dst pos (length hd); dst\n | hd :: tl ->\n unsafe_blit hd 0 dst pos (length hd);\n unsafe_blit sep 0 dst (pos + length hd) seplen;\n unsafe_blits dst (pos + length hd + seplen) sep seplen tl\n\nlet concat sep = function\n [] -> empty\n | l -> let seplen = length sep in\n unsafe_blits\n (create (sum_lengths 0 seplen l))\n 0 sep seplen l\n\nlet cat s1 s2 =\n let l1 = length s1 in\n let l2 = length s2 in\n let r = create (l1 + l2) in\n unsafe_blit s1 0 r 0 l1;\n unsafe_blit s2 0 r l1 l2;\n r\n\n\nexternal char_code: char -> int = \"%identity\"\nexternal char_chr: int -> char = \"%identity\"\n\nlet is_space = function\n | ' ' | '\\012' | '\\n' | '\\r' | '\\t' -> true\n | _ -> false\n\nlet trim s =\n let len = length s in\n let i = ref 0 in\n while !i < len && is_space (unsafe_get s !i) do\n incr i\n done;\n let j = ref (len - 1) in\n while !j >= !i && is_space (unsafe_get s !j) do\n decr j\n done;\n if !j >= !i then\n sub s !i (!j - !i + 1)\n else\n empty\n\nlet escaped s =\n let n = ref 0 in\n for i = 0 to length s - 1 do\n n := !n +\n (match unsafe_get s i with\n | '\\\"' | '\\\\' | '\\n' | '\\t' | '\\r' | '\\b' -> 2\n | ' ' .. '~' -> 1\n | _ -> 4)\n done;\n if !n = length s then copy s else begin\n let s' = create !n in\n n := 0;\n for i = 0 to length s - 1 do\n begin match unsafe_get s i with\n | ('\\\"' | '\\\\') as c ->\n unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n c\n | '\\n' ->\n unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 'n'\n | '\\t' ->\n unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 't'\n | '\\r' ->\n unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 'r'\n | '\\b' ->\n unsafe_set s' !n '\\\\'; incr n; unsafe_set s' !n 'b'\n | (' ' .. '~') as c -> unsafe_set s' !n c\n | c ->\n let a = char_code c in\n unsafe_set s' !n '\\\\';\n incr n;\n unsafe_set s' !n (char_chr (48 + a / 100));\n incr n;\n unsafe_set s' !n (char_chr (48 + (a / 10) mod 10));\n incr n;\n unsafe_set s' !n (char_chr (48 + a mod 10));\n end;\n incr n\n done;\n s'\n end\n\nlet map f s =\n let l = length s in\n if l = 0 then s else begin\n let r = create l in\n for i = 0 to l - 1 do unsafe_set r i (f (unsafe_get s i)) done;\n r\n end\n\nlet mapi f s =\n let l = length s in\n if l = 0 then s else begin\n let r = create l in\n for i = 0 to l - 1 do unsafe_set r i (f i (unsafe_get s i)) done;\n r\n end\n\nlet fold_left f x a =\n let r = ref x in\n for i = 0 to length a - 1 do\n r := f !r (unsafe_get a i)\n done;\n !r\n\nlet fold_right f a x =\n let r = ref x in\n for i = length a - 1 downto 0 do\n r := f (unsafe_get a i) !r\n done;\n !r\n\nlet exists p s =\n let n = length s in\n let rec loop i =\n if i = n then false\n else if p (unsafe_get s i) then true\n else loop (succ i) in\n loop 0\n\nlet for_all p s =\n let n = length s in\n let rec loop i =\n if i = n then true\n else if p (unsafe_get s i) then loop (succ i)\n else false in\n loop 0\n\nlet uppercase_ascii s = map Char.uppercase_ascii s\nlet lowercase_ascii s = map Char.lowercase_ascii s\n\nlet apply1 f s =\n if length s = 0 then s else begin\n let r = copy s in\n unsafe_set r 0 (f(unsafe_get s 0));\n r\n end\n\nlet capitalize_ascii s = apply1 Char.uppercase_ascii s\nlet uncapitalize_ascii s = apply1 Char.lowercase_ascii s\n\n(* duplicated in string.ml *)\nlet starts_with ~prefix s =\n let len_s = length s\n and len_pre = length prefix in\n let rec aux i =\n if i = len_pre then true\n else if unsafe_get s i <> unsafe_get prefix i then false\n else aux (i + 1)\n in len_s >= len_pre && aux 0\n\n(* duplicated in string.ml *)\nlet ends_with ~suffix s =\n let len_s = length s\n and len_suf = length suffix in\n let diff = len_s - len_suf in\n let rec aux i =\n if i = len_suf then true\n else if unsafe_get s (diff + i) <> unsafe_get suffix i then false\n else aux (i + 1)\n in diff >= 0 && aux 0\n\n(* duplicated in string.ml *)\nlet rec index_rec s lim i c =\n if i >= lim then raise Not_found else\n if unsafe_get s i = c then i else index_rec s lim (i + 1) c\n\n(* duplicated in string.ml *)\nlet index s c = index_rec s (length s) 0 c\n\n(* duplicated in string.ml *)\nlet rec index_rec_opt s lim i c =\n if i >= lim then None else\n if unsafe_get s i = c then Some i else index_rec_opt s lim (i + 1) c\n\n(* duplicated in string.ml *)\nlet index_opt s c = index_rec_opt s (length s) 0 c\n\n(* duplicated in string.ml *)\nlet index_from s i c =\n let l = length s in\n if i < 0 || i > l then invalid_arg \"String.index_from / Bytes.index_from\" else\n index_rec s l i c\n\n(* duplicated in string.ml *)\nlet index_from_opt s i c =\n let l = length s in\n if i < 0 || i > l then\n invalid_arg \"String.index_from_opt / Bytes.index_from_opt\"\n else\n index_rec_opt s l i c\n\n(* duplicated in string.ml *)\nlet rec rindex_rec s i c =\n if i < 0 then raise Not_found else\n if unsafe_get s i = c then i else rindex_rec s (i - 1) c\n\n(* duplicated in string.ml *)\nlet rindex s c = rindex_rec s (length s - 1) c\n\n(* duplicated in string.ml *)\nlet rindex_from s i c =\n if i < -1 || i >= length s then\n invalid_arg \"String.rindex_from / Bytes.rindex_from\"\n else\n rindex_rec s i c\n\n(* duplicated in string.ml *)\nlet rec rindex_rec_opt s i c =\n if i < 0 then None else\n if unsafe_get s i = c then Some i else rindex_rec_opt s (i - 1) c\n\n(* duplicated in string.ml *)\nlet rindex_opt s c = rindex_rec_opt s (length s - 1) c\n\n(* duplicated in string.ml *)\nlet rindex_from_opt s i c =\n if i < -1 || i >= length s then\n invalid_arg \"String.rindex_from_opt / Bytes.rindex_from_opt\"\n else\n rindex_rec_opt s i c\n\n\n(* duplicated in string.ml *)\nlet contains_from s i c =\n let l = length s in\n if i < 0 || i > l then\n invalid_arg \"String.contains_from / Bytes.contains_from\"\n else\n try ignore (index_rec s l i c); true with Not_found -> false\n\n\n(* duplicated in string.ml *)\nlet contains s c = contains_from s 0 c\n\n(* duplicated in string.ml *)\nlet rcontains_from s i c =\n if i < 0 || i >= length s then\n invalid_arg \"String.rcontains_from / Bytes.rcontains_from\"\n else\n try ignore (rindex_rec s i c); true with Not_found -> false\n\n\ntype t = bytes\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nexternal equal : t -> t -> bool = \"caml_bytes_equal\" [@@noalloc]\n\n(* duplicated in string.ml *)\nlet split_on_char sep s =\n let r = ref [] in\n let j = ref (length s) in\n for i = length s - 1 downto 0 do\n if unsafe_get s i = sep then begin\n r := sub s (i + 1) (!j - i - 1) :: !r;\n j := i\n end\n done;\n sub s 0 !j :: !r\n\n(* Deprecated functions implemented via other deprecated functions *)\n[@@@ocaml.warning \"-3\"]\nlet uppercase s = map Char.uppercase s\nlet lowercase s = map Char.lowercase s\n\nlet capitalize s = apply1 Char.uppercase s\nlet uncapitalize s = apply1 Char.lowercase s\n\n(** {1 Iterators} *)\n\nlet to_seq s =\n let rec aux i () =\n if i = length s then Seq.Nil\n else\n let x = get s i in\n Seq.Cons (x, aux (i+1))\n in\n aux 0\n\nlet to_seqi s =\n let rec aux i () =\n if i = length s then Seq.Nil\n else\n let x = get s i in\n Seq.Cons ((i,x), aux (i+1))\n in\n aux 0\n\nlet of_seq i =\n let n = ref 0 in\n let buf = ref (make 256 '\\000') in\n let resize () =\n (* resize *)\n let new_len = Int.min (2 * length !buf) Sys.max_string_length in\n if length !buf = new_len then failwith \"Bytes.of_seq: cannot grow bytes\";\n let new_buf = make new_len '\\000' in\n blit !buf 0 new_buf 0 !n;\n buf := new_buf\n in\n Seq.iter\n (fun c ->\n if !n = length !buf then resize();\n set !buf !n c;\n incr n)\n i;\n sub !buf 0 !n\n\n(** {6 Binary encoding/decoding of integers} *)\n\n(* The get_ functions are all duplicated in string.ml *)\n\nexternal unsafe_get_uint8 : bytes -> int -> int = \"%bytes_unsafe_get\"\nexternal unsafe_get_uint16_ne : bytes -> int -> int = \"%caml_bytes_get16u\"\nexternal get_uint8 : bytes -> int -> int = \"%bytes_safe_get\"\nexternal get_uint16_ne : bytes -> int -> int = \"%caml_bytes_get16\"\nexternal get_int32_ne : bytes -> int -> int32 = \"%caml_bytes_get32\"\nexternal get_int64_ne : bytes -> int -> int64 = \"%caml_bytes_get64\"\n\nexternal unsafe_set_uint8 : bytes -> int -> int -> unit = \"%bytes_unsafe_set\"\nexternal unsafe_set_uint16_ne : bytes -> int -> int -> unit\n = \"%caml_bytes_set16u\"\nexternal set_int8 : bytes -> int -> int -> unit = \"%bytes_safe_set\"\nexternal set_int16_ne : bytes -> int -> int -> unit = \"%caml_bytes_set16\"\nexternal set_int32_ne : bytes -> int -> int32 -> unit = \"%caml_bytes_set32\"\nexternal set_int64_ne : bytes -> int -> int64 -> unit = \"%caml_bytes_set64\"\nexternal swap16 : int -> int = \"%bswap16\"\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\n\nlet unsafe_get_uint16_le b i =\n if Sys.big_endian\n then swap16 (unsafe_get_uint16_ne b i)\n else unsafe_get_uint16_ne b i\n\nlet unsafe_get_uint16_be b i =\n if Sys.big_endian\n then unsafe_get_uint16_ne b i\n else swap16 (unsafe_get_uint16_ne b i)\n\nlet get_int8 b i =\n ((get_uint8 b i) lsl (Sys.int_size - 8)) asr (Sys.int_size - 8)\n\nlet get_uint16_le b i =\n if Sys.big_endian then swap16 (get_uint16_ne b i)\n else get_uint16_ne b i\n\nlet get_uint16_be b i =\n if not Sys.big_endian then swap16 (get_uint16_ne b i)\n else get_uint16_ne b i\n\nlet get_int16_ne b i =\n ((get_uint16_ne b i) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int16_le b i =\n ((get_uint16_le b i) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int16_be b i =\n ((get_uint16_be b i) lsl (Sys.int_size - 16)) asr (Sys.int_size - 16)\n\nlet get_int32_le b i =\n if Sys.big_endian then swap32 (get_int32_ne b i)\n else get_int32_ne b i\n\nlet get_int32_be b i =\n if not Sys.big_endian then swap32 (get_int32_ne b i)\n else get_int32_ne b i\n\nlet get_int64_le b i =\n if Sys.big_endian then swap64 (get_int64_ne b i)\n else get_int64_ne b i\n\nlet get_int64_be b i =\n if not Sys.big_endian then swap64 (get_int64_ne b i)\n else get_int64_ne b i\n\nlet unsafe_set_uint16_le b i x =\n if Sys.big_endian\n then unsafe_set_uint16_ne b i (swap16 x)\n else unsafe_set_uint16_ne b i x\n\nlet unsafe_set_uint16_be b i x =\n if Sys.big_endian\n then unsafe_set_uint16_ne b i x else\n unsafe_set_uint16_ne b i (swap16 x)\n\nlet set_int16_le b i x =\n if Sys.big_endian then set_int16_ne b i (swap16 x)\n else set_int16_ne b i x\n\nlet set_int16_be b i x =\n if not Sys.big_endian then set_int16_ne b i (swap16 x)\n else set_int16_ne b i x\n\nlet set_int32_le b i x =\n if Sys.big_endian then set_int32_ne b i (swap32 x)\n else set_int32_ne b i x\n\nlet set_int32_be b i x =\n if not Sys.big_endian then set_int32_ne b i (swap32 x)\n else set_int32_ne b i x\n\nlet set_int64_le b i x =\n if Sys.big_endian then set_int64_ne b i (swap64 x)\n else set_int64_ne b i x\n\nlet set_int64_be b i x =\n if not Sys.big_endian then set_int64_ne b i (swap64 x)\n else set_int64_ne b i x\n\nlet set_uint8 = set_int8\nlet set_uint16_ne = set_int16_ne\nlet set_uint16_be = set_int16_be\nlet set_uint16_le = set_int16_le\n\n(* UTF codecs and validations *)\n\nlet dec_invalid = Uchar.utf_decode_invalid\nlet[@inline] dec_ret n u = Uchar.utf_decode n (Uchar.unsafe_of_int u)\n\n(* In case of decoding error, if we error on the first byte, we\n consume the byte, otherwise we consume the [n] bytes preceeding\n the erroring byte.\n\n This means that if a client uses decodes without caring about\n validity it naturally replace bogus data with Uchar.rep according\n to the WHATWG Encoding standard. Other schemes are possible by\n consulting the number of used bytes on invalid decodes. For more\n details see https://hsivonen.fi/broken-utf-8/\n\n For this reason in [get_utf_8_uchar] we gradually check the next\n byte is available rather than doing it immediately after the\n first byte. Contrast with [is_valid_utf_8]. *)\n\n(* UTF-8 *)\n\nlet[@inline] not_in_x80_to_xBF b = b lsr 6 <> 0b10\nlet[@inline] not_in_xA0_to_xBF b = b lsr 5 <> 0b101\nlet[@inline] not_in_x80_to_x9F b = b lsr 5 <> 0b100\nlet[@inline] not_in_x90_to_xBF b = b < 0x90 || 0xBF < b\nlet[@inline] not_in_x80_to_x8F b = b lsr 4 <> 0x8\n\nlet[@inline] utf_8_uchar_2 b0 b1 =\n ((b0 land 0x1F) lsl 6) lor\n ((b1 land 0x3F))\n\nlet[@inline] utf_8_uchar_3 b0 b1 b2 =\n ((b0 land 0x0F) lsl 12) lor\n ((b1 land 0x3F) lsl 6) lor\n ((b2 land 0x3F))\n\nlet[@inline] utf_8_uchar_4 b0 b1 b2 b3 =\n ((b0 land 0x07) lsl 18) lor\n ((b1 land 0x3F) lsl 12) lor\n ((b2 land 0x3F) lsl 6) lor\n ((b3 land 0x3F))\n\nlet get_utf_8_uchar b i =\n let b0 = get_uint8 b i in (* raises if [i] is not a valid index. *)\n let get = unsafe_get_uint8 in\n let max = length b - 1 in\n match Char.unsafe_chr b0 with (* See The Unicode Standard, Table 3.7 *)\n | '\\x00' .. '\\x7F' -> dec_ret 1 b0\n | '\\xC2' .. '\\xDF' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x80_to_xBF b1 then dec_invalid 1 else\n dec_ret 2 (utf_8_uchar_2 b0 b1)\n | '\\xE0' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_xA0_to_xBF b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n dec_ret 3 (utf_8_uchar_3 b0 b1 b2)\n | '\\xE1' .. '\\xEC' | '\\xEE' .. '\\xEF' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x80_to_xBF b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n dec_ret 3 (utf_8_uchar_3 b0 b1 b2)\n | '\\xED' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x80_to_x9F b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n dec_ret 3 (utf_8_uchar_3 b0 b1 b2)\n | '\\xF0' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x90_to_xBF b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n let i = i + 1 in if i > max then dec_invalid 3 else\n let b3 = get b i in if not_in_x80_to_xBF b3 then dec_invalid 3 else\n dec_ret 4 (utf_8_uchar_4 b0 b1 b2 b3)\n | '\\xF1' .. '\\xF3' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x80_to_xBF b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n let i = i + 1 in if i > max then dec_invalid 3 else\n let b3 = get b i in if not_in_x80_to_xBF b3 then dec_invalid 3 else\n dec_ret 4 (utf_8_uchar_4 b0 b1 b2 b3)\n | '\\xF4' ->\n let i = i + 1 in if i > max then dec_invalid 1 else\n let b1 = get b i in if not_in_x80_to_x8F b1 then dec_invalid 1 else\n let i = i + 1 in if i > max then dec_invalid 2 else\n let b2 = get b i in if not_in_x80_to_xBF b2 then dec_invalid 2 else\n let i = i + 1 in if i > max then dec_invalid 3 else\n let b3 = get b i in if not_in_x80_to_xBF b3 then dec_invalid 3 else\n dec_ret 4 (utf_8_uchar_4 b0 b1 b2 b3)\n | _ -> dec_invalid 1\n\nlet set_utf_8_uchar b i u =\n let set = unsafe_set_uint8 in\n let max = length b - 1 in\n match Uchar.to_int u with\n | u when u < 0 -> assert false\n | u when u <= 0x007F ->\n set_uint8 b i u;\n 1\n | u when u <= 0x07FF ->\n let last = i + 1 in\n if last > max then 0 else\n (set_uint8 b i (0xC0 lor (u lsr 6));\n set b last (0x80 lor (u land 0x3F));\n 2)\n | u when u <= 0xFFFF ->\n let last = i + 2 in\n if last > max then 0 else\n (set_uint8 b i (0xE0 lor (u lsr 12));\n set b (i + 1) (0x80 lor ((u lsr 6) land 0x3F));\n set b last (0x80 lor (u land 0x3F));\n 3)\n | u when u <= 0x10FFFF ->\n let last = i + 3 in\n if last > max then 0 else\n (set_uint8 b i (0xF0 lor (u lsr 18));\n set b (i + 1) (0x80 lor ((u lsr 12) land 0x3F));\n set b (i + 2) (0x80 lor ((u lsr 6) land 0x3F));\n set b last (0x80 lor (u land 0x3F));\n 4)\n | _ -> assert false\n\nlet is_valid_utf_8 b =\n let rec loop max b i =\n if i > max then true else\n let get = unsafe_get_uint8 in\n match Char.unsafe_chr (get b i) with\n | '\\x00' .. '\\x7F' -> loop max b (i + 1)\n | '\\xC2' .. '\\xDF' ->\n let last = i + 1 in\n if last > max\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xE0' ->\n let last = i + 2 in\n if last > max\n || not_in_xA0_to_xBF (get b (i + 1))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xE1' .. '\\xEC' | '\\xEE' .. '\\xEF' ->\n let last = i + 2 in\n if last > max\n || not_in_x80_to_xBF (get b (i + 1))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xED' ->\n let last = i + 2 in\n if last > max\n || not_in_x80_to_x9F (get b (i + 1))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xF0' ->\n let last = i + 3 in\n if last > max\n || not_in_x90_to_xBF (get b (i + 1))\n || not_in_x80_to_xBF (get b (i + 2))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xF1' .. '\\xF3' ->\n let last = i + 3 in\n if last > max\n || not_in_x80_to_xBF (get b (i + 1))\n || not_in_x80_to_xBF (get b (i + 2))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | '\\xF4' ->\n let last = i + 3 in\n if last > max\n || not_in_x80_to_x8F (get b (i + 1))\n || not_in_x80_to_xBF (get b (i + 2))\n || not_in_x80_to_xBF (get b last)\n then false\n else loop max b (last + 1)\n | _ -> false\n in\n loop (length b - 1) b 0\n\n(* UTF-16BE *)\n\nlet get_utf_16be_uchar b i =\n let get = unsafe_get_uint16_be in\n let max = length b - 1 in\n if i < 0 || i > max then invalid_arg \"index out of bounds\" else\n if i = max then dec_invalid 1 else\n match get b i with\n | u when u < 0xD800 || u > 0xDFFF -> dec_ret 2 u\n | u when u > 0xDBFF -> dec_invalid 2\n | hi -> (* combine [hi] with a low surrogate *)\n let last = i + 3 in\n if last > max then dec_invalid (max - i + 1) else\n match get b (i + 2) with\n | u when u < 0xDC00 || u > 0xDFFF -> dec_invalid 2 (* retry here *)\n | lo ->\n let u = (((hi land 0x3FF) lsl 10) lor (lo land 0x3FF)) + 0x10000 in\n dec_ret 4 u\n\nlet set_utf_16be_uchar b i u =\n let set = unsafe_set_uint16_be in\n let max = length b - 1 in\n if i < 0 || i > max then invalid_arg \"index out of bounds\" else\n match Uchar.to_int u with\n | u when u < 0 -> assert false\n | u when u <= 0xFFFF ->\n let last = i + 1 in\n if last > max then 0 else (set b i u; 2)\n | u when u <= 0x10FFFF ->\n let last = i + 3 in\n if last > max then 0 else\n let u' = u - 0x10000 in\n let hi = (0xD800 lor (u' lsr 10)) in\n let lo = (0xDC00 lor (u' land 0x3FF)) in\n set b i hi; set b (i + 2) lo; 4\n | _ -> assert false\n\nlet is_valid_utf_16be b =\n let rec loop max b i =\n let get = unsafe_get_uint16_be in\n if i > max then true else\n if i = max then false else\n match get b i with\n | u when u < 0xD800 || u > 0xDFFF -> loop max b (i + 2)\n | u when u > 0xDBFF -> false\n | _hi ->\n let last = i + 3 in\n if last > max then false else\n match get b (i + 2) with\n | u when u < 0xDC00 || u > 0xDFFF -> false\n | _lo -> loop max b (i + 4)\n in\n loop (length b - 1) b 0\n\n(* UTF-16LE *)\n\nlet get_utf_16le_uchar b i =\n let get = unsafe_get_uint16_le in\n let max = length b - 1 in\n if i < 0 || i > max then invalid_arg \"index out of bounds\" else\n if i = max then dec_invalid 1 else\n match get b i with\n | u when u < 0xD800 || u > 0xDFFF -> dec_ret 2 u\n | u when u > 0xDBFF -> dec_invalid 2\n | hi -> (* combine [hi] with a low surrogate *)\n let last = i + 3 in\n if last > max then dec_invalid (max - i + 1) else\n match get b (i + 2) with\n | u when u < 0xDC00 || u > 0xDFFF -> dec_invalid 2 (* retry here *)\n | lo ->\n let u = (((hi land 0x3FF) lsl 10) lor (lo land 0x3FF)) + 0x10000 in\n dec_ret 4 u\n\nlet set_utf_16le_uchar b i u =\n let set = unsafe_set_uint16_le in\n let max = length b - 1 in\n if i < 0 || i > max then invalid_arg \"index out of bounds\" else\n match Uchar.to_int u with\n | u when u < 0 -> assert false\n | u when u <= 0xFFFF ->\n let last = i + 1 in\n if last > max then 0 else (set b i u; 2)\n | u when u <= 0x10FFFF ->\n let last = i + 3 in\n if last > max then 0 else\n let u' = u - 0x10000 in\n let hi = (0xD800 lor (u' lsr 10)) in\n let lo = (0xDC00 lor (u' land 0x3FF)) in\n set b i hi; set b (i + 2) lo; 4\n | _ -> assert false\n\nlet is_valid_utf_16le b =\n let rec loop max b i =\n let get = unsafe_get_uint16_le in\n if i > max then true else\n if i = max then false else\n match get b i with\n | u when u < 0xD800 || u > 0xDFFF -> loop max b (i + 2)\n | u when u > 0xDBFF -> false\n | _hi ->\n let last = i + 3 in\n if last > max then false else\n match get b (i + 2) with\n | u when u < 0xDC00 || u > 0xDFFF -> false\n | _lo -> loop max b (i + 4)\n in\n loop (length b - 1) b 0\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Gallium, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2014 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* String operations, based on byte sequence operations *)\n\n(* WARNING: Some functions in this file are duplicated in bytes.ml for\n efficiency reasons. When you modify the one in this file you need to\n modify its duplicate in bytes.ml.\n These functions have a \"duplicated\" comment above their definition.\n*)\n\nexternal length : string -> int = \"%string_length\"\nexternal get : string -> int -> char = \"%string_safe_get\"\nexternal set : bytes -> int -> char -> unit = \"%string_safe_set\"\nexternal create : int -> bytes = \"caml_create_string\"\nexternal unsafe_get : string -> int -> char = \"%string_unsafe_get\"\nexternal unsafe_set : bytes -> int -> char -> unit = \"%string_unsafe_set\"\nexternal unsafe_blit : string -> int -> bytes -> int -> int -> unit\n = \"caml_blit_string\" [@@noalloc]\nexternal unsafe_fill : bytes -> int -> int -> char -> unit\n = \"caml_fill_string\" [@@noalloc]\n\nmodule B = Bytes\n\nlet bts = B.unsafe_to_string\nlet bos = B.unsafe_of_string\n\nlet make n c =\n B.make n c |> bts\nlet init n f =\n B.init n f |> bts\nlet empty = \"\"\nlet copy s =\n B.copy (bos s) |> bts\nlet of_bytes = B.to_string\nlet to_bytes = B.of_string\nlet sub s ofs len =\n B.sub (bos s) ofs len |> bts\nlet fill =\n B.fill\nlet blit =\n B.blit_string\n\nlet ensure_ge (x:int) y = if x >= y then x else invalid_arg \"String.concat\"\n\nlet rec sum_lengths acc seplen = function\n | [] -> acc\n | hd :: [] -> length hd + acc\n | hd :: tl -> sum_lengths (ensure_ge (length hd + seplen + acc) acc) seplen tl\n\nlet rec unsafe_blits dst pos sep seplen = function\n [] -> dst\n | hd :: [] ->\n unsafe_blit hd 0 dst pos (length hd); dst\n | hd :: tl ->\n unsafe_blit hd 0 dst pos (length hd);\n unsafe_blit sep 0 dst (pos + length hd) seplen;\n unsafe_blits dst (pos + length hd + seplen) sep seplen tl\n\nlet concat sep = function\n [] -> \"\"\n | l -> let seplen = length sep in bts @@\n unsafe_blits\n (B.create (sum_lengths 0 seplen l))\n 0 sep seplen l\n\nlet cat = ( ^ )\n\n(* duplicated in bytes.ml *)\nlet iter f s =\n for i = 0 to length s - 1 do f (unsafe_get s i) done\n\n(* duplicated in bytes.ml *)\nlet iteri f s =\n for i = 0 to length s - 1 do f i (unsafe_get s i) done\n\nlet map f s =\n B.map f (bos s) |> bts\nlet mapi f s =\n B.mapi f (bos s) |> bts\nlet fold_right f x a =\n B.fold_right f (bos x) a\nlet fold_left f a x =\n B.fold_left f a (bos x)\nlet exists f s =\n B.exists f (bos s)\nlet for_all f s =\n B.for_all f (bos s)\n\n(* Beware: we cannot use B.trim or B.escape because they always make a\n copy, but String.mli spells out some cases where we are not allowed\n to make a copy. *)\n\nlet is_space = function\n | ' ' | '\\012' | '\\n' | '\\r' | '\\t' -> true\n | _ -> false\n\nlet trim s =\n if s = \"\" then s\n else if is_space (unsafe_get s 0) || is_space (unsafe_get s (length s - 1))\n then bts (B.trim (bos s))\n else s\n\nlet escaped s =\n let rec escape_if_needed s n i =\n if i >= n then s else\n match unsafe_get s i with\n | '\\\"' | '\\\\' | '\\000'..'\\031' | '\\127'.. '\\255' ->\n bts (B.escaped (bos s))\n | _ -> escape_if_needed s n (i+1)\n in\n escape_if_needed s (length s) 0\n\n(* duplicated in bytes.ml *)\nlet rec index_rec s lim i c =\n if i >= lim then raise Not_found else\n if unsafe_get s i = c then i else index_rec s lim (i + 1) c\n\n(* duplicated in bytes.ml *)\nlet index s c = index_rec s (length s) 0 c\n\n(* duplicated in bytes.ml *)\nlet rec index_rec_opt s lim i c =\n if i >= lim then None else\n if unsafe_get s i = c then Some i else index_rec_opt s lim (i + 1) c\n\n(* duplicated in bytes.ml *)\nlet index_opt s c = index_rec_opt s (length s) 0 c\n\n(* duplicated in bytes.ml *)\nlet index_from s i c =\n let l = length s in\n if i < 0 || i > l then invalid_arg \"String.index_from / Bytes.index_from\" else\n index_rec s l i c\n\n(* duplicated in bytes.ml *)\nlet index_from_opt s i c =\n let l = length s in\n if i < 0 || i > l then\n invalid_arg \"String.index_from_opt / Bytes.index_from_opt\"\n else\n index_rec_opt s l i c\n\n(* duplicated in bytes.ml *)\nlet rec rindex_rec s i c =\n if i < 0 then raise Not_found else\n if unsafe_get s i = c then i else rindex_rec s (i - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex s c = rindex_rec s (length s - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex_from s i c =\n if i < -1 || i >= length s then\n invalid_arg \"String.rindex_from / Bytes.rindex_from\"\n else\n rindex_rec s i c\n\n(* duplicated in bytes.ml *)\nlet rec rindex_rec_opt s i c =\n if i < 0 then None else\n if unsafe_get s i = c then Some i else rindex_rec_opt s (i - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex_opt s c = rindex_rec_opt s (length s - 1) c\n\n(* duplicated in bytes.ml *)\nlet rindex_from_opt s i c =\n if i < -1 || i >= length s then\n invalid_arg \"String.rindex_from_opt / Bytes.rindex_from_opt\"\n else\n rindex_rec_opt s i c\n\n(* duplicated in bytes.ml *)\nlet contains_from s i c =\n let l = length s in\n if i < 0 || i > l then\n invalid_arg \"String.contains_from / Bytes.contains_from\"\n else\n try ignore (index_rec s l i c); true with Not_found -> false\n\n(* duplicated in bytes.ml *)\nlet contains s c = contains_from s 0 c\n\n(* duplicated in bytes.ml *)\nlet rcontains_from s i c =\n if i < 0 || i >= length s then\n invalid_arg \"String.rcontains_from / Bytes.rcontains_from\"\n else\n try ignore (rindex_rec s i c); true with Not_found -> false\n\nlet uppercase_ascii s =\n B.uppercase_ascii (bos s) |> bts\nlet lowercase_ascii s =\n B.lowercase_ascii (bos s) |> bts\nlet capitalize_ascii s =\n B.capitalize_ascii (bos s) |> bts\nlet uncapitalize_ascii s =\n B.uncapitalize_ascii (bos s) |> bts\n\n(* duplicated in bytes.ml *)\nlet starts_with ~prefix s =\n let len_s = length s\n and len_pre = length prefix in\n let rec aux i =\n if i = len_pre then true\n else if unsafe_get s i <> unsafe_get prefix i then false\n else aux (i + 1)\n in len_s >= len_pre && aux 0\n\n(* duplicated in bytes.ml *)\nlet ends_with ~suffix s =\n let len_s = length s\n and len_suf = length suffix in\n let diff = len_s - len_suf in\n let rec aux i =\n if i = len_suf then true\n else if unsafe_get s (diff + i) <> unsafe_get suffix i then false\n else aux (i + 1)\n in diff >= 0 && aux 0\n\n(* duplicated in bytes.ml *)\nlet split_on_char sep s =\n let r = ref [] in\n let j = ref (length s) in\n for i = length s - 1 downto 0 do\n if unsafe_get s i = sep then begin\n r := sub s (i + 1) (!j - i - 1) :: !r;\n j := i\n end\n done;\n sub s 0 !j :: !r\n\n(* Deprecated functions implemented via other deprecated functions *)\n[@@@ocaml.warning \"-3\"]\nlet uppercase s =\n B.uppercase (bos s) |> bts\nlet lowercase s =\n B.lowercase (bos s) |> bts\nlet capitalize s =\n B.capitalize (bos s) |> bts\nlet uncapitalize s =\n B.uncapitalize (bos s) |> bts\n\ntype t = string\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nexternal equal : string -> string -> bool = \"caml_string_equal\" [@@noalloc]\n\n(** {1 Iterators} *)\n\nlet to_seq s = bos s |> B.to_seq\n\nlet to_seqi s = bos s |> B.to_seqi\n\nlet of_seq g = B.of_seq g |> bts\n\n(* UTF decoders and validators *)\n\nlet get_utf_8_uchar s i = B.get_utf_8_uchar (bos s) i\nlet is_valid_utf_8 s = B.is_valid_utf_8 (bos s)\n\nlet get_utf_16be_uchar s i = B.get_utf_16be_uchar (bos s) i\nlet is_valid_utf_16be s = B.is_valid_utf_16be (bos s)\n\nlet get_utf_16le_uchar s i = B.get_utf_16le_uchar (bos s) i\nlet is_valid_utf_16le s = B.is_valid_utf_16le (bos s)\n\n(** {6 Binary encoding/decoding of integers} *)\n\nexternal get_uint8 : string -> int -> int = \"%string_safe_get\"\nexternal get_uint16_ne : string -> int -> int = \"%caml_string_get16\"\nexternal get_int32_ne : string -> int -> int32 = \"%caml_string_get32\"\nexternal get_int64_ne : string -> int -> int64 = \"%caml_string_get64\"\n\nlet get_int8 s i = B.get_int8 (bos s) i\nlet get_uint16_le s i = B.get_uint16_le (bos s) i\nlet get_uint16_be s i = B.get_uint16_be (bos s) i\nlet get_int16_ne s i = B.get_int16_ne (bos s) i\nlet get_int16_le s i = B.get_int16_le (bos s) i\nlet get_int16_be s i = B.get_int16_be (bos s) i\nlet get_int32_le s i = B.get_int32_le (bos s) i\nlet get_int32_be s i = B.get_int32_be (bos s) i\nlet get_int64_le s i = B.get_int64_le (bos s) i\nlet get_int64_be s i = B.get_int64_be (bos s) i\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1997 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype extern_flags =\n No_sharing\n | Closures\n | Compat_32\n(* note: this type definition is used in 'runtime/debugger.c' *)\n\nexternal to_channel: out_channel -> 'a -> extern_flags list -> unit\n = \"caml_output_value\"\nexternal to_bytes: 'a -> extern_flags list -> bytes\n = \"caml_output_value_to_bytes\"\nexternal to_string: 'a -> extern_flags list -> string\n = \"caml_output_value_to_string\"\nexternal to_buffer_unsafe:\n bytes -> int -> int -> 'a -> extern_flags list -> int\n = \"caml_output_value_to_buffer\"\n\nlet to_buffer buff ofs len v flags =\n if ofs < 0 || len < 0 || ofs > Bytes.length buff - len\n then invalid_arg \"Marshal.to_buffer: substring out of bounds\"\n else to_buffer_unsafe buff ofs len v flags\n\n(* The functions below use byte sequences as input, never using any\n mutation. It makes sense to use non-mutated [bytes] rather than\n [string], because we really work with sequences of bytes, not\n a text representation.\n*)\n\nexternal from_channel: in_channel -> 'a = \"caml_input_value\"\nexternal from_bytes_unsafe: bytes -> int -> 'a = \"caml_input_value_from_bytes\"\nexternal data_size_unsafe: bytes -> int -> int = \"caml_marshal_data_size\"\n\nlet header_size = 20\nlet data_size buff ofs =\n if ofs < 0 || ofs > Bytes.length buff - header_size\n then invalid_arg \"Marshal.data_size\"\n else data_size_unsafe buff ofs\nlet total_size buff ofs = header_size + data_size buff ofs\n\nlet from_bytes buff ofs =\n if ofs < 0 || ofs > Bytes.length buff - header_size\n then invalid_arg \"Marshal.from_bytes\"\n else begin\n let len = data_size_unsafe buff ofs in\n if ofs > Bytes.length buff - (header_size + len)\n then invalid_arg \"Marshal.from_bytes\"\n else from_bytes_unsafe buff ofs\n end\n\nlet from_string buff ofs =\n (* Bytes.unsafe_of_string is safe here, as the produced byte\n sequence is never mutated *)\n from_bytes (Bytes.unsafe_of_string buff) ofs\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* An alias for the type of arrays. *)\ntype 'a t = 'a array\n\n(* Array operations *)\n\nexternal length : 'a array -> int = \"%array_length\"\nexternal get: 'a array -> int -> 'a = \"%array_safe_get\"\nexternal set: 'a array -> int -> 'a -> unit = \"%array_safe_set\"\nexternal unsafe_get: 'a array -> int -> 'a = \"%array_unsafe_get\"\nexternal unsafe_set: 'a array -> int -> 'a -> unit = \"%array_unsafe_set\"\nexternal make: int -> 'a -> 'a array = \"caml_make_vect\"\nexternal create: int -> 'a -> 'a array = \"caml_make_vect\"\nexternal unsafe_sub : 'a array -> int -> int -> 'a array = \"caml_array_sub\"\nexternal append_prim : 'a array -> 'a array -> 'a array = \"caml_array_append\"\nexternal concat : 'a array list -> 'a array = \"caml_array_concat\"\nexternal unsafe_blit :\n 'a array -> int -> 'a array -> int -> int -> unit = \"caml_array_blit\"\nexternal unsafe_fill :\n 'a array -> int -> int -> 'a -> unit = \"caml_array_fill\"\nexternal create_float: int -> float array = \"caml_make_float_vect\"\nlet make_float = create_float\n\nmodule Floatarray = struct\n external create : int -> floatarray = \"caml_floatarray_create\"\n external length : floatarray -> int = \"%floatarray_length\"\n external get : floatarray -> int -> float = \"%floatarray_safe_get\"\n external set : floatarray -> int -> float -> unit = \"%floatarray_safe_set\"\n external unsafe_get : floatarray -> int -> float = \"%floatarray_unsafe_get\"\n external unsafe_set : floatarray -> int -> float -> unit\n = \"%floatarray_unsafe_set\"\nend\n\nlet init l f =\n if l = 0 then [||] else\n if l < 0 then invalid_arg \"Array.init\"\n (* See #6575. We could also check for maximum array size, but this depends\n on whether we create a float array or a regular one... *)\n else\n let res = create l (f 0) in\n for i = 1 to pred l do\n unsafe_set res i (f i)\n done;\n res\n\nlet make_matrix sx sy init =\n let res = create sx [||] in\n for x = 0 to pred sx do\n unsafe_set res x (create sy init)\n done;\n res\n\nlet create_matrix = make_matrix\n\nlet copy a =\n let l = length a in if l = 0 then [||] else unsafe_sub a 0 l\n\nlet append a1 a2 =\n let l1 = length a1 in\n if l1 = 0 then copy a2\n else if length a2 = 0 then unsafe_sub a1 0 l1\n else append_prim a1 a2\n\nlet sub a ofs len =\n if ofs < 0 || len < 0 || ofs > length a - len\n then invalid_arg \"Array.sub\"\n else unsafe_sub a ofs len\n\nlet fill a ofs len v =\n if ofs < 0 || len < 0 || ofs > length a - len\n then invalid_arg \"Array.fill\"\n else unsafe_fill a ofs len v\n\nlet blit a1 ofs1 a2 ofs2 len =\n if len < 0 || ofs1 < 0 || ofs1 > length a1 - len\n || ofs2 < 0 || ofs2 > length a2 - len\n then invalid_arg \"Array.blit\"\n else unsafe_blit a1 ofs1 a2 ofs2 len\n\nlet iter f a =\n for i = 0 to length a - 1 do f(unsafe_get a i) done\n\nlet iter2 f a b =\n if length a <> length b then\n invalid_arg \"Array.iter2: arrays must have the same length\"\n else\n for i = 0 to length a - 1 do f (unsafe_get a i) (unsafe_get b i) done\n\nlet map f a =\n let l = length a in\n if l = 0 then [||] else begin\n let r = create l (f(unsafe_get a 0)) in\n for i = 1 to l - 1 do\n unsafe_set r i (f(unsafe_get a i))\n done;\n r\n end\n\nlet map2 f a b =\n let la = length a in\n let lb = length b in\n if la <> lb then\n invalid_arg \"Array.map2: arrays must have the same length\"\n else begin\n if la = 0 then [||] else begin\n let r = create la (f (unsafe_get a 0) (unsafe_get b 0)) in\n for i = 1 to la - 1 do\n unsafe_set r i (f (unsafe_get a i) (unsafe_get b i))\n done;\n r\n end\n end\n\nlet iteri f a =\n for i = 0 to length a - 1 do f i (unsafe_get a i) done\n\nlet mapi f a =\n let l = length a in\n if l = 0 then [||] else begin\n let r = create l (f 0 (unsafe_get a 0)) in\n for i = 1 to l - 1 do\n unsafe_set r i (f i (unsafe_get a i))\n done;\n r\n end\n\nlet to_list a =\n let rec tolist i res =\n if i < 0 then res else tolist (i - 1) (unsafe_get a i :: res) in\n tolist (length a - 1) []\n\n(* Cannot use List.length here because the List module depends on Array. *)\nlet rec list_length accu = function\n | [] -> accu\n | _::t -> list_length (succ accu) t\n\nlet of_list = function\n [] -> [||]\n | hd::tl as l ->\n let a = create (list_length 0 l) hd in\n let rec fill i = function\n [] -> a\n | hd::tl -> unsafe_set a i hd; fill (i+1) tl in\n fill 1 tl\n\nlet fold_left f x a =\n let r = ref x in\n for i = 0 to length a - 1 do\n r := f !r (unsafe_get a i)\n done;\n !r\n\nlet fold_left_map f acc input_array =\n let len = length input_array in\n if len = 0 then (acc, [||]) else begin\n let acc, elt = f acc (unsafe_get input_array 0) in\n let output_array = create len elt in\n let acc = ref acc in\n for i = 1 to len - 1 do\n let acc', elt = f !acc (unsafe_get input_array i) in\n acc := acc';\n unsafe_set output_array i elt;\n done;\n !acc, output_array\n end\n\nlet fold_right f a x =\n let r = ref x in\n for i = length a - 1 downto 0 do\n r := f (unsafe_get a i) !r\n done;\n !r\n\nlet exists p a =\n let n = length a in\n let rec loop i =\n if i = n then false\n else if p (unsafe_get a i) then true\n else loop (succ i) in\n loop 0\n\nlet for_all p a =\n let n = length a in\n let rec loop i =\n if i = n then true\n else if p (unsafe_get a i) then loop (succ i)\n else false in\n loop 0\n\nlet for_all2 p l1 l2 =\n let n1 = length l1\n and n2 = length l2 in\n if n1 <> n2 then invalid_arg \"Array.for_all2\"\n else let rec loop i =\n if i = n1 then true\n else if p (unsafe_get l1 i) (unsafe_get l2 i) then loop (succ i)\n else false in\n loop 0\n\nlet exists2 p l1 l2 =\n let n1 = length l1\n and n2 = length l2 in\n if n1 <> n2 then invalid_arg \"Array.exists2\"\n else let rec loop i =\n if i = n1 then false\n else if p (unsafe_get l1 i) (unsafe_get l2 i) then true\n else loop (succ i) in\n loop 0\n\nlet mem x a =\n let n = length a in\n let rec loop i =\n if i = n then false\n else if compare (unsafe_get a i) x = 0 then true\n else loop (succ i) in\n loop 0\n\nlet memq x a =\n let n = length a in\n let rec loop i =\n if i = n then false\n else if x == (unsafe_get a i) then true\n else loop (succ i) in\n loop 0\n\nlet find_opt p a =\n let n = length a in\n let rec loop i =\n if i = n then None\n else\n let x = unsafe_get a i in\n if p x then Some x\n else loop (succ i)\n in\n loop 0\n\nlet find_map f a =\n let n = length a in\n let rec loop i =\n if i = n then None\n else\n match f (unsafe_get a i) with\n | None -> loop (succ i)\n | Some _ as r -> r\n in\n loop 0\n\nlet split x =\n if x = [||] then [||], [||]\n else begin\n let a0, b0 = unsafe_get x 0 in\n let n = length x in\n let a = create n a0 in\n let b = create n b0 in\n for i = 1 to n - 1 do\n let ai, bi = unsafe_get x i in\n unsafe_set a i ai;\n unsafe_set b i bi\n done;\n a, b\n end\n\nlet combine a b =\n let na = length a in\n let nb = length b in\n if na <> nb then invalid_arg \"Array.combine\";\n if na = 0 then [||]\n else begin\n let x = create na (unsafe_get a 0, unsafe_get b 0) in\n for i = 1 to na - 1 do\n unsafe_set x i (unsafe_get a i, unsafe_get b i)\n done;\n x\n end\n\nexception Bottom of int\nlet sort cmp a =\n let maxson l i =\n let i31 = i+i+i+1 in\n let x = ref i31 in\n if i31+2 < l then begin\n if cmp (get a i31) (get a (i31+1)) < 0 then x := i31+1;\n if cmp (get a !x) (get a (i31+2)) < 0 then x := i31+2;\n !x\n end else\n if i31+1 < l && cmp (get a i31) (get a (i31+1)) < 0\n then i31+1\n else if i31 < l then i31 else raise (Bottom i)\n in\n let rec trickledown l i e =\n let j = maxson l i in\n if cmp (get a j) e > 0 then begin\n set a i (get a j);\n trickledown l j e;\n end else begin\n set a i e;\n end;\n in\n let trickle l i e = try trickledown l i e with Bottom i -> set a i e in\n let rec bubbledown l i =\n let j = maxson l i in\n set a i (get a j);\n bubbledown l j\n in\n let bubble l i = try bubbledown l i with Bottom i -> i in\n let rec trickleup i e =\n let father = (i - 1) / 3 in\n assert (i <> father);\n if cmp (get a father) e < 0 then begin\n set a i (get a father);\n if father > 0 then trickleup father e else set a 0 e;\n end else begin\n set a i e;\n end;\n in\n let l = length a in\n for i = (l + 1) / 3 - 1 downto 0 do trickle l i (get a i); done;\n for i = l - 1 downto 2 do\n let e = (get a i) in\n set a i (get a 0);\n trickleup (bubble i 0) e;\n done;\n if l > 1 then (let e = (get a 1) in set a 1 (get a 0); set a 0 e)\n\n\nlet cutoff = 5\nlet stable_sort cmp a =\n let merge src1ofs src1len src2 src2ofs src2len dst dstofs =\n let src1r = src1ofs + src1len and src2r = src2ofs + src2len in\n let rec loop i1 s1 i2 s2 d =\n if cmp s1 s2 <= 0 then begin\n set dst d s1;\n let i1 = i1 + 1 in\n if i1 < src1r then\n loop i1 (get a i1) i2 s2 (d + 1)\n else\n blit src2 i2 dst (d + 1) (src2r - i2)\n end else begin\n set dst d s2;\n let i2 = i2 + 1 in\n if i2 < src2r then\n loop i1 s1 i2 (get src2 i2) (d + 1)\n else\n blit a i1 dst (d + 1) (src1r - i1)\n end\n in loop src1ofs (get a src1ofs) src2ofs (get src2 src2ofs) dstofs;\n in\n let isortto srcofs dst dstofs len =\n for i = 0 to len - 1 do\n let e = (get a (srcofs + i)) in\n let j = ref (dstofs + i - 1) in\n while (!j >= dstofs && cmp (get dst !j) e > 0) do\n set dst (!j + 1) (get dst !j);\n decr j;\n done;\n set dst (!j + 1) e;\n done;\n in\n let rec sortto srcofs dst dstofs len =\n if len <= cutoff then isortto srcofs dst dstofs len else begin\n let l1 = len / 2 in\n let l2 = len - l1 in\n sortto (srcofs + l1) dst (dstofs + l1) l2;\n sortto srcofs a (srcofs + l2) l1;\n merge (srcofs + l2) l1 dst (dstofs + l1) l2 dst dstofs;\n end;\n in\n let l = length a in\n if l <= cutoff then isortto 0 a 0 l else begin\n let l1 = l / 2 in\n let l2 = l - l1 in\n let t = make l2 (get a 0) in\n sortto l1 t 0 l2;\n sortto 0 a l2 l1;\n merge l2 l1 t 0 l2 a 0;\n end\n\n\nlet fast_sort = stable_sort\n\n(** {1 Iterators} *)\n\nlet to_seq a =\n let rec aux i () =\n if i < length a\n then\n let x = unsafe_get a i in\n Seq.Cons (x, aux (i+1))\n else Seq.Nil\n in\n aux 0\n\nlet to_seqi a =\n let rec aux i () =\n if i < length a\n then\n let x = unsafe_get a i in\n Seq.Cons ((i,x), aux (i+1))\n else Seq.Nil\n in\n aux 0\n\nlet of_rev_list = function\n [] -> [||]\n | hd::tl as l ->\n let len = list_length 0 l in\n let a = create len hd in\n let rec fill i = function\n [] -> a\n | hd::tl -> unsafe_set a i hd; fill (i-1) tl\n in\n fill (len-2) tl\n\nlet of_seq i =\n let l = Seq.fold_left (fun acc x -> x::acc) [] i in\n of_rev_list l\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Int32]: 32-bit integers *)\n\nexternal neg : int32 -> int32 = \"%int32_neg\"\nexternal add : int32 -> int32 -> int32 = \"%int32_add\"\nexternal sub : int32 -> int32 -> int32 = \"%int32_sub\"\nexternal mul : int32 -> int32 -> int32 = \"%int32_mul\"\nexternal div : int32 -> int32 -> int32 = \"%int32_div\"\nexternal rem : int32 -> int32 -> int32 = \"%int32_mod\"\nexternal logand : int32 -> int32 -> int32 = \"%int32_and\"\nexternal logor : int32 -> int32 -> int32 = \"%int32_or\"\nexternal logxor : int32 -> int32 -> int32 = \"%int32_xor\"\nexternal shift_left : int32 -> int -> int32 = \"%int32_lsl\"\nexternal shift_right : int32 -> int -> int32 = \"%int32_asr\"\nexternal shift_right_logical : int32 -> int -> int32 = \"%int32_lsr\"\nexternal of_int : int -> int32 = \"%int32_of_int\"\nexternal to_int : int32 -> int = \"%int32_to_int\"\nexternal of_float : float -> int32\n = \"caml_int32_of_float\" \"caml_int32_of_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal to_float : int32 -> float\n = \"caml_int32_to_float\" \"caml_int32_to_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal bits_of_float : float -> int32\n = \"caml_int32_bits_of_float\" \"caml_int32_bits_of_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal float_of_bits : int32 -> float\n = \"caml_int32_float_of_bits\" \"caml_int32_float_of_bits_unboxed\"\n [@@unboxed] [@@noalloc]\n\nlet zero = 0l\nlet one = 1l\nlet minus_one = -1l\nlet succ n = add n 1l\nlet pred n = sub n 1l\nlet abs n = if n >= 0l then n else neg n\nlet min_int = 0x80000000l\nlet max_int = 0x7FFFFFFFl\nlet lognot n = logxor n (-1l)\n\nlet unsigned_to_int =\n match Sys.word_size with\n | 32 ->\n let max_int = of_int Stdlib.max_int in\n fun n ->\n if compare zero n <= 0 && compare n max_int <= 0 then\n Some (to_int n)\n else\n None\n | 64 ->\n (* So that it compiles in 32-bit *)\n let mask = 0xFFFF lsl 16 lor 0xFFFF in\n fun n -> Some (to_int n land mask)\n | _ ->\n assert false\n\nexternal format : string -> int32 -> string = \"caml_int32_format\"\nlet to_string n = format \"%d\" n\n\nexternal of_string : string -> int32 = \"caml_int32_of_string\"\n\nlet of_string_opt s =\n (* TODO: expose a non-raising primitive directly. *)\n try Some (of_string s)\n with Failure _ -> None\n\ntype t = int32\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nlet equal (x: t) (y: t) = compare x y = 0\n\nlet unsigned_compare n m =\n compare (sub n min_int) (sub m min_int)\n\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\n\n(* Unsigned division from signed division of the same\n bitness. See Warren Jr., Henry S. (2013). Hacker's Delight (2 ed.), Sec 9-3.\n*)\nlet unsigned_div n d =\n if d < zero then\n if unsigned_compare n d < 0 then zero else one\n else\n let q = shift_left (div (shift_right_logical n 1) d) 1 in\n let r = sub n (mul q d) in\n if unsigned_compare r d >= 0 then succ q else q\n\nlet unsigned_rem n d =\n sub n (mul (unsigned_div n d) d)\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Nativeint]: processor-native integers *)\n\nexternal neg: nativeint -> nativeint = \"%nativeint_neg\"\nexternal add: nativeint -> nativeint -> nativeint = \"%nativeint_add\"\nexternal sub: nativeint -> nativeint -> nativeint = \"%nativeint_sub\"\nexternal mul: nativeint -> nativeint -> nativeint = \"%nativeint_mul\"\nexternal div: nativeint -> nativeint -> nativeint = \"%nativeint_div\"\nexternal rem: nativeint -> nativeint -> nativeint = \"%nativeint_mod\"\nexternal logand: nativeint -> nativeint -> nativeint = \"%nativeint_and\"\nexternal logor: nativeint -> nativeint -> nativeint = \"%nativeint_or\"\nexternal logxor: nativeint -> nativeint -> nativeint = \"%nativeint_xor\"\nexternal shift_left: nativeint -> int -> nativeint = \"%nativeint_lsl\"\nexternal shift_right: nativeint -> int -> nativeint = \"%nativeint_asr\"\nexternal shift_right_logical: nativeint -> int -> nativeint = \"%nativeint_lsr\"\nexternal of_int: int -> nativeint = \"%nativeint_of_int\"\nexternal to_int: nativeint -> int = \"%nativeint_to_int\"\nexternal of_float : float -> nativeint\n = \"caml_nativeint_of_float\" \"caml_nativeint_of_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal to_float : nativeint -> float\n = \"caml_nativeint_to_float\" \"caml_nativeint_to_float_unboxed\"\n [@@unboxed] [@@noalloc]\nexternal of_int32: int32 -> nativeint = \"%nativeint_of_int32\"\nexternal to_int32: nativeint -> int32 = \"%nativeint_to_int32\"\n\nlet zero = 0n\nlet one = 1n\nlet minus_one = -1n\nlet succ n = add n 1n\nlet pred n = sub n 1n\nlet abs n = if n >= 0n then n else neg n\nlet size = Sys.word_size\nlet min_int = shift_left 1n (size - 1)\nlet max_int = sub min_int 1n\nlet lognot n = logxor n (-1n)\n\nlet unsigned_to_int =\n let max_int = of_int Stdlib.max_int in\n fun n ->\n if compare zero n <= 0 && compare n max_int <= 0 then\n Some (to_int n)\n else\n None\n\nexternal format : string -> nativeint -> string = \"caml_nativeint_format\"\nlet to_string n = format \"%d\" n\n\nexternal of_string: string -> nativeint = \"caml_nativeint_of_string\"\n\nlet of_string_opt s =\n (* TODO: expose a non-raising primitive directly. *)\n try Some (of_string s)\n with Failure _ -> None\n\ntype t = nativeint\n\nlet compare (x: t) (y: t) = Stdlib.compare x y\nlet equal (x: t) (y: t) = compare x y = 0\n\nlet unsigned_compare n m =\n compare (sub n min_int) (sub m min_int)\n\nlet min x y : t = if x <= y then x else y\nlet max x y : t = if x >= y then x else y\n\n(* Unsigned division from signed division of the same\n bitness. See Warren Jr., Henry S. (2013). Hacker's Delight (2 ed.), Sec 9-3.\n*)\nlet unsigned_div n d =\n if d < zero then\n if unsigned_compare n d < 0 then zero else one\n else\n let q = shift_left (div (shift_right_logical n 1) d) 1 in\n let r = sub n (mul q d) in\n if unsigned_compare r d >= 0 then succ q else q\n\nlet unsigned_rem n d =\n sub n (mul (unsigned_div n d) d)\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* The parsing engine *)\n\nopen Lexing\n\n(* Internal interface to the parsing engine *)\n\ntype parser_env =\n { mutable s_stack : int array; (* States *)\n mutable v_stack : Obj.t array; (* Semantic attributes *)\n mutable symb_start_stack : position array; (* Start positions *)\n mutable symb_end_stack : position array; (* End positions *)\n mutable stacksize : int; (* Size of the stacks *)\n mutable stackbase : int; (* Base sp for current parse *)\n mutable curr_char : int; (* Last token read *)\n mutable lval : Obj.t; (* Its semantic attribute *)\n mutable symb_start : position; (* Start pos. of the current symbol*)\n mutable symb_end : position; (* End pos. of the current symbol *)\n mutable asp : int; (* The stack pointer for attributes *)\n mutable rule_len : int; (* Number of rhs items in the rule *)\n mutable rule_number : int; (* Rule number to reduce by *)\n mutable sp : int; (* Saved sp for parse_engine *)\n mutable state : int; (* Saved state for parse_engine *)\n mutable errflag : int } (* Saved error flag for parse_engine *)\n[@@warning \"-unused-field\"]\n\ntype parse_tables =\n { actions : (parser_env -> Obj.t) array;\n transl_const : int array;\n transl_block : int array;\n lhs : string;\n len : string;\n defred : string;\n dgoto : string;\n sindex : string;\n rindex : string;\n gindex : string;\n tablesize : int;\n table : string;\n check : string;\n error_function : string -> unit;\n names_const : string;\n names_block : string }\n\nexception YYexit of Obj.t\nexception Parse_error\n\ntype parser_input =\n Start\n | Token_read\n | Stacks_grown_1\n | Stacks_grown_2\n | Semantic_action_computed\n | Error_detected\n\ntype parser_output =\n Read_token\n | Raise_parse_error\n | Grow_stacks_1\n | Grow_stacks_2\n | Compute_semantic_action\n | Call_error_function\n\n(* to avoid warnings *)\nlet _ = [Read_token; Raise_parse_error; Grow_stacks_1; Grow_stacks_2;\n Compute_semantic_action; Call_error_function]\n\nexternal parse_engine :\n parse_tables -> parser_env -> parser_input -> Obj.t -> parser_output\n = \"caml_parse_engine\"\n\nexternal set_trace: bool -> bool\n = \"caml_set_parser_trace\"\n\nlet env =\n { s_stack = Array.make 100 0;\n v_stack = Array.make 100 (Obj.repr ());\n symb_start_stack = Array.make 100 dummy_pos;\n symb_end_stack = Array.make 100 dummy_pos;\n stacksize = 100;\n stackbase = 0;\n curr_char = 0;\n lval = Obj.repr ();\n symb_start = dummy_pos;\n symb_end = dummy_pos;\n asp = 0;\n rule_len = 0;\n rule_number = 0;\n sp = 0;\n state = 0;\n errflag = 0 }\n\nlet grow_stacks() =\n let oldsize = env.stacksize in\n let newsize = oldsize * 2 in\n let new_s = Array.make newsize 0\n and new_v = Array.make newsize (Obj.repr ())\n and new_start = Array.make newsize dummy_pos\n and new_end = Array.make newsize dummy_pos in\n Array.blit env.s_stack 0 new_s 0 oldsize;\n env.s_stack <- new_s;\n Array.blit env.v_stack 0 new_v 0 oldsize;\n env.v_stack <- new_v;\n Array.blit env.symb_start_stack 0 new_start 0 oldsize;\n env.symb_start_stack <- new_start;\n Array.blit env.symb_end_stack 0 new_end 0 oldsize;\n env.symb_end_stack <- new_end;\n env.stacksize <- newsize\n\nlet clear_parser() =\n Array.fill env.v_stack 0 env.stacksize (Obj.repr ());\n env.lval <- Obj.repr ()\n\nlet current_lookahead_fun = ref (fun (_ : Obj.t) -> false)\n\nlet yyparse tables start lexer lexbuf =\n let rec loop cmd arg =\n match parse_engine tables env cmd arg with\n Read_token ->\n let t = Obj.repr(lexer lexbuf) in\n env.symb_start <- lexbuf.lex_start_p;\n env.symb_end <- lexbuf.lex_curr_p;\n loop Token_read t\n | Raise_parse_error ->\n raise Parse_error\n | Compute_semantic_action ->\n let (action, value) =\n try\n (Semantic_action_computed, tables.actions.(env.rule_number) env)\n with Parse_error ->\n (Error_detected, Obj.repr ()) in\n loop action value\n | Grow_stacks_1 ->\n grow_stacks(); loop Stacks_grown_1 (Obj.repr ())\n | Grow_stacks_2 ->\n grow_stacks(); loop Stacks_grown_2 (Obj.repr ())\n | Call_error_function ->\n tables.error_function \"syntax error\";\n loop Error_detected (Obj.repr ()) in\n let init_asp = env.asp\n and init_sp = env.sp\n and init_stackbase = env.stackbase\n and init_state = env.state\n and init_curr_char = env.curr_char\n and init_lval = env.lval\n and init_errflag = env.errflag in\n env.stackbase <- env.sp + 1;\n env.curr_char <- start;\n env.symb_end <- lexbuf.lex_curr_p;\n try\n loop Start (Obj.repr ())\n with exn ->\n let curr_char = env.curr_char in\n env.asp <- init_asp;\n env.sp <- init_sp;\n env.stackbase <- init_stackbase;\n env.state <- init_state;\n env.curr_char <- init_curr_char;\n env.lval <- init_lval;\n env.errflag <- init_errflag;\n match exn with\n YYexit v ->\n Obj.magic v\n | _ ->\n current_lookahead_fun :=\n (fun tok ->\n if Obj.is_block tok\n then tables.transl_block.(Obj.tag tok) = curr_char\n else tables.transl_const.(Obj.magic tok) = curr_char);\n raise exn\n\nlet peek_val env n =\n Obj.magic env.v_stack.(env.asp - n)\n\nlet symbol_start_pos () =\n let rec loop i =\n if i <= 0 then env.symb_end_stack.(env.asp)\n else begin\n let st = env.symb_start_stack.(env.asp - i + 1) in\n let en = env.symb_end_stack.(env.asp - i + 1) in\n if st <> en then st else loop (i - 1)\n end\n in\n loop env.rule_len\n\nlet symbol_end_pos () = env.symb_end_stack.(env.asp)\nlet rhs_start_pos n = env.symb_start_stack.(env.asp - (env.rule_len - n))\nlet rhs_end_pos n = env.symb_end_stack.(env.asp - (env.rule_len - n))\n\nlet symbol_start () = (symbol_start_pos ()).pos_cnum\nlet symbol_end () = (symbol_end_pos ()).pos_cnum\nlet rhs_start n = (rhs_start_pos n).pos_cnum\nlet rhs_end n = (rhs_end_pos n).pos_cnum\n\nlet is_current_lookahead tok =\n (!current_lookahead_fun)(Obj.repr tok)\n\nlet parse_error (_ : string) = ()\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Sets over ordered types *)\n\nmodule type OrderedType =\n sig\n type t\n val compare: t -> t -> int\n end\n\nmodule type S =\n sig\n type elt\n type t\n val empty: t\n val is_empty: t -> bool\n val mem: elt -> t -> bool\n val add: elt -> t -> t\n val singleton: elt -> t\n val remove: elt -> t -> t\n val union: t -> t -> t\n val inter: t -> t -> t\n val disjoint: t -> t -> bool\n val diff: t -> t -> t\n val compare: t -> t -> int\n val equal: t -> t -> bool\n val subset: t -> t -> bool\n val iter: (elt -> unit) -> t -> unit\n val map: (elt -> elt) -> t -> t\n val fold: (elt -> 'a -> 'a) -> t -> 'a -> 'a\n val for_all: (elt -> bool) -> t -> bool\n val exists: (elt -> bool) -> t -> bool\n val filter: (elt -> bool) -> t -> t\n val filter_map: (elt -> elt option) -> t -> t\n val partition: (elt -> bool) -> t -> t * t\n val cardinal: t -> int\n val elements: t -> elt list\n val min_elt: t -> elt\n val min_elt_opt: t -> elt option\n val max_elt: t -> elt\n val max_elt_opt: t -> elt option\n val choose: t -> elt\n val choose_opt: t -> elt option\n val split: elt -> t -> t * bool * t\n val find: elt -> t -> elt\n val find_opt: elt -> t -> elt option\n val find_first: (elt -> bool) -> t -> elt\n val find_first_opt: (elt -> bool) -> t -> elt option\n val find_last: (elt -> bool) -> t -> elt\n val find_last_opt: (elt -> bool) -> t -> elt option\n val of_list: elt list -> t\n val to_seq_from : elt -> t -> elt Seq.t\n val to_seq : t -> elt Seq.t\n val to_rev_seq : t -> elt Seq.t\n val add_seq : elt Seq.t -> t -> t\n val of_seq : elt Seq.t -> t\n end\n\nmodule Make(Ord: OrderedType) =\n struct\n type elt = Ord.t\n type t = Empty | Node of {l:t; v:elt; r:t; h:int}\n\n (* Sets are represented by balanced binary trees (the heights of the\n children differ by at most 2 *)\n\n let height = function\n Empty -> 0\n | Node {h} -> h\n\n (* Creates a new node with left son l, value v and right son r.\n We must have all elements of l < v < all elements of r.\n l and r must be balanced and | height l - height r | <= 2.\n Inline expansion of height for better speed. *)\n\n let create l v r =\n let hl = match l with Empty -> 0 | Node {h} -> h in\n let hr = match r with Empty -> 0 | Node {h} -> h in\n Node{l; v; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n (* Same as create, but performs one step of rebalancing if necessary.\n Assumes l and r balanced and | height l - height r | <= 3.\n Inline expansion of create for better speed in the most frequent case\n where no rebalancing is required. *)\n\n let bal l v r =\n let hl = match l with Empty -> 0 | Node {h} -> h in\n let hr = match r with Empty -> 0 | Node {h} -> h in\n if hl > hr + 2 then begin\n match l with\n Empty -> invalid_arg \"Set.bal\"\n | Node{l=ll; v=lv; r=lr} ->\n if height ll >= height lr then\n create ll lv (create lr v r)\n else begin\n match lr with\n Empty -> invalid_arg \"Set.bal\"\n | Node{l=lrl; v=lrv; r=lrr}->\n create (create ll lv lrl) lrv (create lrr v r)\n end\n end else if hr > hl + 2 then begin\n match r with\n Empty -> invalid_arg \"Set.bal\"\n | Node{l=rl; v=rv; r=rr} ->\n if height rr >= height rl then\n create (create l v rl) rv rr\n else begin\n match rl with\n Empty -> invalid_arg \"Set.bal\"\n | Node{l=rll; v=rlv; r=rlr} ->\n create (create l v rll) rlv (create rlr rv rr)\n end\n end else\n Node{l; v; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n (* Insertion of one element *)\n\n let rec add x = function\n Empty -> Node{l=Empty; v=x; r=Empty; h=1}\n | Node{l; v; r} as t ->\n let c = Ord.compare x v in\n if c = 0 then t else\n if c < 0 then\n let ll = add x l in\n if l == ll then t else bal ll v r\n else\n let rr = add x r in\n if r == rr then t else bal l v rr\n\n let singleton x = Node{l=Empty; v=x; r=Empty; h=1}\n\n (* Beware: those two functions assume that the added v is *strictly*\n smaller (or bigger) than all the present elements in the tree; it\n does not test for equality with the current min (or max) element.\n Indeed, they are only used during the \"join\" operation which\n respects this precondition.\n *)\n\n let rec add_min_element x = function\n | Empty -> singleton x\n | Node {l; v; r} ->\n bal (add_min_element x l) v r\n\n let rec add_max_element x = function\n | Empty -> singleton x\n | Node {l; v; r} ->\n bal l v (add_max_element x r)\n\n (* Same as create and bal, but no assumptions are made on the\n relative heights of l and r. *)\n\n let rec join l v r =\n match (l, r) with\n (Empty, _) -> add_min_element v r\n | (_, Empty) -> add_max_element v l\n | (Node{l=ll; v=lv; r=lr; h=lh}, Node{l=rl; v=rv; r=rr; h=rh}) ->\n if lh > rh + 2 then bal ll lv (join lr v r) else\n if rh > lh + 2 then bal (join l v rl) rv rr else\n create l v r\n\n (* Smallest and greatest element of a set *)\n\n let rec min_elt = function\n Empty -> raise Not_found\n | Node{l=Empty; v} -> v\n | Node{l} -> min_elt l\n\n let rec min_elt_opt = function\n Empty -> None\n | Node{l=Empty; v} -> Some v\n | Node{l} -> min_elt_opt l\n\n let rec max_elt = function\n Empty -> raise Not_found\n | Node{v; r=Empty} -> v\n | Node{r} -> max_elt r\n\n let rec max_elt_opt = function\n Empty -> None\n | Node{v; r=Empty} -> Some v\n | Node{r} -> max_elt_opt r\n\n (* Remove the smallest element of the given set *)\n\n let rec remove_min_elt = function\n Empty -> invalid_arg \"Set.remove_min_elt\"\n | Node{l=Empty; r} -> r\n | Node{l; v; r} -> bal (remove_min_elt l) v r\n\n (* Merge two trees l and r into one.\n All elements of l must precede the elements of r.\n Assume | height l - height r | <= 2. *)\n\n let merge t1 t2 =\n match (t1, t2) with\n (Empty, t) -> t\n | (t, Empty) -> t\n | (_, _) -> bal t1 (min_elt t2) (remove_min_elt t2)\n\n (* Merge two trees l and r into one.\n All elements of l must precede the elements of r.\n No assumption on the heights of l and r. *)\n\n let concat t1 t2 =\n match (t1, t2) with\n (Empty, t) -> t\n | (t, Empty) -> t\n | (_, _) -> join t1 (min_elt t2) (remove_min_elt t2)\n\n (* Splitting. split x s returns a triple (l, present, r) where\n - l is the set of elements of s that are < x\n - r is the set of elements of s that are > x\n - present is false if s contains no element equal to x,\n or true if s contains an element equal to x. *)\n\n let rec split x = function\n Empty ->\n (Empty, false, Empty)\n | Node{l; v; r} ->\n let c = Ord.compare x v in\n if c = 0 then (l, true, r)\n else if c < 0 then\n let (ll, pres, rl) = split x l in (ll, pres, join rl v r)\n else\n let (lr, pres, rr) = split x r in (join l v lr, pres, rr)\n\n (* Implementation of the set operations *)\n\n let empty = Empty\n\n let is_empty = function Empty -> true | _ -> false\n\n let rec mem x = function\n Empty -> false\n | Node{l; v; r} ->\n let c = Ord.compare x v in\n c = 0 || mem x (if c < 0 then l else r)\n\n let rec remove x = function\n Empty -> Empty\n | (Node{l; v; r} as t) ->\n let c = Ord.compare x v in\n if c = 0 then merge l r\n else\n if c < 0 then\n let ll = remove x l in\n if l == ll then t\n else bal ll v r\n else\n let rr = remove x r in\n if r == rr then t\n else bal l v rr\n\n let rec union s1 s2 =\n match (s1, s2) with\n (Empty, t2) -> t2\n | (t1, Empty) -> t1\n | (Node{l=l1; v=v1; r=r1; h=h1}, Node{l=l2; v=v2; r=r2; h=h2}) ->\n if h1 >= h2 then\n if h2 = 1 then add v2 s1 else begin\n let (l2, _, r2) = split v1 s2 in\n join (union l1 l2) v1 (union r1 r2)\n end\n else\n if h1 = 1 then add v1 s2 else begin\n let (l1, _, r1) = split v2 s1 in\n join (union l1 l2) v2 (union r1 r2)\n end\n\n let rec inter s1 s2 =\n match (s1, s2) with\n (Empty, _) -> Empty\n | (_, Empty) -> Empty\n | (Node{l=l1; v=v1; r=r1}, t2) ->\n match split v1 t2 with\n (l2, false, r2) ->\n concat (inter l1 l2) (inter r1 r2)\n | (l2, true, r2) ->\n join (inter l1 l2) v1 (inter r1 r2)\n\n (* Same as split, but compute the left and right subtrees\n only if the pivot element is not in the set. The right subtree\n is computed on demand. *)\n\n type split_bis =\n | Found\n | NotFound of t * (unit -> t)\n\n let rec split_bis x = function\n Empty ->\n NotFound (Empty, (fun () -> Empty))\n | Node{l; v; r; _} ->\n let c = Ord.compare x v in\n if c = 0 then Found\n else if c < 0 then\n match split_bis x l with\n | Found -> Found\n | NotFound (ll, rl) -> NotFound (ll, (fun () -> join (rl ()) v r))\n else\n match split_bis x r with\n | Found -> Found\n | NotFound (lr, rr) -> NotFound (join l v lr, rr)\n\n let rec disjoint s1 s2 =\n match (s1, s2) with\n (Empty, _) | (_, Empty) -> true\n | (Node{l=l1; v=v1; r=r1}, t2) ->\n if s1 == s2 then false\n else match split_bis v1 t2 with\n NotFound(l2, r2) -> disjoint l1 l2 && disjoint r1 (r2 ())\n | Found -> false\n\n let rec diff s1 s2 =\n match (s1, s2) with\n (Empty, _) -> Empty\n | (t1, Empty) -> t1\n | (Node{l=l1; v=v1; r=r1}, t2) ->\n match split v1 t2 with\n (l2, false, r2) ->\n join (diff l1 l2) v1 (diff r1 r2)\n | (l2, true, r2) ->\n concat (diff l1 l2) (diff r1 r2)\n\n type enumeration = End | More of elt * t * enumeration\n\n let rec cons_enum s e =\n match s with\n Empty -> e\n | Node{l; v; r} -> cons_enum l (More(v, r, e))\n\n let rec compare_aux e1 e2 =\n match (e1, e2) with\n (End, End) -> 0\n | (End, _) -> -1\n | (_, End) -> 1\n | (More(v1, r1, e1), More(v2, r2, e2)) ->\n let c = Ord.compare v1 v2 in\n if c <> 0\n then c\n else compare_aux (cons_enum r1 e1) (cons_enum r2 e2)\n\n let compare s1 s2 =\n compare_aux (cons_enum s1 End) (cons_enum s2 End)\n\n let equal s1 s2 =\n compare s1 s2 = 0\n\n let rec subset s1 s2 =\n match (s1, s2) with\n Empty, _ ->\n true\n | _, Empty ->\n false\n | Node {l=l1; v=v1; r=r1}, (Node {l=l2; v=v2; r=r2} as t2) ->\n let c = Ord.compare v1 v2 in\n if c = 0 then\n subset l1 l2 && subset r1 r2\n else if c < 0 then\n subset (Node {l=l1; v=v1; r=Empty; h=0}) l2 && subset r1 t2\n else\n subset (Node {l=Empty; v=v1; r=r1; h=0}) r2 && subset l1 t2\n\n let rec iter f = function\n Empty -> ()\n | Node{l; v; r} -> iter f l; f v; iter f r\n\n let rec fold f s accu =\n match s with\n Empty -> accu\n | Node{l; v; r} -> fold f r (f v (fold f l accu))\n\n let rec for_all p = function\n Empty -> true\n | Node{l; v; r} -> p v && for_all p l && for_all p r\n\n let rec exists p = function\n Empty -> false\n | Node{l; v; r} -> p v || exists p l || exists p r\n\n let rec filter p = function\n Empty -> Empty\n | (Node{l; v; r}) as t ->\n (* call [p] in the expected left-to-right order *)\n let l' = filter p l in\n let pv = p v in\n let r' = filter p r in\n if pv then\n if l==l' && r==r' then t else join l' v r'\n else concat l' r'\n\n let rec partition p = function\n Empty -> (Empty, Empty)\n | Node{l; v; r} ->\n (* call [p] in the expected left-to-right order *)\n let (lt, lf) = partition p l in\n let pv = p v in\n let (rt, rf) = partition p r in\n if pv\n then (join lt v rt, concat lf rf)\n else (concat lt rt, join lf v rf)\n\n let rec cardinal = function\n Empty -> 0\n | Node{l; r} -> cardinal l + 1 + cardinal r\n\n let rec elements_aux accu = function\n Empty -> accu\n | Node{l; v; r} -> elements_aux (v :: elements_aux accu r) l\n\n let elements s =\n elements_aux [] s\n\n let choose = min_elt\n\n let choose_opt = min_elt_opt\n\n let rec find x = function\n Empty -> raise Not_found\n | Node{l; v; r} ->\n let c = Ord.compare x v in\n if c = 0 then v\n else find x (if c < 0 then l else r)\n\n let rec find_first_aux v0 f = function\n Empty ->\n v0\n | Node{l; v; r} ->\n if f v then\n find_first_aux v f l\n else\n find_first_aux v0 f r\n\n let rec find_first f = function\n Empty ->\n raise Not_found\n | Node{l; v; r} ->\n if f v then\n find_first_aux v f l\n else\n find_first f r\n\n let rec find_first_opt_aux v0 f = function\n Empty ->\n Some v0\n | Node{l; v; r} ->\n if f v then\n find_first_opt_aux v f l\n else\n find_first_opt_aux v0 f r\n\n let rec find_first_opt f = function\n Empty ->\n None\n | Node{l; v; r} ->\n if f v then\n find_first_opt_aux v f l\n else\n find_first_opt f r\n\n let rec find_last_aux v0 f = function\n Empty ->\n v0\n | Node{l; v; r} ->\n if f v then\n find_last_aux v f r\n else\n find_last_aux v0 f l\n\n let rec find_last f = function\n Empty ->\n raise Not_found\n | Node{l; v; r} ->\n if f v then\n find_last_aux v f r\n else\n find_last f l\n\n let rec find_last_opt_aux v0 f = function\n Empty ->\n Some v0\n | Node{l; v; r} ->\n if f v then\n find_last_opt_aux v f r\n else\n find_last_opt_aux v0 f l\n\n let rec find_last_opt f = function\n Empty ->\n None\n | Node{l; v; r} ->\n if f v then\n find_last_opt_aux v f r\n else\n find_last_opt f l\n\n let rec find_opt x = function\n Empty -> None\n | Node{l; v; r} ->\n let c = Ord.compare x v in\n if c = 0 then Some v\n else find_opt x (if c < 0 then l else r)\n\n let try_join l v r =\n (* [join l v r] can only be called when (elements of l < v <\n elements of r); use [try_join l v r] when this property may\n not hold, but you hope it does hold in the common case *)\n if (l = Empty || Ord.compare (max_elt l) v < 0)\n && (r = Empty || Ord.compare v (min_elt r) < 0)\n then join l v r\n else union l (add v r)\n\n let rec map f = function\n | Empty -> Empty\n | Node{l; v; r} as t ->\n (* enforce left-to-right evaluation order *)\n let l' = map f l in\n let v' = f v in\n let r' = map f r in\n if l == l' && v == v' && r == r' then t\n else try_join l' v' r'\n\n let try_concat t1 t2 =\n match (t1, t2) with\n (Empty, t) -> t\n | (t, Empty) -> t\n | (_, _) -> try_join t1 (min_elt t2) (remove_min_elt t2)\n\n let rec filter_map f = function\n | Empty -> Empty\n | Node{l; v; r} as t ->\n (* enforce left-to-right evaluation order *)\n let l' = filter_map f l in\n let v' = f v in\n let r' = filter_map f r in\n begin match v' with\n | Some v' ->\n if l == l' && v == v' && r == r' then t\n else try_join l' v' r'\n | None ->\n try_concat l' r'\n end\n\n let of_sorted_list l =\n let rec sub n l =\n match n, l with\n | 0, l -> Empty, l\n | 1, x0 :: l -> Node {l=Empty; v=x0; r=Empty; h=1}, l\n | 2, x0 :: x1 :: l ->\n Node{l=Node{l=Empty; v=x0; r=Empty; h=1}; v=x1; r=Empty; h=2}, l\n | 3, x0 :: x1 :: x2 :: l ->\n Node{l=Node{l=Empty; v=x0; r=Empty; h=1}; v=x1;\n r=Node{l=Empty; v=x2; r=Empty; h=1}; h=2}, l\n | n, l ->\n let nl = n / 2 in\n let left, l = sub nl l in\n match l with\n | [] -> assert false\n | mid :: l ->\n let right, l = sub (n - nl - 1) l in\n create left mid right, l\n in\n fst (sub (List.length l) l)\n\n let of_list l =\n match l with\n | [] -> empty\n | [x0] -> singleton x0\n | [x0; x1] -> add x1 (singleton x0)\n | [x0; x1; x2] -> add x2 (add x1 (singleton x0))\n | [x0; x1; x2; x3] -> add x3 (add x2 (add x1 (singleton x0)))\n | [x0; x1; x2; x3; x4] -> add x4 (add x3 (add x2 (add x1 (singleton x0))))\n | _ -> of_sorted_list (List.sort_uniq Ord.compare l)\n\n let add_seq i m =\n Seq.fold_left (fun s x -> add x s) m i\n\n let of_seq i = add_seq i empty\n\n let rec seq_of_enum_ c () = match c with\n | End -> Seq.Nil\n | More (x, t, rest) -> Seq.Cons (x, seq_of_enum_ (cons_enum t rest))\n\n let to_seq c = seq_of_enum_ (cons_enum c End)\n\n let rec snoc_enum s e =\n match s with\n Empty -> e\n | Node{l; v; r} -> snoc_enum r (More(v, l, e))\n\n let rec rev_seq_of_enum_ c () = match c with\n | End -> Seq.Nil\n | More (x, t, rest) -> Seq.Cons (x, rev_seq_of_enum_ (snoc_enum t rest))\n\n let to_rev_seq c = rev_seq_of_enum_ (snoc_enum c End)\n\n let to_seq_from low s =\n let rec aux low s c = match s with\n | Empty -> c\n | Node {l; r; v; _} ->\n begin match Ord.compare v low with\n | 0 -> More (v, r, c)\n | n when n<0 -> aux low r c\n | _ -> aux low l (More (v, r, c))\n end\n in\n seq_of_enum_ (aux low s End)\n end\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule type OrderedType =\n sig\n type t\n val compare: t -> t -> int\n end\n\nmodule type S =\n sig\n type key\n type !+'a t\n val empty: 'a t\n val is_empty: 'a t -> bool\n val mem: key -> 'a t -> bool\n val add: key -> 'a -> 'a t -> 'a t\n val update: key -> ('a option -> 'a option) -> 'a t -> 'a t\n val singleton: key -> 'a -> 'a t\n val remove: key -> 'a t -> 'a t\n val merge:\n (key -> 'a option -> 'b option -> 'c option) -> 'a t -> 'b t -> 'c t\n val union: (key -> 'a -> 'a -> 'a option) -> 'a t -> 'a t -> 'a t\n val compare: ('a -> 'a -> int) -> 'a t -> 'a t -> int\n val equal: ('a -> 'a -> bool) -> 'a t -> 'a t -> bool\n val iter: (key -> 'a -> unit) -> 'a t -> unit\n val fold: (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n val for_all: (key -> 'a -> bool) -> 'a t -> bool\n val exists: (key -> 'a -> bool) -> 'a t -> bool\n val filter: (key -> 'a -> bool) -> 'a t -> 'a t\n val filter_map: (key -> 'a -> 'b option) -> 'a t -> 'b t\n val partition: (key -> 'a -> bool) -> 'a t -> 'a t * 'a t\n val cardinal: 'a t -> int\n val bindings: 'a t -> (key * 'a) list\n val min_binding: 'a t -> (key * 'a)\n val min_binding_opt: 'a t -> (key * 'a) option\n val max_binding: 'a t -> (key * 'a)\n val max_binding_opt: 'a t -> (key * 'a) option\n val choose: 'a t -> (key * 'a)\n val choose_opt: 'a t -> (key * 'a) option\n val split: key -> 'a t -> 'a t * 'a option * 'a t\n val find: key -> 'a t -> 'a\n val find_opt: key -> 'a t -> 'a option\n val find_first: (key -> bool) -> 'a t -> key * 'a\n val find_first_opt: (key -> bool) -> 'a t -> (key * 'a) option\n val find_last: (key -> bool) -> 'a t -> key * 'a\n val find_last_opt: (key -> bool) -> 'a t -> (key * 'a) option\n val map: ('a -> 'b) -> 'a t -> 'b t\n val mapi: (key -> 'a -> 'b) -> 'a t -> 'b t\n val to_seq : 'a t -> (key * 'a) Seq.t\n val to_rev_seq : 'a t -> (key * 'a) Seq.t\n val to_seq_from : key -> 'a t -> (key * 'a) Seq.t\n val add_seq : (key * 'a) Seq.t -> 'a t -> 'a t\n val of_seq : (key * 'a) Seq.t -> 'a t\n end\n\nmodule Make(Ord: OrderedType) = struct\n\n type key = Ord.t\n\n type 'a t =\n Empty\n | Node of {l:'a t; v:key; d:'a; r:'a t; h:int}\n\n let height = function\n Empty -> 0\n | Node {h} -> h\n\n let create l x d r =\n let hl = height l and hr = height r in\n Node{l; v=x; d; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n let singleton x d = Node{l=Empty; v=x; d; r=Empty; h=1}\n\n let bal l x d r =\n let hl = match l with Empty -> 0 | Node {h} -> h in\n let hr = match r with Empty -> 0 | Node {h} -> h in\n if hl > hr + 2 then begin\n match l with\n Empty -> invalid_arg \"Map.bal\"\n | Node{l=ll; v=lv; d=ld; r=lr} ->\n if height ll >= height lr then\n create ll lv ld (create lr x d r)\n else begin\n match lr with\n Empty -> invalid_arg \"Map.bal\"\n | Node{l=lrl; v=lrv; d=lrd; r=lrr}->\n create (create ll lv ld lrl) lrv lrd (create lrr x d r)\n end\n end else if hr > hl + 2 then begin\n match r with\n Empty -> invalid_arg \"Map.bal\"\n | Node{l=rl; v=rv; d=rd; r=rr} ->\n if height rr >= height rl then\n create (create l x d rl) rv rd rr\n else begin\n match rl with\n Empty -> invalid_arg \"Map.bal\"\n | Node{l=rll; v=rlv; d=rld; r=rlr} ->\n create (create l x d rll) rlv rld (create rlr rv rd rr)\n end\n end else\n Node{l; v=x; d; r; h=(if hl >= hr then hl + 1 else hr + 1)}\n\n let empty = Empty\n\n let is_empty = function Empty -> true | _ -> false\n\n let rec add x data = function\n Empty ->\n Node{l=Empty; v=x; d=data; r=Empty; h=1}\n | Node {l; v; d; r; h} as m ->\n let c = Ord.compare x v in\n if c = 0 then\n if d == data then m else Node{l; v=x; d=data; r; h}\n else if c < 0 then\n let ll = add x data l in\n if l == ll then m else bal ll v d r\n else\n let rr = add x data r in\n if r == rr then m else bal l v d rr\n\n let rec find x = function\n Empty ->\n raise Not_found\n | Node {l; v; d; r} ->\n let c = Ord.compare x v in\n if c = 0 then d\n else find x (if c < 0 then l else r)\n\n let rec find_first_aux v0 d0 f = function\n Empty ->\n (v0, d0)\n | Node {l; v; d; r} ->\n if f v then\n find_first_aux v d f l\n else\n find_first_aux v0 d0 f r\n\n let rec find_first f = function\n Empty ->\n raise Not_found\n | Node {l; v; d; r} ->\n if f v then\n find_first_aux v d f l\n else\n find_first f r\n\n let rec find_first_opt_aux v0 d0 f = function\n Empty ->\n Some (v0, d0)\n | Node {l; v; d; r} ->\n if f v then\n find_first_opt_aux v d f l\n else\n find_first_opt_aux v0 d0 f r\n\n let rec find_first_opt f = function\n Empty ->\n None\n | Node {l; v; d; r} ->\n if f v then\n find_first_opt_aux v d f l\n else\n find_first_opt f r\n\n let rec find_last_aux v0 d0 f = function\n Empty ->\n (v0, d0)\n | Node {l; v; d; r} ->\n if f v then\n find_last_aux v d f r\n else\n find_last_aux v0 d0 f l\n\n let rec find_last f = function\n Empty ->\n raise Not_found\n | Node {l; v; d; r} ->\n if f v then\n find_last_aux v d f r\n else\n find_last f l\n\n let rec find_last_opt_aux v0 d0 f = function\n Empty ->\n Some (v0, d0)\n | Node {l; v; d; r} ->\n if f v then\n find_last_opt_aux v d f r\n else\n find_last_opt_aux v0 d0 f l\n\n let rec find_last_opt f = function\n Empty ->\n None\n | Node {l; v; d; r} ->\n if f v then\n find_last_opt_aux v d f r\n else\n find_last_opt f l\n\n let rec find_opt x = function\n Empty ->\n None\n | Node {l; v; d; r} ->\n let c = Ord.compare x v in\n if c = 0 then Some d\n else find_opt x (if c < 0 then l else r)\n\n let rec mem x = function\n Empty ->\n false\n | Node {l; v; r} ->\n let c = Ord.compare x v in\n c = 0 || mem x (if c < 0 then l else r)\n\n let rec min_binding = function\n Empty -> raise Not_found\n | Node {l=Empty; v; d} -> (v, d)\n | Node {l} -> min_binding l\n\n let rec min_binding_opt = function\n Empty -> None\n | Node {l=Empty; v; d} -> Some (v, d)\n | Node {l}-> min_binding_opt l\n\n let rec max_binding = function\n Empty -> raise Not_found\n | Node {v; d; r=Empty} -> (v, d)\n | Node {r} -> max_binding r\n\n let rec max_binding_opt = function\n Empty -> None\n | Node {v; d; r=Empty} -> Some (v, d)\n | Node {r} -> max_binding_opt r\n\n let rec remove_min_binding = function\n Empty -> invalid_arg \"Map.remove_min_elt\"\n | Node {l=Empty; r} -> r\n | Node {l; v; d; r} -> bal (remove_min_binding l) v d r\n\n let merge t1 t2 =\n match (t1, t2) with\n (Empty, t) -> t\n | (t, Empty) -> t\n | (_, _) ->\n let (x, d) = min_binding t2 in\n bal t1 x d (remove_min_binding t2)\n\n let rec remove x = function\n Empty ->\n Empty\n | (Node {l; v; d; r} as m) ->\n let c = Ord.compare x v in\n if c = 0 then merge l r\n else if c < 0 then\n let ll = remove x l in if l == ll then m else bal ll v d r\n else\n let rr = remove x r in if r == rr then m else bal l v d rr\n\n let rec update x f = function\n Empty ->\n begin match f None with\n | None -> Empty\n | Some data -> Node{l=Empty; v=x; d=data; r=Empty; h=1}\n end\n | Node {l; v; d; r; h} as m ->\n let c = Ord.compare x v in\n if c = 0 then begin\n match f (Some d) with\n | None -> merge l r\n | Some data ->\n if d == data then m else Node{l; v=x; d=data; r; h}\n end else if c < 0 then\n let ll = update x f l in\n if l == ll then m else bal ll v d r\n else\n let rr = update x f r in\n if r == rr then m else bal l v d rr\n\n let rec iter f = function\n Empty -> ()\n | Node {l; v; d; r} ->\n iter f l; f v d; iter f r\n\n let rec map f = function\n Empty ->\n Empty\n | Node {l; v; d; r; h} ->\n let l' = map f l in\n let d' = f d in\n let r' = map f r in\n Node{l=l'; v; d=d'; r=r'; h}\n\n let rec mapi f = function\n Empty ->\n Empty\n | Node {l; v; d; r; h} ->\n let l' = mapi f l in\n let d' = f v d in\n let r' = mapi f r in\n Node{l=l'; v; d=d'; r=r'; h}\n\n let rec fold f m accu =\n match m with\n Empty -> accu\n | Node {l; v; d; r} ->\n fold f r (f v d (fold f l accu))\n\n let rec for_all p = function\n Empty -> true\n | Node {l; v; d; r} -> p v d && for_all p l && for_all p r\n\n let rec exists p = function\n Empty -> false\n | Node {l; v; d; r} -> p v d || exists p l || exists p r\n\n (* Beware: those two functions assume that the added k is *strictly*\n smaller (or bigger) than all the present keys in the tree; it\n does not test for equality with the current min (or max) key.\n\n Indeed, they are only used during the \"join\" operation which\n respects this precondition.\n *)\n\n let rec add_min_binding k x = function\n | Empty -> singleton k x\n | Node {l; v; d; r} ->\n bal (add_min_binding k x l) v d r\n\n let rec add_max_binding k x = function\n | Empty -> singleton k x\n | Node {l; v; d; r} ->\n bal l v d (add_max_binding k x r)\n\n (* Same as create and bal, but no assumptions are made on the\n relative heights of l and r. *)\n\n let rec join l v d r =\n match (l, r) with\n (Empty, _) -> add_min_binding v d r\n | (_, Empty) -> add_max_binding v d l\n | (Node{l=ll; v=lv; d=ld; r=lr; h=lh},\n Node{l=rl; v=rv; d=rd; r=rr; h=rh}) ->\n if lh > rh + 2 then bal ll lv ld (join lr v d r) else\n if rh > lh + 2 then bal (join l v d rl) rv rd rr else\n create l v d r\n\n (* Merge two trees l and r into one.\n All elements of l must precede the elements of r.\n No assumption on the heights of l and r. *)\n\n let concat t1 t2 =\n match (t1, t2) with\n (Empty, t) -> t\n | (t, Empty) -> t\n | (_, _) ->\n let (x, d) = min_binding t2 in\n join t1 x d (remove_min_binding t2)\n\n let concat_or_join t1 v d t2 =\n match d with\n | Some d -> join t1 v d t2\n | None -> concat t1 t2\n\n let rec split x = function\n Empty ->\n (Empty, None, Empty)\n | Node {l; v; d; r} ->\n let c = Ord.compare x v in\n if c = 0 then (l, Some d, r)\n else if c < 0 then\n let (ll, pres, rl) = split x l in (ll, pres, join rl v d r)\n else\n let (lr, pres, rr) = split x r in (join l v d lr, pres, rr)\n\n let rec merge f s1 s2 =\n match (s1, s2) with\n (Empty, Empty) -> Empty\n | (Node {l=l1; v=v1; d=d1; r=r1; h=h1}, _) when h1 >= height s2 ->\n let (l2, d2, r2) = split v1 s2 in\n concat_or_join (merge f l1 l2) v1 (f v1 (Some d1) d2) (merge f r1 r2)\n | (_, Node {l=l2; v=v2; d=d2; r=r2}) ->\n let (l1, d1, r1) = split v2 s1 in\n concat_or_join (merge f l1 l2) v2 (f v2 d1 (Some d2)) (merge f r1 r2)\n | _ ->\n assert false\n\n let rec union f s1 s2 =\n match (s1, s2) with\n | (Empty, s) | (s, Empty) -> s\n | (Node {l=l1; v=v1; d=d1; r=r1; h=h1},\n Node {l=l2; v=v2; d=d2; r=r2; h=h2}) ->\n if h1 >= h2 then\n let (l2, d2, r2) = split v1 s2 in\n let l = union f l1 l2 and r = union f r1 r2 in\n match d2 with\n | None -> join l v1 d1 r\n | Some d2 -> concat_or_join l v1 (f v1 d1 d2) r\n else\n let (l1, d1, r1) = split v2 s1 in\n let l = union f l1 l2 and r = union f r1 r2 in\n match d1 with\n | None -> join l v2 d2 r\n | Some d1 -> concat_or_join l v2 (f v2 d1 d2) r\n\n let rec filter p = function\n Empty -> Empty\n | Node {l; v; d; r} as m ->\n (* call [p] in the expected left-to-right order *)\n let l' = filter p l in\n let pvd = p v d in\n let r' = filter p r in\n if pvd then if l==l' && r==r' then m else join l' v d r'\n else concat l' r'\n\n let rec filter_map f = function\n Empty -> Empty\n | Node {l; v; d; r} ->\n (* call [f] in the expected left-to-right order *)\n let l' = filter_map f l in\n let fvd = f v d in\n let r' = filter_map f r in\n begin match fvd with\n | Some d' -> join l' v d' r'\n | None -> concat l' r'\n end\n\n let rec partition p = function\n Empty -> (Empty, Empty)\n | Node {l; v; d; r} ->\n (* call [p] in the expected left-to-right order *)\n let (lt, lf) = partition p l in\n let pvd = p v d in\n let (rt, rf) = partition p r in\n if pvd\n then (join lt v d rt, concat lf rf)\n else (concat lt rt, join lf v d rf)\n\n type 'a enumeration = End | More of key * 'a * 'a t * 'a enumeration\n\n let rec cons_enum m e =\n match m with\n Empty -> e\n | Node {l; v; d; r} -> cons_enum l (More(v, d, r, e))\n\n let compare cmp m1 m2 =\n let rec compare_aux e1 e2 =\n match (e1, e2) with\n (End, End) -> 0\n | (End, _) -> -1\n | (_, End) -> 1\n | (More(v1, d1, r1, e1), More(v2, d2, r2, e2)) ->\n let c = Ord.compare v1 v2 in\n if c <> 0 then c else\n let c = cmp d1 d2 in\n if c <> 0 then c else\n compare_aux (cons_enum r1 e1) (cons_enum r2 e2)\n in compare_aux (cons_enum m1 End) (cons_enum m2 End)\n\n let equal cmp m1 m2 =\n let rec equal_aux e1 e2 =\n match (e1, e2) with\n (End, End) -> true\n | (End, _) -> false\n | (_, End) -> false\n | (More(v1, d1, r1, e1), More(v2, d2, r2, e2)) ->\n Ord.compare v1 v2 = 0 && cmp d1 d2 &&\n equal_aux (cons_enum r1 e1) (cons_enum r2 e2)\n in equal_aux (cons_enum m1 End) (cons_enum m2 End)\n\n let rec cardinal = function\n Empty -> 0\n | Node {l; r} -> cardinal l + 1 + cardinal r\n\n let rec bindings_aux accu = function\n Empty -> accu\n | Node {l; v; d; r} -> bindings_aux ((v, d) :: bindings_aux accu r) l\n\n let bindings s =\n bindings_aux [] s\n\n let choose = min_binding\n\n let choose_opt = min_binding_opt\n\n let add_seq i m =\n Seq.fold_left (fun m (k,v) -> add k v m) m i\n\n let of_seq i = add_seq i empty\n\n let rec seq_of_enum_ c () = match c with\n | End -> Seq.Nil\n | More (k,v,t,rest) -> Seq.Cons ((k,v), seq_of_enum_ (cons_enum t rest))\n\n let to_seq m =\n seq_of_enum_ (cons_enum m End)\n\n let rec snoc_enum s e =\n match s with\n Empty -> e\n | Node{l; v; d; r} -> snoc_enum r (More(v, d, l, e))\n\n let rec rev_seq_of_enum_ c () = match c with\n | End -> Seq.Nil\n | More (k,v,t,rest) ->\n Seq.Cons ((k,v), rev_seq_of_enum_ (snoc_enum t rest))\n\n let to_rev_seq c =\n rev_seq_of_enum_ (snoc_enum c End)\n\n let to_seq_from low m =\n let rec aux low m c = match m with\n | Empty -> c\n | Node {l; v; d; r; _} ->\n begin match Ord.compare v low with\n | 0 -> More (v, d, r, c)\n | n when n<0 -> aux low r c\n | _ -> aux low l (More (v, d, r, c))\n end\n in\n seq_of_enum_ (aux low m End)\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype 'a t = { mutable c : 'a list; mutable len : int; }\n\nexception Empty\n\nlet create () = { c = []; len = 0; }\n\nlet clear s = s.c <- []; s.len <- 0\n\nlet copy s = { c = s.c; len = s.len; }\n\nlet push x s = s.c <- x :: s.c; s.len <- s.len + 1\n\nlet pop s =\n match s.c with\n | hd::tl -> s.c <- tl; s.len <- s.len - 1; hd\n | [] -> raise Empty\n\nlet pop_opt s =\n match s.c with\n | hd::tl -> s.c <- tl; s.len <- s.len - 1; Some hd\n | [] -> None\n\nlet top s =\n match s.c with\n | hd::_ -> hd\n | [] -> raise Empty\n\nlet top_opt s =\n match s.c with\n | hd::_ -> Some hd\n | [] -> None\n\nlet is_empty s = (s.c = [])\n\nlet length s = s.len\n\nlet iter f s = List.iter f s.c\n\nlet fold f acc s = List.fold_left f acc s.c\n\n(** {1 Iterators} *)\n\nlet to_seq s = List.to_seq s.c\n\nlet add_seq q i = Seq.iter (fun x -> push x q) i\n\nlet of_seq g =\n let s = create() in\n add_seq s g;\n s\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Francois Pottier, projet Cristal, INRIA Rocquencourt *)\n(* Jeremie Dimino, Jane Street Europe *)\n(* *)\n(* Copyright 2002 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nexception Empty\n\ntype 'a cell =\n | Nil\n | Cons of { content: 'a; mutable next: 'a cell }\n\ntype 'a t = {\n mutable length: int;\n mutable first: 'a cell;\n mutable last: 'a cell\n}\n\nlet create () = {\n length = 0;\n first = Nil;\n last = Nil\n}\n\nlet clear q =\n q.length <- 0;\n q.first <- Nil;\n q.last <- Nil\n\nlet add x q =\n let cell = Cons {\n content = x;\n next = Nil\n } in\n match q.last with\n | Nil ->\n q.length <- 1;\n q.first <- cell;\n q.last <- cell\n | Cons last ->\n q.length <- q.length + 1;\n last.next <- cell;\n q.last <- cell\n\nlet push =\n add\n\nlet peek q =\n match q.first with\n | Nil -> raise Empty\n | Cons { content } -> content\n\nlet peek_opt q =\n match q.first with\n | Nil -> None\n | Cons { content } -> Some content\n\nlet top =\n peek\n\nlet take q =\n match q.first with\n | Nil -> raise Empty\n | Cons { content; next = Nil } ->\n clear q;\n content\n | Cons { content; next } ->\n q.length <- q.length - 1;\n q.first <- next;\n content\n\nlet take_opt q =\n match q.first with\n | Nil -> None\n | Cons { content; next = Nil } ->\n clear q;\n Some content\n | Cons { content; next } ->\n q.length <- q.length - 1;\n q.first <- next;\n Some content\n\nlet pop =\n take\n\nlet copy =\n let rec copy q_res prev cell =\n match cell with\n | Nil -> q_res.last <- prev; q_res\n | Cons { content; next } ->\n let res = Cons { content; next = Nil } in\n begin match prev with\n | Nil -> q_res.first <- res\n | Cons p -> p.next <- res\n end;\n copy q_res res next\n in\n fun q -> copy { length = q.length; first = Nil; last = Nil } Nil q.first\n\nlet is_empty q =\n q.length = 0\n\nlet length q =\n q.length\n\nlet iter =\n let rec iter f cell =\n match cell with\n | Nil -> ()\n | Cons { content; next } ->\n f content;\n iter f next\n in\n fun f q -> iter f q.first\n\nlet fold =\n let rec fold f accu cell =\n match cell with\n | Nil -> accu\n | Cons { content; next } ->\n let accu = f accu content in\n fold f accu next\n in\n fun f accu q -> fold f accu q.first\n\nlet transfer q1 q2 =\n if q1.length > 0 then\n match q2.last with\n | Nil ->\n q2.length <- q1.length;\n q2.first <- q1.first;\n q2.last <- q1.last;\n clear q1\n | Cons last ->\n q2.length <- q2.length + q1.length;\n last.next <- q1.first;\n q2.last <- q1.last;\n clear q1\n\n(** {1 Iterators} *)\n\nlet to_seq q =\n let rec aux c () = match c with\n | Nil -> Seq.Nil\n | Cons { content=x; next; } -> Seq.Cons (x, aux next)\n in\n aux q.first\n\nlet add_seq q i = Seq.iter (fun x -> push x q) i\n\nlet of_seq g =\n let q = create() in\n add_seq q g;\n q\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Pierre Weis and Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1999 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Extensible buffers *)\n\ntype t =\n {mutable buffer : bytes;\n mutable position : int;\n mutable length : int;\n initial_buffer : bytes}\n(* Invariants: all parts of the code preserve the invariants that:\n - [0 <= b.position <= b.length]\n - [b.length = Bytes.length b.buffer]\n\n Note in particular that [b.position = b.length] is legal,\n it means that the buffer is full and will have to be extended\n before any further addition. *)\n\nlet create n =\n let n = if n < 1 then 1 else n in\n let n = if n > Sys.max_string_length then Sys.max_string_length else n in\n let s = Bytes.create n in\n {buffer = s; position = 0; length = n; initial_buffer = s}\n\nlet contents b = Bytes.sub_string b.buffer 0 b.position\nlet to_bytes b = Bytes.sub b.buffer 0 b.position\n\nlet sub b ofs len =\n if ofs < 0 || len < 0 || ofs > b.position - len\n then invalid_arg \"Buffer.sub\"\n else Bytes.sub_string b.buffer ofs len\n\n\nlet blit src srcoff dst dstoff len =\n if len < 0 || srcoff < 0 || srcoff > src.position - len\n || dstoff < 0 || dstoff > (Bytes.length dst) - len\n then invalid_arg \"Buffer.blit\"\n else\n Bytes.unsafe_blit src.buffer srcoff dst dstoff len\n\n\nlet nth b ofs =\n if ofs < 0 || ofs >= b.position then\n invalid_arg \"Buffer.nth\"\n else Bytes.unsafe_get b.buffer ofs\n\n\nlet length b = b.position\n\nlet clear b = b.position <- 0\n\nlet reset b =\n b.position <- 0;\n b.buffer <- b.initial_buffer;\n b.length <- Bytes.length b.buffer\n\n(* [resize b more] ensures that [b.position + more <= b.length] holds\n by dynamically extending [b.buffer] if necessary -- and thus\n increasing [b.length].\n\n In particular, after [resize b more] is called, a direct access of\n size [more] at [b.position] will always be in-bounds, so that\n (unsafe_{get,set}) may be used for performance.\n*)\nlet resize b more =\n let old_pos = b.position in\n let old_len = b.length in\n let new_len = ref old_len in\n while old_pos + more > !new_len do new_len := 2 * !new_len done;\n if !new_len > Sys.max_string_length then begin\n if old_pos + more <= Sys.max_string_length\n then new_len := Sys.max_string_length\n else failwith \"Buffer.add: cannot grow buffer\"\n end;\n let new_buffer = Bytes.create !new_len in\n (* PR#6148: let's keep using [blit] rather than [unsafe_blit] in\n this tricky function that is slow anyway. *)\n Bytes.blit b.buffer 0 new_buffer 0 b.position;\n b.buffer <- new_buffer;\n b.length <- !new_len;\n assert (b.position + more <= b.length);\n assert (old_pos + more <= b.length);\n ()\n (* Note: there are various situations (preemptive threads, signals and\n gc finalizers) where OCaml code may be run asynchronously; in\n particular, there may be a race with another user of [b], changing\n its mutable fields in the middle of the [resize] call. The Buffer\n module does not provide any correctness guarantee if that happens,\n but we must still ensure that the datastructure invariants hold for\n memory-safety -- as we plan to use [unsafe_{get,set}].\n\n There are two potential allocation points in this function,\n [ref] and [Bytes.create], but all reads and writes to the fields\n of [b] happen before both of them or after both of them.\n\n We therefore assume that [b.position] may change at these allocations,\n and check that the [b.position + more <= b.length] postcondition\n holds for both values of [b.position], before or after the function\n is called. More precisely, the following invariants must hold if the\n function returns correctly, in addition to the usual buffer invariants:\n - [old(b.position) + more <= new(b.length)]\n - [new(b.position) + more <= new(b.length)]\n - [old(b.length) <= new(b.length)]\n\n Note: [b.position + more <= old(b.length)] does *not*\n hold in general, as it is precisely the case where you need\n to call [resize] to increase [b.length].\n\n Note: [assert] above does not mean that we know the conditions\n always hold, but that the function may return correctly\n only if they hold.\n\n Note: the other functions in this module does not need\n to be checked with this level of scrutiny, given that they\n read/write the buffer immediately after checking that\n [b.position + more <= b.length] hold or calling [resize].\n *)\n\nlet add_char b c =\n let pos = b.position in\n if pos >= b.length then resize b 1;\n Bytes.unsafe_set b.buffer pos c;\n b.position <- pos + 1\n\nlet uchar_utf_8_byte_length_max = 4\nlet uchar_utf_16_byte_length_max = 4\n\nlet rec add_utf_8_uchar b u =\n let pos = b.position in\n if pos >= b.length then resize b uchar_utf_8_byte_length_max;\n let n = Bytes.set_utf_8_uchar b.buffer pos u in\n if n = 0\n then (resize b uchar_utf_8_byte_length_max; add_utf_8_uchar b u)\n else (b.position <- pos + n)\n\nlet rec add_utf_16be_uchar b u =\n let pos = b.position in\n if pos >= b.length then resize b uchar_utf_16_byte_length_max;\n let n = Bytes.set_utf_16be_uchar b.buffer pos u in\n if n = 0\n then (resize b uchar_utf_16_byte_length_max; add_utf_16be_uchar b u)\n else (b.position <- pos + n)\n\nlet rec add_utf_16le_uchar b u =\n let pos = b.position in\n if pos >= b.length then resize b uchar_utf_16_byte_length_max;\n let n = Bytes.set_utf_16le_uchar b.buffer pos u in\n if n = 0\n then (resize b uchar_utf_16_byte_length_max; add_utf_16le_uchar b u)\n else (b.position <- pos + n)\n\nlet add_substring b s offset len =\n if offset < 0 || len < 0 || offset > String.length s - len\n then invalid_arg \"Buffer.add_substring/add_subbytes\";\n let new_position = b.position + len in\n if new_position > b.length then resize b len;\n Bytes.unsafe_blit_string s offset b.buffer b.position len;\n b.position <- new_position\n\nlet add_subbytes b s offset len =\n add_substring b (Bytes.unsafe_to_string s) offset len\n\nlet add_string b s =\n let len = String.length s in\n let new_position = b.position + len in\n if new_position > b.length then resize b len;\n Bytes.unsafe_blit_string s 0 b.buffer b.position len;\n b.position <- new_position\n\nlet add_bytes b s = add_string b (Bytes.unsafe_to_string s)\n\nlet add_buffer b bs =\n add_subbytes b bs.buffer 0 bs.position\n\n(* this (private) function could move into the standard library *)\nlet really_input_up_to ic buf ofs len =\n let rec loop ic buf ~already_read ~ofs ~to_read =\n if to_read = 0 then already_read\n else begin\n let r = input ic buf ofs to_read in\n if r = 0 then already_read\n else begin\n let already_read = already_read + r in\n let ofs = ofs + r in\n let to_read = to_read - r in\n loop ic buf ~already_read ~ofs ~to_read\n end\n end\n in loop ic buf ~already_read:0 ~ofs ~to_read:len\n\n\nlet unsafe_add_channel_up_to b ic len =\n if b.position + len > b.length then resize b len;\n let n = really_input_up_to ic b.buffer b.position len in\n (* The assertion below may fail in weird scenario where\n threaded/finalizer code, run asynchronously during the\n [really_input_up_to] call, races on the buffer; we don't ensure\n correctness in this case, but need to preserve the invariants for\n memory-safety (see discussion of [resize]). *)\n assert (b.position + n <= b.length);\n b.position <- b.position + n;\n n\n\nlet add_channel b ic len =\n if len < 0 || len > Sys.max_string_length then (* PR#5004 *)\n invalid_arg \"Buffer.add_channel\";\n let n = unsafe_add_channel_up_to b ic len in\n (* It is intentional that a consumer catching End_of_file\n will see the data written (see #6719, #7136). *)\n if n < len then raise End_of_file;\n ()\n\nlet output_buffer oc b =\n output oc b.buffer 0 b.position\n\nlet closing = function\n | '(' -> ')'\n | '{' -> '}'\n | _ -> assert false\n\n(* opening and closing: open and close characters, typically ( and )\n k: balance of opening and closing chars\n s: the string where we are searching\n start: the index where we start the search. *)\nlet advance_to_closing opening closing k s start =\n let rec advance k i lim =\n if i >= lim then raise Not_found else\n if s.[i] = opening then advance (k + 1) (i + 1) lim else\n if s.[i] = closing then\n if k = 0 then i else advance (k - 1) (i + 1) lim\n else advance k (i + 1) lim in\n advance k start (String.length s)\n\nlet advance_to_non_alpha s start =\n let rec advance i lim =\n if i >= lim then lim else\n match s.[i] with\n | 'a' .. 'z' | 'A' .. 'Z' | '0' .. '9' | '_' -> advance (i + 1) lim\n | _ -> i in\n advance start (String.length s)\n\n(* We are just at the beginning of an ident in s, starting at start. *)\nlet find_ident s start lim =\n if start >= lim then raise Not_found else\n match s.[start] with\n (* Parenthesized ident ? *)\n | '(' | '{' as c ->\n let new_start = start + 1 in\n let stop = advance_to_closing c (closing c) 0 s new_start in\n String.sub s new_start (stop - start - 1), stop + 1\n (* Regular ident *)\n | _ ->\n let stop = advance_to_non_alpha s (start + 1) in\n String.sub s start (stop - start), stop\n\n(* Substitute $ident, $(ident), or ${ident} in s,\n according to the function mapping f. *)\nlet add_substitute b f s =\n let lim = String.length s in\n let rec subst previous i =\n if i < lim then begin\n match s.[i] with\n | '$' as current when previous = '\\\\' ->\n add_char b current;\n subst ' ' (i + 1)\n | '$' ->\n let j = i + 1 in\n let ident, next_i = find_ident s j lim in\n add_string b (f ident);\n subst ' ' next_i\n | current when previous == '\\\\' ->\n add_char b '\\\\';\n add_char b current;\n subst ' ' (i + 1)\n | '\\\\' as current ->\n subst current (i + 1)\n | current ->\n add_char b current;\n subst current (i + 1)\n end else\n if previous = '\\\\' then add_char b previous in\n subst ' ' 0\n\nlet truncate b len =\n if len < 0 || len > length b then\n invalid_arg \"Buffer.truncate\"\n else\n b.position <- len\n\n(** {1 Iterators} *)\n\nlet to_seq b =\n let rec aux i () =\n (* Note that b.position is not a constant and cannot be lifted out of aux *)\n if i >= b.position then Seq.Nil\n else\n let x = Bytes.unsafe_get b.buffer i in\n Seq.Cons (x, aux (i+1))\n in\n aux 0\n\nlet to_seqi b =\n let rec aux i () =\n (* Note that b.position is not a constant and cannot be lifted out of aux *)\n if i >= b.position then Seq.Nil\n else\n let x = Bytes.unsafe_get b.buffer i in\n Seq.Cons ((i,x), aux (i+1))\n in\n aux 0\n\nlet add_seq b seq = Seq.iter (add_char b) seq\n\nlet of_seq i =\n let b = create 32 in\n add_seq b i;\n b\n\n(** {6 Binary encoding of integers} *)\n\nexternal unsafe_set_int8 : bytes -> int -> int -> unit = \"%bytes_unsafe_set\"\nexternal unsafe_set_int16 : bytes -> int -> int -> unit = \"%caml_bytes_set16u\"\nexternal unsafe_set_int32 : bytes -> int -> int32 -> unit = \"%caml_bytes_set32u\"\nexternal unsafe_set_int64 : bytes -> int -> int64 -> unit = \"%caml_bytes_set64u\"\nexternal swap16 : int -> int = \"%bswap16\"\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\n\n\nlet add_int8 b x =\n let new_position = b.position + 1 in\n if new_position > b.length then resize b 1;\n unsafe_set_int8 b.buffer b.position x;\n b.position <- new_position\n\nlet add_int16_ne b x =\n let new_position = b.position + 2 in\n if new_position > b.length then resize b 2;\n unsafe_set_int16 b.buffer b.position x;\n b.position <- new_position\n\nlet add_int32_ne b x =\n let new_position = b.position + 4 in\n if new_position > b.length then resize b 4;\n unsafe_set_int32 b.buffer b.position x;\n b.position <- new_position\n\nlet add_int64_ne b x =\n let new_position = b.position + 8 in\n if new_position > b.length then resize b 8;\n unsafe_set_int64 b.buffer b.position x;\n b.position <- new_position\n\nlet add_int16_le b x =\n add_int16_ne b (if Sys.big_endian then swap16 x else x)\n\nlet add_int16_be b x =\n add_int16_ne b (if Sys.big_endian then x else swap16 x)\n\nlet add_int32_le b x =\n add_int32_ne b (if Sys.big_endian then swap32 x else x)\n\nlet add_int32_be b x =\n add_int32_ne b (if Sys.big_endian then x else swap32 x)\n\nlet add_int64_le b x =\n add_int64_ne b (if Sys.big_endian then swap64 x else x)\n\nlet add_int64_be b x =\n add_int64_ne b (if Sys.big_endian then x else swap64 x)\n\nlet add_uint8 = add_int8\nlet add_uint16_ne = add_int16_ne\nlet add_uint16_le = add_int16_le\nlet add_uint16_be = add_int16_be\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy and Pierre Weis, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nopen CamlinternalFormatBasics\nopen CamlinternalFormat\n\nlet kfprintf k o (Format (fmt, _)) =\n make_printf (fun acc -> output_acc o acc; k o) End_of_acc fmt\nlet kbprintf k b (Format (fmt, _)) =\n make_printf (fun acc -> bufput_acc b acc; k b) End_of_acc fmt\nlet ikfprintf k oc (Format (fmt, _)) =\n make_iprintf k oc fmt\nlet ikbprintf = ikfprintf\n\nlet fprintf oc fmt = kfprintf ignore oc fmt\nlet bprintf b fmt = kbprintf ignore b fmt\nlet ifprintf oc fmt = ikfprintf ignore oc fmt\nlet ibprintf b fmt = ikbprintf ignore b fmt\nlet printf fmt = fprintf stdout fmt\nlet eprintf fmt = fprintf stderr fmt\n\nlet ksprintf k (Format (fmt, _)) =\n let k' acc =\n let buf = Buffer.create 64 in\n strput_acc buf acc;\n k (Buffer.contents buf) in\n make_printf k' End_of_acc fmt\n\nlet sprintf fmt = ksprintf (fun s -> s) fmt\n\nlet kprintf = ksprintf\n","open! Base\n\nmodule Bigstring0 = struct\n type t =\n ( char\n , Stdlib.Bigarray.int8_unsigned_elt\n , Stdlib.Bigarray.c_layout )\n Stdlib.Bigarray.Array1.t\nend\n\nmodule Array1 = struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) Stdlib.Bigarray.Array1.t\n\n external get : ('a, 'b, 'c) t -> int -> 'a = \"%caml_ba_ref_1\"\n external set : ('a, 'b, 'c) t -> int -> 'a -> unit = \"%caml_ba_set_1\"\n external unsafe_get : ('a, 'b, 'c) t -> int -> 'a = \"%caml_ba_unsafe_ref_1\"\n external unsafe_set : ('a, 'b, 'c) t -> int -> 'a -> unit = \"%caml_ba_unsafe_set_1\"\n external dim : ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\nend\n\ninclude Bigstring0\n\nexternal aux_create\n : max_mem_waiting_gc_in_bytes:int\n -> size:int\n -> t\n = \"bigstring_alloc\"\n\nlet sprintf = Printf.sprintf\n\n(* One needs to use [Caml.Sys.word_size] so that its value is known at compile-time. *)\nlet arch_sixtyfour = Caml.Sys.word_size = 64\nlet arch_big_endian = Caml.Sys.big_endian\nlet not_on_32bit = Caml.Sys.word_size > 32\n\nlet create ?max_mem_waiting_gc_in_bytes size =\n let max_mem_waiting_gc_in_bytes =\n Option.value max_mem_waiting_gc_in_bytes ~default:(-1)\n in\n (* This check is important because [aux_create ~size:(-1)] raises [Out_of_memory], which\n could be confusing during debugging. *)\n if size < 0 then invalid_arg (sprintf \"create: size = %d < 0\" size);\n aux_create ~max_mem_waiting_gc_in_bytes ~size\n;;\n\nlet length = Array1.dim\n\nexternal is_mmapped : t -> bool = \"bigstring_is_mmapped_stub\" [@@noalloc]\n\nlet init n ~f =\n let t = create n in\n for i = 0 to n - 1 do\n t.{i} <- f i\n done;\n t\n;;\n\nlet check_args ~loc ~pos ~len (bstr : t) =\n if pos < 0 then invalid_arg (loc ^ \": pos < 0\");\n if len < 0 then invalid_arg (loc ^ \": len < 0\");\n let bstr_len = length bstr in\n (* Be careful with overflow! We could have bogons like [pos = Int.max_value] or [len =\n Int.max_value] passed by the user. *)\n if bstr_len - pos < len\n then invalid_arg (sprintf \"Bigstring.%s: length(bstr) < pos + len\" loc)\n;;\n\nlet get_opt_len bstr ~pos = function\n | Some len -> len\n | None -> length bstr - pos\n;;\n\n(* Blitting *)\n\nexternal unsafe_blit\n : src:t\n -> src_pos:int\n -> dst:t\n -> dst_pos:int\n -> len:int\n -> unit\n = \"bigstring_blit_stub\"\n[@@noalloc]\n\n(* Exposing the external version of get/set supports better inlining. *)\nexternal get : t -> int -> char = \"%caml_ba_ref_1\"\nexternal set : t -> int -> char -> unit = \"%caml_ba_set_1\"\n\nmodule Bigstring_sequence = struct\n type nonrec t = t\n\n let create ~len = create len\n let length = length\nend\n\nmodule Bytes_sequence = struct\n type t = bytes\n\n let create ~len = Bytes.create len\n let length = Bytes.length\nend\n\ninclude Blit.Make (struct\n include Bigstring_sequence\n\n let unsafe_blit = unsafe_blit\n end)\n\nmodule From_bytes =\n Blit.Make_distinct\n (Bytes_sequence)\n (struct\n external unsafe_blit\n : src:bytes\n -> src_pos:int\n -> dst:t\n -> dst_pos:int\n -> len:int\n -> unit\n = \"bigstring_blit_bytes_bigstring_stub\"\n [@@noalloc]\n\n include Bigstring_sequence\n end)\n\nmodule To_bytes =\n Blit.Make_distinct\n (Bigstring_sequence)\n (struct\n external unsafe_blit\n : src:t\n -> src_pos:int\n -> dst:bytes\n -> dst_pos:int\n -> len:int\n -> unit\n = \"bigstring_blit_bigstring_bytes_stub\"\n [@@noalloc]\n\n include Bytes_sequence\n end)\n\nmodule From_string =\n Blit.Make_distinct\n (struct\n type t = string\n\n let length = String.length\n end)\n (struct\n external unsafe_blit\n : src:string\n -> src_pos:int\n -> dst:t\n -> dst_pos:int\n -> len:int\n -> unit\n = \"bigstring_blit_string_bigstring_stub\"\n [@@noalloc]\n\n include Bigstring_sequence\n end)\n\nmodule To_string = struct\n include To_bytes\n include Blit.Make_to_string (Bigstring0) (To_bytes)\nend\n\nlet of_string = From_string.subo\nlet of_bytes = From_bytes.subo\nlet to_string = To_string.subo\nlet to_bytes = To_bytes.subo\nlet sexp_of_t t = Sexp.Atom (to_string t)\n\nlet t_of_sexp : Sexp.t -> t = function\n | Atom str -> of_string str\n | List _ as sexp ->\n Sexplib0.Sexp_conv.of_sexp_error \"bigstring_of_sexp: atom needed\" sexp\n;;\n\nlet copy t : t = sub t ~pos:0 ~len:(length t)\n\nlet concat =\n let append ~src ~dst ~dst_pos_ref =\n let len = length src in\n let src_pos = 0 in\n let dst_pos = !dst_pos_ref in\n blit ~dst ~dst_pos ~src ~src_pos ~len;\n dst_pos_ref := dst_pos + len\n in\n fun ?sep list ->\n match list with\n | [] -> create 0\n | head :: tail ->\n let head_len = length head in\n let sep_len = Option.value_map sep ~f:length ~default:0 in\n let tail_count = List.length tail in\n let len =\n head_len + (sep_len * tail_count) + List.sum (module Int) tail ~f:length\n in\n let dst = create len in\n let dst_pos_ref = ref 0 in\n append ~src:head ~dst ~dst_pos_ref;\n List.iter tail ~f:(fun src ->\n (match sep with\n | None -> ()\n | Some sep -> append ~src:sep ~dst ~dst_pos_ref);\n append ~src ~dst ~dst_pos_ref);\n assert (!dst_pos_ref = len);\n dst\n;;\n\nexternal unsafe_memset\n : t\n -> pos:int\n -> len:int\n -> char\n -> unit\n = \"bigstring_memset_stub\"\n[@@noalloc]\n\nlet memset t ~pos ~len c =\n Ordered_collection_common.check_pos_len_exn ~pos ~len ~total_length:(length t);\n unsafe_memset t ~pos ~len c\n;;\n\n(* Comparison *)\n\nexternal unsafe_memcmp\n : t\n -> pos1:int\n -> t\n -> pos2:int\n -> len:int\n -> int\n = \"bigstring_memcmp_stub\"\n[@@noalloc]\n\nlet memcmp t1 ~pos1 t2 ~pos2 ~len =\n Ordered_collection_common.check_pos_len_exn ~pos:pos1 ~len ~total_length:(length t1);\n Ordered_collection_common.check_pos_len_exn ~pos:pos2 ~len ~total_length:(length t2);\n unsafe_memcmp t1 ~pos1 t2 ~pos2 ~len\n;;\n\nlet compare t1 t2 =\n if phys_equal t1 t2\n then 0\n else (\n let len1 = length t1 in\n let len2 = length t2 in\n let len = Int.min len1 len2 in\n match unsafe_memcmp t1 ~pos1:0 t2 ~pos2:0 ~len with\n | 0 -> if len1 < len2 then -1 else if len1 > len2 then 1 else 0\n | n -> n)\n;;\n\nexternal internalhash_fold_bigstring\n : Hash.state\n -> t\n -> Hash.state\n = \"internalhash_fold_bigstring\"\n[@@noalloc]\n\nlet _making_sure_the_C_binding_takes_an_int (x : Hash.state) = (x :> int)\nlet hash_fold_t = internalhash_fold_bigstring\nlet hash = Ppx_hash_lib.Std.Hash.of_fold hash_fold_t\n\ntype t_frozen = t [@@deriving compare, hash, sexp]\n\nlet equal t1 t2 =\n if phys_equal t1 t2\n then true\n else (\n let len1 = length t1 in\n let len2 = length t2 in\n Int.equal len1 len2 && Int.equal (unsafe_memcmp t1 ~pos1:0 t2 ~pos2:0 ~len:len1) 0)\n;;\n\n(* Search *)\n\nexternal unsafe_find : t -> char -> pos:int -> len:int -> int = \"bigstring_find\"\n[@@noalloc]\n\nlet find ?(pos = 0) ?len chr bstr =\n let len = get_opt_len bstr ~pos len in\n check_args ~loc:\"find\" ~pos ~len bstr;\n let res = unsafe_find bstr chr ~pos ~len in\n if res < 0 then None else Some res\n;;\n\n(* vim: set filetype=ocaml : *)\n\n(* Binary-packing like accessors *)\n\nexternal int32_of_int : int -> int32 = \"%int32_of_int\"\nexternal int32_to_int : int32 -> int = \"%int32_to_int\"\nexternal int64_of_int : int -> int64 = \"%int64_of_int\"\nexternal int64_to_int : int64 -> int = \"%int64_to_int\"\nexternal swap16 : int -> int = \"%bswap16\"\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\nexternal unsafe_get_16 : t -> int -> int = \"%caml_bigstring_get16u\"\nexternal unsafe_get_32 : t -> int -> int32 = \"%caml_bigstring_get32u\"\nexternal unsafe_get_64 : t -> int -> int64 = \"%caml_bigstring_get64u\"\nexternal unsafe_set_16 : t -> int -> int -> unit = \"%caml_bigstring_set16u\"\nexternal unsafe_set_32 : t -> int -> int32 -> unit = \"%caml_bigstring_set32u\"\nexternal unsafe_set_64 : t -> int -> int64 -> unit = \"%caml_bigstring_set64u\"\n\nlet get_16 (t : t) (pos : int) : int =\n check_args ~loc:\"get_16\" ~pos ~len:2 t;\n unsafe_get_16 t pos\n;;\n\nlet get_32 (t : t) (pos : int) : int32 =\n check_args ~loc:\"get_32\" ~pos ~len:4 t;\n unsafe_get_32 t pos\n;;\n\nlet get_64 (t : t) (pos : int) : int64 =\n check_args ~loc:\"get_64\" ~pos ~len:8 t;\n unsafe_get_64 t pos\n;;\n\nlet set_16_trunc (t : t) (pos : int) (v : int) : unit =\n check_args ~loc:\"set_16\" ~pos ~len:2 t;\n unsafe_set_16 t pos v\n;;\n\nlet set_32 (t : t) (pos : int) (v : int32) : unit =\n check_args ~loc:\"set_32\" ~pos ~len:4 t;\n unsafe_set_32 t pos v\n;;\n\nlet set_64 (t : t) (pos : int) (v : int64) : unit =\n check_args ~loc:\"set_64\" ~pos ~len:8 t;\n unsafe_set_64 t pos v\n;;\n\nlet sign_extend_16 u = (u lsl (Int.num_bits - 16)) asr (Int.num_bits - 16)\n\nlet check_valid_uint16 x ~loc =\n if x < 0 || x > 0xFFFF\n then invalid_arg (sprintf \"%s: %d is not a valid unsigned 16-bit integer\" loc x)\n;;\n\nlet check_valid_int16 x ~loc =\n if x < -0x8000 || x > 0x7FFF\n then invalid_arg (sprintf \"%s: %d is not a valid (signed) 16-bit integer\" loc x)\n;;\n\nlet check_valid_uint8 x ~loc =\n if x < 0 || x > 0xFF\n then invalid_arg (sprintf \"%s: %d is not a valid unsigned 8-bit integer\" loc x)\n;;\n\nlet check_valid_int8 x ~loc =\n if x < -0x80 || x > 0x7F\n then invalid_arg (sprintf \"%s: %d is not a valid (signed) 8-bit integer\" loc x)\n;;\n\nlet check_valid_int32 =\n if not arch_sixtyfour\n then fun _ ~loc:_ -> ()\n else\n fun x ~loc ->\n if x >= -1 lsl 31 && x < 1 lsl 31\n then ()\n else invalid_arg (sprintf \"%s: %d is not a valid (signed) 32-bit integer\" loc x)\n;;\n\nlet check_valid_uint32 =\n if not arch_sixtyfour\n then\n fun x ~loc ->\n if x >= 0\n then ()\n else invalid_arg (sprintf \"%s: %d is not a valid unsigned 32-bit integer\" loc x)\n else\n fun x ~loc ->\n if x >= 0 && x < 1 lsl 32\n then ()\n else invalid_arg (sprintf \"%s: %d is not a valid unsigned 32-bit integer\" loc x)\n;;\n\nlet check_valid_uint64 x ~loc =\n if x >= 0\n then ()\n else invalid_arg (sprintf \"%s: %d is not a valid unsigned 64-bit integer\" loc x)\n;;\n\nlet unsafe_read_int16 t ~pos = sign_extend_16 (unsafe_get_16 t pos)\nlet unsafe_read_int16_swap t ~pos = sign_extend_16 (swap16 (unsafe_get_16 t pos))\nlet unsafe_write_int16 t ~pos x = unsafe_set_16 t pos x\nlet unsafe_write_int16_swap t ~pos x = unsafe_set_16 t pos (swap16 x)\nlet read_int16 t ~pos = sign_extend_16 (get_16 t pos)\nlet read_int16_swap t ~pos = sign_extend_16 (swap16 (get_16 t pos))\n\nlet write_int16_exn t ~pos x =\n check_valid_int16 x ~loc:\"Bigstring.write_int16\";\n set_16_trunc t pos x\n;;\n\nlet write_int16_swap_exn t ~pos x =\n (* Omit \"_swap\" from the error message it's bi-endian. *)\n check_valid_int16 x ~loc:\"Bigstring.write_int16\";\n set_16_trunc t pos (swap16 x)\n;;\n\nlet unsafe_read_uint16 t ~pos = unsafe_get_16 t pos\nlet unsafe_read_uint16_swap t ~pos = swap16 (unsafe_get_16 t pos)\nlet unsafe_write_uint16 t ~pos x = unsafe_set_16 t pos x\nlet unsafe_write_uint16_swap t ~pos x = unsafe_set_16 t pos (swap16 x)\nlet read_uint16 t ~pos = get_16 t pos\nlet read_uint16_swap t ~pos = swap16 (get_16 t pos)\n\nlet write_uint16_exn t ~pos x =\n check_valid_uint16 x ~loc:\"Bigstring.write_uint16\";\n set_16_trunc t pos x\n;;\n\nlet write_uint16_swap_exn t ~pos x =\n (* Omit \"_swap\" from the error message it's bi-endian. *)\n check_valid_uint16 x ~loc:\"Bigstring.write_uint16\";\n set_16_trunc t pos (swap16 x)\n;;\n\nlet unsafe_read_int32_int t ~pos = int32_to_int (unsafe_get_32 t pos)\nlet unsafe_read_int32_int_swap t ~pos = int32_to_int (swap32 (unsafe_get_32 t pos))\nlet unsafe_read_int32 t ~pos = unsafe_get_32 t pos\nlet unsafe_read_int32_swap t ~pos = swap32 (unsafe_get_32 t pos)\nlet unsafe_write_int32 t ~pos x = unsafe_set_32 t pos x\nlet unsafe_write_int32_swap t ~pos x = unsafe_set_32 t pos (swap32 x)\nlet unsafe_write_int32_int t ~pos x = unsafe_set_32 t pos (int32_of_int x)\nlet unsafe_write_int32_int_swap t ~pos x = unsafe_set_32 t pos (swap32 (int32_of_int x))\nlet read_int32_int t ~pos = int32_to_int (get_32 t pos)\nlet read_int32_int_swap t ~pos = int32_to_int (swap32 (get_32 t pos))\nlet read_int32 t ~pos = get_32 t pos\nlet read_int32_swap t ~pos = swap32 (get_32 t pos)\nlet write_int32 t ~pos x = set_32 t pos x\nlet write_int32_swap t ~pos x = set_32 t pos (swap32 x)\n\nlet write_int32_int_exn t ~pos x =\n check_valid_int32 x ~loc:\"Bigstring.write_int32_int\";\n set_32 t pos (int32_of_int x)\n;;\n\nlet write_int32_int_swap_exn t ~pos x =\n (* Omit \"_swap\" from the error message it's bi-endian. *)\n check_valid_int32 x ~loc:\"Bigstring.write_int32_int\";\n set_32 t pos (swap32 (int32_of_int x))\n;;\n\nlet unsafe_read_int64_int t ~pos = int64_to_int (unsafe_get_64 t pos)\nlet unsafe_read_int64_int_swap t ~pos = int64_to_int (swap64 (unsafe_get_64 t pos))\nlet unsafe_read_int64 t ~pos = unsafe_get_64 t pos\nlet unsafe_read_int64_swap t ~pos = swap64 (unsafe_get_64 t pos)\nlet unsafe_write_int64 t ~pos x = unsafe_set_64 t pos x\nlet unsafe_write_int64_swap t ~pos x = unsafe_set_64 t pos (swap64 x)\nlet unsafe_write_int64_int t ~pos x = unsafe_set_64 t pos (int64_of_int x)\nlet unsafe_write_int64_int_swap t ~pos x = unsafe_set_64 t pos (swap64 (int64_of_int x))\nlet read_int64_int t ~pos = int64_to_int (get_64 t pos)\nlet read_int64_int_swap t ~pos = int64_to_int (swap64 (get_64 t pos))\nlet read_int64 t ~pos = get_64 t pos\nlet read_int64_swap t ~pos = swap64 (get_64 t pos)\nlet write_int64 t ~pos x = set_64 t pos x\nlet write_int64_swap t ~pos x = set_64 t pos (swap64 x)\nlet write_int64_int t ~pos x = set_64 t pos (int64_of_int x)\nlet write_int64_int_swap t ~pos x = set_64 t pos (swap64 (int64_of_int x))\n\nlet unsafe_get_int16_be =\n if arch_big_endian then unsafe_read_int16 else unsafe_read_int16_swap\n;;\n\nlet unsafe_get_int16_le =\n if arch_big_endian then unsafe_read_int16_swap else unsafe_read_int16\n;;\n\nlet unsafe_get_uint16_be =\n if arch_big_endian then unsafe_read_uint16 else unsafe_read_uint16_swap\n;;\n\nlet unsafe_get_uint16_le =\n if arch_big_endian then unsafe_read_uint16_swap else unsafe_read_uint16\n;;\n\nlet get_int16_be = if arch_big_endian then read_int16 else read_int16_swap\nlet get_int16_le = if arch_big_endian then read_int16_swap else read_int16\nlet get_uint16_be = if arch_big_endian then read_uint16 else read_uint16_swap\nlet get_uint16_le = if arch_big_endian then read_uint16_swap else read_uint16\n\nlet unsafe_set_int16_be =\n if arch_big_endian then unsafe_write_int16 else unsafe_write_int16_swap\n;;\n\nlet unsafe_set_int16_le =\n if arch_big_endian then unsafe_write_int16_swap else unsafe_write_int16\n;;\n\nlet unsafe_set_uint16_be =\n if arch_big_endian then unsafe_write_uint16 else unsafe_write_uint16_swap\n;;\n\nlet unsafe_set_uint16_le =\n if arch_big_endian then unsafe_write_uint16_swap else unsafe_write_uint16\n;;\n\nlet set_int16_be_exn = if arch_big_endian then write_int16_exn else write_int16_swap_exn\nlet set_int16_le_exn = if arch_big_endian then write_int16_swap_exn else write_int16_exn\n\nlet set_uint16_be_exn =\n if arch_big_endian then write_uint16_exn else write_uint16_swap_exn\n;;\n\nlet set_uint16_le_exn =\n if arch_big_endian then write_uint16_swap_exn else write_uint16_exn\n;;\n\nlet unsafe_get_int32_t_be =\n if arch_big_endian then unsafe_read_int32 else unsafe_read_int32_swap\n;;\n\nlet unsafe_get_int32_t_le =\n if arch_big_endian then unsafe_read_int32_swap else unsafe_read_int32\n;;\n\nlet unsafe_set_int32_t_be =\n if arch_big_endian then unsafe_write_int32 else unsafe_write_int32_swap\n;;\n\nlet unsafe_set_int32_t_le =\n if arch_big_endian then unsafe_write_int32_swap else unsafe_write_int32\n;;\n\nlet get_int32_t_be = if arch_big_endian then read_int32 else read_int32_swap\nlet get_int32_t_le = if arch_big_endian then read_int32_swap else read_int32\nlet set_int32_t_be = if arch_big_endian then write_int32 else write_int32_swap\nlet set_int32_t_le = if arch_big_endian then write_int32_swap else write_int32\n\nlet unsafe_get_int32_be =\n if arch_big_endian then unsafe_read_int32_int else unsafe_read_int32_int_swap\n;;\n\nlet unsafe_get_int32_le =\n if arch_big_endian then unsafe_read_int32_int_swap else unsafe_read_int32_int\n;;\n\nlet unsafe_set_int32_be =\n if arch_big_endian then unsafe_write_int32_int else unsafe_write_int32_int_swap\n;;\n\nlet unsafe_set_int32_le =\n if arch_big_endian then unsafe_write_int32_int_swap else unsafe_write_int32_int\n;;\n\nlet get_int32_be = if arch_big_endian then read_int32_int else read_int32_int_swap\nlet get_int32_le = if arch_big_endian then read_int32_int_swap else read_int32_int\n\nlet set_int32_be_exn =\n if arch_big_endian then write_int32_int_exn else write_int32_int_swap_exn\n;;\n\nlet set_int32_le_exn =\n if arch_big_endian then write_int32_int_swap_exn else write_int32_int_exn\n;;\n\nlet unsafe_get_int64_be_trunc =\n if arch_big_endian then unsafe_read_int64_int else unsafe_read_int64_int_swap\n;;\n\nlet unsafe_get_int64_le_trunc =\n if arch_big_endian then unsafe_read_int64_int_swap else unsafe_read_int64_int\n;;\n\nlet unsafe_set_int64_be =\n if arch_big_endian then unsafe_write_int64_int else unsafe_write_int64_int_swap\n;;\n\nlet unsafe_set_int64_le =\n if arch_big_endian then unsafe_write_int64_int_swap else unsafe_write_int64_int\n;;\n\nlet get_int64_be_trunc = if arch_big_endian then read_int64_int else read_int64_int_swap\nlet get_int64_le_trunc = if arch_big_endian then read_int64_int_swap else read_int64_int\nlet set_int64_be = if arch_big_endian then write_int64_int else write_int64_int_swap\nlet set_int64_le = if arch_big_endian then write_int64_int_swap else write_int64_int\n\nlet unsafe_get_int64_t_be =\n if arch_big_endian then unsafe_read_int64 else unsafe_read_int64_swap\n;;\n\nlet unsafe_get_int64_t_le =\n if arch_big_endian then unsafe_read_int64_swap else unsafe_read_int64\n;;\n\nlet unsafe_set_int64_t_be =\n if arch_big_endian then unsafe_write_int64 else unsafe_write_int64_swap\n;;\n\nlet unsafe_set_int64_t_le =\n if arch_big_endian then unsafe_write_int64_swap else unsafe_write_int64\n;;\n\nlet get_int64_t_be = if arch_big_endian then read_int64 else read_int64_swap\nlet get_int64_t_le = if arch_big_endian then read_int64_swap else read_int64\nlet set_int64_t_be = if arch_big_endian then write_int64 else write_int64_swap\nlet set_int64_t_le = if arch_big_endian then write_int64_swap else write_int64\n\nlet int64_conv_error () =\n failwith \"unsafe_read_int64: value cannot be represented unboxed!\"\n;;\n\nlet uint64_conv_error () =\n failwith \"unsafe_read_uint64: value cannot be represented unboxed!\"\n;;\n\n(* [Poly] is required so that we can compare unboxed [int64]. *)\nlet int64_to_int_exn n =\n if arch_sixtyfour\n then\n if Poly.(n >= -0x4000_0000_0000_0000L && n < 0x4000_0000_0000_0000L)\n then int64_to_int n\n else int64_conv_error ()\n else if Poly.(n >= -0x0000_0000_4000_0000L && n < 0x0000_0000_4000_0000L)\n then int64_to_int n\n else int64_conv_error ()\n;;\n\nlet uint64_to_int_exn n =\n if arch_sixtyfour\n then\n if Poly.(n >= 0L && n < 0x4000_0000_0000_0000L)\n then int64_to_int n\n else uint64_conv_error ()\n else if Poly.(n >= 0L && n < 0x0000_0000_4000_0000L)\n then int64_to_int n\n else uint64_conv_error ()\n;;\n\nlet unsafe_get_int64_be_exn t ~pos = int64_to_int_exn (unsafe_get_int64_t_be t ~pos)\nlet unsafe_get_int64_le_exn t ~pos = int64_to_int_exn (unsafe_get_int64_t_le t ~pos)\nlet get_int64_be_exn t ~pos = int64_to_int_exn (get_int64_t_be t ~pos)\nlet get_int64_le_exn t ~pos = int64_to_int_exn (get_int64_t_le t ~pos)\nlet unsafe_get_uint64_be_exn t ~pos = uint64_to_int_exn (unsafe_get_int64_t_be t ~pos)\nlet unsafe_get_uint64_le_exn t ~pos = uint64_to_int_exn (unsafe_get_int64_t_le t ~pos)\nlet get_uint64_be_exn t ~pos = uint64_to_int_exn (get_int64_t_be t ~pos)\nlet get_uint64_le_exn t ~pos = uint64_to_int_exn (get_int64_t_le t ~pos)\nlet unsafe_set_uint64_be = unsafe_set_int64_be\nlet unsafe_set_uint64_le = unsafe_set_int64_le\n\nlet set_uint64_be_exn t ~pos n =\n check_valid_uint64 ~loc:\"Bigstring.set_uint64_be_exn\" n;\n set_int64_be t ~pos n\n;;\n\nlet set_uint64_le_exn t ~pos n =\n check_valid_uint64 ~loc:\"Bigstring.set_uint64_le_exn\" n;\n set_int64_le t ~pos n\n;;\n\n(* Type annotations on the [t]s are important here: in order for the compiler to generate\n optimized code, it needs to know the fully instantiated type of the bigarray. This is\n because the type of the bigarray encodes the element kind and the layout of the\n bigarray. Without the annotation the compiler generates a C call to the generic access\n functions. *)\nlet unsafe_set_uint8 (t : t) ~pos n = Array1.unsafe_set t pos (Char.unsafe_of_int n)\n\nlet unsafe_set_int8 (t : t) ~pos n =\n (* In all the set functions where there are these tests, it looks like the test could be\n removed, since they are only changing the values of the bytes that are not\n written. *)\n let n = if n < 0 then n + 256 else n in\n Array1.unsafe_set t pos (Char.unsafe_of_int n)\n;;\n\nlet unsafe_get_uint8 (t : t) ~pos = Char.to_int (Array1.unsafe_get t pos)\n\nlet unsafe_get_int8 (t : t) ~pos =\n let n = Char.to_int (Array1.unsafe_get t pos) in\n if n >= 128 then n - 256 else n\n;;\n\nlet set_uint8_exn (t : t) ~pos n =\n check_valid_uint8 ~loc:\"Bigstring.set_uint8_exn\" n;\n Array1.set t pos (Char.unsafe_of_int n)\n;;\n\nlet set_int8_exn (t : t) ~pos n =\n check_valid_int8 ~loc:\"Bigstring.set_int8_exn\" n;\n let n = if n < 0 then n + 256 else n in\n Array1.set t pos (Char.unsafe_of_int n)\n;;\n\nlet get_uint8 (t : t) ~pos = Char.to_int (Array1.get t pos)\n\nlet get_int8 (t : t) ~pos =\n let n = Char.to_int (Array1.get t pos) in\n if n >= 128 then n - 256 else n\n;;\n\nlet unsafe_set_uint32_le t ~pos n =\n let n = if not_on_32bit && n >= 1 lsl 31 then n - (1 lsl 32) else n in\n unsafe_set_int32_le t ~pos n\n;;\n\nlet unsafe_set_uint32_be t ~pos n =\n let n = if not_on_32bit && n >= 1 lsl 31 then n - (1 lsl 32) else n in\n unsafe_set_int32_be t ~pos n\n;;\n\nlet unsafe_get_uint32_le t ~pos =\n let n = unsafe_get_int32_le t ~pos in\n if not_on_32bit && n < 0 then n + (1 lsl 32) else n\n;;\n\nlet unsafe_get_uint32_be t ~pos =\n let n = unsafe_get_int32_be t ~pos in\n if not_on_32bit && n < 0 then n + (1 lsl 32) else n\n;;\n\nlet set_uint32_le_exn t ~pos n =\n check_valid_uint32 ~loc:\"Bigstring.set_uint32_le_exn\" n;\n let n = if not_on_32bit && n >= 1 lsl 31 then n - (1 lsl 32) else n in\n set_int32_le_exn t ~pos n\n;;\n\nlet set_uint32_be_exn t ~pos n =\n check_valid_uint32 ~loc:\"Bigstring.set_uint32_be_exn\" n;\n let n = if not_on_32bit && n >= 1 lsl 31 then n - (1 lsl 32) else n in\n set_int32_be_exn t ~pos n\n;;\n\nlet get_uint32_le t ~pos =\n let n = get_int32_le t ~pos in\n if not_on_32bit && n < 0 then n + (1 lsl 32) else n\n;;\n\nlet get_uint32_be t ~pos =\n let n = get_int32_be t ~pos in\n if not_on_32bit && n < 0 then n + (1 lsl 32) else n\n;;\n\nmodule Private = struct\n let sign_extend_16 = sign_extend_16\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Para, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype key = string\ntype doc = string\ntype usage_msg = string\ntype anon_fun = (string -> unit)\n\ntype spec =\n | Unit of (unit -> unit) (* Call the function with unit argument *)\n | Bool of (bool -> unit) (* Call the function with a bool argument *)\n | Set of bool ref (* Set the reference to true *)\n | Clear of bool ref (* Set the reference to false *)\n | String of (string -> unit) (* Call the function with a string argument *)\n | Set_string of string ref (* Set the reference to the string argument *)\n | Int of (int -> unit) (* Call the function with an int argument *)\n | Set_int of int ref (* Set the reference to the int argument *)\n | Float of (float -> unit) (* Call the function with a float argument *)\n | Set_float of float ref (* Set the reference to the float argument *)\n | Tuple of spec list (* Take several arguments according to the\n spec list *)\n | Symbol of string list * (string -> unit)\n (* Take one of the symbols as argument and\n call the function with the symbol. *)\n | Rest of (string -> unit) (* Stop interpreting keywords and call the\n function with each remaining argument *)\n | Rest_all of (string list -> unit)\n (* Stop interpreting keywords and call the\n function with all remaining arguments. *)\n | Expand of (string -> string array) (* If the remaining arguments to process\n are of the form\n [[\"-foo\"; \"arg\"] @ rest] where \"foo\"\n is registered as [Expand f], then the\n arguments [f \"arg\" @ rest] are\n processed. Only allowed in\n [parse_and_expand_argv_dynamic]. *)\n\nexception Bad of string\nexception Help of string\n\ntype error =\n | Unknown of string\n | Wrong of string * string * string (* option, actual, expected *)\n | Missing of string\n | Message of string\n\nexception Stop of error (* used internally *)\n\nopen Printf\n\nlet rec assoc3 x l =\n match l with\n | [] -> raise Not_found\n | (y1, y2, _) :: _ when y1 = x -> y2\n | _ :: t -> assoc3 x t\n\n\nlet split s =\n let i = String.index s '=' in\n let len = String.length s in\n String.sub s 0 i, String.sub s (i+1) (len-(i+1))\n\n\nlet make_symlist prefix sep suffix l =\n match l with\n | [] -> \"\"\n | h::t -> (List.fold_left (fun x y -> x ^ sep ^ y) (prefix ^ h) t) ^ suffix\n\n\nlet print_spec buf (key, spec, doc) =\n if String.length doc > 0 then\n match spec with\n | Symbol (l, _) ->\n bprintf buf \" %s %s%s\\n\" key (make_symlist \"{\" \"|\" \"}\" l) doc\n | _ ->\n bprintf buf \" %s %s\\n\" key doc\n\n\nlet help_action () = raise (Stop (Unknown \"-help\"))\n\nlet add_help speclist =\n let add1 =\n try ignore (assoc3 \"-help\" speclist); []\n with Not_found ->\n [\"-help\", Unit help_action, \" Display this list of options\"]\n and add2 =\n try ignore (assoc3 \"--help\" speclist); []\n with Not_found ->\n [\"--help\", Unit help_action, \" Display this list of options\"]\n in\n speclist @ (add1 @ add2)\n\n\nlet usage_b buf speclist errmsg =\n bprintf buf \"%s\\n\" errmsg;\n List.iter (print_spec buf) (add_help speclist)\n\n\nlet usage_string speclist errmsg =\n let b = Buffer.create 200 in\n usage_b b speclist errmsg;\n Buffer.contents b\n\n\nlet usage speclist errmsg =\n eprintf \"%s\" (usage_string speclist errmsg)\n\n\nlet current = ref 0\n\nlet bool_of_string_opt x =\n try Some (bool_of_string x)\n with Invalid_argument _ -> None\n\nlet int_of_string_opt x =\n try Some (int_of_string x)\n with Failure _ -> None\n\nlet float_of_string_opt x =\n try Some (float_of_string x)\n with Failure _ -> None\n\nlet parse_and_expand_argv_dynamic_aux allow_expand current argv speclist anonfun\n errmsg =\n let initpos = !current in\n let convert_error error =\n (* convert an internal error to a Bad/Help exception\n *or* add the program name as a prefix and the usage message as a suffix\n to an user-raised Bad exception.\n *)\n let b = Buffer.create 200 in\n let progname =\n if initpos < (Array.length !argv) then !argv.(initpos) else \"(?)\" in\n begin match error with\n | Unknown \"-help\" -> ()\n | Unknown \"--help\" -> ()\n | Unknown s ->\n bprintf b \"%s: unknown option '%s'.\\n\" progname s\n | Missing s ->\n bprintf b \"%s: option '%s' needs an argument.\\n\" progname s\n | Wrong (opt, arg, expected) ->\n bprintf b \"%s: wrong argument '%s'; option '%s' expects %s.\\n\"\n progname arg opt expected\n | Message s -> (* user error message *)\n bprintf b \"%s: %s.\\n\" progname s\n end;\n usage_b b !speclist errmsg;\n if error = Unknown \"-help\" || error = Unknown \"--help\"\n then Help (Buffer.contents b)\n else Bad (Buffer.contents b)\n in\n incr current;\n while !current < (Array.length !argv) do\n begin try\n let s = !argv.(!current) in\n if String.length s >= 1 && s.[0] = '-' then begin\n let action, follow =\n try assoc3 s !speclist, None\n with Not_found ->\n try\n let keyword, arg = split s in\n assoc3 keyword !speclist, Some arg\n with Not_found -> raise (Stop (Unknown s))\n in\n let no_arg () =\n match follow with\n | None -> ()\n | Some arg -> raise (Stop (Wrong (s, arg, \"no argument\"))) in\n let get_arg () =\n match follow with\n | None ->\n if !current + 1 < (Array.length !argv) then !argv.(!current + 1)\n else raise (Stop (Missing s))\n | Some arg -> arg\n in\n let consume_arg () =\n match follow with\n | None -> incr current\n | Some _ -> ()\n in\n let rec treat_action = function\n | Unit f -> no_arg (); f ();\n | Bool f ->\n let arg = get_arg () in\n begin match bool_of_string_opt arg with\n | None -> raise (Stop (Wrong (s, arg, \"a boolean\")))\n | Some s -> f s\n end;\n consume_arg ();\n | Set r -> no_arg (); r := true;\n | Clear r -> no_arg (); r := false;\n | String f ->\n let arg = get_arg () in\n f arg;\n consume_arg ();\n | Symbol (symb, f) ->\n let arg = get_arg () in\n if List.mem arg symb then begin\n f arg;\n consume_arg ();\n end else begin\n raise (Stop (Wrong (s, arg, \"one of: \"\n ^ (make_symlist \"\" \" \" \"\" symb))))\n end\n | Set_string r ->\n r := get_arg ();\n consume_arg ();\n | Int f ->\n let arg = get_arg () in\n begin match int_of_string_opt arg with\n | None -> raise (Stop (Wrong (s, arg, \"an integer\")))\n | Some x -> f x\n end;\n consume_arg ();\n | Set_int r ->\n let arg = get_arg () in\n begin match int_of_string_opt arg with\n | None -> raise (Stop (Wrong (s, arg, \"an integer\")))\n | Some x -> r := x\n end;\n consume_arg ();\n | Float f ->\n let arg = get_arg () in\n begin match float_of_string_opt arg with\n | None -> raise (Stop (Wrong (s, arg, \"a float\")))\n | Some x -> f x\n end;\n consume_arg ();\n | Set_float r ->\n let arg = get_arg () in\n begin match float_of_string_opt arg with\n | None -> raise (Stop (Wrong (s, arg, \"a float\")))\n | Some x -> r := x\n end;\n consume_arg ();\n | Tuple specs ->\n no_arg ();\n List.iter treat_action specs;\n | Rest f ->\n no_arg ();\n while !current < (Array.length !argv) - 1 do\n f !argv.(!current + 1);\n consume_arg ();\n done;\n | Rest_all f ->\n no_arg ();\n let acc = ref [] in\n while !current < Array.length !argv - 1 do\n acc := !argv.(!current + 1) :: !acc;\n consume_arg ();\n done;\n f (List.rev !acc)\n | Expand f ->\n if not allow_expand then\n raise (Invalid_argument \"Arg.Expand is is only allowed with \\\n Arg.parse_and_expand_argv_dynamic\");\n let arg = get_arg () in\n let newarg = f arg in\n consume_arg ();\n let before = Array.sub !argv 0 (!current + 1)\n and after =\n Array.sub !argv (!current + 1)\n ((Array.length !argv) - !current - 1) in\n argv:= Array.concat [before;newarg;after];\n in\n treat_action action end\n else anonfun s\n with | Bad m -> raise (convert_error (Message m));\n | Stop e -> raise (convert_error e);\n end;\n incr current\n done\n\nlet parse_and_expand_argv_dynamic current argv speclist anonfun errmsg =\n parse_and_expand_argv_dynamic_aux true current argv speclist anonfun errmsg\n\nlet parse_argv_dynamic ?(current=current) argv speclist anonfun errmsg =\n parse_and_expand_argv_dynamic_aux false current (ref argv) speclist anonfun\n errmsg\n\n\nlet parse_argv ?(current=current) argv speclist anonfun errmsg =\n parse_argv_dynamic ~current:current argv (ref speclist) anonfun errmsg\n\n\nlet parse l f msg =\n try\n parse_argv Sys.argv l f msg\n with\n | Bad msg -> eprintf \"%s\" msg; exit 2\n | Help msg -> printf \"%s\" msg; exit 0\n\n\nlet parse_dynamic l f msg =\n try\n parse_argv_dynamic Sys.argv l f msg\n with\n | Bad msg -> eprintf \"%s\" msg; exit 2\n | Help msg -> printf \"%s\" msg; exit 0\n\nlet parse_expand l f msg =\n try\n let argv = ref Sys.argv in\n let spec = ref l in\n let current = ref (!current) in\n parse_and_expand_argv_dynamic current argv spec f msg\n with\n | Bad msg -> eprintf \"%s\" msg; exit 2\n | Help msg -> printf \"%s\" msg; exit 0\n\n\nlet second_word s =\n let len = String.length s in\n let rec loop n =\n if n >= len then len\n else if s.[n] = ' ' then loop (n+1)\n else n\n in\n match String.index s '\\t' with\n | n -> loop (n+1)\n | exception Not_found ->\n begin match String.index s ' ' with\n | n -> loop (n+1)\n | exception Not_found -> len\n end\n\n\nlet max_arg_len cur (kwd, spec, doc) =\n match spec with\n | Symbol _ -> Int.max cur (String.length kwd)\n | _ -> Int.max cur (String.length kwd + second_word doc)\n\n\nlet replace_leading_tab s =\n let seen = ref false in\n String.map (function '\\t' when not !seen -> seen := true; ' ' | c -> c) s\n\nlet add_padding len ksd =\n match ksd with\n | (_, _, \"\") ->\n (* Do not pad undocumented options, so that they still don't show up when\n * run through [usage] or [parse]. *)\n ksd\n | (kwd, (Symbol _ as spec), msg) ->\n let cutcol = second_word msg in\n let spaces = String.make ((Int.max 0 (len - cutcol)) + 3) ' ' in\n (kwd, spec, \"\\n\" ^ spaces ^ replace_leading_tab msg)\n | (kwd, spec, msg) ->\n let cutcol = second_word msg in\n let kwd_len = String.length kwd in\n let diff = len - kwd_len - cutcol in\n if diff <= 0 then\n (kwd, spec, replace_leading_tab msg)\n else\n let spaces = String.make diff ' ' in\n let prefix = String.sub (replace_leading_tab msg) 0 cutcol in\n let suffix = String.sub msg cutcol (String.length msg - cutcol) in\n (kwd, spec, prefix ^ spaces ^ suffix)\n\n\nlet align ?(limit=max_int) speclist =\n let completed = add_help speclist in\n let len = List.fold_left max_arg_len 0 completed in\n let len = Int.min len limit in\n List.map (add_padding len) completed\n\nlet trim_cr s =\n let len = String.length s in\n if len > 0 && String.get s (len - 1) = '\\r' then\n String.sub s 0 (len - 1)\n else\n s\n\nlet read_aux trim sep file =\n let ic = open_in_bin file in\n let buf = Buffer.create 200 in\n let words = ref [] in\n let stash () =\n let word = Buffer.contents buf in\n let word = if trim then trim_cr word else word in\n words := word :: !words;\n Buffer.clear buf\n in\n begin\n try while true do\n let c = input_char ic in\n if c = sep then stash () else Buffer.add_char buf c\n done\n with End_of_file -> ()\n end;\n if Buffer.length buf > 0 then stash ();\n close_in ic;\n Array.of_list (List.rev !words)\n\nlet read_arg = read_aux true '\\n'\n\nlet read_arg0 = read_aux false '\\x00'\n\nlet write_aux sep file args =\n let oc = open_out_bin file in\n Array.iter (fun s -> fprintf oc \"%s%c\" s sep) args;\n close_out oc\n\nlet write_arg = write_aux '\\n'\n\nlet write_arg0 = write_aux '\\x00'\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* The OCaml programmers *)\n(* *)\n(* Copyright 2018 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nexternal id : 'a -> 'a = \"%identity\"\nlet const c _ = c\nlet flip f x y = f y x\nlet negate p v = not (p v)\n\nexception Finally_raised of exn\n\nlet () = Printexc.register_printer @@ function\n| Finally_raised exn -> Some (\"Fun.Finally_raised: \" ^ Printexc.to_string exn)\n| _ -> None\n\nlet protect ~(finally : unit -> unit) work =\n let finally_no_exn () =\n try finally () with e ->\n let bt = Printexc.get_raw_backtrace () in\n Printexc.raise_with_backtrace (Finally_raised e) bt\n in\n match work () with\n | result -> finally_no_exn () ; result\n | exception work_exn ->\n let work_bt = Printexc.get_raw_backtrace () in\n finally_no_exn () ;\n Printexc.raise_with_backtrace work_exn work_bt\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Message digest (MD5) *)\n\ntype t = string\n\nlet compare = String.compare\nlet equal = String.equal\n\nexternal unsafe_string: string -> int -> int -> t = \"caml_md5_string\"\nexternal channel: in_channel -> int -> t = \"caml_md5_chan\"\n\nlet string str =\n unsafe_string str 0 (String.length str)\n\nlet bytes b = string (Bytes.unsafe_to_string b)\n\nlet substring str ofs len =\n if ofs < 0 || len < 0 || ofs > String.length str - len\n then invalid_arg \"Digest.substring\"\n else unsafe_string str ofs len\n\nlet subbytes b ofs len = substring (Bytes.unsafe_to_string b) ofs len\n\nlet file filename =\n let ic = open_in_bin filename in\n match channel ic (-1) with\n | d -> close_in ic; d\n | exception e -> close_in ic; raise e\n\nlet output chan digest =\n output_string chan digest\n\nlet input chan = really_input_string chan 16\n\nlet char_hex n =\n Char.unsafe_chr (n + if n < 10 then Char.code '0' else (Char.code 'a' - 10))\n\nlet to_hex d =\n if String.length d <> 16 then invalid_arg \"Digest.to_hex\";\n let result = Bytes.create 32 in\n for i = 0 to 15 do\n let x = Char.code d.[i] in\n Bytes.unsafe_set result (i*2) (char_hex (x lsr 4));\n Bytes.unsafe_set result (i*2+1) (char_hex (x land 0x0f));\n done;\n Bytes.unsafe_to_string result\n\nlet from_hex s =\n if String.length s <> 32 then invalid_arg \"Digest.from_hex\";\n let digit c =\n match c with\n | '0'..'9' -> Char.code c - Char.code '0'\n | 'A'..'F' -> Char.code c - Char.code 'A' + 10\n | 'a'..'f' -> Char.code c - Char.code 'a' + 10\n | _ -> raise (Invalid_argument \"Digest.from_hex\")\n in\n let byte i = digit s.[i] lsl 4 + digit s.[i+1] in\n let result = Bytes.create 16 in\n for i = 0 to 15 do\n Bytes.set result i (Char.chr (byte (2 * i)));\n done;\n Bytes.unsafe_to_string result\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Para, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Pseudo-random number generator\n This is a lagged-Fibonacci F(55, 24, +) with a modified addition\n function to enhance the mixing of bits.\n If we use normal addition, the low-order bit fails tests 1 and 7\n of the Diehard test suite, and bits 1 and 2 also fail test 7.\n If we use multiplication as suggested by Marsaglia, it doesn't fare\n much better.\n By mixing the bits of one of the numbers before addition (XOR the\n 5 high-order bits into the low-order bits), we get a generator that\n passes all the Diehard tests.\n*)\n\nexternal random_seed: unit -> int array = \"caml_sys_random_seed\"\n\nmodule State = struct\n\n type t = { st : int array; mutable idx : int }\n\n let new_state () = { st = Array.make 55 0; idx = 0 }\n let assign st1 st2 =\n Array.blit st2.st 0 st1.st 0 55;\n st1.idx <- st2.idx\n\n\n let full_init s seed =\n let combine accu x = Digest.string (accu ^ Int.to_string x) in\n let extract d =\n Char.code d.[0] + (Char.code d.[1] lsl 8) + (Char.code d.[2] lsl 16)\n + (Char.code d.[3] lsl 24)\n in\n let seed = if Array.length seed = 0 then [| 0 |] else seed in\n let l = Array.length seed in\n for i = 0 to 54 do\n s.st.(i) <- i;\n done;\n let accu = ref \"x\" in\n for i = 0 to 54 + Int.max 55 l do\n let j = i mod 55 in\n let k = i mod l in\n accu := combine !accu seed.(k);\n s.st.(j) <- (s.st.(j) lxor extract !accu) land 0x3FFFFFFF; (* PR#5575 *)\n done;\n s.idx <- 0\n\n\n let make seed =\n let result = new_state () in\n full_init result seed;\n result\n\n\n let make_self_init () = make (random_seed ())\n\n let copy s =\n let result = new_state () in\n assign result s;\n result\n\n\n (* Returns 30 random bits as an integer 0 <= x < 1073741824 *)\n let bits s =\n s.idx <- (s.idx + 1) mod 55;\n let curval = s.st.(s.idx) in\n let newval = s.st.((s.idx + 24) mod 55)\n + (curval lxor ((curval lsr 25) land 0x1F)) in\n let newval30 = newval land 0x3FFFFFFF in (* PR#5575 *)\n s.st.(s.idx) <- newval30;\n newval30\n\n\n let rec intaux s n =\n let r = bits s in\n let v = r mod n in\n if r - v > 0x3FFFFFFF - n + 1 then intaux s n else v\n\n let int s bound =\n if bound > 0x3FFFFFFF || bound <= 0\n then invalid_arg \"Random.int\"\n else intaux s bound\n\n let rec int63aux s n =\n let max_int_32 = (1 lsl 30) + 0x3FFFFFFF in (* 0x7FFFFFFF *)\n let b1 = bits s in\n let b2 = bits s in\n let (r, max_int) =\n if n <= max_int_32 then\n (* 31 random bits on both 64-bit OCaml and JavaScript.\n Use upper 15 bits of b1 and 16 bits of b2. *)\n let bpos =\n (((b2 land 0x3FFFC000) lsl 1) lor (b1 lsr 15))\n in\n (bpos, max_int_32)\n else\n let b3 = bits s in\n (* 62 random bits on 64-bit OCaml; unreachable on JavaScript.\n Use upper 20 bits of b1 and 21 bits of b2 and b3. *)\n let bpos =\n ((((b3 land 0x3FFFFE00) lsl 12) lor (b2 lsr 9)) lsl 20)\n lor (b1 lsr 10)\n in\n (bpos, max_int)\n in\n let v = r mod n in\n if r - v > max_int - n + 1 then int63aux s n else v\n\n let full_int s bound =\n if bound <= 0 then\n invalid_arg \"Random.full_int\"\n else if bound > 0x3FFFFFFF then\n int63aux s bound\n else\n intaux s bound\n\n\n let rec int32aux s n =\n let b1 = Int32.of_int (bits s) in\n let b2 = Int32.shift_left (Int32.of_int (bits s land 1)) 30 in\n let r = Int32.logor b1 b2 in\n let v = Int32.rem r n in\n if Int32.sub r v > Int32.add (Int32.sub Int32.max_int n) 1l\n then int32aux s n\n else v\n\n let int32 s bound =\n if bound <= 0l\n then invalid_arg \"Random.int32\"\n else int32aux s bound\n\n\n let rec int64aux s n =\n let b1 = Int64.of_int (bits s) in\n let b2 = Int64.shift_left (Int64.of_int (bits s)) 30 in\n let b3 = Int64.shift_left (Int64.of_int (bits s land 7)) 60 in\n let r = Int64.logor b1 (Int64.logor b2 b3) in\n let v = Int64.rem r n in\n if Int64.sub r v > Int64.add (Int64.sub Int64.max_int n) 1L\n then int64aux s n\n else v\n\n let int64 s bound =\n if bound <= 0L\n then invalid_arg \"Random.int64\"\n else int64aux s bound\n\n\n let nativeint =\n if Nativeint.size = 32\n then fun s bound -> Nativeint.of_int32 (int32 s (Nativeint.to_int32 bound))\n else fun s bound -> Int64.to_nativeint (int64 s (Int64.of_nativeint bound))\n\n\n (* Returns a float 0 <= x <= 1 with at most 60 bits of precision. *)\n let rawfloat s =\n let scale = 1073741824.0 (* 2^30 *)\n and r1 = Stdlib.float (bits s)\n and r2 = Stdlib.float (bits s)\n in (r1 /. scale +. r2) /. scale\n\n\n let float s bound = rawfloat s *. bound\n\n let bool s = (bits s land 1 = 0)\n\n let bits32 s =\n let b1 = Int32.(shift_right_logical (of_int (bits s)) 14) in (* 16 bits *)\n let b2 = Int32.(shift_right_logical (of_int (bits s)) 14) in (* 16 bits *)\n Int32.(logor b1 (shift_left b2 16))\n\n let bits64 s =\n let b1 = Int64.(shift_right_logical (of_int (bits s)) 9) in (* 21 bits *)\n let b2 = Int64.(shift_right_logical (of_int (bits s)) 9) in (* 21 bits *)\n let b3 = Int64.(shift_right_logical (of_int (bits s)) 8) in (* 22 bits *)\n Int64.(logor b1 (logor (shift_left b2 21) (shift_left b3 42)))\n\n let nativebits =\n if Nativeint.size = 32\n then fun s -> Nativeint.of_int32 (bits32 s)\n else fun s -> Int64.to_nativeint (bits64 s)\n\nend\n\n(* This is the state you get with [init 27182818] and then applying\n the \"land 0x3FFFFFFF\" filter to them. See #5575, #5793, #5977. *)\nlet default = {\n State.st = [|\n 0x3ae2522b; 0x1d8d4634; 0x15b4fad0; 0x18b14ace; 0x12f8a3c4; 0x3b086c47;\n 0x16d467d6; 0x101d91c7; 0x321df177; 0x0176c193; 0x1ff72bf1; 0x1e889109;\n 0x0b464b18; 0x2b86b97c; 0x0891da48; 0x03137463; 0x085ac5a1; 0x15d61f2f;\n 0x3bced359; 0x29c1c132; 0x3a86766e; 0x366d8c86; 0x1f5b6222; 0x3ce1b59f;\n 0x2ebf78e1; 0x27cd1b86; 0x258f3dc3; 0x389a8194; 0x02e4c44c; 0x18c43f7d;\n 0x0f6e534f; 0x1e7df359; 0x055d0b7e; 0x10e84e7e; 0x126198e4; 0x0e7722cb;\n 0x1cbede28; 0x3391b964; 0x3d40e92a; 0x0c59933d; 0x0b8cd0b7; 0x24efff1c;\n 0x2803fdaa; 0x08ebc72e; 0x0f522e32; 0x05398edc; 0x2144a04c; 0x0aef3cbd;\n 0x01ad4719; 0x35b93cd6; 0x2a559d4f; 0x1e6fd768; 0x26e27f36; 0x186f18c3;\n 0x2fbf967a;\n |];\n State.idx = 0;\n}\n\nlet bits () = State.bits default\nlet int bound = State.int default bound\nlet full_int bound = State.full_int default bound\nlet int32 bound = State.int32 default bound\nlet nativeint bound = State.nativeint default bound\nlet int64 bound = State.int64 default bound\nlet float scale = State.float default scale\nlet bool () = State.bool default\nlet bits32 () = State.bits32 default\nlet bits64 () = State.bits64 default\nlet nativebits () = State.nativebits default\n\nlet full_init seed = State.full_init default seed\nlet init seed = State.full_init default [| seed |]\nlet self_init () = full_init (random_seed())\n\n(* Manipulating the current state. *)\n\nlet get_state () = State.copy default\nlet set_state s = State.assign default s\n\n(********************\n\n(* Test functions. Not included in the library.\n The [chisquare] function should be called with n > 10r.\n It returns a triple (low, actual, high).\n If low <= actual <= high, the [g] function passed the test,\n otherwise it failed.\n\n Some results:\n\ninit 27182818; chisquare int 100000 1000\ninit 27182818; chisquare int 100000 100\ninit 27182818; chisquare int 100000 5000\ninit 27182818; chisquare int 1000000 1000\ninit 27182818; chisquare int 100000 1024\ninit 299792643; chisquare int 100000 1024\ninit 14142136; chisquare int 100000 1024\ninit 27182818; init_diff 1024; chisquare diff 100000 1024\ninit 27182818; init_diff 100; chisquare diff 100000 100\ninit 27182818; init_diff2 1024; chisquare diff2 100000 1024\ninit 27182818; init_diff2 100; chisquare diff2 100000 100\ninit 14142136; init_diff2 100; chisquare diff2 100000 100\ninit 299792643; init_diff2 100; chisquare diff2 100000 100\n- : float * float * float = (936.754446796632465, 997.5, 1063.24555320336754)\n# - : float * float * float = (80., 89.7400000000052387, 120.)\n# - : float * float * float = (4858.57864376269, 5045.5, 5141.42135623731)\n# - : float * float * float =\n(936.754446796632465, 944.805999999982305, 1063.24555320336754)\n# - : float * float * float = (960., 1019.19744000000355, 1088.)\n# - : float * float * float = (960., 1059.31776000000536, 1088.)\n# - : float * float * float = (960., 1039.98463999999512, 1088.)\n# - : float * float * float = (960., 1054.38207999999577, 1088.)\n# - : float * float * float = (80., 90.096000000005, 120.)\n# - : float * float * float = (960., 1076.78720000000612, 1088.)\n# - : float * float * float = (80., 85.1760000000067521, 120.)\n# - : float * float * float = (80., 85.2160000000003492, 120.)\n# - : float * float * float = (80., 80.6220000000030268, 120.)\n\n*)\n\n(* Return the sum of the squares of v[i0,i1[ *)\nlet rec sumsq v i0 i1 =\n if i0 >= i1 then 0.0\n else if i1 = i0 + 1 then Stdlib.float v.(i0) *. Stdlib.float v.(i0)\n else sumsq v i0 ((i0+i1)/2) +. sumsq v ((i0+i1)/2) i1\n\n\nlet chisquare g n r =\n if n <= 10 * r then invalid_arg \"chisquare\";\n let f = Array.make r 0 in\n for i = 1 to n do\n let t = g r in\n f.(t) <- f.(t) + 1\n done;\n let t = sumsq f 0 r\n and r = Stdlib.float r\n and n = Stdlib.float n in\n let sr = 2.0 *. sqrt r in\n (r -. sr, (r *. t /. n) -. n, r +. sr)\n\n\n(* This is to test for linear dependencies between successive random numbers.\n*)\nlet st = ref 0\nlet init_diff r = st := int r\nlet diff r =\n let x1 = !st\n and x2 = int r\n in\n st := x2;\n if x1 >= x2 then\n x1 - x2\n else\n r + x1 - x2\n\n\nlet st1 = ref 0\nand st2 = ref 0\n\n\n(* This is to test for quadratic dependencies between successive random\n numbers.\n*)\nlet init_diff2 r = st1 := int r; st2 := int r\nlet diff2 r =\n let x1 = !st1\n and x2 = !st2\n and x3 = int r\n in\n st1 := x2;\n st2 := x3;\n (x3 - x2 - x2 + x1 + 2*r) mod r\n\n\n********************)\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Hash tables *)\n\n(* We do dynamic hashing, and resize the table and rehash the elements\n when buckets become too long. *)\n\ntype ('a, 'b) t =\n { mutable size: int; (* number of entries *)\n mutable data: ('a, 'b) bucketlist array; (* the buckets *)\n seed: int; (* for randomization *)\n mutable initial_size: int; (* initial array size *)\n }\n\nand ('a, 'b) bucketlist =\n Empty\n | Cons of { mutable key: 'a;\n mutable data: 'b;\n mutable next: ('a, 'b) bucketlist }\n\n(* The sign of initial_size encodes the fact that a traversal is\n ongoing or not.\n\n This disables the efficient in place implementation of resizing.\n*)\n\nlet ongoing_traversal h =\n Obj.size (Obj.repr h) < 4 (* compatibility with old hash tables *)\n || h.initial_size < 0\n\nlet flip_ongoing_traversal h =\n h.initial_size <- - h.initial_size\n\n(* To pick random seeds if requested *)\n\nlet randomized_default =\n let params =\n try Sys.getenv \"OCAMLRUNPARAM\" with Not_found ->\n try Sys.getenv \"CAMLRUNPARAM\" with Not_found -> \"\" in\n String.contains params 'R'\n\nlet randomized = ref randomized_default\n\nlet randomize () = randomized := true\nlet is_randomized () = !randomized\n\nlet prng = lazy (Random.State.make_self_init())\n\n(* Functions which appear before the functorial interface must either be\n independent of the hash function or take it as a parameter (see #2202 and\n code below the functor definitions. *)\n\n(* Creating a fresh, empty table *)\n\nlet rec power_2_above x n =\n if x >= n then x\n else if x * 2 > Sys.max_array_length then x\n else power_2_above (x * 2) n\n\nlet create ?(random = !randomized) initial_size =\n let s = power_2_above 16 initial_size in\n let seed = if random then Random.State.bits (Lazy.force prng) else 0 in\n { initial_size = s; size = 0; seed = seed; data = Array.make s Empty }\n\nlet clear h =\n if h.size > 0 then begin\n h.size <- 0;\n Array.fill h.data 0 (Array.length h.data) Empty\n end\n\nlet reset h =\n let len = Array.length h.data in\n if Obj.size (Obj.repr h) < 4 (* compatibility with old hash tables *)\n || len = abs h.initial_size then\n clear h\n else begin\n h.size <- 0;\n h.data <- Array.make (abs h.initial_size) Empty\n end\n\nlet copy_bucketlist = function\n | Empty -> Empty\n | Cons {key; data; next} ->\n let rec loop prec = function\n | Empty -> ()\n | Cons {key; data; next} ->\n let r = Cons {key; data; next} in\n begin match prec with\n | Empty -> assert false\n | Cons prec -> prec.next <- r\n end;\n loop r next\n in\n let r = Cons {key; data; next} in\n loop r next;\n r\n\nlet copy h = { h with data = Array.map copy_bucketlist h.data }\n\nlet length h = h.size\n\nlet insert_all_buckets indexfun inplace odata ndata =\n let nsize = Array.length ndata in\n let ndata_tail = Array.make nsize Empty in\n let rec insert_bucket = function\n | Empty -> ()\n | Cons {key; data; next} as cell ->\n let cell =\n if inplace then cell\n else Cons {key; data; next = Empty}\n in\n let nidx = indexfun key in\n begin match ndata_tail.(nidx) with\n | Empty -> ndata.(nidx) <- cell;\n | Cons tail -> tail.next <- cell;\n end;\n ndata_tail.(nidx) <- cell;\n insert_bucket next\n in\n for i = 0 to Array.length odata - 1 do\n insert_bucket odata.(i)\n done;\n if inplace then\n for i = 0 to nsize - 1 do\n match ndata_tail.(i) with\n | Empty -> ()\n | Cons tail -> tail.next <- Empty\n done\n\nlet resize indexfun h =\n let odata = h.data in\n let osize = Array.length odata in\n let nsize = osize * 2 in\n if nsize < Sys.max_array_length then begin\n let ndata = Array.make nsize Empty in\n let inplace = not (ongoing_traversal h) in\n h.data <- ndata; (* so that indexfun sees the new bucket count *)\n insert_all_buckets (indexfun h) inplace odata ndata\n end\n\nlet iter f h =\n let rec do_bucket = function\n | Empty ->\n ()\n | Cons{key; data; next} ->\n f key data; do_bucket next in\n let old_trav = ongoing_traversal h in\n if not old_trav then flip_ongoing_traversal h;\n try\n let d = h.data in\n for i = 0 to Array.length d - 1 do\n do_bucket d.(i)\n done;\n if not old_trav then flip_ongoing_traversal h;\n with exn when not old_trav ->\n flip_ongoing_traversal h;\n raise exn\n\nlet rec filter_map_inplace_bucket f h i prec = function\n | Empty ->\n begin match prec with\n | Empty -> h.data.(i) <- Empty\n | Cons c -> c.next <- Empty\n end\n | (Cons ({key; data; next} as c)) as slot ->\n begin match f key data with\n | None ->\n h.size <- h.size - 1;\n filter_map_inplace_bucket f h i prec next\n | Some data ->\n begin match prec with\n | Empty -> h.data.(i) <- slot\n | Cons c -> c.next <- slot\n end;\n c.data <- data;\n filter_map_inplace_bucket f h i slot next\n end\n\nlet filter_map_inplace f h =\n let d = h.data in\n let old_trav = ongoing_traversal h in\n if not old_trav then flip_ongoing_traversal h;\n try\n for i = 0 to Array.length d - 1 do\n filter_map_inplace_bucket f h i Empty h.data.(i)\n done;\n if not old_trav then flip_ongoing_traversal h\n with exn when not old_trav ->\n flip_ongoing_traversal h;\n raise exn\n\nlet fold f h init =\n let rec do_bucket b accu =\n match b with\n Empty ->\n accu\n | Cons{key; data; next} ->\n do_bucket next (f key data accu) in\n let old_trav = ongoing_traversal h in\n if not old_trav then flip_ongoing_traversal h;\n try\n let d = h.data in\n let accu = ref init in\n for i = 0 to Array.length d - 1 do\n accu := do_bucket d.(i) !accu\n done;\n if not old_trav then flip_ongoing_traversal h;\n !accu\n with exn when not old_trav ->\n flip_ongoing_traversal h;\n raise exn\n\ntype statistics = {\n num_bindings: int;\n num_buckets: int;\n max_bucket_length: int;\n bucket_histogram: int array\n}\n\nlet rec bucket_length accu = function\n | Empty -> accu\n | Cons{next} -> bucket_length (accu + 1) next\n\nlet stats h =\n let mbl =\n Array.fold_left (fun m b -> Int.max m (bucket_length 0 b)) 0 h.data in\n let histo = Array.make (mbl + 1) 0 in\n Array.iter\n (fun b ->\n let l = bucket_length 0 b in\n histo.(l) <- histo.(l) + 1)\n h.data;\n { num_bindings = h.size;\n num_buckets = Array.length h.data;\n max_bucket_length = mbl;\n bucket_histogram = histo }\n\n(** {1 Iterators} *)\n\nlet to_seq tbl =\n (* capture current array, so that even if the table is resized we\n keep iterating on the same array *)\n let tbl_data = tbl.data in\n (* state: index * next bucket to traverse *)\n let rec aux i buck () = match buck with\n | Empty ->\n if i = Array.length tbl_data\n then Seq.Nil\n else aux(i+1) tbl_data.(i) ()\n | Cons {key; data; next} ->\n Seq.Cons ((key, data), aux i next)\n in\n aux 0 Empty\n\nlet to_seq_keys m = Seq.map fst (to_seq m)\n\nlet to_seq_values m = Seq.map snd (to_seq m)\n\n(* Functorial interface *)\n\nmodule type HashedType =\n sig\n type t\n val equal: t -> t -> bool\n val hash: t -> int\n end\n\nmodule type SeededHashedType =\n sig\n type t\n val equal: t -> t -> bool\n val hash: int -> t -> int\n end\n\nmodule type S =\n sig\n type key\n type !'a t\n val create: int -> 'a t\n val clear : 'a t -> unit\n val reset : 'a t -> unit\n val copy: 'a t -> 'a t\n val add: 'a t -> key -> 'a -> unit\n val remove: 'a t -> key -> unit\n val find: 'a t -> key -> 'a\n val find_opt: 'a t -> key -> 'a option\n val find_all: 'a t -> key -> 'a list\n val replace : 'a t -> key -> 'a -> unit\n val mem : 'a t -> key -> bool\n val iter: (key -> 'a -> unit) -> 'a t -> unit\n val filter_map_inplace: (key -> 'a -> 'a option) -> 'a t -> unit\n val fold: (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n val length: 'a t -> int\n val stats: 'a t -> statistics\n val to_seq : 'a t -> (key * 'a) Seq.t\n val to_seq_keys : _ t -> key Seq.t\n val to_seq_values : 'a t -> 'a Seq.t\n val add_seq : 'a t -> (key * 'a) Seq.t -> unit\n val replace_seq : 'a t -> (key * 'a) Seq.t -> unit\n val of_seq : (key * 'a) Seq.t -> 'a t\n end\n\nmodule type SeededS =\n sig\n type key\n type !'a t\n val create : ?random:bool -> int -> 'a t\n val clear : 'a t -> unit\n val reset : 'a t -> unit\n val copy : 'a t -> 'a t\n val add : 'a t -> key -> 'a -> unit\n val remove : 'a t -> key -> unit\n val find : 'a t -> key -> 'a\n val find_opt: 'a t -> key -> 'a option\n val find_all : 'a t -> key -> 'a list\n val replace : 'a t -> key -> 'a -> unit\n val mem : 'a t -> key -> bool\n val iter : (key -> 'a -> unit) -> 'a t -> unit\n val filter_map_inplace: (key -> 'a -> 'a option) -> 'a t -> unit\n val fold : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n val length : 'a t -> int\n val stats: 'a t -> statistics\n val to_seq : 'a t -> (key * 'a) Seq.t\n val to_seq_keys : _ t -> key Seq.t\n val to_seq_values : 'a t -> 'a Seq.t\n val add_seq : 'a t -> (key * 'a) Seq.t -> unit\n val replace_seq : 'a t -> (key * 'a) Seq.t -> unit\n val of_seq : (key * 'a) Seq.t -> 'a t\n end\n\nmodule MakeSeeded(H: SeededHashedType): (SeededS with type key = H.t) =\n struct\n type key = H.t\n type 'a hashtbl = (key, 'a) t\n type 'a t = 'a hashtbl\n let create = create\n let clear = clear\n let reset = reset\n let copy = copy\n\n let key_index h key =\n (H.hash h.seed key) land (Array.length h.data - 1)\n\n let add h key data =\n let i = key_index h key in\n let bucket = Cons{key; data; next=h.data.(i)} in\n h.data.(i) <- bucket;\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize key_index h\n\n let rec remove_bucket h i key prec = function\n | Empty ->\n ()\n | (Cons {key=k; next}) as c ->\n if H.equal k key\n then begin\n h.size <- h.size - 1;\n match prec with\n | Empty -> h.data.(i) <- next\n | Cons c -> c.next <- next\n end\n else remove_bucket h i key c next\n\n let remove h key =\n let i = key_index h key in\n remove_bucket h i key Empty h.data.(i)\n\n let rec find_rec key = function\n | Empty ->\n raise Not_found\n | Cons{key=k; data; next} ->\n if H.equal key k then data else find_rec key next\n\n let find h key =\n match h.data.(key_index h key) with\n | Empty -> raise Not_found\n | Cons{key=k1; data=d1; next=next1} ->\n if H.equal key k1 then d1 else\n match next1 with\n | Empty -> raise Not_found\n | Cons{key=k2; data=d2; next=next2} ->\n if H.equal key k2 then d2 else\n match next2 with\n | Empty -> raise Not_found\n | Cons{key=k3; data=d3; next=next3} ->\n if H.equal key k3 then d3 else find_rec key next3\n\n let rec find_rec_opt key = function\n | Empty ->\n None\n | Cons{key=k; data; next} ->\n if H.equal key k then Some data else find_rec_opt key next\n\n let find_opt h key =\n match h.data.(key_index h key) with\n | Empty -> None\n | Cons{key=k1; data=d1; next=next1} ->\n if H.equal key k1 then Some d1 else\n match next1 with\n | Empty -> None\n | Cons{key=k2; data=d2; next=next2} ->\n if H.equal key k2 then Some d2 else\n match next2 with\n | Empty -> None\n | Cons{key=k3; data=d3; next=next3} ->\n if H.equal key k3 then Some d3 else find_rec_opt key next3\n\n let find_all h key =\n let rec find_in_bucket = function\n | Empty ->\n []\n | Cons{key=k; data=d; next} ->\n if H.equal k key\n then d :: find_in_bucket next\n else find_in_bucket next in\n find_in_bucket h.data.(key_index h key)\n\n let rec replace_bucket key data = function\n | Empty ->\n true\n | Cons ({key=k; next} as slot) ->\n if H.equal k key\n then (slot.key <- key; slot.data <- data; false)\n else replace_bucket key data next\n\n let replace h key data =\n let i = key_index h key in\n let l = h.data.(i) in\n if replace_bucket key data l then begin\n h.data.(i) <- Cons{key; data; next=l};\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize key_index h\n end\n\n let mem h key =\n let rec mem_in_bucket = function\n | Empty ->\n false\n | Cons{key=k; next} ->\n H.equal k key || mem_in_bucket next in\n mem_in_bucket h.data.(key_index h key)\n\n let add_seq tbl i =\n Seq.iter (fun (k,v) -> add tbl k v) i\n\n let replace_seq tbl i =\n Seq.iter (fun (k,v) -> replace tbl k v) i\n\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n\n let iter = iter\n let filter_map_inplace = filter_map_inplace\n let fold = fold\n let length = length\n let stats = stats\n let to_seq = to_seq\n let to_seq_keys = to_seq_keys\n let to_seq_values = to_seq_values\n end\n\nmodule Make(H: HashedType): (S with type key = H.t) =\n struct\n include MakeSeeded(struct\n type t = H.t\n let equal = H.equal\n let hash (_seed: int) x = H.hash x\n end)\n let create sz = create ~random:false sz\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n end\n\n(* Polymorphic hash function-based tables *)\n(* Code included below the functorial interface to guard against accidental\n use - see #2202 *)\n\nexternal seeded_hash_param :\n int -> int -> int -> 'a -> int = \"caml_hash\" [@@noalloc]\n\nlet hash x = seeded_hash_param 10 100 0 x\nlet hash_param n1 n2 x = seeded_hash_param n1 n2 0 x\nlet seeded_hash seed x = seeded_hash_param 10 100 seed x\n\nlet key_index h key =\n if Obj.size (Obj.repr h) >= 4\n then (seeded_hash_param 10 100 h.seed key) land (Array.length h.data - 1)\n else invalid_arg \"Hashtbl: unsupported hash table format\"\n\nlet add h key data =\n let i = key_index h key in\n let bucket = Cons{key; data; next=h.data.(i)} in\n h.data.(i) <- bucket;\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize key_index h\n\nlet rec remove_bucket h i key prec = function\n | Empty ->\n ()\n | (Cons {key=k; next}) as c ->\n if compare k key = 0\n then begin\n h.size <- h.size - 1;\n match prec with\n | Empty -> h.data.(i) <- next\n | Cons c -> c.next <- next\n end\n else remove_bucket h i key c next\n\nlet remove h key =\n let i = key_index h key in\n remove_bucket h i key Empty h.data.(i)\n\nlet rec find_rec key = function\n | Empty ->\n raise Not_found\n | Cons{key=k; data; next} ->\n if compare key k = 0 then data else find_rec key next\n\nlet find h key =\n match h.data.(key_index h key) with\n | Empty -> raise Not_found\n | Cons{key=k1; data=d1; next=next1} ->\n if compare key k1 = 0 then d1 else\n match next1 with\n | Empty -> raise Not_found\n | Cons{key=k2; data=d2; next=next2} ->\n if compare key k2 = 0 then d2 else\n match next2 with\n | Empty -> raise Not_found\n | Cons{key=k3; data=d3; next=next3} ->\n if compare key k3 = 0 then d3 else find_rec key next3\n\nlet rec find_rec_opt key = function\n | Empty ->\n None\n | Cons{key=k; data; next} ->\n if compare key k = 0 then Some data else find_rec_opt key next\n\nlet find_opt h key =\n match h.data.(key_index h key) with\n | Empty -> None\n | Cons{key=k1; data=d1; next=next1} ->\n if compare key k1 = 0 then Some d1 else\n match next1 with\n | Empty -> None\n | Cons{key=k2; data=d2; next=next2} ->\n if compare key k2 = 0 then Some d2 else\n match next2 with\n | Empty -> None\n | Cons{key=k3; data=d3; next=next3} ->\n if compare key k3 = 0 then Some d3 else find_rec_opt key next3\n\nlet find_all h key =\n let rec find_in_bucket = function\n | Empty ->\n []\n | Cons{key=k; data; next} ->\n if compare k key = 0\n then data :: find_in_bucket next\n else find_in_bucket next in\n find_in_bucket h.data.(key_index h key)\n\nlet rec replace_bucket key data = function\n | Empty ->\n true\n | Cons ({key=k; next} as slot) ->\n if compare k key = 0\n then (slot.key <- key; slot.data <- data; false)\n else replace_bucket key data next\n\nlet replace h key data =\n let i = key_index h key in\n let l = h.data.(i) in\n if replace_bucket key data l then begin\n h.data.(i) <- Cons{key; data; next=l};\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize key_index h\n end\n\nlet mem h key =\n let rec mem_in_bucket = function\n | Empty ->\n false\n | Cons{key=k; next} ->\n compare k key = 0 || mem_in_bucket next in\n mem_in_bucket h.data.(key_index h key)\n\nlet add_seq tbl i =\n Seq.iter (fun (k,v) -> add tbl k v) i\n\nlet replace_seq tbl i =\n Seq.iter (fun (k,v) -> replace tbl k v) i\n\nlet of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n\nlet rebuild ?(random = !randomized) h =\n let s = power_2_above 16 (Array.length h.data) in\n let seed =\n if random then Random.State.bits (Lazy.force prng)\n else if Obj.size (Obj.repr h) >= 4 then h.seed\n else 0 in\n let h' = {\n size = h.size;\n data = Array.make s Empty;\n seed = seed;\n initial_size = if Obj.size (Obj.repr h) >= 4 then h.initial_size else s\n } in\n insert_all_buckets (key_index h') false h.data h'.data;\n h'\n","open! Import\n\nlet poly_equal a b =\n let module Poly = struct\n type t = T : _ -> t\n end in\n Stdppx.Poly.equal (Poly.T a) (Poly.T b)\n\nmodule Context = struct\n type 'a t =\n | Label_declaration : label_declaration t\n | Constructor_declaration : constructor_declaration t\n | Type_declaration : type_declaration t\n | Type_exception : type_exception t\n | Type_extension : type_extension t\n | Extension_constructor : extension_constructor t\n | Pattern : pattern t\n | Core_type : core_type t\n | Expression : expression t\n | Value_description : value_description t\n | Class_type : class_type t\n | Class_type_field : class_type_field t\n | Class_infos : _ class_infos t\n | Class_expr : class_expr t\n | Class_field : class_field t\n | Module_type : module_type t\n | Module_declaration : module_declaration t\n | Module_type_declaration : module_type_declaration t\n | Module_substitution : module_substitution t\n | Open_description : open_description t\n | Open_declaration : open_declaration t\n | Include_infos : _ include_infos t\n | Module_expr : module_expr t\n | Value_binding : value_binding t\n | Module_binding : module_binding t\n | Pstr_eval : structure_item t\n | Pstr_extension : structure_item t\n | Psig_extension : signature_item t\n | Rtag : row_field t\n | Object_type_field : object_field t\n\n let label_declaration = Label_declaration\n let constructor_declaration = Constructor_declaration\n let type_declaration = Type_declaration\n let type_extension = Type_extension\n let type_exception = Type_exception\n let extension_constructor = Extension_constructor\n let pattern = Pattern\n let core_type = Core_type\n let expression = Expression\n let value_description = Value_description\n let class_type = Class_type\n let class_type_field = Class_type_field\n let class_infos = Class_infos\n let class_expr = Class_expr\n let class_field = Class_field\n let module_type = Module_type\n let module_declaration = Module_declaration\n let module_type_declaration = Module_type_declaration\n let open_description = Open_description\n let include_infos = Include_infos\n let module_expr = Module_expr\n let value_binding = Value_binding\n let module_binding = Module_binding\n let pstr_eval = Pstr_eval\n let pstr_extension = Pstr_extension\n let psig_extension = Psig_extension\n let rtag = Rtag\n let object_type_field = Object_type_field\n\n let get_pstr_eval st =\n match st.pstr_desc with\n | Pstr_eval (e, l) -> (e, l)\n | _ -> failwith \"Attribute.Context.get_pstr_eval\"\n\n let get_pstr_extension st =\n match st.pstr_desc with\n | Pstr_extension (e, l) -> (e, l)\n | _ -> failwith \"Attribute.Context.get_pstr_extension\"\n\n let get_psig_extension st =\n match st.psig_desc with\n | Psig_extension (e, l) -> (e, l)\n | _ -> failwith \"Attribute.Context.get_psig_extension\"\n\n let get_attributes : type a. a t -> a -> attributes =\n fun t x ->\n match t with\n | Label_declaration -> x.pld_attributes\n | Constructor_declaration -> x.pcd_attributes\n | Type_declaration -> x.ptype_attributes\n | Type_extension -> x.ptyext_attributes\n | Type_exception -> x.ptyexn_attributes\n | Extension_constructor -> x.pext_attributes\n | Pattern -> x.ppat_attributes\n | Core_type -> x.ptyp_attributes\n | Expression -> x.pexp_attributes\n | Value_description -> x.pval_attributes\n | Class_type -> x.pcty_attributes\n | Class_type_field -> x.pctf_attributes\n | Class_infos -> x.pci_attributes\n | Class_expr -> x.pcl_attributes\n | Class_field -> x.pcf_attributes\n | Module_type -> x.pmty_attributes\n | Module_declaration -> x.pmd_attributes\n | Module_type_declaration -> x.pmtd_attributes\n | Module_substitution -> x.pms_attributes\n | Open_description -> x.popen_attributes\n | Open_declaration -> x.popen_attributes\n | Include_infos -> x.pincl_attributes\n | Module_expr -> x.pmod_attributes\n | Value_binding -> x.pvb_attributes\n | Module_binding -> x.pmb_attributes\n | Pstr_eval -> snd (get_pstr_eval x)\n | Pstr_extension -> snd (get_pstr_extension x)\n | Psig_extension -> snd (get_psig_extension x)\n | Rtag -> x.prf_attributes\n | Object_type_field -> x.pof_attributes\n\n let set_attributes : type a. a t -> a -> attributes -> a =\n fun t x attrs ->\n match t with\n | Label_declaration -> { x with pld_attributes = attrs }\n | Constructor_declaration -> { x with pcd_attributes = attrs }\n | Type_declaration -> { x with ptype_attributes = attrs }\n | Type_extension -> { x with ptyext_attributes = attrs }\n | Type_exception -> { x with ptyexn_attributes = attrs }\n | Extension_constructor -> { x with pext_attributes = attrs }\n | Pattern -> { x with ppat_attributes = attrs }\n | Core_type -> { x with ptyp_attributes = attrs }\n | Expression -> { x with pexp_attributes = attrs }\n | Value_description -> { x with pval_attributes = attrs }\n | Class_type -> { x with pcty_attributes = attrs }\n | Class_type_field -> { x with pctf_attributes = attrs }\n | Class_infos -> { x with pci_attributes = attrs }\n | Class_expr -> { x with pcl_attributes = attrs }\n | Class_field -> { x with pcf_attributes = attrs }\n | Module_type -> { x with pmty_attributes = attrs }\n | Module_declaration -> { x with pmd_attributes = attrs }\n | Module_type_declaration -> { x with pmtd_attributes = attrs }\n | Module_substitution -> { x with pms_attributes = attrs }\n | Open_description -> { x with popen_attributes = attrs }\n | Open_declaration -> { x with popen_attributes = attrs }\n | Include_infos -> { x with pincl_attributes = attrs }\n | Module_expr -> { x with pmod_attributes = attrs }\n | Value_binding -> { x with pvb_attributes = attrs }\n | Module_binding -> { x with pmb_attributes = attrs }\n | Pstr_eval ->\n { x with pstr_desc = Pstr_eval (get_pstr_eval x |> fst, attrs) }\n | Pstr_extension ->\n {\n x with\n pstr_desc = Pstr_extension (get_pstr_extension x |> fst, attrs);\n }\n | Psig_extension ->\n {\n x with\n psig_desc = Psig_extension (get_psig_extension x |> fst, attrs);\n }\n | Rtag -> { x with prf_attributes = attrs }\n | Object_type_field -> { x with pof_attributes = attrs }\n\n let desc : type a. a t -> string = function\n | Label_declaration -> \"label declaration\"\n | Constructor_declaration -> \"constructor declaration\"\n | Type_declaration -> \"type declaration\"\n | Type_extension -> \"type extension\"\n | Type_exception -> \"type exception\"\n | Extension_constructor -> \"extension constructor\"\n | Pattern -> \"pattern\"\n | Core_type -> \"core type\"\n | Expression -> \"expression\"\n | Value_description -> \"value\"\n | Class_type -> \"class type\"\n | Class_type_field -> \"class type field\"\n | Class_infos -> \"class declaration\"\n | Class_expr -> \"class expression\"\n | Class_field -> \"class field\"\n | Module_type -> \"module type\"\n | Module_declaration -> \"module declaration\"\n | Module_type_declaration -> \"module type declaration\"\n | Module_substitution -> \"module substitution\"\n | Open_description -> \"open\"\n | Open_declaration -> \"open\"\n | Include_infos -> \"include\"\n | Module_expr -> \"module expression\"\n | Value_binding -> \"value binding\"\n | Module_binding -> \"module binding\"\n | Pstr_eval -> \"toplevel expression\"\n | Pstr_extension -> \"toplevel extension\"\n | Psig_extension -> \"toplevel signature extension\"\n | Rtag -> \"polymorphic variant tag\"\n | Object_type_field -> \"object type field\"\n\n (*\n let pattern : type a b c d. a t\n -> (attributes, b, c) Ast_pattern.t\n -> (a, c, d) Ast_pattern.t\n -> (a, b, d) Ast_pattern.t = function\n | Label_declaration -> Ast_pattern.pld_attributes\n | Constructor_declaration -> Ast_pattern.pcd_attributes\n | Type_declaration -> Ast_pattern.ptype_attributes\n | Type_extension -> Ast_pattern.ptyext_attributes\n | Extension_constructor -> Ast_pattern.pext_attributes\n*)\n\n let equal : _ t -> _ t -> bool = poly_equal\nend\n\nmodule Floating_context = struct\n type 'a t =\n | Structure_item : structure_item t\n | Signature_item : signature_item t\n | Class_field : class_field t\n | Class_type_field : class_type_field t\n\n let structure_item = Structure_item\n let signature_item = Signature_item\n let class_field = Class_field\n let class_type_field = Class_type_field\n\n let get_attribute_if_is_floating_node : type a. a t -> a -> attribute option =\n fun t x ->\n match (t, x) with\n | Structure_item, { pstr_desc = Pstr_attribute a; _ } -> Some a\n | Signature_item, { psig_desc = Psig_attribute a; _ } -> Some a\n | Class_field, { pcf_desc = Pcf_attribute a; _ } -> Some a\n | Class_type_field, { pctf_desc = Pctf_attribute a; _ } -> Some a\n | _ -> None\n\n let get_attribute t x =\n match get_attribute_if_is_floating_node t x with\n | Some a -> a\n | None -> failwith \"Attribute.Floating.Context.get_attribute\"\n\n let replace_by_dummy : type a. a t -> a -> a =\n let dummy_ext = ({ txt = \"\"; loc = Location.none }, PStr []) in\n fun t x ->\n match t with\n | Structure_item -> { x with pstr_desc = Pstr_extension (dummy_ext, []) }\n | Signature_item -> { x with psig_desc = Psig_extension (dummy_ext, []) }\n | Class_field -> { x with pcf_desc = Pcf_extension dummy_ext }\n | Class_type_field -> { x with pctf_desc = Pctf_extension dummy_ext }\n\n let desc : type a. a t -> string = function\n | Structure_item -> \"structure item\"\n | Signature_item -> \"signature item\"\n | Class_field -> \"class field\"\n | Class_type_field -> \"class type field\"\n\n let equal : _ t -> _ t -> bool = poly_equal\nend\n\ntype packed_context =\n | On_item : _ Context.t -> packed_context\n | Floating : _ Floating_context.t -> packed_context\n\ntype _ payload_parser =\n | Payload_parser :\n (payload, 'a, 'b) Ast_pattern.t * (name_loc:Location.t -> 'a)\n -> 'b payload_parser\n\ntype ('a, 'b) t = {\n name : Name.Pattern.t;\n context : 'a Context.t;\n payload : 'b payload_parser;\n}\n\ntype packed = T : (_, _) t -> packed\n\nlet name t = Name.Pattern.name t.name\nlet context t = t.context\n\nlet registrar =\n Name.Registrar.create ~kind:\"attribute\" ~current_file:__FILE__\n ~string_of_context:(function\n | On_item t -> Some (Context.desc t)\n | Floating t -> Some (Floating_context.desc t ^ \" (floating)\"))\n\nlet declare_with_name_loc name context pattern k =\n Name.Registrar.register ~kind:`Attribute registrar (On_item context) name;\n {\n name = Name.Pattern.make name;\n context;\n payload = Payload_parser (pattern, k);\n }\n\nlet declare name context pattern k =\n declare_with_name_loc name context pattern (fun ~name_loc:_ -> k)\n\nmodule Attribute_table = Caml.Hashtbl.Make (struct\n type t = string loc\n\n let hash : t -> int = Hashtbl.hash\n let equal : t -> t -> bool = Poly.equal\nend)\n\nlet not_seen = Attribute_table.create 128\nlet mark_as_seen { attr_name; _ } = Attribute_table.remove not_seen attr_name\nlet mark_as_handled_manually = mark_as_seen\n\nlet explicitly_drop =\n object\n inherit Ast_traverse.iter\n method! attribute = mark_as_seen\n end\n\nlet get_internal =\n let rec find_best_match t attributes longest_match =\n match attributes with\n | [] -> longest_match\n | ({ attr_name = name; _ } as attr) :: rest ->\n if Name.Pattern.matches t.name name.txt then\n match longest_match with\n | None -> find_best_match t rest (Some attr)\n | Some { attr_name = name'; _ } ->\n let len = String.length name.txt in\n let len' = String.length name'.txt in\n if len > len' then find_best_match t rest (Some attr)\n else if len < len' then find_best_match t rest longest_match\n else Location.raise_errorf ~loc:name.loc \"Duplicated attribute\"\n else find_best_match t rest longest_match\n in\n fun t attributes -> find_best_match t attributes None\n\nlet convert ?(do_mark_as_seen = true) pattern attr =\n if do_mark_as_seen then mark_as_seen attr;\n let (Payload_parser (pattern, k)) = pattern in\n Ast_pattern.parse pattern\n (Common.loc_of_payload attr)\n attr.attr_payload\n (k ~name_loc:attr.attr_name.loc)\n\nlet get t ?mark_as_seen:do_mark_as_seen x =\n let attrs = Context.get_attributes t.context x in\n match get_internal t attrs with\n | None -> None\n | Some attr -> Some (convert t.payload attr ?do_mark_as_seen)\n\nlet consume t x =\n let attrs = Context.get_attributes t.context x in\n match get_internal t attrs with\n | None -> None\n | Some attr ->\n let attrs = List.filter attrs ~f:(fun attr' -> not (attr == attr')) in\n let x = Context.set_attributes t.context x attrs in\n Some (x, convert t.payload attr)\n\nlet remove_seen (type a) (context : a Context.t) packeds (x : a) =\n let attrs = Context.get_attributes context x in\n let matched =\n let rec loop acc = function\n | [] -> acc\n | T t :: rest ->\n if Context.equal t.context context then\n match get_internal t attrs with\n | None -> loop acc rest\n | Some attr ->\n let name = attr.attr_name in\n if Attribute_table.mem not_seen name then loop acc rest\n else loop (attr :: acc) rest\n else loop acc rest\n in\n loop [] packeds\n in\n let attrs =\n List.filter attrs ~f:(fun attr' -> not (List.memq ~set:matched attr'))\n in\n Context.set_attributes context x attrs\n\nlet pattern t p =\n let f = Ast_pattern.to_func p in\n Ast_pattern.of_func (fun ctx loc x k ->\n match consume t x with\n | None -> f ctx loc x (k None)\n | Some (x, v) -> f ctx loc x (k (Some v)))\n\nmodule Floating = struct\n module Context = Floating_context\n\n type ('a, 'b) t = {\n name : Name.Pattern.t;\n context : 'a Context.t;\n payload : 'b payload_parser;\n }\n\n let name t = Name.Pattern.name t.name\n\n let declare name context pattern k =\n Name.Registrar.register ~kind:`Attribute registrar (Floating context) name;\n {\n name = Name.Pattern.make name;\n context;\n payload = Payload_parser (pattern, fun ~name_loc:_ -> k);\n }\n\n let convert ts x =\n match ts with\n | [] -> None\n | { context; _ } :: _ -> (\n assert (List.for_all ts ~f:(fun t -> Context.equal t.context context));\n let attr = Context.get_attribute context x in\n let name = attr.attr_name in\n match\n List.filter ts ~f:(fun t -> Name.Pattern.matches t.name name.txt)\n with\n | [] -> None\n | [ t ] -> Some (convert t.payload attr)\n | l ->\n Location.raise_errorf ~loc:name.loc\n \"Multiple match for floating attributes: %s\"\n (String.concat ~sep:\", \"\n (List.map l ~f:(fun t -> Name.Pattern.name t.name))))\nend\n\nlet check_attribute registrar context name =\n if\n (not\n (Name.Whitelisted.is_whitelisted ~kind:`Attribute name.txt\n || Name.ignore_checks name.txt))\n && Attribute_table.mem not_seen name\n then\n let white_list = Name.Whitelisted.get_attribute_list () in\n Name.Registrar.raise_errorf registrar context ~white_list\n \"Attribute `%s' was not used\" name\n\nlet check_unused =\n object (self)\n inherit Ast_traverse.iter as super\n\n method! attribute { attr_name = name; _ } =\n Location.raise_errorf ~loc:name.loc\n \"attribute not expected here, Ppxlib.Attribute needs updating!\"\n\n method private check_node : type a. a Context.t -> a -> a =\n fun context node ->\n let attrs = Context.get_attributes context node in\n match attrs with\n | [] -> node\n | _ ->\n List.iter attrs\n ~f:(fun ({ attr_name = name; attr_payload = payload; _ } as attr)\n ->\n self#payload payload;\n check_attribute registrar (On_item context) name;\n (* If we allow the attribute to pass through, mark it as seen *)\n mark_as_seen attr);\n Context.set_attributes context node []\n\n method private check_floating : type a. a Floating.Context.t -> a -> a =\n fun context node ->\n match\n Floating.Context.get_attribute_if_is_floating_node context node\n with\n | None -> node\n | Some ({ attr_name = name; attr_payload = payload; _ } as attr) ->\n self#payload payload;\n check_attribute registrar (Floating context) name;\n mark_as_seen attr;\n Floating.Context.replace_by_dummy context node\n\n method! label_declaration x =\n super#label_declaration (self#check_node Label_declaration x)\n\n method! constructor_declaration x =\n super#constructor_declaration (self#check_node Constructor_declaration x)\n\n method! type_declaration x =\n super#type_declaration (self#check_node Type_declaration x)\n\n method! type_extension x =\n super#type_extension (self#check_node Type_extension x)\n\n method! type_exception x =\n super#type_exception (self#check_node Type_exception x)\n\n method! extension_constructor x =\n super#extension_constructor (self#check_node Extension_constructor x)\n\n method! pattern x = super#pattern (self#check_node Pattern x)\n method! core_type x = super#core_type (self#check_node Core_type x)\n method! expression x = super#expression (self#check_node Expression x)\n\n method! value_description x =\n super#value_description (self#check_node Value_description x)\n\n method! class_type x = super#class_type (self#check_node Class_type x)\n\n method! class_infos f x =\n super#class_infos f (self#check_node Class_infos x)\n\n method! class_expr x = super#class_expr (self#check_node Class_expr x)\n method! module_type x = super#module_type (self#check_node Module_type x)\n\n method! module_declaration x =\n super#module_declaration (self#check_node Module_declaration x)\n\n method! module_type_declaration x =\n super#module_type_declaration (self#check_node Module_type_declaration x)\n\n method! open_description x =\n super#open_description (self#check_node Open_description x)\n\n method! open_declaration x =\n super#open_declaration (self#check_node Open_declaration x)\n\n method! include_infos f x =\n super#include_infos f (self#check_node Include_infos x)\n\n method! module_expr x = super#module_expr (self#check_node Module_expr x)\n\n method! value_binding x =\n super#value_binding (self#check_node Value_binding x)\n\n method! module_binding x =\n super#module_binding (self#check_node Module_binding x)\n\n method! class_field x =\n let x = self#check_node Class_field x in\n let x = self#check_floating Class_field x in\n super#class_field x\n\n method! class_type_field x =\n let x = self#check_node Class_type_field x in\n let x = self#check_floating Class_type_field x in\n super#class_type_field x\n\n method! row_field x =\n let x =\n match x.prf_desc with Rtag _ -> self#check_node Rtag x | _ -> x\n in\n super#row_field x\n\n method! core_type_desc x =\n let x =\n match x with\n | Ptyp_object (fields, closed_flag) ->\n let fields =\n List.map fields ~f:(self#check_node Object_type_field)\n in\n Ptyp_object (fields, closed_flag)\n | _ -> x\n in\n super#core_type_desc x\n\n method! structure_item item =\n let item = self#check_floating Structure_item item in\n let item =\n match item.pstr_desc with\n | Pstr_eval _ -> self#check_node Pstr_eval item\n | Pstr_extension _ -> self#check_node Pstr_extension item\n | _ -> item\n in\n super#structure_item item\n\n method! signature_item item =\n let item = self#check_floating Signature_item item in\n let item =\n match item.psig_desc with\n | Psig_extension _ -> self#check_node Psig_extension item\n | _ -> item\n in\n super#signature_item item\n end\n\nlet reset_checks () = Attribute_table.clear not_seen\n\nlet collect =\n object\n inherit Ast_traverse.iter as super\n\n method! attribute ({ attr_name = name; attr_payload = payload; _ } as attr)\n =\n let loc = Common.loc_of_attribute attr in\n super#payload payload;\n Attribute_table.add not_seen name loc\n end\n\nlet check_all_seen () =\n let fail name loc =\n let txt = name.txt in\n if not (Name.ignore_checks txt) then\n Location.raise_errorf ~loc \"Attribute `%s' was silently dropped\" txt\n in\n Attribute_table.iter fail not_seen\n\nlet remove_attributes_present_in table =\n object\n inherit Ast_traverse.iter as super\n\n method! attribute { attr_name = name; attr_payload = payload; _ } =\n super#payload payload;\n Attribute_table.remove table name\n end\n\nlet copy_of_not_seen () =\n let copy = Attribute_table.create (Attribute_table.length not_seen) in\n Attribute_table.iter (Attribute_table.add copy) not_seen;\n copy\n\nlet dropped_so_far_structure st =\n let table = copy_of_not_seen () in\n (remove_attributes_present_in table)#structure st;\n Attribute_table.fold\n (fun name loc acc -> { txt = name.txt; loc } :: acc)\n table []\n\nlet dropped_so_far_signature sg =\n let table = copy_of_not_seen () in\n (remove_attributes_present_in table)#signature sg;\n Attribute_table.fold\n (fun name loc acc -> { txt = name.txt; loc } :: acc)\n table []\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Pierre Weis, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* A pretty-printing facility and definition of formatters for 'parallel'\n (i.e. unrelated or independent) pretty-printing on multiple out channels. *)\n\n(*\n The pretty-printing engine internal data structures.\n*)\n\nlet id x = x\n\n(* A devoted type for sizes to avoid confusion\n between sizes and mere integers. *)\nmodule Size : sig\n type t\n\n val to_int : t -> int\n val of_int : int -> t\n val zero : t\n val unknown : t\n val is_known : t -> bool\nend = struct\n type t = int\n\n let to_int = id\n let of_int = id\n let zero = 0\n let unknown = -1\n let is_known n = n >= 0\nend\n\n\n\n(* The pretty-printing boxes definition:\n a pretty-printing box is either\n - hbox: horizontal box (no line splitting)\n - vbox: vertical box (every break hint splits the line)\n - hvbox: horizontal/vertical box\n (the box behaves as an horizontal box if it fits on\n the current line, otherwise the box behaves as a vertical box)\n - hovbox: horizontal or vertical compacting box\n (the box is compacting material, printing as much material as possible\n on every lines)\n - box: horizontal or vertical compacting box with enhanced box structure\n (the box behaves as an horizontal or vertical box but break hints split\n the line if splitting would move to the left)\n*)\ntype box_type = CamlinternalFormatBasics.block_type =\n | Pp_hbox | Pp_vbox | Pp_hvbox | Pp_hovbox | Pp_box | Pp_fits\n\n\n(* The pretty-printing tokens definition:\n are either text to print or pretty printing\n elements that drive indentation and line splitting. *)\ntype pp_token =\n | Pp_text of string (* normal text *)\n | Pp_break of { (* complete break *)\n fits: string * int * string; (* line is not split *)\n breaks: string * int * string; (* line is split *)\n }\n | Pp_tbreak of int * int (* go to next tabulation *)\n | Pp_stab (* set a tabulation *)\n | Pp_begin of int * box_type (* beginning of a box *)\n | Pp_end (* end of a box *)\n | Pp_tbegin of tbox (* beginning of a tabulation box *)\n | Pp_tend (* end of a tabulation box *)\n | Pp_newline (* to force a newline inside a box *)\n | Pp_if_newline (* to do something only if this very\n line has been broken *)\n | Pp_open_tag of stag (* opening a tag name *)\n | Pp_close_tag (* closing the most recently open tag *)\n\nand stag = ..\n\nand tbox = Pp_tbox of int list ref (* Tabulation box *)\n\ntype tag = string\ntype stag += String_tag of tag\n\n\n(* The pretty-printer queue:\n pretty-printing material is not written in the output as soon as emitted;\n instead, the material is simply recorded in the pretty-printer queue,\n until the enclosing box has a known computed size and proper splitting\n decisions can be made.\n\n The pretty-printer queue contains formatting elements to be printed.\n Each formatting element is a tuple (size, token, length), where\n - length is the declared length of the token,\n - size is effective size of the token when it is printed\n (size is set when the size of the box is known, so that size of break\n hints are definitive). *)\ntype pp_queue_elem = {\n mutable size : Size.t;\n token : pp_token;\n length : int;\n}\n\n\n(* The pretty-printer queue definition. *)\ntype pp_queue = pp_queue_elem Queue.t\n\n(* The pretty-printer scanning stack. *)\n\n(* The pretty-printer scanning stack: scanning element definition. *)\ntype pp_scan_elem = {\n left_total : int; (* Value of pp_left_total when the element was enqueued. *)\n queue_elem : pp_queue_elem\n}\n\n(* The pretty-printer formatting stack:\n the formatting stack contains the description of all the currently active\n boxes; the pretty-printer formatting stack is used to split the lines\n while printing tokens. *)\n\n(* The pretty-printer formatting stack: formatting stack element definition.\n Each stack element describes a pretty-printing box. *)\ntype pp_format_elem = { box_type : box_type; width : int }\n\n(* The formatter definition.\n Each formatter value is a pretty-printer instance with all its\n machinery. *)\ntype formatter = {\n (* The pretty-printer scanning stack. *)\n pp_scan_stack : pp_scan_elem Stack.t;\n (* The pretty-printer formatting stack. *)\n pp_format_stack : pp_format_elem Stack.t;\n pp_tbox_stack : tbox Stack.t;\n (* The pretty-printer semantics tag stack. *)\n pp_tag_stack : stag Stack.t;\n pp_mark_stack : stag Stack.t;\n (* Value of right margin. *)\n mutable pp_margin : int;\n (* Minimal space left before margin, when opening a box. *)\n mutable pp_min_space_left : int;\n (* Maximum value of indentation:\n no box can be opened further. *)\n mutable pp_max_indent : int;\n (* Space remaining on the current line. *)\n mutable pp_space_left : int;\n (* Current value of indentation. *)\n mutable pp_current_indent : int;\n (* True when the line has been broken by the pretty-printer. *)\n mutable pp_is_new_line : bool;\n (* Total width of tokens already printed. *)\n mutable pp_left_total : int;\n (* Total width of tokens ever put in queue. *)\n mutable pp_right_total : int;\n (* Current number of open boxes. *)\n mutable pp_curr_depth : int;\n (* Maximum number of boxes which can be simultaneously open. *)\n mutable pp_max_boxes : int;\n (* Ellipsis string. *)\n mutable pp_ellipsis : string;\n (* Output function. *)\n mutable pp_out_string : string -> int -> int -> unit;\n (* Flushing function. *)\n mutable pp_out_flush : unit -> unit;\n (* Output of new lines. *)\n mutable pp_out_newline : unit -> unit;\n (* Output of break hints spaces. *)\n mutable pp_out_spaces : int -> unit;\n (* Output of indentation of new lines. *)\n mutable pp_out_indent : int -> unit;\n (* Are tags printed ? *)\n mutable pp_print_tags : bool;\n (* Are tags marked ? *)\n mutable pp_mark_tags : bool;\n (* Find opening and closing markers of tags. *)\n mutable pp_mark_open_tag : stag -> string;\n mutable pp_mark_close_tag : stag -> string;\n mutable pp_print_open_tag : stag -> unit;\n mutable pp_print_close_tag : stag -> unit;\n (* The pretty-printer queue. *)\n pp_queue : pp_queue;\n}\n\n\n(* The formatter specific tag handling functions. *)\ntype formatter_stag_functions = {\n mark_open_stag : stag -> string;\n mark_close_stag : stag -> string;\n print_open_stag : stag -> unit;\n print_close_stag : stag -> unit;\n}\n\n\n(* The formatter functions to output material. *)\ntype formatter_out_functions = {\n out_string : string -> int -> int -> unit;\n out_flush : unit -> unit;\n out_newline : unit -> unit;\n out_spaces : int -> unit;\n out_indent : int -> unit;\n}\n\n\n(*\n\n Auxiliaries and basic functions.\n\n*)\n\n(* Enter a token in the pretty-printer queue. *)\nlet pp_enqueue state token =\n state.pp_right_total <- state.pp_right_total + token.length;\n Queue.add token state.pp_queue\n\n\nlet pp_clear_queue state =\n state.pp_left_total <- 1; state.pp_right_total <- 1;\n Queue.clear state.pp_queue\n\n\n(* Pp_infinity: large value for default tokens size.\n\n Pp_infinity is documented as being greater than 1e10; to avoid\n confusion about the word 'greater', we choose pp_infinity greater\n than 1e10 + 1; for correct handling of tests in the algorithm,\n pp_infinity must be even one more than 1e10 + 1; let's stand on the\n safe side by choosing 1.e10+10.\n\n Pp_infinity could probably be 1073741823 that is 2^30 - 1, that is\n the minimal upper bound for integers; now that max_int is defined,\n this limit could also be defined as max_int - 1.\n\n However, before setting pp_infinity to something around max_int, we\n must carefully double-check all the integer arithmetic operations\n that involve pp_infinity, since any overflow would wreck havoc the\n pretty-printing algorithm's invariants. Given that this arithmetic\n correctness check is difficult and error prone and given that 1e10\n + 1 is in practice large enough, there is no need to attempt to set\n pp_infinity to the theoretically maximum limit. It is not worth the\n burden ! *)\nlet pp_infinity = 1000000010\n\n(* Output functions for the formatter. *)\nlet pp_output_string state s = state.pp_out_string s 0 (String.length s)\nand pp_output_newline state = state.pp_out_newline ()\nand pp_output_spaces state n = state.pp_out_spaces n\nand pp_output_indent state n = state.pp_out_indent n\n\n(* Format a textual token *)\nlet format_pp_text state size text =\n state.pp_space_left <- state.pp_space_left - size;\n pp_output_string state text;\n state.pp_is_new_line <- false\n\n(* Format a string by its length, if not empty *)\nlet format_string state s =\n if s <> \"\" then format_pp_text state (String.length s) s\n\n(* To format a break, indenting a new line. *)\nlet break_new_line state (before, offset, after) width =\n format_string state before;\n pp_output_newline state;\n state.pp_is_new_line <- true;\n let indent = state.pp_margin - width + offset in\n (* Don't indent more than pp_max_indent. *)\n let real_indent = Int.min state.pp_max_indent indent in\n state.pp_current_indent <- real_indent;\n state.pp_space_left <- state.pp_margin - state.pp_current_indent;\n pp_output_indent state state.pp_current_indent;\n format_string state after\n\n\n(* To force a line break inside a box: no offset is added. *)\nlet break_line state width = break_new_line state (\"\", 0, \"\") width\n\n(* To format a break that fits on the current line. *)\nlet break_same_line state (before, width, after) =\n format_string state before;\n state.pp_space_left <- state.pp_space_left - width;\n pp_output_spaces state width;\n format_string state after\n\n\n(* To indent no more than pp_max_indent, if one tries to open a box\n beyond pp_max_indent, then the box is rejected on the left\n by simulating a break. *)\nlet pp_force_break_line state =\n match Stack.top_opt state.pp_format_stack with\n | None -> pp_output_newline state\n | Some { box_type; width } ->\n if width > state.pp_space_left then\n match box_type with\n | Pp_fits | Pp_hbox -> ()\n | Pp_vbox | Pp_hvbox | Pp_hovbox | Pp_box -> break_line state width\n\n\n(* To skip a token, if the previous line has been broken. *)\nlet pp_skip_token state =\n match Queue.take_opt state.pp_queue with\n | None -> () (* print_if_newline must have been the last printing command *)\n | Some { size; length; _ } ->\n state.pp_left_total <- state.pp_left_total - length;\n state.pp_space_left <- state.pp_space_left + Size.to_int size\n\n\n(*\n\n The main pretty printing functions.\n\n*)\n\n(* Formatting a token with a given size. *)\nlet format_pp_token state size = function\n\n | Pp_text s ->\n format_pp_text state size s\n\n | Pp_begin (off, ty) ->\n let insertion_point = state.pp_margin - state.pp_space_left in\n if insertion_point > state.pp_max_indent then\n (* can not open a box right there. *)\n begin pp_force_break_line state end;\n let width = state.pp_space_left - off in\n let box_type =\n match ty with\n | Pp_vbox -> Pp_vbox\n | Pp_hbox | Pp_hvbox | Pp_hovbox | Pp_box | Pp_fits ->\n if size > state.pp_space_left then ty else Pp_fits in\n Stack.push { box_type; width } state.pp_format_stack\n\n | Pp_end ->\n Stack.pop_opt state.pp_format_stack |> ignore\n\n | Pp_tbegin (Pp_tbox _ as tbox) ->\n Stack.push tbox state.pp_tbox_stack\n\n | Pp_tend ->\n Stack.pop_opt state.pp_tbox_stack |> ignore\n\n | Pp_stab ->\n begin match Stack.top_opt state.pp_tbox_stack with\n | None -> () (* No open tabulation box. *)\n | Some (Pp_tbox tabs) ->\n let rec add_tab n = function\n | [] -> [n]\n | x :: l as ls -> if n < x then n :: ls else x :: add_tab n l in\n tabs := add_tab (state.pp_margin - state.pp_space_left) !tabs\n end\n\n | Pp_tbreak (n, off) ->\n let insertion_point = state.pp_margin - state.pp_space_left in\n begin match Stack.top_opt state.pp_tbox_stack with\n | None -> () (* No open tabulation box. *)\n | Some (Pp_tbox tabs) ->\n let tab =\n match !tabs with\n | [] -> insertion_point\n | first :: _ ->\n let rec find = function\n | head :: tail ->\n if head >= insertion_point then head else find tail\n | [] -> first in\n find !tabs in\n let offset = tab - insertion_point in\n if offset >= 0\n then break_same_line state (\"\", offset + n, \"\")\n else break_new_line state (\"\", tab + off, \"\") state.pp_margin\n end\n\n | Pp_newline ->\n begin match Stack.top_opt state.pp_format_stack with\n | None -> pp_output_newline state (* No open box. *)\n | Some { width; _} -> break_line state width\n end\n\n | Pp_if_newline ->\n if state.pp_current_indent != state.pp_margin - state.pp_space_left\n then pp_skip_token state\n\n | Pp_break { fits; breaks } ->\n let before, off, _ = breaks in\n begin match Stack.top_opt state.pp_format_stack with\n | None -> () (* No open box. *)\n | Some { box_type; width } ->\n begin match box_type with\n | Pp_hovbox ->\n if size + String.length before > state.pp_space_left\n then break_new_line state breaks width\n else break_same_line state fits\n | Pp_box ->\n (* Have the line just been broken here ? *)\n if state.pp_is_new_line then break_same_line state fits else\n if size + String.length before > state.pp_space_left\n then break_new_line state breaks width else\n (* break the line here leads to new indentation ? *)\n if state.pp_current_indent > state.pp_margin - width + off\n then break_new_line state breaks width\n else break_same_line state fits\n | Pp_hvbox -> break_new_line state breaks width\n | Pp_fits -> break_same_line state fits\n | Pp_vbox -> break_new_line state breaks width\n | Pp_hbox -> break_same_line state fits\n end\n end\n\n | Pp_open_tag tag_name ->\n let marker = state.pp_mark_open_tag tag_name in\n pp_output_string state marker;\n Stack.push tag_name state.pp_mark_stack\n\n | Pp_close_tag ->\n begin match Stack.pop_opt state.pp_mark_stack with\n | None -> () (* No more tag to close. *)\n | Some tag_name ->\n let marker = state.pp_mark_close_tag tag_name in\n pp_output_string state marker\n end\n\n\n(* Print if token size is known else printing is delayed.\n Printing is delayed when the text waiting in the queue requires\n more room to format than exists on the current line. *)\nlet rec advance_left state =\n match Queue.peek_opt state.pp_queue with\n | None -> () (* No tokens to print *)\n | Some { size; token; length } ->\n let pending_count = state.pp_right_total - state.pp_left_total in\n if Size.is_known size || pending_count >= state.pp_space_left then begin\n Queue.take state.pp_queue |> ignore; (* Not empty: we peek into it *)\n let size = if Size.is_known size then Size.to_int size else pp_infinity in\n format_pp_token state size token;\n state.pp_left_total <- length + state.pp_left_total;\n (advance_left [@tailcall]) state\n end\n\n\n(* To enqueue a token : try to advance. *)\nlet enqueue_advance state tok = pp_enqueue state tok; advance_left state\n\n\n(* To enqueue strings. *)\nlet enqueue_string_as state size s =\n enqueue_advance state { size; token = Pp_text s; length = Size.to_int size }\n\n\nlet enqueue_string state s =\n enqueue_string_as state (Size.of_int (String.length s)) s\n\n\n(* Routines for scan stack\n determine size of boxes. *)\n\n(* The scan_stack is never empty. *)\nlet initialize_scan_stack stack =\n Stack.clear stack;\n let queue_elem = { size = Size.unknown; token = Pp_text \"\"; length = 0 } in\n Stack.push { left_total = -1; queue_elem } stack\n\n(* Setting the size of boxes on scan stack:\n if ty = true then size of break is set else size of box is set;\n in each case pp_scan_stack is popped.\n\n Note:\n Pattern matching on scan stack is exhaustive, since scan_stack is never\n empty.\n Pattern matching on token in scan stack is also exhaustive,\n since scan_push is used on breaks and opening of boxes. *)\nlet set_size state ty =\n match Stack.top_opt state.pp_scan_stack with\n | None -> () (* scan_stack is never empty. *)\n | Some { left_total; queue_elem } ->\n let size = Size.to_int queue_elem.size in\n (* test if scan stack contains any data that is not obsolete. *)\n if left_total < state.pp_left_total then\n initialize_scan_stack state.pp_scan_stack\n else\n match queue_elem.token with\n | Pp_break _ | Pp_tbreak (_, _) ->\n if ty then begin\n queue_elem.size <- Size.of_int (state.pp_right_total + size);\n Stack.pop_opt state.pp_scan_stack |> ignore\n end\n | Pp_begin (_, _) ->\n if not ty then begin\n queue_elem.size <- Size.of_int (state.pp_right_total + size);\n Stack.pop_opt state.pp_scan_stack |> ignore\n end\n | Pp_text _ | Pp_stab | Pp_tbegin _ | Pp_tend | Pp_end\n | Pp_newline | Pp_if_newline | Pp_open_tag _ | Pp_close_tag ->\n () (* scan_push is only used for breaks and boxes. *)\n\n\n(* Push a token on pretty-printer scanning stack.\n If b is true set_size is called. *)\nlet scan_push state b token =\n pp_enqueue state token;\n if b then set_size state true;\n let elem = { left_total = state.pp_right_total; queue_elem = token } in\n Stack.push elem state.pp_scan_stack\n\n\n(* To open a new box :\n the user may set the depth bound pp_max_boxes\n any text nested deeper is printed as the ellipsis string. *)\nlet pp_open_box_gen state indent br_ty =\n state.pp_curr_depth <- state.pp_curr_depth + 1;\n if state.pp_curr_depth < state.pp_max_boxes then\n let size = Size.of_int (- state.pp_right_total) in\n let elem = { size; token = Pp_begin (indent, br_ty); length = 0 } in\n scan_push state false elem else\n if state.pp_curr_depth = state.pp_max_boxes\n then enqueue_string state state.pp_ellipsis\n\n\n(* The box which is always open. *)\nlet pp_open_sys_box state = pp_open_box_gen state 0 Pp_hovbox\n\n(* Close a box, setting sizes of its sub boxes. *)\nlet pp_close_box state () =\n if state.pp_curr_depth > 1 then\n begin\n if state.pp_curr_depth < state.pp_max_boxes then\n begin\n pp_enqueue state { size = Size.zero; token = Pp_end; length = 0 };\n set_size state true; set_size state false\n end;\n state.pp_curr_depth <- state.pp_curr_depth - 1;\n end\n\n\n(* Open a tag, pushing it on the tag stack. *)\nlet pp_open_stag state tag_name =\n if state.pp_print_tags then\n begin\n Stack.push tag_name state.pp_tag_stack;\n state.pp_print_open_tag tag_name\n end;\n if state.pp_mark_tags then\n let token = Pp_open_tag tag_name in\n pp_enqueue state { size = Size.zero; token; length = 0 }\n\n\n(* Close a tag, popping it from the tag stack. *)\nlet pp_close_stag state () =\n if state.pp_mark_tags then\n pp_enqueue state { size = Size.zero; token = Pp_close_tag; length = 0 };\n if state.pp_print_tags then\n match Stack.pop_opt state.pp_tag_stack with\n | None -> () (* No more tag to close. *)\n | Some tag_name ->\n state.pp_print_close_tag tag_name\n\nlet pp_open_tag state s = pp_open_stag state (String_tag s)\nlet pp_close_tag state () = pp_close_stag state ()\n\nlet pp_set_print_tags state b = state.pp_print_tags <- b\nlet pp_set_mark_tags state b = state.pp_mark_tags <- b\nlet pp_get_print_tags state () = state.pp_print_tags\nlet pp_get_mark_tags state () = state.pp_mark_tags\nlet pp_set_tags state b =\n pp_set_print_tags state b; pp_set_mark_tags state b\n\n\n(* Handling tag handling functions: get/set functions. *)\nlet pp_get_formatter_stag_functions state () = {\n mark_open_stag = state.pp_mark_open_tag;\n mark_close_stag = state.pp_mark_close_tag;\n print_open_stag = state.pp_print_open_tag;\n print_close_stag = state.pp_print_close_tag;\n}\n\n\nlet pp_set_formatter_stag_functions state {\n mark_open_stag = mot;\n mark_close_stag = mct;\n print_open_stag = pot;\n print_close_stag = pct;\n } =\n state.pp_mark_open_tag <- mot;\n state.pp_mark_close_tag <- mct;\n state.pp_print_open_tag <- pot;\n state.pp_print_close_tag <- pct\n\n\n(* Initialize pretty-printer. *)\nlet pp_rinit state =\n pp_clear_queue state;\n initialize_scan_stack state.pp_scan_stack;\n Stack.clear state.pp_format_stack;\n Stack.clear state.pp_tbox_stack;\n Stack.clear state.pp_tag_stack;\n Stack.clear state.pp_mark_stack;\n state.pp_current_indent <- 0;\n state.pp_curr_depth <- 0;\n state.pp_space_left <- state.pp_margin;\n pp_open_sys_box state\n\nlet clear_tag_stack state =\n Stack.iter (fun _ -> pp_close_tag state ()) state.pp_tag_stack\n\n\n(* Flushing pretty-printer queue. *)\nlet pp_flush_queue state b =\n clear_tag_stack state;\n while state.pp_curr_depth > 1 do\n pp_close_box state ()\n done;\n state.pp_right_total <- pp_infinity;\n advance_left state;\n if b then pp_output_newline state;\n pp_rinit state\n\n(*\n\n Procedures to format values and use boxes.\n\n*)\n\n(* To format a string. *)\nlet pp_print_as_size state size s =\n if state.pp_curr_depth < state.pp_max_boxes\n then enqueue_string_as state size s\n\n\nlet pp_print_as state isize s =\n pp_print_as_size state (Size.of_int isize) s\n\n\nlet pp_print_string state s =\n pp_print_as state (String.length s) s\n\nlet pp_print_bytes state s =\n pp_print_as state (Bytes.length s) (Bytes.to_string s)\n\n(* To format an integer. *)\nlet pp_print_int state i = pp_print_string state (Int.to_string i)\n\n(* To format a float. *)\nlet pp_print_float state f = pp_print_string state (string_of_float f)\n\n(* To format a boolean. *)\nlet pp_print_bool state b = pp_print_string state (string_of_bool b)\n\n(* To format a char. *)\nlet pp_print_char state c =\n pp_print_as state 1 (String.make 1 c)\n\n\n(* Opening boxes. *)\nlet pp_open_hbox state () = pp_open_box_gen state 0 Pp_hbox\nand pp_open_vbox state indent = pp_open_box_gen state indent Pp_vbox\n\nand pp_open_hvbox state indent = pp_open_box_gen state indent Pp_hvbox\nand pp_open_hovbox state indent = pp_open_box_gen state indent Pp_hovbox\nand pp_open_box state indent = pp_open_box_gen state indent Pp_box\n\n\n(* Printing queued text.\n\n [pp_print_flush] prints all pending items in the pretty-printer queue and\n then flushes the low level output device of the formatter to actually\n display printing material.\n\n [pp_print_newline] behaves as [pp_print_flush] after printing an additional\n new line. *)\nlet pp_print_newline state () =\n pp_flush_queue state true; state.pp_out_flush ()\nand pp_print_flush state () =\n pp_flush_queue state false; state.pp_out_flush ()\n\n\n(* To get a newline when one does not want to close the current box. *)\nlet pp_force_newline state () =\n if state.pp_curr_depth < state.pp_max_boxes then\n enqueue_advance state { size = Size.zero; token = Pp_newline; length = 0 }\n\n\n(* To format something, only in case the line has just been broken. *)\nlet pp_print_if_newline state () =\n if state.pp_curr_depth < state.pp_max_boxes then\n enqueue_advance state\n { size = Size.zero; token = Pp_if_newline; length = 0 }\n\n\n(* Generalized break hint that allows printing strings before/after\n same-line offset (width) or new-line offset *)\nlet pp_print_custom_break state ~fits ~breaks =\n let before, width, after = fits in\n if state.pp_curr_depth < state.pp_max_boxes then\n let size = Size.of_int (- state.pp_right_total) in\n let token = Pp_break { fits; breaks } in\n let length = String.length before + width + String.length after in\n let elem = { size; token; length } in\n scan_push state true elem\n\n(* Printing break hints:\n A break hint indicates where a box may be broken.\n If line is broken then offset is added to the indentation of the current\n box else (the value of) width blanks are printed. *)\nlet pp_print_break state width offset =\n pp_print_custom_break state\n ~fits:(\"\", width, \"\") ~breaks:(\"\", offset, \"\")\n\n\n(* Print a space :\n a space is a break hint that prints a single space if the break does not\n split the line;\n a cut is a break hint that prints nothing if the break does not split the\n line. *)\nlet pp_print_space state () = pp_print_break state 1 0\nand pp_print_cut state () = pp_print_break state 0 0\n\n\n(* Tabulation boxes. *)\nlet pp_open_tbox state () =\n state.pp_curr_depth <- state.pp_curr_depth + 1;\n if state.pp_curr_depth < state.pp_max_boxes then\n let size = Size.zero in\n let elem = { size; token = Pp_tbegin (Pp_tbox (ref [])); length = 0 } in\n enqueue_advance state elem\n\n\n(* Close a tabulation box. *)\nlet pp_close_tbox state () =\n if state.pp_curr_depth > 1 then\n begin\n if state.pp_curr_depth < state.pp_max_boxes then\n let elem = { size = Size.zero; token = Pp_tend; length = 0 } in\n enqueue_advance state elem;\n state.pp_curr_depth <- state.pp_curr_depth - 1\n end\n\n\n(* Print a tabulation break. *)\nlet pp_print_tbreak state width offset =\n if state.pp_curr_depth < state.pp_max_boxes then\n let size = Size.of_int (- state.pp_right_total) in\n let elem = { size; token = Pp_tbreak (width, offset); length = width } in\n scan_push state true elem\n\n\nlet pp_print_tab state () = pp_print_tbreak state 0 0\n\nlet pp_set_tab state () =\n if state.pp_curr_depth < state.pp_max_boxes then\n let elem = { size = Size.zero; token = Pp_stab; length = 0 } in\n enqueue_advance state elem\n\n\n(*\n\n Procedures to control the pretty-printers\n\n*)\n\n(* Set_max_boxes. *)\nlet pp_set_max_boxes state n = if n > 1 then state.pp_max_boxes <- n\n\n(* To know the current maximum number of boxes allowed. *)\nlet pp_get_max_boxes state () = state.pp_max_boxes\n\nlet pp_over_max_boxes state () = state.pp_curr_depth = state.pp_max_boxes\n\n(* Ellipsis. *)\nlet pp_set_ellipsis_text state s = state.pp_ellipsis <- s\nand pp_get_ellipsis_text state () = state.pp_ellipsis\n\n\n(* To set the margin of pretty-printer. *)\nlet pp_limit n =\n if n < pp_infinity then n else pred pp_infinity\n\n\n(* Internal pretty-printer functions. *)\nlet pp_set_min_space_left state n =\n if n >= 1 then\n let n = pp_limit n in\n state.pp_min_space_left <- n;\n state.pp_max_indent <- state.pp_margin - state.pp_min_space_left;\n pp_rinit state\n\n\n(* Initially, we have :\n pp_max_indent = pp_margin - pp_min_space_left, and\n pp_space_left = pp_margin. *)\nlet pp_set_max_indent state n =\n if n > 1 then\n pp_set_min_space_left state (state.pp_margin - n)\n\n\nlet pp_get_max_indent state () = state.pp_max_indent\n\nlet pp_set_margin state n =\n if n >= 1 then\n let n = pp_limit n in\n state.pp_margin <- n;\n let new_max_indent =\n (* Try to maintain max_indent to its actual value. *)\n if state.pp_max_indent <= state.pp_margin\n then state.pp_max_indent else\n (* If possible maintain pp_min_space_left to its actual value,\n if this leads to a too small max_indent, take half of the\n new margin, if it is greater than 1. *)\n Int.max (Int.max (state.pp_margin - state.pp_min_space_left)\n (state.pp_margin / 2)) 1 in\n (* Rebuild invariants. *)\n pp_set_max_indent state new_max_indent\n\n\n(** Geometry functions and types *)\ntype geometry = { max_indent:int; margin: int}\n\nlet validate_geometry {margin; max_indent} =\n if max_indent < 2 then\n Error \"max_indent < 2\"\n else if margin <= max_indent then\n Error \"margin <= max_indent\"\n else Ok ()\n\nlet check_geometry geometry =\n match validate_geometry geometry with\n | Ok () -> true\n | Error _ -> false\n\nlet pp_get_margin state () = state.pp_margin\n\nlet pp_set_full_geometry state {margin; max_indent} =\n pp_set_margin state margin;\n pp_set_max_indent state max_indent;\n ()\n\nlet pp_set_geometry state ~max_indent ~margin =\n let geometry = { max_indent; margin } in\n match validate_geometry geometry with\n | Error msg ->\n raise (Invalid_argument (\"Format.pp_set_geometry: \" ^ msg))\n | Ok () ->\n pp_set_full_geometry state geometry\n\nlet pp_safe_set_geometry state ~max_indent ~margin =\n let geometry = { max_indent; margin } in\n match validate_geometry geometry with\n | Error _msg ->\n ()\n | Ok () ->\n pp_set_full_geometry state geometry\n\nlet pp_get_geometry state () =\n { margin = pp_get_margin state (); max_indent = pp_get_max_indent state () }\n\nlet pp_update_geometry state update =\n let geometry = pp_get_geometry state () in\n pp_set_full_geometry state (update geometry)\n\n(* Setting a formatter basic output functions. *)\nlet pp_set_formatter_out_functions state {\n out_string = f;\n out_flush = g;\n out_newline = h;\n out_spaces = i;\n out_indent = j;\n } =\n state.pp_out_string <- f;\n state.pp_out_flush <- g;\n state.pp_out_newline <- h;\n state.pp_out_spaces <- i;\n state.pp_out_indent <- j\n\nlet pp_get_formatter_out_functions state () = {\n out_string = state.pp_out_string;\n out_flush = state.pp_out_flush;\n out_newline = state.pp_out_newline;\n out_spaces = state.pp_out_spaces;\n out_indent = state.pp_out_indent;\n}\n\n\n(* Setting a formatter basic string output and flush functions. *)\nlet pp_set_formatter_output_functions state f g =\n state.pp_out_string <- f; state.pp_out_flush <- g\n\nlet pp_get_formatter_output_functions state () =\n (state.pp_out_string, state.pp_out_flush)\n\n\n(* The default function to output new lines. *)\nlet display_newline state () = state.pp_out_string \"\\n\" 0 1\n\n(* The default function to output spaces. *)\nlet blank_line = String.make 80 ' '\nlet rec display_blanks state n =\n if n > 0 then\n if n <= 80 then state.pp_out_string blank_line 0 n else\n begin\n state.pp_out_string blank_line 0 80;\n display_blanks state (n - 80)\n end\n\n\n(* The default function to output indentation of new lines. *)\nlet display_indent = display_blanks\n\n(* Setting a formatter basic output functions as printing to a given\n [Pervasive.out_channel] value. *)\nlet pp_set_formatter_out_channel state oc =\n state.pp_out_string <- output_substring oc;\n state.pp_out_flush <- (fun () -> flush oc);\n state.pp_out_newline <- display_newline state;\n state.pp_out_spaces <- display_blanks state;\n state.pp_out_indent <- display_indent state\n\n(*\n\n Defining specific formatters\n\n*)\n\nlet default_pp_mark_open_tag = function\n | String_tag s -> \"<\" ^ s ^ \">\"\n | _ -> \"\"\nlet default_pp_mark_close_tag = function\n | String_tag s -> \"\"\n | _ -> \"\"\n\nlet default_pp_print_open_tag = ignore\nlet default_pp_print_close_tag = ignore\n\n(* Building a formatter given its basic output functions.\n Other fields get reasonable default values. *)\nlet pp_make_formatter f g h i j =\n (* The initial state of the formatter contains a dummy box. *)\n let pp_queue = Queue.create () in\n let sys_tok =\n { size = Size.unknown; token = Pp_begin (0, Pp_hovbox); length = 0 } in\n Queue.add sys_tok pp_queue;\n let scan_stack = Stack.create () in\n initialize_scan_stack scan_stack;\n Stack.push { left_total = 1; queue_elem = sys_tok } scan_stack;\n let pp_margin = 78\n and pp_min_space_left = 10 in\n {\n pp_scan_stack = scan_stack;\n pp_format_stack = Stack.create ();\n pp_tbox_stack = Stack.create ();\n pp_tag_stack = Stack.create ();\n pp_mark_stack = Stack.create ();\n pp_margin = pp_margin;\n pp_min_space_left = pp_min_space_left;\n pp_max_indent = pp_margin - pp_min_space_left;\n pp_space_left = pp_margin;\n pp_current_indent = 0;\n pp_is_new_line = true;\n pp_left_total = 1;\n pp_right_total = 1;\n pp_curr_depth = 1;\n pp_max_boxes = max_int;\n pp_ellipsis = \".\";\n pp_out_string = f;\n pp_out_flush = g;\n pp_out_newline = h;\n pp_out_spaces = i;\n pp_out_indent = j;\n pp_print_tags = false;\n pp_mark_tags = false;\n pp_mark_open_tag = default_pp_mark_open_tag;\n pp_mark_close_tag = default_pp_mark_close_tag;\n pp_print_open_tag = default_pp_print_open_tag;\n pp_print_close_tag = default_pp_print_close_tag;\n pp_queue = pp_queue;\n }\n\n\n(* Build a formatter out of its out functions. *)\nlet formatter_of_out_functions out_funs =\n pp_make_formatter\n out_funs.out_string\n out_funs.out_flush\n out_funs.out_newline\n out_funs.out_spaces\n out_funs.out_indent\n\n\n(* Make a formatter with default functions to output spaces,\n indentation, and new lines. *)\nlet make_formatter output flush =\n let ppf = pp_make_formatter output flush ignore ignore ignore in\n ppf.pp_out_newline <- display_newline ppf;\n ppf.pp_out_spaces <- display_blanks ppf;\n ppf.pp_out_indent <- display_indent ppf;\n ppf\n\n\n(* Make a formatter writing to a given [Pervasive.out_channel] value. *)\nlet formatter_of_out_channel oc =\n make_formatter (output_substring oc) (fun () -> flush oc)\n\n\n(* Make a formatter writing to a given [Buffer.t] value. *)\nlet formatter_of_buffer b =\n make_formatter (Buffer.add_substring b) ignore\n\n\n(* Allocating buffer for pretty-printing purposes.\n Default buffer size is pp_buffer_size or 512.\n*)\nlet pp_buffer_size = 512\nlet pp_make_buffer () = Buffer.create pp_buffer_size\n\n(* The standard (shared) buffer. *)\nlet stdbuf = pp_make_buffer ()\n\n(* Predefined formatters standard formatter to print\n to [Stdlib.stdout], [Stdlib.stderr], and {!stdbuf}. *)\nlet std_formatter = formatter_of_out_channel Stdlib.stdout\nand err_formatter = formatter_of_out_channel Stdlib.stderr\nand str_formatter = formatter_of_buffer stdbuf\n\n\n(* [flush_buffer_formatter buf ppf] flushes formatter [ppf],\n then returns the contents of buffer [buf] that is reset.\n Formatter [ppf] is supposed to print to buffer [buf], otherwise this\n function is not really useful. *)\nlet flush_buffer_formatter buf ppf =\n pp_flush_queue ppf false;\n let s = Buffer.contents buf in\n Buffer.reset buf;\n s\n\n\n(* Flush [str_formatter] and get the contents of [stdbuf]. *)\nlet flush_str_formatter () = flush_buffer_formatter stdbuf str_formatter\n\n(*\n Symbolic pretty-printing\n*)\n\n(*\n Symbolic pretty-printing is pretty-printing with no low level output.\n\n When using a symbolic formatter, all regular pretty-printing activities\n occur but output material is symbolic and stored in a buffer of output\n items. At the end of pretty-printing, flushing the output buffer allows\n post-processing of symbolic output before low level output operations.\n*)\n\ntype symbolic_output_item =\n | Output_flush\n | Output_newline\n | Output_string of string\n | Output_spaces of int\n | Output_indent of int\n\ntype symbolic_output_buffer = {\n mutable symbolic_output_contents : symbolic_output_item list;\n}\n\nlet make_symbolic_output_buffer () =\n { symbolic_output_contents = [] }\n\nlet clear_symbolic_output_buffer sob =\n sob.symbolic_output_contents <- []\n\nlet get_symbolic_output_buffer sob =\n List.rev sob.symbolic_output_contents\n\nlet flush_symbolic_output_buffer sob =\n let items = get_symbolic_output_buffer sob in\n clear_symbolic_output_buffer sob;\n items\n\nlet add_symbolic_output_item sob item =\n sob.symbolic_output_contents <- item :: sob.symbolic_output_contents\n\nlet formatter_of_symbolic_output_buffer sob =\n let symbolic_flush sob () =\n add_symbolic_output_item sob Output_flush\n and symbolic_newline sob () =\n add_symbolic_output_item sob Output_newline\n and symbolic_string sob s i n =\n add_symbolic_output_item sob (Output_string (String.sub s i n))\n and symbolic_spaces sob n =\n add_symbolic_output_item sob (Output_spaces n)\n and symbolic_indent sob n =\n add_symbolic_output_item sob (Output_indent n) in\n\n let f = symbolic_string sob\n and g = symbolic_flush sob\n and h = symbolic_newline sob\n and i = symbolic_spaces sob\n and j = symbolic_indent sob in\n pp_make_formatter f g h i j\n\n(*\n\n Basic functions on the 'standard' formatter\n (the formatter that prints to [Stdlib.stdout]).\n\n*)\n\nlet open_hbox = pp_open_hbox std_formatter\nand open_vbox = pp_open_vbox std_formatter\nand open_hvbox = pp_open_hvbox std_formatter\nand open_hovbox = pp_open_hovbox std_formatter\nand open_box = pp_open_box std_formatter\nand close_box = pp_close_box std_formatter\nand open_tag = pp_open_tag std_formatter\nand close_tag = pp_close_tag std_formatter\nand open_stag = pp_open_stag std_formatter\nand close_stag = pp_close_stag std_formatter\nand print_as = pp_print_as std_formatter\nand print_string = pp_print_string std_formatter\nand print_bytes = pp_print_bytes std_formatter\nand print_int = pp_print_int std_formatter\nand print_float = pp_print_float std_formatter\nand print_char = pp_print_char std_formatter\nand print_bool = pp_print_bool std_formatter\nand print_break = pp_print_break std_formatter\nand print_cut = pp_print_cut std_formatter\nand print_space = pp_print_space std_formatter\nand force_newline = pp_force_newline std_formatter\nand print_flush = pp_print_flush std_formatter\nand print_newline = pp_print_newline std_formatter\nand print_if_newline = pp_print_if_newline std_formatter\n\nand open_tbox = pp_open_tbox std_formatter\nand close_tbox = pp_close_tbox std_formatter\nand print_tbreak = pp_print_tbreak std_formatter\n\nand set_tab = pp_set_tab std_formatter\nand print_tab = pp_print_tab std_formatter\n\nand set_margin = pp_set_margin std_formatter\nand get_margin = pp_get_margin std_formatter\n\nand set_max_indent = pp_set_max_indent std_formatter\nand get_max_indent = pp_get_max_indent std_formatter\n\nand set_geometry = pp_set_geometry std_formatter\nand safe_set_geometry = pp_safe_set_geometry std_formatter\nand get_geometry = pp_get_geometry std_formatter\nand update_geometry = pp_update_geometry std_formatter\n\nand set_max_boxes = pp_set_max_boxes std_formatter\nand get_max_boxes = pp_get_max_boxes std_formatter\nand over_max_boxes = pp_over_max_boxes std_formatter\n\nand set_ellipsis_text = pp_set_ellipsis_text std_formatter\nand get_ellipsis_text = pp_get_ellipsis_text std_formatter\n\nand set_formatter_out_channel =\n pp_set_formatter_out_channel std_formatter\n\nand set_formatter_out_functions =\n pp_set_formatter_out_functions std_formatter\nand get_formatter_out_functions =\n pp_get_formatter_out_functions std_formatter\n\nand set_formatter_output_functions =\n pp_set_formatter_output_functions std_formatter\nand get_formatter_output_functions =\n pp_get_formatter_output_functions std_formatter\n\nand set_formatter_stag_functions =\n pp_set_formatter_stag_functions std_formatter\nand get_formatter_stag_functions =\n pp_get_formatter_stag_functions std_formatter\nand set_print_tags =\n pp_set_print_tags std_formatter\nand get_print_tags =\n pp_get_print_tags std_formatter\nand set_mark_tags =\n pp_set_mark_tags std_formatter\nand get_mark_tags =\n pp_get_mark_tags std_formatter\nand set_tags =\n pp_set_tags std_formatter\n\n\n(* Convenience functions *)\n\n(* To format a list *)\nlet rec pp_print_list ?(pp_sep = pp_print_cut) pp_v ppf = function\n | [] -> ()\n | [v] -> pp_v ppf v\n | v :: vs ->\n pp_v ppf v;\n pp_sep ppf ();\n pp_print_list ~pp_sep pp_v ppf vs\n\n(* To format a sequence *)\nlet rec pp_print_seq_in ~pp_sep pp_v ppf seq =\n match seq () with\n | Seq.Nil -> ()\n | Seq.Cons (v, seq) ->\n pp_sep ppf ();\n pp_v ppf v;\n pp_print_seq_in ~pp_sep pp_v ppf seq\n\nlet pp_print_seq ?(pp_sep = pp_print_cut) pp_v ppf seq =\n match seq () with\n | Seq.Nil -> ()\n | Seq.Cons (v, seq) ->\n pp_v ppf v;\n pp_print_seq_in ~pp_sep pp_v ppf seq\n\n(* To format free-flowing text *)\nlet pp_print_text ppf s =\n let len = String.length s in\n let left = ref 0 in\n let right = ref 0 in\n let flush () =\n pp_print_string ppf (String.sub s !left (!right - !left));\n incr right; left := !right;\n in\n while (!right <> len) do\n match s.[!right] with\n | '\\n' ->\n flush ();\n pp_force_newline ppf ()\n | ' ' ->\n flush (); pp_print_space ppf ()\n (* there is no specific support for '\\t'\n as it is unclear what a right semantics would be *)\n | _ -> incr right\n done;\n if !left <> len then flush ()\n\nlet pp_print_option ?(none = fun _ () -> ()) pp_v ppf = function\n| None -> none ppf ()\n| Some v -> pp_v ppf v\n\nlet pp_print_result ~ok ~error ppf = function\n| Ok v -> ok ppf v\n| Error e -> error ppf e\n\nlet pp_print_either ~left ~right ppf = function\n| Either.Left l -> left ppf l\n| Either.Right r -> right ppf r\n\n (**************************************************************)\n\nlet compute_tag output tag_acc =\n let buf = Buffer.create 16 in\n let ppf = formatter_of_buffer buf in\n output ppf tag_acc;\n pp_print_flush ppf ();\n let len = Buffer.length buf in\n if len < 2 then Buffer.contents buf\n else Buffer.sub buf 1 (len - 2)\n\n (**************************************************************\n\n Defining continuations to be passed as arguments of\n CamlinternalFormat.make_printf.\n\n **************************************************************)\n\nopen CamlinternalFormatBasics\nopen CamlinternalFormat\n\n(* Interpret a formatting entity on a formatter. *)\nlet output_formatting_lit ppf fmting_lit = match fmting_lit with\n | Close_box -> pp_close_box ppf ()\n | Close_tag -> pp_close_tag ppf ()\n | Break (_, width, offset) -> pp_print_break ppf width offset\n | FFlush -> pp_print_flush ppf ()\n | Force_newline -> pp_force_newline ppf ()\n | Flush_newline -> pp_print_newline ppf ()\n | Magic_size (_, _) -> ()\n | Escaped_at -> pp_print_char ppf '@'\n | Escaped_percent -> pp_print_char ppf '%'\n | Scan_indic c -> pp_print_char ppf '@'; pp_print_char ppf c\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n printing entities (string, char, flus, ...) in an output_stream. *)\n(* Differ from Printf.output_acc by the interpretation of formatting. *)\n(* Used as a continuation of CamlinternalFormat.make_printf. *)\nlet rec output_acc ppf acc = match acc with\n | Acc_string_literal (Acc_formatting_lit (p, Magic_size (_, size)), s)\n | Acc_data_string (Acc_formatting_lit (p, Magic_size (_, size)), s) ->\n output_acc ppf p;\n pp_print_as_size ppf (Size.of_int size) s;\n | Acc_char_literal (Acc_formatting_lit (p, Magic_size (_, size)), c)\n | Acc_data_char (Acc_formatting_lit (p, Magic_size (_, size)), c) ->\n output_acc ppf p;\n pp_print_as_size ppf (Size.of_int size) (String.make 1 c);\n | Acc_formatting_lit (p, f) ->\n output_acc ppf p;\n output_formatting_lit ppf f;\n | Acc_formatting_gen (p, Acc_open_tag acc') ->\n output_acc ppf p;\n pp_open_stag ppf (String_tag (compute_tag output_acc acc'))\n | Acc_formatting_gen (p, Acc_open_box acc') ->\n output_acc ppf p;\n let (indent, bty) = open_box_of_string (compute_tag output_acc acc') in\n pp_open_box_gen ppf indent bty\n | Acc_string_literal (p, s)\n | Acc_data_string (p, s) -> output_acc ppf p; pp_print_string ppf s;\n | Acc_char_literal (p, c)\n | Acc_data_char (p, c) -> output_acc ppf p; pp_print_char ppf c;\n | Acc_delay (p, f) -> output_acc ppf p; f ppf;\n | Acc_flush p -> output_acc ppf p; pp_print_flush ppf ();\n | Acc_invalid_arg (p, msg) -> output_acc ppf p; invalid_arg msg;\n | End_of_acc -> ()\n\n(* Recursively output an \"accumulator\" containing a reversed list of\n printing entities (string, char, flus, ...) in a buffer. *)\n(* Differ from Printf.bufput_acc by the interpretation of formatting. *)\n(* Used as a continuation of CamlinternalFormat.make_printf. *)\nlet rec strput_acc ppf acc = match acc with\n | Acc_string_literal (Acc_formatting_lit (p, Magic_size (_, size)), s)\n | Acc_data_string (Acc_formatting_lit (p, Magic_size (_, size)), s) ->\n strput_acc ppf p;\n pp_print_as_size ppf (Size.of_int size) s;\n | Acc_char_literal (Acc_formatting_lit (p, Magic_size (_, size)), c)\n | Acc_data_char (Acc_formatting_lit (p, Magic_size (_, size)), c) ->\n strput_acc ppf p;\n pp_print_as_size ppf (Size.of_int size) (String.make 1 c);\n | Acc_delay (Acc_formatting_lit (p, Magic_size (_, size)), f) ->\n strput_acc ppf p;\n pp_print_as_size ppf (Size.of_int size) (f ());\n | Acc_formatting_lit (p, f) ->\n strput_acc ppf p;\n output_formatting_lit ppf f;\n | Acc_formatting_gen (p, Acc_open_tag acc') ->\n strput_acc ppf p;\n pp_open_stag ppf (String_tag (compute_tag strput_acc acc'))\n | Acc_formatting_gen (p, Acc_open_box acc') ->\n strput_acc ppf p;\n let (indent, bty) = open_box_of_string (compute_tag strput_acc acc') in\n pp_open_box_gen ppf indent bty\n | Acc_string_literal (p, s)\n | Acc_data_string (p, s) -> strput_acc ppf p; pp_print_string ppf s;\n | Acc_char_literal (p, c)\n | Acc_data_char (p, c) -> strput_acc ppf p; pp_print_char ppf c;\n | Acc_delay (p, f) -> strput_acc ppf p; pp_print_string ppf (f ());\n | Acc_flush p -> strput_acc ppf p; pp_print_flush ppf ();\n | Acc_invalid_arg (p, msg) -> strput_acc ppf p; invalid_arg msg;\n | End_of_acc -> ()\n\n(*\n\n Defining [fprintf] and various flavors of [fprintf].\n\n*)\n\nlet kfprintf k ppf (Format (fmt, _)) =\n make_printf\n (fun acc -> output_acc ppf acc; k ppf)\n End_of_acc fmt\n\nand ikfprintf k ppf (Format (fmt, _)) =\n make_iprintf k ppf fmt\n\nlet ifprintf _ppf (Format (fmt, _)) =\n make_iprintf ignore () fmt\n\nlet fprintf ppf = kfprintf ignore ppf\nlet printf fmt = fprintf std_formatter fmt\nlet eprintf fmt = fprintf err_formatter fmt\n\nlet kdprintf k (Format (fmt, _)) =\n make_printf\n (fun acc -> k (fun ppf -> output_acc ppf acc))\n End_of_acc fmt\n\nlet dprintf fmt = kdprintf (fun i -> i) fmt\n\nlet ksprintf k (Format (fmt, _)) =\n let b = pp_make_buffer () in\n let ppf = formatter_of_buffer b in\n let k acc =\n strput_acc ppf acc;\n k (flush_buffer_formatter b ppf) in\n make_printf k End_of_acc fmt\n\n\nlet sprintf fmt = ksprintf id fmt\n\nlet kasprintf k (Format (fmt, _)) =\n let b = pp_make_buffer () in\n let ppf = formatter_of_buffer b in\n let k acc =\n output_acc ppf acc;\n k (flush_buffer_formatter b ppf) in\n make_printf k End_of_acc fmt\n\n\nlet asprintf fmt = kasprintf id fmt\n\n(* Flushing standard formatters at end of execution. *)\n\nlet flush_standard_formatters () =\n pp_print_flush std_formatter ();\n pp_print_flush err_formatter ()\n\nlet () = at_exit flush_standard_formatters\n\n(*\n\n Deprecated stuff.\n\n*)\n\n(* Deprecated : subsumed by pp_set_formatter_out_functions *)\nlet pp_set_all_formatter_output_functions state\n ~out:f ~flush:g ~newline:h ~spaces:i =\n pp_set_formatter_output_functions state f g;\n state.pp_out_newline <- h;\n state.pp_out_spaces <- i\n\n(* Deprecated : subsumed by pp_get_formatter_out_functions *)\nlet pp_get_all_formatter_output_functions state () =\n (state.pp_out_string, state.pp_out_flush,\n state.pp_out_newline, state.pp_out_spaces)\n\n\n(* Deprecated : subsumed by set_formatter_out_functions *)\nlet set_all_formatter_output_functions =\n pp_set_all_formatter_output_functions std_formatter\n\n\n(* Deprecated : subsumed by get_formatter_out_functions *)\nlet get_all_formatter_output_functions =\n pp_get_all_formatter_output_functions std_formatter\n\n\n(* Deprecated : error prone function, do not use it.\n This function is neither compositional nor incremental, since it flushes\n the pretty-printer queue at each call.\n To get the same functionality, define a formatter of your own writing to\n the buffer argument, as in\n let ppf = formatter_of_buffer b\n then use {!fprintf ppf} as usual. *)\nlet bprintf b (Format (fmt, _) : ('a, formatter, unit) format) =\n let ppf = formatter_of_buffer b in\n let k acc = output_acc ppf acc; pp_flush_queue ppf false in\n make_printf k End_of_acc fmt\n\n\n(* Deprecated : alias for ksprintf. *)\nlet kprintf = ksprintf\n\n\n\n(* Deprecated tag functions *)\n\ntype formatter_tag_functions = {\n mark_open_tag : tag -> string;\n mark_close_tag : tag -> string;\n print_open_tag : tag -> unit;\n print_close_tag : tag -> unit;\n}\n\n\nlet pp_set_formatter_tag_functions state {\n mark_open_tag = mot;\n mark_close_tag = mct;\n print_open_tag = pot;\n print_close_tag = pct;\n } =\n let stringify f e = function String_tag s -> f s | _ -> e in\n state.pp_mark_open_tag <- stringify mot \"\";\n state.pp_mark_close_tag <- stringify mct \"\";\n state.pp_print_open_tag <- stringify pot ();\n state.pp_print_close_tag <- stringify pct ()\n\nlet pp_get_formatter_tag_functions fmt () =\n let funs = pp_get_formatter_stag_functions fmt () in\n let mark_open_tag s = funs.mark_open_stag (String_tag s) in\n let mark_close_tag s = funs.mark_close_stag (String_tag s) in\n let print_open_tag s = funs.print_open_stag (String_tag s) in\n let print_close_tag s = funs.print_close_stag (String_tag s) in\n {mark_open_tag; mark_close_tag; print_open_tag; print_close_tag}\n\nlet set_formatter_tag_functions =\n pp_set_formatter_tag_functions std_formatter\nand get_formatter_tag_functions =\n pp_get_formatter_tag_functions std_formatter\n","(** Very small tooling for format printers. *)\n\ninclude Format\n\ntype 'a t = Format.formatter -> 'a -> unit\n\n(* Only in the stdlib since 4.02, so we copy. *)\nlet rec list ?(pp_sep = pp_print_cut) pp ppf = function\n | [] -> ()\n | [v] -> pp ppf v\n | v :: vs ->\n pp ppf v;\n pp_sep ppf ();\n list ~pp_sep pp ppf vs\n\n(* want this name to make sure we don't use pp_print_list from stdlib\n accidentally *)\nlet pp_print_list = list\n\nlet str = pp_print_string\nlet sexp fmt s pp x = fprintf fmt \"@[<3>(%s@ %a)@]\" s pp x\nlet pair pp1 pp2 fmt (v1,v2) =\n pp1 fmt v1; pp_print_space fmt () ; pp2 fmt v2\nlet triple pp1 pp2 pp3 fmt (v1, v2, v3) =\n pp1 fmt v1; pp_print_space fmt () ;\n pp2 fmt v2; pp_print_space fmt () ;\n pp3 fmt v3\nlet int = pp_print_int\nlet optint fmt = function\n | None -> ()\n | Some i -> fprintf fmt \"@ %d\" i\n\nlet quote fmt s = Format.fprintf fmt \"\\\"%s\\\"\" s\n\nlet pp_olist pp_elem fmt =\n Format.fprintf fmt \"@[<3>[@ %a@ ]@]\"\n (pp_print_list\n ~pp_sep:(fun fmt () -> fprintf fmt \";@ \")\n pp_elem)\n\nlet pp_str_list = pp_olist quote\n\nlet to_to_string pp x =\n let b = Buffer.create 16 in\n let fmt = Format.formatter_of_buffer b in\n pp fmt x;\n Buffer.contents b\n","\nmodule Pmark = struct\n type t = int\n let equal (x : int) (y : int) = x = y\n let compare (x : int) (y : int) = compare x y\n let r = ref 0\n let gen () = incr r ; !r\n\n let pp = Format.pp_print_int\nend\n\ninclude Pmark\nmodule Set = Set.Make(Pmark)\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Pierre Weis, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2002 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nopen CamlinternalFormatBasics\nopen CamlinternalFormat\n\n(* alias to avoid warning for ambiguity between\n Stdlib.format6\n and CamlinternalFormatBasics.format6\n\n (the former is in fact an alias for the latter,\n but the ambiguity warning doesn't care)\n*)\ntype ('a, 'b, 'c, 'd, 'e, 'f) format6 =\n ('a, 'b, 'c, 'd, 'e, 'f) Stdlib.format6\n\n\n(* The run-time library for scanners. *)\n\n(* Scanning buffers. *)\nmodule type SCANNING = sig\n\n type in_channel\n\n type scanbuf = in_channel\n\n type file_name = string\n\n val stdin : in_channel\n (* The scanning buffer reading from [Stdlib.stdin].\n [stdib] is equivalent to [Scanning.from_channel Stdlib.stdin]. *)\n\n val stdib : in_channel\n (* An alias for [Scanf.stdin], the scanning buffer reading from\n [Stdlib.stdin]. *)\n\n val next_char : scanbuf -> char\n (* [Scanning.next_char ib] advance the scanning buffer for\n one character.\n If no more character can be read, sets a end of file condition and\n returns '\\000'. *)\n\n val invalidate_current_char : scanbuf -> unit\n (* [Scanning.invalidate_current_char ib] mark the current_char as already\n scanned. *)\n\n val peek_char : scanbuf -> char\n (* [Scanning.peek_char ib] returns the current char available in\n the buffer or reads one if necessary (when the current character is\n already scanned).\n If no character can be read, sets an end of file condition and\n returns '\\000'. *)\n\n val checked_peek_char : scanbuf -> char\n (* Same as [Scanning.peek_char] above but always returns a valid char or\n fails: instead of returning a null char when the reading method of the\n input buffer has reached an end of file, the function raises exception\n [End_of_file]. *)\n\n val store_char : int -> scanbuf -> char -> int\n (* [Scanning.store_char lim ib c] adds [c] to the token buffer\n of the scanning buffer [ib]. It also advances the scanning buffer for\n one character and returns [lim - 1], indicating the new limit for the\n length of the current token. *)\n\n val skip_char : int -> scanbuf -> int\n (* [Scanning.skip_char lim ib] ignores the current character. *)\n\n val ignore_char : int -> scanbuf -> int\n (* [Scanning.ignore_char ib lim] ignores the current character and\n decrements the limit. *)\n\n val token : scanbuf -> string\n (* [Scanning.token ib] returns the string stored into the token\n buffer of the scanning buffer: it returns the token matched by the\n format. *)\n\n val reset_token : scanbuf -> unit\n (* [Scanning.reset_token ib] resets the token buffer of\n the given scanning buffer. *)\n\n val char_count : scanbuf -> int\n (* [Scanning.char_count ib] returns the number of characters\n read so far from the given buffer. *)\n\n val line_count : scanbuf -> int\n (* [Scanning.line_count ib] returns the number of new line\n characters read so far from the given buffer. *)\n\n val token_count : scanbuf -> int\n (* [Scanning.token_count ib] returns the number of tokens read\n so far from [ib]. *)\n\n val eof : scanbuf -> bool\n (* [Scanning.eof ib] returns the end of input condition\n of the given buffer. *)\n\n val end_of_input : scanbuf -> bool\n (* [Scanning.end_of_input ib] tests the end of input condition\n of the given buffer (if no char has ever been read, an attempt to\n read one is performed). *)\n\n val beginning_of_input : scanbuf -> bool\n (* [Scanning.beginning_of_input ib] tests the beginning of input\n condition of the given buffer. *)\n\n val name_of_input : scanbuf -> string\n (* [Scanning.name_of_input ib] returns the name of the character\n source for input buffer [ib]. *)\n\n val open_in : file_name -> in_channel\n val open_in_bin : file_name -> in_channel\n val from_file : file_name -> in_channel\n val from_file_bin : file_name -> in_channel\n val from_string : string -> in_channel\n val from_function : (unit -> char) -> in_channel\n val from_channel : Stdlib.in_channel -> in_channel\n\n val close_in : in_channel -> unit\n\n val memo_from_channel : Stdlib.in_channel -> in_channel\n (* Obsolete. *)\n\nend\n\n\nmodule Scanning : SCANNING = struct\n\n (* The run-time library for scanf. *)\n\n type file_name = string\n\n type in_channel_name =\n | From_channel of Stdlib.in_channel\n | From_file of file_name * Stdlib.in_channel\n | From_function\n | From_string\n\n\n type in_channel = {\n mutable ic_eof : bool;\n mutable ic_current_char : char;\n mutable ic_current_char_is_valid : bool;\n mutable ic_char_count : int;\n mutable ic_line_count : int;\n mutable ic_token_count : int;\n ic_get_next_char : unit -> char;\n ic_token_buffer : Buffer.t;\n ic_input_name : in_channel_name;\n }\n\n\n type scanbuf = in_channel\n\n let null_char = '\\000'\n\n (* Reads a new character from input buffer.\n Next_char never fails, even in case of end of input:\n it then simply sets the end of file condition. *)\n let next_char ib =\n try\n let c = ib.ic_get_next_char () in\n ib.ic_current_char <- c;\n ib.ic_current_char_is_valid <- true;\n ib.ic_char_count <- succ ib.ic_char_count;\n if c = '\\n' then ib.ic_line_count <- succ ib.ic_line_count;\n c with\n | End_of_file ->\n let c = null_char in\n ib.ic_current_char <- c;\n ib.ic_current_char_is_valid <- false;\n ib.ic_eof <- true;\n c\n\n\n let peek_char ib =\n if ib.ic_current_char_is_valid\n then ib.ic_current_char\n else next_char ib\n\n\n (* Returns a valid current char for the input buffer. In particular\n no irrelevant null character (as set by [next_char] in case of end\n of input) is returned, since [End_of_file] is raised when\n [next_char] sets the end of file condition while trying to read a\n new character. *)\n let checked_peek_char ib =\n let c = peek_char ib in\n if ib.ic_eof then raise End_of_file;\n c\n\n\n let end_of_input ib =\n ignore (peek_char ib);\n ib.ic_eof\n\n\n let eof ib = ib.ic_eof\n\n let beginning_of_input ib = ib.ic_char_count = 0\n\n let name_of_input ib =\n match ib.ic_input_name with\n | From_channel _ic -> \"unnamed Stdlib input channel\"\n | From_file (fname, _ic) -> fname\n | From_function -> \"unnamed function\"\n | From_string -> \"unnamed character string\"\n\n\n let char_count ib =\n if ib.ic_current_char_is_valid\n then ib.ic_char_count - 1\n else ib.ic_char_count\n\n\n let line_count ib = ib.ic_line_count\n\n let reset_token ib = Buffer.reset ib.ic_token_buffer\n\n let invalidate_current_char ib = ib.ic_current_char_is_valid <- false\n\n let token ib =\n let token_buffer = ib.ic_token_buffer in\n let tok = Buffer.contents token_buffer in\n Buffer.clear token_buffer;\n ib.ic_token_count <- succ ib.ic_token_count;\n tok\n\n\n let token_count ib = ib.ic_token_count\n\n let skip_char width ib =\n invalidate_current_char ib;\n width\n\n\n let ignore_char width ib = skip_char (width - 1) ib\n\n let store_char width ib c =\n Buffer.add_char ib.ic_token_buffer c;\n ignore_char width ib\n\n\n let default_token_buffer_size = 1024\n\n let create iname next = {\n ic_eof = false;\n ic_current_char = null_char;\n ic_current_char_is_valid = false;\n ic_char_count = 0;\n ic_line_count = 0;\n ic_token_count = 0;\n ic_get_next_char = next;\n ic_token_buffer = Buffer.create default_token_buffer_size;\n ic_input_name = iname;\n }\n\n\n let from_string s =\n let i = ref 0 in\n let len = String.length s in\n let next () =\n if !i >= len then raise End_of_file else\n let c = s.[!i] in\n incr i;\n c in\n create From_string next\n\n\n let from_function = create From_function\n\n (* Scanning from an input channel. *)\n\n (* Position of the problem:\n\n We cannot prevent the scanning mechanism to use one lookahead character,\n if needed by the semantics of the format string specifications (e.g. a\n trailing 'skip space' specification in the format string); in this case,\n the mandatory lookahead character is indeed read from the input and not\n used to return the token read. It is thus mandatory to be able to store\n an unused lookahead character somewhere to get it as the first character\n of the next scan.\n\n To circumvent this problem, all the scanning functions get a low level\n input buffer argument where they store the lookahead character when\n needed; additionally, the input buffer is the only source of character of\n a scanner. The [scanbuf] input buffers are defined in module {!Scanning}.\n\n Now we understand that it is extremely important that related and\n successive calls to scanners indeed read from the same input buffer.\n In effect, if a scanner [scan1] is reading from [ib1] and stores an\n unused lookahead character [c1] into its input buffer [ib1], then\n another scanner [scan2] not reading from the same buffer [ib1] will miss\n the character [c1], seemingly vanished in the air from the point of view\n of [scan2].\n\n This mechanism works perfectly to read from strings, from files, and from\n functions, since in those cases, allocating two buffers reading from the\n same source is unnatural.\n\n Still, there is a difficulty in the case of scanning from an input\n channel. In effect, when scanning from an input channel [ic], this channel\n may not have been allocated from within this library. Hence, it may be\n shared (two functions of the user's program may successively read from\n [ic]). This is highly error prone since, one of the function may seek the\n input channel, while the other function has still an unused lookahead\n character in its input buffer. In conclusion, you should never mix direct\n low level reading and high level scanning from the same input channel.\n\n *)\n\n (* Perform bufferized input to improve efficiency. *)\n let file_buffer_size = ref 1024\n\n (* The scanner closes the input channel at end of input. *)\n let scan_close_at_end ic = Stdlib.close_in ic; raise End_of_file\n\n (* The scanner does not close the input channel at end of input:\n it just raises [End_of_file]. *)\n let scan_raise_at_end _ic = raise End_of_file\n\n let from_ic scan_close_ic iname ic =\n let len = !file_buffer_size in\n let buf = Bytes.create len in\n let i = ref 0 in\n let lim = ref 0 in\n let eof = ref false in\n let next () =\n if !i < !lim then begin let c = Bytes.get buf !i in incr i; c end else\n if !eof then raise End_of_file else begin\n lim := input ic buf 0 len;\n if !lim = 0 then begin eof := true; scan_close_ic ic end else begin\n i := 1;\n Bytes.get buf 0\n end\n end in\n create iname next\n\n\n let from_ic_close_at_end = from_ic scan_close_at_end\n let from_ic_raise_at_end = from_ic scan_raise_at_end\n\n (* The scanning buffer reading from [Stdlib.stdin].\n One could try to define [stdib] as a scanning buffer reading a character\n at a time (no bufferization at all), but unfortunately the top-level\n interaction would be wrong. This is due to some kind of\n 'race condition' when reading from [Stdlib.stdin],\n since the interactive compiler and [Scanf.scanf] will simultaneously\n read the material they need from [Stdlib.stdin]; then, confusion\n will result from what should be read by the top-level and what should be\n read by [Scanf.scanf].\n This is even more complicated by the one character lookahead that\n [Scanf.scanf] is sometimes obliged to maintain: the lookahead character\n will be available for the next [Scanf.scanf] entry, seemingly coming from\n nowhere.\n Also no [End_of_file] is raised when reading from stdin: if not enough\n characters have been read, we simply ask to read more. *)\n let stdin =\n from_ic scan_raise_at_end\n (From_file (\"-\", Stdlib.stdin)) Stdlib.stdin\n\n\n let stdib = stdin\n\n let open_in_file open_in fname =\n match fname with\n | \"-\" -> stdin\n | fname ->\n let ic = open_in fname in\n from_ic_close_at_end (From_file (fname, ic)) ic\n\n\n let open_in = open_in_file Stdlib.open_in\n let open_in_bin = open_in_file Stdlib.open_in_bin\n\n let from_file = open_in\n let from_file_bin = open_in_bin\n\n let from_channel ic =\n from_ic_raise_at_end (From_channel ic) ic\n\n\n let close_in ib =\n match ib.ic_input_name with\n | From_channel ic ->\n Stdlib.close_in ic\n | From_file (_fname, ic) -> Stdlib.close_in ic\n | From_function | From_string -> ()\n\n\n (*\n Obsolete: a memo [from_channel] version to build a [Scanning.in_channel]\n scanning buffer out of a [Stdlib.in_channel].\n This function was used to try to preserve the scanning\n semantics for the (now obsolete) function [fscanf].\n Given that all scanner must read from a [Scanning.in_channel] scanning\n buffer, [fscanf] must read from one!\n More precisely, given [ic], all successive calls [fscanf ic] must read\n from the same scanning buffer.\n This obliged this library to allocated scanning buffers that were\n not properly garbage collectable, hence leading to memory leaks.\n If you need to read from a [Stdlib.in_channel] input channel\n [ic], simply define a [Scanning.in_channel] formatted input channel as in\n [let ib = Scanning.from_channel ic], then use [Scanf.bscanf ib] as usual.\n *)\n let memo_from_ic =\n let memo = ref [] in\n (fun scan_close_ic ic ->\n try List.assq ic !memo with\n | Not_found ->\n let ib =\n from_ic scan_close_ic (From_channel ic) ic in\n memo := (ic, ib) :: !memo;\n ib)\n\n\n (* Obsolete: see {!memo_from_ic} above. *)\n let memo_from_channel = memo_from_ic scan_raise_at_end\n\nend\n\n\n(* Formatted input functions. *)\n\ntype ('a, 'b, 'c, 'd) scanner =\n ('a, Scanning.in_channel, 'b, 'c, 'a -> 'd, 'd) format6 -> 'c\n\n\n(* Reporting errors. *)\nexception Scan_failure of string\n\nlet bad_input s = raise (Scan_failure s)\n\nlet bad_input_escape c =\n bad_input (Printf.sprintf \"illegal escape character %C\" c)\n\n\nlet bad_token_length message =\n bad_input\n (Printf.sprintf\n \"scanning of %s failed: \\\n the specified length was too short for token\"\n message)\n\n\nlet bad_end_of_input message =\n bad_input\n (Printf.sprintf\n \"scanning of %s failed: \\\n premature end of file occurred before end of token\"\n message)\n\n\nlet bad_float () =\n bad_input \"no dot or exponent part found in float token\"\n\n\nlet bad_hex_float () =\n bad_input \"not a valid float in hexadecimal notation\"\n\n\nlet character_mismatch_err c ci =\n Printf.sprintf \"looking for %C, found %C\" c ci\n\n\nlet character_mismatch c ci =\n bad_input (character_mismatch_err c ci)\n\n\nlet rec skip_whites ib =\n let c = Scanning.peek_char ib in\n if not (Scanning.eof ib) then begin\n match c with\n | ' ' | '\\t' | '\\n' | '\\r' ->\n Scanning.invalidate_current_char ib; skip_whites ib\n | _ -> ()\n end\n\n\n(* Checking that [c] is indeed in the input, then skips it.\n In this case, the character [c] has been explicitly specified in the\n format as being mandatory in the input; hence we should fail with\n [End_of_file] in case of end_of_input.\n (Remember that [Scan_failure] is raised only when (we can prove by\n evidence) that the input does not match the format string given. We must\n thus differentiate [End_of_file] as an error due to lack of input, and\n [Scan_failure] which is due to provably wrong input. I am not sure this is\n worth the burden: it is complex and somehow subliminal; should be clearer\n to fail with Scan_failure \"Not enough input to complete scanning\"!)\n\n That's why, waiting for a better solution, we use checked_peek_char here.\n We are also careful to treat \"\\r\\n\" in the input as an end of line marker:\n it always matches a '\\n' specification in the input format string. *)\nlet rec check_char ib c =\n match c with\n | ' ' -> skip_whites ib\n | '\\n' -> check_newline ib\n | c -> check_this_char ib c\n\nand check_this_char ib c =\n let ci = Scanning.checked_peek_char ib in\n if ci = c then Scanning.invalidate_current_char ib else\n character_mismatch c ci\n\nand check_newline ib =\n let ci = Scanning.checked_peek_char ib in\n match ci with\n | '\\n' -> Scanning.invalidate_current_char ib\n | '\\r' -> Scanning.invalidate_current_char ib; check_this_char ib '\\n'\n | _ -> character_mismatch '\\n' ci\n\n\n(* Extracting tokens from the output token buffer. *)\n\nlet token_char ib = (Scanning.token ib).[0]\n\nlet token_string = Scanning.token\n\nlet token_bool ib =\n match Scanning.token ib with\n | \"true\" -> true\n | \"false\" -> false\n | s -> bad_input (Printf.sprintf \"invalid boolean '%s'\" s)\n\n\n(* The type of integer conversions. *)\ntype integer_conversion =\n | B_conversion (* Unsigned binary conversion *)\n | D_conversion (* Signed decimal conversion *)\n | I_conversion (* Signed integer conversion *)\n | O_conversion (* Unsigned octal conversion *)\n | U_conversion (* Unsigned decimal conversion *)\n | X_conversion (* Unsigned hexadecimal conversion *)\n\n\nlet integer_conversion_of_char = function\n | 'b' -> B_conversion\n | 'd' -> D_conversion\n | 'i' -> I_conversion\n | 'o' -> O_conversion\n | 'u' -> U_conversion\n | 'x' | 'X' -> X_conversion\n | _ -> assert false\n\n\n(* Extract an integer literal token.\n Since the functions Stdlib.*int*_of_string do not accept a leading +,\n we skip it if necessary. *)\nlet token_int_literal conv ib =\n let tok =\n match conv with\n | D_conversion | I_conversion -> Scanning.token ib\n | U_conversion -> \"0u\" ^ Scanning.token ib\n | O_conversion -> \"0o\" ^ Scanning.token ib\n | X_conversion -> \"0x\" ^ Scanning.token ib\n | B_conversion -> \"0b\" ^ Scanning.token ib in\n let l = String.length tok in\n if l = 0 || tok.[0] <> '+' then tok else String.sub tok 1 (l - 1)\n\n\n(* All the functions that convert a string to a number raise the exception\n Failure when the conversion is not possible.\n This exception is then trapped in [kscanf]. *)\nlet token_int conv ib = int_of_string (token_int_literal conv ib)\n\nlet token_float ib = float_of_string (Scanning.token ib)\n\n(* To scan native ints, int32 and int64 integers.\n We cannot access to conversions to/from strings for those types,\n Nativeint.of_string, Int32.of_string, and Int64.of_string,\n since those modules are not available to [Scanf].\n However, we can bind and use the corresponding primitives that are\n available in the runtime. *)\nexternal nativeint_of_string : string -> nativeint\n = \"caml_nativeint_of_string\"\n\nexternal int32_of_string : string -> int32\n = \"caml_int32_of_string\"\n\nexternal int64_of_string : string -> int64\n = \"caml_int64_of_string\"\n\n\nlet token_nativeint conv ib = nativeint_of_string (token_int_literal conv ib)\nlet token_int32 conv ib = int32_of_string (token_int_literal conv ib)\nlet token_int64 conv ib = int64_of_string (token_int_literal conv ib)\n\n(* Scanning numbers. *)\n\n(* Digits scanning functions suppose that one character has been checked and\n is available, since they return at end of file with the currently found\n token selected.\n\n Put it in another way, the digits scanning functions scan for a possibly\n empty sequence of digits, (hence, a successful scanning from one of those\n functions does not imply that the token is a well-formed number: to get a\n true number, it is mandatory to check that at least one valid digit is\n available before calling one of the digit scanning functions). *)\n\n(* The decimal case is treated especially for optimization purposes. *)\nlet rec scan_decimal_digit_star width ib =\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n match c with\n | '0' .. '9' as c ->\n let width = Scanning.store_char width ib c in\n scan_decimal_digit_star width ib\n | '_' ->\n let width = Scanning.ignore_char width ib in\n scan_decimal_digit_star width ib\n | _ -> width\n\n\nlet scan_decimal_digit_plus width ib =\n if width = 0 then bad_token_length \"decimal digits\" else\n let c = Scanning.checked_peek_char ib in\n match c with\n | '0' .. '9' ->\n let width = Scanning.store_char width ib c in\n scan_decimal_digit_star width ib\n | c ->\n bad_input (Printf.sprintf \"character %C is not a decimal digit\" c)\n\n\n(* To scan numbers from other bases, we use a predicate argument to\n scan digits. *)\nlet scan_digit_star digitp width ib =\n let rec scan_digits width ib =\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n match c with\n | c when digitp c ->\n let width = Scanning.store_char width ib c in\n scan_digits width ib\n | '_' ->\n let width = Scanning.ignore_char width ib in\n scan_digits width ib\n | _ -> width in\n scan_digits width ib\n\n\nlet scan_digit_plus basis digitp width ib =\n (* Ensure we have got enough width left,\n and read at least one digit. *)\n if width = 0 then bad_token_length \"digits\" else\n let c = Scanning.checked_peek_char ib in\n if digitp c then\n let width = Scanning.store_char width ib c in\n scan_digit_star digitp width ib\n else\n bad_input (Printf.sprintf \"character %C is not a valid %s digit\" c basis)\n\n\nlet is_binary_digit = function\n | '0' .. '1' -> true\n | _ -> false\n\n\nlet scan_binary_int = scan_digit_plus \"binary\" is_binary_digit\n\nlet is_octal_digit = function\n | '0' .. '7' -> true\n | _ -> false\n\n\nlet scan_octal_int = scan_digit_plus \"octal\" is_octal_digit\n\nlet is_hexa_digit = function\n | '0' .. '9' | 'a' .. 'f' | 'A' .. 'F' -> true\n | _ -> false\n\n\nlet scan_hexadecimal_int = scan_digit_plus \"hexadecimal\" is_hexa_digit\n\n(* Scan a decimal integer. *)\nlet scan_unsigned_decimal_int = scan_decimal_digit_plus\n\nlet scan_sign width ib =\n let c = Scanning.checked_peek_char ib in\n match c with\n | '+' -> Scanning.store_char width ib c\n | '-' -> Scanning.store_char width ib c\n | _ -> width\n\n\nlet scan_optionally_signed_decimal_int width ib =\n let width = scan_sign width ib in\n scan_unsigned_decimal_int width ib\n\n\n(* Scan an unsigned integer that could be given in any (common) basis.\n If digits are prefixed by one of 0x, 0X, 0o, or 0b, the number is\n assumed to be written respectively in hexadecimal, hexadecimal,\n octal, or binary. *)\nlet scan_unsigned_int width ib =\n match Scanning.checked_peek_char ib with\n | '0' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n begin match c with\n | 'x' | 'X' -> scan_hexadecimal_int (Scanning.store_char width ib c) ib\n | 'o' -> scan_octal_int (Scanning.store_char width ib c) ib\n | 'b' -> scan_binary_int (Scanning.store_char width ib c) ib\n | _ -> scan_decimal_digit_star width ib end\n | _ -> scan_unsigned_decimal_int width ib\n\n\nlet scan_optionally_signed_int width ib =\n let width = scan_sign width ib in\n scan_unsigned_int width ib\n\n\nlet scan_int_conversion conv width ib =\n match conv with\n | B_conversion -> scan_binary_int width ib\n | D_conversion -> scan_optionally_signed_decimal_int width ib\n | I_conversion -> scan_optionally_signed_int width ib\n | O_conversion -> scan_octal_int width ib\n | U_conversion -> scan_unsigned_decimal_int width ib\n | X_conversion -> scan_hexadecimal_int width ib\n\n\n(* Scanning floating point numbers. *)\n\n(* Fractional part is optional and can be reduced to 0 digits. *)\nlet scan_fractional_part width ib =\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n match c with\n | '0' .. '9' as c ->\n scan_decimal_digit_star (Scanning.store_char width ib c) ib\n | _ -> width\n\n\n(* Exp part is optional and can be reduced to 0 digits. *)\nlet scan_exponent_part width ib =\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n match c with\n | 'e' | 'E' as c ->\n scan_optionally_signed_decimal_int (Scanning.store_char width ib c) ib\n | _ -> width\n\n\n(* Scan the integer part of a floating point number, (not using the\n OCaml lexical convention since the integer part can be empty):\n an optional sign, followed by a possibly empty sequence of decimal\n digits (e.g. -.1). *)\nlet scan_integer_part width ib =\n let width = scan_sign width ib in\n scan_decimal_digit_star width ib\n\n\n(*\n For the time being we have (as found in scanf.mli):\n the field width is composed of an optional integer literal\n indicating the maximal width of the token to read.\n Unfortunately, the type-checker let the user write an optional precision,\n since this is valid for printf format strings.\n\n Thus, the next step for Scanf is to support a full width and precision\n indication, more or less similar to the one for printf, possibly extended\n to the specification of a [max, min] range for the width of the token read\n for strings. Something like the following spec for scanf.mli:\n\n The optional [width] is an integer indicating the maximal\n width of the token read. For instance, [%6d] reads an integer,\n having at most 6 characters.\n\n The optional [precision] is a dot [.] followed by an integer:\n\n - in the floating point number conversions ([%f], [%e], [%g], [%F], [%E],\n and [%F] conversions, the [precision] indicates the maximum number of\n digits that may follow the decimal point. For instance, [%.4f] reads a\n [float] with at most 4 fractional digits,\n\n - in the string conversions ([%s], [%S], [%\\[ range \\]]), and in the\n integer number conversions ([%i], [%d], [%u], [%x], [%o], and their\n [int32], [int64], and [native_int] correspondent), the [precision]\n indicates the required minimum width of the token read,\n\n - on all other conversions, the width and precision specify the [max, min]\n range for the width of the token read.\n*)\nlet scan_float width precision ib =\n let width = scan_integer_part width ib in\n if width = 0 then width, precision else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width, precision else\n match c with\n | '.' ->\n let width = Scanning.store_char width ib c in\n let precision = Int.min width precision in\n let width = width - (precision - scan_fractional_part precision ib) in\n scan_exponent_part width ib, precision\n | _ ->\n scan_exponent_part width ib, precision\n\n\nlet check_case_insensitive_string width ib error str =\n let lowercase c =\n match c with\n | 'A' .. 'Z' ->\n char_of_int (int_of_char c - int_of_char 'A' + int_of_char 'a')\n | _ -> c in\n let len = String.length str in\n let width = ref width in\n for i = 0 to len - 1 do\n let c = Scanning.peek_char ib in\n if lowercase c <> lowercase str.[i] then error ();\n if !width = 0 then error ();\n width := Scanning.store_char !width ib c;\n done;\n !width\n\n\nlet scan_hex_float width precision ib =\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n let width = scan_sign width ib in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n match Scanning.peek_char ib with\n | '0' as c -> (\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n let width = check_case_insensitive_string width ib bad_hex_float \"x\" in\n if width = 0 || Scanning.end_of_input ib then width else\n let width = match Scanning.peek_char ib with\n | '.' | 'p' | 'P' -> width\n | _ -> scan_hexadecimal_int width ib in\n if width = 0 || Scanning.end_of_input ib then width else\n let width = match Scanning.peek_char ib with\n | '.' as c -> (\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then width else\n match Scanning.peek_char ib with\n | 'p' | 'P' -> width\n | _ ->\n let precision = Int.min width precision in\n width - (precision - scan_hexadecimal_int precision ib)\n )\n | _ -> width in\n if width = 0 || Scanning.end_of_input ib then width else\n match Scanning.peek_char ib with\n | 'p' | 'P' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n scan_optionally_signed_decimal_int width ib\n | _ -> width\n )\n | 'n' | 'N' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n check_case_insensitive_string width ib bad_hex_float \"an\"\n | 'i' | 'I' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n check_case_insensitive_string width ib bad_hex_float \"nfinity\"\n | _ -> bad_hex_float ()\n\n\nlet scan_caml_float_rest width precision ib =\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n let width = scan_decimal_digit_star width ib in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n let c = Scanning.peek_char ib in\n match c with\n | '.' ->\n let width = Scanning.store_char width ib c in\n (* The effective width available for scanning the fractional part is\n the minimum of declared precision and width left. *)\n let precision = Int.min width precision in\n (* After scanning the fractional part with [precision] provisional width,\n [width_precision] is left. *)\n let width_precision = scan_fractional_part precision ib in\n (* Hence, scanning the fractional part took exactly\n [precision - width_precision] chars. *)\n let frac_width = precision - width_precision in\n (* And new provisional width is [width - width_precision. *)\n let width = width - frac_width in\n scan_exponent_part width ib\n | 'e' | 'E' ->\n scan_exponent_part width ib\n | _ -> bad_float ()\n\n\nlet scan_caml_float width precision ib =\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n let width = scan_sign width ib in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n match Scanning.peek_char ib with\n | '0' as c -> (\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n match Scanning.peek_char ib with\n | 'x' | 'X' as c -> (\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n let width = scan_hexadecimal_int width ib in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n let width = match Scanning.peek_char ib with\n | '.' as c -> (\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then width else\n match Scanning.peek_char ib with\n | 'p' | 'P' -> width\n | _ ->\n let precision = Int.min width precision in\n width - (precision - scan_hexadecimal_int precision ib)\n )\n | 'p' | 'P' -> width\n | _ -> bad_float () in\n if width = 0 || Scanning.end_of_input ib then width else\n match Scanning.peek_char ib with\n | 'p' | 'P' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_hex_float ();\n scan_optionally_signed_decimal_int width ib\n | _ -> width\n )\n | _ ->\n scan_caml_float_rest width precision ib\n )\n | '1' .. '9' as c ->\n let width = Scanning.store_char width ib c in\n if width = 0 || Scanning.end_of_input ib then bad_float ();\n scan_caml_float_rest width precision ib\n(* Special case of nan and infinity:\n | 'i' ->\n | 'n' ->\n*)\n | _ -> bad_float ()\n\n\n(* Scan a regular string:\n stops when encountering a space, if no scanning indication has been given;\n otherwise, stops when encountering the characters in the scanning\n indication [stp].\n It also stops at end of file or when the maximum number of characters has\n been read. *)\nlet scan_string stp width ib =\n let rec loop width =\n if width = 0 then width else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then width else\n match stp with\n | Some c' when c = c' -> Scanning.skip_char width ib\n | Some _ -> loop (Scanning.store_char width ib c)\n | None ->\n match c with\n | ' ' | '\\t' | '\\n' | '\\r' -> width\n | _ -> loop (Scanning.store_char width ib c) in\n loop width\n\n\n(* Scan a char: peek strictly one character in the input, whatsoever. *)\nlet scan_char width ib =\n (* The case width = 0 could not happen here, since it is tested before\n calling scan_char, in the main scanning function.\n if width = 0 then bad_token_length \"a character\" else *)\n Scanning.store_char width ib (Scanning.checked_peek_char ib)\n\n\nlet char_for_backslash = function\n | 'n' -> '\\010'\n | 'r' -> '\\013'\n | 'b' -> '\\008'\n | 't' -> '\\009'\n | c -> c\n\n\n(* The integer value corresponding to the facial value of a valid\n decimal digit character. *)\nlet decimal_value_of_char c = int_of_char c - int_of_char '0'\n\nlet char_for_decimal_code c0 c1 c2 =\n let c =\n 100 * decimal_value_of_char c0 +\n 10 * decimal_value_of_char c1 +\n decimal_value_of_char c2 in\n if c < 0 || c > 255 then\n bad_input\n (Printf.sprintf\n \"bad character decimal encoding \\\\%c%c%c\" c0 c1 c2) else\n char_of_int c\n\n\n(* The integer value corresponding to the facial value of a valid\n hexadecimal digit character. *)\nlet hexadecimal_value_of_char c =\n let d = int_of_char c in\n (* Could also be:\n if d <= int_of_char '9' then d - int_of_char '0' else\n if d <= int_of_char 'F' then 10 + d - int_of_char 'A' else\n if d <= int_of_char 'f' then 10 + d - int_of_char 'a' else assert false\n *)\n if d >= int_of_char 'a' then\n d - 87 (* 10 + int_of_char c - int_of_char 'a' *) else\n if d >= int_of_char 'A' then\n d - 55 (* 10 + int_of_char c - int_of_char 'A' *) else\n d - int_of_char '0'\n\n\nlet char_for_hexadecimal_code c1 c2 =\n let c =\n 16 * hexadecimal_value_of_char c1 +\n hexadecimal_value_of_char c2 in\n if c < 0 || c > 255 then\n bad_input\n (Printf.sprintf \"bad character hexadecimal encoding \\\\%c%c\" c1 c2) else\n char_of_int c\n\n\n(* Called in particular when encountering '\\\\' as starter of a char.\n Stops before the corresponding '\\''. *)\nlet check_next_char message width ib =\n if width = 0 then bad_token_length message else\n let c = Scanning.peek_char ib in\n if Scanning.eof ib then bad_end_of_input message else\n c\n\n\nlet check_next_char_for_char = check_next_char \"a Char\"\nlet check_next_char_for_string = check_next_char \"a String\"\n\nlet scan_backslash_char width ib =\n match check_next_char_for_char width ib with\n | '\\\\' | '\\'' | '\\\"' | 'n' | 't' | 'b' | 'r' as c ->\n Scanning.store_char width ib (char_for_backslash c)\n | '0' .. '9' as c ->\n let get_digit () =\n let c = Scanning.next_char ib in\n match c with\n | '0' .. '9' as c -> c\n | c -> bad_input_escape c in\n let c0 = c in\n let c1 = get_digit () in\n let c2 = get_digit () in\n Scanning.store_char (width - 2) ib (char_for_decimal_code c0 c1 c2)\n | 'x' ->\n let get_digit () =\n let c = Scanning.next_char ib in\n match c with\n | '0' .. '9' | 'A' .. 'F' | 'a' .. 'f' as c -> c\n | c -> bad_input_escape c in\n let c1 = get_digit () in\n let c2 = get_digit () in\n Scanning.store_char (width - 2) ib (char_for_hexadecimal_code c1 c2)\n | c ->\n bad_input_escape c\n\n\n(* Scan a character (an OCaml token). *)\nlet scan_caml_char width ib =\n\n let rec find_start width =\n match Scanning.checked_peek_char ib with\n | '\\'' -> find_char (Scanning.ignore_char width ib)\n | c -> character_mismatch '\\'' c\n\n and find_char width =\n match check_next_char_for_char width ib with\n | '\\\\' ->\n find_stop (scan_backslash_char (Scanning.ignore_char width ib) ib)\n | c ->\n find_stop (Scanning.store_char width ib c)\n\n and find_stop width =\n match check_next_char_for_char width ib with\n | '\\'' -> Scanning.ignore_char width ib\n | c -> character_mismatch '\\'' c in\n\n find_start width\n\n\n(* Scan a delimited string (an OCaml token). *)\nlet scan_caml_string width ib =\n\n let rec find_start width =\n match Scanning.checked_peek_char ib with\n | '\\\"' -> find_stop (Scanning.ignore_char width ib)\n | c -> character_mismatch '\\\"' c\n\n and find_stop width =\n match check_next_char_for_string width ib with\n | '\\\"' -> Scanning.ignore_char width ib\n | '\\\\' -> scan_backslash (Scanning.ignore_char width ib)\n | c -> find_stop (Scanning.store_char width ib c)\n\n and scan_backslash width =\n match check_next_char_for_string width ib with\n | '\\r' -> skip_newline (Scanning.ignore_char width ib)\n | '\\n' -> skip_spaces (Scanning.ignore_char width ib)\n | _ -> find_stop (scan_backslash_char width ib)\n\n and skip_newline width =\n match check_next_char_for_string width ib with\n | '\\n' -> skip_spaces (Scanning.ignore_char width ib)\n | _ -> find_stop (Scanning.store_char width ib '\\r')\n\n and skip_spaces width =\n match check_next_char_for_string width ib with\n | ' ' -> skip_spaces (Scanning.ignore_char width ib)\n | _ -> find_stop width in\n\n find_start width\n\n\n(* Scan a boolean (an OCaml token). *)\nlet scan_bool ib =\n let c = Scanning.checked_peek_char ib in\n let m =\n match c with\n | 't' -> 4\n | 'f' -> 5\n | c ->\n bad_input\n (Printf.sprintf \"the character %C cannot start a boolean\" c) in\n scan_string None m ib\n\n\n(* Scan a string containing elements in char_set and terminated by scan_indic\n if provided. *)\nlet scan_chars_in_char_set char_set scan_indic width ib =\n let rec scan_chars i stp =\n let c = Scanning.peek_char ib in\n if i > 0 && not (Scanning.eof ib) &&\n is_in_char_set char_set c &&\n int_of_char c <> stp then\n let _ = Scanning.store_char max_int ib c in\n scan_chars (i - 1) stp in\n match scan_indic with\n | None -> scan_chars width (-1);\n | Some c ->\n scan_chars width (int_of_char c);\n if not (Scanning.eof ib) then\n let ci = Scanning.peek_char ib in\n if c = ci\n then Scanning.invalidate_current_char ib\n else character_mismatch c ci\n\n\n(* The global error report function for [Scanf]. *)\nlet scanf_bad_input ib = function\n | Scan_failure s | Failure s ->\n let i = Scanning.char_count ib in\n bad_input (Printf.sprintf \"scanf: bad input at char number %i: %s\" i s)\n | x -> raise x\n\n\n(* Get the content of a counter from an input buffer. *)\nlet get_counter ib counter =\n match counter with\n | Line_counter -> Scanning.line_count ib\n | Char_counter -> Scanning.char_count ib\n | Token_counter -> Scanning.token_count ib\n\n\n(* Compute the width of a padding option (see \"%42{\" and \"%123(\"). *)\nlet width_of_pad_opt pad_opt = match pad_opt with\n | None -> max_int\n | Some width -> width\n\n\nlet stopper_of_formatting_lit fmting =\n if fmting = Escaped_percent then '%', \"\" else\n let str = string_of_formatting_lit fmting in\n let stp = str.[1] in\n let sub_str = String.sub str 2 (String.length str - 2) in\n stp, sub_str\n\n\n(******************************************************************************)\n (* Reader management *)\n\n(* A call to take_format_readers on a format is evaluated into functions\n taking readers as arguments and aggregate them into an heterogeneous list *)\n(* When all readers are taken, finally pass the list of the readers to the\n continuation k. *)\nlet rec take_format_readers : type a c d e f .\n ((d, e) heter_list -> e) -> (a, Scanning.in_channel, c, d, e, f) fmt ->\n d =\nfun k fmt -> match fmt with\n | Reader fmt_rest ->\n fun reader ->\n let new_k readers_rest = k (Cons (reader, readers_rest)) in\n take_format_readers new_k fmt_rest\n | Char rest -> take_format_readers k rest\n | Caml_char rest -> take_format_readers k rest\n | String (_, rest) -> take_format_readers k rest\n | Caml_string (_, rest) -> take_format_readers k rest\n | Int (_, _, _, rest) -> take_format_readers k rest\n | Int32 (_, _, _, rest) -> take_format_readers k rest\n | Nativeint (_, _, _, rest) -> take_format_readers k rest\n | Int64 (_, _, _, rest) -> take_format_readers k rest\n | Float (_, _, _, rest) -> take_format_readers k rest\n | Bool (_, rest) -> take_format_readers k rest\n | Alpha rest -> take_format_readers k rest\n | Theta rest -> take_format_readers k rest\n | Flush rest -> take_format_readers k rest\n | String_literal (_, rest) -> take_format_readers k rest\n | Char_literal (_, rest) -> take_format_readers k rest\n | Custom (_, _, rest) -> take_format_readers k rest\n\n | Scan_char_set (_, _, rest) -> take_format_readers k rest\n | Scan_get_counter (_, rest) -> take_format_readers k rest\n | Scan_next_char rest -> take_format_readers k rest\n\n | Formatting_lit (_, rest) -> take_format_readers k rest\n | Formatting_gen (Open_tag (Format (fmt, _)), rest) ->\n take_format_readers k (concat_fmt fmt rest)\n | Formatting_gen (Open_box (Format (fmt, _)), rest) ->\n take_format_readers k (concat_fmt fmt rest)\n\n | Format_arg (_, _, rest) -> take_format_readers k rest\n | Format_subst (_, fmtty, rest) ->\n take_fmtty_format_readers k (erase_rel (symm fmtty)) rest\n | Ignored_param (ign, rest) -> take_ignored_format_readers k ign rest\n\n | End_of_format -> k Nil\n\n(* Take readers associated to an fmtty coming from a Format_subst \"%(...%)\". *)\nand take_fmtty_format_readers : type x y a c d e f .\n ((d, e) heter_list -> e) -> (a, Scanning.in_channel, c, d, x, y) fmtty ->\n (y, Scanning.in_channel, c, x, e, f) fmt -> d =\nfun k fmtty fmt -> match fmtty with\n | Reader_ty fmt_rest ->\n fun reader ->\n let new_k readers_rest = k (Cons (reader, readers_rest)) in\n take_fmtty_format_readers new_k fmt_rest fmt\n | Ignored_reader_ty fmt_rest ->\n fun reader ->\n let new_k readers_rest = k (Cons (reader, readers_rest)) in\n take_fmtty_format_readers new_k fmt_rest fmt\n | Char_ty rest -> take_fmtty_format_readers k rest fmt\n | String_ty rest -> take_fmtty_format_readers k rest fmt\n | Int_ty rest -> take_fmtty_format_readers k rest fmt\n | Int32_ty rest -> take_fmtty_format_readers k rest fmt\n | Nativeint_ty rest -> take_fmtty_format_readers k rest fmt\n | Int64_ty rest -> take_fmtty_format_readers k rest fmt\n | Float_ty rest -> take_fmtty_format_readers k rest fmt\n | Bool_ty rest -> take_fmtty_format_readers k rest fmt\n | Alpha_ty rest -> take_fmtty_format_readers k rest fmt\n | Theta_ty rest -> take_fmtty_format_readers k rest fmt\n | Any_ty rest -> take_fmtty_format_readers k rest fmt\n | Format_arg_ty (_, rest) -> take_fmtty_format_readers k rest fmt\n | End_of_fmtty -> take_format_readers k fmt\n | Format_subst_ty (ty1, ty2, rest) ->\n let ty = trans (symm ty1) ty2 in\n take_fmtty_format_readers k (concat_fmtty ty rest) fmt\n\n(* Take readers associated to an ignored parameter. *)\nand take_ignored_format_readers : type x y a c d e f .\n ((d, e) heter_list -> e) -> (a, Scanning.in_channel, c, d, x, y) ignored ->\n (y, Scanning.in_channel, c, x, e, f) fmt -> d =\nfun k ign fmt -> match ign with\n | Ignored_reader ->\n fun reader ->\n let new_k readers_rest = k (Cons (reader, readers_rest)) in\n take_format_readers new_k fmt\n | Ignored_char -> take_format_readers k fmt\n | Ignored_caml_char -> take_format_readers k fmt\n | Ignored_string _ -> take_format_readers k fmt\n | Ignored_caml_string _ -> take_format_readers k fmt\n | Ignored_int (_, _) -> take_format_readers k fmt\n | Ignored_int32 (_, _) -> take_format_readers k fmt\n | Ignored_nativeint (_, _) -> take_format_readers k fmt\n | Ignored_int64 (_, _) -> take_format_readers k fmt\n | Ignored_float (_, _) -> take_format_readers k fmt\n | Ignored_bool _ -> take_format_readers k fmt\n | Ignored_format_arg _ -> take_format_readers k fmt\n | Ignored_format_subst (_, fmtty) -> take_fmtty_format_readers k fmtty fmt\n | Ignored_scan_char_set _ -> take_format_readers k fmt\n | Ignored_scan_get_counter _ -> take_format_readers k fmt\n | Ignored_scan_next_char -> take_format_readers k fmt\n\n(******************************************************************************)\n (* Generic scanning *)\n\n(* Make a generic scanning function. *)\n(* Scan a stream according to a format and readers obtained by\n take_format_readers, and aggregate scanned values into an\n heterogeneous list. *)\n(* Return the heterogeneous list of scanned values. *)\nlet rec make_scanf : type a c d e f.\n Scanning.in_channel -> (a, Scanning.in_channel, c, d, e, f) fmt ->\n (d, e) heter_list -> (a, f) heter_list =\nfun ib fmt readers -> match fmt with\n | Char rest ->\n let _ = scan_char 0 ib in\n let c = token_char ib in\n Cons (c, make_scanf ib rest readers)\n | Caml_char rest ->\n let _ = scan_caml_char 0 ib in\n let c = token_char ib in\n Cons (c, make_scanf ib rest readers)\n\n | String (pad, Formatting_lit (fmting_lit, rest)) ->\n let stp, str = stopper_of_formatting_lit fmting_lit in\n let scan width _ ib = scan_string (Some stp) width ib in\n let str_rest = String_literal (str, rest) in\n pad_prec_scanf ib str_rest readers pad No_precision scan token_string\n | String (pad, Formatting_gen (Open_tag (Format (fmt', _)), rest)) ->\n let scan width _ ib = scan_string (Some '{') width ib in\n pad_prec_scanf ib (concat_fmt fmt' rest) readers pad No_precision scan\n token_string\n | String (pad, Formatting_gen (Open_box (Format (fmt', _)), rest)) ->\n let scan width _ ib = scan_string (Some '[') width ib in\n pad_prec_scanf ib (concat_fmt fmt' rest) readers pad No_precision scan\n token_string\n | String (pad, rest) ->\n let scan width _ ib = scan_string None width ib in\n pad_prec_scanf ib rest readers pad No_precision scan token_string\n\n | Caml_string (pad, rest) ->\n let scan width _ ib = scan_caml_string width ib in\n pad_prec_scanf ib rest readers pad No_precision scan token_string\n | Int (iconv, pad, prec, rest) ->\n let c = integer_conversion_of_char (char_of_iconv iconv) in\n let scan width _ ib = scan_int_conversion c width ib in\n pad_prec_scanf ib rest readers pad prec scan (token_int c)\n | Int32 (iconv, pad, prec, rest) ->\n let c = integer_conversion_of_char (char_of_iconv iconv) in\n let scan width _ ib = scan_int_conversion c width ib in\n pad_prec_scanf ib rest readers pad prec scan (token_int32 c)\n | Nativeint (iconv, pad, prec, rest) ->\n let c = integer_conversion_of_char (char_of_iconv iconv) in\n let scan width _ ib = scan_int_conversion c width ib in\n pad_prec_scanf ib rest readers pad prec scan (token_nativeint c)\n | Int64 (iconv, pad, prec, rest) ->\n let c = integer_conversion_of_char (char_of_iconv iconv) in\n let scan width _ ib = scan_int_conversion c width ib in\n pad_prec_scanf ib rest readers pad prec scan (token_int64 c)\n | Float ((_, (Float_F | Float_CF)), pad, prec, rest) ->\n pad_prec_scanf ib rest readers pad prec scan_caml_float token_float\n | Float ((_, (Float_f | Float_e | Float_E | Float_g | Float_G)),\n pad, prec, rest) ->\n pad_prec_scanf ib rest readers pad prec scan_float token_float\n | Float ((_, (Float_h | Float_H)), pad, prec, rest) ->\n pad_prec_scanf ib rest readers pad prec scan_hex_float token_float\n | Bool (pad, rest) ->\n let scan _ _ ib = scan_bool ib in\n pad_prec_scanf ib rest readers pad No_precision scan token_bool\n | Alpha _ ->\n invalid_arg \"scanf: bad conversion \\\"%a\\\"\"\n | Theta _ ->\n invalid_arg \"scanf: bad conversion \\\"%t\\\"\"\n | Custom _ ->\n invalid_arg \"scanf: bad conversion \\\"%?\\\" (custom converter)\"\n | Reader fmt_rest ->\n begin match readers with\n | Cons (reader, readers_rest) ->\n let x = reader ib in\n Cons (x, make_scanf ib fmt_rest readers_rest)\n | Nil ->\n invalid_arg \"scanf: missing reader\"\n end\n | Flush rest ->\n if Scanning.end_of_input ib then make_scanf ib rest readers\n else bad_input \"end of input not found\"\n\n | String_literal (str, rest) ->\n String.iter (check_char ib) str;\n make_scanf ib rest readers\n | Char_literal (chr, rest) ->\n check_char ib chr;\n make_scanf ib rest readers\n\n | Format_arg (pad_opt, fmtty, rest) ->\n let _ = scan_caml_string (width_of_pad_opt pad_opt) ib in\n let s = token_string ib in\n let fmt =\n try format_of_string_fmtty s fmtty\n with Failure msg -> bad_input msg\n in\n Cons (fmt, make_scanf ib rest readers)\n | Format_subst (pad_opt, fmtty, rest) ->\n let _ = scan_caml_string (width_of_pad_opt pad_opt) ib in\n let s = token_string ib in\n let fmt, fmt' =\n try\n let Fmt_EBB fmt = fmt_ebb_of_string s in\n let Fmt_EBB fmt' = fmt_ebb_of_string s in\n (* TODO: find a way to avoid reparsing twice *)\n\n (* TODO: these type-checks below *can* fail because of type\n ambiguity in presence of ignored-readers: \"%_r%d\" and \"%d%_r\"\n are typed in the same way.\n\n # Scanf.sscanf \"\\\"%_r%d\\\"3\" \"%(%d%_r%)\" ignore\n (fun fmt n -> string_of_format fmt, n)\n Exception: CamlinternalFormat.Type_mismatch.\n\n We should properly catch this exception.\n *)\n type_format fmt (erase_rel fmtty),\n type_format fmt' (erase_rel (symm fmtty))\n with Failure msg -> bad_input msg\n in\n Cons (Format (fmt, s),\n make_scanf ib (concat_fmt fmt' rest) readers)\n\n | Scan_char_set (width_opt, char_set, Formatting_lit (fmting_lit, rest)) ->\n let stp, str = stopper_of_formatting_lit fmting_lit in\n let width = width_of_pad_opt width_opt in\n scan_chars_in_char_set char_set (Some stp) width ib;\n let s = token_string ib in\n let str_rest = String_literal (str, rest) in\n Cons (s, make_scanf ib str_rest readers)\n | Scan_char_set (width_opt, char_set, rest) ->\n let width = width_of_pad_opt width_opt in\n scan_chars_in_char_set char_set None width ib;\n let s = token_string ib in\n Cons (s, make_scanf ib rest readers)\n | Scan_get_counter (counter, rest) ->\n let count = get_counter ib counter in\n Cons (count, make_scanf ib rest readers)\n | Scan_next_char rest ->\n let c = Scanning.checked_peek_char ib in\n Cons (c, make_scanf ib rest readers)\n\n | Formatting_lit (formatting_lit, rest) ->\n String.iter (check_char ib) (string_of_formatting_lit formatting_lit);\n make_scanf ib rest readers\n | Formatting_gen (Open_tag (Format (fmt', _)), rest) ->\n check_char ib '@'; check_char ib '{';\n make_scanf ib (concat_fmt fmt' rest) readers\n | Formatting_gen (Open_box (Format (fmt', _)), rest) ->\n check_char ib '@'; check_char ib '[';\n make_scanf ib (concat_fmt fmt' rest) readers\n\n | Ignored_param (ign, rest) ->\n let Param_format_EBB fmt' = param_format_of_ignored_format ign rest in\n begin match make_scanf ib fmt' readers with\n | Cons (_, arg_rest) -> arg_rest\n | Nil -> assert false\n end\n\n | End_of_format ->\n Nil\n\n(* Case analysis on padding and precision. *)\n(* Reject formats containing \"%*\" or \"%.*\". *)\n(* Pass padding and precision to the generic scanner `scan'. *)\nand pad_prec_scanf : type a c d e f x y z t .\n Scanning.in_channel -> (a, Scanning.in_channel, c, d, e, f) fmt ->\n (d, e) heter_list -> (x, y) padding -> (y, z -> a) precision ->\n (int -> int -> Scanning.in_channel -> t) ->\n (Scanning.in_channel -> z) ->\n (x, f) heter_list =\nfun ib fmt readers pad prec scan token -> match pad, prec with\n | No_padding, No_precision ->\n let _ = scan max_int max_int ib in\n let x = token ib in\n Cons (x, make_scanf ib fmt readers)\n | No_padding, Lit_precision p ->\n let _ = scan max_int p ib in\n let x = token ib in\n Cons (x, make_scanf ib fmt readers)\n | Lit_padding ((Right | Zeros), w), No_precision ->\n let _ = scan w max_int ib in\n let x = token ib in\n Cons (x, make_scanf ib fmt readers)\n | Lit_padding ((Right | Zeros), w), Lit_precision p ->\n let _ = scan w p ib in\n let x = token ib in\n Cons (x, make_scanf ib fmt readers)\n | Lit_padding (Left, _), _ ->\n invalid_arg \"scanf: bad conversion \\\"%-\\\"\"\n | Lit_padding ((Right | Zeros), _), Arg_precision ->\n invalid_arg \"scanf: bad conversion \\\"%*\\\"\"\n | Arg_padding _, _ ->\n invalid_arg \"scanf: bad conversion \\\"%*\\\"\"\n | No_padding, Arg_precision ->\n invalid_arg \"scanf: bad conversion \\\"%*\\\"\"\n\n(******************************************************************************)\n (* Defining [scanf] and various flavors of [scanf] *)\n\ntype 'a kscanf_result = Args of 'a | Exc of exn\n\nlet kscanf ib ef (Format (fmt, str)) =\n let rec apply : type a b . a -> (a, b) heter_list -> b =\n fun f args -> match args with\n | Cons (x, r) -> apply (f x) r\n | Nil -> f\n in\n let k readers f =\n Scanning.reset_token ib;\n match try Args (make_scanf ib fmt readers) with\n | (Scan_failure _ | Failure _ | End_of_file) as exc -> Exc exc\n | Invalid_argument msg ->\n invalid_arg (msg ^ \" in format \\\"\" ^ String.escaped str ^ \"\\\"\")\n with\n | Args args -> apply f args\n | Exc exc -> ef ib exc\n in\n take_format_readers k fmt\n\n(***)\n\nlet kbscanf = kscanf\nlet bscanf ib fmt = kbscanf ib scanf_bad_input fmt\n\nlet ksscanf s ef fmt = kbscanf (Scanning.from_string s) ef fmt\nlet sscanf s fmt = kbscanf (Scanning.from_string s) scanf_bad_input fmt\n\nlet scanf fmt = kscanf Scanning.stdib scanf_bad_input fmt\n\n(***)\n\n(* Scanning format strings. *)\nlet bscanf_format :\n Scanning.in_channel -> ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n (('a, 'b, 'c, 'd, 'e, 'f) format6 -> 'g) -> 'g =\n fun ib format f ->\n let _ = scan_caml_string max_int ib in\n let str = token_string ib in\n let fmt' =\n try format_of_string_format str format\n with Failure msg -> bad_input msg in\n f fmt'\n\n\nlet sscanf_format :\n string -> ('a, 'b, 'c, 'd, 'e, 'f) format6 ->\n (('a, 'b, 'c, 'd, 'e, 'f) format6 -> 'g) -> 'g =\n fun s format f -> bscanf_format (Scanning.from_string s) format f\n\n\nlet format_from_string s fmt =\n sscanf_format (\"\\\"\" ^ String.escaped s ^ \"\\\"\") fmt (fun x -> x)\n\n\nlet unescaped s =\n sscanf (\"\\\"\" ^ s ^ \"\\\"\") \"%S%!\" (fun x -> x)\n\n\n(* Deprecated *)\nlet kfscanf ic ef fmt = kbscanf (Scanning.memo_from_channel ic) ef fmt\nlet fscanf ic fmt = kscanf (Scanning.memo_from_channel ic) scanf_bad_input fmt\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Registering OCaml values with the C runtime for later callbacks *)\n\nexternal register_named_value : string -> Obj.t -> unit\n = \"caml_register_named_value\"\n\nlet register name v =\n register_named_value name (Obj.repr v)\n\nlet register_exception name (exn : exn) =\n let exn = Obj.repr exn in\n let slot = if Obj.tag exn = Obj.object_tag then exn else Obj.field exn 0 in\n register_named_value name slot\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2004 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\ntype shape =\n | Function\n | Lazy\n | Class\n | Module of shape array\n | Value of Obj.t\n\nlet rec init_mod_field modu i loc shape =\n let init =\n match shape with\n | Function ->\n let rec fn (x : 'a) =\n let fn' : 'a -> 'b = Obj.obj (Obj.field modu i) in\n if fn == fn' then\n raise (Undefined_recursive_module loc)\n else\n fn' x in\n Obj.repr fn\n | Lazy ->\n let rec l =\n lazy (\n let l' = Obj.obj (Obj.field modu i) in\n if l == l' then\n raise (Undefined_recursive_module loc)\n else\n Lazy.force l') in\n Obj.repr l\n | Class ->\n Obj.repr (CamlinternalOO.dummy_class loc)\n | Module comps ->\n Obj.repr (init_mod_block loc comps)\n | Value v -> v\n in\n Obj.set_field modu i init\n\nand init_mod_block loc comps =\n let length = Array.length comps in\n let modu = Obj.new_block 0 length in\n for i = 0 to length - 1 do\n init_mod_field modu i loc comps.(i)\n done;\n modu\n\nlet init_mod loc shape =\n match shape with\n | Module comps ->\n Obj.repr (init_mod_block loc comps)\n | _ -> failwith \"CamlinternalMod.init_mod: not a module\"\n\nlet rec update_mod_field modu i shape n =\n match shape with\n | Function | Lazy ->\n Obj.set_field modu i n\n | Value _ ->\n () (* the value is already there *)\n | Class ->\n assert (Obj.tag n = 0 && Obj.size n = 4);\n let cl = Obj.field modu i in\n for j = 0 to 3 do\n Obj.set_field cl j (Obj.field n j)\n done\n | Module comps ->\n update_mod_block comps (Obj.field modu i) n\n\nand update_mod_block comps o n =\n assert (Obj.tag n = 0 && Obj.size n >= Array.length comps);\n for i = 0 to Array.length comps - 1 do\n update_mod_field o i comps.(i) (Obj.field n i)\n done\n\nlet update_mod shape o n =\n match shape with\n | Module comps ->\n update_mod_block comps o n\n | _ -> failwith \"CamlinternalMod.update_mod: not a module\"\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Manuel Serrano et Xavier Leroy, INRIA Rocquencourt *)\n(* *)\n(* Copyright 2000 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Module [Bigarray]: large, multi-dimensional, numerical arrays *)\n\n(* These types in must be kept in sync with the tables in\n ../typing/typeopt.ml *)\n\ntype float32_elt = Float32_elt\ntype float64_elt = Float64_elt\ntype int8_signed_elt = Int8_signed_elt\ntype int8_unsigned_elt = Int8_unsigned_elt\ntype int16_signed_elt = Int16_signed_elt\ntype int16_unsigned_elt = Int16_unsigned_elt\ntype int32_elt = Int32_elt\ntype int64_elt = Int64_elt\ntype int_elt = Int_elt\ntype nativeint_elt = Nativeint_elt\ntype complex32_elt = Complex32_elt\ntype complex64_elt = Complex64_elt\n\ntype ('a, 'b) kind =\n Float32 : (float, float32_elt) kind\n | Float64 : (float, float64_elt) kind\n | Int8_signed : (int, int8_signed_elt) kind\n | Int8_unsigned : (int, int8_unsigned_elt) kind\n | Int16_signed : (int, int16_signed_elt) kind\n | Int16_unsigned : (int, int16_unsigned_elt) kind\n | Int32 : (int32, int32_elt) kind\n | Int64 : (int64, int64_elt) kind\n | Int : (int, int_elt) kind\n | Nativeint : (nativeint, nativeint_elt) kind\n | Complex32 : (Complex.t, complex32_elt) kind\n | Complex64 : (Complex.t, complex64_elt) kind\n | Char : (char, int8_unsigned_elt) kind\n\ntype c_layout = C_layout_typ\ntype fortran_layout = Fortran_layout_typ (**)\n\ntype 'a layout =\n C_layout: c_layout layout\n | Fortran_layout: fortran_layout layout\n\n(* Keep those constants in sync with the caml_ba_kind enumeration\n in bigarray.h *)\n\nlet float32 = Float32\nlet float64 = Float64\nlet int8_signed = Int8_signed\nlet int8_unsigned = Int8_unsigned\nlet int16_signed = Int16_signed\nlet int16_unsigned = Int16_unsigned\nlet int32 = Int32\nlet int64 = Int64\nlet int = Int\nlet nativeint = Nativeint\nlet complex32 = Complex32\nlet complex64 = Complex64\nlet char = Char\n\nlet kind_size_in_bytes : type a b. (a, b) kind -> int = function\n | Float32 -> 4\n | Float64 -> 8\n | Int8_signed -> 1\n | Int8_unsigned -> 1\n | Int16_signed -> 2\n | Int16_unsigned -> 2\n | Int32 -> 4\n | Int64 -> 8\n | Int -> Sys.word_size / 8\n | Nativeint -> Sys.word_size / 8\n | Complex32 -> 8\n | Complex64 -> 16\n | Char -> 1\n\n(* Keep those constants in sync with the caml_ba_layout enumeration\n in bigarray.h *)\n\nlet c_layout = C_layout\nlet fortran_layout = Fortran_layout\n\nmodule Genarray = struct\n type (!'a, !'b, !'c) t\n external create: ('a, 'b) kind -> 'c layout -> int array -> ('a, 'b, 'c) t\n = \"caml_ba_create\"\n external get: ('a, 'b, 'c) t -> int array -> 'a\n = \"caml_ba_get_generic\"\n external set: ('a, 'b, 'c) t -> int array -> 'a -> unit\n = \"caml_ba_set_generic\"\n\n let rec cloop arr idx f col max =\n if col = Array.length idx then set arr idx (f idx)\n else for j = 0 to pred max.(col) do\n idx.(col) <- j;\n cloop arr idx f (succ col) max\n done\n let rec floop arr idx f col max =\n if col < 0 then set arr idx (f idx)\n else for j = 1 to max.(col) do\n idx.(col) <- j;\n floop arr idx f (pred col) max\n done\n let init (type t) kind (layout : t layout) dims f =\n let arr = create kind layout dims in\n match Array.length dims, layout with\n | 0, _ -> arr\n | dlen, C_layout -> cloop arr (Array.make dlen 0) f 0 dims; arr\n | dlen, Fortran_layout -> floop arr (Array.make dlen 1) f (pred dlen) dims;\n arr\n\n external num_dims: ('a, 'b, 'c) t -> int = \"caml_ba_num_dims\"\n external nth_dim: ('a, 'b, 'c) t -> int -> int = \"caml_ba_dim\"\n let dims a =\n let n = num_dims a in\n let d = Array.make n 0 in\n for i = 0 to n-1 do d.(i) <- nth_dim a i done;\n d\n\n external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n = \"caml_ba_change_layout\"\n\n let size_in_bytes arr =\n (kind_size_in_bytes (kind arr)) * (Array.fold_left ( * ) 1 (dims arr))\n\n external sub_left: ('a, 'b, c_layout) t -> int -> int -> ('a, 'b, c_layout) t\n = \"caml_ba_sub\"\n external sub_right: ('a, 'b, fortran_layout) t -> int -> int ->\n ('a, 'b, fortran_layout) t\n = \"caml_ba_sub\"\n external slice_left: ('a, 'b, c_layout) t -> int array ->\n ('a, 'b, c_layout) t\n = \"caml_ba_slice\"\n external slice_right: ('a, 'b, fortran_layout) t -> int array ->\n ('a, 'b, fortran_layout) t\n = \"caml_ba_slice\"\n external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit\n = \"caml_ba_blit\"\n external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\nend\n\nmodule Array0 = struct\n type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n let create kind layout =\n Genarray.create kind layout [||]\n let get arr = Genarray.get arr [||]\n let set arr = Genarray.set arr [||]\n external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n = \"caml_ba_change_layout\"\n\n let size_in_bytes arr = kind_size_in_bytes (kind arr)\n\n external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n\n let of_value kind layout v =\n let a = create kind layout in\n set a v;\n a\n let init = of_value\nend\n\nmodule Array1 = struct\n type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n let create kind layout dim =\n Genarray.create kind layout [|dim|]\n external get: ('a, 'b, 'c) t -> int -> 'a = \"%caml_ba_ref_1\"\n external set: ('a, 'b, 'c) t -> int -> 'a -> unit = \"%caml_ba_set_1\"\n external unsafe_get: ('a, 'b, 'c) t -> int -> 'a = \"%caml_ba_unsafe_ref_1\"\n external unsafe_set: ('a, 'b, 'c) t -> int -> 'a -> unit\n = \"%caml_ba_unsafe_set_1\"\n external dim: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\n external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n = \"caml_ba_change_layout\"\n\n let size_in_bytes arr =\n (kind_size_in_bytes (kind arr)) * (dim arr)\n\n external sub: ('a, 'b, 'c) t -> int -> int -> ('a, 'b, 'c) t = \"caml_ba_sub\"\n let slice (type t) (a : (_, _, t) Genarray.t) n =\n match layout a with\n | C_layout -> (Genarray.slice_left a [|n|] : (_, _, t) Genarray.t)\n | Fortran_layout -> (Genarray.slice_right a [|n|]: (_, _, t) Genarray.t)\n external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n let c_init arr dim f =\n for i = 0 to pred dim do unsafe_set arr i (f i) done\n let fortran_init arr dim f =\n for i = 1 to dim do unsafe_set arr i (f i) done\n let init (type t) kind (layout : t layout) dim f =\n let arr = create kind layout dim in\n match layout with\n | C_layout -> c_init arr dim f; arr\n | Fortran_layout -> fortran_init arr dim f; arr\n let of_array (type t) kind (layout: t layout) data =\n let ba = create kind layout (Array.length data) in\n let ofs =\n match layout with\n C_layout -> 0\n | Fortran_layout -> 1\n in\n for i = 0 to Array.length data - 1 do unsafe_set ba (i + ofs) data.(i) done;\n ba\nend\n\nmodule Array2 = struct\n type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n let create kind layout dim1 dim2 =\n Genarray.create kind layout [|dim1; dim2|]\n external get: ('a, 'b, 'c) t -> int -> int -> 'a = \"%caml_ba_ref_2\"\n external set: ('a, 'b, 'c) t -> int -> int -> 'a -> unit = \"%caml_ba_set_2\"\n external unsafe_get: ('a, 'b, 'c) t -> int -> int -> 'a\n = \"%caml_ba_unsafe_ref_2\"\n external unsafe_set: ('a, 'b, 'c) t -> int -> int -> 'a -> unit\n = \"%caml_ba_unsafe_set_2\"\n external dim1: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\n external dim2: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_2\"\n external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n = \"caml_ba_change_layout\"\n\n let size_in_bytes arr =\n (kind_size_in_bytes (kind arr)) * (dim1 arr) * (dim2 arr)\n\n external sub_left: ('a, 'b, c_layout) t -> int -> int -> ('a, 'b, c_layout) t\n = \"caml_ba_sub\"\n external sub_right:\n ('a, 'b, fortran_layout) t -> int -> int -> ('a, 'b, fortran_layout) t\n = \"caml_ba_sub\"\n let slice_left a n = Genarray.slice_left a [|n|]\n let slice_right a n = Genarray.slice_right a [|n|]\n external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n let c_init arr dim1 dim2 f =\n for i = 0 to pred dim1 do\n for j = 0 to pred dim2 do\n unsafe_set arr i j (f i j)\n done\n done\n let fortran_init arr dim1 dim2 f =\n for j = 1 to dim2 do\n for i = 1 to dim1 do\n unsafe_set arr i j (f i j)\n done\n done\n let init (type t) kind (layout : t layout) dim1 dim2 f =\n let arr = create kind layout dim1 dim2 in\n match layout with\n | C_layout -> c_init arr dim1 dim2 f; arr\n | Fortran_layout -> fortran_init arr dim1 dim2 f; arr\n let of_array (type t) kind (layout: t layout) data =\n let dim1 = Array.length data in\n let dim2 = if dim1 = 0 then 0 else Array.length data.(0) in\n let ba = create kind layout dim1 dim2 in\n let ofs =\n match layout with\n C_layout -> 0\n | Fortran_layout -> 1\n in\n for i = 0 to dim1 - 1 do\n let row = data.(i) in\n if Array.length row <> dim2 then\n invalid_arg(\"Bigarray.Array2.of_array: non-rectangular data\");\n for j = 0 to dim2 - 1 do\n unsafe_set ba (i + ofs) (j + ofs) row.(j)\n done\n done;\n ba\nend\n\nmodule Array3 = struct\n type (!'a, !'b, !'c) t = ('a, 'b, 'c) Genarray.t\n let create kind layout dim1 dim2 dim3 =\n Genarray.create kind layout [|dim1; dim2; dim3|]\n external get: ('a, 'b, 'c) t -> int -> int -> int -> 'a = \"%caml_ba_ref_3\"\n external set: ('a, 'b, 'c) t -> int -> int -> int -> 'a -> unit\n = \"%caml_ba_set_3\"\n external unsafe_get: ('a, 'b, 'c) t -> int -> int -> int -> 'a\n = \"%caml_ba_unsafe_ref_3\"\n external unsafe_set: ('a, 'b, 'c) t -> int -> int -> int -> 'a -> unit\n = \"%caml_ba_unsafe_set_3\"\n external dim1: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_1\"\n external dim2: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_2\"\n external dim3: ('a, 'b, 'c) t -> int = \"%caml_ba_dim_3\"\n external kind: ('a, 'b, 'c) t -> ('a, 'b) kind = \"caml_ba_kind\"\n external layout: ('a, 'b, 'c) t -> 'c layout = \"caml_ba_layout\"\n\n external change_layout: ('a, 'b, 'c) t -> 'd layout -> ('a, 'b, 'd) t\n = \"caml_ba_change_layout\"\n\n let size_in_bytes arr =\n (kind_size_in_bytes (kind arr)) * (dim1 arr) * (dim2 arr) * (dim3 arr)\n\n external sub_left: ('a, 'b, c_layout) t -> int -> int -> ('a, 'b, c_layout) t\n = \"caml_ba_sub\"\n external sub_right:\n ('a, 'b, fortran_layout) t -> int -> int -> ('a, 'b, fortran_layout) t\n = \"caml_ba_sub\"\n let slice_left_1 a n m = Genarray.slice_left a [|n; m|]\n let slice_right_1 a n m = Genarray.slice_right a [|n; m|]\n let slice_left_2 a n = Genarray.slice_left a [|n|]\n let slice_right_2 a n = Genarray.slice_right a [|n|]\n external blit: ('a, 'b, 'c) t -> ('a, 'b, 'c) t -> unit = \"caml_ba_blit\"\n external fill: ('a, 'b, 'c) t -> 'a -> unit = \"caml_ba_fill\"\n let c_init arr dim1 dim2 dim3 f =\n for i = 0 to pred dim1 do\n for j = 0 to pred dim2 do\n for k = 0 to pred dim3 do\n unsafe_set arr i j k (f i j k)\n done\n done\n done\n let fortran_init arr dim1 dim2 dim3 f =\n for k = 1 to dim3 do\n for j = 1 to dim2 do\n for i = 1 to dim1 do\n unsafe_set arr i j k (f i j k)\n done\n done\n done\n let init (type t) kind (layout : t layout) dim1 dim2 dim3 f =\n let arr = create kind layout dim1 dim2 dim3 in\n match layout with\n | C_layout -> c_init arr dim1 dim2 dim3 f; arr\n | Fortran_layout -> fortran_init arr dim1 dim2 dim3 f; arr\n let of_array (type t) kind (layout: t layout) data =\n let dim1 = Array.length data in\n let dim2 = if dim1 = 0 then 0 else Array.length data.(0) in\n let dim3 = if dim2 = 0 then 0 else Array.length data.(0).(0) in\n let ba = create kind layout dim1 dim2 dim3 in\n let ofs =\n match layout with\n C_layout -> 0\n | Fortran_layout -> 1\n in\n for i = 0 to dim1 - 1 do\n let row = data.(i) in\n if Array.length row <> dim2 then\n invalid_arg(\"Bigarray.Array3.of_array: non-cubic data\");\n for j = 0 to dim2 - 1 do\n let col = row.(j) in\n if Array.length col <> dim3 then\n invalid_arg(\"Bigarray.Array3.of_array: non-cubic data\");\n for k = 0 to dim3 - 1 do\n unsafe_set ba (i + ofs) (j + ofs) (k + ofs) col.(k)\n done\n done\n done;\n ba\nend\n\nexternal genarray_of_array0: ('a, 'b, 'c) Array0.t -> ('a, 'b, 'c) Genarray.t\n = \"%identity\"\nexternal genarray_of_array1: ('a, 'b, 'c) Array1.t -> ('a, 'b, 'c) Genarray.t\n = \"%identity\"\nexternal genarray_of_array2: ('a, 'b, 'c) Array2.t -> ('a, 'b, 'c) Genarray.t\n = \"%identity\"\nexternal genarray_of_array3: ('a, 'b, 'c) Array3.t -> ('a, 'b, 'c) Genarray.t\n = \"%identity\"\nlet array0_of_genarray a =\n if Genarray.num_dims a = 0 then a\n else invalid_arg \"Bigarray.array0_of_genarray\"\nlet array1_of_genarray a =\n if Genarray.num_dims a = 1 then a\n else invalid_arg \"Bigarray.array1_of_genarray\"\nlet array2_of_genarray a =\n if Genarray.num_dims a = 2 then a\n else invalid_arg \"Bigarray.array2_of_genarray\"\nlet array3_of_genarray a =\n if Genarray.num_dims a = 3 then a\n else invalid_arg \"Bigarray.array3_of_genarray\"\n\nexternal reshape:\n ('a, 'b, 'c) Genarray.t -> int array -> ('a, 'b, 'c) Genarray.t\n = \"caml_ba_reshape\"\nlet reshape_0 a = reshape a [||]\nlet reshape_1 a dim1 = reshape a [|dim1|]\nlet reshape_2 a dim1 dim2 = reshape a [|dim1;dim2|]\nlet reshape_3 a dim1 dim2 dim3 = reshape a [|dim1;dim2;dim3|]\n\n(* Force caml_ba_get_{1,2,3,N} to be linked in, since we don't refer\n to those primitives directly in this file *)\n\nlet _ =\n let _ = Genarray.get in\n let _ = Array1.get in\n let _ = Array2.get in\n let _ = Array3.get in\n ()\n\n[@@@ocaml.warning \"-32\"]\nexternal get1: unit -> unit = \"caml_ba_get_1\"\nexternal get2: unit -> unit = \"caml_ba_get_2\"\nexternal get3: unit -> unit = \"caml_ba_get_3\"\nexternal set1: unit -> unit = \"caml_ba_set_1\"\nexternal set2: unit -> unit = \"caml_ba_set_2\"\nexternal set3: unit -> unit = \"caml_ba_set_3\"\n","(** Why allocate a ref instead of storing the int directly?\n\n We generate many more sexp grammars than actually get used, so we prefer to defer the\n id until we need it. The compiler can optimize away allocations that nobody touches.\n*)\n\ntype t = int Lazy.t\n\nlet create =\n let next = ref 0 in\n fun () -> lazy (\n (* As long as we don't give up the global Ocaml runtime lock by allocating, we can\n treat the read and write as atomic. See \"20.12.2 Parallel execution of long-running\n C code\" in the 4.09 manual. *)\n let id = !next in\n next := id + 1;\n id)\n\nlet force (t : t) = Lazy.force t\n\nlet compare a b = compare (force a) (force b)\n","[@@@ocaml.warning \"-3\"]\n\n(* blit_string doesn't exist in [StdLabels.Bytes]... *)\nlet bytes_blit_string ~src ~src_pos ~dst ~dst_pos ~len =\n Bytes.blit_string src src_pos dst dst_pos len\n\nopen StdLabels\nopen Format\n\n(** Type of S-expressions *)\ntype t = Atom of string | List of t list\n\nlet sexp_of_t t = t\nlet t_of_sexp t = t\nlet t_sexp_grammar = Raw_grammar.Inline Any\n\nlet rec compare_list a b =\n match a, b with\n | [] , [] -> 0\n | [] , _ -> -1\n | _ , [] -> 1\n | x::xs, y::ys ->\n let res = compare x y in\n if res <> 0 then res\n else compare_list xs ys\n\nand compare a b =\n if a == b then\n 0\n else\n match a, b with\n | Atom a, Atom b -> String.compare a b\n | Atom _, _ -> -1\n | _, Atom _ -> 1\n | List a, List b -> compare_list a b\n\nlet equal a b = compare a b = 0\n\nexception Not_found_s of t\n\nexception Of_sexp_error of exn * t\n\nmodule Printing = struct\n (* Default indentation level for human-readable conversions *)\n\n let default_indent = ref 1\n\n (* Escaping of strings used as atoms in S-expressions *)\n\n let must_escape str =\n let len = String.length str in\n len = 0 ||\n let rec loop str ix =\n match str.[ix] with\n | '\"' | '(' | ')' | ';' | '\\\\' -> true\n | '|' -> ix > 0 && let next = ix - 1 in Char.equal str.[next] '#' || loop str next\n | '#' -> ix > 0 && let next = ix - 1 in Char.equal str.[next] '|' || loop str next\n | '\\000' .. '\\032' | '\\127' .. '\\255' -> true\n | _ -> ix > 0 && loop str (ix - 1)\n in\n loop str (len - 1)\n\n let escaped s =\n let n = ref 0 in\n for i = 0 to String.length s - 1 do\n n := !n +\n (match String.unsafe_get s i with\n | '\\\"' | '\\\\' | '\\n' | '\\t' | '\\r' | '\\b' -> 2\n | ' ' .. '~' -> 1\n | _ -> 4)\n done;\n if !n = String.length s then s else begin\n let s' = Bytes.create !n in\n n := 0;\n for i = 0 to String.length s - 1 do\n begin match String.unsafe_get s i with\n | ('\\\"' | '\\\\') as c ->\n Bytes.unsafe_set s' !n '\\\\'; incr n; Bytes.unsafe_set s' !n c\n | '\\n' ->\n Bytes.unsafe_set s' !n '\\\\'; incr n; Bytes.unsafe_set s' !n 'n'\n | '\\t' ->\n Bytes.unsafe_set s' !n '\\\\'; incr n; Bytes.unsafe_set s' !n 't'\n | '\\r' ->\n Bytes.unsafe_set s' !n '\\\\'; incr n; Bytes.unsafe_set s' !n 'r'\n | '\\b' ->\n Bytes.unsafe_set s' !n '\\\\'; incr n; Bytes.unsafe_set s' !n 'b'\n | (' ' .. '~') as c -> Bytes.unsafe_set s' !n c\n | c ->\n let a = Char.code c in\n Bytes.unsafe_set s' !n '\\\\';\n incr n;\n Bytes.unsafe_set s' !n (Char.chr (48 + a / 100));\n incr n;\n Bytes.unsafe_set s' !n (Char.chr (48 + (a / 10) mod 10));\n incr n;\n Bytes.unsafe_set s' !n (Char.chr (48 + a mod 10));\n end;\n incr n\n done;\n Bytes.unsafe_to_string s'\n end\n\n let esc_str str =\n let estr = escaped str in\n let elen = String.length estr in\n let res = Bytes.create (elen + 2) in\n bytes_blit_string ~src:estr ~src_pos:0 ~dst:res ~dst_pos:1 ~len:elen;\n Bytes.unsafe_set res 0 '\"';\n Bytes.unsafe_set res (elen + 1) '\"';\n Bytes.unsafe_to_string res\n\n let index_of_newline str start =\n try Some (String.index_from str start '\\n')\n with Not_found -> None\n\n let get_substring str index end_pos_opt =\n let end_pos =\n match end_pos_opt with\n | None -> String.length str\n | Some end_pos -> end_pos\n in\n String.sub str ~pos:index ~len:(end_pos - index)\n\n let is_one_line str =\n match index_of_newline str 0 with\n | None -> true\n | Some index -> index + 1 = String.length str\n\n let pp_hum_maybe_esc_str ppf str =\n if not (must_escape str) then\n pp_print_string ppf str\n else if is_one_line str then\n pp_print_string ppf (esc_str str)\n else begin\n let rec loop index =\n let next_newline = index_of_newline str index in\n let next_line = get_substring str index next_newline in\n pp_print_string ppf (escaped next_line);\n match next_newline with\n | None -> ()\n | Some newline_index ->\n pp_print_string ppf \"\\\\\";\n pp_force_newline ppf ();\n pp_print_string ppf \"\\\\n\";\n loop (newline_index + 1)\n in\n pp_open_box ppf 0;\n (* the leading space is to line up the lines *)\n pp_print_string ppf \" \\\"\";\n loop 0;\n pp_print_string ppf \"\\\"\";\n pp_close_box ppf ();\n end\n\n let mach_maybe_esc_str str =\n if must_escape str then esc_str str else str\n\n (* Output of S-expressions to formatters *)\n\n let rec pp_hum_indent indent ppf = function\n | Atom str -> pp_hum_maybe_esc_str ppf str\n | List (h :: t) ->\n pp_open_box ppf indent;\n pp_print_string ppf \"(\";\n pp_hum_indent indent ppf h;\n pp_hum_rest indent ppf t\n | List [] -> pp_print_string ppf \"()\"\n\n and pp_hum_rest indent ppf = function\n | h :: t ->\n pp_print_space ppf ();\n pp_hum_indent indent ppf h;\n pp_hum_rest indent ppf t\n | [] ->\n pp_print_string ppf \")\";\n pp_close_box ppf ()\n\n let rec pp_mach_internal may_need_space ppf = function\n | Atom str ->\n let str' = mach_maybe_esc_str str in\n let new_may_need_space = str' == str in\n if may_need_space && new_may_need_space then pp_print_string ppf \" \";\n pp_print_string ppf str';\n new_may_need_space\n | List (h :: t) ->\n pp_print_string ppf \"(\";\n let may_need_space = pp_mach_internal false ppf h in\n pp_mach_rest may_need_space ppf t;\n false\n | List [] -> pp_print_string ppf \"()\"; false\n\n and pp_mach_rest may_need_space ppf = function\n | h :: t ->\n let may_need_space = pp_mach_internal may_need_space ppf h in\n pp_mach_rest may_need_space ppf t\n | [] -> pp_print_string ppf \")\"\n\n let pp_hum ppf sexp = pp_hum_indent !default_indent ppf sexp\n\n let pp_mach ppf sexp = ignore (pp_mach_internal false ppf sexp)\n let pp = pp_mach\n\n (* Sexp size *)\n\n let rec size_loop (v, c as acc) = function\n | Atom str -> v + 1, c + String.length str\n | List lst -> List.fold_left lst ~init:acc ~f:size_loop\n\n let size sexp = size_loop (0, 0) sexp\n\n (* Buffer conversions *)\n\n let to_buffer_hum ~buf ?(indent = !default_indent) sexp =\n let ppf = Format.formatter_of_buffer buf in\n Format.fprintf ppf \"%a@?\" (pp_hum_indent indent) sexp\n\n let to_buffer_mach ~buf sexp =\n let rec loop may_need_space = function\n | Atom str ->\n let str' = mach_maybe_esc_str str in\n let new_may_need_space = str' == str in\n if may_need_space && new_may_need_space then Buffer.add_char buf ' ';\n Buffer.add_string buf str';\n new_may_need_space\n | List (h :: t) ->\n Buffer.add_char buf '(';\n let may_need_space = loop false h in\n loop_rest may_need_space t;\n false\n | List [] -> Buffer.add_string buf \"()\"; false\n and loop_rest may_need_space = function\n | h :: t ->\n let may_need_space = loop may_need_space h in\n loop_rest may_need_space t\n | [] -> Buffer.add_char buf ')' in\n ignore (loop false sexp)\n\n let to_buffer = to_buffer_mach\n\n let to_buffer_gen ~buf ~add_char ~add_string sexp =\n let rec loop may_need_space = function\n | Atom str ->\n let str' = mach_maybe_esc_str str in\n let new_may_need_space = str' == str in\n if may_need_space && new_may_need_space then add_char buf ' ';\n add_string buf str';\n new_may_need_space\n | List (h :: t) ->\n add_char buf '(';\n let may_need_space = loop false h in\n loop_rest may_need_space t;\n false\n | List [] -> add_string buf \"()\"; false\n and loop_rest may_need_space = function\n | h :: t ->\n let may_need_space = loop may_need_space h in\n loop_rest may_need_space t\n | [] -> add_char buf ')' in\n ignore (loop false sexp)\n\n (* The maximum size of a thing on the minor heap is 256 words.\n Previously, this size of the returned buffer here was 4096 bytes, which\n caused the Buffer to be allocated on the *major* heap every time.\n\n According to a simple benchmark by Ron, we can improve performance for\n small s-expressions by a factor of ~4 if we only allocate 1024 bytes\n (128 words + some small overhead) worth of buffer initially. And one\n can argue that if it's free to allocate strings smaller than 256 words,\n large s-expressions requiring larger expensive buffers won't notice\n the extra two doublings from 1024 bytes to 2048 and 4096. And especially\n performance-sensitive applications to always pass in a larger buffer to\n use. *)\n let buffer () = Buffer.create 1024\n\n (* String conversions *)\n\n let to_string_hum ?indent = function\n | Atom str when (match index_of_newline str 0 with None -> true | Some _ -> false) ->\n mach_maybe_esc_str str\n | sexp ->\n let buf = buffer () in\n to_buffer_hum ?indent sexp ~buf;\n Buffer.contents buf\n\n let to_string_mach = function\n | Atom str -> mach_maybe_esc_str str\n | sexp ->\n let buf = buffer () in\n to_buffer_mach sexp ~buf;\n Buffer.contents buf\n\n let to_string = to_string_mach\nend\ninclude Printing\n\nlet of_float_style : [ `Underscores | `No_underscores ] ref = ref `No_underscores\nlet of_int_style : [ `Underscores | `No_underscores ] ref = ref `No_underscores\n\nmodule Private = struct\n include Printing\n\n module Raw_grammar = struct\n include Raw_grammar\n\n module Builtin = struct\n let unit_sexp_grammar = Inline (List [])\n let bool_sexp_grammar = Inline (Atom Bool)\n let string_sexp_grammar = Inline (Atom String)\n let bytes_sexp_grammar = string_sexp_grammar\n let char_sexp_grammar = Inline (Atom Char)\n let int_sexp_grammar = Inline (Atom Int)\n let float_sexp_grammar = Inline (Atom Float)\n let int32_sexp_grammar = Inline (Atom Int)\n let int64_sexp_grammar = Inline (Atom Int)\n let nativeint_sexp_grammar = Inline (Atom Int)\n let ref_sexp_grammar = Inline (Explicit_bind ([ \"'a\" ], Explicit_var 0))\n let lazy_t_sexp_grammar = Inline (Explicit_bind ([ \"'a\" ], Explicit_var 0))\n let option_sexp_grammar = Inline (Explicit_bind ([ \"'a\" ], Option (Explicit_var 0)))\n\n let list_sexp_grammar =\n Inline (Explicit_bind ([ \"'a\" ], List [ Many (Explicit_var 0) ]))\n ;;\n\n let array_sexp_grammar = list_sexp_grammar\n end\n\n let empty_sexp_grammar = Inline (Union [])\n let opaque_sexp_grammar = empty_sexp_grammar\n let fun_sexp_grammar = empty_sexp_grammar\n let tuple2_sexp_grammar =\n Inline\n (Explicit_bind\n ([ \"'a\"; \"'b\" ], List [ One (Explicit_var 0); One (Explicit_var 1) ]))\n ;;\n end\nend\n\nlet message name fields =\n let rec conv_fields = function\n | [] -> []\n | (fname, fsexp) :: rest ->\n match fname with\n | \"\" -> fsexp :: conv_fields rest\n | _ -> List [ Atom fname; fsexp ] :: conv_fields rest\n in\n List (Atom name :: conv_fields fields)\n","(* Utility Module for S-expression Conversions *)\nlet polymorphic_compare = compare\nopen StdLabels\nopen MoreLabels\nopen Printf\nopen Sexp\n\ntype sexp_bool = bool\ntype 'a sexp_option = 'a option\ntype 'a sexp_list = 'a list\ntype 'a sexp_array = 'a array\ntype 'a sexp_opaque = 'a\n\n(* Conversion of OCaml-values to S-expressions *)\nexternal format_float : string -> float -> string = \"caml_format_float\"\n\n(* '%.17g' is guaranteed to be round-trippable.\n\n '%.15g' will be round-trippable and not have noise at the last digit or two for a float\n which was converted from a decimal (string) with <= 15 significant digits. So it's\n worth trying first to avoid things like \"3.1400000000000001\".\n\n See comment above [to_string_round_trippable] in {!Core_kernel.Float} for\n detailed explanation and examples. *)\nlet default_string_of_float =\n ref (fun x ->\n let y = format_float \"%.15G\" x in\n if (float_of_string y) = x then\n y\n else\n format_float \"%.17G\" x)\n;;\n\nlet read_old_option_format = ref true\nlet write_old_option_format = ref true\n\nlet list_map f l = List.rev (List.rev_map l ~f)\n\nlet sexp_of_unit () = List []\nlet sexp_of_bool b = Atom (string_of_bool b)\nlet sexp_of_string str = Atom str\nlet sexp_of_bytes bytes = Atom (Bytes.to_string bytes)\nlet sexp_of_char c = Atom (String.make 1 c)\nlet sexp_of_int n = Atom (string_of_int n)\nlet sexp_of_float n = Atom (!default_string_of_float n)\nlet sexp_of_int32 n = Atom (Int32.to_string n)\nlet sexp_of_int64 n = Atom (Int64.to_string n)\nlet sexp_of_nativeint n = Atom (Nativeint.to_string n)\nlet sexp_of_ref sexp_of__a rf = sexp_of__a !rf\nlet sexp_of_lazy_t sexp_of__a lv = sexp_of__a (Lazy.force lv)\n\nlet sexp_of_option sexp_of__a = function\n | Some x when !write_old_option_format -> List [sexp_of__a x]\n | Some x -> List [Atom \"some\"; sexp_of__a x]\n | None when !write_old_option_format -> List []\n | None -> Atom \"none\"\n\nlet sexp_of_pair sexp_of__a sexp_of__b (a, b) =\n List [sexp_of__a a; sexp_of__b b]\n\nlet sexp_of_triple sexp_of__a sexp_of__b sexp_of__c (a, b, c) =\n List [sexp_of__a a; sexp_of__b b; sexp_of__c c]\n\n(* List.rev (List.rev_map ...) is tail recursive, the OCaml standard\n library List.map is NOT. *)\nlet sexp_of_list sexp_of__a lst = List (List.rev (List.rev_map lst ~f:sexp_of__a))\n\nlet sexp_of_array sexp_of__a ar =\n let lst_ref = ref [] in\n for i = Array.length ar - 1 downto 0 do\n lst_ref := sexp_of__a ar.(i) :: !lst_ref\n done;\n List !lst_ref\n\nlet sexp_of_hashtbl sexp_of_key sexp_of_val htbl =\n let coll ~key:k ~data:v acc = List [sexp_of_key k; sexp_of_val v] :: acc in\n List (Hashtbl.fold htbl ~init:[] ~f:coll)\n\nlet sexp_of_opaque _ = Atom \"\"\nlet sexp_of_fun _ = Atom \"\"\n\n\n(* Exception converter registration and lookup *)\n\nmodule Exn_converter = struct\n (* These exception registration functions assume that context-switches\n cannot happen unless there is an allocation. It is reasonable to expect\n that this will remain true for the foreseeable future. That way we\n avoid using mutexes and thus a dependency on the threads library. *)\n\n (* Fast and automatic exception registration *)\n\n module Int = struct\n type t = int\n\n let compare t1 t2 = polymorphic_compare (t1 : int) t2\n end\n\n module Exn_ids = Map.Make (Int)\n\n module Obj = struct\n module Extension_constructor = struct\n [@@@ocaml.warning \"-3\"]\n type t = extension_constructor\n let id = Obj.extension_id\n let of_val = Obj.extension_constructor\n end\n end\n\n let exn_id_map\n : (Obj.Extension_constructor.t, exn -> Sexp.t) Ephemeron.K1.t Exn_ids.t ref =\n ref Exn_ids.empty\n\n (* [Obj.extension_id] works on both the exception itself, and the extension slot of the\n exception. *)\n let rec clean_up_handler (slot : Obj.Extension_constructor.t) =\n let id = Obj.Extension_constructor.id slot in\n let old_exn_id_map = !exn_id_map in\n let new_exn_id_map = Exn_ids.remove id old_exn_id_map in\n (* This trick avoids mutexes and should be fairly efficient *)\n if !exn_id_map != old_exn_id_map then\n clean_up_handler slot\n else\n exn_id_map := new_exn_id_map\n\n (* Ephemerons are used so that [sexp_of_exn] closure don't keep the\n extension_constructor live. *)\n let add ?(finalise = true) extension_constructor sexp_of_exn =\n let id = Obj.Extension_constructor.id extension_constructor in\n let rec loop () =\n let old_exn_id_map = !exn_id_map in\n let ephe = Ephemeron.K1.create () in\n Ephemeron.K1.set_data ephe sexp_of_exn;\n Ephemeron.K1.set_key ephe extension_constructor;\n let new_exn_id_map = Exn_ids.add old_exn_id_map ~key:id ~data:ephe in\n (* This trick avoids mutexes and should be fairly efficient *)\n if !exn_id_map != old_exn_id_map then\n loop ()\n else begin\n exn_id_map := new_exn_id_map;\n if finalise then\n try\n Gc.finalise clean_up_handler extension_constructor\n with Invalid_argument _ ->\n (* Pre-allocated extension constructors cannot be finalised *)\n ()\n end\n in\n loop ()\n\n let add_auto ?finalise exn sexp_of_exn =\n add ?finalise (Obj.Extension_constructor.of_val exn) sexp_of_exn\n\n let find_auto exn =\n let id = Obj.Extension_constructor.id (Obj.Extension_constructor.of_val exn) in\n match Exn_ids.find id !exn_id_map with\n | exception Not_found -> None\n | ephe ->\n match Ephemeron.K1.get_data ephe with\n | None -> None\n | Some sexp_of_exn -> Some (sexp_of_exn exn)\n\n\n module For_unit_tests_only = struct\n let size () = Exn_ids.fold !exn_id_map ~init:0 ~f:(fun ~key:_ ~data:ephe acc ->\n match Ephemeron.K1.get_data ephe with\n | None -> acc\n | Some _ -> acc + 1\n )\n end\n\nend\n\nlet sexp_of_exn_opt exn = Exn_converter.find_auto exn\n\n\nlet sexp_of_exn exn =\n match sexp_of_exn_opt exn with\n | None -> List [Atom (Printexc.to_string exn)]\n | Some sexp -> sexp\n\nlet exn_to_string e = Sexp.to_string_hum (sexp_of_exn e)\n\n(* {[exception Blah [@@deriving sexp]]} generates a call to the function\n [Exn_converter.add] defined in this file. So we are guaranted that as soon as we\n mark an exception as sexpable, this module will be linked in and this printer will be\n registered, which is what we want. *)\nlet () =\n Printexc.register_printer (fun exn ->\n match sexp_of_exn_opt exn with\n | None -> None\n | Some sexp ->\n Some (Sexp.to_string_hum ~indent:2 sexp))\n\n(* Conversion of S-expressions to OCaml-values *)\n\nexception Of_sexp_error = Sexp.Of_sexp_error\n\nlet record_check_extra_fields = ref true\n\nlet of_sexp_error_exn exc sexp = raise (Of_sexp_error (exc, sexp))\n\nlet of_sexp_error what sexp = raise (Of_sexp_error (Failure what, sexp))\n\nlet unit_of_sexp sexp = match sexp with\n | List [] -> ()\n | Atom _ | List _ -> of_sexp_error \"unit_of_sexp: empty list needed\" sexp\n\nlet bool_of_sexp sexp = match sexp with\n | Atom (\"true\" | \"True\") -> true\n | Atom (\"false\" | \"False\") -> false\n | Atom _ -> of_sexp_error \"bool_of_sexp: unknown string\" sexp\n | List _ -> of_sexp_error \"bool_of_sexp: atom needed\" sexp\n\nlet string_of_sexp sexp = match sexp with\n | Atom str -> str\n | List _ -> of_sexp_error \"string_of_sexp: atom needed\" sexp\n\nlet bytes_of_sexp sexp = match sexp with\n | Atom str -> Bytes.of_string str\n | List _ -> of_sexp_error \"bytes_of_sexp: atom needed\" sexp\n\n\nlet char_of_sexp sexp = match sexp with\n | Atom str ->\n if String.length str <> 1 then\n of_sexp_error\n \"char_of_sexp: atom string must contain one character only\" sexp;\n str.[0]\n | List _ -> of_sexp_error \"char_of_sexp: atom needed\" sexp\n\nlet int_of_sexp sexp = match sexp with\n | Atom str ->\n (try int_of_string str\n with exc -> of_sexp_error (\"int_of_sexp: \" ^ exn_to_string exc) sexp)\n | List _ -> of_sexp_error \"int_of_sexp: atom needed\" sexp\n\nlet float_of_sexp sexp = match sexp with\n | Atom str ->\n (try float_of_string str\n with exc ->\n of_sexp_error (\"float_of_sexp: \" ^ exn_to_string exc) sexp)\n | List _ -> of_sexp_error \"float_of_sexp: atom needed\" sexp\n\nlet int32_of_sexp sexp = match sexp with\n | Atom str ->\n (try Int32.of_string str\n with exc ->\n of_sexp_error (\"int32_of_sexp: \" ^ exn_to_string exc) sexp)\n | List _ -> of_sexp_error \"int32_of_sexp: atom needed\" sexp\n\nlet int64_of_sexp sexp = match sexp with\n | Atom str ->\n (try Int64.of_string str\n with exc ->\n of_sexp_error (\"int64_of_sexp: \" ^ exn_to_string exc) sexp)\n | List _ -> of_sexp_error \"int64_of_sexp: atom needed\" sexp\n\nlet nativeint_of_sexp sexp = match sexp with\n | Atom str ->\n (try Nativeint.of_string str\n with exc ->\n of_sexp_error (\"nativeint_of_sexp: \" ^ exn_to_string exc) sexp)\n | List _ -> of_sexp_error \"nativeint_of_sexp: atom needed\" sexp\n\nlet ref_of_sexp a__of_sexp sexp = ref (a__of_sexp sexp)\nlet lazy_t_of_sexp a__of_sexp sexp = Lazy.from_val (a__of_sexp sexp)\n\nlet option_of_sexp a__of_sexp sexp =\n if !read_old_option_format then\n match sexp with\n | List [] | Atom (\"none\" | \"None\") -> None\n | List [el] | List [Atom (\"some\" | \"Some\"); el] -> Some (a__of_sexp el)\n | List _ ->\n of_sexp_error \"option_of_sexp: list must represent optional value\" sexp\n | Atom _ -> of_sexp_error \"option_of_sexp: only none can be atom\" sexp\n else\n match sexp with\n | Atom (\"none\" | \"None\") -> None\n | List [Atom (\"some\" | \"Some\"); el] -> Some (a__of_sexp el)\n | Atom _ -> of_sexp_error \"option_of_sexp: only none can be atom\" sexp\n | List _ -> of_sexp_error \"option_of_sexp: list must be (some el)\" sexp\n\nlet pair_of_sexp a__of_sexp b__of_sexp sexp = match sexp with\n | List [a_sexp; b_sexp] ->\n let a = a__of_sexp a_sexp in\n let b = b__of_sexp b_sexp in\n a, b\n | List _ ->\n of_sexp_error\n \"pair_of_sexp: list must contain exactly two elements only\" sexp\n | Atom _ -> of_sexp_error \"pair_of_sexp: list needed\" sexp\n\nlet triple_of_sexp a__of_sexp b__of_sexp c__of_sexp sexp = match sexp with\n | List [a_sexp; b_sexp; c_sexp] ->\n let a = a__of_sexp a_sexp in\n let b = b__of_sexp b_sexp in\n let c = c__of_sexp c_sexp in\n a, b, c\n | List _ ->\n of_sexp_error\n \"triple_of_sexp: list must contain exactly three elements only\" sexp\n | Atom _ -> of_sexp_error \"triple_of_sexp: list needed\" sexp\n\nlet list_of_sexp a__of_sexp sexp = match sexp with\n | List lst ->\n let rev_lst = List.rev_map lst ~f:a__of_sexp in\n List.rev rev_lst\n | Atom _ -> of_sexp_error \"list_of_sexp: list needed\" sexp\n\nlet array_of_sexp a__of_sexp sexp = match sexp with\n | List [] -> [||]\n | List (h :: t) ->\n let len = List.length t + 1 in\n let res = Array.make len (a__of_sexp h) in\n let rec loop i = function\n | [] -> res\n | h :: t -> res.(i) <- a__of_sexp h; loop (i + 1) t in\n loop 1 t\n | Atom _ -> of_sexp_error \"array_of_sexp: list needed\" sexp\n\nlet hashtbl_of_sexp key_of_sexp val_of_sexp sexp = match sexp with\n | List lst ->\n let htbl = Hashtbl.create 0 in\n let act = function\n | List [k_sexp; v_sexp] ->\n Hashtbl.add htbl ~key:(key_of_sexp k_sexp) ~data:(val_of_sexp v_sexp)\n | List _ | Atom _ ->\n of_sexp_error \"hashtbl_of_sexp: tuple list needed\" sexp\n in\n List.iter lst ~f:act;\n htbl\n | Atom _ -> of_sexp_error \"hashtbl_of_sexp: list needed\" sexp\n\nlet opaque_of_sexp sexp =\n of_sexp_error \"opaque_of_sexp: cannot convert opaque values\" sexp\n\nlet fun_of_sexp sexp =\n of_sexp_error \"fun_of_sexp: cannot convert function values\" sexp\n\n(* Registering default exception printers *)\n\nlet get_flc_error name (file, line, chr) =\n Atom (sprintf \"%s %s:%d:%d\" name file line chr)\n\nlet () =\n List.iter\n ~f:(fun (extension_constructor, handler) -> Exn_converter.add ~finalise:false extension_constructor handler)\n [\n (\n [%extension_constructor Assert_failure],\n (function\n | Assert_failure arg -> get_flc_error \"Assert_failure\" arg\n | _ -> assert false)\n );(\n [%extension_constructor Exit],\n (function\n | Exit -> Atom \"Exit\"\n | _ -> assert false)\n );(\n [%extension_constructor End_of_file],\n (function\n | End_of_file -> Atom \"End_of_file\"\n | _ -> assert false)\n );(\n [%extension_constructor Failure],\n (function\n | Failure arg -> List [Atom \"Failure\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Not_found],\n (function\n | Not_found -> Atom \"Not_found\"\n | _ -> assert false)\n );(\n [%extension_constructor Invalid_argument],\n (function\n | Invalid_argument arg -> List [Atom \"Invalid_argument\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Match_failure],\n (function\n | Match_failure arg -> get_flc_error \"Match_failure\" arg\n | _ -> assert false)\n );(\n [%extension_constructor Not_found_s],\n (function\n | Not_found_s arg -> List [Atom \"Not_found_s\"; arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Sys_error],\n (function\n | Sys_error arg -> List [Atom \"Sys_error\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Arg.Help],\n (function\n | Arg.Help arg -> List [Atom \"Arg.Help\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Arg.Bad],\n (function\n | Arg.Bad arg -> List [Atom \"Arg.Bad\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Lazy.Undefined],\n (function\n | Lazy.Undefined -> Atom \"Lazy.Undefined\"\n | _ -> assert false)\n );(\n [%extension_constructor Parsing.Parse_error],\n (function\n | Parsing.Parse_error -> Atom \"Parsing.Parse_error\"\n | _ -> assert false)\n );(\n [%extension_constructor Queue.Empty],\n (function\n | Queue.Empty -> Atom \"Queue.Empty\"\n | _ -> assert false)\n );(\n [%extension_constructor Scanf.Scan_failure],\n (function\n | Scanf.Scan_failure arg -> List [Atom \"Scanf.Scan_failure\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Stack.Empty],\n (function\n | Stack.Empty -> Atom \"Stack.Empty\"\n | _ -> assert false)\n );(\n [%extension_constructor Stream.Failure],\n (function\n | Stream.Failure -> Atom \"Stream.Failure\"\n | _ -> assert false)\n );(\n [%extension_constructor Stream.Error],\n (function\n | Stream.Error arg -> List [Atom \"Stream.Error\"; Atom arg ]\n | _ -> assert false)\n );(\n [%extension_constructor Sys.Break],\n (function\n | Sys.Break -> Atom \"Sys.Break\"\n | _ -> assert false)\n );(\n [%extension_constructor Of_sexp_error],\n (function\n | Of_sexp_error (exc, sexp) ->\n List [Atom \"Sexplib.Conv.Of_sexp_error\"; sexp_of_exn exc; sexp]\n | _ -> assert false)\n );\n ]\n\nexternal ignore : _ -> unit = \"%ignore\"\nexternal ( = ) : 'a -> 'a -> bool = \"%equal\"\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Damien Doligez, projet Para, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1997 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n[@@@ocaml.warning \"-32\"]\n\nmodule type SeededS = sig\n\n type key\n type !'a t\n val create : ?random (*thwart tools/sync_stdlib_docs*) : bool -> int -> 'a t\n val clear : 'a t -> unit\n val reset : 'a t -> unit\n val copy : 'a t -> 'a t\n val add : 'a t -> key -> 'a -> unit\n val remove : 'a t -> key -> unit\n val find : 'a t -> key -> 'a\n val find_opt : 'a t -> key -> 'a option\n val find_all : 'a t -> key -> 'a list\n val replace : 'a t -> key -> 'a -> unit\n val mem : 'a t -> key -> bool\n val iter : (key -> 'a -> unit) -> 'a t -> unit\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val filter_map_inplace : (key -> 'a -> 'a option) -> 'a t -> unit\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val fold : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val length : 'a t -> int\n val stats : 'a t -> Hashtbl.statistics\n val to_seq : 'a t -> (key * 'a) Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val to_seq_keys : _ t -> key Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val to_seq_values : 'a t -> 'a Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val add_seq : 'a t -> (key * 'a) Seq.t -> unit\n val replace_seq : 'a t -> (key * 'a) Seq.t -> unit\n val of_seq : (key * 'a) Seq.t -> 'a t\n val clean: 'a t -> unit\n val stats_alive: 'a t -> Hashtbl.statistics\n (** same as {!stats} but only count the alive bindings *)\nend\n\nmodule type S = sig\n\n type key\n type !'a t\n val create : int -> 'a t\n val clear : 'a t -> unit\n val reset : 'a t -> unit\n val copy : 'a t -> 'a t\n val add : 'a t -> key -> 'a -> unit\n val remove : 'a t -> key -> unit\n val find : 'a t -> key -> 'a\n val find_opt : 'a t -> key -> 'a option\n val find_all : 'a t -> key -> 'a list\n val replace : 'a t -> key -> 'a -> unit\n val mem : 'a t -> key -> bool\n val iter : (key -> 'a -> unit) -> 'a t -> unit\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val filter_map_inplace : (key -> 'a -> 'a option) -> 'a t -> unit\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val fold : (key -> 'a -> 'b -> 'b) -> 'a t -> 'b -> 'b\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val length : 'a t -> int\n val stats : 'a t -> Hashtbl.statistics\n val to_seq : 'a t -> (key * 'a) Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val to_seq_keys : _ t -> key Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val to_seq_values : 'a t -> 'a Seq.t\n [@@alert old_ephemeron_api \"This function won't be available in 5.0\"]\n val add_seq : 'a t -> (key * 'a) Seq.t -> unit\n val replace_seq : 'a t -> (key * 'a) Seq.t -> unit\n val of_seq : (key * 'a) Seq.t -> 'a t\n val clean: 'a t -> unit\n val stats_alive: 'a t -> Hashtbl.statistics\n (** same as {!stats} but only count the alive bindings *)\nend\n\nmodule GenHashTable = struct\n\n type equal =\n | ETrue | EFalse\n | EDead (** the garbage collector reclaimed the data *)\n\n module MakeSeeded(H: sig\n type t\n type 'a container\n val create: t -> 'a -> 'a container\n val hash: int -> t -> int\n val equal: 'a container -> t -> equal\n val get_data: 'a container -> 'a option\n val get_key: 'a container -> t option\n val set_key_data: 'a container -> t -> 'a -> unit\n val check_key: 'a container -> bool\n end) : SeededS with type key = H.t\n = struct\n\n type 'a t =\n { mutable size: int; (* number of entries *)\n mutable data: 'a bucketlist array; (* the buckets *)\n seed: int; (* for randomization *)\n initial_size: int; (* initial array size *)\n }\n\n and 'a bucketlist =\n | Empty\n | Cons of int (* hash of the key *) * 'a H.container * 'a bucketlist\n\n (** the hash of the key is kept in order to test the equality of the hash\n before the key. Same reason as for Weak.Make *)\n\n type key = H.t\n\n let rec power_2_above x n =\n if x >= n then x\n else if x * 2 > Sys.max_array_length then x\n else power_2_above (x * 2) n\n\n let prng = lazy (Random.State.make_self_init())\n\n let create ?(random = (Hashtbl.is_randomized ())) initial_size =\n let s = power_2_above 16 initial_size in\n let seed = if random then Random.State.bits (Lazy.force prng) else 0 in\n { initial_size = s; size = 0; seed = seed; data = Array.make s Empty }\n\n let clear h =\n h.size <- 0;\n let len = Array.length h.data in\n for i = 0 to len - 1 do\n h.data.(i) <- Empty\n done\n\n let reset h =\n let len = Array.length h.data in\n if len = h.initial_size then\n clear h\n else begin\n h.size <- 0;\n h.data <- Array.make h.initial_size Empty\n end\n\n let copy h = { h with data = Array.copy h.data }\n\n let key_index h hkey =\n hkey land (Array.length h.data - 1)\n\n let clean h =\n let rec do_bucket = function\n | Empty ->\n Empty\n | Cons(_, c, rest) when not (H.check_key c) ->\n h.size <- h.size - 1;\n do_bucket rest\n | Cons(hkey, c, rest) ->\n Cons(hkey, c, do_bucket rest)\n in\n let d = h.data in\n for i = 0 to Array.length d - 1 do\n d.(i) <- do_bucket d.(i)\n done\n\n (** resize is the only function to do the actual cleaning of dead keys\n (remove does it just because it could).\n\n The goal is to:\n\n - not resize infinitely when the actual number of alive keys is\n bounded but keys are continuously added. That would happen if\n this function always resize.\n - not call this function after each addition, that would happen if this\n function don't resize even when only one key is dead.\n\n So the algorithm:\n - clean the keys before resizing\n - if the number of remaining keys is less than half the size of the\n array, don't resize.\n - if it is more, resize.\n\n The second problem remains if the table reaches {!Sys.max_array_length}.\n\n *)\n let resize h =\n let odata = h.data in\n let osize = Array.length odata in\n let nsize = osize * 2 in\n clean h;\n if nsize < Sys.max_array_length && h.size >= osize lsr 1 then begin\n let ndata = Array.make nsize Empty in\n h.data <- ndata; (* so that key_index sees the new bucket count *)\n let rec insert_bucket = function\n Empty -> ()\n | Cons(hkey, data, rest) ->\n insert_bucket rest; (* preserve original order of elements *)\n let nidx = key_index h hkey in\n ndata.(nidx) <- Cons(hkey, data, ndata.(nidx)) in\n for i = 0 to osize - 1 do\n insert_bucket odata.(i)\n done\n end\n\n let add h key info =\n let hkey = H.hash h.seed key in\n let i = key_index h hkey in\n let container = H.create key info in\n let bucket = Cons(hkey, container, h.data.(i)) in\n h.data.(i) <- bucket;\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize h\n\n let remove h key =\n let hkey = H.hash h.seed key in\n let rec remove_bucket = function\n | Empty -> Empty\n | Cons(hk, c, next) when hkey = hk ->\n begin match H.equal c key with\n | ETrue -> h.size <- h.size - 1; next\n | EFalse -> Cons(hk, c, remove_bucket next)\n | EDead ->\n (* The dead key is automatically removed. It is acceptable\n for this function since it already removes a binding *)\n h.size <- h.size - 1;\n remove_bucket next\n end\n | Cons(hk,c,next) -> Cons(hk, c, remove_bucket next) in\n let i = key_index h hkey in\n h.data.(i) <- remove_bucket h.data.(i)\n\n (** {!find} don't remove dead keys because it would be surprising for\n the user that a read-only function mutates the state (eg. concurrent\n access). Same for {!iter}, {!fold}, {!mem}.\n *)\n let rec find_rec key hkey = function\n | Empty ->\n raise Not_found\n | Cons(hk, c, rest) when hkey = hk ->\n begin match H.equal c key with\n | ETrue ->\n begin match H.get_data c with\n | None ->\n (* This case is not impossible because the gc can run between\n H.equal and H.get_data *)\n find_rec key hkey rest\n | Some d -> d\n end\n | EFalse -> find_rec key hkey rest\n | EDead ->\n find_rec key hkey rest\n end\n | Cons(_, _, rest) ->\n find_rec key hkey rest\n\n let find h key =\n let hkey = H.hash h.seed key in\n (* TODO inline 3 iterations *)\n find_rec key hkey (h.data.(key_index h hkey))\n\n let rec find_rec_opt key hkey = function\n | Empty ->\n None\n | Cons(hk, c, rest) when hkey = hk ->\n begin match H.equal c key with\n | ETrue ->\n begin match H.get_data c with\n | None ->\n (* This case is not impossible because the gc can run between\n H.equal and H.get_data *)\n find_rec_opt key hkey rest\n | Some _ as d -> d\n end\n | EFalse -> find_rec_opt key hkey rest\n | EDead ->\n find_rec_opt key hkey rest\n end\n | Cons(_, _, rest) ->\n find_rec_opt key hkey rest\n\n let find_opt h key =\n let hkey = H.hash h.seed key in\n (* TODO inline 3 iterations *)\n find_rec_opt key hkey (h.data.(key_index h hkey))\n\n let find_all h key =\n let hkey = H.hash h.seed key in\n let rec find_in_bucket = function\n | Empty -> []\n | Cons(hk, c, rest) when hkey = hk ->\n begin match H.equal c key with\n | ETrue -> begin match H.get_data c with\n | None ->\n find_in_bucket rest\n | Some d -> d::find_in_bucket rest\n end\n | EFalse -> find_in_bucket rest\n | EDead ->\n find_in_bucket rest\n end\n | Cons(_, _, rest) ->\n find_in_bucket rest in\n find_in_bucket h.data.(key_index h hkey)\n\n\n let replace h key info =\n let hkey = H.hash h.seed key in\n let rec replace_bucket = function\n | Empty -> raise Not_found\n | Cons(hk, c, next) when hkey = hk ->\n begin match H.equal c key with\n | ETrue -> H.set_key_data c key info\n | EFalse | EDead -> replace_bucket next\n end\n | Cons(_,_,next) -> replace_bucket next\n in\n let i = key_index h hkey in\n let l = h.data.(i) in\n try\n replace_bucket l\n with Not_found ->\n let container = H.create key info in\n h.data.(i) <- Cons(hkey, container, l);\n h.size <- h.size + 1;\n if h.size > Array.length h.data lsl 1 then resize h\n\n let mem h key =\n let hkey = H.hash h.seed key in\n let rec mem_in_bucket = function\n | Empty ->\n false\n | Cons(hk, c, rest) when hk = hkey ->\n begin match H.equal c key with\n | ETrue -> true\n | EFalse | EDead -> mem_in_bucket rest\n end\n | Cons(_hk, _c, rest) -> mem_in_bucket rest in\n mem_in_bucket h.data.(key_index h hkey)\n\n let iter f h =\n let rec do_bucket = function\n | Empty ->\n ()\n | Cons(_, c, rest) ->\n begin match H.get_key c, H.get_data c with\n | None, _ | _, None -> ()\n | Some k, Some d -> f k d\n end; do_bucket rest in\n let d = h.data in\n for i = 0 to Array.length d - 1 do\n do_bucket d.(i)\n done\n\n let fold f h init =\n let rec do_bucket b accu =\n match b with\n Empty ->\n accu\n | Cons(_, c, rest) ->\n let accu = begin match H.get_key c, H.get_data c with\n | None, _ | _, None -> accu\n | Some k, Some d -> f k d accu\n end in\n do_bucket rest accu in\n let d = h.data in\n let accu = ref init in\n for i = 0 to Array.length d - 1 do\n accu := do_bucket d.(i) !accu\n done;\n !accu\n\n let filter_map_inplace f h =\n let rec do_bucket = function\n | Empty ->\n Empty\n | Cons(hk, c, rest) ->\n match H.get_key c, H.get_data c with\n | None, _ | _, None ->\n do_bucket rest\n | Some k, Some d ->\n match f k d with\n | None ->\n do_bucket rest\n | Some new_d ->\n H.set_key_data c k new_d;\n Cons(hk, c, do_bucket rest)\n in\n let d = h.data in\n for i = 0 to Array.length d - 1 do\n d.(i) <- do_bucket d.(i)\n done\n\n let length h = h.size\n\n let rec bucket_length accu = function\n | Empty -> accu\n | Cons(_, _, rest) -> bucket_length (accu + 1) rest\n\n let stats h =\n let mbl =\n Array.fold_left (fun m b -> Int.max m (bucket_length 0 b)) 0 h.data in\n let histo = Array.make (mbl + 1) 0 in\n Array.iter\n (fun b ->\n let l = bucket_length 0 b in\n histo.(l) <- histo.(l) + 1)\n h.data;\n { Hashtbl.num_bindings = h.size;\n num_buckets = Array.length h.data;\n max_bucket_length = mbl;\n bucket_histogram = histo }\n\n let rec bucket_length_alive accu = function\n | Empty -> accu\n | Cons(_, c, rest) when H.check_key c ->\n bucket_length_alive (accu + 1) rest\n | Cons(_, _, rest) -> bucket_length_alive accu rest\n\n let stats_alive h =\n let size = ref 0 in\n let mbl =\n Array.fold_left\n (fun m b -> Int.max m (bucket_length_alive 0 b)) 0 h.data\n in\n let histo = Array.make (mbl + 1) 0 in\n Array.iter\n (fun b ->\n let l = bucket_length_alive 0 b in\n size := !size + l;\n histo.(l) <- histo.(l) + 1)\n h.data;\n { Hashtbl.num_bindings = !size;\n num_buckets = Array.length h.data;\n max_bucket_length = mbl;\n bucket_histogram = histo }\n\n let to_seq tbl =\n (* capture current array, so that even if the table is resized we\n keep iterating on the same array *)\n let tbl_data = tbl.data in\n (* state: index * next bucket to traverse *)\n let rec aux i buck () = match buck with\n | Empty ->\n if i = Array.length tbl_data\n then Seq.Nil\n else aux(i+1) tbl_data.(i) ()\n | Cons (_, c, next) ->\n begin match H.get_key c, H.get_data c with\n | None, _ | _, None -> aux i next ()\n | Some key, Some data ->\n Seq.Cons ((key, data), aux i next)\n end\n in\n aux 0 Empty\n\n let to_seq_keys m = Seq.map fst (to_seq m)\n\n let to_seq_values m = Seq.map snd (to_seq m)\n\n let add_seq tbl i =\n Seq.iter (fun (k,v) -> add tbl k v) i\n\n let replace_seq tbl i =\n Seq.iter (fun (k,v) -> replace tbl k v) i\n\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n\n end\nend\n\nmodule ObjEph = Obj.Ephemeron\n\nlet _obj_opt : Obj.t option -> 'a option = fun x ->\n match x with\n | None -> x\n | Some v -> Some (Obj.obj v)\n\n(** The previous function is typed so this one is also correct *)\nlet obj_opt : Obj.t option -> 'a option = fun x -> Obj.magic x\n\n\nmodule K1 = struct\n type ('k,'d) t = ObjEph.t\n\n let create () : ('k,'d) t = ObjEph.create 1\n\n let get_key (t:('k,'d) t) : 'k option = obj_opt (ObjEph.get_key t 0)\n let get_key_copy (t:('k,'d) t) : 'k option = obj_opt (ObjEph.get_key_copy t 0)\n let set_key (t:('k,'d) t) (k:'k) : unit = ObjEph.set_key t 0 (Obj.repr k)\n let unset_key (t:('k,'d) t) : unit = ObjEph.unset_key t 0\n let check_key (t:('k,'d) t) : bool = ObjEph.check_key t 0\n\n let blit_key (t1:('k,'d) t) (t2:('k,'d) t): unit =\n ObjEph.blit_key t1 0 t2 0 1\n\n let get_data (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data t)\n let get_data_copy (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data_copy t)\n let set_data (t:('k,'d) t) (d:'d) : unit = ObjEph.set_data t (Obj.repr d)\n let unset_data (t:('k,'d) t) : unit = ObjEph.unset_data t\n let check_data (t:('k,'d) t) : bool = ObjEph.check_data t\n let blit_data (t1:(_,'d) t) (t2:(_,'d) t) : unit = ObjEph.blit_data t1 t2\n\n let make key data =\n let eph = create () in\n set_data eph data;\n set_key eph key;\n eph\n\n let query eph key =\n match get_key eph with\n | None -> None\n | Some k when k == key -> get_data eph\n | Some _ -> None\n\n module MakeSeeded (H:Hashtbl.SeededHashedType) =\n GenHashTable.MakeSeeded(struct\n type 'a container = (H.t,'a) t\n type t = H.t\n let create k d =\n let c = create () in\n set_data c d;\n set_key c k;\n c\n let hash = H.hash\n let equal c k =\n (* {!get_key_copy} is not used because the equality of the user can be\n the physical equality *)\n match get_key c with\n | None -> GenHashTable.EDead\n | Some k' ->\n if H.equal k k' then GenHashTable.ETrue else GenHashTable.EFalse\n let get_data = get_data\n let get_key = get_key\n let set_key_data c k d =\n unset_data c;\n set_key c k;\n set_data c d\n let check_key = check_key\n end)\n\n module Make(H: Hashtbl.HashedType): (S with type key = H.t) =\n struct\n include MakeSeeded(struct\n type t = H.t\n let equal = H.equal\n let hash (_seed: int) x = H.hash x\n end)\n let create sz = create ~random:false sz\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n end\n\n module Bucket = struct\n\n type nonrec ('k, 'd) t = ('k, 'd) t list ref\n let k1_make = make\n let make () = ref []\n let add b k d = b := k1_make k d :: !b\n\n let test_key k e =\n match get_key e with\n | Some x when x == k -> true\n | _ -> false\n\n let remove b k =\n let rec loop l acc =\n match l with\n | [] -> ()\n | h :: t when test_key k h -> b := List.rev_append acc t\n | h :: t -> loop t (h :: acc)\n in\n loop !b []\n\n let find b k =\n match List.find_opt (test_key k) !b with\n | Some e -> get_data e\n | None -> None\n\n let length b = List.length !b\n let clear b = b := []\n\n end\n\nend\n\nmodule K2 = struct\n type ('k1, 'k2, 'd) t = ObjEph.t\n\n let create () : ('k1,'k2,'d) t = ObjEph.create 2\n\n let get_key1 (t:('k1,'k2,'d) t) : 'k1 option = obj_opt (ObjEph.get_key t 0)\n let get_key1_copy (t:('k1,'k2,'d) t) : 'k1 option =\n obj_opt (ObjEph.get_key_copy t 0)\n let set_key1 (t:('k1,'k2,'d) t) (k:'k1) : unit =\n ObjEph.set_key t 0 (Obj.repr k)\n let unset_key1 (t:('k1,'k2,'d) t) : unit = ObjEph.unset_key t 0\n let check_key1 (t:('k1,'k2,'d) t) : bool = ObjEph.check_key t 0\n\n let get_key2 (t:('k1,'k2,'d) t) : 'k2 option = obj_opt (ObjEph.get_key t 1)\n let get_key2_copy (t:('k1,'k2,'d) t) : 'k2 option =\n obj_opt (ObjEph.get_key_copy t 1)\n let set_key2 (t:('k1,'k2,'d) t) (k:'k2) : unit =\n ObjEph.set_key t 1 (Obj.repr k)\n let unset_key2 (t:('k1,'k2,'d) t) : unit = ObjEph.unset_key t 1\n let check_key2 (t:('k1,'k2,'d) t) : bool = ObjEph.check_key t 1\n\n\n let blit_key1 (t1:('k1,_,_) t) (t2:('k1,_,_) t) : unit =\n ObjEph.blit_key t1 0 t2 0 1\n let blit_key2 (t1:(_,'k2,_) t) (t2:(_,'k2,_) t) : unit =\n ObjEph.blit_key t1 1 t2 1 1\n let blit_key12 (t1:('k1,'k2,_) t) (t2:('k1,'k2,_) t) : unit =\n ObjEph.blit_key t1 0 t2 0 2\n\n let get_data (t:('k1,'k2,'d) t) : 'd option = obj_opt (ObjEph.get_data t)\n let get_data_copy (t:('k1,'k2,'d) t) : 'd option =\n obj_opt (ObjEph.get_data_copy t)\n let set_data (t:('k1,'k2,'d) t) (d:'d) : unit =\n ObjEph.set_data t (Obj.repr d)\n let unset_data (t:('k1,'k2,'d) t) : unit = ObjEph.unset_data t\n let check_data (t:('k1,'k2,'d) t) : bool = ObjEph.check_data t\n let blit_data (t1:(_,_,'d) t) (t2:(_,_,'d) t) : unit = ObjEph.blit_data t1 t2\n\n let make key1 key2 data =\n let eph = create () in\n set_data eph data;\n set_key1 eph key1;\n set_key2 eph key2;\n ignore (Sys.opaque_identity key1);\n eph\n\n let query eph key1 key2 =\n match get_key1 eph with\n | None -> None\n | Some k when k == key1 ->\n begin match get_key2 eph with\n | None -> None\n | Some k when k == key2 -> get_data eph\n | Some _ -> None\n end\n | Some _ -> None\n\n module MakeSeeded\n (H1:Hashtbl.SeededHashedType)\n (H2:Hashtbl.SeededHashedType) =\n GenHashTable.MakeSeeded(struct\n type 'a container = (H1.t,H2.t,'a) t\n type t = H1.t * H2.t\n let create (k1,k2) d =\n let c = create () in\n set_data c d;\n set_key1 c k1; set_key2 c k2;\n c\n let hash seed (k1,k2) =\n H1.hash seed k1 + H2.hash seed k2 * 65599\n let equal c (k1,k2) =\n match get_key1 c, get_key2 c with\n | None, _ | _ , None -> GenHashTable.EDead\n | Some k1', Some k2' ->\n if H1.equal k1 k1' && H2.equal k2 k2'\n then GenHashTable.ETrue else GenHashTable.EFalse\n let get_data = get_data\n let get_key c =\n match get_key1 c, get_key2 c with\n | None, _ | _ , None -> None\n | Some k1', Some k2' -> Some (k1', k2')\n let set_key_data c (k1,k2) d =\n unset_data c;\n set_key1 c k1; set_key2 c k2;\n set_data c d\n let check_key c = check_key1 c && check_key2 c\n end)\n\n module Make(H1: Hashtbl.HashedType)(H2: Hashtbl.HashedType):\n (S with type key = H1.t * H2.t) =\n struct\n include MakeSeeded\n (struct\n type t = H1.t\n let equal = H1.equal\n let hash (_seed: int) x = H1.hash x\n end)\n (struct\n type t = H2.t\n let equal = H2.equal\n let hash (_seed: int) x = H2.hash x\n end)\n let create sz = create ~random:false sz\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n end\n\n module Bucket = struct\n\n type nonrec ('k1, 'k2, 'd) t = ('k1, 'k2, 'd) t list ref\n let k2_make = make\n let make () = ref []\n let add b k1 k2 d = b := k2_make k1 k2 d :: !b\n\n let test_keys k1 k2 e =\n match get_key1 e, get_key2 e with\n | Some x1, Some x2 when x1 == k1 && x2 == k2 -> true\n | _ -> false\n\n let remove b k1 k2 =\n let rec loop l acc =\n match l with\n | [] -> ()\n | h :: t when test_keys k1 k2 h -> b := List.rev_append acc t\n | h :: t -> loop t (h :: acc)\n in\n loop !b []\n\n let find b k1 k2 =\n match List.find_opt (test_keys k1 k2) !b with\n | Some e -> get_data e\n | None -> None\n\n let length b = List.length !b\n let clear b = b := []\n\n end\n\nend\n\nmodule Kn = struct\n type ('k,'d) t = ObjEph.t\n\n let create n : ('k,'d) t = ObjEph.create n\n let length (k:('k,'d) t) : int = ObjEph.length k\n\n let get_key (t:('k,'d) t) (n:int) : 'k option = obj_opt (ObjEph.get_key t n)\n let get_key_copy (t:('k,'d) t) (n:int) : 'k option =\n obj_opt (ObjEph.get_key_copy t n)\n let set_key (t:('k,'d) t) (n:int) (k:'k) : unit =\n ObjEph.set_key t n (Obj.repr k)\n let unset_key (t:('k,'d) t) (n:int) : unit = ObjEph.unset_key t n\n let check_key (t:('k,'d) t) (n:int) : bool = ObjEph.check_key t n\n\n let blit_key (t1:('k,'d) t) (o1:int) (t2:('k,'d) t) (o2:int) (l:int) : unit =\n ObjEph.blit_key t1 o1 t2 o2 l\n\n let get_data (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data t)\n let get_data_copy (t:('k,'d) t) : 'd option = obj_opt (ObjEph.get_data_copy t)\n let set_data (t:('k,'d) t) (d:'d) : unit = ObjEph.set_data t (Obj.repr d)\n let unset_data (t:('k,'d) t) : unit = ObjEph.unset_data t\n let check_data (t:('k,'d) t) : bool = ObjEph.check_data t\n let blit_data (t1:(_,'d) t) (t2:(_,'d) t) : unit = ObjEph.blit_data t1 t2\n\n let make keys data =\n let l = Array.length keys in\n let eph = create l in\n set_data eph data;\n for i = 0 to l - 1 do set_key eph i keys.(i) done;\n eph\n\n let query eph keys =\n let l = length eph in\n try\n if l <> Array.length keys then raise Exit;\n for i = 0 to l - 1 do\n match get_key eph i with\n | None -> raise Exit\n | Some k when k == keys.(i) -> ()\n | Some _ -> raise Exit\n done;\n get_data eph\n with Exit -> None\n\n module MakeSeeded (H:Hashtbl.SeededHashedType) =\n GenHashTable.MakeSeeded(struct\n type 'a container = (H.t,'a) t\n type t = H.t array\n let create k d =\n let c = create (Array.length k) in\n set_data c d;\n for i=0 to Array.length k -1 do\n set_key c i k.(i);\n done;\n c\n let hash seed k =\n let h = ref 0 in\n for i=0 to Array.length k -1 do\n h := H.hash seed k.(i) * 65599 + !h;\n done;\n !h\n let equal c k =\n let len = Array.length k in\n let len' = length c in\n if len != len' then GenHashTable.EFalse\n else\n let rec equal_array k c i =\n if i < 0 then GenHashTable.ETrue\n else\n match get_key c i with\n | None -> GenHashTable.EDead\n | Some ki ->\n if H.equal k.(i) ki\n then equal_array k c (i-1)\n else GenHashTable.EFalse\n in\n equal_array k c (len-1)\n let get_data = get_data\n let get_key c =\n let len = length c in\n if len = 0 then Some [||]\n else\n match get_key c 0 with\n | None -> None\n | Some k0 ->\n let rec fill a i =\n if i < 1 then Some a\n else\n match get_key c i with\n | None -> None\n | Some ki ->\n a.(i) <- ki;\n fill a (i-1)\n in\n let a = Array.make len k0 in\n fill a (len-1)\n let set_key_data c k d =\n unset_data c;\n for i=0 to Array.length k -1 do\n set_key c i k.(i);\n done;\n set_data c d\n let check_key c =\n let rec check c i =\n i < 0 || (check_key c i && check c (i-1)) in\n check c (length c - 1)\n end)\n\n module Make(H: Hashtbl.HashedType): (S with type key = H.t array) =\n struct\n include MakeSeeded(struct\n type t = H.t\n let equal = H.equal\n let hash (_seed: int) x = H.hash x\n end)\n let create sz = create ~random:false sz\n let of_seq i =\n let tbl = create 16 in\n replace_seq tbl i;\n tbl\n end\n\n module Bucket = struct\n\n type nonrec ('k, 'd) t = ('k, 'd) t list ref\n let kn_make = make\n let make () = ref []\n let add b k d = b := kn_make k d :: !b\n\n let test_keys k e =\n try\n if length e <> Array.length k then raise Exit;\n for i = 0 to Array.length k - 1 do\n match get_key e i with\n | Some x when x == k.(i) -> ()\n | _ -> raise Exit\n done;\n true\n with Exit -> false\n\n let remove b k =\n let rec loop l acc =\n match l with\n | [] -> ()\n | h :: t when test_keys k h -> b := List.rev_append acc t\n | h :: t -> loop t (h :: acc)\n in\n loop !b []\n\n let find b k =\n match List.find_opt (test_keys k) !b with\n | Some e -> get_data e\n | None -> None\n\n let length b = List.length !b\n let clear b = b := []\n\n end\n\nend\n","(* Conv_error: Module for Handling Errors during Automated S-expression\n Conversions *)\n\nopen StdLabels\nopen Printf\nopen Sexp_conv\n\nexception Of_sexp_error = Of_sexp_error\n\n(* Errors concerning tuples *)\n\nlet tuple_of_size_n_expected loc n sexp =\n of_sexp_error (sprintf \"%s_of_sexp: tuple of size %d expected\" loc n) sexp\n\n\n(* Errors concerning sum types *)\n\nlet stag_no_args loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: sum tag does not take arguments\") sexp\n\nlet stag_incorrect_n_args loc tag sexp =\n let msg =\n sprintf \"%s_of_sexp: sum tag %S has incorrect number of arguments\" loc tag\n in\n of_sexp_error msg sexp\n\nlet stag_takes_args loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: sum tag must be a structured value\") sexp\n\nlet nested_list_invalid_sum loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: a nested list is an invalid sum\") sexp\n\nlet empty_list_invalid_sum loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: the empty list is an invalid sum\") sexp\n\nlet unexpected_stag loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: unexpected sum tag\") sexp\n\n\n(* Errors concerning records *)\n\nlet record_sexp_bool_with_payload loc sexp =\n let msg =\n loc ^\n \"_of_sexp: record conversion: a [sexp.bool] field was given a payload.\" in\n of_sexp_error msg sexp\n\nlet record_only_pairs_expected loc sexp =\n let msg =\n loc ^\n \"_of_sexp: record conversion: only pairs expected, \\\n their first element must be an atom\" in\n of_sexp_error msg sexp\n\nlet record_superfluous_fields ~what ~loc rev_fld_names sexp =\n let fld_names_str = String.concat (List.rev rev_fld_names) ~sep:\" \" in\n let msg = sprintf \"%s_of_sexp: %s: %s\" loc what fld_names_str in\n of_sexp_error msg sexp\n\nlet record_duplicate_fields loc rev_fld_names sexp =\n record_superfluous_fields ~what:\"duplicate fields\" ~loc rev_fld_names sexp\n\nlet record_extra_fields loc rev_fld_names sexp =\n record_superfluous_fields ~what:\"extra fields\" ~loc rev_fld_names sexp\n\nlet rec record_get_undefined_loop fields = function\n | [] -> String.concat (List.rev fields) ~sep:\" \"\n | (true, field) :: rest -> record_get_undefined_loop (field :: fields) rest\n | _ :: rest -> record_get_undefined_loop fields rest\n\nlet record_undefined_elements loc sexp lst =\n let undefined = record_get_undefined_loop [] lst in\n let msg =\n sprintf \"%s_of_sexp: the following record elements were undefined: %s\"\n loc undefined\n in\n of_sexp_error msg sexp\n\nlet record_list_instead_atom loc sexp =\n let msg = loc ^ \"_of_sexp: list instead of atom for record expected\" in\n of_sexp_error msg sexp\n\nlet record_poly_field_value loc sexp =\n let msg =\n loc ^\n \"_of_sexp: cannot convert values of types resulting from polymorphic \\\n record fields\"\n in\n of_sexp_error msg sexp\n\n\n(* Errors concerning polymorphic variants *)\n\nexception No_variant_match\n\nlet no_variant_match () =\n raise No_variant_match\n\nlet no_matching_variant_found loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: no matching variant found\") sexp\n\nlet ptag_no_args loc sexp =\n of_sexp_error (\n loc ^ \"_of_sexp: polymorphic variant does not take arguments\") sexp\n\nlet ptag_incorrect_n_args loc cnstr sexp =\n let msg =\n sprintf\n \"%s_of_sexp: polymorphic variant tag %S has incorrect number of arguments\"\n loc cnstr\n in\n of_sexp_error msg sexp\n\nlet ptag_takes_args loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: polymorphic variant tag takes an argument\")\n sexp\n\nlet nested_list_invalid_poly_var loc sexp =\n of_sexp_error (\n loc ^ \"_of_sexp: a nested list is an invalid polymorphic variant\") sexp\n\nlet empty_list_invalid_poly_var loc sexp =\n of_sexp_error (\n loc ^ \"_of_sexp: the empty list is an invalid polymorphic variant\") sexp\n\nlet empty_type loc sexp =\n of_sexp_error (loc ^ \"_of_sexp: trying to convert an empty type\") sexp\n","open! Import\nopen Std_internal\n\nlet randomize span ~percent ~scale =\n let mult = Percent.to_mult percent in\n if Float.( < ) mult 0. || Float.( > ) mult 1.\n then\n raise_s\n [%message \"Span.randomize: percent is out of range [0x, 1x]\" (percent : Percent.t)];\n let factor = Random.float_range (1. -. mult) (Float.one_ulp `Up (1. +. mult)) in\n scale span factor\n;;\n\nlet format_decimal n tenths units =\n assert (tenths >= 0 && tenths < 10);\n if n < 10 && tenths <> 0\n then sprintf \"%d.%d%s\" n tenths units\n else sprintf \"%d%s\" n units\n;;\n\nlet short_string ~sign ~hr ~min ~sec ~ms ~us ~ns =\n let s =\n if hr >= 24\n then format_decimal (hr / 24) (Int.of_float (Float.of_int (hr % 24) /. 2.4)) \"d\"\n else if hr > 0\n then format_decimal hr (min / 6) \"h\"\n else if min > 0\n then format_decimal min (sec / 6) \"m\"\n else if sec > 0\n then format_decimal sec (ms / 100) \"s\"\n else if ms > 0\n then format_decimal ms (us / 100) \"ms\"\n else if us > 0\n then format_decimal us (ns / 100) \"us\"\n else sprintf \"%ins\" ns\n in\n match (sign : Sign.t) with\n | Neg -> \"-\" ^ s\n | Zero | Pos -> s\n;;\n","(* This module is included in [Import]. It is aimed at modules that define the standard\n combinators for [sexp_of], [of_sexp], [compare] and [hash] and are included in\n [Import]. *)\n\ninclude (\n Shadow_stdlib :\n module type of struct\n include Shadow_stdlib\n end\n with type 'a ref := 'a ref\n with type ('a, 'b, 'c) format := ('a, 'b, 'c) format\n with type ('a, 'b, 'c, 'd) format4 := ('a, 'b, 'c, 'd) format4\n with type ('a, 'b, 'c, 'd, 'e, 'f) format6 := ('a, 'b, 'c, 'd, 'e, 'f) format6\n (* These modules are redefined in Base *)\n with module Array := Shadow_stdlib.Array\n with module Atomic := Shadow_stdlib.Atomic\n with module Bool := Shadow_stdlib.Bool\n with module Buffer := Shadow_stdlib.Buffer\n with module Bytes := Shadow_stdlib.Bytes\n with module Char := Shadow_stdlib.Char\n with module Either := Shadow_stdlib.Either\n with module Float := Shadow_stdlib.Float\n with module Hashtbl := Shadow_stdlib.Hashtbl\n with module Int := Shadow_stdlib.Int\n with module Int32 := Shadow_stdlib.Int32\n with module Int64 := Shadow_stdlib.Int64\n with module Lazy := Shadow_stdlib.Lazy\n with module List := Shadow_stdlib.List\n with module Map := Shadow_stdlib.Map\n with module Nativeint := Shadow_stdlib.Nativeint\n with module Option := Shadow_stdlib.Option\n with module Printf := Shadow_stdlib.Printf\n with module Queue := Shadow_stdlib.Queue\n with module Random := Shadow_stdlib.Random\n with module Result := Shadow_stdlib.Result\n with module Set := Shadow_stdlib.Set\n with module Stack := Shadow_stdlib.Stack\n with module String := Shadow_stdlib.String\n with module Sys := Shadow_stdlib.Sys\n with module Uchar := Shadow_stdlib.Uchar\n with module Unit := Shadow_stdlib.Unit) [@ocaml.warning \"-3\"]\n\ntype 'a ref = 'a Caml.ref = { mutable contents : 'a }\n\n(* Reshuffle [Caml] so that we choose the modules using labels when available. *)\nmodule Caml = struct\n\n module Arg = Caml.Arg (** @canonical Caml.Arg *)\n\n module Array = Caml.StdLabels.Array (** @canonical Caml.StdLabels.Array *)\n\n module Bool = Caml.Bool (** @canonical Caml.Bool *)\n\n module Buffer = Caml.Buffer (** @canonical Caml.Buffer *)\n\n module Bytes = Caml.StdLabels.Bytes (** @canonical Caml.StdLabels.Bytes *)\n\n module Char = Caml.Char (** @canonical Caml.Char *)\n\n module Ephemeron = Caml.Ephemeron (** @canonical Caml.Ephemeron *)\n\n module Float = Caml.Float (** @canonical Caml.Float *)\n\n module Format = Caml.Format (** @canonical Caml.Format *)\n\n module Fun = Caml.Fun (** @canonical Caml.Fun *)\n\n module Gc = Caml.Gc (** @canonical Caml.Gc *)\n\n module Hashtbl = Caml.MoreLabels.Hashtbl (** @canonical Caml.MoreLabels.Hashtbl *)\n\n module Int32 = Caml.Int32 (** @canonical Caml.Int32 *)\n\n module Int = Caml.Int (** @canonical Caml.Int *)\n\n module Int64 = Caml.Int64 (** @canonical Caml.Int64 *)\n\n module Lazy = Caml.Lazy (** @canonical Caml.Lazy *)\n\n module Lexing = Caml.Lexing (** @canonical Caml.Lexing *)\n\n module List = Caml.StdLabels.List (** @canonical Caml.StdLabels.List *)\n\n module Map = Caml.MoreLabels.Map (** @canonical Caml.MoreLabels.Map *)\n\n module Nativeint = Caml.Nativeint (** @canonical Caml.Nativeint *)\n\n module Obj = Caml.Obj (** @canonical Caml.Obj *)\n\n module Option = Caml.Option (** @canonical Caml.Option *)\n\n module Parsing = Caml.Parsing (** @canonical Caml.Parsing *)\n\n module Printexc = Caml.Printexc (** @canonical Caml.Printexc *)\n\n module Printf = Caml.Printf (** @canonical Caml.Printf *)\n\n module Queue = Caml.Queue (** @canonical Caml.Queue *)\n\n module Random = Caml.Random (** @canonical Caml.Random *)\n\n module Result = Caml.Result (** @canonical Caml.Result *)\n\n module Scanf = Caml.Scanf (** @canonical Caml.Scanf *)\n\n module Seq = Caml.Seq (** @canonical Caml.Seq *)\n\n module Set = Caml.MoreLabels.Set (** @canonical Caml.MoreLabels.Set *)\n\n module Stack = Caml.Stack (** @canonical Caml.Stack *)\n\n module Stream = Caml.Stream [@ocaml.warning \"-3\"] (** @canonical Caml.Stream *)\n\n module String = Caml.StdLabels.String (** @canonical Caml.StdLabels.String *)\n\n module Sys = Caml.Sys (** @canonical Caml.Sys *)\n\n module Uchar = Caml.Uchar (** @canonical Caml.Uchar *)\n\n module Unit = Caml.Unit (** @canonical Caml.Unit *)\n\n include Pervasives [@ocaml.warning \"-3\"]\n\n exception Not_found = Caml.Not_found\nend\n\nexternal ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\n\n(* These need to be declared as an external to get the lazy behavior *)\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\nexternal ( || ) : bool -> bool -> bool = \"%sequor\"\nexternal not : bool -> bool = \"%boolnot\"\n\n(* We use [Obj.magic] here as other implementations generate a conditional jump and the\n performance difference is noticeable. *)\nlet bool_to_int (x : bool) : int = Caml.Obj.magic x\n\n(* This need to be declared as an external for the warnings to work properly *)\nexternal ignore : _ -> unit = \"%ignore\"\n\nlet ( != ) = Caml.( != )\nlet ( * ) = Caml.( * )\nlet ( ** ) = Caml.( ** )\nlet ( *. ) = Caml.( *. )\nlet ( + ) = Caml.( + )\nlet ( +. ) = Caml.( +. )\nlet ( - ) = Caml.( - )\nlet ( -. ) = Caml.( -. )\nlet ( / ) = Caml.( / )\nlet ( /. ) = Caml.( /. )\n\nmodule Poly = Poly0 (** @canonical Base.Poly *)\n\nmodule Int_replace_polymorphic_compare = struct\n let ( < ) (x : int) y = Poly.( < ) x y\n let ( <= ) (x : int) y = Poly.( <= ) x y\n let ( <> ) (x : int) y = Poly.( <> ) x y\n let ( = ) (x : int) y = Poly.( = ) x y\n let ( > ) (x : int) y = Poly.( > ) x y\n let ( >= ) (x : int) y = Poly.( >= ) x y\n let compare (x : int) y = bool_to_int (x > y) - bool_to_int (x < y)\n let ascending (x : int) y = compare x y\n let descending (x : int) y = compare y x\n let equal (x : int) y = Poly.equal x y\n let max (x : int) y = if x >= y then x else y\n let min (x : int) y = if x <= y then x else y\nend\n\ninclude Int_replace_polymorphic_compare\n\nmodule Int32_replace_polymorphic_compare = struct\n let ( < ) (x : Caml.Int32.t) y = Poly.( < ) x y\n let ( <= ) (x : Caml.Int32.t) y = Poly.( <= ) x y\n let ( <> ) (x : Caml.Int32.t) y = Poly.( <> ) x y\n let ( = ) (x : Caml.Int32.t) y = Poly.( = ) x y\n let ( > ) (x : Caml.Int32.t) y = Poly.( > ) x y\n let ( >= ) (x : Caml.Int32.t) y = Poly.( >= ) x y\n let ascending (x : Caml.Int32.t) y = Poly.ascending x y\n let descending (x : Caml.Int32.t) y = Poly.descending x y\n let compare (x : Caml.Int32.t) y = Poly.compare x y\n let equal (x : Caml.Int32.t) y = Poly.equal x y\n let max (x : Caml.Int32.t) y = if x >= y then x else y\n let min (x : Caml.Int32.t) y = if x <= y then x else y\nend\n\nmodule Int64_replace_polymorphic_compare = struct\n let ( < ) (x : Caml.Int64.t) y = Poly.( < ) x y\n let ( <= ) (x : Caml.Int64.t) y = Poly.( <= ) x y\n let ( <> ) (x : Caml.Int64.t) y = Poly.( <> ) x y\n let ( = ) (x : Caml.Int64.t) y = Poly.( = ) x y\n let ( > ) (x : Caml.Int64.t) y = Poly.( > ) x y\n let ( >= ) (x : Caml.Int64.t) y = Poly.( >= ) x y\n let ascending (x : Caml.Int64.t) y = Poly.ascending x y\n let descending (x : Caml.Int64.t) y = Poly.descending x y\n let compare (x : Caml.Int64.t) y = Poly.compare x y\n let equal (x : Caml.Int64.t) y = Poly.equal x y\n let max (x : Caml.Int64.t) y = if x >= y then x else y\n let min (x : Caml.Int64.t) y = if x <= y then x else y\nend\n\nmodule Nativeint_replace_polymorphic_compare = struct\n let ( < ) (x : Caml.Nativeint.t) y = Poly.( < ) x y\n let ( <= ) (x : Caml.Nativeint.t) y = Poly.( <= ) x y\n let ( <> ) (x : Caml.Nativeint.t) y = Poly.( <> ) x y\n let ( = ) (x : Caml.Nativeint.t) y = Poly.( = ) x y\n let ( > ) (x : Caml.Nativeint.t) y = Poly.( > ) x y\n let ( >= ) (x : Caml.Nativeint.t) y = Poly.( >= ) x y\n let ascending (x : Caml.Nativeint.t) y = Poly.ascending x y\n let descending (x : Caml.Nativeint.t) y = Poly.descending x y\n let compare (x : Caml.Nativeint.t) y = Poly.compare x y\n let equal (x : Caml.Nativeint.t) y = Poly.equal x y\n let max (x : Caml.Nativeint.t) y = if x >= y then x else y\n let min (x : Caml.Nativeint.t) y = if x <= y then x else y\nend\n\nmodule Bool_replace_polymorphic_compare = struct\n let ( < ) (x : bool) y = Poly.( < ) x y\n let ( <= ) (x : bool) y = Poly.( <= ) x y\n let ( <> ) (x : bool) y = Poly.( <> ) x y\n let ( = ) (x : bool) y = Poly.( = ) x y\n let ( > ) (x : bool) y = Poly.( > ) x y\n let ( >= ) (x : bool) y = Poly.( >= ) x y\n let ascending (x : bool) y = Poly.ascending x y\n let descending (x : bool) y = Poly.descending x y\n let compare (x : bool) y = Poly.compare x y\n let equal (x : bool) y = Poly.equal x y\n let max (x : bool) y = if x >= y then x else y\n let min (x : bool) y = if x <= y then x else y\nend\n\nmodule Char_replace_polymorphic_compare = struct\n let ( < ) (x : char) y = Poly.( < ) x y\n let ( <= ) (x : char) y = Poly.( <= ) x y\n let ( <> ) (x : char) y = Poly.( <> ) x y\n let ( = ) (x : char) y = Poly.( = ) x y\n let ( > ) (x : char) y = Poly.( > ) x y\n let ( >= ) (x : char) y = Poly.( >= ) x y\n let ascending (x : char) y = Poly.ascending x y\n let descending (x : char) y = Poly.descending x y\n let compare (x : char) y = Poly.compare x y\n let equal (x : char) y = Poly.equal x y\n let max (x : char) y = if x >= y then x else y\n let min (x : char) y = if x <= y then x else y\nend\n\nmodule Uchar_replace_polymorphic_compare = struct\n let i x = Caml.Uchar.to_int x\n let ( < ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( < ) (i x) (i y)\n let ( <= ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( <= ) (i x) (i y)\n let ( <> ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( <> ) (i x) (i y)\n let ( = ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( = ) (i x) (i y)\n let ( > ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( > ) (i x) (i y)\n let ( >= ) (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.( >= ) (i x) (i y)\n\n let ascending (x : Caml.Uchar.t) y =\n Int_replace_polymorphic_compare.ascending (i x) (i y)\n ;;\n\n let descending (x : Caml.Uchar.t) y =\n Int_replace_polymorphic_compare.descending (i x) (i y)\n ;;\n\n let compare (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.compare (i x) (i y)\n let equal (x : Caml.Uchar.t) y = Int_replace_polymorphic_compare.equal (i x) (i y)\n let max (x : Caml.Uchar.t) y = if x >= y then x else y\n let min (x : Caml.Uchar.t) y = if x <= y then x else y\nend\n\nmodule Float_replace_polymorphic_compare = struct\n let ( < ) (x : float) y = Poly.( < ) x y\n let ( <= ) (x : float) y = Poly.( <= ) x y\n let ( <> ) (x : float) y = Poly.( <> ) x y\n let ( = ) (x : float) y = Poly.( = ) x y\n let ( > ) (x : float) y = Poly.( > ) x y\n let ( >= ) (x : float) y = Poly.( >= ) x y\n let ascending (x : float) y = Poly.ascending x y\n let descending (x : float) y = Poly.descending x y\n let compare (x : float) y = Poly.compare x y\n let equal (x : float) y = Poly.equal x y\n let max (x : float) y = if x >= y then x else y\n let min (x : float) y = if x <= y then x else y\nend\n\nmodule String_replace_polymorphic_compare = struct\n let ( < ) (x : string) y = Poly.( < ) x y\n let ( <= ) (x : string) y = Poly.( <= ) x y\n let ( <> ) (x : string) y = Poly.( <> ) x y\n let ( = ) (x : string) y = Poly.( = ) x y\n let ( > ) (x : string) y = Poly.( > ) x y\n let ( >= ) (x : string) y = Poly.( >= ) x y\n let ascending (x : string) y = Poly.ascending x y\n let descending (x : string) y = Poly.descending x y\n let compare (x : string) y = Poly.compare x y\n let equal (x : string) y = Poly.equal x y\n let max (x : string) y = if x >= y then x else y\n let min (x : string) y = if x <= y then x else y\nend\n\nmodule Bytes_replace_polymorphic_compare = struct\n let ( < ) (x : bytes) y = Poly.( < ) x y\n let ( <= ) (x : bytes) y = Poly.( <= ) x y\n let ( <> ) (x : bytes) y = Poly.( <> ) x y\n let ( = ) (x : bytes) y = Poly.( = ) x y\n let ( > ) (x : bytes) y = Poly.( > ) x y\n let ( >= ) (x : bytes) y = Poly.( >= ) x y\n let ascending (x : bytes) y = Poly.ascending x y\n let descending (x : bytes) y = Poly.descending x y\n let compare (x : bytes) y = Poly.compare x y\n let equal (x : bytes) y = Poly.equal x y\n let max (x : bytes) y = if x >= y then x else y\n let min (x : bytes) y = if x <= y then x else y\nend\n\n(* This needs to be defined as an external so that the compiler can specialize it as a\n direct set or caml_modify *)\nexternal ( := ) : 'a ref -> 'a -> unit = \"%setfield0\"\n\n(* These need to be defined as an external otherwise the compiler won't unbox\n references *)\nexternal ( ! ) : 'a ref -> 'a = \"%field0\"\nexternal ref : 'a -> 'a ref = \"%makemutable\"\n\nlet ( @ ) = Caml.( @ )\nlet ( ^ ) = Caml.( ^ )\nlet ( ~- ) = Caml.( ~- )\nlet ( ~-. ) = Caml.( ~-. )\nlet ( asr ) = Caml.( asr )\nlet ( land ) = Caml.( land )\nlet lnot = Caml.lnot\nlet ( lor ) = Caml.( lor )\nlet ( lsl ) = Caml.( lsl )\nlet ( lsr ) = Caml.( lsr )\nlet ( lxor ) = Caml.( lxor )\nlet ( mod ) = Caml.( mod )\nlet abs = Caml.abs\nlet failwith = Caml.failwith\nlet fst = Caml.fst\nlet invalid_arg = Caml.invalid_arg\nlet snd = Caml.snd\n\n(* [raise] needs to be defined as an external as the compiler automatically replaces\n '%raise' by '%reraise' when appropriate. *)\nexternal raise : exn -> _ = \"%raise\"\n\nlet phys_equal = Caml.( == )\nlet decr = Caml.decr\nlet incr = Caml.incr\n\n(* used by sexp_conv, which float0 depends on through option *)\nlet float_of_string = Caml.float_of_string\n\n(* [am_testing] is used in a few places to behave differently when in testing mode, such\n as in [random.ml]. [am_testing] is implemented using [Base_am_testing], a weak C/js\n primitive that returns [false], but when linking an inline-test-runner executable, is\n overridden by another primitive that returns [true]. *)\nexternal am_testing : unit -> bool = \"Base_am_testing\"\n\nlet am_testing = am_testing ()\n","open! Import0\ninclude Caml.Printf\n\n(** failwith, invalid_arg, and exit accepting printf's format. *)\n\nlet failwithf fmt = ksprintf (fun s () -> failwith s) fmt\nlet invalid_argf fmt = ksprintf (fun s () -> invalid_arg s) fmt\n","(* [Array0] defines array functions that are primitives or can be simply defined in terms\n of [Caml.Array]. [Array0] is intended to completely express the part of [Caml.Array]\n that [Base] uses -- no other file in Base other than array0.ml should use [Caml.Array].\n [Array0] has few dependencies, and so is available early in Base's build order. All\n Base files that need to use arrays and come before [Base.Array] in build order should\n do [module Array = Array0]. This includes uses of subscript syntax ([x.(i)], [x.(i) <-\n e]), which the OCaml parser desugars into calls to [Array.get] and [Array.set].\n Defining [module Array = Array0] is also necessary because it prevents ocamldep from\n mistakenly causing a file to depend on [Base.Array]. *)\n\nopen! Import0\nmodule Sys = Sys0\n\nlet invalid_argf = Printf.invalid_argf\n\nmodule Array = struct\n external create : int -> 'a -> 'a array = \"caml_make_vect\"\n external get : 'a array -> int -> 'a = \"%array_safe_get\"\n external length : 'a array -> int = \"%array_length\"\n external set : 'a array -> int -> 'a -> unit = \"%array_safe_set\"\n external unsafe_get : 'a array -> int -> 'a = \"%array_unsafe_get\"\n external unsafe_set : 'a array -> int -> 'a -> unit = \"%array_unsafe_set\"\nend\n\ninclude Array\n\nlet max_length = Sys.max_array_length\n\nlet create ~len x =\n try create len x with\n | Invalid_argument _ -> invalid_argf \"Array.create ~len:%d: invalid length\" len ()\n;;\n\nlet append = Caml.Array.append\nlet blit = Caml.Array.blit\nlet concat = Caml.Array.concat\nlet copy = Caml.Array.copy\nlet fill = Caml.Array.fill\nlet init = Caml.Array.init\nlet make_matrix = Caml.Array.make_matrix\nlet of_list = Caml.Array.of_list\nlet sub = Caml.Array.sub\nlet to_list = Caml.Array.to_list\n\n(* These are eta expanded in order to permute parameter order to follow Base\n conventions. *)\nlet fold t ~init ~f = Caml.Array.fold_left t ~init ~f\nlet fold_right t ~f ~init = Caml.Array.fold_right t ~f ~init\nlet iter t ~f = Caml.Array.iter t ~f\nlet iteri t ~f = Caml.Array.iteri t ~f\nlet map t ~f = Caml.Array.map t ~f\nlet mapi t ~f = Caml.Array.mapi t ~f\nlet stable_sort t ~compare = Caml.Array.stable_sort t ~cmp:compare\n\nlet swap t i j =\n let tmp = t.(i) in\n t.(i) <- t.(j);\n t.(j) <- tmp\n;;\n","(* [Char0] defines char functions that are primitives or can be simply defined in terms of\n [Caml.Char]. [Char0] is intended to completely express the part of [Caml.Char] that\n [Base] uses -- no other file in Base other than char0.ml should use [Caml.Char].\n [Char0] has few dependencies, and so is available early in Base's build order. All\n Base files that need to use chars and come before [Base.Char] in build order should do\n [module Char = Char0]. Defining [module Char = Char0] is also necessary because it\n prevents ocamldep from mistakenly causing a file to depend on [Base.Char]. *)\n\nopen! Import0\n\nlet failwithf = Printf.failwithf\nlet escaped = Caml.Char.escaped\nlet lowercase = Caml.Char.lowercase_ascii\nlet to_int = Caml.Char.code\nlet unsafe_of_int = Caml.Char.unsafe_chr\nlet uppercase = Caml.Char.uppercase_ascii\n\n(* We use our own range test when converting integers to chars rather than\n calling [Caml.Char.chr] because it's simple and it saves us a function call\n and the try-with (exceptions cost, especially in the world with backtraces). *)\nlet int_is_ok i = 0 <= i && i <= 255\nlet min_value = unsafe_of_int 0\nlet max_value = unsafe_of_int 255\nlet of_int i = if int_is_ok i then Some (unsafe_of_int i) else None\n\nlet of_int_exn i =\n if int_is_ok i\n then unsafe_of_int i\n else failwithf \"Char.of_int_exn got integer out of range: %d\" i ()\n;;\n\nlet equal (t1 : char) t2 = Poly.equal t1 t2\n","(* [List0] defines list functions that are primitives or can be simply defined in terms of\n [Caml.List]. [List0] is intended to completely express the part of [Caml.List] that\n [Base] uses -- no other file in Base other than list0.ml should use [Caml.List].\n [List0] has few dependencies, and so is available early in Base's build order. All\n Base files that need to use lists and come before [Base.List] in build order should do\n [module List = List0]. Defining [module List = List0] is also necessary because it\n prevents ocamldep from mistakenly causing a file to depend on [Base.List]. *)\n\nopen! Import0\n\nlet hd_exn = Caml.List.hd\nlet length = Caml.List.length\nlet rev_append = Caml.List.rev_append\nlet tl_exn = Caml.List.tl\nlet unzip = Caml.List.split\n\n(* These are eta expanded in order to permute parameter order to follow Base\n conventions. *)\nlet exists t ~f = Caml.List.exists t ~f\nlet exists2_ok l1 l2 ~f = Caml.List.exists2 l1 l2 ~f\nlet fold t ~init ~f = Caml.List.fold_left t ~f ~init\nlet fold2_ok l1 l2 ~init ~f = Caml.List.fold_left2 l1 l2 ~init ~f\nlet for_all t ~f = Caml.List.for_all t ~f\nlet for_all2_ok l1 l2 ~f = Caml.List.for_all2 l1 l2 ~f\nlet iter t ~f = Caml.List.iter t ~f\nlet iter2_ok l1 l2 ~f = Caml.List.iter2 l1 l2 ~f\nlet nontail_map t ~f = Caml.List.map t ~f\nlet nontail_mapi t ~f = Caml.List.mapi t ~f\nlet partition t ~f = Caml.List.partition t ~f\nlet rev_map t ~f = Caml.List.rev_map t ~f\nlet rev_map2_ok l1 l2 ~f = Caml.List.rev_map2 l1 l2 ~f\nlet sort l ~compare = Caml.List.sort l ~cmp:compare\nlet stable_sort l ~compare = Caml.List.stable_sort l ~cmp:compare\n\nlet rev = function\n | ([] | [ _ ]) as res -> res\n | x :: y :: rest -> rev_append rest [ y; x ]\n;;\n","open Core_kernel\n\nmodule type S = sig\n type 'a t = private 'a list\n\n include Container.S1 with type 'a t := 'a t\n\n val of_list : 'a list -> 'a t\n\n val init : int -> f:(int -> 'a) -> 'a t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val pad : padding_length:int -> zero:'a -> 'a t -> 'a t\nend\n\nmodule T = struct\n include List\n\n let of_list = Fn.id\nend\n\nmodule Msb_first = struct\n include T\n\n let of_lsb_first = List.rev\n\n let pad ~padding_length ~zero xs =\n List.init padding_length ~f:(fun _ -> zero) @ xs\nend\n\nmodule Lsb_first = struct\n include T\n\n let of_msb_first = List.rev\n\n let pad ~padding_length ~zero xs =\n xs @ List.init padding_length ~f:(fun _ -> zero)\nend\n\nlet pad_to_triple_list ~default xs =\n let rec go acc = function\n | [] ->\n List.rev acc\n | [ x1 ] ->\n List.rev ((x1, default, default) :: acc)\n | [ x1; x2 ] ->\n List.rev ((x1, x2, default) :: acc)\n | x1 :: x2 :: x3 :: xs ->\n go ((x1, x2, x3) :: acc) xs\n in\n go [] xs\n","(*\n This is the interface to the runtime support for [ppx_hash].\n\n The [ppx_hash] syntax extension supports: [@@deriving hash] and [%hash_fold: TYPE] and\n [%hash: TYPE]\n\n For type [t] a function [hash_fold_t] of type [Hash.state -> t -> Hash.state] is\n generated.\n\n The generated [hash_fold_] function is compositional, following the structure of the\n type; allowing user overrides at every level. This is in contrast to ocaml's builtin\n polymorphic hashing [Hashtbl.hash] which ignores user overrides.\n\n The generator also provides a direct hash-function [hash] (named [hash_] when !=\n \"t\") of type: [t -> Hash.hash_value].\n\n The folding hash function can be accessed as [%hash_fold: TYPE]\n The direct hash function can be accessed as [%hash: TYPE]\n*)\n\nopen! Import0\nmodule Array = Array0\nmodule Char = Char0\nmodule Int = Int0\nmodule List = List0\ninclude Hash_intf\n\n(** Builtin folding-style hash functions, abstracted over [Hash_intf.S] *)\nmodule Folding (Hash : Hash_intf.S) :\n Hash_intf.Builtin_intf\n with type state = Hash.state\n and type hash_value = Hash.hash_value = struct\n type state = Hash.state\n type hash_value = Hash.hash_value\n type 'a folder = state -> 'a -> state\n\n let hash_fold_unit s () = s\n let hash_fold_int = Hash.fold_int\n let hash_fold_int64 = Hash.fold_int64\n let hash_fold_float = Hash.fold_float\n let hash_fold_string = Hash.fold_string\n let as_int f s x = hash_fold_int s (f x)\n\n (* This ignores the sign bit on 32-bit architectures, but it's unlikely to lead to\n frequent collisions (min_value colliding with 0 is the most likely one). *)\n let hash_fold_int32 = as_int Caml.Int32.to_int\n let hash_fold_char = as_int Char.to_int\n\n let hash_fold_bool =\n as_int (function\n | true -> 1\n | false -> 0)\n ;;\n\n let hash_fold_nativeint s x = hash_fold_int64 s (Caml.Int64.of_nativeint x)\n\n let hash_fold_option hash_fold_elem s = function\n | None -> hash_fold_int s 0\n | Some x -> hash_fold_elem (hash_fold_int s 1) x\n ;;\n\n let rec hash_fold_list_body hash_fold_elem s list =\n match list with\n | [] -> s\n | x :: xs -> hash_fold_list_body hash_fold_elem (hash_fold_elem s x) xs\n ;;\n\n let hash_fold_list hash_fold_elem s list =\n (* The [length] of the list must be incorporated into the hash-state so values of\n types such as [unit list] - ([], [()], [();()],..) are hashed differently. *)\n (* The [length] must come before the elements to avoid a violation of the rule\n enforced by Perfect_hash. *)\n let s = hash_fold_int s (List.length list) in\n let s = hash_fold_list_body hash_fold_elem s list in\n s\n ;;\n\n let hash_fold_lazy_t hash_fold_elem s x = hash_fold_elem s (Caml.Lazy.force x)\n let hash_fold_ref_frozen hash_fold_elem s x = hash_fold_elem s !x\n\n let rec hash_fold_array_frozen_i hash_fold_elem s array i =\n if i = Array.length array\n then s\n else (\n let e = Array.unsafe_get array i in\n hash_fold_array_frozen_i hash_fold_elem (hash_fold_elem s e) array (i + 1))\n ;;\n\n let hash_fold_array_frozen hash_fold_elem s array =\n hash_fold_array_frozen_i\n (* [length] must be incorporated for arrays, as it is for lists. See comment above *)\n hash_fold_elem\n (hash_fold_int s (Array.length array))\n array\n 0\n ;;\n\n (* the duplication here is because we think\n ocaml can't eliminate indirect function calls otherwise. *)\n let hash_nativeint x =\n Hash.get_hash_value (hash_fold_nativeint (Hash.reset (Hash.alloc ())) x)\n ;;\n\n let hash_int64 x = Hash.get_hash_value (hash_fold_int64 (Hash.reset (Hash.alloc ())) x)\n let hash_int32 x = Hash.get_hash_value (hash_fold_int32 (Hash.reset (Hash.alloc ())) x)\n let hash_char x = Hash.get_hash_value (hash_fold_char (Hash.reset (Hash.alloc ())) x)\n let hash_int x = Hash.get_hash_value (hash_fold_int (Hash.reset (Hash.alloc ())) x)\n let hash_bool x = Hash.get_hash_value (hash_fold_bool (Hash.reset (Hash.alloc ())) x)\n\n let hash_string x =\n Hash.get_hash_value (hash_fold_string (Hash.reset (Hash.alloc ())) x)\n ;;\n\n let hash_float x = Hash.get_hash_value (hash_fold_float (Hash.reset (Hash.alloc ())) x)\n let hash_unit x = Hash.get_hash_value (hash_fold_unit (Hash.reset (Hash.alloc ())) x)\nend\n\nmodule F (Hash : Hash_intf.S) :\n Hash_intf.Full\n with type hash_value = Hash.hash_value\n and type state = Hash.state\n and type seed = Hash.seed = struct\n include Hash\n\n type 'a folder = state -> 'a -> state\n\n let create ?seed () = reset ?seed (alloc ())\n let of_fold hash_fold_t t = get_hash_value (hash_fold_t (create ()) t)\n\n module Builtin = Folding (Hash)\n\n let run ?seed folder x =\n Hash.get_hash_value (folder (Hash.reset ?seed (Hash.alloc ())) x)\n ;;\nend\n\nmodule Internalhash : sig\n include\n Hash_intf.S\n with type state = Base_internalhash_types.state\n (* We give a concrete type for [state], albeit only partially exposed (see\n Base_internalhash_types), so that it unifies with the same type in [Base_boot],\n and to allow optimizations for the immediate type. *)\n and type seed = Base_internalhash_types.seed\n and type hash_value = Base_internalhash_types.hash_value\n\n external fold_int64 : state -> int64 -> state = \"Base_internalhash_fold_int64\"\n [@@noalloc]\n\n external fold_int : state -> int -> state = \"Base_internalhash_fold_int\" [@@noalloc]\n\n external fold_float : state -> float -> state = \"Base_internalhash_fold_float\"\n [@@noalloc]\n\n external fold_string : state -> string -> state = \"Base_internalhash_fold_string\"\n [@@noalloc]\n\n external get_hash_value : state -> hash_value = \"Base_internalhash_get_hash_value\"\n [@@noalloc]\nend = struct\n let description = \"internalhash\"\n\n include Base_internalhash_types\n\n let alloc () = create_seeded 0\n let reset ?(seed = 0) _t = create_seeded seed\n\n module For_tests = struct\n let compare_state (a : state) (b : state) = compare (a :> int) (b :> int)\n let state_to_string (state : state) = Int.to_string (state :> int)\n end\nend\n\nmodule T = struct\n include Internalhash\n\n type 'a folder = state -> 'a -> state\n\n let create ?seed () = reset ?seed (alloc ())\n let run ?seed folder x = get_hash_value (folder (reset ?seed (alloc ())) x)\n let of_fold hash_fold_t t = get_hash_value (hash_fold_t (create ()) t)\n\n module Builtin = struct\n module Folding = Folding (Internalhash)\n\n include (\n Folding :\n Hash_intf.Builtin_hash_fold_intf\n with type state := state\n and type 'a folder := 'a folder)\n\n let hash_nativeint = Folding.hash_nativeint\n let hash_int64 = Folding.hash_int64\n let hash_int32 = Folding.hash_int32\n let hash_string = Folding.hash_string\n\n (* [Folding] provides some default implementations for the [hash_*] functions below,\n but they are inefficient for some use-cases because of the use of the [hash_fold]\n functions. At this point, the [hash_value] type has been fixed to [int], so this\n module can provide specialized implementations. *)\n\n let hash_char = Char0.to_int\n\n (* This hash was chosen from here: https://gist.github.com/badboy/6267743\n\n It attempts to fulfill the primary goals of a non-cryptographic hash function:\n\n - a bit change in the input should change ~1/2 of the output bits\n - the output should be uniformly distributed across the output range\n - inputs that are close to each other shouldn't lead to outputs that are close to\n each other.\n - all bits of the input are used in generating the output\n\n In our case we also want it to be fast, non-allocating, and inlinable. *)\n let[@inline always] hash_int (t : int) =\n let t = lnot t + (t lsl 21) in\n let t = t lxor (t lsr 24) in\n let t = t + (t lsl 3) + (t lsl 8) in\n let t = t lxor (t lsr 14) in\n let t = t + (t lsl 2) + (t lsl 4) in\n let t = t lxor (t lsr 28) in\n t + (t lsl 31)\n ;;\n\n let hash_bool x = if x then 1 else 0\n\n external hash_float : float -> int = \"Base_hash_double\" [@@noalloc]\n\n let hash_unit () = 0\n end\nend\n\ninclude T\n","open Import0\n\nlet phys_equal = phys_equal\n\nexternal polymorphic_compare : 'a -> 'a -> int = \"%compare\"\nexternal polymorphic_equal : 'a -> 'a -> bool = \"%equal\"\nexternal ( && ) : bool -> bool -> bool = \"%sequand\"\n\nlet compare_abstract ~type_name _ _ =\n Printf.ksprintf\n failwith\n \"Compare called on the type %s, which is abstract in an implementation.\"\n type_name\n;;\n\nlet equal_abstract ~type_name _ _ =\n Printf.ksprintf\n failwith\n \"Equal called on the type %s, which is abstract in an implementation.\"\n type_name\n;;\n\ntype 'a compare = 'a -> 'a -> int\ntype 'a equal = 'a -> 'a -> bool\n\nmodule Builtin = struct\n let compare_bool : bool compare = Poly.compare\n let compare_char : char compare = Poly.compare\n let compare_float : float compare = Poly.compare\n let compare_int : int compare = Poly.compare\n let compare_int32 : int32 compare = Poly.compare\n let compare_int64 : int64 compare = Poly.compare\n let compare_nativeint : nativeint compare = Poly.compare\n let compare_string : string compare = Poly.compare\n let compare_unit : unit compare = Poly.compare\n\n let compare_array compare_elt a b =\n if phys_equal a b\n then 0\n else (\n let len_a = Array0.length a in\n let len_b = Array0.length b in\n let ret = compare len_a len_b in\n if ret <> 0\n then ret\n else (\n let rec loop i =\n if i = len_a\n then 0\n else (\n let l = Array0.unsafe_get a i\n and r = Array0.unsafe_get b i in\n let res = compare_elt l r in\n if res <> 0 then res else loop (i + 1))\n in\n loop 0))\n ;;\n\n let rec compare_list compare_elt a b =\n match a, b with\n | [], [] -> 0\n | [], _ -> -1\n | _, [] -> 1\n | x :: xs, y :: ys ->\n let res = compare_elt x y in\n if res <> 0 then res else compare_list compare_elt xs ys\n ;;\n\n let compare_option compare_elt a b =\n match a, b with\n | None, None -> 0\n | None, Some _ -> -1\n | Some _, None -> 1\n | Some a, Some b -> compare_elt a b\n ;;\n\n let compare_ref compare_elt a b = compare_elt !a !b\n let equal_bool : bool equal = Poly.equal\n let equal_char : char equal = Poly.equal\n let equal_int : int equal = Poly.equal\n let equal_int32 : int32 equal = Poly.equal\n let equal_int64 : int64 equal = Poly.equal\n let equal_nativeint : nativeint equal = Poly.equal\n let equal_string : string equal = Poly.equal\n let equal_unit : unit equal = Poly.equal\n\n (* [Poly.equal] is IEEE compliant, which is not what we want here. *)\n let equal_float x y = equal_int (compare_float x y) 0\n\n let equal_array equal_elt a b =\n phys_equal a b\n ||\n let len_a = Array0.length a in\n let len_b = Array0.length b in\n equal len_a len_b\n &&\n let rec loop i =\n i = len_a\n ||\n let l = Array0.unsafe_get a i\n and r = Array0.unsafe_get b i in\n equal_elt l r && loop (i + 1)\n in\n loop 0\n ;;\n\n let rec equal_list equal_elt a b =\n match a, b with\n | [], [] -> true\n | [], _ | _, [] -> false\n | x :: xs, y :: ys -> equal_elt x y && equal_list equal_elt xs ys\n ;;\n\n let equal_option equal_elt a b =\n match a, b with\n | None, None -> true\n | None, Some _ | Some _, None -> false\n | Some a, Some b -> equal_elt a b\n ;;\n\n let equal_ref equal_elt a b = equal_elt !a !b\nend\n","(* [String0] defines string functions that are primitives or can be simply defined in\n terms of [Caml.String]. [String0] is intended to completely express the part of\n [Caml.String] that [Base] uses -- no other file in Base other than string0.ml should\n use [Caml.String]. [String0] has few dependencies, and so is available early in Base's\n build order.\n\n All Base files that need to use strings, including the subscript syntax\n [x.(i)] or [x.(i) <- e] which the OCaml parser desugars into calls to\n [String], and come before [Base.String] in build order should do\n\n {[\n module String = String0\n ]}\n\n Defining [module String = String0] is also necessary because it prevents\n ocamldep from mistakenly causing a file to depend on [Base.String]. *)\n\nopen! Import0\nmodule Sys = Sys0\n\nmodule String = struct\n external get : string -> int -> char = \"%string_safe_get\"\n external length : string -> int = \"%string_length\"\n external unsafe_get : string -> int -> char = \"%string_unsafe_get\"\n\n include Bytes_set_primitives\nend\n\ninclude String\n\nlet max_length = Sys.max_string_length\nlet ( ^ ) = ( ^ )\nlet capitalize = Caml.String.capitalize_ascii\nlet compare = Caml.String.compare\nlet[@warning \"-3\"] copy = Caml.String.copy\nlet escaped = Caml.String.escaped\nlet lowercase = Caml.String.lowercase_ascii\nlet make = Caml.String.make\nlet sub = Caml.String.sub\nlet uncapitalize = Caml.String.uncapitalize_ascii\nlet unsafe_blit = Caml.String.unsafe_blit\nlet uppercase = Caml.String.uppercase_ascii\n\nlet concat ?(sep = \"\") l =\n match l with\n | [] -> \"\"\n (* The stdlib does not specialize this case because it could break existing projects. *)\n | [ x ] -> x\n | l -> Caml.String.concat ~sep l\n;;\n\n(* These are eta expanded in order to permute parameter order to follow Base\n conventions. *)\nlet iter t ~f = Caml.String.iter t ~f\n","open Hash.Builtin\nopen Ppx_compare_lib.Builtin\nmodule List = List0\nmodule String = String0\ninclude (Sexplib0.Sexp : module type of Sexplib0.Sexp with type t := Sexplib0.Sexp.t)\n\n(** Type of S-expressions *)\ntype t = Sexplib0.Sexp.t =\n | Atom of string\n | List of t list\n[@@deriving_inline compare, hash]\n\nlet rec compare =\n (fun a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match a__001_, b__002_ with\n | Atom _a__003_, Atom _b__004_ -> compare_string _a__003_ _b__004_\n | Atom _, _ -> -1\n | _, Atom _ -> 1\n | List _a__005_, List _b__006_ -> compare_list compare _a__005_ _b__006_)\n : t -> t -> int)\n;;\n\nlet rec (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n (fun hsv arg ->\n match arg with\n | Atom _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 0 in\n let hsv = hsv in\n hash_fold_string hsv _a0\n | List _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 1 in\n let hsv = hsv in\n hash_fold_list hash_fold_t hsv _a0\n : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state)\n\nand (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func arg =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (let hsv = Ppx_hash_lib.Std.Hash.create () in\n hash_fold_t hsv arg)\n in\n fun x -> func x\n;;\n\n[@@@end]\n\nlet of_string = ()\nlet invariant (_ : t) = ()\n","open! Import\ninclude Sexplib0.Sexpable\n\nmodule Of_sexpable\n (Sexpable : S) (M : sig\n type t\n\n val to_sexpable : t -> Sexpable.t\n val of_sexpable : Sexpable.t -> t\n end) : S with type t := M.t = struct\n let t_of_sexp sexp =\n let s = Sexpable.t_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t t = Sexpable.sexp_of_t (M.to_sexpable t)\nend\n\nmodule Of_sexpable1\n (Sexpable : S1) (M : sig\n type 'a t\n\n val to_sexpable : 'a t -> 'a Sexpable.t\n val of_sexpable : 'a Sexpable.t -> 'a t\n end) : S1 with type 'a t := 'a M.t = struct\n let t_of_sexp a_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a t = Sexpable.sexp_of_t sexp_of_a (M.to_sexpable t)\nend\n\nmodule Of_sexpable2\n (Sexpable : S2) (M : sig\n type ('a, 'b) t\n\n val to_sexpable : ('a, 'b) t -> ('a, 'b) Sexpable.t\n val of_sexpable : ('a, 'b) Sexpable.t -> ('a, 'b) t\n end) : S2 with type ('a, 'b) t := ('a, 'b) M.t = struct\n let t_of_sexp a_of_sexp b_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp b_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a sexp_of_b t =\n Sexpable.sexp_of_t sexp_of_a sexp_of_b (M.to_sexpable t)\n ;;\nend\n\nmodule Of_sexpable3\n (Sexpable : S3) (M : sig\n type ('a, 'b, 'c) t\n\n val to_sexpable : ('a, 'b, 'c) t -> ('a, 'b, 'c) Sexpable.t\n val of_sexpable : ('a, 'b, 'c) Sexpable.t -> ('a, 'b, 'c) t\n end) : S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t = struct\n let t_of_sexp a_of_sexp b_of_sexp c_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp b_of_sexp c_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a sexp_of_b sexp_of_c t =\n Sexpable.sexp_of_t sexp_of_a sexp_of_b sexp_of_c (M.to_sexpable t)\n ;;\nend\n\nmodule Of_stringable (M : Stringable.S) : S with type t := M.t = struct\n let t_of_sexp sexp =\n match sexp with\n | Sexp.Atom s ->\n (try M.of_string s with\n | exn -> of_sexp_error_exn exn sexp)\n | Sexp.List _ ->\n of_sexp_error\n \"Sexpable.Of_stringable.t_of_sexp expected an atom, but got a list\"\n sexp\n ;;\n\n let sexp_of_t t = Sexp.Atom (M.to_string t)\nend\n","open! Import\nmodule Sys = Sys0\n\ntype t =\n | W32\n | W64\n[@@deriving_inline sexp_of]\n\nlet sexp_of_t =\n (function\n | W32 -> Ppx_sexp_conv_lib.Sexp.Atom \"W32\"\n | W64 -> Ppx_sexp_conv_lib.Sexp.Atom \"W64\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet num_bits = function\n | W32 -> 32\n | W64 -> 64\n;;\n\nlet word_size =\n match Sys.word_size_in_bits with\n | 32 -> W32\n | 64 -> W64\n | _ -> failwith \"unknown word size\"\n;;\n","open! Import\n\nlet r = ref [ \"Base.Sexp.pp_hum\" ]\nlet all () = !r\nlet register p = r := p :: !r\n\nmodule type S = sig\n type t\n\n val pp : Formatter.t -> t -> unit\nend\n\nmodule Register_pp (M : sig\n include S\n\n val module_name : string\n end) =\nstruct\n include M\n\n let () = register (M.module_name ^ \".pp\")\nend\n\nmodule Register (M : sig\n type t\n\n val module_name : string\n val to_string : t -> string\n end) =\n Register_pp (struct\n include M\n\n let pp formatter t = Caml.Format.pp_print_string formatter (M.to_string t)\n end)\n","(** [Core_kernel] greatly expands the functionality available in Base while still\n remaining platform-agnostic. Core_kernel changes more frequently (i.e., is less\n stable) than Base.\n\n Some modules are mere extensions of their counterparts in Base, usually adding generic\n functionality by including functors that make them binable, comparable, sexpable,\n blitable, etc. The bulk of Core_kernel, though, is modules providing entirely new\n functionality. *)\n\nopen! Import\n\n\nmodule Applicative = Applicative\nmodule Arg = Arg\nmodule Array = Array\nmodule Avltree = Avltree\nmodule Backtrace = Backtrace\nmodule Bag = Bag\nmodule Bigbuffer = Bigbuffer\nmodule Bigstring = Bigstring\nmodule Bigsubstring = Bigsubstring\nmodule Bin_prot = Core_bin_prot\nmodule Binable = Binable\nmodule Binary_search = Binary_search\nmodule Binary_searchable = Binary_searchable\nmodule Blang = Blang\nmodule Blit = Blit\nmodule Bool = Bool\nmodule Bounded_index = Bounded_index\nmodule Buffer = Base.Buffer\nmodule Byte_units = Byte_units\nmodule Bytes = Bytes\nmodule Caml = Caml\nmodule Char = Char\nmodule Command = Command\nmodule Comparable = Comparable\nmodule Comparator = Comparator\nmodule Comparisons = Comparisons\nmodule Container = Container\nmodule Container_intf = Container_intf\nmodule Continue_or_stop = Continue_or_stop\nmodule Core_kernel_stable = Stable\nmodule Date = Date\nmodule Day_of_week = Day_of_week\nmodule Debug = Debug\nmodule Deque = Deque\nmodule Deriving_hash = Deriving_hash\nmodule Digest = Md5 [@@ocaml.deprecated \"[since 2017-05] Use Md5 instead.\"]\nmodule Doubly_linked = Doubly_linked\nmodule Either = Either\nmodule Ephemeron = Ephemeron\nmodule Equal = Equal\nmodule Error = Error\nmodule Exn = Base.Exn\nmodule Expect_test_config = Expect_test_config\nmodule Fdeque = Fdeque\nmodule Field = Field\nmodule Filename = Filename\nmodule Float = Float\nmodule Float_with_finite_only_serialization = Float_with_finite_only_serialization\nmodule Floatable = Floatable\nmodule Fn = Fn\nmodule Formatter = Formatter\nmodule Fqueue = Fqueue\nmodule Gc = Gc\nmodule Hash = Hash\nmodule Hash_queue = Hash_queue\nmodule Hash_set = Hash_set\nmodule Hashable = Hashable\nmodule Hashtbl = Hashtbl\nmodule Hashtbl_intf = Hashtbl_intf\nmodule Heap_block = Heap_block\nmodule Hexdump = Hexdump\nmodule Hexdump_intf = Hexdump_intf\nmodule Host_and_port = Host_and_port\nmodule Identifiable = Identifiable\nmodule Immediate_option = Immediate_option\nmodule Immediate_option_intf = Immediate_option_intf\nmodule In_channel = In_channel\nmodule Info = Info\nmodule Int = Int\nmodule Int32 = Int32\nmodule Int63 = Int63\nmodule Int64 = Int64\nmodule Int_conversions = Int_conversions\nmodule Int_intf = Int_intf\nmodule Int_math = Int_math\nmodule Intable = Intable\nmodule Interfaces = Interfaces\nmodule Invariant = Invariant\nmodule Lazy = Lazy\nmodule Linked_queue = Linked_queue\nmodule List = List\nmodule Map = Map\nmodule Map_intf = Map_intf\nmodule Maybe_bound = Maybe_bound\nmodule Md5 = Md5\nmodule Memo = Memo\nmodule Monad = Monad\nmodule Month = Month\nmodule Nativeint = Nativeint\nmodule No_polymorphic_compare = No_polymorphic_compare\nmodule Nothing = Nothing\nmodule Only_in_test = Only_in_test\nmodule Option = Option\nmodule Option_array = Option_array\nmodule Optional_syntax = Optional_syntax\nmodule Optional_syntax_intf = Optional_syntax_intf\nmodule Or_error = Or_error\nmodule Ordered_collection_common = Ordered_collection_common\nmodule Ordering = Ordering\nmodule Out_channel = Out_channel\nmodule Percent = Percent\nmodule Perms = Perms\nmodule Pid = Pid\nmodule Poly = Poly\nmodule Polymorphic_compare = Poly [@@deprecated \"[since 2018-11] use [Poly] instead\"]\n\nmodule Popcount = Base.Popcount\n[@@warning \"-3\"]\n[@@deprecated \"[since 2018-10] use [popcount] functions in individual int modules\"]\n\nmodule Pretty_printer = Pretty_printer\nmodule Printexc = Printexc\nmodule Printf = Printf\nmodule Queue = Queue\nmodule Quickcheck = Quickcheck\nmodule Quickcheck_intf = Quickcheck_intf\nmodule Quickcheckable = Quickcheckable\nmodule Random = Base.Random\nmodule Ref = Ref\nmodule Result = Result\nmodule Robustly_comparable = Robustly_comparable\nmodule Sequence = Sequence\nmodule Set = Set\nmodule Set_intf = Set_intf\nmodule Set_once = Set_once\nmodule Sexp_maybe = Sexp.Sexp_maybe\n\nmodule Sexp = Sexp\nmodule Sexpable = Sexpable\nmodule Sign = Sign\nmodule Sign_or_nan = Sign_or_nan\nmodule Source_code_position = Source_code_position\nmodule Splittable_random = Splittable_random\nmodule Stable_comparable = Stable_comparable\nmodule Stable_unit_test = Stable_unit_test\nmodule Stack = Stack\nmodule Staged = Base.Staged\nmodule String = String\nmodule String_id = String_id\nmodule Stringable = Stringable\nmodule Substring = Substring\nmodule Substring_intf = Substring_intf\nmodule Sys = Sys\nmodule Time = Time_float\nmodule Time_ns = Time_ns\nmodule Tuple = Tuple\nmodule Tuple2 = Tuple.T2\nmodule Tuple3 = Tuple.T3\nmodule Type_equal = Type_equal\nmodule Type_immediacy = Type_immediacy\nmodule Uchar = Uchar\nmodule Uniform_array = Uniform_array\nmodule Union_find = Union_find\nmodule Unique_id = Unique_id\nmodule Unit = Unit\nmodule Unit_of_time = Unit_of_time\nmodule Univ_map = Univ_map\n\nmodule Unix = struct end\n[@@deprecated\n \"[since 2020-03] Core_kernel shadows Unix. Use Core.Unix, which overrides some of \\\n Unix's behavior. If necessary, Unix is available and unshadowed as Caml_unix.\"]\n\nmodule Validate = Validate\nmodule Validated = Validated\nmodule Variant = Variant\nmodule Weak = Weak\nmodule With_return = With_return\nmodule Word_size = Word_size\n\nmodule type Unique_id = Unique_id.Id\n\ninclude T (** @open *)\n\ninclude Std_internal\ninclude Not_found\n\n(** {2 Top-level values} *)\n\ntype 'a _maybe_bound = 'a Maybe_bound.t =\n | Incl of 'a\n | Excl of 'a\n | Unbounded\n\nlet am_running_inline_test = am_running_inline_test\nlet am_running_test = am_running_test\nlet does_raise = Exn.does_raise\nlet sec = Time_float.Span.of_sec\n\n(** We perform these side effects here because we want them to run for any code that uses\n [Core_kernel]. If this were in another module in [Core_kernel] that was not used in\n some program, then the side effects might not be run in that program. This will run\n as long as the program refers to at least one value directly in [Std_kernel];\n referring to values in [Std_kernel.Bool], for example, is not sufficient. *)\nlet () = Exn.initialize_module ()\n\n(** To be used in implementing Core, but not by end users. *)\nmodule Core_kernel_private = struct\n module Digit_string_helpers = Digit_string_helpers\n module Time_zone = Zone\n module Ofday_helpers = Ofday_helpers\n module Span_float = Span_float\n\n module Bigbuffer_internal = Bigbuffer_internal\n module Stable_internal = Stable_internal\n module Std_internal = Std_internal\n\n module Time_ns_alternate_sexp = Time_ns_alternate_sexp\nend\n","(* belongs in Common, but moved here to avoid circular dependencies *)\n\nopen! Import\n\ntype 'a return = { return : 'b. 'a -> 'b } [@@unboxed]\n\nlet with_return (type a) f =\n let module M = struct\n (* Raised to indicate ~return was called. Local so that the exception is tied to a\n particular call of [with_return]. *)\n exception Return of a\n end\n in\n let is_alive = ref true in\n let return a =\n if not !is_alive\n then failwith \"use of [return] from a [with_return] that already returned\";\n Exn.raise_without_backtrace (M.Return a)\n in\n try\n let a = f { return } in\n is_alive := false;\n a\n with\n | exn ->\n is_alive := false;\n (match exn with\n | M.Return a -> a\n | _ -> raise exn)\n;;\n\nlet with_return_option f =\n with_return (fun return ->\n f { return = (fun a -> return.return (Some a)) };\n None)\n;;\n\nlet prepend { return } ~f = { return = (fun x -> return (f x)) }\n","open! Import\nmodule List = List0\ninclude Monad_intf\n\nmodule type Basic_general = sig\n type ('a, 'i, 'j, 'd, 'e) t\n\n val bind\n : ('a, 'i, 'j, 'd, 'e) t\n -> f:('a -> ('b, 'j, 'k, 'd, 'e) t)\n -> ('b, 'i, 'k, 'd, 'e) t\n\n val map\n : [ `Define_using_bind\n | `Custom of ('a, 'i, 'j, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'i, 'j, 'd, 'e) t\n ]\n\n val return : 'a -> ('a, 'i, 'i, 'd, 'e) t\nend\n\nmodule Make_general (M : Basic_general) = struct\n let bind = M.bind\n let return = M.return\n let map_via_bind ma ~f = M.bind ma ~f:(fun a -> M.return (f a))\n\n let map =\n match M.map with\n | `Define_using_bind -> map_via_bind\n | `Custom x -> x\n ;;\n\n module Monad_infix = struct\n let ( >>= ) t f = bind t ~f\n let ( >>| ) t f = map t ~f\n end\n\n include Monad_infix\n\n module Let_syntax = struct\n let return = return\n\n include Monad_infix\n\n module Let_syntax = struct\n let return = return\n let bind = bind\n let map = map\n let both a b = a >>= fun a -> b >>| fun b -> a, b\n\n module Open_on_rhs = struct end\n end\n end\n\n let join t = t >>= fun t' -> t'\n let ignore_m t = map t ~f:(fun _ -> ())\n\n let all =\n let rec loop vs = function\n | [] -> return (List.rev vs)\n | t :: ts -> t >>= fun v -> loop (v :: vs) ts\n in\n fun ts -> loop [] ts\n ;;\n\n let rec all_unit = function\n | [] -> return ()\n | t :: ts -> t >>= fun () -> all_unit ts\n ;;\nend\n\nmodule Make_indexed (M : Basic_indexed) :\n S_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) M.t = Make_general (struct\n type ('a, 'i, 'j, 'd, 'e) t = ('a, 'i, 'j) M.t\n\n include (M : Basic_indexed with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t)\n end)\n\nmodule Make3 (M : Basic3) : S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) M.t =\n Make_general (struct\n type ('a, 'i, 'j, 'd, 'e) t = ('a, 'd, 'e) M.t\n\n include (M : Basic3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t)\n end)\n\nmodule Make2 (M : Basic2) : S2 with type ('a, 'd) t := ('a, 'd) M.t =\n Make_general (struct\n type ('a, 'i, 'j, 'd, 'e) t = ('a, 'd) M.t\n\n include (M : Basic2 with type ('a, 'b) t := ('a, 'b) M.t)\n end)\n\nmodule Make (M : Basic) : S with type 'a t := 'a M.t = Make_general (struct\n type ('a, 'i, 'j, 'd, 'e) t = 'a M.t\n\n include (M : Basic with type 'a t := 'a M.t)\n end)\n\nmodule Ident = struct\n type 'a t = 'a\n\n include Make (struct\n type nonrec 'a t = 'a t\n\n let bind a ~f = f a\n let return a = a\n let map = `Custom (fun a ~f -> f a)\n end)\nend\n","open! Import\n\ntype ('a, 'witness) t =\n { compare : 'a -> 'a -> int\n ; sexp_of_t : 'a -> Sexp.t\n }\n\ntype ('a, 'b) comparator = ('a, 'b) t\n\nmodule type S = sig\n type t\n type comparator_witness\n\n val comparator : (t, comparator_witness) comparator\nend\n\nmodule type S1 = sig\n type 'a t\n type comparator_witness\n\n val comparator : ('a t, comparator_witness) comparator\nend\n\nmodule type S_fc = sig\n type comparable_t\n\n include S with type t := comparable_t\nend\n\nlet make (type t) ~compare ~sexp_of_t =\n (module struct\n type comparable_t = t\n type comparator_witness\n\n let comparator = { compare; sexp_of_t }\n end : S_fc\n with type comparable_t = t)\n;;\n\nmodule S_to_S1 (S : S) = struct\n type 'a t = S.t\n type comparator_witness = S.comparator_witness\n\n open S\n\n let comparator = comparator\nend\n\nmodule Make (M : sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) =\nstruct\n include M\n\n type comparator_witness\n\n let comparator = M.{ compare; sexp_of_t }\nend\n\nmodule Make1 (M : sig\n type 'a t\n\n val compare : 'a t -> 'a t -> int\n val sexp_of_t : 'a t -> Sexp.t\n end) =\nstruct\n type comparator_witness\n\n let comparator = M.{ compare; sexp_of_t }\nend\n\nmodule Poly = struct\n type 'a t = 'a\n\n include Make1 (struct\n type 'a t = 'a\n\n let compare = Poly.compare\n let sexp_of_t _ = Sexp.Atom \"_\"\n end)\nend\n\nmodule type Derived = sig\n type 'a t\n type 'cmp comparator_witness\n\n val comparator : ('a, 'cmp) comparator -> ('a t, 'cmp comparator_witness) comparator\nend\n\nmodule Derived (M : sig\n type 'a t [@@deriving_inline compare, sexp_of]\n\n val compare : ('a -> 'a -> int) -> 'a t -> 'a t -> int\n val sexp_of_t : ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) =\nstruct\n type 'cmp comparator_witness\n\n let comparator a =\n { compare = M.compare a.compare; sexp_of_t = M.sexp_of_t a.sexp_of_t }\n ;;\nend\n\nmodule type Derived2 = sig\n type ('a, 'b) t\n type ('cmp_a, 'cmp_b) comparator_witness\n\n val comparator\n : ('a, 'cmp_a) comparator\n -> ('b, 'cmp_b) comparator\n -> (('a, 'b) t, ('cmp_a, 'cmp_b) comparator_witness) comparator\nend\n\nmodule Derived2 (M : sig\n type ('a, 'b) t [@@deriving_inline compare, sexp_of]\n\n val compare : ('a -> 'a -> int) -> ('b -> 'b -> int) -> ('a, 'b) t -> ('a, 'b) t -> int\n\n val sexp_of_t\n : ('a -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('b -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('a, 'b) t\n -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) =\nstruct\n type ('cmp_a, 'cmp_b) comparator_witness\n\n let comparator a b =\n { compare = M.compare a.compare b.compare\n ; sexp_of_t = M.sexp_of_t a.sexp_of_t b.sexp_of_t\n }\n ;;\nend\n\nmodule type Derived_phantom = sig\n type ('a, 'b) t\n type 'cmp comparator_witness\n\n val comparator\n : ('a, 'cmp) comparator\n -> (('a, _) t, 'cmp comparator_witness) comparator\nend\n\nmodule Derived_phantom (M : sig\n type ('a, 'b) t\n\n val compare : ('a -> 'a -> int) -> ('a, 'b) t -> ('a, 'b) t -> int\n val sexp_of_t : ('a -> Sexp.t) -> ('a, _) t -> Sexp.t\n end) =\nstruct\n type 'cmp_a comparator_witness\n\n let comparator a =\n { compare = M.compare a.compare; sexp_of_t = M.sexp_of_t a.sexp_of_t }\n ;;\nend\n","(* The type [t] should be abstract to make the fset and set functions unavailable\n for private types at the level of types (and not by putting None in the field).\n Unfortunately, making the type abstract means that when creating fields (through\n a [create] function) value restriction kicks in. This is worked around by instead\n not making the type abstract, but forcing anyone breaking the abstraction to use\n the [For_generated_code] module, making it obvious to any reader that something ugly\n is going on.\n t_with_perm (and derivatives) is the type that users really use. It is a constructor\n because:\n 1. it makes type errors more readable (less aliasing)\n 2. the typer in ocaml 4.01 allows this:\n\n {[\n module A = struct\n type t = {a : int}\n end\n type t = A.t\n let f (x : t) = x.a\n ]}\n\n (although with Warning 40: a is used out of scope)\n which means that if [t_with_perm] was really an alias on [For_generated_code.t],\n people could say [t.setter] and break the abstraction with no indication that\n something ugly is going on in the source code.\n The warning is (I think) for people who want to make their code compatible with\n previous versions of ocaml, so we may very well turn it off.\n\n The type t_with_perm could also have been a [unit -> For_generated_code.t] to work\n around value restriction and then [For_generated_code.t] would have been a proper\n abstract type, but it looks like it could impact performance (for example, a fold on a\n record type with 40 fields would actually allocate the 40 [For_generated_code.t]'s at\n every single fold.) *)\n\nmodule For_generated_code = struct\n type ('perm, 'record, 'field) t =\n { force_variance : 'perm -> unit\n ; (* force [t] to be contravariant in ['perm], because phantom type variables on\n concrete types don't work that well otherwise (using :> can remove them easily) *)\n name : string\n ; setter : ('record -> 'field -> unit) option\n ; getter : 'record -> 'field\n ; fset : 'record -> 'field -> 'record\n }\n\n let opaque_identity = Sys0.opaque_identity\nend\n\ntype ('perm, 'record, 'field) t_with_perm =\n | Field of ('perm, 'record, 'field) For_generated_code.t\n[@@unboxed]\n\ntype ('record, 'field) t = ([ `Read | `Set_and_create ], 'record, 'field) t_with_perm\ntype ('record, 'field) readonly_t = ([ `Read ], 'record, 'field) t_with_perm\n\nlet name (Field field) = field.name\nlet get (Field field) r = field.getter r\nlet fset (Field field) r v = field.fset r v\nlet setter (Field field) = field.setter\n\ntype ('perm, 'record, 'result) user =\n { f : 'field. ('perm, 'record, 'field) t_with_perm -> 'result }\n\nlet map (Field field) r ~f = field.fset r (f (field.getter r))\n\nlet updater (Field field) =\n match field.setter with\n | None -> None\n | Some setter -> Some (fun r ~f -> setter r (f (field.getter r)))\n;;\n","open! Import\nmodule Int = Int0\nmodule String = String0\n\nmodule T = struct\n type t = Caml.Lexing.position =\n { pos_fname : string\n ; pos_lnum : int\n ; pos_bol : int\n ; pos_cnum : int\n }\n [@@deriving_inline compare, hash, sexp]\n\n let compare =\n (fun a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match compare_string a__001_.pos_fname b__002_.pos_fname with\n | 0 ->\n (match compare_int a__001_.pos_lnum b__002_.pos_lnum with\n | 0 ->\n (match compare_int a__001_.pos_bol b__002_.pos_bol with\n | 0 -> compare_int a__001_.pos_cnum b__002_.pos_cnum\n | n -> n)\n | n -> n)\n | n -> n)\n : t -> t -> int)\n ;;\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n fun hsv arg ->\n let hsv =\n let hsv =\n let hsv =\n let hsv = hsv in\n hash_fold_string hsv arg.pos_fname\n in\n hash_fold_int hsv arg.pos_lnum\n in\n hash_fold_int hsv arg.pos_bol\n in\n hash_fold_int hsv arg.pos_cnum\n ;;\n\n let (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func arg =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (let hsv = Ppx_hash_lib.Std.Hash.create () in\n hash_fold_t hsv arg)\n in\n fun x -> func x\n ;;\n\n let t_of_sexp =\n (let _tp_loc = \"source_code_position0.ml.T.t\" in\n function\n | Ppx_sexp_conv_lib.Sexp.List field_sexps as sexp ->\n let pos_fname_field = ref Ppx_sexp_conv_lib.Option.None\n and pos_lnum_field = ref Ppx_sexp_conv_lib.Option.None\n and pos_bol_field = ref Ppx_sexp_conv_lib.Option.None\n and pos_cnum_field = ref Ppx_sexp_conv_lib.Option.None\n and duplicates = ref []\n and extra = ref [] in\n let rec iter = function\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom field_name :: (([] | [ _ ]) as _field_sexps))\n :: tail ->\n let _field_sexp () =\n match _field_sexps with\n | [ x ] -> x\n | [] -> Ppx_sexp_conv_lib.Conv_error.record_only_pairs_expected _tp_loc sexp\n | _ -> assert false\n in\n (match field_name with\n | \"pos_fname\" ->\n (match !pos_fname_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = string_of_sexp _field_sexp in\n pos_fname_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ -> duplicates := field_name :: !duplicates)\n | \"pos_lnum\" ->\n (match !pos_lnum_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n pos_lnum_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ -> duplicates := field_name :: !duplicates)\n | \"pos_bol\" ->\n (match !pos_bol_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n pos_bol_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ -> duplicates := field_name :: !duplicates)\n | \"pos_cnum\" ->\n (match !pos_cnum_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n pos_cnum_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ -> duplicates := field_name :: !duplicates)\n | _ ->\n if !Ppx_sexp_conv_lib.Conv.record_check_extra_fields\n then extra := field_name :: !extra\n else ());\n iter tail\n | ((Ppx_sexp_conv_lib.Sexp.Atom _ | Ppx_sexp_conv_lib.Sexp.List _) as sexp) :: _\n -> Ppx_sexp_conv_lib.Conv_error.record_only_pairs_expected _tp_loc sexp\n | [] -> ()\n in\n iter field_sexps;\n (match !duplicates with\n | _ :: _ ->\n Ppx_sexp_conv_lib.Conv_error.record_duplicate_fields _tp_loc !duplicates sexp\n | [] ->\n (match !extra with\n | _ :: _ -> Ppx_sexp_conv_lib.Conv_error.record_extra_fields _tp_loc !extra sexp\n | [] ->\n (match !pos_fname_field, !pos_lnum_field, !pos_bol_field, !pos_cnum_field with\n | ( Ppx_sexp_conv_lib.Option.Some pos_fname_value\n , Ppx_sexp_conv_lib.Option.Some pos_lnum_value\n , Ppx_sexp_conv_lib.Option.Some pos_bol_value\n , Ppx_sexp_conv_lib.Option.Some pos_cnum_value ) ->\n { pos_fname = pos_fname_value\n ; pos_lnum = pos_lnum_value\n ; pos_bol = pos_bol_value\n ; pos_cnum = pos_cnum_value\n }\n | _ ->\n Ppx_sexp_conv_lib.Conv_error.record_undefined_elements\n _tp_loc\n sexp\n [ ( Ppx_sexp_conv_lib.Conv.( = )\n !pos_fname_field\n Ppx_sexp_conv_lib.Option.None\n , \"pos_fname\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !pos_lnum_field\n Ppx_sexp_conv_lib.Option.None\n , \"pos_lnum\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !pos_bol_field\n Ppx_sexp_conv_lib.Option.None\n , \"pos_bol\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !pos_cnum_field\n Ppx_sexp_conv_lib.Option.None\n , \"pos_cnum\" )\n ])))\n | Ppx_sexp_conv_lib.Sexp.Atom _ as sexp ->\n Ppx_sexp_conv_lib.Conv_error.record_list_instead_atom _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> t)\n ;;\n\n let sexp_of_t =\n (function\n | { pos_fname = v_pos_fname\n ; pos_lnum = v_pos_lnum\n ; pos_bol = v_pos_bol\n ; pos_cnum = v_pos_cnum\n } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_int v_pos_cnum in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"pos_cnum\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_pos_bol in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"pos_bol\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_pos_lnum in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"pos_lnum\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_string v_pos_fname in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"pos_fname\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\nend\n\ninclude T\ninclude Comparator.Make (T)\n\n(* This is the same function as Ppx_here.lift_position_as_string. *)\nlet make_location_string ~pos_fname ~pos_lnum ~pos_cnum ~pos_bol =\n String.concat\n [ pos_fname; \":\"; Int.to_string pos_lnum; \":\"; Int.to_string (pos_cnum - pos_bol) ]\n;;\n\nlet to_string { Caml.Lexing.pos_fname; pos_lnum; pos_cnum; pos_bol } =\n make_location_string ~pos_fname ~pos_lnum ~pos_cnum ~pos_bol\n;;\n\nlet sexp_of_t t = Sexp.Atom (to_string t)\n","open! Import\ninclude List0\n\nlet is_empty = function\n | [] -> true\n | _ -> false\n;;\n\nlet partition_map t ~f =\n let rec loop t fst snd =\n match t with\n | [] -> rev fst, rev snd\n | x :: t ->\n (match (f x : _ Either0.t) with\n | First y -> loop t (y :: fst) snd\n | Second y -> loop t fst (y :: snd))\n in\n loop t [] []\n;;\n","open! Import\nmodule Either = Either0\n\ntype ('a, 'b) t = ('a, 'b) Caml.result =\n | Ok of 'a\n | Error of 'b\n[@@deriving_inline sexp, compare, equal, hash]\n\nlet t_of_sexp\n : type a b.\n (Ppx_sexp_conv_lib.Sexp.t -> a)\n -> (Ppx_sexp_conv_lib.Sexp.t -> b)\n -> Ppx_sexp_conv_lib.Sexp.t\n -> (a, b) t\n =\n let _tp_loc = \"result.ml.t\" in\n fun _of_a _of_b -> function\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"ok\" | \"Ok\") as _tag) :: sexp_args) as _sexp ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_a v0 in\n Ok v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"error\" | \"Error\") as _tag) :: sexp_args) as _sexp\n ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_b v0 in\n Error v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.Atom (\"ok\" | \"Ok\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.Atom (\"error\" | \"Error\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n;;\n\nlet sexp_of_t\n : type a b.\n (a -> Ppx_sexp_conv_lib.Sexp.t)\n -> (b -> Ppx_sexp_conv_lib.Sexp.t)\n -> (a, b) t\n -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a _of_b -> function\n | Ok v0 ->\n let v0 = _of_a v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Ok\"; v0 ]\n | Error v0 ->\n let v0 = _of_b v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Error\"; v0 ]\n;;\n\nlet compare :\n 'a 'b. ('a -> 'a -> int) -> ('b -> 'b -> int) -> ('a, 'b) t -> ('a, 'b) t -> int\n =\n fun _cmp__a _cmp__b a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match a__001_, b__002_ with\n | Ok _a__003_, Ok _b__004_ -> _cmp__a _a__003_ _b__004_\n | Ok _, _ -> -1\n | _, Ok _ -> 1\n | Error _a__005_, Error _b__006_ -> _cmp__b _a__005_ _b__006_)\n;;\n\nlet equal :\n 'a 'b. ('a -> 'a -> bool) -> ('b -> 'b -> bool) -> ('a, 'b) t -> ('a, 'b) t -> bool\n =\n fun _cmp__a _cmp__b a__007_ b__008_ ->\n if Ppx_compare_lib.phys_equal a__007_ b__008_\n then true\n else (\n match a__007_, b__008_ with\n | Ok _a__009_, Ok _b__010_ -> _cmp__a _a__009_ _b__010_\n | Ok _, _ -> false\n | _, Ok _ -> false\n | Error _a__011_, Error _b__012_ -> _cmp__b _a__011_ _b__012_)\n;;\n\nlet hash_fold_t\n : type a b.\n (Ppx_hash_lib.Std.Hash.state -> a -> Ppx_hash_lib.Std.Hash.state)\n -> (Ppx_hash_lib.Std.Hash.state -> b -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state\n -> (a, b) t\n -> Ppx_hash_lib.Std.Hash.state\n =\n fun _hash_fold_a _hash_fold_b hsv arg ->\n match arg with\n | Ok _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 0 in\n let hsv = hsv in\n _hash_fold_a hsv _a0\n | Error _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 1 in\n let hsv = hsv in\n _hash_fold_b hsv _a0\n;;\n\n[@@@end]\n\ninclude Monad.Make2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n\n let bind x ~f =\n match x with\n | Error _ as x -> x\n | Ok x -> f x\n ;;\n\n let map x ~f =\n match x with\n | Error _ as x -> x\n | Ok x -> Ok (f x)\n ;;\n\n let map = `Custom map\n let return x = Ok x\n end)\n\nlet invariant check_ok check_error t =\n match t with\n | Ok ok -> check_ok ok\n | Error error -> check_error error\n;;\n\nlet fail x = Error x\nlet failf format = Printf.ksprintf fail format\n\nlet map_error t ~f =\n match t with\n | Ok _ as x -> x\n | Error x -> Error (f x)\n;;\n\nlet is_ok = function\n | Ok _ -> true\n | Error _ -> false\n;;\n\nlet is_error = function\n | Ok _ -> false\n | Error _ -> true\n;;\n\nlet ok = function\n | Ok x -> Some x\n | Error _ -> None\n;;\n\nlet error = function\n | Ok _ -> None\n | Error x -> Some x\n;;\n\nlet of_option opt ~error =\n match opt with\n | Some x -> Ok x\n | None -> Error error\n;;\n\nlet iter v ~f =\n match v with\n | Ok x -> f x\n | Error _ -> ()\n;;\n\nlet iter_error v ~f =\n match v with\n | Ok _ -> ()\n | Error x -> f x\n;;\n\nlet to_either : _ t -> _ Either.t = function\n | Ok x -> First x\n | Error x -> Second x\n;;\n\nlet of_either : _ Either.t -> _ t = function\n | First x -> Ok x\n | Second x -> Error x\n;;\n\nlet ok_if_true bool ~error = if bool then Ok () else Error error\n\nlet try_with f =\n try Ok (f ()) with\n | exn -> Error exn\n;;\n\nlet ok_exn = function\n | Ok x -> x\n | Error exn -> raise exn\n;;\n\nlet ok_or_failwith = function\n | Ok x -> x\n | Error str -> failwith str\n;;\n\nmodule Export = struct\n type ('ok, 'err) _result = ('ok, 'err) t =\n | Ok of 'ok\n | Error of 'err\n\n let is_error = is_error\n let is_ok = is_ok\nend\n\nlet combine t1 t2 ~ok ~err =\n match t1, t2 with\n | Ok _, Error e | Error e, Ok _ -> Error e\n | Ok ok1, Ok ok2 -> Ok (ok ok1 ok2)\n | Error err1, Error err2 -> Error (err err1 err2)\n;;\n\nlet combine_errors l =\n let ok, errs = List1.partition_map l ~f:to_either in\n match errs with\n | [] -> Ok ok\n | _ :: _ -> Error errs\n;;\n\nlet combine_errors_unit l = map (combine_errors l) ~f:(fun (_ : unit list) -> ())\n\n(* deprecated binding for export only *)\nlet ok_fst = to_either\n","(** Provides generic signatures for container data structures.\n\n These signatures include functions ([iter], [fold], [exists], [for_all], ...) that\n you would expect to find in any container. Used by including [Container.S0] or\n [Container.S1] in the signature for every container-like data structure ([Array],\n [List], [String], ...) to ensure a consistent interface. *)\n\nopen! Import\n\nmodule Export = struct\n (** [Continue_or_stop.t] is used by the [f] argument to [fold_until] in order to\n indicate whether folding should continue, or stop early. *)\n module Continue_or_stop = struct\n type ('a, 'b) t =\n | Continue of 'a\n | Stop of 'b\n end\nend\n\ninclude Export\n\nmodule type Summable = sig\n type t\n\n (** The result of summing no values. *)\n val zero : t\n\n (** An operation that combines two [t]'s and handles [zero + x] by just returning [x],\n as well as in the symmetric case. *)\n val ( + ) : t -> t -> t\nend\n\n(** Signature for monomorphic container, e.g., string. *)\nmodule type S0 = sig\n type t\n type elt\n\n (** Checks whether the provided element is there, using equality on [elt]s. *)\n val mem : t -> elt -> bool\n\n val length : t -> int\n val is_empty : t -> bool\n\n (** [iter] must allow exceptions raised in [f] to escape, terminating the iteration\n cleanly. The same holds for all functions below taking an [f]. *)\n val iter : t -> f:(elt -> unit) -> unit\n\n (** [fold t ~init ~f] returns [f (... f (f (f init e1) e2) e3 ...) en], where [e1..en]\n are the elements of [t]. *)\n val fold : t -> init:'accum -> f:('accum -> elt -> 'accum) -> 'accum\n\n (** [fold_result t ~init ~f] is a short-circuiting version of [fold] that runs in the\n [Result] monad. If [f] returns an [Error _], that value is returned without any\n additional invocations of [f]. *)\n val fold_result\n : t\n -> init:'accum\n -> f:('accum -> elt -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n (** [fold_until t ~init ~f ~finish] is a short-circuiting version of [fold]. If [f]\n returns [Stop _] the computation ceases and results in that value. If [f] returns\n [Continue _], the fold will proceed. If [f] never returns [Stop _], the final result\n is computed by [finish].\n\n Example:\n\n {[\n type maybe_negative =\n | Found_negative of int\n | All_nonnegative of { sum : int }\n\n (** [first_neg_or_sum list] returns the first negative number in [list], if any,\n otherwise returns the sum of the list. *)\n let first_neg_or_sum =\n List.fold_until ~init:0\n ~f:(fun sum x ->\n if x < 0\n then Stop (Found_negative x)\n else Continue (sum + x))\n ~finish:(fun sum -> All_nonnegative { sum })\n ;;\n\n let x = first_neg_or_sum [1; 2; 3; 4; 5]\n val x : maybe_negative = All_nonnegative {sum = 15}\n\n let y = first_neg_or_sum [1; 2; -3; 4; 5]\n val y : maybe_negative = Found_negative -3\n ]} *)\n val fold_until\n : t\n -> init:'accum\n -> f:('accum -> elt -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n (** Returns [true] if and only if there exists an element for which the provided\n function evaluates to [true]. This is a short-circuiting operation. *)\n val exists : t -> f:(elt -> bool) -> bool\n\n (** Returns [true] if and only if the provided function evaluates to [true] for all\n elements. This is a short-circuiting operation. *)\n val for_all : t -> f:(elt -> bool) -> bool\n\n (** Returns the number of elements for which the provided function evaluates to true. *)\n val count : t -> f:(elt -> bool) -> int\n\n (** Returns the sum of [f i] for all [i] in the container. *)\n val sum : (module Summable with type t = 'sum) -> t -> f:(elt -> 'sum) -> 'sum\n\n (** Returns as an [option] the first element for which [f] evaluates to true. *)\n val find : t -> f:(elt -> bool) -> elt option\n\n (** Returns the first evaluation of [f] that returns [Some], and returns [None] if there\n is no such element. *)\n val find_map : t -> f:(elt -> 'a option) -> 'a option\n\n val to_list : t -> elt list\n val to_array : t -> elt array\n\n (** Returns a min (resp. max) element from the collection using the provided [compare]\n function. In case of a tie, the first element encountered while traversing the\n collection is returned. The implementation uses [fold] so it has the same\n complexity as [fold]. Returns [None] iff the collection is empty. *)\n val min_elt : t -> compare:(elt -> elt -> int) -> elt option\n\n val max_elt : t -> compare:(elt -> elt -> int) -> elt option\nend\n\nmodule type S0_phantom = sig\n type elt\n type 'a t\n\n (** Checks whether the provided element is there, using equality on [elt]s. *)\n val mem : _ t -> elt -> bool\n\n val length : _ t -> int\n val is_empty : _ t -> bool\n val iter : _ t -> f:(elt -> unit) -> unit\n\n (** [fold t ~init ~f] returns [f (... f (f (f init e1) e2) e3 ...) en], where [e1..en]\n are the elements of [t]. *)\n val fold : _ t -> init:'accum -> f:('accum -> elt -> 'accum) -> 'accum\n\n (** [fold_result t ~init ~f] is a short-circuiting version of [fold] that runs in the\n [Result] monad. If [f] returns an [Error _], that value is returned without any\n additional invocations of [f]. *)\n val fold_result\n : _ t\n -> init:'accum\n -> f:('accum -> elt -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n (** [fold_until t ~init ~f ~finish] is a short-circuiting version of [fold]. If [f]\n returns [Stop _] the computation ceases and results in that value. If [f] returns\n [Continue _], the fold will proceed. If [f] never returns [Stop _], the final result\n is computed by [finish].\n\n Example:\n\n {[\n type maybe_negative =\n | Found_negative of int\n | All_nonnegative of { sum : int }\n\n (** [first_neg_or_sum list] returns the first negative number in [list], if any,\n otherwise returns the sum of the list. *)\n let first_neg_or_sum =\n List.fold_until ~init:0\n ~f:(fun sum x ->\n if x < 0\n then Stop (Found_negative x)\n else Continue (sum + x))\n ~finish:(fun sum -> All_nonnegative { sum })\n ;;\n\n let x = first_neg_or_sum [1; 2; 3; 4; 5]\n val x : maybe_negative = All_nonnegative {sum = 15}\n\n let y = first_neg_or_sum [1; 2; -3; 4; 5]\n val y : maybe_negative = Found_negative -3\n ]} *)\n val fold_until\n : _ t\n -> init:'accum\n -> f:('accum -> elt -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n (** Returns [true] if and only if there exists an element for which the provided\n function evaluates to [true]. This is a short-circuiting operation. *)\n val exists : _ t -> f:(elt -> bool) -> bool\n\n (** Returns [true] if and only if the provided function evaluates to [true] for all\n elements. This is a short-circuiting operation. *)\n val for_all : _ t -> f:(elt -> bool) -> bool\n\n (** Returns the number of elements for which the provided function evaluates to true. *)\n val count : _ t -> f:(elt -> bool) -> int\n\n (** Returns the sum of [f i] for all [i] in the container. The order in which the\n elements will be summed is unspecified. *)\n val sum : (module Summable with type t = 'sum) -> _ t -> f:(elt -> 'sum) -> 'sum\n\n (** Returns as an [option] the first element for which [f] evaluates to true. *)\n val find : _ t -> f:(elt -> bool) -> elt option\n\n (** Returns the first evaluation of [f] that returns [Some], and returns [None] if there\n is no such element. *)\n val find_map : _ t -> f:(elt -> 'a option) -> 'a option\n\n val to_list : _ t -> elt list\n val to_array : _ t -> elt array\n\n (** Returns a min (resp max) element from the collection using the provided [compare]\n function, or [None] if the collection is empty. In case of a tie, the first element\n encountered while traversing the collection is returned. *)\n val min_elt : _ t -> compare:(elt -> elt -> int) -> elt option\n\n val max_elt : _ t -> compare:(elt -> elt -> int) -> elt option\nend\n\n(** Signature for polymorphic container, e.g., ['a list] or ['a array]. *)\nmodule type S1 = sig\n type 'a t\n\n (** Checks whether the provided element is there, using [equal]. *)\n val mem : 'a t -> 'a -> equal:('a -> 'a -> bool) -> bool\n\n val length : 'a t -> int\n val is_empty : 'a t -> bool\n val iter : 'a t -> f:('a -> unit) -> unit\n\n (** [fold t ~init ~f] returns [f (... f (f (f init e1) e2) e3 ...) en], where [e1..en]\n are the elements of [t] *)\n val fold : 'a t -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum\n\n (** [fold_result t ~init ~f] is a short-circuiting version of [fold] that runs in the\n [Result] monad. If [f] returns an [Error _], that value is returned without any\n additional invocations of [f]. *)\n val fold_result\n : 'a t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n (** [fold_until t ~init ~f ~finish] is a short-circuiting version of [fold]. If [f]\n returns [Stop _] the computation ceases and results in that value. If [f] returns\n [Continue _], the fold will proceed. If [f] never returns [Stop _], the final result\n is computed by [finish].\n\n Example:\n\n {[\n type maybe_negative =\n | Found_negative of int\n | All_nonnegative of { sum : int }\n\n (** [first_neg_or_sum list] returns the first negative number in [list], if any,\n otherwise returns the sum of the list. *)\n let first_neg_or_sum =\n List.fold_until ~init:0\n ~f:(fun sum x ->\n if x < 0\n then Stop (Found_negative x)\n else Continue (sum + x))\n ~finish:(fun sum -> All_nonnegative { sum })\n ;;\n\n let x = first_neg_or_sum [1; 2; 3; 4; 5]\n val x : maybe_negative = All_nonnegative {sum = 15}\n\n let y = first_neg_or_sum [1; 2; -3; 4; 5]\n val y : maybe_negative = Found_negative -3\n ]} *)\n val fold_until\n : 'a t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n (** Returns [true] if and only if there exists an element for which the provided\n function evaluates to [true]. This is a short-circuiting operation. *)\n val exists : 'a t -> f:('a -> bool) -> bool\n\n (** Returns [true] if and only if the provided function evaluates to [true] for all\n elements. This is a short-circuiting operation. *)\n val for_all : 'a t -> f:('a -> bool) -> bool\n\n (** Returns the number of elements for which the provided function evaluates to true. *)\n val count : 'a t -> f:('a -> bool) -> int\n\n (** Returns the sum of [f i] for all [i] in the container. *)\n val sum : (module Summable with type t = 'sum) -> 'a t -> f:('a -> 'sum) -> 'sum\n\n (** Returns as an [option] the first element for which [f] evaluates to true. *)\n val find : 'a t -> f:('a -> bool) -> 'a option\n\n (** Returns the first evaluation of [f] that returns [Some], and returns [None] if there\n is no such element. *)\n val find_map : 'a t -> f:('a -> 'b option) -> 'b option\n\n val to_list : 'a t -> 'a list\n val to_array : 'a t -> 'a array\n\n (** Returns a minimum (resp maximum) element from the collection using the provided\n [compare] function, or [None] if the collection is empty. In case of a tie, the first\n element encountered while traversing the collection is returned. The implementation\n uses [fold] so it has the same complexity as [fold]. *)\n val min_elt : 'a t -> compare:('a -> 'a -> int) -> 'a option\n\n val max_elt : 'a t -> compare:('a -> 'a -> int) -> 'a option\nend\n\nmodule type S1_phantom_invariant = sig\n type ('a, 'phantom) t\n\n (** Checks whether the provided element is there, using [equal]. *)\n val mem : ('a, _) t -> 'a -> equal:('a -> 'a -> bool) -> bool\n\n val length : (_, _) t -> int\n val is_empty : (_, _) t -> bool\n val iter : ('a, _) t -> f:('a -> unit) -> unit\n\n (** [fold t ~init ~f] returns [f (... f (f (f init e1) e2) e3 ...) en], where [e1..en]\n are the elements of [t]. *)\n val fold : ('a, _) t -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum\n\n (** [fold_result t ~init ~f] is a short-circuiting version of [fold] that runs in the\n [Result] monad. If [f] returns an [Error _], that value is returned without any\n additional invocations of [f]. *)\n val fold_result\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n (** [fold_until t ~init ~f ~finish] is a short-circuiting version of [fold]. If [f]\n returns [Stop _] the computation ceases and results in that value. If [f] returns\n [Continue _], the fold will proceed. If [f] never returns [Stop _], the final result\n is computed by [finish].\n\n Example:\n\n {[\n type maybe_negative =\n | Found_negative of int\n | All_nonnegative of { sum : int }\n\n (** [first_neg_or_sum list] returns the first negative number in [list], if any,\n otherwise returns the sum of the list. *)\n let first_neg_or_sum =\n List.fold_until ~init:0\n ~f:(fun sum x ->\n if x < 0\n then Stop (Found_negative x)\n else Continue (sum + x))\n ~finish:(fun sum -> All_nonnegative { sum })\n ;;\n\n let x = first_neg_or_sum [1; 2; 3; 4; 5]\n val x : maybe_negative = All_nonnegative {sum = 15}\n\n let y = first_neg_or_sum [1; 2; -3; 4; 5]\n val y : maybe_negative = Found_negative -3\n ]} *)\n val fold_until\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n (** Returns [true] if and only if there exists an element for which the provided\n function evaluates to [true]. This is a short-circuiting operation. *)\n val exists : ('a, _) t -> f:('a -> bool) -> bool\n\n (** Returns [true] if and only if the provided function evaluates to [true] for all\n elements. This is a short-circuiting operation. *)\n val for_all : ('a, _) t -> f:('a -> bool) -> bool\n\n (** Returns the number of elements for which the provided function evaluates to true. *)\n val count : ('a, _) t -> f:('a -> bool) -> int\n\n (** Returns the sum of [f i] for all [i] in the container. *)\n val sum : (module Summable with type t = 'sum) -> ('a, _) t -> f:('a -> 'sum) -> 'sum\n\n (** Returns as an [option] the first element for which [f] evaluates to true. *)\n val find : ('a, _) t -> f:('a -> bool) -> 'a option\n\n (** Returns the first evaluation of [f] that returns [Some], and returns [None] if there\n is no such element. *)\n val find_map : ('a, _) t -> f:('a -> 'b option) -> 'b option\n\n val to_list : ('a, _) t -> 'a list\n val to_array : ('a, _) t -> 'a array\n\n (** Returns a min (resp max) element from the collection using the provided [compare]\n function. In case of a tie, the first element encountered while traversing the\n collection is returned. The implementation uses [fold] so it has the same complexity\n as [fold]. Returns [None] iff the collection is empty. *)\n val min_elt : ('a, _) t -> compare:('a -> 'a -> int) -> 'a option\n\n val max_elt : ('a, _) t -> compare:('a -> 'a -> int) -> 'a option\nend\n\nmodule type S1_phantom = sig\n type ('a, +'phantom) t\n\n include S1_phantom_invariant with type ('a, 'phantom) t := ('a, 'phantom) t\nend\n\nmodule type Generic = sig\n type 'a t\n type 'a elt\n\n val length : _ t -> int\n val is_empty : _ t -> bool\n val iter : 'a t -> f:('a elt -> unit) -> unit\n val fold : 'a t -> init:'accum -> f:('accum -> 'a elt -> 'accum) -> 'accum\n\n val fold_result\n : 'a t\n -> init:'accum\n -> f:('accum -> 'a elt -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n val fold_until\n : 'a t\n -> init:'accum\n -> f:('accum -> 'a elt -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n val exists : 'a t -> f:('a elt -> bool) -> bool\n val for_all : 'a t -> f:('a elt -> bool) -> bool\n val count : 'a t -> f:('a elt -> bool) -> int\n val sum : (module Summable with type t = 'sum) -> 'a t -> f:('a elt -> 'sum) -> 'sum\n val find : 'a t -> f:('a elt -> bool) -> 'a elt option\n val find_map : 'a t -> f:('a elt -> 'b option) -> 'b option\n val to_list : 'a t -> 'a elt list\n val to_array : 'a t -> 'a elt array\n val min_elt : 'a t -> compare:('a elt -> 'a elt -> int) -> 'a elt option\n val max_elt : 'a t -> compare:('a elt -> 'a elt -> int) -> 'a elt option\nend\n\nmodule type Generic_phantom = sig\n type ('a, 'phantom) t\n type 'a elt\n\n val length : (_, _) t -> int\n val is_empty : (_, _) t -> bool\n val iter : ('a, _) t -> f:('a elt -> unit) -> unit\n val fold : ('a, _) t -> init:'accum -> f:('accum -> 'a elt -> 'accum) -> 'accum\n\n val fold_result\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a elt -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n val fold_until\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a elt -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n val exists : ('a, _) t -> f:('a elt -> bool) -> bool\n val for_all : ('a, _) t -> f:('a elt -> bool) -> bool\n val count : ('a, _) t -> f:('a elt -> bool) -> int\n\n val sum\n : (module Summable with type t = 'sum)\n -> ('a, _) t\n -> f:('a elt -> 'sum)\n -> 'sum\n\n val find : ('a, _) t -> f:('a elt -> bool) -> 'a elt option\n val find_map : ('a, _) t -> f:('a elt -> 'b option) -> 'b option\n val to_list : ('a, _) t -> 'a elt list\n val to_array : ('a, _) t -> 'a elt array\n val min_elt : ('a, _) t -> compare:('a elt -> 'a elt -> int) -> 'a elt option\n val max_elt : ('a, _) t -> compare:('a elt -> 'a elt -> int) -> 'a elt option\nend\n\nmodule type Make_gen_arg = sig\n type 'a t\n type 'a elt\n\n val fold : 'a t -> init:'accum -> f:('accum -> 'a elt -> 'accum) -> 'accum\n\n (** The [iter] argument to [Container.Make] specifies how to implement the\n container's [iter] function. [`Define_using_fold] means to define [iter]\n via:\n\n {[\n iter t ~f = Container.iter ~fold t ~f\n ]}\n\n [`Custom] overrides the default implementation, presumably with something more\n efficient. Several other functions returned by [Container.Make] are defined in\n terms of [iter], so passing in a more efficient [iter] will improve their efficiency\n as well. *)\n val iter : [ `Define_using_fold | `Custom of 'a t -> f:('a elt -> unit) -> unit ]\n\n (** The [length] argument to [Container.Make] specifies how to implement the\n container's [length] function. [`Define_using_fold] means to define\n [length] via:\n\n {[\n length t ~f = Container.length ~fold t ~f\n ]}\n\n [`Custom] overrides the default implementation, presumably with something more\n efficient. Several other functions returned by [Container.Make] are defined in\n terms of [length], so passing in a more efficient [length] will improve their\n efficiency as well. *)\n val length : [ `Define_using_fold | `Custom of 'a t -> int ]\nend\n\nmodule type Make_arg = Make_gen_arg with type 'a elt := 'a Monad.Ident.t\n\nmodule type Make0_arg = sig\n module Elt : sig\n type t\n\n val equal : t -> t -> bool\n end\n\n type t\n\n val fold : t -> init:'accum -> f:('accum -> Elt.t -> 'accum) -> 'accum\n val iter : [ `Define_using_fold | `Custom of t -> f:(Elt.t -> unit) -> unit ]\n val length : [ `Define_using_fold | `Custom of t -> int ]\nend\n\nmodule type Container = sig\n include module type of struct\n include Export\n end\n\n module type S0 = S0\n module type S0_phantom = S0_phantom\n module type S1 = S1\n module type S1_phantom_invariant = S1_phantom_invariant\n module type S1_phantom = S1_phantom\n module type Generic = Generic\n module type Generic_phantom = Generic_phantom\n module type Summable = Summable\n\n (** Generic definitions of container operations in terms of [fold].\n\n E.g.: [iter ~fold t ~f = fold t ~init:() ~f:(fun () a -> f a)]. *)\n\n type ('t, 'a, 'accum) fold = 't -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum\n type ('t, 'a) iter = 't -> f:('a -> unit) -> unit\n type 't length = 't -> int\n\n val iter : fold:('t, 'a, unit) fold -> ('t, 'a) iter\n val count : fold:('t, 'a, int) fold -> 't -> f:('a -> bool) -> int\n\n val min_elt\n : fold:('t, 'a, 'a option) fold\n -> 't\n -> compare:('a -> 'a -> int)\n -> 'a option\n\n val max_elt\n : fold:('t, 'a, 'a option) fold\n -> 't\n -> compare:('a -> 'a -> int)\n -> 'a option\n\n val length : fold:('t, _, int) fold -> 't -> int\n val to_list : fold:('t, 'a, 'a list) fold -> 't -> 'a list\n\n val sum\n : fold:('t, 'a, 'sum) fold\n -> (module Summable with type t = 'sum)\n -> 't\n -> f:('a -> 'sum)\n -> 'sum\n\n val fold_result\n : fold:('t, 'a, 'b) fold\n -> init:'b\n -> f:('b -> 'a -> ('b, 'e) Result.t)\n -> 't\n -> ('b, 'e) Result.t\n\n val fold_until\n : fold:('t, 'a, 'b) fold\n -> init:'b\n -> f:('b -> 'a -> ('b, 'final) Continue_or_stop.t)\n -> finish:('b -> 'final)\n -> 't\n -> 'final\n\n (** Generic definitions of container operations in terms of [iter] and [length]. *)\n val is_empty : iter:('t, 'a) iter -> 't -> bool\n\n val exists : iter:('t, 'a) iter -> 't -> f:('a -> bool) -> bool\n val for_all : iter:('t, 'a) iter -> 't -> f:('a -> bool) -> bool\n val find : iter:('t, 'a) iter -> 't -> f:('a -> bool) -> 'a option\n val find_map : iter:('t, 'a) iter -> 't -> f:('a -> 'b option) -> 'b option\n val to_array : length:'t length -> iter:('t, 'a) iter -> 't -> 'a array\n\n (** The idiom for using [Container.Make] is to bind the resulting module and to\n explicitly import each of the functions that one wants:\n\n {[\n module C = Container.Make (struct ... end)\n let count = C.count\n let exists = C.exists\n let find = C.find\n (* ... *)\n ]}\n\n This is preferable to:\n\n {[\n include Container.Make (struct ... end)\n ]}\n\n because the [include] makes it too easy to shadow specialized implementations of\n container functions ([length] being a common one).\n\n [Container.Make0] is like [Container.Make], but for monomorphic containers like\n [string]. *)\n module Make (T : Make_arg) : S1 with type 'a t := 'a T.t\n\n module Make0 (T : Make0_arg) : S0 with type t := T.t and type elt := T.Elt.t\nend\n","open! Import\nmodule Array = Array0\nmodule List = List0\ninclude Container_intf\n\nlet with_return = With_return.with_return\n\ntype ('t, 'a, 'accum) fold = 't -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum\ntype ('t, 'a) iter = 't -> f:('a -> unit) -> unit\ntype 't length = 't -> int\n\nlet iter ~fold t ~f = fold t ~init:() ~f:(fun () a -> f a)\nlet count ~fold t ~f = fold t ~init:0 ~f:(fun n a -> if f a then n + 1 else n)\n\nlet sum (type a) ~fold (module M : Summable with type t = a) t ~f =\n fold t ~init:M.zero ~f:(fun n a -> M.( + ) n (f a))\n;;\n\nlet fold_result ~fold ~init ~f t =\n with_return (fun { return } ->\n Result.Ok\n (fold t ~init ~f:(fun acc item ->\n match f acc item with\n | Result.Ok x -> x\n | Error _ as e -> return e)))\n;;\n\nlet fold_until ~fold ~init ~f ~finish t =\n with_return (fun { return } ->\n finish\n (fold t ~init ~f:(fun acc item ->\n match f acc item with\n | Continue_or_stop.Continue x -> x\n | Stop x -> return x)))\n;;\n\nlet min_elt ~fold t ~compare =\n fold t ~init:None ~f:(fun acc elt ->\n match acc with\n | None -> Some elt\n | Some min -> if compare min elt > 0 then Some elt else acc)\n;;\n\nlet max_elt ~fold t ~compare =\n fold t ~init:None ~f:(fun acc elt ->\n match acc with\n | None -> Some elt\n | Some max -> if compare max elt < 0 then Some elt else acc)\n;;\n\nlet length ~fold c = fold c ~init:0 ~f:(fun acc _ -> acc + 1)\n\nlet is_empty ~iter c =\n with_return (fun r ->\n iter c ~f:(fun _ -> r.return false);\n true)\n;;\n\nlet exists ~iter c ~f =\n with_return (fun r ->\n iter c ~f:(fun x -> if f x then r.return true);\n false)\n;;\n\nlet for_all ~iter c ~f =\n with_return (fun r ->\n iter c ~f:(fun x -> if not (f x) then r.return false);\n true)\n;;\n\nlet find_map ~iter t ~f =\n with_return (fun r ->\n iter t ~f:(fun x ->\n match f x with\n | None -> ()\n | Some _ as res -> r.return res);\n None)\n;;\n\nlet find ~iter c ~f =\n with_return (fun r ->\n iter c ~f:(fun x -> if f x then r.return (Some x));\n None)\n;;\n\nlet to_list ~fold c = List.rev (fold c ~init:[] ~f:(fun acc x -> x :: acc))\n\nlet to_array ~length ~iter c =\n let array = ref [||] in\n let i = ref 0 in\n iter c ~f:(fun x ->\n if !i = 0 then array := Array.create ~len:(length c) x;\n !array.(!i) <- x;\n incr i);\n !array\n;;\n\nmodule Make_gen (T : Make_gen_arg) : sig\n include Generic with type 'a t := 'a T.t with type 'a elt := 'a T.elt\nend = struct\n let fold = T.fold\n\n let iter =\n match T.iter with\n | `Custom iter -> iter\n | `Define_using_fold -> fun t ~f -> iter ~fold t ~f\n ;;\n\n let length =\n match T.length with\n | `Custom length -> length\n | `Define_using_fold -> fun t -> length ~fold t\n ;;\n\n let is_empty t = is_empty ~iter t\n let sum m t = sum ~fold m t\n let count t ~f = count ~fold t ~f\n let exists t ~f = exists ~iter t ~f\n let for_all t ~f = for_all ~iter t ~f\n let find_map t ~f = find_map ~iter t ~f\n let find t ~f = find ~iter t ~f\n let to_list t = to_list ~fold t\n let to_array t = to_array ~length ~iter t\n let min_elt t ~compare = min_elt ~fold t ~compare\n let max_elt t ~compare = max_elt ~fold t ~compare\n let fold_result t ~init ~f = fold_result t ~fold ~init ~f\n let fold_until t ~init ~f ~finish = fold_until t ~fold ~init ~f ~finish\nend\n\nmodule Make (T : Make_arg) = struct\n include Make_gen (struct\n include T\n\n type 'a elt = 'a\n end)\n\n let mem t a ~equal = exists t ~f:(equal a)\nend\n\nmodule Make0 (T : Make0_arg) = struct\n include Make_gen (struct\n include (T : Make0_arg with type t := T.t with module Elt := T.Elt)\n\n type 'a t = T.t\n type 'a elt = T.Elt.t\n end)\n\n let mem t elt = exists t ~f:(T.Elt.equal elt)\nend\n\nopen T\n\n\n(* The following functors exist as a consistency check among all the various [S?]\n interfaces. They ensure that each particular [S?] is an instance of a more generic\n signature. *)\nmodule Check\n (T : T1)\n (Elt : T1)\n (M : Generic with type 'a t := 'a T.t with type 'a elt := 'a Elt.t) =\nstruct end\n\nmodule Check_S0 (M : S0) =\n Check\n (struct\n type 'a t = M.t\n end)\n (struct\n type 'a t = M.elt\n end)\n (M)\n\nmodule Check_S0_phantom (M : S0_phantom) =\n Check\n (struct\n type 'a t = 'a M.t\n end)\n (struct\n type 'a t = M.elt\n end)\n (M)\n\nmodule Check_S1 (M : S1) =\n Check\n (struct\n type 'a t = 'a M.t\n end)\n (struct\n type 'a t = 'a\n end)\n (M)\n\ntype phantom\n\nmodule Check_S1_phantom (M : S1_phantom) =\n Check\n (struct\n type 'a t = ('a, phantom) M.t\n end)\n (struct\n type 'a t = 'a\n end)\n (M)\n\nmodule Check_S1_phantom_invariant (M : S1_phantom_invariant) =\n Check\n (struct\n type 'a t = ('a, phantom) M.t\n end)\n (struct\n type 'a t = 'a\n end)\n (M)\n","open! Import\n\ntype 'a t = 'a lazy_t [@@deriving_inline sexp]\n\nlet t_of_sexp : 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t =\n lazy_t_of_sexp\n;;\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n sexp_of_lazy_t\n;;\n\n[@@@end]\n\ninclude (Caml.Lazy : module type of Caml.Lazy with type 'a t := 'a t)\n\nlet map t ~f = lazy (f (force t))\n\nlet compare compare_a t1 t2 =\n if phys_equal t1 t2 then 0 else compare_a (force t1) (force t2)\n;;\n\nlet hash_fold_t = Hash.Builtin.hash_fold_lazy_t\n\ninclude Monad.Make (struct\n type nonrec 'a t = 'a t\n\n let return x = from_val x\n let bind t ~f = lazy (force (f (force t)))\n let map = map\n let map = `Custom map\n end)\n\nmodule T_unforcing = struct\n type nonrec 'a t = 'a t\n\n let sexp_of_t sexp_of_a t =\n if is_val t then sexp_of_a (force t) else sexp_of_string \"\"\n ;;\nend\n","open! Import\n\nmodule type Basic = sig\n type 'a t\n\n val bind : 'a t -> f:('a -> 'b t) -> 'b t\n val return : 'a -> 'a t\n\n (** The following identities ought to hold (for some value of =):\n\n - [return x >>= f = f x]\n - [t >>= fun x -> return x = t]\n - [(t >>= f) >>= g = t >>= fun x -> (f x >>= g)]\n\n Note: [>>=] is the infix notation for [bind]) *)\n\n (** The [map] argument to [Monad.Make] says how to implement the monad's [map] function.\n [`Define_using_bind] means to define [map t ~f = bind t ~f:(fun a -> return (f a))].\n [`Custom] overrides the default implementation, presumably with something more\n efficient.\n\n Some other functions returned by [Monad.Make] are defined in terms of [map], so\n passing in a more efficient [map] will improve their efficiency as well. *)\n val map : [ `Define_using_bind | `Custom of 'a t -> f:('a -> 'b) -> 'b t ]\nend\n\nmodule type Infix = sig\n type 'a t\n\n (** [t >>= f] returns a computation that sequences the computations represented by two\n monad elements. The resulting computation first does [t] to yield a value [v], and\n then runs the computation returned by [f v]. *)\n val ( >>= ) : 'a t -> ('a -> 'b t) -> 'b t\n\n (** [t >>| f] is [t >>= (fun a -> return (f a))]. *)\n val ( >>| ) : 'a t -> ('a -> 'b) -> 'b t\nend\n\n(** Opening a module of this type allows one to use the [%bind] and [%map] syntax\n extensions defined by ppx_let, and brings [return] into scope. *)\nmodule type Syntax = sig\n type 'a t\n\n module Let_syntax : sig\n (** These are convenient to have in scope when programming with a monad: *)\n\n val return : 'a -> 'a t\n\n include Infix with type 'a t := 'a t\n\n module Let_syntax : sig\n val return : 'a -> 'a t\n val bind : 'a t -> f:('a -> 'b t) -> 'b t\n val map : 'a t -> f:('a -> 'b) -> 'b t\n val both : 'a t -> 'b t -> ('a * 'b) t\n\n module Open_on_rhs : sig end\n end\n end\nend\n\nmodule type S_without_syntax = sig\n type 'a t\n\n include Infix with type 'a t := 'a t\n module Monad_infix : Infix with type 'a t := 'a t\n\n (** [bind t ~f] = [t >>= f] *)\n val bind : 'a t -> f:('a -> 'b t) -> 'b t\n\n (** [return v] returns the (trivial) computation that returns v. *)\n val return : 'a -> 'a t\n\n (** [map t ~f] is t >>| f. *)\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n (** [join t] is [t >>= (fun t' -> t')]. *)\n val join : 'a t t -> 'a t\n\n (** [ignore_m t] is [map t ~f:(fun _ -> ())]. [ignore_m] used to be called [ignore],\n but we decided that was a bad name, because it shadowed the widely used\n [Caml.ignore]. Some monads still do [let ignore = ignore_m] for historical\n reasons. *)\n val ignore_m : 'a t -> unit t\n\n val all : 'a t list -> 'a list t\n\n (** Like [all], but ensures that every monadic value in the list produces a unit value,\n all of which are discarded rather than being collected into a list. *)\n val all_unit : unit t list -> unit t\nend\n\nmodule type S = sig\n type 'a t\n\n include S_without_syntax with type 'a t := 'a t\n include Syntax with type 'a t := 'a t\nend\n\n(** Multi parameter monad. The second parameter gets unified across all the computation.\n This is used to encode monads working on a multi parameter data structure like\n ([('a,'b) result]). *)\nmodule type Basic2 = sig\n type ('a, 'e) t\n\n val bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t\n val map : [ `Define_using_bind | `Custom of ('a, 'e) t -> f:('a -> 'b) -> ('b, 'e) t ]\n val return : 'a -> ('a, _) t\nend\n\n(** Same as Infix, except the monad type has two arguments. The second is always just\n passed through. *)\nmodule type Infix2 = sig\n type ('a, 'e) t\n\n val ( >>= ) : ('a, 'e) t -> ('a -> ('b, 'e) t) -> ('b, 'e) t\n val ( >>| ) : ('a, 'e) t -> ('a -> 'b) -> ('b, 'e) t\nend\n\nmodule type Syntax2 = sig\n type ('a, 'e) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, _) t\n\n include Infix2 with type ('a, 'e) t := ('a, 'e) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, _) t\n val bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t\n val map : ('a, 'e) t -> f:('a -> 'b) -> ('b, 'e) t\n val both : ('a, 'e) t -> ('b, 'e) t -> ('a * 'b, 'e) t\n\n module Open_on_rhs : sig end\n end\n end\nend\n\n(** The same as S except the monad type has two arguments. The second is always just\n passed through. *)\nmodule type S2 = sig\n type ('a, 'e) t\n\n include Infix2 with type ('a, 'e) t := ('a, 'e) t\n include Syntax2 with type ('a, 'e) t := ('a, 'e) t\n module Monad_infix : Infix2 with type ('a, 'e) t := ('a, 'e) t\n\n val bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t\n val return : 'a -> ('a, _) t\n val map : ('a, 'e) t -> f:('a -> 'b) -> ('b, 'e) t\n val join : (('a, 'e) t, 'e) t -> ('a, 'e) t\n val ignore_m : (_, 'e) t -> (unit, 'e) t\n val all : ('a, 'e) t list -> ('a list, 'e) t\n val all_unit : (unit, 'e) t list -> (unit, 'e) t\nend\n\n(** Multi parameter monad. The second and third parameters get unified across all the\n computation. *)\nmodule type Basic3 = sig\n type ('a, 'd, 'e) t\n\n val bind : ('a, 'd, 'e) t -> f:('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n\n val map\n : [ `Define_using_bind | `Custom of ('a, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'd, 'e) t ]\n\n val return : 'a -> ('a, _, _) t\nend\n\n(** Same as Infix, except the monad type has three arguments. The second and third are\n always just passed through. *)\nmodule type Infix3 = sig\n type ('a, 'd, 'e) t\n\n val ( >>= ) : ('a, 'd, 'e) t -> ('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n val ( >>| ) : ('a, 'd, 'e) t -> ('a -> 'b) -> ('b, 'd, 'e) t\nend\n\nmodule type Syntax3 = sig\n type ('a, 'd, 'e) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, _, _) t\n\n include Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, _, _) t\n val bind : ('a, 'd, 'e) t -> f:('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n val map : ('a, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'd, 'e) t\n val both : ('a, 'd, 'e) t -> ('b, 'd, 'e) t -> ('a * 'b, 'd, 'e) t\n\n module Open_on_rhs : sig end\n end\n end\nend\n\n(** The same as S except the monad type has three arguments. The second and third are\n always just passed through. *)\nmodule type S3 = sig\n type ('a, 'd, 'e) t\n\n include Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n include Syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n module Monad_infix : Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n val bind : ('a, 'd, 'e) t -> f:('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n val return : 'a -> ('a, _, _) t\n val map : ('a, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'd, 'e) t\n val join : (('a, 'd, 'e) t, 'd, 'e) t -> ('a, 'd, 'e) t\n val ignore_m : (_, 'd, 'e) t -> (unit, 'd, 'e) t\n val all : ('a, 'd, 'e) t list -> ('a list, 'd, 'e) t\n val all_unit : (unit, 'd, 'e) t list -> (unit, 'd, 'e) t\nend\n\n(** Indexed monad, in the style of Atkey. The second and third parameters are composed\n across all computation. To see this more clearly, you can look at the type of bind:\n\n {[\n val bind : ('a, 'i, 'j) t -> f:('a -> ('b, 'j, 'k) t) -> ('b, 'i, 'k) t\n ]}\n\n and isolate some of the type variables to see their individual behaviors:\n\n {[\n val bind : 'a -> f:('a -> 'b ) -> 'b\n val bind : 'i, 'j -> 'j, 'k -> 'i, 'k\n ]}\n\n For more information on Atkey-style indexed monads, see:\n\n {v\n Parameterised Notions of Computation\n Robert Atkey\n http://bentnib.org/paramnotions-jfp.pdf\n v} *)\nmodule type Basic_indexed = sig\n type ('a, 'i, 'j) t\n\n val bind : ('a, 'i, 'j) t -> f:('a -> ('b, 'j, 'k) t) -> ('b, 'i, 'k) t\n\n val map\n : [ `Define_using_bind | `Custom of ('a, 'i, 'j) t -> f:('a -> 'b) -> ('b, 'i, 'j) t ]\n\n val return : 'a -> ('a, 'i, 'i) t\nend\n\n(** Same as Infix, except the monad type has three arguments. The second and third are\n compose across all computation. *)\nmodule type Infix_indexed = sig\n type ('a, 'i, 'j) t\n\n val ( >>= ) : ('a, 'i, 'j) t -> ('a -> ('b, 'j, 'k) t) -> ('b, 'i, 'k) t\n val ( >>| ) : ('a, 'i, 'j) t -> ('a -> 'b) -> ('b, 'i, 'j) t\nend\n\nmodule type Syntax_indexed = sig\n type ('a, 'i, 'j) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, 'i, 'i) t\n\n include Infix_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) t\n\n module Let_syntax : sig\n val return : 'a -> ('a, 'i, 'i) t\n val bind : ('a, 'i, 'j) t -> f:('a -> ('b, 'j, 'k) t) -> ('b, 'i, 'k) t\n val map : ('a, 'i, 'j) t -> f:('a -> 'b) -> ('b, 'i, 'j) t\n val both : ('a, 'i, 'j) t -> ('b, 'j, 'k) t -> ('a * 'b, 'i, 'k) t\n\n module Open_on_rhs : sig end\n end\n end\nend\n\n(** The same as S except the monad type has three arguments. The second and third are\n composed across all computation. *)\nmodule type S_indexed = sig\n type ('a, 'i, 'j) t\n\n include Infix_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) t\n include Syntax_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) t\n module Monad_infix : Infix_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) t\n\n val bind : ('a, 'i, 'j) t -> f:('a -> ('b, 'j, 'k) t) -> ('b, 'i, 'k) t\n val return : 'a -> ('a, 'i, 'i) t\n val map : ('a, 'i, 'j) t -> f:('a -> 'b) -> ('b, 'i, 'j) t\n val join : (('a, 'j, 'k) t, 'i, 'j) t -> ('a, 'i, 'k) t\n val ignore_m : (_, 'i, 'j) t -> (unit, 'i, 'j) t\n val all : ('a, 'i, 'i) t list -> ('a list, 'i, 'i) t\n val all_unit : (unit, 'i, 'i) t list -> (unit, 'i, 'i) t\nend\n\nmodule S_to_S2 (X : S) : S2 with type ('a, 'e) t = 'a X.t = struct\n type ('a, 'e) t = 'a X.t\n\n include (X : S with type 'a t := 'a X.t)\nend\n\nmodule S2_to_S3 (X : S2) : S3 with type ('a, 'd, 'e) t = ('a, 'd) X.t = struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : S2 with type ('a, 'd) t := ('a, 'd) X.t)\nend\n\nmodule S_to_S_indexed (X : S) : S_indexed with type ('a, 'i, 'j) t = 'a X.t = struct\n type ('a, 'i, 'j) t = 'a X.t\n\n include (X : S with type 'a t := 'a X.t)\nend\n\nmodule S2_to_S (X : S2) : S with type 'a t = ('a, unit) X.t = struct\n type 'a t = ('a, unit) X.t\n\n include (X : S2 with type ('a, 'e) t := ('a, 'e) X.t)\nend\n\nmodule S3_to_S2 (X : S3) : S2 with type ('a, 'e) t = ('a, 'e, unit) X.t = struct\n type ('a, 'e) t = ('a, 'e, unit) X.t\n\n include (X : S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t)\nend\n\nmodule S_indexed_to_S2 (X : S_indexed) : S2 with type ('a, 'e) t = ('a, 'e, 'e) X.t =\nstruct\n type ('a, 'e) t = ('a, 'e, 'e) X.t\n\n include (X : S_indexed with type ('a, 'i, 'j) t := ('a, 'i, 'j) X.t)\nend\n\nmodule type Monad = sig\n (** A monad is an abstraction of the concept of sequencing of computations. A value of\n type ['a monad] represents a computation that returns a value of type ['a]. *)\n\n module type Basic = Basic\n module type Basic2 = Basic2\n module type Basic3 = Basic3\n module type Basic_indexed = Basic_indexed\n module type Infix = Infix\n module type Infix2 = Infix2\n module type Infix3 = Infix3\n module type Infix_indexed = Infix_indexed\n module type Syntax = Syntax\n module type Syntax2 = Syntax2\n module type Syntax3 = Syntax3\n module type Syntax_indexed = Syntax_indexed\n module type S_without_syntax = S_without_syntax\n module type S = S\n module type S2 = S2\n module type S3 = S3\n module type S_indexed = S_indexed\n\n module Make (X : Basic) : S with type 'a t := 'a X.t\n module Make2 (X : Basic2) : S2 with type ('a, 'e) t := ('a, 'e) X.t\n module Make3 (X : Basic3) : S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t\n\n module Make_indexed (X : Basic_indexed) :\n S_indexed with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t\n\n module Ident : S with type 'a t = 'a\nend\n","open! Import\n\nlet const c _ = c\n\nexternal ignore : _ -> unit = \"%ignore\"\n\n(* this has the same behavior as [Caml.ignore] *)\n\nlet non f x = not (f x)\n\nlet forever f =\n let rec forever () =\n f ();\n forever ()\n in\n try forever () with\n | e -> e\n;;\n\nexternal id : 'a -> 'a = \"%identity\"\nexternal ( |> ) : 'a -> ('a -> 'b) -> 'b = \"%revapply\"\n\n(* The typical use case for these functions is to pass in functional arguments and get\n functions as a result. *)\nlet compose f g x = f (g x)\nlet flip f x y = f y x\nlet rec apply_n_times ~n f x = if n <= 0 then x else apply_n_times ~n:(n - 1) f (f x)\n","open! Import\nmodule Array = Array0\nmodule Either = Either0\n\n\ninclude List1\n\n(* This itself includes [List0]. *)\n\nlet invalid_argf = Printf.invalid_argf\n\nmodule T = struct\n type 'a t = 'a list [@@deriving_inline sexp, sexp_grammar]\n\n let t_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t\n =\n list_of_sexp\n ;;\n\n let sexp_of_t :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t\n =\n sexp_of_list\n ;;\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"list\" ]\n ; ggid = \"j\\132);\\135qH\\158\\135\\222H\\001\\007\\004\\158\\218\"\n ; types =\n [ \"t\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ])) ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ list_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"list.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\nend\n\nmodule Or_unequal_lengths = struct\n type 'a t =\n | Ok of 'a\n | Unequal_lengths\n [@@deriving_inline compare, sexp_of]\n\n let compare : 'a. ('a -> 'a -> int) -> 'a t -> 'a t -> int =\n fun _cmp__a a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match a__001_, b__002_ with\n | Ok _a__003_, Ok _b__004_ -> _cmp__a _a__003_ _b__004_\n | Ok _, _ -> -1\n | _, Ok _ -> 1\n | Unequal_lengths, Unequal_lengths -> 0)\n ;;\n\n let sexp_of_t\n : type a. (a -> Ppx_sexp_conv_lib.Sexp.t) -> a t -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a -> function\n | Ok v0 ->\n let v0 = _of_a v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Ok\"; v0 ]\n | Unequal_lengths -> Ppx_sexp_conv_lib.Sexp.Atom \"Unequal_lengths\"\n ;;\n\n [@@@end]\nend\n\ninclude T\n\nlet invariant f t = iter t ~f\nlet of_list t = t\n\nlet range' ~compare ~stride ?(start = `inclusive) ?(stop = `exclusive) start_i stop_i =\n let next_i = stride start_i in\n let order x y = Ordering.of_int (compare x y) in\n let raise_stride_cannot_return_same_value () =\n invalid_arg \"List.range': stride function cannot return the same value\"\n in\n let initial_stride_order =\n match order start_i next_i with\n | Equal -> raise_stride_cannot_return_same_value ()\n | Less -> `Less\n | Greater -> `Greater\n in\n let rec loop i accum =\n let i_to_stop_order = order i stop_i in\n match i_to_stop_order, initial_stride_order with\n | Less, `Less | Greater, `Greater ->\n (* haven't yet reached [stop_i]. Continue. *)\n let next_i = stride i in\n (match order i next_i, initial_stride_order with\n | Equal, _ -> raise_stride_cannot_return_same_value ()\n | Less, `Greater | Greater, `Less ->\n invalid_arg \"List.range': stride function cannot change direction\"\n | Less, `Less | Greater, `Greater -> loop next_i (i :: accum))\n | Less, `Greater | Greater, `Less ->\n (* stepped past [stop_i]. Finished. *)\n accum\n | Equal, _ ->\n (* reached [stop_i]. Finished. *)\n (match stop with\n | `inclusive -> i :: accum\n | `exclusive -> accum)\n in\n let start_i =\n match start with\n | `inclusive -> start_i\n | `exclusive -> next_i\n in\n rev (loop start_i [])\n;;\n\nlet range ?(stride = 1) ?(start = `inclusive) ?(stop = `exclusive) start_i stop_i =\n if stride = 0 then invalid_arg \"List.range: stride must be non-zero\";\n range' ~compare ~stride:(fun x -> x + stride) ~start ~stop start_i stop_i\n;;\n\nlet hd t =\n match t with\n | [] -> None\n | x :: _ -> Some x\n;;\n\nlet tl t =\n match t with\n | [] -> None\n | _ :: t' -> Some t'\n;;\n\nlet nth t n =\n if n < 0\n then None\n else (\n let rec nth_aux t n =\n match t with\n | [] -> None\n | a :: t -> if n = 0 then Some a else nth_aux t (n - 1)\n in\n nth_aux t n)\n;;\n\nlet nth_exn t n =\n match nth t n with\n | None -> invalid_argf \"List.nth_exn %d called on list of length %d\" n (length t) ()\n | Some a -> a\n;;\n\nlet unordered_append l1 l2 =\n match l1, l2 with\n | [], l | l, [] -> l\n | _ -> rev_append l1 l2\n;;\n\nlet check_length2_exn name l1 l2 =\n let n1 = length l1 in\n let n2 = length l2 in\n if n1 <> n2 then invalid_argf \"length mismatch in %s: %d <> %d\" name n1 n2 ()\n;;\n\nlet check_length3_exn name l1 l2 l3 =\n let n1 = length l1 in\n let n2 = length l2 in\n let n3 = length l3 in\n if n1 <> n2 || n2 <> n3\n then invalid_argf \"length mismatch in %s: %d <> %d || %d <> %d\" name n1 n2 n2 n3 ()\n;;\n\nlet check_length2 l1 l2 ~f =\n if length l1 <> length l2 then Or_unequal_lengths.Unequal_lengths else Ok (f l1 l2)\n;;\n\nlet check_length3 l1 l2 l3 ~f =\n let n1 = length l1 in\n let n2 = length l2 in\n let n3 = length l3 in\n if n1 <> n2 || n2 <> n3 then Or_unequal_lengths.Unequal_lengths else Ok (f l1 l2 l3)\n;;\n\nlet iter2 l1 l2 ~f = check_length2 l1 l2 ~f:(iter2_ok ~f)\n\nlet iter2_exn l1 l2 ~f =\n check_length2_exn \"iter2_exn\" l1 l2;\n iter2_ok l1 l2 ~f\n;;\n\nlet rev_map2 l1 l2 ~f = check_length2 l1 l2 ~f:(rev_map2_ok ~f)\n\nlet rev_map2_exn l1 l2 ~f =\n check_length2_exn \"rev_map2_exn\" l1 l2;\n rev_map2_ok l1 l2 ~f\n;;\n\nlet fold2 l1 l2 ~init ~f = check_length2 l1 l2 ~f:(fold2_ok ~init ~f)\n\nlet fold2_exn l1 l2 ~init ~f =\n check_length2_exn \"fold2_exn\" l1 l2;\n fold2_ok l1 l2 ~init ~f\n;;\n\nlet for_all2 l1 l2 ~f = check_length2 l1 l2 ~f:(for_all2_ok ~f)\n\nlet for_all2_exn l1 l2 ~f =\n check_length2_exn \"for_all2_exn\" l1 l2;\n for_all2_ok l1 l2 ~f\n;;\n\nlet exists2 l1 l2 ~f = check_length2 l1 l2 ~f:(exists2_ok ~f)\n\nlet exists2_exn l1 l2 ~f =\n check_length2_exn \"exists2_exn\" l1 l2;\n exists2_ok l1 l2 ~f\n;;\n\nlet mem t a ~equal =\n let rec loop equal a = function\n | [] -> false\n | b :: bs -> equal a b || loop equal a bs\n in\n loop equal a t\n;;\n\n(* This is a copy of the code from the standard library, with an extra eta-expansion to\n avoid creating partial closures (showed up for [filter]) in profiling). *)\nlet rev_filter t ~f =\n let rec find ~f accu = function\n | [] -> accu\n | x :: l -> if f x then find ~f (x :: accu) l else find ~f accu l\n in\n find ~f [] t\n;;\n\nlet filter t ~f = rev (rev_filter t ~f)\n\nlet find_map t ~f =\n let rec loop = function\n | [] -> None\n | x :: l ->\n (match f x with\n | None -> loop l\n | Some _ as r -> r)\n in\n loop t\n;;\n\nlet find_map_exn =\n let not_found = Not_found_s (Atom \"List.find_map_exn: not found\") in\n let find_map_exn t ~f =\n match find_map t ~f with\n | None -> raise not_found\n | Some x -> x\n in\n (* named to preserve symbol in compiled binary *)\n find_map_exn\n;;\n\nlet find t ~f =\n let rec loop = function\n | [] -> None\n | x :: l -> if f x then Some x else loop l\n in\n loop t\n;;\n\nlet find_exn =\n let not_found = Not_found_s (Atom \"List.find_exn: not found\") in\n let rec find_exn t ~f =\n match t with\n | [] -> raise not_found\n | x :: t -> if f x then x else find_exn t ~f\n in\n (* named to preserve symbol in compiled binary *)\n find_exn\n;;\n\nlet findi t ~f =\n let rec loop i t =\n match t with\n | [] -> None\n | x :: l -> if f i x then Some (i, x) else loop (i + 1) l\n in\n loop 0 t\n;;\n\nlet find_mapi t ~f =\n let rec loop i t =\n match t with\n | [] -> None\n | x :: l ->\n (match f i x with\n | Some _ as result -> result\n | None -> loop (i + 1) l)\n in\n loop 0 t\n;;\n\nlet find_mapi_exn =\n let not_found = Not_found_s (Atom \"List.find_mapi_exn: not found\") in\n let find_mapi_exn t ~f =\n match find_mapi t ~f with\n | None -> raise not_found\n | Some x -> x\n in\n (* named to preserve symbol in compiled binary *)\n find_mapi_exn\n;;\n\nlet for_alli t ~f =\n let rec loop i t =\n match t with\n | [] -> true\n | hd :: tl -> f i hd && loop (i + 1) tl\n in\n loop 0 t\n;;\n\nlet existsi t ~f =\n let rec loop i t =\n match t with\n | [] -> false\n | hd :: tl -> f i hd || loop (i + 1) tl\n in\n loop 0 t\n;;\n\n(** For the container interface. *)\nlet fold_left = fold\n\nlet to_array = Array.of_list\nlet to_list t = t\n\n(** Tail recursive versions of standard [List] module *)\n\nlet slow_append l1 l2 = rev_append (rev l1) l2\n\n(* There are a few optimized list operations here, including append and map. There are\n basically two optimizations in play: loop unrolling, and dynamic switching between\n stack and heap allocation.\n\n The loop-unrolling is straightforward, we just unroll 5 levels of the loop. This makes\n each iteration faster, and also reduces the number of stack frames consumed per list\n element.\n\n The dynamic switching is done by counting the number of stack frames, and then\n switching to the \"slow\" implementation when we exceed a given limit. This means that\n short lists use the fast stack-allocation method, and long lists use a slower one that\n doesn't require stack space. *)\nlet rec count_append l1 l2 count =\n match l2 with\n | [] -> l1\n | _ ->\n (match l1 with\n | [] -> l2\n | [ x1 ] -> x1 :: l2\n | [ x1; x2 ] -> x1 :: x2 :: l2\n | [ x1; x2; x3 ] -> x1 :: x2 :: x3 :: l2\n | [ x1; x2; x3; x4 ] -> x1 :: x2 :: x3 :: x4 :: l2\n | x1 :: x2 :: x3 :: x4 :: x5 :: tl ->\n x1\n :: x2\n :: x3\n :: x4\n :: x5\n :: (if count > 1000 then slow_append tl l2 else count_append tl l2 (count + 1)))\n;;\n\nlet append l1 l2 = count_append l1 l2 0\nlet slow_map l ~f = rev (rev_map l ~f)\n\nlet rec count_map ~f l ctr =\n match l with\n | [] -> []\n | [ x1 ] ->\n let f1 = f x1 in\n [ f1 ]\n | [ x1; x2 ] ->\n let f1 = f x1 in\n let f2 = f x2 in\n [ f1; f2 ]\n | [ x1; x2; x3 ] ->\n let f1 = f x1 in\n let f2 = f x2 in\n let f3 = f x3 in\n [ f1; f2; f3 ]\n | [ x1; x2; x3; x4 ] ->\n let f1 = f x1 in\n let f2 = f x2 in\n let f3 = f x3 in\n let f4 = f x4 in\n [ f1; f2; f3; f4 ]\n | x1 :: x2 :: x3 :: x4 :: x5 :: tl ->\n let f1 = f x1 in\n let f2 = f x2 in\n let f3 = f x3 in\n let f4 = f x4 in\n let f5 = f x5 in\n f1\n :: f2\n :: f3\n :: f4\n :: f5\n :: (if ctr > 1000 then slow_map ~f tl else count_map ~f tl (ctr + 1))\n;;\n\nlet map l ~f = count_map ~f l 0\n\nlet folding_map t ~init ~f =\n let acc = ref init in\n map t ~f:(fun x ->\n let new_acc, y = f !acc x in\n acc := new_acc;\n y)\n;;\n\nlet fold_map t ~init ~f =\n let acc = ref init in\n let result =\n map t ~f:(fun x ->\n let new_acc, y = f !acc x in\n acc := new_acc;\n y)\n in\n !acc, result\n;;\n\nlet ( >>| ) l f = map l ~f\nlet map2_ok l1 l2 ~f = rev (rev_map2_ok l1 l2 ~f)\nlet map2 l1 l2 ~f = check_length2 l1 l2 ~f:(map2_ok ~f)\n\nlet map2_exn l1 l2 ~f =\n check_length2_exn \"map2_exn\" l1 l2;\n map2_ok l1 l2 ~f\n;;\n\nlet rev_map3_ok l1 l2 l3 ~f =\n let rec loop l1 l2 l3 ac =\n match l1, l2, l3 with\n | [], [], [] -> ac\n | x1 :: l1, x2 :: l2, x3 :: l3 -> loop l1 l2 l3 (f x1 x2 x3 :: ac)\n | _ -> assert false\n in\n loop l1 l2 l3 []\n;;\n\nlet rev_map3 l1 l2 l3 ~f = check_length3 l1 l2 l3 ~f:(rev_map3_ok ~f)\n\nlet rev_map3_exn l1 l2 l3 ~f =\n check_length3_exn \"rev_map3_exn\" l1 l2 l3;\n rev_map3_ok l1 l2 l3 ~f\n;;\n\nlet map3_ok l1 l2 l3 ~f = rev (rev_map3_ok l1 l2 l3 ~f)\nlet map3 l1 l2 l3 ~f = check_length3 l1 l2 l3 ~f:(map3_ok ~f)\n\nlet map3_exn l1 l2 l3 ~f =\n check_length3_exn \"map3_exn\" l1 l2 l3;\n map3_ok l1 l2 l3 ~f\n;;\n\nlet rec rev_map_append l1 l2 ~f =\n match l1 with\n | [] -> l2\n | h :: t -> rev_map_append ~f t (f h :: l2)\n;;\n\nlet fold_right l ~f ~init =\n match l with\n | [] -> init (* avoid the allocation of [~f] below *)\n | _ -> fold ~f:(fun a b -> f b a) ~init (rev l)\n;;\n\nlet unzip list =\n let rec loop list l1 l2 =\n match list with\n | [] -> rev l1, rev l2\n | (x, y) :: tl -> loop tl (x :: l1) (y :: l2)\n in\n loop list [] []\n;;\n\nlet unzip3 list =\n let rec loop list l1 l2 l3 =\n match list with\n | [] -> rev l1, rev l2, rev l3\n | (x, y, z) :: tl -> loop tl (x :: l1) (y :: l2) (z :: l3)\n in\n loop list [] [] []\n;;\n\nlet zip_exn l1 l2 =\n check_length2_exn \"zip_exn\" l1 l2;\n map2_ok ~f:(fun a b -> a, b) l1 l2\n;;\n\nlet zip l1 l2 = map2 ~f:(fun a b -> a, b) l1 l2\n\n(** Additional list operations *)\n\nlet rev_mapi l ~f =\n let rec loop i acc = function\n | [] -> acc\n | h :: t -> loop (i + 1) (f i h :: acc) t\n in\n loop 0 [] l\n;;\n\nlet mapi l ~f = rev (rev_mapi l ~f)\n\nlet folding_mapi t ~init ~f =\n let acc = ref init in\n mapi t ~f:(fun i x ->\n let new_acc, y = f i !acc x in\n acc := new_acc;\n y)\n;;\n\nlet fold_mapi t ~init ~f =\n let acc = ref init in\n let result =\n mapi t ~f:(fun i x ->\n let new_acc, y = f i !acc x in\n acc := new_acc;\n y)\n in\n !acc, result\n;;\n\nlet iteri l ~f =\n ignore\n (fold l ~init:0 ~f:(fun i x ->\n f i x;\n i + 1)\n : int)\n;;\n\nlet foldi t ~init ~f =\n snd (fold t ~init:(0, init) ~f:(fun (i, acc) v -> i + 1, f i acc v))\n;;\n\nlet filteri l ~f =\n rev (foldi l ~f:(fun pos acc x -> if f pos x then x :: acc else acc) ~init:[])\n;;\n\nlet reduce l ~f =\n match l with\n | [] -> None\n | hd :: tl -> Some (fold ~init:hd ~f tl)\n;;\n\nlet reduce_exn l ~f =\n match reduce l ~f with\n | None -> invalid_arg \"List.reduce_exn\"\n | Some v -> v\n;;\n\nlet reduce_balanced l ~f =\n (* Call the \"size\" of a value the number of list elements that have been combined into\n it via calls to [f]. We proceed by using [f] to combine elements in the accumulator\n of the same size until we can't combine any more, then getting a new element from the\n input list and repeating.\n\n With this strategy, in the accumulator:\n - we only ever have elements of sizes a power of two\n - we never have more than one element of each size\n - the sum of all the element sizes is equal to the number of elements consumed\n\n These conditions enforce that list of elements of each size is precisely the binary\n expansion of the number of elements consumed: if you've consumed 13 = 0b1101\n elements, you have one element of size 8, one of size 4, and one of size 1. Hence\n when a new element comes along, the number of combinings you need to do is the number\n of trailing 1s in the binary expansion of [num], the number of elements that have\n already gone into the accumulator. The accumulator is in ascending order of size, so\n the next element to combine with is always the head of the list. *)\n let rec step_accum num acc x =\n if num land 1 = 0\n then x :: acc\n else (\n match acc with\n | [] -> assert false\n (* New elements from later in the input list go on the front of the accumulator, so\n the accumulator is in reverse order wrt the original list order, hence [f y x]\n instead of [f x y]. *)\n | y :: ys -> step_accum (num asr 1) ys (f y x))\n in\n (* Experimentally, inlining [foldi] and unrolling this loop a few times can reduce\n runtime down to a third and allocation to 1/16th or so in the microbenchmarks below.\n However, in most use cases [f] is likely to be expensive (otherwise why do you care\n about the order of reduction?) so the overhead of this function itself doesn't really\n matter. If you come up with a use-case where it does, then that's something you might\n want to try: see hg log -pr 49ef065f429d. *)\n match foldi l ~init:[] ~f:step_accum with\n | [] -> None\n | x :: xs -> Some (fold xs ~init:x ~f:(fun x y -> f y x))\n;;\n\nlet reduce_balanced_exn l ~f =\n match reduce_balanced l ~f with\n | None -> invalid_arg \"List.reduce_balanced_exn\"\n | Some v -> v\n;;\n\nlet groupi l ~break =\n let groups =\n foldi l ~init:[] ~f:(fun i acc x ->\n match acc with\n | [] -> [ [ x ] ]\n | current_group :: tl ->\n if break i (hd_exn current_group) x\n then [ x ] :: current_group :: tl (* start new group *)\n else (x :: current_group) :: tl)\n (* extend current group *)\n in\n match groups with\n | [] -> []\n | l -> rev_map l ~f:rev\n;;\n\nlet group l ~break = groupi l ~break:(fun _ x y -> break x y)\n\nlet concat_map l ~f =\n let rec aux acc = function\n | [] -> rev acc\n | hd :: tl -> aux (rev_append (f hd) acc) tl\n in\n aux [] l\n;;\n\nlet concat_mapi l ~f =\n let rec aux cont acc = function\n | [] -> rev acc\n | hd :: tl -> aux (cont + 1) (rev_append (f cont hd) acc) tl\n in\n aux 0 [] l\n;;\n\nlet merge l1 l2 ~compare =\n let rec loop acc l1 l2 =\n match l1, l2 with\n | [], l2 -> rev_append acc l2\n | l1, [] -> rev_append acc l1\n | h1 :: t1, h2 :: t2 ->\n if compare h1 h2 <= 0 then loop (h1 :: acc) t1 l2 else loop (h2 :: acc) l1 t2\n in\n loop [] l1 l2\n;;\n\ninclude struct\n (* We are explicit about what we import from the general Monad functor so that we don't\n accidentally rebind more efficient list-specific functions. *)\n module Monad = Monad.Make (struct\n type 'a t = 'a list\n\n let bind x ~f = concat_map x ~f\n let map = `Custom map\n let return x = [ x ]\n end)\n\n open Monad\n module Monad_infix = Monad_infix\n module Let_syntax = Let_syntax\n\n let ignore_m = ignore_m\n let join = join\n let bind = bind\n let ( >>= ) t f = bind t ~f\n let return = return\n let all = all\n let all_unit = all_unit\nend\n\n(** returns final element of list *)\nlet rec last_exn list =\n match list with\n | [ x ] -> x\n | _ :: tl -> last_exn tl\n | [] -> invalid_arg \"List.last\"\n;;\n\n(** optionally returns final element of list *)\nlet rec last list =\n match list with\n | [ x ] -> Some x\n | _ :: tl -> last tl\n | [] -> None\n;;\n\nlet rec is_prefix list ~prefix ~equal =\n match prefix with\n | [] -> true\n | hd :: tl ->\n (match list with\n | [] -> false\n | hd' :: tl' -> equal hd hd' && is_prefix tl' ~prefix:tl ~equal)\n;;\n\nlet find_consecutive_duplicate t ~equal =\n match t with\n | [] -> None\n | a1 :: t ->\n let rec loop a1 t =\n match t with\n | [] -> None\n | a2 :: t -> if equal a1 a2 then Some (a1, a2) else loop a2 t\n in\n loop a1 t\n;;\n\n(* returns list without adjacent duplicates *)\nlet remove_consecutive_duplicates ?(which_to_keep = `Last) list ~equal =\n let rec loop to_keep accum = function\n | [] -> to_keep :: accum\n | hd :: tl ->\n if equal hd to_keep\n then (\n let to_keep =\n match which_to_keep with\n | `First -> to_keep\n | `Last -> hd\n in\n loop to_keep accum tl)\n else loop hd (to_keep :: accum) tl\n in\n match list with\n | [] -> []\n | hd :: tl -> rev (loop hd [] tl)\n;;\n\n(** returns sorted version of list with duplicates removed *)\nlet dedup_and_sort ~compare list =\n match list with\n | [] | [ _ ] -> list (* performance hack *)\n | _ ->\n let equal x x' = compare x x' = 0 in\n let sorted = sort ~compare list in\n remove_consecutive_duplicates ~equal sorted\n;;\n\nlet find_a_dup ~compare l =\n let sorted = sort ~compare l in\n let rec loop l =\n match l with\n | [] | [ _ ] -> None\n | hd1 :: (hd2 :: _ as tl) -> if compare hd1 hd2 = 0 then Some hd1 else loop tl\n in\n loop sorted\n;;\n\nlet contains_dup ~compare lst =\n match find_a_dup ~compare lst with\n | Some _ -> true\n | None -> false\n;;\n\nlet find_all_dups ~compare l =\n (* We add this reversal, so we can skip a [rev] at the end. We could skip\n [rev] anyway since we don not give any ordering guarantees, but it is\n nice to get results in natural order. *)\n let compare a b = -1 * compare a b in\n let sorted = sort ~compare l in\n (* Walk the list and record the first of each consecutive run of identical elements *)\n let rec loop sorted prev ~already_recorded acc =\n match sorted with\n | [] -> acc\n | hd :: tl ->\n if compare prev hd <> 0\n then loop tl hd ~already_recorded:false acc\n else if already_recorded\n then loop tl hd ~already_recorded:true acc\n else loop tl hd ~already_recorded:true (hd :: acc)\n in\n match sorted with\n | [] -> []\n | hd :: tl -> loop tl hd ~already_recorded:false []\n;;\n\nlet count t ~f = Container.count ~fold t ~f\nlet sum m t ~f = Container.sum ~fold m t ~f\nlet min_elt t ~compare = Container.min_elt ~fold t ~compare\nlet max_elt t ~compare = Container.max_elt ~fold t ~compare\n\nlet counti t ~f =\n foldi t ~init:0 ~f:(fun idx count a -> if f idx a then count + 1 else count)\n;;\n\nlet init n ~f =\n if n < 0 then invalid_argf \"List.init %d\" n ();\n let rec loop i accum =\n assert (i >= 0);\n if i = 0 then accum else loop (i - 1) (f (i - 1) :: accum)\n in\n loop n []\n;;\n\nlet rev_filter_map l ~f =\n let rec loop l accum =\n match l with\n | [] -> accum\n | hd :: tl ->\n (match f hd with\n | Some x -> loop tl (x :: accum)\n | None -> loop tl accum)\n in\n loop l []\n;;\n\nlet filter_map l ~f = rev (rev_filter_map l ~f)\n\nlet rev_filter_mapi l ~f =\n let rec loop i l accum =\n match l with\n | [] -> accum\n | hd :: tl ->\n (match f i hd with\n | Some x -> loop (i + 1) tl (x :: accum)\n | None -> loop (i + 1) tl accum)\n in\n loop 0 l []\n;;\n\nlet filter_mapi l ~f = rev (rev_filter_mapi l ~f)\nlet filter_opt l = filter_map l ~f:Fn.id\n\nlet partition3_map t ~f =\n let rec loop t fst snd trd =\n match t with\n | [] -> rev fst, rev snd, rev trd\n | x :: t ->\n (match f x with\n | `Fst y -> loop t (y :: fst) snd trd\n | `Snd y -> loop t fst (y :: snd) trd\n | `Trd y -> loop t fst snd (y :: trd))\n in\n loop t [] [] []\n;;\n\nlet partition_tf t ~f =\n let f x : _ Either.t = if f x then First x else Second x in\n partition_map t ~f\n;;\n\nlet partition_result t = partition_map t ~f:Result.to_either\n\nmodule Assoc = struct\n type ('a, 'b) t = ('a * 'b) list [@@deriving_inline sexp]\n\n let t_of_sexp :\n 'a 'b. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> (Ppx_sexp_conv_lib.Sexp.t -> 'b)\n -> Ppx_sexp_conv_lib.Sexp.t -> ('a, 'b) t\n =\n let _tp_loc = \"list.ml.Assoc.t\" in\n fun _of_a _of_b t ->\n list_of_sexp\n (function\n | Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ] ->\n let v0 = _of_a v0\n and v1 = _of_b v1 in\n v0, v1\n | sexp -> Ppx_sexp_conv_lib.Conv_error.tuple_of_size_n_expected _tp_loc 2 sexp)\n t\n ;;\n\n let sexp_of_t :\n 'a 'b. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> ('b -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('a, 'b) t -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a _of_b v ->\n sexp_of_list\n (function\n | v0, v1 ->\n let v0 = _of_a v0\n and v1 = _of_b v1 in\n Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ])\n v\n ;;\n\n [@@@end]\n\n let find t ~equal key =\n match find t ~f:(fun (key', _) -> equal key key') with\n | None -> None\n | Some x -> Some (snd x)\n ;;\n\n let find_exn =\n let not_found = Not_found_s (Atom \"List.Assoc.find_exn: not found\") in\n let find_exn t ~equal key =\n match find t key ~equal with\n | None -> raise not_found\n | Some value -> value\n in\n (* named to preserve symbol in compiled binary *)\n find_exn\n ;;\n\n let mem t ~equal key =\n match find t ~equal key with\n | None -> false\n | Some _ -> true\n ;;\n\n let remove t ~equal key = filter t ~f:(fun (key', _) -> not (equal key key'))\n\n let add t ~equal key value =\n (* the remove doesn't change the map semantics, but keeps the list small *)\n (key, value) :: remove t ~equal key\n ;;\n\n let inverse t = map t ~f:(fun (x, y) -> y, x)\n let map t ~f = map t ~f:(fun (key, value) -> key, f value)\nend\n\nlet sub l ~pos ~len =\n (* We use [pos > length l - len] rather than [pos + len > length l] to avoid the\n possibility of overflow. *)\n if pos < 0 || len < 0 || pos > length l - len then invalid_arg \"List.sub\";\n rev\n (foldi l ~init:[] ~f:(fun i acc el ->\n if i >= pos && i < pos + len then el :: acc else acc))\n;;\n\nlet split_n t_orig n =\n if n <= 0\n then [], t_orig\n else (\n let rec loop n t accum =\n if n = 0\n then rev accum, t\n else (\n match t with\n | [] -> t_orig, [] (* in this case, t_orig = rev accum *)\n | hd :: tl -> loop (n - 1) tl (hd :: accum))\n in\n loop n t_orig [])\n;;\n\n(* copied from [split_n] to avoid allocating a tuple *)\nlet take t_orig n =\n if n <= 0\n then []\n else (\n let rec loop n t accum =\n if n = 0\n then rev accum\n else (\n match t with\n | [] -> t_orig\n | hd :: tl -> loop (n - 1) tl (hd :: accum))\n in\n loop n t_orig [])\n;;\n\nlet rec drop t n =\n match t with\n | _ :: tl when n > 0 -> drop tl (n - 1)\n | t -> t\n;;\n\nlet chunks_of l ~length =\n if length <= 0\n then invalid_argf \"List.chunks_of: Expected length > 0, got %d\" length ();\n let rec aux of_length acc l =\n match l with\n | [] -> rev acc\n | _ :: _ ->\n let sublist, l = split_n l length in\n aux of_length (sublist :: acc) l\n in\n aux length [] l\n;;\n\nlet split_while xs ~f =\n let rec loop acc = function\n | hd :: tl when f hd -> loop (hd :: acc) tl\n | t -> rev acc, t\n in\n loop [] xs\n;;\n\n(* copied from [split_while] to avoid allocating a tuple *)\nlet take_while xs ~f =\n let rec loop acc = function\n | hd :: tl when f hd -> loop (hd :: acc) tl\n | _ -> rev acc\n in\n loop [] xs\n;;\n\nlet rec drop_while t ~f =\n match t with\n | hd :: tl when f hd -> drop_while tl ~f\n | t -> t\n;;\n\nlet drop_last t =\n match rev t with\n | [] -> None\n | _ :: lst -> Some (rev lst)\n;;\n\nlet drop_last_exn t =\n match drop_last t with\n | None -> failwith \"List.drop_last_exn: empty list\"\n | Some lst -> lst\n;;\n\nlet cartesian_product list1 list2 =\n if is_empty list2\n then []\n else (\n let rec loop l1 l2 accum =\n match l1 with\n | [] -> accum\n | hd :: tl -> loop tl l2 (rev_append (map ~f:(fun x -> hd, x) l2) accum)\n in\n rev (loop list1 list2 []))\n;;\n\nlet concat l = fold_right l ~init:[] ~f:append\nlet concat_no_order l = fold l ~init:[] ~f:(fun acc l -> rev_append l acc)\nlet cons x l = x :: l\n\nlet is_sorted l ~compare =\n let rec loop l =\n match l with\n | [] | [ _ ] -> true\n | x1 :: (x2 :: _ as rest) -> compare x1 x2 <= 0 && loop rest\n in\n loop l\n;;\n\nlet is_sorted_strictly l ~compare =\n let rec loop l =\n match l with\n | [] | [ _ ] -> true\n | x1 :: (x2 :: _ as rest) -> compare x1 x2 < 0 && loop rest\n in\n loop l\n;;\n\nmodule Infix = struct\n let ( @ ) = append\nend\n\nlet permute ?(random_state = Random.State.default) list =\n match list with\n (* special cases to speed things up in trivial cases *)\n | [] | [ _ ] -> list\n | [ x; y ] -> if Random.State.bool random_state then [ y; x ] else list\n | _ ->\n let arr = Array.of_list list in\n Array_permute.permute arr ~random_state;\n Array.to_list arr\n;;\n\nlet random_element_exn ?(random_state = Random.State.default) list =\n if is_empty list\n then failwith \"List.random_element_exn: empty list\"\n else nth_exn list (Random.State.int random_state (length list))\n;;\n\nlet random_element ?(random_state = Random.State.default) list =\n try Some (random_element_exn ~random_state list) with\n | _ -> None\n;;\n\nlet rec compare cmp a b =\n match a, b with\n | [], [] -> 0\n | [], _ -> -1\n | _, [] -> 1\n | x :: xs, y :: ys ->\n let n = cmp x y in\n if n = 0 then compare cmp xs ys else n\n;;\n\nlet hash_fold_t = hash_fold_list\n\nlet equal equal t1 t2 =\n let rec loop ~equal t1 t2 =\n match t1, t2 with\n | [], [] -> true\n | x1 :: t1, x2 :: t2 -> equal x1 x2 && loop ~equal t1 t2\n | _ -> false\n in\n loop ~equal t1 t2\n;;\n\nlet transpose =\n let rec transpose_aux t rev_columns =\n match\n partition_map t ~f:(function\n | [] -> Second ()\n | x :: xs -> First (x, xs))\n with\n | _ :: _, _ :: _ -> None\n | [], _ -> Some (rev_append rev_columns [])\n | heads_and_tails, [] ->\n let column, trimmed_rows = unzip heads_and_tails in\n transpose_aux trimmed_rows (column :: rev_columns)\n in\n fun t -> transpose_aux t []\n;;\n\nexception Transpose_got_lists_of_different_lengths of int list [@@deriving_inline sexp]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Transpose_got_lists_of_different_lengths]\n (function\n | Transpose_got_lists_of_different_lengths v0 ->\n let v0 = sexp_of_list sexp_of_int v0 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom\n \"list.ml.Transpose_got_lists_of_different_lengths\"\n ; v0\n ]\n | _ -> assert false)\n;;\n\n[@@@end]\n\nlet transpose_exn l =\n match transpose l with\n | Some l -> l\n | None -> raise (Transpose_got_lists_of_different_lengths (map l ~f:length))\n;;\n\nlet intersperse t ~sep =\n match t with\n | [] -> []\n | x :: xs -> x :: fold_right xs ~init:[] ~f:(fun y acc -> sep :: y :: acc)\n;;\n\nlet fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\nlet fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\n\nlet is_suffix list ~suffix ~equal:equal_elt =\n let list_len = length list in\n let suffix_len = length suffix in\n list_len >= suffix_len && equal equal_elt (drop list (list_len - suffix_len)) suffix\n;;\n","open! Import\n\ntype t =\n | Less\n | Equal\n | Greater\n[@@deriving_inline compare, hash, enumerate, sexp]\n\nlet compare = (Ppx_compare_lib.polymorphic_compare : t -> t -> int)\n\nlet (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n (fun hsv arg ->\n match arg with\n | Less -> Ppx_hash_lib.Std.Hash.fold_int hsv 0\n | Equal -> Ppx_hash_lib.Std.Hash.fold_int hsv 1\n | Greater -> Ppx_hash_lib.Std.Hash.fold_int hsv 2\n : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state)\n;;\n\nlet (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func arg =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (let hsv = Ppx_hash_lib.Std.Hash.create () in\n hash_fold_t hsv arg)\n in\n fun x -> func x\n;;\n\nlet all = ([ Less; Equal; Greater ] : t list)\n\nlet t_of_sexp =\n (let _tp_loc = \"ordering.ml.t\" in\n function\n | Ppx_sexp_conv_lib.Sexp.Atom (\"less\" | \"Less\") -> Less\n | Ppx_sexp_conv_lib.Sexp.Atom (\"equal\" | \"Equal\") -> Equal\n | Ppx_sexp_conv_lib.Sexp.Atom (\"greater\" | \"Greater\") -> Greater\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"less\" | \"Less\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"equal\" | \"Equal\") :: _)\n as sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"greater\" | \"Greater\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> t)\n;;\n\nlet sexp_of_t =\n (function\n | Less -> Ppx_sexp_conv_lib.Sexp.Atom \"Less\"\n | Equal -> Ppx_sexp_conv_lib.Sexp.Atom \"Equal\"\n | Greater -> Ppx_sexp_conv_lib.Sexp.Atom \"Greater\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet equal a b = compare a b = 0\n\nmodule Export = struct\n type _ordering = t =\n | Less\n | Equal\n | Greater\nend\n\nlet of_int n = if n < 0 then Less else if n = 0 then Equal else Greater\n\nlet to_int = function\n | Less -> -1\n | Equal -> 0\n | Greater -> 1\n;;\n","open! Import\ninclude Applicative_intf\n\n(** This module serves mostly as a partial check that [S2] and [S] are in sync, but\n actually calling it is occasionally useful. *)\nmodule S_to_S2 (X : S) : S2 with type ('a, 'e) t = 'a X.t = struct\n type ('a, 'e) t = 'a X.t\n\n include (X : S with type 'a t := 'a X.t)\nend\n\nmodule S2_to_S (X : S2) : S with type 'a t = ('a, unit) X.t = struct\n type 'a t = ('a, unit) X.t\n\n include (X : S2 with type ('a, 'e) t := ('a, 'e) X.t)\nend\n\nmodule S2_to_S3 (X : S2) : S3 with type ('a, 'd, 'e) t = ('a, 'd) X.t = struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : S2 with type ('a, 'd) t := ('a, 'd) X.t)\nend\n\nmodule S3_to_S2 (X : S3) : S2 with type ('a, 'd) t = ('a, 'd, unit) X.t = struct\n type ('a, 'd) t = ('a, 'd, unit) X.t\n\n include (X : S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t)\nend\n\n(* These functors serve only to check that the signatures for various Foo and Foo2 module\n types don't drift apart over time.\n*)\nmodule Check_compatibility = struct\n module Applicative_infix_to_Applicative_infix2 (X : Applicative_infix) :\n Applicative_infix2 with type ('a, 'e) t = 'a X.t = struct\n type ('a, 'e) t = 'a X.t\n\n include (X : Applicative_infix with type 'a t := 'a X.t)\n end\n\n module Applicative_infix2_to_Applicative_infix (X : Applicative_infix2) :\n Applicative_infix with type 'a t = ('a, unit) X.t = struct\n type 'a t = ('a, unit) X.t\n\n include (X : Applicative_infix2 with type ('a, 'e) t := ('a, 'e) X.t)\n end\n\n module Applicative_infix2_to_Applicative_infix3 (X : Applicative_infix2) :\n Applicative_infix3 with type ('a, 'd, 'e) t = ('a, 'd) X.t = struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : Applicative_infix2 with type ('a, 'd) t := ('a, 'd) X.t)\n end\n\n module Applicative_infix3_to_Applicative_infix2 (X : Applicative_infix3) :\n Applicative_infix2 with type ('a, 'd) t = ('a, 'd, unit) X.t = struct\n type ('a, 'd) t = ('a, 'd, unit) X.t\n\n include (X : Applicative_infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t)\n end\n\n module Let_syntax_to_Let_syntax2 (X : Let_syntax) :\n Let_syntax2 with type ('a, 'e) t = 'a X.t = struct\n type ('a, 'e) t = 'a X.t\n\n include (X : Let_syntax with type 'a t := 'a X.t)\n end\n\n module Let_syntax2_to_Let_syntax (X : Let_syntax2) :\n Let_syntax with type 'a t = ('a, unit) X.t = struct\n type 'a t = ('a, unit) X.t\n\n include (X : Let_syntax2 with type ('a, 'e) t := ('a, 'e) X.t)\n end\n\n module Let_syntax2_to_Let_syntax3 (X : Let_syntax2) :\n Let_syntax3 with type ('a, 'd, 'e) t = ('a, 'd) X.t = struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : Let_syntax2 with type ('a, 'd) t := ('a, 'd) X.t)\n end\n\n module Let_syntax3_to_Let_syntax2 (X : Let_syntax3) :\n Let_syntax2 with type ('a, 'd) t = ('a, 'd, unit) X.t = struct\n type ('a, 'd) t = ('a, 'd, unit) X.t\n\n include (X : Let_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t)\n end\nend\n\nmodule Make3 (X : Basic3) : S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t = struct\n include X\n\n let ( <*> ) = apply\n let derived_map t ~f = return f <*> t\n\n let map =\n match X.map with\n | `Define_using_apply -> derived_map\n | `Custom x -> x\n ;;\n\n let ( >>| ) t f = map t ~f\n let map2 ta tb ~f = map ~f ta <*> tb\n let map3 ta tb tc ~f = map ~f ta <*> tb <*> tc\n let all ts = List.fold_right ts ~init:(return []) ~f:(map2 ~f:(fun x xs -> x :: xs))\n let both ta tb = map2 ta tb ~f:(fun a b -> a, b)\n let ( *> ) u v = return (fun () y -> y) <*> u <*> v\n let ( <* ) u v = return (fun x () -> x) <*> u <*> v\n let all_unit ts = List.fold ts ~init:(return ()) ~f:( *> )\n\n module Applicative_infix = struct\n let ( <*> ) = ( <*> )\n let ( *> ) = ( *> )\n let ( <* ) = ( <* )\n let ( >>| ) = ( >>| )\n end\nend\n\nmodule Make2 (X : Basic2) : S2 with type ('a, 'e) t := ('a, 'e) X.t = Make3 (struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : Basic2 with type ('a, 'e) t := ('a, 'e) X.t)\n end)\n\nmodule Make (X : Basic) : S with type 'a t := 'a X.t = Make2 (struct\n type ('a, 'e) t = 'a X.t\n\n include (X : Basic with type 'a t := 'a X.t)\n end)\n\nmodule Make_let_syntax3\n (X : For_let_syntax3) (Intf : sig\n module type S\n end)\n (Impl : Intf.S) =\nstruct\n module Let_syntax = struct\n include X\n\n module Let_syntax = struct\n include X\n module Open_on_rhs = Impl\n end\n end\nend\n\nmodule Make_let_syntax2\n (X : For_let_syntax2) (Intf : sig\n module type S\n end)\n (Impl : Intf.S) =\n Make_let_syntax3\n (struct\n type ('a, 'd, _) t = ('a, 'd) X.t\n\n include (X : For_let_syntax2 with type ('a, 'e) t := ('a, 'e) X.t)\n end)\n (Intf)\n (Impl)\n\nmodule Make_let_syntax\n (X : For_let_syntax) (Intf : sig\n module type S\n end)\n (Impl : Intf.S) =\n Make_let_syntax2\n (struct\n type ('a, _) t = 'a X.t\n\n include (X : For_let_syntax with type 'a t := 'a X.t)\n end)\n (Intf)\n (Impl)\n\nmodule Make3_using_map2 (X : Basic3_using_map2) = Make3 (struct\n include X\n\n let apply tf tx = map2 tf tx ~f:(fun f x -> f x)\n\n let map =\n match map with\n | `Custom map -> `Custom map\n | `Define_using_map2 -> `Define_using_apply\n ;;\n end)\n\nmodule Make2_using_map2 (X : Basic2_using_map2) :\n S2 with type ('a, 'e) t := ('a, 'e) X.t = Make3_using_map2 (struct\n type ('a, 'd, 'e) t = ('a, 'd) X.t\n\n include (X : Basic2_using_map2 with type ('a, 'e) t := ('a, 'e) X.t)\n end)\n\nmodule Make_using_map2 (X : Basic_using_map2) : S with type 'a t := 'a X.t =\n Make2_using_map2 (struct\n type ('a, 'e) t = 'a X.t\n\n include (X : Basic_using_map2 with type 'a t := 'a X.t)\n end)\n\nmodule Of_monad2 (M : Monad.S2) : S2 with type ('a, 'e) t := ('a, 'e) M.t = Make2 (struct\n type ('a, 'e) t = ('a, 'e) M.t\n\n let return = M.return\n let apply mf mx = M.bind mf ~f:(fun f -> M.map mx ~f)\n let map = `Custom M.map\n end)\n\nmodule Of_monad (M : Monad.S) : S with type 'a t := 'a M.t = Of_monad2 (struct\n type ('a, _) t = 'a M.t\n\n include (M : Monad.S with type 'a t := 'a M.t)\n end)\n\nmodule Compose (F : S) (G : S) : S with type 'a t = 'a F.t G.t = struct\n type 'a t = 'a F.t G.t\n\n include Make (struct\n type nonrec 'a t = 'a t\n\n let return a = G.return (F.return a)\n let apply tf tx = G.apply (G.map ~f:F.apply tf) tx\n let custom_map t ~f = G.map ~f:(F.map ~f) t\n let map = `Custom custom_map\n end)\nend\n\nmodule Pair (F : S) (G : S) : S with type 'a t = 'a F.t * 'a G.t = struct\n type 'a t = 'a F.t * 'a G.t\n\n include Make (struct\n type nonrec 'a t = 'a t\n\n let return a = F.return a, G.return a\n let apply tf tx = F.apply (fst tf) (fst tx), G.apply (snd tf) (snd tx)\n let custom_map t ~f = F.map ~f (fst t), G.map ~f (snd t)\n let map = `Custom custom_map\n end)\nend\n","(* This module is trying to minimize dependencies on modules in Core, so as to allow\n [Info], [Error], and [Or_error] to be used in as many places as possible. Please avoid\n adding new dependencies. *)\n\nopen! Import\ninclude Info_intf\nmodule String = String0\n\nmodule Message = struct\n type t =\n | Could_not_construct of Sexp.t\n | String of string\n | Exn of exn\n | Sexp of Sexp.t\n | Tag_sexp of string * Sexp.t * Source_code_position0.t option\n | Tag_t of string * t\n | Tag_arg of string * Sexp.t * t\n | Of_list of int option * t list\n | With_backtrace of t * string (* backtrace *)\n [@@deriving_inline sexp_of]\n\n let rec sexp_of_t =\n (function\n | Could_not_construct v0 ->\n let v0 = Sexp.sexp_of_t v0 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"Could_not_construct\"; v0 ]\n | String v0 ->\n let v0 = sexp_of_string v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"String\"; v0 ]\n | Exn v0 ->\n let v0 = sexp_of_exn v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Exn\"; v0 ]\n | Sexp v0 ->\n let v0 = Sexp.sexp_of_t v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Sexp\"; v0 ]\n | Tag_sexp (v0, v1, v2) ->\n let v0 = sexp_of_string v0\n and v1 = Sexp.sexp_of_t v1\n and v2 = sexp_of_option Source_code_position0.sexp_of_t v2 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Tag_sexp\"; v0; v1; v2 ]\n | Tag_t (v0, v1) ->\n let v0 = sexp_of_string v0\n and v1 = sexp_of_t v1 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Tag_t\"; v0; v1 ]\n | Tag_arg (v0, v1, v2) ->\n let v0 = sexp_of_string v0\n and v1 = Sexp.sexp_of_t v1\n and v2 = sexp_of_t v2 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Tag_arg\"; v0; v1; v2 ]\n | Of_list (v0, v1) ->\n let v0 = sexp_of_option sexp_of_int v0\n and v1 = sexp_of_list sexp_of_t v1 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Of_list\"; v0; v1 ]\n | With_backtrace (v0, v1) ->\n let v0 = sexp_of_t v0\n and v1 = sexp_of_string v1 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"With_backtrace\"; v0; v1 ]\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\n\n let rec to_strings_hum t ac =\n (* We use [Sexp.to_string_mach], despite the fact that we are implementing\n [to_strings_hum], because we want the info to fit on a single line, and once we've\n had to resort to sexps, the message is going to start not looking so pretty\n anyway. *)\n match t with\n | Could_not_construct sexp ->\n \"could not construct info: \" :: Sexp.to_string_mach sexp :: ac\n | String string -> string :: ac\n | Exn exn -> Sexp.to_string_mach (Exn.sexp_of_t exn) :: ac\n | Sexp sexp -> Sexp.to_string_mach sexp :: ac\n | Tag_sexp (tag, sexp, _) -> tag :: \": \" :: Sexp.to_string_mach sexp :: ac\n | Tag_t (tag, t) -> tag :: \": \" :: to_strings_hum t ac\n | Tag_arg (tag, sexp, t) ->\n let body = Sexp.to_string_mach sexp :: \": \" :: to_strings_hum t ac in\n if String.length tag = 0 then body else tag :: \": \" :: body\n | With_backtrace (t, backtrace) ->\n to_strings_hum t (\"\\nBacktrace:\\n\" :: backtrace :: ac)\n | Of_list (trunc_after, ts) ->\n let ts =\n match trunc_after with\n | None -> ts\n | Some max ->\n let n = List.length ts in\n if n <= max\n then ts\n else List.take ts max @ [ String (Printf.sprintf \"and %d more info\" (n - max)) ]\n in\n List.fold (List.rev ts) ~init:ac ~f:(fun ac t ->\n to_strings_hum t (if List.is_empty ac then ac else \"; \" :: ac))\n ;;\n\n let to_string_hum_deprecated t = String.concat (to_strings_hum t [])\n\n let rec to_sexps_hum t ac =\n match t with\n | Could_not_construct _ as t -> sexp_of_t t :: ac\n | String string -> Atom string :: ac\n | Exn exn -> Exn.sexp_of_t exn :: ac\n | Sexp sexp -> sexp :: ac\n | Tag_sexp (tag, sexp, here) ->\n List\n (Atom tag\n :: sexp\n ::\n (match here with\n | None -> []\n | Some here -> [ Source_code_position0.sexp_of_t here ]))\n :: ac\n | Tag_t (tag, t) -> List (Atom tag :: to_sexps_hum t []) :: ac\n | Tag_arg (tag, sexp, t) ->\n let body = sexp :: to_sexps_hum t [] in\n if String.length tag = 0 then List body :: ac else List (Atom tag :: body) :: ac\n | With_backtrace (t, backtrace) ->\n Sexp.List [ to_sexp_hum t; Sexp.Atom backtrace ] :: ac\n | Of_list (_, ts) ->\n List.fold (List.rev ts) ~init:ac ~f:(fun ac t -> to_sexps_hum t ac)\n\n and to_sexp_hum t =\n match to_sexps_hum t [] with\n | [ sexp ] -> sexp\n | sexps -> Sexp.List sexps\n ;;\n\n (* We use [protect] to guard against exceptions raised by user-supplied functions, so\n that failure to produce one part of an info doesn't interfere with other parts. *)\n let protect f =\n try f () with\n | exn -> Could_not_construct (Exn.sexp_of_t exn)\n ;;\n\n let of_info info = protect (fun () -> Lazy.force info)\n let to_info t = lazy t\nend\n\nopen Message\n\ntype t = Message.t Lazy.t\n\nlet invariant _ = ()\nlet to_message = Message.of_info\nlet of_message = Message.to_info\n\n(* It is OK to use [Message.to_sexp_hum], which is not stable, because [t_of_sexp] below\n can handle any sexp. *)\nlet sexp_of_t t = Message.to_sexp_hum (to_message t)\nlet t_of_sexp sexp = lazy (Message.Sexp sexp)\nlet compare t1 t2 = Sexp.compare (sexp_of_t t1) (sexp_of_t t2)\nlet equal t1 t2 = Sexp.equal (sexp_of_t t1) (sexp_of_t t2)\nlet hash_fold_t state t = Sexp.hash_fold_t state (sexp_of_t t)\nlet hash t = Hash.run hash_fold_t t\n\nlet to_string_hum t =\n match to_message t with\n | String s -> s\n | message -> Sexp.to_string_hum (Message.to_sexp_hum message)\n;;\n\nlet to_string_hum_deprecated t = Message.to_string_hum_deprecated (to_message t)\nlet to_string_mach t = Sexp.to_string_mach (sexp_of_t t)\nlet of_lazy l = lazy (protect (fun () -> String (Lazy.force l)))\nlet of_lazy_t lazy_t = Lazy.join lazy_t\nlet of_string message = Lazy.from_val (String message)\nlet createf format = Printf.ksprintf of_string format\nlet of_thunk f = lazy (protect (fun () -> String (f ())))\n\nlet create ?here ?strict tag x sexp_of_x =\n match strict with\n | None -> lazy (protect (fun () -> Tag_sexp (tag, sexp_of_x x, here)))\n | Some () -> of_message (Tag_sexp (tag, sexp_of_x x, here))\n;;\n\nlet create_s sexp = Lazy.from_val (Sexp sexp)\nlet tag t ~tag = lazy (Tag_t (tag, to_message t))\nlet tag_s t ~tag = lazy (protect (fun () -> Tag_arg (\"\", tag, to_message t)))\n\nlet tag_arg t tag x sexp_of_x =\n lazy (protect (fun () -> Tag_arg (tag, sexp_of_x x, to_message t)))\n;;\n\nlet of_list ?trunc_after ts = lazy (Of_list (trunc_after, List.map ts ~f:to_message))\n\nexception Exn of t\n\nlet () =\n (* We install a custom exn-converter rather than use\n [exception Exn of t [@@deriving_inline sexp] ... [@@@end]] to eliminate the extra\n wrapping of \"(Exn ...)\". *)\n Sexplib.Conv.Exn_converter.add [%extension_constructor Exn] (function\n | Exn t -> sexp_of_t t\n | _ ->\n (* Reaching this branch indicates a bug in sexplib. *)\n assert false)\n;;\n\nlet to_exn t =\n if not (Lazy.is_val t)\n then Exn t\n else (\n match Lazy.force t with\n | Message.Exn exn -> exn\n | _ -> Exn t)\n;;\n\nlet of_exn ?backtrace exn =\n let backtrace =\n match backtrace with\n | None -> None\n | Some `Get -> Some (Caml.Printexc.get_backtrace ())\n | Some (`This s) -> Some s\n in\n match exn, backtrace with\n | Exn t, None -> t\n | Exn t, Some backtrace -> lazy (With_backtrace (to_message t, backtrace))\n | _, None -> Lazy.from_val (Message.Exn exn)\n | _, Some backtrace -> lazy (With_backtrace (Sexp (Exn.sexp_of_t exn), backtrace))\n;;\n\ninclude Pretty_printer.Register_pp (struct\n type nonrec t = t\n\n let module_name = \"Base.Info\"\n let pp ppf t = Caml.Format.pp_print_string ppf (to_string_hum t)\n end)\n\nmodule Internal_repr = Message\n\n","(* This module is trying to minimize dependencies on modules in Core, so as to allow\n [Error] and [Or_error] to be used in various places. Please avoid adding new\n dependencies. *)\n\nopen! Import\ninclude Info\n\nlet raise t = raise (to_exn t)\nlet raise_s sexp = raise (create_s sexp)\nlet to_info t = t\nlet of_info t = t\n\ninclude Pretty_printer.Register_pp (struct\n type nonrec t = t\n\n let module_name = \"Base.Error\"\n let pp = pp\n end)\n","open! Import\ninclude Invariant_intf\n\nlet raise_s = Error.raise_s\n\nlet invariant here t sexp_of_t f : unit =\n try f () with\n | exn ->\n raise_s\n (Sexp.message\n \"invariant failed\"\n [ \"\", Source_code_position0.sexp_of_t here\n ; \"exn\", sexp_of_exn exn\n ; \"\", sexp_of_t t\n ])\n;;\n\nlet check_field t f field =\n try f (Field.get field t) with\n | exn ->\n raise_s\n (Sexp.message\n \"problem with field\"\n [ \"field\", sexp_of_string (Field.name field); \"exn\", sexp_of_exn exn ])\n;;\n","open! Import\n\ntype 'a t =\n | Incl of 'a\n | Excl of 'a\n | Unbounded\n[@@deriving_inline enumerate, sexp]\n\nlet all : 'a. 'a list -> 'a t list =\n fun _all_of_a ->\n Ppx_enumerate_lib.List.append\n (let rec map l acc =\n match l with\n | [] -> Ppx_enumerate_lib.List.rev acc\n | enumerate__001_ :: l -> map l (Incl enumerate__001_ :: acc)\n in\n map _all_of_a [])\n (Ppx_enumerate_lib.List.append\n (let rec map l acc =\n match l with\n | [] -> Ppx_enumerate_lib.List.rev acc\n | enumerate__002_ :: l -> map l (Excl enumerate__002_ :: acc)\n in\n map _all_of_a [])\n [ Unbounded ])\n;;\n\nlet t_of_sexp\n : type a. (Ppx_sexp_conv_lib.Sexp.t -> a) -> Ppx_sexp_conv_lib.Sexp.t -> a t\n =\n let _tp_loc = \"maybe_bound.ml.t\" in\n fun _of_a -> function\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"incl\" | \"Incl\") as _tag) :: sexp_args) as _sexp\n ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_a v0 in\n Incl v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"excl\" | \"Excl\") as _tag) :: sexp_args) as _sexp\n ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_a v0 in\n Excl v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.Atom (\"unbounded\" | \"Unbounded\") -> Unbounded\n | Ppx_sexp_conv_lib.Sexp.Atom (\"incl\" | \"Incl\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.Atom (\"excl\" | \"Excl\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"unbounded\" | \"Unbounded\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n;;\n\nlet sexp_of_t\n : type a. (a -> Ppx_sexp_conv_lib.Sexp.t) -> a t -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a -> function\n | Incl v0 ->\n let v0 = _of_a v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Incl\"; v0 ]\n | Excl v0 ->\n let v0 = _of_a v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Excl\"; v0 ]\n | Unbounded -> Ppx_sexp_conv_lib.Sexp.Atom \"Unbounded\"\n;;\n\n[@@@end]\n\ntype interval_comparison =\n | Below_lower_bound\n | In_range\n | Above_upper_bound\n[@@deriving_inline sexp, compare, hash]\n\nlet interval_comparison_of_sexp =\n (let _tp_loc = \"maybe_bound.ml.interval_comparison\" in\n function\n | Ppx_sexp_conv_lib.Sexp.Atom (\"below_lower_bound\" | \"Below_lower_bound\") ->\n Below_lower_bound\n | Ppx_sexp_conv_lib.Sexp.Atom (\"in_range\" | \"In_range\") -> In_range\n | Ppx_sexp_conv_lib.Sexp.Atom (\"above_upper_bound\" | \"Above_upper_bound\") ->\n Above_upper_bound\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"below_lower_bound\" | \"Below_lower_bound\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"in_range\" | \"In_range\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"above_upper_bound\" | \"Above_upper_bound\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> interval_comparison)\n;;\n\nlet sexp_of_interval_comparison =\n (function\n | Below_lower_bound -> Ppx_sexp_conv_lib.Sexp.Atom \"Below_lower_bound\"\n | In_range -> Ppx_sexp_conv_lib.Sexp.Atom \"In_range\"\n | Above_upper_bound -> Ppx_sexp_conv_lib.Sexp.Atom \"Above_upper_bound\"\n : interval_comparison -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\nlet compare_interval_comparison =\n (Ppx_compare_lib.polymorphic_compare\n : interval_comparison -> interval_comparison -> int)\n;;\n\nlet (hash_fold_interval_comparison :\n Ppx_hash_lib.Std.Hash.state -> interval_comparison -> Ppx_hash_lib.Std.Hash.state)\n =\n (fun hsv arg ->\n match arg with\n | Below_lower_bound -> Ppx_hash_lib.Std.Hash.fold_int hsv 0\n | In_range -> Ppx_hash_lib.Std.Hash.fold_int hsv 1\n | Above_upper_bound -> Ppx_hash_lib.Std.Hash.fold_int hsv 2\n : Ppx_hash_lib.Std.Hash.state -> interval_comparison -> Ppx_hash_lib.Std.Hash.state)\n;;\n\nlet (hash_interval_comparison : interval_comparison -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func arg =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (let hsv = Ppx_hash_lib.Std.Hash.create () in\n hash_fold_interval_comparison hsv arg)\n in\n fun x -> func x\n;;\n\n[@@@end]\n\nlet map t ~f =\n match t with\n | Incl incl -> Incl (f incl)\n | Excl excl -> Excl (f excl)\n | Unbounded -> Unbounded\n;;\n\nlet is_lower_bound t ~of_:a ~compare =\n match t with\n | Incl incl -> compare incl a <= 0\n | Excl excl -> compare excl a < 0\n | Unbounded -> true\n;;\n\nlet is_upper_bound t ~of_:a ~compare =\n match t with\n | Incl incl -> compare a incl <= 0\n | Excl excl -> compare a excl < 0\n | Unbounded -> true\n;;\n\nlet bounds_crossed ~lower ~upper ~compare =\n match lower with\n | Unbounded -> false\n | Incl lower | Excl lower ->\n (match upper with\n | Unbounded -> false\n | Incl upper | Excl upper -> compare lower upper > 0)\n;;\n\nlet check_interval_exn ~lower ~upper ~compare =\n if bounds_crossed ~lower ~upper ~compare\n then failwith \"Maybe_bound.compare_to_interval_exn: lower bound > upper bound\"\n;;\n\nlet compare_to_interval_exn ~lower ~upper a ~compare =\n check_interval_exn ~lower ~upper ~compare;\n if not (is_lower_bound lower ~of_:a ~compare)\n then Below_lower_bound\n else if not (is_upper_bound upper ~of_:a ~compare)\n then Above_upper_bound\n else In_range\n;;\n\nlet interval_contains_exn ~lower ~upper a ~compare =\n match compare_to_interval_exn ~lower ~upper a ~compare with\n | In_range -> true\n | Below_lower_bound | Above_upper_bound -> false\n;;\n","open! Import\n\ntype 'a t = ('a, Error.t) Result.t [@@deriving_inline compare, equal, hash, sexp]\n\nlet compare : 'a. ('a -> 'a -> int) -> 'a t -> 'a t -> int =\n fun _cmp__a a__001_ b__002_ -> Result.compare _cmp__a Error.compare a__001_ b__002_\n;;\n\nlet equal : 'a. ('a -> 'a -> bool) -> 'a t -> 'a t -> bool =\n fun _cmp__a a__007_ b__008_ -> Result.equal _cmp__a Error.equal a__007_ b__008_\n;;\n\nlet hash_fold_t :\n 'a. (Ppx_hash_lib.Std.Hash.state -> 'a -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state -> 'a t -> Ppx_hash_lib.Std.Hash.state\n =\n fun _hash_fold_a hsv arg -> Result.hash_fold_t _hash_fold_a Error.hash_fold_t hsv arg\n;;\n\nlet t_of_sexp : 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t =\n let _tp_loc = \"or_error.ml.t\" in\n fun _of_a t -> Result.t_of_sexp _of_a Error.t_of_sexp t\n;;\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n fun _of_a v -> Result.sexp_of_t _of_a Error.sexp_of_t v\n;;\n\n[@@@end]\n\nlet invariant invariant_a t =\n match t with\n | Ok a -> invariant_a a\n | Error error -> Error.invariant error\n;;\n\ninclude (\n Result :\n Monad.S2\n with type ('a, 'b) t := ('a, 'b) Result.t\n with module Let_syntax := Result.Let_syntax)\n\ninclude Applicative.Make (struct\n type nonrec 'a t = 'a t\n\n let return = return\n\n let apply f x =\n Result.combine f x ~ok:(fun f x -> f x) ~err:(fun e1 e2 -> Error.of_list [ e1; e2 ])\n ;;\n\n let map = `Custom map\n end)\n\nmodule Let_syntax = struct\n let return = return\n\n include Monad_infix\n\n module Let_syntax = struct\n let return = return\n let map = map\n let bind = bind\n let both = both\n\n (* from Applicative.Make *)\n module Open_on_rhs = struct end\n end\nend\n\nlet ok = Result.ok\nlet is_ok = Result.is_ok\nlet is_error = Result.is_error\n\nlet try_with ?(backtrace = false) f =\n try Ok (f ()) with\n | exn -> Error (Error.of_exn exn ?backtrace:(if backtrace then Some `Get else None))\n;;\n\nlet try_with_join ?backtrace f = join (try_with ?backtrace f)\n\nlet ok_exn = function\n | Ok x -> x\n | Error err -> Error.raise err\n;;\n\nlet of_exn ?backtrace exn = Error (Error.of_exn ?backtrace exn)\n\nlet of_exn_result ?backtrace = function\n | Ok _ as z -> z\n | Error exn -> of_exn ?backtrace exn\n;;\n\nlet error ?strict message a sexp_of_a = Error (Error.create ?strict message a sexp_of_a)\nlet error_s sexp = Error (Error.create_s sexp)\nlet error_string message = Error (Error.of_string message)\nlet errorf format = Printf.ksprintf error_string format\nlet tag t ~tag = Result.map_error t ~f:(Error.tag ~tag)\nlet tag_s t ~tag = Result.map_error t ~f:(Error.tag_s ~tag)\n\nlet tag_arg t message a sexp_of_a =\n Result.map_error t ~f:(fun e -> Error.tag_arg e message a sexp_of_a)\n;;\n\nlet unimplemented s = error \"unimplemented\" s sexp_of_string\nlet combine_errors l = Result.map_error (Result.combine_errors l) ~f:Error.of_list\nlet combine_errors_unit l = Result.map (combine_errors l) ~f:(fun (_ : unit list) -> ())\n\nlet filter_ok_at_least_one l =\n let ok, errs = List.partition_map l ~f:Result.to_either in\n match ok with\n | [] -> Error (Error.of_list errs)\n | _ -> Ok ok\n;;\n\nlet find_ok l =\n match List.find_map l ~f:Result.ok with\n | Some x -> Ok x\n | None ->\n Error\n (Error.of_list\n (List.map l ~f:(function\n | Ok _ -> assert false\n | Error err -> err)))\n;;\n\nlet find_map_ok l ~f =\n With_return.with_return (fun { return } ->\n Error\n (Error.of_list\n (List.map l ~f:(fun elt ->\n match f elt with\n | Ok _ as x -> return x\n | Error err -> err))))\n;;\n\nlet map = Result.map\nlet iter = Result.iter\nlet iter_error = Result.iter_error\n","open! Import\ninclude Comparable_intf\n\nmodule Validate (T : sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) : Validate with type t := T.t = struct\n module V = Validate\n open Maybe_bound\n\n let to_string t = Sexp.to_string (T.sexp_of_t t)\n\n let validate_bound ~min ~max t =\n V.bounded ~name:to_string ~lower:min ~upper:max ~compare:T.compare t\n ;;\n\n let validate_lbound ~min t = validate_bound ~min ~max:Unbounded t\n let validate_ubound ~max t = validate_bound ~max ~min:Unbounded t\nend\n\nmodule With_zero (T : sig\n type t [@@deriving_inline compare]\n\n val compare : t -> t -> int\n\n [@@@end]\n\n val zero : t\n\n include Validate with type t := t\n end) =\nstruct\n open T\n\n (* Preallocate the interesting bounds to minimize allocation in the implementations of\n [validate_*]. *)\n let excl_zero = Maybe_bound.Excl zero\n let incl_zero = Maybe_bound.Incl zero\n let validate_positive t = validate_lbound ~min:excl_zero t\n let validate_non_negative t = validate_lbound ~min:incl_zero t\n let validate_negative t = validate_ubound ~max:excl_zero t\n let validate_non_positive t = validate_ubound ~max:incl_zero t\n let is_positive t = compare t zero > 0\n let is_non_negative t = compare t zero >= 0\n let is_negative t = compare t zero < 0\n let is_non_positive t = compare t zero <= 0\n let sign t = Sign0.of_int (compare t zero)\nend\n\nmodule Validate_with_zero (T : sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val zero : t\n end) =\nstruct\n module V = Validate (T)\n include V\n\n include With_zero (struct\n include T\n include V\n end)\nend\n\nmodule Poly (T : sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) =\nstruct\n module Replace_polymorphic_compare = struct\n type t = T.t [@@deriving_inline sexp_of]\n\n let sexp_of_t = (T.sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n\n include Poly\n end\n\n include Poly\n\n let between t ~low ~high = low <= t && t <= high\n let clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\n let clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n ;;\n\n let clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n ;;\n\n module C = struct\n include T\n include Comparator.Make (Replace_polymorphic_compare)\n end\n\n include C\n\n include Validate (struct\n type nonrec t = t [@@deriving_inline compare, sexp_of]\n\n let compare = (compare : t -> t -> int)\n let sexp_of_t = (sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n end)\nend\n\nlet gt cmp a b = cmp a b > 0\nlet lt cmp a b = cmp a b < 0\nlet geq cmp a b = cmp a b >= 0\nlet leq cmp a b = cmp a b <= 0\nlet equal cmp a b = cmp a b = 0\nlet not_equal cmp a b = cmp a b <> 0\nlet min cmp t t' = if leq cmp t t' then t else t'\nlet max cmp t t' = if geq cmp t t' then t else t'\n\nmodule Infix (T : sig\n type t [@@deriving_inline compare]\n\n val compare : t -> t -> int\n\n [@@@end]\n end) : Infix with type t := T.t = struct\n let ( > ) a b = gt T.compare a b\n let ( < ) a b = lt T.compare a b\n let ( >= ) a b = geq T.compare a b\n let ( <= ) a b = leq T.compare a b\n let ( = ) a b = equal T.compare a b\n let ( <> ) a b = not_equal T.compare a b\nend\n\nmodule Polymorphic_compare (T : sig\n type t [@@deriving_inline compare]\n\n val compare : t -> t -> int\n\n [@@@end]\n end) : Polymorphic_compare with type t := T.t = struct\n include Infix (T)\n\n let compare = T.compare\n let equal = ( = )\n let min t t' = min compare t t'\n let max t t' = max compare t t'\nend\n\nmodule Make_using_comparator (T : sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n include Comparator.S with type t := t\n end) : S with type t := T.t and type comparator_witness = T.comparator_witness = struct\n module T = struct\n include T\n\n let compare = comparator.compare\n end\n\n include T\n module Replace_polymorphic_compare = Polymorphic_compare (T)\n include Replace_polymorphic_compare\n\n let ascending = compare\n let descending t t' = compare t' t\n let between t ~low ~high = low <= t && t <= high\n let clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\n let clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n ;;\n\n let clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n ;;\n\n include Validate (T)\nend\n\nmodule Make (T : sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end) =\n Make_using_comparator (struct\n include T\n include Comparator.Make (T)\n end)\n\nmodule Inherit (C : sig\n type t [@@deriving_inline compare]\n\n val compare : t -> t -> int\n\n [@@@end]\n end) (T : sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val component : t -> C.t\n end) =\n Make (struct\n type t = T.t [@@deriving_inline sexp_of]\n\n let sexp_of_t = (T.sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n\n let compare t t' = C.compare (T.component t) (T.component t')\n end)\n\n(* compare [x] and [y] lexicographically using functions in the list [cmps] *)\nlet lexicographic cmps x y =\n let rec loop = function\n | cmp :: cmps ->\n let res = cmp x y in\n if res = 0 then loop cmps else res\n | [] -> 0\n in\n loop cmps\n;;\n\nlet lift cmp ~f x y = cmp (f x) (f y)\nlet reverse cmp x y = cmp y x\n","open! Import\n\nmodule type S = sig\n type t [@@deriving_inline hash, sexp]\n\n val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state\n val hash : t -> Ppx_hash_lib.Std.Hash.hash_value\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n [@@@end]\n\n include Stringable.S with type t := t\n include Comparable.S with type t := t\n include Pretty_printer.S with type t := t\nend\n\nmodule Make (T : sig\n type t [@@deriving_inline compare, hash, sexp]\n\n val compare : t -> t -> int\n val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state\n val hash : t -> Ppx_hash_lib.Std.Hash.hash_value\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n [@@@end]\n\n include Stringable.S with type t := t\n\n val module_name : string\n end) =\nstruct\n include T\n include Comparable.Make (T)\n include Pretty_printer.Register (T)\nend\n\nmodule Make_using_comparator (T : sig\n type t [@@deriving_inline hash, sexp]\n\n val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state\n val hash : t -> Ppx_hash_lib.Std.Hash.hash_value\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n [@@@end]\n\n include Comparator.S with type t := t\n include Stringable.S with type t := t\n\n val module_name : string\n end) =\nstruct\n include T\n include Comparable.Make_using_comparator (T)\n include Pretty_printer.Register (T)\nend\n","open! Import\n\nmodule type Infix = Base.Comparable.Infix\nmodule type Polymorphic_compare = Base.Comparable.Polymorphic_compare\nmodule type Validate = Base.Comparable.Validate\nmodule type With_zero = Base.Comparable.With_zero\n\nmodule type S_common = sig\n include Base.Comparable.S\n module Replace_polymorphic_compare : Polymorphic_compare with type t := t\nend\n\n(** Usage example:\n\n {[\n module Foo : sig\n type t = ...\n include Comparable.S with type t := t\n end\n ]}\n\n Then use [Comparable.Make] in the struct (see comparable.mli for an example). *)\n\nmodule type S_plain = sig\n include S_common\n\n module Map :\n Map.S_plain with type Key.t = t with type Key.comparator_witness = comparator_witness\n\n module Set :\n Set.S_plain with type Elt.t = t with type Elt.comparator_witness = comparator_witness\nend\n\nmodule type S = sig\n include S_common\n\n module Map :\n Map.S with type Key.t = t with type Key.comparator_witness = comparator_witness\n\n module Set :\n Set.S with type Elt.t = t with type Elt.comparator_witness = comparator_witness\nend\n\nmodule type Map_and_set_binable = sig\n type t\n\n include Comparator.S with type t := t\n\n module Map :\n Map.S_binable\n with type Key.t = t\n with type Key.comparator_witness = comparator_witness\n\n module Set :\n Set.S_binable\n with type Elt.t = t\n with type Elt.comparator_witness = comparator_witness\nend\n\nmodule type S_binable = sig\n include S_common\n\n include\n Map_and_set_binable\n with type t := t\n with type comparator_witness := comparator_witness\nend\n\n","open! Import\n\nmodule T = struct\n type t = unit [@@deriving_inline enumerate, hash, sexp, sexp_grammar]\n\n let all = ([ () ] : t list)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_unit\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_unit in\n fun x -> func x\n ;;\n\n let t_of_sexp = (unit_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_unit : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"unit\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ unit_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"unit.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare _ _ = 0\n\n let of_string = function\n | \"()\" -> ()\n | _ -> failwith \"Base.Unit.of_string: () expected\"\n ;;\n\n let to_string () = \"()\"\n let module_name = \"Base.Unit\"\nend\n\ninclude T\ninclude Identifiable.Make (T)\n\nlet invariant () = ()\n","open! Import\n\nlet invalid_argf = Printf.invalid_argf\n\nlet slow_check_pos_len_exn ~pos ~len ~total_length =\n if pos < 0 then invalid_argf \"Negative position: %d\" pos ();\n if len < 0 then invalid_argf \"Negative length: %d\" len ();\n (* We use [pos > total_length - len] rather than [pos + len > total_length] to avoid the\n possibility of overflow. *)\n if pos > total_length - len\n then invalid_argf \"pos + len past end: %d + %d > %d\" pos len total_length ()\n[@@cold] [@@inline never] [@@local never] [@@specialise never]\n;;\n\nlet check_pos_len_exn ~pos ~len ~total_length =\n (* This is better than [slow_check_pos_len_exn] for two reasons:\n\n - much less inlined code\n - only one conditional jump\n\n The reason it works is that checking [< 0] is testing the highest order bit, so\n [a < 0 || b < 0] is the same as [a lor b < 0].\n\n [pos + len] can overflow, so [pos > total_length - len] is not equivalent to\n [total_length - len - pos < 0], we need to test for [pos + len] overflow as\n well. *)\n let stop = pos + len in\n if pos lor len lor stop lor (total_length - stop) < 0\n then slow_check_pos_len_exn ~pos ~len ~total_length\n;;\n\nlet get_pos_len_exn ?(pos = 0) ?len () ~total_length =\n let len =\n match len with\n | Some i -> i\n | None -> total_length - pos\n in\n check_pos_len_exn ~pos ~len ~total_length;\n pos, len\n;;\n\nlet get_pos_len ?pos ?len () ~total_length =\n try Result.Ok (get_pos_len_exn () ?pos ?len ~total_length) with\n | Invalid_argument s -> Or_error.error_string s\n;;\n\nmodule Private = struct\n let slow_check_pos_len_exn = slow_check_pos_len_exn\nend\n","open! Import\n\n(* These functions implement a search for the first (resp. last) element\n satisfying a predicate, assuming that the predicate is increasing on\n the container, meaning that, if the container is [u1...un], there exists a\n k such that p(u1)=....=p(uk) = false and p(uk+1)=....=p(un)= true.\n If this k = 1 (resp n), find_last_not_satisfying (resp find_first_satisfying)\n will return None. *)\n\nlet rec linear_search_first_satisfying t ~get ~lo ~hi ~pred =\n if lo > hi\n then None\n else if pred (get t lo)\n then Some lo\n else linear_search_first_satisfying t ~get ~lo:(lo + 1) ~hi ~pred\n;;\n\n(* Takes a container [t], a predicate [pred] and two indices [lo < hi], such that\n [pred] is increasing on [t] between [lo] and [hi].\n\n return a range (lo, hi) where:\n - lo and hi are close enough together for a linear search\n - If [pred] is not constantly [false] on [t] between [lo] and [hi], the first element\n on which [pred] is [true] is between [lo] and [hi]. *)\n(* Invariant: the first element satisfying [pred], if it exists is between [lo] and [hi] *)\nlet rec find_range_near_first_satisfying t ~get ~lo ~hi ~pred =\n (* Warning: this function will not terminate if the constant (currently 8) is\n set <= 1 *)\n if hi - lo <= 8\n then lo, hi\n else (\n let mid = lo + ((hi - lo) / 2) in\n if pred (get t mid)\n (* INVARIANT check: it means the first satisfying element is between [lo] and [mid] *)\n then\n find_range_near_first_satisfying t ~get ~lo ~hi:mid ~pred\n (* INVARIANT check: it means the first satisfying element, if it exists,\n is between [mid+1] and [hi] *)\n else find_range_near_first_satisfying t ~get ~lo:(mid + 1) ~hi ~pred)\n;;\n\nlet find_first_satisfying ?pos ?len t ~get ~length ~pred =\n let pos, len =\n Ordered_collection_common.get_pos_len_exn () ?pos ?len ~total_length:(length t)\n in\n let lo = pos in\n let hi = pos + len - 1 in\n let lo, hi = find_range_near_first_satisfying t ~get ~lo ~hi ~pred in\n linear_search_first_satisfying t ~get ~lo ~hi ~pred\n;;\n\n(* Takes an array with shape [true,...true,false,...false] (i.e., the _reverse_ of what\n is described above) and returns the index of the last true or None if there are no\n true*)\nlet find_last_satisfying ?pos ?len t ~pred ~get ~length =\n let pos, len =\n Ordered_collection_common.get_pos_len_exn () ?pos ?len ~total_length:(length t)\n in\n if len = 0\n then None\n else (\n (* The last satisfying is the one just before the first not satisfying *)\n match find_first_satisfying ~pos ~len t ~get ~length ~pred:(Fn.non pred) with\n | None -> Some (pos + len - 1)\n (* This means that all elements satisfy pred.\n There is at least an element as (len > 0) *)\n | Some i when i = pos -> None (* no element satisfies pred *)\n | Some i -> Some (i - 1))\n;;\n\nlet binary_search ?pos ?len t ~length ~get ~compare how v =\n match how with\n | `Last_strictly_less_than ->\n find_last_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v < 0)\n | `Last_less_than_or_equal_to ->\n find_last_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v <= 0)\n | `First_equal_to ->\n (match\n find_first_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v >= 0)\n with\n | Some x when compare (get t x) v = 0 -> Some x\n | None | Some _ -> None)\n | `Last_equal_to ->\n (match\n find_last_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v <= 0)\n with\n | Some x when compare (get t x) v = 0 -> Some x\n | None | Some _ -> None)\n | `First_greater_than_or_equal_to ->\n find_first_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v >= 0)\n | `First_strictly_greater_than ->\n find_first_satisfying ?pos ?len t ~get ~length ~pred:(fun x -> compare x v > 0)\n;;\n\nlet binary_search_segmented ?pos ?len t ~length ~get ~segment_of how =\n let is_left x =\n match segment_of x with\n | `Left -> true\n | `Right -> false\n in\n let is_right x = not (is_left x) in\n match how with\n | `Last_on_left -> find_last_satisfying ?pos ?len t ~length ~get ~pred:is_left\n | `First_on_right -> find_first_satisfying ?pos ?len t ~length ~get ~pred:is_right\n;;\n","open! Import\ninclude Binary_searchable_intf\n\nmodule type Arg = sig\n type 'a elt\n type 'a t\n\n val get : 'a t -> int -> 'a elt\n val length : _ t -> int\nend\n\nmodule Make_gen (T : Arg) = struct\n let get = T.get\n let length = T.length\n\n let binary_search ?pos ?len t ~compare how v =\n Binary_search.binary_search ?pos ?len t ~get ~length ~compare how v\n ;;\n\n let binary_search_segmented ?pos ?len t ~segment_of how =\n Binary_search.binary_search_segmented ?pos ?len t ~get ~length ~segment_of how\n ;;\nend\n\nmodule Make (T : Indexable) = Make_gen (struct\n type 'a elt = T.elt\n type 'a t = T.t\n\n include (T : Indexable with type elt := T.elt with type t := T.t)\n end)\n\nmodule Make1 (T : Indexable1) = Make_gen (struct\n type 'a elt = 'a\n type 'a t = 'a T.t\n\n let get = T.get\n let length = T.length\n end)\n","(* [Bytes0] defines string functions that are primitives or can be simply\n defined in terms of [Caml.Bytes]. [Bytes0] is intended to completely express\n the part of [Caml.Bytes] that [Base] uses -- no other file in Base other\n than bytes0.ml should use [Caml.Bytes]. [Bytes0] has few dependencies, and\n so is available early in Base's build order.\n\n All Base files that need to use strings and come before [Base.Bytes] in\n build order should do:\n\n {[\n module Bytes = Bytes0\n ]}\n\n Defining [module Bytes = Bytes0] is also necessary because it prevents\n ocamldep from mistakenly causing a file to depend on [Base.Bytes]. *)\n\nopen! Import0\nmodule Sys = Sys0\n\nmodule Primitives = struct\n external get : bytes -> int -> char = \"%bytes_safe_get\"\n external length : bytes -> int = \"%bytes_length\"\n external unsafe_get : bytes -> int -> char = \"%bytes_unsafe_get\"\n\n include Bytes_set_primitives\n\n (* [unsafe_blit_string] is not exported in the [stdlib] so we export it here *)\n external unsafe_blit_string\n : src:string\n -> src_pos:int\n -> dst:bytes\n -> dst_pos:int\n -> len:int\n -> unit\n = \"caml_blit_string\"\n [@@noalloc]\nend\n\ninclude Primitives\n\nlet max_length = Sys.max_string_length\nlet blit = Caml.Bytes.blit\nlet blit_string = Caml.Bytes.blit_string\nlet compare = Caml.Bytes.compare\nlet copy = Caml.Bytes.copy\nlet create = Caml.Bytes.create\nlet fill = Caml.Bytes.fill\nlet make = Caml.Bytes.make\nlet map = Caml.Bytes.map\nlet mapi = Caml.Bytes.mapi\nlet sub = Caml.Bytes.sub\nlet unsafe_blit = Caml.Bytes.unsafe_blit\nlet to_string = Caml.Bytes.to_string\nlet of_string = Caml.Bytes.of_string\n\nlet unsafe_to_string ~no_mutation_while_string_reachable:s =\n Caml.Bytes.unsafe_to_string s\n;;\n\nlet unsafe_of_string_promise_no_mutation = Caml.Bytes.unsafe_of_string\n","open! Import\ninclude Blit_intf\n\nmodule type Sequence_gen = sig\n type 'a t\n\n val length : _ t -> int\nend\n\nmodule Make_gen\n (Src : Sequence_gen) (Dst : sig\n include Sequence_gen\n\n val create_like : len:int -> 'a Src.t -> 'a t\n val unsafe_blit : ('a Src.t, 'a t) blit\n end) =\nstruct\n let unsafe_blit = Dst.unsafe_blit\n\n let blit ~src ~src_pos ~dst ~dst_pos ~len =\n Ordered_collection_common.check_pos_len_exn\n ~pos:src_pos\n ~len\n ~total_length:(Src.length src);\n Ordered_collection_common.check_pos_len_exn\n ~pos:dst_pos\n ~len\n ~total_length:(Dst.length dst);\n if len > 0 then unsafe_blit ~src ~src_pos ~dst ~dst_pos ~len\n ;;\n\n let blito\n ~src\n ?(src_pos = 0)\n ?(src_len = Src.length src - src_pos)\n ~dst\n ?(dst_pos = 0)\n ()\n =\n blit ~src ~src_pos ~len:src_len ~dst ~dst_pos\n ;;\n\n (* [sub] and [subo] ensure that every position of the created sequence is populated by\n an element of the source array. Thus every element of [dst] below is well\n defined. *)\n let sub src ~pos ~len =\n Ordered_collection_common.check_pos_len_exn ~pos ~len ~total_length:(Src.length src);\n let dst = Dst.create_like ~len src in\n if len > 0 then unsafe_blit ~src ~src_pos:pos ~dst ~dst_pos:0 ~len;\n dst\n ;;\n\n let subo ?(pos = 0) ?len src =\n sub\n src\n ~pos\n ~len:\n (match len with\n | Some i -> i\n | None -> Src.length src - pos)\n ;;\nend\n\nmodule Make1 (Sequence : sig\n include Sequence_gen\n\n val create_like : len:int -> 'a t -> 'a t\n val unsafe_blit : ('a t, 'a t) blit\n end) =\n Make_gen (Sequence) (Sequence)\n\nmodule Make1_generic (Sequence : Sequence1) = Make_gen (Sequence) (Sequence)\n\nmodule Make (Sequence : sig\n include Sequence\n\n val create : len:int -> t\n val unsafe_blit : (t, t) blit\n end) =\nstruct\n module Sequence = struct\n type 'a t = Sequence.t\n\n open Sequence\n\n let create_like ~len _ = create ~len\n let length = length\n let unsafe_blit = unsafe_blit\n end\n\n include Make_gen (Sequence) (Sequence)\nend\n\nmodule Make_distinct\n (Src : Sequence) (Dst : sig\n include Sequence\n\n val create : len:int -> t\n val unsafe_blit : (Src.t, t) blit\n end) =\n Make_gen\n (struct\n type 'a t = Src.t\n\n open Src\n\n let length = length\n end)\n (struct\n type 'a t = Dst.t\n\n open Dst\n\n let length = length\n let create_like ~len _ = create ~len\n let unsafe_blit = unsafe_blit\n end)\n\nmodule Make_to_string (T : sig\n type t\n end)\n (To_bytes : S_distinct with type src := T.t with type dst := bytes) =\nstruct\n open To_bytes\n\n let sub src ~pos ~len =\n Bytes0.unsafe_to_string ~no_mutation_while_string_reachable:(sub src ~pos ~len)\n ;;\n\n let subo ?pos ?len src =\n Bytes0.unsafe_to_string ~no_mutation_while_string_reachable:(subo ?pos ?len src)\n ;;\nend\n","open! Import\n\ntype 'a t = 'a option =\n | None\n | Some of 'a\n\ninclude (\nstruct\n type 'a t = 'a option [@@deriving_inline compare, hash, sexp, sexp_grammar]\n\n let compare : 'a. ('a -> 'a -> int) -> 'a t -> 'a t -> int = compare_option\n\n let hash_fold_t :\n 'a. (Ppx_hash_lib.Std.Hash.state -> 'a -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state -> 'a t -> Ppx_hash_lib.Std.Hash.state\n =\n hash_fold_option\n ;;\n\n let t_of_sexp :\n 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t\n =\n option_of_sexp\n ;;\n\n let sexp_of_t :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t\n =\n sexp_of_option\n ;;\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group)\n =\n { implicit_vars = [ \"option\" ]\n ; ggid = \"j\\132);\\135qH\\158\\135\\222H\\001\\007\\004\\158\\218\"\n ; types =\n [ \"t\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ])) ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ option_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"option.ml\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\nend :\nsig\n type 'a t = 'a option [@@deriving_inline compare, hash, sexp, sexp_grammar]\n\n val compare : ('a -> 'a -> int) -> 'a t -> 'a t -> int\n\n val hash_fold_t\n : (Ppx_hash_lib.Std.Hash.state -> 'a -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state\n -> 'a t\n -> Ppx_hash_lib.Std.Hash.state\n\n include Ppx_sexp_conv_lib.Sexpable.S1 with type 'a t := 'a t\n\n val t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t\n\n [@@@end]\nend\nwith type 'a t := 'a t)\n\nlet is_none = function\n | None -> true\n | _ -> false\n;;\n\nlet is_some = function\n | Some _ -> true\n | _ -> false\n;;\n\nlet value_map o ~default ~f =\n match o with\n | Some x -> f x\n | None -> default\n;;\n\nlet iter o ~f =\n match o with\n | None -> ()\n | Some a -> f a\n;;\n\nlet invariant f t = iter t ~f\n\nlet map2 o1 o2 ~f =\n match o1, o2 with\n | Some a1, Some a2 -> Some (f a1 a2)\n | _ -> None\n;;\n\nlet call x ~f =\n match f with\n | None -> ()\n | Some f -> f x\n;;\n\nlet value t ~default =\n match t with\n | None -> default\n | Some x -> x\n;;\n\nlet value_exn ?here ?error ?message t =\n match t with\n | Some x -> x\n | None ->\n let error =\n match here, error, message with\n | None, None, None -> Error.of_string \"Option.value_exn None\"\n | None, None, Some m -> Error.of_string m\n | None, Some e, None -> e\n | None, Some e, Some m -> Error.tag e ~tag:m\n | Some p, None, None ->\n Error.create \"Option.value_exn\" p Source_code_position0.sexp_of_t\n | Some p, None, Some m -> Error.create m p Source_code_position0.sexp_of_t\n | Some p, Some e, _ ->\n Error.create\n (value message ~default:\"\")\n (e, p)\n (sexp_of_pair Error.sexp_of_t Source_code_position0.sexp_of_t)\n in\n Error.raise error\n;;\n\nlet to_array t =\n match t with\n | None -> [||]\n | Some x -> [| x |]\n;;\n\nlet to_list t =\n match t with\n | None -> []\n | Some x -> [ x ]\n;;\n\nlet min_elt t ~compare:_ = t\nlet max_elt t ~compare:_ = t\n\nlet sum (type a) (module M : Container.Summable with type t = a) t ~f =\n match t with\n | None -> M.zero\n | Some x -> f x\n;;\n\nlet for_all t ~f =\n match t with\n | None -> true\n | Some x -> f x\n;;\n\nlet exists t ~f =\n match t with\n | None -> false\n | Some x -> f x\n;;\n\nlet mem t a ~equal =\n match t with\n | None -> false\n | Some a' -> equal a a'\n;;\n\nlet length t =\n match t with\n | None -> 0\n | Some _ -> 1\n;;\n\nlet is_empty = is_none\n\nlet fold t ~init ~f =\n match t with\n | None -> init\n | Some x -> f init x\n;;\n\nlet count t ~f =\n match t with\n | None -> 0\n | Some a -> if f a then 1 else 0\n;;\n\nlet find t ~f =\n match t with\n | None -> None\n | Some x -> if f x then Some x else None\n;;\n\nlet find_map t ~f =\n match t with\n | None -> None\n | Some a -> f a\n;;\n\nlet equal f t t' =\n match t, t' with\n | None, None -> true\n | Some x, Some x' -> f x x'\n | _ -> false\n;;\n\nlet some x = Some x\n\nlet both x y =\n match x, y with\n | Some a, Some b -> Some (a, b)\n | _ -> None\n;;\n\nlet first_some x y =\n match x with\n | Some _ -> x\n | None -> y\n;;\n\nlet some_if cond x = if cond then Some x else None\n\nlet merge a b ~f =\n match a, b with\n | None, x | x, None -> x\n | Some a, Some b -> Some (f a b)\n;;\n\nlet filter t ~f =\n match t with\n | Some v as o when f v -> o\n | _ -> None\n;;\n\nlet try_with f =\n match f () with\n | x -> Some x\n | exception _ -> None\n;;\n\nlet try_with_join f =\n match f () with\n | x -> x\n | exception _ -> None\n;;\n\ninclude Monad.Make (struct\n type 'a t = 'a option\n\n let return x = Some x\n\n let map t ~f =\n match t with\n | None -> None\n | Some a -> Some (f a)\n ;;\n\n let map = `Custom map\n\n let bind o ~f =\n match o with\n | None -> None\n | Some x -> f x\n ;;\n end)\n\nlet fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\nlet fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\n\nlet validate ~none ~some t =\n let module V = Validate in\n match t with\n | None -> V.name \"none\" (V.protect none ())\n | Some x -> V.name \"some\" (V.protect some x)\n;;\n","open! Import\ninclude Either_intf\nmodule Array = Array0\nmodule List = List0\ninclude Either0\n\nlet swap = function\n | First x -> Second x\n | Second x -> First x\n;;\n\nlet is_first = function\n | First _ -> true\n | Second _ -> false\n;;\n\nlet is_second = function\n | First _ -> false\n | Second _ -> true\n;;\n\nlet value (First x | Second x) = x\n\nlet value_map t ~first ~second =\n match t with\n | First x -> first x\n | Second x -> second x\n;;\n\nlet iter = value_map\n\nlet map t ~first ~second =\n match t with\n | First x -> First (first x)\n | Second x -> Second (second x)\n;;\n\nlet first x = First x\nlet second x = Second x\n\nlet equal eq1 eq2 t1 t2 =\n match t1, t2 with\n | First x, First y -> eq1 x y\n | Second x, Second y -> eq2 x y\n | First _, Second _ | Second _, First _ -> false\n;;\n\nlet invariant f s = function\n | First x -> f x\n | Second y -> s y\n;;\n\nmodule Make_focused (M : sig\n type (+'a, +'b) t\n\n val return : 'a -> ('a, _) t\n val other : 'b -> (_, 'b) t\n val either : ('a, 'b) t -> return:('a -> 'c) -> other:('b -> 'c) -> 'c\n\n val combine\n : ('a, 'd) t\n -> ('b, 'd) t\n -> f:('a -> 'b -> 'c)\n -> other:('d -> 'd -> 'd)\n -> ('c, 'd) t\n\n val bind : ('a, 'b) t -> f:('a -> ('c, 'b) t) -> ('c, 'b) t\n end) =\nstruct\n include M\n open With_return\n\n let map t ~f = bind t ~f:(fun x -> return (f x))\n\n include Monad.Make2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n\n let return = return\n let bind = bind\n let map = `Custom map\n end)\n\n module App = Applicative.Make2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n\n let return = return\n let apply t1 t2 = bind t1 ~f:(fun f -> bind t2 ~f:(fun x -> return (f x)))\n let map = `Custom map\n end)\n\n include App\n\n let combine_all =\n let rec other_loop f acc = function\n | [] -> other acc\n | t :: ts ->\n either\n t\n ~return:(fun _ -> other_loop f acc ts)\n ~other:(fun o -> other_loop f (f acc o) ts)\n in\n let rec return_loop f acc = function\n | [] -> return (List.rev acc)\n | t :: ts ->\n either\n t\n ~return:(fun x -> return_loop f (x :: acc) ts)\n ~other:(fun o -> other_loop f o ts)\n in\n fun ts ~f -> return_loop f [] ts\n ;;\n\n let combine_all_unit =\n let rec other_loop f acc = function\n | [] -> other acc\n | t :: ts ->\n either\n t\n ~return:(fun () -> other_loop f acc ts)\n ~other:(fun o -> other_loop f (f acc o) ts)\n in\n let rec return_loop f = function\n | [] -> return ()\n | t :: ts ->\n either t ~return:(fun () -> return_loop f ts) ~other:(fun o -> other_loop f o ts)\n in\n fun ts ~f -> return_loop f ts\n ;;\n\n let to_option t = either t ~return:Option.some ~other:(fun _ -> None)\n let value t ~default = either t ~return:Fn.id ~other:(fun _ -> default)\n\n let with_return f =\n with_return (fun ret -> other (f (With_return.prepend ret ~f:return)))\n ;;\nend\n\nmodule First = Make_focused (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n\n let return = first\n let other = second\n\n let either t ~return ~other =\n match t with\n | First x -> return x\n | Second y -> other y\n ;;\n\n let combine t1 t2 ~f ~other =\n match t1, t2 with\n | First x, First y -> First (f x y)\n | Second x, Second y -> Second (other x y)\n | Second x, _ | _, Second x -> Second x\n ;;\n\n let bind t ~f =\n match t with\n | First x -> f x\n (* Reuse the value in order to avoid allocation. *)\n | Second _ as y -> y\n ;;\n end)\n\nmodule Second = Make_focused (struct\n type nonrec ('a, 'b) t = ('b, 'a) t\n\n let return = second\n let other = first\n\n let either t ~return ~other =\n match t with\n | Second y -> return y\n | First x -> other x\n ;;\n\n let combine t1 t2 ~f ~other =\n match t1, t2 with\n | Second x, Second y -> Second (f x y)\n | First x, First y -> First (other x y)\n | First x, _ | _, First x -> First x\n ;;\n\n let bind t ~f =\n match t with\n | Second x -> f x\n (* Reuse the value in order to avoid allocation, like [First.bind] above. *)\n | First _ as y -> y\n ;;\n end)\n\nmodule Export = struct\n type ('f, 's) _either = ('f, 's) t =\n | First of 'f\n | Second of 's\nend\n","include Indexed_container_intf\n\nlet with_return = With_return.with_return\n\nlet iteri ~fold t ~f =\n ignore\n (fold t ~init:0 ~f:(fun i x ->\n f i x;\n i + 1)\n : int)\n;;\n\nlet foldi ~fold t ~init ~f =\n let i = ref 0 in\n fold t ~init ~f:(fun acc v ->\n let acc = f !i acc v in\n i := !i + 1;\n acc)\n;;\n\nlet counti ~foldi t ~f = foldi t ~init:0 ~f:(fun i n a -> if f i a then n + 1 else n)\n\nlet existsi ~iteri c ~f =\n with_return (fun r ->\n iteri c ~f:(fun i x -> if f i x then r.return true);\n false)\n;;\n\nlet for_alli ~iteri c ~f =\n with_return (fun r ->\n iteri c ~f:(fun i x -> if not (f i x) then r.return false);\n true)\n;;\n\nlet find_mapi ~iteri t ~f =\n with_return (fun r ->\n iteri t ~f:(fun i x ->\n match f i x with\n | None -> ()\n | Some _ as res -> r.return res);\n None)\n;;\n\nlet findi ~iteri c ~f =\n with_return (fun r ->\n iteri c ~f:(fun i x -> if f i x then r.return (Some (i, x)));\n None)\n;;\n\nmodule Make (T : Make_arg) : S1 with type 'a t := 'a T.t = struct\n include Container.Make (T)\n\n let iteri =\n match T.iteri with\n | `Custom iteri -> iteri\n | `Define_using_fold -> fun t ~f -> iteri ~fold t ~f\n ;;\n\n let foldi =\n match T.foldi with\n | `Custom foldi -> foldi\n | `Define_using_fold -> fun t ~init ~f -> foldi ~fold t ~init ~f\n ;;\n\n let counti t ~f = counti ~foldi t ~f\n let existsi t ~f = existsi ~iteri t ~f\n let for_alli t ~f = for_alli ~iteri t ~f\n let find_mapi t ~f = find_mapi ~iteri t ~f\n let findi t ~f = findi ~iteri t ~f\nend\n","open! Import\nopen Container_intf.Export\nmodule Array = Array0\nmodule List = List1\n\nmodule Step = struct\n (* 'a is an item in the sequence, 's is the state that will produce the remainder of\n the sequence *)\n type ('a, 's) t =\n | Done\n | Skip of 's\n | Yield of 'a * 's\n [@@deriving_inline sexp_of]\n\n let sexp_of_t\n : type a s.\n (a -> Ppx_sexp_conv_lib.Sexp.t)\n -> (s -> Ppx_sexp_conv_lib.Sexp.t)\n -> (a, s) t\n -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a _of_s -> function\n | Done -> Ppx_sexp_conv_lib.Sexp.Atom \"Done\"\n | Skip v0 ->\n let v0 = _of_s v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Skip\"; v0 ]\n | Yield (v0, v1) ->\n let v0 = _of_a v0\n and v1 = _of_s v1 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Yield\"; v0; v1 ]\n ;;\n\n [@@@end]\nend\n\nopen Step\n\n(* 'a is an item in the sequence, 's is the state that will produce the remainder of the\n sequence *)\ntype +_ t = Sequence : 's * ('s -> ('a, 's) Step.t) -> 'a t\ntype 'a sequence = 'a t\n\nmodule Expert = struct\n let next_step (Sequence (s, f)) =\n match f s with\n | Done -> Done\n | Skip s -> Skip (Sequence (s, f))\n | Yield (a, s) -> Yield (a, Sequence (s, f))\n ;;\n\n let delayed_fold_step s ~init ~f ~finish =\n let rec loop s next finish f acc =\n match next s with\n | Done -> finish acc\n | Skip s -> f acc None ~k:(loop s next finish f)\n | Yield (a, s) -> f acc (Some a) ~k:(loop s next finish f)\n in\n match s with\n | Sequence (s, next) -> loop s next finish f init\n ;;\nend\n\nlet unfold_step ~init ~f = Sequence (init, f)\n\nlet unfold ~init ~f =\n unfold_step ~init ~f:(fun s ->\n match f s with\n | None -> Step.Done\n | Some (a, s) -> Step.Yield (a, s))\n;;\n\nlet unfold_with s ~init ~f =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( (init, s)\n , fun (seed, s) ->\n match next s with\n | Done -> Done\n | Skip s -> Skip (seed, s)\n | Yield (a, s) ->\n (match f seed a with\n | Done -> Done\n | Skip seed -> Skip (seed, s)\n | Yield (a, seed) -> Yield (a, (seed, s))) )\n;;\n\nlet unfold_with_and_finish s ~init ~running_step ~inner_finished ~finishing_step =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( `Inner_running (init, s)\n , fun state ->\n match state with\n | `Inner_running (state, inner_state) ->\n (match next inner_state with\n | Done -> Skip (`Inner_finished (inner_finished state))\n | Skip inner_state -> Skip (`Inner_running (state, inner_state))\n | Yield (x, inner_state) ->\n (match running_step state x with\n | Done -> Done\n | Skip state -> Skip (`Inner_running (state, inner_state))\n | Yield (y, state) -> Yield (y, `Inner_running (state, inner_state))))\n | `Inner_finished state ->\n (match finishing_step state with\n | Done -> Done\n | Skip state -> Skip (`Inner_finished state)\n | Yield (y, state) -> Yield (y, `Inner_finished state)) )\n;;\n\nlet of_list l =\n unfold_step ~init:l ~f:(function\n | [] -> Done\n | x :: l -> Yield (x, l))\n;;\n\n\nlet fold t ~init ~f =\n let rec loop seed v next f =\n match next seed with\n | Done -> v\n | Skip s -> loop s v next f\n | Yield (a, s) -> loop s (f v a) next f\n in\n match t with\n | Sequence (seed, next) -> loop seed init next f\n;;\n\nlet to_list_rev t = fold t ~init:[] ~f:(fun l x -> x :: l)\n\n\nlet to_list (Sequence (s, next)) =\n let safe_to_list t = List.rev (to_list_rev t) in\n let rec to_list s next i =\n if i = 0\n then safe_to_list (Sequence (s, next))\n else (\n match next s with\n | Done -> []\n | Skip s -> to_list s next i\n | Yield (a, s) -> a :: to_list s next (i - 1))\n in\n to_list s next 500\n;;\n\nlet sexp_of_t sexp_of_a t = sexp_of_list sexp_of_a (to_list t)\n\nlet range ?(stride = 1) ?(start = `inclusive) ?(stop = `exclusive) start_v stop_v =\n let step =\n match stop with\n | `inclusive when stride >= 0 ->\n fun i -> if i > stop_v then Done else Yield (i, i + stride)\n | `inclusive -> fun i -> if i < stop_v then Done else Yield (i, i + stride)\n | `exclusive when stride >= 0 ->\n fun i -> if i >= stop_v then Done else Yield (i, i + stride)\n | `exclusive -> fun i -> if i <= stop_v then Done else Yield (i, i + stride)\n in\n let init =\n match start with\n | `inclusive -> start_v\n | `exclusive -> start_v + stride\n in\n unfold_step ~init ~f:step\n;;\n\nlet of_lazy t_lazy =\n unfold_step ~init:t_lazy ~f:(fun t_lazy ->\n let (Sequence (s, next)) = Lazy.force t_lazy in\n match next s with\n | Done -> Done\n | Skip s ->\n Skip\n (let v = Sequence (s, next) in\n lazy v)\n | Yield (x, s) ->\n Yield\n ( x\n , let v = Sequence (s, next) in\n lazy v ))\n;;\n\nlet map t ~f =\n match t with\n | Sequence (seed, next) ->\n Sequence\n ( seed\n , fun seed ->\n match next seed with\n | Done -> Done\n | Skip s -> Skip s\n | Yield (a, s) -> Yield (f a, s) )\n;;\n\nlet mapi t ~f =\n match t with\n | Sequence (s, next) ->\n Sequence\n ( (0, s)\n , fun (i, s) ->\n match next s with\n | Done -> Done\n | Skip s -> Skip (i, s)\n | Yield (a, s) -> Yield (f i a, (i + 1, s)) )\n;;\n\nlet folding_map t ~init ~f =\n unfold_with t ~init ~f:(fun acc x ->\n let acc, x = f acc x in\n Yield (x, acc))\n;;\n\nlet folding_mapi t ~init ~f =\n unfold_with t ~init:(0, init) ~f:(fun (i, acc) x ->\n let acc, x = f i acc x in\n Yield (x, (i + 1, acc)))\n;;\n\nlet filter t ~f =\n match t with\n | Sequence (seed, next) ->\n Sequence\n ( seed\n , fun seed ->\n match next seed with\n | Done -> Done\n | Skip s -> Skip s\n | Yield (a, s) when f a -> Yield (a, s)\n | Yield (_, s) -> Skip s )\n;;\n\nlet filteri t ~f =\n map ~f:snd (filter (mapi t ~f:(fun i s -> i, s)) ~f:(fun (i, s) -> f i s))\n;;\n\nlet length t =\n let rec loop i s next =\n match next s with\n | Done -> i\n | Skip s -> loop i s next\n | Yield (_, s) -> loop (i + 1) s next\n in\n match t with\n | Sequence (seed, next) -> loop 0 seed next\n;;\n\nlet to_list_rev_with_length t = fold t ~init:([], 0) ~f:(fun (l, i) x -> x :: l, i + 1)\n\nlet to_array t =\n let l, len = to_list_rev_with_length t in\n match l with\n | [] -> [||]\n | x :: l ->\n let a = Array.create ~len x in\n let rec loop i l =\n match l with\n | [] -> assert (i = -1)\n | x :: l ->\n a.(i) <- x;\n loop (i - 1) l\n in\n loop (len - 2) l;\n a\n;;\n\nlet find t ~f =\n let rec loop s next f =\n match next s with\n | Done -> None\n | Yield (a, _) when f a -> Some a\n | Yield (_, s) | Skip s -> loop s next f\n in\n match t with\n | Sequence (seed, next) -> loop seed next f\n;;\n\nlet find_map t ~f =\n let rec loop s next f =\n match next s with\n | Done -> None\n | Yield (a, s) ->\n (match f a with\n | None -> loop s next f\n | some_b -> some_b)\n | Skip s -> loop s next f\n in\n match t with\n | Sequence (seed, next) -> loop seed next f\n;;\n\n\nlet find_mapi t ~f =\n let rec loop s next f i =\n match next s with\n | Done -> None\n | Yield (a, s) ->\n (match f i a with\n | None -> loop s next f (i + 1)\n | some_b -> some_b)\n | Skip s -> loop s next f i\n in\n match t with\n | Sequence (seed, next) -> loop seed next f 0\n;;\n\nlet for_all t ~f =\n let rec loop s next f =\n match next s with\n | Done -> true\n | Yield (a, _) when not (f a) -> false\n | Yield (_, s) | Skip s -> loop s next f\n in\n match t with\n | Sequence (seed, next) -> loop seed next f\n;;\n\nlet for_alli t ~f =\n let rec loop s next f i =\n match next s with\n | Done -> true\n | Yield (a, _) when not (f i a) -> false\n | Yield (_, s) -> loop s next f (i + 1)\n | Skip s -> loop s next f i\n in\n match t with\n | Sequence (seed, next) -> loop seed next f 0\n;;\n\nlet exists t ~f =\n let rec loop s next f =\n match next s with\n | Done -> false\n | Yield (a, _) when f a -> true\n | Yield (_, s) | Skip s -> loop s next f\n in\n match t with\n | Sequence (seed, next) -> loop seed next f\n;;\n\nlet existsi t ~f =\n let rec loop s next f i =\n match next s with\n | Done -> false\n | Yield (a, _) when f i a -> true\n | Yield (_, s) -> loop s next f (i + 1)\n | Skip s -> loop s next f i\n in\n match t with\n | Sequence (seed, next) -> loop seed next f 0\n;;\n\nlet iter t ~f =\n let rec loop seed next f =\n match next seed with\n | Done -> ()\n | Skip s -> loop s next f\n | Yield (a, s) ->\n f a;\n loop s next f\n in\n match t with\n | Sequence (seed, next) -> loop seed next f\n;;\n\nlet is_empty t =\n let rec loop s next =\n match next s with\n | Done -> true\n | Skip s -> loop s next\n | Yield _ -> false\n in\n match t with\n | Sequence (seed, next) -> loop seed next\n;;\n\nlet mem t a ~equal =\n let rec loop s next a =\n match next s with\n | Done -> false\n | Yield (b, _) when equal a b -> true\n | Yield (_, s) | Skip s -> loop s next a\n in\n match t with\n | Sequence (seed, next) -> loop seed next a\n;;\n\nlet empty = Sequence ((), fun () -> Done)\n\nlet bind t ~f =\n unfold_step\n ~f:(function\n | Sequence (seed, next), rest ->\n (match next seed with\n | Done ->\n (match rest with\n | Sequence (seed, next) ->\n (match next seed with\n | Done -> Done\n | Skip s -> Skip (empty, Sequence (s, next))\n | Yield (a, s) -> Skip (f a, Sequence (s, next))))\n | Skip s -> Skip (Sequence (s, next), rest)\n | Yield (a, s) -> Yield (a, (Sequence (s, next), rest))))\n ~init:(empty, t)\n;;\n\nlet return x =\n unfold_step ~init:(Some x) ~f:(function\n | None -> Done\n | Some x -> Yield (x, None))\n;;\n\ninclude Monad.Make (struct\n type nonrec 'a t = 'a t\n\n let map = `Custom map\n let bind = bind\n let return = return\n end)\n\nlet nth s n =\n if n < 0\n then None\n else (\n let rec loop i s next =\n match next s with\n | Done -> None\n | Skip s -> loop i s next\n | Yield (a, s) -> if phys_equal i 0 then Some a else loop (i - 1) s next\n in\n match s with\n | Sequence (s, next) -> loop n s next)\n;;\n\nlet nth_exn s n =\n if n < 0\n then invalid_arg \"Sequence.nth\"\n else (\n match nth s n with\n | None -> failwith \"Sequence.nth\"\n | Some x -> x)\n;;\n\nmodule Merge_with_duplicates_element = struct\n type ('a, 'b) t =\n | Left of 'a\n | Right of 'b\n | Both of 'a * 'b\n [@@deriving_inline compare, hash, sexp]\n\n let compare :\n 'a 'b. ('a -> 'a -> int) -> ('b -> 'b -> int) -> ('a, 'b) t -> ('a, 'b) t -> int\n =\n fun _cmp__a _cmp__b a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match a__001_, b__002_ with\n | Left _a__003_, Left _b__004_ -> _cmp__a _a__003_ _b__004_\n | Left _, _ -> -1\n | _, Left _ -> 1\n | Right _a__005_, Right _b__006_ -> _cmp__b _a__005_ _b__006_\n | Right _, _ -> -1\n | _, Right _ -> 1\n | Both (_a__007_, _a__009_), Both (_b__008_, _b__010_) ->\n (match _cmp__a _a__007_ _b__008_ with\n | 0 -> _cmp__b _a__009_ _b__010_\n | n -> n))\n ;;\n\n let hash_fold_t\n : type a b.\n (Ppx_hash_lib.Std.Hash.state -> a -> Ppx_hash_lib.Std.Hash.state)\n -> (Ppx_hash_lib.Std.Hash.state -> b -> Ppx_hash_lib.Std.Hash.state)\n -> Ppx_hash_lib.Std.Hash.state\n -> (a, b) t\n -> Ppx_hash_lib.Std.Hash.state\n =\n fun _hash_fold_a _hash_fold_b hsv arg ->\n match arg with\n | Left _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 0 in\n let hsv = hsv in\n _hash_fold_a hsv _a0\n | Right _a0 ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 1 in\n let hsv = hsv in\n _hash_fold_b hsv _a0\n | Both (_a0, _a1) ->\n let hsv = Ppx_hash_lib.Std.Hash.fold_int hsv 2 in\n let hsv =\n let hsv = hsv in\n _hash_fold_a hsv _a0\n in\n _hash_fold_b hsv _a1\n ;;\n\n let t_of_sexp\n : type a b.\n (Ppx_sexp_conv_lib.Sexp.t -> a)\n -> (Ppx_sexp_conv_lib.Sexp.t -> b)\n -> Ppx_sexp_conv_lib.Sexp.t\n -> (a, b) t\n =\n let _tp_loc = \"sequence.ml.Merge_with_duplicates_element.t\" in\n fun _of_a _of_b -> function\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"left\" | \"Left\") as _tag) :: sexp_args) as _sexp\n ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_a v0 in\n Left v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"right\" | \"Right\") as _tag) :: sexp_args) as\n _sexp ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_b v0 in\n Right v0\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom ((\"both\" | \"Both\") as _tag) :: sexp_args) as _sexp\n ->\n (match sexp_args with\n | [ v0; v1 ] ->\n let v0 = _of_a v0\n and v1 = _of_b v1 in\n Both (v0, v1)\n | _ -> Ppx_sexp_conv_lib.Conv_error.stag_incorrect_n_args _tp_loc _tag _sexp)\n | Ppx_sexp_conv_lib.Sexp.Atom (\"left\" | \"Left\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.Atom (\"right\" | \"Right\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.Atom (\"both\" | \"Both\") as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_takes_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n ;;\n\n let sexp_of_t\n : type a b.\n (a -> Ppx_sexp_conv_lib.Sexp.t)\n -> (b -> Ppx_sexp_conv_lib.Sexp.t)\n -> (a, b) t\n -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a _of_b -> function\n | Left v0 ->\n let v0 = _of_a v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Left\"; v0 ]\n | Right v0 ->\n let v0 = _of_b v0 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Right\"; v0 ]\n | Both (v0, v1) ->\n let v0 = _of_a v0\n and v1 = _of_b v1 in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Both\"; v0; v1 ]\n ;;\n\n [@@@end]\nend\n\nlet merge_with_duplicates (Sequence (s1, next1)) (Sequence (s2, next2)) ~compare =\n let unshadowed_compare = compare in\n let open Merge_with_duplicates_element in\n let next = function\n | Skip s1, s2 -> Skip (next1 s1, s2)\n | s1, Skip s2 -> Skip (s1, next2 s2)\n | (Yield (a, s1') as s1), (Yield (b, s2') as s2) ->\n let comparison = unshadowed_compare a b in\n if comparison < 0\n then Yield (Left a, (Skip s1', s2))\n else if comparison = 0\n then Yield (Both (a, b), (Skip s1', Skip s2'))\n else Yield (Right b, (s1, Skip s2'))\n | Done, Done -> Done\n | Yield (a, s1), Done -> Yield (Left a, (Skip s1, Done))\n | Done, Yield (b, s2) -> Yield (Right b, (Done, Skip s2))\n in\n Sequence ((Skip s1, Skip s2), next)\n;;\n\nlet merge s1 s2 ~compare =\n map (merge_with_duplicates s1 s2 ~compare) ~f:(function\n | Left x | Right x | Both (x, _) -> x)\n;;\n\nlet hd s =\n let rec loop s next =\n match next s with\n | Done -> None\n | Skip s -> loop s next\n | Yield (a, _) -> Some a\n in\n match s with\n | Sequence (s, next) -> loop s next\n;;\n\nlet hd_exn s =\n match hd s with\n | None -> failwith \"hd_exn\"\n | Some a -> a\n;;\n\nlet tl s =\n let rec loop s next =\n match next s with\n | Done -> None\n | Skip s -> loop s next\n | Yield (_, a) -> Some a\n in\n match s with\n | Sequence (s, next) ->\n (match loop s next with\n | None -> None\n | Some s -> Some (Sequence (s, next)))\n;;\n\nlet tl_eagerly_exn s =\n match tl s with\n | None -> failwith \"Sequence.tl_exn\"\n | Some s -> s\n;;\n\nlet lift_identity next s =\n match next s with\n | Done -> Done\n | Skip s -> Skip (`Identity s)\n | Yield (a, s) -> Yield (a, `Identity s)\n;;\n\nlet next s =\n let rec loop s next =\n match next s with\n | Done -> None\n | Skip s -> loop s next\n | Yield (a, s) -> Some (a, Sequence (s, next))\n in\n match s with\n | Sequence (s, next) -> loop s next\n;;\n\nlet filter_opt s =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( s\n , fun s ->\n match next s with\n | Done -> Done\n | Skip s -> Skip s\n | Yield (None, s) -> Skip s\n | Yield (Some a, s) -> Yield (a, s) )\n;;\n\nlet filter_map s ~f = filter_opt (map s ~f)\nlet filter_mapi s ~f = filter_map (mapi s ~f:(fun i s -> i, s)) ~f:(fun (i, s) -> f i s)\n\nlet split_n s n =\n let rec loop s i accum next =\n if i <= 0\n then List.rev accum, Sequence (s, next)\n else (\n match next s with\n | Done -> List.rev accum, empty\n | Skip s -> loop s i accum next\n | Yield (a, s) -> loop s (i - 1) (a :: accum) next)\n in\n match s with\n | Sequence (s, next) -> loop s n [] next\n;;\n\nlet chunks_exn t n =\n if n <= 0\n then invalid_arg \"Sequence.chunks_exn\"\n else\n unfold_step ~init:t ~f:(fun t ->\n match split_n t n with\n | [], _empty -> Done\n | (_ :: _ as xs), t -> Yield (xs, t))\n;;\n\nlet findi s ~f = find (mapi s ~f:(fun i s -> i, s)) ~f:(fun (i, s) -> f i s)\n\nlet find_exn s ~f =\n match find s ~f with\n | None -> failwith \"Sequence.find_exn\"\n | Some x -> x\n;;\n\nlet append s1 s2 =\n match s1, s2 with\n | Sequence (s1, next1), Sequence (s2, next2) ->\n Sequence\n ( `First_list s1\n , function\n | `First_list s1 ->\n (match next1 s1 with\n | Done -> Skip (`Second_list s2)\n | Skip s1 -> Skip (`First_list s1)\n | Yield (a, s1) -> Yield (a, `First_list s1))\n | `Second_list s2 ->\n (match next2 s2 with\n | Done -> Done\n | Skip s2 -> Skip (`Second_list s2)\n | Yield (a, s2) -> Yield (a, `Second_list s2)) )\n;;\n\nlet concat_map s ~f = bind s ~f\nlet concat s = concat_map s ~f:Fn.id\nlet concat_mapi s ~f = concat_map (mapi s ~f:(fun i s -> i, s)) ~f:(fun (i, s) -> f i s)\n\nlet zip (Sequence (s1, next1)) (Sequence (s2, next2)) =\n let next = function\n | Yield (a, s1), Yield (b, s2) -> Yield ((a, b), (Skip s1, Skip s2))\n | Done, _ | _, Done -> Done\n | Skip s1, s2 -> Skip (next1 s1, s2)\n | s1, Skip s2 -> Skip (s1, next2 s2)\n in\n Sequence ((Skip s1, Skip s2), next)\n;;\n\nlet zip_full (Sequence (s1, next1)) (Sequence (s2, next2)) =\n let next = function\n | Yield (a, s1), Yield (b, s2) -> Yield (`Both (a, b), (Skip s1, Skip s2))\n | Done, Done -> Done\n | Skip s1, s2 -> Skip (next1 s1, s2)\n | s1, Skip s2 -> Skip (s1, next2 s2)\n | Done, Yield (b, s2) -> Yield (`Right b, (Done, next2 s2))\n | Yield (a, s1), Done -> Yield (`Left a, (next1 s1, Done))\n in\n Sequence ((Skip s1, Skip s2), next)\n;;\n\nlet bounded_length (Sequence (seed, next)) ~at_most =\n let rec loop i seed next =\n if i > at_most\n then `Greater\n else (\n match next seed with\n | Done -> `Is i\n | Skip seed -> loop i seed next\n | Yield (_, seed) -> loop (i + 1) seed next)\n in\n loop 0 seed next\n;;\n\nlet length_is_bounded_by ?(min = -1) ?max t =\n let length_is_at_least (Sequence (s, next)) =\n let rec loop s acc =\n if acc >= min\n then true\n else (\n match next s with\n | Done -> false\n | Skip s -> loop s acc\n | Yield (_, s) -> loop s (acc + 1))\n in\n loop s 0\n in\n match max with\n | None -> length_is_at_least t\n | Some max ->\n (match bounded_length t ~at_most:max with\n | `Is len when len >= min -> true\n | _ -> false)\n;;\n\nlet iteri s ~f = iter (mapi s ~f:(fun i s -> i, s)) ~f:(fun (i, s) -> f i s)\n\nlet foldi s ~init ~f =\n fold ~init (mapi s ~f:(fun i s -> i, s)) ~f:(fun acc (i, s) -> f i acc s)\n;;\n\nlet reduce s ~f =\n match next s with\n | None -> None\n | Some (a, s) -> Some (fold s ~init:a ~f)\n;;\n\nlet reduce_exn s ~f =\n match reduce s ~f with\n | None -> failwith \"Sequence.reduce_exn\"\n | Some res -> res\n;;\n\nlet group (Sequence (s, next)) ~break =\n unfold_step\n ~init:(Some ([], s))\n ~f:(function\n | None -> Done\n | Some (acc, s) ->\n (match acc, next s with\n | _, Skip s -> Skip (Some (acc, s))\n | [], Done -> Done\n | acc, Done -> Yield (List.rev acc, None)\n | [], Yield (cur, s) -> Skip (Some ([ cur ], s))\n | (prev :: _ as acc), Yield (cur, s) ->\n if break prev cur\n then Yield (List.rev acc, Some ([ cur ], s))\n else Skip (Some (cur :: acc, s))))\n;;\n\nlet find_consecutive_duplicate (Sequence (s, next)) ~equal =\n let rec loop last_elt s =\n match next s with\n | Done -> None\n | Skip s -> loop last_elt s\n | Yield (a, s) ->\n (match last_elt with\n | Some b when equal a b -> Some (b, a)\n | None | Some _ -> loop (Some a) s)\n in\n loop None s\n;;\n\nlet remove_consecutive_duplicates s ~equal =\n unfold_with s ~init:None ~f:(fun prev a ->\n match prev with\n | Some b when equal a b -> Skip (Some a)\n | None | Some _ -> Yield (a, Some a))\n;;\n\nlet count s ~f = length (filter s ~f)\nlet counti t ~f = length (filteri t ~f)\nlet sum m t ~f = Container.sum ~fold m t ~f\nlet min_elt t ~compare = Container.min_elt ~fold t ~compare\nlet max_elt t ~compare = Container.max_elt ~fold t ~compare\n\nlet init n ~f =\n unfold_step ~init:0 ~f:(fun i -> if i >= n then Done else Yield (f i, i + 1))\n;;\n\nlet sub s ~pos ~len =\n if pos < 0 || len < 0 then failwith \"Sequence.sub\";\n match s with\n | Sequence (s, next) ->\n Sequence\n ( (0, s)\n , fun (i, s) ->\n if i - pos >= len\n then Done\n else (\n match next s with\n | Done -> Done\n | Skip s -> Skip (i, s)\n | Yield (a, s) when i >= pos -> Yield (a, (i + 1, s))\n | Yield (_, s) -> Skip (i + 1, s)) )\n;;\n\nlet take s len =\n if len < 0 then failwith \"Sequence.take\";\n match s with\n | Sequence (s, next) ->\n Sequence\n ( (0, s)\n , fun (i, s) ->\n if i >= len\n then Done\n else (\n match next s with\n | Done -> Done\n | Skip s -> Skip (i, s)\n | Yield (a, s) -> Yield (a, (i + 1, s))) )\n;;\n\nlet drop s len =\n if len < 0 then failwith \"Sequence.drop\";\n match s with\n | Sequence (s, next) ->\n Sequence\n ( (0, s)\n , fun (i, s) ->\n match next s with\n | Done -> Done\n | Skip s -> Skip (i, s)\n | Yield (a, s) when i >= len -> Yield (a, (i + 1, s))\n | Yield (_, s) -> Skip (i + 1, s) )\n;;\n\nlet take_while s ~f =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( s\n , fun s ->\n match next s with\n | Done -> Done\n | Skip s -> Skip s\n | Yield (a, s) when f a -> Yield (a, s)\n | Yield (_, _) -> Done )\n;;\n\nlet drop_while s ~f =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( `Dropping s\n , function\n | `Dropping s ->\n (match next s with\n | Done -> Done\n | Skip s -> Skip (`Dropping s)\n | Yield (a, s) when f a -> Skip (`Dropping s)\n | Yield (a, s) -> Yield (a, `Identity s))\n | `Identity s -> lift_identity next s )\n;;\n\nlet shift_right s x =\n match s with\n | Sequence (seed, next) ->\n Sequence\n ( `Consing (seed, x)\n , function\n | `Consing (seed, x) -> Yield (x, `Identity seed)\n | `Identity s -> lift_identity next s )\n;;\n\nlet shift_right_with_list s l = append (of_list l) s\nlet shift_left = drop\n\nmodule Infix = struct\n let ( @ ) = append\nend\n\nlet intersperse s ~sep =\n match s with\n | Sequence (s, next) ->\n Sequence\n ( `Init s\n , function\n | `Init s ->\n (match next s with\n | Done -> Done\n | Skip s -> Skip (`Init s)\n | Yield (a, s) -> Yield (a, `Running s))\n | `Running s ->\n (match next s with\n | Done -> Done\n | Skip s -> Skip (`Running s)\n | Yield (a, s) -> Yield (sep, `Putting (a, s)))\n | `Putting (a, s) -> Yield (a, `Running s) )\n;;\n\nlet repeat x = unfold_step ~init:x ~f:(fun x -> Yield (x, x))\n\nlet cycle_list_exn xs =\n if List.is_empty xs then invalid_arg \"Sequence.cycle_list_exn\";\n let s = of_list xs in\n concat_map ~f:(fun () -> s) (repeat ())\n;;\n\nlet cartesian_product sa sb = concat_map sa ~f:(fun a -> zip (repeat a) sb)\nlet singleton x = return x\n\nlet delayed_fold s ~init ~f ~finish =\n Expert.delayed_fold_step s ~init ~finish ~f:(fun acc option ~k ->\n match option with\n | None -> k acc\n | Some a -> f acc a ~k)\n;;\n\nlet fold_m ~bind ~return t ~init ~f =\n Expert.delayed_fold_step\n t\n ~init\n ~f:(fun acc option ~k ->\n match option with\n | None -> bind (return acc) ~f:k\n | Some a -> bind (f acc a) ~f:k)\n ~finish:return\n;;\n\nlet iter_m ~bind ~return t ~f =\n Expert.delayed_fold_step\n t\n ~init:()\n ~f:(fun () option ~k ->\n match option with\n | None -> bind (return ()) ~f:k\n | Some a -> bind (f a) ~f:k)\n ~finish:return\n;;\n\nlet fold_until s ~init ~f ~finish =\n let rec loop s next f acc =\n match next s with\n | Done -> finish acc\n | Skip s -> loop s next f acc\n | Yield (a, s) ->\n (match (f acc a : ('a, 'b) Continue_or_stop.t) with\n | Stop x -> x\n | Continue acc -> loop s next f acc)\n in\n match s with\n | Sequence (s, next) -> loop s next f init\n;;\n\nlet fold_result s ~init ~f =\n let rec loop s next f acc =\n match next s with\n | Done -> Result.return acc\n | Skip s -> loop s next f acc\n | Yield (a, s) ->\n (match (f acc a : (_, _) Result.t) with\n | Error _ as e -> e\n | Ok acc -> loop s next f acc)\n in\n match s with\n | Sequence (s, next) -> loop s next f init\n;;\n\nlet force_eagerly t = of_list (to_list t)\n\nlet memoize (type a) (Sequence (s, next)) =\n let module M = struct\n type t = T of (a, t) Step.t Lazy.t\n end\n in\n let rec memoize s = M.T (lazy (find_step s))\n and find_step s =\n match next s with\n | Done -> Done\n | Skip s -> find_step s\n | Yield (a, s) -> Yield (a, memoize s)\n in\n Sequence (memoize s, fun (M.T l) -> Lazy.force l)\n;;\n\nlet drop_eagerly s len =\n let rec loop i ~len s next =\n if i >= len\n then Sequence (s, next)\n else (\n match next s with\n | Done -> empty\n | Skip s -> loop i ~len s next\n | Yield (_, s) -> loop (i + 1) ~len s next)\n in\n match s with\n | Sequence (s, next) -> loop 0 ~len s next\n;;\n\nlet drop_while_option (Sequence (s, next)) ~f =\n let rec loop s =\n match next s with\n | Done -> None\n | Skip s -> loop s\n | Yield (x, s) -> if f x then loop s else Some (x, Sequence (s, next))\n in\n loop s\n;;\n\nlet compare compare_a t1 t2 =\n With_return.with_return (fun r ->\n iter (zip_full t1 t2) ~f:(function\n | `Left _ -> r.return 1\n | `Right _ -> r.return (-1)\n | `Both (v1, v2) ->\n let c = compare_a v1 v2 in\n if c <> 0 then r.return c);\n 0)\n;;\n\nlet equal equal_a t1 t2 =\n for_all (zip_full t1 t2) ~f:(function\n | `Both (a1, a2) -> equal_a a1 a2\n | `Left _ | `Right _ -> false)\n;;\n\nlet round_robin list =\n let next (todo_stack, done_stack) =\n match todo_stack with\n | Sequence (s, f) :: todo_stack ->\n (match f s with\n | Yield (x, s) -> Yield (x, (todo_stack, Sequence (s, f) :: done_stack))\n | Skip s -> Skip (Sequence (s, f) :: todo_stack, done_stack)\n | Done -> Skip (todo_stack, done_stack))\n | [] -> if List.is_empty done_stack then Done else Skip (List.rev done_stack, [])\n in\n let state = list, [] in\n Sequence (state, next)\n;;\n\nlet interleave (Sequence (s1, f1)) =\n let next (todo_stack, done_stack, s1) =\n match todo_stack with\n | Sequence (s2, f2) :: todo_stack ->\n (match f2 s2 with\n | Yield (x, s2) -> Yield (x, (todo_stack, Sequence (s2, f2) :: done_stack, s1))\n | Skip s2 -> Skip (todo_stack, Sequence (s2, f2) :: done_stack, s1)\n | Done -> Skip (todo_stack, done_stack, s1))\n | [] ->\n (match f1 s1, done_stack with\n | Yield (t, s1), _ -> Skip (List.rev (t :: done_stack), [], s1)\n | Skip s1, _ -> Skip (List.rev done_stack, [], s1)\n | Done, _ :: _ -> Skip (List.rev done_stack, [], s1)\n | Done, [] -> Done)\n in\n let state = [], [], s1 in\n Sequence (state, next)\n;;\n\nlet interleaved_cartesian_product s1 s2 =\n map s1 ~f:(fun x1 -> map s2 ~f:(fun x2 -> x1, x2)) |> interleave\n;;\n\nlet of_seq (seq : _ Caml.Seq.t) =\n unfold_step ~init:seq ~f:(fun seq ->\n match seq () with\n | Nil -> Done\n | Cons (hd, tl) -> Yield (hd, tl))\n;;\n\nlet to_seq (Sequence (state, next)) =\n let rec loop state =\n match next state with\n | Done -> Caml.Seq.Nil\n | Skip state -> loop state\n | Yield (hd, state) -> Caml.Seq.Cons (hd, fun () -> loop state)\n in\n fun () -> loop state\n;;\n\nmodule Generator = struct\n type 'elt steps = Wrap of ('elt, unit -> 'elt steps) Step.t\n\n let unwrap (Wrap step) = step\n\n module T = struct\n type ('a, 'elt) t = ('a -> 'elt steps) -> 'elt steps\n\n let return x k = k x\n\n let bind m ~f k =\n m (fun a ->\n let m' = f a in\n m' k)\n ;;\n\n let map m ~f k = m (fun a -> k (f a))\n let map = `Custom map\n end\n\n include T\n include Monad.Make2 (T)\n\n let yield e k = Wrap (Yield (e, k))\n let to_steps t = t (fun () -> Wrap Done)\n\n let of_sequence sequence =\n delayed_fold\n sequence\n ~init:()\n ~f:(fun () x ~k f -> Wrap (Yield (x, fun () -> k () f)))\n ~finish:return\n ;;\n\n let run t =\n let init () = to_steps t in\n let f thunk = unwrap (thunk ()) in\n unfold_step ~init ~f\n ;;\nend\n","open! Import\ninclude Array0\nmodule Int = Int0\n\ntype 'a t = 'a array [@@deriving_inline compare, sexp, sexp_grammar]\n\nlet compare : 'a. ('a -> 'a -> int) -> 'a t -> 'a t -> int = compare_array\n\nlet t_of_sexp : 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t =\n array_of_sexp\n;;\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n sexp_of_array\n;;\n\nlet (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"array\" ]\n ; ggid = \"j\\132);\\135qH\\158\\135\\222H\\001\\007\\004\\158\\218\"\n ; types = [ \"t\", Explicit_bind ([ \"a\" ], Apply (Implicit_var 0, [ Explicit_var 0 ])) ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ array_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"array.ml\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n;;\n\n[@@@end]\n\n(* This module implements a new in-place, constant heap sorting algorithm to replace the\n one used by the standard libraries. Its only purpose is to be faster (hopefully\n strictly faster) than the base sort and stable_sort.\n\n At a high level the algorithm is:\n - pick two pivot points by:\n - pick 5 arbitrary elements from the array\n - sort them within the array\n - take the elements on either side of the middle element of the sort as the pivots\n - sort the array with:\n - all elements less than pivot1 to the left (range 1)\n - all elements >= pivot1 and <= pivot2 in the middle (range 2)\n - all elements > pivot2 to the right (range 3)\n - if pivot1 and pivot2 are equal, then the middle range is sorted, so ignore it\n - recurse into range 1, 2 (if pivot1 and pivot2 are unequal), and 3\n - during recursion there are two inflection points:\n - if the size of the current range is small, use insertion sort to sort it\n - if the stack depth is large, sort the range with heap-sort to avoid n^2 worst-case\n behavior\n\n See the following for more information:\n - \"Dual-Pivot Quicksort\" by Vladimir Yaroslavskiy.\n Available at\n http://www.kriche.com.ar/root/programming/spaceTimeComplexity/DualPivotQuicksort.pdf\n - \"Quicksort is Optimal\" by Sedgewick and Bentley.\n Slides at http://www.cs.princeton.edu/~rs/talks/QuicksortIsOptimal.pdf\n - http://www.sorting-algorithms.com/quick-sort-3-way *)\n\nmodule Sort = struct\n (* For the sake of speed we could use unsafe get/set throughout, but speed tests don't\n show a significant improvement. *)\n let get = get\n let set = set\n\n let swap arr i j =\n let tmp = get arr i in\n set arr i (get arr j);\n set arr j tmp\n ;;\n\n module type Sort = sig\n val sort\n : 'a t\n -> compare:('a -> 'a -> int)\n -> left:int (* leftmost index of sub-array to sort *)\n -> right:int (* rightmost index of sub-array to sort *)\n -> unit\n end\n\n (* http://en.wikipedia.org/wiki/Insertion_sort *)\n module Insertion_sort : Sort = struct\n let sort arr ~compare ~left ~right =\n (* loop invariant:\n [arr] is sorted from [left] to [pos - 1], inclusive *)\n for pos = left + 1 to right do\n (* loop invariants:\n 1. the subarray arr[left .. i-1] is sorted\n 2. the subarray arr[i+1 .. pos] is sorted and contains only elements > v\n 3. arr[i] may be thought of as containing v\n\n Note that this does not allocate a closure, but is left in the for\n loop for the readability of the documentation. *)\n let rec loop arr ~left ~compare i v =\n let i_next = i - 1 in\n if i_next >= left && compare (get arr i_next) v > 0\n then (\n set arr i (get arr i_next);\n loop arr ~left ~compare i_next v)\n else i\n in\n let v = get arr pos in\n let final_pos = loop arr ~left ~compare pos v in\n set arr final_pos v\n done\n ;;\n end\n\n (* http://en.wikipedia.org/wiki/Heapsort *)\n module Heap_sort : Sort = struct\n (* loop invariant:\n root's children are both either roots of max-heaps or > right *)\n let rec heapify arr ~compare root ~left ~right =\n let relative_root = root - left in\n let left_child = (2 * relative_root) + left + 1 in\n let right_child = (2 * relative_root) + left + 2 in\n let largest =\n if left_child <= right && compare (get arr left_child) (get arr root) > 0\n then left_child\n else root\n in\n let largest =\n if right_child <= right && compare (get arr right_child) (get arr largest) > 0\n then right_child\n else largest\n in\n if largest <> root\n then (\n swap arr root largest;\n heapify arr ~compare largest ~left ~right)\n ;;\n\n let build_heap arr ~compare ~left ~right =\n (* Elements in the second half of the array are already heaps of size 1. We move\n through the first half of the array from back to front examining the element at\n hand, and the left and right children, fixing the heap property as we go. *)\n for i = (left + right) / 2 downto left do\n heapify arr ~compare i ~left ~right\n done\n ;;\n\n let sort arr ~compare ~left ~right =\n build_heap arr ~compare ~left ~right;\n (* loop invariants:\n 1. the subarray arr[left ... i] is a max-heap H\n 2. the subarray arr[i+1 ... right] is sorted (call it S)\n 3. every element of H is less than every element of S *)\n for i = right downto left + 1 do\n swap arr left i;\n heapify arr ~compare left ~left ~right:(i - 1)\n done\n ;;\n end\n\n (* http://en.wikipedia.org/wiki/Introsort *)\n module Intro_sort : sig\n include Sort\n\n val five_element_sort\n : 'a t\n -> compare:('a -> 'a -> int)\n -> int\n -> int\n -> int\n -> int\n -> int\n -> unit\n end = struct\n let five_element_sort arr ~compare m1 m2 m3 m4 m5 =\n let compare_and_swap i j =\n if compare (get arr i) (get arr j) > 0 then swap arr i j\n in\n (* Optimal 5-element sorting network:\n\n {v\n 1--o-----o-----o--------------1\n | | |\n 2--o-----|--o--|-----o--o-----2\n | | | | |\n 3--------o--o--|--o--|--o-----3\n | | |\n 4-----o--------o--o--|-----o--4\n | | |\n 5-----o--------------o-----o--5\n v} *)\n compare_and_swap m1 m2;\n compare_and_swap m4 m5;\n compare_and_swap m1 m3;\n compare_and_swap m2 m3;\n compare_and_swap m1 m4;\n compare_and_swap m3 m4;\n compare_and_swap m2 m5;\n compare_and_swap m2 m3;\n compare_and_swap m4 m5\n ;;\n\n (* choose pivots for the array by sorting 5 elements and examining the center three\n elements. The goal is to choose two pivots that will either:\n - break the range up into 3 even partitions\n or\n - eliminate a commonly appearing element by sorting it into the center partition\n by itself\n To this end we look at the center 3 elements of the 5 and return pairs of equal\n elements or the widest range *)\n let choose_pivots arr ~compare ~left ~right =\n let sixth = (right - left) / 6 in\n let m1 = left + sixth in\n let m2 = m1 + sixth in\n let m3 = m2 + sixth in\n let m4 = m3 + sixth in\n let m5 = m4 + sixth in\n five_element_sort arr ~compare m1 m2 m3 m4 m5;\n let m2_val = get arr m2 in\n let m3_val = get arr m3 in\n let m4_val = get arr m4 in\n if compare m2_val m3_val = 0\n then m2_val, m3_val, true\n else if compare m3_val m4_val = 0\n then m3_val, m4_val, true\n else m2_val, m4_val, false\n ;;\n\n let dual_pivot_partition arr ~compare ~left ~right =\n let pivot1, pivot2, pivots_equal = choose_pivots arr ~compare ~left ~right in\n (* loop invariants:\n 1. left <= l < r <= right\n 2. l <= p <= r\n 3. l <= x < p implies arr[x] >= pivot1\n and arr[x] <= pivot2\n 4. left <= x < l implies arr[x] < pivot1\n 5. r < x <= right implies arr[x] > pivot2 *)\n let rec loop l p r =\n let pv = get arr p in\n if compare pv pivot1 < 0\n then (\n swap arr p l;\n cont (l + 1) (p + 1) r)\n else if compare pv pivot2 > 0\n then (\n (* loop invariants: same as those of the outer loop *)\n let rec scan_backwards r =\n if r > p && compare (get arr r) pivot2 > 0 then scan_backwards (r - 1) else r\n in\n let r = scan_backwards r in\n swap arr r p;\n cont l p (r - 1))\n else cont l (p + 1) r\n and cont l p r = if p > r then l, r else loop l p r in\n let l, r = cont left left right in\n l, r, pivots_equal\n ;;\n\n let rec intro_sort arr ~max_depth ~compare ~left ~right =\n let len = right - left + 1 in\n (* This takes care of some edge cases, such as left > right or very short arrays,\n since Insertion_sort.sort handles these cases properly. Thus we don't need to\n make sure that left and right are valid in recursive calls. *)\n if len <= 32\n then Insertion_sort.sort arr ~compare ~left ~right\n else if max_depth < 0\n then Heap_sort.sort arr ~compare ~left ~right\n else (\n let max_depth = max_depth - 1 in\n let l, r, middle_sorted = dual_pivot_partition arr ~compare ~left ~right in\n intro_sort arr ~max_depth ~compare ~left ~right:(l - 1);\n if not middle_sorted then intro_sort arr ~max_depth ~compare ~left:l ~right:r;\n intro_sort arr ~max_depth ~compare ~left:(r + 1) ~right)\n ;;\n\n let log10_of_3 = Caml.log10 3.\n let log3 x = Caml.log10 x /. log10_of_3\n\n let sort arr ~compare ~left ~right =\n let len = right - left + 1 in\n let heap_sort_switch_depth =\n (* with perfect 3-way partitioning, this is the recursion depth *)\n Int.of_float (log3 (Int.to_float len))\n in\n intro_sort arr ~max_depth:heap_sort_switch_depth ~compare ~left ~right\n ;;\n end\nend\n\nlet sort ?pos ?len arr ~compare =\n let pos, len =\n Ordered_collection_common.get_pos_len_exn () ?pos ?len ~total_length:(length arr)\n in\n Sort.Intro_sort.sort arr ~compare ~left:pos ~right:(pos + len - 1)\n;;\n\nlet to_array t = t\nlet is_empty t = length t = 0\n\nlet is_sorted t ~compare =\n let rec is_sorted_loop t ~compare i =\n if i < 1\n then true\n else compare t.(i - 1) t.(i) <= 0 && is_sorted_loop t ~compare (i - 1)\n in\n is_sorted_loop t ~compare (length t - 1)\n;;\n\nlet is_sorted_strictly t ~compare =\n let rec is_sorted_strictly_loop t ~compare i =\n if i < 1\n then true\n else compare t.(i - 1) t.(i) < 0 && is_sorted_strictly_loop t ~compare (i - 1)\n in\n is_sorted_strictly_loop t ~compare (length t - 1)\n;;\n\nlet folding_map t ~init ~f =\n let acc = ref init in\n map t ~f:(fun x ->\n let new_acc, y = f !acc x in\n acc := new_acc;\n y)\n;;\n\nlet fold_map t ~init ~f =\n let acc = ref init in\n let result =\n map t ~f:(fun x ->\n let new_acc, y = f !acc x in\n acc := new_acc;\n y)\n in\n !acc, result\n;;\n\nlet fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\nlet fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\nlet count t ~f = Container.count ~fold t ~f\nlet sum m t ~f = Container.sum ~fold m t ~f\nlet min_elt t ~compare = Container.min_elt ~fold t ~compare\nlet max_elt t ~compare = Container.max_elt ~fold t ~compare\n\nlet foldi t ~init ~f =\n let rec foldi_loop t i ac ~f =\n if i = length t then ac else foldi_loop t (i + 1) (f i ac t.(i)) ~f\n in\n foldi_loop t 0 init ~f\n;;\n\nlet folding_mapi t ~init ~f =\n let acc = ref init in\n mapi t ~f:(fun i x ->\n let new_acc, y = f i !acc x in\n acc := new_acc;\n y)\n;;\n\nlet fold_mapi t ~init ~f =\n let acc = ref init in\n let result =\n mapi t ~f:(fun i x ->\n let new_acc, y = f i !acc x in\n acc := new_acc;\n y)\n in\n !acc, result\n;;\n\nlet counti t ~f =\n foldi t ~init:0 ~f:(fun idx count a -> if f idx a then count + 1 else count)\n;;\n\nlet concat_map t ~f = concat (to_list (map ~f t))\nlet concat_mapi t ~f = concat (to_list (mapi ~f t))\n\nlet rev_inplace t =\n let i = ref 0 in\n let j = ref (length t - 1) in\n while !i < !j do\n swap t !i !j;\n incr i;\n decr j\n done\n;;\n\nlet of_list_rev l =\n match l with\n | [] -> [||]\n | a :: l ->\n let len = 1 + List.length l in\n let t = create ~len a in\n let r = ref l in\n (* We start at [len - 2] because we already put [a] at [t.(len - 1)]. *)\n for i = len - 2 downto 0 do\n match !r with\n | [] -> assert false\n | a :: l ->\n t.(i) <- a;\n r := l\n done;\n t\n;;\n\n(* [of_list_map] and [of_list_rev_map] are based on functions from the OCaml\n distribution. *)\n\nlet of_list_map xs ~f =\n match xs with\n | [] -> [||]\n | hd :: tl ->\n let a = create ~len:(1 + List.length tl) (f hd) in\n let rec fill i = function\n | [] -> a\n | hd :: tl ->\n unsafe_set a i (f hd);\n fill (i + 1) tl\n in\n fill 1 tl\n;;\n\nlet of_list_mapi xs ~f =\n match xs with\n | [] -> [||]\n | hd :: tl ->\n let a = create ~len:(1 + List.length tl) (f 0 hd) in\n let rec fill a i = function\n | [] -> a\n | hd :: tl ->\n unsafe_set a i (f i hd);\n fill a (i + 1) tl\n in\n fill a 1 tl\n;;\n\nlet of_list_rev_map xs ~f =\n let t = of_list_map xs ~f in\n rev_inplace t;\n t\n;;\n\nlet of_list_rev_mapi xs ~f =\n let t = of_list_mapi xs ~f in\n rev_inplace t;\n t\n;;\n\nlet filter_mapi t ~f =\n let r = ref [||] in\n let k = ref 0 in\n for i = 0 to length t - 1 do\n match f i (unsafe_get t i) with\n | None -> ()\n | Some a ->\n if !k = 0 then r := create ~len:(length t) a;\n unsafe_set !r !k a;\n incr k\n done;\n if !k = length t then !r else if !k > 0 then sub ~pos:0 ~len:!k !r else [||]\n;;\n\nlet filter_map t ~f = filter_mapi t ~f:(fun _i a -> f a)\nlet filter_opt t = filter_map t ~f:Fn.id\n\nlet raise_length_mismatch name n1 n2 =\n invalid_argf \"length mismatch in %s: %d <> %d\" name n1 n2 ()\n[@@cold] [@@inline never] [@@local never] [@@specialise never]\n;;\n\nlet check_length2_exn name t1 t2 =\n let n1 = length t1 in\n let n2 = length t2 in\n if n1 <> n2 then raise_length_mismatch name n1 n2\n;;\n\nlet iter2_exn t1 t2 ~f =\n check_length2_exn \"Array.iter2_exn\" t1 t2;\n iteri t1 ~f:(fun i x1 -> f x1 t2.(i))\n;;\n\nlet map2_exn t1 t2 ~f =\n check_length2_exn \"Array.map2_exn\" t1 t2;\n init (length t1) ~f:(fun i -> f t1.(i) t2.(i))\n;;\n\nlet fold2_exn t1 t2 ~init ~f =\n check_length2_exn \"Array.fold2_exn\" t1 t2;\n foldi t1 ~init ~f:(fun i ac x -> f ac x t2.(i))\n;;\n\nlet filter t ~f = filter_map t ~f:(fun x -> if f x then Some x else None)\nlet filteri t ~f = filter_mapi t ~f:(fun i x -> if f i x then Some x else None)\n\nlet exists t ~f =\n let rec exists_loop t ~f i =\n if i < 0 then false else f t.(i) || exists_loop t ~f (i - 1)\n in\n exists_loop t ~f (length t - 1)\n;;\n\nlet existsi t ~f =\n let rec existsi_loop t ~f i =\n if i < 0 then false else f i t.(i) || existsi_loop t ~f (i - 1)\n in\n existsi_loop t ~f (length t - 1)\n;;\n\nlet mem t a ~equal = exists t ~f:(equal a)\n\nlet for_all t ~f =\n let rec for_all_loop t ~f i =\n if i < 0 then true else f t.(i) && for_all_loop t ~f (i - 1)\n in\n for_all_loop t ~f (length t - 1)\n;;\n\nlet for_alli t ~f =\n let rec for_alli_loop t ~f i =\n if i < 0 then true else f i t.(i) && for_alli_loop t ~f (i - 1)\n in\n for_alli_loop t ~f (length t - 1)\n;;\n\nlet exists2_exn t1 t2 ~f =\n let rec exists2_exn_loop t1 t2 ~f i =\n if i < 0 then false else f t1.(i) t2.(i) || exists2_exn_loop t1 t2 ~f (i - 1)\n in\n check_length2_exn \"Array.exists2_exn\" t1 t2;\n exists2_exn_loop t1 t2 ~f (length t1 - 1)\n;;\n\nlet for_all2_exn t1 t2 ~f =\n let rec for_all2_loop t1 t2 ~f i =\n if i < 0 then true else f t1.(i) t2.(i) && for_all2_loop t1 t2 ~f (i - 1)\n in\n check_length2_exn \"Array.for_all2_exn\" t1 t2;\n for_all2_loop t1 t2 ~f (length t1 - 1)\n;;\n\nlet equal equal t1 t2 = length t1 = length t2 && for_all2_exn t1 t2 ~f:equal\n\n\nlet map_inplace t ~f =\n for i = 0 to length t - 1 do\n t.(i) <- f t.(i)\n done\n;;\n\nlet findi t ~f =\n let rec findi_loop t ~f ~length i =\n if i >= length\n then None\n else if f i t.(i)\n then Some (i, t.(i))\n else findi_loop t ~f ~length (i + 1)\n in\n let length = length t in\n findi_loop t ~f ~length 0\n;;\n\nlet findi_exn =\n let not_found = Not_found_s (Atom \"Array.findi_exn: not found\") in\n let findi_exn t ~f =\n match findi t ~f with\n | None -> raise not_found\n | Some x -> x\n in\n (* named to preserve symbol in compiled binary *)\n findi_exn\n;;\n\nlet find_exn =\n let not_found = Not_found_s (Atom \"Array.find_exn: not found\") in\n let find_exn t ~f =\n match findi t ~f:(fun _i x -> f x) with\n | None -> raise not_found\n | Some (_i, x) -> x\n in\n (* named to preserve symbol in compiled binary *)\n find_exn\n;;\n\nlet find t ~f = Option.map (findi t ~f:(fun _i x -> f x)) ~f:(fun (_i, x) -> x)\n\nlet find_map t ~f =\n let rec find_map_loop t ~f ~length i =\n if i >= length\n then None\n else (\n match f t.(i) with\n | None -> find_map_loop t ~f ~length (i + 1)\n | Some _ as res -> res)\n in\n let length = length t in\n find_map_loop t ~f ~length 0\n;;\n\nlet find_map_exn =\n let not_found = Not_found_s (Atom \"Array.find_map_exn: not found\") in\n let find_map_exn t ~f =\n match find_map t ~f with\n | None -> raise not_found\n | Some x -> x\n in\n (* named to preserve symbol in compiled binary *)\n find_map_exn\n;;\n\nlet find_mapi t ~f =\n let rec find_mapi_loop t ~f ~length i =\n if i >= length\n then None\n else (\n match f i t.(i) with\n | None -> find_mapi_loop t ~f ~length (i + 1)\n | Some _ as res -> res)\n in\n let length = length t in\n find_mapi_loop t ~f ~length 0\n;;\n\nlet find_mapi_exn =\n let not_found = Not_found_s (Atom \"Array.find_mapi_exn: not found\") in\n let find_mapi_exn t ~f =\n match find_mapi t ~f with\n | None -> raise not_found\n | Some x -> x\n in\n (* named to preserve symbol in compiled binary *)\n find_mapi_exn\n;;\n\nlet find_consecutive_duplicate t ~equal =\n let n = length t in\n if n <= 1\n then None\n else (\n let result = ref None in\n let i = ref 1 in\n let prev = ref t.(0) in\n while !i < n do\n let cur = t.(!i) in\n if equal cur !prev\n then (\n result := Some (!prev, cur);\n i := n)\n else (\n prev := cur;\n incr i)\n done;\n !result)\n;;\n\nlet reduce t ~f =\n if length t = 0\n then None\n else (\n let r = ref t.(0) in\n for i = 1 to length t - 1 do\n r := f !r t.(i)\n done;\n Some !r)\n;;\n\nlet reduce_exn t ~f =\n match reduce t ~f with\n | None -> invalid_arg \"Array.reduce_exn\"\n | Some v -> v\n;;\n\nlet permute = Array_permute.permute\n\nlet random_element_exn ?(random_state = Random.State.default) t =\n if is_empty t\n then failwith \"Array.random_element_exn: empty array\"\n else t.(Random.State.int random_state (length t))\n;;\n\nlet random_element ?(random_state = Random.State.default) t =\n try Some (random_element_exn ~random_state t) with\n | _ -> None\n;;\n\nlet zip t1 t2 =\n if length t1 <> length t2 then None else Some (map2_exn t1 t2 ~f:(fun x1 x2 -> x1, x2))\n;;\n\nlet zip_exn t1 t2 =\n if length t1 <> length t2\n then failwith \"Array.zip_exn\"\n else map2_exn t1 t2 ~f:(fun x1 x2 -> x1, x2)\n;;\n\nlet unzip t =\n let n = length t in\n if n = 0\n then [||], [||]\n else (\n let x, y = t.(0) in\n let res1 = create ~len:n x in\n let res2 = create ~len:n y in\n for i = 1 to n - 1 do\n let x, y = t.(i) in\n res1.(i) <- x;\n res2.(i) <- y\n done;\n res1, res2)\n;;\n\nlet sorted_copy t ~compare =\n let t1 = copy t in\n sort t1 ~compare;\n t1\n;;\n\nlet partitioni_tf t ~f =\n let both = mapi t ~f:(fun i x -> if f i x then Either.First x else Either.Second x) in\n let trues =\n filter_map both ~f:(function\n | First x -> Some x\n | Second _ -> None)\n in\n let falses =\n filter_map both ~f:(function\n | First _ -> None\n | Second x -> Some x)\n in\n trues, falses\n;;\n\nlet partition_tf t ~f = partitioni_tf t ~f:(fun _i x -> f x)\nlet last t = t.(length t - 1)\n\n(* Convert to a sequence but does not attempt to protect against modification\n in the array. *)\nlet to_sequence_mutable t =\n Sequence.unfold_step ~init:0 ~f:(fun i ->\n if i >= length t then Sequence.Step.Done else Sequence.Step.Yield (t.(i), i + 1))\n;;\n\nlet to_sequence t = to_sequence_mutable (copy t)\n\nlet cartesian_product t1 t2 =\n if is_empty t1 || is_empty t2\n then [||]\n else (\n let n1 = length t1 in\n let n2 = length t2 in\n let t = create ~len:(n1 * n2) (t1.(0), t2.(0)) in\n let r = ref 0 in\n for i1 = 0 to n1 - 1 do\n for i2 = 0 to n2 - 1 do\n t.(!r) <- (t1.(i1), t2.(i2));\n incr r\n done\n done;\n t)\n;;\n\nlet transpose tt =\n if length tt = 0\n then Some [||]\n else (\n let width = length tt in\n let depth = length tt.(0) in\n if exists tt ~f:(fun t -> length t <> depth)\n then None\n else Some (init depth ~f:(fun d -> init width ~f:(fun w -> tt.(w).(d)))))\n;;\n\nlet transpose_exn tt =\n match transpose tt with\n | None -> invalid_arg \"Array.transpose_exn\"\n | Some tt' -> tt'\n;;\n\ninclude Binary_searchable.Make1 (struct\n type nonrec 'a t = 'a t\n\n let get = get\n let length = length\n end)\n\ninclude Blit.Make1 (struct\n type nonrec 'a t = 'a t\n\n let length = length\n\n let create_like ~len t =\n if len = 0\n then [||]\n else (\n assert (length t > 0);\n create ~len t.(0))\n ;;\n\n let unsafe_blit = blit\n end)\n\nlet invariant invariant_a t = iter t ~f:invariant_a\n\nmodule Private = struct\n module Sort = Sort\nend\n","open! Import\nmodule Int = Int0\nmodule String = String0\nmodule Array = Array0\n\n(* We maintain the property that all values of type [t] do not have the tag\n [double_array_tag]. Some functions below assume this in order to avoid testing the\n tag, and will segfault if this property doesn't hold. *)\ntype t = Caml.Obj.t array\n\nlet invariant t = assert (Caml.Obj.tag (Caml.Obj.repr t) <> Caml.Obj.double_array_tag)\nlet length = Array.length\nlet swap t i j = Array.swap t i j\n\nlet sexp_of_t t =\n Sexp.Atom\n (String.concat ~sep:\"\" [ \"\" ])\n;;\n\nlet zero_obj = Caml.Obj.repr (0 : int)\n\n(* We call [Array.create] with a value that is not a float so that the array doesn't get\n tagged with [Double_array_tag]. *)\nlet create_zero ~len = Array.create ~len zero_obj\n\nlet create ~len x =\n (* If we can, use [Array.create] directly. *)\n if Caml.Obj.tag x <> Caml.Obj.double_tag\n then Array.create ~len x\n else (\n (* Otherwise use [create_zero] and set the contents *)\n let t = create_zero ~len in\n let x = Sys.opaque_identity x in\n for i = 0 to len - 1 do\n Array.unsafe_set t i x\n done;\n t)\n;;\n\nlet empty = [||]\n\ntype not_a_float =\n | Not_a_float_0\n | Not_a_float_1 of int\n\nlet _not_a_float_0 = Not_a_float_0\nlet _not_a_float_1 = Not_a_float_1 42\n\nlet get t i =\n (* Make the compiler believe [t] is an array not containing floats so it does not check\n if [t] is tagged with [Double_array_tag]. It is NOT ok to use [int array] since (if\n this function is inlined and the array contains in-heap boxed values) wrong register\n typing may result, leading to a failure to register necessary GC roots. *)\n Caml.Obj.repr ((Caml.Obj.magic (t : t) : not_a_float array).(i) : not_a_float)\n;;\n\nlet[@inline always] unsafe_get t i =\n (* Make the compiler believe [t] is an array not containing floats so it does not check\n if [t] is tagged with [Double_array_tag]. *)\n Caml.Obj.repr\n (Array.unsafe_get (Caml.Obj.magic (t : t) : not_a_float array) i : not_a_float)\n;;\n\nlet[@inline always] unsafe_set_with_caml_modify t i obj =\n (* Same comment as [unsafe_get]. Sys.opaque_identity prevents the compiler from\n potentially wrongly guessing the type of the array based on the type of element, that\n is prevent the implication: (Obj.tag obj = Obj.double_tag) => (Obj.tag t =\n Obj.double_array_tag) which flambda has tried in the past (at least that's assuming\n the compiler respects Sys.opaque_identity, which is not always the case). *)\n Array.unsafe_set\n (Caml.Obj.magic (t : t) : not_a_float array)\n i\n (Caml.Obj.obj (Sys.opaque_identity obj) : not_a_float)\n;;\n\nlet[@inline always] unsafe_set_int_assuming_currently_int t i int =\n (* This skips [caml_modify], which is OK if both the old and new values are integers. *)\n Array.unsafe_set (Caml.Obj.magic (t : t) : int array) i (Sys.opaque_identity int)\n;;\n\n(* For [set] and [unsafe_set], if a pointer is involved, we first do a physical-equality\n test to see if the pointer is changing. If not, we don't need to do the [set], which\n saves a call to [caml_modify]. We think this physical-equality test is worth it\n because it is very cheap (both values are already available from the [is_int] test)\n and because [caml_modify] is expensive. *)\n\nlet set t i obj =\n (* We use [get] first but then we use [Array.unsafe_set] since we know that [i] is\n valid. *)\n let old_obj = get t i in\n if Caml.Obj.is_int old_obj && Caml.Obj.is_int obj\n then unsafe_set_int_assuming_currently_int t i (Caml.Obj.obj obj : int)\n else if not (phys_equal old_obj obj)\n then unsafe_set_with_caml_modify t i obj\n;;\n\nlet[@inline always] unsafe_set t i obj =\n let old_obj = unsafe_get t i in\n if Caml.Obj.is_int old_obj && Caml.Obj.is_int obj\n then unsafe_set_int_assuming_currently_int t i (Caml.Obj.obj obj : int)\n else if not (phys_equal old_obj obj)\n then unsafe_set_with_caml_modify t i obj\n;;\n\nlet[@inline always] unsafe_set_omit_phys_equal_check t i obj =\n let old_obj = unsafe_get t i in\n if Caml.Obj.is_int old_obj && Caml.Obj.is_int obj\n then unsafe_set_int_assuming_currently_int t i (Caml.Obj.obj obj : int)\n else unsafe_set_with_caml_modify t i obj\n;;\n\nlet singleton obj = create ~len:1 obj\n\n(* Pre-condition: t.(i) is an integer. *)\nlet unsafe_set_assuming_currently_int t i obj =\n if Caml.Obj.is_int obj\n then unsafe_set_int_assuming_currently_int t i (Caml.Obj.obj obj : int)\n else\n (* [t.(i)] is an integer and [obj] is not, so we do not need to check if they are\n equal. *)\n unsafe_set_with_caml_modify t i obj\n;;\n\nlet unsafe_set_int t i int =\n let old_obj = unsafe_get t i in\n if Caml.Obj.is_int old_obj\n then unsafe_set_int_assuming_currently_int t i int\n else unsafe_set_with_caml_modify t i (Caml.Obj.repr int)\n;;\n\nlet unsafe_clear_if_pointer t i =\n let old_obj = unsafe_get t i in\n if not (Caml.Obj.is_int old_obj) then unsafe_set_with_caml_modify t i (Caml.Obj.repr 0)\n;;\n\n(** [unsafe_blit] is like [Array.blit], except it uses our own for-loop to avoid\n caml_modify when possible. Its performance is still not comparable to a memcpy. *)\nlet unsafe_blit ~src ~src_pos ~dst ~dst_pos ~len =\n (* When [phys_equal src dst], we need to check whether [dst_pos < src_pos] and have the\n for loop go in the right direction so that we don't overwrite data that we still need\n to read. When [not (phys_equal src dst)], doing this is harmless. From a\n memory-performance perspective, it doesn't matter whether one loops up or down.\n Constant-stride access, forward or backward, should be indistinguishable (at least on\n an intel i7). So, we don't do a check for [phys_equal src dst] and always loop up in\n that case. *)\n if dst_pos < src_pos\n then\n for i = 0 to len - 1 do\n unsafe_set dst (dst_pos + i) (unsafe_get src (src_pos + i))\n done\n else\n for i = len - 1 downto 0 do\n unsafe_set dst (dst_pos + i) (unsafe_get src (src_pos + i))\n done\n;;\n\ninclude Blit.Make (struct\n type nonrec t = t\n\n let create = create_zero\n let length = length\n let unsafe_blit = unsafe_blit\n end)\n\nlet copy src =\n let dst = create_zero ~len:(length src) in\n blito ~src ~dst ();\n dst\n;;\n","open! Import\n\n(* WARNING:\n We use non-memory-safe things throughout the [Trusted] module.\n Most of it is only safe in combination with the type signature (e.g. exposing\n [val copy : 'a t -> 'b t] would be a big mistake). *)\nmodule Trusted : sig\n type 'a t\n\n val empty : 'a t\n val unsafe_create_uninitialized : len:int -> 'a t\n val create_obj_array : len:int -> 'a t\n val create : len:int -> 'a -> 'a t\n val singleton : 'a -> 'a t\n val get : 'a t -> int -> 'a\n val set : 'a t -> int -> 'a -> unit\n val swap : _ t -> int -> int -> unit\n val unsafe_get : 'a t -> int -> 'a\n val unsafe_set : 'a t -> int -> 'a -> unit\n val unsafe_set_omit_phys_equal_check : 'a t -> int -> 'a -> unit\n val unsafe_set_int : 'a t -> int -> int -> unit\n val unsafe_set_int_assuming_currently_int : 'a t -> int -> int -> unit\n val unsafe_set_assuming_currently_int : 'a t -> int -> 'a -> unit\n val length : 'a t -> int\n val unsafe_blit : ('a t, 'a t) Blit.blit\n val copy : 'a t -> 'a t\n val unsafe_clear_if_pointer : _ t -> int -> unit\nend = struct\n type 'a t = Obj_array.t\n\n let empty = Obj_array.empty\n let unsafe_create_uninitialized ~len = Obj_array.create_zero ~len\n let create_obj_array ~len = Obj_array.create_zero ~len\n let create ~len x = Obj_array.create ~len (Caml.Obj.repr x)\n let singleton x = Obj_array.singleton (Caml.Obj.repr x)\n let swap t i j = Obj_array.swap t i j\n let get arr i = Caml.Obj.obj (Obj_array.get arr i)\n let set arr i x = Obj_array.set arr i (Caml.Obj.repr x)\n let unsafe_get arr i = Caml.Obj.obj (Obj_array.unsafe_get arr i)\n let unsafe_set arr i x = Obj_array.unsafe_set arr i (Caml.Obj.repr x)\n let unsafe_set_int arr i x = Obj_array.unsafe_set_int arr i x\n\n let unsafe_set_int_assuming_currently_int arr i x =\n Obj_array.unsafe_set_int_assuming_currently_int arr i x\n ;;\n\n let unsafe_set_assuming_currently_int arr i x =\n Obj_array.unsafe_set_assuming_currently_int arr i (Caml.Obj.repr x)\n ;;\n\n let length = Obj_array.length\n let unsafe_blit = Obj_array.unsafe_blit\n let copy = Obj_array.copy\n\n let unsafe_set_omit_phys_equal_check t i x =\n Obj_array.unsafe_set_omit_phys_equal_check t i (Caml.Obj.repr x)\n ;;\n\n let unsafe_clear_if_pointer = Obj_array.unsafe_clear_if_pointer\nend\n\ninclude Trusted\n\nlet invariant t = assert (Caml.Obj.tag (Caml.Obj.repr t) <> Caml.Obj.double_array_tag)\n\nlet init l ~f =\n if l < 0\n then invalid_arg \"Uniform_array.init\"\n else (\n let res = unsafe_create_uninitialized ~len:l in\n for i = 0 to l - 1 do\n unsafe_set res i (f i)\n done;\n res)\n;;\n\nlet of_array arr = init ~f:(Array.unsafe_get arr) (Array.length arr)\nlet map a ~f = init ~f:(fun i -> f (unsafe_get a i)) (length a)\n\nlet iter a ~f =\n for i = 0 to length a - 1 do\n f (unsafe_get a i)\n done\n;;\n\nlet iteri a ~f =\n for i = 0 to length a - 1 do\n f i (unsafe_get a i)\n done\n;;\n\nlet to_list t = List.init ~f:(get t) (length t)\n\nlet of_list l =\n let len = List.length l in\n let res = unsafe_create_uninitialized ~len in\n List.iteri l ~f:(fun i x -> set res i x);\n res\n;;\n\n(* It is not safe for [to_array] to be the identity function because we have code that\n relies on [float array]s being unboxed, for example in [bin_write_array]. *)\nlet to_array t = Array.init (length t) ~f:(fun i -> unsafe_get t i)\n\nlet exists t ~f =\n let rec loop t ~f i =\n if i < 0 then false else f (unsafe_get t i) || loop t ~f (i - 1)\n in\n loop t ~f (length t - 1)\n;;\n\nlet map2_exn t1 t2 ~f =\n let len = length t1 in\n if length t2 <> len then invalid_arg \"Array.map2_exn\";\n init len ~f:(fun i -> f (unsafe_get t1 i) (unsafe_get t2 i))\n;;\n\ninclude Sexpable.Of_sexpable1\n (Array)\n (struct\n type nonrec 'a t = 'a t\n\n let to_sexpable = to_array\n let of_sexpable = of_array\n end)\n\ninclude Blit.Make1 (struct\n type nonrec 'a t = 'a t\n\n let length = length\n\n let create_like ~len t =\n if len = 0\n then empty\n else (\n assert (length t > 0);\n create ~len (get t 0))\n ;;\n\n let unsafe_blit = unsafe_blit\n end)\n\nlet fold t ~init ~f =\n let r = ref init in\n for i = 0 to length t - 1 do\n r := f !r (unsafe_get t i)\n done;\n !r\n;;\n\nlet min_elt t ~compare = Container.min_elt ~fold t ~compare\nlet max_elt t ~compare = Container.max_elt ~fold t ~compare\n","open! Import\nmodule Array = Array0\nmodule String = String0\ninclude Char0\n\nmodule T = struct\n type t = char [@@deriving_inline compare, hash, sexp, sexp_grammar]\n\n let compare = (compare_char : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_char\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_char in\n fun x -> func x\n ;;\n\n let t_of_sexp = (char_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_char : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"char\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ char_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"char.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let to_string t = String.make 1 t\n\n let of_string s =\n match String.length s with\n | 1 -> s.[0]\n | _ -> failwithf \"Char.of_string: %S\" s ()\n ;;\nend\n\ninclude T\n\ninclude Identifiable.Make (struct\n include T\n\n let module_name = \"Base.Char\"\n end)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! Char_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet all = Array.init 256 ~f:unsafe_of_int |> Array.to_list\n\nlet is_lowercase = function\n | 'a' .. 'z' -> true\n | _ -> false\n;;\n\nlet is_uppercase = function\n | 'A' .. 'Z' -> true\n | _ -> false\n;;\n\nlet is_print = function\n | ' ' .. '~' -> true\n | _ -> false\n;;\n\nlet is_whitespace = function\n | '\\t' | '\\n' | '\\011' (* vertical tab *) | '\\012' (* form feed *) | '\\r' | ' ' -> true\n | _ -> false\n;;\n\nlet is_digit = function\n | '0' .. '9' -> true\n | _ -> false\n;;\n\nlet is_alpha = function\n | 'a' .. 'z' | 'A' .. 'Z' -> true\n | _ -> false\n;;\n\n(* Writing these out, instead of calling [is_alpha] and [is_digit], reduces\n runtime by approx. 30% *)\nlet is_alphanum = function\n | 'a' .. 'z' | 'A' .. 'Z' | '0' .. '9' -> true\n | _ -> false\n;;\n\nlet get_digit_unsafe t = to_int t - to_int '0'\n\nlet get_digit_exn t =\n if is_digit t\n then get_digit_unsafe t\n else failwithf \"Char.get_digit_exn %C: not a digit\" t ()\n;;\n\nlet get_digit t = if is_digit t then Some (get_digit_unsafe t) else None\n\nmodule O = struct\n let ( >= ) = ( >= )\n let ( <= ) = ( <= )\n let ( = ) = ( = )\n let ( > ) = ( > )\n let ( < ) = ( < )\n let ( <> ) = ( <> )\nend\n\nmodule Caseless = struct\n module T = struct\n type t = char [@@deriving_inline sexp]\n\n let t_of_sexp = (char_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_char : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n\n let compare c1 c2 = compare (lowercase c1) (lowercase c2)\n let hash_fold_t state t = hash_fold_char state (lowercase t)\n let hash t = Hash.run hash_fold_t t\n end\n\n include T\n include Comparable.Make (T)\nend\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Char_replace_polymorphic_compare\n","open! Import\nmodule Array = Array0\nmodule Bytes = Bytes0\ninclude String0\n\nlet invalid_argf = Printf.invalid_argf\nlet raise_s = Error.raise_s\nlet stage = Staged.stage\n\nmodule T = struct\n type t = string [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_string\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_string in\n fun x -> func x\n ;;\n\n let t_of_sexp = (string_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_string : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"string\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ string_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"string.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare = compare\nend\n\ninclude T\ninclude Comparator.Make (T)\n\ntype elt = char\n\nlet invariant (_ : t) = ()\n\n(* This is copied/adapted from 'blit.ml'.\n [sub], [subo] could be implemented using [Blit.Make(Bytes)] plus unsafe casts to/from\n string but were inlined here to avoid using [Bytes.unsafe_of_string] as much as possible.\n*)\nlet sub src ~pos ~len =\n if pos = 0 && len = String.length src\n then src\n else (\n Ordered_collection_common.check_pos_len_exn ~pos ~len ~total_length:(length src);\n let dst = Bytes.create len in\n if len > 0 then Bytes.unsafe_blit_string ~src ~src_pos:pos ~dst ~dst_pos:0 ~len;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:dst)\n;;\n\nlet subo ?(pos = 0) ?len src =\n sub\n src\n ~pos\n ~len:\n (match len with\n | Some i -> i\n | None -> length src - pos)\n;;\n\nlet rec contains_unsafe t ~pos ~end_ char =\n pos < end_\n && (Char.equal (unsafe_get t pos) char || contains_unsafe t ~pos:(pos + 1) ~end_ char)\n;;\n\nlet contains ?(pos = 0) ?len t char =\n let total_length = String.length t in\n let len = Option.value len ~default:(total_length - pos) in\n Ordered_collection_common.check_pos_len_exn ~pos ~len ~total_length;\n contains_unsafe t ~pos ~end_:(pos + len) char\n;;\n\nlet is_empty t = length t = 0\n\nlet rec index_from_exn_internal string ~pos ~len ~not_found char =\n if pos >= len\n then raise not_found\n else if Char.equal (unsafe_get string pos) char\n then pos\n else index_from_exn_internal string ~pos:(pos + 1) ~len ~not_found char\n;;\n\nlet index_exn_internal t ~not_found char =\n index_from_exn_internal t ~pos:0 ~len:(length t) ~not_found char\n;;\n\nlet index_exn =\n let not_found = Not_found_s (Atom \"String.index_exn: not found\") in\n let index_exn t char = index_exn_internal t ~not_found char in\n (* named to preserve symbol in compiled binary *)\n index_exn\n;;\n\nlet index_from_exn =\n let not_found = Not_found_s (Atom \"String.index_from_exn: not found\") in\n let index_from_exn t pos char =\n let len = length t in\n if pos < 0 || pos > len\n then invalid_arg \"String.index_from_exn\"\n else index_from_exn_internal t ~pos ~len ~not_found char\n in\n (* named to preserve symbol in compiled binary *)\n index_from_exn\n;;\n\nlet rec rindex_from_exn_internal string ~pos ~len ~not_found char =\n if pos < 0\n then raise not_found\n else if Char.equal (unsafe_get string pos) char\n then pos\n else rindex_from_exn_internal string ~pos:(pos - 1) ~len ~not_found char\n;;\n\nlet rindex_exn_internal t ~not_found char =\n let len = length t in\n rindex_from_exn_internal t ~pos:(len - 1) ~len ~not_found char\n;;\n\nlet rindex_exn =\n let not_found = Not_found_s (Atom \"String.rindex_exn: not found\") in\n let rindex_exn t char = rindex_exn_internal t ~not_found char in\n (* named to preserve symbol in compiled binary *)\n rindex_exn\n;;\n\nlet rindex_from_exn =\n let not_found = Not_found_s (Atom \"String.rindex_from_exn: not found\") in\n let rindex_from_exn t pos char =\n let len = length t in\n if pos < -1 || pos >= len\n then invalid_arg \"String.rindex_from_exn\"\n else rindex_from_exn_internal t ~pos ~len ~not_found char\n in\n (* named to preserve symbol in compiled binary *)\n rindex_from_exn\n;;\n\nlet index t char =\n try Some (index_exn t char) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nlet rindex t char =\n try Some (rindex_exn t char) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nlet index_from t pos char =\n try Some (index_from_exn t pos char) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nlet rindex_from t pos char =\n try Some (rindex_from_exn t pos char) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nmodule Search_pattern0 = struct\n type t =\n { pattern : string\n ; case_sensitive : bool\n ; kmp_array : int array\n }\n\n let sexp_of_t { pattern; case_sensitive; kmp_array = _ } : Sexp.t =\n List\n [ List [ Atom \"pattern\"; sexp_of_string pattern ]\n ; List [ Atom \"case_sensitive\"; sexp_of_bool case_sensitive ]\n ]\n ;;\n\n let pattern t = t.pattern\n let case_sensitive t = t.case_sensitive\n\n (* Find max number of matched characters at [next_text_char], given the current\n [matched_chars]. Try to extend the current match, if chars don't match, try to match\n fewer chars. If chars match then extend the match. *)\n let kmp_internal_loop ~matched_chars ~next_text_char ~pattern ~kmp_array ~char_equal =\n let matched_chars = ref matched_chars in\n while\n !matched_chars > 0\n && not (char_equal next_text_char (unsafe_get pattern !matched_chars))\n do\n matched_chars := Array.unsafe_get kmp_array (!matched_chars - 1)\n done;\n if char_equal next_text_char (unsafe_get pattern !matched_chars)\n then matched_chars := !matched_chars + 1;\n !matched_chars\n ;;\n\n let get_char_equal ~case_sensitive =\n match case_sensitive with\n | true -> Char.equal\n | false -> Char.Caseless.equal\n ;;\n\n (* Classic KMP pre-processing of the pattern: build the int array, which, for each i,\n contains the length of the longest non-trivial prefix of s which is equal to a suffix\n ending at s.[i] *)\n let create pattern ~case_sensitive =\n let n = length pattern in\n let kmp_array = Array.create ~len:n (-1) in\n if n > 0\n then (\n let char_equal = get_char_equal ~case_sensitive in\n Array.unsafe_set kmp_array 0 0;\n let matched_chars = ref 0 in\n for i = 1 to n - 1 do\n matched_chars\n := kmp_internal_loop\n ~matched_chars:!matched_chars\n ~next_text_char:(unsafe_get pattern i)\n ~pattern\n ~kmp_array\n ~char_equal;\n Array.unsafe_set kmp_array i !matched_chars\n done);\n { pattern; case_sensitive; kmp_array }\n ;;\n\n (* Classic KMP: use the pre-processed pattern to optimize look-behinds on non-matches.\n We return int to avoid allocation in [index_exn]. -1 means no match. *)\n let index_internal ?(pos = 0) { pattern; case_sensitive; kmp_array } ~in_:text =\n if pos < 0 || pos > length text - length pattern\n then -1\n else (\n let char_equal = get_char_equal ~case_sensitive in\n let j = ref pos in\n let matched_chars = ref 0 in\n let k = length pattern in\n let n = length text in\n while !j < n && !matched_chars < k do\n let next_text_char = unsafe_get text !j in\n matched_chars\n := kmp_internal_loop\n ~matched_chars:!matched_chars\n ~next_text_char\n ~pattern\n ~kmp_array\n ~char_equal;\n j := !j + 1\n done;\n if !matched_chars = k then !j - k else -1)\n ;;\n\n let matches t str = index_internal t ~in_:str >= 0\n\n let index ?pos t ~in_ =\n let p = index_internal ?pos t ~in_ in\n if p < 0 then None else Some p\n ;;\n\n let index_exn ?pos t ~in_ =\n let p = index_internal ?pos t ~in_ in\n if p >= 0\n then p\n else\n raise_s\n (Sexp.message \"Substring not found\" [ \"substring\", sexp_of_string t.pattern ])\n ;;\n\n let index_all { pattern; case_sensitive; kmp_array } ~may_overlap ~in_:text =\n if length pattern = 0\n then List.init (1 + length text) ~f:Fn.id\n else (\n let char_equal = get_char_equal ~case_sensitive in\n let matched_chars = ref 0 in\n let k = length pattern in\n let n = length text in\n let found = ref [] in\n for j = 0 to n do\n if !matched_chars = k\n then (\n found := (j - k) :: !found;\n (* we just found a match in the previous iteration *)\n match may_overlap with\n | true -> matched_chars := Array.unsafe_get kmp_array (k - 1)\n | false -> matched_chars := 0);\n if j < n\n then (\n let next_text_char = unsafe_get text j in\n matched_chars\n := kmp_internal_loop\n ~matched_chars:!matched_chars\n ~next_text_char\n ~pattern\n ~kmp_array\n ~char_equal)\n done;\n List.rev !found)\n ;;\n\n let replace_first ?pos t ~in_:s ~with_ =\n match index ?pos t ~in_:s with\n | None -> s\n | Some i ->\n let len_s = length s in\n let len_t = length t.pattern in\n let len_with = length with_ in\n let dst = Bytes.create (len_s + len_with - len_t) in\n Bytes.blit_string ~src:s ~src_pos:0 ~dst ~dst_pos:0 ~len:i;\n Bytes.blit_string ~src:with_ ~src_pos:0 ~dst ~dst_pos:i ~len:len_with;\n Bytes.blit_string\n ~src:s\n ~src_pos:(i + len_t)\n ~dst\n ~dst_pos:(i + len_with)\n ~len:(len_s - i - len_t);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:dst\n ;;\n\n\n let replace_all t ~in_:s ~with_ =\n let matches = index_all t ~may_overlap:false ~in_:s in\n match matches with\n | [] -> s\n | _ :: _ ->\n let len_s = length s in\n let len_t = length t.pattern in\n let len_with = length with_ in\n let num_matches = List.length matches in\n let dst = Bytes.create (len_s + ((len_with - len_t) * num_matches)) in\n let next_dst_pos = ref 0 in\n let next_src_pos = ref 0 in\n List.iter matches ~f:(fun i ->\n let len = i - !next_src_pos in\n Bytes.blit_string\n ~src:s\n ~src_pos:!next_src_pos\n ~dst\n ~dst_pos:!next_dst_pos\n ~len;\n Bytes.blit_string\n ~src:with_\n ~src_pos:0\n ~dst\n ~dst_pos:(!next_dst_pos + len)\n ~len:len_with;\n next_dst_pos := !next_dst_pos + len + len_with;\n next_src_pos := !next_src_pos + len + len_t);\n Bytes.blit_string\n ~src:s\n ~src_pos:!next_src_pos\n ~dst\n ~dst_pos:!next_dst_pos\n ~len:(len_s - !next_src_pos);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:dst\n ;;\n\n module Private = struct\n type public = t\n\n type nonrec t = t =\n { pattern : string\n ; case_sensitive : bool\n ; kmp_array : int array\n }\n [@@deriving_inline equal, sexp_of]\n\n let equal =\n (fun a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then true\n else\n Ppx_compare_lib.( && )\n (equal_string a__001_.pattern b__002_.pattern)\n (Ppx_compare_lib.( && )\n (equal_bool a__001_.case_sensitive b__002_.case_sensitive)\n (equal_array equal_int a__001_.kmp_array b__002_.kmp_array))\n : t -> t -> bool)\n ;;\n\n let sexp_of_t =\n (function\n | { pattern = v_pattern\n ; case_sensitive = v_case_sensitive\n ; kmp_array = v_kmp_array\n } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_array sexp_of_int v_kmp_array in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"kmp_array\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_bool v_case_sensitive in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"case_sensitive\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_string v_pattern in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"pattern\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\n\n let representation = Fn.id\n end\nend\n\nmodule Search_pattern_helper = struct\n module Search_pattern = Search_pattern0\nend\n\nopen Search_pattern_helper\n\nlet substr_index_gen ~case_sensitive ?pos t ~pattern =\n Search_pattern.index ?pos (Search_pattern.create ~case_sensitive pattern) ~in_:t\n;;\n\nlet substr_index_exn_gen ~case_sensitive ?pos t ~pattern =\n Search_pattern.index_exn ?pos (Search_pattern.create ~case_sensitive pattern) ~in_:t\n;;\n\nlet substr_index_all_gen ~case_sensitive t ~may_overlap ~pattern =\n Search_pattern.index_all\n (Search_pattern.create ~case_sensitive pattern)\n ~may_overlap\n ~in_:t\n;;\n\nlet substr_replace_first_gen ~case_sensitive ?pos t ~pattern =\n Search_pattern.replace_first\n ?pos\n (Search_pattern.create ~case_sensitive pattern)\n ~in_:t\n;;\n\nlet substr_replace_all_gen ~case_sensitive t ~pattern =\n Search_pattern.replace_all (Search_pattern.create ~case_sensitive pattern) ~in_:t\n;;\n\nlet is_substring_gen ~case_sensitive t ~substring =\n Option.is_some (substr_index_gen t ~pattern:substring ~case_sensitive)\n;;\n\nlet substr_index = substr_index_gen ~case_sensitive:true\nlet substr_index_exn = substr_index_exn_gen ~case_sensitive:true\nlet substr_index_all = substr_index_all_gen ~case_sensitive:true\nlet substr_replace_first = substr_replace_first_gen ~case_sensitive:true\nlet substr_replace_all = substr_replace_all_gen ~case_sensitive:true\nlet is_substring = is_substring_gen ~case_sensitive:true\n\nlet is_substring_at_gen =\n let rec loop ~str ~str_pos ~sub ~sub_pos ~sub_len ~char_equal =\n if sub_pos = sub_len\n then true\n else if char_equal (unsafe_get str str_pos) (unsafe_get sub sub_pos)\n then\n loop ~str ~str_pos:(str_pos + 1) ~sub ~sub_pos:(sub_pos + 1) ~sub_len ~char_equal\n else false\n in\n fun str ~pos:str_pos ~substring:sub ~char_equal ->\n let str_len = length str in\n let sub_len = length sub in\n if str_pos < 0 || str_pos > str_len\n then\n invalid_argf\n \"String.is_substring_at: invalid index %d for string of length %d\"\n str_pos\n str_len\n ();\n str_pos + sub_len <= str_len\n && loop ~str ~str_pos ~sub ~sub_pos:0 ~sub_len ~char_equal\n;;\n\nlet is_suffix_gen string ~suffix ~char_equal =\n let string_len = length string in\n let suffix_len = length suffix in\n string_len >= suffix_len\n && is_substring_at_gen\n string\n ~pos:(string_len - suffix_len)\n ~substring:suffix\n ~char_equal\n;;\n\nlet is_prefix_gen string ~prefix ~char_equal =\n let string_len = length string in\n let prefix_len = length prefix in\n string_len >= prefix_len\n && is_substring_at_gen string ~pos:0 ~substring:prefix ~char_equal\n;;\n\nmodule Caseless = struct\n module T = struct\n type t = string [@@deriving_inline sexp]\n\n let t_of_sexp = (string_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_string : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n [@@@end]\n\n let char_compare_caseless c1 c2 =\n Char.compare (Char.lowercase c1) (Char.lowercase c2)\n ;;\n\n let rec compare_loop ~pos ~string1 ~len1 ~string2 ~len2 =\n if pos = len1\n then if pos = len2 then 0 else -1\n else if pos = len2\n then 1\n else (\n let c =\n char_compare_caseless (unsafe_get string1 pos) (unsafe_get string2 pos)\n in\n match c with\n | 0 -> compare_loop ~pos:(pos + 1) ~string1 ~len1 ~string2 ~len2\n | _ -> c)\n ;;\n\n let compare string1 string2 =\n if phys_equal string1 string2\n then 0\n else\n compare_loop\n ~pos:0\n ~string1\n ~len1:(String.length string1)\n ~string2\n ~len2:(String.length string2)\n ;;\n\n let hash_fold_t state t =\n let len = length t in\n let state = ref (hash_fold_int state len) in\n for pos = 0 to len - 1 do\n state := hash_fold_char !state (Char.lowercase (unsafe_get t pos))\n done;\n !state\n ;;\n\n let hash t = Hash.run hash_fold_t t\n let is_suffix s ~suffix = is_suffix_gen s ~suffix ~char_equal:Char.Caseless.equal\n let is_prefix s ~prefix = is_prefix_gen s ~prefix ~char_equal:Char.Caseless.equal\n let substr_index = substr_index_gen ~case_sensitive:false\n let substr_index_exn = substr_index_exn_gen ~case_sensitive:false\n let substr_index_all = substr_index_all_gen ~case_sensitive:false\n let substr_replace_first = substr_replace_first_gen ~case_sensitive:false\n let substr_replace_all = substr_replace_all_gen ~case_sensitive:false\n let is_substring = is_substring_gen ~case_sensitive:false\n let is_substring_at = is_substring_at_gen ~char_equal:Char.Caseless.equal\n end\n\n include T\n include Comparable.Make (T)\nend\n\nlet of_string = Fn.id\nlet to_string = Fn.id\n\nlet init n ~f =\n if n < 0 then invalid_argf \"String.init %d\" n ();\n let t = Bytes.create n in\n for i = 0 to n - 1 do\n Bytes.set t i (f i)\n done;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:t\n;;\n\nlet to_list s =\n let rec loop acc i = if i < 0 then acc else loop (s.[i] :: acc) (i - 1) in\n loop [] (length s - 1)\n;;\n\nlet to_list_rev s =\n let len = length s in\n let rec loop acc i = if i = len then acc else loop (s.[i] :: acc) (i + 1) in\n loop [] 0\n;;\n\nlet rev t =\n let len = length t in\n let res = Bytes.create len in\n for i = 0 to len - 1 do\n unsafe_set res i (unsafe_get t (len - 1 - i))\n done;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:res\n;;\n\n(** Efficient string splitting *)\n\nlet lsplit2_exn =\n let not_found = Not_found_s (Atom \"String.lsplit2_exn: not found\") in\n let lsplit2_exn line ~on:delim =\n let pos = index_exn_internal line ~not_found delim in\n sub line ~pos:0 ~len:pos, sub line ~pos:(pos + 1) ~len:(length line - pos - 1)\n in\n (* named to preserve symbol in compiled binary *)\n lsplit2_exn\n;;\n\nlet rsplit2_exn =\n let not_found = Not_found_s (Atom \"String.rsplit2_exn: not found\") in\n let rsplit2_exn line ~on:delim =\n let pos = rindex_exn_internal line ~not_found delim in\n sub line ~pos:0 ~len:pos, sub line ~pos:(pos + 1) ~len:(length line - pos - 1)\n in\n (* named to preserve symbol in compiled binary *)\n rsplit2_exn\n;;\n\nlet lsplit2 line ~on =\n try Some (lsplit2_exn line ~on) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nlet rsplit2 line ~on =\n try Some (rsplit2_exn line ~on) with\n | Not_found_s _ | Caml.Not_found -> None\n;;\n\nlet rec char_list_mem l (c : char) =\n match l with\n | [] -> false\n | hd :: tl -> Char.equal hd c || char_list_mem tl c\n;;\n\nlet split_gen str ~on =\n let is_delim =\n match on with\n | `char c' -> fun c -> Char.equal c c'\n | `char_list l -> fun c -> char_list_mem l c\n in\n let len = length str in\n let rec loop acc last_pos pos =\n if pos = -1\n then sub str ~pos:0 ~len:last_pos :: acc\n else if is_delim str.[pos]\n then (\n let pos1 = pos + 1 in\n let sub_str = sub str ~pos:pos1 ~len:(last_pos - pos1) in\n loop (sub_str :: acc) pos (pos - 1))\n else loop acc last_pos (pos - 1)\n in\n loop [] len (len - 1)\n;;\n\nlet split str ~on = split_gen str ~on:(`char on)\nlet split_on_chars str ~on:chars = split_gen str ~on:(`char_list chars)\n\nlet split_lines =\n let back_up_at_newline ~t ~pos ~eol =\n pos := !pos - if !pos > 0 && Char.equal t.[!pos - 1] '\\r' then 2 else 1;\n eol := !pos + 1\n in\n fun t ->\n let n = length t in\n if n = 0\n then []\n else (\n (* Invariant: [-1 <= pos < eol]. *)\n let pos = ref (n - 1) in\n let eol = ref n in\n let ac = ref [] in\n (* We treat the end of the string specially, because if the string ends with a\n newline, we don't want an extra empty string at the end of the output. *)\n if Char.equal t.[!pos] '\\n' then back_up_at_newline ~t ~pos ~eol;\n while !pos >= 0 do\n if Char.( <> ) t.[!pos] '\\n'\n then decr pos\n else (\n (* Because [pos < eol], we know that [start <= eol]. *)\n let start = !pos + 1 in\n ac := sub t ~pos:start ~len:(!eol - start) :: !ac;\n back_up_at_newline ~t ~pos ~eol)\n done;\n sub t ~pos:0 ~len:!eol :: !ac)\n;;\n\nlet is_suffix s ~suffix = is_suffix_gen s ~suffix ~char_equal:Char.equal\nlet is_prefix s ~prefix = is_prefix_gen s ~prefix ~char_equal:Char.equal\n\nlet is_substring_at s ~pos ~substring =\n is_substring_at_gen s ~pos ~substring ~char_equal:Char.equal\n;;\n\nlet wrap_sub_n t n ~name ~pos ~len ~on_error =\n if n < 0\n then invalid_arg (name ^ \" expecting nonnegative argument\")\n else (\n try sub t ~pos ~len with\n | _ -> on_error)\n;;\n\nlet drop_prefix t n =\n wrap_sub_n ~name:\"drop_prefix\" t n ~pos:n ~len:(length t - n) ~on_error:\"\"\n;;\n\nlet drop_suffix t n =\n wrap_sub_n ~name:\"drop_suffix\" t n ~pos:0 ~len:(length t - n) ~on_error:\"\"\n;;\n\nlet prefix t n = wrap_sub_n ~name:\"prefix\" t n ~pos:0 ~len:n ~on_error:t\nlet suffix t n = wrap_sub_n ~name:\"suffix\" t n ~pos:(length t - n) ~len:n ~on_error:t\n\nlet lfindi ?(pos = 0) t ~f =\n let n = length t in\n let rec loop i = if i = n then None else if f i t.[i] then Some i else loop (i + 1) in\n loop pos\n;;\n\nlet find t ~f =\n match lfindi t ~f:(fun _ c -> f c) with\n | None -> None\n | Some i -> Some t.[i]\n;;\n\nlet find_map t ~f =\n let n = length t in\n let rec loop i =\n if i = n\n then None\n else (\n match f t.[i] with\n | None -> loop (i + 1)\n | Some _ as res -> res)\n in\n loop 0\n;;\n\nlet rfindi ?pos t ~f =\n let rec loop i = if i < 0 then None else if f i t.[i] then Some i else loop (i - 1) in\n let pos =\n match pos with\n | Some pos -> pos\n | None -> length t - 1\n in\n loop pos\n;;\n\nlet last_non_drop ~drop t = rfindi t ~f:(fun _ c -> not (drop c))\n\nlet rstrip ?(drop = Char.is_whitespace) t =\n match last_non_drop t ~drop with\n | None -> \"\"\n | Some i -> if i = length t - 1 then t else prefix t (i + 1)\n;;\n\nlet first_non_drop ~drop t = lfindi t ~f:(fun _ c -> not (drop c))\n\nlet lstrip ?(drop = Char.is_whitespace) t =\n match first_non_drop t ~drop with\n | None -> \"\"\n | Some 0 -> t\n | Some n -> drop_prefix t n\n;;\n\n(* [strip t] could be implemented as [lstrip (rstrip t)]. The implementation\n below saves (at least) a factor of two allocation, by only allocating the\n final result. This also saves some amount of time. *)\nlet strip ?(drop = Char.is_whitespace) t =\n let length = length t in\n if length = 0 || not (drop t.[0] || drop t.[length - 1])\n then t\n else (\n match first_non_drop t ~drop with\n | None -> \"\"\n | Some first ->\n (match last_non_drop t ~drop with\n | None -> assert false\n | Some last -> sub t ~pos:first ~len:(last - first + 1)))\n;;\n\nlet mapi t ~f =\n let l = length t in\n let t' = Bytes.create l in\n for i = 0 to l - 1 do\n Bytes.unsafe_set t' i (f i t.[i])\n done;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:t'\n;;\n\n(* repeated code to avoid requiring an extra allocation for a closure on each call. *)\nlet map t ~f =\n let l = length t in\n let t' = Bytes.create l in\n for i = 0 to l - 1 do\n Bytes.unsafe_set t' i (f t.[i])\n done;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:t'\n;;\n\nlet to_array s = Array.init (length s) ~f:(fun i -> s.[i])\n\nlet exists =\n let rec loop s i ~len ~f = i < len && (f s.[i] || loop s (i + 1) ~len ~f) in\n fun s ~f -> loop s 0 ~len:(length s) ~f\n;;\n\nlet for_all =\n let rec loop s i ~len ~f = i = len || (f s.[i] && loop s (i + 1) ~len ~f) in\n fun s ~f -> loop s 0 ~len:(length s) ~f\n;;\n\nlet fold t ~init ~f =\n let n = length t in\n let rec loop i ac = if i = n then ac else loop (i + 1) (f ac t.[i]) in\n loop 0 init\n;;\n\nlet foldi t ~init ~f =\n let n = length t in\n let rec loop i ac = if i = n then ac else loop (i + 1) (f i ac t.[i]) in\n loop 0 init\n;;\n\nlet count t ~f = Container.count ~fold t ~f\nlet sum m t ~f = Container.sum ~fold m t ~f\nlet min_elt t = Container.min_elt ~fold t\nlet max_elt t = Container.max_elt ~fold t\nlet fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\nlet fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\n\nlet mem =\n let rec loop t c ~pos:i ~len =\n i < len && (Char.equal c (unsafe_get t i) || loop t c ~pos:(i + 1) ~len)\n in\n fun t c -> loop t c ~pos:0 ~len:(length t)\n;;\n\nlet tr ~target ~replacement s =\n if Char.equal target replacement\n then s\n else if mem s target\n then map s ~f:(fun c -> if Char.equal c target then replacement else c)\n else s\n;;\n\nlet tr_multi ~target ~replacement =\n if is_empty target\n then stage Fn.id\n else if is_empty replacement\n then invalid_arg \"tr_multi replacement is empty string\"\n else (\n match Bytes_tr.tr_create_map ~target ~replacement with\n | None -> stage Fn.id\n | Some tr_map ->\n stage (fun s ->\n if exists s ~f:(fun c -> Char.( <> ) c (unsafe_get tr_map (Char.to_int c)))\n then map s ~f:(fun c -> unsafe_get tr_map (Char.to_int c))\n else s))\n;;\n\n(* fast version, if we ever need it:\n {[\n let concat_array ~sep ar =\n let ar_len = Array.length ar in\n if ar_len = 0 then \"\"\n else\n let sep_len = length sep in\n let res_len_ref = ref (sep_len * (ar_len - 1)) in\n for i = 0 to ar_len - 1 do\n res_len_ref := !res_len_ref + length ar.(i)\n done;\n let res = create !res_len_ref in\n let str_0 = ar.(0) in\n let len_0 = length str_0 in\n blit ~src:str_0 ~src_pos:0 ~dst:res ~dst_pos:0 ~len:len_0;\n let pos_ref = ref len_0 in\n for i = 1 to ar_len - 1 do\n let pos = !pos_ref in\n blit ~src:sep ~src_pos:0 ~dst:res ~dst_pos:pos ~len:sep_len;\n let new_pos = pos + sep_len in\n let str_i = ar.(i) in\n let len_i = length str_i in\n blit ~src:str_i ~src_pos:0 ~dst:res ~dst_pos:new_pos ~len:len_i;\n pos_ref := new_pos + len_i\n done;\n res\n ]} *)\n\nlet concat_array ?sep ar = concat ?sep (Array.to_list ar)\nlet concat_map ?sep s ~f = concat_array ?sep (Array.map (to_array s) ~f)\n\n(* [filter t f] is implemented by the following algorithm.\n\n Let [n = length t].\n\n 1. Find the lowest [i] such that [not (f t.[i])].\n\n 2. If there is no such [i], then return [t].\n\n 3. If there is such an [i], allocate a string, [out], to hold the result. [out] has\n length [n - 1], which is the maximum possible output size given that there is at least\n one character not satisfying [f].\n\n 4. Copy characters at indices 0 ... [i - 1] from [t] to [out].\n\n 5. Walk through characters at indices [i+1] ... [n-1] of [t], copying those that\n satisfy [f] from [t] to [out].\n\n 6. If we completely filled [out], then return it. If not, return the prefix of [out]\n that we did fill in.\n\n This algorithm has the property that it doesn't allocate a new string if there's\n nothing to filter, which is a common case. *)\nlet filter t ~f =\n let n = length t in\n let i = ref 0 in\n while !i < n && f t.[!i] do\n incr i\n done;\n if !i = n\n then t\n else (\n let out = Bytes.create (n - 1) in\n Bytes.blit_string ~src:t ~src_pos:0 ~dst:out ~dst_pos:0 ~len:!i;\n let out_pos = ref !i in\n incr i;\n while !i < n do\n let c = t.[!i] in\n if f c\n then (\n Bytes.set out !out_pos c;\n incr out_pos);\n incr i\n done;\n let out = Bytes.unsafe_to_string ~no_mutation_while_string_reachable:out in\n if !out_pos = n - 1 then out else sub out ~pos:0 ~len:!out_pos)\n;;\n\nlet chop_prefix s ~prefix =\n if is_prefix s ~prefix then Some (drop_prefix s (length prefix)) else None\n;;\n\nlet chop_prefix_if_exists s ~prefix =\n if is_prefix s ~prefix then drop_prefix s (length prefix) else s\n;;\n\nlet chop_prefix_exn s ~prefix =\n match chop_prefix s ~prefix with\n | Some str -> str\n | None -> invalid_argf \"String.chop_prefix_exn %S %S\" s prefix ()\n;;\n\nlet chop_suffix s ~suffix =\n if is_suffix s ~suffix then Some (drop_suffix s (length suffix)) else None\n;;\n\nlet chop_suffix_if_exists s ~suffix =\n if is_suffix s ~suffix then drop_suffix s (length suffix) else s\n;;\n\nlet chop_suffix_exn s ~suffix =\n match chop_suffix s ~suffix with\n | Some str -> str\n | None -> invalid_argf \"String.chop_suffix_exn %S %S\" s suffix ()\n;;\n\n(* There used to be a custom implementation that was faster for very short strings\n (peaking at 40% faster for 4-6 char long strings).\n This new function is around 20% faster than the default hash function, but slower\n than the previous custom implementation. However, the new OCaml function is well\n behaved, and this implementation is less likely to diverge from the default OCaml\n implementation does, which is a desirable property. (The only way to avoid the\n divergence is to expose the macro redefined in hash_stubs.c in the hash.h header of\n the OCaml compiler.) *)\nmodule Hash = struct\n external hash : string -> int = \"Base_hash_string\" [@@noalloc]\nend\n\n(* [include Hash] to make the [external] version override the [hash] from\n [Hashable.Make_binable], so that we get a little bit of a speedup by exposing it as\n external in the mli. *)\nlet _ = hash\n\ninclude Hash\ninclude Comparable.Validate (T)\n\n(* for interactive top-levels -- modules deriving from String should have String's pretty\n printer. *)\nlet pp = Caml.Format.pp_print_string\nlet of_char c = make 1 c\n\nlet of_char_list l =\n let t = Bytes.create (List.length l) in\n List.iteri l ~f:(fun i c -> Bytes.set t i c);\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:t\n;;\n\nmodule Escaping = struct\n (* If this is changed, make sure to update [escape], which attempts to ensure all the\n invariants checked here. *)\n let build_and_validate_escapeworthy_map escapeworthy_map escape_char func =\n let escapeworthy_map =\n if List.Assoc.mem escapeworthy_map ~equal:Char.equal escape_char\n then escapeworthy_map\n else (escape_char, escape_char) :: escapeworthy_map\n in\n let arr = Array.create ~len:256 (-1) in\n let vals = Array.create ~len:256 false in\n let rec loop = function\n | [] -> Ok arr\n | (c_from, c_to) :: l ->\n let k, v =\n match func with\n | `Escape -> Char.to_int c_from, c_to\n | `Unescape -> Char.to_int c_to, c_from\n in\n if arr.(k) <> -1 || vals.(Char.to_int v)\n then\n Or_error.error_s\n (Sexp.message\n \"escapeworthy_map not one-to-one\"\n [ \"c_from\", sexp_of_char c_from\n ; \"c_to\", sexp_of_char c_to\n ; ( \"escapeworthy_map\"\n , sexp_of_list (sexp_of_pair sexp_of_char sexp_of_char) escapeworthy_map\n )\n ])\n else (\n arr.(k) <- Char.to_int v;\n vals.(Char.to_int v) <- true;\n loop l)\n in\n loop escapeworthy_map\n ;;\n\n let escape_gen ~escapeworthy_map ~escape_char =\n match build_and_validate_escapeworthy_map escapeworthy_map escape_char `Escape with\n | Error _ as x -> x\n | Ok escapeworthy ->\n Ok\n (fun src ->\n (* calculate a list of (index of char to escape * escaped char) first, the order\n is from tail to head *)\n let to_escape_len = ref 0 in\n let to_escape =\n foldi src ~init:[] ~f:(fun i acc c ->\n match escapeworthy.(Char.to_int c) with\n | -1 -> acc\n | n ->\n (* (index of char to escape * escaped char) *)\n incr to_escape_len;\n (i, Char.unsafe_of_int n) :: acc)\n in\n match to_escape with\n | [] -> src\n | _ ->\n (* [to_escape] divide [src] to [List.length to_escape + 1] pieces separated by\n the chars to escape.\n\n Lets take\n {[\n escape_gen_exn\n ~escapeworthy_map:[('a', 'A'); ('b', 'B'); ('c', 'C')]\n ~escape_char:'_'\n ]}\n for example, and assume the string to escape is\n\n \"000a111b222c333\"\n\n then [to_escape] is [(11, 'C'); (7, 'B'); (3, 'A')].\n\n Then we create a [dst] of length [length src + 3] to store the\n result, copy piece \"333\" to [dst] directly, then copy '_' and 'C' to [dst];\n then move on to next; after 3 iterations, copy piece \"000\" and we are done.\n\n Finally the result will be\n\n \"000_A111_B222_C333\" *)\n let src_len = length src in\n let dst_len = src_len + !to_escape_len in\n let dst = Bytes.create dst_len in\n let rec loop last_idx last_dst_pos = function\n | [] ->\n (* copy \"000\" at last *)\n Bytes.blit_string ~src ~src_pos:0 ~dst ~dst_pos:0 ~len:last_idx\n | (idx, escaped_char) :: to_escape ->\n (*[idx] = the char to escape*)\n (* take first iteration for example *)\n (* calculate length of \"333\", minus 1 because we don't copy 'c' *)\n let len = last_idx - idx - 1 in\n (* set the dst_pos to copy to *)\n let dst_pos = last_dst_pos - len in\n (* copy \"333\", set [src_pos] to [idx + 1] to skip 'c' *)\n Bytes.blit_string ~src ~src_pos:(idx + 1) ~dst ~dst_pos ~len;\n (* backoff [dst_pos] by 2 to copy '_' and 'C' *)\n let dst_pos = dst_pos - 2 in\n Bytes.set dst dst_pos escape_char;\n Bytes.set dst (dst_pos + 1) escaped_char;\n loop idx dst_pos to_escape\n in\n (* set [last_dst_pos] and [last_idx] to length of [dst] and [src] first *)\n loop src_len dst_len to_escape;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:dst)\n ;;\n\n let escape_gen_exn ~escapeworthy_map ~escape_char =\n Or_error.ok_exn (escape_gen ~escapeworthy_map ~escape_char) |> stage\n ;;\n\n let escape ~escapeworthy ~escape_char =\n (* For [escape_gen_exn], we don't know how to fix invalid escapeworthy_map so we have\n to raise exception; but in this case, we know how to fix duplicated elements in\n escapeworthy list, so we just fix it instead of raising exception to make this\n function easier to use. *)\n let escapeworthy_map =\n escapeworthy\n |> List.dedup_and_sort ~compare:Char.compare\n |> List.map ~f:(fun c -> c, c)\n in\n escape_gen_exn ~escapeworthy_map ~escape_char\n ;;\n\n (* In an escaped string, any char is either `Escaping, `Escaped or `Literal. For\n example, the escape statuses of chars in string \"a_a__\" with escape_char = '_' are\n\n a : `Literal\n _ : `Escaping\n a : `Escaped\n _ : `Escaping\n _ : `Escaped\n\n [update_escape_status str ~escape_char i previous_status] gets escape status of\n str.[i] basing on escape status of str.[i - 1] *)\n let update_escape_status str ~escape_char i = function\n | `Escaping -> `Escaped\n | `Literal | `Escaped ->\n if Char.equal str.[i] escape_char then `Escaping else `Literal\n ;;\n\n let unescape_gen ~escapeworthy_map ~escape_char =\n match build_and_validate_escapeworthy_map escapeworthy_map escape_char `Unescape with\n | Error _ as x -> x\n | Ok escapeworthy ->\n Ok\n (fun src ->\n (* Continue the example in [escape_gen_exn], now we unescape\n\n \"000_A111_B222_C333\"\n\n back to\n\n \"000a111b222c333\"\n\n Then [to_unescape] is [14; 9; 4], which is indexes of '_'s.\n\n Then we create a string [dst] to store the result, copy \"333\" to it, then copy\n 'c', then move on to next iteration. After 3 iterations copy \"000\" and we are\n done. *)\n (* indexes of escape chars *)\n let to_unescape =\n let rec loop i status acc =\n if i >= length src\n then acc\n else (\n let status = update_escape_status src ~escape_char i status in\n loop\n (i + 1)\n status\n (match status with\n | `Escaping -> i :: acc\n | `Escaped | `Literal -> acc))\n in\n loop 0 `Literal []\n in\n match to_unescape with\n | [] -> src\n | idx :: to_unescape' ->\n let dst = Bytes.create (length src - List.length to_unescape) in\n let rec loop last_idx last_dst_pos = function\n | [] ->\n (* copy \"000\" at last *)\n Bytes.blit_string ~src ~src_pos:0 ~dst ~dst_pos:0 ~len:last_idx\n | idx :: to_unescape ->\n (* [idx] = index of escaping char *)\n (* take 1st iteration as example, calculate the length of \"333\", minus 2 to\n skip '_C' *)\n let len = last_idx - idx - 2 in\n (* point [dst_pos] to the position to copy \"333\" to *)\n let dst_pos = last_dst_pos - len in\n (* copy \"333\" *)\n Bytes.blit_string ~src ~src_pos:(idx + 2) ~dst ~dst_pos ~len;\n (* backoff [dst_pos] by 1 to copy 'c' *)\n let dst_pos = dst_pos - 1 in\n Bytes.set\n dst\n dst_pos\n (match escapeworthy.(Char.to_int src.[idx + 1]) with\n | -1 -> src.[idx + 1]\n | n -> Char.unsafe_of_int n);\n (* update [last_dst_pos] and [last_idx] *)\n loop idx dst_pos to_unescape\n in\n if idx < length src - 1\n then\n (* set [last_dst_pos] and [last_idx] to length of [dst] and [src] *)\n loop (length src) (Bytes.length dst) to_unescape\n else\n (* for escaped string ending with an escaping char like \"000_\", just ignore\n the last escaping char *)\n loop (length src - 1) (Bytes.length dst) to_unescape';\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:dst)\n ;;\n\n let unescape_gen_exn ~escapeworthy_map ~escape_char =\n Or_error.ok_exn (unescape_gen ~escapeworthy_map ~escape_char) |> stage\n ;;\n\n let unescape ~escape_char = unescape_gen_exn ~escapeworthy_map:[] ~escape_char\n\n let preceding_escape_chars str ~escape_char pos =\n let rec loop p cnt =\n if p < 0 || Char.( <> ) str.[p] escape_char then cnt else loop (p - 1) (cnt + 1)\n in\n loop (pos - 1) 0\n ;;\n\n (* In an escaped string, any char is either `Escaping, `Escaped or `Literal. For\n example, the escape statuses of chars in string \"a_a__\" with escape_char = '_' are\n\n a : `Literal\n _ : `Escaping\n a : `Escaped\n _ : `Escaping\n _ : `Escaped\n\n [update_escape_status str ~escape_char i previous_status] gets escape status of\n str.[i] basing on escape status of str.[i - 1] *)\n let update_escape_status str ~escape_char i = function\n | `Escaping -> `Escaped\n | `Literal | `Escaped ->\n if Char.equal str.[i] escape_char then `Escaping else `Literal\n ;;\n\n let escape_status str ~escape_char pos =\n let odd = preceding_escape_chars str ~escape_char pos mod 2 = 1 in\n match odd, Char.equal str.[pos] escape_char with\n | true, (true | false) -> `Escaped\n | false, true -> `Escaping\n | false, false -> `Literal\n ;;\n\n let check_bound str pos function_name =\n if pos >= length str || pos < 0\n then invalid_argf \"%s: out of bounds\" function_name ()\n ;;\n\n let is_char_escaping str ~escape_char pos =\n check_bound str pos \"is_char_escaping\";\n match escape_status str ~escape_char pos with\n | `Escaping -> true\n | `Escaped | `Literal -> false\n ;;\n\n let is_char_escaped str ~escape_char pos =\n check_bound str pos \"is_char_escaped\";\n match escape_status str ~escape_char pos with\n | `Escaped -> true\n | `Escaping | `Literal -> false\n ;;\n\n let is_char_literal str ~escape_char pos =\n check_bound str pos \"is_char_literal\";\n match escape_status str ~escape_char pos with\n | `Literal -> true\n | `Escaped | `Escaping -> false\n ;;\n\n let index_from str ~escape_char pos char =\n check_bound str pos \"index_from\";\n let rec loop i status =\n if i >= pos\n && (match status with\n | `Literal -> true\n | `Escaped | `Escaping -> false)\n && Char.equal str.[i] char\n then Some i\n else (\n let i = i + 1 in\n if i >= length str\n then None\n else loop i (update_escape_status str ~escape_char i status))\n in\n loop pos (escape_status str ~escape_char pos)\n ;;\n\n let index_from_exn str ~escape_char pos char =\n match index_from str ~escape_char pos char with\n | None ->\n raise_s\n (Sexp.message\n \"index_from_exn: not found\"\n [ \"str\", sexp_of_t str\n ; \"escape_char\", sexp_of_char escape_char\n ; \"pos\", sexp_of_int pos\n ; \"char\", sexp_of_char char\n ])\n | Some pos -> pos\n ;;\n\n let index str ~escape_char char = index_from str ~escape_char 0 char\n let index_exn str ~escape_char char = index_from_exn str ~escape_char 0 char\n\n let rindex_from str ~escape_char pos char =\n check_bound str pos \"rindex_from\";\n (* if the target char is the same as [escape_char], we have no way to determine which\n escape_char is literal, so just return None *)\n if Char.equal char escape_char\n then None\n else (\n let rec loop pos =\n if pos < 0\n then None\n else (\n let escape_chars = preceding_escape_chars str ~escape_char pos in\n if escape_chars mod 2 = 0 && Char.equal str.[pos] char\n then Some pos\n else loop (pos - escape_chars - 1))\n in\n loop pos)\n ;;\n\n let rindex_from_exn str ~escape_char pos char =\n match rindex_from str ~escape_char pos char with\n | None ->\n raise_s\n (Sexp.message\n \"rindex_from_exn: not found\"\n [ \"str\", sexp_of_t str\n ; \"escape_char\", sexp_of_char escape_char\n ; \"pos\", sexp_of_int pos\n ; \"char\", sexp_of_char char\n ])\n | Some pos -> pos\n ;;\n\n let rindex str ~escape_char char =\n if is_empty str then None else rindex_from str ~escape_char (length str - 1) char\n ;;\n\n let rindex_exn str ~escape_char char =\n rindex_from_exn str ~escape_char (length str - 1) char\n ;;\n\n (* [split_gen str ~escape_char ~on] works similarly to [String.split_gen], with an\n additional requirement: only split on literal chars, not escaping or escaped *)\n let split_gen str ~escape_char ~on =\n let is_delim =\n match on with\n | `char c' -> fun c -> Char.equal c c'\n | `char_list l -> fun c -> char_list_mem l c\n in\n let len = length str in\n let rec loop acc status last_pos pos =\n if pos = len\n then List.rev (sub str ~pos:last_pos ~len:(len - last_pos) :: acc)\n else (\n let status = update_escape_status str ~escape_char pos status in\n if (match status with\n | `Literal -> true\n | `Escaped | `Escaping -> false)\n && is_delim str.[pos]\n then (\n let sub_str = sub str ~pos:last_pos ~len:(pos - last_pos) in\n loop (sub_str :: acc) status (pos + 1) (pos + 1))\n else loop acc status last_pos (pos + 1))\n in\n loop [] `Literal 0 0\n ;;\n\n let split str ~on = split_gen str ~on:(`char on)\n let split_on_chars str ~on:chars = split_gen str ~on:(`char_list chars)\n\n let split_at str pos =\n sub str ~pos:0 ~len:pos, sub str ~pos:(pos + 1) ~len:(length str - pos - 1)\n ;;\n\n let lsplit2 str ~on ~escape_char =\n Option.map (index str ~escape_char on) ~f:(fun x -> split_at str x)\n ;;\n\n let rsplit2 str ~on ~escape_char =\n Option.map (rindex str ~escape_char on) ~f:(fun x -> split_at str x)\n ;;\n\n let lsplit2_exn str ~on ~escape_char = split_at str (index_exn str ~escape_char on)\n let rsplit2_exn str ~on ~escape_char = split_at str (rindex_exn str ~escape_char on)\n\n (* [last_non_drop_literal] and [first_non_drop_literal] are either both [None] or both\n [Some]. If [Some], then the former is >= the latter. *)\n let last_non_drop_literal ~drop ~escape_char t =\n rfindi t ~f:(fun i c ->\n (not (drop c))\n || is_char_escaping t ~escape_char i\n || is_char_escaped t ~escape_char i)\n ;;\n\n let first_non_drop_literal ~drop ~escape_char t =\n lfindi t ~f:(fun i c ->\n (not (drop c))\n || is_char_escaping t ~escape_char i\n || is_char_escaped t ~escape_char i)\n ;;\n\n let rstrip_literal ?(drop = Char.is_whitespace) t ~escape_char =\n match last_non_drop_literal t ~drop ~escape_char with\n | None -> \"\"\n | Some i -> if i = length t - 1 then t else prefix t (i + 1)\n ;;\n\n let lstrip_literal ?(drop = Char.is_whitespace) t ~escape_char =\n match first_non_drop_literal t ~drop ~escape_char with\n | None -> \"\"\n | Some 0 -> t\n | Some n -> drop_prefix t n\n ;;\n\n (* [strip t] could be implemented as [lstrip (rstrip t)]. The implementation\n below saves (at least) a factor of two allocation, by only allocating the\n final result. This also saves some amount of time. *)\n let strip_literal ?(drop = Char.is_whitespace) t ~escape_char =\n let length = length t in\n (* performance hack: avoid copying [t] in common cases *)\n if length = 0 || not (drop t.[0] || drop t.[length - 1])\n then t\n else (\n match first_non_drop_literal t ~drop ~escape_char with\n | None -> \"\"\n | Some first ->\n (match last_non_drop_literal t ~drop ~escape_char with\n | None -> assert false\n | Some last -> sub t ~pos:first ~len:(last - first + 1)))\n ;;\nend\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! String_replace_polymorphic_compare\n\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\n(* Override [Search_pattern] with default case-sensitivity argument at the end of the\n file, so that call sites above are forced to supply case-sensitivity explicitly. *)\nmodule Search_pattern = struct\n include Search_pattern0\n\n let create ?(case_sensitive = true) pattern = create pattern ~case_sensitive\nend\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude String_replace_polymorphic_compare\n","open! Import\nmodule Array = Array0\n\nlet stage = Staged.stage\n\nmodule T = struct\n type t = bytes [@@deriving_inline sexp, sexp_grammar]\n\n let t_of_sexp = (bytes_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_bytes : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"bytes\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ bytes_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"bytes.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n include Bytes0\n\n let module_name = \"Base.Bytes\"\n let pp fmt t = Caml.Format.fprintf fmt \"%S\" (to_string t)\nend\n\ninclude T\n\nmodule To_bytes = Blit.Make (struct\n include T\n\n let create ~len = create len\n end)\n\ninclude To_bytes\ninclude Comparator.Make (T)\ninclude Comparable.Validate (T)\ninclude Pretty_printer.Register_pp (T)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! Bytes_replace_polymorphic_compare\nmodule To_string = Blit.Make_to_string (T) (To_bytes)\n\nmodule From_string =\n Blit.Make_distinct\n (struct\n type t = string\n\n let length = String.length\n end)\n (struct\n type nonrec t = t\n\n let create ~len = create len\n let length = length\n let unsafe_blit = unsafe_blit_string\n end)\n\nlet invariant (_ : t) = ()\n\nlet init n ~f =\n if Int_replace_polymorphic_compare.( < ) n 0\n then Printf.invalid_argf \"Bytes.init %d\" n ();\n let t = create n in\n for i = 0 to n - 1 do\n unsafe_set t i (f i)\n done;\n t\n;;\n\nlet of_char_list l =\n let t = create (List.length l) in\n List.iteri l ~f:(fun i c -> set t i c);\n t\n;;\n\nlet to_list t =\n let rec loop t i acc =\n if Int_replace_polymorphic_compare.( < ) i 0\n then acc\n else loop t (i - 1) (unsafe_get t i :: acc)\n in\n loop t (length t - 1) []\n;;\n\nlet to_array t = Array.init (length t) ~f:(fun i -> unsafe_get t i)\nlet map t ~f = map t ~f\nlet mapi t ~f = mapi t ~f\n\nlet fold =\n let rec loop t ~f ~len ~pos acc =\n if Int_replace_polymorphic_compare.equal pos len\n then acc\n else loop t ~f ~len ~pos:(pos + 1) (f acc (unsafe_get t pos))\n in\n fun t ~init ~f -> loop t ~f ~len:(length t) ~pos:0 init\n;;\n\nlet foldi =\n let rec loop t ~f ~len ~pos acc =\n if Int_replace_polymorphic_compare.equal pos len\n then acc\n else loop t ~f ~len ~pos:(pos + 1) (f pos acc (unsafe_get t pos))\n in\n fun t ~init ~f -> loop t ~f ~len:(length t) ~pos:0 init\n;;\n\nlet tr ~target ~replacement s =\n for i = 0 to length s - 1 do\n if Char.equal (unsafe_get s i) target then unsafe_set s i replacement\n done\n;;\n\nlet tr_multi ~target ~replacement =\n if Int_replace_polymorphic_compare.( = ) (String.length target) 0\n then stage ignore\n else if Int_replace_polymorphic_compare.( = ) (String.length replacement) 0\n then invalid_arg \"tr_multi: replacement is the empty string\"\n else (\n match Bytes_tr.tr_create_map ~target ~replacement with\n | None -> stage ignore\n | Some tr_map ->\n stage (fun s ->\n for i = 0 to length s - 1 do\n unsafe_set s i (String.unsafe_get tr_map (Char.to_int (unsafe_get s i)))\n done))\n;;\n\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet contains ?pos ?len t char =\n let pos, len =\n Ordered_collection_common.get_pos_len_exn () ?pos ?len ~total_length:(length t)\n in\n let last = pos + len in\n let rec loop i =\n Int_replace_polymorphic_compare.( < ) i last\n && (Char.equal (get t i) char || loop (i + 1))\n in\n loop pos\n;;\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Bytes_replace_polymorphic_compare\n","(* This file was autogenerated by ../generate/generate_pow_overflow_bounds.exe *)\n\nopen! Import\n\nmodule Array = Array0\n\n(* We have to use Int64.to_int_exn instead of int constants to make\n sure that file can be preprocessed on 32-bit machines. *)\n\nlet overflow_bound_max_int32_value : int32 =\n 2147483647l\n\nlet int32_positive_overflow_bounds : int32 array =\n [| 2147483647l\n ; 2147483647l\n ; 46340l\n ; 1290l\n ; 215l\n ; 73l\n ; 35l\n ; 21l\n ; 14l\n ; 10l\n ; 8l\n ; 7l\n ; 5l\n ; 5l\n ; 4l\n ; 4l\n ; 3l\n ; 3l\n ; 3l\n ; 3l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 2l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n ; 1l\n |]\n\nlet overflow_bound_max_int_value : int =\n (-1) lsr 1\n\nlet int_positive_overflow_bounds : int array =\n match Int_conversions.num_bits_int with\n | 32 -> Array.map int32_positive_overflow_bounds ~f:Caml.Int32.to_int\n | 63 ->\n [| Caml.Int64.to_int 4611686018427387903L\n ; Caml.Int64.to_int 4611686018427387903L\n ; Caml.Int64.to_int 2147483647L\n ; 1664510\n ; 46340\n ; 5404\n ; 1290\n ; 463\n ; 215\n ; 118\n ; 73\n ; 49\n ; 35\n ; 27\n ; 21\n ; 17\n ; 14\n ; 12\n ; 10\n ; 9\n ; 8\n ; 7\n ; 7\n ; 6\n ; 5\n ; 5\n ; 5\n ; 4\n ; 4\n ; 4\n ; 4\n ; 3\n ; 3\n ; 3\n ; 3\n ; 3\n ; 3\n ; 3\n ; 3\n ; 3\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 1\n ; 1\n |]\n | 31 ->\n [| 1073741823\n ; 1073741823\n ; 32767\n ; 1023\n ; 181\n ; 63\n ; 31\n ; 19\n ; 13\n ; 10\n ; 7\n ; 6\n ; 5\n ; 4\n ; 4\n ; 3\n ; 3\n ; 3\n ; 3\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 2\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n ; 1\n |]\n | _ -> assert false\n\nlet overflow_bound_max_int63_on_int64_value : int64 =\n 4611686018427387903L\n\nlet int63_on_int64_positive_overflow_bounds : int64 array =\n [| 4611686018427387903L\n ; 4611686018427387903L\n ; 2147483647L\n ; 1664510L\n ; 46340L\n ; 5404L\n ; 1290L\n ; 463L\n ; 215L\n ; 118L\n ; 73L\n ; 49L\n ; 35L\n ; 27L\n ; 21L\n ; 17L\n ; 14L\n ; 12L\n ; 10L\n ; 9L\n ; 8L\n ; 7L\n ; 7L\n ; 6L\n ; 5L\n ; 5L\n ; 5L\n ; 4L\n ; 4L\n ; 4L\n ; 4L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 1L\n ; 1L\n |]\n\nlet overflow_bound_max_int64_value : int64 =\n 9223372036854775807L\n\nlet int64_positive_overflow_bounds : int64 array =\n [| 9223372036854775807L\n ; 9223372036854775807L\n ; 3037000499L\n ; 2097151L\n ; 55108L\n ; 6208L\n ; 1448L\n ; 511L\n ; 234L\n ; 127L\n ; 78L\n ; 52L\n ; 38L\n ; 28L\n ; 22L\n ; 18L\n ; 15L\n ; 13L\n ; 11L\n ; 9L\n ; 8L\n ; 7L\n ; 7L\n ; 6L\n ; 6L\n ; 5L\n ; 5L\n ; 5L\n ; 4L\n ; 4L\n ; 4L\n ; 4L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 3L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 2L\n ; 1L\n |]\n\nlet int64_negative_overflow_bounds : int64 array =\n [| -9223372036854775807L\n ; -9223372036854775807L\n ; -3037000499L\n ; -2097151L\n ; -55108L\n ; -6208L\n ; -1448L\n ; -511L\n ; -234L\n ; -127L\n ; -78L\n ; -52L\n ; -38L\n ; -28L\n ; -22L\n ; -18L\n ; -15L\n ; -13L\n ; -11L\n ; -9L\n ; -8L\n ; -7L\n ; -7L\n ; -6L\n ; -6L\n ; -5L\n ; -5L\n ; -5L\n ; -4L\n ; -4L\n ; -4L\n ; -4L\n ; -3L\n ; -3L\n ; -3L\n ; -3L\n ; -3L\n ; -3L\n ; -3L\n ; -3L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -2L\n ; -1L\n |]\n","open! Import\n\nlet invalid_argf = Printf.invalid_argf\nlet negative_exponent () = Printf.invalid_argf \"exponent can not be negative\" ()\nlet overflow () = Printf.invalid_argf \"integer overflow in pow\" ()\n\n(* To implement [int64_pow], we use C code rather than OCaml to eliminate allocation. *)\nexternal int_math_int_pow : int -> int -> int = \"Base_int_math_int_pow_stub\" [@@noalloc]\nexternal int_math_int64_pow : int64 -> int64 -> int64 = \"Base_int_math_int64_pow_stub\"\n\nlet int_pow base exponent =\n if exponent < 0 then negative_exponent ();\n if abs base > 1\n && (exponent > 63\n || abs base > Pow_overflow_bounds.int_positive_overflow_bounds.(exponent))\n then overflow ();\n int_math_int_pow base exponent\n;;\n\nmodule Int64_with_comparisons = struct\n include Caml.Int64\n\n external ( < ) : int64 -> int64 -> bool = \"%lessthan\"\n external ( > ) : int64 -> int64 -> bool = \"%greaterthan\"\n external ( >= ) : int64 -> int64 -> bool = \"%greaterequal\"\nend\n\n(* we don't do [abs] in int64 case to avoid allocation *)\nlet int64_pow base exponent =\n let open Int64_with_comparisons in\n if exponent < 0L then negative_exponent ();\n if (base > 1L || base < -1L)\n && (exponent > 63L\n || (base >= 0L\n && base > Pow_overflow_bounds.int64_positive_overflow_bounds.(to_int exponent)\n )\n || (base < 0L\n && base < Pow_overflow_bounds.int64_negative_overflow_bounds.(to_int exponent)\n ))\n then overflow ();\n int_math_int64_pow base exponent\n;;\n\nlet int63_pow_on_int64 base exponent =\n let open Int64_with_comparisons in\n if exponent < 0L then negative_exponent ();\n if abs base > 1L\n && (exponent > 63L\n || abs base\n > Pow_overflow_bounds.int63_on_int64_positive_overflow_bounds.(to_int exponent)\n )\n then overflow ();\n int_math_int64_pow base exponent\n;;\n\nmodule type Make_arg = sig\n type t\n\n include Floatable.S with type t := t\n include Stringable.S with type t := t\n\n val ( + ) : t -> t -> t\n val ( - ) : t -> t -> t\n val ( * ) : t -> t -> t\n val ( / ) : t -> t -> t\n val ( ~- ) : t -> t\n\n include Comparisons.Infix with type t := t\n\n val abs : t -> t\n val neg : t -> t\n val zero : t\n val of_int_exn : int -> t\n val rem : t -> t -> t\nend\n\nmodule Make (X : Make_arg) = struct\n open X\n\n let ( % ) x y =\n if y <= zero\n then\n invalid_argf\n \"%s %% %s in core_int.ml: modulus should be positive\"\n (to_string x)\n (to_string y)\n ();\n let rval = X.rem x y in\n if rval < zero then rval + y else rval\n ;;\n\n let one = of_int_exn 1\n\n let ( /% ) x y =\n if y <= zero\n then\n invalid_argf\n \"%s /%% %s in core_int.ml: divisor should be positive\"\n (to_string x)\n (to_string y)\n ();\n if x < zero then ((x + one) / y) - one else x / y\n ;;\n\n (** float division of integers *)\n let ( // ) x y = to_float x /. to_float y\n\n let round_down i ~to_multiple_of:modulus = i - (i % modulus)\n\n let round_up i ~to_multiple_of:modulus =\n let remainder = i % modulus in\n if remainder = zero then i else i + modulus - remainder\n ;;\n\n let round_towards_zero i ~to_multiple_of =\n if i = zero\n then zero\n else if i > zero\n then round_down i ~to_multiple_of\n else round_up i ~to_multiple_of\n ;;\n\n let round_nearest i ~to_multiple_of:modulus =\n let remainder = i % modulus in\n let modulus_minus_remainder = modulus - remainder in\n if modulus_minus_remainder <= remainder\n then i + modulus_minus_remainder\n else i - remainder\n ;;\n\n let round ?(dir = `Nearest) i ~to_multiple_of =\n match dir with\n | `Nearest -> round_nearest i ~to_multiple_of\n | `Down -> round_down i ~to_multiple_of\n | `Up -> round_up i ~to_multiple_of\n | `Zero -> round_towards_zero i ~to_multiple_of\n ;;\nend\n\nmodule Private = struct\n let int_pow = int_pow\n let int64_pow = int64_pow\n let int63_pow_on_int64 = int63_pow_on_int64\n\n module Pow_overflow_bounds = Pow_overflow_bounds\nend\n","open! Import\ninclude Int_intf\ninclude Int0\n\nmodule T = struct\n type t = int [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int in\n fun x -> func x\n ;;\n\n let t_of_sexp = (int_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_int : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"int\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ int_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"int.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare x y = Int_replace_polymorphic_compare.compare x y\n\n let of_string s =\n try of_string s with\n | _ -> Printf.failwithf \"Int.of_string: %S\" s ()\n ;;\n\n let to_string = to_string\nend\n\nlet num_bits = Int_conversions.num_bits_int\nlet float_lower_bound = Float0.lower_bound_for_int num_bits\nlet float_upper_bound = Float0.upper_bound_for_int num_bits\nlet to_float = Caml.float_of_int\nlet of_float_unchecked = Caml.int_of_float\n\nlet of_float f =\n if Float_replace_polymorphic_compare.( >= ) f float_lower_bound\n && Float_replace_polymorphic_compare.( <= ) f float_upper_bound\n then Caml.int_of_float f\n else\n Printf.invalid_argf\n \"Int.of_float: argument (%f) is out of range or NaN\"\n (Float0.box f)\n ()\n;;\n\nlet zero = 0\nlet one = 1\nlet minus_one = -1\n\ninclude T\ninclude Comparator.Make (T)\n\ninclude Comparable.Validate_with_zero (struct\n include T\n\n let zero = zero\n end)\n\nmodule Conv = Int_conversions\ninclude Conv.Make (T)\n\ninclude Conv.Make_hex (struct\n open Int_replace_polymorphic_compare\n\n type t = int [@@deriving_inline compare, hash]\n\n let compare = (compare_int : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let zero = zero\n let neg = ( ~- )\n let ( < ) = ( < )\n let to_string i = Printf.sprintf \"%x\" i\n let of_string s = Caml.Scanf.sscanf s \"%x\" Fn.id\n let module_name = \"Base.Int.Hex\"\n end)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Base.Int\"\n end)\n\n(* Open replace_polymorphic_compare after including functor instantiations so\n they do not shadow its definitions. This is here so that efficient versions\n of the comparison functions are available within this module. *)\nopen! Int_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet pred i = i - 1\nlet succ i = i + 1\nlet to_int i = i\nlet to_int_exn = to_int\nlet of_int i = i\nlet of_int_exn = of_int\nlet max_value = Caml.max_int\nlet min_value = Caml.min_int\nlet max_value_30_bits = 0x3FFF_FFFF\nlet of_int32 = Conv.int32_to_int\nlet of_int32_exn = Conv.int32_to_int_exn\nlet of_int32_trunc = Conv.int32_to_int_trunc\nlet to_int32 = Conv.int_to_int32\nlet to_int32_exn = Conv.int_to_int32_exn\nlet to_int32_trunc = Conv.int_to_int32_trunc\nlet of_int64 = Conv.int64_to_int\nlet of_int64_exn = Conv.int64_to_int_exn\nlet of_int64_trunc = Conv.int64_to_int_trunc\nlet to_int64 = Conv.int_to_int64\nlet of_nativeint = Conv.nativeint_to_int\nlet of_nativeint_exn = Conv.nativeint_to_int_exn\nlet of_nativeint_trunc = Conv.nativeint_to_int_trunc\nlet to_nativeint = Conv.int_to_nativeint\nlet to_nativeint_exn = to_nativeint\nlet abs x = abs x\nlet ( + ) x y = x + y\nlet ( - ) x y = x - y\nlet ( * ) x y = x * y\nlet ( / ) x y = x / y\nlet neg x = -x\nlet ( ~- ) = neg\n\n(* note that rem is not same as % *)\nlet rem a b = a mod b\nlet incr = Caml.incr\nlet decr = Caml.decr\nlet shift_right a b = a asr b\nlet shift_right_logical a b = a lsr b\nlet shift_left a b = a lsl b\nlet bit_not a = lnot a\nlet bit_or a b = a lor b\nlet bit_and a b = a land b\nlet bit_xor a b = a lxor b\nlet pow = Int_math.Private.int_pow\nlet ( ** ) b e = pow b e\n\nmodule Pow2 = struct\n open! Import\n module Sys = Sys0\n\n let raise_s = Error.raise_s\n\n let non_positive_argument () =\n Printf.invalid_argf \"argument must be strictly positive\" ()\n ;;\n\n\n (** \"ceiling power of 2\" - Least power of 2 greater than or equal to x. *)\n let ceil_pow2 x =\n if x <= 0 then non_positive_argument ();\n let x = x - 1 in\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n (* The next line is superfluous on 32-bit architectures, but it's faster to do it\n anyway than to branch *)\n let x = x lor (x lsr 32) in\n x + 1\n ;;\n\n (** \"floor power of 2\" - Largest power of 2 less than or equal to x. *)\n let floor_pow2 x =\n if x <= 0 then non_positive_argument ();\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n (* The next line is superfluous on 32-bit architectures, but it's faster to do it\n anyway than to branch *)\n let x = x lor (x lsr 32) in\n x - (x lsr 1)\n ;;\n\n let is_pow2 x =\n if x <= 0 then non_positive_argument ();\n x land (x - 1) = 0\n ;;\n\n (* C stubs for int clz and ctz to use the CLZ/BSR/CTZ/BSF instruction where possible *)\n external clz\n : (* Note that we pass the tagged int here. See int_math_stubs.c for details on why\n this is correct. *)\n int\n -> (int[@untagged])\n = \"Base_int_math_int_clz\" \"Base_int_math_int_clz_untagged\"\n [@@noalloc]\n\n external ctz\n : (int[@untagged])\n -> (int[@untagged])\n = \"Base_int_math_int_ctz\" \"Base_int_math_int_ctz_untagged\"\n [@@noalloc]\n\n (** Hacker's Delight Second Edition p106 *)\n let floor_log2 i =\n if i <= 0\n then\n raise_s (Sexp.message \"[Int.floor_log2] got invalid input\" [ \"\", sexp_of_int i ]);\n num_bits - 1 - clz i\n ;;\n\n let ceil_log2 i =\n if i <= 0\n then raise_s (Sexp.message \"[Int.ceil_log2] got invalid input\" [ \"\", sexp_of_int i ]);\n if i = 1 then 0 else num_bits - clz (i - 1)\n ;;\nend\n\ninclude Pow2\n\n(* This is already defined by Comparable.Validate_with_zero, but Sign.of_int is\n more direct. *)\nlet sign = Sign.of_int\nlet popcount = Popcount.int_popcount\n\nmodule Pre_O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Int_replace_polymorphic_compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int_exn = of_int_exn\nend\n\nmodule O = struct\n include Pre_O\n\n module F = Int_math.Make (struct\n type nonrec t = t\n\n include Pre_O\n\n let rem = rem\n let to_float = to_float\n let of_float = of_float\n let of_string = T.of_string\n let to_string = T.to_string\n end)\n\n include F\n\n external bswap16 : int -> int = \"%bswap16\"\n\n (* These inlined versions of (%), (/%), and (//) perform better than their functorized\n counterparts in [F] (see benchmarks below).\n\n The reason these functions are inlined in [Int] but not in any of the other integer\n modules is that they existed in [Int] and [Int] alone prior to the introduction of\n the [Int_math.Make] functor, and we didn't want to degrade their performance.\n\n We won't pre-emptively do the same for new functions, unless someone cares, on a case\n by case fashion. *)\n\n let ( % ) x y =\n if y <= zero\n then\n Printf.invalid_argf\n \"%s %% %s in core_int.ml: modulus should be positive\"\n (to_string x)\n (to_string y)\n ();\n let rval = rem x y in\n if rval < zero then rval + y else rval\n ;;\n\n let ( /% ) x y =\n if y <= zero\n then\n Printf.invalid_argf\n \"%s /%% %s in core_int.ml: divisor should be positive\"\n (to_string x)\n (to_string y)\n ();\n if x < zero then ((x + one) / y) - one else x / y\n ;;\n\n let ( // ) x y = to_float x /. to_float y\n let ( land ) = ( land )\n let ( lor ) = ( lor )\n let ( lxor ) = ( lxor )\n let lnot = lnot\n let ( lsl ) = ( lsl )\n let ( asr ) = ( asr )\n let ( lsr ) = ( lsr )\nend\n\ninclude O\n\n(* [Int] and [Int.O] agree value-wise *)\n\nmodule Private = struct\n module O_F = O.F\nend\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after including functor\n application that could shadow its definitions. This is here so that efficient versions\n of the comparison functions are exported by this module. *)\ninclude Int_replace_polymorphic_compare\n","open! Import\n\ntype ('a, 'b) t = T : ('a, 'a) t [@@deriving_inline sexp_of]\n\nlet sexp_of_t\n : type a b.\n (a -> Ppx_sexp_conv_lib.Sexp.t)\n -> (b -> Ppx_sexp_conv_lib.Sexp.t)\n -> (a, b) t\n -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a _of_b -> function\n | T -> Ppx_sexp_conv_lib.Sexp.Atom \"T\"\n;;\n\n[@@@end]\n\ntype ('a, 'b) equal = ('a, 'b) t\n\nlet refl = T\nlet sym (type a b) (T : (a, b) t) : (b, a) t = T\nlet trans (type a b c) (T : (a, b) t) (T : (b, c) t) : (a, c) t = T\nlet conv (type a b) (T : (a, b) t) (a : a) : b = a\n\nmodule Lift (X : sig\n type 'a t\n end) =\nstruct\n let lift (type a b) (T : (a, b) t) : (a X.t, b X.t) t = T\nend\n\nmodule Lift2 (X : sig\n type ('a1, 'a2) t\n end) =\nstruct\n let lift (type a1 b1 a2 b2) (T : (a1, b1) t) (T : (a2, b2) t)\n : ((a1, a2) X.t, (b1, b2) X.t) t\n =\n T\n ;;\nend\n\nmodule Lift3 (X : sig\n type ('a1, 'a2, 'a3) t\n end) =\nstruct\n let lift (type a1 b1 a2 b2 a3 b3) (T : (a1, b1) t) (T : (a2, b2) t) (T : (a3, b3) t)\n : ((a1, a2, a3) X.t, (b1, b2, b3) X.t) t\n =\n T\n ;;\nend\n\nlet detuple2 (type a1 a2 b1 b2) (T : (a1 * a2, b1 * b2) t) : (a1, b1) t * (a2, b2) t =\n T, T\n;;\n\nlet tuple2 (type a1 a2 b1 b2) (T : (a1, b1) t) (T : (a2, b2) t) : (a1 * a2, b1 * b2) t =\n T\n;;\n\nmodule type Injective = sig\n type 'a t\n\n val strip : ('a t, 'b t) equal -> ('a, 'b) equal\nend\n\nmodule type Injective2 = sig\n type ('a1, 'a2) t\n\n val strip : (('a1, 'a2) t, ('b1, 'b2) t) equal -> ('a1, 'b1) equal * ('a2, 'b2) equal\nend\n\nmodule Composition_preserves_injectivity (M1 : Injective) (M2 : Injective) = struct\n type 'a t = 'a M1.t M2.t\n\n let strip e = M1.strip (M2.strip e)\nend\n\nmodule Obj = struct\n module Extension_constructor = struct\n [@@@ocaml.warning \"-3\"]\n\n let id = Caml.Obj.extension_id\n let of_val = Caml.Obj.extension_constructor\n end\nend\n\nmodule Id = struct\n module Uid = Int\n\n module Witness = struct\n module Key = struct\n type _ t = ..\n type type_witness_int = [ `type_witness of int ] [@@deriving_inline sexp_of]\n\n let sexp_of_type_witness_int =\n (function\n | `type_witness v0 ->\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"type_witness\"; sexp_of_int v0 ]\n : type_witness_int -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\n\n let sexp_of_t _sexp_of_a t =\n `type_witness (Obj.Extension_constructor.id (Obj.Extension_constructor.of_val t))\n |> sexp_of_type_witness_int\n ;;\n end\n\n module type S = sig\n type t\n type _ Key.t += Key : t Key.t\n end\n\n type 'a t = (module S with type t = 'a)\n\n let sexp_of_t (type a) sexp_of_a (module M : S with type t = a) =\n M.Key |> Key.sexp_of_t sexp_of_a\n ;;\n\n let create (type t) () =\n let module M = struct\n type nonrec t = t\n type _ Key.t += Key : t Key.t\n end\n in\n (module M : S with type t = t)\n ;;\n\n let uid (type a) (module M : S with type t = a) =\n Obj.Extension_constructor.id (Obj.Extension_constructor.of_val M.Key)\n ;;\n\n (* We want a constant allocated once that [same] can return whenever it gets the same\n witnesses. If we write the constant inside the body of [same], the native-code\n compiler will do the right thing and lift it out. But for clarity and robustness,\n we do it ourselves. *)\n let some_t = Some T\n\n let same (type a b) (a : a t) (b : b t) : (a, b) equal option =\n let module A = (val a : S with type t = a) in\n let module B = (val b : S with type t = b) in\n match A.Key with\n | B.Key -> some_t\n | _ -> None\n ;;\n end\n\n\n type 'a t =\n { witness : 'a Witness.t\n ; name : string\n ; to_sexp : 'a -> Sexp.t\n }\n\n let sexp_of_t _ { witness; name; to_sexp } : Sexp.t =\n if am_testing\n then Atom name\n else\n List\n [ List [ Atom \"name\"; Atom name ]\n ; List [ Atom \"witness\"; witness |> Witness.sexp_of_t to_sexp ]\n ]\n ;;\n\n let to_sexp t = t.to_sexp\n let name t = t.name\n let create ~name to_sexp = { witness = Witness.create (); name; to_sexp }\n let uid t = Witness.uid t.witness\n let hash t = uid t\n let hash_fold_t s t = hash_fold_int s (uid t)\n let same_witness t1 t2 = Witness.same t1.witness t2.witness\n let same t1 t2 = Option.is_some (same_witness t1 t2)\n\n let same_witness_exn t1 t2 =\n match same_witness t1 t2 with\n | Some w -> w\n | None ->\n Error.raise_s\n (Sexp.message\n \"Type_equal.Id.same_witness_exn got different ids\"\n [ ( \"\"\n , sexp_of_pair (sexp_of_t sexp_of_opaque) (sexp_of_t sexp_of_opaque) (t1, t2)\n )\n ])\n ;;\nend\n","open! Import\nopen Std_internal\ninclude Univ_map_intf\nmodule Uid = Type_equal.Id.Uid\n\nmodule Make1\n (Key : Key) (Data : sig\n type ('s, 'a) t [@@deriving sexp_of]\n end) =\nstruct\n (* A wrapper for the [Key] module that adds a dynamic check to [Key.to_type_id].\n\n It's a bug if the user-provided [Key.to_type_id] gives different type ids on\n different calls. Because this check should be fairly cheap, we do it dynamically to\n avoid subtler problems later.\n\n Of course, we're not checking truly pathological things like the provided\n [Key.to_type_id] only changes the value it returns on every third call...\n *)\n module Key = struct\n type 'a t = 'a Key.t [@@deriving sexp_of]\n\n (* test-friendly sexp conversion *)\n let sexp_of_type_id type_id =\n [%sexp\n { name = (Type_equal.Id.name type_id : string)\n ; uid =\n ((if am_running_inline_test\n then Sexp.Atom \"\"\n else Type_equal.Id.Uid.sexp_of_t (Type_equal.Id.uid type_id)) : Sexp.t)\n }]\n ;;\n\n let to_type_id key =\n let type_id1 = Key.to_type_id key in\n let type_id2 = Key.to_type_id key in\n if Type_equal.Id.same type_id1 type_id2\n then type_id1\n else\n raise_s\n [%message\n \"[Key.to_type_id] must not provide different type ids when called on the \\\n same input\"\n (key : _ Key.t)\n (type_id1 : type_id)\n (type_id2 : type_id)]\n ;;\n end\n\n type ('s, 'a) data = ('s, 'a) Data.t\n\n let name_of_key key = Type_equal.Id.name (Key.to_type_id key)\n let uid_of_key key = Type_equal.Id.uid (Key.to_type_id key)\n\n module Packed = struct\n type 's t = T : 'a Key.t * ('s, 'a) Data.t -> 's t\n\n let sexp_of_t sexp_of_a (T (key, data)) =\n Data.sexp_of_t sexp_of_a (Type_equal.Id.to_sexp (Key.to_type_id key)) data\n ;;\n\n let type_id_name (T (key, _)) = name_of_key key\n let type_id_uid (T (key, _)) = uid_of_key key\n end\n\n type 's t = 's Packed.t Uid.Map.t\n\n let sexp_of_t sexp_of_a t =\n Map.data t\n |> List.map ~f:(fun u -> Packed.type_id_name u, u)\n |> List.sort ~compare:(fun (a, _) (b, _) -> String.compare a b)\n |> [%sexp_of: (string * a Packed.t) list]\n ;;\n\n let invariant (t : _ t) =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n Map.iteri t ~f:(fun ~key ~data ->\n assert (Uid.equal key (Packed.type_id_uid data))))\n ;;\n\n let set t key data = Map.set t ~key:(uid_of_key key) ~data:(Packed.T (key, data))\n let mem_by_id t id = Map.mem t id\n let mem t key = mem_by_id t (uid_of_key key)\n let remove_by_id t id = Map.remove t id\n let remove t key = remove_by_id t (uid_of_key key)\n let empty = Uid.Map.empty\n let is_empty = Map.is_empty\n\n let find (type b) t (key : b Key.t) =\n match Map.find t (uid_of_key key) with\n | None -> None\n | Some (Packed.T (key', value)) ->\n (* cannot raise -- see [invariant] *)\n let Type_equal.T =\n Type_equal.Id.same_witness_exn (Key.to_type_id key) (Key.to_type_id key')\n in\n Some (value : (_, b) Data.t)\n ;;\n\n let find_exn t key =\n match find t key with\n | Some data -> data\n | None -> failwithf \"Univ_map.find_exn on unknown key %s\" (name_of_key key) ()\n ;;\n\n let add t key data = if mem t key then `Duplicate else `Ok (set t key data)\n\n let add_exn t key data =\n match add t key data with\n | `Ok t -> t\n | `Duplicate -> failwithf \"Univ_map.add_exn on existing key %s\" (name_of_key key) ()\n ;;\n\n let change_exn t key ~f:update =\n match find t key with\n | Some data -> set t key (update data)\n | None -> failwithf \"Univ_map.change_exn on unknown key %s\" (name_of_key key) ()\n ;;\n\n let change t key ~f:update =\n let orig = find t key in\n let next = update orig in\n match next with\n | Some data -> set t key data\n | None -> if Option.is_none orig then t else remove t key\n ;;\n\n let update t key ~f = change t key ~f:(fun data -> Some (f data))\n let to_alist t = Map.data t\n\n let of_alist_exn t =\n Uid.Map.of_alist_exn (List.map t ~f:(fun p -> Packed.type_id_uid p, p))\n ;;\nend\n\nmodule Make\n (Key : Key) (Data : sig\n type 'a t [@@deriving sexp_of]\n end) =\nstruct\n module M =\n Make1\n (Key)\n (struct\n type (_, 'a) t = 'a Data.t [@@deriving sexp_of]\n end)\n\n type t = unit M.t [@@deriving sexp_of]\n\n module Key = Key\n\n type 'a data = 'a Data.t\n\n let invariant = M.invariant\n let empty = M.empty\n let is_empty = M.is_empty\n let set = M.set\n let mem = M.mem\n let mem_by_id = M.mem_by_id\n let find = M.find\n let find_exn = M.find_exn\n let add = M.add\n let add_exn = M.add_exn\n let change = M.change\n let change_exn = M.change_exn\n let update = M.update\n let remove = M.remove\n let remove_by_id = M.remove_by_id\n\n module Packed = struct\n type t = T : 'a Key.t * 'a Data.t -> t\n end\n\n let to_alist t =\n List.map (M.to_alist t) ~f:(function M.Packed.T (key, data) -> Packed.T (key, data))\n ;;\n\n let of_alist_exn t =\n M.of_alist_exn\n (List.map t ~f:(function Packed.T (key, data) -> M.Packed.T (key, data)))\n ;;\nend\n\nmodule Merge\n (Key : Key)\n (Input1_data : Data1)\n (Input2_data : Data1)\n (Output_data : Data1) =\nstruct\n type 's f =\n { f :\n 'a. key:'a Key.t\n -> [ `Left of ('s, 'a) Input1_data.t\n | `Right of ('s, 'a) Input2_data.t\n | `Both of ('s, 'a) Input1_data.t * ('s, 'a) Input2_data.t\n ] -> ('s, 'a) Output_data.t option\n }\n\n module Output = Make1 (Key) (Output_data)\n\n let merge\n (type s)\n (t1 : s Make1(Key)(Input1_data).t)\n (t2 : s Make1(Key)(Input2_data).t)\n ~f:{ f }\n =\n let f ~key merge_result =\n Option.map (f ~key merge_result) ~f:(fun data -> Output.Packed.T (key, data))\n in\n Map.merge t1 t2 ~f:(fun ~key:_ ->\n function\n | `Left (T (key, data)) -> f ~key (`Left data)\n | `Right (T (key, data)) -> f ~key (`Right data)\n | `Both (T (left_key, left_data), T (right_key, right_data)) ->\n (* Can't raise due to the invariant *)\n let Type_equal.T =\n Type_equal.Id.same_witness_exn\n (Key.to_type_id left_key)\n (Key.to_type_id right_key)\n in\n f ~key:left_key (`Both (left_data, right_data)))\n ;;\nend\n\nmodule Type_id_key = struct\n type 'a t = 'a Type_equal.Id.t [@@deriving sexp_of]\n\n let to_type_id = Fn.id\nend\n\ninclude (\n Make\n (Type_id_key)\n (struct\n type 'a t = 'a [@@deriving sexp_of]\n end) :\n S with type 'a data = 'a and module Key := Type_id_key)\n\nmodule Key = Type_equal.Id\n\nmodule With_default = struct\n module Key = struct\n type 'a t =\n { key : 'a Type_equal.Id.t\n ; default : 'a\n }\n\n let create ~default ~name sexp_of =\n { default; key = Type_equal.Id.create ~name sexp_of }\n ;;\n\n let id t = t.key\n end\n\n let find t { Key.key; default } = Option.value ~default (find t key)\n let set t { Key.key; default = _ } v = set t key v\n let change t k ~f:update = set t k (update (find t k))\nend\n\nmodule With_fold = struct\n module Key = struct\n type ('a, 'b) t =\n { key : 'b With_default.Key.t\n ; f : 'b -> 'a -> 'b\n }\n\n let create ~init ~f ~name sexp_of =\n { f; key = With_default.Key.create ~default:init ~name sexp_of }\n ;;\n\n let id t = With_default.Key.id t.key\n end\n\n let find t { Key.key; f = _ } = With_default.find t key\n let set t { Key.key; f = _ } v = With_default.set t key v\n let change t { Key.key; f = _ } ~f:update = With_default.change t key ~f:update\n let add t { Key.key; f } v = With_default.change t key ~f:(fun acc -> f acc v)\nend\n\nmodule Multi = struct\n open With_fold\n\n module Key = struct\n type 'a t = ('a, 'a list) Key.t\n\n let create ~name sexp_of =\n Key.create ~init:[] ~f:(fun xs x -> x :: xs) ~name (List.sexp_of_t sexp_of)\n ;;\n\n let id = With_fold.Key.id\n end\n\n let set = set\n let find = find\n let add = add\n let change = change\nend\n","open! Import\n\n(** ['a Cheap_option.t] is like ['a option], but it doesn't box [some _] values.\n\n There are several things that are unsafe about it:\n\n - [float t array] (or any array-backed container) is not memory-safe\n because float array optimization is incompatible with unboxed option\n optimization. You have to use [Uniform_array.t] instead of [array].\n\n - Nested options (['a t t]) don't work. They are believed to be\n memory-safe, but not parametric.\n\n - A record with [float t]s in it should be safe, but it's only [t] being\n abstract that gives you safety. If the compiler was smart enough to peek\n through the module signature then it could decide to construct a float\n array instead. *)\nmodule Cheap_option = struct\n (* This is taken from core_kernel. Rather than expose it in the public\n interface of base, just keep a copy around here. *)\n let phys_same (type a b) (a : a) (b : b) = phys_equal a (Caml.Obj.magic b : a)\n\n module T0 : sig\n type 'a t\n\n val none : _ t\n val some : 'a -> 'a t\n val is_none : _ t -> bool\n val is_some : _ t -> bool\n val value_exn : 'a t -> 'a\n val value_unsafe : 'a t -> 'a\n end = struct\n type +'a t\n\n (* Being a pointer, no one outside this module can construct a value that is\n [phys_same] as this one.\n\n It would be simpler to use this value as [none], but we use an immediate instead\n because it lets us avoid caml_modify when setting to [none], making certain\n benchmarks significantly faster (e.g. ../bench/array_queue.exe).\n\n this code is duplicated in Moption, and if we find yet another place where we want\n it we should reconsider making it shared. *)\n let none_substitute : _ t = Caml.Obj.obj (Caml.Obj.new_block Caml.Obj.abstract_tag 1)\n\n let none : _ t =\n (* The number was produced by\n [< /dev/urandom tr -c -d '1234567890abcdef' | head -c 16].\n\n The idea is that a random number will have lower probability to collide with\n anything than any number we can choose ourselves.\n\n We are using a polymorphic variant instead of an integer constant because there\n is a compiler bug where it wrongly assumes that the result of [if _ then c else\n y] is not a pointer if [c] is an integer compile-time constant. This is being\n fixed in https://github.com/ocaml/ocaml/pull/555. The \"memory corruption\" test\n below demonstrates the issue. *)\n Caml.Obj.magic `x6e8ee3478e1d7449\n ;;\n\n let is_none x = phys_equal x none\n let is_some x = not (phys_equal x none)\n\n let some (type a) (x : a) : a t =\n if phys_same x none then none_substitute else Caml.Obj.magic x\n ;;\n\n let value_unsafe (type a) (x : a t) : a =\n if phys_equal x none_substitute then Caml.Obj.magic none else Caml.Obj.magic x\n ;;\n\n let value_exn x =\n if is_some x\n then value_unsafe x\n else failwith \"Option_array.get_some_exn: the element is [None]\"\n ;;\n end\n\n module T1 = struct\n include T0\n\n let of_option = function\n | None -> none\n | Some x -> some x\n ;;\n\n let to_option x = if is_some x then Some (value_unsafe x) else None\n let to_sexpable = to_option\n let of_sexpable = of_option\n end\n\n include T1\n include Sexpable.Of_sexpable1 (Option) (T1)\nend\n\ntype 'a t = 'a Cheap_option.t Uniform_array.t [@@deriving_inline sexp]\n\nlet t_of_sexp : 'a. (Ppx_sexp_conv_lib.Sexp.t -> 'a) -> Ppx_sexp_conv_lib.Sexp.t -> 'a t =\n let _tp_loc = \"option_array.ml.t\" in\n fun _of_a t -> Uniform_array.t_of_sexp (Cheap_option.t_of_sexp _of_a) t\n;;\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n fun _of_a v -> Uniform_array.sexp_of_t (Cheap_option.sexp_of_t _of_a) v\n;;\n\n[@@@end]\n\nlet empty = Uniform_array.empty\nlet create ~len = Uniform_array.create ~len Cheap_option.none\nlet init n ~f = Uniform_array.init n ~f:(fun i -> Cheap_option.of_option (f i))\nlet init_some n ~f = Uniform_array.init n ~f:(fun i -> Cheap_option.some (f i))\nlet length = Uniform_array.length\nlet get t i = Cheap_option.to_option (Uniform_array.get t i)\nlet get_some_exn t i = Cheap_option.value_exn (Uniform_array.get t i)\nlet is_none t i = Cheap_option.is_none (Uniform_array.get t i)\nlet is_some t i = Cheap_option.is_some (Uniform_array.get t i)\nlet set t i x = Uniform_array.set t i (Cheap_option.of_option x)\nlet set_some t i x = Uniform_array.set t i (Cheap_option.some x)\nlet set_none t i = Uniform_array.set t i Cheap_option.none\nlet swap t i j = Uniform_array.swap t i j\nlet unsafe_get t i = Cheap_option.to_option (Uniform_array.unsafe_get t i)\nlet unsafe_get_some_exn t i = Cheap_option.value_exn (Uniform_array.unsafe_get t i)\n\nlet unsafe_get_some_assuming_some t i =\n Cheap_option.value_unsafe (Uniform_array.unsafe_get t i)\n;;\n\nlet unsafe_is_some t i = Cheap_option.is_some (Uniform_array.unsafe_get t i)\nlet unsafe_set t i x = Uniform_array.unsafe_set t i (Cheap_option.of_option x)\nlet unsafe_set_some t i x = Uniform_array.unsafe_set t i (Cheap_option.some x)\nlet unsafe_set_none t i = Uniform_array.unsafe_set t i Cheap_option.none\n\nlet clear t =\n for i = 0 to length t - 1 do\n unsafe_set_none t i\n done\n;;\n\ninclude Blit.Make1_generic (struct\n type nonrec 'a t = 'a t\n\n let length = length\n let create_like ~len _ = create ~len\n let unsafe_blit = Uniform_array.unsafe_blit\n end)\n\nlet copy = Uniform_array.copy\n\nmodule For_testing = struct\n module Unsafe_cheap_option = Cheap_option\nend\n","open! Import\ninclude Stack_intf\n\nlet raise_s = Error.raise_s\n\n(* This implementation is similar to [Deque] in that it uses an array of ['a] and\n a mutable [int] to indicate what in the array is used. We choose to implement [Stack]\n directly rather than on top of [Deque] for performance reasons. E.g. a simple\n microbenchmark shows that push/pop is about 20% faster. *)\ntype 'a t =\n { mutable length : int\n ; mutable elts : 'a Option_array.t\n }\n[@@deriving_inline sexp_of]\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n fun _of_a -> function\n | { length = v_length; elts = v_elts } ->\n let bnds = [] in\n let bnds =\n let arg = Option_array.sexp_of_t _of_a v_elts in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"elts\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_length in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"length\"; arg ] :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n;;\n\n[@@@end]\n\nlet sexp_of_t_internal = sexp_of_t\nlet sexp_of_t = `Rebound_later\nlet _ = sexp_of_t\nlet capacity t = Option_array.length t.elts\n\nlet invariant invariant_a ({ length; elts } as t) : unit =\n try\n assert (0 <= length && length <= Option_array.length elts);\n for i = 0 to length - 1 do\n invariant_a (Option_array.get_some_exn elts i)\n done;\n (* We maintain the invariant that unused elements are unset to avoid a space\n leak. *)\n for i = length to Option_array.length elts - 1 do\n assert (not (Option_array.is_some elts i))\n done\n with\n | exn ->\n raise_s\n (Sexp.message\n \"Stack.invariant failed\"\n [ \"exn\", exn |> Exn.sexp_of_t; \"stack\", t |> sexp_of_t_internal sexp_of_opaque ])\n;;\n\nlet create (type a) () : a t = { length = 0; elts = Option_array.empty }\nlet length t = t.length\nlet is_empty t = length t = 0\n\n(* The order in which elements are visited has been chosen so as to be backwards\n compatible with both [Linked_stack] and [Caml.Stack] *)\nlet fold t ~init ~f =\n let r = ref init in\n for i = t.length - 1 downto 0 do\n r := f !r (Option_array.get_some_exn t.elts i)\n done;\n !r\n;;\n\nlet iter t ~f =\n for i = t.length - 1 downto 0 do\n f (Option_array.get_some_exn t.elts i)\n done\n;;\n\nmodule C = Container.Make (struct\n type nonrec 'a t = 'a t\n\n let fold = fold\n let iter = `Custom iter\n let length = `Custom length\n end)\n\nlet mem = C.mem\nlet exists = C.exists\nlet for_all = C.for_all\nlet count = C.count\nlet sum = C.sum\nlet find = C.find\nlet find_map = C.find_map\nlet to_list = C.to_list\nlet to_array = C.to_array\nlet min_elt = C.min_elt\nlet max_elt = C.max_elt\nlet fold_result = C.fold_result\nlet fold_until = C.fold_until\n\nlet of_list (type a) (l : a list) =\n if List.is_empty l\n then create ()\n else (\n let length = List.length l in\n let elts = Option_array.create ~len:(2 * length) in\n let r = ref l in\n for i = length - 1 downto 0 do\n match !r with\n | [] -> assert false\n | a :: l ->\n Option_array.set_some elts i a;\n r := l\n done;\n { length; elts })\n;;\n\nlet sexp_of_t sexp_of_a t = List.sexp_of_t sexp_of_a (to_list t)\nlet t_of_sexp a_of_sexp sexp = of_list (List.t_of_sexp a_of_sexp sexp)\n\nlet resize t size =\n let arr = Option_array.create ~len:size in\n Option_array.blit ~src:t.elts ~dst:arr ~src_pos:0 ~dst_pos:0 ~len:t.length;\n t.elts <- arr\n;;\n\nlet set_capacity t new_capacity =\n let new_capacity = max new_capacity (length t) in\n if new_capacity <> capacity t then resize t new_capacity\n;;\n\nlet push t a =\n if t.length = Option_array.length t.elts then resize t (2 * (t.length + 1));\n Option_array.set_some t.elts t.length a;\n t.length <- t.length + 1\n;;\n\nlet pop_nonempty t =\n let i = t.length - 1 in\n let result = Option_array.get_some_exn t.elts i in\n Option_array.set_none t.elts i;\n t.length <- i;\n result\n;;\n\nlet pop_error = Error.of_string \"Stack.pop of empty stack\"\nlet pop t = if is_empty t then None else Some (pop_nonempty t)\nlet pop_exn t = if is_empty t then Error.raise pop_error else pop_nonempty t\nlet top_nonempty t = Option_array.get_some_exn t.elts (t.length - 1)\nlet top_error = Error.of_string \"Stack.top of empty stack\"\nlet top t = if is_empty t then None else Some (top_nonempty t)\nlet top_exn t = if is_empty t then Error.raise top_error else top_nonempty t\nlet copy { length; elts } = { length; elts = Option_array.copy elts }\n\nlet clear t =\n if t.length > 0\n then (\n for i = 0 to t.length - 1 do\n Option_array.set_none t.elts i\n done;\n t.length <- 0)\n;;\n\nlet until_empty t f =\n let rec loop () =\n if t.length > 0\n then (\n f (pop_nonempty t);\n loop ())\n in\n loop ()\n;;\n\nlet singleton x =\n let t = create () in\n push t x;\n t\n;;\n","(***********************************************************************)\n(* *)\n(* Objective Caml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. All rights reserved. This file is distributed *)\n(* under the terms of the Apache 2.0 license. See ../THIRD-PARTY.txt *)\n(* for details. *)\n(* *)\n(***********************************************************************)\n\n(* Sets over ordered types *)\n\nopen! Import\ninclude Set_intf\n\nlet with_return = With_return.with_return\n\n\nmodule Tree0 = struct\n type 'a t =\n | Empty\n (* (Leaf x) is the same as (Node (Empty, x, Empty, 1, 1)) but uses less space. *)\n | Leaf of 'a\n (* first int is height, second is sub-tree size *)\n | Node of 'a t * 'a * 'a t * int * int\n\n type 'a tree = 'a t\n\n (* Sets are represented by balanced binary trees (the heights of the children differ by\n at most 2. *)\n let height = function\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, h, _) -> h\n ;;\n\n let length = function\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, s) -> s\n ;;\n\n let invariants =\n let in_range lower upper compare_elt v =\n (match lower with\n | None -> true\n | Some lower -> compare_elt lower v < 0)\n &&\n match upper with\n | None -> true\n | Some upper -> compare_elt v upper < 0\n in\n let rec loop lower upper compare_elt t =\n match t with\n | Empty -> true\n | Leaf v -> in_range lower upper compare_elt v\n | Node (l, v, r, h, n) ->\n let hl = height l\n and hr = height r in\n abs (hl - hr) <= 2\n && h = max hl hr + 1\n && n = length l + length r + 1\n && in_range lower upper compare_elt v\n && loop lower (Some v) compare_elt l\n && loop (Some v) upper compare_elt r\n in\n fun t ~compare_elt -> loop None None compare_elt t\n ;;\n\n let is_empty = function\n | Empty -> true\n | Leaf _ | Node _ -> false\n ;;\n\n (* Creates a new node with left son l, value v and right son r.\n We must have all elements of l < v < all elements of r.\n l and r must be balanced and | height l - height r | <= 2.\n Inline expansion of height for better speed. *)\n\n let create l v r =\n let hl =\n match l with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, h, _) -> h\n in\n let hr =\n match r with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, h, _) -> h\n in\n let h = if hl >= hr then hl + 1 else hr + 1 in\n if h = 1\n then Leaf v\n else (\n let sl =\n match l with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, s) -> s\n in\n let sr =\n match r with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, s) -> s\n in\n Node (l, v, r, h, sl + sr + 1))\n ;;\n\n (* We must call [f] with increasing indexes, because the bin_prot reader in\n Core_kernel.Set needs it. *)\n let of_increasing_iterator_unchecked ~len ~f =\n let rec loop n ~f i =\n match n with\n | 0 -> Empty\n | 1 ->\n let k = f i in\n Leaf k\n | 2 ->\n let kl = f i in\n let k = f (i + 1) in\n create (Leaf kl) k Empty\n | 3 ->\n let kl = f i in\n let k = f (i + 1) in\n let kr = f (i + 2) in\n create (Leaf kl) k (Leaf kr)\n | n ->\n let left_length = n lsr 1 in\n let right_length = n - left_length - 1 in\n let left = loop left_length ~f i in\n let k = f (i + left_length) in\n let right = loop right_length ~f (i + left_length + 1) in\n create left k right\n in\n loop len ~f 0\n ;;\n\n let of_sorted_array_unchecked array ~compare_elt =\n let array_length = Array.length array in\n let next =\n (* We don't check if the array is sorted or keys are duplicated, because that\n checking is slower than the whole [of_sorted_array] function *)\n if array_length < 2 || compare_elt array.(0) array.(1) < 0\n then fun i -> array.(i)\n else fun i -> array.(array_length - 1 - i)\n in\n of_increasing_iterator_unchecked ~len:array_length ~f:next\n ;;\n\n let of_sorted_array array ~compare_elt =\n match array with\n | [||] | [| _ |] -> Result.Ok (of_sorted_array_unchecked array ~compare_elt)\n | _ ->\n with_return (fun r ->\n let increasing =\n match compare_elt array.(0) array.(1) with\n | 0 ->\n r.return (Or_error.error_string \"of_sorted_array: duplicated elements\")\n | i -> i < 0\n in\n for i = 1 to Array.length array - 2 do\n match compare_elt array.(i) array.(i + 1) with\n | 0 ->\n r.return (Or_error.error_string \"of_sorted_array: duplicated elements\")\n | i ->\n if Poly.( <> ) (i < 0) increasing\n then\n r.return\n (Or_error.error_string \"of_sorted_array: elements are not ordered\")\n done;\n Result.Ok (of_sorted_array_unchecked array ~compare_elt))\n ;;\n\n (* Same as create, but performs one step of rebalancing if necessary.\n Assumes l and r balanced and | height l - height r | <= 3.\n Inline expansion of create for better speed in the most frequent case\n where no rebalancing is required. *)\n\n let bal l v r =\n let hl =\n match l with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, h, _) -> h\n in\n let hr =\n match r with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, h, _) -> h\n in\n if hl > hr + 2\n then (\n match l with\n | Empty -> assert false\n | Leaf _ -> assert false (* because h(l)>h(r)+2 and h(leaf)=1 *)\n | Node (ll, lv, lr, _, _) ->\n if height ll >= height lr\n then create ll lv (create lr v r)\n else (\n match lr with\n | Empty -> assert false\n | Leaf lrv ->\n assert (is_empty ll);\n create (create ll lv Empty) lrv (create Empty v r)\n | Node (lrl, lrv, lrr, _, _) -> create (create ll lv lrl) lrv (create lrr v r)))\n else if hr > hl + 2\n then (\n match r with\n | Empty -> assert false\n | Leaf rv -> create (create l v Empty) rv Empty\n | Node (rl, rv, rr, _, _) ->\n if height rr >= height rl\n then create (create l v rl) rv rr\n else (\n match rl with\n | Empty -> assert false\n | Leaf rlv ->\n assert (is_empty rr);\n create (create l v Empty) rlv (create Empty rv rr)\n | Node (rll, rlv, rlr, _, _) -> create (create l v rll) rlv (create rlr rv rr)))\n else (\n let h = if hl >= hr then hl + 1 else hr + 1 in\n let sl =\n match l with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, s) -> s\n in\n let sr =\n match r with\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, s) -> s\n in\n if h = 1 then Leaf v else Node (l, v, r, h, sl + sr + 1))\n ;;\n\n (* Insertion of one element *)\n\n exception Same\n\n let add t x ~compare_elt =\n let rec aux = function\n | Empty -> Leaf x\n | Leaf v ->\n let c = compare_elt x v in\n if c = 0\n then raise Same\n else if c < 0\n then bal (Leaf x) v Empty\n else bal Empty v (Leaf x)\n | Node (l, v, r, _, _) ->\n let c = compare_elt x v in\n if c = 0 then raise Same else if c < 0 then bal (aux l) v r else bal l v (aux r)\n in\n try aux t with\n | Same -> t\n ;;\n\n (* Same as create and bal, but no assumptions are made on the relative heights of l and\n r. *)\n let rec join l v r ~compare_elt =\n match l, r with\n | Empty, _ -> add r v ~compare_elt\n | _, Empty -> add l v ~compare_elt\n | Leaf lv, _ -> add (add r v ~compare_elt) lv ~compare_elt\n | _, Leaf rv -> add (add l v ~compare_elt) rv ~compare_elt\n | Node (ll, lv, lr, lh, _), Node (rl, rv, rr, rh, _) ->\n if lh > rh + 2\n then bal ll lv (join lr v r ~compare_elt)\n else if rh > lh + 2\n then bal (join l v rl ~compare_elt) rv rr\n else create l v r\n ;;\n\n (* Smallest and greatest element of a set *)\n let rec min_elt = function\n | Empty -> None\n | Leaf v | Node (Empty, v, _, _, _) -> Some v\n | Node (l, _, _, _, _) -> min_elt l\n ;;\n\n exception Set_min_elt_exn_of_empty_set [@@deriving_inline sexp]\n\n let () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Set_min_elt_exn_of_empty_set]\n (function\n | Set_min_elt_exn_of_empty_set ->\n Ppx_sexp_conv_lib.Sexp.Atom \"set.ml.Tree0.Set_min_elt_exn_of_empty_set\"\n | _ -> assert false)\n ;;\n\n [@@@end]\n\n exception Set_max_elt_exn_of_empty_set [@@deriving_inline sexp]\n\n let () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Set_max_elt_exn_of_empty_set]\n (function\n | Set_max_elt_exn_of_empty_set ->\n Ppx_sexp_conv_lib.Sexp.Atom \"set.ml.Tree0.Set_max_elt_exn_of_empty_set\"\n | _ -> assert false)\n ;;\n\n [@@@end]\n\n let min_elt_exn t =\n match min_elt t with\n | None -> raise Set_min_elt_exn_of_empty_set\n | Some v -> v\n ;;\n\n let fold_until t ~init ~f ~finish =\n let rec fold_until_helper ~f t acc =\n match t with\n | Empty -> Continue_or_stop.Continue acc\n | Leaf value -> f acc value\n | Node (left, value, right, _, _) ->\n (match fold_until_helper ~f left acc with\n | Stop _a as x -> x\n | Continue acc ->\n (match f acc value with\n | Stop _a as x -> x\n | Continue a -> fold_until_helper ~f right a))\n in\n match fold_until_helper ~f t init with\n | Continue x -> finish x\n | Stop x -> x\n ;;\n\n let rec max_elt = function\n | Empty -> None\n | Leaf v | Node (_, v, Empty, _, _) -> Some v\n | Node (_, _, r, _, _) -> max_elt r\n ;;\n\n let max_elt_exn t =\n match max_elt t with\n | None -> raise Set_max_elt_exn_of_empty_set\n | Some v -> v\n ;;\n\n (* Remove the smallest element of the given set *)\n\n let rec remove_min_elt = function\n | Empty -> invalid_arg \"Set.remove_min_elt\"\n | Leaf _ -> Empty\n | Node (Empty, _, r, _, _) -> r\n | Node (l, v, r, _, _) -> bal (remove_min_elt l) v r\n ;;\n\n (* Merge two trees l and r into one. All elements of l must precede the elements of r.\n Assume | height l - height r | <= 2. *)\n let merge t1 t2 =\n match t1, t2 with\n | Empty, t -> t\n | t, Empty -> t\n | _, _ -> bal t1 (min_elt_exn t2) (remove_min_elt t2)\n ;;\n\n (* Merge two trees l and r into one. All elements of l must precede the elements of r.\n No assumption on the heights of l and r. *)\n let concat t1 t2 ~compare_elt =\n match t1, t2 with\n | Empty, t | t, Empty -> t\n | _, _ -> join t1 (min_elt_exn t2) (remove_min_elt t2) ~compare_elt\n ;;\n\n let split t x ~compare_elt =\n let rec split t =\n match t with\n | Empty -> Empty, None, Empty\n | Leaf v ->\n let c = compare_elt x v in\n if c = 0\n then Empty, Some v, Empty\n else if c < 0\n then Empty, None, Leaf v\n else Leaf v, None, Empty\n | Node (l, v, r, _, _) ->\n let c = compare_elt x v in\n if c = 0\n then l, Some v, r\n else if c < 0\n then (\n let ll, maybe_elt, rl = split l in\n ll, maybe_elt, join rl v r ~compare_elt)\n else (\n let lr, maybe_elt, rr = split r in\n join l v lr ~compare_elt, maybe_elt, rr)\n in\n split t\n ;;\n\n (* Implementation of the set operations *)\n\n let empty = Empty\n\n let rec mem t x ~compare_elt =\n match t with\n | Empty -> false\n | Leaf v ->\n let c = compare_elt x v in\n c = 0\n | Node (l, v, r, _, _) ->\n let c = compare_elt x v in\n c = 0 || mem (if c < 0 then l else r) x ~compare_elt\n ;;\n\n let singleton x = Leaf x\n\n let remove t x ~compare_elt =\n let rec aux t =\n match t with\n | Empty -> raise Same\n | Leaf v -> if compare_elt x v = 0 then Empty else raise Same\n | Node (l, v, r, _, _) ->\n let c = compare_elt x v in\n if c = 0 then merge l r else if c < 0 then bal (aux l) v r else bal l v (aux r)\n in\n try aux t with\n | Same -> t\n ;;\n\n let remove_index t i ~compare_elt:_ =\n let rec aux t i =\n match t with\n | Empty -> raise Same\n | Leaf _ -> if i = 0 then Empty else raise Same\n | Node (l, v, r, _, _) ->\n let l_size = length l in\n let c = Poly.compare i l_size in\n if c = 0\n then merge l r\n else if c < 0\n then bal (aux l i) v r\n else bal l v (aux r (i - l_size - 1))\n in\n try aux t i with\n | Same -> t\n ;;\n\n let union s1 s2 ~compare_elt =\n let rec union s1 s2 =\n if phys_equal s1 s2\n then s1\n else (\n match s1, s2 with\n | Empty, t | t, Empty -> t\n | Leaf v1, _ -> union (Node (Empty, v1, Empty, 1, 1)) s2\n | _, Leaf v2 -> union s1 (Node (Empty, v2, Empty, 1, 1))\n | Node (l1, v1, r1, h1, _), Node (l2, v2, r2, h2, _) ->\n if h1 >= h2\n then\n if h2 = 1\n then add s1 v2 ~compare_elt\n else (\n let l2, _, r2 = split s2 v1 ~compare_elt in\n join (union l1 l2) v1 (union r1 r2) ~compare_elt)\n else if h1 = 1\n then add s2 v1 ~compare_elt\n else (\n let l1, _, r1 = split s1 v2 ~compare_elt in\n join (union l1 l2) v2 (union r1 r2) ~compare_elt))\n in\n union s1 s2\n ;;\n\n let union_list ~comparator ~to_tree xs =\n let compare_elt = comparator.Comparator.compare in\n List.fold xs ~init:empty ~f:(fun ac x -> union ac (to_tree x) ~compare_elt)\n ;;\n\n let inter s1 s2 ~compare_elt =\n let rec inter s1 s2 =\n if phys_equal s1 s2\n then s1\n else (\n match s1, s2 with\n | Empty, _ | _, Empty -> Empty\n | (Leaf elt as singleton), other_set | other_set, (Leaf elt as singleton) ->\n if mem other_set elt ~compare_elt then singleton else Empty\n | Node (l1, v1, r1, _, _), t2 ->\n (match split t2 v1 ~compare_elt with\n | l2, None, r2 -> concat (inter l1 l2) (inter r1 r2) ~compare_elt\n | l2, Some v1, r2 -> join (inter l1 l2) v1 (inter r1 r2) ~compare_elt))\n in\n inter s1 s2\n ;;\n\n let diff s1 s2 ~compare_elt =\n let rec diff s1 s2 =\n if phys_equal s1 s2\n then Empty\n else (\n match s1, s2 with\n | Empty, _ -> Empty\n | t1, Empty -> t1\n | Leaf v1, t2 -> diff (Node (Empty, v1, Empty, 1, 1)) t2\n | Node (l1, v1, r1, _, _), t2 ->\n (match split t2 v1 ~compare_elt with\n | l2, None, r2 -> join (diff l1 l2) v1 (diff r1 r2) ~compare_elt\n | l2, Some _, r2 -> concat (diff l1 l2) (diff r1 r2) ~compare_elt))\n in\n diff s1 s2\n ;;\n\n module Enum = struct\n type increasing\n type decreasing\n\n type ('a, 'direction) t =\n | End\n | More of 'a * 'a tree * ('a, 'direction) t\n\n let rec cons s (e : (_, increasing) t) : (_, increasing) t =\n match s with\n | Empty -> e\n | Leaf v -> More (v, Empty, e)\n | Node (l, v, r, _, _) -> cons l (More (v, r, e))\n ;;\n\n let rec cons_right s (e : (_, decreasing) t) : (_, decreasing) t =\n match s with\n | Empty -> e\n | Leaf v -> More (v, Empty, e)\n | Node (l, v, r, _, _) -> cons_right r (More (v, l, e))\n ;;\n\n let of_set s : (_, increasing) t = cons s End\n let of_set_right s : (_, decreasing) t = cons_right s End\n\n let starting_at_increasing t key compare : (_, increasing) t =\n let rec loop t e =\n match t with\n | Empty -> e\n | Leaf v -> loop (Node (Empty, v, Empty, 1, 1)) e\n | Node (_, v, r, _, _) when compare v key < 0 -> loop r e\n | Node (l, v, r, _, _) -> loop l (More (v, r, e))\n in\n loop t End\n ;;\n\n let starting_at_decreasing t key compare : (_, decreasing) t =\n let rec loop t e =\n match t with\n | Empty -> e\n | Leaf v -> loop (Node (Empty, v, Empty, 1, 1)) e\n | Node (l, v, _, _, _) when compare v key > 0 -> loop l e\n | Node (l, v, r, _, _) -> loop r (More (v, l, e))\n in\n loop t End\n ;;\n\n let compare compare_elt e1 e2 =\n let rec loop e1 e2 =\n match e1, e2 with\n | End, End -> 0\n | End, _ -> -1\n | _, End -> 1\n | More (v1, r1, e1), More (v2, r2, e2) ->\n let c = compare_elt v1 v2 in\n if c <> 0\n then c\n else if phys_equal r1 r2\n then loop e1 e2\n else loop (cons r1 e1) (cons r2 e2)\n in\n loop e1 e2\n ;;\n\n let rec iter ~f = function\n | End -> ()\n | More (a, tree, enum) ->\n f a;\n iter (cons tree enum) ~f\n ;;\n\n let iter2 compare_elt t1 t2 ~f =\n let rec loop t1 t2 =\n match t1, t2 with\n | End, End -> ()\n | End, _ -> iter t2 ~f:(fun a -> f (`Right a))\n | _, End -> iter t1 ~f:(fun a -> f (`Left a))\n | More (a1, tree1, enum1), More (a2, tree2, enum2) ->\n let compare_result = compare_elt a1 a2 in\n if compare_result = 0\n then (\n f (`Both (a1, a2));\n loop (cons tree1 enum1) (cons tree2 enum2))\n else if compare_result < 0\n then (\n f (`Left a1);\n loop (cons tree1 enum1) t2)\n else (\n f (`Right a2);\n loop t1 (cons tree2 enum2))\n in\n loop t1 t2\n ;;\n\n let symmetric_diff t1 t2 ~compare_elt =\n let step state : ((_, _) Either.t, _) Sequence.Step.t =\n match state with\n | End, End -> Done\n | End, More (elt, tree, enum) -> Yield (Second elt, (End, cons tree enum))\n | More (elt, tree, enum), End -> Yield (First elt, (cons tree enum, End))\n | (More (a1, tree1, enum1) as left), (More (a2, tree2, enum2) as right) ->\n let compare_result = compare_elt a1 a2 in\n if compare_result = 0\n then (\n let next_state =\n if phys_equal tree1 tree2\n then enum1, enum2\n else cons tree1 enum1, cons tree2 enum2\n in\n Skip next_state)\n else if compare_result < 0\n then Yield (First a1, (cons tree1 enum1, right))\n else Yield (Second a2, (left, cons tree2 enum2))\n in\n Sequence.unfold_step ~init:(of_set t1, of_set t2) ~f:step\n ;;\n end\n\n let to_sequence_increasing comparator ~from_elt t =\n let next enum =\n match enum with\n | Enum.End -> Sequence.Step.Done\n | Enum.More (k, t, e) -> Sequence.Step.Yield (k, Enum.cons t e)\n in\n let init =\n match from_elt with\n | None -> Enum.of_set t\n | Some key -> Enum.starting_at_increasing t key comparator.Comparator.compare\n in\n Sequence.unfold_step ~init ~f:next\n ;;\n\n let to_sequence_decreasing comparator ~from_elt t =\n let next enum =\n match enum with\n | Enum.End -> Sequence.Step.Done\n | Enum.More (k, t, e) -> Sequence.Step.Yield (k, Enum.cons_right t e)\n in\n let init =\n match from_elt with\n | None -> Enum.of_set_right t\n | Some key -> Enum.starting_at_decreasing t key comparator.Comparator.compare\n in\n Sequence.unfold_step ~init ~f:next\n ;;\n\n let to_sequence\n comparator\n ?(order = `Increasing)\n ?greater_or_equal_to\n ?less_or_equal_to\n t\n =\n let inclusive_bound side t bound =\n let compare_elt = comparator.Comparator.compare in\n let l, maybe, r = split t bound ~compare_elt in\n let t = side (l, r) in\n match maybe with\n | None -> t\n | Some elt -> add t elt ~compare_elt\n in\n match order with\n | `Increasing ->\n let t = Option.fold less_or_equal_to ~init:t ~f:(inclusive_bound fst) in\n to_sequence_increasing comparator ~from_elt:greater_or_equal_to t\n | `Decreasing ->\n let t = Option.fold greater_or_equal_to ~init:t ~f:(inclusive_bound snd) in\n to_sequence_decreasing comparator ~from_elt:less_or_equal_to t\n ;;\n\n\n let rec find_first_satisfying t ~f =\n match t with\n | Empty -> None\n | Leaf v -> if f v then Some v else None\n | Node (l, v, r, _, _) ->\n if f v\n then (\n match find_first_satisfying l ~f with\n | None -> Some v\n | Some _ as x -> x)\n else find_first_satisfying r ~f\n ;;\n\n let rec find_last_satisfying t ~f =\n match t with\n | Empty -> None\n | Leaf v -> if f v then Some v else None\n | Node (l, v, r, _, _) ->\n if f v\n then (\n match find_last_satisfying r ~f with\n | None -> Some v\n | Some _ as x -> x)\n else find_last_satisfying l ~f\n ;;\n\n let binary_search t ~compare how v =\n match how with\n | `Last_strictly_less_than -> find_last_satisfying t ~f:(fun x -> compare x v < 0)\n | `Last_less_than_or_equal_to ->\n find_last_satisfying t ~f:(fun x -> compare x v <= 0)\n | `First_equal_to ->\n (match find_first_satisfying t ~f:(fun x -> compare x v >= 0) with\n | Some x as elt when compare x v = 0 -> elt\n | None | Some _ -> None)\n | `Last_equal_to ->\n (match find_last_satisfying t ~f:(fun x -> compare x v <= 0) with\n | Some x as elt when compare x v = 0 -> elt\n | None | Some _ -> None)\n | `First_greater_than_or_equal_to ->\n find_first_satisfying t ~f:(fun x -> compare x v >= 0)\n | `First_strictly_greater_than ->\n find_first_satisfying t ~f:(fun x -> compare x v > 0)\n ;;\n\n let binary_search_segmented t ~segment_of how =\n let is_left x =\n match segment_of x with\n | `Left -> true\n | `Right -> false\n in\n let is_right x = not (is_left x) in\n match how with\n | `Last_on_left -> find_last_satisfying t ~f:is_left\n | `First_on_right -> find_first_satisfying t ~f:is_right\n ;;\n\n let merge_to_sequence\n comparator\n ?(order = `Increasing)\n ?greater_or_equal_to\n ?less_or_equal_to\n t\n t'\n =\n Sequence.merge_with_duplicates\n (to_sequence comparator ~order ?greater_or_equal_to ?less_or_equal_to t)\n (to_sequence comparator ~order ?greater_or_equal_to ?less_or_equal_to t')\n ~compare:\n (match order with\n | `Increasing -> comparator.compare\n | `Decreasing -> Fn.flip comparator.compare)\n ;;\n\n let compare compare_elt s1 s2 =\n Enum.compare compare_elt (Enum.of_set s1) (Enum.of_set s2)\n ;;\n\n let iter2 s1 s2 ~compare_elt = Enum.iter2 compare_elt (Enum.of_set s1) (Enum.of_set s2)\n let equal s1 s2 ~compare_elt = compare compare_elt s1 s2 = 0\n\n let is_subset s1 ~of_:s2 ~compare_elt =\n let rec is_subset s1 ~of_:s2 =\n match s1, s2 with\n | Empty, _ -> true\n | _, Empty -> false\n | Leaf v1, t2 -> mem t2 v1 ~compare_elt\n | Node (l1, v1, r1, _, _), Leaf v2 ->\n (match l1, r1 with\n | Empty, Empty ->\n (* This case shouldn't occur in practice because we should have constructed\n a Leaf rather than a Node with two Empty subtrees *)\n compare_elt v1 v2 = 0\n | _, _ -> false)\n | Node (l1, v1, r1, _, _), (Node (l2, v2, r2, _, _) as t2) ->\n let c = compare_elt v1 v2 in\n if c = 0\n then\n phys_equal s1 s2 || (is_subset l1 ~of_:l2 && is_subset r1 ~of_:r2)\n (* Note that height and size don't matter here. *)\n else if c < 0\n then is_subset (Node (l1, v1, Empty, 0, 0)) ~of_:l2 && is_subset r1 ~of_:t2\n else is_subset (Node (Empty, v1, r1, 0, 0)) ~of_:r2 && is_subset l1 ~of_:t2\n in\n is_subset s1 ~of_:s2\n ;;\n\n let rec are_disjoint s1 s2 ~compare_elt =\n match s1, s2 with\n | Empty, _ | _, Empty -> true\n | Leaf elt, other_set | other_set, Leaf elt -> not (mem other_set elt ~compare_elt)\n | Node (l1, v1, r1, _, _), t2 ->\n if phys_equal s1 s2\n then false\n else (\n match split t2 v1 ~compare_elt with\n | l2, None, r2 ->\n are_disjoint l1 l2 ~compare_elt && are_disjoint r1 r2 ~compare_elt\n | _, Some _, _ -> false)\n ;;\n\n let iter t ~f =\n let rec iter = function\n | Empty -> ()\n | Leaf v -> f v\n | Node (l, v, r, _, _) ->\n iter l;\n f v;\n iter r\n in\n iter t\n ;;\n\n let symmetric_diff = Enum.symmetric_diff\n\n let rec fold s ~init:accu ~f =\n match s with\n | Empty -> accu\n | Leaf v -> f accu v\n | Node (l, v, r, _, _) -> fold ~f r ~init:(f (fold ~f l ~init:accu) v)\n ;;\n\n let hash_fold_t_ignoring_structure hash_fold_elem state t =\n fold t ~init:(hash_fold_int state (length t)) ~f:hash_fold_elem\n ;;\n\n let count t ~f = Container.count ~fold t ~f\n let sum m t ~f = Container.sum ~fold m t ~f\n\n let rec fold_right s ~init:accu ~f =\n match s with\n | Empty -> accu\n | Leaf v -> f v accu\n | Node (l, v, r, _, _) -> fold_right ~f l ~init:(f v (fold_right ~f r ~init:accu))\n ;;\n\n let rec for_all t ~f:p =\n match t with\n | Empty -> true\n | Leaf v -> p v\n | Node (l, v, r, _, _) -> p v && for_all ~f:p l && for_all ~f:p r\n ;;\n\n let rec exists t ~f:p =\n match t with\n | Empty -> false\n | Leaf v -> p v\n | Node (l, v, r, _, _) -> p v || exists ~f:p l || exists ~f:p r\n ;;\n\n let filter s ~f:p ~compare_elt =\n let rec filt accu = function\n | Empty -> accu\n | Leaf v -> if p v then add accu v ~compare_elt else accu\n | Node (l, v, r, _, _) ->\n filt (filt (if p v then add accu v ~compare_elt else accu) l) r\n in\n filt Empty s\n ;;\n\n let filter_map s ~f:p ~compare_elt =\n let rec filt accu = function\n | Empty -> accu\n | Leaf v ->\n (match p v with\n | None -> accu\n | Some v -> add accu v ~compare_elt)\n | Node (l, v, r, _, _) ->\n filt\n (filt\n (match p v with\n | None -> accu\n | Some v -> add accu v ~compare_elt)\n l)\n r\n in\n filt Empty s\n ;;\n\n let partition_tf s ~f:p ~compare_elt =\n let rec part ((t, f) as accu) = function\n | Empty -> accu\n | Leaf v -> if p v then add t v ~compare_elt, f else t, add f v ~compare_elt\n | Node (l, v, r, _, _) ->\n part\n (part (if p v then add t v ~compare_elt, f else t, add f v ~compare_elt) l)\n r\n in\n part (Empty, Empty) s\n ;;\n\n let rec elements_aux accu = function\n | Empty -> accu\n | Leaf v -> v :: accu\n | Node (l, v, r, _, _) -> elements_aux (v :: elements_aux accu r) l\n ;;\n\n let elements s = elements_aux [] s\n\n let choose t =\n match t with\n | Empty -> None\n | Leaf v -> Some v\n | Node (_, v, _, _, _) -> Some v\n ;;\n\n let choose_exn =\n let not_found = Not_found_s (Atom \"Set.choose_exn: empty set\") in\n let choose_exn t =\n match choose t with\n | None -> raise not_found\n | Some v -> v\n in\n (* named to preserve symbol in compiled binary *)\n choose_exn\n ;;\n\n let of_list lst ~compare_elt =\n List.fold lst ~init:empty ~f:(fun t x -> add t x ~compare_elt)\n ;;\n\n let to_list s = elements s\n\n let of_array a ~compare_elt =\n Array.fold a ~init:empty ~f:(fun t x -> add t x ~compare_elt)\n ;;\n\n (* faster but equivalent to [Array.of_list (to_list t)] *)\n let to_array = function\n | Empty -> [||]\n | Leaf v -> [| v |]\n | Node (l, v, r, _, s) ->\n let res = Array.create ~len:s v in\n let pos_ref = ref 0 in\n let rec loop = function\n (* Invariant: on entry and on exit to [loop], !pos_ref is the next\n available cell in the array. *)\n | Empty -> ()\n | Leaf v ->\n res.(!pos_ref) <- v;\n incr pos_ref\n | Node (l, v, r, _, _) ->\n loop l;\n res.(!pos_ref) <- v;\n incr pos_ref;\n loop r\n in\n loop l;\n (* res.(!pos_ref) is already initialized (by Array.create ~len:above). *)\n incr pos_ref;\n loop r;\n res\n ;;\n\n let map t ~f ~compare_elt = fold t ~init:empty ~f:(fun t x -> add t (f x) ~compare_elt)\n\n let group_by set ~equiv ~compare_elt =\n let rec loop set equiv_classes =\n if is_empty set\n then equiv_classes\n else (\n let x = choose_exn set in\n let equiv_x, not_equiv_x =\n partition_tf set ~f:(fun elt -> phys_equal x elt || equiv x elt) ~compare_elt\n in\n loop not_equiv_x (equiv_x :: equiv_classes))\n in\n loop set []\n ;;\n\n let rec find t ~f =\n match t with\n | Empty -> None\n | Leaf v -> if f v then Some v else None\n | Node (l, v, r, _, _) ->\n if f v\n then Some v\n else (\n match find l ~f with\n | None -> find r ~f\n | Some _ as r -> r)\n ;;\n\n let rec find_map t ~f =\n match t with\n | Empty -> None\n | Leaf v -> f v\n | Node (l, v, r, _, _) ->\n (match f v with\n | Some _ as r -> r\n | None ->\n (match find_map l ~f with\n | None -> find_map r ~f\n | Some _ as r -> r))\n ;;\n\n let find_exn t ~f =\n match find t ~f with\n | None -> failwith \"Set.find_exn failed to find a matching element\"\n | Some e -> e\n ;;\n\n let rec nth t i =\n match t with\n | Empty -> None\n | Leaf v -> if i = 0 then Some v else None\n | Node (l, v, r, _, s) ->\n if i >= s\n then None\n else (\n let l_size = length l in\n let c = Poly.compare i l_size in\n if c < 0 then nth l i else if c = 0 then Some v else nth r (i - l_size - 1))\n ;;\n\n let stable_dedup_list xs ~compare_elt =\n let rec loop xs leftovers already_seen =\n match xs with\n | [] -> List.rev leftovers\n | hd :: tl ->\n if mem already_seen hd ~compare_elt\n then loop tl leftovers already_seen\n else loop tl (hd :: leftovers) (add already_seen hd ~compare_elt)\n in\n loop xs [] empty\n ;;\n\n let t_of_sexp_direct a_of_sexp sexp ~compare_elt =\n match sexp with\n | Sexp.List lst ->\n let elt_lst = List.map lst ~f:a_of_sexp in\n let set = of_list elt_lst ~compare_elt in\n if length set = List.length lst\n then set\n else (\n let set = ref empty in\n List.iter2_exn lst elt_lst ~f:(fun el_sexp el ->\n if mem !set el ~compare_elt\n then of_sexp_error \"Set.t_of_sexp: duplicate element in set\" el_sexp\n else set := add !set el ~compare_elt);\n assert false)\n | sexp -> of_sexp_error \"Set.t_of_sexp: list needed\" sexp\n ;;\n\n let sexp_of_t sexp_of_a t =\n Sexp.List (fold_right t ~init:[] ~f:(fun el acc -> sexp_of_a el :: acc))\n ;;\n\n module Named = struct\n type nonrec ('a, 'cmp) t =\n { tree : 'a t\n ; name : string\n }\n\n let is_subset (subset : _ t) ~of_:(superset : _ t) ~sexp_of_elt ~compare_elt =\n let invalid_elements = diff subset.tree superset.tree ~compare_elt in\n if is_empty invalid_elements\n then Ok ()\n else (\n let invalid_elements_sexp = sexp_of_t sexp_of_elt invalid_elements in\n Or_error.error_s\n (Sexp.message\n (subset.name ^ \" is not a subset of \" ^ superset.name)\n [ \"invalid_elements\", invalid_elements_sexp ]))\n ;;\n\n let equal s1 s2 ~sexp_of_elt ~compare_elt =\n Or_error.combine_errors_unit\n [ is_subset s1 ~of_:s2 ~sexp_of_elt ~compare_elt\n ; is_subset s2 ~of_:s1 ~sexp_of_elt ~compare_elt\n ]\n ;;\n end\nend\n\ntype ('a, 'comparator) t =\n { (* [comparator] is the first field so that polymorphic equality fails on a map due\n to the functional value in the comparator.\n Note that this does not affect polymorphic [compare]: that still produces\n nonsense. *)\n comparator : ('a, 'comparator) Comparator.t\n ; tree : 'a Tree0.t\n }\n\ntype ('a, 'comparator) tree = 'a Tree0.t\n\nlet like { tree = _; comparator } tree = { tree; comparator }\nlet compare_elt t = t.comparator.Comparator.compare\n\nmodule Accessors = struct\n let comparator t = t.comparator\n let invariants t = Tree0.invariants t.tree ~compare_elt:(compare_elt t)\n let length t = Tree0.length t.tree\n let is_empty t = Tree0.is_empty t.tree\n let elements t = Tree0.elements t.tree\n let min_elt t = Tree0.min_elt t.tree\n let min_elt_exn t = Tree0.min_elt_exn t.tree\n let max_elt t = Tree0.max_elt t.tree\n let max_elt_exn t = Tree0.max_elt_exn t.tree\n let choose t = Tree0.choose t.tree\n let choose_exn t = Tree0.choose_exn t.tree\n let to_list t = Tree0.to_list t.tree\n let to_array t = Tree0.to_array t.tree\n let fold t ~init ~f = Tree0.fold t.tree ~init ~f\n let fold_until t ~init ~f = Tree0.fold_until t.tree ~init ~f\n let fold_right t ~init ~f = Tree0.fold_right t.tree ~init ~f\n let fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\n let iter t ~f = Tree0.iter t.tree ~f\n let iter2 a b ~f = Tree0.iter2 a.tree b.tree ~f ~compare_elt:(compare_elt a)\n let exists t ~f = Tree0.exists t.tree ~f\n let for_all t ~f = Tree0.for_all t.tree ~f\n let count t ~f = Tree0.count t.tree ~f\n let sum m t ~f = Tree0.sum m t.tree ~f\n let find t ~f = Tree0.find t.tree ~f\n let find_exn t ~f = Tree0.find_exn t.tree ~f\n let find_map t ~f = Tree0.find_map t.tree ~f\n let mem t a = Tree0.mem t.tree a ~compare_elt:(compare_elt t)\n let filter t ~f = like t (Tree0.filter t.tree ~f ~compare_elt:(compare_elt t))\n let add t a = like t (Tree0.add t.tree a ~compare_elt:(compare_elt t))\n let remove t a = like t (Tree0.remove t.tree a ~compare_elt:(compare_elt t))\n let union t1 t2 = like t1 (Tree0.union t1.tree t2.tree ~compare_elt:(compare_elt t1))\n let inter t1 t2 = like t1 (Tree0.inter t1.tree t2.tree ~compare_elt:(compare_elt t1))\n let diff t1 t2 = like t1 (Tree0.diff t1.tree t2.tree ~compare_elt:(compare_elt t1))\n\n let symmetric_diff t1 t2 =\n Tree0.symmetric_diff t1.tree t2.tree ~compare_elt:(compare_elt t1)\n ;;\n\n let compare_direct t1 t2 = Tree0.compare (compare_elt t1) t1.tree t2.tree\n let equal t1 t2 = Tree0.equal t1.tree t2.tree ~compare_elt:(compare_elt t1)\n\n let is_subset t ~of_ =\n Tree0.is_subset t.tree ~of_:of_.tree ~compare_elt:(compare_elt t)\n ;;\n\n let are_disjoint t1 t2 =\n Tree0.are_disjoint t1.tree t2.tree ~compare_elt:(compare_elt t1)\n ;;\n\n module Named = struct\n type nonrec ('a, 'cmp) t =\n { set : ('a, 'cmp) t\n ; name : string\n }\n\n let to_named_tree { set; name } = { Tree0.Named.tree = set.tree; name }\n\n let is_subset (subset : (_, _) t) ~of_:(superset : (_, _) t) =\n Tree0.Named.is_subset\n (to_named_tree subset)\n ~of_:(to_named_tree superset)\n ~compare_elt:(compare_elt subset.set)\n ~sexp_of_elt:subset.set.comparator.sexp_of_t\n ;;\n\n let equal t1 t2 =\n Or_error.combine_errors_unit [ is_subset t1 ~of_:t2; is_subset t2 ~of_:t1 ]\n ;;\n end\n\n let partition_tf t ~f =\n let tree_t, tree_f = Tree0.partition_tf t.tree ~f ~compare_elt:(compare_elt t) in\n like t tree_t, like t tree_f\n ;;\n\n let split t a =\n let tree1, b, tree2 = Tree0.split t.tree a ~compare_elt:(compare_elt t) in\n like t tree1, b, like t tree2\n ;;\n\n let group_by t ~equiv =\n List.map (Tree0.group_by t.tree ~equiv ~compare_elt:(compare_elt t)) ~f:(like t)\n ;;\n\n let nth t i = Tree0.nth t.tree i\n\n let remove_index t i =\n like t (Tree0.remove_index t.tree i ~compare_elt:(compare_elt t))\n ;;\n\n let sexp_of_t sexp_of_a _ t = Tree0.sexp_of_t sexp_of_a t.tree\n\n let to_sequence ?order ?greater_or_equal_to ?less_or_equal_to t =\n Tree0.to_sequence t.comparator ?order ?greater_or_equal_to ?less_or_equal_to t.tree\n ;;\n\n let binary_search t ~compare how v = Tree0.binary_search t.tree ~compare how v\n\n let binary_search_segmented t ~segment_of how =\n Tree0.binary_search_segmented t.tree ~segment_of how\n ;;\n\n let merge_to_sequence ?order ?greater_or_equal_to ?less_or_equal_to t t' =\n Tree0.merge_to_sequence\n t.comparator\n ?order\n ?greater_or_equal_to\n ?less_or_equal_to\n t.tree\n t'.tree\n ;;\n\n let hash_fold_direct hash_fold_key state t =\n Tree0.hash_fold_t_ignoring_structure hash_fold_key state t.tree\n ;;\nend\n\ninclude Accessors\n\nlet compare _ _ t1 t2 = compare_direct t1 t2\n\nmodule Tree = struct\n type ('a, 'comparator) t = ('a, 'comparator) tree\n\n let ce comparator = comparator.Comparator.compare\n\n let t_of_sexp_direct ~comparator a_of_sexp sexp =\n Tree0.t_of_sexp_direct ~compare_elt:(ce comparator) a_of_sexp sexp\n ;;\n\n let empty_without_value_restriction = Tree0.empty\n let empty ~comparator:_ = empty_without_value_restriction\n let singleton ~comparator:_ e = Tree0.singleton e\n let length t = Tree0.length t\n let invariants ~comparator t = Tree0.invariants t ~compare_elt:(ce comparator)\n let is_empty t = Tree0.is_empty t\n let elements t = Tree0.elements t\n let min_elt t = Tree0.min_elt t\n let min_elt_exn t = Tree0.min_elt_exn t\n let max_elt t = Tree0.max_elt t\n let max_elt_exn t = Tree0.max_elt_exn t\n let choose t = Tree0.choose t\n let choose_exn t = Tree0.choose_exn t\n let to_list t = Tree0.to_list t\n let to_array t = Tree0.to_array t\n let iter t ~f = Tree0.iter t ~f\n let exists t ~f = Tree0.exists t ~f\n let for_all t ~f = Tree0.for_all t ~f\n let count t ~f = Tree0.count t ~f\n let sum m t ~f = Tree0.sum m t ~f\n let find t ~f = Tree0.find t ~f\n let find_exn t ~f = Tree0.find_exn t ~f\n let find_map t ~f = Tree0.find_map t ~f\n let fold t ~init ~f = Tree0.fold t ~init ~f\n let fold_until t ~init ~f = Tree0.fold_until t ~init ~f\n let fold_right t ~init ~f = Tree0.fold_right t ~init ~f\n let map ~comparator t ~f = Tree0.map t ~f ~compare_elt:(ce comparator)\n let filter ~comparator t ~f = Tree0.filter t ~f ~compare_elt:(ce comparator)\n let filter_map ~comparator t ~f = Tree0.filter_map t ~f ~compare_elt:(ce comparator)\n\n let partition_tf ~comparator t ~f =\n Tree0.partition_tf t ~f ~compare_elt:(ce comparator)\n ;;\n\n let iter2 ~comparator a b ~f = Tree0.iter2 a b ~f ~compare_elt:(ce comparator)\n let mem ~comparator t a = Tree0.mem t a ~compare_elt:(ce comparator)\n let add ~comparator t a = Tree0.add t a ~compare_elt:(ce comparator)\n let remove ~comparator t a = Tree0.remove t a ~compare_elt:(ce comparator)\n let union ~comparator t1 t2 = Tree0.union t1 t2 ~compare_elt:(ce comparator)\n let inter ~comparator t1 t2 = Tree0.inter t1 t2 ~compare_elt:(ce comparator)\n let diff ~comparator t1 t2 = Tree0.diff t1 t2 ~compare_elt:(ce comparator)\n\n let symmetric_diff ~comparator t1 t2 =\n Tree0.symmetric_diff t1 t2 ~compare_elt:(ce comparator)\n ;;\n\n let compare_direct ~comparator t1 t2 = Tree0.compare (ce comparator) t1 t2\n let equal ~comparator t1 t2 = Tree0.equal t1 t2 ~compare_elt:(ce comparator)\n let is_subset ~comparator t ~of_ = Tree0.is_subset t ~of_ ~compare_elt:(ce comparator)\n\n let are_disjoint ~comparator t1 t2 =\n Tree0.are_disjoint t1 t2 ~compare_elt:(ce comparator)\n ;;\n\n let of_list ~comparator l = Tree0.of_list l ~compare_elt:(ce comparator)\n let of_array ~comparator a = Tree0.of_array a ~compare_elt:(ce comparator)\n\n let of_sorted_array_unchecked ~comparator a =\n Tree0.of_sorted_array_unchecked a ~compare_elt:(ce comparator)\n ;;\n\n let of_increasing_iterator_unchecked ~comparator:_ ~len ~f =\n Tree0.of_increasing_iterator_unchecked ~len ~f\n ;;\n\n let of_sorted_array ~comparator a =\n Tree0.of_sorted_array a ~compare_elt:(ce comparator)\n ;;\n\n let union_list ~comparator l = Tree0.union_list l ~to_tree:Fn.id ~comparator\n\n let stable_dedup_list ~comparator xs =\n Tree0.stable_dedup_list xs ~compare_elt:(ce comparator)\n ;;\n\n let group_by ~comparator t ~equiv =\n Tree0.group_by t ~equiv ~compare_elt:(ce comparator)\n ;;\n\n let split ~comparator t a = Tree0.split t a ~compare_elt:(ce comparator)\n let nth t i = Tree0.nth t i\n let remove_index ~comparator t i = Tree0.remove_index t i ~compare_elt:(ce comparator)\n let sexp_of_t sexp_of_a _ t = Tree0.sexp_of_t sexp_of_a t\n let to_tree t = t\n let of_tree ~comparator:_ t = t\n\n let to_sequence ~comparator ?order ?greater_or_equal_to ?less_or_equal_to t =\n Tree0.to_sequence comparator ?order ?greater_or_equal_to ?less_or_equal_to t\n ;;\n\n let binary_search ~comparator:_ t ~compare how v = Tree0.binary_search t ~compare how v\n\n let binary_search_segmented ~comparator:_ t ~segment_of how =\n Tree0.binary_search_segmented t ~segment_of how\n ;;\n\n let merge_to_sequence ~comparator ?order ?greater_or_equal_to ?less_or_equal_to t t' =\n Tree0.merge_to_sequence comparator ?order ?greater_or_equal_to ?less_or_equal_to t t'\n ;;\n\n let fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\n\n module Named = struct\n include Tree0.Named\n\n let is_subset ~comparator t1 ~of_:t2 =\n Tree0.Named.is_subset\n t1\n ~of_:t2\n ~compare_elt:(ce comparator)\n ~sexp_of_elt:comparator.Comparator.sexp_of_t\n ;;\n\n let equal ~comparator t1 t2 =\n Tree0.Named.equal\n t1\n t2\n ~compare_elt:(ce comparator)\n ~sexp_of_elt:comparator.Comparator.sexp_of_t\n ;;\n end\nend\n\nmodule Using_comparator = struct\n type nonrec ('elt, 'cmp) t = ('elt, 'cmp) t\n\n include Accessors\n\n let to_tree t = t.tree\n let of_tree ~comparator tree = { comparator; tree }\n\n let t_of_sexp_direct ~comparator a_of_sexp sexp =\n of_tree\n ~comparator\n (Tree0.t_of_sexp_direct ~compare_elt:comparator.compare a_of_sexp sexp)\n ;;\n\n let empty ~comparator = { comparator; tree = Tree0.empty }\n\n module Empty_without_value_restriction (Elt : Comparator.S1) = struct\n let empty = { comparator = Elt.comparator; tree = Tree0.empty }\n end\n\n let singleton ~comparator e = { comparator; tree = Tree0.singleton e }\n\n let union_list ~comparator l =\n of_tree ~comparator (Tree0.union_list ~comparator ~to_tree l)\n ;;\n\n let of_sorted_array_unchecked ~comparator array =\n let tree =\n Tree0.of_sorted_array_unchecked array ~compare_elt:comparator.Comparator.compare\n in\n { comparator; tree }\n ;;\n\n let of_increasing_iterator_unchecked ~comparator ~len ~f =\n of_tree ~comparator (Tree0.of_increasing_iterator_unchecked ~len ~f)\n ;;\n\n let of_sorted_array ~comparator array =\n Or_error.Monad_infix.(\n Tree0.of_sorted_array array ~compare_elt:comparator.Comparator.compare\n >>| fun tree -> { comparator; tree })\n ;;\n\n let of_list ~comparator l =\n { comparator; tree = Tree0.of_list l ~compare_elt:comparator.Comparator.compare }\n ;;\n\n let of_array ~comparator a =\n { comparator; tree = Tree0.of_array a ~compare_elt:comparator.Comparator.compare }\n ;;\n\n let stable_dedup_list ~comparator xs =\n Tree0.stable_dedup_list xs ~compare_elt:comparator.Comparator.compare\n ;;\n\n let map ~comparator t ~f =\n { comparator; tree = Tree0.map t.tree ~f ~compare_elt:comparator.Comparator.compare }\n ;;\n\n let filter_map ~comparator t ~f =\n { comparator\n ; tree = Tree0.filter_map t.tree ~f ~compare_elt:comparator.Comparator.compare\n }\n ;;\n\n module Tree = Tree\nend\n\ntype ('elt, 'cmp) comparator =\n (module Comparator.S with type t = 'elt and type comparator_witness = 'cmp)\n\nlet comparator_s (type k cmp) t : (k, cmp) comparator =\n (module struct\n type t = k\n type comparator_witness = cmp\n\n let comparator = t.comparator\n end)\n;;\n\nlet to_comparator (type elt cmp) ((module M) : (elt, cmp) comparator) = M.comparator\nlet empty m = Using_comparator.empty ~comparator:(to_comparator m)\nlet singleton m a = Using_comparator.singleton ~comparator:(to_comparator m) a\nlet union_list m a = Using_comparator.union_list ~comparator:(to_comparator m) a\n\nlet of_sorted_array_unchecked m a =\n Using_comparator.of_sorted_array_unchecked ~comparator:(to_comparator m) a\n;;\n\nlet of_increasing_iterator_unchecked m ~len ~f =\n Using_comparator.of_increasing_iterator_unchecked ~comparator:(to_comparator m) ~len ~f\n;;\n\nlet of_sorted_array m a =\n Using_comparator.of_sorted_array ~comparator:(to_comparator m) a\n;;\n\nlet of_list m a = Using_comparator.of_list ~comparator:(to_comparator m) a\nlet of_array m a = Using_comparator.of_array ~comparator:(to_comparator m) a\n\nlet stable_dedup_list m a =\n Using_comparator.stable_dedup_list ~comparator:(to_comparator m) a\n;;\n\nlet map m a ~f = Using_comparator.map ~comparator:(to_comparator m) a ~f\nlet filter_map m a ~f = Using_comparator.filter_map ~comparator:(to_comparator m) a ~f\n\nmodule M (Elt : sig\n type t\n type comparator_witness\n end) =\nstruct\n type nonrec t = (Elt.t, Elt.comparator_witness) t\nend\n\nmodule type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\nend\n\nmodule type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Comparator.S with type t := t\nend\n\nmodule type Compare_m = sig end\nmodule type Equal_m = sig end\nmodule type Hash_fold_m = Hasher.S\n\nlet sexp_of_m__t (type elt) (module Elt : Sexp_of_m with type t = elt) t =\n sexp_of_t Elt.sexp_of_t (fun _ -> Sexp.Atom \"_\") t\n;;\n\nlet m__t_of_sexp\n (type elt cmp)\n (module Elt : M_of_sexp with type t = elt and type comparator_witness = cmp)\n sexp\n =\n Using_comparator.t_of_sexp_direct ~comparator:Elt.comparator Elt.t_of_sexp sexp\n;;\n\nlet compare_m__t (module Elt : Compare_m) t1 t2 = compare_direct t1 t2\nlet equal_m__t (module Elt : Equal_m) t1 t2 = equal t1 t2\n\nlet hash_fold_m__t (type elt) (module Elt : Hash_fold_m with type t = elt) state =\n hash_fold_direct Elt.hash_fold_t state\n;;\n\nlet hash_m__t folder t =\n let state = hash_fold_m__t folder (Hash.create ()) t in\n Hash.get_hash_value state\n;;\n\nmodule Poly = struct\n type comparator_witness = Comparator.Poly.comparator_witness\n type nonrec ('elt, 'cmp) set = ('elt, comparator_witness) t\n type nonrec 'elt t = ('elt, comparator_witness) t\n type nonrec 'elt tree = ('elt, comparator_witness) tree\n type nonrec 'elt named = ('elt, comparator_witness) Named.t\n\n include Accessors\n\n let comparator = Comparator.Poly.comparator\n\n include Using_comparator.Empty_without_value_restriction (Comparator.Poly)\n\n let singleton a = Using_comparator.singleton ~comparator a\n let union_list a = Using_comparator.union_list ~comparator a\n\n let of_sorted_array_unchecked a =\n Using_comparator.of_sorted_array_unchecked ~comparator a\n ;;\n\n let of_increasing_iterator_unchecked ~len ~f =\n Using_comparator.of_increasing_iterator_unchecked ~comparator ~len ~f\n ;;\n\n let of_sorted_array a = Using_comparator.of_sorted_array ~comparator a\n let of_list a = Using_comparator.of_list ~comparator a\n let of_array a = Using_comparator.of_array ~comparator a\n let stable_dedup_list a = Using_comparator.stable_dedup_list ~comparator a\n let map a ~f = Using_comparator.map ~comparator a ~f\n let filter_map a ~f = Using_comparator.filter_map ~comparator a ~f\n let of_tree tree = { comparator; tree }\n let to_tree t = t.tree\nend\n","open! Import\nopen! T\n\nmodule type Elt_plain = sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\nend\n\nmodule Without_comparator = Map_intf.Without_comparator\nmodule With_comparator = Map_intf.With_comparator\nmodule With_first_class_module = Map_intf.With_first_class_module\ninclude Container_intf.Export\nmodule Merge_to_sequence_element = Sequence.Merge_with_duplicates_element\n\nmodule type Accessors_generic = sig\n include Container.Generic_phantom\n\n type ('a, 'cmp) tree\n\n (** The [options] type is used to make [Accessors_generic] flexible as to whether a\n comparator is required to be passed to certain functions. *)\n type ('a, 'cmp, 'z) options\n\n type 'cmp cmp\n\n val invariants : ('a, 'cmp, ('a, 'cmp) t -> bool) options\n\n (** override [Container]'s [mem] *)\n val mem : ('a, 'cmp, ('a, 'cmp) t -> 'a elt -> bool) options\n\n val add : ('a, 'cmp, ('a, 'cmp) t -> 'a elt -> ('a, 'cmp) t) options\n val remove : ('a, 'cmp, ('a, 'cmp) t -> 'a elt -> ('a, 'cmp) t) options\n val union : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t) options\n val inter : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t) options\n val diff : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t) options\n\n val symmetric_diff\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t -> ('a, 'cmp) t -> ('a elt, 'a elt) Either.t Sequence.t )\n options\n\n val compare_direct : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> int) options\n val equal : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> bool) options\n val is_subset : ('a, 'cmp, ('a, 'cmp) t -> of_:('a, 'cmp) t -> bool) options\n val are_disjoint : ('a, 'cmp, ('a, 'cmp) t -> ('a, 'cmp) t -> bool) options\n\n type ('a, 'cmp) named\n\n module Named : sig\n val is_subset\n : ('a, 'cmp, ('a, 'cmp) named -> of_:('a, 'cmp) named -> unit Or_error.t) options\n\n val equal\n : ('a, 'cmp, ('a, 'cmp) named -> ('a, 'cmp) named -> unit Or_error.t) options\n end\n\n val fold_until\n : ('a, _) t\n -> init:'b\n -> f:('b -> 'a elt -> ('b, 'final) Continue_or_stop.t)\n -> finish:('b -> 'final)\n -> 'final\n\n val fold_right : ('a, _) t -> init:'b -> f:('a elt -> 'b -> 'b) -> 'b\n\n val iter2\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> f:([ `Left of 'a elt | `Right of 'a elt | `Both of 'a elt * 'a elt ] -> unit)\n -> unit )\n options\n\n val filter : ('a, 'cmp, ('a, 'cmp) t -> f:('a elt -> bool) -> ('a, 'cmp) t) options\n\n val partition_tf\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t -> f:('a elt -> bool) -> ('a, 'cmp) t * ('a, 'cmp) t )\n options\n\n val elements : ('a, _) t -> 'a elt list\n val min_elt : ('a, _) t -> 'a elt option\n val min_elt_exn : ('a, _) t -> 'a elt\n val max_elt : ('a, _) t -> 'a elt option\n val max_elt_exn : ('a, _) t -> 'a elt\n val choose : ('a, _) t -> 'a elt option\n val choose_exn : ('a, _) t -> 'a elt\n\n val split\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t -> 'a elt -> ('a, 'cmp) t * 'a elt option * ('a, 'cmp) t )\n options\n\n val group_by\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t -> equiv:('a elt -> 'a elt -> bool) -> ('a, 'cmp) t list )\n options\n\n val find_exn : ('a, _) t -> f:('a elt -> bool) -> 'a elt\n val nth : ('a, _) t -> int -> 'a elt option\n val remove_index : ('a, 'cmp, ('a, 'cmp) t -> int -> ('a, 'cmp) t) options\n val to_tree : ('a, 'cmp) t -> ('a elt, 'cmp) tree\n\n val to_sequence\n : ( 'a\n , 'cmp\n , ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a elt\n -> ?less_or_equal_to:'a elt\n -> ('a, 'cmp) t\n -> 'a elt Sequence.t )\n options\n\n val binary_search\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t\n -> compare:('a elt -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> 'a elt option )\n options\n\n val binary_search_segmented\n : ( 'a\n , 'cmp\n , ('a, 'cmp) t\n -> segment_of:('a elt -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> 'a elt option )\n options\n\n val merge_to_sequence\n : ( 'a\n , 'cmp\n , ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a elt\n -> ?less_or_equal_to:'a elt\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a elt, 'a elt) Merge_to_sequence_element.t Sequence.t )\n options\nend\n\nmodule type Accessors0 = sig\n include Container.S0\n\n type tree\n type comparator_witness\n\n val invariants : t -> bool\n val mem : t -> elt -> bool\n val add : t -> elt -> t\n val remove : t -> elt -> t\n val union : t -> t -> t\n val inter : t -> t -> t\n val diff : t -> t -> t\n val symmetric_diff : t -> t -> (elt, elt) Either.t Sequence.t\n val compare_direct : t -> t -> int\n val equal : t -> t -> bool\n val is_subset : t -> of_:t -> bool\n val are_disjoint : t -> t -> bool\n\n type named\n\n module Named : sig\n val is_subset : named -> of_:named -> unit Or_error.t\n val equal : named -> named -> unit Or_error.t\n end\n\n val fold_until\n : t\n -> init:'b\n -> f:('b -> elt -> ('b, 'final) Continue_or_stop.t)\n -> finish:('b -> 'final)\n -> 'final\n\n val fold_right : t -> init:'b -> f:(elt -> 'b -> 'b) -> 'b\n\n val iter2\n : t\n -> t\n -> f:([ `Left of elt | `Right of elt | `Both of elt * elt ] -> unit)\n -> unit\n\n val filter : t -> f:(elt -> bool) -> t\n val partition_tf : t -> f:(elt -> bool) -> t * t\n val elements : t -> elt list\n val min_elt : t -> elt option\n val min_elt_exn : t -> elt\n val max_elt : t -> elt option\n val max_elt_exn : t -> elt\n val choose : t -> elt option\n val choose_exn : t -> elt\n val split : t -> elt -> t * elt option * t\n val group_by : t -> equiv:(elt -> elt -> bool) -> t list\n val find_exn : t -> f:(elt -> bool) -> elt\n val nth : t -> int -> elt option\n val remove_index : t -> int -> t\n val to_tree : t -> tree\n\n val to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:elt\n -> ?less_or_equal_to:elt\n -> t\n -> elt Sequence.t\n\n val binary_search\n : t\n -> compare:(elt -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> elt option\n\n val binary_search_segmented\n : t\n -> segment_of:(elt -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> elt option\n\n val merge_to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:elt\n -> ?less_or_equal_to:elt\n -> t\n -> t\n -> (elt, elt) Merge_to_sequence_element.t Sequence.t\nend\n\nmodule type Accessors1 = sig\n include Container.S1\n\n type 'a tree\n type comparator_witness\n\n val invariants : _ t -> bool\n val mem : 'a t -> 'a -> bool\n val add : 'a t -> 'a -> 'a t\n val remove : 'a t -> 'a -> 'a t\n val union : 'a t -> 'a t -> 'a t\n val inter : 'a t -> 'a t -> 'a t\n val diff : 'a t -> 'a t -> 'a t\n val symmetric_diff : 'a t -> 'a t -> ('a, 'a) Either.t Sequence.t\n val compare_direct : 'a t -> 'a t -> int\n val equal : 'a t -> 'a t -> bool\n val is_subset : 'a t -> of_:'a t -> bool\n val are_disjoint : 'a t -> 'a t -> bool\n\n type 'a named\n\n module Named : sig\n val is_subset : 'a named -> of_:'a named -> unit Or_error.t\n val equal : 'a named -> 'a named -> unit Or_error.t\n end\n\n val fold_until\n : 'a t\n -> init:'b\n -> f:('b -> 'a -> ('b, 'final) Continue_or_stop.t)\n -> finish:('b -> 'final)\n -> 'final\n\n val fold_right : 'a t -> init:'b -> f:('a -> 'b -> 'b) -> 'b\n\n val iter2\n : 'a t\n -> 'a t\n -> f:([ `Left of 'a | `Right of 'a | `Both of 'a * 'a ] -> unit)\n -> unit\n\n val filter : 'a t -> f:('a -> bool) -> 'a t\n val partition_tf : 'a t -> f:('a -> bool) -> 'a t * 'a t\n val elements : 'a t -> 'a list\n val min_elt : 'a t -> 'a option\n val min_elt_exn : 'a t -> 'a\n val max_elt : 'a t -> 'a option\n val max_elt_exn : 'a t -> 'a\n val choose : 'a t -> 'a option\n val choose_exn : 'a t -> 'a\n val split : 'a t -> 'a -> 'a t * 'a option * 'a t\n val group_by : 'a t -> equiv:('a -> 'a -> bool) -> 'a t list\n val find_exn : 'a t -> f:('a -> bool) -> 'a\n val nth : 'a t -> int -> 'a option\n val remove_index : 'a t -> int -> 'a t\n val to_tree : 'a t -> 'a tree\n\n val to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> 'a t\n -> 'a Sequence.t\n\n val binary_search\n : 'a t\n -> compare:('a -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> 'a option\n\n val binary_search_segmented\n : 'a t\n -> segment_of:('a -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> 'a option\n\n val merge_to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> 'a t\n -> 'a t\n -> ('a, 'a) Merge_to_sequence_element.t Sequence.t\nend\n\nmodule type Accessors2 = sig\n include Container.S1_phantom_invariant\n\n type ('a, 'cmp) tree\n\n val invariants : (_, _) t -> bool\n val mem : ('a, _) t -> 'a -> bool\n val add : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n val remove : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n val union : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n val inter : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n val diff : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n val symmetric_diff : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'a) Either.t Sequence.t\n val compare_direct : ('a, 'cmp) t -> ('a, 'cmp) t -> int\n val equal : ('a, 'cmp) t -> ('a, 'cmp) t -> bool\n val is_subset : ('a, 'cmp) t -> of_:('a, 'cmp) t -> bool\n val are_disjoint : ('a, 'cmp) t -> ('a, 'cmp) t -> bool\n\n type ('a, 'cmp) named\n\n module Named : sig\n val is_subset : ('a, 'cmp) named -> of_:('a, 'cmp) named -> unit Or_error.t\n val equal : ('a, 'cmp) named -> ('a, 'cmp) named -> unit Or_error.t\n end\n\n val fold_until\n : ('a, _) t\n -> init:'b\n -> f:('b -> 'a -> ('b, 'final) Continue_or_stop.t)\n -> finish:('b -> 'final)\n -> 'final\n\n val fold_right : ('a, _) t -> init:'b -> f:('a -> 'b -> 'b) -> 'b\n\n val iter2\n : ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> f:([ `Left of 'a | `Right of 'a | `Both of 'a * 'a ] -> unit)\n -> unit\n\n val filter : ('a, 'cmp) t -> f:('a -> bool) -> ('a, 'cmp) t\n val partition_tf : ('a, 'cmp) t -> f:('a -> bool) -> ('a, 'cmp) t * ('a, 'cmp) t\n val elements : ('a, _) t -> 'a list\n val min_elt : ('a, _) t -> 'a option\n val min_elt_exn : ('a, _) t -> 'a\n val max_elt : ('a, _) t -> 'a option\n val max_elt_exn : ('a, _) t -> 'a\n val choose : ('a, _) t -> 'a option\n val choose_exn : ('a, _) t -> 'a\n val split : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t * 'a option * ('a, 'cmp) t\n val group_by : ('a, 'cmp) t -> equiv:('a -> 'a -> bool) -> ('a, 'cmp) t list\n val find_exn : ('a, _) t -> f:('a -> bool) -> 'a\n val nth : ('a, _) t -> int -> 'a option\n val remove_index : ('a, 'cmp) t -> int -> ('a, 'cmp) t\n val to_tree : ('a, 'cmp) t -> ('a, 'cmp) tree\n\n val to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> 'a Sequence.t\n\n val binary_search\n : ('a, 'cmp) t\n -> compare:('a -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> 'a option\n\n val binary_search_segmented\n : ('a, 'cmp) t\n -> segment_of:('a -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> 'a option\n\n val merge_to_sequence\n : ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'a) Merge_to_sequence_element.t Sequence.t\nend\n\nmodule type Accessors2_with_comparator = sig\n include Container.S1_phantom_invariant\n\n type ('a, 'cmp) tree\n\n val invariants : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t -> bool\n val mem : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t -> 'a -> bool\n val add : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n val remove : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n\n val union\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n\n val inter\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n\n val diff\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n\n val symmetric_diff\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'a) Either.t Sequence.t\n\n val compare_direct\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> int\n\n val equal : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t -> ('a, 'cmp) t -> bool\n\n val is_subset\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> of_:('a, 'cmp) t\n -> bool\n\n val are_disjoint\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> bool\n\n type ('a, 'cmp) named\n\n module Named : sig\n val is_subset\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) named\n -> of_:('a, 'cmp) named\n -> unit Or_error.t\n\n val equal\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) named\n -> ('a, 'cmp) named\n -> unit Or_error.t\n end\n\n val fold_until\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n val fold_right : ('a, _) t -> init:'accum -> f:('a -> 'accum -> 'accum) -> 'accum\n\n val iter2\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> f:([ `Left of 'a | `Right of 'a | `Both of 'a * 'a ] -> unit)\n -> unit\n\n val filter\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> f:('a -> bool)\n -> ('a, 'cmp) t\n\n val partition_tf\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> f:('a -> bool)\n -> ('a, 'cmp) t * ('a, 'cmp) t\n\n val elements : ('a, _) t -> 'a list\n val min_elt : ('a, _) t -> 'a option\n val min_elt_exn : ('a, _) t -> 'a\n val max_elt : ('a, _) t -> 'a option\n val max_elt_exn : ('a, _) t -> 'a\n val choose : ('a, _) t -> 'a option\n val choose_exn : ('a, _) t -> 'a\n\n val split\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> 'a\n -> ('a, 'cmp) t * 'a option * ('a, 'cmp) t\n\n val group_by\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> equiv:('a -> 'a -> bool)\n -> ('a, 'cmp) t list\n\n val find_exn : ('a, _) t -> f:('a -> bool) -> 'a\n val nth : ('a, _) t -> int -> 'a option\n\n val remove_index\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> int\n -> ('a, 'cmp) t\n\n val to_tree : ('a, 'cmp) t -> ('a, 'cmp) tree\n\n val to_sequence\n : comparator:('a, 'cmp) Comparator.t\n -> ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> 'a Sequence.t\n\n val binary_search\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> compare:('a -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> 'a option\n\n val binary_search_segmented\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> segment_of:('a -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> 'a option\n\n val merge_to_sequence\n : comparator:('a, 'cmp) Comparator.t\n -> ?order:[ `Increasing | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'a) Merge_to_sequence_element.t Sequence.t\nend\n\n(** Consistency checks (same as in [Container]). *)\nmodule Check_accessors\n (T : T2)\n (Tree : T2)\n (Elt : T1)\n (Named : T2)\n (Cmp : T1)\n (Options : T3)\n (M : Accessors_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Options.t\n with type ('a, 'b) t := ('a, 'b) T.t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type 'a elt := 'a Elt.t\n with type 'cmp cmp := 'cmp Cmp.t\n with type ('a, 'b) named := ('a, 'b) Named.t) =\nstruct end\n\nmodule Check_accessors0 (M : Accessors0) =\n Check_accessors\n (struct\n type ('a, 'b) t = M.t\n end)\n (struct\n type ('a, 'b) t = M.tree\n end)\n (struct\n type 'a t = M.elt\n end)\n (struct\n type ('a, 'b) t = M.named\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors1 (M : Accessors1) =\n Check_accessors\n (struct\n type ('a, 'b) t = 'a M.t\n end)\n (struct\n type ('a, 'b) t = 'a M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type ('a, 'b) t = 'a M.named\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors2 (M : Accessors2) =\n Check_accessors\n (struct\n type ('a, 'b) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.named\n end)\n (struct\n type 'a t = 'a\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors2_with_comparator (M : Accessors2_with_comparator) =\n Check_accessors\n (struct\n type ('a, 'b) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.named\n end)\n (struct\n type 'a t = 'a\n end)\n (With_comparator)\n (M)\n\nmodule type Creators_generic = sig\n type ('a, 'cmp) t\n type ('a, 'cmp) set\n type ('a, 'cmp) tree\n type 'a elt\n type ('a, 'cmp, 'z) options\n type 'cmp cmp\n\n val empty : ('a, 'cmp, ('a, 'cmp) t) options\n val singleton : ('a, 'cmp, 'a elt -> ('a, 'cmp) t) options\n val union_list : ('a, 'cmp, ('a, 'cmp) t list -> ('a, 'cmp) t) options\n val of_list : ('a, 'cmp, 'a elt list -> ('a, 'cmp) t) options\n val of_array : ('a, 'cmp, 'a elt array -> ('a, 'cmp) t) options\n val of_sorted_array : ('a, 'cmp, 'a elt array -> ('a, 'cmp) t Or_error.t) options\n val of_sorted_array_unchecked : ('a, 'cmp, 'a elt array -> ('a, 'cmp) t) options\n\n val of_increasing_iterator_unchecked\n : ('a, 'cmp, len:int -> f:(int -> 'a elt) -> ('a, 'cmp) t) options\n\n val stable_dedup_list : ('a, _, 'a elt list -> 'a elt list) options\n\n (** The types of [map] and [filter_map] are subtle. The input set, [('a, _) set],\n reflects the fact that these functions take a set of *any* type, with any\n comparator, while the output set, [('b, 'cmp) t], reflects that the output set has\n the particular ['cmp] of the creation function. The comparator can come in one of\n three ways, depending on which set module is used\n\n - [Set.map] -- comparator comes as an argument\n - [Set.Poly.map] -- comparator is polymorphic comparison\n - [Foo.Set.map] -- comparator is [Foo.comparator] *)\n val map : ('b, 'cmp, ('a, _) set -> f:('a -> 'b elt) -> ('b, 'cmp) t) options\n\n val filter_map\n : ('b, 'cmp, ('a, _) set -> f:('a -> 'b elt option) -> ('b, 'cmp) t) options\n\n val of_tree : ('a, 'cmp, ('a elt, 'cmp) tree -> ('a, 'cmp) t) options\nend\n\nmodule type Creators0 = sig\n type ('a, 'cmp) set\n type t\n type tree\n type elt\n type comparator_witness\n\n val empty : t\n val singleton : elt -> t\n val union_list : t list -> t\n val of_list : elt list -> t\n val of_array : elt array -> t\n val of_sorted_array : elt array -> t Or_error.t\n val of_sorted_array_unchecked : elt array -> t\n val of_increasing_iterator_unchecked : len:int -> f:(int -> elt) -> t\n val stable_dedup_list : elt list -> elt list\n val map : ('a, _) set -> f:('a -> elt) -> t\n val filter_map : ('a, _) set -> f:('a -> elt option) -> t\n val of_tree : tree -> t\nend\n\nmodule type Creators1 = sig\n type ('a, 'cmp) set\n type 'a t\n type 'a tree\n type comparator_witness\n\n val empty : 'a t\n val singleton : 'a -> 'a t\n val union_list : 'a t list -> 'a t\n val of_list : 'a list -> 'a t\n val of_array : 'a array -> 'a t\n val of_sorted_array : 'a array -> 'a t Or_error.t\n val of_sorted_array_unchecked : 'a array -> 'a t\n val of_increasing_iterator_unchecked : len:int -> f:(int -> 'a) -> 'a t\n val stable_dedup_list : 'a list -> 'a list\n val map : ('a, _) set -> f:('a -> 'b) -> 'b t\n val filter_map : ('a, _) set -> f:('a -> 'b option) -> 'b t\n val of_tree : 'a tree -> 'a t\nend\n\nmodule type Creators2 = sig\n type ('a, 'cmp) set\n type ('a, 'cmp) t\n type ('a, 'cmp) tree\n\n val empty : ('a, 'cmp) t\n val singleton : 'a -> ('a, 'cmp) t\n val union_list : ('a, 'cmp) t list -> ('a, 'cmp) t\n val of_list : 'a list -> ('a, 'cmp) t\n val of_array : 'a array -> ('a, 'cmp) t\n val of_sorted_array : 'a array -> ('a, 'cmp) t Or_error.t\n val of_sorted_array_unchecked : 'a array -> ('a, 'cmp) t\n val of_increasing_iterator_unchecked : len:int -> f:(int -> 'a) -> ('a, 'cmp) t\n val stable_dedup_list : 'a list -> 'a list\n val map : ('a, _) set -> f:('a -> 'b) -> ('b, 'cmp) t\n val filter_map : ('a, _) set -> f:('a -> 'b option) -> ('b, 'cmp) t\n val of_tree : ('a, 'cmp) tree -> ('a, 'cmp) t\nend\n\nmodule type Creators2_with_comparator = sig\n type ('a, 'cmp) set\n type ('a, 'cmp) t\n type ('a, 'cmp) tree\n\n val empty : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) t\n val singleton : comparator:('a, 'cmp) Comparator.t -> 'a -> ('a, 'cmp) t\n\n val union_list\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t list\n -> ('a, 'cmp) t\n\n val of_list : comparator:('a, 'cmp) Comparator.t -> 'a list -> ('a, 'cmp) t\n val of_array : comparator:('a, 'cmp) Comparator.t -> 'a array -> ('a, 'cmp) t\n\n val of_sorted_array\n : comparator:('a, 'cmp) Comparator.t\n -> 'a array\n -> ('a, 'cmp) t Or_error.t\n\n val of_sorted_array_unchecked\n : comparator:('a, 'cmp) Comparator.t\n -> 'a array\n -> ('a, 'cmp) t\n\n val of_increasing_iterator_unchecked\n : comparator:('a, 'cmp) Comparator.t\n -> len:int\n -> f:(int -> 'a)\n -> ('a, 'cmp) t\n\n val stable_dedup_list : comparator:('a, 'cmp) Comparator.t -> 'a list -> 'a list\n\n val map\n : comparator:('b, 'cmp) Comparator.t\n -> ('a, _) set\n -> f:('a -> 'b)\n -> ('b, 'cmp) t\n\n val filter_map\n : comparator:('b, 'cmp) Comparator.t\n -> ('a, _) set\n -> f:('a -> 'b option)\n -> ('b, 'cmp) t\n\n val of_tree : comparator:('a, 'cmp) Comparator.t -> ('a, 'cmp) tree -> ('a, 'cmp) t\nend\n\nmodule Check_creators\n (T : T2)\n (Tree : T2)\n (Elt : T1)\n (Cmp : T1)\n (Options : T3)\n (M : Creators_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Options.t\n with type ('a, 'b) t := ('a, 'b) T.t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type 'a elt := 'a Elt.t\n with type 'cmp cmp := 'cmp Cmp.t) =\nstruct end\n\nmodule Check_creators0 (M : Creators0) =\n Check_creators\n (struct\n type ('a, 'b) t = M.t\n end)\n (struct\n type ('a, 'b) t = M.tree\n end)\n (struct\n type 'a t = M.elt\n end)\n (struct\n type 'cmp t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_creators1 (M : Creators1) =\n Check_creators\n (struct\n type ('a, 'b) t = 'a M.t\n end)\n (struct\n type ('a, 'b) t = 'a M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'cmp t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_creators2 (M : Creators2) =\n Check_creators\n (struct\n type ('a, 'b) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'cmp t = 'cmp\n end)\n (Without_comparator)\n (M)\n\nmodule Check_creators2_with_comparator (M : Creators2_with_comparator) =\n Check_creators\n (struct\n type ('a, 'b) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'cmp t = 'cmp\n end)\n (With_comparator)\n (M)\n\nmodule type Creators_and_accessors_generic = sig\n include Accessors_generic\n\n include\n Creators_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) options\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) tree\n with type 'a elt := 'a elt\n with type 'cmp cmp := 'cmp cmp\nend\n\nmodule type Creators_and_accessors0 = sig\n include Accessors0\n\n include\n Creators0\n with type t := t\n with type tree := tree\n with type elt := elt\n with type comparator_witness := comparator_witness\nend\n\nmodule type Creators_and_accessors1 = sig\n include Accessors1\n\n include\n Creators1\n with type 'a t := 'a t\n with type 'a tree := 'a tree\n with type comparator_witness := comparator_witness\nend\n\nmodule type Creators_and_accessors2 = sig\n include Accessors2\n\n include\n Creators2 with type ('a, 'b) t := ('a, 'b) t with type ('a, 'b) tree := ('a, 'b) tree\nend\n\nmodule type Creators_and_accessors2_with_comparator = sig\n include Accessors2_with_comparator\n\n include\n Creators2_with_comparator\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) tree\nend\n\nmodule type S_poly = Creators_and_accessors1\n\nmodule type For_deriving = sig\n type ('a, 'b) t\n\n module type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end\n\n module type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Comparator.S with type t := t\n end\n\n module type Compare_m = sig end\n module type Equal_m = sig end\n module type Hash_fold_m = Hasher.S\n\n val sexp_of_m__t : (module Sexp_of_m with type t = 'elt) -> ('elt, 'cmp) t -> Sexp.t\n\n val m__t_of_sexp\n : (module M_of_sexp with type t = 'elt and type comparator_witness = 'cmp)\n -> Sexp.t\n -> ('elt, 'cmp) t\n\n val compare_m__t : (module Compare_m) -> ('elt, 'cmp) t -> ('elt, 'cmp) t -> int\n val equal_m__t : (module Equal_m) -> ('elt, 'cmp) t -> ('elt, 'cmp) t -> bool\n\n val hash_fold_m__t\n : (module Hash_fold_m with type t = 'elt)\n -> Hash.state\n -> ('elt, _) t\n -> Hash.state\n\n val hash_m__t : (module Hash_fold_m with type t = 'elt) -> ('elt, _) t -> int\nend\n\nmodule type Set = sig\n (** This module defines the [Set] module for [Base]. Functions that construct a set take\n as an argument the comparator for the element type. *)\n\n (** The type of a set. The first type parameter identifies the type of the element, and\n the second identifies the comparator, which determines the comparison function that\n is used for ordering elements in this set. Many operations (e.g., {!union}),\n require that they be passed sets with the same element type and the same comparator\n type. *)\n type ('elt, 'cmp) t [@@deriving_inline compare]\n\n val compare\n : ('elt -> 'elt -> int)\n -> ('cmp -> 'cmp -> int)\n -> ('elt, 'cmp) t\n -> ('elt, 'cmp) t\n -> int\n\n [@@@end]\n\n type ('k, 'cmp) comparator =\n (module Comparator.S with type t = 'k and type comparator_witness = 'cmp)\n\n (** Tests internal invariants of the set data structure. Returns true on success. *)\n val invariants : (_, _) t -> bool\n\n (** Returns a first-class module that can be used to build other map/set/etc\n with the same notion of comparison. *)\n val comparator_s : ('a, 'cmp) t -> ('a, 'cmp) comparator\n\n val comparator : ('a, 'cmp) t -> ('a, 'cmp) Comparator.t\n\n (** Creates an empty set based on the provided comparator. *)\n val empty : ('a, 'cmp) comparator -> ('a, 'cmp) t\n\n (** Creates a set based on the provided comparator that contains only the provided\n element. *)\n val singleton : ('a, 'cmp) comparator -> 'a -> ('a, 'cmp) t\n\n (** Returns the cardinality of the set. [O(1)]. *)\n val length : (_, _) t -> int\n\n (** [is_empty t] is [true] iff [t] is empty. [O(1)]. *)\n val is_empty : (_, _) t -> bool\n\n (** [mem t a] returns [true] iff [a] is in [t]. [O(log n)]. *)\n val mem : ('a, _) t -> 'a -> bool\n\n (** [add t a] returns a new set with [a] added to [t], or returns [t] if [mem t a].\n [O(log n)]. *)\n val add : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n\n (** [remove t a] returns a new set with [a] removed from [t] if [mem t a], or returns [t]\n otherwise. [O(log n)]. *)\n val remove : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t\n\n (** [union t1 t2] returns the union of the two sets. [O(length t1 + length t2)]. *)\n val union : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n\n (** [union c list] returns the union of all the sets in [list]. The\n [comparator] argument is required for the case where [list] is empty.\n [O(max(List.length list, n log n))], where [n] is the sum of sizes of the input sets. *)\n val union_list : ('a, 'cmp) comparator -> ('a, 'cmp) t list -> ('a, 'cmp) t\n\n (** [inter t1 t2] computes the intersection of sets [t1] and [t2]. [O(length t1 +\n length t2)]. *)\n val inter : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n\n (** [diff t1 t2] computes the set difference [t1 - t2], i.e., the set containing all\n elements in [t1] that are not in [t2]. [O(length t1 + length t2)]. *)\n val diff : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'cmp) t\n\n (** [symmetric_diff t1 t2] returns a sequence of changes between [t1] and [t2]. It is\n intended to be efficient in the case where [t1] and [t2] share a large amount of\n structure. *)\n val symmetric_diff : ('a, 'cmp) t -> ('a, 'cmp) t -> ('a, 'a) Either.t Sequence.t\n\n (** [compare_direct t1 t2] compares the sets [t1] and [t2]. It returns the same result\n as [compare], but unlike compare, doesn't require arguments to be passed in for the\n type parameters of the set. [O(length t1 + length t2)]. *)\n val compare_direct : ('a, 'cmp) t -> ('a, 'cmp) t -> int\n\n (** Hash function: a building block to use when hashing data structures containing sets in\n them. [hash_fold_direct hash_fold_key] is compatible with [compare_direct] iff\n [hash_fold_key] is compatible with [(comparator s).compare] of the set [s] being\n hashed. *)\n val hash_fold_direct : 'a Hash.folder -> ('a, 'cmp) t Hash.folder\n\n (** [equal t1 t2] returns [true] iff the two sets have the same elements. [O(length t1 +\n length t2)] *)\n val equal : ('a, 'cmp) t -> ('a, 'cmp) t -> bool\n\n (** [exists t ~f] returns [true] iff there exists an [a] in [t] for which [f a]. [O(n)],\n but returns as soon as it finds an [a] for which [f a]. *)\n val exists : ('a, _) t -> f:('a -> bool) -> bool\n\n (** [for_all t ~f] returns [true] iff for all [a] in [t], [f a]. [O(n)], but returns as\n soon as it finds an [a] for which [not (f a)]. *)\n val for_all : ('a, _) t -> f:('a -> bool) -> bool\n\n (** [count t] returns the number of elements of [t] for which [f] returns [true].\n [O(n)]. *)\n val count : ('a, _) t -> f:('a -> bool) -> int\n\n (** [sum t] returns the sum of [f t] for each [t] in the set.\n [O(n)]. *)\n val sum\n : (module Container.Summable with type t = 'sum)\n -> ('a, _) t\n -> f:('a -> 'sum)\n -> 'sum\n\n (** [find t f] returns an element of [t] for which [f] returns true, with no guarantee as\n to which element is returned. [O(n)], but returns as soon as a suitable element is\n found. *)\n val find : ('a, _) t -> f:('a -> bool) -> 'a option\n\n (** [find_map t f] returns [b] for some [a] in [t] for which [f a = Some b]. If no such\n [a] exists, then [find] returns [None]. [O(n)], but returns as soon as a suitable\n element is found. *)\n val find_map : ('a, _) t -> f:('a -> 'b option) -> 'b option\n\n (** Like [find], but throws an exception on failure. *)\n val find_exn : ('a, _) t -> f:('a -> bool) -> 'a\n\n (** [nth t i] returns the [i]th smallest element of [t], in [O(log n)] time. The\n smallest element has [i = 0]. Returns [None] if [i < 0] or [i >= length t]. *)\n val nth : ('a, _) t -> int -> 'a option\n\n (** [remove_index t i] returns a version of [t] with the [i]th smallest element removed,\n in [O(log n)] time. The smallest element has [i = 0]. Returns [t] if [i < 0] or\n [i >= length t]. *)\n val remove_index : ('a, 'cmp) t -> int -> ('a, 'cmp) t\n\n (** [is_subset t1 ~of_:t2] returns true iff [t1] is a subset of [t2]. *)\n val is_subset : ('a, 'cmp) t -> of_:('a, 'cmp) t -> bool\n\n (** [are_disjoint t1 t2] returns [true] iff [is_empty (inter t1 t2)], but is more\n efficient. *)\n val are_disjoint : ('a, 'cmp) t -> ('a, 'cmp) t -> bool\n\n (** [Named] allows the validation of subset and equality relationships between sets. A\n [Named.t] is a record of a set and a name, where the name is used in error messages,\n and [Named.is_subset] and [Named.equal] validate subset and equality relationships\n respectively.\n\n The error message for, e.g.,\n {[\n Named.is_subset { set = set1; name = \"set1\" } ~of_:{set = set2; name = \"set2\" }\n ]}\n\n looks like\n {v\n (\"set1 is not a subset of set2\" (invalid_elements (...elements of set1 - set2...)))\n v}\n\n so [name] should be a noun phrase that doesn't sound awkward in the above error\n message. Even though it adds verbosity, choosing [name]s that start with the phrase\n \"the set of\" often makes the error message sound more natural.\n *)\n module Named : sig\n type nonrec ('a, 'cmp) t =\n { set : ('a, 'cmp) t\n ; name : string\n }\n\n (** [is_subset t1 ~of_:t2] returns [Ok ()] if [t1] is a subset of [t2] and a\n human-readable error otherwise. *)\n val is_subset : ('a, 'cmp) t -> of_:('a, 'cmp) t -> unit Or_error.t\n\n (** [equal t1 t2] returns [Ok ()] if [t1] is equal to [t2] and a human-readable\n error otherwise. *)\n val equal : ('a, 'cmp) t -> ('a, 'cmp) t -> unit Or_error.t\n end\n\n (** The list or array given to [of_list] and [of_array] need not be sorted. *)\n val of_list : ('a, 'cmp) comparator -> 'a list -> ('a, 'cmp) t\n\n val of_array : ('a, 'cmp) comparator -> 'a array -> ('a, 'cmp) t\n\n (** [to_list] and [to_array] produce sequences sorted in ascending order according to the\n comparator. *)\n val to_list : ('a, _) t -> 'a list\n\n val to_array : ('a, _) t -> 'a array\n\n (** Create set from sorted array. The input must be sorted (either in ascending or\n descending order as given by the comparator) and contain no duplicates, otherwise the\n result is an error. The complexity of this function is [O(n)]. *)\n val of_sorted_array : ('a, 'cmp) comparator -> 'a array -> ('a, 'cmp) t Or_error.t\n\n (** Similar to [of_sorted_array], but without checking the input array. *)\n val of_sorted_array_unchecked : ('a, 'cmp) comparator -> 'a array -> ('a, 'cmp) t\n\n (** [of_increasing_iterator_unchecked c ~len ~f] behaves like [of_sorted_array_unchecked c\n (Array.init len ~f)], with the additional restriction that a decreasing order is not\n supported. The advantage is not requiring you to allocate an intermediate array. [f]\n will be called with 0, 1, ... [len - 1], in order. *)\n val of_increasing_iterator_unchecked\n : ('a, 'cmp) comparator\n -> len:int\n -> f:(int -> 'a)\n -> ('a, 'cmp) t\n\n (** [stable_dedup_list] is here rather than in the [List] module because the\n implementation relies crucially on sets, and because doing so allows one to avoid uses\n of polymorphic comparison by instantiating the functor at a different implementation\n of [Comparator] and using the resulting [stable_dedup_list]. *)\n val stable_dedup_list : ('a, _) comparator -> 'a list -> 'a list\n\n (** [map c t ~f] returns a new set created by applying [f] to every element in\n [t]. The returned set is based on the provided [comparator]. [O(n log n)]. *)\n val map : ('b, 'cmp) comparator -> ('a, _) t -> f:('a -> 'b) -> ('b, 'cmp) t\n\n (** Like {!map}, except elements for which [f] returns [None] will be dropped. *)\n val filter_map\n : ('b, 'cmp) comparator\n -> ('a, _) t\n -> f:('a -> 'b option)\n -> ('b, 'cmp) t\n\n (** [filter t ~f] returns the subset of [t] for which [f] evaluates to true. [O(n log\n n)]. *)\n val filter : ('a, 'cmp) t -> f:('a -> bool) -> ('a, 'cmp) t\n\n (** [fold t ~init ~f] folds over the elements of the set from smallest to largest. *)\n val fold : ('a, _) t -> init:'accum -> f:('accum -> 'a -> 'accum) -> 'accum\n\n (** [fold_result ~init ~f] folds over the elements of the set from smallest to\n largest, short circuiting the fold if [f accum x] is an [Error _] *)\n val fold_result\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'e) Result.t)\n -> ('accum, 'e) Result.t\n\n (** [fold_until t ~init ~f] is a short-circuiting version of [fold]. If [f]\n returns [Stop _] the computation ceases and results in that value. If [f] returns\n [Continue _], the fold will proceed. *)\n val fold_until\n : ('a, _) t\n -> init:'accum\n -> f:('accum -> 'a -> ('accum, 'final) Continue_or_stop.t)\n -> finish:('accum -> 'final)\n -> 'final\n\n\n (** Like {!fold}, except that it goes from the largest to the smallest element. *)\n val fold_right : ('a, _) t -> init:'accum -> f:('a -> 'accum -> 'accum) -> 'accum\n\n (** [iter t ~f] calls [f] on every element of [t], going in order from the smallest to\n largest. *)\n val iter : ('a, _) t -> f:('a -> unit) -> unit\n\n (** Iterate two sets side by side. Complexity is [O(m+n)] where [m] and [n] are the sizes\n of the two input sets. As an example, with the inputs [0; 1] and [1; 2], [f] will be\n called with [`Left 0]; [`Both (1, 1)]; and [`Right 2]. *)\n val iter2\n : ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> f:([ `Left of 'a | `Right of 'a | `Both of 'a * 'a ] -> unit)\n -> unit\n\n (** if [a, b = partition_tf set ~f] then [a] is the elements on which [f] produced [true],\n and [b] is the elements on which [f] produces [false]. *)\n val partition_tf : ('a, 'cmp) t -> f:('a -> bool) -> ('a, 'cmp) t * ('a, 'cmp) t\n\n (** Same as {!to_list}. *)\n val elements : ('a, _) t -> 'a list\n\n (** Returns the smallest element of the set. [O(log n)]. *)\n val min_elt : ('a, _) t -> 'a option\n\n (** Like {!min_elt}, but throws an exception when given an empty set. *)\n val min_elt_exn : ('a, _) t -> 'a\n\n (** Returns the largest element of the set. [O(log n)]. *)\n val max_elt : ('a, _) t -> 'a option\n\n (** Like {!max_elt}, but throws an exception when given an empty set. *)\n val max_elt_exn : ('a, _) t -> 'a\n\n (** returns an arbitrary element, or [None] if the set is empty. *)\n val choose : ('a, _) t -> 'a option\n\n (** Like {!choose}, but throws an exception on an empty set. *)\n val choose_exn : ('a, _) t -> 'a\n\n (** [split t x] produces a triple [(t1, maybe_x, t2)] where [t1] is the set of elements\n strictly less than [x], [maybe_x] is the member (if any) of [t] which compares equal\n to [x], and [t2] is the set of elements strictly larger than [x]. *)\n val split : ('a, 'cmp) t -> 'a -> ('a, 'cmp) t * 'a option * ('a, 'cmp) t\n\n (** if [equiv] is an equivalence predicate, then [group_by set ~equiv] produces a list\n of equivalence classes (i.e., a set-theoretic quotient). E.g.,\n\n {[\n let chars = Set.of_list ['A'; 'a'; 'b'; 'c'] in\n let equiv c c' = Char.equal (Char.uppercase c) (Char.uppercase c') in\n group_by chars ~equiv\n ]}\n\n produces:\n\n {[\n [Set.of_list ['A';'a']; Set.singleton 'b'; Set.singleton 'c']\n ]}\n\n [group_by] runs in O(n^2) time, so if you have a comparison function, it's usually\n much faster to use [Set.of_list]. *)\n val group_by : ('a, 'cmp) t -> equiv:('a -> 'a -> bool) -> ('a, 'cmp) t list\n\n (** [to_sequence t] converts the set [t] to a sequence of the elements between\n [greater_or_equal_to] and [less_or_equal_to] inclusive in the order indicated by\n [order]. If [greater_or_equal_to > less_or_equal_to] the sequence is empty. Cost is\n O(log n) up front and amortized O(1) for each element produced. *)\n val to_sequence\n : ?order:[ `Increasing (** default *) | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> 'a Sequence.t\n\n (** [binary_search t ~compare which elt] returns the element in [t] specified by\n [compare] and [which], if one exists.\n\n [t] must be sorted in increasing order according to [compare], where [compare] and\n [elt] divide [t] into three (possibly empty) segments:\n\n {v\n | < elt | = elt | > elt |\n v}\n\n [binary_search] returns an element on the boundary of segments as specified by\n [which]. See the diagram below next to the [which] variants.\n\n [binary_search] does not check that [compare] orders [t], and behavior is\n unspecified if [compare] doesn't order [t]. Behavior is also unspecified if\n [compare] mutates [t]. *)\n val binary_search\n : ('a, 'cmp) t\n -> compare:('a -> 'key -> int)\n -> [ `Last_strictly_less_than (** {v | < elt X | v} *)\n | `Last_less_than_or_equal_to (** {v | <= elt X | v} *)\n | `Last_equal_to (** {v | = elt X | v} *)\n | `First_equal_to (** {v | X = elt | v} *)\n | `First_greater_than_or_equal_to (** {v | X >= elt | v} *)\n | `First_strictly_greater_than (** {v | X > elt | v} *)\n ]\n -> 'key\n -> 'a option\n\n (** [binary_search_segmented t ~segment_of which] takes a [segment_of] function that\n divides [t] into two (possibly empty) segments:\n\n {v\n | segment_of elt = `Left | segment_of elt = `Right |\n v}\n\n [binary_search_segmented] returns the element on the boundary of the segments as\n specified by [which]: [`Last_on_left] yields the last element of the left segment,\n while [`First_on_right] yields the first element of the right segment. It returns\n [None] if the segment is empty.\n\n [binary_search_segmented] does not check that [segment_of] segments [t] as in the\n diagram, and behavior is unspecified if [segment_of] doesn't segment [t]. Behavior\n is also unspecified if [segment_of] mutates [t]. *)\n val binary_search_segmented\n : ('a, 'cmp) t\n -> segment_of:('a -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> 'a option\n\n (** Produces the elements of the two sets between [greater_or_equal_to] and\n [less_or_equal_to] in [order], noting whether each element appears in the left set,\n the right set, or both. In the both case, both elements are returned, in case the\n caller can distinguish between elements that are equal to the sets' comparator. Runs\n in O(length t + length t'). *)\n module Merge_to_sequence_element : sig\n type ('a, 'b) t = ('a, 'b) Sequence.Merge_with_duplicates_element.t =\n | Left of 'a\n | Right of 'b\n | Both of 'a * 'b\n [@@deriving_inline compare, sexp]\n\n val compare\n : ('a -> 'a -> int)\n -> ('b -> 'b -> int)\n -> ('a, 'b) t\n -> ('a, 'b) t\n -> int\n\n include Ppx_sexp_conv_lib.Sexpable.S2 with type ('a, 'b) t := ('a, 'b) t\n\n [@@@end]\n end\n\n val merge_to_sequence\n : ?order:[ `Increasing (** default *) | `Decreasing ]\n -> ?greater_or_equal_to:'a\n -> ?less_or_equal_to:'a\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> ('a, 'a) Merge_to_sequence_element.t Sequence.t\n\n (** [M] is meant to be used in combination with OCaml applicative functor types:\n\n {[\n type string_set = Set.M(String).t\n ]}\n\n which stands for:\n\n {[\n type string_set = (String.t, String.comparator_witness) Set.t\n ]}\n\n The point is that [Set.M(String).t] supports deriving, whereas the second syntax\n doesn't (because there is no such thing as, say, String.sexp_of_comparator_witness,\n instead you would want to pass the comparator directly). *)\n module M (Elt : sig\n type t\n type comparator_witness\n end) : sig\n type nonrec t = (Elt.t, Elt.comparator_witness) t\n end\n\n include For_deriving with type ('a, 'b) t := ('a, 'b) t\n\n (** A polymorphic Set. *)\n module Poly : S_poly with type 'elt t = ('elt, Comparator.Poly.comparator_witness) t\n\n (** Using comparator is a similar interface as the toplevel of [Set], except the functions\n take a [~comparator:('elt, 'cmp) Comparator.t] where the functions at the toplevel of\n [Set] takes a [('elt, 'cmp) comparator]. *)\n module Using_comparator : sig\n type nonrec ('elt, 'cmp) t = ('elt, 'cmp) t [@@deriving_inline sexp_of]\n\n val sexp_of_t\n : ('elt -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('cmp -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('elt, 'cmp) t\n -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val t_of_sexp_direct\n : comparator:('elt, 'cmp) Comparator.t\n -> (Sexp.t -> 'elt)\n -> Sexp.t\n -> ('elt, 'cmp) t\n\n module Tree : sig\n (** A [Tree.t] contains just the tree data structure that a set is based on, without\n including the comparator. Accordingly, any operation on a [Tree.t] must also take\n as an argument the corresponding comparator. *)\n type ('a, 'cmp) t [@@deriving_inline sexp_of]\n\n val sexp_of_t\n : ('a -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('cmp -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('a, 'cmp) t\n -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val t_of_sexp_direct\n : comparator:('elt, 'cmp) Comparator.t\n -> (Sexp.t -> 'elt)\n -> Sexp.t\n -> ('elt, 'cmp) t\n\n module Named : sig\n type nonrec ('a, 'cmp) t =\n { tree : ('a, 'cmp) t\n ; name : string\n }\n\n val is_subset\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> of_:('a, 'cmp) t\n -> unit Or_error.t\n\n val equal\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'cmp) t\n -> ('a, 'cmp) t\n -> unit Or_error.t\n end\n\n include\n Creators_and_accessors2_with_comparator\n with type ('a, 'b) set := ('a, 'b) t\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) t\n with type ('a, 'b) named := ('a, 'b) Named.t\n with module Named := Named\n\n val empty_without_value_restriction : (_, _) t\n end\n\n include\n Accessors2\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type ('a, 'b) named := ('a, 'b) Named.t\n\n include\n Creators2_with_comparator\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type ('a, 'b) set := ('a, 'b) t\n\n val comparator : ('a, 'cmp) t -> ('a, 'cmp) Comparator.t\n val hash_fold_direct : 'elt Hash.folder -> ('elt, 'cmp) t Hash.folder\n\n module Empty_without_value_restriction (Elt : Comparator.S1) : sig\n val empty : ('a Elt.t, Elt.comparator_witness) t\n end\n end\n\n (** {2 Modules and module types for extending [Set]}\n\n For use in extensions of Base, like [Core_kernel]. *)\n\n module With_comparator = With_comparator\n module With_first_class_module = With_first_class_module\n module Without_comparator = Without_comparator\n\n module type For_deriving = For_deriving\n module type S_poly = S_poly\n module type Accessors0 = Accessors0\n module type Accessors1 = Accessors1\n module type Accessors2 = Accessors2\n module type Accessors2_with_comparator = Accessors2_with_comparator\n module type Accessors_generic = Accessors_generic\n module type Creators0 = Creators0\n module type Creators1 = Creators1\n module type Creators2 = Creators2\n module type Creators2_with_comparator = Creators2_with_comparator\n module type Creators_and_accessors0 = Creators_and_accessors0\n module type Creators_and_accessors1 = Creators_and_accessors1\n module type Creators_and_accessors2 = Creators_and_accessors2\n\n module type Creators_and_accessors2_with_comparator =\n Creators_and_accessors2_with_comparator\n\n module type Creators_generic = Creators_generic\n module type Elt_plain = Elt_plain\nend\n","open! Import\n\n\n(* [t] stores the [t.length] queue elements at consecutive increasing indices of [t.elts],\n mod the capacity of [t], which is [Option_array.length t.elts]. The capacity is\n required to be a power of two (user-requested capacities are rounded up to the nearest\n power), so that mod can quickly be computed using [land t.mask], where [t.mask =\n capacity t - 1]. So, queue element [i] is at [t.elts.( (t.front + i) land t.mask )].\n\n [num_mutations] is used to detect modification during iteration. *)\ntype 'a t =\n { mutable num_mutations : int\n ; mutable front : int\n ; mutable mask : int\n ; mutable length : int\n ; mutable elts : 'a Option_array.t\n }\n[@@deriving_inline sexp_of]\n\nlet sexp_of_t : 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t =\n fun _of_a -> function\n | { num_mutations = v_num_mutations\n ; front = v_front\n ; mask = v_mask\n ; length = v_length\n ; elts = v_elts\n } ->\n let bnds = [] in\n let bnds =\n let arg = Option_array.sexp_of_t _of_a v_elts in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"elts\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_length in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"length\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_mask in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"mask\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_front in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"front\"; arg ] :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_num_mutations in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"num_mutations\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n;;\n\n[@@@end]\n\nmodule type S = Queue_intf.S\n\nlet inc_num_mutations t = t.num_mutations <- t.num_mutations + 1\nlet capacity t = t.mask + 1\nlet elts_index t i = (t.front + i) land t.mask\nlet unsafe_get t i = Option_array.unsafe_get_some_exn t.elts (elts_index t i)\nlet unsafe_is_set t i = Option_array.unsafe_is_some t.elts (elts_index t i)\nlet unsafe_set t i a = Option_array.unsafe_set_some t.elts (elts_index t i) a\nlet unsafe_unset t i = Option_array.unsafe_set_none t.elts (elts_index t i)\n\nlet check_index_exn t i =\n if i < 0 || i >= t.length\n then\n Error.raise_s\n (Sexp.message\n \"Queue index out of bounds\"\n [ \"index\", i |> Int.sexp_of_t; \"length\", t.length |> Int.sexp_of_t ])\n;;\n\nlet get t i =\n check_index_exn t i;\n unsafe_get t i\n;;\n\nlet set t i a =\n check_index_exn t i;\n inc_num_mutations t;\n unsafe_set t i a\n;;\n\nlet is_empty t = t.length = 0\nlet length { length; _ } = length\n\nlet ensure_no_mutation t num_mutations =\n if t.num_mutations <> num_mutations\n then\n Error.raise_s\n (Sexp.message\n \"mutation of queue during iteration\"\n [ \"\", t |> sexp_of_t (fun _ -> Sexp.Atom \"_\") ])\n;;\n\nlet compare =\n let rec unsafe_compare_from compare_elt pos ~t1 ~t2 ~len1 ~len2 ~mut1 ~mut2 =\n match pos = len1, pos = len2 with\n | true, true -> 0\n | true, false -> -1\n | false, true -> 1\n | false, false ->\n let x = compare_elt (unsafe_get t1 pos) (unsafe_get t2 pos) in\n ensure_no_mutation t1 mut1;\n ensure_no_mutation t2 mut2;\n (match x with\n | 0 -> unsafe_compare_from compare_elt (pos + 1) ~t1 ~t2 ~len1 ~len2 ~mut1 ~mut2\n | n -> n)\n in\n fun compare_elt t1 t2 ->\n if phys_equal t1 t2\n then 0\n else\n unsafe_compare_from\n compare_elt\n 0\n ~t1\n ~t2\n ~len1:t1.length\n ~len2:t2.length\n ~mut1:t1.num_mutations\n ~mut2:t2.num_mutations\n;;\n\nlet equal =\n let rec unsafe_equal_from equal_elt pos ~t1 ~t2 ~mut1 ~mut2 ~len =\n pos = len\n ||\n let b = equal_elt (unsafe_get t1 pos) (unsafe_get t2 pos) in\n ensure_no_mutation t1 mut1;\n ensure_no_mutation t2 mut2;\n b && unsafe_equal_from equal_elt (pos + 1) ~t1 ~t2 ~mut1 ~mut2 ~len\n in\n fun equal_elt t1 t2 ->\n phys_equal t1 t2\n ||\n let len1 = t1.length in\n let len2 = t2.length in\n len1 = len2\n && unsafe_equal_from\n equal_elt\n 0\n ~t1\n ~t2\n ~len:len1\n ~mut1:t1.num_mutations\n ~mut2:t2.num_mutations\n;;\n\nlet invariant invariant_a t =\n let { num_mutations; mask = _; elts; front; length } = t in\n assert (front >= 0);\n assert (front < capacity t);\n let capacity = capacity t in\n assert (capacity = Option_array.length elts);\n assert (capacity >= 1);\n assert (Int.is_pow2 capacity);\n assert (length >= 0);\n assert (length <= capacity);\n for i = 0 to capacity - 1 do\n if i < t.length\n then (\n invariant_a (unsafe_get t i);\n ensure_no_mutation t num_mutations)\n else assert (not (unsafe_is_set t i))\n done\n;;\n\nlet create (type a) ?capacity () : a t =\n let capacity =\n match capacity with\n | None -> 1\n | Some capacity ->\n if capacity < 0\n then\n Error.raise_s\n (Sexp.message\n \"cannot have queue with negative capacity\"\n [ \"capacity\", capacity |> Int.sexp_of_t ])\n else if capacity = 0\n then 1\n else Int.ceil_pow2 capacity\n in\n { num_mutations = 0\n ; front = 0\n ; mask = capacity - 1\n ; length = 0\n ; elts = Option_array.create ~len:capacity\n }\n;;\n\nlet blit_to_array ~src dst =\n assert (src.length <= Option_array.length dst);\n let front_len = Int.min src.length (capacity src - src.front) in\n let rest_len = src.length - front_len in\n Option_array.blit ~len:front_len ~src:src.elts ~src_pos:src.front ~dst ~dst_pos:0;\n Option_array.blit ~len:rest_len ~src:src.elts ~src_pos:0 ~dst ~dst_pos:front_len\n;;\n\nlet set_capacity t desired_capacity =\n (* We allow arguments less than 1 to [set_capacity], but translate them to 1 to simplify\n the code that relies on the array length being a power of 2. *)\n inc_num_mutations t;\n let new_capacity = Int.ceil_pow2 (max 1 (max desired_capacity t.length)) in\n if new_capacity <> capacity t\n then (\n let dst = Option_array.create ~len:new_capacity in\n blit_to_array ~src:t dst;\n t.front <- 0;\n t.mask <- new_capacity - 1;\n t.elts <- dst)\n;;\n\nlet enqueue t a =\n inc_num_mutations t;\n if t.length = capacity t then set_capacity t (2 * t.length);\n unsafe_set t t.length a;\n t.length <- t.length + 1\n;;\n\nlet dequeue_nonempty t =\n inc_num_mutations t;\n let elts = t.elts in\n let front = t.front in\n let res = Option_array.get_some_exn elts front in\n Option_array.set_none elts front;\n t.front <- elts_index t 1;\n t.length <- t.length - 1;\n res\n;;\n\nlet dequeue_exn t = if is_empty t then raise Caml.Queue.Empty else dequeue_nonempty t\nlet dequeue t = if is_empty t then None else Some (dequeue_nonempty t)\nlet front_nonempty t = Option_array.unsafe_get_some_exn t.elts t.front\nlet last_nonempty t = unsafe_get t (t.length - 1)\nlet peek t = if is_empty t then None else Some (front_nonempty t)\nlet peek_exn t = if is_empty t then raise Caml.Queue.Empty else front_nonempty t\nlet last t = if is_empty t then None else Some (last_nonempty t)\nlet last_exn t = if is_empty t then raise Caml.Queue.Empty else last_nonempty t\n\nlet clear t =\n inc_num_mutations t;\n if t.length > 0\n then (\n for i = 0 to t.length - 1 do\n unsafe_unset t i\n done;\n t.length <- 0;\n t.front <- 0)\n;;\n\nlet blit_transfer ~src ~dst ?len () =\n inc_num_mutations src;\n inc_num_mutations dst;\n let len =\n match len with\n | None -> src.length\n | Some len ->\n if len < 0\n then\n Error.raise_s\n (Sexp.message\n \"Queue.blit_transfer: negative length\"\n [ \"length\", len |> Int.sexp_of_t ]);\n min len src.length\n in\n if len > 0\n then (\n set_capacity dst (max (capacity dst) (dst.length + len));\n let dst_start = dst.front + dst.length in\n for i = 0 to len - 1 do\n (* This is significantly faster than simply [enqueue dst (dequeue_nonempty src)] *)\n let src_i = (src.front + i) land src.mask in\n let dst_i = (dst_start + i) land dst.mask in\n Option_array.unsafe_set_some\n dst.elts\n dst_i\n (Option_array.unsafe_get_some_exn src.elts src_i);\n Option_array.unsafe_set_none src.elts src_i\n done;\n dst.length <- dst.length + len;\n src.front <- (src.front + len) land src.mask;\n src.length <- src.length - len)\n;;\n\nlet enqueue_all t l =\n (* Traversing the list up front to compute its length is probably (but not definitely)\n better than doubling the underlying array size several times for large queues. *)\n set_capacity t (Int.max (capacity t) (t.length + List.length l));\n List.iter l ~f:(fun x -> enqueue t x)\n;;\n\nlet fold t ~init ~f =\n if t.length = 0\n then init\n else (\n let num_mutations = t.num_mutations in\n let r = ref init in\n for i = 0 to t.length - 1 do\n r := f !r (unsafe_get t i);\n ensure_no_mutation t num_mutations\n done;\n !r)\n;;\n\nlet foldi t ~init ~f =\n let i = ref 0 in\n fold t ~init ~f:(fun acc a ->\n let acc = f !i acc a in\n i := !i + 1;\n acc)\n;;\n\n\n(* [iter] is implemented directly because implementing it in terms of [fold] is\n slower. *)\nlet iter t ~f =\n let num_mutations = t.num_mutations in\n for i = 0 to t.length - 1 do\n f (unsafe_get t i);\n ensure_no_mutation t num_mutations\n done\n;;\n\nlet iteri t ~f =\n let num_mutations = t.num_mutations in\n for i = 0 to t.length - 1 do\n f i (unsafe_get t i);\n ensure_no_mutation t num_mutations\n done\n;;\n\nmodule C = Indexed_container.Make (struct\n type nonrec 'a t = 'a t\n\n let fold = fold\n let iter = `Custom iter\n let length = `Custom length\n let foldi = `Custom foldi\n let iteri = `Custom iteri\n end)\n\nlet count = C.count\nlet exists = C.exists\nlet find = C.find\nlet find_map = C.find_map\nlet fold_result = C.fold_result\nlet fold_until = C.fold_until\nlet for_all = C.for_all\nlet max_elt = C.max_elt\nlet mem = C.mem\nlet min_elt = C.min_elt\nlet sum = C.sum\nlet to_list = C.to_list\nlet counti = C.counti\nlet existsi = C.existsi\nlet find_mapi = C.find_mapi\nlet findi = C.findi\nlet for_alli = C.for_alli\n\n\n(* For [concat_map], [filter_map], and [filter], we don't create [t_result] with [t]'s\n capacity because we have no idea how many elements [t_result] will ultimately hold. *)\nlet concat_map t ~f =\n let t_result = create () in\n iter t ~f:(fun a -> List.iter (f a) ~f:(fun b -> enqueue t_result b));\n t_result\n;;\n\nlet concat_mapi t ~f =\n let t_result = create () in\n iteri t ~f:(fun i a -> List.iter (f i a) ~f:(fun b -> enqueue t_result b));\n t_result\n;;\n\nlet filter_map t ~f =\n let t_result = create () in\n iter t ~f:(fun a ->\n match f a with\n | None -> ()\n | Some b -> enqueue t_result b);\n t_result\n;;\n\nlet filter_mapi t ~f =\n let t_result = create () in\n iteri t ~f:(fun i a ->\n match f i a with\n | None -> ()\n | Some b -> enqueue t_result b);\n t_result\n;;\n\nlet filter t ~f =\n let t_result = create () in\n iter t ~f:(fun a -> if f a then enqueue t_result a);\n t_result\n;;\n\nlet filteri t ~f =\n let t_result = create () in\n iteri t ~f:(fun i a -> if f i a then enqueue t_result a);\n t_result\n;;\n\nlet filter_inplace t ~f =\n let t2 = filter t ~f in\n clear t;\n blit_transfer ~src:t2 ~dst:t ()\n;;\n\nlet filteri_inplace t ~f =\n let t2 = filteri t ~f in\n clear t;\n blit_transfer ~src:t2 ~dst:t ()\n;;\n\nlet copy src =\n let dst = create ~capacity:src.length () in\n blit_to_array ~src dst.elts;\n dst.length <- src.length;\n dst\n;;\n\nlet of_list l =\n (* Traversing the list up front to compute its length is probably (but not definitely)\n better than doubling the underlying array size several times for large queues. *)\n let t = create ~capacity:(List.length l) () in\n List.iter l ~f:(fun x -> enqueue t x);\n t\n;;\n\n(* The queue [t] returned by [create] will have [t.length = 0], [t.front = 0], and\n [capacity t = Int.ceil_pow2 len]. So, we only have to set [t.length] to [len] after\n the blit to maintain all the invariants: [t.length] is equal to the number of elements\n in the queue, [t.front] is the array index of the first element in the queue, and\n [capacity t = Option_array.length t.elts]. *)\nlet init len ~f =\n if len < 0\n then\n Error.raise_s\n (Sexp.message \"Queue.init: negative length\" [ \"length\", len |> Int.sexp_of_t ]);\n let t = create ~capacity:len () in\n assert (Option_array.length t.elts >= len);\n for i = 0 to len - 1 do\n Option_array.unsafe_set_some t.elts i (f i)\n done;\n t.length <- len;\n t\n;;\n\nlet of_array a = init (Array.length a) ~f:(Array.unsafe_get a)\nlet to_array t = Array.init t.length ~f:(fun i -> unsafe_get t i)\n\nlet map ta ~f =\n let num_mutations = ta.num_mutations in\n let tb = create ~capacity:ta.length () in\n tb.length <- ta.length;\n for i = 0 to ta.length - 1 do\n let b = f (unsafe_get ta i) in\n ensure_no_mutation ta num_mutations;\n Option_array.unsafe_set_some tb.elts i b\n done;\n tb\n;;\n\nlet mapi t ~f =\n let i = ref 0 in\n map t ~f:(fun a ->\n let result = f !i a in\n i := !i + 1;\n result)\n;;\n\nlet singleton x =\n let t = create () in\n enqueue t x;\n t\n;;\n\nlet sexp_of_t sexp_of_a t = to_list t |> List.sexp_of_t sexp_of_a\nlet t_of_sexp a_of_sexp sexp = List.t_of_sexp a_of_sexp sexp |> of_list\n","open! Import\n\nmodule T = struct\n type t = |\n\n let unreachable_code = function\n | (_ : t) -> .\n ;;\n\n let all = []\n let hash_fold_t _ t = unreachable_code t\n let hash = unreachable_code\n let compare a _ = unreachable_code a\n let sexp_of_t = unreachable_code\n let t_of_sexp sexp = Sexplib.Conv_error.empty_type \"Base.Nothing.t\" sexp\n let to_string = unreachable_code\n let of_string (_ : string) = failwith \"Base.Nothing.of_string: not supported\"\nend\n\ninclude T\n\ninclude Identifiable.Make (struct\n include T\n\n let module_name = \"Base.Nothing\"\n end)\n","(** [never_returns] should be used as the return type of functions that don't return and\n might block forever, rather than ['a] or [_]. This forces callers of such functions\n to have a call to [never_returns] at the call site, which makes it clear to readers\n what's going on. We do not intend to use this type for functions such as [failwithf]\n that always raise an exception. *)\n\nopen! Import\n\ntype never_returns = Nothing.t [@@deriving sexp_of]\n\nlet never_returns = Nothing.unreachable_code\n","open! Import\nopen! Caml.Nativeint\ninclude Nativeint_replace_polymorphic_compare\n\nmodule T = struct\n type t = nativeint [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_nativeint\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_nativeint in\n fun x -> func x\n ;;\n\n let t_of_sexp = (nativeint_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_nativeint : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"nativeint\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ nativeint_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"nativeint.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare = Nativeint_replace_polymorphic_compare.compare\n let to_string = to_string\n let of_string = of_string\nend\n\ninclude T\ninclude Comparator.Make (T)\n\ninclude Comparable.Validate_with_zero (struct\n include T\n\n let zero = zero\n end)\n\nmodule Conv = Int_conversions\ninclude Conv.Make (T)\n\ninclude Conv.Make_hex (struct\n open Nativeint_replace_polymorphic_compare\n\n type t = nativeint [@@deriving_inline compare, hash]\n\n let compare = (compare_nativeint : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_nativeint\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_nativeint in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let zero = zero\n let neg = neg\n let ( < ) = ( < )\n let to_string i = Printf.sprintf \"%nx\" i\n let of_string s = Caml.Scanf.sscanf s \"%nx\" Fn.id\n let module_name = \"Base.Nativeint.Hex\"\n end)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Base.Nativeint\"\n end)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! Nativeint_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet num_bits = Word_size.num_bits Word_size.word_size\nlet float_lower_bound = Float0.lower_bound_for_int num_bits\nlet float_upper_bound = Float0.upper_bound_for_int num_bits\nlet shift_right_logical = shift_right_logical\nlet shift_right = shift_right\nlet shift_left = shift_left\nlet bit_not = lognot\nlet bit_xor = logxor\nlet bit_or = logor\nlet bit_and = logand\nlet min_value = min_int\nlet max_value = max_int\nlet abs = abs\nlet pred = pred\nlet succ = succ\nlet rem = rem\nlet neg = neg\nlet minus_one = minus_one\nlet one = one\nlet zero = zero\nlet to_float = to_float\nlet of_float_unchecked = of_float\n\nlet of_float f =\n if Float_replace_polymorphic_compare.( >= ) f float_lower_bound\n && Float_replace_polymorphic_compare.( <= ) f float_upper_bound\n then of_float f\n else\n Printf.invalid_argf\n \"Nativeint.of_float: argument (%f) is out of range or NaN\"\n (Float0.box f)\n ()\n;;\n\nmodule Pow2 = struct\n open! Import\n open Nativeint_replace_polymorphic_compare\n module Sys = Sys0\n\n let raise_s = Error.raise_s\n\n let non_positive_argument () =\n Printf.invalid_argf \"argument must be strictly positive\" ()\n ;;\n\n let ( lor ) = Caml.Nativeint.logor\n let ( lsr ) = Caml.Nativeint.shift_right_logical\n let ( land ) = Caml.Nativeint.logand\n\n (** \"ceiling power of 2\" - Least power of 2 greater than or equal to x. *)\n let ceil_pow2 (x : nativeint) =\n if x <= 0n then non_positive_argument ();\n let x = Caml.Nativeint.pred x in\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n (* The next line is superfluous on 32-bit architectures, but it's faster to do it\n anyway than to branch *)\n let x = x lor (x lsr 32) in\n Caml.Nativeint.succ x\n ;;\n\n (** \"floor power of 2\" - Largest power of 2 less than or equal to x. *)\n let floor_pow2 x =\n if x <= 0n then non_positive_argument ();\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n let x = x lor (x lsr 32) in\n Caml.Nativeint.sub x (x lsr 1)\n ;;\n\n let is_pow2 x =\n if x <= 0n then non_positive_argument ();\n x land Caml.Nativeint.pred x = 0n\n ;;\n\n (* C stubs for nativeint clz and ctz to use the CLZ/BSR/CTZ/BSF instruction where possible *)\n external clz\n : (nativeint[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_nativeint_clz\" \"Base_int_math_nativeint_clz_unboxed\"\n [@@noalloc]\n\n external ctz\n : (nativeint[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_nativeint_ctz\" \"Base_int_math_nativeint_ctz_unboxed\"\n [@@noalloc]\n\n (** Hacker's Delight Second Edition p106 *)\n let floor_log2 i =\n if Poly.( <= ) i Caml.Nativeint.zero\n then\n raise_s\n (Sexp.message\n \"[Nativeint.floor_log2] got invalid input\"\n [ \"\", sexp_of_nativeint i ]);\n num_bits - 1 - clz i\n ;;\n\n (** Hacker's Delight Second Edition p106 *)\n let ceil_log2 i =\n if Poly.( <= ) i Caml.Nativeint.zero\n then\n raise_s\n (Sexp.message\n \"[Nativeint.ceil_log2] got invalid input\"\n [ \"\", sexp_of_nativeint i ]);\n if Caml.Nativeint.equal i Caml.Nativeint.one\n then 0\n else num_bits - clz (Caml.Nativeint.pred i)\n ;;\nend\n\ninclude Pow2\n\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet ( / ) = div\nlet ( * ) = mul\nlet ( - ) = sub\nlet ( + ) = add\nlet ( ~- ) = neg\nlet incr r = r := !r + one\nlet decr r = r := !r - one\nlet of_nativeint t = t\nlet of_nativeint_exn = of_nativeint\nlet to_nativeint t = t\nlet to_nativeint_exn = to_nativeint\nlet popcount = Popcount.nativeint_popcount\nlet of_int = Conv.int_to_nativeint\nlet of_int_exn = of_int\nlet to_int = Conv.nativeint_to_int\nlet to_int_exn = Conv.nativeint_to_int_exn\nlet to_int_trunc = Conv.nativeint_to_int_trunc\nlet of_int32 = Conv.int32_to_nativeint\nlet of_int32_exn = of_int32\nlet to_int32 = Conv.nativeint_to_int32\nlet to_int32_exn = Conv.nativeint_to_int32_exn\nlet to_int32_trunc = Conv.nativeint_to_int32_trunc\nlet of_int64 = Conv.int64_to_nativeint\nlet of_int64_exn = Conv.int64_to_nativeint_exn\nlet of_int64_trunc = Conv.int64_to_nativeint_trunc\nlet to_int64 = Conv.nativeint_to_int64\nlet pow b e = of_int_exn (Int_math.Private.int_pow (to_int_exn b) (to_int_exn e))\nlet ( ** ) b e = pow b e\n\nmodule Pre_O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Nativeint_replace_polymorphic_compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int_exn = of_int_exn\nend\n\nmodule O = struct\n include Pre_O\n\n include Int_math.Make (struct\n type nonrec t = t\n\n include Pre_O\n\n let rem = rem\n let to_float = to_float\n let of_float = of_float\n let of_string = T.of_string\n let to_string = T.to_string\n end)\n\n let ( land ) = bit_and\n let ( lor ) = bit_or\n let ( lxor ) = bit_xor\n let lnot = bit_not\n let ( lsl ) = shift_left\n let ( asr ) = shift_right\n let ( lsr ) = shift_right_logical\nend\n\ninclude O\n\n(* [Nativeint] and [Nativeint.O] agree value-wise *)\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Nativeint_replace_polymorphic_compare\n\nexternal bswap : t -> t = \"%bswap_native\"\n","(***********************************************************************)\n(* *)\n(* Objective Caml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. All rights reserved. This file is distributed *)\n(* under the terms of the Apache 2.0 license. See ../THIRD-PARTY.txt *)\n(* for details. *)\n(* *)\n(***********************************************************************)\n\nopen! Import\nmodule List = List0\n\ninclude (\n Map_intf :\n sig\n module Or_duplicate = Map_intf.Or_duplicate\n module Continue_or_stop = Map_intf.Continue_or_stop\n module With_comparator = Map_intf.With_comparator\n module With_first_class_module = Map_intf.With_first_class_module\n module Without_comparator = Map_intf.Without_comparator\n\n (* The module susbstitutions below are needed for older versions of OCaml\n (before 4.07), because back then [module type of] did not keep module\n aliases. *)\n\n include module type of struct\n include Map_intf\n end\n with module Finished_or_unfinished := Map_intf.Finished_or_unfinished\n and module Or_duplicate := Or_duplicate\n and module Continue_or_stop := Continue_or_stop\n and module With_comparator := With_comparator\n and module With_first_class_module := With_first_class_module\n and module Without_comparator := Without_comparator\n end)\n\nmodule Finished_or_unfinished = struct\n include Map_intf.Finished_or_unfinished\n\n (* These two functions are tested in [test_map.ml] to make sure our use of\n [Caml.Obj.magic] is correct and safe. *)\n let of_continue_or_stop : Continue_or_stop.t -> t = Caml.Obj.magic\n let to_continue_or_stop : t -> Continue_or_stop.t = Caml.Obj.magic\nend\n\nlet with_return = With_return.with_return\n\nexception Duplicate [@@deriving_inline sexp]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add [%extension_constructor Duplicate] (function\n | Duplicate -> Ppx_sexp_conv_lib.Sexp.Atom \"map.ml.Duplicate\"\n | _ -> assert false)\n;;\n\n[@@@end]\n\nmodule Tree0 = struct\n type ('k, 'v) t =\n | Empty\n | Leaf of 'k * 'v\n | Node of ('k, 'v) t * 'k * 'v * ('k, 'v) t * int\n\n type ('k, 'v) tree = ('k, 'v) t\n\n let height = function\n | Empty -> 0\n | Leaf _ -> 1\n | Node (_, _, _, _, h) -> h\n ;;\n\n let invariants =\n let in_range lower upper compare_key k =\n (match lower with\n | None -> true\n | Some lower -> compare_key lower k < 0)\n &&\n match upper with\n | None -> true\n | Some upper -> compare_key k upper < 0\n in\n let rec loop lower upper compare_key t =\n match t with\n | Empty -> true\n | Leaf (k, _) -> in_range lower upper compare_key k\n | Node (l, k, _, r, h) ->\n let hl = height l\n and hr = height r in\n abs (hl - hr) <= 2\n && h = max hl hr + 1\n && in_range lower upper compare_key k\n && loop lower (Some k) compare_key l\n && loop (Some k) upper compare_key r\n in\n fun t ~compare_key -> loop None None compare_key t\n ;;\n\n (* precondition: |height(l) - height(r)| <= 2 *)\n let create l x d r =\n let hl = height l\n and hr = height r in\n if hl = 0 && hr = 0\n then Leaf (x, d)\n else Node (l, x, d, r, if hl >= hr then hl + 1 else hr + 1)\n ;;\n\n let singleton key data = Leaf (key, data)\n\n (* We must call [f] with increasing indexes, because the bin_prot reader in\n Core_kernel.Map needs it. *)\n let of_increasing_iterator_unchecked ~len ~f =\n let rec loop n ~f i : (_, _) t =\n match n with\n | 0 -> Empty\n | 1 ->\n let k, v = f i in\n Leaf (k, v)\n | 2 ->\n let kl, vl = f i in\n let k, v = f (i + 1) in\n Node (Leaf (kl, vl), k, v, Empty, 2)\n | 3 ->\n let kl, vl = f i in\n let k, v = f (i + 1) in\n let kr, vr = f (i + 2) in\n Node (Leaf (kl, vl), k, v, Leaf (kr, vr), 2)\n | n ->\n let left_length = n lsr 1 in\n let right_length = n - left_length - 1 in\n let left = loop left_length ~f i in\n let k, v = f (i + left_length) in\n let right = loop right_length ~f (i + left_length + 1) in\n create left k v right\n in\n loop len ~f 0\n ;;\n\n let of_sorted_array_unchecked array ~compare_key =\n let array_length = Array.length array in\n let next =\n if array_length < 2\n ||\n let k0, _ = array.(0) in\n let k1, _ = array.(1) in\n compare_key k0 k1 < 0\n then fun i -> array.(i)\n else fun i -> array.(array_length - 1 - i)\n in\n of_increasing_iterator_unchecked ~len:array_length ~f:next, array_length\n ;;\n\n let of_sorted_array array ~compare_key =\n match array with\n | [||] | [| _ |] -> Result.Ok (of_sorted_array_unchecked array ~compare_key)\n | _ ->\n with_return (fun r ->\n let increasing =\n match compare_key (fst array.(0)) (fst array.(1)) with\n | 0 ->\n r.return (Or_error.error_string \"of_sorted_array: duplicated elements\")\n | i -> i < 0\n in\n for i = 1 to Array.length array - 2 do\n match compare_key (fst array.(i)) (fst array.(i + 1)) with\n | 0 ->\n r.return (Or_error.error_string \"of_sorted_array: duplicated elements\")\n | i ->\n if Poly.( <> ) (i < 0) increasing\n then\n r.return\n (Or_error.error_string \"of_sorted_array: elements are not ordered\")\n done;\n Result.Ok (of_sorted_array_unchecked array ~compare_key))\n ;;\n\n (* precondition: |height(l) - height(r)| <= 3 *)\n let bal l x d r =\n let hl = height l in\n let hr = height r in\n if hl > hr + 2\n then (\n match l with\n | Empty -> invalid_arg \"Map.bal\"\n | Leaf _ -> assert false (* height(Leaf) = 1 && 1 is not larger than hr + 2 *)\n | Node (ll, lv, ld, lr, _) ->\n if height ll >= height lr\n then create ll lv ld (create lr x d r)\n else (\n match lr with\n | Empty -> invalid_arg \"Map.bal\"\n | Leaf (lrv, lrd) ->\n create (create ll lv ld Empty) lrv lrd (create Empty x d r)\n | Node (lrl, lrv, lrd, lrr, _) ->\n create (create ll lv ld lrl) lrv lrd (create lrr x d r)))\n else if hr > hl + 2\n then (\n match r with\n | Empty -> invalid_arg \"Map.bal\"\n | Leaf _ -> assert false (* height(Leaf) = 1 && 1 is not larger than hl + 2 *)\n | Node (rl, rv, rd, rr, _) ->\n if height rr >= height rl\n then create (create l x d rl) rv rd rr\n else (\n match rl with\n | Empty -> invalid_arg \"Map.bal\"\n | Leaf (rlv, rld) ->\n create (create l x d Empty) rlv rld (create Empty rv rd rr)\n | Node (rll, rlv, rld, rlr, _) ->\n create (create l x d rll) rlv rld (create rlr rv rd rr)))\n else create l x d r\n ;;\n\n let empty = Empty\n\n let is_empty = function\n | Empty -> true\n | _ -> false\n ;;\n\n let raise_key_already_present ~key ~sexp_of_key =\n Error.raise_s\n (Sexp.message \"[Map.add_exn] got key already present\" [ \"key\", key |> sexp_of_key ])\n ;;\n\n module Add_or_set = struct\n type t =\n | Add_exn_internal\n | Add_exn\n | Set\n end\n\n\n let rec find_and_add_or_set\n t\n ~length\n ~key:x\n ~data\n ~compare_key\n ~sexp_of_key\n ~(add_or_set : Add_or_set.t)\n =\n match t with\n | Empty -> Leaf (x, data), length + 1\n | Leaf (v, d) ->\n let c = compare_key x v in\n if c = 0\n then (\n match add_or_set with\n | Add_exn_internal -> Exn.raise_without_backtrace Duplicate\n | Add_exn -> raise_key_already_present ~key:x ~sexp_of_key\n | Set -> Leaf (x, data), length)\n else if c < 0\n then Node (Leaf (x, data), v, d, Empty, 2), length + 1\n else Node (Empty, v, d, Leaf (x, data), 2), length + 1\n | Node (l, v, d, r, h) ->\n let c = compare_key x v in\n if c = 0\n then (\n match add_or_set with\n | Add_exn_internal -> Exn.raise_without_backtrace Duplicate\n | Add_exn -> raise_key_already_present ~key:x ~sexp_of_key\n | Set -> Node (l, x, data, r, h), length)\n else if c < 0\n then (\n let l, length =\n find_and_add_or_set\n ~length\n ~key:x\n ~data\n l\n ~compare_key\n ~sexp_of_key\n ~add_or_set\n in\n bal l v d r, length)\n else (\n let r, length =\n find_and_add_or_set\n ~length\n ~key:x\n ~data\n r\n ~compare_key\n ~sexp_of_key\n ~add_or_set\n in\n bal l v d r, length)\n ;;\n\n let add_exn t ~length ~key ~data ~compare_key ~sexp_of_key =\n find_and_add_or_set\n t\n ~length\n ~key\n ~data\n ~compare_key\n ~sexp_of_key\n ~add_or_set:Add_exn\n ;;\n\n let add_exn_internal t ~length ~key ~data ~compare_key ~sexp_of_key =\n find_and_add_or_set\n t\n ~length\n ~key\n ~data\n ~compare_key\n ~sexp_of_key\n ~add_or_set:Add_exn_internal\n ;;\n\n let set t ~length ~key ~data ~compare_key =\n find_and_add_or_set\n t\n ~length\n ~key\n ~data\n ~compare_key\n ~sexp_of_key:(fun _ -> List [])\n ~add_or_set:Set\n ;;\n\n let set' t key data ~compare_key = fst (set t ~length:0 ~key ~data ~compare_key)\n\n module Build_increasing = struct\n module Fragment = struct\n type nonrec ('k, 'v) t =\n { left_subtree : ('k, 'v) t\n ; key : 'k\n ; data : 'v\n }\n\n let singleton_to_tree_exn = function\n | { left_subtree = Empty; key; data } -> singleton key data\n | _ -> failwith \"Map.singleton_to_tree_exn: not a singleton\"\n ;;\n\n let singleton ~key ~data = { left_subtree = Empty; key; data }\n\n (* precondition: |height(l.left_subtree) - height(r)| <= 2,\n max_key(l) < min_key(r)\n *)\n let collapse l r = create l.left_subtree l.key l.data r\n\n (* precondition: |height(l.left_subtree) - height(r.left_subtree)| <= 2,\n max_key(l) < min_key(r)\n *)\n let join l r = { r with left_subtree = collapse l r.left_subtree }\n let max_key t = t.key\n end\n\n (** Build trees from singletons in a balanced way by using skew binary encoding.\n Each level contains trees of the same height, consecutive levels have consecutive\n heights. There are no gaps. The first level are single keys.\n *)\n type ('k, 'v) t =\n | Zero of unit\n (* [unit] to make pattern matching faster *)\n | One of ('k, 'v) t * ('k, 'v) Fragment.t\n | Two of ('k, 'v) t * ('k, 'v) Fragment.t * ('k, 'v) Fragment.t\n\n let empty = Zero ()\n\n let add_unchecked =\n let rec go t x =\n match t with\n | Zero () -> One (t, x)\n | One (t, y) -> Two (t, y, x)\n | Two (t, z, y) -> One (go t (Fragment.join z y), x)\n in\n fun t ~key ~data -> go t (Fragment.singleton ~key ~data)\n ;;\n\n let to_tree =\n let rec go t r =\n match t with\n | Zero () -> r\n | One (t, l) -> go t (Fragment.collapse l r)\n | Two (t, ll, l) -> go t (Fragment.collapse (Fragment.join ll l) r)\n in\n function\n | Zero () -> Empty\n | One (t, r) -> go t (Fragment.singleton_to_tree_exn r)\n | Two (t, l, r) -> go (One (t, l)) (Fragment.singleton_to_tree_exn r)\n ;;\n\n let max_key = function\n | Zero () -> None\n | One (_, r) | Two (_, _, r) -> Some (Fragment.max_key r)\n ;;\n end\n\n let of_increasing_sequence seq ~compare_key =\n with_return (fun { return } ->\n let builder, length =\n Sequence.fold\n seq\n ~init:(Build_increasing.empty, 0)\n ~f:(fun (builder, length) (key, data) ->\n match Build_increasing.max_key builder with\n | Some prev_key when compare_key prev_key key >= 0 ->\n return\n (Or_error.error_string \"of_increasing_sequence: non-increasing key\")\n | _ -> Build_increasing.add_unchecked builder ~key ~data, length + 1)\n in\n Ok (Build_increasing.to_tree builder, length))\n ;;\n\n (* Like [bal] but allows any difference in height between [l] and [r].\n\n O(|height l - height r|) *)\n let rec join l k d r ~compare_key =\n match l, r with\n | Empty, _ -> set' r k d ~compare_key\n | _, Empty -> set' l k d ~compare_key\n | Leaf (lk, ld), _ -> set' (set' r k d ~compare_key) lk ld ~compare_key\n | _, Leaf (rk, rd) -> set' (set' l k d ~compare_key) rk rd ~compare_key\n | Node (ll, lk, ld, lr, lh), Node (rl, rk, rd, rr, rh) ->\n (* [bal] requires height difference <= 3. *)\n if lh > rh + 3\n (* [height lr >= height r],\n therefore [height (join lr k d r ...)] is [height rl + 1] or [height rl]\n therefore the height difference with [ll] will be <= 3 *)\n then bal ll lk ld (join lr k d r ~compare_key)\n else if rh > lh + 3\n then bal (join l k d rl ~compare_key) rk rd rr\n else bal l k d r\n ;;\n\n let rec split t x ~compare_key =\n match t with\n | Empty -> Empty, None, Empty\n | Leaf (k, d) ->\n let cmp = compare_key x k in\n if cmp = 0\n then Empty, Some (k, d), Empty\n else if cmp < 0\n then Empty, None, t\n else t, None, Empty\n | Node (l, k, d, r, _) ->\n let cmp = compare_key x k in\n if cmp = 0\n then l, Some (k, d), r\n else if cmp < 0\n then (\n let ll, maybe, lr = split l x ~compare_key in\n ll, maybe, join lr k d r ~compare_key)\n else (\n let rl, maybe, rr = split r x ~compare_key in\n join l k d rl ~compare_key, maybe, rr)\n ;;\n\n let split_and_reinsert_boundary t ~into x ~compare_key =\n let left, boundary_opt, right = split t x ~compare_key in\n match boundary_opt with\n | None -> left, right\n | Some (key, data) ->\n let insert_into tree = fst (set tree ~key ~data ~length:0 ~compare_key) in\n (match into with\n | `Left -> insert_into left, right\n | `Right -> left, insert_into right)\n ;;\n\n let split_range\n t\n ~(lower_bound : 'a Maybe_bound.t)\n ~(upper_bound : 'a Maybe_bound.t)\n ~compare_key\n =\n if Maybe_bound.bounds_crossed\n ~compare:compare_key\n ~lower:lower_bound\n ~upper:upper_bound\n then empty, empty, empty\n else (\n let left, mid_and_right =\n match lower_bound with\n | Unbounded -> empty, t\n | Incl lb -> split_and_reinsert_boundary ~into:`Right t lb ~compare_key\n | Excl lb -> split_and_reinsert_boundary ~into:`Left t lb ~compare_key\n in\n let mid, right =\n match upper_bound with\n | Unbounded -> mid_and_right, empty\n | Incl lb ->\n split_and_reinsert_boundary ~into:`Left mid_and_right lb ~compare_key\n | Excl lb ->\n split_and_reinsert_boundary ~into:`Right mid_and_right lb ~compare_key\n in\n left, mid, right)\n ;;\n\n let rec find t x ~compare_key =\n match t with\n | Empty -> None\n | Leaf (v, d) -> if compare_key x v = 0 then Some d else None\n | Node (l, v, d, r, _) ->\n let c = compare_key x v in\n if c = 0 then Some d else find (if c < 0 then l else r) x ~compare_key\n ;;\n\n let add_multi t ~length ~key ~data ~compare_key =\n let data = data :: Option.value (find t key ~compare_key) ~default:[] in\n set ~length ~key ~data t ~compare_key\n ;;\n\n let find_multi t x ~compare_key =\n match find t x ~compare_key with\n | None -> []\n | Some l -> l\n ;;\n\n let find_exn =\n let if_not_found key ~sexp_of_key =\n raise (Not_found_s (List [ Atom \"Map.find_exn: not found\"; sexp_of_key key ]))\n in\n let rec find_exn t x ~compare_key ~sexp_of_key =\n match t with\n | Empty -> if_not_found x ~sexp_of_key\n | Leaf (v, d) -> if compare_key x v = 0 then d else if_not_found x ~sexp_of_key\n | Node (l, v, d, r, _) ->\n let c = compare_key x v in\n if c = 0\n then d\n else find_exn (if c < 0 then l else r) x ~compare_key ~sexp_of_key\n in\n (* named to preserve symbol in compiled binary *)\n find_exn\n ;;\n\n let mem t x ~compare_key = Option.is_some (find t x ~compare_key)\n\n let rec min_elt = function\n | Empty -> None\n | Leaf (k, d) -> Some (k, d)\n | Node (Empty, k, d, _, _) -> Some (k, d)\n | Node (l, _, _, _, _) -> min_elt l\n ;;\n\n exception Map_min_elt_exn_of_empty_map [@@deriving_inline sexp]\n\n let () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Map_min_elt_exn_of_empty_map]\n (function\n | Map_min_elt_exn_of_empty_map ->\n Ppx_sexp_conv_lib.Sexp.Atom \"map.ml.Tree0.Map_min_elt_exn_of_empty_map\"\n | _ -> assert false)\n ;;\n\n [@@@end]\n\n exception Map_max_elt_exn_of_empty_map [@@deriving_inline sexp]\n\n let () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Map_max_elt_exn_of_empty_map]\n (function\n | Map_max_elt_exn_of_empty_map ->\n Ppx_sexp_conv_lib.Sexp.Atom \"map.ml.Tree0.Map_max_elt_exn_of_empty_map\"\n | _ -> assert false)\n ;;\n\n [@@@end]\n\n let min_elt_exn t =\n match min_elt t with\n | None -> raise Map_min_elt_exn_of_empty_map\n | Some v -> v\n ;;\n\n let rec max_elt = function\n | Empty -> None\n | Leaf (k, d) -> Some (k, d)\n | Node (_, k, d, Empty, _) -> Some (k, d)\n | Node (_, _, _, r, _) -> max_elt r\n ;;\n\n let max_elt_exn t =\n match max_elt t with\n | None -> raise Map_max_elt_exn_of_empty_map\n | Some v -> v\n ;;\n\n let rec remove_min_elt t =\n match t with\n | Empty -> invalid_arg \"Map.remove_min_elt\"\n | Leaf _ -> Empty\n | Node (Empty, _, _, r, _) -> r\n | Node (l, x, d, r, _) -> bal (remove_min_elt l) x d r\n ;;\n\n let append ~lower_part ~upper_part ~compare_key =\n match max_elt lower_part, min_elt upper_part with\n | None, _ -> `Ok upper_part\n | _, None -> `Ok lower_part\n | Some (max_lower, _), Some (min_upper, v) when compare_key max_lower min_upper < 0\n ->\n let upper_part_without_min = remove_min_elt upper_part in\n `Ok (join ~compare_key lower_part min_upper v upper_part_without_min)\n | _ -> `Overlapping_key_ranges\n ;;\n\n let fold_range_inclusive =\n (* This assumes that min <= max, which is checked by the outer function. *)\n let rec go t ~min ~max ~init ~f ~compare_key =\n match t with\n | Empty -> init\n | Leaf (k, d) ->\n if compare_key k min < 0 || compare_key k max > 0\n then (* k < min || k > max *)\n init\n else f ~key:k ~data:d init\n | Node (l, k, d, r, _) ->\n let c_min = compare_key k min in\n if c_min < 0\n then\n (* if k < min, then this node and its left branch are outside our range *)\n go r ~min ~max ~init ~f ~compare_key\n else if c_min = 0\n then\n (* if k = min, then this node's left branch is outside our range *)\n go r ~min ~max ~init:(f ~key:k ~data:d init) ~f ~compare_key\n else (\n (* k > min *)\n let z = go l ~min ~max ~init ~f ~compare_key in\n let c_max = compare_key k max in\n (* if k > max, we're done *)\n if c_max > 0\n then z\n else (\n let z = f ~key:k ~data:d z in\n (* if k = max, then we fold in this one last value and we're done *)\n if c_max = 0 then z else go r ~min ~max ~init:z ~f ~compare_key))\n in\n fun t ~min ~max ~init ~f ~compare_key ->\n if compare_key min max <= 0 then go t ~min ~max ~init ~f ~compare_key else init\n ;;\n\n let range_to_alist t ~min ~max ~compare_key =\n List.rev\n (fold_range_inclusive\n t\n ~min\n ~max\n ~init:[]\n ~f:(fun ~key ~data l -> (key, data) :: l)\n ~compare_key)\n ;;\n\n let concat_unchecked t1 t2 =\n match t1, t2 with\n | Empty, t -> t\n | t, Empty -> t\n | _, _ ->\n let x, d = min_elt_exn t2 in\n bal t1 x d (remove_min_elt t2)\n ;;\n\n let rec remove t x ~length ~compare_key =\n match t with\n | Empty -> Empty, length\n | Leaf (v, _) -> if compare_key x v = 0 then Empty, length - 1 else t, length\n | Node (l, v, d, r, _) ->\n let c = compare_key x v in\n if c = 0\n then concat_unchecked l r, length - 1\n else if c < 0\n then (\n let l, length = remove l x ~length ~compare_key in\n bal l v d r, length)\n else (\n let r, length = remove r x ~length ~compare_key in\n bal l v d r, length)\n ;;\n\n (* Use exception to avoid tree-rebuild in no-op case *)\n exception Change_no_op\n\n let change t key ~f ~length ~compare_key =\n let rec change_core t key f =\n match t with\n | Empty ->\n (match f None with\n | None -> raise Change_no_op (* equivalent to returning: Empty *)\n | Some data -> Leaf (key, data), length + 1)\n | Leaf (v, d) ->\n let c = compare_key key v in\n if c = 0\n then (\n match f (Some d) with\n | None -> Empty, length - 1\n | Some d' -> Leaf (v, d'), length)\n else if c < 0\n then (\n let l, length = change_core Empty key f in\n bal l v d Empty, length)\n else (\n let r, length = change_core Empty key f in\n bal Empty v d r, length)\n | Node (l, v, d, r, h) ->\n let c = compare_key key v in\n if c = 0\n then (\n match f (Some d) with\n | None -> concat_unchecked l r, length - 1\n | Some data -> Node (l, key, data, r, h), length)\n else if c < 0\n then (\n let l, length = change_core l key f in\n bal l v d r, length)\n else (\n let r, length = change_core r key f in\n bal l v d r, length)\n in\n try change_core t key f with\n | Change_no_op -> t, length\n ;;\n\n let update t key ~f ~length ~compare_key =\n let rec update_core t key f =\n match t with\n | Empty ->\n let data = f None in\n Leaf (key, data), length + 1\n | Leaf (v, d) ->\n let c = compare_key key v in\n if c = 0\n then (\n let d' = f (Some d) in\n Leaf (v, d'), length)\n else if c < 0\n then (\n let l, length = update_core Empty key f in\n bal l v d Empty, length)\n else (\n let r, length = update_core Empty key f in\n bal Empty v d r, length)\n | Node (l, v, d, r, h) ->\n let c = compare_key key v in\n if c = 0\n then (\n let data = f (Some d) in\n Node (l, key, data, r, h), length)\n else if c < 0\n then (\n let l, length = update_core l key f in\n bal l v d r, length)\n else (\n let r, length = update_core r key f in\n bal l v d r, length)\n in\n update_core t key f\n ;;\n\n let remove_multi t key ~length ~compare_key =\n change t key ~length ~compare_key ~f:(function\n | None | Some ([] | [ _ ]) -> None\n | Some (_ :: (_ :: _ as non_empty_tail)) -> Some non_empty_tail)\n ;;\n\n let rec iter_keys t ~f =\n match t with\n | Empty -> ()\n | Leaf (v, _) -> f v\n | Node (l, v, _, r, _) ->\n iter_keys ~f l;\n f v;\n iter_keys ~f r\n ;;\n\n let rec iter t ~f =\n match t with\n | Empty -> ()\n | Leaf (_, d) -> f d\n | Node (l, _, d, r, _) ->\n iter ~f l;\n f d;\n iter ~f r\n ;;\n\n let rec iteri t ~f =\n match t with\n | Empty -> ()\n | Leaf (v, d) -> f ~key:v ~data:d\n | Node (l, v, d, r, _) ->\n iteri ~f l;\n f ~key:v ~data:d;\n iteri ~f r\n ;;\n\n let iteri_until =\n let rec iteri_until_loop t ~f : Continue_or_stop.t =\n match t with\n | Empty -> Continue\n | Leaf (v, d) -> f ~key:v ~data:d\n | Node (l, v, d, r, _) ->\n (match iteri_until_loop ~f l with\n | Stop -> Stop\n | Continue ->\n (match f ~key:v ~data:d with\n | Stop -> Stop\n | Continue -> iteri_until_loop ~f r))\n in\n fun t ~f -> Finished_or_unfinished.of_continue_or_stop (iteri_until_loop t ~f)\n ;;\n\n let rec map t ~f =\n match t with\n | Empty -> Empty\n | Leaf (v, d) -> Leaf (v, f d)\n | Node (l, v, d, r, h) ->\n let l' = map ~f l in\n let d' = f d in\n let r' = map ~f r in\n Node (l', v, d', r', h)\n ;;\n\n let rec mapi t ~f =\n match t with\n | Empty -> Empty\n | Leaf (v, d) -> Leaf (v, f ~key:v ~data:d)\n | Node (l, v, d, r, h) ->\n let l' = mapi ~f l in\n let d' = f ~key:v ~data:d in\n let r' = mapi ~f r in\n Node (l', v, d', r', h)\n ;;\n\n let rec fold t ~init:accu ~f =\n match t with\n | Empty -> accu\n | Leaf (v, d) -> f ~key:v ~data:d accu\n | Node (l, v, d, r, _) -> fold ~f r ~init:(f ~key:v ~data:d (fold ~f l ~init:accu))\n ;;\n\n let rec fold_right t ~init:accu ~f =\n match t with\n | Empty -> accu\n | Leaf (v, d) -> f ~key:v ~data:d accu\n | Node (l, v, d, r, _) ->\n fold_right ~f l ~init:(f ~key:v ~data:d (fold_right ~f r ~init:accu))\n ;;\n\n let filter_keys t ~f ~compare_key =\n fold ~init:(Empty, 0) t ~f:(fun ~key ~data (accu, length) ->\n if f key then set ~length ~key ~data accu ~compare_key else accu, length)\n ;;\n\n\n let filter t ~f ~compare_key =\n fold ~init:(Empty, 0) t ~f:(fun ~key ~data (accu, length) ->\n if f data then set ~length ~key ~data accu ~compare_key else accu, length)\n ;;\n\n let filteri t ~f ~compare_key =\n fold ~init:(Empty, 0) t ~f:(fun ~key ~data (accu, length) ->\n if f ~key ~data then set ~length ~key ~data accu ~compare_key else accu, length)\n ;;\n\n let filter_map t ~f ~compare_key =\n fold ~init:(Empty, 0) t ~f:(fun ~key ~data (accu, length) ->\n match f data with\n | None -> accu, length\n | Some b -> set ~length ~key ~data:b accu ~compare_key)\n ;;\n\n let filter_mapi t ~f ~compare_key =\n fold ~init:(Empty, 0) t ~f:(fun ~key ~data (accu, length) ->\n match f ~key ~data with\n | None -> accu, length\n | Some b -> set ~length ~key ~data:b accu ~compare_key)\n ;;\n\n let partition_mapi t ~f ~compare_key =\n fold\n t\n ~init:((Empty, 0), (Empty, 0))\n ~f:(fun ~key ~data (pair1, pair2) ->\n match (f ~key ~data : _ Either.t) with\n | First x ->\n let t, length = pair1 in\n set t ~key ~data:x ~compare_key ~length, pair2\n | Second y ->\n let t, length = pair2 in\n pair1, set t ~key ~data:y ~compare_key ~length)\n ;;\n\n let partition_map t ~f ~compare_key =\n partition_mapi t ~compare_key ~f:(fun ~key:_ ~data -> f data)\n ;;\n\n let partitioni_tf t ~f ~compare_key =\n partition_mapi t ~compare_key ~f:(fun ~key ~data ->\n if f ~key ~data then First data else Second data)\n ;;\n\n let partition_tf t ~f ~compare_key =\n partition_mapi t ~compare_key ~f:(fun ~key:_ ~data ->\n if f data then First data else Second data)\n ;;\n\n module Enum = struct\n type increasing\n type decreasing\n\n type ('k, 'v, 'direction) t =\n | End\n | More of 'k * 'v * ('k, 'v) tree * ('k, 'v, 'direction) t\n\n let rec cons t (e : (_, _, increasing) t) : (_, _, increasing) t =\n match t with\n | Empty -> e\n | Leaf (v, d) -> More (v, d, Empty, e)\n | Node (l, v, d, r, _) -> cons l (More (v, d, r, e))\n ;;\n\n let rec cons_right t (e : (_, _, decreasing) t) : (_, _, decreasing) t =\n match t with\n | Empty -> e\n | Leaf (v, d) -> More (v, d, Empty, e)\n | Node (l, v, d, r, _) -> cons_right r (More (v, d, l, e))\n ;;\n\n let of_tree tree : (_, _, increasing) t = cons tree End\n let of_tree_right tree : (_, _, decreasing) t = cons_right tree End\n\n let starting_at_increasing t key compare : (_, _, increasing) t =\n let rec loop t e =\n match t with\n | Empty -> e\n | Leaf (v, d) -> loop (Node (Empty, v, d, Empty, 1)) e\n | Node (_, v, _, r, _) when compare v key < 0 -> loop r e\n | Node (l, v, d, r, _) -> loop l (More (v, d, r, e))\n in\n loop t End\n ;;\n\n let starting_at_decreasing t key compare : (_, _, decreasing) t =\n let rec loop t e =\n match t with\n | Empty -> e\n | Leaf (v, d) -> loop (Node (Empty, v, d, Empty, 1)) e\n | Node (l, v, _, _, _) when compare v key > 0 -> loop l e\n | Node (l, v, d, r, _) -> loop r (More (v, d, l, e))\n in\n loop t End\n ;;\n\n let compare compare_key compare_data t1 t2 =\n let rec loop t1 t2 =\n match t1, t2 with\n | End, End -> 0\n | End, _ -> -1\n | _, End -> 1\n | More (v1, d1, r1, e1), More (v2, d2, r2, e2) ->\n let c = compare_key v1 v2 in\n if c <> 0\n then c\n else (\n let c = compare_data d1 d2 in\n if c <> 0\n then c\n else if phys_equal r1 r2\n then loop e1 e2\n else loop (cons r1 e1) (cons r2 e2))\n in\n loop t1 t2\n ;;\n\n let equal compare_key data_equal t1 t2 =\n let rec loop t1 t2 =\n match t1, t2 with\n | End, End -> true\n | End, _ | _, End -> false\n | More (v1, d1, r1, e1), More (v2, d2, r2, e2) ->\n compare_key v1 v2 = 0\n && data_equal d1 d2\n && if phys_equal r1 r2 then loop e1 e2 else loop (cons r1 e1) (cons r2 e2)\n in\n loop t1 t2\n ;;\n\n let rec fold ~init ~f = function\n | End -> init\n | More (key, data, tree, enum) ->\n let next = f ~key ~data init in\n fold (cons tree enum) ~init:next ~f\n ;;\n\n let fold2 compare_key t1 t2 ~init ~f =\n let rec loop t1 t2 curr =\n match t1, t2 with\n | End, End -> curr\n | End, _ ->\n fold t2 ~init:curr ~f:(fun ~key ~data acc -> f ~key ~data:(`Right data) acc)\n | _, End ->\n fold t1 ~init:curr ~f:(fun ~key ~data acc -> f ~key ~data:(`Left data) acc)\n | More (k1, v1, tree1, enum1), More (k2, v2, tree2, enum2) ->\n let compare_result = compare_key k1 k2 in\n if compare_result = 0\n then (\n let next = f ~key:k1 ~data:(`Both (v1, v2)) curr in\n loop (cons tree1 enum1) (cons tree2 enum2) next)\n else if compare_result < 0\n then (\n let next = f ~key:k1 ~data:(`Left v1) curr in\n loop (cons tree1 enum1) t2 next)\n else (\n let next = f ~key:k2 ~data:(`Right v2) curr in\n loop t1 (cons tree2 enum2) next)\n in\n loop t1 t2 init\n ;;\n\n let symmetric_diff t1 t2 ~compare_key ~data_equal =\n let step state =\n match state with\n | End, End -> Sequence.Step.Done\n | End, More (key, data, tree, enum) ->\n Sequence.Step.Yield ((key, `Right data), (End, cons tree enum))\n | More (key, data, tree, enum), End ->\n Sequence.Step.Yield ((key, `Left data), (cons tree enum, End))\n | (More (k1, v1, tree1, enum1) as left), (More (k2, v2, tree2, enum2) as right)\n ->\n let compare_result = compare_key k1 k2 in\n if compare_result = 0\n then (\n let next_state =\n if phys_equal tree1 tree2\n then enum1, enum2\n else cons tree1 enum1, cons tree2 enum2\n in\n if data_equal v1 v2\n then Sequence.Step.Skip next_state\n else Sequence.Step.Yield ((k1, `Unequal (v1, v2)), next_state))\n else if compare_result < 0\n then Sequence.Step.Yield ((k1, `Left v1), (cons tree1 enum1, right))\n else Sequence.Step.Yield ((k2, `Right v2), (left, cons tree2 enum2))\n in\n Sequence.unfold_step ~init:(of_tree t1, of_tree t2) ~f:step\n ;;\n\n let fold_symmetric_diff t1 t2 ~compare_key ~data_equal ~init ~f =\n let add acc k v = f acc (k, `Right v) in\n let remove acc k v = f acc (k, `Left v) in\n let rec loop left right acc =\n match left, right with\n | End, enum -> fold enum ~init:acc ~f:(fun ~key ~data acc -> add acc key data)\n | enum, End -> fold enum ~init:acc ~f:(fun ~key ~data acc -> remove acc key data)\n | (More (k1, v1, tree1, enum1) as left), (More (k2, v2, tree2, enum2) as right)\n ->\n let compare_result = compare_key k1 k2 in\n if compare_result = 0\n then (\n let acc = if data_equal v1 v2 then acc else f acc (k1, `Unequal (v1, v2)) in\n if phys_equal tree1 tree2\n then loop enum1 enum2 acc\n else loop (cons tree1 enum1) (cons tree2 enum2) acc)\n else if compare_result < 0\n then (\n let acc = remove acc k1 v1 in\n loop (cons tree1 enum1) right acc)\n else (\n let acc = add acc k2 v2 in\n loop left (cons tree2 enum2) acc)\n in\n loop (of_tree t1) (of_tree t2) init\n ;;\n end\n\n let to_sequence_increasing comparator ~from_key t =\n let next enum =\n match enum with\n | Enum.End -> Sequence.Step.Done\n | Enum.More (k, v, t, e) -> Sequence.Step.Yield ((k, v), Enum.cons t e)\n in\n let init =\n match from_key with\n | None -> Enum.of_tree t\n | Some key -> Enum.starting_at_increasing t key comparator.Comparator.compare\n in\n Sequence.unfold_step ~init ~f:next\n ;;\n\n let to_sequence_decreasing comparator ~from_key t =\n let next enum =\n match enum with\n | Enum.End -> Sequence.Step.Done\n | Enum.More (k, v, t, e) -> Sequence.Step.Yield ((k, v), Enum.cons_right t e)\n in\n let init =\n match from_key with\n | None -> Enum.of_tree_right t\n | Some key -> Enum.starting_at_decreasing t key comparator.Comparator.compare\n in\n Sequence.unfold_step ~init ~f:next\n ;;\n\n let to_sequence\n comparator\n ?(order = `Increasing_key)\n ?keys_greater_or_equal_to\n ?keys_less_or_equal_to\n t\n =\n let inclusive_bound side t bound =\n let compare_key = comparator.Comparator.compare in\n let l, maybe, r = split t bound ~compare_key in\n let t = side (l, r) in\n match maybe with\n | None -> t\n | Some (key, data) -> set' t key data ~compare_key\n in\n match order with\n | `Increasing_key ->\n let t = Option.fold keys_less_or_equal_to ~init:t ~f:(inclusive_bound fst) in\n to_sequence_increasing comparator ~from_key:keys_greater_or_equal_to t\n | `Decreasing_key ->\n let t = Option.fold keys_greater_or_equal_to ~init:t ~f:(inclusive_bound snd) in\n to_sequence_decreasing comparator ~from_key:keys_less_or_equal_to t\n ;;\n\n let compare compare_key compare_data t1 t2 =\n Enum.compare compare_key compare_data (Enum.of_tree t1) (Enum.of_tree t2)\n ;;\n\n let equal compare_key compare_data t1 t2 =\n Enum.equal compare_key compare_data (Enum.of_tree t1) (Enum.of_tree t2)\n ;;\n\n let iter2 t1 t2 ~f ~compare_key =\n Enum.fold2\n compare_key\n (Enum.of_tree t1)\n (Enum.of_tree t2)\n ~init:()\n ~f:(fun ~key ~data () -> f ~key ~data)\n ;;\n\n let fold2 t1 t2 ~init ~f ~compare_key =\n Enum.fold2 compare_key (Enum.of_tree t1) (Enum.of_tree t2) ~f ~init\n ;;\n\n let symmetric_diff = Enum.symmetric_diff\n\n let fold_symmetric_diff t1 t2 ~compare_key ~data_equal ~init ~f =\n (* [Enum.fold_diffs] is a correct implementation of this function, but is considerably\n slower, as we have to allocate quite a lot of state to track enumeration of a tree.\n Avoid if we can.\n *)\n let slow x y ~init =\n Enum.fold_symmetric_diff x y ~compare_key ~data_equal ~f ~init\n in\n let add acc k v = f acc (k, `Right v) in\n let remove acc k v = f acc (k, `Left v) in\n let delta acc k v v' =\n if data_equal v v' then acc else f acc (k, `Unequal (v, v'))\n in\n (* If two trees have the same structure at the root (and the same key, if they're\n [Node]s) we can trivially diff each subpart in obvious ways. *)\n let rec loop t t' acc =\n if phys_equal t t'\n then acc\n else (\n match t, t' with\n | Empty, new_vals ->\n fold new_vals ~init:acc ~f:(fun ~key ~data acc -> add acc key data)\n | old_vals, Empty ->\n fold old_vals ~init:acc ~f:(fun ~key ~data acc -> remove acc key data)\n | Leaf (k, v), Leaf (k', v') ->\n (match compare_key k k' with\n | x when x = 0 -> delta acc k v v'\n | x when x < 0 ->\n let acc = remove acc k v in\n add acc k' v'\n | _ (* when x > 0 *) ->\n let acc = add acc k' v' in\n remove acc k v)\n | Node (l, k, v, r, _), Node (l', k', v', r', _) when compare_key k k' = 0 ->\n let acc = loop l l' acc in\n let acc = delta acc k v v' in\n loop r r' acc\n (* Our roots aren't the same key. Fallback to the slow mode. Trees with small\n diffs will only do this on very small parts of the tree (hopefully - if the\n overall root is rebalanced, we'll eat the whole cost, unfortunately.) *)\n | Node _, Node _ | Node _, Leaf _ | Leaf _, Node _ -> slow t t' ~init:acc)\n in\n loop t1 t2 init\n ;;\n\n let rec length = function\n | Empty -> 0\n | Leaf _ -> 1\n | Node (l, _, _, r, _) -> length l + length r + 1\n ;;\n\n let hash_fold_t_ignoring_structure hash_fold_key hash_fold_data state t =\n fold\n t\n ~init:(hash_fold_int state (length t))\n ~f:(fun ~key ~data state -> hash_fold_data (hash_fold_key state key) data)\n ;;\n\n let keys t = fold_right ~f:(fun ~key ~data:_ list -> key :: list) t ~init:[]\n let data t = fold_right ~f:(fun ~key:_ ~data list -> data :: list) t ~init:[]\n\n module type Foldable = sig\n val name : string\n\n type 'a t\n\n val fold : 'a t -> init:'b -> f:('b -> 'a -> 'b) -> 'b\n end\n\n module Of_foldable (M : Foldable) = struct\n let of_foldable_fold foldable ~init ~f ~compare_key =\n M.fold foldable ~init:(empty, 0) ~f:(fun (accum, length) (key, data) ->\n let prev_data =\n match find accum key ~compare_key with\n | None -> init\n | Some prev -> prev\n in\n let data = f prev_data data in\n set accum ~length ~key ~data ~compare_key)\n ;;\n\n let of_foldable_reduce foldable ~f ~compare_key =\n M.fold foldable ~init:(empty, 0) ~f:(fun (accum, length) (key, data) ->\n let new_data =\n match find accum key ~compare_key with\n | None -> data\n | Some prev -> f prev data\n in\n set accum ~length ~key ~data:new_data ~compare_key)\n ;;\n\n let of_foldable foldable ~compare_key =\n with_return (fun r ->\n let map =\n M.fold foldable ~init:(empty, 0) ~f:(fun (t, length) (key, data) ->\n let ((_, length') as acc) = set ~length ~key ~data t ~compare_key in\n if length = length' then r.return (`Duplicate_key key) else acc)\n in\n `Ok map)\n ;;\n\n let of_foldable_or_error foldable ~comparator =\n match of_foldable foldable ~compare_key:comparator.Comparator.compare with\n | `Ok x -> Result.Ok x\n | `Duplicate_key key ->\n Or_error.error\n (\"Map.of_\" ^ M.name ^ \"_or_error: duplicate key\")\n key\n comparator.sexp_of_t\n ;;\n\n let of_foldable_exn foldable ~comparator =\n match of_foldable foldable ~compare_key:comparator.Comparator.compare with\n | `Ok x -> x\n | `Duplicate_key key ->\n Error.create\n (\"Map.of_\" ^ M.name ^ \"_exn: duplicate key\")\n key\n comparator.sexp_of_t\n |> Error.raise\n ;;\n end\n\n module Of_alist = Of_foldable (struct\n let name = \"alist\"\n\n type 'a t = 'a list\n\n let fold = List.fold\n end)\n\n let of_alist_fold = Of_alist.of_foldable_fold\n let of_alist_reduce = Of_alist.of_foldable_reduce\n let of_alist = Of_alist.of_foldable\n let of_alist_or_error = Of_alist.of_foldable_or_error\n let of_alist_exn = Of_alist.of_foldable_exn\n\n (* Reverse the input, then fold from left to right. The resulting map uses the first\n instance of each key from the input list. The relative ordering of elements in each\n output list is the same as in the input list. *)\n let of_foldable_multi foldable ~fold ~compare_key =\n let alist = fold foldable ~init:[] ~f:(fun l x -> x :: l) in\n of_alist_fold alist ~init:[] ~f:(fun l x -> x :: l) ~compare_key\n ;;\n\n let of_alist_multi alist ~compare_key =\n of_foldable_multi alist ~fold:List.fold ~compare_key\n ;;\n\n module Of_sequence = Of_foldable (struct\n let name = \"sequence\"\n\n type 'a t = 'a Sequence.t\n\n let fold = Sequence.fold\n end)\n\n let of_sequence_fold = Of_sequence.of_foldable_fold\n let of_sequence_reduce = Of_sequence.of_foldable_reduce\n let of_sequence = Of_sequence.of_foldable\n let of_sequence_or_error = Of_sequence.of_foldable_or_error\n let of_sequence_exn = Of_sequence.of_foldable_exn\n\n let of_sequence_multi sequence ~compare_key =\n of_foldable_multi sequence ~fold:Sequence.fold ~compare_key\n ;;\n\n let for_all t ~f =\n with_return (fun r ->\n iter t ~f:(fun data -> if not (f data) then r.return false);\n true)\n ;;\n\n let for_alli t ~f =\n with_return (fun r ->\n iteri t ~f:(fun ~key ~data -> if not (f ~key ~data) then r.return false);\n true)\n ;;\n\n let exists t ~f =\n with_return (fun r ->\n iter t ~f:(fun data -> if f data then r.return true);\n false)\n ;;\n\n let existsi t ~f =\n with_return (fun r ->\n iteri t ~f:(fun ~key ~data -> if f ~key ~data then r.return true);\n false)\n ;;\n\n let count t ~f =\n fold t ~init:0 ~f:(fun ~key:_ ~data acc -> if f data then acc + 1 else acc)\n ;;\n\n let counti t ~f =\n fold t ~init:0 ~f:(fun ~key ~data acc -> if f ~key ~data then acc + 1 else acc)\n ;;\n\n let to_alist ?(key_order = `Increasing) t =\n match key_order with\n | `Increasing -> fold_right t ~init:[] ~f:(fun ~key ~data x -> (key, data) :: x)\n | `Decreasing -> fold t ~init:[] ~f:(fun ~key ~data x -> (key, data) :: x)\n ;;\n\n let merge t1 t2 ~f ~compare_key =\n let elts = Uniform_array.unsafe_create_uninitialized ~len:(length t1 + length t2) in\n let i = ref 0 in\n iter2 t1 t2 ~compare_key ~f:(fun ~key ~data:values ->\n match f ~key values with\n | Some value ->\n Uniform_array.set elts !i (key, value);\n incr i\n | None -> ());\n let len = !i in\n let get i = Uniform_array.get elts i in\n let tree = of_increasing_iterator_unchecked ~len ~f:get in\n tree, len\n ;;\n\n module Closest_key_impl = struct\n (* [marker] and [repackage] allow us to create \"logical\" options without actually\n allocating any options. Passing [Found key value] to a function is equivalent to\n passing [Some (key, value)]; passing [Missing () ()] is equivalent to passing\n [None]. *)\n type ('k, 'v, 'k_opt, 'v_opt) marker =\n | Missing : ('k, 'v, unit, unit) marker\n | Found : ('k, 'v, 'k, 'v) marker\n\n let repackage\n (type k v k_opt v_opt)\n (marker : (k, v, k_opt, v_opt) marker)\n (k : k_opt)\n (v : v_opt)\n : (k * v) option\n =\n match marker with\n | Missing -> None\n | Found -> Some (k, v)\n ;;\n\n (* The type signature is explicit here to allow polymorphic recursion. *)\n let rec loop :\n 'k 'v 'k_opt 'v_opt. ('k, 'v) tree\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'k -> compare_key:('k -> 'k -> int) -> ('k, 'v, 'k_opt, 'v_opt) marker\n -> 'k_opt -> 'v_opt -> ('k * 'v) option\n =\n fun t dir k ~compare_key found_marker found_key found_value ->\n match t with\n | Empty -> repackage found_marker found_key found_value\n | Leaf (k', v') ->\n let c = compare_key k' k in\n if match dir with\n | `Greater_or_equal_to -> c >= 0\n | `Greater_than -> c > 0\n | `Less_or_equal_to -> c <= 0\n | `Less_than -> c < 0\n then Some (k', v')\n else repackage found_marker found_key found_value\n | Node (l, k', v', r, _) ->\n let c = compare_key k' k in\n if c = 0\n then (\n (* This is a base case (no recursive call). *)\n match dir with\n | `Greater_or_equal_to | `Less_or_equal_to -> Some (k', v')\n | `Greater_than ->\n if is_empty r\n then repackage found_marker found_key found_value\n else min_elt r\n | `Less_than ->\n if is_empty l\n then repackage found_marker found_key found_value\n else max_elt l)\n else (\n (* We are guaranteed here that k' <> k. *)\n (* This is the only recursive case. *)\n match dir with\n | `Greater_or_equal_to | `Greater_than ->\n if c > 0\n then loop l dir k ~compare_key Found k' v'\n else loop r dir k ~compare_key found_marker found_key found_value\n | `Less_or_equal_to | `Less_than ->\n if c < 0\n then loop r dir k ~compare_key Found k' v'\n else loop l dir k ~compare_key found_marker found_key found_value)\n ;;\n\n let closest_key t dir k ~compare_key = loop t dir k ~compare_key Missing () ()\n end\n\n let closest_key = Closest_key_impl.closest_key\n\n let rec rank t k ~compare_key =\n match t with\n | Empty -> None\n | Leaf (k', _) -> if compare_key k' k = 0 then Some 0 else None\n | Node (l, k', _, r, _) ->\n let c = compare_key k' k in\n if c = 0\n then Some (length l)\n else if c > 0\n then rank l k ~compare_key\n else Option.map (rank r k ~compare_key) ~f:(fun rank -> rank + 1 + length l)\n ;;\n\n (* this could be implemented using [Sequence] interface but the following implementation\n allocates only 2 words and doesn't require write-barrier *)\n let rec nth' num_to_search = function\n | Empty -> None\n | Leaf (k, v) ->\n if !num_to_search = 0\n then Some (k, v)\n else (\n decr num_to_search;\n None)\n | Node (l, k, v, r, _) ->\n (match nth' num_to_search l with\n | Some _ as some -> some\n | None ->\n if !num_to_search = 0\n then Some (k, v)\n else (\n decr num_to_search;\n nth' num_to_search r))\n ;;\n\n let nth t n = nth' (ref n) t\n\n\n let rec find_first_satisfying t ~f =\n match t with\n | Empty -> None\n | Leaf (k, v) -> if f ~key:k ~data:v then Some (k, v) else None\n | Node (l, k, v, r, _) ->\n if f ~key:k ~data:v\n then (\n match find_first_satisfying l ~f with\n | None -> Some (k, v)\n | Some _ as x -> x)\n else find_first_satisfying r ~f\n ;;\n\n let rec find_last_satisfying t ~f =\n match t with\n | Empty -> None\n | Leaf (k, v) -> if f ~key:k ~data:v then Some (k, v) else None\n | Node (l, k, v, r, _) ->\n if f ~key:k ~data:v\n then (\n match find_last_satisfying r ~f with\n | None -> Some (k, v)\n | Some _ as x -> x)\n else find_last_satisfying l ~f\n ;;\n\n let binary_search t ~compare how v =\n match how with\n | `Last_strictly_less_than ->\n find_last_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v < 0)\n | `Last_less_than_or_equal_to ->\n find_last_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v <= 0)\n | `First_equal_to ->\n (match\n find_first_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v >= 0)\n with\n | Some (key, data) as pair when compare ~key ~data v = 0 -> pair\n | None | Some _ -> None)\n | `Last_equal_to ->\n (match find_last_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v <= 0) with\n | Some (key, data) as pair when compare ~key ~data v = 0 -> pair\n | None | Some _ -> None)\n | `First_greater_than_or_equal_to ->\n find_first_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v >= 0)\n | `First_strictly_greater_than ->\n find_first_satisfying t ~f:(fun ~key ~data -> compare ~key ~data v > 0)\n ;;\n\n let binary_search_segmented t ~segment_of how =\n let is_left ~key ~data =\n match segment_of ~key ~data with\n | `Left -> true\n | `Right -> false\n in\n let is_right ~key ~data = not (is_left ~key ~data) in\n match how with\n | `Last_on_left -> find_last_satisfying t ~f:is_left\n | `First_on_right -> find_first_satisfying t ~f:is_right\n ;;\n\n type ('k, 'v) acc =\n { mutable bad_key : 'k option\n ; mutable map_length : ('k, 'v) t * int\n }\n\n let of_iteri ~iteri ~compare_key =\n let acc = { bad_key = None; map_length = empty, 0 } in\n iteri ~f:(fun ~key ~data ->\n let map, length = acc.map_length in\n let ((_, length') as pair) = set ~length ~key ~data map ~compare_key in\n if length = length' && Option.is_none acc.bad_key\n then acc.bad_key <- Some key\n else acc.map_length <- pair);\n match acc.bad_key with\n | None -> `Ok acc.map_length\n | Some key -> `Duplicate_key key\n ;;\n\n let t_of_sexp_direct key_of_sexp value_of_sexp sexp ~(comparator : _ Comparator.t) =\n let alist = list_of_sexp (pair_of_sexp key_of_sexp value_of_sexp) sexp in\n let compare_key = comparator.compare in\n match of_alist alist ~compare_key with\n | `Ok v -> v\n | `Duplicate_key k ->\n (* find the sexp of a duplicate key, so the error is narrowed to a key and not\n the whole map *)\n let alist_sexps = list_of_sexp (pair_of_sexp Fn.id Fn.id) sexp in\n let found_first_k = ref false in\n List.iter2_ok alist alist_sexps ~f:(fun (k2, _) (k2_sexp, _) ->\n if compare_key k k2 = 0\n then\n if !found_first_k\n then of_sexp_error \"Map.t_of_sexp_direct: duplicate key\" k2_sexp\n else found_first_k := true);\n assert false\n ;;\n\n let sexp_of_t sexp_of_key sexp_of_value t =\n let f ~key ~data acc = Sexp.List [ sexp_of_key key; sexp_of_value data ] :: acc in\n Sexp.List (fold_right ~f t ~init:[])\n ;;\n\n let combine_errors t ~compare_key ~sexp_of_key =\n let oks, (error_tree, _) = partition_map t ~compare_key ~f:Result.to_either in\n if is_empty error_tree\n then Ok oks\n else Or_error.error_s (sexp_of_t sexp_of_key Error.sexp_of_t error_tree)\n ;;\nend\n\ntype ('k, 'v, 'comparator) t =\n { (* [comparator] is the first field so that polymorphic equality fails on a map due\n to the functional value in the comparator.\n Note that this does not affect polymorphic [compare]: that still produces\n nonsense. *)\n comparator : ('k, 'comparator) Comparator.t\n ; tree : ('k, 'v) Tree0.t\n ; length : int\n }\n\ntype ('k, 'v, 'comparator) tree = ('k, 'v) Tree0.t\n\nlet compare_key t = t.comparator.Comparator.compare\n\n\nlet like { tree = _; length = _; comparator } (tree, length) =\n { tree; length; comparator }\n;;\n\nlet like2 x (y, z) = like x y, like x z\nlet with_same_length { tree = _; comparator; length } tree = { tree; comparator; length }\nlet of_tree ~comparator tree = { tree; comparator; length = Tree0.length tree }\n\n(* Exposing this function would make it very easy for the invariants\n of this module to be broken. *)\nlet of_tree_unsafe ~comparator ~length tree = { tree; comparator; length }\n\nmodule Accessors = struct\n let comparator t = t.comparator\n let to_tree t = t.tree\n let invariants t = Tree0.invariants t.tree ~compare_key:(compare_key t)\n let is_empty t = Tree0.is_empty t.tree\n let length t = t.length\n\n let set t ~key ~data =\n like t (Tree0.set t.tree ~length:t.length ~key ~data ~compare_key:(compare_key t))\n ;;\n\n let add_exn t ~key ~data =\n like\n t\n (Tree0.add_exn\n t.tree\n ~length:t.length\n ~key\n ~data\n ~compare_key:(compare_key t)\n ~sexp_of_key:t.comparator.sexp_of_t)\n ;;\n\n let add_exn_internal t ~key ~data =\n like\n t\n (Tree0.add_exn_internal\n t.tree\n ~length:t.length\n ~key\n ~data\n ~compare_key:(compare_key t)\n ~sexp_of_key:t.comparator.sexp_of_t)\n ;;\n\n let add t ~key ~data =\n match add_exn_internal t ~key ~data with\n | result -> `Ok result\n | exception Duplicate -> `Duplicate\n ;;\n\n let add_multi t ~key ~data =\n like\n t\n (Tree0.add_multi t.tree ~length:t.length ~key ~data ~compare_key:(compare_key t))\n ;;\n\n let remove_multi t key =\n like t (Tree0.remove_multi t.tree ~length:t.length key ~compare_key:(compare_key t))\n ;;\n\n let find_multi t key = Tree0.find_multi t.tree key ~compare_key:(compare_key t)\n\n let change t key ~f =\n like t (Tree0.change t.tree key ~f ~length:t.length ~compare_key:(compare_key t))\n ;;\n\n let update t key ~f =\n like t (Tree0.update t.tree key ~f ~length:t.length ~compare_key:(compare_key t))\n ;;\n\n let find_exn t key =\n Tree0.find_exn\n t.tree\n key\n ~compare_key:(compare_key t)\n ~sexp_of_key:t.comparator.sexp_of_t\n ;;\n\n let find t key = Tree0.find t.tree key ~compare_key:(compare_key t)\n\n let remove t key =\n like t (Tree0.remove t.tree key ~length:t.length ~compare_key:(compare_key t))\n ;;\n\n let mem t key = Tree0.mem t.tree key ~compare_key:(compare_key t)\n let iter_keys t ~f = Tree0.iter_keys t.tree ~f\n let iter t ~f = Tree0.iter t.tree ~f\n let iteri t ~f = Tree0.iteri t.tree ~f\n let iteri_until t ~f = Tree0.iteri_until t.tree ~f\n let iter2 t1 t2 ~f = Tree0.iter2 t1.tree t2.tree ~f ~compare_key:(compare_key t1)\n let map t ~f = with_same_length t (Tree0.map t.tree ~f)\n let mapi t ~f = with_same_length t (Tree0.mapi t.tree ~f)\n let fold t ~init ~f = Tree0.fold t.tree ~f ~init\n let fold_right t ~init ~f = Tree0.fold_right t.tree ~f ~init\n\n let fold2 t1 t2 ~init ~f =\n Tree0.fold2 t1.tree t2.tree ~init ~f ~compare_key:(compare_key t1)\n ;;\n\n let filter_keys t ~f =\n like t (Tree0.filter_keys t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let filter t ~f = like t (Tree0.filter t.tree ~f ~compare_key:(compare_key t))\n let filteri t ~f = like t (Tree0.filteri t.tree ~f ~compare_key:(compare_key t))\n let filter_map t ~f = like t (Tree0.filter_map t.tree ~f ~compare_key:(compare_key t))\n\n let filter_mapi t ~f =\n like t (Tree0.filter_mapi t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let partition_mapi t ~f =\n like2 t (Tree0.partition_mapi t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let partition_map t ~f =\n like2 t (Tree0.partition_map t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let partitioni_tf t ~f =\n like2 t (Tree0.partitioni_tf t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let partition_tf t ~f =\n like2 t (Tree0.partition_tf t.tree ~f ~compare_key:(compare_key t))\n ;;\n\n let combine_errors t =\n Or_error.map\n ~f:(like t)\n (Tree0.combine_errors\n t.tree\n ~compare_key:(compare_key t)\n ~sexp_of_key:t.comparator.sexp_of_t)\n ;;\n\n let compare_direct compare_data t1 t2 =\n Tree0.compare (compare_key t1) compare_data t1.tree t2.tree\n ;;\n\n let equal compare_data t1 t2 =\n Tree0.equal (compare_key t1) compare_data t1.tree t2.tree\n ;;\n\n let keys t = Tree0.keys t.tree\n let data t = Tree0.data t.tree\n let to_alist ?key_order t = Tree0.to_alist ?key_order t.tree\n let validate ~name f t = Validate.alist ~name f (to_alist t)\n let validatei ~name f t = Validate.list ~name:(Fn.compose name fst) f (to_alist t)\n\n let symmetric_diff t1 t2 ~data_equal =\n Tree0.symmetric_diff t1.tree t2.tree ~compare_key:(compare_key t1) ~data_equal\n ;;\n\n let fold_symmetric_diff t1 t2 ~data_equal ~init ~f =\n Tree0.fold_symmetric_diff\n t1.tree\n t2.tree\n ~compare_key:(compare_key t1)\n ~data_equal\n ~init\n ~f\n ;;\n\n let merge t1 t2 ~f =\n like t1 (Tree0.merge t1.tree t2.tree ~f ~compare_key:(compare_key t1))\n ;;\n\n let min_elt t = Tree0.min_elt t.tree\n let min_elt_exn t = Tree0.min_elt_exn t.tree\n let max_elt t = Tree0.max_elt t.tree\n let max_elt_exn t = Tree0.max_elt_exn t.tree\n let for_all t ~f = Tree0.for_all t.tree ~f\n let for_alli t ~f = Tree0.for_alli t.tree ~f\n let exists t ~f = Tree0.exists t.tree ~f\n let existsi t ~f = Tree0.existsi t.tree ~f\n let count t ~f = Tree0.count t.tree ~f\n let counti t ~f = Tree0.counti t.tree ~f\n\n let split t k =\n let l, maybe, r = Tree0.split t.tree k ~compare_key:(compare_key t) in\n let comparator = comparator t in\n (* Try to traverse the least amount possible to calculate the length,\n using height as a heuristic. *)\n let both_len = if Option.is_some maybe then t.length - 1 else t.length in\n if Tree0.height l < Tree0.height r\n then (\n let l = of_tree l ~comparator in\n l, maybe, of_tree_unsafe r ~comparator ~length:(both_len - length l))\n else (\n let r = of_tree r ~comparator in\n of_tree_unsafe l ~comparator ~length:(both_len - length r), maybe, r)\n ;;\n\n let subrange t ~lower_bound ~upper_bound =\n let left, mid, right =\n Tree0.split_range t.tree ~lower_bound ~upper_bound ~compare_key:(compare_key t)\n in\n (* Try to traverse the least amount possible to calculate the length,\n using height as a heuristic. *)\n let outer_joined_height =\n let h_l = Tree0.height left\n and h_r = Tree0.height right in\n if h_l = h_r then h_l + 1 else max h_l h_r\n in\n if outer_joined_height < Tree0.height mid\n then (\n let mid_length = t.length - (Tree0.length left + Tree0.length right) in\n of_tree_unsafe mid ~comparator:(comparator t) ~length:mid_length)\n else of_tree mid ~comparator:(comparator t)\n ;;\n\n let append ~lower_part ~upper_part =\n match\n Tree0.append\n ~compare_key:(compare_key lower_part)\n ~lower_part:lower_part.tree\n ~upper_part:upper_part.tree\n with\n | `Ok tree ->\n `Ok\n (of_tree_unsafe\n tree\n ~comparator:(comparator lower_part)\n ~length:(lower_part.length + upper_part.length))\n | `Overlapping_key_ranges -> `Overlapping_key_ranges\n ;;\n\n let fold_range_inclusive t ~min ~max ~init ~f =\n Tree0.fold_range_inclusive t.tree ~min ~max ~init ~f ~compare_key:(compare_key t)\n ;;\n\n let range_to_alist t ~min ~max =\n Tree0.range_to_alist t.tree ~min ~max ~compare_key:(compare_key t)\n ;;\n\n let closest_key t dir key =\n Tree0.closest_key t.tree dir key ~compare_key:(compare_key t)\n ;;\n\n let nth t n = Tree0.nth t.tree n\n let nth_exn t n = Option.value_exn (nth t n)\n let rank t key = Tree0.rank t.tree key ~compare_key:(compare_key t)\n let sexp_of_t sexp_of_k sexp_of_v _ t = Tree0.sexp_of_t sexp_of_k sexp_of_v t.tree\n\n let to_sequence ?order ?keys_greater_or_equal_to ?keys_less_or_equal_to t =\n Tree0.to_sequence\n t.comparator\n ?order\n ?keys_greater_or_equal_to\n ?keys_less_or_equal_to\n t.tree\n ;;\n\n let binary_search t ~compare how v = Tree0.binary_search t.tree ~compare how v\n\n let binary_search_segmented t ~segment_of how =\n Tree0.binary_search_segmented t.tree ~segment_of how\n ;;\n\n let hash_fold_direct hash_fold_key hash_fold_data state t =\n Tree0.hash_fold_t_ignoring_structure hash_fold_key hash_fold_data state t.tree\n ;;\nend\n\n(* [0] is used as the [length] argument everywhere in this module, since trees do not\n have their lengths stored at the root, unlike maps. The values are discarded always. *)\nmodule Tree = struct\n type ('k, 'v, 'comparator) t = ('k, 'v, 'comparator) tree\n\n let empty_without_value_restriction = Tree0.empty\n let empty ~comparator:_ = empty_without_value_restriction\n let of_tree ~comparator:_ tree = tree\n let singleton ~comparator:_ k v = Tree0.singleton k v\n\n let of_sorted_array_unchecked ~comparator array =\n fst\n (Tree0.of_sorted_array_unchecked array ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sorted_array ~comparator array =\n Tree0.of_sorted_array array ~compare_key:comparator.Comparator.compare\n |> Or_error.map ~f:fst\n ;;\n\n let of_alist ~comparator alist =\n match Tree0.of_alist alist ~compare_key:comparator.Comparator.compare with\n | `Duplicate_key _ as d -> d\n | `Ok (tree, _size) -> `Ok tree\n ;;\n\n let of_alist_or_error ~comparator alist =\n Tree0.of_alist_or_error alist ~comparator |> Or_error.map ~f:fst\n ;;\n\n let of_alist_exn ~comparator alist = fst (Tree0.of_alist_exn alist ~comparator)\n\n let of_alist_multi ~comparator alist =\n fst (Tree0.of_alist_multi alist ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_alist_fold ~comparator alist ~init ~f =\n fst (Tree0.of_alist_fold alist ~init ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_alist_reduce ~comparator alist ~f =\n fst (Tree0.of_alist_reduce alist ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_iteri ~comparator ~iteri =\n match Tree0.of_iteri ~iteri ~compare_key:comparator.Comparator.compare with\n | `Ok (tree, _size) -> `Ok tree\n | `Duplicate_key _ as d -> d\n ;;\n\n let of_increasing_iterator_unchecked ~comparator:_required_by_intf ~len ~f =\n Tree0.of_increasing_iterator_unchecked ~len ~f\n ;;\n\n let of_increasing_sequence ~comparator seq =\n Or_error.map\n ~f:fst\n (Tree0.of_increasing_sequence seq ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence ~comparator seq =\n match Tree0.of_sequence seq ~compare_key:comparator.Comparator.compare with\n | `Duplicate_key _ as d -> d\n | `Ok (tree, _size) -> `Ok tree\n ;;\n\n let of_sequence_or_error ~comparator seq =\n Tree0.of_sequence_or_error seq ~comparator |> Or_error.map ~f:fst\n ;;\n\n let of_sequence_exn ~comparator seq = fst (Tree0.of_sequence_exn seq ~comparator)\n\n let of_sequence_multi ~comparator seq =\n fst (Tree0.of_sequence_multi seq ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence_fold ~comparator seq ~init ~f =\n fst (Tree0.of_sequence_fold seq ~init ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence_reduce ~comparator seq ~f =\n fst (Tree0.of_sequence_reduce seq ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let to_tree t = t\n\n let invariants ~comparator t =\n Tree0.invariants t ~compare_key:comparator.Comparator.compare\n ;;\n\n let is_empty t = Tree0.is_empty t\n let length t = Tree0.length t\n\n let set ~comparator t ~key ~data =\n fst (Tree0.set t ~key ~data ~length:0 ~compare_key:comparator.Comparator.compare)\n ;;\n\n let add_exn ~comparator t ~key ~data =\n fst\n (Tree0.add_exn\n t\n ~key\n ~data\n ~length:0\n ~compare_key:comparator.Comparator.compare\n ~sexp_of_key:comparator.sexp_of_t)\n ;;\n\n let add ~comparator t ~key ~data =\n try `Ok (add_exn t ~comparator ~key ~data) with\n | _ -> `Duplicate\n ;;\n\n let add_multi ~comparator t ~key ~data =\n Tree0.add_multi t ~key ~data ~length:0 ~compare_key:comparator.Comparator.compare\n |> fst\n ;;\n\n let remove_multi ~comparator t key =\n Tree0.remove_multi t key ~length:0 ~compare_key:comparator.Comparator.compare |> fst\n ;;\n\n let find_multi ~comparator t key =\n Tree0.find_multi t key ~compare_key:comparator.Comparator.compare\n ;;\n\n let change ~comparator t key ~f =\n fst (Tree0.change t key ~f ~length:0 ~compare_key:comparator.Comparator.compare)\n ;;\n\n let update ~comparator t key ~f =\n change ~comparator t key ~f:(fun data -> Some (f data))\n ;;\n\n let find_exn ~comparator t key =\n Tree0.find_exn\n t\n key\n ~compare_key:comparator.Comparator.compare\n ~sexp_of_key:comparator.Comparator.sexp_of_t\n ;;\n\n let find ~comparator t key =\n Tree0.find t key ~compare_key:comparator.Comparator.compare\n ;;\n\n let remove ~comparator t key =\n fst (Tree0.remove t key ~length:0 ~compare_key:comparator.Comparator.compare)\n ;;\n\n let mem ~comparator t key = Tree0.mem t key ~compare_key:comparator.Comparator.compare\n let iter_keys t ~f = Tree0.iter_keys t ~f\n let iter t ~f = Tree0.iter t ~f\n let iteri t ~f = Tree0.iteri t ~f\n let iteri_until t ~f = Tree0.iteri_until t ~f\n\n let iter2 ~comparator t1 t2 ~f =\n Tree0.iter2 t1 t2 ~f ~compare_key:comparator.Comparator.compare\n ;;\n\n let map t ~f = Tree0.map t ~f\n let mapi t ~f = Tree0.mapi t ~f\n let fold t ~init ~f = Tree0.fold t ~f ~init\n let fold_right t ~init ~f = Tree0.fold_right t ~f ~init\n\n let fold2 ~comparator t1 t2 ~init ~f =\n Tree0.fold2 t1 t2 ~init ~f ~compare_key:comparator.Comparator.compare\n ;;\n\n let filter_keys ~comparator t ~f =\n fst (Tree0.filter_keys t ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let filter ~comparator t ~f =\n fst (Tree0.filter t ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let filteri ~comparator t ~f =\n fst (Tree0.filteri t ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let filter_map ~comparator t ~f =\n fst (Tree0.filter_map t ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let filter_mapi ~comparator t ~f =\n fst (Tree0.filter_mapi t ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let partition_mapi ~comparator t ~f =\n let (a, _), (b, _) =\n Tree0.partition_mapi t ~f ~compare_key:comparator.Comparator.compare\n in\n a, b\n ;;\n\n let partition_map ~comparator t ~f =\n let (a, _), (b, _) =\n Tree0.partition_map t ~f ~compare_key:comparator.Comparator.compare\n in\n a, b\n ;;\n\n let partitioni_tf ~comparator t ~f =\n let (a, _), (b, _) =\n Tree0.partitioni_tf t ~f ~compare_key:comparator.Comparator.compare\n in\n a, b\n ;;\n\n let partition_tf ~comparator t ~f =\n let (a, _), (b, _) =\n Tree0.partition_tf t ~f ~compare_key:comparator.Comparator.compare\n in\n a, b\n ;;\n\n let combine_errors ~comparator t =\n Or_error.map\n ~f:fst\n (Tree0.combine_errors\n t\n ~compare_key:comparator.Comparator.compare\n ~sexp_of_key:comparator.Comparator.sexp_of_t)\n ;;\n\n let compare_direct ~comparator compare_data t1 t2 =\n Tree0.compare comparator.Comparator.compare compare_data t1 t2\n ;;\n\n let equal ~comparator compare_data t1 t2 =\n Tree0.equal comparator.Comparator.compare compare_data t1 t2\n ;;\n\n let keys t = Tree0.keys t\n let data t = Tree0.data t\n let to_alist ?key_order t = Tree0.to_alist ?key_order t\n let validate ~name f t = Validate.alist ~name f (to_alist t)\n let validatei ~name f t = Validate.list ~name:(Fn.compose name fst) f (to_alist t)\n\n let symmetric_diff ~comparator t1 t2 ~data_equal =\n Tree0.symmetric_diff t1 t2 ~compare_key:comparator.Comparator.compare ~data_equal\n ;;\n\n let fold_symmetric_diff ~comparator t1 t2 ~data_equal ~init ~f =\n Tree0.fold_symmetric_diff\n t1\n t2\n ~compare_key:comparator.Comparator.compare\n ~data_equal\n ~init\n ~f\n ;;\n\n let merge ~comparator t1 t2 ~f =\n fst (Tree0.merge t1 t2 ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let min_elt t = Tree0.min_elt t\n let min_elt_exn t = Tree0.min_elt_exn t\n let max_elt t = Tree0.max_elt t\n let max_elt_exn t = Tree0.max_elt_exn t\n let for_all t ~f = Tree0.for_all t ~f\n let for_alli t ~f = Tree0.for_alli t ~f\n let exists t ~f = Tree0.exists t ~f\n let existsi t ~f = Tree0.existsi t ~f\n let count t ~f = Tree0.count t ~f\n let counti t ~f = Tree0.counti t ~f\n let split ~comparator t k = Tree0.split t k ~compare_key:comparator.Comparator.compare\n\n let append ~comparator ~lower_part ~upper_part =\n Tree0.append ~lower_part ~upper_part ~compare_key:comparator.Comparator.compare\n ;;\n\n let subrange ~comparator t ~lower_bound ~upper_bound =\n let _, ret, _ =\n Tree0.split_range\n t\n ~lower_bound\n ~upper_bound\n ~compare_key:comparator.Comparator.compare\n in\n ret\n ;;\n\n let fold_range_inclusive ~comparator t ~min ~max ~init ~f =\n Tree0.fold_range_inclusive\n t\n ~min\n ~max\n ~init\n ~f\n ~compare_key:comparator.Comparator.compare\n ;;\n\n let range_to_alist ~comparator t ~min ~max =\n Tree0.range_to_alist t ~min ~max ~compare_key:comparator.Comparator.compare\n ;;\n\n let closest_key ~comparator t dir key =\n Tree0.closest_key t dir key ~compare_key:comparator.Comparator.compare\n ;;\n\n let nth ~comparator:_ t n = Tree0.nth t n\n let nth_exn ~comparator t n = Option.value_exn (nth ~comparator t n)\n\n let rank ~comparator t key =\n Tree0.rank t key ~compare_key:comparator.Comparator.compare\n ;;\n\n let sexp_of_t sexp_of_k sexp_of_v _ t = Tree0.sexp_of_t sexp_of_k sexp_of_v t\n\n let t_of_sexp_direct ~comparator k_of_sexp v_of_sexp sexp =\n fst (Tree0.t_of_sexp_direct k_of_sexp v_of_sexp sexp ~comparator)\n ;;\n\n let to_sequence ~comparator ?order ?keys_greater_or_equal_to ?keys_less_or_equal_to t =\n Tree0.to_sequence\n comparator\n ?order\n ?keys_greater_or_equal_to\n ?keys_less_or_equal_to\n t\n ;;\n\n let binary_search ~comparator:_ t ~compare how v = Tree0.binary_search t ~compare how v\n\n let binary_search_segmented ~comparator:_ t ~segment_of how =\n Tree0.binary_search_segmented t ~segment_of how\n ;;\nend\n\nmodule Using_comparator = struct\n type nonrec ('k, 'v, 'cmp) t = ('k, 'v, 'cmp) t\n\n include Accessors\n\n let empty ~comparator = { tree = Tree0.empty; comparator; length = 0 }\n let singleton ~comparator k v = { comparator; tree = Tree0.singleton k v; length = 1 }\n let of_tree0 ~comparator (tree, length) = { comparator; tree; length }\n let of_tree ~comparator tree = of_tree0 ~comparator (tree, Tree0.length tree)\n let to_tree = to_tree\n\n let of_sorted_array_unchecked ~comparator array =\n of_tree0\n ~comparator\n (Tree0.of_sorted_array_unchecked array ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sorted_array ~comparator array =\n Or_error.map\n (Tree0.of_sorted_array array ~compare_key:comparator.Comparator.compare)\n ~f:(fun tree -> of_tree0 ~comparator tree)\n ;;\n\n let of_alist ~comparator alist =\n match Tree0.of_alist alist ~compare_key:comparator.Comparator.compare with\n | `Ok (tree, length) -> `Ok { comparator; tree; length }\n | `Duplicate_key _ as z -> z\n ;;\n\n let of_alist_or_error ~comparator alist =\n Result.map (Tree0.of_alist_or_error alist ~comparator) ~f:(fun tree ->\n of_tree0 ~comparator tree)\n ;;\n\n let of_alist_exn ~comparator alist =\n of_tree0 ~comparator (Tree0.of_alist_exn alist ~comparator)\n ;;\n\n let of_alist_multi ~comparator alist =\n of_tree0\n ~comparator\n (Tree0.of_alist_multi alist ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_alist_fold ~comparator alist ~init ~f =\n of_tree0\n ~comparator\n (Tree0.of_alist_fold alist ~init ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_alist_reduce ~comparator alist ~f =\n of_tree0\n ~comparator\n (Tree0.of_alist_reduce alist ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_iteri ~comparator ~iteri =\n match Tree0.of_iteri ~compare_key:comparator.Comparator.compare ~iteri with\n | `Ok tree_length -> `Ok (of_tree0 ~comparator tree_length)\n | `Duplicate_key _ as z -> z\n ;;\n\n let of_increasing_iterator_unchecked ~comparator ~len ~f =\n of_tree0 ~comparator (Tree0.of_increasing_iterator_unchecked ~len ~f, len)\n ;;\n\n let of_increasing_sequence ~comparator seq =\n Or_error.map\n ~f:(of_tree0 ~comparator)\n (Tree0.of_increasing_sequence seq ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence ~comparator seq =\n match Tree0.of_sequence seq ~compare_key:comparator.Comparator.compare with\n | `Ok (tree, length) -> `Ok { comparator; tree; length }\n | `Duplicate_key _ as z -> z\n ;;\n\n let of_sequence_or_error ~comparator seq =\n Result.map (Tree0.of_sequence_or_error seq ~comparator) ~f:(fun tree ->\n of_tree0 ~comparator tree)\n ;;\n\n let of_sequence_exn ~comparator seq =\n of_tree0 ~comparator (Tree0.of_sequence_exn seq ~comparator)\n ;;\n\n let of_sequence_multi ~comparator seq =\n of_tree0\n ~comparator\n (Tree0.of_sequence_multi seq ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence_fold ~comparator seq ~init ~f =\n of_tree0\n ~comparator\n (Tree0.of_sequence_fold seq ~init ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let of_sequence_reduce ~comparator seq ~f =\n of_tree0\n ~comparator\n (Tree0.of_sequence_reduce seq ~f ~compare_key:comparator.Comparator.compare)\n ;;\n\n let t_of_sexp_direct ~comparator k_of_sexp v_of_sexp sexp =\n of_tree0 ~comparator (Tree0.t_of_sexp_direct k_of_sexp v_of_sexp sexp ~comparator)\n ;;\n\n module Empty_without_value_restriction (K : Comparator.S1) = struct\n let empty = { tree = Tree0.empty; comparator = K.comparator; length = 0 }\n end\n\n module Tree = Tree\nend\n\ninclude Accessors\n\ntype ('k, 'cmp) comparator =\n (module Comparator.S with type t = 'k and type comparator_witness = 'cmp)\n\nlet comparator_s (type k cmp) t : (k, cmp) comparator =\n (module struct\n type t = k\n type comparator_witness = cmp\n\n let comparator = t.comparator\n end)\n;;\n\nlet to_comparator (type k cmp) ((module M) : (k, cmp) comparator) = M.comparator\nlet empty m = Using_comparator.empty ~comparator:(to_comparator m)\nlet singleton m a = Using_comparator.singleton ~comparator:(to_comparator m) a\nlet of_alist m a = Using_comparator.of_alist ~comparator:(to_comparator m) a\n\nlet of_alist_or_error m a =\n Using_comparator.of_alist_or_error ~comparator:(to_comparator m) a\n;;\n\nlet of_alist_exn m a = Using_comparator.of_alist_exn ~comparator:(to_comparator m) a\nlet of_alist_multi m a = Using_comparator.of_alist_multi ~comparator:(to_comparator m) a\n\nlet of_alist_fold m a ~init ~f =\n Using_comparator.of_alist_fold ~comparator:(to_comparator m) a ~init ~f\n;;\n\nlet of_alist_reduce m a ~f =\n Using_comparator.of_alist_reduce ~comparator:(to_comparator m) a ~f\n;;\n\nlet of_sorted_array_unchecked m a =\n Using_comparator.of_sorted_array_unchecked ~comparator:(to_comparator m) a\n;;\n\nlet of_sorted_array m a =\n Using_comparator.of_sorted_array ~comparator:(to_comparator m) a\n;;\n\nlet of_iteri m ~iteri = Using_comparator.of_iteri ~iteri ~comparator:(to_comparator m)\n\nlet of_increasing_iterator_unchecked m ~len ~f =\n Using_comparator.of_increasing_iterator_unchecked ~len ~f ~comparator:(to_comparator m)\n;;\n\nlet of_increasing_sequence m seq =\n Using_comparator.of_increasing_sequence ~comparator:(to_comparator m) seq\n;;\n\nlet of_sequence m s = Using_comparator.of_sequence ~comparator:(to_comparator m) s\n\nlet of_sequence_or_error m s =\n Using_comparator.of_sequence_or_error ~comparator:(to_comparator m) s\n;;\n\nlet of_sequence_exn m s =\n Using_comparator.of_sequence_exn ~comparator:(to_comparator m) s\n;;\n\nlet of_sequence_multi m s =\n Using_comparator.of_sequence_multi ~comparator:(to_comparator m) s\n;;\n\nlet of_sequence_fold m s ~init ~f =\n Using_comparator.of_sequence_fold ~comparator:(to_comparator m) s ~init ~f\n;;\n\nlet of_sequence_reduce m s ~f =\n Using_comparator.of_sequence_reduce ~comparator:(to_comparator m) s ~f\n;;\n\nmodule M (K : sig\n type t\n type comparator_witness\n end) =\nstruct\n type nonrec 'v t = (K.t, 'v, K.comparator_witness) t\nend\n\nmodule type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\nend\n\nmodule type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Comparator.S with type t := t\nend\n\nmodule type Compare_m = sig end\nmodule type Equal_m = sig end\nmodule type Hash_fold_m = Hasher.S\n\nlet sexp_of_m__t (type k) (module K : Sexp_of_m with type t = k) sexp_of_v t =\n sexp_of_t K.sexp_of_t sexp_of_v (fun _ -> Sexp.Atom \"_\") t\n;;\n\nlet m__t_of_sexp\n (type k cmp)\n (module K : M_of_sexp with type t = k and type comparator_witness = cmp)\n v_of_sexp\n sexp\n =\n Using_comparator.t_of_sexp_direct ~comparator:K.comparator K.t_of_sexp v_of_sexp sexp\n;;\n\nlet m__t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t =\n Inline\n (Explicit_bind\n ( [ \"'k\"; \"'v\" ]\n , Apply\n ( Grammar list_sexp_grammar\n , [ Apply\n ( Grammar Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.tuple2_sexp_grammar\n , [ Explicit_var 0; Explicit_var 1 ] )\n ] ) ))\n;;\n\nlet compare_m__t (module K : Compare_m) compare_v t1 t2 = compare_direct compare_v t1 t2\nlet equal_m__t (module K : Equal_m) equal_v t1 t2 = equal equal_v t1 t2\n\nlet hash_fold_m__t (type k) (module K : Hash_fold_m with type t = k) hash_fold_v state =\n hash_fold_direct K.hash_fold_t hash_fold_v state\n;;\n\nlet merge_skewed t1 t2 ~combine =\n let t1, t2, combine =\n if length t2 <= length t1\n then t1, t2, combine\n else t2, t1, fun ~key v1 v2 -> combine ~key v2 v1\n in\n fold t2 ~init:t1 ~f:(fun ~key ~data:v2 t1 ->\n change t1 key ~f:(function\n | None -> Some v2\n | Some v1 -> Some (combine ~key v1 v2)))\n;;\n\nmodule Poly = struct\n type nonrec ('k, 'v) t = ('k, 'v, Comparator.Poly.comparator_witness) t\n type nonrec ('k, 'v) tree = ('k, 'v) Tree0.t\n type comparator_witness = Comparator.Poly.comparator_witness\n\n include Accessors\n\n let comparator = Comparator.Poly.comparator\n let of_tree tree = { tree; comparator; length = Tree0.length tree }\n\n include Using_comparator.Empty_without_value_restriction (Comparator.Poly)\n\n let singleton a = Using_comparator.singleton ~comparator a\n let of_alist a = Using_comparator.of_alist ~comparator a\n let of_alist_or_error a = Using_comparator.of_alist_or_error ~comparator a\n let of_alist_exn a = Using_comparator.of_alist_exn ~comparator a\n let of_alist_multi a = Using_comparator.of_alist_multi ~comparator a\n let of_alist_fold a ~init ~f = Using_comparator.of_alist_fold ~comparator a ~init ~f\n let of_alist_reduce a ~f = Using_comparator.of_alist_reduce ~comparator a ~f\n\n let of_sorted_array_unchecked a =\n Using_comparator.of_sorted_array_unchecked ~comparator a\n ;;\n\n let of_sorted_array a = Using_comparator.of_sorted_array ~comparator a\n let of_iteri ~iteri = Using_comparator.of_iteri ~iteri ~comparator\n\n let of_increasing_iterator_unchecked ~len ~f =\n Using_comparator.of_increasing_iterator_unchecked ~len ~f ~comparator\n ;;\n\n let of_increasing_sequence seq =\n Using_comparator.of_increasing_sequence ~comparator seq\n ;;\n\n let of_sequence s = Using_comparator.of_sequence ~comparator s\n let of_sequence_or_error s = Using_comparator.of_sequence_or_error ~comparator s\n let of_sequence_exn s = Using_comparator.of_sequence_exn ~comparator s\n let of_sequence_multi s = Using_comparator.of_sequence_multi ~comparator s\n\n let of_sequence_fold s ~init ~f =\n Using_comparator.of_sequence_fold ~comparator s ~init ~f\n ;;\n\n let of_sequence_reduce s ~f = Using_comparator.of_sequence_reduce ~comparator s ~f\nend\n","open! Import\nopen! T\n\nmodule Or_duplicate = struct\n type 'a t =\n [ `Ok of 'a\n | `Duplicate\n ]\n [@@deriving_inline sexp_of]\n\n let sexp_of_t :\n 'a. ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_a -> function\n | `Ok v0 -> Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Ok\"; _of_a v0 ]\n | `Duplicate -> Ppx_sexp_conv_lib.Sexp.Atom \"Duplicate\"\n ;;\n\n [@@@end]\nend\n\nmodule Without_comparator = struct\n type ('key, 'cmp, 'z) t = 'z\nend\n\nmodule With_comparator = struct\n type ('key, 'cmp, 'z) t = comparator:('key, 'cmp) Comparator.t -> 'z\nend\n\nmodule With_first_class_module = struct\n type ('key, 'cmp, 'z) t =\n (module Comparator.S with type t = 'key and type comparator_witness = 'cmp) -> 'z\nend\n\nmodule Symmetric_diff_element = struct\n type ('k, 'v) t = 'k * [ `Left of 'v | `Right of 'v | `Unequal of 'v * 'v ]\n [@@deriving_inline compare, sexp]\n\n let compare :\n 'k 'v. ('k -> 'k -> int) -> ('v -> 'v -> int) -> ('k, 'v) t -> ('k, 'v) t -> int\n =\n fun _cmp__k _cmp__v a__001_ b__002_ ->\n let t__003_, t__004_ = a__001_ in\n let t__005_, t__006_ = b__002_ in\n match _cmp__k t__003_ t__005_ with\n | 0 ->\n if Ppx_compare_lib.phys_equal t__004_ t__006_\n then 0\n else (\n match t__004_, t__006_ with\n | `Left _left__007_, `Left _right__008_ -> _cmp__v _left__007_ _right__008_\n | `Right _left__009_, `Right _right__010_ -> _cmp__v _left__009_ _right__010_\n | `Unequal _left__011_, `Unequal _right__012_ ->\n let t__013_, t__014_ = _left__011_ in\n let t__015_, t__016_ = _right__012_ in\n (match _cmp__v t__013_ t__015_ with\n | 0 -> _cmp__v t__014_ t__016_\n | n -> n)\n | x, y -> Ppx_compare_lib.polymorphic_compare x y)\n | n -> n\n ;;\n\n let t_of_sexp :\n 'k 'v. (Ppx_sexp_conv_lib.Sexp.t -> 'k) -> (Ppx_sexp_conv_lib.Sexp.t -> 'v)\n -> Ppx_sexp_conv_lib.Sexp.t -> ('k, 'v) t\n =\n let _tp_loc = \"map_intf.ml.Symmetric_diff_element.t\" in\n fun _of_k _of_v -> function\n | Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ] ->\n let v0 = _of_k v0\n and v1 =\n (fun sexp ->\n try\n match sexp with\n | Ppx_sexp_conv_lib.Sexp.Atom atom as _sexp ->\n (match atom with\n | \"Left\" -> Ppx_sexp_conv_lib.Conv_error.ptag_takes_args _tp_loc _sexp\n | \"Right\" -> Ppx_sexp_conv_lib.Conv_error.ptag_takes_args _tp_loc _sexp\n | \"Unequal\" -> Ppx_sexp_conv_lib.Conv_error.ptag_takes_args _tp_loc _sexp\n | _ -> Ppx_sexp_conv_lib.Conv_error.no_variant_match ())\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom atom :: sexp_args) as _sexp ->\n (match atom with\n | \"Left\" as _tag ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_v v0 in\n `Left v0\n | _ ->\n Ppx_sexp_conv_lib.Conv_error.ptag_incorrect_n_args _tp_loc _tag _sexp)\n | \"Right\" as _tag ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 = _of_v v0 in\n `Right v0\n | _ ->\n Ppx_sexp_conv_lib.Conv_error.ptag_incorrect_n_args _tp_loc _tag _sexp)\n | \"Unequal\" as _tag ->\n (match sexp_args with\n | [ v0 ] ->\n let v0 =\n match v0 with\n | Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ] ->\n let v0 = _of_v v0\n and v1 = _of_v v1 in\n v0, v1\n | sexp ->\n Ppx_sexp_conv_lib.Conv_error.tuple_of_size_n_expected\n _tp_loc\n 2\n sexp\n in\n `Unequal v0\n | _ ->\n Ppx_sexp_conv_lib.Conv_error.ptag_incorrect_n_args _tp_loc _tag _sexp)\n | _ -> Ppx_sexp_conv_lib.Conv_error.no_variant_match ())\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp\n -> Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_poly_var _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_poly_var _tp_loc sexp\n with\n | Ppx_sexp_conv_lib.Conv_error.No_variant_match ->\n Ppx_sexp_conv_lib.Conv_error.no_matching_variant_found _tp_loc sexp)\n v1\n in\n v0, v1\n | sexp -> Ppx_sexp_conv_lib.Conv_error.tuple_of_size_n_expected _tp_loc 2 sexp\n ;;\n\n let sexp_of_t :\n 'k 'v. ('k -> Ppx_sexp_conv_lib.Sexp.t) -> ('v -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('k, 'v) t -> Ppx_sexp_conv_lib.Sexp.t\n =\n fun _of_k _of_v -> function\n | v0, v1 ->\n let v0 = _of_k v0\n and v1 =\n match v1 with\n | `Left v0 ->\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Left\"; _of_v v0 ]\n | `Right v0 ->\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"Right\"; _of_v v0 ]\n | `Unequal v0 ->\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"Unequal\"\n ; (let v0, v1 = v0 in\n let v0 = _of_v v0\n and v1 = _of_v v1 in\n Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ])\n ]\n in\n Ppx_sexp_conv_lib.Sexp.List [ v0; v1 ]\n ;;\n\n [@@@end]\nend\n\nmodule Continue_or_stop = struct\n type t =\n | Continue\n | Stop\n [@@deriving_inline compare, enumerate, equal, sexp_of]\n\n let compare = (Ppx_compare_lib.polymorphic_compare : t -> t -> int)\n let all = ([ Continue; Stop ] : t list)\n let equal = (Ppx_compare_lib.polymorphic_equal : t -> t -> bool)\n\n let sexp_of_t =\n (function\n | Continue -> Ppx_sexp_conv_lib.Sexp.Atom \"Continue\"\n | Stop -> Ppx_sexp_conv_lib.Sexp.Atom \"Stop\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\nend\n\nmodule Finished_or_unfinished = struct\n type t =\n | Finished\n | Unfinished\n [@@deriving_inline compare, enumerate, equal, sexp_of]\n\n let compare = (Ppx_compare_lib.polymorphic_compare : t -> t -> int)\n let all = ([ Finished; Unfinished ] : t list)\n let equal = (Ppx_compare_lib.polymorphic_equal : t -> t -> bool)\n\n let sexp_of_t =\n (function\n | Finished -> Ppx_sexp_conv_lib.Sexp.Atom \"Finished\"\n | Unfinished -> Ppx_sexp_conv_lib.Sexp.Atom \"Unfinished\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\nend\n\nmodule type Accessors_generic = sig\n type ('a, 'b, 'cmp) t\n type ('a, 'b, 'cmp) tree\n type 'a key\n type 'cmp cmp\n type ('a, 'cmp, 'z) options\n\n val invariants : ('k, 'cmp, ('k, 'v, 'cmp) t -> bool) options\n val is_empty : (_, _, _) t -> bool\n val length : (_, _, _) t -> int\n\n val add\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> key:'k key -> data:'v -> ('k, 'v, 'cmp) t Or_duplicate.t )\n options\n\n val add_exn\n : ('k, 'cmp, ('k, 'v, 'cmp) t -> key:'k key -> data:'v -> ('k, 'v, 'cmp) t) options\n\n val set\n : ('k, 'cmp, ('k, 'v, 'cmp) t -> key:'k key -> data:'v -> ('k, 'v, 'cmp) t) options\n\n val add_multi\n : ( 'k\n , 'cmp\n , ('k, 'v list, 'cmp) t -> key:'k key -> data:'v -> ('k, 'v list, 'cmp) t )\n options\n\n val remove_multi\n : ('k, 'cmp, ('k, 'v list, 'cmp) t -> 'k key -> ('k, 'v list, 'cmp) t) options\n\n val find_multi : ('k, 'cmp, ('k, 'v list, 'cmp) t -> 'k key -> 'v list) options\n\n val change\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> 'k key -> f:('v option -> 'v option) -> ('k, 'v, 'cmp) t )\n options\n\n val update\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> 'k key -> f:('v option -> 'v) -> ('k, 'v, 'cmp) t )\n options\n\n val find : ('k, 'cmp, ('k, 'v, 'cmp) t -> 'k key -> 'v option) options\n val find_exn : ('k, 'cmp, ('k, 'v, 'cmp) t -> 'k key -> 'v) options\n val remove : ('k, 'cmp, ('k, 'v, 'cmp) t -> 'k key -> ('k, 'v, 'cmp) t) options\n val mem : ('k, 'cmp, ('k, _, 'cmp) t -> 'k key -> bool) options\n val iter_keys : ('k, _, _) t -> f:('k key -> unit) -> unit\n val iter : (_, 'v, _) t -> f:('v -> unit) -> unit\n val iteri : ('k, 'v, _) t -> f:(key:'k key -> data:'v -> unit) -> unit\n\n val iteri_until\n : ('k, 'v, _) t\n -> f:(key:'k key -> data:'v -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n val iter2\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> f:(key:'k key\n -> data:[ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ]\n -> unit)\n -> unit )\n options\n\n val map : ('k, 'v1, 'cmp) t -> f:('v1 -> 'v2) -> ('k, 'v2, 'cmp) t\n val mapi : ('k, 'v1, 'cmp) t -> f:(key:'k key -> data:'v1 -> 'v2) -> ('k, 'v2, 'cmp) t\n val fold : ('k, 'v, _) t -> init:'a -> f:(key:'k key -> data:'v -> 'a -> 'a) -> 'a\n\n val fold_right\n : ('k, 'v, _) t\n -> init:'a\n -> f:(key:'k key -> data:'v -> 'a -> 'a)\n -> 'a\n\n val fold2\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> init:'a\n -> f:(key:'k key\n -> data:[ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ]\n -> 'a\n -> 'a)\n -> 'a )\n options\n\n val filter_keys\n : ('k, 'cmp, ('k, 'v, 'cmp) t -> f:('k key -> bool) -> ('k, 'v, 'cmp) t) options\n\n val filter : ('k, 'cmp, ('k, 'v, 'cmp) t -> f:('v -> bool) -> ('k, 'v, 'cmp) t) options\n\n val filteri\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> f:(key:'k key -> data:'v -> bool) -> ('k, 'v, 'cmp) t )\n options\n\n val filter_map\n : ('k, 'cmp, ('k, 'v1, 'cmp) t -> f:('v1 -> 'v2 option) -> ('k, 'v2, 'cmp) t) options\n\n val filter_mapi\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> f:(key:'k key -> data:'v1 -> 'v2 option)\n -> ('k, 'v2, 'cmp) t )\n options\n\n val partition_mapi\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> f:(key:'k key -> data:'v1 -> ('v2, 'v3) Either.t)\n -> ('k, 'v2, 'cmp) t * ('k, 'v3, 'cmp) t )\n options\n\n val partition_map\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> f:('v1 -> ('v2, 'v3) Either.t)\n -> ('k, 'v2, 'cmp) t * ('k, 'v3, 'cmp) t )\n options\n\n val partitioni_tf\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> f:(key:'k key -> data:'v -> bool)\n -> ('k, 'v, 'cmp) t * ('k, 'v, 'cmp) t )\n options\n\n val partition_tf\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> f:('v -> bool) -> ('k, 'v, 'cmp) t * ('k, 'v, 'cmp) t )\n options\n\n val combine_errors\n : ('k, 'cmp, ('k, 'v Or_error.t, 'cmp) t -> ('k, 'v, 'cmp) t Or_error.t) options\n\n val compare_direct\n : ( 'k\n , 'cmp\n , ('v -> 'v -> int) -> ('k, 'v, 'cmp) t -> ('k, 'v, 'cmp) t -> int )\n options\n\n val equal\n : ( 'k\n , 'cmp\n , ('v -> 'v -> bool) -> ('k, 'v, 'cmp) t -> ('k, 'v, 'cmp) t -> bool )\n options\n\n val keys : ('k, _, _) t -> 'k key list\n val data : (_, 'v, _) t -> 'v list\n\n val to_alist\n : ?key_order:[ `Increasing | `Decreasing ]\n -> ('k, 'v, _) t\n -> ('k key * 'v) list\n\n val validate\n : name:('k key -> string)\n -> 'v Validate.check\n -> ('k, 'v, _) t Validate.check\n\n val validatei\n : name:('k key -> string)\n -> ('k key * 'v) Validate.check\n -> ('k, 'v, _) t Validate.check\n\n val merge\n : ( 'k\n , 'cmp\n , ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> f:(key:'k key\n -> [ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ]\n -> 'v3 option)\n -> ('k, 'v3, 'cmp) t )\n options\n\n val symmetric_diff\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> data_equal:('v -> 'v -> bool)\n -> ('k key, 'v) Symmetric_diff_element.t Sequence.t )\n options\n\n val fold_symmetric_diff\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> data_equal:('v -> 'v -> bool)\n -> init:'a\n -> f:('a -> ('k key, 'v) Symmetric_diff_element.t -> 'a)\n -> 'a )\n options\n\n val min_elt : ('k, 'v, _) t -> ('k key * 'v) option\n val min_elt_exn : ('k, 'v, _) t -> 'k key * 'v\n val max_elt : ('k, 'v, _) t -> ('k key * 'v) option\n val max_elt_exn : ('k, 'v, _) t -> 'k key * 'v\n val for_all : ('k, 'v, _) t -> f:('v -> bool) -> bool\n val for_alli : ('k, 'v, _) t -> f:(key:'k key -> data:'v -> bool) -> bool\n val exists : ('k, 'v, _) t -> f:('v -> bool) -> bool\n val existsi : ('k, 'v, _) t -> f:(key:'k key -> data:'v -> bool) -> bool\n val count : ('k, 'v, _) t -> f:('v -> bool) -> int\n val counti : ('k, 'v, _) t -> f:(key:'k key -> data:'v -> bool) -> int\n\n val split\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> 'k key\n -> ('k, 'v, 'cmp) t * ('k key * 'v) option * ('k, 'v, 'cmp) t )\n options\n\n val append\n : ( 'k\n , 'cmp\n , lower_part:('k, 'v, 'cmp) t\n -> upper_part:('k, 'v, 'cmp) t\n -> [ `Ok of ('k, 'v, 'cmp) t | `Overlapping_key_ranges ] )\n options\n\n val subrange\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> lower_bound:'k key Maybe_bound.t\n -> upper_bound:'k key Maybe_bound.t\n -> ('k, 'v, 'cmp) t )\n options\n\n val fold_range_inclusive\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> min:'k key\n -> max:'k key\n -> init:'a\n -> f:(key:'k key -> data:'v -> 'a -> 'a)\n -> 'a )\n options\n\n val range_to_alist\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t -> min:'k key -> max:'k key -> ('k key * 'v) list )\n options\n\n val closest_key\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'k key\n -> ('k key * 'v) option )\n options\n\n val nth : ('k, 'cmp, ('k, 'v, 'cmp) t -> int -> ('k key * 'v) option) options\n val nth_exn : ('k, 'cmp, ('k, 'v, 'cmp) t -> int -> 'k key * 'v) options\n val rank : ('k, 'cmp, ('k, _, 'cmp) t -> 'k key -> int option) options\n val to_tree : ('k, 'v, 'cmp) t -> ('k key, 'v, 'cmp) tree\n\n val to_sequence\n : ( 'k\n , 'cmp\n , ?order:[ `Increasing_key | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:'k key\n -> ?keys_less_or_equal_to:'k key\n -> ('k, 'v, 'cmp) t\n -> ('k key * 'v) Sequence.t )\n options\n\n val binary_search\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> compare:(key:'k key -> data:'v -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> ('k key * 'v) option )\n options\n\n val binary_search_segmented\n : ( 'k\n , 'cmp\n , ('k, 'v, 'cmp) t\n -> segment_of:(key:'k key -> data:'v -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> ('k key * 'v) option )\n options\nend\n\nmodule type Accessors1 = sig\n type 'a t\n type 'a tree\n type key\n type comparator_witness\n\n val invariants : _ t -> bool\n val is_empty : _ t -> bool\n val length : _ t -> int\n val add : 'a t -> key:key -> data:'a -> 'a t Or_duplicate.t\n val add_exn : 'a t -> key:key -> data:'a -> 'a t\n val set : 'a t -> key:key -> data:'a -> 'a t\n val add_multi : 'a list t -> key:key -> data:'a -> 'a list t\n val remove_multi : 'a list t -> key -> 'a list t\n val find_multi : 'a list t -> key -> 'a list\n val change : 'a t -> key -> f:('a option -> 'a option) -> 'a t\n val update : 'a t -> key -> f:('a option -> 'a) -> 'a t\n val find : 'a t -> key -> 'a option\n val find_exn : 'a t -> key -> 'a\n val remove : 'a t -> key -> 'a t\n val mem : _ t -> key -> bool\n val iter_keys : _ t -> f:(key -> unit) -> unit\n val iter : 'a t -> f:('a -> unit) -> unit\n val iteri : 'a t -> f:(key:key -> data:'a -> unit) -> unit\n\n val iteri_until\n : 'a t\n -> f:(key:key -> data:'a -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n val iter2\n : 'a t\n -> 'b t\n -> f:(key:key -> data:[ `Left of 'a | `Right of 'b | `Both of 'a * 'b ] -> unit)\n -> unit\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n val mapi : 'a t -> f:(key:key -> data:'a -> 'b) -> 'b t\n val fold : 'a t -> init:'b -> f:(key:key -> data:'a -> 'b -> 'b) -> 'b\n val fold_right : 'a t -> init:'b -> f:(key:key -> data:'a -> 'b -> 'b) -> 'b\n\n val fold2\n : 'a t\n -> 'b t\n -> init:'c\n -> f:(key:key -> data:[ `Left of 'a | `Right of 'b | `Both of 'a * 'b ] -> 'c -> 'c)\n -> 'c\n\n val filter_keys : 'a t -> f:(key -> bool) -> 'a t\n val filter : 'a t -> f:('a -> bool) -> 'a t\n val filteri : 'a t -> f:(key:key -> data:'a -> bool) -> 'a t\n val filter_map : 'a t -> f:('a -> 'b option) -> 'b t\n val filter_mapi : 'a t -> f:(key:key -> data:'a -> 'b option) -> 'b t\n val partition_mapi : 'a t -> f:(key:key -> data:'a -> ('b, 'c) Either.t) -> 'b t * 'c t\n val partition_map : 'a t -> f:('a -> ('b, 'c) Either.t) -> 'b t * 'c t\n val partitioni_tf : 'a t -> f:(key:key -> data:'a -> bool) -> 'a t * 'a t\n val partition_tf : 'a t -> f:('a -> bool) -> 'a t * 'a t\n val combine_errors : 'a Or_error.t t -> 'a t Or_error.t\n val compare_direct : ('a -> 'a -> int) -> 'a t -> 'a t -> int\n val equal : ('a -> 'a -> bool) -> 'a t -> 'a t -> bool\n val keys : _ t -> key list\n val data : 'a t -> 'a list\n val to_alist : ?key_order:[ `Increasing | `Decreasing ] -> 'a t -> (key * 'a) list\n val validate : name:(key -> string) -> 'a Validate.check -> 'a t Validate.check\n\n val validatei\n : name:(key -> string)\n -> (key * 'a) Validate.check\n -> 'a t Validate.check\n\n val merge\n : 'a t\n -> 'b t\n -> f:(key:key -> [ `Left of 'a | `Right of 'b | `Both of 'a * 'b ] -> 'c option)\n -> 'c t\n\n val symmetric_diff\n : 'a t\n -> 'a t\n -> data_equal:('a -> 'a -> bool)\n -> (key, 'a) Symmetric_diff_element.t Sequence.t\n\n val fold_symmetric_diff\n : 'a t\n -> 'a t\n -> data_equal:('a -> 'a -> bool)\n -> init:'c\n -> f:('c -> (key, 'a) Symmetric_diff_element.t -> 'c)\n -> 'c\n\n val min_elt : 'a t -> (key * 'a) option\n val min_elt_exn : 'a t -> key * 'a\n val max_elt : 'a t -> (key * 'a) option\n val max_elt_exn : 'a t -> key * 'a\n val for_all : 'a t -> f:('a -> bool) -> bool\n val for_alli : 'a t -> f:(key:key -> data:'a -> bool) -> bool\n val exists : 'a t -> f:('a -> bool) -> bool\n val existsi : 'a t -> f:(key:key -> data:'a -> bool) -> bool\n val count : 'a t -> f:('a -> bool) -> int\n val counti : 'a t -> f:(key:key -> data:'a -> bool) -> int\n val split : 'a t -> key -> 'a t * (key * 'a) option * 'a t\n\n val append\n : lower_part:'a t\n -> upper_part:'a t\n -> [ `Ok of 'a t | `Overlapping_key_ranges ]\n\n val subrange\n : 'a t\n -> lower_bound:key Maybe_bound.t\n -> upper_bound:key Maybe_bound.t\n -> 'a t\n\n val fold_range_inclusive\n : 'a t\n -> min:key\n -> max:key\n -> init:'b\n -> f:(key:key -> data:'a -> 'b -> 'b)\n -> 'b\n\n val range_to_alist : 'a t -> min:key -> max:key -> (key * 'a) list\n\n val closest_key\n : 'a t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> key\n -> (key * 'a) option\n\n val nth : 'a t -> int -> (key * 'a) option\n val nth_exn : 'a t -> int -> key * 'a\n val rank : _ t -> key -> int option\n val to_tree : 'a t -> 'a tree\n\n val to_sequence\n : ?order:[ `Increasing_key | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:key\n -> ?keys_less_or_equal_to:key\n -> 'a t\n -> (key * 'a) Sequence.t\n\n val binary_search\n : 'a t\n -> compare:(key:key -> data:'a -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> (key * 'a) option\n\n val binary_search_segmented\n : 'a t\n -> segment_of:(key:key -> data:'a -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> (key * 'a) option\nend\n\nmodule type Accessors2 = sig\n type ('a, 'b) t\n type ('a, 'b) tree\n type comparator_witness\n\n val invariants : (_, _) t -> bool\n val is_empty : (_, _) t -> bool\n val length : (_, _) t -> int\n val add : ('a, 'b) t -> key:'a -> data:'b -> ('a, 'b) t Or_duplicate.t\n val add_exn : ('a, 'b) t -> key:'a -> data:'b -> ('a, 'b) t\n val set : ('a, 'b) t -> key:'a -> data:'b -> ('a, 'b) t\n val add_multi : ('a, 'b list) t -> key:'a -> data:'b -> ('a, 'b list) t\n val remove_multi : ('a, 'b list) t -> 'a -> ('a, 'b list) t\n val find_multi : ('a, 'b list) t -> 'a -> 'b list\n val change : ('a, 'b) t -> 'a -> f:('b option -> 'b option) -> ('a, 'b) t\n val update : ('a, 'b) t -> 'a -> f:('b option -> 'b) -> ('a, 'b) t\n val find : ('a, 'b) t -> 'a -> 'b option\n val find_exn : ('a, 'b) t -> 'a -> 'b\n val remove : ('a, 'b) t -> 'a -> ('a, 'b) t\n val mem : ('a, 'b) t -> 'a -> bool\n val iter_keys : ('a, _) t -> f:('a -> unit) -> unit\n val iter : (_, 'b) t -> f:('b -> unit) -> unit\n val iteri : ('a, 'b) t -> f:(key:'a -> data:'b -> unit) -> unit\n\n val iteri_until\n : ('a, 'b) t\n -> f:(key:'a -> data:'b -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n val iter2\n : ('a, 'b) t\n -> ('a, 'c) t\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> unit)\n -> unit\n\n val map : ('a, 'b) t -> f:('b -> 'c) -> ('a, 'c) t\n val mapi : ('a, 'b) t -> f:(key:'a -> data:'b -> 'c) -> ('a, 'c) t\n val fold : ('a, 'b) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n val fold_right : ('a, 'b) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n\n val fold2\n : ('a, 'b) t\n -> ('a, 'c) t\n -> init:'d\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd -> 'd)\n -> 'd\n\n val filter_keys : ('a, 'b) t -> f:('a -> bool) -> ('a, 'b) t\n val filter : ('a, 'b) t -> f:('b -> bool) -> ('a, 'b) t\n val filteri : ('a, 'b) t -> f:(key:'a -> data:'b -> bool) -> ('a, 'b) t\n val filter_map : ('a, 'b) t -> f:('b -> 'c option) -> ('a, 'c) t\n val filter_mapi : ('a, 'b) t -> f:(key:'a -> data:'b -> 'c option) -> ('a, 'c) t\n\n val partition_mapi\n : ('a, 'b) t\n -> f:(key:'a -> data:'b -> ('c, 'd) Either.t)\n -> ('a, 'c) t * ('a, 'd) t\n\n val partition_map\n : ('a, 'b) t\n -> f:('b -> ('c, 'd) Either.t)\n -> ('a, 'c) t * ('a, 'd) t\n\n val partitioni_tf\n : ('a, 'b) t\n -> f:(key:'a -> data:'b -> bool)\n -> ('a, 'b) t * ('a, 'b) t\n\n val partition_tf : ('a, 'b) t -> f:('b -> bool) -> ('a, 'b) t * ('a, 'b) t\n val combine_errors : ('a, 'b Or_error.t) t -> ('a, 'b) t Or_error.t\n val compare_direct : ('b -> 'b -> int) -> ('a, 'b) t -> ('a, 'b) t -> int\n val equal : ('b -> 'b -> bool) -> ('a, 'b) t -> ('a, 'b) t -> bool\n val keys : ('a, _) t -> 'a list\n val data : (_, 'b) t -> 'b list\n val to_alist : ?key_order:[ `Increasing | `Decreasing ] -> ('a, 'b) t -> ('a * 'b) list\n val validate : name:('a -> string) -> 'b Validate.check -> ('a, 'b) t Validate.check\n\n val validatei\n : name:('a -> string)\n -> ('a * 'b) Validate.check\n -> ('a, 'b) t Validate.check\n\n val merge\n : ('a, 'b) t\n -> ('a, 'c) t\n -> f:(key:'a -> [ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd option)\n -> ('a, 'd) t\n\n val symmetric_diff\n : ('a, 'b) t\n -> ('a, 'b) t\n -> data_equal:('b -> 'b -> bool)\n -> ('a, 'b) Symmetric_diff_element.t Sequence.t\n\n val fold_symmetric_diff\n : ('a, 'b) t\n -> ('a, 'b) t\n -> data_equal:('b -> 'b -> bool)\n -> init:'c\n -> f:('c -> ('a, 'b) Symmetric_diff_element.t -> 'c)\n -> 'c\n\n val min_elt : ('a, 'b) t -> ('a * 'b) option\n val min_elt_exn : ('a, 'b) t -> 'a * 'b\n val max_elt : ('a, 'b) t -> ('a * 'b) option\n val max_elt_exn : ('a, 'b) t -> 'a * 'b\n val for_all : (_, 'b) t -> f:('b -> bool) -> bool\n val for_alli : ('a, 'b) t -> f:(key:'a -> data:'b -> bool) -> bool\n val exists : (_, 'b) t -> f:('b -> bool) -> bool\n val existsi : ('a, 'b) t -> f:(key:'a -> data:'b -> bool) -> bool\n val count : (_, 'b) t -> f:('b -> bool) -> int\n val counti : ('a, 'b) t -> f:(key:'a -> data:'b -> bool) -> int\n val split : ('a, 'b) t -> 'a -> ('a, 'b) t * ('a * 'b) option * ('a, 'b) t\n\n val append\n : lower_part:('a, 'b) t\n -> upper_part:('a, 'b) t\n -> [ `Ok of ('a, 'b) t | `Overlapping_key_ranges ]\n\n val subrange\n : ('a, 'b) t\n -> lower_bound:'a Maybe_bound.t\n -> upper_bound:'a Maybe_bound.t\n -> ('a, 'b) t\n\n val fold_range_inclusive\n : ('a, 'b) t\n -> min:'a\n -> max:'a\n -> init:'c\n -> f:(key:'a -> data:'b -> 'c -> 'c)\n -> 'c\n\n val range_to_alist : ('a, 'b) t -> min:'a -> max:'a -> ('a * 'b) list\n\n val closest_key\n : ('a, 'b) t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'a\n -> ('a * 'b) option\n\n val nth : ('a, 'b) t -> int -> ('a * 'b) option\n val nth_exn : ('a, 'b) t -> int -> 'a * 'b\n val rank : ('a, _) t -> 'a -> int option\n val to_tree : ('a, 'b) t -> ('a, 'b) tree\n\n val to_sequence\n : ?order:[ `Increasing_key | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:'a\n -> ?keys_less_or_equal_to:'a\n -> ('a, 'b) t\n -> ('a * 'b) Sequence.t\n\n val binary_search\n : ('k, 'v) t\n -> compare:(key:'k -> data:'v -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> ('k * 'v) option\n\n val binary_search_segmented\n : ('k, 'v) t\n -> segment_of:(key:'k -> data:'v -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> ('k * 'v) option\nend\n\nmodule type Accessors3 = sig\n type ('a, 'b, 'cmp) t\n type ('a, 'b, 'cmp) tree\n\n val invariants : (_, _, _) t -> bool\n val is_empty : (_, _, _) t -> bool\n val length : (_, _, _) t -> int\n val add : ('a, 'b, 'cmp) t -> key:'a -> data:'b -> ('a, 'b, 'cmp) t Or_duplicate.t\n val add_exn : ('a, 'b, 'cmp) t -> key:'a -> data:'b -> ('a, 'b, 'cmp) t\n val set : ('a, 'b, 'cmp) t -> key:'a -> data:'b -> ('a, 'b, 'cmp) t\n val add_multi : ('a, 'b list, 'cmp) t -> key:'a -> data:'b -> ('a, 'b list, 'cmp) t\n val remove_multi : ('a, 'b list, 'cmp) t -> 'a -> ('a, 'b list, 'cmp) t\n val find_multi : ('a, 'b list, 'cmp) t -> 'a -> 'b list\n val change : ('a, 'b, 'cmp) t -> 'a -> f:('b option -> 'b option) -> ('a, 'b, 'cmp) t\n val update : ('a, 'b, 'cmp) t -> 'a -> f:('b option -> 'b) -> ('a, 'b, 'cmp) t\n val find : ('a, 'b, 'cmp) t -> 'a -> 'b option\n val find_exn : ('a, 'b, 'cmp) t -> 'a -> 'b\n val remove : ('a, 'b, 'cmp) t -> 'a -> ('a, 'b, 'cmp) t\n val mem : ('a, 'b, 'cmp) t -> 'a -> bool\n val iter_keys : ('a, _, 'cmp) t -> f:('a -> unit) -> unit\n val iter : (_, 'b, 'cmp) t -> f:('b -> unit) -> unit\n val iteri : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> unit) -> unit\n\n val iteri_until\n : ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n val iter2\n : ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> unit)\n -> unit\n\n val map : ('a, 'b, 'cmp) t -> f:('b -> 'c) -> ('a, 'c, 'cmp) t\n val mapi : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> 'c) -> ('a, 'c, 'cmp) t\n val fold : ('a, 'b, _) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n val fold_right : ('a, 'b, _) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n\n val fold2\n : ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> init:'d\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd -> 'd)\n -> 'd\n\n val filter_keys : ('a, 'b, 'cmp) t -> f:('a -> bool) -> ('a, 'b, 'cmp) t\n val filter : ('a, 'b, 'cmp) t -> f:('b -> bool) -> ('a, 'b, 'cmp) t\n val filteri : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> bool) -> ('a, 'b, 'cmp) t\n val filter_map : ('a, 'b, 'cmp) t -> f:('b -> 'c option) -> ('a, 'c, 'cmp) t\n\n val filter_mapi\n : ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> 'c option)\n -> ('a, 'c, 'cmp) t\n\n val partition_mapi\n : ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> ('c, 'd) Either.t)\n -> ('a, 'c, 'cmp) t * ('a, 'd, 'cmp) t\n\n val partition_map\n : ('a, 'b, 'cmp) t\n -> f:('b -> ('c, 'd) Either.t)\n -> ('a, 'c, 'cmp) t * ('a, 'd, 'cmp) t\n\n val partitioni_tf\n : ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> bool)\n -> ('a, 'b, 'cmp) t * ('a, 'b, 'cmp) t\n\n val partition_tf\n : ('a, 'b, 'cmp) t\n -> f:('b -> bool)\n -> ('a, 'b, 'cmp) t * ('a, 'b, 'cmp) t\n\n val combine_errors : ('a, 'b Or_error.t, 'cmp) t -> ('a, 'b, 'cmp) t Or_error.t\n val compare_direct : ('b -> 'b -> int) -> ('a, 'b, 'cmp) t -> ('a, 'b, 'cmp) t -> int\n val equal : ('b -> 'b -> bool) -> ('a, 'b, 'cmp) t -> ('a, 'b, 'cmp) t -> bool\n val keys : ('a, _, _) t -> 'a list\n val data : (_, 'b, _) t -> 'b list\n\n val to_alist\n : ?key_order:[ `Increasing | `Decreasing ]\n -> ('a, 'b, _) t\n -> ('a * 'b) list\n\n val validate : name:('a -> string) -> 'b Validate.check -> ('a, 'b, _) t Validate.check\n\n val validatei\n : name:('a -> string)\n -> ('a * 'b) Validate.check\n -> ('a, 'b, _) t Validate.check\n\n val merge\n : ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> f:(key:'a -> [ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd option)\n -> ('a, 'd, 'cmp) t\n\n val symmetric_diff\n : ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> data_equal:('b -> 'b -> bool)\n -> ('a, 'b) Symmetric_diff_element.t Sequence.t\n\n val fold_symmetric_diff\n : ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> data_equal:('b -> 'b -> bool)\n -> init:'c\n -> f:('c -> ('a, 'b) Symmetric_diff_element.t -> 'c)\n -> 'c\n\n val min_elt : ('a, 'b, 'cmp) t -> ('a * 'b) option\n val min_elt_exn : ('a, 'b, 'cmp) t -> 'a * 'b\n val max_elt : ('a, 'b, 'cmp) t -> ('a * 'b) option\n val max_elt_exn : ('a, 'b, 'cmp) t -> 'a * 'b\n val for_all : (_, 'b, _) t -> f:('b -> bool) -> bool\n val for_alli : ('a, 'b, _) t -> f:(key:'a -> data:'b -> bool) -> bool\n val exists : (_, 'b, _) t -> f:('b -> bool) -> bool\n val existsi : ('a, 'b, _) t -> f:(key:'a -> data:'b -> bool) -> bool\n val count : (_, 'b, _) t -> f:('b -> bool) -> int\n val counti : ('a, 'b, _) t -> f:(key:'a -> data:'b -> bool) -> int\n\n val split\n : ('k, 'v, 'cmp) t\n -> 'k\n -> ('k, 'v, 'cmp) t * ('k * 'v) option * ('k, 'v, 'cmp) t\n\n val append\n : lower_part:('k, 'v, 'cmp) t\n -> upper_part:('k, 'v, 'cmp) t\n -> [ `Ok of ('k, 'v, 'cmp) t | `Overlapping_key_ranges ]\n\n val subrange\n : ('k, 'v, 'cmp) t\n -> lower_bound:'k Maybe_bound.t\n -> upper_bound:'k Maybe_bound.t\n -> ('k, 'v, 'cmp) t\n\n val fold_range_inclusive\n : ('a, 'b, _) t\n -> min:'a\n -> max:'a\n -> init:'c\n -> f:(key:'a -> data:'b -> 'c -> 'c)\n -> 'c\n\n val range_to_alist : ('a, 'b, _) t -> min:'a -> max:'a -> ('a * 'b) list\n\n val closest_key\n : ('a, 'b, _) t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'a\n -> ('a * 'b) option\n\n val nth : ('a, 'b, _) t -> int -> ('a * 'b) option\n val nth_exn : ('a, 'b, _) t -> int -> 'a * 'b\n val rank : ('a, _, _) t -> 'a -> int option\n val to_tree : ('a, 'b, 'cmp) t -> ('a, 'b, 'cmp) tree\n\n val to_sequence\n : ?order:[ `Increasing_key | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:'a\n -> ?keys_less_or_equal_to:'a\n -> ('a, 'b, _) t\n -> ('a * 'b) Sequence.t\n\n val binary_search\n : ('k, 'v, _) t\n -> compare:(key:'k -> data:'v -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> ('k * 'v) option\n\n val binary_search_segmented\n : ('k, 'v, _) t\n -> segment_of:(key:'k -> data:'v -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> ('k * 'v) option\nend\n\nmodule type Accessors3_with_comparator = sig\n type ('a, 'b, 'cmp) t\n type ('a, 'b, 'cmp) tree\n\n val invariants : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> bool\n val is_empty : ('a, 'b, 'cmp) t -> bool\n val length : ('a, 'b, 'cmp) t -> int\n\n val add\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> key:'a\n -> data:'b\n -> ('a, 'b, 'cmp) t Or_duplicate.t\n\n val add_exn\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> key:'a\n -> data:'b\n -> ('a, 'b, 'cmp) t\n\n val set\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> key:'a\n -> data:'b\n -> ('a, 'b, 'cmp) t\n\n val add_multi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b list, 'cmp) t\n -> key:'a\n -> data:'b\n -> ('a, 'b list, 'cmp) t\n\n val remove_multi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b list, 'cmp) t\n -> 'a\n -> ('a, 'b list, 'cmp) t\n\n val find_multi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b list, 'cmp) t\n -> 'a\n -> 'b list\n\n val change\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> 'a\n -> f:('b option -> 'b option)\n -> ('a, 'b, 'cmp) t\n\n val update\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> 'a\n -> f:('b option -> 'b)\n -> ('a, 'b, 'cmp) t\n\n val find : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> 'a -> 'b option\n val find_exn : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> 'a -> 'b\n\n val remove\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> 'a\n -> ('a, 'b, 'cmp) t\n\n val mem : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> 'a -> bool\n val iter_keys : ('a, _, 'cmp) t -> f:('a -> unit) -> unit\n val iter : (_, 'b, 'cmp) t -> f:('b -> unit) -> unit\n val iteri : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> unit) -> unit\n\n val iteri_until\n : ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n val iter2\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> unit)\n -> unit\n\n val map : ('a, 'b, 'cmp) t -> f:('b -> 'c) -> ('a, 'c, 'cmp) t\n val mapi : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> 'c) -> ('a, 'c, 'cmp) t\n val fold : ('a, 'b, _) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n val fold_right : ('a, 'b, _) t -> init:'c -> f:(key:'a -> data:'b -> 'c -> 'c) -> 'c\n\n val fold2\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> init:'d\n -> f:(key:'a -> data:[ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd -> 'd)\n -> 'd\n\n val filter_keys\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:('a -> bool)\n -> ('a, 'b, 'cmp) t\n\n val filter\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:('b -> bool)\n -> ('a, 'b, 'cmp) t\n\n val filteri\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> bool)\n -> ('a, 'b, 'cmp) t\n\n val filter_map\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:('b -> 'c option)\n -> ('a, 'c, 'cmp) t\n\n val filter_mapi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> 'c option)\n -> ('a, 'c, 'cmp) t\n\n val partition_mapi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> ('c, 'd) Either.t)\n -> ('a, 'c, 'cmp) t * ('a, 'd, 'cmp) t\n\n val partition_map\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:('b -> ('c, 'd) Either.t)\n -> ('a, 'c, 'cmp) t * ('a, 'd, 'cmp) t\n\n val partitioni_tf\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:(key:'a -> data:'b -> bool)\n -> ('a, 'b, 'cmp) t * ('a, 'b, 'cmp) t\n\n val partition_tf\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> f:('b -> bool)\n -> ('a, 'b, 'cmp) t * ('a, 'b, 'cmp) t\n\n val combine_errors\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b Or_error.t, 'cmp) t\n -> ('a, 'b, 'cmp) t Or_error.t\n\n val compare_direct\n : comparator:('a, 'cmp) Comparator.t\n -> ('b -> 'b -> int)\n -> ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> int\n\n val equal\n : comparator:('a, 'cmp) Comparator.t\n -> ('b -> 'b -> bool)\n -> ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> bool\n\n val keys : ('a, _, _) t -> 'a list\n val data : (_, 'b, _) t -> 'b list\n\n val to_alist\n : ?key_order:[ `Increasing | `Decreasing ]\n -> ('a, 'b, _) t\n -> ('a * 'b) list\n\n val validate : name:('a -> string) -> 'b Validate.check -> ('a, 'b, _) t Validate.check\n\n val validatei\n : name:('a -> string)\n -> ('a * 'b) Validate.check\n -> ('a, 'b, _) t Validate.check\n\n val merge\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> ('a, 'c, 'cmp) t\n -> f:(key:'a -> [ `Left of 'b | `Right of 'c | `Both of 'b * 'c ] -> 'd option)\n -> ('a, 'd, 'cmp) t\n\n val symmetric_diff\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> data_equal:('b -> 'b -> bool)\n -> ('a, 'b) Symmetric_diff_element.t Sequence.t\n\n val fold_symmetric_diff\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> ('a, 'b, 'cmp) t\n -> data_equal:('b -> 'b -> bool)\n -> init:'c\n -> f:('c -> ('a, 'b) Symmetric_diff_element.t -> 'c)\n -> 'c\n\n val min_elt : ('a, 'b, 'cmp) t -> ('a * 'b) option\n val min_elt_exn : ('a, 'b, 'cmp) t -> 'a * 'b\n val max_elt : ('a, 'b, 'cmp) t -> ('a * 'b) option\n val max_elt_exn : ('a, 'b, 'cmp) t -> 'a * 'b\n val for_all : ('a, 'b, 'cmp) t -> f:('b -> bool) -> bool\n val for_alli : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> bool) -> bool\n val exists : ('a, 'b, 'cmp) t -> f:('b -> bool) -> bool\n val existsi : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> bool) -> bool\n val count : ('a, 'b, 'cmp) t -> f:('b -> bool) -> int\n val counti : ('a, 'b, 'cmp) t -> f:(key:'a -> data:'b -> bool) -> int\n\n val split\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> 'a\n -> ('a, 'b, 'cmp) t * ('a * 'b) option * ('a, 'b, 'cmp) t\n\n val append\n : comparator:('a, 'cmp) Comparator.t\n -> lower_part:('a, 'b, 'cmp) t\n -> upper_part:('a, 'b, 'cmp) t\n -> [ `Ok of ('a, 'b, 'cmp) t | `Overlapping_key_ranges ]\n\n val subrange\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> lower_bound:'a Maybe_bound.t\n -> upper_bound:'a Maybe_bound.t\n -> ('a, 'b, 'cmp) t\n\n val fold_range_inclusive\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> min:'a\n -> max:'a\n -> init:'c\n -> f:(key:'a -> data:'b -> 'c -> 'c)\n -> 'c\n\n val range_to_alist\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> min:'a\n -> max:'a\n -> ('a * 'b) list\n\n val closest_key\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'a\n -> ('a * 'b) option\n\n val nth\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) t\n -> int\n -> ('a * 'b) option\n\n val nth_exn : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> int -> 'a * 'b\n val rank : comparator:('a, 'cmp) Comparator.t -> ('a, 'b, 'cmp) t -> 'a -> int option\n val to_tree : ('a, 'b, 'cmp) t -> ('a, 'b, 'cmp) tree\n\n val to_sequence\n : comparator:('a, 'cmp) Comparator.t\n -> ?order:[ `Increasing_key | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:'a\n -> ?keys_less_or_equal_to:'a\n -> ('a, 'b, 'cmp) t\n -> ('a * 'b) Sequence.t\n\n val binary_search\n : comparator:('k, 'cmp) Comparator.t\n -> ('k, 'v, 'cmp) t\n -> compare:(key:'k -> data:'v -> 'key -> int)\n -> [ `Last_strictly_less_than\n | `Last_less_than_or_equal_to\n | `Last_equal_to\n | `First_equal_to\n | `First_greater_than_or_equal_to\n | `First_strictly_greater_than\n ]\n -> 'key\n -> ('k * 'v) option\n\n val binary_search_segmented\n : comparator:('k, 'cmp) Comparator.t\n -> ('k, 'v, 'cmp) t\n -> segment_of:(key:'k -> data:'v -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> ('k * 'v) option\nend\n\n(** Consistency checks (same as in [Container]). *)\nmodule Check_accessors\n (T : T3)\n (Tree : T3)\n (Key : T1)\n (Cmp : T1)\n (Options : T3)\n (M : Accessors_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Options.t\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) T.t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n with type 'a key := 'a Key.t\n with type 'cmp cmp := 'cmp Cmp.t) =\nstruct end\n\nmodule Check_accessors1 (M : Accessors1) =\n Check_accessors\n (struct\n type ('a, 'b, 'c) t = 'b M.t\n end)\n (struct\n type ('a, 'b, 'c) t = 'b M.tree\n end)\n (struct\n type 'a t = M.key\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors2 (M : Accessors2) =\n Check_accessors\n (struct\n type ('a, 'b, 'c) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b, 'c) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors3 (M : Accessors3) =\n Check_accessors\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.t\n end)\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'a t = 'a\n end)\n (Without_comparator)\n (M)\n\nmodule Check_accessors3_with_comparator (M : Accessors3_with_comparator) =\n Check_accessors\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.t\n end)\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'a t = 'a\n end)\n (With_comparator)\n (M)\n\nmodule type Creators_generic = sig\n type ('k, 'v, 'cmp) t\n type ('k, 'v, 'cmp) tree\n type 'k key\n type ('a, 'cmp, 'z) options\n type 'cmp cmp\n\n val empty : ('k, 'cmp, ('k, _, 'cmp) t) options\n val singleton : ('k, 'cmp, 'k key -> 'v -> ('k, 'v, 'cmp) t) options\n\n val of_sorted_array\n : ('k, 'cmp, ('k key * 'v) array -> ('k, 'v, 'cmp) t Or_error.t) options\n\n val of_sorted_array_unchecked\n : ('k, 'cmp, ('k key * 'v) array -> ('k, 'v, 'cmp) t) options\n\n val of_increasing_iterator_unchecked\n : ('k, 'cmp, len:int -> f:(int -> 'k key * 'v) -> ('k, 'v, 'cmp) t) options\n\n val of_alist\n : ( 'k\n , 'cmp\n , ('k key * 'v) list -> [ `Ok of ('k, 'v, 'cmp) t | `Duplicate_key of 'k key ] )\n options\n\n val of_alist_or_error\n : ('k, 'cmp, ('k key * 'v) list -> ('k, 'v, 'cmp) t Or_error.t) options\n\n val of_alist_exn : ('k, 'cmp, ('k key * 'v) list -> ('k, 'v, 'cmp) t) options\n val of_alist_multi : ('k, 'cmp, ('k key * 'v) list -> ('k, 'v list, 'cmp) t) options\n\n val of_alist_fold\n : ( 'k\n , 'cmp\n , ('k key * 'v1) list -> init:'v2 -> f:('v2 -> 'v1 -> 'v2) -> ('k, 'v2, 'cmp) t )\n options\n\n val of_alist_reduce\n : ('k, 'cmp, ('k key * 'v) list -> f:('v -> 'v -> 'v) -> ('k, 'v, 'cmp) t) options\n\n val of_increasing_sequence\n : ('k, 'cmp, ('k key * 'v) Sequence.t -> ('k, 'v, 'cmp) t Or_error.t) options\n\n val of_sequence\n : ( 'k\n , 'cmp\n , ('k key * 'v) Sequence.t -> [ `Ok of ('k, 'v, 'cmp) t | `Duplicate_key of 'k key ]\n )\n options\n\n val of_sequence_or_error\n : ('k, 'cmp, ('k key * 'v) Sequence.t -> ('k, 'v, 'cmp) t Or_error.t) options\n\n val of_sequence_exn : ('k, 'cmp, ('k key * 'v) Sequence.t -> ('k, 'v, 'cmp) t) options\n\n val of_sequence_multi\n : ('k, 'cmp, ('k key * 'v) Sequence.t -> ('k, 'v list, 'cmp) t) options\n\n val of_sequence_fold\n : ( 'k\n , 'cmp\n , ('k key * 'v1) Sequence.t\n -> init:'v2\n -> f:('v2 -> 'v1 -> 'v2)\n -> ('k, 'v2, 'cmp) t )\n options\n\n val of_sequence_reduce\n : ( 'k\n , 'cmp\n , ('k key * 'v) Sequence.t -> f:('v -> 'v -> 'v) -> ('k, 'v, 'cmp) t )\n options\n\n val of_iteri\n : ( 'k\n , 'cmp\n , iteri:(f:(key:'k key -> data:'v -> unit) -> unit)\n -> [ `Ok of ('k, 'v, 'cmp) t | `Duplicate_key of 'k key ] )\n options\n\n val of_tree : ('k, 'cmp, ('k key, 'v, 'cmp) tree -> ('k, 'v, 'cmp) t) options\nend\n\nmodule type Creators1 = sig\n type 'a t\n type 'a tree\n type key\n type comparator_witness\n\n val empty : _ t\n val singleton : key -> 'a -> 'a t\n val of_alist : (key * 'a) list -> [ `Ok of 'a t | `Duplicate_key of key ]\n val of_alist_or_error : (key * 'a) list -> 'a t Or_error.t\n val of_alist_exn : (key * 'a) list -> 'a t\n val of_alist_multi : (key * 'a) list -> 'a list t\n val of_alist_fold : (key * 'a) list -> init:'b -> f:('b -> 'a -> 'b) -> 'b t\n val of_alist_reduce : (key * 'a) list -> f:('a -> 'a -> 'a) -> 'a t\n val of_sorted_array : (key * 'a) array -> 'a t Or_error.t\n val of_sorted_array_unchecked : (key * 'a) array -> 'a t\n val of_increasing_iterator_unchecked : len:int -> f:(int -> key * 'a) -> 'a t\n val of_increasing_sequence : (key * 'a) Sequence.t -> 'a t Or_error.t\n val of_sequence : (key * 'a) Sequence.t -> [ `Ok of 'a t | `Duplicate_key of key ]\n val of_sequence_or_error : (key * 'a) Sequence.t -> 'a t Or_error.t\n val of_sequence_exn : (key * 'a) Sequence.t -> 'a t\n val of_sequence_multi : (key * 'a) Sequence.t -> 'a list t\n val of_sequence_fold : (key * 'a) Sequence.t -> init:'b -> f:('b -> 'a -> 'b) -> 'b t\n val of_sequence_reduce : (key * 'a) Sequence.t -> f:('a -> 'a -> 'a) -> 'a t\n\n val of_iteri\n : iteri:(f:(key:key -> data:'v -> unit) -> unit)\n -> [ `Ok of 'v t | `Duplicate_key of key ]\n\n val of_tree : 'a tree -> 'a t\nend\n\nmodule type Creators2 = sig\n type ('a, 'b) t\n type ('a, 'b) tree\n type comparator_witness\n\n val empty : (_, _) t\n val singleton : 'a -> 'b -> ('a, 'b) t\n val of_alist : ('a * 'b) list -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a ]\n val of_alist_or_error : ('a * 'b) list -> ('a, 'b) t Or_error.t\n val of_alist_exn : ('a * 'b) list -> ('a, 'b) t\n val of_alist_multi : ('a * 'b) list -> ('a, 'b list) t\n val of_alist_fold : ('a * 'b) list -> init:'c -> f:('c -> 'b -> 'c) -> ('a, 'c) t\n val of_alist_reduce : ('a * 'b) list -> f:('b -> 'b -> 'b) -> ('a, 'b) t\n val of_sorted_array : ('a * 'b) array -> ('a, 'b) t Or_error.t\n val of_sorted_array_unchecked : ('a * 'b) array -> ('a, 'b) t\n val of_increasing_iterator_unchecked : len:int -> f:(int -> 'a * 'b) -> ('a, 'b) t\n val of_increasing_sequence : ('a * 'b) Sequence.t -> ('a, 'b) t Or_error.t\n val of_sequence : ('a * 'b) Sequence.t -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a ]\n val of_sequence_or_error : ('a * 'b) Sequence.t -> ('a, 'b) t Or_error.t\n val of_sequence_exn : ('a * 'b) Sequence.t -> ('a, 'b) t\n val of_sequence_multi : ('a * 'b) Sequence.t -> ('a, 'b list) t\n\n val of_sequence_fold\n : ('a * 'b) Sequence.t\n -> init:'c\n -> f:('c -> 'b -> 'c)\n -> ('a, 'c) t\n\n val of_sequence_reduce : ('a * 'b) Sequence.t -> f:('b -> 'b -> 'b) -> ('a, 'b) t\n\n val of_iteri\n : iteri:(f:(key:'a -> data:'b -> unit) -> unit)\n -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a ]\n\n val of_tree : ('a, 'b) tree -> ('a, 'b) t\nend\n\nmodule type Creators3_with_comparator = sig\n type ('a, 'b, 'cmp) t\n type ('a, 'b, 'cmp) tree\n\n val empty : comparator:('a, 'cmp) Comparator.t -> ('a, _, 'cmp) t\n val singleton : comparator:('a, 'cmp) Comparator.t -> 'a -> 'b -> ('a, 'b, 'cmp) t\n\n val of_alist\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> [ `Ok of ('a, 'b, 'cmp) t | `Duplicate_key of 'a ]\n\n val of_alist_or_error\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> ('a, 'b, 'cmp) t Or_error.t\n\n val of_alist_exn\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> ('a, 'b, 'cmp) t\n\n val of_alist_multi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> ('a, 'b list, 'cmp) t\n\n val of_alist_fold\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> init:'c\n -> f:('c -> 'b -> 'c)\n -> ('a, 'c, 'cmp) t\n\n val of_alist_reduce\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) list\n -> f:('b -> 'b -> 'b)\n -> ('a, 'b, 'cmp) t\n\n val of_sorted_array\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) array\n -> ('a, 'b, 'cmp) t Or_error.t\n\n val of_sorted_array_unchecked\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) array\n -> ('a, 'b, 'cmp) t\n\n val of_increasing_iterator_unchecked\n : comparator:('a, 'cmp) Comparator.t\n -> len:int\n -> f:(int -> 'a * 'b)\n -> ('a, 'b, 'cmp) t\n\n val of_increasing_sequence\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> ('a, 'b, 'cmp) t Or_error.t\n\n val of_sequence\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> [ `Ok of ('a, 'b, 'cmp) t | `Duplicate_key of 'a ]\n\n val of_sequence_or_error\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> ('a, 'b, 'cmp) t Or_error.t\n\n val of_sequence_exn\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> ('a, 'b, 'cmp) t\n\n val of_sequence_multi\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> ('a, 'b list, 'cmp) t\n\n val of_sequence_fold\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> init:'c\n -> f:('c -> 'b -> 'c)\n -> ('a, 'c, 'cmp) t\n\n val of_sequence_reduce\n : comparator:('a, 'cmp) Comparator.t\n -> ('a * 'b) Sequence.t\n -> f:('b -> 'b -> 'b)\n -> ('a, 'b, 'cmp) t\n\n val of_iteri\n : comparator:('a, 'cmp) Comparator.t\n -> iteri:(f:(key:'a -> data:'b -> unit) -> unit)\n -> [ `Ok of ('a, 'b, 'cmp) t | `Duplicate_key of 'a ]\n\n val of_tree\n : comparator:('a, 'cmp) Comparator.t\n -> ('a, 'b, 'cmp) tree\n -> ('a, 'b, 'cmp) t\nend\n\nmodule Check_creators\n (T : T3)\n (Tree : T3)\n (Key : T1)\n (Cmp : T1)\n (Options : T3)\n (M : Creators_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Options.t\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) T.t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n with type 'a key := 'a Key.t\n with type 'a cmp := 'a Cmp.t) =\nstruct end\n\nmodule Check_creators1 (M : Creators1) =\n Check_creators\n (struct\n type ('a, 'b, 'c) t = 'b M.t\n end)\n (struct\n type ('a, 'b, 'c) t = 'b M.tree\n end)\n (struct\n type 'a t = M.key\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_creators2 (M : Creators2) =\n Check_creators\n (struct\n type ('a, 'b, 'c) t = ('a, 'b) M.t\n end)\n (struct\n type ('a, 'b, 'c) t = ('a, 'b) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'a t = M.comparator_witness\n end)\n (Without_comparator)\n (M)\n\nmodule Check_creators3_with_comparator (M : Creators3_with_comparator) =\n Check_creators\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.t\n end)\n (struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) M.tree\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type 'a t = 'a\n end)\n (With_comparator)\n (M)\n\nmodule type Creators_and_accessors_generic = sig\n include Creators_generic\n\n include\n Accessors_generic\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) tree\n with type 'a key := 'a key\n with type 'a cmp := 'a cmp\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) options\nend\n\nmodule type Creators_and_accessors1 = sig\n include Creators1\n\n include\n Accessors1\n with type 'a t := 'a t\n with type 'a tree := 'a tree\n with type key := key\n with type comparator_witness := comparator_witness\nend\n\nmodule type Creators_and_accessors2 = sig\n include Creators2\n\n include\n Accessors2\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) tree\n with type comparator_witness := comparator_witness\nend\n\nmodule type Creators_and_accessors3_with_comparator = sig\n include Creators3_with_comparator\n\n include\n Accessors3_with_comparator\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) tree\nend\n\nmodule type S_poly = Creators_and_accessors2\n\nmodule type For_deriving = sig\n type ('a, 'b, 'c) t\n\n module type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end\n\n module type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Comparator.S with type t := t\n end\n\n module type Compare_m = sig end\n module type Equal_m = sig end\n module type Hash_fold_m = Hasher.S\n\n val sexp_of_m__t\n : (module Sexp_of_m with type t = 'k)\n -> ('v -> Sexp.t)\n -> ('k, 'v, 'cmp) t\n -> Sexp.t\n\n val m__t_of_sexp\n : (module M_of_sexp with type t = 'k and type comparator_witness = 'cmp)\n -> (Sexp.t -> 'v)\n -> Sexp.t\n -> ('k, 'v, 'cmp) t\n\n val m__t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t\n\n val compare_m__t\n : (module Compare_m)\n -> ('v -> 'v -> int)\n -> ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> int\n\n val equal_m__t\n : (module Equal_m)\n -> ('v -> 'v -> bool)\n -> ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> bool\n\n val hash_fold_m__t\n : (module Hash_fold_m with type t = 'k)\n -> (Hash.state -> 'v -> Hash.state)\n -> Hash.state\n -> ('k, 'v, _) t\n -> Hash.state\nend\n\nmodule type Map = sig\n (** [Map] is a functional data structure (balanced binary tree) implementing finite maps\n over a totally-ordered domain, called a \"key\". *)\n\n type ('key, +'value, 'cmp) t\n\n module Or_duplicate = Or_duplicate\n module Continue_or_stop = Continue_or_stop\n\n module Finished_or_unfinished : sig\n type t = Finished_or_unfinished.t =\n | Finished\n | Unfinished\n [@@deriving_inline compare, enumerate, equal, sexp_of]\n\n val compare : t -> t -> int\n val all : t list\n val equal : t -> t -> bool\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n (** Maps [Continue] to [Finished] and [Stop] to [Unfinished]. *)\n val of_continue_or_stop : Continue_or_stop.t -> t\n\n (** Maps [Finished] to [Continue] and [Unfinished] to [Stop]. *)\n val to_continue_or_stop : t -> Continue_or_stop.t\n end\n\n type ('k, 'cmp) comparator =\n (module Comparator.S with type t = 'k and type comparator_witness = 'cmp)\n\n (** Test if the invariants of the internal AVL search tree hold. *)\n val invariants : (_, _, _) t -> bool\n\n (** Returns a first-class module that can be used to build other map/set/etc.\n with the same notion of comparison. *)\n val comparator_s : ('a, _, 'cmp) t -> ('a, 'cmp) comparator\n\n val comparator : ('a, _, 'cmp) t -> ('a, 'cmp) Comparator.t\n\n (** The empty map. *)\n val empty : ('a, 'cmp) comparator -> ('a, 'b, 'cmp) t\n\n (** A map with one (key, data) pair. *)\n val singleton : ('a, 'cmp) comparator -> 'a -> 'b -> ('a, 'b, 'cmp) t\n\n (** Creates a map from an association list with unique keys. *)\n val of_alist\n : ('a, 'cmp) comparator\n -> ('a * 'b) list\n -> [ `Ok of ('a, 'b, 'cmp) t | `Duplicate_key of 'a ]\n\n (** Creates a map from an association list with unique keys, returning an error if\n duplicate ['a] keys are found. *)\n val of_alist_or_error\n : ('a, 'cmp) comparator\n -> ('a * 'b) list\n -> ('a, 'b, 'cmp) t Or_error.t\n\n (** Creates a map from an association list with unique keys, raising an exception if\n duplicate ['a] keys are found. *)\n val of_alist_exn : ('a, 'cmp) comparator -> ('a * 'b) list -> ('a, 'b, 'cmp) t\n\n (** Creates a map from an association list with possibly repeated keys. The values in\n the map for a given key appear in the same order as they did in the association\n list. *)\n val of_alist_multi : ('a, 'cmp) comparator -> ('a * 'b) list -> ('a, 'b list, 'cmp) t\n\n (** Combines an association list into a map, folding together bound values with common\n keys. *)\n val of_alist_fold\n : ('a, 'cmp) comparator\n -> ('a * 'b) list\n -> init:'c\n -> f:('c -> 'b -> 'c)\n -> ('a, 'c, 'cmp) t\n\n (** Combines an association list into a map, reducing together bound values with common\n keys. *)\n val of_alist_reduce\n : ('a, 'cmp) comparator\n -> ('a * 'b) list\n -> f:('b -> 'b -> 'b)\n -> ('a, 'b, 'cmp) t\n\n (** [of_iteri ~iteri] behaves like [of_alist], except that instead of taking a concrete\n data structure, it takes an iteration function. For instance, to convert a string table\n into a map: [of_iteri (module String) ~f:(Hashtbl.iteri table)]. It is faster than\n adding the elements one by one. *)\n val of_iteri\n : ('a, 'cmp) comparator\n -> iteri:(f:(key:'a -> data:'b -> unit) -> unit)\n -> [ `Ok of ('a, 'b, 'cmp) t | `Duplicate_key of 'a ]\n\n (** Creates a map from a sorted array of key-data pairs. The input array must be sorted\n (either in ascending or descending order), as given by the relevant comparator, and\n must not contain duplicate keys. If either of these conditions does not hold,\n an error is returned. *)\n val of_sorted_array\n : ('a, 'cmp) comparator\n -> ('a * 'b) array\n -> ('a, 'b, 'cmp) t Or_error.t\n\n (** Like [of_sorted_array] except that it returns a map with broken invariants when an\n [Error] would have been returned. *)\n val of_sorted_array_unchecked\n : ('a, 'cmp) comparator\n -> ('a * 'b) array\n -> ('a, 'b, 'cmp) t\n\n (** [of_increasing_iterator_unchecked c ~len ~f] behaves like [of_sorted_array_unchecked c\n (Array.init len ~f)], with the additional restriction that a decreasing order is not\n supported. The advantage is not requiring you to allocate an intermediate array. [f]\n will be called with 0, 1, ... [len - 1], in order. *)\n val of_increasing_iterator_unchecked\n : ('a, 'cmp) comparator\n -> len:int\n -> f:(int -> 'a * 'b)\n -> ('a, 'b, 'cmp) t\n\n (** [of_increasing_sequence c seq] behaves like [of_sorted_array c (Sequence.to_array\n seq)], but does not allocate the intermediate array.\n\n The sequence will be folded over once, and the additional time complexity is {e O(n)}.\n *)\n val of_increasing_sequence\n : ('k, 'cmp) comparator\n -> ('k * 'v) Sequence.t\n -> ('k, 'v, 'cmp) t Or_error.t\n\n (** Creates a map from an association sequence with unique keys.\n\n [of_sequence c seq] behaves like [of_alist c (Sequence.to_list seq)] but\n does not allocate the intermediate list.\n\n If your sequence is increasing, use [of_increasing_sequence].\n *)\n val of_sequence\n : ('k, 'cmp) comparator\n -> ('k * 'v) Sequence.t\n -> [ `Ok of ('k, 'v, 'cmp) t | `Duplicate_key of 'k ]\n\n (** Creates a map from an association sequence with unique keys, returning an error if\n duplicate ['a] keys are found.\n\n [of_sequence_or_error c seq] behaves like [of_alist_or_error c (Sequence.to_list seq)]\n but does not allocate the intermediate list.\n *)\n val of_sequence_or_error\n : ('a, 'cmp) comparator\n -> ('a * 'b) Sequence.t\n -> ('a, 'b, 'cmp) t Or_error.t\n\n (** Creates a map from an association sequence with unique keys, raising an exception if\n duplicate ['a] keys are found.\n\n [of_sequence_exn c seq] behaves like [of_alist_exn c (Sequence.to_list seq)] but\n does not allocate the intermediate list.\n *)\n val of_sequence_exn : ('a, 'cmp) comparator -> ('a * 'b) Sequence.t -> ('a, 'b, 'cmp) t\n\n (** Creates a map from an association sequence with possibly repeated keys. The values in\n the map for a given key appear in the same order as they did in the association\n list.\n\n [of_sequence_multi c seq] behaves like [of_alist_exn c (Sequence.to_list seq)] but\n does not allocate the intermediate list.\n *)\n val of_sequence_multi\n : ('a, 'cmp) comparator\n -> ('a * 'b) Sequence.t\n -> ('a, 'b list, 'cmp) t\n\n (** Combines an association sequence into a map, folding together bound values with common\n keys.\n\n [of_sequence_fold c seq ~init ~f] behaves like [of_alist_fold c (Sequence.to_list seq) ~init ~f]\n but does not allocate the intermediate list.\n *)\n val of_sequence_fold\n : ('a, 'cmp) comparator\n -> ('a * 'b) Sequence.t\n -> init:'c\n -> f:('c -> 'b -> 'c)\n -> ('a, 'c, 'cmp) t\n\n (** Combines an association sequence into a map, reducing together bound values with common\n keys.\n\n [of_sequence_reduce c seq ~f] behaves like [of_alist_reduce c (Sequence.to_list seq) ~f]\n but does not allocate the intermediate list. *)\n val of_sequence_reduce\n : ('a, 'cmp) comparator\n -> ('a * 'b) Sequence.t\n -> f:('b -> 'b -> 'b)\n -> ('a, 'b, 'cmp) t\n\n (** Tests whether a map is empty. *)\n val is_empty : (_, _, _) t -> bool\n\n (** [length map] returns the number of elements in [map]. O(1), but [Tree.length] is\n O(n). *)\n val length : (_, _, _) t -> int\n\n (** Returns a new map with the specified new binding; if the key was already bound, its\n previous binding disappears. *)\n val set : ('k, 'v, 'cmp) t -> key:'k -> data:'v -> ('k, 'v, 'cmp) t\n\n (** [add t ~key ~data] adds a new entry to [t] mapping [key] to [data] and returns [`Ok]\n with the new map, or if [key] is already present in [t], returns [`Duplicate]. *)\n val add : ('k, 'v, 'cmp) t -> key:'k -> data:'v -> ('k, 'v, 'cmp) t Or_duplicate.t\n\n val add_exn : ('k, 'v, 'cmp) t -> key:'k -> data:'v -> ('k, 'v, 'cmp) t\n\n (** If [key] is not present then add a singleton list, otherwise, cons data onto the\n head of the existing list. *)\n val add_multi : ('k, 'v list, 'cmp) t -> key:'k -> data:'v -> ('k, 'v list, 'cmp) t\n\n (** If the key is present, then remove its head element; if the result is empty, remove\n the key. *)\n val remove_multi : ('k, 'v list, 'cmp) t -> 'k -> ('k, 'v list, 'cmp) t\n\n (** Returns the value bound to the given key, or the empty list if there is none. *)\n val find_multi : ('k, 'v list, 'cmp) t -> 'k -> 'v list\n\n (** [change t key ~f] returns a new map [m] that is the same as [t] on all keys except\n for [key], and whose value for [key] is defined by [f], i.e., [find m key = f (find\n t key)]. *)\n val change : ('k, 'v, 'cmp) t -> 'k -> f:('v option -> 'v option) -> ('k, 'v, 'cmp) t\n\n (** [update t key ~f] is [change t key ~f:(fun o -> Some (f o))]. *)\n val update : ('k, 'v, 'cmp) t -> 'k -> f:('v option -> 'v) -> ('k, 'v, 'cmp) t\n\n\n (** Returns [Some value] bound to the given key, or [None] if none exists. *)\n val find : ('k, 'v, 'cmp) t -> 'k -> 'v option\n\n (** Returns the value bound to the given key, raising [Caml.Not_found] or [Not_found_s]\n if none exists. *)\n val find_exn : ('k, 'v, 'cmp) t -> 'k -> 'v\n\n (** Returns a new map with any binding for the key in question removed. *)\n val remove : ('k, 'v, 'cmp) t -> 'k -> ('k, 'v, 'cmp) t\n\n (** [mem map key] tests whether [map] contains a binding for [key]. *)\n val mem : ('k, _, 'cmp) t -> 'k -> bool\n\n val iter_keys : ('k, _, _) t -> f:('k -> unit) -> unit\n val iter : (_, 'v, _) t -> f:('v -> unit) -> unit\n val iteri : ('k, 'v, _) t -> f:(key:'k -> data:'v -> unit) -> unit\n\n (** Iterates until the first time [f] returns [Stop]. If [f] returns [Stop], the final\n result is [Unfinished]. Otherwise, the final result is [Finished]. *)\n val iteri_until\n : ('k, 'v, _) t\n -> f:(key:'k -> data:'v -> Continue_or_stop.t)\n -> Finished_or_unfinished.t\n\n (** Iterates two maps side by side. The complexity of this function is O(M + N). If two\n inputs are [[(0, a); (1, a)]] and [[(1, b); (2, b)]], [f] will be called with [[(0,\n `Left a); (1, `Both (a, b)); (2, `Right b)]]. *)\n val iter2\n : ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> f:(key:'k -> data:[ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ] -> unit)\n -> unit\n\n (** Returns a new map with bound values replaced by [f] applied to the bound values.*)\n val map : ('k, 'v1, 'cmp) t -> f:('v1 -> 'v2) -> ('k, 'v2, 'cmp) t\n\n (** Like [map], but the passed function takes both [key] and [data] as arguments. *)\n val mapi : ('k, 'v1, 'cmp) t -> f:(key:'k -> data:'v1 -> 'v2) -> ('k, 'v2, 'cmp) t\n\n (** Folds over keys and data in the map in increasing order of [key]. *)\n val fold : ('k, 'v, _) t -> init:'a -> f:(key:'k -> data:'v -> 'a -> 'a) -> 'a\n\n (** Folds over keys and data in the map in decreasing order of [key]. *)\n val fold_right : ('k, 'v, _) t -> init:'a -> f:(key:'k -> data:'v -> 'a -> 'a) -> 'a\n\n (** Folds over two maps side by side, like [iter2]. *)\n val fold2\n : ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> init:'a\n -> f:(key:'k\n -> data:[ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ]\n -> 'a\n -> 'a)\n -> 'a\n\n (** [filter], [filteri], [filter_keys], [filter_map], and [filter_mapi] run in O(n * lg\n n) time; they simply accumulate each key & data pair retained by [f] into a new map\n using [add]. *)\n val filter_keys : ('k, 'v, 'cmp) t -> f:('k -> bool) -> ('k, 'v, 'cmp) t\n\n val filter : ('k, 'v, 'cmp) t -> f:('v -> bool) -> ('k, 'v, 'cmp) t\n val filteri : ('k, 'v, 'cmp) t -> f:(key:'k -> data:'v -> bool) -> ('k, 'v, 'cmp) t\n\n (** Returns a new map with bound values filtered by [f] applied to the bound values. *)\n val filter_map : ('k, 'v1, 'cmp) t -> f:('v1 -> 'v2 option) -> ('k, 'v2, 'cmp) t\n\n (** Like [filter_map], but the passed function takes both [key] and [data] as\n arguments. *)\n val filter_mapi\n : ('k, 'v1, 'cmp) t\n -> f:(key:'k -> data:'v1 -> 'v2 option)\n -> ('k, 'v2, 'cmp) t\n\n (** [partition_mapi t ~f] returns two new [t]s, with each key in [t] appearing in\n exactly one of the resulting maps depending on its mapping in [f]. *)\n val partition_mapi\n : ('k, 'v1, 'cmp) t\n -> f:(key:'k -> data:'v1 -> ('v2, 'v3) Either.t)\n -> ('k, 'v2, 'cmp) t * ('k, 'v3, 'cmp) t\n\n (** [partition_map t ~f = partition_mapi t ~f:(fun ~key:_ ~data -> f data)] *)\n val partition_map\n : ('k, 'v1, 'cmp) t\n -> f:('v1 -> ('v2, 'v3) Either.t)\n -> ('k, 'v2, 'cmp) t * ('k, 'v3, 'cmp) t\n\n (**\n {[\n partitioni_tf t ~f\n =\n partition_mapi t ~f:(fun ~key ~data ->\n if f ~key ~data\n then First data\n else Second data)\n ]} *)\n val partitioni_tf\n : ('k, 'v, 'cmp) t\n -> f:(key:'k -> data:'v -> bool)\n -> ('k, 'v, 'cmp) t * ('k, 'v, 'cmp) t\n\n (** [partition_tf t ~f = partitioni_tf t ~f:(fun ~key:_ ~data -> f data)] *)\n val partition_tf\n : ('k, 'v, 'cmp) t\n -> f:('v -> bool)\n -> ('k, 'v, 'cmp) t * ('k, 'v, 'cmp) t\n\n (** Produces [Ok] of a map including all keys if all data is [Ok], or an [Error]\n including all errors otherwise. *)\n val combine_errors : ('k, 'v Or_error.t, 'cmp) t -> ('k, 'v, 'cmp) t Or_error.t\n\n (** Returns a total ordering between maps. The first argument is a total ordering used\n to compare data associated with equal keys in the two maps. *)\n val compare_direct : ('v -> 'v -> int) -> ('k, 'v, 'cmp) t -> ('k, 'v, 'cmp) t -> int\n\n (** Hash function: a building block to use when hashing data structures containing maps in\n them. [hash_fold_direct hash_fold_key] is compatible with [compare_direct] iff\n [hash_fold_key] is compatible with [(comparator m).compare] of the map [m] being\n hashed. *)\n val hash_fold_direct : 'k Hash.folder -> 'v Hash.folder -> ('k, 'v, 'cmp) t Hash.folder\n\n (** [equal cmp m1 m2] tests whether the maps [m1] and [m2] are equal, that is, contain\n the same keys and associate each key with the same value. [cmp] is the equality\n predicate used to compare the values associated with the keys. *)\n val equal : ('v -> 'v -> bool) -> ('k, 'v, 'cmp) t -> ('k, 'v, 'cmp) t -> bool\n\n (** Returns a list of the keys in the given map. *)\n val keys : ('k, _, _) t -> 'k list\n\n (** Returns a list of the data in the given map. *)\n val data : (_, 'v, _) t -> 'v list\n\n (** Creates an association list from the given map. *)\n val to_alist\n : ?key_order:[ `Increasing | `Decreasing ] (** default is [`Increasing] *)\n -> ('k, 'v, _) t\n -> ('k * 'v) list\n\n val validate : name:('k -> string) -> 'v Validate.check -> ('k, 'v, _) t Validate.check\n\n val validatei\n : name:('k -> string)\n -> ('k * 'v) Validate.check\n -> ('k, 'v, _) t Validate.check\n\n (** {2 Additional operations on maps} *)\n\n (** Merges two maps. The runtime is O(length(t1) + length(t2)). You shouldn't use this\n function to merge a list of maps; consider using [merge_skewed] instead. *)\n val merge\n : ('k, 'v1, 'cmp) t\n -> ('k, 'v2, 'cmp) t\n -> f:(key:'k -> [ `Left of 'v1 | `Right of 'v2 | `Both of 'v1 * 'v2 ] -> 'v3 option)\n -> ('k, 'v3, 'cmp) t\n\n (** A special case of [merge], [merge_skewed t1 t2] is a map containing all the\n bindings of [t1] and [t2]. Bindings that appear in both [t1] and [t2] are\n combined into a single value using the [combine] function. In a call\n [combine ~key v1 v2], the value [v1] comes from [t1] and [v2] from [t2].\n\n The runtime of [merge_skewed] is [O(l1 * log(l2))], where [l1] is the length\n of the smaller map and [l2] the length of the larger map. This is likely to\n be faster than [merge] when one of the maps is a lot smaller, or when you\n merge a list of maps. *)\n val merge_skewed\n : ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> combine:(key:'k -> 'v -> 'v -> 'v)\n -> ('k, 'v, 'cmp) t\n\n module Symmetric_diff_element : sig\n type ('k, 'v) t = 'k * [ `Left of 'v | `Right of 'v | `Unequal of 'v * 'v ]\n [@@deriving_inline compare, sexp]\n\n val compare\n : ('k -> 'k -> int)\n -> ('v -> 'v -> int)\n -> ('k, 'v) t\n -> ('k, 'v) t\n -> int\n\n include Ppx_sexp_conv_lib.Sexpable.S2 with type ('k, 'v) t := ('k, 'v) t\n\n [@@@end]\n end\n\n (** [symmetric_diff t1 t2 ~data_equal] returns a list of changes between [t1] and [t2].\n It is intended to be efficient in the case where [t1] and [t2] share a large amount\n of structure. The keys in the output sequence will be in sorted order.\n\n It is assumed that [data_equal] is at least as equating as physical equality: that\n [phys_equal x y] implies [data_equal x y]. Otherwise, [symmetric_diff] may behave in\n unexpected ways. For example, with [~data_equal:(fun _ _ -> false)] it is NOT\n necessarily the case the resulting change sequence will contain an element\n [(k, `Unequal _)] for every key [k] shared by both maps.\n\n Warning: Float equality violates this property! [phys_equal Float.nan Float.nan] is\n true, but [Float.(=) Float.nan Float.nan] is false. *)\n val symmetric_diff\n : ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> data_equal:('v -> 'v -> bool)\n -> ('k, 'v) Symmetric_diff_element.t Sequence.t\n\n (** [fold_symmetric_diff t1 t2 ~data_equal] folds across an implicit sequence of changes\n between [t1] and [t2], in sorted order by keys. Equivalent to\n [Sequence.fold (symmetric_diff t1 t2 ~data_equal)], and more efficient. *)\n val fold_symmetric_diff\n : ('k, 'v, 'cmp) t\n -> ('k, 'v, 'cmp) t\n -> data_equal:('v -> 'v -> bool)\n -> init:'a\n -> f:('a -> ('k, 'v) Symmetric_diff_element.t -> 'a)\n -> 'a\n\n (** [min_elt map] returns [Some (key, data)] pair corresponding to the minimum key in\n [map], or [None] if empty. *)\n val min_elt : ('k, 'v, _) t -> ('k * 'v) option\n\n val min_elt_exn : ('k, 'v, _) t -> 'k * 'v\n\n (** [max_elt map] returns [Some (key, data)] pair corresponding to the maximum key in\n [map], or [None] if [map] is empty. *)\n val max_elt : ('k, 'v, _) t -> ('k * 'v) option\n\n val max_elt_exn : ('k, 'v, _) t -> 'k * 'v\n\n (** These functions have the same semantics as similar functions in [List]. *)\n\n val for_all : ('k, 'v, _) t -> f:('v -> bool) -> bool\n val for_alli : ('k, 'v, _) t -> f:(key:'k -> data:'v -> bool) -> bool\n val exists : ('k, 'v, _) t -> f:('v -> bool) -> bool\n val existsi : ('k, 'v, _) t -> f:(key:'k -> data:'v -> bool) -> bool\n val count : ('k, 'v, _) t -> f:('v -> bool) -> int\n val counti : ('k, 'v, _) t -> f:(key:'k -> data:'v -> bool) -> int\n\n\n (** [split t key] returns a map of keys strictly less than [key], the mapping of [key] if\n any, and a map of keys strictly greater than [key].\n\n Runtime is O(m + log n), where n is the size of the input map and m is the size of\n the smaller of the two output maps. The O(m) term is due to the need to calculate\n the length of the output maps. *)\n val split\n : ('k, 'v, 'cmp) t\n -> 'k\n -> ('k, 'v, 'cmp) t * ('k * 'v) option * ('k, 'v, 'cmp) t\n\n (** [append ~lower_part ~upper_part] returns [`Ok map] where [map] contains all the\n [(key, value)] pairs from the two input maps if all the keys from [lower_part] are\n less than all the keys from [upper_part]. Otherwise it returns\n [`Overlapping_key_ranges].\n\n Runtime is O(log n) where n is the size of the larger input map. This can be\n significantly faster than [Map.merge] or repeated [Map.add].\n\n {[\n assert (match Map.append ~lower_part ~upper_part with\n | `Ok whole_map ->\n Map.to_alist whole_map\n = List.append (to_alist lower_part) (to_alist upper_part)\n | `Overlapping_key_ranges -> true);\n ]} *)\n val append\n : lower_part:('k, 'v, 'cmp) t\n -> upper_part:('k, 'v, 'cmp) t\n -> [ `Ok of ('k, 'v, 'cmp) t | `Overlapping_key_ranges ]\n\n (** [subrange t ~lower_bound ~upper_bound] returns a map containing all the entries from\n [t] whose keys lie inside the interval indicated by [~lower_bound] and\n [~upper_bound]. If this interval is empty, an empty map is returned.\n\n Runtime is O(m + log n), where n is the size of the input map and m is the size of\n the output map. The O(m) term is due to the need to calculate the length of the\n output map. *)\n val subrange\n : ('k, 'v, 'cmp) t\n -> lower_bound:'k Maybe_bound.t\n -> upper_bound:'k Maybe_bound.t\n -> ('k, 'v, 'cmp) t\n\n (** [fold_range_inclusive t ~min ~max ~init ~f] folds [f] (with initial value [~init])\n over all keys (and their associated values) that are in the range [[min, max]]\n (inclusive). *)\n val fold_range_inclusive\n : ('k, 'v, 'cmp) t\n -> min:'k\n -> max:'k\n -> init:'a\n -> f:(key:'k -> data:'v -> 'a -> 'a)\n -> 'a\n\n (** [range_to_alist t ~min ~max] returns an associative list of the elements whose keys\n lie in [[min, max]] (inclusive), with the smallest key being at the head of the\n list. *)\n val range_to_alist : ('k, 'v, 'cmp) t -> min:'k -> max:'k -> ('k * 'v) list\n\n (** [closest_key t dir k] returns the [(key, value)] pair in [t] with [key] closest to\n [k] that satisfies the given inequality bound.\n\n For example, [closest_key t `Less_than k] would be the pair with the closest key to\n [k] where [key < k].\n\n [to_sequence] can be used to get the same results as [closest_key]. It is less\n efficient for individual lookups but more efficient for finding many elements starting\n at some value. *)\n val closest_key\n : ('k, 'v, 'cmp) t\n -> [ `Greater_or_equal_to | `Greater_than | `Less_or_equal_to | `Less_than ]\n -> 'k\n -> ('k * 'v) option\n\n (** [nth t n] finds the (key, value) pair of rank n (i.e., such that there are exactly n\n keys strictly less than the found key), if one exists. O(log(length t) + n) time. *)\n val nth : ('k, 'v, _) t -> int -> ('k * 'v) option\n\n val nth_exn : ('k, 'v, _) t -> int -> 'k * 'v\n\n (** [rank t k] If [k] is in [t], returns the number of keys strictly less than [k] in\n [t], and [None] otherwise. *)\n val rank : ('k, 'v, 'cmp) t -> 'k -> int option\n\n\n\n (** [to_sequence ?order ?keys_greater_or_equal_to ?keys_less_or_equal_to t]\n gives a sequence of key-value pairs between [keys_less_or_equal_to] and\n [keys_greater_or_equal_to] inclusive, presented in [order]. If\n [keys_greater_or_equal_to > keys_less_or_equal_to], the sequence is\n empty.\n\n When neither [keys_greater_or_equal_to] nor [keys_less_or_equal_to] are\n provided, the cost is O(log n) up front and amortized O(1) to produce\n each element. If either is provided (and is used by the order parameter\n provided), then the the cost is O(n) up front, and amortized O(1) to\n produce each element. *)\n val to_sequence\n : ?order:[ `Increasing_key (** default *) | `Decreasing_key ]\n -> ?keys_greater_or_equal_to:'k\n -> ?keys_less_or_equal_to:'k\n -> ('k, 'v, 'cmp) t\n -> ('k * 'v) Sequence.t\n\n (** [binary_search t ~compare which elt] returns the [(key, value)] pair in [t]\n specified by [compare] and [which], if one exists.\n\n [t] must be sorted in increasing order according to [compare], where [compare] and\n [elt] divide [t] into three (possibly empty) segments:\n\n {v\n | < elt | = elt | > elt |\n v}\n\n [binary_search] returns an element on the boundary of segments as specified by\n [which]. See the diagram below next to the [which] variants.\n\n [binary_search] does not check that [compare] orders [t], and behavior is\n unspecified if [compare] doesn't order [t]. Behavior is also unspecified if\n [compare] mutates [t]. *)\n val binary_search\n : ('k, 'v, 'cmp) t\n -> compare:(key:'k -> data:'v -> 'key -> int)\n -> [ `Last_strictly_less_than (** {v | < elt X | v} *)\n | `Last_less_than_or_equal_to (** {v | <= elt X | v} *)\n | `Last_equal_to (** {v | = elt X | v} *)\n | `First_equal_to (** {v | X = elt | v} *)\n | `First_greater_than_or_equal_to (** {v | X >= elt | v} *)\n | `First_strictly_greater_than (** {v | X > elt | v} *)\n ]\n -> 'key\n -> ('k * 'v) option\n\n (** [binary_search_segmented t ~segment_of which] takes a [segment_of] function that\n divides [t] into two (possibly empty) segments:\n\n {v\n | segment_of elt = `Left | segment_of elt = `Right |\n v}\n\n [binary_search_segmented] returns the [(key, value)] pair on the boundary of the\n segments as specified by [which]: [`Last_on_left] yields the last element of the\n left segment, while [`First_on_right] yields the first element of the right segment.\n It returns [None] if the segment is empty.\n\n [binary_search_segmented] does not check that [segment_of] segments [t] as in the\n diagram, and behavior is unspecified if [segment_of] doesn't segment [t]. Behavior\n is also unspecified if [segment_of] mutates [t]. *)\n val binary_search_segmented\n : ('k, 'v, 'cmp) t\n -> segment_of:(key:'k -> data:'v -> [ `Left | `Right ])\n -> [ `Last_on_left | `First_on_right ]\n -> ('k * 'v) option\n\n (** [M] is meant to be used in combination with OCaml applicative functor types:\n\n {[\n type string_to_int_map = int Map.M(String).t\n ]}\n\n which stands for:\n\n {[\n type string_to_int_map = (String.t, int, String.comparator_witness) Map.t\n ]}\n\n The point is that [int Map.M(String).t] supports deriving, whereas the second syntax\n doesn't (because there is no such thing as, say, [String.sexp_of_comparator_witness]\n -- instead you would want to pass the comparator directly).\n\n In addition, when using [@@deriving], the requirements on the key module are only\n those needed to satisfy what you are trying to derive on the map itself. Say you\n write:\n\n {[\n type t = int Map.M(X).t [@@deriving hash]\n ]}\n\n then this will be well typed exactly if [X] contains at least:\n - a type [t] with no parameters\n - a comparator witness\n - a [hash_fold_t] function with the right type *)\n module M (K : sig\n type t\n type comparator_witness\n end) : sig\n type nonrec 'v t = (K.t, 'v, K.comparator_witness) t\n end\n\n include For_deriving with type ('key, 'value, 'cmp) t := ('key, 'value, 'cmp) t\n\n (** A polymorphic Map. *)\n module Poly :\n S_poly\n with type ('key, +'value) t = ('key, 'value, Comparator.Poly.comparator_witness) t\n\n (** [Using_comparator] is a similar interface as the toplevel of [Map], except the\n functions take a [~comparator:('k, 'cmp) Comparator.t], whereas the functions at the\n toplevel of [Map] take a [('k, 'cmp) comparator]. *)\n module Using_comparator : sig\n type nonrec ('k, +'v, 'cmp) t = ('k, 'v, 'cmp) t [@@deriving_inline sexp_of]\n\n val sexp_of_t\n : ('k -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('v -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('cmp -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('k, 'v, 'cmp) t\n -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val t_of_sexp_direct\n : comparator:('k, 'cmp) Comparator.t\n -> (Sexp.t -> 'k)\n -> (Sexp.t -> 'v)\n -> Sexp.t\n -> ('k, 'v, 'cmp) t\n\n module Tree : sig\n type ('k, +'v, 'cmp) t [@@deriving_inline sexp_of]\n\n val sexp_of_t\n : ('k -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('v -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('cmp -> Ppx_sexp_conv_lib.Sexp.t)\n -> ('k, 'v, 'cmp) t\n -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n val t_of_sexp_direct\n : comparator:('k, 'cmp) Comparator.t\n -> (Sexp.t -> 'k)\n -> (Sexp.t -> 'v)\n -> Sexp.t\n -> ('k, 'v, 'cmp) t\n\n include\n Creators_and_accessors3_with_comparator\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) t\n\n val empty_without_value_restriction : (_, _, _) t\n end\n\n include\n Accessors3\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n\n include\n Creators3_with_comparator\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n\n val comparator : ('a, _, 'cmp) t -> ('a, 'cmp) Comparator.t\n\n val hash_fold_direct\n : 'k Hash.folder\n -> 'v Hash.folder\n -> ('k, 'v, 'cmp) t Hash.folder\n\n (** To get around the value restriction, apply the functor and include it. You\n can see an example of this in the [Poly] submodule below. *)\n module Empty_without_value_restriction (K : Comparator.S1) : sig\n val empty : ('a K.t, 'v, K.comparator_witness) t\n end\n end\n\n\n (** {2 Modules and module types for extending [Map]}\n\n For use in extensions of Base, like [Core_kernel]. *)\n\n module With_comparator = With_comparator\n module With_first_class_module = With_first_class_module\n module Without_comparator = Without_comparator\n\n module type For_deriving = For_deriving\n module type S_poly = S_poly\n module type Accessors1 = Accessors1\n module type Accessors2 = Accessors2\n module type Accessors3 = Accessors3\n module type Accessors3_with_comparator = Accessors3_with_comparator\n module type Accessors_generic = Accessors_generic\n module type Creators1 = Creators1\n module type Creators2 = Creators2\n module type Creators3_with_comparator = Creators3_with_comparator\n module type Creators_and_accessors1 = Creators_and_accessors1\n module type Creators_and_accessors2 = Creators_and_accessors2\n\n module type Creators_and_accessors3_with_comparator =\n Creators_and_accessors3_with_comparator\n\n module type Creators_and_accessors_generic = Creators_and_accessors_generic\n module type Creators_generic = Creators_generic\nend\n","open! Import\nopen! Caml.Int64\n\nmodule T = struct\n type t = int64 [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int64\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int64 in\n fun x -> func x\n ;;\n\n let t_of_sexp = (int64_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_int64 : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"int64\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ int64_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"int64.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare = Int64_replace_polymorphic_compare.compare\n let to_string = to_string\n let of_string = of_string\nend\n\ninclude T\ninclude Comparator.Make (T)\n\nlet num_bits = 64\nlet float_lower_bound = Float0.lower_bound_for_int num_bits\nlet float_upper_bound = Float0.upper_bound_for_int num_bits\nlet float_of_bits = float_of_bits\nlet bits_of_float = bits_of_float\nlet shift_right_logical = shift_right_logical\nlet shift_right = shift_right\nlet shift_left = shift_left\nlet bit_not = lognot\nlet bit_xor = logxor\nlet bit_or = logor\nlet bit_and = logand\nlet min_value = min_int\nlet max_value = max_int\nlet abs = abs\nlet pred = pred\nlet succ = succ\nlet pow = Int_math.Private.int64_pow\nlet rem = rem\nlet neg = neg\nlet minus_one = minus_one\nlet one = one\nlet zero = zero\nlet to_float = to_float\nlet of_float_unchecked = Caml.Int64.of_float\n\nlet of_float f =\n if Float_replace_polymorphic_compare.( >= ) f float_lower_bound\n && Float_replace_polymorphic_compare.( <= ) f float_upper_bound\n then Caml.Int64.of_float f\n else\n Printf.invalid_argf\n \"Int64.of_float: argument (%f) is out of range or NaN\"\n (Float0.box f)\n ()\n;;\n\nlet ( ** ) b e = pow b e\n\nexternal bswap64 : t -> t = \"%bswap_int64\"\n\nlet[@inline always] bswap16 x = Caml.Int64.shift_right_logical (bswap64 x) 48\n\nlet[@inline always] bswap32 x =\n (* This is strictly better than coercing to an int32 to perform byteswap. Coercing\n from an int32 will add unnecessary shift operations to sign extend the number\n appropriately.\n *)\n Caml.Int64.shift_right_logical (bswap64 x) 32\n;;\n\nlet[@inline always] bswap48 x = Caml.Int64.shift_right_logical (bswap64 x) 16\n\ninclude Comparable.Validate_with_zero (struct\n include T\n\n let zero = zero\n end)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen Int64_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet ( / ) = div\nlet ( * ) = mul\nlet ( - ) = sub\nlet ( + ) = add\nlet ( ~- ) = neg\nlet incr r = r := !r + one\nlet decr r = r := !r - one\nlet of_int64 t = t\nlet of_int64_exn = of_int64\nlet to_int64 t = t\nlet popcount = Popcount.int64_popcount\n\nmodule Conv = Int_conversions\n\nlet of_int = Conv.int_to_int64\nlet of_int_exn = of_int\nlet to_int = Conv.int64_to_int\nlet to_int_exn = Conv.int64_to_int_exn\nlet to_int_trunc = Conv.int64_to_int_trunc\nlet of_int32 = Conv.int32_to_int64\nlet of_int32_exn = of_int32\nlet to_int32 = Conv.int64_to_int32\nlet to_int32_exn = Conv.int64_to_int32_exn\nlet to_int32_trunc = Conv.int64_to_int32_trunc\nlet of_nativeint = Conv.nativeint_to_int64\nlet of_nativeint_exn = of_nativeint\nlet to_nativeint = Conv.int64_to_nativeint\nlet to_nativeint_exn = Conv.int64_to_nativeint_exn\nlet to_nativeint_trunc = Conv.int64_to_nativeint_trunc\n\nmodule Pow2 = struct\n open! Import\n open Int64_replace_polymorphic_compare\n module Sys = Sys0\n\n let raise_s = Error.raise_s\n\n let non_positive_argument () =\n Printf.invalid_argf \"argument must be strictly positive\" ()\n ;;\n\n let ( lor ) = Caml.Int64.logor\n let ( lsr ) = Caml.Int64.shift_right_logical\n let ( land ) = Caml.Int64.logand\n\n (** \"ceiling power of 2\" - Least power of 2 greater than or equal to x. *)\n let ceil_pow2 x =\n if x <= Caml.Int64.zero then non_positive_argument ();\n let x = Caml.Int64.pred x in\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n let x = x lor (x lsr 32) in\n Caml.Int64.succ x\n ;;\n\n (** \"floor power of 2\" - Largest power of 2 less than or equal to x. *)\n let floor_pow2 x =\n if x <= Caml.Int64.zero then non_positive_argument ();\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n let x = x lor (x lsr 32) in\n Caml.Int64.sub x (x lsr 1)\n ;;\n\n let is_pow2 x =\n if x <= Caml.Int64.zero then non_positive_argument ();\n x land Caml.Int64.pred x = Caml.Int64.zero\n ;;\n\n (* C stubs for int clz and ctz to use the CLZ/BSR/CTZ/BSF instruction where possible *)\n external clz\n : (int64[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_int64_clz\" \"Base_int_math_int64_clz_unboxed\"\n [@@noalloc]\n\n external ctz\n : (int64[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_int64_ctz\" \"Base_int_math_int64_ctz_unboxed\"\n [@@noalloc]\n\n (** Hacker's Delight Second Edition p106 *)\n let floor_log2 i =\n if i <= Caml.Int64.zero\n then\n raise_s\n (Sexp.message \"[Int64.floor_log2] got invalid input\" [ \"\", sexp_of_int64 i ]);\n num_bits - 1 - clz i\n ;;\n\n (** Hacker's Delight Second Edition p106 *)\n let ceil_log2 i =\n if Poly.( <= ) i Caml.Int64.zero\n then\n raise_s\n (Sexp.message \"[Int64.ceil_log2] got invalid input\" [ \"\", sexp_of_int64 i ]);\n if Caml.Int64.equal i Caml.Int64.one then 0 else num_bits - clz (Caml.Int64.pred i)\n ;;\nend\n\ninclude Pow2\ninclude Conv.Make (T)\n\ninclude Conv.Make_hex (struct\n type t = int64 [@@deriving_inline compare, hash]\n\n let compare = (compare_int64 : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int64\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int64 in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let zero = zero\n let neg = ( ~- )\n let ( < ) = ( < )\n let to_string i = Printf.sprintf \"%Lx\" i\n let of_string s = Caml.Scanf.sscanf s \"%Lx\" Fn.id\n let module_name = \"Base.Int64.Hex\"\n end)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Base.Int64\"\n end)\n\nmodule Pre_O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Int64_replace_polymorphic_compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int_exn = of_int_exn\nend\n\nmodule O = struct\n include Pre_O\n\n include Int_math.Make (struct\n type nonrec t = t\n\n include Pre_O\n\n let rem = rem\n let to_float = to_float\n let of_float = of_float\n let of_string = T.of_string\n let to_string = T.to_string\n end)\n\n let ( land ) = bit_and\n let ( lor ) = bit_or\n let ( lxor ) = bit_xor\n let lnot = bit_not\n let ( lsl ) = shift_left\n let ( asr ) = shift_right\n let ( lsr ) = shift_right_logical\nend\n\ninclude O\n\n(* [Int64] and [Int64.O] agree value-wise *)\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Int64_replace_polymorphic_compare\n","open! Import\n\nlet invalid_argf = Printf.invalid_argf\n\nmodule T = struct\n type t = bool [@@deriving_inline compare, enumerate, hash, sexp, sexp_grammar]\n\n let compare = (compare_bool : t -> t -> int)\n let all = ([ false; true ] : t list)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_bool\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_bool in\n fun x -> func x\n ;;\n\n let t_of_sexp = (bool_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_bool : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"bool\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ bool_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"bool.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let of_string = function\n | \"true\" -> true\n | \"false\" -> false\n | s -> invalid_argf \"Bool.of_string: expected true or false but got %s\" s ()\n ;;\n\n let to_string = Caml.string_of_bool\nend\n\ninclude T\ninclude Comparator.Make (T)\ninclude Comparable.Validate (T)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Base.Bool\"\n end)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen! Bool_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet between t ~low ~high = low <= t && t <= high\nlet clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\nlet clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n;;\n\nlet to_int x = bool_to_int x\n\nmodule Non_short_circuiting = struct\n (* We don't expose this, since we don't want to break the invariant mentioned below of\n (to_int true = 1) and (to_int false = 0). *)\n let unsafe_of_int (x : int) : bool = Caml.Obj.magic x\n let ( || ) a b = unsafe_of_int (to_int a lor to_int b)\n let ( && ) a b = unsafe_of_int (to_int a land to_int b)\nend\n\n(* We do this as a direct assert on the theory that it's a cheap thing to test and a\n really core invariant that we never expect to break, and we should be happy for a\n program to fail immediately if this is violated. *)\nlet () = assert (Poly.( = ) (to_int true) 1 && Poly.( = ) (to_int false) 0)\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Bool_replace_polymorphic_compare\n","open! Import\nopen! Caml.Int32\n\nmodule T = struct\n type t = int32 [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int32\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int32 in\n fun x -> func x\n ;;\n\n let t_of_sexp = (int32_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_int32 : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"int32\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ int32_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"int32.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare (x : t) y = compare x y\n let to_string = to_string\n let of_string = of_string\nend\n\ninclude T\ninclude Comparator.Make (T)\n\nlet num_bits = 32\nlet float_lower_bound = Float0.lower_bound_for_int num_bits\nlet float_upper_bound = Float0.upper_bound_for_int num_bits\nlet float_of_bits = float_of_bits\nlet bits_of_float = bits_of_float\nlet shift_right_logical = shift_right_logical\nlet shift_right = shift_right\nlet shift_left = shift_left\nlet bit_not = lognot\nlet bit_xor = logxor\nlet bit_or = logor\nlet bit_and = logand\nlet min_value = min_int\nlet max_value = max_int\nlet abs = abs\nlet pred = pred\nlet succ = succ\nlet rem = rem\nlet neg = neg\nlet minus_one = minus_one\nlet one = one\nlet zero = zero\nlet compare = compare\nlet to_float = to_float\nlet of_float_unchecked = of_float\n\nlet of_float f =\n if Float_replace_polymorphic_compare.( >= ) f float_lower_bound\n && Float_replace_polymorphic_compare.( <= ) f float_upper_bound\n then of_float f\n else\n Printf.invalid_argf\n \"Int32.of_float: argument (%f) is out of range or NaN\"\n (Float0.box f)\n ()\n;;\n\ninclude Comparable.Validate_with_zero (struct\n include T\n\n let zero = zero\n end)\n\nmodule Infix_compare = struct\n open Poly\n\n let ( >= ) (x : t) y = x >= y\n let ( <= ) (x : t) y = x <= y\n let ( = ) (x : t) y = x = y\n let ( > ) (x : t) y = x > y\n let ( < ) (x : t) y = x < y\n let ( <> ) (x : t) y = x <> y\nend\n\nmodule Compare = struct\n include Infix_compare\n\n let compare = compare\n let ascending = compare\n let descending x y = compare y x\n let min (x : t) y = if x < y then x else y\n let max (x : t) y = if x > y then x else y\n let equal (x : t) y = x = y\n let between t ~low ~high = low <= t && t <= high\n let clamp_unchecked t ~min ~max = if t < min then min else if t <= max then t else max\n\n let clamp_exn t ~min ~max =\n assert (min <= max);\n clamp_unchecked t ~min ~max\n ;;\n\n let clamp t ~min ~max =\n if min > max\n then\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n else Ok (clamp_unchecked t ~min ~max)\n ;;\nend\n\ninclude Compare\n\nlet invariant (_ : t) = ()\nlet ( / ) = div\nlet ( * ) = mul\nlet ( - ) = sub\nlet ( + ) = add\nlet ( ~- ) = neg\nlet incr r = r := !r + one\nlet decr r = r := !r - one\nlet of_int32 t = t\nlet of_int32_exn = of_int32\nlet to_int32 t = t\nlet to_int32_exn = to_int32\nlet popcount = Popcount.int32_popcount\n\nmodule Conv = Int_conversions\n\nlet of_int = Conv.int_to_int32\nlet of_int_exn = Conv.int_to_int32_exn\nlet of_int_trunc = Conv.int_to_int32_trunc\nlet to_int = Conv.int32_to_int\nlet to_int_exn = Conv.int32_to_int_exn\nlet to_int_trunc = Conv.int32_to_int_trunc\nlet of_int64 = Conv.int64_to_int32\nlet of_int64_exn = Conv.int64_to_int32_exn\nlet of_int64_trunc = Conv.int64_to_int32_trunc\nlet to_int64 = Conv.int32_to_int64\nlet of_nativeint = Conv.nativeint_to_int32\nlet of_nativeint_exn = Conv.nativeint_to_int32_exn\nlet of_nativeint_trunc = Conv.nativeint_to_int32_trunc\nlet to_nativeint = Conv.int32_to_nativeint\nlet to_nativeint_exn = to_nativeint\nlet pow b e = of_int_exn (Int_math.Private.int_pow (to_int_exn b) (to_int_exn e))\nlet ( ** ) b e = pow b e\n\nexternal bswap32 : t -> t = \"%bswap_int32\"\n\nlet bswap16 x = Caml.Int32.shift_right_logical (bswap32 x) 16\n\nmodule Pow2 = struct\n open! Import\n open Int32_replace_polymorphic_compare\n module Sys = Sys0\n\n let raise_s = Error.raise_s\n\n let non_positive_argument () =\n Printf.invalid_argf \"argument must be strictly positive\" ()\n ;;\n\n let ( lor ) = Caml.Int32.logor\n let ( lsr ) = Caml.Int32.shift_right_logical\n let ( land ) = Caml.Int32.logand\n\n (** \"ceiling power of 2\" - Least power of 2 greater than or equal to x. *)\n let ceil_pow2 x =\n if x <= Caml.Int32.zero then non_positive_argument ();\n let x = Caml.Int32.pred x in\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n Caml.Int32.succ x\n ;;\n\n (** \"floor power of 2\" - Largest power of 2 less than or equal to x. *)\n let floor_pow2 x =\n if x <= Caml.Int32.zero then non_positive_argument ();\n let x = x lor (x lsr 1) in\n let x = x lor (x lsr 2) in\n let x = x lor (x lsr 4) in\n let x = x lor (x lsr 8) in\n let x = x lor (x lsr 16) in\n Caml.Int32.sub x (x lsr 1)\n ;;\n\n let is_pow2 x =\n if x <= Caml.Int32.zero then non_positive_argument ();\n x land Caml.Int32.pred x = Caml.Int32.zero\n ;;\n\n (* C stubs for int32 clz and ctz to use the CLZ/BSR/CTZ/BSF instruction where possible *)\n external clz\n : (int32[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_int32_clz\" \"Base_int_math_int32_clz_unboxed\"\n [@@noalloc]\n\n external ctz\n : (int32[@unboxed])\n -> (int[@untagged])\n = \"Base_int_math_int32_ctz\" \"Base_int_math_int32_ctz_unboxed\"\n [@@noalloc]\n\n (** Hacker's Delight Second Edition p106 *)\n let floor_log2 i =\n if i <= Caml.Int32.zero\n then\n raise_s\n (Sexp.message \"[Int32.floor_log2] got invalid input\" [ \"\", sexp_of_int32 i ]);\n num_bits - 1 - clz i\n ;;\n\n (** Hacker's Delight Second Edition p106 *)\n let ceil_log2 i =\n if i <= Caml.Int32.zero\n then\n raise_s\n (Sexp.message \"[Int32.ceil_log2] got invalid input\" [ \"\", sexp_of_int32 i ]);\n (* The [i = 1] check is needed because clz(0) is undefined *)\n if Caml.Int32.equal i Caml.Int32.one then 0 else num_bits - clz (Caml.Int32.pred i)\n ;;\nend\n\ninclude Pow2\ninclude Conv.Make (T)\n\ninclude Conv.Make_hex (struct\n type t = int32 [@@deriving_inline compare, hash]\n\n let compare = (compare_int32 : t -> t -> int)\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_int32\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_int32 in\n fun x -> func x\n ;;\n\n [@@@end]\n\n let zero = zero\n let neg = ( ~- )\n let ( < ) = ( < )\n let to_string i = Printf.sprintf \"%lx\" i\n let of_string s = Caml.Scanf.sscanf s \"%lx\" Fn.id\n let module_name = \"Base.Int32.Hex\"\n end)\n\ninclude Pretty_printer.Register (struct\n type nonrec t = t\n\n let to_string = to_string\n let module_name = \"Base.Int32\"\n end)\n\nmodule Pre_O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int_exn = of_int_exn\nend\n\nmodule O = struct\n include Pre_O\n\n include Int_math.Make (struct\n type nonrec t = t\n\n include Pre_O\n\n let rem = rem\n let to_float = to_float\n let of_float = of_float\n let of_string = T.of_string\n let to_string = T.to_string\n end)\n\n let ( land ) = bit_and\n let ( lor ) = bit_or\n let ( lxor ) = bit_xor\n let lnot = bit_not\n let ( lsl ) = shift_left\n let ( asr ) = shift_right\n let ( lsr ) = shift_right_logical\nend\n\ninclude O\n\n(* [Int32] and [Int32.O] agree value-wise *)\n","open! Import\n\nlet raise_s = Error.raise_s\n\nmodule Repr = Int63_emul.Repr\n\n(* In a world where the compiler would understand [@@immediate64] attributes on type\n declarations, this module is how one would produce a [type t] with this attribute. *)\nmodule Immediate64 : sig\n module type Non_immediate = sig\n type t\n end\n\n module type Immediate = sig\n type t [@@immediate]\n end\n\n module Make (Immediate : Immediate) (Non_immediate : Non_immediate) : sig\n type t [@@immediate64]\n\n type 'a repr =\n | Immediate : Immediate.t repr\n | Non_immediate : Non_immediate.t repr\n\n val repr : t repr\n end\nend = struct\n module type Non_immediate = sig\n type t\n end\n\n module type Immediate = sig\n type t [@@immediate]\n end\n\n module Make (Immediate : Immediate) (Non_immediate : Non_immediate) = struct\n type t [@@immediate64]\n\n type 'a repr =\n | Immediate : Immediate.t repr\n | Non_immediate : Non_immediate.t repr\n\n let repr =\n match Word_size.word_size with\n | W64 -> (Caml.Obj.magic Immediate : t repr)\n | W32 -> (Caml.Obj.magic Non_immediate : t repr)\n ;;\n end\nend\n\ninclude Immediate64.Make (Int) (Int63_emul)\n\nmodule Backend = struct\n module type S = sig\n type t\n\n include Int_intf.S with type t := t\n\n val of_int : int -> t\n val to_int : t -> int option\n val to_int_trunc : t -> int\n val of_int32 : int32 -> t\n val to_int32 : t -> Int32.t option\n val to_int32_trunc : t -> Int32.t\n val of_int64 : Int64.t -> t option\n val of_int64_trunc : Int64.t -> t\n val of_nativeint : nativeint -> t option\n val to_nativeint : t -> nativeint option\n val of_nativeint_trunc : nativeint -> t\n val to_nativeint_trunc : t -> nativeint\n val of_float_unchecked : float -> t\n val repr : (t, t) Int63_emul.Repr.t\n val bswap16 : t -> t\n val bswap32 : t -> t\n val bswap48 : t -> t\n end\n with type t := t\n\n module Native = struct\n include Int\n\n let to_int x = Some x\n let to_int_trunc x = x\n\n (* [of_int32_exn] is a safe operation on platforms with 64-bit word sizes. *)\n let of_int32 = of_int32_exn\n let to_nativeint_trunc x = to_nativeint x\n let to_nativeint x = Some (to_nativeint x)\n let repr = Int63_emul.Repr.Int\n let bswap32 t = Int64.to_int_trunc (Int64.bswap32 (Int64.of_int t))\n let bswap48 t = Int64.to_int_trunc (Int64.bswap48 (Int64.of_int t))\n end\n\n let impl : (module S) =\n match repr with\n | Immediate -> (module Native : S)\n | Non_immediate -> (module Int63_emul : S)\n ;;\nend\n\ninclude (val Backend.impl : Backend.S)\n\nmodule Overflow_exn = struct\n let ( + ) t u =\n let sum = t + u in\n if bit_or (bit_xor t u) (bit_xor t (bit_not sum)) < zero\n then sum\n else\n raise_s\n (Sexp.message\n \"( + ) overflow\"\n [ \"t\", sexp_of_t t; \"u\", sexp_of_t u; \"sum\", sexp_of_t sum ])\n ;;\n\n let ( - ) t u =\n let diff = t - u in\n let pos_diff = t > u in\n if t <> u && Bool.( <> ) pos_diff (is_positive diff)\n then\n raise_s\n (Sexp.message\n \"( - ) overflow\"\n [ \"t\", sexp_of_t t; \"u\", sexp_of_t u; \"diff\", sexp_of_t diff ])\n else diff\n ;;\n\n let abs t = if t = min_value then failwith \"abs overflow\" else abs t\n let neg t = if t = min_value then failwith \"neg overflow\" else neg t\nend\n\nlet () = assert (Int.( = ) num_bits 63)\n\nlet random_of_int ?(state = Random.State.default) bound =\n of_int (Random.State.int state (to_int_exn bound))\n;;\n\nlet random_of_int64 ?(state = Random.State.default) bound =\n of_int64_exn (Random.State.int64 state (to_int64 bound))\n;;\n\nlet random =\n match Word_size.word_size with\n | W64 -> random_of_int\n | W32 -> random_of_int64\n;;\n\nlet random_incl_of_int ?(state = Random.State.default) lo hi =\n of_int (Random.State.int_incl state (to_int_exn lo) (to_int_exn hi))\n;;\n\nlet random_incl_of_int64 ?(state = Random.State.default) lo hi =\n of_int64_exn (Random.State.int64_incl state (to_int64 lo) (to_int64 hi))\n;;\n\nlet random_incl =\n match Word_size.word_size with\n | W64 -> random_incl_of_int\n | W32 -> random_incl_of_int64\n;;\n\nlet floor_log2 t =\n match Word_size.word_size with\n | W64 -> t |> to_int_exn |> Int.floor_log2\n | W32 ->\n if t <= zero\n then raise_s (Sexp.message \"[Int.floor_log2] got invalid input\" [ \"\", sexp_of_t t ]);\n let floor_log2 = ref (Int.( - ) num_bits 2) in\n while equal zero (bit_and t (shift_left one !floor_log2)) do\n floor_log2 := Int.( - ) !floor_log2 1\n done;\n !floor_log2\n;;\n\nmodule Private = struct\n module Repr = Repr\n\n let repr = repr\n\n module Emul = Int63_emul\nend\n","open! Import\ninclude Hashtbl_intf\n\nmodule type Key = Key.S\n\nlet with_return = With_return.with_return\nlet hash_param = Hashable.hash_param\nlet hash = Hashable.hash\nlet raise_s = Error.raise_s\n\ntype ('k, 'v) t =\n { mutable table : ('k, 'v) Avltree.t array\n ; mutable length : int\n (* [recently_added] is the reference passed to [Avltree.add]. We put it in the hash\n table to avoid allocating it at every [set]. *)\n ; recently_added : bool ref\n ; growth_allowed : bool\n ; hashable : 'k Hashable.t\n ; mutable mutation_allowed : bool (* Set during all iteration operations *)\n }\n\ntype 'a key = 'a\n\nlet sexp_of_key t = t.hashable.Hashable.sexp_of_t\nlet compare_key t = t.hashable.Hashable.compare\n\nlet ensure_mutation_allowed t =\n if not t.mutation_allowed\n then failwith \"Hashtbl: mutation not allowed during iteration\"\n;;\n\nlet without_mutating t f =\n if t.mutation_allowed\n then (\n t.mutation_allowed <- false;\n match f () with\n | x ->\n t.mutation_allowed <- true;\n x\n | exception exn ->\n t.mutation_allowed <- true;\n raise exn)\n else f ()\n;;\n\n(** Internally use a maximum size that is a power of 2. Reverses the above to find the\n floor power of 2 below the system max array length *)\nlet max_table_length = Int.floor_pow2 Array.max_length\n\n(* The default size is chosen to be 0 (as opposed to 128 as it was before) because:\n - 128 can create substantial memory overhead (x10) when creating many tables, most\n of which are not big (say, if you have a hashtbl of hashtbl). And memory overhead is\n not that easy to profile.\n - if a hashtbl is going to grow, it's not clear why 128 is markedly better than other\n sizes (if you going to stick 1000 elements, you're going to grow the hashtable once\n or twice anyway)\n - in other languages (like rust, python, and apparently go), the default is also a\n small size. *)\nlet create ?(growth_allowed = true) ?(size = 0) ~hashable () =\n let size = Int.min (Int.max 1 size) max_table_length in\n let size = Int.ceil_pow2 size in\n { table = Array.create ~len:size Avltree.empty\n ; length = 0\n ; growth_allowed\n ; recently_added = ref false\n ; hashable\n ; mutation_allowed = true\n }\n;;\n\n(** Supplemental hash. This may not be necessary, it is intended as a defense against poor\n hash functions, for which the power of 2 sized table will be especially sensitive.\n With some testing we may choose to add it, but this table is designed to be robust to\n collisions, and in most of my testing this degrades performance. *)\nlet _supplemental_hash h =\n let h = h lxor ((h lsr 20) lxor (h lsr 12)) in\n h lxor (h lsr 7) lxor (h lsr 4)\n;;\n\nlet slot t key =\n let hash = t.hashable.Hashable.hash key in\n (* this is always non-negative because we do [land] with non-negative number *)\n hash land (Array.length t.table - 1)\n;;\n\nlet add_worker t ~replace ~key ~data =\n let i = slot t key in\n let root = t.table.(i) in\n let added = t.recently_added in\n added := false;\n let new_root =\n (* The avl tree might replace the value [replace=true] or do nothing [replace=false]\n to the entry, in that case the table did not get bigger, so we should not\n increment length, we pass in the bool ref t.added so that it can tell us whether\n it added or replaced. We do it this way to avoid extra allocation. Since the bool\n is an immediate it does not go through the write barrier. *)\n Avltree.add ~replace root ~compare:(compare_key t) ~added ~key ~data\n in\n if !added then t.length <- t.length + 1;\n (* This little optimization saves a caml_modify when the tree\n hasn't been rebalanced. *)\n if not (phys_equal new_root root) then t.table.(i) <- new_root\n;;\n\nlet maybe_resize_table t =\n let len = Array.length t.table in\n let should_grow = t.length > len in\n if should_grow && t.growth_allowed\n then (\n let new_array_length = Int.min (len * 2) max_table_length in\n if new_array_length > len\n then (\n let new_table = Array.create ~len:new_array_length Avltree.empty in\n let old_table = t.table in\n t.table <- new_table;\n t.length <- 0;\n let f ~key ~data = add_worker ~replace:true t ~key ~data in\n for i = 0 to Array.length old_table - 1 do\n Avltree.iter old_table.(i) ~f\n done))\n;;\n\nlet set t ~key ~data =\n ensure_mutation_allowed t;\n add_worker ~replace:true t ~key ~data;\n maybe_resize_table t\n;;\n\nlet add t ~key ~data =\n ensure_mutation_allowed t;\n add_worker ~replace:false t ~key ~data;\n if !(t.recently_added)\n then (\n maybe_resize_table t;\n `Ok)\n else `Duplicate\n;;\n\nlet add_exn t ~key ~data =\n match add t ~key ~data with\n | `Ok -> ()\n | `Duplicate ->\n let sexp_of_key = sexp_of_key t in\n let error = Error.create \"Hashtbl.add_exn got key already present\" key sexp_of_key in\n Error.raise error\n;;\n\nlet clear t =\n ensure_mutation_allowed t;\n for i = 0 to Array.length t.table - 1 do\n t.table.(i) <- Avltree.empty\n done;\n t.length <- 0\n;;\n\nlet find_and_call t key ~if_found ~if_not_found =\n (* with a good hash function these first two cases will be the overwhelming majority,\n and Avltree.find is recursive, so it can't be inlined, so doing this avoids a\n function call in most cases. *)\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found v else if_not_found key\n | tree ->\n Avltree.find_and_call tree ~compare:(compare_key t) key ~if_found ~if_not_found\n;;\n\nlet find_and_call1 t key ~a ~if_found ~if_not_found =\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key a\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found v a else if_not_found key a\n | tree ->\n Avltree.find_and_call1 tree ~compare:(compare_key t) key ~a ~if_found ~if_not_found\n;;\n\nlet find_and_call2 t key ~a ~b ~if_found ~if_not_found =\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key a b\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found v a b else if_not_found key a b\n | tree ->\n Avltree.find_and_call2\n tree\n ~compare:(compare_key t)\n key\n ~a\n ~b\n ~if_found\n ~if_not_found\n;;\n\nlet findi_and_call t key ~if_found ~if_not_found =\n (* with a good hash function these first two cases will be the overwhelming majority,\n and Avltree.find is recursive, so it can't be inlined, so doing this avoids a\n function call in most cases. *)\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found ~key:k ~data:v else if_not_found key\n | tree ->\n Avltree.findi_and_call tree ~compare:(compare_key t) key ~if_found ~if_not_found\n;;\n\nlet findi_and_call1 t key ~a ~if_found ~if_not_found =\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key a\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found ~key:k ~data:v a else if_not_found key a\n | tree ->\n Avltree.findi_and_call1 tree ~compare:(compare_key t) key ~a ~if_found ~if_not_found\n;;\n\nlet findi_and_call2 t key ~a ~b ~if_found ~if_not_found =\n match t.table.(slot t key) with\n | Avltree.Empty -> if_not_found key a b\n | Avltree.Leaf { key = k; value = v } ->\n if compare_key t k key = 0 then if_found ~key:k ~data:v a b else if_not_found key a b\n | tree ->\n Avltree.findi_and_call2\n tree\n ~compare:(compare_key t)\n key\n ~a\n ~b\n ~if_found\n ~if_not_found\n;;\n\nlet find =\n let if_found v = Some v in\n let if_not_found _ = None in\n fun t key -> find_and_call t key ~if_found ~if_not_found\n;;\n\nlet mem t key =\n match t.table.(slot t key) with\n | Avltree.Empty -> false\n | Avltree.Leaf { key = k; value = _ } -> compare_key t k key = 0\n | tree -> Avltree.mem tree ~compare:(compare_key t) key\n;;\n\nlet remove t key =\n ensure_mutation_allowed t;\n let i = slot t key in\n let root = t.table.(i) in\n let added_or_removed = t.recently_added in\n added_or_removed := false;\n let new_root =\n Avltree.remove root ~removed:added_or_removed ~compare:(compare_key t) key\n in\n if not (phys_equal root new_root) then t.table.(i) <- new_root;\n if !added_or_removed then t.length <- t.length - 1\n;;\n\nlet length t = t.length\nlet is_empty t = length t = 0\n\nlet fold t ~init ~f =\n if length t = 0\n then init\n else (\n let n = Array.length t.table in\n let acc = ref init in\n let m = t.mutation_allowed in\n match\n t.mutation_allowed <- false;\n for i = 0 to n - 1 do\n match Array.unsafe_get t.table i with\n | Avltree.Empty -> ()\n | Avltree.Leaf { key; value = data } -> acc := f ~key ~data !acc\n | bucket -> acc := Avltree.fold bucket ~init:!acc ~f\n done\n with\n | () ->\n t.mutation_allowed <- m;\n !acc\n | exception exn ->\n t.mutation_allowed <- m;\n raise exn)\n;;\n\nlet iteri t ~f =\n if t.length = 0\n then ()\n else (\n let n = Array.length t.table in\n let m = t.mutation_allowed in\n match\n t.mutation_allowed <- false;\n for i = 0 to n - 1 do\n match Array.unsafe_get t.table i with\n | Avltree.Empty -> ()\n | Avltree.Leaf { key; value = data } -> f ~key ~data\n | bucket -> Avltree.iter bucket ~f\n done\n with\n | () -> t.mutation_allowed <- m\n | exception exn ->\n t.mutation_allowed <- m;\n raise exn)\n;;\n\nlet iter t ~f = iteri t ~f:(fun ~key:_ ~data -> f data)\nlet iter_keys t ~f = iteri t ~f:(fun ~key ~data:_ -> f key)\n\nlet rec choose_nonempty table i =\n let avltree = table.(i) in\n if Avltree.is_empty avltree\n then choose_nonempty table (i + 1)\n else Avltree.choose_exn avltree\n;;\n\nlet choose_exn t =\n if t.length = 0 then raise_s (Sexp.message \"[Hashtbl.choose_exn] of empty hashtbl\" []);\n choose_nonempty t.table 0\n;;\n\nlet choose t = if is_empty t then None else Some (choose_nonempty t.table 0)\n\nlet invariant invariant_key invariant_data t =\n for i = 0 to Array.length t.table - 1 do\n Avltree.invariant t.table.(i) ~compare:(compare_key t)\n done;\n let real_len =\n fold t ~init:0 ~f:(fun ~key ~data i ->\n invariant_key key;\n invariant_data data;\n i + 1)\n in\n assert (real_len = t.length)\n;;\n\nlet find_exn =\n let if_found v _ = v in\n let if_not_found k t =\n raise\n (Not_found_s (List [ Atom \"Hashtbl.find_exn: not found\"; t.hashable.sexp_of_t k ]))\n in\n let find_exn t key = find_and_call1 t key ~a:t ~if_found ~if_not_found in\n (* named to preserve symbol in compiled binary *)\n find_exn\n;;\n\nlet existsi t ~f =\n with_return (fun r ->\n iteri t ~f:(fun ~key ~data -> if f ~key ~data then r.return true);\n false)\n;;\n\nlet exists t ~f = existsi t ~f:(fun ~key:_ ~data -> f data)\nlet for_alli t ~f = not (existsi t ~f:(fun ~key ~data -> not (f ~key ~data)))\nlet for_all t ~f = not (existsi t ~f:(fun ~key:_ ~data -> not (f data)))\n\nlet counti t ~f =\n fold t ~init:0 ~f:(fun ~key ~data acc -> if f ~key ~data then acc + 1 else acc)\n;;\n\nlet count t ~f =\n fold t ~init:0 ~f:(fun ~key:_ ~data acc -> if f data then acc + 1 else acc)\n;;\n\nlet mapi t ~f =\n let new_t =\n create ~growth_allowed:t.growth_allowed ~hashable:t.hashable ~size:t.length ()\n in\n iteri t ~f:(fun ~key ~data -> set new_t ~key ~data:(f ~key ~data));\n new_t\n;;\n\nlet map t ~f = mapi t ~f:(fun ~key:_ ~data -> f data)\nlet copy t = map t ~f:Fn.id\n\nlet filter_mapi t ~f =\n let new_t =\n create ~growth_allowed:t.growth_allowed ~hashable:t.hashable ~size:t.length ()\n in\n iteri t ~f:(fun ~key ~data ->\n match f ~key ~data with\n | Some new_data -> set new_t ~key ~data:new_data\n | None -> ());\n new_t\n;;\n\nlet filter_map t ~f = filter_mapi t ~f:(fun ~key:_ ~data -> f data)\n\nlet filteri t ~f =\n filter_mapi t ~f:(fun ~key ~data -> if f ~key ~data then Some data else None)\n;;\n\nlet filter t ~f = filteri t ~f:(fun ~key:_ ~data -> f data)\nlet filter_keys t ~f = filteri t ~f:(fun ~key ~data:_ -> f key)\n\nlet partition_mapi t ~f =\n let t0 =\n create ~growth_allowed:t.growth_allowed ~hashable:t.hashable ~size:t.length ()\n in\n let t1 =\n create ~growth_allowed:t.growth_allowed ~hashable:t.hashable ~size:t.length ()\n in\n iteri t ~f:(fun ~key ~data ->\n match (f ~key ~data : _ Either.t) with\n | First new_data -> set t0 ~key ~data:new_data\n | Second new_data -> set t1 ~key ~data:new_data);\n t0, t1\n;;\n\nlet partition_map t ~f = partition_mapi t ~f:(fun ~key:_ ~data -> f data)\n\nlet partitioni_tf t ~f =\n partition_mapi t ~f:(fun ~key ~data ->\n if f ~key ~data then First data else Second data)\n;;\n\nlet partition_tf t ~f = partitioni_tf t ~f:(fun ~key:_ ~data -> f data)\n\nlet find_or_add t id ~default =\n match find t id with\n | Some x -> x\n | None ->\n let default = default () in\n set t ~key:id ~data:default;\n default\n;;\n\nlet findi_or_add t id ~default =\n match find t id with\n | Some x -> x\n | None ->\n let default = default id in\n set t ~key:id ~data:default;\n default\n;;\n\n(* Some hashtbl implementations may be able to perform this more efficiently than two\n separate lookups *)\nlet find_and_remove t id =\n let result = find t id in\n if Option.is_some result then remove t id;\n result\n;;\n\n\nlet change t id ~f =\n match f (find t id) with\n | None -> remove t id\n | Some data -> set t ~key:id ~data\n;;\n\nlet update t id ~f = set t ~key:id ~data:(f (find t id))\n\nlet incr_by ~remove_if_zero t key by =\n if remove_if_zero\n then\n change t key ~f:(fun opt ->\n match by + Option.value opt ~default:0 with\n | 0 -> None\n | n -> Some n)\n else\n update t key ~f:(function\n | None -> by\n | Some i -> by + i)\n;;\n\nlet incr ?(by = 1) ?(remove_if_zero = false) t key = incr_by ~remove_if_zero t key by\nlet decr ?(by = 1) ?(remove_if_zero = false) t key = incr_by ~remove_if_zero t key (-by)\n\nlet add_multi t ~key ~data =\n update t key ~f:(function\n | None -> [ data ]\n | Some l -> data :: l)\n;;\n\nlet remove_multi t key =\n match find t key with\n | None -> ()\n | Some [] | Some [ _ ] -> remove t key\n | Some (_ :: tl) -> set t ~key ~data:tl\n;;\n\nlet find_multi t key =\n match find t key with\n | None -> []\n | Some l -> l\n;;\n\nlet create_mapped ?growth_allowed ?size ~hashable ~get_key ~get_data rows =\n let size =\n match size with\n | Some s -> s\n | None -> List.length rows\n in\n let res = create ?growth_allowed ~hashable ~size () in\n let dupes = ref [] in\n List.iter rows ~f:(fun r ->\n let key = get_key r in\n let data = get_data r in\n if mem res key then dupes := key :: !dupes else set res ~key ~data);\n match !dupes with\n | [] -> `Ok res\n | keys -> `Duplicate_keys (List.dedup_and_sort ~compare:hashable.Hashable.compare keys)\n;;\n\nlet create_mapped_multi ?growth_allowed ?size ~hashable ~get_key ~get_data rows =\n let size =\n match size with\n | Some s -> s\n | None -> List.length rows\n in\n let res = create ?growth_allowed ~size ~hashable () in\n List.iter rows ~f:(fun r ->\n let key = get_key r in\n let data = get_data r in\n add_multi res ~key ~data);\n res\n;;\n\nlet of_alist ?growth_allowed ?size ~hashable lst =\n match create_mapped ?growth_allowed ?size ~hashable ~get_key:fst ~get_data:snd lst with\n | `Ok t -> `Ok t\n | `Duplicate_keys k -> `Duplicate_key (List.hd_exn k)\n;;\n\nlet of_alist_report_all_dups ?growth_allowed ?size ~hashable lst =\n create_mapped ?growth_allowed ?size ~hashable ~get_key:fst ~get_data:snd lst\n;;\n\nlet of_alist_or_error ?growth_allowed ?size ~hashable lst =\n match of_alist ?growth_allowed ?size ~hashable lst with\n | `Ok v -> Result.Ok v\n | `Duplicate_key key ->\n let sexp_of_key = hashable.Hashable.sexp_of_t in\n Or_error.error \"Hashtbl.of_alist_exn: duplicate key\" key sexp_of_key\n;;\n\nlet of_alist_exn ?growth_allowed ?size ~hashable lst =\n match of_alist_or_error ?growth_allowed ?size ~hashable lst with\n | Result.Ok v -> v\n | Result.Error e -> Error.raise e\n;;\n\nlet of_alist_multi ?growth_allowed ?size ~hashable lst =\n create_mapped_multi ?growth_allowed ?size ~hashable ~get_key:fst ~get_data:snd lst\n;;\n\nlet to_alist t = fold ~f:(fun ~key ~data list -> (key, data) :: list) ~init:[] t\n\nlet sexp_of_t sexp_of_key sexp_of_data t =\n t\n |> to_alist\n |> List.sort ~compare:(fun (k1, _) (k2, _) -> t.hashable.compare k1 k2)\n |> sexp_of_list (sexp_of_pair sexp_of_key sexp_of_data)\n;;\n\nlet t_of_sexp ~hashable k_of_sexp d_of_sexp sexp =\n let alist = list_of_sexp (pair_of_sexp k_of_sexp d_of_sexp) sexp in\n match of_alist ~hashable alist ~size:(List.length alist) with\n | `Ok v -> v\n | `Duplicate_key k ->\n (* find the sexp of a duplicate key, so the error is narrowed to a key and not\n the whole map *)\n let alist_sexps = list_of_sexp (pair_of_sexp Fn.id Fn.id) sexp in\n let found_first_k = ref false in\n List.iter2_exn alist alist_sexps ~f:(fun (k2, _) (k2_sexp, _) ->\n if hashable.compare k k2 = 0\n then\n if !found_first_k\n then of_sexp_error \"Hashtbl.t_of_sexp: duplicate key\" k2_sexp\n else found_first_k := true);\n assert false\n;;\n\nlet validate ~name f t = Validate.alist ~name f (to_alist t)\nlet keys t = fold t ~init:[] ~f:(fun ~key ~data:_ acc -> key :: acc)\nlet data t = fold ~f:(fun ~key:_ ~data list -> data :: list) ~init:[] t\n\nlet add_to_groups groups ~get_key ~get_data ~combine ~rows =\n List.iter rows ~f:(fun row ->\n let key = get_key row in\n let data = get_data row in\n let data =\n match find groups key with\n | None -> data\n | Some old -> combine old data\n in\n set groups ~key ~data)\n;;\n\nlet group ?growth_allowed ?size ~hashable ~get_key ~get_data ~combine rows =\n let res = create ?growth_allowed ?size ~hashable () in\n add_to_groups res ~get_key ~get_data ~combine ~rows;\n res\n;;\n\nlet create_with_key ?growth_allowed ?size ~hashable ~get_key rows =\n create_mapped ?growth_allowed ?size ~hashable ~get_key ~get_data:Fn.id rows\n;;\n\nlet create_with_key_or_error ?growth_allowed ?size ~hashable ~get_key rows =\n match create_with_key ?growth_allowed ?size ~hashable ~get_key rows with\n | `Ok t -> Result.Ok t\n | `Duplicate_keys keys ->\n let sexp_of_key = hashable.Hashable.sexp_of_t in\n Or_error.error_s\n (Sexp.message\n \"Hashtbl.create_with_key: duplicate keys\"\n [ \"keys\", sexp_of_list sexp_of_key keys ])\n;;\n\nlet create_with_key_exn ?growth_allowed ?size ~hashable ~get_key rows =\n Or_error.ok_exn\n (create_with_key_or_error ?growth_allowed ?size ~hashable ~get_key rows)\n;;\n\nlet merge =\n let maybe_set t ~key ~f d =\n match f ~key d with\n | None -> ()\n | Some v -> set t ~key ~data:v\n in\n fun t_left t_right ~f ->\n if not (Hashable.equal t_left.hashable t_right.hashable)\n then invalid_arg \"Hashtbl.merge: different 'hashable' values\";\n let new_t =\n create\n ~growth_allowed:t_left.growth_allowed\n ~hashable:t_left.hashable\n ~size:t_left.length\n ()\n in\n without_mutating t_left (fun () ->\n without_mutating t_right (fun () ->\n iteri t_left ~f:(fun ~key ~data:left ->\n match find t_right key with\n | None -> maybe_set new_t ~key ~f (`Left left)\n | Some right -> maybe_set new_t ~key ~f (`Both (left, right)));\n iteri t_right ~f:(fun ~key ~data:right ->\n match find t_left key with\n | None -> maybe_set new_t ~key ~f (`Right right)\n | Some _ -> ()\n (* already done above *))));\n new_t\n;;\n\nlet merge_into ~src ~dst ~f =\n iteri src ~f:(fun ~key ~data ->\n let dst_data = find dst key in\n let action = without_mutating dst (fun () -> f ~key data dst_data) in\n match (action : _ Merge_into_action.t) with\n | Remove -> remove dst key\n | Set_to data ->\n (match dst_data with\n | None -> set dst ~key ~data\n | Some dst_data -> if not (phys_equal dst_data data) then set dst ~key ~data))\n;;\n\nlet filteri_inplace t ~f =\n let to_remove =\n fold t ~init:[] ~f:(fun ~key ~data ac -> if f ~key ~data then ac else key :: ac)\n in\n List.iter to_remove ~f:(fun key -> remove t key)\n;;\n\nlet filter_inplace t ~f = filteri_inplace t ~f:(fun ~key:_ ~data -> f data)\nlet filter_keys_inplace t ~f = filteri_inplace t ~f:(fun ~key ~data:_ -> f key)\n\nlet filter_mapi_inplace t ~f =\n let map_results =\n fold t ~init:[] ~f:(fun ~key ~data ac -> (key, f ~key ~data) :: ac)\n in\n List.iter map_results ~f:(fun (key, result) ->\n match result with\n | None -> remove t key\n | Some data -> set t ~key ~data)\n;;\n\nlet filter_map_inplace t ~f = filter_mapi_inplace t ~f:(fun ~key:_ ~data -> f data)\n\nlet mapi_inplace t ~f =\n ensure_mutation_allowed t;\n without_mutating t (fun () -> Array.iter t.table ~f:(Avltree.mapi_inplace ~f))\n;;\n\nlet map_inplace t ~f = mapi_inplace t ~f:(fun ~key:_ ~data -> f data)\n\nlet equal equal t t' =\n length t = length t'\n && with_return (fun r ->\n without_mutating t' (fun () ->\n iteri t ~f:(fun ~key ~data ->\n match find t' key with\n | None -> r.return false\n | Some data' -> if not (equal data data') then r.return false));\n true)\n;;\n\nlet similar = equal\n\nmodule Accessors = struct\n let invariant = invariant\n let choose = choose\n let choose_exn = choose_exn\n let clear = clear\n let copy = copy\n let remove = remove\n let set = set\n let add = add\n let add_exn = add_exn\n let change = change\n let update = update\n let add_multi = add_multi\n let remove_multi = remove_multi\n let find_multi = find_multi\n let mem = mem\n let iter_keys = iter_keys\n let iter = iter\n let iteri = iteri\n let exists = exists\n let existsi = existsi\n let for_all = for_all\n let for_alli = for_alli\n let count = count\n let counti = counti\n let fold = fold\n let length = length\n let is_empty = is_empty\n let map = map\n let mapi = mapi\n let filter_map = filter_map\n let filter_mapi = filter_mapi\n let filter_keys = filter_keys\n let filter = filter\n let filteri = filteri\n let partition_map = partition_map\n let partition_mapi = partition_mapi\n let partition_tf = partition_tf\n let partitioni_tf = partitioni_tf\n let find_or_add = find_or_add\n let findi_or_add = findi_or_add\n let find = find\n let find_exn = find_exn\n let find_and_call = find_and_call\n let find_and_call1 = find_and_call1\n let find_and_call2 = find_and_call2\n let findi_and_call = findi_and_call\n let findi_and_call1 = findi_and_call1\n let findi_and_call2 = findi_and_call2\n let find_and_remove = find_and_remove\n let to_alist = to_alist\n let validate = validate\n let merge = merge\n let merge_into = merge_into\n let keys = keys\n let data = data\n let filter_keys_inplace = filter_keys_inplace\n let filter_inplace = filter_inplace\n let filteri_inplace = filteri_inplace\n let map_inplace = map_inplace\n let mapi_inplace = mapi_inplace\n let filter_map_inplace = filter_map_inplace\n let filter_mapi_inplace = filter_mapi_inplace\n let equal = equal\n let similar = similar\n let incr = incr\n let decr = decr\n let sexp_of_key = sexp_of_key\nend\n\nmodule Creators (Key : sig\n type 'a t\n\n val hashable : 'a t Hashable.t\n end) : sig\n type ('a, 'b) t_ = ('a Key.t, 'b) t\n\n val t_of_sexp : (Sexp.t -> 'a Key.t) -> (Sexp.t -> 'b) -> Sexp.t -> ('a, 'b) t_\n\n include\n Creators_generic\n with type ('a, 'b) t := ('a, 'b) t_\n with type 'a key := 'a Key.t\n with type ('key, 'data, 'a) create_options :=\n ('key, 'data, 'a) create_options_without_first_class_module\nend = struct\n let hashable = Key.hashable\n\n type ('a, 'b) t_ = ('a Key.t, 'b) t\n\n let create ?growth_allowed ?size () = create ?growth_allowed ?size ~hashable ()\n let of_alist ?growth_allowed ?size l = of_alist ?growth_allowed ~hashable ?size l\n\n let of_alist_report_all_dups ?growth_allowed ?size l =\n of_alist_report_all_dups ?growth_allowed ~hashable ?size l\n ;;\n\n let of_alist_or_error ?growth_allowed ?size l =\n of_alist_or_error ?growth_allowed ~hashable ?size l\n ;;\n\n let of_alist_exn ?growth_allowed ?size l =\n of_alist_exn ?growth_allowed ~hashable ?size l\n ;;\n\n let t_of_sexp k_of_sexp d_of_sexp sexp = t_of_sexp ~hashable k_of_sexp d_of_sexp sexp\n\n let of_alist_multi ?growth_allowed ?size l =\n of_alist_multi ?growth_allowed ~hashable ?size l\n ;;\n\n let create_mapped ?growth_allowed ?size ~get_key ~get_data l =\n create_mapped ?growth_allowed ~hashable ?size ~get_key ~get_data l\n ;;\n\n let create_with_key ?growth_allowed ?size ~get_key l =\n create_with_key ?growth_allowed ~hashable ?size ~get_key l\n ;;\n\n let create_with_key_or_error ?growth_allowed ?size ~get_key l =\n create_with_key_or_error ?growth_allowed ~hashable ?size ~get_key l\n ;;\n\n let create_with_key_exn ?growth_allowed ?size ~get_key l =\n create_with_key_exn ?growth_allowed ~hashable ?size ~get_key l\n ;;\n\n let group ?growth_allowed ?size ~get_key ~get_data ~combine l =\n group ?growth_allowed ~hashable ?size ~get_key ~get_data ~combine l\n ;;\nend\n\nmodule Poly = struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n type 'a key = 'a\n\n let hashable = Hashable.poly\n\n include Creators (struct\n type 'a t = 'a\n\n let hashable = hashable\n end)\n\n include Accessors\n\n let sexp_of_t = sexp_of_t\nend\n\nmodule Private = struct\n module type Creators_generic = Creators_generic\n module type Hashable = Hashable.Hashable\n\n type nonrec ('key, 'data, 'z) create_options_without_first_class_module =\n ('key, 'data, 'z) create_options_without_first_class_module\n\n let hashable t = t.hashable\nend\n\nlet create ?growth_allowed ?size m =\n create ~hashable:(Hashable.of_key m) ?growth_allowed ?size ()\n;;\n\nlet of_alist ?growth_allowed ?size m l =\n of_alist ~hashable:(Hashable.of_key m) ?growth_allowed ?size l\n;;\n\nlet of_alist_report_all_dups ?growth_allowed ?size m l =\n of_alist_report_all_dups ~hashable:(Hashable.of_key m) ?growth_allowed ?size l\n;;\n\nlet of_alist_or_error ?growth_allowed ?size m l =\n of_alist_or_error ~hashable:(Hashable.of_key m) ?growth_allowed ?size l\n;;\n\nlet of_alist_exn ?growth_allowed ?size m l =\n of_alist_exn ~hashable:(Hashable.of_key m) ?growth_allowed ?size l\n;;\n\nlet of_alist_multi ?growth_allowed ?size m l =\n of_alist_multi ~hashable:(Hashable.of_key m) ?growth_allowed ?size l\n;;\n\nlet create_mapped ?growth_allowed ?size m ~get_key ~get_data l =\n create_mapped ~hashable:(Hashable.of_key m) ?growth_allowed ?size ~get_key ~get_data l\n;;\n\nlet create_with_key ?growth_allowed ?size m ~get_key l =\n create_with_key ~hashable:(Hashable.of_key m) ?growth_allowed ?size ~get_key l\n;;\n\nlet create_with_key_or_error ?growth_allowed ?size m ~get_key l =\n create_with_key_or_error ~hashable:(Hashable.of_key m) ?growth_allowed ?size ~get_key l\n;;\n\nlet create_with_key_exn ?growth_allowed ?size m ~get_key l =\n create_with_key_exn ~hashable:(Hashable.of_key m) ?growth_allowed ?size ~get_key l\n;;\n\nlet group ?growth_allowed ?size m ~get_key ~get_data ~combine l =\n group ~hashable:(Hashable.of_key m) ?growth_allowed ?size ~get_key ~get_data ~combine l\n;;\n\nlet hashable_s t = Hashable.to_key t.hashable\n\nmodule M (K : T.T) = struct\n type nonrec 'v t = (K.t, 'v) t\nend\n\nmodule type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\nend\n\nmodule type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Key.S with type t := t\nend\n\nlet sexp_of_m__t (type k) (module K : Sexp_of_m with type t = k) sexp_of_v t =\n sexp_of_t K.sexp_of_t sexp_of_v t\n;;\n\nlet m__t_of_sexp (type k) (module K : M_of_sexp with type t = k) v_of_sexp sexp =\n t_of_sexp ~hashable:(Hashable.of_key (module K)) K.t_of_sexp v_of_sexp sexp\n;;\n\n(* typechecking this code is a compile-time test that [Creators] is a specialization of\n [Creators_generic]. *)\nmodule Check : sig end = struct\n module Make_creators_check\n (Type : T.T2)\n (Key : T.T1)\n (Options : T.T3)\n (M : Creators_generic\n with type ('a, 'b) t := ('a, 'b) Type.t\n with type 'a key := 'a Key.t\n with type ('a, 'b, 'z) create_options := ('a, 'b, 'z) Options.t) =\n struct end\n\n module Check_creators_is_specialization_of_creators_generic (M : Creators) =\n Make_creators_check\n (struct\n type ('a, 'b) t = ('a, 'b) M.t\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type ('a, 'b, 'z) t = ('a, 'b, 'z) create_options\n end)\n (struct\n include M\n\n let create ?growth_allowed ?size m () = create ?growth_allowed ?size m\n end)\nend\n","open! Import\n\nmodule Key = struct\n module type S = sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n (** Two [t]s that [compare] equal must have equal hashes for the hashtable\n to behave properly. *)\n val hash : t -> int\n end\n\n type 'a t = (module S with type t = 'a)\nend\n\nmodule Merge_into_action = struct\n type 'a t =\n | Remove\n | Set_to of 'a\nend\n\nmodule type Accessors = sig\n (** {2 Accessors} *)\n\n type ('a, 'b) t\n type 'a key\n\n val sexp_of_key : ('a, _) t -> 'a key -> Sexp.t\n val clear : (_, _) t -> unit\n val copy : ('a, 'b) t -> ('a, 'b) t\n\n (** Attempting to modify ([set], [remove], etc.) the hashtable during iteration ([fold],\n [iter], [iter_keys], [iteri]) will raise an exception. *)\n val fold : ('a, 'b) t -> init:'c -> f:(key:'a key -> data:'b -> 'c -> 'c) -> 'c\n\n val iter_keys : ('a, _) t -> f:('a key -> unit) -> unit\n val iter : (_, 'b) t -> f:('b -> unit) -> unit\n\n (** Iterates over both keys and values.\n\n Example:\n\n {v\n let h = Hashtbl.of_alist_exn (module Int) [(1, 4); (5, 6)] in\n Hashtbl.iteri h ~f:(fun ~key ~data ->\n print_endline (Printf.sprintf \"%d-%d\" key data));;\n 1-4\n 5-6\n - : unit = ()\n v} *)\n val iteri : ('a, 'b) t -> f:(key:'a key -> data:'b -> unit) -> unit\n\n val existsi : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> bool\n val exists : (_, 'b) t -> f:('b -> bool) -> bool\n val for_alli : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> bool\n val for_all : (_, 'b) t -> f:('b -> bool) -> bool\n val counti : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> int\n val count : (_, 'b) t -> f:('b -> bool) -> int\n val length : (_, _) t -> int\n val is_empty : (_, _) t -> bool\n val mem : ('a, _) t -> 'a key -> bool\n val remove : ('a, _) t -> 'a key -> unit\n val choose : ('a, 'b) t -> ('a key * 'b) option\n val choose_exn : ('a, 'b) t -> 'a key * 'b\n\n (** Sets the given [key] to [data]. *)\n val set : ('a, 'b) t -> key:'a key -> data:'b -> unit\n\n (** [add] and [add_exn] leave the table unchanged if the key was already present. *)\n val add : ('a, 'b) t -> key:'a key -> data:'b -> [ `Ok | `Duplicate ]\n\n val add_exn : ('a, 'b) t -> key:'a key -> data:'b -> unit\n\n (** [change t key ~f] changes [t]'s value for [key] to be [f (find t key)]. *)\n val change : ('a, 'b) t -> 'a key -> f:('b option -> 'b option) -> unit\n\n (** [update t key ~f] is [change t key ~f:(fun o -> Some (f o))]. *)\n val update : ('a, 'b) t -> 'a key -> f:('b option -> 'b) -> unit\n\n (** [map t f] returns a new table with values replaced by the result of applying [f]\n to the current values.\n\n Example:\n\n {v\n let h = Hashtbl.of_alist_exn (module Int) [(1, 4); (5, 6)] in\n let h' = Hashtbl.map h ~f:(fun x -> x * 2) in\n Hashtbl.to_alist h';;\n - : (int * int) list = [(5, 12); (1, 8)]\n v} *)\n val map : ('a, 'b) t -> f:('b -> 'c) -> ('a, 'c) t\n\n (** Like [map], but the function [f] takes both key and data as arguments. *)\n val mapi : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'c) -> ('a, 'c) t\n\n (** Returns a new table by filtering the given table's values by [f]: the keys for which\n [f] applied to the current value returns [Some] are kept, and those for which it\n returns [None] are discarded.\n\n Example:\n\n {v\n let h = Hashtbl.of_alist_exn (module Int) [(1, 4); (5, 6)] in\n Hashtbl.filter_map h ~f:(fun x -> if x > 5 then Some x else None)\n |> Hashtbl.to_alist;;\n - : (int * int) list = [(5, 6)]\n v} *)\n val filter_map : ('a, 'b) t -> f:('b -> 'c option) -> ('a, 'c) t\n\n (** Like [filter_map], but the function [f] takes both key and data as arguments. *)\n val filter_mapi : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'c option) -> ('a, 'c) t\n\n val filter_keys : ('a, 'b) t -> f:('a key -> bool) -> ('a, 'b) t\n val filter : ('a, 'b) t -> f:('b -> bool) -> ('a, 'b) t\n val filteri : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> ('a, 'b) t\n\n (** Returns new tables with bound values partitioned by [f] applied to the bound\n values. *)\n val partition_map\n : ('a, 'b) t\n -> f:('b -> ('c, 'd) Either.t)\n -> ('a, 'c) t * ('a, 'd) t\n\n (** Like [partition_map], but the function [f] takes both key and data as arguments. *)\n val partition_mapi\n : ('a, 'b) t\n -> f:(key:'a key -> data:'b -> ('c, 'd) Either.t)\n -> ('a, 'c) t * ('a, 'd) t\n\n (** Returns a pair of tables [(t1, t2)], where [t1] contains all the elements of the\n initial table which satisfy the predicate [f], and [t2] contains the rest. *)\n val partition_tf : ('a, 'b) t -> f:('b -> bool) -> ('a, 'b) t * ('a, 'b) t\n\n (** Like [partition_tf], but the function [f] takes both key and data as arguments. *)\n val partitioni_tf\n : ('a, 'b) t\n -> f:(key:'a key -> data:'b -> bool)\n -> ('a, 'b) t * ('a, 'b) t\n\n (** [find_or_add t k ~default] returns the data associated with key [k] if it is in the\n table [t], and otherwise assigns [k] the value returned by [default ()]. *)\n val find_or_add : ('a, 'b) t -> 'a key -> default:(unit -> 'b) -> 'b\n\n (** Like [find_or_add] but [default] takes the key as an argument. *)\n val findi_or_add : ('a, 'b) t -> 'a key -> default:('a key -> 'b) -> 'b\n\n (** [find t k] returns [Some] (the current binding) of [k] in [t], or [None] if no such\n binding exists. *)\n val find : ('a, 'b) t -> 'a key -> 'b option\n\n (** [find_exn t k] returns the current binding of [k] in [t], or raises [Caml.Not_found]\n or [Not_found_s] if no such binding exists. *)\n val find_exn : ('a, 'b) t -> 'a key -> 'b\n\n (** [find_and_call t k ~if_found ~if_not_found]\n\n is equivalent to:\n\n [match find t k with Some v -> if_found v | None -> if_not_found k]\n\n except that it doesn't allocate the option. *)\n val find_and_call\n : ('a, 'b) t\n -> 'a key\n -> if_found:('b -> 'c)\n -> if_not_found:('a key -> 'c)\n -> 'c\n\n (** Just like [find_and_call], but takes an extra argument which is passed to [if_found]\n and [if_not_found], so that the client code can avoid allocating closures or using\n refs to pass this additional information. This function is only useful in code\n which tries to minimize heap allocation. *)\n val find_and_call1\n : ('a, 'b) t\n -> 'a key\n -> a:'d\n -> if_found:('b -> 'd -> 'c)\n -> if_not_found:('a key -> 'd -> 'c)\n -> 'c\n\n val find_and_call2\n : ('a, 'b) t\n -> 'a key\n -> a:'d\n -> b:'e\n -> if_found:('b -> 'd -> 'e -> 'c)\n -> if_not_found:('a key -> 'd -> 'e -> 'c)\n -> 'c\n\n val findi_and_call\n : ('a, 'b) t\n -> 'a key\n -> if_found:(key:'a key -> data:'b -> 'c)\n -> if_not_found:('a key -> 'c)\n -> 'c\n\n val findi_and_call1\n : ('a, 'b) t\n -> 'a key\n -> a:'d\n -> if_found:(key:'a key -> data:'b -> 'd -> 'c)\n -> if_not_found:('a key -> 'd -> 'c)\n -> 'c\n\n val findi_and_call2\n : ('a, 'b) t\n -> 'a key\n -> a:'d\n -> b:'e\n -> if_found:(key:'a key -> data:'b -> 'd -> 'e -> 'c)\n -> if_not_found:('a key -> 'd -> 'e -> 'c)\n -> 'c\n\n (** [find_and_remove t k] returns Some (the current binding) of k in t and removes it,\n or None is no such binding exists. *)\n val find_and_remove : ('a, 'b) t -> 'a key -> 'b option\n\n (** Merges two hashtables.\n\n The result of [merge f h1 h2] has as keys the set of all [k] in the union of the\n sets of keys of [h1] and [h2] for which [d(k)] is not None, where:\n\n d(k) =\n - [f ~key:k (`Left d1)]\n if [k] in [h1] maps to d1, and [h2] does not have data for [k];\n\n - [f ~key:k (`Right d2)]\n if [k] in [h2] maps to d2, and [h1] does not have data for [k];\n\n - [f ~key:k (`Both (d1, d2))]\n otherwise, where [k] in [h1] maps to [d1] and [k] in [h2] maps to [d2].\n\n Each key [k] is mapped to a single piece of data [x], where [d(k) = Some x].\n\n Example:\n\n {v\n let h1 = Hashtbl.of_alist_exn (module Int) [(1, 5); (2, 3232)] in\n let h2 = Hashtbl.of_alist_exn (module Int) [(1, 3)] in\n Hashtbl.merge h1 h2 ~f:(fun ~key:_ -> function\n | `Left x -> Some (`Left x)\n | `Right x -> Some (`Right x)\n | `Both (x, y) -> if x=y then None else Some (`Both (x,y))\n ) |> Hashtbl.to_alist;;\n - : (int * [> `Both of int * int | `Left of int | `Right of int ]) list =\n [(2, `Left 3232); (1, `Both (5, 3))]\n v} *)\n val merge\n : ('k, 'a) t\n -> ('k, 'b) t\n -> f:(key:'k key -> [ `Left of 'a | `Right of 'b | `Both of 'a * 'b ] -> 'c option)\n -> ('k, 'c) t\n\n\n (** Every [key] in [src] will be removed or set in [dst] according to the return value\n of [f]. *)\n val merge_into\n : src:('k, 'a) t\n -> dst:('k, 'b) t\n -> f:(key:'k key -> 'a -> 'b option -> 'b Merge_into_action.t)\n -> unit\n\n (** Returns the list of all keys for given hashtable. *)\n val keys : ('a, _) t -> 'a key list\n\n (** Returns the list of all data for given hashtable. *)\n val data : (_, 'b) t -> 'b list\n\n (** [filter_inplace t ~f] removes all the elements from [t] that don't satisfy [f]. *)\n val filter_keys_inplace : ('a, _) t -> f:('a key -> bool) -> unit\n\n val filter_inplace : (_, 'b) t -> f:('b -> bool) -> unit\n val filteri_inplace : ('a, 'b) t -> f:(key:'a key -> data:'b -> bool) -> unit\n\n (** [map_inplace t ~f] applies [f] to all elements in [t], transforming them in\n place. *)\n val map_inplace : (_, 'b) t -> f:('b -> 'b) -> unit\n\n val mapi_inplace : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'b) -> unit\n\n (** [filter_map_inplace] combines the effects of [map_inplace] and [filter_inplace]. *)\n val filter_map_inplace : (_, 'b) t -> f:('b -> 'b option) -> unit\n\n val filter_mapi_inplace : ('a, 'b) t -> f:(key:'a key -> data:'b -> 'b option) -> unit\n\n (** [equal f t1 t2] and [similar f t1 t2] both return true iff [t1] and [t2] have the\n same keys and for all keys [k], [f (find_exn t1 k) (find_exn t2 k)]. [equal] and\n [similar] only differ in their types. *)\n val equal : ('b -> 'b -> bool) -> ('a, 'b) t -> ('a, 'b) t -> bool\n\n val similar : ('b1 -> 'b2 -> bool) -> ('a, 'b1) t -> ('a, 'b2) t -> bool\n\n (** Returns the list of all (key, data) pairs for given hashtable. *)\n val to_alist : ('a, 'b) t -> ('a key * 'b) list\n\n val validate\n : name:('a key -> string)\n -> 'b Validate.check\n -> ('a, 'b) t Validate.check\n\n\n (** [remove_if_zero]'s default is [false]. *)\n val incr : ?by:int -> ?remove_if_zero:bool -> ('a, int) t -> 'a key -> unit\n\n val decr : ?by:int -> ?remove_if_zero:bool -> ('a, int) t -> 'a key -> unit\nend\n\nmodule type Multi = sig\n type ('a, 'b) t\n type 'a key\n\n (** [add_multi t ~key ~data] if [key] is present in the table then cons\n [data] on the list, otherwise add [key] with a single element list. *)\n val add_multi : ('a, 'b list) t -> key:'a key -> data:'b -> unit\n\n (** [remove_multi t key] updates the table, removing the head of the list bound to\n [key]. If the list has only one element (or is empty) then the binding is\n removed. *)\n val remove_multi : ('a, _ list) t -> 'a key -> unit\n\n (** [find_multi t key] returns the empty list if [key] is not present in the table,\n returns [t]'s values for [key] otherwise. *)\n val find_multi : ('a, 'b list) t -> 'a key -> 'b list\nend\n\ntype ('key, 'data, 'z) create_options =\n ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'key Key.t\n -> 'z\n\ntype ('key, 'data, 'z) create_options_without_first_class_module =\n ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'z\n\nmodule type Creators_generic = sig\n type ('a, 'b) t\n type 'a key\n type ('key, 'data, 'z) create_options\n\n val create : ('a key, 'b, unit -> ('a, 'b) t) create_options\n\n\n val of_alist\n : ( 'a key\n , 'b\n , ('a key * 'b) list -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a key ] )\n create_options\n\n val of_alist_report_all_dups\n : ( 'a key\n , 'b\n , ('a key * 'b) list -> [ `Ok of ('a, 'b) t | `Duplicate_keys of 'a key list ] )\n create_options\n\n val of_alist_or_error\n : ('a key, 'b, ('a key * 'b) list -> ('a, 'b) t Or_error.t) create_options\n\n val of_alist_exn : ('a key, 'b, ('a key * 'b) list -> ('a, 'b) t) create_options\n\n val of_alist_multi\n : ('a key, 'b list, ('a key * 'b) list -> ('a, 'b list) t) create_options\n\n\n (** {[ create_mapped get_key get_data [x1,...,xn]\n = of_alist [get_key x1, get_data x1; ...; get_key xn, get_data xn] ]} *)\n val create_mapped\n : ( 'a key\n , 'b\n , get_key:('r -> 'a key)\n -> get_data:('r -> 'b)\n -> 'r list\n -> [ `Ok of ('a, 'b) t | `Duplicate_keys of 'a key list ] )\n create_options\n\n\n (** {[ create_with_key ~get_key [x1,...,xn]\n = of_alist [get_key x1, x1; ...; get_key xn, xn] ]} *)\n val create_with_key\n : ( 'a key\n , 'r\n , get_key:('r -> 'a key)\n -> 'r list\n -> [ `Ok of ('a, 'r) t | `Duplicate_keys of 'a key list ] )\n create_options\n\n val create_with_key_or_error\n : ( 'a key\n , 'r\n , get_key:('r -> 'a key) -> 'r list -> ('a, 'r) t Or_error.t )\n create_options\n\n val create_with_key_exn\n : ('a key, 'r, get_key:('r -> 'a key) -> 'r list -> ('a, 'r) t) create_options\n\n\n val group\n : ( 'a key\n , 'b\n , get_key:('r -> 'a key)\n -> get_data:('r -> 'b)\n -> combine:('b -> 'b -> 'b)\n -> 'r list\n -> ('a, 'b) t )\n create_options\nend\n\nmodule type Creators = sig\n type ('a, 'b) t\n\n (** {2 Creators} *)\n\n (** The module you pass to [create] must have a type that is hashable, sexpable, and\n comparable.\n\n Example:\n\n {v\n Hashtbl.create (module Int);;\n - : (int, '_a) Hashtbl.t = ;;\n v} *)\n val create\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a, 'b) t\n\n (** Example:\n\n {v\n Hashtbl.of_alist (module Int) [(3, \"something\"); (2, \"whatever\")]\n - : [ `Duplicate_key of int | `Ok of (int, string) Hashtbl.t ] = `Ok \n v} *)\n val of_alist\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a * 'b) list\n -> [ `Ok of ('a, 'b) t | `Duplicate_key of 'a ]\n\n (** Whereas [of_alist] will report [Duplicate_key] no matter how many dups there are in\n your list, [of_alist_report_all_dups] will report each and every duplicate entry.\n\n For example:\n\n {v\n Hashtbl.of_alist (module Int) [(1, \"foo\"); (1, \"bar\"); (2, \"foo\"); (2, \"bar\")];;\n - : [ `Duplicate_key of int | `Ok of (int, string) Hashtbl.t ] = `Duplicate_key 1\n\n Hashtbl.of_alist_report_all_dups (module Int) [(1, \"foo\"); (1, \"bar\"); (2, \"foo\"); (2, \"bar\")];;\n - : [ `Duplicate_keys of int list | `Ok of (int, string) Hashtbl.t ] = `Duplicate_keys [1; 2]\n v} *)\n val of_alist_report_all_dups\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a * 'b) list\n -> [ `Ok of ('a, 'b) t | `Duplicate_keys of 'a list ]\n\n val of_alist_or_error\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a * 'b) list\n -> ('a, 'b) t Or_error.t\n\n val of_alist_exn\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a * 'b) list\n -> ('a, 'b) t\n\n (** Creates a {{!Multi} \"multi\"} hashtable, i.e., a hashtable where each key points to a\n list potentially containing multiple values. So instead of short-circuiting with a\n [`Duplicate_key] variant on duplicates, as in [of_alist], [of_alist_multi] folds\n those values into a list for the given key:\n\n {v\n let h = Hashtbl.of_alist_multi (module Int) [(1, \"a\"); (1, \"b\"); (2, \"c\"); (2, \"d\")];;\n val h : (int, string list) Hashtbl.t = \n\n Hashtbl.find_exn h 1;;\n - : string list = [\"b\"; \"a\"]\n v} *)\n val of_alist_multi\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> ('a * 'b) list\n -> ('a, 'b list) t\n\n (** Applies the [get_key] and [get_data] functions to the ['r list] to create the\n initial keys and values, respectively, for the new hashtable.\n\n {[ create_mapped get_key get_data [x1;...;xn]\n = of_alist [get_key x1, get_data x1; ...; get_key xn, get_data xn]\n ]}\n\n Example:\n\n {v\n let h =\n Hashtbl.create_mapped (module Int)\n ~get_key:(fun x -> x)\n ~get_data:(fun x -> x + 1)\n [1; 2; 3];;\n val h : [ `Duplicate_keys of int list | `Ok of (int, int) Hashtbl.t ] = `Ok \n\n let h =\n match h with\n | `Ok x -> x\n | `Duplicate_keys _ -> failwith \"\"\n in\n Hashtbl.find_exn h 1;;\n - : int = 2\n v} *)\n val create_mapped\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> get_key:('r -> 'a)\n -> get_data:('r -> 'b)\n -> 'r list\n -> [ `Ok of ('a, 'b) t | `Duplicate_keys of 'a list ]\n\n (** {[ create_with_key ~get_key [x1;...;xn]\n = of_alist [get_key x1, x1; ...; get_key xn, xn] ]} *)\n val create_with_key\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> get_key:('r -> 'a)\n -> 'r list\n -> [ `Ok of ('a, 'r) t | `Duplicate_keys of 'a list ]\n\n val create_with_key_or_error\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> get_key:('r -> 'a)\n -> 'r list\n -> ('a, 'r) t Or_error.t\n\n val create_with_key_exn\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> get_key:('r -> 'a)\n -> 'r list\n -> ('a, 'r) t\n\n (** Like [create_mapped], applies the [get_key] and [get_data] functions to the ['r\n list] to create the initial keys and values, respectively, for the new hashtable --\n and then, like [add_multi], folds together values belonging to the same keys. Here,\n though, the function used for the folding is given by [combine] (instead of just\n being a [cons]).\n\n Example:\n\n {v\n Hashtbl.group (module Int)\n ~get_key:(fun x -> x / 2)\n ~get_data:(fun x -> x)\n ~combine:(fun x y -> x * y)\n [ 1; 2; 3; 4]\n |> Hashtbl.to_alist;;\n - : (int * int) list = [(2, 4); (1, 6); (0, 1)]\n v} *)\n val group\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> get_key:('r -> 'a)\n -> get_data:('r -> 'b)\n -> combine:('b -> 'b -> 'b)\n -> 'r list\n -> ('a, 'b) t\nend\n\nmodule type S_without_submodules = sig\n val hash : 'a -> int\n val hash_param : int -> int -> 'a -> int\n\n type ('a, 'b) t\n\n (** We provide a [sexp_of_t] but not a [t_of_sexp] for this type because one needs to be\n explicit about the hash and comparison functions used when creating a hashtable.\n Note that [Hashtbl.Poly.t] does have [[@@deriving sexp]], and uses OCaml's built-in\n polymorphic comparison and and polymorphic hashing. *)\n val sexp_of_t : ('a -> Sexp.t) -> ('b -> Sexp.t) -> ('a, 'b) t -> Sexp.t\n\n include Creators with type ('a, 'b) t := ('a, 'b) t (** @inline *)\n\n include\n Accessors with type ('a, 'b) t := ('a, 'b) t with type 'a key = 'a\n (** @inline *)\n\n\n include\n Multi with type ('a, 'b) t := ('a, 'b) t with type 'a key := 'a key\n (** @inline *)\n\n val hashable_s : ('key, _) t -> 'key Key.t\n\n include Invariant.S2 with type ('a, 'b) t := ('a, 'b) t\nend\n\nmodule type S_poly = sig\n type ('a, 'b) t [@@deriving_inline sexp]\n\n include Ppx_sexp_conv_lib.Sexpable.S2 with type ('a, 'b) t := ('a, 'b) t\n\n [@@@end]\n\n val hashable : 'a Hashable.t\n\n include Invariant.S2 with type ('a, 'b) t := ('a, 'b) t\n\n include\n Creators_generic\n with type ('a, 'b) t := ('a, 'b) t\n with type 'a key = 'a\n with type ('key, 'data, 'z) create_options :=\n ('key, 'data, 'z) create_options_without_first_class_module\n\n include Accessors with type ('a, 'b) t := ('a, 'b) t with type 'a key := 'a key\n include Multi with type ('a, 'b) t := ('a, 'b) t with type 'a key := 'a key\nend\n\nmodule type For_deriving = sig\n type ('k, 'v) t\n\n module type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end\n\n module type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Key.S with type t := t\n end\n\n val sexp_of_m__t\n : (module Sexp_of_m with type t = 'k)\n -> ('v -> Sexp.t)\n -> ('k, 'v) t\n -> Sexp.t\n\n val m__t_of_sexp\n : (module M_of_sexp with type t = 'k)\n -> (Sexp.t -> 'v)\n -> Sexp.t\n -> ('k, 'v) t\nend\n\nmodule type Hashtbl = sig\n (** A hash table is a mutable data structure implementing a map between keys and values.\n It supports constant-time lookup and in-place modification.\n\n {1 Usage}\n\n As a simple example, we'll create a hash table with string keys using the\n {{!create}[create]} constructor, which expects a module defining the key's type:\n\n {[\n let h = Hashtbl.create (module String);;\n val h : (string, '_a) Hashtbl.t = \n ]}\n\n We can set the values of individual keys with {{!set}[set]}. If the key already has\n a value, it will be overwritten.\n\n {v\n Hashtbl.set h ~key:\"foo\" ~data:5;;\n - : unit = ()\n\n Hashtbl.set h ~key:\"foo\" ~data:6;;\n - : unit = ()\n\n Hashtbl.set h ~key:\"bar\" ~data:6;;\n - : unit = ()\n v}\n\n We can access values by key, or dump all of the hash table's data:\n\n {v\n Hashtbl.find h \"foo\";;\n - : int option = Some 6\n\n Hashtbl.find_exn h \"foo\";;\n - : int = 6\n\n Hashtbl.to_alist h;;\n - : (string * int) list = [(\"foo\", 6); (\"bar\", 6)]\n v}\n\n {{!change}[change]} lets us change a key's value by applying the given function:\n\n {v\n Hashtbl.change h \"foo\" (fun x ->\n match x with\n | Some x -> Some (x * 2)\n | None -> None\n );;\n - : unit = ()\n\n Hashtbl.to_alist h;;\n - : (string * int) list = [(\"foo\", 12); (\"bar\", 6)]\n v}\n\n\n We can use {{!merge}[merge]} to merge two hashtables with fine-grained control over\n how we choose values when a key is present in the first (\"left\") hashtable, the\n second (\"right\"), or both. Here, we'll cons the values when both hashtables have a\n key:\n\n {v\n let h1 = Hashtbl.of_alist_exn (module Int) [(1, 5); (2, 3232)] in\n let h2 = Hashtbl.of_alist_exn (module Int) [(1, 3)] in\n Hashtbl.merge h1 h2 ~f:(fun ~key:_ -> function\n | `Left x -> Some (`Left x)\n | `Right x -> Some (`Right x)\n | `Both (x, y) -> if x=y then None else Some (`Both (x,y))\n ) |> Hashtbl.to_alist;;\n - : (int * [> `Both of int * int | `Left of int | `Right of int ]) list =\n [(2, `Left 3232); (1, `Both (5, 3))]\n v}\n\n {1 Interface} *)\n\n include S_without_submodules (** @inline *)\n\n module type Accessors = Accessors\n module type Creators = Creators\n module type Key = Key.S [@@deprecated \"[since 2019-03] Use [Hashtbl.Key.S]\"]\n module type Multi = Multi\n module type S_poly = S_poly\n module type S_without_submodules = S_without_submodules\n module type For_deriving = For_deriving\n\n module Key = Key\n module Merge_into_action = Merge_into_action\n\n type nonrec ('key, 'data, 'z) create_options = ('key, 'data, 'z) create_options\n\n module Creators (Key : sig\n type 'a t\n\n val hashable : 'a t Hashable.t\n end) : sig\n type ('a, 'b) t_ = ('a Key.t, 'b) t\n\n val t_of_sexp : (Sexp.t -> 'a Key.t) -> (Sexp.t -> 'b) -> Sexp.t -> ('a, 'b) t_\n\n include\n Creators_generic\n with type ('a, 'b) t := ('a, 'b) t_\n with type 'a key := 'a Key.t\n with type ('key, 'data, 'a) create_options :=\n ('key, 'data, 'a) create_options_without_first_class_module\n end\n\n module Poly : S_poly with type ('a, 'b) t = ('a, 'b) t\n\n (** [M] is meant to be used in combination with OCaml applicative functor types:\n\n {[\n type string_to_int_table = int Hashtbl.M(String).t\n ]}\n\n which stands for:\n\n {[\n type string_to_int_table = (String.t, int) Hashtbl.t\n ]}\n\n The point is that [int Hashtbl.M(String).t] supports deriving, whereas the second\n syntax doesn't (because [t_of_sexp] doesn't know what comparison/hash function to\n use). *)\n module M (K : T.T) : sig\n type nonrec 'v t = (K.t, 'v) t\n end\n\n include For_deriving with type ('a, 'b) t := ('a, 'b) t\n\n (**/**)\n\n (*_ See the Jane Street Style Guide for an explanation of [Private] submodules:\n\n https://opensource.janestreet.com/standards/#private-submodules *)\n module Private : sig\n module type Creators_generic = Creators_generic\n\n type nonrec ('key, 'data, 'z) create_options_without_first_class_module =\n ('key, 'data, 'z) create_options_without_first_class_module\n\n val hashable : ('key, _) t -> 'key Hashable.t\n end\nend\n","open! Import\n\nmodule type Key = sig\n type t [@@deriving_inline compare, sexp_of]\n\n val compare : t -> t -> int\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n (** Values returned by [hash] must be non-negative. An exception will be raised in the\n case that [hash] returns a negative value. *)\n val hash : t -> int\nend\n\nmodule Hashable = struct\n type 'a t =\n { hash : 'a -> int\n ; compare : 'a -> 'a -> int\n ; sexp_of_t : 'a -> Sexp.t\n }\n\n (** This function is sound but not complete, meaning that if it returns [true] then it's\n safe to use the two interchangeably. If it's [false], you have no guarantees. For\n example:\n\n {[\n > utop\n open Core;;\n let equal (a : 'a Hashtbl_intf.Hashable.t) b =\n phys_equal a b\n || (phys_equal a.hash b.hash\n && phys_equal a.compare b.compare\n && phys_equal a.sexp_of_t b.sexp_of_t)\n ;;\n let a = Hashtbl_intf.Hashable.{ hash; compare; sexp_of_t = Int.sexp_of_t };;\n let b = Hashtbl_intf.Hashable.{ hash; compare; sexp_of_t = Int.sexp_of_t };;\n equal a b;; (* false?! *)\n ]}\n *)\n let equal a b =\n phys_equal a b\n || (phys_equal a.hash b.hash\n && phys_equal a.compare b.compare\n && phys_equal a.sexp_of_t b.sexp_of_t)\n ;;\n\n let hash_param = Caml.Hashtbl.hash_param\n let hash = Caml.Hashtbl.hash\n let poly = { hash; compare = Poly.compare; sexp_of_t = (fun _ -> Sexp.Atom \"_\") }\n\n let of_key (type a) (module Key : Key with type t = a) =\n { hash = Key.hash; compare = Key.compare; sexp_of_t = Key.sexp_of_t }\n ;;\n\n let to_key (type a) { hash; compare; sexp_of_t } =\n (module struct\n type t = a\n\n let hash = hash\n let compare = compare\n let sexp_of_t = sexp_of_t\n end : Key\n with type t = a)\n ;;\nend\n\ninclude Hashable\n\nmodule type Hashable = sig\n type 'a t = 'a Hashable.t =\n { hash : 'a -> int\n ; compare : 'a -> 'a -> int\n ; sexp_of_t : 'a -> Sexp.t\n }\n\n val equal : 'a t -> 'a t -> bool\n val poly : 'a t\n val of_key : (module Key with type t = 'a) -> 'a t\n val to_key : 'a t -> (module Key with type t = 'a)\n val hash_param : int -> int -> 'a -> int\n val hash : 'a -> int\nend\n","(* A few small things copied from other parts of Base because they depend on us, so we\n can't use them. *)\n\nopen! Import\n\nlet raise_s = Error.raise_s\n\nmodule Int = struct\n type t = int\n\n let max (x : t) y = if x > y then x else y\nend\n\n(* Its important that Empty have no args. It's tempting to make this type a record\n (e.g. to hold the compare function), but a lot of memory is saved by Empty being an\n immediate, since all unused buckets in the hashtbl don't use any memory (besides the\n array cell) *)\ntype ('k, 'v) t =\n | Empty\n | Node of\n { mutable left : ('k, 'v) t\n ; key : 'k\n ; mutable value : 'v\n ; mutable height : int\n ; mutable right : ('k, 'v) t\n }\n | Leaf of\n { key : 'k\n ; mutable value : 'v\n }\n\nlet empty = Empty\n\nlet is_empty = function\n | Empty -> true\n | Leaf _ | Node _ -> false\n;;\n\nlet height = function\n | Empty -> 0\n | Leaf _ -> 1\n | Node { left = _; key = _; value = _; height; right = _ } -> height\n;;\n\nlet invariant compare =\n let legal_left_key key = function\n | Empty -> ()\n | Leaf { key = left_key; value = _ }\n | Node { left = _; key = left_key; value = _; height = _; right = _ } ->\n assert (compare left_key key < 0)\n in\n let legal_right_key key = function\n | Empty -> ()\n | Leaf { key = right_key; value = _ }\n | Node { left = _; key = right_key; value = _; height = _; right = _ } ->\n assert (compare right_key key > 0)\n in\n let rec inv = function\n | Empty | Leaf _ -> ()\n | Node { left; key = k; value = _; height = h; right } ->\n let hl, hr = height left, height right in\n inv left;\n inv right;\n legal_left_key k left;\n legal_right_key k right;\n assert (h = Int.max hl hr + 1);\n assert (abs (hl - hr) <= 2)\n in\n inv\n;;\n\nlet invariant t ~compare = invariant compare t\n\n(* In the following comments,\n 't is balanced' means that 'invariant t' does not\n raise an exception. This implies of course that each node's height field is\n correct.\n 't is balanceable' means that height of the left and right subtrees of t\n differ by at most 3. *)\n\n(* @pre: left and right subtrees have correct heights\n @post: output has the correct height *)\nlet update_height = function\n | Node ({ left; key = _; value = _; height = old_height; right } as x) ->\n let new_height = Int.max (height left) (height right) + 1 in\n if new_height <> old_height then x.height <- new_height\n | Empty | Leaf _ -> assert false\n;;\n\n(* @pre: left and right subtrees are balanced\n @pre: tree is balanceable\n @post: output is balanced (in particular, height is correct) *)\nlet balance tree =\n match tree with\n | Empty | Leaf _ -> tree\n | Node ({ left; key = _; value = _; height = _; right } as root_node) ->\n let hl = height left\n and hr = height right in\n (* + 2 is critically important, lowering it to 1 will break the Leaf\n assumptions in the code below, and will force us to promote leaf nodes in\n the balance routine. It's also faster, since it will balance less often.\n Note that the following code is delicate. The update_height calls must\n occur in the correct order, since update_height assumes its children have\n the correct heights. *)\n if hl > hr + 2\n then (\n match left with\n (* It cannot be a leaf, because even if right is empty, a leaf\n is only height 1 *)\n | Empty | Leaf _ -> assert false\n | Node\n ({ left = left_node_left\n ; key = _\n ; value = _\n ; height = _\n ; right = left_node_right\n } as left_node) ->\n if height left_node_left >= height left_node_right\n then (\n root_node.left <- left_node_right;\n left_node.right <- tree;\n update_height tree;\n update_height left;\n left)\n else (\n (* if right is a leaf, then left must be empty. That means\n height is 2. Even if hr is empty we still can't get here. *)\n match left_node_right with\n | Empty | Leaf _ -> assert false\n | Node\n ({ left = lr_left; key = _; value = _; height = _; right = lr_right } as\n lr_node) ->\n left_node.right <- lr_left;\n root_node.left <- lr_right;\n lr_node.right <- tree;\n lr_node.left <- left;\n update_height left;\n update_height tree;\n update_height left_node_right;\n left_node_right))\n else if hr > hl + 2\n then (\n (* see above for an explanation of why right cannot be a leaf *)\n match right with\n | Empty | Leaf _ -> assert false\n | Node\n ({ left = right_node_left\n ; key = _\n ; value = _\n ; height = _\n ; right = right_node_right\n } as right_node) ->\n if height right_node_right >= height right_node_left\n then (\n root_node.right <- right_node_left;\n right_node.left <- tree;\n update_height tree;\n update_height right;\n right)\n else (\n (* see above for an explanation of why this cannot be a leaf *)\n match right_node_left with\n | Empty | Leaf _ -> assert false\n | Node\n ({ left = rl_left; key = _; value = _; height = _; right = rl_right } as\n rl_node) ->\n right_node.left <- rl_right;\n root_node.right <- rl_left;\n rl_node.left <- tree;\n rl_node.right <- right;\n update_height right;\n update_height tree;\n update_height right_node_left;\n right_node_left))\n else (\n update_height tree;\n tree)\n;;\n\n(* @pre: tree is balanceable\n @pre: abs (height (right node) - height (balance tree)) <= 3\n @post: result is balanceable *)\n\n(* @pre: tree is balanceable\n @pre: abs (height (right node) - height (balance tree)) <= 3\n @post: result is balanceable *)\nlet set_left node tree =\n let tree = balance tree in\n match node with\n | Node ({ left; key = _; value = _; height = _; right = _ } as r) ->\n if phys_equal left tree then () else r.left <- tree;\n update_height node\n | _ -> assert false\n;;\n\n(* @pre: tree is balanceable\n @pre: abs (height (left node) - height (balance tree)) <= 3\n @post: result is balanceable *)\nlet set_right node tree =\n let tree = balance tree in\n match node with\n | Node ({ left = _; key = _; value = _; height = _; right } as r) ->\n if phys_equal right tree then () else r.right <- tree;\n update_height node\n | _ -> assert false\n;;\n\n(* @pre: t is balanced.\n @post: result is balanced, with new node inserted\n @post: !added = true iff the shape of the input tree changed. *)\nlet add =\n let rec add t replace added compare k v =\n match t with\n | Empty ->\n added := true;\n Leaf { key = k; value = v }\n | Leaf ({ key = k'; value = _ } as r) ->\n let c = compare k' k in\n (* This compare is reversed on purpose, we are pretending\n that the leaf was just inserted instead of the other way\n round, that way we only allocate one node. *)\n if c = 0\n then (\n added := false;\n if replace then r.value <- v;\n t)\n else (\n added := true;\n if c < 0\n then Node { left = t; key = k; value = v; height = 2; right = Empty }\n else Node { left = Empty; key = k; value = v; height = 2; right = t })\n | Node ({ left; key = k'; value = _; height = _; right } as r) ->\n let c = compare k k' in\n if c = 0\n then (\n added := false;\n if replace then r.value <- v)\n else if c < 0\n then set_left t (add left replace added compare k v)\n else set_right t (add right replace added compare k v);\n t\n in\n fun t ~replace ~compare ~added ~key ~data ->\n let t = add t replace added compare key data in\n if !added then balance t else t\n;;\n\nlet rec first t =\n match t with\n | Empty -> None\n | Leaf { key = k; value = v }\n | Node { left = Empty; key = k; value = v; height = _; right = _ } -> Some (k, v)\n | Node { left = l; key = _; value = _; height = _; right = _ } -> first l\n;;\n\nlet rec last t =\n match t with\n | Empty -> None\n | Leaf { key = k; value = v }\n | Node { left = _; key = k; value = v; height = _; right = Empty } -> Some (k, v)\n | Node { left = _; key = _; value = _; height = _; right = r } -> last r\n;;\n\n\nlet[@inline always] rec findi_and_call_impl\n t\n ~compare\n k\n arg1\n arg2\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n =\n match t with\n | Empty -> call_if_not_found ~if_not_found k arg1 arg2\n | Leaf { key = k'; value = v } ->\n if compare k k' = 0\n then call_if_found ~if_found ~key:k' ~data:v arg1 arg2\n else call_if_not_found ~if_not_found k arg1 arg2\n | Node { left; key = k'; value = v; height = _; right } ->\n let c = compare k k' in\n if c = 0\n then call_if_found ~if_found ~key:k' ~data:v arg1 arg2\n else\n findi_and_call_impl\n (if c < 0 then left else right)\n ~compare\n k\n arg1\n arg2\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet find_and_call =\n let call_if_found ~if_found ~key:_ ~data () () = if_found data in\n let call_if_not_found ~if_not_found key () () = if_not_found key in\n fun t ~compare k ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n ()\n ()\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet findi_and_call =\n let call_if_found ~if_found ~key ~data () () = if_found ~key ~data in\n let call_if_not_found ~if_not_found key () () = if_not_found key in\n fun t ~compare k ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n ()\n ()\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet find_and_call1 =\n let call_if_found ~if_found ~key:_ ~data arg () = if_found data arg in\n let call_if_not_found ~if_not_found key arg () = if_not_found key arg in\n fun t ~compare k ~a ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n a\n ()\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet findi_and_call1 =\n let call_if_found ~if_found ~key ~data arg () = if_found ~key ~data arg in\n let call_if_not_found ~if_not_found key arg () = if_not_found key arg in\n fun t ~compare k ~a ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n a\n ()\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet find_and_call2 =\n let call_if_found ~if_found ~key:_ ~data arg1 arg2 = if_found data arg1 arg2 in\n let call_if_not_found ~if_not_found key arg1 arg2 = if_not_found key arg1 arg2 in\n fun t ~compare k ~a ~b ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n a\n b\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet findi_and_call2 =\n let call_if_found ~if_found ~key ~data arg1 arg2 = if_found ~key ~data arg1 arg2 in\n let call_if_not_found ~if_not_found key arg1 arg2 = if_not_found key arg1 arg2 in\n fun t ~compare k ~a ~b ~if_found ~if_not_found ->\n findi_and_call_impl\n t\n ~compare\n k\n a\n b\n ~call_if_found\n ~call_if_not_found\n ~if_found\n ~if_not_found\n;;\n\nlet find =\n let if_found v = Some v in\n let if_not_found _ = None in\n fun t ~compare k -> find_and_call t ~compare k ~if_found ~if_not_found\n;;\n\nlet mem =\n let if_found _ = true in\n let if_not_found _ = false in\n fun t ~compare k -> find_and_call t ~compare k ~if_found ~if_not_found\n;;\n\nlet remove =\n let rec min_elt tree =\n match tree with\n | Empty -> Empty\n | Leaf _ -> tree\n | Node { left = Empty; key = _; value = _; height = _; right = _ } -> tree\n | Node { left; key = _; value = _; height = _; right = _ } -> min_elt left\n in\n let rec remove_min_elt tree =\n match tree with\n | Empty -> assert false\n | Leaf _ -> Empty (* This must be the root *)\n | Node { left = Empty; key = _; value = _; height = _; right } -> right\n | Node { left = Leaf _; key = k; value = v; height = _; right = Empty } ->\n Leaf { key = k; value = v }\n | Node { left = Leaf _; key = _; value = _; height = _; right = _ } as node ->\n set_left node Empty;\n tree\n | Node { left; key = _; value = _; height = _; right = _ } as node ->\n set_left node (remove_min_elt left);\n tree\n in\n let merge t1 t2 =\n match t1, t2 with\n | Empty, t -> t\n | t, Empty -> t\n | _, _ ->\n let tree = min_elt t2 in\n (match tree with\n | Empty -> assert false\n | Leaf { key = k; value = v } ->\n let t2 = balance (remove_min_elt t2) in\n Node\n { left = t1\n ; key = k\n ; value = v\n ; height = Int.max (height t1) (height t2) + 1\n ; right = t2\n }\n | Node _ as node ->\n set_right node (remove_min_elt t2);\n set_left node t1;\n node)\n in\n let rec remove t removed compare k =\n match t with\n | Empty ->\n removed := false;\n Empty\n | Leaf { key = k'; value = _ } ->\n if compare k k' = 0\n then (\n removed := true;\n Empty)\n else (\n removed := false;\n t)\n | Node { left; key = k'; value = _; height = _; right } ->\n let c = compare k k' in\n if c = 0\n then (\n removed := true;\n merge left right)\n else if c < 0\n then (\n set_left t (remove left removed compare k);\n t)\n else (\n set_right t (remove right removed compare k);\n t)\n in\n fun t ~removed ~compare k -> balance (remove t removed compare k)\n;;\n\nlet rec fold t ~init ~f =\n match t with\n | Empty -> init\n | Leaf { key; value = data } -> f ~key ~data init\n | Node\n { left = Leaf { key = lkey; value = ldata }\n ; key\n ; value = data\n ; height = _\n ; right = Leaf { key = rkey; value = rdata }\n } -> f ~key:rkey ~data:rdata (f ~key ~data (f ~key:lkey ~data:ldata init))\n | Node\n { left = Leaf { key = lkey; value = ldata }\n ; key\n ; value = data\n ; height = _\n ; right = Empty\n } -> f ~key ~data (f ~key:lkey ~data:ldata init)\n | Node\n { left = Empty\n ; key\n ; value = data\n ; height = _\n ; right = Leaf { key = rkey; value = rdata }\n } -> f ~key:rkey ~data:rdata (f ~key ~data init)\n | Node\n { left; key; value = data; height = _; right = Leaf { key = rkey; value = rdata } }\n -> f ~key:rkey ~data:rdata (f ~key ~data (fold left ~init ~f))\n | Node\n { left = Leaf { key = lkey; value = ldata }; key; value = data; height = _; right }\n -> fold right ~init:(f ~key ~data (f ~key:lkey ~data:ldata init)) ~f\n | Node { left; key; value = data; height = _; right } ->\n fold right ~init:(f ~key ~data (fold left ~init ~f)) ~f\n;;\n\nlet rec iter t ~f =\n match t with\n | Empty -> ()\n | Leaf { key; value = data } -> f ~key ~data\n | Node { left; key; value = data; height = _; right } ->\n iter left ~f;\n f ~key ~data;\n iter right ~f\n;;\n\nlet rec mapi_inplace t ~f =\n match t with\n | Empty -> ()\n | Leaf ({ key; value } as t) -> t.value <- f ~key ~data:value\n | Node ({ left; key; value; height = _; right } as t) ->\n mapi_inplace ~f left;\n t.value <- f ~key ~data:value;\n mapi_inplace ~f right\n;;\n\nlet choose_exn = function\n | Empty -> raise_s (Sexp.message \"[Avltree.choose_exn] of empty hashtbl\" [])\n | Leaf { key; value; _ } | Node { key; value; _ } -> key, value\n;;\n","open! Import\nmodule Key = Hashtbl_intf.Key\n\nmodule type Accessors = sig\n include Container.Generic\n\n (** override [Container.Generic.mem] *)\n val mem : 'a t -> 'a -> bool\n\n (** preserves the equality function *)\n val copy : 'a t -> 'a t\n\n val add : 'a t -> 'a -> unit\n\n (** [strict_add t x] returns [Ok ()] if the [x] was not in [t], or an [Error] if it\n was. *)\n val strict_add : 'a t -> 'a -> unit Or_error.t\n\n val strict_add_exn : 'a t -> 'a -> unit\n val remove : 'a t -> 'a -> unit\n\n (** [strict_remove t x] returns [Ok ()] if the [x] was in [t], or an [Error] if it\n was not. *)\n val strict_remove : 'a t -> 'a -> unit Or_error.t\n\n val strict_remove_exn : 'a t -> 'a -> unit\n val clear : 'a t -> unit\n val equal : 'a t -> 'a t -> bool\n val filter : 'a t -> f:('a -> bool) -> 'a t\n val filter_inplace : 'a t -> f:('a -> bool) -> unit\n\n (** [inter t1 t2] computes the set intersection of [t1] and [t2]. Runs in O(min(length\n t1, length t2)). Behavior is undefined if [t1] and [t2] don't have the same\n equality function. *)\n val inter : 'key t -> 'key t -> 'key t\n\n val union : 'a t -> 'a t -> 'a t\n val diff : 'a t -> 'a t -> 'a t\n val of_hashtbl_keys : ('a, _) Hashtbl.t -> 'a t\n val to_hashtbl : 'key t -> f:('key -> 'data) -> ('key, 'data) Hashtbl.t\nend\n\ntype ('key, 'z) create_options = ('key, unit, 'z) Hashtbl_intf.create_options\n\ntype ('key, 'z) create_options_without_first_class_module =\n ('key, unit, 'z) Hashtbl_intf.create_options_without_first_class_module\n\nmodule type Creators = sig\n type 'a t\n\n val create\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> 'a t\n\n val of_list\n : ?growth_allowed:bool (** defaults to [true] *)\n -> ?size:int (** initial size -- default 0 *)\n -> 'a Key.t\n -> 'a list\n -> 'a t\nend\n\nmodule type Creators_generic = sig\n type 'a t\n type 'a elt\n type ('a, 'z) create_options\n\n val create : ('a, unit -> 'a t) create_options\n val of_list : ('a, 'a elt list -> 'a t) create_options\nend\n\nmodule Check = struct\n module Make_creators_check\n (Type : T.T1)\n (Elt : T.T1)\n (Options : T.T2)\n (M : Creators_generic\n with type 'a t := 'a Type.t\n with type 'a elt := 'a Elt.t\n with type ('a, 'z) create_options := ('a, 'z) Options.t) =\n struct end\n\n module Check_creators_is_specialization_of_creators_generic (M : Creators) =\n Make_creators_check\n (struct\n type 'a t = 'a M.t\n end)\n (struct\n type 'a t = 'a\n end)\n (struct\n type ('a, 'z) t = ('a, 'z) create_options\n end)\n (struct\n include M\n\n let create ?growth_allowed ?size m () = create ?growth_allowed ?size m\n end)\nend\n\nmodule type Hash_set = sig\n type 'a t [@@deriving_inline sexp_of]\n\n val sexp_of_t : ('a -> Ppx_sexp_conv_lib.Sexp.t) -> 'a t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n\n (** We use [[@@deriving sexp_of]] but not [[@@deriving sexp]] because we want people to be\n explicit about the hash and comparison functions used when creating hashtables. One\n can use [Hash_set.Poly.t], which does have [[@@deriving sexp]], to use polymorphic\n comparison and hashing. *)\n\n module Key = Key\n\n module type Creators = Creators\n module type Creators_generic = Creators_generic\n\n type nonrec ('key, 'z) create_options = ('key, 'z) create_options\n\n include Creators with type 'a t := 'a t (** @open *)\n\n module type Accessors = Accessors\n\n include Accessors with type 'a t := 'a t with type 'a elt = 'a (** @open *)\n\n val hashable_s : 'key t -> 'key Key.t\n\n type nonrec ('key, 'z) create_options_without_first_class_module =\n ('key, 'z) create_options_without_first_class_module\n\n (** A hash set that uses polymorphic comparison *)\n module Poly : sig\n type nonrec 'a t = 'a t [@@deriving_inline sexp]\n\n include Ppx_sexp_conv_lib.Sexpable.S1 with type 'a t := 'a t\n\n [@@@end]\n\n include\n Creators_generic\n with type 'a t := 'a t\n with type 'a elt = 'a\n with type ('key, 'z) create_options :=\n ('key, 'z) create_options_without_first_class_module\n\n include Accessors with type 'a t := 'a t with type 'a elt := 'a elt\n end\n\n (** [M] is meant to be used in combination with OCaml applicative functor types:\n\n {[\n type string_hash_set = Hash_set.M(String).t\n ]}\n\n which stands for:\n\n {[\n type string_hash_set = (String.t, int) Hash_set.t\n ]}\n\n The point is that [Hash_set.M(String).t] supports deriving, whereas the second\n syntax doesn't (because [t_of_sexp] doesn't know what comparison/hash function to\n use). *)\n module M (Elt : T.T) : sig\n type nonrec t = Elt.t t\n end\n\n module type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\n end\n\n module type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Hashtbl_intf.Key.S with type t := t\n end\n\n val sexp_of_m__t : (module Sexp_of_m with type t = 'elt) -> 'elt t -> Sexp.t\n val m__t_of_sexp : (module M_of_sexp with type t = 'elt) -> Sexp.t -> 'elt t\n\n module Creators (Elt : sig\n type 'a t\n\n val hashable : 'a t Hashable.t\n end) : sig\n type 'a t_ = 'a Elt.t t\n\n val t_of_sexp : (Sexp.t -> 'a Elt.t) -> Sexp.t -> 'a t_\n\n include\n Creators_generic\n with type 'a t := 'a t_\n with type 'a elt := 'a Elt.t\n with type ('elt, 'z) create_options :=\n ('elt, 'z) create_options_without_first_class_module\n end\n\n (**/**)\n\n (*_ See the Jane Street Style Guide for an explanation of [Private] submodules:\n\n https://opensource.janestreet.com/standards/#private-submodules *)\n module Private : sig\n val hashable : 'a t -> 'a Hashable.t\n end\nend\n","open! Import\ninclude Hash_set_intf\n\nlet hashable_s = Hashtbl.hashable_s\nlet hashable = Hashtbl.Private.hashable\nlet poly_hashable = Hashtbl.Poly.hashable\nlet with_return = With_return.with_return\n\ntype 'a t = ('a, unit) Hashtbl.t\ntype 'a hash_set = 'a t\ntype 'a elt = 'a\n\nmodule Accessors = struct\n let hashable = hashable\n let clear = Hashtbl.clear\n let length = Hashtbl.length\n let mem = Hashtbl.mem\n let is_empty t = Hashtbl.is_empty t\n\n let find_map t ~f =\n with_return (fun r ->\n Hashtbl.iter_keys t ~f:(fun elt ->\n match f elt with\n | None -> ()\n | Some _ as o -> r.return o);\n None)\n ;;\n\n let find t ~f = find_map t ~f:(fun a -> if f a then Some a else None)\n let add t k = Hashtbl.set t ~key:k ~data:()\n\n let strict_add t k =\n if mem t k\n then Or_error.error_string \"element already exists\"\n else (\n Hashtbl.set t ~key:k ~data:();\n Result.Ok ())\n ;;\n\n let strict_add_exn t k = Or_error.ok_exn (strict_add t k)\n let remove = Hashtbl.remove\n\n let strict_remove t k =\n if mem t k\n then (\n remove t k;\n Result.Ok ())\n else Or_error.error \"element not in set\" k (Hashtbl.sexp_of_key t)\n ;;\n\n let strict_remove_exn t k = Or_error.ok_exn (strict_remove t k)\n let fold t ~init ~f = Hashtbl.fold t ~init ~f:(fun ~key ~data:() acc -> f acc key)\n let iter t ~f = Hashtbl.iter_keys t ~f\n let count t ~f = Container.count ~fold t ~f\n let sum m t ~f = Container.sum ~fold m t ~f\n let min_elt t ~compare = Container.min_elt ~fold t ~compare\n let max_elt t ~compare = Container.max_elt ~fold t ~compare\n let fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\n let fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\n let to_list = Hashtbl.keys\n\n let sexp_of_t sexp_of_e t =\n sexp_of_list sexp_of_e (to_list t |> List.sort ~compare:(hashable t).compare)\n ;;\n\n let to_array t =\n let len = length t in\n let index = ref (len - 1) in\n fold t ~init:[||] ~f:(fun acc key ->\n if Array.length acc = 0\n then Array.create ~len key\n else (\n index := !index - 1;\n acc.(!index) <- key;\n acc))\n ;;\n\n let exists t ~f = Hashtbl.existsi t ~f:(fun ~key ~data:() -> f key)\n let for_all t ~f = not (Hashtbl.existsi t ~f:(fun ~key ~data:() -> not (f key)))\n let equal t1 t2 = Hashtbl.equal (fun () () -> true) t1 t2\n let copy t = Hashtbl.copy t\n let filter t ~f = Hashtbl.filteri t ~f:(fun ~key ~data:() -> f key)\n let union t1 t2 = Hashtbl.merge t1 t2 ~f:(fun ~key:_ _ -> Some ())\n let diff t1 t2 = filter t1 ~f:(fun key -> not (Hashtbl.mem t2 key))\n\n let inter t1 t2 =\n let smaller, larger = if length t1 > length t2 then t2, t1 else t1, t2 in\n Hashtbl.filteri smaller ~f:(fun ~key ~data:() -> Hashtbl.mem larger key)\n ;;\n\n let filter_inplace t ~f =\n let to_remove = fold t ~init:[] ~f:(fun ac x -> if f x then ac else x :: ac) in\n List.iter to_remove ~f:(fun x -> remove t x)\n ;;\n\n let of_hashtbl_keys hashtbl = Hashtbl.map hashtbl ~f:ignore\n let to_hashtbl t ~f = Hashtbl.mapi t ~f:(fun ~key ~data:() -> f key)\nend\n\ninclude Accessors\n\nlet create ?growth_allowed ?size m = Hashtbl.create ?growth_allowed ?size m\n\nlet of_list ?growth_allowed ?size m l =\n let size =\n match size with\n | Some x -> x\n | None -> List.length l\n in\n let t = Hashtbl.create ?growth_allowed ~size m in\n List.iter l ~f:(fun k -> add t k);\n t\n;;\n\nlet t_of_sexp m e_of_sexp sexp =\n match sexp with\n | Sexp.Atom _ -> of_sexp_error \"Hash_set.t_of_sexp requires a list\" sexp\n | Sexp.List list ->\n let t = create m ~size:(List.length list) in\n List.iter list ~f:(fun sexp ->\n let e = e_of_sexp sexp in\n match strict_add t e with\n | Ok () -> ()\n | Error _ -> of_sexp_error \"Hash_set.t_of_sexp got a duplicate element\" sexp);\n t\n;;\n\nmodule Creators (Elt : sig\n type 'a t\n\n val hashable : 'a t Hashable.t\n end) : sig\n type 'a t_ = 'a Elt.t t\n\n val t_of_sexp : (Sexp.t -> 'a Elt.t) -> Sexp.t -> 'a t_\n\n include\n Creators_generic\n with type 'a t := 'a t_\n with type 'a elt := 'a Elt.t\n with type ('elt, 'z) create_options :=\n ('elt, 'z) create_options_without_first_class_module\nend = struct\n type 'a t_ = 'a Elt.t t\n\n let create ?growth_allowed ?size () =\n create ?growth_allowed ?size (Hashable.to_key Elt.hashable)\n ;;\n\n let of_list ?growth_allowed ?size l =\n of_list ?growth_allowed ?size (Hashable.to_key Elt.hashable) l\n ;;\n\n let t_of_sexp e_of_sexp sexp = t_of_sexp (Hashable.to_key Elt.hashable) e_of_sexp sexp\nend\n\nmodule Poly = struct\n type 'a t = 'a hash_set\n type 'a elt = 'a\n\n let hashable = poly_hashable\n\n include Creators (struct\n type 'a t = 'a\n\n let hashable = hashable\n end)\n\n include Accessors\n\n let sexp_of_t = sexp_of_t\nend\n\nmodule M (Elt : T.T) = struct\n type nonrec t = Elt.t t\nend\n\nmodule type Sexp_of_m = sig\n type t [@@deriving_inline sexp_of]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n [@@@end]\nend\n\nmodule type M_of_sexp = sig\n type t [@@deriving_inline of_sexp]\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n [@@@end]\n\n include Hashtbl_intf.Key.S with type t := t\nend\n\nlet sexp_of_m__t (type elt) (module Elt : Sexp_of_m with type t = elt) t =\n sexp_of_t Elt.sexp_of_t t\n;;\n\nlet m__t_of_sexp (type elt) (module Elt : M_of_sexp with type t = elt) sexp =\n t_of_sexp (module Elt) Elt.t_of_sexp sexp\n;;\n\nmodule Private = struct\n let hashable = Hashtbl.Private.hashable\nend\n","open! Import\nopen! Printf\nmodule Bytes = Bytes0\ninclude Float0\n\nlet raise_s = Error.raise_s\n\nmodule T = struct\n type t = float [@@deriving_inline hash, sexp, sexp_grammar]\n\n let (hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state) =\n hash_fold_float\n\n and (hash : t -> Ppx_hash_lib.Std.Hash.hash_value) =\n let func = hash_float in\n fun x -> func x\n ;;\n\n let t_of_sexp = (float_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t)\n let sexp_of_t = (sexp_of_float : t -> Ppx_sexp_conv_lib.Sexp.t)\n\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n let (_the_generic_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.generic_group) =\n { implicit_vars = [ \"float\" ]\n ; ggid = \"\\146e\\023\\249\\235eE\\139c\\132W\\195\\137\\129\\235\\025\"\n ; types = [ \"t\", Implicit_var 0 ]\n }\n in\n let (_the_group : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.group) =\n { gid = Ppx_sexp_conv_lib.Lazy_group_id.create ()\n ; apply_implicit = [ float_sexp_grammar ]\n ; generic_group = _the_generic_group\n ; origin = \"float.ml.T\"\n }\n in\n let (t_sexp_grammar : Ppx_sexp_conv_lib.Sexp.Private.Raw_grammar.t) =\n Ref (\"t\", _the_group)\n in\n t_sexp_grammar\n ;;\n\n [@@@end]\n\n let compare = Float_replace_polymorphic_compare.compare\nend\n\ninclude T\ninclude Comparator.Make (T)\n\n(* Open replace_polymorphic_compare after including functor instantiations so they do not\n shadow its definitions. This is here so that efficient versions of the comparison\n functions are available within this module. *)\nopen Float_replace_polymorphic_compare\n\nlet invariant (_ : t) = ()\nlet to_float x = x\nlet of_float x = x\n\nlet of_string s =\n try float_of_string s with\n | _ -> invalid_argf \"Float.of_string %s\" s ()\n;;\n\nexternal format_float : string -> float -> string = \"caml_format_float\"\n\n(* Stolen from [pervasives.ml]. Adds a \".\" at the end if needed. It is in\n [pervasives.mli], but it also says not to use it directly, so we copy and paste the\n code. It makes the assumption on the string passed in argument that it was returned by\n [format_float]. *)\nlet valid_float_lexem s =\n let l = String.length s in\n let rec loop i =\n if Int_replace_polymorphic_compare.( >= ) i l\n then s ^ \".\"\n else (\n match s.[i] with\n | '0' .. '9' | '-' -> loop (i + 1)\n | _ -> s)\n in\n loop 0\n;;\n\n(* Let [y] be a power of 2. Then the next representable float is:\n [z = y * (1 + 2 ** -52)]\n and the previous one is\n [x = y * (1 - 2 ** -53)]\n\n In general, every two adjacent floats are within a factor of between [1 + 2**-53]\n and [1 + 2**-52] from each other, that is within [1 + 1.1e-16] and [1 + 2.3e-16].\n\n So if the decimal representation of a float starts with \"1\", then its adjacent floats\n will usually differ from it by 1, and sometimes by 2, at the 17th significant digit\n (counting from 1).\n\n On the other hand, if the decimal representation starts with \"9\", then the adjacent\n floats will be off by no more than 23 at the 16th and 17th significant digits.\n\n E.g.:\n\n {v\n # sprintf \"%.17g\" (1024. *. (1. -. 2.** (-53.)));;\n 11111111\n 1234 5678901234567\n - : string = \"1023.9999999999999\"\n v}\n Printing a couple of extra digits reveals that the difference indeed is roughly 11 at\n digits 17th and 18th (that is, 13th and 14th after \".\"):\n\n {v\n # sprintf \"%.19g\" (1024. *. (1. -. 2.** (-53.)));;\n 1111111111\n 1234 567890123456789\n - : string = \"1023.999999999999886\"\n v}\n\n The ulp (the difference between adjacent floats) is twice as big on the other side of\n 1024.:\n\n {v\n # sprintf \"%.19g\" (1024. *. (1. +. 2.** (-52.)));;\n 1111111111\n 1234 567890123456789\n - : string = \"1024.000000000000227\"\n v}\n\n Now take a power of 2 which starts with 99:\n\n {v\n # 2.**93. ;;\n 1111111111\n 1 23456789012345678\n - : float = 9.9035203142830422e+27\n\n # 2.**93. *. (1. +. 2.** (-52.));;\n - : float = 9.9035203142830444e+27\n\n # 2.**93. *. (1. -. 2.** (-53.));;\n - : float = 9.9035203142830411e+27\n v}\n\n The difference between 2**93 and its two neighbors is slightly more than, respectively,\n 1 and 2 at significant digit 16.\n\n Those examples show that:\n - 17 significant digits is always sufficient to represent a float without ambiguity\n - 15th significant digit can always be represented accurately\n - converting a decimal number with 16 significant digits to its nearest float and back\n can change the last decimal digit by no more than 1\n\n To make sure that floats obtained by conversion from decimal fractions (e.g. \"3.14\")\n are printed without trailing non-zero digits, one should choose the first among the\n '%.15g', '%.16g', and '%.17g' representations which does round-trip:\n\n {v\n # sprintf \"%.15g\" 3.14;;\n - : string = \"3.14\" (* pick this one *)\n # sprintf \"%.16g\" 3.14;;\n - : string = \"3.14\"\n # sprintf \"%.17g\" 3.14;;\n - : string = \"3.1400000000000001\" (* do not pick this one *)\n\n # sprintf \"%.15g\" 8.000000000000002;;\n - : string = \"8\" (* do not pick this one--does not round-trip *)\n # sprintf \"%.16g\" 8.000000000000002;;\n - : string = \"8.000000000000002\" (* prefer this one *)\n # sprintf \"%.17g\" 8.000000000000002;;\n - : string = \"8.0000000000000018\" (* this one has one digit of junk at the end *)\n v}\n\n Skipping the '%.16g' in the above procedure saves us some time, but it means that, as\n seen in the second example above, occasionally numbers with exactly 16 significant\n digits will have an error introduced at the 17th digit. That is probably OK for\n typical use, because a number with 16 significant digits is \"ugly\" already. Adding one\n more doesn't make it much worse for a human reader.\n\n On the other hand, we cannot skip '%.15g' and only look at '%.16g' and '%.17g', since\n the inaccuracy at the 16th digit might introduce the noise we want to avoid:\n\n {v\n # sprintf \"%.15g\" 9.992;;\n - : string = \"9.992\" (* pick this one *)\n # sprintf \"%.16g\" 9.992;;\n - : string = \"9.992000000000001\" (* do not pick this one--junk at the end *)\n # sprintf \"%.17g\" 9.992;;\n - : string = \"9.9920000000000009\"\n v}\n*)\nlet to_string x =\n valid_float_lexem\n (let y = format_float \"%.15g\" x in\n if float_of_string y = x then y else format_float \"%.17g\" x)\n;;\n\nlet max_value = infinity\nlet min_value = neg_infinity\nlet min_positive_subnormal_value = 2. ** -1074.\nlet min_positive_normal_value = 2. ** -1022.\nlet zero = 0.\nlet one = 1.\nlet minus_one = -1.\nlet pi = 0x3.243F6A8885A308D313198A2E037073\nlet sqrt_pi = 0x1.C5BF891B4EF6AA79C3B0520D5DB938\nlet sqrt_2pi = 0x2.81B263FEC4E0B2CAF9483F5CE459DC\nlet euler = 0x0.93C467E37DB0C7A4D1BE3F810152CB\nlet of_int = Int.to_float\nlet to_int = Int.of_float\nlet of_int63 i = Int63.to_float i\nlet of_int64 i = Caml.Int64.to_float i\nlet to_int64 = Caml.Int64.of_float\nlet iround_lbound = lower_bound_for_int Int.num_bits\nlet iround_ubound = upper_bound_for_int Int.num_bits\n\n(* The performance of the \"exn\" rounding functions is important, so they are written\n out separately, and tuned individually. (We could have the option versions call\n the \"exn\" versions, but that imposes arguably gratuitous overhead---especially\n in the case where the capture of backtraces is enabled upon \"with\"---and that seems\n not worth it when compared to the relatively small amount of code duplication.) *)\n\n(* Error reporting below is very carefully arranged so that, e.g., [iround_nearest_exn]\n itself can be inlined into callers such that they don't need to allocate a box for the\n [float] argument. This is done with a box [box] function carefully chosen to allow the\n compiler to create a separate box for the float only in error cases. See, e.g.,\n [../../zero/test/price_test.ml] for a mechanical test of this property when building\n with [X_LIBRARY_INLINING=true]. *)\n\nlet iround_up t =\n if t > 0.0\n then (\n let t' = ceil t in\n if t' <= iround_ubound then Some (Int.of_float_unchecked t') else None)\n else if t >= iround_lbound\n then Some (Int.of_float_unchecked t)\n else None\n;;\n\nlet[@ocaml.inline always] iround_up_exn t =\n if t > 0.0\n then (\n let t' = ceil t in\n if t' <= iround_ubound\n then Int.of_float_unchecked t'\n else invalid_argf \"Float.iround_up_exn: argument (%f) is too large\" (box t) ())\n else if t >= iround_lbound\n then Int.of_float_unchecked t\n else invalid_argf \"Float.iround_up_exn: argument (%f) is too small or NaN\" (box t) ()\n;;\n\nlet iround_down t =\n if t >= 0.0\n then if t <= iround_ubound then Some (Int.of_float_unchecked t) else None\n else (\n let t' = floor t in\n if t' >= iround_lbound then Some (Int.of_float_unchecked t') else None)\n;;\n\nlet[@ocaml.inline always] iround_down_exn t =\n if t >= 0.0\n then\n if t <= iround_ubound\n then Int.of_float_unchecked t\n else invalid_argf \"Float.iround_down_exn: argument (%f) is too large\" (box t) ()\n else (\n let t' = floor t in\n if t' >= iround_lbound\n then Int.of_float_unchecked t'\n else\n invalid_argf \"Float.iround_down_exn: argument (%f) is too small or NaN\" (box t) ())\n;;\n\nlet iround_towards_zero t =\n if t >= iround_lbound && t <= iround_ubound\n then Some (Int.of_float_unchecked t)\n else None\n;;\n\nlet[@ocaml.inline always] iround_towards_zero_exn t =\n if t >= iround_lbound && t <= iround_ubound\n then Int.of_float_unchecked t\n else\n invalid_argf\n \"Float.iround_towards_zero_exn: argument (%f) is out of range or NaN\"\n (box t)\n ()\n;;\n\n(* Outside of the range (round_nearest_lb..round_nearest_ub), all representable doubles\n are integers in the mathematical sense, and [round_nearest] should be identity.\n\n However, for odd numbers with the absolute value between 2**52 and 2**53, the formula\n [round_nearest x = floor (x + 0.5)] does not hold:\n\n {v\n # let naive_round_nearest x = floor (x +. 0.5);;\n # let x = 2. ** 52. +. 1.;;\n val x : float = 4503599627370497.\n # naive_round_nearest x;;\n - : float = 4503599627370498.\n v}\n*)\n\nlet round_nearest_lb = -.(2. ** 52.)\nlet round_nearest_ub = 2. ** 52.\n\n(* For [x = one_ulp `Down 0.5], the formula [floor (x +. 0.5)] for rounding to nearest\n does not work, because the exact result is halfway between [one_ulp `Down 1.] and [1.],\n and it gets rounded up to [1.] due to the round-ties-to-even rule. *)\nlet one_ulp_less_than_half = one_ulp `Down 0.5\n\nlet add_half_for_round_nearest t =\n t\n +.\n if t = one_ulp_less_than_half\n then one_ulp_less_than_half (* since t < 0.5, make sure the result is < 1.0 *)\n else 0.5\n;;\n\nlet iround_nearest_32 t =\n if t >= 0.\n then (\n let t' = add_half_for_round_nearest t in\n if t' <= iround_ubound then Some (Int.of_float_unchecked t') else None)\n else (\n let t' = floor (t +. 0.5) in\n if t' >= iround_lbound then Some (Int.of_float_unchecked t') else None)\n;;\n\nlet iround_nearest_64 t =\n if t >= 0.\n then\n if t < round_nearest_ub\n then Some (Int.of_float_unchecked (add_half_for_round_nearest t))\n else if t <= iround_ubound\n then Some (Int.of_float_unchecked t)\n else None\n else if t > round_nearest_lb\n then Some (Int.of_float_unchecked (floor (t +. 0.5)))\n else if t >= iround_lbound\n then Some (Int.of_float_unchecked t)\n else None\n;;\n\nlet iround_nearest =\n match Word_size.word_size with\n | W64 -> iround_nearest_64\n | W32 -> iround_nearest_32\n;;\n\nlet iround_nearest_exn_32 t =\n if t >= 0.\n then (\n let t' = add_half_for_round_nearest t in\n if t' <= iround_ubound\n then Int.of_float_unchecked t'\n else invalid_argf \"Float.iround_nearest_exn: argument (%f) is too large\" (box t) ())\n else (\n let t' = floor (t +. 0.5) in\n if t' >= iround_lbound\n then Int.of_float_unchecked t'\n else invalid_argf \"Float.iround_nearest_exn: argument (%f) is too small\" (box t) ())\n;;\n\nlet[@ocaml.inline always] iround_nearest_exn_64 t =\n if t >= 0.\n then\n if t < round_nearest_ub\n then Int.of_float_unchecked (add_half_for_round_nearest t)\n else if t <= iround_ubound\n then Int.of_float_unchecked t\n else invalid_argf \"Float.iround_nearest_exn: argument (%f) is too large\" (box t) ()\n else if t > round_nearest_lb\n then Int.of_float_unchecked (floor (t +. 0.5))\n else if t >= iround_lbound\n then Int.of_float_unchecked t\n else\n invalid_argf \"Float.iround_nearest_exn: argument (%f) is too small or NaN\" (box t) ()\n;;\n\nlet iround_nearest_exn =\n match Word_size.word_size with\n | W64 -> iround_nearest_exn_64\n | W32 -> iround_nearest_exn_32\n;;\n\n(* The following [iround_exn] and [iround] functions are slower than the ones above.\n Their equivalence to those functions is tested in the unit tests below. *)\n\nlet[@inline] iround_exn ?(dir = `Nearest) t =\n match dir with\n | `Zero -> iround_towards_zero_exn t\n | `Nearest -> iround_nearest_exn t\n | `Up -> iround_up_exn t\n | `Down -> iround_down_exn t\n;;\n\nlet iround ?(dir = `Nearest) t =\n try Some (iround_exn ~dir t) with\n | _ -> None\n;;\n\nlet is_inf x =\n match classify_float x with\n | FP_infinite -> true\n | _ -> false\n;;\n\nlet min_inan (x : t) y =\n if is_nan y then x else if is_nan x then y else if x < y then x else y\n;;\n\nlet max_inan (x : t) y =\n if is_nan y then x else if is_nan x then y else if x > y then x else y\n;;\n\nlet add = ( +. )\nlet sub = ( -. )\nlet neg = ( ~-. )\nlet abs = abs_float\nlet scale = ( *. )\nlet square x = x *. x\n\nmodule Parts : sig\n type t\n\n val fractional : t -> float\n val integral : t -> float\n val modf : float -> t\nend = struct\n type t = float * float\n\n let fractional t = fst t\n let integral t = snd t\n let modf = modf\nend\n\nlet modf = Parts.modf\nlet round_down = floor\nlet round_up = ceil\nlet round_towards_zero t = if t >= 0. then round_down t else round_up t\n\n(* see the comment above [round_nearest_lb] and [round_nearest_ub] for an explanation *)\nlet round_nearest t =\n if t > round_nearest_lb && t < round_nearest_ub\n then floor (add_half_for_round_nearest t)\n else t +. 0.\n;;\n\nlet round_nearest_half_to_even t =\n if t <= round_nearest_lb || t >= round_nearest_ub\n then t +. 0.\n else (\n let floor = floor t in\n (* [ceil_or_succ = if t is an integer then t +. 1. else ceil t]. Faster than [ceil]. *)\n let ceil_or_succ = floor +. 1. in\n let diff_floor = t -. floor in\n let diff_ceil = ceil_or_succ -. t in\n if diff_floor < diff_ceil\n then floor\n else if diff_floor > diff_ceil\n then ceil_or_succ\n else if (* exact tie, pick the even *)\n mod_float floor 2. = 0.\n then floor\n else ceil_or_succ)\n;;\n\nlet int63_round_lbound = lower_bound_for_int Int63.num_bits\nlet int63_round_ubound = upper_bound_for_int Int63.num_bits\n\nlet int63_round_up_exn t =\n if t > 0.0\n then (\n let t' = ceil t in\n if t' <= int63_round_ubound\n then Int63.of_float_unchecked t'\n else\n invalid_argf\n \"Float.int63_round_up_exn: argument (%f) is too large\"\n (Float0.box t)\n ())\n else if t >= int63_round_lbound\n then Int63.of_float_unchecked t\n else\n invalid_argf\n \"Float.int63_round_up_exn: argument (%f) is too small or NaN\"\n (Float0.box t)\n ()\n;;\n\nlet int63_round_down_exn t =\n if t >= 0.0\n then\n if t <= int63_round_ubound\n then Int63.of_float_unchecked t\n else\n invalid_argf\n \"Float.int63_round_down_exn: argument (%f) is too large\"\n (Float0.box t)\n ()\n else (\n let t' = floor t in\n if t' >= int63_round_lbound\n then Int63.of_float_unchecked t'\n else\n invalid_argf\n \"Float.int63_round_down_exn: argument (%f) is too small or NaN\"\n (Float0.box t)\n ())\n;;\n\nlet int63_round_nearest_portable_alloc_exn t0 =\n let t = round_nearest t0 in\n if t > 0.\n then\n if t <= int63_round_ubound\n then Int63.of_float_unchecked t\n else\n invalid_argf\n \"Float.int63_round_nearest_portable_alloc_exn: argument (%f) is too large\"\n (box t0)\n ()\n else if t >= int63_round_lbound\n then Int63.of_float_unchecked t\n else\n invalid_argf\n \"Float.int63_round_nearest_portable_alloc_exn: argument (%f) is too small or NaN\"\n (box t0)\n ()\n;;\n\nlet int63_round_nearest_arch64_noalloc_exn f = Int63.of_int (iround_nearest_exn f)\n\nlet int63_round_nearest_exn =\n match Word_size.word_size with\n | W64 -> int63_round_nearest_arch64_noalloc_exn\n | W32 -> int63_round_nearest_portable_alloc_exn\n;;\n\nlet round ?(dir = `Nearest) t =\n match dir with\n | `Nearest -> round_nearest t\n | `Down -> round_down t\n | `Up -> round_up t\n | `Zero -> round_towards_zero t\n;;\n\nmodule Class = struct\n type t =\n | Infinite\n | Nan\n | Normal\n | Subnormal\n | Zero\n [@@deriving_inline compare, enumerate, sexp]\n\n let compare = (Ppx_compare_lib.polymorphic_compare : t -> t -> int)\n let all = ([ Infinite; Nan; Normal; Subnormal; Zero ] : t list)\n\n let t_of_sexp =\n (let _tp_loc = \"float.ml.Class.t\" in\n function\n | Ppx_sexp_conv_lib.Sexp.Atom (\"infinite\" | \"Infinite\") -> Infinite\n | Ppx_sexp_conv_lib.Sexp.Atom (\"nan\" | \"Nan\") -> Nan\n | Ppx_sexp_conv_lib.Sexp.Atom (\"normal\" | \"Normal\") -> Normal\n | Ppx_sexp_conv_lib.Sexp.Atom (\"subnormal\" | \"Subnormal\") -> Subnormal\n | Ppx_sexp_conv_lib.Sexp.Atom (\"zero\" | \"Zero\") -> Zero\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"infinite\" | \"Infinite\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"nan\" | \"Nan\") :: _) as\n sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"normal\" | \"Normal\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom (\"subnormal\" | \"Subnormal\") :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.Atom (\"zero\" | \"Zero\") :: _)\n as sexp -> Ppx_sexp_conv_lib.Conv_error.stag_no_args _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List (Ppx_sexp_conv_lib.Sexp.List _ :: _) as sexp ->\n Ppx_sexp_conv_lib.Conv_error.nested_list_invalid_sum _tp_loc sexp\n | Ppx_sexp_conv_lib.Sexp.List [] as sexp ->\n Ppx_sexp_conv_lib.Conv_error.empty_list_invalid_sum _tp_loc sexp\n | sexp -> Ppx_sexp_conv_lib.Conv_error.unexpected_stag _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> t)\n ;;\n\n let sexp_of_t =\n (function\n | Infinite -> Ppx_sexp_conv_lib.Sexp.Atom \"Infinite\"\n | Nan -> Ppx_sexp_conv_lib.Sexp.Atom \"Nan\"\n | Normal -> Ppx_sexp_conv_lib.Sexp.Atom \"Normal\"\n | Subnormal -> Ppx_sexp_conv_lib.Sexp.Atom \"Subnormal\"\n | Zero -> Ppx_sexp_conv_lib.Sexp.Atom \"Zero\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n [@@@end]\n\n let to_string t = string_of_sexp (sexp_of_t t)\n let of_string s = t_of_sexp (sexp_of_string s)\nend\n\nlet classify t =\n let module C = Class in\n match classify_float t with\n | FP_normal -> C.Normal\n | FP_subnormal -> C.Subnormal\n | FP_zero -> C.Zero\n | FP_infinite -> C.Infinite\n | FP_nan -> C.Nan\n;;\n\nlet is_finite t = not (t = infinity || t = neg_infinity || is_nan t)\n\nlet insert_underscores ?(delimiter = '_') ?(strip_zero = false) string =\n match String.lsplit2 string ~on:'.' with\n | None -> Int_conversions.insert_delimiter string ~delimiter\n | Some (left, right) ->\n let left = Int_conversions.insert_delimiter left ~delimiter in\n let right =\n if strip_zero then String.rstrip right ~drop:(fun c -> Char.( = ) c '0') else right\n in\n (match right with\n | \"\" -> left\n | _ -> left ^ \".\" ^ right)\n;;\n\nlet to_string_hum ?delimiter ?(decimals = 3) ?strip_zero f =\n if Int_replace_polymorphic_compare.( < ) decimals 0\n then invalid_argf \"to_string_hum: invalid argument ~decimals=%d\" decimals ();\n match classify f with\n | Class.Infinite -> if f > 0. then \"inf\" else \"-inf\"\n | Class.Nan -> \"nan\"\n | Class.Normal | Class.Subnormal | Class.Zero ->\n insert_underscores (sprintf \"%.*f\" decimals f) ?delimiter ?strip_zero\n;;\n\nlet sexp_of_t t =\n let sexp = sexp_of_t t in\n match !Sexp.of_float_style with\n | `No_underscores -> sexp\n | `Underscores ->\n (match sexp with\n | List _ ->\n raise_s\n (Sexp.message\n \"[sexp_of_float] produced strange sexp\"\n [ \"sexp\", Sexp.sexp_of_t sexp ])\n | Atom string ->\n if String.contains string 'E' then sexp else Atom (insert_underscores string))\n;;\n\nlet to_padded_compact_string_custom t ?(prefix = \"\") ~kilo ~mega ~giga ~tera ?peta () =\n (* Round a ratio toward the nearest integer, resolving ties toward the nearest even\n number. For sane inputs (in particular, when [denominator] is an integer and\n [abs numerator < 2e52]) this should be accurate. Otherwise, the result might be a\n little bit off, but we don't really use that case. *)\n let iround_ratio_exn ~numerator ~denominator =\n let k = floor (numerator /. denominator) in\n (* if [abs k < 2e53], then both [k] and [k +. 1.] are accurately represented, and in\n particular [k +. 1. > k]. If [denominator] is also an integer, and\n [abs (denominator *. (k +. 1)) < 2e53] (and in some other cases, too), then [lower]\n and [higher] are actually both accurate. Since (roughly)\n [numerator = denominator *. k] then for [abs numerator < 2e52] we should be\n fine. *)\n let lower = denominator *. k in\n let higher = denominator *. (k +. 1.) in\n (* Subtracting numbers within a factor of two from each other is accurate.\n So either the two subtractions below are accurate, or k = 0, or k = -1.\n In case of a tie, round to even. *)\n let diff_right = higher -. numerator in\n let diff_left = numerator -. lower in\n let k = iround_nearest_exn k in\n if diff_right < diff_left\n then k + 1\n else if diff_right > diff_left\n then k\n else if (* a tie *)\n Int_replace_polymorphic_compare.( = ) (k mod 2) 0\n then k\n else k + 1\n in\n match classify t with\n | Class.Infinite -> if t < 0.0 then \"-inf \" else \"inf \"\n | Class.Nan -> \"nan \"\n | Class.Subnormal | Class.Normal | Class.Zero ->\n let go t =\n let conv_one t =\n assert (0. <= t && t < 999.95);\n let x = prefix ^ format_float \"%.1f\" t in\n (* Fix the \".0\" suffix *)\n if String.is_suffix x ~suffix:\".0\"\n then (\n let x = Bytes.of_string x in\n let n = Bytes.length x in\n Bytes.set x (n - 1) ' ';\n Bytes.set x (n - 2) ' ';\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:x)\n else x\n in\n let conv mag t denominator =\n assert (\n (denominator = 100. && t >= 999.95)\n || (denominator >= 100_000. && t >= round_nearest (denominator *. 9.999_5)));\n assert (t < round_nearest (denominator *. 9_999.5));\n let i, d =\n let k = iround_ratio_exn ~numerator:t ~denominator in\n (* [mod] is okay here because we know i >= 0. *)\n k / 10, k mod 10\n in\n let open Int_replace_polymorphic_compare in\n assert (0 <= i && i < 1000);\n assert (0 <= d && d < 10);\n if d = 0\n then sprintf \"%s%d%s \" prefix i mag\n else sprintf \"%s%d%s%d\" prefix i mag d\n in\n (* While the standard metric prefixes (e.g. capital \"M\" rather than \"m\", [1]) are\n nominally more correct, this hinders readability in our case. E.g., 10G6 and\n 1066 look too similar. That's an extreme example, but in general k,m,g,t,p\n probably stand out better than K,M,G,T,P when interspersed with digits.\n\n [1] http://en.wikipedia.org/wiki/Metric_prefix *)\n (* The trick here is that:\n - the first boundary (999.95) as a float is slightly over-represented (so it is\n better approximated as \"1k\" than as \"999.9\"),\n - the other boundaries are accurately represented, because they are integers.\n That's why the strict equalities below do exactly what we want. *)\n if t < 999.95E0\n then conv_one t\n else if t < 999.95E3\n then conv kilo t 100.\n else if t < 999.95E6\n then conv mega t 100_000.\n else if t < 999.95E9\n then conv giga t 100_000_000.\n else if t < 999.95E12\n then conv tera t 100_000_000_000.\n else (\n match peta with\n | None -> sprintf \"%s%.1e\" prefix t\n | Some peta ->\n if t < 999.95E15\n then conv peta t 100_000_000_000_000.\n else sprintf \"%s%.1e\" prefix t)\n in\n if t >= 0. then go t else \"-\" ^ go ~-.t\n;;\n\nlet to_padded_compact_string t =\n to_padded_compact_string_custom t ~kilo:\"k\" ~mega:\"m\" ~giga:\"g\" ~tera:\"t\" ~peta:\"p\" ()\n;;\n\n(* Performance note: Initializing the accumulator to 1 results in one extra\n multiply; e.g., to compute x ** 4, we in principle only need 2 multiplies,\n but this function will have 3 multiplies. However, attempts to avoid this\n (like decrementing n and initializing accum to be x, or handling small\n exponents as a special case) have not yielded anything that is a net\n improvement.\n*)\nlet int_pow x n =\n let open Int_replace_polymorphic_compare in\n if n = 0\n then 1.\n else (\n (* Using [x +. (-0.)] on the following line convinces the compiler to avoid a certain\n boxing (that would result in allocation in each iteration). Soon, the compiler\n shouldn't need this \"hint\" to avoid the boxing. The reason we add -0 rather than 0\n is that [x +. (-0.)] is apparently always the same as [x], whereas [x +. 0.] is\n not, in that it sends [-0.] to [0.]. This makes a difference because we want\n [int_pow (-0.) (-1)] to return neg_infinity just like [-0. ** -1.] would. *)\n let x = ref (x +. -0.) in\n let n = ref n in\n let accum = ref 1. in\n if !n < 0\n then (\n (* x ** n = (1/x) ** -n *)\n x := 1. /. !x;\n n := ~- (!n);\n if !n < 0\n then (\n (* n must have been min_int, so it is now so big that it has wrapped around.\n We decrement it so that it looks positive again, but accordingly have\n to put an extra factor of x in the accumulator.\n *)\n accum := !x;\n decr n));\n (* Letting [a] denote (the original value of) [x ** n], we maintain\n the invariant that [(x ** n) *. accum = a]. *)\n while !n > 1 do\n if !n land 1 <> 0 then accum := !x *. !accum;\n x := !x *. !x;\n n := !n lsr 1\n done;\n (* n is necessarily 1 at this point, so there is one additional\n multiplication by x. *)\n !x *. !accum)\n;;\n\nlet round_gen x ~how =\n if x = 0.\n then 0.\n else if not (is_finite x)\n then x\n else (\n (* Significant digits and decimal digits. *)\n let sd, dd =\n match how with\n | `significant_digits sd ->\n let dd = sd - to_int (round_up (log10 (abs x))) in\n sd, dd\n | `decimal_digits dd ->\n let sd = dd + to_int (round_up (log10 (abs x))) in\n sd, dd\n in\n let open Int_replace_polymorphic_compare in\n if sd < 0\n then 0.\n else if sd >= 17\n then x\n else (\n (* Choose the order that is exactly representable as a float. Small positive\n integers are, but their inverses in most cases are not. *)\n let abs_dd = Int.abs dd in\n if abs_dd > 22 || sd >= 16\n (* 10**22 is exactly representable as a float, but 10**23 is not, so use the slow\n path. Similarly, if we need 16 significant digits in the result, then the integer\n [round_nearest (x order)] might not be exactly representable as a float, since\n for some ranges we only have 15 digits of precision guaranteed.\n\n That said, we are still rounding twice here:\n\n 1) first time when rounding [x *. order] or [x /. order] to the nearest float\n (just the normal way floating-point multiplication or division works),\n\n 2) second time when applying [round_nearest_half_to_even] to the result of the\n above operation\n\n So for arguments within an ulp from a tie we might still produce an off-by-one\n result. *)\n then of_string (sprintf \"%.*g\" sd x)\n else (\n let order = int_pow 10. abs_dd in\n if dd >= 0\n then round_nearest_half_to_even (x *. order) /. order\n else round_nearest_half_to_even (x /. order) *. order)))\n;;\n\nlet round_significant x ~significant_digits =\n if Int_replace_polymorphic_compare.( <= ) significant_digits 0\n then\n invalid_argf\n \"Float.round_significant: invalid argument significant_digits:%d\"\n significant_digits\n ()\n else round_gen x ~how:(`significant_digits significant_digits)\n;;\n\nlet round_decimal x ~decimal_digits = round_gen x ~how:(`decimal_digits decimal_digits)\nlet between t ~low ~high = low <= t && t <= high\n\nlet clamp_exn t ~min ~max =\n (* Also fails if [min] or [max] is nan *)\n assert (min <= max);\n (* clamp_unchecked is in float0.ml *)\n clamp_unchecked t ~min ~max\n;;\n\nlet clamp t ~min ~max =\n (* Also fails if [min] or [max] is nan *)\n if min <= max\n then Ok (clamp_unchecked t ~min ~max)\n else\n Or_error.error_s\n (Sexp.message\n \"clamp requires [min <= max]\"\n [ \"min\", T.sexp_of_t min; \"max\", T.sexp_of_t max ])\n;;\n\nlet ( + ) = ( +. )\nlet ( - ) = ( -. )\nlet ( * ) = ( *. )\nlet ( ** ) = ( ** )\nlet ( / ) = ( /. )\nlet ( ~- ) = ( ~-. )\n\nlet sign_exn t : Sign.t =\n if t > 0.\n then Pos\n else if t < 0.\n then Neg\n else if t = 0.\n then Zero\n else Error.raise_s (Sexp.message \"Float.sign_exn of NAN\" [ \"\", sexp_of_t t ])\n;;\n\nlet sign_or_nan t : Sign_or_nan.t =\n if t > 0. then Pos else if t < 0. then Neg else if t = 0. then Zero else Nan\n;;\n\nlet ieee_negative t =\n let bits = Caml.Int64.bits_of_float t in\n Poly.(bits < Caml.Int64.zero)\n;;\n\nlet exponent_bits = 11\nlet mantissa_bits = 52\nlet exponent_mask64 = Int64.(shift_left one exponent_bits - one)\nlet exponent_mask = Int64.to_int_exn exponent_mask64\nlet mantissa_mask = Int63.(shift_left one mantissa_bits - one)\nlet mantissa_mask64 = Int63.to_int64 mantissa_mask\n\nlet ieee_exponent t =\n let bits = Caml.Int64.bits_of_float t in\n Int64.(bit_and (shift_right_logical bits mantissa_bits) exponent_mask64)\n |> Caml.Int64.to_int\n;;\n\nlet ieee_mantissa t =\n let bits = Caml.Int64.bits_of_float t in\n Int63.of_int64_exn Caml.Int64.(logand bits mantissa_mask64)\n;;\n\nlet create_ieee_exn ~negative ~exponent ~mantissa =\n if Int.(bit_and exponent exponent_mask <> exponent)\n then failwithf \"exponent %d out of range [0, %d]\" exponent exponent_mask ()\n else if Int63.(bit_and mantissa mantissa_mask <> mantissa)\n then\n failwithf\n \"mantissa %s out of range [0, %s]\"\n (Int63.to_string mantissa)\n (Int63.to_string mantissa_mask)\n ()\n else (\n let sign_bits = if negative then Caml.Int64.min_int else Caml.Int64.zero in\n let expt_bits = Caml.Int64.shift_left (Caml.Int64.of_int exponent) mantissa_bits in\n let mant_bits = Int63.to_int64 mantissa in\n let bits = Caml.Int64.(logor sign_bits (logor expt_bits mant_bits)) in\n Caml.Int64.float_of_bits bits)\n;;\n\nlet create_ieee ~negative ~exponent ~mantissa =\n Or_error.try_with (fun () -> create_ieee_exn ~negative ~exponent ~mantissa)\n;;\n\nmodule Terse = struct\n type nonrec t = t\n\n let t_of_sexp = t_of_sexp\n let to_string x = Printf.sprintf \"%.8G\" x\n let sexp_of_t x = Sexp.Atom (to_string x)\n let of_string x = of_string x\nend\n\nlet validate_ordinary t =\n Validate.of_error_opt\n (let module C = Class in\n match classify t with\n | C.Normal | C.Subnormal | C.Zero -> None\n | C.Infinite -> Some \"value is infinite\"\n | C.Nan -> Some \"value is NaN\")\n;;\n\nmodule V = struct\n module ZZ = Comparable.Validate (T)\n\n let validate_bound ~min ~max t =\n Validate.first_failure (validate_ordinary t) (ZZ.validate_bound t ~min ~max)\n ;;\n\n let validate_lbound ~min t =\n Validate.first_failure (validate_ordinary t) (ZZ.validate_lbound t ~min)\n ;;\n\n let validate_ubound ~max t =\n Validate.first_failure (validate_ordinary t) (ZZ.validate_ubound t ~max)\n ;;\nend\n\ninclude V\n\ninclude Comparable.With_zero (struct\n include T\n\n let zero = zero\n\n include V\n end)\n\n(* These are partly here as a performance hack to avoid some boxing we're getting with\n the versions we get from [With_zero]. They also make [Float.is_negative nan] and\n [Float.is_non_positive nan] return [false]; the versions we get from [With_zero] return\n [true]. *)\nlet is_positive t = t > 0.\nlet is_non_negative t = t >= 0.\nlet is_negative t = t < 0.\nlet is_non_positive t = t <= 0.\n\ninclude Pretty_printer.Register (struct\n include T\n\n let module_name = \"Base.Float\"\n let to_string = to_string\n end)\n\nmodule O = struct\n let ( + ) = ( + )\n let ( - ) = ( - )\n let ( * ) = ( * )\n let ( / ) = ( / )\n let ( ~- ) = ( ~- )\n let ( ** ) = ( ** )\n\n include (Float_replace_polymorphic_compare : Comparisons.Infix with type t := t)\n\n let abs = abs\n let neg = neg\n let zero = zero\n let of_int = of_int\n let of_float x = x\nend\n\nmodule O_dot = struct\n let ( *. ) = ( * )\n let ( +. ) = ( + )\n let ( -. ) = ( - )\n let ( /. ) = ( / )\n let ( ~-. ) = ( ~- )\n let ( **. ) = ( ** )\nend\n\nmodule Private = struct\n let box = box\n let clamp_unchecked = clamp_unchecked\n let lower_bound_for_int = lower_bound_for_int\n let upper_bound_for_int = upper_bound_for_int\n let specialized_hash = hash_float\n let one_ulp_less_than_half = one_ulp_less_than_half\n let int63_round_nearest_portable_alloc_exn = int63_round_nearest_portable_alloc_exn\n let int63_round_nearest_arch64_noalloc_exn = int63_round_nearest_arch64_noalloc_exn\n let iround_nearest_exn_64 = iround_nearest_exn_64\nend\n\n(* Include type-specific [Replace_polymorphic_compare] at the end, after\n including functor application that could shadow its definitions. This is\n here so that efficient versions of the comparison functions are exported by\n this module. *)\ninclude Float_replace_polymorphic_compare\n\n(* These functions specifically replace defaults in replace_polymorphic_compare.\n\n The desired behavior here is to propagate a nan if either argument is nan. Because the\n first comparison will always return false if either argument is nan, it suffices to\n check if x is nan. Then, when x is nan or both x and y are nan, we return x = nan; and\n when y is nan but not x, we return y = nan.\n\n There are various ways to implement these functions. The benchmark below shows a few\n different versions. This benchmark was run over an array of random floats (none of\n which are nan).\n\n ┌────────────────────────────────────────────────┬──────────┐\n │ Name │ Time/Run │\n ├────────────────────────────────────────────────┼──────────┤\n │ if is_nan x then x else if x < y then x else y │ 2.42us │\n │ if is_nan x || x < y then x else y │ 2.02us │\n │ if x < y || is_nan x then x else y │ 1.88us │\n └────────────────────────────────────────────────┴──────────┘\n\n The benchmark below was run when x > y is always true (again, no nan values).\n\n ┌────────────────────────────────────────────────┬──────────┐\n │ Name │ Time/Run │\n ├────────────────────────────────────────────────┼──────────┤\n │ if is_nan x then x else if x < y then x else y │ 2.83us │\n │ if is_nan x || x < y then x else y │ 1.97us │\n │ if x < y || is_nan x then x else y │ 1.56us │\n └────────────────────────────────────────────────┴──────────┘\n*)\nlet min (x : t) y = if x < y || is_nan x then x else y\nlet max (x : t) y = if x > y || is_nan x then x else y\n","open! Import\ninclude Buffer_intf\ninclude Caml.Buffer\n\nlet contents_bytes = to_bytes\nlet add_substring t s ~pos ~len = add_substring t s pos len\nlet add_subbytes t s ~pos ~len = add_subbytes t s pos len\nlet sexp_of_t t = sexp_of_string (contents t)\n\nmodule To_bytes =\n Blit.Make_distinct\n (struct\n type nonrec t = t\n\n let length = length\n end)\n (struct\n type t = Bytes.t\n\n let create ~len = Bytes.create len\n let length = Bytes.length\n\n let unsafe_blit ~src ~src_pos ~dst ~dst_pos ~len =\n Caml.Buffer.blit src src_pos dst dst_pos len\n ;;\n end)\n\ninclude To_bytes\nmodule To_string = Blit.Make_to_string (Caml.Buffer) (To_bytes)\n","open Base\n\ntype 'a test_pred\n = ?here:Lexing.position list\n -> ?message:string\n -> ('a -> bool)\n -> 'a\n -> unit\n\ntype 'a test_eq\n = ?here:Lexing.position list\n -> ?message:string\n -> ?equal:('a -> 'a -> bool)\n -> 'a\n -> 'a\n -> unit\n\ntype 'a test_result\n = ?here:Lexing.position list\n -> ?message:string\n -> ?equal:('a -> 'a -> bool)\n -> expect:'a\n -> 'a\n -> unit\n\nexception E of string * Sexp.t [@@deriving sexp]\n\nlet failwith message sexp = raise (E (message, sexp))\n\nlet fail_in_sexp_style ~message ~pos ~here ~tag body =\n let message =\n match message with\n | None -> tag\n | Some s -> s ^ \": \" ^ tag\n in\n let sexp =\n Sexp.List (\n body\n @ [ Sexp.List [ Sexp.Atom \"Loc\"; Sexp.Atom pos ] ]\n @ begin match here with\n | [] -> []\n | _ -> [ Sexp.List [ Sexp.Atom \"Stack\"\n ; [%sexp_of: Source_code_position.t list] here\n ] ]\n end\n )\n in\n failwith message sexp\n\nlet [@cold] test_pred_failed ~message ~pos ~here ~sexpifier t =\n fail_in_sexp_style ~message ~pos ~here ~tag:\"predicate failed\" [\n Sexp.List [Sexp.Atom \"Value\"; sexpifier t]\n ]\n\nlet test_pred ~pos ~sexpifier ~here ?message predicate t =\n if not (predicate t) then\n test_pred_failed ~message ~pos ~here ~sexpifier t\n\nlet r_diff : (from_:string -> to_:string -> unit) option ref = ref None\nlet set_diff_function f = r_diff := f\n\nlet [@cold] test_result_or_eq_failed ~sexpifier ~expect ~got =\n let got = sexpifier got in\n let expect = sexpifier expect in\n begin match !r_diff with\n | None -> ()\n | Some diff ->\n let from_ = Sexp.to_string_hum expect in\n let to_ = Sexp.to_string_hum got in\n diff ~from_ ~to_\n end;\n `Fail (expect, got)\n\nlet test_result_or_eq ~sexpifier ~comparator ?equal ~expect ~got =\n let pass =\n match equal with\n | None -> comparator got expect = 0\n | Some f -> f got expect\n in\n if pass\n then `Pass\n else test_result_or_eq_failed ~sexpifier ~expect ~got\n\nlet [@cold] test_eq_failed ~message ~pos ~here ~t1 ~t2 =\n fail_in_sexp_style ~message ~pos ~here ~tag:\"comparison failed\" [\n t1;\n Sexp.Atom \"vs\";\n t2;\n ]\n\nlet test_eq ~pos ~sexpifier ~comparator ~here ?message ?equal t1 t2 =\n match test_result_or_eq ~sexpifier ~comparator ?equal ~expect:t1 ~got:t2 with\n | `Pass -> ()\n | `Fail (t1, t2) -> test_eq_failed ~message ~pos ~here ~t1 ~t2\n\nlet [@cold] test_result_failed ~message ~pos ~here ~expect ~got =\n fail_in_sexp_style ~message ~pos ~here ~tag:\"got unexpected result\" [\n Sexp.List [Sexp.Atom \"expected\"; expect];\n Sexp.List [Sexp.Atom \"got\"; got];\n ]\n\nlet test_result ~pos ~sexpifier ~comparator ~here ?message ?equal ~expect ~got =\n match test_result_or_eq ~sexpifier ~comparator ?equal ~expect ~got with\n | `Pass -> ()\n | `Fail (expect, got) -> test_result_failed ~message ~pos ~here ~expect ~got\n","type t = string\n\n(* Share the digest of the empty string *)\nlet empty = Digest.string \"\"\nlet make s =\n if s = empty then\n empty\n else\n s\n\nlet compare = compare\n\nlet length = 16\n\nlet to_binary s = s\nlet of_binary_exn s = assert (String.length s = length); make s\nlet unsafe_of_binary = make\n\nlet to_hex = Digest.to_hex\nlet of_hex_exn s = make (Digest.from_hex s)\n\nlet string s = make (Digest.string s)\n\nlet bytes s = make (Digest.bytes s)\n\nlet subbytes bytes ~pos ~len = make (Digest.subbytes bytes pos len)\n","(* Common: common definitions used by binary protocol converters *)\n\nopen Base\nopen Printf\nopen Bigarray\n\ntype pos = int [@@deriving sexp_of]\n\n(* Errors and exceptions *)\n\nexception Buffer_short\nexception No_variant_match\n\nmodule ReadError = struct\n type t =\n | Neg_int8\n | Int_code\n | Int_overflow\n | Nat0_code\n | Nat0_overflow\n | Int32_code\n | Int64_code\n | Nativeint_code\n | Unit_code\n | Bool_code\n | Option_code\n | String_too_long\n | Variant_tag\n | Array_too_long\n | List_too_long of\n { len : int\n ; max_len : int\n }\n | Hashtbl_too_long\n | Sum_tag of string\n | Variant of string\n | Poly_rec_bound of string\n | Variant_wrong_type of string\n | Silly_type of string\n | Empty_type of string\n\n let to_string = function\n | Neg_int8 -> \"Neg_int8\"\n | Int_code -> \"Int_code\"\n | Int_overflow -> \"Int_overflow\"\n | Nat0_code -> \"Nat0_code\"\n | Nat0_overflow -> \"Nat0_overflow\"\n | Int32_code -> \"Int32_code\"\n | Int64_code -> \"Int64_code\"\n | Nativeint_code -> \"Nativeint_code\"\n | Unit_code -> \"Unit_code\"\n | Bool_code -> \"Bool_code\"\n | Option_code -> \"Option_code\"\n | String_too_long -> \"String_too_long\"\n | Variant_tag -> \"Variant_tag\"\n | Array_too_long -> \"Array_too_long\"\n | List_too_long { len; max_len } -> sprintf \"List_too_long / %d (max %d)\" len max_len\n | Hashtbl_too_long -> \"Hashtbl_too_long\"\n | Sum_tag loc -> \"Sum_tag / \" ^ loc\n | Variant loc -> \"Variant / \" ^ loc\n | Poly_rec_bound loc -> \"Poly_rec_bound / \" ^ loc\n | Variant_wrong_type loc -> \"Variant_wrong_type / \" ^ loc\n | Silly_type loc -> \"Silly_type / \" ^ loc\n | Empty_type loc -> \"Empty_type / \" ^ loc\n ;;\n\n let sexp_of_t t = Sexp.Atom (to_string t)\nend\n\nexception Read_error of ReadError.t * pos [@@deriving sexp_of]\nexception Poly_rec_write of string\nexception Empty_type of string\n\nlet raise_read_error err pos = raise (Read_error (err, pos))\n\nlet raise_variant_wrong_type name pos =\n raise (Read_error (ReadError.Variant_wrong_type name, pos))\n;;\n\nlet raise_concurrent_modification loc = failwith (loc ^ \": concurrent modification\")\nlet array_bound_error () = invalid_arg \"index out of bounds\"\n\n(* Buffers *)\n\ntype pos_ref = pos ref\ntype buf = (char, int8_unsigned_elt, c_layout) Array1.t\n\nlet create_buf n = Array1.create Bigarray.char c_layout n\nlet buf_len buf = Array1.dim buf\nlet assert_pos pos = if pos < 0 then array_bound_error ()\nlet check_pos (buf : buf) pos = if pos >= Array1.dim buf then raise Buffer_short\n\nlet safe_get_pos buf pos_ref =\n let pos = !pos_ref in\n check_pos buf pos;\n pos\n;;\n\nlet check_next (buf : buf) next = if next > Array1.dim buf then raise Buffer_short\n\nlet get_opt_pos ~loc ~var = function\n | Some pos ->\n if pos < 0 then invalid_arg (sprintf \"Bin_prot.Common.%s: %s < 0\" loc var);\n pos\n | None -> 0\n;;\n\nexternal unsafe_blit_buf\n : src_pos:int\n -> src:buf\n -> dst_pos:int\n -> dst:buf\n -> len:int\n -> unit\n = \"bin_prot_blit_buf_stub\"\n\nlet blit_buf ?src_pos ~src ?dst_pos ~dst len =\n let loc = \"blit_buf\" in\n let src_pos = get_opt_pos ~loc ~var:\"src_pos\" src_pos in\n let dst_pos = get_opt_pos ~loc ~var:\"dst_pos\" dst_pos in\n if len < 0\n then invalid_arg \"Bin_prot.Common.blit_buf: len < 0\"\n else if len = 0\n then (\n if src_pos > Array1.dim src\n then invalid_arg \"Bin_prot.Common.blit_buf: src_pos > src_len\";\n if dst_pos > Array1.dim dst\n then invalid_arg \"Bin_prot.Common.blit_buf: dst_pos > dst_len\")\n else if src_pos + len > Array1.dim src\n then invalid_arg \"Bin_prot.Common.blit_buf: src_pos + len > src_len\"\n else if dst_pos + len > Array1.dim dst\n then invalid_arg \"Bin_prot.Common.blit_buf: dst_pos + len > dst_len\"\n else unsafe_blit_buf ~src_pos ~src ~dst_pos ~dst ~len\n;;\n\nexternal unsafe_blit_string_buf\n : src_pos:int\n -> string\n -> dst_pos:int\n -> buf\n -> len:int\n -> unit\n = \"bin_prot_blit_string_buf_stub\"\n[@@noalloc]\n\nexternal unsafe_blit_bytes_buf\n : src_pos:int\n -> bytes\n -> dst_pos:int\n -> buf\n -> len:int\n -> unit\n = \"bin_prot_blit_bytes_buf_stub\"\n[@@noalloc]\n\nlet blit_string_buf ?src_pos str ?dst_pos buf ~len =\n let loc = \"blit_string_buf\" in\n let src_pos = get_opt_pos ~loc ~var:\"src_pos\" src_pos in\n let dst_pos = get_opt_pos ~loc ~var:\"dst_pos\" dst_pos in\n if len < 0\n then invalid_arg \"Bin_prot.Common.blit_string_buf: len < 0\"\n else if len = 0\n then (\n if src_pos > String.length str\n then invalid_arg \"Bin_prot.Common.blit_string_buf: src_pos > str_len\";\n if dst_pos > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_string_buf: src_pos > buf\")\n else if src_pos + len > String.length str\n then invalid_arg \"Bin_prot.Common.blit_string_buf: src_pos + len > str_len\"\n else if dst_pos + len > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_string_buf: src_pos + len > buf\"\n else unsafe_blit_string_buf ~src_pos str ~dst_pos buf ~len\n;;\n\nlet blit_bytes_buf ?src_pos str ?dst_pos buf ~len =\n let loc = \"blit_bytes_buf\" in\n let src_pos = get_opt_pos ~loc ~var:\"src_pos\" src_pos in\n let dst_pos = get_opt_pos ~loc ~var:\"dst_pos\" dst_pos in\n if len < 0\n then invalid_arg \"Bin_prot.Common.blit_bytes_buf: len < 0\"\n else if len = 0\n then (\n if src_pos > Bytes.length str\n then invalid_arg \"Bin_prot.Common.blit_bytes_buf: src_pos > str_len\";\n if dst_pos > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_bytes_buf: src_pos > buf\")\n else if src_pos + len > Bytes.length str\n then invalid_arg \"Bin_prot.Common.blit_bytes_buf: src_pos + len > str_len\"\n else if dst_pos + len > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_bytes_buf: src_pos + len > buf\"\n else unsafe_blit_bytes_buf ~src_pos str ~dst_pos buf ~len\n;;\n\nexternal unsafe_blit_buf_string\n : src_pos:int\n -> buf\n -> dst_pos:int\n -> bytes\n -> len:int\n -> unit\n = \"bin_prot_blit_buf_bytes_stub\"\n[@@noalloc]\n\nexternal unsafe_blit_buf_bytes\n : src_pos:int\n -> buf\n -> dst_pos:int\n -> bytes\n -> len:int\n -> unit\n = \"bin_prot_blit_buf_bytes_stub\"\n[@@noalloc]\n\nlet blit_buf_bytes ?src_pos buf ?dst_pos str ~len =\n let loc = \"blit_buf_string\" in\n let src_pos = get_opt_pos ~loc ~var:\"src_pos\" src_pos in\n let dst_pos = get_opt_pos ~loc ~var:\"dst_pos\" dst_pos in\n if len < 0\n then invalid_arg \"Bin_prot.Common.blit_buf_string: len < 0\"\n else if len = 0\n then (\n if src_pos > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_buf_string: src_pos > buf_len\";\n if dst_pos > Bytes.length str\n then invalid_arg \"Bin_prot.Common.blit_buf_string: src_pos > str_len\")\n else if src_pos + len > Array1.dim buf\n then invalid_arg \"Bin_prot.Common.blit_buf_string: src_pos + len > buf_len\"\n else if dst_pos + len > Bytes.length str\n then invalid_arg \"Bin_prot.Common.blit_buf_string: src_pos + len > str_len\"\n else unsafe_blit_buf_bytes ~src_pos buf ~dst_pos str ~len\n;;\n\nlet blit_buf_string = blit_buf_bytes\n\n(* Miscellaneous *)\n\nlet rec copy_htbl_list htbl = function\n | [] -> htbl\n | (k, v) :: rest ->\n Caml.Hashtbl.add htbl k v;\n copy_htbl_list htbl rest\n;;\n\n(* Bigarrays *)\n\ntype vec32 = (float, float32_elt, fortran_layout) Array1.t\ntype vec64 = (float, float64_elt, fortran_layout) Array1.t\ntype vec = vec64\ntype mat32 = (float, float32_elt, fortran_layout) Array2.t\ntype mat64 = (float, float64_elt, fortran_layout) Array2.t\ntype mat = mat64\n\n(* Float arrays *)\n\nexternal unsafe_blit_float_array_buf\n : src_pos:int\n -> float array\n -> dst_pos:int\n -> buf\n -> len:int\n -> unit\n = \"bin_prot_blit_float_array_buf_stub\"\n[@@noalloc]\n\nexternal unsafe_blit_buf_float_array\n : src_pos:int\n -> buf\n -> dst_pos:int\n -> float array\n -> len:int\n -> unit\n = \"bin_prot_blit_buf_float_array_stub\"\n[@@noalloc]\n\n(***)\n\nlet ( + ) = ( + )\n","open Core_kernel\n\nmodule type Nat_intf = Nat.Intf\n\ntype z = Nat.z\n\ntype 'a s = 'a Nat.s\n\nmodule T = struct\n type ('a, _) t = [] : ('a, z) t | ( :: ) : 'a * ('a, 'n) t -> ('a, 'n s) t\nend\n\ninclude T\n\nlet singleton a = [ a ]\n\nlet unsingleton (type a) ([ x ] : (a, z s) t) : a = x\n\nlet rec iter : type a n. (a, n) t -> f:(a -> unit) -> unit =\n fun t ~f -> match t with [] -> () | x :: xs -> f x ; iter xs ~f\n\nlet iteri (type a n) (t : (a, n) t) ~(f : int -> a -> unit) : unit =\n let rec go : type n. int -> (a, n) t -> unit =\n fun acc t ->\n match t with\n | [] ->\n ()\n | x :: xs ->\n f acc x ;\n go (acc + 1) xs\n in\n go 0 t\n\nlet rec length : type a n. (a, n) t -> n Nat.t = function\n | [] ->\n Z\n | _ :: xs ->\n S (length xs)\n\nlet nth v i =\n let rec loop : type a n. int -> (a, n) t -> a option =\n fun j -> function\n | [] ->\n None\n | x :: xs ->\n if Int.equal i j then Some x else loop (j + 1) xs\n in\n loop 0 v\n\nlet nth_exn v i =\n match nth v i with\n | None ->\n invalid_argf \"Vector.nth_exn %d called on a vector of length %d\" i\n (length v |> Nat.to_int)\n ()\n | Some e ->\n e\n\nlet rec iter2 : type a b n. (a, n) t -> (b, n) t -> f:(a -> b -> unit) -> unit =\n fun t1 t2 ~f ->\n match (t1, t2) with\n | [], [] ->\n ()\n | x :: xs, y :: ys ->\n f x y ; iter2 xs ys ~f\n\nlet rec map2 : type a b c n. (a, n) t -> (b, n) t -> f:(a -> b -> c) -> (c, n) t\n =\n fun t1 t2 ~f ->\n match (t1, t2) with\n | [], [] ->\n []\n | x :: xs, y :: ys ->\n f x y :: map2 xs ys ~f\n\nlet rec hhead_off :\n type xs n.\n (xs, n s) Hlist0.H1_1(T).t -> xs Hlist0.HlistId.t * (xs, n) Hlist0.H1_1(T).t\n =\n fun xss ->\n match xss with\n | [] ->\n ([], [])\n | (x :: xs) :: xss ->\n let hds, tls = hhead_off xss in\n (x :: hds, xs :: tls)\n\nlet rec mapn :\n type xs y n.\n (xs, n) Hlist0.H1_1(T).t -> f:(xs Hlist0.HlistId.t -> y) -> (y, n) t =\n fun xss ~f ->\n match xss with\n | [] :: _xss ->\n []\n | (_ :: _) :: _ ->\n let hds, tls = hhead_off xss in\n let y = f hds in\n let ys = mapn tls ~f in\n y :: ys\n | [] ->\n failwith \"mapn: Empty args\"\n\nlet rec nth : type a n. (a, n) t -> int -> a option =\n fun t idx ->\n match t with\n | [] ->\n None\n | x :: _ when idx = 0 ->\n Some x\n | _ :: t ->\n nth t (idx - 1)\n\nlet zip xs ys = map2 xs ys ~f:(fun x y -> (x, y))\n\nlet rec to_list : type a n. (a, n) t -> a list =\n fun t -> match t with [] -> [] | x :: xs -> x :: to_list xs\n\nlet sexp_of_t a _ v = List.sexp_of_t a (to_list v)\n\nlet to_array t = Array.of_list (to_list t)\n\nlet rec init : type a n. int -> n Nat.t -> f:(int -> a) -> (a, n) t =\n fun i n ~f -> match n with Z -> [] | S n -> f i :: init (i + 1) n ~f\n\nlet init n ~f = init 0 n ~f\n\nlet rec _fold_map :\n type acc a b n.\n (a, n) t -> f:(acc -> a -> acc * b) -> init:acc -> acc * (b, n) t =\n fun t ~f ~init ->\n match t with\n | [] ->\n (init, [])\n | x :: xs ->\n let acc, y = f init x in\n let res, ys = _fold_map xs ~f ~init:acc in\n (res, y :: ys)\n\nlet rec map : type a b n. (a, n) t -> f:(a -> b) -> (b, n) t =\n fun t ~f -> match t with [] -> [] | x :: xs -> f x :: map xs ~f\n\nlet mapi (type a b m) (t : (a, m) t) ~(f : int -> a -> b) =\n let rec go : type n. int -> (a, n) t -> (b, n) t =\n fun i t -> match t with [] -> [] | x :: xs -> f i x :: go (i + 1) xs\n in\n go 0 t\n\nlet unzip ts = (map ts ~f:fst, map ts ~f:snd)\n\ntype _ e = T : ('a, 'n) t -> 'a e\n\nlet rec of_list : type a. a list -> a e = function\n | [] ->\n T []\n | x :: xs ->\n let (T xs) = of_list xs in\n T (x :: xs)\n\nlet rec of_list_and_length_exn : type a n. a list -> n Nat.t -> (a, n) t =\n fun xs n ->\n match (xs, n) with\n | [], Z ->\n []\n | x :: xs, S n ->\n x :: of_list_and_length_exn xs n\n | [], S _ | _ :: _, Z ->\n failwith \"Vector: Length mismatch\"\n\nlet of_array_and_length_exn : type a n. a array -> n Nat.t -> (a, n) t =\n fun xs n ->\n if Array.length xs <> Nat.to_int n then\n failwithf \"of_array_and_length_exn: got %d (expected %d)\" (Array.length xs)\n (Nat.to_int n) () ;\n init n ~f:(Array.get xs)\n\nlet rec _take_from_list : type a n. a list -> n Nat.t -> (a, n) t =\n fun xs n ->\n match (xs, n) with\n | _, Z ->\n []\n | x :: xs, S n ->\n x :: _take_from_list xs n\n | [], S _ ->\n failwith \"take_from_list: Not enough to take\"\n\nlet rec fold : type acc a n. (a, n) t -> f:(acc -> a -> acc) -> init:acc -> acc\n =\n fun t ~f ~init ->\n match t with\n | [] ->\n init\n | x :: xs ->\n let acc = f init x in\n fold xs ~f ~init:acc\n\nlet for_all : type a n. (a, n) t -> f:(a -> bool) -> bool =\n fun v ~f ->\n with_return (fun { return } ->\n iter v ~f:(fun x -> if not (f x) then return false) ;\n true )\n\nlet foldi t ~f ~init =\n snd (fold t ~f:(fun (i, acc) x -> (i + 1, f i acc x)) ~init:(0, init))\n\nlet reduce_exn (type n) (t : (_, n) t) ~f =\n match t with\n | [] ->\n failwith \"reduce_exn: empty list\"\n | init :: xs ->\n fold xs ~f ~init\n\nmodule L = struct\n type 'a t = 'a list [@@deriving yojson]\nend\n\nmodule Make = struct\n module Cata (F : sig\n type _ t\n\n val pair : 'a t -> 'b t -> ('a * 'b) t\n\n val cnv : ('a -> 'b) -> ('b -> 'a) -> 'b t -> 'a t\n\n val unit : unit t\n end) =\n struct\n let rec f : type n a. n Nat.t -> a F.t -> (a, n) t F.t =\n fun n tc ->\n match n with\n | Z ->\n F.cnv (function [] -> ()) (fun () -> []) F.unit\n | S n ->\n let tl = f n tc in\n F.cnv\n (function x :: xs -> (x, xs))\n (fun (x, xs) -> x :: xs)\n (F.pair tc tl)\n end\n\n module Sexpable (N : Nat_intf) : Sexpable.S1 with type 'a t := ('a, N.n) t =\n struct\n let sexp_of_t f t = List.sexp_of_t f (to_list t)\n\n let t_of_sexp f s = of_list_and_length_exn (List.t_of_sexp f s) N.n\n end\n\n module Yojson (N : Nat_intf) :\n Sigs.Jsonable.S1 with type 'a t := ('a, N.n) t = struct\n let to_yojson f t = L.to_yojson f (to_list t)\n\n let of_yojson f s =\n Result.map (L.of_yojson f s) ~f:(Fn.flip of_list_and_length_exn N.n)\n end\n\n module Binable (N : Nat_intf) : Binable.S1 with type 'a t := ('a, N.n) t =\n struct\n open Bin_prot\n\n module Tc = Cata (struct\n type 'a t = 'a Type_class.t\n\n let pair = Type_class.bin_pair\n\n let cnv t = Type_class.cnv Fn.id t\n\n let unit = Type_class.bin_unit\n end)\n\n module Shape = Cata (struct\n type _ t = Shape.t\n\n let pair = Shape.bin_shape_pair\n\n let cnv _ _ = Fn.id\n\n let unit = Shape.bin_shape_unit\n end)\n\n module Size = Cata (struct\n type 'a t = 'a Size.sizer\n\n let pair = Size.bin_size_pair\n\n let cnv a_to_b _b_to_a b_sizer a = b_sizer (a_to_b a)\n\n let unit = Size.bin_size_unit\n end)\n\n module Write = Cata (struct\n type 'a t = 'a Write.writer\n\n let pair = Write.bin_write_pair\n\n let cnv a_to_b _b_to_a b_writer buf ~pos a = b_writer buf ~pos (a_to_b a)\n\n let unit = Write.bin_write_unit\n end)\n\n module Writer = Cata (struct\n type 'a t = 'a Type_class.writer\n\n let pair = Type_class.bin_writer_pair\n\n let cnv a_to_b _b_to_a b_writer = Type_class.cnv_writer a_to_b b_writer\n\n let unit = Type_class.bin_writer_unit\n end)\n\n module Reader = Cata (struct\n type 'a t = 'a Type_class.reader\n\n let pair = Type_class.bin_reader_pair\n\n let cnv _a_to_b b_to_a b_reader = Type_class.cnv_reader b_to_a b_reader\n\n let unit = Type_class.bin_reader_unit\n end)\n\n module Read = Cata (struct\n type 'a t = 'a Read.reader\n\n let pair = Read.bin_read_pair\n\n let cnv _a_to_b b_to_a b_reader buf ~pos_ref =\n b_to_a (b_reader buf ~pos_ref)\n\n let unit = Read.bin_read_unit\n end)\n\n let bin_shape_t sh = Shape.f N.n sh\n\n let bin_size_t sz = Size.f N.n sz\n\n let bin_write_t wr = Write.f N.n wr\n\n let bin_writer_t wr = Writer.f N.n wr\n\n let bin_t tc = Tc.f N.n tc\n\n let bin_reader_t re = Reader.f N.n re\n\n let bin_read_t re = Read.f N.n re\n\n let __bin_read_t__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"vector\" !pos_ref\n end\nend\n\ntype ('a, 'n) vec = ('a, 'n) t\n\nmodule With_length (N : Nat.Intf) = struct\n type 'a t = ('a, N.n) vec\n\n let compare c t1 t2 = Base.List.compare c (to_list t1) (to_list t2)\n\n let hash_fold_t f s v = List.hash_fold_t f s (to_list v)\n\n let equal f t1 t2 = List.equal f (to_list t1) (to_list t2)\n\n include Make.Yojson (N)\n include Make.Sexpable (N)\n\n let map (t : 'a t) = map t\n\n let of_list_exn : 'a list -> 'a t = fun ls -> of_list_and_length_exn ls N.n\n\n let to_list : 'a t -> 'a list = to_list\nend\n\nlet rec typ' :\n type f var value n.\n ((var, value, f) Snarky_backendless.Typ.t, n) t\n -> ((var, n) t, (value, n) t, f) Snarky_backendless.Typ.t =\n let open Snarky_backendless.Typ in\n fun elts ->\n match elts with\n | elt :: elts ->\n let tl = typ' elts in\n let there = function x :: xs -> (x, xs) in\n let back (x, xs) = x :: xs in\n transport (elt * tl) ~there ~back |> transport_var ~there ~back\n | [] ->\n let there [] = () in\n let back () = [] in\n transport (unit ()) ~there ~back |> transport_var ~there ~back\n\nlet typ elt n = typ' (init n ~f:(fun _ -> elt))\n\nlet rec append :\n type n m n_m a. (a, n) t -> (a, m) t -> (n, m, n_m) Nat.Adds.t -> (a, n_m) t\n =\n fun t1 t2 adds ->\n match (t1, adds) with\n | [], Z ->\n t2\n | x :: t1, S adds ->\n x :: append t1 t2 adds\n\n(* TODO: Make more efficient *)\nlet rev (type a n) (xs : (a, n) t) : (a, n) t =\n of_list_and_length_exn\n (fold ~init:[] ~f:(fun acc x -> List.cons x acc) xs)\n (length xs)\n\nlet rec _last : type a n. (a, n s) t -> a = function\n | [ x ] ->\n x\n | _ :: (_ :: _ as xs) ->\n _last xs\n\nlet rec split :\n type n m n_m a. (a, n_m) t -> (n, m, n_m) Nat.Adds.t -> (a, n) t * (a, m) t\n =\n fun t adds ->\n match (t, adds) with\n | [], Z ->\n ([], [])\n | _ :: _, Z ->\n ([], t)\n | x :: t1, S adds ->\n let xs, ys = split t1 adds in\n (x :: xs, ys)\n\nlet rec transpose : type a n m. ((a, n) t, m) t -> ((a, m) t, n) t =\n fun xss ->\n match xss with\n | [] ->\n failwith \"transpose: empty list\"\n | [] :: _ ->\n []\n | (_ :: _) :: _ ->\n let heads, tails = unzip (map xss ~f:(fun (x :: xs) -> (x, xs))) in\n heads :: transpose tails\n\nlet rec trim : type a n m. (a, m) t -> (n, m) Nat.Lte.t -> (a, n) t =\n fun v p -> match (v, p) with _, Z -> [] | x :: xs, S p -> x :: trim xs p\n\nlet trim_front (type a n m) (v : (a, m) t) (p : (n, m) Nat.Lte.t) : (a, n) t =\n rev (trim (rev v) p)\n\nlet extend_front_exn : type n m a. (a, n) t -> m Nat.t -> a -> (a, m) t =\n fun v m dummy ->\n let v = to_array v in\n let n = Array.length v in\n let m' = Nat.to_int m in\n assert (n <= m') ;\n let padding = m' - n in\n init m ~f:(fun i -> if i < padding then dummy else v.(i - padding))\n\nlet rec extend_exn : type n m a. (a, n) t -> m Nat.t -> a -> (a, m) t =\n fun v m default ->\n match (v, m) with\n | [], Z ->\n []\n | [], S n ->\n default :: extend_exn [] n default\n | _x :: _xs, Z ->\n failwith \"extend_exn: list too long\"\n | x :: xs, S m ->\n let extended = extend_exn xs m default in\n x :: extended\n\nlet rec extend :\n type a n m. (a, n) t -> (n, m) Nat.Lte.t -> m Nat.t -> a -> (a, m) t =\n fun v p m default ->\n match (v, p, m) with\n | _, Z, Z ->\n []\n | _, Z, S m ->\n default :: extend [] Z m default\n | x :: xs, S p, S m ->\n x :: extend xs p m default\n\nlet extend_front :\n type a n m. (a, n) t -> (n, m) Nat.Lte.t -> m Nat.t -> a -> (a, m) t =\n fun v _p m default -> extend_front_exn v m default\n\nmodule type S = sig\n type 'a t [@@deriving compare, yojson, sexp, hash, equal]\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val of_list_exn : 'a list -> 'a t\n\n val to_list : 'a t -> 'a list\nend\n\nmodule type VECTOR = sig\n type 'a t\n\n include S with type 'a t := 'a t\n\n module Stable : sig\n module V1 : sig\n include S with type 'a t = 'a t\n\n include Sigs.Binable.S1 with type 'a t = 'a t\n\n include Sigs.VERSIONED\n end\n end\nend\n\nmodule With_version (N : Nat.Intf) = struct\n module type S = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type 'a t = ('a, N.n) vec\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val of_list_exn : 'a list -> 'a t\n\n val to_list : 'a t -> 'a list\n end\nend\n\nmodule Vector_2 = struct\n module T = With_length (Nat.N2)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N2.n) vec\n\n include Make.Binable (Nat.N2)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_4 = struct\n module T = With_length (Nat.N4)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N4.n) vec\n\n include Make.Binable (Nat.N4)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_5 = struct\n module T = With_length (Nat.N5)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N5.n) vec\n\n include Make.Binable (Nat.N5)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_6 = struct\n module T = With_length (Nat.N6)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N6.n) vec\n\n include Make.Binable (Nat.N6)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_7 = struct\n module T = With_length (Nat.N7)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N7.n) vec\n\n include Make.Binable (Nat.N7)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_8 = struct\n module T = With_length (Nat.N8)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N8.n) vec\n\n include Make.Binable (Nat.N8)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_15 = struct\n module T = With_length (Nat.N15)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N15.n) vec\n\n include Make.Binable (Nat.N15)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n\nmodule Vector_16 = struct\n module T = With_length (Nat.N16)\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N16.n) vec\n\n include Make.Binable (Nat.N16)\n\n include (T : module type of T with type 'a t := 'a t)\n end\n end]\n\n include T\n\n let _type_equal : type a. (a t, a Stable.Latest.t) Type_equal.t = Type_equal.T\nend\n","(* Read_ml: reading values from the binary protocol using (mostly) OCaml. *)\n\n(* Note: the code is this file is carefully written to avoid unnecessary allocations. When\n touching this code, be sure to run the benchmarks to check for regressions. *)\n\nopen Bigarray\nopen Common\n\ntype 'a reader = buf -> pos_ref:pos_ref -> 'a\ntype ('a, 'b) reader1 = 'a reader -> 'b reader\ntype ('a, 'b, 'c) reader2 = 'a reader -> ('b, 'c) reader1\ntype ('a, 'b, 'c, 'd) reader3 = 'a reader -> ('b, 'c, 'd) reader2\n\nexternal unsafe_get : buf -> int -> char = \"%caml_ba_unsafe_ref_1\"\nexternal unsafe_get8 : buf -> int -> int = \"%caml_ba_unsafe_ref_1\"\n\nlet unsafe_get8_signed buf pos =\n let c = unsafe_get8 buf pos in\n if c >= 128 then c - 256 else c\n;;\n\n(*$ open Bin_prot_cinaps $*)\n\nlet arch_sixtyfour = Sys.word_size = 64\nlet arch_big_endian = Sys.big_endian\nlet max_int_int32 = if arch_sixtyfour then Int32.max_int else Int32.of_int max_int\nlet min_int_int32 = if arch_sixtyfour then Int32.max_int else Int32.of_int min_int\nlet max_int_int64 = Int64.of_int max_int\nlet min_int_int64 = Int64.of_int min_int\n\nlet safe_int_of_int32 pos x =\n if arch_sixtyfour\n then Int32.to_int x\n else if x >= min_int_int32 && x <= max_int_int32\n then Int32.to_int x\n else raise_read_error ReadError.Int_overflow pos\n;;\n\nlet safe_int_of_int64 pos x =\n if x >= min_int_int64 && x <= max_int_int64\n then Int64.to_int x\n else raise_read_error ReadError.Int_overflow pos\n;;\n\nlet safe_nativeint_of_int64 =\n if arch_sixtyfour\n then fun _pos x -> Int64.to_nativeint x\n else\n fun pos x ->\n if x >= Int64.of_nativeint Nativeint.min_int\n && x <= Int64.of_nativeint Nativeint.max_int\n then Int64.to_nativeint x\n else raise_read_error ReadError.Int_overflow pos\n;;\n\nexternal unsafe_get16 : buf -> int -> int = \"%caml_bigstring_get16u\"\nexternal unsafe_get32 : buf -> int -> int32 = \"%caml_bigstring_get32u\"\nexternal unsafe_get64 : buf -> int -> int64 = \"%caml_bigstring_get64u\"\nexternal bswap16 : int -> int = \"%bswap16\"\nexternal bswap32 : int32 -> int32 = \"%bswap_int32\"\nexternal bswap64 : int64 -> int64 = \"%bswap_int64\"\n\nlet unsafe_get16be_unsigned =\n if arch_big_endian\n then unsafe_get16\n else fun buf pos -> unsafe_get16 buf pos |> bswap16\n;;\n\nlet unsafe_get32be =\n if arch_big_endian\n then unsafe_get32\n else fun buf pos -> unsafe_get32 buf pos |> bswap32\n;;\n\nlet unsafe_get64be =\n if arch_big_endian\n then unsafe_get64\n else fun buf pos -> unsafe_get64 buf pos |> bswap64\n;;\n\nlet unsafe_get16le_unsigned =\n if arch_big_endian\n then fun buf pos -> unsafe_get16 buf pos |> bswap16\n else unsafe_get16\n;;\n\nlet unsafe_get32le =\n if arch_big_endian\n then fun buf pos -> unsafe_get32 buf pos |> bswap32\n else unsafe_get32\n;;\n\nlet unsafe_get64le =\n if arch_big_endian\n then fun buf pos -> unsafe_get64 buf pos |> bswap64\n else unsafe_get64\n;;\n\nlet unsafe_get16le_signed buf pos =\n let x = unsafe_get16le_unsigned buf pos in\n if x > 32767 then x - 65536 else x\n;;\n\nlet bin_read_unit buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n if unsafe_get buf pos = '\\000'\n then pos_ref := pos + 1\n else raise_read_error ReadError.Unit_code pos\n;;\n\nlet bin_read_bool buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\000' ->\n pos_ref := pos + 1;\n false\n | '\\001' ->\n pos_ref := pos + 1;\n true\n | _ -> raise_read_error ReadError.Bool_code pos\n;;\n\nlet safe_bin_read_neg_int8 buf ~pos_ref ~pos =\n let next = pos + 1 in\n check_next buf next;\n let n = unsafe_get8_signed buf pos in\n if n >= 0 then raise_read_error ReadError.Neg_int8 !pos_ref;\n pos_ref := next;\n n\n;;\n\nlet safe_bin_read_int16 buf ~pos_ref ~pos =\n let next = pos + 2 in\n check_next buf next;\n pos_ref := next;\n (* Can be above next line (no errors possible with 16bit).\n This should improve the generated code. *)\n unsafe_get16le_signed buf pos\n;;\n\nlet safe_bin_read_int32 buf ~pos_ref ~pos =\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n (* No error possible either. *)\n unsafe_get32le buf pos\n;;\n\nlet safe_bin_read_int64 buf ~pos_ref ~pos =\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n (* No error possible either. *)\n unsafe_get64le buf pos\n;;\n\nlet safe_bin_read_int32_as_int buf ~pos_ref ~pos =\n let next = pos + 4 in\n check_next buf next;\n let n = unsafe_get32le buf pos in\n let n = safe_int_of_int32 !pos_ref n in\n pos_ref := next;\n n\n;;\n\nlet safe_bin_read_int64_as_int buf ~pos_ref ~pos =\n let next = pos + 8 in\n check_next buf next;\n let n = unsafe_get64le buf pos in\n let n = safe_int_of_int64 !pos_ref n in\n pos_ref := next;\n n\n;;\n\nlet safe_bin_read_int32_as_int64 buf ~pos_ref ~pos =\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get32le buf pos in\n Int64.of_int32 n\n;;\n\nlet safe_bin_read_int32_as_nativeint buf ~pos_ref ~pos =\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get32le buf pos in\n Nativeint.of_int32 n\n;;\n\nlet safe_bin_read_int64_as_nativeint buf ~pos_ref ~pos =\n let next = pos + 8 in\n check_next buf next;\n let n = unsafe_get64le buf pos in\n let n = safe_nativeint_of_int64 pos n in\n pos_ref := next;\n n\n;;\n\nlet safe_bin_read_nat0_16 buf ~pos_ref ~pos =\n let next = pos + 2 in\n check_next buf next;\n pos_ref := next;\n Nat0.unsafe_of_int (unsafe_get16le_unsigned buf pos)\n;;\n\nlet safe_bin_read_nat0_32 =\n if arch_sixtyfour\n then (\n let mask_32bit = Int64.to_int 0xffff_ffffL in\n fun buf ~pos_ref ~pos ->\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n let n = Int32.to_int (unsafe_get32le buf pos) in\n if n >= 0\n then Nat0.unsafe_of_int n\n else\n (* Erase the upper bits that were set to 1 during the int32 -> int conversion. *)\n Nat0.unsafe_of_int (n land mask_32bit))\n else\n fun buf ~pos_ref ~pos ->\n let next = pos + 4 in\n check_next buf next;\n let n = unsafe_get32le buf pos in\n if n >= 0l && n <= max_int_int32\n then (\n let n = Nat0.unsafe_of_int (Int32.to_int n) in\n pos_ref := next;\n n)\n else raise_read_error ReadError.Nat0_overflow !pos_ref\n;;\n\nlet safe_bin_read_nat0_64 buf ~pos_ref ~pos =\n let next = pos + 8 in\n check_next buf next;\n let n = unsafe_get64le buf pos in\n if n >= 0L && n <= max_int_int64\n then (\n let n = Nat0.unsafe_of_int (Int64.to_int n) in\n pos_ref := next;\n n)\n else raise_read_error ReadError.Nat0_overflow !pos_ref\n;;\n\nlet bin_read_nat0 buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\x00'..'\\x7f' as ch ->\n pos_ref := pos + 1;\n Nat0.unsafe_of_int (Char.code ch)\n | (*$ Code.char INT16 *)'\\xfe'(*$*) ->\n safe_bin_read_nat0_16 buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT32 *)'\\xfd'(*$*) ->\n safe_bin_read_nat0_32 buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT64 *)'\\xfc'(*$*) ->\n if arch_sixtyfour then\n safe_bin_read_nat0_64 buf ~pos_ref ~pos:(pos + 1)\n else\n raise_read_error ReadError.Nat0_overflow pos\n | _ ->\n raise_read_error ReadError.Nat0_code pos\n[@@ocamlformat \"disable\"]\n\nlet bin_read_bytes buf ~pos_ref =\n let start_pos = !pos_ref in\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n if len > Sys.max_string_length\n then raise_read_error ReadError.String_too_long start_pos;\n let pos = !pos_ref in\n let next = pos + len in\n check_next buf next;\n pos_ref := next;\n let str = Bytes.create len in\n unsafe_blit_buf_bytes ~src_pos:pos buf ~dst_pos:0 str ~len;\n str\n;;\n\nlet bin_read_string buf ~pos_ref =\n let str = bin_read_bytes buf ~pos_ref in\n Bytes.unsafe_to_string str\n;;\n\nlet bin_read_char buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n pos_ref := pos + 1;\n unsafe_get buf pos\n;;\n\nlet bin_read_int buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\x00'..'\\x7f' as ch ->\n pos_ref := pos + 1;\n Char.code ch\n | (*$ Code.char NEG_INT8 *)'\\xff'(*$*) ->\n safe_bin_read_neg_int8 buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT16 *)'\\xfe'(*$*) ->\n safe_bin_read_int16 buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT32 *)'\\xfd'(*$*) ->\n safe_bin_read_int32_as_int buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT64 *)'\\xfc'(*$*) ->\n if arch_sixtyfour then\n safe_bin_read_int64_as_int buf ~pos_ref ~pos:(pos + 1)\n else\n raise_read_error ReadError.Int_overflow pos\n | _ ->\n raise_read_error ReadError.Int_code pos\n[@@ocamlformat \"disable\"]\n\nlet bin_read_float buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n (* No error possible either. *)\n Int64.float_of_bits (unsafe_get64le buf pos)\n;;\n\nlet bin_read_int32 buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\x00'..'\\x7f' as ch ->\n pos_ref := pos + 1;\n Int32.of_int (Char.code ch)\n | (*$ Code.char NEG_INT8 *)'\\xff'(*$*) ->\n Int32.of_int (safe_bin_read_neg_int8 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT16 *)'\\xfe'(*$*) ->\n Int32.of_int (safe_bin_read_int16 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT32 *)'\\xfd'(*$*) ->\n safe_bin_read_int32 buf ~pos_ref ~pos:(pos + 1)\n | _ ->\n raise_read_error ReadError.Int32_code pos\n[@@ocamlformat \"disable\"]\n\nlet bin_read_int64 buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\x00'..'\\x7f' as ch ->\n pos_ref := pos + 1;\n Int64.of_int (Char.code ch)\n | (*$ Code.char NEG_INT8 *)'\\xff'(*$*) ->\n Int64.of_int (safe_bin_read_neg_int8 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT16 *)'\\xfe'(*$*) ->\n Int64.of_int (safe_bin_read_int16 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT32 *)'\\xfd'(*$*) ->\n safe_bin_read_int32_as_int64 buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT64 *)'\\xfc'(*$*) ->\n safe_bin_read_int64 buf ~pos_ref ~pos:(pos + 1)\n | _ ->\n raise_read_error ReadError.Int64_code pos\n[@@ocamlformat \"disable\"]\n\nlet bin_read_nativeint buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\x00'..'\\x7f' as ch ->\n pos_ref := pos + 1;\n Nativeint.of_int (Char.code ch)\n | (*$ Code.char NEG_INT8 *)'\\xff'(*$*) ->\n Nativeint.of_int (safe_bin_read_neg_int8 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT16 *)'\\xfe'(*$*) ->\n Nativeint.of_int (safe_bin_read_int16 buf ~pos_ref ~pos:(pos + 1))\n | (*$ Code.char INT32 *)'\\xfd'(*$*) ->\n safe_bin_read_int32_as_nativeint buf ~pos_ref ~pos:(pos + 1)\n | (*$ Code.char INT64 *)'\\xfc'(*$*) when arch_sixtyfour ->\n safe_bin_read_int64_as_nativeint buf ~pos_ref ~pos:(pos + 1)\n | _ ->\n raise_read_error ReadError.Nativeint_code pos\n[@@ocamlformat \"disable\"]\n\nlet bin_read_ref bin_read_el buf ~pos_ref =\n let el = bin_read_el buf ~pos_ref in\n ref el\n;;\n\nlet bin_read_lazy bin_read_el buf ~pos_ref =\n let el = bin_read_el buf ~pos_ref in\n Lazy.from_val el\n;;\n\nlet bin_read_option bin_read_el buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n match unsafe_get buf pos with\n | '\\000' ->\n pos_ref := pos + 1;\n None\n | '\\001' ->\n pos_ref := pos + 1;\n let el = bin_read_el buf ~pos_ref in\n Some el\n | _ -> raise_read_error ReadError.Option_code pos\n;;\n\nlet bin_read_pair bin_read_a bin_read_b buf ~pos_ref =\n let a = bin_read_a buf ~pos_ref in\n let b = bin_read_b buf ~pos_ref in\n a, b\n;;\n\nlet bin_read_triple bin_read_a bin_read_b bin_read_c buf ~pos_ref =\n let a = bin_read_a buf ~pos_ref in\n let b = bin_read_b buf ~pos_ref in\n let c = bin_read_c buf ~pos_ref in\n a, b, c\n;;\n\nlet bin_read_n_rev_list bin_read_el buf ~pos_ref len =\n let rec loop n acc =\n if n = 0 then acc else loop (n - 1) (bin_read_el buf ~pos_ref :: acc)\n in\n loop len []\n;;\n\nlet bin_read_list_with_max_len ~max_len bin_read_el buf ~pos_ref =\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n if len > max_len then raise_read_error (List_too_long { len; max_len }) !pos_ref;\n let rev_lst = bin_read_n_rev_list bin_read_el buf ~pos_ref len in\n List.rev rev_lst\n;;\n\nlet bin_read_list bin_read_el buf ~pos_ref =\n bin_read_list_with_max_len ~max_len:max_int bin_read_el buf ~pos_ref\n;;\n\nlet dummy_float_buf = create_buf 8\nlet () = ignore (Write.bin_write_float dummy_float_buf ~pos:0 3.1)\n\nlet max_float_array_length =\n if arch_sixtyfour then Sys.max_array_length else Sys.max_array_length / 2\n;;\n\nlet bin_read_float_array buf ~pos_ref =\n let pos = !pos_ref in\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n if len > max_float_array_length then raise_read_error ReadError.Array_too_long pos;\n let size = len * 8 in\n let pos = !pos_ref in\n let next = pos + size in\n check_next buf next;\n let arr = Array.create_float len in\n unsafe_blit_buf_float_array buf arr ~src_pos:pos ~dst_pos:0 ~len;\n pos_ref := next;\n arr\n;;\n\nlet bin_read_array (type a) bin_read_el buf ~pos_ref =\n if (Obj.magic (bin_read_el : a reader) : float reader) == bin_read_float\n then (Obj.magic (bin_read_float_array buf ~pos_ref : float array) : a array)\n else (\n let start_pos = !pos_ref in\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n if len = 0\n then [||]\n else (\n if arch_sixtyfour\n then (\n if len > Sys.max_array_length\n then raise_read_error ReadError.Array_too_long start_pos)\n else if len > Sys.max_array_length / 2\n then (\n let maybe_float =\n try\n let el = bin_read_el dummy_float_buf ~pos_ref:(ref 0) in\n Some el\n with\n | _ -> None\n in\n match maybe_float with\n | None ->\n if len > Sys.max_array_length\n then raise_read_error ReadError.Array_too_long start_pos\n | Some el ->\n if Obj.tag (Obj.repr el) = Obj.double_tag || len > Sys.max_array_length\n then raise_read_error ReadError.Array_too_long start_pos);\n let first = bin_read_el buf ~pos_ref in\n let res = Array.make len first in\n for i = 1 to len - 1 do\n let el = bin_read_el buf ~pos_ref in\n Array.unsafe_set res i el\n done;\n res))\n;;\n\nlet bin_read_hashtbl bin_read_key bin_read_val buf ~pos_ref =\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n let htbl = Hashtbl.create len in\n let read_kv_pair = bin_read_pair bin_read_key bin_read_val in\n let els = bin_read_n_rev_list read_kv_pair buf ~pos_ref len in\n copy_htbl_list htbl els\n;;\n\nexternal buf_of_vec32 : vec32 -> buf = \"%identity\"\nexternal buf_of_vec64 : vec64 -> buf = \"%identity\"\nexternal buf_of_mat32 : mat32 -> buf = \"%identity\"\nexternal buf_of_mat64 : mat64 -> buf = \"%identity\"\n\nlet bin_read_float32_vec buf ~pos_ref =\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n let size = len * 4 in\n let pos = !pos_ref in\n let next = pos + size in\n check_next buf next;\n let vec = Array1.create float32 fortran_layout len in\n unsafe_blit_buf ~src:buf ~src_pos:pos ~dst:(buf_of_vec32 vec) ~dst_pos:0 ~len:size;\n pos_ref := next;\n vec\n;;\n\nlet bin_read_float64_vec buf ~pos_ref =\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n let size = len * 8 in\n let pos = !pos_ref in\n let next = pos + size in\n check_next buf next;\n let vec = Array1.create float64 fortran_layout len in\n unsafe_blit_buf ~src:buf ~src_pos:pos ~dst:(buf_of_vec64 vec) ~dst_pos:0 ~len:size;\n pos_ref := next;\n vec\n;;\n\nlet bin_read_vec = bin_read_float64_vec\n\nlet bin_read_float32_mat buf ~pos_ref =\n let len1 = (bin_read_nat0 buf ~pos_ref :> int) in\n let len2 = (bin_read_nat0 buf ~pos_ref :> int) in\n let size = len1 * len2 * 4 in\n let pos = !pos_ref in\n let next = pos + size in\n check_next buf next;\n let mat = Array2.create float32 fortran_layout len1 len2 in\n unsafe_blit_buf ~src:buf ~src_pos:pos ~dst:(buf_of_mat32 mat) ~dst_pos:0 ~len:size;\n pos_ref := next;\n mat\n;;\n\nlet bin_read_float64_mat buf ~pos_ref =\n let len1 = (bin_read_nat0 buf ~pos_ref :> int) in\n let len2 = (bin_read_nat0 buf ~pos_ref :> int) in\n let size = len1 * len2 * 8 in\n let pos = !pos_ref in\n let next = pos + size in\n check_next buf next;\n let mat = Array2.create float64 fortran_layout len1 len2 in\n unsafe_blit_buf ~src:buf ~src_pos:pos ~dst:(buf_of_mat64 mat) ~dst_pos:0 ~len:size;\n pos_ref := next;\n mat\n;;\n\nlet bin_read_mat = bin_read_float64_mat\n\nlet bin_read_bigstring buf ~pos_ref =\n let len = (bin_read_nat0 buf ~pos_ref :> int) in\n let pos = !pos_ref in\n let next = pos + len in\n check_next buf next;\n let str = create_buf len in\n unsafe_blit_buf ~src:buf ~src_pos:pos ~dst:str ~dst_pos:0 ~len;\n pos_ref := next;\n str\n;;\n\nlet bin_read_variant_int buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n let n = unsafe_get32le buf pos in\n (* [n] must contain an integer already encoded, i.e. [n = 2 * k + 1]. *)\n if Int32.logand n 1l = 0l\n then raise (Read_error (ReadError.Variant_tag, pos))\n else (\n (* We shift it by one bit to the right se we get back [2 * k + 1] in the end. *)\n pos_ref := next;\n Int32.to_int (Int32.shift_right n 1))\n;;\n\nlet bin_read_int_8bit buf ~pos_ref =\n let pos = safe_get_pos buf pos_ref in\n assert_pos pos;\n pos_ref := pos + 1;\n unsafe_get8 buf pos\n;;\n\nlet bin_read_int_16bit buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 2 in\n check_next buf next;\n pos_ref := next;\n unsafe_get16le_unsigned buf pos\n;;\n\nlet bin_read_int_32bit buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get32le buf pos in\n safe_int_of_int32 pos n\n;;\n\nlet bin_read_int_64bit buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get64le buf pos in\n safe_int_of_int64 pos n\n;;\n\nlet bin_read_int64_bits buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n unsafe_get64le buf pos\n;;\n\nlet bin_read_network16_int buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 2 in\n check_next buf next;\n pos_ref := next;\n unsafe_get16be_unsigned buf pos\n;;\n\nlet bin_read_network32_int buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get32be buf pos in\n safe_int_of_int32 pos n\n;;\n\nlet bin_read_network32_int32 buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 4 in\n check_next buf next;\n pos_ref := next;\n unsafe_get32be buf pos\n;;\n\nlet bin_read_network64_int buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n let n = unsafe_get64be buf pos in\n safe_int_of_int64 pos n\n;;\n\nlet bin_read_network64_int64 buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 8 in\n check_next buf next;\n pos_ref := next;\n unsafe_get64be buf pos\n;;\n\n[%%if\n ocaml_version < (4, 07, 0)]\n\nexternal unsafe_bytes_set32 : bytes -> int -> int32 -> unit = \"%caml_string_set32u\"\nexternal unsafe_bytes_set64 : bytes -> int -> int64 -> unit = \"%caml_string_set64u\"\n\n[%%else]\n\nexternal unsafe_bytes_set32 : bytes -> int -> int32 -> unit = \"%caml_bytes_set32u\"\nexternal unsafe_bytes_set64 : bytes -> int -> int64 -> unit = \"%caml_bytes_set64u\"\n\n[%%endif]\n\nlet bin_read_md5 buf ~pos_ref =\n let pos = !pos_ref in\n assert_pos pos;\n let next = pos + 16 in\n check_next buf next;\n pos_ref := next;\n let res = Bytes.create 16 in\n if arch_sixtyfour\n then (\n let a = unsafe_get64 buf pos in\n let b = unsafe_get64 buf (pos + 8) in\n unsafe_bytes_set64 res 0 a;\n unsafe_bytes_set64 res 8 b)\n else (\n let a = unsafe_get32 buf pos in\n let b = unsafe_get32 buf (pos + 4) in\n let c = unsafe_get32 buf (pos + 8) in\n let d = unsafe_get32 buf (pos + 12) in\n unsafe_bytes_set32 res 0 a;\n unsafe_bytes_set32 res 4 b;\n unsafe_bytes_set32 res 8 c;\n unsafe_bytes_set32 res 12 d);\n Md5_lib.unsafe_of_binary (Bytes.unsafe_to_string res)\n;;\n","include Bin_shape_lib.Std.Shape\n\n(* new base shapes *)\nlet bin_shape_unit = basetype (Uuid.of_string \"unit\") []\nlet bin_shape_bool = basetype (Uuid.of_string \"bool\") []\nlet bin_shape_string = basetype (Uuid.of_string \"string\") []\nlet bin_shape_bytes = basetype (Uuid.of_string \"bytes\") []\nlet bin_shape_char = basetype (Uuid.of_string \"char\") []\nlet bin_shape_float = basetype (Uuid.of_string \"float\") []\nlet bin_shape_int = basetype (Uuid.of_string \"int\") []\nlet bin_shape_int32 = basetype (Uuid.of_string \"int32\") []\nlet bin_shape_int63 = basetype (Uuid.of_string \"int63\") []\nlet bin_shape_int64 = basetype (Uuid.of_string \"int64\") []\nlet bin_shape_nativeint = basetype (Uuid.of_string \"nativeint\") []\nlet bin_shape_nat0 = basetype (Uuid.of_string \"nat0\") []\nlet bin_shape_digest = basetype (Uuid.of_string \"digest\") []\nlet bin_shape_float32_vec = basetype (Uuid.of_string \"float32_vec\") []\nlet bin_shape_float64_vec = basetype (Uuid.of_string \"float64_vec\") []\nlet bin_shape_vec = basetype (Uuid.of_string \"vec\") []\nlet bin_shape_float32_mat = basetype (Uuid.of_string \"float32_mat\") []\nlet bin_shape_float64_mat = basetype (Uuid.of_string \"float64_mat\") []\nlet bin_shape_mat = basetype (Uuid.of_string \"mat\") []\nlet bin_shape_bigstring = basetype (Uuid.of_string \"bigstring\") []\nlet bin_shape_variant_int = basetype (Uuid.of_string \"variant_int\") []\nlet bin_shape_int_8bit = basetype (Uuid.of_string \"int_8bit\") []\nlet bin_shape_int_16bit = basetype (Uuid.of_string \"int_16bit\") []\nlet bin_shape_int_32bit = basetype (Uuid.of_string \"int_32bit\") []\nlet bin_shape_int_64bit = basetype (Uuid.of_string \"int_64bit\") []\nlet bin_shape_int64_bits = basetype (Uuid.of_string \"int64_bits\") []\nlet bin_shape_network16_int = basetype (Uuid.of_string \"network16_int\") []\nlet bin_shape_network32_int = basetype (Uuid.of_string \"network32_int\") []\nlet bin_shape_network32_int32 = basetype (Uuid.of_string \"network32_int32\") []\nlet bin_shape_network64_int = basetype (Uuid.of_string \"network64_int\") []\nlet bin_shape_network64_int64 = basetype (Uuid.of_string \"network64_int64\") []\n\n(* new shape constructors *)\nlet bin_shape_ref x = basetype (Uuid.of_string \"ref\") [ x ]\nlet bin_shape_option x = basetype (Uuid.of_string \"option\") [ x ]\nlet bin_shape_list x = basetype (Uuid.of_string \"list\") [ x ]\nlet bin_shape_array x = basetype (Uuid.of_string \"array\") [ x ]\nlet bin_shape_hashtbl x y = basetype (Uuid.of_string \"hashtbl\") [ x; y ]\n\n(* shape alias *)\nlet bin_shape_float_array = bin_shape_array bin_shape_float\n\n(* shape-constructor aliases *)\nlet bin_shape_lazy x = x\nlet bin_shape_pair x y = tuple [ x; y ]\nlet bin_shape_triple x y z = tuple [ x; y; z ]\n","(* Size: compute size of values in the binary protocol. *)\n\nopen Bigarray\n\nlet arch_sixtyfour = Sys.word_size = 64\n\nopen Common\n\nmodule Maximum = struct\n let bin_size_unit = 1\n let bin_size_bool = 1\n let bin_size_char = 1\n let bin_size_md5 = 16\n let bin_size_int_nat0 = if arch_sixtyfour then 9 else 5\n let bin_size_int_negative = if arch_sixtyfour then 9 else 5\n let bin_size_int = max bin_size_int_nat0 bin_size_int_negative\n let bin_size_float = 8\n let bin_size_int32 = 5\n let bin_size_int64 = 9\n let bin_size_nativeint = bin_size_int\n let bin_size_nat0 = bin_size_int_nat0\n let bin_size_variant_int = 4\n let bin_size_int_8bit = 1\n let bin_size_int_16bit = 2\n let bin_size_int_32bit = 4\n let bin_size_int_64bit = 8\n let bin_size_int64_bits = 8\n let bin_size_network16_int = 2\n let bin_size_network32_int = 4\n let bin_size_network32_int32 = 4\n let bin_size_network64_int = 8\n let bin_size_network64_int64 = 8\nend\n\nmodule Minimum = struct\n let bin_size_unit = Maximum.bin_size_unit\n let bin_size_bool = Maximum.bin_size_bool\n let bin_size_char = Maximum.bin_size_char\n let bin_size_md5 = 16\n let bin_size_int_nat0 = 1\n let bin_size_int_negative = 2\n let bin_size_int = min bin_size_int_nat0 bin_size_int_negative\n let bin_size_float = Maximum.bin_size_float\n let bin_size_int32 = bin_size_int\n let bin_size_int64 = bin_size_int\n let bin_size_nativeint = bin_size_int\n let bin_size_nat0 = 1\n let bin_size_ref = 1\n let bin_size_lazy_t = 1\n let bin_size_option = 1\n let bin_size_pair = 1 + 1\n let bin_size_triple = 1 + 1 + 1\n let bin_size_len = bin_size_nat0\n let bin_size_list = bin_size_len\n let bin_size_array = bin_size_len\n let bin_size_hashtbl = bin_size_len\n let bin_size_string = bin_size_len\n let bin_size_bytes = bin_size_len\n let bin_size_vec = bin_size_len\n let bin_size_float32_vec = bin_size_vec\n let bin_size_float64_vec = bin_size_vec\n let bin_size_mat = bin_size_len + bin_size_len\n let bin_size_float32_mat = bin_size_mat\n let bin_size_float64_mat = bin_size_mat\n let bin_size_bigstring = bin_size_len\n let bin_size_float_array = bin_size_len\n let bin_size_variant_int = Maximum.bin_size_variant_int\n let bin_size_int_8bit = Maximum.bin_size_int_8bit\n let bin_size_int_16bit = Maximum.bin_size_int_16bit\n let bin_size_int_32bit = Maximum.bin_size_int_32bit\n let bin_size_int_64bit = Maximum.bin_size_int_64bit\n let bin_size_int64_bits = Maximum.bin_size_int64_bits\n let bin_size_network16_int = Maximum.bin_size_network16_int\n let bin_size_network32_int = Maximum.bin_size_network32_int\n let bin_size_network32_int32 = Maximum.bin_size_network32_int32\n let bin_size_network64_int = Maximum.bin_size_network64_int\n let bin_size_network64_int64 = Maximum.bin_size_network64_int64\nend\n\ntype 'a sizer = 'a -> int\ntype ('a, 'b) sizer1 = 'a sizer -> 'b sizer\ntype ('a, 'b, 'c) sizer2 = 'a sizer -> ('b, 'c) sizer1\ntype ('a, 'b, 'c, 'd) sizer3 = 'a sizer -> ('b, 'c, 'd) sizer2\n\nlet bin_size_unit () = 1\nlet bin_size_bool _ = 1\n\nlet bin_size_int_nat0 n =\n if n < 0x00000080\n then 1\n else if n < 0x00008000\n then 3\n else if arch_sixtyfour && n >= (* 0x80000000 *) 1 lsl 31\n then 9\n else 5\n;;\n\nlet bin_size_int_negative n =\n if n >= -0x00000080\n then 2\n else if n >= -0x00008000\n then 3\n else if arch_sixtyfour && n < (* -0x80000000 *) -(1 lsl 31)\n then 9\n else 5\n;;\n\nlet bin_size_char _ = 1\nlet bin_size_int n = if n >= 0 then bin_size_int_nat0 n else bin_size_int_negative n\n\nlet bin_size_nat0 nat0 =\n let n = (nat0 : Nat0.t :> int) in\n if n < 0x00000080\n then 1\n else if n < 0x00010000\n then 3\n else if arch_sixtyfour && n >= (* 0x100000000 *) 1 lsl 32\n then 9\n else 5\n;;\n\nlet bin_size_string_or_bytes len =\n let plen = Nat0.unsafe_of_int len in\n let size_len = bin_size_nat0 plen in\n size_len + len\n;;\n\nlet bin_size_string str = bin_size_string_or_bytes (String.length str)\nlet bin_size_bytes str = bin_size_string_or_bytes (Bytes.length str)\nlet bin_size_md5 _ = 16\n\nlet bin_size_float f =\n (* If we just ignore the argument the compiler will still require it to exist and be\n boxed. This means that if for instance we call this for a field of a float record,\n the compiler will allocate the float for nothing.\n\n With this line the compiler really ignores the float. *)\n ignore (truncate f);\n 8\n;;\n\nlet bin_size_int32 =\n if arch_sixtyfour\n then fun n -> bin_size_int (Int32.to_int n)\n else\n fun n ->\n if n >= 0x00008000l || n < -0x00008000l then 5 else bin_size_int (Int32.to_int n)\n;;\n\nlet bin_size_int64 =\n if arch_sixtyfour\n then\n fun n ->\n if n >= 0x80000000L || n < -0x80000000L then 9 else bin_size_int (Int64.to_int n)\n else\n fun n ->\n if n >= 0x80000000L || n < -0x80000000L then 9 else bin_size_int32 (Int64.to_int32 n)\n;;\n\nlet bin_size_nativeint =\n if arch_sixtyfour\n then fun n -> bin_size_int64 (Int64.of_nativeint n)\n else fun n -> bin_size_int32 (Nativeint.to_int32 n)\n;;\n\nlet bin_size_ref bin_size_el r = bin_size_el !r\nlet bin_size_lazy_t bin_size_el lv = bin_size_el (Lazy.force lv)\nlet bin_size_lazy = bin_size_lazy_t\n\nlet bin_size_option bin_size_el = function\n | None -> 1\n | Some v -> 1 + bin_size_el v\n;;\n\nlet bin_size_pair bin_size_a bin_size_b (a, b) = bin_size_a a + bin_size_b b\n\nlet bin_size_triple bin_size_a bin_size_b bin_size_c (a, b, c) =\n bin_size_a a + bin_size_b b + bin_size_c c\n;;\n\nlet bin_size_list bin_size_el lst =\n let rec loop len = function\n | [] -> len\n | h :: t -> loop (len + bin_size_el h) t\n in\n let len = Nat0.unsafe_of_int (List.length lst) in\n let size_len = bin_size_nat0 len in\n loop size_len lst\n;;\n\nlet bin_size_len len =\n let plen = Nat0.unsafe_of_int len in\n bin_size_nat0 plen\n;;\n\nlet bin_size_float_array ar =\n let len = Array.length ar in\n bin_size_len len + (8 * len)\n;;\n\nlet bin_size_array_loop bin_size_el ar ~total_len ~n =\n let total_len_ref = ref total_len in\n for i = 0 to n - 1 do\n let el = Array.unsafe_get ar i in\n total_len_ref := !total_len_ref + bin_size_el el\n done;\n !total_len_ref\n;;\n\nlet bin_size_array (type a) bin_size_el ar =\n if (Obj.magic (bin_size_el : a sizer) : float sizer) == bin_size_float\n then bin_size_float_array (Obj.magic (ar : a array) : float array)\n else (\n let n = Array.length ar in\n let total_len = bin_size_len n in\n bin_size_array_loop bin_size_el ar ~total_len ~n)\n;;\n\nlet bin_size_hashtbl bin_size_key bin_size_val htbl =\n let cnt_ref = ref 0 in\n let coll_htbl k v total_len =\n incr cnt_ref;\n total_len + bin_size_key k + bin_size_val v\n in\n let len = Hashtbl.length htbl in\n let total_len = Hashtbl.fold coll_htbl htbl (bin_size_len len) in\n if !cnt_ref <> len then raise_concurrent_modification \"bin_size_hashtbl\";\n total_len\n;;\n\nlet bin_size_gen_vec vec multiplier =\n let len = Array1.dim vec in\n bin_size_len len + (multiplier * len)\n;;\n\nlet bin_size_float32_vec vec = bin_size_gen_vec vec 4\nlet bin_size_float64_vec vec = bin_size_gen_vec vec 8\nlet bin_size_vec = bin_size_float64_vec\n\nlet bin_size_gen_mat mat multiplier =\n let dim1 = Array2.dim1 mat in\n let dim2 = Array2.dim2 mat in\n let size = dim1 * dim2 in\n bin_size_len dim1 + bin_size_len dim2 + (multiplier * size)\n;;\n\nlet bin_size_float32_mat mat = bin_size_gen_mat mat 4\nlet bin_size_float64_mat mat = bin_size_gen_mat mat 8\nlet bin_size_mat = bin_size_float64_mat\nlet bin_size_bigstring buf = bin_size_gen_vec buf 1\nlet bin_size_variant_int _ = 4\nlet bin_size_int_8bit _ = 1\nlet bin_size_int_16bit _ = 2\nlet bin_size_int_32bit _ = 4\nlet bin_size_int_64bit _ = 8\nlet bin_size_int64_bits _ = 8\nlet bin_size_network16_int _ = 2\nlet bin_size_network32_int _ = 4\nlet bin_size_network32_int32 _ = 4\nlet bin_size_network64_int _ = 8\nlet bin_size_network64_int64 _ = 8\n\nlet bin_size_array_no_length bin_size_el ar =\n bin_size_array_loop bin_size_el ar ~total_len:0 ~n:(Array.length ar)\n;;\n","(* Tp_class: sizers, writers, and readers in records *)\n\ntype 'a writer =\n { size : 'a Size.sizer\n ; write : 'a Write.writer\n }\n\ntype 'a reader =\n { read : 'a Read.reader\n ; vtag_read : (int -> 'a) Read.reader\n }\n\ntype 'a t =\n { shape : Shape.t\n ; writer : 'a writer\n ; reader : 'a reader\n }\n\ntype 'a writer0 = 'a writer\ntype 'a reader0 = 'a reader\ntype 'a t0 = 'a t\n\nmodule S1 = struct\n type ('a, 'b) writer = 'a writer0 -> 'b writer0\n type ('a, 'b) reader = 'a reader0 -> 'b reader0\n type ('a, 'b) t = 'a t0 -> 'b t0\nend\n\nmodule S2 = struct\n type ('a, 'b, 'c) writer = 'a writer0 -> ('b, 'c) S1.writer\n type ('a, 'b, 'c) reader = 'a reader0 -> ('b, 'c) S1.reader\n type ('a, 'b, 'c) t = 'a t0 -> ('b, 'c) S1.t\nend\n\nmodule S3 = struct\n type ('a, 'b, 'c, 'd) writer = 'a writer0 -> ('b, 'c, 'd) S2.writer\n type ('a, 'b, 'c, 'd) reader = 'a reader0 -> ('b, 'c, 'd) S2.reader\n type ('a, 'b, 'c, 'd) t = 'a t0 -> ('b, 'c, 'd) S2.t\nend\n\nlet variant_wrong_type name _buf ~pos_ref _x =\n Common.raise_variant_wrong_type name !pos_ref\n;;\n\n(*$ open Bin_prot_cinaps.Str *)\n(*$ mk_base \"unit\" *)\nlet bin_writer_unit = { size = Size.bin_size_unit; write = Write.bin_write_unit }\n\nlet bin_reader_unit =\n { read = Read.bin_read_unit; vtag_read = variant_wrong_type \"unit\" }\n;;\n\nlet bin_shape_unit = Shape.bin_shape_unit\n\nlet bin_unit =\n { shape = bin_shape_unit; writer = bin_writer_unit; reader = bin_reader_unit }\n;;\n\n(*$ mk_base \"bool\" *)\nlet bin_writer_bool = { size = Size.bin_size_bool; write = Write.bin_write_bool }\n\nlet bin_reader_bool =\n { read = Read.bin_read_bool; vtag_read = variant_wrong_type \"bool\" }\n;;\n\nlet bin_shape_bool = Shape.bin_shape_bool\n\nlet bin_bool =\n { shape = bin_shape_bool; writer = bin_writer_bool; reader = bin_reader_bool }\n;;\n\n(*$ mk_base \"string\" *)\nlet bin_writer_string = { size = Size.bin_size_string; write = Write.bin_write_string }\n\nlet bin_reader_string =\n { read = Read.bin_read_string; vtag_read = variant_wrong_type \"string\" }\n;;\n\nlet bin_shape_string = Shape.bin_shape_string\n\nlet bin_string =\n { shape = bin_shape_string; writer = bin_writer_string; reader = bin_reader_string }\n;;\n\n(*$ mk_base \"bytes\" *)\nlet bin_writer_bytes = { size = Size.bin_size_bytes; write = Write.bin_write_bytes }\n\nlet bin_reader_bytes =\n { read = Read.bin_read_bytes; vtag_read = variant_wrong_type \"bytes\" }\n;;\n\nlet bin_shape_bytes = Shape.bin_shape_bytes\n\nlet bin_bytes =\n { shape = bin_shape_bytes; writer = bin_writer_bytes; reader = bin_reader_bytes }\n;;\n\n(*$ mk_base \"char\" *)\nlet bin_writer_char = { size = Size.bin_size_char; write = Write.bin_write_char }\n\nlet bin_reader_char =\n { read = Read.bin_read_char; vtag_read = variant_wrong_type \"char\" }\n;;\n\nlet bin_shape_char = Shape.bin_shape_char\n\nlet bin_char =\n { shape = bin_shape_char; writer = bin_writer_char; reader = bin_reader_char }\n;;\n\n(*$ mk_base \"int\" *)\nlet bin_writer_int = { size = Size.bin_size_int; write = Write.bin_write_int }\nlet bin_reader_int = { read = Read.bin_read_int; vtag_read = variant_wrong_type \"int\" }\nlet bin_shape_int = Shape.bin_shape_int\nlet bin_int = { shape = bin_shape_int; writer = bin_writer_int; reader = bin_reader_int }\n\n(*$ mk_base \"float\" *)\nlet bin_writer_float = { size = Size.bin_size_float; write = Write.bin_write_float }\n\nlet bin_reader_float =\n { read = Read.bin_read_float; vtag_read = variant_wrong_type \"float\" }\n;;\n\nlet bin_shape_float = Shape.bin_shape_float\n\nlet bin_float =\n { shape = bin_shape_float; writer = bin_writer_float; reader = bin_reader_float }\n;;\n\n(*$ mk_base \"int32\" *)\nlet bin_writer_int32 = { size = Size.bin_size_int32; write = Write.bin_write_int32 }\n\nlet bin_reader_int32 =\n { read = Read.bin_read_int32; vtag_read = variant_wrong_type \"int32\" }\n;;\n\nlet bin_shape_int32 = Shape.bin_shape_int32\n\nlet bin_int32 =\n { shape = bin_shape_int32; writer = bin_writer_int32; reader = bin_reader_int32 }\n;;\n\n(*$ mk_base \"int64\" *)\nlet bin_writer_int64 = { size = Size.bin_size_int64; write = Write.bin_write_int64 }\n\nlet bin_reader_int64 =\n { read = Read.bin_read_int64; vtag_read = variant_wrong_type \"int64\" }\n;;\n\nlet bin_shape_int64 = Shape.bin_shape_int64\n\nlet bin_int64 =\n { shape = bin_shape_int64; writer = bin_writer_int64; reader = bin_reader_int64 }\n;;\n\n(*$ mk_base \"nativeint\" *)\nlet bin_writer_nativeint =\n { size = Size.bin_size_nativeint; write = Write.bin_write_nativeint }\n;;\n\nlet bin_reader_nativeint =\n { read = Read.bin_read_nativeint; vtag_read = variant_wrong_type \"nativeint\" }\n;;\n\nlet bin_shape_nativeint = Shape.bin_shape_nativeint\n\nlet bin_nativeint =\n { shape = bin_shape_nativeint\n ; writer = bin_writer_nativeint\n ; reader = bin_reader_nativeint\n }\n;;\n\n(*$ mk_base \"nat0\" *)\nlet bin_writer_nat0 = { size = Size.bin_size_nat0; write = Write.bin_write_nat0 }\n\nlet bin_reader_nat0 =\n { read = Read.bin_read_nat0; vtag_read = variant_wrong_type \"nat0\" }\n;;\n\nlet bin_shape_nat0 = Shape.bin_shape_nat0\n\nlet bin_nat0 =\n { shape = bin_shape_nat0; writer = bin_writer_nat0; reader = bin_reader_nat0 }\n;;\n\n(*$ mk_base1 \"ref\" *)\nlet bin_writer_ref bin_writer_el =\n { size = (fun v -> Size.bin_size_ref bin_writer_el.size v)\n ; write = (fun buf ~pos v -> Write.bin_write_ref bin_writer_el.write buf ~pos v)\n }\n;;\n\nlet bin_reader_ref bin_reader_el =\n { read = (fun buf ~pos_ref -> Read.bin_read_ref bin_reader_el.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"ref\"\n }\n;;\n\nlet bin_shape_ref x1 = Shape.bin_shape_ref x1\n\nlet bin_ref bin_el =\n { shape = bin_shape_ref bin_el.shape\n ; writer = bin_writer_ref bin_el.writer\n ; reader = bin_reader_ref bin_el.reader\n }\n;;\n\n(*$ mk_base1 \"lazy\" *)\nlet bin_writer_lazy bin_writer_el =\n { size = (fun v -> Size.bin_size_lazy bin_writer_el.size v)\n ; write = (fun buf ~pos v -> Write.bin_write_lazy bin_writer_el.write buf ~pos v)\n }\n;;\n\nlet bin_reader_lazy bin_reader_el =\n { read = (fun buf ~pos_ref -> Read.bin_read_lazy bin_reader_el.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"lazy\"\n }\n;;\n\nlet bin_shape_lazy x1 = Shape.bin_shape_lazy x1\n\nlet bin_lazy bin_el =\n { shape = bin_shape_lazy bin_el.shape\n ; writer = bin_writer_lazy bin_el.writer\n ; reader = bin_reader_lazy bin_el.reader\n }\n;;\n\n(*$ mk_base1 \"option\" *)\nlet bin_writer_option bin_writer_el =\n { size = (fun v -> Size.bin_size_option bin_writer_el.size v)\n ; write = (fun buf ~pos v -> Write.bin_write_option bin_writer_el.write buf ~pos v)\n }\n;;\n\nlet bin_reader_option bin_reader_el =\n { read = (fun buf ~pos_ref -> Read.bin_read_option bin_reader_el.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"option\"\n }\n;;\n\nlet bin_shape_option x1 = Shape.bin_shape_option x1\n\nlet bin_option bin_el =\n { shape = bin_shape_option bin_el.shape\n ; writer = bin_writer_option bin_el.writer\n ; reader = bin_reader_option bin_el.reader\n }\n;;\n\n(*$ mk_base2 \"pair\" *)\nlet bin_writer_pair bin_writer_el1 bin_writer_el2 =\n { size = (fun v -> Size.bin_size_pair bin_writer_el1.size bin_writer_el2.size v)\n ; write =\n (fun buf ~pos v ->\n Write.bin_write_pair bin_writer_el1.write bin_writer_el2.write buf ~pos v)\n }\n;;\n\nlet bin_reader_pair bin_reader_el1 bin_reader_el2 =\n { read =\n (fun buf ~pos_ref ->\n Read.bin_read_pair bin_reader_el1.read bin_reader_el2.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"pair\"\n }\n;;\n\nlet bin_shape_pair x1 x2 = Shape.bin_shape_pair x1 x2\n\nlet bin_pair bin_el1 bin_el2 =\n { shape = bin_shape_pair bin_el1.shape bin_el2.shape\n ; writer = bin_writer_pair bin_el1.writer bin_el2.writer\n ; reader = bin_reader_pair bin_el1.reader bin_el2.reader\n }\n;;\n\n(*$ mk_base3 \"triple\" *)\nlet bin_writer_triple bin_writer_el1 bin_writer_el2 bin_writer_el3 =\n { size =\n (fun v ->\n Size.bin_size_triple\n bin_writer_el1.size\n bin_writer_el2.size\n bin_writer_el3.size\n v)\n ; write =\n (fun buf ~pos v ->\n Write.bin_write_triple\n bin_writer_el1.write\n bin_writer_el2.write\n bin_writer_el3.write\n buf\n ~pos\n v)\n }\n;;\n\nlet bin_reader_triple bin_reader_el1 bin_reader_el2 bin_reader_el3 =\n { read =\n (fun buf ~pos_ref ->\n Read.bin_read_triple\n bin_reader_el1.read\n bin_reader_el2.read\n bin_reader_el3.read\n buf\n ~pos_ref)\n ; vtag_read = variant_wrong_type \"triple\"\n }\n;;\n\nlet bin_shape_triple x1 x2 x3 = Shape.bin_shape_triple x1 x2 x3\n\nlet bin_triple bin_el1 bin_el2 bin_el3 =\n { shape = bin_shape_triple bin_el1.shape bin_el2.shape bin_el3.shape\n ; writer = bin_writer_triple bin_el1.writer bin_el2.writer bin_el3.writer\n ; reader = bin_reader_triple bin_el1.reader bin_el2.reader bin_el3.reader\n }\n;;\n\n(*$ mk_base1 \"list\" *)\nlet bin_writer_list bin_writer_el =\n { size = (fun v -> Size.bin_size_list bin_writer_el.size v)\n ; write = (fun buf ~pos v -> Write.bin_write_list bin_writer_el.write buf ~pos v)\n }\n;;\n\nlet bin_reader_list bin_reader_el =\n { read = (fun buf ~pos_ref -> Read.bin_read_list bin_reader_el.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"list\"\n }\n;;\n\nlet bin_shape_list x1 = Shape.bin_shape_list x1\n\nlet bin_list bin_el =\n { shape = bin_shape_list bin_el.shape\n ; writer = bin_writer_list bin_el.writer\n ; reader = bin_reader_list bin_el.reader\n }\n;;\n\n(*$ mk_base1 \"array\" *)\nlet bin_writer_array bin_writer_el =\n { size = (fun v -> Size.bin_size_array bin_writer_el.size v)\n ; write = (fun buf ~pos v -> Write.bin_write_array bin_writer_el.write buf ~pos v)\n }\n;;\n\nlet bin_reader_array bin_reader_el =\n { read = (fun buf ~pos_ref -> Read.bin_read_array bin_reader_el.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"array\"\n }\n;;\n\nlet bin_shape_array x1 = Shape.bin_shape_array x1\n\nlet bin_array bin_el =\n { shape = bin_shape_array bin_el.shape\n ; writer = bin_writer_array bin_el.writer\n ; reader = bin_reader_array bin_el.reader\n }\n;;\n\n(*$ mk_base2 \"hashtbl\" *)\nlet bin_writer_hashtbl bin_writer_el1 bin_writer_el2 =\n { size = (fun v -> Size.bin_size_hashtbl bin_writer_el1.size bin_writer_el2.size v)\n ; write =\n (fun buf ~pos v ->\n Write.bin_write_hashtbl bin_writer_el1.write bin_writer_el2.write buf ~pos v)\n }\n;;\n\nlet bin_reader_hashtbl bin_reader_el1 bin_reader_el2 =\n { read =\n (fun buf ~pos_ref ->\n Read.bin_read_hashtbl bin_reader_el1.read bin_reader_el2.read buf ~pos_ref)\n ; vtag_read = variant_wrong_type \"hashtbl\"\n }\n;;\n\nlet bin_shape_hashtbl x1 x2 = Shape.bin_shape_hashtbl x1 x2\n\nlet bin_hashtbl bin_el1 bin_el2 =\n { shape = bin_shape_hashtbl bin_el1.shape bin_el2.shape\n ; writer = bin_writer_hashtbl bin_el1.writer bin_el2.writer\n ; reader = bin_reader_hashtbl bin_el1.reader bin_el2.reader\n }\n;;\n\n(*$ mk_base \"float32_vec\" *)\nlet bin_writer_float32_vec =\n { size = Size.bin_size_float32_vec; write = Write.bin_write_float32_vec }\n;;\n\nlet bin_reader_float32_vec =\n { read = Read.bin_read_float32_vec; vtag_read = variant_wrong_type \"float32_vec\" }\n;;\n\nlet bin_shape_float32_vec = Shape.bin_shape_float32_vec\n\nlet bin_float32_vec =\n { shape = bin_shape_float32_vec\n ; writer = bin_writer_float32_vec\n ; reader = bin_reader_float32_vec\n }\n;;\n\n(*$ mk_base \"float64_vec\" *)\nlet bin_writer_float64_vec =\n { size = Size.bin_size_float64_vec; write = Write.bin_write_float64_vec }\n;;\n\nlet bin_reader_float64_vec =\n { read = Read.bin_read_float64_vec; vtag_read = variant_wrong_type \"float64_vec\" }\n;;\n\nlet bin_shape_float64_vec = Shape.bin_shape_float64_vec\n\nlet bin_float64_vec =\n { shape = bin_shape_float64_vec\n ; writer = bin_writer_float64_vec\n ; reader = bin_reader_float64_vec\n }\n;;\n\n(*$ mk_base \"vec\" *)\nlet bin_writer_vec = { size = Size.bin_size_vec; write = Write.bin_write_vec }\nlet bin_reader_vec = { read = Read.bin_read_vec; vtag_read = variant_wrong_type \"vec\" }\nlet bin_shape_vec = Shape.bin_shape_vec\nlet bin_vec = { shape = bin_shape_vec; writer = bin_writer_vec; reader = bin_reader_vec }\n\n(*$ mk_base \"float32_mat\" *)\nlet bin_writer_float32_mat =\n { size = Size.bin_size_float32_mat; write = Write.bin_write_float32_mat }\n;;\n\nlet bin_reader_float32_mat =\n { read = Read.bin_read_float32_mat; vtag_read = variant_wrong_type \"float32_mat\" }\n;;\n\nlet bin_shape_float32_mat = Shape.bin_shape_float32_mat\n\nlet bin_float32_mat =\n { shape = bin_shape_float32_mat\n ; writer = bin_writer_float32_mat\n ; reader = bin_reader_float32_mat\n }\n;;\n\n(*$ mk_base \"float64_mat\" *)\nlet bin_writer_float64_mat =\n { size = Size.bin_size_float64_mat; write = Write.bin_write_float64_mat }\n;;\n\nlet bin_reader_float64_mat =\n { read = Read.bin_read_float64_mat; vtag_read = variant_wrong_type \"float64_mat\" }\n;;\n\nlet bin_shape_float64_mat = Shape.bin_shape_float64_mat\n\nlet bin_float64_mat =\n { shape = bin_shape_float64_mat\n ; writer = bin_writer_float64_mat\n ; reader = bin_reader_float64_mat\n }\n;;\n\n(*$ mk_base \"mat\" *)\nlet bin_writer_mat = { size = Size.bin_size_mat; write = Write.bin_write_mat }\nlet bin_reader_mat = { read = Read.bin_read_mat; vtag_read = variant_wrong_type \"mat\" }\nlet bin_shape_mat = Shape.bin_shape_mat\nlet bin_mat = { shape = bin_shape_mat; writer = bin_writer_mat; reader = bin_reader_mat }\n\n(*$ mk_base \"bigstring\" *)\nlet bin_writer_bigstring =\n { size = Size.bin_size_bigstring; write = Write.bin_write_bigstring }\n;;\n\nlet bin_reader_bigstring =\n { read = Read.bin_read_bigstring; vtag_read = variant_wrong_type \"bigstring\" }\n;;\n\nlet bin_shape_bigstring = Shape.bin_shape_bigstring\n\nlet bin_bigstring =\n { shape = bin_shape_bigstring\n ; writer = bin_writer_bigstring\n ; reader = bin_reader_bigstring\n }\n;;\n\n(*$*)\ntype float_array = float array\n\n(*$ mk_base \"float_array\" *)\nlet bin_writer_float_array =\n { size = Size.bin_size_float_array; write = Write.bin_write_float_array }\n;;\n\nlet bin_reader_float_array =\n { read = Read.bin_read_float_array; vtag_read = variant_wrong_type \"float_array\" }\n;;\n\nlet bin_shape_float_array = Shape.bin_shape_float_array\n\nlet bin_float_array =\n { shape = bin_shape_float_array\n ; writer = bin_writer_float_array\n ; reader = bin_reader_float_array\n }\n;;\n\n(*$ mk_base \"variant_int\" *)\nlet bin_writer_variant_int =\n { size = Size.bin_size_variant_int; write = Write.bin_write_variant_int }\n;;\n\nlet bin_reader_variant_int =\n { read = Read.bin_read_variant_int; vtag_read = variant_wrong_type \"variant_int\" }\n;;\n\nlet bin_shape_variant_int = Shape.bin_shape_variant_int\n\nlet bin_variant_int =\n { shape = bin_shape_variant_int\n ; writer = bin_writer_variant_int\n ; reader = bin_reader_variant_int\n }\n;;\n\n(*$ mk_base \"int_8bit\" *)\nlet bin_writer_int_8bit =\n { size = Size.bin_size_int_8bit; write = Write.bin_write_int_8bit }\n;;\n\nlet bin_reader_int_8bit =\n { read = Read.bin_read_int_8bit; vtag_read = variant_wrong_type \"int_8bit\" }\n;;\n\nlet bin_shape_int_8bit = Shape.bin_shape_int_8bit\n\nlet bin_int_8bit =\n { shape = bin_shape_int_8bit\n ; writer = bin_writer_int_8bit\n ; reader = bin_reader_int_8bit\n }\n;;\n\n(*$ mk_base \"int_16bit\" *)\nlet bin_writer_int_16bit =\n { size = Size.bin_size_int_16bit; write = Write.bin_write_int_16bit }\n;;\n\nlet bin_reader_int_16bit =\n { read = Read.bin_read_int_16bit; vtag_read = variant_wrong_type \"int_16bit\" }\n;;\n\nlet bin_shape_int_16bit = Shape.bin_shape_int_16bit\n\nlet bin_int_16bit =\n { shape = bin_shape_int_16bit\n ; writer = bin_writer_int_16bit\n ; reader = bin_reader_int_16bit\n }\n;;\n\n(*$ mk_base \"int_32bit\" *)\nlet bin_writer_int_32bit =\n { size = Size.bin_size_int_32bit; write = Write.bin_write_int_32bit }\n;;\n\nlet bin_reader_int_32bit =\n { read = Read.bin_read_int_32bit; vtag_read = variant_wrong_type \"int_32bit\" }\n;;\n\nlet bin_shape_int_32bit = Shape.bin_shape_int_32bit\n\nlet bin_int_32bit =\n { shape = bin_shape_int_32bit\n ; writer = bin_writer_int_32bit\n ; reader = bin_reader_int_32bit\n }\n;;\n\n(*$ mk_base \"int_64bit\" *)\nlet bin_writer_int_64bit =\n { size = Size.bin_size_int_64bit; write = Write.bin_write_int_64bit }\n;;\n\nlet bin_reader_int_64bit =\n { read = Read.bin_read_int_64bit; vtag_read = variant_wrong_type \"int_64bit\" }\n;;\n\nlet bin_shape_int_64bit = Shape.bin_shape_int_64bit\n\nlet bin_int_64bit =\n { shape = bin_shape_int_64bit\n ; writer = bin_writer_int_64bit\n ; reader = bin_reader_int_64bit\n }\n;;\n\n(*$ mk_base \"int64_bits\" *)\nlet bin_writer_int64_bits =\n { size = Size.bin_size_int64_bits; write = Write.bin_write_int64_bits }\n;;\n\nlet bin_reader_int64_bits =\n { read = Read.bin_read_int64_bits; vtag_read = variant_wrong_type \"int64_bits\" }\n;;\n\nlet bin_shape_int64_bits = Shape.bin_shape_int64_bits\n\nlet bin_int64_bits =\n { shape = bin_shape_int64_bits\n ; writer = bin_writer_int64_bits\n ; reader = bin_reader_int64_bits\n }\n;;\n\n(*$ mk_base \"network16_int\" *)\nlet bin_writer_network16_int =\n { size = Size.bin_size_network16_int; write = Write.bin_write_network16_int }\n;;\n\nlet bin_reader_network16_int =\n { read = Read.bin_read_network16_int; vtag_read = variant_wrong_type \"network16_int\" }\n;;\n\nlet bin_shape_network16_int = Shape.bin_shape_network16_int\n\nlet bin_network16_int =\n { shape = bin_shape_network16_int\n ; writer = bin_writer_network16_int\n ; reader = bin_reader_network16_int\n }\n;;\n\n(*$ mk_base \"network32_int\" *)\nlet bin_writer_network32_int =\n { size = Size.bin_size_network32_int; write = Write.bin_write_network32_int }\n;;\n\nlet bin_reader_network32_int =\n { read = Read.bin_read_network32_int; vtag_read = variant_wrong_type \"network32_int\" }\n;;\n\nlet bin_shape_network32_int = Shape.bin_shape_network32_int\n\nlet bin_network32_int =\n { shape = bin_shape_network32_int\n ; writer = bin_writer_network32_int\n ; reader = bin_reader_network32_int\n }\n;;\n\n(*$ mk_base \"network32_int32\" *)\nlet bin_writer_network32_int32 =\n { size = Size.bin_size_network32_int32; write = Write.bin_write_network32_int32 }\n;;\n\nlet bin_reader_network32_int32 =\n { read = Read.bin_read_network32_int32\n ; vtag_read = variant_wrong_type \"network32_int32\"\n }\n;;\n\nlet bin_shape_network32_int32 = Shape.bin_shape_network32_int32\n\nlet bin_network32_int32 =\n { shape = bin_shape_network32_int32\n ; writer = bin_writer_network32_int32\n ; reader = bin_reader_network32_int32\n }\n;;\n\n(*$ mk_base \"network64_int\" *)\nlet bin_writer_network64_int =\n { size = Size.bin_size_network64_int; write = Write.bin_write_network64_int }\n;;\n\nlet bin_reader_network64_int =\n { read = Read.bin_read_network64_int; vtag_read = variant_wrong_type \"network64_int\" }\n;;\n\nlet bin_shape_network64_int = Shape.bin_shape_network64_int\n\nlet bin_network64_int =\n { shape = bin_shape_network64_int\n ; writer = bin_writer_network64_int\n ; reader = bin_reader_network64_int\n }\n;;\n\n(*$ mk_base \"network64_int64\" *)\nlet bin_writer_network64_int64 =\n { size = Size.bin_size_network64_int64; write = Write.bin_write_network64_int64 }\n;;\n\nlet bin_reader_network64_int64 =\n { read = Read.bin_read_network64_int64\n ; vtag_read = variant_wrong_type \"network64_int64\"\n }\n;;\n\nlet bin_shape_network64_int64 = Shape.bin_shape_network64_int64\n\nlet bin_network64_int64 =\n { shape = bin_shape_network64_int64\n ; writer = bin_writer_network64_int64\n ; reader = bin_reader_network64_int64\n }\n;;\n\n(*$*)\nlet bin_writer_array_no_length bin_writer_el =\n { size =\n (fun v -> (Size.bin_size_array_no_length [@warning \"-3\"]) bin_writer_el.size v)\n ; write =\n (fun buf ~pos v ->\n (Write.bin_write_array_no_length [@warning \"-3\"]) bin_writer_el.write buf ~pos v)\n }\n;;\n\n(* Conversion of binable types *)\n\nlet cnv_writer cnv tp_class =\n { size = (fun v -> tp_class.size (cnv v))\n ; write = (fun buf ~pos v -> tp_class.write buf ~pos (cnv v))\n }\n;;\n\nlet cnv_reader cnv tp_class =\n { read = (fun buf ~pos_ref -> cnv (tp_class.read buf ~pos_ref))\n ; vtag_read = (fun buf ~pos_ref vtag -> cnv (tp_class.vtag_read buf ~pos_ref vtag))\n }\n;;\n\nlet cnv for_shape for_writer for_reader tp_class =\n { shape = for_shape tp_class.shape\n ; writer = cnv_writer for_writer tp_class.writer\n ; reader = cnv_reader for_reader tp_class.reader\n }\n;;\n","(* Utils: utility functions for user convenience *)\n\nopen Common\nopen Size\nopen Type_class\ninclude Utils_intf\n\nlet size_header_length = 8\nlet bin_write_size_header = Write.bin_write_int_64bit\nlet bin_read_size_header = Read.bin_read_int_64bit\n\nlet bin_dump ?(header = false) writer v =\n let buf, pos, pos_len =\n let v_len = writer.size v in\n if header\n then (\n let tot_len = v_len + size_header_length in\n let buf = create_buf tot_len in\n let pos = bin_write_size_header buf ~pos:0 v_len in\n buf, pos, pos + v_len)\n else (\n let buf = create_buf v_len in\n buf, 0, v_len)\n in\n let pos = writer.write buf ~pos v in\n if pos = pos_len\n then buf\n else failwith \"Bin_prot.Utils.bin_dump: size changed during writing\"\n;;\n\n(* Reading from streams *)\n\nlet bin_read_stream ?max_size ~read reader =\n let buf = create_buf size_header_length in\n read buf ~pos:0 ~len:size_header_length;\n let pos_ref = ref 0 in\n let len = bin_read_size_header buf ~pos_ref in\n match max_size with\n | Some max_size when len > max_size ->\n failwith\n (Printf.sprintf\n \"Bin_prot.Utils.bin_read_stream: size exceeds max_size: %d > %d\"\n len\n max_size)\n | _ ->\n let buf = if len > size_header_length then create_buf len else buf in\n read buf ~pos:0 ~len;\n pos_ref := 0;\n let res = reader.read buf ~pos_ref in\n if !pos_ref = len\n then res\n else (\n let msg =\n Printf.sprintf\n \"Bin_prot.Utils.bin_read_stream: protocol lied about length of value: \\\n expected %d, received %d\"\n len\n !pos_ref\n in\n failwith msg)\n;;\n\n(* Conversion of binable types *)\n\nmodule Of_minimal (S : Binable.Minimal.S) : Binable.S with type t := S.t = struct\n include S\n\n let bin_writer_t = { size = bin_size_t; write = bin_write_t }\n let bin_reader_t = { read = bin_read_t; vtag_read = __bin_read_t__ }\n let bin_t = { shape = bin_shape_t; writer = bin_writer_t; reader = bin_reader_t }\nend\n\nlet maybe_annotate_shape maybe_uuid shape =\n match maybe_uuid with\n | None -> shape\n | Some uuid -> Shape.annotate uuid shape\n;;\n\nmodule Make_binable_gen (S : sig\n include Make_binable_without_uuid_spec\n\n val maybe_caller_identity : Shape.Uuid.t option\n end) =\nstruct\n include Of_minimal (struct\n module B = S.Binable\n\n type t = S.t\n\n let bin_shape_t = maybe_annotate_shape S.maybe_caller_identity B.bin_shape_t\n let bin_size_t t = B.bin_size_t (S.to_binable t)\n let bin_write_t buf ~pos t = B.bin_write_t buf ~pos (S.to_binable t)\n let bin_read_t buf ~pos_ref = S.of_binable (B.bin_read_t buf ~pos_ref)\n let __bin_read_t__ buf ~pos_ref n = S.of_binable (B.__bin_read_t__ buf ~pos_ref n)\n end)\nend\n\nmodule Make_binable1_gen (S : sig\n include Make_binable1_without_uuid_spec\n\n val maybe_caller_identity : Shape.Uuid.t option\n end) =\nstruct\n module B = S.Binable\n\n let bin_shape_t bin_shape_el =\n maybe_annotate_shape S.maybe_caller_identity (B.bin_shape_t bin_shape_el)\n ;;\n\n let bin_size_t bin_size_el t = B.bin_size_t bin_size_el (S.to_binable t)\n\n let bin_write_t bin_write_el buf ~pos t =\n B.bin_write_t bin_write_el buf ~pos (S.to_binable t)\n ;;\n\n let bin_read_t bin_read_el buf ~pos_ref =\n S.of_binable (B.bin_read_t bin_read_el buf ~pos_ref)\n ;;\n\n let __bin_read_t__ bin_read_el buf ~pos_ref n =\n S.of_binable (B.__bin_read_t__ bin_read_el buf ~pos_ref n)\n ;;\n\n let bin_writer_t bin_writer =\n { size = (fun v -> bin_size_t bin_writer.size v)\n ; write = (fun buf ~pos v -> bin_write_t bin_writer.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader =\n { read = (fun buf ~pos_ref -> bin_read_t bin_reader.read buf ~pos_ref)\n ; vtag_read =\n (fun _buf ~pos_ref _n ->\n raise_variant_wrong_type \"Bin_prot.Utils.Make_binable1.bin_reader_t\" !pos_ref)\n }\n ;;\n\n let bin_t type_class =\n { shape = bin_shape_t type_class.shape\n ; writer = bin_writer_t type_class.writer\n ; reader = bin_reader_t type_class.reader\n }\n ;;\nend\n\nmodule Make_binable2_gen (S : sig\n include Make_binable2_without_uuid_spec\n\n val maybe_caller_identity : Shape.Uuid.t option\n end) =\nstruct\n module B = S.Binable\n\n let bin_shape_t bin_shape_el1 bin_shape_el2 =\n maybe_annotate_shape\n S.maybe_caller_identity\n (B.bin_shape_t bin_shape_el1 bin_shape_el2)\n ;;\n\n let bin_size_t bin_size_el1 bin_size_el2 t =\n B.bin_size_t bin_size_el1 bin_size_el2 (S.to_binable t)\n ;;\n\n let bin_write_t bin_write_el1 bin_write_el2 buf ~pos t =\n B.bin_write_t bin_write_el1 bin_write_el2 buf ~pos (S.to_binable t)\n ;;\n\n let bin_read_t bin_read_el1 bin_read_el2 buf ~pos_ref =\n S.of_binable (B.bin_read_t bin_read_el1 bin_read_el2 buf ~pos_ref)\n ;;\n\n let __bin_read_t__ bin_read_el1 bin_read_el2 buf ~pos_ref n =\n S.of_binable (B.__bin_read_t__ bin_read_el1 bin_read_el2 buf ~pos_ref n)\n ;;\n\n let bin_writer_t bin_writer1 bin_writer2 =\n { size = (fun v -> bin_size_t bin_writer1.size bin_writer2.size v)\n ; write =\n (fun buf ~pos v -> bin_write_t bin_writer1.write bin_writer2.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader1 bin_reader2 =\n { read =\n (fun buf ~pos_ref -> bin_read_t bin_reader1.read bin_reader2.read buf ~pos_ref)\n ; vtag_read =\n (fun _buf ~pos_ref _n ->\n raise_variant_wrong_type \"Bin_prot.Utils.Make_binable2.bin_reader_t\" !pos_ref)\n }\n ;;\n\n let bin_t type_class1 type_class2 =\n { shape = bin_shape_t type_class1.shape type_class2.shape\n ; writer = bin_writer_t type_class1.writer type_class2.writer\n ; reader = bin_reader_t type_class1.reader type_class2.reader\n }\n ;;\nend\n\nmodule Make_binable3_gen (S : sig\n include Make_binable3_without_uuid_spec\n\n val maybe_caller_identity : Shape.Uuid.t option\n end) =\nstruct\n module B = S.Binable\n\n let bin_shape_t bin_shape_el1 bin_shape_el2 bin_shape_el3 =\n maybe_annotate_shape\n S.maybe_caller_identity\n (B.bin_shape_t bin_shape_el1 bin_shape_el2 bin_shape_el3)\n ;;\n\n let bin_size_t bin_size_el1 bin_size_el2 bin_size_el3 t =\n B.bin_size_t bin_size_el1 bin_size_el2 bin_size_el3 (S.to_binable t)\n ;;\n\n let bin_write_t bin_write_el1 bin_write_el2 bin_write_el3 buf ~pos t =\n B.bin_write_t bin_write_el1 bin_write_el2 bin_write_el3 buf ~pos (S.to_binable t)\n ;;\n\n let bin_read_t bin_read_el1 bin_read_el2 bin_read_el3 buf ~pos_ref =\n S.of_binable (B.bin_read_t bin_read_el1 bin_read_el2 bin_read_el3 buf ~pos_ref)\n ;;\n\n let __bin_read_t__ bin_read_el1 bin_read_el2 bin_read_el3 buf ~pos_ref n =\n S.of_binable (B.__bin_read_t__ bin_read_el1 bin_read_el2 bin_read_el3 buf ~pos_ref n)\n ;;\n\n let bin_writer_t bin_writer1 bin_writer2 bin_writer3 =\n { size = (fun v -> bin_size_t bin_writer1.size bin_writer2.size bin_writer3.size v)\n ; write =\n (fun buf ~pos v ->\n bin_write_t bin_writer1.write bin_writer2.write bin_writer3.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader1 bin_reader2 bin_reader3 =\n { read =\n (fun buf ~pos_ref ->\n bin_read_t bin_reader1.read bin_reader2.read bin_reader3.read buf ~pos_ref)\n ; vtag_read =\n (fun _buf ~pos_ref _n ->\n raise_variant_wrong_type \"Bin_prot.Utils.Make_binable3.bin_reader_t\" !pos_ref)\n }\n ;;\n\n let bin_t type_class1 type_class2 type_class3 =\n { shape = bin_shape_t type_class1.shape type_class2.shape type_class3.shape\n ; writer = bin_writer_t type_class1.writer type_class2.writer type_class3.writer\n ; reader = bin_reader_t type_class1.reader type_class2.reader type_class3.reader\n }\n ;;\nend\n\nmodule Make_binable_with_uuid (S : Make_binable_with_uuid_spec) =\n Make_binable_gen (struct\n include S\n\n let maybe_caller_identity = Some S.caller_identity\n end)\n\nmodule Make_binable1_with_uuid (S : Make_binable1_with_uuid_spec) =\n Make_binable1_gen (struct\n include S\n\n let maybe_caller_identity = Some S.caller_identity\n end)\n\nmodule Make_binable2_with_uuid (S : Make_binable2_with_uuid_spec) =\n Make_binable2_gen (struct\n include S\n\n let maybe_caller_identity = Some S.caller_identity\n end)\n\nmodule Make_binable3_with_uuid (S : Make_binable3_with_uuid_spec) =\n Make_binable3_gen (struct\n include S\n\n let maybe_caller_identity = Some S.caller_identity\n end)\n\nmodule Make_binable_without_uuid (S : Make_binable_without_uuid_spec) =\n Make_binable_gen (struct\n include S\n\n let maybe_caller_identity = None\n end)\n\nmodule Make_binable1_without_uuid (S : Make_binable1_without_uuid_spec) =\n Make_binable1_gen (struct\n include S\n\n let maybe_caller_identity = None\n end)\n\nmodule Make_binable2_without_uuid (S : Make_binable2_without_uuid_spec) =\n Make_binable2_gen (struct\n include S\n\n let maybe_caller_identity = None\n end)\n\nmodule Make_binable3_without_uuid (S : Make_binable3_without_uuid_spec) =\n Make_binable3_gen (struct\n include S\n\n let maybe_caller_identity = None\n end)\n\nmodule Make_binable = Make_binable_without_uuid\nmodule Make_binable1 = Make_binable1_without_uuid\nmodule Make_binable2 = Make_binable2_without_uuid\nmodule Make_binable3 = Make_binable3_without_uuid\n\nlet with_module_name f ~module_name function_name =\n match module_name with\n | None -> f function_name\n | Some module_name -> Printf.ksprintf f \"%s.%s\" module_name function_name\n;;\n\nlet raise_concurrent_modification = with_module_name raise_concurrent_modification\n\nlet raise_read_too_much =\n with_module_name\n (Printf.ksprintf failwith \"%s: tried to read more elements than available\")\n;;\n\nlet raise_read_not_enough =\n with_module_name (Printf.ksprintf failwith \"%s: didn't read all elements\")\n;;\n\nmodule Make_iterable_binable (S : Make_iterable_binable_spec) = struct\n open S\n\n let bin_shape_t =\n Shape.(\n basetype\n caller_identity\n [ basetype\n (Uuid.of_string \"6592371a-4994-11e6-923a-7748e4182764\")\n [ S.bin_shape_el ]\n ])\n ;;\n\n let bin_size_t t =\n let size_ref = ref 0 in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n size_ref := !size_ref + bin_size_el el;\n incr cnt_ref);\n let len = length t in\n if !cnt_ref = len\n then bin_size_nat0 (Nat0.unsafe_of_int len) + !size_ref\n else raise_concurrent_modification ~module_name \"bin_size_t\"\n ;;\n\n let bin_write_t buf ~pos t =\n let len = length t in\n let plen = Nat0.unsafe_of_int len in\n let pos_ref = ref (Write.bin_write_nat0 buf ~pos plen) in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n pos_ref := bin_write_el buf ~pos:!pos_ref el;\n incr cnt_ref);\n if !cnt_ref = len\n then !pos_ref\n else raise_concurrent_modification ~module_name \"bin_write_t\"\n ;;\n\n let bin_read_t buf ~pos_ref =\n let len = (Read.bin_read_nat0 buf ~pos_ref :> int) in\n let idx = ref 0 in\n let next () =\n if !idx >= len then raise_read_too_much ~module_name \"bin_read_t\";\n incr idx;\n bin_read_el buf ~pos_ref\n in\n let result = init ~len ~next in\n if !idx < len then raise_read_not_enough ~module_name \"bin_read_t\";\n result\n ;;\n\n let __bin_read_t__ _buf ~pos_ref _n = raise_variant_wrong_type \"t\" !pos_ref\n let bin_writer_t = { size = bin_size_t; write = bin_write_t }\n let bin_reader_t = { read = bin_read_t; vtag_read = __bin_read_t__ }\n let bin_t = { shape = bin_shape_t; writer = bin_writer_t; reader = bin_reader_t }\nend\n\nmodule Make_iterable_binable1 (S : Make_iterable_binable1_spec) = struct\n open S\n\n let bin_shape_t t =\n Shape.(\n basetype\n caller_identity\n [ basetype\n (Uuid.of_string \"ac8a9ff4-4994-11e6-9a1b-9fb4e933bd9d\")\n [ S.bin_shape_el t ]\n ])\n ;;\n\n let bin_size_t bin_size_a t =\n let size_ref = ref 0 in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n size_ref := !size_ref + bin_size_el bin_size_a el;\n incr cnt_ref);\n let len = length t in\n if !cnt_ref = len\n then bin_size_nat0 (Nat0.unsafe_of_int len) + !size_ref\n else raise_concurrent_modification ~module_name \"bin_size_t\"\n ;;\n\n let bin_write_t bin_write_a buf ~pos t =\n let len = length t in\n let plen = Nat0.unsafe_of_int len in\n let pos_ref = ref (Write.bin_write_nat0 buf ~pos plen) in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n pos_ref := bin_write_el bin_write_a buf ~pos:!pos_ref el;\n incr cnt_ref);\n if !cnt_ref = len\n then !pos_ref\n else raise_concurrent_modification ~module_name \"bin_write_t\"\n ;;\n\n let bin_read_t bin_read_a buf ~pos_ref =\n let len = (Read.bin_read_nat0 buf ~pos_ref :> int) in\n let idx = ref 0 in\n let next () =\n if !idx >= len then raise_read_too_much ~module_name \"bin_read_t\";\n incr idx;\n bin_read_el bin_read_a buf ~pos_ref\n in\n let result = init ~len ~next in\n if !idx < len then raise_read_not_enough ~module_name \"bin_read_t\";\n result\n ;;\n\n let __bin_read_t__ _bin_read_a _buf ~pos_ref _n = raise_variant_wrong_type \"t\" !pos_ref\n\n let bin_writer_t bin_writer =\n { size = (fun v -> bin_size_t bin_writer.size v)\n ; write = (fun buf ~pos v -> bin_write_t bin_writer.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader =\n { read = (fun buf ~pos_ref -> bin_read_t bin_reader.read buf ~pos_ref)\n ; vtag_read = (fun buf ~pos_ref _n -> __bin_read_t__ bin_reader.read buf ~pos_ref _n)\n }\n ;;\n\n let bin_t type_class =\n { shape = bin_shape_t type_class.shape\n ; writer = bin_writer_t type_class.writer\n ; reader = bin_reader_t type_class.reader\n }\n ;;\nend\n\nmodule Make_iterable_binable2 (S : Make_iterable_binable2_spec) = struct\n open S\n\n let bin_shape_t t1 t2 =\n Shape.(\n basetype\n caller_identity\n [ basetype\n (Uuid.of_string \"b4e54ad2-4994-11e6-b8df-87c2997f9f52\")\n [ S.bin_shape_el t1 t2 ]\n ])\n ;;\n\n let bin_size_t bin_size_a bin_size_b t =\n let size_ref = ref 0 in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n size_ref := !size_ref + bin_size_el bin_size_a bin_size_b el;\n incr cnt_ref);\n let len = length t in\n if !cnt_ref = len\n then bin_size_nat0 (Nat0.unsafe_of_int len) + !size_ref\n else raise_concurrent_modification ~module_name \"bin_size_t\"\n ;;\n\n let bin_write_t bin_write_a bin_write_b buf ~pos t =\n let len = length t in\n let plen = Nat0.unsafe_of_int len in\n let pos_ref = ref (Write.bin_write_nat0 buf ~pos plen) in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n pos_ref := bin_write_el bin_write_a bin_write_b buf ~pos:!pos_ref el;\n incr cnt_ref);\n if !cnt_ref = len\n then !pos_ref\n else raise_concurrent_modification ~module_name \"bin_write_t\"\n ;;\n\n let bin_read_t bin_read_a bin_read_b buf ~pos_ref =\n let len = (Read.bin_read_nat0 buf ~pos_ref :> int) in\n let idx = ref 0 in\n let next () =\n if !idx >= len then raise_read_too_much ~module_name \"bin_read_t\";\n incr idx;\n bin_read_el bin_read_a bin_read_b buf ~pos_ref\n in\n let result = init ~len ~next in\n if !idx < len then raise_read_not_enough ~module_name \"bin_read_t\";\n result\n ;;\n\n let __bin_read_t__ _bin_read_a _bin_read_b _buf ~pos_ref _n =\n raise_variant_wrong_type \"t\" !pos_ref\n ;;\n\n let bin_writer_t bin_writer1 bin_writer2 =\n { size = (fun v -> bin_size_t bin_writer1.size bin_writer2.size v)\n ; write =\n (fun buf ~pos v -> bin_write_t bin_writer1.write bin_writer2.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader1 bin_reader2 =\n { read =\n (fun buf ~pos_ref -> bin_read_t bin_reader1.read bin_reader2.read buf ~pos_ref)\n ; vtag_read =\n (fun buf ~pos_ref n ->\n __bin_read_t__ bin_reader1.read bin_reader2.read buf ~pos_ref n)\n }\n ;;\n\n let bin_t type_class1 type_class2 =\n { shape = bin_shape_t type_class1.shape type_class2.shape\n ; writer = bin_writer_t type_class1.writer type_class2.writer\n ; reader = bin_reader_t type_class1.reader type_class2.reader\n }\n ;;\nend\n\nmodule Make_iterable_binable3 (S : Make_iterable_binable3_spec) = struct\n open S\n\n let bin_shape_t t1 t2 t3 =\n Shape.(\n basetype\n caller_identity\n [ basetype\n (Uuid.of_string \"f2112eda-e7d7-11e6-bb36-072e9ce159db\")\n [ S.bin_shape_el t1 t2 t3 ]\n ])\n ;;\n\n let bin_size_t bin_size_a bin_size_b bin_size_c t =\n let size_ref = ref 0 in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n size_ref := !size_ref + bin_size_el bin_size_a bin_size_b bin_size_c el;\n incr cnt_ref);\n let len = length t in\n if !cnt_ref = len\n then bin_size_nat0 (Nat0.unsafe_of_int len) + !size_ref\n else raise_concurrent_modification ~module_name \"bin_size_t\"\n ;;\n\n let bin_write_t bin_write_a bin_write_b bin_write_c buf ~pos t =\n let len = length t in\n let plen = Nat0.unsafe_of_int len in\n let pos_ref = ref (Write.bin_write_nat0 buf ~pos plen) in\n let cnt_ref = ref 0 in\n iter t ~f:(fun el ->\n pos_ref := bin_write_el bin_write_a bin_write_b bin_write_c buf ~pos:!pos_ref el;\n incr cnt_ref);\n if !cnt_ref = len\n then !pos_ref\n else raise_concurrent_modification ~module_name \"bin_write_t\"\n ;;\n\n let bin_read_t bin_read_a bin_read_b bin_read_c buf ~pos_ref =\n let len = (Read.bin_read_nat0 buf ~pos_ref :> int) in\n let idx = ref 0 in\n let next () =\n if !idx >= len then raise_read_too_much ~module_name \"bin_read_t\";\n incr idx;\n bin_read_el bin_read_a bin_read_b bin_read_c buf ~pos_ref\n in\n let result = init ~len ~next in\n if !idx < len then raise_read_not_enough ~module_name \"bin_read_t\";\n result\n ;;\n\n let __bin_read_t__ _bin_read_a _bin_read_b _bin_read_c _buf ~pos_ref _n =\n raise_variant_wrong_type \"t\" !pos_ref\n ;;\n\n let bin_writer_t bin_writer1 bin_writer2 bin_writer3 =\n { size = (fun v -> bin_size_t bin_writer1.size bin_writer2.size bin_writer3.size v)\n ; write =\n (fun buf ~pos v ->\n bin_write_t bin_writer1.write bin_writer2.write bin_writer3.write buf ~pos v)\n }\n ;;\n\n let bin_reader_t bin_reader1 bin_reader2 bin_reader3 =\n { read =\n (fun buf ~pos_ref ->\n bin_read_t bin_reader1.read bin_reader2.read bin_reader3.read buf ~pos_ref)\n ; vtag_read =\n (fun buf ~pos_ref n ->\n __bin_read_t__\n bin_reader1.read\n bin_reader2.read\n bin_reader3.read\n buf\n ~pos_ref\n n)\n }\n ;;\n\n let bin_t type_class1 type_class2 type_class3 =\n { shape = bin_shape_t type_class1.shape type_class2.shape type_class3.shape\n ; writer = bin_writer_t type_class1.writer type_class2.writer type_class3.writer\n ; reader = bin_reader_t type_class1.reader type_class2.reader type_class3.reader\n }\n ;;\nend\n","(**\n This module defines default converters for the types defined in the OCaml\n standard library.\n*)\n\ninclude Size\n\nlet bin_unit = Type_class.bin_unit\nlet bin_shape_unit = Type_class.bin_shape_unit\nlet bin_writer_unit = Type_class.bin_writer_unit\nlet bin_write_unit = Write.bin_write_unit\nlet bin_reader_unit = Type_class.bin_reader_unit\nlet bin_read_unit = Read.bin_read_unit\n\nlet __bin_read_unit__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"unit\" !pos_ref\n;;\n\nlet bin_bool = Type_class.bin_bool\nlet bin_shape_bool = Type_class.bin_shape_bool\nlet bin_writer_bool = Type_class.bin_writer_bool\nlet bin_write_bool = Write.bin_write_bool\nlet bin_reader_bool = Type_class.bin_reader_bool\nlet bin_read_bool = Read.bin_read_bool\n\nlet __bin_read_bool__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"bool\" !pos_ref\n;;\n\nlet bin_string = Type_class.bin_string\nlet bin_shape_string = Type_class.bin_shape_string\nlet bin_writer_string = Type_class.bin_writer_string\nlet bin_write_string = Write.bin_write_string\nlet bin_reader_string = Type_class.bin_reader_string\nlet bin_read_string = Read.bin_read_string\n\nlet __bin_read_string__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"string\" !pos_ref\n;;\n\nlet bin_bytes = Type_class.bin_bytes\nlet bin_shape_bytes = Type_class.bin_shape_bytes\nlet bin_writer_bytes = Type_class.bin_writer_bytes\nlet bin_write_bytes = Write.bin_write_bytes\nlet bin_reader_bytes = Type_class.bin_reader_bytes\nlet bin_read_bytes = Read.bin_read_bytes\n\nlet __bin_read_bytes__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"bytes\" !pos_ref\n;;\n\nlet bin_char = Type_class.bin_char\nlet bin_shape_char = Type_class.bin_shape_char\nlet bin_writer_char = Type_class.bin_writer_char\nlet bin_write_char = Write.bin_write_char\nlet bin_reader_char = Type_class.bin_reader_char\nlet bin_read_char = Read.bin_read_char\n\nlet __bin_read_char__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"char\" !pos_ref\n;;\n\nlet bin_int = Type_class.bin_int\nlet bin_shape_int = Type_class.bin_shape_int\nlet bin_writer_int = Type_class.bin_writer_int\nlet bin_write_int = Write.bin_write_int\nlet bin_reader_int = Type_class.bin_reader_int\nlet bin_read_int = Read.bin_read_int\nlet __bin_read_int__ _buf ~pos_ref _vint = Common.raise_variant_wrong_type \"int\" !pos_ref\nlet bin_float = Type_class.bin_float\nlet bin_shape_float = Type_class.bin_shape_float\nlet bin_writer_float = Type_class.bin_writer_float\nlet bin_write_float = Write.bin_write_float\nlet bin_reader_float = Type_class.bin_reader_float\nlet bin_read_float = Read.bin_read_float\n\nlet __bin_read_float__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float\" !pos_ref\n;;\n\ntype float_array = float array\n\nlet bin_float_array = Type_class.bin_float_array\nlet bin_shape_float_array = Type_class.bin_shape_float_array\nlet bin_writer_float_array = Type_class.bin_writer_float_array\nlet bin_write_float_array = Write.bin_write_float_array\nlet bin_reader_float_array = Type_class.bin_reader_float_array\nlet bin_read_float_array = Read.bin_read_float_array\n\nlet __bin_read_float_array__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float_array\" !pos_ref\n;;\n\nlet bin_int32 = Type_class.bin_int32\nlet bin_shape_int32 = Type_class.bin_shape_int32\nlet bin_writer_int32 = Type_class.bin_writer_int32\nlet bin_write_int32 = Write.bin_write_int32\nlet bin_reader_int32 = Type_class.bin_reader_int32\nlet bin_read_int32 = Read.bin_read_int32\n\nlet __bin_read_int32__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"int32\" !pos_ref\n;;\n\nlet bin_int64 = Type_class.bin_int64\nlet bin_shape_int64 = Type_class.bin_shape_int64\nlet bin_writer_int64 = Type_class.bin_writer_int64\nlet bin_write_int64 = Write.bin_write_int64\nlet bin_reader_int64 = Type_class.bin_reader_int64\nlet bin_read_int64 = Read.bin_read_int64\n\nlet __bin_read_int64__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"int64\" !pos_ref\n;;\n\nlet bin_nativeint = Type_class.bin_nativeint\nlet bin_shape_nativeint = Type_class.bin_shape_nativeint\nlet bin_writer_nativeint = Type_class.bin_writer_nativeint\nlet bin_write_nativeint = Write.bin_write_nativeint\nlet bin_reader_nativeint = Type_class.bin_reader_nativeint\nlet bin_read_nativeint = Read.bin_read_nativeint\n\nlet __bin_read_nativeint__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"nativeint\" !pos_ref\n;;\n\nlet bin_ref = Type_class.bin_ref\nlet bin_shape_ref = Type_class.bin_shape_ref\nlet bin_writer_ref = Type_class.bin_writer_ref\nlet bin_write_ref = Write.bin_write_ref\nlet bin_reader_ref = Type_class.bin_reader_ref\nlet bin_read_ref = Read.bin_read_ref\n\nlet __bin_read_ref__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"ref\" !pos_ref\n;;\n\nlet bin_lazy_t = Type_class.bin_lazy\nlet bin_shape_lazy_t = Type_class.bin_shape_lazy\nlet bin_writer_lazy_t = Type_class.bin_writer_lazy\nlet bin_write_lazy_t = Write.bin_write_lazy\nlet bin_reader_lazy_t = Type_class.bin_reader_lazy\nlet bin_read_lazy_t = Read.bin_read_lazy\n\nlet __bin_read_lazy_t__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"lazy\" !pos_ref\n;;\n\nlet bin_lazy = Type_class.bin_lazy\nlet bin_shape_lazy = Type_class.bin_shape_lazy\nlet bin_writer_lazy = Type_class.bin_writer_lazy\nlet bin_write_lazy = Write.bin_write_lazy\nlet bin_reader_lazy = Type_class.bin_reader_lazy\nlet bin_read_lazy = Read.bin_read_lazy\n\nlet __bin_read_lazy__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"lazy\" !pos_ref\n;;\n\nlet bin_option = Type_class.bin_option\nlet bin_shape_option = Type_class.bin_shape_option\nlet bin_writer_option = Type_class.bin_writer_option\nlet bin_write_option = Write.bin_write_option\nlet bin_reader_option = Type_class.bin_reader_option\nlet bin_read_option = Read.bin_read_option\n\nlet __bin_read_option__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"option\" !pos_ref\n;;\n\nlet bin_list = Type_class.bin_list\nlet bin_shape_list = Type_class.bin_shape_list\nlet bin_writer_list = Type_class.bin_writer_list\nlet bin_write_list = Write.bin_write_list\nlet bin_reader_list = Type_class.bin_reader_list\nlet bin_read_list = Read.bin_read_list\n\nlet __bin_read_list__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"list\" !pos_ref\n;;\n\nlet bin_array = Type_class.bin_array\nlet bin_shape_array = Type_class.bin_shape_array\nlet bin_writer_array = Type_class.bin_writer_array\nlet bin_write_array = Write.bin_write_array\nlet bin_reader_array = Type_class.bin_reader_array\nlet bin_read_array = Read.bin_read_array\n\nlet __bin_read_array__ _f _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"array\" !pos_ref\n;;\n\nlet bin_hashtbl = Type_class.bin_hashtbl\nlet bin_shape_hashtbl = Type_class.bin_shape_hashtbl\nlet bin_writer_hashtbl = Type_class.bin_writer_hashtbl\nlet bin_write_hashtbl = Write.bin_write_hashtbl\nlet bin_reader_hashtbl = Type_class.bin_reader_hashtbl\nlet bin_read_hashtbl = Read.bin_read_hashtbl\n\nlet __bin_read_hashtbl__ _f _g _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"hashtbl\" !pos_ref\n;;\n\nlet bin_bigstring = Type_class.bin_bigstring\nlet bin_shape_bigstring = Type_class.bin_shape_bigstring\nlet bin_writer_bigstring = Type_class.bin_writer_bigstring\nlet bin_write_bigstring = Write.bin_write_bigstring\nlet bin_reader_bigstring = Type_class.bin_reader_bigstring\nlet bin_read_bigstring = Read.bin_read_bigstring\n\nlet __bin_read_bigstring__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"bigstring\" !pos_ref\n;;\n\nlet bin_mat = Type_class.bin_mat\nlet bin_shape_mat = Type_class.bin_shape_mat\nlet bin_writer_mat = Type_class.bin_writer_mat\nlet bin_write_mat = Write.bin_write_mat\nlet bin_reader_mat = Type_class.bin_reader_mat\nlet bin_read_mat = Read.bin_read_mat\nlet __bin_read_mat__ _buf ~pos_ref _vint = Common.raise_variant_wrong_type \"mat\" !pos_ref\nlet bin_float32_mat = Type_class.bin_float32_mat\nlet bin_shape_float32_mat = Type_class.bin_shape_float32_mat\nlet bin_writer_float32_mat = Type_class.bin_writer_float32_mat\nlet bin_write_float32_mat = Write.bin_write_float32_mat\nlet bin_reader_float32_mat = Type_class.bin_reader_float32_mat\nlet bin_read_float32_mat = Read.bin_read_float32_mat\n\nlet __bin_read_float32_mat__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float32_mat\" !pos_ref\n;;\n\nlet bin_float64_mat = Type_class.bin_float64_mat\nlet bin_shape_float64_mat = Type_class.bin_shape_float64_mat\nlet bin_writer_float64_mat = Type_class.bin_writer_float64_mat\nlet bin_write_float64_mat = Write.bin_write_float64_mat\nlet bin_reader_float64_mat = Type_class.bin_reader_float64_mat\nlet bin_read_float64_mat = Read.bin_read_float64_mat\n\nlet __bin_read_float64_mat__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float64_mat\" !pos_ref\n;;\n\nlet bin_vec = Type_class.bin_vec\nlet bin_shape_vec = Type_class.bin_shape_vec\nlet bin_writer_vec = Type_class.bin_writer_vec\nlet bin_write_vec = Write.bin_write_vec\nlet bin_reader_vec = Type_class.bin_reader_vec\nlet bin_read_vec = Read.bin_read_vec\nlet __bin_read_vec__ _buf ~pos_ref _vint = Common.raise_variant_wrong_type \"vec\" !pos_ref\nlet bin_float32_vec = Type_class.bin_float32_vec\nlet bin_shape_float32_vec = Type_class.bin_shape_float32_vec\nlet bin_writer_float32_vec = Type_class.bin_writer_float32_vec\nlet bin_write_float32_vec = Write.bin_write_float32_vec\nlet bin_reader_float32_vec = Type_class.bin_reader_float32_vec\nlet bin_read_float32_vec = Read.bin_read_float32_vec\n\nlet __bin_read_float32_vec__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float32_vec\" !pos_ref\n;;\n\nlet bin_float64_vec = Type_class.bin_float64_vec\nlet bin_shape_float64_vec = Type_class.bin_shape_float64_vec\nlet bin_writer_float64_vec = Type_class.bin_writer_float64_vec\nlet bin_write_float64_vec = Write.bin_write_float64_vec\nlet bin_reader_float64_vec = Type_class.bin_reader_float64_vec\nlet bin_read_float64_vec = Read.bin_read_float64_vec\n\nlet __bin_read_float64_vec__ _buf ~pos_ref _vint =\n Common.raise_variant_wrong_type \"float64_vec\" !pos_ref\n;;\n","module type S = sig\n val pre_test_hook : unit -> unit\nend\n\nlet pre_test_hook = ignore\n","[%%import\n \"config.h\"]\n\nopen! Base\n\n[%%ifdef\n JSC_ARCH_SIXTYFOUR]\n\nexternal nanoseconds_since_unix_epoch_or_zero\n : unit\n -> Int63.t\n = \"time_now_nanoseconds_since_unix_epoch_or_zero\"\n[@@noalloc]\n\n[%%else]\n\nexternal nanoseconds_since_unix_epoch_or_zero\n : unit\n -> Int63.t\n = \"time_now_nanoseconds_since_unix_epoch_or_zero\"\n\n[%%endif]\n\n[%%ifdef\n JSC_POSIX_TIMERS]\n\nlet[@cold] gettime_failed () = failwith \"clock_gettime(CLOCK_REALTIME) failed\"\n\n[%%else]\n\nlet[@cold] gettime_failed () = failwith \"gettimeofday failed\"\n\n[%%endif]\n\nlet nanoseconds_since_unix_epoch () =\n let t = nanoseconds_since_unix_epoch_or_zero () in\n if Int63.( <> ) t Int63.zero then t else gettime_failed ()\n;;\n","module Test_result = struct\n type t = Success | Failure | Error\n\n let to_exit_code = function\n | Success -> 0\n | Failure -> 2\n | Error -> 1\n ;;\n\n let to_string = function\n | Success -> \"success\"\n | Failure -> \"failure\"\n | Error -> \"error\"\n ;;\n\n let combine t1 t2 =\n match t1, t2 with\n | Success, Success -> Success\n | Error , _ | _, Error -> Error\n | Failure, _ | _, Failure -> Failure\n ;;\n\n let combine_all ts = List.fold_left combine Success ts\nend\n\nlet parse_argv argv l f msg =\n try\n Arg.parse_argv argv l f msg\n with\n | Arg.Bad msg -> Printf.eprintf \"%s\" msg; exit 1\n | Arg.Help msg -> Printf.printf \"%s\" msg; exit 0\n;;\n\ntype descr = string\nlet test_modules_ran = ref 0\nlet test_modules_failed = ref 0\nlet tests_ran = ref 0\nlet tests_failed = ref 0\nlet dynamic_lib : string option ref = ref None\ntype filename = string\ntype line_number = int\ntype start_pos = int\ntype end_pos = int\ntype config = (module Inline_test_config.S)\ntype 'a test_function_args\n = config:config\n -> descr:descr\n -> tags:string list\n -> filename:filename\n -> line_number:line_number\n -> start_pos:start_pos\n -> end_pos:end_pos\n -> 'a\n\nmodule Tag_predicate = struct\n type t =\n { required_tags : string list\n ; dropped_tags : string list\n }\n\n let enable_everything = { required_tags = []; dropped_tags = [] }\n\n let drop t tag =\n { dropped_tags = tag :: t.dropped_tags\n ; required_tags = List.filter ((<>) tag) t.required_tags\n }\n\n let require t tag =\n { dropped_tags = List.filter ((<>) tag) t.dropped_tags\n ; required_tags = tag :: t.required_tags\n }\n\n let entire_module_disabled t ~partial_tags:tags =\n List.exists (fun dropped -> List.mem dropped tags) t.dropped_tags\n\n let disabled t ~complete_tags:tags =\n List.exists (fun req -> not (List.mem req tags)) t.required_tags\n || List.exists (fun dropped -> List.mem dropped tags) t.dropped_tags\nend\n\n\ntype which_tests =\n { libname : string\n ; only_test_location : (filename * line_number option * bool ref) list\n ; which_tags : Tag_predicate.t\n }\ntype test_mode =\n { which_tests : which_tests\n ; what_to_do :\n [ `Run_partition of string option\n | `List_partitions\n ]\n }\n\nmodule Action : sig\n type t = [\n | `Ignore\n | `Test_mode of test_mode\n ]\n val get : unit -> t\n val set : t -> unit\nend = struct\n type t = [\n | `Ignore\n | `Test_mode of test_mode\n ]\n let action : t ref = ref `Ignore\n let force_drop =\n try ignore (Sys.getenv \"FORCE_DROP_INLINE_TEST\" : string); true\n with Not_found -> false\n let get () =\n (* This is useful when compiling to javascript.\n Js_of_ocaml can statically evaluate [Sys.getenv \"FORCE_DROP_INLINE_TEST\"]\n and inline the result ([`Ignore]) whenever [get ()] is called.\n Unit tests can then be treated as deadcode since the argument [f] of the [test]\n function below is never used. *)\n if force_drop\n then `Ignore\n else !action\n\n let set v = action := v\nend\n\nmodule Partition : sig\n val found_test : unit -> unit\n val set_current : string -> unit\n val is_current : string option -> bool\n val all : unit -> string list\nend = struct\n let all = Hashtbl.create 23\n let current = ref \"\" let set_current x = current := x\n let found_test () =\n if !current <> \"\" && not (Hashtbl.mem all !current) then\n Hashtbl.add all !current ()\n ;;\n let is_current = function\n | None -> true\n | Some p -> p = !current\n ;;\n let all () =\n List.sort String.compare\n (Hashtbl.fold (fun k () acc -> k :: acc) all [])\n ;;\nend\n\nmodule Module_context = struct\n module T = struct\n type one_module =\n { descr : string\n ; tags : string list\n }\n\n type t = one_module list\n\n let descr t = List.map (fun m -> m.descr) t\n let tags t = List.concat (List.map (fun m -> m.tags) t)\n end\n\n let current : T.t ref = ref []\n\n let with_ ~descr ~tags f =\n let prev = !current in\n current := { T. descr; tags } :: prev;\n try\n f ();\n current := prev;\n with e ->\n current := prev;\n raise e\n\n let current_descr () = T.descr !current\n let current_tags () = T.tags !current\nend\n\nlet verbose = ref false\nlet strict = ref false\nlet show_counts = ref false\nlet list_test_names = ref false\nlet delayed_errors = ref []\nlet stop_on_error = ref false\n\nlet log = ref None\n\nlet time_sec = ref 0.\n\nlet use_color = ref true\nlet in_place = ref false\nlet diff_command = ref None\nlet source_tree_root = ref None\nlet allow_output_patterns = ref false\n\nlet displayed_descr descr filename line start_pos end_pos =\n Printf.sprintf \"File %S, line %d, characters %d-%d%s\"\n filename line start_pos end_pos descr\nlet parse_descr str =\n try Some (Scanf.sscanf str \" File %S , line %d , characters %d - %d %!\"\n (fun file line _start_pos _end_pos -> file, Some line))\n with _ ->\n try Some (Scanf.sscanf str \" File %S , line %d %!\" (fun file line -> file, Some line))\n with _ ->\n try Some (Scanf.sscanf str \" File %S %!\" (fun file -> file, None))\n with _ -> None\n\nlet indent ~by = function\n | \"\" -> \"\"\n | str ->\n let len = String.length str in\n let buf = Buffer.create (len * 2) in\n let indentation = String.make by ' ' in\n Buffer.add_string buf indentation;\n for i = 0 to len - 1; do\n Buffer.add_char buf str.[i];\n if str.[i] = '\\n' && i <> len - 1 then Buffer.add_string buf indentation\n done;\n Buffer.contents buf\n\nlet backtrace_indented ~by =\n let str = Printexc.get_backtrace () in\n indent str ~by\n\nlet () =\n match Array.to_list Sys.argv with\n | name :: \"inline-test-runner\" :: lib :: rest\n when Base.Exported_for_specific_uses.am_testing -> begin\n (* when we see this argument, we switch to test mode *)\n let tests = ref [] in\n let list_partitions = ref false in\n let partition = ref None in\n let tag_predicate = ref Tag_predicate.enable_everything in\n parse_argv (Array.of_list (name :: rest)) (Arg.align [\n \"-list-test-names\", Arg.Unit (fun () -> list_test_names := true; verbose := true),\n \" Do not run tests but show what would have been run\";\n \"-list-partitions\", Arg.Unit (fun () -> list_partitions := true),\n \" Lists all the partitions that contain at least one test or test_module\";\n \"-partition\", Arg.String (fun i -> partition := Some i),\n \" Only run the tests in the given partition\";\n \"-verbose\", Arg.Set verbose, \" Show the tests as they run\";\n \"-stop-on-error\", Arg.Set stop_on_error, \" Run tests only up to the first error \\\n (doesn't work for expect tests)\";\n \"-strict\", Arg.Set strict, \" End with an error if no tests were run\";\n \"-show-counts\", Arg.Set show_counts, \" Show the number of tests ran\";\n \"-log\", Arg.Unit (fun () ->\n (try Sys.remove \"inline_tests.log\" with _ -> ());\n log := Some (open_out \"inline_tests.log\")\n ), \" Log the tests run in inline_tests.log\";\n \"-drop-tag\", Arg.String (fun s ->\n tag_predicate := Tag_predicate.drop !tag_predicate s\n ), \"tag Only run tests not tagged with [tag] (overrides previous -require-tag)\";\n \"-require-tag\", Arg.String (fun s ->\n tag_predicate := Tag_predicate.require !tag_predicate s\n ), \"tag Only run tests tagged with [tag] (overrides previous -drop-tag)\";\n \"-only-test\", Arg.String (fun s ->\n let filename, index =\n match parse_descr s with\n | Some (file, index) -> file, index\n | None ->\n if String.contains s ':' then\n let i = String.index s ':' in\n let filename = String.sub s 0 i in\n let index_string = String.sub s (i + 1) (String.length s - i - 1) in\n let index =\n try int_of_string index_string\n with Failure _ ->\n Printf.eprintf\n \"Argument %s doesn't fit the format filename[:line_number]\\n%!\" s;\n exit 1\n in\n filename, Some index\n else\n s, None\n in\n tests := (filename, index, ref false) :: !tests\n ), \"location Run only the tests specified by all the -only-test options.\n Locations can be one of these forms:\n - file.ml\n - file.ml:line_number\n - File \\\"file.ml\\\"\n - File \\\"file.ml\\\", line 23\n - File \\\"file.ml\\\", line 23, characters 2-3\";\n \"-no-color\", Arg.Clear use_color, \" Summarize tests without using color\";\n \"-in-place\", Arg.Set in_place, \" Update expect tests in place\";\n \"-diff-cmd\", Arg.String (fun s -> diff_command := Some s),\n \" Diff command for tests that require diffing (use - to disable diffing)\";\n \"-allow-output-patterns\", Arg.Set allow_output_patterns,\n \" Allow output patterns in tests expectations\";\n \"-source-tree-root\", Arg.String (fun s -> source_tree_root := Some s),\n \" Path to the root of the source tree\"\n ]) (fun anon ->\n Printf.eprintf \"%s: unexpected anonymous argument %s\\n%!\" name anon;\n exit 1\n ) (Printf.sprintf \"%s %s %s [args]\" name \"inline-test-runner\" lib);\n Action.set (\n `Test_mode\n { which_tests =\n { libname = lib\n ; only_test_location = !tests;\n which_tags = !tag_predicate;\n }\n ; what_to_do =\n if !list_partitions\n then `List_partitions\n else `Run_partition !partition\n })\n end\n | _ ->\n ()\n\nlet am_test_runner =\n match Action.get () with\n | `Test_mode _ -> true\n | `Ignore -> false\n\nlet am_running_inline_test_env_var =\n (* for approximate compatibility, given that the variable is not exactly equivalent\n to what PPX_INLINE_TEST_LIB_AM_RUNNING_INLINE_TEST used to be *)\n \"TESTING_FRAMEWORK\"\n\n(* This value is deprecated in principle, in favor of Core_kernel.am_running_test, so\n we're going to live with the ugly pattern match. *)\nlet am_running_inline_test =\n match Sys.getenv \"PPX_INLINE_TEST_LIB_AM_RUNNING_INLINE_TEST\" with\n | (_ : string) -> true (* for compatibility with people setting this variable directly *)\n | exception Not_found ->\n match Sys.getenv am_running_inline_test_env_var with\n | \"inline-test\" -> true\n | exception Not_found -> false\n | _ -> false\n\nlet testing =\n if am_test_runner\n then `Testing `Am_test_runner\n else\n (if am_running_inline_test\n then `Testing `Am_child_of_test_runner\n else `Not_testing)\n\nlet wall_time_clock_ns () =\n Time_now.nanoseconds_since_unix_epoch ()\n\n\nlet time_without_resetting_random_seeds f =\n let before_ns = wall_time_clock_ns () in\n Base.Exn.protect ~finally:(fun[@inline] () ->\n time_sec := Base.Int63.(wall_time_clock_ns () - before_ns |> to_float) /. 1e9)\n ~f\n\n\nlet saved_caml_random_state = lazy (Caml.Random.State.make [| 100; 200; 300 |])\nlet saved_base_random_state = lazy (Base.Random.State.make [| 111; 222; 333 |])\n\nlet time_and_reset_random_seeds f =\n let caml_random_state = Caml.Random.get_state () in\n let base_random_state = Base.Random.State.copy Base.Random.State.default in\n Caml.Random.set_state (Lazy.force saved_caml_random_state);\n Base.Random.set_state (Lazy.force saved_base_random_state);\n let result = time_without_resetting_random_seeds f in\n Caml.Random.set_state caml_random_state;\n Base.Random.set_state base_random_state;\n result\n\nlet string_of_module_descr () =\n String.concat \"\" (\n List.map (fun s -> \" in TES\" ^ \"T_MODULE at \" ^ String.uncapitalize_ascii s ^ \"\\n\")\n (Module_context.current_descr ())\n )\n\nlet position_match def_filename def_line_number l =\n List.exists (fun (filename, line_number_opt, used) ->\n let position_start =\n String.length def_filename - String.length filename in\n let found =\n position_start >= 0 &&\n let end_of_def_filename =\n String.sub def_filename\n position_start\n (String.length filename) in\n end_of_def_filename = filename\n && (position_start = 0 || def_filename.[position_start - 1] = '/')\n && (match line_number_opt with\n | None -> true\n | Some line_number -> def_line_number = line_number)\n in\n if found then used := true;\n found\n ) l\n\nlet print_delayed_errors () =\n match List.rev !delayed_errors with\n | [] -> ()\n | _ :: _ as delayed_errors ->\n Printf.eprintf \"\\n%s\\n%!\" (String.make 70 '=');\n List.iter (fun message ->\n Printf.eprintf \"%s%!\" message\n ) delayed_errors\n\nlet eprintf_or_delay fmt =\n Printf.ksprintf (fun s ->\n if !verbose then delayed_errors := s :: !delayed_errors\n else Printf.eprintf \"%s%!\" s;\n if !stop_on_error then begin\n print_delayed_errors ();\n exit 2\n end\n ) fmt\n\nlet add_hooks ((module C) : config) f =\n fun () -> C.pre_test_hook (); f ()\n\nlet[@inline never] test ~config ~descr ~tags ~filename:def_filename ~line_number:def_line_number\n ~start_pos ~end_pos f =\n match Action.get () with\n | `Ignore -> ()\n | `Test_mode { which_tests = { libname; only_test_location; which_tags }; what_to_do } ->\n let f = add_hooks config f in\n let descr () = displayed_descr descr def_filename def_line_number start_pos end_pos in\n let complete_tags = tags @ Module_context.current_tags () in\n let should_run =\n Some libname = !dynamic_lib\n && begin match only_test_location with\n | [] -> true\n | _ :: _ -> position_match def_filename def_line_number only_test_location\n end\n && not (Tag_predicate.disabled which_tags ~complete_tags)\n in\n if should_run then begin\n match what_to_do with\n | `List_partitions -> Partition.found_test ()\n | `Run_partition partition ->\n if Partition.is_current partition then begin\n let descr = descr () in\n incr tests_ran;\n begin match !log with\n | None -> ()\n | Some ch -> Printf.fprintf ch \"%s\\n%s\" descr (string_of_module_descr ())\n end;\n if !verbose then begin\n Printf.printf \"%s%!\" descr\n end;\n let print_time_taken () =\n (* If !list_test_names, this is is a harmless zero. *)\n if !verbose then Printf.printf \" (%.3f sec)\\n%!\" !time_sec;\n in\n try\n let failed = not !list_test_names && not (time_and_reset_random_seeds f) in\n print_time_taken ();\n if failed then begin\n incr tests_failed;\n eprintf_or_delay \"%s is false.\\n%s\\n%!\" descr\n (string_of_module_descr ())\n end\n with exn ->\n print_time_taken ();\n let backtrace = backtrace_indented ~by:2 in\n incr tests_failed;\n let exn_str = Printexc.to_string exn in\n let sep = if String.contains exn_str '\\n' then \"\\n\" else \" \" in\n eprintf_or_delay \"%s threw%s%s.\\n%s%s\\n%!\" descr sep exn_str\n backtrace (string_of_module_descr ())\n end\n end\n\nlet set_lib_and_partition static_lib partition =\n match !dynamic_lib with\n | Some _ ->\n (* possible if the interface is used explicitly or if we happen to dynlink something\n that contain tests *)\n ()\n | None ->\n dynamic_lib := Some static_lib;\n match Action.get () with\n | `Ignore -> ()\n | `Test_mode { which_tests; what_to_do } ->\n if which_tests.libname = static_lib then begin\n let requires_partition =\n match what_to_do with\n | `List_partitions | `Run_partition (Some _) -> true\n | `Run_partition None -> false\n in\n if partition = \"\" && requires_partition\n then failwith \"ppx_inline_test: cannot use -list-partition or -partition \\\n without specifying a partition at preprocessing time\"\n else Partition.set_current partition\n end\n\nlet unset_lib static_lib =\n match !dynamic_lib with\n | None ->\n (* not giving an error, because when some annoying people put pa_ounit in their list\n of preprocessors, pa_ounit is set up twice and we have two calls to unset_lib at\n the end of the file, and the second one comes in this branch *)\n ()\n | Some lib ->\n if lib = static_lib then dynamic_lib := None\n\nlet test_unit ~config ~descr ~tags ~filename ~line_number ~start_pos ~end_pos f =\n test ~config ~descr ~tags ~filename ~line_number ~start_pos ~end_pos\n (fun () -> f (); true)\n\nlet[@inline never] test_module ~config ~descr ~tags ~filename:def_filename ~line_number:def_line_number\n ~start_pos ~end_pos f =\n match Action.get () with\n | `Ignore -> ()\n | `Test_mode { which_tests = { libname; only_test_location = _; which_tags }; what_to_do } ->\n let f = add_hooks config f in\n let descr () = displayed_descr descr def_filename def_line_number start_pos end_pos in\n let partial_tags = tags @ Module_context.current_tags () in\n let should_run =\n Some libname = !dynamic_lib\n (* If, no matter what tags a test defines, we certainly will drop all tests within\n this module, then don't run the module at all. This means people can write\n things like the following without breaking the 32-bit build:\n let%test_module [@tags \"64-bits-only\"] = (module struct\n let i = Int64.to_int_exn ....\n end)\n We don't shortcut based on position, as we can't tell what positions the\n inner tests will have. *)\n && not (Tag_predicate.entire_module_disabled which_tags ~partial_tags)\n in\n if should_run then begin\n match what_to_do with\n | `List_partitions -> Partition.found_test ()\n | `Run_partition partition ->\n if Partition.is_current partition then begin\n incr test_modules_ran;\n let descr = descr () in\n try\n Module_context.with_ ~descr ~tags (fun () ->\n (* We do not reset random states upon entering [let%test_module].\n\n Con: Code in test modules can accidentally depend on top-level random\n state effects.\n\n Pros: (1) We don't reset to the same seed on entering a [let%test_module]\n and then a [let%test] inside that module, which could lead to\n accidentally randomly generating the same values in some test. (2) Moving\n code into and out of [let%test_module] does not change its random seed.\n *)\n time_without_resetting_random_seeds f)\n with exn ->\n let backtrace = backtrace_indented ~by:2 in\n incr test_modules_failed;\n let exn_str = Printexc.to_string exn in\n let sep = if String.contains exn_str '\\n' then \"\\n\" else \" \" in\n eprintf_or_delay (\"TES\" ^^ \"T_MODULE at %s threw%s%s.\\n%s%s\\n%!\")\n (String.uncapitalize_ascii descr) sep exn_str backtrace (string_of_module_descr ())\n end\n end\n\nlet summarize () =\n match Action.get () with\n | `Ignore ->\n if Sys.argv <> [||] && Filename.basename Sys.argv.(0) = \"inline_tests_runner.exe\" then\n Printf.eprintf \"inline_tests_runner.exe is not supposed to be run by hand, you \\n\\\n should run the inline_tests_runner script instead.\\n%!\"\n else\n Printf.eprintf \"You are doing something unexpected with the tests. No tests have \\n\\\n been run. You should use the inline_tests_runner script to run \\n\\\n tests.\\n%!\";\n Test_result.Error\n | `Test_mode { which_tests = _; what_to_do = `List_partitions } ->\n List.iter (Printf.printf \"%s\\n\") (Partition.all ());\n Test_result.Success\n | `Test_mode { what_to_do = `Run_partition _; which_tests } -> begin\n begin match !log with\n | None -> ()\n | Some ch -> close_out ch\n end;\n print_delayed_errors ();\n match !tests_failed, !test_modules_failed with\n | 0, 0 -> begin\n if !show_counts then begin\n Printf.eprintf \"%d tests ran, %d test_modules ran\\n%!\" !tests_ran !test_modules_ran\n end;\n let errors =\n let unused_tests =\n List.filter (fun (_, _, used) -> not !used) which_tests.only_test_location\n in\n match unused_tests with\n | [] -> None\n | _ :: _ -> Some unused_tests\n in\n match errors with\n | Some tests ->\n Printf.eprintf \"ppx_inline_test error: the following -only-test flags matched nothing:\";\n List.iter (fun (filename, line_number_opt, _) ->\n match line_number_opt with\n | None -> Printf.eprintf \" %s\" filename\n | Some line_number -> Printf.eprintf \" %s:%d\" filename line_number\n ) tests;\n Printf.eprintf \".\\n%!\";\n Test_result.Error\n | None ->\n if !tests_ran = 0 && !strict then begin\n Printf.eprintf \"ppx_inline_test error: no tests have been run.\\n%!\";\n Test_result.Error\n end else begin\n Test_result.Success\n end\n end\n | count, count_test_modules ->\n Printf.eprintf \"FAILED %d / %d tests%s\\n%!\" count !tests_ran\n (if count_test_modules = 0 then \"\" else Printf.sprintf (\", %d TES\" ^^ \"T_MODULES\") count_test_modules);\n Test_result.Failure\n end\n\nlet use_color = !use_color\nlet in_place = !in_place\nlet diff_command = !diff_command\nlet source_tree_root = !source_tree_root\nlet allow_output_patterns = !allow_output_patterns\n\nlet evaluators = ref [summarize]\nlet add_evaluator ~f = evaluators := f :: !evaluators\nlet exit () =\n List.map (fun f -> f ()) (List.rev !evaluators)\n |> Test_result.combine_all\n |> Test_result.to_exit_code\n |> exit\n","(* this lib should not depend on core *)\nmodule List = struct\n include List\n let compare cmp a b =\n let rec loop a b =\n match a, b with\n | [], [] -> 0\n | [], _ -> -1\n | _ , [] -> 1\n | x :: xs, y :: ys ->\n let n = cmp x y in\n if n = 0 then loop xs ys\n else n\n in\n loop a b\nend\n\nmodule Uid : sig\n type t\n val compare : t -> t -> int\n val equal : t -> t -> bool\n val next : string -> t\n val hash : t -> int\n val name : t -> string\n val static : t\nend = struct\n type t = {\n code : int;\n name : string;\n }\n let compare a b = compare (a.code : int) b.code\n let equal a b = (a.code : int) = b.code\n let uid = ref 0\n let next name = let code = !uid in incr uid; {code; name}\n let hash a = Hashtbl.hash a.code\n let name a = a.name\n let static = next \"static\"\nend\n\nmodule Key = struct\n type t = {\n uid : Uid.t;\n params : t list;\n }\n let rec compare k1 k2 =\n if k1 == k2 then 0 else\n let cmp = Uid.compare k1.uid k2.uid in\n if cmp <> 0 then cmp else\n List.compare compare k1.params k2.params\n let equal a b = compare a b = 0\n let hash = (Hashtbl.hash : t -> int)\n let static = { uid = Uid.static ; params = [] }\nend\n\ntype 'a t = Key.t\ntype 'a typename = 'a t\n\nlet key t = t\nlet uid t = t.Key.uid\nlet name t = Uid.name t.Key.uid\nlet static = Key.static\n\nlet create ?(name=\"Typename.create\") () = { Key.uid = Uid.next name ; params = [] }\n\ninclude struct\n (* The argument for Obj.magic here is the same as the one in core/type_equal *)\n\n let same (type a) (type b) (nm1 : a t) (nm2 : b t) = Key.compare nm1 nm2 = 0\n\n let same_witness (type a) (type b) (nm1 : a t) (nm2 : b t) =\n if Key.compare nm1 nm2 = 0\n then Some (Obj.magic Type_equal.refl : (a, b) Type_equal.t)\n else None\n\n let same_witness_exn (type a) (type b) (nm1 : a t) (nm2 : b t) =\n if Key.compare nm1 nm2 = 0\n then (Obj.magic Type_equal.refl : (a, b) Type_equal.t)\n else failwith \"Typename.same_witness_exn\"\n\nend\n\nmodule type S0 = sig\n type t\n val typename_of_t : t typename\nend\n\nmodule type S1 = sig\n type 'a t\n val typename_of_t : 'a typename -> 'a t typename\nend\n\nmodule type S2 = sig\n type ('a, 'b) t\n val typename_of_t :\n 'a typename\n -> 'b typename\n -> ('a, 'b) t typename\nend\n\nmodule type S3 = sig\n type ('a, 'b, 'c) t\n val typename_of_t :\n 'a typename\n -> 'b typename\n -> 'c typename\n -> ('a, 'b, 'c) t typename\nend\n\nmodule type S4 = sig\n type ('a, 'b, 'c, 'd) t\n val typename_of_t :\n 'a typename\n -> 'b typename\n -> 'c typename\n -> 'd typename\n -> ('a, 'b, 'c, 'd) t typename\nend\n\nmodule type S5 = sig\n type ('a, 'b, 'c, 'd, 'e) t\n val typename_of_t :\n 'a typename\n -> 'b typename\n -> 'c typename\n -> 'd typename\n -> 'e typename\n -> ('a, 'b, 'c, 'd, 'e) t typename\nend\n\nmodule Make0 (X : Named_intf.S0) = struct\n let uid = Uid.next X.name\n let typename_of_t = { Key.uid ; params = [] }\nend\n\nmodule Make1 (X : Named_intf.S1) = struct\n let uid = Uid.next X.name\n let typename_of_t a = { Key.uid ; params = [ a ] }\nend\n\nmodule Make2 (X : Named_intf.S2) = struct\n let uid = Uid.next X.name\n let typename_of_t a b = { Key.uid ; params = [ a ; b ] }\nend\n\nmodule Make3 (X : Named_intf.S3) = struct\n let uid = Uid.next X.name\n let typename_of_t a b c = { Key.uid ; params = [ a ; b ; c ] }\nend\n\nmodule Make4 (X : Named_intf.S4) = struct\n let uid = Uid.next X.name\n let typename_of_t a b c d = { Key.uid ; params = [ a ; b ; c ; d ] }\nend\n\nmodule Make5 (X : Named_intf.S5) = struct\n let uid = Uid.next X.name\n let typename_of_t a b c d e = { Key.uid ; params = [ a ; b ; c ; d ; e ] }\nend\n\nmodule Key_table = Hashtbl.Make (Key)\n\nmodule Table (X : sig\n type 'a t\nend) = struct\n\n type data = Data : 'a t * 'a X.t -> data\n type t = data Key_table.t\n\n let create int = Key_table.create int\n\n let mem table name = Key_table.mem table (key name)\n\n let set table name data =\n Key_table.replace table (key name) (Data (name, data))\n\n let find (type a) table (name : a typename) =\n let data =\n try Some (Key_table.find table (key name))\n with Base.Not_found_s _ | Caml.Not_found -> None\n in\n match data with\n | None -> None\n | Some (Data (name', data)) ->\n (fun (type b) (name' : b typename) (data : b X.t) ->\n let Type_equal.T = (same_witness_exn name' name : (b, a) Type_equal.t) in\n Some (data : a X.t)\n ) name' data\nend\n\nlet fail uid_a uid_b =\n let msg =\n Printf.sprintf \"Typename.Same_witness_exn %S %S\" (Uid.name uid_a) (Uid.name uid_b)\n in\n failwith msg\n\nmodule Same_witness_exn_1 (A : S1) (B : S1) = struct\n type t = { eq : 'a. ('a A.t, 'a B.t) Type_equal.t }\n\n let witness =\n let uid_a = uid (A.typename_of_t static) in\n let uid_b = uid (B.typename_of_t static) in\n if Uid.equal uid_a uid_b\n then { eq = Obj.magic Type_equal.refl }\n else fail uid_a uid_b\nend\n\nmodule Same_witness_exn_2 (A : S2) (B : S2) = struct\n type t = {\n eq : 'a 'b. ( ('a, 'b) A.t,\n ('a, 'b) B.t ) Type_equal.t\n }\n\n let witness =\n let uid_a = uid (A.typename_of_t static static) in\n let uid_b = uid (B.typename_of_t static static) in\n if Uid.equal uid_a uid_b\n then { eq = Obj.magic Type_equal.refl }\n else fail uid_a uid_b\nend\n\nmodule Same_witness_exn_3 (A : S3) (B : S3) = struct\n type t = {\n eq : 'a 'b 'c. ( ('a, 'b, 'c) A.t,\n ('a, 'b, 'c) B.t ) Type_equal.t\n }\n\n let witness =\n let uid_a = uid (A.typename_of_t static static static) in\n let uid_b = uid (B.typename_of_t static static static) in\n if Uid.equal uid_a uid_b\n then { eq = Obj.magic Type_equal.refl }\n else fail uid_a uid_b\nend\n\nmodule Same_witness_exn_4 (A : S4) (B : S4) = struct\n type t = {\n eq : 'a 'b 'c 'd. ( ('a, 'b, 'c, 'd) A.t,\n ('a, 'b, 'c, 'd) B.t ) Type_equal.t\n }\n\n let witness =\n let uid_a = uid (A.typename_of_t static static static static) in\n let uid_b = uid (B.typename_of_t static static static static) in\n if Uid.equal uid_a uid_b\n then { eq = Obj.magic Type_equal.refl }\n else fail uid_a uid_b\nend\n\nmodule Same_witness_exn_5 (A : S5) (B : S5) = struct\n type t = {\n eq : 'a 'b 'c 'd 'e. ( ('a, 'b, 'c, 'd, 'e) A.t,\n ('a, 'b, 'c, 'd, 'e) B.t ) Type_equal.t\n }\n\n let witness =\n let uid_a = uid (A.typename_of_t static static static static static) in\n let uid_b = uid (B.typename_of_t static static static static static) in\n if Uid.equal uid_a uid_b\n then { eq = Obj.magic Type_equal.refl }\n else fail uid_a uid_b\nend\n","open Std_internal\n\nmodule Make0 (X : Named_intf.S0) = struct\n module Name_of_x = Typename.Make0 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named =\n Typerep.Named.T0 (module struct\n type named = X.t\n type t = X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T0 with type t = X.t)\nend\n\nmodule Make1 (X : Named_intf.S1) = struct\n module Name_of_x = Typename.Make1 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named (type p1) of_p1 =\n let typename_of_t = Name_of_x.typename_of_t\n (Typerep.typename_of_t of_p1)\n in\n Typerep.Named.T1 (module struct\n type 'a named = 'a X.t\n type a = p1 let a = of_p1\n type t = p1 X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T1 with type t = p1 X.t)\nend\n\nmodule Make2 (X : Named_intf.S2) = struct\n module Name_of_x = Typename.Make2 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named (type p1) (type p2) of_p1 of_p2 =\n let typename_of_t = Name_of_x.typename_of_t\n (Typerep.typename_of_t of_p1)\n (Typerep.typename_of_t of_p2)\n in\n Typerep.Named.T2 (module struct\n type ('a, 'b) named = ('a, 'b) X.t\n type a = p1 let a = of_p1\n type b = p2 let b = of_p2\n type t = (p1, p2) X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T2 with type t = (p1, p2) X.t)\nend\n\nmodule Make3 (X : Named_intf.S3) = struct\n module Name_of_x = Typename.Make3 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named (type p1) (type p2) (type p3) of_p1 of_p2 of_p3 =\n let typename_of_t = Name_of_x.typename_of_t\n (Typerep.typename_of_t of_p1)\n (Typerep.typename_of_t of_p2)\n (Typerep.typename_of_t of_p3)\n in\n Typerep.Named.T3 (module struct\n type ('a, 'b, 'c) named = ('a, 'b, 'c) X.t\n type a = p1 let a = of_p1\n type b = p2 let b = of_p2\n type c = p3 let c = of_p3\n type t = (p1, p2, p3) X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T3 with type t = (p1, p2, p3) X.t)\nend\n\nmodule Make4 (X : Named_intf.S4) = struct\n module Name_of_x = Typename.Make4 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named (type p1) (type p2) (type p3) (type p4) of_p1 of_p2 of_p3 of_p4 =\n let typename_of_t = Name_of_x.typename_of_t\n (Typerep.typename_of_t of_p1)\n (Typerep.typename_of_t of_p2)\n (Typerep.typename_of_t of_p3)\n (Typerep.typename_of_t of_p4)\n in\n Typerep.Named.T4 (module struct\n type ('a, 'b, 'c, 'd) named = ('a, 'b, 'c, 'd) X.t\n type a = p1 let a = of_p1\n type b = p2 let b = of_p2\n type c = p3 let c = of_p3\n type d = p4 let d = of_p4\n type t = (p1, p2, p3, p4) X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T4 with type t = (p1, p2, p3, p4) X.t)\nend\n\nmodule Make5 (X : Named_intf.S5) = struct\n module Name_of_x = Typename.Make5 (X)\n let typename_of_t = Name_of_x.typename_of_t\n let named\n (type p1) (type p2) (type p3) (type p4) (type p5)\n of_p1 of_p2 of_p3 of_p4 of_p5 =\n let typename_of_t = Name_of_x.typename_of_t\n (Typerep.typename_of_t of_p1)\n (Typerep.typename_of_t of_p2)\n (Typerep.typename_of_t of_p3)\n (Typerep.typename_of_t of_p4)\n (Typerep.typename_of_t of_p5)\n in\n Typerep.Named.T5 (module struct\n type ('a, 'b, 'c, 'd, 'e) named = ('a, 'b, 'c, 'd, 'e) X.t\n type a = p1 let a = of_p1\n type b = p2 let b = of_p2\n type c = p3 let c = of_p3\n type d = p4 let d = of_p4\n type e = p5 let e = of_p5\n type t = (p1, p2, p3, p4, p5) X.t\n let typename_of_named = Name_of_x.typename_of_t\n let typename_of_t = typename_of_t\n let witness = Type_equal.refl\n end : Typerep.Named.T5 with type t = (p1, p2, p3, p4, p5) X.t)\nend\n","(**\n Place holder for common Variants and Fields interface\n*)\n\nmodule M (X : sig\n\n (**\n This functor is essentially there because we use this same interface in different\n contexts, with different types for ['a t].\n\n 1) One use case for it is where ['a X.t = 'a Typerep.t]. These interfaces are then\n part of the type witness built for a type containing a record or a variant in its\n structure. [traverse] will give a way of accessing the type representation for the\n arguments of a variant or record type.\n\n 2) Another use case is for building \"staged generic computations\". In that case, the\n type ['a X.t] is the type of the computation that is being built. [traverse]\n returns the computation built for the argument. The interface no longer exports\n the typerep of the arguments in hopes of enforcing that no typerep traversal\n happens at runtime if the computation happen to be a function.\n *)\n type 'a t\nend) = struct\n\n (* The functions prefixed by [internal] as well as the module suffixed by [_internal]\n are used by the code generated by the camlp4 extension [with typerep] as well as some\n internals of the typerep library. Do not consider using these somewhere else. They\n should ideally not be exported outside the typerep library, but the generated code\n needs somehow to access this, even outside. *)\n\n module Tag_internal = struct\n type ('variant, 'args) create = Args of ('args -> 'variant) | Const of 'variant\n type ('variant, 'args) t =\n { label : string\n ; rep : 'args X.t\n ; arity : int\n ; args_labels: string list\n ; index : int\n ; ocaml_repr : int\n ; tyid : 'args Typename.t\n ; create : ('variant, 'args) create\n }\n end\n\n (**\n Witness of a tag, that is an item in a variant type, also called an \"applied\n variant Constructor\"\n\n The first parameter is the variant type, the second is the type of the tag\n parameters. Example:\n\n {[\n type t =\n | A of (int * string)\n | B of string\n | C of { x : int; y : string }\n ]}\n\n this type has three constructors. For each of them we'll have a corresponding\n [Tag.t]:\n\n {[\n val tag_A : (t, (int * string)) Tag.t\n val tag_B : (t, string ) Tag.t\n val tag_C : (t, (int * string)) Tag.t\n ]}\n\n Note, inline record in variant are typed as if their definition was using tuples,\n without the parenthesis. This is consistent with their runtime representation. But\n the distinction is carried and available for introspection as part of the [Tag.t].\n See [args_labels]. *)\n module Tag : sig\n type ('variant, 'args) create = Args of ('args -> 'variant) | Const of 'variant\n type ('variant, 'args) t\n\n (**\n The name of the constructor as it is given in the concrete syntax\n Examples:\n\n {v\n Constructor | label\n -------------------------\n | A of int | \"A\"\n | `a of int | \"a\"\n | `A of int | \"A\"\n | A of { x : int } | \"A\"\n v}\n\n for standard variant, the ocaml syntax implies that this label will always starts\n with a capital letter. For polymorphic variants, this might be a lowercase char.\n For polymorphic variant, this label does not include the [`] character.\n *)\n val label : (_, _) t -> string\n\n (**\n The size of the ocaml heap block containing the arguments\n\n Examples:\n {v\n 0: | A | 'A\n 1: | A of int | `A of int | A of (int * int) | `A of (int * int)\n | `A of int * int\n | A of { x : int}\n 2: | A of int * float\n | A of { x : int; y : string }\n etc.\n v}\n *)\n val arity : (_, _) t -> int\n\n (** The label of the fields for inline records. For other forms of tags, this is the\n empty list. When this returns a non empty list, the length of the returned list\n is equal to the arity.\n\n Example:\n\n {v\n (1) Empty:\n\n | A | 'A\n | A of int | `A of int | A of (int * int) | `A of (int * int)\n | `A of int * int\n | A of int * float\n\n (2) Non empty:\n\n | A of { x : int } -> [ \"x\" ]\n | A of { x : int; y : string } -> [ \"x\" ; \"y\" ]\n v}\n *)\n val args_labels : (_, _) t -> string list\n\n (**\n The index of the constructor in the list of all the variant type's constructors\n Examples:\n {[\n type t =\n | A of int (* 0 *)\n | B (* 1 *)\n | C of int (* 2 *)\n | D of char (* 3 *)\n | E of { x : int } (* 4 *)\n ]}\n *)\n val index : (_, _) t -> int\n\n (**\n ocaml_repr is related to the runtime of objects. this is essentially a way of\n giving one the ability to rebuild dynamically an [Obj.t] representing a tag.\n\n Polymorphic variants:\n ---------------------\n\n [ocaml_repr] is the hash of the label, as done by the compiler.\n Example:\n print_int (Obj.magic `bar) (* 4895187 *)\n print_int (Obj.magic 'foo) (* 5097222 *)\n\n Standards variants:\n -------------------\n\n [ocaml_repr] is the tag corresponding to the constructor within the type.\n the way it works in the ocaml runtime is by partitioning the constructors regarding\n if they have some arguments or not, preserving the order, then assign increasing\n index withing each partition.\n Example:\n\n {[\n type t = (* no arg *) (* args *)\n | A (* 0 *)\n | B of int (* 0 *)\n | C (* 1 *)\n | D of (float * string) (* 1 *)\n | E (* 2 *)\n | F (* 3 *)\n | G of string (* 2 *)\n | H of { x : int } (* 3 *)\n ]}\n *)\n val ocaml_repr : (_, _) t -> int\n\n (**\n Give back a way of constructing a value of that constructor from its arguments.\n\n Examples:\n\n {[\n type t =\n | A of (int * string)\n | B of int * float\n | C\n | D of { x : int; y : string }\n ]}\n\n [create] will return something equivalent to:\n tag_A : [Args (fun (d : (int * string) -> A d)]\n tag_B : [Args (fun (i, f) -> B (i, f))]\n tag_C : [Const C]\n tag_D : [Args (fun (x, y) -> D { x; y })]\n *)\n val create : ('variant, 'args) t -> ('variant, 'args) create\n\n (** return the type_name of the arguments. might be used to perform some lookup based\n on it while building a computation for example *)\n val tyid : (_, 'args) t -> 'args Typename.t\n\n (** get the representation/computation of the arguments *)\n val traverse : (_, 'args) t -> 'args X.t\n\n (* used by the camlp4 extension to build type witnesses, or by some internal parts of\n typerep. you should feel bad if you need to use it in some user code *)\n val internal_use_only : ('a, 'b) Tag_internal.t -> ('a, 'b) t\n end = struct\n include Tag_internal\n let label t = t.label\n let arity t = t.arity\n let args_labels t = t.args_labels\n let index t = t.index\n let ocaml_repr t = t.ocaml_repr\n let create t = t.create\n let tyid t = t.tyid\n let traverse t = t.rep\n\n let internal_use_only t = t\n end\n\n module Variant_internal = struct\n type _ tag = Tag : ('variant, 'a) Tag.t -> 'variant tag\n type _ value = Value : ('variant, 'a) Tag.t * 'a -> 'variant value\n type 'a t = {\n typename : 'a Typename.t;\n tags : 'a tag array;\n polymorphic : bool;\n value : 'a -> 'a value;\n }\n end\n\n module Variant : sig\n\n (**\n An existential type used to gather all the tags constituing a variant\n type. the ['variant] parameter is the variant type, it is the same for all the\n constructors of that variant type. The type of the parameters might be different\n for each constructor and is thus existential\n *)\n type _ tag = Tag : ('variant, 'args) Tag.t -> 'variant tag\n\n (**\n A similar existential constructor to [_ tag] but this one holds a value whose type\n is the arguments of the tag constructor. A value of type ['a value] is a pair of\n (1) a value of variant type ['a] along with (2) some information about the\n constructor within the type ['a]\n *)\n type _ value = Value : ('variant, 'args) Tag.t * 'args -> 'variant value\n\n (**\n Witness of a variant type. The parameter is the type of the variant type witnessed.\n *)\n type 'a t\n\n val typename_of_t : 'a t -> 'a Typename.t\n\n (**\n Returns the number of tags of this variant type definition.\n *)\n val length : 'a t -> int\n\n (**\n Get the nth tag of this variant type, indexed from 0.\n *)\n val tag : 'a t -> int -> 'a tag\n\n (**\n Distinguish polymorphic variants and standard variants. Typically, polymorphic\n variants tags starts with the [`] character.\n Example\n polymorphic variant: type t = [ `A | `B ]\n standard variant: type t = A | B\n *)\n val is_polymorphic : _ t -> bool\n\n (**\n Pattern matching on a value of this variant type.\n *)\n val value : 'a t -> 'a -> 'a value\n\n (**\n folding along the tags of the variant type\n *)\n val fold : 'a t -> init:'acc -> f:('acc -> 'a tag -> 'acc) -> 'acc\n\n (* used by the camlp4 extension to build type witnesses, or by some internal parts of\n typerep. you should feel bad if you need to use it in some user code *)\n val internal_use_only : 'a Variant_internal.t -> 'a t\n end = struct\n include Variant_internal\n let typename_of_t t = t.typename\n let length t = Array.length t.tags\n let tag t index = t.tags.(index)\n let is_polymorphic t = t.polymorphic\n let value t = t.value\n\n let fold t ~init ~f = Array.fold_left f init t.tags\n\n let internal_use_only t = t\n end\n\n module Field_internal = struct\n type ('record, 'field) t = {\n label : string;\n rep : 'field X.t;\n index : int;\n tyid : 'field Typename.t;\n get : ('record -> 'field);\n (* set : ('record -> 'field -> unit) option; (\\* mutable field *\\) *)\n is_mutable : bool;\n }\n end\n\n (**\n Witness of a field, that is an item in a record type.\n The first parameter is the record type, the second is the type of the field.\n Example:\n {[\n type t = { x : int ; y : string }\n ]}\n This type has two fields. for each of them we'll have a corresponding [Field.t]\n\n val field_x : (t, int) Field.t\n val field_y : (t, string) Field.t\n *)\n module Field : sig\n type ('record, 'field) t\n\n (**\n The name of the field as it is given in the concrete syntax\n Examples:\n {[\n { x : int; (* \"x\" *)\n foo : string; (* \"foo\" *)\n bar : float; (* \"bar\" *)\n }\n ]}\n *)\n val label : (_, _) t -> string\n\n (**\n The 0-based index of the field in the list of all fields for this record type.\n Example:\n {[\n type t = {\n x : int; (* 0 *)\n foo : string; (* 1 *)\n bar : string; (* 2 *)\n }\n ]}\n *)\n val index : (_, _) t -> int\n\n (**\n Field accessors. This corresponds to the dot operation.\n [Field.get bar_field t] returns the field [bar] of the record value [t], just the\n same as [t.bar]\n *)\n val get : ('record, 'field) t -> 'record -> 'field\n\n (** return whether the field is mutable, i.e. whether its declaration is prefixed with\n the keyword [mutable] *)\n val is_mutable : (_, _) t -> bool\n\n (** return the type_name of the arguments. Might be used to perform some lookup based\n on it *)\n val tyid : (_, 'field) t -> 'field Typename.t\n\n (** get the computation of the arguments *)\n val traverse : (_, 'field) t -> 'field X.t\n\n (* used by the camlp4 extension to build type witnesses, or by some internal parts of\n typerep. you should feel bad if you need to use it in some user code *)\n val internal_use_only : ('a, 'b) Field_internal.t -> ('a, 'b) t\n end = struct\n include Field_internal\n let label t = t.label\n let index t = t.index\n let get t = t.get\n let is_mutable t = t.is_mutable\n let tyid t = t.tyid\n let traverse t = t.rep\n\n let internal_use_only t = t\n end\n\n module Record_internal = struct\n type _ field = Field : ('record, 'a) Field.t -> 'record field\n type 'record fields = { get : 'field. ('record, 'field) Field.t -> 'field }\n type 'a t = {\n typename : 'a Typename.t;\n fields : 'a field array;\n has_double_array_tag : bool;\n create : 'a fields -> 'a;\n }\n end\n\n module Record : sig\n\n (**\n An existential type used to gather all the fields constituing a record type. the\n ['record] parameter is the record type, it is the same for all the field of that\n record type. The type of the fields might be different for each field and is thus\n existential.\n *)\n type _ field = Field : ('record, 'a) Field.t -> 'record field\n\n (**\n ['record fields] is a type isomorphic to ['record]. This gives a way to get the\n field value for each field of the record. The advantage of this representation is\n that it is convenient for writing generic computations.\n *)\n type 'record fields = { get : 'field. ('record, 'field) Field.t -> 'field }\n\n (**\n Witness of a record type. The parameter is the type of the record type witnessed.\n *)\n type 'a t\n\n val typename_of_t : 'a t -> 'a Typename.t\n\n (**\n Returns the number of fields of this record type definition.\n *)\n val length : 'a t -> int\n\n (**\n Get the nth field of this record type, indexed from 0.\n *)\n val field : 'a t -> int -> 'a field\n\n (**\n This is a low level metadata regarding the way the ocaml compiler represent the\n array underneath that is the runtime value of a record of type ['a] given a witness\n of type ['a t]. [has_double_array_tag w] returns [true] if the array that\n represents runtime values of this type is an optimized ocaml float array.\n Typically, this will be true for record where all fields are statically known as to\n be [floats].\n\n Note that you can't get this information dynamically by inspecting the typerep once\n it is applied, because there is at this point no way to tell whether one of the\n field is polymorphic in the type definition.\n *)\n val has_double_array_tag : _ t -> bool\n\n (**\n Expose one direction of the isomorphism between a value of type ['a] and a value of\n type ['a fields]. Basically, given an encoding way of accessing the value of all\n the fields of a record, create that record and return it.\n *)\n val create : 'a t -> 'a fields -> 'a\n\n (**\n folding along the tags of the variant type\n *)\n val fold : 'a t -> init:'acc -> f:('acc -> 'a field -> 'acc) -> 'acc\n\n (* used by the camlp4 extension to build type witnesses, or by some internal parts of\n typerep. you should feel bad if you need to use it in some user code *)\n val internal_use_only : 'a Record_internal.t -> 'a t\n end = struct\n include Record_internal\n let typename_of_t t = t.typename\n let length t = Array.length t.fields\n let field t index = t.fields.(index)\n let has_double_array_tag t = t.has_double_array_tag\n let create t = t.create\n let fold t ~init ~f = Array.fold_left f init t.fields\n\n let internal_use_only t = t\n end\nend\n\nmodule type S = sig\n type 'a t\n include (module type of M (struct type 'a rep = 'a t type 'a t = 'a rep end))\nend\n","(* using the hash_variant of pa_type_conv at compile time *)\nlet repr_of_poly_variant : [> ] -> int = fun variant ->\n let obj = Obj.repr variant in\n if Obj.is_int obj then Obj.obj obj\n else\n let size = Obj.size obj in\n assert (size = 2);\n let repr = Obj.field obj 0 in\n (assert (Obj.is_int repr));\n Obj.obj repr\n\nlet hash_variant s =\n let accu = ref 0 in\n for i = 0 to String.length s - 1 do\n accu := 223 * !accu + Char.code s.[i]\n done;\n (* reduce to 31 bits *)\n accu := !accu land (1 lsl 31 - 1);\n (* make it signed for 64 bits architectures *)\n if !accu > 0x3FFFFFFF then !accu - (1 lsl 31) else !accu\n\n(* a few unit tests of cases that have triggered diffs in the past of this\n lib *)\nlet () = assert (repr_of_poly_variant `Latency_stats = hash_variant \"Latency_stats\")\nlet () = assert (repr_of_poly_variant `zero = hash_variant \"zero\")\n\nlet double_array_value = Obj.magic 0.\nlet has_double_array_tag a = Obj.double_array_tag = (Obj.tag (Obj.repr a))\nlet () =\n let module M = struct\n type double = { a : float ; b : float }\n type simple = { c : float ; d : int }\n let double = { a = double_array_value; b = double_array_value; }\n let simple = { c = double_array_value; d = double_array_value; }\n end in\n assert (has_double_array_tag M.double);\n assert (not (has_double_array_tag M.simple));\n;;\n","open Std_internal\n\nmodule Make0 (X : Named_intf.S0) : Typerepable.S\n with type t := X.t\n= struct\n module M = Make_typename.Make0(X)\n let typerep_of_t =\n Typerep.Named (M.named, None)\n let typename_of_t = M.typename_of_t\nend\n\nmodule Make1 (X : Named_intf.S1) : Typerepable.S1\n with type 'a t := 'a X.t\n= struct\n module M = Make_typename.Make1(X)\n let typerep_of_t of_p1 =\n Typerep.Named (M.named of_p1, None)\n let typename_of_t = M.typename_of_t\nend\n\nmodule Make2 (X : Named_intf.S2) : Typerepable.S2\n with type ('a, 'b) t := ('a, 'b) X.t\n= struct\n module M = Make_typename.Make2(X)\n let typerep_of_t of_p1 of_p2 =\n Typerep.Named (M.named of_p1 of_p2, None)\n let typename_of_t = M.typename_of_t\nend\n\nmodule Make3 (X : Named_intf.S3) : Typerepable.S3\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) X.t\n= struct\n module M = Make_typename.Make3(X)\n let typerep_of_t of_p1 of_p2 of_p3 =\n Typerep.Named (M.named of_p1 of_p2 of_p3, None)\n let typename_of_t = M.typename_of_t\nend\n\nmodule Make4 (X : Named_intf.S4) : Typerepable.S4\n with type ('a, 'b, 'c, 'd) t := ('a, 'b, 'c, 'd) X.t\n= struct\n module M = Make_typename.Make4(X)\n let typerep_of_t of_p1 of_p2 of_p3 of_p4 =\n Typerep.Named (M.named of_p1 of_p2 of_p3 of_p4, None)\n let typename_of_t = M.typename_of_t\nend\n\nmodule Make5 (X : Named_intf.S5) : Typerepable.S5\n with type ('a, 'b, 'c, 'd, 'e) t := ('a, 'b, 'c, 'd, 'e) X.t\n= struct\n module M = Make_typename.Make5(X)\n let typerep_of_t of_p1 of_p2 of_p3 of_p4 of_p5 =\n Typerep.Named (M.named of_p1 of_p2 of_p3 of_p4 of_p5, None)\n let typename_of_t = M.typename_of_t\nend\n","open! Base\nopen Import\n\nmodule Name : sig\n type t [@@deriving_inline sexp, compare]\n\n include sig\n [@@@ocaml.warning \"-32\"]\n\n include Ppx_sexp_conv_lib.Sexpable.S with type t := t\n\n val compare : t -> t -> int\n end\n [@@ocaml.doc \"@inline\"]\n\n [@@@end]\n\n val relative_to : dir:string -> t -> string\n\n include Identifiable.S with type t := t\nend = struct\n include String\n\n let relative_to ~dir t =\n if not (Caml.Filename.is_relative t) then t else Caml.Filename.concat dir t\n ;;\nend\n\nlet initial_dir =\n let dir_or_error =\n match Caml.Sys.getcwd () with\n | v -> `Ok v\n | exception exn -> `Exn exn\n in\n fun () ->\n match dir_or_error with\n | `Ok v -> v\n | `Exn exn -> raise exn\n;;\n\nmodule Location = struct\n module T = struct\n type t =\n { filename : Name.t\n ; line_number : int\n ; line_start : int\n ; start_pos : int\n ; end_pos : int\n }\n [@@deriving_inline sexp, compare]\n\n let _ = fun (_ : t) -> ()\n\n let t_of_sexp =\n (let _tp_loc = \"file.ml.Location.T.t\" in\n function\n | Ppx_sexp_conv_lib.Sexp.List field_sexps as sexp ->\n let filename_field = ref Ppx_sexp_conv_lib.Option.None\n and line_number_field = ref Ppx_sexp_conv_lib.Option.None\n and line_start_field = ref Ppx_sexp_conv_lib.Option.None\n and start_pos_field = ref Ppx_sexp_conv_lib.Option.None\n and end_pos_field = ref Ppx_sexp_conv_lib.Option.None\n and duplicates = ref []\n and extra = ref [] in\n let rec iter = function\n | Ppx_sexp_conv_lib.Sexp.List\n (Ppx_sexp_conv_lib.Sexp.Atom field_name :: (([] | [ _ ]) as _field_sexps))\n :: tail ->\n let _field_sexp () =\n match _field_sexps with\n | [ x ] -> x\n | [] ->\n Ppx_sexp_conv_lib.Conv_error.record_only_pairs_expected _tp_loc sexp\n | _ -> assert false\n in\n (match field_name with\n | \"filename\" ->\n (match !filename_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = Name.t_of_sexp _field_sexp in\n filename_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ ->\n duplicates := field_name :: !duplicates)\n | \"line_number\" ->\n (match !line_number_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n line_number_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ ->\n duplicates := field_name :: !duplicates)\n | \"line_start\" ->\n (match !line_start_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n line_start_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ ->\n duplicates := field_name :: !duplicates)\n | \"start_pos\" ->\n (match !start_pos_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n start_pos_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ ->\n duplicates := field_name :: !duplicates)\n | \"end_pos\" ->\n (match !end_pos_field with\n | Ppx_sexp_conv_lib.Option.None ->\n let _field_sexp = _field_sexp () in\n let fvalue = int_of_sexp _field_sexp in\n end_pos_field := Ppx_sexp_conv_lib.Option.Some fvalue\n | Ppx_sexp_conv_lib.Option.Some _ ->\n duplicates := field_name :: !duplicates)\n | _ ->\n if !Ppx_sexp_conv_lib.Conv.record_check_extra_fields\n then extra := field_name :: !extra\n else ());\n iter tail\n | ((Ppx_sexp_conv_lib.Sexp.Atom _ | Ppx_sexp_conv_lib.Sexp.List _) as sexp)\n :: _ -> Ppx_sexp_conv_lib.Conv_error.record_only_pairs_expected _tp_loc sexp\n | [] -> ()\n in\n iter field_sexps;\n (match !duplicates with\n | _ :: _ ->\n Ppx_sexp_conv_lib.Conv_error.record_duplicate_fields _tp_loc !duplicates sexp\n | [] ->\n (match !extra with\n | _ :: _ ->\n Ppx_sexp_conv_lib.Conv_error.record_extra_fields _tp_loc !extra sexp\n | [] ->\n (match\n ( !filename_field\n , !line_number_field\n , !line_start_field\n , !start_pos_field\n , !end_pos_field )\n with\n | ( Ppx_sexp_conv_lib.Option.Some filename_value\n , Ppx_sexp_conv_lib.Option.Some line_number_value\n , Ppx_sexp_conv_lib.Option.Some line_start_value\n , Ppx_sexp_conv_lib.Option.Some start_pos_value\n , Ppx_sexp_conv_lib.Option.Some end_pos_value ) ->\n { filename = filename_value\n ; line_number = line_number_value\n ; line_start = line_start_value\n ; start_pos = start_pos_value\n ; end_pos = end_pos_value\n }\n | _ ->\n Ppx_sexp_conv_lib.Conv_error.record_undefined_elements\n _tp_loc\n sexp\n [ ( Ppx_sexp_conv_lib.Conv.( = )\n !filename_field\n Ppx_sexp_conv_lib.Option.None\n , \"filename\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !line_number_field\n Ppx_sexp_conv_lib.Option.None\n , \"line_number\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !line_start_field\n Ppx_sexp_conv_lib.Option.None\n , \"line_start\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !start_pos_field\n Ppx_sexp_conv_lib.Option.None\n , \"start_pos\" )\n ; ( Ppx_sexp_conv_lib.Conv.( = )\n !end_pos_field\n Ppx_sexp_conv_lib.Option.None\n , \"end_pos\" )\n ])))\n | Ppx_sexp_conv_lib.Sexp.Atom _ as sexp ->\n Ppx_sexp_conv_lib.Conv_error.record_list_instead_atom _tp_loc sexp\n : Ppx_sexp_conv_lib.Sexp.t -> t)\n ;;\n\n let _ = t_of_sexp\n\n let sexp_of_t =\n (function\n | { filename = v_filename\n ; line_number = v_line_number\n ; line_start = v_line_start\n ; start_pos = v_start_pos\n ; end_pos = v_end_pos\n } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_int v_end_pos in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"end_pos\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_start_pos in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"start_pos\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_line_start in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"line_start\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_int v_line_number in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"line_number\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = Name.sexp_of_t v_filename in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"filename\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n ;;\n\n let _ = sexp_of_t\n\n let compare =\n (fun a__001_ b__002_ ->\n if Ppx_compare_lib.phys_equal a__001_ b__002_\n then 0\n else (\n match Name.compare a__001_.filename b__002_.filename with\n | 0 ->\n (match compare_int a__001_.line_number b__002_.line_number with\n | 0 ->\n (match compare_int a__001_.line_start b__002_.line_start with\n | 0 ->\n (match compare_int a__001_.start_pos b__002_.start_pos with\n | 0 -> compare_int a__001_.end_pos b__002_.end_pos\n | n -> n)\n | n -> n)\n | n -> n)\n | n -> n)\n : t -> t -> int)\n ;;\n\n let _ = compare\n\n [@@@end]\n\n let compare a b =\n if not (Name.equal a.filename b.filename)\n then invalid_arg \"Expect_test_collector.File.Location.compare\"\n else compare a b\n ;;\n end\n\n include T\n include Comparable.Make (T)\n\n let beginning_of_file filename =\n { filename; line_number = 1; line_start = 0; start_pos = 0; end_pos = 0 }\n ;;\nend\n\nmodule Digest : sig\n type t [@@deriving_inline sexp_of, compare]\n\n include sig\n [@@@ocaml.warning \"-32\"]\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n val compare : t -> t -> int\n end\n [@@ocaml.doc \"@inline\"]\n\n [@@@end]\n\n val to_string : t -> string\n val of_string : string -> t\nend = struct\n type t = string [@@deriving_inline sexp_of, compare]\n\n let _ = fun (_ : t) -> ()\n let sexp_of_t = (sexp_of_string : t -> Ppx_sexp_conv_lib.Sexp.t)\n let _ = sexp_of_t\n let compare = (compare_string : t -> t -> int)\n let _ = compare\n\n [@@@end]\n\n let to_string t = t\n\n let of_string s =\n let expected_length = 32 in\n if String.length s <> expected_length\n then invalid_arg \"Expect_test_collector.File.Digest.of_string, unexpected length\";\n for i = 0 to expected_length - 1 do\n match s.[i] with\n | '0' .. '9' | 'a' .. 'f' -> ()\n | _ -> invalid_arg \"Expect_test_collector.File.Digest.of_string\"\n done;\n s\n ;;\nend\n","open Expect_test_common\nmodule List = ListLabels\n\nmodule Test_outcome = struct\n type t =\n { file_digest : File.Digest.t\n ; location : File.Location.t\n ; expectations : Expectation.Raw.t list\n ; uncaught_exn_expectation : Expectation.Raw.t option\n ; saved_output : (File.Location.t * string) list\n ; trailing_output : string\n ; upon_unreleasable_issue : Expect_test_config_types.Upon_unreleasable_issue.t\n ; uncaught_exn : (exn * Printexc.raw_backtrace) option\n }\nend\n\nlet tests_run : Test_outcome.t list ref = ref []\n\nlet protect ~finally ~f =\n match f () with\n | x ->\n finally ();\n x\n | exception e ->\n finally ();\n raise e\n;;\n\nmodule Current_file = struct\n let current = ref None\n\n let set ~absolute_filename =\n match !current with\n | None -> current := Some absolute_filename\n | Some _ -> failwith \"Expect_test_collector.set: already set\"\n ;;\n\n let unset () =\n match !current with\n | Some _ -> current := None\n | None -> failwith \"Expect_test_collector.unset: not set\"\n ;;\n\n let get () =\n match !current with\n | Some fn -> fn\n | None -> failwith \"Expect_test_collector.get: not set\"\n ;;\nend\n\nmodule Make (C : Expect_test_config_types.S) = struct\n let ( >>= ) t f = C.IO_flush.bind t ~f\n let return = C.IO_flush.return\n\n module C = struct\n include C\n\n let flush () =\n Format.pp_print_flush Format.std_formatter ();\n Format.pp_print_flush Format.err_formatter ();\n Caml.flush Caml.stdout;\n Caml.flush Caml.stderr;\n C.flush ()\n ;;\n end\n\n module Instance : sig\n val save_output : File.Location.t -> unit C.IO_flush.t\n val save_and_return_output : File.Location.t -> string C.IO_flush.t\n\n val exec\n : file_digest:File.Digest.t\n -> location:File.Location.t\n -> expectations:Expectation.Raw.t list\n -> uncaught_exn_expectation:Expectation.Raw.t option\n -> f:(unit -> unit C.IO_run.t)\n -> unit\n end = struct\n type t =\n { mutable saved : (File.Location.t * int) list\n ; chan : out_channel\n ; filename : File.Name.t\n }\n\n external before_test\n : output:out_channel\n -> stdout:out_channel\n -> stderr:out_channel\n -> unit\n = \"expect_test_collector_before_test\"\n\n external after_test\n : stdout:out_channel\n -> stderr:out_channel\n -> unit\n = \"expect_test_collector_after_test\"\n\n external pos_out : out_channel -> int = \"caml_out_channel_pos_fd\"\n\n let get_position () = pos_out stdout\n\n let create () =\n let filename = Filename.temp_file \"expect-test\" \"output\" in\n let chan = open_out_bin filename in\n before_test ~output:chan ~stdout ~stderr;\n { chan; filename = File.Name.of_string filename; saved = [] }\n ;;\n\n let extract_output ic len =\n let s = really_input_string ic len in\n if not (Check_backtraces.contains_backtraces s)\n then s\n else\n Expect_test_config_types.Upon_unreleasable_issue\n .message_when_expectation_contains_backtrace\n C.upon_unreleasable_issue\n ^ s\n ;;\n\n let relative_filename t = File.Name.relative_to ~dir:(File.initial_dir ()) t.filename\n\n let with_ic fname ~f =\n let ic = open_in_bin fname in\n protect ~finally:(fun () -> close_in ic) ~f:(fun () -> f ic)\n ;;\n\n let get_outputs_and_cleanup t =\n let last_ofs = get_position () in\n after_test ~stdout ~stderr;\n close_out t.chan;\n let fname = relative_filename t in\n protect\n ~finally:(fun () -> Sys.remove fname)\n ~f:(fun () ->\n with_ic fname ~f:(fun ic ->\n let ofs, outputs =\n List.fold_left\n (List.rev t.saved)\n ~init:(0, [])\n ~f:(fun (ofs, acc) (loc, next_ofs) ->\n let s = extract_output ic (next_ofs - ofs) in\n next_ofs, (loc, s) :: acc)\n in\n let trailing_output = extract_output ic (last_ofs - ofs) in\n List.rev outputs, trailing_output))\n ;;\n\n let current_test : (File.Location.t * t) option ref = ref None\n\n let get_current () =\n match !current_test with\n | Some (_, t) -> t\n | None ->\n failwith \"Expect_test_collector.Instance.get_current called outside a test.\"\n ;;\n\n let save_output location =\n let t = get_current () in\n C.flush ()\n >>= fun () ->\n let pos = get_position () in\n t.saved <- (location, pos) :: t.saved;\n return ()\n ;;\n\n let save_and_return_output location =\n let t = get_current () in\n C.flush ()\n >>= fun () ->\n let pos = get_position () in\n let prev_pos =\n match t.saved with\n | [] -> 0\n | (_, prev_pos) :: _ -> prev_pos\n in\n t.saved <- (location, pos) :: t.saved;\n flush t.chan;\n let len = pos - prev_pos in\n return\n (with_ic (relative_filename t) ~f:(fun ic ->\n seek_in ic prev_pos;\n really_input_string ic len))\n ;;\n\n let () =\n Caml.at_exit (fun () ->\n match !current_test with\n | None -> ()\n | Some (loc, t) ->\n let blocks, trailing = get_outputs_and_cleanup t in\n Printf.eprintf\n \"File %S, line %d, characters %d-%d:\\n\\\n Error: program exited while expect test was running!\\n\\\n Output captured so far:\\n\\\n %!\"\n (File.Name.to_string loc.filename)\n loc.line_number\n (loc.start_pos - loc.line_start)\n (loc.end_pos - loc.line_start);\n List.iter blocks ~f:(fun (_, s) -> Printf.eprintf \"%s%!\" s);\n Printf.eprintf \"%s%!\" trailing)\n ;;\n\n let rec final_flush ?(count = 0) k =\n let max_attempts = 10 in\n C.flush ()\n >>= fun () ->\n if C.flushed ()\n then k ~append:\"\"\n else if count = max_attempts\n then\n k\n ~append:\n (Printf.sprintf\n \"\\n\\\n STOPPED COLLECTING OUTPUT AFTER %d FLUSHING ATTEMPS\\n\\\n THERE MUST BE A BACKGROUND JOB PRINTING TO STDOUT\\n\"\n max_attempts)\n else final_flush ~count:(count + 1) k\n ;;\n\n let exec ~file_digest ~location ~expectations ~uncaught_exn_expectation ~f =\n let t = create () in\n current_test := Some (location, t);\n let finally uncaught_exn =\n C.run (fun () ->\n C.IO_flush.to_run\n (final_flush (fun ~append ->\n current_test := None;\n let saved_output, trailing_output = get_outputs_and_cleanup t in\n tests_run\n := { file_digest\n ; location\n ; expectations\n ; uncaught_exn_expectation\n ; saved_output\n ; trailing_output = trailing_output ^ append\n ; upon_unreleasable_issue = C.upon_unreleasable_issue\n ; uncaught_exn\n }\n :: !tests_run;\n return ())))\n in\n match C.run f with\n | () -> finally None\n | exception exn ->\n let bt = Printexc.get_raw_backtrace () in\n finally (Some (exn, bt))\n ;;\n end\n\n let save_output = Instance.save_output\n let save_and_return_output = Instance.save_and_return_output\n\n let run\n ~file_digest\n ~(location : File.Location.t)\n ~absolute_filename:defined_in\n ~description\n ~tags\n ~expectations\n ~uncaught_exn_expectation\n ~inline_test_config\n f\n =\n Ppx_inline_test_lib.Runtime.test\n ~config:inline_test_config\n ~descr:\n (match description with\n | None -> \"\"\n | Some s -> \": \" ^ s)\n ~tags\n ~filename:(File.Name.to_string location.filename)\n ~line_number:location.line_number\n ~start_pos:(location.start_pos - location.line_start)\n ~end_pos:(location.end_pos - location.line_start)\n (fun () ->\n let registering_tests_for = Current_file.get () in\n if defined_in <> registering_tests_for\n then\n Printf.ksprintf\n failwith\n \"Trying to run an expect test from the wrong file.\\n\\\n - test declared at %s:%d\\n\\\n - trying to run it from %s\\n\"\n defined_in\n location.line_number\n registering_tests_for\n else (\n (* To avoid capturing not-yet flushed data of the stdout buffer *)\n C.run (fun () -> C.IO_flush.to_run (C.flush ()));\n Instance.exec ~file_digest ~location ~expectations ~uncaught_exn_expectation ~f;\n true))\n ;;\nend\n[@@inline never]\n\nlet tests_run () =\n (* We prepend tests when we encounter them, so reverse the list to reinstate order *)\n List.rev !tests_run\n;;\n","module Upon_unreleasable_issue = struct\n type t =\n [ `CR (** Leaves a CR, so that features cannot be released. *)\n | `Warning_for_collector_testing (** Only for ppx_expect testing; do not use. *)\n ]\nend\n\nmodule type S = sig\n module IO_run : sig\n type 'a t\n end\n\n module IO_flush : sig\n type 'a t\n\n val return : 'a -> 'a t\n val bind : 'a t -> f:('a -> 'b t) -> 'b t\n val to_run : 'a t -> 'a IO_run.t\n end\n\n (** Flush whatever need to be to get pending output out on file descriptor 0. *)\n val flush : unit -> unit IO_flush.t\n\n (** Run an IO operation until completion *)\n val run : (unit -> unit IO_run.t) -> unit\n\n (** Synchronous check that there is no pending output on file description 0. With async,\n there is no guarantee that on the rhs of a [IO.bind (flush ()) ...] the output is\n completely flushed, that's why we need this. *)\n val flushed : unit -> bool\n\n\n (** [upon_unreleasable_issue] specifies how to deal with output that should not be\n released even if it is accepted (e.g. backtraces). The default is [`CR]. *)\n val upon_unreleasable_issue : Upon_unreleasable_issue.t\nend\n\n(** Configuration for running expect tests *)\nmodule type Expect_test_config_types = sig\n (** To configure expect_test, add the following at the top of your .ml file, or in some\n import.ml:\n\n {[\n module Expect_test_config = struct\n include Expect_test_config\n let pre_redirect_hook () = ...\n end\n ]}\n\n Note that since all expect test are also inline tests, the inline test configuration\n also applies to all expect test.\n *)\n\n module Upon_unreleasable_issue : sig\n include module type of Upon_unreleasable_issue\n\n val equal : t -> t -> bool\n val comment_prefix : t -> string\n\n (** Message to print when an expectation contains a backtrace *)\n val message_when_expectation_contains_backtrace : t -> string\n end\n\n module type S = S\nend\n","module type S = Expect_test_config_types_intf.S\n\nmodule type Expect_test_config_types =\n Expect_test_config_types_intf.Expect_test_config_types\n\nmodule Upon_unreleasable_issue = struct\n include Expect_test_config_types_intf.Upon_unreleasable_issue\n\n let equal t1 t2 = t1 = t2\n\n let comment_prefix = function\n | `CR -> \"CR \"\n | `Warning_for_collector_testing -> \"\"\n ;;\n\n let message_when_expectation_contains_backtrace t =\n Printf.sprintf\n {|\n(* %sexpect_test_collector: This test expectation appears to contain a backtrace.\n This is strongly discouraged as backtraces are fragile.\n Please change this test to not include a backtrace. *)\n\n|}\n (comment_prefix t)\n ;;\nend\n","module IO_run = struct\n type 'a t = 'a\n\n let return x = x\n let bind t ~f = f t\nend\n\nmodule IO_flush = struct\n include IO_run\n\n let to_run t = t\nend\n\nlet flush () = () (* the runtime already flushes [stdout] *)\n\nlet run f = f ()\nlet flushed () = true (* the runtime flushed [stdout] before calling this function *)\n\nlet upon_unreleasable_issue = `CR\n","open! Base\n\nmodule T : sig\n type +'a t\n\n val create : (size:int -> random:Splittable_random.State.t -> 'a) -> 'a t\n val generate : 'a t -> size:int -> random:Splittable_random.State.t -> 'a\nend = struct\n type 'a t = (size:int -> random:Splittable_random.State.t -> 'a) Staged.t\n\n let create f : _ t = Staged.stage f\n\n let generate (t : _ t) ~size ~random =\n if size < 0\n then raise_s [%message \"Base_quickcheck.Generator.generate: size < 0\" (size : int)]\n else Staged.unstage t ~size ~random\n ;;\nend\n\ninclude T\n\nlet size = create (fun ~size ~random:_ -> size)\n\nlet fn dom rng =\n create (fun ~size ~random ->\n let random = Splittable_random.State.split random in\n fun x ->\n let hash = Observer0.observe dom x ~size ~hash:(Hash.alloc ()) in\n let random = Splittable_random.State.copy random in\n Splittable_random.State.perturb random (Hash.get_hash_value hash);\n generate rng ~size ~random)\n;;\n\nlet with_size t ~size = create (fun ~size:_ ~random -> generate t ~size ~random)\n\nlet perturb t salt =\n create (fun ~size ~random ->\n Splittable_random.State.perturb random salt;\n generate t ~size ~random)\n;;\n\nlet filter_map t ~f =\n let rec loop ~size ~random =\n let x = generate t ~size ~random in\n match f x with\n | Some y -> y\n | None -> loop ~size:(size + 1) ~random\n in\n create loop\n;;\n\nlet filter t ~f = filter_map t ~f:(fun x -> if f x then Some x else None)\nlet return x = create (fun ~size:_ ~random:_ -> x)\nlet map t ~f = create (fun ~size ~random -> f (generate t ~size ~random))\n\nlet apply tf tx =\n create (fun ~size ~random ->\n let f = generate tf ~size ~random in\n let x = generate tx ~size ~random in\n f x)\n;;\n\nlet bind t ~f =\n create (fun ~size ~random ->\n let x = generate t ~size ~random in\n generate (f x) ~size ~random)\n;;\n\nlet all list = create (fun ~size ~random -> List.map list ~f:(generate ~size ~random))\n\nlet all_unit list =\n create (fun ~size ~random -> List.iter list ~f:(generate ~size ~random))\n;;\n\nmodule For_applicative = Applicative.Make (struct\n type nonrec 'a t = 'a t\n\n let return = return\n let apply = apply\n let map = `Custom map\n end)\n\nlet both = For_applicative.both\nlet map2 = For_applicative.map2\nlet map3 = For_applicative.map3\n\nmodule Applicative_infix = For_applicative.Applicative_infix\ninclude Applicative_infix\n\nmodule For_monad = Monad.Make (struct\n type nonrec 'a t = 'a t\n\n let return = return\n let bind = bind\n let map = `Custom map\n end)\n\nlet ignore_m = For_monad.ignore_m\nlet join = For_monad.join\n\nmodule Monad_infix = For_monad.Monad_infix\ninclude Monad_infix\nmodule Let_syntax = For_monad.Let_syntax\nopen Let_syntax\n\nlet of_list list =\n if List.is_empty list\n then Error.raise_s [%message \"Base_quickcheck.Generator.of_list: empty list\"];\n let array = Array.of_list list in\n let lo = 0 in\n let hi = Array.length array - 1 in\n create (fun ~size:_ ~random ->\n let index = Splittable_random.int random ~lo ~hi in\n array.(index))\n;;\n\nlet union list = join (of_list list)\n\nlet of_weighted_list alist =\n if List.is_empty alist\n then Error.raise_s [%message \"Base_quickcheck.Generator.of_weighted_list: empty list\"];\n let weights, values = List.unzip alist in\n let value_array = Array.of_list values in\n let total_weight, cumulative_weight_array =\n let array = Array.init (Array.length value_array) ~f:(fun _ -> 0.) in\n let sum =\n List.foldi weights ~init:0. ~f:(fun index acc weight ->\n if not (Float.is_finite weight)\n then\n Error.raise_s\n [%message\n \"Base_quickcheck.Generator.of_weighted_list: weight is not finite\"\n (weight : float)];\n if Float.( < ) weight 0.\n then\n Error.raise_s\n [%message\n \"Base_quickcheck.Generator.of_weighted_list: weight is negative\"\n (weight : float)];\n let cumulative = acc +. weight in\n array.(index) <- cumulative;\n cumulative)\n in\n if Float.( <= ) sum 0.\n then\n Error.raise_s\n [%message \"Base_quickcheck.Generator.of_weighted_list: total weight is zero\"];\n sum, array\n in\n create (fun ~size:_ ~random ->\n let choice = Splittable_random.float random ~lo:0. ~hi:total_weight in\n match\n Array.binary_search\n cumulative_weight_array\n ~compare:Float.compare\n `First_greater_than_or_equal_to\n choice\n with\n | Some index -> value_array.(index)\n | None -> assert false)\n;;\n\nlet weighted_union alist = join (of_weighted_list alist)\nlet of_lazy lazy_t = create (fun ~size ~random -> generate (force lazy_t) ~size ~random)\n\nlet fixed_point of_generator =\n let rec lazy_t = lazy (of_generator (of_lazy lazy_t)) in\n force lazy_t\n;;\n\nlet weighted_recursive_union nonrec_list ~f =\n fixed_point (fun self ->\n let rec_list =\n List.map (f self) ~f:(fun (w, t) ->\n ( w\n , let%bind n = size in\n with_size ~size:(n - 1) t ))\n in\n if List.is_empty nonrec_list || List.is_empty rec_list\n then\n raise_s\n [%message\n \"Base_quickcheck.Generator.weighted_recursive_union: lists must be non-empty\"];\n let nonrec_gen = weighted_union nonrec_list in\n let rec_gen = weighted_union (nonrec_list @ rec_list) in\n match%bind size with\n | 0 -> nonrec_gen\n | _ -> rec_gen)\n;;\n\nlet recursive_union nonrec_list ~f =\n let weighted list = List.map list ~f:(fun t -> 1., t) in\n weighted_recursive_union (weighted nonrec_list) ~f:(fun self -> weighted (f self))\n;;\n\nlet sizes ?(min_length = 0) ?(max_length = Int.max_value) () =\n create (fun ~size ~random ->\n assert (min_length <= max_length);\n let upper_bound = min_length + size in\n let max_length =\n if upper_bound >= min_length (* guard against overflow *)\n then min max_length upper_bound\n else max_length\n in\n (* pick a length, weighted low so that most of the size is spent on elements *)\n let len = Splittable_random.Log_uniform.int random ~lo:min_length ~hi:max_length in\n (* if there are no elements return an empty array, otherwise return a non-empty array\n with the size distributed among the elements *)\n if len = 0\n then []\n else (\n let sizes = Array.init len ~f:(fun _ -> 0) in\n let remaining = size - (len - min_length) in\n let max_index = len - 1 in\n for _ = 1 to remaining do\n (* pick an index, weighted low so that we see unbalanced distributions often *)\n let index = Splittable_random.Log_uniform.int random ~lo:0 ~hi:max_index in\n sizes.(index) <- sizes.(index) + 1\n done;\n (* permute the array so that no index is favored over another *)\n for i = 0 to max_index - 1 do\n let j = Splittable_random.int random ~lo:i ~hi:max_index in\n Array.swap sizes i j\n done;\n assert (Array.sum (module Int) sizes ~f:Fn.id + (len - min_length) = size);\n Array.to_list sizes))\n;;\n\nlet unit = return ()\nlet bool = create (fun ~size:_ ~random -> Splittable_random.bool random)\nlet option value_t = union [ return None; map value_t ~f:Option.return ]\nlet either fst_t snd_t = union [ map fst_t ~f:Either.first; map snd_t ~f:Either.second ]\n\nlet result ok_t err_t =\n map (either ok_t err_t) ~f:(function\n | First ok -> Ok ok\n | Second err -> Error err)\n;;\n\nlet list_generic ?min_length ?max_length elt_gen =\n let%bind sizes = sizes ?min_length ?max_length () in\n List.map sizes ~f:(fun size -> with_size ~size elt_gen) |> all\n;;\n\nlet list elt_gen = list_generic elt_gen\nlet list_non_empty elt_gen = list_generic ~min_length:1 elt_gen\n\nlet list_with_length elt_gen ~length =\n list_generic ~min_length:length ~max_length:length elt_gen\n;;\n\nlet list_filtered elts =\n let elts = Array.of_list elts in\n let length_of_input = Array.length elts in\n create (fun ~size:_ ~random ->\n let length_of_output = Splittable_random.int random ~lo:0 ~hi:length_of_input in\n let indices = Array.init length_of_input ~f:Fn.id in\n (* Choose [length_of_output] random values in the prefix of [indices]. *)\n for i = 0 to length_of_output - 1 do\n let j = Splittable_random.int random ~lo:i ~hi:(length_of_input - 1) in\n Array.swap indices i j\n done;\n (* Sort the chosen indices because we don't want to reorder them. *)\n Array.sort indices ~pos:0 ~len:length_of_output ~compare:Int.compare;\n (* Return the chosen elements. *)\n List.init length_of_output ~f:(fun i -> elts.(indices.(i))))\n;;\n\nlet list_permutations list =\n create (fun ~size:_ ~random ->\n let array = Array.of_list list in\n for i = 1 to Array.length array - 1 do\n let j = Splittable_random.int random ~lo:0 ~hi:i in\n Array.swap array i j\n done;\n Array.to_list array)\n;;\n\nlet char_uniform_inclusive lo hi =\n create (fun ~size:_ ~random ->\n Splittable_random.int random ~lo:(Char.to_int lo) ~hi:(Char.to_int hi)\n |> Char.unsafe_of_int)\n;;\n\nlet char_uppercase = char_uniform_inclusive 'A' 'Z'\nlet char_lowercase = char_uniform_inclusive 'a' 'z'\nlet char_digit = char_uniform_inclusive '0' '9'\nlet char_print_uniform = char_uniform_inclusive ' ' '~'\nlet char_uniform = char_uniform_inclusive Char.min_value Char.max_value\nlet char_alpha = union [ char_lowercase; char_uppercase ]\n\nlet char_alphanum =\n weighted_union\n (* Most people probably expect this to be a uniform distribution, not weighted\n toward digits like we would get with [union] (since there are fewer digits than\n letters). *)\n [ 52., char_alpha; 10., char_digit ]\n;;\n\nlet char_whitespace = of_list (List.filter Char.all ~f:Char.is_whitespace)\nlet char_print = weighted_union [ 10., char_alphanum; 1., char_print_uniform ]\n\nlet char =\n weighted_union\n [ 100., char_print\n ; 10., char_uniform\n ; 1., return Char.min_value\n ; 1., return Char.max_value\n ]\n;;\n\n(* Produces a number from 0 or 1 to size + 1, weighted high. We have found this\n distribution empirically useful for string lengths. *)\nlet small_int ~allow_zero =\n create (fun ~size ~random ->\n let lower_bound = if allow_zero then 0 else 1 in\n let upper_bound = size + 1 in\n let weighted_low =\n Splittable_random.Log_uniform.int random ~lo:0 ~hi:(upper_bound - lower_bound)\n in\n let weighted_high = upper_bound - weighted_low in\n weighted_high)\n;;\n\nlet small_positive_or_zero_int = small_int ~allow_zero:true\nlet small_strictly_positive_int = small_int ~allow_zero:false\n\nmodule type Int_with_random = sig\n include Int.S\n\n val uniform : Splittable_random.State.t -> lo:t -> hi:t -> t\n val log_uniform : Splittable_random.State.t -> lo:t -> hi:t -> t\nend\n\nmodule For_integer (Integer : Int_with_random) = struct\n let uniform_inclusive lo hi =\n create (fun ~size:_ ~random -> Integer.uniform random ~lo ~hi)\n ;;\n\n let log_uniform_inclusive lo hi =\n create (fun ~size:_ ~random -> Integer.log_uniform random ~lo ~hi)\n ;;\n\n let non_uniform f lo hi =\n weighted_union [ 0.05, return lo; 0.05, return hi; 0.9, f lo hi ]\n ;;\n\n let inclusive = non_uniform uniform_inclusive\n let log_inclusive = non_uniform log_uniform_inclusive\n let uniform_all = uniform_inclusive Integer.min_value Integer.max_value\n\n let all =\n [%map\n let negative = bool\n and magnitude = log_inclusive Integer.zero Integer.max_value in\n if negative then Integer.bit_not magnitude else magnitude]\n ;;\nend\n\nmodule For_int = For_integer (struct\n include Int\n\n let uniform = Splittable_random.int\n let log_uniform = Splittable_random.Log_uniform.int\n end)\n\nlet int = For_int.all\nlet int_uniform = For_int.uniform_all\nlet int_inclusive = For_int.inclusive\nlet int_uniform_inclusive = For_int.uniform_inclusive\nlet int_log_inclusive = For_int.log_inclusive\nlet int_log_uniform_inclusive = For_int.log_uniform_inclusive\n\nmodule For_int32 = For_integer (struct\n include Int32\n\n let uniform = Splittable_random.int32\n let log_uniform = Splittable_random.Log_uniform.int32\n end)\n\nlet int32 = For_int32.all\nlet int32_uniform = For_int32.uniform_all\nlet int32_inclusive = For_int32.inclusive\nlet int32_uniform_inclusive = For_int32.uniform_inclusive\nlet int32_log_inclusive = For_int32.log_inclusive\nlet int32_log_uniform_inclusive = For_int32.log_uniform_inclusive\n\nmodule For_int63 = For_integer (struct\n include Int63\n\n let uniform = Splittable_random.int63\n let log_uniform = Splittable_random.Log_uniform.int63\n end)\n\nlet int63 = For_int63.all\nlet int63_uniform = For_int63.uniform_all\nlet int63_inclusive = For_int63.inclusive\nlet int63_uniform_inclusive = For_int63.uniform_inclusive\nlet int63_log_inclusive = For_int63.log_inclusive\nlet int63_log_uniform_inclusive = For_int63.log_uniform_inclusive\n\nmodule For_int64 = For_integer (struct\n include Int64\n\n let uniform = Splittable_random.int64\n let log_uniform = Splittable_random.Log_uniform.int64\n end)\n\nlet int64 = For_int64.all\nlet int64_uniform = For_int64.uniform_all\nlet int64_inclusive = For_int64.inclusive\nlet int64_uniform_inclusive = For_int64.uniform_inclusive\nlet int64_log_inclusive = For_int64.log_inclusive\nlet int64_log_uniform_inclusive = For_int64.log_uniform_inclusive\n\nmodule For_nativeint = For_integer (struct\n include Nativeint\n\n let uniform = Splittable_random.nativeint\n let log_uniform = Splittable_random.Log_uniform.nativeint\n end)\n\nlet nativeint = For_nativeint.all\nlet nativeint_uniform = For_nativeint.uniform_all\nlet nativeint_inclusive = For_nativeint.inclusive\nlet nativeint_uniform_inclusive = For_nativeint.uniform_inclusive\nlet nativeint_log_inclusive = For_nativeint.log_inclusive\nlet nativeint_log_uniform_inclusive = For_nativeint.log_uniform_inclusive\nlet float_zero_exponent = Float.ieee_exponent 0.\nlet float_zero_mantissa = Float.ieee_mantissa 0.\n\nlet float_max_positive_subnormal_value =\n Float.one_ulp `Down Float.min_positive_normal_value\n;;\n\nlet float_subnormal_exponent = Float.ieee_exponent Float.min_positive_subnormal_value\nlet float_min_subnormal_mantissa = Float.ieee_mantissa Float.min_positive_subnormal_value\nlet float_max_subnormal_mantissa = Float.ieee_mantissa float_max_positive_subnormal_value\nlet float_max_positive_normal_value = Float.max_finite_value\nlet float_min_normal_exponent = Float.ieee_exponent Float.min_positive_normal_value\nlet float_max_normal_exponent = Float.ieee_exponent float_max_positive_normal_value\nlet float_max_normal_mantissa = Float.ieee_mantissa float_max_positive_normal_value\nlet float_inf_exponent = Float.ieee_exponent Float.infinity\nlet float_inf_mantissa = Float.ieee_mantissa Float.infinity\nlet float_nan_exponent = Float.ieee_exponent Float.nan\nlet float_min_nan_mantissa = Int63.succ float_inf_mantissa\nlet float_max_nan_mantissa = float_max_normal_mantissa\nlet float_num_mantissa_bits = 52\n\n(* We weight mantissas so that \"integer-like\" values, and values with only a few digits\n past the decimal, are reasonably common. *)\nlet float_normal_mantissa =\n let%bind num_bits = For_int.uniform_inclusive 0 float_num_mantissa_bits in\n let%map bits =\n For_int63.inclusive Int63.zero (Int63.pred (Int63.shift_left Int63.one num_bits))\n in\n Int63.shift_left bits (Int.( - ) float_num_mantissa_bits num_bits)\n;;\n\nlet float_exponent_weighted_low lower_bound upper_bound =\n let%map offset = For_int.log_inclusive 0 (Int.( - ) upper_bound lower_bound) in\n Int.( + ) lower_bound offset\n;;\n\nlet float_exponent_weighted_high lower_bound upper_bound =\n let%map offset = For_int.log_inclusive 0 (Int.( - ) upper_bound lower_bound) in\n Int.( - ) upper_bound offset\n;;\n\n(* We weight exponents such that values near 1 are more likely. *)\nlet float_exponent =\n let midpoint = Float.ieee_exponent 1. in\n union\n [ float_exponent_weighted_high float_min_normal_exponent midpoint\n ; float_exponent_weighted_low midpoint float_max_normal_exponent\n ]\n;;\n\nlet float_zero =\n let%map negative = bool in\n Float.create_ieee_exn\n ~negative\n ~exponent:float_zero_exponent\n ~mantissa:float_zero_mantissa\n;;\n\nlet float_subnormal =\n let%map negative = bool\n and exponent = return float_subnormal_exponent\n and mantissa =\n For_int63.log_inclusive float_min_subnormal_mantissa float_max_subnormal_mantissa\n in\n Float.create_ieee_exn ~negative ~exponent ~mantissa\n;;\n\nlet float_normal =\n let%map negative = bool\n and exponent = float_exponent\n and mantissa = float_normal_mantissa in\n Float.create_ieee_exn ~negative ~exponent ~mantissa\n;;\n\nlet float_infinite =\n let%map negative = bool in\n Float.create_ieee_exn\n ~negative\n ~exponent:float_inf_exponent\n ~mantissa:float_inf_mantissa\n;;\n\nlet float_nan =\n let%map negative = bool\n and exponent = return float_nan_exponent\n and mantissa = For_int63.inclusive float_min_nan_mantissa float_max_nan_mantissa in\n Float.create_ieee_exn ~negative ~exponent ~mantissa\n;;\n\nlet float_of_class c =\n match (c : Float.Class.t) with\n | Zero -> float_zero\n | Subnormal -> float_subnormal\n | Normal -> float_normal\n | Infinite -> float_infinite\n | Nan -> float_nan\n;;\n\nlet float_weight_of_class c =\n match (c : Float.Class.t) with\n | Zero -> 1.\n | Subnormal -> 10.\n | Normal -> 100.\n | Infinite -> 1.\n | Nan -> 1.\n;;\n\nlet float_matching_classes filter =\n List.filter_map Float.Class.all ~f:(fun c ->\n if filter c then Some (float_weight_of_class c, float_of_class c) else None)\n |> weighted_union\n;;\n\nlet float_finite =\n float_matching_classes (function\n | Zero | Subnormal | Normal -> true\n | Infinite | Nan -> false)\n;;\n\nlet float_without_nan =\n float_matching_classes (function\n | Zero | Subnormal | Normal | Infinite -> true\n | Nan -> false)\n;;\n\nlet float = float_matching_classes (fun _ -> true)\n\nlet float_finite_non_zero =\n float_matching_classes (function\n | Subnormal | Normal -> true\n | Zero | Infinite | Nan -> false)\n;;\n\nlet float_strictly_positive =\n let%map t = float_finite_non_zero in\n Float.abs t\n;;\n\nlet float_strictly_negative =\n let%map t = float_finite_non_zero in\n ~-.(Float.abs t)\n;;\n\nlet float_positive_or_zero =\n let%map t = float_finite in\n Float.abs t\n;;\n\nlet float_negative_or_zero =\n let%map t = float_finite in\n ~-.(Float.abs t)\n;;\n\nlet float_uniform_exclusive lower_bound upper_bound =\n let open Float.O in\n if (not (Float.is_finite lower_bound)) || not (Float.is_finite upper_bound)\n then\n raise_s\n [%message\n \"Float.uniform_exclusive: bounds are not finite\"\n (lower_bound : float)\n (upper_bound : float)];\n let lower_inclusive = Float.one_ulp `Up lower_bound in\n let upper_inclusive = Float.one_ulp `Down upper_bound in\n if lower_inclusive > upper_inclusive\n then\n raise_s\n [%message\n \"Float.uniform_exclusive: requested range is empty\"\n (lower_bound : float)\n (upper_bound : float)];\n create (fun ~size:_ ~random ->\n Splittable_random.float random ~lo:lower_inclusive ~hi:upper_inclusive)\n;;\n\nlet float_inclusive lower_bound upper_bound =\n weighted_union\n [ 0.05, return lower_bound\n ; 0.05, return upper_bound\n ; 0.9, float_uniform_exclusive lower_bound upper_bound\n ]\n;;\n\nlet string_with_length_of char_gen ~length =\n list_with_length char_gen ~length |> map ~f:String.of_char_list\n;;\n\nlet string_of char_gen =\n bind small_positive_or_zero_int ~f:(fun length ->\n string_with_length_of char_gen ~length)\n;;\n\nlet string_non_empty_of char_gen =\n bind small_strictly_positive_int ~f:(fun length ->\n string_with_length_of char_gen ~length)\n;;\n\nlet string = string_of char\nlet string_non_empty = string_non_empty_of char\nlet string_with_length ~length = string_with_length_of char ~length\n\nlet sexp_of atom =\n fixed_point (fun self ->\n let%bind size = size in\n (* choose a number weighted low so we have a decreasing, but not vanishing, chance\n to generate atoms as size grows *)\n match%bind For_int.log_uniform_inclusive 0 (size + 1) with\n (* generate an atom using the given size *)\n | 0 ->\n let%map atom = atom in\n Sexp.Atom atom\n (* relying on [List.gen] to distribute [size] over sub-sexps *)\n | _ ->\n let%map list = list self in\n Sexp.List list)\n;;\n\nlet sexp = sexp_of string\n\nlet map_tree_using_comparator ~comparator key_gen data_gen =\n let%bind keys = list key_gen in\n let keys = List.dedup_and_sort keys ~compare:comparator.Comparator.compare in\n let%bind data = list_with_length data_gen ~length:(List.length keys) in\n return (Map.Using_comparator.Tree.of_alist_exn ~comparator (List.zip_exn keys data))\n;;\n\nlet set_tree_using_comparator ~comparator elt_gen =\n map (list elt_gen) ~f:(Set.Using_comparator.Tree.of_list ~comparator)\n;;\n\nlet comparator_of_m\n (type a c)\n (module M : Comparator.S with type t = a and type comparator_witness = c)\n =\n M.comparator\n;;\n\nlet map_t_m m key_gen data_gen =\n let comparator = comparator_of_m m in\n map_tree_using_comparator ~comparator key_gen data_gen\n |> map ~f:(Map.Using_comparator.of_tree ~comparator)\n;;\n\nlet set_t_m m elt_gen =\n let comparator = comparator_of_m m in\n set_tree_using_comparator ~comparator elt_gen\n |> map ~f:(Set.Using_comparator.of_tree ~comparator)\n;;\n\nlet bigarray1 t kind layout =\n let%map elts = list t in\n let elts = Array.of_list elts in\n let dim = Array.length elts in\n let offset = Bigarray_helpers.Layout.offset layout in\n Bigarray_helpers.Array1.init kind layout dim ~f:(fun i -> elts.(i - offset))\n;;\n\nlet bigstring = bigarray1 char Char C_layout\nlet float32_vec = bigarray1 float Float32 Fortran_layout\nlet float64_vec = bigarray1 float Float64 Fortran_layout\n\nlet bigarray2_dim =\n match%bind size with\n | 0 -> return (0, 0)\n | max_total_size ->\n let%bind a =\n (* choose a dimension up to [max_total_size], weighted low to give the other\n dimension a good chance of being comparatively high *)\n int_log_uniform_inclusive 1 max_total_size\n in\n let%bind b =\n (* choose a dimension up to [max_total_size / a], weighted high to reach close to\n [max_total_size] most of the time *)\n let max_b = max_total_size / a in\n let%map b_weighted_low = int_log_uniform_inclusive 0 max_b in\n max_b - b_weighted_low\n in\n (* avoid any skew of a vs b by randomly swapping *)\n if%map bool then a, b else b, a\n;;\n\nlet bigarray2 t kind layout =\n let%bind dim1, dim2 = bigarray2_dim in\n let%map elts = list_with_length ~length:dim1 (list_with_length ~length:dim2 t) in\n let elts = Array.of_list_map ~f:Array.of_list elts in\n let offset = Bigarray_helpers.Layout.offset layout in\n Bigarray_helpers.Array2.init kind layout dim1 dim2 ~f:(fun i j ->\n elts.(i - offset).(j - offset))\n;;\n\nlet float32_mat = bigarray2 float Float32 Fortran_layout\nlet float64_mat = bigarray2 float Float64 Fortran_layout\n","open! Base\n\nmodule Layout = struct\n type 'a t = 'a Bigarray.layout\n\n let offset : type a. a t -> int = function\n | Bigarray.Fortran_layout -> 1\n | Bigarray.C_layout -> 0\n ;;\nend\n\nmodule Array1 = struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) Bigarray.Array1.t\n\n let iteri t ~f =\n let offset = Layout.offset (Bigarray.Array1.layout t) in\n for i = 0 to Bigarray.Array1.dim t - 1 do\n f (i + offset) t.{i + offset}\n done\n ;;\n\n let init (type elt) (kind : (elt, _) Bigarray.kind) layout dim ~f =\n let t = Bigarray.Array1.create kind layout dim in\n iteri t ~f:(fun i (_ : elt) -> t.{i} <- f i);\n t\n ;;\n\n let fold (type elt) (t : (elt, _, _) t) ~init ~f =\n let init = ref init in\n iteri t ~f:(fun i (_ : elt) -> init := f !init t.{i});\n !init\n ;;\n\n let to_array t =\n let offset = Layout.offset (Bigarray.Array1.layout t) in\n Array.init (Bigarray.Array1.dim t) ~f:(fun i -> t.{i + offset})\n ;;\n\n let sexp_of_t sexp_of_elt _sexp_of_pack _sexp_of_layout t =\n [%sexp (to_array t : elt array)]\n ;;\n\n let hash_fold hash_fold_elt state t =\n let state = hash_fold_int state (Bigarray.Array1.dim t) in\n fold t ~init:state ~f:hash_fold_elt\n ;;\nend\n\nmodule Array2 = struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) Bigarray.Array2.t\n\n let iteri t ~f =\n let offset = Layout.offset (Bigarray.Array2.layout t) in\n for i = 0 to Bigarray.Array2.dim1 t - 1 do\n for j = 0 to Bigarray.Array2.dim2 t - 1 do\n f (i + offset) (j + offset) t.{i + offset, j + offset}\n done\n done\n ;;\n\n let init (type elt) (kind : (elt, _) Bigarray.kind) layout dim1 dim2 ~f =\n let t = Bigarray.Array2.create kind layout dim1 dim2 in\n iteri t ~f:(fun i j (_ : elt) -> t.{i, j} <- f i j);\n t\n ;;\n\n let fold (type elt) (t : (elt, _, _) t) ~init ~f =\n let init = ref init in\n iteri t ~f:(fun (_ : int) (_ : int) elt -> init := f !init elt);\n !init\n ;;\n\n let to_array t =\n let offset = Layout.offset (Bigarray.Array2.layout t) in\n Array.init (Bigarray.Array2.dim1 t) ~f:(fun i ->\n Array.init (Bigarray.Array2.dim2 t) ~f:(fun j -> t.{i + offset, j + offset}))\n ;;\n\n let sexp_of_t sexp_of_elt _sexp_of_pack _sexp_of_layout t =\n [%sexp (to_array t : elt array array)]\n ;;\n\n let hash_fold hash_fold_elt state t =\n let state = hash_fold_int state (Bigarray.Array2.dim1 t) in\n let state = hash_fold_int state (Bigarray.Array2.dim2 t) in\n fold t ~init:state ~f:hash_fold_elt\n ;;\nend\n","open! Base\n\ntype 'a t = 'a -> size:int -> hash:Hash.state -> Hash.state\n\nlet create f : _ t = f\n\nlet observe (t : _ t) x ~size ~hash =\n if size < 0\n then raise_s [%message \"Base_quickcheck.Observer.observe: size < 0\" (size : int)]\n else t x ~size ~hash\n;;\n\nlet opaque _ ~size:_ ~hash = hash\n","open Core_kernel\n\n(* This module implements snarky functions for a sponge that can *conditionally* absorb input,\n while branching minimally. Specifically, if absorbing N field elements, this sponge can absorb\n a variable subset of N field elements, while performing N + 1 invocations of the sponge's\n underlying permutation. *)\n\nlet m = 3\n\nlet capacity = 1\n\nlet rate = m - capacity\n\ntype 'f sponge_state =\n | Absorbing of\n { next_index : 'f Snarky_backendless.Boolean.t\n ; xs : ('f Snarky_backendless.Boolean.t * 'f) list\n }\n | Squeezed of int\n\ntype 'f t =\n { mutable state : 'f array\n ; params : 'f Sponge.Params.t\n ; mutable needs_final_permute_if_empty : bool\n ; mutable sponge_state : 'f sponge_state\n }\n\nmodule Make\n (Impl : Snarky_backendless.Snark_intf.Run)\n (P : Sponge.Intf.Permutation with type Field.t = Impl.Field.t) =\nstruct\n open P\n open Impl\n\n type nonrec t = Field.t t\n\n let _state { state; _ } = Array.copy state\n\n let copy { state; params; sponge_state; needs_final_permute_if_empty } =\n { state = Array.copy state\n ; params\n ; sponge_state\n ; needs_final_permute_if_empty\n }\n\n let initial_state = Array.init m ~f:(fun _ -> Field.zero)\n\n let of_sponge { Sponge.state; params; sponge_state; id = _ } =\n match sponge_state with\n | Sponge.Squeezed n ->\n { sponge_state = Squeezed n\n ; state = Array.copy state\n ; needs_final_permute_if_empty = true\n ; params\n }\n | Sponge.Absorbed n -> (\n let abs i =\n { sponge_state = Absorbing { next_index = i; xs = [] }\n ; state = Array.copy state\n ; params\n ; needs_final_permute_if_empty = true\n }\n in\n match n with\n | 0 ->\n abs Boolean.false_\n | 1 ->\n abs Boolean.true_\n | 2 ->\n { sponge_state = Absorbing { next_index = Boolean.false_; xs = [] }\n ; state = P.block_cipher params state\n ; needs_final_permute_if_empty = false\n ; params\n }\n | _ ->\n assert false )\n\n let create ?(init = initial_state) params =\n { params\n ; state = Array.copy init\n ; needs_final_permute_if_empty = true\n ; sponge_state = Absorbing { next_index = Boolean.false_; xs = [] }\n }\n\n let () = assert (rate = 2)\n\n let add_in a i x =\n let i_equals_0 = Boolean.not i in\n let i_equals_1 = i in\n (*\n a.(0) <- a.(0) + i_equals_0 * x\n a.(1) <- a.(1) + i_equals_1 * x *)\n List.iteri [ i_equals_0; i_equals_1 ] ~f:(fun j i_equals_j ->\n let a_j' =\n exists Field.typ\n ~compute:\n As_prover.(\n fun () ->\n let a_j = read Field.typ a.(j) in\n if read Boolean.typ i_equals_j then\n Field.Constant.(a_j + read Field.typ x)\n else a_j)\n in\n assert_r1cs x (i_equals_j :> Field.t) Field.(a_j' - a.(j)) ;\n a.(j) <- a_j' )\n\n let cond_permute ~params ~permute state =\n let permuted = P.block_cipher params (Array.copy state) in\n for i = 0 to m - 1 do\n state.(i) <- Field.if_ permute ~then_:permuted.(i) ~else_:state.(i)\n done\n\n let consume_pairs ~params ~state ~pos:start_pos pairs =\n Array.fold ~init:start_pos pairs ~f:(fun p ((b, x), (b', y)) ->\n (* Semantically, we want to do this.\n match b, b' with\n | 1, 1 ->\n if p = 0\n then state := perm {state with .0 += x, .1 += y }\n else state := {perm {state with .1 += x} with .0 += y}\n | 1, 0 ->\n if p = 0\n then state := {state with .0 += x}\n else state := perm {state with .1 += x}\n | 0, 1 ->\n if p = 0\n then state := {state with .0 += y }\n else state := perm {state with .1 += y}\n | 0, 0 ->\n state\n *)\n let p' = Boolean.( lxor ) p b in\n let pos_after = Boolean.( lxor ) p' b' in\n let y = Field.(y * (b' :> t)) in\n let add_in_y_after_perm =\n (* post\n add in\n (1, 1, 1)\n\n do not add in\n (1, 1, 0)\n (0, 1, 0)\n (0, 1, 1)\n\n (1, 0, 0)\n (1, 0, 1)\n (0, 0, 0)\n (0, 0, 1)\n *)\n (* Only one case where we add in y after the permutation is applied *)\n Boolean.all [ b; b'; p ]\n in\n let add_in_y_before_perm = Boolean.not add_in_y_after_perm in\n add_in state p Field.(x * (b :> t)) ;\n add_in state p' Field.(y * (add_in_y_before_perm :> t)) ;\n let permute =\n (* (b, b', p)\n true:\n (0, 1, 1)\n (1, 0, 1)\n (1, 1, 0)\n (1, 1, 1)\n\n false:\n (0, 0, 0)\n (0, 0, 1)\n (0, 1, 0)\n (1, 0, 0)\n *)\n (* (b && b') || (p && (b || b')) *)\n Boolean.(any [ all [ b; b' ]; all [ p; b ||| b' ] ])\n in\n cond_permute ~params ~permute state ;\n add_in state p' Field.(y * (add_in_y_after_perm :> t)) ;\n pos_after )\n\n let consume ~needs_final_permute_if_empty ~params ~start_pos input state =\n assert (Array.length state = m) ;\n let n = Array.length input in\n let num_pairs = n / 2 in\n let remaining = n - (2 * num_pairs) in\n let pairs =\n Array.init num_pairs ~f:(fun i -> (input.(2 * i), input.((2 * i) + 1)))\n in\n let pos = consume_pairs ~params ~state ~pos:start_pos pairs in\n let empty_imput =\n Boolean.not (Boolean.Array.any (Array.map input ~f:fst))\n in\n let should_permute =\n match remaining with\n | 0 ->\n if needs_final_permute_if_empty then Boolean.(empty_imput ||| pos)\n else pos\n | 1 ->\n let b, x = input.(n - 1) in\n let p = pos in\n let pos_after = Boolean.( lxor ) p b in\n ignore (pos_after : Boolean.var) ;\n add_in state p Field.(x * (b :> t)) ;\n if needs_final_permute_if_empty then Boolean.any [ p; b; empty_imput ]\n else Boolean.any [ p; b ]\n | _ ->\n assert false\n in\n cond_permute ~params ~permute:should_permute state\n\n let absorb (t : t) x =\n match t.sponge_state with\n | Absorbing { next_index; xs } ->\n t.sponge_state <- Absorbing { next_index; xs = x :: xs }\n | Squeezed _ ->\n t.sponge_state <- Absorbing { next_index = Boolean.false_; xs = [ x ] }\n\n let squeeze (t : t) =\n match t.sponge_state with\n | Squeezed n ->\n if n = rate then (\n t.state <- block_cipher t.params t.state ;\n t.sponge_state <- Squeezed 1 ;\n t.state.(0) )\n else (\n t.sponge_state <- Squeezed (n + 1) ;\n t.state.(n) )\n | Absorbing { next_index; xs } ->\n consume ~needs_final_permute_if_empty:t.needs_final_permute_if_empty\n ~start_pos:next_index ~params:t.params (Array.of_list_rev xs) t.state ;\n t.needs_final_permute_if_empty <- true ;\n t.sponge_state <- Squeezed 1 ;\n t.state.(0)\n\n let consume_all_pending (t : t) =\n match t.sponge_state with\n | Squeezed _ ->\n failwith \"Nothing pending\"\n | Absorbing { next_index; xs } ->\n let input = Array.of_list_rev xs in\n assert (Array.length t.state = m) ;\n let n = Array.length input in\n let num_pairs = n / 2 in\n let remaining = n - (2 * num_pairs) in\n let pairs =\n Array.init num_pairs ~f:(fun i ->\n (input.(2 * i), input.((2 * i) + 1)) )\n in\n let pos =\n consume_pairs ~params:t.params ~state:t.state ~pos:next_index pairs\n in\n let pos_after =\n if remaining = 1 then (\n let b, x = input.(n - 1) in\n let p = pos in\n let pos_after = Boolean.( lxor ) p b in\n add_in t.state p Field.(x * (b :> t)) ;\n pos_after )\n else pos\n in\n (* TODO: We should propagate the emptiness state of the pairs,\n otherwise this will break in some edge cases.\n *)\n t.sponge_state <- Absorbing { next_index = pos_after; xs = [] }\n\n let recombine ~original_sponge b (t : t) =\n match[@warning \"-4\"] (original_sponge.sponge_state, t.sponge_state) with\n | Squeezed orig_i, Squeezed curr_i ->\n if orig_i <> curr_i then failwithf \"Squeezed %i vs %i\" orig_i curr_i () ;\n Array.iteri original_sponge.state ~f:(fun i x ->\n t.state.(i) <- Field.if_ b ~then_:t.state.(i) ~else_:x )\n | ( Absorbing { next_index = next_index_orig; xs = xs_orig }\n , Absorbing { next_index = next_index_curr; xs = xs_curr } ) ->\n (* TODO: Should test for full equality here, if we want to catch all\n sponge misuses.\n OTOH, if you're using this sponge then you'd better know what it's\n doing..\n *)\n if List.length xs_orig <> List.length xs_curr then\n failwithf \"Pending absorptions %i vs %i\" (List.length xs_orig)\n (List.length xs_curr) () ;\n Array.iteri original_sponge.state ~f:(fun i x ->\n t.state.(i) <- Field.if_ b ~then_:t.state.(i) ~else_:x ) ;\n t.sponge_state <-\n Absorbing\n { next_index =\n Boolean.if_ b ~then_:next_index_curr ~else_:next_index_orig\n ; xs = xs_curr\n }\n | _, _ ->\n failwith \"Incompatible states\"\n\n let%test_module \"opt_sponge\" =\n ( module struct\n module S = Sponge.Make_sponge (P)\n\n let%test_unit \"correctness\" =\n let params : _ Sponge.Params.t =\n let a () =\n Array.init 3 ~f:(fun _ -> Field.(constant (Constant.random ())))\n in\n { mds = Array.init 3 ~f:(fun _ -> a ())\n ; round_constants = Array.init 40 ~f:(fun _ -> a ())\n }\n in\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%bind n = Quickcheck.Generator.small_positive_int\n and n_pre = Quickcheck.Generator.small_positive_int in\n let%map xs = List.gen_with_length n Field.Constant.gen\n and bs = List.gen_with_length n Bool.quickcheck_generator\n and pre = List.gen_with_length n_pre Field.Constant.gen in\n (pre, List.zip_exn bs xs)\n in\n Quickcheck.test gen ~trials:10 ~f:(fun (pre, ps) ->\n let filtered =\n List.filter_map ps ~f:(fun (b, x) -> if b then Some x else None)\n in\n let init () =\n let pre =\n exists\n (Typ.list ~length:(List.length pre) Field.typ)\n ~compute:(fun () -> pre)\n in\n let s = S.create params in\n List.iter pre ~f:(S.absorb s) ;\n s\n in\n let filtered_res =\n let n = List.length filtered in\n Impl.Internal_Basic.Test.checked_to_unchecked\n (Typ.list ~length:n Field.typ)\n Field.typ\n (fun xs ->\n make_checked (fun () ->\n let s = init () in\n List.iter xs ~f:(S.absorb s) ;\n S.squeeze s ) )\n filtered\n in\n let opt_res =\n let n = List.length ps in\n Impl.Internal_Basic.Test.checked_to_unchecked\n (Typ.list ~length:n (Typ.tuple2 Boolean.typ Field.typ))\n Field.typ\n (fun xs ->\n make_checked (fun () ->\n let s =\n if List.length pre = 0 then create params\n else of_sponge (init ())\n in\n List.iter xs ~f:(absorb s) ;\n squeeze s ) )\n ps\n in\n if not (Field.Constant.equal filtered_res opt_res) then\n failwithf\n !\"hash(%{sexp:Field.Constant.t list}) = %{sexp:Field.Constant.t}\\n\\\n hash(%{sexp:(bool * Field.Constant.t) list}) = \\\n %{sexp:Field.Constant.t}\"\n filtered filtered_res ps opt_res () )\n end )\nend\n","open! Base\n\nmodule T : sig\n type 'a t\n\n val atomic : _ t\n val create : ('a -> 'a Sequence.t) -> 'a t\n val shrink : 'a t -> 'a -> 'a Sequence.t\nend = struct\n type 'a t = 'a -> 'a Sequence.t\n\n let atomic _ = Sequence.empty\n let create = Fn.id\n let shrink = Fn.id\nend\n\ninclude T\n\nlet map t ~f ~f_inverse = create (fun x -> Sequence.map ~f (shrink t (f_inverse x)))\nlet filter t ~f = create (fun x -> Sequence.filter ~f (shrink t x))\n\nlet filter_map t ~f ~f_inverse =\n create (fun x -> Sequence.filter_map ~f (shrink t (f_inverse x)))\n;;\n\nlet of_lazy lazy_t = create (fun x -> Sequence.of_lazy (lazy (shrink (force lazy_t) x)))\n\nlet fixed_point of_shrinker =\n let rec lazy_t = lazy (of_shrinker (of_lazy lazy_t)) in\n of_lazy lazy_t\n;;\n\nlet both fst_t snd_t =\n create (fun (fst, snd) ->\n Sequence.round_robin\n [ Sequence.map (shrink fst_t fst) ~f:(fun fst -> fst, snd)\n ; Sequence.map (shrink snd_t snd) ~f:(fun snd -> fst, snd)\n ])\n;;\n\nlet unit = atomic\nlet bool = atomic\nlet char = atomic\nlet int = atomic\nlet int32 = atomic\nlet int63 = atomic\nlet int64 = atomic\nlet nativeint = atomic\nlet float = atomic\n\nlet bigarray1 src =\n let dim = Bigarray.Array1.dim src in\n match dim with\n | 0 -> Sequence.empty\n | _ ->\n let kind = Bigarray.Array1.kind src in\n let layout = Bigarray.Array1.layout src in\n let offset = Bigarray_helpers.Layout.offset layout in\n Sequence.init dim ~f:(fun to_skip ->\n let to_skip = to_skip + offset in\n Bigarray_helpers.Array1.init kind layout (dim - 1) ~f:(fun i ->\n src.{(if i < to_skip then i else i + 1)}))\n;;\n\nlet bigstring = create bigarray1\nlet float32_vec = create bigarray1\nlet float64_vec = create bigarray1\n\nlet bigarray2 =\n let module Dims = struct\n type t =\n { dim1 : int\n ; dim2 : int\n }\n [@@deriving fields]\n\n let create a = Bigarray.Array2.{ dim1 = dim1 a; dim2 = dim2 a }\n end\n in\n let shrink field src =\n let dims = Dims.create src in\n match Field.get field dims with\n | 0 -> Sequence.empty\n | _ ->\n let kind = Bigarray.Array2.kind src in\n let layout = Bigarray.Array2.layout src in\n let offset = Bigarray_helpers.Layout.offset layout in\n let ({ dim1; dim2 } : Dims.t) = Field.map field dims ~f:Int.pred in\n Sequence.init (Field.get field dims) ~f:(fun to_skip ->\n let to_skip = to_skip + offset in\n let skip i = if i < to_skip then i else i + 1 in\n Bigarray_helpers.Array2.init kind layout dim1 dim2 ~f:(fun dim1 dim2 ->\n let ({ dim1; dim2 } : Dims.t) = Field.map field { dim1; dim2 } ~f:skip in\n src.{dim1, dim2}))\n in\n fun src ->\n Sequence.round_robin [ shrink Dims.Fields.dim1 src; shrink Dims.Fields.dim2 src ]\n;;\n\nlet float32_mat = create bigarray2\nlet float64_mat = create bigarray2\n\nlet option value_t =\n create (function\n | None -> Sequence.empty\n | Some value ->\n Sequence.append\n (Sequence.singleton None)\n (Sequence.map ~f:Option.return (shrink value_t value)))\n;;\n\nlet list elt_t =\n fixed_point (fun list_t ->\n create (function\n | [] -> Sequence.empty\n | head :: tail ->\n Sequence.round_robin\n [ Sequence.singleton tail\n ; Sequence.map (shrink elt_t head) ~f:(fun head -> head :: tail)\n ; Sequence.map (shrink list_t tail) ~f:(fun tail -> head :: tail)\n ]))\n;;\n\nlet string = map (list char) ~f:String.of_char_list ~f_inverse:String.to_list\n\nlet sexp =\n fixed_point (fun shrinker ->\n create (function\n | Sexp.Atom _ -> Sequence.empty\n | Sexp.List l ->\n let shrink_list =\n shrink (list shrinker) l |> Sequence.map ~f:(fun l -> Sexp.List l)\n in\n let shrink_tree = Sequence.of_list l in\n Sequence.round_robin [ shrink_list; shrink_tree ]))\n;;\n\nlet either fst_t snd_t =\n create (fun either ->\n match (either : _ Either.t) with\n | First fst -> Sequence.map (shrink fst_t fst) ~f:Either.first\n | Second snd -> Sequence.map (shrink snd_t snd) ~f:Either.second)\n;;\n\nlet result ok_t err_t =\n map\n (either ok_t err_t)\n ~f:(function\n | First ok -> Ok ok\n | Second err -> Error err)\n ~f_inverse:(function\n | Ok ok -> First ok\n | Error err -> Second err)\n;;\n\nlet map_tree_using_comparator ~comparator key_t data_t =\n create (fun tree ->\n let alist = Map.Using_comparator.Tree.to_alist tree in\n let drop_keys =\n Sequence.map (Sequence.of_list alist) ~f:(fun (k, _) ->\n Map.Using_comparator.Tree.remove ~comparator tree k)\n in\n let shrink_keys =\n Sequence.round_robin\n (List.map alist ~f:(fun (key, data) ->\n let tree = Map.Using_comparator.Tree.remove ~comparator tree key in\n Sequence.filter_map (shrink key_t key) ~f:(fun smaller_key ->\n match\n Map.Using_comparator.Tree.add\n ~comparator\n tree\n ~key:smaller_key\n ~data\n with\n | `Ok tree -> Some tree\n | `Duplicate -> None)))\n in\n let shrink_data =\n Sequence.round_robin\n (List.map alist ~f:(fun (key, data) ->\n Sequence.map (shrink data_t data) ~f:(fun smaller_data ->\n Map.Using_comparator.Tree.set ~comparator tree ~key ~data:smaller_data)))\n in\n Sequence.round_robin [ drop_keys; shrink_keys; shrink_data ])\n;;\n\nlet set_tree_using_comparator ~comparator elt_t =\n create (fun tree ->\n let list = Set.Using_comparator.Tree.to_list tree in\n let drop_elts =\n Sequence.map (Sequence.of_list list) ~f:(fun elt ->\n Set.Using_comparator.Tree.remove ~comparator tree elt)\n in\n let shrink_elts =\n Sequence.round_robin\n (List.map list ~f:(fun elt ->\n let tree = Set.Using_comparator.Tree.remove ~comparator tree elt in\n Sequence.filter_map (shrink elt_t elt) ~f:(fun smaller_elt ->\n match Set.Using_comparator.Tree.mem ~comparator tree smaller_elt with\n | true -> None\n | false ->\n Some (Set.Using_comparator.Tree.add tree ~comparator smaller_elt))))\n in\n Sequence.round_robin [ drop_elts; shrink_elts ])\n;;\n\nlet map_t key_t data_t =\n create (fun map_t ->\n let comparator = Map.comparator map_t in\n let t =\n map\n (map_tree_using_comparator ~comparator key_t data_t)\n ~f:(Map.Using_comparator.of_tree ~comparator)\n ~f_inverse:Map.Using_comparator.to_tree\n in\n shrink t map_t)\n;;\n\nlet set_t elt_t =\n create (fun set_t ->\n let comparator = Set.comparator set_t in\n let t =\n map\n (set_tree_using_comparator ~comparator elt_t)\n ~f:(Set.Using_comparator.of_tree ~comparator)\n ~f_inverse:Set.Using_comparator.to_tree\n in\n shrink t set_t)\n;;\n","open! Base\ninclude Test_intf\n\nmodule Config = struct\n module Seed = struct\n type t =\n | Nondeterministic\n | Deterministic of string\n [@@deriving sexp_of]\n end\n\n module Potentially_infinite_sequence = struct\n type 'a t = 'a Sequence.t\n\n let sexp_of_t sexp_of_elt sequence =\n let prefix, suffix = Sequence.split_n sequence 100 in\n let prefix = List.map prefix ~f:sexp_of_elt in\n let suffix =\n match Sequence.is_empty suffix with\n | true -> []\n | false -> [ [%message \"...\"] ]\n in\n Sexp.List (prefix @ suffix)\n ;;\n end\n\n type t =\n { seed : Seed.t\n ; test_count : int\n ; shrink_count : int\n ; sizes : int Potentially_infinite_sequence.t\n }\n [@@deriving fields, sexp_of]\nend\n\nlet default_config : Config.t =\n { seed = Deterministic \"an arbitrary but deterministic string\"\n ; test_count = 10_000\n ; shrink_count = 10_000\n ; sizes = Sequence.cycle_list_exn (List.range 0 ~start:`inclusive 30 ~stop:`inclusive)\n }\n;;\n\nlet lazy_nondeterministic_state = lazy (Random.State.make_self_init ())\n\nlet initial_random_state ~config =\n match Config.seed config with\n | Nondeterministic ->\n Splittable_random.State.create (force lazy_nondeterministic_state)\n | Deterministic string -> Splittable_random.State.of_int (String.hash string)\n;;\n\nlet one_size_per_test ~(config : Config.t) =\n Sequence.unfold ~init:(config.sizes, 0) ~f:(fun (sizes, number_of_size_values) ->\n match number_of_size_values >= config.test_count with\n | true -> None\n | false ->\n (match Sequence.next sizes with\n | Some (size, remaining_sizes) ->\n Some (size, (remaining_sizes, number_of_size_values + 1))\n | None ->\n raise_s\n [%message\n \"Base_quickcheck.Test.run: insufficient size values for test count\"\n ~test_count:(config.test_count : int)\n (number_of_size_values : int)]))\n;;\n\nlet shrink_error ~shrinker ~config ~f input error =\n let rec loop ~shrink_count ~alternates input error =\n match shrink_count with\n | 0 -> input, error\n | _ ->\n let shrink_count = shrink_count - 1 in\n (match Sequence.next alternates with\n | None -> input, error\n | Some (alternate, alternates) ->\n (match f alternate with\n | Ok () -> loop ~shrink_count ~alternates input error\n | Error error ->\n let alternates = Shrinker.shrink shrinker alternate in\n loop ~shrink_count ~alternates alternate error))\n in\n let shrink_count = Config.shrink_count config in\n let alternates = Shrinker.shrink shrinker input in\n loop ~shrink_count ~alternates input error\n;;\n\nlet input_sequence ~config ~examples ~generator =\n let random = initial_random_state ~config in\n Sequence.append\n (Sequence.of_list examples)\n (one_size_per_test ~config\n |> Sequence.map ~f:(fun size -> Generator.generate generator ~size ~random))\n;;\n\nlet with_sample ~f ?(config = default_config) ?(examples = []) generator =\n let sequence = input_sequence ~config ~examples ~generator in\n f sequence\n;;\n\nlet result (type a) ~f ?(config = default_config) ?(examples = []) m =\n let (module M : S with type t = a) = m in\n with_sample M.quickcheck_generator ~config ~examples ~f:(fun sequence ->\n match\n Sequence.fold_result sequence ~init:() ~f:(fun () input ->\n match f input with\n | Ok () -> Ok ()\n | Error error -> Error (input, error))\n with\n | Ok () -> Ok ()\n | Error (input, error) ->\n let shrinker = M.quickcheck_shrinker in\n let input, error = shrink_error ~shrinker ~config ~f input error in\n Error (input, error))\n;;\n\nlet run (type a) ~f ?config ?examples (module M : S with type t = a) =\n let f x =\n Or_error.try_with_join ~backtrace:(Backtrace.Exn.am_recording ()) (fun () -> f x)\n in\n match result ~f ?config ?examples (module M) with\n | Ok () -> Ok ()\n | Error (input, error) ->\n Or_error.error_s\n [%message \"Base_quickcheck.Test.run: test failed\" (input : M.t) (error : Error.t)]\n;;\n\nlet with_sample_exn ~f ?config ?examples generator =\n let f x = Or_error.try_with (fun () -> f x) in\n with_sample ~f ?config ?examples generator |> Or_error.ok_exn\n;;\n\nlet run_exn ~f ?config ?examples testable =\n let f x =\n Or_error.try_with ~backtrace:(Backtrace.Exn.am_recording ()) (fun () -> f x)\n in\n run ~f ?config ?examples testable |> Or_error.ok_exn\n;;\n","open! Base\ninclude Observer0\n\nlet unmap t ~f = create (fun x ~size ~hash -> observe t (f x) ~size ~hash)\nlet of_hash_fold f = create (fun x ~size:_ ~hash -> f hash x)\nlet of_lazy lazy_t = create (fun x ~size ~hash -> observe (force lazy_t) x ~size ~hash)\n\nlet fixed_point wrap =\n let rec lazy_t = lazy (wrap (of_lazy lazy_t)) in\n of_lazy lazy_t\n;;\n\nlet unit = opaque\nlet bool = of_hash_fold Bool.hash_fold_t\nlet char = of_hash_fold Char.hash_fold_t\nlet int = of_hash_fold Int.hash_fold_t\nlet int32 = of_hash_fold Int32.hash_fold_t\nlet int63 = of_hash_fold Int63.hash_fold_t\nlet int64 = of_hash_fold Int64.hash_fold_t\nlet nativeint = of_hash_fold Nativeint.hash_fold_t\nlet float = of_hash_fold Float.hash_fold_t\nlet string = of_hash_fold String.hash_fold_t\nlet sexp = of_hash_fold Sexp.hash_fold_t\nlet bigstring = of_hash_fold (Bigarray_helpers.Array1.hash_fold hash_fold_char)\nlet float32_vec = of_hash_fold (Bigarray_helpers.Array1.hash_fold hash_fold_float)\nlet float64_vec = of_hash_fold (Bigarray_helpers.Array1.hash_fold hash_fold_float)\nlet float32_mat = of_hash_fold (Bigarray_helpers.Array2.hash_fold hash_fold_float)\nlet float64_mat = of_hash_fold (Bigarray_helpers.Array2.hash_fold hash_fold_float)\n\nlet either fst_t snd_t =\n create (fun either ~size ~hash ->\n match (either : _ Either.t) with\n | First fst -> observe fst_t fst ~size ~hash:(hash_fold_int hash 1)\n | Second snd -> observe snd_t snd ~size ~hash:(hash_fold_int hash 2))\n;;\n\nlet result ok_t err_t =\n unmap (either ok_t err_t) ~f:(function\n | Ok ok -> First ok\n | Error err -> Second err)\n;;\n\nlet both fst_t snd_t =\n create (fun (fst, snd) ~size ~hash ->\n let hash = observe fst_t fst ~size ~hash in\n let hash = observe snd_t snd ~size ~hash in\n hash)\n;;\n\nlet option value_t =\n unmap (either opaque value_t) ~f:(function\n | None -> First ()\n | Some value -> Second value)\n;;\n\nlet list elt_t =\n create (fun list ~size ~hash ->\n let random = Splittable_random.State.of_int (Hash.get_hash_value hash) in\n let length = List.length list in\n let sizes =\n Generator.sizes ~min_length:length ~max_length:length ()\n |> Generator.generate ~size ~random\n in\n List.fold2_exn list sizes ~init:(hash_fold_int hash 0) ~f:(fun hash elt size ->\n observe elt_t elt ~size ~hash:(hash_fold_int hash 1)))\n;;\n\nlet fn dom rng =\n create (fun f ~size ~hash ->\n let random = Splittable_random.State.of_int (Hash.get_hash_value hash) in\n let sizes =\n (* Empirically, doubling the size when generating the list of inputs gives us much\n better coverage of the space of functions. *)\n Generator.generate (Generator.sizes ()) ~size:(size * 2) ~random\n in\n List.fold sizes ~init:hash ~f:(fun hash size ->\n let x = Generator.generate dom ~size ~random in\n observe rng (f x) ~size ~hash))\n;;\n\nlet map_tree key_obs data_obs =\n unmap (list (both key_obs data_obs)) ~f:Map.Using_comparator.Tree.to_alist\n;;\n\nlet set_tree elt_obs = unmap (list elt_obs) ~f:Set.Using_comparator.Tree.to_list\n\nlet map_t key_obs data_obs =\n unmap (map_tree key_obs data_obs) ~f:Map.Using_comparator.to_tree\n;;\n\nlet set_t elt_obs = unmap (set_tree elt_obs) ~f:Set.Using_comparator.to_tree\n","open! Base\nopen! Blit\n\ninclude Test_blit_intf\n\nmodule type S_gen = sig\n open Blit\n type 'a src\n type 'a dst\n (* val blit : ('a src, 'a dst) blit*)\n val blito : ('a src, 'a dst) blito\n (* val unsafe_blit : ('a src, 'a dst) blit*)\n val sub : ('a src, 'a dst) sub\n (*val subo : ('a src, 'a dst) subo*)\nend\n\nmodule type For_tests_gen = sig\n module Elt : sig\n type 'a t\n val equal : bool t -> bool t -> bool\n val of_bool : bool -> bool t\n end\n\n type 'a z\n\n module Src : sig\n type 'a t\n val length : _ t -> int\n val create_bool : len:int -> bool z t\n val get : 'a z t -> int -> 'a Elt.t\n val set : 'a z t -> int -> 'a Elt.t -> unit\n end\n\n module Dst : sig\n type 'a t\n val length : _ t -> int\n val create_bool : len:int -> bool z t\n val get : 'a z t -> int -> 'a Elt.t\n val set : 'a z t -> int -> 'a Elt.t -> unit\n val overlapping_src_dst\n : [ `Do_not_check\n | `Check of ('a Src.t -> 'a t)\n ]\n end\nend\n\nmodule Test_gen\n (For_tests : For_tests_gen)\n (Tested : S_gen\n with type 'a src := 'a For_tests.Src.t\n with type 'a dst := 'a For_tests.Dst.t)\n= struct\n open Tested\n open For_tests\n\n let init ~len ~create ~set ~f =\n let t = create ~len in\n for i = 0 to len - 1 do\n set t i (f i);\n done;\n t\n ;;\n\n (* Test [blit]. *)\n let%test_unit _ =\n let elt1 = Elt.of_bool true in\n let elt2 = Elt.of_bool false in\n assert (not (Elt.equal elt1 elt2));\n let src_bit i = if i land 0x1 = 0 then elt1 else elt2 in\n let dst_bit i = if i land 0x1 = 0 then elt2 else elt1 in\n let n = 4 in\n for src_length = 0 to n do\n for dst_length = 0 to n do\n for src_pos = 0 to src_length do\n for dst_pos = 0 to dst_length do\n for src_len = 0 to min (src_length - src_pos) (dst_length - dst_pos) do\n try\n let is_in_range i = i >= dst_pos && i < dst_pos + src_len in\n let check length get =\n fun name sequence ~expect ->\n for i = 0 to length sequence - 1 do\n if not (Elt.equal (get sequence i) (expect i)) then\n raise_s [%message \"bug\" (name : string) (i : int)]\n done;\n in\n let check_src = check Src.length Src.get in\n let check_dst = check Dst.length Dst.get in\n let src =\n init ~len:src_length ~create:Src.create_bool ~set:Src.set ~f:src_bit\n in\n assert (Src.length src = src_length);\n let dst =\n init ~len:dst_length ~create:Dst.create_bool ~set:Dst.set ~f:dst_bit\n in\n assert (Dst.length dst = dst_length);\n let init_src () =\n for i = 0 to src_length - 1 do\n Src.set src i (src_bit i);\n done\n in\n blito ~src ~src_pos ~src_len ~dst ~dst_pos ();\n check_src \"blit src\" src ~expect:src_bit;\n check_dst \"blit dst\" dst ~expect:(fun i ->\n if is_in_range i\n then src_bit (src_pos + i - dst_pos)\n else dst_bit i);\n begin match Dst.overlapping_src_dst with\n | `Do_not_check -> ()\n | `Check src_to_dst ->\n if dst_pos + src_len <= src_length then begin\n init_src ();\n let dst = src_to_dst src in\n if false then begin\n blito ~src ~src_pos ~src_len ~dst ~dst_pos ();\n check_dst \"blit dst overlapping\" dst ~expect:(fun i ->\n src_bit (if is_in_range i then (src_pos + i - dst_pos) else i));\n end;\n end;\n end;\n (* Check [sub]. *)\n init_src ();\n let dst = sub src ~pos:src_pos ~len:src_len in\n check_src \"sub src\" src ~expect:src_bit;\n check_dst \"sub dst\" dst ~expect:(fun i -> src_bit (src_pos + i));\n with exn ->\n raise_s [%message\n \"bug\"\n (exn : exn)\n (src_length : int) (src_pos : int)\n (dst_length : int) (dst_pos : int)]\n done;\n done;\n done;\n done;\n done\n ;;\nend\n\nmodule Test1\n (Sequence : Sequence1 with type 'a elt := 'a poly)\n (Tested : S1 with type 'a t := 'a Sequence.t)\n = Test_gen\n (struct\n module Elt = struct\n type 'a t = 'a\n let equal = Poly.equal\n let of_bool = Fn.id\n end\n type 'a z = 'a Sequence.z\n module Src = Sequence\n module Dst = struct\n include Sequence\n let overlapping_src_dst = `Check Fn.id\n end\n end)\n (Tested)\n\nmodule Test1_generic\n (Elt : Elt1)\n (Sequence : Sequence1 with type 'a elt := 'a Elt.t)\n (Tested : S1 with type 'a t := 'a Sequence.t)\n = Test_gen\n (struct\n module Elt = Elt\n type 'a z = 'a Sequence.z\n module Src = Sequence\n module Dst = struct\n include Sequence\n let overlapping_src_dst = `Check Fn.id\n end\n end)\n (Tested)\n\nmodule Elt_to_elt1 (Elt : Elt) = struct\n type 'a t = Elt.t\n let equal = Elt.equal\n let of_bool = Elt.of_bool\nend\n\nmodule Test\n (Elt : Elt)\n (Sequence : Sequence with type elt := Elt.t)\n (Tested : S with type t := Sequence.t)\n = Test_gen\n (struct\n module Elt = Elt_to_elt1(Elt)\n type 'a z = unit\n module Src = struct\n open Sequence\n type nonrec 'a t = t\n let length = length\n let get = get\n let set = set\n let create_bool = create\n end\n module Dst = struct\n include Src\n let overlapping_src_dst = `Check Fn.id\n end\n end)\n (Tested)\n\nmodule Test_distinct\n (Elt : Elt)\n (Src : Sequence with type elt := Elt.t)\n (Dst : Sequence with type elt := Elt.t)\n (Tested : S_distinct\n with type src := Src.t\n with type dst := Dst.t)\n = Test_gen\n (struct\n module Elt = Elt_to_elt1 (Elt)\n type 'a z = unit\n module Src = struct\n open Src\n type nonrec 'a t = t\n let length = length\n let get = get\n let set = set\n let create_bool = create\n end\n module Dst = struct\n open Dst\n type nonrec 'a t = t\n let length = length\n let get = get\n let set = set\n let create_bool = create\n let overlapping_src_dst = `Do_not_check\n end\n end)\n (Tested)\n\nmodule Make_and_test\n (Elt : Elt)\n (Sequence : sig\n include Sequence with type elt := Elt.t\n val unsafe_blit : (t, t) blit\n end) = struct\n module B = Make (Sequence)\n include Test (Elt) (Sequence) (B)\n include B\nend\n\nmodule Make_distinct_and_test\n (Elt : Elt)\n (Src : Sequence with type elt := Elt.t)\n (Dst : sig\n include Sequence with type elt := Elt.t\n val unsafe_blit : (Src.t, t) blit\n end) = struct\n module B = Make_distinct (Src) (Dst)\n include Test_distinct (Elt) (Src) (Dst) (B)\n include B\nend\n\nmodule Make1_and_test\n (Sequence : sig\n include Blit.Sequence1\n include Sequence1\n with type 'a t := 'a t\n with type 'a elt := 'a poly\n end) = struct\n module B = Make1 (Sequence)\n include Test1 (Sequence) (B)\n include B\nend\n\nmodule Make1_generic_and_test\n (Elt : Elt1)\n (Sequence : sig\n include Blit.Sequence1\n include Sequence1\n with type 'a t := 'a t\n with type 'a elt := 'a Elt.t\n end) = struct\n module B = Make1_generic (Sequence)\n include Test1_generic (Elt) (Sequence) (B)\n include B\nend\n","open! Base\nopen! Binary_searchable\n\ninclude Test_binary_searchable_intf\n\nmodule type S_gen = sig\n open Binary_searchable\n\n type 'a t\n type 'a elt\n\n val binary_search : ('a t, 'a elt, 'a elt) binary_search\n val binary_search_segmented : ('a t, 'a elt) binary_search_segmented\nend\n\nmodule type Indexable_gen_and_for_test = sig\n include S_gen\n\n module For_test : sig\n val compare : bool elt -> bool elt -> int\n val small : bool elt\n val big : bool elt\n val of_array : bool elt array -> bool t\n end\nend\n\nmodule Test_gen (M : Indexable_gen_and_for_test) = struct\n open M\n\n let%test_module \"test_binary_searchable\" =\n (module struct\n let compare = For_test.compare\n let elt_compare = For_test.compare\n\n let s = For_test.small\n let b = For_test.big\n\n let binary_search ?pos ?len ~compare t how v =\n binary_search ?pos ?len ~compare (For_test.of_array t) how v\n\n let (=) = Poly.equal\n\n let%test _ = binary_search ~compare [| |] `First_equal_to s = None\n let%test _ = binary_search ~compare [| s |] `First_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s |] `First_equal_to b = None\n let%test _ = binary_search ~compare [| s ; b |] `First_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s ; b |] `First_equal_to b = Some 1\n let%test _ = binary_search ~compare [| b ; b |] `First_equal_to s = None\n let%test _ = binary_search ~compare [| s ; s |] `First_equal_to b = None\n let%test _ = binary_search ~compare [| s ; b ; b |] `First_equal_to b = Some 1\n let%test _ = binary_search ~compare [| s ; s ; b |] `First_equal_to s = Some 0\n let%test _ = binary_search ~compare [| b ; b ; b |] `First_equal_to s = None\n\n let%test _ = binary_search ~compare [| |] `Last_equal_to s = None\n let%test _ = binary_search ~compare [| s |] `Last_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s |] `Last_equal_to b = None\n let%test _ = binary_search ~compare [| s ; b |] `Last_equal_to b = Some 1\n let%test _ = binary_search ~compare [| s ; b |] `Last_equal_to s = Some 0\n let%test _ = binary_search ~compare [| b ; b |] `Last_equal_to s = None\n let%test _ = binary_search ~compare [| s ; s |] `Last_equal_to b = None\n let%test _ = binary_search ~compare [| s ; b ; b |] `Last_equal_to b = Some 2\n let%test _ = binary_search ~compare [| s ; s ; b |] `Last_equal_to s = Some 1\n let%test _ = binary_search ~compare [| b ; b; b |] `Last_equal_to s = None\n\n let%test _ = binary_search ~compare [||] `First_greater_than_or_equal_to s = None\n let%test _ = binary_search ~compare [| b |] `First_greater_than_or_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s |] `First_greater_than_or_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s |] `First_strictly_greater_than s = None\n\n let%test _ = binary_search ~compare [||] `Last_less_than_or_equal_to s = None\n let%test _ = binary_search ~compare [| b |] `Last_less_than_or_equal_to s = None\n let%test _ = binary_search ~compare [| s |] `Last_less_than_or_equal_to s = Some 0\n let%test _ = binary_search ~compare [| s |] `Last_strictly_less_than s = None\n\n let create_test_case (num_s, num_b) =\n let arr = Array.create b ~len:(num_s + num_b) in\n for i = 0 to num_s -1 do\n arr.(i) <- s\n done;\n arr\n ;;\n\n let only_small = (10_000, 0)\n let only_big = (0, 10_000)\n\n let both = (2531, 4717)\n\n let%test _ =\n match binary_search (create_test_case only_small) ~compare `First_equal_to s with\n | None -> false\n | Some _ -> true\n\n let%test _ =\n let arr = create_test_case both in\n match binary_search arr ~compare `First_equal_to b with\n | None -> false\n | Some v -> v = 2531\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `First_equal_to b = None\n\n let create_deterministic_test () =\n Array.init 100_000 ~f:(fun i -> if i > 50_000 then b else s)\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_equal_to s = Some 0\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_equal_to s = Some 50_000\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_greater_than_or_equal_to s = Some 0\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_less_than_or_equal_to s = Some 50_000\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_strictly_greater_than s = Some 50_001\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_strictly_less_than b = Some 50_000\n\n (* tests around a gap*)\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_equal_to b = Some 50_001\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_equal_to b = Some 99_999\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_greater_than_or_equal_to b = Some 50_001\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_less_than_or_equal_to b = Some 99_999\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `First_strictly_greater_than b = None\n\n let%test _ =\n let arr = create_deterministic_test () in\n binary_search arr ~compare `Last_strictly_less_than b = Some 50_000\n\n (* test beginning of array *)\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `First_equal_to s = None\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `Last_equal_to s = None\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `First_greater_than_or_equal_to s = Some 0\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `Last_less_than_or_equal_to s = None\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `First_strictly_greater_than s = Some 0\n\n let%test _ =\n let arr = create_test_case only_big in\n binary_search arr ~compare `Last_strictly_less_than b = None\n\n\n (* test end of array *)\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `First_equal_to b = None\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `Last_equal_to b = None\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `First_greater_than_or_equal_to b = None\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `Last_less_than_or_equal_to b = Some 9_999\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `First_strictly_greater_than s = None\n\n let%test _ =\n let arr = create_test_case only_small in\n binary_search arr ~compare `Last_strictly_less_than b = Some 9_999\n\n let%test_unit _ =\n for length = 0 to 5 do\n for num_s = 0 to length do\n let arr = Array.init length ~f:(fun i -> if i < num_s then s else b) in\n for pos = -1 to length do\n for len = -1 to length + 1 do\n (*try*)\n let should_raise =\n Exn.does_raise (fun () ->\n Ordered_collection_common.check_pos_len_exn ~pos ~len\n ~total_length:length)\n in\n let result =\n Result.try_with (fun () ->\n binary_search arr ~pos ~len ~compare:elt_compare `Last_equal_to s)\n in\n match should_raise, result with\n | true , Error _ -> ()\n | true , Ok _ -> failwith \"expected it to raise but it didn't\"\n | false, Error _ -> failwith \"expected it to not raise, but it raised\"\n | false, Ok result ->\n let searched = num_s - 1 in\n let correct_result =\n if searched < pos then None\n else if len = 0 then None\n else if searched >= pos + len then Some(pos + len - 1)\n else Some searched\n in\n if not (correct_result = result) then failwith \"Wrong result\"\n (*with exn ->\n failwiths \"binary_search bug\"\n (exn, `length length, `search_key search_key, `pos pos, `len len)\n <:sexp_of< exn * [ `length of int ] * [ `search_key of int ]\n * [ `pos of int ] * [ `len of int ] >>*)\n done;\n done;\n done;\n done\n ;;\n\n let binary_search_segmented a = binary_search_segmented (For_test.of_array a)\n\n (*test for binary_search_segmented*)\n let%test _ =\n let arr = create_deterministic_test () in\n let segment_of x = if x = b then `Right else `Left in\n binary_search_segmented arr ~segment_of `Last_on_left = Some 50_000 &&\n binary_search_segmented arr ~segment_of `First_on_right = Some 50_001\n\n let%test _ =\n let arr = create_deterministic_test () in\n let segment_of _ = `Right in\n binary_search_segmented arr ~segment_of `Last_on_left = None &&\n binary_search_segmented arr ~segment_of `First_on_right = Some 0\n\n let%test _ =\n let arr = create_deterministic_test () in\n let segment_of _ = `Left in\n binary_search_segmented arr ~segment_of `Last_on_left = Some 99_999 &&\n binary_search_segmented arr ~segment_of `First_on_right = None\n\n end)\nend\n\nmodule Test (M : Binary_searchable_and_for_test) =\n Test_gen\n (struct\n type 'a t = M.t\n type 'a elt = M.elt\n let binary_search = M.binary_search\n let binary_search_segmented = M.binary_search_segmented\n module For_test = M.For_test\n end)\n\nmodule Test1 (M : Binary_searchable1_and_for_test) =\n Test_gen\n (struct\n type 'a t = 'a M.t\n type 'a elt = 'a\n let binary_search = M.binary_search\n let binary_search_segmented = M.binary_search_segmented\n module For_test = struct\n let of_array = M.For_test.of_array\n let compare = Bool.compare\n let small = false\n let big = true\n end\n end)\n\nmodule Make_and_test (M : Indexable_and_for_test) = struct\n module B = Binary_searchable.Make (M)\n include B\n include Test (struct\n type t = M.t\n type elt = M.elt\n include B\n module For_test = M.For_test\n end)\nend\n\nmodule Make1_and_test (M : Indexable1_and_for_test) = struct\n module B = Binary_searchable.Make1 (M)\n include B\n include Test1 (struct\n type 'a t = 'a M.t\n include B\n module For_test = M.For_test\n end)\nend\n","open! Import\n\nmodule type Conv = Conv.S\nmodule type Parser = Parser.S\nmodule type Eager_parser = Parser.S_eager\n\nmodule Conv_error = Conv_error\nmodule Of_sexp_error = Of_sexp_error\nmodule Old_parser_cont_state = Old_parser_cont_state\nmodule Parse_error = Parse_error\nmodule Positions = Positions\nmodule Cst = Cst\nmodule A = Parser_automaton\n\nexception Parse_error = Parse_error.Parse_error\nexception Of_sexp_error = Of_sexp_error.Of_sexp_error\n\nmodule Single =\n Parser.Make\n (Kind.Sexp)\n (struct\n type parsed_value = Sexp.t\n\n let mode = A.Single\n let make_value _ stack = Automaton_stack.get_single stack\n end)\n\nmodule Many =\n Parser.Make\n (Kind.Sexp)\n (struct\n type parsed_value = Sexp.t list\n\n let mode = A.Many\n let make_value _ stack = Automaton_stack.get_many stack\n end)\n\nmodule Eager =\n Parser.Make_eager\n (Kind.Sexp)\n (struct\n type parsed_value = Sexp.t\n\n let make_value _ stack = Automaton_stack.get_single stack\n end)\n\nmodule Single_and_positions =\n Parser.Make\n (Kind.Sexp_with_positions)\n (struct\n type parsed_value = Sexp.t * Positions.t\n\n let mode = A.Single\n let make_value state stack = Automaton_stack.get_single stack, A.positions state\n end)\n\nmodule Many_and_positions =\n Parser.Make\n (Kind.Sexp_with_positions)\n (struct\n type parsed_value = Sexp.t list * Positions.t\n\n let mode = A.Many\n let make_value state stack = Automaton_stack.get_many stack, A.positions state\n end)\n\nmodule Eager_and_positions =\n Parser.Make_eager\n (Kind.Sexp_with_positions)\n (struct\n type parsed_value = Sexp.t * Positions.t\n\n let make_value state stack = Automaton_stack.get_single stack, A.positions state\n end)\n\nmodule Single_just_positions =\n Parser.Make\n (Kind.Positions)\n (struct\n type parsed_value = Positions.t\n\n let mode = A.Single\n let make_value state () = A.positions state\n end)\n\nmodule Many_just_positions =\n Parser.Make\n (Kind.Positions)\n (struct\n type parsed_value = Positions.t\n\n let mode = A.Many\n let make_value state () = A.positions state\n end)\n\nmodule Eager_just_positions =\n Parser.Make_eager\n (Kind.Positions)\n (struct\n type parsed_value = Positions.t\n\n let make_value state () = A.positions state\n end)\n\nmodule Many_cst =\n Parser.Make\n (Kind.Cst)\n (struct\n type parsed_value = Cst.t_or_comment list\n\n let mode = A.Many\n let make_value _ stack = Automaton_stack.For_cst.get_many stack\n end)\n\nmodule Eager_cst =\n Parser.Make_eager\n (Kind.Cst)\n (struct\n type parsed_value = Cst.t_or_comment\n\n let make_value _ stack =\n match Automaton_stack.For_cst.get_many stack with\n | [ sexp ] -> sexp\n | _ -> assert false\n ;;\n end)\n\ntype 'a id = 'a\ntype sexp_list = Sexp.t list\n\nmodule Conv_single =\n Conv.Make\n (struct\n type 'a res = 'a\n type parsed_sexp = Sexp.t\n type chunk_to_conv = Sexp.t\n\n let apply_f x ~f = f x\n let find = Positions.find_sub_sexp_phys\n end)\n (Single)\n (Single_just_positions)\n\nmodule Conv_many =\n Conv.Make\n (struct\n type 'a res = 'a list\n type parsed_sexp = Sexp.t list\n type chunk_to_conv = Sexp.t\n\n let apply_f x ~f = List.rev (List.rev_map x ~f)\n let find = Positions.find_sub_sexp_in_list_phys\n end)\n (Many)\n (Many_just_positions)\n\nmodule Conv_many_at_once =\n Conv.Make\n (struct\n type 'a res = 'a\n type parsed_sexp = Sexp.t list\n type chunk_to_conv = Sexp.t list\n\n let apply_f x ~f = f x\n let find = Positions.find_sub_sexp_in_list_phys\n end)\n (Many)\n (Many_just_positions)\n\nmodule Private = struct\n module Automaton_stack = Automaton_stack\n module Parser_automaton = Parser_automaton\nend\n","open! Import\ninclude Automaton_stack_intf\n\nmodule For_cst = struct\n type t =\n | Empty\n | T_or_comment of Cst.t_or_comment * t\n | Open of Positions.pos * t\n | In_sexp_comment of\n { hash_semi_pos : Positions.pos\n ; rev_comments : Cst.comment list\n ; stack : t\n }\n\n let empty = Empty\n\n let get_many =\n let rec loop acc = function\n | Empty -> acc\n | T_or_comment (t, stack) -> loop (t :: acc) stack\n | Open _ | In_sexp_comment _ -> failwith \"Automaton_stack.For_cst.get_many\"\n in\n fun stack -> loop [] stack\n ;;\nend\n\nmodule Just_positions = struct\n type t = unit\n\n let empty = ()\nend\n\ntype t =\n | Empty\n | Open of t\n | Sexp of Sexp.t * t\n\nlet empty = Empty\n\nlet get_single = function\n | Sexp (sexp, Empty) -> sexp\n | _ -> failwith \"Automaton_stack.get_single\"\n;;\n\nlet get_many =\n let rec loop acc = function\n | Empty -> acc\n | Open _ -> failwith \"Automaton_stack.get_many\"\n | Sexp (sexp, stack) -> loop (sexp :: acc) stack\n in\n fun stack -> loop [] stack\n;;\n","open! Import\n\ntype t =\n { user_exn : exn\n ; sub_sexp : Sexp.t\n ; location : Positions.range option\n }\n[@@deriving_inline sexp_of]\n\nlet sexp_of_t =\n (function\n | { user_exn = v_user_exn; sub_sexp = v_sub_sexp; location = v_location } ->\n let bnds = [] in\n let bnds =\n let arg = sexp_of_option Positions.sexp_of_range v_location in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"location\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = Sexp.sexp_of_t v_sub_sexp in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"sub_sexp\"; arg ]\n :: bnds\n in\n let bnds =\n let arg = sexp_of_exn v_user_exn in\n Ppx_sexp_conv_lib.Sexp.List [ Ppx_sexp_conv_lib.Sexp.Atom \"user_exn\"; arg ]\n :: bnds\n in\n Ppx_sexp_conv_lib.Sexp.List bnds\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet user_exn t = t.user_exn\nlet sub_sexp t = t.sub_sexp\nlet location t = t.location\n\nlet report ppf ~filename t =\n let line, start, stop =\n match t.location with\n | None -> 1, 0, 0\n | Some { start_pos; end_pos } ->\n start_pos.line, start_pos.col, start_pos.col + end_pos.offset - start_pos.offset\n in\n Format.fprintf\n ppf\n \"File \\\"%s\\\", line %d, characters %d-%d:\\n\\\n Error: s-expression conversion error;\\n\\\n exception %s\\n\"\n filename\n line\n start\n stop\n (Printexc.to_string t.user_exn)\n;;\n\nexception Of_sexp_error of t [@@deriving_inline sexp_of]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add\n [%extension_constructor Of_sexp_error]\n (function\n | Of_sexp_error v0 ->\n let v0 = sexp_of_t v0 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"of_sexp_error.ml.Of_sexp_error\"; v0 ]\n | _ -> assert false)\n;;\n\n[@@@end]\n\nlet raise ~user_exn ~sub_sexp ~location =\n raise (Of_sexp_error { user_exn; sub_sexp; location })\n;;\n","open! Import\ninclude Parse_error_intf\n\ntype t =\n { position : Positions.pos\n ; message : string\n ; old_parser_exn : [ `Parse_error | `Failure ]\n }\n\nlet sexp_of_t { position; message; old_parser_exn = _ } : Sexp.t =\n List\n [ List [ Atom \"position\"; Positions.sexp_of_pos position ]\n ; List [ Atom \"message\"; sexp_of_string message ]\n ]\n;;\n\nlet position t = t.position\nlet message t = t.message\nlet old_parser_exn t = t.old_parser_exn\n\nlet report ppf ~filename t =\n let pos = position t in\n let msg = message t in\n Format.fprintf\n ppf\n \"File \\\"%s\\\", line %d, character %d:\\nError: s-expression parsing error;\\n%s\\n\"\n filename\n pos.line\n pos.col\n msg\n;;\n\nexception Parse_error of t [@@deriving_inline sexp]\n\nlet () =\n Ppx_sexp_conv_lib.Conv.Exn_converter.add [%extension_constructor Parse_error] (function\n | Parse_error v0 ->\n let v0 = sexp_of_t v0 in\n Ppx_sexp_conv_lib.Sexp.List\n [ Ppx_sexp_conv_lib.Sexp.Atom \"parse_error.ml.Parse_error\"; v0 ]\n | _ -> assert false)\n;;\n\n[@@@end]\n\nlet raise (reason : Reason.t) position ~at_eof ~atom_buffer =\n let message =\n (* These messages where choosen such that we can build the various Sexplib parsing\n functions on top of Parsexp and keep the same exceptions.\n\n At the time of writing this, a simple layer on top of parsexp to implement the\n sexplib API is passing all the sexplib tests.\n\n Note that parsexp matches the semantic of Sexp.parse which is slightly\n different from the ocamllex/ocamlyacc based parser of Sexplib. The latter one\n is less tested and assumed to be less used. *)\n match reason with\n | Unexpected_char_parsing_hex_escape -> \"unterminated hexadecimal escape sequence\"\n | Unexpected_char_parsing_dec_escape -> \"unterminated decimal escape sequence\"\n | Unterminated_quoted_string -> \"unterminated quoted string\"\n | Unterminated_block_comment -> \"unterminated block comment\"\n | Escape_sequence_out_of_range -> \"escape sequence in quoted string out of range\"\n | Unclosed_paren -> \"unclosed parentheses at end of input\"\n | Too_many_sexps -> \"s-expression followed by data\"\n | Closed_paren_without_opened -> \"unexpected character: ')'\"\n | Comment_token_in_unquoted_atom ->\n if String.equal (Buffer.contents atom_buffer) \"|\"\n then \"illegal end of comment\"\n else \"comment tokens in unquoted atom\"\n | Sexp_comment_without_sexp -> \"unterminated sexp comment\"\n | Unexpected_character_after_cr ->\n if at_eof\n then \"unexpected end of input after carriage return\"\n else \"unexpected character after carriage return\"\n | No_sexp_found_in_input -> \"no s-expression found in input\"\n | Automaton_in_error_state -> failwith \"Parsexp.Parser_automaton: parser is dead\"\n in\n let old_parser_exn =\n match reason, at_eof with\n | Too_many_sexps, _ | _, true -> `Failure\n | Comment_token_in_unquoted_atom, _\n when String.equal (Buffer.contents atom_buffer) \"|\" -> `Failure\n | _ -> `Parse_error\n in\n raise (Parse_error { position; message; old_parser_exn })\n;;\n\nmodule Private = struct\n module Reason = Reason\n\n let old_parser_exn = old_parser_exn\n let raise = raise\nend\n","open! Import\n\nmodule Public = struct\n type state_cst =\n { token_buffer : Buffer.t\n ; (* Starting positions of the current token *)\n mutable token_start_pos : Positions.pos\n }\n\n type ('u, 's) kind =\n | Positions : (Positions.Builder.t, unit) kind\n | Sexp : (unit, Automaton_stack.t) kind\n | Sexp_with_positions : (Positions.Builder.t, Automaton_stack.t) kind\n | Cst : (state_cst, Automaton_stack.For_cst.t) kind\n\n type ('u, 's) state =\n { mutable automaton_state : int\n ; kind : ('u, 's) kind\n ; mutable depth : int\n ; (* Number of opened #| when parsing a block comment *)\n mutable block_comment_depth : int\n ; (* Stack of ignoring depths; the current depth is pushed\n each time a #; comment is entered. *)\n mutable ignoring_stack : int list\n ; (* When parsing an escape sequence of the form \"\\\\NNN\" or \"\\\\XX\", this accumulates\n the computed number *)\n mutable escaped_value : int\n ; (* Buffer for accumulating atoms *)\n atom_buffer : Buffer.t\n ; user_state : 'u\n ; mode : ('u, 's) mode\n ; mutable full_sexps : int\n ; mutable offset : int (* global offset *)\n ; mutable line_number : int\n ; mutable bol_offset : int (* offset of beginning of line *)\n }\n\n and ('u, 's) mode =\n | Single\n | Many\n | Eager of\n { got_sexp : ('u, 's) state -> 's -> 's\n ; mutable no_sexp_is_error : bool\n }\n\n let initial_user_state : type u s. (u, s) kind -> Positions.pos -> u =\n fun kind initial_pos ->\n match kind with\n | Positions -> Positions.Builder.create ~initial_pos ()\n | Sexp -> ()\n | Sexp_with_positions -> Positions.Builder.create ~initial_pos ()\n | Cst ->\n (* [token_start_pos] is set to a dummy location here. It is properly set when we\n start to capture a token from the input *)\n { token_buffer = Buffer.create 128; token_start_pos = Positions.beginning_of_file }\n ;;\n\n (* these magic numbers are checked in gen_parser_automaton.ml:\n let () = assert (initial = 0)\n let () = assert (to_int Error = 1) *)\n let initial_state = 0\n let error_state = 1\n\n let new_state ?(initial_pos = Positions.beginning_of_file) mode kind =\n { kind\n ; depth = 0\n ; automaton_state = initial_state\n ; block_comment_depth = 0\n ; ignoring_stack = []\n ; escaped_value = 0\n ; atom_buffer = Buffer.create 128\n ; user_state = initial_user_state kind initial_pos\n ; mode\n ; full_sexps = 0\n ; offset = initial_pos.offset\n ; line_number = initial_pos.line\n ; bol_offset = initial_pos.offset - initial_pos.col\n }\n ;;\n\n let mode t = t.mode\n let positions t = Positions.Builder.contents t.user_state\n let atom_buffer t = t.atom_buffer\n let offset state = state.offset\n let line state = state.line_number\n let column state = state.offset - state.bol_offset\n let position t = { Positions.col = column t; line = line t; offset = offset t }\n\n let reset_user_state : type u s. (u, s) state -> unit =\n fun t ->\n match t.kind with\n | Positions -> Positions.Builder.reset t.user_state (position t)\n | Sexp -> ()\n | Sexp_with_positions -> Positions.Builder.reset t.user_state (position t)\n | Cst -> Buffer.clear t.user_state.token_buffer\n ;;\n\n let reset ?(pos = Positions.beginning_of_file) t =\n t.depth <- 0;\n t.automaton_state <- initial_state;\n t.block_comment_depth <- 0;\n t.ignoring_stack <- [];\n t.escaped_value <- 0;\n t.full_sexps <- 0;\n t.offset <- pos.offset;\n t.line_number <- pos.line;\n t.bol_offset <- pos.offset - pos.col;\n reset_user_state t;\n Buffer.clear t.atom_buffer\n ;;\n\n type context =\n | Sexp_comment\n | Sexp\n\n let is_ignoring state =\n match state.ignoring_stack with\n | _ :: _ -> true\n | [] -> false\n ;;\n\n let is_not_ignoring state = not (is_ignoring state)\n let context state = if is_not_ignoring state then Sexp else Sexp_comment\n let has_unclosed_paren state = state.depth > 0\n let set_error_state state = state.automaton_state <- error_state\n\n module Error = Parse_error\n\n let automaton_state state = state.automaton_state\nend\n\nopen Public\n\nlet raise_error : type a b. (a, b) state -> _ =\n fun state ~at_eof reason ->\n set_error_state state;\n Parse_error.Private.raise\n reason\n { line = state.line_number\n ; col = state.offset - state.bol_offset\n ; offset = state.offset\n }\n ~at_eof\n ~atom_buffer:state.atom_buffer\n;;\n\ntype nonrec context = context =\n | Sexp_comment\n | Sexp\n\nlet context = context\n\ntype ('u, 's) action = ('u, 's) state -> char -> 's -> 's\ntype ('u, 's) epsilon_action = ('u, 's) state -> 's -> 's\n\nlet current_pos ?(delta = 0) state : Positions.pos =\n let offset = state.offset + delta in\n { line = state.line_number; col = offset - state.bol_offset; offset }\n;;\n\nlet set_automaton_state state x = state.automaton_state <- x\nlet advance state = state.offset <- state.offset + 1\n\nlet advance_eol : type u s. (u, s) state -> unit =\n fun state ->\n let newline_offset = state.offset in\n state.offset <- newline_offset + 1;\n state.bol_offset <- state.offset;\n state.line_number <- state.line_number + 1;\n match state.kind with\n | Positions -> Positions.Builder.add_newline state.user_state ~offset:newline_offset\n | Sexp_with_positions ->\n Positions.Builder.add_newline state.user_state ~offset:newline_offset\n | _ -> ()\n;;\n\nlet block_comment_depth state = state.block_comment_depth\n\nlet add_token_char : type u s. (u, s) action =\n fun state char stack ->\n match state.kind with\n | Cst ->\n Buffer.add_char state.user_state.token_buffer char;\n stack\n | _ -> stack\n;;\n\nlet add_atom_char state c stack =\n Buffer.add_char state.atom_buffer c;\n stack\n;;\n\nlet add_quoted_atom_char state c stack =\n Buffer.add_char state.atom_buffer c;\n add_token_char state c stack\n;;\n\nlet check_new_sexp_allowed state =\n let is_single =\n match state.mode with\n | Single -> true\n | _ -> false\n in\n if is_single && state.full_sexps > 0 && is_not_ignoring state\n then raise_error state ~at_eof:false Too_many_sexps\n;;\n\nlet add_pos state ~delta =\n Positions.Builder.add state.user_state ~offset:(state.offset + delta)\n;;\n\nlet add_first_char : type u s. (u, s) action =\n fun state char stack ->\n check_new_sexp_allowed state;\n Buffer.add_char state.atom_buffer char;\n (* For non-quoted atoms, we save both positions at the end. We can always determine the\n start position from the end position and the atom length for non-quoted atoms.\n\n Doing it this way allows us to detect single characater atoms for which we need to\n save the position twice. *)\n stack\n;;\n\nlet eps_add_first_char_hash : type u s. (u, s) epsilon_action =\n fun state stack ->\n check_new_sexp_allowed state;\n Buffer.add_char state.atom_buffer '#';\n stack\n;;\n\nlet start_quoted_string : type u s. (u, s) action =\n fun state _char stack ->\n check_new_sexp_allowed state;\n match state.kind with\n | Positions ->\n if is_not_ignoring state then add_pos state ~delta:0;\n stack\n | Sexp_with_positions ->\n if is_not_ignoring state then add_pos state ~delta:0;\n stack\n | Cst ->\n state.user_state.token_start_pos <- current_pos state;\n Buffer.add_char state.user_state.token_buffer '\"';\n stack\n | Sexp -> stack\n;;\n\nlet add_escaped state c stack =\n let c' =\n match c with\n | 'n' -> '\\n'\n | 'r' -> '\\r'\n | 'b' -> '\\b'\n | 't' -> '\\t'\n | '\\\\' | '\\'' | '\"' -> c\n | _ ->\n Buffer.add_char state.atom_buffer '\\\\';\n c\n in\n Buffer.add_char state.atom_buffer c';\n add_token_char state c stack\n;;\n\nlet eps_add_escaped_cr state stack =\n Buffer.add_char state.atom_buffer '\\r';\n stack\n;;\n\nlet dec_val c = Char.code c - Char.code '0'\n\nlet hex_val c =\n match c with\n | '0' .. '9' -> Char.code c - Char.code '0'\n | 'a' .. 'f' -> Char.code c - Char.code 'a' + 10\n | _ -> Char.code c - Char.code 'A' + 10\n;;\n\nlet add_dec_escape_char state c stack =\n state.escaped_value <- (state.escaped_value * 10) + dec_val c;\n add_token_char state c stack\n;;\n\nlet add_last_dec_escape_char state c stack =\n let value = (state.escaped_value * 10) + dec_val c in\n state.escaped_value <- 0;\n if value > 255 then raise_error state ~at_eof:false Escape_sequence_out_of_range;\n Buffer.add_char state.atom_buffer (Char.chr value);\n add_token_char state c stack\n;;\n\nlet comment_add_last_dec_escape_char state c stack =\n let value = (state.escaped_value * 10) + dec_val c in\n state.escaped_value <- 0;\n if value > 255 then raise_error state ~at_eof:false Escape_sequence_out_of_range;\n add_token_char state c stack\n;;\n\nlet add_hex_escape_char state c stack =\n state.escaped_value <- (state.escaped_value lsl 4) lor hex_val c;\n add_token_char state c stack\n;;\n\nlet add_last_hex_escape_char state c stack =\n let value = (state.escaped_value lsl 4) lor hex_val c in\n state.escaped_value <- 0;\n Buffer.add_char state.atom_buffer (Char.chr value);\n add_token_char state c stack\n;;\n\nlet opening : type u s. (u, s) state -> char -> s -> s =\n fun state _char stack ->\n check_new_sexp_allowed state;\n state.depth <- state.depth + 1;\n match state.kind with\n | Positions ->\n if is_not_ignoring state then add_pos state ~delta:0;\n stack\n | Sexp -> if is_not_ignoring state then Open stack else stack\n | Sexp_with_positions ->\n if is_not_ignoring state\n then (\n add_pos state ~delta:0;\n Open stack)\n else stack\n | Cst -> Open (current_pos state, stack)\n;;\n\nlet do_reset_positions state =\n Positions.Builder.reset\n state.user_state\n { line = state.line_number\n ; col = state.offset - state.bol_offset\n ; offset = state.offset\n }\n;;\n\nlet reset_positions : type u s. (u, s) state -> unit =\n fun state ->\n match state.kind with\n | Positions -> do_reset_positions state\n | Sexp_with_positions -> do_reset_positions state\n | Sexp -> ()\n | Cst -> ()\n;;\n\nlet toplevel_sexp_or_comment_added state stack ~delta =\n match state.mode with\n | Single | Many -> stack\n | Eager { got_sexp = f; _ } ->\n (* Modify the offset so that [f] get a state pointing to the end of the current\n s-expression *)\n let saved_offset = state.offset in\n state.offset <- state.offset + delta;\n let saved_full_sexps = state.full_sexps in\n (match f state stack with\n | exception e ->\n set_error_state state;\n raise e\n | stack ->\n (* This assert is not a full protection against the user mutating the state but\n it should catch most cases. *)\n assert (state.offset = saved_offset + delta && state.full_sexps = saved_full_sexps);\n state.offset <- saved_offset;\n reset_positions state;\n stack)\n;;\n\nlet is_top_level state = is_not_ignoring state && state.depth = 0\n\nlet comment_added_assuming_cst state stack ~delta =\n if is_top_level state then toplevel_sexp_or_comment_added state stack ~delta else stack\n;;\n\nlet maybe_pop_ignoring_stack state =\n match state.ignoring_stack with\n | inner_comment_depth :: _tl when inner_comment_depth > state.depth ->\n raise_error state ~at_eof:false Sexp_comment_without_sexp\n | inner_comment_depth :: tl when inner_comment_depth = state.depth ->\n state.ignoring_stack <- tl;\n true\n | _ -> false\n;;\n\nlet sexp_added : type u s. (u, s) state -> s -> delta:int -> s =\n fun state stack ~delta ->\n let is_comment = maybe_pop_ignoring_stack state in\n if is_top_level state\n then (\n if not is_comment then state.full_sexps <- state.full_sexps + 1;\n if (not is_comment)\n ||\n match state.kind with\n | Cst -> true\n | _ -> false\n then toplevel_sexp_or_comment_added state stack ~delta\n else stack)\n else stack\n;;\n\nlet rec make_list acc : Automaton_stack.t -> Automaton_stack.t = function\n | Empty -> assert false\n | Open stack -> Sexp (List acc, stack)\n | Sexp (sexp, stack) -> make_list (sexp :: acc) stack\n;;\n\nlet add_comment_to_stack_cst comment (stack : Automaton_stack.For_cst.t)\n : Automaton_stack.For_cst.t\n =\n match stack with\n | In_sexp_comment r ->\n In_sexp_comment { r with rev_comments = comment :: r.rev_comments }\n | _ -> T_or_comment (Comment comment, stack)\n;;\n\nlet add_sexp_to_stack_cst sexp : Automaton_stack.For_cst.t -> Automaton_stack.For_cst.t\n = function\n | In_sexp_comment { hash_semi_pos; rev_comments; stack } ->\n let comment : Cst.comment =\n Sexp_comment { hash_semi_pos; comments = List.rev rev_comments; sexp }\n in\n add_comment_to_stack_cst comment stack\n | stack -> T_or_comment (Sexp sexp, stack)\n;;\n\nlet rec make_list_cst end_pos acc\n : Automaton_stack.For_cst.t -> Automaton_stack.For_cst.t\n = function\n | T_or_comment (t, stack) -> make_list_cst end_pos (t :: acc) stack\n | Open (start_pos, stack) ->\n let sexp : Cst.t = List { loc = { start_pos; end_pos }; elements = acc } in\n add_sexp_to_stack_cst sexp stack\n | Empty | In_sexp_comment _ -> assert false\n;;\n\nlet closing : type u s. (u, s) state -> char -> s -> s =\n fun state _char stack ->\n if state.depth > 0\n then (\n let stack : s =\n match state.kind with\n | Positions ->\n (* Note we store end positions as inclusive in [Positions.t], so we use [delta:0],\n while in the [Cst] case we save directly the final ranges, so we use\n [delta:1]. *)\n if is_not_ignoring state then add_pos state ~delta:0;\n stack\n | Sexp -> if is_not_ignoring state then make_list [] stack else stack\n | Sexp_with_positions ->\n if is_not_ignoring state\n then (\n add_pos state ~delta:0;\n make_list [] stack)\n else stack\n | Cst -> make_list_cst (current_pos state ~delta:1) [] stack\n in\n state.depth <- state.depth - 1;\n sexp_added state stack ~delta:1)\n else raise_error state ~at_eof:false Closed_paren_without_opened\n;;\n\nlet make_loc ?(delta = 0) state : Positions.range =\n { start_pos = state.user_state.token_start_pos; end_pos = current_pos state ~delta }\n;;\n\n(* This is always called on the position exactly following the last character of a\n non-quoted atom *)\nlet add_non_quoted_atom_pos state ~atom =\n let len = String.length atom in\n if len = 1\n then Positions.Builder.add_twice state.user_state ~offset:(state.offset - 1)\n else (\n add_pos state ~delta:(-len);\n add_pos state ~delta:(-1))\n;;\n\nlet eps_push_atom : type u s. (u, s) epsilon_action =\n fun state stack ->\n let str = Buffer.contents state.atom_buffer in\n Buffer.clear state.atom_buffer;\n let stack : s =\n match state.kind with\n | Positions ->\n if is_not_ignoring state then add_non_quoted_atom_pos state ~atom:str;\n stack\n | Sexp -> if is_not_ignoring state then Sexp (Atom str, stack) else stack\n | Sexp_with_positions ->\n if is_not_ignoring state\n then (\n add_non_quoted_atom_pos state ~atom:str;\n Sexp (Atom str, stack))\n else stack\n | Cst ->\n let loc : Positions.range =\n { start_pos = current_pos state ~delta:(-String.length str)\n ; end_pos = current_pos state ~delta:0\n }\n in\n let sexp : Cst.t = Atom { loc; atom = str; unescaped = Some str } in\n add_sexp_to_stack_cst sexp stack\n in\n sexp_added state stack ~delta:0\n;;\n\nlet push_quoted_atom : type u s. (u, s) action =\n fun state _char stack ->\n let str = Buffer.contents state.atom_buffer in\n Buffer.clear state.atom_buffer;\n let stack : s =\n match state.kind with\n | Positions ->\n if is_not_ignoring state then add_pos state ~delta:0;\n stack\n | Sexp -> if is_not_ignoring state then Sexp (Atom str, stack) else stack\n | Sexp_with_positions ->\n if is_not_ignoring state\n then (\n add_pos state ~delta:0;\n Sexp (Atom str, stack))\n else stack\n | Cst ->\n let buf = state.user_state.token_buffer in\n Buffer.add_char buf '\"';\n let s = Buffer.contents buf in\n Buffer.clear buf;\n let sexp : Cst.t =\n Atom { loc = make_loc state ~delta:1; atom = str; unescaped = Some s }\n in\n add_sexp_to_stack_cst sexp stack\n in\n sexp_added state stack ~delta:1\n;;\n\nlet start_sexp_comment : type u s. (u, s) action =\n fun state _char stack ->\n state.ignoring_stack <- state.depth :: state.ignoring_stack;\n match state.kind with\n | Cst ->\n In_sexp_comment\n { hash_semi_pos = current_pos state ~delta:(-1); rev_comments = []; stack }\n | _ -> stack\n;;\n\nlet start_block_comment : type u s. (u, s) state -> char -> s -> s =\n fun state char stack ->\n state.block_comment_depth <- state.block_comment_depth + 1;\n match state.kind with\n | Positions -> stack\n | Sexp -> stack\n | Sexp_with_positions -> stack\n | Cst ->\n if state.block_comment_depth = 1\n then (\n state.user_state.token_start_pos <- current_pos state ~delta:(-1);\n Buffer.add_char state.user_state.token_buffer '#');\n Buffer.add_char state.user_state.token_buffer char;\n stack\n;;\n\nlet end_block_comment : type u s. (u, s) state -> char -> s -> s =\n fun state char stack ->\n state.block_comment_depth <- state.block_comment_depth - 1;\n match state.kind with\n | Positions -> stack\n | Sexp -> stack\n | Sexp_with_positions -> stack\n | Cst ->\n let buf = state.user_state.token_buffer in\n Buffer.add_char buf char;\n if state.block_comment_depth = 0\n then (\n let s = Buffer.contents buf in\n Buffer.clear buf;\n let comment : Cst.comment =\n Plain_comment { loc = make_loc state ~delta:1; comment = s }\n in\n let stack = add_comment_to_stack_cst comment stack in\n comment_added_assuming_cst state stack ~delta:1)\n else stack\n;;\n\nlet start_line_comment : type u s. (u, s) action =\n fun state char stack ->\n match state.kind with\n | Cst ->\n state.user_state.token_start_pos <- current_pos state;\n Buffer.add_char state.user_state.token_buffer char;\n stack\n | _ -> stack\n;;\n\nlet end_line_comment : type u s. (u, s) epsilon_action =\n fun state stack ->\n match state.kind with\n | Positions -> stack\n | Sexp -> stack\n | Sexp_with_positions -> stack\n | Cst ->\n let buf = state.user_state.token_buffer in\n let s = Buffer.contents buf in\n Buffer.clear buf;\n let comment : Cst.comment = Plain_comment { loc = make_loc state; comment = s } in\n let stack = add_comment_to_stack_cst comment stack in\n comment_added_assuming_cst state stack ~delta:0\n;;\n\nlet eps_eoi_check : type u s. (u, s) epsilon_action =\n fun state stack ->\n if state.depth > 0 then raise_error state ~at_eof:true Unclosed_paren;\n if is_ignoring state then raise_error state ~at_eof:true Sexp_comment_without_sexp;\n if state.full_sexps = 0\n then (\n match state.mode with\n | Many | Eager { no_sexp_is_error = false; _ } -> ()\n | Single | Eager { no_sexp_is_error = true; _ } ->\n raise_error state ~at_eof:true No_sexp_found_in_input);\n stack\n;;\n","open Parser_automaton_internal\ninclude Public\n\nlet raise = Parser_automaton_internal.raise_error\n\ntype u'\ntype s'\n\n(*$ open Parsexp_cinaps_helpers.Gen_parser_automaton ;; *)\n(*$ print_code () ;; *)\n\nlet tr_00 state char stack =\n let stack = add_first_char state char stack in\n set_automaton_state state 3;\n advance state;\n stack\n;;\n\nlet tr_01 state _char stack =\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_02 state _char stack =\n set_automaton_state state 0;\n advance_eol state;\n stack\n;;\n\nlet tr_03 state _char stack =\n set_automaton_state state 2;\n advance state;\n stack\n;;\n\nlet tr_04 state char stack =\n let stack = start_quoted_string state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_05 state _char stack =\n set_automaton_state state 7;\n advance state;\n stack\n;;\n\nlet tr_06 state char stack =\n let stack = opening state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_07 state char stack =\n let stack = closing state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_08 state char stack =\n let stack = start_line_comment state char stack in\n set_automaton_state state 6;\n advance state;\n stack\n;;\n\nlet tr_09 state char stack =\n let stack = add_first_char state char stack in\n set_automaton_state state 5;\n advance state;\n stack\n;;\n\nlet tr_10 _state _char _stack = raise _state ~at_eof:false Automaton_in_error_state\nlet tr_11 _state _char _stack = raise _state ~at_eof:false Unexpected_character_after_cr\n\nlet tr_12 state char stack =\n let stack = add_atom_char state char stack in\n set_automaton_state state 3;\n advance state;\n stack\n;;\n\nlet tr_13 state _char stack =\n let stack = eps_push_atom state stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_14 state _char stack =\n let stack = eps_push_atom state stack in\n set_automaton_state state 0;\n advance_eol state;\n stack\n;;\n\nlet tr_15 state _char stack =\n let stack = eps_push_atom state stack in\n set_automaton_state state 2;\n advance state;\n stack\n;;\n\nlet tr_16 state char stack =\n let stack = eps_push_atom state stack in\n let stack = start_quoted_string state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_17 state char stack =\n let stack = add_atom_char state char stack in\n set_automaton_state state 4;\n advance state;\n stack\n;;\n\nlet tr_18 state char stack =\n let stack = eps_push_atom state stack in\n let stack = opening state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_19 state char stack =\n let stack = eps_push_atom state stack in\n let stack = closing state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_20 state char stack =\n let stack = eps_push_atom state stack in\n let stack = start_line_comment state char stack in\n set_automaton_state state 6;\n advance state;\n stack\n;;\n\nlet tr_21 state char stack =\n let stack = add_atom_char state char stack in\n set_automaton_state state 5;\n advance state;\n stack\n;;\n\nlet tr_22 _state _char _stack = raise _state ~at_eof:false Comment_token_in_unquoted_atom\n\nlet tr_23 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 6;\n advance state;\n stack\n;;\n\nlet tr_24 state _char stack =\n let stack = end_line_comment state stack in\n set_automaton_state state 0;\n advance_eol state;\n stack\n;;\n\nlet tr_25 state _char stack =\n let stack = end_line_comment state stack in\n set_automaton_state state 2;\n advance state;\n stack\n;;\n\nlet tr_26 state char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = add_atom_char state char stack in\n set_automaton_state state 3;\n advance state;\n stack\n;;\n\nlet tr_27 state _char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_28 state _char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n set_automaton_state state 0;\n advance_eol state;\n stack\n;;\n\nlet tr_29 state _char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n set_automaton_state state 2;\n advance state;\n stack\n;;\n\nlet tr_30 state char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n let stack = start_quoted_string state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_31 state char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = add_atom_char state char stack in\n set_automaton_state state 4;\n advance state;\n stack\n;;\n\nlet tr_32 state char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n let stack = opening state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_33 state char stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n let stack = closing state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_34 state char stack =\n let stack = start_sexp_comment state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_35 state char stack =\n let stack = start_block_comment state char stack in\n set_automaton_state state 16;\n advance state;\n stack\n;;\n\nlet tr_36 state char stack =\n let stack = add_quoted_atom_char state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_37 state char stack =\n let stack = add_quoted_atom_char state char stack in\n set_automaton_state state 8;\n advance_eol state;\n stack\n;;\n\nlet tr_38 state char stack =\n let stack = push_quoted_atom state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_39 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 9;\n advance state;\n stack\n;;\n\nlet tr_40 state char stack =\n let stack = add_escaped state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_41 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 15;\n advance_eol state;\n stack\n;;\n\nlet tr_42 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 10;\n advance state;\n stack\n;;\n\nlet tr_43 state char stack =\n let stack = add_dec_escape_char state char stack in\n set_automaton_state state 11;\n advance state;\n stack\n;;\n\nlet tr_44 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 13;\n advance state;\n stack\n;;\n\nlet tr_45 state char stack =\n let stack = eps_add_escaped_cr state stack in\n let stack = add_quoted_atom_char state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_46 state char stack =\n let stack = eps_add_escaped_cr state stack in\n let stack = push_quoted_atom state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_47 state char stack =\n let stack = eps_add_escaped_cr state stack in\n let stack = add_token_char state char stack in\n set_automaton_state state 9;\n advance state;\n stack\n;;\n\nlet tr_48 _state _char _stack =\n raise _state ~at_eof:false Unexpected_char_parsing_dec_escape\n;;\n\nlet tr_49 state char stack =\n let stack = add_dec_escape_char state char stack in\n set_automaton_state state 12;\n advance state;\n stack\n;;\n\nlet tr_50 state char stack =\n let stack = add_last_dec_escape_char state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_51 _state _char _stack =\n raise _state ~at_eof:false Unexpected_char_parsing_hex_escape\n;;\n\nlet tr_52 state char stack =\n let stack = add_hex_escape_char state char stack in\n set_automaton_state state 14;\n advance state;\n stack\n;;\n\nlet tr_53 state char stack =\n let stack = add_last_hex_escape_char state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_54 state char stack =\n let stack = add_quoted_atom_char state char stack in\n set_automaton_state state 8;\n advance state;\n stack\n;;\n\nlet tr_55 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 15;\n advance state;\n stack\n;;\n\nlet tr_56 state char stack =\n let stack = add_quoted_atom_char state char stack in\n set_automaton_state state 8;\n advance_eol state;\n stack\n;;\n\nlet tr_57 state char stack =\n let stack = push_quoted_atom state char stack in\n set_automaton_state state 0;\n advance state;\n stack\n;;\n\nlet tr_58 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 9;\n advance state;\n stack\n;;\n\nlet tr_59 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 16;\n advance state;\n stack\n;;\n\nlet tr_60 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 16;\n advance_eol state;\n stack\n;;\n\nlet tr_61 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 19;\n advance state;\n stack\n;;\n\nlet tr_62 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 18;\n advance state;\n stack\n;;\n\nlet tr_63 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 17;\n advance state;\n stack\n;;\n\nlet tr_64 state char stack =\n let stack = end_block_comment state char stack in\n set_automaton_state state (if block_comment_depth state <> 0 then 16 else 0);\n advance state;\n stack\n;;\n\nlet tr_65 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 19;\n advance_eol state;\n stack\n;;\n\nlet tr_66 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 20;\n advance state;\n stack\n;;\n\nlet tr_67 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 26;\n advance_eol state;\n stack\n;;\n\nlet tr_68 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 21;\n advance state;\n stack\n;;\n\nlet tr_69 state char stack =\n let stack = add_dec_escape_char state char stack in\n set_automaton_state state 22;\n advance state;\n stack\n;;\n\nlet tr_70 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 24;\n advance state;\n stack\n;;\n\nlet tr_71 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 19;\n advance state;\n stack\n;;\n\nlet tr_72 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 16;\n advance state;\n stack\n;;\n\nlet tr_73 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 20;\n advance state;\n stack\n;;\n\nlet tr_74 state char stack =\n let stack = add_dec_escape_char state char stack in\n set_automaton_state state 23;\n advance state;\n stack\n;;\n\nlet tr_75 state char stack =\n let stack = comment_add_last_dec_escape_char state char stack in\n set_automaton_state state 19;\n advance state;\n stack\n;;\n\nlet tr_76 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 25;\n advance state;\n stack\n;;\n\nlet tr_77 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 26;\n advance state;\n stack\n;;\n\nlet tr_78 state char stack =\n let stack = add_token_char state char stack in\n set_automaton_state state 19;\n advance_eol state;\n stack\n;;\n\nlet tr_eoi_00 state stack = eps_eoi_check state stack\nlet tr_eoi_01 state _stack = raise state ~at_eof:true Automaton_in_error_state\nlet tr_eoi_02 state _stack = raise state ~at_eof:true Unexpected_character_after_cr\n\nlet tr_eoi_03 state stack =\n let stack = eps_push_atom state stack in\n eps_eoi_check state stack\n;;\n\nlet tr_eoi_04 state stack =\n let stack = end_line_comment state stack in\n eps_eoi_check state stack\n;;\n\nlet tr_eoi_05 state stack =\n let stack = eps_add_first_char_hash state stack in\n let stack = eps_push_atom state stack in\n eps_eoi_check state stack\n;;\n\nlet tr_eoi_06 state _stack = raise state ~at_eof:true Unterminated_quoted_string\nlet tr_eoi_07 state _stack = raise state ~at_eof:true Unterminated_block_comment\n\nlet transitions =\n [| tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_01\n ; tr_02\n ; tr_00\n ; tr_01\n ; tr_03\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_01\n ; tr_00\n ; tr_04\n ; tr_05\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_06\n ; tr_07\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_08\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_09\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_00\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_10\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_02\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_11\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_14\n ; tr_12\n ; tr_13\n ; tr_15\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_12\n ; tr_16\n ; tr_17\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_18\n ; tr_19\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_20\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_21\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_14\n ; tr_12\n ; tr_13\n ; tr_15\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_12\n ; tr_16\n ; tr_17\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_18\n ; tr_19\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_20\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_22\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_14\n ; tr_12\n ; tr_13\n ; tr_15\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_13\n ; tr_12\n ; tr_16\n ; tr_22\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_18\n ; tr_19\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_20\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_21\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_12\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_24\n ; tr_23\n ; tr_23\n ; tr_25\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_23\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_27\n ; tr_28\n ; tr_26\n ; tr_27\n ; tr_29\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_27\n ; tr_26\n ; tr_30\n ; tr_31\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_32\n ; tr_33\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_34\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_35\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_26\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_37\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_38\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_39\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_36\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_41\n ; tr_40\n ; tr_40\n ; tr_42\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_43\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_44\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_40\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_41\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_46\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_47\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_45\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_49\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_50\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_52\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_53\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_55\n ; tr_56\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_55\n ; tr_54\n ; tr_57\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_58\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_54\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_60\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_61\n ; tr_62\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_63\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_60\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_61\n ; tr_64\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_63\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_60\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_61\n ; tr_62\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_35\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_59\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_65\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_59\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_66\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_67\n ; tr_61\n ; tr_61\n ; tr_68\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_69\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_70\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_67\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_72\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_73\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_74\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_75\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_48\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_76\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_61\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_51\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_77\n ; tr_78\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_77\n ; tr_71\n ; tr_72\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_73\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n ; tr_71\n |]\n;;\n\nlet transitions_eoi =\n [| tr_eoi_00\n ; tr_eoi_01\n ; tr_eoi_02\n ; tr_eoi_03\n ; tr_eoi_03\n ; tr_eoi_03\n ; tr_eoi_04\n ; tr_eoi_05\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_06\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n ; tr_eoi_07\n |]\n;;\n\nlet old_parser_approx_cont_states : Old_parser_cont_state.t array =\n [| Parsing_toplevel_whitespace\n ; Parsing_toplevel_whitespace\n ; Parsing_nested_whitespace\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_toplevel_whitespace\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_atom\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n ; Parsing_block_comment\n |]\n;;\n\n(*$*)\n\nlet feed (type u s) (state : (u, s) state) char (stack : s) : s =\n let idx = (automaton_state state lsl 8) lor Char.code char in\n (* We need an Obj.magic as the type of the array can't be generalized.\n This problem will go away when we get immutable arrays. *)\n let magic\n : ((u', s') state -> char -> s' -> s') array\n -> ((u, s) state -> char -> s -> s) array\n =\n Obj.magic\n in\n (magic transitions).(idx) state char stack\n[@@inline always]\n;;\n\nlet feed_eoi (type u s) (state : (u, s) state) (stack : s) : s =\n let magic : ((u', s') state -> s' -> s') array -> ((u, s) state -> s -> s) array =\n Obj.magic\n in\n let stack = (magic transitions_eoi).(automaton_state state) state stack in\n set_error_state state;\n stack\n;;\n\nlet old_parser_cont_state state : Old_parser_cont_state.t =\n match context state with\n | Sexp_comment -> Parsing_sexp_comment\n | Sexp ->\n (match\n old_parser_approx_cont_states.(automaton_state state), has_unclosed_paren state\n with\n | Parsing_toplevel_whitespace, true -> Parsing_list\n | s, _ -> s)\n;;\n","open! Import\ninclude Kind_intf\n\nlet create (type stack state) (module Stack : Stack with type t = stack) kind\n : (module S with type Stack.t = stack and type state = state)\n =\n (module struct\n module Stack = Stack\n\n type nonrec state = state\n\n let kind = kind\n end)\n;;\n\nmodule Sexp = (val create (module Automaton_stack) Sexp)\nmodule Sexp_with_positions = (val create (module Automaton_stack) Sexp_with_positions)\nmodule Positions = (val create (module Automaton_stack.Just_positions) Positions)\nmodule Cst = (val create (module Automaton_stack.For_cst) Cst)\n","open! Import\n\nlet rec feed_substring_unsafe str state stack i stop =\n if i < stop\n then (\n let c = String.unsafe_get str i in\n let stack = Parser_automaton.feed state c stack in\n feed_substring_unsafe str state stack (i + 1) stop)\n else stack\n;;\n\nlet rec feed_subbytes_unsafe str state stack i stop =\n if i < stop\n then (\n let c = Bytes.unsafe_get str i in\n let stack = Parser_automaton.feed state c stack in\n feed_subbytes_unsafe str state stack (i + 1) stop)\n else stack\n;;\n\nlet feed_substring state str ~pos ~len stack =\n let str_len = String.length str in\n if pos < 0 || len < 0 || pos > str_len - len then invalid_arg \"Parsexp.feed_substring\";\n feed_substring_unsafe str state stack pos (pos + len)\n;;\n\nlet feed_subbytes state str ~pos ~len stack =\n let str_len = Bytes.length str in\n if pos < 0 || len < 0 || pos > str_len - len then invalid_arg \"Parsexp.feed_subbytes\";\n feed_subbytes_unsafe str state stack pos (pos + len)\n;;\n\nlet feed_string state str stack =\n feed_substring_unsafe str state stack 0 (String.length str)\n;;\n\nlet feed_bytes state str stack =\n feed_subbytes_unsafe str state stack 0 (Bytes.length str)\n;;\n","open! Import\ninclude Parser_intf\n\n\nmodule Make (Kind : Kind.S) (Mode : Mode(Kind).S) :\n S\n with type parsed_value = Mode.parsed_value\n with type State.t = (Kind.state, Kind.Stack.t) A.state\n with module Stack = Kind.Stack = struct\n type parsed_value = Mode.parsed_value\n\n module Stack = Kind.Stack\n\n module State = struct\n type t = (Kind.state, Kind.Stack.t) A.state\n\n let create ?pos () = A.new_state ?initial_pos:pos Mode.mode Kind.kind\n let reset = A.reset\n let offset = A.offset\n let line = A.line\n let column = A.column\n let position t : Positions.pos = { offset = offset t; line = line t; col = column t }\n let stop state = A.set_error_state state\n end\n\n let feed = A.feed\n let feed_eoi state stack = Mode.make_value state (A.feed_eoi state stack)\n let feed_substring = Automaton_helpers.feed_substring\n let feed_string = Automaton_helpers.feed_string\n let feed_subbytes = Automaton_helpers.feed_subbytes\n let feed_bytes = Automaton_helpers.feed_bytes\n\n let parse_string_exn str =\n let state = State.create () in\n feed_eoi state (feed_string state str Kind.Stack.empty)\n ;;\n\n let parse_string str =\n match parse_string_exn str with\n | x -> Ok x\n | exception Parse_error.Parse_error e -> Error e\n ;;\nend\n\nmodule Make_eager (Kind : Kind.S) (Mode : Mode_eager(Kind).S) :\n S_eager\n with type parsed_value = Mode.parsed_value\n with type State.t = (Kind.state, Kind.Stack.t) A.state\n with module Stack = Kind.Stack = struct\n type parsed_value = Mode.parsed_value\n\n module Stack = Kind.Stack\n\n module State = struct\n module Read_only = struct\n type t = (Kind.state, Kind.Stack.t) A.state\n\n let offset = A.offset\n let line = A.line\n let column = A.column\n\n let position t : Positions.pos =\n { offset = offset t; line = line t; col = column t }\n ;;\n end\n\n include Read_only\n\n let create ?pos ?(no_sexp_is_error = false) f =\n let got_sexp state stack =\n let parsed_value = Mode.make_value state stack in\n f state parsed_value;\n Stack.empty\n in\n A.new_state ?initial_pos:pos (Eager { got_sexp; no_sexp_is_error }) Kind.kind\n ;;\n\n let reset = A.reset\n let stop t = A.set_error_state t\n let old_parser_cont_state t = Parser_automaton.old_parser_cont_state t\n end\n\n let feed = A.feed\n let feed_eoi state stack = ignore (A.feed_eoi state stack : Stack.t)\n let feed_substring = Automaton_helpers.feed_substring\n let feed_string = Automaton_helpers.feed_string\n let feed_subbytes = Automaton_helpers.feed_subbytes\n let feed_bytes = Automaton_helpers.feed_bytes\n\n module Lexbuf_consumer = struct\n type t = State.t\n\n exception Got_sexp of parsed_value * Positions.pos\n\n let got_sexp state parsed_value =\n raise_notrace (Got_sexp (parsed_value, State.position state))\n ;;\n\n let create () = State.create got_sexp\n\n let pos_of_lexbuf lexbuf =\n let p = lexbuf.Lexing.lex_curr_p in\n { Positions.line = p.pos_lnum; col = p.pos_cnum - p.pos_bol; offset = p.pos_cnum }\n ;;\n\n let update_lexbuf (lexbuf : Lexing.lexbuf) (pos : Positions.pos) =\n let p = pos.offset - lexbuf.lex_abs_pos in\n lexbuf.lex_curr_pos <- p;\n lexbuf.lex_start_pos <- p;\n lexbuf.lex_curr_p\n <- { lexbuf.lex_curr_p with\n pos_lnum = pos.line\n ; pos_cnum = pos.offset\n ; pos_bol = pos.offset - pos.col\n }\n ;;\n\n let rec feed_lexbuf t (lexbuf : Lexing.lexbuf) stack =\n let stack =\n feed_subbytes\n t\n lexbuf.lex_buffer\n stack\n ~pos:lexbuf.lex_curr_pos\n ~len:(lexbuf.lex_buffer_len - lexbuf.lex_curr_pos)\n in\n lexbuf.lex_curr_pos <- lexbuf.lex_buffer_len;\n lexbuf.lex_start_pos <- lexbuf.lex_buffer_len;\n if not lexbuf.lex_eof_reached\n then (\n lexbuf.refill_buff lexbuf;\n feed_lexbuf t lexbuf stack)\n else feed_eoi t stack\n ;;\n\n let parse_gen t (lexbuf : Lexing.lexbuf) =\n A.reset t ~pos:(pos_of_lexbuf lexbuf);\n match feed_lexbuf t lexbuf Stack.empty with\n | () ->\n update_lexbuf lexbuf (State.position t);\n None\n | exception Got_sexp (parsed_value, pos) ->\n update_lexbuf lexbuf pos;\n Some parsed_value\n | exception exn ->\n update_lexbuf lexbuf (State.position t);\n raise exn\n ;;\n\n let set_no_sexp_is_error t x =\n match A.mode t with\n | Eager e -> e.no_sexp_is_error <- x\n | _ -> assert false\n ;;\n\n let parse t lexbuf =\n set_no_sexp_is_error t true;\n match parse_gen t lexbuf with\n | Some x -> x\n | None -> failwith \"Parsexp.parse_gen: None\"\n ;;\n\n let parse_opt t lexbuf =\n set_no_sexp_is_error t false;\n parse_gen t lexbuf\n ;;\n end\nend\n","open! Import\ninclude Conv_intf\n\nmodule Make\n (Mode : Mode)\n (Sexp_parser : Parser.S with type parsed_value = Mode.parsed_sexp)\n (Positions_parser : Parser.S with type parsed_value = Positions.t) =\nstruct\n let reraise positions parsed_value ~sub user_exn =\n let location = Mode.find positions parsed_value ~sub in\n Of_sexp_error.raise ~user_exn ~sub_sexp:sub ~location\n ;;\n\n let parse_string_exn str f =\n let parsed_value = Sexp_parser.parse_string_exn str in\n match Mode.apply_f parsed_value ~f with\n | x -> x\n | exception Sexp.Of_sexp_error (exn, sub) ->\n let positions = Positions_parser.parse_string_exn str in\n reraise positions parsed_value exn ~sub\n ;;\n\n let parse_string str f : (_, Conv_error.t) result =\n match parse_string_exn str f with\n | x -> Ok x\n | exception Parse_error.Parse_error e -> Error (Parse_error e)\n | exception Of_sexp_error.Of_sexp_error e -> Error (Of_sexp_error e)\n ;;\n\n let conv_exn (parsed_value, positions) f =\n match Mode.apply_f parsed_value ~f with\n | x -> x\n | exception Sexp.Of_sexp_error (exn, sub) -> reraise positions parsed_value exn ~sub\n ;;\n\n let conv x f =\n match conv_exn x f with\n | x -> Ok x\n | exception Of_sexp_error.Of_sexp_error e -> Error e\n ;;\n\n let conv_combine result f : (_, Conv_error.t) result =\n match result with\n | Error e -> Error (Parse_error e)\n | Ok x ->\n (match conv x f with\n | Ok _ as r -> r\n | Error e -> Error (Of_sexp_error e))\n ;;\nend\n","(* Sexp: Module for handling S-expressions (I/O, etc.) *)\n\nopen Format\nopen Bigarray\nmodule Sexplib = Sexplib0\nmodule Conv = Sexplib.Sexp_conv\n\n(* conv.ml depends on us so we can only use this module *)\n\ninclude Type\n\ntype bigstring = (char, int8_unsigned_elt, c_layout) Array1.t\n\ninclude (\n Sexplib.Sexp :\n module type of struct\n include Sexplib.Sexp\n end\n with type t := t)\n\ninclude Private\n\n(* Output of S-expressions to I/O-channels *)\n\nlet with_new_buffer oc f =\n let buf = buffer () in\n f buf;\n Buffer.output_buffer oc buf\n;;\n\nlet output_hum oc sexp = with_new_buffer oc (fun buf -> to_buffer_hum sexp ~buf)\n\nlet output_hum_indent indent oc sexp =\n with_new_buffer oc (fun buf -> to_buffer_hum ~indent sexp ~buf)\n;;\n\nlet output_mach oc sexp = with_new_buffer oc (fun buf -> to_buffer_mach sexp ~buf)\nlet output = output_mach\n\n(* Output of S-expressions to file *)\n\n(* The temp file functions in the OCaml Filename module do not support\n permissions. But opening a file with given permissions is different\n from opening it and chmoding it to these permissions, because the umask\n is taken in account. Under Unix there's no easy way to get the umask in\n a thread-safe way. *)\nmodule Tmp_file = struct\n let prng = ref None\n\n let temp_file_name prefix suffix =\n let rand_state =\n match !prng with\n | Some v -> v\n | None ->\n let ret = Random.State.make_self_init () in\n prng := Some ret;\n ret\n in\n let rnd = Random.State.bits rand_state land 0xFFFFFF in\n Printf.sprintf \"%s%06x%s\" prefix rnd suffix\n ;;\n\n (* Keep the permissions loose. Sexps are usually shared and rarely private*)\n let open_temp_file ?(perm = 0o666) prefix suffix =\n let rec try_name counter =\n let name = temp_file_name prefix suffix in\n try\n let oc =\n open_out_gen [ Open_wronly; Open_creat; Open_excl; Open_text ] perm name\n in\n name, oc\n with\n | Sys_error _ as e -> if counter >= 1000 then raise e else try_name (counter + 1)\n in\n try_name 0\n ;;\nend\n\nlet save_of_output ?perm output_function file sexp =\n let tmp_name, oc = Tmp_file.open_temp_file ?perm file \"tmp\" in\n (try\n output_function oc sexp;\n close_out oc\n with\n | e ->\n close_out_noerr oc;\n (try Sys.remove tmp_name with\n | _ -> ());\n raise e);\n Sys.rename tmp_name file\n;;\n\nlet output_sexp_nl do_output oc sexp =\n do_output oc sexp;\n output_string oc \"\\n\"\n;;\n\nlet save_hum ?perm file sexp = save_of_output ?perm (output_sexp_nl output_hum) file sexp\nlet save_mach ?perm file sexp = save_of_output ?perm output_mach file sexp\nlet save = save_mach\nlet output_sexps_nl do_output oc sexps = List.iter (output_sexp_nl do_output oc) sexps\n\nlet save_sexps_hum ?perm file sexps =\n save_of_output ?perm (output_sexps_nl output_hum) file sexps\n;;\n\nlet save_sexps_mach ?perm file sexps =\n save_of_output ?perm (output_sexps_nl output_mach) file sexps\n;;\n\nlet save_sexps = save_sexps_mach\n\n(* Scan functions *)\n\nlet scan_sexp ?buf lexbuf = Parser.sexp (Lexer.main ?buf) lexbuf\nlet scan_sexp_opt ?buf lexbuf = Parser.sexp_opt (Lexer.main ?buf) lexbuf\nlet scan_sexps ?buf lexbuf = Parser.sexps (Lexer.main ?buf) lexbuf\nlet scan_rev_sexps ?buf lexbuf = Parser.rev_sexps (Lexer.main ?buf) lexbuf\n\nlet get_main_buf buf =\n let buf =\n match buf with\n | None -> Buffer.create 128\n | Some buf -> buf\n in\n Lexer.main ~buf\n;;\n\nlet scan_fold_sexps ?buf ~f ~init lexbuf =\n let main = get_main_buf buf in\n let rec loop acc =\n match Parser.sexp_opt main lexbuf with\n | None -> acc\n | Some sexp -> loop (f acc sexp)\n in\n loop init\n;;\n\nlet scan_iter_sexps ?buf ~f lexbuf =\n scan_fold_sexps ?buf lexbuf ~init:() ~f:(fun () sexp -> f sexp)\n;;\n\nlet scan_sexps_conv ?buf ~f lexbuf =\n let coll acc sexp = f sexp :: acc in\n List.rev (scan_fold_sexps ?buf ~f:coll ~init:[] lexbuf)\n;;\n\nlet sexp_conversion_error_message ?containing_sexp ?location ?invalid_sexp () ~exn : t =\n List\n (List.concat\n [ [ Atom \"Of_sexp_error\" ]\n ; (match location with\n | None -> []\n | Some x -> [ Atom x ])\n ; [ (match exn with\n | Failure x -> Atom x\n | _ -> Conv.sexp_of_exn exn)\n ]\n ; (match invalid_sexp with\n | None -> []\n | Some x -> [ List [ Atom \"invalid_sexp\"; x ] ])\n ; (match containing_sexp with\n | None -> []\n | Some x -> [ List [ Atom \"containing_sexp\"; x ] ])\n ])\n;;\n\n(* Partial parsing *)\n\nmodule Annot = struct\n type pos = Parsexp.Positions.pos =\n { line : int\n ; col : int\n ; offset : int\n }\n\n type range = Parsexp.Positions.range =\n { start_pos : pos\n ; end_pos : pos\n }\n\n type t =\n | Atom of range * Type.t\n | List of range * t list * Type.t\n\n type 'a conv =\n [ `Result of 'a\n | `Error of exn * t\n ]\n\n exception Conv_exn of string * exn\n\n let () =\n Conv.Exn_converter.add ~finalise:false [%extension_constructor Conv_exn] (function\n | Conv_exn (location, exn) -> sexp_conversion_error_message () ~location ~exn\n | _ -> assert false)\n ;;\n\n type stack =\n { mutable positions : pos list\n ; mutable stack : t list list\n }\n\n let get_sexp = function\n | Atom (_, sexp) | List (_, _, sexp) -> sexp\n ;;\n\n let get_range = function\n | Atom (range, _) | List (range, _, _) -> range\n ;;\n\n let sexp_of_conv sexp_of_a = function\n | `Result a -> Type.List [ Atom \"Result\"; a |> sexp_of_a ]\n | `Error (exn, t) ->\n List [ Atom \"Error\"; List [ exn |> Conv.sexp_of_exn; t |> get_sexp ] ]\n ;;\n\n exception Annot_sexp of t\n\n let find_sexp annot_sexp sexp =\n let rec loop annot_sexp =\n match annot_sexp with\n | (Atom (_, sub_sexp) | List (_, _, sub_sexp)) when sexp == sub_sexp ->\n raise (Annot_sexp annot_sexp)\n | List (_, annots, _) -> List.iter loop annots\n | Atom _ -> ()\n in\n try\n loop annot_sexp;\n None\n with\n | Annot_sexp res -> Some res\n ;;\nend\n\nlet () =\n Conv.Exn_converter.add ~finalise:false [%extension_constructor Of_sexp_error] (function\n | Of_sexp_error (Annot.Conv_exn (location, exn), invalid_sexp) ->\n sexp_conversion_error_message () ~location ~invalid_sexp ~exn\n | Of_sexp_error (exn, invalid_sexp) ->\n sexp_conversion_error_message () ~invalid_sexp ~exn\n | _ ->\n (* Reaching this branch indicates a bug in sexplib. *)\n assert false)\n;;\n\nmodule Parse_pos = struct\n type t =\n { mutable text_line : int\n ; mutable text_char : int\n ; mutable global_offset : int\n ; mutable buf_pos : int\n }\n\n let create ?(text_line = 1) ?(text_char = 0) ?(buf_pos = 0) ?(global_offset = 0) () =\n let fail msg = failwith (\"Sexplib.Sexp.Parse_pos.create: \" ^ msg) in\n if text_line < 1\n then fail \"text_line < 1\"\n else if text_char < 0\n then fail \"text_char < 0\"\n else if global_offset < 0\n then fail \"global_offset < 0\"\n else if buf_pos < 0\n then fail \"buf_pos < 0\"\n else { text_line; text_char; global_offset; buf_pos }\n ;;\n\n let with_buf_pos t buf_pos = { t with buf_pos }\nend\n\nmodule Cont_state = Parsexp.Old_parser_cont_state\n\ntype ('a, 't) parse_result =\n | Done of 't * Parse_pos.t\n | Cont of Cont_state.t * ('a, 't) parse_fun\n\nand ('a, 't) parse_fun = pos:int -> len:int -> 'a -> ('a, 't) parse_result\n\ntype 't parse_state = { parse_pos : Parse_pos.t }\n\ntype parse_error =\n { err_msg : string\n ; parse_state : [ `Sexp of t list list parse_state | `Annot of Annot.stack parse_state ]\n }\n\nexception Parse_error of parse_error\n\nlet () =\n Conv.Exn_converter.add ~finalise:false [%extension_constructor Parse_error] (function\n | Parse_error pe ->\n let ppos =\n match pe.parse_state with\n | `Sexp { parse_pos } | `Annot { parse_pos } -> parse_pos\n in\n List\n [ Atom \"Sexplib.Sexp.Parse_error\"\n ; List\n [ List [ Atom \"err_msg\"; Atom pe.err_msg ]\n ; List [ Atom \"text_line\"; Conv.sexp_of_int ppos.Parse_pos.text_line ]\n ; List [ Atom \"text_char\"; Conv.sexp_of_int ppos.Parse_pos.text_char ]\n ; List\n [ Atom \"global_offset\"; Conv.sexp_of_int ppos.Parse_pos.global_offset ]\n ; List [ Atom \"buf_pos\"; Conv.sexp_of_int ppos.Parse_pos.buf_pos ]\n ]\n ]\n | _ -> assert false)\n;;\n\nmodule Parser_output : sig\n module type T = sig\n module Impl : Parsexp.Eager_parser\n\n type output\n\n exception Found of output\n\n val raise_found : Impl.State.Read_only.t -> Impl.parsed_value -> unit\n end\n\n module Bare_sexp : T with type output = Type.t\n module Annotated_sexp : T with type output = Annot.t\nend = struct\n module type T = sig\n module Impl : Parsexp.Eager_parser\n\n type output\n\n exception Found of output\n\n val raise_found : Impl.State.Read_only.t -> Impl.parsed_value -> unit\n end\n\n module I = Parsexp.Positions.Iterator\n\n let rec annotate_sexp sexp iter =\n match sexp with\n | Type.Atom _ ->\n let start_pos = I.advance_exn iter ~skip:0 in\n let end_pos = I.advance_exn iter ~skip:0 in\n Annot.Atom ({ start_pos; end_pos }, sexp)\n | Type.List l ->\n let start_pos = I.advance_exn iter ~skip:0 in\n let annot = annotate_sexp_list l iter in\n let end_pos = I.advance_exn iter ~skip:0 in\n Annot.List ({ start_pos; end_pos }, annot, sexp)\n\n and annotate_sexp_list sexps iter =\n List.rev (List.rev_map (fun sexp -> annotate_sexp sexp iter) sexps)\n ;;\n\n module Bare_sexp = struct\n module Impl = Parsexp.Eager\n\n type output = Type.t\n\n exception Found of output\n\n let raise_found _state sexp = raise_notrace (Found sexp)\n end\n\n module Annotated_sexp = struct\n module Impl = Parsexp.Eager_and_positions\n\n type output = Annot.t\n\n exception Found of output\n\n let raise_found _state (sexp, positions) =\n let annot = annotate_sexp sexp (I.create positions) in\n raise_notrace (Found annot)\n ;;\n end\nend\n\nmodule Make_parser (T : sig\n include Parser_output.T\n\n type input\n\n val length : input -> int\n\n val unsafe_feed_loop\n : Impl.State.t\n -> Impl.Stack.t\n -> input\n -> max_pos:int\n -> pos:int\n -> Impl.Stack.t\n end) : sig\n val parse\n : ?parse_pos:Parse_pos.t\n -> ?len:int\n -> T.input\n -> (T.input, T.output) parse_result\nend = struct\n let parse_pos_of_state state buf_pos =\n { Parse_pos.text_line = T.Impl.State.line state\n ; Parse_pos.text_char = T.Impl.State.column state\n ; Parse_pos.global_offset = T.Impl.State.offset state\n ; Parse_pos.buf_pos\n }\n ;;\n\n let check_str_bounds ~pos ~len str =\n if pos < 0 then invalid_arg \"parse: pos < 0\";\n if len < 0 then invalid_arg \"parse: len < 0\";\n let str_len = T.length str in\n let pos_len = pos + len in\n if pos_len > str_len then invalid_arg \"parse: pos + len > str_len\";\n pos_len - 1\n ;;\n\n let raise_parse_error state pos msg =\n let parse_state = { parse_pos = parse_pos_of_state state pos } in\n let parse_error = { err_msg = msg; parse_state = `Sexp parse_state } in\n raise (Parse_error parse_error)\n ;;\n\n let handle_parsexp_error state pos e =\n let msg = Parsexp.Parse_error.message e in\n match Parsexp.Parse_error.Private.old_parser_exn e with\n | `Parse_error -> raise_parse_error state pos msg\n | `Failure -> failwith msg\n ;;\n\n let rec run_feed_loop state stack ~pos ~len str =\n let max_pos = check_str_bounds ~pos ~len str in\n let previous_offset = T.Impl.State.offset state in\n match T.unsafe_feed_loop state stack str ~max_pos ~pos with\n | stack -> mk_cont_state state stack\n | exception T.Found result ->\n let offset = T.Impl.State.offset state in\n let next_pos = pos + (offset - previous_offset) in\n Done (result, parse_pos_of_state state next_pos)\n | exception Parsexp.Parse_error.Parse_error err ->\n handle_parsexp_error\n state\n (pos + (T.Impl.State.offset state - previous_offset))\n err\n\n and mk_cont_state state stack =\n let parse_fun =\n let used_ref = ref false in\n fun ~pos ~len str ->\n if !used_ref\n then failwith \"Sexplib.Sexp: parser continuation called twice\"\n else (\n used_ref := true;\n run_feed_loop state stack ~pos ~len str)\n in\n let cont_state = T.Impl.State.old_parser_cont_state state in\n Cont (cont_state, parse_fun)\n ;;\n\n let parse ?(parse_pos = Parse_pos.create ()) ?len str =\n let pos, buf_pos =\n let { Parse_pos.text_line; text_char; global_offset; buf_pos } = parse_pos in\n ( { Parsexp.Positions.line = text_line; col = text_char; offset = global_offset }\n , buf_pos )\n in\n let state = T.Impl.State.create ~pos ~no_sexp_is_error:false T.raise_found in\n let stack = T.Impl.Stack.empty in\n let len =\n match len with\n | Some x -> x\n | None -> T.length str - buf_pos\n in\n run_feed_loop state stack str ~pos:buf_pos ~len\n ;;\nend\n[@@inline always]\n\nmodule String_single_sexp = Make_parser (struct\n include Parser_output.Bare_sexp\n\n type input = string\n\n let length = String.length\n\n let rec unsafe_feed_loop state stack str ~max_pos ~pos =\n if pos <= max_pos\n then (\n let stack = Impl.feed state (String.unsafe_get str pos) stack in\n unsafe_feed_loop state stack str ~max_pos ~pos:(pos + 1))\n else stack\n ;;\n end)\n\nlet parse_str = String_single_sexp.parse\nlet parse = String_single_sexp.parse\n\nmodule String_single_annot = Make_parser (struct\n include Parser_output.Annotated_sexp\n\n type input = string\n\n let length = String.length\n\n let rec unsafe_feed_loop state stack str ~max_pos ~pos =\n if pos <= max_pos\n then (\n let stack = Impl.feed state (String.unsafe_get str pos) stack in\n unsafe_feed_loop state stack str ~max_pos ~pos:(pos + 1))\n else stack\n ;;\n end)\n\nlet parse_str_annot = String_single_annot.parse\n\nmodule Bigstring_single_sexp = Make_parser (struct\n include Parser_output.Bare_sexp\n\n type input = bigstring\n\n let length = Array1.dim\n\n let rec unsafe_feed_loop state stack (str : input) ~max_pos ~pos =\n if pos <= max_pos\n then (\n let stack = Impl.feed state (Array1.unsafe_get str pos) stack in\n unsafe_feed_loop state stack str ~max_pos ~pos:(pos + 1))\n else stack\n ;;\n end)\n\nlet parse_bigstring = Bigstring_single_sexp.parse\n\nmodule Bigstring_single_annot = Make_parser (struct\n include Parser_output.Annotated_sexp\n\n type input = bigstring\n\n let length = Array1.dim\n\n let rec unsafe_feed_loop state stack (str : input) ~max_pos ~pos =\n if pos <= max_pos\n then (\n let stack = Impl.feed state (Array1.unsafe_get str pos) stack in\n unsafe_feed_loop state stack str ~max_pos ~pos:(pos + 1))\n else stack\n ;;\n end)\n\nlet parse_bigstring_annot = Bigstring_single_annot.parse\n\n(* Input functions *)\n\nlet mk_this_parse ?parse_pos my_parse =\n ();\n fun ~pos ~len str ->\n let parse_pos =\n match parse_pos with\n | None -> Parse_pos.create ~buf_pos:pos ()\n | Some parse_pos ->\n parse_pos.Parse_pos.buf_pos <- pos;\n parse_pos\n in\n my_parse ?parse_pos:(Some parse_pos) ?len:(Some len) str\n;;\n\n(* [ws_buf] must contain a single space character *)\nlet feed_end_of_input ~this_parse ~ws_buf =\n (* When parsing atoms, the incremental parser cannot tell whether\n it is at the end until it hits whitespace. We therefore feed it\n one space to determine whether it is finished. *)\n match this_parse ~pos:0 ~len:1 ws_buf with\n | Done (sexp, _) -> Ok sexp\n | Cont (cont_state, _) -> Error cont_state\n;;\n\nlet gen_input_sexp my_parse ?parse_pos ic =\n let buf = Bytes.create 1 in\n let rec loop this_parse =\n match input_char ic with\n | exception End_of_file ->\n (match feed_end_of_input ~this_parse ~ws_buf:\" \" with\n | Ok sexp -> sexp\n | Error _ -> raise End_of_file)\n | c ->\n Bytes.set buf 0 c;\n (match this_parse ~pos:0 ~len:1 (Bytes.unsafe_to_string buf) with\n | Done (sexp, _) -> sexp\n | Cont (_, this_parse) -> loop this_parse)\n in\n loop (mk_this_parse ?parse_pos my_parse)\n;;\n\nlet input_sexp ?parse_pos ic = gen_input_sexp parse ?parse_pos ic\n\nlet gen_input_rev_sexps my_parse ~ws_buf ?parse_pos ?(buf = Bytes.create 8192) ic =\n let rev_sexps_ref = ref [] in\n let buf_len = Bytes.length buf in\n let rec loop this_parse ~pos ~len =\n if len > 0\n then (\n match this_parse ~pos ~len (Bytes.unsafe_to_string buf) with\n | Done (sexp, ({ Parse_pos.buf_pos; _ } as parse_pos)) ->\n rev_sexps_ref := sexp :: !rev_sexps_ref;\n let n_parsed = buf_pos - pos in\n let this_parse = mk_this_parse ~parse_pos my_parse in\n if n_parsed = len\n then (\n let new_len = input ic buf 0 buf_len in\n loop this_parse ~pos:0 ~len:new_len)\n else loop this_parse ~pos:buf_pos ~len:(len - n_parsed)\n | Cont (_, this_parse) -> loop this_parse ~pos:0 ~len:(input ic buf 0 buf_len))\n else (\n match feed_end_of_input ~this_parse ~ws_buf with\n | Ok sexp -> sexp :: !rev_sexps_ref\n | Error Parsing_toplevel_whitespace -> !rev_sexps_ref\n | Error cont_state ->\n failwith\n (\"Sexplib.Sexp.input_rev_sexps: reached EOF while in state \"\n ^ Cont_state.to_string cont_state))\n in\n let len = input ic buf 0 buf_len in\n let this_parse = mk_this_parse ?parse_pos my_parse in\n loop this_parse ~pos:0 ~len\n;;\n\nlet input_rev_sexps ?parse_pos ?buf ic =\n gen_input_rev_sexps parse ~ws_buf:\" \" ?parse_pos ?buf ic\n;;\n\nlet input_sexps ?parse_pos ?buf ic = List.rev (input_rev_sexps ?parse_pos ?buf ic)\n\n(* of_string and of_bigstring *)\n\nlet of_string_bigstring loc my_parse ws_buf get_len get_sub str =\n match my_parse ?parse_pos:None ?len:None str with\n | Done (sexp, parse_pos) ->\n (match my_parse ?parse_pos:(Some parse_pos) ?len:None str with\n | Done (_sexp2, _) ->\n failwith\n (sprintf\n \"Sexplib.Sexp.%s: got multiple S-expressions where only one was expected.\"\n loc)\n | Cont (Cont_state.Parsing_toplevel_whitespace, _) -> sexp\n | Cont (_, _) ->\n (* not using [feed_end_of_input] here means \"a b\" will end up here and not in\n \"multiple S-expressions\" branch, but it doesn't matter that much *)\n failwith\n (sprintf\n \"Sexplib.Sexp.%s: S-expression followed by data at position %d...\"\n loc\n parse_pos.buf_pos))\n | Cont (_, this_parse) ->\n (match feed_end_of_input ~this_parse ~ws_buf with\n | Ok sexp -> sexp\n | Error cont_state ->\n let cont_state_str = Cont_state.to_string cont_state in\n failwith\n (sprintf\n \"Sexplib.Sexp.%s: incomplete S-expression while in state %s: %s\"\n loc\n cont_state_str\n (get_sub str 0 (get_len str))))\n;;\n\nlet of_string str =\n of_string_bigstring \"of_string\" parse \" \" String.length String.sub str\n;;\n\nlet get_bstr_sub_str bstr pos len =\n let str = Bytes.create len in\n for i = 0 to len - 1 do\n Bytes.set str i bstr.{pos + i}\n done;\n Bytes.unsafe_to_string str\n;;\n\nlet bstr_ws_buf = Array1.create char c_layout 1\nlet () = bstr_ws_buf.{0} <- ' '\n\nlet of_bigstring bstr =\n of_string_bigstring\n \"of_bigstring\"\n parse_bigstring\n bstr_ws_buf\n Array1.dim\n get_bstr_sub_str\n bstr\n;;\n\n(* Loading *)\n\nlet gen_load_rev_sexps input_rev_sexps ?buf file =\n let ic = open_in file in\n try\n let sexps = input_rev_sexps ?parse_pos:None ?buf ic in\n close_in ic;\n sexps\n with\n | exc ->\n close_in_noerr ic;\n raise exc\n;;\n\nlet load_rev_sexps ?buf file = gen_load_rev_sexps input_rev_sexps ?buf file\nlet load_sexps ?buf file = List.rev (load_rev_sexps ?buf file)\nlet gen_load_sexp_loc = \"Sexplib.Sexp.gen_load_sexp\"\n\nlet gen_load_sexp my_parse ?(strict = true) ?(buf = Bytes.create 8192) file =\n let buf_len = Bytes.length buf in\n let ic = open_in file in\n let rec loop this_parse =\n let len = input ic buf 0 buf_len in\n if len = 0\n then (\n match feed_end_of_input ~this_parse ~ws_buf:\" \" with\n | Ok sexp -> sexp\n | Error cont_state ->\n failwith\n (sprintf\n \"%s: EOF in %s while in state %s\"\n gen_load_sexp_loc\n file\n (Cont_state.to_string cont_state)))\n else (\n match this_parse ~pos:0 ~len (Bytes.unsafe_to_string buf) with\n | Done (sexp, ({ Parse_pos.buf_pos; _ } as parse_pos)) when strict ->\n let rec strict_loop this_parse ~pos ~len =\n match this_parse ~pos ~len (Bytes.unsafe_to_string buf) with\n | Done _ ->\n failwith\n (sprintf \"%s: more than one S-expression in file %s\" gen_load_sexp_loc file)\n | Cont (cont_state, this_parse) ->\n let len = input ic buf 0 buf_len in\n if len > 0\n then strict_loop this_parse ~pos:0 ~len\n else if cont_state = Cont_state.Parsing_toplevel_whitespace\n then sexp\n else\n failwith\n (sprintf\n \"%s: %s in state %s loading file %s\"\n gen_load_sexp_loc\n \"additional incomplete data\"\n (Cont_state.to_string cont_state)\n file)\n in\n let this_parse = mk_this_parse ~parse_pos my_parse in\n strict_loop this_parse ~pos:buf_pos ~len:(len - buf_pos)\n | Done (sexp, _) -> sexp\n | Cont (_, this_parse) -> loop this_parse)\n in\n try\n let sexp = loop (mk_this_parse my_parse) in\n close_in ic;\n sexp\n with\n | exc ->\n close_in_noerr ic;\n raise exc\n;;\n\nlet load_sexp ?strict ?buf file = gen_load_sexp parse ?strict ?buf file\n\nmodule Annotated = struct\n include Annot\n\n let parse = parse_str_annot\n let parse_bigstring = parse_bigstring_annot\n\n let input_rev_sexps ?parse_pos ?buf ic =\n gen_input_rev_sexps parse ~ws_buf:\" \" ?parse_pos ?buf ic\n ;;\n\n let input_sexp ?parse_pos ic = gen_input_sexp parse ?parse_pos ic\n let input_sexps ?parse_pos ?buf ic = List.rev (input_rev_sexps ?parse_pos ?buf ic)\n\n let of_string str =\n of_string_bigstring \"Annotated.of_string\" parse \" \" String.length String.sub str\n ;;\n\n let of_bigstring bstr =\n of_string_bigstring\n \"Annotated.of_bigstring\"\n parse_bigstring\n bstr_ws_buf\n Array1.dim\n get_bstr_sub_str\n bstr\n ;;\n\n let load_rev_sexps ?buf file = gen_load_rev_sexps input_rev_sexps ?buf file\n let load_sexps ?buf file = List.rev (load_rev_sexps ?buf file)\n let load_sexp ?strict ?buf file = gen_load_sexp parse ?strict ?buf file\n\n let conv f annot_sexp =\n let sexp = get_sexp annot_sexp in\n try `Result (f sexp) with\n | Of_sexp_error (exc, bad_sexp) as e ->\n (match find_sexp annot_sexp bad_sexp with\n | None -> raise e\n | Some bad_annot_sexp -> `Error (exc, bad_annot_sexp))\n ;;\n\n let get_conv_exn ~file ~exc annot_sexp =\n let range = get_range annot_sexp in\n let { start_pos = { line; col; offset = _ }; end_pos = _ } = range in\n let loc = sprintf \"%s:%d:%d\" file line col in\n Of_sexp_error (Annot.Conv_exn (loc, exc), get_sexp annot_sexp)\n ;;\nend\n\nlet load_sexp_conv ?(strict = true) ?(buf = Bytes.create 8192) file f =\n let sexp = load_sexp ~strict ~buf file in\n try `Result (f sexp) with\n | Of_sexp_error _ -> Annotated.conv f (Annotated.load_sexp ~strict ~buf file)\n;;\n\nlet raise_conv_exn ~file = function\n | `Result res -> res\n | `Error (exc, annot_sexp) -> raise (Annotated.get_conv_exn ~file ~exc annot_sexp)\n;;\n\nlet load_sexp_conv_exn ?strict ?buf file f =\n raise_conv_exn ~file (load_sexp_conv ?strict ?buf file f)\n;;\n\nlet load_sexps_conv ?(buf = Bytes.create 8192) file f =\n let rev_sexps = load_rev_sexps ~buf file in\n try List.rev_map (fun sexp -> `Result (f sexp)) rev_sexps with\n | Of_sexp_error _ as e ->\n (match Annotated.load_rev_sexps ~buf file with\n | [] ->\n (* File is now empty - perhaps it was a temporary file handle? *)\n raise e\n | rev_annot_sexps ->\n List.rev_map (fun annot_sexp -> Annotated.conv f annot_sexp) rev_annot_sexps)\n;;\n\nlet load_sexps_conv_exn ?(buf = Bytes.create 8192) file f =\n let rev_sexps = load_rev_sexps ~buf file in\n try List.rev_map f rev_sexps with\n | Of_sexp_error _ as e ->\n (match Annotated.load_rev_sexps ~buf file with\n | [] ->\n (* File is now empty - perhaps it was a temporary file handle? *)\n raise e\n | rev_annot_sexps ->\n List.rev_map\n (fun annot_sexp -> raise_conv_exn ~file (Annotated.conv f annot_sexp))\n rev_annot_sexps)\n;;\n\nlet gen_of_string_conv of_string annot_of_string str f =\n let sexp = of_string str in\n try `Result (f sexp) with\n | Of_sexp_error _ -> Annotated.conv f (annot_of_string str)\n;;\n\nlet of_string_conv str f = gen_of_string_conv of_string Annotated.of_string str f\n\nlet of_bigstring_conv bstr f =\n gen_of_string_conv of_bigstring Annotated.of_bigstring bstr f\n;;\n\nmodule Of_string_conv_exn = struct\n type t =\n { exc : exn\n ; sexp : Type.t\n ; sub_sexp : Type.t\n }\n\n exception E of t\n\n let () =\n Conv.Exn_converter.add ~finalise:false [%extension_constructor E] (function\n | E osce ->\n sexp_conversion_error_message\n ()\n ~invalid_sexp:osce.sub_sexp\n ~exn:osce.exc\n ~containing_sexp:osce.sexp\n | _ -> assert false)\n ;;\nend\n\nlet gen_of_string_conv_exn of_string str f =\n let sexp = of_string str in\n try f sexp with\n | Of_sexp_error (exc, sub_sexp) ->\n raise (Of_string_conv_exn.E { Of_string_conv_exn.exc; sexp; sub_sexp })\n;;\n\nlet of_string_conv_exn str f = gen_of_string_conv_exn of_string str f\nlet of_bigstring_conv_exn bstr f = gen_of_string_conv_exn of_bigstring bstr f\n\n(* Utilities for automated type conversions *)\n\nlet unit = List []\n\nlet is_unit = function\n | List [] -> true\n | _ -> false\n;;\n\nexternal sexp_of_t : t -> t = \"%identity\"\nexternal t_of_sexp : t -> t = \"%identity\"\n\n(* Utilities for conversion error handling *)\n\ntype found =\n [ `Found\n | `Pos of int * found\n ]\n\ntype search_result =\n [ `Not_found\n | found\n ]\n\nlet rec search_physical sexp ~contained =\n if sexp == contained\n then `Found\n else (\n match sexp with\n | Atom _ -> `Not_found\n | List lst ->\n let rec loop i = function\n | [] -> `Not_found\n | h :: t ->\n let res = search_physical h ~contained in\n (match res with\n | `Not_found -> loop (i + 1) t\n | #found as found -> `Pos (i, found))\n in\n loop 0 lst)\n;;\n\nlet rec subst_found sexp ~subst = function\n | `Found -> subst\n | `Pos (pos, found) ->\n (match sexp with\n | Atom _ -> failwith \"Sexplib.Sexp.subst_found: atom when position requested\"\n | List lst ->\n let rec loop acc pos = function\n | [] -> failwith \"Sexplib.Sexp.subst_found: short list when position requested\"\n | h :: t when pos <> 0 -> loop (h :: acc) (pos - 1) t\n | h :: t -> List (List.rev_append acc (subst_found h ~subst found :: t))\n in\n loop [] pos lst)\n;;\n","open! Import\n\ntype t =\n | Parsing_toplevel_whitespace\n | Parsing_nested_whitespace\n | Parsing_atom\n | Parsing_list\n | Parsing_sexp_comment\n | Parsing_block_comment\n[@@deriving_inline sexp_of]\n\nlet sexp_of_t =\n (function\n | Parsing_toplevel_whitespace ->\n Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_toplevel_whitespace\"\n | Parsing_nested_whitespace -> Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_nested_whitespace\"\n | Parsing_atom -> Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_atom\"\n | Parsing_list -> Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_list\"\n | Parsing_sexp_comment -> Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_sexp_comment\"\n | Parsing_block_comment -> Ppx_sexp_conv_lib.Sexp.Atom \"Parsing_block_comment\"\n : t -> Ppx_sexp_conv_lib.Sexp.t)\n;;\n\n[@@@end]\n\nlet to_string t =\n match sexp_of_t t with\n | Atom s -> s\n | List _ -> failwith \"BUG: [sexp_of_t] returned a [List _]\"\n;;\n","open Printf\nopen Bigarray\ninclude Sexplib0.Sexp_conv\nopen Sexp\n\ntype bigstring = (char, int8_unsigned_elt, c_layout) Array1.t\ntype float32_vec = (float, float32_elt, fortran_layout) Array1.t\ntype float64_vec = (float, float64_elt, fortran_layout) Array1.t\ntype vec = float64_vec\ntype float32_mat = (float, float32_elt, fortran_layout) Array2.t\ntype float64_mat = (float, float64_elt, fortran_layout) Array2.t\ntype mat = float64_mat\n\nlet sexp_of_float_vec vec =\n let lst_ref = ref [] in\n for i = Array1.dim vec downto 1 do\n lst_ref := sexp_of_float vec.{i} :: !lst_ref\n done;\n List !lst_ref\n;;\n\nlet sexp_of_bigstring (bstr : bigstring) =\n let n = Array1.dim bstr in\n let str = Bytes.create n in\n for i = 0 to n - 1 do\n Bytes.set str i bstr.{i}\n done;\n Atom (Bytes.unsafe_to_string str)\n;;\n\nlet sexp_of_float32_vec (vec : float32_vec) = sexp_of_float_vec vec\nlet sexp_of_float64_vec (vec : float64_vec) = sexp_of_float_vec vec\nlet sexp_of_vec (vec : vec) = sexp_of_float_vec vec\n\nlet sexp_of_float_mat mat =\n let m = Array2.dim1 mat in\n let n = Array2.dim2 mat in\n let lst_ref = ref [] in\n (* It's surprising that we serialize [Fortran_layout] matrices in row-major order. I can\n only speculate that it was chosen for readability. The cache performance is\n irrelevant because people who care won't serialize to sexp. *)\n for row = n downto 1 do\n for col = m downto 1 do\n lst_ref := sexp_of_float mat.{col, row} :: !lst_ref\n done\n done;\n List (sexp_of_int m :: sexp_of_int n :: !lst_ref)\n;;\n\nlet sexp_of_float32_mat (mat : float32_mat) = sexp_of_float_mat mat\nlet sexp_of_float64_mat (mat : float64_mat) = sexp_of_float_mat mat\nlet sexp_of_mat (mat : mat) = sexp_of_float_mat mat\nlet bigstring_sexp_grammar : Sexplib0.Sexp.Private.Raw_grammar.t = Inline (Atom String)\n\nlet bigstring_of_sexp sexp =\n match sexp with\n | Atom str ->\n let len = String.length str in\n let bstr = Array1.create char c_layout len in\n for i = 0 to len - 1 do\n bstr.{i} <- str.[i]\n done;\n bstr\n | List _ -> of_sexp_error \"bigstring_of_sexp: atom needed\" sexp\n;;\n\nlet float_vec_of_sexp empty_float_vec create_float_vec sexp =\n match sexp with\n | List [] -> empty_float_vec\n | List lst ->\n let len = List.length lst in\n let res = create_float_vec len in\n let rec loop i = function\n | [] -> res\n | h :: t ->\n res.{i} <- float_of_sexp h;\n loop (i + 1) t\n in\n loop 1 lst\n | Atom _ -> of_sexp_error \"float_vec_of_sexp: list needed\" sexp\n;;\n\nlet create_float32_vec = Array1.create float32 fortran_layout\nlet create_float64_vec = Array1.create float64 fortran_layout\nlet empty_float32_vec = create_float32_vec 0\nlet empty_float64_vec = create_float64_vec 0\nlet float32_vec_of_sexp = float_vec_of_sexp empty_float32_vec create_float32_vec\nlet float64_vec_of_sexp = float_vec_of_sexp empty_float64_vec create_float64_vec\nlet vec_of_sexp = float_vec_of_sexp empty_float64_vec create_float64_vec\n\nlet vec_sexp_grammar : Sexplib0.Sexp.Private.Raw_grammar.t =\n Inline (List [ Many (Atom Float) ])\n;;\n\nlet float32_vec_sexp_grammar = vec_sexp_grammar\nlet float64_vec_sexp_grammar = vec_sexp_grammar\n\nlet check_too_much_data sexp data res =\n if data = [] then res else of_sexp_error \"float_mat_of_sexp: too much data\" sexp\n;;\n\nlet float_mat_of_sexp create_float_mat sexp =\n match sexp with\n | List (sm :: sn :: data) ->\n let m = int_of_sexp sm in\n let n = int_of_sexp sn in\n let res = create_float_mat m n in\n if m = 0 || n = 0\n then check_too_much_data sexp data res\n else (\n let rec loop_cols col data =\n let vec = Array2.slice_right res col in\n let rec loop_rows row = function\n | [] -> of_sexp_error \"float_mat_of_sexp: not enough data\" sexp\n | h :: t ->\n vec.{row} <- float_of_sexp h;\n if row = m\n then\n if col = n then check_too_much_data sexp t res else loop_cols (col + 1) t\n else loop_rows (row + 1) t\n in\n loop_rows 1 data\n in\n loop_cols 1 data)\n | List _ -> of_sexp_error \"float_mat_of_sexp: list too short\" sexp\n | Atom _ -> of_sexp_error \"float_mat_of_sexp: list needed\" sexp\n;;\n\nlet create_float32_mat = Array2.create float32 fortran_layout\nlet create_float64_mat = Array2.create float64 fortran_layout\nlet float32_mat_of_sexp = float_mat_of_sexp create_float32_mat\nlet float64_mat_of_sexp = float_mat_of_sexp create_float64_mat\nlet mat_of_sexp = float_mat_of_sexp create_float64_mat\n\nlet mat_sexp_grammar : Sexplib0.Sexp.Private.Raw_grammar.t =\n Inline (List [ One (Atom Int); One (Atom Int); Many (Atom Float) ])\n;;\n\nlet float32_mat_sexp_grammar = mat_sexp_grammar\nlet float64_mat_sexp_grammar = mat_sexp_grammar\nlet string_of__of__sexp_of to_sexp x = Sexp.to_string (to_sexp x)\n\nlet of_string__of__of_sexp of_sexp s =\n try\n let sexp = Sexp.of_string s in\n of_sexp sexp\n with\n | e ->\n failwith\n (sprintf \"of_string failed on %s with %s\" s (Sexp.to_string_hum (sexp_of_exn e)))\n;;\n","\n(* We do not [include Base] here, and instead import modules that [Core_kernel] doesn't\n extend, because we want code in [Core_kernel] to be clear when it references a [Base]\n module that [Core_kernel] is overriding. *)\nmodule Applicative = Base.Applicative\nmodule Avltree = Base.Avltree\nmodule Backtrace = Base.Backtrace\nmodule Binary_search = Base.Binary_search\nmodule Comparisons = Base.Comparisons\nmodule Continue_or_stop = Base.Continue_or_stop\nmodule Equal = Base.Equal\nmodule Exn = Base.Exn\nmodule Floatable = Base.Floatable\nmodule Formatter = Base.Formatter\nmodule Hash = Base.Hash\nmodule Hasher = Base.Hasher\nmodule Indexed_container = Base.Indexed_container\nmodule Intable = Base.Intable\nmodule Int_conversions = Base.Int_conversions\nmodule Int_math = Base.Int_math\nmodule Invariant = Base.Invariant\nmodule Monad = Base.Monad\nmodule Poly = Base.Poly\n\nmodule Popcount = Base.Popcount\n[@@warning \"-3\"]\n[@@deprecated \"[since 2018-10] use [popcount] functions in individual int modules\"]\n\nmodule Pretty_printer = Base.Pretty_printer\nmodule Random = Base.Random\nmodule Staged = Base.Staged\nmodule Stringable = Base.Stringable\nmodule Uchar = Base.Uchar\nmodule Validate = Base.Validate\nmodule With_return = Base.With_return\nmodule Word_size = Base.Word_size\n\n(* We do include [Base]'s top-level value and type bindings, because they don't cause\n any confusion, and duplicating them would be error prone. *)\ninclude Base.Export\ninclude Stdio\ninclude Base_for_tests\ninclude Bin_prot.Std\nmodule Field = Fieldslib.Field\n\nmodule From_sexplib : sig\n type bigstring = Sexplib.Conv.bigstring [@@deriving sexp]\n type mat = Sexplib.Conv.mat [@@deriving sexp]\n type vec = Sexplib.Conv.vec [@@deriving sexp]\n\n (* [sexp_of_opaque] and [opaque_of_sexp] are used by the code generated from\n [[@@deriving sexp]], [[%sexp_of: ]], and [[%of_sexp: ]]. The type [_ sexp_opaque]\n expands to uses of [sexp_of_opaque] and [opaque_of_sexp]. *)\n\n val sexp_of_opaque : _ -> Base.Sexp.t\n val opaque_of_sexp : Base.Sexp.t -> _\n val sexp_of_pair : ('a -> Base.Sexp.t) -> ('b -> Base.Sexp.t) -> 'a * 'b -> Base.Sexp.t\n val pair_of_sexp : (Base.Sexp.t -> 'a) -> (Base.Sexp.t -> 'b) -> Base.Sexp.t -> 'a * 'b\n\n exception Of_sexp_error of exn * Base.Sexp.t\n\n val of_sexp_error : string -> Base.Sexp.t -> _\n val of_sexp_error_exn : exn -> Base.Sexp.t -> _\nend =\n Sexplib.Conv\n\ninclude From_sexplib\n\n(* [sexp_opaque] indicates to [ppx_sexp_conv] that a value should be rendered as [_], i.e.\n [Sexp.Atom \"_\"]. Here we expose the [@@deriving] aspects of [sexp_opaque] so that\n other ppx's treat [sexp_opaque] correctly, by ignoring it and processing the underlying\n type. *)\ninclude (\nstruct\n type 'a sexp_opaque = 'a [@@deriving bin_io, compare, hash, typerep]\nend :\nsig\n type 'a sexp_opaque [@@deriving bin_io, compare, hash, typerep]\nend\nwith type 'a sexp_opaque := 'a)\n\ninclude (\n Typerep_lib.Std :\n module type of struct\n include Typerep_lib.Std\n end\n with module Type_equal := Typerep_lib.Std.Type_equal)\n\nmodule Variant = Variantslib.Variant\n\nlet with_return = With_return.with_return\nlet am_running_inline_test = Ppx_inline_test_lib.Runtime.am_running_inline_test\n\nlet am_running_test =\n try\n ignore (Caml.Sys.getenv \"TESTING_FRAMEWORK\" : string);\n true\n with\n (* [Caml.*] never raises [Not_found_s] *)\n | Caml.Not_found -> false\n;;\n\ntype 'a identity = 'a\n\nmodule Not_found = struct\n exception\n Not_found = Not_found\n [@deprecated\n {|[since 2018-02] Instead of raising [Not_found], consider using [raise_s] with an\ninformative error message. If code needs to distinguish [Not_found] from other\nexceptions, please change it to handle both [Not_found] and [Not_found_s]. Then, instead\nof raising [Not_found], raise [Not_found_s] with an informative error message.|}]\n\n exception Not_found_s = Base.Not_found_s\nend\n\ninclude Not_found\n","open! Import\ninclude Base.Sexpable\n\nmodule Stable = struct\n module Of_sexpable = struct\n module V1\n (Sexpable : S) (M : sig\n type t\n\n val to_sexpable : t -> Sexpable.t\n val of_sexpable : Sexpable.t -> t\n end) : S with type t := M.t = struct\n let t_of_sexp sexp =\n let s = Sexpable.t_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t t = Sexpable.sexp_of_t (M.to_sexpable t)\n end\n end\n\n module Of_sexpable1 = struct\n module V1\n (Sexpable : S1) (M : sig\n type 'a t\n\n val to_sexpable : 'a t -> 'a Sexpable.t\n val of_sexpable : 'a Sexpable.t -> 'a t\n end) : S1 with type 'a t := 'a M.t = struct\n let t_of_sexp a_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a t = Sexpable.sexp_of_t sexp_of_a (M.to_sexpable t)\n end\n end\n\n module Of_sexpable2 = struct\n module V1\n (Sexpable : S2) (M : sig\n type ('a, 'b) t\n\n val to_sexpable : ('a, 'b) t -> ('a, 'b) Sexpable.t\n val of_sexpable : ('a, 'b) Sexpable.t -> ('a, 'b) t\n end) : S2 with type ('a, 'b) t := ('a, 'b) M.t = struct\n let t_of_sexp a_of_sexp b_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp b_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a sexp_of_b t =\n Sexpable.sexp_of_t sexp_of_a sexp_of_b (M.to_sexpable t)\n ;;\n end\n end\n\n module Of_sexpable3 = struct\n module V1\n (Sexpable : S3) (M : sig\n type ('a, 'b, 'c) t\n\n val to_sexpable : ('a, 'b, 'c) t -> ('a, 'b, 'c) Sexpable.t\n val of_sexpable : ('a, 'b, 'c) Sexpable.t -> ('a, 'b, 'c) t\n end) : S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t = struct\n let t_of_sexp a_of_sexp b_of_sexp c_of_sexp sexp =\n let s = Sexpable.t_of_sexp a_of_sexp b_of_sexp c_of_sexp sexp in\n try M.of_sexpable s with\n | exn -> of_sexp_error_exn exn sexp\n ;;\n\n let sexp_of_t sexp_of_a sexp_of_b sexp_of_c t =\n Sexpable.sexp_of_t sexp_of_a sexp_of_b sexp_of_c (M.to_sexpable t)\n ;;\n end\n end\n\n module Of_stringable = struct\n module V1 (M : Stringable.S) : S with type t := M.t = struct\n let t_of_sexp sexp =\n match sexp with\n | Sexplib.Sexp.Atom s ->\n (try M.of_string s with\n | exn -> of_sexp_error_exn exn sexp)\n | Sexplib.Sexp.List _ ->\n of_sexp_error\n \"Sexpable.Of_stringable.t_of_sexp expected an atom, but got a list\"\n sexp\n ;;\n\n let sexp_of_t t = Sexplib.Sexp.Atom (M.to_string t)\n end\n end\n\n module To_stringable = struct\n module V1 (M : S) : Stringable.S with type t := M.t = struct\n let of_string x = Sexplib.Conv.of_string__of__of_sexp M.t_of_sexp x\n let to_string x = Sexplib.Conv.string_of__of__sexp_of M.sexp_of_t x\n end\n end\nend\n\nmodule To_stringable = Stable.To_stringable.V1\n","open! Import\nopen Bin_prot.Binable\nopen Bigarray\n\nmodule type Conv_without_uuid = sig\n type binable\n type t\n\n val to_binable : t -> binable\n val of_binable : binable -> t\nend\n\nmodule type Conv1_without_uuid = sig\n type 'a binable\n type 'a t\n\n val to_binable : 'a t -> 'a binable\n val of_binable : 'a binable -> 'a t\nend\n\nmodule type Conv2_without_uuid = sig\n type ('a, 'b) binable\n type ('a, 'b) t\n\n val to_binable : ('a, 'b) t -> ('a, 'b) binable\n val of_binable : ('a, 'b) binable -> ('a, 'b) t\nend\n\nmodule type Conv3_without_uuid = sig\n type ('a, 'b, 'c) binable\n type ('a, 'b, 'c) t\n\n val to_binable : ('a, 'b, 'c) t -> ('a, 'b, 'c) binable\n val of_binable : ('a, 'b, 'c) binable -> ('a, 'b, 'c) t\nend\n\nmodule type Conv = sig\n include Conv_without_uuid\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\nmodule type Conv1 = sig\n include Conv1_without_uuid\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\nmodule type Conv2 = sig\n include Conv2_without_uuid\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\nmodule type Conv3 = sig\n include Conv3_without_uuid\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\nmodule type Conv_sexpable = sig\n include Sexpable.S\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\nmodule type Conv_stringable = sig\n include Stringable.S\n\n val caller_identity : Bin_prot.Shape.Uuid.t\nend\n\n(** Module types and utilities for dealing with types that support the bin-io binary\n encoding. *)\nmodule type Binable = sig\n (** We copy the definition of the bigstring type here, because we cannot depend on\n bigstring.ml *)\n type bigstring = (char, int8_unsigned_elt, c_layout) Array1.t\n\n (** New code should use [@@deriving bin_io]. These module types ([S], [S1], and [S2])\n are exported only for backwards compatibility. *)\n module type S = S\n\n module type S_only_functions = S_only_functions\n module type S1 = S1\n module type S2 = S2\n module type S3 = S3\n\n module Minimal : sig\n module type S = Minimal.S\n module type S1 = Minimal.S1\n module type S2 = Minimal.S2\n module type S3 = Minimal.S3\n end\n\n module type Conv = Conv\n module type Conv1 = Conv1\n module type Conv2 = Conv2\n module type Conv3 = Conv3\n module type Conv_sexpable = Conv_sexpable\n module type Conv_stringable = Conv_stringable\n module type Conv_without_uuid = Conv_without_uuid\n module type Conv1_without_uuid = Conv1_without_uuid\n module type Conv2_without_uuid = Conv2_without_uuid\n module type Conv3_without_uuid = Conv3_without_uuid\n\n (** [Of_binable*] functors are for when you want the binary representation of one type\n to be the same as that for some other isomorphic type. *)\n\n module Of_binable_with_uuid\n (Binable : Minimal.S)\n (M : Conv with type binable := Binable.t) : S with type t := M.t\n\n module Of_binable1_with_uuid\n (Binable : Minimal.S1)\n (M : Conv1 with type 'a binable := 'a Binable.t) : S1 with type 'a t := 'a M.t\n\n module Of_binable2_with_uuid\n (Binable : Minimal.S2)\n (M : Conv2 with type ('a, 'b) binable := ('a, 'b) Binable.t) :\n S2 with type ('a, 'b) t := ('a, 'b) M.t\n\n module Of_binable3_with_uuid\n (Binable : Minimal.S3)\n (M : Conv3 with type ('a, 'b, 'c) binable := ('a, 'b, 'c) Binable.t) :\n S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t\n\n module Of_binable_without_uuid\n (Binable : Minimal.S)\n (M : Conv_without_uuid with type binable := Binable.t) : S with type t := M.t\n [@@alert legacy \"Use [Of_binable_with_uuid] if possible.\"]\n\n module Of_binable1_without_uuid\n (Binable : Minimal.S1)\n (M : Conv1_without_uuid with type 'a binable := 'a Binable.t) :\n S1 with type 'a t := 'a M.t\n [@@alert legacy \"Use [Of_binable1_with_uuid] if possible.\"]\n\n module Of_binable2_without_uuid\n (Binable : Minimal.S2)\n (M : Conv2_without_uuid with type ('a, 'b) binable := ('a, 'b) Binable.t) :\n S2 with type ('a, 'b) t := ('a, 'b) M.t\n [@@alert legacy \"Use [Of_binable2_with_uuid] if possible.\"]\n\n module Of_binable3_without_uuid\n (Binable : Minimal.S3)\n (M : Conv3_without_uuid with type ('a, 'b, 'c) binable := ('a, 'b, 'c) Binable.t) :\n S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t\n [@@alert legacy \"Use [Of_binable3_with_uuid] if possible.\"]\n\n module Of_binable = Of_binable_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_binable_with_uuid] if possible, otherwise use \\\n [Of_binable_without_uuid].\"]\n\n module Of_binable1 = Of_binable1_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_binable1_with_uuid] if possible, otherwise use \\\n [Of_binable1_without_uuid].\"]\n\n module Of_binable2 = Of_binable2_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_binable2_with_uuid] if possible, otherwise use \\\n [Of_binable2_without_uuid].\"]\n\n module Of_binable3 = Of_binable3_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_binable3_with_uuid] if possible, otherwise use \\\n [Of_binable3_without_uuid].\"]\n\n (** [Of_sexpable_with_uuid] serializes a value using the bin-io of the sexp\n serialization of the value. This is not as efficient as using [@@deriving bin_io].\n However, it is useful when performance isn't important and there are obstacles to\n using [@@deriving bin_io], e.g., some type missing [@@deriving bin_io].\n [Of_sexpable_with_uuid] is also useful when one wants to be forgiving about format\n changes, due to the sexp serialization being more robust to changes like adding or\n removing a constructor. *)\n\n module Of_sexpable_with_uuid (M : Conv_sexpable) : S with type t := M.t\n module Of_stringable_with_uuid (M : Conv_stringable) : S with type t := M.t\n\n module Of_sexpable_without_uuid (M : Sexpable.S) : S with type t := M.t\n [@@alert legacy \"Use [Of_sexpable_with_uuid] if possible.\"]\n\n module Of_stringable_without_uuid (M : Stringable.S) : S with type t := M.t\n [@@alert legacy \"Use [Of_stringable_with_uuid] if possible.\"]\n\n module Of_sexpable = Of_sexpable_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_sexpable_with_uuid] if possible, otherwise use \\\n [Of_sexpable_without_uuid].\"]\n\n module Of_stringable = Of_stringable_without_uuid\n [@@alert \"-legacy\"]\n [@@deprecated\n \"[since 2019-11] Use [Of_stringable_with_uuid] if possible, otherwise use \\\n [Of_stringable_without_uuid].\"]\n\n type 'a m = (module S with type t = 'a)\n\n val of_bigstring : 'a m -> bigstring -> 'a\n\n val to_bigstring\n : ?prefix_with_length:bool (** defaults to false *)\n -> 'a m\n -> 'a\n -> bigstring\n\n val of_string : 'a m -> string -> 'a\n val to_string : 'a m -> 'a -> string\n\n (** The following functors preserve stability: if applied to stable types with stable\n (de)serializations, they will produce stable types with stable (de)serializations.\n\n Note: In all cases, stability of the input (and therefore the output) depends on the\n semantics of all conversion functions (e.g. [to_string], [to_sexpable]) not changing\n in the future.\n *)\n\n module Stable : sig\n module Of_binable : sig\n module V1 : (module type of Of_binable_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_binable_with_uuid\n end\n\n module Of_binable1 : sig\n module V1 : (module type of Of_binable1_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_binable1_with_uuid\n end\n\n module Of_binable2 : sig\n module V1 : (module type of Of_binable2_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_binable2_with_uuid\n end\n\n module Of_binable3 : sig\n module V1 : (module type of Of_binable3_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_binable3_with_uuid\n end\n\n module Of_sexpable : sig\n module V1 : (module type of Of_sexpable_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_sexpable_with_uuid\n end\n\n module Of_stringable : sig\n module V1 : (module type of Of_stringable_without_uuid) [@alert \"-legacy\"]\n [@@alert legacy \"Use [V2] instead.\"]\n\n module V2 : module type of Of_stringable_with_uuid\n end\n end\nend\n","open! Import\nopen Binable_intf\ninclude Bin_prot.Binable\nmodule Shape = Bin_prot.Shape\nmodule List = Base.List\n\nmodule Stable = struct\n module Of_binable = struct\n module V1\n (Binable : Minimal.S)\n (M : Conv_without_uuid with type binable := Binable.t) : S with type t := M.t =\n Bin_prot.Utils.Make_binable_without_uuid (struct\n module Binable = Binable\n include M\n end)\n [@@alert \"-legacy\"]\n\n module V2 (Binable : Minimal.S) (M : Conv with type binable := Binable.t) :\n S with type t := M.t = Bin_prot.Utils.Make_binable_with_uuid (struct\n module Binable = Binable\n include M\n end)\n end\n\n module Of_binable1 = struct\n module V1\n (Binable : Minimal.S1)\n (M : Conv1_without_uuid with type 'a binable := 'a Binable.t) :\n S1 with type 'a t := 'a M.t = Bin_prot.Utils.Make_binable1_without_uuid (struct\n module Binable = Binable\n include M\n end)\n [@@alert \"-legacy\"]\n\n module V2 (Binable : Minimal.S1) (M : Conv1 with type 'a binable := 'a Binable.t) :\n S1 with type 'a t := 'a M.t = Bin_prot.Utils.Make_binable1_with_uuid (struct\n module Binable = Binable\n include M\n end)\n end\n\n module Of_binable2 = struct\n module V1\n (Binable : Minimal.S2)\n (M : Conv2_without_uuid with type ('a, 'b) binable := ('a, 'b) Binable.t) :\n S2 with type ('a, 'b) t := ('a, 'b) M.t =\n Bin_prot.Utils.Make_binable2_without_uuid (struct\n module Binable = Binable\n include M\n end)\n [@@alert \"-legacy\"]\n\n module V2\n (Binable : Minimal.S2)\n (M : Conv2 with type ('a, 'b) binable := ('a, 'b) Binable.t) :\n S2 with type ('a, 'b) t := ('a, 'b) M.t =\n Bin_prot.Utils.Make_binable2_with_uuid (struct\n module Binable = Binable\n include M\n end)\n end\n\n module Of_binable3 = struct\n module V1\n (Binable : Minimal.S3)\n (M : Conv3_without_uuid with type ('a, 'b, 'c) binable := ('a, 'b, 'c) Binable.t) :\n S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t =\n Bin_prot.Utils.Make_binable3_without_uuid (struct\n module Binable = Binable\n include M\n end)\n [@@alert \"-legacy\"]\n\n module V2\n (Binable : Minimal.S3)\n (M : Conv3 with type ('a, 'b, 'c) binable := ('a, 'b, 'c) Binable.t) :\n S3 with type ('a, 'b, 'c) t := ('a, 'b, 'c) M.t =\n Bin_prot.Utils.Make_binable3_with_uuid (struct\n module Binable = Binable\n include M\n end)\n end\n\n module Of_sexpable = struct\n module V1 (M : Sexpable.S) =\n Of_binable.V1\n (struct\n type t = Base.Sexp.t =\n | Atom of string\n | List of t list\n [@@deriving bin_io]\n end)\n (struct\n type t = M.t\n\n let to_binable = M.sexp_of_t\n let of_binable = M.t_of_sexp\n end)\n\n module V2 (M : Conv_sexpable) =\n Of_binable.V2\n (struct\n type t = Base.Sexp.t =\n | Atom of string\n | List of t list\n [@@deriving bin_io]\n end)\n (struct\n type t = M.t\n\n let to_binable = M.sexp_of_t\n let of_binable = M.t_of_sexp\n let caller_identity = M.caller_identity\n end)\n end\n\n module Of_stringable = struct\n module V1 (M : Stringable.S) = Bin_prot.Utils.Make_binable_without_uuid (struct\n module Binable = struct\n type t = string [@@deriving bin_io]\n end\n\n type t = M.t\n\n let to_binable = M.to_string\n\n (* Wrap exception for improved diagnostics. *)\n exception Of_binable of string * exn [@@deriving sexp]\n\n let of_binable s =\n try M.of_string s with\n | x -> raise (Of_binable (s, x))\n ;;\n end)\n [@@alert \"-legacy\"]\n\n module V2 (M : Conv_stringable) = Bin_prot.Utils.Make_binable_with_uuid (struct\n module Binable = struct\n type t = string [@@deriving bin_io]\n end\n\n type t = M.t\n\n let to_binable = M.to_string\n\n (* Wrap exception for improved diagnostics. *)\n exception Of_binable of string * exn [@@deriving sexp]\n\n let of_binable s =\n try M.of_string s with\n | x -> raise (Of_binable (s, x))\n ;;\n\n let caller_identity = M.caller_identity\n end)\n end\nend\n\nopen Bigarray\n\ntype bigstring = (char, int8_unsigned_elt, c_layout) Array1.t\n\n\ntype 'a m = (module S with type t = 'a)\n\nlet of_bigstring (type a) m bigstring =\n let module M = (val m : S with type t = a) in\n let pos_ref = ref 0 in\n let t = M.bin_read_t bigstring ~pos_ref in\n assert (!pos_ref = Array1.dim bigstring);\n t\n;;\n\n(* Using the [Bigstring] module would introduce a cyclic dependency. *)\nlet create_bigstring size = Array1.create Bigarray.char Bigarray.c_layout size\n\nlet to_bigstring ?(prefix_with_length = false) (type a) m t =\n let module M = (val m : S with type t = a) in\n let t_length = M.bin_size_t t in\n let bigstring_length =\n if prefix_with_length then t_length + 8 (* the size of a 64-bit int *) else t_length\n in\n let bigstring = create_bigstring bigstring_length in\n let pos =\n if prefix_with_length\n then Bin_prot.Write.bin_write_int_64bit bigstring ~pos:0 t_length\n else 0\n in\n let pos = M.bin_write_t bigstring ~pos t in\n assert (pos = bigstring_length);\n bigstring\n;;\n\nmodule Of_binable_with_uuid = Stable.Of_binable.V2\nmodule Of_binable1_with_uuid = Stable.Of_binable1.V2\nmodule Of_binable2_with_uuid = Stable.Of_binable2.V2\nmodule Of_binable3_with_uuid = Stable.Of_binable3.V2\nmodule Of_sexpable_with_uuid = Stable.Of_sexpable.V2\nmodule Of_stringable_with_uuid = Stable.Of_stringable.V2\n\nmodule Of_binable_without_uuid = Stable.Of_binable.V1\n[@@alert legacy \"Use [Of_binable_with_uuid] if possible.\"]\n\nmodule Of_binable1_without_uuid = Stable.Of_binable1.V1\n[@@alert legacy \"Use [Of_binable1_with_uuid] if possible.\"]\n\nmodule Of_binable2_without_uuid = Stable.Of_binable2.V1\n[@@alert legacy \"Use [Of_binable2_with_uuid] if possible.\"]\n\nmodule Of_binable3_without_uuid = Stable.Of_binable3.V1\n[@@alert legacy \"Use [Of_binable3_with_uuid] if possible.\"]\n\nmodule Of_sexpable_without_uuid = Stable.Of_sexpable.V1\n[@@alert legacy \"Use [Of_sexpable_with_uuid] if possible.\"]\n\nmodule Of_stringable_without_uuid = Stable.Of_stringable.V1\n[@@alert legacy \"Use [Of_stringable_with_uuid] if possible.\"]\n\nmodule type S_only_functions_and_shape = sig\n include S_only_functions\n\n val bin_shape_t : Shape.t\nend\n\n(* check that only the functions & shape are sufficient for [@@deriving bin_io] *)\nmodule Of_only_functions_and_shape (X : S_only_functions_and_shape) : S = struct\n type t = X.t [@@deriving bin_io]\nend\n","(** This module extends {{!Base.Printf}[Base.Printf]}. *)\n\nopen! Import\n\ninclude Base.Printf (** @open *)\n\nlet eprintf = Stdio.Out_channel.eprintf\nlet fprintf = Stdio.Out_channel.fprintf\nlet kfprintf = Stdio.Out_channel.kfprintf\nlet printf = Stdio.Out_channel.printf\n\n\n(** print to stderr; exit 1 *)\nlet exitf fmt =\n ksprintf\n (fun s () ->\n eprintf \"%s\\n%!\" s;\n exit 1)\n fmt\n;;\n","open! Import\nmodule Comparator = Base.Comparator\n\ntype ('a, 'witness) t = ('a, 'witness) Comparator.t = private\n { compare : 'a -> 'a -> int\n ; sexp_of_t : 'a -> Base.Sexp.t\n }\n\nmodule type Base_mask = module type of Comparator with type ('a, 'b) t := ('a, 'b) t\n\ninclude (Comparator : Base_mask)\n\nmodule Stable = struct\n module V1 = struct\n type nonrec ('a, 'witness) t = ('a, 'witness) t = private\n { compare : 'a -> 'a -> int\n ; sexp_of_t : 'a -> Base.Sexp.t\n }\n\n type ('a, 'b) comparator = ('a, 'b) t\n\n module type S = S\n module type S1 = S1\n\n let make = make\n\n module Make = Make\n module Make1 = Make1\n end\nend\n","open! Import\nmodule Result = Base.Result\n\nmodule Stable = struct\n module V1 = struct\n type ('a, 'b) t = ('a, 'b) Result.t =\n | Ok of 'a\n | Error of 'b\n [@@deriving bin_io, compare, hash, sexp]\n\n let map x ~f1 ~f2 =\n match x with\n | Error err -> Error (f2 err)\n | Ok x -> Ok (f1 x)\n ;;\n end\n\n module V1_stable_unit_test = struct\n type t = (string, int) V1.t [@@deriving bin_io, compare, hash, sexp]\n\n let equal = [%compare.equal: t]\n\n let tests =\n [ V1.Ok \"foo\", \"(Ok foo)\", \"\\000\\003foo\"; V1.Error 7, \"(Error 7)\", \"\\001\\007\" ]\n ;;\n end\nend\n\ninclude Stable.V1\ninclude Result\n","include Base.Container\n\nmodule type S1_permissions = Container_intf.S1_permissions\n","let ( |! ) x y = x |> y\n","(** Extends {{!Base.Fn}[Base.Fn]}. *)\n\ninclude Base.Fn (** @open *)\n\ninclude Deprecate_pipe_bang\n","include Base.Ordered_collection_common\n\nlet normalize ~length_fun t i = if i < 0 then i + length_fun t else i\n\nlet slice ~length_fun ~sub_fun t start stop =\n let stop = if stop = 0 then length_fun t else stop in\n let pos = normalize ~length_fun t start in\n let len = normalize ~length_fun t stop - pos in\n sub_fun t ~pos ~len\n;;\n","open! Import\ninclude Base.Sequence\n\ninclude Bin_prot.Utils.Make_binable1_without_uuid [@alert \"-legacy\"] (struct\n module Binable = struct\n type 'a t = 'a list [@@deriving bin_io]\n end\n\n type 'a t = 'a Base.Sequence.t\n\n let of_binable = Base.Sequence.of_list\n let to_binable = Base.Sequence.to_list\n end)\n\nmodule Step = struct\n include Step\n\n type ('a, 's) t = ('a, 's) Step.t =\n | Done\n | Skip of 's\n | Yield of 'a * 's\n [@@deriving bin_io]\nend\n\nmodule Merge_with_duplicates_element = struct\n include Merge_with_duplicates_element\n\n type ('a, 'b) t = ('a, 'b) Merge_with_duplicates_element.t =\n | Left of 'a\n | Right of 'b\n | Both of 'a * 'b\n [@@deriving bin_io]\nend\n\nmodule type Heap = sig\n type 'a t\n\n val create : compare:('a -> 'a -> int) -> 'a t\n val add : 'a t -> 'a -> 'a t\n val remove_min : 'a t -> ('a * 'a t) option\nend\n\nlet merge_all (module Heap : Heap) seqs ~compare =\n let module Merge_all_state = struct\n type 'a t =\n { heap : ('a * 'a Base.Sequence.t) Heap.t\n ; not_yet_in_heap : 'a Base.Sequence.t list\n }\n [@@deriving fields]\n\n let create = Fields.create\n end\n in\n unfold_step\n ~init:\n (Merge_all_state.create\n ~heap:(Heap.create ~compare:(Base.Comparable.lift compare ~f:fst))\n ~not_yet_in_heap:seqs)\n ~f:(fun { heap; not_yet_in_heap } ->\n match not_yet_in_heap with\n | seq :: not_yet_in_heap ->\n (match Expert.next_step seq with\n | Done -> Skip { not_yet_in_heap; heap }\n | Skip seq -> Skip { not_yet_in_heap = seq :: not_yet_in_heap; heap }\n | Yield (elt, seq) -> Skip { not_yet_in_heap; heap = Heap.add heap (elt, seq) })\n | [] ->\n (match Heap.remove_min heap with\n | None -> Done\n | Some ((elt, seq), heap) -> Yield (elt, { heap; not_yet_in_heap = [ seq ] })))\n;;\n","open! Import\nopen Perms.Export\nmodule Array = Base.Array\nmodule Core_sequence = Sequence\n\ninclude (\n Base.Array :\n sig\n type 'a t = 'a array [@@deriving sexp, compare, sexp_grammar]\n end)\n\ntype 'a t = 'a array [@@deriving bin_io, typerep]\n\nmodule Private = Base.Array.Private\n\nmodule T = struct\n include Base.Array\n\n let normalize t i = Ordered_collection_common.normalize ~length_fun:length t i\n\n let slice t start stop =\n Ordered_collection_common.slice ~length_fun:length ~sub_fun:sub t start stop\n ;;\n\n let nget t i = t.(normalize t i)\n let nset t i v = t.(normalize t i) <- v\n\n module Sequence = struct\n open Base.Array\n\n let length = length\n let get = get\n let set = set\n end\n\n (* See OCaml perf notes for why these array blits are special cased -- in particular,\n the section entitled \"Fast, Slow and Incorrect Array blits\" of\n https://janestreet.github.io/ocaml-perf-notes.html *)\n module Int = struct\n type t_ = int array [@@deriving bin_io, compare, sexp]\n\n module Unsafe_blit = struct\n external unsafe_blit\n : src:t_\n -> src_pos:int\n -> dst:t_\n -> dst_pos:int\n -> len:int\n -> unit\n = \"core_array_unsafe_int_blit\"\n [@@noalloc]\n end\n\n include Test_blit.Make_and_test\n (struct\n type t = int\n\n let equal = ( = )\n let of_bool b = if b then 1 else 0\n end)\n (struct\n type t = t_ [@@deriving sexp_of]\n\n include Sequence\n\n let create ~len = create ~len 0\n\n include Unsafe_blit\n end)\n\n include Unsafe_blit\n end\n\n module Float = struct\n type t_ = float array [@@deriving bin_io, compare, sexp]\n\n module Unsafe_blit = struct\n external unsafe_blit\n : src:t_\n -> src_pos:int\n -> dst:t_\n -> dst_pos:int\n -> len:int\n -> unit\n = \"core_array_unsafe_float_blit\"\n [@@noalloc]\n end\n\n include Test_blit.Make_and_test\n (struct\n type t = float\n\n let equal = Base.Float.equal\n let of_bool b = if b then 1. else 0.\n end)\n (struct\n type t = t_ [@@deriving sexp_of]\n\n include Sequence\n\n let create ~len = create ~len 0.\n\n include Unsafe_blit\n end)\n\n include Unsafe_blit\n end\nend\n\nmodule type Permissioned = sig\n type ('a, -'perms) t\n\n include Container.S1_permissions with type ('a, 'perms) t := ('a, 'perms) t\n include Blit.S1_permissions with type ('a, 'perms) t := ('a, 'perms) t\n include Binary_searchable.S1_permissions with type ('a, 'perms) t := ('a, 'perms) t\n\n val length : (_, _) t -> int\n val is_empty : (_, _) t -> bool\n external get : ('a, [> read ]) t -> int -> 'a = \"%array_safe_get\"\n external set : ('a, [> write ]) t -> int -> 'a -> unit = \"%array_safe_set\"\n external unsafe_get : ('a, [> read ]) t -> int -> 'a = \"%array_unsafe_get\"\n external unsafe_set : ('a, [> write ]) t -> int -> 'a -> unit = \"%array_unsafe_set\"\n val create : len:int -> 'a -> ('a, [< _ perms ]) t\n val init : int -> f:(int -> 'a) -> ('a, [< _ perms ]) t\n val make_matrix : dimx:int -> dimy:int -> 'a -> (('a, [< _ perms ]) t, [< _ perms ]) t\n val append : ('a, [> read ]) t -> ('a, [> read ]) t -> ('a, [< _ perms ]) t\n val concat : ('a, [> read ]) t list -> ('a, [< _ perms ]) t\n val copy : ('a, [> read ]) t -> ('a, [< _ perms ]) t\n val fill : ('a, [> write ]) t -> pos:int -> len:int -> 'a -> unit\n val of_list : 'a list -> ('a, [< _ perms ]) t\n val map : ('a, [> read ]) t -> f:('a -> 'b) -> ('b, [< _ perms ]) t\n\n val folding_map\n : ('a, [> read ]) t\n -> init:'b\n -> f:('b -> 'a -> 'b * 'c)\n -> ('c, [< _ perms ]) t\n\n val fold_map\n : ('a, [> read ]) t\n -> init:'b\n -> f:('b -> 'a -> 'b * 'c)\n -> 'b * ('c, [< _ perms ]) t\n\n val mapi : ('a, [> read ]) t -> f:(int -> 'a -> 'b) -> ('b, [< _ perms ]) t\n val iteri : ('a, [> read ]) t -> f:(int -> 'a -> unit) -> unit\n val foldi : ('a, [> read ]) t -> init:'b -> f:(int -> 'b -> 'a -> 'b) -> 'b\n\n val folding_mapi\n : ('a, [> read ]) t\n -> init:'b\n -> f:(int -> 'b -> 'a -> 'b * 'c)\n -> ('c, [< _ perms ]) t\n\n val fold_mapi\n : ('a, [> read ]) t\n -> init:'b\n -> f:(int -> 'b -> 'a -> 'b * 'c)\n -> 'b * ('c, [< _ perms ]) t\n\n val fold_right : ('a, [> read ]) t -> f:('a -> 'b -> 'b) -> init:'b -> 'b\n\n val sort\n : ?pos:int\n -> ?len:int\n -> ('a, [> read_write ]) t\n -> compare:('a -> 'a -> int)\n -> unit\n\n val stable_sort : ('a, [> read_write ]) t -> compare:('a -> 'a -> int) -> unit\n val is_sorted : ('a, [> read ]) t -> compare:('a -> 'a -> int) -> bool\n val is_sorted_strictly : ('a, [> read ]) t -> compare:('a -> 'a -> int) -> bool\n\n val concat_map\n : ('a, [> read ]) t\n -> f:('a -> ('b, [> read ]) t)\n -> ('b, [< _ perms ]) t\n\n val concat_mapi\n : ('a, [> read ]) t\n -> f:(int -> 'a -> ('b, [> read ]) t)\n -> ('b, [< _ perms ]) t\n\n val partition_tf\n : ('a, [> read ]) t\n -> f:('a -> bool)\n -> ('a, [< _ perms ]) t * ('a, [< _ perms ]) t\n\n val partitioni_tf\n : ('a, [> read ]) t\n -> f:(int -> 'a -> bool)\n -> ('a, [< _ perms ]) t * ('a, [< _ perms ]) t\n\n val cartesian_product\n : ('a, [> read ]) t\n -> ('b, [> read ]) t\n -> ('a * 'b, [< _ perms ]) t\n\n val transpose\n : (('a, [> read ]) t, [> read ]) t\n -> (('a, [< _ perms ]) t, [< _ perms ]) t option\n\n val transpose_exn\n : (('a, [> read ]) t, [> read ]) t\n -> (('a, [< _ perms ]) t, [< _ perms ]) t\n\n val normalize : ('a, _) t -> int -> int\n val slice : ('a, [> read ]) t -> int -> int -> ('a, [< _ perms ]) t\n val nget : ('a, [> read ]) t -> int -> 'a\n val nset : ('a, [> write ]) t -> int -> 'a -> unit\n val filter_opt : ('a option, [> read ]) t -> ('a, [< _ perms ]) t\n val filter_map : ('a, [> read ]) t -> f:('a -> 'b option) -> ('b, [< _ perms ]) t\n\n val filter_mapi\n : ('a, [> read ]) t\n -> f:(int -> 'a -> 'b option)\n -> ('b, [< _ perms ]) t\n\n val for_alli : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> bool\n val existsi : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> bool\n val counti : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> int\n val iter2_exn : ('a, [> read ]) t -> ('b, [> read ]) t -> f:('a -> 'b -> unit) -> unit\n\n val map2_exn\n : ('a, [> read ]) t\n -> ('b, [> read ]) t\n -> f:('a -> 'b -> 'c)\n -> ('c, [< _ perms ]) t\n\n val fold2_exn\n : ('a, [> read ]) t\n -> ('b, [> read ]) t\n -> init:'c\n -> f:('c -> 'a -> 'b -> 'c)\n -> 'c\n\n val for_all2_exn\n : ('a, [> read ]) t\n -> ('b, [> read ]) t\n -> f:('a -> 'b -> bool)\n -> bool\n\n val exists2_exn\n : ('a, [> read ]) t\n -> ('b, [> read ]) t\n -> f:('a -> 'b -> bool)\n -> bool\n\n val filter : ('a, [> read ]) t -> f:('a -> bool) -> ('a, [< _ perms ]) t\n val filteri : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> ('a, [< _ perms ]) t\n val swap : ('a, [> read_write ]) t -> int -> int -> unit\n val rev_inplace : ('a, [> read_write ]) t -> unit\n val of_list_rev : 'a list -> ('a, [< _ perms ]) t\n val of_list_map : 'a list -> f:('a -> 'b) -> ('b, [< _ perms ]) t\n val of_list_mapi : 'a list -> f:(int -> 'a -> 'b) -> ('b, [< _ perms ]) t\n val of_list_rev_map : 'a list -> f:('a -> 'b) -> ('b, [< _ perms ]) t\n val of_list_rev_mapi : 'a list -> f:(int -> 'a -> 'b) -> ('b, [< _ perms ]) t\n val map_inplace : ('a, [> read_write ]) t -> f:('a -> 'a) -> unit\n val find_exn : ('a, [> read ]) t -> f:('a -> bool) -> 'a\n val find_map_exn : ('a, [> read ]) t -> f:('a -> 'b option) -> 'b\n val findi : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> (int * 'a) option\n val findi_exn : ('a, [> read ]) t -> f:(int -> 'a -> bool) -> int * 'a\n val find_mapi : ('a, [> read ]) t -> f:(int -> 'a -> 'b option) -> 'b option\n val find_mapi_exn : ('a, [> read ]) t -> f:(int -> 'a -> 'b option) -> 'b\n\n val find_consecutive_duplicate\n : ('a, [> read ]) t\n -> equal:('a -> 'a -> bool)\n -> ('a * 'a) option\n\n val reduce : ('a, [> read ]) t -> f:('a -> 'a -> 'a) -> 'a option\n val reduce_exn : ('a, [> read ]) t -> f:('a -> 'a -> 'a) -> 'a\n val permute : ?random_state:Random.State.t -> ('a, [> read_write ]) t -> unit\n val random_element : ?random_state:Random.State.t -> ('a, [> read ]) t -> 'a option\n val random_element_exn : ?random_state:Random.State.t -> ('a, [> read ]) t -> 'a\n val zip : ('a, [> read ]) t -> ('b, [> read ]) t -> ('a * 'b, [< _ perms ]) t option\n val zip_exn : ('a, [> read ]) t -> ('b, [> read ]) t -> ('a * 'b, [< _ perms ]) t\n val unzip : ('a * 'b, [> read ]) t -> ('a, [< _ perms ]) t * ('b, [< _ perms ]) t\n\n val sorted_copy\n : ('a, [> read ]) t\n -> compare:('a -> 'a -> int)\n -> ('a, [< _ perms ]) t\n\n val last : ('a, [> read ]) t -> 'a\n val equal : ('a -> 'a -> bool) -> ('a, [> read ]) t -> ('a, [> read ]) t -> bool\n val to_sequence : ('a, [> read ]) t -> 'a Sequence.t\n val to_sequence_mutable : ('a, [> read ]) t -> 'a Sequence.t\nend\n\nmodule Permissioned : sig\n type ('a, -'perms) t [@@deriving bin_io, compare, sexp]\n\n module Int : sig\n type nonrec -'perms t = (int, 'perms) t [@@deriving bin_io, compare, sexp]\n\n include Blit.S_permissions with type 'perms t := 'perms t\n\n external unsafe_blit\n : src:[> read ] t\n -> src_pos:int\n -> dst:[> write ] t\n -> dst_pos:int\n -> len:int\n -> unit\n = \"core_array_unsafe_int_blit\"\n [@@noalloc]\n end\n\n module Float : sig\n type nonrec -'perms t = (float, 'perms) t [@@deriving bin_io, compare, sexp]\n\n include Blit.S_permissions with type 'perms t := 'perms t\n\n external unsafe_blit\n : src:[> read ] t\n -> src_pos:int\n -> dst:[> write ] t\n -> dst_pos:int\n -> len:int\n -> unit\n = \"core_array_unsafe_float_blit\"\n [@@noalloc]\n end\n\n val of_array_id : 'a array -> ('a, [< read_write ]) t\n val to_array_id : ('a, [> read_write ]) t -> 'a array\n val to_sequence_immutable : ('a, [> immutable ]) t -> 'a Sequence.t\n\n include Permissioned with type ('a, 'perms) t := ('a, 'perms) t\nend = struct\n type ('a, -'perms) t = 'a array [@@deriving bin_io, compare, sexp, typerep]\n\n module Int = struct\n include T.Int\n\n type -'perms t = t_ [@@deriving bin_io, compare, sexp]\n end\n\n module Float = struct\n include T.Float\n\n type -'perms t = t_ [@@deriving bin_io, compare, sexp]\n end\n\n let to_array_id = Fn.id\n let of_array_id = Fn.id\n\n include (T : Permissioned with type ('a, 'b) t := ('a, 'b) t) [@ocaml.warning \"-3\"]\n\n let to_array = copy\n let to_sequence_immutable = to_sequence_mutable\nend\n\nmodule type S = sig\n type 'a t\n\n include Binary_searchable.S1 with type 'a t := 'a t\n include Container.S1 with type 'a t := 'a t\n\n external get : 'a t -> int -> 'a = \"%array_safe_get\"\n external set : 'a t -> int -> 'a -> unit = \"%array_safe_set\"\n external unsafe_get : 'a t -> int -> 'a = \"%array_unsafe_get\"\n external unsafe_set : 'a t -> int -> 'a -> unit = \"%array_unsafe_set\"\n val create : len:int -> 'a -> 'a t\n val init : int -> f:(int -> 'a) -> 'a t\n val make_matrix : dimx:int -> dimy:int -> 'a -> 'a t t\n val append : 'a t -> 'a t -> 'a t\n val concat : 'a t list -> 'a t\n val copy : 'a t -> 'a t\n val fill : 'a t -> pos:int -> len:int -> 'a -> unit\n\n include Blit.S1 with type 'a t := 'a t\n\n val of_list : 'a list -> 'a t\n val map : 'a t -> f:('a -> 'b) -> 'b t\n val folding_map : 'a t -> init:'b -> f:('b -> 'a -> 'b * 'c) -> 'c t\n val fold_map : 'a t -> init:'b -> f:('b -> 'a -> 'b * 'c) -> 'b * 'c t\n val mapi : 'a t -> f:(int -> 'a -> 'b) -> 'b t\n val iteri : 'a t -> f:(int -> 'a -> unit) -> unit\n val foldi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b) -> 'b\n val folding_mapi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b * 'c) -> 'c t\n val fold_mapi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b * 'c) -> 'b * 'c t\n val fold_right : 'a t -> f:('a -> 'b -> 'b) -> init:'b -> 'b\n val sort : ?pos:int -> ?len:int -> 'a t -> compare:('a -> 'a -> int) -> unit\n val stable_sort : 'a t -> compare:('a -> 'a -> int) -> unit\n val is_sorted : 'a t -> compare:('a -> 'a -> int) -> bool\n val is_sorted_strictly : 'a t -> compare:('a -> 'a -> int) -> bool\n val concat_map : 'a t -> f:('a -> 'b t) -> 'b t\n val concat_mapi : 'a t -> f:(int -> 'a -> 'b t) -> 'b t\n val partition_tf : 'a t -> f:('a -> bool) -> 'a t * 'a t\n val partitioni_tf : 'a t -> f:(int -> 'a -> bool) -> 'a t * 'a t\n val cartesian_product : 'a t -> 'b t -> ('a * 'b) t\n val transpose : 'a t t -> 'a t t option\n val transpose_exn : 'a t t -> 'a t t\n val normalize : 'a t -> int -> int\n val slice : 'a t -> int -> int -> 'a t\n val nget : 'a t -> int -> 'a\n val nset : 'a t -> int -> 'a -> unit\n val filter_opt : 'a option t -> 'a t\n val filter_map : 'a t -> f:('a -> 'b option) -> 'b t\n val filter_mapi : 'a t -> f:(int -> 'a -> 'b option) -> 'b t\n val for_alli : 'a t -> f:(int -> 'a -> bool) -> bool\n val existsi : 'a t -> f:(int -> 'a -> bool) -> bool\n val counti : 'a t -> f:(int -> 'a -> bool) -> int\n val iter2_exn : 'a t -> 'b t -> f:('a -> 'b -> unit) -> unit\n val map2_exn : 'a t -> 'b t -> f:('a -> 'b -> 'c) -> 'c t\n val fold2_exn : 'a t -> 'b t -> init:'c -> f:('c -> 'a -> 'b -> 'c) -> 'c\n val for_all2_exn : 'a t -> 'b t -> f:('a -> 'b -> bool) -> bool\n val exists2_exn : 'a t -> 'b t -> f:('a -> 'b -> bool) -> bool\n val filter : 'a t -> f:('a -> bool) -> 'a t\n val filteri : 'a t -> f:(int -> 'a -> bool) -> 'a t\n val swap : 'a t -> int -> int -> unit\n val rev_inplace : 'a t -> unit\n val of_list_rev : 'a list -> 'a t\n val of_list_map : 'a list -> f:('a -> 'b) -> 'b t\n val of_list_mapi : 'a list -> f:(int -> 'a -> 'b) -> 'b t\n val of_list_rev_map : 'a list -> f:('a -> 'b) -> 'b t\n val of_list_rev_mapi : 'a list -> f:(int -> 'a -> 'b) -> 'b t\n val map_inplace : 'a t -> f:('a -> 'a) -> unit\n val find_exn : 'a t -> f:('a -> bool) -> 'a\n val find_map_exn : 'a t -> f:('a -> 'b option) -> 'b\n val findi : 'a t -> f:(int -> 'a -> bool) -> (int * 'a) option\n val findi_exn : 'a t -> f:(int -> 'a -> bool) -> int * 'a\n val find_mapi : 'a t -> f:(int -> 'a -> 'b option) -> 'b option\n val find_mapi_exn : 'a t -> f:(int -> 'a -> 'b option) -> 'b\n val find_consecutive_duplicate : 'a t -> equal:('a -> 'a -> bool) -> ('a * 'a) option\n val reduce : 'a t -> f:('a -> 'a -> 'a) -> 'a option\n val reduce_exn : 'a t -> f:('a -> 'a -> 'a) -> 'a\n val permute : ?random_state:Random.State.t -> 'a t -> unit\n val random_element : ?random_state:Random.State.t -> 'a t -> 'a option\n val random_element_exn : ?random_state:Random.State.t -> 'a t -> 'a\n val zip : 'a t -> 'b t -> ('a * 'b) t option\n val zip_exn : 'a t -> 'b t -> ('a * 'b) t\n val unzip : ('a * 'b) t -> 'a t * 'b t\n val sorted_copy : 'a t -> compare:('a -> 'a -> int) -> 'a t\n val last : 'a t -> 'a\n val equal : ('a -> 'a -> bool) -> 'a t -> 'a t -> bool\n val to_sequence : 'a t -> 'a Core_sequence.t\n val to_sequence_mutable : 'a t -> 'a Core_sequence.t\nend\n\ninclude (T : S with type 'a t := 'a array) [@ocaml.warning \"-3\"]\n\nlet invariant invariant_a t = iter t ~f:invariant_a\nlet max_length = Sys.max_array_length\n\nmodule Int = struct\n include T.Int\n\n type t = t_ [@@deriving bin_io, compare, sexp]\nend\n\nmodule Float = struct\n include T.Float\n\n type t = t_ [@@deriving bin_io, compare, sexp]\nend\n\nmodule Check1 (M : S) : sig\n type ('a, -'perm) t_\n\n include Permissioned with type ('a, 'perm) t := ('a, 'perm) t_\nend = struct\n include M\n\n type ('a, -'perm) t_ = 'a t\nend\n\nmodule Check2 (M : Permissioned) : sig\n type 'a t_\n\n include S with type 'a t := 'a t_\nend = struct\n include M\n\n type 'a t_ = ('a, read_write) t\nend\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n include Base.Source_code_position\n\n type t = Base.Source_code_position.t =\n { pos_fname : string\n ; pos_lnum : int\n ; pos_bol : int\n ; pos_cnum : int\n }\n [@@deriving bin_io, compare, hash, sexp]\n end\nend\n\ninclude Stable.V1\n\nlet to_string = Base.Source_code_position.to_string\nlet sexp_of_t = Base.Source_code_position.sexp_of_t\n","(* This module is trying to minimize dependencies on modules in Core, so as to allow\n [Info], [Error], and [Or_error] to be used in is many places places as possible.\n Please avoid adding new dependencies. *)\n\nopen! Import\nopen! Info_intf\n\nmodule type S = Base.Info.S\n\nmodule Source_code_position = Source_code_position0\nmodule Binable = Binable0\n\nmodule Sexp = struct\n include Sexplib.Sexp\n\n include (\n struct\n type t = Base.Sexp.t =\n | Atom of string\n | List of t list\n [@@deriving bin_io, compare, hash]\n end :\n sig\n type t [@@deriving bin_io, compare, hash]\n end\n with type t := t)\nend\n\nmodule Binable_exn = struct\n module Stable = struct\n module V1 = struct\n module T = struct\n type t = exn [@@deriving sexp_of]\n end\n\n include T\n\n include Binable.Stable.Of_binable.V1 [@alert \"-legacy\"]\n (Sexp)\n (struct\n include T\n\n let to_binable t = t |> [%sexp_of: t]\n let of_binable = Exn.create_s\n end)\n end\n end\nend\n\nmodule Extend (Info : Base.Info.S) = struct\n include Info\n\n module Internal_repr = struct\n module Stable = struct\n module Binable_exn = Binable_exn.Stable\n\n module Source_code_position = struct\n module V1 = struct\n type t = Source_code_position.Stable.V1.t [@@deriving bin_io]\n\n (* [sexp_of_t] as defined here is unstable; this is OK because there is no\n [t_of_sexp]. [sexp_of_t] is only used to produce a sexp that is never\n deserialized as a [Source_code_position]. *)\n let sexp_of_t = Source_code_position.sexp_of_t\n end\n end\n\n module V2 = struct\n type t = Info.Internal_repr.t =\n | Could_not_construct of Sexp.t\n | String of string\n | Exn of Binable_exn.V1.t\n | Sexp of Sexp.t\n | Tag_sexp of string * Sexp.t * Source_code_position.V1.t option\n | Tag_t of string * t\n | Tag_arg of string * Sexp.t * t\n | Of_list of int option * t list\n | With_backtrace of t * string (* backtrace *)\n [@@deriving bin_io, sexp_of]\n end\n end\n\n include Stable.V2\n\n let to_info = Info.Internal_repr.to_info\n let of_info = Info.Internal_repr.of_info\n end\n\n module Stable = struct\n module V2 = struct\n module T = struct\n type t = Info.t [@@deriving sexp, compare, hash]\n end\n\n include T\n include Comparator.Stable.V1.Make (T)\n\n include Binable.Stable.Of_binable.V1 [@alert \"-legacy\"]\n (Internal_repr.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable = Info.Internal_repr.of_info\n let of_binable = Info.Internal_repr.to_info\n end)\n end\n\n module V1 = struct\n module T = struct\n type t = Info.t [@@deriving compare]\n\n include Sexpable.Stable.Of_sexpable.V1\n (Sexp)\n (struct\n type nonrec t = t\n\n let to_sexpable = Info.sexp_of_t\n let of_sexpable = Info.t_of_sexp\n end)\n\n let compare = compare\n end\n\n include T\n include Comparator.Stable.V1.Make (T)\n\n include Binable.Stable.Of_binable.V1 [@alert \"-legacy\"]\n (Sexp)\n (struct\n type nonrec t = t\n\n let to_binable = sexp_of_t\n let of_binable = t_of_sexp\n end)\n end\n end\n\n type t = Stable.V2.t [@@deriving bin_io]\nend\n\ninclude Extend (Base.Info)\n\n","include Base.Error\ninclude Info.Extend (Base.Error)\n\nlet failwiths ?strict ~here message a sexp_of_a =\n raise (create ?strict ~here message a sexp_of_a)\n;;\n\nlet failwithp ?strict here message a sexp_of_a =\n raise (create ?strict ~here message a sexp_of_a)\n;;\n","(** Derived from [Base.T]. Used for matching bare signatures with just a type. *)\n\nopen! Import\ninclude Base.T\n\nmodule type T_bin = sig\n type t [@@deriving bin_io]\nend\n","open! Import\nopen! Typerep_lib.Std\nmodule Array = Base.Array\ninclude Base.List\n\ntype 'a t = 'a list [@@deriving bin_io, typerep]\n\nmodule Assoc = struct\n include Assoc\n\n type ('a, 'b) t = ('a * 'b) list [@@deriving bin_io]\n\n let[@deprecated\n \"[since 2016-06] This does not respect the equivalence class promised by \\\n List.Assoc. Use List.compare directly if that's what you want.\"] compare\n (type a b)\n compare_a\n compare_b\n =\n [%compare: (a * b) list]\n ;;\nend\n\nlet to_string ~f t =\n Sexplib.Sexp.to_string (sexp_of_t (fun x -> Sexplib.Sexp.Atom x) (map t ~f))\n;;\n\ninclude Comparator.Derived (struct\n type nonrec 'a t = 'a t [@@deriving sexp_of, compare]\n end)\n\nlet quickcheck_generator = Base_quickcheck.Generator.list\nlet gen_non_empty = Base_quickcheck.Generator.list_non_empty\n\nlet gen_with_length length quickcheck_generator =\n Base_quickcheck.Generator.list_with_length quickcheck_generator ~length\n;;\n\nlet gen_filtered = Base_quickcheck.Generator.list_filtered\nlet gen_permutations = Base_quickcheck.Generator.list_permutations\nlet quickcheck_observer = Base_quickcheck.Observer.list\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.list\n","open! Import\nopen Hashtbl_intf\nmodule Avltree = Avltree\nmodule Binable = Binable0\nmodule Hashable = Hashtbl_intf.Hashable\nmodule Merge_into_action = Hashtbl_intf.Merge_into_action\nmodule List = List0\n\nlet failwiths = Error.failwiths\n\nmodule Creators = Hashtbl.Creators\n\ninclude (\n Hashtbl :\n sig\n type ('a, 'b) t = ('a, 'b) Hashtbl.t [@@deriving sexp_of]\n\n include Base.Hashtbl.S_without_submodules with type ('a, 'b) t := ('a, 'b) t\n end)\n\nmodule Using_hashable = struct\n type nonrec ('a, 'b) t = ('a, 'b) t [@@deriving sexp_of]\n\n let create ?growth_allowed ?size ~hashable () =\n create ?growth_allowed ?size (Base.Hashable.to_key hashable)\n ;;\n\n let of_alist ?growth_allowed ?size ~hashable l =\n of_alist ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\n\n let of_alist_report_all_dups ?growth_allowed ?size ~hashable l =\n of_alist_report_all_dups ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\n\n let of_alist_or_error ?growth_allowed ?size ~hashable l =\n of_alist_or_error ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\n\n let of_alist_exn ?growth_allowed ?size ~hashable l =\n of_alist_exn ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\n\n let of_alist_multi ?growth_allowed ?size ~hashable l =\n of_alist_multi ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\n\n let create_mapped ?growth_allowed ?size ~hashable ~get_key ~get_data l =\n create_mapped\n ?growth_allowed\n ?size\n (Base.Hashable.to_key hashable)\n ~get_key\n ~get_data\n l\n ;;\n\n let create_with_key ?growth_allowed ?size ~hashable ~get_key l =\n create_with_key ?growth_allowed ?size (Base.Hashable.to_key hashable) ~get_key l\n ;;\n\n let create_with_key_or_error ?growth_allowed ?size ~hashable ~get_key l =\n create_with_key_or_error\n ?growth_allowed\n ?size\n (Base.Hashable.to_key hashable)\n ~get_key\n l\n ;;\n\n let create_with_key_exn ?growth_allowed ?size ~hashable ~get_key l =\n create_with_key_exn ?growth_allowed ?size (Base.Hashable.to_key hashable) ~get_key l\n ;;\n\n let group ?growth_allowed ?size ~hashable ~get_key ~get_data ~combine l =\n group\n ?growth_allowed\n ?size\n (Base.Hashable.to_key hashable)\n ~get_key\n ~get_data\n ~combine\n l\n ;;\nend\n\nmodule type S_plain = S_plain with type ('a, 'b) hashtbl = ('a, 'b) t\nmodule type S = S with type ('a, 'b) hashtbl = ('a, 'b) t\nmodule type S_binable = S_binable with type ('a, 'b) hashtbl = ('a, 'b) t\nmodule type Key_plain = Key_plain\nmodule type Key = Key\nmodule type Key_binable = Key_binable\n\nmodule Poly = struct\n include Hashtbl.Poly\n\n include Bin_prot.Utils.Make_iterable_binable2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n type ('a, 'b) el = 'a * 'b [@@deriving bin_io]\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"8f3e445c-4992-11e6-a279-3703be311e7b\"\n ;;\n\n let module_name = Some \"Core_kernel.Hashtbl\"\n let length = length\n let iter t ~f = iteri t ~f:(fun ~key ~data -> f (key, data))\n\n let init ~len ~next =\n let t = create ~size:len () in\n for _i = 0 to len - 1 do\n let key, data = next () in\n match find t key with\n | None -> set t ~key ~data\n | Some _ -> failwith \"Core_hashtbl.bin_read_t_: duplicate key\"\n done;\n t\n ;;\n end)\nend\n\nmodule Make_plain (Key : Key_plain) = struct\n let hashable =\n { Hashable.hash = Key.hash; compare = Key.compare; sexp_of_t = Key.sexp_of_t }\n ;;\n\n type key = Key.t\n type ('a, 'b) hashtbl = ('a, 'b) t\n type 'a t = (Key.t, 'a) hashtbl\n type ('a, 'b) t__ = (Key.t, 'b) hashtbl\n type 'a key_ = Key.t\n\n include Creators (struct\n type 'a t = Key.t\n\n let hashable = hashable\n end)\n\n include (\n Hashtbl :\n sig\n include\n Hashtbl.Accessors\n with type ('a, 'b) t := ('a, 'b) t__\n with type 'a key := 'a key_\n\n include\n Hashtbl.Multi with type ('a, 'b) t := ('a, 'b) t__ with type 'a key := 'a key_\n\n include Invariant.S2 with type ('a, 'b) t := ('a, 'b) hashtbl\n end)\n\n let invariant invariant_key t = invariant ignore invariant_key t\n let sexp_of_t sexp_of_v t = Poly.sexp_of_t Key.sexp_of_t sexp_of_v t\n\n module Provide_of_sexp\n (Key : sig\n type t [@@deriving of_sexp]\n end\n with type t := key) =\n struct\n let t_of_sexp v_of_sexp sexp = t_of_sexp Key.t_of_sexp v_of_sexp sexp\n end\n\n module Provide_bin_io\n (Key' : sig\n type t [@@deriving bin_io]\n end\n with type t := key) =\n Bin_prot.Utils.Make_iterable_binable1 (struct\n module Key = struct\n include Key\n include Key'\n end\n\n type nonrec 'a t = 'a t\n type 'a el = Key.t * 'a [@@deriving bin_io]\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"8fabab0a-4992-11e6-8cca-9ba2c4686d9e\"\n ;;\n\n let module_name = Some \"Core_kernel.Hashtbl\"\n let length = length\n let iter t ~f = iteri t ~f:(fun ~key ~data -> f (key, data))\n\n let init ~len ~next =\n let t = create ~size:len () in\n for _i = 0 to len - 1 do\n let key, data = next () in\n match find t key with\n | None -> set t ~key ~data\n | Some _ ->\n failwiths\n ~here:[%here]\n \"Hashtbl.bin_read_t: duplicate key\"\n key\n [%sexp_of: Key.t]\n done;\n t\n ;;\n end)\nend\n\nmodule Make (Key : Key) = struct\n include Make_plain (Key)\n include Provide_of_sexp (Key)\nend\n\nmodule Make_binable (Key : Key_binable) = struct\n include Make (Key)\n include Provide_bin_io (Key)\nend\n\nmodule M = Hashtbl.M\n\nmodule type For_deriving = For_deriving\n\ninclude (Hashtbl : For_deriving with type ('a, 'b) t := ('a, 'b) t)\n\nlet hashable = Hashtbl.Private.hashable\n","open! Import\nopen Hash_set_intf\ninclude Base.Hash_set\n\nmodule type S_plain = S_plain with type 'a hash_set := 'a t\nmodule type S = S with type 'a hash_set := 'a t\nmodule type S_binable = S_binable with type 'a hash_set := 'a t\nmodule type Elt_plain = Hashtbl.Key_plain\nmodule type Elt = Hashtbl.Key\nmodule type Elt_binable = Hashtbl.Key_binable\n\nmodule Make_plain (Elt : Elt_plain) = struct\n type elt = Elt.t\n type nonrec t = elt t\n type 'a elt_ = elt\n\n include Creators (struct\n type 'a t = Elt.t\n\n let hashable = Hashtbl.Hashable.of_key (module Elt)\n end)\n\n let sexp_of_t t = Poly.sexp_of_t Elt.sexp_of_t t\n\n module Provide_of_sexp\n (X : sig\n type t [@@deriving of_sexp]\n end\n with type t := elt) =\n struct\n let t_of_sexp sexp = t_of_sexp X.t_of_sexp sexp\n end\n\n module Provide_bin_io\n (X : sig\n type t [@@deriving bin_io]\n end\n with type t := elt) =\n Bin_prot.Utils.Make_iterable_binable (struct\n module Elt = struct\n include Elt\n include X\n end\n\n type nonrec t = t\n type el = Elt.t [@@deriving bin_io]\n\n let _ = bin_el\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"ad381672-4992-11e6-9e36-b76dc8cd466f\"\n ;;\n\n let module_name = Some \"Core_kernel.Hash_set\"\n let length = length\n let iter = iter\n\n let init ~len ~next =\n let t = create ~size:len () in\n for _i = 0 to len - 1 do\n let v = next () in\n add t v\n done;\n t\n ;;\n end)\nend\n\nmodule Make (Elt : Elt) = struct\n include Make_plain (Elt)\n include Provide_of_sexp (Elt)\nend\n\nmodule Make_binable (Elt : Elt_binable) = struct\n include Make (Elt)\n include Provide_bin_io (Elt)\nend\n\nmodule Using_hashable = struct\n type 'a elt = 'a\n\n let create ?growth_allowed ?size ~hashable () =\n create ?growth_allowed ?size (Base.Hashable.to_key hashable)\n ;;\n\n let of_list ?growth_allowed ?size ~hashable l =\n of_list ?growth_allowed ?size (Base.Hashable.to_key hashable) l\n ;;\nend\n\nlet hashable = Private.hashable\nlet create ?growth_allowed ?size m = create ?growth_allowed ?size m\n","open! Import\ninclude Base.Or_error\n\ntype 'a t = ('a, Error.t) Result.t [@@deriving bin_io]\n\nmodule Expect_test_config = struct\n module IO = Base.Or_error\n module IO_run = IO\n\n module IO_flush = struct\n include IO\n\n let to_run t = t\n end\n\n let flush () = return ()\n let run f = ok_exn (f ())\n let flushed () = true\n let upon_unreleasable_issue = Expect_test_config.upon_unreleasable_issue\nend\n\nmodule Stable = struct\n module V1 = struct\n type 'a t = ('a, Error.Stable.V1.t) Result.Stable.V1.t\n [@@deriving bin_io, compare, sexp]\n\n let map x ~f = Result.Stable.V1.map x ~f1:f ~f2:Fn.id\n end\n\n module V2 = struct\n type 'a t = ('a, Error.Stable.V2.t) Result.Stable.V1.t\n [@@deriving bin_io, compare, sexp]\n\n let map x ~f = Result.Stable.V1.map x ~f1:f ~f2:Fn.id\n end\nend\n","open! Import\nopen Map_intf\nmodule List = List0\n\nmodule Symmetric_diff_element = struct\n module Stable = struct\n module V1 = struct\n type ('k, 'v) t = 'k * [ `Left of 'v | `Right of 'v | `Unequal of 'v * 'v ]\n [@@deriving bin_io, compare, sexp]\n\n let%expect_test _ =\n print_endline [%bin_digest: (int, string) t];\n [%expect {| 00674be9fe8dfe9e9ad476067d7d8101 |}]\n ;;\n\n let map (k, diff) ~f1 ~f2 =\n let k = f1 k in\n let diff =\n match diff with\n | `Left v -> `Left (f2 v)\n | `Right v -> `Right (f2 v)\n | `Unequal (v1, v2) -> `Unequal (f2 v1, f2 v2)\n in\n k, diff\n ;;\n\n let map_data t ~f = map t ~f1:Fn.id ~f2:f\n\n let left (_key, diff) =\n match diff with\n | `Left x | `Unequal (x, _) -> Some x\n | `Right _ -> None\n ;;\n\n let right (_key, diff) =\n match diff with\n | `Right x | `Unequal (_, x) -> Some x\n | `Left _ -> None\n ;;\n end\n end\n\n include Stable.V1\nend\n\nmodule Continue_or_stop = Base.Map.Continue_or_stop\nmodule Finished_or_unfinished = Base.Map.Finished_or_unfinished\n\ntype ('k, 'cmp) comparator =\n (module Comparator.S with type t = 'k and type comparator_witness = 'cmp)\n\nlet to_comparator (type k cmp) ((module M) : (k, cmp) Map.comparator) = M.comparator\n\nlet of_comparator (type k cmp) comparator : (k, cmp) Map.comparator =\n (module struct\n type t = k\n type comparator_witness = cmp\n\n let comparator = comparator\n end)\n;;\n\nmodule For_quickcheck = struct\n let gen_tree ~comparator k_gen v_gen =\n Base_quickcheck.Generator.map_tree_using_comparator ~comparator k_gen v_gen\n ;;\n\n let quickcheck_generator ~comparator k_gen v_gen =\n Base_quickcheck.Generator.map_t_m (of_comparator comparator) k_gen v_gen\n ;;\n\n let obs_tree k_obs v_obs = Base_quickcheck.Observer.map_tree k_obs v_obs\n\n let shr_tree ~comparator k_shr v_shr =\n Base_quickcheck.Shrinker.map_tree_using_comparator ~comparator k_shr v_shr\n ;;\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.map_t_m\nlet quickcheck_observer = Base_quickcheck.Observer.map_t\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.map_t\n\nmodule Using_comparator = struct\n include Map.Using_comparator\n include For_quickcheck\n\n let of_hashtbl_exn ~comparator hashtbl =\n match of_iteri ~comparator ~iteri:(Hashtbl.iteri hashtbl) with\n | `Ok map -> map\n | `Duplicate_key key ->\n Error.failwiths\n ~here:[%here]\n \"Map.of_hashtbl_exn: duplicate key\"\n key\n comparator.sexp_of_t\n ;;\n\n let tree_of_hashtbl_exn ~comparator hashtbl =\n to_tree (of_hashtbl_exn ~comparator hashtbl)\n ;;\n\n let key_set ~comparator t =\n Base.Set.Using_comparator.of_sorted_array_unchecked\n ~comparator\n (List.to_array (keys t))\n ;;\n\n let key_set_of_tree ~comparator t = key_set ~comparator (of_tree ~comparator t)\n\n let of_key_set key_set ~f =\n of_sorted_array_unchecked\n ~comparator:(Base.Set.comparator key_set)\n (Array.map (Base.Set.to_array key_set) ~f:(fun key -> key, f key))\n ;;\n\n let tree_of_key_set key_set ~f = to_tree (of_key_set key_set ~f)\nend\n\nmodule Accessors = struct\n include (\n Map.Using_comparator :\n Map.Accessors3\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) Map.t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t)\n\n let quickcheck_observer k v = quickcheck_observer k v\n let quickcheck_shrinker k v = quickcheck_shrinker k v\n let key_set t = Using_comparator.key_set t ~comparator:(Using_comparator.comparator t)\nend\n\nlet key_set t = Using_comparator.key_set ~comparator:(Using_comparator.comparator t) t\nlet of_key_set = Using_comparator.of_key_set\nlet hash_fold_direct = Using_comparator.hash_fold_direct\nlet comparator = Using_comparator.comparator\nlet comparator_s = Base.Map.comparator_s\n\ntype 'k key = 'k\ntype 'c cmp = 'c\n\ninclude (\nstruct\n include Map\n\n let of_tree m = Map.Using_comparator.of_tree ~comparator:(to_comparator m)\n let to_tree = Map.Using_comparator.to_tree\nend :\nsig\n type ('a, 'b, 'c) t = ('a, 'b, 'c) Map.t\n\n include\n Map.Creators_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Map.With_first_class_module.t\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\n with type 'k key := 'k key\n with type 'c cmp := 'c cmp\n\n include\n Map.Accessors3\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) Tree.t\nend)\n\nmodule Empty_without_value_restriction = Using_comparator.Empty_without_value_restriction\n\nlet find_or_error t key =\n let comparator = comparator t in\n match find t key with\n | Some data -> Ok data\n | None ->\n let sexp_of_key = comparator.sexp_of_t in\n Or_error.error_s [%message \"key not found\" ~_:(key : key)]\n;;\n\nlet merge_skewed = Map.merge_skewed\nlet of_hashtbl_exn m t = Using_comparator.of_hashtbl_exn ~comparator:(to_comparator m) t\n\nmodule Creators (Key : Comparator.S1) : sig\n type ('a, 'b, 'c) t_ = ('a Key.t, 'b, Key.comparator_witness) t\n type ('a, 'b, 'c) tree = ('a, 'b, Key.comparator_witness) Tree.t\n type ('a, 'b, 'c) options = ('a, 'b, 'c) Without_comparator.t\n\n val t_of_sexp\n : (Base.Sexp.t -> 'a Key.t)\n -> (Base.Sexp.t -> 'b)\n -> Base.Sexp.t\n -> ('a, 'b, _) t_\n\n include\n Creators_generic\n with type ('a, 'b, 'c) t := ('a, 'b, 'c) t_\n with type ('a, 'b, 'c) tree := ('a, 'b, 'c) tree\n with type 'a key := 'a Key.t\n with type 'a cmp := Key.comparator_witness\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) options\nend = struct\n type ('a, 'b, 'c) options = ('a, 'b, 'c) Without_comparator.t\n\n let comparator = Key.comparator\n\n type ('a, 'b, 'c) t_ = ('a Key.t, 'b, Key.comparator_witness) t\n type ('a, 'b, 'c) tree = ('a, 'b, Key.comparator_witness) Tree.t\n\n module M_empty = Empty_without_value_restriction (Key)\n\n let empty = M_empty.empty\n let of_tree tree = Using_comparator.of_tree ~comparator tree\n let singleton k v = Using_comparator.singleton ~comparator k v\n\n let of_sorted_array_unchecked array =\n Using_comparator.of_sorted_array_unchecked ~comparator array\n ;;\n\n let of_sorted_array array = Using_comparator.of_sorted_array ~comparator array\n\n let of_increasing_iterator_unchecked ~len ~f =\n Using_comparator.of_increasing_iterator_unchecked ~comparator ~len ~f\n ;;\n\n let of_increasing_sequence seq =\n Using_comparator.of_increasing_sequence ~comparator seq\n ;;\n\n let of_sequence seq = Using_comparator.of_sequence ~comparator seq\n let of_sequence_or_error seq = Using_comparator.of_sequence_or_error ~comparator seq\n let of_sequence_exn seq = Using_comparator.of_sequence_exn ~comparator seq\n let of_sequence_multi seq = Using_comparator.of_sequence_multi ~comparator seq\n\n let of_sequence_fold seq ~init ~f =\n Using_comparator.of_sequence_fold ~comparator seq ~init ~f\n ;;\n\n let of_sequence_reduce seq ~f = Using_comparator.of_sequence_reduce ~comparator seq ~f\n let of_alist alist = Using_comparator.of_alist ~comparator alist\n let of_alist_or_error alist = Using_comparator.of_alist_or_error ~comparator alist\n let of_alist_exn alist = Using_comparator.of_alist_exn ~comparator alist\n let of_hashtbl_exn hashtbl = Using_comparator.of_hashtbl_exn ~comparator hashtbl\n let of_alist_multi alist = Using_comparator.of_alist_multi ~comparator alist\n\n let of_alist_fold alist ~init ~f =\n Using_comparator.of_alist_fold ~comparator alist ~init ~f\n ;;\n\n let of_alist_reduce alist ~f = Using_comparator.of_alist_reduce ~comparator alist ~f\n let of_iteri ~iteri = Using_comparator.of_iteri ~comparator ~iteri\n\n let t_of_sexp k_of_sexp v_of_sexp sexp =\n Using_comparator.t_of_sexp_direct ~comparator k_of_sexp v_of_sexp sexp\n ;;\n\n let of_key_set key_set ~f = Using_comparator.of_key_set key_set ~f\n\n let quickcheck_generator gen_k gen_v =\n Using_comparator.quickcheck_generator ~comparator gen_k gen_v\n ;;\nend\n\nmodule Make_tree (Key : Comparator.S1) = struct\n open Tree\n\n let comparator = Key.comparator\n let sexp_of_t = sexp_of_t\n let t_of_sexp a b c = t_of_sexp_direct a b c ~comparator\n let empty = empty_without_value_restriction\n let of_tree tree = tree\n let singleton a = singleton a ~comparator\n let of_sorted_array_unchecked a = of_sorted_array_unchecked a ~comparator\n let of_sorted_array a = of_sorted_array a ~comparator\n\n let of_increasing_iterator_unchecked ~len ~f =\n of_increasing_iterator_unchecked ~len ~f ~comparator\n ;;\n\n let of_increasing_sequence seq = of_increasing_sequence ~comparator seq\n let of_sequence s = of_sequence s ~comparator\n let of_sequence_or_error s = of_sequence_or_error s ~comparator\n let of_sequence_exn s = of_sequence_exn s ~comparator\n let of_sequence_multi s = of_sequence_multi s ~comparator\n let of_sequence_fold s ~init ~f = of_sequence_fold s ~init ~f ~comparator\n let of_sequence_reduce s ~f = of_sequence_reduce s ~f ~comparator\n let of_alist a = of_alist a ~comparator\n let of_alist_or_error a = of_alist_or_error a ~comparator\n let of_alist_exn a = of_alist_exn a ~comparator\n let of_hashtbl_exn a = Using_comparator.tree_of_hashtbl_exn a ~comparator\n let of_alist_multi a = of_alist_multi a ~comparator\n let of_alist_fold a ~init ~f = of_alist_fold a ~init ~f ~comparator\n let of_alist_reduce a ~f = of_alist_reduce a ~f ~comparator\n let of_iteri ~iteri = of_iteri ~iteri ~comparator\n let of_key_set = Using_comparator.tree_of_key_set\n let to_tree t = t\n let invariants a = invariants a ~comparator\n let is_empty a = is_empty a\n let length a = length a\n let set a ~key ~data = set a ~key ~data ~comparator\n let add a ~key ~data = add a ~key ~data ~comparator\n let add_exn a ~key ~data = add_exn a ~key ~data ~comparator\n let add_multi a ~key ~data = add_multi a ~key ~data ~comparator\n let remove_multi a b = remove_multi a b ~comparator\n let find_multi a b = find_multi a b ~comparator\n let change a b ~f = change a b ~f ~comparator\n let update a b ~f = update a b ~f ~comparator\n let find_exn a b = find_exn a b ~comparator\n let find a b = find a b ~comparator\n let remove a b = remove a b ~comparator\n let mem a b = mem a b ~comparator\n let iter_keys = iter_keys\n let iter = iter\n let iteri = iteri\n let iteri_until = iteri_until\n let iter2 a b ~f = iter2 a b ~f ~comparator\n let map = map\n let mapi = mapi\n let fold = fold\n let fold_right = fold_right\n let fold2 a b ~init ~f = fold2 a b ~init ~f ~comparator\n let filter_keys a ~f = filter_keys a ~f ~comparator\n let filter a ~f = filter a ~f ~comparator\n let filteri a ~f = filteri a ~f ~comparator\n let filter_map a ~f = filter_map a ~f ~comparator\n let filter_mapi a ~f = filter_mapi a ~f ~comparator\n let partition_mapi t ~f = partition_mapi t ~f ~comparator\n let partition_map t ~f = partition_map t ~f ~comparator\n let partitioni_tf t ~f = partitioni_tf t ~f ~comparator\n let partition_tf t ~f = partition_tf t ~f ~comparator\n let combine_errors t = combine_errors t ~comparator\n let compare_direct a b c = compare_direct a b c ~comparator\n let equal a b c = equal a b c ~comparator\n let keys = keys\n let data = data\n let to_alist = to_alist\n let validate = validate\n let validatei = validatei\n let symmetric_diff a b ~data_equal = symmetric_diff a b ~data_equal ~comparator\n\n let fold_symmetric_diff a b ~data_equal ~init ~f =\n fold_symmetric_diff a b ~data_equal ~f ~init ~comparator\n ;;\n\n let merge a b ~f = merge a b ~f ~comparator\n let min_elt = min_elt\n let min_elt_exn = min_elt_exn\n let max_elt = max_elt\n let max_elt_exn = max_elt_exn\n let for_all = for_all\n let for_alli = for_alli\n let exists = exists\n let existsi = existsi\n let count = count\n let counti = counti\n let split a b = split a b ~comparator\n let append ~lower_part ~upper_part = append ~lower_part ~upper_part ~comparator\n\n let subrange t ~lower_bound ~upper_bound =\n subrange t ~lower_bound ~upper_bound ~comparator\n ;;\n\n let fold_range_inclusive t ~min ~max ~init ~f =\n fold_range_inclusive t ~min ~max ~init ~f ~comparator\n ;;\n\n let range_to_alist t ~min ~max = range_to_alist t ~min ~max ~comparator\n let closest_key a b c = closest_key a b c ~comparator\n let nth a = nth a ~comparator\n let nth_exn a = nth_exn a ~comparator\n let rank a b = rank a b ~comparator\n\n let to_sequence ?order ?keys_greater_or_equal_to ?keys_less_or_equal_to t =\n to_sequence ~comparator ?order ?keys_greater_or_equal_to ?keys_less_or_equal_to t\n ;;\n\n let binary_search t ~compare how v = binary_search ~comparator t ~compare how v\n\n let binary_search_segmented t ~segment_of how =\n binary_search_segmented ~comparator t ~segment_of how\n ;;\n\n let key_set t = Using_comparator.key_set_of_tree ~comparator t\n let quickcheck_generator k v = For_quickcheck.gen_tree ~comparator k v\n let quickcheck_observer k v = For_quickcheck.obs_tree k v\n let quickcheck_shrinker k v = For_quickcheck.shr_tree ~comparator k v\nend\n\n(* Don't use [of_sorted_array] to avoid the allocation of an intermediate array *)\nlet init_for_bin_prot ~len ~f ~comparator =\n let map = Using_comparator.of_increasing_iterator_unchecked ~len ~f ~comparator in\n if invariants map\n then map\n else (\n (* The invariants are broken, but we can still traverse the structure. *)\n match Using_comparator.of_iteri ~iteri:(iteri map) ~comparator with\n | `Ok map -> map\n | `Duplicate_key _key -> failwith \"Map.bin_read_t: duplicate element in map\")\n;;\n\nmodule Poly = struct\n include Creators (Comparator.Poly)\n\n type ('a, 'b, 'c) map = ('a, 'b, 'c) t\n type ('k, 'v) t = ('k, 'v, Comparator.Poly.comparator_witness) map\n type comparator_witness = Comparator.Poly.comparator_witness\n\n include Accessors\n\n let compare _ cmpv t1 t2 = compare_direct cmpv t1 t2\n\n let sexp_of_t sexp_of_k sexp_of_v t =\n Using_comparator.sexp_of_t sexp_of_k sexp_of_v [%sexp_of: _] t\n ;;\n\n include Bin_prot.Utils.Make_iterable_binable2 (struct\n type nonrec ('a, 'b) t = ('a, 'b) t\n type ('a, 'b) el = 'a * 'b [@@deriving bin_io]\n\n let _ = bin_el\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"b7d7b1a0-4992-11e6-8a32-bbb221fa025c\"\n ;;\n\n let module_name = Some \"Core_kernel.Map\"\n let length = length\n let iter t ~f = iteri t ~f:(fun ~key ~data -> f (key, data))\n\n let init ~len ~next =\n init_for_bin_prot ~len ~f:(fun _ -> next ()) ~comparator:Comparator.Poly.comparator\n ;;\n end)\n\n module Tree = struct\n include Make_tree (Comparator.Poly)\n\n type ('k, +'v) t = ('k, 'v, Comparator.Poly.comparator_witness) tree\n type comparator_witness = Comparator.Poly.comparator_witness\n\n let sexp_of_t sexp_of_k sexp_of_v t = sexp_of_t sexp_of_k sexp_of_v [%sexp_of: _] t\n end\nend\n\nmodule type Key_plain = Key_plain\nmodule type Key = Key\nmodule type Key_binable = Key_binable\nmodule type Key_hashable = Key_hashable\nmodule type Key_binable_hashable = Key_binable_hashable\nmodule type S_plain = S_plain\nmodule type S = S\nmodule type S_binable = S_binable\n\nmodule Key_bin_io = Key_bin_io\n\nmodule Provide_bin_io (Key : Key_bin_io.S) =\n Bin_prot.Utils.Make_iterable_binable1 (struct\n module Key = Key\n\n type nonrec 'v t = (Key.t, 'v, Key.comparator_witness) t\n type 'v el = Key.t * 'v [@@deriving bin_io]\n\n let _ = bin_el\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"dfb300f8-4992-11e6-9c15-73a2ac6b815c\"\n ;;\n\n let module_name = Some \"Core_kernel.Map\"\n let length = length\n let iter t ~f = iteri t ~f:(fun ~key ~data -> f (key, data))\n\n let init ~len ~next =\n init_for_bin_prot ~len ~f:(fun _ -> next ()) ~comparator:Key.comparator\n ;;\n end)\n\nmodule Make_plain_using_comparator (Key : sig\n type t [@@deriving sexp_of]\n\n include Comparator.S with type t := t\n end) =\nstruct\n module Key = Key\n module Key_S1 = Comparator.S_to_S1 (Key)\n include Creators (Key_S1)\n\n type key = Key.t\n type ('a, 'b, 'c) map = ('a, 'b, 'c) t\n type 'v t = (key, 'v, Key.comparator_witness) map\n\n include Accessors\n\n let compare cmpv t1 t2 = compare_direct cmpv t1 t2\n\n let sexp_of_t sexp_of_v t =\n Using_comparator.sexp_of_t Key.sexp_of_t sexp_of_v [%sexp_of: _] t\n ;;\n\n module Provide_of_sexp\n (Key : sig\n type t [@@deriving of_sexp]\n end\n with type t := Key.t) =\n struct\n let t_of_sexp v_of_sexp sexp = t_of_sexp Key.t_of_sexp v_of_sexp sexp\n end\n\n module Provide_hash (Key' : Hasher.S with type t := Key.t) = struct\n let hash_fold_t (type a) hash_fold_data state (t : a t) =\n Using_comparator.hash_fold_direct Key'.hash_fold_t hash_fold_data state t\n ;;\n end\n\n module Provide_bin_io\n (Key' : sig\n type t [@@deriving bin_io]\n end\n with type t := Key.t) =\n Provide_bin_io (struct\n include Key\n include Key'\n end)\n\n module Tree = struct\n include Make_tree (Key_S1)\n\n type +'v t = (Key.t, 'v, Key.comparator_witness) tree\n\n let sexp_of_t sexp_of_v t = sexp_of_t Key.sexp_of_t sexp_of_v [%sexp_of: _] t\n\n module Provide_of_sexp\n (X : sig\n type t [@@deriving of_sexp]\n end\n with type t := Key.t) =\n struct\n let t_of_sexp v_of_sexp sexp = t_of_sexp X.t_of_sexp v_of_sexp sexp\n end\n end\nend\n\nmodule Make_plain (Key : Key_plain) = Make_plain_using_comparator (struct\n include Key\n include Comparator.Make (Key)\n end)\n\nmodule Make_using_comparator (Key_sexp : sig\n type t [@@deriving sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include Make_plain_using_comparator (Key_sexp)\n module Key = Key_sexp\n include Provide_of_sexp (Key)\n\n module Tree = struct\n include Tree\n include Provide_of_sexp (Key)\n end\nend\n\nmodule Make (Key : Key) = Make_using_comparator (struct\n include Key\n include Comparator.Make (Key)\n end)\n\nmodule Make_binable_using_comparator (Key_bin_sexp : sig\n type t [@@deriving bin_io, sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include Make_using_comparator (Key_bin_sexp)\n module Key = Key_bin_sexp\n include Provide_bin_io (Key)\nend\n\nmodule Make_binable (Key : Key_binable) = Make_binable_using_comparator (struct\n include Key\n include Comparator.Make (Key)\n end)\n\nmodule For_deriving = struct\n module M = Map.M\n\n let bin_shape_m__t (type t c) (m : (t, c) Key_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_shape_t\n ;;\n\n let bin_size_m__t (type t c) (m : (t, c) Key_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_size_t\n ;;\n\n let bin_write_m__t (type t c) (m : (t, c) Key_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_write_t\n ;;\n\n let bin_read_m__t (type t c) (m : (t, c) Key_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_read_t\n ;;\n\n let __bin_read_m__t__ (type t c) (m : (t, c) Key_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.__bin_read_t__\n ;;\n\n module type Quickcheck_generator_m = sig\n include Comparator.S\n\n val quickcheck_generator : t Quickcheck.Generator.t\n end\n\n module type Quickcheck_observer_m = sig\n include Comparator.S\n\n val quickcheck_observer : t Quickcheck.Observer.t\n end\n\n module type Quickcheck_shrinker_m = sig\n include Comparator.S\n\n val quickcheck_shrinker : t Quickcheck.Shrinker.t\n end\n\n let quickcheck_generator_m__t\n (type k cmp)\n (module Key : Quickcheck_generator_m\n with type t = k\n and type comparator_witness = cmp)\n v_generator\n =\n quickcheck_generator (module Key) Key.quickcheck_generator v_generator\n ;;\n\n let quickcheck_observer_m__t\n (type k cmp)\n (module Key : Quickcheck_observer_m\n with type t = k\n and type comparator_witness = cmp)\n v_observer\n =\n quickcheck_observer Key.quickcheck_observer v_observer\n ;;\n\n let quickcheck_shrinker_m__t\n (type k cmp)\n (module Key : Quickcheck_shrinker_m\n with type t = k\n and type comparator_witness = cmp)\n v_shrinker\n =\n quickcheck_shrinker Key.quickcheck_shrinker v_shrinker\n ;;\n\n module type For_deriving = Map.For_deriving\n\n include (Map : For_deriving with type ('a, 'b, 'c) t := ('a, 'b, 'c) t)\nend\n\ninclude For_deriving\n\nmodule Tree = struct\n include Tree\n\n let of_hashtbl_exn = Using_comparator.tree_of_hashtbl_exn\n let key_set = Using_comparator.key_set_of_tree\n let of_key_set = Using_comparator.tree_of_key_set\n let quickcheck_generator ~comparator k v = For_quickcheck.gen_tree ~comparator k v\n let quickcheck_observer k v = For_quickcheck.obs_tree k v\n let quickcheck_shrinker ~comparator k v = For_quickcheck.shr_tree ~comparator k v\nend\n\nmodule Stable = struct\n module V1 = struct\n type nonrec ('k, 'v, 'cmp) t = ('k, 'v, 'cmp) t\n\n module type S = sig\n type key\n type comparator_witness\n type nonrec 'a t = (key, 'a, comparator_witness) t\n\n include Stable_module_types.S1 with type 'a t := 'a t\n end\n\n module Make (Key : Stable_module_types.S0) = Make_binable_using_comparator (Key)\n end\n\n module Symmetric_diff_element = Symmetric_diff_element.Stable\nend\n","open! Import\nmodule List = List0\nopen Set_intf\nmodule Merge_to_sequence_element = Merge_to_sequence_element\nmodule Named = Named\n\nmodule type Elt_plain = Elt_plain\nmodule type Elt = Elt\nmodule type Elt_binable = Elt_binable\n\nlet to_comparator (type k cmp) ((module M) : (k, cmp) Set.comparator) = M.comparator\n\nlet of_comparator (type k cmp) comparator : (k, cmp) Set.comparator =\n (module struct\n type t = k\n type comparator_witness = cmp\n\n let comparator = comparator\n end)\n;;\n\nmodule For_quickcheck = struct\n let quickcheck_generator ~comparator elt_gen =\n Base_quickcheck.Generator.set_t_m (of_comparator comparator) elt_gen\n ;;\n\n let gen_tree ~comparator elt_gen =\n Base_quickcheck.Generator.set_tree_using_comparator ~comparator elt_gen\n ;;\n\n let quickcheck_observer elt_obs = Base_quickcheck.Observer.set_t elt_obs\n let obs_tree elt_obs = Base_quickcheck.Observer.set_tree elt_obs\n let quickcheck_shrinker elt_shr = Base_quickcheck.Shrinker.set_t elt_shr\n\n let shr_tree ~comparator elt_shr =\n Base_quickcheck.Shrinker.set_tree_using_comparator ~comparator elt_shr\n ;;\nend\n\nlet quickcheck_generator m elt_gen =\n For_quickcheck.quickcheck_generator ~comparator:(to_comparator m) elt_gen\n;;\n\nlet quickcheck_observer = For_quickcheck.quickcheck_observer\nlet quickcheck_shrinker = For_quickcheck.quickcheck_shrinker\n\nmodule Tree = struct\n include Tree\n\n let to_map ~comparator t = Map.of_key_set (Set.Using_comparator.of_tree t ~comparator)\n let of_map_keys m = Set.Using_comparator.to_tree (Map.key_set m)\n\n let of_hash_set ~comparator hset =\n Hash_set.fold hset ~init:(empty ~comparator) ~f:(fun t x -> add t x ~comparator)\n ;;\n\n let of_hashtbl_keys ~comparator hashtbl =\n Hashtbl.fold hashtbl ~init:(empty ~comparator) ~f:(fun ~key:x ~data:_ t ->\n add t x ~comparator)\n ;;\n\n let quickcheck_generator = For_quickcheck.gen_tree\n let quickcheck_observer = For_quickcheck.obs_tree\n let quickcheck_shrinker = For_quickcheck.shr_tree\nend\n\nmodule Accessors = struct\n include (\n Set.Using_comparator :\n Set.Accessors2\n with type ('a, 'b) t := ('a, 'b) Set.t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type ('a, 'b) named := ('a, 'b) Set.Named.t)\n\n let to_map = Map.of_key_set\n let quickcheck_observer = quickcheck_observer\n let quickcheck_shrinker = quickcheck_shrinker\nend\n\ntype 'a cmp = 'a\ntype 'a elt = 'a\n\ninclude (\nstruct\n include Set\n\n let of_tree m = Set.Using_comparator.of_tree ~comparator:(to_comparator m)\n let to_tree = Set.Using_comparator.to_tree\n let sexp_of_t = Set.Using_comparator.sexp_of_t\n\n module Empty_without_value_restriction =\n Set.Using_comparator.Empty_without_value_restriction\nend :\nsig\n type ('a, 'b) t = ('a, 'b) Set.t [@@deriving sexp_of]\n\n include\n Set.Creators_generic\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Set.With_first_class_module.t\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) set := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type 'a cmp := 'a cmp\n with type 'a elt := 'a elt\n\n include\n Set.Accessors2\n with type ('a, 'b) t := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) Tree.t\n with type ('a, 'b) named := ('a, 'b) Set.Named.t\n with module Named := Named\nend)\n\ntype ('k, 'cmp) comparator =\n (module Comparator.S with type t = 'k and type comparator_witness = 'cmp)\n\nlet compare _ _ t1 t2 = compare_direct t1 t2\n\nmodule Using_comparator = struct\n include (\n Set.Using_comparator :\n module type of struct\n include Set.Using_comparator\n end\n with module Tree := Set.Using_comparator.Tree)\n\n include For_quickcheck\n\n let of_map_keys = Map.key_set\n\n let of_hash_set ~comparator hset =\n of_tree ~comparator (Tree.of_hash_set hset ~comparator)\n ;;\n\n let of_hashtbl_keys ~comparator hashtbl =\n of_tree ~comparator (Tree.of_hashtbl_keys hashtbl ~comparator)\n ;;\nend\n\nlet to_map = Map.of_key_set\nlet of_map_keys = Map.key_set\nlet hash_fold_direct = Using_comparator.hash_fold_direct\nlet comparator = Using_comparator.comparator\nlet of_hash_set m hset = Using_comparator.of_hash_set ~comparator:(to_comparator m) hset\n\nlet of_hashtbl_keys m hashtbl =\n Using_comparator.of_hashtbl_keys ~comparator:(to_comparator m) hashtbl\n;;\n\nmodule Creators (Elt : Comparator.S1) : sig\n type nonrec ('a, 'comparator) t_ = ('a Elt.t, Elt.comparator_witness) t\n type ('a, 'b) tree = ('a, Elt.comparator_witness) Tree.t\n type 'a elt_ = 'a Elt.t\n type 'a cmp_ = Elt.comparator_witness\n\n val t_of_sexp : (Base.Sexp.t -> 'a Elt.t) -> Base.Sexp.t -> ('a, 'comparator) t_\n\n include\n Creators_generic\n with type ('a, 'b) t := ('a, 'b) t_\n with type ('a, 'b) set := ('a, 'b) t\n with type ('a, 'b) tree := ('a, 'b) tree\n with type 'a elt := 'a elt_\n with type ('a, 'b, 'c) options := ('a, 'b, 'c) Without_comparator.t\n with type 'a cmp := 'a cmp_\nend = struct\n open Using_comparator\n\n type nonrec ('a, 'comparator) t_ = ('a Elt.t, Elt.comparator_witness) t\n type ('a, 'b) tree = ('a, Elt.comparator_witness) Tree.t\n type 'a elt_ = 'a Elt.t\n type 'cmp cmp_ = Elt.comparator_witness\n\n let comparator = Elt.comparator\n let of_tree tree = of_tree ~comparator tree\n let of_sorted_array_unchecked array = of_sorted_array_unchecked ~comparator array\n\n let of_increasing_iterator_unchecked ~len ~f =\n of_increasing_iterator_unchecked ~comparator ~len ~f\n ;;\n\n let of_sorted_array array = of_sorted_array ~comparator array\n\n module M_empty = Empty_without_value_restriction (Elt)\n\n let empty = M_empty.empty\n let singleton e = singleton ~comparator e\n let union_list l = union_list ~comparator l\n let of_list l = of_list ~comparator l\n let of_hash_set h = of_hash_set ~comparator h\n let of_hashtbl_keys h = of_hashtbl_keys ~comparator h\n let of_array a = of_array ~comparator a\n let stable_dedup_list xs = stable_dedup_list ~comparator xs\n let map t ~f = map ~comparator t ~f\n let filter_map t ~f = filter_map ~comparator t ~f\n\n let t_of_sexp a_of_sexp sexp =\n of_tree (Tree.t_of_sexp_direct a_of_sexp sexp ~comparator)\n ;;\n\n let of_map_keys = Map.key_set\n let quickcheck_generator elt = quickcheck_generator ~comparator elt\nend\n\nmodule Make_tree (Elt : Comparator.S1) = struct\n let comparator = Elt.comparator\n let empty = Tree.empty_without_value_restriction\n let singleton e = Tree.singleton ~comparator e\n let invariants t = Tree.invariants t ~comparator\n let length t = Tree.length t\n let is_empty t = Tree.is_empty t\n let elements t = Tree.elements t\n let min_elt t = Tree.min_elt t\n let min_elt_exn t = Tree.min_elt_exn t\n let max_elt t = Tree.max_elt t\n let max_elt_exn t = Tree.max_elt_exn t\n let choose t = Tree.choose t\n let choose_exn t = Tree.choose_exn t\n let to_list t = Tree.to_list t\n let to_array t = Tree.to_array t\n let iter t ~f = Tree.iter t ~f\n let iter2 a b ~f = Tree.iter2 a b ~f ~comparator\n let exists t ~f = Tree.exists t ~f\n let for_all t ~f = Tree.for_all t ~f\n let count t ~f = Tree.count t ~f\n let sum m t ~f = Tree.sum m t ~f\n let find t ~f = Tree.find t ~f\n let find_exn t ~f = Tree.find_exn t ~f\n let find_map t ~f = Tree.find_map t ~f\n let fold t ~init ~f = Tree.fold t ~init ~f\n let fold_until t ~init ~f = Tree.fold_until t ~init ~f\n let fold_right t ~init ~f = Tree.fold_right t ~init ~f\n let fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\n let map t ~f = Tree.map t ~f ~comparator\n let filter t ~f = Tree.filter t ~f ~comparator\n let filter_map t ~f = Tree.filter_map t ~f ~comparator\n let partition_tf t ~f = Tree.partition_tf t ~f ~comparator\n let mem t a = Tree.mem t a ~comparator\n let add t a = Tree.add t a ~comparator\n let remove t a = Tree.remove t a ~comparator\n let union t1 t2 = Tree.union t1 t2 ~comparator\n let inter t1 t2 = Tree.inter t1 t2 ~comparator\n let diff t1 t2 = Tree.diff t1 t2 ~comparator\n let symmetric_diff t1 t2 = Tree.symmetric_diff t1 t2 ~comparator\n let compare_direct t1 t2 = Tree.compare_direct ~comparator t1 t2\n let equal t1 t2 = Tree.equal t1 t2 ~comparator\n let is_subset t ~of_ = Tree.is_subset t ~of_ ~comparator\n let are_disjoint t1 t2 = Tree.are_disjoint t1 t2 ~comparator\n let of_list l = Tree.of_list l ~comparator\n let of_hash_set h = Tree.of_hash_set h ~comparator\n let of_hashtbl_keys h = Tree.of_hashtbl_keys h ~comparator\n let of_array a = Tree.of_array a ~comparator\n let of_sorted_array_unchecked a = Tree.of_sorted_array_unchecked a ~comparator\n\n let of_increasing_iterator_unchecked ~len ~f =\n Tree.of_increasing_iterator_unchecked ~len ~f ~comparator\n ;;\n\n let of_sorted_array a = Tree.of_sorted_array a ~comparator\n let union_list l = Tree.union_list l ~comparator\n let stable_dedup_list xs = Tree.stable_dedup_list xs ~comparator\n let group_by t ~equiv = Tree.group_by t ~equiv ~comparator\n let split t a = Tree.split t a ~comparator\n let nth t i = Tree.nth t i\n let remove_index t i = Tree.remove_index t i ~comparator\n let to_tree t = t\n let of_tree t = t\n\n let to_sequence ?order ?greater_or_equal_to ?less_or_equal_to t =\n Tree.to_sequence ~comparator ?order ?greater_or_equal_to ?less_or_equal_to t\n ;;\n\n let binary_search t ~compare how v = Tree.binary_search ~comparator t ~compare how v\n\n let binary_search_segmented t ~segment_of how =\n Tree.binary_search_segmented ~comparator t ~segment_of how\n ;;\n\n let merge_to_sequence ?order ?greater_or_equal_to ?less_or_equal_to t t' =\n Tree.merge_to_sequence ~comparator ?order ?greater_or_equal_to ?less_or_equal_to t t'\n ;;\n\n let of_map_keys = Tree.of_map_keys\n let to_map t ~f = Tree.to_map ~comparator t ~f\n\n module Named = struct\n let is_subset t ~of_ = Tree.Named.is_subset t ~of_ ~comparator\n let equal t1 t2 = Tree.Named.equal t1 t2 ~comparator\n end\n\n let quickcheck_generator elt = For_quickcheck.gen_tree elt ~comparator\n let quickcheck_observer elt = For_quickcheck.obs_tree elt\n let quickcheck_shrinker elt = For_quickcheck.shr_tree elt ~comparator\nend\n\n(* Don't use [of_sorted_array] to avoid the allocation of an intermediate array *)\nlet init_for_bin_prot ~len ~f ~comparator =\n let set = Using_comparator.of_increasing_iterator_unchecked ~comparator ~len ~f in\n if invariants set\n then set\n else\n Using_comparator.of_tree\n ~comparator\n (fold set ~init:(Tree.empty ~comparator) ~f:(fun acc elt ->\n if Tree.mem acc elt ~comparator\n then failwith \"Set.bin_read_t: duplicate element in map\"\n else Tree.add acc elt ~comparator))\n;;\n\nmodule Poly = struct\n module Elt = Comparator.Poly\n include Creators (Elt)\n\n type nonrec 'a t = ('a, Elt.comparator_witness) t\n type 'a named = ('a, Elt.comparator_witness) Named.t\n\n include Accessors\n\n let compare _ t1 t2 = compare_direct t1 t2\n let sexp_of_t sexp_of_k t = sexp_of_t sexp_of_k [%sexp_of: _] t\n\n include Bin_prot.Utils.Make_iterable_binable1 (struct\n type nonrec 'a t = 'a t\n type 'a el = 'a [@@deriving bin_io]\n\n let _ = bin_el\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"88bcc478-4992-11e6-a95d-ff4831acf410\"\n ;;\n\n let module_name = Some \"Core_kernel.Set\"\n let length = length\n let iter t ~f = iter ~f:(fun key -> f key) t\n\n let init ~len ~next =\n init_for_bin_prot ~len ~f:(fun _ -> next ()) ~comparator:Comparator.Poly.comparator\n ;;\n end)\n\n module Tree = struct\n include Make_tree (Comparator.Poly)\n\n type 'elt t = ('elt, Comparator.Poly.comparator_witness) tree\n type 'a named = ('a, Elt.comparator_witness) Tree.Named.t\n\n let sexp_of_t sexp_of_elt t = Tree.sexp_of_t sexp_of_elt [%sexp_of: _] t\n\n let t_of_sexp elt_of_sexp sexp =\n Tree.t_of_sexp_direct elt_of_sexp sexp ~comparator:Comparator.Poly.comparator\n ;;\n end\nend\n\nmodule type S_plain = S_plain\nmodule type S = S\nmodule type S_binable = S_binable\n\nmodule Elt_bin_io = Elt_bin_io\n\nmodule Provide_bin_io (Elt : Elt_bin_io.S) = Bin_prot.Utils.Make_iterable_binable (struct\n type nonrec t = (Elt.t, Elt.comparator_witness) t\n type el = Elt.t [@@deriving bin_io]\n\n let _ = bin_el\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"8989278e-4992-11e6-8f4a-6b89776b1e53\"\n ;;\n\n let module_name = Some \"Core_kernel.Set\"\n let length = length\n let iter t ~f = iter ~f:(fun key -> f key) t\n\n let init ~len ~next =\n init_for_bin_prot ~len ~f:(fun _ -> next ()) ~comparator:Elt.comparator\n ;;\n end)\n\nmodule Make_plain_using_comparator (Elt : sig\n type t [@@deriving sexp_of]\n\n include Comparator.S with type t := t\n end) =\nstruct\n module Elt = Elt\n module Elt_S1 = Comparator.S_to_S1 (Elt)\n include Creators (Elt_S1)\n\n type ('a, 'b) set = ('a, 'b) t\n type t = (Elt.t, Elt.comparator_witness) set\n type named = (Elt.t, Elt.comparator_witness) Named.t\n\n include Accessors\n\n let compare t1 t2 = compare_direct t1 t2\n let sexp_of_t t = sexp_of_t Elt.sexp_of_t [%sexp_of: _] t\n\n module Provide_of_sexp\n (Elt : sig\n type t [@@deriving of_sexp]\n end\n with type t := Elt.t) =\n struct\n let t_of_sexp sexp = t_of_sexp Elt.t_of_sexp sexp\n end\n\n module Provide_hash (Elt : Hasher.S with type t := Elt.t) = struct\n let hash_fold_t state t = Using_comparator.hash_fold_direct Elt.hash_fold_t state t\n\n let hash t =\n Ppx_hash_lib.Std.Hash.get_hash_value\n (hash_fold_t (Ppx_hash_lib.Std.Hash.create ()) t)\n ;;\n end\n\n module Provide_bin_io\n (Elt' : sig\n type t [@@deriving bin_io]\n end\n with type t := Elt.t) =\n Provide_bin_io (struct\n include Elt\n include Elt'\n end)\n\n module Tree = struct\n include Make_tree (Elt_S1)\n\n type t = (Elt.t, Elt.comparator_witness) tree\n type named = (Elt.t, Elt.comparator_witness) Tree.Named.t\n\n let compare t1 t2 = compare_direct t1 t2\n let sexp_of_t t = Tree.sexp_of_t Elt.sexp_of_t [%sexp_of: _] t\n\n module Provide_of_sexp\n (X : sig\n type t [@@deriving of_sexp]\n end\n with type t := Elt.t) =\n struct\n let t_of_sexp sexp =\n Tree.t_of_sexp_direct X.t_of_sexp sexp ~comparator:Elt_S1.comparator\n ;;\n end\n end\nend\n\nmodule Make_plain (Elt : Elt_plain) = Make_plain_using_comparator (struct\n include Elt\n include Comparator.Make (Elt)\n end)\n\nmodule Make_using_comparator (Elt_sexp : sig\n type t [@@deriving sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include Make_plain_using_comparator (Elt_sexp)\n module Elt = Elt_sexp\n include Provide_of_sexp (Elt)\n\n module Tree = struct\n include Tree\n include Provide_of_sexp (Elt)\n end\nend\n\nmodule Make (Elt : Elt) = Make_using_comparator (struct\n include Elt\n include Comparator.Make (Elt)\n end)\n\nmodule Make_binable_using_comparator (Elt_bin_sexp : sig\n type t [@@deriving bin_io, sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include Make_using_comparator (Elt_bin_sexp)\n module Elt = Elt_bin_sexp\n include Provide_bin_io (Elt)\nend\n\nmodule Make_binable (Elt : Elt_binable) = Make_binable_using_comparator (struct\n include Elt\n include Comparator.Make (Elt)\n end)\n\nmodule For_deriving = struct\n module M = Set.M\n\n let bin_shape_m__t (type t c) (m : (t, c) Elt_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_shape_t\n ;;\n\n let bin_size_m__t (type t c) (m : (t, c) Elt_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_size_t\n ;;\n\n let bin_write_m__t (type t c) (m : (t, c) Elt_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_write_t\n ;;\n\n let bin_read_m__t (type t c) (m : (t, c) Elt_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.bin_read_t\n ;;\n\n let __bin_read_m__t__ (type t c) (m : (t, c) Elt_bin_io.t) =\n let module M = Provide_bin_io ((val m)) in\n M.__bin_read_t__\n ;;\n\n module type Quickcheck_generator_m = sig\n include Comparator.S\n\n val quickcheck_generator : t Quickcheck.Generator.t\n end\n\n module type Quickcheck_observer_m = sig\n include Comparator.S\n\n val quickcheck_observer : t Quickcheck.Observer.t\n end\n\n module type Quickcheck_shrinker_m = sig\n include Comparator.S\n\n val quickcheck_shrinker : t Quickcheck.Shrinker.t\n end\n\n let quickcheck_generator_m__t\n (type t cmp)\n (module Elt : Quickcheck_generator_m\n with type t = t\n and type comparator_witness = cmp)\n =\n quickcheck_generator (module Elt) Elt.quickcheck_generator\n ;;\n\n let quickcheck_observer_m__t\n (type t cmp)\n (module Elt : Quickcheck_observer_m\n with type t = t\n and type comparator_witness = cmp)\n =\n quickcheck_observer Elt.quickcheck_observer\n ;;\n\n let quickcheck_shrinker_m__t\n (type t cmp)\n (module Elt : Quickcheck_shrinker_m\n with type t = t\n and type comparator_witness = cmp)\n =\n quickcheck_shrinker Elt.quickcheck_shrinker\n ;;\n\n module type For_deriving = Set.For_deriving\n\n include (Set : For_deriving with type ('a, 'b) t := ('a, 'b) t)\nend\n\ninclude For_deriving\n\nmodule Stable = struct\n module V1 = struct\n type nonrec ('a, 'cmp) t = ('a, 'cmp) t\n\n module type S = sig\n type elt\n type elt_comparator_witness\n type nonrec t = (elt, elt_comparator_witness) t\n\n include Stable_module_types.S0_without_comparator with type t := t\n end\n\n include For_deriving\n module Make (Elt : Stable_module_types.S0) = Make_binable_using_comparator (Elt)\n end\nend\n","open! Import\nmodule List = Base.List\ninclude Comparable_intf\nmodule Infix = Base.Comparable.Infix\nmodule Polymorphic_compare = Base.Comparable.Polymorphic_compare\nmodule Validate = Base.Comparable.Validate\n\nmodule With_zero (T : sig\n type t [@@deriving compare, sexp]\n\n val zero : t\n\n include Validate with type t := t\n end) =\n Base.Comparable.With_zero (T)\n\nmodule Validate_with_zero (T : sig\n type t [@@deriving compare, sexp]\n\n val zero : t\n end) =\n Base.Comparable.Validate_with_zero (T)\n\nmodule Map_and_set_binable_using_comparator (T : sig\n type t [@@deriving bin_io, compare, sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include T\n module Map = Map.Make_binable_using_comparator (T)\n module Set = Set.Make_binable_using_comparator (T)\nend\n\nmodule Map_and_set_binable (T : sig\n type t [@@deriving bin_io, compare, sexp]\n end) =\n Map_and_set_binable_using_comparator (struct\n include T\n include Comparator.Make (T)\n end)\n\nmodule Poly (T : sig\n type t [@@deriving sexp]\n end) =\nstruct\n module C = struct\n include T\n include Base.Comparable.Poly (T)\n end\n\n include C\n module Replace_polymorphic_compare : Polymorphic_compare with type t := t = C\n module Map = Map.Make_using_comparator (C)\n module Set = Set.Make_using_comparator (C)\nend\n\nmodule Make_plain_using_comparator (T : sig\n type t [@@deriving sexp_of]\n\n include Comparator.S with type t := t\n end) : S_plain with type t := T.t and type comparator_witness = T.comparator_witness =\nstruct\n include T\n module M = Base.Comparable.Make_using_comparator (T)\n include M\n module Replace_polymorphic_compare : Polymorphic_compare with type t := t = M\n module Map = Map.Make_plain_using_comparator (T)\n module Set = Set.Make_plain_using_comparator (T)\nend\n\nmodule Make_plain (T : sig\n type t [@@deriving compare, sexp_of]\n end) =\n Make_plain_using_comparator (struct\n include T\n include Comparator.Make (T)\n end)\n\nmodule Make_using_comparator (T : sig\n type t [@@deriving sexp]\n\n include Comparator.S with type t := t\n end) : S with type t := T.t and type comparator_witness = T.comparator_witness = struct\n include T\n module M = Base.Comparable.Make_using_comparator (T)\n include M\n module Replace_polymorphic_compare : Polymorphic_compare with type t := t = M\n module Map = Map.Make_using_comparator (T)\n module Set = Set.Make_using_comparator (T)\nend\n\nmodule Make (T : sig\n type t [@@deriving compare, sexp]\n end) : S with type t := T.t = Make_using_comparator (struct\n include T\n include Comparator.Make (T)\n end)\n\nmodule Make_binable_using_comparator (T : sig\n type t [@@deriving bin_io, sexp]\n\n include Comparator.S with type t := t\n end) =\nstruct\n include T\n module M = Base.Comparable.Make_using_comparator (T)\n include M\n module Replace_polymorphic_compare : Polymorphic_compare with type t := t = M\n module Map = Map.Make_binable_using_comparator (T)\n module Set = Set.Make_binable_using_comparator (T)\nend\n\nmodule Make_binable (T : sig\n type t [@@deriving bin_io, compare, sexp]\n end) =\n Make_binable_using_comparator (struct\n include T\n include Comparator.Make (T)\n end)\n\nmodule Extend\n (M : Base.Comparable.S) (X : sig\n type t = M.t [@@deriving sexp]\n end) =\nstruct\n module T = struct\n include M\n\n include (\n X :\n sig\n type t = M.t [@@deriving sexp]\n end\n with type t := t)\n end\n\n include T\n module Replace_polymorphic_compare : Comparisons.S with type t := t = M\n module Map = Map.Make_using_comparator (T)\n module Set = Set.Make_using_comparator (T)\nend\n\nmodule Extend_binable\n (M : Base.Comparable.S) (X : sig\n type t = M.t [@@deriving bin_io, sexp]\n end) =\nstruct\n module T = struct\n include M\n\n include (\n X :\n sig\n type t = M.t [@@deriving bin_io, sexp]\n end\n with type t := t)\n end\n\n include T\n module Replace_polymorphic_compare : Comparisons.S with type t := t = M\n module Map = Map.Make_binable_using_comparator (T)\n module Set = Set.Make_binable_using_comparator (T)\nend\n\nmodule Inherit (C : sig\n type t [@@deriving compare]\n end) (T : sig\n type t [@@deriving sexp]\n\n val component : t -> C.t\n end) =\n Make (struct\n type t = T.t [@@deriving sexp]\n\n let compare t t' = C.compare (T.component t) (T.component t')\n end)\n\nlet lexicographic = Base.Comparable.lexicographic\nlet lift = Base.Comparable.lift\nlet reverse = Base.Comparable.reverse\n\nmodule Stable = struct\n module V1 = struct\n module type S = sig\n type comparable\n type comparator_witness\n\n module Map :\n Map.Stable.V1.S\n with type key := comparable\n with type comparator_witness := comparator_witness\n\n module Set :\n Set.Stable.V1.S\n with type elt := comparable\n with type elt_comparator_witness := comparator_witness\n end\n\n module Make (X : Stable_module_types.S0) = struct\n module Map = Map.Stable.V1.Make (X)\n module Set = Set.Stable.V1.Make (X)\n end\n end\nend\n","(** Doubly-linked lists.\n\n Compared to other doubly-linked lists, in this one:\n\n 1. Calls to modification functions ([insert*], [move*], ...) detect if the list is\n being iterated over ([iter], [fold], ...), and if so raise an exception. For example,\n a use like the following would raise:\n\n {[\n iter t ~f:(fun _ -> ... remove t e ...)\n ]}\n\n 2. There is a designated \"front\" and \"back\" of each list, rather than viewing each\n element as an equal in a ring.\n\n 3. Elements know which list they're in. Each operation that takes an [Elt.t] also\n takes a [t], first checks that the [Elt] belongs to the [t], and if not, raises.\n\n 4. Related to (3), lists cannot be split, though a sort of splicing is available as\n [transfer]. In other words, no operation will cause one list to become two. This\n makes this module unsuitable for maintaining the faces of a planar graph under edge\n insertion and deletion, for example.\n\n 5. Another property permitted by (3) and (4) is that [length] is O(1).\n*)\n\nopen! Import\n\nmodule type S = sig\n module Elt : sig\n type 'a t\n\n val value : 'a t -> 'a\n\n (** pointer equality *)\n val equal : 'a t -> 'a t -> bool\n\n val set : 'a t -> 'a -> unit\n val sexp_of_t : ('a -> Base.Sexp.t) -> 'a t -> Base.Sexp.t\n end\n\n type 'a t [@@deriving compare, sexp]\n\n include Container.S1 with type 'a t := 'a t\n include Invariant.S1 with type 'a t := 'a t\n\n (** {2 Creating doubly-linked lists} *)\n\n val create : unit -> 'a t\n\n (** [of_list l] returns a doubly-linked list [t] with the same elements as [l] and in the\n same order (i.e., the first element of [l] is the first element of [t]). It is always\n the case that [l = to_list (of_list l)]. *)\n val of_list : 'a list -> 'a t\n\n val of_array : 'a array -> 'a t\n\n (** {2 Predicates} *)\n\n (** pointer equality *)\n val equal : 'a t -> 'a t -> bool\n\n val is_first : 'a t -> 'a Elt.t -> bool\n val is_last : 'a t -> 'a Elt.t -> bool\n val mem_elt : 'a t -> 'a Elt.t -> bool\n\n (** {2 Constant-time extraction of first and last elements} *)\n\n val first_elt : 'a t -> 'a Elt.t option\n val last_elt : 'a t -> 'a Elt.t option\n val first : 'a t -> 'a option\n val last : 'a t -> 'a option\n\n (** {2 Constant-time retrieval of next or previous element} *)\n\n val next : 'a t -> 'a Elt.t -> 'a Elt.t option\n val prev : 'a t -> 'a Elt.t -> 'a Elt.t option\n\n (** {2 Constant-time insertion of a new element} *)\n\n val insert_before : 'a t -> 'a Elt.t -> 'a -> 'a Elt.t\n val insert_after : 'a t -> 'a Elt.t -> 'a -> 'a Elt.t\n val insert_first : 'a t -> 'a -> 'a Elt.t\n val insert_last : 'a t -> 'a -> 'a Elt.t\n\n (** {2 Constant-time move of an element from and to positions in the same list}\n\n An exception is raised if [elt] is equal to [anchor]. *)\n\n val move_to_front : 'a t -> 'a Elt.t -> unit\n val move_to_back : 'a t -> 'a Elt.t -> unit\n val move_after : 'a t -> 'a Elt.t -> anchor:'a Elt.t -> unit\n val move_before : 'a t -> 'a Elt.t -> anchor:'a Elt.t -> unit\n\n (** {2 Constant-time removal of an element} *)\n\n val remove : 'a t -> 'a Elt.t -> unit\n val remove_first : 'a t -> 'a option\n val remove_last : 'a t -> 'a option\n val iteri : 'a t -> f:(int -> 'a -> unit) -> unit\n val foldi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b) -> 'b\n\n (** [fold_elt t ~init ~f] is the same as fold, except [f] is called with the ['a Elt.t]'s\n from the list instead of the contained ['a] values.\n\n Note that like other iteration functions, it is an error to mutate [t] inside the\n fold. If you'd like to call [remove] on any of the ['a Elt.t]'s, use\n [filter_inplace]. *)\n val fold_elt : 'a t -> init:'b -> f:('b -> 'a Elt.t -> 'b) -> 'b\n\n val foldi_elt : 'a t -> init:'b -> f:(int -> 'b -> 'a Elt.t -> 'b) -> 'b\n val iter_elt : 'a t -> f:('a Elt.t -> unit) -> unit\n val iteri_elt : 'a t -> f:(int -> 'a Elt.t -> unit) -> unit\n\n\n val fold_right : 'a t -> init:'b -> f:('a -> 'b -> 'b) -> 'b\n val fold_right_elt : 'a t -> init:'b -> f:('a Elt.t -> 'b -> 'b) -> 'b\n\n (** [find_elt t ~f] finds the first element in [t] that satisfies [f], by testing each of\n element of [t] in turn until [f] succeeds. *)\n val find_elt : 'a t -> f:('a -> bool) -> 'a Elt.t option\n\n val findi_elt : 'a t -> f:(int -> 'a -> bool) -> (int * 'a Elt.t) option\n\n (** [clear t] removes all elements from the list in constant time. *)\n val clear : 'a t -> unit\n\n val copy : 'a t -> 'a t\n\n (** [transfer ~src ~dst] has the same behavior as\n [iter src ~f:(insert_last dst); clear src] except that it runs in constant time.\n\n If [s = to_list src] and [d = to_list dst], then after [transfer ~src ~dst]:\n\n [to_list src = []]\n\n [to_list dst = d @ s] *)\n val transfer : src:'a t -> dst:'a t -> unit\n\n (** {2 Linear-time mapping of lists (creates a new list)} *)\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n val mapi : 'a t -> f:(int -> 'a -> 'b) -> 'b t\n val filter : 'a t -> f:('a -> bool) -> 'a t\n val filteri : 'a t -> f:(int -> 'a -> bool) -> 'a t\n val filter_map : 'a t -> f:('a -> 'b option) -> 'b t\n val filter_mapi : 'a t -> f:(int -> 'a -> 'b option) -> 'b t\n\n (** {2 Linear-time partition of lists (creates two new lists)} *)\n\n val partition_tf : 'a t -> f:('a -> bool) -> 'a t * 'a t\n val partitioni_tf : 'a t -> f:(int -> 'a -> bool) -> 'a t * 'a t\n val partition_map : 'a t -> f:('a -> ('b, 'c) Either.t) -> 'b t * 'c t\n val partition_mapi : 'a t -> f:(int -> 'a -> ('b, 'c) Either.t) -> 'b t * 'c t\n\n (** {2 Linear-time in-place mapping of lists} *)\n\n (** [map_inplace t ~f] replaces all values [v] with [f v] *)\n val map_inplace : 'a t -> f:('a -> 'a) -> unit\n\n val mapi_inplace : 'a t -> f:(int -> 'a -> 'a) -> unit\n\n (** [filter_inplace t ~f] removes all elements of [t] that don't satisfy [f]. *)\n val filter_inplace : 'a t -> f:('a -> bool) -> unit\n\n val filteri_inplace : 'a t -> f:(int -> 'a -> bool) -> unit\n\n (** If [f] returns [None], the element is removed, else the value is replaced with the\n contents of the [Some] *)\n val filter_map_inplace : 'a t -> f:('a -> 'a option) -> unit\n\n val filter_mapi_inplace : 'a t -> f:(int -> 'a -> 'a option) -> unit\n\n (** [unchecked_iter t ~f] behaves like [iter t ~f] except that [f] is allowed to modify\n [t]. Adding or removing elements before the element currently being visited has no\n effect on the traversal. Elements added after the element currently being visited\n will be traversed. Elements deleted after the element currently being visited will\n not be traversed. Deleting the element currently being visited is an error that is not\n detected (presumably leading to an infinite loop). *)\n val unchecked_iter : 'a t -> f:('a -> unit) -> unit\n\n\n (** A sequence of values from the doubly-linked list. It makes an intermediate copy of the\n list so that the returned sequence is immune to any subsequent mutation of the\n original list. *)\n val to_sequence : 'a t -> 'a Sequence.t\nend\n\nmodule type Doubly_linked = sig\n module type S = S\n\n include S\nend\n","include List0 (** @inline *)\n\n(** [stable_dedup] Same as [dedup] but maintains the order of the list and doesn't allow\n compare function to be specified (otherwise, the implementation in terms of Set.t\n would hide a heavyweight functor instantiation at each call). *)\nlet stable_dedup = Set.Poly.stable_dedup_list\n\n(* This function is staged to indicate that real work (the functor application) takes\n place after a partial application. *)\nlet stable_dedup_staged (type a) ~(compare : a -> a -> int)\n : (a list -> a list) Base.Staged.t\n =\n let module Set =\n Set.Make (struct\n type t = a\n\n let compare = compare\n\n (* [stable_dedup_list] never calls these *)\n let t_of_sexp _ = assert false\n let sexp_of_t _ = assert false\n end)\n in\n Base.Staged.stage Set.stable_dedup_list\n;;\n\nlet zip_with_remainder =\n let rec zip_with_acc_and_remainder acc xs ys =\n match xs, ys with\n | [], [] -> rev acc, None\n | fst, [] -> rev acc, Some (Either.First fst)\n | [], snd -> rev acc, Some (Either.Second snd)\n | x :: xs, y :: ys -> zip_with_acc_and_remainder ((x, y) :: acc) xs ys\n in\n fun xs ys -> zip_with_acc_and_remainder [] xs ys\n;;\n\ntype sexp_thunk = unit -> Base.Sexp.t\n\nlet sexp_of_sexp_thunk x = x ()\n\nexception Duplicate_found of sexp_thunk * Base.String.t [@@deriving sexp]\n\nlet exn_if_dup ~compare ?(context = \"exn_if_dup\") t ~to_sexp =\n match find_a_dup ~compare t with\n | None -> ()\n | Some dup -> raise (Duplicate_found ((fun () -> to_sexp dup), context))\n;;\n\nlet slice a start stop =\n Ordered_collection_common.slice ~length_fun:length ~sub_fun:sub a start stop\n;;\n\nmodule Stable = struct\n module V1 = struct\n type nonrec 'a t = 'a t [@@deriving sexp, bin_io, compare]\n end\nend\n","open! Import\ninclude Base.Option\n\ntype 'a t = 'a option [@@deriving bin_io, typerep]\n\ninclude Comparator.Derived (struct\n type nonrec 'a t = 'a t [@@deriving sexp_of, compare]\n end)\n\nlet quickcheck_generator = Base_quickcheck.Generator.option\nlet quickcheck_observer = Base_quickcheck.Observer.option\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.option\n\nmodule Stable = struct\n module V1 = struct\n type nonrec 'a t = 'a t [@@deriving bin_io, compare, equal, sexp]\n end\nend\n\nmodule Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n\n (* [unsafe_value] is only safe to call when [is_none] returns [false]. To avoid\n repeating the [is_none] check, we declare [Unchecked_some]. [Unchecked_some x]\n has the same representation as [Some x], but the type has no [None] clause.\n\n We make sure all this works with tests of [unsafe_value] in test_option.ml.\n\n We tried using [Obj.field] instead. It generates much worse native code due to\n float array representations. *)\n\n module Unchecked_some = struct\n (* Warning 37 tells us [Unchecked_some] is never used as a constructor. This is\n intentional, so we disable the warning. *)\n type 'a t = Unchecked_some of 'a [@@ocaml.boxed] [@@ocaml.warning \"-37\"]\n end\n\n let unsafe_value (type a) (t : a t) : a =\n let (Unchecked_some value) = (Obj.magic t : a Unchecked_some.t) in\n value\n ;;\n end\nend\n","(* This code is based on the MLton library set/disjoint.fun, which has the\n following copyright notice.\n*)\n(* Copyright (C) 1999-2005 Henry Cejtin, Matthew Fluet, Suresh\n * Jagannathan, and Stephen Weeks.\n *\n * MLton is released under a BSD-style license.\n * See the file MLton-LICENSE for details.\n*)\n\nopen! Import\n\n(*\n {v\n Root\n |\n Inner\n / .. | .. \\\n Inner Inner Inner\n /|\\ /|\\ /|\\\n ... ... ...\n v}\n\n We construct the `inverted' tree in the ML representation.\n The direction of the edges is UPWARDS.\n Starting with any ['a t] we can step directly to its parent.\n But we can't (and don't need to) start from the root and step to its children.\n*)\n\n(*\n [rank] is an upper bound on the depth of any node in the up-tree.\n\n Imagine an unlucky sequence of operations in which you create N\n individual [t]-values and then union them together in such a way\n that you always pick the root of each tree to union together, so that\n no path compression takes place. If you don't take care to somehow\n balance the resulting up-tree, it is possible that you end up with one\n big long chain of N links, and then calling [representative] on the\n deepest node takes Theta(N) time. With the balancing scheme of never\n increasing the rank of a node unnecessarily, it would take O(log N).\n*)\ntype 'a root =\n { mutable value : 'a\n ; mutable rank : int\n }\n\ntype 'a t = { mutable node : 'a node }\n\nand 'a node =\n | Inner of 'a t\n (* [Inner x] is a node whose parent is [x]. *)\n | Root of 'a root\n\nlet invariant _ t =\n let rec loop t depth =\n match t.node with\n | Inner t -> loop t (depth + 1)\n | Root r -> assert (depth <= r.rank)\n in\n loop t 0\n;;\n\nlet create v = { node = Root { value = v; rank = 0 } }\n\n(* invariants:\n [inner.node] = [inner_node] = [Inner t].\n [descendants] are the proper descendants of [inner] we've visited.\n*)\nlet rec compress t ~inner_node ~inner ~descendants =\n match t.node with\n | Root r ->\n (* t is the root of the tree.\n Re-point all descendants directly to it by setting them to [Inner t].\n Note: we don't re-point [inner] as it already points there. *)\n List.iter descendants ~f:(fun t -> t.node <- inner_node);\n t, r\n | Inner t' as node ->\n compress t' ~inner_node:node ~inner:t ~descendants:(inner :: descendants)\n;;\n\nlet representative t =\n match t.node with\n | Root r -> t, r\n | Inner t' as node -> compress t' ~inner_node:node ~inner:t ~descendants:[]\n;;\n\nlet root t =\n match t.node with\n | Root r ->\n (* avoid tuple allocation in the fast path *)\n r\n | _ -> snd (representative t)\n;;\n\nlet rank t = (root t).rank\nlet get t = (root t).value\nlet set t v = (root t).value <- v\nlet same_class t1 t2 = phys_equal (root t1) (root t2)\n\nlet union t1 t2 =\n let t1, r1 = representative t1 in\n let t2, r2 = representative t2 in\n if phys_equal r1 r2\n then ()\n else (\n let n1 = r1.rank in\n let n2 = r2.rank in\n if n1 < n2\n then t1.node <- Inner t2\n else (\n t2.node <- Inner t1;\n if n1 = n2 then r1.rank <- r1.rank + 1))\n;;\n\nlet is_compressed t =\n invariant ignore t;\n match t.node with\n | Root _ -> true\n | Inner t ->\n (match t.node with\n | Root _ -> true\n | Inner _ -> false)\n;;\n\nmodule Private = struct\n let is_compressed = is_compressed\n let rank = rank\nend\n","open! Import\ninclude Doubly_linked_intf\n\n(* INVARIANT: This exception is raised if a list is mutated during a pending iteration.\n\n This invariant is guaranteed by the Header and Elt modules in conjunction. All\n downstream code in this module need not be concerned with this invariant.\n*)\nexception Attempt_to_mutate_list_during_iteration\n\nlet phys_equal = ( == )\n\nmodule Header : sig\n type t\n\n val create : unit -> t\n val length : t -> int\n val equal : t -> t -> bool\n val incr_length : by:int -> t -> unit\n val check_no_pending_iterations : t -> unit\n\n (* Unfortunate, but by specializing [with_iteration] for different arities, a large\n amount of allocation during folds and iterations is avoided.\n\n The original type of [with_iteration] was\n [val with_iteration : t -> (unit -> 'a) -> 'a]\n\n The difference between\n {[\n let x = e in\n let f () = g x in\n f ()\n ]}\n and\n {[\n let x = e in\n let f x = g x in\n f x\n ]}\n is that in the first case the closure for [f] contains a pointer to [x],\n and in the second case it doesn't. A closure without pointers to enclosing\n environment is implemented as a naked function pointer, so we don't\n allocate at all.\n\n For the same reason we make sure not to call [Result.try_with (fun () -> ...)]\n inside [with_iteration] and do an explicit match statement instead. *)\n\n val with_iteration_2 : t -> 'a -> 'b -> ('a -> 'b -> 'c) -> 'c\n val with_iteration_3 : t -> 'a -> 'b -> 'c -> ('a -> 'b -> 'c -> 'd) -> 'd\n val with_iteration_4 : t -> 'a -> 'b -> 'c -> 'd -> ('a -> 'b -> 'c -> 'd -> 'e) -> 'e\n val merge : t -> t -> [ `Same_already | `Merged ]\nend = struct\n type s =\n { mutable length : int\n ;\n mutable pending_iterations : int\n }\n\n type t = s Union_find.t\n\n let create () = Union_find.create { length = 1; pending_iterations = 0 }\n let equal (t1 : t) t2 = Union_find.same_class t1 t2\n let length t = (Union_find.get t).length\n\n let union_find_get__check_no_pending_iterations t =\n let s = Union_find.get t in\n if s.pending_iterations > 0 then raise Attempt_to_mutate_list_during_iteration else s\n ;;\n\n let check_no_pending_iterations t =\n ignore (union_find_get__check_no_pending_iterations t : s)\n ;;\n\n let incr_length ~by:n t =\n let s = union_find_get__check_no_pending_iterations t in\n s.length <- s.length + n\n ;;\n\n (* Care is taken not to allocate in [with_iteration_*], since it is called every second\n by [every_second] in [writer0.ml] *)\n\n let incr_pending_iters s = s.pending_iterations <- s.pending_iterations + 1\n let decr_pending_iters s = s.pending_iterations <- s.pending_iterations - 1\n\n let with_iteration_2 t a b f =\n let s = Union_find.get t in\n incr_pending_iters s;\n match f a b with\n | exception exn ->\n decr_pending_iters s;\n raise exn\n | r ->\n decr_pending_iters s;\n r\n ;;\n\n let with_iteration_3 t a b c f =\n let s = Union_find.get t in\n incr_pending_iters s;\n match f a b c with\n | exception exn ->\n decr_pending_iters s;\n raise exn\n | r ->\n decr_pending_iters s;\n r\n ;;\n\n let with_iteration_4 t a b c d f =\n let s = Union_find.get t in\n incr_pending_iters s;\n match f a b c d with\n | exception exn ->\n decr_pending_iters s;\n raise exn\n | r ->\n decr_pending_iters s;\n r\n ;;\n\n let merge (t1 : t) t2 =\n if Union_find.same_class t1 t2\n then `Same_already\n else (\n let n1 = (union_find_get__check_no_pending_iterations t1).length in\n let n2 = (union_find_get__check_no_pending_iterations t2).length in\n with_iteration_4 t1 t1 t2 n1 n2 (fun t1 t2 n1 n2 ->\n with_iteration_4 t2 t1 t2 n1 n2 (fun t1 t2 n1 n2 ->\n Union_find.union t1 t2;\n Union_find.set t1 { length = n1 + n2; pending_iterations = 0 }));\n `Merged)\n ;;\nend\n\nmodule Elt : sig\n type 'a t [@@deriving sexp_of]\n\n val header : 'a t -> Header.t\n val equal : 'a t -> 'a t -> bool\n val create : 'a -> 'a t\n val value : 'a t -> 'a\n val set : 'a t -> 'a -> unit\n val unlink : 'a t -> unit\n val split_or_splice_before : 'a t -> 'a t -> unit\n val split_or_splice_after : 'a t -> 'a t -> unit\n val insert_after : 'a t -> 'a -> 'a t\n val insert_before : 'a t -> 'a -> 'a t\n val unlink_before : 'a t -> 'a t\n val next : 'a t -> 'a t\n val prev : 'a t -> 'a t\nend = struct\n type 'a t =\n { mutable value : 'a\n ; mutable prev : 'a t\n ; mutable next : 'a t\n ; mutable header : Header.t\n }\n\n let equal = phys_equal\n let next t = t.next\n let prev t = t.prev\n let header t = t.header\n\n let create_aux v header =\n let rec t = { value = v; prev = t; next = t; header } in\n t\n ;;\n\n let is_singleton t = equal t t.prev\n let sexp_of_t sexp_of_a t = sexp_of_a t.value\n let create v = create_aux v (Header.create ())\n let value t = t.value\n let set t v = t.value <- v\n\n (*\n [split_or_splice] is sufficient as the lone primitive for\n accomplishing all pointer updates on cyclic loops of list nodes.\n It takes two \"gaps\" between adjacent linked list nodes. If the gaps\n point into the same list, the result is that it will be split into\n two lists afterwards. If the gaps point into different lists, the\n result is that they will be spliced together into one list afterwards.\n\n {v\n Before After\n -----+ +----- -----+ +-----\n A | <--> | B A | <--- ---> | B\n -----+ +----- -----+ \\ / +-----\n X\n -----+ +----- -----+ / \\ +-----\n C | <--> | D C | <--- ---> | D\n -----+ +----- -----+ +-----\n v} *)\n\n let unsafe_split_or_splice ~prev1:a ~next1:b ~prev2:c ~next2:d =\n a.next <- d;\n d.prev <- a;\n c.next <- b;\n b.prev <- c\n ;;\n\n let unsafe_split_or_splice_after t1 t2 =\n unsafe_split_or_splice\n ~next1:t1.next\n ~prev1:t1.next.prev\n ~next2:t2.next\n ~prev2:t2.next.prev\n ;;\n\n let unsafe_split_or_splice_before t1 t2 =\n unsafe_split_or_splice\n ~prev1:t1.prev\n ~next1:t1.prev.next\n ~prev2:t2.prev\n ~next2:t2.prev.next\n ;;\n\n let check_two_nodes_no_pending_iterations t1 t2 =\n Header.check_no_pending_iterations t1.header;\n if not (Header.equal t1.header t2.header)\n then Header.check_no_pending_iterations t2.header\n ;;\n\n (* We redefine safe versions for export *)\n let split_or_splice_after t1 t2 =\n check_two_nodes_no_pending_iterations t1 t2;\n unsafe_split_or_splice_after t1 t2\n ;;\n\n let split_or_splice_before t1 t2 =\n check_two_nodes_no_pending_iterations t1 t2;\n unsafe_split_or_splice_before t1 t2\n ;;\n\n let insert_before t v =\n Header.incr_length t.header ~by:1;\n let node = create_aux v t.header in\n unsafe_split_or_splice_before t node;\n node\n ;;\n\n let insert_after t v =\n Header.incr_length t.header ~by:1;\n let node = create_aux v t.header in\n unsafe_split_or_splice_after t node;\n node\n ;;\n\n let dummy_header = Header.create ()\n\n let unlink_before t =\n let node = t.prev in\n if is_singleton node\n then node\n else (\n Header.incr_length t.header ~by:(-1);\n unsafe_split_or_splice_before t node;\n node.header <- dummy_header;\n node)\n ;;\n\n let unlink_after t =\n let node = t.next in\n if is_singleton node\n then node\n else (\n Header.incr_length t.header ~by:(-1);\n unsafe_split_or_splice_after t node;\n node.header <- dummy_header;\n node)\n ;;\n\n let unlink t = ignore (unlink_after t.prev : _ t)\nend\n\ntype 'a t = 'a Elt.t option ref\n\nlet invariant invariant_a t =\n match !t with\n | None -> ()\n | Some head ->\n let header = Elt.header head in\n let rec loop n elt =\n let next_elt = Elt.next elt in\n let prev_elt = Elt.prev elt in\n assert (Elt.equal elt (Elt.prev next_elt));\n assert (Elt.equal elt (Elt.next prev_elt));\n assert (Header.equal (Elt.header elt) header);\n invariant_a (Elt.value elt);\n if Elt.equal next_elt head then n else loop (n + 1) next_elt\n in\n let len = loop 1 head in\n assert (len = Header.length header)\n;;\n\nlet create (type a) () : a t = ref None\nlet equal (t : _ t) t' = phys_equal t t'\n\nlet of_list = function\n | [] -> create ()\n | x :: xs ->\n let first = Elt.create x in\n let _last = List.fold xs ~init:first ~f:Elt.insert_after in\n ref (Some first)\n;;\n\nlet of_array = function\n | [||] -> create ()\n | arr ->\n let first = Elt.create arr.(0) in\n let rec loop arr elt i =\n if i < Array.length arr then loop arr (Elt.insert_after elt arr.(i)) (i + 1)\n in\n loop arr first 1;\n ref (Some first)\n;;\n\nlet map t ~f =\n match !t with\n | None -> create ()\n | Some first ->\n let new_first = Elt.create (f (Elt.value first)) in\n Header.with_iteration_3\n (Elt.header first)\n f\n new_first\n first\n (fun f new_first first ->\n let rec loop f acc first elt =\n let acc = Elt.insert_after acc (f (Elt.value elt)) in\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f acc first next\n in\n (* unroll and skip first elt *)\n let next = Elt.next first in\n if not (phys_equal next first) then loop f new_first first next);\n ref (Some new_first)\n;;\n\nlet mapi t ~f =\n match !t with\n | None -> create ()\n | Some first ->\n let new_first = Elt.create (f 0 (Elt.value first)) in\n Header.with_iteration_3\n (Elt.header first)\n f\n new_first\n first\n (fun f new_first first ->\n let rec loop f i acc first elt =\n let acc = Elt.insert_after acc (f i (Elt.value elt)) in\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f (i + 1) acc first next\n in\n (* unroll and skip first elt *)\n let next = Elt.next first in\n if not (phys_equal next first) then loop f 1 new_first first next);\n ref (Some new_first)\n;;\n\nlet fold_elt t ~init ~f =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f init first (fun f init first ->\n let rec loop f acc first elt =\n let acc = f acc elt in\n let next = Elt.next elt in\n if phys_equal next first then acc else loop f acc first next\n in\n loop f init first first)\n;;\n\nlet foldi_elt t ~init ~f =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f init first (fun f init first ->\n let rec loop f i acc first elt =\n let acc = f i acc elt in\n let next = Elt.next elt in\n if phys_equal next first then acc else loop f (i + 1) acc first next\n in\n loop f 0 init first first)\n;;\n\nlet fold_elt_1 t ~init ~f a =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f a init first (fun f a init first ->\n let rec loop f a acc first elt =\n let acc = f a acc elt in\n let next = Elt.next elt in\n if phys_equal next first then acc else loop f a acc first next\n in\n loop f a init first first)\n;;\n\nlet foldi_elt_1 t ~init ~f a =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f a init first (fun f a init first ->\n let rec loop f i a acc first elt =\n let acc = f i a acc elt in\n let next = Elt.next elt in\n if phys_equal next first then acc else loop f (i + 1) a acc first next\n in\n loop f 0 a init first first)\n;;\n\nlet iter_elt t ~f = fold_elt_1 t ~init:() ~f:(fun f () elt -> f elt) f\nlet iteri_elt t ~f = foldi_elt t ~init:() ~f:(fun i () elt -> f i elt)\n\nopen With_return\n\nlet find_elt t ~f =\n with_return (fun r ->\n fold_elt_1 t f ~init:() ~f:(fun f () elt ->\n if f (Elt.value elt) then r.return (Some elt));\n None)\n;;\n\nlet findi_elt t ~f =\n with_return (fun r ->\n foldi_elt_1 t f ~init:() ~f:(fun i f () elt ->\n if f i (Elt.value elt) then r.return (Some (i, elt)));\n None)\n;;\n\n(* this function is lambda lifted for performance, to make direct recursive calls instead\n of calls through its closure. It also avoids the initial closure allocation. *)\nlet rec iter_loop first f elt =\n f (Elt.value elt);\n let next = Elt.next elt in\n if not (phys_equal next first) then iter_loop first f next\n;;\n\nlet iter t ~f =\n match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_2 (Elt.header first) first f (fun first f ->\n iter_loop first f first)\n;;\n\nlet length t =\n match !t with\n | None -> 0\n | Some first -> Header.length (Elt.header first)\n;;\n\nlet rec iteri_loop first f i elt =\n f i (Elt.value elt);\n let next = Elt.next elt in\n if not (phys_equal next first) then iteri_loop first f (i + 1) next\n;;\n\nlet iteri t ~f =\n match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_2 (Elt.header first) first f (fun first f ->\n iteri_loop first f 0 first)\n;;\n\nlet foldi t ~init ~f =\n foldi_elt_1 t ~init f ~f:(fun i f acc elt -> f i acc (Elt.value elt))\n;;\n\nmodule C = Container.Make (struct\n type nonrec 'a t = 'a t\n\n let fold t ~init ~f = fold_elt_1 t ~init f ~f:(fun f acc elt -> f acc (Elt.value elt))\n let iter = `Custom iter\n let length = `Custom length\n end)\n\nlet count = C.count\nlet sum = C.sum\nlet exists = C.exists\nlet find = C.find\nlet find_map = C.find_map\nlet fold = C.fold\nlet for_all = C.for_all\nlet mem = C.mem\nlet to_array = C.to_array\nlet min_elt = C.min_elt\nlet max_elt = C.max_elt\nlet fold_result = C.fold_result\nlet fold_until = C.fold_until\n\nlet unchecked_iter t ~f =\n match !t with\n | None -> ()\n | Some first ->\n let rec loop t f elt =\n f (Elt.value elt);\n let next = Elt.next elt in\n match !t with\n (* the first element of the bag may have been changed by [f] *)\n | None -> ()\n | Some first -> if not (phys_equal first next) then loop t f next\n in\n loop t f first\n;;\n\nlet is_empty t = Option.is_none !t\n\n(* more efficient than what Container.Make returns *)\n\nlet fold_right t ~init ~f =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f init first (fun f init first ->\n let rec loop f acc elt =\n let prev = Elt.prev elt in\n let acc = f (Elt.value prev) acc in\n if phys_equal prev first then acc else loop f acc prev\n in\n loop f init first)\n;;\n\nlet fold_right_elt t ~init ~f =\n match !t with\n | None -> init\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f init first (fun f init first ->\n let rec loop f acc elt =\n let prev = Elt.prev elt in\n let acc = f prev acc in\n if phys_equal prev first then acc else loop f acc prev\n in\n loop f init first)\n;;\n\nlet to_list t = fold_right t ~init:[] ~f:(fun x tl -> x :: tl)\nlet sexp_of_t sexp_of_a t = List.sexp_of_t sexp_of_a (to_list t)\nlet t_of_sexp a_of_sexp s = of_list (List.t_of_sexp a_of_sexp s)\nlet copy t = of_list (to_list t)\nlet clear t = t := None\n\nlet compare compare_elt t1 t2 =\n match !t1, !t2 with\n | None, None -> 0\n | None, _ -> -1\n | _, None -> 1\n | Some f1, Some f2 ->\n Header.with_iteration_3 (Elt.header f1) compare_elt f1 f2 (fun compare_elt f1 f2 ->\n Header.with_iteration_3\n (Elt.header f2)\n compare_elt\n f1\n f2\n (fun compare_elt f1 f2 ->\n let rec loop compare_elt elt1 f1 elt2 f2 =\n let compare_result = compare_elt (Elt.value elt1) (Elt.value elt2) in\n if compare_result <> 0\n then compare_result\n else (\n let next1 = Elt.next elt1 in\n let next2 = Elt.next elt2 in\n match phys_equal next1 f1, phys_equal next2 f2 with\n | true, true -> 0\n | true, false -> -1\n | false, true -> 1\n | false, false -> loop compare_elt next1 f1 next2 f2)\n in\n loop compare_elt f1 f1 f2 f2))\n;;\n\nexception Transfer_src_and_dst_are_same_list\n\nlet transfer ~src ~dst =\n if phys_equal src dst then raise Transfer_src_and_dst_are_same_list;\n match !src with\n | None -> ()\n | Some src_head ->\n (match !dst with\n | None ->\n dst := Some src_head;\n clear src\n | Some dst_head ->\n (match Header.merge (Elt.header src_head) (Elt.header dst_head) with\n | `Same_already -> raise Transfer_src_and_dst_are_same_list\n | `Merged ->\n Elt.split_or_splice_before dst_head src_head;\n clear src))\n;;\n\nlet map_inplace t ~f = iter_elt t ~f:(fun elt -> Elt.set elt (f (Elt.value elt)))\nlet mapi_inplace t ~f = iteri_elt t ~f:(fun i elt -> Elt.set elt (f i (Elt.value elt)))\n\nlet remove_list t to_remove =\n List.iter to_remove ~f:(fun elt ->\n (match !t with\n | None -> ()\n | Some head ->\n if Elt.equal head elt\n then (\n let next_elt = Elt.next elt in\n t := if Elt.equal head next_elt then None else Some next_elt));\n Elt.unlink elt)\n;;\n\nlet filter_inplace t ~f =\n let to_remove =\n List.rev\n (fold_elt t ~init:[] ~f:(fun elts elt ->\n if f (Elt.value elt) then elts else elt :: elts))\n in\n remove_list t to_remove\n;;\n\nlet filteri_inplace t ~f =\n let to_remove =\n List.rev\n (foldi_elt t ~init:[] ~f:(fun i elts elt ->\n if f i (Elt.value elt) then elts else elt :: elts))\n in\n remove_list t to_remove\n;;\n\nlet filter_map_inplace t ~f =\n let to_remove =\n List.rev\n (fold_elt t ~init:[] ~f:(fun elts elt ->\n match f (Elt.value elt) with\n | None -> elt :: elts\n | Some value ->\n Elt.set elt value;\n elts))\n in\n remove_list t to_remove\n;;\n\nlet filter_mapi_inplace t ~f =\n let to_remove =\n List.rev\n (foldi_elt t ~init:[] ~f:(fun i elts elt ->\n match f i (Elt.value elt) with\n | None -> elt :: elts\n | Some value ->\n Elt.set elt value;\n elts))\n in\n remove_list t to_remove\n;;\n\nexception Elt_does_not_belong_to_list\n\nlet first_elt t = !t\nlet last_elt t = Option.map ~f:Elt.prev !t\nlet first t = Option.map ~f:Elt.value (first_elt t)\nlet last t = Option.map ~f:Elt.value (last_elt t)\n\nlet is_first t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Header.equal (Elt.header first) (Elt.header elt)\n then Elt.equal elt first\n else raise Elt_does_not_belong_to_list\n;;\n\nlet is_last t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Header.equal (Elt.header first) (Elt.header elt)\n then (\n let last = Elt.prev first in\n Elt.equal elt last)\n else raise Elt_does_not_belong_to_list\n;;\n\nlet mem_elt t elt =\n match !t with\n | None -> false\n | Some first -> Header.equal (Elt.header first) (Elt.header elt)\n;;\n\nlet prev t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Elt.equal elt first\n then None\n else if Header.equal (Elt.header first) (Elt.header elt)\n then Some (Elt.prev elt)\n else raise Elt_does_not_belong_to_list\n;;\n\nlet next t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n let last = Elt.prev first in\n if Elt.equal elt last\n then None\n else if Header.equal (Elt.header first) (Elt.header elt)\n then Some (Elt.next elt)\n else raise Elt_does_not_belong_to_list\n;;\n\nlet insert_after t elt v =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Header.equal (Elt.header first) (Elt.header elt)\n then Elt.insert_after elt v\n else raise Elt_does_not_belong_to_list\n;;\n\nlet insert_before t elt v =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Elt.equal elt first\n then (\n let new_elt = Elt.insert_before first v in\n t := Some new_elt;\n new_elt)\n else if Header.equal (Elt.header first) (Elt.header elt)\n then Elt.insert_before elt v\n else raise Elt_does_not_belong_to_list\n;;\n\nlet insert_empty t v =\n let new_elt = Elt.create v in\n t := Some new_elt;\n new_elt\n;;\n\nlet insert_last t v =\n match !t with\n | None -> insert_empty t v\n | Some first -> Elt.insert_before first v\n;;\n\nlet insert_first t v =\n match !t with\n | None -> insert_empty t v\n | Some first ->\n let new_elt = Elt.insert_before first v in\n t := Some new_elt;\n new_elt\n;;\n\nlet remove_last t =\n match !t with\n | None -> None\n | Some first ->\n let last = Elt.unlink_before first in\n if Elt.equal first last then t := None;\n Some (Elt.value last)\n;;\n\nlet remove_first t =\n match !t with\n | None -> None\n | Some first ->\n let second = Elt.next first in\n Elt.unlink first;\n t := if Elt.equal first second then None else Some second;\n Some (Elt.value first)\n;;\n\nlet remove t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Elt.equal elt first\n then ignore (remove_first t : _ option)\n else if Header.equal (Elt.header first) (Elt.header elt)\n then Elt.unlink elt\n else raise Elt_does_not_belong_to_list\n;;\n\nlet filter t ~f =\n let new_t = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f new_t first (fun f new_t first ->\n let rec loop f new_t first elt =\n if f (Elt.value elt)\n then insert_last new_t (Elt.value elt) |> (ignore : _ Elt.t -> unit);\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f new_t first next\n in\n loop f new_t first first));\n new_t\n;;\n\nlet filteri t ~f =\n let new_t = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f new_t first (fun f new_t first ->\n let rec loop f i new_t first elt =\n if f i (Elt.value elt)\n then insert_last new_t (Elt.value elt) |> (ignore : _ Elt.t -> unit);\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f (i + 1) new_t first next\n in\n loop f 0 new_t first first));\n new_t\n;;\n\nlet filter_map t ~f =\n let new_t = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f new_t first (fun f new_t first ->\n let rec loop f new_t first elt =\n (match f (Elt.value elt) with\n | None -> ()\n | Some value -> insert_last new_t value |> (ignore : _ Elt.t -> unit));\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f new_t first next\n in\n loop f new_t first first));\n new_t\n;;\n\nlet filter_mapi t ~f =\n let new_t = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_3 (Elt.header first) f new_t first (fun f new_t first ->\n let rec loop f i new_t first elt =\n (match f i (Elt.value elt) with\n | None -> ()\n | Some value -> insert_last new_t value |> (ignore : _ Elt.t -> unit));\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f (i + 1) new_t first next\n in\n loop f 0 new_t first first));\n new_t\n;;\n\nlet partition_tf t ~f =\n let t1 = create () in\n let t2 = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f t1 t2 first (fun f t1 t2 first ->\n let rec loop f t1 t2 first elt =\n insert_last (if f (Elt.value elt) then t1 else t2) (Elt.value elt)\n |> (ignore : _ Elt.t -> unit);\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f t1 t2 first next\n in\n loop f t1 t2 first first));\n t1, t2\n;;\n\nlet partitioni_tf t ~f =\n let t1 = create () in\n let t2 = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f t1 t2 first (fun f t1 t2 first ->\n let rec loop f i t1 t2 first elt =\n insert_last (if f i (Elt.value elt) then t1 else t2) (Elt.value elt)\n |> (ignore : _ Elt.t -> unit);\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f (i + 1) t1 t2 first next\n in\n loop f 0 t1 t2 first first));\n t1, t2\n;;\n\nlet partition_map t ~f =\n let t1 = create () in\n let t2 = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f t1 t2 first (fun f t1 t2 first ->\n let rec loop f t1 t2 first elt =\n (match (f (Elt.value elt) : (_, _) Either.t) with\n | First value -> insert_last t1 value |> (ignore : _ Elt.t -> unit)\n | Second value -> insert_last t2 value |> (ignore : _ Elt.t -> unit));\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f t1 t2 first next\n in\n loop f t1 t2 first first));\n t1, t2\n;;\n\nlet partition_mapi t ~f =\n let t1 = create () in\n let t2 = create () in\n (match !t with\n | None -> ()\n | Some first ->\n Header.with_iteration_4 (Elt.header first) f t1 t2 first (fun f t1 t2 first ->\n let rec loop f i t1 t2 first elt =\n (match (f i (Elt.value elt) : (_, _) Either.t) with\n | First value -> insert_last t1 value |> (ignore : _ Elt.t -> unit)\n | Second value -> insert_last t2 value |> (ignore : _ Elt.t -> unit));\n let next = Elt.next elt in\n if not (phys_equal next first) then loop f (i + 1) t1 t2 first next\n in\n loop f 0 t1 t2 first first));\n t1, t2\n;;\n\nexception Invalid_move__elt_equals_anchor\n\nlet move_before t elt ~anchor =\n if Elt.equal anchor elt then raise Invalid_move__elt_equals_anchor;\n if Header.equal (Elt.header anchor) (Elt.header elt)\n then (\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Header.equal (Elt.header first) (Elt.header elt)\n then (\n (* unlink [elt] *)\n let after_elt = Elt.next elt in\n Elt.split_or_splice_before elt after_elt;\n let first =\n if Elt.equal first elt\n then (\n t := Some after_elt;\n after_elt)\n else first\n in\n (* splice [elt] in before [anchor] *)\n Elt.split_or_splice_before anchor elt;\n if Elt.equal first anchor then t := Some elt)\n else raise Elt_does_not_belong_to_list)\n else raise Elt_does_not_belong_to_list\n;;\n\nlet move_to_front t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first -> if not (Elt.equal elt first) then move_before t elt ~anchor:first\n;;\n\nlet move_after t elt ~anchor =\n if Elt.equal anchor elt then raise Invalid_move__elt_equals_anchor;\n if Header.equal (Elt.header anchor) (Elt.header elt)\n then (\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n if Header.equal (Elt.header first) (Elt.header elt)\n then (\n (* unlink [elt] *)\n let after_elt = Elt.next elt in\n Elt.split_or_splice_before elt after_elt;\n if Elt.equal first elt then t := Some after_elt;\n (* splice [elt] in after [anchor] *)\n Elt.split_or_splice_after anchor elt)\n else raise Elt_does_not_belong_to_list)\n else raise Elt_does_not_belong_to_list\n;;\n\nlet move_to_back t elt =\n match !t with\n | None -> raise Elt_does_not_belong_to_list\n | Some first ->\n let last = Elt.prev first in\n if not (Elt.equal elt last) then move_after t elt ~anchor:last\n;;\n\nlet to_sequence t = to_list t |> Sequence.of_list\n","open! Import\ninclude Bag_intf\ninclude (Doubly_linked : Doubly_linked.S)\n\nlet add = insert_first\nlet add_unit t v = add t v |> (ignore : _ Elt.t -> unit)\nlet elts t = fold_elt t ~init:[] ~f:(fun acc elt -> elt :: acc)\nlet remove_one = remove_first\nlet choose = first_elt\n\nlet until_empty t f =\n let rec loop () =\n Option.iter (remove_one t) ~f:(fun v ->\n f v;\n loop ())\n in\n loop ()\n;;\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n type t = Base.Sexp.t =\n | Atom of string\n | List of t list\n [@@deriving bin_io, compare, hash]\n\n let t_of_sexp = Sexplib.Sexp.t_of_sexp\n let sexp_of_t = Sexplib.Sexp.sexp_of_t\n end\nend\n\ninclude Stable.V1\n\ninclude (\n Base.Sexp :\n module type of struct\n include Base.Sexp\n end\n with type t := t)\n\ninclude (\n Sexplib.Sexp :\n module type of struct\n include Sexplib.Sexp\n end\n with type t := t)\n\nmodule O = struct\n type sexp = Base.Sexp.t =\n | Atom of string\n | List of t list\nend\n\nmodule Sexp_maybe = struct\n type nonrec 'a t = ('a, t * Error.t) Result.t [@@deriving bin_io, compare, hash]\n\n let sexp_of_t sexp_of_a t =\n match t with\n | Result.Ok a -> sexp_of_a a\n | Result.Error (sexp, err) ->\n List [ Atom \"sexp_parse_error\"; sexp; Error.sexp_of_t err ]\n ;;\n\n let t_of_sexp a_of_sexp sexp =\n match sexp with\n | List [ Atom \"sexp_parse_error\"; sexp; _ ] | sexp ->\n (try Result.Ok (a_of_sexp sexp) with\n | exn -> Result.Error (sexp, Error.of_exn exn))\n ;;\nend\n\nmodule With_text = struct\n open Result.Export\n\n type 'a t =\n { value : 'a\n ; text : string\n }\n [@@deriving bin_io]\n\n let sexp_of_t _ t = Atom t.text\n\n let of_text value_of_sexp ?(filename = \"\") text =\n match Or_error.try_with (fun () -> of_string_conv text value_of_sexp) with\n | Ok (`Result value) -> Ok { value; text }\n | Error _ as err -> err\n | Ok (`Error (exn, annotated)) ->\n Error (Error.of_exn (Annotated.get_conv_exn annotated ~file:filename ~exc:exn))\n ;;\n\n let t_of_sexp a_of_sexp sexp =\n match sexp with\n | List _ ->\n of_sexp_error\n \"With_text.t should be stored as an atom, but instead a list was found.\"\n sexp\n | Atom text -> of_text a_of_sexp text |> Or_error.ok_exn\n ;;\n\n let text t = t.text\n let value t = t.value\n\n let of_value sexp_of_value value =\n let text = sexp_of_value value |> to_string_hum in\n { value; text }\n ;;\nend\n\ntype 'a no_raise = 'a [@@deriving bin_io, sexp]\n\nlet sexp_of_no_raise sexp_of_a a =\n try sexp_of_a a with\n | exn ->\n (try List [ Atom \"failure building sexp\"; sexp_of_exn exn ] with\n | _ -> Atom \"could not build sexp for exn raised when building sexp for value\")\n;;\n\ninclude Comparable.Extend (Base.Sexp) (Base.Sexp)\n\nlet of_sexp_allow_extra_fields_recursively of_sexp sexp =\n let r = Sexplib.Conv.record_check_extra_fields in\n let prev = !r in\n Exn.protect\n ~finally:(fun () -> r := prev)\n ~f:(fun () ->\n r := false;\n of_sexp sexp)\n;;\n\nlet quickcheck_generator = Base_quickcheck.Generator.sexp\nlet quickcheck_observer = Base_quickcheck.Observer.sexp\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.sexp\n","open! Import\nopen Hash_queue_intf\n\nmodule type Key = Key\nmodule type S_backend = S_backend\n\nmodule Make_backend (Table : Hashtbl_intf.Hashtbl) : S_backend = struct\n module type Backend =\n S1\n with type 'key create_arg := 'key Hashtbl.Hashable.t\n with type 'key create_key := 'key\n\n module Backend : Backend = struct\n module Key_value = struct\n module T = struct\n type ('key, 'value) t =\n { key : 'key\n ; mutable value : 'value\n }\n end\n\n include T\n\n let key t = t.key\n let value t = t.value\n\n let sexp_of_t sexp_of_key sexp_of_data { key; value } =\n [%sexp_of: key * data] (key, value)\n ;;\n end\n\n open Key_value.T\n module Elt = Doubly_linked.Elt\n\n type ('key, 'data) t =\n { mutable num_readers : int\n ; queue : ('key, 'data) Key_value.t Doubly_linked.t\n ; table : ('key, ('key, 'data) Key_value.t Elt.t) Table.t\n }\n\n let sexp_of_t sexp_of_key sexp_of_data t =\n [%sexp_of: (key, data) Key_value.t Doubly_linked.t] t.queue\n ;;\n\n let invariant t =\n assert (Doubly_linked.length t.queue = Table.length t.table);\n (* Look at each element in the queue, checking:\n * - every element in the queue is in the hash table\n * - there are no duplicate keys\n *)\n let keys = Table.create ~size:(Table.length t.table) (Table.hashable_s t.table) in\n Doubly_linked.iter t.queue ~f:(fun kv ->\n let key = kv.key in\n match Table.find t.table key with\n | None -> assert false\n | Some _ ->\n assert (not (Table.mem keys key));\n Table.set keys ~key ~data:())\n ;;\n\n let create ?(growth_allowed = true) ?(size = 16) hashable =\n { num_readers = 0\n ; queue = Doubly_linked.create ()\n ; table = Table.create ~growth_allowed ~size (Table.Hashable.to_key hashable)\n }\n ;;\n\n let read t f =\n t.num_readers <- t.num_readers + 1;\n Exn.protect ~f ~finally:(fun () -> t.num_readers <- t.num_readers - 1)\n ;;\n\n let ensure_can_modify t =\n if t.num_readers > 0\n then failwith \"It is an error to modify a Hash_queue.t while iterating over it.\"\n ;;\n\n let clear t =\n ensure_can_modify t;\n Doubly_linked.clear t.queue;\n Table.clear t.table\n ;;\n\n let length t = Table.length t.table\n let is_empty t = length t = 0\n\n let lookup t k =\n match Table.find t.table k with\n | None -> None\n | Some elt -> Some (Elt.value elt).value\n ;;\n\n let lookup_exn t k = (Elt.value (Table.find_exn t.table k)).value\n let mem t k = Table.mem t.table k\n\n (* Note that this is the tail-recursive Core_list.map *)\n let to_list t = List.map (Doubly_linked.to_list t.queue) ~f:Key_value.value\n let to_array t = Array.map (Doubly_linked.to_array t.queue) ~f:Key_value.value\n\n let for_all t ~f =\n read t (fun () -> Doubly_linked.for_all t.queue ~f:(fun kv -> f kv.value))\n ;;\n\n let exists t ~f =\n read t (fun () -> Doubly_linked.exists t.queue ~f:(fun kv -> f kv.value))\n ;;\n\n let find_map t ~f =\n read t (fun () -> Doubly_linked.find_map t.queue ~f:(fun kv -> f kv.value))\n ;;\n\n let find t ~f =\n read t (fun () ->\n Option.map\n (Doubly_linked.find t.queue ~f:(fun kv -> f kv.value))\n ~f:Key_value.value)\n ;;\n\n let enqueue t back_or_front key value =\n ensure_can_modify t;\n if Table.mem t.table key\n then `Key_already_present\n else (\n let contents = { Key_value.key; value } in\n let elt =\n match back_or_front with\n | `back -> Doubly_linked.insert_last t.queue contents\n | `front -> Doubly_linked.insert_first t.queue contents\n in\n Table.set t.table ~key ~data:elt;\n `Ok)\n ;;\n\n let enqueue_back t = enqueue t `back\n let enqueue_front t = enqueue t `front\n\n let raise_enqueue_duplicate_key t key =\n raise_s\n [%message\n \"Hash_queue.enqueue_exn: duplicate key\"\n ~_:(Table.sexp_of_key t.table key : Sexp.t)]\n ;;\n\n let enqueue_exn t back_or_front key value =\n match enqueue t back_or_front key value with\n | `Key_already_present -> raise_enqueue_duplicate_key t key\n | `Ok -> ()\n ;;\n\n let enqueue_back_exn t = enqueue_exn t `back\n let enqueue_front_exn t = enqueue_exn t `front\n\n (* Performance hack: we implement this version separately to avoid allocation from the\n option. *)\n let lookup_and_move_to_back_exn t key =\n ensure_can_modify t;\n let elt = Table.find_exn t.table key in\n Doubly_linked.move_to_back t.queue elt;\n Key_value.value (Elt.value elt)\n ;;\n\n let lookup_and_move_to_back t key =\n let open Option.Let_syntax in\n ensure_can_modify t;\n let%map elt = Table.find t.table key in\n Doubly_linked.move_to_back t.queue elt;\n Key_value.value (Elt.value elt)\n ;;\n\n let lookup_and_move_to_front_exn t key =\n ensure_can_modify t;\n let elt = Table.find_exn t.table key in\n Doubly_linked.move_to_front t.queue elt;\n Key_value.value (Elt.value elt)\n ;;\n\n let lookup_and_move_to_front t key =\n let open Option.Let_syntax in\n ensure_can_modify t;\n let%map elt = Table.find t.table key in\n Doubly_linked.move_to_front t.queue elt;\n Key_value.value (Elt.value elt)\n ;;\n\n let dequeue_with_key t back_or_front =\n ensure_can_modify t;\n let maybe_kv =\n match back_or_front with\n | `back -> Doubly_linked.remove_last t.queue\n | `front -> Doubly_linked.remove_first t.queue\n in\n match maybe_kv with\n | None -> None\n | Some kv ->\n Table.remove t.table kv.key;\n Some (kv.key, kv.value)\n ;;\n\n let raise_dequeue_with_key_empty () =\n raise_s [%message \"Hash_queue.dequeue_with_key: empty queue\"]\n ;;\n\n let dequeue_with_key_exn t back_or_front =\n match dequeue_with_key t back_or_front with\n | None -> raise_dequeue_with_key_empty ()\n | Some (k, v) -> k, v\n ;;\n\n let dequeue_back_with_key t = dequeue_with_key t `back\n let dequeue_back_with_key_exn t = dequeue_with_key_exn t `back\n let dequeue_front_with_key t = dequeue_with_key t `front\n let dequeue_front_with_key_exn t = dequeue_with_key_exn t `front\n\n let dequeue t back_or_front =\n match dequeue_with_key t back_or_front with\n | None -> None\n | Some (_, v) -> Some v\n ;;\n\n let dequeue_back t = dequeue t `back\n let dequeue_front t = dequeue t `front\n\n let first_with_key t =\n match Doubly_linked.first t.queue with\n | None -> None\n | Some { key; value } -> Some (key, value)\n ;;\n\n let first t =\n match Doubly_linked.first t.queue with\n | None -> None\n | Some kv -> Some kv.value\n ;;\n\n let raise_dequeue_empty () = raise_s [%message \"Hash_queue.dequeue_exn: empty queue\"]\n\n let dequeue_exn t back_or_front =\n match dequeue t back_or_front with\n | None -> raise_dequeue_empty ()\n | Some v -> v\n ;;\n\n let dequeue_back_exn t = dequeue_exn t `back\n let dequeue_front_exn t = dequeue_exn t `front\n\n let keys t =\n (* Return the keys in the order of the queue. *)\n List.map (Doubly_linked.to_list t.queue) ~f:Key_value.key\n ;;\n\n let iteri t ~f =\n read t (fun () ->\n Doubly_linked.iter t.queue ~f:(fun kv -> f ~key:kv.key ~data:kv.value))\n ;;\n\n let iter t ~f = iteri t ~f:(fun ~key:_ ~data -> f data)\n\n let foldi t ~init ~f =\n read t (fun () ->\n Doubly_linked.fold t.queue ~init ~f:(fun ac kv ->\n f ac ~key:kv.key ~data:kv.value))\n ;;\n\n let fold t ~init ~f = foldi t ~init ~f:(fun ac ~key:_ ~data -> f ac data)\n let count t ~f = Container.count ~fold t ~f\n let sum m t ~f = Container.sum m ~fold t ~f\n let min_elt t ~compare = Container.min_elt ~fold t ~compare\n let max_elt t ~compare = Container.max_elt ~fold t ~compare\n let fold_result t ~init ~f = Container.fold_result ~fold ~init ~f t\n let fold_until t ~init ~f = Container.fold_until ~fold ~init ~f t\n\n let dequeue_all t ~f =\n let rec loop () =\n match dequeue_front t with\n | None -> ()\n | Some v ->\n f v;\n loop ()\n in\n loop ()\n ;;\n\n let remove t k =\n ensure_can_modify t;\n match Table.find_and_remove t.table k with\n | None -> `No_such_key\n | Some elt ->\n Doubly_linked.remove t.queue elt;\n `Ok\n ;;\n\n let raise_remove_unknown_key t key =\n raise_s\n [%message\n \"Hash_queue.remove_exn: unknown key\"\n ~_:(Table.sexp_of_key t.table key : Sexp.t)]\n ;;\n\n let remove_exn t k =\n ensure_can_modify t;\n match remove t k with\n | `No_such_key -> raise_remove_unknown_key t k\n | `Ok -> ()\n ;;\n\n let lookup_and_remove t k =\n ensure_can_modify t;\n match Table.find_and_remove t.table k with\n | None -> None\n | Some elt ->\n Doubly_linked.remove t.queue elt;\n Some (Elt.value elt).value\n ;;\n\n let replace t k v =\n ensure_can_modify t;\n match Table.find t.table k with\n | None -> `No_such_key\n | Some elt ->\n (Elt.value elt).value <- v;\n `Ok\n ;;\n\n let raise_replace_unknown_key t key =\n raise_s\n [%message\n \"Hash_queue.replace_exn: unknown key\"\n ~_:(Table.sexp_of_key t.table key : Sexp.t)]\n ;;\n\n let replace_exn t k v =\n ensure_can_modify t;\n match replace t k v with\n | `No_such_key -> raise_replace_unknown_key t k\n | `Ok -> ()\n ;;\n\n let drop ?(n = 1) t back_or_front =\n if n >= length t\n then clear t\n else\n for _ = 1 to n do\n ignore (dequeue_with_key t back_or_front : _ option)\n done\n ;;\n\n let drop_back ?n t = drop ?n t `back\n let drop_front ?n t = drop ?n t `front\n end\n\n module type S = S0 with type ('key, 'data) hash_queue := ('key, 'data) Backend.t\n\n module Make (Key : Key) : S with type key = Key.t = struct\n include (Backend : Backend with type ('k, 'd) t := ('k, 'd) Backend.t)\n\n type key = Key.t\n type 'data t = (Key.t, 'data) Backend.t [@@deriving sexp_of]\n\n let hashable = Table.Hashable.of_key (module Key)\n let create ?growth_allowed ?size () = create ?growth_allowed ?size hashable\n end\n\n include Backend\nend\n\ninclude Make_backend (Hashtbl)\n","(** Functors and interfaces used to make modules hashable. *)\n\nopen! Import\nmodule Binable = Binable0\n\nmodule type Common = sig\n type t [@@deriving compare, hash]\n\n val hashable : t Hashtbl.Hashable.t\nend\n\nmodule type S_plain = sig\n include Common\n module Table : Hashtbl.S_plain with type key = t\n module Hash_set : Hash_set.S_plain with type elt = t\n module Hash_queue : Hash_queue.S with type key = t\nend\n\nmodule type S = sig\n include Common\n module Table : Hashtbl.S with type key = t\n module Hash_set : Hash_set.S with type elt = t\n module Hash_queue : Hash_queue.S with type key = t\nend\n\nmodule Make_plain (T : sig\n type t [@@deriving hash]\n\n include Hashtbl.Key_plain with type t := t\n end) : S_plain with type t := T.t = struct\n include T\n module Table = Hashtbl.Make_plain (T)\n module Hash_set = Hash_set.Make_plain (T)\n module Hash_queue = Hash_queue.Make (T)\n\n let hashable = Table.hashable\nend\n\nmodule Make_plain_and_derive_hash_fold_t (T : Hashtbl.Key_plain) :\n S_plain with type t := T.t = Make_plain (struct\n include T\n\n let hash_fold_t state t = hash_fold_int state (hash t)\n end)\n\nmodule Make (T : sig\n type t [@@deriving hash]\n\n include Hashtbl.Key with type t := t\n end) : S with type t := T.t = struct\n include T\n module Table = Hashtbl.Make (T)\n module Hash_set = Hash_set.Make (T)\n module Hash_queue = Hash_queue.Make (T)\n\n let hashable = Table.hashable\nend\n\nmodule Make_and_derive_hash_fold_t (T : Hashtbl.Key) : S with type t := T.t =\n Make (struct\n include T\n\n let hash_fold_t state t = hash_fold_int state (hash t)\n end)\n\nmodule type S_binable = sig\n type t [@@deriving hash]\n\n val hashable : t Hashtbl.Hashable.t\n\n module Table : Hashtbl.S_binable with type key = t\n module Hash_set : Hash_set.S_binable with type elt = t\n module Hash_queue : Hash_queue.S with type key = t\nend\n\nmodule Make_binable (T : sig\n type t [@@deriving hash]\n\n include Hashtbl.Key_binable with type t := t\n end) : S_binable with type t := T.t = struct\n module Table = Hashtbl.Make_binable (T)\n module Hash_set = Hash_set.Make_binable (T)\n module Hash_queue = Hash_queue.Make (T)\n include T\n\n let hashable = Table.hashable\nend\n\nmodule Make_binable_and_derive_hash_fold_t (T : Hashtbl.Key_binable) :\n S_binable with type t := T.t = Make_binable (struct\n include T\n\n let hash_fold_t state t = hash_fold_int state (hash t)\n end)\n\nmodule Stable : sig\n module V1 : sig\n module type S = sig\n type key\n\n module Table : sig\n type 'a t = (key, 'a) Hashtbl.t [@@deriving sexp, bin_io]\n end\n\n module Hash_set : sig\n type t = key Hash_set.t [@@deriving sexp, bin_io]\n end\n end\n\n module Make (Key : Hashtbl.Key_binable) : S with type key := Key.t\n end\nend = struct\n module V1 = struct\n module type S = sig\n type key\n\n module Table : sig\n type 'a t = (key, 'a) Hashtbl.t [@@deriving sexp, bin_io]\n end\n\n module Hash_set : sig\n type t = key Hash_set.t [@@deriving sexp, bin_io]\n end\n end\n\n module Make (Key : Hashtbl.Key_binable) : S with type key := Key.t = struct\n module Table = Hashtbl.Make_binable (Key)\n module Hash_set = Hash_set.Make_binable (Key)\n end\n end\nend\n","open! Import\nmodule Binable = Binable0\n\nmodule type S_common = sig\n type t [@@deriving compare, hash, sexp_of]\n\n include Stringable.S with type t := t\n include Pretty_printer.S with type t := t\nend\n\nmodule type S_plain = sig\n include S_common\n include Comparable.S_plain with type t := t\n include Hashable.S_plain with type t := t\nend\n\nmodule type S_not_binable = sig\n type t [@@deriving hash, sexp]\n\n include S_common with type t := t\n include Comparable.S with type t := t\n include Hashable.S with type t := t\nend\n\nmodule type S = sig\n type t [@@deriving bin_io, hash, sexp]\n\n include S_common with type t := t\n include Comparable.S_binable with type t := t\n include Hashable.S_binable with type t := t\nend\n\nmodule Make_plain (T : sig\n type t [@@deriving compare, hash, sexp_of]\n\n include Stringable.S with type t := t\n\n val module_name : string\n end) =\nstruct\n include T\n include Comparable.Make_plain (T)\n include Hashable.Make_plain (T)\n include Pretty_printer.Register (T)\nend\n\nmodule Make (T : sig\n type t [@@deriving bin_io, compare, hash, sexp]\n\n include Stringable.S with type t := t\n\n val module_name : string\n end) =\nstruct\n include T\n include Comparable.Make_binable (T)\n include Hashable.Make_binable (T)\n include Pretty_printer.Register (T)\nend\n\nmodule Make_and_derive_hash_fold_t (T : sig\n type t [@@deriving bin_io, compare, sexp]\n\n include Stringable.S with type t := t\n\n val hash : t -> int\n val module_name : string\n end) =\n Make (struct\n include T\n\n let hash_fold_t state t = hash_fold_int state (hash t)\n end)\n\nmodule Make_using_comparator (T : sig\n type t [@@deriving bin_io, compare, hash, sexp]\n\n include Comparator.S with type t := t\n include Stringable.S with type t := t\n\n val module_name : string\n end) =\nstruct\n include T\n include Comparable.Make_binable_using_comparator (T)\n include Hashable.Make_binable (T)\n include Pretty_printer.Register (T)\nend\n\nmodule Make_using_comparator_and_derive_hash_fold_t (T : sig\n type t [@@deriving bin_io, compare, sexp]\n\n include Comparator.S with type t := t\n include Stringable.S with type t := t\n\n val hash : t -> int\n val module_name : string\n end) =\n Make_using_comparator (struct\n include T\n\n let hash_fold_t state t = hash_fold_int state (hash t)\n end)\n\nmodule Extend (M : Base.Identifiable.S) (B : Binable0.S with type t = M.t) = struct\n module T = struct\n include M\n include (B : Binable.S with type t := t)\n end\n\n include T\n include Comparable.Extend_binable (M) (T)\n include Hashable.Make_binable (T)\nend\n","open! Import\n\ntype t = bool [@@deriving bin_io, typerep]\n\ninclude Identifiable.Extend\n (Base.Bool)\n (struct\n type nonrec t = t [@@deriving bin_io]\n end)\n\nmodule Replace_polymorphic_compare = Base.Bool\n\ninclude (\n Base.Bool :\n module type of struct\n include Base.Bool\n end\n with type t := t)\n\nlet quickcheck_generator = Base_quickcheck.Generator.bool\nlet quickcheck_observer = Base_quickcheck.Observer.bool\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.bool\n\nmodule Stable = struct\n module V1 = struct\n type nonrec t = t [@@deriving compare, sexp, bin_io]\n end\nend\n","(** A functor for displaying a type as a sequence of ASCII characters printed in\n hexadecimal.\n\n [sexp_of_t] and [to_string_hum] print [t] in a similar format to 'hexdump' on Unix\n systems. For example, the string \"Back off, man, I'm a scientist.\" renders as:\n\n {v\n00000000 42 61 63 6b 20 6f 66 66 2c 20 6d 61 6e 2c 20 49 |Back off, man, I|\n00000010 27 6d 20 61 20 73 63 69 65 6e 74 69 73 74 2e |'m a scientist.|\n v}\n\n [to_sequence] produces a sequence of strings representing lines in the hex dump. It\n can be used to process a hex dump incrementally, for example with potentially infinite\n values, or to avoid keeping the entire output in memory at once. *)\n\nopen! Import\n\nmodule type S = sig\n type t\n\n module Hexdump : sig\n type nonrec t = t [@@deriving sexp_of]\n\n (** [to_string_hum] renders [t] as a multi-line ASCII string in hexdump format. [pos]\n and [len] select a subrange of [t] to render. [max_lines] determines the maximum\n number of lines of hex dump to produce. If the full hex dump exceeds this number,\n lines in the middle are replaced by a single \"...\"; the beginning and end of the\n hex dump are left intact. In order to produce at least some readable hex dump, at\n least 3 lines are always produced. *)\n val to_string_hum\n : ?max_lines:int (** default: [!default_max_lines] *)\n -> ?pos:int\n -> ?len:int\n -> t\n -> string\n\n (** [to_sequence] produces the lines of [to_string_hum] as a sequence of strings.\n This may be useful for incrementally rendering a large hex dump without producing\n the whole thing in memory. Optional arguments function as in [to_string_hum]. *)\n val to_sequence\n : ?max_lines:int (** default: [!default_max_lines] *)\n -> ?pos:int\n -> ?len:int\n -> t\n -> string Sequence.t\n\n (** [[%sexp_of: Hexdump.Pretty.t]] is the same as [[%sexp_of: Hexdump.t]], unless the\n underlying sequence of characters is entirely printable. In that case, it is\n rendered directly as a string. This allows e.g. test output to be much more\n compact in the common (printable) case while still being interpretable for any\n byte sequence. *)\n module Pretty : sig\n type nonrec t = t [@@deriving sexp_of]\n end\n end\nend\n\nmodule type S1 = sig\n type _ t\n\n module Hexdump : sig\n type nonrec 'a t = 'a t [@@deriving sexp_of]\n\n val to_string_hum : ?max_lines:int -> ?pos:int -> ?len:int -> _ t -> string\n\n\n val to_sequence : ?max_lines:int -> ?pos:int -> ?len:int -> _ t -> string Sequence.t\n\n module Pretty : sig\n type nonrec 'a t = 'a t [@@deriving sexp_of]\n end\n end\nend\n\nmodule type S2 = sig\n type (_, _) t\n\n module Hexdump : sig\n type nonrec ('a, 'b) t = ('a, 'b) t [@@deriving sexp_of]\n\n val to_string_hum : ?max_lines:int -> ?pos:int -> ?len:int -> (_, _) t -> string\n\n val to_sequence\n : ?max_lines:int\n -> ?pos:int\n -> ?len:int\n -> (_, _) t\n -> string Sequence.t\n\n module Pretty : sig\n type nonrec ('a, 'b) t = ('a, 'b) t [@@deriving sexp_of]\n end\n end\nend\n\n(** The functor [Hexdump.Of_indexable] uses [length] and [get] to iterate over the\n characters in a value and produce a hex dump. *)\nmodule type Indexable = sig\n type t\n\n val length : t -> int\n val get : t -> int -> char\nend\n\nmodule type Indexable1 = sig\n type _ t\n\n val length : _ t -> int\n val get : _ t -> int -> char\nend\n\nmodule type Indexable2 = sig\n type (_, _) t\n\n val length : (_, _) t -> int\n val get : (_, _) t -> int -> char\nend\n\nmodule type Hexdump = sig\n module type Indexable = Indexable\n module type Indexable1 = Indexable1\n module type Indexable2 = Indexable2\n module type S = S\n module type S1 = S1\n module type S2 = S2\n\n (** Can be used to override the default [~lines] argument for [to_string_hum] and\n [to_sequence] in [S]. *)\n val default_max_lines : int ref\n\n module Of_indexable (T : Indexable) : S with type t := T.t\n module Of_indexable1 (T : Indexable1) : S1 with type 'a t := 'a T.t\n module Of_indexable2 (T : Indexable2) : S2 with type ('a, 'b) t := ('a, 'b) T.t\nend\n","open! Import\nmodule Char = Base.Char\nmodule Int = Base.Int\nmodule String = Base.String\ninclude Hexdump_intf\n\nlet bytes_per_line = 16\n\n(* Initialize to enough lines to display 4096 bytes -- large enough that, for example, a\n complete Ethernet packet can always be displayed -- including the line containing the\n final index. *)\nlet default_max_lines = ref ((4096 / bytes_per_line) + 1)\n\nmodule Of_indexable2 (T : Indexable2) = struct\n module Hexdump = struct\n include T\n\n let hex_of_pos pos = Printf.sprintf \"%08x\" pos\n\n let hex_of_char t ~start ~until offset =\n let pos = start + offset in\n if pos >= until then \" \" else Printf.sprintf \"%02x\" (Char.to_int (get t pos))\n ;;\n\n let hex_of_line t ~start ~until =\n Printf.sprintf\n \"%s %s %s %s %s %s %s %s %s %s %s %s %s %s %s %s\"\n (hex_of_char t ~start ~until 0)\n (hex_of_char t ~start ~until 1)\n (hex_of_char t ~start ~until 2)\n (hex_of_char t ~start ~until 3)\n (hex_of_char t ~start ~until 4)\n (hex_of_char t ~start ~until 5)\n (hex_of_char t ~start ~until 6)\n (hex_of_char t ~start ~until 7)\n (hex_of_char t ~start ~until 8)\n (hex_of_char t ~start ~until 9)\n (hex_of_char t ~start ~until 10)\n (hex_of_char t ~start ~until 11)\n (hex_of_char t ~start ~until 12)\n (hex_of_char t ~start ~until 13)\n (hex_of_char t ~start ~until 14)\n (hex_of_char t ~start ~until 15)\n ;;\n\n let printable_string t ~start ~until =\n String.init (until - start) ~f:(fun i ->\n let char = get t (start + i) in\n if Char.is_print char then char else '.')\n ;;\n\n let line t ~pos ~len ~line_index =\n let start = pos + (line_index * bytes_per_line) in\n let until = min (start + bytes_per_line) (pos + len) in\n Printf.sprintf\n \"%s %s |%s|\"\n (hex_of_pos start)\n (hex_of_line t ~start ~until)\n (printable_string t ~start ~until)\n ;;\n\n let to_sequence ?max_lines ?pos ?len t =\n let pos, len =\n Ordered_collection_common.get_pos_len_exn () ?pos ?len ~total_length:(length t)\n in\n let max_lines =\n match max_lines with\n | Some max_lines -> max_lines\n | None -> !default_max_lines\n in\n (* always produce at least 3 lines: first line of hex, ellipsis, last line of hex *)\n let max_lines = max max_lines 3 in\n (* unabridged lines = lines of hex + line with final index *)\n let unabridged_lines =\n Int.round_up len ~to_multiple_of:bytes_per_line / bytes_per_line\n in\n (* Figure out where we need to skip from and to if [max_lines < unabridged_lines].\n Skip after half the actual hex lines (subtracting one line for the ellipsis).\n Skip to near the end, less the number of lines remaining to produce, plus the\n ellipsis line. *)\n let skip_from = (max_lines - 1) / 2 in\n let skip_to = unabridged_lines - (max_lines - skip_from) + 1 in\n Sequence.unfold_step ~init:0 ~f:(fun line_index ->\n if line_index >= unabridged_lines\n then Done\n else if line_index = skip_from && max_lines < unabridged_lines\n then Yield (\"...\", skip_to)\n else Yield (line t ~pos ~len ~line_index, line_index + 1))\n ;;\n\n let to_string_hum ?max_lines ?pos ?len t =\n to_sequence ?max_lines ?pos ?len t |> Sequence.to_list |> String.concat ~sep:\"\\n\"\n ;;\n\n let sexp_of_t _ _ t = to_sequence t |> Sequence.to_list |> [%sexp_of: string list]\n\n module Pretty = struct\n include T\n\n let printable =\n let rec printable_from t ~pos ~length =\n pos >= length\n || (Char.is_print (get t pos) && printable_from t ~pos:(pos + 1) ~length)\n in\n fun t -> printable_from t ~pos:0 ~length:(length t)\n ;;\n\n let to_string t = String.init (length t) ~f:(fun pos -> get t pos)\n\n let sexp_of_t sexp_of_a sexp_of_b t =\n if printable t then [%sexp (to_string t : string)] else [%sexp (t : (a, b) t)]\n ;;\n end\n end\nend\n\nmodule Of_indexable1 (T : Indexable1) = struct\n module M = Of_indexable2 (struct\n type ('a, _) t = 'a T.t\n\n let length = T.length\n let get = T.get\n end)\n\n module Hexdump = struct\n include T\n\n let sexp_of_t x t = M.Hexdump.sexp_of_t x [%sexp_of: _] t\n let to_sequence = M.Hexdump.to_sequence\n let to_string_hum = M.Hexdump.to_string_hum\n\n module Pretty = struct\n include T\n\n let sexp_of_t sexp_of_a t = [%sexp (t : (a, _) M.Hexdump.Pretty.t)]\n end\n end\nend\n\nmodule Of_indexable (T : Indexable) = struct\n module M = Of_indexable1 (struct\n type _ t = T.t\n\n let length = T.length\n let get = T.get\n end)\n\n module Hexdump = struct\n include T\n\n let sexp_of_t t = M.Hexdump.sexp_of_t [%sexp_of: _] t\n let to_sequence = M.Hexdump.to_sequence\n let to_string_hum = M.Hexdump.to_string_hum\n\n module Pretty = struct\n include T\n\n let sexp_of_t t = [%sexp (t : _ M.Hexdump.Pretty.t)]\n end\n end\nend\n","open! Import\ninclude Base.String\n\n(* These two are needed because [include Identifiable.Extend] (present later in the file)\n binds new [Map] and [Set] modules. *)\nmodule Core_map = Map\nmodule Core_set = Set\n\nmodule Stable = struct\n module V1 = struct\n module T = struct\n include Base.String\n\n type t = string [@@deriving bin_io]\n end\n\n include T\n\n let to_string = Fn.id\n let of_string = Fn.id\n\n include Comparable.Stable.V1.Make (T)\n include Hashable.Stable.V1.Make (T)\n end\nend\n\nmodule Caseless = struct\n module T = struct\n include Caseless\n\n type t = string [@@deriving bin_io]\n end\n\n include T\n include Comparable.Make_binable_using_comparator (T)\n include Hashable.Make_binable (T)\nend\n\ntype t = string [@@deriving typerep]\n\ninclude Identifiable.Extend\n (Base.String)\n (struct\n type t = string [@@deriving bin_io]\n end)\n\ninclude Hexdump.Of_indexable (struct\n type t = string\n\n let length = length\n let get = get\n end)\n\nlet quickcheck_generator = Base_quickcheck.Generator.string\nlet quickcheck_observer = Base_quickcheck.Observer.string\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.string\nlet gen_nonempty = Base_quickcheck.Generator.string_non_empty\nlet gen' = Base_quickcheck.Generator.string_of\nlet gen_nonempty' = Base_quickcheck.Generator.string_non_empty_of\n\nlet gen_with_length length chars =\n Base_quickcheck.Generator.string_with_length_of chars ~length\n;;\n\nlet take_while t ~f =\n match lfindi t ~f:(fun _ elt -> not (f elt)) with\n | None -> t\n | Some i -> sub t ~pos:0 ~len:i\n;;\n\nlet rtake_while t ~f =\n match rfindi t ~f:(fun _ elt -> not (f elt)) with\n | None -> t\n | Some i -> sub t ~pos:(i + 1) ~len:(length t - i - 1)\n;;\n\n(** See {!Array.normalize} for the following 4 functions. *)\nlet normalize t i = Ordered_collection_common.normalize ~length_fun:length t i\n\nlet slice t start stop =\n Ordered_collection_common.slice ~length_fun:length ~sub_fun:sub t start stop\n;;\n\nlet nget x i =\n let module String = Base.String in\n x.[normalize x i]\n;;\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n include Base.Bytes\n\n type t = bytes [@@deriving bin_io, typerep]\n end\nend\n\ninclude Stable.V1\n\ninclude Hexdump.Of_indexable (struct\n type t = bytes\n\n let length = length\n let get = get\n end)\n\nlet quickcheck_generator =\n String.quickcheck_generator |> Quickcheck.Generator.map ~f:of_string\n;;\n\nlet quickcheck_observer =\n String.quickcheck_observer |> Quickcheck.Observer.unmap ~f:to_string\n;;\n\nlet quickcheck_shrinker =\n String.quickcheck_shrinker |> Quickcheck.Shrinker.map ~f:of_string ~f_inverse:to_string\n;;\n\nlet gen' char_gen = String.gen' char_gen |> Quickcheck.Generator.map ~f:of_string\n\nlet gen_with_length len char_gen =\n String.gen_with_length len char_gen |> Quickcheck.Generator.map ~f:of_string\n;;\n","open! Import\n\ntype t = char [@@deriving typerep]\n\ninclude Identifiable.Extend\n (Base.Char)\n (struct\n type t = char [@@deriving bin_io]\n end)\n\n(* include [Base.Char] after the application of [Identifiable.Extend] to replace the\n [Comparable] functions with the pervasive versions *)\ninclude (\n Base.Char :\n module type of struct\n include Base.Char\n end\n with type t := t)\n\nmodule Caseless = struct\n module T = struct\n include Caseless\n\n type t = char [@@deriving bin_io]\n end\n\n include T\n include Comparable.Make_binable_using_comparator (T)\n include Hashable.Make_binable (T)\nend\n\nmodule Replace_polymorphic_compare = Base.Char\n\nlet quickcheck_generator = Base_quickcheck.Generator.char\nlet quickcheck_observer = Base_quickcheck.Observer.char\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.char\nlet gen_digit = Base_quickcheck.Generator.char_digit\nlet gen_lowercase = Base_quickcheck.Generator.char_lowercase\nlet gen_uppercase = Base_quickcheck.Generator.char_uppercase\nlet gen_alpha = Base_quickcheck.Generator.char_alpha\nlet gen_alphanum = Base_quickcheck.Generator.char_alphanum\nlet gen_print = Base_quickcheck.Generator.char_print\nlet gen_whitespace = Base_quickcheck.Generator.char_whitespace\nlet gen_uniform_inclusive = Base_quickcheck.Generator.char_uniform_inclusive\n","include Caml\n\n(* At Jane Street, the OCaml stdlib is patched to define [Pervasives.raise] as the\n [\"%reraise\"] primitive. We do this as the compiler is currently not good enough at\n automatically detecting reraise [1]. We patch the stdlib so that everything is\n affected, including libraries defined before base such as sexplib or non Jane Street\n libraries.\n\n We need this definition so that this implementation can match its interface with the\n patched stdlib and with the original one.\n\n [[1] http://caml.inria.fr/mantis/view.php?id=6556\n*)\nexternal raise : exn -> 'a = \"%reraise\"\n","open! Import\nmodule Sign = Base.Sign\n\nmodule Stable = struct\n module V1 = struct\n type t = Sign.t =\n | Neg\n | Zero\n | Pos\n [@@deriving sexp, bin_io, compare, hash, typerep, enumerate]\n end\nend\n\ninclude Stable.V1\ninclude Sign\ninclude Identifiable.Extend (Sign) (Stable.V1)\n","external format_float : string -> float -> string = \"caml_format_float\"\n\n(* Stolen from [pervasives.ml]. Adds a \".\" at the end if needed. It is in\n [pervasives.mli], but it also says not to use it directly, so we copy and paste the\n code. It makes the assumption on the string passed in argument that it was returned by\n [format_float] *)\nlet valid_float_lexem s =\n let l = String.length s in\n let rec loop i =\n if i >= l\n then s ^ \".\"\n else (\n match s.[i] with\n | '0' .. '9' | '-' -> loop (i + 1)\n | _ -> s)\n in\n loop 0\n;;\n\nopen! Import\nmodule List = Base.List\n\nmodule T = struct\n include Base.Float\n\n type t = float [@@deriving bin_io, typerep]\nend\n\ninclude T\ninclude Hashable.Make_binable (T)\ninclude Comparable.Map_and_set_binable_using_comparator (T)\nmodule Replace_polymorphic_compare : Comparisons.S with type t := t = T\n\nmodule Robust_compare = struct\n module type S = sig\n (* intended to be a tolerance on human-entered floats *)\n\n val robust_comparison_tolerance : float\n\n include Robustly_comparable.S with type t := float\n end\n\n module Make (T : sig\n val robust_comparison_tolerance : float\n end) : S = struct\n (* We have test in the tree that rely on these functions not allocating, even without\n X_LIBRARY_INLING. The only way to ensure that these don't create temporary boxed\n floats without X_LIBRARY_INLING is for this code to see the float operations as\n externals, as defined in [Pervasives]. That's why we use [Poly] and float\n arithmetic from [Caml]. *)\n open Poly\n\n let robust_comparison_tolerance = T.robust_comparison_tolerance\n let ( >=. ) x y = x >= Caml.( -. ) y robust_comparison_tolerance\n let ( <=. ) x y = y >=. x\n let ( =. ) x y = x >=. y && y >=. x\n let ( >. ) x y = x > Caml.( +. ) y robust_comparison_tolerance\n let ( <. ) x y = y >. x\n let ( <>. ) x y = not (x =. y)\n\n let robustly_compare x y =\n let d = Caml.( -. ) x y in\n if d < Caml.( ~-. ) robust_comparison_tolerance\n then -1\n else if d > robust_comparison_tolerance\n then 1\n else 0\n ;;\n end\nend\n\nmodule Robustly_comparable = Robust_compare.Make (struct\n let robust_comparison_tolerance = 1E-7\n end)\n\ninclude Robustly_comparable\n\nmodule O = struct\n include Base.Float.O\n include Robustly_comparable\nend\n\nmodule Terse = struct\n type nonrec t = t [@@deriving bin_io]\n\n include (\n Base.Float.Terse :\n module type of struct\n include Base.Float.Terse\n end\n with type t := t)\nend\n\nlet robust_sign t : Sign.t = if t >. 0. then Pos else if t <. 0. then Neg else Zero\n\n(* There are two issues:\n - Float.sign used to use robust comparison, and users of [Core] might have come to\n depend on this.\n - Robustness aside, what we get from Comparable.With_zero would map nan to Neg.\n*)\nlet sign = robust_sign\n\n(* Standard 12 significant digits, exponential notation used as necessary, guaranteed to\n be a valid OCaml float lexem, not to look like an int. *)\nlet to_string_12 x = valid_float_lexem (format_float \"%.12g\" x)\nlet quickcheck_generator = Base_quickcheck.Generator.float\nlet quickcheck_observer = Base_quickcheck.Observer.float\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.float\nlet gen_uniform_excl = Base_quickcheck.Generator.float_uniform_exclusive\nlet gen_incl = Base_quickcheck.Generator.float_inclusive\nlet gen_without_nan = Base_quickcheck.Generator.float_without_nan\nlet gen_finite = Base_quickcheck.Generator.float_finite\nlet gen_positive = Base_quickcheck.Generator.float_strictly_positive\nlet gen_negative = Base_quickcheck.Generator.float_strictly_negative\nlet gen_zero = Base_quickcheck.Generator.float_of_class Zero\nlet gen_nan = Base_quickcheck.Generator.float_of_class Nan\nlet gen_subnormal = Base_quickcheck.Generator.float_of_class Subnormal\nlet gen_normal = Base_quickcheck.Generator.float_of_class Normal\nlet gen_infinite = Base_quickcheck.Generator.float_of_class Infinite\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n module T = struct\n include Base.Int\n\n type t = int [@@deriving hash, bin_io, sexp]\n end\n\n include T\n include Comparable.Stable.V1.Make (T)\n end\nend\n\ninclude Identifiable.Extend\n (Base.Int)\n (struct\n type t = int [@@deriving bin_io]\n end)\n\nmodule Replace_polymorphic_compare = Base.Int\ninclude Base.Int\n\ntype t = int [@@deriving typerep]\n\nmodule Hex = struct\n include Hex\n\n type nonrec t = t [@@deriving typerep, bin_io]\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.int\nlet quickcheck_observer = Base_quickcheck.Observer.int\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.int\nlet gen_incl = Base_quickcheck.Generator.int_inclusive\nlet gen_uniform_incl = Base_quickcheck.Generator.int_uniform_inclusive\nlet gen_log_incl = Base_quickcheck.Generator.int_log_inclusive\nlet gen_log_uniform_incl = Base_quickcheck.Generator.int_log_uniform_inclusive\n","open! Import\n\ninclude Identifiable.Extend\n (Base.Int32)\n (struct\n type t = int32 [@@deriving bin_io]\n end)\n\ninclude Base.Int32\n\ntype t = int32 [@@deriving typerep]\n\nmodule Hex = struct\n include Hex\n\n type nonrec t = t [@@deriving typerep, bin_io]\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.int32\nlet quickcheck_observer = Base_quickcheck.Observer.int32\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.int32\nlet gen_incl = Base_quickcheck.Generator.int32_inclusive\nlet gen_uniform_incl = Base_quickcheck.Generator.int32_uniform_inclusive\nlet gen_log_incl = Base_quickcheck.Generator.int32_log_inclusive\nlet gen_log_uniform_incl = Base_quickcheck.Generator.int32_log_uniform_inclusive\n","(* unsigned_extended.ml *)\n\nopen Core_kernel\ninclude Intf\nopen Snark_params\nopen Tick\n\nmodule type Unsigned_intf = Unsigned.S\n\nmodule Extend\n (Unsigned : Unsigned.S) (M : sig\n val length : int\n end) : S with type t = Unsigned.t = struct\n assert (M.length < Field.size_in_bits - 3)\n\n let length_in_bits = M.length\n\n module T = struct\n include Sexpable.Of_stringable (Unsigned)\n\n type t = Unsigned.t\n\n let compare = Unsigned.compare\n\n let hash_fold_t s t = Int64.hash_fold_t s (Unsigned.to_int64 t)\n\n let hash t = Int64.hash (Unsigned.to_int64 t)\n\n let to_bigint t =\n let i64 = Unsigned.to_int64 t in\n if Int64.(i64 >= 0L) then Bignum_bigint.of_int64 i64\n else\n Bignum_bigint.(\n of_int64 i64 - of_int64 Int64.min_value + of_int64 Int64.max_value\n + one)\n end\n\n include T\n include Hashable.Make (T)\n\n include (Unsigned : Unsigned_intf with type t := t)\n\n (* serializes to and from json as strings since bit lengths > 32 cannot be represented in json *)\n let to_yojson n = `String (to_string n)\n\n let of_yojson = function\n | `String s ->\n Ok (of_string s)\n | _ ->\n Error \"expected string\"\n\n let ( < ) x y = compare x y < 0\n\n let ( > ) x y = compare x y > 0\n\n let ( = ) x y = compare x y = 0\n\n let ( <= ) x y = compare x y <= 0\n\n let ( >= ) x y = compare x y >= 0\nend\n\nmodule UInt64 = struct\n module M =\n Extend\n (Unsigned.UInt64)\n (struct\n let length = 64\n end)\n\n (* this module allows use to generate With_all_version_tags from the\n Binable.Of_binable functor below, needed to decode transaction ids\n for V1 signed commands; it does not add any tags\n *)\n module Int64_for_version_tags = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t = (Int64.t[@version_asserted])\n\n let to_latest = Fn.id\n\n module With_all_version_tags = struct\n type typ = t [@@deriving bin_io_unversioned]\n\n type t = typ [@@deriving bin_io_unversioned]\n end\n end\n end]\n end\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Unsigned.UInt64.t\n\n let to_latest = Fn.id\n\n (* these are defined in the Extend functor, rather than derived, so import them *)\n [%%define_locally\n M.\n ( equal\n , compare\n , hash\n , hash_fold_t\n , sexp_of_t\n , t_of_sexp\n , to_yojson\n , of_yojson )]\n\n module M = struct\n type t = Unsigned.UInt64.t\n\n let to_binable = Unsigned.UInt64.to_int64\n\n let of_binable = Unsigned.UInt64.of_int64\n end\n\n include Binable.Of_binable (Int64_for_version_tags.Stable.V1) (M)\n end\n end]\n\n include M\n\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n\n let to_uint64 : t -> uint64 = Fn.id\n\n let of_uint64 : uint64 -> t = Fn.id\nend\n\nmodule UInt32 = struct\n module M =\n Extend\n (Unsigned.UInt32)\n (struct\n let length = 32\n end)\n\n (* this module allows use to generate With_all_version_tags from the\n Binable.Of_binable functor below, needed to decode transaction ids\n for V1 signed commands; it does not add any tags\n *)\n module Int32_for_version_tags = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t = (Int32.t[@version_asserted])\n\n let to_latest = Fn.id\n\n module With_all_version_tags = struct\n type typ = t [@@deriving bin_io_unversioned]\n\n type t = typ [@@deriving bin_io_unversioned]\n end\n end\n end]\n end\n\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Unsigned.UInt32.t\n\n let to_latest = Fn.id\n\n (* these are defined in the Extend functor, rather than derived, so import them *)\n [%%define_locally\n M.\n ( equal\n , compare\n , hash\n , hash_fold_t\n , sexp_of_t\n , t_of_sexp\n , to_yojson\n , of_yojson )]\n\n module M = struct\n type t = Unsigned.UInt32.t\n\n let to_binable = Unsigned.UInt32.to_int32\n\n let of_binable = Unsigned.UInt32.of_int32\n end\n\n include Binable.Of_binable (Int32_for_version_tags.Stable.V1) (M)\n end\n end]\n\n include M\n\n let to_uint32 : t -> uint32 = Fn.id\n\n let of_uint32 : uint32 -> t = Fn.id\nend\n","open! Import\n\ninclude Identifiable.Extend\n (Base.Int64)\n (struct\n type t = int64 [@@deriving bin_io]\n end)\n\ninclude Base.Int64\n\ntype t = int64 [@@deriving typerep]\n\nmodule Hex = struct\n include Hex\n\n type nonrec t = t [@@deriving typerep, bin_io]\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.int64\nlet quickcheck_observer = Base_quickcheck.Observer.int64\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.int64\nlet gen_incl = Base_quickcheck.Generator.int64_inclusive\nlet gen_uniform_incl = Base_quickcheck.Generator.int64_uniform_inclusive\nlet gen_log_incl = Base_quickcheck.Generator.int64_log_inclusive\nlet gen_log_uniform_incl = Base_quickcheck.Generator.int64_log_uniform_inclusive\n","open! Import\n\nmodule Bin : Binable0.S with type t := Base.Int63.t = struct\n module Bin_emulated = struct\n type t = Base.Int63.Private.Emul.t\n\n include Binable0.Of_binable_without_uuid [@alert \"-legacy\"]\n (Int64)\n (struct\n type nonrec t = t\n\n let of_binable = Base.Int63.Private.Emul.W.wrap_exn\n let to_binable = Base.Int63.Private.Emul.W.unwrap\n end)\n end\n\n type 'a binable = (module Binable0.S with type t = 'a)\n\n let binable_of_repr : type a b. (a, b) Base.Int63.Private.Repr.t -> b binable\n = function\n | Base.Int63.Private.Repr.Int -> (module Int)\n | Base.Int63.Private.Repr.Int64 -> (module Bin_emulated)\n ;;\n\n let binable : Base.Int63.t binable = binable_of_repr Base.Int63.Private.repr\n\n include (val binable)\n\n let bin_shape_t = Bin_prot.Shape.bin_shape_int63\nend\n\nmodule Stable = struct\n module V1 = struct\n module T = struct\n type t = Base.Int63.t [@@deriving hash, sexp]\n\n include Bin\n\n include (\n Base.Int63 :\n Base.Comparable.S\n with type t := t\n with type comparator_witness = Base.Int63.comparator_witness)\n end\n\n include T\n include Comparable.Stable.V1.Make (T)\n end\nend\n\n(* This [include struct] is required because it lets us shadow [t] when we include\n [Base.Int63] later on. *)\ninclude struct\n type t = Base.Int63.t\nend\n\nlet typerep_of_t = typerep_of_int63\nlet typename_of_t = typename_of_int63\n\ninclude Identifiable.Extend\n (Base.Int63)\n (struct\n type nonrec t = t\n\n include Bin\n end)\n\nmodule Replace_polymorphic_compare : Comparable.Polymorphic_compare with type t := t =\n Base.Int63\n\ninclude Base.Int63\n\nmodule Hex = struct\n include Hex\n\n type nonrec t = t [@@deriving typerep, bin_io]\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.int63\nlet quickcheck_observer = Base_quickcheck.Observer.int63\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.int63\nlet gen_incl = Base_quickcheck.Generator.int63_inclusive\nlet gen_uniform_incl = Base_quickcheck.Generator.int63_uniform_inclusive\nlet gen_log_incl = Base_quickcheck.Generator.int63_log_inclusive\nlet gen_log_uniform_incl = Base_quickcheck.Generator.int63_log_uniform_inclusive\n","module Stable = struct\n open Base.Export\n open Bin_prot.Std\n\n module V1 = struct\n module T = struct\n type t = unit [@@deriving bin_io, compare, sexp]\n end\n\n include T\n include Comparator.Stable.V1.Make (T)\n\n let%expect_test _ =\n print_endline [%bin_digest: t];\n [%expect {| 86ba5df747eec837f0b391dd49f33f9e |}]\n ;;\n end\nend\n\nopen! Import\n\ninclude Identifiable.Extend\n (Base.Unit)\n (struct\n type t = unit [@@deriving bin_io]\n end)\n\ninclude Base.Unit\n\ntype t = unit [@@deriving typerep]\n\nlet quickcheck_generator = Base_quickcheck.Generator.unit\nlet quickcheck_observer = Base_quickcheck.Observer.unit\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.unit\n\nmodule type S = sig end\n\ntype m = (module S)\n","(** Various interface exports. *)\n\nopen! Import\n\nmodule type Applicative = Applicative.S\nmodule type Binable = Binable0.S\nmodule type Comparable = Comparable.S\nmodule type Comparable_binable = Comparable.S_binable\nmodule type Floatable = Floatable.S\nmodule type Hashable = Hashable.S\nmodule type Hashable_binable = Hashable.S_binable\nmodule type Identifiable = Identifiable.S\nmodule type Infix_comparators = Comparable.Infix\nmodule type Intable = Intable.S\nmodule type Monad = Monad.S\nmodule type Quickcheckable = Quickcheckable.S\nmodule type Robustly_comparable = Robustly_comparable.S\nmodule type Sexpable = Sexpable.S\nmodule type Stable = Stable_module_types.S0\nmodule type Stable_int63able = Stable_int63able.S\nmodule type Stable_without_comparator = Stable_module_types.S0_without_comparator\nmodule type Stable1 = Stable_module_types.S1\nmodule type Stable2 = Stable_module_types.S2\nmodule type Stable3 = Stable_module_types.S3\nmodule type Stable4 = Stable_module_types.S4\nmodule type Stringable = Stringable.S\nmodule type Unit = Unit.S\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n open Sexplib.Std\n\n type 'a t = 'a lazy_t [@@deriving bin_io, sexp, typerep]\n\n let map = Base.Lazy.map\n let compare = Base.Lazy.compare\n let t_sexp_grammar = lazy_t_sexp_grammar\n end\nend\n\nmodule type Base_mask = module type of Base.Lazy with type 'a t := 'a Stable.V1.t\n\ninclude Stable.V1\ninclude (Base.Lazy : Base_mask)\n","open! Import\n\ninclude Identifiable.Extend\n (Base.Nativeint)\n (struct\n type t = nativeint [@@deriving bin_io]\n end)\n\ninclude Base.Nativeint\n\ntype t = nativeint [@@deriving typerep]\n\nmodule Hex = struct\n include Hex\n\n type nonrec t = t [@@deriving typerep, bin_io]\nend\n\nlet quickcheck_generator = Base_quickcheck.Generator.nativeint\nlet quickcheck_observer = Base_quickcheck.Observer.nativeint\nlet quickcheck_shrinker = Base_quickcheck.Shrinker.nativeint\nlet gen_incl = Base_quickcheck.Generator.nativeint_inclusive\nlet gen_uniform_incl = Base_quickcheck.Generator.nativeint_uniform_inclusive\nlet gen_log_incl = Base_quickcheck.Generator.nativeint_log_inclusive\nlet gen_log_uniform_incl = Base_quickcheck.Generator.nativeint_log_uniform_inclusive\n","open! Import\n\nmodule Stable = struct\n module V1 = struct\n type t = Base.Nothing.t = |\n\n module Shape = struct\n type t [@@deriving bin_shape]\n end\n\n let unreachable_code = Base.Nothing.unreachable_code\n let bin_shape_t = Shape.bin_shape_t\n let tp_loc = [%here].pos_fname ^ \".Stable.V1.t\"\n let all = []\n let hash_fold_t _ t = unreachable_code t\n let hash = unreachable_code\n let compare a _ = unreachable_code a\n let bin_size_t = unreachable_code\n let bin_write_t _buf ~pos:_ t = unreachable_code t\n let bin_writer_t = { Bin_prot.Type_class.size = bin_size_t; write = bin_write_t }\n\n let __bin_read_t__ _buf ~pos_ref _ =\n Bin_prot.Common.raise_variant_wrong_type tp_loc !pos_ref\n ;;\n\n let bin_read_t _buf ~pos_ref =\n Bin_prot.Common.raise_read_error (Empty_type tp_loc) !pos_ref\n ;;\n\n let bin_reader_t =\n { Bin_prot.Type_class.read = bin_read_t; vtag_read = __bin_read_t__ }\n ;;\n\n let bin_t =\n { Bin_prot.Type_class.writer = bin_writer_t\n ; reader = bin_reader_t\n ; shape = bin_shape_t\n }\n ;;\n\n let sexp_of_t = unreachable_code\n let t_of_sexp sexp = Sexplib.Conv_error.empty_type tp_loc sexp\n end\nend\n\ninclude Stable.V1\ninclude Base.Nothing\ninclude Identifiable.Extend (Base.Nothing) (Stable.V1)\n","open! Import\n\ntype t = Base.Ordering.t =\n | Less\n | Equal\n | Greater\n[@@deriving bin_io, compare, hash, sexp]\n\nmodule type Base_mask = module type of Base.Ordering with type t := t\n\ninclude (Base.Ordering : Base_mask)\n","open! Import\n\nmodule T = struct\n include Base.Ref\n\n include (\n struct\n type 'a t = 'a ref [@@deriving bin_io, typerep]\n end :\n sig\n type 'a t = 'a ref [@@deriving bin_io, typerep]\n end\n with type 'a t := 'a t)\nend\n\ninclude T\n\nmodule Permissioned = struct\n include T\n\n type ('a, -'perms) t = 'a T.t [@@deriving bin_io, sexp]\n\n let read_only = Fn.id\n let of_ref = Fn.id\n let to_ref = Fn.id\n let set = ( := )\n let get = ( ! )\nend\n","(* zkapp_command_logic.ml *)\n\nopen Core_kernel\nopen Mina_base\n\nmodule type Iffable = sig\n type bool\n\n type t\n\n val if_ : bool -> then_:t -> else_:t -> t\nend\n\nmodule type Bool_intf = sig\n type t\n\n include Iffable with type t := t and type bool := t\n\n val true_ : t\n\n val false_ : t\n\n val equal : t -> t -> t\n\n val not : t -> t\n\n val ( ||| ) : t -> t -> t\n\n val ( &&& ) : t -> t -> t\n\n module Assert : sig\n (* [pos] is file,line,col,endcol from __POS__ *)\n val is_true : pos:string * int * int * int -> t -> unit\n\n (* [pos] is file,line,col,endcol from __POS__ *)\n val any : pos:string * int * int * int -> t list -> unit\n end\n\n val display : t -> label:string -> string\n\n val all : t list -> t\n\n type failure_status\n\n type failure_status_tbl\n\n (* [pos] is file,line,col,endcol from __POS__ *)\n val assert_with_failure_status_tbl :\n pos:string * int * int * int -> t -> failure_status_tbl -> unit\nend\n\nmodule type Balance_intf = sig\n include Iffable\n\n type amount\n\n type signed_amount\n\n val sub_amount_flagged : t -> amount -> t * [ `Underflow of bool ]\n\n val add_signed_amount_flagged : t -> signed_amount -> t * [ `Overflow of bool ]\nend\n\nmodule type Receipt_chain_hash_intf = sig\n include Iffable\n\n type transaction_commitment\n\n type index\n\n module Elt : sig\n type t\n\n val of_transaction_commitment : transaction_commitment -> t\n end\n\n val cons_zkapp_command_commitment : index -> Elt.t -> t -> t\nend\n\nmodule type Amount_intf = sig\n include Iffable\n\n type unsigned = t\n\n module Signed : sig\n include Iffable with type bool := bool\n\n val equal : t -> t -> bool\n\n val is_neg : t -> bool\n\n val is_non_neg : t -> bool\n\n val negate : t -> t\n\n val add_flagged : t -> t -> t * [ `Overflow of bool ]\n\n val of_unsigned : unsigned -> t\n end\n\n val zero : t\n\n val equal : t -> t -> bool\n\n val add_flagged : t -> t -> t * [ `Overflow of bool ]\n\n val add_signed_flagged : t -> Signed.t -> t * [ `Overflow of bool ]\n\n val of_constant_fee : Currency.Fee.t -> t\nend\n\nmodule type Account_id_intf = sig\n include Iffable\n\n type public_key\n\n type token_id\n\n val invalid : t\n\n val equal : t -> t -> bool\n\n val create : public_key -> token_id -> t\n\n val derive_token_id : owner:t -> token_id\nend\n\nmodule type Global_slot_since_genesis_intf = sig\n include Iffable\n\n val zero : t\n\n val ( > ) : t -> t -> bool\n\n val equal : t -> t -> bool\nend\n\nmodule type Global_slot_span_intf = sig\n include Iffable\n\n val zero : t\n\n val ( > ) : t -> t -> bool\nend\n\nmodule type Verification_key_hash_intf = sig\n type t\n\n type bool\n\n val equal : t -> t -> bool\nend\n\nmodule type Timing_intf = sig\n include Iffable\n\n type global_slot_span\n\n val vesting_period : t -> global_slot_span\nend\n\nmodule type Token_id_intf = sig\n include Iffable\n\n val equal : t -> t -> bool\n\n val default : t\nend\n\nmodule type Actions_intf = sig\n type t\n\n type bool\n\n type field\n\n val is_empty : t -> bool\n\n val push_events : field -> t -> field\nend\n\nmodule type Protocol_state_precondition_intf = sig\n type t\nend\n\nmodule type Valid_while_precondition_intf = sig\n type t\nend\n\nmodule Local_state = struct\n open Core_kernel\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ( 'stack_frame\n , 'call_stack\n , 'signed_amount\n , 'ledger\n , 'bool\n , 'comm\n , 'length\n , 'failure_status_tbl )\n t =\n ( 'stack_frame\n , 'call_stack\n , 'signed_amount\n , 'ledger\n , 'bool\n , 'comm\n , 'length\n , 'failure_status_tbl )\n Mina_wire_types.Mina_transaction_logic.Zkapp_command_logic\n .Local_state\n .V1\n .t =\n { stack_frame : 'stack_frame\n ; call_stack : 'call_stack\n ; transaction_commitment : 'comm\n ; full_transaction_commitment : 'comm\n ; excess : 'signed_amount\n ; supply_increase : 'signed_amount\n ; ledger : 'ledger\n ; success : 'bool\n ; account_update_index : 'length\n ; failure_status_tbl : 'failure_status_tbl\n ; will_succeed : 'bool\n }\n [@@deriving compare, equal, hash, sexp, yojson, fields, hlist]\n end\n end]\n\n let typ stack_frame call_stack excess supply_increase ledger bool comm length\n failure_status_tbl =\n Pickles.Impls.Step.Typ.of_hlistable\n [ stack_frame\n ; call_stack\n ; comm\n ; comm\n ; excess\n ; supply_increase\n ; ledger\n ; bool\n ; length\n ; failure_status_tbl\n ; bool\n ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n module Value = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n ( Mina_base.Stack_frame.Digest.Stable.V1.t\n , Mina_base.Call_stack_digest.Stable.V1.t\n , ( Currency.Amount.Stable.V1.t\n , Sgn.Stable.V1.t )\n Currency.Signed_poly.Stable.V1.t\n , Ledger_hash.Stable.V1.t\n , bool\n , Zkapp_command.Transaction_commitment.Stable.V1.t\n , Mina_numbers.Index.Stable.V1.t\n , Transaction_status.Failure.Collection.Stable.V1.t )\n Stable.V1.t\n [@@deriving equal, compare, hash, yojson, sexp]\n\n let to_latest = Fn.id\n end\n end]\n end\n\n module Checked = struct\n open Pickles.Impls.Step\n\n type t =\n ( Stack_frame.Digest.Checked.t\n , Call_stack_digest.Checked.t\n , Currency.Amount.Signed.Checked.t\n , Ledger_hash.var\n , Boolean.var\n , Zkapp_command.Transaction_commitment.Checked.t\n , Mina_numbers.Index.Checked.t\n , unit )\n Stable.Latest.t\n end\nend\n\nmodule type Set_or_keep_intf = sig\n type _ t\n\n type bool\n\n val is_set : _ t -> bool\n\n val is_keep : _ t -> bool\n\n val set_or_keep : if_:(bool -> then_:'a -> else_:'a -> 'a) -> 'a t -> 'a -> 'a\nend\n\nmodule type Account_update_intf = sig\n type t\n\n type bool\n\n type call_forest\n\n type signed_amount\n\n type transaction_commitment\n\n type protocol_state_precondition\n\n type valid_while_precondition\n\n type public_key\n\n type token_id\n\n type account_id\n\n type account\n\n type nonce\n\n type verification_key_hash\n\n type _ or_ignore\n\n val balance_change : t -> signed_amount\n\n val protocol_state_precondition : t -> protocol_state_precondition\n\n val valid_while_precondition : t -> valid_while_precondition\n\n val public_key : t -> public_key\n\n val token_id : t -> token_id\n\n val account_id : t -> account_id\n\n val may_use_parents_own_token : t -> bool\n\n val may_use_token_inherited_from_parent : t -> bool\n\n val use_full_commitment : t -> bool\n\n val increment_nonce : t -> bool\n\n val implicit_account_creation_fee : t -> bool\n\n val check_authorization :\n will_succeed:bool\n -> commitment:transaction_commitment\n -> calls:call_forest\n -> t\n -> [ `Proof_verifies of bool ] * [ `Signature_verifies of bool ]\n\n val is_signed : t -> bool\n\n val is_proved : t -> bool\n\n val verification_key_hash : t -> verification_key_hash\n\n module Update : sig\n type _ set_or_keep\n\n type timing\n\n val timing : t -> timing set_or_keep\n\n type field\n\n val app_state : t -> field set_or_keep Zkapp_state.V.t\n\n type verification_key\n\n val verification_key : t -> verification_key set_or_keep\n\n type actions\n\n val actions : t -> actions\n\n type zkapp_uri\n\n val zkapp_uri : t -> zkapp_uri set_or_keep\n\n type token_symbol\n\n val token_symbol : t -> token_symbol set_or_keep\n\n val delegate : t -> public_key set_or_keep\n\n type state_hash\n\n val voting_for : t -> state_hash set_or_keep\n\n type permissions\n\n val permissions : t -> permissions set_or_keep\n end\n\n module Account_precondition : sig\n val nonce : t -> nonce Zkapp_precondition.Closed_interval.t or_ignore\n end\nend\n\nmodule type Opt_intf = sig\n type bool\n\n type 'a t\n\n val is_some : 'a t -> bool\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val or_default :\n if_:(bool -> then_:'a -> else_:'a -> 'a) -> 'a t -> default:'a -> 'a\n\n val or_exn : 'a t -> 'a\nend\n\nmodule type Stack_intf = sig\n include Iffable\n\n module Opt : Opt_intf with type bool := bool\n\n type elt\n\n val empty : unit -> t\n\n val is_empty : t -> bool\n\n val pop_exn : t -> elt * t\n\n val pop : t -> (elt * t) Opt.t\n\n val push : elt -> onto:t -> t\nend\n\nmodule type Call_forest_intf = sig\n include Iffable\n\n type account_update\n\n module Opt : Opt_intf with type bool := bool\n\n val empty : unit -> t\n\n val is_empty : t -> bool\n\n val pop_exn : t -> (account_update * t) * t\nend\n\nmodule type Stack_frame_intf = sig\n type caller\n\n type call_forest\n\n include Iffable\n\n val caller : t -> caller\n\n val caller_caller : t -> caller\n\n val calls : t -> call_forest\n\n val make : caller:caller -> caller_caller:caller -> calls:call_forest -> t\nend\n\nmodule type Call_stack_intf = sig\n type stack_frame\n\n include Stack_intf with type elt := stack_frame\nend\n\nmodule type Ledger_intf = sig\n include Iffable\n\n type public_key\n\n type token_id\n\n type account_update\n\n type account\n\n type inclusion_proof\n\n val empty : depth:int -> unit -> t\n\n val get_account : account_update -> t -> account * inclusion_proof\n\n val set_account : t -> account * inclusion_proof -> t\n\n val check_inclusion : t -> account * inclusion_proof -> unit\n\n val check_account :\n public_key -> token_id -> account * inclusion_proof -> [ `Is_new of bool ]\nend\n\nmodule type Controller_intf = sig\n include Iffable\n\n val check : proof_verifies:bool -> signature_verifies:bool -> t -> bool\nend\n\nmodule type Account_intf = sig\n type t\n\n type bool\n\n type public_key\n\n type account_id\n\n module Permissions : sig\n type controller\n\n val access : t -> controller\n\n val edit_state : t -> controller\n\n val send : t -> controller\n\n val receive : t -> controller\n\n val set_delegate : t -> controller\n\n val set_permissions : t -> controller\n\n val set_verification_key : t -> controller\n\n val set_zkapp_uri : t -> controller\n\n val edit_action_state : t -> controller\n\n val set_token_symbol : t -> controller\n\n val increment_nonce : t -> controller\n\n val set_voting_for : t -> controller\n\n val set_timing : t -> controller\n\n include Iffable with type bool := bool\n end\n\n type timing\n\n type token_id\n\n type receipt_chain_hash\n\n val timing : t -> timing\n\n val set_timing : t -> timing -> t\n\n val is_timed : t -> bool\n\n val set_token_id : t -> token_id -> t\n\n type balance\n\n val balance : t -> balance\n\n val set_balance : balance -> t -> t\n\n type global_slot\n\n val check_timing :\n txn_global_slot:global_slot\n -> t\n -> [ `Invalid_timing of bool | `Insufficient_balance of bool ] * timing\n\n val receipt_chain_hash : t -> receipt_chain_hash\n\n val set_receipt_chain_hash : t -> receipt_chain_hash -> t\n\n (** Fill the zkapp field of the account if it's currently [None] *)\n val make_zkapp : t -> t\n\n (** If the current account has no zkApp fields set, reset its zkapp field to\n [None].\n *)\n val unmake_zkapp : t -> t\n\n val proved_state : t -> bool\n\n val set_proved_state : bool -> t -> t\n\n type field\n\n val app_state : t -> field Zkapp_state.V.t\n\n val set_app_state : field Zkapp_state.V.t -> t -> t\n\n val register_verification_key : t -> unit\n\n type verification_key\n\n val verification_key : t -> verification_key\n\n val set_verification_key : verification_key -> t -> t\n\n type verification_key_hash\n\n val verification_key_hash : t -> verification_key_hash\n\n val last_action_slot : t -> global_slot\n\n val set_last_action_slot : global_slot -> t -> t\n\n val action_state : t -> field Pickles_types.Vector.Vector_5.t\n\n val set_action_state : field Pickles_types.Vector.Vector_5.t -> t -> t\n\n type zkapp_uri\n\n val zkapp_uri : t -> zkapp_uri\n\n val set_zkapp_uri : zkapp_uri -> t -> t\n\n type token_symbol\n\n val token_symbol : t -> token_symbol\n\n val set_token_symbol : token_symbol -> t -> t\n\n val public_key : t -> public_key\n\n val set_public_key : public_key -> t -> t\n\n val delegate : t -> public_key\n\n val set_delegate : public_key -> t -> t\n\n type nonce\n\n val nonce : t -> nonce\n\n val set_nonce : nonce -> t -> t\n\n type state_hash\n\n val voting_for : t -> state_hash\n\n val set_voting_for : state_hash -> t -> t\n\n val permissions : t -> Permissions.t\n\n val set_permissions : Permissions.t -> t -> t\nend\n\nmodule Eff = struct\n type (_, _) t =\n | Check_valid_while_precondition :\n 'valid_while_precondition * 'global_state\n -> ( 'bool\n , < bool : 'bool\n ; valid_while_precondition : 'valid_while_precondition\n ; global_state : 'global_state\n ; .. > )\n t\n | Check_account_precondition :\n (* the bool input is a new_account flag *)\n 'account_update\n * 'account\n * 'bool\n * 'local_state\n -> ( 'local_state\n , < bool : 'bool\n ; account_update : 'account_update\n ; account : 'account\n ; local_state : 'local_state\n ; .. > )\n t\n | Check_protocol_state_precondition :\n 'protocol_state_pred * 'global_state\n -> ( 'bool\n , < bool : 'bool\n ; global_state : 'global_state\n ; protocol_state_precondition : 'protocol_state_pred\n ; .. > )\n t\n | Init_account :\n { account_update : 'account_update; account : 'account }\n -> ( 'account\n , < account_update : 'account_update ; account : 'account ; .. > )\n t\nend\n\ntype 'e handler = { perform : 'r. ('r, 'e) Eff.t -> 'r }\n\nmodule type Inputs_intf = sig\n val with_label : label:string -> (unit -> 'a) -> 'a\n\n module Bool : Bool_intf\n\n module Field : Iffable with type bool := Bool.t\n\n module Amount : Amount_intf with type bool := Bool.t\n\n module Balance :\n Balance_intf\n with type bool := Bool.t\n and type amount := Amount.t\n and type signed_amount := Amount.Signed.t\n\n module Public_key : Iffable with type bool := Bool.t\n\n module Token_id : Token_id_intf with type bool := Bool.t\n\n module Account_id :\n Account_id_intf\n with type bool := Bool.t\n and type public_key := Public_key.t\n and type token_id := Token_id.t\n\n module Set_or_keep : Set_or_keep_intf with type bool := Bool.t\n\n module Protocol_state_precondition : Protocol_state_precondition_intf\n\n module Valid_while_precondition : Valid_while_precondition_intf\n\n module Controller : Controller_intf with type bool := Bool.t\n\n module Global_slot_since_genesis :\n Global_slot_since_genesis_intf with type bool := Bool.t\n\n module Global_slot_span : Global_slot_span_intf with type bool := Bool.t\n\n module Nonce : sig\n include Iffable with type bool := Bool.t\n\n val succ : t -> t\n end\n\n module State_hash : Iffable with type bool := Bool.t\n\n module Timing :\n Timing_intf\n with type bool := Bool.t\n and type global_slot_span := Global_slot_span.t\n\n module Zkapp_uri : Iffable with type bool := Bool.t\n\n module Token_symbol : Iffable with type bool := Bool.t\n\n module Opt : Opt_intf with type bool := Bool.t\n\n module rec Receipt_chain_hash :\n (Receipt_chain_hash_intf\n with type bool := Bool.t\n and type transaction_commitment := Transaction_commitment.t\n and type index := Index.t)\n\n and Verification_key : (Iffable with type bool := Bool.t)\n and Verification_key_hash :\n (Verification_key_hash_intf with type bool := Bool.t)\n\n and Account :\n (Account_intf\n with type Permissions.controller := Controller.t\n and type timing := Timing.t\n and type balance := Balance.t\n and type receipt_chain_hash := Receipt_chain_hash.t\n and type bool := Bool.t\n and type global_slot := Global_slot_since_genesis.t\n and type field := Field.t\n and type verification_key := Verification_key.t\n and type verification_key_hash := Verification_key_hash.t\n and type zkapp_uri := Zkapp_uri.t\n and type token_symbol := Token_symbol.t\n and type public_key := Public_key.t\n and type nonce := Nonce.t\n and type state_hash := State_hash.t\n and type token_id := Token_id.t\n and type account_id := Account_id.t)\n\n and Actions :\n (Actions_intf with type bool := Bool.t and type field := Field.t)\n\n and Account_update :\n (Account_update_intf\n with type signed_amount := Amount.Signed.t\n and type protocol_state_precondition := Protocol_state_precondition.t\n and type valid_while_precondition := Valid_while_precondition.t\n and type token_id := Token_id.t\n and type bool := Bool.t\n and type account := Account.t\n and type public_key := Public_key.t\n and type nonce := Nonce.t\n and type account_id := Account_id.t\n and type verification_key_hash := Verification_key_hash.t\n and type Update.timing := Timing.t\n and type 'a Update.set_or_keep := 'a Set_or_keep.t\n and type Update.field := Field.t\n and type Update.verification_key := Verification_key.t\n and type Update.actions := Actions.t\n and type Update.zkapp_uri := Zkapp_uri.t\n and type Update.token_symbol := Token_symbol.t\n and type Update.state_hash := State_hash.t\n and type Update.permissions := Account.Permissions.t)\n\n and Nonce_precondition : sig\n val is_constant :\n Nonce.t Zkapp_precondition.Closed_interval.t Account_update.or_ignore\n -> Bool.t\n end\n\n and Ledger :\n (Ledger_intf\n with type bool := Bool.t\n and type account := Account.t\n and type account_update := Account_update.t\n and type token_id := Token_id.t\n and type public_key := Public_key.t)\n\n and Call_forest :\n (Call_forest_intf\n with type t = Account_update.call_forest\n and type bool := Bool.t\n and type account_update := Account_update.t\n and module Opt := Opt)\n\n and Stack_frame :\n (Stack_frame_intf\n with type bool := Bool.t\n and type call_forest := Call_forest.t\n and type caller := Token_id.t)\n\n and Call_stack :\n (Call_stack_intf\n with type stack_frame := Stack_frame.t\n and type bool := Bool.t\n and module Opt := Opt)\n\n and Transaction_commitment : sig\n include\n Iffable\n with type bool := Bool.t\n and type t = Account_update.transaction_commitment\n\n val empty : t\n\n val commitment : account_updates:Call_forest.t -> t\n\n val full_commitment :\n account_update:Account_update.t -> memo_hash:Field.t -> commitment:t -> t\n end\n\n and Index : sig\n include Iffable with type bool := Bool.t\n\n val zero : t\n\n val succ : t -> t\n end\n\n module Local_state : sig\n type t =\n ( Stack_frame.t\n , Call_stack.t\n , Amount.Signed.t\n , Ledger.t\n , Bool.t\n , Transaction_commitment.t\n , Index.t\n , Bool.failure_status_tbl )\n Local_state.t\n\n val add_check : t -> Transaction_status.Failure.t -> Bool.t -> t\n\n val update_failure_status_tbl : t -> Bool.failure_status -> Bool.t -> t\n\n val add_new_failure_status_bucket : t -> t\n end\n\n module Global_state : sig\n type t\n\n val first_pass_ledger : t -> Ledger.t\n\n val set_first_pass_ledger : should_update:Bool.t -> t -> Ledger.t -> t\n\n val second_pass_ledger : t -> Ledger.t\n\n val set_second_pass_ledger : should_update:Bool.t -> t -> Ledger.t -> t\n\n val fee_excess : t -> Amount.Signed.t\n\n val set_fee_excess : t -> Amount.Signed.t -> t\n\n val supply_increase : t -> Amount.Signed.t\n\n val set_supply_increase : t -> Amount.Signed.t -> t\n\n val block_global_slot : t -> Global_slot_since_genesis.t\n end\nend\n\nmodule Start_data = struct\n open Core_kernel\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('account_updates, 'field, 'bool) t =\n { account_updates : 'account_updates\n ; memo_hash : 'field\n ; will_succeed : 'bool\n }\n [@@deriving sexp, yojson]\n end\n end]\nend\n\nmodule Make (Inputs : Inputs_intf) = struct\n open Inputs\n\n let default_caller = Token_id.default\n\n let stack_frame_default () =\n Stack_frame.make ~caller:default_caller ~caller_caller:default_caller\n ~calls:(Call_forest.empty ())\n\n let assert_ ~pos b = Bool.Assert.is_true ~pos b\n\n (* Pop from the call stack, returning dummy values if the stack is empty. *)\n let pop_call_stack (s : Call_stack.t) : Stack_frame.t * Call_stack.t =\n let res = Call_stack.pop s in\n (* Split out the option returned by Call_stack.pop into two options *)\n let next_frame, next_call_stack =\n (Opt.map ~f:fst res, Opt.map ~f:snd res)\n in\n (* Handle the None cases *)\n ( Opt.or_default ~if_:Stack_frame.if_ ~default:(stack_frame_default ())\n next_frame\n , Opt.or_default ~if_:Call_stack.if_ ~default:(Call_stack.empty ())\n next_call_stack )\n\n type get_next_account_update_result =\n { account_update : Account_update.t\n ; caller_id : Token_id.t\n ; account_update_forest : Call_forest.t\n ; new_call_stack : Call_stack.t\n ; new_frame : Stack_frame.t\n }\n\n let get_next_account_update (current_forest : Stack_frame.t)\n (* The stack for the most recent zkApp *)\n (call_stack : Call_stack.t) (* The partially-completed parent stacks *)\n : get_next_account_update_result =\n (* If the current stack is complete, 'return' to the previous\n partially-completed one.\n *)\n let current_forest, call_stack =\n let next_forest, next_call_stack =\n (* Invariant: call_stack contains only non-empty forests. *)\n pop_call_stack call_stack\n in\n (* TODO: I believe current should only be empty for the first account_update in\n a transaction. *)\n let current_is_empty =\n Call_forest.is_empty (Stack_frame.calls current_forest)\n in\n ( Stack_frame.if_ current_is_empty ~then_:next_forest ~else_:current_forest\n , Call_stack.if_ current_is_empty ~then_:next_call_stack ~else_:call_stack\n )\n in\n let (account_update, account_update_forest), remainder_of_current_forest =\n Call_forest.pop_exn (Stack_frame.calls current_forest)\n in\n let may_use_parents_own_token =\n Account_update.may_use_parents_own_token account_update\n in\n let may_use_token_inherited_from_parent =\n Account_update.may_use_token_inherited_from_parent account_update\n in\n let caller_id =\n Token_id.if_ may_use_token_inherited_from_parent\n ~then_:(Stack_frame.caller_caller current_forest)\n ~else_:\n (Token_id.if_ may_use_parents_own_token\n ~then_:(Stack_frame.caller current_forest)\n ~else_:Token_id.default )\n in\n (* Cases:\n - [account_update_forest] is empty, [remainder_of_current_forest] is empty.\n Pop from the call stack to get another forest, which is guaranteed to be non-empty.\n The result of popping becomes the \"current forest\".\n - [account_update_forest] is empty, [remainder_of_current_forest] is non-empty.\n Push nothing to the stack. [remainder_of_current_forest] becomes new \"current forest\"\n - [account_update_forest] is non-empty, [remainder_of_current_forest] is empty.\n Push nothing to the stack. [account_update_forest] becomes new \"current forest\"\n - [account_update_forest] is non-empty, [remainder_of_current_forest] is non-empty:\n Push [remainder_of_current_forest] to the stack. [account_update_forest] becomes new \"current forest\".\n *)\n let account_update_forest_empty =\n Call_forest.is_empty account_update_forest\n in\n let remainder_of_current_forest_empty =\n Call_forest.is_empty remainder_of_current_forest\n in\n let newly_popped_frame, popped_call_stack = pop_call_stack call_stack in\n let remainder_of_current_forest_frame : Stack_frame.t =\n Stack_frame.make\n ~caller:(Stack_frame.caller current_forest)\n ~caller_caller:(Stack_frame.caller_caller current_forest)\n ~calls:remainder_of_current_forest\n in\n let new_call_stack =\n Call_stack.if_ account_update_forest_empty\n ~then_:\n (Call_stack.if_ remainder_of_current_forest_empty\n ~then_:\n (* Don't actually need the or_default used in this case. *)\n popped_call_stack ~else_:call_stack )\n ~else_:\n (Call_stack.if_ remainder_of_current_forest_empty ~then_:call_stack\n ~else_:\n (Call_stack.push remainder_of_current_forest_frame\n ~onto:call_stack ) )\n in\n let new_frame =\n Stack_frame.if_ account_update_forest_empty\n ~then_:\n (Stack_frame.if_ remainder_of_current_forest_empty\n ~then_:newly_popped_frame ~else_:remainder_of_current_forest_frame )\n ~else_:\n (let caller =\n Account_id.derive_token_id\n ~owner:(Account_update.account_id account_update)\n and caller_caller = caller_id in\n Stack_frame.make ~calls:account_update_forest ~caller ~caller_caller\n )\n in\n { account_update\n ; caller_id\n ; account_update_forest\n ; new_frame\n ; new_call_stack\n }\n\n let update_action_state (action_state : _ Pickles_types.Vector.t) actions\n ~txn_global_slot ~last_action_slot =\n (* Push events to s1. *)\n let [ s1'; s2'; s3'; s4'; s5' ] = action_state in\n let is_empty = Actions.is_empty actions in\n let s1_updated = Actions.push_events s1' actions in\n let s1 = Field.if_ is_empty ~then_:s1' ~else_:s1_updated in\n (* Shift along if not empty and last update wasn't this slot *)\n let is_this_slot =\n Global_slot_since_genesis.equal txn_global_slot last_action_slot\n in\n let is_empty_or_this_slot = Bool.(is_empty ||| is_this_slot) in\n let s5 = Field.if_ is_empty_or_this_slot ~then_:s5' ~else_:s4' in\n let s4 = Field.if_ is_empty_or_this_slot ~then_:s4' ~else_:s3' in\n let s3 = Field.if_ is_empty_or_this_slot ~then_:s3' ~else_:s2' in\n let s2 = Field.if_ is_empty_or_this_slot ~then_:s2' ~else_:s1' in\n let last_action_slot =\n Global_slot_since_genesis.if_ is_empty ~then_:last_action_slot\n ~else_:txn_global_slot\n in\n (([ s1; s2; s3; s4; s5 ] : _ Pickles_types.Vector.t), last_action_slot)\n\n let apply ~(constraint_constants : Genesis_constants.Constraint_constants.t)\n ~(is_start : [ `Yes of _ Start_data.t | `No | `Compute of _ Start_data.t ])\n (h :\n (< global_state : Global_state.t\n ; transaction_commitment : Transaction_commitment.t\n ; full_transaction_commitment : Transaction_commitment.t\n ; amount : Amount.t\n ; bool : Bool.t\n ; failure : Bool.failure_status\n ; .. >\n as\n 'env )\n handler )\n ((global_state : Global_state.t), (local_state : Local_state.t)) =\n let open Inputs in\n let is_start' =\n let is_empty_call_forest =\n Call_forest.is_empty (Stack_frame.calls local_state.stack_frame)\n in\n ( match is_start with\n | `Compute _ ->\n ()\n | `Yes _ ->\n assert_ ~pos:__POS__ is_empty_call_forest\n | `No ->\n assert_ ~pos:__POS__ (Bool.not is_empty_call_forest) ) ;\n match is_start with\n | `Yes _ ->\n Bool.true_\n | `No ->\n Bool.false_\n | `Compute _ ->\n is_empty_call_forest\n in\n let will_succeed =\n match is_start with\n | `Compute start_data ->\n Bool.if_ is_start' ~then_:start_data.will_succeed\n ~else_:local_state.will_succeed\n | `Yes start_data ->\n start_data.will_succeed\n | `No ->\n local_state.will_succeed\n in\n let local_state =\n { local_state with\n ledger =\n Inputs.Ledger.if_ is_start'\n ~then_:(Inputs.Global_state.first_pass_ledger global_state)\n ~else_:local_state.ledger\n ; will_succeed\n }\n in\n let ( (account_update, remaining, call_stack)\n , account_update_forest\n , local_state\n , (a, inclusion_proof) ) =\n let to_pop, call_stack =\n match is_start with\n | `Compute start_data ->\n ( Stack_frame.if_ is_start'\n ~then_:\n (Stack_frame.make ~calls:start_data.account_updates\n ~caller:default_caller ~caller_caller:default_caller )\n ~else_:local_state.stack_frame\n , Call_stack.if_ is_start' ~then_:(Call_stack.empty ())\n ~else_:local_state.call_stack )\n | `Yes start_data ->\n ( Stack_frame.make ~calls:start_data.account_updates\n ~caller:default_caller ~caller_caller:default_caller\n , Call_stack.empty () )\n | `No ->\n (local_state.stack_frame, local_state.call_stack)\n in\n let { account_update\n ; caller_id\n ; account_update_forest\n ; new_frame = remaining\n ; new_call_stack = call_stack\n } =\n with_label ~label:\"get next account update\" (fun () ->\n (* TODO: Make the stack frame hashed inside of the local state *)\n get_next_account_update to_pop call_stack )\n in\n let local_state =\n with_label ~label:\"token owner not caller\" (fun () ->\n let default_token_or_token_owner_was_caller =\n (* Check that the token owner was consulted if using a non-default\n token *)\n let account_update_token_id =\n Account_update.token_id account_update\n in\n Bool.( ||| )\n (Token_id.equal account_update_token_id Token_id.default)\n (Token_id.equal account_update_token_id caller_id)\n in\n Local_state.add_check local_state Token_owner_not_caller\n default_token_or_token_owner_was_caller )\n in\n let ((a, inclusion_proof) as acct) =\n with_label ~label:\"get account\" (fun () ->\n Inputs.Ledger.get_account account_update local_state.ledger )\n in\n Inputs.Ledger.check_inclusion local_state.ledger (a, inclusion_proof) ;\n let transaction_commitment, full_transaction_commitment =\n match is_start with\n | `No ->\n ( local_state.transaction_commitment\n , local_state.full_transaction_commitment )\n | `Yes start_data | `Compute start_data ->\n let tx_commitment_on_start =\n Transaction_commitment.commitment\n ~account_updates:(Stack_frame.calls remaining)\n in\n let full_tx_commitment_on_start =\n Transaction_commitment.full_commitment ~account_update\n ~memo_hash:start_data.memo_hash\n ~commitment:tx_commitment_on_start\n in\n let tx_commitment =\n Transaction_commitment.if_ is_start' ~then_:tx_commitment_on_start\n ~else_:local_state.transaction_commitment\n in\n let full_tx_commitment =\n Transaction_commitment.if_ is_start'\n ~then_:full_tx_commitment_on_start\n ~else_:local_state.full_transaction_commitment\n in\n (tx_commitment, full_tx_commitment)\n in\n let local_state =\n { local_state with transaction_commitment; full_transaction_commitment }\n in\n ( (account_update, remaining, call_stack)\n , account_update_forest\n , local_state\n , acct )\n in\n let local_state =\n { local_state with stack_frame = remaining; call_stack }\n in\n let local_state = Local_state.add_new_failure_status_bucket local_state in\n (* Register verification key, in case it needs to be 'side-loaded' to\n verify a zkapp proof.\n *)\n Account.register_verification_key a ;\n let (`Is_new account_is_new) =\n Inputs.Ledger.check_account\n (Account_update.public_key account_update)\n (Account_update.token_id account_update)\n (a, inclusion_proof)\n in\n (* delegate to public key if new account using default token *)\n let a =\n let self_delegate =\n let account_update_token_id = Account_update.token_id account_update in\n Bool.(\n account_is_new\n &&& Token_id.equal account_update_token_id Token_id.default)\n in\n (* in-SNARK, a new account has the empty public key here\n in that case, use the public key from the account update, not the account\n *)\n Account.set_delegate\n (Public_key.if_ self_delegate\n ~then_:(Account_update.public_key account_update)\n ~else_:(Account.delegate a) )\n a\n in\n let matching_verification_key_hashes =\n Inputs.Bool.(\n (not (Account_update.is_proved account_update))\n ||| Verification_key_hash.equal\n (Account.verification_key_hash a)\n (Account_update.verification_key_hash account_update))\n in\n let local_state =\n Local_state.add_check local_state Unexpected_verification_key_hash\n matching_verification_key_hashes\n in\n let local_state =\n h.perform\n (Check_account_precondition\n (account_update, a, account_is_new, local_state) )\n in\n let protocol_state_predicate_satisfied =\n h.perform\n (Check_protocol_state_precondition\n ( Account_update.protocol_state_precondition account_update\n , global_state ) )\n in\n let local_state =\n Local_state.add_check local_state Protocol_state_precondition_unsatisfied\n protocol_state_predicate_satisfied\n in\n let local_state =\n let valid_while_satisfied =\n h.perform\n (Check_valid_while_precondition\n ( Account_update.valid_while_precondition account_update\n , global_state ) )\n in\n Local_state.add_check local_state Valid_while_precondition_unsatisfied\n valid_while_satisfied\n in\n let `Proof_verifies proof_verifies, `Signature_verifies signature_verifies =\n let commitment =\n Inputs.Transaction_commitment.if_\n (Inputs.Account_update.use_full_commitment account_update)\n ~then_:local_state.full_transaction_commitment\n ~else_:local_state.transaction_commitment\n in\n Inputs.Account_update.check_authorization\n ~will_succeed:local_state.will_succeed ~commitment\n ~calls:account_update_forest account_update\n in\n assert_ ~pos:__POS__\n (Bool.equal proof_verifies (Account_update.is_proved account_update)) ;\n assert_ ~pos:__POS__\n (Bool.equal signature_verifies (Account_update.is_signed account_update)) ;\n (* The fee-payer must increment their nonce. *)\n let local_state =\n Local_state.add_check local_state Fee_payer_nonce_must_increase\n Inputs.Bool.(\n Inputs.Account_update.increment_nonce account_update ||| not is_start')\n in\n let local_state =\n Local_state.add_check local_state Fee_payer_must_be_signed\n Inputs.Bool.(signature_verifies ||| not is_start')\n in\n let local_state =\n let precondition_has_constant_nonce =\n Inputs.Account_update.Account_precondition.nonce account_update\n |> Inputs.Nonce_precondition.is_constant\n in\n let increments_nonce_and_constrains_its_old_value =\n Inputs.Bool.(\n Inputs.Account_update.increment_nonce account_update\n &&& precondition_has_constant_nonce)\n in\n let depends_on_the_fee_payers_nonce_and_isnt_the_fee_payer =\n Inputs.Bool.(\n Inputs.Account_update.use_full_commitment account_update\n &&& not is_start')\n in\n let does_not_use_a_signature = Inputs.Bool.not signature_verifies in\n Local_state.add_check local_state Zkapp_command_replay_check_failed\n Inputs.Bool.(\n increments_nonce_and_constrains_its_old_value\n ||| depends_on_the_fee_payers_nonce_and_isnt_the_fee_payer\n ||| does_not_use_a_signature)\n in\n let a = Account.set_token_id a (Account_update.token_id account_update) in\n let account_update_token = Account_update.token_id account_update in\n let account_update_token_is_default =\n Token_id.(equal default) account_update_token\n in\n let account_is_untimed = Bool.not (Account.is_timed a) in\n (* Set account timing. *)\n let a, local_state =\n let timing = Account_update.Update.timing account_update in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_timing a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_timing\n Bool.(\n Set_or_keep.is_keep timing\n ||| (account_is_untimed &&& has_permission))\n in\n let timing =\n Set_or_keep.set_or_keep ~if_:Timing.if_ timing (Account.timing a)\n in\n let vesting_period = Timing.vesting_period timing in\n (* Assert that timing is valid, otherwise we may have a division by 0. *)\n assert_ ~pos:__POS__ Global_slot_span.(vesting_period > zero) ;\n let a = Account.set_timing a timing in\n (a, local_state)\n in\n let account_creation_fee =\n Amount.of_constant_fee constraint_constants.account_creation_fee\n in\n let implicit_account_creation_fee =\n Account_update.implicit_account_creation_fee account_update\n in\n (* Check the token for implicit account creation fee payment. *)\n let local_state =\n Local_state.add_check local_state Cannot_pay_creation_fee_in_token\n Bool.(\n (not implicit_account_creation_fee)\n ||| account_update_token_is_default)\n in\n (* Compute the change to the account balance. *)\n let local_state, actual_balance_change =\n let balance_change = Account_update.balance_change account_update in\n let neg_creation_fee =\n let open Amount.Signed in\n negate (of_unsigned account_creation_fee)\n in\n let balance_change_for_creation, `Overflow creation_overflow =\n let open Amount.Signed in\n add_flagged balance_change neg_creation_fee\n in\n let pay_creation_fee =\n Bool.(account_is_new &&& implicit_account_creation_fee)\n in\n let creation_overflow = Bool.(pay_creation_fee &&& creation_overflow) in\n let balance_change =\n Amount.Signed.if_ pay_creation_fee ~then_:balance_change_for_creation\n ~else_:balance_change\n in\n let local_state =\n Local_state.add_check local_state Amount_insufficient_to_create_account\n Bool.(\n not\n ( pay_creation_fee\n &&& (creation_overflow ||| Amount.Signed.is_neg balance_change) ))\n in\n (local_state, balance_change)\n in\n (* Apply balance change. *)\n let a, local_state =\n let pay_creation_fee_from_excess =\n Bool.(account_is_new &&& not implicit_account_creation_fee)\n in\n let balance, `Overflow failed1 =\n Balance.add_signed_amount_flagged (Account.balance a)\n actual_balance_change\n in\n (* TODO: Should this report 'insufficient balance'? *)\n let local_state =\n Local_state.add_check local_state Overflow (Bool.not failed1)\n in\n let account_creation_fee =\n Amount.of_constant_fee constraint_constants.account_creation_fee\n in\n let local_state =\n (* Conditionally subtract account creation fee from fee excess *)\n let excess_minus_creation_fee, `Overflow excess_update_failed =\n Amount.Signed.add_flagged local_state.excess\n Amount.Signed.(negate (of_unsigned account_creation_fee))\n in\n let local_state =\n Local_state.add_check local_state Local_excess_overflow\n Bool.(not (pay_creation_fee_from_excess &&& excess_update_failed))\n in\n { local_state with\n excess =\n Amount.Signed.if_ pay_creation_fee_from_excess\n ~then_:excess_minus_creation_fee ~else_:local_state.excess\n }\n in\n let local_state =\n (* Conditionally subtract account creation fee from supply increase *)\n let ( supply_increase_minus_creation_fee\n , `Overflow supply_increase_update_failed ) =\n Amount.Signed.add_flagged local_state.supply_increase\n Amount.Signed.(negate (of_unsigned account_creation_fee))\n in\n let local_state =\n Local_state.add_check local_state Local_supply_increase_overflow\n Bool.(not (account_is_new &&& supply_increase_update_failed))\n in\n { local_state with\n supply_increase =\n Amount.Signed.if_ account_is_new\n ~then_:supply_increase_minus_creation_fee\n ~else_:local_state.supply_increase\n }\n in\n let is_receiver = Amount.Signed.is_non_neg actual_balance_change in\n let local_state =\n let controller =\n Controller.if_ is_receiver\n ~then_:(Account.Permissions.receive a)\n ~else_:(Account.Permissions.send a)\n in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies controller\n in\n Local_state.add_check local_state Update_not_permitted_balance\n Bool.(\n has_permission\n ||| Amount.Signed.(\n equal (of_unsigned Amount.zero) actual_balance_change))\n in\n let a = Account.set_balance balance a in\n (a, local_state)\n in\n let txn_global_slot = Global_state.block_global_slot global_state in\n (* Check timing with current balance *)\n let a, local_state =\n let `Invalid_timing invalid_timing, timing =\n match Account.check_timing ~txn_global_slot a with\n | `Insufficient_balance _, _ ->\n failwith \"Did not propose a balance change at this timing check!\"\n | `Invalid_timing invalid_timing, timing ->\n (* NB: Have to destructure to remove the possibility of\n [`Insufficient_balance _] in the type.\n *)\n (`Invalid_timing invalid_timing, timing)\n in\n let local_state =\n Local_state.add_check local_state Source_minimum_balance_violation\n (Bool.not invalid_timing)\n in\n let a = Account.set_timing a timing in\n (a, local_state)\n in\n (* Transform into a zkApp account.\n This must be done before updating zkApp fields!\n *)\n let a = Account.make_zkapp a in\n (* Check that the account can be accessed with the given authorization. *)\n let local_state =\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.access a)\n in\n Local_state.add_check local_state Update_not_permitted_access\n has_permission\n in\n (* Update app state. *)\n let a, local_state =\n let app_state = Account_update.Update.app_state account_update in\n let keeping_app_state =\n Bool.all\n (List.map ~f:Set_or_keep.is_keep\n (Pickles_types.Vector.to_list app_state) )\n in\n let changing_entire_app_state =\n Bool.all\n (List.map ~f:Set_or_keep.is_set\n (Pickles_types.Vector.to_list app_state) )\n in\n let proved_state =\n (* The [proved_state] tracks whether the app state has been entirely\n determined by proofs ([true] if so), to allow zkApp authors to be\n confident that their initialization logic has been run, rather than\n some malicious deployer instantiating the zkApp in an account with\n some fake non-initial state.\n The logic here is:\n * if the state is unchanged, keep the previous value;\n * if the state has been entirely replaced, and the authentication\n was a proof, the state has been 'proved' and [proved_state] is set\n to [true];\n * if the state has been partially updated by a proof, the\n [proved_state] is unchanged;\n * if the state has been changed by some authentication other than a\n proof, the state is considered to have been tampered with, and\n [proved_state] is reset to [false].\n *)\n Bool.if_ keeping_app_state ~then_:(Account.proved_state a)\n ~else_:\n (Bool.if_ proof_verifies\n ~then_:\n (Bool.if_ changing_entire_app_state ~then_:Bool.true_\n ~else_:(Account.proved_state a) )\n ~else_:Bool.false_ )\n in\n let a = Account.set_proved_state proved_state a in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.edit_state a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_app_state\n Bool.(keeping_app_state ||| has_permission)\n in\n let app_state =\n Pickles_types.Vector.map2 app_state (Account.app_state a)\n ~f:(Set_or_keep.set_or_keep ~if_:Field.if_)\n in\n let a = Account.set_app_state app_state a in\n (a, local_state)\n in\n (* Set verification key. *)\n let a, local_state =\n let verification_key =\n Account_update.Update.verification_key account_update\n in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_verification_key a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_verification_key\n Bool.(Set_or_keep.is_keep verification_key ||| has_permission)\n in\n let verification_key =\n Set_or_keep.set_or_keep ~if_:Verification_key.if_ verification_key\n (Account.verification_key a)\n in\n let a = Account.set_verification_key verification_key a in\n (a, local_state)\n in\n (* Update action state. *)\n let a, local_state =\n let actions = Account_update.Update.actions account_update in\n let last_action_slot = Account.last_action_slot a in\n let action_state, last_action_slot =\n update_action_state (Account.action_state a) actions ~txn_global_slot\n ~last_action_slot\n in\n let is_empty =\n (* also computed in update_action_state, but messy to return it *)\n Actions.is_empty actions\n in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.edit_action_state a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_action_state\n Bool.(is_empty ||| has_permission)\n in\n let a =\n a\n |> Account.set_action_state action_state\n |> Account.set_last_action_slot last_action_slot\n in\n (a, local_state)\n in\n (* Update zkApp URI. *)\n let a, local_state =\n let zkapp_uri = Account_update.Update.zkapp_uri account_update in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_zkapp_uri a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_zkapp_uri\n Bool.(Set_or_keep.is_keep zkapp_uri ||| has_permission)\n in\n let zkapp_uri =\n Set_or_keep.set_or_keep ~if_:Zkapp_uri.if_ zkapp_uri\n (Account.zkapp_uri a)\n in\n let a = Account.set_zkapp_uri zkapp_uri a in\n (a, local_state)\n in\n (* At this point, all possible changes have been made to the zkapp\n part of an account. Reset zkApp state to [None] if that part\n is unmodified.\n *)\n let a = Account.unmake_zkapp a in\n (* Update token symbol. *)\n let a, local_state =\n let token_symbol = Account_update.Update.token_symbol account_update in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_token_symbol a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_token_symbol\n Bool.(Set_or_keep.is_keep token_symbol ||| has_permission)\n in\n let token_symbol =\n Set_or_keep.set_or_keep ~if_:Token_symbol.if_ token_symbol\n (Account.token_symbol a)\n in\n let a = Account.set_token_symbol token_symbol a in\n (a, local_state)\n in\n (* Update delegate. *)\n let a, local_state =\n let delegate = Account_update.Update.delegate account_update in\n (* for new accounts using the default token, we've already\n set the delegate to the public key\n *)\n let base_delegate = Account.delegate a in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_delegate a)\n in\n let local_state =\n (* Note: only accounts for the default token can delegate. *)\n Local_state.add_check local_state Update_not_permitted_delegate\n Bool.(\n Set_or_keep.is_keep delegate\n ||| (has_permission &&& account_update_token_is_default))\n in\n let delegate =\n Set_or_keep.set_or_keep ~if_:Public_key.if_ delegate base_delegate\n in\n let a = Account.set_delegate delegate a in\n (a, local_state)\n in\n (* Update nonce. *)\n let a, local_state =\n let nonce = Account.nonce a in\n let increment_nonce = Account_update.increment_nonce account_update in\n let nonce =\n Nonce.if_ increment_nonce ~then_:(Nonce.succ nonce) ~else_:nonce\n in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.increment_nonce a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_nonce\n Bool.((not increment_nonce) ||| has_permission)\n in\n let a = Account.set_nonce nonce a in\n (a, local_state)\n in\n (* Update voting-for. *)\n let a, local_state =\n let voting_for = Account_update.Update.voting_for account_update in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_voting_for a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_voting_for\n Bool.(Set_or_keep.is_keep voting_for ||| has_permission)\n in\n let voting_for =\n Set_or_keep.set_or_keep ~if_:State_hash.if_ voting_for\n (Account.voting_for a)\n in\n let a = Account.set_voting_for voting_for a in\n (a, local_state)\n in\n (* Update receipt chain hash *)\n let a =\n let new_hash =\n let old_hash = Account.receipt_chain_hash a in\n Receipt_chain_hash.if_\n (let open Inputs.Bool in\n signature_verifies ||| proof_verifies)\n ~then_:\n (let elt =\n local_state.full_transaction_commitment\n |> Receipt_chain_hash.Elt.of_transaction_commitment\n in\n Receipt_chain_hash.cons_zkapp_command_commitment\n local_state.account_update_index elt old_hash )\n ~else_:old_hash\n in\n Account.set_receipt_chain_hash a new_hash\n in\n (* Finally, update permissions.\n This should be the last update applied, to ensure that any earlier\n updates use the account's existing permissions, and not permissions that\n are specified by the account_update!\n *)\n let a, local_state =\n let permissions = Account_update.Update.permissions account_update in\n let has_permission =\n Controller.check ~proof_verifies ~signature_verifies\n (Account.Permissions.set_permissions a)\n in\n let local_state =\n Local_state.add_check local_state Update_not_permitted_permissions\n Bool.(Set_or_keep.is_keep permissions ||| has_permission)\n in\n let permissions =\n Set_or_keep.set_or_keep ~if_:Account.Permissions.if_ permissions\n (Account.permissions a)\n in\n let a = Account.set_permissions permissions a in\n (a, local_state)\n in\n (* Initialize account's pk, in case it is new. *)\n let a = h.perform (Init_account { account_update; account = a }) in\n (* DO NOT ADD ANY UPDATES HERE. They must be earlier in the code.\n See comment above.\n *)\n let local_delta =\n (* NOTE: It is *not* correct to use the actual change in balance here.\n Indeed, if the account creation fee is paid, using that amount would\n be equivalent to paying it out to the block producer.\n In the case of a failure that prevents any updates from being applied,\n every other account_update in this transaction will also fail, and the\n excess will never be promoted to the global excess, so this amount is\n irrelevant.\n *)\n Amount.Signed.negate (Account_update.balance_change account_update)\n in\n let new_local_fee_excess, `Overflow overflowed =\n (* We only allow the default token for fees. *)\n Bool.(\n assert_ ~pos:__POS__\n ( (not is_start')\n ||| ( account_update_token_is_default\n &&& Amount.Signed.is_non_neg local_delta ) )) ;\n let new_local_fee_excess, `Overflow overflow =\n Amount.Signed.add_flagged local_state.excess local_delta\n in\n ( Amount.Signed.if_ account_update_token_is_default\n ~then_:new_local_fee_excess ~else_:local_state.excess\n , (* No overflow if we aren't using the result of the addition (which we don't in the case that account_update token is not default). *)\n `Overflow (Bool.( &&& ) account_update_token_is_default overflow) )\n in\n let local_state = { local_state with excess = new_local_fee_excess } in\n let local_state =\n Local_state.add_check local_state Local_excess_overflow\n (Bool.not overflowed)\n in\n (* If a's token ID differs from that in the local state, then\n the local state excess gets moved into the execution state's fee excess.\n\n If there are more zkapp_command to execute after this one, then the local delta gets\n accumulated in the local state.\n\n If there are no more zkapp_command to execute, then we do the same as if we switch tokens.\n The local state excess (plus the local delta) gets moved to the fee excess if it is default token.\n *)\n let new_ledger =\n Inputs.Ledger.set_account local_state.ledger (a, inclusion_proof)\n in\n let is_last_account_update =\n Call_forest.is_empty (Stack_frame.calls remaining)\n in\n let local_state =\n { local_state with\n ledger = new_ledger\n ; transaction_commitment =\n Transaction_commitment.if_ is_last_account_update\n ~then_:Transaction_commitment.empty\n ~else_:local_state.transaction_commitment\n ; full_transaction_commitment =\n Transaction_commitment.if_ is_last_account_update\n ~then_:Transaction_commitment.empty\n ~else_:local_state.full_transaction_commitment\n }\n in\n let valid_fee_excess =\n let delta_settled =\n Amount.Signed.equal local_state.excess Amount.(Signed.of_unsigned zero)\n in\n (* 1) ignore local excess if it is_start because it will be promoted to global\n excess and then set to zero later in the code\n 2) ignore everything but last account update since the excess wouldn't have\n been settled\n 3) Excess should be settled after the last account update has been applied.\n *)\n Bool.(is_start' ||| not is_last_account_update ||| delta_settled)\n in\n let local_state =\n Local_state.add_check local_state Invalid_fee_excess valid_fee_excess\n in\n let is_start_or_last = Bool.(is_start' ||| is_last_account_update) in\n let update_global_state_fee_excess =\n Bool.(is_start_or_last &&& local_state.success)\n in\n let global_state, global_excess_update_failed =\n let amt = Global_state.fee_excess global_state in\n let res, `Overflow overflow =\n Amount.Signed.add_flagged amt local_state.excess\n in\n let global_excess_update_failed =\n Bool.(update_global_state_fee_excess &&& overflow)\n in\n let new_amt =\n Amount.Signed.if_ update_global_state_fee_excess ~then_:res ~else_:amt\n in\n ( Global_state.set_fee_excess global_state new_amt\n , global_excess_update_failed )\n in\n let local_state =\n { local_state with\n excess =\n Amount.Signed.if_ is_start_or_last\n ~then_:Amount.(Signed.of_unsigned zero)\n ~else_:local_state.excess\n }\n in\n let local_state =\n Local_state.add_check local_state Global_excess_overflow\n Bool.(not global_excess_update_failed)\n in\n (* add local supply increase in global state *)\n let new_global_supply_increase, global_supply_increase_update_failed =\n let res, `Overflow overflow =\n Amount.Signed.add_flagged\n (Global_state.supply_increase global_state)\n local_state.supply_increase\n in\n (res, overflow)\n in\n let local_state =\n Local_state.add_check local_state Global_supply_increase_overflow\n Bool.(not global_supply_increase_update_failed)\n in\n (* The first account_update must succeed. *)\n Bool.(\n assert_with_failure_status_tbl ~pos:__POS__\n ((not is_start') ||| local_state.success)\n local_state.failure_status_tbl) ;\n (* If we are the fee payer (is_start' = true), push the first pass ledger\n and set the local ledger to be the second pass ledger in preparation for\n the children.\n *)\n let local_state, global_state =\n let is_fee_payer = is_start' in\n let global_state =\n Global_state.set_first_pass_ledger ~should_update:is_fee_payer\n global_state local_state.ledger\n in\n let local_state =\n { local_state with\n ledger =\n Inputs.Ledger.if_ is_fee_payer\n ~then_:(Global_state.second_pass_ledger global_state)\n ~else_:local_state.ledger\n }\n in\n (local_state, global_state)\n in\n (* If this is the last account update, and [will_succeed] is false, then\n [success] must also be false.\n *)\n Bool.(\n Assert.any ~pos:__POS__\n [ not is_last_account_update\n ; local_state.will_succeed\n ; not local_state.success\n ]) ;\n (* If this is the last party and there were no failures, update the second\n pass ledger and the supply increase.\n *)\n let global_state =\n let is_successful_last_party =\n Bool.(is_last_account_update &&& local_state.success)\n in\n let global_state =\n Global_state.set_supply_increase global_state\n (Amount.Signed.if_ is_successful_last_party\n ~then_:new_global_supply_increase\n ~else_:(Global_state.supply_increase global_state) )\n in\n Global_state.set_second_pass_ledger\n ~should_update:is_successful_last_party global_state local_state.ledger\n in\n let local_state =\n (* Make sure to reset the local_state at the end of a transaction.\n The following fields are already reset\n - zkapp_command\n - transaction_commitment\n - full_transaction_commitment\n - excess\n so we need to reset\n - token_id = Token_id.default\n - ledger = Frozen_ledger_hash.empty_hash\n - success = true\n - account_update_index = Index.zero\n - supply_increase = Amount.Signed.zero\n *)\n { local_state with\n ledger =\n Inputs.Ledger.if_ is_last_account_update\n ~then_:(Inputs.Ledger.empty ~depth:0 ())\n ~else_:local_state.ledger\n ; success =\n Bool.if_ is_last_account_update ~then_:Bool.true_\n ~else_:local_state.success\n ; account_update_index =\n Inputs.Index.if_ is_last_account_update ~then_:Inputs.Index.zero\n ~else_:(Inputs.Index.succ local_state.account_update_index)\n ; supply_increase =\n Amount.Signed.if_ is_last_account_update\n ~then_:Amount.(Signed.of_unsigned zero)\n ~else_:local_state.supply_increase\n ; will_succeed =\n Bool.if_ is_last_account_update ~then_:Bool.true_\n ~else_:local_state.will_succeed\n }\n in\n (global_state, local_state)\n\n let step h state = apply ~is_start:`No h state\n\n let start start_data h state = apply ~is_start:(`Yes start_data) h state\nend\n","open! Import\nopen Std_internal\nmodule Repr = Int63\n\nmodule T : sig\n type t [@@deriving compare, hash, sexp_of]\n\n val to_string : t -> string\n val of_repr : Repr.t -> t\n val to_repr : t -> Repr.t\nend = struct\n type t = Repr.t [@@deriving compare, hash]\n\n let of_repr = Fn.id\n let to_repr = Fn.id\n\n let to_string n =\n let open Repr in\n let kib = of_int 1024 in\n let mib = kib * kib in\n let gib = kib * mib in\n let n_abs = abs n in\n if n_abs < kib\n then sprintf \"%dB\" (to_int_exn n)\n else if n_abs < mib\n then sprintf \"%gK\" (to_float n /. to_float kib)\n else if n_abs < gib\n then sprintf \"%gM\" (to_float n /. to_float mib)\n else sprintf \"%gG\" (to_float n /. to_float gib)\n ;;\n\n let sexp_of_t n = Sexp.Atom (to_string n)\nend\n\ninclude T\n\nlet bytes_int_exn t = Repr.to_int_exn (to_repr t)\n","open! Import\nopen Std_internal\nopen Bigarray\nmodule Binable = Binable0\n\nmodule Stable = struct\n module V1 = struct\n include Base_bigstring\n\n module Z : sig\n type t = (char, int8_unsigned_elt, c_layout) Array1.t [@@deriving bin_io]\n end = struct\n type t = bigstring [@@deriving bin_io]\n end\n\n include Z\n\n type t_frozen = t [@@deriving bin_io]\n end\nend\n\nmodule T = Stable.V1\ninclude T\nmodule Unstable = T\n\nlet create ?max_mem_waiting_gc size =\n let max_mem_waiting_gc_in_bytes =\n Option.map max_mem_waiting_gc ~f:Byte_units0.bytes_int_exn\n in\n create ?max_mem_waiting_gc_in_bytes size\n;;\n\nlet sub_shared ?(pos = 0) ?len (bstr : t) =\n let len = get_opt_len bstr ~pos len in\n Array1.sub bstr pos len\n;;\n\n(* Destruction *)\n\nexternal unsafe_destroy : t -> unit = \"bigstring_destroy_stub\"\n\nexternal unsafe_destroy_and_resize : t -> len:int -> t = \"bigstring_realloc\"\n\n(* Reading / writing bin-prot *)\n\nlet read_bin_prot_verbose_errors t ?(pos = 0) ?len reader =\n let len = get_opt_len t len ~pos in\n let limit = pos + len in\n check_args ~loc:\"read_bin_prot_verbose_errors\" t ~pos ~len;\n let invalid_data message a sexp_of_a =\n `Invalid_data (Error.create message a sexp_of_a)\n in\n let read bin_reader ~pos ~len =\n if len > limit - pos\n then `Not_enough_data\n else (\n let pos_ref = ref pos in\n match\n try `Ok (bin_reader t ~pos_ref) with\n | exn -> `Invalid_data (Error.of_exn exn)\n with\n | `Invalid_data _ as x -> x\n | `Ok result ->\n let expected_pos = pos + len in\n if !pos_ref = expected_pos\n then `Ok (result, expected_pos)\n else\n invalid_data\n \"pos_ref <> expected_pos\"\n (!pos_ref, expected_pos)\n [%sexp_of: int * int])\n in\n match\n read Bin_prot.Utils.bin_read_size_header ~pos ~len:Bin_prot.Utils.size_header_length\n with\n | (`Not_enough_data | `Invalid_data _) as x -> x\n | `Ok (element_length, pos) ->\n if element_length < 0\n then invalid_data \"negative element length %d\" element_length [%sexp_of: int]\n else read reader.Bin_prot.Type_class.read ~pos ~len:element_length\n;;\n\nlet read_bin_prot t ?pos ?len reader =\n match read_bin_prot_verbose_errors t ?pos ?len reader with\n | `Ok x -> Ok x\n | `Invalid_data e -> Error (Error.tag e ~tag:\"Invalid data\")\n | `Not_enough_data -> Or_error.error_string \"not enough data\"\n;;\n\nlet write_bin_prot t ?(pos = 0) writer v =\n let data_len = writer.Bin_prot.Type_class.size v in\n let total_len = data_len + Bin_prot.Utils.size_header_length in\n if pos < 0\n then\n failwiths ~here:[%here] \"Bigstring.write_bin_prot: negative pos\" pos [%sexp_of: int];\n if pos + total_len > length t\n then\n failwiths\n ~here:[%here]\n \"Bigstring.write_bin_prot: not enough room\"\n (`pos pos, `pos_after_writing (pos + total_len), `bigstring_length (length t))\n [%sexp_of:\n [ `pos of int ] * [ `pos_after_writing of int ] * [ `bigstring_length of int ]];\n let pos_after_size_header = Bin_prot.Utils.bin_write_size_header t ~pos data_len in\n let pos_after_data = writer.Bin_prot.Type_class.write t ~pos:pos_after_size_header v in\n if pos_after_data - pos <> total_len\n then\n failwiths\n ~here:[%here]\n \"Bigstring.write_bin_prot bug!\"\n ( `pos_after_data pos_after_data\n , `start_pos pos\n , `bin_prot_size_header_length Bin_prot.Utils.size_header_length\n , `data_len data_len\n , `total_len total_len )\n [%sexp_of:\n [ `pos_after_data of int ]\n * [ `start_pos of int ]\n * [ `bin_prot_size_header_length of int ]\n * [ `data_len of int ]\n * [ `total_len of int ]];\n pos_after_data\n;;\n\n(* Hex dump *)\n\ninclude Hexdump.Of_indexable (struct\n type nonrec t = t\n\n let length = length\n let get = get\n end)\n\nlet rec last_nonmatch_plus_one ~buf ~min_pos ~pos ~char =\n let pos' = pos - 1 in\n if pos' >= min_pos && Char.( = ) (get buf pos') char\n then last_nonmatch_plus_one ~buf ~min_pos ~pos:pos' ~char\n else pos\n;;\n\nlet get_tail_padded_fixed_string ~padding t ~pos ~len () =\n let data_end =\n last_nonmatch_plus_one ~buf:t ~min_pos:pos ~pos:(pos + len) ~char:padding\n in\n to_string t ~pos ~len:(data_end - pos)\n;;\n\nlet set_tail_padded_fixed_string ~padding t ~pos ~len value =\n let slen = String.length value in\n if slen > len\n then\n Printf.failwithf\n \"Bigstring.set_tail_padded_fixed_string: %S is longer than %d\"\n value\n len\n ();\n From_string.blit ~src:value ~dst:t ~src_pos:0 ~dst_pos:pos ~len:slen;\n for i = pos + slen to pos + len - 1 do\n set t i padding\n done\n;;\n\nlet rec first_nonmatch ~buf ~pos ~max_pos ~char =\n if pos <= max_pos && Char.( = ) (get buf pos) char\n then first_nonmatch ~buf ~pos:(Int.succ pos) ~max_pos ~char\n else pos\n;;\n\nlet set_head_padded_fixed_string ~padding t ~pos ~len value =\n let slen = String.length value in\n if slen > len\n then\n Printf.failwithf\n \"Bigstring.set_head_padded_fixed_string: %S is longer than %d\"\n value\n len\n ();\n From_string.blit ~src:value ~dst:t ~src_pos:0 ~dst_pos:(pos + len - slen) ~len:slen;\n for i = pos to pos + len - slen - 1 do\n set t i padding\n done\n;;\n\nlet get_head_padded_fixed_string ~padding t ~pos ~len () =\n let data_begin = first_nonmatch ~buf:t ~pos ~max_pos:(pos + len - 1) ~char:padding in\n to_string t ~pos:data_begin ~len:(len - (data_begin - pos))\n;;\n","open! Import\ninclude Bin_prot\n\nmodule Writer = struct\n type 'a t = 'a Bin_prot.Type_class.writer =\n { size : 'a Size.sizer\n ; write : 'a Write.writer\n }\n\n let to_string t v =\n let len = t.size v in\n let buf = Bigstring.create len in\n let pos = t.write buf ~pos:0 v in\n assert (pos = Bigstring.length buf);\n let str = Bigstring.to_string buf in\n Bigstring.unsafe_destroy buf;\n str\n ;;\n\n let to_bytes t v =\n let len = t.size v in\n let buf = Bigstring.create len in\n let pos = t.write buf ~pos:0 v in\n assert (pos = Bigstring.length buf);\n let str = Bigstring.to_bytes buf in\n Bigstring.unsafe_destroy buf;\n str\n ;;\nend\n\nmodule Reader = struct\n type 'a t = 'a Bin_prot.Type_class.reader =\n { read : 'a Read.reader\n ; vtag_read : (int -> 'a) Read.reader\n }\n\n let of_string t string =\n let buf = Bigstring.of_string string in\n let pos_ref = ref 0 in\n let v = t.read buf ~pos_ref in\n assert (!pos_ref = Bigstring.length buf);\n Bigstring.unsafe_destroy buf;\n v\n ;;\n\n let of_bytes t bytes =\n let buf = Bigstring.of_bytes bytes in\n let pos_ref = ref 0 in\n let v = t.read buf ~pos_ref in\n assert (!pos_ref = Bigstring.length buf);\n Bigstring.unsafe_destroy buf;\n v\n ;;\nend\n","module T = struct\n include Bin_prot.Md5\n\n let sexp_of_t t = t |> to_hex |> String.sexp_of_t\n let t_of_sexp s = s |> String.t_of_sexp |> of_hex_exn\nend\n\nlet hash_fold_t accum t = String.hash_fold_t accum (T.to_binary t)\nlet hash t = String.hash (T.to_binary t)\n\nmodule As_binary_string = struct\n module Stable = struct\n module V1 = struct\n type t = T.t [@@deriving compare]\n\n let hash_fold_t = hash_fold_t\n let hash = hash\n let sexp_of_t x = String.sexp_of_t (T.to_binary x)\n let t_of_sexp x = T.of_binary_exn (String.t_of_sexp x)\n\n include Bin_prot.Utils.Make_binable_without_uuid [@alert \"-legacy\"] (struct\n module Binable = String\n\n type t = Bin_prot.Md5.t\n\n let to_binable = T.to_binary\n let of_binable = T.of_binary_exn\n end)\n end\n end\n\n include Stable.V1\n include Comparable.Make (Stable.V1)\n include Hashable.Make (Stable.V1)\nend\n\nmodule Stable = struct\n module V1 = struct\n type t = T.t [@@deriving compare, sexp]\n\n let hash_fold_t = hash_fold_t\n let hash = hash\n\n include Bin_prot.Utils.Make_binable_without_uuid [@alert \"-legacy\"] (struct\n module Binable = Bin_prot.Md5\n\n type t = Bin_prot.Md5.t\n\n let to_binable = Fn.id\n let of_binable = Fn.id\n end)\n end\n\n let digest_string s = Md5_lib.string s\nend\n\ninclude Stable.V1\ninclude Comparable.Make (Stable.V1)\ninclude Hashable.Make (Stable.V1)\n\nlet digest_num_bytes = 16\nlet to_hex = T.to_hex\nlet from_hex = T.of_hex_exn\nlet of_hex_exn = T.of_hex_exn\nlet of_binary_exn = T.of_binary_exn\nlet to_binary = T.to_binary\nlet digest_string = Stable.digest_string\nlet digest_bytes = Md5_lib.bytes\n\nexternal caml_sys_open\n : string\n -> Caml.open_flag list\n -> perm:int\n -> int\n = \"caml_sys_open\"\n\nexternal caml_sys_close : int -> unit = \"caml_sys_close\"\nexternal digest_fd_blocking : int -> string = \"core_md5_fd\"\n\nlet digest_file_blocking path =\n of_binary_exn\n (Base.Exn.protectx\n (caml_sys_open path [ Open_rdonly; Open_binary ] ~perm:0o000)\n ~f:digest_fd_blocking\n ~finally:caml_sys_close)\n;;\n\nlet file = digest_file_blocking\n\nlet digest_channel_blocking_without_releasing_runtime_lock channel ~len =\n of_binary_exn (Caml.Digest.channel channel len)\n;;\n\nlet channel channel len =\n digest_channel_blocking_without_releasing_runtime_lock channel ~len\n;;\n\nlet output_blocking t oc = Caml.Digest.output oc (to_binary t)\nlet output oc t = output_blocking t oc\nlet input_blocking ic = of_binary_exn (Caml.Digest.input ic)\nlet input = input_blocking\nlet digest_subbytes = Md5_lib.subbytes\nlet string = digest_string\nlet bytes = digest_bytes\nlet subbytes s pos len = digest_subbytes s ~pos ~len\n\nlet digest_bin_prot writer value =\n digest_string (Core_bin_prot.Writer.to_string writer value)\n;;\n\nexternal c_digest_subbigstring\n : Bigstring.t\n -> pos:int\n -> len:int\n -> res:Bytes.t\n -> unit\n = \"core_md5_digest_subbigstring\"\n\nlet unsafe_digest_subbigstring buf ~pos ~len =\n (* It's more efficient to allocate the result on the OCaml side and declare the C\n function as noalloc than to let the C function allocate. *)\n let res = Bytes.create 16 in\n c_digest_subbigstring buf ~pos ~len ~res;\n Md5_lib.unsafe_of_binary\n (Bytes.unsafe_to_string ~no_mutation_while_string_reachable:res)\n;;\n\nlet digest_subbigstring buf ~pos ~len =\n Ordered_collection_common.check_pos_len_exn\n ~pos\n ~len\n ~total_length:(Bigstring.length buf);\n unsafe_digest_subbigstring buf ~pos ~len\n;;\n\nlet digest_bigstring buf =\n unsafe_digest_subbigstring buf ~pos:0 ~len:(Bigstring.length buf)\n;;\n","(** Time-zone handling. *)\n\nopen! Import\n\n(** The internal time representation of [Zone.t]. This is a tiny subset of [Time0_intf.S],\n see that interface for details such as the meaning of [Span] and [Date_and_ofday].\n\n The name of the interface reflects the fact that the interface only gives you access\n to the seconds of the [t]. But you can use this interface with types that have higher\n precision than that, hence the rounding implied in the name of\n [to_int63_seconds_round_down_exn].\n*)\nmodule type Time_in_seconds = sig\n module Span : sig\n type t\n\n val of_int63_seconds : Int63.t -> t\n val to_int63_seconds_round_down_exn : t -> Int63.t\n end\n\n module Date_and_ofday : sig\n type t\n\n val of_synthetic_span_since_epoch : Span.t -> t\n val to_synthetic_span_since_epoch : t -> Span.t\n end\n\n type t\n\n val of_span_since_epoch : Span.t -> t\n val to_span_since_epoch : t -> Span.t\nend\n\n(** This is the interface of [Zone], but not the interface of [Time.Zone] or\n [Time_ns.Zone]. For those, look at [Time_intf.Zone] *)\nmodule type S = sig\n (** {1 User-friendly interface} *)\n\n (** The type of a time-zone.\n\n bin_io and sexp representations of Zone.t are the name of the zone, and\n not the full data that is read from disk when Zone.find is called. The\n full Zone.t is reconstructed on the receiving/reading side by reloading\n the zone file from disk. Any zone name that is accepted by [find] is\n acceptable in the bin_io and sexp representations. *)\n type t [@@deriving sexp_of, compare]\n\n (** [input_tz_file ~zonename ~filename] read in [filename] and return [t]\n with [name t] = [zonename] *)\n val input_tz_file : zonename:string -> filename:string -> t\n\n (** [likely_machine_zones] is a list of zone names that will be searched\n first when trying to determine the machine zone of a box. Setting this\n to a likely set of zones for your application will speed the very first\n use of the local timezone. *)\n val likely_machine_zones : string list ref\n\n (** [of_utc_offset offset] returns a timezone with a static UTC offset (given in\n hours). *)\n val of_utc_offset : hours:int -> t\n\n (** [utc] the UTC time zone. Included for convenience *)\n val utc : t\n\n val name : t -> string\n\n (** [original_filename t] return the filename [t] was loaded from (if any) *)\n val original_filename : t -> string option\n\n (** [digest t] return the MD5 digest of the file the t was created from (if any) *)\n val digest : t -> Md5.t option\n\n module Time_in_seconds : Time_in_seconds\n\n (** For performance testing only; [reset_transition_cache t] resets an internal cache in\n [t] used to speed up repeated lookups of the same clock shift transition. *)\n val reset_transition_cache : t -> unit\n\n (** A time zone index refers to a range of times delimited by DST transitions at one or\n both ends. Every time belongs to exactly one such range. The times of DST\n transitions themselves belong to the range for which they are the lower bound. *)\n module Index : sig\n type t [@@immediate]\n\n val next : t -> t\n val prev : t -> t\n end\n\n (** Gets the index of a time. *)\n val index : t -> Time_in_seconds.t -> Index.t\n\n val index_of_date_and_ofday : t -> Time_in_seconds.Date_and_ofday.t -> Index.t\n\n (** Gets the UTC offset of times in a specific range.\n\n This can raise if you use an [Index.t] that is out of bounds for this [t]. *)\n val index_offset_from_utc_exn : t -> Index.t -> Time_in_seconds.Span.t\n\n (** [index_abbreviation_exn t index] returns the abbreviation name (such as EDT, EST,\n JST) of given zone [t] for the range of [index]. This string conversion is one-way\n only, and cannot reliably be turned back into a [t]. This function reads and writes\n the zone's cached index. Raises if [index] is out of bounds for [t]. *)\n val index_abbreviation_exn : t -> Index.t -> string\n\n (** Accessors for the DST transitions delimiting the start and end of a range, if any.\n The [_exn] accessors raise if there is no such transition. These accessors are split\n up to increase performance and improve allocation; they are intended as a low-level\n back-end for commonly-used time conversion functions. See [Time.Zone] and\n [Time_ns.Zone] for higher-level accessors that return an optional tuple for clock\n shifts in either direction. *)\n val index_has_prev_clock_shift : t -> Index.t -> bool\n\n val index_prev_clock_shift_time_exn : t -> Index.t -> Time_in_seconds.t\n val index_prev_clock_shift_amount_exn : t -> Index.t -> Time_in_seconds.Span.t\n val index_has_next_clock_shift : t -> Index.t -> bool\n val index_next_clock_shift_time_exn : t -> Index.t -> Time_in_seconds.t\n val index_next_clock_shift_amount_exn : t -> Index.t -> Time_in_seconds.Span.t\nend\n\nmodule type S_stable = sig\n type t\n\n module Full_data : sig\n module V1 : Stable_module_types.S0_without_comparator with type t = t\n end\nend\n\nmodule type Zone = sig\n module type S = S\n module type S_stable = S_stable\n\n include S\n module Stable : S_stable with type t := t\nend\n","open! Import\ninclude Binable_intf\ninclude Binable0\n\n(* [of_string] and [to_string] can't go in binable0.ml due to a cyclic dependency. *)\nlet of_string m string = of_bigstring m (Bigstring.of_string string)\nlet to_string m t = Bigstring.to_string (to_bigstring m t)\n\nmodule Of_binable = Of_binable_without_uuid [@@alert \"-legacy\"]\nmodule Of_binable1 = Of_binable1_without_uuid [@@alert \"-legacy\"]\nmodule Of_binable2 = Of_binable2_without_uuid [@@alert \"-legacy\"]\nmodule Of_binable3 = Of_binable3_without_uuid [@@alert \"-legacy\"]\nmodule Of_sexpable = Of_sexpable_without_uuid [@@alert \"-legacy\"]\nmodule Of_stringable = Of_stringable_without_uuid [@@alert \"-legacy\"]\n","(* Functions for parsing time zone database files (zic files).\n\n A time zone file consists (conceptually - the representation is more\n compact) of an ordered list of (Time.t * [local_time_type]) that mark\n the boundaries (marked from the epoch) at which various time adjustment\n regimes are in effect. This can also be thought of as breaking down all\n time past the epoch into ranges with a [local_time_type] that describes the\n offset from GMT to apply to each range to get local time.\n*)\n\nopen Import\nopen Std_internal\nopen! Int.Replace_polymorphic_compare\ninclude Zone_intf\n\nexception Invalid_file_format of string [@@deriving sexp]\n\nmodule Stable = struct\n module Full_data = struct\n module V1 = struct\n module Index = struct\n type t = int\n\n let next = Int.succ\n let prev = Int.pred\n let before_first_transition = -1\n\n (* Some existing clients expect [index >= 0], so we never serialize a negative\n index. This conversion can be removed if new stable versions are minted. *)\n let to_external t = max 0 t\n\n (* When the index of a time zone with no transitions is converted via to_external,\n its value becomes 0 even though its transition array is empty (and it should\n have been -1). When the converted value is changed back to a Zone.t through\n of_external, returning this value for its index could result in unsafe array\n accesses to the transition array of the zone (since there is no transition at\n index 0). Also, it does not make sense to keep the converted index because it\n is intended to be a mutable value used for caching. So of_external always sets\n the index to -1, which is a safe value. *)\n let of_external (_ : t) = -1\n\n include Binable.Of_binable_without_uuid [@alert \"-legacy\"]\n (Int)\n (struct\n type t = int\n\n let to_binable = to_external\n let of_binable = of_external\n end)\n\n include Sexpable.Of_sexpable\n (Int)\n (struct\n type t = int\n\n let to_sexpable = to_external\n let of_sexpable = of_external\n end)\n end\n\n module Regime = struct\n type t =\n { utc_offset_in_seconds : Int63.Stable.V1.t\n ; is_dst : bool\n ; abbrv : string\n }\n [@@deriving bin_io, sexp]\n end\n\n (* holds information about when leap seconds should be applied - unused\n because we are translating based on a epoch system clock (see the Core_zone\n documentation). *)\n module Leap_second = struct\n type t =\n { time_in_seconds_since_epoch : Int63.Stable.V1.t\n ; seconds : int\n }\n [@@deriving bin_io, sexp]\n end\n\n module Transition = struct\n type t =\n { start_time_in_seconds_since_epoch : Int63.Stable.V1.t\n ; new_regime : Regime.t\n }\n [@@deriving bin_io, sexp]\n end\n\n type t =\n { name : string\n ; original_filename : string option\n ;\n digest : Md5.As_binary_string.t option\n ; transitions : Transition.t array\n ; (* caches the index of the last transition we used to make lookups faster *)\n mutable last_regime_index : Index.t\n ; default_local_time_type : Regime.t\n ; leap_seconds : Leap_second.t list\n }\n [@@deriving bin_io, sexp]\n\n (* this relies on zones with the same name having the same transitions *)\n let compare t1 t2 = String.compare t1.name t2.name\n let original_filename zone = zone.original_filename\n let digest zone = zone.digest\n\n module Zone_file : sig\n val input_tz_file : zonename:string -> filename:string -> t\n end = struct\n let bool_of_int i = i <> 0\n\n let input_long_as_int32 =\n let long = Bytes.create 4 in\n let int32_of_char chr = Int32.of_int_exn (int_of_char chr) in\n fun ic ->\n In_channel.really_input_exn ic ~buf:long ~pos:0 ~len:4;\n let sb1 = Int32.shift_left (int32_of_char (Bytes.get long 0)) 24 in\n let sb2 = Int32.shift_left (int32_of_char (Bytes.get long 1)) 16 in\n let sb3 = Int32.shift_left (int32_of_char (Bytes.get long 2)) 8 in\n let sb4 = int32_of_char (Bytes.get long 3) in\n Int32.bit_or (Int32.bit_or sb1 sb2) (Int32.bit_or sb3 sb4)\n ;;\n\n (* Note that this is only safe to use on numbers that will fit into a 31-bit\n int. UNIX timestamps won't, for example. In our case this is only used\n to hold small numbers that are never interpreted as timestamps. *)\n let input_long_as_int ic = Int32.to_int_exn (input_long_as_int32 ic)\n let input_long_as_int63 ic = Int63.of_int32 (input_long_as_int32 ic)\n\n let input_long_long_as_int63 ic =\n let int63_of_char chr = Int63.of_int_exn (int_of_char chr) in\n let shift c bits = Int63.shift_left (int63_of_char c) bits in\n let long_long = Bytes.create 8 in\n In_channel.really_input_exn ic ~buf:long_long ~pos:0 ~len:8;\n let result = shift (Bytes.get long_long 0) 56 in\n let result = Int63.bit_or result (shift (Bytes.get long_long 1) 48) in\n let result = Int63.bit_or result (shift (Bytes.get long_long 2) 40) in\n let result = Int63.bit_or result (shift (Bytes.get long_long 3) 32) in\n let result = Int63.bit_or result (shift (Bytes.get long_long 4) 24) in\n let result = Int63.bit_or result (shift (Bytes.get long_long 5) 16) in\n let result = Int63.bit_or result (shift (Bytes.get long_long 6) 8) in\n let result = Int63.bit_or result (int63_of_char (Bytes.get long_long 7)) in\n result\n ;;\n\n let input_list ic ~len ~f =\n let rec loop c lst =\n if c > 0 then loop (c - 1) (f ic :: lst) else List.rev lst\n in\n loop len []\n ;;\n\n let input_array ic ~len ~f = Array.of_list (input_list ic ~len ~f)\n\n let input_regime ic =\n let utc_offset_in_seconds = input_long_as_int63 ic in\n let is_dst = bool_of_int (Option.value_exn (In_channel.input_byte ic)) in\n let abbrv_index = Option.value_exn (In_channel.input_byte ic) in\n let lt abbrv = { Regime.utc_offset_in_seconds; is_dst; abbrv } in\n lt, abbrv_index\n ;;\n\n let input_abbreviations ic ~len =\n let raw_abbrvs =\n input_list ic ~len ~f:(fun ic -> Option.value_exn (In_channel.input_char ic))\n in\n let buf = Buffer.create len in\n let _, indexed_abbrvs =\n List.fold raw_abbrvs ~init:(0, Map.Poly.empty) ~f:(fun (index, abbrvs) c ->\n match c with\n | '\\000' ->\n let data = Buffer.contents buf in\n let next_index = index + String.length data + 1 in\n let abbrvs = Map.set abbrvs ~key:index ~data in\n Buffer.clear buf;\n next_index, abbrvs\n | c ->\n Buffer.add_char buf c;\n index, abbrvs)\n in\n if Buffer.length buf <> 0\n then\n raise\n (Invalid_file_format\n \"missing \\000 terminating character in input_abbreviations\");\n indexed_abbrvs\n ;;\n\n let input_tz_file_gen ~input_transition ~input_leap_second ic =\n let utc_local_count = input_long_as_int ic in\n let std_wall_count = input_long_as_int ic in\n let leap_count = input_long_as_int ic in\n let transition_count = input_long_as_int ic in\n let type_count = input_long_as_int ic in\n let abbrv_char_count = input_long_as_int ic in\n let transition_times =\n input_list ic ~f:input_transition ~len:transition_count\n in\n let transition_indices =\n input_list\n ic\n ~f:(fun ic -> Option.value_exn (In_channel.input_byte ic))\n ~len:transition_count\n in\n let regimes = input_list ic ~f:input_regime ~len:type_count in\n let abbreviations = input_abbreviations ic ~len:abbrv_char_count in\n let leap_seconds = input_list ic ~f:input_leap_second ~len:leap_count in\n (* The following two arrays indicate two boolean values per regime that\n represent a three-value type that would translate to:\n\n type transition_type = UTC | Standard | Wall_clock\n\n However, these are only used by the system library when handling the case where the\n TZ variable is set, not to a time zone name, but instead is of the form:\n\n TZ = \"std offset dst offset, rule\"\n\n Which is deeply obscure, and almost certainly a mistake to use. This library makes\n no pretense about handling this case. We continue to read them in for\n completeness, and because it's possible that we will later discover a case where\n they are used. *)\n let _std_wall_indicators =\n input_array ic ~len:std_wall_count ~f:(fun ic ->\n bool_of_int (Option.value_exn (In_channel.input_byte ic)))\n in\n let _utc_local_indicators =\n input_array ic ~len:utc_local_count ~f:(fun ic ->\n bool_of_int (Option.value_exn (In_channel.input_byte ic)))\n in\n let regimes =\n Array.of_list\n (List.map regimes ~f:(fun (lt, abbrv_index) ->\n let abbrv = Map.find_exn abbreviations abbrv_index in\n lt abbrv))\n in\n let raw_transitions =\n List.map2_exn transition_times transition_indices ~f:(fun time index ->\n let regime = regimes.(index) in\n time, regime)\n in\n let transitions =\n let rec make_transitions acc l =\n match l with\n | [] -> Array.of_list (List.rev acc)\n | (start_time_in_seconds_since_epoch, new_regime) :: rest ->\n make_transitions\n ({ Transition.start_time_in_seconds_since_epoch; new_regime } :: acc)\n rest\n in\n make_transitions [] raw_transitions\n in\n let default_local_time_type =\n match Array.find regimes ~f:(fun r -> not r.Regime.is_dst) with\n | None -> regimes.(0)\n | Some ltt -> ltt\n in\n fun name ~original_filename ~digest ->\n { name\n ; original_filename = Some original_filename\n ; digest = Some digest\n ; transitions\n ; last_regime_index = Index.before_first_transition\n ; default_local_time_type\n ; leap_seconds\n }\n ;;\n\n let input_leap_second_gen ~input_leap_second ic =\n let time_in_seconds_since_epoch = input_leap_second ic in\n let seconds = input_long_as_int ic in\n { Leap_second.time_in_seconds_since_epoch; seconds }\n ;;\n\n let read_header ic =\n let magic =\n let buf = Bytes.create 4 in\n In_channel.really_input_exn ic ~buf ~pos:0 ~len:4;\n Bytes.unsafe_to_string ~no_mutation_while_string_reachable:buf\n in\n if not (String.equal magic \"TZif\")\n then raise (Invalid_file_format \"magic characters TZif not present\");\n let version =\n match In_channel.input_char ic with\n | Some '\\000' -> `V1\n | Some '2' -> `V2\n | Some '3' -> `V3\n | None -> raise (Invalid_file_format \"expected version, found nothing\")\n | Some bad_version ->\n raise (Invalid_file_format (sprintf \"version (%c) is invalid\" bad_version))\n in\n (* space reserved for future use in the format *)\n In_channel.really_input_exn ic ~buf:(Bytes.create 15) ~pos:0 ~len:15;\n version\n ;;\n\n let input_tz_file_v1 ic =\n let input_leap_second =\n input_leap_second_gen ~input_leap_second:input_long_as_int63\n in\n input_tz_file_gen ~input_transition:input_long_as_int63 ~input_leap_second ic\n ;;\n\n (*\n version 2 timezone files have the format:\n\n part 1 - exactly the same as v1\n\n part 2 - same format as v1, except that 8 bytes are used to store\n transition times and leap seconds\n\n part 3 - a newline-encloded, POSIX-TZ-environment-variable-style\n string for use in handling instants after the last transition time\n stored in the file (with nothing between the newlines if there is no\n POSIX representation for such instants)\n\n We handle files in this format by parsing the first part exactly as a v1\n timezone file and then continuing to parse with 64bit reading functions in the\n right places.\n\n Version 3 timezone files are the same as version 2, except the\n POSIX-TZ-environment-variable-style string in part 3 may use two minor\n extensions to the POSIX TZ format (the hours part of its transition\n times may be signed and range from -167 through 167 instead of the\n POSIX-required unsigned values from 0 through 24; and DST is in effect all\n year if it starts January 1 at 00:00 and ends December 31 at 24:00 plus the\n difference between daylight saving and standard time).\n\n As we don't actually do anything with part 3 anyway, we can just read v3\n files as v2.\n *)\n let input_tz_file_v2_or_v3 ~version ic =\n let (_ : string -> original_filename:string -> digest:Md5_lib.t -> t) =\n input_tz_file_v1 ic\n in\n (* the header is fully repeated *)\n assert ([%compare.equal: [ `V1 | `V2 | `V3 ]] (read_header ic) version);\n let input_leap_second =\n input_leap_second_gen ~input_leap_second:input_long_long_as_int63\n in\n input_tz_file_gen\n ~input_transition:input_long_long_as_int63\n ~input_leap_second\n ic\n ;;\n\n let input_tz_file ~zonename ~filename =\n try\n protectx (In_channel.create filename) ~finally:In_channel.close ~f:(fun ic ->\n let make_zone =\n match read_header ic with\n | `V1 -> input_tz_file_v1 ic\n | (`V2 | `V3) as version -> input_tz_file_v2_or_v3 ~version ic\n in\n let digest = Md5.digest_file_blocking filename in\n let r = make_zone zonename ~original_filename:filename ~digest in\n r)\n with\n | Invalid_file_format reason ->\n raise (Invalid_file_format (sprintf \"%s - %s\" filename reason))\n ;;\n end\n\n let of_utc_offset ~hours:offset =\n assert (offset >= -24 && offset <= 24);\n let name =\n if offset = 0\n then \"UTC\"\n else sprintf \"UTC%s%d\" (if offset < 0 then \"-\" else \"+\") (abs offset)\n in\n let utc_offset_in_seconds = Int63.of_int (offset * 60 * 60) in\n { name\n ; original_filename = None\n ; digest = None\n ; transitions = [||]\n ; last_regime_index = Index.before_first_transition\n ; default_local_time_type =\n { Regime.utc_offset_in_seconds; is_dst = false; abbrv = name }\n ; leap_seconds = []\n }\n ;;\n end\n end\nend\n\ninclude Stable.Full_data.V1\n\nlet sexp_of_t t = Sexp.Atom t.name\n\nlet likely_machine_zones =\n ref [ \"America/New_York\"; \"Europe/London\"; \"Asia/Hong_Kong\"; \"America/Chicago\" ]\n;;\n\nlet input_tz_file = Zone_file.input_tz_file\nlet utc = of_utc_offset ~hours:0\nlet name zone = zone.name\nlet reset_transition_cache t = t.last_regime_index <- Index.before_first_transition\n\n(* Raises if [index >= Array.length t.transitions] *)\nlet get_regime_exn t index =\n if index < 0 then t.default_local_time_type else t.transitions.(index).new_regime\n;;\n\n(* In \"absolute mode\", a number of seconds is interpreted as an offset of that many\n seconds from the UNIX epoch, ignoring leap seconds.\n\n In \"date and ofday mode\", you interpret the number of seconds as a number of days in\n combination with a number of seconds since midnight, which gives you a calendar day and\n a clock face time. Then you take the time that those represent in some relevant\n timezone.\n\n Of course, if the timezone in question has DST shifts, the date and ofday might\n represent two or zero times. These times will be interpreted according to either the\n previous UTC offset or the next one, in a way whose precise details you probably\n shouldn't depend on.\n\n (For the curious, what we do is: compute the \"relative time\" of the shift according to\n the new regime, and assign relative times to the old regime or new regime depending on\n which side of the shift time they occur. Since this amounts to using the old regime\n when the clocks move forward and the new regime when the clocks move back, it's\n equivalent to calculating the corresponding Time.t's relative to both the old and the\n new regime and picking the one that occurs later. Yes, later. I had to draw a diagram\n to persuade myself that it's that way round, but it is.)\n*)\nmodule Mode = struct\n type t =\n | Absolute\n | Date_and_ofday\nend\n\nlet effective_start_time ~mode (x : Transition.t) =\n let open Int63.O in\n match (mode : Mode.t) with\n | Absolute -> x.start_time_in_seconds_since_epoch\n | Date_and_ofday ->\n x.start_time_in_seconds_since_epoch + x.new_regime.utc_offset_in_seconds\n;;\n\nlet index_lower_bound_contains_seconds_since_epoch t index ~mode seconds =\n index < 0 || Int63.( >= ) seconds (effective_start_time ~mode t.transitions.(index))\n;;\n\nlet index_upper_bound_contains_seconds_since_epoch t index ~mode seconds =\n index + 1 >= Array.length t.transitions\n || Int63.( < ) seconds (effective_start_time ~mode t.transitions.(index + 1))\n;;\n\nlet binary_search_index_of_seconds_since_epoch t ~mode seconds : Index.t =\n Array.binary_search_segmented\n t.transitions\n `Last_on_left\n ~segment_of:(fun transition ->\n if Int63.( <= ) (effective_start_time transition ~mode) seconds\n then `Left\n else `Right)\n |> Option.value ~default:Index.before_first_transition\n;;\n\nlet index_of_seconds_since_epoch t ~mode seconds =\n let index =\n let index = t.last_regime_index in\n if not (index_lower_bound_contains_seconds_since_epoch t index ~mode seconds)\n (* time is before cached index; try previous index *)\n then (\n let index = index - 1 in\n if not (index_lower_bound_contains_seconds_since_epoch t index ~mode seconds)\n (* time is before previous index; fall back on binary search *)\n then\n binary_search_index_of_seconds_since_epoch t ~mode seconds\n (* time is before cached index and not before previous, so within previous *)\n else index)\n else if not (index_upper_bound_contains_seconds_since_epoch t index ~mode seconds)\n (* time is after cached index; try next index *)\n then (\n let index = index + 1 in\n if not (index_upper_bound_contains_seconds_since_epoch t index ~mode seconds)\n (* time is after next index; fall back on binary search *)\n then\n binary_search_index_of_seconds_since_epoch t ~mode seconds\n (* time is after cached index and not after next, so within next *)\n else index (* time is within cached index *))\n else index\n in\n t.last_regime_index <- index;\n index\n;;\n\nmodule Time_in_seconds : sig\n include Zone_intf.Time_in_seconds\nend = struct\n module Span = struct\n type t = Int63.t\n\n let of_int63_seconds = ident\n let to_int63_seconds_round_down_exn = ident\n end\n\n module Absolute = struct\n type t = Int63.t\n\n let of_span_since_epoch = ident\n let to_span_since_epoch = ident\n end\n\n module Date_and_ofday = struct\n type t = Int63.t\n\n let of_synthetic_span_since_epoch = ident\n let to_synthetic_span_since_epoch = ident\n end\n\n include Absolute\nend\n\nlet index t time =\n Time_in_seconds.to_span_since_epoch time\n |> Time_in_seconds.Span.to_int63_seconds_round_down_exn\n |> index_of_seconds_since_epoch t ~mode:Absolute\n;;\n\nlet index_of_date_and_ofday t time =\n Time_in_seconds.Date_and_ofday.to_synthetic_span_since_epoch time\n |> Time_in_seconds.Span.to_int63_seconds_round_down_exn\n |> index_of_seconds_since_epoch t ~mode:Date_and_ofday\n;;\n\nlet index_has_prev_clock_shift t index = index >= 0 && index < Array.length t.transitions\nlet index_has_next_clock_shift t index = index_has_prev_clock_shift t (index + 1)\n\nlet index_prev_clock_shift_time_exn t index =\n let transition = t.transitions.(index) in\n transition.start_time_in_seconds_since_epoch\n |> Time_in_seconds.Span.of_int63_seconds\n |> Time_in_seconds.of_span_since_epoch\n;;\n\nlet index_next_clock_shift_time_exn t index =\n index_prev_clock_shift_time_exn t (index + 1)\n;;\n\nlet index_prev_clock_shift_amount_exn t index =\n let transition = t.transitions.(index) in\n let after = transition.new_regime in\n let before =\n if index = 0 then t.default_local_time_type else t.transitions.(index - 1).new_regime\n in\n Int63.( - ) after.utc_offset_in_seconds before.utc_offset_in_seconds\n |> Time_in_seconds.Span.of_int63_seconds\n;;\n\nlet index_next_clock_shift_amount_exn t index =\n index_prev_clock_shift_amount_exn t (index + 1)\n;;\n\nlet index_abbreviation_exn t index =\n let regime = get_regime_exn t index in\n regime.abbrv\n;;\n\nlet index_offset_from_utc_exn t index =\n let regime = get_regime_exn t index in\n Time_in_seconds.Span.of_int63_seconds regime.utc_offset_in_seconds\n;;\n","open! Import\ninclude Base.Source_code_position\ninclude Source_code_position0\ninclude Comparable.Extend (Base.Source_code_position) (Source_code_position0)\ninclude Hashable.Make (Source_code_position0)\n","open! Import\nopen Std_internal\nopen Validated_intf\n\nmodule type Raw = Raw\n\ntype ('raw, 'witness) t = 'raw\n\nmodule type S = S with type ('a, 'b) validated := ('a, 'b) t\nmodule type S_bin_io = S_bin_io with type ('a, 'b) validated := ('a, 'b) t\n\nmodule type S_bin_io_compare_hash_sexp =\n S_bin_io_compare_hash_sexp with type ('a, 'b) validated := ('a, 'b) t\n\nlet raw t = t\n\nmodule Make (Raw : Raw) = struct\n type witness\n type t = Raw.t [@@deriving sexp_of]\n\n let validation_failed t error =\n Error.create\n \"validation failed\"\n (t, error, Raw.here)\n [%sexp_of: Raw.t * Error.t * Source_code_position.t]\n ;;\n\n let create_exn t =\n match Validate.result (Raw.validate t) with\n | Ok () -> t\n | Error error -> Error.raise (validation_failed t error)\n ;;\n\n let create t =\n match Validate.result (Raw.validate t) with\n | Ok () -> Ok t\n | Error error -> Error (validation_failed t error)\n ;;\n\n let t_of_sexp sexp = create_exn (Raw.t_of_sexp sexp)\n let raw t = t\nend\n\nmodule Add_bin_io (Raw : sig\n type t [@@deriving bin_io]\n\n include Raw_bin_io with type t := t\n end)\n (Validated : S with type raw := Raw.t) =\nstruct\n include Binable.Of_binable_without_uuid [@alert \"-legacy\"]\n (Raw)\n (struct\n type t = Raw.t\n\n let of_binable raw =\n if Raw.validate_binio_deserialization\n then Validated.create_exn raw\n else raw\n ;;\n\n let to_binable = Fn.id\n end)\nend\n\nmodule Add_compare (Raw : sig\n type t [@@deriving compare]\n\n include Raw with type t := t\n end)\n (Validated : S with type raw := Raw.t) =\nstruct\n let compare t1 t2 = [%compare: Raw.t] (raw t1) (raw t2)\nend\n\nmodule Add_hash (Raw : sig\n type t [@@deriving hash]\n\n include Raw with type t := t\n end)\n (Validated : S with type raw := Raw.t) =\nstruct\n let hash_fold_t state t = Raw.hash_fold_t state (Validated.raw t)\n let hash t = Raw.hash (Validated.raw t)\nend\n\nmodule Add_typerep (Raw : sig\n type t [@@deriving typerep]\n\n include Raw with type t := t\n end)\n (Validated : S with type raw := Raw.t) =\nstruct\n type t = Raw.t [@@deriving typerep]\nend\n\nmodule Make_binable (Raw : Raw_bin_io) = struct\n module T0 = Make (Raw)\n include T0\n include Add_bin_io (Raw) (T0)\nend\n\nmodule Make_bin_io_compare_hash_sexp (Raw : sig\n type t [@@deriving compare, hash]\n\n include Raw_bin_io with type t := t\n end) =\nstruct\n module T = Make_binable (Raw)\n include T\n include Add_compare (Raw) (T)\n\n include (\n Add_hash (Raw) (T) :\n sig\n type t [@@deriving hash]\n end\n with type t := t)\nend\n","include Base.Type_equal\n\nmodule Id = struct\n include Id\n\n module Uid = struct\n module Upstream = Base.Type_equal.Id.Uid\n include Base.Type_equal.Id.Uid\n\n include Comparable.Extend\n (Upstream)\n (struct\n type t = Base.Type_equal.Id.Uid.t [@@deriving sexp]\n end)\n\n include Hashable.Make (Upstream)\n end\nend\n","(** Universal/heterogeneous maps, useful for storing values of arbitrary type in a single\n map.\n\n In order to recover a value, it must be looked up with exactly the [Key.t] it was\n stored in. In other words, given different [Key.t]s from the same [string], one will\n not be able to recover the key stored in the other one.\n\n This is similar to [Univ] in spirit.\n*)\n\nopen! Import\n\nmodule type Key = sig\n type 'a t [@@deriving sexp_of]\n\n (** For correct behavior of the map, [to_type_id] must return the same\n [Type_equal.Id] on different calls on the same input.\n *)\n val to_type_id : 'a t -> 'a Type_equal.Id.t\nend\n\nmodule type Data = sig\n type 'a t [@@deriving sexp_of]\nend\n\nmodule type Data1 = sig\n type ('s, 'a) t [@@deriving sexp_of]\nend\n\nmodule type S = sig\n type t [@@deriving sexp_of]\n\n module Key : Key\n\n type 'a data\n\n include Invariant.S with type t := t\n\n val empty : t\n val is_empty : t -> bool\n val set : t -> 'a Key.t -> 'a data -> t\n val mem : t -> 'a Key.t -> bool\n val mem_by_id : t -> Type_equal.Id.Uid.t -> bool\n val find : t -> 'a Key.t -> 'a data option\n val find_exn : t -> 'a Key.t -> 'a data\n val add : t -> 'a Key.t -> 'a data -> [ `Ok of t | `Duplicate ]\n val add_exn : t -> 'a Key.t -> 'a data -> t\n val change : t -> 'a Key.t -> f:('a data option -> 'a data option) -> t\n val change_exn : t -> 'a Key.t -> f:('a data -> 'a data) -> t\n val update : t -> 'a Key.t -> f:('a data option -> 'a data) -> t\n val remove : t -> 'a Key.t -> t\n val remove_by_id : t -> Type_equal.Id.Uid.t -> t\n\n module Packed : sig\n type t = T : 'a Key.t * 'a data -> t\n end\n\n val to_alist : t -> Packed.t list\n val of_alist_exn : Packed.t list -> t\nend\n\nmodule type S1 = sig\n (** The ['s] parameter is shared across all values stored in the map. *)\n type 's t [@@deriving sexp_of]\n\n module Key : Key\n\n type ('s, 'a) data\n\n val invariant : _ t -> unit\n val empty : _ t\n val is_empty : _ t -> bool\n val set : 's t -> 'a Key.t -> ('s, 'a) data -> 's t\n val mem : _ t -> _ Key.t -> bool\n val mem_by_id : _ t -> Type_equal.Id.Uid.t -> bool\n val find : 's t -> 'a Key.t -> ('s, 'a) data option\n val find_exn : 's t -> 'a Key.t -> ('s, 'a) data\n val add : 's t -> 'a Key.t -> ('s, 'a) data -> [ `Ok of 's t | `Duplicate ]\n val add_exn : 's t -> 'a Key.t -> ('s, 'a) data -> 's t\n\n val change\n : 's t\n -> 'a Key.t\n -> f:(('s, 'a) data option -> ('s, 'a) data option)\n -> 's t\n\n val change_exn : 's t -> 'a Key.t -> f:(('s, 'a) data -> ('s, 'a) data) -> 's t\n val update : 's t -> 'a Key.t -> f:(('s, 'a) data option -> ('s, 'a) data) -> 's t\n val remove : 's t -> 'a Key.t -> 's t\n val remove_by_id : 's t -> Type_equal.Id.Uid.t -> 's t\n\n module Packed : sig\n type 's t = T : 'a Key.t * ('s, 'a) data -> 's t\n end\n\n val to_alist : 's t -> 's Packed.t list\n val of_alist_exn : 's Packed.t list -> 's t\nend\n\nmodule type Univ_map = sig\n module type S = S\n module type S1 = S1\n module type Key = Key\n module type Data = Data\n\n module Type_id_key : Key with type 'a t = 'a Type_equal.Id.t\n include S with type 'a data = 'a and module Key := Type_id_key\n\n (** This binding is convenient because existing call sites often refer to\n [Univ_map.Key.create].\n *)\n module Key = Type_equal.Id\n\n module Make (Key : Key) (Data : Data) :\n S with type 'a data = 'a Data.t and module Key = Key\n\n module Make1 (Key : Key) (Data : Data1) :\n S1 with type ('s, 'a) data = ('s, 'a) Data.t and module Key = Key\n\n module Merge\n (Key : Key)\n (Input1_data : Data1)\n (Input2_data : Data1)\n (Output_data : Data1) : sig\n type 's f =\n { f :\n 'a. key:'a Key.t\n -> [ `Left of ('s, 'a) Input1_data.t\n | `Right of ('s, 'a) Input2_data.t\n | `Both of ('s, 'a) Input1_data.t * ('s, 'a) Input2_data.t\n ] -> ('s, 'a) Output_data.t option\n }\n\n (** The analogue of the normal [Map.merge] function. *)\n val merge\n : 's Make1(Key)(Input1_data).t\n -> 's Make1(Key)(Input2_data).t\n -> f:'s f\n -> 's Make1(Key)(Output_data).t\n end\n\n (** keys with associated default values, so that [find] is no longer partial *)\n module With_default : sig\n module Key : sig\n type 'a t\n\n val create : default:'a -> name:string -> ('a -> Sexp.t) -> 'a t\n val id : 'a t -> 'a Type_equal.Id.t\n end\n\n val set : t -> 'a Key.t -> 'a -> t\n val find : t -> 'a Key.t -> 'a\n val change : t -> 'a Key.t -> f:('a -> 'a) -> t\n end\n\n (** keys that map to an accumulator value with an associated fold operation *)\n module With_fold : sig\n module Key : sig\n type ('a, 'b) t\n\n val create\n : init:'b\n -> f:('b -> 'a -> 'b)\n -> name:string\n -> ('b -> Sexp.t)\n -> ('a, 'b) t\n\n val id : ('a, 'b) t -> 'b Type_equal.Id.t\n end\n\n (** reset the accumulator *)\n val set : t -> ('a, 'b) Key.t -> 'b -> t\n\n (** the current accumulator *)\n val find : t -> ('a, 'b) Key.t -> 'b\n\n (** fold value into accumulator *)\n val add : t -> ('a, 'b) Key.t -> 'a -> t\n\n (** accumulator update *)\n val change : t -> ('a, 'b) Key.t -> f:('b -> 'b) -> t\n end\n\n (** list-accumulating keys with a default value of the empty list *)\n module Multi : sig\n module Key : sig\n type 'a t\n\n val create : name:string -> ('a -> Sexp.t) -> 'a t\n val id : 'a t -> 'a list Type_equal.Id.t\n end\n\n val set : t -> 'a Key.t -> 'a list -> t\n val find : t -> 'a Key.t -> 'a list\n val add : t -> 'a Key.t -> 'a -> t\n val change : t -> 'a Key.t -> f:('a list -> 'a list) -> t\n end\nend\n","open! Import\n\ntype t =\n | Nanosecond\n | Microsecond\n | Millisecond\n | Second\n | Minute\n | Hour\n | Day\n[@@deriving sexp, compare, enumerate, hash]\n","open! Import\nopen Std_internal\nopen Unique_id_intf\n\nmodule type Id = Id\n\n(* Only \"make\" can cause a context-switch that might lead to a race.\n Thus we have to check whether the contents of the cell remained\n unchanged across this call. The subsequent comparison, dereferencing\n and assignment cannot cause context switches. If the contents of the\n cell had changed, we will have to try again to obtain a unique id.\n This is essentially like a spin-lock and is virtually guaranteed to\n succeed quickly. *)\nlet rec race_free_create_loop cell make =\n let x = !cell in\n let new_x = make x in\n if phys_equal !cell x\n then (\n cell := new_x;\n x)\n else race_free_create_loop cell make\n;;\n\nmodule Int () = struct\n include Int\n\n let current = ref zero\n let create () = race_free_create_loop current succ\nend\n\nmodule Int63 () = struct\n include Int63\n\n let current = ref zero\n let create () = race_free_create_loop current succ\nend\n","open! Import\ninclude Base.Uniform_array\n\ninclude Binable.Of_binable1_without_uuid [@alert \"-legacy\"]\n (Array)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable = to_array\n let of_binable = of_array\n end)\n","open! Import\n\nlet failwithf = Printf.failwithf\n\nmodule Stable = struct\n module V1 = struct\n module T = struct\n type t =\n | Sun\n | Mon\n | Tue\n | Wed\n | Thu\n | Fri\n | Sat\n [@@deriving bin_io, compare, hash, quickcheck]\n\n let to_string t =\n match t with\n | Sun -> \"SUN\"\n | Mon -> \"MON\"\n | Tue -> \"TUE\"\n | Wed -> \"WED\"\n | Thu -> \"THU\"\n | Fri -> \"FRI\"\n | Sat -> \"SAT\"\n ;;\n\n let to_string_long t =\n match t with\n | Sun -> \"Sunday\"\n | Mon -> \"Monday\"\n | Tue -> \"Tuesday\"\n | Wed -> \"Wednesday\"\n | Thu -> \"Thursday\"\n | Fri -> \"Friday\"\n | Sat -> \"Saturday\"\n ;;\n\n let of_string_internal s =\n match String.uppercase s with\n | \"SUN\" | \"SUNDAY\" -> Sun\n | \"MON\" | \"MONDAY\" -> Mon\n | \"TUE\" | \"TUESDAY\" -> Tue\n | \"WED\" | \"WEDNESDAY\" -> Wed\n | \"THU\" | \"THURSDAY\" -> Thu\n | \"FRI\" | \"FRIDAY\" -> Fri\n | \"SAT\" | \"SATURDAY\" -> Sat\n | _ -> failwithf \"Day_of_week.of_string: %S\" s ()\n ;;\n\n let of_int_exn i =\n match i with\n | 0 -> Sun\n | 1 -> Mon\n | 2 -> Tue\n | 3 -> Wed\n | 4 -> Thu\n | 5 -> Fri\n | 6 -> Sat\n | _ -> failwithf \"Day_of_week.of_int_exn: %d\" i ()\n ;;\n\n (* Be very generous with of_string. We accept all possible capitalizations and the\n integer representations as well. *)\n let of_string s =\n try of_string_internal s with\n | _ ->\n (try of_int_exn (Int.of_string s) with\n | _ -> failwithf \"Day_of_week.of_string: %S\" s ())\n ;;\n\n (* this is in T rather than outside so that the later functor application to build maps\n uses this sexp representation *)\n include Sexpable.Stable.Of_stringable.V1 (struct\n type nonrec t = t\n\n let of_string = of_string\n let to_string = to_string\n end)\n end\n\n include T\n\n module Unstable = struct\n include T\n include (Comparable.Make_binable (T) : Comparable.S_binable with type t := t)\n include Hashable.Make_binable (T)\n end\n\n include Comparable.Stable.V1.Make (Unstable)\n include Hashable.Stable.V1.Make (Unstable)\n end\nend\n\ninclude Stable.V1.Unstable\n\nlet weekdays = [ Mon; Tue; Wed; Thu; Fri ]\nlet weekends = [ Sat; Sun ]\n\n(* written out to save overhead when loading modules. The members of the set and the\n ordering should never change, so speed wins over something more complex that proves\n the order = the order in t at runtime *)\nlet all = [ Sun; Mon; Tue; Wed; Thu; Fri; Sat ]\n\nlet of_int i =\n try Some (of_int_exn i) with\n | _ -> None\n;;\n\nlet to_int t =\n match t with\n | Sun -> 0\n | Mon -> 1\n | Tue -> 2\n | Wed -> 3\n | Thu -> 4\n | Fri -> 5\n | Sat -> 6\n;;\n\nlet iso_8601_weekday_number t =\n match t with\n | Mon -> 1\n | Tue -> 2\n | Wed -> 3\n | Thu -> 4\n | Fri -> 5\n | Sat -> 6\n | Sun -> 7\n;;\n\nlet num_days_in_week = 7\nlet shift t i = of_int_exn (Int.( % ) (to_int t + i) num_days_in_week)\n\nlet num_days ~from ~to_ =\n let d = to_int to_ - to_int from in\n if Int.(d < 0) then d + num_days_in_week else d\n;;\n\nlet is_sun_or_sat t = t = Sun || t = Sat\n","open! Import\nopen Std_internal\nopen Digit_string_helpers\n\nlet suffixes char =\n let sprintf = Printf.sprintf in\n [ sprintf \"%c\" char; sprintf \"%cM\" char; sprintf \"%c.M\" char; sprintf \"%c.M.\" char ]\n |> List.concat_map ~f:(fun suffix ->\n [ String.lowercase suffix; String.uppercase suffix ])\n;;\n\nlet am_suffixes = lazy (suffixes 'A')\nlet pm_suffixes = lazy (suffixes 'P')\n\n(* Avoids the allocation that [List.find] would entail in both both the closure input and\n the option output. *)\nlet rec find_suffix string suffixes =\n match suffixes with\n | suffix :: suffixes ->\n if String.is_suffix string ~suffix then suffix else find_suffix string suffixes\n | [] -> \"\"\n;;\n\nlet has_colon string pos ~until = pos < until && Char.equal ':' string.[pos]\n\n(* This function defines what we meant by \"decimal point\", because in some string formats\n it means '.' and in some it can be '.' or ','. There's no particular demand for support\n for ',', and using just '.' lets us use [Float.of_string] for the decimal substring\n without any substitutions. *)\nlet char_is_decimal_point string pos = Char.equal '.' string.[pos]\n\nlet decrement_length_if_ends_in_space string len =\n if len > 0 && Char.equal ' ' string.[len - 1] then len - 1 else len\n;;\n\nlet[@cold] invalid_string string ~reason =\n raise_s [%message \"Time.Ofday: invalid string\" string reason]\n;;\n\nlet check_digits_with_underscore_and_return_if_nonzero string pos ~until =\n let nonzero = ref false in\n for pos = pos to until - 1 do\n match string.[pos] with\n | '0' | '_' -> ()\n | '1' .. '9' -> nonzero := true\n | _ ->\n invalid_string\n string\n ~reason:\"expected digits and/or underscores after decimal point\"\n done;\n !nonzero\n;;\n\nlet check_digits_without_underscore_and_return_if_nonzero string pos ~until =\n let nonzero = ref false in\n for pos = pos to until - 1 do\n match string.[pos] with\n | '0' -> ()\n | '1' .. '9' -> nonzero := true\n | _ -> invalid_string string ~reason:\"expected digits after decimal point\"\n done;\n !nonzero\n;;\n\nlet parse string ~f =\n let len = String.length string in\n let am_or_pm, until =\n (* discriminate among AM (1:30am), PM (12:30:00 P.M.), or 24-hr (13:00). *)\n match\n ( find_suffix string (Lazy.force am_suffixes)\n , find_suffix string (Lazy.force pm_suffixes) )\n with\n | \"\", \"\" -> `hr_24, len\n | am, \"\" -> `hr_AM, decrement_length_if_ends_in_space string (len - String.length am)\n | \"\", pm -> `hr_PM, decrement_length_if_ends_in_space string (len - String.length pm)\n | _, _ -> `hr_24, assert false\n (* Immediately above, it may seem nonsensical to write [`hr_24, assert false] when the\n [`hr_24] can never be returned. We do this to help the compiler figure out never to\n allocate a tuple in this code: the [let] pattern is syntactically a tuple and every\n match clause is syntactically a tuple. *)\n in\n let pos = 0 in\n let pos, hr, expect_minutes_and_seconds =\n (* e.g. \"1:00\" or \"1:00:00\" *)\n if has_colon string (pos + 1) ~until\n then\n pos + 2, read_1_digit_int string ~pos, `Minutes_and_maybe_seconds\n (* e.g. \"12:00\" or \"12:00:00\" *)\n else if has_colon string (pos + 2) ~until\n then\n pos + 3, read_2_digit_int string ~pos, `Minutes_and_maybe_seconds\n (* e.g. \"1am\"; must have AM or PM (checked below) *)\n else if pos + 1 = until\n then\n pos + 1, read_1_digit_int string ~pos, `Neither_minutes_nor_seconds\n (* e.g. \"12am\"; must have AM or PM (checked below) *)\n else if pos + 2 = until\n then\n pos + 2, read_2_digit_int string ~pos, `Neither_minutes_nor_seconds\n (* e.g. \"0930\"; must not have seconds *)\n else pos + 2, read_2_digit_int string ~pos, `Minutes_but_not_seconds\n in\n let pos, min, expect_seconds =\n match expect_minutes_and_seconds with\n | `Neither_minutes_nor_seconds ->\n (* e.g. \"12am\" *)\n pos, 0, false\n | (`Minutes_and_maybe_seconds | `Minutes_but_not_seconds) as maybe_seconds ->\n (* e.g. \"12:00:00\" *)\n if has_colon string (pos + 2) ~until\n then\n ( pos + 3\n , read_2_digit_int string ~pos\n , match maybe_seconds with\n | `Minutes_and_maybe_seconds -> true\n | `Minutes_but_not_seconds ->\n invalid_string string ~reason:\"expected end of string after minutes\" )\n (* e.g. \"12:00\" *)\n else if pos + 2 = until\n then pos + 2, read_2_digit_int string ~pos, false\n else\n invalid_string\n string\n ~reason:\"expected colon or am/pm suffix with optional space after minutes\"\n in\n let sec, subsec_pos, subsec_len, subsec_nonzero =\n match expect_seconds with\n | false ->\n (* e.g. \"12am\" or \"12:00\" *)\n if pos = until\n then 0, pos, 0, false\n else\n (* This case is actually unreachable, based on the various ways that\n [expect_seconds] can end up false. *)\n invalid_string string ~reason:\"BUG: did not expect seconds, but found them\"\n | true ->\n (* e.g. \"12:00:00\" *)\n if pos + 2 > until\n then\n (* e.g. \"12:00:0\" *)\n invalid_string string ~reason:\"expected two digits of seconds\"\n else (\n let sec = read_2_digit_int string ~pos in\n let pos = pos + 2 in\n (* e.g. \"12:00:00\" *)\n if pos = until\n then sec, pos, 0, false (* e.g. \"12:00:00.123\" *)\n else if pos < until && char_is_decimal_point string pos\n then\n ( sec\n , pos\n , until - pos\n , check_digits_with_underscore_and_return_if_nonzero string (pos + 1) ~until )\n else\n invalid_string\n string\n ~reason:\"expected decimal point or am/pm suffix after seconds\")\n in\n let hr =\n (* NB. We already know [hr] is non-negative, because it's the result of\n [read_2_digit_int]. *)\n match am_or_pm with\n | `hr_AM ->\n (* e.g. \"12:00am\" *)\n if hr < 1 || hr > 12\n then invalid_string string ~reason:\"hours out of bounds\"\n else if hr = 12\n then 0\n else hr\n | `hr_PM ->\n (* e.g. \"12:00pm\" *)\n if hr < 1 || hr > 12\n then invalid_string string ~reason:\"hours out of bounds\"\n else if hr = 12\n then 12\n else hr + 12\n | `hr_24 ->\n (match expect_minutes_and_seconds with\n | `Neither_minutes_nor_seconds ->\n invalid_string string ~reason:\"hours without minutes or AM/PM\"\n | `Minutes_but_not_seconds | `Minutes_and_maybe_seconds ->\n if hr > 24\n then invalid_string string ~reason:\"hours out of bounds\"\n else if hr = 24 && (min > 0 || sec > 0 || subsec_nonzero)\n then invalid_string string ~reason:\"time is past 24:00:00\" (* e.g. \"13:00:00\" *)\n else hr)\n in\n let min =\n if min > 59 then invalid_string string ~reason:\"minutes out of bounds\" else min\n in\n let sec =\n if sec > 60 then invalid_string string ~reason:\"seconds out of bounds\" else sec\n in\n let subsec_len = if sec = 60 || not subsec_nonzero then 0 else subsec_len in\n f string ~hr ~min ~sec ~subsec_pos ~subsec_len\n;;\n\nlet parse_iso8601_extended ?pos ?len str ~f =\n let pos, len =\n match\n Ordered_collection_common.get_pos_len\n ()\n ?pos\n ?len\n ~total_length:(String.length str)\n with\n | Result.Ok z -> z\n | Result.Error s ->\n failwithf \"Ofday.of_string_iso8601_extended: %s\" (Error.to_string_mach s) ()\n in\n if len < 2\n then failwith \"len < 2\"\n else (\n let hr = read_2_digit_int str ~pos in\n if hr > 24 then failwith \"hour > 24\";\n if len = 2\n then f str ~hr ~min:0 ~sec:0 ~subsec_pos:(pos + len) ~subsec_len:0\n else if len < 5\n then failwith \"2 < len < 5\"\n else if not (Char.equal str.[pos + 2] ':')\n then failwith \"first colon missing\"\n else (\n let min = read_2_digit_int str ~pos:(pos + 3) in\n if min >= 60 then failwith \"minute > 60\";\n if hr = 24 && min <> 0 then failwith \"24 hours and non-zero minute\";\n if len = 5\n then f str ~hr ~min ~sec:0 ~subsec_pos:(pos + len) ~subsec_len:0\n else if len < 8\n then failwith \"5 < len < 8\"\n else if not (Char.equal str.[pos + 5] ':')\n then failwith \"second colon missing\"\n else (\n let sec = read_2_digit_int str ~pos:(pos + 6) in\n (* second can be 60 in the case of a leap second. Unfortunately, what with\n non-hour-multiple timezone offsets, we can't say anything about what\n the hour or minute must be in that case *)\n if sec > 60 then failwithf \"invalid second: %i\" sec ();\n if hr = 24 && sec <> 0 then failwith \"24 hours and non-zero seconds\";\n if len = 8\n then f str ~hr ~min ~sec ~subsec_pos:(pos + len) ~subsec_len:0\n else if len = 9\n then failwith \"length = 9\"\n else (\n match str.[pos + 8] with\n | '.' | ',' ->\n let subsec_pos = pos + 8 in\n let subsec_len =\n match\n check_digits_without_underscore_and_return_if_nonzero\n str\n (subsec_pos + 1)\n ~until:(pos + len)\n with\n | true when sec = 60 -> 0\n | true when hr = 24 -> failwith \"24 hours and non-zero subseconds\"\n | _ -> len - 8\n in\n f str ~hr ~min ~sec ~subsec_pos ~subsec_len\n | _ -> failwith \"missing subsecond separator\"))))\n;;\n","open! Import\ninclude Bin_prot.Std\ninclude Hash.Builtin\n\ninclude (\n Base :\n sig\n type nonrec 'a array = 'a array [@@deriving sexp, sexp_grammar]\n type nonrec bool = bool [@@deriving sexp, sexp_grammar]\n type nonrec char = char [@@deriving sexp, sexp_grammar]\n type nonrec exn = exn [@@deriving sexp_of]\n type nonrec float = float [@@deriving sexp, sexp_grammar]\n type nonrec int = int [@@deriving sexp, sexp_grammar]\n type nonrec int32 = int32 [@@deriving sexp, sexp_grammar]\n type nonrec int64 = int64 [@@deriving sexp, sexp_grammar]\n type nonrec 'a list = 'a list [@@deriving sexp, sexp_grammar]\n type nonrec nativeint = nativeint [@@deriving sexp, sexp_grammar]\n type nonrec 'a option = 'a option [@@deriving sexp, sexp_grammar]\n type nonrec 'a ref = 'a ref [@@deriving sexp, sexp_grammar]\n type nonrec string = string [@@deriving sexp, sexp_grammar]\n type nonrec bytes = bytes [@@deriving sexp, sexp_grammar]\n type nonrec unit = unit [@@deriving sexp, sexp_grammar]\n end\n with type 'a array := 'a array\n with type bool := bool\n with type char := char\n with type exn := exn\n with type float := float\n with type int := int\n with type int32 := int32\n with type int64 := int64\n with type 'a list := 'a list\n with type nativeint := nativeint\n with type 'a option := 'a option\n with type 'a ref := 'a ref\n with type string := string\n with type bytes := bytes\n with type unit := unit)\n\ninclude (\nstruct\n type 'a sexp_option = ('a Std_internal.sexp_option[@ocaml.warning \"-3\"])\n [@@deriving bin_io, compare, hash]\n\n type 'a sexp_list = ('a Std_internal.sexp_list[@ocaml.warning \"-3\"])\n [@@deriving bin_io, compare, hash]\nend :\nsig\n type 'a sexp_option = ('a Std_internal.sexp_option[@ocaml.warning \"-3\"])\n [@@deriving bin_io, compare, hash]\n\n type 'a sexp_list = ('a Std_internal.sexp_list[@ocaml.warning \"-3\"])\n [@@deriving bin_io, compare, hash]\nend\nwith type 'a sexp_option := ('a Std_internal.sexp_option[@ocaml.warning \"-3\"])\nwith type 'a sexp_list := ('a Std_internal.sexp_list[@ocaml.warning \"-3\"]))\n\ntype 'a sexp_option = ('a Std_internal.sexp_option[@ocaml.warning \"-3\"])\n[@@deprecated \"[since 2019-03] use [@sexp.option] instead\"]\n\ntype 'a sexp_list = ('a Std_internal.sexp_list[@ocaml.warning \"-3\"])\n[@@deprecated \"[since 2019-03] use [@sexp.list] instead\"]\n","open Ppx_compare_lib.Builtin\n\nmodule Stable = struct\n open Stable_internal\n module Binable = Binable.Stable\n\n module V1 = struct\n exception Nan_or_inf [@@deriving sexp]\n\n type t = float [@@deriving compare, hash]\n\n let verify t =\n match Caml.classify_float t with\n | FP_normal | FP_subnormal | FP_zero -> ()\n | FP_infinite | FP_nan -> raise Nan_or_inf\n ;;\n\n include Binable.Of_binable.V1 [@alert \"-legacy\"]\n (Float)\n (struct\n type nonrec t = t\n\n let of_binable t =\n verify t;\n t\n ;;\n\n let to_binable t =\n verify t;\n t\n ;;\n end)\n\n let sexp_of_t = Float.sexp_of_t\n\n let t_of_sexp = function\n | Sexp.Atom _ as sexp ->\n let t = Float.t_of_sexp sexp in\n (try verify t with\n | e -> Import.of_sexp_error (Import.Exn.to_string e) sexp);\n t\n | s -> Import.of_sexp_error \"Decimal.t_of_sexp: Expected Atom, found List\" s\n ;;\n end\nend\n\ninclude Stable.V1\n","open Async_kernel\nopen Core_kernel\n\nmodule type Time_intf = sig\n type t\n\n module Span : sig\n type t\n\n val to_time_ns_span : t -> Time_ns.Span.t\n\n val ( - ) : t -> t -> t\n end\n\n module Controller : sig\n type t\n end\n\n val now : Controller.t -> t\n\n val diff : t -> t -> Span.t\nend\n\nmodule Timeout_intf (Time : Time_intf) = struct\n module type S = sig\n type 'a t\n\n val create : Time.Controller.t -> Time.Span.t -> f:(Time.t -> 'a) -> 'a t\n\n val to_deferred : 'a t -> 'a Async_kernel.Deferred.t\n\n val peek : 'a t -> 'a option\n\n val cancel : Time.Controller.t -> 'a t -> 'a -> unit\n\n val remaining_time : 'a t -> Time.Span.t\n\n val await :\n timeout_duration:Time.Span.t\n -> Time.Controller.t\n -> 'a Deferred.t\n -> [ `Ok of 'a | `Timeout ] Deferred.t\n\n val await_exn :\n timeout_duration:Time.Span.t\n -> Time.Controller.t\n -> 'a Deferred.t\n -> 'a Deferred.t\n end\nend\n\nmodule Make (Time : Time_intf) : Timeout_intf(Time).S = struct\n type 'a t =\n { deferred : 'a Deferred.t\n ; cancel : 'a -> unit\n ; start_time : Time.t\n ; span : Time.Span.t\n ; ctrl : Time.Controller.t\n }\n\n let create ctrl span ~f:action =\n let open Deferred.Let_syntax in\n let cancel_ivar = Ivar.create () in\n let timeout = after (Time.Span.to_time_ns_span span) >>| fun () -> None in\n let deferred =\n Deferred.any [ Ivar.read cancel_ivar; timeout ]\n >>| function None -> action (Time.now ctrl) | Some x -> x\n in\n let cancel value = Ivar.fill_if_empty cancel_ivar (Some value) in\n { ctrl; deferred; cancel; start_time = Time.now ctrl; span }\n\n let to_deferred { deferred; _ } = deferred\n\n let peek { deferred; _ } = Deferred.peek deferred\n\n let cancel _ { cancel; _ } value = cancel value\n\n let remaining_time { ctrl : _; start_time; span; _ } =\n let current_time = Time.now ctrl in\n let time_elapsed = Time.diff current_time start_time in\n Time.Span.(span - time_elapsed)\n\n let await ~timeout_duration time_controller deferred =\n let timeout =\n Deferred.create (fun ivar ->\n ignore\n ( create time_controller timeout_duration ~f:(fun x ->\n if Ivar.is_full ivar then\n [%log' error (Logger.create ())] \"Ivar.fill bug is here!\" ;\n Ivar.fill_if_empty ivar x )\n : unit t ) )\n in\n Deferred.(\n choose\n [ choice deferred (fun x -> `Ok x); choice timeout (Fn.const `Timeout) ])\n\n let await_exn ~timeout_duration time_controller deferred =\n match%map await ~timeout_duration time_controller deferred with\n | `Timeout ->\n failwith \"timeout\"\n | `Ok x ->\n x\nend\n\nmodule Core_time = Make (struct\n include (\n Core_kernel.Time :\n module type of Core_kernel.Time\n with module Span := Core_kernel.Time.Span\n and type underlying = float )\n\n module Controller = struct\n type t = unit\n end\n\n module Span = struct\n include Core_kernel.Time.Span\n\n let to_time_ns_span = Fn.compose Core_kernel.Time_ns.Span.of_ns to_ns\n end\n\n let diff x y =\n let x_ns = Span.to_ns @@ to_span_since_epoch x in\n let y_ns = Span.to_ms @@ to_span_since_epoch y in\n Span.of_ns (x_ns -. y_ns)\nend)\n\nmodule Core_time_ns = Make (struct\n include (\n Core_kernel.Time_ns :\n module type of Core_kernel.Time_ns\n with module Span := Core_kernel.Time_ns.Span )\n\n module Controller = struct\n type t = unit\n end\n\n module Span = struct\n include Core_kernel.Time_ns.Span\n\n let to_time_ns_span = Fn.id\n end\n\n let diff x y =\n let x_ns = Span.to_ns @@ to_span_since_epoch x in\n let y_ns = Span.to_ms @@ to_span_since_epoch y in\n Span.of_ns (x_ns -. y_ns)\nend)\n","open! Import\nopen! Std_internal\nmodule Date = Date0\n\nmodule type Zone = sig\n module Time : Time0_intf.S\n include Zone.S with type t = Zone.t and module Time_in_seconds := Time\n\n (** [abbreviation t time] returns the abbreviation name (such as EDT, EST, JST) of given\n zone [t] at [time]. This string conversion is one-way only, and cannot reliably be\n turned back into a [t]. This function reads and writes the zone's cached index. *)\n val abbreviation : t -> Time.t -> string\n\n (** [absolute_time_of_date_and_ofday] and [date_and_ofday_of_absolute_time] convert\n between absolute times and date + ofday forms. These are low level functions not\n intended for most clients. These functions read and write the zone's cached index.\n *)\n val absolute_time_of_date_and_ofday : t -> Time.Date_and_ofday.t -> Time.t\n\n val date_and_ofday_of_absolute_time : t -> Time.t -> Time.Date_and_ofday.t\n\n (** Takes a [Time.t] and returns the next [Time.t] strictly after it, if any, that the\n time zone UTC offset changes, and by how much it does so. *)\n val next_clock_shift : t -> strictly_after:Time.t -> (Time.t * Time.Span.t) option\n\n (** As [next_clock_shift], but *at or before* the given time. *)\n val prev_clock_shift : t -> at_or_before:Time.t -> (Time.t * Time.Span.t) option\nend\n\nmodule type Basic = sig\n module Time : Time0_intf.S\n\n (*_ necessary to preserve type equality with the Time functor argument *)\n\n include module type of struct\n include Time\n end\n [@ocaml.remove_aliases]\n\n (** [now ()] returns a [t] representing the current time *)\n val now : unit -> t\n\n module Zone : Zone with module Time := Time\n\n (** {6 Basic operations on times} *)\n\n (** [add t s] adds the span [s] to time [t] and returns the resulting time.\n\n NOTE: adding spans as a means of adding days is not accurate, and may run into trouble\n due to shifts in daylight savings time, float arithmetic issues, and leap seconds.\n See the comment at the top of Zone.mli for a more complete discussion of some of\n the issues of time-keeping. For spans that cross date boundaries, use date functions\n instead.\n *)\n val add : t -> Span.t -> t\n\n (** [sub t s] subtracts the span [s] from time [t] and returns the\n resulting time. See important note for [add]. *)\n val sub : t -> Span.t -> t\n\n (** [diff t1 t2] returns time [t1] minus time [t2]. *)\n val diff : t -> t -> Span.t\n\n (** [abs_diff t1 t2] returns the absolute span of time [t1] minus time [t2]. *)\n val abs_diff : t -> t -> Span.t\nend\n\nmodule type Shared = sig\n type t\n\n include Quickcheck.S_range with type t := t\n\n module Span : sig\n type t\n end\n\n module Ofday : sig\n type t\n end\n\n (** {6 Comparisons} *)\n\n val is_earlier : t -> than:t -> bool\n val is_later : t -> than:t -> bool\n\n (** {6 Conversions} *)\n\n val of_date_ofday : zone:Zone.t -> Date.t -> Ofday.t -> t\n\n (** Because timezone offsets change throughout the year (clocks go forward or back) some\n local times can occur twice or not at all. In the case that they occur twice, this\n function gives [`Twice] with both occurrences in order; if they do not occur at all,\n this function gives [`Never] with the time at which the local clock skips over the\n desired time of day.\n\n Note that this is really only intended to work with DST transitions and not unusual or\n dramatic changes, like the calendar change in 1752 (run \"cal 9 1752\" in a shell to\n see). In particular it makes the assumption that midnight of each day is unambiguous.\n\n Most callers should use {!of_date_ofday} rather than this function. In the [`Twice]\n and [`Never] cases, {!of_date_ofday} will return reasonable times for most uses. *)\n val of_date_ofday_precise\n : Date.t\n -> Ofday.t\n -> zone:Zone.t\n -> [ `Once of t | `Twice of t * t | `Never of t ]\n\n val to_date_ofday : t -> zone:Zone.t -> Date.t * Ofday.t\n\n (** Always returns the [Date.t * Ofday.t] that [to_date_ofday] would have returned, and in\n addition returns a variant indicating whether the time is associated with a time zone\n transition.\n\n {v\n - `Only -> there is a one-to-one mapping between [t]'s and\n [Date.t * Ofday.t] pairs\n - `Also_at -> there is another [t] that maps to the same [Date.t * Ofday.t]\n (this date/time pair happened twice because the clock fell back)\n - `Also_skipped -> there is another [Date.t * Ofday.t] pair that never happened (due\n to a jump forward) that [of_date_ofday] would map to the same\n [t].\n v}\n *)\n val to_date_ofday_precise\n : t\n -> zone:Zone.t\n -> Date.t * Ofday.t * [ `Only | `Also_at of t | `Also_skipped of Date.t * Ofday.t ]\n\n val to_date : t -> zone:Zone.t -> Date.t\n val to_ofday : t -> zone:Zone.t -> Ofday.t\n\n (** For performance testing only; [reset_date_cache ()] resets an internal cache used to\n speed up [to_date] and related functions when called repeatedly on times that fall\n within the same day. *)\n val reset_date_cache : unit -> unit\n\n (** Unlike [Time_ns], this module purposely omits [max_value] and [min_value]:\n 1. They produce unintuitive corner cases because most people's mental models of time\n do not include +/- infinity as concrete values\n 2. In practice, when people ask for these values, it is for questionable uses, e.g.,\n as null values to use in place of explicit options. *)\n\n (** midnight, Jan 1, 1970 in UTC *)\n val epoch : t\n\n (** It's unspecified what happens if the given date/ofday/zone correspond to more than\n one date/ofday pair in the other zone. *)\n val convert : from_tz:Zone.t -> to_tz:Zone.t -> Date.t -> Ofday.t -> Date.t * Ofday.t\n\n val utc_offset : t -> zone:Zone.t -> Span.t\n\n (** {6 Other string conversions} *)\n\n (** The [{to,of}_string] functions in [Time] convert to UTC time, because a local time\n zone is not necessarily available. They are generous in what they will read in. *)\n include\n Stringable with type t := t\n\n (** [to_filename_string t ~zone] converts [t] to string with format\n YYYY-MM-DD_HH-MM-SS.mmm which is suitable for using in filenames. *)\n val to_filename_string : t -> zone:Zone.t -> string\n\n (** [of_filename_string s ~zone] converts [s] that has format YYYY-MM-DD_HH-MM-SS.mmm into\n time. *)\n val of_filename_string : string -> zone:Zone.t -> t\n\n (** [to_string_abs ~zone t] is the same as [to_string t] except that it uses the given\n time zone. *)\n val to_string_abs : t -> zone:Zone.t -> string\n\n (** [to_string_abs_trimmed] is the same as [to_string_abs], but drops trailing seconds\n and milliseconds if they are 0. *)\n val to_string_abs_trimmed : t -> zone:Zone.t -> string\n\n val to_string_abs_parts : t -> zone:Zone.t -> string list\n\n (** Same as [to_string_abs_trimmed], except it leaves off the timezone, so won't\n reliably round trip. *)\n val to_string_trimmed : t -> zone:Zone.t -> string\n\n (** Same as [to_string_abs], but without milliseconds *)\n val to_sec_string : t -> zone:Zone.t -> string\n\n (** [of_localized_string ~zone str] read in the given string assuming that it represents\n a time in zone and return the appropriate Time.t *)\n val of_localized_string : zone:Zone.t -> string -> t\n\n (** [of_string_gen ~default_zone ~find_zone s] attempts to parse [s] as a [t], calling\n out to [default_zone] and [find_zone] as needed. *)\n val of_string_gen\n : default_zone:(unit -> Zone.t)\n -> find_zone:(string -> Zone.t)\n -> string\n -> t\n\n (** [to_string_iso8601_basic] return a string representation of the following form:\n %Y-%m-%dT%H:%M:%S.%s%Z\n e.g.\n [ to_string_iso8601_basic ~zone:Time.Zone.utc epoch = \"1970-01-01T00:00:00.000000Z\" ]\n *)\n val to_string_iso8601_basic : t -> zone:Zone.t -> string\n\n (** [occurrence side time ~ofday ~zone] returns a [Time.t] that is the occurrence of\n ofday (in the given [zone]) that is the latest occurrence (<=) [time] or the\n earliest occurrence (>=) [time], according to [side].\n\n NOTE: If the given time converted to wall clock time in the given zone is equal to\n ofday then the t returned will be equal to the t given.\n *)\n val occurrence\n : [ `First_after_or_at | `Last_before_or_at ]\n -> t\n -> ofday:Ofday.t\n -> zone:Zone.t\n -> t\nend\n\nmodule type S = sig\n include Basic\n include Shared with type t := t with module Span := Span with module Ofday := Ofday\nend\n\nmodule type Time = sig\n module type S = S\n\n module Make (Time : Time0_intf.S) : S with module Time := Time\nend\n","(* See Time_float.ml for the primary instantiation of this functor that is visible outside\n of Core_kernel as Time (see core_kernel.ml and std.ml). *)\nopen! Import\nopen Std_internal\nopen! Int.Replace_polymorphic_compare\ninclude Time_intf\nmodule Zone0 = Zone\n\nmodule Make (Time0 : Time0_intf.S) = struct\n module Time0 = Time0\n include Time0\n\n let epoch = of_span_since_epoch Span.zero\n let is_earlier t1 ~than:t2 = t1 <. t2\n let is_later t1 ~than:t2 = t1 >. t2\n\n module Zone : sig\n include Time_intf.Zone with module Time := Time0\n end = struct\n include Zone\n\n let of_span_in_seconds span_in_seconds =\n (* NB. no actual rounding or exns can occur here *)\n Time_in_seconds.Span.to_int63_seconds_round_down_exn span_in_seconds\n |> Time0.Span.of_int63_seconds\n ;;\n\n let of_time_in_seconds time_in_seconds =\n Time_in_seconds.to_span_since_epoch time_in_seconds\n (* NB. no actual rounding or exns can occur here *)\n |> Time_in_seconds.Span.to_int63_seconds_round_down_exn\n |> Time0.Span.of_int63_seconds\n |> Time0.of_span_since_epoch\n ;;\n\n let to_time_in_seconds_round_down_exn time =\n Time0.to_span_since_epoch time\n |> Time0.Span.to_int63_seconds_round_down_exn\n |> Time_in_seconds.Span.of_int63_seconds\n |> Time_in_seconds.of_span_since_epoch\n ;;\n\n let to_date_and_ofday_in_seconds_round_down_exn relative =\n Time0.Date_and_ofday.to_synthetic_span_since_epoch relative\n |> Time0.Span.to_int63_seconds_round_down_exn\n |> Time_in_seconds.Span.of_int63_seconds\n |> Time_in_seconds.Date_and_ofday.of_synthetic_span_since_epoch\n ;;\n\n let index t time = index t (to_time_in_seconds_round_down_exn time)\n\n let index_of_date_and_ofday t relative =\n index_of_date_and_ofday t (to_date_and_ofday_in_seconds_round_down_exn relative)\n ;;\n\n let index_offset_from_utc_exn t index =\n of_span_in_seconds (index_offset_from_utc_exn t index)\n ;;\n\n let index_prev_clock_shift_time_exn t index =\n of_time_in_seconds (index_prev_clock_shift_time_exn t index)\n ;;\n\n let index_next_clock_shift_time_exn t index =\n of_time_in_seconds (index_next_clock_shift_time_exn t index)\n ;;\n\n let index_prev_clock_shift_amount_exn t index =\n of_span_in_seconds (index_prev_clock_shift_amount_exn t index)\n ;;\n\n let index_next_clock_shift_amount_exn t index =\n of_span_in_seconds (index_next_clock_shift_amount_exn t index)\n ;;\n\n let abbreviation t time =\n (* no exn because [index] always returns a valid index *)\n index_abbreviation_exn t (index t time)\n ;;\n\n let index_prev_clock_shift t index =\n match index_has_prev_clock_shift t index with\n | false -> None\n | true ->\n Some\n ( index_prev_clock_shift_time_exn t index\n , index_prev_clock_shift_amount_exn t index )\n ;;\n\n let index_next_clock_shift t index = index_prev_clock_shift t (Index.next index)\n let prev_clock_shift t ~at_or_before:time = index_prev_clock_shift t (index t time)\n let next_clock_shift t ~strictly_after:time = index_next_clock_shift t (index t time)\n\n let date_and_ofday_of_absolute_time t time =\n let index = index t time in\n (* no exn because [index] always returns a valid index *)\n let offset_from_utc = index_offset_from_utc_exn t index in\n Time0.Date_and_ofday.of_absolute time ~offset_from_utc\n ;;\n\n let absolute_time_of_date_and_ofday t relative =\n let index = index_of_date_and_ofday t relative in\n (* no exn because [index_of_date_and_ofday] always returns a valid index *)\n let offset_from_utc = index_offset_from_utc_exn t index in\n Time0.Date_and_ofday.to_absolute relative ~offset_from_utc\n ;;\n end\n\n let abs_diff t1 t2 = Span.abs (diff t1 t2)\n\n let of_date_ofday ~zone date ofday =\n let relative = Date_and_ofday.of_date_ofday date ofday in\n Zone.absolute_time_of_date_and_ofday zone relative\n ;;\n\n let of_date_ofday_precise date ofday ~zone =\n (* We assume that there will be only one zone shift within a given local day. *)\n let start_of_day = of_date_ofday ~zone date Ofday.start_of_day in\n let proposed_time = add start_of_day (Ofday.to_span_since_start_of_day ofday) in\n match Zone.next_clock_shift zone ~strictly_after:start_of_day with\n | None -> `Once proposed_time\n | Some (shift_start, shift_amount) ->\n let shift_backwards = Span.(shift_amount < zero) in\n (* start and end of the \"problematic region\" *)\n let s, e =\n if shift_backwards\n then add shift_start shift_amount, shift_start\n else shift_start, add shift_start shift_amount\n in\n if proposed_time < s\n then `Once proposed_time\n else if s <= proposed_time && proposed_time < e\n then\n if shift_backwards\n then `Twice (proposed_time, sub proposed_time shift_amount)\n else `Never shift_start\n else `Once (sub proposed_time shift_amount)\n ;;\n\n module Date_cache = struct\n type t =\n { mutable zone : Zone.t\n ; mutable cache_start_incl : Time0.t\n ; mutable cache_until_excl : Time0.t\n ; mutable effective_day_start : Time0.t\n ; mutable date : Date0.t\n }\n end\n\n let date_cache : Date_cache.t =\n { zone = Zone.utc\n ; cache_start_incl = epoch\n ; cache_until_excl = epoch\n ; effective_day_start = epoch\n ; date = Date0.unix_epoch\n }\n ;;\n\n let reset_date_cache () =\n date_cache.zone <- Zone.utc;\n date_cache.cache_start_incl <- epoch;\n date_cache.cache_until_excl <- epoch;\n date_cache.effective_day_start <- epoch;\n date_cache.date <- Date0.unix_epoch\n ;;\n\n let is_in_cache time ~zone =\n phys_equal zone date_cache.zone\n && Time0.( >= ) time date_cache.cache_start_incl\n && Time0.( < ) time date_cache.cache_until_excl\n ;;\n\n let set_date_cache time ~zone =\n match is_in_cache time ~zone with\n | true -> ()\n | false ->\n let index = Zone.index zone time in\n (* no exn because [Zone.index] always returns a valid index *)\n let offset_from_utc = Zone.index_offset_from_utc_exn zone index in\n let rel = Date_and_ofday.of_absolute time ~offset_from_utc in\n let date = Date_and_ofday.to_date rel in\n let span = Date_and_ofday.to_ofday rel |> Ofday.to_span_since_start_of_day in\n let effective_day_start =\n Time0.sub (Date_and_ofday.to_absolute rel ~offset_from_utc) span\n in\n let effective_day_until = Time0.add effective_day_start Span.day in\n let cache_start_incl =\n match Zone.index_has_prev_clock_shift zone index with\n | false -> effective_day_start\n | true ->\n effective_day_start\n |> Time0.max (Zone.index_prev_clock_shift_time_exn zone index)\n in\n let cache_until_excl =\n match Zone.index_has_next_clock_shift zone index with\n | false -> effective_day_until\n | true ->\n effective_day_until\n |> Time0.min (Zone.index_next_clock_shift_time_exn zone index)\n in\n date_cache.zone <- zone;\n date_cache.cache_start_incl <- cache_start_incl;\n date_cache.cache_until_excl <- cache_until_excl;\n date_cache.effective_day_start <- effective_day_start;\n date_cache.date <- date\n ;;\n\n let to_date time ~zone =\n set_date_cache time ~zone;\n date_cache.date\n ;;\n\n let to_ofday time ~zone =\n set_date_cache time ~zone;\n Time0.diff time date_cache.effective_day_start\n |> Ofday.of_span_since_start_of_day_exn\n ;;\n\n let to_date_ofday time ~zone = to_date time ~zone, to_ofday time ~zone\n\n (* The correctness of this algorithm (interface, even) depends on the fact that\n timezone shifts aren't too close together (as in, it can't simultaneously be the\n case that a timezone shift of X hours occurred less than X hours ago, *and*\n a timezone shift of Y hours will occur in less than Y hours' time) *)\n let to_date_ofday_precise time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let clock_shift_after = Zone.next_clock_shift zone ~strictly_after:time in\n let clock_shift_before_or_at = Zone.prev_clock_shift zone ~at_or_before:time in\n let also_skipped_earlier amount =\n (* Using [date] and raising on [None] here is OK on the assumption that clock\n shifts can't cross date boundaries. This is true in all cases I've ever heard\n of (and [of_date_ofday_precise] would need revisiting if it turned out to be\n false) *)\n match Ofday.sub ofday amount with\n | Some ofday -> `Also_skipped (date, ofday)\n | None ->\n raise_s\n [%message\n \"Time.to_date_ofday_precise\"\n ~span_since_epoch:(to_span_since_epoch time : Span.t)\n (zone : Zone.t)]\n in\n let ambiguity =\n (* Edge cases: the instant of transition belongs to the new zone regime. So if the\n clock moved by an hour exactly one hour ago, there's no ambiguity, because the\n hour-ago time belongs to the same regime as you, and conversely, if the clock\n will move by an hour in an hours' time, there *is* ambiguity. Hence [>.] for\n the first case and [<=.] for the second. *)\n match clock_shift_before_or_at, clock_shift_after with\n | Some (start, amount), _ when add start (Span.abs amount) >. time ->\n (* clock shifted recently *)\n if Span.(amount > zero)\n then\n (* clock shifted forward recently: we skipped a time *)\n also_skipped_earlier amount\n else (\n (* clock shifted back recently: this date/ofday already happened *)\n assert (Span.(amount < zero));\n `Also_at (sub time (Span.abs amount)))\n | _, Some (start, amount) when sub start (Span.abs amount) <=. time ->\n (* clock is about to shift *)\n if Span.(amount > zero)\n then (* clock about to shift forward: no effect *)\n `Only\n else (\n (* clock about to shift back: this date/ofday will be repeated *)\n assert (Span.(amount < zero));\n `Also_at (add time (Span.abs amount)))\n | _ -> `Only\n in\n date, ofday, ambiguity\n ;;\n\n let convert ~from_tz ~to_tz date ofday =\n let start_time = of_date_ofday ~zone:from_tz date ofday in\n to_date_ofday ~zone:to_tz start_time\n ;;\n\n let utc_offset t ~zone =\n let utc_epoch = Zone.date_and_ofday_of_absolute_time zone t in\n Span.( - )\n (Date_and_ofday.to_synthetic_span_since_epoch utc_epoch)\n (to_span_since_epoch t)\n ;;\n\n let offset_string time ~zone =\n let utc_offset = utc_offset time ~zone in\n let is_utc = Span.( = ) utc_offset Span.zero in\n if is_utc\n then \"Z\"\n else\n String.concat\n [ (if Span.( < ) utc_offset Span.zero then \"-\" else \"+\")\n ; Ofday.to_string_trimmed\n (Ofday.of_span_since_start_of_day_exn (Span.abs utc_offset))\n ]\n ;;\n\n let to_string_abs_parts time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let offset_string = offset_string time ~zone in\n [ Date0.to_string date\n ; String.concat ~sep:\"\" [ Ofday.to_string ofday; offset_string ]\n ]\n ;;\n\n let to_string_abs_trimmed time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let offset_string = offset_string time ~zone in\n String.concat\n ~sep:\" \"\n [ Date0.to_string date; Ofday.to_string_trimmed ofday ^ offset_string ]\n ;;\n\n let to_string_abs time ~zone = String.concat ~sep:\" \" (to_string_abs_parts ~zone time)\n let to_string t = to_string_abs t ~zone:Zone.utc\n\n let to_string_iso8601_basic time ~zone =\n String.concat ~sep:\"T\" (to_string_abs_parts ~zone time)\n ;;\n\n let to_string_trimmed t ~zone =\n let date, sec = to_date_ofday ~zone t in\n Date0.to_string date ^ \" \" ^ Ofday.to_string_trimmed sec\n ;;\n\n let to_sec_string t ~zone =\n let date, sec = to_date_ofday ~zone t in\n Date0.to_string date ^ \" \" ^ Ofday.to_sec_string sec\n ;;\n\n let to_filename_string t ~zone =\n let date, ofday = to_date_ofday ~zone t in\n Date0.to_string date\n ^ \"_\"\n ^ String.tr ~target:':' ~replacement:'-' (Ofday.to_string ofday)\n ;;\n\n let of_filename_string s ~zone =\n try\n match String.lsplit2 s ~on:'_' with\n | None -> failwith \"no space in filename string\"\n | Some (date, ofday) ->\n let date = Date0.of_string date in\n let ofday = String.tr ~target:'-' ~replacement:':' ofday in\n let ofday = Ofday.of_string ofday in\n of_date_ofday date ofday ~zone\n with\n | exn -> invalid_argf \"Time.of_filename_string (%s): %s\" s (Exn.to_string exn) ()\n ;;\n\n let of_localized_string ~zone str =\n try\n match String.lsplit2 str ~on:' ' with\n | None -> invalid_arg (sprintf \"no space in date_ofday string: %s\" str)\n | Some (date, time) ->\n let date = Date0.of_string date in\n let ofday = Ofday.of_string time in\n of_date_ofday ~zone date ofday\n with\n | e -> Exn.reraise e \"Time.of_localized_string\"\n ;;\n\n let occurrence before_or_after t ~ofday ~zone =\n let first_guess_date = to_date t ~zone in\n let first_guess = of_date_ofday ~zone first_guess_date ofday in\n let cmp, increment =\n match before_or_after with\n | `Last_before_or_at -> ( <= ), -1\n | `First_after_or_at -> ( >= ), 1\n in\n if cmp first_guess t\n then first_guess\n else of_date_ofday ~zone (Date0.add_days first_guess_date increment) ofday\n ;;\n\n let ensure_colon_in_offset offset =\n let offset_length = String.length offset in\n if Int.( <= ) offset_length 2\n && Char.is_digit offset.[0]\n && Char.is_digit offset.[offset_length - 1]\n then offset ^ \":00\"\n else if Char.( = ) offset.[1] ':' || Char.( = ) offset.[2] ':'\n then offset\n else if Int.( < ) offset_length 3 || Int.( > ) offset_length 4\n then failwithf \"invalid offset %s\" offset ()\n else\n String.concat\n [ String.slice offset 0 (offset_length - 2)\n ; \":\"\n ; String.slice offset (offset_length - 2) offset_length\n ]\n ;;\n\n exception Time_of_string of string * Exn.t [@@deriving sexp]\n\n let of_string_gen ~default_zone ~find_zone s =\n try\n let date, ofday, tz =\n match String.split s ~on:' ' with\n | [ day; month; year; ofday ] ->\n String.concat [ day; \" \"; month; \" \"; year ], ofday, None\n | [ date; ofday; tz ] -> date, ofday, Some tz\n | [ date; ofday ] -> date, ofday, None\n | [ s ] ->\n (match String.rsplit2 ~on:'T' s with\n | Some (date, ofday) -> date, ofday, None\n | None -> failwith \"no spaces or T found\")\n | _ -> failwith \"too many spaces\"\n in\n let ofday_to_sec od = Span.to_sec (Ofday.to_span_since_start_of_day od) in\n let ofday, utc_offset =\n match tz with\n | Some _ -> ofday, None\n | None ->\n if Char.( = ) ofday.[String.length ofday - 1] 'Z'\n then String.sub ofday ~pos:0 ~len:(String.length ofday - 1), Some 0.\n else (\n match String.lsplit2 ~on:'+' ofday with\n | Some (l, r) ->\n l, Some (ofday_to_sec (Ofday.of_string (ensure_colon_in_offset r)))\n | None ->\n (match String.lsplit2 ~on:'-' ofday with\n | Some (l, r) ->\n l, Some (-1. *. ofday_to_sec (Ofday.of_string (ensure_colon_in_offset r)))\n | None -> ofday, None))\n in\n let date = Date0.of_string date in\n let ofday = Ofday.of_string ofday in\n match tz with\n | Some tz -> of_date_ofday ~zone:(find_zone tz) date ofday\n | None ->\n (match utc_offset with\n | None ->\n let zone = default_zone () in\n of_date_ofday ~zone date ofday\n | Some utc_offset ->\n let utc_t = of_date_ofday ~zone:Zone.utc date ofday in\n sub utc_t (Span.of_sec utc_offset))\n with\n | e -> raise (Time_of_string (s, e))\n ;;\n\n let of_string s =\n let default_zone () = raise_s [%message \"time has no time zone or UTC offset\" s] in\n let find_zone zone_name =\n failwithf \"unable to lookup Zone %s. Try using Core.Time.of_string\" zone_name ()\n in\n of_string_gen ~default_zone ~find_zone s\n ;;\n\n let quickcheck_shrinker =\n Quickcheck.Shrinker.map\n Span.quickcheck_shrinker\n ~f:of_span_since_epoch\n ~f_inverse:to_span_since_epoch\n ;;\n\n let quickcheck_observer =\n Quickcheck.Observer.unmap Span.quickcheck_observer ~f:to_span_since_epoch\n ;;\n\n let quickcheck_generator =\n Quickcheck.Generator.map Span.quickcheck_generator ~f:of_span_since_epoch\n ;;\n\n let gen_incl lo hi =\n Span.gen_incl (to_span_since_epoch lo) (to_span_since_epoch hi)\n |> Quickcheck.Generator.map ~f:of_span_since_epoch\n ;;\n\n let gen_uniform_incl lo hi =\n Span.gen_uniform_incl (to_span_since_epoch lo) (to_span_since_epoch hi)\n |> Quickcheck.Generator.map ~f:of_span_since_epoch\n ;;\nend\n","open! Import\nopen Std_internal\nopen! Int.Replace_polymorphic_compare\nmodule Span = Span_float\nmodule Ofday = Ofday_float\n\nmodule Absolute = struct\n type underlying = Float.t\n\n include (\n Float :\n sig\n type t = float [@@deriving bin_io, hash, typerep]\n\n include Comparable.S_common with type t := t\n\n include module type of struct\n include Float.O\n end\n end)\n\n (* due to precision limitations in float we can't expect better than microsecond\n precision *)\n include Float.Robust_compare.Make (struct\n let robust_comparison_tolerance = 1E-6\n end)\n\n let diff t1 t2 = Span.of_sec (t1 - t2)\n let add t span = t +. Span.to_sec span\n let sub t span = t -. Span.to_sec span\n let prev t = Float.one_ulp `Down t\n let next t = Float.one_ulp `Up t\n let to_span_since_epoch = Span.of_sec\n let of_span_since_epoch = Span.to_sec\nend\n\ninclude Absolute\n\nmodule Date_and_ofday = struct\n type t = float\n\n let of_synthetic_span_since_epoch span = Span.to_sec span\n let to_synthetic_span_since_epoch t = Span.of_sec t\n\n let of_date_ofday date ofday =\n let days =\n Float.of_int (Date0.Days.diff (Date0.Days.of_date date) Date0.Days.unix_epoch)\n in\n (days *. 86400.) +. Span.to_sec (Ofday.to_span_since_start_of_day ofday)\n ;;\n\n let to_absolute relative ~offset_from_utc = sub relative offset_from_utc\n let of_absolute absolute ~offset_from_utc = add absolute offset_from_utc\n\n (* Years out of range for [Date.create_exn]. *)\n let[@cold] assert_in_bounds ~sec_since_epoch =\n (* $ TZ=UTC date --date=@-62167219200\n Sat Jan 1 00:00:00 UTC 0000 *)\n let gmtime_lower_bound = -62_167_219_200. in\n (* $ TZ=UTC date --date=@253402300799\n Fri Dec 31 23:59:59 UTC 9999 *)\n let gmtime_upper_bound = 253_402_300_799. in\n if Float.( >= ) sec_since_epoch (gmtime_upper_bound +. 1.)\n || Float.( < ) sec_since_epoch gmtime_lower_bound\n then failwithf \"Time.gmtime: out of range (%f)\" sec_since_epoch ()\n ;;\n\n let sec_per_day = Int63.of_int 86_400\n\n let to_days_from_epoch t =\n assert_in_bounds ~sec_since_epoch:t;\n let open Int63.O in\n let days_from_epoch_approx = Int63.of_float t / sec_per_day in\n (* when [t] is negative the integer division that calculated days_from_epoch_approx\n will leave us one day short because it truncates (e.g. -100 / 86_400 = 0 and we\n want -1) -- adjust for that here. *)\n if Float.( < ) t (Int63.to_float (days_from_epoch_approx * sec_per_day))\n then Int63.pred days_from_epoch_approx\n else days_from_epoch_approx\n ;;\n\n let ofday_of_days_from_epoch t ~days_from_epoch =\n let open Int63.O in\n let days_from_epoch_in_sec = Int63.to_float (days_from_epoch * sec_per_day) in\n let remainder = t -. days_from_epoch_in_sec in\n Span.of_sec remainder |> Ofday.of_span_since_start_of_day_exn\n ;;\n\n let date_of_days_from_epoch ~days_from_epoch =\n Int63.to_int_exn days_from_epoch\n |> Date0.Days.add_days Date0.Days.unix_epoch\n |> Date0.Days.to_date\n ;;\n\n let to_date t =\n let days_from_epoch = to_days_from_epoch t in\n date_of_days_from_epoch ~days_from_epoch\n ;;\n\n let to_ofday t =\n let days_from_epoch = to_days_from_epoch t in\n ofday_of_days_from_epoch t ~days_from_epoch\n ;;\n\n let to_date_ofday t =\n let days_from_epoch = to_days_from_epoch t in\n let date = date_of_days_from_epoch ~days_from_epoch in\n let ofday = ofday_of_days_from_epoch t ~days_from_epoch in\n date, ofday\n ;;\nend\n\nlet next_multiple_internal ~can_equal_after ~base ~after ~interval =\n if Span.( <= ) interval Span.zero\n then\n failwiths\n ~here:[%here]\n \"Time.next_multiple got nonpositive interval\"\n interval\n [%sexp_of: Span.t];\n let base_to_after = diff after base in\n if Span.( < ) base_to_after Span.zero\n then base (* [after < base], choose [k = 0]. *)\n else (\n let next =\n add\n base\n (Span.scale\n interval\n (Float.round ~dir:`Down (Span.( // ) base_to_after interval)))\n in\n if next > after || (can_equal_after && next = after) then next else add next interval)\n;;\n\nlet next_multiple ?(can_equal_after = false) ~base ~after ~interval () =\n next_multiple_internal ~can_equal_after ~base ~after ~interval\n;;\n\nlet prev_multiple ?(can_equal_before = false) ~base ~before ~interval () =\n next_multiple_internal\n ~can_equal_after:(not can_equal_before)\n ~base\n ~after:(sub before interval)\n ~interval\n;;\n\nlet now () =\n let float_ns = Time_now.nanoseconds_since_unix_epoch () |> Int63.to_float in\n of_span_since_epoch (Span.of_sec (float_ns *. 1E-9))\n;;\n\nmodule Stable = struct\n module Span = Span.Stable\n module Ofday = Ofday.Stable\nend\n","open! Import\nopen! Std_internal\n\nmodule type S_kernel_without_zone = Time0_intf.S\nmodule type S_kernel = Time_intf.S\n\nmodule Zone_stable = Zone.Stable\ninclude Time.Make (Time_float0)\ninclude Time_float0\n\nmodule Stable = struct\n include Time_float0.Stable\n\n module With_utc_sexp = struct\n (* V2 is actually the first version of this in Core_kernel, but a V1 stable module\n with generous parsing, unix-dependent [t_of_sexp] already existed in Core *)\n module V2 = struct\n type nonrec t = t [@@deriving bin_io, compare, hash]\n\n let sexp_of_t t = [%sexp (to_string_abs_parts t ~zone:Zone.utc : string list)]\n\n let t_of_sexp sexp =\n try\n match sexp with\n | Sexp.List [ Sexp.Atom date; Sexp.Atom ofday_and_possibly_zone ] ->\n of_string_gen\n ~default_zone:(fun () -> Zone.utc)\n ~find_zone:(fun _ ->\n of_sexp_error \"Time.Stable.With_utc.V2.t_of_sexp: unknown time zone\" sexp)\n (date ^ \" \" ^ ofday_and_possibly_zone)\n | _ -> of_sexp_error \"Time.Stable.With_utc.V2.t_of_sexp\" sexp\n with\n | Of_sexp_error _ as e -> raise e\n | e ->\n of_sexp_error\n (sprintf \"Time.Stable.With_utc.V2.t_of_sexp: %s\" (Exn.to_string e))\n sexp\n ;;\n end\n end\n\n module Zone = Zone_stable\nend\n","open! Import\nopen Std_internal\n\nlet arch_sixtyfour = Sys.word_size = 64\n\nmodule Span = Span_ns\nmodule Ofday = Ofday_ns\n\ntype t = Span.t (* since the Unix epoch (1970-01-01 00:00:00 UTC) *)\n[@@deriving bin_io, compare, hash, typerep]\n\ninclude (Span : Comparable.Infix with type t := t)\ninclude (Span : Quickcheck.S_range with type t := t)\n\nlet now = Span.since_unix_epoch\nlet equal = Span.equal\nlet min_value_for_1us_rounding = Span.min_value_for_1us_rounding\nlet max_value_for_1us_rounding = Span.max_value_for_1us_rounding\nlet epoch = Span.zero\nlet add = Span.( + )\nlet sub = Span.( - )\nlet diff = Span.( - )\nlet abs_diff t u = Span.abs (diff t u)\nlet max = Span.max\nlet min = Span.min\nlet next = Span.next\nlet prev = Span.prev\nlet to_span_since_epoch t = t\nlet of_span_since_epoch s = s\nlet to_int63_ns_since_epoch t : Int63.t = Span.to_int63_ns (to_span_since_epoch t)\nlet of_int63_ns_since_epoch i = of_span_since_epoch (Span.of_int63_ns i)\nlet[@cold] overflow () = raise_s [%message \"Time_ns: overflow\"]\nlet is_earlier t1 ~than:t2 = t1 < t2\nlet is_later t1 ~than:t2 = t1 > t2\n\nlet add_overflowed x y ~sum =\n if Span.( > ) y Span.zero then Span.( < ) sum x else Span.( > ) sum x\n;;\n\nlet sub_overflowed x y ~diff =\n if Span.( > ) y Span.zero then Span.( > ) diff x else Span.( < ) diff x\n;;\n\nlet add_exn x y =\n let sum = add x y in\n if add_overflowed x y ~sum then overflow () else sum\n;;\n\nlet sub_exn x y =\n let diff = sub x y in\n if sub_overflowed x y ~diff then overflow () else diff\n;;\n\nlet add_saturating x y =\n let sum = add x y in\n if add_overflowed x y ~sum\n then\n if Span.(y > zero)\n then Span.max_value_representable\n else Span.min_value_representable\n else sum\n;;\n\nlet sub_saturating x y =\n let diff = sub x y in\n if sub_overflowed x y ~diff\n then\n if Span.(y > zero)\n then Span.min_value_representable\n else Span.max_value_representable\n else diff\n;;\n\nlet to_int_ns_since_epoch =\n if arch_sixtyfour\n then fun t -> Int63.to_int_exn (to_int63_ns_since_epoch t)\n else fun _ -> failwith \"Time_ns.to_int_ns_since_epoch: unsupported on 32bit machines\"\n;;\n\nlet of_int_ns_since_epoch i = of_int63_ns_since_epoch (Int63.of_int i)\n\nlet to_time_float_round_nearest t =\n Time_float.of_span_since_epoch\n (Span.to_span_float_round_nearest (to_span_since_epoch t))\n;;\n\nlet to_time_float_round_nearest_microsecond t =\n Time_float.of_span_since_epoch\n (Span.to_span_float_round_nearest_microsecond (to_span_since_epoch t))\n;;\n\nlet min_time_value_for_1us_rounding =\n to_time_float_round_nearest min_value_for_1us_rounding\n;;\n\nlet max_time_value_for_1us_rounding =\n to_time_float_round_nearest max_value_for_1us_rounding\n;;\n\nlet check_before_conversion_for_1us_rounding time =\n if Time_float.( < ) time min_time_value_for_1us_rounding\n || Time_float.( > ) time max_time_value_for_1us_rounding\n then\n failwiths\n ~here:[%here]\n \"Time_ns does not support this time\"\n time\n [%sexp_of: Time_float.Stable.With_utc_sexp.V2.t]\n;;\n\nlet of_time_float_round_nearest time =\n of_span_since_epoch\n (Span.of_span_float_round_nearest (Time_float.to_span_since_epoch time))\n;;\n\nlet of_time_float_round_nearest_microsecond time =\n check_before_conversion_for_1us_rounding time;\n of_span_since_epoch\n (Span.of_span_float_round_nearest_microsecond (Time_float.to_span_since_epoch time))\n;;\n\nlet[@cold] raise_next_multiple_got_nonpositive_interval interval =\n failwiths\n ~here:[%here]\n \"Time_ns.next_multiple got nonpositive interval\"\n interval\n [%sexp_of: Span.t]\n;;\n\nlet next_multiple_internal ~can_equal_after ~base ~after ~interval =\n if Span.( <= ) interval Span.zero\n then raise_next_multiple_got_nonpositive_interval interval;\n let base_to_after = diff after base in\n if Span.( < ) base_to_after Span.zero\n then base (* [after < base], choose [k = 0]. *)\n else (\n let next = add base (Span.scale_int63 interval (Span.div base_to_after interval)) in\n if next > after || (can_equal_after && next = after) then next else add next interval)\n;;\n\nlet next_multiple ?(can_equal_after = false) ~base ~after ~interval () =\n next_multiple_internal ~can_equal_after ~base ~after ~interval\n;;\n\nlet prev_multiple ?(can_equal_before = false) ~base ~before ~interval () =\n next_multiple_internal\n ~can_equal_after:(not can_equal_before)\n ~base\n ~after:(sub before interval)\n ~interval\n;;\n\nlet random ?state () = Span.random ?state ()\n\nmodule Utc : sig\n val to_date_and_span_since_start_of_day : t -> Date0.t * Span.t\n val of_date_and_span_since_start_of_day : Date0.t -> Span.t -> t\nend = struct\n (* a recreation of the system call gmtime specialized to the fields we need that also\n doesn't rely on Unix. *)\n let to_date_and_span_since_start_of_day t =\n let open Int63.O in\n let ( !< ) i = Int63.of_int_exn i in\n let ( !> ) t = Int63.to_int_exn t in\n let ns_since_epoch = to_int63_ns_since_epoch t in\n let ns_per_day = !<86_400 * !<1_000_000_000 in\n let approx_days_from_epoch = ns_since_epoch / ns_per_day in\n let days_from_epoch =\n if ns_since_epoch < !<0 && approx_days_from_epoch * ns_per_day <> ns_since_epoch\n then approx_days_from_epoch - !<1\n else approx_days_from_epoch\n in\n let ns_since_start_of_day = ns_since_epoch - (ns_per_day * days_from_epoch) in\n let date =\n Date0.Days.add_days Date0.Days.unix_epoch !>days_from_epoch |> Date0.Days.to_date\n in\n let span_since_start_of_day = Span.of_int63_ns ns_since_start_of_day in\n date, span_since_start_of_day\n ;;\n\n let of_date_and_span_since_start_of_day date span_since_start_of_day =\n assert (\n Span.( >= ) span_since_start_of_day Span.zero\n && Span.( < ) span_since_start_of_day Span.day);\n let days_from_epoch =\n Date0.Days.diff (Date0.Days.of_date date) Date0.Days.unix_epoch\n in\n let span_in_days_since_epoch = Span.scale_int Span.day days_from_epoch in\n let span_since_epoch = Span.( + ) span_in_days_since_epoch span_since_start_of_day in\n of_span_since_epoch span_since_epoch\n ;;\nend\n\nmodule Alternate_sexp = struct\n type nonrec t = t\n\n module Ofday_as_span = struct\n open Int.O\n\n let seconds_to_string seconds_span =\n let seconds = Span.to_int_sec seconds_span in\n let h = seconds / 3600 in\n let m = seconds / 60 % 60 in\n let s = seconds % 60 in\n sprintf \"%02d:%02d:%02d\" h m s\n ;;\n\n let two_digit_of_string string =\n assert (String.length string = 2 && String.for_all string ~f:Char.is_digit);\n Int.of_string string\n ;;\n\n let seconds_of_string seconds_string =\n match String.split seconds_string ~on:':' with\n | [ h_string; m_string; s_string ] ->\n let h = two_digit_of_string h_string in\n let m = two_digit_of_string m_string in\n let s = two_digit_of_string s_string in\n Span.of_int_sec ((((h * 60) + m) * 60) + s)\n | _ -> assert false\n ;;\n\n let ns_of_100_ms = 100_000_000\n let ns_of_10_ms = 10_000_000\n let ns_of_1_ms = 1_000_000\n let ns_of_100_us = 100_000\n let ns_of_10_us = 10_000\n let ns_of_1_us = 1_000\n let ns_of_100_ns = 100\n let ns_of_10_ns = 10\n let ns_of_1_ns = 1\n\n let sub_second_to_string sub_second_span =\n let open Int.O in\n let ns = Span.to_int63_ns sub_second_span |> Int63.to_int_exn in\n if ns = 0\n then \"\"\n else if ns % ns_of_100_ms = 0\n then sprintf \".%01d\" (ns / ns_of_100_ms)\n else if ns % ns_of_10_ms = 0\n then sprintf \".%02d\" (ns / ns_of_10_ms)\n else if ns % ns_of_1_ms = 0\n then sprintf \".%03d\" (ns / ns_of_1_ms)\n else if ns % ns_of_100_us = 0\n then sprintf \".%04d\" (ns / ns_of_100_us)\n else if ns % ns_of_10_us = 0\n then sprintf \".%05d\" (ns / ns_of_10_us)\n else if ns % ns_of_1_us = 0\n then sprintf \".%06d\" (ns / ns_of_1_us)\n else if ns % ns_of_100_ns = 0\n then sprintf \".%07d\" (ns / ns_of_100_ns)\n else if ns % ns_of_10_ns = 0\n then sprintf \".%08d\" (ns / ns_of_10_ns)\n else sprintf \".%09d\" ns\n ;;\n\n let sub_second_of_string string =\n if String.is_empty string\n then Span.zero\n else (\n let digits = String.chop_prefix_exn string ~prefix:\".\" in\n assert (String.for_all digits ~f:Char.is_digit);\n let multiplier =\n match String.length digits with\n | 1 -> ns_of_100_ms\n | 2 -> ns_of_10_ms\n | 3 -> ns_of_1_ms\n | 4 -> ns_of_100_us\n | 5 -> ns_of_10_us\n | 6 -> ns_of_1_us\n | 7 -> ns_of_100_ns\n | 8 -> ns_of_10_ns\n | 9 -> ns_of_1_ns\n | _ -> assert false\n in\n Span.of_int63_ns (Int63.of_int (Int.of_string digits * multiplier)))\n ;;\n\n let to_string span =\n assert (Span.( >= ) span Span.zero && Span.( < ) span Span.day);\n let seconds_span = span |> Span.to_int_sec |> Span.of_int_sec in\n let sub_second_span = Span.( - ) span seconds_span in\n seconds_to_string seconds_span ^ sub_second_to_string sub_second_span\n ;;\n\n let of_string string =\n let len = String.length string in\n let prefix_len = 8 in\n (* \"HH:MM:DD\" *)\n let suffix_len = len - prefix_len in\n let seconds_string = String.sub string ~pos:0 ~len:prefix_len in\n let sub_second_string = String.sub string ~pos:prefix_len ~len:suffix_len in\n let seconds_span = seconds_of_string seconds_string in\n let sub_second_span = sub_second_of_string sub_second_string in\n Span.( + ) seconds_span sub_second_span\n ;;\n end\n\n let to_string t =\n let date, span_since_start_of_day = Utc.to_date_and_span_since_start_of_day t in\n Date0.to_string date ^ \" \" ^ Ofday_as_span.to_string span_since_start_of_day ^ \"Z\"\n ;;\n\n let of_string string =\n let date_string, ofday_string_with_zone = String.lsplit2_exn string ~on:' ' in\n let ofday_string = String.chop_suffix_exn ofday_string_with_zone ~suffix:\"Z\" in\n let date = Date0.of_string date_string in\n let ofday = Ofday_as_span.of_string ofday_string in\n Utc.of_date_and_span_since_start_of_day date ofday\n ;;\n\n include Sexpable.Of_stringable (struct\n type nonrec t = t\n\n let to_string = to_string\n let of_string = of_string\n end)\n\n module Stable = struct\n module V1 = struct\n (* see tests in lib/core_kernel/test/test_time_ns that ensure stability of this\n representation *)\n type nonrec t = t [@@deriving bin_io, compare, sexp]\n end\n end\nend\n\nmodule Stable = struct\n module Alternate_sexp = Alternate_sexp.Stable\n module Span = Span.Stable\n module Ofday = Ofday.Stable\nend\n\n(* this code is directly duplicated from Time.ml functor, converted enough to get Time_ns\n to/of_string working *)\nmodule To_and_of_string : sig\n val of_date_ofday : zone:Zone.t -> Date.t -> Ofday.t -> t\n\n val of_date_ofday_precise\n : Date.t\n -> Ofday.t\n -> zone:Zone.t\n -> [ `Once of t | `Twice of t * t | `Never of t ]\n\n val to_date_ofday : t -> zone:Zone.t -> Date.t * Ofday.t\n\n val to_date_ofday_precise\n : t\n -> zone:Zone.t\n -> Date.t * Ofday.t * [ `Only | `Also_at of t | `Also_skipped of Date.t * Ofday.t ]\n\n val to_date : t -> zone:Zone.t -> Date.t\n val to_ofday : t -> zone:Zone.t -> Ofday.t\n val convert : from_tz:Zone.t -> to_tz:Zone.t -> Date.t -> Ofday.t -> Date.t * Ofday.t\n val reset_date_cache : unit -> unit\n val utc_offset : t -> zone:Zone.t -> Span.t\n\n include Stringable with type t := t\n\n val to_filename_string : t -> zone:Zone.t -> string\n val of_filename_string : string -> zone:Zone.t -> t\n val to_string_trimmed : t -> zone:Zone.t -> string\n val to_sec_string : t -> zone:Zone.t -> string\n val of_localized_string : zone:Zone.t -> string -> t\n\n val of_string_gen\n : default_zone:(unit -> Zone.t)\n -> find_zone:(string -> Zone.t)\n -> string\n -> t\n\n val to_string_abs : t -> zone:Zone.t -> string\n val to_string_abs_trimmed : t -> zone:Zone.t -> string\n val to_string_abs_parts : t -> zone:Zone.t -> string list\n val to_string_iso8601_basic : t -> zone:Zone.t -> string\n\n val occurrence\n : [ `First_after_or_at | `Last_before_or_at ]\n -> t\n -> ofday:Ofday.t\n -> zone:Zone.t\n -> t\nend = struct\n (* this code is directly duplicated from Time_float0.ml, converted enough to get\n Time_ns to/of_string working *)\n module Date_and_ofday = struct\n type t = Int63.t\n\n let to_synthetic_span_since_epoch t = Span.of_int63_ns t\n\n let of_date_ofday date ofday =\n let days =\n Date0.Days.diff (Date0.Days.of_date date) Date0.Days.unix_epoch |> Int63.of_int\n in\n let open Int63.O in\n (days * Span.to_int63_ns Span.day)\n + Span.to_int63_ns (Ofday.to_span_since_start_of_day ofday)\n ;;\n\n let to_absolute relative ~offset_from_utc =\n sub_exn (Span.of_int63_ns relative) offset_from_utc\n ;;\n\n let of_absolute absolute ~offset_from_utc =\n Span.to_int63_ns (add_exn absolute offset_from_utc)\n ;;\n\n let ns_per_day = Span.to_int63_ns Span.day\n\n let to_days_from_epoch t =\n (* note Time_ns represents about 146 years, not enough for [Date.create_exn] to ever\n raise *)\n let open Int63.O in\n let days_from_epoch_approx = t / ns_per_day in\n (* when [t] is negative the integer division that calculated days_from_epoch_approx\n will leave us one day short because it truncates (e.g. -100 / 86_400 = 0 and we\n want -1) -- adjust for that here. *)\n if t < days_from_epoch_approx * ns_per_day\n then Int63.pred days_from_epoch_approx\n else days_from_epoch_approx\n ;;\n\n let ofday_of_days_from_epoch t ~days_from_epoch =\n let open Int63.O in\n let days_from_epoch_in_ns = days_from_epoch * ns_per_day in\n let remainder = t - days_from_epoch_in_ns in\n Span.of_int63_ns remainder |> Ofday.of_span_since_start_of_day_exn\n ;;\n\n let date_of_days_from_epoch ~days_from_epoch =\n Int63.to_int_exn days_from_epoch\n |> Date0.Days.add_days Date0.Days.unix_epoch\n |> Date0.Days.to_date\n ;;\n\n let to_date t =\n let days_from_epoch = to_days_from_epoch t in\n date_of_days_from_epoch ~days_from_epoch\n ;;\n\n let to_ofday t =\n let days_from_epoch = to_days_from_epoch t in\n ofday_of_days_from_epoch t ~days_from_epoch\n ;;\n end\n\n module Zone0 = Zone\n\n module Zone : sig\n (* This interface is directly duplicated from Time_intf.Zone, converted enough to get\n this to work.\n\n The problem is has references to Time0_intf.S, which is the functor input interface\n that Time_ns currently does not satisfy. *)\n\n type time = t\n type t = Zone.t [@@deriving sexp_of]\n\n module Index = Zone.Index\n\n (* copied functions reexported from Zone *)\n\n val utc : t\n val index_has_prev_clock_shift : t -> Index.t -> bool\n val index_has_next_clock_shift : t -> Index.t -> bool\n\n (* new functions defined below *)\n\n val index : t -> time -> Index.t\n val index_offset_from_utc_exn : t -> Index.t -> time\n val index_prev_clock_shift_time_exn : t -> Index.t -> time\n val index_next_clock_shift_time_exn : t -> Index.t -> time\n val absolute_time_of_date_and_ofday : t -> Date_and_ofday.t -> time\n val date_and_ofday_of_absolute_time : t -> time -> Date_and_ofday.t\n val next_clock_shift : t -> strictly_after:time -> (time * Span.t) option\n val prev_clock_shift : t -> at_or_before:time -> (time * Span.t) option\n end = struct\n type time = t\n\n include Zone\n\n let of_span_in_seconds span_in_seconds =\n (* NB. no actual rounding or exns can occur here *)\n Time_in_seconds.Span.to_int63_seconds_round_down_exn span_in_seconds\n |> Span.of_int63_seconds\n ;;\n\n let of_time_in_seconds time_in_seconds =\n Time_in_seconds.to_span_since_epoch time_in_seconds\n (* NB. no actual rounding or exns can occur here *)\n |> Time_in_seconds.Span.to_int63_seconds_round_down_exn\n |> Span.of_int63_seconds\n |> of_span_since_epoch\n ;;\n\n let to_time_in_seconds_round_down_exn time =\n to_span_since_epoch time\n |> Span.to_int63_seconds_round_down_exn\n |> Time_in_seconds.Span.of_int63_seconds\n |> Time_in_seconds.of_span_since_epoch\n ;;\n\n let to_date_and_ofday_in_seconds_round_down_exn relative =\n Date_and_ofday.to_synthetic_span_since_epoch relative\n |> Span.to_int63_seconds_round_down_exn\n |> Time_in_seconds.Span.of_int63_seconds\n |> Time_in_seconds.Date_and_ofday.of_synthetic_span_since_epoch\n ;;\n\n let index t time = index t (to_time_in_seconds_round_down_exn time)\n\n let index_of_date_and_ofday t relative =\n index_of_date_and_ofday t (to_date_and_ofday_in_seconds_round_down_exn relative)\n ;;\n\n let index_offset_from_utc_exn t index =\n of_span_in_seconds (index_offset_from_utc_exn t index)\n ;;\n\n let index_prev_clock_shift_time_exn t index =\n of_time_in_seconds (index_prev_clock_shift_time_exn t index)\n ;;\n\n let index_next_clock_shift_time_exn t index =\n of_time_in_seconds (index_next_clock_shift_time_exn t index)\n ;;\n\n let index_prev_clock_shift_amount_exn t index =\n of_span_in_seconds (index_prev_clock_shift_amount_exn t index)\n ;;\n\n let index_prev_clock_shift t index =\n match index_has_prev_clock_shift t index with\n | false -> None\n | true ->\n Some\n ( index_prev_clock_shift_time_exn t index\n , index_prev_clock_shift_amount_exn t index )\n ;;\n\n let index_next_clock_shift t index = index_prev_clock_shift t (Index.next index)\n let prev_clock_shift t ~at_or_before:time = index_prev_clock_shift t (index t time)\n let next_clock_shift t ~strictly_after:time = index_next_clock_shift t (index t time)\n\n let date_and_ofday_of_absolute_time t time =\n let index = index t time in\n (* no exn because [index] always returns a valid index *)\n let offset_from_utc = index_offset_from_utc_exn t index in\n Date_and_ofday.of_absolute time ~offset_from_utc\n ;;\n\n let absolute_time_of_date_and_ofday t relative =\n let index = index_of_date_and_ofday t relative in\n (* no exn because [index_of_date_and_ofday] always returns a valid index *)\n let offset_from_utc = index_offset_from_utc_exn t index in\n Date_and_ofday.to_absolute relative ~offset_from_utc\n ;;\n end\n\n let of_date_ofday ~zone date ofday =\n let relative = Date_and_ofday.of_date_ofday date ofday in\n Zone.absolute_time_of_date_and_ofday zone relative\n ;;\n\n let of_date_ofday_precise date ofday ~zone =\n (* We assume that there will be only one zone shift within a given local day. *)\n let start_of_day = of_date_ofday ~zone date Ofday.start_of_day in\n let proposed_time = add start_of_day (Ofday.to_span_since_start_of_day ofday) in\n match Zone.next_clock_shift zone ~strictly_after:start_of_day with\n | None -> `Once proposed_time\n | Some (shift_start, shift_amount) ->\n let shift_backwards = Span.(shift_amount < zero) in\n (* start and end of the \"problematic region\" *)\n let s, e =\n if shift_backwards\n then add shift_start shift_amount, shift_start\n else shift_start, add shift_start shift_amount\n in\n if proposed_time < s\n then `Once proposed_time\n else if s <= proposed_time && proposed_time < e\n then\n if shift_backwards\n then `Twice (proposed_time, sub proposed_time shift_amount)\n else `Never shift_start\n else `Once (sub proposed_time shift_amount)\n ;;\n\n module Date_cache = struct\n type nonrec t =\n { mutable zone : Zone.t\n ; mutable cache_start_incl : t\n ; mutable cache_until_excl : t\n ; mutable effective_day_start : t\n ; mutable date : Date0.t\n }\n end\n\n let date_cache : Date_cache.t =\n { zone = Zone.utc\n ; cache_start_incl = epoch\n ; cache_until_excl = epoch\n ; effective_day_start = epoch\n ; date = Date0.unix_epoch\n }\n ;;\n\n let reset_date_cache () =\n date_cache.zone <- Zone.utc;\n date_cache.cache_start_incl <- epoch;\n date_cache.cache_until_excl <- epoch;\n date_cache.effective_day_start <- epoch;\n date_cache.date <- Date0.unix_epoch\n ;;\n\n let is_in_cache time ~zone =\n phys_equal zone date_cache.zone\n && time >= date_cache.cache_start_incl\n && time < date_cache.cache_until_excl\n ;;\n\n let set_date_cache time ~zone =\n match is_in_cache time ~zone with\n | true -> ()\n | false ->\n let index = Zone.index zone time in\n (* no exn because [Zone.index] always returns a valid index *)\n let offset_from_utc = Zone.index_offset_from_utc_exn zone index in\n let rel = Date_and_ofday.of_absolute time ~offset_from_utc in\n let date = Date_and_ofday.to_date rel in\n let span = Date_and_ofday.to_ofday rel |> Ofday.to_span_since_start_of_day in\n let effective_day_start =\n sub (Date_and_ofday.to_absolute rel ~offset_from_utc) span\n in\n let effective_day_until = add effective_day_start Span.day in\n let cache_start_incl =\n match Zone.index_has_prev_clock_shift zone index with\n | false -> effective_day_start\n | true ->\n effective_day_start |> max (Zone.index_prev_clock_shift_time_exn zone index)\n in\n let cache_until_excl =\n match Zone.index_has_next_clock_shift zone index with\n | false -> effective_day_until\n | true ->\n effective_day_until |> min (Zone.index_next_clock_shift_time_exn zone index)\n in\n date_cache.zone <- zone;\n date_cache.cache_start_incl <- cache_start_incl;\n date_cache.cache_until_excl <- cache_until_excl;\n date_cache.effective_day_start <- effective_day_start;\n date_cache.date <- date\n ;;\n\n let to_date time ~zone =\n set_date_cache time ~zone;\n date_cache.date\n ;;\n\n let to_ofday time ~zone =\n set_date_cache time ~zone;\n diff time date_cache.effective_day_start |> Ofday.of_span_since_start_of_day_exn\n ;;\n\n let to_date_ofday time ~zone = to_date time ~zone, to_ofday time ~zone\n\n (* The correctness of this algorithm (interface, even) depends on the fact that\n timezone shifts aren't too close together (as in, it can't simultaneously be the\n case that a timezone shift of X hours occurred less than X hours ago, *and*\n a timezone shift of Y hours will occur in less than Y hours' time) *)\n let to_date_ofday_precise time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let clock_shift_after = Zone.next_clock_shift zone ~strictly_after:time in\n let clock_shift_before_or_at = Zone.prev_clock_shift zone ~at_or_before:time in\n let also_skipped_earlier amount =\n (* Using [date] and raising on [None] here is OK on the assumption that clock\n shifts can't cross date boundaries. This is true in all cases I've ever heard\n of (and [of_date_ofday_precise] would need revisiting if it turned out to be\n false) *)\n match Ofday.sub ofday amount with\n | Some ofday -> `Also_skipped (date, ofday)\n | None ->\n raise_s\n [%message\n \"Time.to_date_ofday_precise\"\n ~span_since_epoch:(to_span_since_epoch time : Span.t)\n (zone : Zone.t)]\n in\n let ambiguity =\n (* Edge cases: the instant of transition belongs to the new zone regime. So if the\n clock moved by an hour exactly one hour ago, there's no ambiguity, because the\n hour-ago time belongs to the same regime as you, and conversely, if the clock\n will move by an hour in an hours' time, there *is* ambiguity. Hence [>.] for\n the first case and [<=.] for the second. *)\n match clock_shift_before_or_at, clock_shift_after with\n | Some (start, amount), _ when add start (Span.abs amount) > time ->\n (* clock shifted recently *)\n if Span.(amount > zero)\n then\n (* clock shifted forward recently: we skipped a time *)\n also_skipped_earlier amount\n else (\n (* clock shifted back recently: this date/ofday already happened *)\n assert (Span.(amount < zero));\n `Also_at (sub time (Span.abs amount)))\n | _, Some (start, amount) when sub start (Span.abs amount) <= time ->\n (* clock is about to shift *)\n if Span.(amount > zero)\n then (* clock about to shift forward: no effect *)\n `Only\n else (\n (* clock about to shift back: this date/ofday will be repeated *)\n assert (Span.(amount < zero));\n `Also_at (add time (Span.abs amount)))\n | _ -> `Only\n in\n date, ofday, ambiguity\n ;;\n\n let convert ~from_tz ~to_tz date ofday =\n let start_time = of_date_ofday ~zone:from_tz date ofday in\n to_date_ofday ~zone:to_tz start_time\n ;;\n\n let utc_offset t ~zone =\n let utc_epoch = Zone.date_and_ofday_of_absolute_time zone t in\n Span.( - )\n (Date_and_ofday.to_synthetic_span_since_epoch utc_epoch)\n (to_span_since_epoch t)\n ;;\n\n let offset_string time ~zone =\n let utc_offset = utc_offset time ~zone in\n let is_utc = Span.( = ) utc_offset Span.zero in\n if is_utc\n then \"Z\"\n else\n String.concat\n [ (if Span.( < ) utc_offset Span.zero then \"-\" else \"+\")\n ; Ofday.to_string_trimmed\n (Ofday.of_span_since_start_of_day_exn (Span.abs utc_offset))\n ]\n ;;\n\n let to_string_abs_parts =\n let attempt time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let offset_string = offset_string time ~zone in\n [ Date0.to_string date\n ; String.concat ~sep:\"\" [ Ofday.to_string ofday; offset_string ]\n ]\n in\n fun time ~zone ->\n try attempt time ~zone with\n | (_ : exn) ->\n (* If we overflow applying the UTC offset, try again with UTC time. *)\n attempt time ~zone:Zone.utc\n ;;\n\n let to_string_abs_trimmed time ~zone =\n let date, ofday = to_date_ofday time ~zone in\n let offset_string = offset_string time ~zone in\n String.concat\n ~sep:\" \"\n [ Date0.to_string date; Ofday.to_string_trimmed ofday ^ offset_string ]\n ;;\n\n let to_string_abs time ~zone = String.concat ~sep:\" \" (to_string_abs_parts ~zone time)\n let to_string t = to_string_abs t ~zone:Zone.utc\n\n let to_string_iso8601_basic time ~zone =\n String.concat ~sep:\"T\" (to_string_abs_parts ~zone time)\n ;;\n\n let to_string_trimmed t ~zone =\n let date, sec = to_date_ofday ~zone t in\n Date0.to_string date ^ \" \" ^ Ofday.to_string_trimmed sec\n ;;\n\n let to_sec_string t ~zone =\n let date, sec = to_date_ofday ~zone t in\n Date0.to_string date ^ \" \" ^ Ofday.to_sec_string sec\n ;;\n\n let to_filename_string t ~zone =\n let date, ofday = to_date_ofday ~zone t in\n Date0.to_string date\n ^ \"_\"\n ^ String.tr\n ~target:':'\n ~replacement:'-'\n (String.drop_suffix (Ofday.to_string ofday) 3)\n ;;\n\n let of_filename_string s ~zone =\n try\n match String.lsplit2 s ~on:'_' with\n | None -> failwith \"no space in filename string\"\n | Some (date, ofday) ->\n let date = Date0.of_string date in\n let ofday = String.tr ~target:'-' ~replacement:':' ofday in\n let ofday = Ofday.of_string ofday in\n of_date_ofday date ofday ~zone\n with\n | exn -> invalid_argf \"Time.of_filename_string (%s): %s\" s (Exn.to_string exn) ()\n ;;\n\n let of_localized_string ~zone str =\n try\n match String.lsplit2 str ~on:' ' with\n | None -> invalid_arg (sprintf \"no space in date_ofday string: %s\" str)\n | Some (date, time) ->\n let date = Date0.of_string date in\n let ofday = Ofday.of_string time in\n of_date_ofday ~zone date ofday\n with\n | e -> Exn.reraise e \"Time.of_localized_string\"\n ;;\n\n let occurrence before_or_after t ~ofday ~zone =\n let first_guess_date = to_date t ~zone in\n let first_guess = of_date_ofday ~zone first_guess_date ofday in\n let cmp, increment =\n match before_or_after with\n | `Last_before_or_at -> ( <= ), -1\n | `First_after_or_at -> ( >= ), 1\n in\n if cmp first_guess t\n then first_guess\n else of_date_ofday ~zone (Date0.add_days first_guess_date increment) ofday\n ;;\n\n let ensure_colon_in_offset offset =\n let offset_length = String.length offset in\n if Int.( <= ) offset_length 2\n && Char.is_digit offset.[0]\n && Char.is_digit offset.[offset_length - 1]\n then offset ^ \":00\"\n else if Char.( = ) offset.[1] ':' || Char.( = ) offset.[2] ':'\n then offset\n else if Int.( < ) offset_length 3 || Int.( > ) offset_length 4\n then failwithf \"invalid offset %s\" offset ()\n else\n String.concat\n [ String.slice offset 0 (offset_length - 2)\n ; \":\"\n ; String.slice offset (offset_length - 2) offset_length\n ]\n ;;\n\n exception Time_ns_of_string of string * Exn.t [@@deriving sexp]\n\n let of_string_gen ~default_zone ~find_zone s =\n try\n let date, ofday, tz =\n match String.split s ~on:' ' with\n | [ day; month; year; ofday ] ->\n String.concat [ day; \" \"; month; \" \"; year ], ofday, None\n | [ date; ofday; tz ] -> date, ofday, Some tz\n | [ date; ofday ] -> date, ofday, None\n | [ s ] ->\n (match String.rsplit2 ~on:'T' s with\n | Some (date, ofday) -> date, ofday, None\n | None -> failwith \"no spaces or T found\")\n | _ -> failwith \"too many spaces\"\n in\n let ofday_to_sec od = Span.to_sec (Ofday.to_span_since_start_of_day od) in\n let ofday, utc_offset =\n match tz with\n | Some _ -> ofday, None\n | None ->\n if Char.( = ) ofday.[String.length ofday - 1] 'Z'\n then String.sub ofday ~pos:0 ~len:(String.length ofday - 1), Some 0.\n else (\n match String.lsplit2 ~on:'+' ofday with\n | Some (l, r) ->\n l, Some (ofday_to_sec (Ofday.of_string (ensure_colon_in_offset r)))\n | None ->\n (match String.lsplit2 ~on:'-' ofday with\n | Some (l, r) ->\n l, Some (-1. *. ofday_to_sec (Ofday.of_string (ensure_colon_in_offset r)))\n | None -> ofday, None))\n in\n let date = Date0.of_string date in\n let ofday = Ofday.of_string ofday in\n match tz with\n | Some tz -> of_date_ofday ~zone:(find_zone tz) date ofday\n | None ->\n (match utc_offset with\n | None ->\n let zone = default_zone () in\n of_date_ofday ~zone date ofday\n | Some utc_offset ->\n let utc_t = of_date_ofday ~zone:Zone.utc date ofday in\n sub utc_t (Span.of_sec utc_offset))\n with\n | e -> raise (Time_ns_of_string (s, e))\n ;;\n\n let of_string s =\n let default_zone () = raise_s [%message \"time has no time zone or UTC offset\" s] in\n let find_zone zone_name =\n failwithf \"unable to lookup Zone %s. Try using Core.Time.of_string\" zone_name ()\n in\n of_string_gen ~default_zone ~find_zone s\n ;;\nend\n\ninclude To_and_of_string\n\nlet min_value_representable = of_span_since_epoch Span.min_value_representable\nlet max_value_representable = of_span_since_epoch Span.max_value_representable\n\n(* Legacy definitions based on rounding to the nearest microsecond. *)\nlet min_value = min_value_for_1us_rounding\nlet max_value = max_value_for_1us_rounding\nlet to_time = to_time_float_round_nearest_microsecond\nlet of_time = of_time_float_round_nearest_microsecond\n\nmodule For_ppx_module_timer = struct\n open Ppx_module_timer_runtime\n\n let () =\n Duration.format\n := (module struct\n let duration_of_span s = s |> Span.to_int63_ns |> Duration.of_nanoseconds\n let span_of_duration d = d |> Duration.to_nanoseconds |> Span.of_int63_ns\n let of_string string = string |> Span.of_string |> duration_of_span\n\n let to_string_with_same_unit durations =\n let spans = durations |> List.map ~f:span_of_duration in\n let unit_of_time =\n spans\n |> List.max_elt ~compare:Span.compare\n |> Option.value_map\n ~f:Span.to_unit_of_time\n ~default:Unit_of_time.Nanosecond\n in\n spans |> List.map ~f:(Span.to_string_hum ~unit_of_time ~align_decimal:true)\n ;;\n end)\n ;;\nend\n","open! Import\n\n(* A [Time_ns] that uses its alternate sexp representation. *)\ninclude Time_ns\ninclude Alternate_sexp\n","module Stable = struct\n open Stable_internal\n\n module T = struct\n type 'a t =\n { mutable value : 'a option\n ; mutable set_at : Source_code_position.Stable.V1.t\n }\n [@@deriving fields]\n end\n\n module V1 = struct\n module Format = struct\n type 'a t = 'a option ref [@@deriving bin_io, sexp]\n end\n\n module T = struct\n type 'a t = 'a T.t\n\n let of_format (v1 : 'a Format.t) : 'a t = { value = !v1; set_at = [%here] }\n let to_format (t : 'a t) : 'a Format.t = ref t.value\n end\n\n include T\n\n include Binable.Of_binable1_without_uuid [@alert \"-legacy\"]\n (Format)\n (struct\n include T\n\n let of_binable = of_format\n let to_binable = to_format\n end)\n\n include Sexpable.Of_sexpable1\n (Format)\n (struct\n include T\n\n let of_sexpable = of_format\n let to_sexpable = to_format\n end)\n end\nend\n\nopen! Import\nmodule Unstable = Stable.V1\nopen Stable.T\n\ntype 'a t = 'a Stable.T.t\n\nlet sexp_of_t sexp_of_a { value; set_at } =\n match value with\n | None -> [%message \"unset\"]\n | Some value ->\n [%message \"\" (value : a) ~set_at:(set_at |> Source_code_position.to_string)]\n;;\n\nlet invariant invariant_a t =\n match t.value with\n | None -> ()\n | Some a -> invariant_a a\n;;\n\nlet create () = { value = None; set_at = [%here] }\n\nlet set_internal t here value =\n t.value <- Some value;\n t.set_at <- here\n;;\n\nlet set_if_none t here value = if Option.is_none t.value then set_internal t here value\n\nlet set t here value =\n if Option.is_none t.value\n then (\n set_internal t here value;\n Ok ())\n else\n Or_error.error_s\n [%message\n \"[Set_once.set_exn] already set\"\n ~setting_at:(here : Source_code_position.t)\n ~previously_set_at:(t.set_at : Source_code_position.t)]\n;;\n\nlet set_exn t here value = Or_error.ok_exn (set t here value)\nlet get t = t.value\n\nlet get_exn (t : _ t) here =\n match t.value with\n | Some a -> a\n | None ->\n raise_s [%message \"[Set_once.get_exn] unset\" ~at:(here : Source_code_position.t)]\n;;\n\nlet is_none t = Option.is_none t.value\nlet is_some t = Option.is_some t.value\nlet iter t ~f = Option.iter t.value ~f\n\nmodule Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n let unsafe_value t = get_exn t [%here]\n end\nend\n","open! Import\n\ntype 'a t = 'a [@@deriving sexp_of]\n\nexternal is_heap_block : Caml.Obj.t -> bool = \"Core_kernel_heap_block_is_heap_block\"\n[@@noalloc]\n\nlet is_ok v = is_heap_block (Caml.Obj.repr v)\nlet create v = if is_ok v then Some v else None\n\nlet create_exn v =\n if is_ok v then v else failwith \"Heap_block.create_exn called with non heap block\"\n;;\n\nlet value t = t\nlet bytes_per_word = Word_size.(num_bits word_size) / 8\n\nlet bytes (type a) (t : a t) =\n (Caml.Obj.size (Caml.Obj.repr (t : a t)) + 1) * bytes_per_word\n;;\n","open! Import\ninclude Base.Queue\n\ninclude Test_binary_searchable.Make1_and_test (struct\n type nonrec 'a t = 'a t\n\n let get = get\n let length = length\n\n module For_test = struct\n let of_array a =\n let r = create () in\n (* We enqueue everything twice, and dequeue it once to ensure:\n - that the queue has the same content as the array.\n - that it has, in most cases, an interesting internal structure*)\n for i = 0 to Array.length a - 1 do\n enqueue r a.(i)\n done;\n for i = 0 to Array.length a - 1 do\n ignore (dequeue_exn r : bool);\n enqueue r a.(i)\n done;\n r\n ;;\n end\n end)\n\nmodule Serialization_v1 = struct\n let sexp_of_t = sexp_of_t\n let t_of_sexp = t_of_sexp\n\n include Bin_prot.Utils.Make_iterable_binable1 (struct\n type nonrec 'a t = 'a t\n type 'a el = 'a [@@deriving bin_io]\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"b4c84254-4992-11e6-9ba7-734e154027bd\"\n ;;\n\n let module_name = Some \"Core_kernel.Queue\"\n let length = length\n let iter = iter\n let init ~len ~next = init len ~f:(fun _ -> next ())\n end)\nend\n\ninclude Serialization_v1\n\nmodule Stable = struct\n module V1 = struct\n type nonrec 'a t = 'a t [@@deriving compare]\n\n include Serialization_v1\n\n (* We don't have a [%bin_digest] expect test here because the bin_io is mostly hand\n written, and [core_queue_unit_tests.ml] has unit tests for specific values. *)\n\n let map = map\n end\nend\n","open! Import\ninclude Base.Option_array\n\nlet to_array t = Array.init (length t) ~f:(fun i -> unsafe_get t i)\nlet of_array a = init (Array.length a) ~f:(fun i -> Array.unsafe_get a i)\n\ninclude Binable.Of_binable1_without_uuid [@alert \"-legacy\"]\n (struct\n type 'a t = 'a option array [@@deriving sexp, bin_io]\n end)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable = to_array\n let of_binable = of_array\n end)\n","open! Import\nopen Std_internal\n\ntype ('a, 'b) fn = 'a -> 'b\n\nmodule Result = struct\n type 'a t =\n | Rval of 'a\n | Expt of exn\n\n let return = function\n | Rval v -> v\n | Expt e -> raise e\n ;;\n\n let capture f x =\n try Rval (f x) with\n | Sys.Break as e -> raise e\n | e -> Expt e\n ;;\nend\n\nlet unit f =\n let l = Lazy.from_fun f in\n fun () -> Lazy.force l\n;;\n\nlet unbounded (type a) ?(hashable = Hashtbl.Hashable.poly) f =\n let cache =\n let module A =\n Hashable.Make_plain_and_derive_hash_fold_t (struct\n type t = a\n\n let { Hashtbl.Hashable.hash; compare; sexp_of_t } = hashable\n end)\n in\n A.Table.create () ~size:0\n in\n (* Allocate this closure at the call to [unbounded], not at each call to the memoized\n function. *)\n let really_call_f arg = Result.capture f arg in\n fun arg -> Result.return (Hashtbl.findi_or_add cache arg ~default:really_call_f)\n;;\n\n(* the same but with a bound on cache size *)\nlet lru (type a) ?(hashable = Hashtbl.Hashable.poly) ~max_cache_size f =\n if max_cache_size <= 0\n then failwithf \"Memo.lru: max_cache_size of %i <= 0\" max_cache_size ();\n let module Cache =\n Hash_queue.Make (struct\n type t = a\n\n let { Hashtbl.Hashable.hash; compare; sexp_of_t } = hashable\n end)\n in\n let cache = Cache.create () in\n fun arg ->\n Result.return\n (match Cache.lookup_and_move_to_back cache arg with\n | Some result -> result\n | None ->\n let result = Result.capture f arg in\n Cache.enqueue_back_exn cache arg result;\n (* eject least recently used cache entry *)\n if Cache.length cache > max_cache_size\n then ignore (Cache.dequeue_front_exn cache : _ Result.t);\n result)\n;;\n\nlet general ?hashable ?cache_size_bound f =\n match cache_size_bound with\n | None -> unbounded ?hashable f\n | Some n -> lru ?hashable ~max_cache_size:n f\n;;\n\nlet of_comparable (type index) (module M : Comparable.S_plain with type t = index) f =\n let m = ref M.Map.empty in\n fun (x : M.t) ->\n let v =\n match Map.find !m x with\n | Some v -> v\n | None ->\n let v = Result.capture f x in\n m := Map.set !m ~key:x ~data:v;\n v\n in\n Result.return v\n;;\n","open! Import\nopen Std_internal\n\ntype 'a t =\n { (* [arr] is a cyclic buffer *)\n mutable arr : 'a Option_array.t\n ; (* [front_index] and [back_index] are the positions in which new elements may be\n enqueued. This makes the active part of [arr] the range from [front_index+1] to\n [back_index-1] (modulo the length of [arr] and wrapping around if necessary). Note\n that this means the active range is maximized when [front_index = back_index], which\n occurs when there are [Array.length arr - 1] active elements. *)\n mutable front_index : int\n ; mutable back_index : int\n ; (* apparent_front_index is what is exposed as the front index externally. It has no\n real relation to the array -- every enqueue to the front decrements it and every\n dequeue from the front increments it. *)\n mutable apparent_front_index : int\n ; mutable length : int\n ; (* We keep arr_length here as a speed hack. Calling Array.length on arr is actually\n meaningfully slower. *)\n mutable arr_length : int\n ; never_shrink : bool\n }\n\nlet create ?initial_length ?never_shrink () =\n let never_shrink =\n match never_shrink with\n | None -> Option.is_some initial_length\n | Some b -> b\n in\n let initial_length = Option.value ~default:7 initial_length in\n if initial_length < 0\n then\n invalid_argf \"passed negative initial_length to Deque.create: %i\" initial_length ();\n (* Make the initial array length be [initial_length + 1] so we can fit [initial_length]\n elements without growing. We never quite use the whole array. *)\n let arr_length = initial_length + 1 in\n { arr = Option_array.create ~len:arr_length\n ; front_index = 0\n ; back_index = 1\n ; apparent_front_index = 0\n ; length = 0\n ; arr_length\n ; never_shrink\n }\n;;\n\nlet length t = t.length\nlet is_empty t = length t = 0\n\n(* We keep track of the length in a mutable field for speed, but this calculation should\n be correct by construction, and can be used for testing. *)\nlet _invariant_length t =\n let constructed_length =\n if t.front_index < t.back_index\n then t.back_index - t.front_index - 1\n else t.back_index - t.front_index - 1 + t.arr_length\n in\n assert (length t = constructed_length)\n;;\n\n(* The various \"when_not_empty\" functions return misleading numbers when the dequeue is\n empty. They are safe to call if it is known that the dequeue is non-empty. *)\nlet apparent_front_index_when_not_empty t = t.apparent_front_index\nlet apparent_back_index_when_not_empty t = t.apparent_front_index + length t - 1\n\nlet actual_front_index_when_not_empty t =\n if t.front_index = t.arr_length - 1 then 0 else t.front_index + 1\n;;\n\nlet actual_back_index_when_not_empty t =\n if t.back_index = 0 then t.arr_length - 1 else t.back_index - 1\n;;\n\nlet checked t f = if is_empty t then None else Some (f t)\nlet apparent_front_index t = checked t apparent_front_index_when_not_empty\nlet apparent_back_index t = checked t apparent_back_index_when_not_empty\n\nlet foldi' t dir ~init ~f =\n if is_empty t\n then init\n else (\n let apparent_front = apparent_front_index_when_not_empty t in\n let apparent_back = apparent_back_index_when_not_empty t in\n let actual_front = actual_front_index_when_not_empty t in\n let actual_back = actual_back_index_when_not_empty t in\n let rec loop acc ~apparent_i ~real_i ~stop_pos ~step =\n if real_i = stop_pos\n then acc, apparent_i\n else\n loop\n (f apparent_i acc (Option_array.get_some_exn t.arr real_i))\n ~apparent_i:(apparent_i + step)\n ~real_i:(real_i + step)\n ~stop_pos\n ~step\n in\n (* We want to iterate from actual_front to actual_back (or vice versa), but we may\n need to wrap around the array to do so. Thus we do the following:\n 1. If the active range is contiguous (i.e. actual_front <= actual_back), then loop\n starting at the appropriate end of the active range until we reach the first\n element outside of it.\n 2. If it is not contiguous (actual_front > actual_back), then first loop from the\n appropriate end of the active range to the end of the array. Then, loop from\n the opposite end of the array to the opposite end of the active range.\n *)\n match dir with\n | `front_to_back ->\n if actual_front <= actual_back\n then (\n let acc, _ =\n loop\n init\n ~apparent_i:apparent_front\n ~real_i:actual_front\n ~stop_pos:(actual_back + 1)\n ~step:1\n in\n acc)\n else (\n let acc, apparent_i =\n loop\n init\n ~apparent_i:apparent_front\n ~real_i:actual_front\n ~stop_pos:t.arr_length\n ~step:1\n in\n let acc, _ =\n loop acc ~apparent_i ~real_i:0 ~stop_pos:(actual_back + 1) ~step:1\n in\n acc)\n | `back_to_front ->\n if actual_front <= actual_back\n then (\n let acc, _ =\n loop\n init\n ~apparent_i:apparent_back\n ~real_i:actual_back\n ~stop_pos:(actual_front - 1)\n ~step:(-1)\n in\n acc)\n else (\n let acc, apparent_i =\n loop\n init\n ~apparent_i:apparent_back\n ~real_i:actual_back\n ~stop_pos:(-1)\n ~step:(-1)\n in\n let acc, _ =\n loop\n acc\n ~apparent_i\n ~real_i:(t.arr_length - 1)\n ~stop_pos:(actual_front - 1)\n ~step:(-1)\n in\n acc))\n;;\n\nlet fold' t dir ~init ~f = foldi' t dir ~init ~f:(fun _ acc v -> f acc v)\nlet iteri' t dir ~f = foldi' t dir ~init:() ~f:(fun i () v -> f i v)\nlet iter' t dir ~f = foldi' t dir ~init:() ~f:(fun _ () v -> f v)\nlet fold t ~init ~f = fold' t `front_to_back ~init ~f\nlet foldi t ~init ~f = foldi' t `front_to_back ~init ~f\nlet iteri t ~f = iteri' t `front_to_back ~f\n\nlet iteri_internal t ~f =\n if not (is_empty t)\n then (\n let actual_front = actual_front_index_when_not_empty t in\n let actual_back = actual_back_index_when_not_empty t in\n let rec loop ~real_i ~stop_pos =\n if real_i < stop_pos\n then (\n f t.arr real_i;\n loop ~real_i:(real_i + 1) ~stop_pos)\n in\n if actual_front <= actual_back\n then loop ~real_i:actual_front ~stop_pos:(actual_back + 1)\n else (\n loop ~real_i:actual_front ~stop_pos:t.arr_length;\n loop ~real_i:0 ~stop_pos:(actual_back + 1)))\n;;\n\nlet iter t ~f = iteri_internal t ~f:(fun arr i -> Option_array.get_some_exn arr i |> f)\n\nlet clear t =\n if t.never_shrink\n then\n (* clear the array to allow elements to be garbage collected *)\n iteri_internal t ~f:Option_array.unsafe_set_none\n else t.arr <- Option_array.create ~len:8;\n t.front_index <- 0;\n t.back_index <- 1;\n t.length <- 0;\n t.arr_length <- Option_array.length t.arr\n;;\n\n(* We have to be careful here, importing all of Container.Make would change the runtime of\n some functions ([length] minimally) silently without changing the semantics. We get\n around that by importing things explicitly. *)\nmodule C = Container.Make (struct\n type nonrec 'a t = 'a t\n\n let fold = fold\n let iter = `Custom iter\n let length = `Custom length\n end)\n\nlet count = C.count\nlet sum = C.sum\nlet exists = C.exists\nlet mem = C.mem\nlet for_all = C.for_all\nlet find_map = C.find_map\nlet find = C.find\nlet to_list = C.to_list\nlet min_elt = C.min_elt\nlet max_elt = C.max_elt\nlet fold_result = C.fold_result\nlet fold_until = C.fold_until\n\nlet blit new_arr t =\n assert (not (is_empty t));\n let actual_front = actual_front_index_when_not_empty t in\n let actual_back = actual_back_index_when_not_empty t in\n let old_arr = t.arr in\n if actual_front <= actual_back\n then\n Option_array.blit\n ~src:old_arr\n ~dst:new_arr\n ~src_pos:actual_front\n ~dst_pos:0\n ~len:(length t)\n else (\n let break_pos = Option_array.length old_arr - actual_front in\n Option_array.blit\n ~src:old_arr\n ~dst:new_arr\n ~src_pos:actual_front\n ~dst_pos:0\n ~len:break_pos;\n Option_array.blit\n ~src:old_arr\n ~dst:new_arr\n ~src_pos:0\n ~dst_pos:break_pos\n ~len:(actual_back + 1));\n (* length depends on t.arr and t.front_index, so this needs to be first *)\n t.back_index <- length t;\n t.arr <- new_arr;\n t.arr_length <- Option_array.length new_arr;\n t.front_index <- Option_array.length new_arr - 1;\n (* Since t.front_index = Option_array.length new_arr - 1, this is asserting that t.back_index\n is a valid index in the array and that the array can support at least one more\n element -- recall, if t.front_index = t.back_index then the array is full.\n\n Note that this is true if and only if Option_array.length new_arr > length t + 1.\n *)\n assert (t.front_index > t.back_index)\n;;\n\nlet maybe_shrink_underlying t =\n if (not t.never_shrink) && t.arr_length > 10 && t.arr_length / 3 > length t\n then (\n let new_arr = Option_array.create ~len:(t.arr_length / 2) in\n blit new_arr t)\n;;\n\nlet grow_underlying t =\n let new_arr = Option_array.create ~len:(t.arr_length * 2) in\n blit new_arr t\n;;\n\nlet enqueue_back t v =\n if t.front_index = t.back_index then grow_underlying t;\n Option_array.set_some t.arr t.back_index v;\n t.back_index <- (if t.back_index = t.arr_length - 1 then 0 else t.back_index + 1);\n t.length <- t.length + 1\n;;\n\nlet enqueue_front t v =\n if t.front_index = t.back_index then grow_underlying t;\n Option_array.set_some t.arr t.front_index v;\n t.front_index <- (if t.front_index = 0 then t.arr_length - 1 else t.front_index - 1);\n t.apparent_front_index <- t.apparent_front_index - 1;\n t.length <- t.length + 1\n;;\n\nlet enqueue t back_or_front v =\n match back_or_front with\n | `back -> enqueue_back t v\n | `front -> enqueue_front t v\n;;\n\nlet peek_front_nonempty t =\n Option_array.get_some_exn t.arr (actual_front_index_when_not_empty t)\n;;\n\nlet peek_front_exn t =\n if is_empty t\n then failwith \"Deque.peek_front_exn passed an empty queue\"\n else peek_front_nonempty t\n;;\n\nlet peek_front t = if is_empty t then None else Some (peek_front_nonempty t)\n\nlet peek_back_nonempty t =\n Option_array.get_some_exn t.arr (actual_back_index_when_not_empty t)\n;;\n\nlet peek_back_exn t =\n if is_empty t\n then failwith \"Deque.peek_back_exn passed an empty queue\"\n else peek_back_nonempty t\n;;\n\nlet peek_back t = if is_empty t then None else Some (peek_back_nonempty t)\n\nlet peek t back_or_front =\n match back_or_front with\n | `back -> peek_back t\n | `front -> peek_front t\n;;\n\nlet dequeue_front_nonempty t =\n let i = actual_front_index_when_not_empty t in\n let res = Option_array.get_some_exn t.arr i in\n Option_array.set_none t.arr i;\n t.front_index <- i;\n t.apparent_front_index <- t.apparent_front_index + 1;\n t.length <- t.length - 1;\n maybe_shrink_underlying t;\n res\n;;\n\nlet dequeue_front_exn t =\n if is_empty t\n then failwith \"Deque.dequeue_front_exn passed an empty queue\"\n else dequeue_front_nonempty t\n;;\n\nlet dequeue_front t = if is_empty t then None else Some (dequeue_front_nonempty t)\n\nlet dequeue_back_nonempty t =\n let i = actual_back_index_when_not_empty t in\n let res = Option_array.get_some_exn t.arr i in\n Option_array.set_none t.arr i;\n t.back_index <- i;\n t.length <- t.length - 1;\n maybe_shrink_underlying t;\n res\n;;\n\nlet dequeue_back_exn t =\n if is_empty t\n then failwith \"Deque.dequeue_back_exn passed an empty queue\"\n else dequeue_back_nonempty t\n;;\n\nlet dequeue_back t = if is_empty t then None else Some (dequeue_back_nonempty t)\n\nlet dequeue_exn t back_or_front =\n match back_or_front with\n | `front -> dequeue_front_exn t\n | `back -> dequeue_back_exn t\n;;\n\nlet dequeue t back_or_front =\n match back_or_front with\n | `front -> dequeue_front t\n | `back -> dequeue_back t\n;;\n\nlet drop_gen ?(n = 1) ~dequeue t =\n if n < 0 then invalid_argf \"Deque.drop: negative input (%d)\" n ();\n let rec loop n =\n if n > 0\n then (\n match dequeue t with\n | None -> ()\n | Some _ -> loop (n - 1))\n in\n loop n\n;;\n\nlet drop_front ?n t = drop_gen ?n ~dequeue:dequeue_front t\nlet drop_back ?n t = drop_gen ?n ~dequeue:dequeue_back t\n\nlet drop ?n t back_or_front =\n match back_or_front with\n | `back -> drop_back ?n t\n | `front -> drop_front ?n t\n;;\n\nlet assert_not_empty t name = if is_empty t then failwithf \"%s: Deque.t is empty\" name ()\n\nlet true_index_exn t i =\n let i_from_zero = i - t.apparent_front_index in\n if i_from_zero < 0 || length t <= i_from_zero\n then (\n assert_not_empty t \"Deque.true_index_exn\";\n let apparent_front = apparent_front_index_when_not_empty t in\n let apparent_back = apparent_back_index_when_not_empty t in\n invalid_argf\n \"invalid index: %i for array with indices (%i,%i)\"\n i\n apparent_front\n apparent_back\n ());\n let true_i = t.front_index + 1 + i_from_zero in\n if true_i >= t.arr_length then true_i - t.arr_length else true_i\n;;\n\nlet get t i = Option_array.get_some_exn t.arr (true_index_exn t i)\n\nlet get_opt t i =\n try Some (get t i) with\n | _ -> None\n;;\n\nlet set_exn t i v = Option_array.set_some t.arr (true_index_exn t i) v\n\nlet to_array t =\n match peek_front t with\n | None -> [||]\n | Some front ->\n let arr = Array.create ~len:(length t) front in\n ignore\n (fold t ~init:0 ~f:(fun i v ->\n arr.(i) <- v;\n i + 1)\n : int);\n arr\n;;\n\nlet of_array arr =\n let t = create ~initial_length:(Array.length arr + 1) () in\n Array.iter arr ~f:(fun v -> enqueue_back t v);\n t\n;;\n\ninclude Bin_prot.Utils.Make_iterable_binable1 (struct\n type nonrec 'a t = 'a t\n type 'a el = 'a [@@deriving bin_io]\n\n let caller_identity =\n Bin_prot.Shape.Uuid.of_string \"34c1e9ca-4992-11e6-a686-8b4bd4f87796\"\n ;;\n\n let module_name = Some \"Core_kernel.Deque\"\n let length = length\n let iter t ~f = iter t ~f\n\n let init ~len ~next =\n let t = create ~initial_length:len () in\n for _i = 0 to len - 1 do\n let x = next () in\n enqueue_back t x\n done;\n t\n ;;\n end)\n\nlet t_of_sexp f sexp = of_array (Array.t_of_sexp f sexp)\nlet sexp_of_t f t = Array.sexp_of_t f (to_array t)\n\n(* re-expose these here under a different name to avoid internal confusion *)\nlet back_index = apparent_back_index\nlet front_index = apparent_front_index\n\nlet back_index_exn t =\n assert_not_empty t \"Deque.back_index_exn\";\n apparent_back_index_when_not_empty t\n;;\n\nlet front_index_exn t =\n assert_not_empty t \"Deque.front_index_exn\";\n apparent_front_index_when_not_empty t\n;;\n\nmodule Binary_searchable = Test_binary_searchable.Make1_and_test (struct\n type nonrec 'a t = 'a t\n\n let get t i = get t (front_index_exn t + i)\n let length = length\n\n module For_test = struct\n let of_array = of_array\n end\n end)\n\n(* The \"stable\" indices used in this module make the application of the\n [Binary_searchable] functor awkward. We need to be sure to translate incoming\n positions from stable space to the expected 0 -> length - 1 space and then we need to\n translate them back on return. *)\nlet binary_search ?pos ?len t ~compare how v =\n let pos =\n match pos with\n | None -> None\n | Some pos -> Some (pos - t.apparent_front_index)\n in\n match Binary_searchable.binary_search ?pos ?len t ~compare how v with\n | None -> None\n | Some untranslated_i -> Some (t.apparent_front_index + untranslated_i)\n;;\n\nlet binary_search_segmented ?pos ?len t ~segment_of how =\n let pos =\n match pos with\n | None -> None\n | Some pos -> Some (pos - t.apparent_front_index)\n in\n match Binary_searchable.binary_search_segmented ?pos ?len t ~segment_of how with\n | None -> None\n | Some untranslated_i -> Some (t.apparent_front_index + untranslated_i)\n;;\n","open! Import\nmodule List = Base.List\nmodule String = Base.String\n\nlet eprint message = Printf.eprintf \"%s\\n%!\" message\nlet eprint_s sexp = eprint (Sexp.to_string_hum sexp)\nlet eprints message a sexp_of_a = eprint_s ([%sexp_of: string * a] (message, a))\nlet eprintf format = Printf.ksprintf eprint format\nlet failwiths = Error.failwiths\n\nmodule Make () = struct\n let check_invariant = ref true\n let show_messages = ref true\n\n let debug invariant ~module_name name ts arg sexp_of_arg sexp_of_result f =\n if !show_messages\n then eprints (String.concat ~sep:\"\" [ module_name; \".\"; name ]) arg sexp_of_arg;\n if !check_invariant\n then (\n try List.iter ts ~f:invariant with\n | exn ->\n failwiths\n ~here:[%here]\n \"invariant pre-condition failed\"\n (name, exn)\n [%sexp_of: string * exn]);\n let result_or_exn = Result.try_with f in\n if !check_invariant\n then (\n try List.iter ts ~f:invariant with\n | exn ->\n failwiths\n ~here:[%here]\n \"invariant post-condition failed\"\n (name, exn)\n [%sexp_of: string * exn]);\n if !show_messages\n then\n eprints\n (String.concat ~sep:\"\" [ module_name; \".\"; name; \"-result\" ])\n result_or_exn\n [%sexp_of: (result, exn) Result.t];\n Result.ok_exn result_or_exn\n ;;\nend\n\nlet should_print_backtrace = ref false\n\nlet am_internal here message =\n (* In this function we use [Printf.eprintf] rather than [Debug.eprintf], because the\n former doesn't flush, while the latter does. We'd rather flush once at the end,\n rather than three times. *)\n Printf.eprintf \"%s:\\n\" (Source_code_position.to_string here);\n if !should_print_backtrace\n then\n Printf.eprintf\n \"%s\\n\"\n (Backtrace.get () |> [%sexp_of: Backtrace.t] |> Sexp.to_string_hum);\n (match message with\n | None -> ()\n | Some message -> Printf.eprintf \"%s\\n\" message);\n Printf.eprintf \"%!\"\n;;\n\nlet am here = am_internal here None\nlet amf here fmt = Printf.ksprintf (fun string -> am_internal here (Some string)) fmt\n\nlet ams here message a sexp_of_a =\n am_internal here (Some ((message, a) |> [%sexp_of: string * a] |> Sexp.to_string_hum))\n;;\n","(** Imperative set-like data structure.\n\n There are a few differences from simple sets:\n\n - Duplicates are allowed.\n - It doesn't require anything (hashable, comparable) of elements in the bag.\n - Addition and removal are constant time operations.\n\n It is an error to modify a bag ([add], [remove], [remove_one], ...) during iteration\n ([fold], [iter], ...). *)\n\nopen! Import\n\nmodule type S = sig\n module Elt : sig\n type 'a t\n\n val equal : 'a t -> 'a t -> bool\n val sexp_of_t : ('a -> Sexp.t) -> 'a t -> Sexp.t\n val value : 'a t -> 'a\n end\n\n type 'a t [@@deriving sexp]\n\n (** Much of a bag's interface comes from the generic {!Base.Container} module. *)\n include\n Container.S1 with type 'a t := 'a t\n\n include Invariant.S1 with type 'a t := 'a t\n\n (** [create ()] returns an empty bag. *)\n val create : unit -> 'a t\n\n (** [add t v] adds [v] to the bag [t], returning an element that can\n later be removed from the bag. [add] runs in constant time. *)\n val add : 'a t -> 'a -> 'a Elt.t\n\n val add_unit : 'a t -> 'a -> unit\n\n (** [mem_elt t elt] returns whether or not [elt] is in [t]. It is like [mem] (included\n from [Container]), but it takes an ['a Elt.t] instead of an ['a] and runs in constant\n time instead of linear time. *)\n val mem_elt : 'a t -> 'a Elt.t -> bool\n\n (** [remove t elt] removes [elt] from the bag [t], raising an exception if [elt]\n is not in the bag. [remove] runs in constant time. *)\n val remove : 'a t -> 'a Elt.t -> unit\n\n (** [choose t] returns some element in the bag. *)\n val choose : 'a t -> 'a Elt.t option\n\n (** [remove_one t] removes some element from the bag, and returns its value.\n [remove_one] runs in constant time. *)\n val remove_one : 'a t -> 'a option\n\n (** [clear t] removes all elements from the bag. [clear] runs in constant time. *)\n val clear : 'a t -> unit\n\n (** [filter_inplace t ~f] removes all the elements from [t] that don't satisfy [f]. *)\n val filter_inplace : 'a t -> f:('a -> bool) -> unit\n\n val iter_elt : 'a t -> f:('a Elt.t -> unit) -> unit\n\n (** [find_elt t ~f] returns the first element in the bag satisfying [f], returning [None]\n if none is found. *)\n val find_elt : 'a t -> f:('a -> bool) -> 'a Elt.t option\n\n (** [until_empty t f] repeatedly removes values [v] from [t], running [f v] on each one,\n until [t] is empty. Running [f] may add elements to [t] if it wants. *)\n val until_empty : 'a t -> ('a -> unit) -> unit\n\n (** [transfer ~src ~dst] moves all of the elements from [src] to [dst] in constant\n time. *)\n val transfer : src:'a t -> dst:'a t -> unit\n\n val of_list : 'a list -> 'a t\n val elts : 'a t -> 'a Elt.t list\n\n (** [unchecked_iter t ~f] behaves like [iter t ~f] except that [f] is allowed to modify\n [t]. Elements added by [f] may or may not be visited; elements removed by [f] that\n have not been visited will not be visited. It is an (undetected) error to delete the\n current element. *)\n val unchecked_iter : 'a t -> f:('a -> unit) -> unit\nend\n\nmodule type Bag = sig\n (** The module type of the Bag module.\n\n Example usage:\n {[\n module My_bag : Bag.S = Bag\n ]}\n\n Now [My_bag.Elt.t] can't be used with any other [Bag.t] type.\n *)\n module type S = S\n\n include S\nend\n","(*\n * Copyright (c) 2013 Jeremy Yallop.\n *\n * This file is distributed under the terms of the MIT License.\n * See the file LICENSE for details.\n *)\n\nmodule Pervasives = Pervasives [@@ocaml.warning \"-3\"]\n\nexternal init : unit -> unit = \"integers_unsigned_init\"\nlet () = init ()\n\n(* Boxed unsigned types *)\nmodule type Basics = sig\n type t\n\n val add : t -> t -> t\n val sub : t -> t -> t\n val mul : t -> t -> t\n val div : t -> t -> t\n val rem : t -> t -> t\n val max_int : t\n val logand : t -> t -> t\n val logor : t -> t -> t\n val logxor : t -> t -> t\n val shift_left : t -> int -> t\n val shift_right : t -> int -> t\n val of_int : int -> t\n val to_int : t -> int\n val of_int64 : int64 -> t\n val to_int64 : t -> int64\n val of_string : string -> t\n val to_string : t -> string\nend\n\n\nmodule type Extras = sig\n type t\n\n val zero : t\n val one : t\n val lognot : t -> t\n val succ : t -> t\n val pred : t -> t\n val compare : t -> t -> int\n val equal : t -> t -> bool\n val max : t -> t -> t\n val min : t -> t -> t\n val pp : Format.formatter -> t -> unit\nend\n\n\nmodule type Infix = sig\n type t\n val (+) : t -> t -> t\n val (-) : t -> t -> t\n val ( * ) : t -> t -> t\n val (/) : t -> t -> t\n val (mod) : t -> t -> t\n val (land) : t -> t -> t\n val (lor) : t -> t -> t\n val (lxor) : t -> t -> t\n val (lsl) : t -> int -> t\n val (lsr) : t -> int -> t\nend\n\n\nmodule type S = sig\n include Basics\n include Extras with type t := t\n\n module Infix : Infix with type t := t\nend\n\n\nmodule MakeInfix (B : Basics) =\nstruct\n open B\n let (+) = add\n let (-) = sub\n let ( * ) = mul\n let (/) = div\n let (mod) = rem\n let (land) = logand\n let (lor) = logor\n let (lxor) = logxor\n let (lsl) = shift_left\n let (lsr) = shift_right\nend\n\n\nmodule Extras(Basics : Basics) : Extras with type t := Basics.t =\nstruct\n open Basics\n let zero = of_int 0\n let one = of_int 1\n let succ n = add n one\n let pred n = sub n one\n let lognot n = logxor n max_int\n let compare (x : t) (y : t) = Pervasives.compare x y\n let equal (x : t) (y : t) = Pervasives.(=) x y\n let max (x : t) (y : t) = Pervasives.max x y\n let min (x : t) (y : t) = Pervasives.min x y\n let pp fmt x = Format.fprintf fmt \"%s\" (to_string x)\nend\n\n\nmodule UInt8 : S with type t = private int =\nstruct\n module B =\n struct\n type t = int\n let max_int = 255\n let add : t -> t -> t = fun x y -> (x + y) land max_int\n let sub : t -> t -> t = fun x y -> (x - y) land max_int\n let mul : t -> t -> t = fun x y -> (x * y) land max_int\n let div : t -> t -> t = (/)\n let rem : t -> t -> t = (mod)\n let logand: t -> t -> t = (land)\n let logor: t -> t -> t = (lor)\n let logxor : t -> t -> t = (lxor)\n let shift_left : t -> int -> t = fun x y -> (x lsl y) land max_int\n let shift_right : t -> int -> t = (lsr)\n let of_int (x: int): t =\n (* For backwards compatibility, this wraps *)\n x land max_int\n external to_int : t -> int = \"%identity\"\n let of_int64 : int64 -> t = fun x -> of_int (Int64.to_int x)\n let to_int64 : t -> int64 = fun x -> Int64.of_int (to_int x)\n external of_string : string -> t = \"integers_uint8_of_string\"\n let to_string : t -> string = string_of_int\n end\n include B\n include Extras(B)\n module Infix = MakeInfix(B)\nend\n\n\nmodule UInt16 : S with type t = private int =\nstruct\n module B =\n struct\n type t = int\n let max_int = 65535\n let add : t -> t -> t = fun x y -> (x + y) land max_int\n let sub : t -> t -> t = fun x y -> (x - y) land max_int\n let mul : t -> t -> t = fun x y -> (x * y) land max_int\n let div : t -> t -> t = (/)\n let rem : t -> t -> t = (mod)\n let logand: t -> t -> t = (land)\n let logor: t -> t -> t = (lor)\n let logxor : t -> t -> t = (lxor)\n let shift_left : t -> int -> t = fun x y -> (x lsl y) land max_int\n let shift_right : t -> int -> t = (lsr)\n let of_int (x: int): t =\n (* For backwards compatibility, this wraps *)\n x land max_int\n external to_int : t -> int = \"%identity\"\n let of_int64 : int64 -> t = fun x -> Int64.to_int x |> of_int\n let to_int64 : t -> int64 = fun x -> to_int x |> Int64.of_int\n external of_string : string -> t = \"integers_uint16_of_string\"\n let to_string : t -> string = string_of_int\n end\n include B\n include Extras(B)\n module Infix = MakeInfix(B)\nend\n\n\nmodule UInt32 : sig\n include S\n external of_int32 : int32 -> t = \"integers_uint32_of_int32\"\n external to_int32 : t -> int32 = \"integers_int32_of_uint32\"\nend = \nstruct\n module B =\n struct\n type t\n external add : t -> t -> t = \"integers_uint32_add\"\n external sub : t -> t -> t = \"integers_uint32_sub\"\n external mul : t -> t -> t = \"integers_uint32_mul\"\n external div : t -> t -> t = \"integers_uint32_div\"\n external rem : t -> t -> t = \"integers_uint32_rem\"\n external logand : t -> t -> t = \"integers_uint32_logand\"\n external logor : t -> t -> t = \"integers_uint32_logor\"\n external logxor : t -> t -> t = \"integers_uint32_logxor\"\n external shift_left : t -> int -> t = \"integers_uint32_shift_left\"\n external shift_right : t -> int -> t = \"integers_uint32_shift_right\"\n external of_int : int -> t = \"integers_uint32_of_int\"\n external to_int : t -> int = \"integers_uint32_to_int\"\n external of_int64 : int64 -> t = \"integers_uint32_of_int64\"\n external to_int64 : t -> int64 = \"integers_uint32_to_int64\"\n external of_string : string -> t = \"integers_uint32_of_string\"\n external to_string : t -> string = \"integers_uint32_to_string\"\n external _max_int : unit -> t = \"integers_uint32_max\"\n let max_int = _max_int ()\n end\n include B\n include Extras(B)\n module Infix = MakeInfix(B)\n external of_int32 : int32 -> t = \"integers_uint32_of_int32\"\n external to_int32 : t -> int32 = \"integers_int32_of_uint32\"\nend\n\n\nmodule UInt64 : sig\n include S\n external of_int64 : int64 -> t = \"integers_uint64_of_int64\"\n external to_int64 : t -> int64 = \"integers_uint64_to_int64\"\n external of_uint32 : UInt32.t -> t = \"integers_uint64_of_uint32\"\n external to_uint32 : t -> UInt32.t = \"integers_uint32_of_uint64\"\nend = \nstruct\n module B =\n struct\n type t\n external add : t -> t -> t = \"integers_uint64_add\"\n external sub : t -> t -> t = \"integers_uint64_sub\"\n external mul : t -> t -> t = \"integers_uint64_mul\"\n external div : t -> t -> t = \"integers_uint64_div\"\n external rem : t -> t -> t = \"integers_uint64_rem\"\n external logand : t -> t -> t = \"integers_uint64_logand\"\n external logor : t -> t -> t = \"integers_uint64_logor\"\n external logxor : t -> t -> t = \"integers_uint64_logxor\"\n external shift_left : t -> int -> t = \"integers_uint64_shift_left\"\n external shift_right : t -> int -> t = \"integers_uint64_shift_right\"\n external of_int : int -> t = \"integers_uint64_of_int\"\n external to_int : t -> int = \"integers_uint64_to_int\"\n external of_int64 : int64 -> t = \"integers_uint64_of_int64\"\n external to_int64 : t -> int64 = \"integers_uint64_to_int64\"\n external of_uint32 : UInt32.t -> t = \"integers_uint64_of_uint32\"\n external to_uint32 : t -> UInt32.t = \"integers_uint32_of_uint64\"\n external of_string : string -> t = \"integers_uint64_of_string\"\n external to_string : t -> string = \"integers_uint64_to_string\"\n external _max_int : unit -> t = \"integers_uint64_max\"\n let max_int = _max_int ()\n end\n include B\n include Extras(B)\n module Infix = MakeInfix(B)\nend\n\n\nlet of_byte_size : int -> (module S) = function\n | 1 -> (module UInt8)\n | 2 -> (module UInt16)\n | 4 -> (module UInt32)\n | 8 -> (module UInt64)\n | _ -> invalid_arg \"Unsigned.of_byte_size\"\n\n \nexternal size_t_size : unit -> int = \"integers_size_t_size\"\nexternal ushort_size : unit -> int = \"integers_ushort_size\"\nexternal uint_size : unit -> int = \"integers_uint_size\"\nexternal ulong_size : unit -> int = \"integers_ulong_size\"\nexternal ulonglong_size : unit -> int = \"integers_ulonglong_size\"\n\nmodule Size_t : S = (val of_byte_size (size_t_size ()))\nmodule UChar = UInt8\nmodule UShort : S = (val of_byte_size (ushort_size ()))\nmodule UInt : S = (val of_byte_size (uint_size ()))\nmodule ULong : S = (val of_byte_size (ulong_size ()))\nmodule ULLong : S = (val of_byte_size (ulonglong_size ()))\n\ntype uchar = UChar.t\ntype uint8 = UInt8.t\ntype uint16 = UInt16.t\ntype uint32 = UInt32.t\ntype uint64 = UInt64.t\ntype size_t = Size_t.t\ntype ushort = UShort.t\ntype uint = UInt.t\ntype ulong = ULong.t\ntype ullong = ULLong.t\n","exception Error of string\n\nlet error s = raise (Error s)\n\n\n(*\n Debugging utilities.\n*)\n\nlet string8_of_int x =\n let s = Bytes.create 8 in\n for i = 0 to 7 do\n Bytes.set s (7-i) (Char.chr (0xff land (x lsr (8 * i))))\n done;\n Bytes.to_string s\n\nlet string4_of_int x =\n let s = Bytes.create 4 in\n for i = 0 to 3 do\n Bytes.set s (3-i) (Char.chr (0xff land (x lsr (8 * i))))\n done;\n Bytes.to_string s\n\nlet print_bits ?(pos = 0) ?len s =\n let slen = String.length s in\n if pos < 0 || (pos > 0 && pos >= slen) then\n invalid_arg \"Bi_util.print_bits\";\n let len =\n match len with\n None -> slen - pos\n | Some len ->\n if len > slen - pos then invalid_arg \"Bi_util.print_bits\"\n else len\n in\n\n let r = Bytes.create (len * 9) in\n for i = 0 to len - 1 do\n let k = i * 9 in\n let x = Char.code s.[pos+i] in\n for j = 0 to 7 do\n Bytes.set r (k+j) (if (x lsr (7 - j)) land 1 = 0 then '0' else '1')\n done;\n Bytes.set r (k+8) (if (i + 1) mod 8 = 0 then '\\n' else ' ')\n done;\n Bytes.to_string r\n\n(* int size in bits *)\nlet int_size =\n let c = ref 0 in\n let r = ref (-1) in\n while !r <> 0 do\n r := !r lsr 1;\n incr c\n done;\n !c\n","type t = {\n mutable o_s : bytes;\n mutable o_max_len : int;\n mutable o_len : int;\n mutable o_offs : int;\n o_init_len : int;\n o_make_room : (t -> int -> unit);\n mutable o_shared : Bi_share.Wr.tbl;\n o_shared_init_len : int;\n}\n\nlet really_extend b n =\n let slen0 = b.o_max_len in\n let reqlen = b.o_len + n in\n let slen =\n let x = max reqlen (2 * slen0) in\n if x <= Sys.max_string_length then x\n else\n if Sys.max_string_length < reqlen then\n\tinvalid_arg \"Buf.extend: reached Sys.max_string_length\"\n else\n\tSys.max_string_length\n in\n let s = Bytes.create slen in\n Bytes.blit b.o_s 0 s 0 b.o_len;\n b.o_s <- s;\n b.o_max_len <- slen\n\nlet flush_to_output abstract_output b n =\n abstract_output (Bytes.to_string b.o_s) 0 b.o_len;\n b.o_offs <- b.o_offs + b.o_len;\n b.o_len <- 0;\n if n > b.o_max_len then\n really_extend b n\n\nlet flush_to_channel oc = flush_to_output (output_substring oc)\n\n\nlet create ?(make_room = really_extend) ?(shrlen = 16) n = {\n o_s = Bytes.create n;\n o_max_len = n;\n o_len = 0;\n o_offs = 0;\n o_init_len = n;\n o_make_room = make_room;\n o_shared = Bi_share.Wr.create shrlen;\n o_shared_init_len = shrlen;\n}\n\nlet create_channel_writer ?(len = 4096) ?shrlen oc =\n create ~make_room:(flush_to_channel oc) ?shrlen len\n\nlet flush_channel_writer b =\n b.o_make_room b 0\n\nlet create_output_writer ?(len = 4096) ?shrlen out =\n create ~make_room:(flush_to_output out#output) ?shrlen len\n\nlet flush_output_writer = flush_channel_writer\n\n\n(*\n Guarantee that the buffer string has enough room for n additional bytes.\n*)\nlet extend b n =\n if b.o_len + n > b.o_max_len then\n b.o_make_room b n\n\nlet alloc b n =\n extend b n;\n let pos = b.o_len in\n b.o_len <- pos + n;\n pos\n\nlet add_sub blit b s pos len =\n extend b len;\n blit s pos b.o_s b.o_len len;\n b.o_len <- b.o_len + len\n\nlet add_substring = add_sub String.blit\nlet add_subbytes = add_sub Bytes.blit\n\nlet add_string b s =\n add_substring b s 0 (String.length s)\n\nlet add_bytes b s =\n add_subbytes b s 0 (Bytes.length s)\n\n\nlet add_char b c =\n let pos = alloc b 1 in\n Bytes.set b.o_s pos c\n\nlet unsafe_add_char b c =\n let len = b.o_len in\n Bytes.set b.o_s len c;\n b.o_len <- len + 1\n\nlet add_char2 b c1 c2 =\n let pos = alloc b 2 in\n let s = b.o_s in\n Bytes.unsafe_set s pos c1;\n Bytes.unsafe_set s (pos+1) c2\n\nlet add_char4 b c1 c2 c3 c4 =\n let pos = alloc b 4 in\n let s = b.o_s in\n Bytes.unsafe_set s pos c1;\n Bytes.unsafe_set s (pos+1) c2;\n Bytes.unsafe_set s (pos+2) c3;\n Bytes.unsafe_set s (pos+3) c4\n\n\n\nlet clear b =\n b.o_offs <- 0;\n b.o_len <- 0;\n Bi_share.Wr.clear b.o_shared\n\nlet reset b =\n if Bytes.length b.o_s <> b.o_init_len then\n b.o_s <- Bytes.create b.o_init_len;\n b.o_offs <- 0;\n b.o_len <- 0;\n b.o_shared <- Bi_share.Wr.create b.o_shared_init_len\n\nlet contents b = Bytes.sub_string b.o_s 0 b.o_len\n","type type_id = int\n\nlet dummy_type_id = 0\n\nlet create_type_id =\n let n = ref dummy_type_id in\n fun () ->\n incr n;\n if !n < 0 then\n failwith \"Bi_share.Rd_poly.create_type_id: \\\n exhausted available type_id's\"\n else\n !n\n\nmodule Wr =\nstruct\n module H = Hashtbl.Make (\n struct\n type t = Obj.t * type_id\n let equal (x1, t1) (x2, t2) = x1 == x2 && t1 == t2\n let hash = Hashtbl.hash\n end\n )\n\n type tbl = int H.t\n\n let create = H.create\n let clear tbl =\n if H.length tbl > 0 then\n H.clear tbl\n\n let put tbl k pos =\n try\n let pos0 = H.find tbl (Obj.magic k) in\n pos - pos0\n with Not_found ->\n H.add tbl (Obj.magic k) pos;\n 0\nend\n\nmodule Rd =\nstruct\n type tbl = ((int * type_id), Obj.t) Hashtbl.t\n\n let create n = Hashtbl.create n\n let clear = Hashtbl.clear\n\n let put tbl pos x =\n Hashtbl.add tbl pos x\n\n let get tbl pos =\n try Hashtbl.find tbl pos\n with Not_found ->\n Bi_util.error \"Corrupted data (invalid reference)\"\nend\n","include Ppx_deriving_runtime\n\nlet (>>=) x f =\n match x with Result.Ok x -> f x | (Result.Error _) as x -> x\n\nlet (>|=) x f =\n x >>= fun x -> Result.Ok (f x)\n\nlet rec map_bind f acc xs =\n match xs with\n | x :: xs -> f x >>= fun x -> map_bind f (x :: acc) xs\n | [] -> Result.Ok (List.rev acc)\n\ntype 'a error_or = ('a, string) Result.result\n\n(** [safe_map f l] returns the same value as [List.map f l], but\n computes it tail-recursively so that large list lengths don't\n cause a stack overflow *)\nlet safe_map f l = List.rev (List.rev_map f l)\n","(* This file is generated automatically with ocaml_gen. *)\n\nmodule BigInt256 = struct\n type nonrec t\n\n external of_numeral : string -> int -> int -> t = \"caml_bigint_256_of_numeral\"\n\n external of_decimal_string : string -> t = \"caml_bigint_256_of_decimal_string\"\n\n external num_limbs : unit -> int = \"caml_bigint_256_num_limbs\"\n\n external bytes_per_limb : unit -> int = \"caml_bigint_256_bytes_per_limb\"\n\n external div : t -> t -> t = \"caml_bigint_256_div\"\n\n external compare : t -> t -> int = \"caml_bigint_256_compare\"\n\n external print : t -> unit = \"caml_bigint_256_print\"\n\n external to_string : t -> string = \"caml_bigint_256_to_string\"\n\n external test_bit : t -> int -> bool = \"caml_bigint_256_test_bit\"\n\n external to_bytes : t -> bytes = \"caml_bigint_256_to_bytes\"\n\n external of_bytes : bytes -> t = \"caml_bigint_256_of_bytes\"\n\n external deep_copy : t -> t = \"caml_bigint_256_deep_copy\"\nend\n\nmodule Fp = struct\n type nonrec t\n\n external size_in_bits : unit -> int = \"caml_pasta_fp_size_in_bits\"\n\n external size : unit -> BigInt256.t = \"caml_pasta_fp_size\"\n\n external add : t -> t -> t = \"caml_pasta_fp_add\"\n\n external sub : t -> t -> t = \"caml_pasta_fp_sub\"\n\n external negate : t -> t = \"caml_pasta_fp_negate\"\n\n external mul : t -> t -> t = \"caml_pasta_fp_mul\"\n\n external div : t -> t -> t = \"caml_pasta_fp_div\"\n\n external inv : t -> t option = \"caml_pasta_fp_inv\"\n\n external square : t -> t = \"caml_pasta_fp_square\"\n\n external is_square : t -> bool = \"caml_pasta_fp_is_square\"\n\n external sqrt : t -> t option = \"caml_pasta_fp_sqrt\"\n\n external of_int : int -> t = \"caml_pasta_fp_of_int\"\n\n external to_string : t -> string = \"caml_pasta_fp_to_string\"\n\n external of_string : string -> t = \"caml_pasta_fp_of_string\"\n\n external print : t -> unit = \"caml_pasta_fp_print\"\n\n external copy : t -> t -> unit = \"caml_pasta_fp_copy\"\n\n external mut_add : t -> t -> unit = \"caml_pasta_fp_mut_add\"\n\n external mut_sub : t -> t -> unit = \"caml_pasta_fp_mut_sub\"\n\n external mut_mul : t -> t -> unit = \"caml_pasta_fp_mut_mul\"\n\n external mut_square : t -> unit = \"caml_pasta_fp_mut_square\"\n\n external compare : t -> t -> int = \"caml_pasta_fp_compare\"\n\n external equal : t -> t -> bool = \"caml_pasta_fp_equal\"\n\n external random : unit -> t = \"caml_pasta_fp_random\"\n\n external rng : int -> t = \"caml_pasta_fp_rng\"\n\n external to_bigint : t -> BigInt256.t = \"caml_pasta_fp_to_bigint\"\n\n external of_bigint : BigInt256.t -> t = \"caml_pasta_fp_of_bigint\"\n\n external two_adic_root_of_unity : unit -> t\n = \"caml_pasta_fp_two_adic_root_of_unity\"\n\n external domain_generator : int -> t = \"caml_pasta_fp_domain_generator\"\n\n external to_bytes : t -> bytes = \"caml_pasta_fp_to_bytes\"\n\n external of_bytes : bytes -> t = \"caml_pasta_fp_of_bytes\"\n\n external deep_copy : t -> t = \"caml_pasta_fp_deep_copy\"\nend\n\nmodule Fq = struct\n type nonrec t\n\n external size_in_bits : unit -> int = \"caml_pasta_fq_size_in_bits\"\n\n external size : unit -> BigInt256.t = \"caml_pasta_fq_size\"\n\n external add : t -> t -> t = \"caml_pasta_fq_add\"\n\n external sub : t -> t -> t = \"caml_pasta_fq_sub\"\n\n external negate : t -> t = \"caml_pasta_fq_negate\"\n\n external mul : t -> t -> t = \"caml_pasta_fq_mul\"\n\n external div : t -> t -> t = \"caml_pasta_fq_div\"\n\n external inv : t -> t option = \"caml_pasta_fq_inv\"\n\n external square : t -> t = \"caml_pasta_fq_square\"\n\n external is_square : t -> bool = \"caml_pasta_fq_is_square\"\n\n external sqrt : t -> t option = \"caml_pasta_fq_sqrt\"\n\n external of_int : int -> t = \"caml_pasta_fq_of_int\"\n\n external to_string : t -> string = \"caml_pasta_fq_to_string\"\n\n external of_string : string -> t = \"caml_pasta_fq_of_string\"\n\n external print : t -> unit = \"caml_pasta_fq_print\"\n\n external copy : t -> t -> unit = \"caml_pasta_fq_copy\"\n\n external mut_add : t -> t -> unit = \"caml_pasta_fq_mut_add\"\n\n external mut_sub : t -> t -> unit = \"caml_pasta_fq_mut_sub\"\n\n external mut_mul : t -> t -> unit = \"caml_pasta_fq_mut_mul\"\n\n external mut_square : t -> unit = \"caml_pasta_fq_mut_square\"\n\n external compare : t -> t -> int = \"caml_pasta_fq_compare\"\n\n external equal : t -> t -> bool = \"caml_pasta_fq_equal\"\n\n external random : unit -> t = \"caml_pasta_fq_random\"\n\n external rng : int -> t = \"caml_pasta_fq_rng\"\n\n external to_bigint : t -> BigInt256.t = \"caml_pasta_fq_to_bigint\"\n\n external of_bigint : BigInt256.t -> t = \"caml_pasta_fq_of_bigint\"\n\n external two_adic_root_of_unity : unit -> t\n = \"caml_pasta_fq_two_adic_root_of_unity\"\n\n external domain_generator : int -> t = \"caml_pasta_fq_domain_generator\"\n\n external to_bytes : t -> bytes = \"caml_pasta_fq_to_bytes\"\n\n external of_bytes : bytes -> t = \"caml_pasta_fq_of_bytes\"\n\n external deep_copy : t -> t = \"caml_pasta_fq_deep_copy\"\nend\n\nmodule Vesta = struct\n module BaseField = struct\n type nonrec t = Fq.t\n end\n\n module ScalarField = struct\n type nonrec t = Fp.t\n end\n\n module Affine = struct\n type nonrec t = Fq.t Kimchi_types.or_infinity\n end\n\n type nonrec t\n\n external one : unit -> t = \"caml_vesta_one\"\n\n external add : t -> t -> t = \"caml_vesta_add\"\n\n external sub : t -> t -> t = \"caml_vesta_sub\"\n\n external negate : t -> t = \"caml_vesta_negate\"\n\n external double : t -> t = \"caml_vesta_double\"\n\n external scale : t -> Fp.t -> t = \"caml_vesta_scale\"\n\n external random : unit -> t = \"caml_vesta_random\"\n\n external rng : int -> t = \"caml_vesta_rng\"\n\n external endo_base : unit -> Fq.t = \"caml_vesta_endo_base\"\n\n external endo_scalar : unit -> Fp.t = \"caml_vesta_endo_scalar\"\n\n external to_affine : t -> Fq.t Kimchi_types.or_infinity\n = \"caml_vesta_to_affine\"\n\n external of_affine : Fq.t Kimchi_types.or_infinity -> t\n = \"caml_vesta_of_affine\"\n\n external of_affine_coordinates : Fq.t -> Fq.t -> t\n = \"caml_vesta_of_affine_coordinates\"\n\n external deep_copy :\n Fq.t Kimchi_types.or_infinity -> Fq.t Kimchi_types.or_infinity\n = \"caml_vesta_affine_deep_copy\"\nend\n\nmodule Pallas = struct\n module BaseField = struct\n type nonrec t = Fp.t\n end\n\n module ScalarField = struct\n type nonrec t = Fq.t\n end\n\n module Affine = struct\n type nonrec t = Fp.t Kimchi_types.or_infinity\n end\n\n type nonrec t\n\n external one : unit -> t = \"caml_pallas_one\"\n\n external add : t -> t -> t = \"caml_pallas_add\"\n\n external sub : t -> t -> t = \"caml_pallas_sub\"\n\n external negate : t -> t = \"caml_pallas_negate\"\n\n external double : t -> t = \"caml_pallas_double\"\n\n external scale : t -> Fq.t -> t = \"caml_pallas_scale\"\n\n external random : unit -> t = \"caml_pallas_random\"\n\n external rng : int -> t = \"caml_pallas_rng\"\n\n external endo_base : unit -> Fp.t = \"caml_pallas_endo_base\"\n\n external endo_scalar : unit -> Fq.t = \"caml_pallas_endo_scalar\"\n\n external to_affine : t -> Fp.t Kimchi_types.or_infinity\n = \"caml_pallas_to_affine\"\n\n external of_affine : Fp.t Kimchi_types.or_infinity -> t\n = \"caml_pallas_of_affine\"\n\n external of_affine_coordinates : Fp.t -> Fp.t -> t\n = \"caml_pallas_of_affine_coordinates\"\n\n external deep_copy :\n Fp.t Kimchi_types.or_infinity -> Fp.t Kimchi_types.or_infinity\n = \"caml_pallas_affine_deep_copy\"\nend\n","open Core_kernel\n\ntype 'a t = 'a * 'a [@@deriving bin_io, sexp, eq, compare]\n\nlet map (x1, x2) ~f = (f x1, f x2)\n\nlet map2 (x1, x2) (y1, y2) ~f = (f x1 y1, f x2 y2)\n\nlet iter (x1, x2) ~f = f x1 ; f x2\n","open Core_kernel\n\nmodule type S = sig\n type 'a t [@@deriving bin_io, sexp, eq, compare]\n\n val iter : 'a t -> f:('a -> unit) -> unit\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val map2 : 'a t -> 'b t -> f:('a -> 'b -> 'c) -> 'c t\nend\n","open Core_kernel\n\ntype t = Zero | One | Two | Three [@@deriving sexp, eq, bin_io, hash]\n\nlet of_bits_lsb : bool Double.t -> t = function\n | false, false ->\n Zero\n | true, false ->\n One\n | false, true ->\n Two\n | true, true ->\n Three\n","open Core_kernel\n\ntype 'a t = 'a * 'a * 'a * 'a [@@deriving bin_io, sexp, eq, compare]\n\nlet get ((x0, x1, x2, x3) : 'a t) (i : Four.t) =\n match i with Zero -> x0 | One -> x1 | Two -> x2 | Three -> x3\n\nlet map (x1, x2, x3, x4) ~f = (f x1, f x2, f x3, f x4)\n\nlet map2 (x1, x2, x3, x4) (y1, y2, y3, y4) ~f =\n (f x1 y1, f x2 y2, f x3 y3, f x4 y4)\n\nlet iter (x1, x2, x3, x4) ~f = f x1 ; f x2 ; f x3 ; f x4\n","open Core_kernel\n\ntype 'a t = 'a * 'a * 'a [@@deriving bin_io, sexp, eq, compare]\n\nlet map (x1, x2, x3) ~f = (f x1, f x2, f x3)\n\nlet map2 (x1, x2, x3) (y1, y2, y3) ~f = (f x1 y1, f x2 y2, f x3 y3)\n\nlet iter (x1, x2, x3) ~f = f x1 ; f x2 ; f x3\n","module Double = Double\nmodule Triple = Triple\nmodule Quadruple = Quadruple\nmodule Four = Four\n","(* bits.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Fold_lib\nopen Bitstring_lib\n\n(* Someday: Make more efficient by giving Field.unpack a length argument in\n camlsnark *)\nlet unpack_field unpack ~bit_length x = List.take (unpack x) bit_length\n\nlet bits_per_char = 8\n\nlet pad (type a) ~length ~default (bs : a Bitstring.Lsb_first.t) =\n let bs = (bs :> a list) in\n let padding = length - List.length bs in\n assert (padding >= 0) ;\n bs @ List.init padding ~f:(fun _ -> default)\n\nmodule Vector = struct\n module type Basic = sig\n type t\n\n val length : int\n\n val get : t -> int -> bool\n\n val set : t -> int -> bool -> t\n end\n\n module type S = sig\n include Basic\n\n val empty : t\n\n val set : t -> int -> bool -> t\n end\n\n module UInt64 : S with type t = Unsigned.UInt64.t = struct\n open Unsigned.UInt64.Infix\n include Unsigned.UInt64\n\n let length = 64\n\n let empty = zero\n\n let get t i = equal ((t lsr i) land one) one\n\n let set t i b = if b then t lor (one lsl i) else t land lognot (one lsl i)\n end\n\n module UInt32 : S with type t = Unsigned.UInt32.t = struct\n open Unsigned.UInt32.Infix\n include Unsigned.UInt32\n\n let length = 32\n\n let empty = zero\n\n let get t i = equal ((t lsr i) land one) one\n\n let set t i b = if b then t lor (one lsl i) else t land lognot (one lsl i)\n end\n\n module Make (V : S) : Bits_intf.Convertible_bits with type t = V.t = struct\n type t = V.t\n\n let fold t =\n { Fold.fold =\n (fun ~init ~f ->\n let rec go acc i =\n if i = V.length then acc else go (f acc (V.get t i)) (i + 1)\n in\n go init 0 )\n }\n\n let iter t ~f =\n for i = 0 to V.length - 1 do\n f (V.get t i)\n done\n\n let to_bits t = List.init V.length ~f:(V.get t)\n\n let of_bits bools =\n List.foldi bools ~init:V.empty ~f:(fun i t bool -> V.set t i bool)\n\n let size_in_bits = V.length\n end\nend\n\nmodule UInt64 : Bits_intf.Convertible_bits with type t := Unsigned.UInt64.t =\n Vector.Make (Vector.UInt64)\n\nmodule UInt32 : Bits_intf.Convertible_bits with type t := Unsigned.UInt32.t =\n Vector.Make (Vector.UInt32)\n\n[%%ifdef consensus_mechanism]\n\nmodule type Big_int_intf = sig\n include Snarky_backendless.Bigint_intf.S\n\n val to_field : t -> field\nend\n\nmodule Make_field0\n (Field : Snarky_backendless.Field_intf.S)\n (Bigint : Big_int_intf with type field := Field.t) (M : sig\n val bit_length : int\n end) : Bits_intf.S with type t = Field.t = struct\n open M\n\n type t = Field.t\n\n let fold t =\n { Fold.fold =\n (fun ~init ~f ->\n let n = Bigint.of_field t in\n let rec go acc i =\n if i = bit_length then acc\n else go (f acc (Bigint.test_bit n i)) (i + 1)\n in\n go init 0 )\n }\n\n let iter t ~f =\n let n = Bigint.of_field t in\n for i = 0 to bit_length - 1 do\n f (Bigint.test_bit n i)\n done\n\n let to_bits t =\n let n = Bigint.of_field t in\n let rec go acc i =\n if i < 0 then acc else go (Bigint.test_bit n i :: acc) (i - 1)\n in\n go [] (bit_length - 1)\n\n let size_in_bits = bit_length\nend\n\nmodule Make_field\n (Field : Snarky_backendless.Field_intf.S)\n (Bigint : Big_int_intf with type field := Field.t) :\n Bits_intf.S with type t = Field.t =\n Make_field0 (Field) (Bigint)\n (struct\n let bit_length = Field.size_in_bits\n end)\n\nmodule Small\n (Field : Snarky_backendless.Field_intf.S)\n (Bigint : Big_int_intf with type field := Field.t) (M : sig\n val bit_length : int\n end) : Bits_intf.S with type t = Field.t = struct\n let () = assert (M.bit_length < Field.size_in_bits)\n\n include Make_field0 (Field) (Bigint) (M)\nend\n\nmodule Snarkable = struct\n module Small_bit_vector\n (Impl : Snarky_backendless.Snark_intf.S) (V : sig\n type t\n\n val empty : t\n\n val length : int\n\n val get : t -> int -> bool\n\n val set : t -> int -> bool -> t\n end) :\n Bits_intf.Snarkable.Small\n with type ('a, 'b) typ := ('a, 'b) Impl.Typ.t\n and type 'a checked := 'a Impl.Checked.t\n and type boolean_var := Impl.Boolean.var\n and type field_var := Impl.Field.Var.t\n and type Packed.var = Impl.Field.Var.t\n and type Packed.value = V.t\n and type Unpacked.var = Impl.Boolean.var list\n and type Unpacked.value = V.t\n and type comparison_result := Impl.Field.Checked.comparison_result =\n struct\n open Impl\n\n let bit_length = V.length\n\n let () = assert (bit_length < Field.size_in_bits)\n\n let size_in_bits = bit_length\n\n let init ~f =\n let rec go acc i =\n if i = V.length then acc else go (V.set acc i (f i)) (i + 1)\n in\n go V.empty 0\n\n module Packed = struct\n type var = Field.Var.t\n\n type value = V.t\n\n let typ : (var, value) Typ.t =\n Field.typ\n |> Typ.transport\n ~there:(fun t ->\n let rec go two_to_the_i i acc =\n if i = V.length then acc\n else\n let acc =\n if V.get t i then Field.add two_to_the_i acc else acc\n in\n go (Field.add two_to_the_i two_to_the_i) (i + 1) acc\n in\n go Field.one 0 Field.zero )\n ~back:(fun t ->\n let n = Bigint.of_field t in\n init ~f:(fun i -> Bigint.test_bit n i) )\n\n let size_in_bits = size_in_bits\n end\n\n let v_to_list n v =\n List.init n ~f:(fun i -> if i < V.length then V.get v i else false)\n\n let v_of_list vs =\n List.foldi vs ~init:V.empty ~f:(fun i acc b ->\n if i < V.length then V.set acc i b else acc )\n\n let pack_var = Field.Var.project\n\n let pack_value = Fn.id\n\n module Unpacked = struct\n type var = Boolean.var list\n\n type value = V.t\n\n let typ : (var, value) Typ.t =\n Typ.transport\n (Typ.list ~length:V.length Boolean.typ)\n ~there:(v_to_list V.length) ~back:v_of_list\n\n let var_to_bits = Bitstring.Lsb_first.of_list\n\n let var_of_bits = pad ~length:V.length ~default:Boolean.false_\n\n let var_to_triples (bs : var) =\n Bitstring_lib.Bitstring.pad_to_triple_list ~default:Boolean.false_ bs\n\n let var_of_value v =\n List.init V.length ~f:(fun i -> Boolean.var_of_value (V.get v i))\n\n let size_in_bits = size_in_bits\n end\n\n let unpack_var x = Impl.Field.Checked.unpack x ~length:bit_length\n\n let var_of_field = unpack_var\n\n let var_of_field_unsafe = Fn.id\n\n let unpack_value (x : Packed.value) : Unpacked.value = x\n\n let compare_var x y =\n Impl.Field.Checked.compare ~bit_length:V.length (pack_var x) (pack_var y)\n\n let%snarkydef_ increment_if_var bs (b : Boolean.var) =\n let open Impl in\n let v = Field.Var.pack bs in\n let v' = Field.Var.add v (b :> Field.Var.t) in\n Field.Checked.unpack v' ~length:V.length\n\n let%snarkydef_ increment_var bs =\n let open Impl in\n let v = Field.Var.pack bs in\n let v' = Field.Var.add v (Field.Var.constant Field.one) in\n Field.Checked.unpack v' ~length:V.length\n\n let%snarkydef_ equal_var (n : Unpacked.var) (n' : Unpacked.var) =\n Field.Checked.equal (pack_var n) (pack_var n')\n\n let%snarkydef_ assert_equal_var (n : Unpacked.var) (n' : Unpacked.var) =\n Field.Checked.Assert.equal (pack_var n) (pack_var n')\n\n let if_ (cond : Boolean.var) ~(then_ : Unpacked.var) ~(else_ : Unpacked.var)\n : Unpacked.var Checked.t =\n match\n List.map2 then_ else_ ~f:(fun then_ else_ ->\n Boolean.if_ cond ~then_ ~else_ )\n with\n | Ok result ->\n Checked.List.all result\n | Unequal_lengths ->\n failwith \"Bits.if_: unpacked bit lengths were unequal\"\n end\n\n module UInt64 (Impl : Snarky_backendless.Snark_intf.S) =\n Small_bit_vector (Impl) (Vector.UInt64)\n module UInt32 (Impl : Snarky_backendless.Snark_intf.S) =\n Small_bit_vector (Impl) (Vector.UInt32)\n\n module Field_backed\n (Impl : Snarky_backendless.Snark_intf.S) (M : sig\n val bit_length : int\n end) =\n struct\n open Impl\n include M\n\n let size_in_bits = bit_length\n\n module Packed = struct\n type var = Field.Var.t\n\n type value = Field.t\n\n let typ = Typ.field\n\n let assert_equal = Field.Checked.Assert.equal\n\n let size_in_bits = size_in_bits\n end\n\n module Unpacked = struct\n type var = Boolean.var list\n\n type value = Field.t\n\n let typ : (var, value) Typ.t =\n Typ.transport\n (Typ.list ~length:bit_length Boolean.typ)\n ~there:(unpack_field Field.unpack ~bit_length)\n ~back:Field.project\n\n let var_to_bits = Bitstring_lib.Bitstring.Lsb_first.of_list\n\n let var_of_bits = pad ~length:bit_length ~default:Boolean.false_\n\n let var_to_triples (bs : var) =\n Bitstring_lib.Bitstring.pad_to_triple_list ~default:Boolean.false_ bs\n\n let var_of_value v =\n unpack_field Field.unpack ~bit_length v\n |> List.map ~f:Boolean.var_of_value\n\n let size_in_bits = size_in_bits\n end\n\n let project_value = Fn.id\n\n let project_var = Field.Var.project\n\n let choose_preimage_var : Packed.var -> Unpacked.var Checked.t =\n Field.Checked.choose_preimage_var ~length:bit_length\n\n let unpack_value = Fn.id\n end\n\n module Field (Impl : Snarky_backendless.Snark_intf.S) :\n Bits_intf.Snarkable.Lossy\n with type ('a, 'b) typ := ('a, 'b) Impl.Typ.t\n and type 'a checked := 'a Impl.Checked.t\n and type boolean_var := Impl.Boolean.var\n and type Packed.var = Impl.Field.Var.t\n and type Packed.value = Impl.Field.t\n and type Unpacked.var = Impl.Boolean.var list\n and type Unpacked.value = Impl.Field.t =\n Field_backed\n (Impl)\n (struct\n let bit_length = Impl.Field.size_in_bits\n end)\n\n module Small\n (Impl : Snarky_backendless.Snark_intf.S) (M : sig\n val bit_length : int\n end) :\n Bits_intf.Snarkable.Faithful\n with type ('a, 'b) typ := ('a, 'b) Impl.Typ.t\n and type 'a checked := 'a Impl.Checked.t\n and type boolean_var := Impl.Boolean.var\n and type Packed.var = Impl.Field.Var.t\n and type Packed.value = Impl.Field.t\n and type Unpacked.var = Impl.Boolean.var list\n and type Unpacked.value = Impl.Field.t = struct\n let () = assert (M.bit_length < Impl.Field.size_in_bits)\n\n include Field_backed (Impl) (M)\n\n let pack_var bs =\n assert (Mina_stdlib.List.Length.Compare.(bs = M.bit_length)) ;\n project_var bs\n\n let pack_value = Fn.id\n\n let unpack_var = Impl.Field.Checked.unpack ~length:M.bit_length\n end\nend\n\nmodule Make_unpacked\n (Impl : Snarky_backendless.Snark_intf.S) (M : sig\n val bit_length : int\n end) =\nstruct\n open Impl\n\n module T = struct\n type var = Boolean.var list\n\n type value = Boolean.value list\n end\n\n include T\n\n let typ : (var, value) Typ.t = Typ.list ~length:M.bit_length Boolean.typ\nend\n\n[%%endif]\n","open Core_kernel\n\nmodule Interval = struct\n (* Semantically (a, b) : t is the closed interval [a, b] *)\n type t = int * int [@@deriving eq, sexp]\n\n let before (_, b1) (a2, _) = b1 <= a2\n\n let gen_from start =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = Int.gen_incl start Int.max_value_30_bits in\n let%map y = Int.gen_incl x Int.max_value_30_bits in\n (x, y)\n\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let%bind x = Int.gen_incl Int.min_value Int.max_value_30_bits in\n let%map y = Int.gen_incl x Int.max_value_30_bits in\n (x, y)\n\n let%test_unit \"gen is correct\" =\n Quickcheck.test gen ~f:(fun (x, y) -> assert (x <= y))\nend\n\n(* Simplest possible implementation. Should be an increasing list of\n disjoint intervals.\n Semantically is the set of ints corresponding to the union of these\n ntervals. *)\ntype t = Interval.t list [@@deriving eq, sexp]\n\nlet empty : t = []\n\nlet union_intervals_exn (a1, b1) (a2, b2) =\n let ( = ) = Int.( = ) in\n if b1 = a2 then `Combine (a1, b2)\n else if b2 = a1 then `Combine (a2, b1)\n else if b1 < a2 then `Disjoint_ordered\n else if b2 < a1 then `Disjoint_inverted\n else failwithf \"Intervals not disjoint: (%d, %d) and (%d, %d)\" a1 b1 a2 b2 ()\n\nlet of_interval i = [ i ]\n\nlet rec canonicalize = function\n | [] ->\n []\n | [ i1 ] ->\n [ i1 ]\n | (a1, a2) :: (a3, a4) :: t ->\n if a2 = a3 then canonicalize ((a1, a4) :: t)\n else (a1, a2) :: canonicalize ((a3, a4) :: t)\n\nlet rec disjoint_union_exn t1 t2 =\n match (t1, t2) with\n | t, [] | [], t ->\n t\n | i1 :: t1', i2 :: t2' -> (\n match union_intervals_exn i1 i2 with\n | `Combine (a, b) ->\n (a, b) :: disjoint_union_exn t1' t2'\n | `Disjoint_ordered ->\n i1 :: disjoint_union_exn t1' t2\n | `Disjoint_inverted ->\n i2 :: disjoint_union_exn t1 t2' )\n\nlet disjoint_union_exn t1 t2 = canonicalize (disjoint_union_exn t1 t2)\n\nlet rec disjoint t1 t2 =\n match (t1, t2) with\n | _, [] | [], _ ->\n true\n | i1 :: t1', i2 :: t2' ->\n if Interval.before i1 i2 then disjoint t1' t2\n else if Interval.before i2 i1 then disjoint t1 t2'\n else false\n\n(* Someday: inefficient *)\nlet of_intervals_exn is =\n match is with\n | [] ->\n []\n | i :: is ->\n List.fold is ~init:(of_interval i) ~f:(fun acc x ->\n disjoint_union_exn (of_interval x) acc )\n\nlet to_interval = function\n | [ i ] ->\n Ok i\n | [] ->\n Or_error.error_string \"Interval_union.to_interval: the union is empty\\n\"\n | _ :: _ :: _ as xs ->\n Or_error.error_string\n (Printf.sprintf\n !\"Interval_union.to_interval: expected a single interval in the \\\n union, got multiple disjoint intervals %{sexp: Interval.t list}\\n\"\n xs )\n\nlet right_endpoint t = Option.map ~f:snd (List.last t)\n\nlet left_endpoint t = Option.map ~f:fst (List.hd t)\n\nlet invariant t =\n let rec go = function\n | [ (a, b) ] ->\n assert (a <= b)\n | [] ->\n ()\n | (a1, b1) :: ((a2, _) :: _ as t) ->\n assert (a1 <= b1) ;\n assert (b1 < a2) ;\n go t\n in\n go t\n\nlet gen_from ?(min_size = 0) start =\n let open Quickcheck.Generator.Let_syntax in\n let rec go acc size start =\n if size = 0 then return (of_intervals_exn (List.rev acc))\n else\n let%bind ((_, y) as i) = Interval.gen_from start in\n go (i :: acc) (size - 1) y\n in\n let%bind size = Quickcheck.Generator.small_positive_int in\n go [] (min_size + size) start\n\nlet gen = gen_from Int.min_value\n\nlet%test_unit \"check invariant\" = Quickcheck.test gen ~f:invariant\n\nlet gen_disjoint_pair =\n let open Quickcheck.Generator.Let_syntax in\n let%bind t1 = gen in\n let y = List.last_exn t1 |> snd in\n let%map t2 = gen_from y in\n (t1, t2)\n\nlet%test_unit \"canonicalize\" =\n assert (equal (canonicalize [ (1, 2); (2, 3) ]) [ (1, 3) ])\n\nlet%test_unit \"disjoint union doesn't care about order\" =\n Quickcheck.test gen_disjoint_pair ~f:(fun (a, b) ->\n assert (equal (disjoint_union_exn a b) (disjoint_union_exn b a)) )\n\nlet%test_unit \"check invariant on disjoint union\" =\n Quickcheck.test gen_disjoint_pair ~f:(fun (a, b) ->\n invariant (disjoint_union_exn a b) )\n\nlet%test_unit \"disjoint_union works with holes\" =\n let gen =\n let open Quickcheck.Generator.Let_syntax in\n let s = 1000000 in\n let%bind y0 = Int.gen_incl 0 s in\n let%bind y1 = Int.gen_incl (y0 + 1) (y0 + s) in\n let%bind y2 = Int.gen_incl (y1 + 1) (y1 + s) in\n let%bind y3 = Int.gen_incl (y2 + 1) (y2 + s) in\n return (of_interval (y1, y2), of_intervals_exn [ (y0, y1); (y2, y3) ])\n in\n Quickcheck.test gen ~f:(fun (x, y) -> invariant (disjoint_union_exn x y))\n","open Core_kernel\n\ntype t = Big_int.big_int\n\nlet equal = Big_int.eq_big_int\n\nlet num_bits = Big_int.num_bits_big_int\n\nlet shift_right = Big_int.shift_right_big_int\n\nlet shift_left = Big_int.shift_left_big_int\n\nlet log_and = Big_int.and_big_int\n\nlet log_or = Big_int.or_big_int\n\nlet of_int = Big_int.big_int_of_int\n\nlet test_bit t i =\n equal (log_and Big_int.unit_big_int (shift_right t i)) Big_int.unit_big_int\n\nlet to_bytes x =\n let n = num_bits x in\n let num_bytes = (n + 7) / 8 in\n String.init num_bytes ~f:(fun byte ->\n let c i =\n let bit = (8 * byte) + i in\n if test_bit x bit then 1 lsl i else 0\n in\n Char.of_int_exn\n (c 0 lor c 1 lor c 2 lor c 3 lor c 4 lor c 5 lor c 6 lor c 7) )\n\nlet of_bytes x =\n String.foldi x ~init:Big_int.zero_big_int ~f:(fun i acc c ->\n log_or acc (shift_left (of_int (Char.to_int c)) (8 * i)) )\n\nlet ( + ) = Big_int.add_big_int\n\nlet ( - ) = Big_int.sub_big_int\n\nlet ( * ) = Big_int.mult_big_int\n\nlet ( % ) = Big_int.mod_big_int\n\nlet ( // ) = Big_int.div_big_int\n\nlet ( < ) = Big_int.lt_big_int\n\nlet to_int_exn = Big_int.int_of_big_int\n\nlet compare = Big_int.compare_big_int\n\nmodule String_hum = struct\n type nonrec t = t\n\n let of_string = Big_int.big_int_of_string\n\n let to_string = Big_int.string_of_big_int\nend\n\ninclude Sexpable.Of_stringable (String_hum)\n\ninclude (String_hum : Stringable.S with type t := t)\n\nlet hash t = Stdlib.Hashtbl.hash t\n\nlet hash_fold_t h t = hash_fold_int h (hash t)\n\nlet to_yojson t = `String (to_string t)\n\nlet of_yojson = function\n | `String s ->\n Ok (of_string s)\n | _ ->\n Error \"Nat.of_yojson: Expected string\"\n\n[@@@alert \"-legacy\"]\n\n(** this serialization is not used for fields *)\ninclude Binable.Of_stringable_without_uuid (struct\n type nonrec t = t\n\n let of_string = of_bytes\n\n let to_string = to_bytes\nend)\n","type ('var, 'value) t = { var : 'var; mutable value : 'value option }\n\nlet var { var; _ } = var\n","(** The usual Janestreet [Monad] interfaces, with [Let_syntax] included in the\n monad module. *)\nopen Core_kernel\n\nopen Monad\n\nmodule type Let_syntax = sig\n type 'a t\n\n val return : 'a -> 'a t\n\n val bind : 'a t -> f:('a -> 'b t) -> 'b t\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val both : 'a t -> 'b t -> ('a * 'b) t\n\n module Open_on_rhs : sig end\nend\n\nmodule type Base_syntax = sig\n type 'a t\n\n val return : 'a -> 'a t\n\n include Infix with type 'a t := 'a t\nend\n\nmodule type Syntax = sig\n include Base_syntax\n\n include Let_syntax with type 'a t := 'a t\nend\n\nmodule type S = sig\n type 'a t\n\n include S_without_syntax with type 'a t := 'a t\n\n module Let_syntax : sig\n include Base_syntax with type 'a t := 'a t\n\n include Let_syntax with type 'a t := 'a t\n\n module Let_syntax : Let_syntax with type 'a t := 'a t\n end\nend\n\nmodule type Let_syntax2 = sig\n type ('a, 'e) t\n\n val return : 'a -> ('a, 'e) t\n\n val bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t\n\n val map : ('a, 'e) t -> f:('a -> 'b) -> ('b, 'e) t\n\n val both : ('a, 'e) t -> ('b, 'e) t -> ('a * 'b, 'e) t\n\n module Open_on_rhs : sig end\nend\n\nmodule type Base_syntax2 = sig\n type ('a, 'e) t\n\n val return : 'a -> ('a, 'e) t\n\n include Infix2 with type ('a, 'e) t := ('a, 'e) t\nend\n\nmodule type Syntax2 = sig\n include Base_syntax2\n\n include Let_syntax2 with type ('a, 'e) t := ('a, 'e) t\nend\n\nmodule type S_without_syntax2 = sig\n type ('a, 'e) t\n\n include Infix2 with type ('a, 'e) t := ('a, 'e) t\n\n module Monad_infix : Infix2 with type ('a, 'e) t := ('a, 'e) t\n\n val bind : ('a, 'e) t -> f:('a -> ('b, 'e) t) -> ('b, 'e) t\n\n val return : 'a -> ('a, _) t\n\n val map : ('a, 'e) t -> f:('a -> 'b) -> ('b, 'e) t\n\n val join : (('a, 'e) t, 'e) t -> ('a, 'e) t\n\n val ignore_m : (_, 'e) t -> (unit, 'e) t\n\n val all : ('a, 'e) t list -> ('a list, 'e) t\n\n val all_unit : (unit, 'e) t list -> (unit, 'e) t\nend\n\nmodule type S2 = sig\n type ('a, 'e) t\n\n include S_without_syntax2 with type ('a, 'e) t := ('a, 'e) t\n\n module Let_syntax : sig\n include Base_syntax2 with type ('a, 'e) t := ('a, 'e) t\n\n include Let_syntax2 with type ('a, 'e) t := ('a, 'e) t\n\n module Let_syntax : Let_syntax2 with type ('a, 'e) t := ('a, 'e) t\n end\nend\n\nmodule type Let_syntax3 = sig\n type ('a, 'd, 'e) t\n\n val return : 'a -> ('a, 'd, 'e) t\n\n val bind : ('a, 'd, 'e) t -> f:('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n\n val map : ('a, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'd, 'e) t\n\n val both : ('a, 'd, 'e) t -> ('b, 'd, 'e) t -> ('a * 'b, 'd, 'e) t\n\n module Open_on_rhs : sig end\nend\n\nmodule type Base_syntax3 = sig\n type ('a, 'd, 'e) t\n\n val return : 'a -> ('a, 'd, 'e) t\n\n include Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\nend\n\nmodule type Syntax3 = sig\n include Base_syntax3\n\n include Let_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\nend\n\nmodule type S_without_syntax3 = sig\n type ('a, 'd, 'e) t\n\n include Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n module Monad_infix : Infix3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n val bind : ('a, 'd, 'e) t -> f:('a -> ('b, 'd, 'e) t) -> ('b, 'd, 'e) t\n\n val return : 'a -> ('a, _, _) t\n\n val map : ('a, 'd, 'e) t -> f:('a -> 'b) -> ('b, 'd, 'e) t\n\n val join : (('a, 'd, 'e) t, 'd, 'e) t -> ('a, 'd, 'e) t\n\n val ignore_m : (_, 'd, 'e) t -> (unit, 'd, 'e) t\n\n val all : ('a, 'd, 'e) t list -> ('a list, 'd, 'e) t\n\n val all_unit : (unit, 'd, 'e) t list -> (unit, 'd, 'e) t\nend\n\nmodule type S3 = sig\n type ('a, 'd, 'e) t\n\n include S_without_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n module Let_syntax : sig\n include Base_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n include Let_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n\n module Let_syntax : Let_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t\n end\nend\n\nmodule Make3 (X : Monad.Basic3) :\n S3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) X.t = struct\n include X\n module M = Monad.Make3 (X)\n module Let = M.Let_syntax.Let_syntax\n\n [@@@warning \"-3\"]\n\n include (M : S_without_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t)\n\n module Let_syntax = struct\n include (\n M.Let_syntax : Base_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t )\n\n include (Let : Let_syntax3 with type ('a, 'd, 'e) t := ('a, 'd, 'e) t)\n\n module Let_syntax = Let\n end\nend\n\nmodule Make2 (X : Monad.Basic2) : S2 with type ('a, 'e) t := ('a, 'e) X.t =\nMake3 (struct\n type ('a, 'd, 'e) t = ('a, 'e) X.t\n\n include (X : Monad.Basic3 with type ('a, 'd, 'e) t := ('a, 'e) X.t)\nend)\n\nmodule Make (X : Monad.Basic) : S with type 'a t := 'a X.t = Make2 (struct\n type ('a, 'e) t = 'a X.t\n\n include (X : Monad.Basic2 with type ('a, 'e) t := 'a X.t)\nend)\n","type _ t = ..\n\ntype _ t += Fail : 'a t\n\ntype 'a req = 'a t\n\ntype response = ..\n\ntype response += Unhandled\n\nlet unhandled = Unhandled\n\nmodule Response = struct\n type 'a t = Provide of 'a | Delegate of 'a req | Unhandled\nend\n\ntype request =\n | With : { request : 'a t; respond : 'a Response.t -> response } -> request\n\nmodule Handler = struct\n type single = { handle : 'a. 'a t -> 'a Response.t }\n\n type t = single list\n\n let fail = []\n\n let run : t -> string list -> 'a req -> 'a =\n fun stack0 label_stack req0 ->\n let rec go req = function\n | [] ->\n failwith\n ( \"Unhandled request: \"\n ^ Core_kernel.String.concat ~sep:\"\\n\" label_stack )\n | { handle } :: hs -> (\n match handle req with\n | Provide x ->\n x\n | Delegate req' ->\n go req' hs\n | Unhandled ->\n go req hs )\n in\n go req0 stack0\n\n let create_single (handler : request -> response) : single =\n let handle : type a. a req -> a Response.t =\n fun request ->\n let module T = struct\n type response += T of a Response.t\n end in\n match handler (With { request; respond = (fun x -> T.T x) }) with\n | T.T x ->\n x\n | _ ->\n Response.Unhandled\n in\n { handle }\n\n let push (t : t) (single : single) : t = single :: t\nend\n","open Core_kernel\n\nmodule Make (Field : sig\n type t [@@deriving sexp]\n\n val equal : t -> t -> bool\nend)\n(Basic : Checked_intf.Basic with type 'f field = Field.t)\n(As_prover : As_prover_intf.Basic with type 'f field := 'f Basic.field) :\n Checked_intf.S\n with module Types = Basic.Types\n with type 'f field = 'f Basic.field = struct\n include Basic\n\n let request_witness (typ : ('var, 'value, 'f field) Types.Typ.t)\n (r : ('value Request.t, 'f field) As_prover.t) =\n let%map h = exists typ (Request r) in\n Handle.var h\n\n let request ?such_that typ r =\n match such_that with\n | None ->\n request_witness typ (As_prover.return r)\n | Some such_that ->\n let open Let_syntax in\n let%bind x = request_witness typ (As_prover.return r) in\n let%map () = such_that x in\n x\n\n let exists_handle ?request ?compute typ =\n let provider =\n let request =\n Option.value request ~default:(As_prover.return Request.Fail)\n in\n match compute with\n | None ->\n Types.Provider.Request request\n | Some c ->\n Types.Provider.Both (request, c)\n in\n exists typ provider\n\n let exists ?request ?compute typ =\n let%map h = exists_handle ?request ?compute typ in\n Handle.var h\n\n type response = Request.response\n\n let unhandled = Request.unhandled\n\n type request = Request.request =\n | With :\n { request : 'a Request.t; respond : 'a Request.Response.t -> response }\n -> request\n\n let handle t k = with_handler (Request.Handler.create_single k) t\n\n let handle_as_prover t k =\n let handler = ref None in\n let%bind () =\n as_prover\n As_prover.(\n let%map h = k in\n handler := Some h)\n in\n handle t (fun request -> (Option.value_exn !handler) request)\n\n let assert_ ?label c = add_constraint (Constraint.override_label c label)\n\n let assert_r1cs ?label a b c = assert_ (Constraint.r1cs ?label a b c)\n\n let assert_square ?label a c = assert_ (Constraint.square ?label a c)\n\n let assert_all ?label cs =\n List.fold_right cs ~init:(return ()) ~f:(fun c (acc : _ t) ->\n bind acc ~f:(fun () ->\n add_constraint (Constraint.override_label c label) ) )\n\n let assert_equal ?label x y =\n match (x, y) with\n | Cvar.Constant x, Cvar.Constant y ->\n if Field.equal x y then return ()\n else\n failwithf !\"assert_equal: %{sexp: Field.t} != %{sexp: Field.t}\" x y ()\n | _ ->\n assert_ (Constraint.equal ?label x y)\nend\n","module As_prover = struct\n type ('a, 'f) t = ('f Cvar.t -> 'f) -> 'a\nend\n\nmodule Provider = struct\n module T = struct\n (** The different ways to generate a value for the circuit witness.\n\n If [Both], this attempts the request first, and falls back on compute\n if the request is unhandled or raises an exception.\n *)\n type ('request, 'compute) provider =\n | Request of 'request\n | Compute of 'compute\n | Both of 'request * 'compute\n end\n\n include T\n\n type ('request, 'compute) t = ('request, 'compute) provider\nend\n\nmodule Typ = struct\n module T = struct\n (** The type [('var, 'value, 'field, 'checked) t] describes a mapping from\n OCaml types to the variables and constraints they represent:\n - ['value] is the OCaml type\n - ['field] is the type of the field elements\n - ['var] is some other type that contains some R1CS variables\n - ['checked] is the type of checked computation that verifies the stored\n contents as R1CS variables.\n\n For convenience and readability, it is usually best to have the ['var]\n type mirror the ['value] type in structure, for example:\n{[\n type t = {b1 : bool; b2 : bool} (* 'value *)\n\n let or (x : t) = x.b1 || x.b2\n\n module Checked = struct\n type t = {b1 : Snark.Boolean.var; b2 : Snark.Boolean.var} (* 'var *)\n\n let or (x : t) = Snark.Boolean.(x.b1 || x.b2)\n end\n]}*)\n type ('var, 'value, 'aux, 'field, 'checked) typ' =\n { var_to_fields : 'var -> 'field Cvar.t array * 'aux\n ; var_of_fields : 'field Cvar.t array * 'aux -> 'var\n ; value_to_fields : 'value -> 'field array * 'aux\n ; value_of_fields : 'field array * 'aux -> 'value\n ; size_in_field_elements : int\n ; constraint_system_auxiliary : unit -> 'aux\n ; check : 'var -> 'checked\n }\n\n type ('var, 'value, 'field, 'checked) typ =\n | Typ :\n ('var, 'value, 'aux, 'field, 'checked) typ'\n -> ('var, 'value, 'field, 'checked) typ\n end\n\n include T\n\n type ('var, 'value, 'field, 'checked) t = ('var, 'value, 'field, 'checked) typ\nend\n\nmodule type Types = sig\n module Checked : sig\n type ('a, 'f) t\n end\n\n module Typ : sig\n include module type of Typ.T\n\n type ('var, 'value, 'f) t = ('var, 'value, 'f, (unit, 'f) Checked.t) Typ.t\n end\n\n module Provider : sig\n include module type of Provider.T\n\n type ('a, 'f) t =\n (('a Request.t, 'f) As_prover.t, ('a, 'f) As_prover.t) provider\n end\nend\n","open Core_kernel\n\ntype ('a, 'f) t = ('a, 'f) Types.As_prover.t\n\nlet map t ~f tbl =\n let x = t tbl in\n f x\n\nlet bind t ~f tbl =\n let x = t tbl in\n f x tbl\n\nlet return x _ = x\n\nlet run t tbl = t tbl\n\nlet get_state _tbl s = (s, s)\n\nlet set_state s _tbl _ = (s, ())\n\nlet modify_state f _tbl s = (f s, ())\n\nlet map2 x y ~f tbl =\n let x = x tbl in\n let y = y tbl in\n f x y\n\nlet read_var (v : 'var) : ('field, 'field) t = fun tbl -> tbl v\n\nlet read\n (Typ { var_to_fields; value_of_fields; _ } :\n ('var, 'value, 'field, _) Types.Typ.t ) (var : 'var) : ('value, 'field) t\n =\n fun tbl ->\n let field_vars, aux = var_to_fields var in\n let fields = Array.map ~f:tbl field_vars in\n value_of_fields (fields, aux)\n\ninclude Monad_let.Make2 (struct\n type nonrec ('a, 'e) t = ('a, 'e) t\n\n let map = `Custom map\n\n let bind = bind\n\n let return = return\nend)\n\nmodule Provider = struct\n (** The different ways to generate a value of type ['a] for a circuit\n witness over field ['f].\n\n This is one of:\n * a [Request], dispatching an ['a Request.t];\n * [Compute], running a computation to generate the value;\n * [Both], attempting to dispatch an ['a Request.t], and falling back to\n the computation if the request is unhandled or raises an exception.\n *)\n type nonrec ('a, 'f) t = (('a Request.t, 'f) t, ('a, 'f) t) Types.Provider.t\n\n open Types.Provider\n\n let run t stack tbl (handler : Request.Handler.t) =\n match t with\n | Request rc ->\n let r = run rc tbl in\n Request.Handler.run handler stack r\n | Compute c ->\n run c tbl\n | Both (rc, c) -> (\n let r = run rc tbl in\n match Request.Handler.run handler stack r with\n | exception _ ->\n run c tbl\n | x ->\n x )\nend\n\nmodule Handle = struct\n let value (t : ('var, 'value) Handle.t) : ('value, 'field) t =\n fun _ -> Option.value_exn t.value\nend\n\nmodule type Extended = sig\n type field\n\n include As_prover_intf.Basic with type 'f field := field\n\n type nonrec 'a t = ('a, field) t\nend\n\nmodule Make_extended (Env : sig\n type field\nend)\n(As_prover : As_prover_intf.Basic with type 'f field := Env.field) =\nstruct\n include Env\n include As_prover\n\n type nonrec 'a t = ('a, field) t\nend\n","module Vector = struct\n open Core_kernel\n\n type 'elt t =\n | T :\n (module Snarky_intf.Vector.S with type elt = 'elt and type t = 't)\n * 't Type_equal.Id.t\n * 't\n -> 'elt t\n\n let unit = Type_equal.Id.create ~name:\"unit\" Unit.sexp_of_t\n\n let null : type a. a t =\n let module T = struct\n type elt = a\n\n type t = unit\n\n let create () = ()\n\n let get _ _ = failwith \"Vector.null: get\"\n\n let emplace_back _ _ = failwith \"Vector.null: emplace_back\"\n\n let length () = 0\n end in\n T ((module T), unit, ())\n\n let get (type x) (T ((module T), _, t) : x t) i = T.get t i\n\n let emplace_back (type x) (T ((module T), _, t) : x t) x = T.emplace_back t x\nend\n\n(** The internal state used to run a checked computation. *)\ntype 'field t =\n { system : 'field Constraint_system.t option\n ; input : 'field Vector.t\n ; aux : 'field Vector.t\n ; eval_constraints : bool\n ; num_inputs : int\n ; next_auxiliary : int ref\n ; has_witness : bool\n ; stack : string list\n ; handler : Request.Handler.t\n ; is_running : bool\n ; as_prover : bool ref\n ; log_constraint :\n ( ?at_label_boundary:[ `Start | `End ] * string\n -> ('field Cvar.t, 'field) Constraint.t option\n -> unit )\n option\n }\n\nlet make ~num_inputs ~input ~next_auxiliary ~aux ?system ~eval_constraints\n ?log_constraint ?handler ~with_witness ?(stack = []) ?(is_running = true) ()\n =\n next_auxiliary := num_inputs ;\n (* We can't evaluate the constraints if we are not computing over a value. *)\n let eval_constraints = eval_constraints && with_witness in\n { system\n ; input\n ; aux\n ; eval_constraints\n ; num_inputs\n ; next_auxiliary\n ; has_witness = with_witness\n ; stack\n ; handler = Option.value handler ~default:Request.Handler.fail\n ; is_running\n ; as_prover = ref false\n ; log_constraint\n }\n\nlet dump (t : _ t) =\n Format.sprintf\n \"state { is_running: %B; as_prover: %B; has_witness: %B; eval_constraints: \\\n %B; num_inputs: %d; next_auxiliary: %d }\\n\"\n t.is_running !(t.as_prover) t.has_witness t.eval_constraints t.num_inputs\n !(t.next_auxiliary)\n\nlet get_variable_value { num_inputs; input; aux; _ } : int -> 'field =\n fun i ->\n if i < num_inputs then Vector.get input i else Vector.get aux (i - num_inputs)\n\nlet store_field_elt { next_auxiliary; aux; _ } x =\n let v = !next_auxiliary in\n incr next_auxiliary ; Vector.emplace_back aux x ; Cvar.Unsafe.of_index v\n\nlet alloc_var { next_auxiliary; _ } () =\n let v = !next_auxiliary in\n incr next_auxiliary ; Cvar.Unsafe.of_index v\n\nlet has_witness { has_witness; _ } = has_witness\n\nlet as_prover { as_prover; _ } = !as_prover\n\nlet set_as_prover t as_prover = t.as_prover := as_prover\n\nlet stack { stack; _ } = stack\n\nlet set_stack t stack = { t with stack }\n\nlet log_constraint { log_constraint; _ } = log_constraint\n\nlet eval_constraints { eval_constraints; _ } = eval_constraints\n\nlet system { system; _ } = system\n\nlet handler { handler; _ } = handler\n\nlet set_handler t handler = { t with handler }\n\nlet is_running { is_running; _ } = is_running\n\nlet set_is_running t is_running = { t with is_running }\n\nlet next_auxiliary { next_auxiliary; _ } = !next_auxiliary\n","module type Basic = sig\n module Types : Types.Types\n\n type ('a, 'f) t = ('a, 'f) Types.Checked.t\n\n type 'f field\n\n include Monad_let.S2 with type ('a, 'f) t := ('a, 'f) t\n\n val add_constraint :\n ('f field Cvar.t, 'f field) Constraint.t -> (unit, 'f field) t\n\n val as_prover : (unit, 'f field) As_prover0.t -> (unit, 'f field) t\n\n val mk_lazy : (unit -> ('a, 'f) t) -> ('a Lazy.t, 'f) t\n\n val with_label : string -> (unit -> ('a, 'f field) t) -> ('a, 'f field) t\n\n val with_handler :\n Request.Handler.single -> (unit -> ('a, 'f field) t) -> ('a, 'f field) t\n\n val exists :\n ('var, 'value, 'f field) Types.Typ.t\n -> ('value, 'f field) Types.Provider.t\n -> (('var, 'value) Handle.t, 'f field) t\n\n val next_auxiliary : unit -> (int, 'f field) t\n\n val direct :\n ('f field Run_state.t -> 'f field Run_state.t * 'a) -> ('a, 'f field) t\n\n val constraint_count :\n ?weight:(('f field Cvar.t, 'f field) Constraint.t -> int)\n -> ?log:(?start:bool -> string -> int -> unit)\n -> (unit -> ('a, 'f field) t)\n -> int\nend\n\nmodule type S = sig\n module Types : Types.Types\n\n type ('a, 'f) t = ('a, 'f) Types.Checked.t\n\n type 'f field\n\n include Monad_let.S2 with type ('a, 'f) t := ('a, 'f) t\n\n val as_prover : (unit, 'f field) As_prover0.t -> (unit, 'f field) t\n\n val mk_lazy : (unit -> ('a, 'f) t) -> ('a Lazy.t, 'f) t\n\n val request_witness :\n ('var, 'value, 'f field) Types.Typ.t\n -> ('value Request.t, 'f field) As_prover0.t\n -> ('var, 'f field) t\n\n val request :\n ?such_that:('var -> (unit, 'f field) t)\n -> ('var, 'value, 'f field) Types.Typ.t\n -> 'value Request.t\n -> ('var, 'f field) t\n\n val exists_handle :\n ?request:('value Request.t, 'f field) As_prover0.t\n -> ?compute:('value, 'f field) As_prover0.t\n -> ('var, 'value, 'f field) Types.Typ.t\n -> (('var, 'value) Handle.t, 'f field) t\n\n val exists :\n ?request:('value Request.t, 'f field) As_prover0.t\n -> ?compute:('value, 'f field) As_prover0.t\n -> ('var, 'value, 'f field) Types.Typ.t\n -> ('var, 'f field) t\n\n type response = Request.response\n\n val unhandled : response\n\n type request = Request.request =\n | With :\n { request : 'a Request.t; respond : 'a Request.Response.t -> response }\n -> request\n\n val handle :\n (unit -> ('a, 'f field) t) -> (request -> response) -> ('a, 'f field) t\n\n val handle_as_prover :\n (unit -> ('a, 'f field) t)\n -> (request -> response, 'f field) As_prover0.t\n -> ('a, 'f field) t\n\n val next_auxiliary : unit -> (int, 'f field) t\n\n val with_label : string -> (unit -> ('a, 'f field) t) -> ('a, 'f field) t\n\n val assert_ :\n ?label:Base.string\n -> ('f field Cvar.t, 'f field) Constraint.t\n -> (unit, 'f field) t\n\n val assert_r1cs :\n ?label:Base.string\n -> 'f field Cvar.t\n -> 'f field Cvar.t\n -> 'f field Cvar.t\n -> (unit, 'f field) t\n\n val assert_square :\n ?label:Base.string\n -> 'f field Cvar.t\n -> 'f field Cvar.t\n -> (unit, 'f field) t\n\n val assert_all :\n ?label:Base.string\n -> ('f field Cvar.t, 'f field) Constraint.t list\n -> (unit, 'f field) t\n\n val assert_equal :\n ?label:Base.string\n -> 'f field Cvar.t\n -> 'f field Cvar.t\n -> (unit, 'f field) t\n\n val direct :\n ('f field Run_state.t -> 'f field Run_state.t * 'a) -> ('a, 'f field) t\n\n val constraint_count :\n ?weight:(('f field Cvar.t, 'f field) Constraint.t -> int)\n -> ?log:(?start:bool -> string -> int -> unit)\n -> (unit -> ('a, 'f field) t)\n -> int\nend\n\nmodule type Extended = sig\n type field\n\n module Types : Types.Types\n\n type 'a t = ('a, field) Types.Checked.t\n\n include\n S\n with module Types := Types\n with type 'f field := field\n and type ('a, 'f) t := ('a, 'f) Types.Checked.t\n\n val run : 'a t -> field Run_state.t -> field Run_state.t * 'a\nend\n\nmodule Unextend (Checked : Extended) :\n S with module Types = Checked.Types with type 'f field = Checked.field =\nstruct\n include (\n Checked :\n S\n with module Types = Checked.Types\n with type 'f field := Checked.field\n and type ('a, 'f) t := ('a, 'f) Checked.Types.Checked.t )\n\n type 'f field = Checked.field\n\n type ('a, 'f) t = ('a, 'f) Types.Checked.t\nend\n","open Core_kernel\n\ntype 'a t = 'a option ref\n\nmodule Make_ref_typ (Checked : Monad_let.S2) = struct\n let typ : ('a t, 'a, _, _) Types.Typ.t =\n Typ\n { var_to_fields = (fun x -> ([||], !x))\n ; var_of_fields = (fun (_, x) -> ref x)\n ; value_to_fields = (fun x -> ([||], Some x))\n ; value_of_fields = (fun (_, x) -> Option.value_exn x)\n ; size_in_field_elements = 0\n ; constraint_system_auxiliary = (fun () -> None)\n ; check = (fun _ -> Checked.return ())\n }\nend\n\nmodule type S = sig\n module Types : Types.Types\n\n type ('a, 'f) checked\n\n type 'f field\n\n type nonrec 'a t = 'a t\n\n val create : ('a, 'f field) As_prover0.t -> ('a t, 'f field) checked\n\n val get : 'a t -> ('a, 'f field) As_prover0.t\n\n val set : 'a t -> 'a -> (unit, 'f field) As_prover0.t\nend\n\nmodule Make\n (Checked : Checked_intf.S)\n (As_prover : As_prover_intf.Basic\n with type 'f field := 'f Checked.field\n and type ('a, 'f) Provider.t =\n ('a, 'f) Checked.Types.Provider.t) :\n S\n with module Types = Checked.Types\n and type ('a, 'f) checked := ('a, 'f) Checked.t\n and type 'f field = 'f Checked.field = struct\n module Types = Checked.Types\n\n type 'f field = 'f Checked.field\n\n type nonrec 'a t = 'a t\n\n let create (x : ('a, 'f Checked.field) As_prover.t) :\n ('a t, 'f Checked.field) Checked.t =\n let r = ref None in\n let open Checked in\n let%map () =\n Checked.as_prover (As_prover.map x ~f:(fun x -> r := Some x))\n in\n r\n\n open As_prover.Let_syntax\n\n let get (r : 'a t) =\n let%map () = As_prover.return () in\n Option.value_exn !r\n\n let set (r : 'a t) x =\n let%map () = As_prover.return () in\n r := Some x\nend\n","type 'v t = 'v\n\nmodule Unsafe = struct\n let create x = x\nend\n","open Core_kernel\nmodule Types0 = Types\n\nmodule Make\n (Backend : Backend_extended.S)\n (Checked : Checked_intf.Extended with type field = Backend.Field.t)\n (As_prover : As_prover0.Extended with type field := Backend.Field.t)\n (Runner : Checked_runner.S\n with module Types := Checked.Types\n with type field := Backend.Field.t\n and type cvar := Backend.Cvar.t\n and type constr := Backend.Constraint.t option\n and type r1cs := Backend.R1CS_constraint_system.t) =\nstruct\n open Backend\n\n let set_constraint_logger = Runner.set_constraint_logger\n\n let clear_constraint_logger = Runner.clear_constraint_logger\n\n type field = Field.t\n\n let field_vec_id : Field.Vector.t Type_equal.Id.t =\n Type_equal.Id.create ~name:\"field-vector\" sexp_of_opaque\n\n let pack_field_vec v =\n Run_state.Vector.T ((module Field.Vector), field_vec_id, v)\n\n let field_vec () = pack_field_vec (Field.Vector.create ())\n\n module Proof_inputs = struct\n type t =\n { public_inputs : Field.Vector.t; auxiliary_inputs : Field.Vector.t }\n end\n\n module Bigint = Bigint\n module Field0 = Field\n module Cvar = Cvar\n module Constraint = Constraint\n\n module Handler = struct\n type t = Request.request -> Request.response\n end\n\n module Runner = Runner\n\n (* TODO-someday: Add pass to unify variables which have an Equal constraint *)\n let constraint_system ~run ~num_inputs ~return_typ:(Types.Typ.Typ return_typ)\n output t : R1CS_constraint_system.t =\n let input = field_vec () in\n let next_auxiliary = ref num_inputs in\n let aux = field_vec () in\n let system = R1CS_constraint_system.create () in\n let state =\n Runner.State.make ~num_inputs ~input ~next_auxiliary ~aux ~system\n ~with_witness:false ()\n in\n let state, res = run t state in\n let res, _ = return_typ.var_to_fields res in\n let output, _ = return_typ.var_to_fields output in\n let _state =\n Array.fold2_exn ~init:state res output ~f:(fun state res output ->\n fst @@ Checked.run (Checked.assert_equal res output) state )\n in\n let auxiliary_input_size = !next_auxiliary - num_inputs in\n R1CS_constraint_system.set_auxiliary_input_size system auxiliary_input_size ;\n system\n\n let auxiliary_input ?system ~run ~num_inputs\n ?(handlers = ([] : Handler.t list)) t0 (input : Field.Vector.t)\n ~return_typ:(Types.Typ.Typ return_typ) ~output : Field.Vector.t * _ =\n let next_auxiliary = ref num_inputs in\n let aux = Field.Vector.create () in\n let handler =\n List.fold ~init:Request.Handler.fail handlers ~f:(fun handler h ->\n Request.Handler.(push handler (create_single h)) )\n in\n let state =\n Runner.State.make ?system ~num_inputs ~input:(pack_field_vec input)\n ~next_auxiliary ~aux:(pack_field_vec aux) ~handler ~with_witness:true ()\n in\n let state, res = run t0 state in\n let res, auxiliary_output_data = return_typ.var_to_fields res in\n let output, _ = return_typ.var_to_fields output in\n let _state =\n Array.fold2_exn ~init:state res output ~f:(fun state res output ->\n Field.Vector.emplace_back input (Runner.get_value state res) ;\n fst @@ Checked.run (Checked.assert_equal res output) state )\n in\n let true_output =\n return_typ.var_of_fields (output, auxiliary_output_data)\n in\n Option.iter system ~f:(fun system ->\n let auxiliary_input_size = !next_auxiliary - num_inputs in\n R1CS_constraint_system.set_auxiliary_input_size system\n auxiliary_input_size ;\n R1CS_constraint_system.finalize system ) ;\n (aux, true_output)\n\n let run_and_check_exn' ~run t0 =\n let num_inputs = 0 in\n let input = field_vec () in\n let next_auxiliary = ref 0 in\n let aux = Field.Vector.create () in\n let system = R1CS_constraint_system.create () in\n let get_value : Cvar.t -> Field.t =\n let get_one v = Field.Vector.get aux v in\n Cvar.eval (`Return_values_will_be_mutated get_one)\n in\n let state =\n Runner.State.make ~num_inputs ~input ~next_auxiliary\n ~aux:(pack_field_vec aux) ~system ~eval_constraints:true\n ~with_witness:true ()\n in\n let _, x = run t0 state in\n (x, get_value)\n\n let run_and_check' ~run t0 =\n match run_and_check_exn' ~run t0 with\n | exception e ->\n Or_error.of_exn ~backtrace:`Get e\n | res ->\n Ok res\n\n let run_and_check_deferred_exn' ~map ~run t0 =\n let num_inputs = 0 in\n let input = field_vec () in\n let next_auxiliary = ref 0 in\n let aux = Field.Vector.create () in\n let system = R1CS_constraint_system.create () in\n let get_value : Cvar.t -> Field.t =\n let get_one v = Field.Vector.get aux v in\n Cvar.eval (`Return_values_will_be_mutated get_one)\n in\n let state =\n Runner.State.make ~num_inputs ~input ~next_auxiliary\n ~aux:(pack_field_vec aux) ~system ~eval_constraints:true\n ~with_witness:true ()\n in\n let res = run t0 state in\n map res ~f:(function _, x -> (x, get_value))\n\n let run_and_check_deferred' ~map ~return ~run t0 =\n match\n run_and_check_deferred_exn'\n ~map:(fun x ~f -> map x ~f:(fun x -> Ok (f x)))\n ~run t0\n with\n | exception e ->\n return (Or_error.of_exn ~backtrace:`Get e)\n | res ->\n res\n\n let run_unchecked ~run t0 =\n let num_inputs = 0 in\n let input = field_vec () in\n let next_auxiliary = ref 0 in\n let aux = field_vec () in\n let state =\n Runner.State.make ~num_inputs ~input ~next_auxiliary ~aux\n ~with_witness:true ()\n in\n match run t0 state with _, x -> x\n\n let run_and_check_exn ~run t =\n let x, get_value = run_and_check_exn' ~run t in\n let x = As_prover.run x get_value in\n x\n\n let run_and_check ~run t =\n Or_error.map (run_and_check' ~run t) ~f:(fun (x, get_value) ->\n let x = As_prover.run x get_value in\n x )\n\n let check_exn ~run t = run_and_check_exn' ~run t |> Fn.const ()\n\n let check ~run t = run_and_check' ~run t |> Result.map ~f:(Fn.const ())\n\n module Run = struct\n let alloc_var next_input () =\n let v = !next_input in\n incr next_input ; Cvar.Unsafe.of_index v\n\n let store_field_elt primary_input next_input x =\n let v = alloc_var next_input () in\n Field.Vector.emplace_back primary_input x ;\n v\n\n let collect_input_constraints :\n type checked input_var input_value.\n int ref\n -> input_typ:\n ( input_var\n , input_value\n , field\n , (unit, field) Checked.Types.Checked.t )\n Types.Typ.typ\n -> return_typ:_ Types.Typ.t\n -> (unit -> input_var -> checked)\n -> _ * (unit -> checked) Checked.t =\n fun next_input ~input_typ:(Typ input_typ) ~return_typ:(Typ return_typ) k ->\n (* allocate variables for the public input and the public output *)\n let open Checked in\n let alloc_input\n { Types0.Typ.var_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; _\n } =\n var_of_fields\n ( Core_kernel.Array.init size_in_field_elements ~f:(fun _ ->\n alloc_var next_input () )\n , constraint_system_auxiliary () )\n in\n let var = alloc_input input_typ in\n let retval = alloc_input return_typ in\n\n (* create constraints to validate the input (using the input [Typ]'s [check]) *)\n let circuit =\n let%bind () = input_typ.check var in\n Checked.return (fun () -> k () var)\n in\n (retval, circuit)\n\n let r1cs_h :\n type a checked input_var input_value retval.\n run:(a, checked) Runner.run\n -> int ref\n -> input_typ:\n ( input_var\n , input_value\n , field\n , (unit, field) Checked.Types.Checked.t )\n Types.Typ.typ\n -> return_typ:(a, retval, _, _) Types.Typ.t\n -> (input_var -> checked)\n -> R1CS_constraint_system.t =\n fun ~run next_input ~input_typ ~return_typ k ->\n (* allocate variables for the public input and the public output *)\n let retval, checked =\n collect_input_constraints next_input ~input_typ ~return_typ (fun () ->\n k )\n in\n\n (* ? *)\n let run_in_run checked state =\n let state, x = Checked.run checked state in\n run x state\n in\n\n (* ? *)\n constraint_system ~run:run_in_run ~num_inputs:!next_input ~return_typ\n retval\n (Checked.map ~f:(fun r -> r ()) checked)\n\n let constraint_system (type a checked input_var) :\n run:(a, checked) Runner.run\n -> input_typ:(input_var, _, _, _) Types.Typ.typ\n -> return_typ:_\n -> (input_var -> checked)\n -> R1CS_constraint_system.t =\n fun ~run ~input_typ ~return_typ k ->\n r1cs_h ~run (ref 0) ~input_typ ~return_typ k\n\n let generate_public_input :\n ('input_var, 'input_value, _, _) Types.Typ.typ\n -> 'input_value\n -> Field.Vector.t =\n fun (Typ { value_to_fields; _ }) value ->\n let primary_input = Field.Vector.create () in\n let next_input = ref 0 in\n let store_field_elt = store_field_elt primary_input next_input in\n let fields, _aux = value_to_fields value in\n let _fields = Array.map ~f:store_field_elt fields in\n primary_input\n\n let conv :\n type r_var r_value.\n (int -> _ -> r_var -> Field.Vector.t -> r_value)\n -> ('input_var, 'input_value, _, _) Types.Typ.t\n -> _ Types.Typ.t\n -> (unit -> 'input_var -> r_var)\n -> 'input_value\n -> r_value =\n fun cont0 input_typ (Typ return_typ) k0 ->\n let primary_input = Field.Vector.create () in\n let next_input = ref 0 in\n let store_field_elt x =\n let v = !next_input in\n incr next_input ;\n Field.Vector.emplace_back primary_input x ;\n Cvar.Unsafe.of_index v\n in\n let (Typ { var_of_fields; value_to_fields; _ }) = input_typ in\n fun value ->\n let fields, aux = value_to_fields value in\n let fields = Array.map ~f:store_field_elt fields in\n let var = var_of_fields (fields, aux) in\n let retval =\n return_typ.var_of_fields\n ( Core_kernel.Array.init return_typ.size_in_field_elements\n ~f:(fun _ -> alloc_var next_input ())\n , return_typ.constraint_system_auxiliary () )\n in\n cont0 !next_input retval (k0 () var) primary_input\n\n let generate_auxiliary_input :\n run:('a, 'checked) Runner.run\n -> input_typ:_ Types.Typ.t\n -> return_typ:(_, _, _, _) Types.Typ.t\n -> ?handlers:Handler.t list\n -> 'k_var\n -> 'k_value =\n fun ~run ~input_typ ~return_typ ?handlers k ->\n conv\n (fun num_inputs output c primary ->\n let auxiliary =\n auxiliary_input ~run ?handlers ~return_typ ~output ~num_inputs c\n primary\n in\n ignore auxiliary )\n input_typ return_typ\n (fun () -> k)\n\n let generate_witness_conv :\n run:('a, 'checked) Runner.run\n -> f:(Proof_inputs.t -> _ -> 'out)\n -> input_typ:_ Types.Typ.t\n -> return_typ:_ Types.Typ.t\n -> ?handlers:Handler.t list\n -> 'k_var\n -> 'k_value =\n fun ~run ~f ~input_typ ~return_typ ?handlers k ->\n conv\n (fun num_inputs output c primary ->\n let auxiliary, output =\n auxiliary_input ~run ?handlers ~return_typ ~output ~num_inputs c\n primary\n in\n let output =\n let (Typ return_typ) = return_typ in\n let fields, aux = return_typ.var_to_fields output in\n let read_cvar =\n let get_one i =\n if i < num_inputs then Field.Vector.get primary i\n else Field.Vector.get auxiliary (i - num_inputs)\n in\n Cvar.eval (`Return_values_will_be_mutated get_one)\n in\n let fields = Array.map ~f:read_cvar fields in\n return_typ.value_of_fields (fields, aux)\n in\n f\n { Proof_inputs.public_inputs = primary\n ; auxiliary_inputs = auxiliary\n }\n output )\n input_typ return_typ\n (fun () -> k)\n\n let generate_witness =\n generate_witness_conv ~f:(fun inputs _output -> inputs)\n end\n\n module Perform = struct\n let generate_witness ~run t ~return_typ k =\n Run.generate_witness ~run t ~return_typ k\n\n let generate_witness_conv ~run ~f t ~return_typ k =\n Run.generate_witness_conv ~run ~f t ~return_typ k\n\n let constraint_system = Run.constraint_system\n\n let run_unchecked = run_unchecked\n\n let run_and_check_exn = run_and_check_exn\n\n let run_and_check = run_and_check\n\n let check_exn = check_exn\n\n let check = check\n end\n\n let conv f spec return_typ k =\n Run.conv (fun _ _ x _ -> f x) spec return_typ (fun () -> k)\n\n let generate_auxiliary_input ~input_typ ~return_typ k =\n Run.generate_auxiliary_input ~run:Checked.run ~input_typ ~return_typ k\n\n let generate_public_input = Run.generate_public_input\n\n let generate_witness ~input_typ ~return_typ k =\n Run.generate_witness ~run:Checked.run ~input_typ ~return_typ k\n\n let generate_witness_conv ~f ~input_typ ~return_typ k =\n Run.generate_witness_conv ~run:Checked.run ~f ~input_typ ~return_typ k\n\n let constraint_system ~input_typ ~return_typ k =\n Run.constraint_system ~run:Checked.run ~input_typ ~return_typ k\n\n let run_unchecked t = run_unchecked ~run:Checked.run t\n\n let run_and_check t = run_and_check ~run:Checked.run t\n\n let run_and_check_exn t = run_and_check_exn ~run:Checked.run t\n\n let check t = check ~run:Checked.run t\n\n let check_exn t = check_exn ~run:Checked.run t\nend\n","open Core_kernel\nopen Types.Typ\n\nmodule Data_spec0 = struct\n (** A list of {!type:Type.Typ.t} values, describing the inputs to a checked\n computation. The type [('r_var, 'r_value, 'k_var, 'k_value, 'field) t]\n represents\n - ['k_value] is the OCaml type of the computation\n - ['r_value] is the OCaml type of the result\n - ['k_var] is the type of the computation within the R1CS\n - ['k_value] is the type of the result within the R1CS\n - ['field] is the field over which the R1CS operates\n - ['checked] is the type of checked computation that verifies the stored\n contents as R1CS variables.\n\n This functions the same as OCaml's default list type:\n{[\n Data_spec.[typ1; typ2; typ3]\n\n Data_spec.(typ1 :: typs)\n\n let open Data_spec in\n [typ1; typ2; typ3; typ4; typ5]\n\n let open Data_spec in\n typ1 :: typ2 :: typs\n\n]}\n all function as you would expect.\n *)\n type ('r_var, 'r_value, 'k_var, 'k_value, 'f, 'checked) data_spec =\n | ( :: ) :\n ('var, 'value, 'f, 'checked) Types.Typ.t\n * ('r_var, 'r_value, 'k_var, 'k_value, 'f, 'checked) data_spec\n -> ( 'r_var\n , 'r_value\n , 'var -> 'k_var\n , 'value -> 'k_value\n , 'f\n , 'checked )\n data_spec\n | [] : ('r_var, 'r_value, 'r_var, 'r_value, 'f, 'checked) data_spec\nend\n\nmodule Intf = struct\n module type S = sig\n type field\n\n type field_var\n\n type 'field checked\n\n module Var : sig\n type t\n\n val size_in_field_elements : int\n\n val to_field_elements : t -> field_var array\n\n val of_field_elements : field_var array -> t\n\n val check : t -> field checked\n end\n\n module Value : sig\n type t\n\n val size_in_field_elements : int\n\n val to_field_elements : t -> field array\n\n val of_field_elements : field array -> t\n end\n end\nend\n\nmodule type Checked_monad = sig\n type ('a, 'f) t\n\n type 'f field\n\n include Monad_let.S2 with type ('a, 'e) t := ('a, 'e) t\n\n module Types : Types.Types\nend\n\nmodule Make (Checked : Checked_monad) = struct\n type ('var, 'value, 'field) t =\n ('var, 'value, 'field, (unit, 'field) Checked.t) Types.Typ.t\n\n type ('var, 'value, 'field) typ = ('var, 'value, 'field) t\n\n module type S = sig\n type field\n\n include\n Intf.S\n with type 'field checked := (unit, 'field) Checked.t\n and type field := field\n and type field_var := field Cvar.t\n end\n\n module Data_spec = struct\n include Data_spec0\n\n type ('r_var, 'r_value, 'k_var, 'k_value, 'f) t =\n ('r_var, 'r_value, 'k_var, 'k_value, 'f, (unit, 'f) Checked.t) data_spec\n\n let size t =\n let rec go :\n type r_var r_value k_var k_value.\n int -> (r_var, r_value, k_var, k_value, 'f) t -> int =\n fun acc t ->\n match t with\n | [] ->\n acc\n | Typ { size_in_field_elements; _ } :: t' ->\n go (acc + size_in_field_elements) t'\n in\n go 0 t\n end\n\n module T = struct\n let unit () : (unit, unit, 'field) t =\n Typ\n { var_to_fields = (fun () -> ([||], ()))\n ; var_of_fields = (fun _ -> ())\n ; value_to_fields = (fun () -> ([||], ()))\n ; value_of_fields = (fun _ -> ())\n ; size_in_field_elements = 0\n ; constraint_system_auxiliary = (fun () -> ())\n ; check = (fun () -> Checked.return ())\n }\n\n let field () : ('field Cvar.t, 'field, 'field) t =\n Typ\n { var_to_fields = (fun f -> ([| f |], ()))\n ; var_of_fields = (fun (fields, _) -> fields.(0))\n ; value_to_fields = (fun f -> ([| f |], ()))\n ; value_of_fields = (fun (fields, _) -> fields.(0))\n ; size_in_field_elements = 1\n ; constraint_system_auxiliary = (fun () -> ())\n ; check = (fun _ -> Checked.return ())\n }\n\n module Internal = struct\n let snarkless value : _ t =\n Typ\n { var_to_fields = (fun _ -> ([||], ()))\n ; var_of_fields = (fun _ -> value)\n ; value_to_fields =\n (fun value' ->\n assert (phys_equal value value') ;\n ([||], ()) )\n ; value_of_fields = (fun _ -> value)\n ; size_in_field_elements = 0\n ; constraint_system_auxiliary = (fun () -> ())\n ; check = (fun _ -> Checked.return ())\n }\n\n module Ref_typ = As_prover_ref.Make_ref_typ (Checked)\n\n let ref () = Ref_typ.typ\n end\n\n let transport (type var value1 value2 field)\n (Typ\n { var_to_fields\n ; var_of_fields\n ; value_to_fields\n ; value_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check\n } :\n (var, value1, field) t ) ~(there : value2 -> value1)\n ~(back : value1 -> value2) : (var, value2, field) t =\n Typ\n { var_to_fields\n ; var_of_fields\n ; value_to_fields = (fun x -> value_to_fields (there x))\n ; value_of_fields = (fun x -> back (value_of_fields x))\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check\n }\n\n let transport_var (type var1 var2 value field)\n (Typ\n { var_to_fields\n ; var_of_fields\n ; value_to_fields\n ; value_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check\n } :\n (var1, value, field) t ) ~(there : var2 -> var1) ~(back : var1 -> var2)\n : (var2, value, field) t =\n Typ\n { var_to_fields = (fun x -> var_to_fields (there x))\n ; var_of_fields = (fun x -> back (var_of_fields x))\n ; value_to_fields\n ; value_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check = (fun x -> check (there x))\n }\n\n let list ~length\n (Typ\n { var_to_fields\n ; var_of_fields\n ; value_to_fields\n ; value_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check\n } :\n ('elt_var, 'elt_value, 'field) t ) :\n ('elt_var list, 'elt_value list, 'field) t =\n (* NB: We store the size_in_field_elements of each in the auxiliary\n data, to allow for 'reads' of e.g. list of lists of different\n lengths.\n *)\n Typ\n { var_to_fields =\n (fun ts ->\n let rec go ts ((fieldss, auxes) as acc) =\n match ts with\n | [] ->\n acc\n | t :: tl ->\n let fields, aux = var_to_fields t in\n let acc =\n ( Array.append fieldss fields\n , (aux, Array.length fields) :: auxes )\n in\n go tl acc\n in\n go ts ([||], []) )\n ; var_of_fields =\n (fun (fields, auxes) ->\n let vars, _ =\n List.fold\n ~init:([], Array.length fields)\n auxes\n ~f:(fun (vars, end_pos) (aux, num_fields) ->\n let end_pos = end_pos - num_fields in\n let var =\n var_of_fields\n (Array.sub ~pos:end_pos ~len:num_fields fields, aux)\n in\n (var :: vars, end_pos) )\n in\n vars )\n ; value_to_fields =\n (fun ts ->\n let rec go ts ((fieldss, auxes) as acc) =\n match ts with\n | [] ->\n acc\n | t :: tl ->\n let fields, aux = value_to_fields t in\n let acc =\n ( Array.append fieldss fields\n , (aux, Array.length fields) :: auxes )\n in\n go tl acc\n in\n go ts ([||], []) )\n ; value_of_fields =\n (fun (fields, auxes) ->\n let vars, _ =\n List.fold\n ~init:([], Array.length fields)\n auxes\n ~f:(fun (vars, end_pos) (aux, num_fields) ->\n let end_pos = end_pos - num_fields in\n let var =\n value_of_fields\n (Array.sub ~pos:end_pos ~len:num_fields fields, aux)\n in\n (var :: vars, end_pos) )\n in\n vars )\n ; size_in_field_elements = length * size_in_field_elements\n ; constraint_system_auxiliary =\n (fun () ->\n List.init length ~f:(fun _ ->\n (constraint_system_auxiliary (), size_in_field_elements) ) )\n ; check = (fun ts -> Checked.all_unit (List.map ts ~f:check))\n }\n\n let array ~length typ =\n list ~length typ\n |> transport ~there:Array.to_list ~back:Array.of_list\n |> transport_var ~there:Array.to_list ~back:Array.of_list\n\n let hlist (type k_var k_value)\n (spec0 : (unit, unit, k_var, k_value, 'f) Data_spec.t) :\n ((unit, k_var) H_list.t, (unit, k_value) H_list.t, 'f) t =\n let rec go :\n type k_var k_value.\n (unit, unit, k_var, k_value, 'f) Data_spec.t\n -> ((unit, k_var) H_list.t, (unit, k_value) H_list.t, 'f) t =\n fun spec0 ->\n let open H_list in\n match spec0 with\n | [] ->\n Typ\n { var_to_fields = (fun [] -> ([||], ()))\n ; var_of_fields = (fun _ -> [])\n ; value_to_fields = (fun [] -> ([||], ()))\n ; value_of_fields = (fun _ -> [])\n ; size_in_field_elements = 0\n ; constraint_system_auxiliary = (fun () -> ())\n ; check = (fun [] -> Checked.return ())\n }\n | Typ\n { var_to_fields\n ; var_of_fields\n ; value_to_fields\n ; value_of_fields\n ; size_in_field_elements\n ; constraint_system_auxiliary\n ; check\n }\n :: spec0 ->\n let (Typ typ) = go spec0 in\n let open H_list in\n Typ\n { var_to_fields =\n (fun (x :: tl) ->\n let fields, aux = var_to_fields x in\n let fieldss, auxes = typ.var_to_fields tl in\n ( Array.append fields fieldss\n , (aux, Array.length fields, auxes) ) )\n ; var_of_fields =\n (fun (fields, (hd, len, tl)) ->\n let var =\n var_of_fields (Array.sub ~pos:0 ~len fields, hd)\n in\n let tl =\n typ.var_of_fields\n ( Array.sub ~pos:len\n ~len:(Array.length fields - len)\n fields\n , tl )\n in\n var :: tl )\n ; value_to_fields =\n (fun (x :: tl) ->\n let fields, aux = value_to_fields x in\n let fieldss, auxes = typ.value_to_fields tl in\n ( Array.append fields fieldss\n , (aux, Array.length fields, auxes) ) )\n ; value_of_fields =\n (fun (fields, (hd, len, tl)) ->\n let value =\n value_of_fields (Array.sub ~pos:0 ~len fields, hd)\n in\n let tl =\n typ.value_of_fields\n ( Array.sub ~pos:len\n ~len:(Array.length fields - len)\n fields\n , tl )\n in\n value :: tl )\n ; size_in_field_elements =\n size_in_field_elements + typ.size_in_field_elements\n ; constraint_system_auxiliary =\n (fun () ->\n let hd = constraint_system_auxiliary () in\n let auxes = typ.constraint_system_auxiliary () in\n (hd, size_in_field_elements, auxes) )\n ; check =\n (fun (x :: tl) ->\n Checked.bind (check x) ~f:(fun () -> typ.check tl) )\n }\n in\n go spec0\n\n let tuple2 typ1 typ2 =\n let open H_list in\n hlist [ typ1; typ2 ]\n |> transport\n ~there:(fun (a, b) -> [ a; b ])\n ~back:(fun ([ a; b ] : (unit, _ -> _ -> unit) H_list.t) -> (a, b))\n |> transport_var\n ~there:(fun (a, b) -> [ a; b ])\n ~back:(fun ([ a; b ] : (unit, _ -> _ -> unit) H_list.t) -> (a, b))\n\n let ( * ) = tuple2\n\n let tuple3 typ1 typ2 typ3 =\n let open H_list in\n hlist [ typ1; typ2; typ3 ]\n |> transport\n ~there:(fun (a, b, c) -> [ a; b; c ])\n ~back:(fun ([ a; b; c ] : (unit, _ -> _ -> _ -> unit) H_list.t) ->\n (a, b, c) )\n |> transport_var\n ~there:(fun (a, b, c) -> [ a; b; c ])\n ~back:(fun ([ a; b; c ] : (unit, _ -> _ -> _ -> unit) H_list.t) ->\n (a, b, c) )\n\n let tuple4 typ1 typ2 typ3 typ4 =\n let open H_list in\n hlist [ typ1; typ2; typ3; typ4 ]\n |> transport\n ~there:(fun (a, b, c, d) -> [ a; b; c; d ])\n ~back:(fun ([ a; b; c; d ] :\n (unit, _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d) )\n |> transport_var\n ~there:(fun (a, b, c, d) -> [ a; b; c; d ])\n ~back:(fun ([ a; b; c; d ] :\n (unit, _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d) )\n\n let tuple5 typ1 typ2 typ3 typ4 typ5 =\n let open H_list in\n hlist [ typ1; typ2; typ3; typ4; typ5 ]\n |> transport\n ~there:(fun (a, b, c, d, e) -> [ a; b; c; d; e ])\n ~back:(fun ([ a; b; c; d; e ] :\n (unit, _ -> _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d, e) )\n |> transport_var\n ~there:(fun (a, b, c, d, e) -> [ a; b; c; d; e ])\n ~back:(fun ([ a; b; c; d; e ] :\n (unit, _ -> _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d, e) )\n\n let tuple6 typ1 typ2 typ3 typ4 typ5 typ6 =\n let open H_list in\n hlist [ typ1; typ2; typ3; typ4; typ5; typ6 ]\n |> transport\n ~there:(fun (a, b, c, d, e, f) -> [ a; b; c; d; e; f ])\n ~back:(fun ([ a; b; c; d; e; f ] :\n (unit, _ -> _ -> _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d, e, f) )\n |> transport_var\n ~there:(fun (a, b, c, d, e, f) -> [ a; b; c; d; e; f ])\n ~back:(fun ([ a; b; c; d; e; f ] :\n (unit, _ -> _ -> _ -> _ -> _ -> _ -> unit) H_list.t ) ->\n (a, b, c, d, e, f) )\n\n let of_hlistable (spec : (unit, unit, 'k_var, 'k_value, 'f) Data_spec.t)\n ~(var_to_hlist : 'var -> (unit, 'k_var) H_list.t)\n ~(var_of_hlist : (unit, 'k_var) H_list.t -> 'var)\n ~(value_to_hlist : 'value -> (unit, 'k_value) H_list.t)\n ~(value_of_hlist : (unit, 'k_value) H_list.t -> 'value) :\n ('var, 'value, 'f) t =\n hlist spec\n |> transport ~there:value_to_hlist ~back:value_of_hlist\n |> transport_var ~there:var_to_hlist ~back:var_of_hlist\n end\n\n include T\nend\n\ninclude Make (Checked_runner.Simple)\n","open Core_kernel\n\n(** Helpers for operating over a sequence of data (currently, either an array\n or a list) inside of a monad.\n*)\nmodule type S = sig\n type 'a monad\n\n type 'a t\n\n type boolean\n\n val foldi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b monad) -> 'b monad\n\n val fold : 'a t -> init:'b -> f:('b -> 'a -> 'b monad) -> 'b monad\n\n val fold_map :\n 'a t -> init:'b -> f:('b -> 'a -> ('b * 'c) monad) -> ('b * 'c t) monad\n\n val exists : 'a t -> f:('a -> boolean monad) -> boolean monad\n\n val existsi : 'a t -> f:(int -> 'a -> boolean monad) -> boolean monad\n\n val for_all : 'a t -> f:('a -> boolean monad) -> boolean monad\n\n val for_alli : 'a t -> f:(int -> 'a -> boolean monad) -> boolean monad\n\n val all : 'a monad t -> 'a t monad\n\n val all_unit : unit monad t -> unit monad\n\n val init : int -> f:(int -> 'a monad) -> 'a t monad\n\n val iter : 'a t -> f:('a -> unit monad) -> unit monad\n\n val iteri : 'a t -> f:(int -> 'a -> unit monad) -> unit monad\n\n val map : 'a t -> f:('a -> 'b monad) -> 'b t monad\n\n val mapi : 'a t -> f:(int -> 'a -> 'b monad) -> 'b t monad\nend\n\nmodule List\n (M : Monad_let.S) (Bool : sig\n type t\n\n val any : t list -> t M.t\n\n val all : t list -> t M.t\n end) :\n S\n with type 'a t = 'a list\n and type 'a monad := 'a M.t\n and type boolean := Bool.t = struct\n type 'a t = 'a list\n\n open M.Let_syntax\n\n let foldi t ~init ~f =\n let rec go i acc = function\n | [] ->\n return acc\n | x :: xs ->\n let%bind acc = f i acc x in\n go (i + 1) acc xs\n in\n go 0 init t\n\n let fold t ~init ~f = foldi t ~init ~f:(fun _ acc x -> f acc x)\n\n let fold_map xs ~init ~f =\n let%map res, ys =\n fold xs ~init:(init, []) ~f:(fun (acc, ys) x ->\n let%map acc, y = f acc x in\n (acc, y :: ys) )\n in\n (res, List.rev ys)\n\n let all = M.all\n\n let all_unit = M.all_unit\n\n let init n ~f =\n let rec go acc i =\n if i < 0 then return acc\n else\n let%bind x = f i in\n go (x :: acc) (i - 1)\n in\n go [] (n - 1)\n\n let iteri t ~f =\n let rec go i = function\n | [] ->\n return ()\n | x :: xs ->\n let%bind () = f i x in\n go (i + 1) xs\n in\n go 0 t\n\n let iter t ~f = iteri t ~f:(fun _i x -> f x)\n\n let mapi t ~f =\n let rec go i acc = function\n | [] ->\n return (List.rev acc)\n | x :: xs ->\n let%bind y = f i x in\n go (i + 1) (y :: acc) xs\n in\n go 0 [] t\n\n let map t ~f = mapi t ~f:(fun _i x -> f x)\n\n (* The following functions use [map] to evaluate [f] on every element, since\n * we can't shortcut in the snark -- every constraint is either always\n present or always absent -- so we need to apply [f] to all of them\n * [Bool.any]/[Bool.all] operate by calculating the sum of the array,\n which requires an R1CS variable representing each element to be\n available.\n *)\n\n let existsi t ~f = mapi t ~f >>= Bool.any\n\n let exists t ~f = map t ~f >>= Bool.any\n\n let for_alli t ~f = mapi t ~f >>= Bool.all\n\n let for_all t ~f = map t ~f >>= Bool.all\nend\n\nmodule Array\n (M : Monad_let.S) (Bool : sig\n type t\n\n val any : t array -> t M.t\n\n val all : t array -> t M.t\n end) :\n S\n with type 'a t = 'a array\n and type 'a monad := 'a M.t\n and type boolean := Bool.t = struct\n type 'a t = 'a array\n\n open M.Let_syntax\n\n let foldi t ~init ~f =\n Array.foldi t ~init:(M.return init) ~f:(fun i acc x ->\n let%bind acc = acc in\n f i acc x )\n\n let fold t ~init ~f =\n Array.fold t ~init:(M.return init) ~f:(fun acc x ->\n let%bind acc = acc in\n f acc x )\n\n let iteri t ~f = foldi t ~init:() ~f:(fun i () x -> f i x)\n\n let iter t ~f = fold t ~init:() ~f:(fun () x -> f x)\n\n let init n ~f =\n let rec go arr i =\n if i < 0 then M.return arr\n else\n let%bind x = f i in\n Array.unsafe_set arr i x ;\n go arr (i - 1)\n in\n if n < 0 then invalid_arg \"Monad_sequence.Array.init\"\n else if n = 0 then M.return [||]\n else\n let%bind last = f (n - 1) in\n let arr = Array.create ~len:n last in\n go arr (n - 2)\n\n let mapi t ~f = init (Array.length t) ~f:(fun i -> f i (Array.unsafe_get t i))\n\n let map t ~f = mapi t ~f:(fun _i x -> f x)\n\n let fold_map t ~init ~f =\n let res = ref init in\n let%map t =\n map t ~f:(fun x ->\n let%map acc, y = f !res x in\n res := acc ;\n y )\n in\n (!res, t)\n\n let all = map ~f:(fun x -> x)\n\n let all_unit = iter ~f:(fun x -> x)\n\n (* The following functions use [map] to evaluate [f] on every element, since\n * we can't shortcut in the snark -- every constraint is either always\n present or always absent -- so we need to apply [f] to all of them\n * [Bool.any]/[Bool.all] operate by calculating the sum of the array,\n which requires an R1CS variable representing each element to be\n available.\n *)\n\n let existsi t ~f = mapi t ~f >>= Bool.any\n\n let exists t ~f = map t ~f >>= Bool.any\n\n let for_alli t ~f = mapi t ~f >>= Bool.all\n\n let for_all t ~f = map t ~f >>= Bool.all\nend\n","open Core_kernel\n\nlet int_to_bits ~length n =\n let ith_bit i = (n lsr i) land 1 = 1 in\n List.init length ~f:ith_bit\n\nlet int_of_bits bs =\n List.foldi bs ~init:0 ~f:(fun i acc b -> if b then acc + (1 lsl i) else acc)\n\nmodule Make\n (Impl : Snark_intf.Basic) (M : sig\n type t [@@deriving enum]\n end) =\nstruct\n open Impl\n\n (* TODO: Make this throw when the elt is too big *)\n let field_to_int x = int_of_bits (List.take (Field.unpack x) 62)\n\n open M\n\n let _unused = M.min (* generate unused variable error *)\n\n let bit_length =\n let n = Int.ceil_log2 (M.max + 1) in\n assert (n < Field.size_in_bits) ;\n n\n\n type var = Field.Var.t\n\n let to_field t = Field.of_int (to_enum t)\n\n let of_field x = Option.value_exn (of_enum (field_to_int x))\n\n let assert_equal x y = Field.Checked.Assert.equal x y\n\n let typ : (var, t) Typ.t =\n let check =\n if M.max = 1 then fun x -> assert_ (Constraint.boolean x)\n else fun x ->\n Field.Checked.Assert.lte ~bit_length x\n (constant Field.typ (Field.of_int M.max))\n in\n let (Typ typ) = Typ.transport Field.typ ~there:to_field ~back:of_field in\n Typ { typ with check }\n\n let var_to_bits : var -> Boolean.var list Checked.t =\n Field.Checked.unpack ~length:bit_length\n\n let to_bits t = int_to_bits ~length:bit_length (to_enum t)\n\n let if_ b ~(then_ : var) ~(else_ : var) = Field.Checked.if_ b ~then_ ~else_\n\n let var t : var = constant Field.typ (to_field t)\n\n let ( = ) = Field.Checked.equal\nend\n\nmodule Run = struct\n module Make\n (Impl : Snark_intf.Run_basic) (M : sig\n type t [@@deriving enum]\n end) =\n struct\n open Impl\n include Make (Impl.Internal_Basic) (M)\n\n let assert_equal x y = run_checked (assert_equal x y)\n\n let var_to_bits x = run_checked (var_to_bits x)\n\n let if_ x ~then_ ~else_ = run_checked (if_ x ~then_ ~else_)\n\n let ( = ) x y = run_checked (x = y)\n end\nend\n","module Bignum_bigint = Bigint\nopen Core_kernel\n\nlet pow2 n = Bignum_bigint.(pow (of_int 2) (of_int n))\n\nlet bigint_num_bits =\n let rec go acc i =\n if Bignum_bigint.(acc = zero) then i\n else go (Bignum_bigint.shift_right acc 1) (i + 1)\n in\n fun n -> go n 0\n\nmodule Make (Impl : Snark_intf.Basic) = struct\n open Impl\n open Let_syntax\n\n type t =\n { upper_bound : Bignum_bigint.t\n ; lower_bound : Bignum_bigint.t\n ; var : Field.Var.t\n ; bits : Boolean.var list option\n }\n\n let two_to_the n =\n let rec go acc i = if i <= 0 then acc else go (Field.add acc acc) (i - 1) in\n go Field.one n\n\n let to_bits { var; bits; upper_bound; lower_bound = _ } =\n let length = bigint_num_bits upper_bound in\n with_label \"Number.to_bits\" (fun () ->\n match bits with\n | Some bs ->\n return (List.take bs length)\n | None ->\n Field.Checked.unpack var ~length )\n\n let of_bits bs =\n let n = List.length bs in\n assert (n < Field.size_in_bits) ;\n { upper_bound = Bignum_bigint.(pow2 n - one)\n ; lower_bound = Bignum_bigint.zero\n ; var = Field.Var.pack bs\n ; bits = Some bs\n }\n\n let mul_pow_2 n (`Two_to_the k) =\n let%map bits = to_bits n in\n let multiplied = List.init k ~f:(fun _ -> Boolean.false_) @ bits in\n let upper_bound =\n Bignum_bigint.(n.upper_bound * pow (of_int 2) (of_int k))\n in\n assert (Bignum_bigint.(upper_bound < Field.size)) ;\n { upper_bound\n ; lower_bound = Bignum_bigint.(n.lower_bound * pow (of_int 2) (of_int k))\n ; var = Field.Var.pack multiplied\n ; bits = Some multiplied\n }\n\n let div_pow_2 n (`Two_to_the k) =\n let%map bits = to_bits n in\n let divided = List.drop bits k in\n let divided_of_bits = of_bits divided in\n { upper_bound =\n Bignum_bigint.(divided_of_bits.upper_bound / pow (of_int 2) (of_int k))\n ; lower_bound =\n Bignum_bigint.(divided_of_bits.lower_bound / pow (of_int 2) (of_int k))\n ; var = divided_of_bits.var\n ; bits = divided_of_bits.bits\n }\n\n let clamp_to_n_bits t n =\n assert (n < Field.size_in_bits) ;\n with_label \"Number.clamp_to_n_bits\" (fun () ->\n let k = pow2 n in\n if Bignum_bigint.(t.upper_bound < k) then return t\n else\n let%bind bs = to_bits t in\n let bs' = List.take bs n in\n let g = Field.Var.project bs' in\n let%bind fits = Field.Checked.equal t.var g in\n let%map r =\n Field.Checked.if_ fits ~then_:g\n ~else_:(constant Field.typ Field.(sub (two_to_the n) one))\n in\n { upper_bound = Bignum_bigint.(k - one)\n ; lower_bound = t.lower_bound\n ; var = r\n ; bits = None\n } )\n\n let ( < ) x y =\n let open Bignum_bigint in\n (*\n x [ ]\n y [ ]\n\n x [ ]\n y [ ]\n *)\n with_label \"Number.(<)\" (fun () ->\n if x.upper_bound < y.lower_bound then return Boolean.true_\n else if x.lower_bound >= y.upper_bound then return Boolean.false_\n else\n let bit_length =\n Int.max\n (bigint_num_bits x.upper_bound)\n (bigint_num_bits y.upper_bound)\n in\n let%map { less; _ } = Field.Checked.compare ~bit_length x.var y.var in\n less )\n\n let ( <= ) x y =\n let open Bignum_bigint in\n (*\n x [ ]\n y [ ]\n\n x [ ]\n y [ ]\n *)\n with_label \"Number.(<=)\" (fun () ->\n if x.upper_bound <= y.lower_bound then return Boolean.true_\n else if x.lower_bound > y.upper_bound then return Boolean.false_\n else\n let bit_length =\n Int.max\n (bigint_num_bits x.upper_bound)\n (bigint_num_bits y.upper_bound)\n in\n let%map { less_or_equal; _ } =\n Field.Checked.compare ~bit_length x.var y.var\n in\n less_or_equal )\n\n let ( > ) x y = y < x\n\n let ( >= ) x y = y <= x\n\n let ( = ) x y =\n (* TODO: Have \"short circuiting\" for efficiency as above. *)\n Field.Checked.equal x.var y.var\n\n let to_var { var; _ } = var\n\n let constant x =\n let tick_n = Bigint.of_field x in\n let n = Bigint.to_bignum_bigint tick_n in\n { upper_bound = n\n ; lower_bound = n\n ; var = constant Field.typ x\n ; bits =\n Some\n (List.init (bigint_num_bits n) ~f:(fun i ->\n constant Boolean.typ (Bigint.test_bit tick_n i) ) )\n }\n\n let one = constant Field.one\n\n let zero = constant Field.zero\n\n let of_pow_2 (`Two_to_the k) = constant (Field.of_int (Int.pow 2 k))\n\n let if_ b ~then_ ~else_ =\n let%map var = Field.Checked.if_ b ~then_:then_.var ~else_:else_.var in\n let open Bignum_bigint in\n { upper_bound = max then_.upper_bound else_.upper_bound\n ; lower_bound = min then_.lower_bound else_.lower_bound\n ; var\n ; bits = None\n }\n\n let ( + ) x y =\n let open Bignum_bigint in\n let upper_bound = x.upper_bound + y.upper_bound in\n if upper_bound < Field.size then\n { upper_bound\n ; lower_bound = x.lower_bound + y.lower_bound\n ; var = Field.Var.add x.var y.var\n ; bits = None\n }\n else\n failwithf \"Number.+: Potential overflow: (%s + %s > Field.size)\"\n (to_string x.upper_bound) (to_string y.upper_bound) ()\n\n (* Compute (n, k) -> ceil(n / 2^k) using the identity\n\n ceil(n / m)\n =\n if n % m = 0\n then floor(n / m)\n else floor(n / m) + 1\n =\n if m * floor(n / m) = n\n then floor(n / m)\n else floor(n / m) + 1\n *)\n let ceil_div_pow_2 n m =\n let%bind floor_div = div_pow_2 n m in\n let%bind m_divides_n = mul_pow_2 floor_div m >>= ( = ) n in\n if_ m_divides_n ~then_:floor_div ~else_:(floor_div + one)\n\n let ( - ) x y =\n let open Bignum_bigint in\n (* x_upper_bound >= x >= x_lower_bound >= y_upper_bound >= y >= y_lower_bound *)\n if x.lower_bound >= y.upper_bound then\n { upper_bound = x.upper_bound - y.lower_bound\n ; lower_bound = x.lower_bound - y.upper_bound\n ; var = Field.Var.sub x.var y.var\n ; bits = None\n }\n else\n failwithf \"Number.-: Potential underflow (%s < %s)\"\n (to_string x.lower_bound) (to_string y.upper_bound) ()\n\n let ( * ) x y =\n let open Bignum_bigint in\n with_label \"Number.(*)\" (fun () ->\n let upper_bound = x.upper_bound * y.upper_bound in\n if upper_bound < Field.size then\n let%map var = Field.Checked.mul x.var y.var in\n { upper_bound\n ; lower_bound = x.lower_bound * y.lower_bound\n ; var\n ; bits = None\n }\n else\n failwithf \"Number.*: Potential overflow: (%s * %s > Field.size)\"\n (to_string x.upper_bound) (to_string y.upper_bound) () )\n\n (* x mod n = x - n * floor(x / n) *)\n let mod_pow_2 x n =\n let%bind x_div_n = div_pow_2 x n in\n let%map n_x_div_n = mul_pow_2 x_div_n n in\n let res = x - n_x_div_n in\n { res with\n lower_bound = Bignum_bigint.zero\n ; upper_bound =\n (let (`Two_to_the k) = n in\n Bignum_bigint.(pow (of_int 2) (of_int k)) )\n }\n\n let min x y =\n let%bind less = x < y in\n if_ less ~then_:x ~else_:y\n\n let max x y =\n let%bind less = x < y in\n if_ less ~then_:y ~else_:x\nend\n\nmodule Run = struct\n module Make (Impl : Snark_intf.Run_basic) = struct\n open Impl\n include Make (Impl.Internal_Basic)\n\n let ( * ) x y = run_checked (x * y)\n\n let if_ x ~then_ ~else_ = run_checked (if_ x ~then_ ~else_)\n\n let ( < ) x y = run_checked (x < y)\n\n let ( > ) x y = run_checked (x > y)\n\n let ( <= ) x y = run_checked (x <= y)\n\n let ( >= ) x y = run_checked (x >= y)\n\n let ( = ) x y = run_checked (x = y)\n\n let min x y = run_checked (min x y)\n\n let max x y = run_checked (max x y)\n\n let to_bits x = run_checked (to_bits x)\n\n let div_pow_2 x y = run_checked (div_pow_2 x y)\n\n let ceil_div_pow_2 x y = run_checked (ceil_div_pow_2 x y)\n\n let mul_pow_2 x y = run_checked (mul_pow_2 x y)\n\n let mod_pow_2 x y = run_checked (mod_pow_2 x y)\n\n let clamp_to_n_bits x y = run_checked (clamp_to_n_bits x y)\n end\nend\n","include Snark0\nmodule Backend_intf = Backend_intf\nmodule Merkle_tree = Merkle_tree\n","(* shapes.ml -- registry of Bin_prot shapes *)\n\nopen Core_kernel\nmodule Shape_tbl = Hashtbl.Make (Base.String)\n\nlet shape_tbl : (Bin_prot.Shape.t * string) Shape_tbl.t = Shape_tbl.create ()\n\nlet find path_to_type = Shape_tbl.find shape_tbl path_to_type\n\nlet iteri ~f = Shape_tbl.iteri shape_tbl ~f\n\nlet equal_shapes shape1 shape2 =\n let canonical1 = Bin_prot.Shape.eval shape1 in\n let canonical2 = Bin_prot.Shape.eval shape2 in\n Bin_prot.Shape.Canonical.compare canonical1 canonical2 = 0\n\nlet register path_to_type (shape : Bin_prot.Shape.t) (ty_decl : string) =\n match Shape_tbl.add shape_tbl ~key:path_to_type ~data:(shape, ty_decl) with\n | `Ok ->\n ()\n | `Duplicate -> (\n (* versioned types inside functors that are called more than\n once will yield duplicates; OK if the shapes are the same\n *)\n match find path_to_type with\n | Some (shape', _ty_decl) ->\n if not (equal_shapes shape shape') then\n failwithf \"Different type shapes at path %s\" path_to_type ()\n else ()\n | None ->\n failwithf \"Expected to find registered shape at path %s\" path_to_type\n () )\n","(*----------------------------------------------------------------------------\n Copyright (c) 2017 Inhabited Type LLC.\n\n All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions\n are met:\n\n 1. Redistributions of source code must retain the above copyright\n notice, this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in the\n documentation and/or other materials provided with the distribution.\n\n 3. Neither the name of the author nor the names of his contributors\n may be used to endorse or promote products derived from this software\n without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS ``AS IS'' AND ANY EXPRESS\n OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR\n ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\n STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN\n ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n POSSIBILITY OF SUCH DAMAGE.\n ----------------------------------------------------------------------------*)\n\ntype t =\n { mutable parser_committed_bytes : int\n ; client_committed_bytes : int\n ; off : int\n ; len : int\n ; buffer : Bigstringaf.t\n }\n\nlet create buffer ~off ~len ~committed_bytes =\n { parser_committed_bytes = committed_bytes\n ; client_committed_bytes = committed_bytes\n ; off\n ; len\n ; buffer }\n\nlet length t = t.client_committed_bytes + t.len\nlet client_committed_bytes t = t.client_committed_bytes\nlet parser_committed_bytes t = t.parser_committed_bytes\n\nlet committed_bytes_discrepancy t = t.parser_committed_bytes - t.client_committed_bytes\nlet bytes_for_client_to_commit t = committed_bytes_discrepancy t\n\nlet parser_uncommitted_bytes t = t.len - bytes_for_client_to_commit t\n\nlet invariant t =\n assert (parser_committed_bytes t + parser_uncommitted_bytes t = length t);\n assert (parser_committed_bytes t - client_committed_bytes t = bytes_for_client_to_commit t);\n;;\n\nlet offset_in_buffer t pos =\n t.off + pos - t.client_committed_bytes\n\nlet apply t pos len ~f =\n let off = offset_in_buffer t pos in\n f t.buffer ~off ~len\n\nlet unsafe_get_char t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get t.buffer off\n\nlet unsafe_get_int16_le t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int16_le t.buffer off\n\nlet unsafe_get_int32_le t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int32_le t.buffer off\n\nlet unsafe_get_int64_le t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int64_le t.buffer off\n\nlet unsafe_get_int16_be t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int16_be t.buffer off\n\nlet unsafe_get_int32_be t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int32_be t.buffer off\n\nlet unsafe_get_int64_be t pos =\n let off = offset_in_buffer t pos in\n Bigstringaf.unsafe_get_int64_be t.buffer off\n\nlet count_while t pos ~f =\n let buffer = t.buffer in\n let off = offset_in_buffer t pos in\n let i = ref off in\n let limit = t.off + t.len in\n while !i < limit && f (Bigstringaf.unsafe_get buffer !i) do\n incr i\n done;\n !i - off\n;;\n\nlet commit t pos =\n t.parser_committed_bytes <- pos\n;;\n","module State = struct\n type 'a t =\n | Partial of 'a partial\n | Lazy of 'a t Lazy.t\n | Done of int * 'a\n | Fail of int * string list * string\n\n and 'a partial =\n { committed : int\n ; continue : Bigstringaf.t -> off:int -> len:int -> More.t -> 'a t }\n\nend\ntype 'a with_state = Input.t -> int -> More.t -> 'a\n\ntype 'a failure = (string list -> string -> 'a State.t) with_state\ntype ('a, 'r) success = ('a -> 'r State.t) with_state\n\ntype 'a t =\n { run : 'r. ('r failure -> ('a, 'r) success -> 'r State.t) with_state }\n\nlet fail_k input pos _ marks msg =\n State.Fail(pos - Input.client_committed_bytes input, marks, msg)\nlet succeed_k input pos _ v =\n State.Done(pos - Input.client_committed_bytes input, v)\n\nlet rec to_exported_state = function\n | State.Partial {committed;continue} ->\n Exported_state.Partial\n { committed\n ; continue =\n fun bs ~off ~len more ->\n to_exported_state (continue bs ~off ~len more)}\n | State.Done (i,x) -> Exported_state.Done (i,x)\n | State.Fail (i, sl, s) -> Exported_state.Fail (i, sl, s)\n | State.Lazy x -> to_exported_state (Lazy.force x)\n\nlet parse p =\n let input = Input.create Bigstringaf.empty ~committed_bytes:0 ~off:0 ~len:0 in\n to_exported_state (p.run input 0 Incomplete fail_k succeed_k)\n\nlet parse_bigstring p input =\n let input = Input.create input ~committed_bytes:0 ~off:0 ~len:(Bigstringaf.length input) in\n Exported_state.state_to_result (to_exported_state (p.run input 0 Complete fail_k succeed_k))\n\nmodule Monad = struct\n let return v =\n { run = fun input pos more _fail succ ->\n succ input pos more v\n }\n\n let fail msg =\n { run = fun input pos more fail _succ ->\n fail input pos more [] msg\n }\n\n let (>>=) p f =\n { run = fun input pos more fail succ ->\n let succ' input' pos' more' v = (f v).run input' pos' more' fail succ in\n p.run input pos more fail succ'\n }\n\n let (>>|) p f =\n { run = fun input pos more fail succ ->\n let succ' input' pos' more' v = succ input' pos' more' (f v) in\n p.run input pos more fail succ'\n }\n\n let (<$>) f m =\n m >>| f\n\n let (<*>) f m =\n (* f >>= fun f -> m >>| f *)\n { run = fun input pos more fail succ ->\n let succ0 input0 pos0 more0 f =\n let succ1 input1 pos1 more1 m = succ input1 pos1 more1 (f m) in\n m.run input0 pos0 more0 fail succ1\n in\n f.run input pos more fail succ0 }\n\n let lift f m =\n f <$> m\n\n let lift2 f m1 m2 =\n { run = fun input pos more fail succ ->\n let succ1 input1 pos1 more1 m1 =\n let succ2 input2 pos2 more2 m2 = succ input2 pos2 more2 (f m1 m2) in\n m2.run input1 pos1 more1 fail succ2\n in\n m1.run input pos more fail succ1 }\n\n let lift3 f m1 m2 m3 =\n { run = fun input pos more fail succ ->\n let succ1 input1 pos1 more1 m1 =\n let succ2 input2 pos2 more2 m2 =\n let succ3 input3 pos3 more3 m3 =\n succ input3 pos3 more3 (f m1 m2 m3) in\n m3.run input2 pos2 more2 fail succ3 in\n m2.run input1 pos1 more1 fail succ2\n in\n m1.run input pos more fail succ1 }\n\n let lift4 f m1 m2 m3 m4 =\n { run = fun input pos more fail succ ->\n let succ1 input1 pos1 more1 m1 =\n let succ2 input2 pos2 more2 m2 =\n let succ3 input3 pos3 more3 m3 =\n let succ4 input4 pos4 more4 m4 =\n succ input4 pos4 more4 (f m1 m2 m3 m4) in\n m4.run input3 pos3 more3 fail succ4 in\n m3.run input2 pos2 more2 fail succ3 in\n m2.run input1 pos1 more1 fail succ2\n in\n m1.run input pos more fail succ1 }\n\n let ( *>) a b =\n (* a >>= fun _ -> b *)\n { run = fun input pos more fail succ ->\n let succ' input' pos' more' _ = b.run input' pos' more' fail succ in\n a.run input pos more fail succ'\n }\n\n let (<* ) a b =\n (* a >>= fun x -> b >>| fun _ -> x *)\n { run = fun input pos more fail succ ->\n let succ0 input0 pos0 more0 x =\n let succ1 input1 pos1 more1 _ = succ input1 pos1 more1 x in\n b.run input0 pos0 more0 fail succ1\n in\n a.run input pos more fail succ0 }\nend\n\nmodule Choice = struct\n let () p mark =\n { run = fun input pos more fail succ ->\n let fail' input' pos' more' marks msg =\n fail input' pos' more' (mark::marks) msg in\n p.run input pos more fail' succ\n }\n\n let (<|>) p q =\n { run = fun input pos more fail succ ->\n let fail' input' pos' more' marks msg =\n (* The only two constructors that introduce new failure continuations are\n * [] and [<|>]. If the initial input position is less than the length\n * of the committed input, then calling the failure continuation will\n * have the effect of unwinding all choices and collecting marks along\n * the way. *)\n if pos < Input.parser_committed_bytes input' then\n fail input' pos' more marks msg\n else\n q.run input' pos more' fail succ in\n p.run input pos more fail' succ\n }\nend\n\nmodule Monad_use_for_debugging = struct\n let return = Monad.return\n let fail = Monad.fail\n let (>>=) = Monad.(>>=)\n\n let (>>|) m f = m >>= fun x -> return (f x)\n\n let (<$>) f m = m >>| f\n let (<*>) f m = f >>= fun f -> m >>| f\n\n let lift = (>>|)\n let lift2 f m1 m2 = f <$> m1 <*> m2\n let lift3 f m1 m2 m3 = f <$> m1 <*> m2 <*> m3\n let lift4 f m1 m2 m3 m4 = f <$> m1 <*> m2 <*> m3 <*> m4\n\n let ( *>) a b = a >>= fun _ -> b\n let (<* ) a b = a >>= fun x -> b >>| fun _ -> x\nend\n","(*----------------------------------------------------------------------------\n Copyright (c) 2016 Inhabited Type LLC.\n\n All rights reserved.\n\n Redistribution and use in source and binary forms, with or without\n modification, are permitted provided that the following conditions\n are met:\n\n 1. Redistributions of source code must retain the above copyright\n notice, this list of conditions and the following disclaimer.\n\n 2. Redistributions in binary form must reproduce the above copyright\n notice, this list of conditions and the following disclaimer in the\n documentation and/or other materials provided with the distribution.\n\n 3. Neither the name of the author nor the names of his contributors\n may be used to endorse or promote products derived from this software\n without specific prior written permission.\n\n THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS ``AS IS'' AND ANY EXPRESS\n OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE FOR\n ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\n STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN\n ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n POSSIBILITY OF SUCH DAMAGE.\n ----------------------------------------------------------------------------*)\n\nmodule Bigarray = struct\n (* Do not access Bigarray operations directly. If anything's needed, refer to\n * the internal Bigstring module. *)\nend\n\ntype bigstring = Bigstringaf.t\n\n\nmodule Unbuffered = struct\n include Parser\n\n include Exported_state\n\n type more = More.t =\n | Complete\n | Incomplete\nend\n\ninclude Unbuffered\ninclude Parser.Monad\ninclude Parser.Choice\n\nmodule Buffered = struct\n type unconsumed = Buffering.unconsumed =\n { buf : bigstring\n ; off : int\n ; len : int }\n\n type input =\n [ `Bigstring of bigstring\n | `String of string ]\n\n type 'a state =\n | Partial of ([ input | `Eof ] -> 'a state)\n | Done of unconsumed * 'a\n | Fail of unconsumed * string list * string\n\n let from_unbuffered_state ~f buffering = function\n | Unbuffered.Partial p -> Partial (f p)\n | Unbuffered.Done(consumed, v) ->\n let unconsumed = Buffering.unconsumed ~shift:consumed buffering in\n Done(unconsumed, v)\n | Unbuffered.Fail(consumed, marks, msg) ->\n let unconsumed = Buffering.unconsumed ~shift:consumed buffering in\n Fail(unconsumed, marks, msg)\n\n let parse ?(initial_buffer_size=0x1000) p =\n if initial_buffer_size < 1 then\n failwith \"parse: invalid argument, initial_buffer_size < 1\";\n let buffering = Buffering.create initial_buffer_size in\n let rec f p input =\n Buffering.shift buffering p.committed;\n let more : More.t =\n match input with\n | `Eof -> Complete\n | #input as input ->\n Buffering.feed_input buffering input;\n Incomplete\n in\n let for_reading = Buffering.for_reading buffering in\n p.continue for_reading ~off:0 ~len:(Bigstringaf.length for_reading) more\n |> from_unbuffered_state buffering ~f\n in\n Unbuffered.parse p\n |> from_unbuffered_state buffering ~f\n\n let feed state input =\n match state with\n | Partial k -> k input\n | Fail(unconsumed, marks, msg) ->\n begin match input with\n | `Eof -> state\n | #input as input ->\n let buffering = Buffering.of_unconsumed unconsumed in\n Buffering.feed_input buffering input;\n Fail(Buffering.unconsumed buffering, marks, msg)\n end\n | Done(unconsumed, v) ->\n begin match input with\n | `Eof -> state\n | #input as input ->\n let buffering = Buffering.of_unconsumed unconsumed in\n Buffering.feed_input buffering input;\n Done(Buffering.unconsumed buffering, v)\n end\n\n let state_to_option = function\n | Done(_, v) -> Some v\n | Partial _ -> None\n | Fail _ -> None\n\n let state_to_result = function\n | Partial _ -> Error \"incomplete input\"\n | Done(_, v) -> Ok v\n | Fail(_, marks, msg) -> Error (Unbuffered.fail_to_string marks msg)\n\n let state_to_unconsumed = function\n | Done(unconsumed, _)\n | Fail(unconsumed, _, _) -> Some unconsumed\n | Partial _ -> None\n\nend\n\n(** BEGIN: getting input *)\n\nlet rec prompt input pos fail succ =\n (* [prompt] should only call [succ] if it has received more input. If there\n * is no chance that the input will grow, i.e., [more = Complete], then\n * [prompt] should call [fail]. Otherwise (in the case where the input\n * hasn't grown but [more = Incomplete] just prompt again. *)\n let parser_uncommitted_bytes = Input.parser_uncommitted_bytes input in\n let parser_committed_bytes = Input.parser_committed_bytes input in\n (* The continuation should not hold any references to input above. *)\n let continue input ~off ~len more =\n if len < parser_uncommitted_bytes then\n failwith \"prompt: input shrunk!\";\n let input = Input.create input ~off ~len ~committed_bytes:parser_committed_bytes in\n if len = parser_uncommitted_bytes then\n match (more : More.t) with\n | Complete -> fail input pos More.Complete\n | Incomplete -> prompt input pos fail succ\n else\n succ input pos more\n in\n State.Partial { committed = Input.bytes_for_client_to_commit input; continue }\n\nlet demand_input =\n { run = fun input pos more fail succ ->\n match (more : More.t) with\n | Complete -> fail input pos more [] \"not enough input\"\n | Incomplete ->\n let succ' input' pos' more' = succ input' pos' more' ()\n and fail' input' pos' more' = fail input' pos' more' [] \"not enough input\" in\n prompt input pos fail' succ'\n }\n\nlet ensure_suspended n input pos more fail succ =\n let rec go =\n { run = fun input' pos' more' fail' succ' ->\n if pos' + n <= Input.length input' then\n succ' input' pos' more' ()\n else\n (demand_input *> go).run input' pos' more' fail' succ'\n }\n in\n (demand_input *> go).run input pos more fail succ\n\nlet unsafe_apply len ~f =\n { run = fun input pos more _fail succ ->\n succ input (pos + len) more (Input.apply input pos len ~f)\n }\n\nlet unsafe_apply_opt len ~f =\n { run = fun input pos more fail succ ->\n match Input.apply input pos len ~f with\n | Error e -> fail input pos more [] e\n | Ok x -> succ input (pos + len) more x\n }\n\nlet ensure n p =\n { run = fun input pos more fail succ ->\n if pos + n <= Input.length input\n then p.run input pos more fail succ\n else\n let succ' input' pos' more' () = p.run input' pos' more' fail succ in\n ensure_suspended n input pos more fail succ' }\n\n(** END: getting input *)\n\nlet at_end_of_input =\n { run = fun input pos more _ succ ->\n if pos < Input.length input then\n succ input pos more false\n else match more with\n | Complete -> succ input pos more true\n | Incomplete ->\n let succ' input' pos' more' = succ input' pos' more' false\n and fail' input' pos' more' = succ input' pos' more' true in\n prompt input pos fail' succ'\n }\n\nlet end_of_input =\n at_end_of_input\n >>= function\n | true -> return ()\n | false -> fail \"end_of_input\"\n\nlet advance n =\n if n < 0\n then fail \"advance\"\n else\n let p =\n { run = fun input pos more _fail succ -> succ input (pos + n) more () }\n in\n ensure n p\n\nlet pos =\n { run = fun input pos more _fail succ -> succ input pos more pos }\n\nlet available =\n { run = fun input pos more _fail succ ->\n succ input pos more (Input.length input - pos)\n }\n\nlet commit =\n { run = fun input pos more _fail succ ->\n Input.commit input pos;\n succ input pos more () }\n\n(* Do not use this if [p] contains a [commit]. *)\nlet unsafe_lookahead p =\n { run = fun input pos more fail succ ->\n let succ' input' _ more' v = succ input' pos more' v in\n p.run input pos more fail succ' }\n\nlet peek_char =\n { run = fun input pos more _fail succ ->\n if pos < Input.length input then\n succ input pos more (Some (Input.unsafe_get_char input pos))\n else if more = Complete then\n succ input pos more None\n else\n let succ' input' pos' more' =\n succ input' pos' more' (Some (Input.unsafe_get_char input' pos'))\n and fail' input' pos' more' =\n succ input' pos' more' None in\n prompt input pos fail' succ'\n }\n\n(* This parser is too important to not be optimized. Do a custom job. *)\nlet rec peek_char_fail =\n { run = fun input pos more fail succ ->\n if pos < Input.length input\n then succ input pos more (Input.unsafe_get_char input pos)\n else\n let succ' input' pos' more' () =\n peek_char_fail.run input' pos' more' fail succ in\n ensure_suspended 1 input pos more fail succ' }\n\nlet satisfy f =\n { run = fun input pos more fail succ ->\n if pos < Input.length input then\n let c = Input.unsafe_get_char input pos in\n if f c\n then succ input (pos + 1) more c\n else Printf.ksprintf (fail input pos more []) \"satisfy: %C\" c\n else\n let succ' input' pos' more' () =\n let c = Input.unsafe_get_char input' pos' in\n if f c\n then succ input' (pos' + 1) more' c\n else Printf.ksprintf (fail input' pos' more' []) \"satisfy: %C\" c\n in\n ensure_suspended 1 input pos more fail succ' }\n\nlet char c =\n let p =\n { run = fun input pos more fail succ ->\n if Input.unsafe_get_char input pos = c\n then succ input (pos + 1) more c\n else fail input pos more [] (Printf.sprintf \"char %C\" c) }\n in\n ensure 1 p\n\nlet not_char c =\n let p =\n { run = fun input pos more fail succ ->\n let c' = Input.unsafe_get_char input pos in\n if c <> c'\n then succ input (pos + 1) more c'\n else fail input pos more [] (Printf.sprintf \"not char %C\" c) }\n in\n ensure 1 p\n\nlet any_char =\n let p =\n { run = fun input pos more _fail succ ->\n succ input (pos + 1) more (Input.unsafe_get_char input pos) }\n in\n ensure 1 p\n\nlet int8 i =\n let p =\n { run = fun input pos more fail succ ->\n let c = Char.code (Input.unsafe_get_char input pos) in\n if c = i land 0xff\n then succ input (pos + 1) more c\n else fail input pos more [] (Printf.sprintf \"int8 %d\" i) }\n in\n ensure 1 p\n\nlet any_uint8 =\n let p =\n { run = fun input pos more _fail succ ->\n let c = Input.unsafe_get_char input pos in\n succ input (pos + 1) more (Char.code c) }\n in\n ensure 1 p\n\nlet any_int8 =\n (* https://graphics.stanford.edu/~seander/bithacks.html#VariableSignExtendRisky *)\n let s = Sys.int_size - 8 in\n let p =\n { run = fun input pos more _fail succ ->\n let c = Input.unsafe_get_char input pos in\n succ input (pos + 1) more ((Char.code c lsl s) asr s) }\n in\n ensure 1 p\n\nlet skip f =\n let p =\n { run = fun input pos more fail succ ->\n if f (Input.unsafe_get_char input pos)\n then succ input (pos + 1) more ()\n else fail input pos more [] \"skip\" }\n in\n ensure 1 p\n\nlet rec count_while ~init ~f ~with_buffer =\n { run = fun input pos more fail succ ->\n let len = Input.count_while input (pos + init) ~f in\n let input_len = Input.length input in\n let init' = init + len in\n (* Check if the loop terminated because it reached the end of the input\n * buffer. If so, then prompt for additional input and continue. *)\n if pos + init' < input_len || more = Complete\n then succ input (pos + init') more (Input.apply input pos init' ~f:with_buffer)\n else\n let succ' input' pos' more' =\n (count_while ~init:init' ~f ~with_buffer).run input' pos' more' fail succ\n and fail' input' pos' more' =\n succ input' (pos' + init') more' (Input.apply input' pos' init' ~f:with_buffer)\n in\n prompt input pos fail' succ'\n }\n\nlet rec count_while1 ~f ~with_buffer =\n { run = fun input pos more fail succ ->\n let len = Input.count_while input pos ~f in\n let input_len = Input.length input in\n (* Check if the loop terminated because it reached the end of the input\n * buffer. If so, then prompt for additional input and continue. *)\n if len < 1\n then\n if pos < input_len || more = Complete\n then fail input pos more [] \"count_while1\"\n else\n let succ' input' pos' more' =\n (count_while1 ~f ~with_buffer).run input' pos' more' fail succ\n and fail' input' pos' more' =\n fail input' pos' more' [] \"count_while1\"\n in\n prompt input pos fail' succ'\n else if pos + len < input_len || more = Complete\n then succ input (pos + len) more (Input.apply input pos len ~f:with_buffer)\n else\n let succ' input' pos' more' =\n (count_while ~init:len ~f ~with_buffer).run input' pos' more' fail succ\n and fail' input' pos' more' =\n succ input' (pos' + len) more' (Input.apply input' pos' len ~f:with_buffer)\n in\n prompt input pos fail' succ'\n }\n\nlet string_ f s =\n (* XXX(seliopou): Inefficient. Could check prefix equality to short-circuit\n * the io. *)\n let len = String.length s in\n ensure len (unsafe_apply_opt len ~f:(fun buffer ~off ~len ->\n let i = ref 0 in\n while !i < len && Char.equal (f (Bigstringaf.unsafe_get buffer (off + !i)))\n (f (String.unsafe_get s !i))\n do\n incr i\n done;\n if len = !i\n then Ok (Bigstringaf.substring buffer ~off ~len)\n else Error \"string\"))\n\nlet string s = string_ (fun x -> x) s\nlet string_ci s = string_ Char.lowercase_ascii s\n\nlet skip_while f =\n count_while ~init:0 ~f ~with_buffer:(fun _ ~off:_ ~len:_ -> ())\n\nlet take n =\n if n < 0\n then fail \"take: n < 0\"\n else\n let n = max n 0 in\n ensure n (unsafe_apply n ~f:Bigstringaf.substring)\n\nlet take_bigstring n =\n if n < 0\n then fail \"take_bigstring: n < 0\"\n else\n let n = max n 0 in\n ensure n (unsafe_apply n ~f:Bigstringaf.copy)\n\nlet take_bigstring_while f =\n count_while ~init:0 ~f ~with_buffer:Bigstringaf.copy\n\nlet take_bigstring_while1 f =\n count_while1 ~f ~with_buffer:Bigstringaf.copy\n\nlet take_bigstring_till f =\n take_bigstring_while (fun c -> not (f c))\n\nlet peek_string n =\n unsafe_lookahead (take n)\n\nlet take_while f =\n count_while ~init:0 ~f ~with_buffer:Bigstringaf.substring\n\nlet take_while1 f =\n count_while1 ~f ~with_buffer:Bigstringaf.substring\n\nlet take_till f =\n take_while (fun c -> not (f c))\n\nlet choice ?(failure_msg=\"no more choices\") ps =\n List.fold_right (<|>) ps (fail failure_msg)\n\nlet fix_direct f =\n let rec p = lazy (f r)\n and r = { run = fun buf pos more fail succ ->\n (Lazy.force p).run buf pos more fail succ }\n in\n r\n\nlet fix_lazy f =\n let max_steps = 20 in\n let steps = ref max_steps in\n let rec p = lazy (f r)\n and r = { run = fun buf pos more fail succ ->\n decr steps;\n if !steps < 0\n then (\n steps := max_steps;\n State.Lazy (lazy ((Lazy.force p).run buf pos more fail succ)))\n else\n (Lazy.force p).run buf pos more fail succ\n }\n in\n r\n\nlet fix = match Sys.backend_type with\n | Native -> fix_direct\n | Bytecode -> fix_direct\n | Other _ -> fix_lazy\n\nlet option x p =\n p <|> return x\n\nlet cons x xs = x :: xs\n\nlet rec list ps =\n match ps with\n | [] -> return []\n | p::ps -> lift2 cons p (list ps)\n\nlet count n p =\n if n < 0 \n then fail \"count: n < 0\"\n else \n let rec loop = function\n | 0 -> return []\n | n -> lift2 cons p (loop (n - 1))\n in\n loop n\n\nlet many p =\n fix (fun m ->\n (lift2 cons p m) <|> return [])\n\nlet many1 p =\n lift2 cons p (many p)\n\nlet many_till p t =\n fix (fun m ->\n (t *> return []) <|> (lift2 cons p m))\n\nlet sep_by1 s p =\n fix (fun m ->\n lift2 cons p ((s *> m) <|> return []))\n\nlet sep_by s p =\n (lift2 cons p ((s *> sep_by1 s p) <|> return [])) <|> return []\n\nlet skip_many p =\n fix (fun m ->\n (p *> m) <|> return ())\n\nlet skip_many1 p =\n p *> skip_many p\n\nlet end_of_line =\n (char '\\n' *> return ()) <|> (string \"\\r\\n\" *> return ()) \"end_of_line\"\n\nlet scan_ state f ~with_buffer =\n { run = fun input pos more fail succ ->\n let state = ref state in\n let parser =\n count_while ~init:0 ~f:(fun c ->\n match f !state c with\n | None -> false\n | Some state' -> state := state'; true)\n ~with_buffer\n >>| fun x -> x, !state\n in\n parser.run input pos more fail succ }\n\nlet scan state f =\n scan_ state f ~with_buffer:Bigstringaf.substring\n\nlet scan_state state f =\n scan_ state f ~with_buffer:(fun _ ~off:_ ~len:_ -> ())\n >>| fun ((), state) -> state\n\nlet scan_string state f =\n scan state f >>| fst\n\nlet consume_with p f =\n { run = fun input pos more fail succ ->\n let start = pos in\n let parser_committed_bytes = Input.parser_committed_bytes input in\n let succ' input' pos' more' _ =\n if parser_committed_bytes <> Input.parser_committed_bytes input'\n then fail input' pos' more' [] \"consumed: parser committed\"\n else (\n let len = pos' - start in\n let consumed = Input.apply input' start len ~f in\n succ input' pos' more' consumed)\n in\n p.run input pos more fail succ'\n }\n\nlet consumed p = consume_with p Bigstringaf.substring\nlet consumed_bigstring p = consume_with p Bigstringaf.copy\n\nlet both a b = lift2 (fun a b -> a, b) a b\nlet map t ~f = t >>| f\nlet bind t ~f = t >>= f\nlet map2 a b ~f = lift2 f a b\nlet map3 a b c ~f = lift3 f a b c\nlet map4 a b c d ~f = lift4 f a b c d\n\nmodule Let_syntax = struct\n let return = return\n let ( >>| ) = ( >>| )\n let ( >>= ) = ( >>= )\n\n module Let_syntax = struct\n let return = return\n let map = map\n let bind = bind\n let both = both\n let map2 = map2\n let map3 = map3\n let map4 = map4\n end\nend\n\nlet ( let+ ) = ( >>| )\nlet ( let* ) = ( >>= )\nlet ( and+ ) = both\n\nmodule BE = struct\n (* XXX(seliopou): The pattern in both this module and [LE] are a compromise\n * between efficiency and code reuse. By inlining [ensure] you can recover\n * about 2 nanoseconds on average. That may add up in certain applications.\n *\n * This pattern does not allocate in the fast (success) path.\n * *)\n let int16 n =\n let bytes = 2 in\n let p =\n { run = fun input pos more fail succ ->\n if Input.unsafe_get_int16_be input pos = (n land 0xffff)\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"BE.int16\" }\n in\n ensure bytes p\n\n let int32 n =\n let bytes = 4 in\n let p =\n { run = fun input pos more fail succ ->\n if Int32.equal (Input.unsafe_get_int32_be input pos) n\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"BE.int32\" }\n in\n ensure bytes p\n\n let int64 n =\n let bytes = 8 in\n let p =\n { run = fun input pos more fail succ ->\n if Int64.equal (Input.unsafe_get_int64_be input pos) n\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"BE.int64\" }\n in\n ensure bytes p\n\n let any_uint16 =\n ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_be bs off))\n\n let any_int16 =\n ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_sign_extended_be bs off))\n\n let any_int32 =\n ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int32_be bs off))\n\n let any_int64 =\n ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int64_be bs off))\n\n let any_float =\n ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Int32.float_of_bits (Bigstringaf.unsafe_get_int32_be bs off)))\n\n let any_double =\n ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Int64.float_of_bits (Bigstringaf.unsafe_get_int64_be bs off)))\nend\n\nmodule LE = struct\n let int16 n =\n let bytes = 2 in\n let p =\n { run = fun input pos more fail succ ->\n if Input.unsafe_get_int16_le input pos = (n land 0xffff)\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"LE.int16\" }\n in\n ensure bytes p\n\n let int32 n =\n let bytes = 4 in\n let p =\n { run = fun input pos more fail succ ->\n if Int32.equal (Input.unsafe_get_int32_le input pos) n\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"LE.int32\" }\n in\n ensure bytes p\n\n let int64 n =\n let bytes = 8 in\n let p =\n { run = fun input pos more fail succ ->\n if Int64.equal (Input.unsafe_get_int64_le input pos) n\n then succ input (pos + bytes) more ()\n else fail input pos more [] \"LE.int64\" }\n in\n ensure bytes p\n\n\n let any_uint16 =\n ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_le bs off))\n\n let any_int16 =\n ensure 2 (unsafe_apply 2 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int16_sign_extended_le bs off))\n\n let any_int32 =\n ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int32_le bs off))\n\n let any_int64 =\n ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Bigstringaf.unsafe_get_int64_le bs off))\n\n let any_float =\n ensure 4 (unsafe_apply 4 ~f:(fun bs ~off ~len:_ -> Int32.float_of_bits (Bigstringaf.unsafe_get_int32_le bs off)))\n\n let any_double =\n ensure 8 (unsafe_apply 8 ~f:(fun bs ~off ~len:_ -> Int64.float_of_bits (Bigstringaf.unsafe_get_int64_le bs off)))\nend\n\nmodule Unsafe = struct\n let take n f =\n let n = max n 0 in\n ensure n (unsafe_apply n ~f)\n\n let peek n f =\n unsafe_lookahead (take n f)\n\n let take_while check f =\n count_while ~init:0 ~f:check ~with_buffer:f\n\n let take_while1 check f =\n count_while1 ~f:check ~with_buffer:f\n\n let take_till check f =\n take_while (fun c -> not (check c)) f\nend\n\nmodule Consume = struct\n type t =\n | Prefix\n | All\nend\n\nlet parse_bigstring ~consume p bs =\n let p =\n match (consume : Consume.t) with\n | Prefix -> p\n | All -> p <* end_of_input\n in\n Unbuffered.parse_bigstring p bs\n\nlet parse_string ~consume p s =\n let len = String.length s in\n let bs = Bigstringaf.create len in\n Bigstringaf.unsafe_blit_from_string s ~src_off:0 bs ~dst_off:0 ~len;\n parse_bigstring ~consume p bs\n","open Core_kernel\n\ntype mode = Hidden | Inline | After\n\ntype config =\n { mode : mode; max_interpolation_length : int; pretty_print : bool }\n\nlet rec result_fold_left ls ~init ~f =\n match ls with\n | [] ->\n Ok init\n | h :: t -> (\n match f init h with\n | Ok init' ->\n result_fold_left t ~init:init' ~f\n | Error err ->\n Error err )\n\nlet parser =\n let open Angstrom in\n let not_f f x = not (f x) in\n let or_f f g x = f x || g x in\n let is_alpha = function\n | 'a' .. 'z' | 'A' .. 'Z' | '_' ->\n true\n | _ ->\n false\n in\n let is_numeric = function '0' .. '9' -> true | _ -> false in\n let interpolation =\n lift2\n (fun c s -> String.of_char c ^ s)\n (char '$' *> commit *> satisfy is_alpha)\n (take_while (or_f is_alpha is_numeric))\n in\n let message =\n many1\n (choice\n [ (take_while1 (not_f (Char.equal '$')) >>| fun x -> `Raw x)\n ; (interpolation >>| fun x -> `Interpolate x)\n ] )\n in\n message <* end_of_input\n\nlet parse = Angstrom.parse_string ~consume:All parser\n\n(* map and concat vs. fold: which is better for strings? *)\nlet render ~max_interpolation_length ~format_json metadata items =\n let open Result.Let_syntax in\n let%map msg, extra =\n result_fold_left items ~init:(\"\", []) ~f:(fun (msg_acc, extra_acc) el ->\n match el with\n | `Raw str ->\n Ok (msg_acc ^ str, extra_acc)\n | `Interpolate id ->\n let%map json =\n String.Map.find metadata id\n |> Result.of_option ~error:(sprintf \"bad interpolation for %s\" id)\n in\n let str = format_json json in\n if String.length str > max_interpolation_length then\n (msg_acc ^ \"$\" ^ id, (id, str) :: extra_acc)\n else (msg_acc ^ str, extra_acc) )\n in\n (msg, List.rev extra)\n\nlet interpolate { mode; max_interpolation_length; pretty_print } msg metadata =\n let open Result.Let_syntax in\n let format_json =\n if pretty_print then Yojson.Safe.pretty_to_string\n else Yojson.Safe.to_string ?buf:None ?len:None\n in\n match mode with\n | Hidden ->\n Ok (msg, [])\n | Inline ->\n let%bind items = parse msg in\n render ~max_interpolation_length ~format_json metadata items\n | After ->\n Ok\n ( msg\n , List.map (String.Map.to_alist metadata) ~f:(fun (k, v) ->\n (k, format_json v) ) )\n","open Core_kernel\n\ntype t = ..\n\ntype id = string [@@deriving equal, yojson, sexp]\n\nmodule Set = String.Set\n\nlet id_of_string s = s\n\nlet string_of_id s = s\n\ntype repr =\n { id : id\n ; event_name : string\n ; arguments : String.Set.t\n ; log : t -> (string * (string * Yojson.Safe.t) list) option\n ; parse : (string * Yojson.Safe.t) list -> t option\n }\n\nmodule Registry = struct\n let reprs : repr list ref = ref []\n\n let register_constructor repr = reprs := repr :: !reprs\nend\n\nlet parse_exn id json_pairs =\n let result =\n List.find_map !Registry.reprs ~f:(fun repr ->\n if equal_id id repr.id then\n let json_pairs =\n (* Remove additional metadata that may have been added to the log\n message.\n *)\n List.filter json_pairs ~f:(fun (field_name, _) ->\n Set.mem repr.arguments field_name )\n in\n match repr.parse json_pairs with\n | Some t ->\n Some t\n | None ->\n failwithf\n \"parse_exn: parser for id %s found, but failed when applied to \\\n arguments: %s\"\n id\n ( List.map json_pairs ~f:(fun (name, json) ->\n sprintf \"%s = %s\" name (Yojson.Safe.to_string json) )\n |> String.concat ~sep:\",\" )\n ()\n else None )\n in\n match result with\n | Some data ->\n data\n | None ->\n failwithf \"parse_exn: did not find matching parser for id %s\" id ()\n\nlet log t =\n let result =\n List.find_map !Registry.reprs ~f:(fun repr ->\n Option.map (repr.log t) ~f:(fun (msg, fields) -> (msg, repr.id, fields)) )\n in\n match result with\n | Some data ->\n data\n | None ->\n let[@warning \"-3\"] name =\n Obj.extension_name (Obj.extension_constructor t)\n in\n failwithf \"log: did not find matching logger for %s\" name ()\n\nlet register_constructor = Registry.register_constructor\n\nlet dump_registered_events () =\n List.map !Registry.reprs ~f:(fun { event_name; id; arguments; _ } ->\n (event_name, id, Set.to_list arguments) )\n\nlet check_interpolations_exn ~msg_loc msg label_names =\n (* don't use Logproc_lib, which depends on C++ code\n using Interpolator_lib allows use in js_of_ocaml\n the `parse` code is the same\n *)\n match Interpolator_lib.Interpolator.parse msg with\n | Error err ->\n failwithf\n \"%s\\nEncountered an error while parsing the structured log message: %s\"\n msg_loc err ()\n | Ok items ->\n List.iter items ~f:(function\n | `Interpolate interp\n when not (List.mem ~equal:String.equal label_names interp) ->\n failwithf\n \"%s\\n\\\n The structured log message contains interpolation point \\\"$%s\\\" \\\n which is not a field in the record\"\n msg_loc interp ()\n | _ ->\n () )\n","type z = Z of z\n\ntype 'a s = Z | S of 'a\n\ntype _ t = Z : z t | S : 'n t -> 'n s t\n\ntype 'a nat = 'a t\n\ntype e = T : 'n nat -> e\n\nlet to_int : type n. n t -> int =\n let rec go : type n. int -> n t -> int =\n fun acc n -> match n with Z -> acc | S n -> go (acc + 1) n\n in\n fun x -> go 0 x\n\nlet rec of_int : int -> e =\n fun n ->\n if n < 0 then failwith \"of_int: negative\"\n else if n = 0 then T Z\n else\n let (T n) = of_int (n - 1) in\n T (S n)\n\nmodule type Intf = sig\n type n\n\n val n : n t\nend\n\nmodule Adds = struct\n type ('a, 'b, 'c) t =\n | Z : (z, 'n, 'n) t\n | S : ('a, 'b, 'c) t -> ('a s, 'b, 'c s) t\n\n let rec add_zr : type n. n nat -> (n, z, n) t = function\n | Z ->\n Z\n | S n ->\n let pi = add_zr n in\n S pi\nend\n\nmodule Lte = struct\n type (_, _) t = Z : (z, _) t | S : ('n, 'm) t -> ('n s, 'm s) t\n\n let rec refl : type n. n nat -> (n, n) t = function\n | Z ->\n Z\n | S n ->\n S (refl n)\n\n let rec trans : type a b c. (a, b) t -> (b, c) t -> (a, c) t =\n fun t1 t2 -> match (t1, t2) with Z, _ -> Z | S t1, S t2 -> S (trans t1 t2)\nend\n\nmodule N0 = struct\n type 'a plus_n = 'a\n\n type n = z\n\n let n = Z\n\n let add m = (m, Adds.Z)\n\n let eq = Core_kernel.Type_equal.T\nend\n\nmodule Add = struct\n module type Intf = sig\n type _ plus_n\n\n type n\n\n val eq : (n, z plus_n) Core_kernel.Type_equal.t\n\n val n : z plus_n t\n\n val add : 'm nat -> 'm plus_n nat * (z plus_n, 'm, 'm plus_n) Adds.t\n end\n\n let rec create : type n. n nat -> (module Intf with type n = n) = function\n | Z ->\n (module N0)\n | S n ->\n let (module N) = create n in\n let T = N.eq in\n let module Sn = struct\n type 'a plus_n = 'a N.plus_n s\n\n type n = N.n s\n\n let n = S N.n\n\n let eq = Core_kernel.Type_equal.T\n\n let add t =\n let t_plus_n, pi = N.add t in\n (S t_plus_n, Adds.S pi)\n end in\n (module Sn)\n\n let n : type n. (module Intf with type n = n) -> n nat =\n fun (module N) ->\n let T = N.eq in\n N.n\n\n module type Intf_transparent = sig\n type _ plus_n\n\n type n = z plus_n\n\n val eq : (n, z plus_n) Core_kernel.Type_equal.t\n\n val n : z plus_n t\n\n val add : 'm nat -> 'm plus_n nat * (z plus_n, 'm, 'm plus_n) Adds.t\n end\nend\n\nmodule S (N : Add.Intf) = struct\n type 'a plus_n = 'a N.plus_n s\n\n type n = z plus_n\n\n let n = S N.n\n\n let add m =\n let k, pi = N.add m in\n (S k, Adds.S pi)\n\n let eq = match N.eq with T -> Core_kernel.Type_equal.T\nend\n\nmodule N1 = S (N0)\nmodule N2 = S (N1)\nmodule N3 = S (N2)\nmodule N4 = S (N3)\nmodule N5 = S (N4)\nmodule N6 = S (N5)\nmodule N7 = S (N6)\nmodule N8 = S (N7)\nmodule N9 = S (N8)\nmodule N10 = S (N9)\nmodule N11 = S (N10)\nmodule N12 = S (N11)\nmodule N13 = S (N12)\nmodule N14 = S (N13)\nmodule N15 = S (N14)\nmodule N16 = S (N15)\nmodule N17 = S (N16)\nmodule N18 = S (N17)\nmodule N19 = S (N18)\nmodule N20 = S (N19)\nmodule N21 = S (N20)\nmodule N22 = S (N21)\nmodule N23 = S (N22)\nmodule N24 = S (N23)\nmodule N25 = S (N24)\nmodule N26 = S (N25)\nmodule N27 = S (N26)\nmodule N28 = S (N27)\nmodule N29 = S (N28)\nmodule N30 = S (N29)\nmodule N31 = S (N30)\nmodule N32 = S (N31)\nmodule N33 = S (N32)\nmodule N34 = S (N33)\nmodule N35 = S (N34)\nmodule N36 = S (N35)\nmodule N37 = S (N36)\nmodule N38 = S (N37)\nmodule N39 = S (N38)\nmodule N40 = S (N39)\nmodule N41 = S (N40)\nmodule N42 = S (N41)\nmodule N43 = S (N42)\nmodule N44 = S (N43)\nmodule N45 = S (N44)\nmodule N46 = S (N45)\nmodule N47 = S (N46)\nmodule N48 = S (N47)\n\nmodule Empty = struct\n type t = T of t\n\n let rec elim : type a. t -> a = function T t -> elim t\nend\n\nmodule Not = struct\n type 'a t = 'a -> Empty.t\nend\n\nopen Core_kernel\n\nlet rec compare :\n type n m. n t -> m t -> [ `Lte of (n, m) Lte.t | `Gt of (n, m) Lte.t Not.t ]\n =\n fun n m ->\n match (n, m) with\n | Z, _ ->\n `Lte Lte.Z\n | S _, Z ->\n `Gt (function _ -> .)\n | S n, S m -> (\n match compare n m with\n | `Lte pi ->\n `Lte (S pi)\n | `Gt gt ->\n `Gt (function S pi -> gt pi) )\n\nlet lte_exn n m =\n match compare n m with `Lte pi -> pi | `Gt _gt -> failwith \"lte_exn\"\n\nlet rec gt_implies_gte :\n type n m. n nat -> m nat -> (n, m) Lte.t Not.t -> (m, n) Lte.t =\n fun n m not_lte ->\n match (n, m) with\n | Z, _ ->\n Empty.elim (not_lte Z)\n | S _, Z ->\n Z\n | S n, S m ->\n S (gt_implies_gte n m (fun pi -> not_lte (S pi)))\n\nlet rec eq :\n type n m.\n n nat\n -> m nat\n -> [ `Equal of (n, m) Type_equal.t\n | `Not_equal of (n, m) Type_equal.t Not.t ] =\n fun n m ->\n match (n, m) with\n | Z, Z ->\n `Equal T\n | S _, Z ->\n `Not_equal (function _ -> .)\n | Z, S _ ->\n `Not_equal (function _ -> .)\n | S n, S m -> (\n match eq n m with\n | `Equal T ->\n `Equal T\n | `Not_equal f ->\n `Not_equal (function T -> f T) )\n\nlet eq_exn : type n m. n nat -> m nat -> (n, m) Type_equal.t =\n fun n m ->\n match eq n m with\n | `Equal t ->\n t\n | `Not_equal _ ->\n failwithf \"eq_exn: %d vs %d\" (to_int n) (to_int m) ()\n\nmodule type I = Add.Intf_transparent\n","module Length = struct\n type (_, _) t =\n | Z : (unit, Nat.z) t\n | S : ('tail, 'n) t -> ('a * 'tail, 'n Nat.s) t\n\n let rec to_nat : type xs n. (xs, n) t -> n Nat.t = function\n | Z ->\n Z\n | S n ->\n S (to_nat n)\n\n type 'xs n = T : 'n Nat.t * ('xs, 'n) t -> 'xs n\n\n let rec contr :\n type xs n m. (xs, n) t -> (xs, m) t -> (n, m) Core_kernel.Type_equal.t =\n fun t1 t2 ->\n match (t1, t2) with\n | Z, Z ->\n T\n | S n, S m ->\n let T = contr n m in\n T\nend\n\nmodule H1 (F : Poly_types.T1) = struct\n type _ t = [] : unit t | ( :: ) : 'a F.t * 'b t -> ('a * 'b) t\n\n let rec length : type tail1. tail1 t -> tail1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\nend\n\nmodule H1_1 (F : Poly_types.T2) = struct\n type (_, 's) t =\n | [] : (unit, _) t\n | ( :: ) : ('a, 's) F.t * ('b, 's) t -> ('a * 'b, 's) t\n\n let rec length : type tail1 tail2. (tail1, tail2) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\nend\n\nmodule Id = struct\n type 'a t = 'a\nend\n\nmodule HlistId = H1 (Id)\n","open Core_kernel\nopen Pickles_types\nmodule Max_state_size = Nat.N8\n\nmodule V = struct\n (* Think about versioning here! These vector types *will* change\n serialization if the numbers above change, and so will require a new\n version number. Thus, it's important that these are modules with new\n versioned types, and not just module aliases to the corresponding vector\n implementation.\n *)\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = 'a Vector.Vector_8.Stable.V1.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n type 'a t = 'a Vector.Vector_8.t\n [@@deriving compare, yojson, sexp, hash, equal]\n\n let map = Vector.map\n\n let of_list_exn = Vector.Vector_8.of_list_exn\n\n let to_list = Vector.to_list\nend\n\nlet _type_equal :\n type a. (a V.t, a Vector.With_length(Max_state_size).t) Type_equal.t =\n Type_equal.T\n\nlet typ t = Vector.typ t Max_state_size.n\n\nopen Core_kernel\n\nmodule Value = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t = Zkapp_basic.F.Stable.V1.t V.Stable.V1.t\n [@@deriving sexp, equal, yojson, hash, compare]\n\n let to_latest = Fn.id\n end\n end]\n\n type t = Zkapp_basic.F.t V.t [@@deriving sexp, equal, yojson, hash, compare]\n\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\nend\n\nlet to_input (t : _ V.t) ~f =\n Vector.(reduce_exn (map t ~f) ~f:Random_oracle_input.Chunked.append)\n\nlet deriver inner obj =\n let open Fields_derivers_zkapps.Derivers in\n iso ~map:V.of_list_exn ~contramap:V.to_list\n ((list ~static_length:(Nat.to_int Max_state_size.n) @@ inner @@ o ())\n (o ()) )\n obj\n","open Core_kernel\nopen Kimchi_backend_common\n\nmodule Rounds : sig\n open Pickles_types\n\n module Wrap : Nat.Add.Intf_transparent\n\n module Wrap_vector : Vector.With_version(Wrap).S\n\n module Step : Nat.Add.Intf_transparent\n\n module Step_vector : Vector.With_version(Step).S\nend = struct\n open Pickles_types\n module Wrap = Nat.N15\n module Step = Nat.N16\n\n (* Think about versioning here! These vector types *will* change\n serialization if the numbers above change, and so will require a new\n version number. Thus, it's important that these are modules with new\n versioned types, and not just module aliases to the corresponding vector\n implementation.\n *)\n\n module Wrap_vector = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = 'a Vector.Vector_15.Stable.V1.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n type 'a t = 'a Vector.Vector_15.t\n [@@deriving compare, yojson, sexp, hash, equal]\n\n let map = Vector.map\n\n let of_list_exn = Vector.Vector_15.of_list_exn\n\n let to_list = Vector.to_list\n end\n\n module Step_vector = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = 'a Vector.Vector_16.Stable.V1.t\n [@@deriving compare, yojson, sexp, hash, equal]\n end\n end]\n\n type 'a t = 'a Vector.Vector_16.t\n [@@deriving compare, yojson, sexp, hash, equal]\n\n let map = Vector.map\n\n let of_list_exn = Vector.Vector_16.of_list_exn\n\n let to_list = Vector.to_list\n end\nend\n\n(* why use a functor here? *)\nmodule Bigint256 =\n Kimchi_backend_common.Bigint.Make\n (Pasta_bindings.BigInt256)\n (struct\n let length_in_bytes = 32\n end)\n\n(* the two pasta fields and curves *)\n\nmodule Fp = Field.Make (struct\n module Bigint = Bigint256\n include Pasta_bindings.Fp\n module Vector = Kimchi_bindings.FieldVectors.Fp\nend)\n\nmodule Fq = Field.Make (struct\n module Bigint = Bigint256\n include Pasta_bindings.Fq\n module Vector = Kimchi_bindings.FieldVectors.Fq\nend)\n\nmodule Vesta = struct\n module Params = struct\n open Fq\n\n let a = zero\n\n let b = of_int 5\n end\n\n include Curve.Make (Fq) (Fp) (Params) (Pasta_bindings.Vesta)\nend\n\nmodule Pallas = struct\n module Params = struct\n open Fp\n\n let a = zero\n\n let b = of_int 5\n end\n\n include Curve.Make (Fp) (Fq) (Params) (Pasta_bindings.Pallas)\nend\n\n(* the polynomial commitment types *)\n\nmodule Fq_poly_comm = Kimchi_backend_common.Poly_comm.Make (struct\n module Curve = Pallas\n module Base_field = Fp\n\n module Backend = struct\n type t = Curve.Affine.Backend.t Kimchi_types.poly_comm\n\n let shifted ({ shifted; _ } : t) = shifted\n\n let unshifted ({ unshifted; _ } : t) = unshifted\n\n let make :\n Curve.Affine.Backend.t array -> Curve.Affine.Backend.t option -> t =\n fun unshifted shifted : t -> { shifted; unshifted }\n end\nend)\n\nmodule Fp_poly_comm = Kimchi_backend_common.Poly_comm.Make (struct\n module Curve = Vesta\n module Base_field = Fq\n\n module Backend = struct\n type t = Curve.Affine.Backend.t Kimchi_types.poly_comm\n\n let shifted ({ shifted; _ } : t) = shifted\n\n let unshifted ({ unshifted; _ } : t) = unshifted\n\n let make :\n Curve.Affine.Backend.t array -> Curve.Affine.Backend.t option -> t =\n fun unshifted shifted : t -> { shifted; unshifted }\n end\nend)\n\n(* poseidon params *)\n\nlet poseidon_params_fp = Sponge.Params.(map pasta_p_kimchi ~f:Fp.of_string)\n\nlet poseidon_params_fq = Sponge.Params.(map pasta_q_kimchi ~f:Fq.of_string)\n","open Core_kernel\nopen Poly_types\nmodule Id = Hlist0.Id\nmodule HlistId = Hlist0.HlistId\nmodule H1_1 = Hlist0.H1_1\n\nmodule E13 (T : T1) = struct\n type ('a, _, _) t = 'a T.t\nend\n\nmodule E23 (T : T2) = struct\n type ('a, 'b, _) t = ('a, 'b) T.t\nend\n\nmodule E01 (T : T0) = struct\n type _ t = T.t\nend\n\nmodule E02 (T : T0) = struct\n type (_, _) t = T.t\nend\n\nmodule E03 (T : T0) = struct\n type (_, _, _) t = T.t\nend\n\nmodule E04 (T : T0) = struct\n type (_, _, _, _) t = T.t\nend\n\nmodule E06 (T : T0) = struct\n type (_, _, _, _, _, _) t = T.t\nend\n\nmodule Tuple2 (F : T3) (G : T3) = struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) F.t * ('a, 'b, 'c) G.t\nend\n\nmodule Tuple3 (F : T3) (G : T3) (H : T3) = struct\n type ('a, 'b, 'c) t = ('a, 'b, 'c) F.t * ('a, 'b, 'c) G.t * ('a, 'b, 'c) H.t\nend\n\nmodule Tuple4 (F : T3) (G : T3) (H : T3) (I : T3) = struct\n type ('a, 'b, 'c) t =\n ('a, 'b, 'c) F.t * ('a, 'b, 'c) G.t * ('a, 'b, 'c) H.t * ('a, 'b, 'c) I.t\nend\n\nmodule Tuple5 (F : T3) (G : T3) (H : T3) (I : T3) (J : T3) = struct\n type ('a, 'b, 'c) t =\n ('a, 'b, 'c) F.t\n * ('a, 'b, 'c) G.t\n * ('a, 'b, 'c) H.t\n * ('a, 'b, 'c) I.t\n * ('a, 'b, 'c) J.t\nend\n\nmodule Arg1 = struct\n type ('a, _, _) t = 'a\nend\n\nmodule Arg2 = struct\n type (_, 'a, _) t = 'a\nend\n\nmodule Apply2 (F : T2) (X : T1) (Y : T1) = struct\n type ('a, 'b) t = ('a X.t, 'b Y.t) F.t\nend\n\nmodule Dup (F : T2) = struct\n type 'a t = ('a, 'a) F.t\nend\n\nmodule Length = Hlist0.Length\n\nmodule H1 = struct\n module T = Hlist0.H1\n\n module Iter\n (F : T1) (C : sig\n val f : 'a F.t -> unit\n end) =\n struct\n let rec f : type a. a T(F).t -> unit = function\n | [] ->\n ()\n | x :: xs ->\n C.f x ; f xs\n end\n\n module Of_vector (X : T0) = struct\n let rec f :\n type xs length.\n (xs, length) Length.t -> (X.t, length) Vector.t -> xs T(E01(X)).t =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\n\n module Map\n (F : T1)\n (G : T1) (C : sig\n val f : 'a F.t -> 'a G.t\n end) =\n struct\n let rec f : type a. a T(F).t -> a T(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module Fold\n (F : T1)\n (X : T0) (C : sig\n val f : X.t -> 'a F.t -> X.t\n end) =\n struct\n let rec f : type a. init:X.t -> a T(F).t -> X.t =\n fun ~init xs ->\n match xs with [] -> init | x :: xs -> f ~init:(C.f init x) xs\n end\n\n module Map_reduce\n (F : T1)\n (X : T0) (C : sig\n val reduce : X.t -> X.t -> X.t\n\n val map : 'a F.t -> X.t\n end) =\n struct\n let rec f : type a. X.t -> a T(F).t -> X.t =\n fun acc xs ->\n match xs with [] -> acc | x :: xs -> f (C.reduce acc (C.map x)) xs\n\n let f (type a) (xs : a T(F).t) =\n match xs with\n | [] ->\n failwith \"Hlist.Map_reduce: empty list\"\n | x :: xs ->\n f (C.map x) xs\n end\n\n module To_vector (X : T0) = struct\n let rec f :\n type xs length.\n (xs, length) Length.t -> xs T(E01(X)).t -> (X.t, length) Vector.t =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\n\n module Tuple2 (F : T1) (G : T1) = struct\n type 'a t = 'a F.t * 'a G.t\n end\n\n module Zip (F : T1) (G : T1) = struct\n let rec f : type a. a T(F).t -> a T(G).t -> a T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Typ (Impl : sig\n type field\n end)\n (F : T1)\n (Var : T1)\n (Val : T1) (C : sig\n val f : 'a F.t -> ('a Var.t, 'a Val.t, Impl.field) Snarky_backendless.Typ.t\n end) =\n struct\n let rec f :\n type xs.\n xs T(F).t\n -> (xs T(Var).t, xs T(Val).t, Impl.field) Snarky_backendless.Typ.t =\n let transport, transport_var, tuple2, unit =\n Snarky_backendless.Typ.(transport, transport_var, tuple2, unit)\n in\n fun ts ->\n match ts with\n | t :: ts ->\n let tail = f ts in\n transport\n (tuple2 (C.f t) tail)\n ~there:(fun (x :: xs : _ T(Val).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n |> transport_var\n ~there:(fun (x :: xs : _ T(Var).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n | [] ->\n let there _ = () in\n transport (unit ()) ~there ~back:(fun () : _ T(Val).t -> [])\n |> transport_var ~there ~back:(fun () : _ T(Var).t -> [])\n end\nend\n\nmodule H2 = struct\n module Arg1 = struct\n type ('a, _) t = 'a\n end\n\n module Arg2 = struct\n type (_, 'a) t = 'a\n end\n\n module Tuple2 (F : T2) (G : T2) = struct\n type ('a, 'b) t = ('a, 'b) F.t * ('a, 'b) G.t\n end\n\n module T (F : T2) = struct\n type (_, _) t =\n | [] : (unit, unit) t\n | ( :: ) : ('a1, 'a2) F.t * ('b1, 'b2) t -> ('a1 * 'b1, 'a2 * 'b2) t\n\n let rec length : type tail1 tail2. (tail1, tail2) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\n\n module Zip (F : T2) (G : T2) = struct\n let rec f :\n type a b. (a, b) T(F).t -> (a, b) T(G).t -> (a, b) T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Map\n (F : T2)\n (G : T2) (C : sig\n val f : ('a, 'b) F.t -> ('a, 'b) G.t\n end) =\n struct\n let rec f : type a b. (a, b) T(F).t -> (a, b) T(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module Typ (Impl : sig\n type field\n\n module Typ : sig\n type ('var, 'value) t = ('var, 'value, field) Snarky_backendless.Typ.t\n end\n end) =\n struct\n let transport, transport_var, tuple2, unit =\n Snarky_backendless.Typ.(transport, transport_var, tuple2, unit)\n\n let rec f :\n type vars values.\n (vars, values) T(Impl.Typ).t\n -> ( vars H1.T(Id).t\n , values H1.T(Id).t\n , Impl.field )\n Snarky_backendless.Typ.t =\n fun ts ->\n match ts with\n | [] ->\n let there _ = () in\n transport (unit ()) ~there ~back:(fun () : _ H1.T(Id).t -> [])\n |> transport_var ~there ~back:(fun () : _ H1.T(Id).t -> [])\n | t :: ts ->\n transport\n (tuple2 t (f ts))\n ~there:(fun (x :: xs : _ H1.T(Id).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n |> transport_var\n ~there:(fun (x :: xs : _ H1.T(Id).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n end\nend\n\nmodule H3_2 = struct\n module T (F : sig\n type (_, _, _, _, _) t\n end) =\n struct\n type (_, _, _, 's1, 's2) t =\n | [] : (unit, unit, unit, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 's1, 's2) F.t * ('b1, 'b2, 'b3, 's1, 's2) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 's1, 's2) t\n\n let rec length : type t1 t2 t3 e1 e2. (t1, t2, t3, e1, e2) t -> t1 Length.n\n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H3_3 = struct\n module T (F : sig\n type (_, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, 's1, 's2, 's3) t =\n | [] : (unit, unit, unit, _, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 's1, 's2, 's3) F.t * ('b1, 'b2, 'b3, 's1, 's2, 's3) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 's1, 's2, 's3) t\n\n let rec length :\n type t1 t2 t3 e1 e2 e3. (t1, t2, t3, e1, e2, e3) t -> t1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H3_4 = struct\n module T (F : sig\n type (_, _, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, 's1, 's2, 's3, 's4) t =\n | [] : (unit, unit, unit, _, _, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 's1, 's2, 's3, 's4) F.t\n * ('b1, 'b2, 'b3, 's1, 's2, 's3, 's4) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 's1, 's2, 's3, 's4) t\n\n let rec length :\n type t1 t2 t3 e1 e2 e3 e4. (t1, t2, t3, e1, e2, e3, e4) t -> t1 Length.n\n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H2_1 = struct\n module T (F : sig\n type (_, _, _) t\n end) =\n struct\n type (_, _, 's) t =\n | [] : (unit, unit, _) t\n | ( :: ) :\n ('a1, 'a2, 's) F.t * ('b1, 'b2, 's) t\n -> ('a1 * 'b1, 'a2 * 'b2, 's) t\n\n let rec length : type tail1 tail2 e. (tail1, tail2, e) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\n\n module Iter\n (F : T3) (C : sig\n val f : ('a, 'b, 'c) F.t -> unit\n end) =\n struct\n let rec f : type a b c. (a, b, c) T(F).t -> unit = function\n | [] ->\n ()\n | x :: xs ->\n C.f x ; f xs\n end\n\n module Map_\n (F : T3)\n (G : T3) (Env : sig\n type t\n end) (C : sig\n val f : ('a, 'b, Env.t) F.t -> ('a, 'b, Env.t) G.t\n end) =\n struct\n let rec f : type a b. (a, b, Env.t) T(F).t -> (a, b, Env.t) T(G).t =\n function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module Map\n (F : T3)\n (G : T3) (C : sig\n val f : ('a, 'b, 'c) F.t -> ('a, 'b, 'c) G.t\n end) =\n struct\n let f : type a b c. (a, b, c) T(F).t -> (a, b, c) T(G).t =\n fun xs ->\n let module M =\n Map_ (F) (G)\n (struct\n type t = c\n end)\n (struct\n let f = C.f\n end)\n in\n M.f xs\n end\n\n module Zip (F : T3) (G : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(F).t -> (a, b, c) T(G).t -> (a, b, c) T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Zip3 (F1 : T3) (F2 : T3) (F3 : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(F1).t\n -> (a, b, c) T(F2).t\n -> (a, b, c) T(F3).t\n -> (a, b, c) T(Tuple3(F1)(F2)(F3)).t =\n fun xs ys zs ->\n match (xs, ys, zs) with\n | [], [], [] ->\n []\n | x :: xs, y :: ys, z :: zs ->\n (x, y, z) :: f xs ys zs\n end\n\n module Unzip3 (F1 : T3) (F2 : T3) (F3 : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(Tuple3(F1)(F2)(F3)).t\n -> (a, b, c) T(F1).t * (a, b, c) T(F2).t * (a, b, c) T(F3).t =\n fun ts ->\n match ts with\n | [] ->\n ([], [], [])\n | (x, y, z) :: ts ->\n let xs, ys, zs = f ts in\n (x :: xs, y :: ys, z :: zs)\n end\n\n module Zip4 (F1 : T3) (F2 : T3) (F3 : T3) (F4 : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(F1).t\n -> (a, b, c) T(F2).t\n -> (a, b, c) T(F3).t\n -> (a, b, c) T(F4).t\n -> (a, b, c) T(Tuple4(F1)(F2)(F3)(F4)).t =\n fun xs ys zs ws ->\n match (xs, ys, zs, ws) with\n | [], [], [], [] ->\n []\n | x :: xs, y :: ys, z :: zs, w :: ws ->\n (x, y, z, w) :: f xs ys zs ws\n end\n\n module Zip5 (F1 : T3) (F2 : T3) (F3 : T3) (F4 : T3) (F5 : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(F1).t\n -> (a, b, c) T(F2).t\n -> (a, b, c) T(F3).t\n -> (a, b, c) T(F4).t\n -> (a, b, c) T(F5).t\n -> (a, b, c) T(Tuple5(F1)(F2)(F3)(F4)(F5)).t =\n fun l1 l2 l3 l4 l5 ->\n match (l1, l2, l3, l4, l5) with\n | [], [], [], [], [] ->\n []\n | x1 :: l1, x2 :: l2, x3 :: l3, x4 :: l4, x5 :: l5 ->\n (x1, x2, x3, x4, x5) :: f l1 l2 l3 l4 l5\n end\n\n module Of_vector (X : T0) = struct\n let rec f :\n type e xs ys length.\n (xs, length) Length.t\n -> (ys, length) Length.t\n -> (X.t, length) Vector.t\n -> (xs, ys, e) T(E03(X)).t =\n fun l1 l2 v ->\n match (l1, l2, v) with\n | Z, Z, [] ->\n []\n | S n1, S n2, x :: xs ->\n x :: f n1 n2 xs\n end\n\n module To_vector (X : T0) = struct\n let rec f :\n type e xs ys length.\n (xs, length) Length.t\n -> (xs, ys, e) T(E03(X)).t\n -> (X.t, length) Vector.t =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\nend\n\nmodule H3 = struct\n module T (F : sig\n type (_, _, _) t\n end) =\n struct\n type (_, _, _) t =\n | [] : (unit, unit, unit) t\n | ( :: ) :\n ('a1, 'a2, 'a3) F.t * ('b1, 'b2, 'b3) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3) t\n\n let rec length :\n type tail1 tail2 tail3. (tail1, tail2, tail3) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\n\n module To_vector (X : T0) = struct\n let rec f :\n type a b c length.\n (a, length) Length.t -> (a, b, c) T(E03(X)).t -> (X.t, length) Vector.t\n =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\n\n module Zip (F : T3) (G : T3) = struct\n let rec f :\n type a b c.\n (a, b, c) T(F).t -> (a, b, c) T(G).t -> (a, b, c) T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Arg1 = struct\n type ('a, _, _) t = 'a\n end\n\n module Map1_to_H1\n (F : T3)\n (G : T1) (C : sig\n val f : ('a, 'b, 'c) F.t -> 'a G.t\n end) =\n struct\n let rec f : type a b c. (a, b, c) T(F).t -> a H1.T(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module Map2_to_H1\n (F : T3)\n (G : T1) (C : sig\n val f : ('a, 'b, 'c) F.t -> 'b G.t\n end) =\n struct\n let rec f : type a b c. (a, b, c) T(F).t -> b H1.T(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module Map\n (F : T3)\n (G : T3) (C : sig\n val f : ('a, 'b, 'c) F.t -> ('a, 'b, 'c) G.t\n end) =\n struct\n let rec f : type a b c. (a, b, c) T(F).t -> (a, b, c) T(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\nend\n\nmodule H4 = struct\n module T (F : sig\n type (_, _, _, _) t\n end) =\n struct\n type (_, _, _, _) t =\n | [] : (unit, unit, unit, unit) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4) F.t * ('b1, 'b2, 'b3, 'b4) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 'a4 * 'b4) t\n\n let rec length :\n type tail1 tail2 tail3 tail4.\n (tail1, tail2, tail3, tail4) t -> tail1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\n\n module Fold\n (F : T4)\n (X : T0) (C : sig\n val f : X.t -> _ F.t -> X.t\n end) =\n struct\n let rec f : type a b c d. init:X.t -> (a, b, c, d) T(F).t -> X.t =\n fun ~init xs ->\n match xs with [] -> init | x :: xs -> f ~init:(C.f init x) xs\n end\n\n module Iter\n (F : T4) (C : sig\n val f : _ F.t -> unit\n end) =\n struct\n let rec f : type a b c d. (a, b, c, d) T(F).t -> unit =\n fun xs -> match xs with [] -> () | x :: xs -> C.f x ; f xs\n end\n\n module Map\n (F : T4)\n (G : T4) (C : sig\n val f : ('a, 'b, 'c, 'd) F.t -> ('a, 'b, 'c, 'd) G.t\n end) =\n struct\n let rec f : type a b c d. (a, b, c, d) T(F).t -> (a, b, c, d) T(G).t =\n function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module To_vector (X : T0) = struct\n let rec f :\n type a b c d length.\n (a, length) Length.t\n -> (a, b, c, d) T(E04(X)).t\n -> (X.t, length) Vector.t =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\n\n module Tuple2 (F : T4) (G : T4) = struct\n type ('a, 'b, 'c, 'd) t = ('a, 'b, 'c, 'd) F.t * ('a, 'b, 'c, 'd) G.t\n end\n\n module Zip (F : T4) (G : T4) = struct\n let rec f :\n type a b c d.\n (a, b, c, d) T(F).t\n -> (a, b, c, d) T(G).t\n -> (a, b, c, d) T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Length_1_to_2 (F : T4) = struct\n let rec f :\n type n xs ys a b.\n (xs, ys, a, b) T(F).t -> (xs, n) Length.t -> (ys, n) Length.t =\n fun xs n -> match (xs, n) with [], Z -> Z | _ :: xs, S n -> S (f xs n)\n end\n\n module Typ (Impl : sig\n type field\n end)\n (F : T4)\n (Var : T3)\n (Val : T3) (C : sig\n val f :\n ('var, 'value, 'n1, 'n2) F.t\n -> ( ('var, 'n1, 'n2) Var.t\n , ('value, 'n1, 'n2) Val.t\n , Impl.field )\n Snarky_backendless.Typ.t\n end) =\n struct\n let transport, transport_var, tuple2, unit =\n Snarky_backendless.Typ.(transport, transport_var, tuple2, unit)\n\n let rec f :\n type vars values ns1 ns2.\n (vars, values, ns1, ns2) T(F).t\n -> ( (vars, ns1, ns2) H3.T(Var).t\n , (values, ns1, ns2) H3.T(Val).t\n , Impl.field )\n Snarky_backendless.Typ.t =\n fun ts ->\n match ts with\n | [] ->\n let there _ = () in\n transport (unit ()) ~there ~back:(fun () : _ H3.T(Val).t -> [])\n |> transport_var ~there ~back:(fun () : _ H3.T(Var).t -> [])\n | t :: ts ->\n transport\n (tuple2 (C.f t) (f ts))\n ~there:(fun (x :: xs : _ H3.T(Val).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n |> transport_var\n ~there:(fun (x :: xs : _ H3.T(Var).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n end\nend\n\nmodule H6 = struct\n module T (F : sig\n type (_, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, _, _) t =\n | [] : (unit, unit, unit, unit, unit, unit) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) F.t * ('b1, 'b2, 'b3, 'b4, 'b5, 'b6) t\n -> ( 'a1 * 'b1\n , 'a2 * 'b2\n , 'a3 * 'b3\n , 'a4 * 'b4\n , 'a5 * 'b5\n , 'a6 * 'b6 )\n t\n\n let rec length :\n type tail1 tail2 tail3 tail4 tail5 tail6.\n (tail1, tail2, tail3, tail4, tail5, tail6) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\n\n module Fold\n (F : T6)\n (X : T0) (C : sig\n val f : X.t -> _ F.t -> X.t\n end) =\n struct\n let rec f :\n type a1 a2 a3 a4 a5 a6.\n init:X.t -> (a1, a2, a3, a4, a5, a6) T(F).t -> X.t =\n fun ~init xs ->\n match xs with [] -> init | x :: xs -> f ~init:(C.f init x) xs\n end\n\n module Iter\n (F : T6) (C : sig\n val f : _ F.t -> unit\n end) =\n struct\n let rec f : type a1 a2 a3 a4 a5 a6. (a1, a2, a3, a4, a5, a6) T(F).t -> unit\n =\n fun xs -> match xs with [] -> () | x :: xs -> C.f x ; f xs\n end\n\n module Map\n (F : T6)\n (G : T6) (C : sig\n val f :\n ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) F.t\n -> ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) G.t\n end) =\n struct\n let rec f :\n type a1 a2 a3 a4 a5 a6.\n (a1, a2, a3, a4, a5, a6) T(F).t -> (a1, a2, a3, a4, a5, a6) T(G).t =\n function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\n end\n\n module To_vector (X : T0) = struct\n let rec f :\n type a1 a2 a3 a4 a5 a6 length.\n (a1, length) Length.t\n -> (a1, a2, a3, a4, a5, a6) T(E06(X)).t\n -> (X.t, length) Vector.t =\n fun l1 v ->\n match (l1, v) with Z, [] -> [] | S n1, x :: xs -> x :: f n1 xs\n end\n\n module Tuple2 (F : T6) (G : T6) = struct\n type ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) t =\n ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) F.t * ('a1, 'a2, 'a3, 'a4, 'a5, 'a6) G.t\n end\n\n module Zip (F : T6) (G : T6) = struct\n let rec f :\n type a1 a2 a3 a4 a5 a6.\n (a1, a2, a3, a4, a5, a6) T(F).t\n -> (a1, a2, a3, a4, a5, a6) T(G).t\n -> (a1, a2, a3, a4, a5, a6) T(Tuple2(F)(G)).t =\n fun xs ys ->\n match (xs, ys) with [], [] -> [] | x :: xs, y :: ys -> (x, y) :: f xs ys\n end\n\n module Length_1_to_2 (F : T6) = struct\n let rec f :\n type n a1 a2 a3 a4 a5 a6.\n (a1, a2, a3, a4, a5, a6) T(F).t -> (a1, n) Length.t -> (a2, n) Length.t\n =\n fun xs n -> match (xs, n) with [], Z -> Z | _ :: xs, S n -> S (f xs n)\n end\n\n module Typ (Impl : sig\n type field\n end)\n (F : T6)\n (Var : T4)\n (Val : T4) (C : sig\n val f :\n ('var, 'value, 'ret_var, 'ret_value, 'n1, 'n2) F.t\n -> ( ('var, 'ret_var, 'n1, 'n2) Var.t\n , ('value, 'ret_value, 'n1, 'n2) Val.t\n , Impl.field )\n Snarky_backendless.Typ.t\n end) =\n struct\n let transport, transport_var, tuple2, unit =\n Snarky_backendless.Typ.(transport, transport_var, tuple2, unit)\n\n let rec f :\n type vars values ret_vars ret_values ns1 ns2.\n (vars, values, ret_vars, ret_values, ns1, ns2) T(F).t\n -> ( (vars, ret_vars, ns1, ns2) H4.T(Var).t\n , (values, ret_values, ns1, ns2) H4.T(Val).t\n , Impl.field )\n Snarky_backendless.Typ.t =\n fun ts ->\n match ts with\n | [] ->\n let there _ = () in\n transport (unit ()) ~there ~back:(fun () : _ H4.T(Val).t -> [])\n |> transport_var ~there ~back:(fun () : _ H4.T(Var).t -> [])\n | t :: ts ->\n transport\n (tuple2 (C.f t) (f ts))\n ~there:(fun (x :: xs : _ H4.T(Val).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n |> transport_var\n ~there:(fun (x :: xs : _ H4.T(Var).t) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n end\nend\n\nmodule H4_2 = struct\n module T (F : sig\n type (_, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, 's1, 's2) t =\n | [] : (unit, unit, unit, unit, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 's1, 's2) F.t * ('b1, 'b2, 'b3, 'b4, 's1, 's2) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 'a4 * 'b4, 's1, 's2) t\n\n let rec length :\n type t1 t2 t3 t4 e1 e2. (t1, t2, t3, t4, e1, e2) t -> t1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H4_4 = struct\n module T (F : sig\n type (_, _, _, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, 's1, 's2, 's3, 's4) t =\n | [] : (unit, unit, unit, unit, _, _, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 's1, 's2, 's3, 's4) F.t\n * ('b1, 'b2, 'b3, 'b4, 's1, 's2, 's3, 's4) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 'a4 * 'b4, 's1, 's2, 's3, 's4) t\n\n let rec length :\n type t1 t2 t3 t4 e1 e2 e3 e4.\n (t1, t2, t3, t4, e1, e2, e3, e4) t -> t1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H4_6 = struct\n module T (F : sig\n type (_, _, _, _, _, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, 's1, 's2, 's3, 's4, 's5, 's6) t =\n | [] : (unit, unit, unit, unit, _, _, _, _, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 's1, 's2, 's3, 's4, 's5, 's6) F.t\n * ('b1, 'b2, 'b3, 'b4, 's1, 's2, 's3, 's4, 's5, 's6) t\n -> ( 'a1 * 'b1\n , 'a2 * 'b2\n , 'a3 * 'b3\n , 'a4 * 'b4\n , 's1\n , 's2\n , 's3\n , 's4\n , 's5\n , 's6 )\n t\n\n let rec length :\n type t1 t2 t3 t4 e1 e2 e3 e4 e5 e6.\n (t1, t2, t3, t4, e1, e2, e3, e4, e5, e6) t -> t1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H6_2 = struct\n module T (F : sig\n type (_, _, _, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, _, _, 's1, 's2) t =\n | [] : (unit, unit, unit, unit, unit, unit, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 'a5, 'a6, 's1, 's2) F.t\n * ('b1, 'b2, 'b3, 'b4, 'b5, 'b6, 's1, 's2) t\n -> ( 'a1 * 'b1\n , 'a2 * 'b2\n , 'a3 * 'b3\n , 'a4 * 'b4\n , 'a5 * 'b5\n , 'a6 * 'b6\n , 's1\n , 's2 )\n t\n\n let rec length :\n type t1 t2 t3 t4 t5 t6 e1 e2.\n (t1, t2, t3, t4, t5, t6, e1, e2) t -> t1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H6_4 = struct\n module T (F : sig\n type (_, _, _, _, _, _, _, _, _, _) t\n end) =\n struct\n type (_, _, _, _, _, _, 's1, 's2, 's3, 's4) t =\n | [] : (unit, unit, unit, unit, unit, unit, _, _, _, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 'a4, 'a5, 'a6, 's1, 's2, 's3, 's4) F.t\n * ('b1, 'b2, 'b3, 'b4, 'b5, 'b6, 's1, 's2, 's3, 's4) t\n -> ( 'a1 * 'b1\n , 'a2 * 'b2\n , 'a3 * 'b3\n , 'a4 * 'b4\n , 'a5 * 'b5\n , 'a6 * 'b6\n , 's1\n , 's2\n , 's3\n , 's4 )\n t\n\n let rec length :\n type t1 t2 t3 t4 t5 t6 e1 e2 e3 e4.\n (t1, t2, t3, t4, t5, t6, e1, e2, e3, e4) t -> t1 Length.n = function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\n end\nend\n\nmodule H3_1 (F : sig\n type (_, _, _, _) t\nend) =\nstruct\n type (_, _, _, 's) t =\n | [] : (unit, unit, unit, _) t\n | ( :: ) :\n ('a1, 'a2, 'a3, 's) F.t * ('b1, 'b2, 'b3, 's) t\n -> ('a1 * 'b1, 'a2 * 'b2, 'a3 * 'b3, 's) t\n\n let rec length :\n type tail1 tail2 tail3 e. (tail1, tail2, tail3, e) t -> tail1 Length.n =\n function\n | [] ->\n T (Z, Z)\n | _ :: xs ->\n let (T (n, p)) = length xs in\n T (S n, S p)\nend\n\nmodule Map_1_specific\n (F : T2)\n (G : T2) (C : sig\n type b1\n\n type b2\n\n val f : ('a, b1) F.t -> ('a, b2) G.t\n end) =\nstruct\n let rec f : type a. (a, C.b1) H1_1(F).t -> (a, C.b2) H1_1(G).t = function\n | [] ->\n []\n | x :: xs ->\n let y = C.f x in\n y :: f xs\nend\n\nopen Nat\n\nmodule type Max_s = sig\n type ns\n\n type n\n\n val n : n t\n\n val p : (ns, n) H1_1(Lte).t\nend\n\ntype 'ns max = (module Max_s with type ns = 'ns)\n\nlet rec max : type n ns. (n * ns) H1.T(Nat).t -> (n * ns) max =\n fun xs ->\n match xs with\n | [ x ] ->\n let module M = struct\n type nonrec ns = n * ns\n\n type nonrec n = n\n\n let n = x\n\n let p : (_, _) H1_1(Lte).t = [ Lte.refl x ]\n end in\n (module M : Max_s with type ns = n * ns)\n | x :: (_ :: _ as ys) -> (\n let (module Max) = max ys in\n match compare x Max.n with\n | `Lte p_x ->\n let module M = struct\n type nonrec ns = n * ns\n\n type n = Max.n\n\n let n = Max.n\n\n let p : (ns, Max.n) H1_1(Lte).t = p_x :: Max.p\n end in\n (module M)\n | `Gt gt ->\n let max_lt_x = gt_implies_gte x Max.n gt in\n let module M =\n Map_1_specific (Lte) (Lte)\n (struct\n type b1 = Max.n\n\n type b2 = n\n\n let f : type a. (a, Max.n) Lte.t -> (a, n) Lte.t =\n fun a_lt_max -> Lte.trans a_lt_max max_lt_x\n end)\n in\n let module M : Max_s with type ns = n * ns = struct\n type nonrec ns = n * ns\n\n type nonrec n = n\n\n let n = x\n\n let p : (ns, n) H1_1(Lte).t = Lte.refl x :: M.f Max.p\n end in\n (module M) )\n\nlet max_exn : type ns. ns H1.T(Nat).t -> ns max = function\n | [] ->\n failwith \"max_exn: empty list\"\n | _ :: _ as xs ->\n max xs\n\nmodule Maxes = struct\n module type S = sig\n type ns\n\n type length\n\n val length : (ns, length) Length.t\n\n val maxes : ns H1.T(Nat).t\n end\n\n type 'length t = T : 'ns H1.T(Nat).t * ('ns, 'length) Length.t -> 'length t\n\n let rec f : type branches n. ((int, branches) Vector.t, n) Vector.t -> n t =\n function\n | [] ->\n T ([], Length.Z)\n | v :: vs ->\n let (T (maxes, len)) = f vs in\n let (T n) = Nat.of_int (Vector.reduce_exn v ~f:Int.max) in\n T (n :: maxes, S len)\n\n let m (type length) (vs : (_, length) Vector.t) :\n (module S with type length = length) =\n let g :\n type length ns.\n ns H1.T(Nat).t\n -> (ns, length) Length.t\n -> (module S with type length = length) =\n fun maxes length ->\n ( module struct\n type nonrec length = length\n\n type nonrec ns = ns\n\n let length = length\n\n let maxes = maxes\n end )\n in\n let (T (ms, len)) = f vs in\n g ms len\nend\n\nmodule Lengths = struct\n let rec extract :\n type prev_varss ns env.\n (prev_varss, ns, env) H2_1.T(E23(Length)).t -> ns H1.T(Nat).t = function\n | [] ->\n []\n | n :: ns ->\n (* TODO: This is quadratic because of Length.to_nat *)\n Length.to_nat n :: extract ns\n\n type ('prev_varss, 'prev_valss, 'env) t =\n | T :\n ('prev_varss, 'ns, 'env) H2_1.T(E23(Length)).t\n -> ('prev_varss, 'prev_valss, 'env) t\nend\n","open Core_kernel\n\n[@@@warning \"-4\"]\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type 'a t = Infinity | Finite of 'a\n [@@deriving sexp, equal, compare, hash, yojson]\n end\nend]\n\n[@@@warning \"+4\"]\n\nlet finite_exn = function\n | Finite x ->\n x\n | Infinity ->\n failwith \"curve point must not be the point at infinity\"\n","open Core_kernel\nopen Pickles_types\nopen Pickles_base\nmodule Scalars = Scalars\nmodule Domain = Domain\nmodule Opt = Opt\n\ntype 'field plonk_domain =\n < vanishing_polynomial : 'field -> 'field\n ; shifts : 'field Plonk_types.Shifts.t\n ; generator : 'field >\n\ntype 'field domain = < size : 'field ; vanishing_polynomial : 'field -> 'field >\n\nmodule type Bool_intf = sig\n type t\n\n val true_ : t\n\n val false_ : t\n\n val ( &&& ) : t -> t -> t\n\n val ( ||| ) : t -> t -> t\n\n val any : t list -> t\nend\n\nmodule type Field_intf = sig\n type t\n\n val size_in_bits : int\n\n val zero : t\n\n val one : t\n\n val of_int : int -> t\n\n val ( * ) : t -> t -> t\n\n val ( / ) : t -> t -> t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val inv : t -> t\n\n val negate : t -> t\nend\n\nmodule type Field_with_if_intf = sig\n include Field_intf\n\n type bool\n\n val if_ : bool -> then_:(unit -> t) -> else_:(unit -> t) -> t\nend\n\ntype 'f field = (module Field_intf with type t = 'f)\n\nlet pow2pow (type t) ((module F) : t field) (x : t) n : t =\n let rec go acc i = if i = 0 then acc else go F.(acc * acc) (i - 1) in\n go x n\n\n(* x^{2 ^ k} - 1 *)\nlet vanishing_polynomial (type t) ((module F) : t field) domain x =\n let k = Domain.log2_size domain in\n F.(pow2pow (module F) x k - one)\n\nlet domain (type t) ((module F) : t field) ~shifts ~domain_generator\n (domain : Domain.t) : t plonk_domain =\n let log2_size = Domain.log2_size domain in\n let shifts = shifts ~log2_size in\n let generator = domain_generator ~log2_size in\n object\n method shifts = shifts\n\n method vanishing_polynomial x = vanishing_polynomial (module F) domain x\n\n method generator = generator\n end\n\nlet actual_evaluation (type f) (module Field : Field_intf with type t = f)\n (e : Field.t array) (pt : Field.t) ~rounds : Field.t =\n let pt_n =\n let rec go acc i = if i = 0 then acc else go Field.(acc * acc) (i - 1) in\n go pt rounds\n in\n match List.rev (Array.to_list e) with\n | e :: es ->\n List.fold ~init:e es ~f:(fun acc fx -> Field.(fx + (pt_n * acc)))\n | [] ->\n Field.of_int 0\n\nlet evals_of_split_evals field ~zeta ~zetaw (es : _ Plonk_types.Evals.t) ~rounds\n =\n let e = Fn.flip (actual_evaluation field ~rounds) in\n Plonk_types.Evals.map es ~f:(fun (x1, x2) -> (e zeta x1, e zetaw x2))\n\nopen Composition_types.Wrap.Proof_state.Deferred_values.Plonk\n\ntype 'bool all_feature_flags = 'bool Lazy.t Plonk_types.Features.Full.t\n\nlet expand_feature_flags (type boolean)\n (module B : Bool_intf with type t = boolean)\n (features : boolean Plonk_types.Features.t) : boolean all_feature_flags =\n features\n |> Plonk_types.Features.map ~f:(fun x -> lazy x)\n |> Plonk_types.Features.to_full ~or_:(fun x y ->\n lazy B.(Lazy.force x ||| Lazy.force y) )\n\nlet lookup_tables_used feature_flags =\n let module Bool = struct\n type t = Opt.Flag.t\n\n let (true_ : t) = Yes\n\n let (false_ : t) = No\n\n let ( &&& ) (x : t) (y : t) : t =\n match (x, y) with\n | Yes, Yes ->\n Yes\n | Maybe, _ | _, Maybe ->\n Maybe\n | No, _ | _, No ->\n No\n\n let ( ||| ) (x : t) (y : t) : t =\n match (x, y) with\n | Yes, _ | _, Yes ->\n Yes\n | Maybe, _ | _, Maybe ->\n Maybe\n | No, No ->\n No\n\n let any = List.fold_left ~f:( ||| ) ~init:false_\n end in\n let all_feature_flags = expand_feature_flags (module Bool) feature_flags in\n Lazy.force all_feature_flags.uses_lookups\n\nlet get_feature_flag (feature_flags : _ all_feature_flags)\n (feature : Kimchi_types.feature_flag) =\n let lazy_flag =\n Plonk_types.Features.Full.get_feature_flag feature_flags feature\n in\n Option.map ~f:Lazy.force lazy_flag\n\nlet scalars_env (type boolean t) (module B : Bool_intf with type t = boolean)\n (module F : Field_with_if_intf with type t = t and type bool = boolean)\n ~endo ~mds ~field_of_hex ~domain ~srs_length_log2\n ({ alpha; beta; gamma; zeta; joint_combiner; feature_flags } :\n (t, _, boolean) Minimal.t ) (e : (_ * _, _) Plonk_types.Evals.In_circuit.t)\n =\n let feature_flags = expand_feature_flags (module B) feature_flags in\n let witness = Vector.to_array e.w in\n let coefficients = Vector.to_array e.coefficients in\n let var (col, row) =\n let get_eval =\n match (row : Scalars.curr_or_next) with Curr -> fst | Next -> snd\n in\n match[@warning \"-4\"] (col : Scalars.Column.t) with\n | Witness i ->\n get_eval witness.(i)\n | Index Poseidon ->\n get_eval e.poseidon_selector\n | Index Generic ->\n get_eval e.generic_selector\n | Index CompleteAdd ->\n get_eval e.complete_add_selector\n | Index VarBaseMul ->\n get_eval e.mul_selector\n | Index EndoMul ->\n get_eval e.emul_selector\n | Index EndoMulScalar ->\n get_eval e.endomul_scalar_selector\n | Index RangeCheck0 ->\n get_eval (Opt.value_exn e.range_check0_selector)\n | Index RangeCheck1 ->\n get_eval (Opt.value_exn e.range_check1_selector)\n | Index ForeignFieldAdd ->\n get_eval (Opt.value_exn e.foreign_field_add_selector)\n | Index ForeignFieldMul ->\n get_eval (Opt.value_exn e.foreign_field_mul_selector)\n | Index Xor16 ->\n get_eval (Opt.value_exn e.xor_selector)\n | Index Rot64 ->\n get_eval (Opt.value_exn e.rot_selector)\n | Index i ->\n failwithf\n !\"Index %{sexp:Scalars.Gate_type.t}\\n\\\n %! should have been linearized away\"\n i ()\n | Coefficient i ->\n get_eval coefficients.(i)\n | LookupTable ->\n get_eval (Opt.value_exn e.lookup_table)\n | LookupSorted i ->\n get_eval\n (Opt.value_exn (Option.value_exn (Vector.nth e.lookup_sorted i)))\n | LookupAggreg ->\n get_eval (Opt.value_exn e.lookup_aggregation)\n | LookupRuntimeTable ->\n get_eval (Opt.value_exn e.runtime_lookup_table)\n | LookupKindIndex Lookup ->\n get_eval (Opt.value_exn e.lookup_gate_lookup_selector)\n | LookupKindIndex Xor ->\n get_eval (Opt.value_exn e.xor_lookup_selector)\n | LookupKindIndex RangeCheck ->\n get_eval (Opt.value_exn e.range_check_lookup_selector)\n | LookupKindIndex ForeignFieldMul ->\n get_eval (Opt.value_exn e.foreign_field_mul_lookup_selector)\n | LookupRuntimeSelector ->\n get_eval (Opt.value_exn e.runtime_lookup_table_selector)\n in\n let open F in\n let square x = x * x in\n let rec pow x n =\n if n = 0 then one\n else if n = 1 then x\n else\n let y = pow (square x) Int.(n / 2) in\n if n mod 2 = 0 then y else x * y\n in\n let alpha_pows =\n let arr = Array.create ~len:71 one in\n arr.(1) <- alpha ;\n for i = 2 to Int.(Array.length arr - 1) do\n arr.(i) <- alpha * arr.(Int.(i - 1))\n done ;\n arr\n in\n let w4, w3, w2, w1 =\n (* generator^{n - 3} *)\n let gen = domain#generator in\n (* gen_inv = gen^{n - 1} = gen^{-1} *)\n let w1 = one / gen in\n let w2 = square w1 in\n let w3 = w2 * w1 in\n let w4 = lazy (w3 * w1) in\n (w4, w3, w2, w1)\n in\n let zk_polynomial =\n (* Vanishing polynomial of [w1, w2, w3]\n evaluated at x = zeta\n *)\n (zeta - w1) * (zeta - w2) * (zeta - w3)\n in\n let zeta_to_n_minus_1 = lazy (domain#vanishing_polynomial zeta) in\n { Scalars.Env.add = ( + )\n ; sub = ( - )\n ; mul = ( * )\n ; square\n ; alpha_pow = (fun i -> alpha_pows.(i))\n ; var\n ; pow = Tuple2.uncurry pow\n ; field = field_of_hex\n ; cell = Fn.id\n ; double = (fun x -> of_int 2 * x)\n ; zk_polynomial\n ; omega_to_minus_3 = w3\n ; zeta_to_n_minus_1 = domain#vanishing_polynomial zeta\n ; endo_coefficient = endo\n ; mds = (fun (row, col) -> mds.(row).(col))\n ; srs_length_log2\n ; vanishes_on_zero_knowledge_and_previous_rows =\n ( match joint_combiner with\n | None ->\n (* No need to compute anything when not using lookups *)\n F.one\n | Some _ ->\n zk_polynomial * (zeta - Lazy.force w4) )\n ; joint_combiner = Option.value joint_combiner ~default:F.one\n ; beta\n ; gamma\n ; unnormalized_lagrange_basis =\n (fun i ->\n let w_to_i =\n match i with\n | 0 ->\n one\n | 1 ->\n domain#generator\n | -1 ->\n w1\n | -2 ->\n w2\n | -3 ->\n w3\n | -4 ->\n Lazy.force w4\n | _ ->\n failwith \"TODO\"\n in\n Lazy.force zeta_to_n_minus_1 / (zeta - w_to_i) )\n ; if_feature =\n (fun (feature, e1, e2) ->\n let if_ b ~then_ ~else_ =\n match b with None -> e2 () | Some b -> F.if_ b ~then_ ~else_\n in\n let b = get_feature_flag feature_flags feature in\n if_ b ~then_:e1 ~else_:e2 )\n }\n\n(* TODO: not true anymore if lookup is used *)\n\n(** The offset of the powers of alpha for the permutation.\n(see https://github.com/o1-labs/proof-systems/blob/516b16fc9b0fdcab5c608cd1aea07c0c66b6675d/kimchi/src/index.rs#L190) *)\nlet perm_alpha0 : int = 21\n\nmodule Make (Shifted_value : Shifted_value.S) (Sc : Scalars.S) = struct\n (** Computes the ft evaluation at zeta.\n (see https://o1-labs.github.io/mina-book/crypto/plonk/maller_15.html#the-evaluation-of-l)\n *)\n let ft_eval0 (type t) (module F : Field_intf with type t = t) ~domain\n ~(env : t Scalars.Env.t)\n ({ alpha = _; beta; gamma; zeta; joint_combiner = _; feature_flags = _ } :\n _ Minimal.t ) (e : (_ * _, _) Plonk_types.Evals.In_circuit.t) p_eval0 =\n let open Plonk_types.Evals.In_circuit in\n let e0 field = fst (field e) in\n let e1 field = snd (field e) in\n let e0_s = Vector.map e.s ~f:fst in\n let zkp = env.zk_polynomial in\n let alpha_pow = env.alpha_pow in\n let zeta1m1 = env.zeta_to_n_minus_1 in\n let open F in\n let w0 = Vector.to_array e.w |> Array.map ~f:fst in\n let ft_eval0 =\n let a0 = alpha_pow perm_alpha0 in\n let w_n = w0.(Nat.to_int Plonk_types.Permuts_minus_1.n) in\n let init = (w_n + gamma) * e1 z * a0 * zkp in\n (* TODO: This shares some computation with the permutation scalar in\n derive_plonk. Could share between them. *)\n Vector.foldi e0_s ~init ~f:(fun i acc s ->\n ((beta * s) + w0.(i) + gamma) * acc )\n in\n let shifts = domain#shifts in\n let ft_eval0 = ft_eval0 - p_eval0 in\n let ft_eval0 =\n ft_eval0\n - Array.foldi shifts\n ~init:(alpha_pow perm_alpha0 * zkp * e0 z)\n ~f:(fun i acc s -> acc * (gamma + (beta * zeta * s) + w0.(i)))\n in\n let nominator =\n ( zeta1m1\n * alpha_pow Int.(perm_alpha0 + 1)\n * (zeta - env.omega_to_minus_3)\n + (zeta1m1 * alpha_pow Int.(perm_alpha0 + 2) * (zeta - one)) )\n * (one - e0 z)\n in\n let denominator = (zeta - env.omega_to_minus_3) * (zeta - one) in\n let ft_eval0 = ft_eval0 + (nominator / denominator) in\n let constant_term = Sc.constant_term env in\n ft_eval0 - constant_term\n\n (** Computes the list of scalars used in the linearization. *)\n let derive_plonk (type t) ?(with_label = fun _ (f : unit -> t) -> f ())\n (module F : Field_intf with type t = t) ~(env : t Scalars.Env.t) ~shift =\n let _ = with_label in\n let open F in\n fun ({ alpha\n ; beta\n ; gamma\n ; zeta\n ; joint_combiner\n ; feature_flags = actual_feature_flags\n } :\n _ Minimal.t )\n (e : (_ * _, _) Plonk_types.Evals.In_circuit.t)\n (*((e0, e1) : _ Plonk_types.Evals.In_circuit.t Double.t) *) ->\n let open Plonk_types.Evals.In_circuit in\n let e1 field = snd (field e) in\n let zkp = env.zk_polynomial in\n let alpha_pow = env.alpha_pow in\n let w0 = Vector.map e.w ~f:fst in\n let perm =\n let w0 = Vector.to_array w0 in\n with_label __LOC__ (fun () ->\n Vector.foldi e.s\n ~init:(e1 z * beta * alpha_pow perm_alpha0 * zkp)\n ~f:(fun i acc (s, _) -> acc * (gamma + (beta * s) + w0.(i)))\n |> negate )\n in\n In_circuit.map_fields\n ~f:(Shifted_value.of_field (module F) ~shift)\n { alpha\n ; beta\n ; gamma\n ; zeta\n ; zeta_to_domain_size = env.zeta_to_n_minus_1 + F.one\n ; zeta_to_srs_length = pow2pow (module F) zeta env.srs_length_log2\n ; perm\n ; joint_combiner = Opt.of_option joint_combiner\n ; feature_flags = actual_feature_flags\n }\n\n (** Check that computed proof scalars match the expected ones,\n using the native field.\n Note that the expected scalars are used to check\n the linearization in a proof over the other field\n (where those checks are more efficient),\n but we deferred the arithmetic checks until here\n so that we have the efficiency of the native field.\n *)\n let checked (type t)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = t)\n ~shift ~env (plonk : (_, _, _, _ Opt.t, _ Opt.t, _) In_circuit.t) evals =\n let actual =\n derive_plonk ~with_label:Impl.with_label\n (module Impl.Field)\n ~shift ~env\n { alpha = plonk.alpha\n ; beta = plonk.beta\n ; gamma = plonk.gamma\n ; zeta = plonk.zeta\n ; joint_combiner = Opt.to_option_unsafe plonk.joint_combiner\n ; feature_flags = plonk.feature_flags\n }\n evals\n in\n let open Impl in\n let open In_circuit in\n with_label __LOC__ (fun () ->\n with_label __LOC__ (fun () ->\n List.map\n ~f:(fun f -> Shifted_value.equal Field.equal (f plonk) (f actual))\n [ perm ] )\n |> Boolean.all )\nend\n","open Core_kernel\n\ntype ('a, 'n, 'm) t =\n { without_degree_bound : 'n Nat.t; with_degree_bound : ('a, 'm) Vector.t }\n\nlet map t ~f = { t with with_degree_bound = Vector.map t.with_degree_bound ~f }\n\nlet num_bits n = Int.floor_log2 n + 1\n\nlet pow ~one ~mul x n =\n assert (n >= 0) ;\n let k = num_bits n in\n let rec go acc i =\n if i < 0 then acc\n else\n let acc = mul acc acc in\n let b = (n lsr i) land 1 = 1 in\n let acc = if b then mul x acc else acc in\n go acc (i - 1)\n in\n go one (k - 1)\n\nlet create ~without_degree_bound ~with_degree_bound =\n { without_degree_bound; with_degree_bound }\n\nlet combine_commitments _t ~scale ~add ~xi (type n)\n (without_degree_bound : (_, n) Vector.t) with_degree_bound =\n match without_degree_bound with\n | [] ->\n failwith \"combine_commitments: empty list\"\n | init :: without_degree_bound ->\n let polys =\n Vector.to_list without_degree_bound\n @ List.concat_map (Vector.to_list with_degree_bound)\n ~f:(fun (unshifted, shifted) -> [ unshifted; shifted ])\n in\n List.fold_left polys ~init ~f:(fun acc p -> add p (scale acc xi))\n\nlet combine_evaluations' (type a n m)\n ({ without_degree_bound = _; with_degree_bound } : (a, n Nat.s, m) t)\n ~shifted_pow ~mul ~add ~one:_ ~evaluation_point ~xi\n (init :: evals0 : (_, n Nat.s) Vector.t) (evals1 : (_, m) Vector.t) =\n let evals =\n Vector.to_list evals0\n @ List.concat\n (Vector.to_list\n (Vector.map2 with_degree_bound evals1 ~f:(fun deg fx ->\n [ fx; mul (shifted_pow deg evaluation_point) fx ] ) ) )\n in\n List.fold_left evals ~init ~f:(fun acc fx -> add fx (mul acc xi))\n\nlet[@warning \"-45\"] combine_evaluations' (type n) (t : (_, n, _) t) ~shifted_pow\n ~mul ~add ~one ~evaluation_point ~xi (evals0 : (_, n) Vector.t) evals1 =\n match evals0 with\n | Vector.[] ->\n failwith \"Empty evals0\"\n | _ :: _ ->\n combine_evaluations' t ~shifted_pow ~mul ~add ~one ~evaluation_point ~xi\n evals0 evals1\n\nlet combine_evaluations (type f) t ~crs_max_degree ~(mul : f -> f -> f) ~add\n ~one ~evaluation_point ~xi evals0 evals1 =\n let pow = pow ~one ~mul in\n combine_evaluations' t evals0 evals1\n ~shifted_pow:(fun deg x -> pow x (crs_max_degree - deg))\n ~mul ~add ~one ~evaluation_point ~xi\n\nopen Plonk_types.Poly_comm\n\nlet combine_split_commitments _t ~scale_and_add ~init:i ~xi (type n)\n (without_degree_bound : (_, n) Vector.t) with_degree_bound =\n let flat =\n List.concat_map (Vector.to_list without_degree_bound) ~f:Array.to_list\n @ List.concat_map (Vector.to_list with_degree_bound)\n ~f:(fun { With_degree_bound.unshifted; shifted } ->\n Array.to_list unshifted @ [ shifted ] )\n in\n let rec go = function\n | [] ->\n failwith \"combine_split_commitments: empty\"\n | init :: comms -> (\n match i init with\n | None ->\n go comms\n | Some init ->\n List.fold_left comms ~init ~f:(fun acc p ->\n scale_and_add ~acc ~xi p ) )\n in\n go (List.rev flat)\n\nlet combine_split_evaluations (type f f')\n ~(mul_and_add : acc:f' -> xi:f' -> f -> f') ~init:(i : f -> f') ~(xi : f')\n (evals0 : f array list) : f' =\n let flat = List.concat_map evals0 ~f:Array.to_list in\n match List.rev flat with\n | [] ->\n failwith \"combine_split_evaluations: empty\"\n | init :: es ->\n List.fold_left es ~init:(i init) ~f:(fun acc fx ->\n mul_and_add ~acc ~xi fx )\n","type ('a, _) t =\n | [] : ('a, 'n) t\n | ( :: ) : 'a * ('a, 'n) t -> ('a, 'n Nat.s) t\n\nlet rec to_list : type a n. (a, n) t -> a list = function\n | [] ->\n []\n | x :: xs ->\n x :: to_list xs\n\nlet rec _length : type a n. (a, n) t -> int = function\n | [] ->\n 0\n | _ :: xs ->\n 1 + _length xs\n\nlet rec to_vector : type a n. (a, n) t -> a Vector.e = function\n | [] ->\n T []\n | x :: xs ->\n let (T xs) = to_vector xs in\n T (x :: xs)\n\nlet rec of_vector : type a n m. (a, n) Vector.t -> (n, m) Nat.Lte.t -> (a, m) t\n =\n fun v p ->\n match (v, p) with [], _ -> [] | x :: xs, S p -> x :: of_vector xs p\n\nlet rec of_list_and_length_exn : type a n. a list -> n Nat.t -> (a, n) t =\n fun xs n ->\n match (xs, n) with\n | [], _ ->\n []\n | x :: xs, S n ->\n x :: of_list_and_length_exn xs n\n | _ :: _, Z ->\n failwith \"At_most: Length mismatch\"\n\nmodule type S = sig\n type 'a t\n\n include Sigs.Hash_foldable.S1 with type 'a t := 'a t\n\n include Sigs.Comparable.S1 with type 'a t := 'a t\n\n include Sigs.Jsonable.S1 with type 'a t := 'a t\n\n include Sigs.Sexpable.S1 with type 'a t := 'a t\nend\n\nmodule type VERSIONED = sig\n type 'a ty\n\n module Stable : sig\n module V1 : sig\n type 'a t = 'a ty\n\n include Sigs.VERSIONED\n\n include Sigs.Binable.S1 with type 'a t := 'a t\n\n include S with type 'a t := 'a t\n end\n end\n\n type 'a t = 'a Stable.V1.t\n\n include S with type 'a t := 'a t\nend\n\nmodule Make = struct\n module Yojson (N : Nat.Intf) :\n Sigs.Jsonable.S1 with type 'a t := ('a, N.n) t = struct\n let to_yojson f t = Vector.L.to_yojson f (to_list t)\n\n let of_yojson f s =\n Core_kernel.Result.map (Vector.L.of_yojson f s)\n ~f:(Base.Fn.flip of_list_and_length_exn N.n)\n end\n\n module Sexpable (N : Nat.Intf) :\n Core_kernel.Sexpable.S1 with type 'a t := ('a, N.n) t =\n Core_kernel.Sexpable.Of_sexpable1\n (Base.List)\n (struct\n type nonrec 'a t = ('a, N.n) t\n\n let to_sexpable = to_list\n\n let of_sexpable xs = of_list_and_length_exn xs N.n\n end)\nend\n\ntype ('a, 'n) at_most = ('a, 'n) t\n\nmodule With_length (N : Nat.Intf) : S with type 'a t = ('a, N.n) at_most =\nstruct\n type 'a t = ('a, N.n) at_most\n\n let compare c t1 t2 = Base.List.compare c (to_list t1) (to_list t2)\n\n let hash_fold_t f s v = Base.List.hash_fold_t f s (to_list v)\n\n let equal f t1 t2 = List.equal f (to_list t1) (to_list t2)\n\n include Make.Sexpable (N)\n include Make.Yojson (N)\nend\n\nmodule At_most_2 = struct\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N2.n) at_most\n\n include\n Core_kernel.Binable.Of_binable1_without_uuid\n (Core_kernel.List.Stable.V1)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable = to_list\n\n let of_binable xs = of_list_and_length_exn xs Nat.N2.n\n end)\n\n include (\n With_length\n (Nat.N2) :\n module type of With_length (Nat.N2) with type 'a t := 'a t )\n end\n end]\n\n type 'a t = 'a Stable.Latest.t [@@deriving sexp, equal, compare, hash, yojson]\n\n type 'a ty = 'a t\n end\n\nmodule At_most_8 = struct\n [%%versioned_binable\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, Nat.N8.n) at_most\n\n include\n Core_kernel.Binable.Of_binable1_without_uuid\n (Core_kernel.List.Stable.V1)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable = to_list\n\n let of_binable xs = of_list_and_length_exn xs Nat.N8.n\n end)\n\n include (\n With_length\n (Nat.N8) :\n module type of With_length (Nat.N8) with type 'a t := 'a t )\n end\n end]\n\n type 'a t = 'a Stable.Latest.t [@@deriving sexp, equal, compare, hash, yojson]\n\n type 'a ty = 'a t\n end\n","(* This file is generated automatically with ocaml_gen. *)\n\nmodule FieldVectors = struct\n module Fp = struct\n type nonrec t\n\n type nonrec elt = Pasta_bindings.Fp.t\n\n external create : unit -> t = \"caml_fp_vector_create\"\n\n external length : t -> int = \"caml_fp_vector_length\"\n\n external emplace_back : t -> elt -> unit = \"caml_fp_vector_emplace_back\"\n\n external get : t -> int -> elt = \"caml_fp_vector_get\"\n\n external set : t -> int -> elt -> unit = \"caml_fp_vector_set\"\n end\n\n module Fq = struct\n type nonrec t\n\n type nonrec elt = Pasta_bindings.Fq.t\n\n external create : unit -> t = \"caml_fq_vector_create\"\n\n external length : t -> int = \"caml_fq_vector_length\"\n\n external emplace_back : t -> elt -> unit = \"caml_fq_vector_emplace_back\"\n\n external get : t -> int -> elt = \"caml_fq_vector_get\"\n\n external set : t -> int -> elt -> unit = \"caml_fq_vector_set\"\n end\nend\n\nmodule Protocol = struct\n module Gates = struct\n module Vector = struct\n module Fp = struct\n type nonrec t\n\n type nonrec elt = Pasta_bindings.Fp.t Kimchi_types.circuit_gate\n\n external create : unit -> t = \"caml_pasta_fp_plonk_gate_vector_create\"\n\n external add : t -> elt -> unit = \"caml_pasta_fp_plonk_gate_vector_add\"\n\n external get : t -> int -> elt = \"caml_pasta_fp_plonk_gate_vector_get\"\n\n external len : t -> int = \"caml_pasta_fp_plonk_gate_vector_len\"\n\n external wrap : t -> Kimchi_types.wire -> Kimchi_types.wire -> unit\n = \"caml_pasta_fp_plonk_gate_vector_wrap\"\n\n external digest : int -> t -> bytes\n = \"caml_pasta_fp_plonk_gate_vector_digest\"\n\n external to_json : int -> t -> string\n = \"caml_pasta_fp_plonk_circuit_serialize\"\n end\n\n module Fq = struct\n type nonrec t\n\n type nonrec elt = Pasta_bindings.Fq.t Kimchi_types.circuit_gate\n\n external create : unit -> t = \"caml_pasta_fq_plonk_gate_vector_create\"\n\n external add : t -> elt -> unit = \"caml_pasta_fq_plonk_gate_vector_add\"\n\n external get : t -> int -> elt = \"caml_pasta_fq_plonk_gate_vector_get\"\n\n external len : t -> int = \"caml_pasta_fq_plonk_gate_vector_len\"\n\n external wrap : t -> Kimchi_types.wire -> Kimchi_types.wire -> unit\n = \"caml_pasta_fq_plonk_gate_vector_wrap\"\n\n external digest : int -> t -> bytes\n = \"caml_pasta_fq_plonk_gate_vector_digest\"\n\n external to_json : int -> t -> string\n = \"caml_pasta_fq_plonk_circuit_serialize\"\n end\n end\n end\n\n module SRS = struct\n module Fp = struct\n type nonrec t\n\n module Poly_comm = struct\n type nonrec t =\n Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n end\n\n external create : int -> t = \"caml_fp_srs_create\"\n\n external write : bool option -> t -> string -> unit = \"caml_fp_srs_write\"\n\n external read : int option -> string -> t option = \"caml_fp_srs_read\"\n\n external lagrange_commitment :\n t\n -> int\n -> int\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fp_srs_lagrange_commitment\"\n\n external add_lagrange_basis : t -> int -> unit\n = \"caml_fp_srs_add_lagrange_basis\"\n\n external commit_evaluations :\n t\n -> int\n -> Pasta_bindings.Fp.t array\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fp_srs_commit_evaluations\"\n\n external b_poly_commitment :\n t\n -> Pasta_bindings.Fp.t array\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fp_srs_b_poly_commitment\"\n\n external batch_accumulator_check :\n t\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity array\n -> Pasta_bindings.Fp.t array\n -> bool = \"caml_fp_srs_batch_accumulator_check\"\n\n external batch_accumulator_generate :\n t\n -> int\n -> Pasta_bindings.Fp.t array\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity array\n = \"caml_fp_srs_batch_accumulator_generate\"\n\n external urs_h : t -> Pasta_bindings.Fq.t Kimchi_types.or_infinity\n = \"caml_fp_srs_h\"\n end\n\n module Fq = struct\n type nonrec t\n\n external create : int -> t = \"caml_fq_srs_create\"\n\n external write : bool option -> t -> string -> unit = \"caml_fq_srs_write\"\n\n external read : int option -> string -> t option = \"caml_fq_srs_read\"\n\n external lagrange_commitment :\n t\n -> int\n -> int\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fq_srs_lagrange_commitment\"\n\n external add_lagrange_basis : t -> int -> unit\n = \"caml_fq_srs_add_lagrange_basis\"\n\n external commit_evaluations :\n t\n -> int\n -> Pasta_bindings.Fq.t array\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fq_srs_commit_evaluations\"\n\n external b_poly_commitment :\n t\n -> Pasta_bindings.Fq.t array\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n = \"caml_fq_srs_b_poly_commitment\"\n\n external batch_accumulator_check :\n t\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity array\n -> Pasta_bindings.Fq.t array\n -> bool = \"caml_fq_srs_batch_accumulator_check\"\n\n external batch_accumulator_generate :\n t\n -> int\n -> Pasta_bindings.Fq.t array\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity array\n = \"caml_fq_srs_batch_accumulator_generate\"\n\n external urs_h : t -> Pasta_bindings.Fp.t Kimchi_types.or_infinity\n = \"caml_fq_srs_h\"\n end\n end\n\n module Index = struct\n module Fp = struct\n type nonrec t\n\n external create :\n Gates.Vector.Fp.t\n -> int\n -> Pasta_bindings.Fp.t Kimchi_types.lookup_table array\n -> Pasta_bindings.Fp.t Kimchi_types.runtime_table_cfg array\n -> int\n -> SRS.Fp.t\n -> t\n = \"caml_pasta_fp_plonk_index_create_bytecode\" \"caml_pasta_fp_plonk_index_create\"\n\n external max_degree : t -> int = \"caml_pasta_fp_plonk_index_max_degree\"\n\n external public_inputs : t -> int\n = \"caml_pasta_fp_plonk_index_public_inputs\"\n\n external domain_d1_size : t -> int\n = \"caml_pasta_fp_plonk_index_domain_d1_size\"\n\n external domain_d4_size : t -> int\n = \"caml_pasta_fp_plonk_index_domain_d4_size\"\n\n external domain_d8_size : t -> int\n = \"caml_pasta_fp_plonk_index_domain_d8_size\"\n\n external read : int option -> SRS.Fp.t -> string -> t\n = \"caml_pasta_fp_plonk_index_read\"\n\n external write : bool option -> t -> string -> unit\n = \"caml_pasta_fp_plonk_index_write\"\n end\n\n module Fq = struct\n type nonrec t\n\n external create :\n Gates.Vector.Fq.t\n -> int\n -> Pasta_bindings.Fq.t Kimchi_types.lookup_table array\n -> Pasta_bindings.Fq.t Kimchi_types.runtime_table_cfg array\n -> int\n -> SRS.Fq.t\n -> t\n = \"caml_pasta_fq_plonk_index_create_bytecode\" \"caml_pasta_fq_plonk_index_create\"\n\n external max_degree : t -> int = \"caml_pasta_fq_plonk_index_max_degree\"\n\n external public_inputs : t -> int\n = \"caml_pasta_fq_plonk_index_public_inputs\"\n\n external domain_d1_size : t -> int\n = \"caml_pasta_fq_plonk_index_domain_d1_size\"\n\n external domain_d4_size : t -> int\n = \"caml_pasta_fq_plonk_index_domain_d4_size\"\n\n external domain_d8_size : t -> int\n = \"caml_pasta_fq_plonk_index_domain_d8_size\"\n\n external read : int option -> SRS.Fq.t -> string -> t\n = \"caml_pasta_fq_plonk_index_read\"\n\n external write : bool option -> t -> string -> unit\n = \"caml_pasta_fq_plonk_index_write\"\n end\n end\n\n module VerifierIndex = struct\n module Fp = struct\n type nonrec t =\n ( Pasta_bindings.Fp.t\n , SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n\n external create : Index.Fp.t -> t\n = \"caml_pasta_fp_plonk_verifier_index_create\"\n\n external read : int option -> SRS.Fp.t -> string -> t\n = \"caml_pasta_fp_plonk_verifier_index_read\"\n\n external write : bool option -> t -> string -> unit\n = \"caml_pasta_fp_plonk_verifier_index_write\"\n\n external shifts : int -> Pasta_bindings.Fp.t array\n = \"caml_pasta_fp_plonk_verifier_index_shifts\"\n\n external dummy : unit -> t = \"caml_pasta_fp_plonk_verifier_index_dummy\"\n\n external deep_copy : t -> t\n = \"caml_pasta_fp_plonk_verifier_index_deep_copy\"\n end\n\n module Fq = struct\n type nonrec t =\n ( Pasta_bindings.Fq.t\n , SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n\n external create : Index.Fq.t -> t\n = \"caml_pasta_fq_plonk_verifier_index_create\"\n\n external read : int option -> SRS.Fq.t -> string -> t\n = \"caml_pasta_fq_plonk_verifier_index_read\"\n\n external write : bool option -> t -> string -> unit\n = \"caml_pasta_fq_plonk_verifier_index_write\"\n\n external shifts : int -> Pasta_bindings.Fq.t array\n = \"caml_pasta_fq_plonk_verifier_index_shifts\"\n\n external dummy : unit -> t = \"caml_pasta_fq_plonk_verifier_index_dummy\"\n\n external deep_copy : t -> t\n = \"caml_pasta_fq_plonk_verifier_index_deep_copy\"\n end\n end\n\n module Oracles = struct\n module Fp = struct\n type nonrec t = Pasta_bindings.Fp.t Kimchi_types.oracles\n\n external create :\n Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n array\n -> ( Pasta_bindings.Fp.t\n , SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.prover_proof\n -> t = \"fp_oracles_create_no_public\"\n\n external create_with_public_evals :\n Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n array\n -> ( Pasta_bindings.Fp.t\n , SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n -> t = \"fp_oracles_create\"\n\n external dummy : unit -> Pasta_bindings.Fp.t Kimchi_types.random_oracles\n = \"fp_oracles_dummy\"\n\n external deep_copy :\n Pasta_bindings.Fp.t Kimchi_types.random_oracles\n -> Pasta_bindings.Fp.t Kimchi_types.random_oracles\n = \"fp_oracles_deep_copy\"\n end\n\n module Fq = struct\n type nonrec t = Pasta_bindings.Fq.t Kimchi_types.oracles\n\n external create :\n Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n array\n -> ( Pasta_bindings.Fq.t\n , SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.prover_proof\n -> t = \"fq_oracles_create_no_public\"\n\n external create_with_public_evals :\n Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n array\n -> ( Pasta_bindings.Fq.t\n , SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n -> t = \"fq_oracles_create\"\n\n external dummy : unit -> Pasta_bindings.Fq.t Kimchi_types.random_oracles\n = \"fq_oracles_dummy\"\n\n external deep_copy :\n Pasta_bindings.Fq.t Kimchi_types.random_oracles\n -> Pasta_bindings.Fq.t Kimchi_types.random_oracles\n = \"fq_oracles_deep_copy\"\n end\n end\n\n module Proof = struct\n module Fp = struct\n external create :\n Index.Fp.t\n -> FieldVectors.Fp.t array\n -> Pasta_bindings.Fp.t Kimchi_types.runtime_table array\n -> Pasta_bindings.Fp.t array\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity array\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public = \"caml_pasta_fp_plonk_proof_create\"\n\n external create_and_verify :\n Index.Fp.t\n -> FieldVectors.Fp.t array\n -> Pasta_bindings.Fp.t Kimchi_types.runtime_table array\n -> Pasta_bindings.Fp.t array\n -> Pasta_bindings.Fq.t Kimchi_types.or_infinity array\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_create_and_verify\"\n\n external example_with_lookup :\n SRS.Fp.t\n -> Index.Fp.t\n * Pasta_bindings.Fp.t\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_lookup\"\n\n external example_with_ffadd :\n SRS.Fp.t\n -> Index.Fp.t\n * Pasta_bindings.Fp.t\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_ffadd\"\n\n external example_with_xor :\n SRS.Fp.t\n -> Index.Fp.t\n * (Pasta_bindings.Fp.t * Pasta_bindings.Fp.t)\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_xor\"\n\n external example_with_rot :\n SRS.Fp.t\n -> Index.Fp.t\n * (Pasta_bindings.Fp.t * Pasta_bindings.Fp.t)\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_rot\"\n\n external example_with_foreign_field_mul :\n SRS.Fp.t\n -> Index.Fp.t\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_foreign_field_mul\"\n\n external example_with_range_check :\n SRS.Fp.t\n -> Index.Fp.t\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_range_check\"\n\n external example_with_range_check0 :\n SRS.Fp.t\n -> Index.Fp.t\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_example_with_range_check0\"\n\n external verify :\n ( Pasta_bindings.Fp.t\n , SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n -> bool = \"caml_pasta_fp_plonk_proof_verify\"\n\n external batch_verify :\n ( Pasta_bindings.Fp.t\n , SRS.Fp.t\n , Pasta_bindings.Fq.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n array\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n array\n -> bool = \"caml_pasta_fp_plonk_proof_batch_verify\"\n\n external dummy :\n unit\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public = \"caml_pasta_fp_plonk_proof_dummy\"\n\n external deep_copy :\n ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n -> ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fp_plonk_proof_deep_copy\"\n end\n\n module Fq = struct\n external create :\n Index.Fq.t\n -> FieldVectors.Fq.t array\n -> Pasta_bindings.Fq.t Kimchi_types.runtime_table array\n -> Pasta_bindings.Fq.t array\n -> Pasta_bindings.Fp.t Kimchi_types.or_infinity array\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public = \"caml_pasta_fq_plonk_proof_create\"\n\n external verify :\n ( Pasta_bindings.Fq.t\n , SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n -> bool = \"caml_pasta_fq_plonk_proof_verify\"\n\n external batch_verify :\n ( Pasta_bindings.Fq.t\n , SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n array\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n array\n -> bool = \"caml_pasta_fq_plonk_proof_batch_verify\"\n\n external dummy :\n unit\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public = \"caml_pasta_fq_plonk_proof_dummy\"\n\n external deep_copy :\n ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n -> ( Pasta_bindings.Fp.t Kimchi_types.or_infinity\n , Pasta_bindings.Fq.t )\n Kimchi_types.proof_with_public\n = \"caml_pasta_fq_plonk_proof_deep_copy\"\n end\n end\nend\n","open Core_kernel\n\ntype 'a t = { mds : 'a array array; round_constants : 'a array array }\n[@@deriving bin_io]\n\nlet map { mds; round_constants } ~f =\n let f = Array.map ~f:(Array.map ~f) in\n { mds = f mds; round_constants = f round_constants }\n","let params_Bn128 =\n { Params.mds =\n [| [| \"15913613074278028058360498857043999222867772811338037425231170199156889337604\"\n ; \"65180538277771794992983614695816638391617290189527384182155063505825555179\"\n ; \"5394145287608961087977235806233358974273334844303649346024304966582176196487\"\n |]\n ; [| \"15414815283538893716009156559702084916211023875136356807248219032453798152465\"\n ; \"3463018243616155786290732419705147785020336294529003837260493734746385539469\"\n ; \"12716468877825667500219920861172138145894921271005565146996037137547785771411\"\n |]\n ; [| \"1792045203208933407244693490495238027092197802128268175009298962707699842710\"\n ; \"76356542649790718492035692281837451271781062546545119705441901238018861818\"\n ; \"9520069514281255561624128661339565451189764370791651000392579220353790670830\"\n |]\n |]\n ; round_constants =\n [| [| \"12455131979215983316735047846658291859029812584241282581257197013302738138666\"\n ; \"20029656970890966196099810168066995443524989185718089119520857141365451679654\"\n ; \"8929913078653797661905726823410775654210481762974885244818731639242977419622\"\n |]\n ; [| \"8662787891019924101534530927954444401015394189462080864609938870691307539536\"\n ; \"20294115837600366998212029140165760858924828875933683067126492672917588261877\"\n ; \"2682014173266320611146882768057075830238591616831154961603507352639750394592\"\n |]\n ; [| \"18907515456503482670621260399010811269866082079896285203284611749350771281411\"\n ; \"1424609887444859910324043210736091906100438801135358613993092433663809225411\"\n ; \"1531059541788158835714117823424146308635531997487162670061618032695665453831\"\n |]\n ; [| \"19444238474448321066398700689084787616548516614414549514749853660756611792379\"\n ; \"2236237945310446639621733106225706828551103453944652411264620402517164583264\"\n ; \"12605646628049520919535266096828454658561884709869426105979276828733666269521\"\n |]\n ; [| \"14653124040822125428573681427514890989900893513402451718822527259901516216058\"\n ; \"1535968898232047429062068090527484451997796559364245278047376516596586180554\"\n ; \"3307538294663905716144414865227035949873283327379581103741297483063276195183\"\n |]\n ; [| \"21111467054595055527346262240389751012262991994706430976179289552457483727796\"\n ; \"17649294376560630922417546944777537620537408190408066211453084495108565929366\"\n ; \"7683463515567855955851784553909126014159314191075450219244796328948411069744\"\n |]\n ; [| \"21262229851583325466767017312569047417622760705999088078958228786464449033067\"\n ; \"11691182518884460508022694337582074624192039580202157360389815110719437213363\"\n ; \"8690728446593494554377477996892461126663797704587025899930929227865493269824\"\n |]\n ; [| \"21622260498668079571860417097494779160364898191075577203239012897437375456411\"\n ; \"21067767847052854366896470071519184914663018103241392453030719014890445499665\"\n ; \"21348828409856354758094844442899573788047317201055667836817119877806560465334\"\n |]\n ; [| \"2704440995725305992776846806711930876273040749514871232837487081811513368296\"\n ; \"1142050494870706434296077676238780951797136607536187326800297147932619878418\"\n ; \"3652944740784795248484484454916800802095288396765069024258114251561069674735\"\n |]\n ; [| \"1747641587474624832364464288237802774971629275511085691789065855359044028198\"\n ; \"14935834110027005954806028171080511939971704126366459140378790942754129686907\"\n ; \"3215720726490672077485888789426411334496962379737529853320875594879037332594\"\n |]\n ; [| \"2892159931078719741396670290810431382361178666606213506995456264415113913847\"\n ; \"1938538891009879014088646889644828497511974353410971027478866497380422633484\"\n ; \"13916214761542255527505866254811968868327635410573168146297241319868121689821\"\n |]\n ; [| \"266821775768872344171470219200118028338254464492956024813242747554382748942\"\n ; \"11055386921184594780372263378420826851562920740321950336882051897732501262543\"\n ; \"2504617730099125455929793538006173214604536705392412461363354681040283013164\"\n |]\n ; [| \"8077046888362371937918818344109572894796988781119069525502907016581642522710\"\n ; \"7281012798633884984170366068851653834509460567285503188952416990462599509288\"\n ; \"11914125581503780978633571238267986373793149282818856451291452464271781243920\"\n |]\n ; [| \"5911373857383996424444312456230128887937254975139357544835683280828995545397\"\n ; \"20728259298426389276714612941176977888429183727869747381529137474366072279101\"\n ; \"8331123017723440628782766975941869108307759426898189357261715346312601104654\"\n |]\n ; [| \"19978529403683797449165109778464832800224916941903951374610236813523844409526\"\n ; \"17316158269457914256007584527534747738658973027567786054549020564540952112346\"\n ; \"7848194400773744361171082305364633343688318123652518347170031226439829254882\"\n |]\n ; [| \"17698087730709566968258013675219881840614043344609152682517330801348583470562\"\n ; \"2484533502052370851335172153342694835144795809438965797062785488685902188726\"\n ; \"13372068881052003992228272108672679285817785895634149926809187580418595890381\"\n |]\n ; [| \"4450005426773734601782625050142815413017019480402129494014819930729323864775\"\n ; \"15031465389782276133463098319911853017052619244999605688724393058338301291115\"\n ; \"6028902109643218557806340932181364476799161079643636815411563224652423572198\"\n |]\n ; [| \"2957732585137901025626087202113249345076588554941059487693780861098604986119\"\n ; \"12565476532112137808460978474958060441970941349010371267577877299656634907765\"\n ; \"10508327646678453674728048391759640526197954899878596680197847666563367632543\"\n |]\n ; [| \"4493451765845812430310778141104432201437429164475176054680492630627878568332\"\n ; \"15095408309586969968044201398966210357547906905122453139947200130015688526573\"\n ; \"10819130048432875198797495465270179395954461390529553930221225323229387202234\"\n |]\n ; [| \"15905267794015672354278595057670574122197927816429433548802165993220415414073\"\n ; \"19290205907831398371768999387869637435049824367233327965730120884036212709842\"\n ; \"15451920390057917627290027104082580122165965120355347782937661856388593985245\"\n |]\n ; [| \"6425598873527092853966039409614693840647173123073098849086711894647944582332\"\n ; \"17307716513182567320564075539526480893558355908652993731441220999922946005081\"\n ; \"19372285427179952013203092658533484049593114439149219035606060254764845851391\"\n |]\n ; [| \"14724939606645168531546334343600232253284320276481307778787768813885931648950\"\n ; \"4684996260500305121238590806572541849891754312215139285622888510153705963000\"\n ; \"19906278135333202031075665370853003279083131420237405129919260859757146418025\"\n |]\n ; [| \"3999693912508849442569285360026642503093489903926874133118153062461080435481\"\n ; \"20129375303694053217240183105192753906500831553949001131297105718176015558964\"\n ; \"17281496576809338419011697046933296343189100335422897604615575811331627359485\"\n |]\n ; [| \"15637748291684046440453413703705692658155214802161964102299272768648229342362\"\n ; \"2094444825794502002152585986969571562449905861771519270554787618649438333195\"\n ; \"1152889601932463959824817875107315518104722504910095364729880245759523916044\"\n |]\n ; [| \"12114165850379066500859611262167642397834899331804245444372878412987365128590\"\n ; \"20821227542001445006023346122554483849065713580779858784021328359824080462519\"\n ; \"3440756720132945332811173288138999408441021502908547499697282473681525253805\"\n |]\n ; [| \"20938628428302899368158656913047855118000040623605421135349389583331392728782\"\n ; \"8850081254230234130482383430433176873344633494243110112848647064077741649744\"\n ; \"1819639941546179668398979507053724449231350395599747300736218202072168364980\"\n |]\n ; [| \"21219092773772827667886204262476112905428217689703647484316763603169544906986\"\n ; \"13148487544990345541730567143235754764404038697816450525897467218977412799129\"\n ; \"13598807739063229961519663325640861142062394342851403440808670891533339780790\"\n |]\n ; [| \"18784327298376147342042823437947970462892869194728299228507919810276864843414\"\n ; \"2764493745803317574883853704043825342340808631956690807684613803167040529511\"\n ; \"21531775639025076953020023111055490895978901214310417059307899853240995381819\"\n |]\n ; [| \"19964398501876039777029130298682737202257582985971095863290288610857831427638\"\n ; \"15003442983970848114681480873546789629160262059108570865485071572172687676835\"\n ; \"20614241966717622390914334053622572167995367802051836931454426877074875942253\"\n |]\n ; [| \"19733168743390283576337440585736332292298547880804855952734808967278966077887\"\n ; \"20530621481603446397085836296967350209890164029268319619481535419199429275412\"\n ; \"12361620530467399202722610329149901344545851901477091854159960517963801528971\"\n |]\n ; [| \"9497854724940806346676139162466690071592872530638144182764466319052293463165\"\n ; \"7549205476288061047040852944548942878112823732145584918107208536541712726277\"\n ; \"9010672859023729500640324904403960830965495099902505763591033382017769059028\"\n |]\n ; [| \"809006882768062359480853341102632220777932068978149301935174282279746446958\"\n ; \"7106371976957177712230305966566701811850820970657101896348127436646177656365\"\n ; \"18845123379649840503129460949570724717923057602542920800815047452665097128575\"\n |]\n ; [| \"14712923944932171466124439335703740452883296028663247289510978550197451911919\"\n ; \"19555759172327736128240171000715903945570888389700763573790859521156095228287\"\n ; \"17179695917466049633838471880559548490881310699092342418090873652775810295378\"\n |]\n ; [| \"18944876856792381816055068913314141690530834943354883079085532905267119397008\"\n ; \"3257630700960849517603336097571474897923100547762764495987576852490355943460\"\n ; \"3963500912949736174926372928446487843084987377580944585294277449817215093365\"\n |]\n ; [| \"21304716730402869084944080869903443431235336418077153507261240151959530377653\"\n ; \"18998265936988640248585036755202701418246223100957416731998639191794797638003\"\n ; \"16839625825914009701942141907800050396084195897386326382915730670235616618695\"\n |]\n ; [| \"16907937154215020261110468963982390213438461071031811101554056252102505124726\"\n ; \"1294898660752289889975651445755491766586322714088107994205473403531724749589\"\n ; \"9172546393414544394143001120250095355087186863911844697260687867341704896778\"\n |]\n ; [| \"18891778779724165209072874482651171817270086247356116562427206569585293483055\"\n ; \"13093554332096549605604948416229955030385793767090042194569924056338021838108\"\n ; \"6540069282618873496342140872069384185118574828832026154295825270730722501809\"\n |]\n ; [| \"11698805795265597745890922320669982345748592147825010914959366790903803563027\"\n ; \"11128587690756409041400570351324823090287237584985813997261416805030246953137\"\n ; \"574796972312053991589591668868339165343116554180562026519971681663627339366\"\n |]\n ; [| \"8263653526367544279471418475309371793291954818747935714794248360166503487859\"\n ; \"495546618036723566920914648951352373868059898268055487677897567226892784967\"\n ; \"2528292188392170914010448139211586215817069915670005292953294092269979070980\"\n |]\n ; [| \"14954597262610438728753406794870316034770442280143947719391702684620418262496\"\n ; \"2873290581141877304970576969082349138229332018341156071844198415188999408160\"\n ; \"7877226570858832633875209751493918650976179001613717862579011309181456152753\"\n |]\n ; [| \"5290811263292128650829809831924435265520706616680110737471312421357061576251\"\n ; \"5711353914598993184207904758686192904620948114158132435163135551043392236587\"\n ; \"9671966951859991559346179676315084295317241890404128352532995814366687016784\"\n |]\n ; [| \"20648234869018782942484412385329986060607455807332118750782252709151244400533\"\n ; \"1521221467156754943933671253020851096017281629892920730907443291972734010497\"\n ; \"6375300799036358132607612364454746219201386369274233783761503007631282551380\"\n |]\n ; [| \"18921242117750773300194037006101341214923275379274370683247849512779159129078\"\n ; \"7813033521740037204631731835076108697814182206021466630450781049551634237483\"\n ; \"7795208366125068859216483161820518701837348485078219412133643408967011329822\"\n |]\n ; [| \"21634048616875364065210304993971256601326650069082669576726378272437410251852\"\n ; \"1440291557054822025042926468154900761163167753541613162663250995564641638121\"\n ; \"8030862880899531201072645375229460968330384014296763956553993045932171788794\"\n |]\n ; [| \"18227143364048378671809657511264604955612895339528675264153781365139338073044\"\n ; \"21758886539711282145698252967647695643837152466011063420158481037553923112829\"\n ; \"2085588517087605436136379278738013214233743532079287631079316773925068862732\"\n |]\n ; [| \"9513664655545306376987968929852776467090105742275395185801917554996684570014\"\n ; \"3550496136894926428779047632731319031180547135184616875506154252232382772731\"\n ; \"17611757480287922505786279147168077243913583114117625089682651438292645979006\"\n |]\n ; [| \"9510531870810299962531161626148485102758508164021526746981465493469502973181\"\n ; \"13147395489659079072941169740078305253501735721348147621757420460777184976765\"\n ; \"20981004218820236011689230170078809973840534961691702543937445515733151438851\"\n |]\n ; [| \"7510474971056266438887013036637998526887329893492694485779774584612719651459\"\n ; \"1410506880075029891986606588556057112819357276074907152324471561666187504226\"\n ; \"8531153700191448965915372279944017070557402838400132057846710117192547288312\"\n |]\n ; [| \"9754021311900999917627020811752417367253388211990562024285328010011773088524\"\n ; \"2596434275792412604724294796434266571220373976229139969740378299737237088707\"\n ; \"12362606196840499695717697542757730593369897628148107607660372162713524022091\"\n |]\n ; [| \"7436712609498458515091822640340398689078308761236724993140849063351217155692\"\n ; \"13658397008139421803306375444518324400013880452735832208526361116879733324843\"\n ; \"8172299227253932586074375157726142633344272790321861656172484971306271304428\"\n |]\n ; [| \"8605586894544301092657394167906502995894014247978769840701086209902531650480\"\n ; \"8900145888985471928279988821934068156350024482295663273746853580585203659117\"\n ; \"10470367937616887936936637392485540045417066546520320064401889047735866701687\"\n |]\n ; [| \"11506602210275354295255815678397482725225279643868372198705067756030230710066\"\n ; \"17848856881287888035559207919717746181941756011012420474955535369227552058196\"\n ; \"19621145748343950799654655801831590696734631175445290325293238308726746856381\"\n |]\n ; [| \"12864577757979281303137787677967581089249504938390812240088160999517854207023\"\n ; \"18146514933233558325125054842576736679593504913006946427595273862389774486334\"\n ; \"17884323247493851213892188228998881081766487773962855826892871743190914823275\"\n |]\n ; [| \"15402752720164650756401756498467037967910822997380610100998339390049962612988\"\n ; \"7603833157231114748089157493970988832295123465399487746989788482408777456140\"\n ; \"2397354421161661799662850246720819176952681967344524176801474312220041680576\"\n |]\n ; [| \"4644616545339594419852483555455431260822330146405566037177120172304445909733\"\n ; \"5263316028405817083848964416595634986103420395264546879434975622138579030157\"\n ; \"17782273009863750298483603933610732253879825505411230932533407287574651036994\"\n |]\n ; [| \"6757311365906043231713330034681410088312690560822302805339061832230418577842\"\n ; \"1747290142831105666564148972092238090059848968766027623980111244846463775952\"\n ; \"15626225602106279302483693031455114927351808163854564654776963760236790234423\"\n |]\n ; [| \"4913834867494755682369542218157533479788980551925269537630059523083653281581\"\n ; \"9877617390649361889067963484857474874019563445507538784053773745685676317984\"\n ; \"8907943459697784281828563593274242625606699321626165523327303792165072591809\"\n |]\n ; [| \"14664441047816797924985624056829230652985567659075289185564514710695287602702\"\n ; \"7007559757050385070202651829819464617707337597545855825279581955097245183469\"\n ; \"9907785227545441866241924986174555965766785257012652276622736289520175209842\"\n |]\n ; [| \"7597089497072493253646609764279824048404496412283438400323292326749646956121\"\n ; \"17909115638003629710512488646279326535029895707443505816458395075119245680309\"\n ; \"19899288359840151413448648239934294957736422087766709732366801832575234898200\"\n |]\n ; [| \"2776453255551777594442164922386336989357594907242688467733231910101268428455\"\n ; \"8731512921802677638551206899688496704819923065834522157915668185471088199231\"\n ; \"4270476107979642660344328132306502268479679050594759895042187137572326348178\"\n |]\n ; [| \"372963191403207230700085823960930798511810380777302780932220121859190714585\"\n ; \"1925392345596430848747460046135384348851089627416455489129305703977614383441\"\n ; \"17789118105598492176513882528357022912279065134405326075480819364512109487507\"\n |]\n ; [| \"20825008332751730091153821568987055752818061964131515789006779860691972036326\"\n ; \"12268072226614207724192089529070006978828099093641075700056577974897967878044\"\n ; \"8022939345678575485891537869705234790517539631432710130025799605516328239965\"\n |]\n ; [| \"15920446357440463160102379501579737913732417583637399015449814673775945192536\"\n ; \"4889967763577997404116252754960720158524059605911680924823220236886032161368\"\n ; \"13012115310019421859484865413402512912208022868124085927375736053832542569552\"\n |]\n ; [| \"11184812848348784840758139578916764774803469528077342079324383443440533140274\"\n ; \"10919525644265283860710095821750480494008303946536963464168615308937735732928\"\n ; \"16643027351354734329387947050668943310718100664075062130784371167893146427056\"\n |]\n ; [| \"2547391079287933146721925003560805204947901674695385307171999864858240689647\"\n ; \"5461671591847528192305502006203904211083239588855740323679605269651748982133\"\n ; \"1475483405991676112203600016600397946486872901513454996978092595555024286449\"\n |]\n ; [| \"5284066352388289958166453130467461920311116585098603685258698324490583696214\"\n ; \"11079707743980425617427448803513138667107248696505015838485445487813501565055\"\n ; \"18819466619498056228169794477791931948230648942982309978769076145394195937041\"\n |]\n ; [| \"20108313126965297449432768889178575293551084908049301416432179490902972394331\"\n ; \"18446218870769123862937242938812447270514023886221086573211479802027270358088\"\n ; \"16636528128134911466622907961467317982179835733058354229921170933476186200761\"\n |]\n ; [| \"21580255665898770000010464770058710398562069327783167608746916860519840032223\"\n ; \"14719915601901504081829966027980062397831689039960210526441564682684152170817\"\n ; \"797386830910520008361185815477523544664694040635544500916993469578452189812\"\n |]\n ; [| \"9191954826842055432037975444679415772735351199913945274909680288228536535340\"\n ; \"11513278700830950317038408125611466230422950302149566779135423862866530023329\"\n ; \"13459513701495368402370574098477760729128222868352131109204646186188457791240\"\n |]\n ; [| \"5838069727284828316721466034821618997221603062621589223178808662165373261546\"\n ; \"6979902978975477924362644821755411140298300026935490428140425890908442375988\"\n ; \"16599678038272927378481138839511139789855186087290435109798146115836043579679\"\n |]\n ; [| \"12381797209422929428691015082010109537263140181969703876017444022025467803832\"\n ; \"6196650026284414689888119006953515712490610535320673834463816720858366634575\"\n ; \"18782265413128936113173411940279630009396595382244197409034789821410800698518\"\n |]\n ; [| \"18317002472599225949038448120242542829985613745531554876060436499109578301758\"\n ; \"1113479082803535302111716504211921283895099225074844625686926178204705529642\"\n ; \"5260759667255734667421232066934840926892602367345740699882163520384512718144\"\n |]\n ; [| \"127322212868745470136356444796372247628159800282485305190839131621480537609\"\n ; \"12956514709922286639520985225111137950302442378466870763868693820049405409474\"\n ; \"16137538628380664965477096166491883462931577135505027115582810475234963977421\"\n |]\n ; [| \"11057045636926688236651567778699977961671424092293844825634750356999128470728\"\n ; \"20835936071817504066403719723663997794776505092359954695254304206506756731833\"\n ; \"11961388648747677421997837882451601307689195235077835309786508479783430361445\"\n |]\n ; [| \"1793573889039951715150662350698925328676543592757846244725079508391393408932\"\n ; \"13402289137612357934827599869485046878369856459821775713222740005646790544884\"\n ; \"6508055411788943934719705492602467864380077642763636443982129530687343724318\"\n |]\n ; [| \"17607902685988307931266356493635411696470169831190714792315124728753478035177\"\n ; \"8194273390415023152581060020119881338779571723515253104919314696738194355344\"\n ; \"14994505851254731180804912001382376960436431877822495675906581329931114145032\"\n |]\n ; [| \"18381184948945816702338052755591260342844745389721883995323025098702517473904\"\n ; \"9186573784864449816023279170257163602574499515262252135042448697937263179368\"\n ; \"16881796086836744646703159464114164393240695449455598565494759189917589453976\"\n |]\n ; [| \"20572234397819806324185746612386811237648846766146640064924937718650897781978\"\n ; \"15398960110011455954857390264976694406010423055791889624651258877641756178391\"\n ; \"7626627472565586612974136909394190701438927259101824156422280944508708088979\"\n |]\n ; [| \"5225513048091970342186287982290643286434413678466132108172918521639972895801\"\n ; \"20796219142718322272479527852102350372678035311367637066794738260059405761892\"\n ; \"18867914789735779656943683552060466421616672953566565464125163675462552310225\"\n |]\n ; [| \"1082743678015977585514191190870862236773423558498135453104771878687511906366\"\n ; \"12623224059252254308457589993365174837697684756635908936641223908438823373531\"\n ; \"12555890586414377546838955106772636059664719538696271061728900536297596172906\"\n |]\n ; [| \"15264924047176739600757644598701762120134127746088692861582462406342309222440\"\n ; \"13735945315945382005247895569035266667172550063549145646185577935658666385507\"\n ; \"16846296242516834547231537358954027537902709068158411294345086281698311539718\"\n |]\n ; [| \"5529559903327977764360588597603235134251022845353553657623467329197099735440\"\n ; \"17896661983150937411004047429485556264820315976705642986609974816436222162633\"\n ; \"6132147645856673317909222426799071493032959293586440635818225286067400272621\"\n |]\n ; [| \"19910536448857177568998054979673460274356626268309923630750601690129744044143\"\n ; \"21837022717353361125929262770547893899304355057483567328441690117551675150495\"\n ; \"18222937567706439527101614170488289588444167715669706061945406480673991437911\"\n |]\n ; [| \"1444795096087046870164826172194881116549489406599247123900277072374333222523\"\n ; \"7789285740743619796571024808404378017415878533792118428790588967260363950606\"\n ; \"2733591517253510124338232417535938539627593736745105875672348998709544742241\"\n |]\n ; [| \"10797236245657229835704604790990749002913266164534811352882924972411330424481\"\n ; \"8586865110658270624125510090452038681539626362312203247529227232785490000213\"\n ; \"16990606351055720221300633612533434675038905235719867684891402550154692840579\"\n |]\n ; [| \"13886834869596827027283068322204563244577723967928602405785473534631482228259\"\n ; \"15370041030312982119820349355806306848945675230473045778175606920520020444465\"\n ; \"4892392164144856036080673702415932177491638051096567008590655427718905654995\"\n |]\n ; [| \"7156056361402750618478307158538015778512650133626207855710105646992193371811\"\n ; \"18611994297623980580066352324654520696209128189173454279498506046357017146863\"\n ; \"20685574625754044704454597610042653981655420607405749168756591785339765348017\"\n |]\n ; [| \"19771798755427122057663307238031585225333077748195038834574552418532105026109\"\n ; \"7198246770791404776745997973411401046335399072925979346193035999274650139809\"\n ; \"4023053642231617394331377349850999955271972515156538475518460583299482183537\"\n |]\n ; [| \"8600241056877374090996492763915201371612819917708477598778176717657922462947\"\n ; \"13457797645730052033686724345687857978500724093559828625307818927699840833531\"\n ; \"16026530057488171235747101959040626414628692240827947554707033614704824950299\"\n |]\n ; [| \"17395049232451382970906883167116397657891664802601579276725674512534883408665\"\n ; \"9339859050789350561021790367067195330588925099928812336960590308144433379361\"\n ; \"2949098252117356570135518983407292742860689840833413663842097549831698684366\"\n |]\n ; [| \"20556719902345568138970735755829852608784985449829745172855204153387982836579\"\n ; \"17130405757403641097651484965062131526367059595476924144885570325828777794585\"\n ; \"12098791849907955483840555979771849699037912527654257328360429401569823685788\"\n |]\n ; [| \"17814517977679061356584950826520510701145481336316888282105225134451035883368\"\n ; \"18340263833447961155645725374025776400999561225129160795675360757778486987388\"\n ; \"2393071357700172397099185245759131983536576193657235776526704600015951290441\"\n |]\n ; [| \"4212550607122984812935174903270756328485507924528581618288369631872316849833\"\n ; \"4619648579309903974086199484827129282821840232468518761664883379486001128848\"\n ; \"11830688953328429351984357834116389341476681935757757908813724623462162230171\"\n |]\n ; [| \"9433820477150269924006815701757707228705128802452735931367255389078887381031\"\n ; \"19125188968599512029274834491491595733696896208317777847233033576184416289376\"\n ; \"5918385816682866756860679567405784562483373873565987668410277610868983146285\"\n |]\n ; [| \"11679489428851609457960439894174478045625452323813143057634803520728058419797\"\n ; \"5724733785096476011403606227853139854344547354731648536310363676109859979599\"\n ; \"17573793517331212796808333696068548553394697853729636886331034644281465518715\"\n |]\n ; [| \"282611654311082728776282944765587839903391931876410017096206359579538734085\"\n ; \"742728073451137928865285752406697012428821295824901554854990717103000537584\"\n ; \"20306380368695786945008272690438693745796297843799468268993907772341096948885\"\n |]\n ; [| \"18100113160685180514467703718098463577197975190144073884222766672672318113538\"\n ; \"3596350844916320672068639652188042917240676939829686824217717083735102849099\"\n ; \"20838832950303269747058536033620845977209873531644245727210334971563271393066\"\n |]\n ; [| \"6253957843395630813948692334683334608532810817769598722493240718085139817265\"\n ; \"19309791485130397858271625213458465097936495981008767692231734090527713082114\"\n ; \"5939164146353625472313254161303475736537743070584069770562424769865448756665\"\n |]\n ; [| \"12298194698807155456066733319264594344499679328227389872285371269582859681345\"\n ; \"10410720333027720675907856932360489614426170334449240317306371002856268450593\"\n ; \"13207537521011022812319141236421268356825327806625537047299253455889808792527\"\n |]\n ; [| \"2622643323130765702269424224791233611920515499144047449633123689743564676648\"\n ; \"7934318163093606910388307192320021056510770283350564327826894301919432120323\"\n ; \"7390981975273378581893427566935692330605702531948453130383999822487328794460\"\n |]\n |]\n }\n\nlet params_Mnt4_298 =\n { Params.mds =\n [| [| \"181324588122329172048070802614406344967661900669343676997796156524662650229663511778086513\"\n ; \"263839662794798230944406038483748877420003467481254943330033497627810628977768312588897021\"\n ; \"47787034086054868794736504598805355240746067397315425760363325479582067585554122384528750\"\n |]\n ; [| \"391385728862913577230643656405794210023251219169789744235774373121108965138889307827345939\"\n ; \"368056256556859616791833365938123080683505948787537081082804782658777406001515743364112843\"\n ; \"249229689710372851346889167834108105226843437678081232334602983010385341756350839066179566\"\n |]\n ; [| \"391761630355250451965959916078641131603140945583687294349414005799846378806556028223600720\"\n ; \"309426222273897994989187985039896323914733463925481353595665936771905869408957537639744345\"\n ; \"429282034891350663871556405902853196474768911490694799502975387461169986038745882893853806\"\n |]\n |]\n ; round_constants =\n [| [| \"78119860594733808983474265082430117124674905785489385612351809573030163625517\"\n ; \"41917899842730241418346215913324270532073353586134123463219061327941260175271\"\n ; \"74594641694171623328644944059182600919855574964222988275913344198970402906473\"\n |]\n ; [| \"96215759378377024990520153908983544755208851791126218239402755616994541522004\"\n ; \"64070601581278917442704840630680311036021557676765751754522901046069205253111\"\n ; \"112123228532462696722378911494343451272980413618911326680094528285518792872677\"\n |]\n ; [| \"84572244072021308337360477634782636535511175281144388234379224309078196768262\"\n ; \"45201095631123410354816854701250642083197167601967427301389500806815426216645\"\n ; \"23419302413627434057960523568681421397183896397903197013759822219271473949448\"\n |]\n ; [| \"63220724218126871510891512179599337793645245415246618202146262033908228783613\"\n ; \"67900966560828272306360950341997532094196196655192755442359232962244590070115\"\n ; \"56382132371728071364028077587343004835658613510701494793375685201885283260755\"\n |]\n ; [| \"80317852656339951095312898663286716255545986714650554749917139819628941702909\"\n ; \"110977183257428423540294096816813859894739618561444416996538397449475628658639\"\n ; \"25195781166503180938390820610484311038421647727795615447439501669639084690800\"\n |]\n ; [| \"108664438541952156416331885221418851366456449596370568350972106298760717710264\"\n ; \"17649294376560630922417546944777537620537408190408066211453084495108565929366\"\n ; \"95236435002924956844837407534938226368352771792739587594037613075251645052212\"\n |]\n ; [| \"43150472723422600689013423057826322506171125106415122422656432973040257528684\"\n ; \"77355911134402286174761911573353899889837132781450260391484427670446862700214\"\n ; \"8690728446593494554377477996892461126663797704587025899930929227865493269824\"\n |]\n ; [| \"109175231986025180460846040078523879514558355792739714578031829643740609438879\"\n ; \"64844253590731404811389281562033735091759746904073461140427127388042062490899\"\n ; \"43237071281695629980341250188156848876595681601471702180515324064382368960951\"\n |]\n ; [| \"2704440995725305992776846806711930876273040749514871232837487081811513368296\"\n ; \"66806779110388532101035294912010606217442229808784290357894909707660045365269\"\n ; \"25541187612624070470730890200174075890643652797181103367956318438136878170352\"\n |]\n ; [| \"89300613074831725721350087269266903129165086877175223066581882601662278010666\"\n ; \"36824076981866281177052433916337787028520068526782493484076995129329938182524\"\n ; \"68880449342008497744225106025198236600142055580985632884415488154606462819445\"\n |]\n ; [| \"68556888546596545408135887526582256648006271867854316538090068824142539400698\"\n ; \"111379753250206255125320675615931203940253796355491142745969887430259465111569\"\n ; \"101469186248899356416491489235841069222521093012237305521090058066171355672289\"\n |]\n ; [| \"87819793263125973233157093200229218382531712066157093399606059493857616731410\"\n ; \"11055386921184594780372263378420826851562920740321950336882051897732501262543\"\n ; \"111945832089295501567161822264292548657346358707472584179854375613919325491249\"\n |]\n ; [| \"95630018375719472826904441325138673248990446382783206900295723762884876505178\"\n ; \"94833984285990985873155989049880754188702918168949640563745233736765833491756\"\n ; \"77578854197021606645372788474039811639438242484066959482386065023999206730771\"\n |]\n ; [| \"27799616729223271646690718201487403976485619375555391888533887467404804041014\"\n ; \"42616502170265664498961018686434252976977548128285781725227341660941880774718\"\n ; \"95884094505080541517768389956970969462501217028562326732054532092615835087122\"\n |]\n ; [| \"107531500891040898338150732759493933154418374543568088749403053559827078391994\"\n ; \"17316158269457914256007584527534747738658973027567786054549020564540952112346\"\n ; \"51624680144452294805663893795879183520785046924484587034566439599591446246116\"\n |]\n ; [| \"17698087730709566968258013675219881840614043344609152682517330801348583470562\"\n ; \"111925747861248746962567200879629070277886617811519137515553806421564944666811\"\n ; \"57148554624730554436721083599187229462914514696466218614205595953570212881615\"\n |]\n ; [| \"92002976914130835490768248031171915767210477082066266868807636677032557847243\"\n ; \"58807951133460826577955909810426403194149348045831674376120801431489918282349\"\n ; \"93581873597000319446791963913210464830992618681307774190204379970955657554666\"\n |]\n ; [| \"46734218328816451470118898692627799522173317355773128175090189234250221977353\"\n ; \"12565476532112137808460978474958060441970941349010371267577877299656634907765\"\n ; \"54284813390357004119220859882274190703294683700710665367594256039714984623777\"\n |]\n ; [| \"92046423253202913319296401122133532555630886766139313429473309376931112550800\"\n ; \"15095408309586969968044201398966210357547906905122453139947200130015688526573\"\n ; \"76483858663950700865536712701042004661599554591777656961315837882956812689085\"\n |]\n ; [| \"37793510665854947576525000802927849210746292216845467892500370179796223909690\"\n ; \"84954934523349224038508216623641462700694917568481430996824733443763638196693\"\n ; \"81116649005575743294029244339854405387811058321603450814032274416116019472096\"\n |]\n ; [| \"28313841745366368076212445154871968929195537523489133192784916081223753077949\"\n ; \"17307716513182567320564075539526480893558355908652993731441220999922946005081\"\n ; \"63148771170858502457695904149048034226689843239981287723002468627916462842625\"\n |]\n ; [| \"14724939606645168531546334343600232253284320276481307778787768813885931648950\"\n ; \"4684996260500305121238590806572541849891754312215139285622888510153705963000\"\n ; \"63682763879011752475568476861367553456179860221069473817315669232908763409259\"\n |]\n ; [| \"47776179656187399887062096850541192680190218704758942820514561435612697426715\"\n ; \"42017618175533328439486588850450028995049195954365035474995309904751824054581\"\n ; \"39169739448648613641258102792190571431737464735838931948313779997907435855102\"\n |]\n ; [| \"37525991163523321662699819448962967746703579202577998445997476955224037837979\"\n ; \"67759173441312327668891803222741396828094999063019622301649400178376863820046\"\n ; \"23041132473771739182071223620364590606653086905326129708428084432335332411661\"\n |]\n ; [| \"77778894465896892167598828497939467663479992533052348475467490972714790615441\"\n ; \"20821227542001445006023346122554483849065713580779858784021328359824080462519\"\n ; \"47217242463811495777303984778653549585537750303740616187093690846833142245039\"\n |]\n ; [| \"42826871300142174590405062658305130206548405024021455479047593769907201224399\"\n ; \"8850081254230234130482383430433176873344633494243110112848647064077741649744\"\n ; \"1819639941546179668398979507053724449231350395599747300736218202072168364980\"\n |]\n ; [| \"21219092773772827667886204262476112905428217689703647484316763603169544906986\"\n ; \"35036730416829620763976972888493029852952403098232484869595671405553221294746\"\n ; \"35487050610902505183766069070898136230610758743267437784506875078109148276407\"\n |]\n ; [| \"62560813042054697786535634928462520639989597995560367915904328183428481834648\"\n ; \"112205708104999693686115882430330200785082630634036862526175634736046083007596\"\n ; \"109084747126382177842005646092084591250172358815974554434100716599544229364287\"\n |]\n ; [| \"63740884245554590221521941789197287379354311786803164550686696984009448418872\"\n ; \"58779928727649398559174292364061339806256990859940639552881479945324304668069\"\n ; \"20614241966717622390914334053622572167995367802051836931454426877074875942253\"\n |]\n ; [| \"41621411615229558798583846330993607380846912281220890296433013153854774573504\"\n ; \"20530621481603446397085836296967350209890164029268319619481535419199429275412\"\n ; \"99914592017824500091708233310179001698739309503141229228952777264267035511439\"\n |]\n ; [| \"9497854724940806346676139162466690071592872530638144182764466319052293463165\"\n ; \"7549205476288061047040852944548942878112823732145584918107208536541712726277\"\n ; \"30898915730863004722886730649661235919513859500318540107289237568593577554645\"\n |]\n ; [| \"22697249754607337581727259086359907309326296469394183645633378468855554942575\"\n ; \"72771100592475003378969523202338527077495914171905204927442739996373603143216\"\n ; \"84509851995167666169868678185342549983568150803791023831909660012392522615426\"\n |]\n ; [| \"36601166816771446688370845080961015541431660429079281633209182736773260407536\"\n ; \"19555759172327736128240171000715903945570888389700763573790859521156095228287\"\n ; \"82844424532983875300577689116331373756526403900340445449185486212503235782229\"\n |]\n ; [| \"40833119728631657038301474658571416779079199343770917422783737091842927892625\"\n ; \"68922359316478675184342553333343300163568193749010867527082189412217781430311\"\n ; \"91516472400306837063911995909475588197278444979245081960087094196120449075833\"\n |]\n ; [| \"21304716730402869084944080869903443431235336418077153507261240151959530377653\"\n ; \"106551237424345741137570659736231801772439680702621554106791455938098031620471\"\n ; \"104392597313271110590927764888829150750277653499050463757708547416538850601163\"\n |]\n ; [| \"16907937154215020261110468963982390213438461071031811101554056252102505124726\"\n ; \"23183141532591565112222057191012766855134687114504142337903677590107533245206\"\n ; \"96725517880771645283128624101279195709280644465575982072053504613644938879246\"\n |]\n ; [| \"84556507395241990875812091718422997082915179448604219593521819129312718969906\"\n ; \"100646525819453650494590571397259055384579251368754179569362740802641255820576\"\n ; \"50316555026297423940834952362583934362215303629664094841692233643882339493043\"\n |]\n ; [| \"77363534410783423412630139556441807611393685349073113946053979350631229049878\"\n ; \"54905073434434959485893381841839373267383966385817882684657825178181863944371\"\n ; \"110016011331508430102821620395154714608084938556260733745010992614542669817451\"\n |]\n ; [| \"52040139270046094723964229965823921970388683619580004402190656733318120479093\"\n ; \"495546618036723566920914648951352373868059898268055487677897567226892784967\"\n ; \"2528292188392170914010448139211586215817069915670005292953294092269979070980\"\n |]\n ; [| \"36842840134449713950999812540127591123318806680559982063089906871196226758113\"\n ; \"112314504940338253416202605695368724580971154020421327790335219348068041886245\"\n ; \"51653712314537383078368021242008468828072907802445786549975419682333073143987\"\n |]\n ; [| \"27179054135131403873076215577181710354069071017096145081169516607932870071868\"\n ; \"93264325401956094073193527739715293258814405715822269809955952297346626219055\"\n ; \"75336695567377817226085396912086909560962335091652231383627608374094112503635\"\n |]\n ; [| \"42536477740858058164730818130587261149155820207748153094480456895727052896150\"\n ; \"45297707210835305388426482743535401273114010430724989418303851665124351001731\"\n ; \"28263543670875633354854018109712021307749750769690268127459707194207091046997\"\n |]\n ; [| \"40809484989590048522440442751358616303471639779690405026946053699354967624695\"\n ; \"51589519265418587649124543325590658874910911006853535317847189422703251228717\"\n ; \"73459936981642894525955700397592343967482441686326322443228255968694436816673\"\n |]\n ; [| \"87298777232393189731949522229743081866971743270330772607820990832164835738703\"\n ; \"23328534428894097247289332213412175849711532153957647506361455182140450133738\"\n ; \"51807348624578081645565456865744011145427112815128832643950401419083788780028\"\n |]\n ; [| \"62003629107726929116302469001779155132709624140360743951550189738290955064278\"\n ; \"109311858027068383034683875948676795998030610067675200794951297783857157095297\"\n ; \"2085588517087605436136379278738013214233743532079287631079316773925068862732\"\n |]\n ; [| \"9513664655545306376987968929852776467090105742275395185801917554996684570014\"\n ; \"91103467624252027317764670613760419385374004736848754250298970998535616755199\"\n ; \"39500000352127197728032684892425352332461947514533659433380855624868454474623\"\n |]\n ; [| \"75175260486328125629270378861920310368403601365269629778076078053196928460032\"\n ; \"56923881233337629517433981230592855430598464522180216309153828833928801967999\"\n ; \"20981004218820236011689230170078809973840534961691702543937445515733151438851\"\n |]\n ; [| \"73175203586574092105626230272409823792532423094740797516874387144340145138310\"\n ; \"45186992623753580336479418079070607289916086076906975839720879934817804495460\"\n ; \"96084125187548549854900995260973117424750860440064269432639526863495781270780\"\n |]\n ; [| \"53530507055579550362119832302266967544350117012822630711681736383163390079758\"\n ; \"24484677147631687826970700541691541659768738376645174313438582486313045584324\"\n ; \"99915577684197600584703320523786830947563355229812244982453188909016758004559\"\n |]\n ; [| \"73101441225016284181831039876112223954723401962484828024235461623078642642543\"\n ; \"57434882751817972247799186935032874577110609253567900895922769490031350316077\"\n ; \"73837027842771758252813592393497967898989365991569964687267097531033696791279\"\n |]\n ; [| \"8605586894544301092657394167906502995894014247978769840701086209902531650480\"\n ; \"8900145888985471928279988821934068156350024482295663273746853580585203659117\"\n ; \"76135096553134713603675854628257365311062159747768423095496501607463292188538\"\n |]\n ; [| \"77171330825793179961995032914169307990870372845116475229799680315757656196917\"\n ; \"17848856881287888035559207919717746181941756011012420474955535369227552058196\"\n ; \"85285874363861776466393873037603415962379724376693393356387850868454172343232\"\n |]\n ; [| \"34752820629818556525384193423224856177797869338806846583786365186093662702640\"\n ; \"61923000676912108769617866333091286856690233713839015114991682235541391477568\"\n ; \"105437294734850952102877811210027981435959945375626993201685688489494148805743\"\n |]\n ; [| \"37290995592003925978648162243724313056459187397796644444696543576625771108605\"\n ; \"95156804644588215637074780475000089186488581067063625121782605228712011438608\"\n ; \"111838568780358037910894878973007194619694503969424695895292495245099084158661\"\n |]\n ; [| \"114085830904535970531084512281741806703564152148485737755668141105183488387818\"\n ; \"27151558900245092306095370161852910074651784795680581223133179808714387525774\"\n ; \"17782273009863750298483603933610732253879825505411230932533407287574651036994\"\n |]\n ; [| \"72422039981423868898452547270453235353957783762070405836433674391957844064693\"\n ; \"23635533014670380888810554717349513178608213369182061967678315431422272271569\"\n ; \"59402711345784829746976504521969665104448536964686633342173372133388407225657\"\n |]\n ; [| \"92466806354851856571355165199186633833982438153589406912422876269386887264049\"\n ; \"9877617390649361889067963484857474874019563445507538784053773745685676317984\"\n ; \"74572672075215609948567780829046067891251792522874268554421916351892498078660\"\n |]\n ; [| \"36552683919656073147232029802086505741533932059491323529262718897271096098319\"\n ; \"28895802628889660292449057575076739706255701997961890168977786141673053679086\"\n ; \"9907785227545441866241924986174555965766785257012652276622736289520175209842\"\n |]\n ; [| \"29485332368911768475893015509537099136952860812699472744021496513325455451738\"\n ; \"39797358509842904932758894391536601623578260107859540160156599261695054175926\"\n ; \"107452259847197252302434271220963395311929879689430847107159618578878468880668\"\n |]\n ; [| \"24664696127391052816688570667643612077905959307658722811431436096677076924072\"\n ; \"52507998665481228083044018390203046881916651866666590845312076558622705190465\"\n ; \"69935204723497468327083545368078327534124772251842862926136799697299751835029\"\n |]\n ; [| \"372963191403207230700085823960930798511810380777302780932220121859190714585\"\n ; \"111366606704792806959979488772421759791592911629496627207620326636856656861526\"\n ; \"39677360977437767398760288273614298000827429534821360419179023551087917983124\"\n |]\n ; [| \"64601494076430280535646633059501605929914790764963584476403188233843589027560\"\n ; \"34156315098453482946438495274327282067376463494057110043754782161473776373661\"\n ; \"73687667961196401152630755105477060056162632832680813161120412165243753726816\"\n |]\n ; [| \"37808689229279738382348785246837013002280781984053433359148018860351753688153\"\n ; \"26778210635417272626362658500217995247072424006327715268521424423461840656985\"\n ; \"13012115310019421859484865413402512912208022868124085927375736053832542569552\"\n |]\n ; [| \"33073055720188060063004545324174039863351833928493376423022587630016341635891\"\n ; \"76584254259783109527449313057522305759653397147785066495263227868665161219779\"\n ; \"38531270223194009551634352795926218399266465064491096474482575354468954922673\"\n |]\n ; [| \"90100362566645034035707547984589905559141359276359522681964816611161474672115\"\n ; \"93014643079204629081291124987233004565276697190519877698472422015954982964601\"\n ; \"110916697765188052223435628742886773389228694903593626715469113528434066764534\"\n |]\n ; [| \"114725280711584666069398481856753837363052938587178775403749719257369626174299\"\n ; \"32967950615819700839673854548770413755655613096921050182183649674389310060672\"\n ; \"106372438106855157117155417458821032302424106544646447353561892891697429919509\"\n |]\n ; [| \"41996555998804572671679174634435850382099449308465335760130383677478780889948\"\n ; \"105999190358126224751922865919841547624707481487885223948004296548330504340556\"\n ; \"16636528128134911466622907961467317982179835733058354229921170933476186200761\"\n |]\n ; [| \"43468498537738045222256870515315985487110433728199201952445121047095648527840\"\n ; \"102272887089258604970815589009009162752025146641624347901234381428987386153285\"\n ; \"797386830910520008361185815477523544664694040635544500916993469578452189812\"\n |]\n ; [| \"96744926314199156321023598425708516126928808801578082649702497034531770517808\"\n ; \"99066250188188051206024031106640566584616407903813704153928240609169764005797\"\n ; \"101012485188852469291356197079506861083321680470016268483997462932491691773708\"\n |]\n ; [| \"49614555470963378761214277525336169174318331863453657910575217035316990252780\"\n ; \"94532874466332578813348267802784511494491757628599627802933242637211676358456\"\n ; \"60376163781951477822973950330025689966951914888122503797194554488987660570913\"\n |]\n ; [| \"99934768696780030317676638063039209891456597783633841250810260768328701786300\"\n ; \"71861378641802240356627336242725340978135703736568776865558429280585792121426\"\n ; \"84446994028646761779912629176051455275041688583492300440129402381138226185369\"\n |]\n ; [| \"18317002472599225949038448120242542829985613745531554876060436499109578301758\"\n ; \"23001721954642810524358122249469196372443463625490878969385130364780514025259\"\n ; \"49037245410934285111914043557449391103989331168177809387278571893536129709378\"\n |]\n ; [| \"65792050828386571136875573680568197513273253001530588336285451691348906024460\"\n ; \"12956514709922286639520985225111137950302442378466870763868693820049405409474\"\n ; \"38025781500219940187723501911749158551479941535921061459281014661810772473038\"\n |]\n ; [| \"98610017124283789125637190759729078315864881693957982200427567103302362453196\"\n ; \"42724178943656779288650125468921272883324869492775989038952508393082565227450\"\n ; \"99514360136104778310983460863480701661882652836741972684579325226086664343913\"\n |]\n ; [| \"111234788248236327826382691076985300771418365594838017963216100441270435887017\"\n ; \"35290532009451633157074005614742321966918220860237810056920944192222599040501\"\n ; \"72172784027306769601458922728374293130025170844011739475076742090414769211169\"\n |]\n ; [| \"61384388429666858375759167984149961873566898632022783479711533101905095026411\"\n ; \"8194273390415023152581060020119881338779571723515253104919314696738194355344\"\n ; \"80659234466772556847544129237154202226081525079070598707001193889658539631883\"\n |]\n ; [| \"62157670692624367146830864246105810519941474190553952682719433471854134465138\"\n ; \"74851302400382275482762496406028988868219592716510355166137061257664688666219\"\n ; \"16881796086836744646703159464114164393240695449455598565494759189917589453976\"\n |]\n ; [| \"42460477269659081546432152357644086326197211166562674408623141905226706277595\"\n ; \"81063688725529281621596607500748519671655516257039992655745871437369181665242\"\n ; \"51403113216244137057466948399908740878535656059933892843818689317660325080213\"\n |]\n ; [| \"49001998791770520786679099472805193463531142479298200795569326894791589887035\"\n ; \"42684462014557597494725933597359625461226399711783671410492942446635214257509\"\n ; \"106420886277092880545929306533089566775810130555230702838917980421765786292693\"\n |]\n ; [| \"110523958037212353696746219917157237679515245560578307171595792811566554384451\"\n ; \"56399709802930804752950401483879725014794413557467977624037632281590440364765\"\n ; \"100108862073771478435824578087801736413858177140360408436521717282600830155374\"\n |]\n ; [| \"59041409790855290045250456089216312297230856546920761548978870779493926213674\"\n ; \"13735945315945382005247895569035266667172550063549145646185577935658666385507\"\n ; \"16846296242516834547231537358954027537902709068158411294345086281698311539718\"\n |]\n ; [| \"114970774262524353875592617323889610576992844847433725376114488262076142213525\"\n ; \"17896661983150937411004047429485556264820315976705642986609974816436222162633\"\n ; \"115573362005053049429141251153085446935774781295666612354309246218946442750706\"\n |]\n ; [| \"85575265064375003235737272215445285540001719469558026661845214249857169530994\"\n ; \"87501751332871186792668480006319719164949448258731670359536302677279100637346\"\n ; \"105775909055063540416087237151517389942637625317333843436738223226977225420379\"\n |]\n ; [| \"110886009455283422981396854898481256559291311408679418842391298005253375700608\"\n ; \"95342257228100720685556647789433478371609336135456255803583405713563597933074\"\n ; \"2733591517253510124338232417535938539627593736745105875672348998709544742241\"\n |]\n ; [| \"32685479117496505057951010536248024091461630564950845696581129158987138920098\"\n ; \"96139836598015371513111133071481139035733083963976340622322043979088723982681\"\n ; \"16990606351055720221300633612533434675038905235719867684891402550154692840579\"\n |]\n ; [| \"13886834869596827027283068322204563244577723967928602405785473534631482228259\"\n ; \"81034769645830807786559566591578132114590768431721148809270219480247445931316\"\n ; \"26780635035984131258327079447673207266040002451512601352288859614294714150612\"\n |]\n ; [| \"72820784976920576285217524394309841044157743334874310886804718206719618858662\"\n ; \"84276722913141806246805569560426345961854221390421557310593118606084442633714\"\n ; \"42573817497593319926701003355299929070203785007821783512454795971915573843634\"\n |]\n ; [| \"41660041627266397279909712983288860313881442148611073178272756605107913521726\"\n ; \"7198246770791404776745997973411401046335399072925979346193035999274650139809\"\n ; \"91576025129588718283317000330880100309465430116820675850311277329602716166005\"\n |]\n ; [| \"30488483928716649313242898509172476460161184318124511942476380904233730958564\"\n ; \"35346040517569327255933130090945133067049088493975862969006023114275649329148\"\n ; \"59803015801166721680239913449555176591725421041660016242103441987856441941533\"\n |]\n ; [| \"17395049232451382970906883167116397657891664802601579276725674512534883408665\"\n ; \"96892830538146451450007413348096295684782382701592949711753407054447667361829\"\n ; \"46725583995795907014628330473921842919957418641665482351238505922983315675600\"\n |]\n ; [| \"20556719902345568138970735755829852608784985449829745172855204153387982836579\"\n ; \"17130405757403641097651484965062131526367059595476924144885570325828777794585\"\n ; \"99651763337265056372826178960800950053231370129318394703153246147873057668256\"\n |]\n ; [| \"17814517977679061356584950826520510701145481336316888282105225134451035883368\"\n ; \"62116749577126511600138536864540326578096290025961229483071769130930103978622\"\n ; \"68057799973217998063838402481530957249181669394905338807621317159743376777292\"\n |]\n ; [| \"26100793478962260035181580648528031417033872324944615961986573818448125345450\"\n ; \"26507891451149179196332605230084404371370204632884553105363087566061809624465\"\n ; \"55607174697006979796477169324630939518573410736589826596210132996613779221405\"\n |]\n ; [| \"75098549092668095590746032937529532494350222003700838962461867948806312867882\"\n ; \"62901674712278062473767645982006145910793625009149846534629441949336033280610\"\n ; \"5918385816682866756860679567405784562483373873565987668410277610868983146285\"\n |]\n ; [| \"99232460916208710346946062875203578399818909925477280432427620267031292402265\"\n ; \"115165948144292852122635634954139515297086369356811820254801384608988902457684\"\n ; \"39462036389170488019054739441325823641943062254145671230029238830857274014332\"\n |]\n ; [| \"109723826013507458840008311671051963282645213933956581735587227292458581212170\"\n ; \"88295699560808238817850908733435797366622278897489038929647807463406234520052\"\n ; \"20306380368695786945008272690438693745796297843799468268993907772341096948885\"\n |]\n ; [| \"39988356032524455736714109463355738665746339590560108227920970859248126609155\"\n ; \"47372836588594871116561451142702593094337405740661755511614125456886719840333\"\n ; \"42727075822142544969304941778878121065758237932060280070908539158139079888683\"\n |]\n ; [| \"115695172202592006925180721060969710051274632819849770440984261650964182295350\"\n ; \"41198034356969673080518030958715740186484860381424802035929938277103521577731\"\n ; \"115380378505550001583545282887589851179279565072664241489053445702744491234750\"\n |]\n ; [| \"56074680442485705900559544809779144521596408129059458559681779642734476672579\"\n ; \"54187206076706271120400668422875039791522899135281309004702779376007885441827\"\n ; \"100760509008368123701304764217450368711018785408289674422092070202193042774995\"\n |]\n ; [| \"2622643323130765702269424224791233611920515499144047449633123689743564676648\"\n ; \"95487289650450707799373930173349121410704227885014701702619711048222666102791\"\n ; \"94943953462630479470879050547964792684799160133612590505176816568790562776928\"\n |]\n |]\n }\n\nlet params_Mnt4_753 =\n { Params.mds =\n [| [| \"18008368437737423474309001369890301521976028259557869102888851965525650962978826556079921598599098888590302388431866694591858505845787597588918688371226882207991627422083815074127761663891796146172734531991290402968541914191945\"\n ; \"32962087054539410523956712909309686802653898657605569239066684150412875533806729129396719808139132458477579312916467576544007112173179883702872518317566248974424872120316787037296877442303550788674087649228607529914336317231815\"\n ; \"5483644920564955035638567475101171013329909513705951195576914157062781400017095978578204379959018576768230785151221956162299596069033091214145892295417145700700562355150808732841416210677611704678816316579070697592848376918151\"\n |]\n ; [| \"22978648816866328436434244623482365207916416489037627250857600725663194263360344221738155318310265722276036466391561221273100146793047089336717612168000266025808046352571957200240941276891050003938106626328014785436301089444973\"\n ; \"30994637628885441247541289546067547358628828834593234742882770745561956454298316691254641971835514862825457645395555821312465912408960063865618013131940007283956832467402859348036195396599351702172170219903104023278420827940135\"\n ; \"7096546890972108774287040498267941446510912236116268882520023333699636048386130304511472040490894498194252489942856762189629237475878134498814298584446894911200379613916180563419809701971057277837757006070684068787238347669992\"\n |]\n ; [| \"36972350749469737754741804679554799140755989986720531577443294433161553396641362942311484418395414339763390349161399190591697773588979458652577643792428305947365748981633559835484411429153283032734484874265223184021528054671667\"\n ; \"41737243523985324129413602960234190443256387558212939183466624464606481865667576817406507424236723364751044981130064473555650490691461017936143464747647507236853158008794221676669840197156981325463879378696484711828785706949884\"\n ; \"17173689835840458026597473076649786448044751322360472626284380020090825232350642484368920024327948574743378803111953285570783101340571478325610471380479472689631139762331626281838772360396878623880994496993923849428256427219637\"\n |]\n |]\n ; round_constants =\n [| [| \"78119860594733808983474265082430117124674905785489385612351809573030163625517\"\n ; \"41917899842730241418346215913324270532073353586134123463219061327941260175271\"\n ; \"74594641694171623328644944059182600919855574964222988275913344198970402906473\"\n |]\n ; [| \"96215759378377024990520153908983544755208851791126218239402755616994541522004\"\n ; \"64070601581278917442704840630680311036021557676765751754522901046069205253111\"\n ; \"112123228532462696722378911494343451272980413618911326680094528285518792872677\"\n |]\n ; [| \"84572244072021308337360477634782636535511175281144388234379224309078196768262\"\n ; \"45201095631123410354816854701250642083197167601967427301389500806815426216645\"\n ; \"23419302413627434057960523568681421397183896397903197013759822219271473949448\"\n |]\n ; [| \"63220724218126871510891512179599337793645245415246618202146262033908228783613\"\n ; \"67900966560828272306360950341997532094196196655192755442359232962244590070115\"\n ; \"56382132371728071364028077587343004835658613510701494793375685201885283260755\"\n |]\n ; [| \"80317852656339951095312898663286716255545986714650554749917139819628941702909\"\n ; \"110977183257428423540294096816813859894739618561444416996538397449475628658639\"\n ; \"25195781166503180938390820610484311038421647727795615447439501669639084690800\"\n |]\n ; [| \"108664438541952156416331885221418851366456449596370568350972106298760717710264\"\n ; \"17649294376560630922417546944777537620537408190408066211453084495108565929366\"\n ; \"95236435002924956844837407534938226368352771792739587594037613075251645052212\"\n |]\n ; [| \"43150472723422600689013423057826322506171125106415122422656432973040257528684\"\n ; \"77355911134402286174761911573353899889837132781450260391484427670446862700214\"\n ; \"8690728446593494554377477996892461126663797704587025899930929227865493269824\"\n |]\n ; [| \"109175231986025180460846040078523879514558355792739714578031829643740609438879\"\n ; \"64844253590731404811389281562033735091759746904073461140427127388042062490899\"\n ; \"43237071281695629980341250188156848876595681601471702180515324064382368960951\"\n |]\n ; [| \"2704440995725305992776846806711930876273040749514871232837487081811513368296\"\n ; \"66806779110388532101035294912010606217442229808784290357894909707660045365269\"\n ; \"25541187612624070470730890200174075890643652797181103367956318438136878170352\"\n |]\n ; [| \"89300613074831725721350087269266903129165086877175223066581882601662278010666\"\n ; \"36824076981866281177052433916337787028520068526782493484076995129329938182524\"\n ; \"68880449342008497744225106025198236600142055580985632884415488154606462819445\"\n |]\n ; [| \"68556888546596545408135887526582256648006271867854316538090068824142539400698\"\n ; \"111379753250206255125320675615931203940253796355491142745969887430259465111569\"\n ; \"101469186248899356416491489235841069222521093012237305521090058066171355672289\"\n |]\n ; [| \"87819793263125973233157093200229218382531712066157093399606059493857616731410\"\n ; \"11055386921184594780372263378420826851562920740321950336882051897732501262543\"\n ; \"111945832089295501567161822264292548657346358707472584179854375613919325491249\"\n |]\n ; [| \"95630018375719472826904441325138673248990446382783206900295723762884876505178\"\n ; \"94833984285990985873155989049880754188702918168949640563745233736765833491756\"\n ; \"77578854197021606645372788474039811639438242484066959482386065023999206730771\"\n |]\n ; [| \"27799616729223271646690718201487403976485619375555391888533887467404804041014\"\n ; \"42616502170265664498961018686434252976977548128285781725227341660941880774718\"\n ; \"95884094505080541517768389956970969462501217028562326732054532092615835087122\"\n |]\n ; [| \"107531500891040898338150732759493933154418374543568088749403053559827078391994\"\n ; \"17316158269457914256007584527534747738658973027567786054549020564540952112346\"\n ; \"51624680144452294805663893795879183520785046924484587034566439599591446246116\"\n |]\n ; [| \"17698087730709566968258013675219881840614043344609152682517330801348583470562\"\n ; \"111925747861248746962567200879629070277886617811519137515553806421564944666811\"\n ; \"57148554624730554436721083599187229462914514696466218614205595953570212881615\"\n |]\n ; [| \"92002976914130835490768248031171915767210477082066266868807636677032557847243\"\n ; \"58807951133460826577955909810426403194149348045831674376120801431489918282349\"\n ; \"93581873597000319446791963913210464830992618681307774190204379970955657554666\"\n |]\n ; [| \"46734218328816451470118898692627799522173317355773128175090189234250221977353\"\n ; \"12565476532112137808460978474958060441970941349010371267577877299656634907765\"\n ; \"54284813390357004119220859882274190703294683700710665367594256039714984623777\"\n |]\n ; [| \"92046423253202913319296401122133532555630886766139313429473309376931112550800\"\n ; \"15095408309586969968044201398966210357547906905122453139947200130015688526573\"\n ; \"76483858663950700865536712701042004661599554591777656961315837882956812689085\"\n |]\n ; [| \"37793510665854947576525000802927849210746292216845467892500370179796223909690\"\n ; \"84954934523349224038508216623641462700694917568481430996824733443763638196693\"\n ; \"81116649005575743294029244339854405387811058321603450814032274416116019472096\"\n |]\n ; [| \"28313841745366368076212445154871968929195537523489133192784916081223753077949\"\n ; \"17307716513182567320564075539526480893558355908652993731441220999922946005081\"\n ; \"63148771170858502457695904149048034226689843239981287723002468627916462842625\"\n |]\n ; [| \"14724939606645168531546334343600232253284320276481307778787768813885931648950\"\n ; \"4684996260500305121238590806572541849891754312215139285622888510153705963000\"\n ; \"63682763879011752475568476861367553456179860221069473817315669232908763409259\"\n |]\n ; [| \"47776179656187399887062096850541192680190218704758942820514561435612697426715\"\n ; \"42017618175533328439486588850450028995049195954365035474995309904751824054581\"\n ; \"39169739448648613641258102792190571431737464735838931948313779997907435855102\"\n |]\n ; [| \"37525991163523321662699819448962967746703579202577998445997476955224037837979\"\n ; \"67759173441312327668891803222741396828094999063019622301649400178376863820046\"\n ; \"23041132473771739182071223620364590606653086905326129708428084432335332411661\"\n |]\n ; [| \"77778894465896892167598828497939467663479992533052348475467490972714790615441\"\n ; \"20821227542001445006023346122554483849065713580779858784021328359824080462519\"\n ; \"47217242463811495777303984778653549585537750303740616187093690846833142245039\"\n |]\n ; [| \"42826871300142174590405062658305130206548405024021455479047593769907201224399\"\n ; \"8850081254230234130482383430433176873344633494243110112848647064077741649744\"\n ; \"1819639941546179668398979507053724449231350395599747300736218202072168364980\"\n |]\n ; [| \"21219092773772827667886204262476112905428217689703647484316763603169544906986\"\n ; \"35036730416829620763976972888493029852952403098232484869595671405553221294746\"\n ; \"35487050610902505183766069070898136230610758743267437784506875078109148276407\"\n |]\n ; [| \"62560813042054697786535634928462520639989597995560367915904328183428481834648\"\n ; \"112205708104999693686115882430330200785082630634036862526175634736046083007596\"\n ; \"109084747126382177842005646092084591250172358815974554434100716599544229364287\"\n |]\n ; [| \"63740884245554590221521941789197287379354311786803164550686696984009448418872\"\n ; \"58779928727649398559174292364061339806256990859940639552881479945324304668069\"\n ; \"20614241966717622390914334053622572167995367802051836931454426877074875942253\"\n |]\n ; [| \"41621411615229558798583846330993607380846912281220890296433013153854774573504\"\n ; \"20530621481603446397085836296967350209890164029268319619481535419199429275412\"\n ; \"99914592017824500091708233310179001698739309503141229228952777264267035511439\"\n |]\n ; [| \"9497854724940806346676139162466690071592872530638144182764466319052293463165\"\n ; \"7549205476288061047040852944548942878112823732145584918107208536541712726277\"\n ; \"30898915730863004722886730649661235919513859500318540107289237568593577554645\"\n |]\n ; [| \"22697249754607337581727259086359907309326296469394183645633378468855554942575\"\n ; \"72771100592475003378969523202338527077495914171905204927442739996373603143216\"\n ; \"84509851995167666169868678185342549983568150803791023831909660012392522615426\"\n |]\n ; [| \"36601166816771446688370845080961015541431660429079281633209182736773260407536\"\n ; \"19555759172327736128240171000715903945570888389700763573790859521156095228287\"\n ; \"82844424532983875300577689116331373756526403900340445449185486212503235782229\"\n |]\n ; [| \"40833119728631657038301474658571416779079199343770917422783737091842927892625\"\n ; \"68922359316478675184342553333343300163568193749010867527082189412217781430311\"\n ; \"91516472400306837063911995909475588197278444979245081960087094196120449075833\"\n |]\n ; [| \"21304716730402869084944080869903443431235336418077153507261240151959530377653\"\n ; \"106551237424345741137570659736231801772439680702621554106791455938098031620471\"\n ; \"104392597313271110590927764888829150750277653499050463757708547416538850601163\"\n |]\n ; [| \"16907937154215020261110468963982390213438461071031811101554056252102505124726\"\n ; \"23183141532591565112222057191012766855134687114504142337903677590107533245206\"\n ; \"96725517880771645283128624101279195709280644465575982072053504613644938879246\"\n |]\n ; [| \"84556507395241990875812091718422997082915179448604219593521819129312718969906\"\n ; \"100646525819453650494590571397259055384579251368754179569362740802641255820576\"\n ; \"50316555026297423940834952362583934362215303629664094841692233643882339493043\"\n |]\n ; [| \"77363534410783423412630139556441807611393685349073113946053979350631229049878\"\n ; \"54905073434434959485893381841839373267383966385817882684657825178181863944371\"\n ; \"110016011331508430102821620395154714608084938556260733745010992614542669817451\"\n |]\n ; [| \"52040139270046094723964229965823921970388683619580004402190656733318120479093\"\n ; \"495546618036723566920914648951352373868059898268055487677897567226892784967\"\n ; \"2528292188392170914010448139211586215817069915670005292953294092269979070980\"\n |]\n ; [| \"36842840134449713950999812540127591123318806680559982063089906871196226758113\"\n ; \"112314504940338253416202605695368724580971154020421327790335219348068041886245\"\n ; \"51653712314537383078368021242008468828072907802445786549975419682333073143987\"\n |]\n ; [| \"27179054135131403873076215577181710354069071017096145081169516607932870071868\"\n ; \"93264325401956094073193527739715293258814405715822269809955952297346626219055\"\n ; \"75336695567377817226085396912086909560962335091652231383627608374094112503635\"\n |]\n ; [| \"42536477740858058164730818130587261149155820207748153094480456895727052896150\"\n ; \"45297707210835305388426482743535401273114010430724989418303851665124351001731\"\n ; \"28263543670875633354854018109712021307749750769690268127459707194207091046997\"\n |]\n ; [| \"40809484989590048522440442751358616303471639779690405026946053699354967624695\"\n ; \"51589519265418587649124543325590658874910911006853535317847189422703251228717\"\n ; \"73459936981642894525955700397592343967482441686326322443228255968694436816673\"\n |]\n ; [| \"87298777232393189731949522229743081866971743270330772607820990832164835738703\"\n ; \"23328534428894097247289332213412175849711532153957647506361455182140450133738\"\n ; \"51807348624578081645565456865744011145427112815128832643950401419083788780028\"\n |]\n ; [| \"62003629107726929116302469001779155132709624140360743951550189738290955064278\"\n ; \"109311858027068383034683875948676795998030610067675200794951297783857157095297\"\n ; \"2085588517087605436136379278738013214233743532079287631079316773925068862732\"\n |]\n ; [| \"9513664655545306376987968929852776467090105742275395185801917554996684570014\"\n ; \"91103467624252027317764670613760419385374004736848754250298970998535616755199\"\n ; \"39500000352127197728032684892425352332461947514533659433380855624868454474623\"\n |]\n ; [| \"75175260486328125629270378861920310368403601365269629778076078053196928460032\"\n ; \"56923881233337629517433981230592855430598464522180216309153828833928801967999\"\n ; \"20981004218820236011689230170078809973840534961691702543937445515733151438851\"\n |]\n ; [| \"73175203586574092105626230272409823792532423094740797516874387144340145138310\"\n ; \"45186992623753580336479418079070607289916086076906975839720879934817804495460\"\n ; \"96084125187548549854900995260973117424750860440064269432639526863495781270780\"\n |]\n ; [| \"53530507055579550362119832302266967544350117012822630711681736383163390079758\"\n ; \"24484677147631687826970700541691541659768738376645174313438582486313045584324\"\n ; \"99915577684197600584703320523786830947563355229812244982453188909016758004559\"\n |]\n ; [| \"73101441225016284181831039876112223954723401962484828024235461623078642642543\"\n ; \"57434882751817972247799186935032874577110609253567900895922769490031350316077\"\n ; \"73837027842771758252813592393497967898989365991569964687267097531033696791279\"\n |]\n ; [| \"8605586894544301092657394167906502995894014247978769840701086209902531650480\"\n ; \"8900145888985471928279988821934068156350024482295663273746853580585203659117\"\n ; \"76135096553134713603675854628257365311062159747768423095496501607463292188538\"\n |]\n ; [| \"77171330825793179961995032914169307990870372845116475229799680315757656196917\"\n ; \"17848856881287888035559207919717746181941756011012420474955535369227552058196\"\n ; \"85285874363861776466393873037603415962379724376693393356387850868454172343232\"\n |]\n ; [| \"34752820629818556525384193423224856177797869338806846583786365186093662702640\"\n ; \"61923000676912108769617866333091286856690233713839015114991682235541391477568\"\n ; \"105437294734850952102877811210027981435959945375626993201685688489494148805743\"\n |]\n ; [| \"37290995592003925978648162243724313056459187397796644444696543576625771108605\"\n ; \"95156804644588215637074780475000089186488581067063625121782605228712011438608\"\n ; \"111838568780358037910894878973007194619694503969424695895292495245099084158661\"\n |]\n ; [| \"114085830904535970531084512281741806703564152148485737755668141105183488387818\"\n ; \"27151558900245092306095370161852910074651784795680581223133179808714387525774\"\n ; \"17782273009863750298483603933610732253879825505411230932533407287574651036994\"\n |]\n ; [| \"72422039981423868898452547270453235353957783762070405836433674391957844064693\"\n ; \"23635533014670380888810554717349513178608213369182061967678315431422272271569\"\n ; \"59402711345784829746976504521969665104448536964686633342173372133388407225657\"\n |]\n ; [| \"92466806354851856571355165199186633833982438153589406912422876269386887264049\"\n ; \"9877617390649361889067963484857474874019563445507538784053773745685676317984\"\n ; \"74572672075215609948567780829046067891251792522874268554421916351892498078660\"\n |]\n ; [| \"36552683919656073147232029802086505741533932059491323529262718897271096098319\"\n ; \"28895802628889660292449057575076739706255701997961890168977786141673053679086\"\n ; \"9907785227545441866241924986174555965766785257012652276622736289520175209842\"\n |]\n ; [| \"29485332368911768475893015509537099136952860812699472744021496513325455451738\"\n ; \"39797358509842904932758894391536601623578260107859540160156599261695054175926\"\n ; \"107452259847197252302434271220963395311929879689430847107159618578878468880668\"\n |]\n ; [| \"24664696127391052816688570667643612077905959307658722811431436096677076924072\"\n ; \"52507998665481228083044018390203046881916651866666590845312076558622705190465\"\n ; \"69935204723497468327083545368078327534124772251842862926136799697299751835029\"\n |]\n ; [| \"372963191403207230700085823960930798511810380777302780932220121859190714585\"\n ; \"111366606704792806959979488772421759791592911629496627207620326636856656861526\"\n ; \"39677360977437767398760288273614298000827429534821360419179023551087917983124\"\n |]\n ; [| \"64601494076430280535646633059501605929914790764963584476403188233843589027560\"\n ; \"34156315098453482946438495274327282067376463494057110043754782161473776373661\"\n ; \"73687667961196401152630755105477060056162632832680813161120412165243753726816\"\n |]\n ; [| \"37808689229279738382348785246837013002280781984053433359148018860351753688153\"\n ; \"26778210635417272626362658500217995247072424006327715268521424423461840656985\"\n ; \"13012115310019421859484865413402512912208022868124085927375736053832542569552\"\n |]\n ; [| \"33073055720188060063004545324174039863351833928493376423022587630016341635891\"\n ; \"76584254259783109527449313057522305759653397147785066495263227868665161219779\"\n ; \"38531270223194009551634352795926218399266465064491096474482575354468954922673\"\n |]\n ; [| \"90100362566645034035707547984589905559141359276359522681964816611161474672115\"\n ; \"93014643079204629081291124987233004565276697190519877698472422015954982964601\"\n ; \"110916697765188052223435628742886773389228694903593626715469113528434066764534\"\n |]\n ; [| \"114725280711584666069398481856753837363052938587178775403749719257369626174299\"\n ; \"32967950615819700839673854548770413755655613096921050182183649674389310060672\"\n ; \"106372438106855157117155417458821032302424106544646447353561892891697429919509\"\n |]\n ; [| \"41996555998804572671679174634435850382099449308465335760130383677478780889948\"\n ; \"105999190358126224751922865919841547624707481487885223948004296548330504340556\"\n ; \"16636528128134911466622907961467317982179835733058354229921170933476186200761\"\n |]\n ; [| \"43468498537738045222256870515315985487110433728199201952445121047095648527840\"\n ; \"102272887089258604970815589009009162752025146641624347901234381428987386153285\"\n ; \"797386830910520008361185815477523544664694040635544500916993469578452189812\"\n |]\n ; [| \"96744926314199156321023598425708516126928808801578082649702497034531770517808\"\n ; \"99066250188188051206024031106640566584616407903813704153928240609169764005797\"\n ; \"101012485188852469291356197079506861083321680470016268483997462932491691773708\"\n |]\n ; [| \"49614555470963378761214277525336169174318331863453657910575217035316990252780\"\n ; \"94532874466332578813348267802784511494491757628599627802933242637211676358456\"\n ; \"60376163781951477822973950330025689966951914888122503797194554488987660570913\"\n |]\n ; [| \"99934768696780030317676638063039209891456597783633841250810260768328701786300\"\n ; \"71861378641802240356627336242725340978135703736568776865558429280585792121426\"\n ; \"84446994028646761779912629176051455275041688583492300440129402381138226185369\"\n |]\n ; [| \"18317002472599225949038448120242542829985613745531554876060436499109578301758\"\n ; \"23001721954642810524358122249469196372443463625490878969385130364780514025259\"\n ; \"49037245410934285111914043557449391103989331168177809387278571893536129709378\"\n |]\n ; [| \"65792050828386571136875573680568197513273253001530588336285451691348906024460\"\n ; \"12956514709922286639520985225111137950302442378466870763868693820049405409474\"\n ; \"38025781500219940187723501911749158551479941535921061459281014661810772473038\"\n |]\n ; [| \"98610017124283789125637190759729078315864881693957982200427567103302362453196\"\n ; \"42724178943656779288650125468921272883324869492775989038952508393082565227450\"\n ; \"99514360136104778310983460863480701661882652836741972684579325226086664343913\"\n |]\n ; [| \"111234788248236327826382691076985300771418365594838017963216100441270435887017\"\n ; \"35290532009451633157074005614742321966918220860237810056920944192222599040501\"\n ; \"72172784027306769601458922728374293130025170844011739475076742090414769211169\"\n |]\n ; [| \"61384388429666858375759167984149961873566898632022783479711533101905095026411\"\n ; \"8194273390415023152581060020119881338779571723515253104919314696738194355344\"\n ; \"80659234466772556847544129237154202226081525079070598707001193889658539631883\"\n |]\n ; [| \"62157670692624367146830864246105810519941474190553952682719433471854134465138\"\n ; \"74851302400382275482762496406028988868219592716510355166137061257664688666219\"\n ; \"16881796086836744646703159464114164393240695449455598565494759189917589453976\"\n |]\n ; [| \"42460477269659081546432152357644086326197211166562674408623141905226706277595\"\n ; \"81063688725529281621596607500748519671655516257039992655745871437369181665242\"\n ; \"51403113216244137057466948399908740878535656059933892843818689317660325080213\"\n |]\n ; [| \"49001998791770520786679099472805193463531142479298200795569326894791589887035\"\n ; \"42684462014557597494725933597359625461226399711783671410492942446635214257509\"\n ; \"106420886277092880545929306533089566775810130555230702838917980421765786292693\"\n |]\n ; [| \"110523958037212353696746219917157237679515245560578307171595792811566554384451\"\n ; \"56399709802930804752950401483879725014794413557467977624037632281590440364765\"\n ; \"100108862073771478435824578087801736413858177140360408436521717282600830155374\"\n |]\n ; [| \"59041409790855290045250456089216312297230856546920761548978870779493926213674\"\n ; \"13735945315945382005247895569035266667172550063549145646185577935658666385507\"\n ; \"16846296242516834547231537358954027537902709068158411294345086281698311539718\"\n |]\n ; [| \"114970774262524353875592617323889610576992844847433725376114488262076142213525\"\n ; \"17896661983150937411004047429485556264820315976705642986609974816436222162633\"\n ; \"115573362005053049429141251153085446935774781295666612354309246218946442750706\"\n |]\n ; [| \"85575265064375003235737272215445285540001719469558026661845214249857169530994\"\n ; \"87501751332871186792668480006319719164949448258731670359536302677279100637346\"\n ; \"105775909055063540416087237151517389942637625317333843436738223226977225420379\"\n |]\n ; [| \"110886009455283422981396854898481256559291311408679418842391298005253375700608\"\n ; \"95342257228100720685556647789433478371609336135456255803583405713563597933074\"\n ; \"2733591517253510124338232417535938539627593736745105875672348998709544742241\"\n |]\n ; [| \"32685479117496505057951010536248024091461630564950845696581129158987138920098\"\n ; \"96139836598015371513111133071481139035733083963976340622322043979088723982681\"\n ; \"16990606351055720221300633612533434675038905235719867684891402550154692840579\"\n |]\n ; [| \"13886834869596827027283068322204563244577723967928602405785473534631482228259\"\n ; \"81034769645830807786559566591578132114590768431721148809270219480247445931316\"\n ; \"26780635035984131258327079447673207266040002451512601352288859614294714150612\"\n |]\n ; [| \"72820784976920576285217524394309841044157743334874310886804718206719618858662\"\n ; \"84276722913141806246805569560426345961854221390421557310593118606084442633714\"\n ; \"42573817497593319926701003355299929070203785007821783512454795971915573843634\"\n |]\n ; [| \"41660041627266397279909712983288860313881442148611073178272756605107913521726\"\n ; \"7198246770791404776745997973411401046335399072925979346193035999274650139809\"\n ; \"91576025129588718283317000330880100309465430116820675850311277329602716166005\"\n |]\n ; [| \"30488483928716649313242898509172476460161184318124511942476380904233730958564\"\n ; \"35346040517569327255933130090945133067049088493975862969006023114275649329148\"\n ; \"59803015801166721680239913449555176591725421041660016242103441987856441941533\"\n |]\n ; [| \"17395049232451382970906883167116397657891664802601579276725674512534883408665\"\n ; \"96892830538146451450007413348096295684782382701592949711753407054447667361829\"\n ; \"46725583995795907014628330473921842919957418641665482351238505922983315675600\"\n |]\n ; [| \"20556719902345568138970735755829852608784985449829745172855204153387982836579\"\n ; \"17130405757403641097651484965062131526367059595476924144885570325828777794585\"\n ; \"99651763337265056372826178960800950053231370129318394703153246147873057668256\"\n |]\n ; [| \"17814517977679061356584950826520510701145481336316888282105225134451035883368\"\n ; \"62116749577126511600138536864540326578096290025961229483071769130930103978622\"\n ; \"68057799973217998063838402481530957249181669394905338807621317159743376777292\"\n |]\n ; [| \"26100793478962260035181580648528031417033872324944615961986573818448125345450\"\n ; \"26507891451149179196332605230084404371370204632884553105363087566061809624465\"\n ; \"55607174697006979796477169324630939518573410736589826596210132996613779221405\"\n |]\n ; [| \"75098549092668095590746032937529532494350222003700838962461867948806312867882\"\n ; \"62901674712278062473767645982006145910793625009149846534629441949336033280610\"\n ; \"5918385816682866756860679567405784562483373873565987668410277610868983146285\"\n |]\n ; [| \"99232460916208710346946062875203578399818909925477280432427620267031292402265\"\n ; \"115165948144292852122635634954139515297086369356811820254801384608988902457684\"\n ; \"39462036389170488019054739441325823641943062254145671230029238830857274014332\"\n |]\n ; [| \"109723826013507458840008311671051963282645213933956581735587227292458581212170\"\n ; \"88295699560808238817850908733435797366622278897489038929647807463406234520052\"\n ; \"20306380368695786945008272690438693745796297843799468268993907772341096948885\"\n |]\n ; [| \"39988356032524455736714109463355738665746339590560108227920970859248126609155\"\n ; \"47372836588594871116561451142702593094337405740661755511614125456886719840333\"\n ; \"42727075822142544969304941778878121065758237932060280070908539158139079888683\"\n |]\n ; [| \"115695172202592006925180721060969710051274632819849770440984261650964182295350\"\n ; \"41198034356969673080518030958715740186484860381424802035929938277103521577731\"\n ; \"115380378505550001583545282887589851179279565072664241489053445702744491234750\"\n |]\n ; [| \"56074680442485705900559544809779144521596408129059458559681779642734476672579\"\n ; \"54187206076706271120400668422875039791522899135281309004702779376007885441827\"\n ; \"100760509008368123701304764217450368711018785408289674422092070202193042774995\"\n |]\n ; [| \"2622643323130765702269424224791233611920515499144047449633123689743564676648\"\n ; \"95487289650450707799373930173349121410704227885014701702619711048222666102791\"\n ; \"94943953462630479470879050547964792684799160133612590505176816568790562776928\"\n |]\n |]\n }\n\nlet params_Bn382_p =\n { Params.mds =\n [| [| \"4926718831512540855203478495979679874185641835428705237807701341316303469093728860979847281433445543762468419547411\"\n ; \"4453596550915421838691584449484083455887331059810907256950733279540412430443020452528503585415545381600691692720802\"\n ; \"1809585458879543727351605930307281128231661313471183867681242998028598391382436278589655704222701087043779610899776\"\n |]\n ; [| \"3780881913608981191949291171826187563049531728010823449829977324390598960444713739971716972221840264885560113043153\"\n ; \"2776232227357305515637478180339794495756715372405744816056109665788926102619439001152349187314657683550310562099867\"\n ; \"5103043266714397927073209822516498302262227174566336138856687248083295588845596823903140201767618523431001452833199\"\n |]\n ; [| \"2159355678817062797712812554732125404698639502388517586006300841333631216487588790808135492514630783259920881851018\"\n ; \"3193464442349738376799117666463048091278737759406985595335727474699041234966227606028409475413066859111860974240541\"\n ; \"3068849848776138129466484826306219095394321880438971409892892215677003762666783452446184790715435684915272918256552\"\n |]\n |]\n ; round_constants =\n [| [| \"78119860594733808983474265082430117124674905785489385612351809573030163625517\"\n ; \"41917899842730241418346215913324270532073353586134123463219061327941260175271\"\n ; \"74594641694171623328644944059182600919855574964222988275913344198970402906473\"\n |]\n ; [| \"96215759378377024990520153908983544755208851791126218239402755616994541522004\"\n ; \"64070601581278917442704840630680311036021557676765751754522901046069205253111\"\n ; \"112123228532462696722378911494343451272980413618911326680094528285518792872677\"\n |]\n ; [| \"84572244072021308337360477634782636535511175281144388234379224309078196768262\"\n ; \"45201095631123410354816854701250642083197167601967427301389500806815426216645\"\n ; \"23419302413627434057960523568681421397183896397903197013759822219271473949448\"\n |]\n ; [| \"63220724218126871510891512179599337793645245415246618202146262033908228783613\"\n ; \"67900966560828272306360950341997532094196196655192755442359232962244590070115\"\n ; \"56382132371728071364028077587343004835658613510701494793375685201885283260755\"\n |]\n ; [| \"80317852656339951095312898663286716255545986714650554749917139819628941702909\"\n ; \"110977183257428423540294096816813859894739618561444416996538397449475628658639\"\n ; \"25195781166503180938390820610484311038421647727795615447439501669639084690800\"\n |]\n ; [| \"108664438541952156416331885221418851366456449596370568350972106298760717710264\"\n ; \"17649294376560630922417546944777537620537408190408066211453084495108565929366\"\n ; \"95236435002924956844837407534938226368352771792739587594037613075251645052212\"\n |]\n ; [| \"43150472723422600689013423057826322506171125106415122422656432973040257528684\"\n ; \"77355911134402286174761911573353899889837132781450260391484427670446862700214\"\n ; \"8690728446593494554377477996892461126663797704587025899930929227865493269824\"\n |]\n ; [| \"109175231986025180460846040078523879514558355792739714578031829643740609438879\"\n ; \"64844253590731404811389281562033735091759746904073461140427127388042062490899\"\n ; \"43237071281695629980341250188156848876595681601471702180515324064382368960951\"\n |]\n ; [| \"2704440995725305992776846806711930876273040749514871232837487081811513368296\"\n ; \"66806779110388532101035294912010606217442229808784290357894909707660045365269\"\n ; \"25541187612624070470730890200174075890643652797181103367956318438136878170352\"\n |]\n ; [| \"89300613074831725721350087269266903129165086877175223066581882601662278010666\"\n ; \"36824076981866281177052433916337787028520068526782493484076995129329938182524\"\n ; \"68880449342008497744225106025198236600142055580985632884415488154606462819445\"\n |]\n ; [| \"68556888546596545408135887526582256648006271867854316538090068824142539400698\"\n ; \"111379753250206255125320675615931203940253796355491142745969887430259465111569\"\n ; \"101469186248899356416491489235841069222521093012237305521090058066171355672289\"\n |]\n ; [| \"87819793263125973233157093200229218382531712066157093399606059493857616731410\"\n ; \"11055386921184594780372263378420826851562920740321950336882051897732501262543\"\n ; \"111945832089295501567161822264292548657346358707472584179854375613919325491249\"\n |]\n ; [| \"95630018375719472826904441325138673248990446382783206900295723762884876505178\"\n ; \"94833984285990985873155989049880754188702918168949640563745233736765833491756\"\n ; \"77578854197021606645372788474039811639438242484066959482386065023999206730771\"\n |]\n ; [| \"27799616729223271646690718201487403976485619375555391888533887467404804041014\"\n ; \"42616502170265664498961018686434252976977548128285781725227341660941880774718\"\n ; \"95884094505080541517768389956970969462501217028562326732054532092615835087122\"\n |]\n ; [| \"107531500891040898338150732759493933154418374543568088749403053559827078391994\"\n ; \"17316158269457914256007584527534747738658973027567786054549020564540952112346\"\n ; \"51624680144452294805663893795879183520785046924484587034566439599591446246116\"\n |]\n ; [| \"17698087730709566968258013675219881840614043344609152682517330801348583470562\"\n ; \"111925747861248746962567200879629070277886617811519137515553806421564944666811\"\n ; \"57148554624730554436721083599187229462914514696466218614205595953570212881615\"\n |]\n ; [| \"92002976914130835490768248031171915767210477082066266868807636677032557847243\"\n ; \"58807951133460826577955909810426403194149348045831674376120801431489918282349\"\n ; \"93581873597000319446791963913210464830992618681307774190204379970955657554666\"\n |]\n ; [| \"46734218328816451470118898692627799522173317355773128175090189234250221977353\"\n ; \"12565476532112137808460978474958060441970941349010371267577877299656634907765\"\n ; \"54284813390357004119220859882274190703294683700710665367594256039714984623777\"\n |]\n ; [| \"92046423253202913319296401122133532555630886766139313429473309376931112550800\"\n ; \"15095408309586969968044201398966210357547906905122453139947200130015688526573\"\n ; \"76483858663950700865536712701042004661599554591777656961315837882956812689085\"\n |]\n ; [| \"37793510665854947576525000802927849210746292216845467892500370179796223909690\"\n ; \"84954934523349224038508216623641462700694917568481430996824733443763638196693\"\n ; \"81116649005575743294029244339854405387811058321603450814032274416116019472096\"\n |]\n ; [| \"28313841745366368076212445154871968929195537523489133192784916081223753077949\"\n ; \"17307716513182567320564075539526480893558355908652993731441220999922946005081\"\n ; \"63148771170858502457695904149048034226689843239981287723002468627916462842625\"\n |]\n ; [| \"14724939606645168531546334343600232253284320276481307778787768813885931648950\"\n ; \"4684996260500305121238590806572541849891754312215139285622888510153705963000\"\n ; \"63682763879011752475568476861367553456179860221069473817315669232908763409259\"\n |]\n ; [| \"47776179656187399887062096850541192680190218704758942820514561435612697426715\"\n ; \"42017618175533328439486588850450028995049195954365035474995309904751824054581\"\n ; \"39169739448648613641258102792190571431737464735838931948313779997907435855102\"\n |]\n ; [| \"37525991163523321662699819448962967746703579202577998445997476955224037837979\"\n ; \"67759173441312327668891803222741396828094999063019622301649400178376863820046\"\n ; \"23041132473771739182071223620364590606653086905326129708428084432335332411661\"\n |]\n ; [| \"77778894465896892167598828497939467663479992533052348475467490972714790615441\"\n ; \"20821227542001445006023346122554483849065713580779858784021328359824080462519\"\n ; \"47217242463811495777303984778653549585537750303740616187093690846833142245039\"\n |]\n ; [| \"42826871300142174590405062658305130206548405024021455479047593769907201224399\"\n ; \"8850081254230234130482383430433176873344633494243110112848647064077741649744\"\n ; \"1819639941546179668398979507053724449231350395599747300736218202072168364980\"\n |]\n ; [| \"21219092773772827667886204262476112905428217689703647484316763603169544906986\"\n ; \"35036730416829620763976972888493029852952403098232484869595671405553221294746\"\n ; \"35487050610902505183766069070898136230610758743267437784506875078109148276407\"\n |]\n ; [| \"62560813042054697786535634928462520639989597995560367915904328183428481834648\"\n ; \"112205708104999693686115882430330200785082630634036862526175634736046083007596\"\n ; \"109084747126382177842005646092084591250172358815974554434100716599544229364287\"\n |]\n ; [| \"63740884245554590221521941789197287379354311786803164550686696984009448418872\"\n ; \"58779928727649398559174292364061339806256990859940639552881479945324304668069\"\n ; \"20614241966717622390914334053622572167995367802051836931454426877074875942253\"\n |]\n ; [| \"41621411615229558798583846330993607380846912281220890296433013153854774573504\"\n ; \"20530621481603446397085836296967350209890164029268319619481535419199429275412\"\n ; \"99914592017824500091708233310179001698739309503141229228952777264267035511439\"\n |]\n ; [| \"9497854724940806346676139162466690071592872530638144182764466319052293463165\"\n ; \"7549205476288061047040852944548942878112823732145584918107208536541712726277\"\n ; \"30898915730863004722886730649661235919513859500318540107289237568593577554645\"\n |]\n ; [| \"22697249754607337581727259086359907309326296469394183645633378468855554942575\"\n ; \"72771100592475003378969523202338527077495914171905204927442739996373603143216\"\n ; \"84509851995167666169868678185342549983568150803791023831909660012392522615426\"\n |]\n ; [| \"36601166816771446688370845080961015541431660429079281633209182736773260407536\"\n ; \"19555759172327736128240171000715903945570888389700763573790859521156095228287\"\n ; \"82844424532983875300577689116331373756526403900340445449185486212503235782229\"\n |]\n ; [| \"40833119728631657038301474658571416779079199343770917422783737091842927892625\"\n ; \"68922359316478675184342553333343300163568193749010867527082189412217781430311\"\n ; \"91516472400306837063911995909475588197278444979245081960087094196120449075833\"\n |]\n ; [| \"21304716730402869084944080869903443431235336418077153507261240151959530377653\"\n ; \"106551237424345741137570659736231801772439680702621554106791455938098031620471\"\n ; \"104392597313271110590927764888829150750277653499050463757708547416538850601163\"\n |]\n ; [| \"16907937154215020261110468963982390213438461071031811101554056252102505124726\"\n ; \"23183141532591565112222057191012766855134687114504142337903677590107533245206\"\n ; \"96725517880771645283128624101279195709280644465575982072053504613644938879246\"\n |]\n ; [| \"84556507395241990875812091718422997082915179448604219593521819129312718969906\"\n ; \"100646525819453650494590571397259055384579251368754179569362740802641255820576\"\n ; \"50316555026297423940834952362583934362215303629664094841692233643882339493043\"\n |]\n ; [| \"77363534410783423412630139556441807611393685349073113946053979350631229049878\"\n ; \"54905073434434959485893381841839373267383966385817882684657825178181863944371\"\n ; \"110016011331508430102821620395154714608084938556260733745010992614542669817451\"\n |]\n ; [| \"52040139270046094723964229965823921970388683619580004402190656733318120479093\"\n ; \"495546618036723566920914648951352373868059898268055487677897567226892784967\"\n ; \"2528292188392170914010448139211586215817069915670005292953294092269979070980\"\n |]\n ; [| \"36842840134449713950999812540127591123318806680559982063089906871196226758113\"\n ; \"112314504940338253416202605695368724580971154020421327790335219348068041886245\"\n ; \"51653712314537383078368021242008468828072907802445786549975419682333073143987\"\n |]\n ; [| \"27179054135131403873076215577181710354069071017096145081169516607932870071868\"\n ; \"93264325401956094073193527739715293258814405715822269809955952297346626219055\"\n ; \"75336695567377817226085396912086909560962335091652231383627608374094112503635\"\n |]\n ; [| \"42536477740858058164730818130587261149155820207748153094480456895727052896150\"\n ; \"45297707210835305388426482743535401273114010430724989418303851665124351001731\"\n ; \"28263543670875633354854018109712021307749750769690268127459707194207091046997\"\n |]\n ; [| \"40809484989590048522440442751358616303471639779690405026946053699354967624695\"\n ; \"51589519265418587649124543325590658874910911006853535317847189422703251228717\"\n ; \"73459936981642894525955700397592343967482441686326322443228255968694436816673\"\n |]\n ; [| \"87298777232393189731949522229743081866971743270330772607820990832164835738703\"\n ; \"23328534428894097247289332213412175849711532153957647506361455182140450133738\"\n ; \"51807348624578081645565456865744011145427112815128832643950401419083788780028\"\n |]\n ; [| \"62003629107726929116302469001779155132709624140360743951550189738290955064278\"\n ; \"109311858027068383034683875948676795998030610067675200794951297783857157095297\"\n ; \"2085588517087605436136379278738013214233743532079287631079316773925068862732\"\n |]\n ; [| \"9513664655545306376987968929852776467090105742275395185801917554996684570014\"\n ; \"91103467624252027317764670613760419385374004736848754250298970998535616755199\"\n ; \"39500000352127197728032684892425352332461947514533659433380855624868454474623\"\n |]\n ; [| \"75175260486328125629270378861920310368403601365269629778076078053196928460032\"\n ; \"56923881233337629517433981230592855430598464522180216309153828833928801967999\"\n ; \"20981004218820236011689230170078809973840534961691702543937445515733151438851\"\n |]\n ; [| \"73175203586574092105626230272409823792532423094740797516874387144340145138310\"\n ; \"45186992623753580336479418079070607289916086076906975839720879934817804495460\"\n ; \"96084125187548549854900995260973117424750860440064269432639526863495781270780\"\n |]\n ; [| \"53530507055579550362119832302266967544350117012822630711681736383163390079758\"\n ; \"24484677147631687826970700541691541659768738376645174313438582486313045584324\"\n ; \"99915577684197600584703320523786830947563355229812244982453188909016758004559\"\n |]\n ; [| \"73101441225016284181831039876112223954723401962484828024235461623078642642543\"\n ; \"57434882751817972247799186935032874577110609253567900895922769490031350316077\"\n ; \"73837027842771758252813592393497967898989365991569964687267097531033696791279\"\n |]\n ; [| \"8605586894544301092657394167906502995894014247978769840701086209902531650480\"\n ; \"8900145888985471928279988821934068156350024482295663273746853580585203659117\"\n ; \"76135096553134713603675854628257365311062159747768423095496501607463292188538\"\n |]\n ; [| \"77171330825793179961995032914169307990870372845116475229799680315757656196917\"\n ; \"17848856881287888035559207919717746181941756011012420474955535369227552058196\"\n ; \"85285874363861776466393873037603415962379724376693393356387850868454172343232\"\n |]\n ; [| \"34752820629818556525384193423224856177797869338806846583786365186093662702640\"\n ; \"61923000676912108769617866333091286856690233713839015114991682235541391477568\"\n ; \"105437294734850952102877811210027981435959945375626993201685688489494148805743\"\n |]\n ; [| \"37290995592003925978648162243724313056459187397796644444696543576625771108605\"\n ; \"95156804644588215637074780475000089186488581067063625121782605228712011438608\"\n ; \"111838568780358037910894878973007194619694503969424695895292495245099084158661\"\n |]\n ; [| \"114085830904535970531084512281741806703564152148485737755668141105183488387818\"\n ; \"27151558900245092306095370161852910074651784795680581223133179808714387525774\"\n ; \"17782273009863750298483603933610732253879825505411230932533407287574651036994\"\n |]\n ; [| \"72422039981423868898452547270453235353957783762070405836433674391957844064693\"\n ; \"23635533014670380888810554717349513178608213369182061967678315431422272271569\"\n ; \"59402711345784829746976504521969665104448536964686633342173372133388407225657\"\n |]\n ; [| \"92466806354851856571355165199186633833982438153589406912422876269386887264049\"\n ; \"9877617390649361889067963484857474874019563445507538784053773745685676317984\"\n ; \"74572672075215609948567780829046067891251792522874268554421916351892498078660\"\n |]\n ; [| \"36552683919656073147232029802086505741533932059491323529262718897271096098319\"\n ; \"28895802628889660292449057575076739706255701997961890168977786141673053679086\"\n ; \"9907785227545441866241924986174555965766785257012652276622736289520175209842\"\n |]\n ; [| \"29485332368911768475893015509537099136952860812699472744021496513325455451738\"\n ; \"39797358509842904932758894391536601623578260107859540160156599261695054175926\"\n ; \"107452259847197252302434271220963395311929879689430847107159618578878468880668\"\n |]\n ; [| \"24664696127391052816688570667643612077905959307658722811431436096677076924072\"\n ; \"52507998665481228083044018390203046881916651866666590845312076558622705190465\"\n ; \"69935204723497468327083545368078327534124772251842862926136799697299751835029\"\n |]\n ; [| \"372963191403207230700085823960930798511810380777302780932220121859190714585\"\n ; \"111366606704792806959979488772421759791592911629496627207620326636856656861526\"\n ; \"39677360977437767398760288273614298000827429534821360419179023551087917983124\"\n |]\n ; [| \"64601494076430280535646633059501605929914790764963584476403188233843589027560\"\n ; \"34156315098453482946438495274327282067376463494057110043754782161473776373661\"\n ; \"73687667961196401152630755105477060056162632832680813161120412165243753726816\"\n |]\n ; [| \"37808689229279738382348785246837013002280781984053433359148018860351753688153\"\n ; \"26778210635417272626362658500217995247072424006327715268521424423461840656985\"\n ; \"13012115310019421859484865413402512912208022868124085927375736053832542569552\"\n |]\n ; [| \"33073055720188060063004545324174039863351833928493376423022587630016341635891\"\n ; \"76584254259783109527449313057522305759653397147785066495263227868665161219779\"\n ; \"38531270223194009551634352795926218399266465064491096474482575354468954922673\"\n |]\n ; [| \"90100362566645034035707547984589905559141359276359522681964816611161474672115\"\n ; \"93014643079204629081291124987233004565276697190519877698472422015954982964601\"\n ; \"110916697765188052223435628742886773389228694903593626715469113528434066764534\"\n |]\n ; [| \"114725280711584666069398481856753837363052938587178775403749719257369626174299\"\n ; \"32967950615819700839673854548770413755655613096921050182183649674389310060672\"\n ; \"106372438106855157117155417458821032302424106544646447353561892891697429919509\"\n |]\n ; [| \"41996555998804572671679174634435850382099449308465335760130383677478780889948\"\n ; \"105999190358126224751922865919841547624707481487885223948004296548330504340556\"\n ; \"16636528128134911466622907961467317982179835733058354229921170933476186200761\"\n |]\n ; [| \"43468498537738045222256870515315985487110433728199201952445121047095648527840\"\n ; \"102272887089258604970815589009009162752025146641624347901234381428987386153285\"\n ; \"797386830910520008361185815477523544664694040635544500916993469578452189812\"\n |]\n ; [| \"96744926314199156321023598425708516126928808801578082649702497034531770517808\"\n ; \"99066250188188051206024031106640566584616407903813704153928240609169764005797\"\n ; \"101012485188852469291356197079506861083321680470016268483997462932491691773708\"\n |]\n ; [| \"49614555470963378761214277525336169174318331863453657910575217035316990252780\"\n ; \"94532874466332578813348267802784511494491757628599627802933242637211676358456\"\n ; \"60376163781951477822973950330025689966951914888122503797194554488987660570913\"\n |]\n ; [| \"99934768696780030317676638063039209891456597783633841250810260768328701786300\"\n ; \"71861378641802240356627336242725340978135703736568776865558429280585792121426\"\n ; \"84446994028646761779912629176051455275041688583492300440129402381138226185369\"\n |]\n ; [| \"18317002472599225949038448120242542829985613745531554876060436499109578301758\"\n ; \"23001721954642810524358122249469196372443463625490878969385130364780514025259\"\n ; \"49037245410934285111914043557449391103989331168177809387278571893536129709378\"\n |]\n ; [| \"65792050828386571136875573680568197513273253001530588336285451691348906024460\"\n ; \"12956514709922286639520985225111137950302442378466870763868693820049405409474\"\n ; \"38025781500219940187723501911749158551479941535921061459281014661810772473038\"\n |]\n ; [| \"98610017124283789125637190759729078315864881693957982200427567103302362453196\"\n ; \"42724178943656779288650125468921272883324869492775989038952508393082565227450\"\n ; \"99514360136104778310983460863480701661882652836741972684579325226086664343913\"\n |]\n ; [| \"111234788248236327826382691076985300771418365594838017963216100441270435887017\"\n ; \"35290532009451633157074005614742321966918220860237810056920944192222599040501\"\n ; \"72172784027306769601458922728374293130025170844011739475076742090414769211169\"\n |]\n ; [| \"61384388429666858375759167984149961873566898632022783479711533101905095026411\"\n ; \"8194273390415023152581060020119881338779571723515253104919314696738194355344\"\n ; \"80659234466772556847544129237154202226081525079070598707001193889658539631883\"\n |]\n ; [| \"62157670692624367146830864246105810519941474190553952682719433471854134465138\"\n ; \"74851302400382275482762496406028988868219592716510355166137061257664688666219\"\n ; \"16881796086836744646703159464114164393240695449455598565494759189917589453976\"\n |]\n ; [| \"42460477269659081546432152357644086326197211166562674408623141905226706277595\"\n ; \"81063688725529281621596607500748519671655516257039992655745871437369181665242\"\n ; \"51403113216244137057466948399908740878535656059933892843818689317660325080213\"\n |]\n ; [| \"49001998791770520786679099472805193463531142479298200795569326894791589887035\"\n ; \"42684462014557597494725933597359625461226399711783671410492942446635214257509\"\n ; \"106420886277092880545929306533089566775810130555230702838917980421765786292693\"\n |]\n ; [| \"110523958037212353696746219917157237679515245560578307171595792811566554384451\"\n ; \"56399709802930804752950401483879725014794413557467977624037632281590440364765\"\n ; \"100108862073771478435824578087801736413858177140360408436521717282600830155374\"\n |]\n ; [| \"59041409790855290045250456089216312297230856546920761548978870779493926213674\"\n ; \"13735945315945382005247895569035266667172550063549145646185577935658666385507\"\n ; \"16846296242516834547231537358954027537902709068158411294345086281698311539718\"\n |]\n ; [| \"114970774262524353875592617323889610576992844847433725376114488262076142213525\"\n ; \"17896661983150937411004047429485556264820315976705642986609974816436222162633\"\n ; \"115573362005053049429141251153085446935774781295666612354309246218946442750706\"\n |]\n ; [| \"85575265064375003235737272215445285540001719469558026661845214249857169530994\"\n ; \"87501751332871186792668480006319719164949448258731670359536302677279100637346\"\n ; \"105775909055063540416087237151517389942637625317333843436738223226977225420379\"\n |]\n ; [| \"110886009455283422981396854898481256559291311408679418842391298005253375700608\"\n ; \"95342257228100720685556647789433478371609336135456255803583405713563597933074\"\n ; \"2733591517253510124338232417535938539627593736745105875672348998709544742241\"\n |]\n ; [| \"32685479117496505057951010536248024091461630564950845696581129158987138920098\"\n ; \"96139836598015371513111133071481139035733083963976340622322043979088723982681\"\n ; \"16990606351055720221300633612533434675038905235719867684891402550154692840579\"\n |]\n ; [| \"13886834869596827027283068322204563244577723967928602405785473534631482228259\"\n ; \"81034769645830807786559566591578132114590768431721148809270219480247445931316\"\n ; \"26780635035984131258327079447673207266040002451512601352288859614294714150612\"\n |]\n ; [| \"72820784976920576285217524394309841044157743334874310886804718206719618858662\"\n ; \"84276722913141806246805569560426345961854221390421557310593118606084442633714\"\n ; \"42573817497593319926701003355299929070203785007821783512454795971915573843634\"\n |]\n ; [| \"41660041627266397279909712983288860313881442148611073178272756605107913521726\"\n ; \"7198246770791404776745997973411401046335399072925979346193035999274650139809\"\n ; \"91576025129588718283317000330880100309465430116820675850311277329602716166005\"\n |]\n ; [| \"30488483928716649313242898509172476460161184318124511942476380904233730958564\"\n ; \"35346040517569327255933130090945133067049088493975862969006023114275649329148\"\n ; \"59803015801166721680239913449555176591725421041660016242103441987856441941533\"\n |]\n ; [| \"17395049232451382970906883167116397657891664802601579276725674512534883408665\"\n ; \"96892830538146451450007413348096295684782382701592949711753407054447667361829\"\n ; \"46725583995795907014628330473921842919957418641665482351238505922983315675600\"\n |]\n ; [| \"20556719902345568138970735755829852608784985449829745172855204153387982836579\"\n ; \"17130405757403641097651484965062131526367059595476924144885570325828777794585\"\n ; \"99651763337265056372826178960800950053231370129318394703153246147873057668256\"\n |]\n ; [| \"17814517977679061356584950826520510701145481336316888282105225134451035883368\"\n ; \"62116749577126511600138536864540326578096290025961229483071769130930103978622\"\n ; \"68057799973217998063838402481530957249181669394905338807621317159743376777292\"\n |]\n ; [| \"26100793478962260035181580648528031417033872324944615961986573818448125345450\"\n ; \"26507891451149179196332605230084404371370204632884553105363087566061809624465\"\n ; \"55607174697006979796477169324630939518573410736589826596210132996613779221405\"\n |]\n ; [| \"75098549092668095590746032937529532494350222003700838962461867948806312867882\"\n ; \"62901674712278062473767645982006145910793625009149846534629441949336033280610\"\n ; \"5918385816682866756860679567405784562483373873565987668410277610868983146285\"\n |]\n ; [| \"99232460916208710346946062875203578399818909925477280432427620267031292402265\"\n ; \"115165948144292852122635634954139515297086369356811820254801384608988902457684\"\n ; \"39462036389170488019054739441325823641943062254145671230029238830857274014332\"\n |]\n ; [| \"109723826013507458840008311671051963282645213933956581735587227292458581212170\"\n ; \"88295699560808238817850908733435797366622278897489038929647807463406234520052\"\n ; \"20306380368695786945008272690438693745796297843799468268993907772341096948885\"\n |]\n ; [| \"39988356032524455736714109463355738665746339590560108227920970859248126609155\"\n ; \"47372836588594871116561451142702593094337405740661755511614125456886719840333\"\n ; \"42727075822142544969304941778878121065758237932060280070908539158139079888683\"\n |]\n ; [| \"115695172202592006925180721060969710051274632819849770440984261650964182295350\"\n ; \"41198034356969673080518030958715740186484860381424802035929938277103521577731\"\n ; \"115380378505550001583545282887589851179279565072664241489053445702744491234750\"\n |]\n ; [| \"56074680442485705900559544809779144521596408129059458559681779642734476672579\"\n ; \"54187206076706271120400668422875039791522899135281309004702779376007885441827\"\n ; \"100760509008368123701304764217450368711018785408289674422092070202193042774995\"\n |]\n ; [| \"2622643323130765702269424224791233611920515499144047449633123689743564676648\"\n ; \"95487289650450707799373930173349121410704227885014701702619711048222666102791\"\n ; \"94943953462630479470879050547964792684799160133612590505176816568790562776928\"\n |]\n |]\n }\n\nlet params_Bn382_q =\n { Params.mds =\n [| [| \"2663538809597650435844500745640128112500797729229320076136089551791530014683740176469459837095745057420024990698304\"\n ; \"3372673220977743741609068262704292488957271565700673274891426149291073445433316668667874458522247135736401556339737\"\n ; \"4702399048364054789745695060954166226249916683594965873315202085308155435886379283955080194729213218481069112754347\"\n |]\n ; [| \"2215778453553447259216822687321394545528815439827126692759606056122905656424424554076355712016973336681821219494537\"\n ; \"1284753801167450198664971157009572170099813485759371112881157467066929464161583508786486164543283350228782139803094\"\n ; \"1136441139974396511543268992916724168911879411721635269198331720240499757381302440272659128030869203409955304203115\"\n |]\n ; [| \"5295202322853619951220986804473857321275810243906349721146315070442772012272591642930885737122084843222525444659152\"\n ; \"2585574180998322214773500417577043354533137309395421285678021891228333612974808568921533701659765694493897008321886\"\n ; \"4327637570022845964174929847928171567054668769686956705326721990617716210727017530524703225454617877992054172811917\"\n |]\n |]\n ; round_constants =\n [| [| \"78119860594733808983474265082430117124674905785489385612351809573030163625517\"\n ; \"41917899842730241418346215913324270532073353586134123463219061327941260175271\"\n ; \"74594641694171623328644944059182600919855574964222988275913344198970402906473\"\n |]\n ; [| \"96215759378377024990520153908983544755208851791126218239402755616994541522004\"\n ; \"64070601581278917442704840630680311036021557676765751754522901046069205253111\"\n ; \"112123228532462696722378911494343451272980413618911326680094528285518792872677\"\n |]\n ; [| \"84572244072021308337360477634782636535511175281144388234379224309078196768262\"\n ; \"45201095631123410354816854701250642083197167601967427301389500806815426216645\"\n ; \"23419302413627434057960523568681421397183896397903197013759822219271473949448\"\n |]\n ; [| \"63220724218126871510891512179599337793645245415246618202146262033908228783613\"\n ; \"67900966560828272306360950341997532094196196655192755442359232962244590070115\"\n ; \"56382132371728071364028077587343004835658613510701494793375685201885283260755\"\n |]\n ; [| \"80317852656339951095312898663286716255545986714650554749917139819628941702909\"\n ; \"110977183257428423540294096816813859894739618561444416996538397449475628658639\"\n ; \"25195781166503180938390820610484311038421647727795615447439501669639084690800\"\n |]\n ; [| \"108664438541952156416331885221418851366456449596370568350972106298760717710264\"\n ; \"17649294376560630922417546944777537620537408190408066211453084495108565929366\"\n ; \"95236435002924956844837407534938226368352771792739587594037613075251645052212\"\n |]\n ; [| \"43150472723422600689013423057826322506171125106415122422656432973040257528684\"\n ; \"77355911134402286174761911573353899889837132781450260391484427670446862700214\"\n ; \"8690728446593494554377477996892461126663797704587025899930929227865493269824\"\n |]\n ; [| \"109175231986025180460846040078523879514558355792739714578031829643740609438879\"\n ; \"64844253590731404811389281562033735091759746904073461140427127388042062490899\"\n ; \"43237071281695629980341250188156848876595681601471702180515324064382368960951\"\n |]\n ; [| \"2704440995725305992776846806711930876273040749514871232837487081811513368296\"\n ; \"66806779110388532101035294912010606217442229808784290357894909707660045365269\"\n ; \"25541187612624070470730890200174075890643652797181103367956318438136878170352\"\n |]\n ; [| \"89300613074831725721350087269266903129165086877175223066581882601662278010666\"\n ; \"36824076981866281177052433916337787028520068526782493484076995129329938182524\"\n ; \"68880449342008497744225106025198236600142055580985632884415488154606462819445\"\n |]\n ; [| \"68556888546596545408135887526582256648006271867854316538090068824142539400698\"\n ; \"111379753250206255125320675615931203940253796355491142745969887430259465111569\"\n ; \"101469186248899356416491489235841069222521093012237305521090058066171355672289\"\n |]\n ; [| \"87819793263125973233157093200229218382531712066157093399606059493857616731410\"\n ; \"11055386921184594780372263378420826851562920740321950336882051897732501262543\"\n ; \"111945832089295501567161822264292548657346358707472584179854375613919325491249\"\n |]\n ; [| \"95630018375719472826904441325138673248990446382783206900295723762884876505178\"\n ; \"94833984285990985873155989049880754188702918168949640563745233736765833491756\"\n ; \"77578854197021606645372788474039811639438242484066959482386065023999206730771\"\n |]\n ; [| \"27799616729223271646690718201487403976485619375555391888533887467404804041014\"\n ; \"42616502170265664498961018686434252976977548128285781725227341660941880774718\"\n ; \"95884094505080541517768389956970969462501217028562326732054532092615835087122\"\n |]\n ; [| \"107531500891040898338150732759493933154418374543568088749403053559827078391994\"\n ; \"17316158269457914256007584527534747738658973027567786054549020564540952112346\"\n ; \"51624680144452294805663893795879183520785046924484587034566439599591446246116\"\n |]\n ; [| \"17698087730709566968258013675219881840614043344609152682517330801348583470562\"\n ; \"111925747861248746962567200879629070277886617811519137515553806421564944666811\"\n ; \"57148554624730554436721083599187229462914514696466218614205595953570212881615\"\n |]\n ; [| \"92002976914130835490768248031171915767210477082066266868807636677032557847243\"\n ; \"58807951133460826577955909810426403194149348045831674376120801431489918282349\"\n ; \"93581873597000319446791963913210464830992618681307774190204379970955657554666\"\n |]\n ; [| \"46734218328816451470118898692627799522173317355773128175090189234250221977353\"\n ; \"12565476532112137808460978474958060441970941349010371267577877299656634907765\"\n ; \"54284813390357004119220859882274190703294683700710665367594256039714984623777\"\n |]\n ; [| \"92046423253202913319296401122133532555630886766139313429473309376931112550800\"\n ; \"15095408309586969968044201398966210357547906905122453139947200130015688526573\"\n ; \"76483858663950700865536712701042004661599554591777656961315837882956812689085\"\n |]\n ; [| \"37793510665854947576525000802927849210746292216845467892500370179796223909690\"\n ; \"84954934523349224038508216623641462700694917568481430996824733443763638196693\"\n ; \"81116649005575743294029244339854405387811058321603450814032274416116019472096\"\n |]\n ; [| \"28313841745366368076212445154871968929195537523489133192784916081223753077949\"\n ; \"17307716513182567320564075539526480893558355908652993731441220999922946005081\"\n ; \"63148771170858502457695904149048034226689843239981287723002468627916462842625\"\n |]\n ; [| \"14724939606645168531546334343600232253284320276481307778787768813885931648950\"\n ; \"4684996260500305121238590806572541849891754312215139285622888510153705963000\"\n ; \"63682763879011752475568476861367553456179860221069473817315669232908763409259\"\n |]\n ; [| \"47776179656187399887062096850541192680190218704758942820514561435612697426715\"\n ; \"42017618175533328439486588850450028995049195954365035474995309904751824054581\"\n ; \"39169739448648613641258102792190571431737464735838931948313779997907435855102\"\n |]\n ; [| \"37525991163523321662699819448962967746703579202577998445997476955224037837979\"\n ; \"67759173441312327668891803222741396828094999063019622301649400178376863820046\"\n ; \"23041132473771739182071223620364590606653086905326129708428084432335332411661\"\n |]\n ; [| \"77778894465896892167598828497939467663479992533052348475467490972714790615441\"\n ; \"20821227542001445006023346122554483849065713580779858784021328359824080462519\"\n ; \"47217242463811495777303984778653549585537750303740616187093690846833142245039\"\n |]\n ; [| \"42826871300142174590405062658305130206548405024021455479047593769907201224399\"\n ; \"8850081254230234130482383430433176873344633494243110112848647064077741649744\"\n ; \"1819639941546179668398979507053724449231350395599747300736218202072168364980\"\n |]\n ; [| \"21219092773772827667886204262476112905428217689703647484316763603169544906986\"\n ; \"35036730416829620763976972888493029852952403098232484869595671405553221294746\"\n ; \"35487050610902505183766069070898136230610758743267437784506875078109148276407\"\n |]\n ; [| \"62560813042054697786535634928462520639989597995560367915904328183428481834648\"\n ; \"112205708104999693686115882430330200785082630634036862526175634736046083007596\"\n ; \"109084747126382177842005646092084591250172358815974554434100716599544229364287\"\n |]\n ; [| \"63740884245554590221521941789197287379354311786803164550686696984009448418872\"\n ; \"58779928727649398559174292364061339806256990859940639552881479945324304668069\"\n ; \"20614241966717622390914334053622572167995367802051836931454426877074875942253\"\n |]\n ; [| \"41621411615229558798583846330993607380846912281220890296433013153854774573504\"\n ; \"20530621481603446397085836296967350209890164029268319619481535419199429275412\"\n ; \"99914592017824500091708233310179001698739309503141229228952777264267035511439\"\n |]\n ; [| \"9497854724940806346676139162466690071592872530638144182764466319052293463165\"\n ; \"7549205476288061047040852944548942878112823732145584918107208536541712726277\"\n ; \"30898915730863004722886730649661235919513859500318540107289237568593577554645\"\n |]\n ; [| \"22697249754607337581727259086359907309326296469394183645633378468855554942575\"\n ; \"72771100592475003378969523202338527077495914171905204927442739996373603143216\"\n ; \"84509851995167666169868678185342549983568150803791023831909660012392522615426\"\n |]\n ; [| \"36601166816771446688370845080961015541431660429079281633209182736773260407536\"\n ; \"19555759172327736128240171000715903945570888389700763573790859521156095228287\"\n ; \"82844424532983875300577689116331373756526403900340445449185486212503235782229\"\n |]\n ; [| \"40833119728631657038301474658571416779079199343770917422783737091842927892625\"\n ; \"68922359316478675184342553333343300163568193749010867527082189412217781430311\"\n ; \"91516472400306837063911995909475588197278444979245081960087094196120449075833\"\n |]\n ; [| \"21304716730402869084944080869903443431235336418077153507261240151959530377653\"\n ; \"106551237424345741137570659736231801772439680702621554106791455938098031620471\"\n ; \"104392597313271110590927764888829150750277653499050463757708547416538850601163\"\n |]\n ; [| \"16907937154215020261110468963982390213438461071031811101554056252102505124726\"\n ; \"23183141532591565112222057191012766855134687114504142337903677590107533245206\"\n ; \"96725517880771645283128624101279195709280644465575982072053504613644938879246\"\n |]\n ; [| \"84556507395241990875812091718422997082915179448604219593521819129312718969906\"\n ; \"100646525819453650494590571397259055384579251368754179569362740802641255820576\"\n ; \"50316555026297423940834952362583934362215303629664094841692233643882339493043\"\n |]\n ; [| \"77363534410783423412630139556441807611393685349073113946053979350631229049878\"\n ; \"54905073434434959485893381841839373267383966385817882684657825178181863944371\"\n ; \"110016011331508430102821620395154714608084938556260733745010992614542669817451\"\n |]\n ; [| \"52040139270046094723964229965823921970388683619580004402190656733318120479093\"\n ; \"495546618036723566920914648951352373868059898268055487677897567226892784967\"\n ; \"2528292188392170914010448139211586215817069915670005292953294092269979070980\"\n |]\n ; [| \"36842840134449713950999812540127591123318806680559982063089906871196226758113\"\n ; \"112314504940338253416202605695368724580971154020421327790335219348068041886245\"\n ; \"51653712314537383078368021242008468828072907802445786549975419682333073143987\"\n |]\n ; [| \"27179054135131403873076215577181710354069071017096145081169516607932870071868\"\n ; \"93264325401956094073193527739715293258814405715822269809955952297346626219055\"\n ; \"75336695567377817226085396912086909560962335091652231383627608374094112503635\"\n |]\n ; [| \"42536477740858058164730818130587261149155820207748153094480456895727052896150\"\n ; \"45297707210835305388426482743535401273114010430724989418303851665124351001731\"\n ; \"28263543670875633354854018109712021307749750769690268127459707194207091046997\"\n |]\n ; [| \"40809484989590048522440442751358616303471639779690405026946053699354967624695\"\n ; \"51589519265418587649124543325590658874910911006853535317847189422703251228717\"\n ; \"73459936981642894525955700397592343967482441686326322443228255968694436816673\"\n |]\n ; [| \"87298777232393189731949522229743081866971743270330772607820990832164835738703\"\n ; \"23328534428894097247289332213412175849711532153957647506361455182140450133738\"\n ; \"51807348624578081645565456865744011145427112815128832643950401419083788780028\"\n |]\n ; [| \"62003629107726929116302469001779155132709624140360743951550189738290955064278\"\n ; \"109311858027068383034683875948676795998030610067675200794951297783857157095297\"\n ; \"2085588517087605436136379278738013214233743532079287631079316773925068862732\"\n |]\n ; [| \"9513664655545306376987968929852776467090105742275395185801917554996684570014\"\n ; \"91103467624252027317764670613760419385374004736848754250298970998535616755199\"\n ; \"39500000352127197728032684892425352332461947514533659433380855624868454474623\"\n |]\n ; [| \"75175260486328125629270378861920310368403601365269629778076078053196928460032\"\n ; \"56923881233337629517433981230592855430598464522180216309153828833928801967999\"\n ; \"20981004218820236011689230170078809973840534961691702543937445515733151438851\"\n |]\n ; [| \"73175203586574092105626230272409823792532423094740797516874387144340145138310\"\n ; \"45186992623753580336479418079070607289916086076906975839720879934817804495460\"\n ; \"96084125187548549854900995260973117424750860440064269432639526863495781270780\"\n |]\n ; [| \"53530507055579550362119832302266967544350117012822630711681736383163390079758\"\n ; \"24484677147631687826970700541691541659768738376645174313438582486313045584324\"\n ; \"99915577684197600584703320523786830947563355229812244982453188909016758004559\"\n |]\n ; [| \"73101441225016284181831039876112223954723401962484828024235461623078642642543\"\n ; \"57434882751817972247799186935032874577110609253567900895922769490031350316077\"\n ; \"73837027842771758252813592393497967898989365991569964687267097531033696791279\"\n |]\n ; [| \"8605586894544301092657394167906502995894014247978769840701086209902531650480\"\n ; \"8900145888985471928279988821934068156350024482295663273746853580585203659117\"\n ; \"76135096553134713603675854628257365311062159747768423095496501607463292188538\"\n |]\n ; [| \"77171330825793179961995032914169307990870372845116475229799680315757656196917\"\n ; \"17848856881287888035559207919717746181941756011012420474955535369227552058196\"\n ; \"85285874363861776466393873037603415962379724376693393356387850868454172343232\"\n |]\n ; [| \"34752820629818556525384193423224856177797869338806846583786365186093662702640\"\n ; \"61923000676912108769617866333091286856690233713839015114991682235541391477568\"\n ; \"105437294734850952102877811210027981435959945375626993201685688489494148805743\"\n |]\n ; [| \"37290995592003925978648162243724313056459187397796644444696543576625771108605\"\n ; \"95156804644588215637074780475000089186488581067063625121782605228712011438608\"\n ; \"111838568780358037910894878973007194619694503969424695895292495245099084158661\"\n |]\n ; [| \"114085830904535970531084512281741806703564152148485737755668141105183488387818\"\n ; \"27151558900245092306095370161852910074651784795680581223133179808714387525774\"\n ; \"17782273009863750298483603933610732253879825505411230932533407287574651036994\"\n |]\n ; [| \"72422039981423868898452547270453235353957783762070405836433674391957844064693\"\n ; \"23635533014670380888810554717349513178608213369182061967678315431422272271569\"\n ; \"59402711345784829746976504521969665104448536964686633342173372133388407225657\"\n |]\n ; [| \"92466806354851856571355165199186633833982438153589406912422876269386887264049\"\n ; \"9877617390649361889067963484857474874019563445507538784053773745685676317984\"\n ; \"74572672075215609948567780829046067891251792522874268554421916351892498078660\"\n |]\n ; [| \"36552683919656073147232029802086505741533932059491323529262718897271096098319\"\n ; \"28895802628889660292449057575076739706255701997961890168977786141673053679086\"\n ; \"9907785227545441866241924986174555965766785257012652276622736289520175209842\"\n |]\n ; [| \"29485332368911768475893015509537099136952860812699472744021496513325455451738\"\n ; \"39797358509842904932758894391536601623578260107859540160156599261695054175926\"\n ; \"107452259847197252302434271220963395311929879689430847107159618578878468880668\"\n |]\n ; [| \"24664696127391052816688570667643612077905959307658722811431436096677076924072\"\n ; \"52507998665481228083044018390203046881916651866666590845312076558622705190465\"\n ; \"69935204723497468327083545368078327534124772251842862926136799697299751835029\"\n |]\n ; [| \"372963191403207230700085823960930798511810380777302780932220121859190714585\"\n ; \"111366606704792806959979488772421759791592911629496627207620326636856656861526\"\n ; \"39677360977437767398760288273614298000827429534821360419179023551087917983124\"\n |]\n ; [| \"64601494076430280535646633059501605929914790764963584476403188233843589027560\"\n ; \"34156315098453482946438495274327282067376463494057110043754782161473776373661\"\n ; \"73687667961196401152630755105477060056162632832680813161120412165243753726816\"\n |]\n ; [| \"37808689229279738382348785246837013002280781984053433359148018860351753688153\"\n ; \"26778210635417272626362658500217995247072424006327715268521424423461840656985\"\n ; \"13012115310019421859484865413402512912208022868124085927375736053832542569552\"\n |]\n ; [| \"33073055720188060063004545324174039863351833928493376423022587630016341635891\"\n ; \"76584254259783109527449313057522305759653397147785066495263227868665161219779\"\n ; \"38531270223194009551634352795926218399266465064491096474482575354468954922673\"\n |]\n ; [| \"90100362566645034035707547984589905559141359276359522681964816611161474672115\"\n ; \"93014643079204629081291124987233004565276697190519877698472422015954982964601\"\n ; \"110916697765188052223435628742886773389228694903593626715469113528434066764534\"\n |]\n ; [| \"114725280711584666069398481856753837363052938587178775403749719257369626174299\"\n ; \"32967950615819700839673854548770413755655613096921050182183649674389310060672\"\n ; \"106372438106855157117155417458821032302424106544646447353561892891697429919509\"\n |]\n ; [| \"41996555998804572671679174634435850382099449308465335760130383677478780889948\"\n ; \"105999190358126224751922865919841547624707481487885223948004296548330504340556\"\n ; \"16636528128134911466622907961467317982179835733058354229921170933476186200761\"\n |]\n ; [| \"43468498537738045222256870515315985487110433728199201952445121047095648527840\"\n ; \"102272887089258604970815589009009162752025146641624347901234381428987386153285\"\n ; \"797386830910520008361185815477523544664694040635544500916993469578452189812\"\n |]\n ; [| \"96744926314199156321023598425708516126928808801578082649702497034531770517808\"\n ; \"99066250188188051206024031106640566584616407903813704153928240609169764005797\"\n ; \"101012485188852469291356197079506861083321680470016268483997462932491691773708\"\n |]\n ; [| \"49614555470963378761214277525336169174318331863453657910575217035316990252780\"\n ; \"94532874466332578813348267802784511494491757628599627802933242637211676358456\"\n ; \"60376163781951477822973950330025689966951914888122503797194554488987660570913\"\n |]\n ; [| \"99934768696780030317676638063039209891456597783633841250810260768328701786300\"\n ; \"71861378641802240356627336242725340978135703736568776865558429280585792121426\"\n ; \"84446994028646761779912629176051455275041688583492300440129402381138226185369\"\n |]\n ; [| \"18317002472599225949038448120242542829985613745531554876060436499109578301758\"\n ; \"23001721954642810524358122249469196372443463625490878969385130364780514025259\"\n ; \"49037245410934285111914043557449391103989331168177809387278571893536129709378\"\n |]\n ; [| \"65792050828386571136875573680568197513273253001530588336285451691348906024460\"\n ; \"12956514709922286639520985225111137950302442378466870763868693820049405409474\"\n ; \"38025781500219940187723501911749158551479941535921061459281014661810772473038\"\n |]\n ; [| \"98610017124283789125637190759729078315864881693957982200427567103302362453196\"\n ; \"42724178943656779288650125468921272883324869492775989038952508393082565227450\"\n ; \"99514360136104778310983460863480701661882652836741972684579325226086664343913\"\n |]\n ; [| \"111234788248236327826382691076985300771418365594838017963216100441270435887017\"\n ; \"35290532009451633157074005614742321966918220860237810056920944192222599040501\"\n ; \"72172784027306769601458922728374293130025170844011739475076742090414769211169\"\n |]\n ; [| \"61384388429666858375759167984149961873566898632022783479711533101905095026411\"\n ; \"8194273390415023152581060020119881338779571723515253104919314696738194355344\"\n ; \"80659234466772556847544129237154202226081525079070598707001193889658539631883\"\n |]\n ; [| \"62157670692624367146830864246105810519941474190553952682719433471854134465138\"\n ; \"74851302400382275482762496406028988868219592716510355166137061257664688666219\"\n ; \"16881796086836744646703159464114164393240695449455598565494759189917589453976\"\n |]\n ; [| \"42460477269659081546432152357644086326197211166562674408623141905226706277595\"\n ; \"81063688725529281621596607500748519671655516257039992655745871437369181665242\"\n ; \"51403113216244137057466948399908740878535656059933892843818689317660325080213\"\n |]\n ; [| \"49001998791770520786679099472805193463531142479298200795569326894791589887035\"\n ; \"42684462014557597494725933597359625461226399711783671410492942446635214257509\"\n ; \"106420886277092880545929306533089566775810130555230702838917980421765786292693\"\n |]\n ; [| \"110523958037212353696746219917157237679515245560578307171595792811566554384451\"\n ; \"56399709802930804752950401483879725014794413557467977624037632281590440364765\"\n ; \"100108862073771478435824578087801736413858177140360408436521717282600830155374\"\n |]\n ; [| \"59041409790855290045250456089216312297230856546920761548978870779493926213674\"\n ; \"13735945315945382005247895569035266667172550063549145646185577935658666385507\"\n ; \"16846296242516834547231537358954027537902709068158411294345086281698311539718\"\n |]\n ; [| \"114970774262524353875592617323889610576992844847433725376114488262076142213525\"\n ; \"17896661983150937411004047429485556264820315976705642986609974816436222162633\"\n ; \"115573362005053049429141251153085446935774781295666612354309246218946442750706\"\n |]\n ; [| \"85575265064375003235737272215445285540001719469558026661845214249857169530994\"\n ; \"87501751332871186792668480006319719164949448258731670359536302677279100637346\"\n ; \"105775909055063540416087237151517389942637625317333843436738223226977225420379\"\n |]\n ; [| \"110886009455283422981396854898481256559291311408679418842391298005253375700608\"\n ; \"95342257228100720685556647789433478371609336135456255803583405713563597933074\"\n ; \"2733591517253510124338232417535938539627593736745105875672348998709544742241\"\n |]\n ; [| \"32685479117496505057951010536248024091461630564950845696581129158987138920098\"\n ; \"96139836598015371513111133071481139035733083963976340622322043979088723982681\"\n ; \"16990606351055720221300633612533434675038905235719867684891402550154692840579\"\n |]\n ; [| \"13886834869596827027283068322204563244577723967928602405785473534631482228259\"\n ; \"81034769645830807786559566591578132114590768431721148809270219480247445931316\"\n ; \"26780635035984131258327079447673207266040002451512601352288859614294714150612\"\n |]\n ; [| \"72820784976920576285217524394309841044157743334874310886804718206719618858662\"\n ; \"84276722913141806246805569560426345961854221390421557310593118606084442633714\"\n ; \"42573817497593319926701003355299929070203785007821783512454795971915573843634\"\n |]\n ; [| \"41660041627266397279909712983288860313881442148611073178272756605107913521726\"\n ; \"7198246770791404776745997973411401046335399072925979346193035999274650139809\"\n ; \"91576025129588718283317000330880100309465430116820675850311277329602716166005\"\n |]\n ; [| \"30488483928716649313242898509172476460161184318124511942476380904233730958564\"\n ; \"35346040517569327255933130090945133067049088493975862969006023114275649329148\"\n ; \"59803015801166721680239913449555176591725421041660016242103441987856441941533\"\n |]\n ; [| \"17395049232451382970906883167116397657891664802601579276725674512534883408665\"\n ; \"96892830538146451450007413348096295684782382701592949711753407054447667361829\"\n ; \"46725583995795907014628330473921842919957418641665482351238505922983315675600\"\n |]\n ; [| \"20556719902345568138970735755829852608784985449829745172855204153387982836579\"\n ; \"17130405757403641097651484965062131526367059595476924144885570325828777794585\"\n ; \"99651763337265056372826178960800950053231370129318394703153246147873057668256\"\n |]\n ; [| \"17814517977679061356584950826520510701145481336316888282105225134451035883368\"\n ; \"62116749577126511600138536864540326578096290025961229483071769130930103978622\"\n ; \"68057799973217998063838402481530957249181669394905338807621317159743376777292\"\n |]\n ; [| \"26100793478962260035181580648528031417033872324944615961986573818448125345450\"\n ; \"26507891451149179196332605230084404371370204632884553105363087566061809624465\"\n ; \"55607174697006979796477169324630939518573410736589826596210132996613779221405\"\n |]\n ; [| \"75098549092668095590746032937529532494350222003700838962461867948806312867882\"\n ; \"62901674712278062473767645982006145910793625009149846534629441949336033280610\"\n ; \"5918385816682866756860679567405784562483373873565987668410277610868983146285\"\n |]\n ; [| \"99232460916208710346946062875203578399818909925477280432427620267031292402265\"\n ; \"115165948144292852122635634954139515297086369356811820254801384608988902457684\"\n ; \"39462036389170488019054739441325823641943062254145671230029238830857274014332\"\n |]\n ; [| \"109723826013507458840008311671051963282645213933956581735587227292458581212170\"\n ; \"88295699560808238817850908733435797366622278897489038929647807463406234520052\"\n ; \"20306380368695786945008272690438693745796297843799468268993907772341096948885\"\n |]\n ; [| \"39988356032524455736714109463355738665746339590560108227920970859248126609155\"\n ; \"47372836588594871116561451142702593094337405740661755511614125456886719840333\"\n ; \"42727075822142544969304941778878121065758237932060280070908539158139079888683\"\n |]\n ; [| \"115695172202592006925180721060969710051274632819849770440984261650964182295350\"\n ; \"41198034356969673080518030958715740186484860381424802035929938277103521577731\"\n ; \"115380378505550001583545282887589851179279565072664241489053445702744491234750\"\n |]\n ; [| \"56074680442485705900559544809779144521596408129059458559681779642734476672579\"\n ; \"54187206076706271120400668422875039791522899135281309004702779376007885441827\"\n ; \"100760509008368123701304764217450368711018785408289674422092070202193042774995\"\n |]\n ; [| \"2622643323130765702269424224791233611920515499144047449633123689743564676648\"\n ; \"95487289650450707799373930173349121410704227885014701702619711048222666102791\"\n ; \"94943953462630479470879050547964792684799160133612590505176816568790562776928\"\n |]\n |]\n }\n\nlet params_Tweedle_p =\n { Params.mds =\n [| [| \"7892482395656804349644706591899634788891398382785975587948820587975527991027\"\n ; \"11929678886172339432249632245409218061683715785450195046937244296345281508001\"\n ; \"14031028727666215233628980515424371116641513455277823607571812548899776279020\"\n |]\n ; [| \"7068151019014908222760412877815939864640073704531562607661785991407609364631\"\n ; \"20000306279614657869922305271027332599039933086359117559307552225546808822661\"\n ; \"11789548007016973514330291636006559052177068373404372008308286066331957081587\"\n |]\n ; [| \"4596429675096962119861928990065498834900102715520185745595618370978168039762\"\n ; \"2419382603939993361171611462560649281200390612440053944534827125842944774778\"\n ; \"4204784055784266414484460653790149892220936342148543538356735100428170988226\"\n |]\n |]\n ; round_constants =\n [| [| \"23871411633030431908815309679954664955316835501833596382711537998018196877083\"\n ; \"10266075254464775081489705012423357777448464454058081904455633881524670629031\"\n ; \"25330590157378829472296364867033252573045672523068709711474216638118028547521\"\n |]\n ; [| \"17731890776914364842025248625325793211421093305063918487984842622991225662959\"\n ; \"11733994571128449437695833182309936427385843597031955163409472509305883070660\"\n ; \"24434628986405408065629924634775662413138564617325268165975978656343592221427\"\n |]\n ; [| \"24536402423562099407865959531182080003010952879037409125240233415066893274478\"\n ; \"6659347569024195568957991805519163899458248905612848191888227437243439812692\"\n ; \"5960767186841646855432896459128104017951108167445308950169111825889581577061\"\n |]\n ; [| \"4971911842906289673901226938513151439879412562713230347716896457803333981940\"\n ; \"309541453644722548825874753903709706899515232384157286261751156736135339003\"\n ; \"2269569616427699911129222135189454646445178229181823882769580159958019242097\"\n |]\n ; [| \"26993878188558092116624938696043644448548700311708990249335713416846104251941\"\n ; \"24517651748676427005644984612090266723222512573361699639974666939135208353913\"\n ; \"1097726622863402924577966380605322382732118204644384325315739877029330402588\"\n |]\n ; [| \"6426758383747111723734570359305954670329012940529176997601958694540682554431\"\n ; \"21998569714212750241527571701712502925679335862585921971643825857153225305984\"\n ; \"11047558033241019082897471004499357092985291837411225795336191143257516860961\"\n |]\n ; [| \"9093665141362071558275397247216897637652502299054137932451490373194253077166\"\n ; \"1800243967051770052116464993247352026875477402681617776355019059173229087774\"\n ; \"26123174928857348712960596162051313701754733407348331834302644408819678596924\"\n |]\n ; [| \"23812410588002831655659233838637953883343555294778677500694584331113461461429\"\n ; \"16568937332253520415004151553015144261880434455738996526515454547064570797856\"\n ; \"17416986733486903313008211792802080561485956593184988794629480990990241332753\"\n |]\n ; [| \"18850099810484503215488003706456560440897969494004838374239261525322319819433\"\n ; \"11994895177966687446998282218714100449449665604701986885520927508332599942486\"\n ; \"1425492478667258597960503405197195915139351100492375612463171033833952312365\"\n |]\n ; [| \"26851566219342728401327392853793780102411433232004161234295219003581835075094\"\n ; \"344621744446962141869707506851008584085694659330775548168637253712934505608\"\n ; \"27869765162837447936932893631710126670776990181965052553686418664996771747596\"\n |]\n ; [| \"16748261191950640387981479364297758560864676430387245694151916012002124597033\"\n ; \"14637099470938912277872449097875538968878222997977657926224477080477442009809\"\n ; \"20134098049637875993058446069963966007404168258760138083222194380042623128253\"\n |]\n ; [| \"172643149346341872053831853059095100992686236318507345773031309275063274280\"\n ; \"21874843113613945727298268457562401417065305917171338167509212463100548326138\"\n ; \"1700476193411517352507365601977550539756670894414173315822287469432716857784\"\n |]\n ; [| \"1993872240998785476519726097091542582716493962333829952600400285464827481667\"\n ; \"8472968691234464451203870490242938239228570177726710854613935637388109305350\"\n ; \"3164353924636797794161130496213914461962109666565363218256253978570495482041\"\n |]\n ; [| \"18244688836192292124520893341941070140825196416664991549095593577108644921872\"\n ; \"19859999153394936655973233989554564211615670588445691525235383025282647829759\"\n ; \"14768311403338750313336252298369831176491426375153840900301806527515974149276\"\n |]\n ; [| \"25048746858150888741163510410158558227335767837462499905107113911114136816901\"\n ; \"9227230998590560160520502436666565937931267956328463227409811272485685606743\"\n ; \"4696776701448869702784130024458706731441259445875220148105235193026890671102\"\n |]\n ; [| \"11301287347994988321521498920971508070471338636236053007115010700214623134272\"\n ; \"748252891813253856881595793948847132117119525095726183576703279303135116231\"\n ; \"1209563742600434023250112835996756101387112259967014633008182172249296990489\"\n |]\n ; [| \"22609170854153903022054335214005629175374223898873094415826508662474540012601\"\n ; \"5756488621395177188006147242675038050365093553404446887430772051137609241084\"\n ; \"12204891034723523196031315166164117720044397647721380430344188362824579202559\"\n |]\n ; [| \"77948413643208929474117747177500706081858969144437292876038062365116961856\"\n ; \"4819244967439699230735093723487091713222852277599700902443121153586483108261\"\n ; \"27255193365519906102265579122686066635100777748346545926565256522831777732553\"\n |]\n ; [| \"17483513281289738114320990201034187042331906234136726563186654929503890752423\"\n ; \"34539753269842243397370782720638857152602526530856732612587217775462538897\"\n ; \"26670389866012575823645511883620356698491268371217559959046672563897471132762\"\n |]\n ; [| \"6221497512567057828130180875424737245292473047926600299819610408205436413046\"\n ; \"19660878074830892741426544634587706872027677058382555048951769961524177907107\"\n ; \"18156934729803692033361542236751723515055361449102326383067242692178901601513\"\n |]\n ; [| \"20073967418251150136032317311523223358394853170230955059721556689651929220184\"\n ; \"27772273899948728907116549961890766782916787451941456619762132483552045169192\"\n ; \"15971692165674397331342925986736499624826262396209267283406828364924966200635\"\n |]\n ; [| \"16416286997172332555663573131890151419265070164405909524639440666852040213934\"\n ; \"20103224377910718515832192173396139379357815331321992767836849578341263715617\"\n ; \"1992082765658661183841193649461040448653056879234437404013909283532649563512\"\n |]\n ; [| \"19951269645786270967009199575056978741590225092285762370657308905017645787726\"\n ; \"9251473059263374648207691341973093388418035271819559725381912479353472754743\"\n ; \"2444980378309704186211898448086030379464888548066321109843797635753120477485\"\n |]\n ; [| \"10928282022919314114783091884635542308337867197724629946199953660957345275397\"\n ; \"20860003419679976346116549953191442898649396106318245755983695478063963781522\"\n ; \"9125646500493112058936359272551424490842840477766749690227538466206819804312\"\n |]\n ; [| \"20177768780524517369036303031063597036475507744395182409567531978700484378289\"\n ; \"23849136275489209274738706275875891467606042431504310216391474226820256396157\"\n ; \"7976082325486396563438765887430351103212480060205218817888924447342264023448\"\n |]\n ; [| \"21218093079130866432053178184495259038615729811686678720305378508679861852386\"\n ; \"22222629794092576664613127689533080951595674722722217395604438734265291507137\"\n ; \"16117082350553416755654415094185598367594750430516162377370652361756124580927\"\n |]\n ; [| \"15386072248373014774707633578974000489889916088461822982033430186915251599101\"\n ; \"20059444943956181967567300338884496353066968918285957577453937920821326774911\"\n ; \"15969043598280333886921493788703960477679932825020353079985508309173442399807\"\n |]\n ; [| \"18441908288363677832500730109945652708871777726808321883963939341572708678438\"\n ; \"9156742662968671243472647671483446293299984596395820828399187385978257187180\"\n ; \"26117513962333705951186643847036445264112495570596099092098117311469761624146\"\n |]\n ; [| \"9227362126330995448990863192270789313546500545949776416489812561581590597341\"\n ; \"1651638493276735214427785026108815161181550587953472105263074483216056083718\"\n ; \"19754190980633296736565417422427507009115461976496493840015545861722778641757\"\n |]\n ; [| \"24059801258623894209907222963420795819610514468735113836904109681657134646406\"\n ; \"2507773721870400383553935214026283806800287719784543798652125141300020939070\"\n ; \"11545619277487756168659369622509301766172311628766869964453828841442812398464\"\n |]\n ; [| \"18599404251801695916676262627086229256833226846935875794848292474360329710182\"\n ; \"7672585728603312485277463389894405790617721546034983006052523579994187672256\"\n ; \"11663243875044039826255065018193844285574447293546626080552543307831236101532\"\n |]\n ; [| \"3736737114971552038249889038312531109770417843384959461392265945390839075490\"\n ; \"15405041123991166901995181017584204362284350353917954151561434093358377932416\"\n ; \"21190402840771768305757114855125881983900480564766015821826135703463049645985\"\n |]\n ; [| \"27657612144465152844076751970773624300501046484432872648148700499103897742199\"\n ; \"20388430216478368624703227056329193371722737732187907129943643410513691213535\"\n ; \"3344820289563345194933219828087298037081196856323727299522946086140971056423\"\n |]\n ; [| \"8527890306194452597728380300408050856248447791462807214374322801696709074298\"\n ; \"3344453085657711280093205964282996094870704440396012352126082601788308767424\"\n ; \"24129621344772065907359832544790760848535846792550779738943452820186937321016\"\n |]\n ; [| \"16682281929114205892868637273887744852593056654081569289385196216494586052059\"\n ; \"13390546402723680321309451408062261872073917009165123815466701909179323058725\"\n ; \"12454401735435545041240744062413508439776638863019945214106500639361960301753\"\n |]\n ; [| \"22691978545214712333682322509829714302565160720214993370385276444403705409774\"\n ; \"9304194978657396762457989504468955280882290742713614422164474050373984880419\"\n ; \"24518330162580075369755426938387542128644607789410819379604533097820563945147\"\n |]\n ; [| \"7793343388923696013769312876044250715843242497839331541419306365445952124334\"\n ; \"15474893610836752417132140205467036343146784962533163791549972307193429176684\"\n ; \"11116443861170111868320138692617094510473035491476329457635995671799970535803\"\n |]\n ; [| \"16877979504226807061419377389528064425375368470773322489308736865456734785901\"\n ; \"12194411710031950769113984418215809481238312707786246344424020890556957457012\"\n ; \"21329761519619810559319231763677758647122208920134924045388361417919054295294\"\n |]\n ; [| \"15486704070124713197776757158780492106937367947624672577943214567891933787258\"\n ; \"21879500021741312414877635555959377131752915257473724817131516706125013556007\"\n ; \"5043420522702480930107029442863985487527788786987286425206067343205474678396\"\n |]\n ; [| \"28416728565535371153714147767297875894376657006631966873680443521362574322416\"\n ; \"28188295006821213084652983277541040229663295908823345264477158493251950224190\"\n ; \"811696348709499453953485215191565713676093511624729934721077050082968313251\"\n |]\n ; [| \"14655407507725921832105500951552761181971660775931368508685072434505922507512\"\n ; \"15452937371493366546640620581126461399707812646853303452806945678641253144882\"\n ; \"2286261699720696752622655970051026147406838467804385944265035557798199981133\"\n |]\n ; [| \"1992557442353308000623574109100253608701924636766704840114158126271278280731\"\n ; \"21694450413109623921951195958057854484852090181678130751969309977692551536018\"\n ; \"9249731319012017779017326743606194923643668526628748858217378905811538368382\"\n |]\n ; [| \"3939219222555454896586029131514042607480723623744884435463307473774574605152\"\n ; \"10797179208934709183850676357345550930799476411664074421966228250898236909457\"\n ; \"16003349341141317690412220236365636756328414540434964599637729177724750393340\"\n |]\n ; [| \"7139886020914795212662604367684684711418131042431587260958077772503994611059\"\n ; \"14548527492795536984793003371667969667596401576140783527415224992442661296652\"\n ; \"27784961580458637262287375576745710987249457442419641954865148924289640098875\"\n |]\n ; [| \"12713866702735338063343936521670481149781186654485300349666527843472483230312\"\n ; \"9092010170409960335483537084430885053488154353385070704782245279718737955046\"\n ; \"5094923690647683377313391496286927104459466521704225286803035696710155177995\"\n |]\n ; [| \"25569861054853573619838769694313237597861085179963737149403330254183532535529\"\n ; \"5878170049851666055783493866996165172583448340223151974352193778036352307943\"\n ; \"3872169186443882698001210463876163485285999493224352597337453067537500276246\"\n |]\n ; [| \"18665784052407501847083570675839500069230593336210620138506436003881713609889\"\n ; \"18152379076079140594000518889838158343416361432991548307242241800589989006514\"\n ; \"15293096858608991177688271468787656348083923851728718260954929346470077552533\"\n |]\n ; [| \"27458404667733046540990542309129625717764044091884418745028933631962947220717\"\n ; \"8006229583150739842023227507854792176671075468287456095936807010603225964853\"\n ; \"6673337136101970490098396053273218923846658878925354650729739777392657741321\"\n |]\n ; [| \"2866189528434329040657150614965317384179174137415824086986689674293245440869\"\n ; \"850286832335872065552208685923468151432517596206010380489009288659201960609\"\n ; \"826167896454325673153913201896766310675528897953588379016483511428072705149\"\n |]\n ; [| \"11091353885350315399281534279307640099073252617438924758095267005171197532901\"\n ; \"24332996362686645308612352679547748916117510430673097992758824281388269163049\"\n ; \"7697281120418309884363241543849152373040915185661630590946085871626953307630\"\n |]\n ; [| \"26903415823976566965446163261389520506645994486239829395342314389345167145490\"\n ; \"16331473399937436063872600675479075998365344725582239128025161788438169634490\"\n ; \"27478782423978673109458866577304881582710228942880032866222151681880849121754\"\n |]\n ; [| \"9157575957419463790299788535651375681659171956515351213017221629165597230565\"\n ; \"7212846269226025424784660189052377648721231465719295820195086840304302908764\"\n ; \"15079360452490344164815517579543356820049766968077892340838182489029333395345\"\n |]\n ; [| \"2164387758948063499404878920144621238577478053584327446777845938241996921307\"\n ; \"21971530571660454464263042379401691171478093875859848797664553305525096942047\"\n ; \"24996214603829854187327550321668003124272776524258345997409641809486816101711\"\n |]\n ; [| \"5012530167147645132123926239187192574015992833971936940239020886743588014969\"\n ; \"3538797852945828178389690727899551008654641317873025930608250831273186708784\"\n ; \"16351872580375794420559957848346781277378485393541927811867651422570033372488\"\n |]\n ; [| \"6649114213329992677018914668592605228429520774140774692558017652328554186338\"\n ; \"18665440706841919461000547042069933770374154186835596054373579551791088230368\"\n ; \"12068241390808361251909200960327581910129328275585071206860621578629194685379\"\n |]\n ; [| \"15905233165225780889629861680805819536375352205513425939444748949014424918343\"\n ; \"12508454002472469574115566912186222048654143934720930056557327011774683943013\"\n ; \"7034709393479901734220602275921317679827342926959053187089378763382019774818\"\n |]\n ; [| \"15071057763697867068980601577937010855726002209360872455781029717330270540558\"\n ; \"26837903264629473479982710556353240390490167539626299502592215453725741017346\"\n ; \"15815857256588462989339312138660989790088642030075547425161293150909179052889\"\n |]\n ; [| \"17790122309815232908548524561514677539176024837185249994150799440752116986971\"\n ; \"25681654720833964361368816492300991096107229186861423365051433302640152727160\"\n ; \"25092605033552047946753252380591729771370646821844905835767238550702091926466\"\n |]\n ; [| \"9133411374125723094094125880554229361676050614544252095679163115115894136841\"\n ; \"26932002400667217014602216630093364493283860795391062254701152928395308796018\"\n ; \"22106228556612087153532192407561886213520535606346621942342426362558131787963\"\n |]\n ; [| \"9406311227783101741290261235550552478435250008098267151139650559181505389852\"\n ; \"27348341640941808284285285580081335760088527770841163602103782109071842104934\"\n ; \"23559463527614164053397335039301766055455415575615533929384690127861601499457\"\n |]\n ; [| \"5619769611055946079310055282596239209008895876149398331145676663636029101157\"\n ; \"13578163259668232168333668013435506407087237516177382960962039602890195751920\"\n ; \"7413830766934399815434854130814997370862812666201550415594211525136216734282\"\n |]\n ; [| \"13792443813595271204983556094168533754933130020885607088800378971405796327369\"\n ; \"27980816529551052578978463084908633402261105969483057107732537724040827783618\"\n ; \"9086585172488644340339192486024741212137636677834987669856236495399842977922\"\n |]\n ; [| \"11313421680706870429846305787628308653216330618143751161363947025312249024761\"\n ; \"4021066901602104243187251101773896805730813605469425950314405128776613579602\"\n ; \"14767121153557006971815403909933008062947309032922288476507340789333378073654\"\n |]\n ; [| \"20370619771295344300690236727919219226792483779515051540457737461170706414475\"\n ; \"19057013717580762168292421969225077213646512718101800237917624429055981813838\"\n ; \"18802159878265458151106922138846829134121904345009173021788332776013230402104\"\n |]\n ; [| \"24016190866456985740426033746487501435211791016346499791546425666381940738421\"\n ; \"287764449305195377184537313636736253449783439200917075011454826449334249192\"\n ; \"28924625533476565101998318658547220617045362556325453564311201040145506030261\"\n |]\n ; [| \"7599844266964312760321206419543935528432789425869947893826782118191539450266\"\n ; \"27134279976752686312431326985386138880800506706870947398386273393113450719312\"\n ; \"16691817056677639737321251699552704590963223686119737935250825199787652805166\"\n |]\n ; [| \"22998044684431557794791841708335486493573768985622899417439899102757564768837\"\n ; \"9401177121715465262238174135751147495308547205972761175814504972150026367535\"\n ; \"26790130566347368063997033116765929382273650193131343958415387299771850673985\"\n |]\n ; [| \"3677775394669979862889071463502051146295423081411873494668961683260168561200\"\n ; \"15979374501543368828047096104571216535562304582450829728472504102636784119438\"\n ; \"27983949821598015961883988148799706647207081688438954093427232113605924435366\"\n |]\n ; [| \"27544538692601828352117435876403689629911776874104761257423949309268045763185\"\n ; \"26518335501934972769761573274318670551390596750003847775195848446258018442847\"\n ; \"4394131430649458263649250511378672198908409479410475627536485368480589477325\"\n |]\n ; [| \"17852065984807648650789061534513315071882379764409167220327155188497750610044\"\n ; \"18175119138227704225937550148743137184987075122850987480893509516338237125431\"\n ; \"9213947738410262749305252213461572203334592178012688401993745223133683403178\"\n |]\n ; [| \"27122114905718250703139963834720424986105744685568269961612244344496328439886\"\n ; \"4760667796367744574889553071124411738303713877930746202875952709775583533416\"\n ; \"6869551919316193097108785401949737566268346424578556997536454243546346759675\"\n |]\n ; [| \"23037512317774976799069981329205938965143927594538311039095844313686020797562\"\n ; \"5054896342931452597037605872652090619656314276168870046892307499425423949760\"\n ; \"23203714262075719720359794801639953965353238316905585901583196491094684440749\"\n |]\n ; [| \"28934221989290923495677613925521064896104825372643558590174660971609344537462\"\n ; \"8088721343567483152949374218613505786573889657303344700058590499312426775261\"\n ; \"21917953186139856111153943474716456656175171733392297547383518245334653482436\"\n |]\n ; [| \"13961331694190054971056058301976924809966415553682688755720832242614168486723\"\n ; \"12544911152480935441357195703690990795365136419393151814200219795399220718629\"\n ; \"21695520803994090395949407367250368059907198292643658069384062711565918112344\"\n |]\n ; [| \"3716150465866919736709076695055976565597785970845650354410730126658608015494\"\n ; \"327336957994661404033945962575518119150720065183392456042720063992483355163\"\n ; \"3665947140103366584087139828849494245835014110441785513464272098210192613654\"\n |]\n ; [| \"26369492318428928735445021592697190549303995382614357682017136715337112747935\"\n ; \"27749815921003845385723497945745117881231921684907697336156182087899053510673\"\n ; \"10355044492217226758344497131673377893070994153140912920311451906060821340248\"\n |]\n ; [| \"4628431130793759981513415398028190279858542396207977476299170127225184781705\"\n ; \"11394587544387541452118107143659899713641924256823223827419604528665720745426\"\n ; \"27501113180347337346361365060944451586249867412705472720376921357546323344395\"\n |]\n ; [| \"28278837938314100710292020893318211455155607281093551519038981321116602349373\"\n ; \"4157302910095235339431818149458321721626091681389723550549352022675823861398\"\n ; \"10647753346148135279439456095440861046789212730332155466632561589399089133326\"\n |]\n ; [| \"16276422291909940897533508339274805427392027844787029744067454575137039713632\"\n ; \"23729032431762932898115881024840919797648524831708845029533918801044987536615\"\n ; \"22905612910561717552380974405189058153230663615322248220713638543054825797666\"\n |]\n ; [| \"5444504530356500737158011550177553406072045906791914738537751528417224842639\"\n ; \"28510386747999403469810407444832806233927676089588288134899522943795774693661\"\n ; \"19805413841948596162239177018362584237164470208997373794301520395085284750539\"\n |]\n ; [| \"19122547678583805564624026606820513504429328853794128995861987147454516637234\"\n ; \"14149390468608933390700184668781640373558946294178094543601697991189519008854\"\n ; \"20866357658195086764903364035397344007481887992484022195436866986726691198910\"\n |]\n ; [| \"3091400614672562681643141264311087165471646584668481415815002651728679925334\"\n ; \"19494024337294025984052821389584821264663721932805988242535888300060571638572\"\n ; \"17644592732159647749467251733367874632398437355549297444150061364959517600595\"\n |]\n ; [| \"20396032354914064522098028139725361423909280526354910804413358051025918529619\"\n ; \"8139121339158552499821459368548404840589616792874943249851117821336073953085\"\n ; \"10922434269468548872208754791993251262753058094227791965335951350558389242990\"\n |]\n ; [| \"15649912252593120246156581284146963323803608017723227709583948225917889870238\"\n ; \"21372394998583927818008072510481270840383010669604639655072625570587680791691\"\n ; \"8898065452020133817419600668300082490862298528579716847829659770466997068972\"\n |]\n ; [| \"18650547661483668504889775893476275079031609582673355265573607371710055926487\"\n ; \"23618674478465955845441421736720381271262239925598902631963493613481722447464\"\n ; \"12891746797231517000473007152761525047439710094872911258902687687042685332250\"\n |]\n ; [| \"1833893631568920050533599834904970213411923339935020486417653785575000615143\"\n ; \"21710180770129352998141024499580964469666455613123734716169584679669510873775\"\n ; \"8320010738639970594139541432443041967828948675894027397631123863826975291437\"\n |]\n ; [| \"20373837152733625366974701596758373355440504238040809868686624790270197493528\"\n ; \"12781438644864943427350664202279855672900381345640622661363395863727232461941\"\n ; \"5622234659258862655204519959448765784253304067430902712408596795866706826032\"\n |]\n ; [| \"1029291849649659108434334644503982141075719243675099861198550852722630712209\"\n ; \"3399484996504249361098308540916753999551454215950119214258113924944098529133\"\n ; \"4228806379514872892076346437718106945625482776494389450700910204388632399170\"\n |]\n ; [| \"16757668050571560648475639292687013846146697092325505133502515482647055695358\"\n ; \"18015084288230839372033169918933220044489391040316918002447358599016172874588\"\n ; \"22518355405199157615512407427389375489730975216718755365792251880852001347523\"\n |]\n ; [| \"20573368860115893940170639217949296882201199808293037762710789923980031371642\"\n ; \"9960840295218443524938341356473179849353725032041141822502293175783147220810\"\n ; \"16607996476430852400280109630637008547605338554739450722762338812055064961040\"\n |]\n ; [| \"7171658568863901784323661701131019863889729147856087046438022012589987643202\"\n ; \"10419002933357804877530761113458274768874412386136675204576115138741608012739\"\n ; \"18861306008102317898949274209011264398227868370415517665809396034224603196914\"\n |]\n ; [| \"1158669061044700880156383735717084681300773582244764163190588381073092936750\"\n ; \"22580910367253859335421514059655021468195876007209097419255510855097011721727\"\n ; \"25227641011701829958282079681052124431202635521215558068499733331989655141417\"\n |]\n ; [| \"17631556489231839623790313532079202613255385273277758734940753078216858815087\"\n ; \"12364579808565613988949646111979230705580282638991093972288646497224214207629\"\n ; \"27329142993476341161848962227966301919437953833554828144399467978240930742586\"\n |]\n ; [| \"18928954276816129093422581186438144214889196137619925522418500128918638106192\"\n ; \"2694991762120052049414391511440055444192349820338943254217225671225856705354\"\n ; \"24550218467559691781293396903076544150117989130151493573851599275085996606415\"\n |]\n ; [| \"2263637838316531719424059727023190126413315239400030877929788886432292775329\"\n ; \"17640968677322424538098309260107170953689147177463962461922714776240524875178\"\n ; \"19443928844574086327434242479460066104315747577578735497796887088983936043942\"\n |]\n ; [| \"11946837349828339651553745139029680016817294186050265590839923356905805035357\"\n ; \"22348022813139862849068148377528486325131041514035743832201785720676226808476\"\n ; \"26916778334032102178669575567836710673110496650392713945070999799105131256857\"\n |]\n ; [| \"6772367578799449199630493680882624055636516414598646521039901701866152406803\"\n ; \"12963643276721087785826784687244852783616903441339291312110495293886231701342\"\n ; \"3495180091566437950872177051556773503914696078922351249973160522225629648761\"\n |]\n ; [| \"19636722086015988900698322500132161186603083218895346390169893819062129539093\"\n ; \"5666220019570366878592707781772835552094759159906603422414363731979336135967\"\n ; \"7874102875783310620499310739194930556976996287514313823549459686051373482140\"\n |]\n ; [| \"14280578027404451144128482988128079454347604231057136906257574339598355143304\"\n ; \"5144471065355127918389406816656570319104327848925794556365711516976530276907\"\n ; \"14225884822276867436898370040228402906367131879332823332133680447067984518507\"\n |]\n ; [| \"28941268628390287870660292646709031665780090480358777746775844529193861308069\"\n ; \"13377111905191945833969566484261585035643984609846866899463874566132398229000\"\n ; \"22564078765828517667859311123307256081299021587637307540298808998440794108520\"\n |]\n |]\n }\n\nlet params_Tweedle_q =\n { Params.mds =\n [| [| \"25915736081177016241546598112391708036536987432422305635260260760208122221944\"\n ; \"16297879259961607025362014922234140032361260365432098634487800168878994764928\"\n ; \"6033733257175634837476818019847848256912403026667817175660404282168388911176\"\n |]\n ; [| \"14045886505657516091660160567697347035599074026719425910347091110613125329282\"\n ; \"28063323679221750580410141978618538612191923017649765586082296380600660325013\"\n ; \"16819697298174473653322938069684433995665518997062997223549599541089417145617\"\n |]\n ; [| \"15413524273045791515306211887939932559344561300389872507948116835986601106260\"\n ; \"36421043490025209186163871592492585408887527098720780722489614383638192290\"\n ; \"19794181301775644846947316991663934780462668882189182094267354309951373752713\"\n |]\n |]\n ; round_constants =\n [| [| \"1407093205071385134019160203229442695267924164910042285561052671714302327117\"\n ; \"11779724282856814171131489762288461172831486048510303387508269258305405159494\"\n ; \"20501356828629986222924519680141334519157249096910596964295651887901812757851\"\n |]\n ; [| \"23419085236318922177448829791267506851321183371308368120588907466638891990218\"\n ; \"23622615725307076779847815917182329276803050417362884676509671384840820735432\"\n ; \"9803250007852134109663616761249682289000165070757264268444033227122154712435\"\n |]\n ; [| \"8258125311635369235384004583299440393524061932038233801638278824513198056900\"\n ; \"7351712538809193694641892798746315547120734114915787568462574210306016208172\"\n ; \"3059129220572147109518378560013963561504677918762824375487834543428745926058\"\n |]\n ; [| \"2042383557155251217884643242454382272036567754448083296933565675865119461967\"\n ; \"15129675271994104178514880712320024929034675263917539062120100905141109232670\"\n ; \"2643699531755105343660845635266167445623854478292984863437116378029552006216\"\n |]\n ; [| \"21874906039195160027003265247067314884270948612748992177669773940314010123091\"\n ; \"19764685963582912390728638382178998584043501872176444130158409984862908383367\"\n ; \"24731701819796788156889906156124721070820824358000508514589474587782991304615\"\n |]\n ; [| \"23349997101843053192913636118003774827214499818459416641628849125511955859433\"\n ; \"24717674860585372478964575915011580548457995997758548284742988139987280611508\"\n ; \"28526106831601024593647394922551831336459814654587212090704645596629587939482\"\n |]\n ; [| \"11124237076008500471717934253870630742394346079041199265139475769025505862924\"\n ; \"5603568104404435184153167261671260274794550222989896759977234085169877356121\"\n ; \"18631968134615245163535085925543871536654560418979608277352837363265788104887\"\n |]\n ; [| \"25622000111684154876169657771818113353862466658383499382458602104118482932612\"\n ; \"14685553097248008037900441153689553464954749573708220558483151708440673116626\"\n ; \"22638290793036874494380252722781129323329912946279958525645948986012903271588\"\n |]\n ; [| \"26722642316240919944771155748582214575762636956156192045531407557947082330441\"\n ; \"11688527178001319047781582359974030014986749568962572618484185726534538143302\"\n ; \"4132435099492261681531450855031935115318187070155419444963918466294918478458\"\n |]\n ; [| \"20141284225901340938890656022639520931541470876509036146369749046098483015757\"\n ; \"18736332138502980964445308743240819782522235173987082303305443804684531454297\"\n ; \"17600693717098925665126422004940106422694608593016843967562670357150381420609\"\n |]\n ; [| \"18592614129146387690177360441516834331069369945676621261719641293117078327702\"\n ; \"14150577074637411884886261168762693600439005064514241836521926118301097417857\"\n ; \"19031036144447273288422615508693769842934451415657310442034112526338125336308\"\n |]\n ; [| \"26053352781064856963576604784372156952426155549559043326273302769112379165473\"\n ; \"12778639913079427028917330759671637587295979742641290726186546285252525246028\"\n ; \"21084419118692958743436020036593002996130380427307664962379311458126599853734\"\n |]\n ; [| \"1683679732388236007430336774551658766186300637910023597309960010871812663155\"\n ; \"382382265518823882035704612421171594350637534457994341641249505478238999843\"\n ; \"24103231983573822934379730503341131278940831646017600293219010706164863268100\"\n |]\n ; [| \"15002924105159692538984514753644972208898096660405454273558411866368262628713\"\n ; \"8060462184755100984999826027229470284760371993470314636251170461776357079944\"\n ; \"8014397154910879842052615519912717212158245202057892272449783600873015574114\"\n |]\n ; [| \"22515836383808274667935072370173638116426359208031587416631515348588332802165\"\n ; \"16360177906204352406408982804994067585455569983797470664902705838290946655225\"\n ; \"7377024122149545148833892203521810447795322854651603924615290711324827954389\"\n |]\n ; [| \"13822535231889686674929431810384661533456403404275348094834293881078653521828\"\n ; \"11336050547636194564207457615233402475265718541062192408495224405268258092008\"\n ; \"18805821644425041501933345241847488386094077373308766699152348641373866215637\"\n |]\n ; [| \"2953706678908410496027875422038498650868917425939787828661796632154883847146\"\n ; \"22240918382283561059183778204822808538520952332636130676150942209160161480801\"\n ; \"16015663662903953014672458804500981049100146349056166187951058089247981862386\"\n |]\n ; [| \"24566120104055916417636960820360051385362045582201684271866443305615866009754\"\n ; \"15228716568582234525417425530930303055506743342549413293218302255768537007353\"\n ; \"28426124059260498940560550539619538039187481771001333967681038135790962915359\"\n |]\n ; [| \"12599554983931780658667521993267051645893868162155451498896637831795673118184\"\n ; \"1743852770826535536371230785504182299307419480962231494027537273484933148311\"\n ; \"16732518316750597282164750160114357349321948404345032126728303794088049194652\"\n |]\n ; [| \"2939281672959978006600800750725734354669446788664764296199685579097815688131\"\n ; \"556549314727718724918645466738763616425350766385166232734551188399043650782\"\n ; \"6329117812888271765311270770521948075037705083688439409207121873030159665123\"\n |]\n ; [| \"6923365867589651412567397268415595797793475737512742162240319715473926481537\"\n ; \"4709424083348196884624344278997759837872647743148178850362091985071988205427\"\n ; \"1605876544033197953000953983514955993933721338350067171290806459066306025695\"\n |]\n ; [| \"4856902810419335425286300966705023110125381957049978608074194350995662024158\"\n ; \"20115199687715104656653685599631056012389662876070860842940278390288575808663\"\n ; \"22603228560902176600736298140950778622069342058615699936072284883863656072632\"\n |]\n ; [| \"24638889469288846994071707357580162402582890839221549302411376340642923220642\"\n ; \"8913206227935260631493024400945766094870661822141101533706907528294845461904\"\n ; \"8927637538483897027107933030206270470499387407187148996083180177802476521625\"\n |]\n ; [| \"25384650098348911768966273053118959028169194481031323865282329732266030144680\"\n ; \"8576715726771771074868969966299138879569870568699811773298590613391459414307\"\n ; \"3736564798057387316276742408343458912069444888643530254776791689428332583857\"\n |]\n ; [| \"20271224536548381827255516591952574401260411805623699585521321246109241454930\"\n ; \"22919819358488746629260266084595897095209320929848482502446393294056491878897\"\n ; \"25806583473442384033721287178211835499298441266111076622895704944892288698730\"\n |]\n ; [| \"11271425654462192981130104009501267954567715499141722773571838183810298369617\"\n ; \"11963379853558729949243781995772428902494203393999693908696977832618218983729\"\n ; \"13559702535330349895320048426685665280396765028909072427284399240094315358267\"\n |]\n ; [| \"27798947305954309531282132451491992692211979630877274468503798794516296093624\"\n ; \"10139836872400883770038180190686397055576624900289129633646571009821193103303\"\n ; \"1681175063131614831383428140062517416675656042319902366945851342455320095975\"\n |]\n ; [| \"762311789472828450694939050895584869062612821719579283252590387322583966709\"\n ; \"2491291459395889912950418486840554679531585085810901240245257580168300654138\"\n ; \"26335391344920052134408519665978324228030775533115901754595026922650621387203\"\n |]\n ; [| \"5213934155193667555020919712276789476025967849892310766358967009263904788906\"\n ; \"21596654192879006807545262299640391626541355389417053174982949135914632601259\"\n ; \"11543651420409105093285035822258612547933041509768934342943688172902948155496\"\n |]\n ; [| \"6912476548173319038280387824458412456324099644037049670165470126637201776352\"\n ; \"1249979215389391088361432819941458017849901973474233553675756693352168310261\"\n ; \"8800672549391869855287240050462700541180857572619168816793782094195159154680\"\n |]\n ; [| \"28839355932304714762685479310377995008738258609935766418698284661589499598024\"\n ; \"9159710460329873378525040285653524567247412401936807205880030247592503719192\"\n ; \"3169998943567105341123452675041701435607857255203848874399754618805253622740\"\n |]\n ; [| \"10847531416223195148660243132827532434469902981120107367281282638460589851312\"\n ; \"14278009698362110794389980561773702824351567830428544578500093225142170712282\"\n ; \"9939277074183953713358210481928994846174442435889738896177490616666695764405\"\n |]\n ; [| \"326943879771829400219165757090427396897467323936588117324383366036029433704\"\n ; \"9374630771131918886890707351323606275428692663736893032376887751531034826056\"\n ; \"11290359581308816011059133790190691320815711617432693226101285885253555535565\"\n |]\n ; [| \"3911773409691474638225302262361438181771774863685935030974147227178932759469\"\n ; \"22956796290890941726039085400420127418179229593189943764136263359967499205095\"\n ; \"24905285680262095209614295868376139501135921243025528029309869104981722146091\"\n |]\n ; [| \"15396187849300264600949181619153171915541270808841426006223982193824166071313\"\n ; \"2021103552199756934225861737484570471349644013573281450873950919842892776230\"\n ; \"27806074863915516268783086994108941110298172438899852542592001290302316983529\"\n |]\n ; [| \"20850985044745265985587285429983550433472508184202273658904387230312500935146\"\n ; \"26750188037261381177305438051189173436844269300804365655670910061723402311840\"\n ; \"5346322587722845563528031827169305184007234875695836707960307122364690080342\"\n |]\n ; [| \"6220486513127683592919002338026088751244535283268014603675952476125549409312\"\n ; \"19903676557766566961511712707831152869695369024367352451363145661501930906935\"\n ; \"1180890285168209978184781715739655933965222804468162152537914819015316336929\"\n |]\n ; [| \"14777748415006576804127517907788573988371775407557947805900937323975909847953\"\n ; \"20105710741166769379631189443035554033451548978342191459802351018727518338375\"\n ; \"15000279473920339785489843141790752670514139742561441953224274301751356279088\"\n |]\n ; [| \"10845580737423146858413611539996656798831260499192914333052323948287095325896\"\n ; \"9807299453661141796892511560669448305233135023678812710641622817525465476789\"\n ; \"18820070346872194506701007873416449730211513161354530152730232231128055179020\"\n |]\n ; [| \"21552635109132824636995550194415349978714050563816356406378271654768042443914\"\n ; \"424252812084212000584148587569013716105926976846895922827871912164530554017\"\n ; \"19731111636912344832419806270898792823432039785853920997930198140374517037138\"\n |]\n ; [| \"22034227457855960657032112217714947497269347815575055932350706059498866808825\"\n ; \"28900549436482563321706115220019073654618056963014478327301367425569435393025\"\n ; \"9690323567346977726143631917040896368566497117131585170975102457752911385070\"\n |]\n ; [| \"24901777589153809722090856106322215040853844303892027345081846927117655474799\"\n ; \"24618629228062397341252905498799061176053328430774401516486784312004562743191\"\n ; \"28607940154394052066154355049458241016994677703128094815451893517962352487603\"\n |]\n ; [| \"28028628276659162325922057320540093432599391103119722511477699756313028345898\"\n ; \"22855357183685501398606162033830514721290735737703014103574096507164859341813\"\n ; \"27834367819357692909285882545810100377631199500915361384737671966983146025809\"\n |]\n ; [| \"1152586797671427538966496719385915934546059520122802470413322678492958894682\"\n ; \"508384107034063705486611598325755112413731704833369868231768120077490444630\"\n ; \"19300657361561951607131776332671479212098250434693263049514294780805629653473\"\n |]\n ; [| \"15470960985350481400842167015023775571355492800121582793999502093397427698383\"\n ; \"17720942074350206208330220964590971549266016335665304491607989853024314401251\"\n ; \"28851134571887486837044103758388058466256575668947796957305978438699899353287\"\n |]\n ; [| \"3578785053164294612963526112344478663211208096085744338409755465254754875674\"\n ; \"21326437066553963598520552760114586864776638322466352011871692222662384645363\"\n ; \"13429745934270095487255860144847939327740721270623398376981782305947706095670\"\n |]\n ; [| \"26319050026331552836426774369067652650059182744902567571224496539143745005789\"\n ; \"1078263435617676875695007120605477838039487913270059992176509301150569425787\"\n ; \"20512958822951485066323868584206248027312484777844371817239233161574729401619\"\n |]\n ; [| \"3439862210936907243622471091733755342416004198449084092526552267425888891334\"\n ; \"26344024615038835357968358502500389300221110985359344438627145422128854936010\"\n ; \"4407509671483019180323111663733989542669030294423331160640503012574051046463\"\n |]\n ; [| \"23686502687109748462558238297713453205336655550865311005650407347470798706276\"\n ; \"20935865617522634258880604534809753050761951325231883554583651243657755177384\"\n ; \"28068466419776916874263313788106583531149883580106732537932576845496874610760\"\n |]\n ; [| \"9340583216031797210406121496934538779821608465213537538754368179509091190496\"\n ; \"8378478185794583011191561708485020796460113225246093188020296866408689405447\"\n ; \"13593729876983630500293152970812869181694169206857373826104652065849275824904\"\n |]\n ; [| \"225582802476164593958918341784756417052231176877435466478201328339339298792\"\n ; \"11190000628324239936372479652026730262762535908110580922398549511844970564726\"\n ; \"14408510109047970600383365920163973974300511112581396474451952115423633760669\"\n |]\n ; [| \"15419712893693617903799150033771605514243986042167614240262941635002474003403\"\n ; \"7731439925760230991749404015249576908754514348048350297750723620909282729431\"\n ; \"19666770682774865023295895307812388197776507921636129891377759111914829255638\"\n |]\n ; [| \"8087212899093356791510655283154899277086785698103236127882829927797366304828\"\n ; \"20433944315277380264641847906582628806193939008300369182185651050982835630279\"\n ; \"19313210645126659866795487832507797079135783289793587088105157706081916299559\"\n |]\n ; [| \"9123328805166387524465533579226697545839760827737590290669661663774141633743\"\n ; \"3879879306261238409785977281757250639343229913301993681022375404219618433235\"\n ; \"9517409716012760917696192179044536803939394129766651220028362590735480122573\"\n |]\n ; [| \"20332463768718929699130730432447025575189976076426482297440430469341755042921\"\n ; \"23053672884236177934514268600149479745125027580775805056144654269680148757624\"\n ; \"25226946353885521968414981773406166683897441042573998588821906686512894266029\"\n |]\n ; [| \"21175609603299698220053961274718080893444373067044100451463712419133495237612\"\n ; \"9553694240553762923597118226736247618469252203348132132110825914961792198835\"\n ; \"17843854580091429191163038608499805869715159461506741160730374911681651289471\"\n |]\n ; [| \"14269966061002750716248007081424385164175906346684599134425437034554624251236\"\n ; \"5362620995145057363259413950799285152609317352806427035690937773014391566299\"\n ; \"4205064533075248547624548681629884406823264917512221686783667975932358100596\"\n |]\n ; [| \"1447928410709031033534935853216514556147486755632766593078722977427728960730\"\n ; \"28245240921931699941506083221177914425757254840948018801597419359119971216733\"\n ; \"26525902932142017663120008236364707593713540498564605735573010501454347937720\"\n |]\n ; [| \"7368631296987951000711115613504553604704592237398914353915901403543114662889\"\n ; \"5554881053965220973295749123586734879290036494602787556161693926447302760390\"\n ; \"24967171202016264042634677694667363841007103245517469364248634966946756557992\"\n |]\n ; [| \"11573826089465863056429265227887713664716641745106347139398991914839486636523\"\n ; \"1937718699958481554769675564975554369566343919737475668546953656937087754563\"\n ; \"11930922536251020493907238369241004043321211518887691790013224522248735046033\"\n |]\n ; [| \"22785017658870359000526032391904855161537701900296638953930381770914415145341\"\n ; \"25976628305796286420142020978093161249350138636110131585936062956834855313329\"\n ; \"16303236307764870561352823146290518191951038219791428310990760657710142544538\"\n |]\n ; [| \"27093108982678491292736852279722292369809241753037402387831341673617292355433\"\n ; \"7240163250117019016769197875995700032806501977645639130984508545602324096827\"\n ; \"22203724525852948038550437387972982668395471437091775649961488356662998264151\"\n |]\n ; [| \"4684246545018636131749425719987566020282183864196151512373949996479685177204\"\n ; \"25146969866420782139590198915491672984778622065064131222228045794185882122026\"\n ; \"27592425452661098730505196328609404774740926022433368462118081059212268546033\"\n |]\n ; [| \"17586009379821990524587867681671154015571782654760878221394286500330572879956\"\n ; \"17466109782412583174035666757463650324907665895615102404350838404505294814861\"\n ; \"6801099680371208186449438911369486272231733437775451500294923992271849771500\"\n |]\n ; [| \"14709234089749348360616371037761032504562743719673952659049173960937006221457\"\n ; \"20550184887334781662092751106487190173000191851604597380877613197870113909079\"\n ; \"28406290890506223928300453112417162962784806964069027890524481548485194752847\"\n |]\n ; [| \"481714770023051785525400834238336329808423276768584726829869103876837700377\"\n ; \"4020991797205864659257764480061098490500855823437474389403990553320209934398\"\n ; \"16337095167623579562847225379575824048052657014596464618336659839371535688692\"\n |]\n ; [| \"23217111278739825984846557926350102803991056777137304871503782411490597852276\"\n ; \"12165535003710678763048152747651928445434323221944097116678948970350369208929\"\n ; \"9488689094750447786105144162385165112898472220919295987197253237633013659895\"\n |]\n ; [| \"15982980312773671675473213613073972898714178082762602910121113887258972139946\"\n ; \"21878657311388335888708327724490657766902944759667044620416025845959804126630\"\n ; \"13675090710467970179628129651886021836957928350486496127049130621993923573755\"\n |]\n ; [| \"20917518447937574010663058701489181063333313587680044759711243380728520685863\"\n ; \"6170213040301483568981693148798365424121650111680781917289361228522864615996\"\n ; \"21775919999815502126259344494851143760329007416636852564546368286124982536695\"\n |]\n ; [| \"24368490522730194755777521472193388991367336341364002103399150275833011922423\"\n ; \"23758037332911549734847840203343330629256629298188143399488142378421247847690\"\n ; \"27571203431800228771338832670745356383939659914478358343820683195821147658740\"\n |]\n ; [| \"13755890941050195595545518932064686480206338615096777475340391971161142758063\"\n ; \"1146646539267290799737842332448542194132747795692489481869657131476583545261\"\n ; \"12804413470423903667943767263817101023115585083457063162343920360142649266798\"\n |]\n ; [| \"14409531300005419187223363160445506887342750079089420367658939335895822993543\"\n ; \"17814204056137953075459933026732902773040596329028927521838357681289997118113\"\n ; \"7817950203232955618618957010364419159456278143380878513604058657652018062980\"\n |]\n ; [| \"25960264684815433578190462022149634694335702464818992353329781703033013233121\"\n ; \"25759640500090985800437893091627346304260382311106694139575298427306966520523\"\n ; \"28367407529609657391892674962602105816261356754665670959257133180337999840539\"\n |]\n ; [| \"14266800571483937742793133924056626153889815742052966634816685646807339508312\"\n ; \"19127339481560024189602206365457486575195002728494501053095019117702139872893\"\n ; \"28519789563308940253093752790854817966629126140155280689836626891738001080737\"\n |]\n ; [| \"6956040341676069594538770374637867923851690699633394576277451833826951657961\"\n ; \"21005839334445364578511922473026653470661503168441639424115223139672665178130\"\n ; \"28315945273881727033707996355494725432549327504432844662583768252508930919892\"\n |]\n ; [| \"23821368050370699560443847027609270446880531147779436118159731211758008434917\"\n ; \"16481474195192864226077436336148187210130651787958956807674920780544075759296\"\n ; \"9201162478838874386717176037702794693750993812982695310231747629926752684935\"\n |]\n ; [| \"28632598467805640977248891280150694716252721359271588938464824193707123356074\"\n ; \"26685464290112784835718410452005685502357915255553654159429733217095134319675\"\n ; \"23238436156616628957271098742219023373736106288667637787431116054734729902810\"\n |]\n ; [| \"11100700451337429910479488290132218019001384186778460632129760648736641453089\"\n ; \"1514360569355020424898405719576361021811778172693203007691280959952152364455\"\n ; \"8340047814157949706510940907075594981467165368035215496966506269014211515161\"\n |]\n ; [| \"2427640653249618892553580189088976454401710146993511837542094625722279344011\"\n ; \"13594733327028460655848011453697829703783521855510653296924838920678502849608\"\n ; \"23299557907058685778984064294190866024328373590131005250950142719507348823505\"\n |]\n ; [| \"16957366136159159628470985738911466666552608209993423872602970163277075193826\"\n ; \"18413473853520613049315131192841305891076833008669861411383562686504219287358\"\n ; \"23006926050889222476128897576830486416666235970076803315213892539278411622015\"\n |]\n ; [| \"9774905316340561579539853883151948424138741303135183297579387042285531085133\"\n ; \"10269962303207382593854468302115992150940915300353510160768219325150644267118\"\n ; \"7959157234270969248940923336563675290410277851870343572948477386731238161393\"\n |]\n ; [| \"16106024964504098503571852149534027928523108637339842287012373190722613251659\"\n ; \"14745173385311451223498911097599033554863252099869795844775385009273683860264\"\n ; \"19937960969760569200449808442711281818884901583558873199752602417155970563987\"\n |]\n ; [| \"3182366146375526747362994559814691338395593175949415378173407263876720083397\"\n ; \"17413302548292738580314411603626834416295685927950587784515273510105438873422\"\n ; \"4889919393105279580426440996922797206571373750340190707744646290242059542853\"\n |]\n ; [| \"12846868702289135169703545726353247801195875942556949295948719366264621666233\"\n ; \"216026894661943610141047365076631027216797294256741428193225490408409896066\"\n ; \"5594507038710796719799954595203002154918429779115131548267228293545608955934\"\n |]\n ; [| \"20683325187150331608421945253309437504612179745536037022444222877738935657188\"\n ; \"17258155199327171857088567149720370973460517702673221805327154937215155098037\"\n ; \"19531451346903375647980488842525266722395393577734760487171780808563121552715\"\n |]\n ; [| \"15001316252470008872398592005036567799341341008679319658354851032874333308382\"\n ; \"3153366364932652911576884248299389708958131128720414599588818761136290661667\"\n ; \"6755239607153943600624506592209826209761618621309160929893160538996653160964\"\n |]\n ; [| \"27386913053417648783169595109305635785586212401824032172587510910095445670008\"\n ; \"13255419335681899162220762381979787288418216927844199356802168847207218078328\"\n ; \"24056932697318807312802542300271008041574260214121915600042800629313367235460\"\n |]\n ; [| \"681706469194140471433006526218256921616949602161281492934799081124952223492\"\n ; \"7859466024237704991714057608591467007441884809553786534483120034131115786526\"\n ; \"16700668341177433681838948975596616692527529309395474903935090736709940070878\"\n |]\n ; [| \"22901316653569929238119228745362176008602504925113946861459962514753719309663\"\n ; \"22640283367220911539563798732800666806616130576227469449706008775827807382817\"\n ; \"19535281588527177916573861327698030605390832518994091195537441015284187660038\"\n |]\n ; [| \"24027911193734335746676746844040947617820732337092851583866178947775548114262\"\n ; \"18133232728995811983770470174587129261332348411742016303225452920487624098342\"\n ; \"5194749654862040835697949936835668263923802179629880492924388865332422989363\"\n |]\n ; [| \"9316005463786577585413113516915677504827184958655839058352363543312786833160\"\n ; \"19044257614252585758763026210126521817485691264322479305708941715087727988354\"\n ; \"24488455675278660807809390650162487037017599485528141481545441190036504950534\"\n |]\n ; [| \"20189530657293446691983795945222508167625355746118650082940427940595276845732\"\n ; \"18164715324891407664606312435855154695754327590709603495801185914278567423821\"\n ; \"3777285533445984127387924239502713396887498568124548831616871789655039173588\"\n |]\n ; [| \"15592830182691848850373386427196961486282012390610273530420460470172877717683\"\n ; \"25760859528166610551872518774575759523111878433095409331041961249196989169616\"\n ; \"24722046352010883056709269730597243888430933191481739010765617998146349934086\"\n |]\n ; [| \"28753571052849887152802307457879116732346031260848508112338593673454875118992\"\n ; \"3001384261845987887110277211273546956213661938635022280612595622904841185681\"\n ; \"14677009419547603678203788843515487352782342288802842850372444676527117589395\"\n |]\n ; [| \"22844611608619408029685336179217843453642421101233912107898751889136663864792\"\n ; \"17906137102637384489732199749359922643081810160900805140716991796711023316200\"\n ; \"586544213343455846993111183121079851951145071960141918284223009850760128570\"\n |]\n ; [| \"10073022737051199071936469142782915912111557650707356761559885949095600793223\"\n ; \"18767707439586621911012683484743285554245197776295242644551355924169214852141\"\n ; \"4119962398253504109413010562733363762918650892359086980174059883847160426733\"\n |]\n ; [| \"22822667561075354253870135521524118501968910357712769905157593725117077725730\"\n ; \"19021134546417697443807407377942768385512805335328886525219419127991328099808\"\n ; \"543520545955418275520704370531208732549254996101593838150191956610790962041\"\n |]\n ; [| \"13465682039988507334664785354077591628283934378748051390584708440723246405022\"\n ; \"14968258475921764664246292128413258686551060309754574320898450232154678954678\"\n ; \"21308271006956028514569991019983954873714018423377636189886404602491045197837\"\n |]\n ; [| \"8144208462590654621513596158704608446866068401332835980335197042714849642337\"\n ; \"20834284501721431645327510539019601687008489803392802952240179181017009408562\"\n ; \"28229089440547774816202807517944174133449953515318622356237408090506536035121\"\n |]\n ; [| \"4701139152778460212311525289989698272661680893554566356761097167593286071097\"\n ; \"1311177055788535572979185179079106285448805711141806719704208925309029338758\"\n ; \"15261537101227695093574937572139198753629872383884947512058428039104133367921\"\n |]\n |]\n }\n\nlet params_Pasta_p_legacy =\n { Params.mds =\n [| [| \"5328350144166205084223774245058198666309664348635459768305312917086056785354\"\n ; \"15214731724107930304595906373487084110291887262136882623959435918484004667388\"\n ; \"22399519358931858664262538157042328690232277435337286643350379269028878354609\"\n |]\n ; [| \"10086628405675314879458652402278736459294354590428582803795166650930540770072\"\n ; \"17127968360683744052278857147989507037142007029142438136689352416106177192235\"\n ; \"14207324749280135281015658576564097509614634975132487654324863824516044294735\"\n |]\n ; [| \"3059104278162906687184746935153057867173086006783171716838577369156969739687\"\n ; \"16755849208683706534025643823697988418063305979108082130624352443958404325985\"\n ; \"16889774624482628108075965871448623911656600744832339664842346756371603433407\"\n |]\n |]\n ; round_constants =\n [| [| \"1346081094044643970582493287085428191977688221215786919106342366360741041016\"\n ; \"10635969173348128974923358283368657934408577270968219574411363948927109531877\"\n ; \"18431955373344919956072236142080066866861234899777299873162413437379924987003\"\n |]\n ; [| \"5797044060651575840084283729791357462720161727701814038830889113712361837236\"\n ; \"931288489507796144596974766082847744938192694315568692730730202141894005205\"\n ; \"13659894470945121760517769979107966886673294523737498361566285362771110125394\"\n |]\n ; [| \"6076231707445968054305995680347976771585015308155855387339303513025362636128\"\n ; \"28822740034050339685362260108484262889265034407340240070058997651710236456303\"\n ; \"23420266473857869790486107029614186913447272961845992963194006142267563993493\"\n |]\n ; [| \"13753917374184785903125509246122783296344288469304898921025291716613575849357\"\n ; \"22396739346703340038555577564698139382745239004673153148674304627904081092826\"\n ; \"13064238335532551154986111986409392866270911640785653458047811526842088084911\"\n |]\n ; [| \"23165923875642452719095776619341762858050322341374771345641255745672274104746\"\n ; \"1876216571769482372914291210815859835162659440705283782713345335434924136736\"\n ; \"25448252060136178247213604035267580231762596830634036926922217427938159849142\"\n |]\n ; [| \"2161875315509206970842862195937323600322108268401381254431163181777726747153\"\n ; \"19159855698625842998331760283165907305622417625829203038229273729196960321630\"\n ; \"24828563875172432296791053766778475681869974948122169083176331088266823626561\"\n |]\n ; [| \"15959479662608710141128458274961057999257961784282074767105536637788386907463\"\n ; \"8006369581283017287449277389162056290714176164680299906116833200510117952858\"\n ; \"18794336794618132129607701188430371953320538976527988886453665523008714542779\"\n |]\n ; [| \"19408271715954593722501381885401160867835377473312521553027032015227895029571\"\n ; \"13654747284005184272412579731446984220568337794941823533879059135026064413631\"\n ; \"14094055032353750931629930778481002727722804310855727808905931659115939920989\"\n |]\n ; [| \"13241818625838429282823260827177433104574315653706102174619924764342778921524\"\n ; \"25709259239494174564705048436260891089407557689981668111890003079561388887725\"\n ; \"26866626910239634723971078462134580196819809568632305020800296809092442642381\"\n |]\n ; [| \"23886826350713085163238005260075062110062681905356997481925492650252417143049\"\n ; \"16853602711255261520713463306790360324679500458440235992292027384928526778856\"\n ; \"18444710386168488194610417945072711530390091945738595259171890487504771614189\"\n |]\n ; [| \"16896789009769903615328691751424474161656500693270070895928499575572871141439\"\n ; \"23842266984616972287898037872537536999393060934879414668030219493005225085992\"\n ; \"24369698563802298585444760814856330583118549706483939267059237951238240608187\"\n |]\n ; [| \"25360195173713628054110426524260405937218170863260484655473435413697869858790\"\n ; \"1486437708678506228822038923353468635394979165769861487132708983207562337116\"\n ; \"18653498960429911228442559598959970807723487073275324556015861725806677047150\"\n |]\n ; [| \"18878179044241268037057256060083772636369783391816038647949347814518015576522\"\n ; \"178715779905629247116805974152863592571182389085419970371289655361443016848\"\n ; \"8381006794425876451998903949255801618132578446062133243427381291481465852184\"\n |]\n ; [| \"4176946262813877719206528849579392120806054050640974718891398605746592169324\"\n ; \"16376345520728802444699629729684297833862527190772376028981704525651968727081\"\n ; \"8399065769082251057361366626601550736334213197703006866551331927128775757919\"\n |]\n ; [| \"15435308585611812393531506745122614542196708285088622615406141986333182280857\"\n ; \"4082259282787276939431186930090898350392871145699460879678141552997816391817\"\n ; \"26348742719959309014730178326877937464605873211235784184917342950648457078699\"\n |]\n ; [| \"9707631711734344681918469569872517425107158187591261754498805460753455298868\"\n ; \"27910768846011709391567916011595957279088224137468948238696800459136335473132\"\n ; \"20407239095656434708569263842372155762970847207558227886302782130015730063802\"\n |]\n ; [| \"22726225412881182965250630589245572283256255052470345984553083359461473893802\"\n ; \"12443967854426795490638709950679156338200426963050610832781263082981525248175\"\n ; \"27102543658848146076219989119639465430524061997280788166887046421706499775415\"\n |]\n ; [| \"14427224233985680214097547669945064793149553513421479297921556194475574770861\"\n ; \"22917454832925781549840198815703114840452733537799472739275668965081704937832\"\n ; \"3455076056123630366063931123762198941796412458154689469887583689725886013901\"\n |]\n ; [| \"4513100023937785913596662867311227004762025658663076805918211014066645403017\"\n ; \"18187619530784075723418065322038024507729605774832001333883311123910954334059\"\n ; \"9447065431426150382325592560406989926365684509675374414068135115024495130938\"\n |]\n ; [| \"3227816098015819796753427754968234889554095489076864339942014527747604603014\"\n ; \"14798316759185072116520458171957899889489461918408669809912344751222514418582\"\n ; \"23013904852315603905843158448056763116188801262838729536210355401378476650033\"\n |]\n ; [| \"20979191509934291452182967564058656088941447895799901211038858159903580333267\"\n ; \"20772973010251235271448378823573767262405703078344288856168565499702414379868\"\n ; \"10105446427739226002497411811738001382334316505480517822035303561899927603685\"\n |]\n ; [| \"11079074761356717003579108002319997196881121172538617046865136940931215263187\"\n ; \"4693927775411489288330326150094711670434597808961717172753867514688725690438\"\n ; \"18581720304902876944842830383273503265470859268712618325357902881821721540119\"\n |]\n ; [| \"3065369948183164725765083504606321683481629263177690053939474679689088169185\"\n ; \"18515622379147081456114962668688706121098539582467584736624699157043365677487\"\n ; \"17563088600719312877716085528177751048248154461245613291986010180187238198006\"\n |]\n ; [| \"26199746176994924146211004840756471702409132230831594954444947705902602287290\"\n ; \"7576136600627345523051497639367002272003104458453478964661395239732811642605\"\n ; \"20058687874612168338994287374025378897088936171250328231848098497610185784281\"\n |]\n ; [| \"16894722532414195606958290526999761110785277556463400588047573469106594850228\"\n ; \"13961730805696859614283621225672002906734926278118993580398533742874863598733\"\n ; \"25256842011135514243352951950573936602906198374305137963222382546140030647211\"\n |]\n ; [| \"18530360047537856737482157200091774590035773602620205695980247565433703032532\"\n ; \"23014819965938599260086897799541446473887833964178378497976832161473586995397\"\n ; \"27911426213258307990762460361663504655967992659180759140364181941291843542489\"\n |]\n ; [| \"1067338118323302017358103178057182291035336430305886255160210378977812067042\"\n ; \"17219092885519007424608854460610388434712113621163885775309496940189894433620\"\n ; \"16432921127615937542183846559291144733339643093361323334499888895135356545408\"\n |]\n ; [| \"28608851042959977114787048070153637607786033079364369200270218128830983558707\"\n ; \"10121629780013165888398831090128011045011860641816380162950736555305748332191\"\n ; \"2348036340843128746981122630521268144839343500596932561106759754644596320722\"\n |]\n ; [| \"16619881370356823200358060093334065394764987467483650323706184068451904156452\"\n ; \"2302436627861989749837563733434625231689351276818486757748445924305258835336\"\n ; \"27514536540953539473280001431110316405453388911725550380123851609652679788049\"\n |]\n ; [| \"9459277727420672604737117687200019308525004979918488827092207438664125039815\"\n ; \"23425670740358068509956137586663046763224562225383386726193078231034380596217\"\n ; \"7641885067011661443791509688937280323563328029517832788240965464798835873658\"\n |]\n ; [| \"9579420382351699601929202663836555665702024548386778299996961509578687980280\"\n ; \"18513671386572584282611234979588379470994484682444053600751415262497237017703\"\n ; \"24923151431234706142737221165378041700050312199585085101919834422744926421604\"\n |]\n ; [| \"21131320841803068139502705966375283830095161079635803028011171241658723560073\"\n ; \"19208476595309656066589572658712717685014329237892885950958199953675225096566\"\n ; \"24023185216737416080949689106968568821656545490748664446389634158498624398204\"\n |]\n ; [| \"7510552996848634969347937904645640209946785877619890235458182993413526028718\"\n ; \"3694415017252995094553868781762548289196990492336482360084813900937464847638\"\n ; \"9219021070107873028263141554048987416559034633883158827414043929220388719352\"\n |]\n ; [| \"5058327241234443421111591959922712922949620710493120384930391763032694640881\"\n ; \"13148252221647574076185511663661016015859769210867362839817254885265598775418\"\n ; \"15186790492457240277904880519227706403545816456632095870015828239411033220638\"\n |]\n ; [| \"2775942914650502409705888572245750999561427024488403026572311267798009048466\"\n ; \"6277965230841030155341171319927732572492215818164736949144854827643964384893\"\n ; \"24144742149845235561087977558785057713814731737434473021812189457617252043745\"\n |]\n ; [| \"25789129719327437503403457598813971826156253950521984610569937361506914183550\"\n ; \"21500534320778995945845999974779950304491968082325255355181901574840373597824\"\n ; \"17185359848218837018503091932245529880546896465437232425673134558221638601375\"\n |]\n ; [| \"12253896579078110143384981818031883112606762215016553811786428215758384195713\"\n ; \"12956658260778456372481429232709881794962204180363200699121804724437678625542\"\n ; \"3023603786717368708677300377055384474816569333060487675635618249403832078921\"\n |]\n ; [| \"4186492855716808019562789862833898284927736051002588766326482010810259565130\"\n ; \"4263939782228419774639068267872291539552889472311225829898746091327730032923\"\n ; \"24068843626280451423530509388397151179174104901782990365720205643492047328816\"\n |]\n ; [| \"14564937827374621319716285527475223392664010281568256859627186463065876537730\"\n ; \"28367596550218705971881480694115935470211319172596432472834880507822452927283\"\n ; \"28712267437482356021504544448225827500268648754270274754623969882031853409874\"\n |]\n ; [| \"4542596163006916397403529184431773692747461300288194722982487051249951403191\"\n ; \"2530461821259252672899452671728393208543894014761816288817584587718369998371\"\n ; \"12886393063011539390567049190923398676964700147222878509238966758839020897414\"\n |]\n ; [| \"21593897590707514492037699253654745501762191795293908682495110982956631870528\"\n ; \"13233005790593128135480716846773978578237145313006994631606474472023504621256\"\n ; \"21621863098292803642478350494794106282518362577273973885587684567452726939909\"\n |]\n ; [| \"26068620073001644720969640099644251616742620988609091568084348314770436291745\"\n ; \"18248589586787935500122854210401321966459127818593446990365211078521058875685\"\n ; \"21247134484403265289037859533347798468858819117600251067578809852124865474448\"\n |]\n ; [| \"7947383127165915366383984718363902897504221803836013123394785749404572432524\"\n ; \"22173041014621867335598230447618036223462011647696367239478182269973488867154\"\n ; \"16773227734018849308448505860847939069870370055633571816925675705713088305139\"\n |]\n ; [| \"10708707957340055662073314227607620808612686977606082605219160019699644826999\"\n ; \"21249897193797038261479589555720746994050836195265348846222835266344091683000\"\n ; \"12581195059139097540117398803363514148192715293133623516709277290477633379593\"\n |]\n ; [| \"19779599816866992123290302397082614570282926215253589712189610064229996603178\"\n ; \"21749216503901548676985371189807470207364320167486559936962401093285243029177\"\n ; \"17600045923623503357380202389718735904174992978547372448837488832457719009224\"\n |]\n ; [| \"2732872979548118117758016335601225525660858727422778256671975055129965858636\"\n ; \"13703031005128062046175331918702218558750713240446179585947851411173844703597\"\n ; \"28447710105386636841938034820015573492556750872924193415447818187228356409281\"\n |]\n ; [| \"28539960355005748517007309210788803416171161412204526246799800716567376494244\"\n ; \"21329318452221893900731030722137844458345358926323127858742388587761302609863\"\n ; \"28135302149599894709369178097439582767613940517471323224020113411362601191873\"\n |]\n ; [| \"24980774120400248734054527936006392540889095705961960837980443629260392758683\"\n ; \"20339911045808632098936066397942175169549806052128535543540543556255197716643\"\n ; \"7929293103930252545581851978492699598413941396422930641071359388697302362494\"\n |]\n ; [| \"8911092207145893152276662096451247820054843777071569723455408545101628926203\"\n ; \"19648860643145256523615441075182036100116634560394529500146405733687718224516\"\n ; \"14635387208623683806428528837466762532853903031263830054986064902455379735903\"\n |]\n ; [| \"11555212214346132926966321609673228184079851030522218543981385635403167028692\"\n ; \"20896918157639814425520058178561910811657326967880217845710779511927814874973\"\n ; \"4650158165912007049140499755153804318686705949436165235742106170124284287326\"\n |]\n ; [| \"13880660273492757167295696447853232191657893303250187467329180558670697369810\"\n ; \"8043529172463774320604378774840863923445982272478964686447801046272917236836\"\n ; \"2134399296482715903442913099374581981696436050603410080564843555725771329441\"\n |]\n ; [| \"27320952903412641133501507962185246982787769547770982814240701526492601978122\"\n ; \"23417491374379751329394424924400186404791519133465537872457405970098902747611\"\n ; \"17612427354278346772575179176139417348059847375297761006336024476146551185903\"\n |]\n ; [| \"10710998507064742997612080847223278109404482930427999113323732519626499166548\"\n ; \"14958094513415797513745395709487730603918953350067504982704138489305723550923\"\n ; \"24096319595904213497633343966229498735553590589105811393277073274927955202995\"\n |]\n ; [| \"17983724131200292654039765185049138356840415443160477259330748730019147254309\"\n ; \"17598096800487588874709548646068838880468456205252324677357706597166777506441\"\n ; \"27420647821110229619898200875848631488422182349567475956209153112306555222281\"\n |]\n ; [| \"448538544835457571662601142415301047108854812427100562339376187510452313026\"\n ; \"23494184556634922103535803143214434479598067155171780264810485708203176455201\"\n ; \"22626342941879801989161990529511235538216563009907378573817996229389756621777\"\n |]\n ; [| \"26128268137723417163973860961686381960826033145738852158792607959175787222856\"\n ; \"20225791828042873305317281581105429726352058325970107209484198122707862156597\"\n ; \"7538871133759632802857159609785118198934349221046986784429069814655215585732\"\n |]\n ; [| \"26184554861259642274153262777073624024579929401668865520166966302070394487366\"\n ; \"28755259264665180745537307265993667261709206143628938749669440804401623257679\"\n ; \"11896066093033549470312328497237649508068258723531931099214795928200015717321\"\n |]\n ; [| \"21657721599978732693249012287058163532690942515202465984736373311077240614059\"\n ; \"9214914097169852704753116653702415951907628005986883140609006971322091003693\"\n ; \"18710111680849814325169297240208687402588261569152088592693815711857504371037\"\n |]\n ; [| \"6813635166770764528979084175325709935892248249948967889926276426090222296643\"\n ; \"20546585456429436268067726231902751119458200511988152296570567167520382569278\"\n ; \"20087466019194902429054761607398988292568594301671509779549344754172952693871\"\n |]\n ; [| \"28185105286740691904534067831357491310995891986363455251895371651360605333143\"\n ; \"10108348212894231193041286244259038275269464277821588425688314560368589986063\"\n ; \"11433633215392393209829215018579238412423821563056156785641278458497271271546\"\n |]\n ; [| \"27870881917195016999862550657996865268956893566432995492427618003637597051321\"\n ; \"102309803677783876701097881491240456320211833502658383473112057006867019389\"\n ; \"22844040227595875612525628393174357057929113317578127744718774517498324646590\"\n |]\n ; [| \"18364790233947478619325319418813215212267974311771564959136180502266118026133\"\n ; \"2480624341921718230432383518425561514824501138863702825916674641657321180841\"\n ; \"16778939567530361665956758171503829349658551798564323167725356065198936433124\"\n |]\n ; [| \"11947564511486966895926950599696532964589539443187518177489990556481125699966\"\n ; \"3133187646540385483015602955087323554103587039123577645562801570574691666057\"\n ; \"27704797101265438206569218421707753788081674727344603874614391656565567951541\"\n |]\n ; [| \"13001484695584753475562184349533365512515447041450030471627087395341039487710\"\n ; \"477322000667279478600757543806155989948171541982639893984064422067850617496\"\n ; \"13913755821658634147813329813115566967428755223601185963529801459396673113438\"\n |]\n ; [| \"16621869429023470107454028095846067937827722393398508604914831452950874033411\"\n ; \"21755744236927410239079501831014076529931327263341620300431356747367343619046\"\n ; \"26538666591151124505694487799121414506088199961481579132019627484065014831180\"\n |]\n ; [| \"3066480818457008068617042549071052338581291837882909165666223566402713429090\"\n ; \"16182268213934119294035309949459684472027705439038023775276926916166831108357\"\n ; \"28907604876608422892474268478706783033050951245339691569015166507728369585190\"\n |]\n ; [| \"27973960109508292680965426133498827831691369851701664449575719912259359998113\"\n ; \"1456924360278399121996742356757866616312146358469991014696110099534285524446\"\n ; \"8234248752911525485438611255163504976087091103090603316695312869292347668495\"\n |]\n ; [| \"8716078950082339630026654067608811496722305720644485560320987802533380421009\"\n ; \"19016744645809919602099479306503354923553336014593353020688463619133130053825\"\n ; \"24379650661051444982012238084495990858827340608012118841005379796362233056432\"\n |]\n ; [| \"2245379544097631382062919677963998259142792890502492881341386639439507471783\"\n ; \"28788137434161061988371619554419440748189388934884757179010092973102292086583\"\n ; \"7187000185648741287953633167647835668543536354944774631102766873251849991238\"\n |]\n ; [| \"18319349500538500800225762827448369057030532278398270164660609327776487168142\"\n ; \"2622932985948021877314529887962683530522545893985767148345336304947201715671\"\n ; \"13805188629797792210337544360632964855143280581052079479249966961215582531026\"\n |]\n ; [| \"27457600993464082637917106210690168172469473943609357897393615707457194410878\"\n ; \"15448646156961779103834447043970817898237835202826003934642165760908058355399\"\n ; \"9396792545729486882231669677795667529746274932273033601723318032992363022062\"\n |]\n ; [| \"9927877141952679457141759789181418464292082444806533413864151258248124544859\"\n ; \"23827901395971835838179844085051957393677906360196119690926757794561937573142\"\n ; \"3273544693673216914876067527455588276979859627093391584406340272737391174619\"\n |]\n ; [| \"19571510438350300564152393820251652609646082150148656806391655428002614034315\"\n ; \"4458840243585913642400750597703353770666314833058197517675446022682775625834\"\n ; \"6452218213610300363069953741424106105609715382419342511693148495219793324457\"\n |]\n ; [| \"14558167930891460678441266912176752652821641543245953113671886345167213541771\"\n ; \"10650967986920075561478528461783351160938460620955779955379459848889204404950\"\n ; \"19990009778942542934049216419052172134625404062770188357110708518621145688588\"\n |]\n ; [| \"26855242974447190235826233682457047761532515293146087151296725996543442567035\"\n ; \"22785340043356532865086769889360674409753343398766563441587096485751538658065\"\n ; \"28603049427449348335651629195385434188071937908693764500052489540779792538285\"\n |]\n ; [| \"20545812864989828913452616721240947168977365844984763819184465128164378967167\"\n ; \"23234068381345797209897730226956922073109641728569353961504167817770340037954\"\n ; \"26031714567641615877877111172701145299483019910006153132858512509897185854695\"\n |]\n ; [| \"9512221744061419790435674197238913998387834650389922233458121639503195504983\"\n ; \"12587458000103271975978240683793268604398305885278203470492658961734100340536\"\n ; \"9670291694005369437277651504604785512303147991710650505302465204429311229197\"\n |]\n ; [| \"26995526763045548800439747262386290359229145489609341602564040676717570935439\"\n ; \"23742712112104280264401317024221734961713400615669958343926511931219510484675\"\n ; \"27931469778579449247589315744656633392873808631802461175539563849884447358271\"\n |]\n ; [| \"20669006894143187877081688942720159738269397552445286314270368345994751825389\"\n ; \"26891772301075275370472640177651637211280740381619976926886106618375467277414\"\n ; \"28387986011980449959047232529988203397251084614417760995257355718700961696092\"\n |]\n ; [| \"6579105010484741592730389416372694666279917604793318157514380025250233913402\"\n ; \"11007035767869292700964744408562802781669930023548892567535397874932420229930\"\n ; \"981148366863906885900456473323410468923514528856216824044152942069412627408\"\n |]\n ; [| \"22213671088722307302576907504985884923571642958053627659840326928319445671280\"\n ; \"1318836216310789598614608105109389429335273432455224127576823891011367206122\"\n ; \"25586582796990779718352441955439394949194222626688223867952982491529809559257\"\n |]\n ; [| \"4923739488579452777913681531125585976446366144127161879759262506690369040090\"\n ; \"23505612338866210737103599484620591026802005128655081877133994175016351514827\"\n ; \"323887003859465324514901860965142186539600668250760639664361851354147799637\"\n |]\n ; [| \"10198923064967306784017949469108033682156920551672348936591491217255268794658\"\n ; \"9593680688139131432883442351722730169325112619984238956948153423155998917175\"\n ; \"27027988263960602112273050725720071355535922812577299127302015348825197871870\"\n |]\n ; [| \"14419883951157390867695097127684346981136020111885301573583640959136319507752\"\n ; \"5104414988075833278683649298543440897371415916271358703850262680431809374355\"\n ; \"24739655595299332818980677669648719986462429574612913501586844601377825836782\"\n |]\n ; [| \"28522818684103966731129743408029731246564480741348128436668680764518115102581\"\n ; \"21520350704208288978690888796633940487888044365108767319141211249242880355961\"\n ; \"17391005598311948834360476853940353239444383292422171321575043660157438608537\"\n |]\n ; [| \"15367833944125677011173327826570204350687925236257190051755087781855930646142\"\n ; \"21715073802090413714601069529558707101797361591183718695054701329871284436172\"\n ; \"8994093285353831008525761670339342200997965950202092028313103110478252647618\"\n |]\n ; [| \"8370824693889782161629525898408725452177580012023459750897244954935682978671\"\n ; \"16123253540853556024347150096993154278773652905830608614979368087152152043083\"\n ; \"3535380953353495025888433493640531836449699255364366295870140701379497967423\"\n |]\n ; [| \"6954518484798178646508803478426114267143074508396663899281411171704702743829\"\n ; \"28903134801897070276701950388422104654018369750191967384271618837091859516942\"\n ; \"20872505363530172448468374920196608937030884647150175861507911076568784054834\"\n |]\n ; [| \"6902861581703501105786795670676641959401710346423594578401934671029571262513\"\n ; \"10124161387604183369443890585742198433184078889862870469507328332805848271064\"\n ; \"10488004060799269337071647841224034919633445750252076195310163972966405029030\"\n |]\n ; [| \"507704911991278613147490289466075160618843900088471236546244459176211783848\"\n ; \"7252739745607302667257774481690407709040936359589867974787811552896597703097\"\n ; \"23278073497974004442836030100920157527910770509761505828038443336325476654930\"\n |]\n ; [| \"22766285055433137793164317120096790621982728188995759745859222009100808389090\"\n ; \"23129058299483468195787339200845749049960038336751758017949899311636830205152\"\n ; \"16665333681978951552434356320651834889869437822496200946959897681307959400425\"\n |]\n ; [| \"12145699202182574939376505075528461451757079041659894988784442097333218352048\"\n ; \"26340666275844437932755852805027863696219004039301187587209926587657008948704\"\n ; \"19208771804191839410002226941825269105677187954811130189835856228258013753206\"\n |]\n ; [| \"21957102494792377508237608216278079874536155315851198461024084071231867104453\"\n ; \"6933367436450995525851693784691226222726503560893470094614235356287049091852\"\n ; \"15707767379191450768747057313641112321773921923533732633534831270357733757271\"\n |]\n ; [| \"27661963645951389261638591385668507557739541354225916772550248746235106571003\"\n ; \"19699458096897937575096494582288688995241392471402204995195057374756282223421\"\n ; \"902873385171181344315871113842580653512118892800584003934454469411716098791\"\n |]\n ; [| \"17184835876565576154014372215369798779520343573944211203710896053325717110660\"\n ; \"664657295519303589036289440053175741110032988007278988577620229144220576240\"\n ; \"10803972669668998371638869508774217165881281885838503958226056357738500321396\"\n |]\n ; [| \"2329846733754251453632375727999372856194157027336139087170310553870624325301\"\n ; \"14139944357035048486675740400655356660678187875721949218090128899571575479791\"\n ; \"18368148273419807418427674359327442879484531833435081951870369910704734685351\"\n |]\n ; [| \"10480273665080572189328459165704340191901489646067580012574464138528963201459\"\n ; \"21773636700078124500346009061678153597323236568110076029811348966753228682835\"\n ; \"18184268307211429260956076021417309535471438696101133218049142374847151474905\"\n |]\n ; [| \"25957533025669311312382992376854735734491934602484112256289764602447226406852\"\n ; \"22223261506176684934865714490719116745135417403915426392159449667435294570739\"\n ; \"22937309162832499167063076416585504361695925730111272512450449042837586253575\"\n |]\n ; [| \"16956181785481598286719868503945127919581091625126206673934113115358441284347\"\n ; \"8497782777197814773596870810881707148695901557289856910220737358078100998191\"\n ; \"21135503731586600979470064722475007625236017670426339278983640892218291297054\"\n |]\n ; [| \"17809297343844488723046665739910571149089769215421130894378638450427880983923\"\n ; \"72435395972188389387093550708873189001876361107443937983754878061522372356\"\n ; \"7511239878692099209014947248389283109997289411550315391143819429585903287870\"\n |]\n |]\n }\n\nlet params_Pasta_q_legacy =\n { Params.mds =\n [| [| \"25059545165736646824438510995018528850798284624488112529736697979897721366717\"\n ; \"16698749787253722942243837797889445179074274353678606740096686335476872429399\"\n ; \"8431542578059462988142441820574484670502416261430105626118810753064502454172\"\n |]\n ; [| \"24729854844697760654067608751525498327180690314591492982304918187023029914826\"\n ; \"1121552144213806241339137182024814961508305746462827911242566288860442556748\"\n ; \"13091758359064753420271764138904670126701916846914918026096660522220974412796\"\n |]\n ; [| \"14318325434506839029297004068378670093722923223466359838374948921878384497878\"\n ; \"21049625586117008961018856577112352485632537866388888422067379870460247825481\"\n ; \"11967204246156045515212780049644733421582972293043836026003728262137316485428\"\n |]\n |]\n ; round_constants =\n [| [| \"27823288320934189888335104419667051541440213716337979953029039814477122015803\"\n ; \"7253519329434178666336171171011092435792450637855327869661074429483992798663\"\n ; \"12943190030917713819083161989292505641412002214667543002424543294305586713622\"\n |]\n ; [| \"27652450736585745228854776198724711889399928847227796610514615862285675851603\"\n ; \"14974144387861463358629448488728583756510094143360287299992064027672013096218\"\n ; \"7097911473075039536684392748485048129620058816999734741035507137919094344000\"\n |]\n ; [| \"9833471627477871590542564294396788818371219099618369953520953128833069622998\"\n ; \"1216722705894969315906023467727879380441696627034784137237245320657648994073\"\n ; \"23711484374443627488130462875874481115682053816071105446952037381155017895779\"\n |]\n ; [| \"20334834189812750348389095362218130162301260954195045344340626330588177435942\"\n ; \"4366529093468402654059406041856606540091882399834904947969748538808812090209\"\n ; \"19522556558624240319308906783506879200944684005866343832929046513996276368523\"\n |]\n ; [| \"23468156490044127088707992399042874063294495237928703268006456122691893114531\"\n ; \"10734041842950229608874281327056547473719120183996972794393760960989413485309\"\n ; \"3234488841736382875399536096222344212453291206089588556042783786752950726222\"\n |]\n ; [| \"7306686533350672818132556583061081086083445583634785280645571504913340166178\"\n ; \"10055837153364380487257619433543992440564488619143210451383396316865395141767\"\n ; \"17005554504252596333905431799020688136174578956026736789538843112027911340688\"\n |]\n ; [| \"11088831290647913265184319169987825710158339243590017331996929570375044581141\"\n ; \"18272514567796081346048223631818362002154999137167000861967874931307115963229\"\n ; \"2041522009924764288246767723256644894737485859434724922096489305438150594740\"\n |]\n ; [| \"11154210356751829838084431411705166756691650190195364032751879907682556256563\"\n ; \"23653929191474563116794828027291046485627178938492016942565292972650213420708\"\n ; \"10285757729660670290227890459658768244478343389595417793240783735403842747803\"\n |]\n ; [| \"27122162076320933627388879342386660773804566925381935727677186578594924773004\"\n ; \"25134653885736994960102027470761976149413229279137043556790564613470281817026\"\n ; \"6659993804933127797936877003954612022106867848874586482405999929720922911898\"\n |]\n ; [| \"1999981756946475588545224006048368808065463727746380893415897089701535614681\"\n ; \"117353258519553885966322353309393133659964765643696354970870351531909803419\"\n ; \"6394630448856946333677807337170062255969284635756530106258303122060761829375\"\n |]\n ; [| \"10402812455948335282625861441472459100503153859758204506020258199084032529891\"\n ; \"24521576250845873373537149390654765866957414335470107480004100764170074644129\"\n ; \"28343148273143818383375888384222625178643820136230475659994359540667696060401\"\n |]\n ; [| \"19466274031477176253567256907114468319559962421369951854132011198919308086813\"\n ; \"15950373298313107490097624474333726880960801439930364792944142444680782981647\"\n ; \"17502012461772831993035812876278636151120700925824710547719185259039723973873\"\n |]\n ; [| \"13427943193313984564171438077343446106584745896824089935661921301233540577663\"\n ; \"19169237962582795898123052276700824726897554497737731003794686518711369308701\"\n ; \"9083808098781854981749406088158848274120691731417104666413783119140757689434\"\n |]\n ; [| \"3085572928600572710130215355481483413152463940337003200200686333839836936060\"\n ; \"6423923726405952993270285921266354528708083436156049822651047436988725799335\"\n ; \"11711163607312960445460153090393005414044253191457667104588071606706527083035\"\n |]\n ; [| \"22862764769570580579955370870655020558642400260785510683021349826526091593487\"\n ; \"27106527830212782583531586155197640258773355519954630305727973089302997251797\"\n ; \"16868720082666046473782251283858811018289758418191781142790257643516182531272\"\n |]\n ; [| \"23158332713461282002423665990353034524451940720249144308509697639018478890344\"\n ; \"4196222884247438401050717959999141753538715859111095883718384227804271580571\"\n ; \"22572557742560406175483660351232922626321427879380236408573364865152875751999\"\n |]\n ; [| \"6498384178588263785275487016065720553418371000134613854044334919909896078231\"\n ; \"19713457172464396779910830357144111010125169288012289325852007667562797201617\"\n ; \"9370618609381654599580351346089018265074763897101213494189302119360756555515\"\n |]\n ; [| \"17332110085907729652621872688438506098032926644356340523235380228784153361946\"\n ; \"15828217198541208438489225959666895536847479530801819210983017536719128875310\"\n ; \"22909304389117426005516739639132057953847831090140119017131773808660581359339\"\n |]\n ; [| \"13274846258473860762348270229895556617343668531781906800111616196606379168678\"\n ; \"20563817685937794654177709363835160405142894424010788995801747935877119235477\"\n ; \"20063600011389636949850146896035168067037303328482473908141578341678944583640\"\n |]\n ; [| \"15561372644915625354729031742269409074452750500059702572378336917069173281200\"\n ; \"1198490580487628040011397824278054034135841708228898001350812771879916960859\"\n ; \"18879421345448691096589106007214815329241576402832734110268197859756832871926\"\n |]\n ; [| \"27399632471000964892968952930054846863781961828780329177494048571243833336763\"\n ; \"2834864942083315409826100384502236980961959328095446142898875620023252496233\"\n ; \"4869045848545701242953923765295279010470656159359352534992875895020324731123\"\n |]\n ; [| \"14325690392479768681007652408098324173976655892283539787053225046370602615453\"\n ; \"25414347192966841451685828069955147897403238857128755301675290249558576625379\"\n ; \"16590289516213461810017744664371295027301564689635234008641715363769691252951\"\n |]\n ; [| \"7999784177991937194560403228390571132248134775394758539082341051882961743020\"\n ; \"27627395050531728876502002078316976742781103442109539911472055005902825690089\"\n ; \"18036356111926470640247668504029296840956365668466479796170120459318979414011\"\n |]\n ; [| \"5913242795575813219801658492942666827872903959995896555280069960017119884723\"\n ; \"14937809672911513589131385409454363020800493802245991188388679796557583708641\"\n ; \"3172852326416764473757677332305817213305384800572730229499136253125245597387\"\n |]\n ; [| \"1832396283457909430686926169612235735546922286254241081539828449889942491358\"\n ; \"28715821183944831340251190244581222742951105435037341519427068245935486106710\"\n ; \"14690804016462235339916279821852369558429158839477443587616468985654313024916\"\n |]\n ; [| \"10594946257886875886350188493790544854294225726533811714616959802551003511354\"\n ; \"16258660270470428008977128056439132854218579917105801771424980524100431529141\"\n ; \"14389177900004589865692617486629808338224936524382373991229450083375030187419\"\n |]\n ; [| \"5254897446260226925010930278774739002366094838197608352776711034691419167908\"\n ; \"10017451766970898293191969301037043760556997294605718695671614691099240320486\"\n ; \"10377472495000399544094005473576037833003171018156457133642162749306784348836\"\n |]\n ; [| \"23218136335641731339524766058408447175805302377930780974300993009302336516500\"\n ; \"20191488824991124775021487716004416112776365506510575739204924567600203901269\"\n ; \"110606975331244410915904098772946457859594892267516924942421765736318866617\"\n |]\n ; [| \"23027069668757981664879070455867290821752779218098836684714327441246591774759\"\n ; \"4589247739673767474307973868199446429401684489991453077155492434850787381702\"\n ; \"6379670142720597470858520674745082918596505550095259476677356817872026090713\"\n |]\n ; [| \"19764864476474764903616550282446756103765436833072775572851316648333869235114\"\n ; \"12894898442410371982703732271804085318212494678649934125021268012840299185637\"\n ; \"4894374129066677193060314651654909732906317879933995748486904122303748724381\"\n |]\n ; [| \"9392947448126670174003480248219776361392113047007441983095267747240201787052\"\n ; \"17448004227122961073493138290943872881683504888463872361350949670680638193246\"\n ; \"24898908270148995600292988565336948748670477048995196059344166957302253353468\"\n |]\n ; [| \"17672969484563875329340665269765905710099865885284111146969980578304648998989\"\n ; \"17315183356963381222871645160515357484888194239021894873634846607120433299603\"\n ; \"16657291105770020999163388035414073826686069942847209725990896237129724531623\"\n |]\n ; [| \"20045358898180937726150285529789401521185856403599282370725965114285467221394\"\n ; \"7604720689465762204259558177050824657125765219907087093134275946944476764623\"\n ; \"4946157133141303389791048466320735878774808191447977218588320463643439643617\"\n |]\n ; [| \"16095543778893367554646246146733094380954235388863918230797975064302848608110\"\n ; \"9495028757440948201524349973141898811031260740727574963230822567659024070475\"\n ; \"15652394153551772951410898217296838776100645778717025418259184512269824513281\"\n |]\n ; [| \"22221075851011525495207739030167842998461976982084095286887110082203892655949\"\n ; \"9773505979109619840461605806117798267810157941804844442655531835520967463113\"\n ; \"9699921110253873916726596291176974227884871755181878140734719120429532053002\"\n |]\n ; [| \"17682231260051753498617845281951269726537935653976607531850308842757348601329\"\n ; \"18026887242590310014427209724078991193599958030254077118842503456583403950827\"\n ; \"25015306241717221564050692754953747248185536052663170582824605966511132780487\"\n |]\n ; [| \"16913017783534832741366331557377027835283393598087920619147327295000966841306\"\n ; \"14346687497088016967038616732353182101844963538110413455107565365722012953284\"\n ; \"5306566980905870284116776586767806070957377455264987606648038923624253495328\"\n |]\n ; [| \"1776756375313230649731428479835496304149043878892306245847918259342669070843\"\n ; \"490116546446566363527874936210269421699868025744627465261205141315457929764\"\n ; \"15895862901922909582174688550455317647454688607836801729345729632260371594678\"\n |]\n ; [| \"13688862447353097641921417721564599384304916802983599264426675175604875742315\"\n ; \"24548198092994361104088706233911543485350973671834385909863857501675802878279\"\n ; \"13459479827606540544689621578844182868859283770589890980132135394570347186061\"\n |]\n ; [| \"24044394058320635022361075601656905043313553792325674538366784156913803812196\"\n ; \"13224911244448701263582762940879464967836683002210854167321246073960841644522\"\n ; \"8458040493721843207908979005771386571338972860793346258045061108188537269575\"\n |]\n ; [| \"3373954096140863425424783847439718500809124286660183499962641073452219575239\"\n ; \"20786023834921480994573103385555575391782193954100981434750965529916600088428\"\n ; \"4062313531423140960397881434049476366932415559401603628257162927863296206641\"\n |]\n ; [| \"1898020409546207805320648144920011726191859363441411206281917919526161244598\"\n ; \"24277367400752675228358431727080852820923883244494414698417676920127526770088\"\n ; \"27041649732785968593009926556186278849799597604234485085263424041769060430672\"\n |]\n ; [| \"21584002498671958383320932658470323644925729001241157174062149135688934590153\"\n ; \"296461973635637542200993277788422285516983090690405454296351759221006819546\"\n ; \"8818839967799505500555627771598501831696804919367222237507197660660892665148\"\n |]\n ; [| \"4439337387294703935549667847378420965887876421209156336246561071020526953695\"\n ; \"27771844118085313731256751422668441516968763521122036346441924658635531209834\"\n ; \"7599670163703076794117421319905831310613637703095599713786252660612843368075\"\n |]\n ; [| \"12193036087689296361781682831088176514376474290884092260169857032550680408546\"\n ; \"25791228645469784134598013409595043692878987806412190415747720776255632142972\"\n ; \"8504882545271841062057911639581320453656588156705418395838850434018335784764\"\n |]\n ; [| \"9130894449689099154616722799255778500706692445872833148087121191022987751351\"\n ; \"21553577145491938499114888018915447040714863615699957078888430024590510223125\"\n ; \"8307396866731830889712140446282281226154409273955284908758959517111805068379\"\n |]\n ; [| \"20697895431092576068009892921110410029570860731610412906827921169156559036877\"\n ; \"25847730491997591203980701133953084257949899509409890411883471391399589272255\"\n ; \"27068530132452520868806589188908435601314783511462339379808399629696227108300\"\n |]\n ; [| \"20579165271364650486101631743580639117276566815442383429004130800710012624677\"\n ; \"2049872261441584532266169243588650339607343237488816821021818230059988793881\"\n ; \"5229222520976935575159907831883087156061470447412599430611711892673497144820\"\n |]\n ; [| \"16888076312477210105490768408731364790051105858421097779712165387651960648918\"\n ; \"2063328481371063362698477795877294174447601367525854450572877036817950486588\"\n ; \"9978860706589405700636863259000379424111716695830255414810479786243742448788\"\n |]\n ; [| \"10317246955612741053663756285229154782235034400014758881046851747850823867516\"\n ; \"13593887292763642751523995903547641851467767154363297491262315140569344482619\"\n ; \"23402502496341059894809445627668621422181262255992641144517916256091271283596\"\n |]\n ; [| \"21967434350664893350794692419887682460286669021917537287854750673456386148796\"\n ; \"23353689534149296842880441871386688481067867589772985300786059302345245225322\"\n ; \"23735357311909906399385947858290446886270449558355528121401365099315742122681\"\n |]\n ; [| \"10912898365787795098976682182552503726774830131561177111534481011887568028225\"\n ; \"24870024081013773996332492735582388115312107253015059784314149687041374665561\"\n ; \"14959251092871859358484341584905048546998757007023469906733200814028817787676\"\n |]\n ; [| \"4862971281682736739478329712142805000991054403202074379778464975706269552737\"\n ; \"18880974505260055428677233450169574923539187497744705144686621167223290501713\"\n ; \"15019860251830177408295304948562135143018077531659007557525973719668356977506\"\n |]\n ; [| \"20568371280002005481616540220671990391004159655382801184704914533391923227442\"\n ; \"17618564901060519653065801707062565705965252069071642419351201848751288646311\"\n ; \"6175806441176276214249342720153255252512916129811023844537243081853881530586\"\n |]\n ; [| \"296698681032659410437385638424768886607081580850224832109048866253174706324\"\n ; \"7268871617745116292779237678539517235521185661165310960197803054547440338193\"\n ; \"16341563652551468195688432165785741488638381548308118992703945905571040710551\"\n |]\n ; [| \"20802839862702262365306655858469071118895773474002102559223288884562755221802\"\n ; \"8463358659774659224604995990679067672391550969286021897665237635502349549078\"\n ; \"15978158329915368408793563753006455633333602546915141756185279989524351398011\"\n |]\n ; [| \"17622341778239430423221939745175386197971754657696111634181640277323050526814\"\n ; \"10608335237642480929422693089800206983573202659550442733156493623334131463648\"\n ; \"4030685945296549297325867649675145444613863086399488872024691844215015865404\"\n |]\n ; [| \"13622512335702925704246239293965891829357706731007005465669806728128070589631\"\n ; \"28096860376731134760587904422020552532782566250134663540225061105608367763617\"\n ; \"23408844245917750106421907693053932839460443870282241477420090247810403742130\"\n |]\n ; [| \"1333283643113200911795408607575124847498003548266053936354869116413818233994\"\n ; \"5114627784027951102582115213264649034477290065123683766415035791913182621990\"\n ; \"12764392856508616755454501281162355366590010491252202055937861522683929322726\"\n |]\n ; [| \"17151467035003081822551161487450697402952914914532916714361135117937359660435\"\n ; \"5790806510531167647314677971786602969791369262808321427822737321737295918626\"\n ; \"25402570155872412453028168278079114058150183483929245811506328339445321991585\"\n |]\n ; [| \"12920564330262937347355086382215038686842973035591062422536047377306795551956\"\n ; \"12250718187966551349934722909284957659425918779784022718640942555655844833782\"\n ; \"20895727170003937274470408646745579174029123755980503191289166493378198853753\"\n |]\n ; [| \"15956841763991535793203092153585710767934653432429666292367107371891246878431\"\n ; \"165004921874760145525553135393467831289178931448821175010841518884068397358\"\n ; \"21701359314438421232412634090067127199084976819670003578888860920096628455908\"\n |]\n ; [| \"6848902582754636090737517131578591551788309332465803574486567584842713095075\"\n ; \"9148729239860297908222294166176107790125495380930731971791358581588488088179\"\n ; \"8358777029774639487464736856867300896187008886831215496030522112768313792659\"\n |]\n ; [| \"27763005231503543326388909385720946430141828710795454442053340035715385775564\"\n ; \"22636772741960501900595405662321074335936299276173491651140399382705798268766\"\n ; \"24200783367862580793810376984298862005065285339141826318611417638508272680935\"\n |]\n ; [| \"822600333766772255824054922496304222560196931439044456446485963982870790028\"\n ; \"11620067212793640354075687381092798024341928813664220586751309617921494471627\"\n ; \"25396694389942268941157432367167881033474136344183279866045115614823524486381\"\n |]\n ; [| \"7950044866662305700342331645322097694799649174330586954392082006195652431589\"\n ; \"22840933456350447931596740831047097851905435130998852812846918451453709541072\"\n ; \"5952562873278923355396014494234833112602416727163262543950012068378966526374\"\n |]\n ; [| \"14941744106899001396490468834896552276228477518658489130424851675983796484223\"\n ; \"8411858922787427790040186603365979935733234451728885815156429633351516622170\"\n ; \"25728130512642084604375585079417861667709258338193885601642539891291402554672\"\n |]\n ; [| \"20604517750643336005470932595806868673102682184328905598449933465373164368567\"\n ; \"18692086501272312775058232861104840534405554074751818414995965413576504506898\"\n ; \"5269470419857278770474250796707995245651827289253410681285877302520855951649\"\n |]\n ; [| \"132958317750014592125353639381410869535729112359715476758774573020346177038\"\n ; \"17193272337125758342712697198430394405858515930784181707588441236523237399507\"\n ; \"6907588900146294348775248591028498082882128985613063249028470164033147125714\"\n |]\n ; [| \"16309200565821244573168333253815499203949927814550835828103574182056728678956\"\n ; \"4607702890113363215119270116443817064683508025122288758534057630367234921015\"\n ; \"11237233790658676278102726466515564713414270355327201961157117083230382852243\"\n |]\n ; [| \"10064330808822528140235288193284673078859867025792057686345339813053087817354\"\n ; \"25051392317202122071857024659315208391485135039862063722352057784569902851363\"\n ; \"22126617513529506569359166365810362424423294611767941651490344758258540414004\"\n |]\n ; [| \"12091746476208536681080525048942500448418433204654951972926283776785275935445\"\n ; \"12111265990251598624141275756247422663513559759757319153701374783734518534525\"\n ; \"26739984777421171183341767053331505211465422029143782259686543457935639077074\"\n |]\n ; [| \"7819054201259648899956766259173509994826070622646983709427380262867238635463\"\n ; \"10445115028929965619698941897016402172414044576496139170399391316067978563932\"\n ; \"19684711726373570147937187126430934630002495670017015298886915356480224463252\"\n |]\n ; [| \"11239307846668865409559961011092791606629566617449107300929575297206367273772\"\n ; \"28805033990368921872277896029043745855817246151363711680251631474098318414959\"\n ; \"18401979852581903763050302976527384564541846667710514970197455751949363551773\"\n |]\n ; [| \"28263368266760706140556936890723050350981960590399696453960533699777929937332\"\n ; \"13171701559671490165454061311663500722478022888953080003164558696925706691950\"\n ; \"19602525380638837013300511621093845194121859856160220235414966930348094741920\"\n |]\n ; [| \"25875044639134258735138554352016034131847861924507451443931721478575773042344\"\n ; \"1286919834973261464274310810959674232070230673485764517044208498391267530988\"\n ; \"12782511029953763844753944101233413908378422219581060868637062846684140416599\"\n |]\n ; [| \"13777170936966635591451775007775796682884247670199445877358680218373012583133\"\n ; \"13914069095415962019849305704612514109938496116014955678392598600149568146470\"\n ; \"6783088795558416833900023860884913748051142639172416787734707305655085393583\"\n |]\n ; [| \"23759768419633407428810307098986751935262813445177317925266674188878521655568\"\n ; \"6216329803333944314103957880878676099988045568818271561443283432381325370083\"\n ; \"25114051080902804484727511815467173212803244349938543937989789439460074114186\"\n |]\n ; [| \"1180226883916835404878157801250992605812628262348217873510319284727730147381\"\n ; \"28284648834460517620415684321276302970692148546984768206724059094698247703614\"\n ; \"24033429483804377793699007789045563117176754720883449007735536724064971910209\"\n |]\n ; [| \"24837980504224007072003842463132805986188595503848986775222831487536454430702\"\n ; \"7321472857412311158120212341338101751477713807416898032253162676888996785560\"\n ; \"16969570257066093255532410834694788936815887939867116143226504248562357179280\"\n |]\n ; [| \"4125673734564343532339577642546830393637205447174011175535077670456408467503\"\n ; \"10632713303134500465283168727266716395067246541628032088845987128902453337705\"\n ; \"9574680283229048309682722855094170144602083182060214720561022770315159925050\"\n |]\n ; [| \"25200516884616393326554198239117840577353244771178619578270272915036798525203\"\n ; \"8016037998616729200273828218865709942562955788458067024686069967773623280702\"\n ; \"23152730567726048528634883257060835573481024340136073260056069507023870894846\"\n |]\n ; [| \"4936905020024289826614920724630062129669650361835193562496220267355967500709\"\n ; \"18184641423707818974834811540508053654673520711184768800680158891503991754351\"\n ; \"27444333582924293137279963432375877042954535401580653830648855025913046131946\"\n |]\n ; [| \"19258787990037904339970574900663327047151333605558856194461096727736980981409\"\n ; \"7307247571008211080591958435739460884694126720317257874083215846110062993851\"\n ; \"26746958803361511836036369403239292474668097850167071971132263374551313661859\"\n |]\n ; [| \"2986707284687082908367239099770334052301679778803284796428725648583327571996\"\n ; \"11076872572044729168706875668696902097477024573484865352103135025101837260335\"\n ; \"7676893881767745856368855909105588397337840304590696665395773396488415841368\"\n |]\n ; [| \"8035879860710675293804855837795384803722427367423273349615911494186867635695\"\n ; \"8777228662288028976220651807443998778731851272244712495838227067153229552036\"\n ; \"9404729766074943289512201205781943537326342248324517034957699512018199204738\"\n |]\n ; [| \"28138039971941229743877350137198714871803339371774209928210486168306126282046\"\n ; \"24746372913562546565307551019536112359520027514996722419915199065654026706269\"\n ; \"5992908251399318789048901337027258610373870655662449861810221050890563237785\"\n |]\n ; [| \"8986662495311798908019190514368815106790964767556070538172234209887075670815\"\n ; \"7819511120920480038906806637526904433010099047963872696607543518954984324963\"\n ; \"20040748576462413617236432113139264992338669108015478382493668322296306085726\"\n |]\n ; [| \"12604124251667268108802430657250418818373981324591677149693775791311237018115\"\n ; \"3713446680888938926487722727702881477451007635693922407499275812693082163524\"\n ; \"4729722979346651955109002515433891123630816656581607922377526264122826791278\"\n |]\n ; [| \"16455155466899261355363975391464726179721089911718581260053823330812044805329\"\n ; \"27164824221249686345132567624748537410457840627513096638619870411838704887939\"\n ; \"16276969634012778467682584281076733912813949584479602315250697584070339970173\"\n |]\n ; [| \"25641921087422510763187305803178924090589997867692682422161021888360562111214\"\n ; \"3667017006482520184366983251713265998942338144600409725070021931240855063242\"\n ; \"16624027448839826107498199322162430278228409173124621849582911009734159268523\"\n |]\n ; [| \"26317000137938324098695631123138063604840025944173958478354566632124186905402\"\n ; \"26340841271036888065816939024344358177648115802586515509528813558078622483283\"\n ; \"26760792070192677486356259617078495242352693159824472284838522738202103374517\"\n |]\n ; [| \"12721771512080997403280267277695539784262535121086502864139373913498888705215\"\n ; \"22548741447254480389350118476622153801605101093013811309651936063066499340364\"\n ; \"27978367330497576661463216897542761474015119849207592150731961184044447336019\"\n |]\n ; [| \"25747063373517637067792390107027157627279718780430393414118399515398493230570\"\n ; \"20151199118555759838932276113163555479083735668386566652089241087017456180596\"\n ; \"18879014815739649515414305835536994932451911664341341839193146489857284960764\"\n |]\n ; [| \"3810373645102571961856835110796286023878561472775937446095180271215591973482\"\n ; \"21670724524877659990430014767408914315012249576025971870416576542969889929722\"\n ; \"3915354581322191374887706360194439190056113572215823372708498368264986411752\"\n |]\n ; [| \"25396010083988081390296945409600690498532747776857675039749936403891275914607\"\n ; \"27390501373018759994091671141783422648482925902652559051505224556105818276432\"\n ; \"21943756395113869385673889596972393684048914861116005493936041142864388308640\"\n |]\n ; [| \"21009529429359499435346117020843766611662779822918934812595290904562681460194\"\n ; \"4403095793362209982879649985124453117401775317228756238293170861698283724152\"\n ; \"13402721305808954031052740171341806281977967539270936940650446104784640742956\"\n |]\n ; [| \"27491349623398243944682353258003517841463983130426355707277141054509970413931\"\n ; \"839162295650533705111165213845914661169544698196543148318540951139745338443\"\n ; \"2360031015226134235320333722839592171180466963140089662936226146376372598269\"\n |]\n ; [| \"23187073805281466301515357725635655379740035976872552251192653562569108948332\"\n ; \"13415450340633894897579130593672628357474718745976391717544515771527056769433\"\n ; \"20551598721856083916810924558283736201557848101716997060847530300465710342492\"\n |]\n ; [| \"3672594647865661748928752317746079229095373133257293162774720337138304704736\"\n ; \"28656412123828764424722913154831876184400121058128257557942467880106263931024\"\n ; \"12488798341044520189714771416078903136558391518843419705687775573556817797577\"\n |]\n |]\n }\n\nlet params_Pasta_p_kimchi =\n { Params.mds =\n [| [| \"12035446894107573964500871153637039653510326950134440362813193268448863222019\"\n ; \"25461374787957152039031444204194007219326765802730624564074257060397341542093\"\n ; \"27667907157110496066452777015908813333407980290333709698851344970789663080149\"\n |]\n ; [| \"4491931056866994439025447213644536587424785196363427220456343191847333476930\"\n ; \"14743631939509747387607291926699970421064627808101543132147270746750887019919\"\n ; \"9448400033389617131295304336481030167723486090288313334230651810071857784477\"\n |]\n ; [| \"10525578725509990281643336361904863911009900817790387635342941550657754064843\"\n ; \"27437632000253211280915908546961303399777448677029255413769125486614773776695\"\n ; \"27566319851776897085443681456689352477426926500749993803132851225169606086988\"\n |]\n |]\n ; round_constants =\n [| [| \"21155079691556475130150866428468322463125560312786319980770950159250751855431\"\n ; \"16883442198399350202652499677723930673110172289234921799701652810789093522349\"\n ; \"17030687036425314703519085065002231920937594822150793091243263847382891822670\"\n |]\n ; [| \"25216718237129482752721276445368692059997901880654047883630276346421457427360\"\n ; \"9054264347380455706540423067244764093107767235485930776517975315876127782582\"\n ; \"26439087121446593160953570192891907825526260324480347638727375735543609856888\"\n |]\n ; [| \"15251000790817261169639394496851831733819930596125214313084182526610855787494\"\n ; \"10861916012597714684433535077722887124099023163589869801449218212493070551767\"\n ; \"18597653523270601187312528478986388028263730767495975370566527202946430104139\"\n |]\n ; [| \"15831416454198644276563319006805490049460322229057756462580029181847589006611\"\n ; \"15171856919255965617705854914448645702014039524159471542852132430360867202292\"\n ; \"15488495958879593647482715143904752785889816789652405888927117106448507625751\"\n |]\n ; [| \"19039802679983063488134304670998725949842655199289961967801223969839823940152\"\n ; \"4720101937153217036737330058775388037616286510783561045464678919473230044408\"\n ; \"10226318327254973427513859412126640040910264416718766418164893837597674300190\"\n |]\n ; [| \"20878756131129218406920515859235137275859844638301967889441262030146031838819\"\n ; \"7178475685651744631172532830973371642652029385893667810726019303466125436953\"\n ; \"1996970955918516145107673266490486752153434673064635795711751450164177339618\"\n |]\n ; [| \"15205545916434157464929420145756897321482314798910153575340430817222504672630\"\n ; \"25660296961552699573824264215804279051322332899472350724416657386062327210698\"\n ; \"13842611741937412200312851417353455040950878279339067816479233688850376089318\"\n |]\n ; [| \"1383799642177300432144836486981606294838630135265094078921115713566691160459\"\n ; \"1135532281155277588005319334542025976079676424839948500020664227027300010929\"\n ; \"4384117336930380014868572224801371377488688194169758696438185377724744869360\"\n |]\n ; [| \"21725577575710270071808882335900370909424604447083353471892004026180492193649\"\n ; \"676128913284806802699862508051022306366147359505124346651466289788974059668\"\n ; \"25186611339598418732666781049829183886812651492845008333418424746493100589207\"\n |]\n ; [| \"10402240124664763733060094237696964473609580414190944671778761753887884341073\"\n ; \"11918307118590866200687906627767559273324023585642003803337447146531313172441\"\n ; \"16895677254395661024186292503536662354181715337630376909778003268311296637301\"\n |]\n ; [| \"23818602699032741669874498456696325705498383130221297580399035778119213224810\"\n ; \"4285193711150023248690088154344086684336247475445482883105661485741762600154\"\n ; \"19133204443389422404056150665863951250222934590192266371578950735825153238612\"\n |]\n ; [| \"5515589673266504033533906836494002702866463791762187140099560583198974233395\"\n ; \"11830435563729472715615302060564876527985621376031612798386367965451821182352\"\n ; \"7510711479224915247011074129666445216001563200717943545636462819681638560128\"\n |]\n ; [| \"24694843201907722940091503626731830056550128225297370217610328578733387733444\"\n ; \"27361655066973784653563425664091383058914302579694897188019422193564924110528\"\n ; \"21606788186194534241166833954371013788633495786419718955480491478044413102713\"\n |]\n ; [| \"19934060063390905409309407607814787335159021816537006003398035237707924006757\"\n ; \"8495813630060004961768092461554180468161254914257386012937942498774724649553\"\n ; \"27524960680529762202005330464726908693944660961000958842417927307941561848461\"\n |]\n ; [| \"15178481650950399259757805400615635703086255035073919114667254549690862896985\"\n ; \"16164780354695672259791105197274509251141405713012804937107314962551600380870\"\n ; \"10529167793600778056702353412758954281652843049850979705476598375597148191979\"\n |]\n ; [| \"721141070179074082553302896292167103755384741083338957818644728290501449040\"\n ; \"22044408985956234023934090378372374883099115753118261312473550998188148912041\"\n ; \"27068254103241989852888872162525066148367014691482601147536314217249046186315\"\n |]\n ; [| \"3880429241956357176819112098792744584376727450211873998699580893624868748961\"\n ; \"17387097125522937623262508065966749501583017524609697127088211568136333655623\"\n ; \"6256814421247770895467770393029354017922744712896100913895513234184920631289\"\n |]\n ; [| \"2942627347777337187690939671601251987500285937340386328746818861972711408579\"\n ; \"24031654937764287280548628128490074801809101323243546313826173430897408945397\"\n ; \"14401457902976567713827506689641442844921449636054278900045849050301331732143\"\n |]\n ; [| \"20170632877385406450742199836933900257692624353889848352407590794211839130727\"\n ; \"24056496193857444725324410428861722338174099794084586764867109123681727290181\"\n ; \"11257913009612703357266904349759250619633397075667824800196659858304604714965\"\n |]\n ; [| \"22228158921984425749199071461510152694025757871561406897041788037116931009246\"\n ; \"9152163378317846541430311327336774331416267016980485920222768197583559318682\"\n ; \"13906695403538884432896105059360907560653506400343268230130536740148070289175\"\n |]\n ; [| \"7220714562509721437034241786731185291972496952091254931195414855962344025067\"\n ; \"27608867305903811397208862801981345878179337369367554478205559689592889691927\"\n ; \"13288465747219756218882697408422850918209170830515545272152965967042670763153\"\n |]\n ; [| \"8251343892709140154567051772980662609566359215743613773155065627504813327653\"\n ; \"22035238365102171608166944627493632660244312563934708756134297161332908879090\"\n ; \"13560937766273321037807329177749403409731524715067067740487246745322577571823\"\n |]\n ; [| \"21652518608959234550262559135285358020552897349934571164032339186996805408040\"\n ; \"22479086963324173427634460342145551255011746993910136574926173581069603086891\"\n ; \"13676501958531751140966255121288182631772843001727158043704693838707387130095\"\n |]\n ; [| \"5680310394102577950568930199056707827608275306479994663197187031893244826674\"\n ; \"25125360450906166639190392763071557410047335755341060350879819485506243289998\"\n ; \"22659254028501616785029594492374243581602744364859762239504348429834224676676\"\n |]\n ; [| \"23101411405087512171421838856759448177512679869882987631073569441496722536782\"\n ; \"24149774013240355952057123660656464942409328637280437515964899830988178868108\"\n ; \"5782097512368226173095183217893826020351125522160843964147125728530147423065\"\n |]\n ; [| \"13540762114500083869920564649399977644344247485313990448129838910231204868111\"\n ; \"20421637734328811337527547703833013277831804985438407401987624070721139913982\"\n ; \"7742664118615900772129122541139124149525273579639574972380600206383923500701\"\n |]\n ; [| \"1109643801053963021778418773196543643970146666329661268825691230294798976318\"\n ; \"16580663920817053843121063692728699890952505074386761779275436996241901223840\"\n ; \"14638514680222429058240285918830106208025229459346033470787111294847121792366\"\n |]\n ; [| \"17080385857812672649489217965285727739557573467014392822992021264701563205891\"\n ; \"26176268111736737558502775993925696791974738793095023824029827577569530708665\"\n ; \"4382756253392449071896813428140986330161215829425086284611219278674857536001\"\n |]\n ; [| \"13934033814940585315406666445960471293638427404971553891617533231178815348902\"\n ; \"27054912732979753314774418228399230433963143177662848084045249524271046173121\"\n ; \"28916070403698593376490976676534962592542013020010643734621202484860041243391\"\n |]\n ; [| \"24820015636966360150164458094894587765384135259446295278101998130934963922381\"\n ; \"7969535238488580655870884015145760954416088335296905520306227531221721881868\"\n ; \"7690547696740080985104189563436871930607055124031711216224219523236060212249\"\n |]\n ; [| \"9712576468091272384496248353414290908377825697488757134833205246106605867289\"\n ; \"12148698031438398980683630141370402088785182722473169207262735228500190477924\"\n ; \"14359657643133476969781351728574842164124292705609900285041476162075031948227\"\n |]\n ; [| \"23563839965372067275137992801035780013422228997724286060975035719045352435470\"\n ; \"4184634822776323233231956802962638484057536837393405750680645555481330909086\"\n ; \"16249511905185772125762038789038193114431085603985079639889795722501216492487\"\n |]\n ; [| \"11001863048692031559800673473526311616702863826063550559568315794438941516621\"\n ; \"4702354107983530219070178410740869035350641284373933887080161024348425080464\"\n ; \"23751680507533064238793742311430343910720206725883441625894258483004979501613\"\n |]\n ; [| \"28670526516158451470169873496541739545860177757793329093045522432279094518766\"\n ; \"3568312993091537758218792253361873752799472566055209125947589819564395417072\"\n ; \"1819755756343439646550062754332039103654718693246396323207323333948654200950\"\n |]\n ; [| \"5372129954699791301953948907349887257752247843844511069896766784624930478273\"\n ; \"17512156688034945920605615850550150476471921176481039715733979181538491476080\"\n ; \"25777105342317622165159064911913148785971147228777677435200128966844208883059\"\n |]\n ; [| \"25350392006158741749134238306326265756085455157012701586003300872637887157982\"\n ; \"20096724945283767296886159120145376967480397366990493578897615204296873954844\"\n ; \"8063283381910110762785892100479219642751540456251198202214433355775540036851\"\n |]\n ; [| \"4393613870462297385565277757207010824900723217720226130342463666351557475823\"\n ; \"9874972555132910032057499689351411450892722671352476280351715757363137891038\"\n ; \"23590926474329902351439438151596866311245682682435235170001347511997242904868\"\n |]\n ; [| \"17723373371137275859467518615551278584842947963894791032296774955869958211070\"\n ; \"2350345015303336966039836492267992193191479606566494799781846958620636621159\"\n ; \"27755207882790211140683010581856487965587066971982625511152297537534623405016\"\n |]\n ; [| \"6584607987789185408123601849106260907671314994378225066806060862710814193906\"\n ; \"609759108847171587253578490536519506369136135254150754300671591987320319770\"\n ; \"28435187585965602110074342250910608316032945187476441868666714022529803033083\"\n |]\n ; [| \"16016664911651770663938916450245705908287192964254704641717751103464322455303\"\n ; \"17551273293154696089066968171579395800922204266630874071186322718903959339163\"\n ; \"20414195497994754529479032467015716938594722029047207834858832838081413050198\"\n |]\n ; [| \"19773307918850685463180290966774465805537520595602496529624568184993487593855\"\n ; \"24598603838812162820757838364185126333280131847747737533989799467867231166980\"\n ; \"11040972566103463398651864390163813377135738019556270484707889323659789290225\"\n |]\n ; [| \"5189242080957784038860188184443287562488963023922086723850863987437818393811\"\n ; \"1435203288979376557721239239445613396009633263160237764653161500252258220144\"\n ; \"13066591163578079667911016543985168493088721636164837520689376346534152547210\"\n |]\n ; [| \"17345901407013599418148210465150865782628422047458024807490502489711252831342\"\n ; \"22139633362249671900128029132387275539363684188353969065288495002671733200348\"\n ; \"1061056418502836172283188490483332922126033656372467737207927075184389487061\"\n |]\n ; [| \"10241738906190857416046229928455551829189196941239601756375665129874835232299\"\n ; \"27808033332417845112292408673209999320983657696373938259351951416571545364415\"\n ; \"18820154989873674261497645724903918046694142479240549687085662625471577737140\"\n |]\n ; [| \"7983688435214640842673294735439196010654951226956101271763849527529940619307\"\n ; \"17067928657801807648925755556866676899145460770352731818062909643149568271566\"\n ; \"24472070825156236829515738091791182856425635433388202153358580534810244942762\"\n |]\n ; [| \"25752201169361795911258625731016717414310986450004737514595241038036936283227\"\n ; \"26041505376284666160132119888949817249574689146924196064963008712979256107535\"\n ; \"23977050489096115210391718599021827780049209314283111721864956071820102846008\"\n |]\n ; [| \"26678257097278788410676026718736087312816016749016738933942134600725962413805\"\n ; \"10480026985951498884090911619636977502506079971893083605102044931823547311729\"\n ; \"21126631300593007055117122830961273871167754554670317425822083333557535463396\"\n |]\n ; [| \"1564862894215434177641156287699106659379648851457681469848362532131406827573\"\n ; \"13247162472821152334486419054854847522301612781818744556576865965657773174584\"\n ; \"8673615954922496961704442777870253767001276027366984739283715623634850885984\"\n |]\n ; [| \"2794525076937490807476666942602262298677291735723129868457629508555429470085\"\n ; \"4656175953888995612264371467596648522808911819700660048695373348629527757049\"\n ; \"23221574237857660318443567292601561932489621919104226163978909845174616477329\"\n |]\n ; [| \"1878392460078272317716114458784636517603142716091316893054365153068227117145\"\n ; \"2370412714505757731457251173604396662292063533194555369091306667486647634097\"\n ; \"17409784861870189930766639925394191888667317762328427589153989811980152373276\"\n |]\n ; [| \"25869136641898166514111941708608048269584233242773814014385564101168774293194\"\n ; \"11361209360311194794795494027949518465383235799633128250259863567683341091323\"\n ; \"14913258820718821235077379851098720071902170702113538811112331615559409988569\"\n |]\n ; [| \"12957012022018304419868287033513141736995211906682903915897515954290678373899\"\n ; \"17128889547450684566010972445328859295804027707361763477802050112063630550300\"\n ; \"23329219085372232771288306767242735245018143857623151155581182779769305489903\"\n |]\n ; [| \"1607741027962933685476527275858938699728586794398382348454736018784568853937\"\n ; \"2611953825405141009309433982109911976923326848135736099261873796908057448476\"\n ; \"7372230383134982628913227482618052530364724821976589156840317933676130378411\"\n |]\n ; [| \"20203606758501212620842735123770014952499754751430660463060696990317556818571\"\n ; \"4678361398979174017885631008335559529633853759463947250620930343087749944307\"\n ; \"27176462634198471376002287271754121925750749676999036165457559387195124025594\"\n |]\n ; [| \"6361981813552614697928697527332318530502852015189048838072565811230204474643\"\n ; \"13815234633287489023151647353581705241145927054858922281829444557905946323248\"\n ; \"10888828634279127981352133512429657747610298502219125571406085952954136470354\"\n |]\n |]\n }\n\nlet params_Pasta_q_kimchi =\n { Params.mds =\n [| [| \"28115781186772277486790024060542467295096710153315236019619365740021995624782\"\n ; \"22098002279041163367053200604969603243328318626084412751290336872362628294144\"\n ; \"10518156075882958317589806716220047551309200159506906232124952575033472931386\"\n |]\n ; [| \"8515206633865386306014865142947895502833797732365705727001733785057042819852\"\n ; \"19310731234716792175834594131802557577955166208124819468043130037927500684373\"\n ; \"361439796332338311597104753147071943681730695313819021679602959964518909239\"\n |]\n ; [| \"2193808570710678216879007026210418088296432071066284289131688133644970611483\"\n ; \"1201496953174589855481629688627002262719699487577300614284420648015658009380\"\n ; \"11619800255560837597192574795389782851917036920101027584480912719351481334717\"\n |]\n |]\n ; round_constants =\n [| [| \"2517640872121921965298496967863234221143680281046699148760560696057284005606\"\n ; \"3391756047431116221709518926936538303706203177575259437741546230828058541679\"\n ; \"28193080211857729746868575888309975056941007202713113547154010421664334143056\"\n |]\n ; [| \"25261619184426186938919514618416881383323154981235406731208902193655587998749\"\n ; \"5438499261516835502981531641588657477212528137520578797088407969732830437134\"\n ; \"1447697894671779324954748568939217281372628544919576009518449387265606369859\"\n |]\n ; [| \"5035532530235542599906399941203951970682478985022204457211063504597080640029\"\n ; \"18548939393800290417015907795270784249198528773378593112394621615021029911007\"\n ; \"28314657632459005492203969796973258399484591559931227050853551342156833947891\"\n |]\n ; [| \"10075465805557971120845970058070916255338843492716768289922460436606689369477\"\n ; \"21985996556868691161386211003270106475915714625334030557267947035839814254081\"\n ; \"9778523497398309788873186849997676949503189428912377745814036481347657299161\"\n |]\n ; [| \"6085447467925843146276340167082679235758707259098174769103982431882228334038\"\n ; \"11214803418623679719680560978819619149235769633101428825693192995405955507848\"\n ; \"20585482519401972421539035665320299097144487427998598740316244173221216198246\"\n |]\n ; [| \"18602266896623204184748247002001496873223612100325866696399863661914256384486\"\n ; \"22165919841309962137671309308234475433816142848229812860682345190836583925843\"\n ; \"22833505632200982123686653495190412951871851216487329681987951602744930627412\"\n |]\n ; [| \"200996541962081036547810490655955282117589336000744078845964972887355639644\"\n ; \"17159390488590225463405148524511348095493761844950655304775985535830170165304\"\n ; \"7519689807382250126180254188667761476713509751388558140260305473388567529705\"\n |]\n ; [| \"14159331841037307097148990917607709903712709092721125605507719995418592745663\"\n ; \"10490695046555645615062072066940833278139280813429718770298136076375411280286\"\n ; \"9996921069626538041923613626115903019578182147993504053879837245826104687293\"\n |]\n ; [| \"28009241574980093348462093077828465154604666812509186537490618830383877236685\"\n ; \"18925279443828804264179873719494108834579217607847079902207023181925588871175\"\n ; \"13126164514615718686767880517156253918404905174962666942976286681458411835722\"\n |]\n ; [| \"1125667389564136291825905670957082668987611691949011617627091942772124917554\"\n ; \"12737072162917928935765906421286553437026542524142430058538254259863452556200\"\n ; \"9855113244149548216327019561589719324434080884827484555441182992249251832158\"\n |]\n ; [| \"6006604346195593001833550983798183088851044846011297061071167569148810544010\"\n ; \"23783465709464699444911580329342599880163107932561352210466223087637763994288\"\n ; \"1581060363083815351710754851350813999229829634252940169154424073664057276774\"\n |]\n ; [| \"24121961545310887440574053281799796355427122479626872394472157625455666323022\"\n ; \"23925781309638869606256007860000699567158045595326122474217734988331349678475\"\n ; \"433512980570318160778040929743715681206456334448542248765142091911433454703\"\n |]\n ; [| \"8080307140515367021419180108267113624095868360927897204642243727009503935719\"\n ; \"13661807750191096117929173962837770733539092996971801228126331071941306856508\"\n ; \"9268394414065063505331314418649987795374055416089324253185088859000252370756\"\n |]\n ; [| \"22374115023493407761095751712373350824513305398485824175669182288521610150311\"\n ; \"22951274634403942446739133926874770994604864227598567536319143390467218980824\"\n ; \"21411532836345163980832919797897483979345524322135010935120723250070247464549\"\n |]\n ; [| \"20688285497159372157224857370703211924056803904697620218749985029000049442943\"\n ; \"8350087190167057556241775495760369408781696125331535735138679647687106863977\"\n ; \"13485893160159637778707269611856683957779710980787754997470728774769162419576\"\n |]\n ; [| \"4621792784192688819920303666439776744566536330750316034321950771579978771021\"\n ; \"13900656491552343190424687336475573267660717627286734246676255663734655019912\"\n ; \"16577037405341365304416318048187907895286388691199320947077947552959834207823\"\n |]\n ; [| \"17453637937712580666297652202332273322112052411250919589546137386514183913993\"\n ; \"9852736110707561006399582579453396957225552488023642073454517393228764176471\"\n ; \"8053970357622019747109700798952789019805031210730923951116580579194625334710\"\n |]\n ; [| \"14566849926060034944494603512439278530775668595134329897253012222562109882008\"\n ; \"8863944349051942080060073891691580009950648437676309749771884964336231381737\"\n ; \"16455762285584757654310476505019438984453107876908065440396394186006196612077\"\n |]\n ; [| \"28098375311516838082882166381119795701982164671360574802728073046992978741339\"\n ; \"13538346067341652694825445642847479918140731375902310280683284825070643960891\"\n ; \"18313412784975078534612748781201087502203257054025866271209086293337241477805\"\n |]\n ; [| \"24807061345703288899043018750567607387907450632666147403804744880717736838940\"\n ; \"16638378638176552952794487891875614248110181610295183306789394461536640085108\"\n ; \"2342874860138849081032934096750004917991517717553229739958552529472431319656\"\n |]\n ; [| \"21631810094765090996871180483650934431972930909326270651252393395613356531282\"\n ; \"2220759912186713489010197903069023809260408491503960321105305330086947471014\"\n ; \"14815764944505758746761442212662459585220143243155504464852948007238083120696\"\n |]\n ; [| \"23947619952183462858644581465494050309407721428302029371055887418452994318961\"\n ; \"25035254658153233628169609451068923631269927394392748023889572264723092874720\"\n ; \"17468020412163678868776493601957969748197290347006692843306595815987772942732\"\n |]\n ; [| \"15262198027618900223004625662874755104828479630165814039838611768431063172994\"\n ; \"25161066724266754383358798644805908588326959881061318668106454787543611445887\"\n ; \"2454250001039770891411267760383268680504653332090622148533496270387793031332\"\n |]\n ; [| \"9171946491887082474979985164918822959719377078284664312866368737511724712644\"\n ; \"6672870238005411132577302023934139592378291207852994424857452575898007687159\"\n ; \"2950400608762766076731526167833938554190979516192019010641815746350334547745\"\n |]\n ; [| \"10653725154501691589476837895400001173933804810435931645261606197625601363132\"\n ; \"12717400214508961810851553873706609743505640660238109459222577386574996883747\"\n ; \"5871058785976817081042949511195036111847495052209270758342334312740290470200\"\n |]\n ; [| \"18192562665205900830717234913238180302424621739145466326708104656354353538015\"\n ; \"19946412409172091711185698839696950657650658896270607012902209489827790455314\"\n ; \"21997416257528392077410699901606794827305154904508120972585193876767785262539\"\n |]\n ; [| \"16525092684784199198745517563091041705366544303388462641935777835264970071331\"\n ; \"27613372589672512522307803997948488817865025374001297632527692577079750053456\"\n ; \"23369674747888778238616865774843237791546925005553032792584302158017141634655\"\n |]\n ; [| \"11012136308159330675912474383855146192700147583104742924419195363346115019405\"\n ; \"20632243971343595216801828590185617698839041744000918292113739726624680548813\"\n ; \"10530371852841765918702282883445676639977895775479854136871270050807595649710\"\n |]\n ; [| \"1610594053831245596683250788274018471388810111366046583216577135605955718023\"\n ; \"452300846172044702598793611907955884294868639769163388132276731316720796255\"\n ; \"22297945145153422883128810575530182077542612397826351322358420927950400316504\"\n |]\n ; [| \"28212510899948152845929142163236606049756849316851154583029383581129293825706\"\n ; \"28325924586146971645663587791728624896861517146549428987043066595915712075981\"\n ; \"23489013325315178311518261165509151135555509351661386106070231815049642443022\"\n |]\n ; [| \"10150108696154604591036176090028652090941375062280095655463112192524823306544\"\n ; \"14935856239824547404885450872472169780177654619496758596151670953532153419587\"\n ; \"4367251608666794961207658726914177158125339342277880902441218521648798930454\"\n |]\n ; [| \"14278046449956534912766622635951826857049583276976844525135170835571509013020\"\n ; \"11627801940273881243235293875277734806211947530882079339115454640100174268255\"\n ; \"22853853581419894582873479603685652928885253184240650995805892818180355600894\"\n |]\n ; [| \"4405193089432137585625363585733613667088817369599257533888439029942466720878\"\n ; \"26434497741746827048559732407319982377645052620918789373329661707603241810667\"\n ; \"23558650878002025381506445692526977061352711282820117441110868042756853707843\"\n |]\n ; [| \"27427423077748345654234924309581695092179468167973406115643356520054395647078\"\n ; \"17585801825757985265979208086560185342609289319992678737491966299829354657891\"\n ; \"22079131836316223121286612953926945430480043835170303484162677394496378207190\"\n |]\n ; [| \"20126865597655889981803452476686954944892814234259869552204215672627920656068\"\n ; \"5591585339015997308682985123056479221565470335707041924016523106405300562835\"\n ; \"9422316572086279209843572429137982927615080330725918371521370800874341571474\"\n |]\n ; [| \"2735677349719528139570614238939713941030373684882307164259316901880218894412\"\n ; \"16229147459127626384090303399894157248853232127961182470501666316464149067069\"\n ; \"17151067888069760812629817914442472623785916486309268828873486698948911058517\"\n |]\n ; [| \"13833972862865550568348750465964022581895521701070662509936215512761615491351\"\n ; \"9624679817699048440664645568701817641311119158936258215534754849666144699339\"\n ; \"10273179847163882031630140477902608240997857384703412878925192706057610103613\"\n |]\n ; [| \"3172037826021850467928085880043492158321918352296515787555947245998877188849\"\n ; \"28890802281119993101506497911757988639840653958256859430239635494708187190915\"\n ; \"23496953773368274731821824281559682992786773767847557735733251263969009271239\"\n |]\n ; [| \"1509044982655321910215442389040863370827049078919961070795919190828975736187\"\n ; \"13927172650979098916742472053302036482743492746437467103459483008024082210879\"\n ; \"17248379591027039069313293591621091031164062825086122980769287846951363066520\"\n |]\n ; [| \"11350333545134487336540967650634077894516131586708748380417042089147896079201\"\n ; \"639497848254405996993150855123515463224731962182127668267769103213580096582\"\n ; \"24528361599642320451530127347946798949257664936307333999618279589325586618880\"\n |]\n ; [| \"8217015496508457685301448884203977810298711070026260090660268003968421268717\"\n ; \"6703444480721420507060701216472376128524677965704475494357937059812166295103\"\n ; \"8051365375874262471960241848873604339195556527603956582828833313772444122472\"\n |]\n ; [| \"10412735174026641936105532807659667596947675372330827493649954160029449767122\"\n ; \"8447576362386697729021229138353952824970707645851763166490398451107606293885\"\n ; \"4802965296970904162106502573136505305073730277702271660292532219583823320181\"\n |]\n ; [| \"3244354881334856885788568976540712586633556478250043997221528214026130052269\"\n ; \"817270901440592571623549787267103386561304980129799240746702119063425010300\"\n ; \"6566338353152134577893356938981496347522747926131278635019050445923229718029\"\n |]\n ; [| \"4854521709622003124815206874897232905514824969466266873443062691298769768277\"\n ; \"12830134034124699064152980183243986699241944691238427861184919962819448276943\"\n ; \"24309439157688106320977023683093060719537142150089588950480669629964661236785\"\n |]\n ; [| \"1853791709949511636795588377016980571084333441972847324139062389997895453872\"\n ; \"11399505004623970417786749745036397690793259153591025248188283534764565207306\"\n ; \"6280235834578097246976697944083887557501831809932305676532914637669922657807\"\n |]\n ; [| \"1516294190187225192808636261678393666537186816904214776860202535671714230097\"\n ; \"5835813607391397757416951433662507638966861369364000865214031356023042341328\"\n ; \"25777313996516799380163546628133415256678997511953860435781885414872422583905\"\n |]\n ; [| \"9749298878960864917089442034293906589697892682402070689770627645324414273893\"\n ; \"19986612197193695239708718365565978831607994386509967951279410162135133793419\"\n ; \"5020585421647265067890838871263925730422335215511670656851726444447972642755\"\n |]\n ; [| \"7256822974971238434100017358319972368738353570339258522235883585691301791128\"\n ; \"9789139064283320903202623693175751994730652446378861671859478926598420184293\"\n ; \"19283468246375057076525422714896652730563534118070235174488237489890270899533\"\n |]\n ; [| \"11487321478704551489982188818171823402443882145686911658585221913500937481156\"\n ; \"16513958012405406860890342996091255867910990589443610357743227675107758695101\"\n ; \"24764429351173766080138047602436205744310671344674490826288279531917797263231\"\n |]\n ; [| \"8256258316375000496541664568891934707113720493937218096466691600593595285909\"\n ; \"26919625894863883593081175799908601863265420311251948374988589188905317081443\"\n ; \"10135851848127171199130812615581006825969108287418884763125596866448544567342\"\n |]\n ; [| \"17567146349912867622479843655652582453162587996421871126612027345809646551661\"\n ; \"2524802431860351616270075327416865184018211992251290134350377936184047953453\"\n ; \"3417609143162661859785838333493682460709943782149216513733553607075915176256\"\n |]\n ; [| \"6906455011502599710165862205505812668908382042647994457156780865092846286493\"\n ; \"21042097659487317081899343674473811663642293019125869396575405454328274948985\"\n ; \"25222370053690749913129090298406788520061040938312366403907461864202905656238\"\n |]\n ; [| \"18933201791079410639949505893100361911334261775545573219434897335758052335005\"\n ; \"14503331557348715387048413780116585195932777696828173626366829282421027153184\"\n ; \"3558781473325529402549318082942465709639711182863041375748599816583729962116\"\n |]\n ; [| \"23932570601084008621895097434501731960424360312878373523779451810455362953625\"\n ; \"13286131463754478912858022007443470896920464302917391606059553157137090717219\"\n ; \"9969435194445819847988134248075866286921574284754991873902788928171429847506\"\n |]\n ; [| \"10821551500865029673311799086099720530496516676117927814621168667836737594374\"\n ; \"57689402905128519605376551862931564078571458212398163192591670282543962941\"\n ; \"4484359679395800410695081358212522306960518636189521201445105538223906998486\"\n |]\n |]\n }\n","open! Core_kernel\nopen! Import\n\nmodule type Slots = sig\n (** [Slots] has types [t1], ..., [t12] of arities 1 to 12 that are isomorphic to tuple\n types of the corresponding arities. Type [('a0, ..., 'a) t] corresponds to\n ['a0 * ... * 'a].\n\n Each type [ti] is an instance of type [('tuple, 'variant) t], in which ['tuple] is\n the tuple type ['a0 * ... * 'a] and ['variant] is an encoding of the tuple type\n in the form: [[ `S0 of `a0 | `S1 of `a1 | ... | `S of `a ]].\n\n The encoding of the slots using a polymorphic variant allows one to write functions\n that are polymorphic in the tuple type, and require that a tuple have a certain\n slot, but allow more slots.\n\n We make [t] itself a polymorphic variant type so that one can easily encode cyclic\n types, e.g. lists, like:\n\n {[\n type 'a slots = ('a, 'a slots Pointer.t) Slots.t2\n ]}\n\n Observe that [slots] in the above is cyclic, but that OCaml allows it because the\n definition expands to:\n\n {[\n type 'a slots = [ `Slots of ('a * 'a slots Pointer.t,\n [ `S0 of 'a\n | `S1 of 'a slots Pointer.t\n ]\n ) u\n ]\n ]}\n\n Ultimately, a [Slots.t] is used as a phantom type that ensures consistent usage of\n the tuples in the data structure containing them. *)\n\n type ('tuple, 'variant) u\n type ('tuple, 'variant) t = [ `Slots of ('tuple, 'variant) u ] [@@deriving sexp_of]\n\n val slots_per_tuple : (_, _) t -> int\n\n type 'a0 t1 = ('a0, [ `S0 of 'a0 ]) t [@@deriving sexp_of]\n type ('a0, 'a1) t2 = ('a0 * 'a1, [ `S0 of 'a0 | `S1 of 'a1 ]) t [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2) t3 = ('a0 * 'a1 * 'a2, [ `S0 of 'a0 | `S1 of 'a1 | `S2 of 'a2 ]) t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3) t4 =\n ('a0 * 'a1 * 'a2 * 'a3, [ `S0 of 'a0 | `S1 of 'a1 | `S2 of 'a2 | `S3 of 'a3 ]) t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4) t5 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4\n , [ `S0 of 'a0 | `S1 of 'a1 | `S2 of 'a2 | `S3 of 'a3 | `S4 of 'a4 ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5) t6 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5\n , [ `S0 of 'a0 | `S1 of 'a1 | `S2 of 'a2 | `S3 of 'a3 | `S4 of 'a4 | `S5 of 'a5 ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6) t7 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7) t8 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8) t9 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9) t10 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n | `S9 of 'a9\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10) t11 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9 * 'a10\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n | `S9 of 'a9\n | `S10 of 'a10\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11) t12 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9 * 'a10 * 'a11\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n | `S9 of 'a9\n | `S10 of 'a10\n | `S11 of 'a11\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11, 'a12) t13 =\n ( 'a0 * 'a1 * 'a2 * 'a3 * 'a4 * 'a5 * 'a6 * 'a7 * 'a8 * 'a9 * 'a10 * 'a11 * 'a12\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n | `S9 of 'a9\n | `S10 of 'a10\n | `S11 of 'a11\n | `S12 of 'a12\n ] )\n t\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11, 'a12, 'a13) t14 =\n ( 'a0\n * 'a1\n * 'a2\n * 'a3\n * 'a4\n * 'a5\n * 'a6\n * 'a7\n * 'a8\n * 'a9\n * 'a10\n * 'a11\n * 'a12\n * 'a13\n , [ `S0 of 'a0\n | `S1 of 'a1\n | `S2 of 'a2\n | `S3 of 'a3\n | `S4 of 'a4\n | `S5 of 'a5\n | `S6 of 'a6\n | `S7 of 'a7\n | `S8 of 'a8\n | `S9 of 'a9\n | `S10 of 'a10\n | `S11 of 'a11\n | `S12 of 'a12\n | `S13 of 'a13\n ] )\n t\n [@@deriving sexp_of]\n\n val t1 : _ t1\n val t2 : (_, _) t2\n val t3 : (_, _, _) t3\n val t4 : (_, _, _, _) t4\n val t5 : (_, _, _, _, _) t5\n val t6 : (_, _, _, _, _, _) t6\n val t7 : (_, _, _, _, _, _, _) t7\n val t8 : (_, _, _, _, _, _, _, _) t8\n val t9 : (_, _, _, _, _, _, _, _, _) t9\n val t10 : (_, _, _, _, _, _, _, _, _, _) t10\n val t11 : (_, _, _, _, _, _, _, _, _, _, _) t11\n val t12 : (_, _, _, _, _, _, _, _, _, _, _, _) t12\n val t13 : (_, _, _, _, _, _, _, _, _, _, _, _, _) t13\n val t14 : (_, _, _, _, _, _, _, _, _, _, _, _, _, _) t14\nend\n\nmodule type Slot = sig\n (** A [Slot.t] represents a slot in a tuple type. *)\n type ('variant, 'a) t [@@deriving sexp_of]\n\n val equal : ('v, 'a) t -> ('v, 'a) t -> bool\n\n (** [ti] is the [i]'th slot. *)\n\n val t0 : ([> `S0 of 'a ], 'a) t\n val t1 : ([> `S1 of 'a ], 'a) t\n val t2 : ([> `S2 of 'a ], 'a) t\n val t3 : ([> `S3 of 'a ], 'a) t\n val t4 : ([> `S4 of 'a ], 'a) t\n val t5 : ([> `S5 of 'a ], 'a) t\n val t6 : ([> `S6 of 'a ], 'a) t\n val t7 : ([> `S7 of 'a ], 'a) t\n val t8 : ([> `S8 of 'a ], 'a) t\n val t9 : ([> `S9 of 'a ], 'a) t\n val t10 : ([> `S10 of 'a ], 'a) t\n val t11 : ([> `S11 of 'a ], 'a) t\n val t12 : ([> `S12 of 'a ], 'a) t\n val t13 : ([> `S13 of 'a ], 'a) t\nend\n","open! Core_kernel\nopen! Import\ninclude Tuple_type_intf\n\nmodule Slots = struct\n type u_ = { slots_per_tuple : int } [@@deriving sexp_of]\n type ('tuple, 'variant) u = u_ [@@deriving sexp_of]\n type t_ = [ `Slots of u_ ] [@@deriving sexp_of]\n type ('tuple, 'variant) t = t_ [@@deriving sexp_of]\n\n let slots_per_tuple (`Slots { slots_per_tuple = n }) = n\n\n type 'a0 t1 = t_ [@@deriving sexp_of]\n type ('a0, 'a1) t2 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2) t3 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3) t4 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4) t5 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5) t6 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6) t7 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7) t8 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8) t9 = t_ [@@deriving sexp_of]\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9) t10 = t_ [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10) t11 = t_\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11) t12 = t_\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11, 'a12) t13 = t_\n [@@deriving sexp_of]\n\n type ('a0, 'a1, 'a2, 'a3, 'a4, 'a5, 'a6, 'a7, 'a8, 'a9, 'a10, 'a11, 'a12, 'a13) t14 =\n t_\n [@@deriving sexp_of]\n\n let t1 = `Slots { slots_per_tuple = 1 }\n let t2 = `Slots { slots_per_tuple = 2 }\n let t3 = `Slots { slots_per_tuple = 3 }\n let t4 = `Slots { slots_per_tuple = 4 }\n let t5 = `Slots { slots_per_tuple = 5 }\n let t6 = `Slots { slots_per_tuple = 6 }\n let t7 = `Slots { slots_per_tuple = 7 }\n let t8 = `Slots { slots_per_tuple = 8 }\n let t9 = `Slots { slots_per_tuple = 9 }\n let t10 = `Slots { slots_per_tuple = 10 }\n let t11 = `Slots { slots_per_tuple = 11 }\n let t12 = `Slots { slots_per_tuple = 12 }\n let t13 = `Slots { slots_per_tuple = 13 }\n let t14 = `Slots { slots_per_tuple = 14 }\nend\n","open! Core_kernel\nmodule Pool = Tuple_pool\nmodule Pointer = Pool.Pointer\n\n(* This pool holds nodes that would be represented more traditionally as:\n\n {[\n type 'a t =\n | Empty\n | Heap of 'a * 'a t list ]}\n\n We will represent them as a left-child, right-sibling tree in a triplet\n (value * left_child * right_sibling). The left child and all right siblings\n of the left child form a linked list representing the subheaps of a given heap:\n\n {v\n A\n /\n B -> C -> D -> E -> F\n / / /\n G H->I->J K->L\n v} *)\n\nmodule Node : sig\n (* Exposing [private int] is a significant performance improvement, because it allows\n the compiler to skip the write barrier. *)\n\n type 'a t = private int\n\n module Id : sig\n type t\n\n val of_int : int -> t\n val equal : t -> t -> bool\n end\n\n module Pool : sig\n type 'a node = 'a t\n type 'a t\n\n val create : min_size:int -> 'a t\n val is_full : 'a t -> bool\n val length : 'a t -> int\n val grow : 'a t -> 'a t\n val copy : 'a t -> 'a node -> 'a node * 'a t\n end\n\n (** [allocate v ~pool] allocates a new node from the pool with no child or sibling *)\n val allocate : 'a -> pool:'a Pool.t -> id:Id.t -> 'a t\n\n (** [free t ~pool] frees [t] for reuse. It is an error to access [t] after this. *)\n val free : 'a t -> pool:'a Pool.t -> unit\n\n (** a special [t] that represents the empty node *)\n val empty : unit -> 'a t\n\n val is_empty : 'a t -> bool\n val equal : 'a t -> 'a t -> bool\n\n (** [value_exn t ~pool] return the value of [t], raise if [is_empty t] *)\n val value_exn : 'a t -> pool:'a Pool.t -> 'a\n\n val id : 'a t -> pool:'a Pool.t -> Id.t\n val child : 'a t -> pool:'a Pool.t -> 'a t\n val sibling : 'a t -> pool:'a Pool.t -> 'a t\n\n (** [prev t] is either the parent of [t] or the sibling immediately left of [t] *)\n val prev : 'a t -> pool:'a Pool.t -> 'a t\n\n (** [add_child t ~child ~pool] Add a child to [t], preserving existing children as\n siblings of [child]. [t] and [child] should not be empty and [child] should have no\n sibling and have no prev node. *)\n val add_child : 'a t -> child:'a t -> pool:'a Pool.t -> unit\n\n (** disconnect and return the sibling *)\n val disconnect_sibling : 'a t -> pool:'a Pool.t -> 'a t\n\n (** disconnect and return the child *)\n val disconnect_child : 'a t -> pool:'a Pool.t -> 'a t\n\n (** [detach t ~pool] removes [t] from the tree, adjusting pointers around it. After\n [detach], [t] is the root of a standalone heap, which is detached from the original\n heap. *)\n val detach : 'a t -> pool:'a Pool.t -> unit\nend = struct\n module Id = Int\n\n let dummy_id : Id.t = -1\n\n type 'a node =\n ('a, 'a node Pointer.t, 'a node Pointer.t, 'a node Pointer.t, Id.t) Pool.Slots.t5\n\n type 'a t = 'a node Pointer.t\n\n let empty = Pointer.null\n let is_empty = Pointer.is_null\n let equal = Pointer.phys_equal\n let value t ~pool = Pool.get pool t Pool.Slot.t0\n let child t ~pool = Pool.get pool t Pool.Slot.t1\n let sibling t ~pool = Pool.get pool t Pool.Slot.t2\n let prev t ~pool = Pool.get pool t Pool.Slot.t3\n let id t ~pool = Pool.get pool t Pool.Slot.t4\n\n (* let set_value t v ~pool = Pool.set pool t Pool.Slot.t0 v *)\n let set_child t v ~pool = Pool.set pool t Pool.Slot.t1 v\n let set_sibling t v ~pool = Pool.set pool t Pool.Slot.t2 v\n let set_prev t v ~pool = Pool.set pool t Pool.Slot.t3 v\n\n let value_exn t ~pool =\n assert (not (is_empty t));\n value t ~pool\n ;;\n\n let allocate value ~pool ~id = Pool.new5 pool value (empty ()) (empty ()) (empty ()) id\n let free t ~pool = Pool.unsafe_free pool t\n\n let disconnect_sibling t ~pool =\n let sibling = sibling t ~pool in\n if not (is_empty sibling)\n then (\n set_sibling t (empty ()) ~pool;\n set_prev sibling (empty ()) ~pool);\n sibling\n ;;\n\n let disconnect_child t ~pool =\n let child = child t ~pool in\n if not (is_empty child)\n then (\n set_child t (empty ()) ~pool;\n set_prev child (empty ()) ~pool);\n child\n ;;\n\n let add_child t ~child:new_child ~pool =\n (* assertions we would make, but for speed:\n assert (not (is_empty t));\n assert (not (is_empty new_child));\n assert (is_empty (sibling new_child ~pool));\n assert (is_empty (prev new_child ~pool));\n *)\n let current_child = disconnect_child t ~pool in\n (* add [new_child] to the list of [t]'s children (which may be empty) *)\n set_sibling new_child current_child ~pool;\n if not (is_empty current_child) then set_prev current_child new_child ~pool;\n set_child t new_child ~pool;\n set_prev new_child t ~pool\n ;;\n\n let detach t ~pool =\n if not (is_empty t)\n then (\n let prev = prev t ~pool in\n if not (is_empty prev)\n then (\n let relation_to_prev = if equal t (child prev ~pool) then `child else `sibling in\n set_prev t (empty ()) ~pool;\n let sibling = disconnect_sibling t ~pool in\n (match relation_to_prev with\n | `child -> set_child prev sibling ~pool\n | `sibling -> set_sibling prev sibling ~pool);\n if not (is_empty sibling) then set_prev sibling prev ~pool))\n ;;\n\n module Pool = struct\n type 'a t = 'a node Pool.t\n type nonrec 'a node = 'a node Pointer.t\n\n let create (type a) ~min_size:capacity : a t =\n Pool.create\n Pool.Slots.t5\n ~capacity\n ~dummy:\n ( (Obj.magic None : a)\n , Pointer.null ()\n , Pointer.null ()\n , Pointer.null ()\n , dummy_id )\n ;;\n\n let is_full t = Pool.is_full t\n let length t = Pool.length t\n let grow t = Pool.grow t\n\n let copy t start =\n let t' = create ~min_size:(Pool.capacity t) in\n let copy_node node to_visit =\n if is_empty node\n then empty (), to_visit\n else (\n (* we use the same id, but that's ok since ids should be unique per heap *)\n let new_node =\n allocate (value_exn node ~pool:t) ~pool:t' ~id:(id node ~pool:t)\n in\n let to_visit =\n (new_node, `child, child node ~pool:t)\n :: (new_node, `sibling, sibling node ~pool:t)\n :: to_visit\n in\n new_node, to_visit)\n in\n let rec loop to_visit =\n match to_visit with\n | [] -> ()\n | (node_to_update, slot, node_to_copy) :: rest ->\n let new_node, to_visit = copy_node node_to_copy rest in\n (match slot with\n | `child -> set_child node_to_update new_node ~pool:t'\n | `sibling -> set_sibling node_to_update new_node ~pool:t');\n if not (is_empty new_node) then set_prev new_node node_to_update ~pool:t';\n loop to_visit\n in\n let new_start, to_visit = copy_node start [] in\n loop to_visit;\n new_start, t'\n ;;\n end\nend\n\ntype 'a t =\n { (* cmp is placed first to short-circuit polymorphic compare *)\n cmp : 'a -> 'a -> int\n ; mutable pool : 'a Node.Pool.t\n ; (* invariant: [root] never has a sibling *)\n mutable root : 'a Node.t\n ; mutable num_of_allocated_nodes : int\n }\n\nlet invariant _ t =\n let rec loop to_visit =\n match to_visit with\n | [] -> ()\n | (node, expected_prev, maybe_parent_value) :: rest ->\n if not (Node.is_empty node)\n then (\n let this_value = Node.value_exn node ~pool:t.pool in\n assert (Node.equal (Node.prev node ~pool:t.pool) expected_prev);\n Option.iter maybe_parent_value ~f:(fun parent_value ->\n assert (t.cmp parent_value this_value <= 0));\n loop\n ((Node.child node ~pool:t.pool, node, Some this_value)\n :: (Node.sibling node ~pool:t.pool, node, maybe_parent_value)\n :: rest))\n else loop rest\n in\n assert (Node.is_empty t.root || Node.is_empty (Node.sibling t.root ~pool:t.pool));\n loop [ t.root, Node.empty (), None ]\n;;\n\nlet create ?(min_size = 1) ~cmp () =\n { cmp\n ; pool = Node.Pool.create ~min_size\n ; root = Node.empty ()\n ; num_of_allocated_nodes = 0\n }\n;;\n\nlet copy { cmp; pool; root; num_of_allocated_nodes } =\n let root, pool = Node.Pool.copy pool root in\n { cmp; pool; root; num_of_allocated_nodes }\n;;\n\nlet allocate t v =\n if Node.Pool.is_full t.pool then t.pool <- Node.Pool.grow t.pool;\n t.num_of_allocated_nodes <- t.num_of_allocated_nodes + 1;\n Node.allocate v ~pool:t.pool ~id:(Node.Id.of_int t.num_of_allocated_nodes)\n;;\n\n(* translation:\n {[\n match root1, root2 with\n | None, h | h, None -> h\n | Some (Node (v1, children1)), Some (Node (v2, children2)) ->\n if v1 < v2\n then Some (Node (v1, root2 :: children1))\n else Some (Node (v2, root1 :: children2))\n ]}\n\n This function assumes neither root has a prev node (usually because the inputs come\n from [disconnect_*] or are the top of the heap or are the output of this function). *)\nlet merge t root1 root2 =\n if Node.is_empty root1\n then root2\n else if Node.is_empty root2\n then root1\n else (\n let add_child t node ~child =\n Node.add_child node ~pool:t.pool ~child;\n node\n in\n let v1 = Node.value_exn root1 ~pool:t.pool in\n let v2 = Node.value_exn root2 ~pool:t.pool in\n if t.cmp v1 v2 < 0\n then add_child t root1 ~child:root2\n else add_child t root2 ~child:root1)\n;;\n\nlet top_exn t =\n if Node.is_empty t.root\n then failwith \"Heap.top_exn called on an empty heap\"\n else Node.value_exn t.root ~pool:t.pool\n;;\n\nlet top t = if Node.is_empty t.root then None else Some (top_exn t)\n\nlet add_node t v =\n let node = allocate t v in\n t.root <- merge t t.root node;\n node\n;;\n\nlet add t v = ignore (add_node t v : _ Node.t)\n\n(* [merge_pairs] takes a list of heap roots and merges consecutive pairs, reducing the\n list of length n to n/2. Then it merges the merged pairs into a single heap. One\n intuition is that this is somewhat like building a single level of a binary tree.\n\n The output heap does not contain the value that was at the root of the input heap.\n\n We break the function into two parts. A first stage that is willing to use limited\n stack instead of heap allocation for bookkeeping, and a second stage that shifts to\n using a list as an accumulator if we go too deep.\n\n This can be made tail recursive and non-allocating by starting with an empty heap and\n merging merged pairs into it. Unfortunately this \"left fold\" version is not what is\n described in the original paper by Fredman et al.; they specifically say that\n children should be merged together from the end of the list to the beginning of the\n list. ([merge] is not associative, so order matters.)\n*)\n(* translation:\n {[\n let rec loop acc = function\n | [] -> acc\n | [head] -> head :: acc\n | head :: next1 :: next2 -> loop (merge head next1 :: acc) next2\n in\n match loop [] children with\n | [] -> None\n | [h] -> Some h\n | x :: xs -> Some (List.fold xs ~init:x ~f:merge)\n ]}\n*)\nlet allocating_merge_pairs t head =\n let rec loop acc head =\n if Node.is_empty head\n then acc\n else (\n let next1 = Node.disconnect_sibling head ~pool:t.pool in\n if Node.is_empty next1\n then head :: acc\n else (\n let next2 = Node.disconnect_sibling next1 ~pool:t.pool in\n loop (merge t head next1 :: acc) next2))\n in\n match loop [] head with\n | [] -> Node.empty ()\n | [ h ] -> h\n | x :: xs -> List.fold xs ~init:x ~f:(fun acc heap -> merge t acc heap)\n;;\n\n(* translation:\n {[\n match t.root with\n | Node (_, children) ->\n let rec loop depth children =\n if depth >= max_stack_depth\n then allocating_merge_pairs t childen\n else begin\n match children with\n | [] -> None\n | [head] -> Some head\n | head :: next1 :: next2 ->\n merge (merge head next1) (loop (depth + 1) next2)\n end\n in\n loop 0 children\n ]}\n*)\nlet merge_pairs =\n let max_stack_depth = 1_000 in\n let rec loop t depth head =\n if depth >= max_stack_depth\n then allocating_merge_pairs t head\n else if Node.is_empty head\n then head\n else (\n let next1 = Node.disconnect_sibling head ~pool:t.pool in\n if Node.is_empty next1\n then head\n else (\n let next2 = Node.disconnect_sibling next1 ~pool:t.pool in\n (* merge the first two nodes in our list, and then merge the result with the\n result of recursively calling merge_pairs on the tail *)\n merge t (merge t head next1) (loop t (depth + 1) next2)))\n in\n fun t head -> loop t 0 head\n;;\n\nlet remove_non_empty t node =\n let pool = t.pool in\n Node.detach node ~pool;\n let merged_children = merge_pairs t (Node.disconnect_child node ~pool) in\n let new_root =\n if Node.equal t.root node then merged_children else merge t t.root merged_children\n in\n Node.free node ~pool;\n t.root <- new_root\n;;\n\nlet remove_top t = if not (Node.is_empty t.root) then remove_non_empty t t.root\n\nlet pop_exn t =\n let r = top_exn t in\n remove_top t;\n r\n;;\n\nlet pop t = if Node.is_empty t.root then None else Some (pop_exn t)\n\nlet pop_if t f =\n match top t with\n | None -> None\n | Some v ->\n if f v\n then (\n remove_top t;\n Some v)\n else None\n;;\n\n(* pairing heaps are not balanced trees, and therefore we can't rely on a balance\n property to stop ourselves from overflowing the stack. *)\nlet fold t ~init ~f =\n let pool = t.pool in\n let rec loop acc to_visit =\n match to_visit with\n | [] -> acc\n | node :: rest ->\n if Node.is_empty node\n then loop acc rest\n else (\n let to_visit = Node.sibling ~pool node :: Node.child ~pool node :: rest in\n loop (f acc (Node.value_exn ~pool node)) to_visit)\n in\n loop init [ t.root ]\n;;\n\n(* almost identical to fold, copied for speed purposes *)\nlet iter t ~f =\n let pool = t.pool in\n let rec loop to_visit =\n match to_visit with\n | [] -> ()\n | node :: rest ->\n if Node.is_empty node\n then loop rest\n else (\n f (Node.value_exn ~pool node);\n let to_visit = Node.sibling ~pool node :: Node.child ~pool node :: rest in\n loop to_visit)\n in\n loop [ t.root ]\n;;\n\nlet length t = Node.Pool.length t.pool\n\nmodule C = Container.Make (struct\n type nonrec 'a t = 'a t\n\n let fold = fold\n let iter = `Custom iter\n let length = `Custom length\n end)\n\nlet is_empty t = Node.is_empty t.root\nlet mem = C.mem\nlet exists = C.exists\nlet for_all = C.for_all\nlet count = C.count\nlet sum = C.sum\nlet find = C.find\nlet find_map = C.find_map\nlet to_list = C.to_list\nlet to_array = C.to_array\nlet min_elt = C.min_elt\nlet max_elt = C.max_elt\nlet fold_result = C.fold_result\nlet fold_until = C.fold_until\n\nlet of_array arr ~cmp =\n let t = create ~min_size:(Array.length arr) ~cmp () in\n Array.iter arr ~f:(fun v -> add t v);\n t\n;;\n\nlet of_list l ~cmp = of_array (Array.of_list l) ~cmp\nlet sexp_of_t f t = Array.sexp_of_t f (to_array t |> Array.sorted_copy ~compare:t.cmp)\n\nmodule Elt = struct\n type nonrec 'a t =\n { mutable node : 'a Node.t\n ; node_id : Node.Id.t\n ; heap : 'a t\n }\n\n (* If ids are different, it means that the node has already been removed by some\n other means (and possibly reused). *)\n let is_node_valid t = Node.Id.equal (Node.id ~pool:t.heap.pool t.node) t.node_id\n\n let value t =\n if is_node_valid t then Some (Node.value_exn t.node ~pool:t.heap.pool) else None\n ;;\n\n let value_exn t =\n if is_node_valid t\n then Node.value_exn t.node ~pool:t.heap.pool\n else failwith \"Heap.value_exn: node was removed from the heap\"\n ;;\n\n let sexp_of_t sexp_of_a t = [%sexp (value t : a option)]\nend\n\nlet remove t (token : _ Elt.t) =\n if not (phys_equal t token.heap)\n then failwith \"cannot remove from a different heap\"\n else if not (Node.is_empty token.node)\n then (\n if Elt.is_node_valid token then remove_non_empty t token.node;\n token.node <- Node.empty ())\n;;\n\nlet add_removable t v =\n let node = add_node t v in\n { Elt.node; heap = t; node_id = Node.id ~pool:t.pool node }\n;;\n\nlet update t token v =\n remove t token;\n add_removable t v\n;;\n\nlet find_elt =\n let rec loop t f nodes =\n match nodes with\n | [] -> None\n | node :: rest ->\n if Node.is_empty node\n then loop t f rest\n else if f (Node.value_exn node ~pool:t.pool)\n then Some { Elt.node; heap = t; node_id = Node.id ~pool:t.pool node }\n else\n loop t f (Node.sibling node ~pool:t.pool :: Node.child node ~pool:t.pool :: rest)\n in\n fun t ~f -> loop t f [ t.root ]\n;;\n\nmodule Unsafe = struct\n module Elt = struct\n type 'a heap = 'a t\n type 'a t = 'a Node.t\n\n let value t heap = Node.value_exn ~pool:heap.pool t\n end\n\n let add_removable = add_node\n let remove = remove_non_empty\n\n let update t elt v =\n remove t elt;\n add_removable t v\n ;;\nend\n","open! Core_kernel\n\nmodule Make (M : sig\n val am_running_test : bool\n end) =\nstruct\n type 'a t = 'a [@@deriving bin_io, compare, sexp]\n\n let sexp_of_t sexp_of_a a =\n if M.am_running_test then Sexp.Atom \"\" else sexp_of_a a\n ;;\n\n module With_non_roundtripping_in_test_of_sexp = struct\n type nonrec 'a t = 'a t [@@deriving bin_io, compare, sexp]\n end\nend\n\nlet%test_module _ =\n (module struct\n module Turned_off = struct\n module Sexp_hidden_in_test_turned_off = Make (struct\n let am_running_test = false\n end)\n\n type nonrec t = int Sexp_hidden_in_test_turned_off.t [@@deriving sexp_of]\n end\n\n module Turned_on = struct\n module Sexp_hidden_in_test_turned_on = Make (struct\n let am_running_test = true\n end)\n\n type nonrec t = int Sexp_hidden_in_test_turned_on.t [@@deriving sexp_of]\n end\n\n let%expect_test \"Turned on\" =\n print_s [%sexp (1024 : Turned_on.t)];\n [%expect {| |}]\n ;;\n\n let%expect_test \"Turned off\" =\n print_s ([%sexp_of: Turned_off.t] 1024);\n [%expect {| 1024 |}]\n ;;\n end)\n;;\n\ninclude Make (struct\n let am_running_test = am_running_test\n end)\n","(* This module exploits the fact that OCaml does not perform context-switches under\n certain conditions. It can therefore avoid using mutexes.\n\n Given the semantics of the current OCaml runtime (and for the foreseeable future), code\n sections documented as atomic below will never contain a context-switch. The deciding\n criterion is whether they contain allocations or calls to external/builtin functions.\n If there is none, a context-switch cannot happen. Assignments without allocations,\n field access, pattern-matching, etc., do not trigger context-switches.\n\n Code reviewers should therefore make sure that the sections documented as atomic below\n do not violate the above assumptions. It is prudent to disassemble the .o file (using\n [objdump -dr]) and examine it. *)\n\nopen! Core_kernel\nopen! Import\n\nmodule Elt = struct\n type 'a t =\n { mutable value : 'a Uopt.t\n ; mutable next : ('a t Uopt.t[@sexp.opaque])\n }\n [@@deriving sexp_of]\n\n let create () = { value = Uopt.none; next = Uopt.none }\nend\n\ntype 'a t =\n { mutable length : int\n (* [front] to [back] has [length + 1] linked elements, where the first [length] hold the\n values in the queue, and the last is [back], holding no value. *)\n ; mutable front : 'a Elt.t\n ; mutable back : 'a Elt.t\n (* [unused_elts] is singly linked via [next], and ends with [sentinel]. All elts in\n [unused_elts] have [Uopt.is_none elt.value]. *)\n ; mutable unused_elts : 'a Elt.t Uopt.t\n }\n[@@deriving fields, sexp_of]\n\nlet invariant _invariant_a t =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~length:(check (fun length -> assert (length >= 0)))\n ~front:\n (check (fun front ->\n let i = ref t.length in\n let r = ref front in\n while !i > 0 do\n decr i;\n let elt = !r in\n r := Uopt.value_exn elt.Elt.next;\n assert (Uopt.is_some elt.value)\n done;\n assert (phys_equal !r t.back)))\n ~back:(check (fun back -> assert (Uopt.is_none back.Elt.value)))\n ~unused_elts:\n (check (fun unused_elts ->\n let r = ref unused_elts in\n while Uopt.is_some !r do\n let elt = Uopt.value_exn !r in\n r := elt.Elt.next;\n assert (Uopt.is_none elt.value)\n done)))\n;;\n\nlet create () =\n let elt = Elt.create () in\n { front = elt; back = elt; length = 0; unused_elts = Uopt.none }\n;;\n\nlet get_unused_elt t =\n (* BEGIN ATOMIC SECTION *)\n if Uopt.is_some t.unused_elts\n then (\n let elt = Uopt.unsafe_value t.unused_elts in\n t.unused_elts <- elt.next;\n elt (* END ATOMIC SECTION *))\n else Elt.create ()\n;;\n\nlet enqueue (type a) (t : a t) (a : a) =\n let new_back = get_unused_elt t in\n (* BEGIN ATOMIC SECTION *)\n t.length <- t.length + 1;\n t.back.value <- Uopt.some a;\n t.back.next <- Uopt.some new_back;\n t.back <- new_back\n;;\n\n(* END ATOMIC SECTION *)\n\nlet return_unused_elt t (elt : _ Elt.t) =\n (* BEGIN ATOMIC SECTION *)\n elt.value <- Uopt.none;\n elt.next <- t.unused_elts;\n t.unused_elts <- Uopt.some elt;\n (* END ATOMIC SECTION *)\n ()\n;;\n\nlet[@cold] raise_dequeue_empty t =\n failwiths\n ~here:[%here]\n \"Thread_safe_queue.dequeue_exn of empty queue\"\n t\n [%sexp_of: _ t]\n;;\n\nlet dequeue_exn t =\n (* BEGIN ATOMIC SECTION *)\n if t.length = 0 then raise_dequeue_empty t;\n let elt = t.front in\n let a = elt.value in\n t.front <- Uopt.unsafe_value elt.next;\n t.length <- t.length - 1;\n (* END ATOMIC SECTION *)\n return_unused_elt t elt;\n Uopt.unsafe_value a\n;;\n\nlet clear_internal_pool t = t.unused_elts <- Uopt.none\n\nmodule Private = struct\n module Uopt = Uopt\nend\n","include Core_kernel.Core_kernel_private.Time_ns_alternate_sexp\n\n(* [after] is like [add], but deals nicely with the case of overflow by instead returning\n [max_value]. Time-source functions use [after] to avoid immediately firing events that\n should never fire, due to the overflow leading to a negative time that appears to be in\n the past. We don't check underflow because that is very unlikely, requiring both a\n negative time and a negative span. *)\nlet after t span =\n let result = add t span in\n if Span.( > ) span Span.zero && result < t then max_value_for_1us_rounding else result\n;;\n","open Core_kernel\nopen Import\n\nlet debug = Debug.monitor\n\ntype t = Types.Monitor.t =\n { name : Info.t\n ; here : Source_code_position.t option\n ; id : int\n ; parent : t option\n ; mutable next_error : exn Types.Ivar.t\n ; (* [Monitor.send_exn] schedules a job for each element of [handlers_for_all_errors]. *)\n mutable handlers_for_all_errors : (Types.Execution_context.t * (exn -> unit)) Bag.t\n ; (* [Monitor.send_exn] extends each tail in [tails_for_all_errors]. *)\n mutable tails_for_all_errors : exn Types.Tail.t list\n ; mutable has_seen_error : bool\n ; mutable is_detached : bool\n }\n[@@deriving fields]\n\nmodule Pretty = struct\n type one =\n { name : Info.t\n ; here : Source_code_position.t option\n ; id : int\n ; has_seen_error : bool\n ; is_detached : bool\n }\n [@@deriving sexp_of]\n\n type t = one list [@@deriving sexp_of]\nend\n\nlet to_pretty =\n let rec loop\n { name\n ; here\n ; id\n ; parent\n ; has_seen_error\n ; is_detached\n ; next_error = _\n ; handlers_for_all_errors = _\n ; tails_for_all_errors = _\n }\n ac\n =\n let ac = { Pretty.name; here; id; has_seen_error; is_detached } :: ac in\n match parent with\n | None -> List.rev ac\n | Some t -> loop t ac\n in\n fun t -> loop t []\n;;\n\nlet sexp_of_t t = Pretty.sexp_of_t (to_pretty t)\n\nlet next_id =\n let r = ref 0 in\n fun () ->\n incr r;\n !r\n;;\n\nlet create_with_parent ?here ?info ?name parent =\n let id = next_id () in\n let name =\n match info, name with\n | Some i, None -> i\n | Some i, Some s -> Info.tag i ~tag:s\n | None, Some s -> Info.of_string s\n | None, None -> Info.create \"id\" id [%sexp_of: int]\n in\n let t =\n { name\n ; here\n ; parent\n ; id\n ; next_error = { cell = Empty }\n ; handlers_for_all_errors = Bag.create ()\n ; tails_for_all_errors = []\n ; has_seen_error = false\n ; is_detached = false\n }\n in\n if debug then Debug.log \"created monitor\" t [%sexp_of: t];\n t\n;;\n\nlet main = create_with_parent ~name:\"main\" None\n","module Time_ns_in_this_directory = Time_ns\nopen Core_kernel\nmodule Time_ns = Time_ns_in_this_directory\ninclude Async_kernel_config.Print_debug_messages_for\n\nlet log message a sexp_of_a =\n eprintf\n \"%s\\n%!\"\n (Sexp.to_string_hum\n ([%sexp_of: Sexp.t * Time_ns.t * string * a]\n (!Async_kernel_config.task_id (), Time_ns.now (), message, a)))\n;;\n\nlet log_string message = log message () [%sexp_of: unit]\n","module Debug_in_this_directory = Debug\nmodule Time_ns_in_this_directory = Time_ns\nopen! Core_kernel\ninclude Int.Replace_polymorphic_compare\nmodule Debug = Debug_in_this_directory\nmodule Time_ns = Time_ns_in_this_directory\nmodule Epoll_max_ready_events = Async_kernel_config.Epoll_max_ready_events\nmodule Max_inter_cycle_timeout = Async_kernel_config.Max_inter_cycle_timeout\nmodule Max_num_open_file_descrs = Async_kernel_config.Max_num_open_file_descrs\nmodule Max_num_threads = Async_kernel_config.Max_num_threads\nmodule Pool = Tuple_pool\n\nmodule Max_num_jobs_per_priority_per_cycle =\n Async_kernel_config.Max_num_jobs_per_priority_per_cycle\n\nlet concat = String.concat\nlet eprint = Core_kernel.Debug.eprint\nlet eprint_s = Core_kernel.Debug.eprint_s\nlet eprints = Core_kernel.Debug.eprints\nlet print_s sexp = printf \"%s\\n%!\" (sexp |> Sexp.to_string_hum)\nlet sec = Time_ns.Span.of_sec\n\n(* We don't want to use these modules in Async_kernel, to avoid difficulties with\n using it on js_of_ocaml. *)\nmodule Thread = struct end\nmodule Unix = struct end\n","open! Core_kernel\nopen! Import\n\ntype t =\n | Normal\n | Low\n[@@deriving sexp_of]\n\nlet normal = Normal\nlet low = Low\n","(* This file defines the mutually recursive types at the heart of Async. The functions\n associated with the types are defined in the corresponding file(s) for each module.\n This file should define only types, not functions, since functions defined inside the\n recursive modules are not inlined.\n\n If you need to add functionality to a module but doing so would create a dependency\n cycle, split the file into pieces as needed to break the cycle, e.g. scheduler0.ml,\n scheduler1.ml, scheduler.ml. *)\n\nopen! Core_kernel\nopen! Import\n\nmodule rec Cell : sig\n type any =\n [ `Empty\n | `Empty_one_handler\n | `Empty_one_or_more_handlers\n | `Full\n | `Indir\n ]\n\n type ('a, 'b) t =\n | Empty_one_or_more_handlers :\n { mutable run : 'a -> unit\n ; execution_context : Execution_context.t\n ; mutable prev : 'a Handler.t\n ; mutable next : 'a Handler.t\n }\n -> ('a, [> `Empty_one_or_more_handlers ]) t\n | Empty_one_handler :\n ('a -> unit) * Execution_context.t\n -> ('a, [> `Empty_one_handler ]) t\n | Empty : ('a, [> `Empty ]) t\n | Full : 'a -> ('a, [> `Full ]) t\n | Indir : 'a Ivar.t -> ('a, [> `Indir ]) t\nend =\n Cell\n\nand Handler : sig\n type 'a t = ('a, [ `Empty_one_or_more_handlers ]) Cell.t\nend =\n Handler\n\nand Ivar : sig\n type 'a t = { mutable cell : ('a, Cell.any) Cell.t }\n\n module Immutable : sig\n type 'a t = { cell : ('a, Cell.any) Cell.t }\n end\nend =\n Ivar\n\nand Deferred : sig\n type +'a t\nend =\n Deferred\n\nand Execution_context : sig\n type t =\n { monitor : Monitor.t\n ; priority : Priority.t\n ; local_storage : Univ_map.t\n ; tid : int\n ; backtrace_history : Backtrace.t list\n }\nend =\n Execution_context\n\nand Monitor : sig\n type t =\n { name : Info.t\n ; here : Source_code_position.t option\n ; id : int\n ; parent : t option\n ; mutable next_error : exn Ivar.t\n ; mutable handlers_for_all_errors : (Execution_context.t * (exn -> unit)) Bag.t\n ; mutable tails_for_all_errors : exn Tail.t list\n ; mutable has_seen_error : bool\n ; mutable is_detached : bool\n }\nend =\n Monitor\n\nand Tail : sig\n type 'a t = { mutable next : 'a Stream.next Ivar.t }\nend =\n Tail\n\nand Stream : sig\n type 'a t = 'a next Deferred.t\n\n and 'a next =\n | Nil\n | Cons of 'a * 'a t\nend =\n Stream\n\n(* We avoid using [module rec] to define [Bvar], so that [to_repr] and [of_repr] are\n inlined. *)\nmodule Bvar : sig\n type ('a, -'permission) t\n\n (** [repr] exists so that we may hide the implementation of a [Bvar.t], and then add a\n phantom type to it upstream. Without this, the phantom type variable would allow\n for anything to be coerced in and out, since it is unused. *)\n type 'a repr =\n { mutable has_any_waiters : bool\n ; mutable ivar : 'a Ivar.t\n }\n\n val of_repr : 'a repr -> ('a, 'permission) t\n val to_repr : ('a, 'permission) t -> 'a repr\nend = struct\n type 'a repr =\n { mutable has_any_waiters : bool\n ; mutable ivar : 'a Ivar.t\n }\n\n type ('a, 'permission) t = 'a repr\n\n let to_repr t = t\n let of_repr t = t\nend\n\nmodule rec Event : sig\n module Status : sig\n type t =\n | Aborted\n | Fired\n | Happening\n | Scheduled\n | Unscheduled\n end\n\n type t =\n { mutable alarm : Job_or_event.t Timing_wheel.Alarm.t\n ; mutable at : Time_ns.t\n ; callback : unit -> unit\n ; execution_context : Execution_context.t\n ; mutable interval : Time_ns.Span.t option\n ; mutable next_fired : t\n ; mutable status : Status.t\n }\nend =\n Event\n\nand External_job : sig\n type t = T : Execution_context.t * ('a -> unit) * 'a -> t\nend =\n External_job\n\nand Job : sig\n type slots = (Execution_context.t, Obj.t -> unit, Obj.t) Pool.Slots.t3\n type t = slots Pool.Pointer.t\nend =\n Job\n\nand Job_or_event : sig\n type t\nend =\n Job_or_event\n\nand Job_pool : sig\n type t = Job.slots Pool.t\nend =\n Job_pool\n\nand Job_queue : sig\n type t =\n { mutable num_jobs_run : int\n ; mutable jobs_left_this_cycle : int\n ; mutable jobs : Obj.t Uniform_array.t\n ; mutable mask : int\n ; mutable front : int\n ; mutable length : int\n }\nend =\n Job_queue\n\nand Jobs : sig\n type t =\n { scheduler : Scheduler.t\n ; mutable job_pool : Job_pool.t\n ; normal : Job_queue.t\n ; low : Job_queue.t\n }\nend =\n Jobs\n\nand Scheduler : sig\n\n type t =\n { mutable check_access : (unit -> unit) option\n ; mutable job_pool : Job_pool.t\n ; normal_priority_jobs : Job_queue.t\n ; low_priority_jobs : Job_queue.t\n ; very_low_priority_workers : Very_low_priority_worker.t Deque.t\n ; mutable main_execution_context : Execution_context.t\n ; mutable current_execution_context : Execution_context.t\n ; mutable uncaught_exn : (Exn.t * Sexp.t) option\n ; mutable cycle_count : int\n ; mutable cycle_start : Time_ns.t\n ; mutable in_cycle : bool\n ; mutable run_every_cycle_start : (unit -> unit) list\n ; mutable run_every_cycle_end : (unit -> unit) list\n ; mutable last_cycle_time : Time_ns.Span.t\n ; mutable last_cycle_num_jobs : int\n ; mutable total_cycle_time : Time_ns.Span.t\n ; mutable time_source : read_write Time_source.t1\n ; external_jobs : External_job.t Thread_safe_queue.t\n ; mutable thread_safe_external_job_hook : unit -> unit\n ; mutable job_queued_hook : (Priority.t -> unit) option\n ; mutable event_added_hook : (Time_ns.t -> unit) option\n ; mutable yield : (unit, read_write) Bvar.t\n ; mutable yield_until_no_jobs_remain : (unit, read_write) Bvar.t\n ; mutable check_invariants : bool\n ; mutable max_num_jobs_per_priority_per_cycle : Max_num_jobs_per_priority_per_cycle.t\n ; mutable record_backtraces : bool\n ; mutable on_start_of_cycle : unit -> unit\n ; mutable on_end_of_cycle : unit -> unit\n ; mutable long_jobs_last_cycle : (Execution_context.t * Time_ns.Span.t) list\n ; mutable cycle_started : bool\n }\nend =\n Scheduler\n\nand Time_source_id : Unique_id.Id = Unique_id.Int63 ()\n\nand Time_source : sig\n type -'rw t1 =\n { id : Time_source_id.t\n ; mutable advance_errors : Error.t list\n ; mutable am_advancing : bool\n ; events : Job_or_event.t Timing_wheel.t\n ; mutable fired_events : Event.t\n ; mutable most_recently_fired : Event.t\n ; handle_fired : Job_or_event.t Timing_wheel.Alarm.t -> unit\n ; is_wall_clock : bool\n ; scheduler : Scheduler.t\n }\nend =\n Time_source\n\nand Very_low_priority_worker : sig\n module Exec_result : sig\n type t =\n | Finished\n | Not_finished\n end\n\n type t =\n { execution_context : Execution_context.t\n ; exec : unit -> Exec_result.t\n }\nend =\n Very_low_priority_worker\n","open! Core_kernel\nopen! Import\nmodule Monitor = Monitor0\n\ntype t = Types.Execution_context.t =\n { monitor : Monitor.t\n ; priority : Priority.t\n ; local_storage : Univ_map.t\n ; tid : int\n ; backtrace_history : Backtrace.t list\n }\n[@@deriving fields, sexp_of]\n\nlet invariant (_ : t) = ()\n\nlet main =\n { monitor = Monitor.main\n ; priority = Priority.normal\n ; local_storage = Univ_map.empty\n ; tid = 0\n ; backtrace_history = []\n }\n;;\n\nlet create_like ?monitor ?priority ?local_storage t =\n let monitor = Option.value monitor ~default:t.monitor in\n { monitor\n ; priority = Option.value priority ~default:t.priority\n ; local_storage = Option.value local_storage ~default:t.local_storage\n ; tid = t.tid\n ; backtrace_history = t.backtrace_history\n }\n;;\n\nlet find_local t key = Univ_map.find t.local_storage key\n\nlet with_local t key data =\n { t with local_storage = Univ_map.change t.local_storage key ~f:(fun _ -> data) }\n;;\n\nlet with_tid t tid =\n { t with tid }\n;;\n\nlet record_backtrace t =\n { t with backtrace_history = Backtrace.get () :: t.backtrace_history }\n;;\n","open! Core_kernel\nopen! Import\nmodule Scheduler = Scheduler0\n\nlet dummy_e = Execution_context.main\nlet dummy_f : Obj.t -> unit = ignore\nlet dummy_a : Obj.t = Obj.repr ()\nlet slots_per_elt = 3\n\nmodule A = Uniform_array\n\n(* This is essentially a specialized [Flat_queue], done for reasons of speed. *)\ntype t = Types.Job_queue.t =\n { mutable num_jobs_run : int\n ; mutable jobs_left_this_cycle : int\n ; (* [jobs] is an array of length [capacity t * slots_per_elt], where each elt has the\n three components of a job ([execution_context], [f], [a]) in consecutive spots in\n [jobs]. [enqueue] doubles the length of [jobs] if [jobs] is full. [jobs] never\n shrinks. [jobs] is somewhat like a [Core_kernel.Pool] specialized to 3-tuples; we\n don't use [Pool] because that implements a set, where [jobs] is a queue. *)\n mutable jobs : (Obj.t A.t[@sexp.opaque])\n ; (* [mask] is [capacity t - 1], and is used for quickly computing [i mod (capacity\n t)] *)\n mutable mask : int\n ; (* [front] is the index of the first job in the queue. The array index of that job's\n execution context is [front * slots_per_elt]. *)\n mutable front : int\n ; mutable length : int\n }\n[@@deriving fields, sexp_of]\n\nlet offset t i = (t.front + i) land t.mask * slots_per_elt\nlet capacity t = t.mask + 1\n\nlet invariant t : unit =\n Invariant.invariant [%here] t [%sexp_of: t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~num_jobs_run:(check (fun num_jobs_run -> assert (num_jobs_run >= 0)))\n ~jobs_left_this_cycle:\n (check (fun jobs_left_this_cycle -> assert (jobs_left_this_cycle >= 0)))\n ~jobs:\n (check (fun jobs ->\n for i = 0 to t.length - 1 do\n Execution_context.invariant\n (Obj.obj (A.get jobs (offset t i)) : Execution_context.t)\n done))\n ~mask:\n (check (fun mask ->\n let capacity = mask + 1 in\n assert (Int.is_pow2 capacity);\n assert (capacity * slots_per_elt = A.length t.jobs)))\n ~front:\n (check (fun front ->\n assert (front >= 0);\n assert (front < capacity t)))\n ~length:\n (check (fun length ->\n assert (length >= 0);\n assert (length <= capacity t))))\n;;\n\nlet create_array ~capacity = A.create_obj_array ~len:(capacity * slots_per_elt)\n\nlet create () =\n let capacity = 1 in\n { num_jobs_run = 0\n ; jobs_left_this_cycle = 0\n ; jobs = create_array ~capacity\n ; mask = capacity - 1\n ; front = 0\n ; length = 0\n }\n;;\n\nlet clear t =\n t.front <- 0;\n t.length <- 0;\n t.jobs_left_this_cycle <- 0\n;;\n\nlet grow t =\n let old_capacity = capacity t in\n let new_capacity = old_capacity * 2 in\n let old_jobs = t.jobs in\n let old_front = t.front in\n let len1 = Int.min t.length (old_capacity - old_front) * slots_per_elt in\n let len2 = (t.length * slots_per_elt) - len1 in\n let new_jobs = create_array ~capacity:new_capacity in\n A.blit\n ~len:len1\n ~src:old_jobs\n ~src_pos:(old_front * slots_per_elt)\n ~dst:new_jobs\n ~dst_pos:0;\n A.blit ~len:len2 ~src:old_jobs ~src_pos:0 ~dst:new_jobs ~dst_pos:len1;\n t.mask <- new_capacity - 1;\n t.jobs <- new_jobs;\n t.front <- 0\n;;\n\nlet set (type a) t i execution_context f a =\n let offset = offset t i in\n A.unsafe_set t.jobs offset (Obj.repr (execution_context : Execution_context.t));\n A.unsafe_set t.jobs (offset + 1) (Obj.repr (f : a -> unit));\n A.unsafe_set t.jobs (offset + 2) (Obj.repr (a : a))\n;;\n\nlet enqueue t execution_context f a =\n if t.length = capacity t then grow t;\n set t t.length execution_context f a;\n t.length <- t.length + 1\n;;\n\nlet set_jobs_left_this_cycle t n =\n if n < 0\n then\n raise_s\n [%message \"Jobs.set_jobs_left_this_cycle got negative number\" (n : int) (t : t)];\n t.jobs_left_this_cycle <- n\n;;\n\nlet can_run_a_job t = t.length > 0 && t.jobs_left_this_cycle > 0\n\nlet run_job t (scheduler : Scheduler.t) execution_context f a =\n t.num_jobs_run <- t.num_jobs_run + 1;\n Scheduler.set_execution_context scheduler execution_context;\n f a\n;;\n\nlet run_external_jobs t (scheduler : Scheduler.t) =\n let external_jobs = scheduler.external_jobs in\n while Thread_safe_queue.length external_jobs > 0 do\n let (External_job.T (execution_context, f, a)) =\n Thread_safe_queue.dequeue_exn external_jobs\n in\n run_job t scheduler execution_context f a\n done\n;;\n\nlet run_jobs (type a) t (scheduler : Scheduler.t) =\n (* We do the [try-with] outside of the [while] because it is cheaper than doing a\n [try-with] for each job. *)\n (* [run_external_jobs] before entering the loop, since it might enqueue a job,\n changing [t.length]. *)\n try\n run_external_jobs t scheduler;\n while can_run_a_job t do\n let this_job = offset t 0 in\n let execution_context : Execution_context.t =\n Obj.obj (A.unsafe_get t.jobs this_job)\n in\n let f : a -> unit = Obj.obj (A.unsafe_get t.jobs (this_job + 1)) in\n let a : a = Obj.obj (A.unsafe_get t.jobs (this_job + 2)) in\n (* We clear out the job right now so that it isn't live at the next minor\n collection. We tried not doing this and saw significant (15% or so) performance\n hits due to spurious promotion. *)\n set t 0 dummy_e dummy_f dummy_a;\n t.front <- (t.front + 1) land t.mask;\n t.length <- t.length - 1;\n t.jobs_left_this_cycle <- t.jobs_left_this_cycle - 1;\n (* It is OK if [run_job] or [run_external_jobs] raises, in which case the exn is\n handled by the outer try-with. The only side effects we have done are to take\n the job out of the queue and decrement [jobs_left_this_cycle]. [run_job] or\n [run_external_jobs] may side effect [t], either by enqueueing jobs, or by\n clearing [t]. *)\n (!Tracing.fns).on_job_enter execution_context ;\n let start = Time_ns.now () in\n run_job t scheduler execution_context f a;\n let this_job_time = Time_ns.(diff (now ()) start) in\n if Float.(Time_ns.Span.to_ms this_job_time >= 2000.) then scheduler.long_jobs_last_cycle <- (execution_context, this_job_time) :: scheduler.long_jobs_last_cycle;\n (!Tracing.fns).on_job_exit execution_context this_job_time ;\n (* [run_external_jobs] at each iteration of the [while] loop, for fairness. *)\n run_external_jobs t scheduler\n done;\n Ok ()\n with\n | exn ->\n (* We call [Exn.backtrace] immediately after catching an unhandled exception, to\n ensure there is no intervening code that interferes with the global backtrace\n state. *)\n let backtrace = Backtrace.Exn.most_recent () in\n Error (exn, backtrace)\n;;\n","type tracing_fns =\n { on_job_enter : Execution_context.t -> unit\n ; on_job_exit : Execution_context.t -> Time_ns.Span.t -> unit }\n\nlet fns = ref { on_job_enter= (fun _ -> ()); on_job_exit= (fun _ _ -> ()) }\n","open! Core_kernel\nopen! Import\ninclude Types.External_job\n\nlet sexp_of_t _ = Sexp.Atom \"\"\n","open! Core_kernel\nopen! Import\nopen Pool\nmodule Pointer = Pointer\nmodule Slot = Slot\n\nlet dummy_e = Execution_context.main\nlet dummy_f : Obj.t -> unit = ignore\nlet dummy_a : Obj.t = Obj.repr ()\n\ntype slots = (Execution_context.t, Obj.t -> unit, (Obj.t[@sexp.opaque])) Slots.t3\n[@@deriving sexp_of]\n\ntype t = slots Pool.t [@@deriving sexp_of]\n\nlet invariant t = Pool.invariant ignore t\nlet create () = create Slots.t3 ~capacity:1 ~dummy:(dummy_e, dummy_f, dummy_a)\n","open! Core_kernel\nopen! Import\nmodule Event = Types.Event\nmodule Job = Types.Job\ninclude Types.Job_or_event\n\n(* This redefinition of [Event] is here so the type checks are right next to\n [Obj.magic]s. *)\nmodule Event_is_block : sig end = struct\n open Types\n open Event\n\n type _t = t =\n { (* must never be immediate *)\n mutable alarm : Job_or_event.t Timing_wheel.Alarm.t\n ; mutable at : Time_ns.t\n ; callback : unit -> unit\n ; execution_context : Execution_context.t\n ; mutable interval : Time_ns.Span.t option\n ; mutable next_fired : t\n ; mutable status : Status.t\n }\nend\n\nmodule Job_is_not_block : sig end = struct\n module Ensure_private_int (M : sig\n type t = private int\n end) =\n struct\n type _t = M.t\n end\n\n include Ensure_private_int (Job)\nend\n\nlet of_event event : t = Obj.magic (event : Event.t)\nlet of_job job : t = Obj.magic (job : Job.t)\nlet is_event (t : t) = Obj.is_block (Obj.repr t)\nlet is_job (t : t) = Obj.is_int (Obj.repr t)\n\nmodule Match = struct\n type _ kind =\n | Event : Event.t kind\n | Job : Job.t kind\n\n type packed = K : _ kind -> packed\n\n let kind t = if is_event t then K Event else K Job\n let project (type a) (_ : a kind) job_or_event = (Obj.magic : t -> a) job_or_event\nend\n","open! Core_kernel\nopen! Import\ninclude Types.Scheduler\n\nlet events t = t.time_source.events\n\nlet set_execution_context t execution_context =\n (* Avoid a caml_modify in most cases. *)\n (* XXX: see where job_queue also modifies current_execution_context *)\n if not (phys_equal t.current_execution_context execution_context) then (\n t.cycle_started <- false ;\n t.current_execution_context <- execution_context )\n","open! Core_kernel\nopen! Import\n\nmodule Time_ns = struct\n include Time_ns\n\n external format : float -> string -> string = \"core_kernel_time_ns_format\"\n\n (* We use a more pleasant format than [Core_kernel.Time_ns.sexp_of_t],\n which has to be messier for round trippability. *)\n let sexp_of_t t =\n [%sexp\n (format (t |> to_span_since_epoch |> Span.to_sec) \"%Y-%m-%dT%H:%M:%S%z\" : string)]\n ;;\nend\n\nmodule Alarm = struct\n include Timing_wheel.Alarm\n\n let is_null t = phys_equal t (null ())\nend\n\nmodule Alarm_precision = Timing_wheel.Alarm_precision\n\nlet default_timing_wheel_config =\n (* 1/8th of a millisecond alarm_precision seems sufficient to avoid having many alarms\n in the same interval, which avoids quadratic insertion sort when firing alarms. And\n the level bits give us levels of >1s, >1m, >1h, >1d. See test in\n [../test/test_synchronous_time_source.ml]. *)\n Timing_wheel.Config.create\n ~alarm_precision:Alarm_precision.(div about_one_millisecond ~pow2:3)\n ~level_bits:(Timing_wheel.Level_bits.create_exn [ 13; 6; 6; 5 ])\n ()\n;;\n\ntype callback = unit -> unit\n\nmodule Id = Types.Time_source_id\n\nmodule T1 = struct\n module Event = struct\n module Status = struct\n type t = Types.Event.Status.t =\n | Aborted\n (* in [fired_events], must not run *)\n | Fired\n (* in [fired_events], ready to run *)\n | Happening\n (* currently running the callback *)\n | Scheduled\n (* in the timing wheel *)\n | Unscheduled (* not in timing wheel or [fired_events] *)\n [@@deriving compare, sexp_of]\n\n let transition_is_allowed ~from ~to_ =\n match from, to_ with\n | Aborted, Unscheduled (* skipped running callback *)\n | Fired, Happening (* started running callback *)\n | Fired, Aborted (* aborted *)\n | Happening, Scheduled (* for repeating events *)\n | Happening, Unscheduled (* event callback finished *)\n | Scheduled, Fired (* moved from timing wheel to [fired_events] *)\n | Scheduled, Unscheduled (* aborted *)\n | Unscheduled, Fired (* event scheduled in the past *)\n | Unscheduled, Scheduled (* event scheduled in the future *) -> true\n | (Aborted | Fired | Happening | Scheduled | Unscheduled), _ -> false\n ;;\n end\n\n type t = Types.Event.t =\n { (* [alarm] is non-null iff the event is in the timing wheel. *)\n mutable alarm : Job_or_event.t Alarm.t\n ; mutable at : Time_ns.t\n ; callback : unit -> unit\n ; execution_context : Execution_context.t\n ; (* [interval] is the period for the periodic events *)\n mutable interval : Time_ns.Span.t option\n ; (* [next_fired] is a singly-linked list of fired events, linked via [next_fired].\n An event is added to the list when it fires, either because it is added with a\n time in the past, or because time advances. [advance_by_alarms] iterates over\n the events in [next_fired] and runs them, emptying the list. *)\n mutable next_fired : t\n ; mutable status : Status.t\n }\n [@@deriving fields]\n\n (* [none] is used to indicate the end of the singly-linked list of fired events. *)\n let rec none =\n { alarm = Alarm.null ()\n ; at = Time_ns.min_value_for_1us_rounding\n ; callback = (fun () -> assert false)\n ; execution_context = Execution_context.main\n ; interval = None\n ; next_fired = none\n ; status = Unscheduled\n }\n ;;\n\n let is_none t = phys_equal t none\n let is_some t = not (is_none t)\n\n let sexp_of_t\n ({ alarm = _\n ; at\n ; callback = _\n ; execution_context = _\n ; interval\n ; next_fired = _\n ; status\n } as t)\n =\n if is_none t\n then [%sexp \"none\"]\n else\n [%message\n \"\" (status : Status.t) (at : Time_ns.t) (interval : Time_ns.Span.t option)]\n ;;\n\n let invariant t =\n Invariant.invariant [%here] t [%sexp_of: t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~alarm:\n (check (fun alarm ->\n [%test_result: bool]\n (Alarm.is_null alarm)\n ~expect:\n (match t.status with\n | Aborted | Fired | Happening | Unscheduled -> true\n | Scheduled -> false)))\n ~at:ignore\n ~callback:ignore\n ~execution_context:ignore\n ~interval:ignore\n ~next_fired:\n (check (fun next_fired ->\n if is_some next_fired\n then (\n match t.status with\n | Aborted | Fired -> ()\n | Happening | Scheduled | Unscheduled -> assert false)))\n ~status:ignore)\n ;;\n\n let compare_at t1 t2 = Time_ns.compare t1.at t2.at\n\n let set_status t to_ =\n let from = t.status in\n if not (Status.transition_is_allowed ~from ~to_)\n then\n raise_s\n [%message\n [%here]\n \"bug -- set_status transition not allowed\"\n (from : Status.t)\n (to_ : Status.t)\n ~event:(t : t)];\n t.status <- to_\n ;;\n end\n\n module Job_or_event = struct\n include Job_or_event\n\n let sexp_of_t t =\n let open Job_or_event.Match in\n let (K k) = kind t in\n match k, project k t with\n | Event, event -> [%sexp (event : Event.t)]\n | Job, _ ->\n (* We don't display the [Job.t]s in [events] because those are\n pool pointers, which are uninformative. *)\n [%message \"\"]\n ;;\n end\n\n type -'rw t = 'rw Types.Time_source.t1 =\n { id : Id.t\n ; (* [advance_errors] accumulates errors raised by alarms run by\n [advance_by_alarms]. *)\n mutable advance_errors : Error.t list\n ; (* [am_advancing] is true only during [advance_by_alarms], and is used to cause\n callbacks to raise if they call [advance_by_alarms]. *)\n mutable am_advancing : bool\n ; events : Job_or_event.t Timing_wheel.t\n ; (* [fired_events] is the front of the singly linked list of fired events, which is\n stored in increasing order of [Event.at]. *)\n mutable fired_events : Event.t\n ; (* [most_recently_fired] is the event that was most recently inserted into\n [fired_events]. It is used as an optimization to allow insertion of subsequent\n events to start later in the list rather than at the beginning. It specifically\n avoids quadratic behavior when inserting multiple events that have exactly the\n same time -- the time source fires such events in the order they were added, and\n we want them to be in that same order in [fired_events]. *)\n mutable most_recently_fired : Event.t\n ; (* We store [handle_fired] in [t] to avoid allocating it every time we call\n [advance_clock]. *)\n handle_fired : Job_or_event.t Alarm.t -> unit\n ; is_wall_clock : bool\n ; scheduler : Scheduler0.t\n }\n [@@deriving fields]\n\n (* We don't include the [id] in the sexp because the user (rightly) can't control it, so\n it's hard to make it deterministic in tests. *)\n let sexp_of_t\n _\n { id = _\n ; advance_errors = _\n ; am_advancing = _\n ; events\n ; fired_events = _\n ; handle_fired = _\n ; is_wall_clock\n ; most_recently_fired = _\n ; scheduler = _\n }\n =\n let now = Timing_wheel.now events in\n if is_wall_clock\n then [%message \"wall_clock\" (now : Time_ns.t)]\n else (\n let all_events = ref [] in\n Timing_wheel.iter events ~f:(fun alarm ->\n all_events := (Alarm.at events alarm, Alarm.value events alarm) :: !all_events);\n let events =\n List.sort !all_events ~compare:(fun (at1, _) (at2, _) -> Time_ns.compare at1 at2)\n |> List.map ~f:snd\n in\n [%message \"\" (now : Time_ns.t) (events : Job_or_event.t list)])\n ;;\n\n let timing_wheel_now t = Timing_wheel.now t.events\n\n let is_in_fired_events t event =\n with_return (fun r ->\n let current = ref t.fired_events in\n while Event.is_some !current do\n if phys_equal !current event then r.return true;\n current := !current.next_fired\n done;\n false)\n ;;\n\n let invariant_with_jobs (type rw) ~job:(job_invariant : Job.t -> unit) (t : rw t) =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter\n ~id:ignore\n ~advance_errors:ignore\n ~am_advancing:ignore\n ~events:\n (check (fun events ->\n Timing_wheel.invariant ignore events;\n Timing_wheel.iter events ~f:(fun alarm ->\n let job_or_event = Alarm.value events alarm in\n let open Job_or_event.Match in\n let (K k) = kind job_or_event in\n match k, project k job_or_event with\n | Job, job -> job_invariant job\n | Event, event ->\n assert (phys_equal alarm event.alarm);\n [%test_result: Time_ns.t] event.at ~expect:(Alarm.at events alarm);\n [%test_result: Event.Status.t] event.status ~expect:Scheduled)))\n ~fired_events:\n (check (fun (fired_events : Event.t) ->\n let current = ref fired_events in\n while Event.is_some !current do\n assert (Time_ns.( <= ) !current.at (timing_wheel_now t));\n let next = !current.next_fired in\n if Event.is_some next then assert (Time_ns.( <= ) !current.at next.at);\n current := next\n done))\n ~handle_fired:ignore\n ~is_wall_clock:ignore\n ~most_recently_fired:\n (check (fun most_recently_fired ->\n if Event.is_some t.most_recently_fired\n then assert (is_in_fired_events t most_recently_fired)))\n ~scheduler:ignore)\n ;;\n\n let invariant t = invariant_with_jobs ~job:(fun _ -> ()) t\nend\n\nopen T1\n\ntype t = read T1.t [@@deriving sexp_of]\n\nlet invariant = invariant\nlet invariant_with_jobs = invariant_with_jobs\n\nmodule Read_write = struct\n type t = read_write T1.t [@@deriving sexp_of]\n\n let invariant = invariant\n let invariant_with_jobs = invariant_with_jobs\nend\n\nlet id t = t.id\nlet is_wall_clock t = t.is_wall_clock\nlet length t = Timing_wheel.length t.events\nlet max_allowed_alarm_time t = Timing_wheel.max_allowed_alarm_time t.events\nlet read_only (t : [> read ] T1.t) = (t :> t)\n\n(* [fire t event] sets [event.status = Fired] and inserts [event] into [t.fired_events] in\n sorted time order. *)\nlet fire t (event : Event.t) =\n Event.set_status event Fired;\n event.alarm <- Alarm.null ();\n let prev = ref Event.none in\n let current = ref t.fired_events in\n (* If [event] belongs after [t.most_recently_fired], then we start the insertion there\n rather than at the front of [t.fired_events]. This works nicely if we're getting the\n alarms in non-decreasing time order, which is close to what [Timing_wheel]\n provides (although [Timing_wheel] doesn't guarantee time ordering for times in the\n same interval). *)\n if Event.is_some t.most_recently_fired\n && Time_ns.( >= ) event.at t.most_recently_fired.at\n then (\n prev := t.most_recently_fired;\n current := !prev.next_fired);\n (* We use [Time_ns.( <= )] rather than [<] so that [event] is added after other events\n at the same time. Since [Timing_wheel] fires alarms in a bucket in the order in\n which they were added, using [<=] keeps events at the same time in the order in which\n they were added. *)\n while Event.is_some !current && Time_ns.( <= ) !current.at event.at do\n prev := !current;\n current := !current.next_fired\n done;\n event.next_fired <- !current;\n t.most_recently_fired <- event;\n if Event.is_none !prev then t.fired_events <- event else !prev.next_fired <- event\n;;\n\nlet alarm_precision t = Timing_wheel.alarm_precision t.events\nlet next_alarm_fires_at t = Timing_wheel.next_alarm_fires_at t.events\nlet now t = if t.is_wall_clock then Time_ns.now () else timing_wheel_now t\nlet timing_wheel_now = timing_wheel_now\n\nlet schedule t (event : Event.t) =\n Event.set_status event Scheduled;\n event.alarm <- Timing_wheel.add t.events ~at:event.at (event |> Job_or_event.of_event)\n;;\n\nmodule Event = struct\n include Event\n\n let create_internal t ~at ~interval ~callback =\n { alarm = Alarm.null ()\n ; at\n ; callback\n ; execution_context = t.scheduler.current_execution_context\n ; interval\n ; next_fired = none\n ; status = Unscheduled\n }\n ;;\n\n let add t event =\n if Time_ns.( <= ) event.at (timing_wheel_now t)\n then fire t event\n else schedule t event\n ;;\n\n let create_and_add t ~at ~interval ~callback =\n let event = create_internal t ~at ~interval ~callback in\n add t event;\n event\n ;;\n\n let at t at callback = create_and_add t ~at ~interval:None ~callback\n\n let after t span callback =\n create_and_add t ~at:(Time_ns.after (now t) span) ~interval:None ~callback\n ;;\n\n let require_span_at_least_alarm_precision t span =\n let alarm_precision = alarm_precision t in\n if Time_ns.Span.( < ) span alarm_precision\n then\n raise_s\n [%message\n \"interval span smaller than alarm precision\"\n (span : Time_ns.Span.t)\n (alarm_precision : Time_ns.Span.t)]\n ;;\n\n let at_intervals t span callback =\n require_span_at_least_alarm_precision t span;\n create_and_add t ~at:(now t) ~interval:(Some span) ~callback\n ;;\n\n module Abort_result = struct\n type t =\n | Ok\n | Currently_happening\n | Previously_unscheduled\n [@@deriving sexp_of]\n end\n\n let abort t (event : t) : Abort_result.t =\n match event.status with\n | Aborted -> Previously_unscheduled\n | Happening ->\n if Option.is_none event.interval\n then Currently_happening\n else (\n event.interval <- None;\n Ok)\n | Fired ->\n Event.set_status event Aborted;\n Ok\n | Scheduled ->\n Event.set_status event Unscheduled;\n Timing_wheel.remove t.events event.alarm;\n event.alarm <- Alarm.null ();\n Ok\n | Unscheduled -> Previously_unscheduled\n ;;\n\n let abort_if_possible t event = ignore (abort t event : Abort_result.t)\n\n let abort_exn t event =\n match abort t event with\n | Ok -> ()\n | reason ->\n raise_s\n [%message\n \"[Synchronous_time_source.abort_exn] cannot abort event\"\n (reason : Abort_result.t)]\n ;;\n\n let create t callback = create_internal t ~at:Time_ns.epoch ~interval:None ~callback\n\n let schedule_at_internal t (event : t) at ~interval =\n (* [Fired] is disallowed to prevent the user from entering into an infinite loop. The\n user could specify [at] in the past which would constantly add [callback] to the\n back of [t.next_fired] if this function is called from [callback]. *)\n match event.status with\n | (Aborted | Happening | Scheduled | Fired) as status ->\n Or_error.error_s\n [%message \"cannot schedule an event with status\" ~_:(status : Event.Status.t)]\n | Unscheduled ->\n event.at <- at;\n event.interval <- interval;\n add t event;\n Ok ()\n ;;\n\n let schedule_at t event at = schedule_at_internal t event at ~interval:None\n let schedule_after t event span = schedule_at t event (Time_ns.after (now t) span)\n\n let schedule_at_intervals t event span =\n require_span_at_least_alarm_precision t span;\n schedule_at_internal t event (now t) ~interval:(Some span)\n ;;\n\n module Reschedule_result = struct\n type t =\n | Ok\n | Currently_happening\n | Recently_aborted\n | Recently_fired\n [@@deriving sexp_of]\n end\n\n let reschedule_at t event at : Reschedule_result.t =\n match event.status with\n | Aborted -> Recently_aborted\n | Fired -> Recently_fired\n | Happening -> Currently_happening\n | Scheduled ->\n event.at <- at;\n if Time_ns.( > ) at (timing_wheel_now t)\n then Timing_wheel.reschedule t.events event.alarm ~at\n else (\n Timing_wheel.remove t.events event.alarm;\n fire t event);\n Ok\n | Unscheduled ->\n event.at <- at;\n event.interval <- None;\n add t event;\n Ok\n ;;\n\n let reschedule_after t event span = reschedule_at t event (Time_ns.after (now t) span)\n\n module Option = struct\n type value = t\n type nonrec t = t\n\n let is_none = is_none\n let is_some = is_some\n\n let some value =\n (* This assert shouldn't fail because [t] is a [value] and so should never\n be [none]. *)\n assert (is_some value);\n value\n ;;\n\n (* It should be impossible for [some_is_representable] to return [false]\n because its input is a [value], but since it's only loosely enforced we\n handle the general case. *)\n let some_is_representable value =\n assert (is_some value);\n true\n ;;\n\n let none = none\n let unchecked_value = Fn.id\n let value t ~default = if is_none t then default else unchecked_value t\n\n let value_exn t =\n if is_none t\n then raise_s [%message \"[Synchronous_time_source.Event.Option.value_exn None]\"];\n t\n ;;\n\n let to_option t = if is_none t then None else Some t\n\n let of_option = function\n | None -> none\n | Some t -> some t\n ;;\n\n let sexp_of_t t = to_option t |> [%sexp_of: t option]\n\n module Optional_syntax = struct\n module Optional_syntax = struct\n let is_none = is_none\n let unsafe_value = Fn.id\n end\n end\n end\n\nend\n\nlet run_after t span callback = ignore (Event.after t span callback : Event.t)\nlet run_at t at callback = ignore (Event.at t at callback : Event.t)\n\nlet run_at_intervals t span callback =\n ignore (Event.at_intervals t span callback : Event.t)\n;;\n\ntype send_exn = Monitor0.t -> ?backtrace:[ `Get | `This of Backtrace.t ] -> exn -> unit\n\nlet run_fired_events t ~(send_exn : send_exn option) =\n let current_execution_context = t.scheduler.current_execution_context in\n while Event.is_some t.fired_events do\n let event = t.fired_events in\n if phys_equal event t.most_recently_fired then t.most_recently_fired <- Event.none;\n t.fired_events <- event.next_fired;\n event.next_fired <- Event.none;\n match event.status with\n | Aborted -> Event.set_status event Unscheduled\n | Happening | Scheduled | Unscheduled -> assert false\n | Fired ->\n Event.set_status event Happening;\n (* We set the execution context so that [event.callback] runs in the same context\n that was in place when [event] was created. *)\n Scheduler0.set_execution_context t.scheduler event.execution_context;\n (match event.callback () with\n | exception exn ->\n (match send_exn with\n | None -> t.advance_errors <- Error.of_exn exn :: t.advance_errors\n | Some send_exn ->\n let backtrace = Backtrace.get () in\n send_exn event.execution_context.monitor exn ~backtrace:(`This backtrace));\n Event.set_status event Unscheduled\n | () ->\n (match event.interval with\n | None -> Event.set_status event Unscheduled\n | Some interval ->\n event.at\n <- Time_ns.next_multiple\n ()\n ~base:event.at\n ~after:(timing_wheel_now t)\n ~interval;\n schedule t event))\n done;\n Scheduler0.set_execution_context t.scheduler current_execution_context\n;;\n\nlet advance_clock t ~to_ ~send_exn =\n Timing_wheel.advance_clock t.events ~to_ ~handle_fired:t.handle_fired;\n run_fired_events t ~send_exn\n;;\n\nlet fire_past_alarms t ~send_exn =\n Timing_wheel.fire_past_alarms t.events ~handle_fired:t.handle_fired;\n run_fired_events t ~send_exn\n;;\n\nlet advance_internal t ~to_ ~send_exn =\n advance_clock t ~to_ ~send_exn;\n fire_past_alarms t ~send_exn\n;;\n\nlet prepare_to_advance t ~send_exn =\n if t.am_advancing\n then raise_s [%message \"cannot call [advance_by_alarms] from callback\"];\n t.am_advancing <- true;\n (match t.advance_errors with\n | [] -> ()\n | _ -> t.advance_errors <- []);\n run_fired_events t ~send_exn\n;;\n\nlet finish_advancing t =\n t.am_advancing <- false;\n match t.advance_errors with\n | [] -> Ok ()\n | errors ->\n t.advance_errors <- [];\n Error (Error.of_list errors)\n;;\n\nlet advance_by_alarms t ~to_ =\n let send_exn = None in\n prepare_to_advance t ~send_exn;\n let continue = ref true in\n while !continue do\n if Timing_wheel.is_empty t.events\n then continue := false\n else (\n let next_alarm_fires_at = Timing_wheel.next_alarm_fires_at_exn t.events in\n if Time_ns.( >= ) next_alarm_fires_at to_\n then continue := false\n else\n (* We use the actual alarm time, rather than [next_alarm_fires_at], so as not to\n expose (or accumulate errors associated with) the precision of\n [Timing_wheel]. *)\n advance_internal\n t\n ~to_:(Timing_wheel.max_alarm_time_in_min_interval_exn t.events)\n ~send_exn)\n done;\n advance_internal t ~to_ ~send_exn;\n finish_advancing t\n;;\n\nlet advance_directly t ~to_ =\n let send_exn = None in\n prepare_to_advance t ~send_exn;\n advance_internal t ~to_ ~send_exn;\n finish_advancing t\n;;\n\nmodule Expert = struct\n let max_alarm_time_in_min_timing_wheel_interval t =\n Timing_wheel.max_alarm_time_in_min_interval t.events\n ;;\n\n let has_events_to_run t = Event.is_some t.fired_events\nend\n","open Core_kernel\nopen Import\ninclude Scheduler0\nmodule Synchronous_time_source = Synchronous_time_source0\nmodule Event = Synchronous_time_source.Event\nmodule Alarm = Timing_wheel.Alarm\nmodule Job_or_event = Synchronous_time_source.T1.Job_or_event\n\nlet debug = Debug.scheduler\n\nmodule Ivar = struct\n open Types.Ivar\n\n let create_with_cell cell = { cell }\n let create () = create_with_cell Empty\n\n let create_full (type a) (a : a) =\n (* We allocate an immutable ivar and then cast it to a mutable ivar. The immutability\n allows OCaml to statically allocate the ivar if [a] is constant. This cast is safe\n because a full ivar is never mutated. We also believe that we will not trigger\n flambda to spuriously repor warning 59, mutation of known immutable data. All\n mutations of an ivar cell, i.e. [foo.cell <- ...], are directly preceded by a\n [match foo.cell] that prevents the [Full] case from reaching the modification. So\n flambda should always eliminate the [foo.cell <- ...] of a constant [Full] ivar,\n and not warn. *)\n (Obj.magic : a Immutable.t -> a t) { cell = Full a }\n ;;\nend\n\nmodule Bvar = struct\n open Types.Bvar\n\n let create () = of_repr { has_any_waiters = false; ivar = Ivar.create () }\nend\n\nmodule Very_low_priority_worker = struct\n module Exec_result = struct\n type t = Types.Very_low_priority_worker.Exec_result.t =\n | Finished\n | Not_finished\n [@@deriving sexp_of]\n end\n\n type t = Types.Very_low_priority_worker.t =\n { execution_context : Execution_context.t\n ; exec : unit -> Exec_result.t\n }\n [@@deriving fields, sexp_of]\n\n let invariant t =\n Invariant.invariant [%here] t [%sexp_of: t] (fun () ->\n let check f = Invariant.check_field t f in\n Fields.iter ~execution_context:(check Execution_context.invariant) ~exec:ignore)\n ;;\nend\n\ntype t = Scheduler0.t =\n { (* [check_access] optionally holds a function to run to check whether access to [t] is\n currently allowed. It is used to detect invalid access to the scheduler from a\n thread. *)\n mutable check_access : (unit -> unit) option\n ; mutable job_pool : Job_pool.t\n ; normal_priority_jobs : Job_queue.t\n ; low_priority_jobs : Job_queue.t\n ; very_low_priority_workers : Very_low_priority_worker.t Deque.t\n ; mutable main_execution_context : Execution_context.t\n ; mutable current_execution_context : Execution_context.t\n (* The scheduler calls [got_uncaught_exn] when an exception bubbles to the top of the\n monitor tree without being handled. This function guarantees to never run another\n job after this by calling [clear] and because [enqueue_job] will never add another\n job. *)\n ; mutable uncaught_exn : (Exn.t * Sexp.t) option\n ; mutable cycle_count : int\n ; mutable cycle_start : Time_ns.t\n ; mutable in_cycle : bool\n ; mutable run_every_cycle_start : (unit -> unit) list\n ; mutable run_every_cycle_end : (unit -> unit) list\n ; mutable last_cycle_time : Time_ns.Span.t\n ; mutable last_cycle_num_jobs : int\n ; mutable total_cycle_time : Time_ns.Span.t\n ; mutable time_source : read_write Synchronous_time_source.T1.t\n (* [external_jobs] is a queue of actions sent from outside of async. This is for the\n case where we want to schedule a job or fill an ivar from a context where it is not\n safe to run async code, because the async lock isn't held. For instance: - in an\n OCaml finalizer, as they can run at any time in any thread.\n\n The way to do it is to queue a thunk in [external_jobs] and call\n [thread_safe_external_job_hook], which is responsible for notifying the scheduler\n that new actions are available.\n\n When using Async on unix, [thread_safe_external_job_hook] is set in [Async_unix]\n to call [Interruptor.thread_safe_interrupt], which will wake up the\n [Async_unix] scheduler and run a cycle.\n\n Note that this hook might be used in other context (js_of_ocaml, mirage).\n\n When running a cycle, we pull external actions at every job and perform them\n immediately. *)\n ; external_jobs : External_job.t Thread_safe_queue.t\n ; mutable thread_safe_external_job_hook : unit -> unit\n (* [job_queued_hook] and [event_added_hook] aim to be used by js_of_ocaml. *)\n (* We use [_ option] here because those hooks will not be set in the common case\n and we want to avoid extra function calls. *)\n ; mutable job_queued_hook : (Priority.t -> unit) option\n ; mutable event_added_hook : (Time_ns.t -> unit) option\n ; mutable yield : ((unit, read_write) Types.Bvar.t[@sexp.opaque])\n ; mutable yield_until_no_jobs_remain :\n ((unit, read_write) Types.Bvar.t[@sexp.opaque] (* configuration*))\n ; mutable check_invariants : bool\n ; mutable max_num_jobs_per_priority_per_cycle : Max_num_jobs_per_priority_per_cycle.t\n ; mutable record_backtraces : bool\n ; mutable on_start_of_cycle : unit -> unit\n ; mutable on_end_of_cycle : unit -> unit\n ; mutable long_jobs_last_cycle : (Execution_context.t * Time_ns.Span.t) list\n ; mutable cycle_started : bool\n }\n[@@deriving fields, sexp_of]\n\nlet uncaught_exn_unwrapped = uncaught_exn\n\nlet uncaught_exn t =\n match t.uncaught_exn with\n | None -> None\n | Some (exn, sexp) ->\n Some (Error.create \"unhandled exception\" (exn, sexp) [%sexp_of: Exn.t * Sexp.t])\n;;\n\nlet num_pending_jobs t =\n Job_queue.length t.normal_priority_jobs + Job_queue.length t.low_priority_jobs\n;;\n\nlet num_jobs_run t =\n Job_queue.num_jobs_run t.normal_priority_jobs\n + Job_queue.num_jobs_run t.low_priority_jobs\n;;\n\nlet last_cycle_num_jobs t = t.last_cycle_num_jobs\n\nlet invariant t : unit =\n try\n let check f field = f (Field.get field t) in\n Fields.iter\n ~check_access:ignore\n ~job_pool:(check Job_pool.invariant)\n ~normal_priority_jobs:(check Job_queue.invariant)\n ~low_priority_jobs:(check Job_queue.invariant)\n ~very_low_priority_workers:\n (check (fun q -> Deque.iter q ~f:Very_low_priority_worker.invariant))\n ~main_execution_context:(check Execution_context.invariant)\n ~current_execution_context:(check Execution_context.invariant)\n ~uncaught_exn:\n (check (fun uncaught_exn ->\n if is_some uncaught_exn then assert (num_pending_jobs t = 0)))\n ~cycle_count:(check (fun cycle_count -> assert (cycle_count >= 0)))\n ~cycle_start:ignore\n ~in_cycle:ignore\n ~run_every_cycle_start:ignore\n ~run_every_cycle_end:ignore\n ~last_cycle_time:ignore\n ~total_cycle_time:ignore\n ~last_cycle_num_jobs:\n (check (fun last_cycle_num_jobs -> assert (last_cycle_num_jobs >= 0)))\n ~time_source:\n (check\n (Synchronous_time_source.Read_write.invariant_with_jobs ~job:(fun job ->\n assert (Pool.pointer_is_valid t.job_pool job))))\n ~external_jobs:ignore\n ~thread_safe_external_job_hook:ignore\n ~job_queued_hook:ignore\n ~event_added_hook:ignore\n ~yield:ignore\n ~yield_until_no_jobs_remain:ignore\n ~check_invariants:ignore\n ~max_num_jobs_per_priority_per_cycle:ignore\n ~record_backtraces:ignore\n ~cycle_started:ignore\n ~long_jobs_last_cycle:ignore\n ~on_start_of_cycle:ignore\n ~on_end_of_cycle:ignore\n with\n | exn -> raise_s [%message \"Scheduler.invariant failed\" (exn : exn) (t : t)]\n;;\n\nlet free_job t job = Pool.free t.job_pool job\n\nlet enqueue t (execution_context : Execution_context.t) f a =\n (* If there's been an uncaught exn, we don't add the job, since we don't want any jobs\n to run once there's been an uncaught exn. *)\n if is_none t.uncaught_exn\n then (\n let priority = execution_context.priority in\n let job_queue =\n match priority with\n | Normal -> t.normal_priority_jobs\n | Low -> t.low_priority_jobs\n in\n Job_queue.enqueue job_queue execution_context f a;\n match t.job_queued_hook with\n | None -> ()\n | Some f -> f priority)\n;;\n\nlet enqueue_job t job ~free_job =\n let job_pool = t.job_pool in\n enqueue\n t\n (Pool.get job_pool job Pool.Slot.t0)\n (Pool.get job_pool job Pool.Slot.t1)\n (Pool.get job_pool job Pool.Slot.t2);\n if free_job then Pool.free t.job_pool job\n;;\n\nlet handle_fired (time_source : _ Synchronous_time_source.T1.t) job_or_event =\n let open Job_or_event.Match in\n let (K k) = kind job_or_event in\n match k, project k job_or_event with\n | Job, job -> enqueue_job time_source.scheduler job ~free_job:true\n | Event, event -> Synchronous_time_source.fire time_source event\n;;\n\nlet create () =\n let now = Time_ns.now () in\n let rec t =\n { check_access = None\n ; job_pool = Job_pool.create ()\n ; normal_priority_jobs = Job_queue.create ()\n ; low_priority_jobs = Job_queue.create ()\n ; very_low_priority_workers = Deque.create ()\n ; main_execution_context = Execution_context.main\n ; current_execution_context = Execution_context.main\n ; uncaught_exn = None\n ; cycle_start = now\n ; cycle_count = 0\n ; in_cycle = false\n ; run_every_cycle_start = []\n ; run_every_cycle_end = []\n ; last_cycle_time = sec 0.\n ; last_cycle_num_jobs = 0\n ; total_cycle_time = sec 0.\n ; time_source\n ; external_jobs = Thread_safe_queue.create ()\n ; thread_safe_external_job_hook = ignore\n ; job_queued_hook = None\n ; event_added_hook = None\n ; yield = Bvar.create ()\n ; yield_until_no_jobs_remain = Bvar.create () (* configuration *)\n ; check_invariants = Async_kernel_config.check_invariants\n ; max_num_jobs_per_priority_per_cycle =\n Async_kernel_config.max_num_jobs_per_priority_per_cycle\n ; record_backtraces = Async_kernel_config.record_backtraces\n ; cycle_started = false\n ; on_start_of_cycle = Fn.id\n ; on_end_of_cycle = Fn.id\n ; long_jobs_last_cycle= []\n }\n and events =\n Timing_wheel.create ~config:Async_kernel_config.timing_wheel_config ~start:now\n and time_source : _ Synchronous_time_source.T1.t =\n { id = Types.Time_source_id.create ()\n ; advance_errors = []\n ; am_advancing = false\n ; events\n ; handle_fired = (fun alarm -> handle_fired time_source (Alarm.value events alarm))\n ; fired_events = Event.none\n ; is_wall_clock = true\n ; most_recently_fired = Event.none\n ; scheduler = t\n }\n in\n t\n;;\n\nlet is_dead t = is_some t.uncaught_exn\nlet set_check_access t f = t.check_access <- f\n\nlet t_ref =\n match Result.try_with create with\n | Ok t -> ref t\n | Error exn ->\n Debug.log \"Async cannot create its raw scheduler\" exn [%sexp_of: exn];\n exit 1\n;;\n\nlet check_access t =\n match t.check_access with\n | None -> ()\n | Some f -> f ()\n;;\n\nlet t () =\n let t = !t_ref in\n check_access t;\n t\n;;\n\nlet current_execution_context t =\n if t.record_backtraces\n then Execution_context.record_backtrace t.current_execution_context\n else t.current_execution_context\n;;\n\nlet with_execution_context t tmp_context ~f =\n let old_context = current_execution_context t in\n set_execution_context t tmp_context;\n protect ~f ~finally:(fun () -> set_execution_context t old_context)\n;;\n\nlet create_job (type a) t execution_context f a =\n if Pool.is_full t.job_pool then t.job_pool <- Pool.grow t.job_pool;\n Pool.new3\n t.job_pool\n execution_context\n (Obj.magic (f : a -> unit) : Obj.t -> unit)\n (Obj.repr (a : a))\n;;\n\nlet got_uncaught_exn t exn sexp =\n if debug then Debug.log \"got_uncaught_exn\" (exn, sexp) [%sexp_of: Exn.t * Sexp.t];\n List.iter [ t.normal_priority_jobs; t.low_priority_jobs ] ~f:Job_queue.clear;\n t.uncaught_exn <- Some (exn, sexp)\n;;\n\n(* [start_cycle t ~max_num_jobs_per_priority] enables subsequent calls of [run_jobs]\n to run up to [max_num_jobs_per_priority] jobs of each priority level. *)\nlet start_cycle t ~max_num_jobs_per_priority =\n let n = Max_num_jobs_per_priority_per_cycle.raw max_num_jobs_per_priority in\n Job_queue.set_jobs_left_this_cycle t.normal_priority_jobs n;\n Job_queue.set_jobs_left_this_cycle t.low_priority_jobs n\n;;\n\n(* [run_jobs t] removes jobs from [t] one at a time and runs them, stopping as soon\n as an unhandled exception is raised, or when no more jobs can be run at any priority,\n as per [~max_num_jobs_per_priority]. *)\nlet rec run_jobs t =\n match Job_queue.run_jobs t.normal_priority_jobs t with\n | Error _ as e -> e\n | Ok () ->\n (match Job_queue.run_jobs t.low_priority_jobs t with\n | Error _ as e -> e\n | Ok () ->\n if Job_queue.can_run_a_job t.normal_priority_jobs\n || Job_queue.can_run_a_job t.low_priority_jobs\n then run_jobs t\n else Ok ())\n;;\n\nlet stabilize t =\n start_cycle\n t\n ~max_num_jobs_per_priority:\n (Max_num_jobs_per_priority_per_cycle.create_exn Int.max_value);\n match run_jobs t with\n | Ok () -> Ok ()\n | Error (exn, _backtrace) -> Error exn\n;;\n\nlet create_time_source\n ?(timing_wheel_config = Async_kernel_config.timing_wheel_config)\n ~now\n ()\n =\n let t = t () in\n let events = Timing_wheel.create ~config:timing_wheel_config ~start:now in\n let rec time_source : _ Synchronous_time_source.T1.t =\n { id = Types.Time_source_id.create ()\n ; advance_errors = []\n ; am_advancing = false\n ; events\n ; handle_fired = (fun alarm -> handle_fired time_source (Alarm.value events alarm))\n ; fired_events = Event.none\n ; is_wall_clock = false\n ; most_recently_fired = Event.none\n ; scheduler = t\n }\n in\n time_source\n;;\n\nlet wall_clock () = Synchronous_time_source.read_only (t ()).time_source\n","open! Core_kernel\nopen! Import\nopen! Deferred_std\nmodule Deferred = Deferred1\nmodule Scheduler = Scheduler1\nmodule Stream = Async_stream\ninclude (Scheduler : module type of Scheduler with module Bvar := Scheduler.Bvar)\n\nlet t = Scheduler.t\n\ninclude Monitor.Exported_for_scheduler\n\nlet find_local key = Execution_context.find_local (current_execution_context (t ())) key\n\nlet with_local key value ~f =\n let t = t () in\n let execution_context =\n Execution_context.with_local (current_execution_context t) key value\n in\n with_execution_context t execution_context ~f\n;;\n\nlet main_execution_context = (t ()).main_execution_context\nlet can_run_a_job t = num_pending_jobs t > 0 || Bvar.has_any_waiters t.yield\nlet has_upcoming_event t = not (Timing_wheel.is_empty (events t))\nlet next_upcoming_event t = Timing_wheel.next_alarm_fires_at (events t)\nlet next_upcoming_event_exn t = Timing_wheel.next_alarm_fires_at_exn (events t)\nlet event_precision t = Timing_wheel.alarm_precision (events t)\nlet cycle_start t = t.cycle_start\nlet run_every_cycle_start t ~f = t.run_every_cycle_start <- f :: t.run_every_cycle_start\nlet run_every_cycle_end t ~f = t.run_every_cycle_end <- f :: t.run_every_cycle_end\n\nlet map_cycle_times t ~f =\n Stream.create (fun tail ->\n run_every_cycle_start t ~f:(fun () -> Tail.extend tail (f t.last_cycle_time)))\n;;\n\nlet long_cycles t ~at_least =\n Stream.create (fun tail ->\n run_every_cycle_start t ~f:(fun () ->\n if Time_ns.Span.( >= ) t.last_cycle_time at_least\n then Tail.extend tail t.last_cycle_time))\n;;\n\nlet long_cycles_with_context t ~at_least =\n Stream.create (fun tail ->\n run_every_cycle_start t ~f:(fun () ->\n if Time_ns.Span.( >= ) t.last_cycle_time at_least\n then Tail.extend tail (t.last_cycle_time,t.current_execution_context)))\n;;\n\nlet long_jobs_with_context t =\n Stream.create (fun tail ->\n run_every_cycle_start t ~f:(fun () ->\n List.iter t.long_jobs_last_cycle ~f:(fun job -> Tail.extend tail job) ; t.long_jobs_last_cycle <- [] ))\n;;\n\nlet cycle_num_jobs t =\n Stream.create (fun tail ->\n run_every_cycle_start t ~f:(fun () -> Tail.extend tail t.last_cycle_num_jobs))\n;;\n\nlet cycle_count t = t.cycle_count\n\nlet set_max_num_jobs_per_priority_per_cycle t int =\n t.max_num_jobs_per_priority_per_cycle\n <- Max_num_jobs_per_priority_per_cycle.create_exn int\n;;\n\nlet max_num_jobs_per_priority_per_cycle t =\n Max_num_jobs_per_priority_per_cycle.raw t.max_num_jobs_per_priority_per_cycle\n;;\n\nlet set_thread_safe_external_job_hook t f = t.thread_safe_external_job_hook <- f\n\nlet thread_safe_enqueue_external_job t execution_context f a =\n Thread_safe_queue.enqueue t.external_jobs (External_job.T (execution_context, f, a));\n t.thread_safe_external_job_hook ()\n;;\n\nlet set_event_added_hook t f = t.event_added_hook <- Some f\nlet set_job_queued_hook t f = t.job_queued_hook <- Some f\n\nlet create_alarm t f =\n let execution_context = current_execution_context t in\n Gc.Expert.Alarm.create (fun () ->\n thread_safe_enqueue_external_job t execution_context f ())\n;;\n\nlet add_finalizer t heap_block f =\n let execution_context = current_execution_context t in\n let finalizer heap_block =\n (* Here we can be in any thread, and may not be holding the async lock. So, we can\n only do thread-safe things.\n\n By putting [heap_block] in [external_jobs], we are keeping it alive until the next\n time the async scheduler gets around to dequeueing it. Calling\n [t.thread_safe_external_job_hook] ensures that will happen in short order. Thus,\n we are not dramatically increasing the lifetime of [heap_block], since the OCaml\n runtime already resurrected [heap_block] so that we could refer to it here. The\n OCaml runtime already removed the finalizer function when it noticed [heap_block]\n could be finalized, so there is no infinite loop in which we are causing the\n finalizer to run again. Also, OCaml does not impose any requirement on finalizer\n functions that they need to dispose of the block, so it's fine that we keep\n [heap_block] around until later. *)\n if Debug.finalizers then Debug.log_string \"enqueueing finalizer\";\n thread_safe_enqueue_external_job t execution_context f heap_block\n in\n if Debug.finalizers then Debug.log_string \"adding finalizer\";\n (* We use [Caml.Gc.finalise] instead of [Core_kernel.Gc.add_finalizer] because the latter\n has its own wrapper around [Caml.Gc.finalise] to run finalizers synchronously. *)\n try Caml.Gc.finalise finalizer heap_block with\n | Invalid_argument _ ->\n (* [Heap_block] ensures that this will only fail for static data, in which case we\n can drop the finalizer since the block will never be collected.*)\n ()\n;;\n\nlet add_finalizer_exn t x f =\n add_finalizer t (Heap_block.create_exn x) (fun heap_block ->\n f (Heap_block.value heap_block))\n;;\n\nlet add_finalizer_last t heap_block f =\n let execution_context = current_execution_context t in\n let finalizer () =\n (* Here we can be in any thread, and may not be holding the async lock. So, we can\n only do thread-safe things. *)\n if Debug.finalizers\n then Debug.log_string \"enqueueing finalizer (using 'last' semantic)\";\n thread_safe_enqueue_external_job t execution_context f ()\n in\n if Debug.finalizers then Debug.log_string \"adding finalizer (using 'last' semantic)\";\n (* We use [Caml.Gc.finalise_last] instead of [Core_kernel.Gc.add_finalizer_last] because\n the latter has its own wrapper around [Caml.Gc.finalise_last] to run finalizers\n synchronously. *)\n try Caml.Gc.finalise_last finalizer heap_block with\n | Invalid_argument _ ->\n (* [Heap_block] ensures that this will only fail for static data, in which case we\n can drop the finalizer since the block will never be collected.*)\n ()\n;;\n\nlet add_finalizer_last_exn t x f = add_finalizer_last t (Heap_block.create_exn x) f\n\n(** [force_current_cycle_to_end] sets the number of normal jobs allowed to run in this\n cycle to zero. Thus, after the currently running job completes, the scheduler will\n switch to low priority jobs and then end the current cycle. *)\nlet force_current_cycle_to_end t =\n Job_queue.set_jobs_left_this_cycle t.normal_priority_jobs 0\n;;\n\n(* We preallocate [send_exn] to avoid allocating it on each call to [advance_clock]. *)\nlet send_exn = Some Monitor.send_exn\n\nlet advance_clock t ~now =\n Synchronous_time_source0.advance_internal t.time_source ~to_:now ~send_exn\n;;\n\nlet run_cycle t =\n if debug then Debug.log \"run_cycle starting\" t [%sexp_of: t];\n t.on_start_of_cycle ();\n let now = Time_ns.now () in\n t.cycle_count <- t.cycle_count + 1;\n t.cycle_start <- now;\n t.in_cycle <- true;\n Bvar.broadcast t.yield ();\n let num_jobs_run_at_start_of_cycle = num_jobs_run t in\n List.iter t.run_every_cycle_start ~f:(fun f -> f ());\n advance_clock t ~now;\n start_cycle t ~max_num_jobs_per_priority:t.max_num_jobs_per_priority_per_cycle;\n let rec run_jobs t =\n match Scheduler.run_jobs t with\n | Ok () -> ()\n | Error (exn, backtrace) ->\n Monitor.send_exn (Monitor.current ()) exn ~backtrace:(`This backtrace);\n (* [run_jobs] stopped due to an exn. There may still be jobs that could be\n run this cycle, so [run_jobs] again. *)\n run_jobs t\n in\n run_jobs t;\n let cycle_time = Time_ns.diff (Time_ns.now ()) t.cycle_start in\n t.last_cycle_time <- cycle_time;\n t.last_cycle_num_jobs <- num_jobs_run t - num_jobs_run_at_start_of_cycle;\n t.total_cycle_time <- Time_ns.Span.(t.total_cycle_time + cycle_time);\n if Bvar.has_any_waiters t.yield_until_no_jobs_remain && num_pending_jobs t = 0\n then Bvar.broadcast t.yield_until_no_jobs_remain ();\n List.iter t.run_every_cycle_end ~f:(fun f -> f ());\n t.in_cycle <- false;\n t.on_end_of_cycle ();\n if debug\n then\n Debug.log\n \"run_cycle finished\"\n (uncaught_exn t, is_some (next_upcoming_event t))\n [%sexp_of: Error.t option * bool]\n;;\n\nlet run_cycles_until_no_jobs_remain () =\n if debug then Debug.log_string \"run_cycles_until_no_jobs_remain starting\";\n let t = t () in\n if is_dead t\n then\n raise_s\n [%message\n \"run_cycles_until_no_jobs_remain cannot proceed -- scheduler is dead\"\n ~scheduler:(t : t)];\n let rec loop () =\n run_cycle t;\n advance_clock t ~now:(Time_ns.now ());\n if can_run_a_job t then loop ()\n in\n loop ();\n (* Reset the current execution context to maintain the invariant that when we're not in\n a job, [current_execution_context = main_execution_context]. *)\n set_execution_context t t.main_execution_context;\n if debug then Debug.log_string \"run_cycles_until_no_jobs_remain finished\";\n Option.iter (uncaught_exn t) ~f:Error.raise\n;;\n\nlet make_async_unusable () =\n let t = !t_ref in\n t.check_access\n <- Some\n (fun () ->\n raise_s [%sexp \"Async scheduler is unusable due to [make_async_unusable]\"])\n;;\n\nlet reset_in_forked_process () =\n if debug then Debug.log_string \"reset_in_forked_process\";\n (* There is no need to empty [main_monitor_hole]. *)\n Scheduler.(t_ref := create ())\n;;\n\nlet check_invariants t = t.check_invariants\nlet set_check_invariants t b = t.check_invariants <- b\nlet set_record_backtraces t b = t.record_backtraces <- b\nlet set_on_start_of_cycle t f = t.on_start_of_cycle <- f\nlet set_on_end_of_cycle t f = t.on_end_of_cycle <- f\nlet yield t = Bvar.wait t.yield\n\nlet yield_until_no_jobs_remain ?(may_return_immediately = false) t =\n if may_return_immediately && num_pending_jobs t = 0\n then return ()\n else Bvar.wait t.yield_until_no_jobs_remain\n;;\n\nlet yield_every ~n =\n if n <= 0\n then raise_s [%message \"Scheduler.yield_every got nonpositive count\" (n : int)]\n else if n = 1\n then stage (fun t -> yield t)\n else (\n let count_until_yield = ref n in\n stage (fun t ->\n decr count_until_yield;\n if !count_until_yield > 0\n then return ()\n else (\n count_until_yield := n;\n yield t)))\n;;\n\nlet total_cycle_time t =\n (* Adjust for the fact the caller's probably an Async job. *)\n if t.in_cycle\n then (\n let this_cycle_time = Time_ns.(diff (now ()) t.cycle_start) in\n Time_ns.Span.(t.total_cycle_time + this_cycle_time))\n else t.total_cycle_time\n;;\n\nmodule Very_low_priority_work = struct\n module Worker_result = Very_low_priority_worker.Exec_result\n\n\n let rec run t = run_workers t ~num_execs_before_yielding:1_000\n\n and run_workers t ~num_execs_before_yielding =\n if num_execs_before_yielding = 0\n then yield_then_run t\n else if not (Deque.is_empty t.very_low_priority_workers)\n then (\n let worker = Deque.dequeue_front_exn t.very_low_priority_workers in\n set_execution_context t worker.execution_context;\n run_worker t worker ~num_execs_before_yielding)\n\n and yield_then_run t =\n if not (Deque.is_empty t.very_low_priority_workers)\n then Deferred.upon (yield t) (fun () -> run t)\n\n and run_worker t worker ~num_execs_before_yielding =\n assert (phys_equal t.current_execution_context worker.execution_context);\n if num_execs_before_yielding = 0\n then (\n Deque.enqueue_front t.very_low_priority_workers worker;\n yield_then_run t)\n else (\n let num_execs_before_yielding = num_execs_before_yielding - 1 in\n match worker.exec () with\n | Finished -> run_workers t ~num_execs_before_yielding\n | Not_finished -> run_worker t worker ~num_execs_before_yielding\n | exception exn ->\n let bt = Backtrace.Exn.most_recent () in\n Monitor.send_exn (Monitor.current ()) exn ~backtrace:(`This bt);\n run_workers t ~num_execs_before_yielding)\n ;;\n\n let enqueue ~f =\n let t = t () in\n let queue = t.very_low_priority_workers in\n let running = not (Deque.is_empty queue) in\n let execution_context =\n Execution_context.create_like (current_execution_context t) ~priority:Low\n in\n Deque.enqueue_back queue { execution_context; exec = f };\n if not running then enqueue t execution_context run t\n ;;\nend\n\nmodule For_bench = struct\n let advance_clock = advance_clock\nend\n","open! Core_kernel\nopen! Import\nmodule Scheduler = Scheduler1\nmodule Cell = Types.Cell\n\ntype any =\n [ `Empty\n | `Empty_one_handler\n | `Empty_one_or_more_handlers\n | `Full\n | `Indir\n ]\n\ntype 'a t = 'a Types.Ivar.t = { mutable cell : ('a, any) cell }\n\n(* The ['b] is used to encode the constructor. This allows us to write functions that\n take only one of the constructors, with no runtime test.\n\n We maintain the invariant that the directed graph with ivars as nodes and [Indir]s as\n edges is acyclic. The only functions that create an [Indir] are [squash] and\n [connect], and for those, the target of the [Indir] is always a non-[Indir]. Thus, the\n newly added edges are never part of a cycle. *)\nand ('a, 'b) cell = ('a, 'b) Types.Cell.t =\n | Empty_one_or_more_handlers :\n { (* [run] is mutable so we can set it to [ignore] when the handler is removed.\n This is used when we install a handler on a full ivar since it is immediately\n added to the scheduler. *)\n mutable run : 'a -> unit\n ; execution_context : Execution_context.t\n ; (* [prev] and [next] circularly doubly link all handlers of the same ivar. *)\n mutable prev : ('a, [ `Empty_one_or_more_handlers ]) cell\n ; mutable next : ('a, [ `Empty_one_or_more_handlers ]) cell\n }\n -> ('a, [> `Empty_one_or_more_handlers ]) cell\n | Empty_one_handler :\n ('a -> unit) * Execution_context.t\n -> ('a, [> `Empty_one_handler ]) cell\n | Empty : ('a, [> `Empty ]) cell\n | Full : 'a -> ('a, [> `Full ]) cell\n | Indir : 'a t -> ('a, [> `Indir ]) cell\n\nmodule Handler = struct\n type 'a t = ('a, [ `Empty_one_or_more_handlers ]) cell\n\n let run (Empty_one_or_more_handlers t : _ t) = t.run\n let execution_context (Empty_one_or_more_handlers t : _ t) = t.execution_context\n let prev (Empty_one_or_more_handlers t : _ t) = t.prev\n let next (Empty_one_or_more_handlers t : _ t) = t.next\n let set_run (Empty_one_or_more_handlers t : _ t) x = t.run <- x\n let set_prev (Empty_one_or_more_handlers t : _ t) x = t.prev <- x\n let set_next (Empty_one_or_more_handlers t : _ t) x = t.next <- x\n\n let create run execution_context =\n (* An optimized implementation of:\n\n {[\n let rec t =\n Empty_one_or_more_handlers\n { run\n ; execution_context\n ; prev = t\n ; next = t }\n in\n h1 ]}\n\n However the compilation of recursive value in OCaml is not optimal: the value is\n allocated twice and copied once (with a loop calling caml_modify). This is not\n necessary for simple recursive definitions like this one.\n\n Instead we allocate the value with dummy fields and update them after. *)\n let t =\n Empty_one_or_more_handlers\n { run; execution_context; prev = Obj.magic None; next = Obj.magic None }\n in\n set_prev t t;\n set_next t t;\n t\n ;;\n\n let create2 run1 execution_context1 run2 execution_context2 =\n (* An optimized implementation of:\n\n {[\n let rec t1 =\n { run = run1\n ; execution_context = execution_context1\n ; prev = t2\n ; next = t2 }\n and t2 =\n { run = run2\n ; execution_context = execution_context2\n ; prev = t1\n ; next = t1 }\n in\n t1 ]} *)\n let t1 =\n Empty_one_or_more_handlers\n { run = run1\n ; execution_context = execution_context1\n ; prev = Obj.magic None\n ; next = Obj.magic None\n }\n in\n let t2 =\n Empty_one_or_more_handlers\n { run = run2; execution_context = execution_context2; prev = t1; next = t1 }\n in\n set_prev t1 t2;\n set_next t1 t2;\n t1\n ;;\n\n let invariant t =\n Execution_context.invariant (execution_context t);\n let r = ref (next t) in\n while not (phys_equal !r t) do\n let t1 = !r in\n assert (phys_equal (prev (next t1)) t1);\n Execution_context.invariant (execution_context t1);\n r := next !r\n done\n ;;\n\n let is_singleton t = phys_equal t (next t)\n\n let length t =\n let n = ref 1 in\n let r = ref (next t) in\n while not (phys_equal !r t) do\n incr n;\n r := next !r\n done;\n !n\n ;;\n\n let enqueue t scheduler v = Scheduler.enqueue scheduler (execution_context t) (run t) v\n\n let schedule_jobs t v =\n let scheduler = Scheduler.t () in\n enqueue t scheduler v;\n let r = ref (next t) in\n while not (phys_equal !r t) do\n enqueue !r scheduler v;\n r := next !r\n done\n ;;\n\n let unlink t =\n set_prev (next t) (prev t);\n set_next (prev t) (next t);\n set_prev t t;\n set_next t t\n ;;\n\n let add t run execution_context =\n let result =\n Empty_one_or_more_handlers { run; execution_context; prev = prev t; next = t }\n in\n set_next (prev t) result;\n set_prev t result;\n result\n ;;\n\n (* [splice t1 t2] creates:\n\n {v\n --> t1 <--> ... <--> last1 <--> t2 <--> ... <--> last2 <--\n | |\n ----------------------------------------------------------\n v} *)\n let splice t1 t2 =\n let last1 = prev t1 in\n let last2 = prev t2 in\n set_next last1 t2;\n set_next last2 t1;\n set_prev t1 last2;\n set_prev t2 last1\n ;;\n\n let of_list l =\n match l with\n | [] -> None\n | (run, execution_context) :: l ->\n let first = create run execution_context in\n let rec loop prev l =\n match l with\n | [] -> set_prev first prev\n | (run, execution_context) :: l ->\n let t =\n Empty_one_or_more_handlers { run; execution_context; prev; next = first }\n in\n set_next prev t;\n loop t l\n in\n loop first l;\n Some first\n ;;\n\n let to_list first =\n let rec loop t acc =\n let acc = (run t, execution_context t) :: acc in\n if phys_equal t first then acc else loop (prev t) acc\n in\n loop (prev first) []\n ;;\n\n let sexp_of_t _ (t : _ t) =\n let (Empty_one_or_more_handlers { run = _; execution_context; next = _; prev = _ }) =\n t\n in\n [%message (execution_context : Execution_context.t)]\n ;;\nend\n\ntype 'a ivar = 'a t\n\n(* Compiled as the identity. *)\nlet cell_of_handler : _ Handler.t -> _ = function\n | Empty_one_or_more_handlers _ as x -> (x :> (_, any) cell)\n;;\n\nlet equal (t : _ t) t' = phys_equal t t'\nlet indir t = { cell = Indir t }\n\ninclude Scheduler.Ivar\n\n(* [squash t] returns the non-[Indir] ivar at the end of the (possibly empty) chain of\n [Indir]s starting with [t] and ensures that all [Indir]s along that chain are replaced\n with an [Indir] pointing to the end of the chain. *)\nlet squash =\n let rec follow indir t =\n (* [indir = Indir t] *)\n match t.cell with\n | Indir t' as indir' -> follow indir' t'\n | _ -> indir\n in\n let rec update t indir =\n match t.cell with\n | Indir t' ->\n t.cell <- indir;\n update t' indir\n | _ -> t\n in\n fun t ->\n match t.cell with\n | Indir t' ->\n (match t'.cell with\n | Indir t'' as indir -> update t (follow indir t'')\n | _ -> t' (* nothing to do, since [t] is a chain with a single [Indir] *))\n | _ -> t\n;;\n\n(* nothing to do, since [t] isn't an [Indir]. *)\n\nlet invariant a_invariant t =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full a -> a_invariant a\n | Empty -> ()\n | Empty_one_handler (_, execution_context) ->\n Execution_context.invariant execution_context\n | Empty_one_or_more_handlers _ as handler -> Handler.invariant handler\n;;\n\nlet sexp_of_t sexp_of_a t : Sexp.t =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full a -> List [ Atom \"Full\"; sexp_of_a a ]\n | Empty | Empty_one_handler _ | Empty_one_or_more_handlers _ -> Atom \"Empty\"\n;;\n\nlet peek t =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full a -> Some a\n | Empty | Empty_one_handler _ | Empty_one_or_more_handlers _ -> None\n;;\n\nlet value t ~if_empty_then_failwith =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full a -> a\n | Empty | Empty_one_handler _ | Empty_one_or_more_handlers _ ->\n failwith if_empty_then_failwith\n;;\n\nlet value_exn t = value t ~if_empty_then_failwith:\"Ivar.value_exn called on empty ivar\"\n\nlet is_empty t =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full _ -> false\n | Empty | Empty_one_handler _ | Empty_one_or_more_handlers _ -> true\n;;\n\nlet is_full t = not (is_empty t)\n\nlet fill t v =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full _ -> raise_s [%message \"Ivar.fill of full ivar\" (t : _ t)]\n | Empty -> t.cell <- Full v\n | Empty_one_handler (run, execution_context) ->\n t.cell <- Full v;\n Scheduler.(enqueue (t ())) execution_context run v\n | Empty_one_or_more_handlers _ as handler ->\n t.cell <- Full v;\n Handler.schedule_jobs handler v\n;;\n\nlet remove_handler t (handler : _ Handler.t) =\n Handler.set_run handler ignore;\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Empty | Empty_one_handler _ ->\n (* These are only possible if [handler] was already removed. *)\n ()\n | Full _ ->\n (* This is possible if [t] was filled before we try to remove the handler. E.g.\n [Deferred.choose] will do this. *)\n ()\n | Empty_one_or_more_handlers _ as cell ->\n if Handler.is_singleton handler\n then t.cell <- Empty\n else (\n if phys_equal handler cell then t.cell <- cell_of_handler (Handler.next handler);\n Handler.unlink handler)\n;;\n\nlet add_handler t run execution_context =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Empty ->\n let handler = Handler.create run execution_context in\n t.cell <- cell_of_handler handler;\n handler\n | Empty_one_handler (run', execution_context') ->\n let handler = Handler.create2 run execution_context run' execution_context' in\n t.cell <- cell_of_handler handler;\n handler\n | Empty_one_or_more_handlers _ as handler -> Handler.add handler run execution_context\n | Full v ->\n let handler = Handler.create run execution_context in\n (* [run] calls [handler.run], which, if [handler] has been removed, has been changed\n to [ignore]. *)\n let run v = Handler.run handler v in\n Scheduler.(enqueue (t ())) execution_context run v;\n handler\n;;\n\nlet has_handlers t =\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Empty_one_handler _ | Empty_one_or_more_handlers _ -> true\n | Empty | Full _ -> false\n;;\n\nlet upon' t run = add_handler t run Scheduler.(current_execution_context (t ()))\n\n(* [upon] is conceptually the same as:\n\n {[\n let upon t f = ignore (upon' t run) ]}\n\n However, below is a more efficient implementation, which is worth doing because [upon]\n is very widely used and is so much more common than [upon']. The below implementation\n avoids the use of the bag of handlers in the extremely common case of one handler for\n the deferred. *)\nlet upon t run =\n let scheduler = Scheduler.t () in\n let execution_context = Scheduler.current_execution_context scheduler in\n let t = squash t in\n match t.cell with\n | Indir _ -> assert false (* fulfilled by [squash] *)\n | Full v -> Scheduler.enqueue scheduler execution_context run v\n | Empty -> t.cell <- Empty_one_handler (run, execution_context)\n | Empty_one_handler (run', execution_context') ->\n t.cell\n <- cell_of_handler (Handler.create2 run execution_context run' execution_context')\n | Empty_one_or_more_handlers _ as handler ->\n ignore (Handler.add handler run execution_context : _ Handler.t)\n;;\n\n(* [connect] takes ivars [bind_result] and [bind_rhs], and makes [bind_rhs]\n be an [Indir] pointing to the non-indir cell reachable from [bind_result]. On entry\n to [connect], [bind_result] and [bind_rhs] may be chains, since [bind_rhs] is an\n arbitrary user-supplied deferred, and [bind_result] is returned to the user prior to\n being [connect]ed, and may have been converted to an indirection in the case of\n right-nested binds.\n\n The purpose of [connect] is to make tail-recursive bind loops use constant space.\n E.g.:\n\n {[\n let rec loop i =\n if i = 0\n then return ()\n else (\n let%bind () = after (sec 1.) in\n loop (i - 1)) ]}\n\n [connect] makes intermediate bind results all be [Indir]s pointing at the outermost\n bind, rather than being a linear-length chain, with each pointing to the previous one.\n Then, since the program is only holding on to the innermost and outermost binds all the\n intermediate ones can be garbage collected.\n\n [connect] works by squashing its arguments so that the [bind_rhs] always points at the\n ultimate result. *)\nlet connect =\n (* [repoint_indirs ~ivar ~indir ~bind_result] repoints to [indir] all the ivars in the\n chain reachable from [ivar], and returns the non-[Indir] cell at the end of the\n chain. After repointing, we will merge the handlers in that cell with the handlers\n in [bind_result], and put the merged set of handlers in [bind_result]. *)\n let rec repoint_indirs ~ivar ~indir ~bind_result =\n let cell = ivar.cell in\n match cell with\n | Indir ivar' ->\n ivar.cell <- indir;\n repoint_indirs ~ivar:ivar' ~indir ~bind_result\n | Full _ -> cell\n | Empty | Empty_one_handler _ | Empty_one_or_more_handlers _ ->\n (* It is possible that [bind_result] and [bind_rhs] are not equal, but their chains\n of indirs lead to the same non-[Indir] cell, in which case we cannot set that\n cell to point to itself, because that would introduce a cycle. *)\n if not (phys_equal ivar bind_result) then ivar.cell <- indir;\n cell\n in\n fun ~bind_result ~bind_rhs ->\n if not (phys_equal bind_result bind_rhs)\n then (\n let bind_result = squash bind_result in\n let indir = Indir bind_result in\n let bind_rhs_contents = repoint_indirs ~ivar:bind_rhs ~indir ~bind_result in\n (* update [bind_result] with the union of handlers in [bind_result] and\n [bind_rhs] *)\n match bind_result.cell, bind_rhs_contents with\n | Indir _, _ | _, Indir _ -> assert false\n (* fulfilled by [squash] and [repoint_indirs] *)\n (* [connect] is only used in bind, whose ivar is only ever exported as a read-only\n deferred. Thus, [bind_result] must be empty. *)\n | Full _, _ -> assert false\n | _, Empty -> ()\n | Empty, _ -> bind_result.cell <- bind_rhs_contents\n | Empty_one_handler (run, execution_context), Full v ->\n bind_result.cell <- bind_rhs_contents;\n Scheduler.(enqueue (t ())) execution_context run v\n | (Empty_one_or_more_handlers _ as handler), Full v ->\n bind_result.cell <- bind_rhs_contents;\n Handler.schedule_jobs handler v\n | ( Empty_one_handler (run1, execution_context1)\n , Empty_one_handler (run2, execution_context2) ) ->\n let handler1 = Handler.create2 run1 execution_context1 run2 execution_context2 in\n bind_result.cell <- cell_of_handler handler1\n | ( (Empty_one_or_more_handlers _ as handler1)\n , Empty_one_handler (run2, execution_context2) ) ->\n ignore (Handler.add handler1 run2 execution_context2 : _ Handler.t)\n | ( Empty_one_handler (run1, execution_context1)\n , (Empty_one_or_more_handlers _ as handler2) ) ->\n let handler1 = Handler.add handler2 run1 execution_context1 in\n bind_result.cell <- cell_of_handler handler1\n | ( (Empty_one_or_more_handlers _ as handler1)\n , (Empty_one_or_more_handlers _ as handler2) ) ->\n Handler.splice handler1 handler2)\n;;\n","open! Core_kernel\nopen! Import\nmodule Ivar = Ivar0\nmodule Handler = Ivar.Handler\n\n(* Deferreds present a covariant view of ivars. We could actually implement deferreds\n using a record of closures, as in the [essence_of_deferred] record below, for which the\n OCaml type checker can infer covariance. However, doing so would make [Ivar.read] very\n costly, because it would have to allocate lots of closures and a record. Instead of\n doing this, we make deferreds an abstract covariant type, which concretely is just the\n ivar, and use [Obj.magic] to convert back and forth between a deferred and its concrete\n representation as an ivar. This [Obj.magic] is safe because the representation is\n always just an ivar, and the covariance follows from the fact that all the deferred\n operations are equivalent to those implemented directly on top of the\n [essence_of_deferred].\n\n {[\n type (+'a, 'execution_context) essence_of_deferred =\n { peek : unit -> 'a option\n ; is_determined : unit -> bool\n ; upon : ('a -> unit) -> unit\n ; upon' : ('a -> unit) -> Unregister.t\n ; install_removable_handler : ('a, 'execution_context) Raw_handler.t -> Unregister.t; } ]} *)\n\ntype +'a t = 'a Types.Deferred.t\n\n(* the abstract covariant type, equivalent to ivar *)\n\nlet of_ivar (type a) (ivar : a Ivar.t) : a t = Obj.magic ivar\nlet to_ivar (type a) t : a Ivar.t = Obj.magic (t : a t)\nlet invariant invariant_a t = Ivar.invariant invariant_a (to_ivar t)\nlet sexp_of_t sexp_of_a t = Ivar.sexp_of_t sexp_of_a (to_ivar t)\nlet peek t = Ivar.peek (to_ivar t)\nlet return a = of_ivar (Ivar.create_full a)\nlet is_determined t = Ivar.is_full (to_ivar t)\n\nlet value_exn t =\n Ivar.value\n (to_ivar t)\n ~if_empty_then_failwith:\"Deferred.value_exn called on undetermined deferred\"\n;;\n\nlet upon t f = Ivar.upon (to_ivar t) f\n\nlet create f =\n let result = Ivar.create () in\n f result;\n of_ivar result\n;;\n\n(* don't use [create] here as it would allocate one more closure *)\nlet bind t ~f =\n let bind_result = Ivar.create () in\n upon t (fun a -> Ivar.connect ~bind_result ~bind_rhs:(to_ivar (f a)));\n of_ivar bind_result\n;;\n\nlet add_handler t f execution_context = Ivar.add_handler (to_ivar t) f execution_context\nlet remove_handler t h = Ivar.remove_handler (to_ivar t) h\n","open Core_kernel\nmodule Deferred = Deferred0\ninclude Ivar0\n\nlet read = Deferred.of_ivar\nlet fill_if_empty t v = if is_empty t then fill t v\n\ninclude Binable.Of_binable1 [@alert \"-legacy\"]\n (Option)\n (struct\n type nonrec 'a t = 'a t\n\n let to_binable t = peek t\n\n let of_binable = function\n | None -> create ()\n | Some a -> create_full a\n ;;\n end)\n","(** [Monad_sequence.S] is a generic interface specifying functions that deal with a\n container and a monad. It is specialized to the [Deferred] monad and used with\n various containers in modules [Deferred.Array], [Deferred.List], [Deferred.Queue], and\n [Deferred.Sequence]. The [Monad_sequence.how] type specifies the parallelism of\n container iterators. *)\n\nopen! Core_kernel\nopen! Import\n\ntype how =\n [ `Parallel (** like [`Max_concurrent_jobs Int.max_value] *)\n | `Sequential\n (** [`Sequential] is often but not always the same as [`Max_concurrent_jobs 1]\n (for example, they differ in the [Or_error] monad). *)\n | `Max_concurrent_jobs of int\n ]\n[@@deriving sexp_of]\n\nmodule type S = sig\n type 'a monad\n type 'a t\n\n val foldi : 'a t -> init:'b -> f:(int -> 'b -> 'a -> 'b monad) -> 'b monad\n val fold : 'a t -> init:'b -> f:('b -> 'a -> 'b monad) -> 'b monad\n val find : 'a t -> f:('a -> bool monad) -> 'a option monad\n val findi : 'a t -> f:(int -> 'a -> bool monad) -> (int * 'a) option monad\n val find_map : 'a t -> f:('a -> 'b option monad) -> 'b option monad\n val find_mapi : 'a t -> f:(int -> 'a -> 'b option monad) -> 'b option monad\n val exists : 'a t -> f:('a -> bool monad) -> bool monad\n val existsi : 'a t -> f:(int -> 'a -> bool monad) -> bool monad\n val for_all : 'a t -> f:('a -> bool monad) -> bool monad\n val for_alli : 'a t -> f:(int -> 'a -> bool monad) -> bool monad\n val all : 'a monad t -> 'a t monad\n val all_unit : unit monad t -> unit monad\n\n (** {2 Deferred iterators}\n\n In the following, the default [how] is [`Sequential] *)\n\n val init : ?how:how -> int -> f:(int -> 'a monad) -> 'a t monad\n val iter : ?how:how -> 'a t -> f:('a -> unit monad) -> unit monad\n val iteri : ?how:how -> 'a t -> f:(int -> 'a -> unit monad) -> unit monad\n val map : ?how:how -> 'a t -> f:('a -> 'b monad) -> 'b t monad\n val mapi : ?how:how -> 'a t -> f:(int -> 'a -> 'b monad) -> 'b t monad\n val filter : ?how:how -> 'a t -> f:('a -> bool monad) -> 'a t monad\n val filteri : ?how:how -> 'a t -> f:(int -> 'a -> bool monad) -> 'a t monad\n val filter_map : ?how:how -> 'a t -> f:('a -> 'b option monad) -> 'b t monad\n val filter_mapi : ?how:how -> 'a t -> f:(int -> 'a -> 'b option monad) -> 'b t monad\n val concat_map : ?how:how -> 'a t -> f:('a -> 'b t monad) -> 'b t monad\n val concat_mapi : ?how:how -> 'a t -> f:(int -> 'a -> 'b t monad) -> 'b t monad\nend\n","open Core_kernel\nmodule Scheduler = Scheduler1\ninclude Deferred0\n\n(* To avoid a space leak, it is necessary that [never] allocates a new ivar whenever it is\n called. Code can bind on [never ()], so if we re-used the ivar, we could endlessly\n accumulate handlers. *)\nlet never () = Ivar.read (Ivar.create ())\n\nmodule M = Monad.Make (struct\n include Deferred0\n\n let map t ~f =\n (* We manually inline [Deferred.create] here, because the non-flambda compiler isn't\n able to optimize away the closure that would be be created. *)\n let result = Ivar.create () in\n upon t (fun a -> Ivar.fill result (f a));\n of_ivar result\n ;;\n\n let map = `Custom map\n end)\n\ninclude M\n\n(* We rebind all the various [return]s because the use of the [Monad.Make] functor\n causes the compiler to not inline [return], and hence makes it impossible to\n statically allocate constants like [return ()]. By rebinding [return] as\n [Deferred0.return], the compiler can see that:\n\n {[\n return a = { Ivar.Immutable. cell = Full a } ]}\n\n And hence, if [a] is constant, then the return is constant and can be statically\n allocated. When compiling with flambda, the compiler inlines [return] and this manual\n rebinding would not help; we've decided to do it anyway so that non-flambda builds\n get the optimization. *)\nlet return = Deferred0.return\n\nmodule Let_syntax = struct\n include M.Let_syntax\n\n let return = Deferred0.return\n\n module Let_syntax = struct\n include M.Let_syntax.Let_syntax\n\n let return = Deferred0.return\n end\nend\n\nopen Let_syntax\n\n(* We shadow [all] on-purpose here, since the default definition introduces a chain of\n binds as long as the list. *)\nlet all = `Make_sure_to_define_all_elsewhere\nlet _ = all\nlet unit = return ()\n\nlet both t1 t2 =\n create (fun result ->\n upon t1 (fun a1 -> upon t2 (fun a2 -> Ivar.fill result (a1, a2))))\n;;\n\nmodule Infix = struct\n include Monad_infix\n\n let ( >>> ) = upon\n let ppx_both = both\nend\n\nopen Infix\n\nlet don't_wait_for (_ : unit t) = ()\n\nmodule Choice = struct\n type +'a t = T : 'b Deferred0.t * ('b -> 'a) -> 'a t\n\n let map (T (t, f1)) ~f:f2 = T (t, fun x -> f2 (f1 x))\nend\n\ntype 'a choice = 'a Choice.t\n\nmodule Unregister = struct\n (* This representation saves 2n words for a list of n choices. *)\n type t =\n | Nil : t\n | Cons : 'a Deferred0.t * 'a Deferred0.Handler.t * t -> t\n\n let rec process = function\n | Nil -> ()\n | Cons (t, handler, rest) ->\n remove_handler t handler;\n process rest\n ;;\nend\n\nlet choice t f = Choice.T (t, f)\n\nlet enabled choices =\n let result = Ivar.create () in\n let unregisters = ref Unregister.Nil in\n let ready _ =\n if Ivar.is_empty result\n then (\n Unregister.process !unregisters;\n Ivar.fill result (fun () ->\n List.rev\n (List.fold choices ~init:[] ~f:(fun ac (Choice.T (t, f)) ->\n match peek t with\n | None -> ac\n | Some v -> f v :: ac))))\n in\n let execution_context = Scheduler.(current_execution_context (t ())) in\n unregisters\n := List.fold choices ~init:Unregister.Nil ~f:(fun acc (Choice.T (t, _)) ->\n Cons (t, Deferred0.add_handler t ready execution_context, acc));\n Ivar.read result\n;;\n\nlet rec choose_result choices =\n match choices with\n | [] -> assert false\n | Choice.T (t, f) :: choices ->\n (match peek t with\n | None -> choose_result choices\n | Some v -> f v)\n;;\n\nlet choose choices =\n let result = Ivar.create () in\n let unregisters = ref Unregister.Nil in\n let ready _ =\n if Ivar.is_empty result\n then (\n Unregister.process !unregisters;\n Ivar.fill result (choose_result choices))\n in\n let execution_context = Scheduler.(current_execution_context (t ())) in\n unregisters\n := List.fold choices ~init:Unregister.Nil ~f:(fun acc (Choice.T (t, _)) ->\n Cons (t, Deferred0.add_handler t ready execution_context, acc));\n Ivar.read result\n;;\n\nlet any_f ts f = choose (List.map ts ~f:(fun t -> choice t f))\nlet any ts = any_f ts Fn.id\nlet any_unit ts = any_f ts (Fn.ignore : unit -> unit)\n\nlet for_ start ~to_ ~do_ =\n let rec loop i =\n if i > to_\n then return ()\n else (\n let%bind () = do_ i in\n loop (i + 1))\n in\n loop start\n;;\n\nlet repeat_until_finished state f =\n create (fun finished ->\n let rec loop state =\n f state\n >>> function\n | `Repeat state -> loop state\n | `Finished result -> Ivar.fill finished result\n in\n loop state)\n;;\n\nlet forever state f =\n repeat_until_finished state (fun state ->\n let%map state = f state in\n `Repeat state)\n >>> never_returns\n;;\n\ntype how = Monad_sequence.how [@@deriving sexp_of]\n\nmodule type Monad_sequence = Monad_sequence.S with type 'a monad := 'a t\n\n\nlet fold t ~init ~f =\n create (fun result ->\n let rec loop t b =\n match t with\n | [] -> Ivar.fill result b\n | x :: xs -> f b x >>> fun b -> loop xs b\n in\n loop t init)\n;;\n\nlet seqmap t ~f = fold t ~init:[] ~f:(fun bs a -> f a >>| fun b -> b :: bs) >>| List.rev\nlet all ds = seqmap ds ~f:Fn.id\nlet all_unit ds = fold ds ~init:() ~f:(fun () d -> d)\nlet ok x = x >>| fun x -> Ok x\n","open Deferred1\ninclude Infix\ninclude Let_syntax\n\nlet choice = choice\nlet choose = choose\nlet don't_wait_for = don't_wait_for\nlet never = never\nlet return = return\nlet upon = upon\n","open! Core_kernel\nopen! Import\n\ntype 'a u =\n | Empty of 'a Ivar.t\n | Full\n[@@deriving sexp_of]\n\ntype 'a t = 'a u ref [@@deriving sexp_of]\n\nlet invariant _ t =\n Invariant.invariant [%here] t [%sexp_of: _ t] (fun () ->\n match !t with\n | Full -> ()\n | Empty ivar -> assert (Ivar.is_empty ivar))\n;;\n\nlet create () =\n let ivar = Ivar.create () in\n let t = ref (Empty ivar) in\n t, Ivar.read ivar\n;;\n\nlet is_empty t =\n match !t with\n | Empty _ -> true\n | Full -> false\n;;\n\nlet fill t a =\n match !t with\n | Empty i ->\n t := Full;\n Ivar.fill i a\n | Full -> raise_s [%message \"attempt to fill full ivar\"]\n;;\n","open! Core_kernel\nopen! Import\nmodule Deferred = Deferred1\n\nmodule Stream = struct\n type 'a t = 'a next Deferred.t\n\n and 'a next = 'a Types.Stream.next =\n | Nil\n | Cons of 'a * 'a t\n\n let sexp_of_t sexp_of_a t =\n let rec loop d ac : Sexp.t =\n match Deferred.peek d with\n | None -> List (List.rev (Sexp.Atom \"...\" :: ac))\n | Some Nil -> List (List.rev ac)\n | Some (Cons (a, t)) -> loop t (sexp_of_a a :: ac)\n in\n loop t []\n ;;\n\n let next t = t\nend\n\ntype 'a t = 'a Types.Tail.t =\n { (* [next] points at the tail of the stream *) mutable next : 'a Stream.next Ivar.t }\n[@@deriving fields]\n\nlet sexp_of_t _ t : Sexp.t =\n Atom (if Ivar.is_empty t.next then \"\" else \"\")\n;;\n\nlet create () = { next = Ivar.create () }\nlet collect t = Ivar.read (next t)\nlet is_closed t = Ivar.is_full (next t)\n\nlet fill_exn t v =\n if is_closed t then raise_s [%message \"stream is closed\"] else Ivar.fill (next t) v\n;;\n\nlet close_exn t = fill_exn t Nil\nlet close_if_open t = if not (is_closed t) then Ivar.fill (next t) Nil\n\nlet extend t v =\n let next = Ivar.create () in\n fill_exn t (Cons (v, Ivar.read next));\n t.next <- next\n;;\n","open Core_kernel\nopen Deferred_std\nmodule Deferred = Deferred1\ninclude Tail.Stream\n\nlet first_exn t =\n match%map next t with\n | Nil -> raise_s [%message \"Stream.first of empty stream\"]\n | Cons (x, _) -> x\n;;\n\nlet fold' t ~init ~f =\n Deferred.create (fun result ->\n let rec loop t b =\n upon (next t) (function\n | Nil -> Ivar.fill result b\n | Cons (v, t) -> upon (f b v) (loop t))\n in\n loop t init)\n;;\n\n(* [fold] is implemented to avoid per-stream-element deferred overhead in the case when\n multiple stream elements are available simultaneously. *)\nlet fold t ~init ~f =\n Deferred.create (fun result ->\n let rec loop t b =\n match Deferred.peek (next t) with\n | None -> upon (next t) (fun next -> loop_next next b)\n | Some next -> loop_next next b\n and loop_next next b =\n match next with\n | Nil -> Ivar.fill result b\n | Cons (v, t) -> loop t (f b v)\n in\n loop t init)\n;;\n\nlet length t = fold t ~init:0 ~f:(fun n _ -> n + 1)\nlet iter' t ~f = fold' t ~init:() ~f:(fun () v -> f v)\n\nlet closed t =\n match Deferred.peek (next t) with\n | Some Nil -> return ()\n | _ -> iter' t ~f:(fun _ -> return ())\n;;\n\nlet iter t ~f =\n don't_wait_for\n (iter' t ~f:(fun a ->\n f a;\n return ()))\n;;\n\nlet create f =\n let tail = Tail.create () in\n (* collect before calling [f], in case [f] immediately extends. *)\n let t = Tail.collect tail in\n f tail;\n t\n;;\n\nlet unfold b ~f =\n create (fun tail ->\n let rec loop b =\n upon (f b) (function\n | None -> Tail.close_exn tail\n | Some (a, b) ->\n Tail.extend tail a;\n loop b)\n in\n loop b)\n;;\n\nlet of_list l =\n create (fun tail ->\n List.iter l ~f:(fun x -> Tail.extend tail x);\n Tail.close_exn tail)\n;;\n\nlet to_list s = fold' s ~init:[] ~f:(fun b a -> return (a :: b)) >>| List.rev\nlet copy_to_tail t tail = iter' t ~f:(fun a -> return (Tail.extend tail a))\n\nlet append t1 t2 =\n create (fun tail ->\n upon (copy_to_tail t1 tail) (fun () ->\n upon (copy_to_tail t2 tail) (fun () -> Tail.close_exn tail)))\n;;\n\nlet concat t =\n create (fun tail ->\n upon (iter' t ~f:(fun t -> copy_to_tail t tail)) (fun () -> Tail.close_exn tail))\n;;\n\nlet filter' t ~f =\n create (fun tail ->\n upon\n (iter' t ~f:(fun v ->\n match%map f v with\n | false -> ()\n | true -> Tail.extend tail v))\n (fun () -> Tail.close_exn tail))\n;;\n\nlet filter_deprecated t ~f = filter' t ~f:(fun a -> return (f a))\n\nlet filter_map' t ~f =\n create (fun tail ->\n upon\n (iter' t ~f:(fun v ->\n match%map f v with\n | None -> ()\n | Some v -> Tail.extend tail v))\n (fun () -> Tail.close_exn tail))\n;;\n\nlet filter_map_deprecated t ~f = filter_map' t ~f:(fun a -> return (f a))\n\nlet map' t ~f =\n create (fun tail ->\n upon\n (iter' t ~f:(fun v -> f v >>| Tail.extend tail))\n (fun () -> Tail.close_exn tail))\n;;\n\nlet map t ~f = map' t ~f:(fun a -> return (f a))\n\nlet first_n s n =\n create (fun tail ->\n let rec loop s n =\n if n = 0\n then Tail.close_exn tail\n else\n upon (next s) (function\n | Nil -> Tail.close_exn tail\n | Cons (x, t) ->\n Tail.extend tail x;\n loop t (n - 1))\n in\n loop s n)\n;;\n\nlet available_now t =\n let rec loop t ac =\n match Deferred.peek (next t) with\n | None | Some Nil -> List.rev ac, t\n | Some (Cons (x, t)) -> loop t (x :: ac)\n in\n loop t []\n;;\n\nlet split ?(stop = Deferred.never ()) ?(f = fun _ -> `Continue) t =\n let reason_for_stopping = Ivar.create () in\n let prefix = Tail.create () in\n let finish v =\n Tail.close_exn prefix;\n Ivar.fill reason_for_stopping v\n in\n let rec loop t =\n choose [ choice stop (fun () -> `Stopped); choice (next t) (fun o -> `Next o) ]\n >>> function\n | `Stopped -> finish (`Stopped t)\n | `Next o ->\n (match o with\n | Nil -> finish `End_of_stream\n | Cons (a, t) ->\n (match f a with\n | `Continue ->\n Tail.extend prefix a;\n loop t\n | `Found b -> finish (`Found (b, t))))\n in\n loop t;\n Tail.collect prefix, Ivar.read reason_for_stopping\n;;\n\nlet find t ~f =\n let _, found = split t ~f:(fun a -> if f a then `Found a else `Continue) in\n match%map found with\n | `Stopped _ -> assert false\n | (`End_of_stream | `Found _) as x -> x\n;;\n\nlet ungroup t =\n create (fun tail ->\n upon\n (iter' t ~f:(fun l ->\n List.iter l ~f:(fun x -> Tail.extend tail x);\n return ()))\n (fun () -> Tail.close_exn tail))\n;;\n\nlet interleave ts =\n create (fun tail ->\n (* The interleaved stream should be closed when the outer stream and all of\n the inner streams have been closed. Keep a count of the number of open\n streams and close the interleaved stream when that count becomes\n zero. *)\n let num_open = ref 1 in\n (* 1 for the outer stream that is open *)\n let close () =\n num_open := !num_open - 1;\n if !num_open = 0 then Tail.close_exn tail\n in\n let outer_closed =\n iter' ts ~f:(fun t ->\n num_open := !num_open + 1;\n upon (copy_to_tail t tail) close;\n return ())\n in\n upon outer_closed close)\n;;\n\nlet take_until t d =\n create (fun tail ->\n let rec loop t =\n upon\n (choose [ choice d (fun () -> `Stop); choice (next t) (fun z -> `Next z) ])\n (function\n | `Stop | `Next Nil -> Tail.close_exn tail\n | `Next (Cons (x, t)) ->\n Tail.extend tail x;\n loop t)\n in\n loop t)\n;;\n\nlet iter_durably' t ~f =\n Deferred.create (fun result ->\n let rec loop t =\n next t\n >>> function\n | Nil -> Ivar.fill result ()\n | Cons (x, t) ->\n Monitor.try_with ~rest:`Raise (fun () -> f x)\n >>> fun z ->\n loop t;\n (match z with\n | Ok () -> ()\n | Error e -> Monitor.send_exn (Monitor.current ()) e)\n in\n loop t)\n;;\n\nlet iter_durably_report_end t ~f =\n Deferred.create (fun result ->\n let rec loop t =\n next t\n >>> function\n | Nil -> Ivar.fill result ()\n | Cons (x, t) ->\n (* We immediately call [loop], thus making the iter durable. Any exceptions\n raised by [f] will not prevent the loop from continuing, and will go to the\n monitor of whomever called [iter_durably_report_end]. *)\n loop t;\n f x\n in\n loop t)\n;;\n\nlet iter_durably t ~f = don't_wait_for (iter_durably_report_end t ~f)\n\nlet of_fun f =\n unfold () ~f:(fun () ->\n let%map a = f () in\n Some (a, ()))\n;;\n","include Synchronous_time_source0\n\nlet create = Scheduler1.create_time_source\nlet wall_clock = Scheduler1.wall_clock\n","open! Core_kernel\nopen! Import\n\ntype ('a, 'permission) t = ('a, 'permission) Types.Bvar.t\n\ntype 'a repr = 'a Types.Bvar.repr =\n { mutable has_any_waiters : bool\n ; mutable ivar : 'a Ivar.t\n }\n[@@deriving fields, sexp_of]\n\nlet invariant invariant_a _ t =\n let repr = Types.Bvar.to_repr t in\n Invariant.invariant [%here] repr [%sexp_of: _ repr] (fun () ->\n let check f = Invariant.check_field repr f in\n Fields_of_repr.iter\n ~has_any_waiters:\n (check (fun has_any_waiters ->\n if Ivar.has_handlers repr.ivar then assert has_any_waiters))\n ~ivar:\n (check (fun ivar ->\n Ivar.invariant invariant_a ivar;\n assert (Ivar.is_empty ivar))))\n;;\n\nlet sexp_of_t _ _ t =\n let { has_any_waiters; ivar = _ } = Types.Bvar.to_repr t in\n (* We don't show [ivar] because it's always empty. *)\n [%message (has_any_waiters : bool)]\n;;\n\ninclude Scheduler1.Bvar\n\nlet broadcast t a =\n let repr = Types.Bvar.to_repr t in\n if repr.has_any_waiters\n then (\n repr.has_any_waiters <- false;\n Ivar.fill repr.ivar a;\n repr.ivar <- Ivar.create ())\n;;\n\nlet wait t =\n let repr = Types.Bvar.to_repr t in\n repr.has_any_waiters <- true;\n Ivar.read repr.ivar\n;;\n\nlet has_any_waiters t =\n let repr = Types.Bvar.to_repr t in\n repr.has_any_waiters\n;;\n","open! Core_kernel\nopen! Import\nopen! Deferred_std\n\nlet debug = Debug.clock\n\nmodule Alarm = Timing_wheel.Alarm\nmodule Deferred = Deferred1\nmodule Scheduler = Scheduler1\n\nlet upon = Deferred.upon\nlet choose = Deferred.choose\nlet choice = Deferred.choice\nlet ( >>> ) = upon\n\nmodule T1 = struct\n include Synchronous_time_source0.T1\n\n (* We don't include the [id] in the sexp because the user (rightly) can't control it, so\n it's hard to make it deterministic in tests. *)\n let sexp_of_t\n _\n { id = _\n ; advance_errors = _\n ; am_advancing = _\n ; events\n ; fired_events = _\n ; handle_fired = _\n ; is_wall_clock\n ; most_recently_fired = _\n ; scheduler = _\n }\n =\n if is_wall_clock\n then [%message \"\"]\n else\n [%message\n (is_wall_clock : bool)\n (* We don't display the [Job.t]s in [events] because those are\n pool pointers, which are uninformative. *)\n (events : _ Timing_wheel.t)]\n ;;\nend\n\nopen T1\n\nmodule Read_write = struct\n type t = read_write T1.t [@@deriving sexp_of]\n\n let invariant = invariant\n let invariant_with_jobs = invariant_with_jobs\nend\n\ntype t = read T1.t [@@deriving sexp_of]\n\nlet invariant = invariant\nlet invariant_with_jobs = invariant_with_jobs\nlet read_only (t : [> read ] T1.t) = (t :> t)\nlet create = Scheduler.create_time_source\nlet wall_clock = Scheduler.wall_clock\nlet alarm_precision t = Timing_wheel.alarm_precision t.events\nlet next_alarm_fires_at t = Timing_wheel.next_alarm_fires_at t.events\nlet timing_wheel_now t = Timing_wheel.now t.events\nlet id t = t.id\n\nmodule Id = Synchronous_time_source0.Id\n\nlet now t =\n if t.is_wall_clock\n then\n (* For the wall-clock time-source, we use [Time_ns.now ()] rather than\n [Timing_wheel.now t.events]. The latter is only updated at the start of each\n cycle. There can be substantial difference between the two when people do long\n running computations or mix blocking code with async. And humans expect that\n wall-clock time is based on [Time.now], not some artifact of async\n implementation. *)\n Time_ns.now ()\n else timing_wheel_now t\n;;\n\n(* We preallocate [send_exn] to avoid allocating it on each call to [advance_clock]. *)\nlet send_exn = Some Monitor.send_exn\nlet advance_directly t ~to_ = Synchronous_time_source0.advance_clock t ~to_ ~send_exn\nlet advance_directly_by t by = advance_directly t ~to_:(Time_ns.after (now t) by)\nlet advance = advance_directly\nlet advance_by = advance_directly_by\nlet fire_past_alarms t = Synchronous_time_source0.fire_past_alarms t ~send_exn\nlet yield t = Bvar.wait (Scheduler.yield t.scheduler)\n\nlet advance_by_alarms ?wait_for t ~to_ =\n let run_queued_alarms () =\n (* Every time we want to run queued alarms we need to yield control back to the\n [Async.Scheduler] and [wait_for] any logic that is supposed to finish at this time\n before advancing. If no [wait_for] logic is specified we can simply yield control\n by invoking [yield t], which enqueues another job at the end of the scheduler job\n queue so alarm jobs have the opportunity to run before we advance. *)\n match wait_for with\n | None -> yield t\n | Some f -> f ()\n in\n let finish () =\n advance_directly t ~to_;\n fire_past_alarms t;\n (* so that alarms scheduled at or before [to_] fire *)\n run_queued_alarms ()\n in\n let rec walk_alarms () =\n match next_alarm_fires_at t with\n | None -> finish ()\n | Some next_alarm_fires_at ->\n if Time_ns.( >= ) next_alarm_fires_at to_\n then finish ()\n else (\n advance_directly t ~to_:next_alarm_fires_at;\n let queued_alarms_ran = run_queued_alarms () in\n if Deferred.is_determined queued_alarms_ran\n then walk_alarms ()\n else (\n let%bind () = queued_alarms_ran in\n walk_alarms ()))\n in\n (* This first [run_queued_alarms] call allows [Clock_ns.every] the opportunity to run\n its continuation deferreds so that they can reschedule alarms. This is particularly\n useful in our \"advance hits intermediate alarms\" unit test below, but likely useful\n in other cases where [every] is synchronously followed by [advance]. *)\n let%bind () = run_queued_alarms () in\n walk_alarms ()\n;;\n\nlet advance_by_alarms_by ?wait_for t by =\n advance_by_alarms ?wait_for t ~to_:(Time_ns.after (now t) by)\n;;\n\nlet span_to_time t span = Time_ns.after (now t) span\n\nlet schedule_job t ~at execution_context f a =\n let alarm =\n Timing_wheel.add\n t.events\n ~at\n (Job_or_event.of_job (Scheduler.create_job t.scheduler execution_context f a))\n in\n (match t.scheduler.event_added_hook with\n | None -> ()\n | Some f -> f at);\n alarm\n;;\n\nlet run_at_internal t time f a =\n let execution_context = Scheduler.current_execution_context t.scheduler in\n if Time_ns.( > ) time (Timing_wheel.now t.events)\n then schedule_job t ~at:time execution_context f a\n else (\n Scheduler.enqueue t.scheduler execution_context f a;\n Alarm.null ())\n;;\n\nlet run_at t time f a = ignore (run_at_internal t time f a : _ Alarm.t)\nlet run_after t span f a = run_at t (span_to_time t span) f a\n\nlet at =\n let fill result = Ivar.fill result () in\n fun t time ->\n if Time_ns.( <= ) time (Timing_wheel.now t.events)\n then return ()\n else (\n let result = Ivar.create () in\n ignore (run_at_internal t time fill result : _ Alarm.t);\n Ivar.read result)\n;;\n\nlet after t span = at t (span_to_time t span)\n\nlet remove_alarm t alarm : unit =\n let job_or_event = Alarm.value t.events alarm in\n (let open Job_or_event.Match in\n let (K k) = kind job_or_event in\n match k, project k job_or_event with\n | Job, job -> Scheduler.free_job t.scheduler job\n | Event, _ ->\n (* This is unreachable because [alarm] only ever comes from [Event.alarm] which only\n ever gets populated by a call to [schedule_job]. *)\n assert false);\n Timing_wheel.remove t.events alarm\n;;\n\nlet remove_alarm_if_scheduled t alarm =\n if Timing_wheel.mem t.events alarm then remove_alarm t alarm\n;;\n\nmodule Event = struct\n module Fired = struct\n type ('a, 'h) t =\n | Aborted of 'a\n | Happened of 'h\n [@@deriving sexp_of]\n end\n\n type ('a, 'h) t =\n { mutable alarm : Job_or_event.t Alarm.t\n ; mutable fire : unit -> unit\n ; (* As long as [Ivar.is_empty fired], we have not yet committed to whether the event\n will happen or be aborted. When [Ivar.is_empty fired], the alarm may or may not\n be in the timing wheel -- if it isn't, then there's a job in Async's job queue\n that will fire the event, unless it is aborted before that job can run. *)\n fired : ('a, 'h) Fired.t Ivar.t\n ; (* [num_fires_to_skip] is used to reschedule events that have fired and entered the\n Async job queue, but have not yet run. Those jobs only run if [num_fires_to_skip\n = 0], and otherwise just decrement it. So, to reschedule an event in such a\n state, we increment [num_fires_to_skip] and add a new alarm to the timing\n wheel. *)\n mutable num_fires_to_skip : int\n ; (* [scheduled_at] is the time at which [t] has most recently been scheduled to fire.\n While [t.alarm] is still in the timing wheel, this is the same as [Alarm.at\n t.alarm]. *)\n mutable scheduled_at : Time_ns.t\n ; time_source : Synchronous_time_source.t\n }\n [@@deriving fields, sexp_of]\n\n type t_unit = (unit, unit) t [@@deriving sexp_of]\n\n let fired t = Ivar.read t.fired\n\n let invariant invariant_a invariant_h t =\n Invariant.invariant [%here] t [%sexp_of: (_, _) t] (fun () ->\n let events = t.time_source.events in\n let check f = Invariant.check_field t f in\n Fields.iter\n ~alarm:\n (check (fun alarm ->\n if Ivar.is_full t.fired\n then assert (not (Timing_wheel.mem events alarm))\n else if Timing_wheel.mem events alarm\n then assert (Job_or_event.is_job (Alarm.value events alarm))))\n ~fire:ignore\n ~fired:\n (check (fun (fired : _ Fired.t Ivar.t) ->\n match Deferred.peek (Ivar.read fired) with\n | None -> ()\n | Some (Aborted a) -> invariant_a a\n | Some (Happened h) -> invariant_h h))\n ~num_fires_to_skip:\n (check (fun num_fires_to_skip -> assert (num_fires_to_skip >= 0)))\n ~scheduled_at:\n (check (fun scheduled_at ->\n if Timing_wheel.mem events t.alarm\n then\n [%test_result: Time_ns.t]\n scheduled_at\n ~expect:(Alarm.at events t.alarm)))\n ~time_source:ignore)\n ;;\n\n module Status = struct\n type ('a, 'h) t =\n | Aborted of 'a\n | Happened of 'h\n | Scheduled_at of Time_ns.t\n [@@deriving sexp_of]\n end\n\n let status t : _ Status.t =\n match Deferred.peek (Ivar.read t.fired) with\n | None -> Scheduled_at t.scheduled_at\n | Some (Aborted a) -> Aborted a\n | Some (Happened h) -> Happened h\n ;;\n\n module Abort_result = struct\n type ('a, 'h) t =\n | Ok\n | Previously_aborted of 'a\n | Previously_happened of 'h\n [@@deriving sexp_of]\n end\n\n let abort t a : _ Abort_result.t =\n if debug then Debug.log \"Time_source.Event.abort\" t [%sexp_of: (_, _) t];\n match Deferred.peek (fired t) with\n | Some (Aborted a) -> Previously_aborted a\n | Some (Happened h) -> Previously_happened h\n | None ->\n Ivar.fill t.fired (Aborted a);\n remove_alarm_if_scheduled t.time_source t.alarm;\n Ok\n ;;\n\n let abort_exn t a =\n match abort t a with\n | Ok -> ()\n | Previously_happened _ ->\n raise_s\n [%message \"Clock.Event.abort_exn failed to abort event that previously happened\"]\n | Previously_aborted _ ->\n raise_s\n [%message \"Clock.Event.abort_exn failed to abort event that previously aborted\"]\n ;;\n\n let abort_if_possible t a = ignore (abort t a : _ Abort_result.t)\n let schedule t = t.alarm <- run_at_internal t.time_source t.scheduled_at t.fire ()\n\n module Reschedule_result = struct\n type ('a, 'h) t =\n | Ok\n | Previously_aborted of 'a\n | Previously_happened of 'h\n [@@deriving sexp_of]\n end\n\n let reschedule_at t at : _ Reschedule_result.t =\n if debug\n then\n Debug.log\n \"Time_source.Event.reschedule_at\"\n (t, at)\n [%sexp_of: (_, _) t * Time_ns.t];\n match Deferred.peek (fired t) with\n | Some (Aborted a) -> Previously_aborted a\n | Some (Happened h) -> Previously_happened h\n | None ->\n let events = t.time_source.events in\n let is_in_timing_wheel = Timing_wheel.mem events t.alarm in\n let am_trying_to_reschedule_in_the_future =\n Time_ns.( > ) at (Timing_wheel.now events)\n in\n t.scheduled_at <- at;\n (match am_trying_to_reschedule_in_the_future, is_in_timing_wheel with\n | false, false -> ()\n | false, true ->\n t.time_source.handle_fired t.alarm;\n Timing_wheel.remove events t.alarm\n | true, false ->\n t.num_fires_to_skip <- t.num_fires_to_skip + 1;\n schedule t\n | true, true -> Timing_wheel.reschedule events t.alarm ~at);\n Ok\n ;;\n\n let reschedule_after t span = reschedule_at t (span_to_time t.time_source span)\n\n let run_at time_source scheduled_at f z =\n if debug then Debug.log \"Time_source.Event.run_at\" scheduled_at [%sexp_of: Time_ns.t];\n let t =\n { alarm = Alarm.null ()\n ; fire = ignore (* set below *)\n ; fired = Ivar.create ()\n ; num_fires_to_skip = 0\n ; scheduled_at\n ; time_source = read_only time_source\n }\n in\n let fire () =\n (* [fire] runs in an Async job. The event may have been aborted after the job\n was enqueued, so [fire] must check [fired]. *)\n if Ivar.is_empty t.fired\n then\n if t.num_fires_to_skip > 0\n then t.num_fires_to_skip <- t.num_fires_to_skip - 1\n else (\n let result = f z in\n (* [f z] may have aborted the event, so we must check [fired] again. *)\n if Ivar.is_empty t.fired then Ivar.fill t.fired (Happened result))\n in\n t.fire <- fire;\n schedule t;\n t\n ;;\n\n let at time_source time = run_at time_source time ignore ()\n\n let run_after time_source span f a =\n run_at time_source (span_to_time time_source span) f a\n ;;\n\n let after time_source span = at time_source (span_to_time time_source span)\nend\n\nlet at_times ?(stop = Deferred.never ()) t next_time =\n let tail = Tail.create () in\n let rec loop () =\n choose\n [ choice stop (fun () -> `Stop); choice (at t (next_time ())) (fun () -> `Tick) ]\n >>> function\n | `Stop -> Tail.close_exn tail\n | `Tick ->\n Tail.extend tail ();\n loop ()\n in\n loop ();\n Tail.collect tail\n;;\n\nlet at_varying_intervals ?stop t compute_span =\n at_times t ?stop (fun () -> Time_ns.after (now t) (compute_span ()))\n;;\n\nlet at_intervals ?start ?stop t interval =\n let start =\n match start with\n | Some x -> x\n | None -> now t\n in\n at_times t ?stop (fun () ->\n Time_ns.next_multiple ~base:start ~after:(now t) ~interval ())\n;;\n\nmodule Continue = struct\n type t =\n | Immediately\n | After of Time_ns.Span.t\n | Next_multiple of Time_ns.t * Time_ns.Span.t\n\n let immediately = Immediately\n\n let at t time_source =\n match t with\n | Immediately -> Timing_wheel.now time_source.events\n | After span -> span_to_time time_source span\n | Next_multiple (base, interval) ->\n Time_ns.next_multiple ~base ~after:(now time_source) ~interval ()\n ;;\nend\n\nlet run_repeatedly\n ?(start = return ())\n ?stop\n ?(continue_on_error = true)\n ?(finished = Ivar.create ())\n t\n ~f\n ~continue\n =\n start\n >>> fun () ->\n let alarm = ref (Alarm.null ()) in\n let stop =\n match stop with\n | None -> Deferred.never ()\n | Some stop ->\n upon stop (fun () ->\n if Timing_wheel.mem t.events !alarm\n then (\n remove_alarm t !alarm;\n Ivar.fill_if_empty finished ()));\n stop\n in\n (* [run_f], [continue_f], and [continue_try_with] are defined so that we allocate their\n closures once, not once per iteration. *)\n let rec run_f () =\n (* Before calling [f], we synchronously check whether [stop] is determined. *)\n if Deferred.is_determined stop\n then Ivar.fill_if_empty finished ()\n else if continue_on_error\n then Monitor.try_with f ~run:`Now ~rest:`Raise >>> continue_try_with\n else (\n let d = f () in\n if Deferred.is_determined d then continue_f () else d >>> continue_f)\n and continue_f () =\n if Deferred.is_determined stop\n then Ivar.fill_if_empty finished ()\n else alarm := run_at_internal t (Continue.at continue t) run_f ()\n and continue_try_with or_error =\n (match or_error with\n | Ok () -> ()\n | Error error -> Monitor.send_exn (Monitor.current ()) error);\n continue_f ()\n in\n run_f ()\n;;\n\nlet every' ?start ?stop ?continue_on_error ?finished t span f =\n if Time_ns.Span.( <= ) span Time_ns.Span.zero\n then\n raise_s [%message \"Time_source.every got nonpositive span\" (span : Time_ns.Span.t)];\n run_repeatedly t ?start ?stop ?continue_on_error ?finished ~f ~continue:(After span)\n;;\n\nlet every ?start ?stop ?continue_on_error t span f =\n every' t ?start ?stop ?continue_on_error ?finished:None span (fun () ->\n f ();\n return ())\n;;\n\nlet run_at_intervals' ?start ?stop ?continue_on_error t interval f =\n let now = now t in\n let base, start =\n match start with\n | None -> now, None\n | Some start ->\n ( start\n , Some\n (at\n t\n (Time_ns.next_multiple\n ()\n ~base:start\n ~after:now\n ~can_equal_after:true\n ~interval)) )\n in\n run_repeatedly\n t\n ?start\n ?stop\n ?continue_on_error\n ~f\n ~continue:(Next_multiple (base, interval))\n;;\n\nlet run_at_intervals ?start ?stop ?continue_on_error t interval f =\n run_at_intervals' ?start ?stop ?continue_on_error t interval (fun () ->\n f ();\n return ())\n;;\n\nlet with_timeout t span d =\n let timeout = Event.after t span in\n choose\n (* The code below does exhaustive case analysis in both [choice]s. Because [timeout]\n does not escape the scope of this function, certain cases should be impossible, and\n are marked as such with exceptions. We do not expect those exceptions to occur,\n but if they do, it likely indicates a bug in [choose] rather than\n [with_timeout]. *)\n [ choice d (fun v ->\n (match Event.abort timeout () with\n (* [Previously_happened] can occur if both [d] and [wait] become determined at\n the same time, e.g. [with_timeout (sec 0.) (return ())]. *)\n | Ok | Previously_happened () -> ()\n | Previously_aborted () ->\n raise_s [%message \"Time_source.with_timeout bug: should only abort once\"]);\n `Result v)\n ; choice (Event.fired timeout) (function\n | Happened () -> `Timeout\n | Aborted () ->\n raise_s\n [%message \"Time_source.with_timeout bug: both completed and timed out\"])\n ]\n;;\n\nlet of_synchronous t = t\nlet to_synchronous t = t\n","open! Base\n\ntype _ t =\n | Stack : 'a Stack.t -> 'a t\n | Counter : { mutable length : int } -> unit t\n[@@deriving sexp_of]\n\nlet of_list list = Stack (Stack.of_list list)\n\nlet create_counter ~length =\n if length < 0\n then\n raise_s\n [%message \"[Stack_or_counter.create_counter] got negative length\" (length : int)];\n Counter { length }\n;;\n\nlet length (type a) (t : a t) =\n match t with\n | Stack s -> Stack.length s\n | Counter r -> r.length\n;;\n\nlet clear (type a) (t : a t) =\n match t with\n | Stack s -> Stack.clear s\n | Counter r -> r.length <- 0\n;;\n\nlet push (type a) (t : a t) a =\n match t with\n | Stack s -> Stack.push s a\n | Counter r -> r.length <- r.length + 1\n;;\n\nlet pop_exn (type a) (t : a t) =\n match t with\n | Stack s -> Stack.pop_exn s\n | Counter r ->\n if r.length = 0 then raise_s [%message \"[Stack_or_counter.pop_exn] of empty stack\"];\n r.length <- r.length - 1\n;;\n\nlet iter (type a) (t : a t) ~(f : a -> unit) =\n match t with\n | Stack s -> Stack.iter s ~f\n | Counter r ->\n for _ = 1 to r.length do\n f ()\n done\n;;\n","open! Core_kernel\nopen! Import\nopen! Deferred_std\nmodule Deferred = Deferred1\n\ntype 'a outcome =\n [ `Ok of 'a\n | `Aborted\n | `Raised of exn\n ]\n[@@deriving sexp_of]\n\nmodule Internal_job : sig\n type 'a t [@@deriving sexp_of]\n\n val create : ('a -> 'b Deferred.t) -> 'a t * 'b outcome Deferred.t\n\n (* Every internal job will eventually be either [run] or [abort]ed, but not both. *)\n\n val run : 'a t -> 'a -> [ `Ok | `Raised ] Deferred.t\n val abort : _ t -> unit\nend = struct\n type 'a t =\n { start : [ `Abort | `Start of 'a ] Ivar.t\n ; outcome : [ `Ok | `Aborted | `Raised ] Deferred.t\n }\n [@@deriving sexp_of]\n\n let create work =\n let start = Ivar.create () in\n let result =\n match%bind Ivar.read start with\n | `Abort -> return `Aborted\n | `Start a ->\n (match%map Monitor.try_with (fun () -> work a) with\n | Ok a -> `Ok a\n | Error exn -> `Raised exn)\n in\n let outcome =\n match%map result with\n | `Ok _ -> `Ok\n | `Aborted -> `Aborted\n | `Raised _ -> `Raised\n in\n let t = { start; outcome } in\n t, result\n ;;\n\n let run t a =\n Ivar.fill t.start (`Start a);\n match%map t.outcome with\n | `Aborted -> assert false\n | (`Ok | `Raised) as x -> x\n ;;\n\n let abort t = Ivar.fill t.start `Abort\nend\n\ntype 'a t =\n { continue_on_error : bool\n ; max_concurrent_jobs : int\n ; (* [job_resources_not_in_use] holds resources that are not currently in use by a\n running job. *)\n job_resources_not_in_use : 'a Stack_or_counter.t\n ;\n (* [jobs_waiting_to_start] is the queue of jobs that haven't yet started. *)\n jobs_waiting_to_start : 'a Internal_job.t Queue.t\n ; (* [0 <= num_jobs_running <= max_concurrent_jobs]. *)\n mutable num_jobs_running : int\n ; (* [capacity_available] is [Some ivar] if user code has called [capacity_available t]\n and is waiting to be notified when capacity is available in the throttle.\n [maybe_start_job] will fill [ivar] when capacity becomes available, i.e. when\n [jobs_waiting_to_start] is empty and [num_jobs_running < max_concurrent_jobs]. *)\n mutable capacity_available : unit Ivar.t option\n ; (* [is_dead] is true if [t] was killed due to a job raising an exception or [kill t]\n being called. *)\n mutable is_dead : bool\n ; (* [cleans] holds functions that will be called to clean each resource when [t] is\n killed. *)\n mutable cleans : ('a -> unit Deferred.t) list\n ; (* [num_resources_not_cleaned] is the number of resources whose clean functions have\n not yet completed. While [t] is alive, [num_resources_not_cleaned =\n max_concurrent_jobs]. Once [t] is killed, [num_resources_not_cleaned] decreases to\n zero over time as the clean functions complete. *)\n mutable num_resources_not_cleaned : int\n ; (* [cleaned] becomes determined when [num_resources_not_cleaned] reaches zero,\n i.e. after [t] is killed and all its clean functions complete. *)\n cleaned : unit Ivar.t\n }\n[@@deriving fields, sexp_of]\n\nlet invariant invariant_a t : unit =\n try\n let check f field = f (Field.get field t) in\n Fields.iter\n ~continue_on_error:ignore\n ~max_concurrent_jobs:\n (check (fun max_concurrent_jobs -> assert (max_concurrent_jobs > 0)))\n ~job_resources_not_in_use:\n (check (fun job_resources_not_in_use ->\n Stack_or_counter.iter job_resources_not_in_use ~f:invariant_a;\n assert (\n Stack_or_counter.length job_resources_not_in_use\n = if t.is_dead then 0 else t.max_concurrent_jobs - t.num_jobs_running)))\n ~jobs_waiting_to_start:\n (check (function jobs_waiting_to_start ->\n if t.is_dead then assert (Queue.is_empty jobs_waiting_to_start)))\n ~num_jobs_running:\n (check (fun num_jobs_running ->\n assert (num_jobs_running >= 0);\n assert (num_jobs_running <= t.max_concurrent_jobs);\n if num_jobs_running < t.max_concurrent_jobs\n then assert (Queue.is_empty t.jobs_waiting_to_start)))\n ~capacity_available:\n (check (function\n | None -> ()\n | Some ivar -> assert (Ivar.is_empty ivar)))\n ~is_dead:ignore\n ~cleans:ignore\n ~num_resources_not_cleaned:\n (check (fun num_resources_not_cleaned ->\n assert (num_resources_not_cleaned >= 0);\n assert (num_resources_not_cleaned <= t.max_concurrent_jobs);\n if num_resources_not_cleaned < t.max_concurrent_jobs then assert t.is_dead))\n ~cleaned:\n (check (fun cleaned ->\n if Ivar.is_full cleaned then assert (t.num_resources_not_cleaned = 0)))\n with\n | exn -> raise_s [%message \"Throttle.invariant failed\" (exn : exn) (t : _ t)]\n;;\n\nmodule T2 = struct\n type nonrec ('a, 'kind) t = 'a t [@@deriving sexp_of]\n\n let invariant invariant_a _ t = invariant invariant_a t\nend\n\nlet num_jobs_waiting_to_start t = Queue.length t.jobs_waiting_to_start\n\nlet clean_resource t a =\n Deferred.all_unit (List.map t.cleans ~f:(fun f -> f a))\n >>> fun () ->\n t.num_resources_not_cleaned <- t.num_resources_not_cleaned - 1;\n if t.num_resources_not_cleaned = 0 then Ivar.fill t.cleaned ()\n;;\n\nlet kill t =\n if not t.is_dead\n then (\n t.is_dead <- true;\n Queue.iter t.jobs_waiting_to_start ~f:Internal_job.abort;\n Queue.clear t.jobs_waiting_to_start;\n Stack_or_counter.iter t.job_resources_not_in_use ~f:(fun a -> clean_resource t a);\n Stack_or_counter.clear t.job_resources_not_in_use)\n;;\n\nlet at_kill t f =\n (* We preserve the execution context so that exceptions raised by [f] go to the monitor\n in effect when [at_kill] was called. *)\n let f = unstage (Monitor.Exported_for_scheduler.preserve_execution_context' f) in\n t.cleans <- f :: t.cleans\n;;\n\nlet cleaned t = Ivar.read t.cleaned\n\nlet rec start_job t =\n assert (not t.is_dead);\n assert (t.num_jobs_running < t.max_concurrent_jobs);\n assert (not (Queue.is_empty t.jobs_waiting_to_start));\n let job = Queue.dequeue_exn t.jobs_waiting_to_start in\n t.num_jobs_running <- t.num_jobs_running + 1;\n let job_resource = Stack_or_counter.pop_exn t.job_resources_not_in_use in\n Internal_job.run job job_resource\n >>> fun res ->\n t.num_jobs_running <- t.num_jobs_running - 1;\n (match res with\n | `Ok -> ()\n | `Raised -> if not t.continue_on_error then kill t);\n if t.is_dead\n then clean_resource t job_resource\n else (\n Stack_or_counter.push t.job_resources_not_in_use job_resource;\n if not (Queue.is_empty t.jobs_waiting_to_start)\n then start_job t\n else (\n match t.capacity_available with\n | None -> ()\n | Some ivar ->\n Ivar.fill ivar ();\n t.capacity_available <- None))\n;;\n\nlet create_internal ~continue_on_error job_resources =\n let max_concurrent_jobs = Stack_or_counter.length job_resources in\n { continue_on_error\n ; max_concurrent_jobs\n ; job_resources_not_in_use = job_resources\n ; jobs_waiting_to_start = Queue.create ()\n ; num_jobs_running = 0\n ; capacity_available = None\n ; is_dead = false\n ; cleans = []\n ; num_resources_not_cleaned = max_concurrent_jobs\n ; cleaned = Ivar.create ()\n }\n;;\n\nlet create_with ~continue_on_error job_resources =\n create_internal ~continue_on_error (Stack_or_counter.of_list job_resources)\n;;\n\nmodule Sequencer = struct\n type nonrec 'a t = 'a t [@@deriving sexp_of]\n\n let create ?(continue_on_error = false) a = create_with ~continue_on_error [ a ]\nend\n\nlet create ~continue_on_error ~max_concurrent_jobs =\n if max_concurrent_jobs <= 0\n then\n raise_s\n [%message\n \"Throttle.create requires positive max_concurrent_jobs, but got\"\n (max_concurrent_jobs : int)];\n create_internal\n ~continue_on_error\n (Stack_or_counter.create_counter ~length:max_concurrent_jobs)\n;;\n\nmodule Job = struct\n type ('a, 'b) t =\n { internal_job : 'a Internal_job.t\n ; result : [ `Ok of 'b | `Aborted | `Raised of exn ] Deferred.t\n }\n\n let result t = t.result\n let abort t = Internal_job.abort t.internal_job\n\n let create f =\n let internal_job, result = Internal_job.create f in\n { internal_job; result }\n ;;\nend\n\nlet enqueue' t f =\n let job = Job.create f in\n if t.is_dead\n then Job.abort job\n else (\n Queue.enqueue t.jobs_waiting_to_start job.internal_job;\n if t.num_jobs_running < t.max_concurrent_jobs then start_job t);\n Job.result job\n;;\n\nlet handle_enqueue_result result =\n match result with\n | `Ok a -> a\n | `Aborted -> raise_s [%message \"throttle aborted job\"]\n | `Raised exn -> raise exn\n;;\n\nlet enqueue t f = enqueue' t f >>| handle_enqueue_result\n\nlet enqueue_exclusive t f =\n let n = t.max_concurrent_jobs in\n if Int.( >= ) n 1_000_000\n then\n raise_s\n [%sexp\n \"[enqueue_exclusive] was called with a very large value of \\\n [max_concurrent_jobs]. This doesn't work.\"];\n let done_ = Ivar.create () in\n assert (n > 0);\n let f_placeholder _slot = Ivar.read done_ in\n for _ = 1 to n - 1 do\n don't_wait_for (enqueue t f_placeholder)\n done;\n let%map result = enqueue' t (fun _slot -> f ()) in\n Ivar.fill done_ ();\n handle_enqueue_result result\n;;\n\nlet monad_sequence_how ?(how = `Sequential) ~f =\n stage\n (match how with\n | `Parallel -> f\n | (`Sequential | `Max_concurrent_jobs _) as how ->\n let max_concurrent_jobs =\n match how with\n | `Sequential -> 1\n | `Max_concurrent_jobs max_concurrent_jobs -> max_concurrent_jobs\n in\n let t = create ~continue_on_error:false ~max_concurrent_jobs in\n fun a -> enqueue t (fun () -> f a))\n;;\n\nlet monad_sequence_how2 ?(how = `Sequential) ~f =\n stage\n (match how with\n | `Parallel -> f\n | (`Sequential | `Max_concurrent_jobs _) as how ->\n let max_concurrent_jobs =\n match how with\n | `Sequential -> 1\n | `Max_concurrent_jobs max_concurrent_jobs -> max_concurrent_jobs\n in\n let t = create ~continue_on_error:false ~max_concurrent_jobs in\n fun a1 a2 -> enqueue t (fun () -> f a1 a2))\n;;\n\nlet prior_jobs_done t =\n (* We queue [t.max_concurrent_jobs] dummy jobs and when they are all started we know\n that all prior jobs finished. We make sure that all dummy jobs wait for the last one\n to get started before finishing. *)\n Deferred.create (fun all_dummy_jobs_running ->\n let dummy_jobs_running = ref 0 in\n for _ = 1 to t.max_concurrent_jobs do\n don't_wait_for\n (enqueue t (fun _ ->\n incr dummy_jobs_running;\n if !dummy_jobs_running = t.max_concurrent_jobs\n then Ivar.fill all_dummy_jobs_running ();\n Ivar.read all_dummy_jobs_running))\n done)\n;;\n\nlet capacity_available t =\n if num_jobs_running t < max_concurrent_jobs t\n then return ()\n else (\n match t.capacity_available with\n | Some ivar -> Ivar.read ivar\n | None -> Deferred.create (fun ivar -> t.capacity_available <- Some ivar))\n;;\n","open! Core_kernel\nopen! Import\ninclude Scheduler\n\nlet enqueue_job execution_context f a = enqueue (t ()) execution_context f a\n\nlet thread_safe_enqueue_job execution_context f a =\n thread_safe_enqueue_external_job (t ()) execution_context f a\n;;\n\nlet current_execution_context () = current_execution_context (t ())\nlet cycle_count () = cycle_count (t ())\nlet cycle_start_ns () = cycle_start (t ())\nlet cycle_start () = Time_ns.to_time_float_round_nearest (cycle_start_ns ())\nlet cycle_times_ns () = map_cycle_times (t ()) ~f:Fn.id\nlet cycle_times () = map_cycle_times (t ()) ~f:Time_ns.Span.to_span_float_round_nearest\nlet total_cycle_time () = total_cycle_time (t ())\nlet long_cycles ~at_least = long_cycles (t ()) ~at_least\nlet long_cycles_with_context ~at_least = long_cycles_with_context (t ()) ~at_least\nlet long_jobs_with_context = long_jobs_with_context (t ())\nlet last_cycle_time () = last_cycle_time (t ())\nlet event_precision_ns () = event_precision (t ())\nlet event_precision () = Time_ns.Span.to_span_float_round_nearest (event_precision_ns ())\n\nlet set_max_num_jobs_per_priority_per_cycle i =\n set_max_num_jobs_per_priority_per_cycle (t ()) i\n;;\n\nlet max_num_jobs_per_priority_per_cycle () = max_num_jobs_per_priority_per_cycle (t ())\nlet set_record_backtraces bool = set_record_backtraces (t ()) bool\nlet force_current_cycle_to_end () = force_current_cycle_to_end (t ())\nlet yield () = yield (t ())\nlet yield_until_no_jobs_remain ?may_return_immediately () =\n yield_until_no_jobs_remain ?may_return_immediately (t ())\n;;\n\nlet yield_every ~n =\n let yield_every = Staged.unstage (yield_every ~n) in\n let t = t () in\n stage (fun () -> yield_every t)\n;;\n\nlet num_jobs_run () = num_jobs_run (t ())\nlet num_pending_jobs () = num_pending_jobs (t ())\n\nmodule Expert = struct\n let run_cycles_until_no_jobs_remain = run_cycles_until_no_jobs_remain\n let set_on_start_of_cycle f = set_on_start_of_cycle (t ()) f\n let set_on_end_of_cycle f = set_on_end_of_cycle (t ()) f\n let last_cycle_num_jobs () = last_cycle_num_jobs (t ())\n let run_every_cycle_start f = run_every_cycle_start (t ()) ~f\n let run_every_cycle_end f = run_every_cycle_end (t ()) ~f\nend\n\nmodule Private = Scheduler\n","open! Core_kernel\nopen! Import\n\nmodule type Clock = Clock_intf.Clock\nmodule type Clock_deprecated = Clock_intf.Clock_deprecated\n\nmodule Scheduler = Scheduler1\n\nlet time_source () = (Scheduler.t ()).time_source |> Time_source.of_synchronous\nlet after span = Time_source.after (time_source ()) span\nlet at time = Time_source.at (time_source ()) time\n\nlet at_varying_intervals ?stop compute_span =\n Time_source.at_varying_intervals ?stop (time_source ()) compute_span\n;;\n\nlet at_intervals ?start ?stop interval =\n Time_source.at_intervals ?start ?stop (time_source ()) interval\n;;\n\nlet every' ?start ?stop ?continue_on_error ?finished span f =\n Time_source.every' ?start ?stop ?continue_on_error ?finished (time_source ()) span f\n;;\n\nlet every ?start ?stop ?continue_on_error span f =\n Time_source.every ?start ?stop ?continue_on_error (time_source ()) span f\n;;\n\nlet run_after span f a = Time_source.run_after (time_source ()) span f a\nlet run_at time f a = Time_source.run_at (time_source ()) time f a\n\nlet run_at_intervals ?start ?stop ?continue_on_error interval f =\n Time_source.run_at_intervals\n ?start\n ?stop\n ?continue_on_error\n (time_source ())\n interval\n f\n;;\n\nlet run_at_intervals' ?start ?stop ?continue_on_error interval f =\n Time_source.run_at_intervals'\n ?start\n ?stop\n ?continue_on_error\n (time_source ())\n interval\n f\n;;\n\nlet with_timeout span d = Time_source.with_timeout (time_source ()) span d\n\nmodule Event = struct\n include Time_source.Event\n\n let after span = after (time_source ()) span\n let run_after span f a = run_after (time_source ()) span f a\n let at time = at (time_source ()) time\n let run_at time f z = run_at (time_source ()) time f z\nend\n","open Core_kernel\nopen Deferred_std\nmodule Deferred = Deferred1\n\nlet foldi t ~init ~f =\n Deferred.create (fun result ->\n let rec loop t i b =\n match t with\n | [] -> Ivar.fill result b\n | x :: xs -> f i b x >>> fun b -> loop xs (i + 1) b\n in\n loop t 0 init)\n;;\n\nlet fold t ~init ~f = foldi t ~init ~f:(fun _ a x -> f a x)\n\nlet seqmapi t ~f =\n foldi t ~init:[] ~f:(fun i bs a ->\n let%map b = f i a in\n b :: bs)\n >>| List.rev\n;;\n\nlet all ds = seqmapi ds ~f:(fun _ x -> x)\nlet all_unit ds = Deferred.ignore_m (fold ds ~init:() ~f:(fun () d -> d))\n\nlet iteri ?(how = `Sequential) t ~f =\n match how with\n | (`Parallel | `Max_concurrent_jobs _) as how ->\n all_unit (List.mapi t ~f:(unstage (Throttle.monad_sequence_how2 ~how ~f)))\n | `Sequential -> foldi t ~init:() ~f:(fun i () x -> f i x)\n;;\n\nlet mapi ?(how = `Sequential) t ~f =\n match how with\n | (`Parallel | `Max_concurrent_jobs _) as how ->\n all (List.mapi t ~f:(unstage (Throttle.monad_sequence_how2 ~how ~f)))\n | `Sequential -> seqmapi t ~f\n;;\n\nlet filteri ?how t ~f =\n let%map bools = mapi t ?how ~f in\n List.rev (List.fold2_exn t bools ~init:[] ~f:(fun ac x b -> if b then x :: ac else ac))\n;;\n\nlet filter_mapi ?how t ~f = mapi t ?how ~f >>| List.filter_opt\nlet concat_mapi ?how t ~f = mapi t ?how ~f >>| List.concat\n\nlet find_mapi t ~f =\n let rec find_mapi t ~f i =\n match t with\n | [] -> return None\n | hd :: tl ->\n (match%bind f i hd with\n | None -> find_mapi tl ~f (i + 1)\n | Some _ as some -> return some)\n in\n find_mapi t ~f 0\n;;\n\nlet findi t ~f =\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if b then Some (i, elt) else None)\n;;\n\nlet find t ~f =\n find_mapi t ~f:(fun _ elt ->\n let%map b = f elt in\n if b then Some elt else None)\n;;\n\nlet existsi t ~f =\n match%map\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if b then Some () else None)\n with\n | Some () -> true\n | None -> false\n;;\n\nlet for_alli t ~f =\n match%map\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if not b then Some () else None)\n with\n | Some () -> false\n | None -> true\n;;\n\nlet iter ?how t ~f = iteri ?how t ~f:(fun _ a -> f a)\nlet map ?how t ~f = mapi ?how t ~f:(fun _ a -> f a)\nlet filter ?how t ~f = filteri ?how t ~f:(fun _ a -> f a)\nlet filter_map ?how t ~f = filter_mapi ?how t ~f:(fun _ a -> f a)\nlet concat_map ?how t ~f = concat_mapi ?how t ~f:(fun _ a -> f a)\nlet find_map t ~f = find_mapi t ~f:(fun _ a -> f a)\nlet exists t ~f = existsi t ~f:(fun _ a -> f a)\nlet for_all t ~f = for_alli t ~f:(fun _ a -> f a)\nlet init ?how n ~f = map ?how (List.init n ~f:Fn.id) ~f\n","open Core_kernel\nopen Deferred_std\nmodule Deferred = Deferred1\n\nmodule T = struct\n type ('a, 'error) t = ('a, 'error) Result.t Deferred.t\nend\n\ninclude T\n\nlet combine t1 t2 ~ok ~err =\n let%map t1 = t1\n and t2 = t2 in\n Result.combine t1 t2 ~ok ~err\n;;\n\ninclude Monad.Make2 (struct\n include T\n\n let return a = Deferred.return (Ok a)\n\n let bind t ~f =\n Deferred.bind t ~f:(function\n | Ok a -> f a\n | Error _ as error -> Deferred.return error)\n ;;\n\n let map t ~f = Deferred.map t ~f:(fun r -> Result.map r ~f)\n let map = `Custom map\n end)\n\nlet fail x = Deferred.return (Error x)\nlet failf format = Printf.ksprintf fail format\nlet map_error t ~f = Deferred.map t ~f:(fun r -> Result.map_error r ~f)\n","open! Core_kernel\nopen! Import\nmodule Deferred = Deferred1\n\nmodule Monitor = struct\n let try_with = Monitor.try_with\nend\n\n(* Copied to [eager_deferred_or_error.ml]. There should be no diffs below this line. *)\n\ninclude (Deferred_result : Monad.S2 with type ('a, 'b) t := ('a, 'b) Deferred_result.t)\n\ntype 'a t = 'a Or_error.t Deferred.t\n\ninclude Applicative.Make (struct\n type nonrec 'a t = 'a t\n\n let return = return\n\n let apply f x =\n Deferred_result.combine\n f\n x\n ~ok:(fun f x -> f x)\n ~err:(fun e1 e2 -> Error.of_list [ e1; e2 ])\n ;;\n\n let map = `Custom map\n end)\n\nmodule Let_syntax = struct\n let return = return\n\n include Monad_infix\n\n module Let_syntax = struct\n let return = return\n let map = map\n let bind = bind\n let both = both\n\n (* from Applicative.Make *)\n module Open_on_rhs = struct end\n end\nend\n\nopen Let_syntax\n\nlet fail error = Deferred.return (Result.fail error)\nlet ok_exn t = Deferred.map t ~f:Or_error.ok_exn\nlet of_exn exn = Deferred.return (Or_error.of_exn exn)\nlet of_exn_result t = Deferred.map t ~f:Or_error.of_exn_result\nlet error msg v sexp_of = Deferred.return (Or_error.error msg v sexp_of)\nlet error_s sexp = Deferred.return (Or_error.error_s sexp)\nlet error_string msg = Deferred.return (Or_error.error_string msg)\nlet errorf format = ksprintf error_string format\nlet tag t ~tag = Deferred.map t ~f:(Or_error.tag ~tag)\nlet tag_s t ~tag = Deferred.map t ~f:(Or_error.tag_s ~tag)\n\nlet tag_arg t message a sexp_of_a =\n Deferred.map t ~f:(fun t -> Or_error.tag_arg t message a sexp_of_a)\n;;\n\nlet unimplemented msg = Deferred.return (Or_error.unimplemented msg)\nlet combine_errors l = Deferred.map (Deferred.all l) ~f:Or_error.combine_errors\nlet combine_errors_unit l = Deferred.map (Deferred.all l) ~f:Or_error.combine_errors_unit\n\nlet filter_ok_at_least_one l =\n Deferred.map (Deferred.all l) ~f:Or_error.filter_ok_at_least_one\n;;\n\nlet find_map_ok l ~f =\n Deferred.repeat_until_finished (l, []) (fun (l, errors) ->\n match l with\n | [] ->\n let errors = Error.of_list (List.rev errors) in\n Deferred.return (`Finished (Error errors))\n | hd :: tl ->\n Deferred.map (f hd) ~f:(function\n | Error current_error -> `Repeat (tl, current_error :: errors)\n | Ok result -> `Finished (Ok result)))\n;;\n\nlet ok_unit = return ()\n\nlet try_with ?extract_exn ?run ?here ?name f =\n Deferred.map (Monitor.try_with ?extract_exn ?run ?here ?name f) ~f:(function\n | Error exn -> Error (Error.of_exn exn)\n | Ok _ as ok -> ok)\n;;\n\nlet try_with_join ?extract_exn ?run ?here ?name f =\n Deferred.map (try_with ?extract_exn ?run ?here ?name f) ~f:Or_error.join\n;;\n\nmodule List = struct\n let foldi list ~init:acc ~f =\n let rec loop i acc = function\n | [] -> return acc\n | hd :: tl ->\n let%bind acc = f i acc hd in\n loop (i + 1) acc tl\n in\n loop 0 acc list\n ;;\n\n let fold t ~init ~f = foldi t ~init ~f:(fun _ a x -> f a x)\n\n let seqmapi t ~f =\n foldi t ~init:[] ~f:(fun i bs a ->\n let%map b = f i a in\n b :: bs)\n >>| List.rev\n ;;\n\n let all = all\n let all_unit = all_unit\n\n let iteri ?(how = `Sequential) t ~f =\n match how with\n | (`Parallel | `Max_concurrent_jobs _) as how ->\n all_unit (List.mapi t ~f:(unstage (Throttle.monad_sequence_how2 ~how ~f)))\n | `Sequential -> foldi t ~init:() ~f:(fun i () x -> f i x)\n ;;\n\n let mapi ?(how = `Sequential) t ~f =\n match how with\n | (`Parallel | `Max_concurrent_jobs _) as how ->\n all (List.mapi t ~f:(unstage (Throttle.monad_sequence_how2 ~how ~f)))\n | `Sequential -> seqmapi t ~f\n ;;\n\n let filter_mapi ?how t ~f = mapi t ?how ~f >>| List.filter_opt\n let concat_mapi ?how t ~f = mapi t ?how ~f >>| List.concat\n\n let filteri ?how t ~f =\n filter_mapi ?how t ~f:(fun i x ->\n let%map b = f i x in\n if b then Some x else None)\n ;;\n\n let find_mapi t ~f =\n let rec find_mapi t ~f i =\n match t with\n | [] -> return None\n | hd :: tl ->\n (match%bind f i hd with\n | None -> find_mapi tl ~f (i + 1)\n | Some _ as some -> return some)\n in\n find_mapi t ~f 0\n ;;\n\n let find_map t ~f = find_mapi t ~f:(fun _ a -> f a)\n\n let findi t ~f =\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if b then Some (i, elt) else None)\n ;;\n\n let find t ~f =\n find_map t ~f:(fun elt ->\n let%map b = f elt in\n if b then Some elt else None)\n ;;\n\n let existsi t ~f =\n match%map\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if b then Some () else None)\n with\n | Some () -> true\n | None -> false\n ;;\n\n let for_alli t ~f =\n match%map\n find_mapi t ~f:(fun i elt ->\n let%map b = f i elt in\n if not b then Some () else None)\n with\n | Some () -> false\n | None -> true\n ;;\n\n let iter ?how t ~f = iteri ?how t ~f:(fun _ a -> f a)\n let map ?how t ~f = mapi ?how t ~f:(fun _ a -> f a)\n let filter ?how t ~f = filteri ?how t ~f:(fun _ a -> f a)\n let filter_map ?how t ~f = filter_mapi ?how t ~f:(fun _ a -> f a)\n let concat_map ?how t ~f = concat_mapi ?how t ~f:(fun _ a -> f a)\n let find_map t ~f = find_mapi t ~f:(fun _ a -> f a)\n let exists t ~f = existsi t ~f:(fun _ a -> f a)\n let for_all t ~f = for_alli t ~f:(fun _ a -> f a)\n let init ?how n ~f = map ?how (List.init n ~f:Fn.id) ~f\nend\n\nlet rec repeat_until_finished state f =\n match%bind f state with\n | `Repeat state -> repeat_until_finished state f\n | `Finished state -> return state\n;;\n","open Core_kernel\nopen Deferred_std\nmodule List = Deferred_list\n\n(* We implement all of the [Queue] operations by converting the queue to a list and then\n using the corresponding [List] operation. We use lists rather than arrays because\n arrays longer than a certain length are allocated in the major heap, which can cause\n unnecessary promotion of the elements in the queue. Also, when one is folding or\n iterating over an array, the entire array must be kept alive. When folding or\n iterating over a list, only the remaining tail of the list is kept alive. So, using\n arrays rather than lists would increase the live-space needed by the program. *)\n\nlet foldi t ~init ~f = List.foldi (Queue.to_list t) ~init ~f\nlet fold t ~init ~f = List.fold (Queue.to_list t) ~init ~f\nlet all t = List.all (Queue.to_list t) >>| Queue.of_list\nlet all_unit t = List.all_unit (Queue.to_list t)\nlet iter ?how t ~f = List.iter ?how (Queue.to_list t) ~f\nlet iteri ?how t ~f = List.iteri ?how (Queue.to_list t) ~f\nlet map ?how t ~f = List.map ?how (Queue.to_list t) ~f >>| Queue.of_list\nlet mapi ?how t ~f = List.mapi ?how (Queue.to_list t) ~f >>| Queue.of_list\nlet init ?how n ~f = List.init ?how n ~f >>| Queue.of_list\nlet filter ?how t ~f = List.filter ?how (Queue.to_list t) ~f >>| Queue.of_list\nlet filteri ?how t ~f = List.filteri ?how (Queue.to_list t) ~f >>| Queue.of_list\nlet filter_map ?how t ~f = List.filter_map ?how (Queue.to_list t) ~f >>| Queue.of_list\nlet filter_mapi ?how t ~f = List.filter_mapi ?how (Queue.to_list t) ~f >>| Queue.of_list\n\nlet concat_map ?how t ~f =\n List.concat_map ?how (Queue.to_list t) ~f:(fun x -> f x >>| Queue.to_list)\n >>| Queue.of_list\n;;\n\nlet concat_mapi ?how t ~f =\n List.concat_mapi ?how (Queue.to_list t) ~f:(fun i x -> f i x >>| Queue.to_list)\n >>| Queue.of_list\n;;\n\nlet find_map t ~f = List.find_map (Queue.to_list t) ~f\nlet find_mapi t ~f = List.find_mapi (Queue.to_list t) ~f\nlet find t ~f = List.find (Queue.to_list t) ~f\nlet findi t ~f = List.findi (Queue.to_list t) ~f\nlet for_all t ~f = List.for_all (Queue.to_list t) ~f\nlet for_alli t ~f = List.for_alli (Queue.to_list t) ~f\nlet exists t ~f = List.exists (Queue.to_list t) ~f\nlet existsi t ~f = List.existsi (Queue.to_list t) ~f\n","include Deferred1\nmodule Array = Deferred_array\nmodule List = Deferred_list\nmodule Map = Deferred_map\nmodule Memo = Deferred_memo\nmodule Option = Deferred_option\nmodule Or_error = Deferred_or_error\nmodule Queue = Deferred_queue\nmodule Result = Deferred_result\nmodule Sequence = Deferred_sequence\n","open Core_kernel\ninclude Gc\n\n(** [add_finalizer f x] is like [Gc.finalise f x], except that the finalizer is guaranteed\n to run as an Async job (i.e. without interrupting other Async jobs). Unprotected use\n of [Caml.Gc.finalise] or [Core.Gc.add_finalizer] in Async programs is wrong, because\n the finalizers won't hold the async lock, and thus could interleave arbitrarily with\n async jobs. *)\nlet add_finalizer heap_block f = Scheduler.(add_finalizer (t ())) heap_block f\n\nlet add_finalizer_exn heap_block f = Scheduler.(add_finalizer_exn (t ())) heap_block f\nlet add_finalizer_last heap_block f = Scheduler.(add_finalizer_last (t ())) heap_block f\n\nlet add_finalizer_last_exn heap_block f =\n Scheduler.(add_finalizer_last_exn (t ())) heap_block f\n;;\n\nmodule Alarm = struct\n module Alarm = Gc.Expert.Alarm\n\n type t = Alarm.t [@@deriving sexp_of]\n\n let create f = Scheduler.(create_alarm (t ())) f\n let delete = Alarm.delete\nend\n","# 1 \"src/digestif_bi.ml\"\nopen Bigarray_compat\n\ntype t = (char, int8_unsigned_elt, c_layout) Array1.t\n\nlet create n = Array1.create Char c_layout n\n\nlet length = Array1.dim\n\nlet sub = Array1.sub\n\nlet empty = Array1.create Char c_layout 0\n\nlet get = Array1.get\n\nlet copy t =\n let r = create (length t) in\n Array1.blit t r ;\n r\n\nlet init l f =\n let v = Array1.create Char c_layout l in\n for i = 0 to l - 1 do\n Array1.set v i (f i)\n done ;\n v\n\nexternal unsafe_get_32 : t -> int -> int32 = \"%caml_bigstring_get32u\"\n\nexternal unsafe_get_64 : t -> int -> int64 = \"%caml_bigstring_get64u\"\n\nlet unsafe_get_nat : t -> int -> nativeint =\n fun s i ->\n if Sys.word_size = 32\n then Nativeint.of_int32 @@ unsafe_get_32 s i\n else Int64.to_nativeint @@ unsafe_get_64 s i\n\nexternal unsafe_set_32 : t -> int -> int32 -> unit = \"%caml_bigstring_set32u\"\n\nexternal unsafe_set_64 : t -> int -> int64 -> unit = \"%caml_bigstring_set64u\"\n\nlet unsafe_set_nat : t -> int -> nativeint -> unit =\n fun s i v ->\n if Sys.word_size = 32\n then unsafe_set_32 s i (Nativeint.to_int32 v)\n else unsafe_set_64 s i (Int64.of_nativeint v)\n\nlet to_string v = String.init (length v) (Array1.get v)\n\nlet blit_from_bytes src src_off dst dst_off len =\n for i = 0 to len - 1 do\n Array1.set dst (dst_off + i) (Bytes.get src (src_off + i))\n done\n\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\n\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\n\nexternal swapnat : nativeint -> nativeint = \"%bswap_native\"\n\nlet cpu_to_be32 s i v =\n if Sys.big_endian then unsafe_set_32 s i v else unsafe_set_32 s i (swap32 v)\n\nlet cpu_to_le32 s i v =\n if Sys.big_endian then unsafe_set_32 s i (swap32 v) else unsafe_set_32 s i v\n\nlet cpu_to_be64 s i v =\n if Sys.big_endian then unsafe_set_64 s i v else unsafe_set_64 s i (swap64 v)\n\nlet cpu_to_le64 s i v =\n if Sys.big_endian then unsafe_set_64 s i (swap64 v) else unsafe_set_64 s i v\n\nlet be32_to_cpu s i =\n if Sys.big_endian then unsafe_get_32 s i else swap32 @@ unsafe_get_32 s i\n\nlet le32_to_cpu s i =\n if Sys.big_endian then swap32 @@ unsafe_get_32 s i else unsafe_get_32 s i\n\nlet be64_to_cpu s i =\n if Sys.big_endian then unsafe_get_64 s i else swap64 @@ unsafe_get_64 s i\n\nlet le64_to_cpu s i =\n if Sys.big_endian then swap64 @@ unsafe_get_64 s i else unsafe_get_64 s i\n\nlet benat_to_cpu s i =\n if Sys.big_endian then unsafe_get_nat s i else swapnat @@ unsafe_get_nat s i\n\nlet cpu_to_benat s i v =\n if Sys.big_endian\n then unsafe_set_nat s i v\n else unsafe_set_nat s i (swapnat v)\n","# 1 \"src/digestif_by.ml\"\ninclude Bytes\n\nexternal unsafe_get_32 : t -> int -> int32 = \"%caml_string_get32u\"\n\nexternal unsafe_get_64 : t -> int -> int64 = \"%caml_string_get64u\"\n\nlet unsafe_get_nat : t -> int -> nativeint =\n fun s i ->\n if Sys.word_size = 32\n then Nativeint.of_int32 @@ unsafe_get_32 s i\n else Int64.to_nativeint @@ unsafe_get_64 s i\n\nexternal unsafe_set_32 : t -> int -> int32 -> unit = \"%caml_string_set32u\"\n\nexternal unsafe_set_64 : t -> int -> int64 -> unit = \"%caml_string_set64u\"\n\nlet unsafe_set_nat : t -> int -> nativeint -> unit =\n fun s i v ->\n if Sys.word_size = 32\n then unsafe_set_32 s i (Nativeint.to_int32 v)\n else unsafe_set_64 s i (Int64.of_nativeint v)\n\nlet blit_from_bigstring src src_off dst dst_off len =\n for i = 0 to len - 1 do\n set dst (dst_off + i) src.{src_off + i}\n done\n\nlet rpad a size x =\n let l = length a in\n let b = create size in\n blit a 0 b 0 l ;\n fill b l (size - l) x ;\n b\n\nexternal swap32 : int32 -> int32 = \"%bswap_int32\"\n\nexternal swap64 : int64 -> int64 = \"%bswap_int64\"\n\nexternal swapnat : nativeint -> nativeint = \"%bswap_native\"\n\nlet cpu_to_be32 s i v =\n if Sys.big_endian then unsafe_set_32 s i v else unsafe_set_32 s i (swap32 v)\n\nlet cpu_to_le32 s i v =\n if Sys.big_endian then unsafe_set_32 s i (swap32 v) else unsafe_set_32 s i v\n\nlet cpu_to_be64 s i v =\n if Sys.big_endian then unsafe_set_64 s i v else unsafe_set_64 s i (swap64 v)\n\nlet cpu_to_le64 s i v =\n if Sys.big_endian then unsafe_set_64 s i (swap64 v) else unsafe_set_64 s i v\n\nlet be32_to_cpu s i =\n if Sys.big_endian then unsafe_get_32 s i else swap32 @@ unsafe_get_32 s i\n\nlet le32_to_cpu s i =\n if Sys.big_endian then swap32 @@ unsafe_get_32 s i else unsafe_get_32 s i\n\nlet be64_to_cpu s i =\n if Sys.big_endian then unsafe_get_64 s i else swap64 @@ unsafe_get_64 s i\n\nlet le64_to_cpu s i =\n if Sys.big_endian then swap64 @@ unsafe_get_64 s i else unsafe_get_64 s i\n\nlet benat_to_cpu s i =\n if Sys.big_endian then unsafe_get_nat s i else swapnat @@ unsafe_get_nat s i\n\nlet cpu_to_benat s i v =\n if Sys.big_endian\n then unsafe_set_nat s i v\n else unsafe_set_nat s i (swapnat v)\n","module Nat = struct\n include Nativeint\n\n let ( lxor ) = Nativeint.logxor\nend\n\nmodule type BUFFER = sig\n type t\n\n val length : t -> int\n\n val sub : t -> int -> int -> t\n\n val copy : t -> t\n\n val benat_to_cpu : t -> int -> nativeint\n\n val cpu_to_benat : t -> int -> nativeint -> unit\nend\n\nlet imin (a : int) (b : int) = if a < b then a else b\n\nmodule Make (B : BUFFER) = struct\n let size_of_long = Sys.word_size / 8\n\n (* XXX(dinosaure): I'm not sure about this code. May be we don't need the\n first loop and the _optimization_ is irrelevant. *)\n let xor_into src src_off dst dst_off n =\n let n = ref n in\n let i = ref 0 in\n while !n >= size_of_long do\n B.cpu_to_benat dst (dst_off + !i)\n Nat.(\n B.benat_to_cpu dst (dst_off + !i)\n lxor B.benat_to_cpu src (src_off + !i)) ;\n n := !n - size_of_long ;\n i := !i + size_of_long\n done ;\n while !n > 0 do\n B.cpu_to_benat dst (dst_off + !i)\n Nat.(\n B.benat_to_cpu src (src_off + !i)\n lxor B.benat_to_cpu dst (dst_off + !i)) ;\n incr i ;\n decr n\n done\n\n let xor_into a b n =\n if n > imin (B.length a) (B.length b)\n then raise (Invalid_argument \"Baijiu.Xor.xor_inrot: buffers to small\")\n else xor_into a 0 b 0 n\n\n let xor a b =\n let l = imin (B.length a) (B.length b) in\n let r = B.copy (B.sub b 0 l) in\n xor_into a r l ;\n r\nend\n\nmodule Bytes = Make (Digestif_by)\nmodule Bigstring = Make (Digestif_bi)\n","# 1 \"src/digestif_conv.ml\"\nlet invalid_arg fmt = Format.ksprintf (fun s -> invalid_arg s) fmt\n\nmodule Make (D : sig\n val digest_size : int\nend) =\nstruct\n let to_hex hash =\n let res = Bytes.create (D.digest_size * 2) in\n let chr x =\n match x with\n | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 -> Char.chr (48 + x)\n | _ -> Char.chr (97 + (x - 10)) in\n for i = 0 to D.digest_size - 1 do\n let v = Char.code hash.[i] in\n Bytes.unsafe_set res (i * 2) (chr (v lsr 4)) ;\n Bytes.unsafe_set res ((i * 2) + 1) (chr (v land 0x0F))\n done ;\n Bytes.unsafe_to_string res\n\n let code x =\n match x with\n | '0' .. '9' -> Char.code x - Char.code '0'\n | 'A' .. 'F' -> Char.code x - Char.code 'A' + 10\n | 'a' .. 'f' -> Char.code x - Char.code 'a' + 10\n | _ -> invalid_arg \"of_hex: %02X\" (Char.code x)\n\n let decode chr1 chr2 = Char.chr ((code chr1 lsl 4) lor code chr2)\n\n let of_hex hex =\n let offset = ref 0 in\n let rec go have_first idx =\n if !offset + idx >= String.length hex\n then '\\x00'\n else\n match hex.[!offset + idx] with\n | ' ' | '\\t' | '\\r' | '\\n' ->\n incr offset ;\n go have_first idx\n | chr2 when have_first -> chr2\n | chr1 ->\n incr offset ;\n let chr2 = go true idx in\n if chr2 <> '\\x00'\n then decode chr1 chr2\n else invalid_arg \"of_hex: odd number of hex characters\" in\n String.init D.digest_size (go false)\n\n let of_hex_opt hex =\n match of_hex hex with\n | digest -> Some digest\n | exception Invalid_argument _ -> None\n\n let consistent_of_hex str =\n let offset = ref 0 in\n let rec go have_first idx =\n if !offset + idx >= String.length str\n then invalid_arg \"Not enough hex value\"\n else\n match str.[!offset + idx] with\n | ' ' | '\\t' | '\\r' | '\\n' ->\n incr offset ;\n go have_first idx\n | chr2 when have_first -> chr2\n | chr1 ->\n incr offset ;\n let chr2 = go true idx in\n decode chr1 chr2 in\n let res = String.init D.digest_size (go false) in\n let is_wsp = function ' ' | '\\t' | '\\r' | '\\n' -> true | _ -> false in\n while\n D.digest_size + !offset < String.length str\n && is_wsp str.[!offset + (D.digest_size * 2)]\n do\n incr offset\n done ;\n if !offset + D.digest_size = String.length str\n then res\n else\n invalid_arg \"Too much enough bytes (reach: %d, expect: %d)\"\n (!offset + (D.digest_size * 2))\n (String.length str)\n\n let consistent_of_hex_opt hex =\n match consistent_of_hex hex with\n | digest -> Some digest\n | exception Invalid_argument _ -> None\n\n let pp ppf hash =\n for i = 0 to D.digest_size - 1 do\n Format.fprintf ppf \"%02x\" (Char.code hash.[i])\n done\n\n let of_raw_string x =\n if String.length x <> D.digest_size\n then invalid_arg \"invalid hash size\"\n else x\n\n let of_raw_string_opt x =\n match of_raw_string x with\n | digest -> Some digest\n | exception Invalid_argument _ -> None\n\n let to_raw_string x = x\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let lnot = Int32.lognot\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\n\n let ror32 a n = (a lsr n) lor (a lsl (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\nend\n\nmodule type S = sig\n type kind = [ `MD5 ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int32 array }\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `MD5 ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int32 array }\n\n let dup ctx = { size = ctx.size; b = By.copy ctx.b; h = Array.copy ctx.h }\n\n let init () =\n let b = By.make 64 '\\x00' in\n {\n size = 0L;\n b;\n h = [| 0x67452301l; 0xefcdab89l; 0x98badcfel; 0x10325476l |];\n }\n\n let f1 x y z = Int32.(z lxor (x land (y lxor z)))\n\n let f2 x y z = f1 z x y\n\n let f3 x y z = Int32.(x lxor y lxor z)\n\n let f4 x y z = Int32.(y lxor (x lor lnot z))\n\n let md5_do_chunk :\n type a. le32_to_cpu:(a -> int -> int32) -> ctx -> a -> int -> unit =\n fun ~le32_to_cpu ctx buf off ->\n let a, b, c, d =\n (ref ctx.h.(0), ref ctx.h.(1), ref ctx.h.(2), ref ctx.h.(3)) in\n let w = Array.make 16 0l in\n for i = 0 to 15 do\n w.(i) <- le32_to_cpu buf (off + (i * 4))\n done ;\n let round f a b c d i k s =\n let open Int32 in\n a := !a + f !b !c !d + w.(i) + k ;\n a := rol32 !a s ;\n a := !a + !b in\n round f1 a b c d 0 0xd76aa478l 7 ;\n round f1 d a b c 1 0xe8c7b756l 12 ;\n round f1 c d a b 2 0x242070dbl 17 ;\n round f1 b c d a 3 0xc1bdceeel 22 ;\n round f1 a b c d 4 0xf57c0fafl 7 ;\n round f1 d a b c 5 0x4787c62al 12 ;\n round f1 c d a b 6 0xa8304613l 17 ;\n round f1 b c d a 7 0xfd469501l 22 ;\n round f1 a b c d 8 0x698098d8l 7 ;\n round f1 d a b c 9 0x8b44f7afl 12 ;\n round f1 c d a b 10 0xffff5bb1l 17 ;\n round f1 b c d a 11 0x895cd7bel 22 ;\n round f1 a b c d 12 0x6b901122l 7 ;\n round f1 d a b c 13 0xfd987193l 12 ;\n round f1 c d a b 14 0xa679438el 17 ;\n round f1 b c d a 15 0x49b40821l 22 ;\n round f2 a b c d 1 0xf61e2562l 5 ;\n round f2 d a b c 6 0xc040b340l 9 ;\n round f2 c d a b 11 0x265e5a51l 14 ;\n round f2 b c d a 0 0xe9b6c7aal 20 ;\n round f2 a b c d 5 0xd62f105dl 5 ;\n round f2 d a b c 10 0x02441453l 9 ;\n round f2 c d a b 15 0xd8a1e681l 14 ;\n round f2 b c d a 4 0xe7d3fbc8l 20 ;\n round f2 a b c d 9 0x21e1cde6l 5 ;\n round f2 d a b c 14 0xc33707d6l 9 ;\n round f2 c d a b 3 0xf4d50d87l 14 ;\n round f2 b c d a 8 0x455a14edl 20 ;\n round f2 a b c d 13 0xa9e3e905l 5 ;\n round f2 d a b c 2 0xfcefa3f8l 9 ;\n round f2 c d a b 7 0x676f02d9l 14 ;\n round f2 b c d a 12 0x8d2a4c8al 20 ;\n round f3 a b c d 5 0xfffa3942l 4 ;\n round f3 d a b c 8 0x8771f681l 11 ;\n round f3 c d a b 11 0x6d9d6122l 16 ;\n round f3 b c d a 14 0xfde5380cl 23 ;\n round f3 a b c d 1 0xa4beea44l 4 ;\n round f3 d a b c 4 0x4bdecfa9l 11 ;\n round f3 c d a b 7 0xf6bb4b60l 16 ;\n round f3 b c d a 10 0xbebfbc70l 23 ;\n round f3 a b c d 13 0x289b7ec6l 4 ;\n round f3 d a b c 0 0xeaa127fal 11 ;\n round f3 c d a b 3 0xd4ef3085l 16 ;\n round f3 b c d a 6 0x04881d05l 23 ;\n round f3 a b c d 9 0xd9d4d039l 4 ;\n round f3 d a b c 12 0xe6db99e5l 11 ;\n round f3 c d a b 15 0x1fa27cf8l 16 ;\n round f3 b c d a 2 0xc4ac5665l 23 ;\n round f4 a b c d 0 0xf4292244l 6 ;\n round f4 d a b c 7 0x432aff97l 10 ;\n round f4 c d a b 14 0xab9423a7l 15 ;\n round f4 b c d a 5 0xfc93a039l 21 ;\n round f4 a b c d 12 0x655b59c3l 6 ;\n round f4 d a b c 3 0x8f0ccc92l 10 ;\n round f4 c d a b 10 0xffeff47dl 15 ;\n round f4 b c d a 1 0x85845dd1l 21 ;\n round f4 a b c d 8 0x6fa87e4fl 6 ;\n round f4 d a b c 15 0xfe2ce6e0l 10 ;\n round f4 c d a b 6 0xa3014314l 15 ;\n round f4 b c d a 13 0x4e0811a1l 21 ;\n round f4 a b c d 4 0xf7537e82l 6 ;\n round f4 d a b c 11 0xbd3af235l 10 ;\n round f4 c d a b 2 0x2ad7d2bbl 15 ;\n round f4 b c d a 9 0xeb86d391l 21 ;\n let open Int32 in\n ctx.h.(0) <- ctx.h.(0) + !a ;\n ctx.h.(1) <- ctx.h.(1) + !b ;\n ctx.h.(2) <- ctx.h.(2) + !c ;\n ctx.h.(3) <- ctx.h.(3) + !d ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n le32_to_cpu:(a -> int -> int32) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~le32_to_cpu ctx buf off len ->\n let idx = ref Int64.(to_int (ctx.size land 0x3FL)) in\n let len = ref len in\n let off = ref off in\n let to_fill = 64 - !idx in\n ctx.size <- Int64.add ctx.size (Int64.of_int !len) ;\n if !idx <> 0 && !len >= to_fill\n then (\n blit buf !off ctx.b !idx to_fill ;\n md5_do_chunk ~le32_to_cpu:By.le32_to_cpu ctx ctx.b 0 ;\n len := !len - to_fill ;\n off := !off + to_fill ;\n idx := 0) ;\n while !len >= 64 do\n md5_do_chunk ~le32_to_cpu ctx buf !off ;\n len := !len - 64 ;\n off := !off + 64\n done ;\n if !len <> 0 then blit buf !off ctx.b !idx !len ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~le32_to_cpu:By.le32_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~le32_to_cpu:Bi.le32_to_cpu\n\n let unsafe_get ctx =\n let index = Int64.(to_int (ctx.size land 0x3FL)) in\n let padlen = if index < 56 then 56 - index else 64 + 56 - index in\n let padding = By.init padlen (function 0 -> '\\x80' | _ -> '\\x00') in\n let bits = By.create 8 in\n By.cpu_to_le64 bits 0 Int64.(ctx.size lsl 3) ;\n unsafe_feed_bytes ctx padding 0 padlen ;\n unsafe_feed_bytes ctx bits 0 8 ;\n let res = By.create (4 * 4) in\n for i = 0 to 3 do\n By.cpu_to_le32 res (i * 4) ctx.h.(i)\n done ;\n res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `RMD160 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let lnot = Int32.lognot\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\n\n let ror32 a n = (a lsr n) lor (a lsl (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\nend\n\nmodule Unsafe : S = struct\n type kind = [ `RMD160 ]\n\n type ctx = { s : int32 array; mutable n : int; h : int32 array; b : Bytes.t }\n\n let dup ctx =\n { s = Array.copy ctx.s; n = ctx.n; h = Array.copy ctx.h; b = By.copy ctx.b }\n\n let init () =\n let b = By.make 64 '\\x00' in\n {\n s = [| 0l; 0l |];\n n = 0;\n b;\n h = [| 0x67452301l; 0xefcdab89l; 0x98badcfel; 0x10325476l; 0xc3d2e1f0l |];\n }\n\n let f x y z = Int32.(x lxor y lxor z)\n\n let g x y z = Int32.(x land y lor (lnot x land z))\n\n let h x y z = Int32.(x lor lnot y lxor z)\n\n let i x y z = Int32.(x land z lor (y land lnot z))\n\n let j x y z = Int32.(x lxor (y lor lnot z))\n\n let ff a b c d e x s =\n let open Int32 in\n a := !a + f !b !c !d + x ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let gg a b c d e x s =\n let open Int32 in\n a := !a + g !b !c !d + x + 0x5a827999l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let hh a b c d e x s =\n let open Int32 in\n a := !a + h !b !c !d + x + 0x6ed9eba1l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let ii a b c d e x s =\n let open Int32 in\n a := !a + i !b !c !d + x + 0x8f1bbcdcl ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let jj a b c d e x s =\n let open Int32 in\n a := !a + j !b !c !d + x + 0xa953fd4el ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let fff a b c d e x s =\n let open Int32 in\n a := !a + f !b !c !d + x ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let ggg a b c d e x s =\n let open Int32 in\n a := !a + g !b !c !d + x + 0x7a6d76e9l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let hhh a b c d e x s =\n let open Int32 in\n a := !a + h !b !c !d + x + 0x6d703ef3l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let iii a b c d e x s =\n let open Int32 in\n a := !a + i !b !c !d + x + 0x5c4dd124l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let jjj a b c d e x s =\n let open Int32 in\n a := !a + j !b !c !d + x + 0x50a28be6l ;\n a := rol32 !a s + !e ;\n c := rol32 !c 10\n\n let rmd160_do_chunk :\n type a. le32_to_cpu:(a -> int -> int32) -> ctx -> a -> int -> unit =\n fun ~le32_to_cpu ctx buff off ->\n let aa, bb, cc, dd, ee, aaa, bbb, ccc, ddd, eee =\n ( ref ctx.h.(0),\n ref ctx.h.(1),\n ref ctx.h.(2),\n ref ctx.h.(3),\n ref ctx.h.(4),\n ref ctx.h.(0),\n ref ctx.h.(1),\n ref ctx.h.(2),\n ref ctx.h.(3),\n ref ctx.h.(4) ) in\n let w = Array.make 16 0l in\n for i = 0 to 15 do\n w.(i) <- le32_to_cpu buff (off + (i * 4))\n done ;\n ff aa bb cc dd ee w.(0) 11 ;\n ff ee aa bb cc dd w.(1) 14 ;\n ff dd ee aa bb cc w.(2) 15 ;\n ff cc dd ee aa bb w.(3) 12 ;\n ff bb cc dd ee aa w.(4) 5 ;\n ff aa bb cc dd ee w.(5) 8 ;\n ff ee aa bb cc dd w.(6) 7 ;\n ff dd ee aa bb cc w.(7) 9 ;\n ff cc dd ee aa bb w.(8) 11 ;\n ff bb cc dd ee aa w.(9) 13 ;\n ff aa bb cc dd ee w.(10) 14 ;\n ff ee aa bb cc dd w.(11) 15 ;\n ff dd ee aa bb cc w.(12) 6 ;\n ff cc dd ee aa bb w.(13) 7 ;\n ff bb cc dd ee aa w.(14) 9 ;\n ff aa bb cc dd ee w.(15) 8 ;\n gg ee aa bb cc dd w.(7) 7 ;\n gg dd ee aa bb cc w.(4) 6 ;\n gg cc dd ee aa bb w.(13) 8 ;\n gg bb cc dd ee aa w.(1) 13 ;\n gg aa bb cc dd ee w.(10) 11 ;\n gg ee aa bb cc dd w.(6) 9 ;\n gg dd ee aa bb cc w.(15) 7 ;\n gg cc dd ee aa bb w.(3) 15 ;\n gg bb cc dd ee aa w.(12) 7 ;\n gg aa bb cc dd ee w.(0) 12 ;\n gg ee aa bb cc dd w.(9) 15 ;\n gg dd ee aa bb cc w.(5) 9 ;\n gg cc dd ee aa bb w.(2) 11 ;\n gg bb cc dd ee aa w.(14) 7 ;\n gg aa bb cc dd ee w.(11) 13 ;\n gg ee aa bb cc dd w.(8) 12 ;\n hh dd ee aa bb cc w.(3) 11 ;\n hh cc dd ee aa bb w.(10) 13 ;\n hh bb cc dd ee aa w.(14) 6 ;\n hh aa bb cc dd ee w.(4) 7 ;\n hh ee aa bb cc dd w.(9) 14 ;\n hh dd ee aa bb cc w.(15) 9 ;\n hh cc dd ee aa bb w.(8) 13 ;\n hh bb cc dd ee aa w.(1) 15 ;\n hh aa bb cc dd ee w.(2) 14 ;\n hh ee aa bb cc dd w.(7) 8 ;\n hh dd ee aa bb cc w.(0) 13 ;\n hh cc dd ee aa bb w.(6) 6 ;\n hh bb cc dd ee aa w.(13) 5 ;\n hh aa bb cc dd ee w.(11) 12 ;\n hh ee aa bb cc dd w.(5) 7 ;\n hh dd ee aa bb cc w.(12) 5 ;\n ii cc dd ee aa bb w.(1) 11 ;\n ii bb cc dd ee aa w.(9) 12 ;\n ii aa bb cc dd ee w.(11) 14 ;\n ii ee aa bb cc dd w.(10) 15 ;\n ii dd ee aa bb cc w.(0) 14 ;\n ii cc dd ee aa bb w.(8) 15 ;\n ii bb cc dd ee aa w.(12) 9 ;\n ii aa bb cc dd ee w.(4) 8 ;\n ii ee aa bb cc dd w.(13) 9 ;\n ii dd ee aa bb cc w.(3) 14 ;\n ii cc dd ee aa bb w.(7) 5 ;\n ii bb cc dd ee aa w.(15) 6 ;\n ii aa bb cc dd ee w.(14) 8 ;\n ii ee aa bb cc dd w.(5) 6 ;\n ii dd ee aa bb cc w.(6) 5 ;\n ii cc dd ee aa bb w.(2) 12 ;\n jj bb cc dd ee aa w.(4) 9 ;\n jj aa bb cc dd ee w.(0) 15 ;\n jj ee aa bb cc dd w.(5) 5 ;\n jj dd ee aa bb cc w.(9) 11 ;\n jj cc dd ee aa bb w.(7) 6 ;\n jj bb cc dd ee aa w.(12) 8 ;\n jj aa bb cc dd ee w.(2) 13 ;\n jj ee aa bb cc dd w.(10) 12 ;\n jj dd ee aa bb cc w.(14) 5 ;\n jj cc dd ee aa bb w.(1) 12 ;\n jj bb cc dd ee aa w.(3) 13 ;\n jj aa bb cc dd ee w.(8) 14 ;\n jj ee aa bb cc dd w.(11) 11 ;\n jj dd ee aa bb cc w.(6) 8 ;\n jj cc dd ee aa bb w.(15) 5 ;\n jj bb cc dd ee aa w.(13) 6 ;\n jjj aaa bbb ccc ddd eee w.(5) 8 ;\n jjj eee aaa bbb ccc ddd w.(14) 9 ;\n jjj ddd eee aaa bbb ccc w.(7) 9 ;\n jjj ccc ddd eee aaa bbb w.(0) 11 ;\n jjj bbb ccc ddd eee aaa w.(9) 13 ;\n jjj aaa bbb ccc ddd eee w.(2) 15 ;\n jjj eee aaa bbb ccc ddd w.(11) 15 ;\n jjj ddd eee aaa bbb ccc w.(4) 5 ;\n jjj ccc ddd eee aaa bbb w.(13) 7 ;\n jjj bbb ccc ddd eee aaa w.(6) 7 ;\n jjj aaa bbb ccc ddd eee w.(15) 8 ;\n jjj eee aaa bbb ccc ddd w.(8) 11 ;\n jjj ddd eee aaa bbb ccc w.(1) 14 ;\n jjj ccc ddd eee aaa bbb w.(10) 14 ;\n jjj bbb ccc ddd eee aaa w.(3) 12 ;\n jjj aaa bbb ccc ddd eee w.(12) 6 ;\n iii eee aaa bbb ccc ddd w.(6) 9 ;\n iii ddd eee aaa bbb ccc w.(11) 13 ;\n iii ccc ddd eee aaa bbb w.(3) 15 ;\n iii bbb ccc ddd eee aaa w.(7) 7 ;\n iii aaa bbb ccc ddd eee w.(0) 12 ;\n iii eee aaa bbb ccc ddd w.(13) 8 ;\n iii ddd eee aaa bbb ccc w.(5) 9 ;\n iii ccc ddd eee aaa bbb w.(10) 11 ;\n iii bbb ccc ddd eee aaa w.(14) 7 ;\n iii aaa bbb ccc ddd eee w.(15) 7 ;\n iii eee aaa bbb ccc ddd w.(8) 12 ;\n iii ddd eee aaa bbb ccc w.(12) 7 ;\n iii ccc ddd eee aaa bbb w.(4) 6 ;\n iii bbb ccc ddd eee aaa w.(9) 15 ;\n iii aaa bbb ccc ddd eee w.(1) 13 ;\n iii eee aaa bbb ccc ddd w.(2) 11 ;\n hhh ddd eee aaa bbb ccc w.(15) 9 ;\n hhh ccc ddd eee aaa bbb w.(5) 7 ;\n hhh bbb ccc ddd eee aaa w.(1) 15 ;\n hhh aaa bbb ccc ddd eee w.(3) 11 ;\n hhh eee aaa bbb ccc ddd w.(7) 8 ;\n hhh ddd eee aaa bbb ccc w.(14) 6 ;\n hhh ccc ddd eee aaa bbb w.(6) 6 ;\n hhh bbb ccc ddd eee aaa w.(9) 14 ;\n hhh aaa bbb ccc ddd eee w.(11) 12 ;\n hhh eee aaa bbb ccc ddd w.(8) 13 ;\n hhh ddd eee aaa bbb ccc w.(12) 5 ;\n hhh ccc ddd eee aaa bbb w.(2) 14 ;\n hhh bbb ccc ddd eee aaa w.(10) 13 ;\n hhh aaa bbb ccc ddd eee w.(0) 13 ;\n hhh eee aaa bbb ccc ddd w.(4) 7 ;\n hhh ddd eee aaa bbb ccc w.(13) 5 ;\n ggg ccc ddd eee aaa bbb w.(8) 15 ;\n ggg bbb ccc ddd eee aaa w.(6) 5 ;\n ggg aaa bbb ccc ddd eee w.(4) 8 ;\n ggg eee aaa bbb ccc ddd w.(1) 11 ;\n ggg ddd eee aaa bbb ccc w.(3) 14 ;\n ggg ccc ddd eee aaa bbb w.(11) 14 ;\n ggg bbb ccc ddd eee aaa w.(15) 6 ;\n ggg aaa bbb ccc ddd eee w.(0) 14 ;\n ggg eee aaa bbb ccc ddd w.(5) 6 ;\n ggg ddd eee aaa bbb ccc w.(12) 9 ;\n ggg ccc ddd eee aaa bbb w.(2) 12 ;\n ggg bbb ccc ddd eee aaa w.(13) 9 ;\n ggg aaa bbb ccc ddd eee w.(9) 12 ;\n ggg eee aaa bbb ccc ddd w.(7) 5 ;\n ggg ddd eee aaa bbb ccc w.(10) 15 ;\n ggg ccc ddd eee aaa bbb w.(14) 8 ;\n fff bbb ccc ddd eee aaa w.(12) 8 ;\n fff aaa bbb ccc ddd eee w.(15) 5 ;\n fff eee aaa bbb ccc ddd w.(10) 12 ;\n fff ddd eee aaa bbb ccc w.(4) 9 ;\n fff ccc ddd eee aaa bbb w.(1) 12 ;\n fff bbb ccc ddd eee aaa w.(5) 5 ;\n fff aaa bbb ccc ddd eee w.(8) 14 ;\n fff eee aaa bbb ccc ddd w.(7) 6 ;\n fff ddd eee aaa bbb ccc w.(6) 8 ;\n fff ccc ddd eee aaa bbb w.(2) 13 ;\n fff bbb ccc ddd eee aaa w.(13) 6 ;\n fff aaa bbb ccc ddd eee w.(14) 5 ;\n fff eee aaa bbb ccc ddd w.(0) 15 ;\n fff ddd eee aaa bbb ccc w.(3) 13 ;\n fff ccc ddd eee aaa bbb w.(9) 11 ;\n fff bbb ccc ddd eee aaa w.(11) 11 ;\n let open Int32 in\n ddd := !ddd + !cc + ctx.h.(1) ;\n (* final result for h[0]. *)\n ctx.h.(1) <- ctx.h.(2) + !dd + !eee ;\n ctx.h.(2) <- ctx.h.(3) + !ee + !aaa ;\n ctx.h.(3) <- ctx.h.(4) + !aa + !bbb ;\n ctx.h.(4) <- ctx.h.(0) + !bb + !ccc ;\n ctx.h.(0) <- !ddd ;\n ()\n\n exception Leave\n\n let feed :\n type a.\n le32_to_cpu:(a -> int -> int32) ->\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~le32_to_cpu ~blit ctx buf off len ->\n let t = ref ctx.s.(0) in\n let off = ref off in\n let len = ref len in\n ctx.s.(0) <- Int32.add !t (Int32.of_int (!len lsl 3)) ;\n if ctx.s.(0) < !t then ctx.s.(1) <- Int32.(ctx.s.(1) + 1l) ;\n ctx.s.(1) <- Int32.add ctx.s.(1) (Int32.of_int (!len lsr 29)) ;\n try\n if ctx.n <> 0\n then (\n let t = 64 - ctx.n in\n if !len < t\n then (\n blit buf !off ctx.b ctx.n !len ;\n ctx.n <- ctx.n + !len ;\n raise Leave) ;\n blit buf !off ctx.b ctx.n t ;\n rmd160_do_chunk ~le32_to_cpu:By.le32_to_cpu ctx ctx.b 0 ;\n off := !off + t ;\n len := !len - t) ;\n while !len >= 64 do\n rmd160_do_chunk ~le32_to_cpu ctx buf !off ;\n off := !off + 64 ;\n len := !len - 64\n done ;\n blit buf !off ctx.b 0 !len ;\n ctx.n <- !len\n with Leave -> ()\n\n let unsafe_feed_bytes ctx buf off len =\n feed ~blit:By.blit ~le32_to_cpu:By.le32_to_cpu ctx buf off len\n\n let unsafe_feed_bigstring ctx buf off len =\n feed ~blit:By.blit_from_bigstring ~le32_to_cpu:Bi.le32_to_cpu ctx buf off\n len\n\n let unsafe_get ctx =\n let i = ref (ctx.n + 1) in\n let res = By.create (5 * 4) in\n By.set ctx.b ctx.n '\\x80' ;\n if !i > 56\n then (\n By.fill ctx.b !i (64 - !i) '\\x00' ;\n rmd160_do_chunk ~le32_to_cpu:By.le32_to_cpu ctx ctx.b 0 ;\n i := 0) ;\n By.fill ctx.b !i (56 - !i) '\\x00' ;\n By.cpu_to_le32 ctx.b 56 ctx.s.(0) ;\n By.cpu_to_le32 ctx.b 60 ctx.s.(1) ;\n rmd160_do_chunk ~le32_to_cpu:By.le32_to_cpu ctx ctx.b 0 ;\n for i = 0 to 4 do\n By.cpu_to_le32 res (i * 4) ctx.h.(i)\n done ;\n res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\nend\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA1 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA1 ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int32 array }\n\n let dup ctx = { size = ctx.size; b = By.copy ctx.b; h = Array.copy ctx.h }\n\n let init () =\n let b = By.make 64 '\\x00' in\n {\n size = 0L;\n b;\n h = [| 0x67452301l; 0xefcdab89l; 0x98badcfel; 0x10325476l; 0xc3d2e1f0l |];\n }\n\n let f1 x y z = Int32.(z lxor (x land (y lxor z)))\n\n let f2 x y z = Int32.(x lxor y lxor z)\n\n let f3 x y z = Int32.((x land y) + (z land (x lxor y)))\n\n let f4 = f2\n\n let k1 = 0x5a827999l\n\n let k2 = 0x6ed9eba1l\n\n let k3 = 0x8f1bbcdcl\n\n let k4 = 0xca62c1d6l\n\n let sha1_do_chunk :\n type a. be32_to_cpu:(a -> int -> int32) -> ctx -> a -> int -> unit =\n fun ~be32_to_cpu ctx buf off ->\n let a = ref ctx.h.(0) in\n let b = ref ctx.h.(1) in\n let c = ref ctx.h.(2) in\n let d = ref ctx.h.(3) in\n let e = ref ctx.h.(4) in\n let w = Array.make 16 0l in\n let m i =\n let ( && ) a b = a land b in\n let ( -- ) a b = a - b in\n let v =\n Int32.(\n rol32\n (w.(i && 0x0F)\n lxor w.((i -- 14) && 0x0F)\n lxor w.((i -- 8) && 0x0F)\n lxor w.((i -- 3) && 0x0F))\n 1) in\n w.(i land 0x0F) <- v ;\n w.(i land 0x0F) in\n let round a b c d e f k w =\n (e := Int32.(!e + rol32 !a 5 + f !b !c !d + k + w)) ;\n b := Int32.(rol32 !b 30) in\n for i = 0 to 15 do\n w.(i) <- be32_to_cpu buf (off + (i * 4))\n done ;\n round a b c d e f1 k1 w.(0) ;\n round e a b c d f1 k1 w.(1) ;\n round d e a b c f1 k1 w.(2) ;\n round c d e a b f1 k1 w.(3) ;\n round b c d e a f1 k1 w.(4) ;\n round a b c d e f1 k1 w.(5) ;\n round e a b c d f1 k1 w.(6) ;\n round d e a b c f1 k1 w.(7) ;\n round c d e a b f1 k1 w.(8) ;\n round b c d e a f1 k1 w.(9) ;\n round a b c d e f1 k1 w.(10) ;\n round e a b c d f1 k1 w.(11) ;\n round d e a b c f1 k1 w.(12) ;\n round c d e a b f1 k1 w.(13) ;\n round b c d e a f1 k1 w.(14) ;\n round a b c d e f1 k1 w.(15) ;\n round e a b c d f1 k1 (m 16) ;\n round d e a b c f1 k1 (m 17) ;\n round c d e a b f1 k1 (m 18) ;\n round b c d e a f1 k1 (m 19) ;\n round a b c d e f2 k2 (m 20) ;\n round e a b c d f2 k2 (m 21) ;\n round d e a b c f2 k2 (m 22) ;\n round c d e a b f2 k2 (m 23) ;\n round b c d e a f2 k2 (m 24) ;\n round a b c d e f2 k2 (m 25) ;\n round e a b c d f2 k2 (m 26) ;\n round d e a b c f2 k2 (m 27) ;\n round c d e a b f2 k2 (m 28) ;\n round b c d e a f2 k2 (m 29) ;\n round a b c d e f2 k2 (m 30) ;\n round e a b c d f2 k2 (m 31) ;\n round d e a b c f2 k2 (m 32) ;\n round c d e a b f2 k2 (m 33) ;\n round b c d e a f2 k2 (m 34) ;\n round a b c d e f2 k2 (m 35) ;\n round e a b c d f2 k2 (m 36) ;\n round d e a b c f2 k2 (m 37) ;\n round c d e a b f2 k2 (m 38) ;\n round b c d e a f2 k2 (m 39) ;\n round a b c d e f3 k3 (m 40) ;\n round e a b c d f3 k3 (m 41) ;\n round d e a b c f3 k3 (m 42) ;\n round c d e a b f3 k3 (m 43) ;\n round b c d e a f3 k3 (m 44) ;\n round a b c d e f3 k3 (m 45) ;\n round e a b c d f3 k3 (m 46) ;\n round d e a b c f3 k3 (m 47) ;\n round c d e a b f3 k3 (m 48) ;\n round b c d e a f3 k3 (m 49) ;\n round a b c d e f3 k3 (m 50) ;\n round e a b c d f3 k3 (m 51) ;\n round d e a b c f3 k3 (m 52) ;\n round c d e a b f3 k3 (m 53) ;\n round b c d e a f3 k3 (m 54) ;\n round a b c d e f3 k3 (m 55) ;\n round e a b c d f3 k3 (m 56) ;\n round d e a b c f3 k3 (m 57) ;\n round c d e a b f3 k3 (m 58) ;\n round b c d e a f3 k3 (m 59) ;\n round a b c d e f4 k4 (m 60) ;\n round e a b c d f4 k4 (m 61) ;\n round d e a b c f4 k4 (m 62) ;\n round c d e a b f4 k4 (m 63) ;\n round b c d e a f4 k4 (m 64) ;\n round a b c d e f4 k4 (m 65) ;\n round e a b c d f4 k4 (m 66) ;\n round d e a b c f4 k4 (m 67) ;\n round c d e a b f4 k4 (m 68) ;\n round b c d e a f4 k4 (m 69) ;\n round a b c d e f4 k4 (m 70) ;\n round e a b c d f4 k4 (m 71) ;\n round d e a b c f4 k4 (m 72) ;\n round c d e a b f4 k4 (m 73) ;\n round b c d e a f4 k4 (m 74) ;\n round a b c d e f4 k4 (m 75) ;\n round e a b c d f4 k4 (m 76) ;\n round d e a b c f4 k4 (m 77) ;\n round c d e a b f4 k4 (m 78) ;\n round b c d e a f4 k4 (m 79) ;\n ctx.h.(0) <- Int32.add ctx.h.(0) !a ;\n ctx.h.(1) <- Int32.add ctx.h.(1) !b ;\n ctx.h.(2) <- Int32.add ctx.h.(2) !c ;\n ctx.h.(3) <- Int32.add ctx.h.(3) !d ;\n ctx.h.(4) <- Int32.add ctx.h.(4) !e ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n be32_to_cpu:(a -> int -> int32) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~be32_to_cpu ctx buf off len ->\n let idx = ref Int64.(to_int (ctx.size land 0x3FL)) in\n let len = ref len in\n let off = ref off in\n let to_fill = 64 - !idx in\n ctx.size <- Int64.add ctx.size (Int64.of_int !len) ;\n if !idx <> 0 && !len >= to_fill\n then (\n blit buf !off ctx.b !idx to_fill ;\n sha1_do_chunk ~be32_to_cpu:By.be32_to_cpu ctx ctx.b 0 ;\n len := !len - to_fill ;\n off := !off + to_fill ;\n idx := 0) ;\n while !len >= 64 do\n sha1_do_chunk ~be32_to_cpu ctx buf !off ;\n len := !len - 64 ;\n off := !off + 64\n done ;\n if !len <> 0 then blit buf !off ctx.b !idx !len ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~be32_to_cpu:By.be32_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~be32_to_cpu:Bi.be32_to_cpu\n\n let unsafe_get ctx =\n let index = Int64.(to_int (ctx.size land 0x3FL)) in\n let padlen = if index < 56 then 56 - index else 64 + 56 - index in\n let padding = By.init padlen (function 0 -> '\\x80' | _ -> '\\x00') in\n let bits = By.create 8 in\n By.cpu_to_be64 bits 0 Int64.(ctx.size lsl 3) ;\n unsafe_feed_bytes ctx padding 0 padlen ;\n unsafe_feed_bytes ctx bits 0 8 ;\n let res = By.create (5 * 4) in\n for i = 0 to 4 do\n By.cpu_to_be32 res (i * 4) ctx.h.(i)\n done ;\n res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int32 = struct\n include Int32\n\n let ( lsl ) = Int32.shift_left\n\n let ( lsr ) = Int32.shift_right_logical\n\n let ( asr ) = Int32.shift_right\n\n let ( lor ) = Int32.logor\n\n let ( lxor ) = Int32.logxor\n\n let ( land ) = Int32.logand\n\n let ( + ) = Int32.add\n\n let rol32 a n = (a lsl n) lor (a lsr (32 - n))\n\n let ror32 a n = (a lsr n) lor (a lsl (32 - n))\nend\n\nmodule Int64 = struct\n include Int64\n\n let ( land ) = Int64.logand\n\n let ( lsl ) = Int64.shift_left\nend\n\nmodule type S = sig\n type kind = [ `SHA256 ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int32 array }\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA256 ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int32 array }\n\n let dup ctx = { size = ctx.size; b = By.copy ctx.b; h = Array.copy ctx.h }\n\n let init () =\n let b = By.make 128 '\\x00' in\n {\n size = 0L;\n b;\n h =\n [|\n 0x6a09e667l;\n 0xbb67ae85l;\n 0x3c6ef372l;\n 0xa54ff53al;\n 0x510e527fl;\n 0x9b05688cl;\n 0x1f83d9abl;\n 0x5be0cd19l;\n |];\n }\n\n let k =\n [|\n 0x428a2f98l;\n 0x71374491l;\n 0xb5c0fbcfl;\n 0xe9b5dba5l;\n 0x3956c25bl;\n 0x59f111f1l;\n 0x923f82a4l;\n 0xab1c5ed5l;\n 0xd807aa98l;\n 0x12835b01l;\n 0x243185bel;\n 0x550c7dc3l;\n 0x72be5d74l;\n 0x80deb1fel;\n 0x9bdc06a7l;\n 0xc19bf174l;\n 0xe49b69c1l;\n 0xefbe4786l;\n 0x0fc19dc6l;\n 0x240ca1ccl;\n 0x2de92c6fl;\n 0x4a7484aal;\n 0x5cb0a9dcl;\n 0x76f988dal;\n 0x983e5152l;\n 0xa831c66dl;\n 0xb00327c8l;\n 0xbf597fc7l;\n 0xc6e00bf3l;\n 0xd5a79147l;\n 0x06ca6351l;\n 0x14292967l;\n 0x27b70a85l;\n 0x2e1b2138l;\n 0x4d2c6dfcl;\n 0x53380d13l;\n 0x650a7354l;\n 0x766a0abbl;\n 0x81c2c92el;\n 0x92722c85l;\n 0xa2bfe8a1l;\n 0xa81a664bl;\n 0xc24b8b70l;\n 0xc76c51a3l;\n 0xd192e819l;\n 0xd6990624l;\n 0xf40e3585l;\n 0x106aa070l;\n 0x19a4c116l;\n 0x1e376c08l;\n 0x2748774cl;\n 0x34b0bcb5l;\n 0x391c0cb3l;\n 0x4ed8aa4al;\n 0x5b9cca4fl;\n 0x682e6ff3l;\n 0x748f82eel;\n 0x78a5636fl;\n 0x84c87814l;\n 0x8cc70208l;\n 0x90befffal;\n 0xa4506cebl;\n 0xbef9a3f7l;\n 0xc67178f2l;\n |]\n\n let e0 x = Int32.(ror32 x 2 lxor ror32 x 13 lxor ror32 x 22)\n\n let e1 x = Int32.(ror32 x 6 lxor ror32 x 11 lxor ror32 x 25)\n\n let s0 x = Int32.(ror32 x 7 lxor ror32 x 18 lxor (x lsr 3))\n\n let s1 x = Int32.(ror32 x 17 lxor ror32 x 19 lxor (x lsr 10))\n\n let sha256_do_chunk :\n type a. be32_to_cpu:(a -> int -> int32) -> ctx -> a -> int -> unit =\n fun ~be32_to_cpu ctx buf off ->\n let a, b, c, d, e, f, g, h, t1, t2 =\n ( ref ctx.h.(0),\n ref ctx.h.(1),\n ref ctx.h.(2),\n ref ctx.h.(3),\n ref ctx.h.(4),\n ref ctx.h.(5),\n ref ctx.h.(6),\n ref ctx.h.(7),\n ref 0l,\n ref 0l ) in\n let w = Array.make 64 0l in\n for i = 0 to 15 do\n w.(i) <- be32_to_cpu buf (off + (i * 4))\n done ;\n let ( -- ) a b = a - b in\n for i = 16 to 63 do\n w.(i) <- Int32.(s1 w.(i -- 2) + w.(i -- 7) + s0 w.(i -- 15) + w.(i -- 16))\n done ;\n let round a b c d e f g h k w =\n let open Int32 in\n t1 := !h + e1 !e + (!g lxor (!e land (!f lxor !g))) + k + w ;\n t2 := e0 !a + (!a land !b lor (!c land (!a lor !b))) ;\n d := !d + !t1 ;\n h := !t1 + !t2 in\n for i = 0 to 7 do\n round a b c d e f g h k.((i * 8) + 0) w.((i * 8) + 0) ;\n round h a b c d e f g k.((i * 8) + 1) w.((i * 8) + 1) ;\n round g h a b c d e f k.((i * 8) + 2) w.((i * 8) + 2) ;\n round f g h a b c d e k.((i * 8) + 3) w.((i * 8) + 3) ;\n round e f g h a b c d k.((i * 8) + 4) w.((i * 8) + 4) ;\n round d e f g h a b c k.((i * 8) + 5) w.((i * 8) + 5) ;\n round c d e f g h a b k.((i * 8) + 6) w.((i * 8) + 6) ;\n round b c d e f g h a k.((i * 8) + 7) w.((i * 8) + 7)\n done ;\n let open Int32 in\n ctx.h.(0) <- ctx.h.(0) + !a ;\n ctx.h.(1) <- ctx.h.(1) + !b ;\n ctx.h.(2) <- ctx.h.(2) + !c ;\n ctx.h.(3) <- ctx.h.(3) + !d ;\n ctx.h.(4) <- ctx.h.(4) + !e ;\n ctx.h.(5) <- ctx.h.(5) + !f ;\n ctx.h.(6) <- ctx.h.(6) + !g ;\n ctx.h.(7) <- ctx.h.(7) + !h ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n be32_to_cpu:(a -> int -> int32) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~be32_to_cpu ctx buf off len ->\n let idx = ref Int64.(to_int (ctx.size land 0x3FL)) in\n let len = ref len in\n let off = ref off in\n let to_fill = 64 - !idx in\n ctx.size <- Int64.add ctx.size (Int64.of_int !len) ;\n if !idx <> 0 && !len >= to_fill\n then (\n blit buf !off ctx.b !idx to_fill ;\n sha256_do_chunk ~be32_to_cpu:By.be32_to_cpu ctx ctx.b 0 ;\n len := !len - to_fill ;\n off := !off + to_fill ;\n idx := 0) ;\n while !len >= 64 do\n sha256_do_chunk ~be32_to_cpu ctx buf !off ;\n len := !len - 64 ;\n off := !off + 64\n done ;\n if !len <> 0 then blit buf !off ctx.b !idx !len ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~be32_to_cpu:By.be32_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~be32_to_cpu:Bi.be32_to_cpu\n\n let unsafe_get ctx =\n let index = Int64.(to_int (ctx.size land 0x3FL)) in\n let padlen = if index < 56 then 56 - index else 64 + 56 - index in\n let padding = By.init padlen (function 0 -> '\\x80' | _ -> '\\x00') in\n let bits = By.create 8 in\n By.cpu_to_be64 bits 0 Int64.(ctx.size lsl 3) ;\n unsafe_feed_bytes ctx padding 0 padlen ;\n unsafe_feed_bytes ctx bits 0 8 ;\n let res = By.create (8 * 4) in\n for i = 0 to 7 do\n By.cpu_to_be32 res (i * 4) ctx.h.(i)\n done ;\n res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA224 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA224 ]\n\n open Baijiu_sha256.Unsafe\n\n type nonrec ctx = ctx\n\n let init () =\n let b = By.make 128 '\\x00' in\n {\n size = 0L;\n b;\n h =\n [|\n 0xc1059ed8l;\n 0x367cd507l;\n 0x3070dd17l;\n 0xf70e5939l;\n 0xffc00b31l;\n 0x68581511l;\n 0x64f98fa7l;\n 0xbefa4fa4l;\n |];\n }\n\n let unsafe_get ctx =\n let res = unsafe_get ctx in\n By.sub res 0 28\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int64 = struct\n include Int64\n\n let ( lsl ) = Int64.shift_left\n\n let ( lsr ) = Int64.shift_right_logical\n\n let ( asr ) = Int64.shift_right\n\n let ( lor ) = Int64.logor\n\n let ( land ) = Int64.logand\n\n let ( lxor ) = Int64.logxor\n\n let ( + ) = Int64.add\n\n let ror64 a n = (a lsr n) lor (a lsl (64 - n))\n\n let rol64 a n = (a lsl n) lor (a lsr (64 - n))\nend\n\nmodule Unsafe = struct\n type ctx = {\n q : int64 array;\n rsize : int;\n (* block size *)\n mdlen : int;\n (* output size *)\n mutable pt : int;\n }\n\n let dup ctx =\n { q = Array.copy ctx.q; rsize = ctx.rsize; mdlen = ctx.mdlen; pt = ctx.pt }\n\n let init mdlen =\n let rsize = 200 - (2 * mdlen) in\n { q = Array.make 25 0L; rsize; mdlen; pt = 0 }\n\n let keccakf_rounds = 24\n\n let keccaft_rndc : int64 array =\n [|\n 0x0000000000000001L;\n 0x0000000000008082L;\n 0x800000000000808aL;\n 0x8000000080008000L;\n 0x000000000000808bL;\n 0x0000000080000001L;\n 0x8000000080008081L;\n 0x8000000000008009L;\n 0x000000000000008aL;\n 0x0000000000000088L;\n 0x0000000080008009L;\n 0x000000008000000aL;\n 0x000000008000808bL;\n 0x800000000000008bL;\n 0x8000000000008089L;\n 0x8000000000008003L;\n 0x8000000000008002L;\n 0x8000000000000080L;\n 0x000000000000800aL;\n 0x800000008000000aL;\n 0x8000000080008081L;\n 0x8000000000008080L;\n 0x0000000080000001L;\n 0x8000000080008008L;\n |]\n\n let keccaft_rotc : int array =\n [|\n 1;\n 3;\n 6;\n 10;\n 15;\n 21;\n 28;\n 36;\n 45;\n 55;\n 2;\n 14;\n 27;\n 41;\n 56;\n 8;\n 25;\n 43;\n 62;\n 18;\n 39;\n 61;\n 20;\n 44;\n |]\n\n let keccakf_piln : int array =\n [|\n 10;\n 7;\n 11;\n 17;\n 18;\n 3;\n 5;\n 16;\n 8;\n 21;\n 24;\n 4;\n 15;\n 23;\n 19;\n 13;\n 12;\n 2;\n 20;\n 14;\n 22;\n 9;\n 6;\n 1;\n |]\n\n let swap64 = if Sys.big_endian then By.swap64 else fun x -> x\n\n let sha3_keccakf (q : int64 array) =\n if Sys.big_endian then Array.iteri (fun i sti -> q.(i) <- swap64 sti) q ;\n\n for r = 0 to keccakf_rounds - 1 do\n let ( lxor ) = Int64.( lxor ) in\n let lnot = Int64.lognot in\n let ( land ) = Int64.( land ) in\n (* Theta *)\n let bc =\n Array.init 5 (fun i ->\n q.(i) lxor q.(i + 5) lxor q.(i + 10) lxor q.(i + 15) lxor q.(i + 20))\n in\n for i = 0 to 4 do\n let t = bc.((i + 4) mod 5) lxor Int64.rol64 bc.((i + 1) mod 5) 1 in\n for k = 0 to 4 do\n let j = k * 5 in\n q.(j + i) <- q.(j + i) lxor t\n done\n done ;\n\n (* Rho Pi *)\n let t = ref q.(1) in\n let _ =\n Array.iteri\n (fun i rotc ->\n let j = keccakf_piln.(i) in\n bc.(0) <- q.(j) ;\n q.(j) <- Int64.rol64 !t rotc ;\n t := bc.(0))\n keccaft_rotc in\n\n (* Chi *)\n for k = 0 to 4 do\n let j = k * 5 in\n let bc = Array.init 5 (fun i -> q.(j + i)) in\n for i = 0 to 4 do\n q.(j + i) <-\n q.(j + i) lxor (lnot bc.((i + 1) mod 5) land bc.((i + 2) mod 5))\n done\n done ;\n\n (* Iota *)\n q.(0) <- q.(0) lxor keccaft_rndc.(r)\n done ;\n\n if Sys.big_endian then Array.iteri (fun i sti -> q.(i) <- swap64 sti) q\n\n let masks =\n [|\n 0xffffffffffffff00L;\n 0xffffffffffff00ffL;\n 0xffffffffff00ffffL;\n 0xffffffff00ffffffL;\n 0xffffff00ffffffffL;\n 0xffff00ffffffffffL;\n 0xff00ffffffffffffL;\n 0x00ffffffffffffffL;\n |]\n\n let feed :\n type a. get_uint8:(a -> int -> int) -> ctx -> a -> int -> int -> unit =\n fun ~get_uint8 ctx buf off len ->\n let ( && ) = ( land ) in\n\n let ( lxor ) = Int64.( lxor ) in\n let ( land ) = Int64.( land ) in\n let ( lor ) = Int64.( lor ) in\n let ( lsr ) = Int64.( lsr ) in\n let ( lsl ) = Int64.( lsl ) in\n\n let j = ref ctx.pt in\n\n for i = 0 to len - 1 do\n let v =\n (ctx.q.(!j / 8) land (0xffL lsl ((!j && 0x7) * 8))) lsr ((!j && 0x7) * 8)\n in\n let v = v lxor Int64.of_int (get_uint8 buf (off + i)) in\n ctx.q.(!j / 8) <-\n ctx.q.(!j / 8) land masks.(!j && 0x7) lor (v lsl ((!j && 0x7) * 8)) ;\n incr j ;\n if !j >= ctx.rsize\n then (\n sha3_keccakf ctx.q ;\n j := 0)\n done ;\n\n ctx.pt <- !j\n\n let unsafe_feed_bytes ctx buf off len =\n let get_uint8 buf off = Char.code (By.get buf off) in\n feed ~get_uint8 ctx buf off len\n\n let unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit =\n fun ctx buf off len ->\n let get_uint8 buf off = Char.code (Bi.get buf off) in\n feed ~get_uint8 ctx buf off len\n\n let unsafe_get ctx =\n let ( && ) = ( land ) in\n\n let ( lxor ) = Int64.( lxor ) in\n let ( lsl ) = Int64.( lsl ) in\n\n let v = ctx.q.(ctx.pt / 8) in\n let v = v lxor (0x6L lsl ((ctx.pt && 0x7) * 8)) in\n ctx.q.(ctx.pt / 8) <- v ;\n\n let v = ctx.q.((ctx.rsize - 1) / 8) in\n let v = v lxor (0x80L lsl (((ctx.rsize - 1) && 0x7) * 8)) in\n ctx.q.((ctx.rsize - 1) / 8) <- v ;\n\n sha3_keccakf ctx.q ;\n\n (* Get hash *)\n (* if the hash size in bytes is not a multiple of 8 (meaning it is\n not composed of whole int64 words, like for sha3_224), we\n extract the whole last int64 word from the state [ctx.st] and\n cut the hash at the right size after conversion to bytes. *)\n let n =\n let r = ctx.mdlen mod 8 in\n ctx.mdlen + if r = 0 then 0 else 8 - r in\n\n let hash = By.create n in\n for i = 0 to (n / 8) - 1 do\n By.unsafe_set_64 hash (i * 8) ctx.q.(i)\n done ;\n\n By.sub hash 0 ctx.mdlen\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA3_512 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA3_512 ]\n\n open Baijiu_sha3.Unsafe\n\n type nonrec ctx = ctx\n\n let init () = Baijiu_sha3.Unsafe.init 64\n\n let unsafe_get = unsafe_get\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int64 = struct\n include Int64\n\n let ( lsl ) = Int64.shift_left\n\n let ( lsr ) = Int64.shift_right_logical\n\n let ( asr ) = Int64.shift_right\n\n let ( lor ) = Int64.logor\n\n let ( land ) = Int64.logand\n\n let ( lxor ) = Int64.logxor\n\n let ( + ) = Int64.add\n\n let ror64 a n = (a lsr n) lor (a lsl (64 - n))\n\n let rol64 a n = (a lsl n) lor (a lsr (64 - n))\nend\n\nmodule type S = sig\n type kind = [ `SHA512 ]\n\n type ctx = { mutable size : int64 array; b : Bytes.t; h : int64 array }\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA512 ]\n\n type ctx = { mutable size : int64 array; b : Bytes.t; h : int64 array }\n\n let dup ctx =\n { size = Array.copy ctx.size; b = By.copy ctx.b; h = Array.copy ctx.h }\n\n let init () =\n let b = By.make 128 '\\x00' in\n {\n size = [| 0L; 0L |];\n b;\n h =\n [|\n 0x6a09e667f3bcc908L;\n 0xbb67ae8584caa73bL;\n 0x3c6ef372fe94f82bL;\n 0xa54ff53a5f1d36f1L;\n 0x510e527fade682d1L;\n 0x9b05688c2b3e6c1fL;\n 0x1f83d9abfb41bd6bL;\n 0x5be0cd19137e2179L;\n |];\n }\n\n let k =\n [|\n 0x428a2f98d728ae22L;\n 0x7137449123ef65cdL;\n 0xb5c0fbcfec4d3b2fL;\n 0xe9b5dba58189dbbcL;\n 0x3956c25bf348b538L;\n 0x59f111f1b605d019L;\n 0x923f82a4af194f9bL;\n 0xab1c5ed5da6d8118L;\n 0xd807aa98a3030242L;\n 0x12835b0145706fbeL;\n 0x243185be4ee4b28cL;\n 0x550c7dc3d5ffb4e2L;\n 0x72be5d74f27b896fL;\n 0x80deb1fe3b1696b1L;\n 0x9bdc06a725c71235L;\n 0xc19bf174cf692694L;\n 0xe49b69c19ef14ad2L;\n 0xefbe4786384f25e3L;\n 0x0fc19dc68b8cd5b5L;\n 0x240ca1cc77ac9c65L;\n 0x2de92c6f592b0275L;\n 0x4a7484aa6ea6e483L;\n 0x5cb0a9dcbd41fbd4L;\n 0x76f988da831153b5L;\n 0x983e5152ee66dfabL;\n 0xa831c66d2db43210L;\n 0xb00327c898fb213fL;\n 0xbf597fc7beef0ee4L;\n 0xc6e00bf33da88fc2L;\n 0xd5a79147930aa725L;\n 0x06ca6351e003826fL;\n 0x142929670a0e6e70L;\n 0x27b70a8546d22ffcL;\n 0x2e1b21385c26c926L;\n 0x4d2c6dfc5ac42aedL;\n 0x53380d139d95b3dfL;\n 0x650a73548baf63deL;\n 0x766a0abb3c77b2a8L;\n 0x81c2c92e47edaee6L;\n 0x92722c851482353bL;\n 0xa2bfe8a14cf10364L;\n 0xa81a664bbc423001L;\n 0xc24b8b70d0f89791L;\n 0xc76c51a30654be30L;\n 0xd192e819d6ef5218L;\n 0xd69906245565a910L;\n 0xf40e35855771202aL;\n 0x106aa07032bbd1b8L;\n 0x19a4c116b8d2d0c8L;\n 0x1e376c085141ab53L;\n 0x2748774cdf8eeb99L;\n 0x34b0bcb5e19b48a8L;\n 0x391c0cb3c5c95a63L;\n 0x4ed8aa4ae3418acbL;\n 0x5b9cca4f7763e373L;\n 0x682e6ff3d6b2b8a3L;\n 0x748f82ee5defb2fcL;\n 0x78a5636f43172f60L;\n 0x84c87814a1f0ab72L;\n 0x8cc702081a6439ecL;\n 0x90befffa23631e28L;\n 0xa4506cebde82bde9L;\n 0xbef9a3f7b2c67915L;\n 0xc67178f2e372532bL;\n 0xca273eceea26619cL;\n 0xd186b8c721c0c207L;\n 0xeada7dd6cde0eb1eL;\n 0xf57d4f7fee6ed178L;\n 0x06f067aa72176fbaL;\n 0x0a637dc5a2c898a6L;\n 0x113f9804bef90daeL;\n 0x1b710b35131c471bL;\n 0x28db77f523047d84L;\n 0x32caab7b40c72493L;\n 0x3c9ebe0a15c9bebcL;\n 0x431d67c49c100d4cL;\n 0x4cc5d4becb3e42b6L;\n 0x597f299cfc657e2aL;\n 0x5fcb6fab3ad6faecL;\n 0x6c44198c4a475817L;\n |]\n\n let e0 x = Int64.(ror64 x 28 lxor ror64 x 34 lxor ror64 x 39)\n\n let e1 x = Int64.(ror64 x 14 lxor ror64 x 18 lxor ror64 x 41)\n\n let s0 x = Int64.(ror64 x 1 lxor ror64 x 8 lxor (x lsr 7))\n\n let s1 x = Int64.(ror64 x 19 lxor ror64 x 61 lxor (x lsr 6))\n\n let sha512_do_chunk :\n type a. be64_to_cpu:(a -> int -> int64) -> ctx -> a -> int -> unit =\n fun ~be64_to_cpu ctx buf off ->\n let a, b, c, d, e, f, g, h, t1, t2 =\n ( ref ctx.h.(0),\n ref ctx.h.(1),\n ref ctx.h.(2),\n ref ctx.h.(3),\n ref ctx.h.(4),\n ref ctx.h.(5),\n ref ctx.h.(6),\n ref ctx.h.(7),\n ref 0L,\n ref 0L ) in\n let w = Array.make 80 0L in\n for i = 0 to 15 do\n w.(i) <- be64_to_cpu buf (off + (i * 8))\n done ;\n let ( -- ) a b = a - b in\n for i = 16 to 79 do\n w.(i) <- Int64.(s1 w.(i -- 2) + w.(i -- 7) + s0 w.(i -- 15) + w.(i -- 16))\n done ;\n let round a b c d e f g h k w =\n let open Int64 in\n t1 := !h + e1 !e + (!g lxor (!e land (!f lxor !g))) + k + w ;\n t2 := e0 !a + (!a land !b lor (!c land (!a lor !b))) ;\n d := !d + !t1 ;\n h := !t1 + !t2 in\n for i = 0 to 9 do\n round a b c d e f g h k.((i * 8) + 0) w.((i * 8) + 0) ;\n round h a b c d e f g k.((i * 8) + 1) w.((i * 8) + 1) ;\n round g h a b c d e f k.((i * 8) + 2) w.((i * 8) + 2) ;\n round f g h a b c d e k.((i * 8) + 3) w.((i * 8) + 3) ;\n round e f g h a b c d k.((i * 8) + 4) w.((i * 8) + 4) ;\n round d e f g h a b c k.((i * 8) + 5) w.((i * 8) + 5) ;\n round c d e f g h a b k.((i * 8) + 6) w.((i * 8) + 6) ;\n round b c d e f g h a k.((i * 8) + 7) w.((i * 8) + 7)\n done ;\n let open Int64 in\n ctx.h.(0) <- ctx.h.(0) + !a ;\n ctx.h.(1) <- ctx.h.(1) + !b ;\n ctx.h.(2) <- ctx.h.(2) + !c ;\n ctx.h.(3) <- ctx.h.(3) + !d ;\n ctx.h.(4) <- ctx.h.(4) + !e ;\n ctx.h.(5) <- ctx.h.(5) + !f ;\n ctx.h.(6) <- ctx.h.(6) + !g ;\n ctx.h.(7) <- ctx.h.(7) + !h ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n be64_to_cpu:(a -> int -> int64) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~be64_to_cpu ctx buf off len ->\n let idx = ref Int64.(to_int (ctx.size.(0) land 0x7FL)) in\n let len = ref len in\n let off = ref off in\n let to_fill = 128 - !idx in\n ctx.size.(0) <- Int64.add ctx.size.(0) (Int64.of_int !len) ;\n if ctx.size.(0) < Int64.of_int !len\n then ctx.size.(1) <- Int64.succ ctx.size.(1) ;\n if !idx <> 0 && !len >= to_fill\n then (\n blit buf !off ctx.b !idx to_fill ;\n sha512_do_chunk ~be64_to_cpu:By.be64_to_cpu ctx ctx.b 0 ;\n len := !len - to_fill ;\n off := !off + to_fill ;\n idx := 0) ;\n while !len >= 128 do\n sha512_do_chunk ~be64_to_cpu ctx buf !off ;\n len := !len - 128 ;\n off := !off + 128\n done ;\n if !len <> 0 then blit buf !off ctx.b !idx !len ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~be64_to_cpu:By.be64_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~be64_to_cpu:Bi.be64_to_cpu\n\n let unsafe_get ctx =\n let index = Int64.(to_int (ctx.size.(0) land 0x7FL)) in\n let padlen = if index < 112 then 112 - index else 128 + 112 - index in\n let padding = By.init padlen (function 0 -> '\\x80' | _ -> '\\x00') in\n let bits = By.create 16 in\n By.cpu_to_be64 bits 0 Int64.((ctx.size.(1) lsl 3) lor (ctx.size.(0) lsr 61)) ;\n By.cpu_to_be64 bits 8 Int64.(ctx.size.(0) lsl 3) ;\n unsafe_feed_bytes ctx padding 0 padlen ;\n unsafe_feed_bytes ctx bits 0 16 ;\n let res = By.create (8 * 8) in\n for i = 0 to 7 do\n By.cpu_to_be64 res (i * 8) ctx.h.(i)\n done ;\n res\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA384 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA384 ]\n\n open Baijiu_sha512.Unsafe\n\n type nonrec ctx = ctx\n\n let init () =\n let b = By.make 128 '\\x00' in\n {\n size = [| 0L; 0L |];\n b;\n h =\n [|\n 0xcbbb9d5dc1059ed8L;\n 0x629a292a367cd507L;\n 0x9159015a3070dd17L;\n 0x152fecd8f70e5939L;\n 0x67332667ffc00b31L;\n 0x8eb44a8768581511L;\n 0xdb0c2e0d64f98fa7L;\n 0x47b5481dbefa4fa4L;\n |];\n }\n\n let unsafe_get ctx =\n let res = unsafe_get ctx in\n By.sub res 0 48\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA3_224 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA3_224 ]\n\n open Baijiu_sha3.Unsafe\n\n type nonrec ctx = ctx\n\n let init () = Baijiu_sha3.Unsafe.init 28\n\n let unsafe_get = unsafe_get\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA3_256 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA3_256 ]\n\n open Baijiu_sha3.Unsafe\n\n type nonrec ctx = ctx\n\n let init () = Baijiu_sha3.Unsafe.init 32\n\n let unsafe_get = unsafe_get\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule type S = sig\n type ctx\n\n type kind = [ `SHA3_384 ]\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `SHA3_384 ]\n\n open Baijiu_sha3.Unsafe\n\n type nonrec ctx = ctx\n\n let init () = Baijiu_sha3.Unsafe.init 48\n\n let unsafe_get = unsafe_get\n\n let dup = dup\n\n let unsafe_feed_bytes = unsafe_feed_bytes\n\n let unsafe_feed_bigstring = unsafe_feed_bigstring\nend\n","module By = Digestif_by\nmodule Bi = Digestif_bi\n\nmodule Int64 = struct\n include Int64\n\n let ( lsl ) = Int64.shift_left\n\n let ( lsr ) = Int64.shift_right_logical\n\n let ( asr ) = Int64.shift_right\n\n let ( lor ) = Int64.logor\n\n let ( land ) = Int64.logand\n\n let ( lxor ) = Int64.logxor\n\n let ( + ) = Int64.add\n\n let ror64 a n = (a lsr n) lor (a lsl (64 - n))\n\n let rol64 a n = (a lsl n) lor (a lsr (64 - n))\nend\n\nmodule type S = sig\n type kind = [ `WHIRLPOOL ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int64 array }\n\n val init : unit -> ctx\n\n val unsafe_feed_bytes : ctx -> By.t -> int -> int -> unit\n\n val unsafe_feed_bigstring : ctx -> Bi.t -> int -> int -> unit\n\n val unsafe_get : ctx -> By.t\n\n val dup : ctx -> ctx\nend\n\nmodule Unsafe : S = struct\n type kind = [ `WHIRLPOOL ]\n\n type ctx = { mutable size : int64; b : Bytes.t; h : int64 array }\n\n let dup ctx = { size = ctx.size; b = By.copy ctx.b; h = Array.copy ctx.h }\n\n let init () =\n let b = By.make 64 '\\x00' in\n { size = 0L; b; h = Array.make 8 Int64.zero }\n\n let k =\n [|\n [|\n 0x18186018c07830d8L;\n 0x23238c2305af4626L;\n 0xc6c63fc67ef991b8L;\n 0xe8e887e8136fcdfbL;\n 0x878726874ca113cbL;\n 0xb8b8dab8a9626d11L;\n 0x0101040108050209L;\n 0x4f4f214f426e9e0dL;\n 0x3636d836adee6c9bL;\n 0xa6a6a2a6590451ffL;\n 0xd2d26fd2debdb90cL;\n 0xf5f5f3f5fb06f70eL;\n 0x7979f979ef80f296L;\n 0x6f6fa16f5fcede30L;\n 0x91917e91fcef3f6dL;\n 0x52525552aa07a4f8L;\n 0x60609d6027fdc047L;\n 0xbcbccabc89766535L;\n 0x9b9b569baccd2b37L;\n 0x8e8e028e048c018aL;\n 0xa3a3b6a371155bd2L;\n 0x0c0c300c603c186cL;\n 0x7b7bf17bff8af684L;\n 0x3535d435b5e16a80L;\n 0x1d1d741de8693af5L;\n 0xe0e0a7e05347ddb3L;\n 0xd7d77bd7f6acb321L;\n 0xc2c22fc25eed999cL;\n 0x2e2eb82e6d965c43L;\n 0x4b4b314b627a9629L;\n 0xfefedffea321e15dL;\n 0x575741578216aed5L;\n 0x15155415a8412abdL;\n 0x7777c1779fb6eee8L;\n 0x3737dc37a5eb6e92L;\n 0xe5e5b3e57b56d79eL;\n 0x9f9f469f8cd92313L;\n 0xf0f0e7f0d317fd23L;\n 0x4a4a354a6a7f9420L;\n 0xdada4fda9e95a944L;\n 0x58587d58fa25b0a2L;\n 0xc9c903c906ca8fcfL;\n 0x2929a429558d527cL;\n 0x0a0a280a5022145aL;\n 0xb1b1feb1e14f7f50L;\n 0xa0a0baa0691a5dc9L;\n 0x6b6bb16b7fdad614L;\n 0x85852e855cab17d9L;\n 0xbdbdcebd8173673cL;\n 0x5d5d695dd234ba8fL;\n 0x1010401080502090L;\n 0xf4f4f7f4f303f507L;\n 0xcbcb0bcb16c08bddL;\n 0x3e3ef83eedc67cd3L;\n 0x0505140528110a2dL;\n 0x676781671fe6ce78L;\n 0xe4e4b7e47353d597L;\n 0x27279c2725bb4e02L;\n 0x4141194132588273L;\n 0x8b8b168b2c9d0ba7L;\n 0xa7a7a6a7510153f6L;\n 0x7d7de97dcf94fab2L;\n 0x95956e95dcfb3749L;\n 0xd8d847d88e9fad56L;\n 0xfbfbcbfb8b30eb70L;\n 0xeeee9fee2371c1cdL;\n 0x7c7ced7cc791f8bbL;\n 0x6666856617e3cc71L;\n 0xdddd53dda68ea77bL;\n 0x17175c17b84b2eafL;\n 0x4747014702468e45L;\n 0x9e9e429e84dc211aL;\n 0xcaca0fca1ec589d4L;\n 0x2d2db42d75995a58L;\n 0xbfbfc6bf9179632eL;\n 0x07071c07381b0e3fL;\n 0xadad8ead012347acL;\n 0x5a5a755aea2fb4b0L;\n 0x838336836cb51befL;\n 0x3333cc3385ff66b6L;\n 0x636391633ff2c65cL;\n 0x02020802100a0412L;\n 0xaaaa92aa39384993L;\n 0x7171d971afa8e2deL;\n 0xc8c807c80ecf8dc6L;\n 0x19196419c87d32d1L;\n 0x494939497270923bL;\n 0xd9d943d9869aaf5fL;\n 0xf2f2eff2c31df931L;\n 0xe3e3abe34b48dba8L;\n 0x5b5b715be22ab6b9L;\n 0x88881a8834920dbcL;\n 0x9a9a529aa4c8293eL;\n 0x262698262dbe4c0bL;\n 0x3232c8328dfa64bfL;\n 0xb0b0fab0e94a7d59L;\n 0xe9e983e91b6acff2L;\n 0x0f0f3c0f78331e77L;\n 0xd5d573d5e6a6b733L;\n 0x80803a8074ba1df4L;\n 0xbebec2be997c6127L;\n 0xcdcd13cd26de87ebL;\n 0x3434d034bde46889L;\n 0x48483d487a759032L;\n 0xffffdbffab24e354L;\n 0x7a7af57af78ff48dL;\n 0x90907a90f4ea3d64L;\n 0x5f5f615fc23ebe9dL;\n 0x202080201da0403dL;\n 0x6868bd6867d5d00fL;\n 0x1a1a681ad07234caL;\n 0xaeae82ae192c41b7L;\n 0xb4b4eab4c95e757dL;\n 0x54544d549a19a8ceL;\n 0x93937693ece53b7fL;\n 0x222288220daa442fL;\n 0x64648d6407e9c863L;\n 0xf1f1e3f1db12ff2aL;\n 0x7373d173bfa2e6ccL;\n 0x12124812905a2482L;\n 0x40401d403a5d807aL;\n 0x0808200840281048L;\n 0xc3c32bc356e89b95L;\n 0xecec97ec337bc5dfL;\n 0xdbdb4bdb9690ab4dL;\n 0xa1a1bea1611f5fc0L;\n 0x8d8d0e8d1c830791L;\n 0x3d3df43df5c97ac8L;\n 0x97976697ccf1335bL;\n 0x0000000000000000L;\n 0xcfcf1bcf36d483f9L;\n 0x2b2bac2b4587566eL;\n 0x7676c57697b3ece1L;\n 0x8282328264b019e6L;\n 0xd6d67fd6fea9b128L;\n 0x1b1b6c1bd87736c3L;\n 0xb5b5eeb5c15b7774L;\n 0xafaf86af112943beL;\n 0x6a6ab56a77dfd41dL;\n 0x50505d50ba0da0eaL;\n 0x45450945124c8a57L;\n 0xf3f3ebf3cb18fb38L;\n 0x3030c0309df060adL;\n 0xefef9bef2b74c3c4L;\n 0x3f3ffc3fe5c37edaL;\n 0x55554955921caac7L;\n 0xa2a2b2a2791059dbL;\n 0xeaea8fea0365c9e9L;\n 0x656589650fecca6aL;\n 0xbabad2bab9686903L;\n 0x2f2fbc2f65935e4aL;\n 0xc0c027c04ee79d8eL;\n 0xdede5fdebe81a160L;\n 0x1c1c701ce06c38fcL;\n 0xfdfdd3fdbb2ee746L;\n 0x4d4d294d52649a1fL;\n 0x92927292e4e03976L;\n 0x7575c9758fbceafaL;\n 0x06061806301e0c36L;\n 0x8a8a128a249809aeL;\n 0xb2b2f2b2f940794bL;\n 0xe6e6bfe66359d185L;\n 0x0e0e380e70361c7eL;\n 0x1f1f7c1ff8633ee7L;\n 0x6262956237f7c455L;\n 0xd4d477d4eea3b53aL;\n 0xa8a89aa829324d81L;\n 0x96966296c4f43152L;\n 0xf9f9c3f99b3aef62L;\n 0xc5c533c566f697a3L;\n 0x2525942535b14a10L;\n 0x59597959f220b2abL;\n 0x84842a8454ae15d0L;\n 0x7272d572b7a7e4c5L;\n 0x3939e439d5dd72ecL;\n 0x4c4c2d4c5a619816L;\n 0x5e5e655eca3bbc94L;\n 0x7878fd78e785f09fL;\n 0x3838e038ddd870e5L;\n 0x8c8c0a8c14860598L;\n 0xd1d163d1c6b2bf17L;\n 0xa5a5aea5410b57e4L;\n 0xe2e2afe2434dd9a1L;\n 0x616199612ff8c24eL;\n 0xb3b3f6b3f1457b42L;\n 0x2121842115a54234L;\n 0x9c9c4a9c94d62508L;\n 0x1e1e781ef0663ceeL;\n 0x4343114322528661L;\n 0xc7c73bc776fc93b1L;\n 0xfcfcd7fcb32be54fL;\n 0x0404100420140824L;\n 0x51515951b208a2e3L;\n 0x99995e99bcc72f25L;\n 0x6d6da96d4fc4da22L;\n 0x0d0d340d68391a65L;\n 0xfafacffa8335e979L;\n 0xdfdf5bdfb684a369L;\n 0x7e7ee57ed79bfca9L;\n 0x242490243db44819L;\n 0x3b3bec3bc5d776feL;\n 0xabab96ab313d4b9aL;\n 0xcece1fce3ed181f0L;\n 0x1111441188552299L;\n 0x8f8f068f0c890383L;\n 0x4e4e254e4a6b9c04L;\n 0xb7b7e6b7d1517366L;\n 0xebeb8beb0b60cbe0L;\n 0x3c3cf03cfdcc78c1L;\n 0x81813e817cbf1ffdL;\n 0x94946a94d4fe3540L;\n 0xf7f7fbf7eb0cf31cL;\n 0xb9b9deb9a1676f18L;\n 0x13134c13985f268bL;\n 0x2c2cb02c7d9c5851L;\n 0xd3d36bd3d6b8bb05L;\n 0xe7e7bbe76b5cd38cL;\n 0x6e6ea56e57cbdc39L;\n 0xc4c437c46ef395aaL;\n 0x03030c03180f061bL;\n 0x565645568a13acdcL;\n 0x44440d441a49885eL;\n 0x7f7fe17fdf9efea0L;\n 0xa9a99ea921374f88L;\n 0x2a2aa82a4d825467L;\n 0xbbbbd6bbb16d6b0aL;\n 0xc1c123c146e29f87L;\n 0x53535153a202a6f1L;\n 0xdcdc57dcae8ba572L;\n 0x0b0b2c0b58271653L;\n 0x9d9d4e9d9cd32701L;\n 0x6c6cad6c47c1d82bL;\n 0x3131c43195f562a4L;\n 0x7474cd7487b9e8f3L;\n 0xf6f6fff6e309f115L;\n 0x464605460a438c4cL;\n 0xacac8aac092645a5L;\n 0x89891e893c970fb5L;\n 0x14145014a04428b4L;\n 0xe1e1a3e15b42dfbaL;\n 0x16165816b04e2ca6L;\n 0x3a3ae83acdd274f7L;\n 0x6969b9696fd0d206L;\n 0x09092409482d1241L;\n 0x7070dd70a7ade0d7L;\n 0xb6b6e2b6d954716fL;\n 0xd0d067d0ceb7bd1eL;\n 0xeded93ed3b7ec7d6L;\n 0xcccc17cc2edb85e2L;\n 0x424215422a578468L;\n 0x98985a98b4c22d2cL;\n 0xa4a4aaa4490e55edL;\n 0x2828a0285d885075L;\n 0x5c5c6d5cda31b886L;\n 0xf8f8c7f8933fed6bL;\n 0x8686228644a411c2L;\n |];\n [|\n 0xd818186018c07830L;\n 0x2623238c2305af46L;\n 0xb8c6c63fc67ef991L;\n 0xfbe8e887e8136fcdL;\n 0xcb878726874ca113L;\n 0x11b8b8dab8a9626dL;\n 0x0901010401080502L;\n 0x0d4f4f214f426e9eL;\n 0x9b3636d836adee6cL;\n 0xffa6a6a2a6590451L;\n 0x0cd2d26fd2debdb9L;\n 0x0ef5f5f3f5fb06f7L;\n 0x967979f979ef80f2L;\n 0x306f6fa16f5fcedeL;\n 0x6d91917e91fcef3fL;\n 0xf852525552aa07a4L;\n 0x4760609d6027fdc0L;\n 0x35bcbccabc897665L;\n 0x379b9b569baccd2bL;\n 0x8a8e8e028e048c01L;\n 0xd2a3a3b6a371155bL;\n 0x6c0c0c300c603c18L;\n 0x847b7bf17bff8af6L;\n 0x803535d435b5e16aL;\n 0xf51d1d741de8693aL;\n 0xb3e0e0a7e05347ddL;\n 0x21d7d77bd7f6acb3L;\n 0x9cc2c22fc25eed99L;\n 0x432e2eb82e6d965cL;\n 0x294b4b314b627a96L;\n 0x5dfefedffea321e1L;\n 0xd5575741578216aeL;\n 0xbd15155415a8412aL;\n 0xe87777c1779fb6eeL;\n 0x923737dc37a5eb6eL;\n 0x9ee5e5b3e57b56d7L;\n 0x139f9f469f8cd923L;\n 0x23f0f0e7f0d317fdL;\n 0x204a4a354a6a7f94L;\n 0x44dada4fda9e95a9L;\n 0xa258587d58fa25b0L;\n 0xcfc9c903c906ca8fL;\n 0x7c2929a429558d52L;\n 0x5a0a0a280a502214L;\n 0x50b1b1feb1e14f7fL;\n 0xc9a0a0baa0691a5dL;\n 0x146b6bb16b7fdad6L;\n 0xd985852e855cab17L;\n 0x3cbdbdcebd817367L;\n 0x8f5d5d695dd234baL;\n 0x9010104010805020L;\n 0x07f4f4f7f4f303f5L;\n 0xddcbcb0bcb16c08bL;\n 0xd33e3ef83eedc67cL;\n 0x2d0505140528110aL;\n 0x78676781671fe6ceL;\n 0x97e4e4b7e47353d5L;\n 0x0227279c2725bb4eL;\n 0x7341411941325882L;\n 0xa78b8b168b2c9d0bL;\n 0xf6a7a7a6a7510153L;\n 0xb27d7de97dcf94faL;\n 0x4995956e95dcfb37L;\n 0x56d8d847d88e9fadL;\n 0x70fbfbcbfb8b30ebL;\n 0xcdeeee9fee2371c1L;\n 0xbb7c7ced7cc791f8L;\n 0x716666856617e3ccL;\n 0x7bdddd53dda68ea7L;\n 0xaf17175c17b84b2eL;\n 0x454747014702468eL;\n 0x1a9e9e429e84dc21L;\n 0xd4caca0fca1ec589L;\n 0x582d2db42d75995aL;\n 0x2ebfbfc6bf917963L;\n 0x3f07071c07381b0eL;\n 0xacadad8ead012347L;\n 0xb05a5a755aea2fb4L;\n 0xef838336836cb51bL;\n 0xb63333cc3385ff66L;\n 0x5c636391633ff2c6L;\n 0x1202020802100a04L;\n 0x93aaaa92aa393849L;\n 0xde7171d971afa8e2L;\n 0xc6c8c807c80ecf8dL;\n 0xd119196419c87d32L;\n 0x3b49493949727092L;\n 0x5fd9d943d9869aafL;\n 0x31f2f2eff2c31df9L;\n 0xa8e3e3abe34b48dbL;\n 0xb95b5b715be22ab6L;\n 0xbc88881a8834920dL;\n 0x3e9a9a529aa4c829L;\n 0x0b262698262dbe4cL;\n 0xbf3232c8328dfa64L;\n 0x59b0b0fab0e94a7dL;\n 0xf2e9e983e91b6acfL;\n 0x770f0f3c0f78331eL;\n 0x33d5d573d5e6a6b7L;\n 0xf480803a8074ba1dL;\n 0x27bebec2be997c61L;\n 0xebcdcd13cd26de87L;\n 0x893434d034bde468L;\n 0x3248483d487a7590L;\n 0x54ffffdbffab24e3L;\n 0x8d7a7af57af78ff4L;\n 0x6490907a90f4ea3dL;\n 0x9d5f5f615fc23ebeL;\n 0x3d202080201da040L;\n 0x0f6868bd6867d5d0L;\n 0xca1a1a681ad07234L;\n 0xb7aeae82ae192c41L;\n 0x7db4b4eab4c95e75L;\n 0xce54544d549a19a8L;\n 0x7f93937693ece53bL;\n 0x2f222288220daa44L;\n 0x6364648d6407e9c8L;\n 0x2af1f1e3f1db12ffL;\n 0xcc7373d173bfa2e6L;\n 0x8212124812905a24L;\n 0x7a40401d403a5d80L;\n 0x4808082008402810L;\n 0x95c3c32bc356e89bL;\n 0xdfecec97ec337bc5L;\n 0x4ddbdb4bdb9690abL;\n 0xc0a1a1bea1611f5fL;\n 0x918d8d0e8d1c8307L;\n 0xc83d3df43df5c97aL;\n 0x5b97976697ccf133L;\n 0x0000000000000000L;\n 0xf9cfcf1bcf36d483L;\n 0x6e2b2bac2b458756L;\n 0xe17676c57697b3ecL;\n 0xe68282328264b019L;\n 0x28d6d67fd6fea9b1L;\n 0xc31b1b6c1bd87736L;\n 0x74b5b5eeb5c15b77L;\n 0xbeafaf86af112943L;\n 0x1d6a6ab56a77dfd4L;\n 0xea50505d50ba0da0L;\n 0x5745450945124c8aL;\n 0x38f3f3ebf3cb18fbL;\n 0xad3030c0309df060L;\n 0xc4efef9bef2b74c3L;\n 0xda3f3ffc3fe5c37eL;\n 0xc755554955921caaL;\n 0xdba2a2b2a2791059L;\n 0xe9eaea8fea0365c9L;\n 0x6a656589650feccaL;\n 0x03babad2bab96869L;\n 0x4a2f2fbc2f65935eL;\n 0x8ec0c027c04ee79dL;\n 0x60dede5fdebe81a1L;\n 0xfc1c1c701ce06c38L;\n 0x46fdfdd3fdbb2ee7L;\n 0x1f4d4d294d52649aL;\n 0x7692927292e4e039L;\n 0xfa7575c9758fbceaL;\n 0x3606061806301e0cL;\n 0xae8a8a128a249809L;\n 0x4bb2b2f2b2f94079L;\n 0x85e6e6bfe66359d1L;\n 0x7e0e0e380e70361cL;\n 0xe71f1f7c1ff8633eL;\n 0x556262956237f7c4L;\n 0x3ad4d477d4eea3b5L;\n 0x81a8a89aa829324dL;\n 0x5296966296c4f431L;\n 0x62f9f9c3f99b3aefL;\n 0xa3c5c533c566f697L;\n 0x102525942535b14aL;\n 0xab59597959f220b2L;\n 0xd084842a8454ae15L;\n 0xc57272d572b7a7e4L;\n 0xec3939e439d5dd72L;\n 0x164c4c2d4c5a6198L;\n 0x945e5e655eca3bbcL;\n 0x9f7878fd78e785f0L;\n 0xe53838e038ddd870L;\n 0x988c8c0a8c148605L;\n 0x17d1d163d1c6b2bfL;\n 0xe4a5a5aea5410b57L;\n 0xa1e2e2afe2434dd9L;\n 0x4e616199612ff8c2L;\n 0x42b3b3f6b3f1457bL;\n 0x342121842115a542L;\n 0x089c9c4a9c94d625L;\n 0xee1e1e781ef0663cL;\n 0x6143431143225286L;\n 0xb1c7c73bc776fc93L;\n 0x4ffcfcd7fcb32be5L;\n 0x2404041004201408L;\n 0xe351515951b208a2L;\n 0x2599995e99bcc72fL;\n 0x226d6da96d4fc4daL;\n 0x650d0d340d68391aL;\n 0x79fafacffa8335e9L;\n 0x69dfdf5bdfb684a3L;\n 0xa97e7ee57ed79bfcL;\n 0x19242490243db448L;\n 0xfe3b3bec3bc5d776L;\n 0x9aabab96ab313d4bL;\n 0xf0cece1fce3ed181L;\n 0x9911114411885522L;\n 0x838f8f068f0c8903L;\n 0x044e4e254e4a6b9cL;\n 0x66b7b7e6b7d15173L;\n 0xe0ebeb8beb0b60cbL;\n 0xc13c3cf03cfdcc78L;\n 0xfd81813e817cbf1fL;\n 0x4094946a94d4fe35L;\n 0x1cf7f7fbf7eb0cf3L;\n 0x18b9b9deb9a1676fL;\n 0x8b13134c13985f26L;\n 0x512c2cb02c7d9c58L;\n 0x05d3d36bd3d6b8bbL;\n 0x8ce7e7bbe76b5cd3L;\n 0x396e6ea56e57cbdcL;\n 0xaac4c437c46ef395L;\n 0x1b03030c03180f06L;\n 0xdc565645568a13acL;\n 0x5e44440d441a4988L;\n 0xa07f7fe17fdf9efeL;\n 0x88a9a99ea921374fL;\n 0x672a2aa82a4d8254L;\n 0x0abbbbd6bbb16d6bL;\n 0x87c1c123c146e29fL;\n 0xf153535153a202a6L;\n 0x72dcdc57dcae8ba5L;\n 0x530b0b2c0b582716L;\n 0x019d9d4e9d9cd327L;\n 0x2b6c6cad6c47c1d8L;\n 0xa43131c43195f562L;\n 0xf37474cd7487b9e8L;\n 0x15f6f6fff6e309f1L;\n 0x4c464605460a438cL;\n 0xa5acac8aac092645L;\n 0xb589891e893c970fL;\n 0xb414145014a04428L;\n 0xbae1e1a3e15b42dfL;\n 0xa616165816b04e2cL;\n 0xf73a3ae83acdd274L;\n 0x066969b9696fd0d2L;\n 0x4109092409482d12L;\n 0xd77070dd70a7ade0L;\n 0x6fb6b6e2b6d95471L;\n 0x1ed0d067d0ceb7bdL;\n 0xd6eded93ed3b7ec7L;\n 0xe2cccc17cc2edb85L;\n 0x68424215422a5784L;\n 0x2c98985a98b4c22dL;\n 0xeda4a4aaa4490e55L;\n 0x752828a0285d8850L;\n 0x865c5c6d5cda31b8L;\n 0x6bf8f8c7f8933fedL;\n 0xc28686228644a411L;\n |];\n [|\n 0x30d818186018c078L;\n 0x462623238c2305afL;\n 0x91b8c6c63fc67ef9L;\n 0xcdfbe8e887e8136fL;\n 0x13cb878726874ca1L;\n 0x6d11b8b8dab8a962L;\n 0x0209010104010805L;\n 0x9e0d4f4f214f426eL;\n 0x6c9b3636d836adeeL;\n 0x51ffa6a6a2a65904L;\n 0xb90cd2d26fd2debdL;\n 0xf70ef5f5f3f5fb06L;\n 0xf2967979f979ef80L;\n 0xde306f6fa16f5fceL;\n 0x3f6d91917e91fcefL;\n 0xa4f852525552aa07L;\n 0xc04760609d6027fdL;\n 0x6535bcbccabc8976L;\n 0x2b379b9b569baccdL;\n 0x018a8e8e028e048cL;\n 0x5bd2a3a3b6a37115L;\n 0x186c0c0c300c603cL;\n 0xf6847b7bf17bff8aL;\n 0x6a803535d435b5e1L;\n 0x3af51d1d741de869L;\n 0xddb3e0e0a7e05347L;\n 0xb321d7d77bd7f6acL;\n 0x999cc2c22fc25eedL;\n 0x5c432e2eb82e6d96L;\n 0x96294b4b314b627aL;\n 0xe15dfefedffea321L;\n 0xaed5575741578216L;\n 0x2abd15155415a841L;\n 0xeee87777c1779fb6L;\n 0x6e923737dc37a5ebL;\n 0xd79ee5e5b3e57b56L;\n 0x23139f9f469f8cd9L;\n 0xfd23f0f0e7f0d317L;\n 0x94204a4a354a6a7fL;\n 0xa944dada4fda9e95L;\n 0xb0a258587d58fa25L;\n 0x8fcfc9c903c906caL;\n 0x527c2929a429558dL;\n 0x145a0a0a280a5022L;\n 0x7f50b1b1feb1e14fL;\n 0x5dc9a0a0baa0691aL;\n 0xd6146b6bb16b7fdaL;\n 0x17d985852e855cabL;\n 0x673cbdbdcebd8173L;\n 0xba8f5d5d695dd234L;\n 0x2090101040108050L;\n 0xf507f4f4f7f4f303L;\n 0x8bddcbcb0bcb16c0L;\n 0x7cd33e3ef83eedc6L;\n 0x0a2d050514052811L;\n 0xce78676781671fe6L;\n 0xd597e4e4b7e47353L;\n 0x4e0227279c2725bbL;\n 0x8273414119413258L;\n 0x0ba78b8b168b2c9dL;\n 0x53f6a7a7a6a75101L;\n 0xfab27d7de97dcf94L;\n 0x374995956e95dcfbL;\n 0xad56d8d847d88e9fL;\n 0xeb70fbfbcbfb8b30L;\n 0xc1cdeeee9fee2371L;\n 0xf8bb7c7ced7cc791L;\n 0xcc716666856617e3L;\n 0xa77bdddd53dda68eL;\n 0x2eaf17175c17b84bL;\n 0x8e45474701470246L;\n 0x211a9e9e429e84dcL;\n 0x89d4caca0fca1ec5L;\n 0x5a582d2db42d7599L;\n 0x632ebfbfc6bf9179L;\n 0x0e3f07071c07381bL;\n 0x47acadad8ead0123L;\n 0xb4b05a5a755aea2fL;\n 0x1bef838336836cb5L;\n 0x66b63333cc3385ffL;\n 0xc65c636391633ff2L;\n 0x041202020802100aL;\n 0x4993aaaa92aa3938L;\n 0xe2de7171d971afa8L;\n 0x8dc6c8c807c80ecfL;\n 0x32d119196419c87dL;\n 0x923b494939497270L;\n 0xaf5fd9d943d9869aL;\n 0xf931f2f2eff2c31dL;\n 0xdba8e3e3abe34b48L;\n 0xb6b95b5b715be22aL;\n 0x0dbc88881a883492L;\n 0x293e9a9a529aa4c8L;\n 0x4c0b262698262dbeL;\n 0x64bf3232c8328dfaL;\n 0x7d59b0b0fab0e94aL;\n 0xcff2e9e983e91b6aL;\n 0x1e770f0f3c0f7833L;\n 0xb733d5d573d5e6a6L;\n 0x1df480803a8074baL;\n 0x6127bebec2be997cL;\n 0x87ebcdcd13cd26deL;\n 0x68893434d034bde4L;\n 0x903248483d487a75L;\n 0xe354ffffdbffab24L;\n 0xf48d7a7af57af78fL;\n 0x3d6490907a90f4eaL;\n 0xbe9d5f5f615fc23eL;\n 0x403d202080201da0L;\n 0xd00f6868bd6867d5L;\n 0x34ca1a1a681ad072L;\n 0x41b7aeae82ae192cL;\n 0x757db4b4eab4c95eL;\n 0xa8ce54544d549a19L;\n 0x3b7f93937693ece5L;\n 0x442f222288220daaL;\n 0xc86364648d6407e9L;\n 0xff2af1f1e3f1db12L;\n 0xe6cc7373d173bfa2L;\n 0x248212124812905aL;\n 0x807a40401d403a5dL;\n 0x1048080820084028L;\n 0x9b95c3c32bc356e8L;\n 0xc5dfecec97ec337bL;\n 0xab4ddbdb4bdb9690L;\n 0x5fc0a1a1bea1611fL;\n 0x07918d8d0e8d1c83L;\n 0x7ac83d3df43df5c9L;\n 0x335b97976697ccf1L;\n 0x0000000000000000L;\n 0x83f9cfcf1bcf36d4L;\n 0x566e2b2bac2b4587L;\n 0xece17676c57697b3L;\n 0x19e68282328264b0L;\n 0xb128d6d67fd6fea9L;\n 0x36c31b1b6c1bd877L;\n 0x7774b5b5eeb5c15bL;\n 0x43beafaf86af1129L;\n 0xd41d6a6ab56a77dfL;\n 0xa0ea50505d50ba0dL;\n 0x8a5745450945124cL;\n 0xfb38f3f3ebf3cb18L;\n 0x60ad3030c0309df0L;\n 0xc3c4efef9bef2b74L;\n 0x7eda3f3ffc3fe5c3L;\n 0xaac755554955921cL;\n 0x59dba2a2b2a27910L;\n 0xc9e9eaea8fea0365L;\n 0xca6a656589650fecL;\n 0x6903babad2bab968L;\n 0x5e4a2f2fbc2f6593L;\n 0x9d8ec0c027c04ee7L;\n 0xa160dede5fdebe81L;\n 0x38fc1c1c701ce06cL;\n 0xe746fdfdd3fdbb2eL;\n 0x9a1f4d4d294d5264L;\n 0x397692927292e4e0L;\n 0xeafa7575c9758fbcL;\n 0x0c3606061806301eL;\n 0x09ae8a8a128a2498L;\n 0x794bb2b2f2b2f940L;\n 0xd185e6e6bfe66359L;\n 0x1c7e0e0e380e7036L;\n 0x3ee71f1f7c1ff863L;\n 0xc4556262956237f7L;\n 0xb53ad4d477d4eea3L;\n 0x4d81a8a89aa82932L;\n 0x315296966296c4f4L;\n 0xef62f9f9c3f99b3aL;\n 0x97a3c5c533c566f6L;\n 0x4a102525942535b1L;\n 0xb2ab59597959f220L;\n 0x15d084842a8454aeL;\n 0xe4c57272d572b7a7L;\n 0x72ec3939e439d5ddL;\n 0x98164c4c2d4c5a61L;\n 0xbc945e5e655eca3bL;\n 0xf09f7878fd78e785L;\n 0x70e53838e038ddd8L;\n 0x05988c8c0a8c1486L;\n 0xbf17d1d163d1c6b2L;\n 0x57e4a5a5aea5410bL;\n 0xd9a1e2e2afe2434dL;\n 0xc24e616199612ff8L;\n 0x7b42b3b3f6b3f145L;\n 0x42342121842115a5L;\n 0x25089c9c4a9c94d6L;\n 0x3cee1e1e781ef066L;\n 0x8661434311432252L;\n 0x93b1c7c73bc776fcL;\n 0xe54ffcfcd7fcb32bL;\n 0x0824040410042014L;\n 0xa2e351515951b208L;\n 0x2f2599995e99bcc7L;\n 0xda226d6da96d4fc4L;\n 0x1a650d0d340d6839L;\n 0xe979fafacffa8335L;\n 0xa369dfdf5bdfb684L;\n 0xfca97e7ee57ed79bL;\n 0x4819242490243db4L;\n 0x76fe3b3bec3bc5d7L;\n 0x4b9aabab96ab313dL;\n 0x81f0cece1fce3ed1L;\n 0x2299111144118855L;\n 0x03838f8f068f0c89L;\n 0x9c044e4e254e4a6bL;\n 0x7366b7b7e6b7d151L;\n 0xcbe0ebeb8beb0b60L;\n 0x78c13c3cf03cfdccL;\n 0x1ffd81813e817cbfL;\n 0x354094946a94d4feL;\n 0xf31cf7f7fbf7eb0cL;\n 0x6f18b9b9deb9a167L;\n 0x268b13134c13985fL;\n 0x58512c2cb02c7d9cL;\n 0xbb05d3d36bd3d6b8L;\n 0xd38ce7e7bbe76b5cL;\n 0xdc396e6ea56e57cbL;\n 0x95aac4c437c46ef3L;\n 0x061b03030c03180fL;\n 0xacdc565645568a13L;\n 0x885e44440d441a49L;\n 0xfea07f7fe17fdf9eL;\n 0x4f88a9a99ea92137L;\n 0x54672a2aa82a4d82L;\n 0x6b0abbbbd6bbb16dL;\n 0x9f87c1c123c146e2L;\n 0xa6f153535153a202L;\n 0xa572dcdc57dcae8bL;\n 0x16530b0b2c0b5827L;\n 0x27019d9d4e9d9cd3L;\n 0xd82b6c6cad6c47c1L;\n 0x62a43131c43195f5L;\n 0xe8f37474cd7487b9L;\n 0xf115f6f6fff6e309L;\n 0x8c4c464605460a43L;\n 0x45a5acac8aac0926L;\n 0x0fb589891e893c97L;\n 0x28b414145014a044L;\n 0xdfbae1e1a3e15b42L;\n 0x2ca616165816b04eL;\n 0x74f73a3ae83acdd2L;\n 0xd2066969b9696fd0L;\n 0x124109092409482dL;\n 0xe0d77070dd70a7adL;\n 0x716fb6b6e2b6d954L;\n 0xbd1ed0d067d0ceb7L;\n 0xc7d6eded93ed3b7eL;\n 0x85e2cccc17cc2edbL;\n 0x8468424215422a57L;\n 0x2d2c98985a98b4c2L;\n 0x55eda4a4aaa4490eL;\n 0x50752828a0285d88L;\n 0xb8865c5c6d5cda31L;\n 0xed6bf8f8c7f8933fL;\n 0x11c28686228644a4L;\n |];\n [|\n 0x7830d818186018c0L;\n 0xaf462623238c2305L;\n 0xf991b8c6c63fc67eL;\n 0x6fcdfbe8e887e813L;\n 0xa113cb878726874cL;\n 0x626d11b8b8dab8a9L;\n 0x0502090101040108L;\n 0x6e9e0d4f4f214f42L;\n 0xee6c9b3636d836adL;\n 0x0451ffa6a6a2a659L;\n 0xbdb90cd2d26fd2deL;\n 0x06f70ef5f5f3f5fbL;\n 0x80f2967979f979efL;\n 0xcede306f6fa16f5fL;\n 0xef3f6d91917e91fcL;\n 0x07a4f852525552aaL;\n 0xfdc04760609d6027L;\n 0x766535bcbccabc89L;\n 0xcd2b379b9b569bacL;\n 0x8c018a8e8e028e04L;\n 0x155bd2a3a3b6a371L;\n 0x3c186c0c0c300c60L;\n 0x8af6847b7bf17bffL;\n 0xe16a803535d435b5L;\n 0x693af51d1d741de8L;\n 0x47ddb3e0e0a7e053L;\n 0xacb321d7d77bd7f6L;\n 0xed999cc2c22fc25eL;\n 0x965c432e2eb82e6dL;\n 0x7a96294b4b314b62L;\n 0x21e15dfefedffea3L;\n 0x16aed55757415782L;\n 0x412abd15155415a8L;\n 0xb6eee87777c1779fL;\n 0xeb6e923737dc37a5L;\n 0x56d79ee5e5b3e57bL;\n 0xd923139f9f469f8cL;\n 0x17fd23f0f0e7f0d3L;\n 0x7f94204a4a354a6aL;\n 0x95a944dada4fda9eL;\n 0x25b0a258587d58faL;\n 0xca8fcfc9c903c906L;\n 0x8d527c2929a42955L;\n 0x22145a0a0a280a50L;\n 0x4f7f50b1b1feb1e1L;\n 0x1a5dc9a0a0baa069L;\n 0xdad6146b6bb16b7fL;\n 0xab17d985852e855cL;\n 0x73673cbdbdcebd81L;\n 0x34ba8f5d5d695dd2L;\n 0x5020901010401080L;\n 0x03f507f4f4f7f4f3L;\n 0xc08bddcbcb0bcb16L;\n 0xc67cd33e3ef83eedL;\n 0x110a2d0505140528L;\n 0xe6ce78676781671fL;\n 0x53d597e4e4b7e473L;\n 0xbb4e0227279c2725L;\n 0x5882734141194132L;\n 0x9d0ba78b8b168b2cL;\n 0x0153f6a7a7a6a751L;\n 0x94fab27d7de97dcfL;\n 0xfb374995956e95dcL;\n 0x9fad56d8d847d88eL;\n 0x30eb70fbfbcbfb8bL;\n 0x71c1cdeeee9fee23L;\n 0x91f8bb7c7ced7cc7L;\n 0xe3cc716666856617L;\n 0x8ea77bdddd53dda6L;\n 0x4b2eaf17175c17b8L;\n 0x468e454747014702L;\n 0xdc211a9e9e429e84L;\n 0xc589d4caca0fca1eL;\n 0x995a582d2db42d75L;\n 0x79632ebfbfc6bf91L;\n 0x1b0e3f07071c0738L;\n 0x2347acadad8ead01L;\n 0x2fb4b05a5a755aeaL;\n 0xb51bef838336836cL;\n 0xff66b63333cc3385L;\n 0xf2c65c636391633fL;\n 0x0a04120202080210L;\n 0x384993aaaa92aa39L;\n 0xa8e2de7171d971afL;\n 0xcf8dc6c8c807c80eL;\n 0x7d32d119196419c8L;\n 0x70923b4949394972L;\n 0x9aaf5fd9d943d986L;\n 0x1df931f2f2eff2c3L;\n 0x48dba8e3e3abe34bL;\n 0x2ab6b95b5b715be2L;\n 0x920dbc88881a8834L;\n 0xc8293e9a9a529aa4L;\n 0xbe4c0b262698262dL;\n 0xfa64bf3232c8328dL;\n 0x4a7d59b0b0fab0e9L;\n 0x6acff2e9e983e91bL;\n 0x331e770f0f3c0f78L;\n 0xa6b733d5d573d5e6L;\n 0xba1df480803a8074L;\n 0x7c6127bebec2be99L;\n 0xde87ebcdcd13cd26L;\n 0xe468893434d034bdL;\n 0x75903248483d487aL;\n 0x24e354ffffdbffabL;\n 0x8ff48d7a7af57af7L;\n 0xea3d6490907a90f4L;\n 0x3ebe9d5f5f615fc2L;\n 0xa0403d202080201dL;\n 0xd5d00f6868bd6867L;\n 0x7234ca1a1a681ad0L;\n 0x2c41b7aeae82ae19L;\n 0x5e757db4b4eab4c9L;\n 0x19a8ce54544d549aL;\n 0xe53b7f93937693ecL;\n 0xaa442f222288220dL;\n 0xe9c86364648d6407L;\n 0x12ff2af1f1e3f1dbL;\n 0xa2e6cc7373d173bfL;\n 0x5a24821212481290L;\n 0x5d807a40401d403aL;\n 0x2810480808200840L;\n 0xe89b95c3c32bc356L;\n 0x7bc5dfecec97ec33L;\n 0x90ab4ddbdb4bdb96L;\n 0x1f5fc0a1a1bea161L;\n 0x8307918d8d0e8d1cL;\n 0xc97ac83d3df43df5L;\n 0xf1335b97976697ccL;\n 0x0000000000000000L;\n 0xd483f9cfcf1bcf36L;\n 0x87566e2b2bac2b45L;\n 0xb3ece17676c57697L;\n 0xb019e68282328264L;\n 0xa9b128d6d67fd6feL;\n 0x7736c31b1b6c1bd8L;\n 0x5b7774b5b5eeb5c1L;\n 0x2943beafaf86af11L;\n 0xdfd41d6a6ab56a77L;\n 0x0da0ea50505d50baL;\n 0x4c8a574545094512L;\n 0x18fb38f3f3ebf3cbL;\n 0xf060ad3030c0309dL;\n 0x74c3c4efef9bef2bL;\n 0xc37eda3f3ffc3fe5L;\n 0x1caac75555495592L;\n 0x1059dba2a2b2a279L;\n 0x65c9e9eaea8fea03L;\n 0xecca6a656589650fL;\n 0x686903babad2bab9L;\n 0x935e4a2f2fbc2f65L;\n 0xe79d8ec0c027c04eL;\n 0x81a160dede5fdebeL;\n 0x6c38fc1c1c701ce0L;\n 0x2ee746fdfdd3fdbbL;\n 0x649a1f4d4d294d52L;\n 0xe0397692927292e4L;\n 0xbceafa7575c9758fL;\n 0x1e0c360606180630L;\n 0x9809ae8a8a128a24L;\n 0x40794bb2b2f2b2f9L;\n 0x59d185e6e6bfe663L;\n 0x361c7e0e0e380e70L;\n 0x633ee71f1f7c1ff8L;\n 0xf7c4556262956237L;\n 0xa3b53ad4d477d4eeL;\n 0x324d81a8a89aa829L;\n 0xf4315296966296c4L;\n 0x3aef62f9f9c3f99bL;\n 0xf697a3c5c533c566L;\n 0xb14a102525942535L;\n 0x20b2ab59597959f2L;\n 0xae15d084842a8454L;\n 0xa7e4c57272d572b7L;\n 0xdd72ec3939e439d5L;\n 0x6198164c4c2d4c5aL;\n 0x3bbc945e5e655ecaL;\n 0x85f09f7878fd78e7L;\n 0xd870e53838e038ddL;\n 0x8605988c8c0a8c14L;\n 0xb2bf17d1d163d1c6L;\n 0x0b57e4a5a5aea541L;\n 0x4dd9a1e2e2afe243L;\n 0xf8c24e616199612fL;\n 0x457b42b3b3f6b3f1L;\n 0xa542342121842115L;\n 0xd625089c9c4a9c94L;\n 0x663cee1e1e781ef0L;\n 0x5286614343114322L;\n 0xfc93b1c7c73bc776L;\n 0x2be54ffcfcd7fcb3L;\n 0x1408240404100420L;\n 0x08a2e351515951b2L;\n 0xc72f2599995e99bcL;\n 0xc4da226d6da96d4fL;\n 0x391a650d0d340d68L;\n 0x35e979fafacffa83L;\n 0x84a369dfdf5bdfb6L;\n 0x9bfca97e7ee57ed7L;\n 0xb44819242490243dL;\n 0xd776fe3b3bec3bc5L;\n 0x3d4b9aabab96ab31L;\n 0xd181f0cece1fce3eL;\n 0x5522991111441188L;\n 0x8903838f8f068f0cL;\n 0x6b9c044e4e254e4aL;\n 0x517366b7b7e6b7d1L;\n 0x60cbe0ebeb8beb0bL;\n 0xcc78c13c3cf03cfdL;\n 0xbf1ffd81813e817cL;\n 0xfe354094946a94d4L;\n 0x0cf31cf7f7fbf7ebL;\n 0x676f18b9b9deb9a1L;\n 0x5f268b13134c1398L;\n 0x9c58512c2cb02c7dL;\n 0xb8bb05d3d36bd3d6L;\n 0x5cd38ce7e7bbe76bL;\n 0xcbdc396e6ea56e57L;\n 0xf395aac4c437c46eL;\n 0x0f061b03030c0318L;\n 0x13acdc565645568aL;\n 0x49885e44440d441aL;\n 0x9efea07f7fe17fdfL;\n 0x374f88a9a99ea921L;\n 0x8254672a2aa82a4dL;\n 0x6d6b0abbbbd6bbb1L;\n 0xe29f87c1c123c146L;\n 0x02a6f153535153a2L;\n 0x8ba572dcdc57dcaeL;\n 0x2716530b0b2c0b58L;\n 0xd327019d9d4e9d9cL;\n 0xc1d82b6c6cad6c47L;\n 0xf562a43131c43195L;\n 0xb9e8f37474cd7487L;\n 0x09f115f6f6fff6e3L;\n 0x438c4c464605460aL;\n 0x2645a5acac8aac09L;\n 0x970fb589891e893cL;\n 0x4428b414145014a0L;\n 0x42dfbae1e1a3e15bL;\n 0x4e2ca616165816b0L;\n 0xd274f73a3ae83acdL;\n 0xd0d2066969b9696fL;\n 0x2d12410909240948L;\n 0xade0d77070dd70a7L;\n 0x54716fb6b6e2b6d9L;\n 0xb7bd1ed0d067d0ceL;\n 0x7ec7d6eded93ed3bL;\n 0xdb85e2cccc17cc2eL;\n 0x578468424215422aL;\n 0xc22d2c98985a98b4L;\n 0x0e55eda4a4aaa449L;\n 0x8850752828a0285dL;\n 0x31b8865c5c6d5cdaL;\n 0x3fed6bf8f8c7f893L;\n 0xa411c28686228644L;\n |];\n [|\n 0xc07830d818186018L;\n 0x05af462623238c23L;\n 0x7ef991b8c6c63fc6L;\n 0x136fcdfbe8e887e8L;\n 0x4ca113cb87872687L;\n 0xa9626d11b8b8dab8L;\n 0x0805020901010401L;\n 0x426e9e0d4f4f214fL;\n 0xadee6c9b3636d836L;\n 0x590451ffa6a6a2a6L;\n 0xdebdb90cd2d26fd2L;\n 0xfb06f70ef5f5f3f5L;\n 0xef80f2967979f979L;\n 0x5fcede306f6fa16fL;\n 0xfcef3f6d91917e91L;\n 0xaa07a4f852525552L;\n 0x27fdc04760609d60L;\n 0x89766535bcbccabcL;\n 0xaccd2b379b9b569bL;\n 0x048c018a8e8e028eL;\n 0x71155bd2a3a3b6a3L;\n 0x603c186c0c0c300cL;\n 0xff8af6847b7bf17bL;\n 0xb5e16a803535d435L;\n 0xe8693af51d1d741dL;\n 0x5347ddb3e0e0a7e0L;\n 0xf6acb321d7d77bd7L;\n 0x5eed999cc2c22fc2L;\n 0x6d965c432e2eb82eL;\n 0x627a96294b4b314bL;\n 0xa321e15dfefedffeL;\n 0x8216aed557574157L;\n 0xa8412abd15155415L;\n 0x9fb6eee87777c177L;\n 0xa5eb6e923737dc37L;\n 0x7b56d79ee5e5b3e5L;\n 0x8cd923139f9f469fL;\n 0xd317fd23f0f0e7f0L;\n 0x6a7f94204a4a354aL;\n 0x9e95a944dada4fdaL;\n 0xfa25b0a258587d58L;\n 0x06ca8fcfc9c903c9L;\n 0x558d527c2929a429L;\n 0x5022145a0a0a280aL;\n 0xe14f7f50b1b1feb1L;\n 0x691a5dc9a0a0baa0L;\n 0x7fdad6146b6bb16bL;\n 0x5cab17d985852e85L;\n 0x8173673cbdbdcebdL;\n 0xd234ba8f5d5d695dL;\n 0x8050209010104010L;\n 0xf303f507f4f4f7f4L;\n 0x16c08bddcbcb0bcbL;\n 0xedc67cd33e3ef83eL;\n 0x28110a2d05051405L;\n 0x1fe6ce7867678167L;\n 0x7353d597e4e4b7e4L;\n 0x25bb4e0227279c27L;\n 0x3258827341411941L;\n 0x2c9d0ba78b8b168bL;\n 0x510153f6a7a7a6a7L;\n 0xcf94fab27d7de97dL;\n 0xdcfb374995956e95L;\n 0x8e9fad56d8d847d8L;\n 0x8b30eb70fbfbcbfbL;\n 0x2371c1cdeeee9feeL;\n 0xc791f8bb7c7ced7cL;\n 0x17e3cc7166668566L;\n 0xa68ea77bdddd53ddL;\n 0xb84b2eaf17175c17L;\n 0x02468e4547470147L;\n 0x84dc211a9e9e429eL;\n 0x1ec589d4caca0fcaL;\n 0x75995a582d2db42dL;\n 0x9179632ebfbfc6bfL;\n 0x381b0e3f07071c07L;\n 0x012347acadad8eadL;\n 0xea2fb4b05a5a755aL;\n 0x6cb51bef83833683L;\n 0x85ff66b63333cc33L;\n 0x3ff2c65c63639163L;\n 0x100a041202020802L;\n 0x39384993aaaa92aaL;\n 0xafa8e2de7171d971L;\n 0x0ecf8dc6c8c807c8L;\n 0xc87d32d119196419L;\n 0x7270923b49493949L;\n 0x869aaf5fd9d943d9L;\n 0xc31df931f2f2eff2L;\n 0x4b48dba8e3e3abe3L;\n 0xe22ab6b95b5b715bL;\n 0x34920dbc88881a88L;\n 0xa4c8293e9a9a529aL;\n 0x2dbe4c0b26269826L;\n 0x8dfa64bf3232c832L;\n 0xe94a7d59b0b0fab0L;\n 0x1b6acff2e9e983e9L;\n 0x78331e770f0f3c0fL;\n 0xe6a6b733d5d573d5L;\n 0x74ba1df480803a80L;\n 0x997c6127bebec2beL;\n 0x26de87ebcdcd13cdL;\n 0xbde468893434d034L;\n 0x7a75903248483d48L;\n 0xab24e354ffffdbffL;\n 0xf78ff48d7a7af57aL;\n 0xf4ea3d6490907a90L;\n 0xc23ebe9d5f5f615fL;\n 0x1da0403d20208020L;\n 0x67d5d00f6868bd68L;\n 0xd07234ca1a1a681aL;\n 0x192c41b7aeae82aeL;\n 0xc95e757db4b4eab4L;\n 0x9a19a8ce54544d54L;\n 0xece53b7f93937693L;\n 0x0daa442f22228822L;\n 0x07e9c86364648d64L;\n 0xdb12ff2af1f1e3f1L;\n 0xbfa2e6cc7373d173L;\n 0x905a248212124812L;\n 0x3a5d807a40401d40L;\n 0x4028104808082008L;\n 0x56e89b95c3c32bc3L;\n 0x337bc5dfecec97ecL;\n 0x9690ab4ddbdb4bdbL;\n 0x611f5fc0a1a1bea1L;\n 0x1c8307918d8d0e8dL;\n 0xf5c97ac83d3df43dL;\n 0xccf1335b97976697L;\n 0x0000000000000000L;\n 0x36d483f9cfcf1bcfL;\n 0x4587566e2b2bac2bL;\n 0x97b3ece17676c576L;\n 0x64b019e682823282L;\n 0xfea9b128d6d67fd6L;\n 0xd87736c31b1b6c1bL;\n 0xc15b7774b5b5eeb5L;\n 0x112943beafaf86afL;\n 0x77dfd41d6a6ab56aL;\n 0xba0da0ea50505d50L;\n 0x124c8a5745450945L;\n 0xcb18fb38f3f3ebf3L;\n 0x9df060ad3030c030L;\n 0x2b74c3c4efef9befL;\n 0xe5c37eda3f3ffc3fL;\n 0x921caac755554955L;\n 0x791059dba2a2b2a2L;\n 0x0365c9e9eaea8feaL;\n 0x0fecca6a65658965L;\n 0xb9686903babad2baL;\n 0x65935e4a2f2fbc2fL;\n 0x4ee79d8ec0c027c0L;\n 0xbe81a160dede5fdeL;\n 0xe06c38fc1c1c701cL;\n 0xbb2ee746fdfdd3fdL;\n 0x52649a1f4d4d294dL;\n 0xe4e0397692927292L;\n 0x8fbceafa7575c975L;\n 0x301e0c3606061806L;\n 0x249809ae8a8a128aL;\n 0xf940794bb2b2f2b2L;\n 0x6359d185e6e6bfe6L;\n 0x70361c7e0e0e380eL;\n 0xf8633ee71f1f7c1fL;\n 0x37f7c45562629562L;\n 0xeea3b53ad4d477d4L;\n 0x29324d81a8a89aa8L;\n 0xc4f4315296966296L;\n 0x9b3aef62f9f9c3f9L;\n 0x66f697a3c5c533c5L;\n 0x35b14a1025259425L;\n 0xf220b2ab59597959L;\n 0x54ae15d084842a84L;\n 0xb7a7e4c57272d572L;\n 0xd5dd72ec3939e439L;\n 0x5a6198164c4c2d4cL;\n 0xca3bbc945e5e655eL;\n 0xe785f09f7878fd78L;\n 0xddd870e53838e038L;\n 0x148605988c8c0a8cL;\n 0xc6b2bf17d1d163d1L;\n 0x410b57e4a5a5aea5L;\n 0x434dd9a1e2e2afe2L;\n 0x2ff8c24e61619961L;\n 0xf1457b42b3b3f6b3L;\n 0x15a5423421218421L;\n 0x94d625089c9c4a9cL;\n 0xf0663cee1e1e781eL;\n 0x2252866143431143L;\n 0x76fc93b1c7c73bc7L;\n 0xb32be54ffcfcd7fcL;\n 0x2014082404041004L;\n 0xb208a2e351515951L;\n 0xbcc72f2599995e99L;\n 0x4fc4da226d6da96dL;\n 0x68391a650d0d340dL;\n 0x8335e979fafacffaL;\n 0xb684a369dfdf5bdfL;\n 0xd79bfca97e7ee57eL;\n 0x3db4481924249024L;\n 0xc5d776fe3b3bec3bL;\n 0x313d4b9aabab96abL;\n 0x3ed181f0cece1fceL;\n 0x8855229911114411L;\n 0x0c8903838f8f068fL;\n 0x4a6b9c044e4e254eL;\n 0xd1517366b7b7e6b7L;\n 0x0b60cbe0ebeb8bebL;\n 0xfdcc78c13c3cf03cL;\n 0x7cbf1ffd81813e81L;\n 0xd4fe354094946a94L;\n 0xeb0cf31cf7f7fbf7L;\n 0xa1676f18b9b9deb9L;\n 0x985f268b13134c13L;\n 0x7d9c58512c2cb02cL;\n 0xd6b8bb05d3d36bd3L;\n 0x6b5cd38ce7e7bbe7L;\n 0x57cbdc396e6ea56eL;\n 0x6ef395aac4c437c4L;\n 0x180f061b03030c03L;\n 0x8a13acdc56564556L;\n 0x1a49885e44440d44L;\n 0xdf9efea07f7fe17fL;\n 0x21374f88a9a99ea9L;\n 0x4d8254672a2aa82aL;\n 0xb16d6b0abbbbd6bbL;\n 0x46e29f87c1c123c1L;\n 0xa202a6f153535153L;\n 0xae8ba572dcdc57dcL;\n 0x582716530b0b2c0bL;\n 0x9cd327019d9d4e9dL;\n 0x47c1d82b6c6cad6cL;\n 0x95f562a43131c431L;\n 0x87b9e8f37474cd74L;\n 0xe309f115f6f6fff6L;\n 0x0a438c4c46460546L;\n 0x092645a5acac8aacL;\n 0x3c970fb589891e89L;\n 0xa04428b414145014L;\n 0x5b42dfbae1e1a3e1L;\n 0xb04e2ca616165816L;\n 0xcdd274f73a3ae83aL;\n 0x6fd0d2066969b969L;\n 0x482d124109092409L;\n 0xa7ade0d77070dd70L;\n 0xd954716fb6b6e2b6L;\n 0xceb7bd1ed0d067d0L;\n 0x3b7ec7d6eded93edL;\n 0x2edb85e2cccc17ccL;\n 0x2a57846842421542L;\n 0xb4c22d2c98985a98L;\n 0x490e55eda4a4aaa4L;\n 0x5d8850752828a028L;\n 0xda31b8865c5c6d5cL;\n 0x933fed6bf8f8c7f8L;\n 0x44a411c286862286L;\n |];\n [|\n 0x18c07830d8181860L;\n 0x2305af462623238cL;\n 0xc67ef991b8c6c63fL;\n 0xe8136fcdfbe8e887L;\n 0x874ca113cb878726L;\n 0xb8a9626d11b8b8daL;\n 0x0108050209010104L;\n 0x4f426e9e0d4f4f21L;\n 0x36adee6c9b3636d8L;\n 0xa6590451ffa6a6a2L;\n 0xd2debdb90cd2d26fL;\n 0xf5fb06f70ef5f5f3L;\n 0x79ef80f2967979f9L;\n 0x6f5fcede306f6fa1L;\n 0x91fcef3f6d91917eL;\n 0x52aa07a4f8525255L;\n 0x6027fdc04760609dL;\n 0xbc89766535bcbccaL;\n 0x9baccd2b379b9b56L;\n 0x8e048c018a8e8e02L;\n 0xa371155bd2a3a3b6L;\n 0x0c603c186c0c0c30L;\n 0x7bff8af6847b7bf1L;\n 0x35b5e16a803535d4L;\n 0x1de8693af51d1d74L;\n 0xe05347ddb3e0e0a7L;\n 0xd7f6acb321d7d77bL;\n 0xc25eed999cc2c22fL;\n 0x2e6d965c432e2eb8L;\n 0x4b627a96294b4b31L;\n 0xfea321e15dfefedfL;\n 0x578216aed5575741L;\n 0x15a8412abd151554L;\n 0x779fb6eee87777c1L;\n 0x37a5eb6e923737dcL;\n 0xe57b56d79ee5e5b3L;\n 0x9f8cd923139f9f46L;\n 0xf0d317fd23f0f0e7L;\n 0x4a6a7f94204a4a35L;\n 0xda9e95a944dada4fL;\n 0x58fa25b0a258587dL;\n 0xc906ca8fcfc9c903L;\n 0x29558d527c2929a4L;\n 0x0a5022145a0a0a28L;\n 0xb1e14f7f50b1b1feL;\n 0xa0691a5dc9a0a0baL;\n 0x6b7fdad6146b6bb1L;\n 0x855cab17d985852eL;\n 0xbd8173673cbdbdceL;\n 0x5dd234ba8f5d5d69L;\n 0x1080502090101040L;\n 0xf4f303f507f4f4f7L;\n 0xcb16c08bddcbcb0bL;\n 0x3eedc67cd33e3ef8L;\n 0x0528110a2d050514L;\n 0x671fe6ce78676781L;\n 0xe47353d597e4e4b7L;\n 0x2725bb4e0227279cL;\n 0x4132588273414119L;\n 0x8b2c9d0ba78b8b16L;\n 0xa7510153f6a7a7a6L;\n 0x7dcf94fab27d7de9L;\n 0x95dcfb374995956eL;\n 0xd88e9fad56d8d847L;\n 0xfb8b30eb70fbfbcbL;\n 0xee2371c1cdeeee9fL;\n 0x7cc791f8bb7c7cedL;\n 0x6617e3cc71666685L;\n 0xdda68ea77bdddd53L;\n 0x17b84b2eaf17175cL;\n 0x4702468e45474701L;\n 0x9e84dc211a9e9e42L;\n 0xca1ec589d4caca0fL;\n 0x2d75995a582d2db4L;\n 0xbf9179632ebfbfc6L;\n 0x07381b0e3f07071cL;\n 0xad012347acadad8eL;\n 0x5aea2fb4b05a5a75L;\n 0x836cb51bef838336L;\n 0x3385ff66b63333ccL;\n 0x633ff2c65c636391L;\n 0x02100a0412020208L;\n 0xaa39384993aaaa92L;\n 0x71afa8e2de7171d9L;\n 0xc80ecf8dc6c8c807L;\n 0x19c87d32d1191964L;\n 0x497270923b494939L;\n 0xd9869aaf5fd9d943L;\n 0xf2c31df931f2f2efL;\n 0xe34b48dba8e3e3abL;\n 0x5be22ab6b95b5b71L;\n 0x8834920dbc88881aL;\n 0x9aa4c8293e9a9a52L;\n 0x262dbe4c0b262698L;\n 0x328dfa64bf3232c8L;\n 0xb0e94a7d59b0b0faL;\n 0xe91b6acff2e9e983L;\n 0x0f78331e770f0f3cL;\n 0xd5e6a6b733d5d573L;\n 0x8074ba1df480803aL;\n 0xbe997c6127bebec2L;\n 0xcd26de87ebcdcd13L;\n 0x34bde468893434d0L;\n 0x487a75903248483dL;\n 0xffab24e354ffffdbL;\n 0x7af78ff48d7a7af5L;\n 0x90f4ea3d6490907aL;\n 0x5fc23ebe9d5f5f61L;\n 0x201da0403d202080L;\n 0x6867d5d00f6868bdL;\n 0x1ad07234ca1a1a68L;\n 0xae192c41b7aeae82L;\n 0xb4c95e757db4b4eaL;\n 0x549a19a8ce54544dL;\n 0x93ece53b7f939376L;\n 0x220daa442f222288L;\n 0x6407e9c86364648dL;\n 0xf1db12ff2af1f1e3L;\n 0x73bfa2e6cc7373d1L;\n 0x12905a2482121248L;\n 0x403a5d807a40401dL;\n 0x0840281048080820L;\n 0xc356e89b95c3c32bL;\n 0xec337bc5dfecec97L;\n 0xdb9690ab4ddbdb4bL;\n 0xa1611f5fc0a1a1beL;\n 0x8d1c8307918d8d0eL;\n 0x3df5c97ac83d3df4L;\n 0x97ccf1335b979766L;\n 0x0000000000000000L;\n 0xcf36d483f9cfcf1bL;\n 0x2b4587566e2b2bacL;\n 0x7697b3ece17676c5L;\n 0x8264b019e6828232L;\n 0xd6fea9b128d6d67fL;\n 0x1bd87736c31b1b6cL;\n 0xb5c15b7774b5b5eeL;\n 0xaf112943beafaf86L;\n 0x6a77dfd41d6a6ab5L;\n 0x50ba0da0ea50505dL;\n 0x45124c8a57454509L;\n 0xf3cb18fb38f3f3ebL;\n 0x309df060ad3030c0L;\n 0xef2b74c3c4efef9bL;\n 0x3fe5c37eda3f3ffcL;\n 0x55921caac7555549L;\n 0xa2791059dba2a2b2L;\n 0xea0365c9e9eaea8fL;\n 0x650fecca6a656589L;\n 0xbab9686903babad2L;\n 0x2f65935e4a2f2fbcL;\n 0xc04ee79d8ec0c027L;\n 0xdebe81a160dede5fL;\n 0x1ce06c38fc1c1c70L;\n 0xfdbb2ee746fdfdd3L;\n 0x4d52649a1f4d4d29L;\n 0x92e4e03976929272L;\n 0x758fbceafa7575c9L;\n 0x06301e0c36060618L;\n 0x8a249809ae8a8a12L;\n 0xb2f940794bb2b2f2L;\n 0xe66359d185e6e6bfL;\n 0x0e70361c7e0e0e38L;\n 0x1ff8633ee71f1f7cL;\n 0x6237f7c455626295L;\n 0xd4eea3b53ad4d477L;\n 0xa829324d81a8a89aL;\n 0x96c4f43152969662L;\n 0xf99b3aef62f9f9c3L;\n 0xc566f697a3c5c533L;\n 0x2535b14a10252594L;\n 0x59f220b2ab595979L;\n 0x8454ae15d084842aL;\n 0x72b7a7e4c57272d5L;\n 0x39d5dd72ec3939e4L;\n 0x4c5a6198164c4c2dL;\n 0x5eca3bbc945e5e65L;\n 0x78e785f09f7878fdL;\n 0x38ddd870e53838e0L;\n 0x8c148605988c8c0aL;\n 0xd1c6b2bf17d1d163L;\n 0xa5410b57e4a5a5aeL;\n 0xe2434dd9a1e2e2afL;\n 0x612ff8c24e616199L;\n 0xb3f1457b42b3b3f6L;\n 0x2115a54234212184L;\n 0x9c94d625089c9c4aL;\n 0x1ef0663cee1e1e78L;\n 0x4322528661434311L;\n 0xc776fc93b1c7c73bL;\n 0xfcb32be54ffcfcd7L;\n 0x0420140824040410L;\n 0x51b208a2e3515159L;\n 0x99bcc72f2599995eL;\n 0x6d4fc4da226d6da9L;\n 0x0d68391a650d0d34L;\n 0xfa8335e979fafacfL;\n 0xdfb684a369dfdf5bL;\n 0x7ed79bfca97e7ee5L;\n 0x243db44819242490L;\n 0x3bc5d776fe3b3becL;\n 0xab313d4b9aabab96L;\n 0xce3ed181f0cece1fL;\n 0x1188552299111144L;\n 0x8f0c8903838f8f06L;\n 0x4e4a6b9c044e4e25L;\n 0xb7d1517366b7b7e6L;\n 0xeb0b60cbe0ebeb8bL;\n 0x3cfdcc78c13c3cf0L;\n 0x817cbf1ffd81813eL;\n 0x94d4fe354094946aL;\n 0xf7eb0cf31cf7f7fbL;\n 0xb9a1676f18b9b9deL;\n 0x13985f268b13134cL;\n 0x2c7d9c58512c2cb0L;\n 0xd3d6b8bb05d3d36bL;\n 0xe76b5cd38ce7e7bbL;\n 0x6e57cbdc396e6ea5L;\n 0xc46ef395aac4c437L;\n 0x03180f061b03030cL;\n 0x568a13acdc565645L;\n 0x441a49885e44440dL;\n 0x7fdf9efea07f7fe1L;\n 0xa921374f88a9a99eL;\n 0x2a4d8254672a2aa8L;\n 0xbbb16d6b0abbbbd6L;\n 0xc146e29f87c1c123L;\n 0x53a202a6f1535351L;\n 0xdcae8ba572dcdc57L;\n 0x0b582716530b0b2cL;\n 0x9d9cd327019d9d4eL;\n 0x6c47c1d82b6c6cadL;\n 0x3195f562a43131c4L;\n 0x7487b9e8f37474cdL;\n 0xf6e309f115f6f6ffL;\n 0x460a438c4c464605L;\n 0xac092645a5acac8aL;\n 0x893c970fb589891eL;\n 0x14a04428b4141450L;\n 0xe15b42dfbae1e1a3L;\n 0x16b04e2ca6161658L;\n 0x3acdd274f73a3ae8L;\n 0x696fd0d2066969b9L;\n 0x09482d1241090924L;\n 0x70a7ade0d77070ddL;\n 0xb6d954716fb6b6e2L;\n 0xd0ceb7bd1ed0d067L;\n 0xed3b7ec7d6eded93L;\n 0xcc2edb85e2cccc17L;\n 0x422a578468424215L;\n 0x98b4c22d2c98985aL;\n 0xa4490e55eda4a4aaL;\n 0x285d8850752828a0L;\n 0x5cda31b8865c5c6dL;\n 0xf8933fed6bf8f8c7L;\n 0x8644a411c2868622L;\n |];\n [|\n 0x6018c07830d81818L;\n 0x8c2305af46262323L;\n 0x3fc67ef991b8c6c6L;\n 0x87e8136fcdfbe8e8L;\n 0x26874ca113cb8787L;\n 0xdab8a9626d11b8b8L;\n 0x0401080502090101L;\n 0x214f426e9e0d4f4fL;\n 0xd836adee6c9b3636L;\n 0xa2a6590451ffa6a6L;\n 0x6fd2debdb90cd2d2L;\n 0xf3f5fb06f70ef5f5L;\n 0xf979ef80f2967979L;\n 0xa16f5fcede306f6fL;\n 0x7e91fcef3f6d9191L;\n 0x5552aa07a4f85252L;\n 0x9d6027fdc0476060L;\n 0xcabc89766535bcbcL;\n 0x569baccd2b379b9bL;\n 0x028e048c018a8e8eL;\n 0xb6a371155bd2a3a3L;\n 0x300c603c186c0c0cL;\n 0xf17bff8af6847b7bL;\n 0xd435b5e16a803535L;\n 0x741de8693af51d1dL;\n 0xa7e05347ddb3e0e0L;\n 0x7bd7f6acb321d7d7L;\n 0x2fc25eed999cc2c2L;\n 0xb82e6d965c432e2eL;\n 0x314b627a96294b4bL;\n 0xdffea321e15dfefeL;\n 0x41578216aed55757L;\n 0x5415a8412abd1515L;\n 0xc1779fb6eee87777L;\n 0xdc37a5eb6e923737L;\n 0xb3e57b56d79ee5e5L;\n 0x469f8cd923139f9fL;\n 0xe7f0d317fd23f0f0L;\n 0x354a6a7f94204a4aL;\n 0x4fda9e95a944dadaL;\n 0x7d58fa25b0a25858L;\n 0x03c906ca8fcfc9c9L;\n 0xa429558d527c2929L;\n 0x280a5022145a0a0aL;\n 0xfeb1e14f7f50b1b1L;\n 0xbaa0691a5dc9a0a0L;\n 0xb16b7fdad6146b6bL;\n 0x2e855cab17d98585L;\n 0xcebd8173673cbdbdL;\n 0x695dd234ba8f5d5dL;\n 0x4010805020901010L;\n 0xf7f4f303f507f4f4L;\n 0x0bcb16c08bddcbcbL;\n 0xf83eedc67cd33e3eL;\n 0x140528110a2d0505L;\n 0x81671fe6ce786767L;\n 0xb7e47353d597e4e4L;\n 0x9c2725bb4e022727L;\n 0x1941325882734141L;\n 0x168b2c9d0ba78b8bL;\n 0xa6a7510153f6a7a7L;\n 0xe97dcf94fab27d7dL;\n 0x6e95dcfb37499595L;\n 0x47d88e9fad56d8d8L;\n 0xcbfb8b30eb70fbfbL;\n 0x9fee2371c1cdeeeeL;\n 0xed7cc791f8bb7c7cL;\n 0x856617e3cc716666L;\n 0x53dda68ea77bddddL;\n 0x5c17b84b2eaf1717L;\n 0x014702468e454747L;\n 0x429e84dc211a9e9eL;\n 0x0fca1ec589d4cacaL;\n 0xb42d75995a582d2dL;\n 0xc6bf9179632ebfbfL;\n 0x1c07381b0e3f0707L;\n 0x8ead012347acadadL;\n 0x755aea2fb4b05a5aL;\n 0x36836cb51bef8383L;\n 0xcc3385ff66b63333L;\n 0x91633ff2c65c6363L;\n 0x0802100a04120202L;\n 0x92aa39384993aaaaL;\n 0xd971afa8e2de7171L;\n 0x07c80ecf8dc6c8c8L;\n 0x6419c87d32d11919L;\n 0x39497270923b4949L;\n 0x43d9869aaf5fd9d9L;\n 0xeff2c31df931f2f2L;\n 0xabe34b48dba8e3e3L;\n 0x715be22ab6b95b5bL;\n 0x1a8834920dbc8888L;\n 0x529aa4c8293e9a9aL;\n 0x98262dbe4c0b2626L;\n 0xc8328dfa64bf3232L;\n 0xfab0e94a7d59b0b0L;\n 0x83e91b6acff2e9e9L;\n 0x3c0f78331e770f0fL;\n 0x73d5e6a6b733d5d5L;\n 0x3a8074ba1df48080L;\n 0xc2be997c6127bebeL;\n 0x13cd26de87ebcdcdL;\n 0xd034bde468893434L;\n 0x3d487a7590324848L;\n 0xdbffab24e354ffffL;\n 0xf57af78ff48d7a7aL;\n 0x7a90f4ea3d649090L;\n 0x615fc23ebe9d5f5fL;\n 0x80201da0403d2020L;\n 0xbd6867d5d00f6868L;\n 0x681ad07234ca1a1aL;\n 0x82ae192c41b7aeaeL;\n 0xeab4c95e757db4b4L;\n 0x4d549a19a8ce5454L;\n 0x7693ece53b7f9393L;\n 0x88220daa442f2222L;\n 0x8d6407e9c8636464L;\n 0xe3f1db12ff2af1f1L;\n 0xd173bfa2e6cc7373L;\n 0x4812905a24821212L;\n 0x1d403a5d807a4040L;\n 0x2008402810480808L;\n 0x2bc356e89b95c3c3L;\n 0x97ec337bc5dfececL;\n 0x4bdb9690ab4ddbdbL;\n 0xbea1611f5fc0a1a1L;\n 0x0e8d1c8307918d8dL;\n 0xf43df5c97ac83d3dL;\n 0x6697ccf1335b9797L;\n 0x0000000000000000L;\n 0x1bcf36d483f9cfcfL;\n 0xac2b4587566e2b2bL;\n 0xc57697b3ece17676L;\n 0x328264b019e68282L;\n 0x7fd6fea9b128d6d6L;\n 0x6c1bd87736c31b1bL;\n 0xeeb5c15b7774b5b5L;\n 0x86af112943beafafL;\n 0xb56a77dfd41d6a6aL;\n 0x5d50ba0da0ea5050L;\n 0x0945124c8a574545L;\n 0xebf3cb18fb38f3f3L;\n 0xc0309df060ad3030L;\n 0x9bef2b74c3c4efefL;\n 0xfc3fe5c37eda3f3fL;\n 0x4955921caac75555L;\n 0xb2a2791059dba2a2L;\n 0x8fea0365c9e9eaeaL;\n 0x89650fecca6a6565L;\n 0xd2bab9686903babaL;\n 0xbc2f65935e4a2f2fL;\n 0x27c04ee79d8ec0c0L;\n 0x5fdebe81a160dedeL;\n 0x701ce06c38fc1c1cL;\n 0xd3fdbb2ee746fdfdL;\n 0x294d52649a1f4d4dL;\n 0x7292e4e039769292L;\n 0xc9758fbceafa7575L;\n 0x1806301e0c360606L;\n 0x128a249809ae8a8aL;\n 0xf2b2f940794bb2b2L;\n 0xbfe66359d185e6e6L;\n 0x380e70361c7e0e0eL;\n 0x7c1ff8633ee71f1fL;\n 0x956237f7c4556262L;\n 0x77d4eea3b53ad4d4L;\n 0x9aa829324d81a8a8L;\n 0x6296c4f431529696L;\n 0xc3f99b3aef62f9f9L;\n 0x33c566f697a3c5c5L;\n 0x942535b14a102525L;\n 0x7959f220b2ab5959L;\n 0x2a8454ae15d08484L;\n 0xd572b7a7e4c57272L;\n 0xe439d5dd72ec3939L;\n 0x2d4c5a6198164c4cL;\n 0x655eca3bbc945e5eL;\n 0xfd78e785f09f7878L;\n 0xe038ddd870e53838L;\n 0x0a8c148605988c8cL;\n 0x63d1c6b2bf17d1d1L;\n 0xaea5410b57e4a5a5L;\n 0xafe2434dd9a1e2e2L;\n 0x99612ff8c24e6161L;\n 0xf6b3f1457b42b3b3L;\n 0x842115a542342121L;\n 0x4a9c94d625089c9cL;\n 0x781ef0663cee1e1eL;\n 0x1143225286614343L;\n 0x3bc776fc93b1c7c7L;\n 0xd7fcb32be54ffcfcL;\n 0x1004201408240404L;\n 0x5951b208a2e35151L;\n 0x5e99bcc72f259999L;\n 0xa96d4fc4da226d6dL;\n 0x340d68391a650d0dL;\n 0xcffa8335e979fafaL;\n 0x5bdfb684a369dfdfL;\n 0xe57ed79bfca97e7eL;\n 0x90243db448192424L;\n 0xec3bc5d776fe3b3bL;\n 0x96ab313d4b9aababL;\n 0x1fce3ed181f0ceceL;\n 0x4411885522991111L;\n 0x068f0c8903838f8fL;\n 0x254e4a6b9c044e4eL;\n 0xe6b7d1517366b7b7L;\n 0x8beb0b60cbe0ebebL;\n 0xf03cfdcc78c13c3cL;\n 0x3e817cbf1ffd8181L;\n 0x6a94d4fe35409494L;\n 0xfbf7eb0cf31cf7f7L;\n 0xdeb9a1676f18b9b9L;\n 0x4c13985f268b1313L;\n 0xb02c7d9c58512c2cL;\n 0x6bd3d6b8bb05d3d3L;\n 0xbbe76b5cd38ce7e7L;\n 0xa56e57cbdc396e6eL;\n 0x37c46ef395aac4c4L;\n 0x0c03180f061b0303L;\n 0x45568a13acdc5656L;\n 0x0d441a49885e4444L;\n 0xe17fdf9efea07f7fL;\n 0x9ea921374f88a9a9L;\n 0xa82a4d8254672a2aL;\n 0xd6bbb16d6b0abbbbL;\n 0x23c146e29f87c1c1L;\n 0x5153a202a6f15353L;\n 0x57dcae8ba572dcdcL;\n 0x2c0b582716530b0bL;\n 0x4e9d9cd327019d9dL;\n 0xad6c47c1d82b6c6cL;\n 0xc43195f562a43131L;\n 0xcd7487b9e8f37474L;\n 0xfff6e309f115f6f6L;\n 0x05460a438c4c4646L;\n 0x8aac092645a5acacL;\n 0x1e893c970fb58989L;\n 0x5014a04428b41414L;\n 0xa3e15b42dfbae1e1L;\n 0x5816b04e2ca61616L;\n 0xe83acdd274f73a3aL;\n 0xb9696fd0d2066969L;\n 0x2409482d12410909L;\n 0xdd70a7ade0d77070L;\n 0xe2b6d954716fb6b6L;\n 0x67d0ceb7bd1ed0d0L;\n 0x93ed3b7ec7d6ededL;\n 0x17cc2edb85e2ccccL;\n 0x15422a5784684242L;\n 0x5a98b4c22d2c9898L;\n 0xaaa4490e55eda4a4L;\n 0xa0285d8850752828L;\n 0x6d5cda31b8865c5cL;\n 0xc7f8933fed6bf8f8L;\n 0x228644a411c28686L;\n |];\n [|\n 0x186018c07830d818L;\n 0x238c2305af462623L;\n 0xc63fc67ef991b8c6L;\n 0xe887e8136fcdfbe8L;\n 0x8726874ca113cb87L;\n 0xb8dab8a9626d11b8L;\n 0x0104010805020901L;\n 0x4f214f426e9e0d4fL;\n 0x36d836adee6c9b36L;\n 0xa6a2a6590451ffa6L;\n 0xd26fd2debdb90cd2L;\n 0xf5f3f5fb06f70ef5L;\n 0x79f979ef80f29679L;\n 0x6fa16f5fcede306fL;\n 0x917e91fcef3f6d91L;\n 0x525552aa07a4f852L;\n 0x609d6027fdc04760L;\n 0xbccabc89766535bcL;\n 0x9b569baccd2b379bL;\n 0x8e028e048c018a8eL;\n 0xa3b6a371155bd2a3L;\n 0x0c300c603c186c0cL;\n 0x7bf17bff8af6847bL;\n 0x35d435b5e16a8035L;\n 0x1d741de8693af51dL;\n 0xe0a7e05347ddb3e0L;\n 0xd77bd7f6acb321d7L;\n 0xc22fc25eed999cc2L;\n 0x2eb82e6d965c432eL;\n 0x4b314b627a96294bL;\n 0xfedffea321e15dfeL;\n 0x5741578216aed557L;\n 0x155415a8412abd15L;\n 0x77c1779fb6eee877L;\n 0x37dc37a5eb6e9237L;\n 0xe5b3e57b56d79ee5L;\n 0x9f469f8cd923139fL;\n 0xf0e7f0d317fd23f0L;\n 0x4a354a6a7f94204aL;\n 0xda4fda9e95a944daL;\n 0x587d58fa25b0a258L;\n 0xc903c906ca8fcfc9L;\n 0x29a429558d527c29L;\n 0x0a280a5022145a0aL;\n 0xb1feb1e14f7f50b1L;\n 0xa0baa0691a5dc9a0L;\n 0x6bb16b7fdad6146bL;\n 0x852e855cab17d985L;\n 0xbdcebd8173673cbdL;\n 0x5d695dd234ba8f5dL;\n 0x1040108050209010L;\n 0xf4f7f4f303f507f4L;\n 0xcb0bcb16c08bddcbL;\n 0x3ef83eedc67cd33eL;\n 0x05140528110a2d05L;\n 0x6781671fe6ce7867L;\n 0xe4b7e47353d597e4L;\n 0x279c2725bb4e0227L;\n 0x4119413258827341L;\n 0x8b168b2c9d0ba78bL;\n 0xa7a6a7510153f6a7L;\n 0x7de97dcf94fab27dL;\n 0x956e95dcfb374995L;\n 0xd847d88e9fad56d8L;\n 0xfbcbfb8b30eb70fbL;\n 0xee9fee2371c1cdeeL;\n 0x7ced7cc791f8bb7cL;\n 0x66856617e3cc7166L;\n 0xdd53dda68ea77bddL;\n 0x175c17b84b2eaf17L;\n 0x47014702468e4547L;\n 0x9e429e84dc211a9eL;\n 0xca0fca1ec589d4caL;\n 0x2db42d75995a582dL;\n 0xbfc6bf9179632ebfL;\n 0x071c07381b0e3f07L;\n 0xad8ead012347acadL;\n 0x5a755aea2fb4b05aL;\n 0x8336836cb51bef83L;\n 0x33cc3385ff66b633L;\n 0x6391633ff2c65c63L;\n 0x020802100a041202L;\n 0xaa92aa39384993aaL;\n 0x71d971afa8e2de71L;\n 0xc807c80ecf8dc6c8L;\n 0x196419c87d32d119L;\n 0x4939497270923b49L;\n 0xd943d9869aaf5fd9L;\n 0xf2eff2c31df931f2L;\n 0xe3abe34b48dba8e3L;\n 0x5b715be22ab6b95bL;\n 0x881a8834920dbc88L;\n 0x9a529aa4c8293e9aL;\n 0x2698262dbe4c0b26L;\n 0x32c8328dfa64bf32L;\n 0xb0fab0e94a7d59b0L;\n 0xe983e91b6acff2e9L;\n 0x0f3c0f78331e770fL;\n 0xd573d5e6a6b733d5L;\n 0x803a8074ba1df480L;\n 0xbec2be997c6127beL;\n 0xcd13cd26de87ebcdL;\n 0x34d034bde4688934L;\n 0x483d487a75903248L;\n 0xffdbffab24e354ffL;\n 0x7af57af78ff48d7aL;\n 0x907a90f4ea3d6490L;\n 0x5f615fc23ebe9d5fL;\n 0x2080201da0403d20L;\n 0x68bd6867d5d00f68L;\n 0x1a681ad07234ca1aL;\n 0xae82ae192c41b7aeL;\n 0xb4eab4c95e757db4L;\n 0x544d549a19a8ce54L;\n 0x937693ece53b7f93L;\n 0x2288220daa442f22L;\n 0x648d6407e9c86364L;\n 0xf1e3f1db12ff2af1L;\n 0x73d173bfa2e6cc73L;\n 0x124812905a248212L;\n 0x401d403a5d807a40L;\n 0x0820084028104808L;\n 0xc32bc356e89b95c3L;\n 0xec97ec337bc5dfecL;\n 0xdb4bdb9690ab4ddbL;\n 0xa1bea1611f5fc0a1L;\n 0x8d0e8d1c8307918dL;\n 0x3df43df5c97ac83dL;\n 0x976697ccf1335b97L;\n 0x0000000000000000L;\n 0xcf1bcf36d483f9cfL;\n 0x2bac2b4587566e2bL;\n 0x76c57697b3ece176L;\n 0x82328264b019e682L;\n 0xd67fd6fea9b128d6L;\n 0x1b6c1bd87736c31bL;\n 0xb5eeb5c15b7774b5L;\n 0xaf86af112943beafL;\n 0x6ab56a77dfd41d6aL;\n 0x505d50ba0da0ea50L;\n 0x450945124c8a5745L;\n 0xf3ebf3cb18fb38f3L;\n 0x30c0309df060ad30L;\n 0xef9bef2b74c3c4efL;\n 0x3ffc3fe5c37eda3fL;\n 0x554955921caac755L;\n 0xa2b2a2791059dba2L;\n 0xea8fea0365c9e9eaL;\n 0x6589650fecca6a65L;\n 0xbad2bab9686903baL;\n 0x2fbc2f65935e4a2fL;\n 0xc027c04ee79d8ec0L;\n 0xde5fdebe81a160deL;\n 0x1c701ce06c38fc1cL;\n 0xfdd3fdbb2ee746fdL;\n 0x4d294d52649a1f4dL;\n 0x927292e4e0397692L;\n 0x75c9758fbceafa75L;\n 0x061806301e0c3606L;\n 0x8a128a249809ae8aL;\n 0xb2f2b2f940794bb2L;\n 0xe6bfe66359d185e6L;\n 0x0e380e70361c7e0eL;\n 0x1f7c1ff8633ee71fL;\n 0x62956237f7c45562L;\n 0xd477d4eea3b53ad4L;\n 0xa89aa829324d81a8L;\n 0x966296c4f4315296L;\n 0xf9c3f99b3aef62f9L;\n 0xc533c566f697a3c5L;\n 0x25942535b14a1025L;\n 0x597959f220b2ab59L;\n 0x842a8454ae15d084L;\n 0x72d572b7a7e4c572L;\n 0x39e439d5dd72ec39L;\n 0x4c2d4c5a6198164cL;\n 0x5e655eca3bbc945eL;\n 0x78fd78e785f09f78L;\n 0x38e038ddd870e538L;\n 0x8c0a8c148605988cL;\n 0xd163d1c6b2bf17d1L;\n 0xa5aea5410b57e4a5L;\n 0xe2afe2434dd9a1e2L;\n 0x6199612ff8c24e61L;\n 0xb3f6b3f1457b42b3L;\n 0x21842115a5423421L;\n 0x9c4a9c94d625089cL;\n 0x1e781ef0663cee1eL;\n 0x4311432252866143L;\n 0xc73bc776fc93b1c7L;\n 0xfcd7fcb32be54ffcL;\n 0x0410042014082404L;\n 0x515951b208a2e351L;\n 0x995e99bcc72f2599L;\n 0x6da96d4fc4da226dL;\n 0x0d340d68391a650dL;\n 0xfacffa8335e979faL;\n 0xdf5bdfb684a369dfL;\n 0x7ee57ed79bfca97eL;\n 0x2490243db4481924L;\n 0x3bec3bc5d776fe3bL;\n 0xab96ab313d4b9aabL;\n 0xce1fce3ed181f0ceL;\n 0x1144118855229911L;\n 0x8f068f0c8903838fL;\n 0x4e254e4a6b9c044eL;\n 0xb7e6b7d1517366b7L;\n 0xeb8beb0b60cbe0ebL;\n 0x3cf03cfdcc78c13cL;\n 0x813e817cbf1ffd81L;\n 0x946a94d4fe354094L;\n 0xf7fbf7eb0cf31cf7L;\n 0xb9deb9a1676f18b9L;\n 0x134c13985f268b13L;\n 0x2cb02c7d9c58512cL;\n 0xd36bd3d6b8bb05d3L;\n 0xe7bbe76b5cd38ce7L;\n 0x6ea56e57cbdc396eL;\n 0xc437c46ef395aac4L;\n 0x030c03180f061b03L;\n 0x5645568a13acdc56L;\n 0x440d441a49885e44L;\n 0x7fe17fdf9efea07fL;\n 0xa99ea921374f88a9L;\n 0x2aa82a4d8254672aL;\n 0xbbd6bbb16d6b0abbL;\n 0xc123c146e29f87c1L;\n 0x535153a202a6f153L;\n 0xdc57dcae8ba572dcL;\n 0x0b2c0b582716530bL;\n 0x9d4e9d9cd327019dL;\n 0x6cad6c47c1d82b6cL;\n 0x31c43195f562a431L;\n 0x74cd7487b9e8f374L;\n 0xf6fff6e309f115f6L;\n 0x4605460a438c4c46L;\n 0xac8aac092645a5acL;\n 0x891e893c970fb589L;\n 0x145014a04428b414L;\n 0xe1a3e15b42dfbae1L;\n 0x165816b04e2ca616L;\n 0x3ae83acdd274f73aL;\n 0x69b9696fd0d20669L;\n 0x092409482d124109L;\n 0x70dd70a7ade0d770L;\n 0xb6e2b6d954716fb6L;\n 0xd067d0ceb7bd1ed0L;\n 0xed93ed3b7ec7d6edL;\n 0xcc17cc2edb85e2ccL;\n 0x4215422a57846842L;\n 0x985a98b4c22d2c98L;\n 0xa4aaa4490e55eda4L;\n 0x28a0285d88507528L;\n 0x5c6d5cda31b8865cL;\n 0xf8c7f8933fed6bf8L;\n 0x86228644a411c286L;\n |];\n |]\n\n let whirlpool_do_chunk :\n type a. be64_to_cpu:(a -> int -> int64) -> ctx -> a -> int -> unit =\n fun ~be64_to_cpu ctx buf off ->\n let key = Array.init 2 (fun _ -> Array.make 8 Int64.zero) in\n let state = Array.init 2 (fun _ -> Array.make 8 Int64.zero) in\n let m = ref 0 in\n let rc =\n [|\n 0x1823c6e887b8014fL;\n 0x36a6d2f5796f9152L;\n 0x60bc9b8ea30c7b35L;\n 0x1de0d7c22e4bfe57L;\n 0x157737e59ff04adaL;\n 0x58c9290ab1a06b85L;\n 0xbd5d10f4cb3e0567L;\n 0xe427418ba77d95d8L;\n 0xfbee7c66dd17479eL;\n 0xca2dbf07ad5a8333L;\n |] in\n for i = 0 to 7 do\n key.(0).(i) <- ctx.h.(i) ;\n let off = off + (i * 8) in\n state.(0).(i) <- Int64.(be64_to_cpu buf off lxor ctx.h.(i)) ;\n ctx.h.(i) <- state.(0).(i)\n done ;\n let wp_op src shift =\n let mask v = Int64.(to_int (v land 0xffL)) in\n let get_k i =\n k.(i).(mask\n (Int64.shift_right src.((shift + 8 - i) land 7) (56 - (8 * i))))\n in\n Array.fold_left Int64.logxor Int64.zero (Array.init 8 get_k) in\n for i = 0 to 9 do\n let m0, m1 = (!m, !m lxor 1) in\n let upd_key i = key.(m1).(i) <- wp_op key.(m0) i in\n let upd_state i =\n state.(m1).(i) <- Int64.(wp_op state.(m0) i lxor key.(m1).(i)) in\n for i = 0 to 7 do\n upd_key i\n done ;\n key.(m1).(0) <- Int64.(key.(m1).(0) lxor rc.(i)) ;\n for i = 0 to 7 do\n upd_state i\n done ;\n m := !m lxor 1\n done ;\n let upd_hash i = Int64.(ctx.h.(i) <- ctx.h.(i) lxor state.(0).(i)) in\n for i = 0 to 7 do\n upd_hash i\n done ;\n ()\n\n let feed :\n type a.\n blit:(a -> int -> By.t -> int -> int -> unit) ->\n be64_to_cpu:(a -> int -> int64) ->\n ctx ->\n a ->\n int ->\n int ->\n unit =\n fun ~blit ~be64_to_cpu ctx buf off len ->\n let idx = ref Int64.(to_int (ctx.size land 0x3FL)) in\n let len = ref len in\n let off = ref off in\n let to_fill = 64 - !idx in\n ctx.size <- Int64.add ctx.size (Int64.of_int !len) ;\n if !idx <> 0 && !len >= to_fill\n then (\n blit buf !off ctx.b !idx to_fill ;\n whirlpool_do_chunk ~be64_to_cpu:By.be64_to_cpu ctx ctx.b 0 ;\n len := !len - to_fill ;\n off := !off + to_fill ;\n idx := 0) ;\n while !len >= 64 do\n whirlpool_do_chunk ~be64_to_cpu ctx buf !off ;\n len := !len - 64 ;\n off := !off + 64\n done ;\n if !len <> 0 then blit buf !off ctx.b !idx !len ;\n ()\n\n let unsafe_feed_bytes = feed ~blit:By.blit ~be64_to_cpu:By.be64_to_cpu\n\n let unsafe_feed_bigstring =\n feed ~blit:By.blit_from_bigstring ~be64_to_cpu:Bi.be64_to_cpu\n\n let unsafe_get ctx =\n let index = Int64.(to_int (ctx.size land 0x3FL)) + 1 in\n By.set ctx.b (index - 1) '\\x80' ;\n if index > 32\n then (\n By.fill ctx.b index (64 - index) '\\x00' ;\n whirlpool_do_chunk ~be64_to_cpu:By.be64_to_cpu ctx ctx.b 0 ;\n By.fill ctx.b 0 56 '\\x00')\n else By.fill ctx.b index (56 - index) '\\x00' ;\n By.cpu_to_be64 ctx.b 56 Int64.(ctx.size lsl 3) ;\n whirlpool_do_chunk ~be64_to_cpu:By.be64_to_cpu ctx ctx.b 0 ;\n let res = By.create (8 * 8) in\n for i = 0 to 7 do\n By.cpu_to_be64 res (i * 8) ctx.h.(i)\n done ;\n res\nend\n","# 1 \"src/digestif_eq.ml\"\nmodule Make (D : sig\n val digest_size : int\nend) =\nstruct\n let _ = D.digest_size\n\n let equal a b = Eqaf.equal a b\n\n let unsafe_compare a b = String.compare a b\nend\n","let[@inline always] char_chr ch =\n (* Char.chr contains a branch on [ch] and a plt indirection, this\n * implementation ensures well-formedness by construction and avoids that: *)\n Char.unsafe_chr (ch land 0xff)\n\nlet[@inline] get x i = String.unsafe_get x i |> Char.code\n\n(* XXX(dinosaure): we use [unsafe_get] to avoid jump to exception:\n\n sarq $1, %rbx\n movzbq (%rax,%rbx), %rax\n leaq 1(%rax,%rax), %rax\n ret\n*)\n\nexternal unsafe_get_int16 : string -> int -> int = \"%caml_string_get16u\"\nlet[@inline] get16 x i = unsafe_get_int16 x i\n\n(* XXX(dinosaure): same as [unsafe_get] but for [int16]:\n\n sarq $1, %rbx\n movzwq (%rax,%rbx), %rax\n leaq 1(%rax,%rax), %rax\n ret\n*)\n\nlet equal ~ln a b =\n let l1 = ln asr 1 in\n\n (*\n sarq $1, %rcx\n orq $1, %rcx\n *)\n\n let r = ref 0 in\n\n (*\n movq $1, %rdx\n *)\n\n for i = 0 to pred l1 do r := !r lor (get16 a (i * 2) lxor get16 b (i * 2)) done ;\n\n (*\n movq $1, %rsi\n addq $-2, %rcx\n cmpq %rcx, %rsi\n jg .L104\n.L105:\n leaq -1(%rsi,%rsi), %r8\n\n sarq $1, %r8\n movzwq (%rdi,%r8), %r9\n leaq 1(%r9,%r9), %r9\n movzwq (%rbx,%r8), %r8\n leaq 1(%r8,%r8), %r8\n\n // [unsafe_get_int16 a i] and [unsafe_get_int6 b i]\n\n xorq %r9, %r8\n orq $1, %r8\n orq %r8, %rdx\n movq %rsi, %r8\n addq $2, %rsi\n cmpq %rcx, %r8\n jne .L105\n.L104:\n *)\n\n for _ = 1 to ln land 1 do r := !r lor (get a (ln - 1) lxor get b (ln - 1)) done ;\n\n (*\n movq $3, %rsi\n movq %rax, %rcx\n andq $3, %rcx\n cmpq %rcx, %rsi\n jg .L102\n.L103:\n movq %rax, %r8\n addq $-2, %r8\n\n sarq $1, %r8\n movzbq (%rdi,%r8), %r9\n leaq 1(%r9,%r9), %r9\n movzbq (%rbx,%r8), %r8\n leaq 1(%r8,%r8), %r8\n\n // [unsafe_get a i] and [unsafe_get b i]\n\n xorq %r9, %r8\n orq $1, %r8\n orq %r8, %rdx\n movq %rsi, %r8\n addq $2, %rsi\n cmpq %rcx, %r8\n jne .L103\n.L102:\n *)\n\n !r = 0\n\n(*\n cmpq $1, %rdx\n sete %al\n movzbq %al, %rax\n leaq 1(%rax,%rax), %rax\n ret\n*)\n\nlet equal a b =\n let al = String.length a in\n let bl = String.length b in\n if al <> bl\n then false\n else equal ~ln:al a b\n\nlet[@inline always] compare (a:int) b = a - b\nlet[@inline always] sixteen_if_minus_one_or_less n = (n asr Sys.int_size) land 16\nlet[@inline always] eight_if_one_or_more n = ((-n) asr Sys.int_size) land 8\n\nlet compare_le ~ln a b =\n let r = ref 0 in\n let i = ref (pred ln) in\n\n while !i >= 0 do\n let xa = get a !i and xb = get b !i in\n let c = compare xa xb in\n r := !r lor ((sixteen_if_minus_one_or_less c + eight_if_one_or_more c) lsr !r) ;\n decr i ;\n done ;\n\n (!r land 8) - (!r land 16)\n\nlet compare_le_with_len ~len:ln a b =\n let al = String.length a in\n let bl = String.length b in\n if ln = 0 then 0\n else if (al lxor ln) lor (bl lxor ln) <> 0\n then invalid_arg \"compare_le_with_len\"\n else compare_le ~ln a b\n\nlet compare_le a b =\n let al = String.length a in\n let bl = String.length b in\n if al < bl\n then 1\n else if al > bl\n then (-1)\n else compare_le ~ln:al (* = bl *) a b\n\nlet compare_be ~ln a b =\n let r = ref 0 in\n let i = ref 0 in\n\n while !i < ln do\n let xa = get a !i and xb = get b !i in\n let c = compare xa xb in\n r := !r lor ((sixteen_if_minus_one_or_less c + eight_if_one_or_more c) lsr !r) ;\n incr i ;\n done ;\n\n (!r land 8) - (!r land 16)\n\nlet compare_be_with_len ~len:ln a b =\n let al = String.length a in\n let bl = String.length b in\n if ln = 0 then 0\n else if (al lxor ln) lor (bl lxor ln) <> 0\n then invalid_arg \"compare_be_with_len\"\n else compare_be ~ln a b\n\nlet compare_be a b =\n let al = String.length a in\n let bl = String.length b in\n if al < bl then 1\n else if al > bl then (-1)\n else compare_be ~ln:al (* = bl *) a b\n\nlet[@inline always] minus_one_or_less n =\n n lsr (Sys.int_size - 1)\n\nlet[@inline always] one_if_not_zero n =\n minus_one_or_less ((- n) lor n)\n\nlet[@inline always] zero_if_not_zero n =\n (one_if_not_zero n) - 1\n\nlet[@inline always] select_int choose_b a b =\n let mask = ((- choose_b) lor choose_b) asr Sys.int_size in\n (a land (lnot mask)) lor (b land mask)\n\nexternal int_of_bool : bool -> int = \"%identity\"\nexternal unsafe_bool_of_int : int -> bool = \"%identity\"\n\nlet[@inline] bool_of_int n =\n unsafe_bool_of_int (one_if_not_zero n)\n\nlet[@inline always] find_uint8 ~off ~len ~f str =\n let i = ref (len - 1) in\n let a = ref (lnot 0) in\n while !i >= off do\n let byte = get str !i in\n let pred = int_of_bool (f byte) in\n (* XXX(dinosaure): a composition of [f] with [bool_of_int] such as\n [let f = bool_of_int <.> f in] implies an allocation (of a closure).\n To be GC-free, we must store result of [f] into a register, and apply\n [bool_of_int] then (introspection was done on OCaml 4.08.1). *)\n a := select_int (((!i - off) land min_int) lor pred) !a !i ;\n decr i ;\n done ; !a\n\nlet find_uint8 ?(off= 0) ~f str =\n (* XXX(dinosaure): with this overload, OCaml is able to produce 2 [find_uint8].\n One with [off= 0] and one other where [off] is an argument. I think it's about\n cross-module optimization where a call to [find_uint8 ~f v] will directly call\n the first one and a call to [find_uint8 ~off:x ~f v] will call the second one. *)\n let len = String.length str in\n find_uint8 ~off ~len ~f str\n\nlet exists_uint8 ?off ~f str =\n let v = find_uint8 ?off ~f str in\n let r = select_int (v + 1) 0 1 in\n unsafe_bool_of_int r\n\nlet divmod ~(x:int32) ~(m:int32) : int32 * int32 =\n (* Division and remainder being constant-time with respect to [x]\n * ( NOT [m] !). The OCaml variant would be:\n * [(x / m , x mod m)] where [x] is a secret and [m] is not secret.\n * Adapted from the NTRU Prime team's algorithm from\n * supercop/crypto_kem/sntrup761/ref/uint32.c\n * cite the round-2 ntru prime submission to nistpqc (march 2019)\n * Note that in practice this works for at least some much larger [x] and [m],\n * but it's unclear to me how to evaluate *which*, so leaving the original\n * restrictions in.\n *)\n let ( - ) , ( + ), ( * ) = Int32.(sub, add, mul) in\n let ( >> ) = Int32.shift_right_logical in\n if (m <= 0l) then raise (Invalid_argument \"m <= 0\") ;\n if (m >= 16348l) then raise (Invalid_argument \"m >= 16348 not supported\") ;\n\n let of_uint32 uint =\n (* apparently Int64.of_int32 sign-extends ... great... avoid that: *)\n let b = Bytes.make 8 '\\x00' in\n Unsafe.set_int32_le b 0 uint ;\n Unsafe.get_int64_le b 0\n in\n\n let x_0 = x in\n\n let x_2, q_1 =\n let int32_div_unsigned n d =\n (* can be replaced by Int32.unsigned_div\n * from OCaml >= 4.10 *)\n let sub,min_int = Int32.(sub,min_int)in\n let int32_unsigned_compare n m =\n Int32.compare (sub n min_int) (sub m min_int)\n in\n if d < 0_l then\n if int32_unsigned_compare n d < 0 then 0_l else 1_l\n else\n let q =\n let open Int32 in\n shift_left (Int32.div (Int32.shift_right_logical n 1) d) 1 in\n let r = sub n (Int32.mul q d) in\n if int32_unsigned_compare r d >= 0 then Int32.succ q else q\n in\n let v = int32_div_unsigned Int32.min_int m |> of_uint32 in\n (*let v = 0x80_00_00_00 / m in*) (* floored div *)\n let x_1, q_0 =\n let qpart_0 =\n let open Int64 in\n shift_right_logical (mul (of_uint32 x_0) v) 31\n |> to_int32\n in\n x_0 - (qpart_0 * m), qpart_0\n in\n let qpart_1 =\n let open Int64 in\n shift_right_logical (mul (of_uint32 x_1) v) 31\n |> to_int32 in\n x_1 - (qpart_1 * m),\n (q_0 + qpart_1 + 1l) in\n let x_3 = x_2 - m in\n let mask = 0l - (x_3 >> 31) in\n q_1 + mask, x_3 + (Int32.logand mask m)\n\nlet ascii_of_int32 ~digits (n:int32) : string =\n (* Recursively calls [divmod n 10]; the remainder is turned into ASCII\n and the quotient is used for the next division.*)\n if digits < 0 then raise (Invalid_argument \"digits < 0\");\n let out = Bytes.make digits '0' in\n let rec loop x = function\n | -1 -> Bytes.unsafe_to_string out\n | idx ->\n let next, this = divmod ~x ~m:10l in\n Bytes.set out idx @@ char_chr (0x30 lor (Int32.to_int this)) ;\n loop next (pred idx)\n in loop n (pred digits)\n\nlet[@inline always] to_hex_nibble f : char =\n let a = 86 + f in\n let c = 1 + ((a - 71 * ((a land 0x10) lsr 4)) lor 0x20) in\n char_chr c\n\nlet hex_of_string rawbytes =\n String.init (2 * String.length rawbytes)\n (fun idx ->\n let byt = String.get rawbytes (idx lsr 1) |> Char.code in\n (* select which 4 bits to use, this can probably be done faster:*)\n let nib = 0xf land (byt lsr (((lnot idx) land 1) lsl 2)) in\n to_hex_nibble nib)\n\nlet hex_of_bytes rawbytes = hex_of_string (Bytes.unsafe_to_string rawbytes)\n\nlet[@inline always] select_a_if_in_range ~low ~high ~n a b =\n (* select [a] if [low <= n <= high] and [b] if [n] is out of range.*)\n (* NB: ONLY WORKS FOR [0 <= low <= high <= max_int]*)\n (* The idea being that:\n 1.a) if low <= n : (n - low) is positive +\n 1.b) if low > n : (n - low) is negative -\n 2.a) if n <= high: (high - n) is positive +\n 2.b) if n > high: (high - n) is negative -\n We OR the numbers together; we only really care about the sign bit\n which is set when negative.\n Thus both numbers are positive iff (low <= n && n <= high).\n We then select the sign bit with (land min_int) and use that to choose:\n *)\n let out_of_range = (* choose b if out of range *)\n ((n - low) lor (high - n)\n land min_int)\n in\n select_int out_of_range a b\n\nlet lowercase_ascii src =\n (* ct version of String.lowercase_ascii *)\n String.map\n ( fun ch -> let n = Char.code ch in\n (* 0x41 is 'A'; 0x5a is 'Z'; 0x20 controls case for ASCII letters *)\n select_a_if_in_range ~low:0x41 ~high:0x5a ~n (n lor 0x20) (n)\n |> char_chr\n ) src\n\nlet uppercase_ascii src =\n (* ct version of String.uppercase_ascii *)\n String.map\n ( fun ch -> let n = Char.code ch in\n (* 0x61 is 'a'; 0x7a is 'z'; 0x20 controls case for ASCII letters *)\n select_a_if_in_range ~low:0x61 ~high:0x7a ~n (n lxor 0x20) (n)\n |> char_chr\n ) src\n\nlet bytes_of_hex rawhex =\n (* hex length must be multiple of 2: *)\n let error_bitmap = ref ((String.length rawhex land 1) lsl 4) in\n let decoded =\n Bytes.init (String.length rawhex lsr 1)\n (fun idx ->\n let idx = idx lsl 1 in\n let nib idx =\n String.get rawhex idx\n |> Char.code\n |> fun n -> (* uppercase -> lowercase: *)\n select_a_if_in_range ~low:0x41 ~high:0x5a\n ~n\n (n lor 0x20) (* set case bit *)\n n (* leave as-is *)\n |> fun n -> (* now either invalid; lowercase; numeric*)\n (select_a_if_in_range ~low:0x30 ~high:0x39\n ~n\n (n - 0x30) (* numeric: subtract '0' to get [0..9] *)\n (select_a_if_in_range ~low:0x61 ~high:0x66\n ~n\n (* a-f: subtract 'a' and add 10 to get [10..15]: *)\n (n - 0x61 + 10)\n (0xff) (* invalid, ensure we set upper bits of error_bitmap *)\n )\n )\n in\n let nibf0 = nib idx\n and nib0f = nib (succ idx) in\n error_bitmap := !error_bitmap lor nibf0 lor nib0f ;\n char_chr ((nibf0 lsl 4) lor nib0f)\n )\n in\n (* if any non-nibble bits were set in !error_bitmap, decoding failed: *)\n decoded, !error_bitmap land (lnot 0xf)\n\nlet string_of_hex rawhex =\n let byt, error = bytes_of_hex rawhex in\n Bytes.unsafe_to_string byt, error\n","open Core_kernel\nopen Async_kernel\n\n[%%import \"/src/config.mlh\"]\n\nmodule Spec = struct\n type t =\n | On_disk of { directory : string; should_write : bool }\n | S3 of { bucket_prefix : string; install_path : string }\nend\n\n[%%inject \"may_download\", download_snark_keys]\n\nlet may_download = ref may_download\n\nlet set_downloads_enabled b = may_download := b\n\nlet may_download () = !may_download\n\nmodule T (M : sig\n type _ t\nend) =\nstruct\n type ('a, 'b) t = { write : 'a -> 'b -> unit M.t; read : 'a -> 'b M.t }\nend\n\nmodule Disk_storable (M : sig\n type _ t\nend) =\nstruct\n type ('k, 'v) t =\n { to_string : 'k -> string\n ; read : 'k -> path:string -> 'v M.t\n ; write : 'k -> 'v -> string -> unit M.t\n }\nend\n\nmodule type S = sig\n module M : sig\n type _ t\n end\n\n type ('a, 'b) t = ('a, 'b) T(M).t =\n { write : 'a -> 'b -> unit M.t; read : 'a -> 'b M.t }\n\n module Disk_storable : sig\n type ('k, 'v) t = ('k, 'v) Disk_storable(M).t =\n { to_string : 'k -> string\n ; read : 'k -> path:string -> 'v M.t\n ; write : 'k -> 'v -> string -> unit M.t\n }\n\n val of_binable :\n ('k -> string) -> (module Binable.S with type t = 'v) -> ('k, 'v) t\n\n val simple :\n ('k -> string)\n -> ('k -> path:string -> 'v M.t)\n -> ('k -> 'v -> string -> unit M.t)\n -> ('k, 'v) t\n end\n\n val read :\n Spec.t list\n -> ('k, 'v) Disk_storable.t\n -> 'k\n -> ('v * [> `Cache_hit | `Locally_generated ]) M.t\n\n val write : Spec.t list -> ('k, 'v) Disk_storable.t -> 'k -> 'v -> unit M.t\nend\n\nmodule type Sync = S with module M := Or_error\n\nmodule type Async = S with module M := Deferred.Or_error\n\nmodule Trivial : Sync = struct\n include T (Or_error)\n\n module Disk_storable = struct\n include Disk_storable (Or_error)\n\n let of_binable to_string _m =\n let read _ ~path:_ =\n Or_error.error_string \"Key_cache: Trivial store cannot read\"\n in\n let write _k _t _path = Ok () in\n { to_string; read; write }\n\n let simple to_string read write = { to_string; read; write }\n end\n\n let read _spec { Disk_storable.to_string = _; read = _; write = _ } _k =\n Or_error.error_string \"Key_cache: Trivial store cannot read\"\n\n let write _spec { Disk_storable.to_string = _; read = _; write = _ } _k _v =\n Ok ()\nend\n\nmodule Trivial_async : Async = struct\n include T (Deferred.Or_error)\n\n module Disk_storable = struct\n include Disk_storable (Deferred.Or_error)\n\n let of_binable to_string _m =\n let read _ ~path:_ =\n Deferred.Or_error.error_string \"Key_cache: Trivial store cannot read\"\n in\n let write _k _t _path = Deferred.Or_error.return () in\n { to_string; read; write }\n\n let simple to_string read write = { to_string; read; write }\n end\n\n let read _spec { Disk_storable.to_string = _; read = _; write = _ } _k =\n Deferred.Or_error.error_string \"Key_cache: Trivial store cannot read\"\n\n let write _spec { Disk_storable.to_string = _; read = _; write = _ } _k _v =\n Deferred.Or_error.return ()\nend\n\nlet sync = ref (module Trivial : Sync)\n\nlet async = ref (module Trivial_async : Async)\n\nlet set_sync_implementation x = sync := x\n\nlet set_async_implementation x = async := x\n\nmodule Sync : Sync = struct\n include T (Or_error)\n\n module Disk_storable = struct\n include Disk_storable (Or_error)\n\n let of_binable to_string binable =\n let (module M) = !sync in\n M.Disk_storable.of_binable to_string binable\n\n let simple to_string read write =\n let (module M) = !sync in\n M.Disk_storable.simple to_string read write\n end\n\n let read spec ds k =\n let (module M) = !sync in\n M.read spec ds k\n\n let write spec ds k v =\n let (module M) = !sync in\n M.write spec ds k v\nend\n\nmodule Async : Async = struct\n include T (Deferred.Or_error)\n\n module Disk_storable = struct\n include Disk_storable (Deferred.Or_error)\n\n let of_binable to_string binable =\n let (module M) = !async in\n M.Disk_storable.of_binable to_string binable\n\n let simple to_string read write =\n let (module M) = !async in\n M.Disk_storable.simple to_string read write\n end\n\n let read spec ds k =\n let (module M) = !async in\n M.read spec ds k\n\n let write spec ds k v =\n let (module M) = !async in\n M.write spec ds k v\nend\n","open Core_kernel\n\nmodule Partial = struct\n module Bin_io (M : Intf.Input.Bin_io_intf) :\n Intf.Partial.Bin_io_intf with type t := M.t = struct\n open Bin_prot.Type_class\n\n let bin_size_t = M.bin_size_t\n\n let bin_write_t = M.bin_write_t\n\n let bin_read_t buf ~pos_ref =\n Table.attach_finalizer M.id (M.bin_read_t buf ~pos_ref)\n\n let __bin_read_t__ buf ~pos_ref i =\n Table.attach_finalizer M.id (M.__bin_read_t__ buf ~pos_ref i)\n\n let bin_shape_t = M.bin_shape_t\n\n let bin_writer_t = M.bin_writer_t\n\n let bin_reader_t = { read = bin_read_t; vtag_read = __bin_read_t__ }\n\n let bin_t =\n { shape = bin_shape_t; writer = bin_writer_t; reader = bin_reader_t }\n end\n\n module Sexp (M : Intf.Input.Sexp_intf) :\n Intf.Partial.Sexp_intf with type t := M.t = struct\n let sexp_of_t = M.sexp_of_t\n\n let t_of_sexp t = Table.attach_finalizer M.id (M.t_of_sexp t)\n end\n\n module Yojson (M : Intf.Input.Yojson_intf) :\n Intf.Partial.Yojson_intf with type t := M.t = struct\n let to_yojson = M.to_yojson\n\n let of_yojson json =\n M.of_yojson json |> Result.map ~f:(Table.attach_finalizer M.id)\n end\nend\n\nmodule Basic (M : Intf.Input.Basic_intf) :\n Intf.Output.Basic_intf with type t = M.t and type 'a creator := 'a M.creator =\nstruct\n type t = M.t\n\n let create = M.map_creator M.create ~f:(Table.attach_finalizer M.id)\nend\n\nmodule Bin_io (M : Intf.Input.Bin_io_intf) :\n Intf.Output.Bin_io_intf with type t = M.t and type 'a creator := 'a M.creator =\nstruct\n include Basic (M)\n include Partial.Bin_io (M)\nend\n\nmodule Sexp (M : Intf.Input.Sexp_intf) :\n Intf.Output.Sexp_intf with type t = M.t and type 'a creator := 'a M.creator =\nstruct\n include Basic (M)\n include Partial.Sexp (M)\nend\n\nmodule Bin_io_and_sexp (M : Intf.Input.Bin_io_and_sexp_intf) :\n Intf.Output.Bin_io_and_sexp_intf\n with type t = M.t\n and type 'a creator := 'a M.creator = struct\n include Basic (M)\n include Partial.Bin_io (M)\n include Partial.Sexp (M)\nend\n\nmodule Yojson (M : Intf.Input.Yojson_intf) :\n Intf.Output.Yojson_intf with type t = M.t and type 'a creator := 'a M.creator =\nstruct\n include Basic (M)\n include Partial.Yojson (M)\nend\n\nmodule Bin_io_and_yojson (M : Intf.Input.Bin_io_and_yojson_intf) :\n Intf.Output.Bin_io_and_yojson_intf\n with type t = M.t\n and type 'a creator := 'a M.creator = struct\n include Basic (M)\n include Partial.Bin_io (M)\n include Partial.Yojson (M)\nend\n\nmodule Full (M : Intf.Input.Full_intf) :\n Intf.Output.Full_intf with type t = M.t and type 'a creator := 'a M.creator =\nstruct\n include Basic (M)\n include Partial.Bin_io (M)\n include Partial.Sexp (M)\n include Partial.Yojson (M)\nend\n\nmodule Versioned_v1 = struct\n module Basic_intf (M : Intf.Input.Versioned_v1.Basic_intf) : sig\n include\n Intf.Output.Versioned_v1.Basic_intf\n with type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V1 = struct\n include Bin_io (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n end\n\n module Sexp (M : Intf.Input.Versioned_v1.Sexp_intf) : sig\n include\n Intf.Output.Versioned_v1.Sexp_intf\n with type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V1 = struct\n include Bin_io_and_sexp (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n end\n\n module Yojson (M : Intf.Input.Versioned_v1.Yojson_intf) : sig\n include\n Intf.Output.Versioned_v1.Yojson_intf\n with type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V1 = struct\n include Bin_io_and_yojson (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n end\n\n module Full_compare_eq_hash\n (M : Intf.Input.Versioned_v1.Full_compare_eq_hash_intf) : sig\n include\n Intf.Output.Versioned_v1.Full_compare_eq_hash_intf\n with type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V1 = struct\n include Full (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let compare = M.Stable.V1.compare\n\n let equal = M.Stable.V1.equal\n\n let hash = M.Stable.V1.hash\n\n let hash_fold_t = M.Stable.V1.hash_fold_t\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n\n let equal = M.equal\n\n let compare = M.compare\n\n let hash = M.hash\n\n let hash_fold_t = M.hash_fold_t\n end\n\n module Full (M : Intf.Input.Versioned_v1.Full_intf) : sig\n include\n Intf.Output.Versioned_v1.Full_intf\n with type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V1 = struct\n include Full (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n end\nend\n\nmodule Versioned_v2 = struct\n module Sexp (M : Intf.Input.Versioned_v2.Sexp_intf) : sig\n include\n Intf.Output.Versioned_v2.Sexp_intf\n with type Stable.V2.t = M.Stable.V2.t\n and type 'a Stable.V2.creator = 'a M.Stable.V2.creator\n and type Stable.V1.t = M.Stable.V1.t\n and type 'a Stable.V1.creator = 'a M.Stable.V1.creator\n end = struct\n module Stable = struct\n module V2 = struct\n include Bin_io_and_sexp (struct\n let id = M.id\n\n include M.Stable.V2\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V2.creator\n end\n\n module V1 = struct\n include Bin_io_and_sexp (struct\n let id = M.id\n\n include M.Stable.V1\n end)\n\n let __versioned__ = ()\n\n type 'a creator = 'a M.Stable.V1.creator\n\n let to_latest = M.Stable.V1.to_latest\n end\n\n module Latest = V2\n end\n\n type t = Stable.V2.t\n end\nend\n","type 'a t\n\nexternal run_in_thread : (unit -> 'a) -> 'a t = \"deferred_run\"\n\nlet block_on_async_exn (_ : unit -> 'a t) : 'a =\n failwith \"You can't block on async execution in JS\"\n\nexternal map : 'a t -> f:('a -> 'b) -> 'b t = \"deferred_map\"\n\nexternal bind : 'a t -> f:('a -> 'b t) -> 'b t = \"deferred_bind\"\n\nexternal upon : 'a t -> ('a -> unit) -> unit = \"deferred_upon\"\n\nexternal upon_exn : 'a t -> ('a -> unit) -> unit = \"deferred_upon_exn\"\n\nexternal is_determined : 'a t -> bool = \"deferred_is_determined\"\n\nexternal peek : 'a t -> 'a option = \"deferred_peek\"\n\nexternal value_exn : 'a t -> 'a = \"deferred_value_exn\"\n\nexternal return : 'a -> 'a t = \"deferred_return\"\n\nexternal create : (('a -> unit) -> unit) -> 'a t = \"deferred_create\"\n\nlet to_deferred promise =\n let module Ivar = Async_kernel.Ivar in\n let ivar = Ivar.create () in\n upon_exn promise (fun x -> Ivar.fill ivar x) ;\n Ivar.read ivar\n\ninclude Base.Monad.Make (struct\n type nonrec 'a t = 'a t\n\n let map = `Custom map\n\n let bind = bind\n\n let return = return\nend)\n","open Core_kernel\n\nlet key = Univ_map.Key.create ~name:\"logger\" sexp_of_opaque\n\nlet with_logger logger f =\n Async_kernel.Async_kernel_scheduler.with_local key logger ~f\n\nlet get_opt () = Async_kernel.Async_kernel_scheduler.find_local key\n\nlet get () = Option.value (get_opt ()) ~default:(Logger.null ())\n","open Intf\nopen Core_kernel\n\nmodule type Inputs_intf = sig\n module Base_field : sig\n type t\n end\n\n module Curve : sig\n module Affine : sig\n type t = Base_field.t * Base_field.t\n\n module Backend : sig\n type t = Base_field.t Kimchi_types.or_infinity\n\n val zero : unit -> t\n\n val create : Base_field.t -> Base_field.t -> t\n end\n\n val of_backend :\n Backend.t -> (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t\n end\n end\n\n module Backend : sig\n type t\n\n val make :\n Curve.Affine.Backend.t array -> Curve.Affine.Backend.t option -> t\n\n val shifted : t -> Curve.Affine.Backend.t option\n\n val unshifted : t -> Curve.Affine.Backend.t array\n end\nend\n\ntype 'a t =\n [ `With_degree_bound of\n ('a * 'a) Pickles_types.Or_infinity.t\n Pickles_types.Plonk_types.Poly_comm.With_degree_bound.t\n | `Without_degree_bound of\n ('a * 'a) Pickles_types.Plonk_types.Poly_comm.Without_degree_bound.t ]\n\nmodule Make (Inputs : Inputs_intf) = struct\n open Inputs\n module Backend = Backend\n\n type nonrec t = Base_field.t t\n\n module G_affine = Curve.Affine.Backend\n\n let g (a, b) = G_affine.create a b\n\n let g_vec arr = Array.map ~f:g arr\n\n let or_infinity_to_backend :\n ('a * 'a) Pickles_types.Or_infinity.t -> 'a Kimchi_types.or_infinity =\n function\n | Infinity ->\n Infinity\n | Finite (x, y) ->\n Finite (x, y)\n\n let or_infinity_of_backend :\n 'a Kimchi_types.or_infinity -> ('a * 'a) Pickles_types.Or_infinity.t =\n function\n | Infinity ->\n Infinity\n | Finite (x, y) ->\n Finite (x, y)\n\n let with_degree_bound_to_backend\n (commitment :\n (Base_field.t * Base_field.t) Pickles_types.Or_infinity.t\n Pickles_types.Plonk_types.Poly_comm.With_degree_bound.t ) : Backend.t =\n Backend.make\n (Array.map ~f:or_infinity_to_backend commitment.unshifted)\n (Some (or_infinity_to_backend commitment.shifted))\n\n let without_degree_bound_to_backend\n (commitment :\n (Base_field.t * Base_field.t)\n Pickles_types.Plonk_types.Poly_comm.Without_degree_bound.t ) : Backend.t\n =\n Backend.make\n (Array.map ~f:(fun x -> Kimchi_types.Finite (fst x, snd x)) commitment)\n None\n\n let to_backend (t : t) : Backend.t =\n match t with\n | `With_degree_bound t ->\n with_degree_bound_to_backend t\n | `Without_degree_bound t ->\n without_degree_bound_to_backend t\n\n let of_backend' (t : Backend.t) =\n ( Backend.unshifted t\n , Option.map (Backend.shifted t) ~f:Curve.Affine.of_backend )\n\n let of_backend_with_degree_bound (t : Backend.t) : t =\n let open Pickles_types.Plonk_types.Poly_comm in\n match Backend.shifted t with\n | None ->\n assert false\n | Some shifted ->\n let shifted = or_infinity_of_backend shifted in\n let unshifted =\n Backend.unshifted t |> Array.map ~f:or_infinity_of_backend\n in\n `With_degree_bound { unshifted; shifted }\n\n (*\n type 'a t =\n [ `With_degree_bound of\n ('a * 'a) Pickles_types.Or_infinity.t\n Pickles_types.Plonk_types.Poly_comm.With_degree_bound.t\n | `Without_degree_bound of\n ('a * 'a) Pickles_types.Plonk_types.Poly_comm.Without_degree_bound.t\n ]\n *)\n\n let of_backend_without_degree_bound (t : Backend.t) =\n let open Pickles_types.Plonk_types.Poly_comm in\n let unshifted = Backend.unshifted t in\n match Backend.shifted t with\n | None ->\n `Without_degree_bound\n (Array.map unshifted ~f:(function\n | Infinity ->\n failwith\n \"Pickles cannot handle point at infinity. Commitments must \\\n be representable in affine coordinates\"\n | Finite (x, y) ->\n (x, y) ) )\n | _ ->\n assert false\nend\n","open Core_kernel\nopen Intf\n\nmodule type Inputs_intf = sig\n module Verifier_index : T0\n\n module Field : sig\n type t\n end\n\n module Proof : sig\n type t\n\n type with_public_evals\n\n module Challenge_polynomial : T0\n\n module Backend : sig\n type t\n\n type with_public_evals\n end\n\n val to_backend :\n Challenge_polynomial.t list -> Field.t list -> t -> Backend.t\n\n val to_backend_with_public_evals :\n Challenge_polynomial.t list\n -> Field.t list\n -> with_public_evals\n -> Backend.with_public_evals\n end\n\n module Backend : sig\n type t = Field.t Kimchi_types.oracles\n\n val create : Verifier_index.t -> Proof.Backend.t -> t\n\n val create_with_public_evals :\n Verifier_index.t -> Proof.Backend.with_public_evals -> t\n end\nend\n\nmodule Make (Inputs : Inputs_intf) = struct\n open Inputs\n\n let create vk prev_challenge input (pi : Proof.t) =\n let pi = Proof.to_backend prev_challenge input pi in\n Backend.create vk pi\n\n let create_with_public_evals vk prev_challenge input\n (pi : Proof.with_public_evals) =\n let pi = Proof.to_backend_with_public_evals prev_challenge input pi in\n Backend.create_with_public_evals vk pi\n\n open Backend\n\n let scalar_challenge t = Scalar_challenge.create t\n\n let alpha (t : t) = t.o.alpha_chal\n\n let beta (t : t) = t.o.beta\n\n let gamma (t : t) = t.o.gamma\n\n let zeta (t : t) = t.o.zeta_chal\n\n let joint_combiner_chal (t : t) = Option.map ~f:fst t.o.joint_combiner\n\n let joint_combiner (t : t) = Option.map ~f:snd t.o.joint_combiner\n\n let digest_before_evaluations (t : t) = t.digest_before_evaluations\n\n let v (t : t) = t.o.v_chal\n\n let u (t : t) = t.o.u_chal\n\n let p_eval_1 (t : t) = fst t.p_eval\n\n let p_eval_2 (t : t) = snd t.p_eval\n\n let opening_prechallenges (t : t) =\n Array.map ~f:scalar_challenge t.opening_prechallenges\nend\n","(** number of witness *)\nlet columns = 15\n\n(** number of columns that take part in the permutation *)\nlet permutation_cols = 7\n","module Poly_comm0 = Poly_comm\nopen Unsigned.Size_t\n\nmodule type Stable_v1 = sig\n module Stable : sig\n module V1 : sig\n type t [@@deriving version, bin_io, sexp, compare, yojson, hash, equal]\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t [@@deriving sexp, compare, yojson]\nend\n\nmodule type Inputs_intf = sig\n open Intf\n\n val name : string\n\n module Rounds : Pickles_types.Nat.Intf\n\n module Gate_vector : sig\n open Unsigned\n\n type t\n\n val wrap : t -> Kimchi_types.wire -> Kimchi_types.wire -> unit\n end\n\n module Urs : sig\n type t\n\n val read : int option -> string -> t option\n\n val write : bool option -> t -> string -> unit\n\n val create : int -> t\n end\n\n module Scalar_field : sig\n include Stable_v1\n\n val one : t\n end\n\n module Constraint_system : sig\n type t\n\n val get_primary_input_size : t -> int\n\n val get_prev_challenges : t -> int option\n\n val set_prev_challenges : t -> int -> unit\n\n val finalize_and_get_gates :\n t\n -> Gate_vector.t\n * Scalar_field.t Kimchi_types.lookup_table array\n * Scalar_field.t Kimchi_types.runtime_table_cfg array\n end\n\n module Index : sig\n type t\n\n (** [create\n gates\n nb_public\n runtime_tables_cfg\n nb_prev_challanges\n srs] *)\n val create :\n Gate_vector.t\n -> int\n -> Scalar_field.t Kimchi_types.lookup_table array\n -> Scalar_field.t Kimchi_types.runtime_table_cfg array\n -> int\n -> Urs.t\n -> t\n end\n\n module Curve : sig\n module Base_field : sig\n type t\n end\n\n module Affine : sig\n type t = Base_field.t * Base_field.t\n end\n end\n\n module Poly_comm : sig\n module Backend : sig\n type t\n end\n\n type t = Curve.Base_field.t Poly_comm0.t\n\n val of_backend_without_degree_bound : Backend.t -> t\n end\n\n module Verifier_index : sig\n type t =\n ( Scalar_field.t\n , Urs.t\n , Poly_comm.Backend.t )\n Kimchi_types.VerifierIndex.verifier_index\n\n val create : Index.t -> t\n end\nend\n\nmodule Make (Inputs : Inputs_intf) = struct\n open Core_kernel\n\n type t = { index : Inputs.Index.t; cs : Inputs.Constraint_system.t }\n\n let name =\n sprintf \"%s_%d_v4\" Inputs.name (Pickles_types.Nat.to_int Inputs.Rounds.n)\n\n let set_urs_info, load_urs =\n let urs_info = Set_once.create () in\n let urs = ref None in\n let degree = 1 lsl Pickles_types.Nat.to_int Inputs.Rounds.n in\n let set_urs_info specs = Set_once.set_exn urs_info Lexing.dummy_pos specs in\n let load () =\n match !urs with\n | Some urs ->\n urs\n | None ->\n let specs =\n match Set_once.get urs_info with\n | None ->\n failwith \"Dlog_based.urs: Info not set\"\n | Some t ->\n t\n in\n let store =\n Key_cache.Sync.Disk_storable.simple\n (fun () -> name)\n (fun () ~path ->\n Or_error.try_with_join (fun () ->\n match Inputs.Urs.read None path with\n | Some urs ->\n Ok urs\n | None ->\n Or_error.errorf\n \"Could not read the URS from disk; its format did \\\n not match the expected format\" ) )\n (fun _ urs path ->\n Or_error.try_with (fun () -> Inputs.Urs.write None urs path) )\n in\n let u =\n match Key_cache.Sync.read specs store () with\n | Ok (u, _) ->\n u\n | Error _e ->\n let urs = Inputs.Urs.create degree in\n let (_ : (unit, Error.t) Result.t) =\n Key_cache.Sync.write\n (List.filter specs ~f:(function\n | On_disk _ ->\n true\n | S3 _ ->\n false ) )\n store () urs\n in\n urs\n in\n urs := Some u ;\n u\n in\n (set_urs_info, load)\n\n let create ~prev_challenges cs =\n let gates, fixed_lookup_tables, runtime_table_cfgs =\n Inputs.Constraint_system.finalize_and_get_gates cs\n in\n let public_input_size =\n Inputs.Constraint_system.get_primary_input_size cs\n in\n let prev_challenges =\n match Inputs.Constraint_system.get_prev_challenges cs with\n | None ->\n Inputs.Constraint_system.set_prev_challenges cs prev_challenges ;\n prev_challenges\n | Some prev_challenges' ->\n assert (prev_challenges = prev_challenges') ;\n prev_challenges'\n in\n let index =\n Inputs.Index.create gates public_input_size fixed_lookup_tables\n runtime_table_cfgs prev_challenges (load_urs ())\n in\n { index; cs }\n\n let vk t = Inputs.Verifier_index.create t.index\n\n let pk t = t\n\n let array_to_vector a = Pickles_types.Vector.of_list (Array.to_list a)\n\n (** does this convert a backend.verifier_index to a pickles_types.verifier_index? *)\n let vk_commitments (t : Inputs.Verifier_index.t) :\n Inputs.Curve.Affine.t Pickles_types.Plonk_verification_key_evals.t =\n let g c : Inputs.Curve.Affine.t =\n match Inputs.Poly_comm.of_backend_without_degree_bound c with\n | `Without_degree_bound x ->\n x.(0)\n | `With_degree_bound _ ->\n assert false\n in\n { sigma_comm =\n Pickles_types.Vector.init Pickles_types.Plonk_types.Permuts.n\n ~f:(fun i -> g t.evals.sigma_comm.(i))\n ; coefficients_comm =\n Pickles_types.Vector.init Pickles_types.Plonk_types.Columns.n\n ~f:(fun i -> g t.evals.coefficients_comm.(i))\n ; generic_comm = g t.evals.generic_comm\n ; psm_comm = g t.evals.psm_comm\n ; complete_add_comm = g t.evals.complete_add_comm\n ; mul_comm = g t.evals.mul_comm\n ; emul_comm = g t.evals.emul_comm\n ; endomul_scalar_comm = g t.evals.endomul_scalar_comm\n }\n\n let full_vk_commitments (t : Inputs.Verifier_index.t) :\n ( Inputs.Curve.Affine.t\n , Inputs.Curve.Affine.t option )\n Pickles_types.Plonk_verification_key_evals.Step.t =\n let g c : Inputs.Curve.Affine.t =\n match Inputs.Poly_comm.of_backend_without_degree_bound c with\n | `Without_degree_bound x ->\n x.(0)\n | `With_degree_bound _ ->\n assert false\n in\n let lookup f =\n let open Option.Let_syntax in\n let%bind l = t.lookup_index in\n f l >>| g\n in\n { sigma_comm =\n Pickles_types.Vector.init Pickles_types.Plonk_types.Permuts.n\n ~f:(fun i -> g t.evals.sigma_comm.(i))\n ; coefficients_comm =\n Pickles_types.Vector.init Pickles_types.Plonk_types.Columns.n\n ~f:(fun i -> g t.evals.coefficients_comm.(i))\n ; generic_comm = g t.evals.generic_comm\n ; psm_comm = g t.evals.psm_comm\n ; complete_add_comm = g t.evals.complete_add_comm\n ; mul_comm = g t.evals.mul_comm\n ; emul_comm = g t.evals.emul_comm\n ; endomul_scalar_comm = g t.evals.endomul_scalar_comm\n ; xor_comm = Option.map ~f:g t.evals.xor_comm\n ; range_check0_comm = Option.map ~f:g t.evals.range_check0_comm\n ; range_check1_comm = Option.map ~f:g t.evals.range_check1_comm\n ; foreign_field_add_comm = Option.map ~f:g t.evals.foreign_field_add_comm\n ; foreign_field_mul_comm = Option.map ~f:g t.evals.foreign_field_mul_comm\n ; rot_comm = Option.map ~f:g t.evals.rot_comm\n ; lookup_table_comm =\n Pickles_types.Vector.init\n Pickles_types.Plonk_types.Lookup_sorted_minus_1.n ~f:(fun i ->\n lookup (fun l -> Option.try_with (fun () -> l.lookup_table.(i))) )\n ; lookup_table_ids = lookup (fun l -> l.table_ids)\n ; runtime_tables_selector = lookup (fun l -> l.runtime_tables_selector)\n ; lookup_selector_lookup = lookup (fun l -> l.lookup_selectors.lookup)\n ; lookup_selector_xor = lookup (fun l -> l.lookup_selectors.xor)\n ; lookup_selector_range_check =\n lookup (fun l -> l.lookup_selectors.range_check)\n ; lookup_selector_ffmul = lookup (fun l -> l.lookup_selectors.ffmul)\n }\nend\n","module Bigint = Bigint\nmodule Field = Field\nmodule Curve = Curve\nmodule Poly_comm = Poly_comm\nmodule Plonk_constraint_system = Plonk_constraint_system\nmodule Dlog_plonk_based_keypair = Dlog_plonk_based_keypair\nmodule Constants = Constants\nmodule Plonk_dlog_proof = Plonk_dlog_proof\nmodule Plonk_dlog_oracles = Plonk_dlog_oracles\nmodule Scalar_challenge = Scalar_challenge\nmodule Endoscale_round = Endoscale_round\nmodule Scale_round = Scale_round\nmodule Endoscale_scalar_round = Endoscale_scalar_round\nmodule Intf = Intf\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\nmodule Backend = Kimchi_backend.Pasta.Vesta_based_plonk\nmodule Impl = Pickles.Impls.Step\nmodule Field = Impl.Field\nmodule Boolean = Impl.Boolean\nmodule As_prover = Impl.As_prover\nmodule Typ = Impl.Typ\n\n(* light-weight wrapper around snarky-ml core *)\n\nlet typ (size_in_fields : int) = Typ.array ~length:size_in_fields Field.typ\n\nlet exists (size_in_fields : int) (compute : unit -> Field.Constant.t array) =\n Impl.exists (typ size_in_fields) ~compute\n\nlet exists_var (compute : unit -> Field.Constant.t) =\n Impl.exists Field.typ ~compute\n\nmodule Run = struct\n let as_prover = Impl.as_prover\n\n let in_prover_block () = As_prover.in_prover_block () |> Js.bool\n\n let run_and_check (f : unit -> unit) =\n try\n Impl.run_and_check_exn (fun () ->\n f () ;\n fun () -> () )\n with exn -> Util.raise_exn exn\n\n let run_unchecked (f : unit -> unit) =\n try\n Impl.run_and_check_exn (fun () ->\n Snarky_backendless.Snark0.set_eval_constraints false ;\n f () ;\n Snarky_backendless.Snark0.set_eval_constraints true ;\n fun () -> () )\n with exn -> Util.raise_exn exn\n\n let constraint_system (main : unit -> unit) =\n let cs =\n Impl.constraint_system ~input_typ:Impl.Typ.unit ~return_typ:Impl.Typ.unit\n (fun () -> main)\n in\n object%js\n val rows = Backend.R1CS_constraint_system.get_rows_len cs\n\n val digest =\n Backend.R1CS_constraint_system.digest cs |> Md5.to_hex |> Js.string\n\n val json =\n Backend.R1CS_constraint_system.to_json cs\n |> Js.string |> Util.json_parse\n end\nend\n\nmodule Field' = struct\n (** add x, y to get a new AST node Add(x, y); handles if x, y are constants *)\n let add x y = Field.add x y\n\n (** scale x by a constant to get a new AST node Scale(c, x); handles if x is a constant; handles c=0,1 *)\n let scale c x = Field.scale x c\n\n (** witnesses z = x*y and constrains it with [assert_r1cs]; handles constants *)\n let mul x y = Field.mul x y\n\n (** evaluates a CVar by unfolding the AST and reading Vars from a list of public input + aux values *)\n let read_var (x : Field.t) = As_prover.read_var x\n\n (** x === y without handling of constants *)\n let assert_equal x y = Impl.assert_ (Impl.Constraint.equal x y)\n\n (** x*y === z without handling of constants *)\n let assert_mul x y z = Impl.assert_ (Impl.Constraint.r1cs x y z)\n\n (** x*x === y without handling of constants *)\n let assert_square x y = Impl.assert_ (Impl.Constraint.square x y)\n\n (** x*x === x without handling of constants *)\n let assert_boolean x = Impl.assert_ (Impl.Constraint.boolean x)\n\n (** check x < y and x <= y.\n this is used in all comparisons, including with assert *)\n let compare (bit_length : int) x y =\n let ({ less; less_or_equal } : Field.comparison_result) =\n Field.compare ~bit_length x y\n in\n (less, less_or_equal)\n\n let to_bits (length : int) x =\n Field.choose_preimage_var ~length x |> Array.of_list\n\n let from_bits bits = Array.to_list bits |> Field.project\n\n (** returns x truncated to the lowest [16 * length_div_16] bits\n => can be used to assert that x fits in [16 * length_div_16] bits.\n\n more efficient than [to_bits] because it uses the [EC_endoscalar] gate;\n does 16 bits per row (vs 1 bits per row that you can do with generic gates).\n *)\n let truncate_to_bits16 (length_div_16 : int) x =\n let _a, _b, x0 =\n Pickles.Scalar_challenge.to_field_checked' ~num_bits:(length_div_16 * 16)\n (module Impl)\n { inner = x }\n in\n x0\n\n (* can be implemented with Field.to_constant_and_terms *)\n let seal x = Pickles.Util.seal (module Impl) x\n\n let to_constant_and_terms x = Field.to_constant_and_terms x\nend\n\nmodule Bool = struct\n let not x = Boolean.not x\n\n let and_ x y = Boolean.(x &&& y)\n\n let or_ x y = Boolean.(x ||| y)\n\n let assert_equal x y = Boolean.Assert.(x = y)\n\n let equals x y = Boolean.equal x y\nend\n\nmodule Group = struct\n let ec_add p1 p2 p3 inf same_x slope inf_z x21_inv =\n let open Impl in\n with_label \"Elliptic Curve Addition\" (fun () ->\n assert_\n { annotation = Some __LOC__\n ; basic =\n Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint.T\n (EC_add_complete\n { p1; p2; p3; inf; same_x; slope; inf_z; x21_inv } )\n } ;\n p3 )\n\n let scale p (scalar_bits : Boolean.var array) =\n Pickles.Step_main_inputs.Ops.scale_fast_msb_bits p\n (Shifted_value scalar_bits)\nend\n\nmodule Circuit = struct\n module Main = struct\n let of_js (main : Field.t array -> unit) =\n let main' public_input () = main public_input in\n main'\n end\n\n let compile main public_input_size =\n let input_typ = typ public_input_size in\n let return_typ = Impl.Typ.unit in\n let cs = Impl.constraint_system ~input_typ ~return_typ (Main.of_js main) in\n Impl.Keypair.generate ~prev_challenges:0 cs\n\n let prove main public_input_size public_input keypair =\n let pk = Impl.Keypair.pk keypair in\n let input_typ = typ public_input_size in\n let return_typ = Impl.Typ.unit in\n Impl.generate_witness_conv ~input_typ ~return_typ\n ~f:(fun { Impl.Proof_inputs.auxiliary_inputs; public_inputs } () ->\n Backend.Proof.create pk ~auxiliary:auxiliary_inputs\n ~primary:public_inputs )\n (Main.of_js main) public_input\n\n let verify public_input proof vk =\n let public_input_vec = Backend.Field.Vector.create () in\n Array.iter public_input ~f:(fun x ->\n Backend.Field.Vector.emplace_back public_input_vec x ) ;\n Backend.Proof.verify proof vk public_input_vec |> Js.bool\n\n module Keypair = struct\n let get_vk t = Impl.Keypair.vk t\n\n external prover_to_json :\n Kimchi_bindings.Protocol.Index.Fp.t -> Js.js_string Js.t\n = \"prover_to_json\"\n\n let get_cs_json t =\n (Impl.Keypair.pk t).index |> prover_to_json |> Util.json_parse\n end\nend\n\nmodule Poseidon = struct\n let update (state : Field.t Random_oracle.State.t) (input : Field.t array) :\n Field.t Random_oracle.State.t =\n Random_oracle.Checked.update ~state input\n\n let hash_to_group (xs : Field.t array) =\n let input = Random_oracle.Checked.hash xs in\n Snark_params.Group_map.Checked.to_group input\n\n (* sponge *)\n\n let to_unchecked (x : Field.t) =\n match x with Constant y -> y | y -> As_prover.read_var y\n\n module Poseidon_sponge_checked =\n Sponge.Make_sponge (Pickles.Step_main_inputs.Sponge.Permutation)\n module Poseidon_sponge =\n Sponge.Make_sponge (Sponge.Poseidon (Pickles.Tick_field_sponge.Inputs))\n\n let sponge_params = Kimchi_pasta_basic.poseidon_params_fp\n\n let sponge_params_checked = Sponge.Params.map sponge_params ~f:Field.constant\n\n type sponge =\n | Checked of Poseidon_sponge_checked.t\n | Unchecked of Poseidon_sponge.t\n\n (* returns a \"sponge\" that stays opaque to JS *)\n let sponge_create (is_checked : bool Js.t) : sponge =\n if Js.to_bool is_checked then\n Checked (Poseidon_sponge_checked.create ?init:None sponge_params_checked)\n else Unchecked (Poseidon_sponge.create ?init:None sponge_params)\n\n let sponge_absorb (sponge : sponge) (field : Field.t) : unit =\n match sponge with\n | Checked s ->\n Poseidon_sponge_checked.absorb s field\n | Unchecked s ->\n Poseidon_sponge.absorb s @@ to_unchecked field\n\n let sponge_squeeze (sponge : sponge) : Field.t =\n match sponge with\n | Checked s ->\n Poseidon_sponge_checked.squeeze s\n | Unchecked s ->\n Poseidon_sponge.squeeze s |> Impl.Field.constant\nend\n\nlet snarky =\n object%js\n method exists = exists\n\n method existsVar = exists_var\n\n val run =\n let open Run in\n object%js\n method asProver = as_prover\n\n val inProverBlock = in_prover_block\n\n method runAndCheck = run_and_check\n\n method runUnchecked = run_unchecked\n\n method constraintSystem = constraint_system\n end\n\n val field =\n let open Field' in\n object%js\n method add = add\n\n method scale = scale\n\n method mul = mul\n\n method readVar = read_var\n\n method assertEqual = assert_equal\n\n method assertMul = assert_mul\n\n method assertSquare = assert_square\n\n method assertBoolean = assert_boolean\n\n method compare = compare\n\n method toBits = to_bits\n\n method fromBits = from_bits\n\n method truncateToBits16 = truncate_to_bits16\n\n method seal = seal\n\n method toConstantAndTerms = to_constant_and_terms\n end\n\n val bool =\n object%js\n method not = Bool.not\n\n method and_ = Bool.and_\n\n method or_ = Bool.or_\n\n method assertEqual = Bool.assert_equal\n\n method equals = Bool.equals\n end\n\n val group =\n object%js\n method ecadd = Group.ec_add\n\n method scale = Group.scale\n end\n\n val circuit =\n object%js\n method compile = Circuit.compile\n\n method prove = Circuit.prove\n\n method verify = Circuit.verify\n\n val keypair =\n object%js\n method getVerificationKey = Circuit.Keypair.get_vk\n\n method getConstraintSystemJSON = Circuit.Keypair.get_cs_json\n end\n end\n\n val poseidon =\n object%js\n method update = Poseidon.update\n\n method hashToGroup = Poseidon.hash_to_group\n\n val sponge =\n object%js\n method create = Poseidon.sponge_create\n\n method absorb = Poseidon.sponge_absorb\n\n method squeeze = Poseidon.sponge_squeeze\n end\n end\n end\n","open Kimchi_backend_common\nopen Kimchi_pasta_basic\n\ninclude\n Plonk_constraint_system.Make (Fp) (Kimchi_bindings.Protocol.Gates.Vector.Fp)\n (struct\n let params = poseidon_params_fp\n end)\n","open Kimchi_backend_common\nopen Kimchi_pasta_basic\n\ninclude\n Plonk_constraint_system.Make (Fq) (Kimchi_bindings.Protocol.Gates.Vector.Fq)\n (struct\n let params = poseidon_params_fq\n end)\n","module Basic = Kimchi_pasta_basic\n\nmodule Pallas_based_plonk = struct\n module Field = Pallas_based_plonk.Field\n module Curve = Pallas_based_plonk.Curve\n module Bigint = Pallas_based_plonk.Bigint\n\n let field_size = Pallas_based_plonk.field_size\n\n module Verification_key = Pallas_based_plonk.Verification_key\n module R1CS_constraint_system = Pallas_based_plonk.R1CS_constraint_system\n module Rounds_vector = Pallas_based_plonk.Rounds_vector\n module Rounds = Pallas_based_plonk.Rounds\n module Keypair = Pallas_based_plonk.Keypair\n module Proof = Pallas_based_plonk.Proof\n module Proving_key = Pallas_based_plonk.Proving_key\n module Oracles = Pallas_based_plonk.Oracles\nend\n\nmodule Vesta_based_plonk = struct\n module Field = Vesta_based_plonk.Field\n module Curve = Vesta_based_plonk.Curve\n module Bigint = Vesta_based_plonk.Bigint\n\n let field_size = Vesta_based_plonk.field_size\n\n module Verification_key = Vesta_based_plonk.Verification_key\n module R1CS_constraint_system = Vesta_based_plonk.R1CS_constraint_system\n module Rounds_vector = Vesta_based_plonk.Rounds_vector\n module Rounds = Vesta_based_plonk.Rounds\n module Keypair = Vesta_based_plonk.Keypair\n module Proof = Vesta_based_plonk.Proof\n module Proving_key = Vesta_based_plonk.Proving_key\n module Oracles = Vesta_based_plonk.Oracles\nend\n\nmodule Pasta = struct\n module Rounds = Pasta.Rounds\n module Bigint256 = Pasta.Bigint256\n module Fp = Pasta.Fp\n module Fq = Pasta.Fq\n module Vesta = Pasta.Vesta\n module Pallas = Pasta.Pallas\nend\n","open Utils\n\nmodule Types = struct\n module type S = V1S0\nend\n\nmodule type Concrete = Types.S with type V1.t = Unsigned.UInt64.t\n\nmodule M = struct\n module V1 = struct\n type t = Unsigned.UInt64.t\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\n(** We first define a [Types] module, with the expected final signature of this\n module (hidden types should be hidden here) *)\nmodule Types = struct\n module type S = sig\n module Fee : V1S0\n\n module Amount : V1S0\n\n module Balance : V1S0\n end\nend\n\n(** We define a module type [Concrete], where we replace hidden types in\n {!Types.S} by their actual definition. This module will not be exported. *)\nmodule type Concrete =\n Types.S\n with type Fee.V1.t = Unsigned.UInt64.t\n and type Amount.V1.t = Unsigned.UInt64.t\n and type Balance.V1.t = Unsigned.UInt64.t\n\n(** Then we define the actual module [M] with its type definitions. It must be\n compatible with {!Concrete} *)\nmodule M = struct\n module Fee = struct\n module V1 = struct\n type t = Unsigned.UInt64.t\n end\n end\n\n module Amount = struct\n module V1 = struct\n type t = Unsigned.UInt64.t\n end\n end\n\n module Balance = struct\n module V1 = struct\n type t = Amount.V1.t\n end\n end\nend\n\n(** [Local_sig] is the type of functors which receive a {!Types.S} module and\n return a complete module signature (with operations etc.) based on these\n types. It will be expected to be given by the implementation module. *)\nmodule type Local_sig = Signature(Types).S\n\n(** To make a full module, the implementation module will have to use [Make] and\n provide: (i) a {!Local_sig} functor to know the final signature of the\n module and (ii) a functor which takes the concrete types defined here and\n make the actual full module, adding type equalities where needed. *)\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n\n(** Finally, we include our module to make the types available to everyone (they\n will be hidden in the MLI *)\ninclude M\n","open Utils\n\nmodule Branch_data = struct\n module Types = struct\n module type S = sig\n module Domain_log2 : V1S0\n\n module V1 : sig\n type t =\n { proofs_verified : Pickles_base.Proofs_verified.V1.t\n ; domain_log2 : Domain_log2.V1.t\n }\n end\n end\n end\n\n module type Concrete = Types.S with type Domain_log2.V1.t = char\n\n module M = struct\n module Domain_log2 = struct\n module V1 = struct\n type t = char\n end\n end\n\n module V1 = struct\n type t =\n { proofs_verified : Pickles_base.Proofs_verified.V1.t\n ; domain_log2 : Domain_log2.V1.t\n }\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Wrap = struct\n module Proof_state = struct\n module Messages_for_next_wrap_proof = struct\n module V1 = struct\n type ('g1, 'bulletproof_challenges) t =\n { challenge_polynomial_commitment : 'g1\n ; old_bulletproof_challenges : 'bulletproof_challenges\n }\n end\n end\n\n module Deferred_values = struct\n module Plonk = struct\n module Minimal = struct\n module V1 = struct\n type ('challenge, 'scalar_challenge, 'bool) t =\n { alpha : 'scalar_challenge\n ; beta : 'challenge\n ; gamma : 'challenge\n ; zeta : 'scalar_challenge\n ; joint_combiner : 'scalar_challenge option\n ; feature_flags :\n 'bool Pickles_types.Plonk_types.Features.Stable.V1.t\n }\n end\n end\n end\n\n module V1 = struct\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bulletproof_challenges\n , 'branch_data )\n t =\n { plonk : 'plonk\n ; combined_inner_product : 'fp\n ; b : 'fp\n ; xi : 'scalar_challenge\n ; bulletproof_challenges : 'bulletproof_challenges\n ; branch_data : 'branch_data\n }\n end\n\n module Minimal = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'bulletproof_challenges\n , 'branch_data )\n t =\n { plonk : ('challenge, 'scalar_challenge, 'bool) Plonk.Minimal.V1.t\n ; bulletproof_challenges : 'bulletproof_challenges\n ; branch_data : 'branch_data\n }\n end\n end\n end\n\n module V1 = struct\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n t =\n { deferred_values :\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'bp_chals\n , 'index )\n Deferred_values.V1.t\n ; sponge_digest_before_evaluations : 'digest\n ; messages_for_next_wrap_proof : 'messages_for_next_wrap_proof\n }\n end\n\n module Minimal = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n t =\n { deferred_values :\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'bp_chals\n , 'index )\n Deferred_values.Minimal.V1.t\n ; sponge_digest_before_evaluations : 'digest\n ; messages_for_next_wrap_proof : 'messages_for_next_wrap_proof\n }\n end\n end\n end\n\n module Statement = struct\n module V1 = struct\n type ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n t =\n { proof_state :\n ( 'plonk\n , 'scalar_challenge\n , 'fp\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Proof_state.V1.t\n ; messages_for_next_step_proof : 'messages_for_next_step_proof\n }\n end\n\n module Minimal = struct\n module V1 = struct\n type ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'messages_for_next_step_proof\n , 'bp_chals\n , 'index )\n t =\n { proof_state :\n ( 'challenge\n , 'scalar_challenge\n , 'fp\n , 'bool\n , 'messages_for_next_wrap_proof\n , 'digest\n , 'bp_chals\n , 'index )\n Proof_state.Minimal.V1.t\n ; messages_for_next_step_proof : 'messages_for_next_step_proof\n }\n end\n end\n end\nend\n","open Utils\n\nmodule M = struct\n module Backend = struct\n module Tick = struct\n module Field = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\n end\n end\n end\n\n module Wrap_wire_proof = struct\n module Columns_vec = Pickles_types.Vector.Vector_15\n module Coefficients_vec = Pickles_types.Vector.Vector_15\n module Quotient_polynomial_vec = Pickles_types.Vector.Vector_7\n module Permuts_minus_1_vec = Pickles_types.Vector.Vector_6\n\n module Commitments = struct\n module V1 = struct\n type t =\n { w_comm :\n (Pasta_bindings.Fp.t * Pasta_bindings.Fp.t)\n Columns_vec.Stable.V1.t\n ; z_comm : Pasta_bindings.Fp.t * Pasta_bindings.Fp.t\n ; t_comm :\n (Pasta_bindings.Fp.t * Pasta_bindings.Fp.t)\n Quotient_polynomial_vec.Stable.V1.t\n }\n end\n end\n\n module Evaluations = struct\n module V1 = struct\n type t =\n { w :\n (Pasta_bindings.Fq.t * Pasta_bindings.Fq.t)\n Columns_vec.Stable.V1.t\n ; coefficients :\n (Pasta_bindings.Fq.t * Pasta_bindings.Fq.t)\n Columns_vec.Stable.V1.t\n ; z : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; s :\n (Pasta_bindings.Fq.t * Pasta_bindings.Fq.t)\n Permuts_minus_1_vec.Stable.V1.t\n ; generic_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; poseidon_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; complete_add_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; mul_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; emul_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n ; endomul_scalar_selector : Pasta_bindings.Fq.t * Pasta_bindings.Fq.t\n }\n end\n end\n\n module V1 = struct\n type t =\n { commitments : Commitments.V1.t\n ; evaluations : Evaluations.V1.t\n ; ft_eval1 : Pasta_bindings.Fq.t\n ; bulletproof :\n ( Pasta_bindings.Fp.t * Pasta_bindings.Fp.t\n , Pasta_bindings.Fq.t )\n Pickles_types.Plonk_types.Openings.Bulletproof.Stable.V1.t\n }\n end\n end\n\n module Proof = struct\n type challenge_constant =\n Pickles_limb_vector.Constant.Make(Pickles_types.Nat.N2).t\n\n type tock_affine = Pasta_bindings.Fp.t * Pasta_bindings.Fp.t\n\n type 'a step_bp_vec = 'a Kimchi_pasta.Basic.Rounds.Step_vector.Stable.V1.t\n\n module Base = struct\n module Wrap = struct\n module V2 = struct\n type digest_constant =\n Pickles_limb_vector.Constant.Make(Pickles_types.Nat.N4).t\n\n type ('messages_for_next_wrap_proof, 'messages_for_next_step_proof) t =\n { statement :\n ( challenge_constant\n , challenge_constant Kimchi_types.scalar_challenge\n , Snark_params.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool\n , 'messages_for_next_wrap_proof\n , digest_constant\n , 'messages_for_next_step_proof\n , challenge_constant Kimchi_types.scalar_challenge\n Pickles_bulletproof_challenge.V1.t\n step_bp_vec\n , Pickles_composition_types.Branch_data.V1.t )\n Pickles_composition_types.Wrap.Statement.Minimal.V1.t\n ; prev_evals :\n ( Snark_params.Tick.Field.t\n , Snark_params.Tick.Field.t array )\n Pickles_types.Plonk_types.All_evals.t\n ; proof : Wrap_wire_proof.V1.t\n }\n end\n end\n end\n\n type ('s, 'mlmb, _) with_data =\n | T :\n ( 'mlmb Pickles_reduced_messages_for_next_proof_over_same_field.Wrap.t\n , ( 's\n , (tock_affine, 'most_recent_width) Pickles_types.Vector.t\n , ( challenge_constant Kimchi_types.scalar_challenge\n Pickles_bulletproof_challenge.V1.t\n step_bp_vec\n , 'most_recent_width )\n Pickles_types.Vector.t )\n Pickles_reduced_messages_for_next_proof_over_same_field.Step.V1.t\n )\n Base.Wrap.V2.t\n -> ('s, 'mlmb, _) with_data\n\n type ('max_width, 'mlmb) t = (unit, 'mlmb, 'max_width) with_data\n\n module Proofs_verified_2 = struct\n module V2 = struct\n type nonrec t = (Pickles_types.Nat.N2.n, Pickles_types.Nat.N2.n) t\n end\n end\n end\n\n module Side_loaded = struct\n module Verification_key = struct\n module Vk = struct\n type t =\n ( Pasta_bindings.Fq.t\n , Kimchi_bindings.Protocol.SRS.Fq.t\n , Pasta_bindings.Fp.t Kimchi_types.or_infinity Kimchi_types.poly_comm\n )\n Kimchi_types.VerifierIndex.verifier_index\n end\n\n type tock_curve_affine =\n Snark_params.Tick.Field.t * Snark_params.Tick.Field.t\n\n module V2 = struct\n type t =\n ( tock_curve_affine\n , Pickles_base.Proofs_verified.V1.t\n , Vk.t )\n Pickles_base.Side_loaded_verification_key.Poly.V2.t\n end\n\n module Max_width = Pickles_types.Nat.N2\n end\n\n module Proof = struct\n module V2 = struct\n type t =\n (Verification_key.Max_width.n, Verification_key.Max_width.n) Proof.t\n end\n end\n end\nend\n\nmodule Types = struct\n module type S = sig\n module Proof : sig\n type ('a, 'b) t\n\n module Proofs_verified_2 : sig\n module V2 : sig\n type nonrec t = (Pickles_types.Nat.N2.n, Pickles_types.Nat.N2.n) t\n end\n end\n end\n\n module Side_loaded : sig\n module Verification_key : sig\n module Max_width : module type of Pickles_types.Nat.N2\n\n module V2 : sig\n type t\n end\n end\n\n module Proof : sig\n module V2 : sig\n type t =\n (Verification_key.Max_width.n, Verification_key.Max_width.n) Proof.t\n end\n end\n end\n\n module Backend : sig\n module Tick : sig\n module Field : sig\n module V1 : sig\n type t = Pasta_bindings.Fp.t\n end\n end\n end\n end\n end\nend\n\nmodule Concrete_ = M\n\nmodule type Concrete =\n Types.S\n with type Side_loaded.Verification_key.V2.t =\n M.Side_loaded.Verification_key.V2.t\n and type Backend.Tick.Field.V1.t = Pasta_bindings.Fp.t\n and type ('a, 'b) Proof.t = ('a, 'b) M.Proof.t\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","[%%import \"/src/config.mlh\"]\n\nopen Utils\n\nmodule Types = struct\n module type S = sig\n module Digest : V1S0\n\n include V2S0\n end\nend\n\n[%%ifdef consensus_mechanism]\n\nmodule type Concrete =\n Types.S\n with type Digest.V1.t = Pickles.Backend.Tick.Field.V1.t\n and type V2.t =\n Public_key.Compressed.V1.t * Pickles.Backend.Tick.Field.V1.t\n\n[%%else]\n\nmodule type Concrete =\n Types.S\n with type Digest.V1.t = Snark_params.Tick.Field.t\n and type V2.t = Public_key.Compressed.V1.t * Snark_params.Tick.Field.V1.t\n\n[%%endif]\n\nmodule M = struct\n [%%ifdef consensus_mechanism]\n\n module Digest = struct\n module V1 = struct\n type t = Pickles.Backend.Tick.Field.V1.t\n end\n end\n\n module V2 = struct\n type t = Public_key.Compressed.V1.t * Pickles.Backend.Tick.Field.V1.t\n end\n\n [%%else]\n\n module Digest = struct\n module V1 = struct\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module V2 = struct\n type t = Public_key.Compressed.V1.t * Snark_params.Tick.Field.V1.t\n end\n\n [%%endif]\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Account_nonce = struct\n module Types = struct\n module type S = V1S0\n end\n\n module type Concrete = Types.S with type V1.t = Unsigned.UInt32.t\n\n module M = struct\n module V1 = struct\n type t = Unsigned.UInt32.t\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Global_slot_legacy = struct\n module Types = struct\n module type S = V1S0\n end\n\n module type Concrete = Types.S with type V1.t = Unsigned.UInt32.t\n\n module M = struct\n module V1 = struct\n type t = Unsigned.UInt32.t\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Global_slot_since_genesis = struct\n module Types = struct\n module type S = V1S0\n end\n\n type global_slot = Since_genesis of Unsigned.UInt32.t [@@unboxed]\n\n module type Concrete = Types.S with type V1.t = global_slot\n\n module M = struct\n module V1 = struct\n type t = global_slot\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Global_slot_since_hard_fork = struct\n module Types = struct\n module type S = V1S0\n end\n\n type global_slot = Since_hard_fork of Unsigned.UInt32.t [@@unboxed]\n\n module type Concrete = Types.S with type V1.t = global_slot\n\n module M = struct\n module V1 = struct\n type t = global_slot\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Global_slot_span = struct\n module Types = struct\n module type S = V1S0\n end\n\n type global_slot_span = Global_slot_span of Unsigned.UInt32.t [@@unboxed]\n\n module type Concrete = Types.S with type V1.t = global_slot_span\n\n module M = struct\n module V1 = struct\n type t = global_slot_span\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Length = struct\n module Types = struct\n module type S = V1S0\n end\n\n module type Concrete = Types.S with type V1.t = Unsigned.UInt32.t\n\n module M = struct\n module V1 = struct\n type t = Unsigned.UInt32.t\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n\nmodule Index = struct\n module Types = struct\n module type S = V1S0\n end\n\n module type Concrete = Types.S with type V1.t = Unsigned.UInt32.t\n\n module M = struct\n module V1 = struct\n type t = Unsigned.UInt32.t\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module V1 : sig\n type t = private Mina_base_zkapp_basic.F.V1.t\n end\n end\nend\n\nmodule type Concrete = sig\n module V1 : sig\n type t = Pasta_bindings.Fp.t\n end\nend\n\nmodule M = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module V1 : sig\n type t = private\n { receiver_pk : Public_key.Compressed.V1.t; fee : Currency.Fee.V1.t }\n end\n end\nend\n\nmodule type Concrete = sig\n module V1 : sig\n type t =\n { receiver_pk : Public_key.Compressed.V1.t; fee : Currency.Fee.V1.t }\n end\nend\n\nmodule M = struct\n module V1 = struct\n type t =\n { receiver_pk : Public_key.Compressed.V1.t; fee : Currency.Fee.V1.t }\n end\nend\n\nmodule type Local_sig = Utils.Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module V1 : sig\n type t = private\n { receiver : Public_key.Compressed.V1.t\n ; amount : Currency.Amount.V1.t\n ; fee_transfer : Mina_base_coinbase_fee_transfer.V1.t option\n }\n end\n end\nend\n\nmodule M = struct\n module V1 = struct\n type t =\n { receiver : Public_key.Compressed.V1.t\n ; amount : Currency.Amount.V1.t\n ; fee_transfer : Mina_base_coinbase_fee_transfer.V1.t option\n }\n end\nend\n\nmodule type Concrete = sig\n module V1 : sig\n type t =\n { receiver : Public_key.Compressed.V1.t\n ; amount : Currency.Amount.V1.t\n ; fee_transfer : Mina_base_coinbase_fee_transfer.V1.t option\n }\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module Single : sig\n module V2 : sig\n type t = private\n { receiver_pk : Public_key.Compressed.V1.t\n ; fee : Currency.Fee.V1.t\n ; fee_token : Mina_base_token_id.V2.t\n }\n end\n end\n\n module V2 : sig\n type t = private Single.V2.t One_or_two.V1.t\n end\n end\nend\n\nmodule M = struct\n module Single = struct\n module V2 = struct\n type t =\n { receiver_pk : Public_key.Compressed.V1.t\n ; fee : Currency.Fee.V1.t\n ; fee_token : Mina_base_token_id.V2.t\n }\n end\n end\n\n module V2 = struct\n type t = Single.V2.t One_or_two.V1.t\n end\nend\n\nmodule type Concrete = sig\n module Single : sig\n module V2 : sig\n type t =\n { receiver_pk : Public_key.Compressed.V1.t\n ; fee : Currency.Fee.V1.t\n ; fee_token : Mina_base_token_id.V2.t\n }\n end\n end\n\n module V2 : sig\n type t = Single.V2.t One_or_two.V1.t\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module State_stack : sig\n module V1 : sig\n type t\n end\n end\n\n module Stack_versioned : sig\n module V1 : sig\n type nonrec t\n end\n end\n\n module Hash_builder : sig\n module V1 : sig\n type t = private Snark_params.Tick.Field.t\n end\n end\n\n module Hash_versioned : sig\n module V1 : sig\n type t = Hash_builder.V1.t\n end\n end\n end\nend\n\nmodule type Concrete = sig\n module Poly : sig\n type ('tree, 'stack_id) t =\n { tree : 'tree; pos_list : 'stack_id list; new_pos : 'stack_id }\n end\n\n module Stack_hash : sig\n module V1 : sig\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module State_stack : sig\n module Poly : sig\n module V1 : sig\n type 'stack_hash t = { init : 'stack_hash; curr : 'stack_hash }\n end\n end\n\n module V1 : sig\n type t = Stack_hash.V1.t Poly.V1.t\n end\n end\n\n module Coinbase_stack : sig\n module V1 : sig\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module Stack_versioned : sig\n module Poly : sig\n module V1 : sig\n type ('data_stack, 'state_stack) t =\n { data : 'data_stack; state : 'state_stack }\n end\n end\n\n module V1 : sig\n type t = (Coinbase_stack.V1.t, State_stack.V1.t) Poly.V1.t\n end\n end\n\n module Hash_builder : sig\n module V1 : sig\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module Hash_versioned : sig\n module V1 : sig\n type t = Hash_builder.V1.t\n end\n end\nend\n\nmodule M = struct\n module Poly = struct\n type ('tree, 'stack_id) t =\n { tree : 'tree; pos_list : 'stack_id list; new_pos : 'stack_id }\n end\n\n module Stack_hash = struct\n module V1 = struct\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module State_stack = struct\n module Poly = struct\n module V1 = struct\n type 'stack_hash t = { init : 'stack_hash; curr : 'stack_hash }\n end\n end\n\n module V1 = struct\n type t = Stack_hash.V1.t Poly.V1.t\n end\n end\n\n module Coinbase_stack = struct\n module V1 = struct\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module Stack_versioned = struct\n module Poly = struct\n module V1 = struct\n type ('data_stack, 'state_stack) t =\n { data : 'data_stack; state : 'state_stack }\n end\n end\n\n module V1 = struct\n type t = (Coinbase_stack.V1.t, State_stack.V1.t) Poly.V1.t\n end\n end\n\n module Hash_builder = struct\n module V1 = struct\n type t = Snark_params.Tick.Field.t\n end\n end\n\n module Hash_versioned = struct\n module V1 = struct\n type t = Hash_builder.V1.t\n end\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = V1S0\nend\n\nmodule type Concrete = Types.S with type V1.t = string\n\nmodule M = struct\n module V1 = struct\n type t = string\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Poly = struct\n module V1 = struct\n type ('payload, 'pk, 'signature) t =\n { payload : 'payload; signer : 'pk; signature : 'signature }\n end\nend\n\nmodule V1 = struct\n type t =\n ( Mina_base_signed_command_payload.V1.t\n , Public_key.V1.t\n , Mina_base_signature.V1.t )\n Poly.V1.t\nend\n\nmodule V2 = struct\n type t =\n ( Mina_base_signed_command_payload.V2.t\n , Public_key.V1.t\n , Mina_base_signature.V1.t )\n Poly.V1.t\nend\n\nmodule Types = struct\n module type S = sig\n module With_valid_signature : V2S0 with type V2.t = private V2.t\n end\nend\n\nmodule type Concrete = Types.S with type With_valid_signature.V2.t = V2.t\n\nmodule M = struct\n module With_valid_signature = struct\n module V2 = struct\n type t = V2.t\n end\n end\nend\n\nmodule type Local_sig = Utils.Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module Digest : V1S0\n end\nend\n\nmodule type Concrete = Types.S with type Digest.V1.t = string\n\nmodule M = struct\n module Digest = struct\n module V1 = struct\n type t = string\n end\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Digest = struct\n module Types = struct\n module type S = sig\n module V1 : sig\n type t = private Mina_base_zkapp_basic.F.V1.t\n end\n end\n end\n\n module type Concrete = sig\n module V1 : sig\n type t = Pasta_bindings.Fp.t\n end\n end\n\n module M = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\n end\n\n module type Local_sig = Signature(Types).S\n\n module Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\n include M\nend\n","open Utils\n\nmodule Types = struct\n module type S = sig\n module Aux_hash : sig\n type t\n\n module V1 : sig\n type nonrec t = t\n end\n end\n\n module Pending_coinbase_aux : V1S0\n\n module V1 : S0\n end\nend\n\nmodule type Concrete = sig\n module Aux_hash : sig\n type t = string\n\n module V1 : sig\n type nonrec t = t\n end\n end\n\n module Pending_coinbase_aux : sig\n module V1 : sig\n type t = string\n end\n end\n\n module Non_snark : sig\n module V1 : sig\n type t =\n { ledger_hash : Mina_base_ledger_hash.V1.t\n ; aux_hash : Aux_hash.V1.t\n ; pending_coinbase_aux : Pending_coinbase_aux.V1.t\n }\n end\n end\n\n module Poly : sig\n module V1 : sig\n type ('non_snark, 'pending_coinbase_hash) t =\n { non_snark : 'non_snark\n ; pending_coinbase_hash : 'pending_coinbase_hash\n }\n end\n end\n\n module V1 : sig\n type t =\n (Non_snark.V1.t, Mina_base_pending_coinbase.Hash_versioned.V1.t) Poly.V1.t\n end\nend\n\nmodule M = struct\n module Aux_hash = struct\n type t = string\n\n module V1 = struct\n type nonrec t = string\n end\n end\n\n module Pending_coinbase_aux = struct\n module V1 = struct\n type t = string\n end\n end\n\n module Non_snark = struct\n module V1 = struct\n type t =\n { ledger_hash : Mina_base_ledger_hash.V1.t\n ; aux_hash : Aux_hash.V1.t\n ; pending_coinbase_aux : Pending_coinbase_aux.V1.t\n }\n end\n end\n\n module Poly = struct\n module V1 = struct\n type ('non_snark, 'pending_coinbase_hash) t =\n { non_snark : 'non_snark\n ; pending_coinbase_hash : 'pending_coinbase_hash\n }\n end\n end\n\n module V1 = struct\n type t =\n (Non_snark.V1.t, Mina_base_pending_coinbase.Hash_versioned.V1.t) Poly.V1.t\n end\nend\n\nmodule type Local_sig = Signature(Types).S\n\nmodule Make\n (Signature : Local_sig) (F : functor (A : Concrete) -> Signature(A).S) =\n F (M)\ninclude M\n","open Utils\n\nmodule Digest_types = struct\n module type S = sig\n module Account_update : sig\n module V1 : sig\n type t = private Pasta_bindings.Fp.t\n end\n end\n\n module Forest : sig\n module V1 : sig\n type t = private Pasta_bindings.Fp.t\n end\n end\n end\nend\n\nmodule Digest_M = struct\n module Account_update = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\n end\n\n module Forest = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\n end\nend\n\nmodule type Digest_concrete = sig\n module Account_update : sig\n module V1 : sig\n type t = Pasta_bindings.Fp.t\n end\n end\n\n module Forest : sig\n module V1 : sig\n type t = Pasta_bindings.Fp.t\n end\n end\nend\n\nmodule type Digest_local_sig = Signature(Digest_types).S\n\nmodule Digest_make\n (Signature : Digest_local_sig) (F : functor (A : Digest_concrete) ->\n Signature(A).S) =\n F (Digest_M)\n\nmodule Call_forest = struct\n module Digest = Digest_M\n\n module Tree = struct\n module V1 = struct\n type ('account_update, 'account_update_digest, 'digest) t =\n { account_update : 'account_update\n ; account_update_digest : 'account_update_digest\n ; calls :\n ( ('account_update, 'account_update_digest, 'digest) t\n , 'digest )\n Mina_base_with_stack_hash.V1.t\n list\n }\n end\n end\n\n module V1 = struct\n type ('account_update, 'account_update_digest, 'digest) t =\n ( ('account_update, 'account_update_digest, 'digest) Tree.V1.t\n , 'digest )\n Mina_base_with_stack_hash.V1.t\n list\n end\nend\n\nmodule V1 = struct\n type t =\n { fee_payer : Mina_base_account_update.Fee_payer.V1.t\n ; account_updates :\n ( Mina_base_account_update.V1.t\n , Call_forest.Digest.Account_update.V1.t\n , Call_forest.Digest.Forest.V1.t )\n Call_forest.V1.t\n ; memo : Mina_base_signed_command_memo.V1.t\n }\nend\n\nmodule Valid = struct\n module Verification_key_hash = struct\n module V1 = struct\n type t = Mina_base_zkapp_basic.F.V1.t\n end\n end\n\n module V1 = struct\n type t = { zkapp_command : V1.t }\n end\nend\n\nmodule Transaction_commitment = struct\n module V1 = struct\n type t = Pasta_bindings.Fp.t\n end\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2012 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* TODO: remove this open *)\nopen Stdlib0\nmodule Location = Astlib.Location\nmodule Longident = Astlib.Longident\nopen Astlib.Ast_412\n\n[@@@warning \"-9\"]\n\nopen Asttypes\nopen Parsetree\n\ntype 'a with_loc = 'a Location.loc\ntype loc = Location.t\ntype lid = Longident.t with_loc\ntype str = string with_loc\ntype str_opt = string option with_loc\ntype attrs = attribute list\n\nlet default_loc = ref Location.none\n\ntype ref_and_value = R : 'a ref * 'a -> ref_and_value\n\nlet protect_ref =\n let set_ref (R (r, v)) = r := v in\n fun ref f ->\n let (R (r, _)) = ref in\n let backup = R (r, !r) in\n set_ref ref;\n match f () with\n | x ->\n set_ref backup;\n x\n | exception e ->\n set_ref backup;\n raise e\n\nlet with_default_loc l f = protect_ref (R (default_loc, l)) f\n\nmodule Const = struct\n let integer ?suffix i = Pconst_integer (i, suffix)\n let int ?suffix i = integer ?suffix (Int.to_string i)\n let int32 ?(suffix = 'l') i = integer ~suffix (Int32.to_string i)\n let int64 ?(suffix = 'L') i = integer ~suffix (Int64.to_string i)\n let nativeint ?(suffix = 'n') i = integer ~suffix (Nativeint.to_string i)\n let float ?suffix f = Pconst_float (f, suffix)\n let char c = Pconst_char c\n\n let string ?quotation_delimiter ?(loc = !default_loc) s =\n Pconst_string (s, loc, quotation_delimiter)\nend\n\nmodule Attr = struct\n let mk ?(loc = !default_loc) name payload =\n { attr_name = name; attr_payload = payload; attr_loc = loc }\nend\n\nmodule Typ = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n {\n ptyp_desc = d;\n ptyp_loc = loc;\n ptyp_loc_stack = [];\n ptyp_attributes = attrs;\n }\n\n let attr d a = { d with ptyp_attributes = d.ptyp_attributes @ [ a ] }\n let any ?loc ?attrs () = mk ?loc ?attrs Ptyp_any\n let var ?loc ?attrs a = mk ?loc ?attrs (Ptyp_var a)\n let arrow ?loc ?attrs a b c = mk ?loc ?attrs (Ptyp_arrow (a, b, c))\n let tuple ?loc ?attrs a = mk ?loc ?attrs (Ptyp_tuple a)\n let constr ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_constr (a, b))\n let object_ ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_object (a, b))\n let class_ ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_class (a, b))\n let alias ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_alias (a, b))\n let variant ?loc ?attrs a b c = mk ?loc ?attrs (Ptyp_variant (a, b, c))\n let poly ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_poly (a, b))\n let package ?loc ?attrs a b = mk ?loc ?attrs (Ptyp_package (a, b))\n let extension ?loc ?attrs a = mk ?loc ?attrs (Ptyp_extension a)\n\n let force_poly t =\n match t.ptyp_desc with Ptyp_poly _ -> t | _ -> poly ~loc:t.ptyp_loc [] t\n (* -> ghost? *)\n\n let varify_constructors var_names t =\n let check_variable vl loc v =\n if List.mem v vl then\n Location.raise_errorf ~loc \"variable in scope syntax error: %s\" v\n in\n let var_names = List.map (fun v -> v.txt) var_names in\n let rec loop t =\n let desc =\n match t.ptyp_desc with\n | Ptyp_any -> Ptyp_any\n | Ptyp_var x ->\n check_variable var_names t.ptyp_loc x;\n Ptyp_var x\n | Ptyp_arrow (label, core_type, core_type') ->\n Ptyp_arrow (label, loop core_type, loop core_type')\n | Ptyp_tuple lst -> Ptyp_tuple (List.map loop lst)\n | Ptyp_constr ({ txt = Longident.Lident s }, [])\n when List.mem s var_names ->\n Ptyp_var s\n | Ptyp_constr (longident, lst) ->\n Ptyp_constr (longident, List.map loop lst)\n | Ptyp_object (lst, o) -> Ptyp_object (List.map loop_object_field lst, o)\n | Ptyp_class (longident, lst) ->\n Ptyp_class (longident, List.map loop lst)\n | Ptyp_alias (core_type, string) ->\n check_variable var_names t.ptyp_loc string;\n Ptyp_alias (loop core_type, string)\n | Ptyp_variant (row_field_list, flag, lbl_lst_option) ->\n Ptyp_variant\n (List.map loop_row_field row_field_list, flag, lbl_lst_option)\n | Ptyp_poly (string_lst, core_type) ->\n List.iter\n (fun v -> check_variable var_names t.ptyp_loc v.txt)\n string_lst;\n Ptyp_poly (string_lst, loop core_type)\n | Ptyp_package (longident, lst) ->\n Ptyp_package\n (longident, List.map (fun (n, typ) -> (n, loop typ)) lst)\n | Ptyp_extension (s, arg) -> Ptyp_extension (s, arg)\n in\n { t with ptyp_desc = desc }\n and loop_row_field field =\n let prf_desc =\n match field.prf_desc with\n | Rtag (label, flag, lst) -> Rtag (label, flag, List.map loop lst)\n | Rinherit t -> Rinherit (loop t)\n in\n { field with prf_desc }\n and loop_object_field field =\n let pof_desc =\n match field.pof_desc with\n | Otag (label, t) -> Otag (label, loop t)\n | Oinherit t -> Oinherit (loop t)\n in\n { field with pof_desc }\n in\n loop t\nend\n\nmodule Pat = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n {\n ppat_desc = d;\n ppat_loc = loc;\n ppat_loc_stack = [];\n ppat_attributes = attrs;\n }\n\n let attr d a = { d with ppat_attributes = d.ppat_attributes @ [ a ] }\n let any ?loc ?attrs () = mk ?loc ?attrs Ppat_any\n let var ?loc ?attrs a = mk ?loc ?attrs (Ppat_var a)\n let alias ?loc ?attrs a b = mk ?loc ?attrs (Ppat_alias (a, b))\n let constant ?loc ?attrs a = mk ?loc ?attrs (Ppat_constant a)\n let interval ?loc ?attrs a b = mk ?loc ?attrs (Ppat_interval (a, b))\n let tuple ?loc ?attrs a = mk ?loc ?attrs (Ppat_tuple a)\n let construct ?loc ?attrs a b = mk ?loc ?attrs (Ppat_construct (a, b))\n let variant ?loc ?attrs a b = mk ?loc ?attrs (Ppat_variant (a, b))\n let record ?loc ?attrs a b = mk ?loc ?attrs (Ppat_record (a, b))\n let array ?loc ?attrs a = mk ?loc ?attrs (Ppat_array a)\n let or_ ?loc ?attrs a b = mk ?loc ?attrs (Ppat_or (a, b))\n let constraint_ ?loc ?attrs a b = mk ?loc ?attrs (Ppat_constraint (a, b))\n let type_ ?loc ?attrs a = mk ?loc ?attrs (Ppat_type a)\n let lazy_ ?loc ?attrs a = mk ?loc ?attrs (Ppat_lazy a)\n let unpack ?loc ?attrs a = mk ?loc ?attrs (Ppat_unpack a)\n let open_ ?loc ?attrs a b = mk ?loc ?attrs (Ppat_open (a, b))\n let exception_ ?loc ?attrs a = mk ?loc ?attrs (Ppat_exception a)\n let extension ?loc ?attrs a = mk ?loc ?attrs (Ppat_extension a)\nend\n\nmodule Exp = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n {\n pexp_desc = d;\n pexp_loc = loc;\n pexp_loc_stack = [];\n pexp_attributes = attrs;\n }\n\n let attr d a = { d with pexp_attributes = d.pexp_attributes @ [ a ] }\n let ident ?loc ?attrs a = mk ?loc ?attrs (Pexp_ident a)\n let constant ?loc ?attrs a = mk ?loc ?attrs (Pexp_constant a)\n let let_ ?loc ?attrs a b c = mk ?loc ?attrs (Pexp_let (a, b, c))\n let fun_ ?loc ?attrs a b c d = mk ?loc ?attrs (Pexp_fun (a, b, c, d))\n let function_ ?loc ?attrs a = mk ?loc ?attrs (Pexp_function a)\n let apply ?loc ?attrs a b = mk ?loc ?attrs (Pexp_apply (a, b))\n let match_ ?loc ?attrs a b = mk ?loc ?attrs (Pexp_match (a, b))\n let try_ ?loc ?attrs a b = mk ?loc ?attrs (Pexp_try (a, b))\n let tuple ?loc ?attrs a = mk ?loc ?attrs (Pexp_tuple a)\n let construct ?loc ?attrs a b = mk ?loc ?attrs (Pexp_construct (a, b))\n let variant ?loc ?attrs a b = mk ?loc ?attrs (Pexp_variant (a, b))\n let record ?loc ?attrs a b = mk ?loc ?attrs (Pexp_record (a, b))\n let field ?loc ?attrs a b = mk ?loc ?attrs (Pexp_field (a, b))\n let setfield ?loc ?attrs a b c = mk ?loc ?attrs (Pexp_setfield (a, b, c))\n let array ?loc ?attrs a = mk ?loc ?attrs (Pexp_array a)\n let ifthenelse ?loc ?attrs a b c = mk ?loc ?attrs (Pexp_ifthenelse (a, b, c))\n let sequence ?loc ?attrs a b = mk ?loc ?attrs (Pexp_sequence (a, b))\n let while_ ?loc ?attrs a b = mk ?loc ?attrs (Pexp_while (a, b))\n let for_ ?loc ?attrs a b c d e = mk ?loc ?attrs (Pexp_for (a, b, c, d, e))\n let constraint_ ?loc ?attrs a b = mk ?loc ?attrs (Pexp_constraint (a, b))\n let coerce ?loc ?attrs a b c = mk ?loc ?attrs (Pexp_coerce (a, b, c))\n let send ?loc ?attrs a b = mk ?loc ?attrs (Pexp_send (a, b))\n let new_ ?loc ?attrs a = mk ?loc ?attrs (Pexp_new a)\n let setinstvar ?loc ?attrs a b = mk ?loc ?attrs (Pexp_setinstvar (a, b))\n let override ?loc ?attrs a = mk ?loc ?attrs (Pexp_override a)\n let letmodule ?loc ?attrs a b c = mk ?loc ?attrs (Pexp_letmodule (a, b, c))\n let letexception ?loc ?attrs a b = mk ?loc ?attrs (Pexp_letexception (a, b))\n let assert_ ?loc ?attrs a = mk ?loc ?attrs (Pexp_assert a)\n let lazy_ ?loc ?attrs a = mk ?loc ?attrs (Pexp_lazy a)\n let poly ?loc ?attrs a b = mk ?loc ?attrs (Pexp_poly (a, b))\n let object_ ?loc ?attrs a = mk ?loc ?attrs (Pexp_object a)\n let newtype ?loc ?attrs a b = mk ?loc ?attrs (Pexp_newtype (a, b))\n let pack ?loc ?attrs a = mk ?loc ?attrs (Pexp_pack a)\n let open_ ?loc ?attrs a b = mk ?loc ?attrs (Pexp_open (a, b))\n\n let letop ?loc ?attrs let_ ands body =\n mk ?loc ?attrs (Pexp_letop { let_; ands; body })\n\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pexp_extension a)\n let unreachable ?loc ?attrs () = mk ?loc ?attrs Pexp_unreachable\n let case lhs ?guard rhs = { pc_lhs = lhs; pc_guard = guard; pc_rhs = rhs }\n\n let binding_op op pat exp loc =\n { pbop_op = op; pbop_pat = pat; pbop_exp = exp; pbop_loc = loc }\nend\n\nmodule Mty = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pmty_desc = d; pmty_loc = loc; pmty_attributes = attrs }\n\n let attr d a = { d with pmty_attributes = d.pmty_attributes @ [ a ] }\n let ident ?loc ?attrs a = mk ?loc ?attrs (Pmty_ident a)\n let alias ?loc ?attrs a = mk ?loc ?attrs (Pmty_alias a)\n let signature ?loc ?attrs a = mk ?loc ?attrs (Pmty_signature a)\n let functor_ ?loc ?attrs a b = mk ?loc ?attrs (Pmty_functor (a, b))\n let with_ ?loc ?attrs a b = mk ?loc ?attrs (Pmty_with (a, b))\n let typeof_ ?loc ?attrs a = mk ?loc ?attrs (Pmty_typeof a)\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pmty_extension a)\nend\n\nmodule Mod = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pmod_desc = d; pmod_loc = loc; pmod_attributes = attrs }\n\n let attr d a = { d with pmod_attributes = d.pmod_attributes @ [ a ] }\n let ident ?loc ?attrs x = mk ?loc ?attrs (Pmod_ident x)\n let structure ?loc ?attrs x = mk ?loc ?attrs (Pmod_structure x)\n let functor_ ?loc ?attrs arg body = mk ?loc ?attrs (Pmod_functor (arg, body))\n let apply ?loc ?attrs m1 m2 = mk ?loc ?attrs (Pmod_apply (m1, m2))\n let constraint_ ?loc ?attrs m mty = mk ?loc ?attrs (Pmod_constraint (m, mty))\n let unpack ?loc ?attrs e = mk ?loc ?attrs (Pmod_unpack e)\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pmod_extension a)\nend\n\nmodule Sig = struct\n let mk ?(loc = !default_loc) d = { psig_desc = d; psig_loc = loc }\n let value ?loc a = mk ?loc (Psig_value a)\n let type_ ?loc rec_flag a = mk ?loc (Psig_type (rec_flag, a))\n let type_subst ?loc a = mk ?loc (Psig_typesubst a)\n let type_extension ?loc a = mk ?loc (Psig_typext a)\n let exception_ ?loc a = mk ?loc (Psig_exception a)\n let module_ ?loc a = mk ?loc (Psig_module a)\n let mod_subst ?loc a = mk ?loc (Psig_modsubst a)\n let rec_module ?loc a = mk ?loc (Psig_recmodule a)\n let modtype ?loc a = mk ?loc (Psig_modtype a)\n let open_ ?loc a = mk ?loc (Psig_open a)\n let include_ ?loc a = mk ?loc (Psig_include a)\n let class_ ?loc a = mk ?loc (Psig_class a)\n let class_type ?loc a = mk ?loc (Psig_class_type a)\n let extension ?loc ?(attrs = []) a = mk ?loc (Psig_extension (a, attrs))\n let attribute ?loc a = mk ?loc (Psig_attribute a)\nend\n\nmodule Str = struct\n let mk ?(loc = !default_loc) d = { pstr_desc = d; pstr_loc = loc }\n let eval ?loc ?(attrs = []) a = mk ?loc (Pstr_eval (a, attrs))\n let value ?loc a b = mk ?loc (Pstr_value (a, b))\n let primitive ?loc a = mk ?loc (Pstr_primitive a)\n let type_ ?loc rec_flag a = mk ?loc (Pstr_type (rec_flag, a))\n let type_extension ?loc a = mk ?loc (Pstr_typext a)\n let exception_ ?loc a = mk ?loc (Pstr_exception a)\n let module_ ?loc a = mk ?loc (Pstr_module a)\n let rec_module ?loc a = mk ?loc (Pstr_recmodule a)\n let modtype ?loc a = mk ?loc (Pstr_modtype a)\n let open_ ?loc a = mk ?loc (Pstr_open a)\n let class_ ?loc a = mk ?loc (Pstr_class a)\n let class_type ?loc a = mk ?loc (Pstr_class_type a)\n let include_ ?loc a = mk ?loc (Pstr_include a)\n let extension ?loc ?(attrs = []) a = mk ?loc (Pstr_extension (a, attrs))\n let attribute ?loc a = mk ?loc (Pstr_attribute a)\nend\n\nmodule Cl = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pcl_desc = d; pcl_loc = loc; pcl_attributes = attrs }\n\n let attr d a = { d with pcl_attributes = d.pcl_attributes @ [ a ] }\n let constr ?loc ?attrs a b = mk ?loc ?attrs (Pcl_constr (a, b))\n let structure ?loc ?attrs a = mk ?loc ?attrs (Pcl_structure a)\n let fun_ ?loc ?attrs a b c d = mk ?loc ?attrs (Pcl_fun (a, b, c, d))\n let apply ?loc ?attrs a b = mk ?loc ?attrs (Pcl_apply (a, b))\n let let_ ?loc ?attrs a b c = mk ?loc ?attrs (Pcl_let (a, b, c))\n let constraint_ ?loc ?attrs a b = mk ?loc ?attrs (Pcl_constraint (a, b))\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pcl_extension a)\n let open_ ?loc ?attrs a b = mk ?loc ?attrs (Pcl_open (a, b))\nend\n\nmodule Cty = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pcty_desc = d; pcty_loc = loc; pcty_attributes = attrs }\n\n let attr d a = { d with pcty_attributes = d.pcty_attributes @ [ a ] }\n let constr ?loc ?attrs a b = mk ?loc ?attrs (Pcty_constr (a, b))\n let signature ?loc ?attrs a = mk ?loc ?attrs (Pcty_signature a)\n let arrow ?loc ?attrs a b c = mk ?loc ?attrs (Pcty_arrow (a, b, c))\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pcty_extension a)\n let open_ ?loc ?attrs a b = mk ?loc ?attrs (Pcty_open (a, b))\nend\n\nmodule Ctf = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pctf_desc = d; pctf_loc = loc; pctf_attributes = attrs }\n\n let inherit_ ?loc ?attrs a = mk ?loc ?attrs (Pctf_inherit a)\n let val_ ?loc ?attrs a b c d = mk ?loc ?attrs (Pctf_val (a, b, c, d))\n let method_ ?loc ?attrs a b c d = mk ?loc ?attrs (Pctf_method (a, b, c, d))\n let constraint_ ?loc ?attrs a b = mk ?loc ?attrs (Pctf_constraint (a, b))\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pctf_extension a)\n let attribute ?loc a = mk ?loc (Pctf_attribute a)\n let attr d a = { d with pctf_attributes = d.pctf_attributes @ [ a ] }\nend\n\nmodule Cf = struct\n let mk ?(loc = !default_loc) ?(attrs = []) d =\n { pcf_desc = d; pcf_loc = loc; pcf_attributes = attrs }\n\n let inherit_ ?loc ?attrs a b c = mk ?loc ?attrs (Pcf_inherit (a, b, c))\n let val_ ?loc ?attrs a b c = mk ?loc ?attrs (Pcf_val (a, b, c))\n let method_ ?loc ?attrs a b c = mk ?loc ?attrs (Pcf_method (a, b, c))\n let constraint_ ?loc ?attrs a b = mk ?loc ?attrs (Pcf_constraint (a, b))\n let initializer_ ?loc ?attrs a = mk ?loc ?attrs (Pcf_initializer a)\n let extension ?loc ?attrs a = mk ?loc ?attrs (Pcf_extension a)\n let attribute ?loc a = mk ?loc (Pcf_attribute a)\n let virtual_ ct = Cfk_virtual ct\n let concrete o e = Cfk_concrete (o, e)\n let attr d a = { d with pcf_attributes = d.pcf_attributes @ [ a ] }\nend\n\nmodule Val = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?(prim = []) name typ =\n {\n pval_name = name;\n pval_type = typ;\n pval_attributes = attrs;\n pval_loc = loc;\n pval_prim = prim;\n }\nend\n\nmodule Md = struct\n let mk ?(loc = !default_loc) ?(attrs = []) name typ =\n { pmd_name = name; pmd_type = typ; pmd_attributes = attrs; pmd_loc = loc }\nend\n\nmodule Ms = struct\n let mk ?(loc = !default_loc) ?(attrs = []) name syn =\n {\n pms_name = name;\n pms_manifest = syn;\n pms_attributes = attrs;\n pms_loc = loc;\n }\nend\n\nmodule Mtd = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?typ name =\n {\n pmtd_name = name;\n pmtd_type = typ;\n pmtd_attributes = attrs;\n pmtd_loc = loc;\n }\nend\n\nmodule Mb = struct\n let mk ?(loc = !default_loc) ?(attrs = []) name expr =\n { pmb_name = name; pmb_expr = expr; pmb_attributes = attrs; pmb_loc = loc }\nend\n\nmodule Opn = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?(override = Fresh) expr =\n {\n popen_expr = expr;\n popen_override = override;\n popen_loc = loc;\n popen_attributes = attrs;\n }\nend\n\nmodule Incl = struct\n let mk ?(loc = !default_loc) ?(attrs = []) mexpr =\n { pincl_mod = mexpr; pincl_loc = loc; pincl_attributes = attrs }\nend\n\nmodule Vb = struct\n let mk ?(loc = !default_loc) ?(attrs = []) pat expr =\n { pvb_pat = pat; pvb_expr = expr; pvb_attributes = attrs; pvb_loc = loc }\nend\n\nmodule Ci = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?(virt = Concrete) ?(params = [])\n name expr =\n {\n pci_virt = virt;\n pci_params = params;\n pci_name = name;\n pci_expr = expr;\n pci_attributes = attrs;\n pci_loc = loc;\n }\nend\n\nmodule Type = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?(params = []) ?(cstrs = [])\n ?(kind = Ptype_abstract) ?(priv = Public) ?manifest name =\n {\n ptype_name = name;\n ptype_params = params;\n ptype_cstrs = cstrs;\n ptype_kind = kind;\n ptype_private = priv;\n ptype_manifest = manifest;\n ptype_attributes = attrs;\n ptype_loc = loc;\n }\n\n let constructor ?(loc = !default_loc) ?(attrs = []) ?(args = Pcstr_tuple [])\n ?res name =\n {\n pcd_name = name;\n pcd_args = args;\n pcd_res = res;\n pcd_loc = loc;\n pcd_attributes = attrs;\n }\n\n let field ?(loc = !default_loc) ?(attrs = []) ?(mut = Immutable) name typ =\n {\n pld_name = name;\n pld_mutable = mut;\n pld_type = typ;\n pld_loc = loc;\n pld_attributes = attrs;\n }\nend\n\n(** Type extensions *)\nmodule Te = struct\n let mk ?(loc = !default_loc) ?(attrs = []) ?(params = []) ?(priv = Public)\n path constructors =\n {\n ptyext_path = path;\n ptyext_params = params;\n ptyext_constructors = constructors;\n ptyext_private = priv;\n ptyext_loc = loc;\n ptyext_attributes = attrs;\n }\n\n let mk_exception ?(loc = !default_loc) ?(attrs = []) constructor =\n {\n ptyexn_constructor = constructor;\n ptyexn_loc = loc;\n ptyexn_attributes = attrs;\n }\n\n let constructor ?(loc = !default_loc) ?(attrs = []) name kind =\n {\n pext_name = name;\n pext_kind = kind;\n pext_loc = loc;\n pext_attributes = attrs;\n }\n\n let decl ?(loc = !default_loc) ?(attrs = []) ?(args = Pcstr_tuple []) ?res\n name =\n {\n pext_name = name;\n pext_kind = Pext_decl (args, res);\n pext_loc = loc;\n pext_attributes = attrs;\n }\n\n let rebind ?(loc = !default_loc) ?(attrs = []) name lid =\n {\n pext_name = name;\n pext_kind = Pext_rebind lid;\n pext_loc = loc;\n pext_attributes = attrs;\n }\nend\n\nmodule Csig = struct\n let mk self fields = { pcsig_self = self; pcsig_fields = fields }\nend\n\nmodule Cstr = struct\n let mk self fields = { pcstr_self = self; pcstr_fields = fields }\nend\n\n(** Row fields *)\nmodule Rf = struct\n let mk ?(loc = !default_loc) ?(attrs = []) desc =\n { prf_desc = desc; prf_loc = loc; prf_attributes = attrs }\n\n let tag ?loc ?attrs label const tys =\n mk ?loc ?attrs (Rtag (label, const, tys))\n\n let inherit_ ?loc ty = mk ?loc (Rinherit ty)\nend\n\n(** Object fields *)\nmodule Of = struct\n let mk ?(loc = !default_loc) ?(attrs = []) desc =\n { pof_desc = desc; pof_loc = loc; pof_attributes = attrs }\n\n let tag ?loc ?attrs label ty = mk ?loc ?attrs (Otag (label, ty))\n let inherit_ ?loc ty = mk ?loc (Oinherit ty)\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Daniel C. Buenzli *)\n(* *)\n(* Copyright 2014 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nexternal format_int : string -> int -> string = \"caml_format_int\"\n\nlet err_no_pred = \"U+0000 has no predecessor\"\nlet err_no_succ = \"U+10FFFF has no successor\"\nlet err_not_sv i = format_int \"%X\" i ^ \" is not an Unicode scalar value\"\nlet err_not_latin1 u = \"U+\" ^ format_int \"%04X\" u ^ \" is not a latin1 character\"\n\ntype t = int\n\nlet min = 0x0000\nlet max = 0x10FFFF\nlet lo_bound = 0xD7FF\nlet hi_bound = 0xE000\n\nlet bom = 0xFEFF\nlet rep = 0xFFFD\n\nlet succ u =\n if u = lo_bound then hi_bound else\n if u = max then invalid_arg err_no_succ else\n u + 1\n\nlet pred u =\n if u = hi_bound then lo_bound else\n if u = min then invalid_arg err_no_pred else\n u - 1\n\nlet is_valid i = (min <= i && i <= lo_bound) || (hi_bound <= i && i <= max)\nlet of_int i = if is_valid i then i else invalid_arg (err_not_sv i)\nexternal unsafe_of_int : int -> t = \"%identity\"\nexternal to_int : t -> int = \"%identity\"\n\nlet is_char u = u < 256\nlet of_char c = Char.code c\nlet to_char u =\n if u > 255 then invalid_arg (err_not_latin1 u) else\n Char.unsafe_chr u\n\nlet unsafe_to_char = Char.unsafe_chr\n\nlet equal : int -> int -> bool = ( = )\nlet compare : int -> int -> int = Stdlib.compare\nlet hash = to_int\n\n(* UTF codecs tools *)\n\ntype utf_decode = int\n(* This is an int [0xDUUUUUU] decomposed as follows:\n - [D] is four bits for decode information, the highest bit is set if the\n decode is valid. The three lower bits indicate the number of elements\n from the source that were consumed by the decode.\n - [UUUUUU] is the decoded Unicode character or the Unicode replacement\n character U+FFFD if for invalid decodes. *)\n\nlet valid_bit = 27\nlet decode_bits = 24\n\nlet[@inline] utf_decode_is_valid d = (d lsr valid_bit) = 1\nlet[@inline] utf_decode_length d = (d lsr decode_bits) land 0b111\nlet[@inline] utf_decode_uchar d = unsafe_of_int (d land 0xFFFFFF)\nlet[@inline] utf_decode n u = ((8 lor n) lsl decode_bits) lor (to_int u)\nlet[@inline] utf_decode_invalid n = (n lsl decode_bits) lor rep\n\nlet utf_8_byte_length u = match to_int u with\n| u when u < 0 -> assert false\n| u when u <= 0x007F -> 1\n| u when u <= 0x07FF -> 2\n| u when u <= 0xFFFF -> 3\n| u when u <= 0x10FFFF -> 4\n| _ -> assert false\n\nlet utf_16_byte_length u = match to_int u with\n| u when u < 0 -> assert false\n| u when u <= 0xFFFF -> 2\n| u when u <= 0x10FFFF -> 4\n| _ -> assert false\n","module Int = struct\n let to_string = string_of_int\nend\n\nmodule Option = struct\n let map f o = match o with None -> None | Some v -> Some (f v)\nend\n","include Ocaml_common.Location\n\nlet set_input_name name = input_name := name\n\nmodule Error = struct\n [@@@warning \"-37\"]\n\n type old_t (*IF_NOT_AT_LEAST 408 = Ocaml_common.Location.error *) = {\n loc: t;\n msg: string;\n sub: old_t list;\n if_highlight: string;\n }\n\n type location_report_kind (*IF_AT_LEAST 408 = Ocaml_common.Location.report_kind *) =\n | Report_error\n | Report_warning of string\n | Report_warning_as_error of string\n | Report_alert of string\n | Report_alert_as_error of string\n\n type location_msg = (Format.formatter -> unit) loc\n\n type location_report (*IF_AT_LEAST 408 = Ocaml_common.Location.report *) = {\n kind : location_report_kind;\n main : location_msg;\n sub : location_msg list;\n }\n\n type t (*IF_AT_LEAST 408 = Ocaml_common.Location.error *) (*IF_NOT_AT_LEAST 408 = old_t *)\n (** On ocaml >= 4.08: [t] is a [location_report] for which [location_report_kind] must be [Report_error]. *)\n\n type version_specific_t = [`New_error of location_report | `Old_error of old_t]\n\n let version_specific_t_of_t : t -> version_specific_t = fun x ->\n (*IF_AT_LEAST 408 `New_error x *)\n (*IF_NOT_AT_LEAST 408 `Old_error x *)\n\n let is_well_formed error =\n match version_specific_t_of_t error with\n | `New_error { kind = Report_error; _ } -> true\n | `New_error _ -> false\n | `Old_error _ -> true\n\n let string_of_location_msg (msg : location_msg) = Format.asprintf \"%t\" msg.txt\n\n let main_msg error =\n match version_specific_t_of_t error with\n | `New_error { main; _ } ->\n { txt = string_of_location_msg main; loc = main.loc }\n | `Old_error { msg; loc; _ } -> { txt = msg; loc }\n\n let sub_msgs error =\n match version_specific_t_of_t error with\n | `New_error { sub; _ } ->\n List.map\n (fun err -> { txt = string_of_location_msg err; loc = err.loc })\n sub\n | `Old_error { sub; _ } ->\n let rec deeply_flattened_sub_msgs acc = function\n | [] -> acc\n | { loc; msg; sub; _ } :: tail ->\n deeply_flattened_sub_msgs ({ txt = msg; loc } :: acc) (sub @ tail)\n in\n deeply_flattened_sub_msgs [] sub\n\n let of_exn exn =\n (*IF_AT_LEAST 406 match error_of_exn exn with | Some (`Ok e) -> Some e | None | Some `Already_displayed -> None *)\n (*IF_NOT_AT_LEAST 406 error_of_exn exn*)\n\n let _set_main_msg_old error msg = { error with msg }\n\n let _set_main_msg_new error msg =\n let txt ppf = Format.pp_print_string ppf msg in\n let main = { error.main with txt } in\n { error with main }\n\n let set_main_msg error msg =\n (*IF_NOT_AT_LEAST 408 _set_main_msg_old error msg*)\n (*IF_AT_LEAST 408 _set_main_msg_new error msg*)\n\n let _make_error_of_message_old ~sub { loc; txt } =\n let sub =\n List.map\n (fun { loc; txt } -> { loc; msg = txt; sub = []; if_highlight = txt })\n sub\n in\n { loc; msg = txt; sub; if_highlight = txt }\n\n let _make_error_of_message_new ~sub { loc; txt } =\n let mk_txt x ppf = Format.pp_print_string ppf x in\n let mk loc x = { loc; txt = mk_txt x } in\n {\n kind = Report_error;\n main = mk loc txt;\n sub = List.map (fun { loc; txt } -> mk loc txt) sub;\n }\n\n let make ~sub msg =\n (*IF_NOT_AT_LEAST 408 _make_error_of_message_old ~sub msg*)\n (*IF_AT_LEAST 408 _make_error_of_message_new ~sub msg*)\n\n let _set_main_loc_old error loc = { error with loc }\n\n let _set_main_loc_new error loc =\n let main = { error.main with loc } in\n { error with main }\n\n let set_main_loc error loc =\n (*IF_NOT_AT_LEAST 408 _set_main_loc_old error loc*)\n (*IF_AT_LEAST 408 _set_main_loc_new error loc*)\nend\n\nlet raise_errorf ?loc msg = raise_errorf ?loc msg\n","(*$ open Ppxlib_cinaps_helpers $*)\nopen! Import\nmodule Format = Caml.Format\nmodule Filename = Caml.Filename\n\n(* TODO: make the \"deriving.\" depend on the matching attribute name. *)\nlet end_marker_sig =\n Attribute.Floating.declare \"deriving.end\" Signature_item\n Ast_pattern.(pstr nil)\n ()\n\nlet end_marker_str =\n Attribute.Floating.declare \"deriving.end\" Structure_item\n Ast_pattern.(pstr nil)\n ()\n\nmodule type T1 = sig\n type 'a t\nend\n\nmodule Make (M : sig\n type t\n\n val get_loc : t -> Location.t\n val end_marker : (t, unit) Attribute.Floating.t\n\n module Transform (T : T1) : sig\n val apply :\n < structure_item : structure_item T.t\n ; signature_item : signature_item T.t\n ; .. > ->\n t T.t\n end\n\n val parse : Lexing.lexbuf -> t list\n val pp : Format.formatter -> t -> unit\n val to_sexp : t -> Sexp.t\nend) =\nstruct\n let extract_prefix ~pos l =\n let rec loop acc = function\n | [] ->\n let loc =\n { Location.loc_start = pos; loc_end = pos; loc_ghost = false }\n in\n Location.raise_errorf ~loc \"ppxlib: [@@@@@@%s] attribute missing\"\n (Attribute.Floating.name M.end_marker)\n | x :: l -> (\n match Attribute.Floating.convert [ M.end_marker ] x with\n | None -> loop (x :: acc) l\n | Some () -> (List.rev acc, (M.get_loc x).loc_start)\n | exception Failure _ -> loop (x :: acc) l)\n in\n loop [] l\n\n let remove_loc =\n object\n inherit Ast_traverse.map\n method! location _ = Location.none\n method! location_stack _ = []\n end\n\n module M_map = M.Transform (struct\n type 'a t = 'a -> 'a\n end)\n\n let remove_loc x = M_map.apply remove_loc x\n let rec last prev = function [] -> prev | x :: l -> last x l\n\n let diff_asts ~generated ~round_trip =\n let with_temp_file f =\n Exn.protectx (Filename.temp_file \"ppxlib\" \"\") ~finally:Caml.Sys.remove ~f\n in\n with_temp_file (fun fn1 ->\n with_temp_file (fun fn2 ->\n with_temp_file (fun out ->\n let dump fn ast =\n Out_channel.with_file fn ~f:(fun oc ->\n let ppf = Format.formatter_of_out_channel oc in\n Sexp.pp_hum ppf (M.to_sexp ast);\n Format.pp_print_flush ppf ())\n in\n dump fn1 generated;\n dump fn2 round_trip;\n let cmd =\n Printf.sprintf\n \"patdiff -ascii -alt-old generated -alt-new \\\n 'generated->printed->parsed' %s %s &> %s\"\n (Filename.quote fn1) (Filename.quote fn2)\n (Filename.quote out)\n in\n let ok =\n Caml.Sys.command cmd = 1\n ||\n let cmd =\n Printf.sprintf\n \"diff --label generated --label \\\n 'generated->printed->parsed' %s %s &> %s\"\n (Filename.quote fn1) (Filename.quote fn2)\n (Filename.quote out)\n in\n Caml.Sys.command cmd = 1\n in\n if ok then In_channel.read_all out\n else \"\")))\n\n let parse_string s =\n match M.parse (Lexing.from_string s) with [ x ] -> x | _ -> assert false\n\n let rec match_loop ~end_pos ~mismatch_handler ~expected ~source =\n match (expected, source) with\n | [], [] -> ()\n | [], x :: l ->\n let loc =\n { (M.get_loc x) with loc_end = (M.get_loc (last x l)).loc_end }\n in\n mismatch_handler loc []\n | _, [] ->\n let loc =\n { Location.loc_ghost = false; loc_start = end_pos; loc_end = end_pos }\n in\n mismatch_handler loc expected\n | x :: expected, y :: source ->\n let loc = M.get_loc y in\n let x = remove_loc x in\n let y = remove_loc y in\n if Poly.( <> ) x y then (\n let round_trip =\n remove_loc (parse_string (Format.asprintf \"%a@.\" M.pp x))\n in\n if Poly.( <> ) x round_trip then\n Location.raise_errorf ~loc\n \"ppxlib: the corrected code doesn't round-trip.\\n\\\n This is probably a bug in the OCaml printer:\\n\\\n %s\"\n (diff_asts ~generated:x ~round_trip);\n mismatch_handler loc [ x ]);\n match_loop ~end_pos ~mismatch_handler ~expected ~source\n\n let do_match ~pos ~expected ~mismatch_handler source =\n let source, end_pos = extract_prefix ~pos source in\n match_loop ~end_pos ~mismatch_handler ~expected ~source\nend\n\n(*$*)\nmodule Str = Make (struct\n type t = structure_item\n\n let get_loc x = x.pstr_loc\n let end_marker = end_marker_str\n\n module Transform (T : T1) = struct\n let apply o = o#structure_item\n end\n\n let parse = Parse.implementation\n let pp = Pprintast.structure_item\n let to_sexp = Ast_traverse.sexp_of#structure_item\nend)\n\n(*$ str_to_sig _last_text_block *)\nmodule Sig = Make (struct\n type t = signature_item\n\n let get_loc x = x.psig_loc\n let end_marker = end_marker_sig\n\n module Transform (T : T1) = struct\n let apply o = o#signature_item\n end\n\n let parse = Parse.interface\n let pp = Pprintast.signature_item\n let to_sexp = Ast_traverse.sexp_of#signature_item\nend)\n\n(*$*)\n\nlet match_structure = Str.do_match\nlet match_signature = Sig.do_match\n","open Stdlib0\nmodule From = Ast_414\nmodule To = Ast_413\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.13\" missing_feature\n\nlet rec copy_toplevel_phrase :\n Ast_414.Parsetree.toplevel_phrase -> Ast_413.Parsetree.toplevel_phrase =\n function\n | Ast_414.Parsetree.Ptop_def x0 ->\n Ast_413.Parsetree.Ptop_def (copy_structure x0)\n | Ast_414.Parsetree.Ptop_dir x0 ->\n Ast_413.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_414.Parsetree.toplevel_directive -> Ast_413.Parsetree.toplevel_directive\n =\n fun {\n Ast_414.Parsetree.pdir_name;\n Ast_414.Parsetree.pdir_arg;\n Ast_414.Parsetree.pdir_loc;\n } ->\n {\n Ast_413.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_413.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_413.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_414.Parsetree.directive_argument -> Ast_413.Parsetree.directive_argument\n =\n fun { Ast_414.Parsetree.pdira_desc; Ast_414.Parsetree.pdira_loc } ->\n {\n Ast_413.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_413.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_414.Parsetree.directive_argument_desc ->\n Ast_413.Parsetree.directive_argument_desc = function\n | Ast_414.Parsetree.Pdir_string x0 -> Ast_413.Parsetree.Pdir_string x0\n | Ast_414.Parsetree.Pdir_int (x0, x1) ->\n Ast_413.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_414.Parsetree.Pdir_ident x0 ->\n Ast_413.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_414.Parsetree.Pdir_bool x0 -> Ast_413.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_414.Parsetree.expression -> Ast_413.Parsetree.expression =\n fun {\n Ast_414.Parsetree.pexp_desc;\n Ast_414.Parsetree.pexp_loc;\n Ast_414.Parsetree.pexp_loc_stack;\n Ast_414.Parsetree.pexp_attributes;\n } ->\n {\n Ast_413.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_413.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_413.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_413.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_414.Parsetree.expression_desc -> Ast_413.Parsetree.expression_desc =\n function\n | Ast_414.Parsetree.Pexp_ident x0 ->\n Ast_413.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_414.Parsetree.Pexp_constant x0 ->\n Ast_413.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_414.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_414.Parsetree.Pexp_function x0 ->\n Ast_413.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_414.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_413.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_414.Parsetree.Pexp_apply (x0, x1) ->\n Ast_413.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_414.Parsetree.Pexp_match (x0, x1) ->\n Ast_413.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_414.Parsetree.Pexp_try (x0, x1) ->\n Ast_413.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_414.Parsetree.Pexp_tuple x0 ->\n Ast_413.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_414.Parsetree.Pexp_construct (x0, x1) ->\n Ast_413.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_414.Parsetree.Pexp_variant (x0, x1) ->\n Ast_413.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_414.Parsetree.Pexp_record (x0, x1) ->\n Ast_413.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_414.Parsetree.Pexp_field (x0, x1) ->\n Ast_413.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_414.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_414.Parsetree.Pexp_array x0 ->\n Ast_413.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_414.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_414.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_413.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_while (x0, x1) ->\n Ast_413.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_413.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_414.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_413.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_414.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_414.Parsetree.Pexp_send (x0, x1) ->\n Ast_413.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_414.Parsetree.Pexp_new x0 ->\n Ast_413.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_414.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_413.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_override x0 ->\n Ast_413.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_414.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_414.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_413.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_assert x0 ->\n Ast_413.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_414.Parsetree.Pexp_lazy x0 ->\n Ast_413.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_414.Parsetree.Pexp_poly (x0, x1) ->\n Ast_413.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_414.Parsetree.Pexp_object x0 ->\n Ast_413.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_414.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_413.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_pack x0 ->\n Ast_413.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_414.Parsetree.Pexp_open (x0, x1) ->\n Ast_413.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_414.Parsetree.Pexp_letop x0 ->\n Ast_413.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_414.Parsetree.Pexp_extension x0 ->\n Ast_413.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_414.Parsetree.Pexp_unreachable -> Ast_413.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_414.Parsetree.letop -> Ast_413.Parsetree.letop =\n fun { Ast_414.Parsetree.let_; Ast_414.Parsetree.ands; Ast_414.Parsetree.body } ->\n {\n Ast_413.Parsetree.let_ = copy_binding_op let_;\n Ast_413.Parsetree.ands = List.map copy_binding_op ands;\n Ast_413.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_414.Parsetree.binding_op -> Ast_413.Parsetree.binding_op =\n fun {\n Ast_414.Parsetree.pbop_op;\n Ast_414.Parsetree.pbop_pat;\n Ast_414.Parsetree.pbop_exp;\n Ast_414.Parsetree.pbop_loc;\n } ->\n {\n Ast_413.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_413.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_413.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_413.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_414.Asttypes.direction_flag -> Ast_413.Asttypes.direction_flag =\n function\n | Ast_414.Asttypes.Upto -> Ast_413.Asttypes.Upto\n | Ast_414.Asttypes.Downto -> Ast_413.Asttypes.Downto\n\nand copy_case : Ast_414.Parsetree.case -> Ast_413.Parsetree.case =\n fun {\n Ast_414.Parsetree.pc_lhs;\n Ast_414.Parsetree.pc_guard;\n Ast_414.Parsetree.pc_rhs;\n } ->\n {\n Ast_413.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_413.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_413.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_414.Parsetree.value_binding -> Ast_413.Parsetree.value_binding =\n fun {\n Ast_414.Parsetree.pvb_pat;\n Ast_414.Parsetree.pvb_expr;\n Ast_414.Parsetree.pvb_attributes;\n Ast_414.Parsetree.pvb_loc;\n } ->\n {\n Ast_413.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_413.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_413.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_413.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_414.Parsetree.pattern -> Ast_413.Parsetree.pattern =\n fun {\n Ast_414.Parsetree.ppat_desc;\n Ast_414.Parsetree.ppat_loc;\n Ast_414.Parsetree.ppat_loc_stack;\n Ast_414.Parsetree.ppat_attributes;\n } ->\n {\n Ast_413.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_413.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_413.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_413.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_414.Parsetree.pattern_desc -> Ast_413.Parsetree.pattern_desc = function\n | Ast_414.Parsetree.Ppat_any -> Ast_413.Parsetree.Ppat_any\n | Ast_414.Parsetree.Ppat_var x0 ->\n Ast_413.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_414.Parsetree.Ppat_alias (x0, x1) ->\n Ast_413.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_414.Parsetree.Ppat_constant x0 ->\n Ast_413.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_414.Parsetree.Ppat_interval (x0, x1) ->\n Ast_413.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_414.Parsetree.Ppat_tuple x0 ->\n Ast_413.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_414.Parsetree.Ppat_construct (x0, x1) ->\n Ast_413.Parsetree.Ppat_construct\n ( copy_loc copy_Longident_t x0,\n Option.map\n (fun x ->\n let x0, x1 = x in\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_pattern x1))\n x1 )\n | Ast_414.Parsetree.Ppat_variant (x0, x1) ->\n Ast_413.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_414.Parsetree.Ppat_record (x0, x1) ->\n Ast_413.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_414.Parsetree.Ppat_array x0 ->\n Ast_413.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_414.Parsetree.Ppat_or (x0, x1) ->\n Ast_413.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_414.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_413.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_414.Parsetree.Ppat_type x0 ->\n Ast_413.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_414.Parsetree.Ppat_lazy x0 ->\n Ast_413.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_414.Parsetree.Ppat_unpack x0 ->\n Ast_413.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_414.Parsetree.Ppat_exception x0 ->\n Ast_413.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_414.Parsetree.Ppat_extension x0 ->\n Ast_413.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_414.Parsetree.Ppat_open (x0, x1) ->\n Ast_413.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_414.Parsetree.core_type -> Ast_413.Parsetree.core_type\n =\n fun {\n Ast_414.Parsetree.ptyp_desc;\n Ast_414.Parsetree.ptyp_loc;\n Ast_414.Parsetree.ptyp_loc_stack;\n Ast_414.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_413.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_413.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_413.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_414.Parsetree.location_stack -> Ast_413.Parsetree.location_stack =\n fun x -> x\n\nand copy_core_type_desc :\n Ast_414.Parsetree.core_type_desc -> Ast_413.Parsetree.core_type_desc =\n function\n | Ast_414.Parsetree.Ptyp_any -> Ast_413.Parsetree.Ptyp_any\n | Ast_414.Parsetree.Ptyp_var x0 -> Ast_413.Parsetree.Ptyp_var x0\n | Ast_414.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_413.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_414.Parsetree.Ptyp_tuple x0 ->\n Ast_413.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_414.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_413.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_414.Parsetree.Ptyp_object (x0, x1) ->\n Ast_413.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_414.Parsetree.Ptyp_class (x0, x1) ->\n Ast_413.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_414.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_413.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_414.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_413.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_414.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_413.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_414.Parsetree.Ptyp_package x0 ->\n Ast_413.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_414.Parsetree.Ptyp_extension x0 ->\n Ast_413.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_414.Parsetree.package_type -> Ast_413.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_414.Parsetree.row_field -> Ast_413.Parsetree.row_field\n =\n fun {\n Ast_414.Parsetree.prf_desc;\n Ast_414.Parsetree.prf_loc;\n Ast_414.Parsetree.prf_attributes;\n } ->\n {\n Ast_413.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_413.Parsetree.prf_loc = copy_location prf_loc;\n Ast_413.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_414.Parsetree.row_field_desc -> Ast_413.Parsetree.row_field_desc =\n function\n | Ast_414.Parsetree.Rtag (x0, x1, x2) ->\n Ast_413.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_414.Parsetree.Rinherit x0 ->\n Ast_413.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_414.Parsetree.object_field -> Ast_413.Parsetree.object_field =\n fun {\n Ast_414.Parsetree.pof_desc;\n Ast_414.Parsetree.pof_loc;\n Ast_414.Parsetree.pof_attributes;\n } ->\n {\n Ast_413.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_413.Parsetree.pof_loc = copy_location pof_loc;\n Ast_413.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_414.Parsetree.attributes -> Ast_413.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_414.Parsetree.attribute -> Ast_413.Parsetree.attribute\n =\n fun {\n Ast_414.Parsetree.attr_name;\n Ast_414.Parsetree.attr_payload;\n Ast_414.Parsetree.attr_loc;\n } ->\n {\n Ast_413.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_413.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_413.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_414.Parsetree.payload -> Ast_413.Parsetree.payload =\n function\n | Ast_414.Parsetree.PStr x0 -> Ast_413.Parsetree.PStr (copy_structure x0)\n | Ast_414.Parsetree.PSig x0 -> Ast_413.Parsetree.PSig (copy_signature x0)\n | Ast_414.Parsetree.PTyp x0 -> Ast_413.Parsetree.PTyp (copy_core_type x0)\n | Ast_414.Parsetree.PPat (x0, x1) ->\n Ast_413.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_414.Parsetree.structure -> Ast_413.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_414.Parsetree.structure_item -> Ast_413.Parsetree.structure_item =\n fun { Ast_414.Parsetree.pstr_desc; Ast_414.Parsetree.pstr_loc } ->\n {\n Ast_413.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_413.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_414.Parsetree.structure_item_desc ->\n Ast_413.Parsetree.structure_item_desc = function\n | Ast_414.Parsetree.Pstr_eval (x0, x1) ->\n Ast_413.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_414.Parsetree.Pstr_value (x0, x1) ->\n Ast_413.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_414.Parsetree.Pstr_primitive x0 ->\n Ast_413.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_414.Parsetree.Pstr_type (x0, x1) ->\n Ast_413.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_414.Parsetree.Pstr_typext x0 ->\n Ast_413.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_414.Parsetree.Pstr_exception x0 ->\n Ast_413.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_414.Parsetree.Pstr_module x0 ->\n Ast_413.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_414.Parsetree.Pstr_recmodule x0 ->\n Ast_413.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_414.Parsetree.Pstr_modtype x0 ->\n Ast_413.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_414.Parsetree.Pstr_open x0 ->\n Ast_413.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_414.Parsetree.Pstr_class x0 ->\n Ast_413.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_414.Parsetree.Pstr_class_type x0 ->\n Ast_413.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_414.Parsetree.Pstr_include x0 ->\n Ast_413.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_414.Parsetree.Pstr_attribute x0 ->\n Ast_413.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_414.Parsetree.Pstr_extension (x0, x1) ->\n Ast_413.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_414.Parsetree.include_declaration ->\n Ast_413.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_414.Parsetree.class_declaration -> Ast_413.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_414.Parsetree.class_expr -> Ast_413.Parsetree.class_expr =\n fun {\n Ast_414.Parsetree.pcl_desc;\n Ast_414.Parsetree.pcl_loc;\n Ast_414.Parsetree.pcl_attributes;\n } ->\n {\n Ast_413.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_413.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_413.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_414.Parsetree.class_expr_desc -> Ast_413.Parsetree.class_expr_desc =\n function\n | Ast_414.Parsetree.Pcl_constr (x0, x1) ->\n Ast_413.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_414.Parsetree.Pcl_structure x0 ->\n Ast_413.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_414.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_413.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_414.Parsetree.Pcl_apply (x0, x1) ->\n Ast_413.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_414.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_413.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_414.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_413.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_414.Parsetree.Pcl_extension x0 ->\n Ast_413.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_414.Parsetree.Pcl_open (x0, x1) ->\n Ast_413.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_414.Parsetree.class_structure -> Ast_413.Parsetree.class_structure =\n fun { Ast_414.Parsetree.pcstr_self; Ast_414.Parsetree.pcstr_fields } ->\n {\n Ast_413.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_413.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_414.Parsetree.class_field -> Ast_413.Parsetree.class_field =\n fun {\n Ast_414.Parsetree.pcf_desc;\n Ast_414.Parsetree.pcf_loc;\n Ast_414.Parsetree.pcf_attributes;\n } ->\n {\n Ast_413.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_413.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_413.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_414.Parsetree.class_field_desc -> Ast_413.Parsetree.class_field_desc =\n function\n | Ast_414.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_413.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_414.Parsetree.Pcf_val x0 ->\n Ast_413.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_414.Parsetree.Pcf_method x0 ->\n Ast_413.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_414.Parsetree.Pcf_constraint x0 ->\n Ast_413.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_414.Parsetree.Pcf_initializer x0 ->\n Ast_413.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_414.Parsetree.Pcf_attribute x0 ->\n Ast_413.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_414.Parsetree.Pcf_extension x0 ->\n Ast_413.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_414.Parsetree.class_field_kind -> Ast_413.Parsetree.class_field_kind =\n function\n | Ast_414.Parsetree.Cfk_virtual x0 ->\n Ast_413.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_414.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_413.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_414.Parsetree.open_declaration -> Ast_413.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_414.Parsetree.module_binding -> Ast_413.Parsetree.module_binding =\n fun {\n Ast_414.Parsetree.pmb_name;\n Ast_414.Parsetree.pmb_expr;\n Ast_414.Parsetree.pmb_attributes;\n Ast_414.Parsetree.pmb_loc;\n } ->\n {\n Ast_413.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_413.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_413.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_413.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_414.Parsetree.module_expr -> Ast_413.Parsetree.module_expr =\n fun {\n Ast_414.Parsetree.pmod_desc;\n Ast_414.Parsetree.pmod_loc;\n Ast_414.Parsetree.pmod_attributes;\n } ->\n {\n Ast_413.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_413.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_413.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_414.Parsetree.module_expr_desc -> Ast_413.Parsetree.module_expr_desc =\n function\n | Ast_414.Parsetree.Pmod_ident x0 ->\n Ast_413.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_414.Parsetree.Pmod_structure x0 ->\n Ast_413.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_414.Parsetree.Pmod_functor (x0, x1) ->\n Ast_413.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_414.Parsetree.Pmod_apply (x0, x1) ->\n Ast_413.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_414.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_413.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_414.Parsetree.Pmod_unpack x0 ->\n Ast_413.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_414.Parsetree.Pmod_extension x0 ->\n Ast_413.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_414.Parsetree.functor_parameter -> Ast_413.Parsetree.functor_parameter =\n function\n | Ast_414.Parsetree.Unit -> Ast_413.Parsetree.Unit\n | Ast_414.Parsetree.Named (x0, x1) ->\n Ast_413.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_414.Parsetree.module_type -> Ast_413.Parsetree.module_type =\n fun {\n Ast_414.Parsetree.pmty_desc;\n Ast_414.Parsetree.pmty_loc;\n Ast_414.Parsetree.pmty_attributes;\n } ->\n {\n Ast_413.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_413.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_413.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_414.Parsetree.module_type_desc -> Ast_413.Parsetree.module_type_desc =\n function\n | Ast_414.Parsetree.Pmty_ident x0 ->\n Ast_413.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_414.Parsetree.Pmty_signature x0 ->\n Ast_413.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_414.Parsetree.Pmty_functor (x0, x1) ->\n Ast_413.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_414.Parsetree.Pmty_with (x0, x1) ->\n Ast_413.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_414.Parsetree.Pmty_typeof x0 ->\n Ast_413.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_414.Parsetree.Pmty_extension x0 ->\n Ast_413.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_414.Parsetree.Pmty_alias x0 ->\n Ast_413.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_414.Parsetree.with_constraint -> Ast_413.Parsetree.with_constraint =\n function\n | Ast_414.Parsetree.Pwith_type (x0, x1) ->\n Ast_413.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_414.Parsetree.Pwith_module (x0, x1) ->\n Ast_413.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_414.Parsetree.Pwith_modtype (x0, x1) ->\n Ast_413.Parsetree.Pwith_modtype\n (copy_loc copy_Longident_t x0, copy_module_type x1)\n | Ast_414.Parsetree.Pwith_modtypesubst (x0, x1) ->\n Ast_413.Parsetree.Pwith_modtypesubst\n (copy_loc copy_Longident_t x0, copy_module_type x1)\n | Ast_414.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_413.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_414.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_413.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_414.Parsetree.signature -> Ast_413.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_414.Parsetree.signature_item -> Ast_413.Parsetree.signature_item =\n fun { Ast_414.Parsetree.psig_desc; Ast_414.Parsetree.psig_loc } ->\n {\n Ast_413.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_413.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_414.Parsetree.signature_item_desc ->\n Ast_413.Parsetree.signature_item_desc = function\n | Ast_414.Parsetree.Psig_value x0 ->\n Ast_413.Parsetree.Psig_value (copy_value_description x0)\n | Ast_414.Parsetree.Psig_type (x0, x1) ->\n Ast_413.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_414.Parsetree.Psig_typesubst x0 ->\n Ast_413.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_414.Parsetree.Psig_typext x0 ->\n Ast_413.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_414.Parsetree.Psig_exception x0 ->\n Ast_413.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_414.Parsetree.Psig_module x0 ->\n Ast_413.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_414.Parsetree.Psig_modsubst x0 ->\n Ast_413.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_414.Parsetree.Psig_recmodule x0 ->\n Ast_413.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_414.Parsetree.Psig_modtype x0 ->\n Ast_413.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_414.Parsetree.Psig_modtypesubst x0 ->\n Ast_413.Parsetree.Psig_modtypesubst (copy_module_type_declaration x0)\n | Ast_414.Parsetree.Psig_open x0 ->\n Ast_413.Parsetree.Psig_open (copy_open_description x0)\n | Ast_414.Parsetree.Psig_include x0 ->\n Ast_413.Parsetree.Psig_include (copy_include_description x0)\n | Ast_414.Parsetree.Psig_class x0 ->\n Ast_413.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_414.Parsetree.Psig_class_type x0 ->\n Ast_413.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_414.Parsetree.Psig_attribute x0 ->\n Ast_413.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_414.Parsetree.Psig_extension (x0, x1) ->\n Ast_413.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_414.Parsetree.class_type_declaration ->\n Ast_413.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_414.Parsetree.class_description -> Ast_413.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_414.Parsetree.class_type -> Ast_413.Parsetree.class_type =\n fun {\n Ast_414.Parsetree.pcty_desc;\n Ast_414.Parsetree.pcty_loc;\n Ast_414.Parsetree.pcty_attributes;\n } ->\n {\n Ast_413.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_413.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_413.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_414.Parsetree.class_type_desc -> Ast_413.Parsetree.class_type_desc =\n function\n | Ast_414.Parsetree.Pcty_constr (x0, x1) ->\n Ast_413.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_414.Parsetree.Pcty_signature x0 ->\n Ast_413.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_414.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_413.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_414.Parsetree.Pcty_extension x0 ->\n Ast_413.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_414.Parsetree.Pcty_open (x0, x1) ->\n Ast_413.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_414.Parsetree.class_signature -> Ast_413.Parsetree.class_signature =\n fun { Ast_414.Parsetree.pcsig_self; Ast_414.Parsetree.pcsig_fields } ->\n {\n Ast_413.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_413.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_414.Parsetree.class_type_field -> Ast_413.Parsetree.class_type_field =\n fun {\n Ast_414.Parsetree.pctf_desc;\n Ast_414.Parsetree.pctf_loc;\n Ast_414.Parsetree.pctf_attributes;\n } ->\n {\n Ast_413.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_413.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_413.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_414.Parsetree.class_type_field_desc ->\n Ast_413.Parsetree.class_type_field_desc = function\n | Ast_414.Parsetree.Pctf_inherit x0 ->\n Ast_413.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_414.Parsetree.Pctf_val x0 ->\n Ast_413.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_414.Parsetree.Pctf_method x0 ->\n Ast_413.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_414.Parsetree.Pctf_constraint x0 ->\n Ast_413.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_414.Parsetree.Pctf_attribute x0 ->\n Ast_413.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_414.Parsetree.Pctf_extension x0 ->\n Ast_413.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_414.Parsetree.extension -> Ast_413.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_414.Parsetree.class_infos ->\n 'g0 Ast_413.Parsetree.class_infos =\n fun f0\n {\n Ast_414.Parsetree.pci_virt;\n Ast_414.Parsetree.pci_params;\n Ast_414.Parsetree.pci_name;\n Ast_414.Parsetree.pci_expr;\n Ast_414.Parsetree.pci_loc;\n Ast_414.Parsetree.pci_attributes;\n } ->\n {\n Ast_413.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_413.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n pci_params;\n Ast_413.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_413.Parsetree.pci_expr = f0 pci_expr;\n Ast_413.Parsetree.pci_loc = copy_location pci_loc;\n Ast_413.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_414.Asttypes.virtual_flag -> Ast_413.Asttypes.virtual_flag = function\n | Ast_414.Asttypes.Virtual -> Ast_413.Asttypes.Virtual\n | Ast_414.Asttypes.Concrete -> Ast_413.Asttypes.Concrete\n\nand copy_include_description :\n Ast_414.Parsetree.include_description ->\n Ast_413.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_414.Parsetree.include_infos ->\n 'g0 Ast_413.Parsetree.include_infos =\n fun f0\n {\n Ast_414.Parsetree.pincl_mod;\n Ast_414.Parsetree.pincl_loc;\n Ast_414.Parsetree.pincl_attributes;\n } ->\n {\n Ast_413.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_413.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_413.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_414.Parsetree.open_description -> Ast_413.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_414.Parsetree.open_infos ->\n 'g0 Ast_413.Parsetree.open_infos =\n fun f0\n {\n Ast_414.Parsetree.popen_expr;\n Ast_414.Parsetree.popen_override;\n Ast_414.Parsetree.popen_loc;\n Ast_414.Parsetree.popen_attributes;\n } ->\n {\n Ast_413.Parsetree.popen_expr = f0 popen_expr;\n Ast_413.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_413.Parsetree.popen_loc = copy_location popen_loc;\n Ast_413.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_414.Asttypes.override_flag -> Ast_413.Asttypes.override_flag = function\n | Ast_414.Asttypes.Override -> Ast_413.Asttypes.Override\n | Ast_414.Asttypes.Fresh -> Ast_413.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_414.Parsetree.module_type_declaration ->\n Ast_413.Parsetree.module_type_declaration =\n fun {\n Ast_414.Parsetree.pmtd_name;\n Ast_414.Parsetree.pmtd_type;\n Ast_414.Parsetree.pmtd_attributes;\n Ast_414.Parsetree.pmtd_loc;\n } ->\n {\n Ast_413.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_413.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_413.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_413.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_414.Parsetree.module_substitution ->\n Ast_413.Parsetree.module_substitution =\n fun {\n Ast_414.Parsetree.pms_name;\n Ast_414.Parsetree.pms_manifest;\n Ast_414.Parsetree.pms_attributes;\n Ast_414.Parsetree.pms_loc;\n } ->\n {\n Ast_413.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_413.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_413.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_413.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_414.Parsetree.module_declaration -> Ast_413.Parsetree.module_declaration\n =\n fun {\n Ast_414.Parsetree.pmd_name;\n Ast_414.Parsetree.pmd_type;\n Ast_414.Parsetree.pmd_attributes;\n Ast_414.Parsetree.pmd_loc;\n } ->\n {\n Ast_413.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_413.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_413.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_413.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_414.Parsetree.type_exception -> Ast_413.Parsetree.type_exception =\n fun {\n Ast_414.Parsetree.ptyexn_constructor;\n Ast_414.Parsetree.ptyexn_loc;\n Ast_414.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_413.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_413.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_414.Parsetree.type_extension -> Ast_413.Parsetree.type_extension =\n fun {\n Ast_414.Parsetree.ptyext_path;\n Ast_414.Parsetree.ptyext_params;\n Ast_414.Parsetree.ptyext_constructors;\n Ast_414.Parsetree.ptyext_private;\n Ast_414.Parsetree.ptyext_loc;\n Ast_414.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_413.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptyext_params;\n Ast_413.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_413.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_413.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_413.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_414.Parsetree.extension_constructor ->\n Ast_413.Parsetree.extension_constructor =\n fun {\n Ast_414.Parsetree.pext_name;\n Ast_414.Parsetree.pext_kind;\n Ast_414.Parsetree.pext_loc;\n Ast_414.Parsetree.pext_attributes;\n } ->\n {\n Ast_413.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_413.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_413.Parsetree.pext_loc = copy_location pext_loc;\n Ast_413.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_414.Parsetree.extension_constructor_kind ->\n Ast_413.Parsetree.extension_constructor_kind = function\n | Ast_414.Parsetree.Pext_decl (x0, x1, x2) -> (\n match x0 with\n | [] ->\n Ast_413.Parsetree.Pext_decl\n (copy_constructor_arguments x1, Option.map copy_core_type x2)\n | hd :: _ ->\n migration_error hd.loc \"type parameters in extension constructors\")\n | Ast_414.Parsetree.Pext_rebind x0 ->\n Ast_413.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_414.Parsetree.type_declaration -> Ast_413.Parsetree.type_declaration =\n fun {\n Ast_414.Parsetree.ptype_name;\n Ast_414.Parsetree.ptype_params;\n Ast_414.Parsetree.ptype_cstrs;\n Ast_414.Parsetree.ptype_kind;\n Ast_414.Parsetree.ptype_private;\n Ast_414.Parsetree.ptype_manifest;\n Ast_414.Parsetree.ptype_attributes;\n Ast_414.Parsetree.ptype_loc;\n } ->\n {\n Ast_413.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_413.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptype_params;\n Ast_413.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_413.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_413.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_413.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_413.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_413.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_414.Asttypes.private_flag -> Ast_413.Asttypes.private_flag = function\n | Ast_414.Asttypes.Private -> Ast_413.Asttypes.Private\n | Ast_414.Asttypes.Public -> Ast_413.Asttypes.Public\n\nand copy_type_kind : Ast_414.Parsetree.type_kind -> Ast_413.Parsetree.type_kind\n = function\n | Ast_414.Parsetree.Ptype_abstract -> Ast_413.Parsetree.Ptype_abstract\n | Ast_414.Parsetree.Ptype_variant x0 ->\n Ast_413.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_414.Parsetree.Ptype_record x0 ->\n Ast_413.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_414.Parsetree.Ptype_open -> Ast_413.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_414.Parsetree.constructor_declaration ->\n Ast_413.Parsetree.constructor_declaration =\n fun {\n Ast_414.Parsetree.pcd_name;\n Ast_414.Parsetree.pcd_vars;\n Ast_414.Parsetree.pcd_args;\n Ast_414.Parsetree.pcd_res;\n Ast_414.Parsetree.pcd_loc;\n Ast_414.Parsetree.pcd_attributes;\n } ->\n match pcd_vars with\n | [] ->\n {\n Ast_413.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_413.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_413.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_413.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_413.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n | hd :: _ -> migration_error hd.loc \"pcd_vars in constructor declarations\"\n\nand copy_constructor_arguments :\n Ast_414.Parsetree.constructor_arguments ->\n Ast_413.Parsetree.constructor_arguments = function\n | Ast_414.Parsetree.Pcstr_tuple x0 ->\n Ast_413.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_414.Parsetree.Pcstr_record x0 ->\n Ast_413.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_414.Parsetree.label_declaration -> Ast_413.Parsetree.label_declaration =\n fun {\n Ast_414.Parsetree.pld_name;\n Ast_414.Parsetree.pld_mutable;\n Ast_414.Parsetree.pld_type;\n Ast_414.Parsetree.pld_loc;\n Ast_414.Parsetree.pld_attributes;\n } ->\n {\n Ast_413.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_413.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_413.Parsetree.pld_type = copy_core_type pld_type;\n Ast_413.Parsetree.pld_loc = copy_location pld_loc;\n Ast_413.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_414.Asttypes.mutable_flag -> Ast_413.Asttypes.mutable_flag = function\n | Ast_414.Asttypes.Immutable -> Ast_413.Asttypes.Immutable\n | Ast_414.Asttypes.Mutable -> Ast_413.Asttypes.Mutable\n\nand copy_injectivity :\n Ast_414.Asttypes.injectivity -> Ast_413.Asttypes.injectivity = function\n | Ast_414.Asttypes.Injective -> Ast_413.Asttypes.Injective\n | Ast_414.Asttypes.NoInjectivity -> Ast_413.Asttypes.NoInjectivity\n\nand copy_variance : Ast_414.Asttypes.variance -> Ast_413.Asttypes.variance =\n function\n | Ast_414.Asttypes.Covariant -> Ast_413.Asttypes.Covariant\n | Ast_414.Asttypes.Contravariant -> Ast_413.Asttypes.Contravariant\n | Ast_414.Asttypes.NoVariance -> Ast_413.Asttypes.NoVariance\n\nand copy_value_description :\n Ast_414.Parsetree.value_description -> Ast_413.Parsetree.value_description =\n fun {\n Ast_414.Parsetree.pval_name;\n Ast_414.Parsetree.pval_type;\n Ast_414.Parsetree.pval_prim;\n Ast_414.Parsetree.pval_attributes;\n Ast_414.Parsetree.pval_loc;\n } ->\n {\n Ast_413.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_413.Parsetree.pval_type = copy_core_type pval_type;\n Ast_413.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_413.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_413.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_414.Parsetree.object_field_desc -> Ast_413.Parsetree.object_field_desc =\n function\n | Ast_414.Parsetree.Otag (x0, x1) ->\n Ast_413.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_414.Parsetree.Oinherit x0 ->\n Ast_413.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_414.Asttypes.arg_label -> Ast_413.Asttypes.arg_label =\n function\n | Ast_414.Asttypes.Nolabel -> Ast_413.Asttypes.Nolabel\n | Ast_414.Asttypes.Labelled x0 -> Ast_413.Asttypes.Labelled x0\n | Ast_414.Asttypes.Optional x0 -> Ast_413.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_414.Asttypes.closed_flag -> Ast_413.Asttypes.closed_flag = function\n | Ast_414.Asttypes.Closed -> Ast_413.Asttypes.Closed\n | Ast_414.Asttypes.Open -> Ast_413.Asttypes.Open\n\nand copy_label : Ast_414.Asttypes.label -> Ast_413.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_414.Asttypes.rec_flag -> Ast_413.Asttypes.rec_flag =\n function\n | Ast_414.Asttypes.Nonrecursive -> Ast_413.Asttypes.Nonrecursive\n | Ast_414.Asttypes.Recursive -> Ast_413.Asttypes.Recursive\n\nand copy_constant : Ast_414.Parsetree.constant -> Ast_413.Parsetree.constant =\n function\n | Ast_414.Parsetree.Pconst_integer (x0, x1) ->\n Ast_413.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_414.Parsetree.Pconst_char x0 -> Ast_413.Parsetree.Pconst_char x0\n | Ast_414.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_413.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_414.Parsetree.Pconst_float (x0, x1) ->\n Ast_413.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_414.Asttypes.loc -> 'g0 Ast_413.Asttypes.loc =\n fun f0 { Ast_414.Asttypes.txt; Ast_414.Asttypes.loc } ->\n { Ast_413.Asttypes.txt = f0 txt; Ast_413.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_413\nmodule To = Ast_414\n\nlet rec copy_toplevel_phrase :\n Ast_413.Parsetree.toplevel_phrase -> Ast_414.Parsetree.toplevel_phrase =\n function\n | Ast_413.Parsetree.Ptop_def x0 ->\n Ast_414.Parsetree.Ptop_def (copy_structure x0)\n | Ast_413.Parsetree.Ptop_dir x0 ->\n Ast_414.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_413.Parsetree.toplevel_directive -> Ast_414.Parsetree.toplevel_directive\n =\n fun {\n Ast_413.Parsetree.pdir_name;\n Ast_413.Parsetree.pdir_arg;\n Ast_413.Parsetree.pdir_loc;\n } ->\n {\n Ast_414.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_414.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_414.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_413.Parsetree.directive_argument -> Ast_414.Parsetree.directive_argument\n =\n fun { Ast_413.Parsetree.pdira_desc; Ast_413.Parsetree.pdira_loc } ->\n {\n Ast_414.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_414.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_413.Parsetree.directive_argument_desc ->\n Ast_414.Parsetree.directive_argument_desc = function\n | Ast_413.Parsetree.Pdir_string x0 -> Ast_414.Parsetree.Pdir_string x0\n | Ast_413.Parsetree.Pdir_int (x0, x1) ->\n Ast_414.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_413.Parsetree.Pdir_ident x0 ->\n Ast_414.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_413.Parsetree.Pdir_bool x0 -> Ast_414.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_413.Parsetree.expression -> Ast_414.Parsetree.expression =\n fun {\n Ast_413.Parsetree.pexp_desc;\n Ast_413.Parsetree.pexp_loc;\n Ast_413.Parsetree.pexp_loc_stack;\n Ast_413.Parsetree.pexp_attributes;\n } ->\n {\n Ast_414.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_414.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_414.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_414.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_413.Parsetree.expression_desc -> Ast_414.Parsetree.expression_desc =\n function\n | Ast_413.Parsetree.Pexp_ident x0 ->\n Ast_414.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pexp_constant x0 ->\n Ast_414.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_413.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_414.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_413.Parsetree.Pexp_function x0 ->\n Ast_414.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_413.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_414.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_413.Parsetree.Pexp_apply (x0, x1) ->\n Ast_414.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_413.Parsetree.Pexp_match (x0, x1) ->\n Ast_414.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_413.Parsetree.Pexp_try (x0, x1) ->\n Ast_414.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_413.Parsetree.Pexp_tuple x0 ->\n Ast_414.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_413.Parsetree.Pexp_construct (x0, x1) ->\n Ast_414.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_413.Parsetree.Pexp_variant (x0, x1) ->\n Ast_414.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_413.Parsetree.Pexp_record (x0, x1) ->\n Ast_414.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_413.Parsetree.Pexp_field (x0, x1) ->\n Ast_414.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_413.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_414.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_413.Parsetree.Pexp_array x0 ->\n Ast_414.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_413.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_414.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_413.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_414.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_while (x0, x1) ->\n Ast_414.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_414.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_413.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_414.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_413.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_414.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_413.Parsetree.Pexp_send (x0, x1) ->\n Ast_414.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_413.Parsetree.Pexp_new x0 ->\n Ast_414.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_414.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_override x0 ->\n Ast_414.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_413.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_414.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_413.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_414.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_assert x0 ->\n Ast_414.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_413.Parsetree.Pexp_lazy x0 ->\n Ast_414.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_413.Parsetree.Pexp_poly (x0, x1) ->\n Ast_414.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_413.Parsetree.Pexp_object x0 ->\n Ast_414.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_413.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_414.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_pack x0 ->\n Ast_414.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_413.Parsetree.Pexp_open (x0, x1) ->\n Ast_414.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_letop x0 ->\n Ast_414.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_413.Parsetree.Pexp_extension x0 ->\n Ast_414.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_413.Parsetree.Pexp_unreachable -> Ast_414.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_413.Parsetree.letop -> Ast_414.Parsetree.letop =\n fun { Ast_413.Parsetree.let_; Ast_413.Parsetree.ands; Ast_413.Parsetree.body } ->\n {\n Ast_414.Parsetree.let_ = copy_binding_op let_;\n Ast_414.Parsetree.ands = List.map copy_binding_op ands;\n Ast_414.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_413.Parsetree.binding_op -> Ast_414.Parsetree.binding_op =\n fun {\n Ast_413.Parsetree.pbop_op;\n Ast_413.Parsetree.pbop_pat;\n Ast_413.Parsetree.pbop_exp;\n Ast_413.Parsetree.pbop_loc;\n } ->\n {\n Ast_414.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_414.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_414.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_414.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_413.Asttypes.direction_flag -> Ast_414.Asttypes.direction_flag =\n function\n | Ast_413.Asttypes.Upto -> Ast_414.Asttypes.Upto\n | Ast_413.Asttypes.Downto -> Ast_414.Asttypes.Downto\n\nand copy_case : Ast_413.Parsetree.case -> Ast_414.Parsetree.case =\n fun {\n Ast_413.Parsetree.pc_lhs;\n Ast_413.Parsetree.pc_guard;\n Ast_413.Parsetree.pc_rhs;\n } ->\n {\n Ast_414.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_414.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_414.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_413.Parsetree.value_binding -> Ast_414.Parsetree.value_binding =\n fun {\n Ast_413.Parsetree.pvb_pat;\n Ast_413.Parsetree.pvb_expr;\n Ast_413.Parsetree.pvb_attributes;\n Ast_413.Parsetree.pvb_loc;\n } ->\n {\n Ast_414.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_414.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_414.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_414.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_413.Parsetree.pattern -> Ast_414.Parsetree.pattern =\n fun {\n Ast_413.Parsetree.ppat_desc;\n Ast_413.Parsetree.ppat_loc;\n Ast_413.Parsetree.ppat_loc_stack;\n Ast_413.Parsetree.ppat_attributes;\n } ->\n {\n Ast_414.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_414.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_414.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_414.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_413.Parsetree.pattern_desc -> Ast_414.Parsetree.pattern_desc = function\n | Ast_413.Parsetree.Ppat_any -> Ast_414.Parsetree.Ppat_any\n | Ast_413.Parsetree.Ppat_var x0 ->\n Ast_414.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_413.Parsetree.Ppat_alias (x0, x1) ->\n Ast_414.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_413.Parsetree.Ppat_constant x0 ->\n Ast_414.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_413.Parsetree.Ppat_interval (x0, x1) ->\n Ast_414.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_413.Parsetree.Ppat_tuple x0 ->\n Ast_414.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_413.Parsetree.Ppat_construct (x0, x1) ->\n Ast_414.Parsetree.Ppat_construct\n ( copy_loc copy_Longident_t x0,\n Option.map\n (fun x ->\n let x0, x1 = x in\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_pattern x1))\n x1 )\n | Ast_413.Parsetree.Ppat_variant (x0, x1) ->\n Ast_414.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_413.Parsetree.Ppat_record (x0, x1) ->\n Ast_414.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_413.Parsetree.Ppat_array x0 ->\n Ast_414.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_413.Parsetree.Ppat_or (x0, x1) ->\n Ast_414.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_413.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_414.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_413.Parsetree.Ppat_type x0 ->\n Ast_414.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Ppat_lazy x0 ->\n Ast_414.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_413.Parsetree.Ppat_unpack x0 ->\n Ast_414.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_413.Parsetree.Ppat_exception x0 ->\n Ast_414.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_413.Parsetree.Ppat_extension x0 ->\n Ast_414.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_413.Parsetree.Ppat_open (x0, x1) ->\n Ast_414.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_413.Parsetree.core_type -> Ast_414.Parsetree.core_type\n =\n fun {\n Ast_413.Parsetree.ptyp_desc;\n Ast_413.Parsetree.ptyp_loc;\n Ast_413.Parsetree.ptyp_loc_stack;\n Ast_413.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_414.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_414.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_414.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_414.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_413.Parsetree.location_stack -> Ast_414.Parsetree.location_stack =\n fun x -> x\n\nand copy_core_type_desc :\n Ast_413.Parsetree.core_type_desc -> Ast_414.Parsetree.core_type_desc =\n function\n | Ast_413.Parsetree.Ptyp_any -> Ast_414.Parsetree.Ptyp_any\n | Ast_413.Parsetree.Ptyp_var x0 -> Ast_414.Parsetree.Ptyp_var x0\n | Ast_413.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_414.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_413.Parsetree.Ptyp_tuple x0 ->\n Ast_414.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_413.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_414.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_object (x0, x1) ->\n Ast_414.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_413.Parsetree.Ptyp_class (x0, x1) ->\n Ast_414.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_414.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_413.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_414.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_413.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_414.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_package x0 ->\n Ast_414.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_413.Parsetree.Ptyp_extension x0 ->\n Ast_414.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_413.Parsetree.package_type -> Ast_414.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_413.Parsetree.row_field -> Ast_414.Parsetree.row_field\n =\n fun {\n Ast_413.Parsetree.prf_desc;\n Ast_413.Parsetree.prf_loc;\n Ast_413.Parsetree.prf_attributes;\n } ->\n {\n Ast_414.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_414.Parsetree.prf_loc = copy_location prf_loc;\n Ast_414.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_413.Parsetree.row_field_desc -> Ast_414.Parsetree.row_field_desc =\n function\n | Ast_413.Parsetree.Rtag (x0, x1, x2) ->\n Ast_414.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_413.Parsetree.Rinherit x0 ->\n Ast_414.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_413.Parsetree.object_field -> Ast_414.Parsetree.object_field =\n fun {\n Ast_413.Parsetree.pof_desc;\n Ast_413.Parsetree.pof_loc;\n Ast_413.Parsetree.pof_attributes;\n } ->\n {\n Ast_414.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_414.Parsetree.pof_loc = copy_location pof_loc;\n Ast_414.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_413.Parsetree.attributes -> Ast_414.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_413.Parsetree.attribute -> Ast_414.Parsetree.attribute\n =\n fun {\n Ast_413.Parsetree.attr_name;\n Ast_413.Parsetree.attr_payload;\n Ast_413.Parsetree.attr_loc;\n } ->\n {\n Ast_414.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_414.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_414.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_413.Parsetree.payload -> Ast_414.Parsetree.payload =\n function\n | Ast_413.Parsetree.PStr x0 -> Ast_414.Parsetree.PStr (copy_structure x0)\n | Ast_413.Parsetree.PSig x0 -> Ast_414.Parsetree.PSig (copy_signature x0)\n | Ast_413.Parsetree.PTyp x0 -> Ast_414.Parsetree.PTyp (copy_core_type x0)\n | Ast_413.Parsetree.PPat (x0, x1) ->\n Ast_414.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_413.Parsetree.structure -> Ast_414.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_413.Parsetree.structure_item -> Ast_414.Parsetree.structure_item =\n fun { Ast_413.Parsetree.pstr_desc; Ast_413.Parsetree.pstr_loc } ->\n {\n Ast_414.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_414.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_413.Parsetree.structure_item_desc ->\n Ast_414.Parsetree.structure_item_desc = function\n | Ast_413.Parsetree.Pstr_eval (x0, x1) ->\n Ast_414.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_413.Parsetree.Pstr_value (x0, x1) ->\n Ast_414.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_413.Parsetree.Pstr_primitive x0 ->\n Ast_414.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_413.Parsetree.Pstr_type (x0, x1) ->\n Ast_414.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_413.Parsetree.Pstr_typext x0 ->\n Ast_414.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_413.Parsetree.Pstr_exception x0 ->\n Ast_414.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_413.Parsetree.Pstr_module x0 ->\n Ast_414.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_413.Parsetree.Pstr_recmodule x0 ->\n Ast_414.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_413.Parsetree.Pstr_modtype x0 ->\n Ast_414.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_413.Parsetree.Pstr_open x0 ->\n Ast_414.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_413.Parsetree.Pstr_class x0 ->\n Ast_414.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_413.Parsetree.Pstr_class_type x0 ->\n Ast_414.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_413.Parsetree.Pstr_include x0 ->\n Ast_414.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_413.Parsetree.Pstr_attribute x0 ->\n Ast_414.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pstr_extension (x0, x1) ->\n Ast_414.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_413.Parsetree.include_declaration ->\n Ast_414.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_413.Parsetree.class_declaration -> Ast_414.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_413.Parsetree.class_expr -> Ast_414.Parsetree.class_expr =\n fun {\n Ast_413.Parsetree.pcl_desc;\n Ast_413.Parsetree.pcl_loc;\n Ast_413.Parsetree.pcl_attributes;\n } ->\n {\n Ast_414.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_414.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_414.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_413.Parsetree.class_expr_desc -> Ast_414.Parsetree.class_expr_desc =\n function\n | Ast_413.Parsetree.Pcl_constr (x0, x1) ->\n Ast_414.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Pcl_structure x0 ->\n Ast_414.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_413.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_414.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_413.Parsetree.Pcl_apply (x0, x1) ->\n Ast_414.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_413.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_414.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_413.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_414.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_413.Parsetree.Pcl_extension x0 ->\n Ast_414.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_413.Parsetree.Pcl_open (x0, x1) ->\n Ast_414.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_413.Parsetree.class_structure -> Ast_414.Parsetree.class_structure =\n fun { Ast_413.Parsetree.pcstr_self; Ast_413.Parsetree.pcstr_fields } ->\n {\n Ast_414.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_414.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_413.Parsetree.class_field -> Ast_414.Parsetree.class_field =\n fun {\n Ast_413.Parsetree.pcf_desc;\n Ast_413.Parsetree.pcf_loc;\n Ast_413.Parsetree.pcf_attributes;\n } ->\n {\n Ast_414.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_414.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_414.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_413.Parsetree.class_field_desc -> Ast_414.Parsetree.class_field_desc =\n function\n | Ast_413.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_414.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_413.Parsetree.Pcf_val x0 ->\n Ast_414.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_413.Parsetree.Pcf_method x0 ->\n Ast_414.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_413.Parsetree.Pcf_constraint x0 ->\n Ast_414.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_413.Parsetree.Pcf_initializer x0 ->\n Ast_414.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_413.Parsetree.Pcf_attribute x0 ->\n Ast_414.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pcf_extension x0 ->\n Ast_414.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_413.Parsetree.class_field_kind -> Ast_414.Parsetree.class_field_kind =\n function\n | Ast_413.Parsetree.Cfk_virtual x0 ->\n Ast_414.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_413.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_414.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_413.Parsetree.open_declaration -> Ast_414.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_413.Parsetree.module_binding -> Ast_414.Parsetree.module_binding =\n fun {\n Ast_413.Parsetree.pmb_name;\n Ast_413.Parsetree.pmb_expr;\n Ast_413.Parsetree.pmb_attributes;\n Ast_413.Parsetree.pmb_loc;\n } ->\n {\n Ast_414.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_414.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_414.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_414.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_413.Parsetree.module_expr -> Ast_414.Parsetree.module_expr =\n fun {\n Ast_413.Parsetree.pmod_desc;\n Ast_413.Parsetree.pmod_loc;\n Ast_413.Parsetree.pmod_attributes;\n } ->\n {\n Ast_414.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_414.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_414.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_413.Parsetree.module_expr_desc -> Ast_414.Parsetree.module_expr_desc =\n function\n | Ast_413.Parsetree.Pmod_ident x0 ->\n Ast_414.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pmod_structure x0 ->\n Ast_414.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_413.Parsetree.Pmod_functor (x0, x1) ->\n Ast_414.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_413.Parsetree.Pmod_apply (x0, x1) ->\n Ast_414.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_413.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_414.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_413.Parsetree.Pmod_unpack x0 ->\n Ast_414.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_413.Parsetree.Pmod_extension x0 ->\n Ast_414.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_413.Parsetree.functor_parameter -> Ast_414.Parsetree.functor_parameter =\n function\n | Ast_413.Parsetree.Unit -> Ast_414.Parsetree.Unit\n | Ast_413.Parsetree.Named (x0, x1) ->\n Ast_414.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_413.Parsetree.module_type -> Ast_414.Parsetree.module_type =\n fun {\n Ast_413.Parsetree.pmty_desc;\n Ast_413.Parsetree.pmty_loc;\n Ast_413.Parsetree.pmty_attributes;\n } ->\n {\n Ast_414.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_414.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_414.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_413.Parsetree.module_type_desc -> Ast_414.Parsetree.module_type_desc =\n function\n | Ast_413.Parsetree.Pmty_ident x0 ->\n Ast_414.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pmty_signature x0 ->\n Ast_414.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_413.Parsetree.Pmty_functor (x0, x1) ->\n Ast_414.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_413.Parsetree.Pmty_with (x0, x1) ->\n Ast_414.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_413.Parsetree.Pmty_typeof x0 ->\n Ast_414.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_413.Parsetree.Pmty_extension x0 ->\n Ast_414.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_413.Parsetree.Pmty_alias x0 ->\n Ast_414.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_413.Parsetree.with_constraint -> Ast_414.Parsetree.with_constraint =\n function\n | Ast_413.Parsetree.Pwith_type (x0, x1) ->\n Ast_414.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_413.Parsetree.Pwith_module (x0, x1) ->\n Ast_414.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_413.Parsetree.Pwith_modtype (x0, x1) ->\n Ast_414.Parsetree.Pwith_modtype\n (copy_loc copy_Longident_t x0, copy_module_type x1)\n | Ast_413.Parsetree.Pwith_modtypesubst (x0, x1) ->\n Ast_414.Parsetree.Pwith_modtypesubst\n (copy_loc copy_Longident_t x0, copy_module_type x1)\n | Ast_413.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_414.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_413.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_414.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_413.Parsetree.signature -> Ast_414.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_413.Parsetree.signature_item -> Ast_414.Parsetree.signature_item =\n fun { Ast_413.Parsetree.psig_desc; Ast_413.Parsetree.psig_loc } ->\n {\n Ast_414.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_414.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_413.Parsetree.signature_item_desc ->\n Ast_414.Parsetree.signature_item_desc = function\n | Ast_413.Parsetree.Psig_value x0 ->\n Ast_414.Parsetree.Psig_value (copy_value_description x0)\n | Ast_413.Parsetree.Psig_type (x0, x1) ->\n Ast_414.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_413.Parsetree.Psig_typesubst x0 ->\n Ast_414.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_413.Parsetree.Psig_typext x0 ->\n Ast_414.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_413.Parsetree.Psig_exception x0 ->\n Ast_414.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_413.Parsetree.Psig_module x0 ->\n Ast_414.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_413.Parsetree.Psig_modsubst x0 ->\n Ast_414.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_413.Parsetree.Psig_recmodule x0 ->\n Ast_414.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_413.Parsetree.Psig_modtype x0 ->\n Ast_414.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_413.Parsetree.Psig_modtypesubst x0 ->\n Ast_414.Parsetree.Psig_modtypesubst (copy_module_type_declaration x0)\n | Ast_413.Parsetree.Psig_open x0 ->\n Ast_414.Parsetree.Psig_open (copy_open_description x0)\n | Ast_413.Parsetree.Psig_include x0 ->\n Ast_414.Parsetree.Psig_include (copy_include_description x0)\n | Ast_413.Parsetree.Psig_class x0 ->\n Ast_414.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_413.Parsetree.Psig_class_type x0 ->\n Ast_414.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_413.Parsetree.Psig_attribute x0 ->\n Ast_414.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Psig_extension (x0, x1) ->\n Ast_414.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_413.Parsetree.class_type_declaration ->\n Ast_414.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_413.Parsetree.class_description -> Ast_414.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_413.Parsetree.class_type -> Ast_414.Parsetree.class_type =\n fun {\n Ast_413.Parsetree.pcty_desc;\n Ast_413.Parsetree.pcty_loc;\n Ast_413.Parsetree.pcty_attributes;\n } ->\n {\n Ast_414.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_414.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_414.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_413.Parsetree.class_type_desc -> Ast_414.Parsetree.class_type_desc =\n function\n | Ast_413.Parsetree.Pcty_constr (x0, x1) ->\n Ast_414.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Pcty_signature x0 ->\n Ast_414.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_413.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_414.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_413.Parsetree.Pcty_extension x0 ->\n Ast_414.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_413.Parsetree.Pcty_open (x0, x1) ->\n Ast_414.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_413.Parsetree.class_signature -> Ast_414.Parsetree.class_signature =\n fun { Ast_413.Parsetree.pcsig_self; Ast_413.Parsetree.pcsig_fields } ->\n {\n Ast_414.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_414.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_413.Parsetree.class_type_field -> Ast_414.Parsetree.class_type_field =\n fun {\n Ast_413.Parsetree.pctf_desc;\n Ast_413.Parsetree.pctf_loc;\n Ast_413.Parsetree.pctf_attributes;\n } ->\n {\n Ast_414.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_414.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_414.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_413.Parsetree.class_type_field_desc ->\n Ast_414.Parsetree.class_type_field_desc = function\n | Ast_413.Parsetree.Pctf_inherit x0 ->\n Ast_414.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_413.Parsetree.Pctf_val x0 ->\n Ast_414.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_413.Parsetree.Pctf_method x0 ->\n Ast_414.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_413.Parsetree.Pctf_constraint x0 ->\n Ast_414.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_413.Parsetree.Pctf_attribute x0 ->\n Ast_414.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pctf_extension x0 ->\n Ast_414.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_413.Parsetree.extension -> Ast_414.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.class_infos ->\n 'g0 Ast_414.Parsetree.class_infos =\n fun f0\n {\n Ast_413.Parsetree.pci_virt;\n Ast_413.Parsetree.pci_params;\n Ast_413.Parsetree.pci_name;\n Ast_413.Parsetree.pci_expr;\n Ast_413.Parsetree.pci_loc;\n Ast_413.Parsetree.pci_attributes;\n } ->\n {\n Ast_414.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_414.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n pci_params;\n Ast_414.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_414.Parsetree.pci_expr = f0 pci_expr;\n Ast_414.Parsetree.pci_loc = copy_location pci_loc;\n Ast_414.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_413.Asttypes.virtual_flag -> Ast_414.Asttypes.virtual_flag = function\n | Ast_413.Asttypes.Virtual -> Ast_414.Asttypes.Virtual\n | Ast_413.Asttypes.Concrete -> Ast_414.Asttypes.Concrete\n\nand copy_include_description :\n Ast_413.Parsetree.include_description ->\n Ast_414.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.include_infos ->\n 'g0 Ast_414.Parsetree.include_infos =\n fun f0\n {\n Ast_413.Parsetree.pincl_mod;\n Ast_413.Parsetree.pincl_loc;\n Ast_413.Parsetree.pincl_attributes;\n } ->\n {\n Ast_414.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_414.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_414.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_413.Parsetree.open_description -> Ast_414.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.open_infos ->\n 'g0 Ast_414.Parsetree.open_infos =\n fun f0\n {\n Ast_413.Parsetree.popen_expr;\n Ast_413.Parsetree.popen_override;\n Ast_413.Parsetree.popen_loc;\n Ast_413.Parsetree.popen_attributes;\n } ->\n {\n Ast_414.Parsetree.popen_expr = f0 popen_expr;\n Ast_414.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_414.Parsetree.popen_loc = copy_location popen_loc;\n Ast_414.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_413.Asttypes.override_flag -> Ast_414.Asttypes.override_flag = function\n | Ast_413.Asttypes.Override -> Ast_414.Asttypes.Override\n | Ast_413.Asttypes.Fresh -> Ast_414.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_413.Parsetree.module_type_declaration ->\n Ast_414.Parsetree.module_type_declaration =\n fun {\n Ast_413.Parsetree.pmtd_name;\n Ast_413.Parsetree.pmtd_type;\n Ast_413.Parsetree.pmtd_attributes;\n Ast_413.Parsetree.pmtd_loc;\n } ->\n {\n Ast_414.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_414.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_414.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_414.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_413.Parsetree.module_substitution ->\n Ast_414.Parsetree.module_substitution =\n fun {\n Ast_413.Parsetree.pms_name;\n Ast_413.Parsetree.pms_manifest;\n Ast_413.Parsetree.pms_attributes;\n Ast_413.Parsetree.pms_loc;\n } ->\n {\n Ast_414.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_414.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_414.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_414.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_413.Parsetree.module_declaration -> Ast_414.Parsetree.module_declaration\n =\n fun {\n Ast_413.Parsetree.pmd_name;\n Ast_413.Parsetree.pmd_type;\n Ast_413.Parsetree.pmd_attributes;\n Ast_413.Parsetree.pmd_loc;\n } ->\n {\n Ast_414.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_414.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_414.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_414.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_413.Parsetree.type_exception -> Ast_414.Parsetree.type_exception =\n fun {\n Ast_413.Parsetree.ptyexn_constructor;\n Ast_413.Parsetree.ptyexn_loc;\n Ast_413.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_414.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_414.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_414.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_413.Parsetree.type_extension -> Ast_414.Parsetree.type_extension =\n fun {\n Ast_413.Parsetree.ptyext_path;\n Ast_413.Parsetree.ptyext_params;\n Ast_413.Parsetree.ptyext_constructors;\n Ast_413.Parsetree.ptyext_private;\n Ast_413.Parsetree.ptyext_loc;\n Ast_413.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_414.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_414.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptyext_params;\n Ast_414.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_414.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_414.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_414.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_413.Parsetree.extension_constructor ->\n Ast_414.Parsetree.extension_constructor =\n fun {\n Ast_413.Parsetree.pext_name;\n Ast_413.Parsetree.pext_kind;\n Ast_413.Parsetree.pext_loc;\n Ast_413.Parsetree.pext_attributes;\n } ->\n {\n Ast_414.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_414.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_414.Parsetree.pext_loc = copy_location pext_loc;\n Ast_414.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_413.Parsetree.extension_constructor_kind ->\n Ast_414.Parsetree.extension_constructor_kind = function\n | Ast_413.Parsetree.Pext_decl (x0, x1) ->\n Ast_414.Parsetree.Pext_decl\n ([], copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_413.Parsetree.Pext_rebind x0 ->\n Ast_414.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_413.Parsetree.type_declaration -> Ast_414.Parsetree.type_declaration =\n fun {\n Ast_413.Parsetree.ptype_name;\n Ast_413.Parsetree.ptype_params;\n Ast_413.Parsetree.ptype_cstrs;\n Ast_413.Parsetree.ptype_kind;\n Ast_413.Parsetree.ptype_private;\n Ast_413.Parsetree.ptype_manifest;\n Ast_413.Parsetree.ptype_attributes;\n Ast_413.Parsetree.ptype_loc;\n } ->\n {\n Ast_414.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_414.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptype_params;\n Ast_414.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_414.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_414.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_414.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_414.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_414.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_413.Asttypes.private_flag -> Ast_414.Asttypes.private_flag = function\n | Ast_413.Asttypes.Private -> Ast_414.Asttypes.Private\n | Ast_413.Asttypes.Public -> Ast_414.Asttypes.Public\n\nand copy_type_kind : Ast_413.Parsetree.type_kind -> Ast_414.Parsetree.type_kind\n = function\n | Ast_413.Parsetree.Ptype_abstract -> Ast_414.Parsetree.Ptype_abstract\n | Ast_413.Parsetree.Ptype_variant x0 ->\n Ast_414.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_413.Parsetree.Ptype_record x0 ->\n Ast_414.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_413.Parsetree.Ptype_open -> Ast_414.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_413.Parsetree.constructor_declaration ->\n Ast_414.Parsetree.constructor_declaration =\n fun {\n Ast_413.Parsetree.pcd_name;\n Ast_413.Parsetree.pcd_args;\n Ast_413.Parsetree.pcd_res;\n Ast_413.Parsetree.pcd_loc;\n Ast_413.Parsetree.pcd_attributes;\n } ->\n {\n Ast_414.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_414.Parsetree.pcd_vars = [];\n Ast_414.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_414.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_414.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_414.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_413.Parsetree.constructor_arguments ->\n Ast_414.Parsetree.constructor_arguments = function\n | Ast_413.Parsetree.Pcstr_tuple x0 ->\n Ast_414.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_413.Parsetree.Pcstr_record x0 ->\n Ast_414.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_413.Parsetree.label_declaration -> Ast_414.Parsetree.label_declaration =\n fun {\n Ast_413.Parsetree.pld_name;\n Ast_413.Parsetree.pld_mutable;\n Ast_413.Parsetree.pld_type;\n Ast_413.Parsetree.pld_loc;\n Ast_413.Parsetree.pld_attributes;\n } ->\n {\n Ast_414.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_414.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_414.Parsetree.pld_type = copy_core_type pld_type;\n Ast_414.Parsetree.pld_loc = copy_location pld_loc;\n Ast_414.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_413.Asttypes.mutable_flag -> Ast_414.Asttypes.mutable_flag = function\n | Ast_413.Asttypes.Immutable -> Ast_414.Asttypes.Immutable\n | Ast_413.Asttypes.Mutable -> Ast_414.Asttypes.Mutable\n\nand copy_injectivity :\n Ast_413.Asttypes.injectivity -> Ast_414.Asttypes.injectivity = function\n | Ast_413.Asttypes.Injective -> Ast_414.Asttypes.Injective\n | Ast_413.Asttypes.NoInjectivity -> Ast_414.Asttypes.NoInjectivity\n\nand copy_variance : Ast_413.Asttypes.variance -> Ast_414.Asttypes.variance =\n function\n | Ast_413.Asttypes.Covariant -> Ast_414.Asttypes.Covariant\n | Ast_413.Asttypes.Contravariant -> Ast_414.Asttypes.Contravariant\n | Ast_413.Asttypes.NoVariance -> Ast_414.Asttypes.NoVariance\n\nand copy_value_description :\n Ast_413.Parsetree.value_description -> Ast_414.Parsetree.value_description =\n fun {\n Ast_413.Parsetree.pval_name;\n Ast_413.Parsetree.pval_type;\n Ast_413.Parsetree.pval_prim;\n Ast_413.Parsetree.pval_attributes;\n Ast_413.Parsetree.pval_loc;\n } ->\n {\n Ast_414.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_414.Parsetree.pval_type = copy_core_type pval_type;\n Ast_414.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_414.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_414.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_413.Parsetree.object_field_desc -> Ast_414.Parsetree.object_field_desc =\n function\n | Ast_413.Parsetree.Otag (x0, x1) ->\n Ast_414.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_413.Parsetree.Oinherit x0 ->\n Ast_414.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_413.Asttypes.arg_label -> Ast_414.Asttypes.arg_label =\n function\n | Ast_413.Asttypes.Nolabel -> Ast_414.Asttypes.Nolabel\n | Ast_413.Asttypes.Labelled x0 -> Ast_414.Asttypes.Labelled x0\n | Ast_413.Asttypes.Optional x0 -> Ast_414.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_413.Asttypes.closed_flag -> Ast_414.Asttypes.closed_flag = function\n | Ast_413.Asttypes.Closed -> Ast_414.Asttypes.Closed\n | Ast_413.Asttypes.Open -> Ast_414.Asttypes.Open\n\nand copy_label : Ast_413.Asttypes.label -> Ast_414.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_413.Asttypes.rec_flag -> Ast_414.Asttypes.rec_flag =\n function\n | Ast_413.Asttypes.Nonrecursive -> Ast_414.Asttypes.Nonrecursive\n | Ast_413.Asttypes.Recursive -> Ast_414.Asttypes.Recursive\n\nand copy_constant : Ast_413.Parsetree.constant -> Ast_414.Parsetree.constant =\n function\n | Ast_413.Parsetree.Pconst_integer (x0, x1) ->\n Ast_414.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_413.Parsetree.Pconst_char x0 -> Ast_414.Parsetree.Pconst_char x0\n | Ast_413.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_414.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_413.Parsetree.Pconst_float (x0, x1) ->\n Ast_414.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_413.Asttypes.loc -> 'g0 Ast_414.Asttypes.loc =\n fun f0 { Ast_413.Asttypes.txt; Ast_413.Asttypes.loc } ->\n { Ast_414.Asttypes.txt = f0 txt; Ast_414.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_413\nmodule To = Ast_412\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.13\" missing_feature\n\nlet rec copy_toplevel_phrase :\n Ast_413.Parsetree.toplevel_phrase -> Ast_412.Parsetree.toplevel_phrase =\n function\n | Ast_413.Parsetree.Ptop_def x0 ->\n Ast_412.Parsetree.Ptop_def (copy_structure x0)\n | Ast_413.Parsetree.Ptop_dir x0 ->\n Ast_412.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_413.Parsetree.toplevel_directive -> Ast_412.Parsetree.toplevel_directive\n =\n fun {\n Ast_413.Parsetree.pdir_name;\n Ast_413.Parsetree.pdir_arg;\n Ast_413.Parsetree.pdir_loc;\n } ->\n {\n Ast_412.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_412.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_412.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_413.Parsetree.directive_argument -> Ast_412.Parsetree.directive_argument\n =\n fun { Ast_413.Parsetree.pdira_desc; Ast_413.Parsetree.pdira_loc } ->\n {\n Ast_412.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_412.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_413.Parsetree.directive_argument_desc ->\n Ast_412.Parsetree.directive_argument_desc = function\n | Ast_413.Parsetree.Pdir_string x0 -> Ast_412.Parsetree.Pdir_string x0\n | Ast_413.Parsetree.Pdir_int (x0, x1) ->\n Ast_412.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_413.Parsetree.Pdir_ident x0 ->\n Ast_412.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_413.Parsetree.Pdir_bool x0 -> Ast_412.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_413.Parsetree.expression -> Ast_412.Parsetree.expression =\n fun {\n Ast_413.Parsetree.pexp_desc;\n Ast_413.Parsetree.pexp_loc;\n Ast_413.Parsetree.pexp_loc_stack;\n Ast_413.Parsetree.pexp_attributes;\n } ->\n {\n Ast_412.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_412.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_412.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_412.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_413.Parsetree.expression_desc -> Ast_412.Parsetree.expression_desc =\n function\n | Ast_413.Parsetree.Pexp_ident x0 ->\n Ast_412.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pexp_constant x0 ->\n Ast_412.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_413.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_413.Parsetree.Pexp_function x0 ->\n Ast_412.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_413.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_412.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_413.Parsetree.Pexp_apply (x0, x1) ->\n Ast_412.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_413.Parsetree.Pexp_match (x0, x1) ->\n Ast_412.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_413.Parsetree.Pexp_try (x0, x1) ->\n Ast_412.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_413.Parsetree.Pexp_tuple x0 ->\n Ast_412.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_413.Parsetree.Pexp_construct (x0, x1) ->\n Ast_412.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_413.Parsetree.Pexp_variant (x0, x1) ->\n Ast_412.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_413.Parsetree.Pexp_record (x0, x1) ->\n Ast_412.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_413.Parsetree.Pexp_field (x0, x1) ->\n Ast_412.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_413.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_413.Parsetree.Pexp_array x0 ->\n Ast_412.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_413.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_413.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_412.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_while (x0, x1) ->\n Ast_412.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_412.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_413.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_412.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_413.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_413.Parsetree.Pexp_send (x0, x1) ->\n Ast_412.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_413.Parsetree.Pexp_new x0 ->\n Ast_412.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_412.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_override x0 ->\n Ast_412.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_413.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_413.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_412.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_assert x0 ->\n Ast_412.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_413.Parsetree.Pexp_lazy x0 ->\n Ast_412.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_413.Parsetree.Pexp_poly (x0, x1) ->\n Ast_412.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_413.Parsetree.Pexp_object x0 ->\n Ast_412.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_413.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_412.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_pack x0 ->\n Ast_412.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_413.Parsetree.Pexp_open (x0, x1) ->\n Ast_412.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_413.Parsetree.Pexp_letop x0 ->\n Ast_412.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_413.Parsetree.Pexp_extension x0 ->\n Ast_412.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_413.Parsetree.Pexp_unreachable -> Ast_412.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_413.Parsetree.letop -> Ast_412.Parsetree.letop =\n fun { Ast_413.Parsetree.let_; Ast_413.Parsetree.ands; Ast_413.Parsetree.body } ->\n {\n Ast_412.Parsetree.let_ = copy_binding_op let_;\n Ast_412.Parsetree.ands = List.map copy_binding_op ands;\n Ast_412.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_413.Parsetree.binding_op -> Ast_412.Parsetree.binding_op =\n fun {\n Ast_413.Parsetree.pbop_op;\n Ast_413.Parsetree.pbop_pat;\n Ast_413.Parsetree.pbop_exp;\n Ast_413.Parsetree.pbop_loc;\n } ->\n {\n Ast_412.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_412.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_412.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_412.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_413.Asttypes.direction_flag -> Ast_412.Asttypes.direction_flag =\n function\n | Ast_413.Asttypes.Upto -> Ast_412.Asttypes.Upto\n | Ast_413.Asttypes.Downto -> Ast_412.Asttypes.Downto\n\nand copy_case : Ast_413.Parsetree.case -> Ast_412.Parsetree.case =\n fun {\n Ast_413.Parsetree.pc_lhs;\n Ast_413.Parsetree.pc_guard;\n Ast_413.Parsetree.pc_rhs;\n } ->\n {\n Ast_412.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_412.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_412.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_413.Parsetree.value_binding -> Ast_412.Parsetree.value_binding =\n fun {\n Ast_413.Parsetree.pvb_pat;\n Ast_413.Parsetree.pvb_expr;\n Ast_413.Parsetree.pvb_attributes;\n Ast_413.Parsetree.pvb_loc;\n } ->\n {\n Ast_412.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_412.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_412.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_412.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_413.Parsetree.pattern -> Ast_412.Parsetree.pattern =\n fun {\n Ast_413.Parsetree.ppat_desc;\n Ast_413.Parsetree.ppat_loc;\n Ast_413.Parsetree.ppat_loc_stack;\n Ast_413.Parsetree.ppat_attributes;\n } ->\n {\n Ast_412.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_412.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_412.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_412.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_413.Parsetree.pattern_desc -> Ast_412.Parsetree.pattern_desc = function\n | Ast_413.Parsetree.Ppat_any -> Ast_412.Parsetree.Ppat_any\n | Ast_413.Parsetree.Ppat_var x0 ->\n Ast_412.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_413.Parsetree.Ppat_alias (x0, x1) ->\n Ast_412.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_413.Parsetree.Ppat_constant x0 ->\n Ast_412.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_413.Parsetree.Ppat_interval (x0, x1) ->\n Ast_412.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_413.Parsetree.Ppat_tuple x0 ->\n Ast_412.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_413.Parsetree.Ppat_construct (x0, x1) ->\n Ast_412.Parsetree.Ppat_construct\n ( copy_loc copy_Longident_t x0,\n Option.map\n (fun x ->\n let x0, x1 = x in\n (match x0 with\n | [] -> ()\n | ty :: _ ->\n migration_error ty.Ast_413.Asttypes.loc\n \"existentials in pattern-matching\");\n copy_pattern x1)\n x1 )\n | Ast_413.Parsetree.Ppat_variant (x0, x1) ->\n Ast_412.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_413.Parsetree.Ppat_record (x0, x1) ->\n Ast_412.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_413.Parsetree.Ppat_array x0 ->\n Ast_412.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_413.Parsetree.Ppat_or (x0, x1) ->\n Ast_412.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_413.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_412.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_413.Parsetree.Ppat_type x0 ->\n Ast_412.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Ppat_lazy x0 ->\n Ast_412.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_413.Parsetree.Ppat_unpack x0 ->\n Ast_412.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_413.Parsetree.Ppat_exception x0 ->\n Ast_412.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_413.Parsetree.Ppat_extension x0 ->\n Ast_412.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_413.Parsetree.Ppat_open (x0, x1) ->\n Ast_412.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_413.Parsetree.core_type -> Ast_412.Parsetree.core_type\n =\n fun {\n Ast_413.Parsetree.ptyp_desc;\n Ast_413.Parsetree.ptyp_loc;\n Ast_413.Parsetree.ptyp_loc_stack;\n Ast_413.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_412.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_412.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_412.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_413.Parsetree.location_stack -> Ast_412.Parsetree.location_stack =\n fun x -> List.map copy_location x\n\nand copy_core_type_desc :\n Ast_413.Parsetree.core_type_desc -> Ast_412.Parsetree.core_type_desc =\n function\n | Ast_413.Parsetree.Ptyp_any -> Ast_412.Parsetree.Ptyp_any\n | Ast_413.Parsetree.Ptyp_var x0 -> Ast_412.Parsetree.Ptyp_var x0\n | Ast_413.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_412.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_413.Parsetree.Ptyp_tuple x0 ->\n Ast_412.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_413.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_412.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_object (x0, x1) ->\n Ast_412.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_413.Parsetree.Ptyp_class (x0, x1) ->\n Ast_412.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_412.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_413.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_412.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_413.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_412.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_413.Parsetree.Ptyp_package x0 ->\n Ast_412.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_413.Parsetree.Ptyp_extension x0 ->\n Ast_412.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_413.Parsetree.package_type -> Ast_412.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_413.Parsetree.row_field -> Ast_412.Parsetree.row_field\n =\n fun {\n Ast_413.Parsetree.prf_desc;\n Ast_413.Parsetree.prf_loc;\n Ast_413.Parsetree.prf_attributes;\n } ->\n {\n Ast_412.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_412.Parsetree.prf_loc = copy_location prf_loc;\n Ast_412.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_413.Parsetree.row_field_desc -> Ast_412.Parsetree.row_field_desc =\n function\n | Ast_413.Parsetree.Rtag (x0, x1, x2) ->\n Ast_412.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_413.Parsetree.Rinherit x0 ->\n Ast_412.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_413.Parsetree.object_field -> Ast_412.Parsetree.object_field =\n fun {\n Ast_413.Parsetree.pof_desc;\n Ast_413.Parsetree.pof_loc;\n Ast_413.Parsetree.pof_attributes;\n } ->\n {\n Ast_412.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_412.Parsetree.pof_loc = copy_location pof_loc;\n Ast_412.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_413.Parsetree.attributes -> Ast_412.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_413.Parsetree.attribute -> Ast_412.Parsetree.attribute\n =\n fun {\n Ast_413.Parsetree.attr_name;\n Ast_413.Parsetree.attr_payload;\n Ast_413.Parsetree.attr_loc;\n } ->\n {\n Ast_412.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_412.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_412.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_413.Parsetree.payload -> Ast_412.Parsetree.payload =\n function\n | Ast_413.Parsetree.PStr x0 -> Ast_412.Parsetree.PStr (copy_structure x0)\n | Ast_413.Parsetree.PSig x0 -> Ast_412.Parsetree.PSig (copy_signature x0)\n | Ast_413.Parsetree.PTyp x0 -> Ast_412.Parsetree.PTyp (copy_core_type x0)\n | Ast_413.Parsetree.PPat (x0, x1) ->\n Ast_412.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_413.Parsetree.structure -> Ast_412.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_413.Parsetree.structure_item -> Ast_412.Parsetree.structure_item =\n fun { Ast_413.Parsetree.pstr_desc; Ast_413.Parsetree.pstr_loc } ->\n {\n Ast_412.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_412.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_413.Parsetree.structure_item_desc ->\n Ast_412.Parsetree.structure_item_desc = function\n | Ast_413.Parsetree.Pstr_eval (x0, x1) ->\n Ast_412.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_413.Parsetree.Pstr_value (x0, x1) ->\n Ast_412.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_413.Parsetree.Pstr_primitive x0 ->\n Ast_412.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_413.Parsetree.Pstr_type (x0, x1) ->\n Ast_412.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_413.Parsetree.Pstr_typext x0 ->\n Ast_412.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_413.Parsetree.Pstr_exception x0 ->\n Ast_412.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_413.Parsetree.Pstr_module x0 ->\n Ast_412.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_413.Parsetree.Pstr_recmodule x0 ->\n Ast_412.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_413.Parsetree.Pstr_modtype x0 ->\n Ast_412.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_413.Parsetree.Pstr_open x0 ->\n Ast_412.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_413.Parsetree.Pstr_class x0 ->\n Ast_412.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_413.Parsetree.Pstr_class_type x0 ->\n Ast_412.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_413.Parsetree.Pstr_include x0 ->\n Ast_412.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_413.Parsetree.Pstr_attribute x0 ->\n Ast_412.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pstr_extension (x0, x1) ->\n Ast_412.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_413.Parsetree.include_declaration ->\n Ast_412.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_413.Parsetree.class_declaration -> Ast_412.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_413.Parsetree.class_expr -> Ast_412.Parsetree.class_expr =\n fun {\n Ast_413.Parsetree.pcl_desc;\n Ast_413.Parsetree.pcl_loc;\n Ast_413.Parsetree.pcl_attributes;\n } ->\n {\n Ast_412.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_412.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_412.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_413.Parsetree.class_expr_desc -> Ast_412.Parsetree.class_expr_desc =\n function\n | Ast_413.Parsetree.Pcl_constr (x0, x1) ->\n Ast_412.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Pcl_structure x0 ->\n Ast_412.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_413.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_412.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_413.Parsetree.Pcl_apply (x0, x1) ->\n Ast_412.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_413.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_412.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_413.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_412.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_413.Parsetree.Pcl_extension x0 ->\n Ast_412.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_413.Parsetree.Pcl_open (x0, x1) ->\n Ast_412.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_413.Parsetree.class_structure -> Ast_412.Parsetree.class_structure =\n fun { Ast_413.Parsetree.pcstr_self; Ast_413.Parsetree.pcstr_fields } ->\n {\n Ast_412.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_412.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_413.Parsetree.class_field -> Ast_412.Parsetree.class_field =\n fun {\n Ast_413.Parsetree.pcf_desc;\n Ast_413.Parsetree.pcf_loc;\n Ast_413.Parsetree.pcf_attributes;\n } ->\n {\n Ast_412.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_412.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_412.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_413.Parsetree.class_field_desc -> Ast_412.Parsetree.class_field_desc =\n function\n | Ast_413.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_412.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_413.Parsetree.Pcf_val x0 ->\n Ast_412.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_413.Parsetree.Pcf_method x0 ->\n Ast_412.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_413.Parsetree.Pcf_constraint x0 ->\n Ast_412.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_413.Parsetree.Pcf_initializer x0 ->\n Ast_412.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_413.Parsetree.Pcf_attribute x0 ->\n Ast_412.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pcf_extension x0 ->\n Ast_412.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_413.Parsetree.class_field_kind -> Ast_412.Parsetree.class_field_kind =\n function\n | Ast_413.Parsetree.Cfk_virtual x0 ->\n Ast_412.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_413.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_412.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_413.Parsetree.open_declaration -> Ast_412.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_413.Parsetree.module_binding -> Ast_412.Parsetree.module_binding =\n fun {\n Ast_413.Parsetree.pmb_name;\n Ast_413.Parsetree.pmb_expr;\n Ast_413.Parsetree.pmb_attributes;\n Ast_413.Parsetree.pmb_loc;\n } ->\n {\n Ast_412.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_412.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_412.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_412.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_413.Parsetree.module_expr -> Ast_412.Parsetree.module_expr =\n fun {\n Ast_413.Parsetree.pmod_desc;\n Ast_413.Parsetree.pmod_loc;\n Ast_413.Parsetree.pmod_attributes;\n } ->\n {\n Ast_412.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_412.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_412.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_413.Parsetree.module_expr_desc -> Ast_412.Parsetree.module_expr_desc =\n function\n | Ast_413.Parsetree.Pmod_ident x0 ->\n Ast_412.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pmod_structure x0 ->\n Ast_412.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_413.Parsetree.Pmod_functor (x0, x1) ->\n Ast_412.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_413.Parsetree.Pmod_apply (x0, x1) ->\n Ast_412.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_413.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_412.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_413.Parsetree.Pmod_unpack x0 ->\n Ast_412.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_413.Parsetree.Pmod_extension x0 ->\n Ast_412.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_413.Parsetree.functor_parameter -> Ast_412.Parsetree.functor_parameter =\n function\n | Ast_413.Parsetree.Unit -> Ast_412.Parsetree.Unit\n | Ast_413.Parsetree.Named (x0, x1) ->\n Ast_412.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_413.Parsetree.module_type -> Ast_412.Parsetree.module_type =\n fun {\n Ast_413.Parsetree.pmty_desc;\n Ast_413.Parsetree.pmty_loc;\n Ast_413.Parsetree.pmty_attributes;\n } ->\n {\n Ast_412.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_412.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_412.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_413.Parsetree.module_type_desc -> Ast_412.Parsetree.module_type_desc =\n function\n | Ast_413.Parsetree.Pmty_ident x0 ->\n Ast_412.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_413.Parsetree.Pmty_signature x0 ->\n Ast_412.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_413.Parsetree.Pmty_functor (x0, x1) ->\n Ast_412.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_413.Parsetree.Pmty_with (x0, x1) ->\n Ast_412.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_413.Parsetree.Pmty_typeof x0 ->\n Ast_412.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_413.Parsetree.Pmty_extension x0 ->\n Ast_412.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_413.Parsetree.Pmty_alias x0 ->\n Ast_412.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_413.Parsetree.with_constraint -> Ast_412.Parsetree.with_constraint =\n function\n | Ast_413.Parsetree.Pwith_type (x0, x1) ->\n Ast_412.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_413.Parsetree.Pwith_module (x0, x1) ->\n Ast_412.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_413.Parsetree.Pwith_modtype (_x0, x1) ->\n migration_error x1.Ast_413.Parsetree.pmty_loc \"module type substitution\"\n | Ast_413.Parsetree.Pwith_modtypesubst (_x0, x1) ->\n migration_error x1.Ast_413.Parsetree.pmty_loc\n \"destructive module type substitution\"\n | Ast_413.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_412.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_413.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_412.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_413.Parsetree.signature -> Ast_412.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_413.Parsetree.signature_item -> Ast_412.Parsetree.signature_item =\n fun { Ast_413.Parsetree.psig_desc; Ast_413.Parsetree.psig_loc } ->\n {\n Ast_412.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_412.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_413.Parsetree.signature_item_desc ->\n Ast_412.Parsetree.signature_item_desc = function\n | Ast_413.Parsetree.Psig_value x0 ->\n Ast_412.Parsetree.Psig_value (copy_value_description x0)\n | Ast_413.Parsetree.Psig_type (x0, x1) ->\n Ast_412.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_413.Parsetree.Psig_typesubst x0 ->\n Ast_412.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_413.Parsetree.Psig_typext x0 ->\n Ast_412.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_413.Parsetree.Psig_exception x0 ->\n Ast_412.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_413.Parsetree.Psig_module x0 ->\n Ast_412.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_413.Parsetree.Psig_modsubst x0 ->\n Ast_412.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_413.Parsetree.Psig_recmodule x0 ->\n Ast_412.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_413.Parsetree.Psig_modtype x0 ->\n Ast_412.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_413.Parsetree.Psig_modtypesubst x0 ->\n migration_error x0.Ast_413.Parsetree.pmtd_loc\n \"local module type substitution\"\n | Ast_413.Parsetree.Psig_open x0 ->\n Ast_412.Parsetree.Psig_open (copy_open_description x0)\n | Ast_413.Parsetree.Psig_include x0 ->\n Ast_412.Parsetree.Psig_include (copy_include_description x0)\n | Ast_413.Parsetree.Psig_class x0 ->\n Ast_412.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_413.Parsetree.Psig_class_type x0 ->\n Ast_412.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_413.Parsetree.Psig_attribute x0 ->\n Ast_412.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Psig_extension (x0, x1) ->\n Ast_412.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_413.Parsetree.class_type_declaration ->\n Ast_412.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_413.Parsetree.class_description -> Ast_412.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_413.Parsetree.class_type -> Ast_412.Parsetree.class_type =\n fun {\n Ast_413.Parsetree.pcty_desc;\n Ast_413.Parsetree.pcty_loc;\n Ast_413.Parsetree.pcty_attributes;\n } ->\n {\n Ast_412.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_412.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_412.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_413.Parsetree.class_type_desc -> Ast_412.Parsetree.class_type_desc =\n function\n | Ast_413.Parsetree.Pcty_constr (x0, x1) ->\n Ast_412.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_413.Parsetree.Pcty_signature x0 ->\n Ast_412.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_413.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_412.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_413.Parsetree.Pcty_extension x0 ->\n Ast_412.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_413.Parsetree.Pcty_open (x0, x1) ->\n Ast_412.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_413.Parsetree.class_signature -> Ast_412.Parsetree.class_signature =\n fun { Ast_413.Parsetree.pcsig_self; Ast_413.Parsetree.pcsig_fields } ->\n {\n Ast_412.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_412.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_413.Parsetree.class_type_field -> Ast_412.Parsetree.class_type_field =\n fun {\n Ast_413.Parsetree.pctf_desc;\n Ast_413.Parsetree.pctf_loc;\n Ast_413.Parsetree.pctf_attributes;\n } ->\n {\n Ast_412.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_412.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_412.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_413.Parsetree.class_type_field_desc ->\n Ast_412.Parsetree.class_type_field_desc = function\n | Ast_413.Parsetree.Pctf_inherit x0 ->\n Ast_412.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_413.Parsetree.Pctf_val x0 ->\n Ast_412.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_413.Parsetree.Pctf_method x0 ->\n Ast_412.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_413.Parsetree.Pctf_constraint x0 ->\n Ast_412.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_413.Parsetree.Pctf_attribute x0 ->\n Ast_412.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_413.Parsetree.Pctf_extension x0 ->\n Ast_412.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_413.Parsetree.extension -> Ast_412.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.class_infos ->\n 'g0 Ast_412.Parsetree.class_infos =\n fun f0\n {\n Ast_413.Parsetree.pci_virt;\n Ast_413.Parsetree.pci_params;\n Ast_413.Parsetree.pci_name;\n Ast_413.Parsetree.pci_expr;\n Ast_413.Parsetree.pci_loc;\n Ast_413.Parsetree.pci_attributes;\n } ->\n {\n Ast_412.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_412.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n pci_params;\n Ast_412.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_412.Parsetree.pci_expr = f0 pci_expr;\n Ast_412.Parsetree.pci_loc = copy_location pci_loc;\n Ast_412.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_413.Asttypes.virtual_flag -> Ast_412.Asttypes.virtual_flag = function\n | Ast_413.Asttypes.Virtual -> Ast_412.Asttypes.Virtual\n | Ast_413.Asttypes.Concrete -> Ast_412.Asttypes.Concrete\n\nand copy_include_description :\n Ast_413.Parsetree.include_description ->\n Ast_412.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.include_infos ->\n 'g0 Ast_412.Parsetree.include_infos =\n fun f0\n {\n Ast_413.Parsetree.pincl_mod;\n Ast_413.Parsetree.pincl_loc;\n Ast_413.Parsetree.pincl_attributes;\n } ->\n {\n Ast_412.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_412.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_412.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_413.Parsetree.open_description -> Ast_412.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_413.Parsetree.open_infos ->\n 'g0 Ast_412.Parsetree.open_infos =\n fun f0\n {\n Ast_413.Parsetree.popen_expr;\n Ast_413.Parsetree.popen_override;\n Ast_413.Parsetree.popen_loc;\n Ast_413.Parsetree.popen_attributes;\n } ->\n {\n Ast_412.Parsetree.popen_expr = f0 popen_expr;\n Ast_412.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_412.Parsetree.popen_loc = copy_location popen_loc;\n Ast_412.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_413.Asttypes.override_flag -> Ast_412.Asttypes.override_flag = function\n | Ast_413.Asttypes.Override -> Ast_412.Asttypes.Override\n | Ast_413.Asttypes.Fresh -> Ast_412.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_413.Parsetree.module_type_declaration ->\n Ast_412.Parsetree.module_type_declaration =\n fun {\n Ast_413.Parsetree.pmtd_name;\n Ast_413.Parsetree.pmtd_type;\n Ast_413.Parsetree.pmtd_attributes;\n Ast_413.Parsetree.pmtd_loc;\n } ->\n {\n Ast_412.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_412.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_412.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_412.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_413.Parsetree.module_substitution ->\n Ast_412.Parsetree.module_substitution =\n fun {\n Ast_413.Parsetree.pms_name;\n Ast_413.Parsetree.pms_manifest;\n Ast_413.Parsetree.pms_attributes;\n Ast_413.Parsetree.pms_loc;\n } ->\n {\n Ast_412.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_412.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_412.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_412.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_413.Parsetree.module_declaration -> Ast_412.Parsetree.module_declaration\n =\n fun {\n Ast_413.Parsetree.pmd_name;\n Ast_413.Parsetree.pmd_type;\n Ast_413.Parsetree.pmd_attributes;\n Ast_413.Parsetree.pmd_loc;\n } ->\n {\n Ast_412.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_412.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_412.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_412.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_413.Parsetree.type_exception -> Ast_412.Parsetree.type_exception =\n fun {\n Ast_413.Parsetree.ptyexn_constructor;\n Ast_413.Parsetree.ptyexn_loc;\n Ast_413.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_412.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_412.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_413.Parsetree.type_extension -> Ast_412.Parsetree.type_extension =\n fun {\n Ast_413.Parsetree.ptyext_path;\n Ast_413.Parsetree.ptyext_params;\n Ast_413.Parsetree.ptyext_constructors;\n Ast_413.Parsetree.ptyext_private;\n Ast_413.Parsetree.ptyext_loc;\n Ast_413.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_412.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptyext_params;\n Ast_412.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_412.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_412.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_412.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_413.Parsetree.extension_constructor ->\n Ast_412.Parsetree.extension_constructor =\n fun {\n Ast_413.Parsetree.pext_name;\n Ast_413.Parsetree.pext_kind;\n Ast_413.Parsetree.pext_loc;\n Ast_413.Parsetree.pext_attributes;\n } ->\n {\n Ast_412.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_412.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_412.Parsetree.pext_loc = copy_location pext_loc;\n Ast_412.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_413.Parsetree.extension_constructor_kind ->\n Ast_412.Parsetree.extension_constructor_kind = function\n | Ast_413.Parsetree.Pext_decl (x0, x1) ->\n Ast_412.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_413.Parsetree.Pext_rebind x0 ->\n Ast_412.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_413.Parsetree.type_declaration -> Ast_412.Parsetree.type_declaration =\n fun {\n Ast_413.Parsetree.ptype_name;\n Ast_413.Parsetree.ptype_params;\n Ast_413.Parsetree.ptype_cstrs;\n Ast_413.Parsetree.ptype_kind;\n Ast_413.Parsetree.ptype_private;\n Ast_413.Parsetree.ptype_manifest;\n Ast_413.Parsetree.ptype_attributes;\n Ast_413.Parsetree.ptype_loc;\n } ->\n {\n Ast_412.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_412.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptype_params;\n Ast_412.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_412.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_412.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_412.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_412.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_412.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_413.Asttypes.private_flag -> Ast_412.Asttypes.private_flag = function\n | Ast_413.Asttypes.Private -> Ast_412.Asttypes.Private\n | Ast_413.Asttypes.Public -> Ast_412.Asttypes.Public\n\nand copy_type_kind : Ast_413.Parsetree.type_kind -> Ast_412.Parsetree.type_kind\n = function\n | Ast_413.Parsetree.Ptype_abstract -> Ast_412.Parsetree.Ptype_abstract\n | Ast_413.Parsetree.Ptype_variant x0 ->\n Ast_412.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_413.Parsetree.Ptype_record x0 ->\n Ast_412.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_413.Parsetree.Ptype_open -> Ast_412.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_413.Parsetree.constructor_declaration ->\n Ast_412.Parsetree.constructor_declaration =\n fun {\n Ast_413.Parsetree.pcd_name;\n Ast_413.Parsetree.pcd_args;\n Ast_413.Parsetree.pcd_res;\n Ast_413.Parsetree.pcd_loc;\n Ast_413.Parsetree.pcd_attributes;\n } ->\n {\n Ast_412.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_412.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_412.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_412.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_412.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_413.Parsetree.constructor_arguments ->\n Ast_412.Parsetree.constructor_arguments = function\n | Ast_413.Parsetree.Pcstr_tuple x0 ->\n Ast_412.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_413.Parsetree.Pcstr_record x0 ->\n Ast_412.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_413.Parsetree.label_declaration -> Ast_412.Parsetree.label_declaration =\n fun {\n Ast_413.Parsetree.pld_name;\n Ast_413.Parsetree.pld_mutable;\n Ast_413.Parsetree.pld_type;\n Ast_413.Parsetree.pld_loc;\n Ast_413.Parsetree.pld_attributes;\n } ->\n {\n Ast_412.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_412.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_412.Parsetree.pld_type = copy_core_type pld_type;\n Ast_412.Parsetree.pld_loc = copy_location pld_loc;\n Ast_412.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_413.Asttypes.mutable_flag -> Ast_412.Asttypes.mutable_flag = function\n | Ast_413.Asttypes.Immutable -> Ast_412.Asttypes.Immutable\n | Ast_413.Asttypes.Mutable -> Ast_412.Asttypes.Mutable\n\nand copy_injectivity :\n Ast_413.Asttypes.injectivity -> Ast_412.Asttypes.injectivity = function\n | Ast_413.Asttypes.Injective -> Ast_412.Asttypes.Injective\n | Ast_413.Asttypes.NoInjectivity -> Ast_412.Asttypes.NoInjectivity\n\nand copy_variance : Ast_413.Asttypes.variance -> Ast_412.Asttypes.variance =\n function\n | Ast_413.Asttypes.Covariant -> Ast_412.Asttypes.Covariant\n | Ast_413.Asttypes.Contravariant -> Ast_412.Asttypes.Contravariant\n | Ast_413.Asttypes.NoVariance -> Ast_412.Asttypes.NoVariance\n\nand copy_value_description :\n Ast_413.Parsetree.value_description -> Ast_412.Parsetree.value_description =\n fun {\n Ast_413.Parsetree.pval_name;\n Ast_413.Parsetree.pval_type;\n Ast_413.Parsetree.pval_prim;\n Ast_413.Parsetree.pval_attributes;\n Ast_413.Parsetree.pval_loc;\n } ->\n {\n Ast_412.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_412.Parsetree.pval_type = copy_core_type pval_type;\n Ast_412.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_412.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_412.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_413.Parsetree.object_field_desc -> Ast_412.Parsetree.object_field_desc =\n function\n | Ast_413.Parsetree.Otag (x0, x1) ->\n Ast_412.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_413.Parsetree.Oinherit x0 ->\n Ast_412.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_413.Asttypes.arg_label -> Ast_412.Asttypes.arg_label =\n function\n | Ast_413.Asttypes.Nolabel -> Ast_412.Asttypes.Nolabel\n | Ast_413.Asttypes.Labelled x0 -> Ast_412.Asttypes.Labelled x0\n | Ast_413.Asttypes.Optional x0 -> Ast_412.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_413.Asttypes.closed_flag -> Ast_412.Asttypes.closed_flag = function\n | Ast_413.Asttypes.Closed -> Ast_412.Asttypes.Closed\n | Ast_413.Asttypes.Open -> Ast_412.Asttypes.Open\n\nand copy_label : Ast_413.Asttypes.label -> Ast_412.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_413.Asttypes.rec_flag -> Ast_412.Asttypes.rec_flag =\n function\n | Ast_413.Asttypes.Nonrecursive -> Ast_412.Asttypes.Nonrecursive\n | Ast_413.Asttypes.Recursive -> Ast_412.Asttypes.Recursive\n\nand copy_constant : Ast_413.Parsetree.constant -> Ast_412.Parsetree.constant =\n function\n | Ast_413.Parsetree.Pconst_integer (x0, x1) ->\n Ast_412.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_413.Parsetree.Pconst_char x0 -> Ast_412.Parsetree.Pconst_char x0\n | Ast_413.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_412.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_413.Parsetree.Pconst_float (x0, x1) ->\n Ast_412.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_413.Asttypes.loc -> 'g0 Ast_412.Asttypes.loc =\n fun f0 { Ast_413.Asttypes.txt; Ast_413.Asttypes.loc } ->\n { Ast_412.Asttypes.txt = f0 txt; Ast_412.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_412\nmodule To = Ast_413\n\nlet rec copy_toplevel_phrase :\n Ast_412.Parsetree.toplevel_phrase -> Ast_413.Parsetree.toplevel_phrase =\n function\n | Ast_412.Parsetree.Ptop_def x0 ->\n Ast_413.Parsetree.Ptop_def (copy_structure x0)\n | Ast_412.Parsetree.Ptop_dir x0 ->\n Ast_413.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_412.Parsetree.toplevel_directive -> Ast_413.Parsetree.toplevel_directive\n =\n fun {\n Ast_412.Parsetree.pdir_name;\n Ast_412.Parsetree.pdir_arg;\n Ast_412.Parsetree.pdir_loc;\n } ->\n {\n Ast_413.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_413.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_413.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_412.Parsetree.directive_argument -> Ast_413.Parsetree.directive_argument\n =\n fun { Ast_412.Parsetree.pdira_desc; Ast_412.Parsetree.pdira_loc } ->\n {\n Ast_413.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_413.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_412.Parsetree.directive_argument_desc ->\n Ast_413.Parsetree.directive_argument_desc = function\n | Ast_412.Parsetree.Pdir_string x0 -> Ast_413.Parsetree.Pdir_string x0\n | Ast_412.Parsetree.Pdir_int (x0, x1) ->\n Ast_413.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_412.Parsetree.Pdir_ident x0 ->\n Ast_413.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_412.Parsetree.Pdir_bool x0 -> Ast_413.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_412.Parsetree.expression -> Ast_413.Parsetree.expression =\n fun {\n Ast_412.Parsetree.pexp_desc;\n Ast_412.Parsetree.pexp_loc;\n Ast_412.Parsetree.pexp_loc_stack;\n Ast_412.Parsetree.pexp_attributes;\n } ->\n {\n Ast_413.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_413.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_413.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_413.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_412.Parsetree.expression_desc -> Ast_413.Parsetree.expression_desc =\n function\n | Ast_412.Parsetree.Pexp_ident x0 ->\n Ast_413.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pexp_constant x0 ->\n Ast_413.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_412.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_412.Parsetree.Pexp_function x0 ->\n Ast_413.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_412.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_413.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_412.Parsetree.Pexp_apply (x0, x1) ->\n Ast_413.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_412.Parsetree.Pexp_match (x0, x1) ->\n Ast_413.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_412.Parsetree.Pexp_try (x0, x1) ->\n Ast_413.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_412.Parsetree.Pexp_tuple x0 ->\n Ast_413.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_412.Parsetree.Pexp_construct (x0, x1) ->\n Ast_413.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_412.Parsetree.Pexp_variant (x0, x1) ->\n Ast_413.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_412.Parsetree.Pexp_record (x0, x1) ->\n Ast_413.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_412.Parsetree.Pexp_field (x0, x1) ->\n Ast_413.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_412.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_412.Parsetree.Pexp_array x0 ->\n Ast_413.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_412.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_412.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_413.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_while (x0, x1) ->\n Ast_413.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_413.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_412.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_413.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_412.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_412.Parsetree.Pexp_send (x0, x1) ->\n Ast_413.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_412.Parsetree.Pexp_new x0 ->\n Ast_413.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_413.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_override x0 ->\n Ast_413.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_412.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_413.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_412.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_413.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_assert x0 ->\n Ast_413.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_412.Parsetree.Pexp_lazy x0 ->\n Ast_413.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_412.Parsetree.Pexp_poly (x0, x1) ->\n Ast_413.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_412.Parsetree.Pexp_object x0 ->\n Ast_413.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_412.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_413.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_pack x0 ->\n Ast_413.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_412.Parsetree.Pexp_open (x0, x1) ->\n Ast_413.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_letop x0 ->\n Ast_413.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_412.Parsetree.Pexp_extension x0 ->\n Ast_413.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_412.Parsetree.Pexp_unreachable -> Ast_413.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_412.Parsetree.letop -> Ast_413.Parsetree.letop =\n fun { Ast_412.Parsetree.let_; Ast_412.Parsetree.ands; Ast_412.Parsetree.body } ->\n {\n Ast_413.Parsetree.let_ = copy_binding_op let_;\n Ast_413.Parsetree.ands = List.map copy_binding_op ands;\n Ast_413.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_412.Parsetree.binding_op -> Ast_413.Parsetree.binding_op =\n fun {\n Ast_412.Parsetree.pbop_op;\n Ast_412.Parsetree.pbop_pat;\n Ast_412.Parsetree.pbop_exp;\n Ast_412.Parsetree.pbop_loc;\n } ->\n {\n Ast_413.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_413.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_413.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_413.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_412.Asttypes.direction_flag -> Ast_413.Asttypes.direction_flag =\n function\n | Ast_412.Asttypes.Upto -> Ast_413.Asttypes.Upto\n | Ast_412.Asttypes.Downto -> Ast_413.Asttypes.Downto\n\nand copy_case : Ast_412.Parsetree.case -> Ast_413.Parsetree.case =\n fun {\n Ast_412.Parsetree.pc_lhs;\n Ast_412.Parsetree.pc_guard;\n Ast_412.Parsetree.pc_rhs;\n } ->\n {\n Ast_413.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_413.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_413.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_412.Parsetree.value_binding -> Ast_413.Parsetree.value_binding =\n fun {\n Ast_412.Parsetree.pvb_pat;\n Ast_412.Parsetree.pvb_expr;\n Ast_412.Parsetree.pvb_attributes;\n Ast_412.Parsetree.pvb_loc;\n } ->\n {\n Ast_413.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_413.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_413.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_413.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_412.Parsetree.pattern -> Ast_413.Parsetree.pattern =\n fun {\n Ast_412.Parsetree.ppat_desc;\n Ast_412.Parsetree.ppat_loc;\n Ast_412.Parsetree.ppat_loc_stack;\n Ast_412.Parsetree.ppat_attributes;\n } ->\n {\n Ast_413.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_413.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_413.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_413.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_412.Parsetree.pattern_desc -> Ast_413.Parsetree.pattern_desc = function\n | Ast_412.Parsetree.Ppat_any -> Ast_413.Parsetree.Ppat_any\n | Ast_412.Parsetree.Ppat_var x0 ->\n Ast_413.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_412.Parsetree.Ppat_alias (x0, x1) ->\n Ast_413.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_412.Parsetree.Ppat_constant x0 ->\n Ast_413.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_412.Parsetree.Ppat_interval (x0, x1) ->\n Ast_413.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_412.Parsetree.Ppat_tuple x0 ->\n Ast_413.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_412.Parsetree.Ppat_construct (x0, x1) ->\n Ast_413.Parsetree.Ppat_construct\n ( copy_loc copy_Longident_t x0,\n Option.map (fun x -> ([], copy_pattern x)) x1 )\n | Ast_412.Parsetree.Ppat_variant (x0, x1) ->\n Ast_413.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_412.Parsetree.Ppat_record (x0, x1) ->\n Ast_413.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_412.Parsetree.Ppat_array x0 ->\n Ast_413.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_412.Parsetree.Ppat_or (x0, x1) ->\n Ast_413.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_412.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_413.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_412.Parsetree.Ppat_type x0 ->\n Ast_413.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Ppat_lazy x0 ->\n Ast_413.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_412.Parsetree.Ppat_unpack x0 ->\n Ast_413.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_412.Parsetree.Ppat_exception x0 ->\n Ast_413.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_412.Parsetree.Ppat_extension x0 ->\n Ast_413.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_412.Parsetree.Ppat_open (x0, x1) ->\n Ast_413.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_412.Parsetree.core_type -> Ast_413.Parsetree.core_type\n =\n fun {\n Ast_412.Parsetree.ptyp_desc;\n Ast_412.Parsetree.ptyp_loc;\n Ast_412.Parsetree.ptyp_loc_stack;\n Ast_412.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_413.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_413.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_413.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_412.Parsetree.location_stack -> Ast_413.Parsetree.location_stack =\n fun x -> List.map copy_location x\n\nand copy_core_type_desc :\n Ast_412.Parsetree.core_type_desc -> Ast_413.Parsetree.core_type_desc =\n function\n | Ast_412.Parsetree.Ptyp_any -> Ast_413.Parsetree.Ptyp_any\n | Ast_412.Parsetree.Ptyp_var x0 -> Ast_413.Parsetree.Ptyp_var x0\n | Ast_412.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_413.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_412.Parsetree.Ptyp_tuple x0 ->\n Ast_413.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_412.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_413.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_object (x0, x1) ->\n Ast_413.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_412.Parsetree.Ptyp_class (x0, x1) ->\n Ast_413.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_413.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_412.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_413.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_412.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_413.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_package x0 ->\n Ast_413.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_412.Parsetree.Ptyp_extension x0 ->\n Ast_413.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_412.Parsetree.package_type -> Ast_413.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_412.Parsetree.row_field -> Ast_413.Parsetree.row_field\n =\n fun {\n Ast_412.Parsetree.prf_desc;\n Ast_412.Parsetree.prf_loc;\n Ast_412.Parsetree.prf_attributes;\n } ->\n {\n Ast_413.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_413.Parsetree.prf_loc = copy_location prf_loc;\n Ast_413.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_412.Parsetree.row_field_desc -> Ast_413.Parsetree.row_field_desc =\n function\n | Ast_412.Parsetree.Rtag (x0, x1, x2) ->\n Ast_413.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_412.Parsetree.Rinherit x0 ->\n Ast_413.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_412.Parsetree.object_field -> Ast_413.Parsetree.object_field =\n fun {\n Ast_412.Parsetree.pof_desc;\n Ast_412.Parsetree.pof_loc;\n Ast_412.Parsetree.pof_attributes;\n } ->\n {\n Ast_413.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_413.Parsetree.pof_loc = copy_location pof_loc;\n Ast_413.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_412.Parsetree.attributes -> Ast_413.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_412.Parsetree.attribute -> Ast_413.Parsetree.attribute\n =\n fun {\n Ast_412.Parsetree.attr_name;\n Ast_412.Parsetree.attr_payload;\n Ast_412.Parsetree.attr_loc;\n } ->\n {\n Ast_413.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_413.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_413.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_412.Parsetree.payload -> Ast_413.Parsetree.payload =\n function\n | Ast_412.Parsetree.PStr x0 -> Ast_413.Parsetree.PStr (copy_structure x0)\n | Ast_412.Parsetree.PSig x0 -> Ast_413.Parsetree.PSig (copy_signature x0)\n | Ast_412.Parsetree.PTyp x0 -> Ast_413.Parsetree.PTyp (copy_core_type x0)\n | Ast_412.Parsetree.PPat (x0, x1) ->\n Ast_413.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_412.Parsetree.structure -> Ast_413.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_412.Parsetree.structure_item -> Ast_413.Parsetree.structure_item =\n fun { Ast_412.Parsetree.pstr_desc; Ast_412.Parsetree.pstr_loc } ->\n {\n Ast_413.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_413.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_412.Parsetree.structure_item_desc ->\n Ast_413.Parsetree.structure_item_desc = function\n | Ast_412.Parsetree.Pstr_eval (x0, x1) ->\n Ast_413.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_412.Parsetree.Pstr_value (x0, x1) ->\n Ast_413.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_412.Parsetree.Pstr_primitive x0 ->\n Ast_413.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_412.Parsetree.Pstr_type (x0, x1) ->\n Ast_413.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_412.Parsetree.Pstr_typext x0 ->\n Ast_413.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_412.Parsetree.Pstr_exception x0 ->\n Ast_413.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_412.Parsetree.Pstr_module x0 ->\n Ast_413.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_412.Parsetree.Pstr_recmodule x0 ->\n Ast_413.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_412.Parsetree.Pstr_modtype x0 ->\n Ast_413.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_412.Parsetree.Pstr_open x0 ->\n Ast_413.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_412.Parsetree.Pstr_class x0 ->\n Ast_413.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_412.Parsetree.Pstr_class_type x0 ->\n Ast_413.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_412.Parsetree.Pstr_include x0 ->\n Ast_413.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_412.Parsetree.Pstr_attribute x0 ->\n Ast_413.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pstr_extension (x0, x1) ->\n Ast_413.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_412.Parsetree.include_declaration ->\n Ast_413.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_412.Parsetree.class_declaration -> Ast_413.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_412.Parsetree.class_expr -> Ast_413.Parsetree.class_expr =\n fun {\n Ast_412.Parsetree.pcl_desc;\n Ast_412.Parsetree.pcl_loc;\n Ast_412.Parsetree.pcl_attributes;\n } ->\n {\n Ast_413.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_413.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_413.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_412.Parsetree.class_expr_desc -> Ast_413.Parsetree.class_expr_desc =\n function\n | Ast_412.Parsetree.Pcl_constr (x0, x1) ->\n Ast_413.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Pcl_structure x0 ->\n Ast_413.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_412.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_413.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_412.Parsetree.Pcl_apply (x0, x1) ->\n Ast_413.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_412.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_413.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_412.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_413.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_412.Parsetree.Pcl_extension x0 ->\n Ast_413.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_412.Parsetree.Pcl_open (x0, x1) ->\n Ast_413.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_412.Parsetree.class_structure -> Ast_413.Parsetree.class_structure =\n fun { Ast_412.Parsetree.pcstr_self; Ast_412.Parsetree.pcstr_fields } ->\n {\n Ast_413.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_413.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_412.Parsetree.class_field -> Ast_413.Parsetree.class_field =\n fun {\n Ast_412.Parsetree.pcf_desc;\n Ast_412.Parsetree.pcf_loc;\n Ast_412.Parsetree.pcf_attributes;\n } ->\n {\n Ast_413.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_413.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_413.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_412.Parsetree.class_field_desc -> Ast_413.Parsetree.class_field_desc =\n function\n | Ast_412.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_413.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_412.Parsetree.Pcf_val x0 ->\n Ast_413.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_412.Parsetree.Pcf_method x0 ->\n Ast_413.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_412.Parsetree.Pcf_constraint x0 ->\n Ast_413.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_412.Parsetree.Pcf_initializer x0 ->\n Ast_413.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_412.Parsetree.Pcf_attribute x0 ->\n Ast_413.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pcf_extension x0 ->\n Ast_413.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_412.Parsetree.class_field_kind -> Ast_413.Parsetree.class_field_kind =\n function\n | Ast_412.Parsetree.Cfk_virtual x0 ->\n Ast_413.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_412.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_413.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_412.Parsetree.open_declaration -> Ast_413.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_412.Parsetree.module_binding -> Ast_413.Parsetree.module_binding =\n fun {\n Ast_412.Parsetree.pmb_name;\n Ast_412.Parsetree.pmb_expr;\n Ast_412.Parsetree.pmb_attributes;\n Ast_412.Parsetree.pmb_loc;\n } ->\n {\n Ast_413.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_413.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_413.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_413.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_412.Parsetree.module_expr -> Ast_413.Parsetree.module_expr =\n fun {\n Ast_412.Parsetree.pmod_desc;\n Ast_412.Parsetree.pmod_loc;\n Ast_412.Parsetree.pmod_attributes;\n } ->\n {\n Ast_413.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_413.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_413.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_412.Parsetree.module_expr_desc -> Ast_413.Parsetree.module_expr_desc =\n function\n | Ast_412.Parsetree.Pmod_ident x0 ->\n Ast_413.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pmod_structure x0 ->\n Ast_413.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_412.Parsetree.Pmod_functor (x0, x1) ->\n Ast_413.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_412.Parsetree.Pmod_apply (x0, x1) ->\n Ast_413.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_412.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_413.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_412.Parsetree.Pmod_unpack x0 ->\n Ast_413.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_412.Parsetree.Pmod_extension x0 ->\n Ast_413.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_412.Parsetree.functor_parameter -> Ast_413.Parsetree.functor_parameter =\n function\n | Ast_412.Parsetree.Unit -> Ast_413.Parsetree.Unit\n | Ast_412.Parsetree.Named (x0, x1) ->\n Ast_413.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_412.Parsetree.module_type -> Ast_413.Parsetree.module_type =\n fun {\n Ast_412.Parsetree.pmty_desc;\n Ast_412.Parsetree.pmty_loc;\n Ast_412.Parsetree.pmty_attributes;\n } ->\n {\n Ast_413.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_413.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_413.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_412.Parsetree.module_type_desc -> Ast_413.Parsetree.module_type_desc =\n function\n | Ast_412.Parsetree.Pmty_ident x0 ->\n Ast_413.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pmty_signature x0 ->\n Ast_413.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_412.Parsetree.Pmty_functor (x0, x1) ->\n Ast_413.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_412.Parsetree.Pmty_with (x0, x1) ->\n Ast_413.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_412.Parsetree.Pmty_typeof x0 ->\n Ast_413.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_412.Parsetree.Pmty_extension x0 ->\n Ast_413.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_412.Parsetree.Pmty_alias x0 ->\n Ast_413.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_412.Parsetree.with_constraint -> Ast_413.Parsetree.with_constraint =\n function\n | Ast_412.Parsetree.Pwith_type (x0, x1) ->\n Ast_413.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_412.Parsetree.Pwith_module (x0, x1) ->\n Ast_413.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_412.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_413.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_412.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_413.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_412.Parsetree.signature -> Ast_413.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_412.Parsetree.signature_item -> Ast_413.Parsetree.signature_item =\n fun { Ast_412.Parsetree.psig_desc; Ast_412.Parsetree.psig_loc } ->\n {\n Ast_413.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_413.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_412.Parsetree.signature_item_desc ->\n Ast_413.Parsetree.signature_item_desc = function\n | Ast_412.Parsetree.Psig_value x0 ->\n Ast_413.Parsetree.Psig_value (copy_value_description x0)\n | Ast_412.Parsetree.Psig_type (x0, x1) ->\n Ast_413.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_412.Parsetree.Psig_typesubst x0 ->\n Ast_413.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_412.Parsetree.Psig_typext x0 ->\n Ast_413.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_412.Parsetree.Psig_exception x0 ->\n Ast_413.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_412.Parsetree.Psig_module x0 ->\n Ast_413.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_412.Parsetree.Psig_modsubst x0 ->\n Ast_413.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_412.Parsetree.Psig_recmodule x0 ->\n Ast_413.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_412.Parsetree.Psig_modtype x0 ->\n Ast_413.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_412.Parsetree.Psig_open x0 ->\n Ast_413.Parsetree.Psig_open (copy_open_description x0)\n | Ast_412.Parsetree.Psig_include x0 ->\n Ast_413.Parsetree.Psig_include (copy_include_description x0)\n | Ast_412.Parsetree.Psig_class x0 ->\n Ast_413.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_412.Parsetree.Psig_class_type x0 ->\n Ast_413.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_412.Parsetree.Psig_attribute x0 ->\n Ast_413.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Psig_extension (x0, x1) ->\n Ast_413.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_412.Parsetree.class_type_declaration ->\n Ast_413.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_412.Parsetree.class_description -> Ast_413.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_412.Parsetree.class_type -> Ast_413.Parsetree.class_type =\n fun {\n Ast_412.Parsetree.pcty_desc;\n Ast_412.Parsetree.pcty_loc;\n Ast_412.Parsetree.pcty_attributes;\n } ->\n {\n Ast_413.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_413.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_413.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_412.Parsetree.class_type_desc -> Ast_413.Parsetree.class_type_desc =\n function\n | Ast_412.Parsetree.Pcty_constr (x0, x1) ->\n Ast_413.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Pcty_signature x0 ->\n Ast_413.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_412.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_413.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_412.Parsetree.Pcty_extension x0 ->\n Ast_413.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_412.Parsetree.Pcty_open (x0, x1) ->\n Ast_413.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_412.Parsetree.class_signature -> Ast_413.Parsetree.class_signature =\n fun { Ast_412.Parsetree.pcsig_self; Ast_412.Parsetree.pcsig_fields } ->\n {\n Ast_413.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_413.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_412.Parsetree.class_type_field -> Ast_413.Parsetree.class_type_field =\n fun {\n Ast_412.Parsetree.pctf_desc;\n Ast_412.Parsetree.pctf_loc;\n Ast_412.Parsetree.pctf_attributes;\n } ->\n {\n Ast_413.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_413.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_413.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_412.Parsetree.class_type_field_desc ->\n Ast_413.Parsetree.class_type_field_desc = function\n | Ast_412.Parsetree.Pctf_inherit x0 ->\n Ast_413.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_412.Parsetree.Pctf_val x0 ->\n Ast_413.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_412.Parsetree.Pctf_method x0 ->\n Ast_413.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_412.Parsetree.Pctf_constraint x0 ->\n Ast_413.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_412.Parsetree.Pctf_attribute x0 ->\n Ast_413.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pctf_extension x0 ->\n Ast_413.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_412.Parsetree.extension -> Ast_413.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.class_infos ->\n 'g0 Ast_413.Parsetree.class_infos =\n fun f0\n {\n Ast_412.Parsetree.pci_virt;\n Ast_412.Parsetree.pci_params;\n Ast_412.Parsetree.pci_name;\n Ast_412.Parsetree.pci_expr;\n Ast_412.Parsetree.pci_loc;\n Ast_412.Parsetree.pci_attributes;\n } ->\n {\n Ast_413.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_413.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n pci_params;\n Ast_413.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_413.Parsetree.pci_expr = f0 pci_expr;\n Ast_413.Parsetree.pci_loc = copy_location pci_loc;\n Ast_413.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_412.Asttypes.virtual_flag -> Ast_413.Asttypes.virtual_flag = function\n | Ast_412.Asttypes.Virtual -> Ast_413.Asttypes.Virtual\n | Ast_412.Asttypes.Concrete -> Ast_413.Asttypes.Concrete\n\nand copy_include_description :\n Ast_412.Parsetree.include_description ->\n Ast_413.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.include_infos ->\n 'g0 Ast_413.Parsetree.include_infos =\n fun f0\n {\n Ast_412.Parsetree.pincl_mod;\n Ast_412.Parsetree.pincl_loc;\n Ast_412.Parsetree.pincl_attributes;\n } ->\n {\n Ast_413.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_413.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_413.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_412.Parsetree.open_description -> Ast_413.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.open_infos ->\n 'g0 Ast_413.Parsetree.open_infos =\n fun f0\n {\n Ast_412.Parsetree.popen_expr;\n Ast_412.Parsetree.popen_override;\n Ast_412.Parsetree.popen_loc;\n Ast_412.Parsetree.popen_attributes;\n } ->\n {\n Ast_413.Parsetree.popen_expr = f0 popen_expr;\n Ast_413.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_413.Parsetree.popen_loc = copy_location popen_loc;\n Ast_413.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_412.Asttypes.override_flag -> Ast_413.Asttypes.override_flag = function\n | Ast_412.Asttypes.Override -> Ast_413.Asttypes.Override\n | Ast_412.Asttypes.Fresh -> Ast_413.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_412.Parsetree.module_type_declaration ->\n Ast_413.Parsetree.module_type_declaration =\n fun {\n Ast_412.Parsetree.pmtd_name;\n Ast_412.Parsetree.pmtd_type;\n Ast_412.Parsetree.pmtd_attributes;\n Ast_412.Parsetree.pmtd_loc;\n } ->\n {\n Ast_413.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_413.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_413.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_413.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_412.Parsetree.module_substitution ->\n Ast_413.Parsetree.module_substitution =\n fun {\n Ast_412.Parsetree.pms_name;\n Ast_412.Parsetree.pms_manifest;\n Ast_412.Parsetree.pms_attributes;\n Ast_412.Parsetree.pms_loc;\n } ->\n {\n Ast_413.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_413.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_413.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_413.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_412.Parsetree.module_declaration -> Ast_413.Parsetree.module_declaration\n =\n fun {\n Ast_412.Parsetree.pmd_name;\n Ast_412.Parsetree.pmd_type;\n Ast_412.Parsetree.pmd_attributes;\n Ast_412.Parsetree.pmd_loc;\n } ->\n {\n Ast_413.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_413.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_413.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_413.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_412.Parsetree.type_exception -> Ast_413.Parsetree.type_exception =\n fun {\n Ast_412.Parsetree.ptyexn_constructor;\n Ast_412.Parsetree.ptyexn_loc;\n Ast_412.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_413.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_413.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_412.Parsetree.type_extension -> Ast_413.Parsetree.type_extension =\n fun {\n Ast_412.Parsetree.ptyext_path;\n Ast_412.Parsetree.ptyext_params;\n Ast_412.Parsetree.ptyext_constructors;\n Ast_412.Parsetree.ptyext_private;\n Ast_412.Parsetree.ptyext_loc;\n Ast_412.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_413.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_413.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptyext_params;\n Ast_413.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_413.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_413.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_413.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_412.Parsetree.extension_constructor ->\n Ast_413.Parsetree.extension_constructor =\n fun {\n Ast_412.Parsetree.pext_name;\n Ast_412.Parsetree.pext_kind;\n Ast_412.Parsetree.pext_loc;\n Ast_412.Parsetree.pext_attributes;\n } ->\n {\n Ast_413.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_413.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_413.Parsetree.pext_loc = copy_location pext_loc;\n Ast_413.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_412.Parsetree.extension_constructor_kind ->\n Ast_413.Parsetree.extension_constructor_kind = function\n | Ast_412.Parsetree.Pext_decl (x0, x1) ->\n Ast_413.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_412.Parsetree.Pext_rebind x0 ->\n Ast_413.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_412.Parsetree.type_declaration -> Ast_413.Parsetree.type_declaration =\n fun {\n Ast_412.Parsetree.ptype_name;\n Ast_412.Parsetree.ptype_params;\n Ast_412.Parsetree.ptype_cstrs;\n Ast_412.Parsetree.ptype_kind;\n Ast_412.Parsetree.ptype_private;\n Ast_412.Parsetree.ptype_manifest;\n Ast_412.Parsetree.ptype_attributes;\n Ast_412.Parsetree.ptype_loc;\n } ->\n {\n Ast_413.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_413.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, x1 = x1 in\n (copy_variance x0, copy_injectivity x1) ))\n ptype_params;\n Ast_413.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_413.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_413.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_413.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_413.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_413.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_412.Asttypes.private_flag -> Ast_413.Asttypes.private_flag = function\n | Ast_412.Asttypes.Private -> Ast_413.Asttypes.Private\n | Ast_412.Asttypes.Public -> Ast_413.Asttypes.Public\n\nand copy_type_kind : Ast_412.Parsetree.type_kind -> Ast_413.Parsetree.type_kind\n = function\n | Ast_412.Parsetree.Ptype_abstract -> Ast_413.Parsetree.Ptype_abstract\n | Ast_412.Parsetree.Ptype_variant x0 ->\n Ast_413.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_412.Parsetree.Ptype_record x0 ->\n Ast_413.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_412.Parsetree.Ptype_open -> Ast_413.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_412.Parsetree.constructor_declaration ->\n Ast_413.Parsetree.constructor_declaration =\n fun {\n Ast_412.Parsetree.pcd_name;\n Ast_412.Parsetree.pcd_args;\n Ast_412.Parsetree.pcd_res;\n Ast_412.Parsetree.pcd_loc;\n Ast_412.Parsetree.pcd_attributes;\n } ->\n {\n Ast_413.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_413.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_413.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_413.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_413.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_412.Parsetree.constructor_arguments ->\n Ast_413.Parsetree.constructor_arguments = function\n | Ast_412.Parsetree.Pcstr_tuple x0 ->\n Ast_413.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_412.Parsetree.Pcstr_record x0 ->\n Ast_413.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_412.Parsetree.label_declaration -> Ast_413.Parsetree.label_declaration =\n fun {\n Ast_412.Parsetree.pld_name;\n Ast_412.Parsetree.pld_mutable;\n Ast_412.Parsetree.pld_type;\n Ast_412.Parsetree.pld_loc;\n Ast_412.Parsetree.pld_attributes;\n } ->\n {\n Ast_413.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_413.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_413.Parsetree.pld_type = copy_core_type pld_type;\n Ast_413.Parsetree.pld_loc = copy_location pld_loc;\n Ast_413.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_412.Asttypes.mutable_flag -> Ast_413.Asttypes.mutable_flag = function\n | Ast_412.Asttypes.Immutable -> Ast_413.Asttypes.Immutable\n | Ast_412.Asttypes.Mutable -> Ast_413.Asttypes.Mutable\n\nand copy_injectivity :\n Ast_412.Asttypes.injectivity -> Ast_413.Asttypes.injectivity = function\n | Ast_412.Asttypes.Injective -> Ast_413.Asttypes.Injective\n | Ast_412.Asttypes.NoInjectivity -> Ast_413.Asttypes.NoInjectivity\n\nand copy_variance : Ast_412.Asttypes.variance -> Ast_413.Asttypes.variance =\n function\n | Ast_412.Asttypes.Covariant -> Ast_413.Asttypes.Covariant\n | Ast_412.Asttypes.Contravariant -> Ast_413.Asttypes.Contravariant\n | Ast_412.Asttypes.NoVariance -> Ast_413.Asttypes.NoVariance\n\nand copy_value_description :\n Ast_412.Parsetree.value_description -> Ast_413.Parsetree.value_description =\n fun {\n Ast_412.Parsetree.pval_name;\n Ast_412.Parsetree.pval_type;\n Ast_412.Parsetree.pval_prim;\n Ast_412.Parsetree.pval_attributes;\n Ast_412.Parsetree.pval_loc;\n } ->\n {\n Ast_413.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_413.Parsetree.pval_type = copy_core_type pval_type;\n Ast_413.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_413.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_413.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_412.Parsetree.object_field_desc -> Ast_413.Parsetree.object_field_desc =\n function\n | Ast_412.Parsetree.Otag (x0, x1) ->\n Ast_413.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_412.Parsetree.Oinherit x0 ->\n Ast_413.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_412.Asttypes.arg_label -> Ast_413.Asttypes.arg_label =\n function\n | Ast_412.Asttypes.Nolabel -> Ast_413.Asttypes.Nolabel\n | Ast_412.Asttypes.Labelled x0 -> Ast_413.Asttypes.Labelled x0\n | Ast_412.Asttypes.Optional x0 -> Ast_413.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_412.Asttypes.closed_flag -> Ast_413.Asttypes.closed_flag = function\n | Ast_412.Asttypes.Closed -> Ast_413.Asttypes.Closed\n | Ast_412.Asttypes.Open -> Ast_413.Asttypes.Open\n\nand copy_label : Ast_412.Asttypes.label -> Ast_413.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_412.Asttypes.rec_flag -> Ast_413.Asttypes.rec_flag =\n function\n | Ast_412.Asttypes.Nonrecursive -> Ast_413.Asttypes.Nonrecursive\n | Ast_412.Asttypes.Recursive -> Ast_413.Asttypes.Recursive\n\nand copy_constant : Ast_412.Parsetree.constant -> Ast_413.Parsetree.constant =\n function\n | Ast_412.Parsetree.Pconst_integer (x0, x1) ->\n Ast_413.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_412.Parsetree.Pconst_char x0 -> Ast_413.Parsetree.Pconst_char x0\n | Ast_412.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_413.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_412.Parsetree.Pconst_float (x0, x1) ->\n Ast_413.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_412.Asttypes.loc -> 'g0 Ast_413.Asttypes.loc =\n fun f0 { Ast_412.Asttypes.txt; Ast_412.Asttypes.loc } ->\n { Ast_413.Asttypes.txt = f0 txt; Ast_413.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_412\nmodule To = Ast_411\n\nlet rec copy_toplevel_phrase :\n Ast_412.Parsetree.toplevel_phrase -> Ast_411.Parsetree.toplevel_phrase =\n function\n | Ast_412.Parsetree.Ptop_def x0 ->\n Ast_411.Parsetree.Ptop_def (copy_structure x0)\n | Ast_412.Parsetree.Ptop_dir x0 ->\n Ast_411.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_412.Parsetree.toplevel_directive -> Ast_411.Parsetree.toplevel_directive\n =\n fun {\n Ast_412.Parsetree.pdir_name;\n Ast_412.Parsetree.pdir_arg;\n Ast_412.Parsetree.pdir_loc;\n } ->\n {\n Ast_411.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_411.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_411.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_412.Parsetree.directive_argument -> Ast_411.Parsetree.directive_argument\n =\n fun { Ast_412.Parsetree.pdira_desc; Ast_412.Parsetree.pdira_loc } ->\n {\n Ast_411.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_411.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_412.Parsetree.directive_argument_desc ->\n Ast_411.Parsetree.directive_argument_desc = function\n | Ast_412.Parsetree.Pdir_string x0 -> Ast_411.Parsetree.Pdir_string x0\n | Ast_412.Parsetree.Pdir_int (x0, x1) ->\n Ast_411.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_412.Parsetree.Pdir_ident x0 ->\n Ast_411.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_412.Parsetree.Pdir_bool x0 -> Ast_411.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_412.Parsetree.expression -> Ast_411.Parsetree.expression =\n fun {\n Ast_412.Parsetree.pexp_desc;\n Ast_412.Parsetree.pexp_loc;\n Ast_412.Parsetree.pexp_loc_stack;\n Ast_412.Parsetree.pexp_attributes;\n } ->\n {\n Ast_411.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_411.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_411.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_411.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_412.Parsetree.expression_desc -> Ast_411.Parsetree.expression_desc =\n function\n | Ast_412.Parsetree.Pexp_ident x0 ->\n Ast_411.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pexp_constant x0 ->\n Ast_411.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_412.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_412.Parsetree.Pexp_function x0 ->\n Ast_411.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_412.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_411.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_412.Parsetree.Pexp_apply (x0, x1) ->\n Ast_411.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_412.Parsetree.Pexp_match (x0, x1) ->\n Ast_411.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_412.Parsetree.Pexp_try (x0, x1) ->\n Ast_411.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_412.Parsetree.Pexp_tuple x0 ->\n Ast_411.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_412.Parsetree.Pexp_construct (x0, x1) ->\n Ast_411.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_412.Parsetree.Pexp_variant (x0, x1) ->\n Ast_411.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_412.Parsetree.Pexp_record (x0, x1) ->\n Ast_411.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_412.Parsetree.Pexp_field (x0, x1) ->\n Ast_411.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_412.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_412.Parsetree.Pexp_array x0 ->\n Ast_411.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_412.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_412.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_411.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_while (x0, x1) ->\n Ast_411.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_411.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_412.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_411.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_412.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_412.Parsetree.Pexp_send (x0, x1) ->\n Ast_411.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_412.Parsetree.Pexp_new x0 ->\n Ast_411.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_411.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_override x0 ->\n Ast_411.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_412.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_412.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_411.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_assert x0 ->\n Ast_411.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_412.Parsetree.Pexp_lazy x0 ->\n Ast_411.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_412.Parsetree.Pexp_poly (x0, x1) ->\n Ast_411.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_412.Parsetree.Pexp_object x0 ->\n Ast_411.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_412.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_411.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_pack x0 ->\n Ast_411.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_412.Parsetree.Pexp_open (x0, x1) ->\n Ast_411.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_412.Parsetree.Pexp_letop x0 ->\n Ast_411.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_412.Parsetree.Pexp_extension x0 ->\n Ast_411.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_412.Parsetree.Pexp_unreachable -> Ast_411.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_412.Parsetree.letop -> Ast_411.Parsetree.letop =\n fun { Ast_412.Parsetree.let_; Ast_412.Parsetree.ands; Ast_412.Parsetree.body } ->\n {\n Ast_411.Parsetree.let_ = copy_binding_op let_;\n Ast_411.Parsetree.ands = List.map copy_binding_op ands;\n Ast_411.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_412.Parsetree.binding_op -> Ast_411.Parsetree.binding_op =\n fun {\n Ast_412.Parsetree.pbop_op;\n Ast_412.Parsetree.pbop_pat;\n Ast_412.Parsetree.pbop_exp;\n Ast_412.Parsetree.pbop_loc;\n } ->\n {\n Ast_411.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_411.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_411.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_411.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_412.Asttypes.direction_flag -> Ast_411.Asttypes.direction_flag =\n function\n | Ast_412.Asttypes.Upto -> Ast_411.Asttypes.Upto\n | Ast_412.Asttypes.Downto -> Ast_411.Asttypes.Downto\n\nand copy_case : Ast_412.Parsetree.case -> Ast_411.Parsetree.case =\n fun {\n Ast_412.Parsetree.pc_lhs;\n Ast_412.Parsetree.pc_guard;\n Ast_412.Parsetree.pc_rhs;\n } ->\n {\n Ast_411.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_411.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_411.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_412.Parsetree.value_binding -> Ast_411.Parsetree.value_binding =\n fun {\n Ast_412.Parsetree.pvb_pat;\n Ast_412.Parsetree.pvb_expr;\n Ast_412.Parsetree.pvb_attributes;\n Ast_412.Parsetree.pvb_loc;\n } ->\n {\n Ast_411.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_411.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_411.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_411.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_412.Parsetree.pattern -> Ast_411.Parsetree.pattern =\n fun {\n Ast_412.Parsetree.ppat_desc;\n Ast_412.Parsetree.ppat_loc;\n Ast_412.Parsetree.ppat_loc_stack;\n Ast_412.Parsetree.ppat_attributes;\n } ->\n {\n Ast_411.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_411.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_411.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_411.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_412.Parsetree.pattern_desc -> Ast_411.Parsetree.pattern_desc = function\n | Ast_412.Parsetree.Ppat_any -> Ast_411.Parsetree.Ppat_any\n | Ast_412.Parsetree.Ppat_var x0 ->\n Ast_411.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_412.Parsetree.Ppat_alias (x0, x1) ->\n Ast_411.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_412.Parsetree.Ppat_constant x0 ->\n Ast_411.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_412.Parsetree.Ppat_interval (x0, x1) ->\n Ast_411.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_412.Parsetree.Ppat_tuple x0 ->\n Ast_411.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_412.Parsetree.Ppat_construct (x0, x1) ->\n Ast_411.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_412.Parsetree.Ppat_variant (x0, x1) ->\n Ast_411.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_412.Parsetree.Ppat_record (x0, x1) ->\n Ast_411.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_412.Parsetree.Ppat_array x0 ->\n Ast_411.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_412.Parsetree.Ppat_or (x0, x1) ->\n Ast_411.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_412.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_411.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_412.Parsetree.Ppat_type x0 ->\n Ast_411.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Ppat_lazy x0 ->\n Ast_411.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_412.Parsetree.Ppat_unpack x0 ->\n Ast_411.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_412.Parsetree.Ppat_exception x0 ->\n Ast_411.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_412.Parsetree.Ppat_extension x0 ->\n Ast_411.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_412.Parsetree.Ppat_open (x0, x1) ->\n Ast_411.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_412.Parsetree.core_type -> Ast_411.Parsetree.core_type\n =\n fun {\n Ast_412.Parsetree.ptyp_desc;\n Ast_412.Parsetree.ptyp_loc;\n Ast_412.Parsetree.ptyp_loc_stack;\n Ast_412.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_411.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_411.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_411.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_412.Parsetree.location_stack -> Ast_411.Parsetree.location_stack =\n fun x -> x\n\nand copy_core_type_desc :\n Ast_412.Parsetree.core_type_desc -> Ast_411.Parsetree.core_type_desc =\n function\n | Ast_412.Parsetree.Ptyp_any -> Ast_411.Parsetree.Ptyp_any\n | Ast_412.Parsetree.Ptyp_var x0 -> Ast_411.Parsetree.Ptyp_var x0\n | Ast_412.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_411.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_412.Parsetree.Ptyp_tuple x0 ->\n Ast_411.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_412.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_411.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_object (x0, x1) ->\n Ast_411.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_412.Parsetree.Ptyp_class (x0, x1) ->\n Ast_411.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_411.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_412.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_411.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_412.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_411.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_412.Parsetree.Ptyp_package x0 ->\n Ast_411.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_412.Parsetree.Ptyp_extension x0 ->\n Ast_411.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_412.Parsetree.package_type -> Ast_411.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_412.Parsetree.row_field -> Ast_411.Parsetree.row_field\n =\n fun {\n Ast_412.Parsetree.prf_desc;\n Ast_412.Parsetree.prf_loc;\n Ast_412.Parsetree.prf_attributes;\n } ->\n {\n Ast_411.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_411.Parsetree.prf_loc = copy_location prf_loc;\n Ast_411.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_412.Parsetree.row_field_desc -> Ast_411.Parsetree.row_field_desc =\n function\n | Ast_412.Parsetree.Rtag (x0, x1, x2) ->\n Ast_411.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_412.Parsetree.Rinherit x0 ->\n Ast_411.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_412.Parsetree.object_field -> Ast_411.Parsetree.object_field =\n fun {\n Ast_412.Parsetree.pof_desc;\n Ast_412.Parsetree.pof_loc;\n Ast_412.Parsetree.pof_attributes;\n } ->\n {\n Ast_411.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_411.Parsetree.pof_loc = copy_location pof_loc;\n Ast_411.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_412.Parsetree.attributes -> Ast_411.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_412.Parsetree.attribute -> Ast_411.Parsetree.attribute\n =\n fun {\n Ast_412.Parsetree.attr_name;\n Ast_412.Parsetree.attr_payload;\n Ast_412.Parsetree.attr_loc;\n } ->\n {\n Ast_411.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_411.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_411.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_412.Parsetree.payload -> Ast_411.Parsetree.payload =\n function\n | Ast_412.Parsetree.PStr x0 -> Ast_411.Parsetree.PStr (copy_structure x0)\n | Ast_412.Parsetree.PSig x0 -> Ast_411.Parsetree.PSig (copy_signature x0)\n | Ast_412.Parsetree.PTyp x0 -> Ast_411.Parsetree.PTyp (copy_core_type x0)\n | Ast_412.Parsetree.PPat (x0, x1) ->\n Ast_411.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_412.Parsetree.structure -> Ast_411.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_412.Parsetree.structure_item -> Ast_411.Parsetree.structure_item =\n fun { Ast_412.Parsetree.pstr_desc; Ast_412.Parsetree.pstr_loc } ->\n {\n Ast_411.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_411.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_412.Parsetree.structure_item_desc ->\n Ast_411.Parsetree.structure_item_desc = function\n | Ast_412.Parsetree.Pstr_eval (x0, x1) ->\n Ast_411.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_412.Parsetree.Pstr_value (x0, x1) ->\n Ast_411.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_412.Parsetree.Pstr_primitive x0 ->\n Ast_411.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_412.Parsetree.Pstr_type (x0, x1) ->\n Ast_411.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_412.Parsetree.Pstr_typext x0 ->\n Ast_411.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_412.Parsetree.Pstr_exception x0 ->\n Ast_411.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_412.Parsetree.Pstr_module x0 ->\n Ast_411.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_412.Parsetree.Pstr_recmodule x0 ->\n Ast_411.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_412.Parsetree.Pstr_modtype x0 ->\n Ast_411.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_412.Parsetree.Pstr_open x0 ->\n Ast_411.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_412.Parsetree.Pstr_class x0 ->\n Ast_411.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_412.Parsetree.Pstr_class_type x0 ->\n Ast_411.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_412.Parsetree.Pstr_include x0 ->\n Ast_411.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_412.Parsetree.Pstr_attribute x0 ->\n Ast_411.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pstr_extension (x0, x1) ->\n Ast_411.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_412.Parsetree.include_declaration ->\n Ast_411.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_412.Parsetree.class_declaration -> Ast_411.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_412.Parsetree.class_expr -> Ast_411.Parsetree.class_expr =\n fun {\n Ast_412.Parsetree.pcl_desc;\n Ast_412.Parsetree.pcl_loc;\n Ast_412.Parsetree.pcl_attributes;\n } ->\n {\n Ast_411.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_411.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_411.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_412.Parsetree.class_expr_desc -> Ast_411.Parsetree.class_expr_desc =\n function\n | Ast_412.Parsetree.Pcl_constr (x0, x1) ->\n Ast_411.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Pcl_structure x0 ->\n Ast_411.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_412.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_411.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_412.Parsetree.Pcl_apply (x0, x1) ->\n Ast_411.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_412.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_411.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_412.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_411.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_412.Parsetree.Pcl_extension x0 ->\n Ast_411.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_412.Parsetree.Pcl_open (x0, x1) ->\n Ast_411.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_412.Parsetree.class_structure -> Ast_411.Parsetree.class_structure =\n fun { Ast_412.Parsetree.pcstr_self; Ast_412.Parsetree.pcstr_fields } ->\n {\n Ast_411.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_411.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_412.Parsetree.class_field -> Ast_411.Parsetree.class_field =\n fun {\n Ast_412.Parsetree.pcf_desc;\n Ast_412.Parsetree.pcf_loc;\n Ast_412.Parsetree.pcf_attributes;\n } ->\n {\n Ast_411.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_411.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_411.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_412.Parsetree.class_field_desc -> Ast_411.Parsetree.class_field_desc =\n function\n | Ast_412.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_411.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_412.Parsetree.Pcf_val x0 ->\n Ast_411.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_412.Parsetree.Pcf_method x0 ->\n Ast_411.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_412.Parsetree.Pcf_constraint x0 ->\n Ast_411.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_412.Parsetree.Pcf_initializer x0 ->\n Ast_411.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_412.Parsetree.Pcf_attribute x0 ->\n Ast_411.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pcf_extension x0 ->\n Ast_411.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_412.Parsetree.class_field_kind -> Ast_411.Parsetree.class_field_kind =\n function\n | Ast_412.Parsetree.Cfk_virtual x0 ->\n Ast_411.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_412.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_411.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_412.Parsetree.open_declaration -> Ast_411.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_412.Parsetree.module_binding -> Ast_411.Parsetree.module_binding =\n fun {\n Ast_412.Parsetree.pmb_name;\n Ast_412.Parsetree.pmb_expr;\n Ast_412.Parsetree.pmb_attributes;\n Ast_412.Parsetree.pmb_loc;\n } ->\n {\n Ast_411.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_411.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_411.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_411.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_412.Parsetree.module_expr -> Ast_411.Parsetree.module_expr =\n fun {\n Ast_412.Parsetree.pmod_desc;\n Ast_412.Parsetree.pmod_loc;\n Ast_412.Parsetree.pmod_attributes;\n } ->\n {\n Ast_411.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_411.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_411.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_412.Parsetree.module_expr_desc -> Ast_411.Parsetree.module_expr_desc =\n function\n | Ast_412.Parsetree.Pmod_ident x0 ->\n Ast_411.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pmod_structure x0 ->\n Ast_411.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_412.Parsetree.Pmod_functor (x0, x1) ->\n Ast_411.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_412.Parsetree.Pmod_apply (x0, x1) ->\n Ast_411.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_412.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_411.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_412.Parsetree.Pmod_unpack x0 ->\n Ast_411.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_412.Parsetree.Pmod_extension x0 ->\n Ast_411.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_412.Parsetree.functor_parameter -> Ast_411.Parsetree.functor_parameter =\n function\n | Ast_412.Parsetree.Unit -> Ast_411.Parsetree.Unit\n | Ast_412.Parsetree.Named (x0, x1) ->\n Ast_411.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_412.Parsetree.module_type -> Ast_411.Parsetree.module_type =\n fun {\n Ast_412.Parsetree.pmty_desc;\n Ast_412.Parsetree.pmty_loc;\n Ast_412.Parsetree.pmty_attributes;\n } ->\n {\n Ast_411.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_411.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_411.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_412.Parsetree.module_type_desc -> Ast_411.Parsetree.module_type_desc =\n function\n | Ast_412.Parsetree.Pmty_ident x0 ->\n Ast_411.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_412.Parsetree.Pmty_signature x0 ->\n Ast_411.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_412.Parsetree.Pmty_functor (x0, x1) ->\n Ast_411.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_412.Parsetree.Pmty_with (x0, x1) ->\n Ast_411.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_412.Parsetree.Pmty_typeof x0 ->\n Ast_411.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_412.Parsetree.Pmty_extension x0 ->\n Ast_411.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_412.Parsetree.Pmty_alias x0 ->\n Ast_411.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_412.Parsetree.with_constraint -> Ast_411.Parsetree.with_constraint =\n function\n | Ast_412.Parsetree.Pwith_type (x0, x1) ->\n Ast_411.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_412.Parsetree.Pwith_module (x0, x1) ->\n Ast_411.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_412.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_411.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_412.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_411.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_412.Parsetree.signature -> Ast_411.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_412.Parsetree.signature_item -> Ast_411.Parsetree.signature_item =\n fun { Ast_412.Parsetree.psig_desc; Ast_412.Parsetree.psig_loc } ->\n {\n Ast_411.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_411.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_412.Parsetree.signature_item_desc ->\n Ast_411.Parsetree.signature_item_desc = function\n | Ast_412.Parsetree.Psig_value x0 ->\n Ast_411.Parsetree.Psig_value (copy_value_description x0)\n | Ast_412.Parsetree.Psig_type (x0, x1) ->\n Ast_411.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_412.Parsetree.Psig_typesubst x0 ->\n Ast_411.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_412.Parsetree.Psig_typext x0 ->\n Ast_411.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_412.Parsetree.Psig_exception x0 ->\n Ast_411.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_412.Parsetree.Psig_module x0 ->\n Ast_411.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_412.Parsetree.Psig_modsubst x0 ->\n Ast_411.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_412.Parsetree.Psig_recmodule x0 ->\n Ast_411.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_412.Parsetree.Psig_modtype x0 ->\n Ast_411.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_412.Parsetree.Psig_open x0 ->\n Ast_411.Parsetree.Psig_open (copy_open_description x0)\n | Ast_412.Parsetree.Psig_include x0 ->\n Ast_411.Parsetree.Psig_include (copy_include_description x0)\n | Ast_412.Parsetree.Psig_class x0 ->\n Ast_411.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_412.Parsetree.Psig_class_type x0 ->\n Ast_411.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_412.Parsetree.Psig_attribute x0 ->\n Ast_411.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Psig_extension (x0, x1) ->\n Ast_411.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_412.Parsetree.class_type_declaration ->\n Ast_411.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_412.Parsetree.class_description -> Ast_411.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_412.Parsetree.class_type -> Ast_411.Parsetree.class_type =\n fun {\n Ast_412.Parsetree.pcty_desc;\n Ast_412.Parsetree.pcty_loc;\n Ast_412.Parsetree.pcty_attributes;\n } ->\n {\n Ast_411.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_411.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_411.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_412.Parsetree.class_type_desc -> Ast_411.Parsetree.class_type_desc =\n function\n | Ast_412.Parsetree.Pcty_constr (x0, x1) ->\n Ast_411.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_412.Parsetree.Pcty_signature x0 ->\n Ast_411.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_412.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_411.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_412.Parsetree.Pcty_extension x0 ->\n Ast_411.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_412.Parsetree.Pcty_open (x0, x1) ->\n Ast_411.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_412.Parsetree.class_signature -> Ast_411.Parsetree.class_signature =\n fun { Ast_412.Parsetree.pcsig_self; Ast_412.Parsetree.pcsig_fields } ->\n {\n Ast_411.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_411.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_412.Parsetree.class_type_field -> Ast_411.Parsetree.class_type_field =\n fun {\n Ast_412.Parsetree.pctf_desc;\n Ast_412.Parsetree.pctf_loc;\n Ast_412.Parsetree.pctf_attributes;\n } ->\n {\n Ast_411.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_411.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_411.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_412.Parsetree.class_type_field_desc ->\n Ast_411.Parsetree.class_type_field_desc = function\n | Ast_412.Parsetree.Pctf_inherit x0 ->\n Ast_411.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_412.Parsetree.Pctf_val x0 ->\n Ast_411.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_412.Parsetree.Pctf_method x0 ->\n Ast_411.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_412.Parsetree.Pctf_constraint x0 ->\n Ast_411.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_412.Parsetree.Pctf_attribute x0 ->\n Ast_411.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_412.Parsetree.Pctf_extension x0 ->\n Ast_411.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_412.Parsetree.extension -> Ast_411.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.class_infos ->\n 'g0 Ast_411.Parsetree.class_infos =\n fun f0\n {\n Ast_412.Parsetree.pci_virt;\n Ast_412.Parsetree.pci_params;\n Ast_412.Parsetree.pci_name;\n Ast_412.Parsetree.pci_expr;\n Ast_412.Parsetree.pci_loc;\n Ast_412.Parsetree.pci_attributes;\n } ->\n {\n Ast_411.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_411.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, _ = x1 in\n copy_variance x0 ))\n pci_params;\n Ast_411.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_411.Parsetree.pci_expr = f0 pci_expr;\n Ast_411.Parsetree.pci_loc = copy_location pci_loc;\n Ast_411.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_412.Asttypes.virtual_flag -> Ast_411.Asttypes.virtual_flag = function\n | Ast_412.Asttypes.Virtual -> Ast_411.Asttypes.Virtual\n | Ast_412.Asttypes.Concrete -> Ast_411.Asttypes.Concrete\n\nand copy_include_description :\n Ast_412.Parsetree.include_description ->\n Ast_411.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.include_infos ->\n 'g0 Ast_411.Parsetree.include_infos =\n fun f0\n {\n Ast_412.Parsetree.pincl_mod;\n Ast_412.Parsetree.pincl_loc;\n Ast_412.Parsetree.pincl_attributes;\n } ->\n {\n Ast_411.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_411.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_411.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_412.Parsetree.open_description -> Ast_411.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_412.Parsetree.open_infos ->\n 'g0 Ast_411.Parsetree.open_infos =\n fun f0\n {\n Ast_412.Parsetree.popen_expr;\n Ast_412.Parsetree.popen_override;\n Ast_412.Parsetree.popen_loc;\n Ast_412.Parsetree.popen_attributes;\n } ->\n {\n Ast_411.Parsetree.popen_expr = f0 popen_expr;\n Ast_411.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_411.Parsetree.popen_loc = copy_location popen_loc;\n Ast_411.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_412.Asttypes.override_flag -> Ast_411.Asttypes.override_flag = function\n | Ast_412.Asttypes.Override -> Ast_411.Asttypes.Override\n | Ast_412.Asttypes.Fresh -> Ast_411.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_412.Parsetree.module_type_declaration ->\n Ast_411.Parsetree.module_type_declaration =\n fun {\n Ast_412.Parsetree.pmtd_name;\n Ast_412.Parsetree.pmtd_type;\n Ast_412.Parsetree.pmtd_attributes;\n Ast_412.Parsetree.pmtd_loc;\n } ->\n {\n Ast_411.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_411.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_411.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_411.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_412.Parsetree.module_substitution ->\n Ast_411.Parsetree.module_substitution =\n fun {\n Ast_412.Parsetree.pms_name;\n Ast_412.Parsetree.pms_manifest;\n Ast_412.Parsetree.pms_attributes;\n Ast_412.Parsetree.pms_loc;\n } ->\n {\n Ast_411.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_411.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_411.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_411.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_412.Parsetree.module_declaration -> Ast_411.Parsetree.module_declaration\n =\n fun {\n Ast_412.Parsetree.pmd_name;\n Ast_412.Parsetree.pmd_type;\n Ast_412.Parsetree.pmd_attributes;\n Ast_412.Parsetree.pmd_loc;\n } ->\n {\n Ast_411.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_411.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_411.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_411.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_412.Parsetree.type_exception -> Ast_411.Parsetree.type_exception =\n fun {\n Ast_412.Parsetree.ptyexn_constructor;\n Ast_412.Parsetree.ptyexn_loc;\n Ast_412.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_411.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_411.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_412.Parsetree.type_extension -> Ast_411.Parsetree.type_extension =\n fun {\n Ast_412.Parsetree.ptyext_path;\n Ast_412.Parsetree.ptyext_params;\n Ast_412.Parsetree.ptyext_constructors;\n Ast_412.Parsetree.ptyext_private;\n Ast_412.Parsetree.ptyext_loc;\n Ast_412.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_411.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, _ = x1 in\n copy_variance x0 ))\n ptyext_params;\n Ast_411.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_411.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_411.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_411.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_412.Parsetree.extension_constructor ->\n Ast_411.Parsetree.extension_constructor =\n fun {\n Ast_412.Parsetree.pext_name;\n Ast_412.Parsetree.pext_kind;\n Ast_412.Parsetree.pext_loc;\n Ast_412.Parsetree.pext_attributes;\n } ->\n {\n Ast_411.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_411.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_411.Parsetree.pext_loc = copy_location pext_loc;\n Ast_411.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_412.Parsetree.extension_constructor_kind ->\n Ast_411.Parsetree.extension_constructor_kind = function\n | Ast_412.Parsetree.Pext_decl (x0, x1) ->\n Ast_411.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_412.Parsetree.Pext_rebind x0 ->\n Ast_411.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_412.Parsetree.type_declaration -> Ast_411.Parsetree.type_declaration =\n fun {\n Ast_412.Parsetree.ptype_name;\n Ast_412.Parsetree.ptype_params;\n Ast_412.Parsetree.ptype_cstrs;\n Ast_412.Parsetree.ptype_kind;\n Ast_412.Parsetree.ptype_private;\n Ast_412.Parsetree.ptype_manifest;\n Ast_412.Parsetree.ptype_attributes;\n Ast_412.Parsetree.ptype_loc;\n } ->\n {\n Ast_411.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_411.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n ( copy_core_type x0,\n let x0, _ = x1 in\n copy_variance x0 ))\n ptype_params;\n Ast_411.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_411.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_411.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_411.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_411.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_411.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_412.Asttypes.private_flag -> Ast_411.Asttypes.private_flag = function\n | Ast_412.Asttypes.Private -> Ast_411.Asttypes.Private\n | Ast_412.Asttypes.Public -> Ast_411.Asttypes.Public\n\nand copy_type_kind : Ast_412.Parsetree.type_kind -> Ast_411.Parsetree.type_kind\n = function\n | Ast_412.Parsetree.Ptype_abstract -> Ast_411.Parsetree.Ptype_abstract\n | Ast_412.Parsetree.Ptype_variant x0 ->\n Ast_411.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_412.Parsetree.Ptype_record x0 ->\n Ast_411.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_412.Parsetree.Ptype_open -> Ast_411.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_412.Parsetree.constructor_declaration ->\n Ast_411.Parsetree.constructor_declaration =\n fun {\n Ast_412.Parsetree.pcd_name;\n Ast_412.Parsetree.pcd_args;\n Ast_412.Parsetree.pcd_res;\n Ast_412.Parsetree.pcd_loc;\n Ast_412.Parsetree.pcd_attributes;\n } ->\n {\n Ast_411.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_411.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_411.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_411.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_411.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_412.Parsetree.constructor_arguments ->\n Ast_411.Parsetree.constructor_arguments = function\n | Ast_412.Parsetree.Pcstr_tuple x0 ->\n Ast_411.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_412.Parsetree.Pcstr_record x0 ->\n Ast_411.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_412.Parsetree.label_declaration -> Ast_411.Parsetree.label_declaration =\n fun {\n Ast_412.Parsetree.pld_name;\n Ast_412.Parsetree.pld_mutable;\n Ast_412.Parsetree.pld_type;\n Ast_412.Parsetree.pld_loc;\n Ast_412.Parsetree.pld_attributes;\n } ->\n {\n Ast_411.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_411.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_411.Parsetree.pld_type = copy_core_type pld_type;\n Ast_411.Parsetree.pld_loc = copy_location pld_loc;\n Ast_411.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_412.Asttypes.mutable_flag -> Ast_411.Asttypes.mutable_flag = function\n | Ast_412.Asttypes.Immutable -> Ast_411.Asttypes.Immutable\n | Ast_412.Asttypes.Mutable -> Ast_411.Asttypes.Mutable\n\nand copy_variance : Ast_412.Asttypes.variance -> Ast_411.Asttypes.variance =\n function\n | Ast_412.Asttypes.Covariant -> Ast_411.Asttypes.Covariant\n | Ast_412.Asttypes.Contravariant -> Ast_411.Asttypes.Contravariant\n | Ast_412.Asttypes.NoVariance -> Ast_411.Asttypes.Invariant\n\nand copy_value_description :\n Ast_412.Parsetree.value_description -> Ast_411.Parsetree.value_description =\n fun {\n Ast_412.Parsetree.pval_name;\n Ast_412.Parsetree.pval_type;\n Ast_412.Parsetree.pval_prim;\n Ast_412.Parsetree.pval_attributes;\n Ast_412.Parsetree.pval_loc;\n } ->\n {\n Ast_411.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_411.Parsetree.pval_type = copy_core_type pval_type;\n Ast_411.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_411.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_411.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_412.Parsetree.object_field_desc -> Ast_411.Parsetree.object_field_desc =\n function\n | Ast_412.Parsetree.Otag (x0, x1) ->\n Ast_411.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_412.Parsetree.Oinherit x0 ->\n Ast_411.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_412.Asttypes.arg_label -> Ast_411.Asttypes.arg_label =\n function\n | Ast_412.Asttypes.Nolabel -> Ast_411.Asttypes.Nolabel\n | Ast_412.Asttypes.Labelled x0 -> Ast_411.Asttypes.Labelled x0\n | Ast_412.Asttypes.Optional x0 -> Ast_411.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_412.Asttypes.closed_flag -> Ast_411.Asttypes.closed_flag = function\n | Ast_412.Asttypes.Closed -> Ast_411.Asttypes.Closed\n | Ast_412.Asttypes.Open -> Ast_411.Asttypes.Open\n\nand copy_label : Ast_412.Asttypes.label -> Ast_411.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_412.Asttypes.rec_flag -> Ast_411.Asttypes.rec_flag =\n function\n | Ast_412.Asttypes.Nonrecursive -> Ast_411.Asttypes.Nonrecursive\n | Ast_412.Asttypes.Recursive -> Ast_411.Asttypes.Recursive\n\nand copy_constant : Ast_412.Parsetree.constant -> Ast_411.Parsetree.constant =\n function\n | Ast_412.Parsetree.Pconst_integer (x0, x1) ->\n Ast_411.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_412.Parsetree.Pconst_char x0 -> Ast_411.Parsetree.Pconst_char x0\n | Ast_412.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_411.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_412.Parsetree.Pconst_float (x0, x1) ->\n Ast_411.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_412.Asttypes.loc -> 'g0 Ast_411.Asttypes.loc =\n fun f0 { Ast_412.Asttypes.txt; Ast_412.Asttypes.loc } ->\n { Ast_411.Asttypes.txt = f0 txt; Ast_411.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_411\nmodule To = Ast_412\n\nlet rec copy_toplevel_phrase :\n Ast_411.Parsetree.toplevel_phrase -> Ast_412.Parsetree.toplevel_phrase =\n function\n | Ast_411.Parsetree.Ptop_def x0 ->\n Ast_412.Parsetree.Ptop_def (copy_structure x0)\n | Ast_411.Parsetree.Ptop_dir x0 ->\n Ast_412.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_411.Parsetree.toplevel_directive -> Ast_412.Parsetree.toplevel_directive\n =\n fun {\n Ast_411.Parsetree.pdir_name;\n Ast_411.Parsetree.pdir_arg;\n Ast_411.Parsetree.pdir_loc;\n } ->\n {\n Ast_412.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_412.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_412.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_411.Parsetree.directive_argument -> Ast_412.Parsetree.directive_argument\n =\n fun { Ast_411.Parsetree.pdira_desc; Ast_411.Parsetree.pdira_loc } ->\n {\n Ast_412.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_412.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_411.Parsetree.directive_argument_desc ->\n Ast_412.Parsetree.directive_argument_desc = function\n | Ast_411.Parsetree.Pdir_string x0 -> Ast_412.Parsetree.Pdir_string x0\n | Ast_411.Parsetree.Pdir_int (x0, x1) ->\n Ast_412.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_411.Parsetree.Pdir_ident x0 ->\n Ast_412.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_411.Parsetree.Pdir_bool x0 -> Ast_412.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_411.Parsetree.expression -> Ast_412.Parsetree.expression =\n fun {\n Ast_411.Parsetree.pexp_desc;\n Ast_411.Parsetree.pexp_loc;\n Ast_411.Parsetree.pexp_loc_stack;\n Ast_411.Parsetree.pexp_attributes;\n } ->\n {\n Ast_412.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_412.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_412.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_412.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_411.Parsetree.expression_desc -> Ast_412.Parsetree.expression_desc =\n function\n | Ast_411.Parsetree.Pexp_ident x0 ->\n Ast_412.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pexp_constant x0 ->\n Ast_412.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_411.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_411.Parsetree.Pexp_function x0 ->\n Ast_412.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_411.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_412.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_411.Parsetree.Pexp_apply (x0, x1) ->\n Ast_412.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_411.Parsetree.Pexp_match (x0, x1) ->\n Ast_412.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_411.Parsetree.Pexp_try (x0, x1) ->\n Ast_412.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_411.Parsetree.Pexp_tuple x0 ->\n Ast_412.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_411.Parsetree.Pexp_construct (x0, x1) ->\n Ast_412.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_411.Parsetree.Pexp_variant (x0, x1) ->\n Ast_412.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_411.Parsetree.Pexp_record (x0, x1) ->\n Ast_412.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_411.Parsetree.Pexp_field (x0, x1) ->\n Ast_412.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_411.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_411.Parsetree.Pexp_array x0 ->\n Ast_412.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_411.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_411.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_412.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_while (x0, x1) ->\n Ast_412.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_412.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_411.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_412.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_411.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_411.Parsetree.Pexp_send (x0, x1) ->\n Ast_412.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_411.Parsetree.Pexp_new x0 ->\n Ast_412.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_412.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_override x0 ->\n Ast_412.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_411.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_412.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_411.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_412.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_assert x0 ->\n Ast_412.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_411.Parsetree.Pexp_lazy x0 ->\n Ast_412.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_411.Parsetree.Pexp_poly (x0, x1) ->\n Ast_412.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_411.Parsetree.Pexp_object x0 ->\n Ast_412.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_411.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_412.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_pack x0 ->\n Ast_412.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_411.Parsetree.Pexp_open (x0, x1) ->\n Ast_412.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_letop x0 ->\n Ast_412.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_411.Parsetree.Pexp_extension x0 ->\n Ast_412.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_411.Parsetree.Pexp_unreachable -> Ast_412.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_411.Parsetree.letop -> Ast_412.Parsetree.letop =\n fun { Ast_411.Parsetree.let_; Ast_411.Parsetree.ands; Ast_411.Parsetree.body } ->\n {\n Ast_412.Parsetree.let_ = copy_binding_op let_;\n Ast_412.Parsetree.ands = List.map copy_binding_op ands;\n Ast_412.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_411.Parsetree.binding_op -> Ast_412.Parsetree.binding_op =\n fun {\n Ast_411.Parsetree.pbop_op;\n Ast_411.Parsetree.pbop_pat;\n Ast_411.Parsetree.pbop_exp;\n Ast_411.Parsetree.pbop_loc;\n } ->\n {\n Ast_412.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_412.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_412.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_412.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_411.Asttypes.direction_flag -> Ast_412.Asttypes.direction_flag =\n function\n | Ast_411.Asttypes.Upto -> Ast_412.Asttypes.Upto\n | Ast_411.Asttypes.Downto -> Ast_412.Asttypes.Downto\n\nand copy_case : Ast_411.Parsetree.case -> Ast_412.Parsetree.case =\n fun {\n Ast_411.Parsetree.pc_lhs;\n Ast_411.Parsetree.pc_guard;\n Ast_411.Parsetree.pc_rhs;\n } ->\n {\n Ast_412.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_412.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_412.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_411.Parsetree.value_binding -> Ast_412.Parsetree.value_binding =\n fun {\n Ast_411.Parsetree.pvb_pat;\n Ast_411.Parsetree.pvb_expr;\n Ast_411.Parsetree.pvb_attributes;\n Ast_411.Parsetree.pvb_loc;\n } ->\n {\n Ast_412.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_412.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_412.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_412.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_411.Parsetree.pattern -> Ast_412.Parsetree.pattern =\n fun {\n Ast_411.Parsetree.ppat_desc;\n Ast_411.Parsetree.ppat_loc;\n Ast_411.Parsetree.ppat_loc_stack;\n Ast_411.Parsetree.ppat_attributes;\n } ->\n {\n Ast_412.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_412.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_412.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_412.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_411.Parsetree.pattern_desc -> Ast_412.Parsetree.pattern_desc = function\n | Ast_411.Parsetree.Ppat_any -> Ast_412.Parsetree.Ppat_any\n | Ast_411.Parsetree.Ppat_var x0 ->\n Ast_412.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_411.Parsetree.Ppat_alias (x0, x1) ->\n Ast_412.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_411.Parsetree.Ppat_constant x0 ->\n Ast_412.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_411.Parsetree.Ppat_interval (x0, x1) ->\n Ast_412.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_411.Parsetree.Ppat_tuple x0 ->\n Ast_412.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_411.Parsetree.Ppat_construct (x0, x1) ->\n Ast_412.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_411.Parsetree.Ppat_variant (x0, x1) ->\n Ast_412.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_411.Parsetree.Ppat_record (x0, x1) ->\n Ast_412.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_411.Parsetree.Ppat_array x0 ->\n Ast_412.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_411.Parsetree.Ppat_or (x0, x1) ->\n Ast_412.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_411.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_412.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_411.Parsetree.Ppat_type x0 ->\n Ast_412.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Ppat_lazy x0 ->\n Ast_412.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_411.Parsetree.Ppat_unpack x0 ->\n Ast_412.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_411.Parsetree.Ppat_exception x0 ->\n Ast_412.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_411.Parsetree.Ppat_extension x0 ->\n Ast_412.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_411.Parsetree.Ppat_open (x0, x1) ->\n Ast_412.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_411.Parsetree.core_type -> Ast_412.Parsetree.core_type\n =\n fun {\n Ast_411.Parsetree.ptyp_desc;\n Ast_411.Parsetree.ptyp_loc;\n Ast_411.Parsetree.ptyp_loc_stack;\n Ast_411.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_412.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_412.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_412.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack :\n Ast_411.Parsetree.location_stack -> Ast_412.Parsetree.location_stack =\n fun x -> x\n\nand copy_core_type_desc :\n Ast_411.Parsetree.core_type_desc -> Ast_412.Parsetree.core_type_desc =\n function\n | Ast_411.Parsetree.Ptyp_any -> Ast_412.Parsetree.Ptyp_any\n | Ast_411.Parsetree.Ptyp_var x0 -> Ast_412.Parsetree.Ptyp_var x0\n | Ast_411.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_412.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_411.Parsetree.Ptyp_tuple x0 ->\n Ast_412.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_411.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_412.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_object (x0, x1) ->\n Ast_412.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_411.Parsetree.Ptyp_class (x0, x1) ->\n Ast_412.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_412.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_411.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_412.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_411.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_412.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_package x0 ->\n Ast_412.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_411.Parsetree.Ptyp_extension x0 ->\n Ast_412.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_411.Parsetree.package_type -> Ast_412.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_411.Parsetree.row_field -> Ast_412.Parsetree.row_field\n =\n fun {\n Ast_411.Parsetree.prf_desc;\n Ast_411.Parsetree.prf_loc;\n Ast_411.Parsetree.prf_attributes;\n } ->\n {\n Ast_412.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_412.Parsetree.prf_loc = copy_location prf_loc;\n Ast_412.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_411.Parsetree.row_field_desc -> Ast_412.Parsetree.row_field_desc =\n function\n | Ast_411.Parsetree.Rtag (x0, x1, x2) ->\n Ast_412.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_411.Parsetree.Rinherit x0 ->\n Ast_412.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_411.Parsetree.object_field -> Ast_412.Parsetree.object_field =\n fun {\n Ast_411.Parsetree.pof_desc;\n Ast_411.Parsetree.pof_loc;\n Ast_411.Parsetree.pof_attributes;\n } ->\n {\n Ast_412.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_412.Parsetree.pof_loc = copy_location pof_loc;\n Ast_412.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_411.Parsetree.attributes -> Ast_412.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_411.Parsetree.attribute -> Ast_412.Parsetree.attribute\n =\n fun {\n Ast_411.Parsetree.attr_name;\n Ast_411.Parsetree.attr_payload;\n Ast_411.Parsetree.attr_loc;\n } ->\n {\n Ast_412.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_412.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_412.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_411.Parsetree.payload -> Ast_412.Parsetree.payload =\n function\n | Ast_411.Parsetree.PStr x0 -> Ast_412.Parsetree.PStr (copy_structure x0)\n | Ast_411.Parsetree.PSig x0 -> Ast_412.Parsetree.PSig (copy_signature x0)\n | Ast_411.Parsetree.PTyp x0 -> Ast_412.Parsetree.PTyp (copy_core_type x0)\n | Ast_411.Parsetree.PPat (x0, x1) ->\n Ast_412.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_411.Parsetree.structure -> Ast_412.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_411.Parsetree.structure_item -> Ast_412.Parsetree.structure_item =\n fun { Ast_411.Parsetree.pstr_desc; Ast_411.Parsetree.pstr_loc } ->\n {\n Ast_412.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_412.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_411.Parsetree.structure_item_desc ->\n Ast_412.Parsetree.structure_item_desc = function\n | Ast_411.Parsetree.Pstr_eval (x0, x1) ->\n Ast_412.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_411.Parsetree.Pstr_value (x0, x1) ->\n Ast_412.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_411.Parsetree.Pstr_primitive x0 ->\n Ast_412.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_411.Parsetree.Pstr_type (x0, x1) ->\n Ast_412.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_411.Parsetree.Pstr_typext x0 ->\n Ast_412.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_411.Parsetree.Pstr_exception x0 ->\n Ast_412.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_411.Parsetree.Pstr_module x0 ->\n Ast_412.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_411.Parsetree.Pstr_recmodule x0 ->\n Ast_412.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_411.Parsetree.Pstr_modtype x0 ->\n Ast_412.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_411.Parsetree.Pstr_open x0 ->\n Ast_412.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_411.Parsetree.Pstr_class x0 ->\n Ast_412.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_411.Parsetree.Pstr_class_type x0 ->\n Ast_412.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_411.Parsetree.Pstr_include x0 ->\n Ast_412.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_411.Parsetree.Pstr_attribute x0 ->\n Ast_412.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pstr_extension (x0, x1) ->\n Ast_412.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_411.Parsetree.include_declaration ->\n Ast_412.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_411.Parsetree.class_declaration -> Ast_412.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_411.Parsetree.class_expr -> Ast_412.Parsetree.class_expr =\n fun {\n Ast_411.Parsetree.pcl_desc;\n Ast_411.Parsetree.pcl_loc;\n Ast_411.Parsetree.pcl_attributes;\n } ->\n {\n Ast_412.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_412.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_412.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_411.Parsetree.class_expr_desc -> Ast_412.Parsetree.class_expr_desc =\n function\n | Ast_411.Parsetree.Pcl_constr (x0, x1) ->\n Ast_412.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Pcl_structure x0 ->\n Ast_412.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_411.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_412.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_411.Parsetree.Pcl_apply (x0, x1) ->\n Ast_412.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_411.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_412.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_411.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_412.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_411.Parsetree.Pcl_extension x0 ->\n Ast_412.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_411.Parsetree.Pcl_open (x0, x1) ->\n Ast_412.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_411.Parsetree.class_structure -> Ast_412.Parsetree.class_structure =\n fun { Ast_411.Parsetree.pcstr_self; Ast_411.Parsetree.pcstr_fields } ->\n {\n Ast_412.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_412.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_411.Parsetree.class_field -> Ast_412.Parsetree.class_field =\n fun {\n Ast_411.Parsetree.pcf_desc;\n Ast_411.Parsetree.pcf_loc;\n Ast_411.Parsetree.pcf_attributes;\n } ->\n {\n Ast_412.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_412.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_412.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_411.Parsetree.class_field_desc -> Ast_412.Parsetree.class_field_desc =\n function\n | Ast_411.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_412.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_411.Parsetree.Pcf_val x0 ->\n Ast_412.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_411.Parsetree.Pcf_method x0 ->\n Ast_412.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_411.Parsetree.Pcf_constraint x0 ->\n Ast_412.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_411.Parsetree.Pcf_initializer x0 ->\n Ast_412.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_411.Parsetree.Pcf_attribute x0 ->\n Ast_412.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pcf_extension x0 ->\n Ast_412.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_411.Parsetree.class_field_kind -> Ast_412.Parsetree.class_field_kind =\n function\n | Ast_411.Parsetree.Cfk_virtual x0 ->\n Ast_412.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_411.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_412.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_411.Parsetree.open_declaration -> Ast_412.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_411.Parsetree.module_binding -> Ast_412.Parsetree.module_binding =\n fun {\n Ast_411.Parsetree.pmb_name;\n Ast_411.Parsetree.pmb_expr;\n Ast_411.Parsetree.pmb_attributes;\n Ast_411.Parsetree.pmb_loc;\n } ->\n {\n Ast_412.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_412.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_412.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_412.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_411.Parsetree.module_expr -> Ast_412.Parsetree.module_expr =\n fun {\n Ast_411.Parsetree.pmod_desc;\n Ast_411.Parsetree.pmod_loc;\n Ast_411.Parsetree.pmod_attributes;\n } ->\n {\n Ast_412.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_412.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_412.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_411.Parsetree.module_expr_desc -> Ast_412.Parsetree.module_expr_desc =\n function\n | Ast_411.Parsetree.Pmod_ident x0 ->\n Ast_412.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pmod_structure x0 ->\n Ast_412.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_411.Parsetree.Pmod_functor (x0, x1) ->\n Ast_412.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_411.Parsetree.Pmod_apply (x0, x1) ->\n Ast_412.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_411.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_412.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_411.Parsetree.Pmod_unpack x0 ->\n Ast_412.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_411.Parsetree.Pmod_extension x0 ->\n Ast_412.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_411.Parsetree.functor_parameter -> Ast_412.Parsetree.functor_parameter =\n function\n | Ast_411.Parsetree.Unit -> Ast_412.Parsetree.Unit\n | Ast_411.Parsetree.Named (x0, x1) ->\n Ast_412.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_411.Parsetree.module_type -> Ast_412.Parsetree.module_type =\n fun {\n Ast_411.Parsetree.pmty_desc;\n Ast_411.Parsetree.pmty_loc;\n Ast_411.Parsetree.pmty_attributes;\n } ->\n {\n Ast_412.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_412.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_412.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_411.Parsetree.module_type_desc -> Ast_412.Parsetree.module_type_desc =\n function\n | Ast_411.Parsetree.Pmty_ident x0 ->\n Ast_412.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pmty_signature x0 ->\n Ast_412.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_411.Parsetree.Pmty_functor (x0, x1) ->\n Ast_412.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_411.Parsetree.Pmty_with (x0, x1) ->\n Ast_412.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_411.Parsetree.Pmty_typeof x0 ->\n Ast_412.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_411.Parsetree.Pmty_extension x0 ->\n Ast_412.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_411.Parsetree.Pmty_alias x0 ->\n Ast_412.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_411.Parsetree.with_constraint -> Ast_412.Parsetree.with_constraint =\n function\n | Ast_411.Parsetree.Pwith_type (x0, x1) ->\n Ast_412.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_411.Parsetree.Pwith_module (x0, x1) ->\n Ast_412.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_411.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_412.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_411.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_412.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_411.Parsetree.signature -> Ast_412.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_411.Parsetree.signature_item -> Ast_412.Parsetree.signature_item =\n fun { Ast_411.Parsetree.psig_desc; Ast_411.Parsetree.psig_loc } ->\n {\n Ast_412.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_412.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_411.Parsetree.signature_item_desc ->\n Ast_412.Parsetree.signature_item_desc = function\n | Ast_411.Parsetree.Psig_value x0 ->\n Ast_412.Parsetree.Psig_value (copy_value_description x0)\n | Ast_411.Parsetree.Psig_type (x0, x1) ->\n Ast_412.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_411.Parsetree.Psig_typesubst x0 ->\n Ast_412.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_411.Parsetree.Psig_typext x0 ->\n Ast_412.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_411.Parsetree.Psig_exception x0 ->\n Ast_412.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_411.Parsetree.Psig_module x0 ->\n Ast_412.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_411.Parsetree.Psig_modsubst x0 ->\n Ast_412.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_411.Parsetree.Psig_recmodule x0 ->\n Ast_412.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_411.Parsetree.Psig_modtype x0 ->\n Ast_412.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_411.Parsetree.Psig_open x0 ->\n Ast_412.Parsetree.Psig_open (copy_open_description x0)\n | Ast_411.Parsetree.Psig_include x0 ->\n Ast_412.Parsetree.Psig_include (copy_include_description x0)\n | Ast_411.Parsetree.Psig_class x0 ->\n Ast_412.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_411.Parsetree.Psig_class_type x0 ->\n Ast_412.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_411.Parsetree.Psig_attribute x0 ->\n Ast_412.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Psig_extension (x0, x1) ->\n Ast_412.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_411.Parsetree.class_type_declaration ->\n Ast_412.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_411.Parsetree.class_description -> Ast_412.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_411.Parsetree.class_type -> Ast_412.Parsetree.class_type =\n fun {\n Ast_411.Parsetree.pcty_desc;\n Ast_411.Parsetree.pcty_loc;\n Ast_411.Parsetree.pcty_attributes;\n } ->\n {\n Ast_412.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_412.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_412.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_411.Parsetree.class_type_desc -> Ast_412.Parsetree.class_type_desc =\n function\n | Ast_411.Parsetree.Pcty_constr (x0, x1) ->\n Ast_412.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Pcty_signature x0 ->\n Ast_412.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_411.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_412.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_411.Parsetree.Pcty_extension x0 ->\n Ast_412.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_411.Parsetree.Pcty_open (x0, x1) ->\n Ast_412.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_411.Parsetree.class_signature -> Ast_412.Parsetree.class_signature =\n fun { Ast_411.Parsetree.pcsig_self; Ast_411.Parsetree.pcsig_fields } ->\n {\n Ast_412.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_412.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_411.Parsetree.class_type_field -> Ast_412.Parsetree.class_type_field =\n fun {\n Ast_411.Parsetree.pctf_desc;\n Ast_411.Parsetree.pctf_loc;\n Ast_411.Parsetree.pctf_attributes;\n } ->\n {\n Ast_412.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_412.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_412.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_411.Parsetree.class_type_field_desc ->\n Ast_412.Parsetree.class_type_field_desc = function\n | Ast_411.Parsetree.Pctf_inherit x0 ->\n Ast_412.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_411.Parsetree.Pctf_val x0 ->\n Ast_412.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_411.Parsetree.Pctf_method x0 ->\n Ast_412.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_411.Parsetree.Pctf_constraint x0 ->\n Ast_412.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_411.Parsetree.Pctf_attribute x0 ->\n Ast_412.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pctf_extension x0 ->\n Ast_412.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_411.Parsetree.extension -> Ast_412.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.class_infos ->\n 'g0 Ast_412.Parsetree.class_infos =\n fun f0\n {\n Ast_411.Parsetree.pci_virt;\n Ast_411.Parsetree.pci_params;\n Ast_411.Parsetree.pci_name;\n Ast_411.Parsetree.pci_expr;\n Ast_411.Parsetree.pci_loc;\n Ast_411.Parsetree.pci_attributes;\n } ->\n {\n Ast_412.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_412.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, (copy_variance x1, Ast_412.Asttypes.NoInjectivity)))\n pci_params;\n Ast_412.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_412.Parsetree.pci_expr = f0 pci_expr;\n Ast_412.Parsetree.pci_loc = copy_location pci_loc;\n Ast_412.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_411.Asttypes.virtual_flag -> Ast_412.Asttypes.virtual_flag = function\n | Ast_411.Asttypes.Virtual -> Ast_412.Asttypes.Virtual\n | Ast_411.Asttypes.Concrete -> Ast_412.Asttypes.Concrete\n\nand copy_include_description :\n Ast_411.Parsetree.include_description ->\n Ast_412.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.include_infos ->\n 'g0 Ast_412.Parsetree.include_infos =\n fun f0\n {\n Ast_411.Parsetree.pincl_mod;\n Ast_411.Parsetree.pincl_loc;\n Ast_411.Parsetree.pincl_attributes;\n } ->\n {\n Ast_412.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_412.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_412.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_411.Parsetree.open_description -> Ast_412.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.open_infos ->\n 'g0 Ast_412.Parsetree.open_infos =\n fun f0\n {\n Ast_411.Parsetree.popen_expr;\n Ast_411.Parsetree.popen_override;\n Ast_411.Parsetree.popen_loc;\n Ast_411.Parsetree.popen_attributes;\n } ->\n {\n Ast_412.Parsetree.popen_expr = f0 popen_expr;\n Ast_412.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_412.Parsetree.popen_loc = copy_location popen_loc;\n Ast_412.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_411.Asttypes.override_flag -> Ast_412.Asttypes.override_flag = function\n | Ast_411.Asttypes.Override -> Ast_412.Asttypes.Override\n | Ast_411.Asttypes.Fresh -> Ast_412.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_411.Parsetree.module_type_declaration ->\n Ast_412.Parsetree.module_type_declaration =\n fun {\n Ast_411.Parsetree.pmtd_name;\n Ast_411.Parsetree.pmtd_type;\n Ast_411.Parsetree.pmtd_attributes;\n Ast_411.Parsetree.pmtd_loc;\n } ->\n {\n Ast_412.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_412.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_412.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_412.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_411.Parsetree.module_substitution ->\n Ast_412.Parsetree.module_substitution =\n fun {\n Ast_411.Parsetree.pms_name;\n Ast_411.Parsetree.pms_manifest;\n Ast_411.Parsetree.pms_attributes;\n Ast_411.Parsetree.pms_loc;\n } ->\n {\n Ast_412.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_412.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_412.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_412.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_411.Parsetree.module_declaration -> Ast_412.Parsetree.module_declaration\n =\n fun {\n Ast_411.Parsetree.pmd_name;\n Ast_411.Parsetree.pmd_type;\n Ast_411.Parsetree.pmd_attributes;\n Ast_411.Parsetree.pmd_loc;\n } ->\n {\n Ast_412.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_412.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_412.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_412.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_411.Parsetree.type_exception -> Ast_412.Parsetree.type_exception =\n fun {\n Ast_411.Parsetree.ptyexn_constructor;\n Ast_411.Parsetree.ptyexn_loc;\n Ast_411.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_412.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_412.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_411.Parsetree.type_extension -> Ast_412.Parsetree.type_extension =\n fun {\n Ast_411.Parsetree.ptyext_path;\n Ast_411.Parsetree.ptyext_params;\n Ast_411.Parsetree.ptyext_constructors;\n Ast_411.Parsetree.ptyext_private;\n Ast_411.Parsetree.ptyext_loc;\n Ast_411.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_412.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_412.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, (copy_variance x1, Ast_412.Asttypes.NoInjectivity)))\n ptyext_params;\n Ast_412.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_412.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_412.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_412.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_411.Parsetree.extension_constructor ->\n Ast_412.Parsetree.extension_constructor =\n fun {\n Ast_411.Parsetree.pext_name;\n Ast_411.Parsetree.pext_kind;\n Ast_411.Parsetree.pext_loc;\n Ast_411.Parsetree.pext_attributes;\n } ->\n {\n Ast_412.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_412.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_412.Parsetree.pext_loc = copy_location pext_loc;\n Ast_412.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_411.Parsetree.extension_constructor_kind ->\n Ast_412.Parsetree.extension_constructor_kind = function\n | Ast_411.Parsetree.Pext_decl (x0, x1) ->\n Ast_412.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_411.Parsetree.Pext_rebind x0 ->\n Ast_412.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_411.Parsetree.type_declaration -> Ast_412.Parsetree.type_declaration =\n fun {\n Ast_411.Parsetree.ptype_name;\n Ast_411.Parsetree.ptype_params;\n Ast_411.Parsetree.ptype_cstrs;\n Ast_411.Parsetree.ptype_kind;\n Ast_411.Parsetree.ptype_private;\n Ast_411.Parsetree.ptype_manifest;\n Ast_411.Parsetree.ptype_attributes;\n Ast_411.Parsetree.ptype_loc;\n } ->\n {\n Ast_412.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_412.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, (copy_variance x1, Ast_412.Asttypes.NoInjectivity)))\n ptype_params;\n Ast_412.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_412.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_412.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_412.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_412.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_412.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_411.Asttypes.private_flag -> Ast_412.Asttypes.private_flag = function\n | Ast_411.Asttypes.Private -> Ast_412.Asttypes.Private\n | Ast_411.Asttypes.Public -> Ast_412.Asttypes.Public\n\nand copy_type_kind : Ast_411.Parsetree.type_kind -> Ast_412.Parsetree.type_kind\n = function\n | Ast_411.Parsetree.Ptype_abstract -> Ast_412.Parsetree.Ptype_abstract\n | Ast_411.Parsetree.Ptype_variant x0 ->\n Ast_412.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_411.Parsetree.Ptype_record x0 ->\n Ast_412.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_411.Parsetree.Ptype_open -> Ast_412.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_411.Parsetree.constructor_declaration ->\n Ast_412.Parsetree.constructor_declaration =\n fun {\n Ast_411.Parsetree.pcd_name;\n Ast_411.Parsetree.pcd_args;\n Ast_411.Parsetree.pcd_res;\n Ast_411.Parsetree.pcd_loc;\n Ast_411.Parsetree.pcd_attributes;\n } ->\n {\n Ast_412.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_412.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_412.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_412.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_412.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_411.Parsetree.constructor_arguments ->\n Ast_412.Parsetree.constructor_arguments = function\n | Ast_411.Parsetree.Pcstr_tuple x0 ->\n Ast_412.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_411.Parsetree.Pcstr_record x0 ->\n Ast_412.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_411.Parsetree.label_declaration -> Ast_412.Parsetree.label_declaration =\n fun {\n Ast_411.Parsetree.pld_name;\n Ast_411.Parsetree.pld_mutable;\n Ast_411.Parsetree.pld_type;\n Ast_411.Parsetree.pld_loc;\n Ast_411.Parsetree.pld_attributes;\n } ->\n {\n Ast_412.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_412.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_412.Parsetree.pld_type = copy_core_type pld_type;\n Ast_412.Parsetree.pld_loc = copy_location pld_loc;\n Ast_412.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_411.Asttypes.mutable_flag -> Ast_412.Asttypes.mutable_flag = function\n | Ast_411.Asttypes.Immutable -> Ast_412.Asttypes.Immutable\n | Ast_411.Asttypes.Mutable -> Ast_412.Asttypes.Mutable\n\nand copy_variance : Ast_411.Asttypes.variance -> Ast_412.Asttypes.variance =\n function\n | Ast_411.Asttypes.Covariant -> Ast_412.Asttypes.Covariant\n | Ast_411.Asttypes.Contravariant -> Ast_412.Asttypes.Contravariant\n | Ast_411.Asttypes.Invariant -> Ast_412.Asttypes.NoVariance\n\nand copy_value_description :\n Ast_411.Parsetree.value_description -> Ast_412.Parsetree.value_description =\n fun {\n Ast_411.Parsetree.pval_name;\n Ast_411.Parsetree.pval_type;\n Ast_411.Parsetree.pval_prim;\n Ast_411.Parsetree.pval_attributes;\n Ast_411.Parsetree.pval_loc;\n } ->\n {\n Ast_412.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_412.Parsetree.pval_type = copy_core_type pval_type;\n Ast_412.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_412.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_412.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_411.Parsetree.object_field_desc -> Ast_412.Parsetree.object_field_desc =\n function\n | Ast_411.Parsetree.Otag (x0, x1) ->\n Ast_412.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_411.Parsetree.Oinherit x0 ->\n Ast_412.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_411.Asttypes.arg_label -> Ast_412.Asttypes.arg_label =\n function\n | Ast_411.Asttypes.Nolabel -> Ast_412.Asttypes.Nolabel\n | Ast_411.Asttypes.Labelled x0 -> Ast_412.Asttypes.Labelled x0\n | Ast_411.Asttypes.Optional x0 -> Ast_412.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_411.Asttypes.closed_flag -> Ast_412.Asttypes.closed_flag = function\n | Ast_411.Asttypes.Closed -> Ast_412.Asttypes.Closed\n | Ast_411.Asttypes.Open -> Ast_412.Asttypes.Open\n\nand copy_label : Ast_411.Asttypes.label -> Ast_412.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_411.Asttypes.rec_flag -> Ast_412.Asttypes.rec_flag =\n function\n | Ast_411.Asttypes.Nonrecursive -> Ast_412.Asttypes.Nonrecursive\n | Ast_411.Asttypes.Recursive -> Ast_412.Asttypes.Recursive\n\nand copy_constant : Ast_411.Parsetree.constant -> Ast_412.Parsetree.constant =\n function\n | Ast_411.Parsetree.Pconst_integer (x0, x1) ->\n Ast_412.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_411.Parsetree.Pconst_char x0 -> Ast_412.Parsetree.Pconst_char x0\n | Ast_411.Parsetree.Pconst_string (x0, x1, x2) ->\n Ast_412.Parsetree.Pconst_string\n (x0, copy_location x1, Option.map (fun x -> x) x2)\n | Ast_411.Parsetree.Pconst_float (x0, x1) ->\n Ast_412.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_411.Asttypes.loc -> 'g0 Ast_412.Asttypes.loc =\n fun f0 { Ast_411.Asttypes.txt; Ast_411.Asttypes.loc } ->\n { Ast_412.Asttypes.txt = f0 txt; Ast_412.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_411\nmodule To = Ast_410\n\nlet rec copy_toplevel_phrase :\n Ast_411.Parsetree.toplevel_phrase -> Ast_410.Parsetree.toplevel_phrase =\n function\n | Ast_411.Parsetree.Ptop_def x0 ->\n Ast_410.Parsetree.Ptop_def (copy_structure x0)\n | Ast_411.Parsetree.Ptop_dir x0 ->\n Ast_410.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_411.Parsetree.toplevel_directive -> Ast_410.Parsetree.toplevel_directive\n =\n fun {\n Ast_411.Parsetree.pdir_name;\n Ast_411.Parsetree.pdir_arg;\n Ast_411.Parsetree.pdir_loc;\n } ->\n {\n Ast_410.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_410.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_410.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_411.Parsetree.directive_argument -> Ast_410.Parsetree.directive_argument\n =\n fun { Ast_411.Parsetree.pdira_desc; Ast_411.Parsetree.pdira_loc } ->\n {\n Ast_410.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_410.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_411.Parsetree.directive_argument_desc ->\n Ast_410.Parsetree.directive_argument_desc = function\n | Ast_411.Parsetree.Pdir_string x0 -> Ast_410.Parsetree.Pdir_string x0\n | Ast_411.Parsetree.Pdir_int (x0, x1) ->\n Ast_410.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_411.Parsetree.Pdir_ident x0 ->\n Ast_410.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_411.Parsetree.Pdir_bool x0 -> Ast_410.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_411.Parsetree.expression -> Ast_410.Parsetree.expression =\n fun {\n Ast_411.Parsetree.pexp_desc;\n Ast_411.Parsetree.pexp_loc;\n Ast_411.Parsetree.pexp_loc_stack;\n Ast_411.Parsetree.pexp_attributes;\n } ->\n {\n Ast_410.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_410.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_410.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_410.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expr x = copy_expression x\n\nand copy_expression_desc :\n Ast_411.Parsetree.expression_desc -> Ast_410.Parsetree.expression_desc =\n function\n | Ast_411.Parsetree.Pexp_ident x0 ->\n Ast_410.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pexp_constant x0 ->\n Ast_410.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_411.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_411.Parsetree.Pexp_function x0 ->\n Ast_410.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_411.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_410.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_411.Parsetree.Pexp_apply (x0, x1) ->\n Ast_410.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_411.Parsetree.Pexp_match (x0, x1) ->\n Ast_410.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_411.Parsetree.Pexp_try (x0, x1) ->\n Ast_410.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_411.Parsetree.Pexp_tuple x0 ->\n Ast_410.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_411.Parsetree.Pexp_construct (x0, x1) ->\n Ast_410.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_411.Parsetree.Pexp_variant (x0, x1) ->\n Ast_410.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_411.Parsetree.Pexp_record (x0, x1) ->\n Ast_410.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_411.Parsetree.Pexp_field (x0, x1) ->\n Ast_410.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_411.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_411.Parsetree.Pexp_array x0 ->\n Ast_410.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_411.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_411.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_410.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_while (x0, x1) ->\n Ast_410.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_410.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_411.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_410.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_411.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_411.Parsetree.Pexp_send (x0, x1) ->\n Ast_410.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_411.Parsetree.Pexp_new x0 ->\n Ast_410.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_410.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_override x0 ->\n Ast_410.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_411.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_411.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_410.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_assert x0 ->\n Ast_410.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_411.Parsetree.Pexp_lazy x0 ->\n Ast_410.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_411.Parsetree.Pexp_poly (x0, x1) ->\n Ast_410.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_411.Parsetree.Pexp_object x0 ->\n Ast_410.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_411.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_410.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_pack x0 ->\n Ast_410.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_411.Parsetree.Pexp_open (x0, x1) ->\n Ast_410.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_411.Parsetree.Pexp_letop x0 ->\n Ast_410.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_411.Parsetree.Pexp_extension x0 ->\n Ast_410.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_411.Parsetree.Pexp_unreachable -> Ast_410.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_411.Parsetree.letop -> Ast_410.Parsetree.letop =\n fun { Ast_411.Parsetree.let_; Ast_411.Parsetree.ands; Ast_411.Parsetree.body } ->\n {\n Ast_410.Parsetree.let_ = copy_binding_op let_;\n Ast_410.Parsetree.ands = List.map copy_binding_op ands;\n Ast_410.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_411.Parsetree.binding_op -> Ast_410.Parsetree.binding_op =\n fun {\n Ast_411.Parsetree.pbop_op;\n Ast_411.Parsetree.pbop_pat;\n Ast_411.Parsetree.pbop_exp;\n Ast_411.Parsetree.pbop_loc;\n } ->\n {\n Ast_410.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_410.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_410.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_410.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_411.Asttypes.direction_flag -> Ast_410.Asttypes.direction_flag =\n function\n | Ast_411.Asttypes.Upto -> Ast_410.Asttypes.Upto\n | Ast_411.Asttypes.Downto -> Ast_410.Asttypes.Downto\n\nand copy_case : Ast_411.Parsetree.case -> Ast_410.Parsetree.case =\n fun {\n Ast_411.Parsetree.pc_lhs;\n Ast_411.Parsetree.pc_guard;\n Ast_411.Parsetree.pc_rhs;\n } ->\n {\n Ast_410.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_410.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_410.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_cases : Ast_411.Parsetree.case list -> Ast_410.Parsetree.case list =\n fun x -> List.map copy_case x\n\nand copy_value_binding :\n Ast_411.Parsetree.value_binding -> Ast_410.Parsetree.value_binding =\n fun {\n Ast_411.Parsetree.pvb_pat;\n Ast_411.Parsetree.pvb_expr;\n Ast_411.Parsetree.pvb_attributes;\n Ast_411.Parsetree.pvb_loc;\n } ->\n {\n Ast_410.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_410.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_410.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_410.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_411.Parsetree.pattern -> Ast_410.Parsetree.pattern =\n fun {\n Ast_411.Parsetree.ppat_desc;\n Ast_411.Parsetree.ppat_loc;\n Ast_411.Parsetree.ppat_loc_stack;\n Ast_411.Parsetree.ppat_attributes;\n } ->\n {\n Ast_410.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_410.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_410.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_410.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pat x = copy_pattern x\n\nand copy_pattern_desc :\n Ast_411.Parsetree.pattern_desc -> Ast_410.Parsetree.pattern_desc = function\n | Ast_411.Parsetree.Ppat_any -> Ast_410.Parsetree.Ppat_any\n | Ast_411.Parsetree.Ppat_var x0 ->\n Ast_410.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_411.Parsetree.Ppat_alias (x0, x1) ->\n Ast_410.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_411.Parsetree.Ppat_constant x0 ->\n Ast_410.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_411.Parsetree.Ppat_interval (x0, x1) ->\n Ast_410.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_411.Parsetree.Ppat_tuple x0 ->\n Ast_410.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_411.Parsetree.Ppat_construct (x0, x1) ->\n Ast_410.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_411.Parsetree.Ppat_variant (x0, x1) ->\n Ast_410.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_411.Parsetree.Ppat_record (x0, x1) ->\n Ast_410.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_411.Parsetree.Ppat_array x0 ->\n Ast_410.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_411.Parsetree.Ppat_or (x0, x1) ->\n Ast_410.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_411.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_410.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_411.Parsetree.Ppat_type x0 ->\n Ast_410.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Ppat_lazy x0 ->\n Ast_410.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_411.Parsetree.Ppat_unpack x0 ->\n Ast_410.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_411.Parsetree.Ppat_exception x0 ->\n Ast_410.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_411.Parsetree.Ppat_extension x0 ->\n Ast_410.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_411.Parsetree.Ppat_open (x0, x1) ->\n Ast_410.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_411.Parsetree.core_type -> Ast_410.Parsetree.core_type\n =\n fun {\n Ast_411.Parsetree.ptyp_desc;\n Ast_411.Parsetree.ptyp_loc;\n Ast_411.Parsetree.ptyp_loc_stack;\n Ast_411.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_410.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_410.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_410.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_typ x = copy_core_type x\n\nand copy_location_stack :\n Ast_411.Parsetree.location_stack -> Ast_410.Parsetree.location_stack =\n fun x -> List.map copy_location x\n\nand copy_core_type_desc :\n Ast_411.Parsetree.core_type_desc -> Ast_410.Parsetree.core_type_desc =\n function\n | Ast_411.Parsetree.Ptyp_any -> Ast_410.Parsetree.Ptyp_any\n | Ast_411.Parsetree.Ptyp_var x0 -> Ast_410.Parsetree.Ptyp_var x0\n | Ast_411.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_410.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_411.Parsetree.Ptyp_tuple x0 ->\n Ast_410.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_411.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_410.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_object (x0, x1) ->\n Ast_410.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_411.Parsetree.Ptyp_class (x0, x1) ->\n Ast_410.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_410.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_411.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_410.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_411.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_410.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_411.Parsetree.Ptyp_package x0 ->\n Ast_410.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_411.Parsetree.Ptyp_extension x0 ->\n Ast_410.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_411.Parsetree.package_type -> Ast_410.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_411.Parsetree.row_field -> Ast_410.Parsetree.row_field\n =\n fun {\n Ast_411.Parsetree.prf_desc;\n Ast_411.Parsetree.prf_loc;\n Ast_411.Parsetree.prf_attributes;\n } ->\n {\n Ast_410.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_410.Parsetree.prf_loc = copy_location prf_loc;\n Ast_410.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_411.Parsetree.row_field_desc -> Ast_410.Parsetree.row_field_desc =\n function\n | Ast_411.Parsetree.Rtag (x0, x1, x2) ->\n Ast_410.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_411.Parsetree.Rinherit x0 ->\n Ast_410.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_411.Parsetree.object_field -> Ast_410.Parsetree.object_field =\n fun {\n Ast_411.Parsetree.pof_desc;\n Ast_411.Parsetree.pof_loc;\n Ast_411.Parsetree.pof_attributes;\n } ->\n {\n Ast_410.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_410.Parsetree.pof_loc = copy_location pof_loc;\n Ast_410.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_411.Parsetree.attributes -> Ast_410.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_411.Parsetree.attribute -> Ast_410.Parsetree.attribute\n =\n fun {\n Ast_411.Parsetree.attr_name;\n Ast_411.Parsetree.attr_payload;\n Ast_411.Parsetree.attr_loc;\n } ->\n {\n Ast_410.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_410.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_410.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_411.Parsetree.payload -> Ast_410.Parsetree.payload =\n function\n | Ast_411.Parsetree.PStr x0 -> Ast_410.Parsetree.PStr (copy_structure x0)\n | Ast_411.Parsetree.PSig x0 -> Ast_410.Parsetree.PSig (copy_signature x0)\n | Ast_411.Parsetree.PTyp x0 -> Ast_410.Parsetree.PTyp (copy_core_type x0)\n | Ast_411.Parsetree.PPat (x0, x1) ->\n Ast_410.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_411.Parsetree.structure -> Ast_410.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_411.Parsetree.structure_item -> Ast_410.Parsetree.structure_item =\n fun { Ast_411.Parsetree.pstr_desc; Ast_411.Parsetree.pstr_loc } ->\n {\n Ast_410.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_410.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_411.Parsetree.structure_item_desc ->\n Ast_410.Parsetree.structure_item_desc = function\n | Ast_411.Parsetree.Pstr_eval (x0, x1) ->\n Ast_410.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_411.Parsetree.Pstr_value (x0, x1) ->\n Ast_410.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_411.Parsetree.Pstr_primitive x0 ->\n Ast_410.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_411.Parsetree.Pstr_type (x0, x1) ->\n Ast_410.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_411.Parsetree.Pstr_typext x0 ->\n Ast_410.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_411.Parsetree.Pstr_exception x0 ->\n Ast_410.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_411.Parsetree.Pstr_module x0 ->\n Ast_410.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_411.Parsetree.Pstr_recmodule x0 ->\n Ast_410.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_411.Parsetree.Pstr_modtype x0 ->\n Ast_410.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_411.Parsetree.Pstr_open x0 ->\n Ast_410.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_411.Parsetree.Pstr_class x0 ->\n Ast_410.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_411.Parsetree.Pstr_class_type x0 ->\n Ast_410.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_411.Parsetree.Pstr_include x0 ->\n Ast_410.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_411.Parsetree.Pstr_attribute x0 ->\n Ast_410.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pstr_extension (x0, x1) ->\n Ast_410.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_411.Parsetree.include_declaration ->\n Ast_410.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_411.Parsetree.class_declaration -> Ast_410.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_411.Parsetree.class_expr -> Ast_410.Parsetree.class_expr =\n fun {\n Ast_411.Parsetree.pcl_desc;\n Ast_411.Parsetree.pcl_loc;\n Ast_411.Parsetree.pcl_attributes;\n } ->\n {\n Ast_410.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_410.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_410.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_411.Parsetree.class_expr_desc -> Ast_410.Parsetree.class_expr_desc =\n function\n | Ast_411.Parsetree.Pcl_constr (x0, x1) ->\n Ast_410.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Pcl_structure x0 ->\n Ast_410.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_411.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_410.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_411.Parsetree.Pcl_apply (x0, x1) ->\n Ast_410.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_411.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_410.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_411.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_410.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_411.Parsetree.Pcl_extension x0 ->\n Ast_410.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_411.Parsetree.Pcl_open (x0, x1) ->\n Ast_410.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_411.Parsetree.class_structure -> Ast_410.Parsetree.class_structure =\n fun { Ast_411.Parsetree.pcstr_self; Ast_411.Parsetree.pcstr_fields } ->\n {\n Ast_410.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_410.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_411.Parsetree.class_field -> Ast_410.Parsetree.class_field =\n fun {\n Ast_411.Parsetree.pcf_desc;\n Ast_411.Parsetree.pcf_loc;\n Ast_411.Parsetree.pcf_attributes;\n } ->\n {\n Ast_410.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_410.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_410.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_411.Parsetree.class_field_desc -> Ast_410.Parsetree.class_field_desc =\n function\n | Ast_411.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_410.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_411.Parsetree.Pcf_val x0 ->\n Ast_410.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_411.Parsetree.Pcf_method x0 ->\n Ast_410.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_411.Parsetree.Pcf_constraint x0 ->\n Ast_410.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_411.Parsetree.Pcf_initializer x0 ->\n Ast_410.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_411.Parsetree.Pcf_attribute x0 ->\n Ast_410.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pcf_extension x0 ->\n Ast_410.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_411.Parsetree.class_field_kind -> Ast_410.Parsetree.class_field_kind =\n function\n | Ast_411.Parsetree.Cfk_virtual x0 ->\n Ast_410.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_411.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_410.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_411.Parsetree.open_declaration -> Ast_410.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_411.Parsetree.module_binding -> Ast_410.Parsetree.module_binding =\n fun {\n Ast_411.Parsetree.pmb_name;\n Ast_411.Parsetree.pmb_expr;\n Ast_411.Parsetree.pmb_attributes;\n Ast_411.Parsetree.pmb_loc;\n } ->\n {\n Ast_410.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_410.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_410.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_410.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_411.Parsetree.module_expr -> Ast_410.Parsetree.module_expr =\n fun {\n Ast_411.Parsetree.pmod_desc;\n Ast_411.Parsetree.pmod_loc;\n Ast_411.Parsetree.pmod_attributes;\n } ->\n {\n Ast_410.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_410.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_410.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_411.Parsetree.module_expr_desc -> Ast_410.Parsetree.module_expr_desc =\n function\n | Ast_411.Parsetree.Pmod_ident x0 ->\n Ast_410.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pmod_structure x0 ->\n Ast_410.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_411.Parsetree.Pmod_functor (x0, x1) ->\n Ast_410.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_411.Parsetree.Pmod_apply (x0, x1) ->\n Ast_410.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_411.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_410.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_411.Parsetree.Pmod_unpack x0 ->\n Ast_410.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_411.Parsetree.Pmod_extension x0 ->\n Ast_410.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_411.Parsetree.functor_parameter -> Ast_410.Parsetree.functor_parameter =\n function\n | Ast_411.Parsetree.Unit -> Ast_410.Parsetree.Unit\n | Ast_411.Parsetree.Named (x0, x1) ->\n Ast_410.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_411.Parsetree.module_type -> Ast_410.Parsetree.module_type =\n fun {\n Ast_411.Parsetree.pmty_desc;\n Ast_411.Parsetree.pmty_loc;\n Ast_411.Parsetree.pmty_attributes;\n } ->\n {\n Ast_410.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_410.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_410.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_411.Parsetree.module_type_desc -> Ast_410.Parsetree.module_type_desc =\n function\n | Ast_411.Parsetree.Pmty_ident x0 ->\n Ast_410.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_411.Parsetree.Pmty_signature x0 ->\n Ast_410.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_411.Parsetree.Pmty_functor (x0, x1) ->\n Ast_410.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_411.Parsetree.Pmty_with (x0, x1) ->\n Ast_410.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_411.Parsetree.Pmty_typeof x0 ->\n Ast_410.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_411.Parsetree.Pmty_extension x0 ->\n Ast_410.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_411.Parsetree.Pmty_alias x0 ->\n Ast_410.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_411.Parsetree.with_constraint -> Ast_410.Parsetree.with_constraint =\n function\n | Ast_411.Parsetree.Pwith_type (x0, x1) ->\n Ast_410.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_411.Parsetree.Pwith_module (x0, x1) ->\n Ast_410.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_411.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_410.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_411.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_410.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_411.Parsetree.signature -> Ast_410.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_411.Parsetree.signature_item -> Ast_410.Parsetree.signature_item =\n fun { Ast_411.Parsetree.psig_desc; Ast_411.Parsetree.psig_loc } ->\n {\n Ast_410.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_410.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_411.Parsetree.signature_item_desc ->\n Ast_410.Parsetree.signature_item_desc = function\n | Ast_411.Parsetree.Psig_value x0 ->\n Ast_410.Parsetree.Psig_value (copy_value_description x0)\n | Ast_411.Parsetree.Psig_type (x0, x1) ->\n Ast_410.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_411.Parsetree.Psig_typesubst x0 ->\n Ast_410.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_411.Parsetree.Psig_typext x0 ->\n Ast_410.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_411.Parsetree.Psig_exception x0 ->\n Ast_410.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_411.Parsetree.Psig_module x0 ->\n Ast_410.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_411.Parsetree.Psig_modsubst x0 ->\n Ast_410.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_411.Parsetree.Psig_recmodule x0 ->\n Ast_410.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_411.Parsetree.Psig_modtype x0 ->\n Ast_410.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_411.Parsetree.Psig_open x0 ->\n Ast_410.Parsetree.Psig_open (copy_open_description x0)\n | Ast_411.Parsetree.Psig_include x0 ->\n Ast_410.Parsetree.Psig_include (copy_include_description x0)\n | Ast_411.Parsetree.Psig_class x0 ->\n Ast_410.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_411.Parsetree.Psig_class_type x0 ->\n Ast_410.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_411.Parsetree.Psig_attribute x0 ->\n Ast_410.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Psig_extension (x0, x1) ->\n Ast_410.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_411.Parsetree.class_type_declaration ->\n Ast_410.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_411.Parsetree.class_description -> Ast_410.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_411.Parsetree.class_type -> Ast_410.Parsetree.class_type =\n fun {\n Ast_411.Parsetree.pcty_desc;\n Ast_411.Parsetree.pcty_loc;\n Ast_411.Parsetree.pcty_attributes;\n } ->\n {\n Ast_410.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_410.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_410.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_411.Parsetree.class_type_desc -> Ast_410.Parsetree.class_type_desc =\n function\n | Ast_411.Parsetree.Pcty_constr (x0, x1) ->\n Ast_410.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_411.Parsetree.Pcty_signature x0 ->\n Ast_410.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_411.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_410.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_411.Parsetree.Pcty_extension x0 ->\n Ast_410.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_411.Parsetree.Pcty_open (x0, x1) ->\n Ast_410.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_411.Parsetree.class_signature -> Ast_410.Parsetree.class_signature =\n fun { Ast_411.Parsetree.pcsig_self; Ast_411.Parsetree.pcsig_fields } ->\n {\n Ast_410.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_410.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_411.Parsetree.class_type_field -> Ast_410.Parsetree.class_type_field =\n fun {\n Ast_411.Parsetree.pctf_desc;\n Ast_411.Parsetree.pctf_loc;\n Ast_411.Parsetree.pctf_attributes;\n } ->\n {\n Ast_410.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_410.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_410.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_411.Parsetree.class_type_field_desc ->\n Ast_410.Parsetree.class_type_field_desc = function\n | Ast_411.Parsetree.Pctf_inherit x0 ->\n Ast_410.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_411.Parsetree.Pctf_val x0 ->\n Ast_410.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_411.Parsetree.Pctf_method x0 ->\n Ast_410.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_411.Parsetree.Pctf_constraint x0 ->\n Ast_410.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_411.Parsetree.Pctf_attribute x0 ->\n Ast_410.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_411.Parsetree.Pctf_extension x0 ->\n Ast_410.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_411.Parsetree.extension -> Ast_410.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.class_infos ->\n 'g0 Ast_410.Parsetree.class_infos =\n fun f0\n {\n Ast_411.Parsetree.pci_virt;\n Ast_411.Parsetree.pci_params;\n Ast_411.Parsetree.pci_name;\n Ast_411.Parsetree.pci_expr;\n Ast_411.Parsetree.pci_loc;\n Ast_411.Parsetree.pci_attributes;\n } ->\n {\n Ast_410.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_410.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_410.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_410.Parsetree.pci_expr = f0 pci_expr;\n Ast_410.Parsetree.pci_loc = copy_location pci_loc;\n Ast_410.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_411.Asttypes.virtual_flag -> Ast_410.Asttypes.virtual_flag = function\n | Ast_411.Asttypes.Virtual -> Ast_410.Asttypes.Virtual\n | Ast_411.Asttypes.Concrete -> Ast_410.Asttypes.Concrete\n\nand copy_include_description :\n Ast_411.Parsetree.include_description ->\n Ast_410.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.include_infos ->\n 'g0 Ast_410.Parsetree.include_infos =\n fun f0\n {\n Ast_411.Parsetree.pincl_mod;\n Ast_411.Parsetree.pincl_loc;\n Ast_411.Parsetree.pincl_attributes;\n } ->\n {\n Ast_410.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_410.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_410.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_411.Parsetree.open_description -> Ast_410.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_411.Parsetree.open_infos ->\n 'g0 Ast_410.Parsetree.open_infos =\n fun f0\n {\n Ast_411.Parsetree.popen_expr;\n Ast_411.Parsetree.popen_override;\n Ast_411.Parsetree.popen_loc;\n Ast_411.Parsetree.popen_attributes;\n } ->\n {\n Ast_410.Parsetree.popen_expr = f0 popen_expr;\n Ast_410.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_410.Parsetree.popen_loc = copy_location popen_loc;\n Ast_410.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_411.Asttypes.override_flag -> Ast_410.Asttypes.override_flag = function\n | Ast_411.Asttypes.Override -> Ast_410.Asttypes.Override\n | Ast_411.Asttypes.Fresh -> Ast_410.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_411.Parsetree.module_type_declaration ->\n Ast_410.Parsetree.module_type_declaration =\n fun {\n Ast_411.Parsetree.pmtd_name;\n Ast_411.Parsetree.pmtd_type;\n Ast_411.Parsetree.pmtd_attributes;\n Ast_411.Parsetree.pmtd_loc;\n } ->\n {\n Ast_410.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_410.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_410.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_410.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_411.Parsetree.module_substitution ->\n Ast_410.Parsetree.module_substitution =\n fun {\n Ast_411.Parsetree.pms_name;\n Ast_411.Parsetree.pms_manifest;\n Ast_411.Parsetree.pms_attributes;\n Ast_411.Parsetree.pms_loc;\n } ->\n {\n Ast_410.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_410.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_410.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_410.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_411.Parsetree.module_declaration -> Ast_410.Parsetree.module_declaration\n =\n fun {\n Ast_411.Parsetree.pmd_name;\n Ast_411.Parsetree.pmd_type;\n Ast_411.Parsetree.pmd_attributes;\n Ast_411.Parsetree.pmd_loc;\n } ->\n {\n Ast_410.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_410.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_410.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_410.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_411.Parsetree.type_exception -> Ast_410.Parsetree.type_exception =\n fun {\n Ast_411.Parsetree.ptyexn_constructor;\n Ast_411.Parsetree.ptyexn_loc;\n Ast_411.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_410.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_410.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_411.Parsetree.type_extension -> Ast_410.Parsetree.type_extension =\n fun {\n Ast_411.Parsetree.ptyext_path;\n Ast_411.Parsetree.ptyext_params;\n Ast_411.Parsetree.ptyext_constructors;\n Ast_411.Parsetree.ptyext_private;\n Ast_411.Parsetree.ptyext_loc;\n Ast_411.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_410.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_410.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_410.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_410.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_410.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_411.Parsetree.extension_constructor ->\n Ast_410.Parsetree.extension_constructor =\n fun {\n Ast_411.Parsetree.pext_name;\n Ast_411.Parsetree.pext_kind;\n Ast_411.Parsetree.pext_loc;\n Ast_411.Parsetree.pext_attributes;\n } ->\n {\n Ast_410.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_410.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_410.Parsetree.pext_loc = copy_location pext_loc;\n Ast_410.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_411.Parsetree.extension_constructor_kind ->\n Ast_410.Parsetree.extension_constructor_kind = function\n | Ast_411.Parsetree.Pext_decl (x0, x1) ->\n Ast_410.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_411.Parsetree.Pext_rebind x0 ->\n Ast_410.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_411.Parsetree.type_declaration -> Ast_410.Parsetree.type_declaration =\n fun {\n Ast_411.Parsetree.ptype_name;\n Ast_411.Parsetree.ptype_params;\n Ast_411.Parsetree.ptype_cstrs;\n Ast_411.Parsetree.ptype_kind;\n Ast_411.Parsetree.ptype_private;\n Ast_411.Parsetree.ptype_manifest;\n Ast_411.Parsetree.ptype_attributes;\n Ast_411.Parsetree.ptype_loc;\n } ->\n {\n Ast_410.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_410.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_410.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_410.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_410.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_410.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_410.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_410.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_411.Asttypes.private_flag -> Ast_410.Asttypes.private_flag = function\n | Ast_411.Asttypes.Private -> Ast_410.Asttypes.Private\n | Ast_411.Asttypes.Public -> Ast_410.Asttypes.Public\n\nand copy_type_kind : Ast_411.Parsetree.type_kind -> Ast_410.Parsetree.type_kind\n = function\n | Ast_411.Parsetree.Ptype_abstract -> Ast_410.Parsetree.Ptype_abstract\n | Ast_411.Parsetree.Ptype_variant x0 ->\n Ast_410.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_411.Parsetree.Ptype_record x0 ->\n Ast_410.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_411.Parsetree.Ptype_open -> Ast_410.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_411.Parsetree.constructor_declaration ->\n Ast_410.Parsetree.constructor_declaration =\n fun {\n Ast_411.Parsetree.pcd_name;\n Ast_411.Parsetree.pcd_args;\n Ast_411.Parsetree.pcd_res;\n Ast_411.Parsetree.pcd_loc;\n Ast_411.Parsetree.pcd_attributes;\n } ->\n {\n Ast_410.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_410.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_410.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_410.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_410.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_411.Parsetree.constructor_arguments ->\n Ast_410.Parsetree.constructor_arguments = function\n | Ast_411.Parsetree.Pcstr_tuple x0 ->\n Ast_410.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_411.Parsetree.Pcstr_record x0 ->\n Ast_410.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_411.Parsetree.label_declaration -> Ast_410.Parsetree.label_declaration =\n fun {\n Ast_411.Parsetree.pld_name;\n Ast_411.Parsetree.pld_mutable;\n Ast_411.Parsetree.pld_type;\n Ast_411.Parsetree.pld_loc;\n Ast_411.Parsetree.pld_attributes;\n } ->\n {\n Ast_410.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_410.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_410.Parsetree.pld_type = copy_core_type pld_type;\n Ast_410.Parsetree.pld_loc = copy_location pld_loc;\n Ast_410.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_411.Asttypes.mutable_flag -> Ast_410.Asttypes.mutable_flag = function\n | Ast_411.Asttypes.Immutable -> Ast_410.Asttypes.Immutable\n | Ast_411.Asttypes.Mutable -> Ast_410.Asttypes.Mutable\n\nand copy_variance : Ast_411.Asttypes.variance -> Ast_410.Asttypes.variance =\n function\n | Ast_411.Asttypes.Covariant -> Ast_410.Asttypes.Covariant\n | Ast_411.Asttypes.Contravariant -> Ast_410.Asttypes.Contravariant\n | Ast_411.Asttypes.Invariant -> Ast_410.Asttypes.Invariant\n\nand copy_value_description :\n Ast_411.Parsetree.value_description -> Ast_410.Parsetree.value_description =\n fun {\n Ast_411.Parsetree.pval_name;\n Ast_411.Parsetree.pval_type;\n Ast_411.Parsetree.pval_prim;\n Ast_411.Parsetree.pval_attributes;\n Ast_411.Parsetree.pval_loc;\n } ->\n {\n Ast_410.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_410.Parsetree.pval_type = copy_core_type pval_type;\n Ast_410.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_410.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_410.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_411.Parsetree.object_field_desc -> Ast_410.Parsetree.object_field_desc =\n function\n | Ast_411.Parsetree.Otag (x0, x1) ->\n Ast_410.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_411.Parsetree.Oinherit x0 ->\n Ast_410.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_411.Asttypes.arg_label -> Ast_410.Asttypes.arg_label =\n function\n | Ast_411.Asttypes.Nolabel -> Ast_410.Asttypes.Nolabel\n | Ast_411.Asttypes.Labelled x0 -> Ast_410.Asttypes.Labelled x0\n | Ast_411.Asttypes.Optional x0 -> Ast_410.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_411.Asttypes.closed_flag -> Ast_410.Asttypes.closed_flag = function\n | Ast_411.Asttypes.Closed -> Ast_410.Asttypes.Closed\n | Ast_411.Asttypes.Open -> Ast_410.Asttypes.Open\n\nand copy_label : Ast_411.Asttypes.label -> Ast_410.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_411.Asttypes.rec_flag -> Ast_410.Asttypes.rec_flag =\n function\n | Ast_411.Asttypes.Nonrecursive -> Ast_410.Asttypes.Nonrecursive\n | Ast_411.Asttypes.Recursive -> Ast_410.Asttypes.Recursive\n\nand copy_constant : Ast_411.Parsetree.constant -> Ast_410.Parsetree.constant =\n function\n | Ast_411.Parsetree.Pconst_integer (x0, x1) ->\n Ast_410.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_411.Parsetree.Pconst_char x0 -> Ast_410.Parsetree.Pconst_char x0\n | Ast_411.Parsetree.Pconst_string (x0, _, x2) ->\n Ast_410.Parsetree.Pconst_string (x0, Option.map (fun x -> x) x2)\n | Ast_411.Parsetree.Pconst_float (x0, x1) ->\n Ast_410.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_411.Asttypes.loc -> 'g0 Ast_410.Asttypes.loc =\n fun f0 { Ast_411.Asttypes.txt; Ast_411.Asttypes.loc } ->\n { Ast_410.Asttypes.txt = f0 txt; Ast_410.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_410\nmodule To = Ast_411\n\nlet rec copy_toplevel_phrase :\n Ast_410.Parsetree.toplevel_phrase -> Ast_411.Parsetree.toplevel_phrase =\n function\n | Ast_410.Parsetree.Ptop_def x0 ->\n Ast_411.Parsetree.Ptop_def (copy_structure x0)\n | Ast_410.Parsetree.Ptop_dir x0 ->\n Ast_411.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_410.Parsetree.toplevel_directive -> Ast_411.Parsetree.toplevel_directive\n =\n fun {\n Ast_410.Parsetree.pdir_name;\n Ast_410.Parsetree.pdir_arg;\n Ast_410.Parsetree.pdir_loc;\n } ->\n {\n Ast_411.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_411.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_411.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_410.Parsetree.directive_argument -> Ast_411.Parsetree.directive_argument\n =\n fun { Ast_410.Parsetree.pdira_desc; Ast_410.Parsetree.pdira_loc } ->\n {\n Ast_411.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_411.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_410.Parsetree.directive_argument_desc ->\n Ast_411.Parsetree.directive_argument_desc = function\n | Ast_410.Parsetree.Pdir_string x0 -> Ast_411.Parsetree.Pdir_string x0\n | Ast_410.Parsetree.Pdir_int (x0, x1) ->\n Ast_411.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_410.Parsetree.Pdir_ident x0 ->\n Ast_411.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_410.Parsetree.Pdir_bool x0 -> Ast_411.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_410.Parsetree.expression -> Ast_411.Parsetree.expression =\n fun {\n Ast_410.Parsetree.pexp_desc;\n Ast_410.Parsetree.pexp_loc;\n Ast_410.Parsetree.pexp_loc_stack;\n Ast_410.Parsetree.pexp_attributes;\n } ->\n {\n Ast_411.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_411.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_411.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_411.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expr x = copy_expression x\n\nand copy_expression_desc :\n Ast_410.Parsetree.expression_desc -> Ast_411.Parsetree.expression_desc =\n function\n | Ast_410.Parsetree.Pexp_ident x0 ->\n Ast_411.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pexp_constant x0 ->\n Ast_411.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_410.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_410.Parsetree.Pexp_function x0 ->\n Ast_411.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_410.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_411.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_410.Parsetree.Pexp_apply (x0, x1) ->\n Ast_411.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_410.Parsetree.Pexp_match (x0, x1) ->\n Ast_411.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_410.Parsetree.Pexp_try (x0, x1) ->\n Ast_411.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_410.Parsetree.Pexp_tuple x0 ->\n Ast_411.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_410.Parsetree.Pexp_construct (x0, x1) ->\n Ast_411.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_410.Parsetree.Pexp_variant (x0, x1) ->\n Ast_411.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_410.Parsetree.Pexp_record (x0, x1) ->\n Ast_411.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_410.Parsetree.Pexp_field (x0, x1) ->\n Ast_411.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_410.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_410.Parsetree.Pexp_array x0 ->\n Ast_411.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_410.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_410.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_411.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_while (x0, x1) ->\n Ast_411.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_411.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_410.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_411.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_410.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_410.Parsetree.Pexp_send (x0, x1) ->\n Ast_411.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_410.Parsetree.Pexp_new x0 ->\n Ast_411.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_411.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_override x0 ->\n Ast_411.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_410.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_411.Parsetree.Pexp_letmodule\n ( copy_loc (fun x -> Option.map (fun x -> x) x) x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_410.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_411.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_assert x0 ->\n Ast_411.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_410.Parsetree.Pexp_lazy x0 ->\n Ast_411.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_410.Parsetree.Pexp_poly (x0, x1) ->\n Ast_411.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_410.Parsetree.Pexp_object x0 ->\n Ast_411.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_410.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_411.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_pack x0 ->\n Ast_411.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_410.Parsetree.Pexp_open (x0, x1) ->\n Ast_411.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_letop x0 ->\n Ast_411.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_410.Parsetree.Pexp_extension x0 ->\n Ast_411.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_410.Parsetree.Pexp_unreachable -> Ast_411.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_410.Parsetree.letop -> Ast_411.Parsetree.letop =\n fun { Ast_410.Parsetree.let_; Ast_410.Parsetree.ands; Ast_410.Parsetree.body } ->\n {\n Ast_411.Parsetree.let_ = copy_binding_op let_;\n Ast_411.Parsetree.ands = List.map copy_binding_op ands;\n Ast_411.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_410.Parsetree.binding_op -> Ast_411.Parsetree.binding_op =\n fun {\n Ast_410.Parsetree.pbop_op;\n Ast_410.Parsetree.pbop_pat;\n Ast_410.Parsetree.pbop_exp;\n Ast_410.Parsetree.pbop_loc;\n } ->\n {\n Ast_411.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_411.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_411.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_411.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_410.Asttypes.direction_flag -> Ast_411.Asttypes.direction_flag =\n function\n | Ast_410.Asttypes.Upto -> Ast_411.Asttypes.Upto\n | Ast_410.Asttypes.Downto -> Ast_411.Asttypes.Downto\n\nand copy_case : Ast_410.Parsetree.case -> Ast_411.Parsetree.case =\n fun {\n Ast_410.Parsetree.pc_lhs;\n Ast_410.Parsetree.pc_guard;\n Ast_410.Parsetree.pc_rhs;\n } ->\n {\n Ast_411.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_411.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_411.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_cases : Ast_410.Parsetree.case list -> Ast_411.Parsetree.case list =\n fun x -> List.map copy_case x\n\nand copy_value_binding :\n Ast_410.Parsetree.value_binding -> Ast_411.Parsetree.value_binding =\n fun {\n Ast_410.Parsetree.pvb_pat;\n Ast_410.Parsetree.pvb_expr;\n Ast_410.Parsetree.pvb_attributes;\n Ast_410.Parsetree.pvb_loc;\n } ->\n {\n Ast_411.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_411.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_411.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_411.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_410.Parsetree.pattern -> Ast_411.Parsetree.pattern =\n fun {\n Ast_410.Parsetree.ppat_desc;\n Ast_410.Parsetree.ppat_loc;\n Ast_410.Parsetree.ppat_loc_stack;\n Ast_410.Parsetree.ppat_attributes;\n } ->\n {\n Ast_411.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_411.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_411.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_411.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pat x = copy_pattern x\n\nand copy_pattern_desc :\n Ast_410.Parsetree.pattern_desc -> Ast_411.Parsetree.pattern_desc = function\n | Ast_410.Parsetree.Ppat_any -> Ast_411.Parsetree.Ppat_any\n | Ast_410.Parsetree.Ppat_var x0 ->\n Ast_411.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_410.Parsetree.Ppat_alias (x0, x1) ->\n Ast_411.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_410.Parsetree.Ppat_constant x0 ->\n Ast_411.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_410.Parsetree.Ppat_interval (x0, x1) ->\n Ast_411.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_410.Parsetree.Ppat_tuple x0 ->\n Ast_411.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_410.Parsetree.Ppat_construct (x0, x1) ->\n Ast_411.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_410.Parsetree.Ppat_variant (x0, x1) ->\n Ast_411.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_410.Parsetree.Ppat_record (x0, x1) ->\n Ast_411.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_410.Parsetree.Ppat_array x0 ->\n Ast_411.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_410.Parsetree.Ppat_or (x0, x1) ->\n Ast_411.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_410.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_411.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_410.Parsetree.Ppat_type x0 ->\n Ast_411.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Ppat_lazy x0 ->\n Ast_411.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_410.Parsetree.Ppat_unpack x0 ->\n Ast_411.Parsetree.Ppat_unpack\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0)\n | Ast_410.Parsetree.Ppat_exception x0 ->\n Ast_411.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_410.Parsetree.Ppat_extension x0 ->\n Ast_411.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_410.Parsetree.Ppat_open (x0, x1) ->\n Ast_411.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_410.Parsetree.core_type -> Ast_411.Parsetree.core_type\n =\n fun {\n Ast_410.Parsetree.ptyp_desc;\n Ast_410.Parsetree.ptyp_loc;\n Ast_410.Parsetree.ptyp_loc_stack;\n Ast_410.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_411.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_411.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_411.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_typ x = copy_core_type x\n\nand copy_location_stack :\n Ast_410.Parsetree.location_stack -> Ast_411.Parsetree.location_stack =\n fun x -> List.map copy_location x\n\nand copy_core_type_desc :\n Ast_410.Parsetree.core_type_desc -> Ast_411.Parsetree.core_type_desc =\n function\n | Ast_410.Parsetree.Ptyp_any -> Ast_411.Parsetree.Ptyp_any\n | Ast_410.Parsetree.Ptyp_var x0 -> Ast_411.Parsetree.Ptyp_var x0\n | Ast_410.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_411.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_410.Parsetree.Ptyp_tuple x0 ->\n Ast_411.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_410.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_411.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_object (x0, x1) ->\n Ast_411.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_410.Parsetree.Ptyp_class (x0, x1) ->\n Ast_411.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_411.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_410.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_411.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_410.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_411.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_package x0 ->\n Ast_411.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_410.Parsetree.Ptyp_extension x0 ->\n Ast_411.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_410.Parsetree.package_type -> Ast_411.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_410.Parsetree.row_field -> Ast_411.Parsetree.row_field\n =\n fun {\n Ast_410.Parsetree.prf_desc;\n Ast_410.Parsetree.prf_loc;\n Ast_410.Parsetree.prf_attributes;\n } ->\n {\n Ast_411.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_411.Parsetree.prf_loc = copy_location prf_loc;\n Ast_411.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_410.Parsetree.row_field_desc -> Ast_411.Parsetree.row_field_desc =\n function\n | Ast_410.Parsetree.Rtag (x0, x1, x2) ->\n Ast_411.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_410.Parsetree.Rinherit x0 ->\n Ast_411.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_410.Parsetree.object_field -> Ast_411.Parsetree.object_field =\n fun {\n Ast_410.Parsetree.pof_desc;\n Ast_410.Parsetree.pof_loc;\n Ast_410.Parsetree.pof_attributes;\n } ->\n {\n Ast_411.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_411.Parsetree.pof_loc = copy_location pof_loc;\n Ast_411.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_410.Parsetree.attributes -> Ast_411.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_410.Parsetree.attribute -> Ast_411.Parsetree.attribute\n =\n fun {\n Ast_410.Parsetree.attr_name;\n Ast_410.Parsetree.attr_payload;\n Ast_410.Parsetree.attr_loc;\n } ->\n {\n Ast_411.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_411.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_411.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_410.Parsetree.payload -> Ast_411.Parsetree.payload =\n function\n | Ast_410.Parsetree.PStr x0 -> Ast_411.Parsetree.PStr (copy_structure x0)\n | Ast_410.Parsetree.PSig x0 -> Ast_411.Parsetree.PSig (copy_signature x0)\n | Ast_410.Parsetree.PTyp x0 -> Ast_411.Parsetree.PTyp (copy_core_type x0)\n | Ast_410.Parsetree.PPat (x0, x1) ->\n Ast_411.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_410.Parsetree.structure -> Ast_411.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_410.Parsetree.structure_item -> Ast_411.Parsetree.structure_item =\n fun { Ast_410.Parsetree.pstr_desc; Ast_410.Parsetree.pstr_loc } ->\n {\n Ast_411.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_411.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_410.Parsetree.structure_item_desc ->\n Ast_411.Parsetree.structure_item_desc = function\n | Ast_410.Parsetree.Pstr_eval (x0, x1) ->\n Ast_411.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_410.Parsetree.Pstr_value (x0, x1) ->\n Ast_411.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_410.Parsetree.Pstr_primitive x0 ->\n Ast_411.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_410.Parsetree.Pstr_type (x0, x1) ->\n Ast_411.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_410.Parsetree.Pstr_typext x0 ->\n Ast_411.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_410.Parsetree.Pstr_exception x0 ->\n Ast_411.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_410.Parsetree.Pstr_module x0 ->\n Ast_411.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_410.Parsetree.Pstr_recmodule x0 ->\n Ast_411.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_410.Parsetree.Pstr_modtype x0 ->\n Ast_411.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_410.Parsetree.Pstr_open x0 ->\n Ast_411.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_410.Parsetree.Pstr_class x0 ->\n Ast_411.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_410.Parsetree.Pstr_class_type x0 ->\n Ast_411.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_410.Parsetree.Pstr_include x0 ->\n Ast_411.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_410.Parsetree.Pstr_attribute x0 ->\n Ast_411.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pstr_extension (x0, x1) ->\n Ast_411.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_410.Parsetree.include_declaration ->\n Ast_411.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_410.Parsetree.class_declaration -> Ast_411.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_410.Parsetree.class_expr -> Ast_411.Parsetree.class_expr =\n fun {\n Ast_410.Parsetree.pcl_desc;\n Ast_410.Parsetree.pcl_loc;\n Ast_410.Parsetree.pcl_attributes;\n } ->\n {\n Ast_411.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_411.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_411.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_410.Parsetree.class_expr_desc -> Ast_411.Parsetree.class_expr_desc =\n function\n | Ast_410.Parsetree.Pcl_constr (x0, x1) ->\n Ast_411.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Pcl_structure x0 ->\n Ast_411.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_410.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_411.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_410.Parsetree.Pcl_apply (x0, x1) ->\n Ast_411.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_410.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_411.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_410.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_411.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_410.Parsetree.Pcl_extension x0 ->\n Ast_411.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_410.Parsetree.Pcl_open (x0, x1) ->\n Ast_411.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_410.Parsetree.class_structure -> Ast_411.Parsetree.class_structure =\n fun { Ast_410.Parsetree.pcstr_self; Ast_410.Parsetree.pcstr_fields } ->\n {\n Ast_411.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_411.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_410.Parsetree.class_field -> Ast_411.Parsetree.class_field =\n fun {\n Ast_410.Parsetree.pcf_desc;\n Ast_410.Parsetree.pcf_loc;\n Ast_410.Parsetree.pcf_attributes;\n } ->\n {\n Ast_411.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_411.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_411.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_410.Parsetree.class_field_desc -> Ast_411.Parsetree.class_field_desc =\n function\n | Ast_410.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_411.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_410.Parsetree.Pcf_val x0 ->\n Ast_411.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_410.Parsetree.Pcf_method x0 ->\n Ast_411.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_410.Parsetree.Pcf_constraint x0 ->\n Ast_411.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_410.Parsetree.Pcf_initializer x0 ->\n Ast_411.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_410.Parsetree.Pcf_attribute x0 ->\n Ast_411.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pcf_extension x0 ->\n Ast_411.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_410.Parsetree.class_field_kind -> Ast_411.Parsetree.class_field_kind =\n function\n | Ast_410.Parsetree.Cfk_virtual x0 ->\n Ast_411.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_410.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_411.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_410.Parsetree.open_declaration -> Ast_411.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_410.Parsetree.module_binding -> Ast_411.Parsetree.module_binding =\n fun {\n Ast_410.Parsetree.pmb_name;\n Ast_410.Parsetree.pmb_expr;\n Ast_410.Parsetree.pmb_attributes;\n Ast_410.Parsetree.pmb_loc;\n } ->\n {\n Ast_411.Parsetree.pmb_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmb_name;\n Ast_411.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_411.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_411.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_410.Parsetree.module_expr -> Ast_411.Parsetree.module_expr =\n fun {\n Ast_410.Parsetree.pmod_desc;\n Ast_410.Parsetree.pmod_loc;\n Ast_410.Parsetree.pmod_attributes;\n } ->\n {\n Ast_411.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_411.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_411.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_410.Parsetree.module_expr_desc -> Ast_411.Parsetree.module_expr_desc =\n function\n | Ast_410.Parsetree.Pmod_ident x0 ->\n Ast_411.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pmod_structure x0 ->\n Ast_411.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_410.Parsetree.Pmod_functor (x0, x1) ->\n Ast_411.Parsetree.Pmod_functor\n (copy_functor_parameter x0, copy_module_expr x1)\n | Ast_410.Parsetree.Pmod_apply (x0, x1) ->\n Ast_411.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_410.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_411.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_410.Parsetree.Pmod_unpack x0 ->\n Ast_411.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_410.Parsetree.Pmod_extension x0 ->\n Ast_411.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_410.Parsetree.functor_parameter -> Ast_411.Parsetree.functor_parameter =\n function\n | Ast_410.Parsetree.Unit -> Ast_411.Parsetree.Unit\n | Ast_410.Parsetree.Named (x0, x1) ->\n Ast_411.Parsetree.Named\n (copy_loc (fun x -> Option.map (fun x -> x) x) x0, copy_module_type x1)\n\nand copy_module_type :\n Ast_410.Parsetree.module_type -> Ast_411.Parsetree.module_type =\n fun {\n Ast_410.Parsetree.pmty_desc;\n Ast_410.Parsetree.pmty_loc;\n Ast_410.Parsetree.pmty_attributes;\n } ->\n {\n Ast_411.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_411.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_411.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_410.Parsetree.module_type_desc -> Ast_411.Parsetree.module_type_desc =\n function\n | Ast_410.Parsetree.Pmty_ident x0 ->\n Ast_411.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pmty_signature x0 ->\n Ast_411.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_410.Parsetree.Pmty_functor (x0, x1) ->\n Ast_411.Parsetree.Pmty_functor\n (copy_functor_parameter x0, copy_module_type x1)\n | Ast_410.Parsetree.Pmty_with (x0, x1) ->\n Ast_411.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_410.Parsetree.Pmty_typeof x0 ->\n Ast_411.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_410.Parsetree.Pmty_extension x0 ->\n Ast_411.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_410.Parsetree.Pmty_alias x0 ->\n Ast_411.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_410.Parsetree.with_constraint -> Ast_411.Parsetree.with_constraint =\n function\n | Ast_410.Parsetree.Pwith_type (x0, x1) ->\n Ast_411.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_410.Parsetree.Pwith_module (x0, x1) ->\n Ast_411.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_410.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_411.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_410.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_411.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_410.Parsetree.signature -> Ast_411.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_410.Parsetree.signature_item -> Ast_411.Parsetree.signature_item =\n fun { Ast_410.Parsetree.psig_desc; Ast_410.Parsetree.psig_loc } ->\n {\n Ast_411.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_411.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_410.Parsetree.signature_item_desc ->\n Ast_411.Parsetree.signature_item_desc = function\n | Ast_410.Parsetree.Psig_value x0 ->\n Ast_411.Parsetree.Psig_value (copy_value_description x0)\n | Ast_410.Parsetree.Psig_type (x0, x1) ->\n Ast_411.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_410.Parsetree.Psig_typesubst x0 ->\n Ast_411.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_410.Parsetree.Psig_typext x0 ->\n Ast_411.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_410.Parsetree.Psig_exception x0 ->\n Ast_411.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_410.Parsetree.Psig_module x0 ->\n Ast_411.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_410.Parsetree.Psig_modsubst x0 ->\n Ast_411.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_410.Parsetree.Psig_recmodule x0 ->\n Ast_411.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_410.Parsetree.Psig_modtype x0 ->\n Ast_411.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_410.Parsetree.Psig_open x0 ->\n Ast_411.Parsetree.Psig_open (copy_open_description x0)\n | Ast_410.Parsetree.Psig_include x0 ->\n Ast_411.Parsetree.Psig_include (copy_include_description x0)\n | Ast_410.Parsetree.Psig_class x0 ->\n Ast_411.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_410.Parsetree.Psig_class_type x0 ->\n Ast_411.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_410.Parsetree.Psig_attribute x0 ->\n Ast_411.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Psig_extension (x0, x1) ->\n Ast_411.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_410.Parsetree.class_type_declaration ->\n Ast_411.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_410.Parsetree.class_description -> Ast_411.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_410.Parsetree.class_type -> Ast_411.Parsetree.class_type =\n fun {\n Ast_410.Parsetree.pcty_desc;\n Ast_410.Parsetree.pcty_loc;\n Ast_410.Parsetree.pcty_attributes;\n } ->\n {\n Ast_411.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_411.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_411.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_410.Parsetree.class_type_desc -> Ast_411.Parsetree.class_type_desc =\n function\n | Ast_410.Parsetree.Pcty_constr (x0, x1) ->\n Ast_411.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Pcty_signature x0 ->\n Ast_411.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_410.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_411.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_410.Parsetree.Pcty_extension x0 ->\n Ast_411.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_410.Parsetree.Pcty_open (x0, x1) ->\n Ast_411.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_410.Parsetree.class_signature -> Ast_411.Parsetree.class_signature =\n fun { Ast_410.Parsetree.pcsig_self; Ast_410.Parsetree.pcsig_fields } ->\n {\n Ast_411.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_411.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_410.Parsetree.class_type_field -> Ast_411.Parsetree.class_type_field =\n fun {\n Ast_410.Parsetree.pctf_desc;\n Ast_410.Parsetree.pctf_loc;\n Ast_410.Parsetree.pctf_attributes;\n } ->\n {\n Ast_411.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_411.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_411.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_410.Parsetree.class_type_field_desc ->\n Ast_411.Parsetree.class_type_field_desc = function\n | Ast_410.Parsetree.Pctf_inherit x0 ->\n Ast_411.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_410.Parsetree.Pctf_val x0 ->\n Ast_411.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_410.Parsetree.Pctf_method x0 ->\n Ast_411.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_410.Parsetree.Pctf_constraint x0 ->\n Ast_411.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_410.Parsetree.Pctf_attribute x0 ->\n Ast_411.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pctf_extension x0 ->\n Ast_411.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_410.Parsetree.extension -> Ast_411.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.class_infos ->\n 'g0 Ast_411.Parsetree.class_infos =\n fun f0\n {\n Ast_410.Parsetree.pci_virt;\n Ast_410.Parsetree.pci_params;\n Ast_410.Parsetree.pci_name;\n Ast_410.Parsetree.pci_expr;\n Ast_410.Parsetree.pci_loc;\n Ast_410.Parsetree.pci_attributes;\n } ->\n {\n Ast_411.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_411.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_411.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_411.Parsetree.pci_expr = f0 pci_expr;\n Ast_411.Parsetree.pci_loc = copy_location pci_loc;\n Ast_411.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_410.Asttypes.virtual_flag -> Ast_411.Asttypes.virtual_flag = function\n | Ast_410.Asttypes.Virtual -> Ast_411.Asttypes.Virtual\n | Ast_410.Asttypes.Concrete -> Ast_411.Asttypes.Concrete\n\nand copy_include_description :\n Ast_410.Parsetree.include_description ->\n Ast_411.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.include_infos ->\n 'g0 Ast_411.Parsetree.include_infos =\n fun f0\n {\n Ast_410.Parsetree.pincl_mod;\n Ast_410.Parsetree.pincl_loc;\n Ast_410.Parsetree.pincl_attributes;\n } ->\n {\n Ast_411.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_411.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_411.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_410.Parsetree.open_description -> Ast_411.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.open_infos ->\n 'g0 Ast_411.Parsetree.open_infos =\n fun f0\n {\n Ast_410.Parsetree.popen_expr;\n Ast_410.Parsetree.popen_override;\n Ast_410.Parsetree.popen_loc;\n Ast_410.Parsetree.popen_attributes;\n } ->\n {\n Ast_411.Parsetree.popen_expr = f0 popen_expr;\n Ast_411.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_411.Parsetree.popen_loc = copy_location popen_loc;\n Ast_411.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_410.Asttypes.override_flag -> Ast_411.Asttypes.override_flag = function\n | Ast_410.Asttypes.Override -> Ast_411.Asttypes.Override\n | Ast_410.Asttypes.Fresh -> Ast_411.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_410.Parsetree.module_type_declaration ->\n Ast_411.Parsetree.module_type_declaration =\n fun {\n Ast_410.Parsetree.pmtd_name;\n Ast_410.Parsetree.pmtd_type;\n Ast_410.Parsetree.pmtd_attributes;\n Ast_410.Parsetree.pmtd_loc;\n } ->\n {\n Ast_411.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_411.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_411.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_411.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_410.Parsetree.module_substitution ->\n Ast_411.Parsetree.module_substitution =\n fun {\n Ast_410.Parsetree.pms_name;\n Ast_410.Parsetree.pms_manifest;\n Ast_410.Parsetree.pms_attributes;\n Ast_410.Parsetree.pms_loc;\n } ->\n {\n Ast_411.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_411.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_411.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_411.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_410.Parsetree.module_declaration -> Ast_411.Parsetree.module_declaration\n =\n fun {\n Ast_410.Parsetree.pmd_name;\n Ast_410.Parsetree.pmd_type;\n Ast_410.Parsetree.pmd_attributes;\n Ast_410.Parsetree.pmd_loc;\n } ->\n {\n Ast_411.Parsetree.pmd_name =\n copy_loc (fun x -> Option.map (fun x -> x) x) pmd_name;\n Ast_411.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_411.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_411.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_410.Parsetree.type_exception -> Ast_411.Parsetree.type_exception =\n fun {\n Ast_410.Parsetree.ptyexn_constructor;\n Ast_410.Parsetree.ptyexn_loc;\n Ast_410.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_411.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_411.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_410.Parsetree.type_extension -> Ast_411.Parsetree.type_extension =\n fun {\n Ast_410.Parsetree.ptyext_path;\n Ast_410.Parsetree.ptyext_params;\n Ast_410.Parsetree.ptyext_constructors;\n Ast_410.Parsetree.ptyext_private;\n Ast_410.Parsetree.ptyext_loc;\n Ast_410.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_411.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_411.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_411.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_411.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_411.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_411.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_410.Parsetree.extension_constructor ->\n Ast_411.Parsetree.extension_constructor =\n fun {\n Ast_410.Parsetree.pext_name;\n Ast_410.Parsetree.pext_kind;\n Ast_410.Parsetree.pext_loc;\n Ast_410.Parsetree.pext_attributes;\n } ->\n {\n Ast_411.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_411.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_411.Parsetree.pext_loc = copy_location pext_loc;\n Ast_411.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_410.Parsetree.extension_constructor_kind ->\n Ast_411.Parsetree.extension_constructor_kind = function\n | Ast_410.Parsetree.Pext_decl (x0, x1) ->\n Ast_411.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_410.Parsetree.Pext_rebind x0 ->\n Ast_411.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_410.Parsetree.type_declaration -> Ast_411.Parsetree.type_declaration =\n fun {\n Ast_410.Parsetree.ptype_name;\n Ast_410.Parsetree.ptype_params;\n Ast_410.Parsetree.ptype_cstrs;\n Ast_410.Parsetree.ptype_kind;\n Ast_410.Parsetree.ptype_private;\n Ast_410.Parsetree.ptype_manifest;\n Ast_410.Parsetree.ptype_attributes;\n Ast_410.Parsetree.ptype_loc;\n } ->\n {\n Ast_411.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_411.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_411.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_411.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_411.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_411.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_411.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_411.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_410.Asttypes.private_flag -> Ast_411.Asttypes.private_flag = function\n | Ast_410.Asttypes.Private -> Ast_411.Asttypes.Private\n | Ast_410.Asttypes.Public -> Ast_411.Asttypes.Public\n\nand copy_type_kind : Ast_410.Parsetree.type_kind -> Ast_411.Parsetree.type_kind\n = function\n | Ast_410.Parsetree.Ptype_abstract -> Ast_411.Parsetree.Ptype_abstract\n | Ast_410.Parsetree.Ptype_variant x0 ->\n Ast_411.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_410.Parsetree.Ptype_record x0 ->\n Ast_411.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_410.Parsetree.Ptype_open -> Ast_411.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_410.Parsetree.constructor_declaration ->\n Ast_411.Parsetree.constructor_declaration =\n fun {\n Ast_410.Parsetree.pcd_name;\n Ast_410.Parsetree.pcd_args;\n Ast_410.Parsetree.pcd_res;\n Ast_410.Parsetree.pcd_loc;\n Ast_410.Parsetree.pcd_attributes;\n } ->\n {\n Ast_411.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_411.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_411.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_411.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_411.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_410.Parsetree.constructor_arguments ->\n Ast_411.Parsetree.constructor_arguments = function\n | Ast_410.Parsetree.Pcstr_tuple x0 ->\n Ast_411.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_410.Parsetree.Pcstr_record x0 ->\n Ast_411.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_410.Parsetree.label_declaration -> Ast_411.Parsetree.label_declaration =\n fun {\n Ast_410.Parsetree.pld_name;\n Ast_410.Parsetree.pld_mutable;\n Ast_410.Parsetree.pld_type;\n Ast_410.Parsetree.pld_loc;\n Ast_410.Parsetree.pld_attributes;\n } ->\n {\n Ast_411.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_411.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_411.Parsetree.pld_type = copy_core_type pld_type;\n Ast_411.Parsetree.pld_loc = copy_location pld_loc;\n Ast_411.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_410.Asttypes.mutable_flag -> Ast_411.Asttypes.mutable_flag = function\n | Ast_410.Asttypes.Immutable -> Ast_411.Asttypes.Immutable\n | Ast_410.Asttypes.Mutable -> Ast_411.Asttypes.Mutable\n\nand copy_variance : Ast_410.Asttypes.variance -> Ast_411.Asttypes.variance =\n function\n | Ast_410.Asttypes.Covariant -> Ast_411.Asttypes.Covariant\n | Ast_410.Asttypes.Contravariant -> Ast_411.Asttypes.Contravariant\n | Ast_410.Asttypes.Invariant -> Ast_411.Asttypes.Invariant\n\nand copy_value_description :\n Ast_410.Parsetree.value_description -> Ast_411.Parsetree.value_description =\n fun {\n Ast_410.Parsetree.pval_name;\n Ast_410.Parsetree.pval_type;\n Ast_410.Parsetree.pval_prim;\n Ast_410.Parsetree.pval_attributes;\n Ast_410.Parsetree.pval_loc;\n } ->\n {\n Ast_411.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_411.Parsetree.pval_type = copy_core_type pval_type;\n Ast_411.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_411.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_411.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_410.Parsetree.object_field_desc -> Ast_411.Parsetree.object_field_desc =\n function\n | Ast_410.Parsetree.Otag (x0, x1) ->\n Ast_411.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_410.Parsetree.Oinherit x0 ->\n Ast_411.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_410.Asttypes.arg_label -> Ast_411.Asttypes.arg_label =\n function\n | Ast_410.Asttypes.Nolabel -> Ast_411.Asttypes.Nolabel\n | Ast_410.Asttypes.Labelled x0 -> Ast_411.Asttypes.Labelled x0\n | Ast_410.Asttypes.Optional x0 -> Ast_411.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_410.Asttypes.closed_flag -> Ast_411.Asttypes.closed_flag = function\n | Ast_410.Asttypes.Closed -> Ast_411.Asttypes.Closed\n | Ast_410.Asttypes.Open -> Ast_411.Asttypes.Open\n\nand copy_label : Ast_410.Asttypes.label -> Ast_411.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_410.Asttypes.rec_flag -> Ast_411.Asttypes.rec_flag =\n function\n | Ast_410.Asttypes.Nonrecursive -> Ast_411.Asttypes.Nonrecursive\n | Ast_410.Asttypes.Recursive -> Ast_411.Asttypes.Recursive\n\nand copy_constant : Ast_410.Parsetree.constant -> Ast_411.Parsetree.constant =\n function\n | Ast_410.Parsetree.Pconst_integer (x0, x1) ->\n Ast_411.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_410.Parsetree.Pconst_char x0 -> Ast_411.Parsetree.Pconst_char x0\n | Ast_410.Parsetree.Pconst_string (x0, x1) ->\n Ast_411.Parsetree.Pconst_string\n (x0, Location.none, Option.map (fun x -> x) x1)\n | Ast_410.Parsetree.Pconst_float (x0, x1) ->\n Ast_411.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_410.Asttypes.loc -> 'g0 Ast_411.Asttypes.loc =\n fun f0 { Ast_410.Asttypes.txt; Ast_410.Asttypes.loc } ->\n { Ast_411.Asttypes.txt = f0 txt; Ast_411.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","module From = Ast_410\nmodule To = Ast_409\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.10\" missing_feature\n\nlet map_option f x = match x with None -> None | Some x -> Some (f x)\n\nlet rec copy_toplevel_phrase :\n Ast_410.Parsetree.toplevel_phrase -> Ast_409.Parsetree.toplevel_phrase =\n function\n | Ast_410.Parsetree.Ptop_def x0 ->\n Ast_409.Parsetree.Ptop_def (copy_structure x0)\n | Ast_410.Parsetree.Ptop_dir x0 ->\n Ast_409.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_410.Parsetree.toplevel_directive -> Ast_409.Parsetree.toplevel_directive\n =\n fun {\n Ast_410.Parsetree.pdir_name;\n Ast_410.Parsetree.pdir_arg;\n Ast_410.Parsetree.pdir_loc;\n } ->\n {\n Ast_409.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_409.Parsetree.pdir_arg = map_option copy_directive_argument pdir_arg;\n Ast_409.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_410.Parsetree.directive_argument -> Ast_409.Parsetree.directive_argument\n =\n fun { Ast_410.Parsetree.pdira_desc; Ast_410.Parsetree.pdira_loc } ->\n {\n Ast_409.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_409.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_410.Parsetree.directive_argument_desc ->\n Ast_409.Parsetree.directive_argument_desc = function\n | Ast_410.Parsetree.Pdir_string x0 -> Ast_409.Parsetree.Pdir_string x0\n | Ast_410.Parsetree.Pdir_int (x0, x1) ->\n Ast_409.Parsetree.Pdir_int (x0, map_option (fun x -> x) x1)\n | Ast_410.Parsetree.Pdir_ident x0 ->\n Ast_409.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_410.Parsetree.Pdir_bool x0 -> Ast_409.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_410.Parsetree.expression -> Ast_409.Parsetree.expression =\n fun {\n Ast_410.Parsetree.pexp_desc;\n Ast_410.Parsetree.pexp_loc;\n Ast_410.Parsetree.pexp_loc_stack;\n Ast_410.Parsetree.pexp_attributes;\n } ->\n {\n Ast_409.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_409.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_409.Parsetree.pexp_loc_stack = copy_location_stack pexp_loc_stack;\n Ast_409.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_410.Parsetree.expression_desc -> Ast_409.Parsetree.expression_desc =\n function\n | Ast_410.Parsetree.Pexp_ident x0 ->\n Ast_409.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pexp_constant x0 ->\n Ast_409.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_410.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_410.Parsetree.Pexp_function x0 ->\n Ast_409.Parsetree.Pexp_function (List.map copy_case x0)\n | Ast_410.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_409.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n map_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_410.Parsetree.Pexp_apply (x0, x1) ->\n Ast_409.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_410.Parsetree.Pexp_match (x0, x1) ->\n Ast_409.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | Ast_410.Parsetree.Pexp_try (x0, x1) ->\n Ast_409.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | Ast_410.Parsetree.Pexp_tuple x0 ->\n Ast_409.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_410.Parsetree.Pexp_construct (x0, x1) ->\n Ast_409.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, map_option copy_expression x1)\n | Ast_410.Parsetree.Pexp_variant (x0, x1) ->\n Ast_409.Parsetree.Pexp_variant\n (copy_label x0, map_option copy_expression x1)\n | Ast_410.Parsetree.Pexp_record (x0, x1) ->\n Ast_409.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n map_option copy_expression x1 )\n | Ast_410.Parsetree.Pexp_field (x0, x1) ->\n Ast_409.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_410.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_410.Parsetree.Pexp_array x0 ->\n Ast_409.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_410.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, map_option copy_expression x2)\n | Ast_410.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_409.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_while (x0, x1) ->\n Ast_409.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_409.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_410.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_409.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_410.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_coerce\n (copy_expression x0, map_option copy_core_type x1, copy_core_type x2)\n | Ast_410.Parsetree.Pexp_send (x0, x1) ->\n Ast_409.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_410.Parsetree.Pexp_new x0 ->\n Ast_409.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_409.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_override x0 ->\n Ast_409.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_410.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_letmodule\n ( copy_loc\n (function\n | None -> migration_error x0.loc \"anonymous let module\"\n | Some x -> x)\n x0,\n copy_module_expr x1,\n copy_expression x2 )\n | Ast_410.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_409.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_assert x0 ->\n Ast_409.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_410.Parsetree.Pexp_lazy x0 ->\n Ast_409.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_410.Parsetree.Pexp_poly (x0, x1) ->\n Ast_409.Parsetree.Pexp_poly\n (copy_expression x0, map_option copy_core_type x1)\n | Ast_410.Parsetree.Pexp_object x0 ->\n Ast_409.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_410.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_409.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_pack x0 ->\n Ast_409.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_410.Parsetree.Pexp_open (x0, x1) ->\n Ast_409.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_410.Parsetree.Pexp_letop x0 ->\n Ast_409.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_410.Parsetree.Pexp_extension x0 ->\n Ast_409.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_410.Parsetree.Pexp_unreachable -> Ast_409.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_410.Parsetree.letop -> Ast_409.Parsetree.letop =\n fun { Ast_410.Parsetree.let_; Ast_410.Parsetree.ands; Ast_410.Parsetree.body } ->\n {\n Ast_409.Parsetree.let_ = copy_binding_op let_;\n Ast_409.Parsetree.ands = List.map copy_binding_op ands;\n Ast_409.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_410.Parsetree.binding_op -> Ast_409.Parsetree.binding_op =\n fun {\n Ast_410.Parsetree.pbop_op;\n Ast_410.Parsetree.pbop_pat;\n Ast_410.Parsetree.pbop_exp;\n Ast_410.Parsetree.pbop_loc;\n } ->\n {\n Ast_409.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_409.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_409.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_409.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_410.Asttypes.direction_flag -> Ast_409.Asttypes.direction_flag =\n function\n | Ast_410.Asttypes.Upto -> Ast_409.Asttypes.Upto\n | Ast_410.Asttypes.Downto -> Ast_409.Asttypes.Downto\n\nand copy_case : Ast_410.Parsetree.case -> Ast_409.Parsetree.case =\n fun {\n Ast_410.Parsetree.pc_lhs;\n Ast_410.Parsetree.pc_guard;\n Ast_410.Parsetree.pc_rhs;\n } ->\n {\n Ast_409.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_409.Parsetree.pc_guard = map_option copy_expression pc_guard;\n Ast_409.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_cases : Ast_410.Parsetree.case list -> Ast_409.Parsetree.cases =\n fun x -> List.map copy_case x\n\nand copy_value_binding :\n Ast_410.Parsetree.value_binding -> Ast_409.Parsetree.value_binding =\n fun {\n Ast_410.Parsetree.pvb_pat;\n Ast_410.Parsetree.pvb_expr;\n Ast_410.Parsetree.pvb_attributes;\n Ast_410.Parsetree.pvb_loc;\n } ->\n {\n Ast_409.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_409.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_409.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_409.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_410.Parsetree.pattern -> Ast_409.Parsetree.pattern =\n fun {\n Ast_410.Parsetree.ppat_desc;\n Ast_410.Parsetree.ppat_loc;\n Ast_410.Parsetree.ppat_loc_stack;\n Ast_410.Parsetree.ppat_attributes;\n } ->\n {\n Ast_409.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_409.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_409.Parsetree.ppat_loc_stack = copy_location_stack ppat_loc_stack;\n Ast_409.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_410.Parsetree.pattern_desc -> Ast_409.Parsetree.pattern_desc = function\n | Ast_410.Parsetree.Ppat_any -> Ast_409.Parsetree.Ppat_any\n | Ast_410.Parsetree.Ppat_var x0 ->\n Ast_409.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_410.Parsetree.Ppat_alias (x0, x1) ->\n Ast_409.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_410.Parsetree.Ppat_constant x0 ->\n Ast_409.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_410.Parsetree.Ppat_interval (x0, x1) ->\n Ast_409.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_410.Parsetree.Ppat_tuple x0 ->\n Ast_409.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_410.Parsetree.Ppat_construct (x0, x1) ->\n Ast_409.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, map_option copy_pattern x1)\n | Ast_410.Parsetree.Ppat_variant (x0, x1) ->\n Ast_409.Parsetree.Ppat_variant (copy_label x0, map_option copy_pattern x1)\n | Ast_410.Parsetree.Ppat_record (x0, x1) ->\n Ast_409.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_410.Parsetree.Ppat_array x0 ->\n Ast_409.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_410.Parsetree.Ppat_or (x0, x1) ->\n Ast_409.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_410.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_409.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_410.Parsetree.Ppat_type x0 ->\n Ast_409.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Ppat_lazy x0 ->\n Ast_409.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_410.Parsetree.Ppat_unpack x0 ->\n Ast_409.Parsetree.Ppat_unpack\n (copy_loc\n (function\n | None -> migration_error x0.loc \"anynymous unpack\" | Some x -> x)\n x0)\n | Ast_410.Parsetree.Ppat_exception x0 ->\n Ast_409.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_410.Parsetree.Ppat_extension x0 ->\n Ast_409.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_410.Parsetree.Ppat_open (x0, x1) ->\n Ast_409.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_410.Parsetree.core_type -> Ast_409.Parsetree.core_type\n =\n fun {\n Ast_410.Parsetree.ptyp_desc;\n Ast_410.Parsetree.ptyp_loc;\n Ast_410.Parsetree.ptyp_loc_stack;\n Ast_410.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_409.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_409.Parsetree.ptyp_loc_stack = copy_location_stack ptyp_loc_stack;\n Ast_409.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_location_stack : Ast_410.Parsetree.location_stack -> Location.t list =\n fun x -> List.map copy_location x\n\nand copy_core_type_desc :\n Ast_410.Parsetree.core_type_desc -> Ast_409.Parsetree.core_type_desc =\n function\n | Ast_410.Parsetree.Ptyp_any -> Ast_409.Parsetree.Ptyp_any\n | Ast_410.Parsetree.Ptyp_var x0 -> Ast_409.Parsetree.Ptyp_var x0\n | Ast_410.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_409.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_410.Parsetree.Ptyp_tuple x0 ->\n Ast_409.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_410.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_409.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_object (x0, x1) ->\n Ast_409.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_410.Parsetree.Ptyp_class (x0, x1) ->\n Ast_409.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_409.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_410.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_409.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n map_option (fun x -> List.map copy_label x) x2 )\n | Ast_410.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_409.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_410.Parsetree.Ptyp_package x0 ->\n Ast_409.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_410.Parsetree.Ptyp_extension x0 ->\n Ast_409.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_410.Parsetree.package_type -> Ast_409.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_410.Parsetree.row_field -> Ast_409.Parsetree.row_field\n =\n fun {\n Ast_410.Parsetree.prf_desc;\n Ast_410.Parsetree.prf_loc;\n Ast_410.Parsetree.prf_attributes;\n } ->\n {\n Ast_409.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_409.Parsetree.prf_loc = copy_location prf_loc;\n Ast_409.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_410.Parsetree.row_field_desc -> Ast_409.Parsetree.row_field_desc =\n function\n | Ast_410.Parsetree.Rtag (x0, x1, x2) ->\n Ast_409.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_410.Parsetree.Rinherit x0 ->\n Ast_409.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_410.Parsetree.object_field -> Ast_409.Parsetree.object_field =\n fun {\n Ast_410.Parsetree.pof_desc;\n Ast_410.Parsetree.pof_loc;\n Ast_410.Parsetree.pof_attributes;\n } ->\n {\n Ast_409.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_409.Parsetree.pof_loc = copy_location pof_loc;\n Ast_409.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_410.Parsetree.attributes -> Ast_409.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_410.Parsetree.attribute -> Ast_409.Parsetree.attribute\n =\n fun {\n Ast_410.Parsetree.attr_name;\n Ast_410.Parsetree.attr_payload;\n Ast_410.Parsetree.attr_loc;\n } ->\n {\n Ast_409.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_409.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_409.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_410.Parsetree.payload -> Ast_409.Parsetree.payload =\n function\n | Ast_410.Parsetree.PStr x0 -> Ast_409.Parsetree.PStr (copy_structure x0)\n | Ast_410.Parsetree.PSig x0 -> Ast_409.Parsetree.PSig (copy_signature x0)\n | Ast_410.Parsetree.PTyp x0 -> Ast_409.Parsetree.PTyp (copy_core_type x0)\n | Ast_410.Parsetree.PPat (x0, x1) ->\n Ast_409.Parsetree.PPat (copy_pattern x0, map_option copy_expression x1)\n\nand copy_structure : Ast_410.Parsetree.structure -> Ast_409.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_410.Parsetree.structure_item -> Ast_409.Parsetree.structure_item =\n fun { Ast_410.Parsetree.pstr_desc; Ast_410.Parsetree.pstr_loc } ->\n {\n Ast_409.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_409.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_410.Parsetree.structure_item_desc ->\n Ast_409.Parsetree.structure_item_desc = function\n | Ast_410.Parsetree.Pstr_eval (x0, x1) ->\n Ast_409.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_410.Parsetree.Pstr_value (x0, x1) ->\n Ast_409.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_410.Parsetree.Pstr_primitive x0 ->\n Ast_409.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_410.Parsetree.Pstr_type (x0, x1) ->\n Ast_409.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_410.Parsetree.Pstr_typext x0 ->\n Ast_409.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_410.Parsetree.Pstr_exception x0 ->\n Ast_409.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_410.Parsetree.Pstr_module x0 ->\n Ast_409.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_410.Parsetree.Pstr_recmodule x0 ->\n Ast_409.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_410.Parsetree.Pstr_modtype x0 ->\n Ast_409.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_410.Parsetree.Pstr_open x0 ->\n Ast_409.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_410.Parsetree.Pstr_class x0 ->\n Ast_409.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_410.Parsetree.Pstr_class_type x0 ->\n Ast_409.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_410.Parsetree.Pstr_include x0 ->\n Ast_409.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_410.Parsetree.Pstr_attribute x0 ->\n Ast_409.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pstr_extension (x0, x1) ->\n Ast_409.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_410.Parsetree.include_declaration ->\n Ast_409.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_410.Parsetree.class_declaration -> Ast_409.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_410.Parsetree.class_expr -> Ast_409.Parsetree.class_expr =\n fun {\n Ast_410.Parsetree.pcl_desc;\n Ast_410.Parsetree.pcl_loc;\n Ast_410.Parsetree.pcl_attributes;\n } ->\n {\n Ast_409.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_409.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_409.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_410.Parsetree.class_expr_desc -> Ast_409.Parsetree.class_expr_desc =\n function\n | Ast_410.Parsetree.Pcl_constr (x0, x1) ->\n Ast_409.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Pcl_structure x0 ->\n Ast_409.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_410.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_409.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n map_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_410.Parsetree.Pcl_apply (x0, x1) ->\n Ast_409.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_410.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_409.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_410.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_409.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_410.Parsetree.Pcl_extension x0 ->\n Ast_409.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_410.Parsetree.Pcl_open (x0, x1) ->\n Ast_409.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_410.Parsetree.class_structure -> Ast_409.Parsetree.class_structure =\n fun { Ast_410.Parsetree.pcstr_self; Ast_410.Parsetree.pcstr_fields } ->\n {\n Ast_409.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_409.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_410.Parsetree.class_field -> Ast_409.Parsetree.class_field =\n fun {\n Ast_410.Parsetree.pcf_desc;\n Ast_410.Parsetree.pcf_loc;\n Ast_410.Parsetree.pcf_attributes;\n } ->\n {\n Ast_409.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_409.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_409.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_410.Parsetree.class_field_desc -> Ast_409.Parsetree.class_field_desc =\n function\n | Ast_410.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_409.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n map_option (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_410.Parsetree.Pcf_val x0 ->\n Ast_409.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_410.Parsetree.Pcf_method x0 ->\n Ast_409.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_410.Parsetree.Pcf_constraint x0 ->\n Ast_409.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_410.Parsetree.Pcf_initializer x0 ->\n Ast_409.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_410.Parsetree.Pcf_attribute x0 ->\n Ast_409.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pcf_extension x0 ->\n Ast_409.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_410.Parsetree.class_field_kind -> Ast_409.Parsetree.class_field_kind =\n function\n | Ast_410.Parsetree.Cfk_virtual x0 ->\n Ast_409.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_410.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_409.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_410.Parsetree.open_declaration -> Ast_409.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_410.Parsetree.module_binding -> Ast_409.Parsetree.module_binding =\n fun {\n Ast_410.Parsetree.pmb_name;\n Ast_410.Parsetree.pmb_expr;\n Ast_410.Parsetree.pmb_attributes;\n Ast_410.Parsetree.pmb_loc;\n } ->\n {\n Ast_409.Parsetree.pmb_name =\n copy_loc\n (function\n | Some x -> x\n | None -> migration_error pmb_name.loc \"anonymous module binding\")\n pmb_name;\n Ast_409.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_409.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_409.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_410.Parsetree.module_expr -> Ast_409.Parsetree.module_expr =\n fun {\n Ast_410.Parsetree.pmod_desc;\n Ast_410.Parsetree.pmod_loc;\n Ast_410.Parsetree.pmod_attributes;\n } ->\n {\n Ast_409.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_409.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_409.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_410.Parsetree.module_expr_desc -> Ast_409.Parsetree.module_expr_desc =\n function\n | Ast_410.Parsetree.Pmod_ident x0 ->\n Ast_409.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pmod_structure x0 ->\n Ast_409.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_410.Parsetree.Pmod_functor (x0, x1) ->\n let x, y = copy_functor_parameter x0 in\n Ast_409.Parsetree.Pmod_functor (x, y, copy_module_expr x1)\n | Ast_410.Parsetree.Pmod_apply (x0, x1) ->\n Ast_409.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_410.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_409.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_410.Parsetree.Pmod_unpack x0 ->\n Ast_409.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_410.Parsetree.Pmod_extension x0 ->\n Ast_409.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_functor_parameter :\n Ast_410.Parsetree.functor_parameter ->\n string Ast_409.Asttypes.loc * Ast_409.Parsetree.module_type option =\n function\n | Ast_410.Parsetree.Unit -> ({ loc = Location.none; txt = \"*\" }, None)\n | Ast_410.Parsetree.Named (x0, x1) ->\n ( copy_loc (function None -> \"_\" | Some x -> x) x0,\n Some (copy_module_type x1) )\n\nand copy_module_type :\n Ast_410.Parsetree.module_type -> Ast_409.Parsetree.module_type =\n fun {\n Ast_410.Parsetree.pmty_desc;\n Ast_410.Parsetree.pmty_loc;\n Ast_410.Parsetree.pmty_attributes;\n } ->\n {\n Ast_409.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_409.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_409.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_410.Parsetree.module_type_desc -> Ast_409.Parsetree.module_type_desc =\n function\n | Ast_410.Parsetree.Pmty_ident x0 ->\n Ast_409.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_410.Parsetree.Pmty_signature x0 ->\n Ast_409.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_410.Parsetree.Pmty_functor (x0, x1) ->\n let x, y = copy_functor_parameter x0 in\n Ast_409.Parsetree.Pmty_functor (x, y, copy_module_type x1)\n | Ast_410.Parsetree.Pmty_with (x0, x1) ->\n Ast_409.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_410.Parsetree.Pmty_typeof x0 ->\n Ast_409.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_410.Parsetree.Pmty_extension x0 ->\n Ast_409.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_410.Parsetree.Pmty_alias x0 ->\n Ast_409.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_410.Parsetree.with_constraint -> Ast_409.Parsetree.with_constraint =\n function\n | Ast_410.Parsetree.Pwith_type (x0, x1) ->\n Ast_409.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_410.Parsetree.Pwith_module (x0, x1) ->\n Ast_409.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_410.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_409.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_410.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_409.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_410.Parsetree.signature -> Ast_409.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_410.Parsetree.signature_item -> Ast_409.Parsetree.signature_item =\n fun { Ast_410.Parsetree.psig_desc; Ast_410.Parsetree.psig_loc } ->\n {\n Ast_409.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_409.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_410.Parsetree.signature_item_desc ->\n Ast_409.Parsetree.signature_item_desc = function\n | Ast_410.Parsetree.Psig_value x0 ->\n Ast_409.Parsetree.Psig_value (copy_value_description x0)\n | Ast_410.Parsetree.Psig_type (x0, x1) ->\n Ast_409.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_410.Parsetree.Psig_typesubst x0 ->\n Ast_409.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_410.Parsetree.Psig_typext x0 ->\n Ast_409.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_410.Parsetree.Psig_exception x0 ->\n Ast_409.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_410.Parsetree.Psig_module x0 ->\n Ast_409.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_410.Parsetree.Psig_modsubst x0 ->\n Ast_409.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_410.Parsetree.Psig_recmodule x0 ->\n Ast_409.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_410.Parsetree.Psig_modtype x0 ->\n Ast_409.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_410.Parsetree.Psig_open x0 ->\n Ast_409.Parsetree.Psig_open (copy_open_description x0)\n | Ast_410.Parsetree.Psig_include x0 ->\n Ast_409.Parsetree.Psig_include (copy_include_description x0)\n | Ast_410.Parsetree.Psig_class x0 ->\n Ast_409.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_410.Parsetree.Psig_class_type x0 ->\n Ast_409.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_410.Parsetree.Psig_attribute x0 ->\n Ast_409.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Psig_extension (x0, x1) ->\n Ast_409.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_410.Parsetree.class_type_declaration ->\n Ast_409.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_410.Parsetree.class_description -> Ast_409.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_410.Parsetree.class_type -> Ast_409.Parsetree.class_type =\n fun {\n Ast_410.Parsetree.pcty_desc;\n Ast_410.Parsetree.pcty_loc;\n Ast_410.Parsetree.pcty_attributes;\n } ->\n {\n Ast_409.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_409.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_409.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_410.Parsetree.class_type_desc -> Ast_409.Parsetree.class_type_desc =\n function\n | Ast_410.Parsetree.Pcty_constr (x0, x1) ->\n Ast_409.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_410.Parsetree.Pcty_signature x0 ->\n Ast_409.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_410.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_409.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_410.Parsetree.Pcty_extension x0 ->\n Ast_409.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_410.Parsetree.Pcty_open (x0, x1) ->\n Ast_409.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_410.Parsetree.class_signature -> Ast_409.Parsetree.class_signature =\n fun { Ast_410.Parsetree.pcsig_self; Ast_410.Parsetree.pcsig_fields } ->\n {\n Ast_409.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_409.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_410.Parsetree.class_type_field -> Ast_409.Parsetree.class_type_field =\n fun {\n Ast_410.Parsetree.pctf_desc;\n Ast_410.Parsetree.pctf_loc;\n Ast_410.Parsetree.pctf_attributes;\n } ->\n {\n Ast_409.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_409.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_409.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_410.Parsetree.class_type_field_desc ->\n Ast_409.Parsetree.class_type_field_desc = function\n | Ast_410.Parsetree.Pctf_inherit x0 ->\n Ast_409.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_410.Parsetree.Pctf_val x0 ->\n Ast_409.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_410.Parsetree.Pctf_method x0 ->\n Ast_409.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_410.Parsetree.Pctf_constraint x0 ->\n Ast_409.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_410.Parsetree.Pctf_attribute x0 ->\n Ast_409.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_410.Parsetree.Pctf_extension x0 ->\n Ast_409.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_410.Parsetree.extension -> Ast_409.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.class_infos ->\n 'g0 Ast_409.Parsetree.class_infos =\n fun f0\n {\n Ast_410.Parsetree.pci_virt;\n Ast_410.Parsetree.pci_params;\n Ast_410.Parsetree.pci_name;\n Ast_410.Parsetree.pci_expr;\n Ast_410.Parsetree.pci_loc;\n Ast_410.Parsetree.pci_attributes;\n } ->\n {\n Ast_409.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_409.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_409.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_409.Parsetree.pci_expr = f0 pci_expr;\n Ast_409.Parsetree.pci_loc = copy_location pci_loc;\n Ast_409.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_410.Asttypes.virtual_flag -> Ast_409.Asttypes.virtual_flag = function\n | Ast_410.Asttypes.Virtual -> Ast_409.Asttypes.Virtual\n | Ast_410.Asttypes.Concrete -> Ast_409.Asttypes.Concrete\n\nand copy_include_description :\n Ast_410.Parsetree.include_description ->\n Ast_409.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.include_infos ->\n 'g0 Ast_409.Parsetree.include_infos =\n fun f0\n {\n Ast_410.Parsetree.pincl_mod;\n Ast_410.Parsetree.pincl_loc;\n Ast_410.Parsetree.pincl_attributes;\n } ->\n {\n Ast_409.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_409.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_409.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_410.Parsetree.open_description -> Ast_409.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_410.Parsetree.open_infos ->\n 'g0 Ast_409.Parsetree.open_infos =\n fun f0\n {\n Ast_410.Parsetree.popen_expr;\n Ast_410.Parsetree.popen_override;\n Ast_410.Parsetree.popen_loc;\n Ast_410.Parsetree.popen_attributes;\n } ->\n {\n Ast_409.Parsetree.popen_expr = f0 popen_expr;\n Ast_409.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_409.Parsetree.popen_loc = copy_location popen_loc;\n Ast_409.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_410.Asttypes.override_flag -> Ast_409.Asttypes.override_flag = function\n | Ast_410.Asttypes.Override -> Ast_409.Asttypes.Override\n | Ast_410.Asttypes.Fresh -> Ast_409.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_410.Parsetree.module_type_declaration ->\n Ast_409.Parsetree.module_type_declaration =\n fun {\n Ast_410.Parsetree.pmtd_name;\n Ast_410.Parsetree.pmtd_type;\n Ast_410.Parsetree.pmtd_attributes;\n Ast_410.Parsetree.pmtd_loc;\n } ->\n {\n Ast_409.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_409.Parsetree.pmtd_type = map_option copy_module_type pmtd_type;\n Ast_409.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_409.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_410.Parsetree.module_substitution ->\n Ast_409.Parsetree.module_substitution =\n fun {\n Ast_410.Parsetree.pms_name;\n Ast_410.Parsetree.pms_manifest;\n Ast_410.Parsetree.pms_attributes;\n Ast_410.Parsetree.pms_loc;\n } ->\n {\n Ast_409.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_409.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_409.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_409.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_410.Parsetree.module_declaration -> Ast_409.Parsetree.module_declaration\n =\n fun {\n Ast_410.Parsetree.pmd_name;\n Ast_410.Parsetree.pmd_type;\n Ast_410.Parsetree.pmd_attributes;\n Ast_410.Parsetree.pmd_loc;\n } ->\n {\n Ast_409.Parsetree.pmd_name =\n copy_loc\n (function\n | None -> migration_error pmd_name.loc \"anonymous module declaration\"\n | Some x -> x)\n pmd_name;\n Ast_409.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_409.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_409.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_410.Parsetree.type_exception -> Ast_409.Parsetree.type_exception =\n fun {\n Ast_410.Parsetree.ptyexn_constructor;\n Ast_410.Parsetree.ptyexn_loc;\n Ast_410.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_409.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_409.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_410.Parsetree.type_extension -> Ast_409.Parsetree.type_extension =\n fun {\n Ast_410.Parsetree.ptyext_path;\n Ast_410.Parsetree.ptyext_params;\n Ast_410.Parsetree.ptyext_constructors;\n Ast_410.Parsetree.ptyext_private;\n Ast_410.Parsetree.ptyext_loc;\n Ast_410.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_409.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_409.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_409.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_409.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_409.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_410.Parsetree.extension_constructor ->\n Ast_409.Parsetree.extension_constructor =\n fun {\n Ast_410.Parsetree.pext_name;\n Ast_410.Parsetree.pext_kind;\n Ast_410.Parsetree.pext_loc;\n Ast_410.Parsetree.pext_attributes;\n } ->\n {\n Ast_409.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_409.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_409.Parsetree.pext_loc = copy_location pext_loc;\n Ast_409.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_410.Parsetree.extension_constructor_kind ->\n Ast_409.Parsetree.extension_constructor_kind = function\n | Ast_410.Parsetree.Pext_decl (x0, x1) ->\n Ast_409.Parsetree.Pext_decl\n (copy_constructor_arguments x0, map_option copy_core_type x1)\n | Ast_410.Parsetree.Pext_rebind x0 ->\n Ast_409.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_410.Parsetree.type_declaration -> Ast_409.Parsetree.type_declaration =\n fun {\n Ast_410.Parsetree.ptype_name;\n Ast_410.Parsetree.ptype_params;\n Ast_410.Parsetree.ptype_cstrs;\n Ast_410.Parsetree.ptype_kind;\n Ast_410.Parsetree.ptype_private;\n Ast_410.Parsetree.ptype_manifest;\n Ast_410.Parsetree.ptype_attributes;\n Ast_410.Parsetree.ptype_loc;\n } ->\n {\n Ast_409.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_409.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_409.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_409.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_409.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_409.Parsetree.ptype_manifest = map_option copy_core_type ptype_manifest;\n Ast_409.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_409.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_410.Asttypes.private_flag -> Ast_409.Asttypes.private_flag = function\n | Ast_410.Asttypes.Private -> Ast_409.Asttypes.Private\n | Ast_410.Asttypes.Public -> Ast_409.Asttypes.Public\n\nand copy_type_kind : Ast_410.Parsetree.type_kind -> Ast_409.Parsetree.type_kind\n = function\n | Ast_410.Parsetree.Ptype_abstract -> Ast_409.Parsetree.Ptype_abstract\n | Ast_410.Parsetree.Ptype_variant x0 ->\n Ast_409.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_410.Parsetree.Ptype_record x0 ->\n Ast_409.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_410.Parsetree.Ptype_open -> Ast_409.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_410.Parsetree.constructor_declaration ->\n Ast_409.Parsetree.constructor_declaration =\n fun {\n Ast_410.Parsetree.pcd_name;\n Ast_410.Parsetree.pcd_args;\n Ast_410.Parsetree.pcd_res;\n Ast_410.Parsetree.pcd_loc;\n Ast_410.Parsetree.pcd_attributes;\n } ->\n {\n Ast_409.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_409.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_409.Parsetree.pcd_res = map_option copy_core_type pcd_res;\n Ast_409.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_409.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_410.Parsetree.constructor_arguments ->\n Ast_409.Parsetree.constructor_arguments = function\n | Ast_410.Parsetree.Pcstr_tuple x0 ->\n Ast_409.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_410.Parsetree.Pcstr_record x0 ->\n Ast_409.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_410.Parsetree.label_declaration -> Ast_409.Parsetree.label_declaration =\n fun {\n Ast_410.Parsetree.pld_name;\n Ast_410.Parsetree.pld_mutable;\n Ast_410.Parsetree.pld_type;\n Ast_410.Parsetree.pld_loc;\n Ast_410.Parsetree.pld_attributes;\n } ->\n {\n Ast_409.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_409.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_409.Parsetree.pld_type = copy_core_type pld_type;\n Ast_409.Parsetree.pld_loc = copy_location pld_loc;\n Ast_409.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_410.Asttypes.mutable_flag -> Ast_409.Asttypes.mutable_flag = function\n | Ast_410.Asttypes.Immutable -> Ast_409.Asttypes.Immutable\n | Ast_410.Asttypes.Mutable -> Ast_409.Asttypes.Mutable\n\nand copy_variance : Ast_410.Asttypes.variance -> Ast_409.Asttypes.variance =\n function\n | Ast_410.Asttypes.Covariant -> Ast_409.Asttypes.Covariant\n | Ast_410.Asttypes.Contravariant -> Ast_409.Asttypes.Contravariant\n | Ast_410.Asttypes.Invariant -> Ast_409.Asttypes.Invariant\n\nand copy_value_description :\n Ast_410.Parsetree.value_description -> Ast_409.Parsetree.value_description =\n fun {\n Ast_410.Parsetree.pval_name;\n Ast_410.Parsetree.pval_type;\n Ast_410.Parsetree.pval_prim;\n Ast_410.Parsetree.pval_attributes;\n Ast_410.Parsetree.pval_loc;\n } ->\n {\n Ast_409.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_409.Parsetree.pval_type = copy_core_type pval_type;\n Ast_409.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_409.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_409.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_410.Parsetree.object_field_desc -> Ast_409.Parsetree.object_field_desc =\n function\n | Ast_410.Parsetree.Otag (x0, x1) ->\n Ast_409.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_410.Parsetree.Oinherit x0 ->\n Ast_409.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_410.Asttypes.arg_label -> Ast_409.Asttypes.arg_label =\n function\n | Ast_410.Asttypes.Nolabel -> Ast_409.Asttypes.Nolabel\n | Ast_410.Asttypes.Labelled x0 -> Ast_409.Asttypes.Labelled x0\n | Ast_410.Asttypes.Optional x0 -> Ast_409.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_410.Asttypes.closed_flag -> Ast_409.Asttypes.closed_flag = function\n | Ast_410.Asttypes.Closed -> Ast_409.Asttypes.Closed\n | Ast_410.Asttypes.Open -> Ast_409.Asttypes.Open\n\nand copy_label : Ast_410.Asttypes.label -> Ast_409.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_410.Asttypes.rec_flag -> Ast_409.Asttypes.rec_flag =\n function\n | Ast_410.Asttypes.Nonrecursive -> Ast_409.Asttypes.Nonrecursive\n | Ast_410.Asttypes.Recursive -> Ast_409.Asttypes.Recursive\n\nand copy_constant : Ast_410.Parsetree.constant -> Ast_409.Parsetree.constant =\n function\n | Ast_410.Parsetree.Pconst_integer (x0, x1) ->\n Ast_409.Parsetree.Pconst_integer (x0, map_option (fun x -> x) x1)\n | Ast_410.Parsetree.Pconst_char x0 -> Ast_409.Parsetree.Pconst_char x0\n | Ast_410.Parsetree.Pconst_string (x0, x1) ->\n Ast_409.Parsetree.Pconst_string (x0, map_option (fun x -> x) x1)\n | Ast_410.Parsetree.Pconst_float (x0, x1) ->\n Ast_409.Parsetree.Pconst_float (x0, map_option (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_410.Asttypes.loc -> 'g0 Ast_409.Asttypes.loc =\n fun f0 { Ast_410.Asttypes.txt; Ast_410.Asttypes.loc } ->\n { Ast_409.Asttypes.txt = f0 txt; Ast_409.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n\nlet copy_expr = copy_expression\nlet copy_pat = copy_pattern\nlet copy_typ = copy_core_type\n","module From = Ast_409\nmodule To = Ast_410\n\nlet map_option f x = match x with None -> None | Some x -> Some (f x)\n\nlet rec copy_toplevel_phrase :\n Ast_409.Parsetree.toplevel_phrase -> Ast_410.Parsetree.toplevel_phrase =\n function\n | Ast_409.Parsetree.Ptop_def x0 ->\n Ast_410.Parsetree.Ptop_def (copy_structure x0)\n | Ast_409.Parsetree.Ptop_dir x0 ->\n Ast_410.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_409.Parsetree.toplevel_directive -> Ast_410.Parsetree.toplevel_directive\n =\n fun {\n Ast_409.Parsetree.pdir_name;\n Ast_409.Parsetree.pdir_arg;\n Ast_409.Parsetree.pdir_loc;\n } ->\n {\n Ast_410.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_410.Parsetree.pdir_arg = map_option copy_directive_argument pdir_arg;\n Ast_410.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_409.Parsetree.directive_argument -> Ast_410.Parsetree.directive_argument\n =\n fun { Ast_409.Parsetree.pdira_desc; Ast_409.Parsetree.pdira_loc } ->\n {\n Ast_410.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_410.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_409.Parsetree.directive_argument_desc ->\n Ast_410.Parsetree.directive_argument_desc = function\n | Ast_409.Parsetree.Pdir_string x0 -> Ast_410.Parsetree.Pdir_string x0\n | Ast_409.Parsetree.Pdir_int (x0, x1) ->\n Ast_410.Parsetree.Pdir_int (x0, map_option (fun x -> x) x1)\n | Ast_409.Parsetree.Pdir_ident x0 ->\n Ast_410.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_409.Parsetree.Pdir_bool x0 -> Ast_410.Parsetree.Pdir_bool x0\n\nand copy_expression :\n Ast_409.Parsetree.expression -> Ast_410.Parsetree.expression =\n fun {\n Ast_409.Parsetree.pexp_desc;\n Ast_409.Parsetree.pexp_loc;\n Ast_409.Parsetree.pexp_loc_stack;\n Ast_409.Parsetree.pexp_attributes;\n } ->\n {\n Ast_410.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_410.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_410.Parsetree.pexp_loc_stack = List.map copy_location pexp_loc_stack;\n Ast_410.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_409.Parsetree.expression_desc -> Ast_410.Parsetree.expression_desc =\n function\n | Ast_409.Parsetree.Pexp_ident x0 ->\n Ast_410.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pexp_constant x0 ->\n Ast_410.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_409.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_function x0 ->\n Ast_410.Parsetree.Pexp_function (copy_cases x0)\n | Ast_409.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_410.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n map_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_409.Parsetree.Pexp_apply (x0, x1) ->\n Ast_410.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_409.Parsetree.Pexp_match (x0, x1) ->\n Ast_410.Parsetree.Pexp_match (copy_expression x0, copy_cases x1)\n | Ast_409.Parsetree.Pexp_try (x0, x1) ->\n Ast_410.Parsetree.Pexp_try (copy_expression x0, copy_cases x1)\n | Ast_409.Parsetree.Pexp_tuple x0 ->\n Ast_410.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_409.Parsetree.Pexp_construct (x0, x1) ->\n Ast_410.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, map_option copy_expression x1)\n | Ast_409.Parsetree.Pexp_variant (x0, x1) ->\n Ast_410.Parsetree.Pexp_variant\n (copy_label x0, map_option copy_expression x1)\n | Ast_409.Parsetree.Pexp_record (x0, x1) ->\n Ast_410.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n map_option copy_expression x1 )\n | Ast_409.Parsetree.Pexp_field (x0, x1) ->\n Ast_410.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_409.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_array x0 ->\n Ast_410.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_409.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, map_option copy_expression x2)\n | Ast_409.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_410.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_while (x0, x1) ->\n Ast_410.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_410.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_409.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_410.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_409.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_coerce\n (copy_expression x0, map_option copy_core_type x1, copy_core_type x2)\n | Ast_409.Parsetree.Pexp_send (x0, x1) ->\n Ast_410.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_409.Parsetree.Pexp_new x0 ->\n Ast_410.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_410.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_override x0 ->\n Ast_410.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_409.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_410.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> Some x) x0, copy_module_expr x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_410.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_assert x0 ->\n Ast_410.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_409.Parsetree.Pexp_lazy x0 ->\n Ast_410.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_409.Parsetree.Pexp_poly (x0, x1) ->\n Ast_410.Parsetree.Pexp_poly\n (copy_expression x0, map_option copy_core_type x1)\n | Ast_409.Parsetree.Pexp_object x0 ->\n Ast_410.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_409.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_410.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_pack x0 ->\n Ast_410.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_409.Parsetree.Pexp_open (x0, x1) ->\n Ast_410.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_letop x0 ->\n Ast_410.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_409.Parsetree.Pexp_extension x0 ->\n Ast_410.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_409.Parsetree.Pexp_unreachable -> Ast_410.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_409.Parsetree.letop -> Ast_410.Parsetree.letop =\n fun { Ast_409.Parsetree.let_; Ast_409.Parsetree.ands; Ast_409.Parsetree.body } ->\n {\n Ast_410.Parsetree.let_ = copy_binding_op let_;\n Ast_410.Parsetree.ands = List.map copy_binding_op ands;\n Ast_410.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_409.Parsetree.binding_op -> Ast_410.Parsetree.binding_op =\n fun {\n Ast_409.Parsetree.pbop_op;\n Ast_409.Parsetree.pbop_pat;\n Ast_409.Parsetree.pbop_exp;\n Ast_409.Parsetree.pbop_loc;\n } ->\n {\n Ast_410.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_410.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_410.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_410.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_409.Asttypes.direction_flag -> Ast_410.Asttypes.direction_flag =\n function\n | Ast_409.Asttypes.Upto -> Ast_410.Asttypes.Upto\n | Ast_409.Asttypes.Downto -> Ast_410.Asttypes.Downto\n\nand copy_cases : Ast_409.Parsetree.cases -> Ast_410.Parsetree.case list =\n fun x -> List.map copy_case x\n\nand copy_case : Ast_409.Parsetree.case -> Ast_410.Parsetree.case =\n fun {\n Ast_409.Parsetree.pc_lhs;\n Ast_409.Parsetree.pc_guard;\n Ast_409.Parsetree.pc_rhs;\n } ->\n {\n Ast_410.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_410.Parsetree.pc_guard = map_option copy_expression pc_guard;\n Ast_410.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_409.Parsetree.value_binding -> Ast_410.Parsetree.value_binding =\n fun {\n Ast_409.Parsetree.pvb_pat;\n Ast_409.Parsetree.pvb_expr;\n Ast_409.Parsetree.pvb_attributes;\n Ast_409.Parsetree.pvb_loc;\n } ->\n {\n Ast_410.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_410.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_410.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_410.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_409.Parsetree.pattern -> Ast_410.Parsetree.pattern =\n fun {\n Ast_409.Parsetree.ppat_desc;\n Ast_409.Parsetree.ppat_loc;\n Ast_409.Parsetree.ppat_loc_stack;\n Ast_409.Parsetree.ppat_attributes;\n } ->\n {\n Ast_410.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_410.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_410.Parsetree.ppat_loc_stack = List.map copy_location ppat_loc_stack;\n Ast_410.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_409.Parsetree.pattern_desc -> Ast_410.Parsetree.pattern_desc = function\n | Ast_409.Parsetree.Ppat_any -> Ast_410.Parsetree.Ppat_any\n | Ast_409.Parsetree.Ppat_var x0 ->\n Ast_410.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_409.Parsetree.Ppat_alias (x0, x1) ->\n Ast_410.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_409.Parsetree.Ppat_constant x0 ->\n Ast_410.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_409.Parsetree.Ppat_interval (x0, x1) ->\n Ast_410.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_409.Parsetree.Ppat_tuple x0 ->\n Ast_410.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_409.Parsetree.Ppat_construct (x0, x1) ->\n Ast_410.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, map_option copy_pattern x1)\n | Ast_409.Parsetree.Ppat_variant (x0, x1) ->\n Ast_410.Parsetree.Ppat_variant (copy_label x0, map_option copy_pattern x1)\n | Ast_409.Parsetree.Ppat_record (x0, x1) ->\n Ast_410.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_409.Parsetree.Ppat_array x0 ->\n Ast_410.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_409.Parsetree.Ppat_or (x0, x1) ->\n Ast_410.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_409.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_410.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_409.Parsetree.Ppat_type x0 ->\n Ast_410.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Ppat_lazy x0 ->\n Ast_410.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_409.Parsetree.Ppat_unpack x0 ->\n Ast_410.Parsetree.Ppat_unpack (copy_loc (fun x -> Some x) x0)\n | Ast_409.Parsetree.Ppat_exception x0 ->\n Ast_410.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_409.Parsetree.Ppat_extension x0 ->\n Ast_410.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_409.Parsetree.Ppat_open (x0, x1) ->\n Ast_410.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_409.Parsetree.core_type -> Ast_410.Parsetree.core_type\n =\n fun {\n Ast_409.Parsetree.ptyp_desc;\n Ast_409.Parsetree.ptyp_loc;\n Ast_409.Parsetree.ptyp_loc_stack;\n Ast_409.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_410.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_410.Parsetree.ptyp_loc_stack = List.map copy_location ptyp_loc_stack;\n Ast_410.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n Ast_409.Parsetree.core_type_desc -> Ast_410.Parsetree.core_type_desc =\n function\n | Ast_409.Parsetree.Ptyp_any -> Ast_410.Parsetree.Ptyp_any\n | Ast_409.Parsetree.Ptyp_var x0 -> Ast_410.Parsetree.Ptyp_var x0\n | Ast_409.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_410.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_409.Parsetree.Ptyp_tuple x0 ->\n Ast_410.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_409.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_410.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_object (x0, x1) ->\n Ast_410.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_409.Parsetree.Ptyp_class (x0, x1) ->\n Ast_410.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_410.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_409.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_410.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n map_option (fun x -> List.map copy_label x) x2 )\n | Ast_409.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_410.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_package x0 ->\n Ast_410.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_409.Parsetree.Ptyp_extension x0 ->\n Ast_410.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_409.Parsetree.package_type -> Ast_410.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_409.Parsetree.row_field -> Ast_410.Parsetree.row_field\n =\n fun {\n Ast_409.Parsetree.prf_desc;\n Ast_409.Parsetree.prf_loc;\n Ast_409.Parsetree.prf_attributes;\n } ->\n {\n Ast_410.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_410.Parsetree.prf_loc = copy_location prf_loc;\n Ast_410.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_409.Parsetree.row_field_desc -> Ast_410.Parsetree.row_field_desc =\n function\n | Ast_409.Parsetree.Rtag (x0, x1, x2) ->\n Ast_410.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_409.Parsetree.Rinherit x0 ->\n Ast_410.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_409.Parsetree.object_field -> Ast_410.Parsetree.object_field =\n fun {\n Ast_409.Parsetree.pof_desc;\n Ast_409.Parsetree.pof_loc;\n Ast_409.Parsetree.pof_attributes;\n } ->\n {\n Ast_410.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_410.Parsetree.pof_loc = copy_location pof_loc;\n Ast_410.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_409.Parsetree.attributes -> Ast_410.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_409.Parsetree.attribute -> Ast_410.Parsetree.attribute\n =\n fun {\n Ast_409.Parsetree.attr_name;\n Ast_409.Parsetree.attr_payload;\n Ast_409.Parsetree.attr_loc;\n } ->\n {\n Ast_410.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_410.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_410.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_409.Parsetree.payload -> Ast_410.Parsetree.payload =\n function\n | Ast_409.Parsetree.PStr x0 -> Ast_410.Parsetree.PStr (copy_structure x0)\n | Ast_409.Parsetree.PSig x0 -> Ast_410.Parsetree.PSig (copy_signature x0)\n | Ast_409.Parsetree.PTyp x0 -> Ast_410.Parsetree.PTyp (copy_core_type x0)\n | Ast_409.Parsetree.PPat (x0, x1) ->\n Ast_410.Parsetree.PPat (copy_pattern x0, map_option copy_expression x1)\n\nand copy_structure : Ast_409.Parsetree.structure -> Ast_410.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_409.Parsetree.structure_item -> Ast_410.Parsetree.structure_item =\n fun { Ast_409.Parsetree.pstr_desc; Ast_409.Parsetree.pstr_loc } ->\n {\n Ast_410.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_410.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_409.Parsetree.structure_item_desc ->\n Ast_410.Parsetree.structure_item_desc = function\n | Ast_409.Parsetree.Pstr_eval (x0, x1) ->\n Ast_410.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_409.Parsetree.Pstr_value (x0, x1) ->\n Ast_410.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_409.Parsetree.Pstr_primitive x0 ->\n Ast_410.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_409.Parsetree.Pstr_type (x0, x1) ->\n Ast_410.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_409.Parsetree.Pstr_typext x0 ->\n Ast_410.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_409.Parsetree.Pstr_exception x0 ->\n Ast_410.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_409.Parsetree.Pstr_module x0 ->\n Ast_410.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_409.Parsetree.Pstr_recmodule x0 ->\n Ast_410.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_409.Parsetree.Pstr_modtype x0 ->\n Ast_410.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_409.Parsetree.Pstr_open x0 ->\n Ast_410.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_409.Parsetree.Pstr_class x0 ->\n Ast_410.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_409.Parsetree.Pstr_class_type x0 ->\n Ast_410.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_409.Parsetree.Pstr_include x0 ->\n Ast_410.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_409.Parsetree.Pstr_attribute x0 ->\n Ast_410.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pstr_extension (x0, x1) ->\n Ast_410.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_409.Parsetree.include_declaration ->\n Ast_410.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_409.Parsetree.class_declaration -> Ast_410.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_409.Parsetree.class_expr -> Ast_410.Parsetree.class_expr =\n fun {\n Ast_409.Parsetree.pcl_desc;\n Ast_409.Parsetree.pcl_loc;\n Ast_409.Parsetree.pcl_attributes;\n } ->\n {\n Ast_410.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_410.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_410.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_409.Parsetree.class_expr_desc -> Ast_410.Parsetree.class_expr_desc =\n function\n | Ast_409.Parsetree.Pcl_constr (x0, x1) ->\n Ast_410.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Pcl_structure x0 ->\n Ast_410.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_409.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_410.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n map_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_409.Parsetree.Pcl_apply (x0, x1) ->\n Ast_410.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_409.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_410.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_409.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_410.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_409.Parsetree.Pcl_extension x0 ->\n Ast_410.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_409.Parsetree.Pcl_open (x0, x1) ->\n Ast_410.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_409.Parsetree.class_structure -> Ast_410.Parsetree.class_structure =\n fun { Ast_409.Parsetree.pcstr_self; Ast_409.Parsetree.pcstr_fields } ->\n {\n Ast_410.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_410.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_409.Parsetree.class_field -> Ast_410.Parsetree.class_field =\n fun {\n Ast_409.Parsetree.pcf_desc;\n Ast_409.Parsetree.pcf_loc;\n Ast_409.Parsetree.pcf_attributes;\n } ->\n {\n Ast_410.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_410.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_410.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_409.Parsetree.class_field_desc -> Ast_410.Parsetree.class_field_desc =\n function\n | Ast_409.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_410.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n map_option (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_409.Parsetree.Pcf_val x0 ->\n Ast_410.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_409.Parsetree.Pcf_method x0 ->\n Ast_410.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_409.Parsetree.Pcf_constraint x0 ->\n Ast_410.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_409.Parsetree.Pcf_initializer x0 ->\n Ast_410.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_409.Parsetree.Pcf_attribute x0 ->\n Ast_410.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pcf_extension x0 ->\n Ast_410.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_409.Parsetree.class_field_kind -> Ast_410.Parsetree.class_field_kind =\n function\n | Ast_409.Parsetree.Cfk_virtual x0 ->\n Ast_410.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_409.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_410.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_409.Parsetree.open_declaration -> Ast_410.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_409.Parsetree.module_binding -> Ast_410.Parsetree.module_binding =\n fun {\n Ast_409.Parsetree.pmb_name;\n Ast_409.Parsetree.pmb_expr;\n Ast_409.Parsetree.pmb_attributes;\n Ast_409.Parsetree.pmb_loc;\n } ->\n {\n Ast_410.Parsetree.pmb_name = copy_loc (fun x -> Some x) pmb_name;\n Ast_410.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_410.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_410.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_409.Parsetree.module_expr -> Ast_410.Parsetree.module_expr =\n fun {\n Ast_409.Parsetree.pmod_desc;\n Ast_409.Parsetree.pmod_loc;\n Ast_409.Parsetree.pmod_attributes;\n } ->\n {\n Ast_410.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_410.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_410.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_409.Parsetree.module_expr_desc -> Ast_410.Parsetree.module_expr_desc =\n function\n | Ast_409.Parsetree.Pmod_ident x0 ->\n Ast_410.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pmod_structure x0 ->\n Ast_410.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_409.Parsetree.Pmod_functor (x0, x1, x2) ->\n Ast_410.Parsetree.Pmod_functor\n ( (match (x0.txt, x1) with\n | \"*\", None -> Unit\n | \"_\", Some mt ->\n Named (copy_loc (fun _ -> None) x0, copy_module_type mt)\n | _, Some mt ->\n Named (copy_loc (fun x -> Some x) x0, copy_module_type mt)\n | _ -> assert false),\n copy_module_expr x2 )\n | Ast_409.Parsetree.Pmod_apply (x0, x1) ->\n Ast_410.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_409.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_410.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_409.Parsetree.Pmod_unpack x0 ->\n Ast_410.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_409.Parsetree.Pmod_extension x0 ->\n Ast_410.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type :\n Ast_409.Parsetree.module_type -> Ast_410.Parsetree.module_type =\n fun {\n Ast_409.Parsetree.pmty_desc;\n Ast_409.Parsetree.pmty_loc;\n Ast_409.Parsetree.pmty_attributes;\n } ->\n {\n Ast_410.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_410.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_410.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_409.Parsetree.module_type_desc -> Ast_410.Parsetree.module_type_desc =\n function\n | Ast_409.Parsetree.Pmty_ident x0 ->\n Ast_410.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pmty_signature x0 ->\n Ast_410.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_409.Parsetree.Pmty_functor (x0, x1, x2) ->\n Ast_410.Parsetree.Pmty_functor\n ( (match (x0.txt, x1) with\n | \"*\", None -> Unit\n | \"_\", Some mt ->\n Named (copy_loc (fun _ -> None) x0, copy_module_type mt)\n | _, Some mt ->\n Named (copy_loc (fun x -> Some x) x0, copy_module_type mt)\n | _ -> assert false),\n copy_module_type x2 )\n | Ast_409.Parsetree.Pmty_with (x0, x1) ->\n Ast_410.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_409.Parsetree.Pmty_typeof x0 ->\n Ast_410.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_409.Parsetree.Pmty_extension x0 ->\n Ast_410.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_409.Parsetree.Pmty_alias x0 ->\n Ast_410.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_409.Parsetree.with_constraint -> Ast_410.Parsetree.with_constraint =\n function\n | Ast_409.Parsetree.Pwith_type (x0, x1) ->\n Ast_410.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_409.Parsetree.Pwith_module (x0, x1) ->\n Ast_410.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_409.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_410.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_409.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_410.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_409.Parsetree.signature -> Ast_410.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_409.Parsetree.signature_item -> Ast_410.Parsetree.signature_item =\n fun { Ast_409.Parsetree.psig_desc; Ast_409.Parsetree.psig_loc } ->\n {\n Ast_410.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_410.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_409.Parsetree.signature_item_desc ->\n Ast_410.Parsetree.signature_item_desc = function\n | Ast_409.Parsetree.Psig_value x0 ->\n Ast_410.Parsetree.Psig_value (copy_value_description x0)\n | Ast_409.Parsetree.Psig_type (x0, x1) ->\n Ast_410.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_409.Parsetree.Psig_typesubst x0 ->\n Ast_410.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_409.Parsetree.Psig_typext x0 ->\n Ast_410.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_409.Parsetree.Psig_exception x0 ->\n Ast_410.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_409.Parsetree.Psig_module x0 ->\n Ast_410.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_409.Parsetree.Psig_modsubst x0 ->\n Ast_410.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_409.Parsetree.Psig_recmodule x0 ->\n Ast_410.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_409.Parsetree.Psig_modtype x0 ->\n Ast_410.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_409.Parsetree.Psig_open x0 ->\n Ast_410.Parsetree.Psig_open (copy_open_description x0)\n | Ast_409.Parsetree.Psig_include x0 ->\n Ast_410.Parsetree.Psig_include (copy_include_description x0)\n | Ast_409.Parsetree.Psig_class x0 ->\n Ast_410.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_409.Parsetree.Psig_class_type x0 ->\n Ast_410.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_409.Parsetree.Psig_attribute x0 ->\n Ast_410.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Psig_extension (x0, x1) ->\n Ast_410.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_409.Parsetree.class_type_declaration ->\n Ast_410.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_409.Parsetree.class_description -> Ast_410.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_409.Parsetree.class_type -> Ast_410.Parsetree.class_type =\n fun {\n Ast_409.Parsetree.pcty_desc;\n Ast_409.Parsetree.pcty_loc;\n Ast_409.Parsetree.pcty_attributes;\n } ->\n {\n Ast_410.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_410.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_410.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_409.Parsetree.class_type_desc -> Ast_410.Parsetree.class_type_desc =\n function\n | Ast_409.Parsetree.Pcty_constr (x0, x1) ->\n Ast_410.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Pcty_signature x0 ->\n Ast_410.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_409.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_410.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_409.Parsetree.Pcty_extension x0 ->\n Ast_410.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_409.Parsetree.Pcty_open (x0, x1) ->\n Ast_410.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_409.Parsetree.class_signature -> Ast_410.Parsetree.class_signature =\n fun { Ast_409.Parsetree.pcsig_self; Ast_409.Parsetree.pcsig_fields } ->\n {\n Ast_410.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_410.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_409.Parsetree.class_type_field -> Ast_410.Parsetree.class_type_field =\n fun {\n Ast_409.Parsetree.pctf_desc;\n Ast_409.Parsetree.pctf_loc;\n Ast_409.Parsetree.pctf_attributes;\n } ->\n {\n Ast_410.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_410.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_410.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_409.Parsetree.class_type_field_desc ->\n Ast_410.Parsetree.class_type_field_desc = function\n | Ast_409.Parsetree.Pctf_inherit x0 ->\n Ast_410.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_409.Parsetree.Pctf_val x0 ->\n Ast_410.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_409.Parsetree.Pctf_method x0 ->\n Ast_410.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_409.Parsetree.Pctf_constraint x0 ->\n Ast_410.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_409.Parsetree.Pctf_attribute x0 ->\n Ast_410.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pctf_extension x0 ->\n Ast_410.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_409.Parsetree.extension -> Ast_410.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.class_infos ->\n 'g0 Ast_410.Parsetree.class_infos =\n fun f0\n {\n Ast_409.Parsetree.pci_virt;\n Ast_409.Parsetree.pci_params;\n Ast_409.Parsetree.pci_name;\n Ast_409.Parsetree.pci_expr;\n Ast_409.Parsetree.pci_loc;\n Ast_409.Parsetree.pci_attributes;\n } ->\n {\n Ast_410.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_410.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_410.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_410.Parsetree.pci_expr = f0 pci_expr;\n Ast_410.Parsetree.pci_loc = copy_location pci_loc;\n Ast_410.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_409.Asttypes.virtual_flag -> Ast_410.Asttypes.virtual_flag = function\n | Ast_409.Asttypes.Virtual -> Ast_410.Asttypes.Virtual\n | Ast_409.Asttypes.Concrete -> Ast_410.Asttypes.Concrete\n\nand copy_include_description :\n Ast_409.Parsetree.include_description ->\n Ast_410.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.include_infos ->\n 'g0 Ast_410.Parsetree.include_infos =\n fun f0\n {\n Ast_409.Parsetree.pincl_mod;\n Ast_409.Parsetree.pincl_loc;\n Ast_409.Parsetree.pincl_attributes;\n } ->\n {\n Ast_410.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_410.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_410.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_409.Parsetree.open_description -> Ast_410.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.open_infos ->\n 'g0 Ast_410.Parsetree.open_infos =\n fun f0\n {\n Ast_409.Parsetree.popen_expr;\n Ast_409.Parsetree.popen_override;\n Ast_409.Parsetree.popen_loc;\n Ast_409.Parsetree.popen_attributes;\n } ->\n {\n Ast_410.Parsetree.popen_expr = f0 popen_expr;\n Ast_410.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_410.Parsetree.popen_loc = copy_location popen_loc;\n Ast_410.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_409.Asttypes.override_flag -> Ast_410.Asttypes.override_flag = function\n | Ast_409.Asttypes.Override -> Ast_410.Asttypes.Override\n | Ast_409.Asttypes.Fresh -> Ast_410.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_409.Parsetree.module_type_declaration ->\n Ast_410.Parsetree.module_type_declaration =\n fun {\n Ast_409.Parsetree.pmtd_name;\n Ast_409.Parsetree.pmtd_type;\n Ast_409.Parsetree.pmtd_attributes;\n Ast_409.Parsetree.pmtd_loc;\n } ->\n {\n Ast_410.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_410.Parsetree.pmtd_type = map_option copy_module_type pmtd_type;\n Ast_410.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_410.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_409.Parsetree.module_substitution ->\n Ast_410.Parsetree.module_substitution =\n fun {\n Ast_409.Parsetree.pms_name;\n Ast_409.Parsetree.pms_manifest;\n Ast_409.Parsetree.pms_attributes;\n Ast_409.Parsetree.pms_loc;\n } ->\n {\n Ast_410.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_410.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_410.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_410.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_409.Parsetree.module_declaration -> Ast_410.Parsetree.module_declaration\n =\n fun {\n Ast_409.Parsetree.pmd_name;\n Ast_409.Parsetree.pmd_type;\n Ast_409.Parsetree.pmd_attributes;\n Ast_409.Parsetree.pmd_loc;\n } ->\n {\n Ast_410.Parsetree.pmd_name = copy_loc (fun x -> Some x) pmd_name;\n Ast_410.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_410.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_410.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_409.Parsetree.type_exception -> Ast_410.Parsetree.type_exception =\n fun {\n Ast_409.Parsetree.ptyexn_constructor;\n Ast_409.Parsetree.ptyexn_loc;\n Ast_409.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_410.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_410.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_409.Parsetree.type_extension -> Ast_410.Parsetree.type_extension =\n fun {\n Ast_409.Parsetree.ptyext_path;\n Ast_409.Parsetree.ptyext_params;\n Ast_409.Parsetree.ptyext_constructors;\n Ast_409.Parsetree.ptyext_private;\n Ast_409.Parsetree.ptyext_loc;\n Ast_409.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_410.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_410.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_410.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_410.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_410.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_410.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_409.Parsetree.extension_constructor ->\n Ast_410.Parsetree.extension_constructor =\n fun {\n Ast_409.Parsetree.pext_name;\n Ast_409.Parsetree.pext_kind;\n Ast_409.Parsetree.pext_loc;\n Ast_409.Parsetree.pext_attributes;\n } ->\n {\n Ast_410.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_410.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_410.Parsetree.pext_loc = copy_location pext_loc;\n Ast_410.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_409.Parsetree.extension_constructor_kind ->\n Ast_410.Parsetree.extension_constructor_kind = function\n | Ast_409.Parsetree.Pext_decl (x0, x1) ->\n Ast_410.Parsetree.Pext_decl\n (copy_constructor_arguments x0, map_option copy_core_type x1)\n | Ast_409.Parsetree.Pext_rebind x0 ->\n Ast_410.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_409.Parsetree.type_declaration -> Ast_410.Parsetree.type_declaration =\n fun {\n Ast_409.Parsetree.ptype_name;\n Ast_409.Parsetree.ptype_params;\n Ast_409.Parsetree.ptype_cstrs;\n Ast_409.Parsetree.ptype_kind;\n Ast_409.Parsetree.ptype_private;\n Ast_409.Parsetree.ptype_manifest;\n Ast_409.Parsetree.ptype_attributes;\n Ast_409.Parsetree.ptype_loc;\n } ->\n {\n Ast_410.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_410.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_410.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_410.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_410.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_410.Parsetree.ptype_manifest = map_option copy_core_type ptype_manifest;\n Ast_410.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_410.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_409.Asttypes.private_flag -> Ast_410.Asttypes.private_flag = function\n | Ast_409.Asttypes.Private -> Ast_410.Asttypes.Private\n | Ast_409.Asttypes.Public -> Ast_410.Asttypes.Public\n\nand copy_type_kind : Ast_409.Parsetree.type_kind -> Ast_410.Parsetree.type_kind\n = function\n | Ast_409.Parsetree.Ptype_abstract -> Ast_410.Parsetree.Ptype_abstract\n | Ast_409.Parsetree.Ptype_variant x0 ->\n Ast_410.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_409.Parsetree.Ptype_record x0 ->\n Ast_410.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_409.Parsetree.Ptype_open -> Ast_410.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_409.Parsetree.constructor_declaration ->\n Ast_410.Parsetree.constructor_declaration =\n fun {\n Ast_409.Parsetree.pcd_name;\n Ast_409.Parsetree.pcd_args;\n Ast_409.Parsetree.pcd_res;\n Ast_409.Parsetree.pcd_loc;\n Ast_409.Parsetree.pcd_attributes;\n } ->\n {\n Ast_410.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_410.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_410.Parsetree.pcd_res = map_option copy_core_type pcd_res;\n Ast_410.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_410.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_409.Parsetree.constructor_arguments ->\n Ast_410.Parsetree.constructor_arguments = function\n | Ast_409.Parsetree.Pcstr_tuple x0 ->\n Ast_410.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_409.Parsetree.Pcstr_record x0 ->\n Ast_410.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_409.Parsetree.label_declaration -> Ast_410.Parsetree.label_declaration =\n fun {\n Ast_409.Parsetree.pld_name;\n Ast_409.Parsetree.pld_mutable;\n Ast_409.Parsetree.pld_type;\n Ast_409.Parsetree.pld_loc;\n Ast_409.Parsetree.pld_attributes;\n } ->\n {\n Ast_410.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_410.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_410.Parsetree.pld_type = copy_core_type pld_type;\n Ast_410.Parsetree.pld_loc = copy_location pld_loc;\n Ast_410.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_409.Asttypes.mutable_flag -> Ast_410.Asttypes.mutable_flag = function\n | Ast_409.Asttypes.Immutable -> Ast_410.Asttypes.Immutable\n | Ast_409.Asttypes.Mutable -> Ast_410.Asttypes.Mutable\n\nand copy_variance : Ast_409.Asttypes.variance -> Ast_410.Asttypes.variance =\n function\n | Ast_409.Asttypes.Covariant -> Ast_410.Asttypes.Covariant\n | Ast_409.Asttypes.Contravariant -> Ast_410.Asttypes.Contravariant\n | Ast_409.Asttypes.Invariant -> Ast_410.Asttypes.Invariant\n\nand copy_value_description :\n Ast_409.Parsetree.value_description -> Ast_410.Parsetree.value_description =\n fun {\n Ast_409.Parsetree.pval_name;\n Ast_409.Parsetree.pval_type;\n Ast_409.Parsetree.pval_prim;\n Ast_409.Parsetree.pval_attributes;\n Ast_409.Parsetree.pval_loc;\n } ->\n {\n Ast_410.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_410.Parsetree.pval_type = copy_core_type pval_type;\n Ast_410.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_410.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_410.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_409.Parsetree.object_field_desc -> Ast_410.Parsetree.object_field_desc =\n function\n | Ast_409.Parsetree.Otag (x0, x1) ->\n Ast_410.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_409.Parsetree.Oinherit x0 ->\n Ast_410.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_409.Asttypes.arg_label -> Ast_410.Asttypes.arg_label =\n function\n | Ast_409.Asttypes.Nolabel -> Ast_410.Asttypes.Nolabel\n | Ast_409.Asttypes.Labelled x0 -> Ast_410.Asttypes.Labelled x0\n | Ast_409.Asttypes.Optional x0 -> Ast_410.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_409.Asttypes.closed_flag -> Ast_410.Asttypes.closed_flag = function\n | Ast_409.Asttypes.Closed -> Ast_410.Asttypes.Closed\n | Ast_409.Asttypes.Open -> Ast_410.Asttypes.Open\n\nand copy_label : Ast_409.Asttypes.label -> Ast_410.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_409.Asttypes.rec_flag -> Ast_410.Asttypes.rec_flag =\n function\n | Ast_409.Asttypes.Nonrecursive -> Ast_410.Asttypes.Nonrecursive\n | Ast_409.Asttypes.Recursive -> Ast_410.Asttypes.Recursive\n\nand copy_constant : Ast_409.Parsetree.constant -> Ast_410.Parsetree.constant =\n function\n | Ast_409.Parsetree.Pconst_integer (x0, x1) ->\n Ast_410.Parsetree.Pconst_integer (x0, map_option (fun x -> x) x1)\n | Ast_409.Parsetree.Pconst_char x0 -> Ast_410.Parsetree.Pconst_char x0\n | Ast_409.Parsetree.Pconst_string (x0, x1) ->\n Ast_410.Parsetree.Pconst_string (x0, map_option (fun x -> x) x1)\n | Ast_409.Parsetree.Pconst_float (x0, x1) ->\n Ast_410.Parsetree.Pconst_float (x0, map_option (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_409.Asttypes.loc -> 'g0 Ast_410.Asttypes.loc =\n fun f0 { Ast_409.Asttypes.txt; Ast_409.Asttypes.loc } ->\n { Ast_410.Asttypes.txt = f0 txt; Ast_410.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n\nlet copy_expr = copy_expression\nlet copy_pat = copy_pattern\nlet copy_typ = copy_core_type\n","open Stdlib0\nmodule From = Ast_409\nmodule To = Ast_408\n\nlet rec copy_toplevel_phrase :\n Ast_409.Parsetree.toplevel_phrase -> Ast_408.Parsetree.toplevel_phrase =\n function\n | Ast_409.Parsetree.Ptop_def x0 ->\n Ast_408.Parsetree.Ptop_def (copy_structure x0)\n | Ast_409.Parsetree.Ptop_dir x0 ->\n Ast_408.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_409.Parsetree.toplevel_directive -> Ast_408.Parsetree.toplevel_directive\n =\n fun {\n Ast_409.Parsetree.pdir_name;\n Ast_409.Parsetree.pdir_arg;\n Ast_409.Parsetree.pdir_loc;\n } ->\n {\n Ast_408.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_408.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_408.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_409.Parsetree.directive_argument -> Ast_408.Parsetree.directive_argument\n =\n fun { Ast_409.Parsetree.pdira_desc; Ast_409.Parsetree.pdira_loc } ->\n {\n Ast_408.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_408.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_409.Parsetree.directive_argument_desc ->\n Ast_408.Parsetree.directive_argument_desc = function\n | Ast_409.Parsetree.Pdir_string x0 -> Ast_408.Parsetree.Pdir_string x0\n | Ast_409.Parsetree.Pdir_int (x0, x1) ->\n Ast_408.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_409.Parsetree.Pdir_ident x0 ->\n Ast_408.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_409.Parsetree.Pdir_bool x0 -> Ast_408.Parsetree.Pdir_bool x0\n\nand copy_typ : Ast_409.Parsetree.typ -> Ast_408.Parsetree.typ =\n fun x -> copy_core_type x\n\nand copy_pat : Ast_409.Parsetree.pat -> Ast_408.Parsetree.pat =\n fun x -> copy_pattern x\n\nand copy_expr : Ast_409.Parsetree.expr -> Ast_408.Parsetree.expr =\n fun x -> copy_expression x\n\nand copy_expression :\n Ast_409.Parsetree.expression -> Ast_408.Parsetree.expression =\n fun {\n Ast_409.Parsetree.pexp_desc;\n Ast_409.Parsetree.pexp_loc;\n Ast_409.Parsetree.pexp_loc_stack;\n Ast_409.Parsetree.pexp_attributes;\n } ->\n {\n Ast_408.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_408.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_408.Parsetree.pexp_loc_stack = List.map copy_location pexp_loc_stack;\n Ast_408.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_409.Parsetree.expression_desc -> Ast_408.Parsetree.expression_desc =\n function\n | Ast_409.Parsetree.Pexp_ident x0 ->\n Ast_408.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pexp_constant x0 ->\n Ast_408.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_409.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_408.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_function x0 ->\n Ast_408.Parsetree.Pexp_function (copy_cases x0)\n | Ast_409.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_408.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_409.Parsetree.Pexp_apply (x0, x1) ->\n Ast_408.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_409.Parsetree.Pexp_match (x0, x1) ->\n Ast_408.Parsetree.Pexp_match (copy_expression x0, copy_cases x1)\n | Ast_409.Parsetree.Pexp_try (x0, x1) ->\n Ast_408.Parsetree.Pexp_try (copy_expression x0, copy_cases x1)\n | Ast_409.Parsetree.Pexp_tuple x0 ->\n Ast_408.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_409.Parsetree.Pexp_construct (x0, x1) ->\n Ast_408.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_409.Parsetree.Pexp_variant (x0, x1) ->\n Ast_408.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_409.Parsetree.Pexp_record (x0, x1) ->\n Ast_408.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_409.Parsetree.Pexp_field (x0, x1) ->\n Ast_408.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_409.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_408.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_array x0 ->\n Ast_408.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_409.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_408.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_409.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_408.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_while (x0, x1) ->\n Ast_408.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_408.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_409.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_408.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_409.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_408.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_409.Parsetree.Pexp_send (x0, x1) ->\n Ast_408.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_409.Parsetree.Pexp_new x0 ->\n Ast_408.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_408.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_override x0 ->\n Ast_408.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_409.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_408.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | Ast_409.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_408.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_assert x0 ->\n Ast_408.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_409.Parsetree.Pexp_lazy x0 ->\n Ast_408.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_409.Parsetree.Pexp_poly (x0, x1) ->\n Ast_408.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_409.Parsetree.Pexp_object x0 ->\n Ast_408.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_409.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_408.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_pack x0 ->\n Ast_408.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_409.Parsetree.Pexp_open (x0, x1) ->\n Ast_408.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_409.Parsetree.Pexp_letop x0 ->\n Ast_408.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_409.Parsetree.Pexp_extension x0 ->\n Ast_408.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_409.Parsetree.Pexp_unreachable -> Ast_408.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_409.Parsetree.letop -> Ast_408.Parsetree.letop =\n fun { Ast_409.Parsetree.let_; Ast_409.Parsetree.ands; Ast_409.Parsetree.body } ->\n {\n Ast_408.Parsetree.let_ = copy_binding_op let_;\n Ast_408.Parsetree.ands = List.map copy_binding_op ands;\n Ast_408.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_409.Parsetree.binding_op -> Ast_408.Parsetree.binding_op =\n fun {\n Ast_409.Parsetree.pbop_op;\n Ast_409.Parsetree.pbop_pat;\n Ast_409.Parsetree.pbop_exp;\n Ast_409.Parsetree.pbop_loc;\n } ->\n {\n Ast_408.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_408.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_408.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_408.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_409.Asttypes.direction_flag -> Ast_408.Asttypes.direction_flag =\n function\n | Ast_409.Asttypes.Upto -> Ast_408.Asttypes.Upto\n | Ast_409.Asttypes.Downto -> Ast_408.Asttypes.Downto\n\nand copy_cases : Ast_409.Parsetree.cases -> Ast_408.Parsetree.cases =\n fun x -> List.map copy_case x\n\nand copy_case : Ast_409.Parsetree.case -> Ast_408.Parsetree.case =\n fun {\n Ast_409.Parsetree.pc_lhs;\n Ast_409.Parsetree.pc_guard;\n Ast_409.Parsetree.pc_rhs;\n } ->\n {\n Ast_408.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_408.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_408.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_409.Parsetree.value_binding -> Ast_408.Parsetree.value_binding =\n fun {\n Ast_409.Parsetree.pvb_pat;\n Ast_409.Parsetree.pvb_expr;\n Ast_409.Parsetree.pvb_attributes;\n Ast_409.Parsetree.pvb_loc;\n } ->\n {\n Ast_408.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_408.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_408.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_408.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_409.Parsetree.pattern -> Ast_408.Parsetree.pattern =\n fun {\n Ast_409.Parsetree.ppat_desc;\n Ast_409.Parsetree.ppat_loc;\n Ast_409.Parsetree.ppat_loc_stack;\n Ast_409.Parsetree.ppat_attributes;\n } ->\n {\n Ast_408.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_408.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_408.Parsetree.ppat_loc_stack = List.map copy_location ppat_loc_stack;\n Ast_408.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_409.Parsetree.pattern_desc -> Ast_408.Parsetree.pattern_desc = function\n | Ast_409.Parsetree.Ppat_any -> Ast_408.Parsetree.Ppat_any\n | Ast_409.Parsetree.Ppat_var x0 ->\n Ast_408.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_409.Parsetree.Ppat_alias (x0, x1) ->\n Ast_408.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_409.Parsetree.Ppat_constant x0 ->\n Ast_408.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_409.Parsetree.Ppat_interval (x0, x1) ->\n Ast_408.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_409.Parsetree.Ppat_tuple x0 ->\n Ast_408.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_409.Parsetree.Ppat_construct (x0, x1) ->\n Ast_408.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_409.Parsetree.Ppat_variant (x0, x1) ->\n Ast_408.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_409.Parsetree.Ppat_record (x0, x1) ->\n Ast_408.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_409.Parsetree.Ppat_array x0 ->\n Ast_408.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_409.Parsetree.Ppat_or (x0, x1) ->\n Ast_408.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_409.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_408.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_409.Parsetree.Ppat_type x0 ->\n Ast_408.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Ppat_lazy x0 ->\n Ast_408.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_409.Parsetree.Ppat_unpack x0 ->\n Ast_408.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | Ast_409.Parsetree.Ppat_exception x0 ->\n Ast_408.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_409.Parsetree.Ppat_extension x0 ->\n Ast_408.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_409.Parsetree.Ppat_open (x0, x1) ->\n Ast_408.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_409.Parsetree.core_type -> Ast_408.Parsetree.core_type\n =\n fun {\n Ast_409.Parsetree.ptyp_desc;\n Ast_409.Parsetree.ptyp_loc;\n Ast_409.Parsetree.ptyp_loc_stack;\n Ast_409.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_408.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_408.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_408.Parsetree.ptyp_loc_stack = List.map copy_location ptyp_loc_stack;\n Ast_408.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n Ast_409.Parsetree.core_type_desc -> Ast_408.Parsetree.core_type_desc =\n function\n | Ast_409.Parsetree.Ptyp_any -> Ast_408.Parsetree.Ptyp_any\n | Ast_409.Parsetree.Ptyp_var x0 -> Ast_408.Parsetree.Ptyp_var x0\n | Ast_409.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_408.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_409.Parsetree.Ptyp_tuple x0 ->\n Ast_408.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_409.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_408.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_object (x0, x1) ->\n Ast_408.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_409.Parsetree.Ptyp_class (x0, x1) ->\n Ast_408.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_408.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_409.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_408.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_409.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_408.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_409.Parsetree.Ptyp_package x0 ->\n Ast_408.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_409.Parsetree.Ptyp_extension x0 ->\n Ast_408.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_409.Parsetree.package_type -> Ast_408.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_409.Parsetree.row_field -> Ast_408.Parsetree.row_field\n =\n fun {\n Ast_409.Parsetree.prf_desc;\n Ast_409.Parsetree.prf_loc;\n Ast_409.Parsetree.prf_attributes;\n } ->\n {\n Ast_408.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_408.Parsetree.prf_loc = copy_location prf_loc;\n Ast_408.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_409.Parsetree.row_field_desc -> Ast_408.Parsetree.row_field_desc =\n function\n | Ast_409.Parsetree.Rtag (x0, x1, x2) ->\n Ast_408.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_409.Parsetree.Rinherit x0 ->\n Ast_408.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_409.Parsetree.object_field -> Ast_408.Parsetree.object_field =\n fun {\n Ast_409.Parsetree.pof_desc;\n Ast_409.Parsetree.pof_loc;\n Ast_409.Parsetree.pof_attributes;\n } ->\n {\n Ast_408.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_408.Parsetree.pof_loc = copy_location pof_loc;\n Ast_408.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_409.Parsetree.attributes -> Ast_408.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_409.Parsetree.attribute -> Ast_408.Parsetree.attribute\n =\n fun {\n Ast_409.Parsetree.attr_name;\n Ast_409.Parsetree.attr_payload;\n Ast_409.Parsetree.attr_loc;\n } ->\n {\n Ast_408.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_408.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_408.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_409.Parsetree.payload -> Ast_408.Parsetree.payload =\n function\n | Ast_409.Parsetree.PStr x0 -> Ast_408.Parsetree.PStr (copy_structure x0)\n | Ast_409.Parsetree.PSig x0 -> Ast_408.Parsetree.PSig (copy_signature x0)\n | Ast_409.Parsetree.PTyp x0 -> Ast_408.Parsetree.PTyp (copy_core_type x0)\n | Ast_409.Parsetree.PPat (x0, x1) ->\n Ast_408.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_409.Parsetree.structure -> Ast_408.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_409.Parsetree.structure_item -> Ast_408.Parsetree.structure_item =\n fun { Ast_409.Parsetree.pstr_desc; Ast_409.Parsetree.pstr_loc } ->\n {\n Ast_408.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_408.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_409.Parsetree.structure_item_desc ->\n Ast_408.Parsetree.structure_item_desc = function\n | Ast_409.Parsetree.Pstr_eval (x0, x1) ->\n Ast_408.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_409.Parsetree.Pstr_value (x0, x1) ->\n Ast_408.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_409.Parsetree.Pstr_primitive x0 ->\n Ast_408.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_409.Parsetree.Pstr_type (x0, x1) ->\n Ast_408.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_409.Parsetree.Pstr_typext x0 ->\n Ast_408.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_409.Parsetree.Pstr_exception x0 ->\n Ast_408.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_409.Parsetree.Pstr_module x0 ->\n Ast_408.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_409.Parsetree.Pstr_recmodule x0 ->\n Ast_408.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_409.Parsetree.Pstr_modtype x0 ->\n Ast_408.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_409.Parsetree.Pstr_open x0 ->\n Ast_408.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_409.Parsetree.Pstr_class x0 ->\n Ast_408.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_409.Parsetree.Pstr_class_type x0 ->\n Ast_408.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_409.Parsetree.Pstr_include x0 ->\n Ast_408.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_409.Parsetree.Pstr_attribute x0 ->\n Ast_408.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pstr_extension (x0, x1) ->\n Ast_408.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_409.Parsetree.include_declaration ->\n Ast_408.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_409.Parsetree.class_declaration -> Ast_408.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_409.Parsetree.class_expr -> Ast_408.Parsetree.class_expr =\n fun {\n Ast_409.Parsetree.pcl_desc;\n Ast_409.Parsetree.pcl_loc;\n Ast_409.Parsetree.pcl_attributes;\n } ->\n {\n Ast_408.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_408.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_408.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_409.Parsetree.class_expr_desc -> Ast_408.Parsetree.class_expr_desc =\n function\n | Ast_409.Parsetree.Pcl_constr (x0, x1) ->\n Ast_408.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Pcl_structure x0 ->\n Ast_408.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_409.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_408.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_409.Parsetree.Pcl_apply (x0, x1) ->\n Ast_408.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_409.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_408.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_409.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_408.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_409.Parsetree.Pcl_extension x0 ->\n Ast_408.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_409.Parsetree.Pcl_open (x0, x1) ->\n Ast_408.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_409.Parsetree.class_structure -> Ast_408.Parsetree.class_structure =\n fun { Ast_409.Parsetree.pcstr_self; Ast_409.Parsetree.pcstr_fields } ->\n {\n Ast_408.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_408.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_409.Parsetree.class_field -> Ast_408.Parsetree.class_field =\n fun {\n Ast_409.Parsetree.pcf_desc;\n Ast_409.Parsetree.pcf_loc;\n Ast_409.Parsetree.pcf_attributes;\n } ->\n {\n Ast_408.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_408.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_408.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_409.Parsetree.class_field_desc -> Ast_408.Parsetree.class_field_desc =\n function\n | Ast_409.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_408.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_409.Parsetree.Pcf_val x0 ->\n Ast_408.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_409.Parsetree.Pcf_method x0 ->\n Ast_408.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_409.Parsetree.Pcf_constraint x0 ->\n Ast_408.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_409.Parsetree.Pcf_initializer x0 ->\n Ast_408.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_409.Parsetree.Pcf_attribute x0 ->\n Ast_408.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pcf_extension x0 ->\n Ast_408.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_409.Parsetree.class_field_kind -> Ast_408.Parsetree.class_field_kind =\n function\n | Ast_409.Parsetree.Cfk_virtual x0 ->\n Ast_408.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_409.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_408.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_409.Parsetree.open_declaration -> Ast_408.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_409.Parsetree.module_binding -> Ast_408.Parsetree.module_binding =\n fun {\n Ast_409.Parsetree.pmb_name;\n Ast_409.Parsetree.pmb_expr;\n Ast_409.Parsetree.pmb_attributes;\n Ast_409.Parsetree.pmb_loc;\n } ->\n {\n Ast_408.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n Ast_408.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_408.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_408.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_409.Parsetree.module_expr -> Ast_408.Parsetree.module_expr =\n fun {\n Ast_409.Parsetree.pmod_desc;\n Ast_409.Parsetree.pmod_loc;\n Ast_409.Parsetree.pmod_attributes;\n } ->\n {\n Ast_408.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_408.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_408.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_409.Parsetree.module_expr_desc -> Ast_408.Parsetree.module_expr_desc =\n function\n | Ast_409.Parsetree.Pmod_ident x0 ->\n Ast_408.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pmod_structure x0 ->\n Ast_408.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_409.Parsetree.Pmod_functor (x0, x1, x2) ->\n Ast_408.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n Option.map copy_module_type x1,\n copy_module_expr x2 )\n | Ast_409.Parsetree.Pmod_apply (x0, x1) ->\n Ast_408.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_409.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_408.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_409.Parsetree.Pmod_unpack x0 ->\n Ast_408.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_409.Parsetree.Pmod_extension x0 ->\n Ast_408.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type :\n Ast_409.Parsetree.module_type -> Ast_408.Parsetree.module_type =\n fun {\n Ast_409.Parsetree.pmty_desc;\n Ast_409.Parsetree.pmty_loc;\n Ast_409.Parsetree.pmty_attributes;\n } ->\n {\n Ast_408.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_408.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_408.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_409.Parsetree.module_type_desc -> Ast_408.Parsetree.module_type_desc =\n function\n | Ast_409.Parsetree.Pmty_ident x0 ->\n Ast_408.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_409.Parsetree.Pmty_signature x0 ->\n Ast_408.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_409.Parsetree.Pmty_functor (x0, x1, x2) ->\n Ast_408.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n Option.map copy_module_type x1,\n copy_module_type x2 )\n | Ast_409.Parsetree.Pmty_with (x0, x1) ->\n Ast_408.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_409.Parsetree.Pmty_typeof x0 ->\n Ast_408.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_409.Parsetree.Pmty_extension x0 ->\n Ast_408.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_409.Parsetree.Pmty_alias x0 ->\n Ast_408.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_409.Parsetree.with_constraint -> Ast_408.Parsetree.with_constraint =\n function\n | Ast_409.Parsetree.Pwith_type (x0, x1) ->\n Ast_408.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_409.Parsetree.Pwith_module (x0, x1) ->\n Ast_408.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_409.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_408.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_409.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_408.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_409.Parsetree.signature -> Ast_408.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_409.Parsetree.signature_item -> Ast_408.Parsetree.signature_item =\n fun { Ast_409.Parsetree.psig_desc; Ast_409.Parsetree.psig_loc } ->\n {\n Ast_408.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_408.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_409.Parsetree.signature_item_desc ->\n Ast_408.Parsetree.signature_item_desc = function\n | Ast_409.Parsetree.Psig_value x0 ->\n Ast_408.Parsetree.Psig_value (copy_value_description x0)\n | Ast_409.Parsetree.Psig_type (x0, x1) ->\n Ast_408.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_409.Parsetree.Psig_typesubst x0 ->\n Ast_408.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_409.Parsetree.Psig_typext x0 ->\n Ast_408.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_409.Parsetree.Psig_exception x0 ->\n Ast_408.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_409.Parsetree.Psig_module x0 ->\n Ast_408.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_409.Parsetree.Psig_modsubst x0 ->\n Ast_408.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_409.Parsetree.Psig_recmodule x0 ->\n Ast_408.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_409.Parsetree.Psig_modtype x0 ->\n Ast_408.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_409.Parsetree.Psig_open x0 ->\n Ast_408.Parsetree.Psig_open (copy_open_description x0)\n | Ast_409.Parsetree.Psig_include x0 ->\n Ast_408.Parsetree.Psig_include (copy_include_description x0)\n | Ast_409.Parsetree.Psig_class x0 ->\n Ast_408.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_409.Parsetree.Psig_class_type x0 ->\n Ast_408.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_409.Parsetree.Psig_attribute x0 ->\n Ast_408.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Psig_extension (x0, x1) ->\n Ast_408.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_409.Parsetree.class_type_declaration ->\n Ast_408.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_409.Parsetree.class_description -> Ast_408.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_409.Parsetree.class_type -> Ast_408.Parsetree.class_type =\n fun {\n Ast_409.Parsetree.pcty_desc;\n Ast_409.Parsetree.pcty_loc;\n Ast_409.Parsetree.pcty_attributes;\n } ->\n {\n Ast_408.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_408.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_408.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_409.Parsetree.class_type_desc -> Ast_408.Parsetree.class_type_desc =\n function\n | Ast_409.Parsetree.Pcty_constr (x0, x1) ->\n Ast_408.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_409.Parsetree.Pcty_signature x0 ->\n Ast_408.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_409.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_408.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_409.Parsetree.Pcty_extension x0 ->\n Ast_408.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_409.Parsetree.Pcty_open (x0, x1) ->\n Ast_408.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_409.Parsetree.class_signature -> Ast_408.Parsetree.class_signature =\n fun { Ast_409.Parsetree.pcsig_self; Ast_409.Parsetree.pcsig_fields } ->\n {\n Ast_408.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_408.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_409.Parsetree.class_type_field -> Ast_408.Parsetree.class_type_field =\n fun {\n Ast_409.Parsetree.pctf_desc;\n Ast_409.Parsetree.pctf_loc;\n Ast_409.Parsetree.pctf_attributes;\n } ->\n {\n Ast_408.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_408.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_408.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_409.Parsetree.class_type_field_desc ->\n Ast_408.Parsetree.class_type_field_desc = function\n | Ast_409.Parsetree.Pctf_inherit x0 ->\n Ast_408.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_409.Parsetree.Pctf_val x0 ->\n Ast_408.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_409.Parsetree.Pctf_method x0 ->\n Ast_408.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_409.Parsetree.Pctf_constraint x0 ->\n Ast_408.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_409.Parsetree.Pctf_attribute x0 ->\n Ast_408.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_409.Parsetree.Pctf_extension x0 ->\n Ast_408.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_409.Parsetree.extension -> Ast_408.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.class_infos ->\n 'g0 Ast_408.Parsetree.class_infos =\n fun f0\n {\n Ast_409.Parsetree.pci_virt;\n Ast_409.Parsetree.pci_params;\n Ast_409.Parsetree.pci_name;\n Ast_409.Parsetree.pci_expr;\n Ast_409.Parsetree.pci_loc;\n Ast_409.Parsetree.pci_attributes;\n } ->\n {\n Ast_408.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_408.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_408.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_408.Parsetree.pci_expr = f0 pci_expr;\n Ast_408.Parsetree.pci_loc = copy_location pci_loc;\n Ast_408.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_409.Asttypes.virtual_flag -> Ast_408.Asttypes.virtual_flag = function\n | Ast_409.Asttypes.Virtual -> Ast_408.Asttypes.Virtual\n | Ast_409.Asttypes.Concrete -> Ast_408.Asttypes.Concrete\n\nand copy_include_description :\n Ast_409.Parsetree.include_description ->\n Ast_408.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.include_infos ->\n 'g0 Ast_408.Parsetree.include_infos =\n fun f0\n {\n Ast_409.Parsetree.pincl_mod;\n Ast_409.Parsetree.pincl_loc;\n Ast_409.Parsetree.pincl_attributes;\n } ->\n {\n Ast_408.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_408.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_408.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_409.Parsetree.open_description -> Ast_408.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_409.Parsetree.open_infos ->\n 'g0 Ast_408.Parsetree.open_infos =\n fun f0\n {\n Ast_409.Parsetree.popen_expr;\n Ast_409.Parsetree.popen_override;\n Ast_409.Parsetree.popen_loc;\n Ast_409.Parsetree.popen_attributes;\n } ->\n {\n Ast_408.Parsetree.popen_expr = f0 popen_expr;\n Ast_408.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_408.Parsetree.popen_loc = copy_location popen_loc;\n Ast_408.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_409.Asttypes.override_flag -> Ast_408.Asttypes.override_flag = function\n | Ast_409.Asttypes.Override -> Ast_408.Asttypes.Override\n | Ast_409.Asttypes.Fresh -> Ast_408.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_409.Parsetree.module_type_declaration ->\n Ast_408.Parsetree.module_type_declaration =\n fun {\n Ast_409.Parsetree.pmtd_name;\n Ast_409.Parsetree.pmtd_type;\n Ast_409.Parsetree.pmtd_attributes;\n Ast_409.Parsetree.pmtd_loc;\n } ->\n {\n Ast_408.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_408.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_408.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_408.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_409.Parsetree.module_substitution ->\n Ast_408.Parsetree.module_substitution =\n fun {\n Ast_409.Parsetree.pms_name;\n Ast_409.Parsetree.pms_manifest;\n Ast_409.Parsetree.pms_attributes;\n Ast_409.Parsetree.pms_loc;\n } ->\n {\n Ast_408.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_408.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_408.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_408.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_409.Parsetree.module_declaration -> Ast_408.Parsetree.module_declaration\n =\n fun {\n Ast_409.Parsetree.pmd_name;\n Ast_409.Parsetree.pmd_type;\n Ast_409.Parsetree.pmd_attributes;\n Ast_409.Parsetree.pmd_loc;\n } ->\n {\n Ast_408.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n Ast_408.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_408.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_408.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_409.Parsetree.type_exception -> Ast_408.Parsetree.type_exception =\n fun {\n Ast_409.Parsetree.ptyexn_constructor;\n Ast_409.Parsetree.ptyexn_loc;\n Ast_409.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_408.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_408.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_408.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_409.Parsetree.type_extension -> Ast_408.Parsetree.type_extension =\n fun {\n Ast_409.Parsetree.ptyext_path;\n Ast_409.Parsetree.ptyext_params;\n Ast_409.Parsetree.ptyext_constructors;\n Ast_409.Parsetree.ptyext_private;\n Ast_409.Parsetree.ptyext_loc;\n Ast_409.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_408.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_408.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_408.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_408.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_408.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_408.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_409.Parsetree.extension_constructor ->\n Ast_408.Parsetree.extension_constructor =\n fun {\n Ast_409.Parsetree.pext_name;\n Ast_409.Parsetree.pext_kind;\n Ast_409.Parsetree.pext_loc;\n Ast_409.Parsetree.pext_attributes;\n } ->\n {\n Ast_408.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_408.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_408.Parsetree.pext_loc = copy_location pext_loc;\n Ast_408.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_409.Parsetree.extension_constructor_kind ->\n Ast_408.Parsetree.extension_constructor_kind = function\n | Ast_409.Parsetree.Pext_decl (x0, x1) ->\n Ast_408.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_409.Parsetree.Pext_rebind x0 ->\n Ast_408.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_409.Parsetree.type_declaration -> Ast_408.Parsetree.type_declaration =\n fun {\n Ast_409.Parsetree.ptype_name;\n Ast_409.Parsetree.ptype_params;\n Ast_409.Parsetree.ptype_cstrs;\n Ast_409.Parsetree.ptype_kind;\n Ast_409.Parsetree.ptype_private;\n Ast_409.Parsetree.ptype_manifest;\n Ast_409.Parsetree.ptype_attributes;\n Ast_409.Parsetree.ptype_loc;\n } ->\n {\n Ast_408.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_408.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_408.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_408.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_408.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_408.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_408.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_408.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_409.Asttypes.private_flag -> Ast_408.Asttypes.private_flag = function\n | Ast_409.Asttypes.Private -> Ast_408.Asttypes.Private\n | Ast_409.Asttypes.Public -> Ast_408.Asttypes.Public\n\nand copy_type_kind : Ast_409.Parsetree.type_kind -> Ast_408.Parsetree.type_kind\n = function\n | Ast_409.Parsetree.Ptype_abstract -> Ast_408.Parsetree.Ptype_abstract\n | Ast_409.Parsetree.Ptype_variant x0 ->\n Ast_408.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_409.Parsetree.Ptype_record x0 ->\n Ast_408.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_409.Parsetree.Ptype_open -> Ast_408.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_409.Parsetree.constructor_declaration ->\n Ast_408.Parsetree.constructor_declaration =\n fun {\n Ast_409.Parsetree.pcd_name;\n Ast_409.Parsetree.pcd_args;\n Ast_409.Parsetree.pcd_res;\n Ast_409.Parsetree.pcd_loc;\n Ast_409.Parsetree.pcd_attributes;\n } ->\n {\n Ast_408.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_408.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_408.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_408.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_408.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_409.Parsetree.constructor_arguments ->\n Ast_408.Parsetree.constructor_arguments = function\n | Ast_409.Parsetree.Pcstr_tuple x0 ->\n Ast_408.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_409.Parsetree.Pcstr_record x0 ->\n Ast_408.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_409.Parsetree.label_declaration -> Ast_408.Parsetree.label_declaration =\n fun {\n Ast_409.Parsetree.pld_name;\n Ast_409.Parsetree.pld_mutable;\n Ast_409.Parsetree.pld_type;\n Ast_409.Parsetree.pld_loc;\n Ast_409.Parsetree.pld_attributes;\n } ->\n {\n Ast_408.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_408.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_408.Parsetree.pld_type = copy_core_type pld_type;\n Ast_408.Parsetree.pld_loc = copy_location pld_loc;\n Ast_408.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_409.Asttypes.mutable_flag -> Ast_408.Asttypes.mutable_flag = function\n | Ast_409.Asttypes.Immutable -> Ast_408.Asttypes.Immutable\n | Ast_409.Asttypes.Mutable -> Ast_408.Asttypes.Mutable\n\nand copy_variance : Ast_409.Asttypes.variance -> Ast_408.Asttypes.variance =\n function\n | Ast_409.Asttypes.Covariant -> Ast_408.Asttypes.Covariant\n | Ast_409.Asttypes.Contravariant -> Ast_408.Asttypes.Contravariant\n | Ast_409.Asttypes.Invariant -> Ast_408.Asttypes.Invariant\n\nand copy_value_description :\n Ast_409.Parsetree.value_description -> Ast_408.Parsetree.value_description =\n fun {\n Ast_409.Parsetree.pval_name;\n Ast_409.Parsetree.pval_type;\n Ast_409.Parsetree.pval_prim;\n Ast_409.Parsetree.pval_attributes;\n Ast_409.Parsetree.pval_loc;\n } ->\n {\n Ast_408.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_408.Parsetree.pval_type = copy_core_type pval_type;\n Ast_408.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_408.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_408.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_409.Parsetree.object_field_desc -> Ast_408.Parsetree.object_field_desc =\n function\n | Ast_409.Parsetree.Otag (x0, x1) ->\n Ast_408.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_409.Parsetree.Oinherit x0 ->\n Ast_408.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_409.Asttypes.arg_label -> Ast_408.Asttypes.arg_label =\n function\n | Ast_409.Asttypes.Nolabel -> Ast_408.Asttypes.Nolabel\n | Ast_409.Asttypes.Labelled x0 -> Ast_408.Asttypes.Labelled x0\n | Ast_409.Asttypes.Optional x0 -> Ast_408.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_409.Asttypes.closed_flag -> Ast_408.Asttypes.closed_flag = function\n | Ast_409.Asttypes.Closed -> Ast_408.Asttypes.Closed\n | Ast_409.Asttypes.Open -> Ast_408.Asttypes.Open\n\nand copy_label : Ast_409.Asttypes.label -> Ast_408.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_409.Asttypes.rec_flag -> Ast_408.Asttypes.rec_flag =\n function\n | Ast_409.Asttypes.Nonrecursive -> Ast_408.Asttypes.Nonrecursive\n | Ast_409.Asttypes.Recursive -> Ast_408.Asttypes.Recursive\n\nand copy_constant : Ast_409.Parsetree.constant -> Ast_408.Parsetree.constant =\n function\n | Ast_409.Parsetree.Pconst_integer (x0, x1) ->\n Ast_408.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_409.Parsetree.Pconst_char x0 -> Ast_408.Parsetree.Pconst_char x0\n | Ast_409.Parsetree.Pconst_string (x0, x1) ->\n Ast_408.Parsetree.Pconst_string (x0, Option.map (fun x -> x) x1)\n | Ast_409.Parsetree.Pconst_float (x0, x1) ->\n Ast_408.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_409.Asttypes.loc -> 'g0 Ast_408.Asttypes.loc =\n fun f0 { Ast_409.Asttypes.txt; Ast_409.Asttypes.loc } ->\n { Ast_408.Asttypes.txt = f0 txt; Ast_408.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","open Stdlib0\nmodule From = Ast_408\nmodule To = Ast_409\n\nlet rec copy_toplevel_phrase :\n Ast_408.Parsetree.toplevel_phrase -> Ast_409.Parsetree.toplevel_phrase =\n function\n | Ast_408.Parsetree.Ptop_def x0 ->\n Ast_409.Parsetree.Ptop_def (copy_structure x0)\n | Ast_408.Parsetree.Ptop_dir x0 ->\n Ast_409.Parsetree.Ptop_dir (copy_toplevel_directive x0)\n\nand copy_toplevel_directive :\n Ast_408.Parsetree.toplevel_directive -> Ast_409.Parsetree.toplevel_directive\n =\n fun {\n Ast_408.Parsetree.pdir_name;\n Ast_408.Parsetree.pdir_arg;\n Ast_408.Parsetree.pdir_loc;\n } ->\n {\n Ast_409.Parsetree.pdir_name = copy_loc (fun x -> x) pdir_name;\n Ast_409.Parsetree.pdir_arg = Option.map copy_directive_argument pdir_arg;\n Ast_409.Parsetree.pdir_loc = copy_location pdir_loc;\n }\n\nand copy_directive_argument :\n Ast_408.Parsetree.directive_argument -> Ast_409.Parsetree.directive_argument\n =\n fun { Ast_408.Parsetree.pdira_desc; Ast_408.Parsetree.pdira_loc } ->\n {\n Ast_409.Parsetree.pdira_desc = copy_directive_argument_desc pdira_desc;\n Ast_409.Parsetree.pdira_loc = copy_location pdira_loc;\n }\n\nand copy_directive_argument_desc :\n Ast_408.Parsetree.directive_argument_desc ->\n Ast_409.Parsetree.directive_argument_desc = function\n | Ast_408.Parsetree.Pdir_string x0 -> Ast_409.Parsetree.Pdir_string x0\n | Ast_408.Parsetree.Pdir_int (x0, x1) ->\n Ast_409.Parsetree.Pdir_int (x0, Option.map (fun x -> x) x1)\n | Ast_408.Parsetree.Pdir_ident x0 ->\n Ast_409.Parsetree.Pdir_ident (copy_Longident_t x0)\n | Ast_408.Parsetree.Pdir_bool x0 -> Ast_409.Parsetree.Pdir_bool x0\n\nand copy_typ : Ast_408.Parsetree.typ -> Ast_409.Parsetree.typ =\n fun x -> copy_core_type x\n\nand copy_pat : Ast_408.Parsetree.pat -> Ast_409.Parsetree.pat =\n fun x -> copy_pattern x\n\nand copy_expr : Ast_408.Parsetree.expr -> Ast_409.Parsetree.expr =\n fun x -> copy_expression x\n\nand copy_expression :\n Ast_408.Parsetree.expression -> Ast_409.Parsetree.expression =\n fun {\n Ast_408.Parsetree.pexp_desc;\n Ast_408.Parsetree.pexp_loc;\n Ast_408.Parsetree.pexp_loc_stack;\n Ast_408.Parsetree.pexp_attributes;\n } ->\n {\n Ast_409.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n Ast_409.Parsetree.pexp_loc = copy_location pexp_loc;\n Ast_409.Parsetree.pexp_loc_stack = List.map copy_location pexp_loc_stack;\n Ast_409.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n Ast_408.Parsetree.expression_desc -> Ast_409.Parsetree.expression_desc =\n function\n | Ast_408.Parsetree.Pexp_ident x0 ->\n Ast_409.Parsetree.Pexp_ident (copy_loc copy_Longident_t x0)\n | Ast_408.Parsetree.Pexp_constant x0 ->\n Ast_409.Parsetree.Pexp_constant (copy_constant x0)\n | Ast_408.Parsetree.Pexp_let (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | Ast_408.Parsetree.Pexp_function x0 ->\n Ast_409.Parsetree.Pexp_function (copy_cases x0)\n | Ast_408.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n Ast_409.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | Ast_408.Parsetree.Pexp_apply (x0, x1) ->\n Ast_409.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_408.Parsetree.Pexp_match (x0, x1) ->\n Ast_409.Parsetree.Pexp_match (copy_expression x0, copy_cases x1)\n | Ast_408.Parsetree.Pexp_try (x0, x1) ->\n Ast_409.Parsetree.Pexp_try (copy_expression x0, copy_cases x1)\n | Ast_408.Parsetree.Pexp_tuple x0 ->\n Ast_409.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | Ast_408.Parsetree.Pexp_construct (x0, x1) ->\n Ast_409.Parsetree.Pexp_construct\n (copy_loc copy_Longident_t x0, Option.map copy_expression x1)\n | Ast_408.Parsetree.Pexp_variant (x0, x1) ->\n Ast_409.Parsetree.Pexp_variant\n (copy_label x0, Option.map copy_expression x1)\n | Ast_408.Parsetree.Pexp_record (x0, x1) ->\n Ast_409.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_expression x1))\n x0,\n Option.map copy_expression x1 )\n | Ast_408.Parsetree.Pexp_field (x0, x1) ->\n Ast_409.Parsetree.Pexp_field\n (copy_expression x0, copy_loc copy_Longident_t x1)\n | Ast_408.Parsetree.Pexp_setfield (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_Longident_t x1, copy_expression x2)\n | Ast_408.Parsetree.Pexp_array x0 ->\n Ast_409.Parsetree.Pexp_array (List.map copy_expression x0)\n | Ast_408.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, Option.map copy_expression x2)\n | Ast_408.Parsetree.Pexp_sequence (x0, x1) ->\n Ast_409.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_while (x0, x1) ->\n Ast_409.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n Ast_409.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | Ast_408.Parsetree.Pexp_constraint (x0, x1) ->\n Ast_409.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | Ast_408.Parsetree.Pexp_coerce (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_coerce\n (copy_expression x0, Option.map copy_core_type x1, copy_core_type x2)\n | Ast_408.Parsetree.Pexp_send (x0, x1) ->\n Ast_409.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | Ast_408.Parsetree.Pexp_new x0 ->\n Ast_409.Parsetree.Pexp_new (copy_loc copy_Longident_t x0)\n | Ast_408.Parsetree.Pexp_setinstvar (x0, x1) ->\n Ast_409.Parsetree.Pexp_setinstvar\n (copy_loc copy_label x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_override x0 ->\n Ast_409.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | Ast_408.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n Ast_409.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | Ast_408.Parsetree.Pexp_letexception (x0, x1) ->\n Ast_409.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_assert x0 ->\n Ast_409.Parsetree.Pexp_assert (copy_expression x0)\n | Ast_408.Parsetree.Pexp_lazy x0 ->\n Ast_409.Parsetree.Pexp_lazy (copy_expression x0)\n | Ast_408.Parsetree.Pexp_poly (x0, x1) ->\n Ast_409.Parsetree.Pexp_poly\n (copy_expression x0, Option.map copy_core_type x1)\n | Ast_408.Parsetree.Pexp_object x0 ->\n Ast_409.Parsetree.Pexp_object (copy_class_structure x0)\n | Ast_408.Parsetree.Pexp_newtype (x0, x1) ->\n Ast_409.Parsetree.Pexp_newtype\n (copy_loc (fun x -> x) x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_pack x0 ->\n Ast_409.Parsetree.Pexp_pack (copy_module_expr x0)\n | Ast_408.Parsetree.Pexp_open (x0, x1) ->\n Ast_409.Parsetree.Pexp_open (copy_open_declaration x0, copy_expression x1)\n | Ast_408.Parsetree.Pexp_letop x0 ->\n Ast_409.Parsetree.Pexp_letop (copy_letop x0)\n | Ast_408.Parsetree.Pexp_extension x0 ->\n Ast_409.Parsetree.Pexp_extension (copy_extension x0)\n | Ast_408.Parsetree.Pexp_unreachable -> Ast_409.Parsetree.Pexp_unreachable\n\nand copy_letop : Ast_408.Parsetree.letop -> Ast_409.Parsetree.letop =\n fun { Ast_408.Parsetree.let_; Ast_408.Parsetree.ands; Ast_408.Parsetree.body } ->\n {\n Ast_409.Parsetree.let_ = copy_binding_op let_;\n Ast_409.Parsetree.ands = List.map copy_binding_op ands;\n Ast_409.Parsetree.body = copy_expression body;\n }\n\nand copy_binding_op :\n Ast_408.Parsetree.binding_op -> Ast_409.Parsetree.binding_op =\n fun {\n Ast_408.Parsetree.pbop_op;\n Ast_408.Parsetree.pbop_pat;\n Ast_408.Parsetree.pbop_exp;\n Ast_408.Parsetree.pbop_loc;\n } ->\n {\n Ast_409.Parsetree.pbop_op = copy_loc (fun x -> x) pbop_op;\n Ast_409.Parsetree.pbop_pat = copy_pattern pbop_pat;\n Ast_409.Parsetree.pbop_exp = copy_expression pbop_exp;\n Ast_409.Parsetree.pbop_loc = copy_location pbop_loc;\n }\n\nand copy_direction_flag :\n Ast_408.Asttypes.direction_flag -> Ast_409.Asttypes.direction_flag =\n function\n | Ast_408.Asttypes.Upto -> Ast_409.Asttypes.Upto\n | Ast_408.Asttypes.Downto -> Ast_409.Asttypes.Downto\n\nand copy_cases : Ast_408.Parsetree.cases -> Ast_409.Parsetree.cases =\n fun x -> List.map copy_case x\n\nand copy_case : Ast_408.Parsetree.case -> Ast_409.Parsetree.case =\n fun {\n Ast_408.Parsetree.pc_lhs;\n Ast_408.Parsetree.pc_guard;\n Ast_408.Parsetree.pc_rhs;\n } ->\n {\n Ast_409.Parsetree.pc_lhs = copy_pattern pc_lhs;\n Ast_409.Parsetree.pc_guard = Option.map copy_expression pc_guard;\n Ast_409.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n Ast_408.Parsetree.value_binding -> Ast_409.Parsetree.value_binding =\n fun {\n Ast_408.Parsetree.pvb_pat;\n Ast_408.Parsetree.pvb_expr;\n Ast_408.Parsetree.pvb_attributes;\n Ast_408.Parsetree.pvb_loc;\n } ->\n {\n Ast_409.Parsetree.pvb_pat = copy_pattern pvb_pat;\n Ast_409.Parsetree.pvb_expr = copy_expression pvb_expr;\n Ast_409.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n Ast_409.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : Ast_408.Parsetree.pattern -> Ast_409.Parsetree.pattern =\n fun {\n Ast_408.Parsetree.ppat_desc;\n Ast_408.Parsetree.ppat_loc;\n Ast_408.Parsetree.ppat_loc_stack;\n Ast_408.Parsetree.ppat_attributes;\n } ->\n {\n Ast_409.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n Ast_409.Parsetree.ppat_loc = copy_location ppat_loc;\n Ast_409.Parsetree.ppat_loc_stack = List.map copy_location ppat_loc_stack;\n Ast_409.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc :\n Ast_408.Parsetree.pattern_desc -> Ast_409.Parsetree.pattern_desc = function\n | Ast_408.Parsetree.Ppat_any -> Ast_409.Parsetree.Ppat_any\n | Ast_408.Parsetree.Ppat_var x0 ->\n Ast_409.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | Ast_408.Parsetree.Ppat_alias (x0, x1) ->\n Ast_409.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | Ast_408.Parsetree.Ppat_constant x0 ->\n Ast_409.Parsetree.Ppat_constant (copy_constant x0)\n | Ast_408.Parsetree.Ppat_interval (x0, x1) ->\n Ast_409.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | Ast_408.Parsetree.Ppat_tuple x0 ->\n Ast_409.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | Ast_408.Parsetree.Ppat_construct (x0, x1) ->\n Ast_409.Parsetree.Ppat_construct\n (copy_loc copy_Longident_t x0, Option.map copy_pattern x1)\n | Ast_408.Parsetree.Ppat_variant (x0, x1) ->\n Ast_409.Parsetree.Ppat_variant (copy_label x0, Option.map copy_pattern x1)\n | Ast_408.Parsetree.Ppat_record (x0, x1) ->\n Ast_409.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | Ast_408.Parsetree.Ppat_array x0 ->\n Ast_409.Parsetree.Ppat_array (List.map copy_pattern x0)\n | Ast_408.Parsetree.Ppat_or (x0, x1) ->\n Ast_409.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | Ast_408.Parsetree.Ppat_constraint (x0, x1) ->\n Ast_409.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | Ast_408.Parsetree.Ppat_type x0 ->\n Ast_409.Parsetree.Ppat_type (copy_loc copy_Longident_t x0)\n | Ast_408.Parsetree.Ppat_lazy x0 ->\n Ast_409.Parsetree.Ppat_lazy (copy_pattern x0)\n | Ast_408.Parsetree.Ppat_unpack x0 ->\n Ast_409.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | Ast_408.Parsetree.Ppat_exception x0 ->\n Ast_409.Parsetree.Ppat_exception (copy_pattern x0)\n | Ast_408.Parsetree.Ppat_extension x0 ->\n Ast_409.Parsetree.Ppat_extension (copy_extension x0)\n | Ast_408.Parsetree.Ppat_open (x0, x1) ->\n Ast_409.Parsetree.Ppat_open (copy_loc copy_Longident_t x0, copy_pattern x1)\n\nand copy_core_type : Ast_408.Parsetree.core_type -> Ast_409.Parsetree.core_type\n =\n fun {\n Ast_408.Parsetree.ptyp_desc;\n Ast_408.Parsetree.ptyp_loc;\n Ast_408.Parsetree.ptyp_loc_stack;\n Ast_408.Parsetree.ptyp_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n Ast_409.Parsetree.ptyp_loc = copy_location ptyp_loc;\n Ast_409.Parsetree.ptyp_loc_stack = List.map copy_location ptyp_loc_stack;\n Ast_409.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n Ast_408.Parsetree.core_type_desc -> Ast_409.Parsetree.core_type_desc =\n function\n | Ast_408.Parsetree.Ptyp_any -> Ast_409.Parsetree.Ptyp_any\n | Ast_408.Parsetree.Ptyp_var x0 -> Ast_409.Parsetree.Ptyp_var x0\n | Ast_408.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n Ast_409.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | Ast_408.Parsetree.Ptyp_tuple x0 ->\n Ast_409.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | Ast_408.Parsetree.Ptyp_constr (x0, x1) ->\n Ast_409.Parsetree.Ptyp_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_408.Parsetree.Ptyp_object (x0, x1) ->\n Ast_409.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | Ast_408.Parsetree.Ptyp_class (x0, x1) ->\n Ast_409.Parsetree.Ptyp_class\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_408.Parsetree.Ptyp_alias (x0, x1) ->\n Ast_409.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | Ast_408.Parsetree.Ptyp_variant (x0, x1, x2) ->\n Ast_409.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n Option.map (fun x -> List.map copy_label x) x2 )\n | Ast_408.Parsetree.Ptyp_poly (x0, x1) ->\n Ast_409.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | Ast_408.Parsetree.Ptyp_package x0 ->\n Ast_409.Parsetree.Ptyp_package (copy_package_type x0)\n | Ast_408.Parsetree.Ptyp_extension x0 ->\n Ast_409.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type :\n Ast_408.Parsetree.package_type -> Ast_409.Parsetree.package_type =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_Longident_t x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_Longident_t x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : Ast_408.Parsetree.row_field -> Ast_409.Parsetree.row_field\n =\n fun {\n Ast_408.Parsetree.prf_desc;\n Ast_408.Parsetree.prf_loc;\n Ast_408.Parsetree.prf_attributes;\n } ->\n {\n Ast_409.Parsetree.prf_desc = copy_row_field_desc prf_desc;\n Ast_409.Parsetree.prf_loc = copy_location prf_loc;\n Ast_409.Parsetree.prf_attributes = copy_attributes prf_attributes;\n }\n\nand copy_row_field_desc :\n Ast_408.Parsetree.row_field_desc -> Ast_409.Parsetree.row_field_desc =\n function\n | Ast_408.Parsetree.Rtag (x0, x1, x2) ->\n Ast_409.Parsetree.Rtag\n (copy_loc copy_label x0, x1, List.map copy_core_type x2)\n | Ast_408.Parsetree.Rinherit x0 ->\n Ast_409.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field :\n Ast_408.Parsetree.object_field -> Ast_409.Parsetree.object_field =\n fun {\n Ast_408.Parsetree.pof_desc;\n Ast_408.Parsetree.pof_loc;\n Ast_408.Parsetree.pof_attributes;\n } ->\n {\n Ast_409.Parsetree.pof_desc = copy_object_field_desc pof_desc;\n Ast_409.Parsetree.pof_loc = copy_location pof_loc;\n Ast_409.Parsetree.pof_attributes = copy_attributes pof_attributes;\n }\n\nand copy_attributes :\n Ast_408.Parsetree.attributes -> Ast_409.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : Ast_408.Parsetree.attribute -> Ast_409.Parsetree.attribute\n =\n fun {\n Ast_408.Parsetree.attr_name;\n Ast_408.Parsetree.attr_payload;\n Ast_408.Parsetree.attr_loc;\n } ->\n {\n Ast_409.Parsetree.attr_name = copy_loc (fun x -> x) attr_name;\n Ast_409.Parsetree.attr_payload = copy_payload attr_payload;\n Ast_409.Parsetree.attr_loc = copy_location attr_loc;\n }\n\nand copy_payload : Ast_408.Parsetree.payload -> Ast_409.Parsetree.payload =\n function\n | Ast_408.Parsetree.PStr x0 -> Ast_409.Parsetree.PStr (copy_structure x0)\n | Ast_408.Parsetree.PSig x0 -> Ast_409.Parsetree.PSig (copy_signature x0)\n | Ast_408.Parsetree.PTyp x0 -> Ast_409.Parsetree.PTyp (copy_core_type x0)\n | Ast_408.Parsetree.PPat (x0, x1) ->\n Ast_409.Parsetree.PPat (copy_pattern x0, Option.map copy_expression x1)\n\nand copy_structure : Ast_408.Parsetree.structure -> Ast_409.Parsetree.structure\n =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n Ast_408.Parsetree.structure_item -> Ast_409.Parsetree.structure_item =\n fun { Ast_408.Parsetree.pstr_desc; Ast_408.Parsetree.pstr_loc } ->\n {\n Ast_409.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n Ast_409.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n Ast_408.Parsetree.structure_item_desc ->\n Ast_409.Parsetree.structure_item_desc = function\n | Ast_408.Parsetree.Pstr_eval (x0, x1) ->\n Ast_409.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | Ast_408.Parsetree.Pstr_value (x0, x1) ->\n Ast_409.Parsetree.Pstr_value\n (copy_rec_flag x0, List.map copy_value_binding x1)\n | Ast_408.Parsetree.Pstr_primitive x0 ->\n Ast_409.Parsetree.Pstr_primitive (copy_value_description x0)\n | Ast_408.Parsetree.Pstr_type (x0, x1) ->\n Ast_409.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_408.Parsetree.Pstr_typext x0 ->\n Ast_409.Parsetree.Pstr_typext (copy_type_extension x0)\n | Ast_408.Parsetree.Pstr_exception x0 ->\n Ast_409.Parsetree.Pstr_exception (copy_type_exception x0)\n | Ast_408.Parsetree.Pstr_module x0 ->\n Ast_409.Parsetree.Pstr_module (copy_module_binding x0)\n | Ast_408.Parsetree.Pstr_recmodule x0 ->\n Ast_409.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | Ast_408.Parsetree.Pstr_modtype x0 ->\n Ast_409.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | Ast_408.Parsetree.Pstr_open x0 ->\n Ast_409.Parsetree.Pstr_open (copy_open_declaration x0)\n | Ast_408.Parsetree.Pstr_class x0 ->\n Ast_409.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | Ast_408.Parsetree.Pstr_class_type x0 ->\n Ast_409.Parsetree.Pstr_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_408.Parsetree.Pstr_include x0 ->\n Ast_409.Parsetree.Pstr_include (copy_include_declaration x0)\n | Ast_408.Parsetree.Pstr_attribute x0 ->\n Ast_409.Parsetree.Pstr_attribute (copy_attribute x0)\n | Ast_408.Parsetree.Pstr_extension (x0, x1) ->\n Ast_409.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n Ast_408.Parsetree.include_declaration ->\n Ast_409.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n Ast_408.Parsetree.class_declaration -> Ast_409.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr :\n Ast_408.Parsetree.class_expr -> Ast_409.Parsetree.class_expr =\n fun {\n Ast_408.Parsetree.pcl_desc;\n Ast_408.Parsetree.pcl_loc;\n Ast_408.Parsetree.pcl_attributes;\n } ->\n {\n Ast_409.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n Ast_409.Parsetree.pcl_loc = copy_location pcl_loc;\n Ast_409.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n Ast_408.Parsetree.class_expr_desc -> Ast_409.Parsetree.class_expr_desc =\n function\n | Ast_408.Parsetree.Pcl_constr (x0, x1) ->\n Ast_409.Parsetree.Pcl_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_408.Parsetree.Pcl_structure x0 ->\n Ast_409.Parsetree.Pcl_structure (copy_class_structure x0)\n | Ast_408.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n Ast_409.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n Option.map copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | Ast_408.Parsetree.Pcl_apply (x0, x1) ->\n Ast_409.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | Ast_408.Parsetree.Pcl_let (x0, x1, x2) ->\n Ast_409.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | Ast_408.Parsetree.Pcl_constraint (x0, x1) ->\n Ast_409.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | Ast_408.Parsetree.Pcl_extension x0 ->\n Ast_409.Parsetree.Pcl_extension (copy_extension x0)\n | Ast_408.Parsetree.Pcl_open (x0, x1) ->\n Ast_409.Parsetree.Pcl_open (copy_open_description x0, copy_class_expr x1)\n\nand copy_class_structure :\n Ast_408.Parsetree.class_structure -> Ast_409.Parsetree.class_structure =\n fun { Ast_408.Parsetree.pcstr_self; Ast_408.Parsetree.pcstr_fields } ->\n {\n Ast_409.Parsetree.pcstr_self = copy_pattern pcstr_self;\n Ast_409.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field :\n Ast_408.Parsetree.class_field -> Ast_409.Parsetree.class_field =\n fun {\n Ast_408.Parsetree.pcf_desc;\n Ast_408.Parsetree.pcf_loc;\n Ast_408.Parsetree.pcf_attributes;\n } ->\n {\n Ast_409.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n Ast_409.Parsetree.pcf_loc = copy_location pcf_loc;\n Ast_409.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n Ast_408.Parsetree.class_field_desc -> Ast_409.Parsetree.class_field_desc =\n function\n | Ast_408.Parsetree.Pcf_inherit (x0, x1, x2) ->\n Ast_409.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n Option.map (fun x -> copy_loc (fun x -> x) x) x2 )\n | Ast_408.Parsetree.Pcf_val x0 ->\n Ast_409.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | Ast_408.Parsetree.Pcf_method x0 ->\n Ast_409.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | Ast_408.Parsetree.Pcf_constraint x0 ->\n Ast_409.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_408.Parsetree.Pcf_initializer x0 ->\n Ast_409.Parsetree.Pcf_initializer (copy_expression x0)\n | Ast_408.Parsetree.Pcf_attribute x0 ->\n Ast_409.Parsetree.Pcf_attribute (copy_attribute x0)\n | Ast_408.Parsetree.Pcf_extension x0 ->\n Ast_409.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n Ast_408.Parsetree.class_field_kind -> Ast_409.Parsetree.class_field_kind =\n function\n | Ast_408.Parsetree.Cfk_virtual x0 ->\n Ast_409.Parsetree.Cfk_virtual (copy_core_type x0)\n | Ast_408.Parsetree.Cfk_concrete (x0, x1) ->\n Ast_409.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_open_declaration :\n Ast_408.Parsetree.open_declaration -> Ast_409.Parsetree.open_declaration =\n fun x -> copy_open_infos copy_module_expr x\n\nand copy_module_binding :\n Ast_408.Parsetree.module_binding -> Ast_409.Parsetree.module_binding =\n fun {\n Ast_408.Parsetree.pmb_name;\n Ast_408.Parsetree.pmb_expr;\n Ast_408.Parsetree.pmb_attributes;\n Ast_408.Parsetree.pmb_loc;\n } ->\n {\n Ast_409.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n Ast_409.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n Ast_409.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n Ast_409.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr :\n Ast_408.Parsetree.module_expr -> Ast_409.Parsetree.module_expr =\n fun {\n Ast_408.Parsetree.pmod_desc;\n Ast_408.Parsetree.pmod_loc;\n Ast_408.Parsetree.pmod_attributes;\n } ->\n {\n Ast_409.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n Ast_409.Parsetree.pmod_loc = copy_location pmod_loc;\n Ast_409.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n Ast_408.Parsetree.module_expr_desc -> Ast_409.Parsetree.module_expr_desc =\n function\n | Ast_408.Parsetree.Pmod_ident x0 ->\n Ast_409.Parsetree.Pmod_ident (copy_loc copy_Longident_t x0)\n | Ast_408.Parsetree.Pmod_structure x0 ->\n Ast_409.Parsetree.Pmod_structure (copy_structure x0)\n | Ast_408.Parsetree.Pmod_functor (x0, x1, x2) ->\n Ast_409.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n Option.map copy_module_type x1,\n copy_module_expr x2 )\n | Ast_408.Parsetree.Pmod_apply (x0, x1) ->\n Ast_409.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | Ast_408.Parsetree.Pmod_constraint (x0, x1) ->\n Ast_409.Parsetree.Pmod_constraint\n (copy_module_expr x0, copy_module_type x1)\n | Ast_408.Parsetree.Pmod_unpack x0 ->\n Ast_409.Parsetree.Pmod_unpack (copy_expression x0)\n | Ast_408.Parsetree.Pmod_extension x0 ->\n Ast_409.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type :\n Ast_408.Parsetree.module_type -> Ast_409.Parsetree.module_type =\n fun {\n Ast_408.Parsetree.pmty_desc;\n Ast_408.Parsetree.pmty_loc;\n Ast_408.Parsetree.pmty_attributes;\n } ->\n {\n Ast_409.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n Ast_409.Parsetree.pmty_loc = copy_location pmty_loc;\n Ast_409.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n Ast_408.Parsetree.module_type_desc -> Ast_409.Parsetree.module_type_desc =\n function\n | Ast_408.Parsetree.Pmty_ident x0 ->\n Ast_409.Parsetree.Pmty_ident (copy_loc copy_Longident_t x0)\n | Ast_408.Parsetree.Pmty_signature x0 ->\n Ast_409.Parsetree.Pmty_signature (copy_signature x0)\n | Ast_408.Parsetree.Pmty_functor (x0, x1, x2) ->\n Ast_409.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n Option.map copy_module_type x1,\n copy_module_type x2 )\n | Ast_408.Parsetree.Pmty_with (x0, x1) ->\n Ast_409.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | Ast_408.Parsetree.Pmty_typeof x0 ->\n Ast_409.Parsetree.Pmty_typeof (copy_module_expr x0)\n | Ast_408.Parsetree.Pmty_extension x0 ->\n Ast_409.Parsetree.Pmty_extension (copy_extension x0)\n | Ast_408.Parsetree.Pmty_alias x0 ->\n Ast_409.Parsetree.Pmty_alias (copy_loc copy_Longident_t x0)\n\nand copy_with_constraint :\n Ast_408.Parsetree.with_constraint -> Ast_409.Parsetree.with_constraint =\n function\n | Ast_408.Parsetree.Pwith_type (x0, x1) ->\n Ast_409.Parsetree.Pwith_type\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_408.Parsetree.Pwith_module (x0, x1) ->\n Ast_409.Parsetree.Pwith_module\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n | Ast_408.Parsetree.Pwith_typesubst (x0, x1) ->\n Ast_409.Parsetree.Pwith_typesubst\n (copy_loc copy_Longident_t x0, copy_type_declaration x1)\n | Ast_408.Parsetree.Pwith_modsubst (x0, x1) ->\n Ast_409.Parsetree.Pwith_modsubst\n (copy_loc copy_Longident_t x0, copy_loc copy_Longident_t x1)\n\nand copy_signature : Ast_408.Parsetree.signature -> Ast_409.Parsetree.signature\n =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n Ast_408.Parsetree.signature_item -> Ast_409.Parsetree.signature_item =\n fun { Ast_408.Parsetree.psig_desc; Ast_408.Parsetree.psig_loc } ->\n {\n Ast_409.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n Ast_409.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n Ast_408.Parsetree.signature_item_desc ->\n Ast_409.Parsetree.signature_item_desc = function\n | Ast_408.Parsetree.Psig_value x0 ->\n Ast_409.Parsetree.Psig_value (copy_value_description x0)\n | Ast_408.Parsetree.Psig_type (x0, x1) ->\n Ast_409.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | Ast_408.Parsetree.Psig_typesubst x0 ->\n Ast_409.Parsetree.Psig_typesubst (List.map copy_type_declaration x0)\n | Ast_408.Parsetree.Psig_typext x0 ->\n Ast_409.Parsetree.Psig_typext (copy_type_extension x0)\n | Ast_408.Parsetree.Psig_exception x0 ->\n Ast_409.Parsetree.Psig_exception (copy_type_exception x0)\n | Ast_408.Parsetree.Psig_module x0 ->\n Ast_409.Parsetree.Psig_module (copy_module_declaration x0)\n | Ast_408.Parsetree.Psig_modsubst x0 ->\n Ast_409.Parsetree.Psig_modsubst (copy_module_substitution x0)\n | Ast_408.Parsetree.Psig_recmodule x0 ->\n Ast_409.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | Ast_408.Parsetree.Psig_modtype x0 ->\n Ast_409.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | Ast_408.Parsetree.Psig_open x0 ->\n Ast_409.Parsetree.Psig_open (copy_open_description x0)\n | Ast_408.Parsetree.Psig_include x0 ->\n Ast_409.Parsetree.Psig_include (copy_include_description x0)\n | Ast_408.Parsetree.Psig_class x0 ->\n Ast_409.Parsetree.Psig_class (List.map copy_class_description x0)\n | Ast_408.Parsetree.Psig_class_type x0 ->\n Ast_409.Parsetree.Psig_class_type\n (List.map copy_class_type_declaration x0)\n | Ast_408.Parsetree.Psig_attribute x0 ->\n Ast_409.Parsetree.Psig_attribute (copy_attribute x0)\n | Ast_408.Parsetree.Psig_extension (x0, x1) ->\n Ast_409.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n Ast_408.Parsetree.class_type_declaration ->\n Ast_409.Parsetree.class_type_declaration =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n Ast_408.Parsetree.class_description -> Ast_409.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type :\n Ast_408.Parsetree.class_type -> Ast_409.Parsetree.class_type =\n fun {\n Ast_408.Parsetree.pcty_desc;\n Ast_408.Parsetree.pcty_loc;\n Ast_408.Parsetree.pcty_attributes;\n } ->\n {\n Ast_409.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n Ast_409.Parsetree.pcty_loc = copy_location pcty_loc;\n Ast_409.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n Ast_408.Parsetree.class_type_desc -> Ast_409.Parsetree.class_type_desc =\n function\n | Ast_408.Parsetree.Pcty_constr (x0, x1) ->\n Ast_409.Parsetree.Pcty_constr\n (copy_loc copy_Longident_t x0, List.map copy_core_type x1)\n | Ast_408.Parsetree.Pcty_signature x0 ->\n Ast_409.Parsetree.Pcty_signature (copy_class_signature x0)\n | Ast_408.Parsetree.Pcty_arrow (x0, x1, x2) ->\n Ast_409.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | Ast_408.Parsetree.Pcty_extension x0 ->\n Ast_409.Parsetree.Pcty_extension (copy_extension x0)\n | Ast_408.Parsetree.Pcty_open (x0, x1) ->\n Ast_409.Parsetree.Pcty_open (copy_open_description x0, copy_class_type x1)\n\nand copy_class_signature :\n Ast_408.Parsetree.class_signature -> Ast_409.Parsetree.class_signature =\n fun { Ast_408.Parsetree.pcsig_self; Ast_408.Parsetree.pcsig_fields } ->\n {\n Ast_409.Parsetree.pcsig_self = copy_core_type pcsig_self;\n Ast_409.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n Ast_408.Parsetree.class_type_field -> Ast_409.Parsetree.class_type_field =\n fun {\n Ast_408.Parsetree.pctf_desc;\n Ast_408.Parsetree.pctf_loc;\n Ast_408.Parsetree.pctf_attributes;\n } ->\n {\n Ast_409.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n Ast_409.Parsetree.pctf_loc = copy_location pctf_loc;\n Ast_409.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n Ast_408.Parsetree.class_type_field_desc ->\n Ast_409.Parsetree.class_type_field_desc = function\n | Ast_408.Parsetree.Pctf_inherit x0 ->\n Ast_409.Parsetree.Pctf_inherit (copy_class_type x0)\n | Ast_408.Parsetree.Pctf_val x0 ->\n Ast_409.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_408.Parsetree.Pctf_method x0 ->\n Ast_409.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | Ast_408.Parsetree.Pctf_constraint x0 ->\n Ast_409.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | Ast_408.Parsetree.Pctf_attribute x0 ->\n Ast_409.Parsetree.Pctf_attribute (copy_attribute x0)\n | Ast_408.Parsetree.Pctf_extension x0 ->\n Ast_409.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : Ast_408.Parsetree.extension -> Ast_409.Parsetree.extension\n =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_408.Parsetree.class_infos ->\n 'g0 Ast_409.Parsetree.class_infos =\n fun f0\n {\n Ast_408.Parsetree.pci_virt;\n Ast_408.Parsetree.pci_params;\n Ast_408.Parsetree.pci_name;\n Ast_408.Parsetree.pci_expr;\n Ast_408.Parsetree.pci_loc;\n Ast_408.Parsetree.pci_attributes;\n } ->\n {\n Ast_409.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n Ast_409.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n Ast_409.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n Ast_409.Parsetree.pci_expr = f0 pci_expr;\n Ast_409.Parsetree.pci_loc = copy_location pci_loc;\n Ast_409.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag :\n Ast_408.Asttypes.virtual_flag -> Ast_409.Asttypes.virtual_flag = function\n | Ast_408.Asttypes.Virtual -> Ast_409.Asttypes.Virtual\n | Ast_408.Asttypes.Concrete -> Ast_409.Asttypes.Concrete\n\nand copy_include_description :\n Ast_408.Parsetree.include_description ->\n Ast_409.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_408.Parsetree.include_infos ->\n 'g0 Ast_409.Parsetree.include_infos =\n fun f0\n {\n Ast_408.Parsetree.pincl_mod;\n Ast_408.Parsetree.pincl_loc;\n Ast_408.Parsetree.pincl_attributes;\n } ->\n {\n Ast_409.Parsetree.pincl_mod = f0 pincl_mod;\n Ast_409.Parsetree.pincl_loc = copy_location pincl_loc;\n Ast_409.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n Ast_408.Parsetree.open_description -> Ast_409.Parsetree.open_description =\n fun x -> copy_open_infos (fun x -> copy_loc copy_Longident_t x) x\n\nand copy_open_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 Ast_408.Parsetree.open_infos ->\n 'g0 Ast_409.Parsetree.open_infos =\n fun f0\n {\n Ast_408.Parsetree.popen_expr;\n Ast_408.Parsetree.popen_override;\n Ast_408.Parsetree.popen_loc;\n Ast_408.Parsetree.popen_attributes;\n } ->\n {\n Ast_409.Parsetree.popen_expr = f0 popen_expr;\n Ast_409.Parsetree.popen_override = copy_override_flag popen_override;\n Ast_409.Parsetree.popen_loc = copy_location popen_loc;\n Ast_409.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n Ast_408.Asttypes.override_flag -> Ast_409.Asttypes.override_flag = function\n | Ast_408.Asttypes.Override -> Ast_409.Asttypes.Override\n | Ast_408.Asttypes.Fresh -> Ast_409.Asttypes.Fresh\n\nand copy_module_type_declaration :\n Ast_408.Parsetree.module_type_declaration ->\n Ast_409.Parsetree.module_type_declaration =\n fun {\n Ast_408.Parsetree.pmtd_name;\n Ast_408.Parsetree.pmtd_type;\n Ast_408.Parsetree.pmtd_attributes;\n Ast_408.Parsetree.pmtd_loc;\n } ->\n {\n Ast_409.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n Ast_409.Parsetree.pmtd_type = Option.map copy_module_type pmtd_type;\n Ast_409.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n Ast_409.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_substitution :\n Ast_408.Parsetree.module_substitution ->\n Ast_409.Parsetree.module_substitution =\n fun {\n Ast_408.Parsetree.pms_name;\n Ast_408.Parsetree.pms_manifest;\n Ast_408.Parsetree.pms_attributes;\n Ast_408.Parsetree.pms_loc;\n } ->\n {\n Ast_409.Parsetree.pms_name = copy_loc (fun x -> x) pms_name;\n Ast_409.Parsetree.pms_manifest = copy_loc copy_Longident_t pms_manifest;\n Ast_409.Parsetree.pms_attributes = copy_attributes pms_attributes;\n Ast_409.Parsetree.pms_loc = copy_location pms_loc;\n }\n\nand copy_module_declaration :\n Ast_408.Parsetree.module_declaration -> Ast_409.Parsetree.module_declaration\n =\n fun {\n Ast_408.Parsetree.pmd_name;\n Ast_408.Parsetree.pmd_type;\n Ast_408.Parsetree.pmd_attributes;\n Ast_408.Parsetree.pmd_loc;\n } ->\n {\n Ast_409.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n Ast_409.Parsetree.pmd_type = copy_module_type pmd_type;\n Ast_409.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n Ast_409.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_exception :\n Ast_408.Parsetree.type_exception -> Ast_409.Parsetree.type_exception =\n fun {\n Ast_408.Parsetree.ptyexn_constructor;\n Ast_408.Parsetree.ptyexn_loc;\n Ast_408.Parsetree.ptyexn_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyexn_constructor =\n copy_extension_constructor ptyexn_constructor;\n Ast_409.Parsetree.ptyexn_loc = copy_location ptyexn_loc;\n Ast_409.Parsetree.ptyexn_attributes = copy_attributes ptyexn_attributes;\n }\n\nand copy_type_extension :\n Ast_408.Parsetree.type_extension -> Ast_409.Parsetree.type_extension =\n fun {\n Ast_408.Parsetree.ptyext_path;\n Ast_408.Parsetree.ptyext_params;\n Ast_408.Parsetree.ptyext_constructors;\n Ast_408.Parsetree.ptyext_private;\n Ast_408.Parsetree.ptyext_loc;\n Ast_408.Parsetree.ptyext_attributes;\n } ->\n {\n Ast_409.Parsetree.ptyext_path = copy_loc copy_Longident_t ptyext_path;\n Ast_409.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n Ast_409.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n Ast_409.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n Ast_409.Parsetree.ptyext_loc = copy_location ptyext_loc;\n Ast_409.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n Ast_408.Parsetree.extension_constructor ->\n Ast_409.Parsetree.extension_constructor =\n fun {\n Ast_408.Parsetree.pext_name;\n Ast_408.Parsetree.pext_kind;\n Ast_408.Parsetree.pext_loc;\n Ast_408.Parsetree.pext_attributes;\n } ->\n {\n Ast_409.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n Ast_409.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n Ast_409.Parsetree.pext_loc = copy_location pext_loc;\n Ast_409.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n Ast_408.Parsetree.extension_constructor_kind ->\n Ast_409.Parsetree.extension_constructor_kind = function\n | Ast_408.Parsetree.Pext_decl (x0, x1) ->\n Ast_409.Parsetree.Pext_decl\n (copy_constructor_arguments x0, Option.map copy_core_type x1)\n | Ast_408.Parsetree.Pext_rebind x0 ->\n Ast_409.Parsetree.Pext_rebind (copy_loc copy_Longident_t x0)\n\nand copy_type_declaration :\n Ast_408.Parsetree.type_declaration -> Ast_409.Parsetree.type_declaration =\n fun {\n Ast_408.Parsetree.ptype_name;\n Ast_408.Parsetree.ptype_params;\n Ast_408.Parsetree.ptype_cstrs;\n Ast_408.Parsetree.ptype_kind;\n Ast_408.Parsetree.ptype_private;\n Ast_408.Parsetree.ptype_manifest;\n Ast_408.Parsetree.ptype_attributes;\n Ast_408.Parsetree.ptype_loc;\n } ->\n {\n Ast_409.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n Ast_409.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n Ast_409.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n Ast_409.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n Ast_409.Parsetree.ptype_private = copy_private_flag ptype_private;\n Ast_409.Parsetree.ptype_manifest = Option.map copy_core_type ptype_manifest;\n Ast_409.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n Ast_409.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag :\n Ast_408.Asttypes.private_flag -> Ast_409.Asttypes.private_flag = function\n | Ast_408.Asttypes.Private -> Ast_409.Asttypes.Private\n | Ast_408.Asttypes.Public -> Ast_409.Asttypes.Public\n\nand copy_type_kind : Ast_408.Parsetree.type_kind -> Ast_409.Parsetree.type_kind\n = function\n | Ast_408.Parsetree.Ptype_abstract -> Ast_409.Parsetree.Ptype_abstract\n | Ast_408.Parsetree.Ptype_variant x0 ->\n Ast_409.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | Ast_408.Parsetree.Ptype_record x0 ->\n Ast_409.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | Ast_408.Parsetree.Ptype_open -> Ast_409.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n Ast_408.Parsetree.constructor_declaration ->\n Ast_409.Parsetree.constructor_declaration =\n fun {\n Ast_408.Parsetree.pcd_name;\n Ast_408.Parsetree.pcd_args;\n Ast_408.Parsetree.pcd_res;\n Ast_408.Parsetree.pcd_loc;\n Ast_408.Parsetree.pcd_attributes;\n } ->\n {\n Ast_409.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n Ast_409.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n Ast_409.Parsetree.pcd_res = Option.map copy_core_type pcd_res;\n Ast_409.Parsetree.pcd_loc = copy_location pcd_loc;\n Ast_409.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n Ast_408.Parsetree.constructor_arguments ->\n Ast_409.Parsetree.constructor_arguments = function\n | Ast_408.Parsetree.Pcstr_tuple x0 ->\n Ast_409.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | Ast_408.Parsetree.Pcstr_record x0 ->\n Ast_409.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n Ast_408.Parsetree.label_declaration -> Ast_409.Parsetree.label_declaration =\n fun {\n Ast_408.Parsetree.pld_name;\n Ast_408.Parsetree.pld_mutable;\n Ast_408.Parsetree.pld_type;\n Ast_408.Parsetree.pld_loc;\n Ast_408.Parsetree.pld_attributes;\n } ->\n {\n Ast_409.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n Ast_409.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n Ast_409.Parsetree.pld_type = copy_core_type pld_type;\n Ast_409.Parsetree.pld_loc = copy_location pld_loc;\n Ast_409.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag :\n Ast_408.Asttypes.mutable_flag -> Ast_409.Asttypes.mutable_flag = function\n | Ast_408.Asttypes.Immutable -> Ast_409.Asttypes.Immutable\n | Ast_408.Asttypes.Mutable -> Ast_409.Asttypes.Mutable\n\nand copy_variance : Ast_408.Asttypes.variance -> Ast_409.Asttypes.variance =\n function\n | Ast_408.Asttypes.Covariant -> Ast_409.Asttypes.Covariant\n | Ast_408.Asttypes.Contravariant -> Ast_409.Asttypes.Contravariant\n | Ast_408.Asttypes.Invariant -> Ast_409.Asttypes.Invariant\n\nand copy_value_description :\n Ast_408.Parsetree.value_description -> Ast_409.Parsetree.value_description =\n fun {\n Ast_408.Parsetree.pval_name;\n Ast_408.Parsetree.pval_type;\n Ast_408.Parsetree.pval_prim;\n Ast_408.Parsetree.pval_attributes;\n Ast_408.Parsetree.pval_loc;\n } ->\n {\n Ast_409.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n Ast_409.Parsetree.pval_type = copy_core_type pval_type;\n Ast_409.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n Ast_409.Parsetree.pval_attributes = copy_attributes pval_attributes;\n Ast_409.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_object_field_desc :\n Ast_408.Parsetree.object_field_desc -> Ast_409.Parsetree.object_field_desc =\n function\n | Ast_408.Parsetree.Otag (x0, x1) ->\n Ast_409.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x1)\n | Ast_408.Parsetree.Oinherit x0 ->\n Ast_409.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_arg_label : Ast_408.Asttypes.arg_label -> Ast_409.Asttypes.arg_label =\n function\n | Ast_408.Asttypes.Nolabel -> Ast_409.Asttypes.Nolabel\n | Ast_408.Asttypes.Labelled x0 -> Ast_409.Asttypes.Labelled x0\n | Ast_408.Asttypes.Optional x0 -> Ast_409.Asttypes.Optional x0\n\nand copy_closed_flag :\n Ast_408.Asttypes.closed_flag -> Ast_409.Asttypes.closed_flag = function\n | Ast_408.Asttypes.Closed -> Ast_409.Asttypes.Closed\n | Ast_408.Asttypes.Open -> Ast_409.Asttypes.Open\n\nand copy_label : Ast_408.Asttypes.label -> Ast_409.Asttypes.label = fun x -> x\n\nand copy_rec_flag : Ast_408.Asttypes.rec_flag -> Ast_409.Asttypes.rec_flag =\n function\n | Ast_408.Asttypes.Nonrecursive -> Ast_409.Asttypes.Nonrecursive\n | Ast_408.Asttypes.Recursive -> Ast_409.Asttypes.Recursive\n\nand copy_constant : Ast_408.Parsetree.constant -> Ast_409.Parsetree.constant =\n function\n | Ast_408.Parsetree.Pconst_integer (x0, x1) ->\n Ast_409.Parsetree.Pconst_integer (x0, Option.map (fun x -> x) x1)\n | Ast_408.Parsetree.Pconst_char x0 -> Ast_409.Parsetree.Pconst_char x0\n | Ast_408.Parsetree.Pconst_string (x0, x1) ->\n Ast_409.Parsetree.Pconst_string (x0, Option.map (fun x -> x) x1)\n | Ast_408.Parsetree.Pconst_float (x0, x1) ->\n Ast_409.Parsetree.Pconst_float (x0, Option.map (fun x -> x) x1)\n\nand copy_Longident_t : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0.\n ('f0 -> 'g0) -> 'f0 Ast_408.Asttypes.loc -> 'g0 Ast_409.Asttypes.loc =\n fun f0 { Ast_408.Asttypes.txt; Ast_408.Asttypes.loc } ->\n { Ast_409.Asttypes.txt = f0 txt; Ast_409.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\n","module From = Ast_408\nmodule To = Ast_407\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.08\" missing_feature\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir\n {\n From.Parsetree.pdir_name;\n From.Parsetree.pdir_arg;\n From.Parsetree.pdir_loc = _;\n } ->\n To.Parsetree.Ptop_dir\n ( pdir_name.Location.txt,\n match pdir_arg with\n | None -> To.Parsetree.Pdir_none\n | Some arg -> copy_directive_argument arg )\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n fun { From.Parsetree.pdira_desc; From.Parsetree.pdira_loc = _pdira_loc } ->\n copy_directive_argument_desc pdira_desc\n\nand copy_directive_argument_desc :\n From.Parsetree.directive_argument_desc -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nand copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_loc_stack = _;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc copy_label x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1) -> (\n match x0.From.Parsetree.popen_expr.From.Parsetree.pmod_desc with\n | Pmod_ident lid ->\n To.Parsetree.Pexp_open\n ( copy_override_flag x0.From.Parsetree.popen_override,\n copy_loc copy_longident lid,\n copy_expression x1 )\n | Pmod_structure _ | Pmod_functor _ | Pmod_apply _ | Pmod_constraint _\n | Pmod_unpack _ | Pmod_extension _ ->\n migration_error x0.From.Parsetree.popen_loc \"complex open\")\n | From.Parsetree.Pexp_letop { let_; ands = _; body = _ } ->\n migration_error let_.pbop_op.loc \"let operators\"\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_loc_stack = _;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_loc_stack = _;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n fun {\n From.Parsetree.prf_desc;\n From.Parsetree.prf_loc = _;\n From.Parsetree.prf_attributes;\n } ->\n match prf_desc with\n | From.Parsetree.Rtag (x0, x1, x2) ->\n To.Parsetree.Rtag\n ( copy_loc copy_label x0,\n copy_attributes prf_attributes,\n copy_bool x1,\n List.map copy_core_type x2 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field : From.Parsetree.object_field -> To.Parsetree.object_field\n =\n fun {\n From.Parsetree.pof_desc;\n From.Parsetree.pof_loc = _;\n From.Parsetree.pof_attributes;\n } ->\n match pof_desc with\n | From.Parsetree.Otag (x0, x1) ->\n To.Parsetree.Otag\n ( copy_loc copy_label x0,\n copy_attributes pof_attributes,\n copy_core_type x1 )\n | From.Parsetree.Oinherit x0 -> To.Parsetree.Oinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun {\n From.Parsetree.attr_name;\n From.Parsetree.attr_payload;\n From.Parsetree.attr_loc = _;\n } ->\n (copy_loc (fun x -> x) attr_name, copy_payload attr_payload)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception\n (let e =\n copy_extension_constructor x0.From.Parsetree.ptyexn_constructor\n in\n {\n e with\n pext_attributes =\n e.pext_attributes @ copy_attributes x0.ptyexn_attributes;\n })\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 -> (\n match x0.From.Parsetree.popen_expr.From.Parsetree.pmod_desc with\n | Pmod_ident lid ->\n To.Parsetree.Pstr_open\n {\n To.Parsetree.popen_lid = copy_loc copy_longident lid;\n To.Parsetree.popen_override =\n copy_override_flag x0.From.Parsetree.popen_override;\n To.Parsetree.popen_loc = copy_location x0.From.Parsetree.popen_loc;\n To.Parsetree.popen_attributes =\n copy_attributes x0.From.Parsetree.popen_attributes;\n }\n | Pmod_structure _ | Pmod_functor _ | Pmod_apply _ | Pmod_constraint _\n | Pmod_unpack _ | Pmod_extension _ ->\n migration_error x0.From.Parsetree.popen_loc \"complex open\")\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n | From.Parsetree.Pcl_open (x0, x1) ->\n To.Parsetree.Pcl_open\n ( copy_override_flag x0.From.Parsetree.popen_override,\n copy_loc copy_longident x0.From.Parsetree.popen_expr,\n copy_class_expr x1 )\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (fun x -> copy_loc (fun x -> x) x) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst (x0, x1) ->\n To.Parsetree.Pwith_typesubst\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typesubst x0 ->\n let x0_loc =\n match x0 with\n | [] -> Location.none\n | { From.Parsetree.ptype_loc; _ } :: _ -> ptype_loc\n in\n migration_error x0_loc \"type substitution in signatures\"\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception\n (let e =\n copy_extension_constructor x0.From.Parsetree.ptyexn_constructor\n in\n {\n e with\n pext_attributes =\n e.pext_attributes @ copy_attributes x0.ptyexn_attributes;\n })\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_modsubst x0 ->\n migration_error x0.pms_loc \"module substitution in signatures\"\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n | From.Parsetree.Pcty_open (x0, x1) ->\n To.Parsetree.Pcty_open\n ( copy_override_flag x0.From.Parsetree.popen_override,\n copy_loc copy_longident x0.From.Parsetree.popen_expr,\n copy_class_type x1 )\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n let x1 =\n match x0.txt with\n | \"ocaml.error\" | \"error\" -> (\n match x1 with\n | PStr (hd :: tl) -> From.Parsetree.PStr (hd :: hd :: tl)\n | _ -> x1)\n | _ -> x1\n in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_expr;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_expr;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\n(* and copy_type_exception :\n From.Parsetree.type_exception -> To.Parsetree.type_exception =\n fun\n { From.Parsetree.ptyexn_constructor = ptyexn_constructor;\n From.Parsetree.ptyexn_loc = ptyexn_loc;\n From.Parsetree.ptyexn_attributes = ptyexn_attributes }\n ->\n {\n To.Parsetree.ptyexn_constructor =\n (copy_extension_constructor ptyexn_constructor);\n To.Parsetree.ptyexn_loc = (copy_location ptyexn_loc);\n To.Parsetree.ptyexn_attributes =\n (copy_attributes ptyexn_attributes)\n }*)\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_loc = _;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","module From = Ast_407\nmodule To = Ast_408\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir\n {\n To.Parsetree.pdir_name =\n { Location.txt = x0; Location.loc = Location.none };\n To.Parsetree.pdir_arg = copy_directive_argument x1;\n To.Parsetree.pdir_loc = Location.none;\n }\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument option\n =\n let wrap pdira_desc =\n Some { To.Parsetree.pdira_desc; To.Parsetree.pdira_loc = Location.none }\n in\n function\n | From.Parsetree.Pdir_none -> None\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0 |> wrap\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1) |> wrap\n | From.Parsetree.Pdir_ident x0 ->\n To.Parsetree.Pdir_ident (copy_longident x0) |> wrap\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0) |> wrap\n\nand copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_loc_stack = [];\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc copy_label x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc copy_label x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_label x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n ( {\n To.Parsetree.popen_expr =\n {\n To.Parsetree.pmod_desc =\n To.Parsetree.Pmod_ident (copy_loc copy_longident x1);\n To.Parsetree.pmod_loc = x1.Location.loc;\n To.Parsetree.pmod_attributes = [];\n };\n To.Parsetree.popen_override = copy_override_flag x0;\n To.Parsetree.popen_loc = x1.Location.loc;\n To.Parsetree.popen_attributes = [];\n },\n copy_expression x2 )\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_loc_stack = [];\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_loc_stack = [];\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n {\n To.Parsetree.prf_desc =\n To.Parsetree.Rtag\n (copy_loc copy_label x0, copy_bool x2, List.map copy_core_type x3);\n To.Parsetree.prf_loc = x0.Location.loc;\n To.Parsetree.prf_attributes = copy_attributes x1;\n }\n | From.Parsetree.Rinherit x0 ->\n {\n To.Parsetree.prf_desc = To.Parsetree.Rinherit (copy_core_type x0);\n To.Parsetree.prf_loc = x0.From.Parsetree.ptyp_loc;\n To.Parsetree.prf_attributes = [];\n }\n\nand copy_object_field : From.Parsetree.object_field -> To.Parsetree.object_field\n = function\n | From.Parsetree.Otag (x0, x1, x2) ->\n {\n To.Parsetree.pof_desc =\n To.Parsetree.Otag (copy_loc copy_label x0, copy_core_type x2);\n To.Parsetree.pof_loc = x0.Location.loc;\n To.Parsetree.pof_attributes = copy_attributes x1;\n }\n | From.Parsetree.Oinherit x0 ->\n {\n To.Parsetree.pof_desc = To.Parsetree.Oinherit (copy_core_type x0);\n To.Parsetree.pof_loc = x0.From.Parsetree.ptyp_loc;\n To.Parsetree.pof_attributes = [];\n }\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n {\n To.Parsetree.attr_name = copy_loc (fun x -> x) x0;\n To.Parsetree.attr_payload = copy_payload x1;\n To.Parsetree.attr_loc = x0.Location.loc;\n }\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n let atat, at =\n List.partition\n (function\n | { Location.txt = \"ocaml.deprecated\" | \"deprecated\"; _ }, _ ->\n false\n | _ -> true)\n x0.pext_attributes\n in\n let x0 = { x0 with pext_attributes = at } in\n To.Parsetree.Pstr_exception\n {\n To.Parsetree.ptyexn_constructor = copy_extension_constructor x0;\n To.Parsetree.ptyexn_loc = x0.From.Parsetree.pext_loc;\n To.Parsetree.ptyexn_attributes = copy_attributes atat;\n }\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open\n {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n To.Parsetree.Pstr_open\n {\n To.Parsetree.popen_expr =\n {\n To.Parsetree.pmod_desc =\n To.Parsetree.Pmod_ident (copy_loc copy_longident popen_lid);\n To.Parsetree.pmod_loc = popen_loc;\n To.Parsetree.pmod_attributes = [];\n };\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n | From.Parsetree.Pcl_open (x0, x1, x2) ->\n To.Parsetree.Pcl_open\n ( {\n To.Parsetree.popen_expr = copy_loc copy_longident x1;\n To.Parsetree.popen_override = copy_override_flag x0;\n To.Parsetree.popen_loc = x1.Location.loc;\n To.Parsetree.popen_attributes = [];\n },\n copy_class_expr x2 )\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n let fields =\n List.sort\n (fun (a : From.Parsetree.class_field) (b : From.Parsetree.class_field) ->\n compare a.pcf_loc.loc_start.pos_cnum b.pcf_loc.loc_start.pos_cnum)\n pcstr_fields\n in\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (fun x -> copy_loc (fun x -> x) x) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_mutable_flag x1, copy_class_field_kind x2))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n (copy_loc copy_label x0, copy_private_flag x1, copy_class_field_kind x2))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst (x0, x1) ->\n To.Parsetree.Pwith_typesubst\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n let atat, at =\n List.partition\n (function\n | { Location.txt = \"ocaml.deprecated\" | \"deprecated\"; _ }, _ ->\n false\n | _ -> true)\n x0.pext_attributes\n in\n let x0 = { x0 with pext_attributes = at } in\n\n To.Parsetree.Psig_exception\n {\n To.Parsetree.ptyexn_constructor = copy_extension_constructor x0;\n To.Parsetree.ptyexn_loc = x0.From.Parsetree.pext_loc;\n To.Parsetree.ptyexn_attributes = copy_attributes atat;\n }\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n | From.Parsetree.Pcty_open (x0, x1, x2) ->\n To.Parsetree.Pcty_open\n ( {\n To.Parsetree.popen_expr = copy_loc copy_longident x1;\n To.Parsetree.popen_override = copy_override_flag x0;\n To.Parsetree.popen_loc = x1.Location.loc;\n To.Parsetree.popen_attributes = [];\n },\n copy_class_type x2 )\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n let fields =\n List.sort\n (fun (a : From.Parsetree.class_type_field)\n (b : From.Parsetree.class_type_field) ->\n compare a.pctf_loc.loc_start.pos_cnum b.pctf_loc.loc_start.pos_cnum)\n pcsig_fields\n in\n\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc copy_label x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n let x1 =\n match x0.txt with\n | \"ocaml.error\" | \"error\" -> (\n match x1 with\n | PStr (hd :: _ :: tl) -> From.Parsetree.PStr (hd :: tl)\n | _ -> x1)\n | _ -> x1\n in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_expr = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_loc = ptyext_path.Location.loc;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_407\nmodule To = Ast_406\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_loc copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field : From.Parsetree.object_field -> To.Parsetree.object_field\n = function\n | From.Parsetree.Otag (x0, x1, x2) ->\n To.Parsetree.Otag\n (copy_loc (fun x -> x) x0, copy_attributes x1, copy_core_type x2)\n | From.Parsetree.Oinherit x -> To.Parsetree.Oinherit (copy_core_type x)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n | From.Parsetree.Pcl_open (ovf, loc, ce) ->\n To.Parsetree.Pcl_open\n (copy_override_flag ovf, copy_loc copy_longident loc, copy_class_expr ce)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (copy_loc (fun x -> x)) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst (x0, x1) ->\n To.Parsetree.Pwith_typesubst\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n | From.Parsetree.Pcty_open (ovf, loc, cty) ->\n To.Parsetree.Pcty_open\n ( copy_override_flag ovf,\n copy_loc copy_longident loc,\n copy_class_type cty )\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_406\nmodule To = Ast_407\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n (List.map copy_object_field x0, copy_closed_flag x1)\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_loc copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_object_field : From.Parsetree.object_field -> To.Parsetree.object_field\n = function\n | From.Parsetree.Otag (x0, x1, x2) ->\n To.Parsetree.Otag\n (copy_loc (fun x -> x) x0, copy_attributes x1, copy_core_type x2)\n | From.Parsetree.Oinherit x -> To.Parsetree.Oinherit (copy_core_type x)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n | From.Parsetree.Pcl_open (ovf, loc, ce) ->\n To.Parsetree.Pcl_open\n (copy_override_flag ovf, copy_loc copy_longident loc, copy_class_expr ce)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (copy_loc (fun x -> x)) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst (x0, x1) ->\n To.Parsetree.Pwith_typesubst\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n | From.Parsetree.Pcty_open (ovf, loc, cty) ->\n To.Parsetree.Pcty_open\n ( copy_override_flag ovf,\n copy_loc copy_longident loc,\n copy_class_type cty )\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_406\nmodule To = Ast_405\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.06\" missing_feature\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (function\n | From.Parsetree.Otag (x0, x1, x2) ->\n ( copy_loc (fun x -> x) x0,\n copy_attributes x1,\n copy_core_type x2 )\n | From.Parsetree.Oinherit _ ->\n migration_error Location.none \"inheritance in object type\")\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0.txt,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n | From.Parsetree.Pcl_open (_, loc, _) ->\n migration_error loc.Location.loc \"module open in class expression\"\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (copy_loc (fun x -> x)) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst ({ txt = Longident.Lident _; _ }, x0) ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst ({ txt = Longident.Lident x0; loc }, x1) ->\n To.Parsetree.Pwith_modsubst ({ txt = x0; loc }, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst ({ loc; _ }, _x0) ->\n migration_error loc \"type substitution inside a submodule\"\n | From.Parsetree.Pwith_modsubst ({ loc; _ }, _x1) ->\n migration_error loc \"module substitution inside a submodule\"\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n | From.Parsetree.Pcty_open (_, loc, _) ->\n migration_error loc.Location.loc \"module open in class type\"\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_405\nmodule To = Ast_406\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n To.Parsetree.Otag\n (copy_loc (fun x -> x) x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> copy_loc (fun x -> x) x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( { txt = copy_label x0; loc = Location.none },\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (copy_loc (fun x -> x)) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst\n ( copy_loc (fun x -> Longident.Lident x) x0.From.Parsetree.ptype_name,\n copy_type_declaration x0 )\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> Longident.Lident x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_405\nmodule To = Ast_404\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, x1.From.Asttypes.txt)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (x0.From.Asttypes.txt, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (x0.From.Asttypes.txt, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly\n (List.map (fun x -> x.From.Asttypes.txt) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (fun x -> x.From.Asttypes.txt) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( x0.From.Asttypes.txt,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( x0.From.Asttypes.txt,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_404\nmodule To = Ast_405\n\nlet noloc x = { Location.txt = x; loc = Location.none }\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, noloc x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception (x0, x1) ->\n To.Parsetree.Pexp_letexception\n (copy_extension_constructor x0, copy_expression x1)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (noloc x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open (x0, x1) ->\n To.Parsetree.Ppat_open (copy_loc copy_longident x0, copy_pattern x1)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (noloc x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly (List.map (fun x -> noloc x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n ( copy_override_flag x0,\n copy_class_expr x1,\n copy_option (fun x -> noloc x) x2 )\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n ( noloc x0,\n copy_mutable_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n ( noloc x0,\n copy_private_flag x1,\n copy_virtual_flag x2,\n copy_core_type x3 ))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_404\nmodule To = Ast_403\n\nlet from_loc { Location.txt = _; loc } = loc\n\nlet migration_error loc missing_feature =\n Location.raise_errorf ~loc\n \"migration error: %s is not supported before OCaml 4.04\" missing_feature\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_loc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc loc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_letexception _ -> migration_error loc \"local exceptions\"\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_loc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc loc :\n From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n | From.Parsetree.Ppat_open _ -> migration_error loc \"module open in patterns\"\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly (List.map (fun x -> x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n (copy_override_flag x0, copy_class_expr x1, copy_option (fun x -> x) x2)\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_mutable_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_private_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_403\nmodule To = Ast_404\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n | From.Parsetree.Pexp_unreachable -> To.Parsetree.Pexp_unreachable\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n To.Parsetree.Ptyp_arrow\n (copy_arg_label x0, copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly (List.map (fun x -> x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PSig x0 -> To.Parsetree.PSig (copy_signature x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type (x0, x1) ->\n To.Parsetree.Pstr_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n (copy_override_flag x0, copy_class_expr x1, copy_option (fun x -> x) x2)\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type (x0, x1) ->\n To.Parsetree.Psig_type\n (copy_rec_flag x0, List.map copy_type_declaration x1)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n To.Parsetree.Pcty_arrow\n (copy_arg_label x0, copy_core_type x1, copy_class_type x2)\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_mutable_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_private_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n (copy_constructor_arguments x0, copy_option copy_core_type x1)\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args = copy_constructor_arguments pcd_args;\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_constructor_arguments :\n From.Parsetree.constructor_arguments -> To.Parsetree.constructor_arguments =\n function\n | From.Parsetree.Pcstr_tuple x0 ->\n To.Parsetree.Pcstr_tuple (List.map copy_core_type x0)\n | From.Parsetree.Pcstr_record x0 ->\n To.Parsetree.Pcstr_record (List.map copy_label_declaration x0)\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_arg_label : From.Asttypes.arg_label -> To.Asttypes.arg_label = function\n | From.Asttypes.Nolabel -> To.Asttypes.Nolabel\n | From.Asttypes.Labelled x0 -> To.Asttypes.Labelled x0\n | From.Asttypes.Optional x0 -> To.Asttypes.Optional x0\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Parsetree.constant -> To.Parsetree.constant = function\n | From.Parsetree.Pconst_integer (x0, x1) ->\n To.Parsetree.Pconst_integer (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_char x0 -> To.Parsetree.Pconst_char x0\n | From.Parsetree.Pconst_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pconst_float (x0, x1) ->\n To.Parsetree.Pconst_float (x0, copy_option (fun x -> x) x1)\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int (x0, x1) ->\n To.Parsetree.Pdir_int (x0, copy_option (fun x -> x) x1)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(**************************************************************************)\n(* *)\n(* OCaml Migrate Parsetree *)\n(* *)\n(* Frédéric Bour *)\n(* Alain Frisch, LexiFi *)\n(* *)\n(* Copyright 2017 Institut National de Recherche en Informatique et *)\n(* en Automatique (INRIA). *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\nmodule From = Ast_402\nmodule To = Ast_403\n\nlet extract_predef_option label typ =\n let open From in\n let open Longident in\n match (label, typ.Parsetree.ptyp_desc) with\n | ( To.Asttypes.Optional _,\n From.Parsetree.Ptyp_constr\n ({ Location.txt = Ldot (Lident \"*predef*\", \"option\"); _ }, [ d ]) ) ->\n d\n | _ -> typ\n\nlet rec copy_expression : From.Parsetree.expression -> To.Parsetree.expression =\n fun {\n From.Parsetree.pexp_desc;\n From.Parsetree.pexp_loc;\n From.Parsetree.pexp_attributes;\n } ->\n {\n To.Parsetree.pexp_desc = copy_expression_desc pexp_desc;\n To.Parsetree.pexp_loc = copy_location pexp_loc;\n To.Parsetree.pexp_attributes = copy_attributes pexp_attributes;\n }\n\nand copy_expression_desc :\n From.Parsetree.expression_desc -> To.Parsetree.expression_desc = function\n | From.Parsetree.Pexp_ident x0 ->\n To.Parsetree.Pexp_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_constant x0 ->\n To.Parsetree.Pexp_constant (copy_constant x0)\n | From.Parsetree.Pexp_let (x0, x1, x2) ->\n To.Parsetree.Pexp_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_expression x2)\n | From.Parsetree.Pexp_function x0 ->\n To.Parsetree.Pexp_function (List.map copy_case x0)\n | From.Parsetree.Pexp_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pexp_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_expression x3 )\n | From.Parsetree.Pexp_apply (x0, x1) ->\n To.Parsetree.Pexp_apply\n ( copy_expression x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pexp_match (x0, x1) ->\n To.Parsetree.Pexp_match (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_try (x0, x1) ->\n To.Parsetree.Pexp_try (copy_expression x0, List.map copy_case x1)\n | From.Parsetree.Pexp_tuple x0 ->\n To.Parsetree.Pexp_tuple (List.map copy_expression x0)\n | From.Parsetree.Pexp_construct (x0, x1) ->\n To.Parsetree.Pexp_construct\n (copy_loc copy_longident x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_variant (x0, x1) ->\n To.Parsetree.Pexp_variant (copy_label x0, copy_option copy_expression x1)\n | From.Parsetree.Pexp_record (x0, x1) ->\n To.Parsetree.Pexp_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_expression x1))\n x0,\n copy_option copy_expression x1 )\n | From.Parsetree.Pexp_field (x0, x1) ->\n To.Parsetree.Pexp_field (copy_expression x0, copy_loc copy_longident x1)\n | From.Parsetree.Pexp_setfield (x0, x1, x2) ->\n To.Parsetree.Pexp_setfield\n (copy_expression x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_array x0 ->\n To.Parsetree.Pexp_array (List.map copy_expression x0)\n | From.Parsetree.Pexp_ifthenelse (x0, x1, x2) ->\n To.Parsetree.Pexp_ifthenelse\n (copy_expression x0, copy_expression x1, copy_option copy_expression x2)\n | From.Parsetree.Pexp_sequence (x0, x1) ->\n To.Parsetree.Pexp_sequence (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_while (x0, x1) ->\n To.Parsetree.Pexp_while (copy_expression x0, copy_expression x1)\n | From.Parsetree.Pexp_for (x0, x1, x2, x3, x4) ->\n To.Parsetree.Pexp_for\n ( copy_pattern x0,\n copy_expression x1,\n copy_expression x2,\n copy_direction_flag x3,\n copy_expression x4 )\n | From.Parsetree.Pexp_constraint (x0, x1) ->\n To.Parsetree.Pexp_constraint (copy_expression x0, copy_core_type x1)\n | From.Parsetree.Pexp_coerce (x0, x1, x2) ->\n To.Parsetree.Pexp_coerce\n (copy_expression x0, copy_option copy_core_type x1, copy_core_type x2)\n | From.Parsetree.Pexp_send (x0, x1) ->\n To.Parsetree.Pexp_send (copy_expression x0, x1)\n | From.Parsetree.Pexp_new x0 ->\n To.Parsetree.Pexp_new (copy_loc copy_longident x0)\n | From.Parsetree.Pexp_setinstvar (x0, x1) ->\n To.Parsetree.Pexp_setinstvar (copy_loc (fun x -> x) x0, copy_expression x1)\n | From.Parsetree.Pexp_override x0 ->\n To.Parsetree.Pexp_override\n (List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_expression x1))\n x0)\n | From.Parsetree.Pexp_letmodule (x0, x1, x2) ->\n To.Parsetree.Pexp_letmodule\n (copy_loc (fun x -> x) x0, copy_module_expr x1, copy_expression x2)\n | From.Parsetree.Pexp_assert x0 ->\n To.Parsetree.Pexp_assert (copy_expression x0)\n | From.Parsetree.Pexp_lazy x0 -> To.Parsetree.Pexp_lazy (copy_expression x0)\n | From.Parsetree.Pexp_poly (x0, x1) ->\n To.Parsetree.Pexp_poly (copy_expression x0, copy_option copy_core_type x1)\n | From.Parsetree.Pexp_object x0 ->\n To.Parsetree.Pexp_object (copy_class_structure x0)\n | From.Parsetree.Pexp_newtype (x0, x1) ->\n To.Parsetree.Pexp_newtype (x0, copy_expression x1)\n | From.Parsetree.Pexp_pack x0 -> To.Parsetree.Pexp_pack (copy_module_expr x0)\n | From.Parsetree.Pexp_open (x0, x1, x2) ->\n To.Parsetree.Pexp_open\n (copy_override_flag x0, copy_loc copy_longident x1, copy_expression x2)\n | From.Parsetree.Pexp_extension x0 ->\n To.Parsetree.Pexp_extension (copy_extension x0)\n\nand copy_direction_flag :\n From.Asttypes.direction_flag -> To.Asttypes.direction_flag = function\n | From.Asttypes.Upto -> To.Asttypes.Upto\n | From.Asttypes.Downto -> To.Asttypes.Downto\n\nand copy_case : From.Parsetree.case -> To.Parsetree.case =\n fun { From.Parsetree.pc_lhs; From.Parsetree.pc_guard; From.Parsetree.pc_rhs } ->\n {\n To.Parsetree.pc_lhs = copy_pattern pc_lhs;\n To.Parsetree.pc_guard = copy_option copy_expression pc_guard;\n To.Parsetree.pc_rhs = copy_expression pc_rhs;\n }\n\nand copy_value_binding :\n From.Parsetree.value_binding -> To.Parsetree.value_binding =\n fun {\n From.Parsetree.pvb_pat;\n From.Parsetree.pvb_expr;\n From.Parsetree.pvb_attributes;\n From.Parsetree.pvb_loc;\n } ->\n {\n To.Parsetree.pvb_pat = copy_pattern pvb_pat;\n To.Parsetree.pvb_expr = copy_expression pvb_expr;\n To.Parsetree.pvb_attributes = copy_attributes pvb_attributes;\n To.Parsetree.pvb_loc = copy_location pvb_loc;\n }\n\nand copy_pattern : From.Parsetree.pattern -> To.Parsetree.pattern =\n fun {\n From.Parsetree.ppat_desc;\n From.Parsetree.ppat_loc;\n From.Parsetree.ppat_attributes;\n } ->\n {\n To.Parsetree.ppat_desc = copy_pattern_desc ppat_desc;\n To.Parsetree.ppat_loc = copy_location ppat_loc;\n To.Parsetree.ppat_attributes = copy_attributes ppat_attributes;\n }\n\nand copy_pattern_desc : From.Parsetree.pattern_desc -> To.Parsetree.pattern_desc\n = function\n | From.Parsetree.Ppat_any -> To.Parsetree.Ppat_any\n | From.Parsetree.Ppat_var x0 ->\n To.Parsetree.Ppat_var (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_alias (x0, x1) ->\n To.Parsetree.Ppat_alias (copy_pattern x0, copy_loc (fun x -> x) x1)\n | From.Parsetree.Ppat_constant x0 ->\n To.Parsetree.Ppat_constant (copy_constant x0)\n | From.Parsetree.Ppat_interval (x0, x1) ->\n To.Parsetree.Ppat_interval (copy_constant x0, copy_constant x1)\n | From.Parsetree.Ppat_tuple x0 ->\n To.Parsetree.Ppat_tuple (List.map copy_pattern x0)\n | From.Parsetree.Ppat_construct (x0, x1) ->\n To.Parsetree.Ppat_construct\n (copy_loc copy_longident x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_variant (x0, x1) ->\n To.Parsetree.Ppat_variant (copy_label x0, copy_option copy_pattern x1)\n | From.Parsetree.Ppat_record (x0, x1) ->\n To.Parsetree.Ppat_record\n ( List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_pattern x1))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ppat_array x0 ->\n To.Parsetree.Ppat_array (List.map copy_pattern x0)\n | From.Parsetree.Ppat_or (x0, x1) ->\n To.Parsetree.Ppat_or (copy_pattern x0, copy_pattern x1)\n | From.Parsetree.Ppat_constraint (x0, x1) ->\n To.Parsetree.Ppat_constraint (copy_pattern x0, copy_core_type x1)\n | From.Parsetree.Ppat_type x0 ->\n To.Parsetree.Ppat_type (copy_loc copy_longident x0)\n | From.Parsetree.Ppat_lazy x0 -> To.Parsetree.Ppat_lazy (copy_pattern x0)\n | From.Parsetree.Ppat_unpack x0 ->\n To.Parsetree.Ppat_unpack (copy_loc (fun x -> x) x0)\n | From.Parsetree.Ppat_exception x0 ->\n To.Parsetree.Ppat_exception (copy_pattern x0)\n | From.Parsetree.Ppat_extension x0 ->\n To.Parsetree.Ppat_extension (copy_extension x0)\n\nand copy_core_type : From.Parsetree.core_type -> To.Parsetree.core_type =\n fun {\n From.Parsetree.ptyp_desc;\n From.Parsetree.ptyp_loc;\n From.Parsetree.ptyp_attributes;\n } ->\n {\n To.Parsetree.ptyp_desc = copy_core_type_desc ptyp_desc;\n To.Parsetree.ptyp_loc = copy_location ptyp_loc;\n To.Parsetree.ptyp_attributes = copy_attributes ptyp_attributes;\n }\n\nand copy_core_type_desc :\n From.Parsetree.core_type_desc -> To.Parsetree.core_type_desc = function\n | From.Parsetree.Ptyp_any -> To.Parsetree.Ptyp_any\n | From.Parsetree.Ptyp_var x0 -> To.Parsetree.Ptyp_var x0\n | From.Parsetree.Ptyp_arrow (x0, x1, x2) ->\n let label = copy_arg_label x0 in\n To.Parsetree.Ptyp_arrow\n ( label,\n copy_core_type (extract_predef_option label x1),\n copy_core_type x2 )\n | From.Parsetree.Ptyp_tuple x0 ->\n To.Parsetree.Ptyp_tuple (List.map copy_core_type x0)\n | From.Parsetree.Ptyp_constr (x0, x1) ->\n To.Parsetree.Ptyp_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_object (x0, x1) ->\n To.Parsetree.Ptyp_object\n ( List.map\n (fun x ->\n let x0, x1, x2 = x in\n (x0, copy_attributes x1, copy_core_type x2))\n x0,\n copy_closed_flag x1 )\n | From.Parsetree.Ptyp_class (x0, x1) ->\n To.Parsetree.Ptyp_class\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Ptyp_alias (x0, x1) ->\n To.Parsetree.Ptyp_alias (copy_core_type x0, x1)\n | From.Parsetree.Ptyp_variant (x0, x1, x2) ->\n To.Parsetree.Ptyp_variant\n ( List.map copy_row_field x0,\n copy_closed_flag x1,\n copy_option (fun x -> List.map copy_label x) x2 )\n | From.Parsetree.Ptyp_poly (x0, x1) ->\n To.Parsetree.Ptyp_poly (List.map (fun x -> x) x0, copy_core_type x1)\n | From.Parsetree.Ptyp_package x0 ->\n To.Parsetree.Ptyp_package (copy_package_type x0)\n | From.Parsetree.Ptyp_extension x0 ->\n To.Parsetree.Ptyp_extension (copy_extension x0)\n\nand copy_package_type : From.Parsetree.package_type -> To.Parsetree.package_type\n =\n fun x ->\n let x0, x1 = x in\n ( copy_loc copy_longident x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_loc copy_longident x0, copy_core_type x1))\n x1 )\n\nand copy_row_field : From.Parsetree.row_field -> To.Parsetree.row_field =\n function\n | From.Parsetree.Rtag (x0, x1, x2, x3) ->\n To.Parsetree.Rtag\n ( copy_label x0,\n copy_attributes x1,\n copy_bool x2,\n List.map copy_core_type x3 )\n | From.Parsetree.Rinherit x0 -> To.Parsetree.Rinherit (copy_core_type x0)\n\nand copy_attributes : From.Parsetree.attributes -> To.Parsetree.attributes =\n fun x -> List.map copy_attribute x\n\nand copy_attribute : From.Parsetree.attribute -> To.Parsetree.attribute =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_payload : From.Parsetree.payload -> To.Parsetree.payload = function\n | From.Parsetree.PStr x0 -> To.Parsetree.PStr (copy_structure x0)\n | From.Parsetree.PTyp x0 -> To.Parsetree.PTyp (copy_core_type x0)\n | From.Parsetree.PPat (x0, x1) ->\n To.Parsetree.PPat (copy_pattern x0, copy_option copy_expression x1)\n\nand copy_structure : From.Parsetree.structure -> To.Parsetree.structure =\n fun x -> List.map copy_structure_item x\n\nand copy_structure_item :\n From.Parsetree.structure_item -> To.Parsetree.structure_item =\n fun { From.Parsetree.pstr_desc; From.Parsetree.pstr_loc } ->\n {\n To.Parsetree.pstr_desc = copy_structure_item_desc pstr_desc;\n To.Parsetree.pstr_loc = copy_location pstr_loc;\n }\n\nand copy_structure_item_desc :\n From.Parsetree.structure_item_desc -> To.Parsetree.structure_item_desc =\n function\n | From.Parsetree.Pstr_eval (x0, x1) ->\n To.Parsetree.Pstr_eval (copy_expression x0, copy_attributes x1)\n | From.Parsetree.Pstr_value (x0, x1) ->\n To.Parsetree.Pstr_value (copy_rec_flag x0, List.map copy_value_binding x1)\n | From.Parsetree.Pstr_primitive x0 ->\n To.Parsetree.Pstr_primitive (copy_value_description x0)\n | From.Parsetree.Pstr_type x0 ->\n let recflag, types = type_declarations x0 in\n To.Parsetree.Pstr_type (recflag, types)\n | From.Parsetree.Pstr_typext x0 ->\n To.Parsetree.Pstr_typext (copy_type_extension x0)\n | From.Parsetree.Pstr_exception x0 ->\n To.Parsetree.Pstr_exception (copy_extension_constructor x0)\n | From.Parsetree.Pstr_module x0 ->\n To.Parsetree.Pstr_module (copy_module_binding x0)\n | From.Parsetree.Pstr_recmodule x0 ->\n To.Parsetree.Pstr_recmodule (List.map copy_module_binding x0)\n | From.Parsetree.Pstr_modtype x0 ->\n To.Parsetree.Pstr_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Pstr_open x0 ->\n To.Parsetree.Pstr_open (copy_open_description x0)\n | From.Parsetree.Pstr_class x0 ->\n To.Parsetree.Pstr_class (List.map copy_class_declaration x0)\n | From.Parsetree.Pstr_class_type x0 ->\n To.Parsetree.Pstr_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Pstr_include x0 ->\n To.Parsetree.Pstr_include (copy_include_declaration x0)\n | From.Parsetree.Pstr_attribute x0 ->\n To.Parsetree.Pstr_attribute (copy_attribute x0)\n | From.Parsetree.Pstr_extension (x0, x1) ->\n To.Parsetree.Pstr_extension (copy_extension x0, copy_attributes x1)\n\nand copy_include_declaration :\n From.Parsetree.include_declaration -> To.Parsetree.include_declaration =\n fun x -> copy_include_infos copy_module_expr x\n\nand copy_class_declaration :\n From.Parsetree.class_declaration -> To.Parsetree.class_declaration =\n fun x -> copy_class_infos copy_class_expr x\n\nand copy_class_expr : From.Parsetree.class_expr -> To.Parsetree.class_expr =\n fun {\n From.Parsetree.pcl_desc;\n From.Parsetree.pcl_loc;\n From.Parsetree.pcl_attributes;\n } ->\n {\n To.Parsetree.pcl_desc = copy_class_expr_desc pcl_desc;\n To.Parsetree.pcl_loc = copy_location pcl_loc;\n To.Parsetree.pcl_attributes = copy_attributes pcl_attributes;\n }\n\nand copy_class_expr_desc :\n From.Parsetree.class_expr_desc -> To.Parsetree.class_expr_desc = function\n | From.Parsetree.Pcl_constr (x0, x1) ->\n To.Parsetree.Pcl_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcl_structure x0 ->\n To.Parsetree.Pcl_structure (copy_class_structure x0)\n | From.Parsetree.Pcl_fun (x0, x1, x2, x3) ->\n To.Parsetree.Pcl_fun\n ( copy_arg_label x0,\n copy_option copy_expression x1,\n copy_pattern x2,\n copy_class_expr x3 )\n | From.Parsetree.Pcl_apply (x0, x1) ->\n To.Parsetree.Pcl_apply\n ( copy_class_expr x0,\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_arg_label x0, copy_expression x1))\n x1 )\n | From.Parsetree.Pcl_let (x0, x1, x2) ->\n To.Parsetree.Pcl_let\n (copy_rec_flag x0, List.map copy_value_binding x1, copy_class_expr x2)\n | From.Parsetree.Pcl_constraint (x0, x1) ->\n To.Parsetree.Pcl_constraint (copy_class_expr x0, copy_class_type x1)\n | From.Parsetree.Pcl_extension x0 ->\n To.Parsetree.Pcl_extension (copy_extension x0)\n\nand copy_class_structure :\n From.Parsetree.class_structure -> To.Parsetree.class_structure =\n fun { From.Parsetree.pcstr_self; From.Parsetree.pcstr_fields } ->\n {\n To.Parsetree.pcstr_self = copy_pattern pcstr_self;\n To.Parsetree.pcstr_fields = List.map copy_class_field pcstr_fields;\n }\n\nand copy_class_field : From.Parsetree.class_field -> To.Parsetree.class_field =\n fun {\n From.Parsetree.pcf_desc;\n From.Parsetree.pcf_loc;\n From.Parsetree.pcf_attributes;\n } ->\n {\n To.Parsetree.pcf_desc = copy_class_field_desc pcf_desc;\n To.Parsetree.pcf_loc = copy_location pcf_loc;\n To.Parsetree.pcf_attributes = copy_attributes pcf_attributes;\n }\n\nand copy_class_field_desc :\n From.Parsetree.class_field_desc -> To.Parsetree.class_field_desc = function\n | From.Parsetree.Pcf_inherit (x0, x1, x2) ->\n To.Parsetree.Pcf_inherit\n (copy_override_flag x0, copy_class_expr x1, copy_option (fun x -> x) x2)\n | From.Parsetree.Pcf_val x0 ->\n To.Parsetree.Pcf_val\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_mutable_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_method x0 ->\n To.Parsetree.Pcf_method\n (let x0, x1, x2 = x0 in\n ( copy_loc (fun x -> x) x0,\n copy_private_flag x1,\n copy_class_field_kind x2 ))\n | From.Parsetree.Pcf_constraint x0 ->\n To.Parsetree.Pcf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pcf_initializer x0 ->\n To.Parsetree.Pcf_initializer (copy_expression x0)\n | From.Parsetree.Pcf_attribute x0 ->\n To.Parsetree.Pcf_attribute (copy_attribute x0)\n | From.Parsetree.Pcf_extension x0 ->\n To.Parsetree.Pcf_extension (copy_extension x0)\n\nand copy_class_field_kind :\n From.Parsetree.class_field_kind -> To.Parsetree.class_field_kind = function\n | From.Parsetree.Cfk_virtual x0 ->\n To.Parsetree.Cfk_virtual (copy_core_type x0)\n | From.Parsetree.Cfk_concrete (x0, x1) ->\n To.Parsetree.Cfk_concrete (copy_override_flag x0, copy_expression x1)\n\nand copy_module_binding :\n From.Parsetree.module_binding -> To.Parsetree.module_binding =\n fun {\n From.Parsetree.pmb_name;\n From.Parsetree.pmb_expr;\n From.Parsetree.pmb_attributes;\n From.Parsetree.pmb_loc;\n } ->\n {\n To.Parsetree.pmb_name = copy_loc (fun x -> x) pmb_name;\n To.Parsetree.pmb_expr = copy_module_expr pmb_expr;\n To.Parsetree.pmb_attributes = copy_attributes pmb_attributes;\n To.Parsetree.pmb_loc = copy_location pmb_loc;\n }\n\nand copy_module_expr : From.Parsetree.module_expr -> To.Parsetree.module_expr =\n fun {\n From.Parsetree.pmod_desc;\n From.Parsetree.pmod_loc;\n From.Parsetree.pmod_attributes;\n } ->\n {\n To.Parsetree.pmod_desc = copy_module_expr_desc pmod_desc;\n To.Parsetree.pmod_loc = copy_location pmod_loc;\n To.Parsetree.pmod_attributes = copy_attributes pmod_attributes;\n }\n\nand copy_module_expr_desc :\n From.Parsetree.module_expr_desc -> To.Parsetree.module_expr_desc = function\n | From.Parsetree.Pmod_ident x0 ->\n To.Parsetree.Pmod_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmod_structure x0 ->\n To.Parsetree.Pmod_structure (copy_structure x0)\n | From.Parsetree.Pmod_functor (x0, x1, x2) ->\n To.Parsetree.Pmod_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_expr x2 )\n | From.Parsetree.Pmod_apply (x0, x1) ->\n To.Parsetree.Pmod_apply (copy_module_expr x0, copy_module_expr x1)\n | From.Parsetree.Pmod_constraint (x0, x1) ->\n To.Parsetree.Pmod_constraint (copy_module_expr x0, copy_module_type x1)\n | From.Parsetree.Pmod_unpack x0 ->\n To.Parsetree.Pmod_unpack (copy_expression x0)\n | From.Parsetree.Pmod_extension x0 ->\n To.Parsetree.Pmod_extension (copy_extension x0)\n\nand copy_module_type : From.Parsetree.module_type -> To.Parsetree.module_type =\n fun {\n From.Parsetree.pmty_desc;\n From.Parsetree.pmty_loc;\n From.Parsetree.pmty_attributes;\n } ->\n {\n To.Parsetree.pmty_desc = copy_module_type_desc pmty_desc;\n To.Parsetree.pmty_loc = copy_location pmty_loc;\n To.Parsetree.pmty_attributes = copy_attributes pmty_attributes;\n }\n\nand copy_module_type_desc :\n From.Parsetree.module_type_desc -> To.Parsetree.module_type_desc = function\n | From.Parsetree.Pmty_ident x0 ->\n To.Parsetree.Pmty_ident (copy_loc copy_longident x0)\n | From.Parsetree.Pmty_signature x0 ->\n To.Parsetree.Pmty_signature (copy_signature x0)\n | From.Parsetree.Pmty_functor (x0, x1, x2) ->\n To.Parsetree.Pmty_functor\n ( copy_loc (fun x -> x) x0,\n copy_option copy_module_type x1,\n copy_module_type x2 )\n | From.Parsetree.Pmty_with (x0, x1) ->\n To.Parsetree.Pmty_with\n (copy_module_type x0, List.map copy_with_constraint x1)\n | From.Parsetree.Pmty_typeof x0 ->\n To.Parsetree.Pmty_typeof (copy_module_expr x0)\n | From.Parsetree.Pmty_extension x0 ->\n To.Parsetree.Pmty_extension (copy_extension x0)\n | From.Parsetree.Pmty_alias x0 ->\n To.Parsetree.Pmty_alias (copy_loc copy_longident x0)\n\nand copy_with_constraint :\n From.Parsetree.with_constraint -> To.Parsetree.with_constraint = function\n | From.Parsetree.Pwith_type (x0, x1) ->\n To.Parsetree.Pwith_type\n (copy_loc copy_longident x0, copy_type_declaration x1)\n | From.Parsetree.Pwith_module (x0, x1) ->\n To.Parsetree.Pwith_module\n (copy_loc copy_longident x0, copy_loc copy_longident x1)\n | From.Parsetree.Pwith_typesubst x0 ->\n To.Parsetree.Pwith_typesubst (copy_type_declaration x0)\n | From.Parsetree.Pwith_modsubst (x0, x1) ->\n To.Parsetree.Pwith_modsubst\n (copy_loc (fun x -> x) x0, copy_loc copy_longident x1)\n\nand copy_signature : From.Parsetree.signature -> To.Parsetree.signature =\n fun x -> List.map copy_signature_item x\n\nand copy_signature_item :\n From.Parsetree.signature_item -> To.Parsetree.signature_item =\n fun { From.Parsetree.psig_desc; From.Parsetree.psig_loc } ->\n {\n To.Parsetree.psig_desc = copy_signature_item_desc psig_desc;\n To.Parsetree.psig_loc = copy_location psig_loc;\n }\n\nand copy_signature_item_desc :\n From.Parsetree.signature_item_desc -> To.Parsetree.signature_item_desc =\n function\n | From.Parsetree.Psig_value x0 ->\n To.Parsetree.Psig_value (copy_value_description x0)\n | From.Parsetree.Psig_type x0 ->\n let recflag, types = type_declarations x0 in\n To.Parsetree.Psig_type (recflag, types)\n | From.Parsetree.Psig_typext x0 ->\n To.Parsetree.Psig_typext (copy_type_extension x0)\n | From.Parsetree.Psig_exception x0 ->\n To.Parsetree.Psig_exception (copy_extension_constructor x0)\n | From.Parsetree.Psig_module x0 ->\n To.Parsetree.Psig_module (copy_module_declaration x0)\n | From.Parsetree.Psig_recmodule x0 ->\n To.Parsetree.Psig_recmodule (List.map copy_module_declaration x0)\n | From.Parsetree.Psig_modtype x0 ->\n To.Parsetree.Psig_modtype (copy_module_type_declaration x0)\n | From.Parsetree.Psig_open x0 ->\n To.Parsetree.Psig_open (copy_open_description x0)\n | From.Parsetree.Psig_include x0 ->\n To.Parsetree.Psig_include (copy_include_description x0)\n | From.Parsetree.Psig_class x0 ->\n To.Parsetree.Psig_class (List.map copy_class_description x0)\n | From.Parsetree.Psig_class_type x0 ->\n To.Parsetree.Psig_class_type (List.map copy_class_type_declaration x0)\n | From.Parsetree.Psig_attribute x0 ->\n To.Parsetree.Psig_attribute (copy_attribute x0)\n | From.Parsetree.Psig_extension (x0, x1) ->\n To.Parsetree.Psig_extension (copy_extension x0, copy_attributes x1)\n\nand copy_class_type_declaration :\n From.Parsetree.class_type_declaration -> To.Parsetree.class_type_declaration\n =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_description :\n From.Parsetree.class_description -> To.Parsetree.class_description =\n fun x -> copy_class_infos copy_class_type x\n\nand copy_class_type : From.Parsetree.class_type -> To.Parsetree.class_type =\n fun {\n From.Parsetree.pcty_desc;\n From.Parsetree.pcty_loc;\n From.Parsetree.pcty_attributes;\n } ->\n {\n To.Parsetree.pcty_desc = copy_class_type_desc pcty_desc;\n To.Parsetree.pcty_loc = copy_location pcty_loc;\n To.Parsetree.pcty_attributes = copy_attributes pcty_attributes;\n }\n\nand copy_class_type_desc :\n From.Parsetree.class_type_desc -> To.Parsetree.class_type_desc = function\n | From.Parsetree.Pcty_constr (x0, x1) ->\n To.Parsetree.Pcty_constr\n (copy_loc copy_longident x0, List.map copy_core_type x1)\n | From.Parsetree.Pcty_signature x0 ->\n To.Parsetree.Pcty_signature (copy_class_signature x0)\n | From.Parsetree.Pcty_arrow (x0, x1, x2) ->\n let label = copy_arg_label x0 in\n To.Parsetree.Pcty_arrow\n ( label,\n copy_core_type (extract_predef_option label x1),\n copy_class_type x2 )\n | From.Parsetree.Pcty_extension x0 ->\n To.Parsetree.Pcty_extension (copy_extension x0)\n\nand copy_class_signature :\n From.Parsetree.class_signature -> To.Parsetree.class_signature =\n fun { From.Parsetree.pcsig_self; From.Parsetree.pcsig_fields } ->\n {\n To.Parsetree.pcsig_self = copy_core_type pcsig_self;\n To.Parsetree.pcsig_fields = List.map copy_class_type_field pcsig_fields;\n }\n\nand copy_class_type_field :\n From.Parsetree.class_type_field -> To.Parsetree.class_type_field =\n fun {\n From.Parsetree.pctf_desc;\n From.Parsetree.pctf_loc;\n From.Parsetree.pctf_attributes;\n } ->\n {\n To.Parsetree.pctf_desc = copy_class_type_field_desc pctf_desc;\n To.Parsetree.pctf_loc = copy_location pctf_loc;\n To.Parsetree.pctf_attributes = copy_attributes pctf_attributes;\n }\n\nand copy_class_type_field_desc :\n From.Parsetree.class_type_field_desc -> To.Parsetree.class_type_field_desc =\n function\n | From.Parsetree.Pctf_inherit x0 ->\n To.Parsetree.Pctf_inherit (copy_class_type x0)\n | From.Parsetree.Pctf_val x0 ->\n To.Parsetree.Pctf_val\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_mutable_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_method x0 ->\n To.Parsetree.Pctf_method\n (let x0, x1, x2, x3 = x0 in\n (x0, copy_private_flag x1, copy_virtual_flag x2, copy_core_type x3))\n | From.Parsetree.Pctf_constraint x0 ->\n To.Parsetree.Pctf_constraint\n (let x0, x1 = x0 in\n (copy_core_type x0, copy_core_type x1))\n | From.Parsetree.Pctf_attribute x0 ->\n To.Parsetree.Pctf_attribute (copy_attribute x0)\n | From.Parsetree.Pctf_extension x0 ->\n To.Parsetree.Pctf_extension (copy_extension x0)\n\nand copy_extension : From.Parsetree.extension -> To.Parsetree.extension =\n fun x ->\n let x0, x1 = x in\n (copy_loc (fun x -> x) x0, copy_payload x1)\n\nand copy_class_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.class_infos ->\n 'g0 To.Parsetree.class_infos =\n fun f0\n {\n From.Parsetree.pci_virt;\n From.Parsetree.pci_params;\n From.Parsetree.pci_name;\n From.Parsetree.pci_expr;\n From.Parsetree.pci_loc;\n From.Parsetree.pci_attributes;\n } ->\n {\n To.Parsetree.pci_virt = copy_virtual_flag pci_virt;\n To.Parsetree.pci_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n pci_params;\n To.Parsetree.pci_name = copy_loc (fun x -> x) pci_name;\n To.Parsetree.pci_expr = f0 pci_expr;\n To.Parsetree.pci_loc = copy_location pci_loc;\n To.Parsetree.pci_attributes = copy_attributes pci_attributes;\n }\n\nand copy_virtual_flag : From.Asttypes.virtual_flag -> To.Asttypes.virtual_flag =\n function\n | From.Asttypes.Virtual -> To.Asttypes.Virtual\n | From.Asttypes.Concrete -> To.Asttypes.Concrete\n\nand copy_include_description :\n From.Parsetree.include_description -> To.Parsetree.include_description =\n fun x -> copy_include_infos copy_module_type x\n\nand copy_include_infos :\n 'f0 'g0.\n ('f0 -> 'g0) ->\n 'f0 From.Parsetree.include_infos ->\n 'g0 To.Parsetree.include_infos =\n fun f0\n {\n From.Parsetree.pincl_mod;\n From.Parsetree.pincl_loc;\n From.Parsetree.pincl_attributes;\n } ->\n {\n To.Parsetree.pincl_mod = f0 pincl_mod;\n To.Parsetree.pincl_loc = copy_location pincl_loc;\n To.Parsetree.pincl_attributes = copy_attributes pincl_attributes;\n }\n\nand copy_open_description :\n From.Parsetree.open_description -> To.Parsetree.open_description =\n fun {\n From.Parsetree.popen_lid;\n From.Parsetree.popen_override;\n From.Parsetree.popen_loc;\n From.Parsetree.popen_attributes;\n } ->\n {\n To.Parsetree.popen_lid = copy_loc copy_longident popen_lid;\n To.Parsetree.popen_override = copy_override_flag popen_override;\n To.Parsetree.popen_loc = copy_location popen_loc;\n To.Parsetree.popen_attributes = copy_attributes popen_attributes;\n }\n\nand copy_override_flag :\n From.Asttypes.override_flag -> To.Asttypes.override_flag = function\n | From.Asttypes.Override -> To.Asttypes.Override\n | From.Asttypes.Fresh -> To.Asttypes.Fresh\n\nand copy_module_type_declaration :\n From.Parsetree.module_type_declaration ->\n To.Parsetree.module_type_declaration =\n fun {\n From.Parsetree.pmtd_name;\n From.Parsetree.pmtd_type;\n From.Parsetree.pmtd_attributes;\n From.Parsetree.pmtd_loc;\n } ->\n {\n To.Parsetree.pmtd_name = copy_loc (fun x -> x) pmtd_name;\n To.Parsetree.pmtd_type = copy_option copy_module_type pmtd_type;\n To.Parsetree.pmtd_attributes = copy_attributes pmtd_attributes;\n To.Parsetree.pmtd_loc = copy_location pmtd_loc;\n }\n\nand copy_module_declaration :\n From.Parsetree.module_declaration -> To.Parsetree.module_declaration =\n fun {\n From.Parsetree.pmd_name;\n From.Parsetree.pmd_type;\n From.Parsetree.pmd_attributes;\n From.Parsetree.pmd_loc;\n } ->\n {\n To.Parsetree.pmd_name = copy_loc (fun x -> x) pmd_name;\n To.Parsetree.pmd_type = copy_module_type pmd_type;\n To.Parsetree.pmd_attributes = copy_attributes pmd_attributes;\n To.Parsetree.pmd_loc = copy_location pmd_loc;\n }\n\nand copy_type_extension :\n From.Parsetree.type_extension -> To.Parsetree.type_extension =\n fun {\n From.Parsetree.ptyext_path;\n From.Parsetree.ptyext_params;\n From.Parsetree.ptyext_constructors;\n From.Parsetree.ptyext_private;\n From.Parsetree.ptyext_attributes;\n } ->\n {\n To.Parsetree.ptyext_path = copy_loc copy_longident ptyext_path;\n To.Parsetree.ptyext_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptyext_params;\n To.Parsetree.ptyext_constructors =\n List.map copy_extension_constructor ptyext_constructors;\n To.Parsetree.ptyext_private = copy_private_flag ptyext_private;\n To.Parsetree.ptyext_attributes = copy_attributes ptyext_attributes;\n }\n\nand copy_extension_constructor :\n From.Parsetree.extension_constructor -> To.Parsetree.extension_constructor =\n fun {\n From.Parsetree.pext_name;\n From.Parsetree.pext_kind;\n From.Parsetree.pext_loc;\n From.Parsetree.pext_attributes;\n } ->\n {\n To.Parsetree.pext_name = copy_loc (fun x -> x) pext_name;\n To.Parsetree.pext_kind = copy_extension_constructor_kind pext_kind;\n To.Parsetree.pext_loc = copy_location pext_loc;\n To.Parsetree.pext_attributes = copy_attributes pext_attributes;\n }\n\nand copy_extension_constructor_kind :\n From.Parsetree.extension_constructor_kind ->\n To.Parsetree.extension_constructor_kind = function\n | From.Parsetree.Pext_decl (x0, x1) ->\n To.Parsetree.Pext_decl\n ( To.Parsetree.Pcstr_tuple (List.map copy_core_type x0),\n copy_option copy_core_type x1 )\n | From.Parsetree.Pext_rebind x0 ->\n To.Parsetree.Pext_rebind (copy_loc copy_longident x0)\n\nand copy_type_declaration :\n From.Parsetree.type_declaration -> To.Parsetree.type_declaration =\n fun {\n From.Parsetree.ptype_name;\n From.Parsetree.ptype_params;\n From.Parsetree.ptype_cstrs;\n From.Parsetree.ptype_kind;\n From.Parsetree.ptype_private;\n From.Parsetree.ptype_manifest;\n From.Parsetree.ptype_attributes;\n From.Parsetree.ptype_loc;\n } ->\n {\n To.Parsetree.ptype_name = copy_loc (fun x -> x) ptype_name;\n To.Parsetree.ptype_params =\n List.map\n (fun x ->\n let x0, x1 = x in\n (copy_core_type x0, copy_variance x1))\n ptype_params;\n To.Parsetree.ptype_cstrs =\n List.map\n (fun x ->\n let x0, x1, x2 = x in\n (copy_core_type x0, copy_core_type x1, copy_location x2))\n ptype_cstrs;\n To.Parsetree.ptype_kind = copy_type_kind ptype_kind;\n To.Parsetree.ptype_private = copy_private_flag ptype_private;\n To.Parsetree.ptype_manifest = copy_option copy_core_type ptype_manifest;\n To.Parsetree.ptype_attributes = copy_attributes ptype_attributes;\n To.Parsetree.ptype_loc = copy_location ptype_loc;\n }\n\nand copy_private_flag : From.Asttypes.private_flag -> To.Asttypes.private_flag =\n function\n | From.Asttypes.Private -> To.Asttypes.Private\n | From.Asttypes.Public -> To.Asttypes.Public\n\nand copy_type_kind : From.Parsetree.type_kind -> To.Parsetree.type_kind =\n function\n | From.Parsetree.Ptype_abstract -> To.Parsetree.Ptype_abstract\n | From.Parsetree.Ptype_variant x0 ->\n To.Parsetree.Ptype_variant (List.map copy_constructor_declaration x0)\n | From.Parsetree.Ptype_record x0 ->\n To.Parsetree.Ptype_record (List.map copy_label_declaration x0)\n | From.Parsetree.Ptype_open -> To.Parsetree.Ptype_open\n\nand copy_label_declaration :\n From.Parsetree.label_declaration -> To.Parsetree.label_declaration =\n fun {\n From.Parsetree.pld_name;\n From.Parsetree.pld_mutable;\n From.Parsetree.pld_type;\n From.Parsetree.pld_loc;\n From.Parsetree.pld_attributes;\n } ->\n {\n To.Parsetree.pld_name = copy_loc (fun x -> x) pld_name;\n To.Parsetree.pld_mutable = copy_mutable_flag pld_mutable;\n To.Parsetree.pld_type = copy_core_type pld_type;\n To.Parsetree.pld_loc = copy_location pld_loc;\n To.Parsetree.pld_attributes = copy_attributes pld_attributes;\n }\n\nand copy_mutable_flag : From.Asttypes.mutable_flag -> To.Asttypes.mutable_flag =\n function\n | From.Asttypes.Immutable -> To.Asttypes.Immutable\n | From.Asttypes.Mutable -> To.Asttypes.Mutable\n\nand copy_constructor_declaration :\n From.Parsetree.constructor_declaration ->\n To.Parsetree.constructor_declaration =\n fun {\n From.Parsetree.pcd_name;\n From.Parsetree.pcd_args;\n From.Parsetree.pcd_res;\n From.Parsetree.pcd_loc;\n From.Parsetree.pcd_attributes;\n } ->\n {\n To.Parsetree.pcd_name = copy_loc (fun x -> x) pcd_name;\n To.Parsetree.pcd_args =\n To.Parsetree.Pcstr_tuple (List.map copy_core_type pcd_args);\n To.Parsetree.pcd_res = copy_option copy_core_type pcd_res;\n To.Parsetree.pcd_loc = copy_location pcd_loc;\n To.Parsetree.pcd_attributes = copy_attributes pcd_attributes;\n }\n\nand copy_variance : From.Asttypes.variance -> To.Asttypes.variance = function\n | From.Asttypes.Covariant -> To.Asttypes.Covariant\n | From.Asttypes.Contravariant -> To.Asttypes.Contravariant\n | From.Asttypes.Invariant -> To.Asttypes.Invariant\n\nand copy_value_description :\n From.Parsetree.value_description -> To.Parsetree.value_description =\n fun {\n From.Parsetree.pval_name;\n From.Parsetree.pval_type;\n From.Parsetree.pval_prim;\n From.Parsetree.pval_attributes;\n From.Parsetree.pval_loc;\n } ->\n {\n To.Parsetree.pval_name = copy_loc (fun x -> x) pval_name;\n To.Parsetree.pval_type = copy_core_type pval_type;\n To.Parsetree.pval_prim = List.map (fun x -> x) pval_prim;\n To.Parsetree.pval_attributes = copy_attributes pval_attributes;\n To.Parsetree.pval_loc = copy_location pval_loc;\n }\n\nand copy_closed_flag : From.Asttypes.closed_flag -> To.Asttypes.closed_flag =\n function\n | From.Asttypes.Closed -> To.Asttypes.Closed\n | From.Asttypes.Open -> To.Asttypes.Open\n\nand copy_label : From.Asttypes.label -> To.Asttypes.label = fun x -> x\n\nand copy_arg_label : From.Asttypes.label -> To.Asttypes.arg_label =\n fun x ->\n if x <> \"\" then\n if x.[0] = '?' then\n To.Asttypes.Optional (String.sub x 1 (String.length x - 1))\n else To.Asttypes.Labelled x\n else To.Asttypes.Nolabel\n\nand copy_rec_flag : From.Asttypes.rec_flag -> To.Asttypes.rec_flag = function\n | From.Asttypes.Nonrecursive -> To.Asttypes.Nonrecursive\n | From.Asttypes.Recursive -> To.Asttypes.Recursive\n\nand copy_constant : From.Asttypes.constant -> To.Parsetree.constant = function\n | From.Asttypes.Const_int x0 ->\n To.Parsetree.Pconst_integer (string_of_int x0, None)\n | From.Asttypes.Const_char x0 -> To.Parsetree.Pconst_char x0\n | From.Asttypes.Const_string (x0, x1) ->\n To.Parsetree.Pconst_string (x0, copy_option (fun x -> x) x1)\n | From.Asttypes.Const_float x0 -> To.Parsetree.Pconst_float (x0, None)\n | From.Asttypes.Const_int32 x0 ->\n To.Parsetree.Pconst_integer (Int32.to_string x0, Some 'l')\n | From.Asttypes.Const_int64 x0 ->\n To.Parsetree.Pconst_integer (Int64.to_string x0, Some 'L')\n | From.Asttypes.Const_nativeint x0 ->\n To.Parsetree.Pconst_integer (Nativeint.to_string x0, Some 'n')\n\nand copy_option : 'f0 'g0. ('f0 -> 'g0) -> 'f0 option -> 'g0 option =\n fun f0 -> function None -> None | Some x0 -> Some (f0 x0)\n\nand copy_longident : Longident.t -> Longident.t = fun x -> x\n\nand copy_loc :\n 'f0 'g0. ('f0 -> 'g0) -> 'f0 From.Asttypes.loc -> 'g0 To.Asttypes.loc =\n fun f0 { From.Asttypes.txt; From.Asttypes.loc } ->\n { To.Asttypes.txt = f0 txt; To.Asttypes.loc = copy_location loc }\n\nand copy_location : Location.t -> Location.t = fun x -> x\nand copy_bool : bool -> bool = function false -> false | true -> true\n\nand type_declarations types =\n let is_nonrec (attr, _) = attr.Location.txt = \"nonrec\" in\n match List.map copy_type_declaration types with\n | x :: xs when List.exists is_nonrec x.To.Parsetree.ptype_attributes ->\n let ptype_attributes =\n List.filter (fun x -> not (is_nonrec x)) x.To.Parsetree.ptype_attributes\n in\n (To.Asttypes.Nonrecursive, { x with To.Parsetree.ptype_attributes } :: xs)\n | types -> (To.Asttypes.Recursive, types)\n\nlet rec copy_toplevel_phrase :\n From.Parsetree.toplevel_phrase -> To.Parsetree.toplevel_phrase = function\n | From.Parsetree.Ptop_def x0 -> To.Parsetree.Ptop_def (copy_structure x0)\n | From.Parsetree.Ptop_dir (x0, x1) ->\n To.Parsetree.Ptop_dir (x0, copy_directive_argument x1)\n\nand copy_directive_argument :\n From.Parsetree.directive_argument -> To.Parsetree.directive_argument =\n function\n | From.Parsetree.Pdir_none -> To.Parsetree.Pdir_none\n | From.Parsetree.Pdir_string x0 -> To.Parsetree.Pdir_string x0\n | From.Parsetree.Pdir_int x0 -> To.Parsetree.Pdir_int (string_of_int x0, None)\n | From.Parsetree.Pdir_ident x0 -> To.Parsetree.Pdir_ident (copy_longident x0)\n | From.Parsetree.Pdir_bool x0 -> To.Parsetree.Pdir_bool (copy_bool x0)\n\nlet copy_cases x = List.map copy_case x\nlet copy_pat = copy_pattern\nlet copy_expr = copy_expression\nlet copy_typ = copy_core_type\n","(* This file is used to control what we use from the current compiler and what is embed in\n this library.\n\n It must be opened in all modules, especially the ones coming from the compiler.\n*)\n\nmodule Js = Versions.OCaml_412\nmodule Ocaml = Versions.OCaml_current\n\nmodule Select_ast (Ocaml : Versions.OCaml_version) = struct\n include Js\n\n module Type = struct\n type ('js, 'ocaml) t =\n | Signature\n : (Js.Ast.Parsetree.signature, Ocaml.Ast.Parsetree.signature) t\n | Structure\n : (Js.Ast.Parsetree.structure, Ocaml.Ast.Parsetree.structure) t\n | Toplevel_phrase\n : ( Js.Ast.Parsetree.toplevel_phrase,\n Ocaml.Ast.Parsetree.toplevel_phrase )\n t\n | Expression\n : (Js.Ast.Parsetree.expression, Ocaml.Ast.Parsetree.expression) t\n | Core_type\n : (Js.Ast.Parsetree.core_type, Ocaml.Ast.Parsetree.core_type) t\n | Type_declaration\n : ( Js.Ast.Parsetree.type_declaration,\n Ocaml.Ast.Parsetree.type_declaration )\n t\n | Type_extension\n : ( Js.Ast.Parsetree.type_extension,\n Ocaml.Ast.Parsetree.type_extension )\n t\n | Extension_constructor\n : ( Js.Ast.Parsetree.extension_constructor,\n Ocaml.Ast.Parsetree.extension_constructor )\n t\n | List : ('a, 'b) t -> ('a list, 'b list) t\n | Pair : ('a, 'b) t * ('c, 'd) t -> ('a * 'c, 'b * 'd) t\n end\n\n open Type\n module Of_ocaml = Versions.Convert (Ocaml) (Js)\n module To_ocaml = Versions.Convert (Js) (Ocaml)\n\n let rec of_ocaml : type ocaml js. (js, ocaml) Type.t -> ocaml -> js =\n let open Of_ocaml in\n fun node ->\n match node with\n | Signature -> copy_signature\n | Structure -> copy_structure\n | Toplevel_phrase -> copy_toplevel_phrase\n | Expression -> copy_expression\n | Core_type -> copy_core_type\n | Type_declaration -> copy_type_declaration\n | Type_extension -> copy_type_extension\n | Extension_constructor -> copy_extension_constructor\n | List t -> List.map (of_ocaml t)\n | Pair (a, b) ->\n let f = of_ocaml a in\n let g = of_ocaml b in\n fun (x, y) -> (f x, g y)\n\n let rec to_ocaml : type ocaml js. (js, ocaml) Type.t -> js -> ocaml =\n let open To_ocaml in\n fun node ->\n match node with\n | Signature -> copy_signature\n | Structure -> copy_structure\n | Toplevel_phrase -> copy_toplevel_phrase\n | Expression -> copy_expression\n | Core_type -> copy_core_type\n | Type_declaration -> copy_type_declaration\n | Type_extension -> copy_type_extension\n | Extension_constructor -> copy_extension_constructor\n | List t -> List.map (to_ocaml t)\n | Pair (a, b) ->\n let f = to_ocaml a in\n let g = to_ocaml b in\n fun (x, y) -> (f x, g y)\n\n let of_ocaml_mapper item f ctxt x = to_ocaml item x |> f ctxt |> of_ocaml item\n let to_ocaml_mapper item f ctxt x = of_ocaml item x |> f ctxt |> to_ocaml item\nend\n\nmodule Selected_ast = Select_ast (Ocaml)\nmodule Ast_helper = Ast_helper_lite\n\n(* Modules from Ast_ of Astlib, where is the compiler version the ppxlib driver is compiled with *)\nmodule Parsetree = Selected_ast.Ast.Parsetree\nmodule Asttypes = Selected_ast.Ast.Asttypes\n\n(* Other Astlib modules *)\nmodule Location = Astlib.Location\nmodule Longident = Astlib.Longident\n\nmodule Parse = struct\n include Astlib.Parse\n module Of_ocaml = Versions.Convert (Ocaml) (Js)\n\n let implementation lexbuf = implementation lexbuf |> Of_ocaml.copy_structure\n let interface lexbuf = interface lexbuf |> Of_ocaml.copy_signature\n\n let toplevel_phrase lexbuf =\n toplevel_phrase lexbuf |> Of_ocaml.copy_toplevel_phrase\n\n let use_file lexbuf =\n use_file lexbuf |> List.map Of_ocaml.copy_toplevel_phrase\n\n let core_type lexbuf = core_type lexbuf |> Of_ocaml.copy_core_type\n let expression lexbuf = expression lexbuf |> Of_ocaml.copy_expression\n let pattern lexbuf = pattern lexbuf |> Of_ocaml.copy_pattern\nend\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(** Definition of the OCaml AST *)\n\nopen Import\n\n(* This file is obtained by:\n\n - copying a subset of the corresponding ast_xxx.ml file from Astlib\n (sub-modules Asttypes and Parsetree)\n - adding the type definitions for position, location, loc and longident\n - flattening all the modules\n - removing Asttypes.constant (unused and conflicts with Parsetree.constant)\n - renaming a few types:\n - - Location.t -> location\n - - Longident.t -> longident\n - adding a type longident_loc = longident loc and replacing all the occurrences of the\n latter by the former. This is so that we can override iteration an the level of a\n longident loc\n - adding a type cases = case list\n - replacing all the (*IF_CURRENT = Foo.bar*) by: = Foo.bar\n - removing the extra values at the end of the file\n - replacing app [type ...] by [and ...] to make everything one recursive block\n - adding [@@deriving_inline traverse][@@@end] at the end\n\n To update it to a newer OCaml version, create a new module with the above from the\n latest compiler and add the following module definitions and opens to get it to\n compile:\n [{\n module Ast = Versions.OCaml_4xx\n open Ast.Ast\n module Location = Ocaml_common.Location\n module Longident = Ocaml_common.Longident\n }]\n\n Once you have generated the inlined derived traversal classes by running\n [{ dune build @lint }] you can replace the above mentioned module definitions by a\n [open Import] and update [Import] so that the [Js] module points to\n [Versions.OCaml_4xx].\n*)\n\n(* Source code locations (ranges of positions), used in parsetree. *)\n\ntype position = Lexing.position = {\n pos_fname : string;\n pos_lnum : int;\n pos_bol : int;\n pos_cnum : int;\n}\n\nand location = Location.t = {\n loc_start : position;\n loc_end : position;\n loc_ghost : bool;\n}\n\nand location_stack = location list\n\n(* Note on the use of Lexing.position in this module.\n If [pos_fname = \"\"], then use [!input_name] instead.\n If [pos_lnum = -1], then [pos_bol = 0]. Use [pos_cnum] and\n re-parse the file to get the line and character numbers.\n Else all fields are correct.\n*)\nand 'a loc = 'a Location.loc = { txt : 'a; loc : location }\n\n(* Long identifiers, used in parsetree. *)\nand longident = Longident.t =\n | Lident of string\n | Ldot of longident * string\n | Lapply of longident * longident\n\nand longident_loc = longident loc\n\n(** Auxiliary AST types used by parsetree and typedtree. *)\n\nand rec_flag = Asttypes.rec_flag = Nonrecursive | Recursive\n\nand direction_flag = Asttypes.direction_flag = Upto | Downto\n\n(* Order matters, used in polymorphic comparison *)\nand private_flag = Asttypes.private_flag = Private | Public\nand mutable_flag = Asttypes.mutable_flag = Immutable | Mutable\nand virtual_flag = Asttypes.virtual_flag = Virtual | Concrete\nand override_flag = Asttypes.override_flag = Override | Fresh\nand closed_flag = Asttypes.closed_flag = Closed | Open\nand label = string\n\nand arg_label = Asttypes.arg_label =\n | Nolabel\n | Labelled of string (* label:T -> ... *)\n | Optional of string\n(* ?label:T -> ... *)\n\nand variance = Asttypes.variance = Covariant | Contravariant | NoVariance\nand injectivity = Asttypes.injectivity = Injective | NoInjectivity\n\n(** Abstract syntax tree produced by parsing *)\n\nand constant = Parsetree.constant =\n | Pconst_integer of string * char option\n (* 3 3l 3L 3n\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes except 'l', 'L' and 'n' are rejected by the typechecker\n *)\n | Pconst_char of char\n (* 'c' *)\n | Pconst_string of string * location * string option\n (* \"constant\"\n {delim|other constant|delim}\n\n The location span the content of the string, without the delimiters.\n *)\n | Pconst_float of string * char option\n(* 3.4 2e5 1.4e-4\n\n Suffixes [g-z][G-Z] are accepted by the parser.\n Suffixes are rejected by the typechecker.\n*)\n\n(** {1 Extension points} *)\n\nand attribute = Parsetree.attribute = {\n attr_name : string loc;\n attr_payload : payload;\n attr_loc : location;\n}\n(* [@id ARG]\n [@@id ARG]\n\n Metadata containers passed around within the AST.\n The compiler ignores unknown attributes.\n*)\n\nand extension = string loc * payload\n(* [%id ARG]\n [%%id ARG]\n\n Sub-language placeholder -- rejected by the typechecker.\n*)\n\nand attributes = attribute list\n\nand payload = Parsetree.payload =\n | PStr of structure\n | PSig of signature (* : SIG *)\n | PTyp of core_type (* : T *)\n | PPat of pattern * expression option\n(* ? P or ? P when E *)\n\n(* Type expressions *)\n\n(** {1 Core language} *)\n\nand core_type = Parsetree.core_type = {\n ptyp_desc : core_type_desc;\n ptyp_loc : location;\n ptyp_loc_stack : location_stack;\n ptyp_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand core_type_desc = Parsetree.core_type_desc =\n | Ptyp_any\n (* _ *)\n | Ptyp_var of string\n (* 'a *)\n | Ptyp_arrow of arg_label * core_type * core_type\n (* T1 -> T2 Simple\n ~l:T1 -> T2 Labelled\n ?l:T1 -> T2 Optional\n *)\n | Ptyp_tuple of core_type list\n (* T1 * ... * Tn\n\n Invariant: n >= 2\n *)\n | Ptyp_constr of longident_loc * core_type list\n (* tconstr\n T tconstr\n (T1, ..., Tn) tconstr\n *)\n | Ptyp_object of object_field list * closed_flag\n (* < l1:T1; ...; ln:Tn > (flag = Closed)\n < l1:T1; ...; ln:Tn; .. > (flag = Open)\n *)\n | Ptyp_class of longident_loc * core_type list\n (* #tconstr\n T #tconstr\n (T1, ..., Tn) #tconstr\n *)\n | Ptyp_alias of core_type * string\n (* T as 'a *)\n | Ptyp_variant of row_field list * closed_flag * label list option\n (* [ `A|`B ] (flag = Closed; labels = None)\n [> `A|`B ] (flag = Open; labels = None)\n [< `A|`B ] (flag = Closed; labels = Some [])\n [< `A|`B > `X `Y ](flag = Closed; labels = Some [\"X\";\"Y\"])\n *)\n | Ptyp_poly of string loc list * core_type (* 'a1 ... 'an. T\n\n Can only appear in the following context:\n\n - As the core_type of a Ppat_constraint node corresponding\n to a constraint on a let-binding: let x : 'a1 ... 'an. T\n = e ...\n\n - Under Cfk_virtual for methods (not values).\n\n - As the core_type of a Pctf_method node.\n\n - As the core_type of a Pexp_poly node.\n\n - As the pld_type field of a label_declaration.\n\n - As a core_type of a Ptyp_object node.\n *)\n | Ptyp_package of package_type\n (* (module S) *)\n | Ptyp_extension of extension\n(* [%id] *)\n\nand package_type = longident_loc * (longident_loc * core_type) list\n(*\n (module S)\n (module S with type t1 = T1 and ... and tn = Tn)\n*)\n\nand row_field = Parsetree.row_field = {\n prf_desc : row_field_desc;\n prf_loc : location;\n prf_attributes : attributes;\n}\n\nand row_field_desc = Parsetree.row_field_desc =\n | Rtag of label loc * bool * core_type list\n (* [`A] ( true, [] )\n [`A of T] ( false, [T] )\n [`A of T1 & .. & Tn] ( false, [T1;...Tn] )\n [`A of & T1 & .. & Tn] ( true, [T1;...Tn] )\n\n - The 2nd field is true if the tag contains a\n constant (empty) constructor.\n - '&' occurs when several types are used for the same constructor\n (see 4.2 in the manual)\n\n - TODO: switch to a record representation, and keep location\n *)\n | Rinherit of core_type\n(* [ | t ] *)\n\nand object_field = Parsetree.object_field = {\n pof_desc : object_field_desc;\n pof_loc : location;\n pof_attributes : attributes;\n}\n\nand object_field_desc = Parsetree.object_field_desc =\n | Otag of label loc * core_type\n | Oinherit of core_type\n\n(* Patterns *)\nand pattern = Parsetree.pattern = {\n ppat_desc : pattern_desc;\n ppat_loc : location;\n ppat_loc_stack : location_stack;\n ppat_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand pattern_desc = Parsetree.pattern_desc =\n | Ppat_any\n (* _ *)\n | Ppat_var of string loc\n (* x *)\n | Ppat_alias of pattern * string loc\n (* P as 'a *)\n | Ppat_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Ppat_interval of constant * constant\n (* 'a'..'z'\n\n Other forms of interval are recognized by the parser\n but rejected by the type-checker. *)\n | Ppat_tuple of pattern list\n (* (P1, ..., Pn)\n\n Invariant: n >= 2\n *)\n | Ppat_construct of longident_loc * pattern option\n (* C None\n C P Some P\n C (P1, ..., Pn) Some (Ppat_tuple [P1; ...; Pn])\n *)\n | Ppat_variant of label * pattern option\n (* `A (None)\n `A P (Some P)\n *)\n | Ppat_record of (longident_loc * pattern) list * closed_flag\n (* { l1=P1; ...; ln=Pn } (flag = Closed)\n { l1=P1; ...; ln=Pn; _} (flag = Open)\n\n Invariant: n > 0\n *)\n | Ppat_array of pattern list\n (* [| P1; ...; Pn |] *)\n | Ppat_or of pattern * pattern\n (* P1 | P2 *)\n | Ppat_constraint of pattern * core_type\n (* (P : T) *)\n | Ppat_type of longident_loc\n (* #tconst *)\n | Ppat_lazy of pattern\n (* lazy P *)\n | Ppat_unpack of string option loc\n (* (module P)\n Note: (module P : S) is represented as\n Ppat_constraint(Ppat_unpack, Ptyp_package)\n *)\n | Ppat_exception of pattern\n (* exception P *)\n | Ppat_extension of extension\n (* [%id] *)\n | Ppat_open of longident_loc * pattern\n(* M.(P) *)\n\n(* Value expressions *)\nand expression = Parsetree.expression = {\n pexp_desc : expression_desc;\n pexp_loc : location;\n pexp_loc_stack : location_stack;\n pexp_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand expression_desc = Parsetree.expression_desc =\n | Pexp_ident of longident_loc\n (* x\n M.x\n *)\n | Pexp_constant of constant\n (* 1, 'a', \"true\", 1.0, 1l, 1L, 1n *)\n | Pexp_let of rec_flag * value_binding list * expression\n (* let P1 = E1 and ... and Pn = EN in E (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in E (flag = Recursive)\n *)\n | Pexp_function of cases\n (* function P1 -> E1 | ... | Pn -> En *)\n | Pexp_fun of arg_label * expression option * pattern * expression\n (* fun P -> E1 (Simple, None)\n fun ~l:P -> E1 (Labelled l, None)\n fun ?l:P -> E1 (Optional l, None)\n fun ?l:(P = E0) -> E1 (Optional l, Some E0)\n\n Notes:\n - If E0 is provided, only Optional is allowed.\n - \"fun P1 P2 .. Pn -> E1\" is represented as nested Pexp_fun.\n - \"let f P = E\" is represented using Pexp_fun.\n *)\n | Pexp_apply of expression * (arg_label * expression) list\n (* E0 ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pexp_match of expression * cases\n (* match E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_try of expression * cases\n (* try E0 with P1 -> E1 | ... | Pn -> En *)\n | Pexp_tuple of expression list\n (* (E1, ..., En)\n\n Invariant: n >= 2\n *)\n | Pexp_construct of longident_loc * expression option\n (* C None\n C E Some E\n C (E1, ..., En) Some (Pexp_tuple[E1;...;En])\n *)\n | Pexp_variant of label * expression option\n (* `A (None)\n `A E (Some E)\n *)\n | Pexp_record of (longident_loc * expression) list * expression option\n (* { l1=P1; ...; ln=Pn } (None)\n { E0 with l1=P1; ...; ln=Pn } (Some E0)\n\n Invariant: n > 0\n *)\n | Pexp_field of expression * longident_loc\n (* E.l *)\n | Pexp_setfield of expression * longident_loc * expression\n (* E1.l <- E2 *)\n | Pexp_array of expression list\n (* [| E1; ...; En |] *)\n | Pexp_ifthenelse of expression * expression * expression option\n (* if E1 then E2 else E3 *)\n | Pexp_sequence of expression * expression\n (* E1; E2 *)\n | Pexp_while of expression * expression\n (* while E1 do E2 done *)\n | Pexp_for of pattern * expression * expression * direction_flag * expression\n (* for i = E1 to E2 do E3 done (flag = Upto)\n for i = E1 downto E2 do E3 done (flag = Downto)\n *)\n | Pexp_constraint of expression * core_type\n (* (E : T) *)\n | Pexp_coerce of expression * core_type option * core_type\n (* (E :> T) (None, T)\n (E : T0 :> T) (Some T0, T)\n *)\n | Pexp_send of expression * label loc\n (* E # m *)\n | Pexp_new of longident_loc\n (* new M.c *)\n | Pexp_setinstvar of label loc * expression\n (* x <- 2 *)\n | Pexp_override of (label loc * expression) list\n (* {< x1 = E1; ...; Xn = En >} *)\n | Pexp_letmodule of string option loc * module_expr * expression\n (* let module M = ME in E *)\n | Pexp_letexception of extension_constructor * expression\n (* let exception C in E *)\n | Pexp_assert of expression\n (* assert E\n Note: \"assert false\" is treated in a special way by the\n type-checker. *)\n | Pexp_lazy of expression\n (* lazy E *)\n | Pexp_poly of expression * core_type option\n (* Used for method bodies.\n\n Can only be used as the expression under Cfk_concrete\n for methods (not values). *)\n | Pexp_object of class_structure\n (* object ... end *)\n | Pexp_newtype of string loc * expression\n (* fun (type t) -> E *)\n | Pexp_pack of module_expr\n (* (module ME)\n\n (module ME : S) is represented as\n Pexp_constraint(Pexp_pack, Ptyp_package S) *)\n | Pexp_open of open_declaration * expression\n (* M.(E)\n let open M in E\n let! open M in E *)\n | Pexp_letop of letop\n (* let* P = E in E\n let* P = E and* P = E in E *)\n | Pexp_extension of extension\n (* [%id] *)\n | Pexp_unreachable\n(* . *)\n\nand case = Parsetree.case = {\n (* (P -> E) or (P when E0 -> E) *)\n pc_lhs : pattern;\n pc_guard : expression option;\n pc_rhs : expression;\n}\n\nand letop = Parsetree.letop = {\n let_ : binding_op;\n ands : binding_op list;\n body : expression;\n}\n\nand binding_op = Parsetree.binding_op = {\n pbop_op : string loc;\n pbop_pat : pattern;\n pbop_exp : expression;\n pbop_loc : location;\n}\n\n(* Value descriptions *)\nand value_description = Parsetree.value_description = {\n pval_name : string loc;\n pval_type : core_type;\n pval_prim : string list;\n pval_attributes : attributes;\n (* ... [@@id1] [@@id2] *)\n pval_loc : location;\n}\n\n(*\n val x: T (prim = [])\n external x: T = \"s1\" ... \"sn\" (prim = [\"s1\";...\"sn\"])\n*)\n\n(* Type declarations *)\nand type_declaration = Parsetree.type_declaration = {\n ptype_name : string loc;\n ptype_params : (core_type * (variance * injectivity)) list;\n (* ('a1,...'an) t; None represents _*)\n ptype_cstrs : (core_type * core_type * location) list;\n (* ... constraint T1=T1' ... constraint Tn=Tn' *)\n ptype_kind : type_kind;\n ptype_private : private_flag;\n (* = private ... *)\n ptype_manifest : core_type option;\n (* = T *)\n ptype_attributes : attributes;\n (* ... [@@id1] [@@id2] *)\n ptype_loc : location;\n}\n\n(*\n type t (abstract, no manifest)\n type t = T0 (abstract, manifest=T0)\n type t = C of T | ... (variant, no manifest)\n type t = T0 = C of T | ... (variant, manifest=T0)\n type t = {l: T; ...} (record, no manifest)\n type t = T0 = {l : T; ...} (record, manifest=T0)\n type t = .. (open, no manifest)\n*)\nand type_kind = Parsetree.type_kind =\n | Ptype_abstract\n | Ptype_variant of constructor_declaration list\n | Ptype_record of label_declaration list\n (* Invariant: non-empty list *)\n | Ptype_open\n\nand label_declaration = Parsetree.label_declaration = {\n pld_name : string loc;\n pld_mutable : mutable_flag;\n pld_type : core_type;\n pld_loc : location;\n pld_attributes : attributes; (* l : T [@id1] [@id2] *)\n}\n\n(* { ...; l: T; ... } (mutable=Immutable)\n { ...; mutable l: T; ... } (mutable=Mutable)\n\n Note: T can be a Ptyp_poly.\n*)\nand constructor_declaration = Parsetree.constructor_declaration = {\n pcd_name : string loc;\n pcd_args : constructor_arguments;\n pcd_res : core_type option;\n pcd_loc : location;\n pcd_attributes : attributes; (* C of ... [@id1] [@id2] *)\n}\n\nand constructor_arguments = Parsetree.constructor_arguments =\n | Pcstr_tuple of core_type list\n | Pcstr_record of label_declaration list\n\n(*\n | C of T1 * ... * Tn (res = None, args = Pcstr_tuple [])\n | C: T0 (res = Some T0, args = [])\n | C: T1 * ... * Tn -> T0 (res = Some T0, args = Pcstr_tuple)\n | C of {...} (res = None, args = Pcstr_record)\n | C: {...} -> T0 (res = Some T0, args = Pcstr_record)\n | C of {...} as t (res = None, args = Pcstr_record)\n*)\nand type_extension = Parsetree.type_extension = {\n ptyext_path : longident_loc;\n ptyext_params : (core_type * (variance * injectivity)) list;\n ptyext_constructors : extension_constructor list;\n ptyext_private : private_flag;\n ptyext_loc : location;\n ptyext_attributes : attributes; (* ... [@@id1] [@@id2] *)\n}\n(*\n type t += ...\n*)\n\nand extension_constructor = Parsetree.extension_constructor = {\n pext_name : string loc;\n pext_kind : extension_constructor_kind;\n pext_loc : location;\n pext_attributes : attributes; (* C of ... [@id1] [@id2] *)\n}\n\nand type_exception = Parsetree.type_exception = {\n ptyexn_constructor : extension_constructor;\n ptyexn_loc : location;\n ptyexn_attributes : attributes;\n}\n\nand extension_constructor_kind = Parsetree.extension_constructor_kind =\n | Pext_decl of constructor_arguments * core_type option\n (*\n | C of T1 * ... * Tn ([T1; ...; Tn], None)\n | C: T0 ([], Some T0)\n | C: T1 * ... * Tn -> T0 ([T1; ...; Tn], Some T0)\n *)\n | Pext_rebind of longident_loc\n(*\n | C = D\n *)\n\n(* Type expressions for the class language *)\n\n(** {1 Class language} *)\n\nand class_type = Parsetree.class_type = {\n pcty_desc : class_type_desc;\n pcty_loc : location;\n pcty_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand class_type_desc = Parsetree.class_type_desc =\n | Pcty_constr of longident_loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcty_signature of class_signature\n (* object ... end *)\n | Pcty_arrow of arg_label * core_type * class_type\n (* T -> CT Simple\n ~l:T -> CT Labelled l\n ?l:T -> CT Optional l\n *)\n | Pcty_extension of extension\n (* [%id] *)\n | Pcty_open of open_description * class_type\n(* let open M in CT *)\n\nand class_signature = Parsetree.class_signature = {\n pcsig_self : core_type;\n pcsig_fields : class_type_field list;\n}\n(* object('selfpat) ... end\n object ... end (self = Ptyp_any)\n*)\n\nand class_type_field = Parsetree.class_type_field = {\n pctf_desc : class_type_field_desc;\n pctf_loc : location;\n pctf_attributes : attributes; (* ... [@@id1] [@@id2] *)\n}\n\nand class_type_field_desc = Parsetree.class_type_field_desc =\n | Pctf_inherit of class_type\n (* inherit CT *)\n | Pctf_val of (label loc * mutable_flag * virtual_flag * core_type)\n (* val x: T *)\n | Pctf_method of (label loc * private_flag * virtual_flag * core_type)\n (* method x: T\n\n Note: T can be a Ptyp_poly.\n *)\n | Pctf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pctf_attribute of attribute\n (* [@@@id] *)\n | Pctf_extension of extension\n(* [%%id] *)\n\nand 'a class_infos = 'a Parsetree.class_infos = {\n pci_virt : virtual_flag;\n pci_params : (core_type * (variance * injectivity)) list;\n pci_name : string loc;\n pci_expr : 'a;\n pci_loc : location;\n pci_attributes : attributes; (* ... [@@id1] [@@id2] *)\n}\n(* class c = ...\n class ['a1,...,'an] c = ...\n class virtual c = ...\n\n Also used for \"class type\" declaration.\n*)\n\nand class_description = class_type class_infos\nand class_type_declaration = class_type class_infos\n\n(* Value expressions for the class language *)\nand class_expr = Parsetree.class_expr = {\n pcl_desc : class_expr_desc;\n pcl_loc : location;\n pcl_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand class_expr_desc = Parsetree.class_expr_desc =\n | Pcl_constr of longident_loc * core_type list\n (* c\n ['a1, ..., 'an] c *)\n | Pcl_structure of class_structure\n (* object ... end *)\n | Pcl_fun of arg_label * expression option * pattern * class_expr\n (* fun P -> CE (Simple, None)\n fun ~l:P -> CE (Labelled l, None)\n fun ?l:P -> CE (Optional l, None)\n fun ?l:(P = E0) -> CE (Optional l, Some E0)\n *)\n | Pcl_apply of class_expr * (arg_label * expression) list\n (* CE ~l1:E1 ... ~ln:En\n li can be empty (non labeled argument) or start with '?'\n (optional argument).\n\n Invariant: n > 0\n *)\n | Pcl_let of rec_flag * value_binding list * class_expr\n (* let P1 = E1 and ... and Pn = EN in CE (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN in CE (flag = Recursive)\n *)\n | Pcl_constraint of class_expr * class_type\n (* (CE : CT) *)\n | Pcl_extension of extension\n (* [%id] *)\n | Pcl_open of open_description * class_expr\n(* let open M in CE *)\n\nand class_structure = Parsetree.class_structure = {\n pcstr_self : pattern;\n pcstr_fields : class_field list;\n}\n(* object(selfpat) ... end\n object ... end (self = Ppat_any)\n*)\n\nand class_field = Parsetree.class_field = {\n pcf_desc : class_field_desc;\n pcf_loc : location;\n pcf_attributes : attributes; (* ... [@@id1] [@@id2] *)\n}\n\nand class_field_desc = Parsetree.class_field_desc =\n | Pcf_inherit of override_flag * class_expr * string loc option\n (* inherit CE\n inherit CE as x\n inherit! CE\n inherit! CE as x\n *)\n | Pcf_val of (label loc * mutable_flag * class_field_kind)\n (* val x = E\n val virtual x: T\n *)\n | Pcf_method of (label loc * private_flag * class_field_kind)\n (* method x = E (E can be a Pexp_poly)\n method virtual x: T (T can be a Ptyp_poly)\n *)\n | Pcf_constraint of (core_type * core_type)\n (* constraint T1 = T2 *)\n | Pcf_initializer of expression\n (* initializer E *)\n | Pcf_attribute of attribute\n (* [@@@id] *)\n | Pcf_extension of extension\n(* [%%id] *)\n\nand class_field_kind = Parsetree.class_field_kind =\n | Cfk_virtual of core_type\n | Cfk_concrete of override_flag * expression\n\nand class_declaration = class_expr class_infos\n(* Type expressions for the module language *)\n\n(** {1 Module language} *)\n\nand module_type = Parsetree.module_type = {\n pmty_desc : module_type_desc;\n pmty_loc : location;\n pmty_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand module_type_desc = Parsetree.module_type_desc =\n | Pmty_ident of longident_loc\n (* S *)\n | Pmty_signature of signature\n (* sig ... end *)\n | Pmty_functor of functor_parameter * module_type\n (* functor(X : MT1) -> MT2 *)\n | Pmty_with of module_type * with_constraint list\n (* MT with ... *)\n | Pmty_typeof of module_expr\n (* module type of ME *)\n | Pmty_extension of extension\n (* [%id] *)\n | Pmty_alias of longident_loc\n(* (module M) *)\n\nand functor_parameter = Parsetree.functor_parameter =\n | Unit\n (* () *)\n | Named of string option loc * module_type\n(* (X : MT) Some X, MT\n (_ : MT) None, MT *)\n\nand signature = signature_item list\n\nand signature_item = Parsetree.signature_item = {\n psig_desc : signature_item_desc;\n psig_loc : location;\n}\n\nand signature_item_desc = Parsetree.signature_item_desc =\n | Psig_value of value_description\n (*\n val x: T\n external x: T = \"s1\" ... \"sn\"\n *)\n | Psig_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Psig_typesubst of type_declaration list\n (* type t1 := ... and ... and tn := ... *)\n | Psig_typext of type_extension\n (* type t1 += ... *)\n | Psig_exception of type_exception\n (* exception C of T *)\n | Psig_module of module_declaration\n (* module X : MT *)\n | Psig_modsubst of module_substitution\n (* module X := M *)\n | Psig_recmodule of module_declaration list\n (* module rec X1 : MT1 and ... and Xn : MTn *)\n | Psig_modtype of module_type_declaration\n (* module type S = MT\n module type S *)\n | Psig_open of open_description\n (* open X *)\n | Psig_include of include_description\n (* include MT *)\n | Psig_class of class_description list\n (* class c1 : ... and ... and cn : ... *)\n | Psig_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Psig_attribute of attribute\n (* [@@@id] *)\n | Psig_extension of extension * attributes\n(* [%%id] *)\n\nand module_declaration = Parsetree.module_declaration = {\n pmd_name : string option loc;\n pmd_type : module_type;\n pmd_attributes : attributes;\n (* ... [@@id1] [@@id2] *)\n pmd_loc : location;\n}\n(* S : MT *)\n\nand module_substitution = Parsetree.module_substitution = {\n pms_name : string loc;\n pms_manifest : longident_loc;\n pms_attributes : attributes;\n pms_loc : location;\n}\n\nand module_type_declaration = Parsetree.module_type_declaration = {\n pmtd_name : string loc;\n pmtd_type : module_type option;\n pmtd_attributes : attributes;\n (* ... [@@id1] [@@id2] *)\n pmtd_loc : location;\n}\n(* S = MT\n S (abstract module type declaration, pmtd_type = None)\n*)\n\nand 'a open_infos = 'a Parsetree.open_infos = {\n popen_expr : 'a;\n popen_override : override_flag;\n popen_loc : location;\n popen_attributes : attributes;\n}\n\nand open_description = longident_loc open_infos\n(* open! X - popen_override = Override (silences the 'used identifier\n shadowing' warning)\n open X - popen_override = Fresh\n*)\n\nand open_declaration = module_expr open_infos\n\nand 'a include_infos = 'a Parsetree.include_infos = {\n pincl_mod : 'a;\n pincl_loc : location;\n pincl_attributes : attributes;\n}\n\nand include_description = module_type include_infos\n(* include MT *)\n\nand include_declaration = module_expr include_infos\n(* include ME *)\n\nand with_constraint = Parsetree.with_constraint =\n | Pwith_type of longident_loc * type_declaration\n (* with type X.t = ...\n\n Note: the last component of the longident must match\n the name of the type_declaration. *)\n | Pwith_module of longident_loc * longident_loc\n (* with module X.Y = Z *)\n | Pwith_typesubst of longident_loc * type_declaration\n (* with type X.t := ..., same format as [Pwith_type] *)\n | Pwith_modsubst of longident_loc * longident_loc\n(* with module X.Y := Z *)\n\n(* Value expressions for the module language *)\nand module_expr = Parsetree.module_expr = {\n pmod_desc : module_expr_desc;\n pmod_loc : location;\n pmod_attributes : attributes; (* ... [@id1] [@id2] *)\n}\n\nand module_expr_desc = Parsetree.module_expr_desc =\n | Pmod_ident of longident_loc\n (* X *)\n | Pmod_structure of structure\n (* struct ... end *)\n | Pmod_functor of functor_parameter * module_expr\n (* functor(X : MT1) -> ME *)\n | Pmod_apply of module_expr * module_expr\n (* ME1(ME2) *)\n | Pmod_constraint of module_expr * module_type\n (* (ME : MT) *)\n | Pmod_unpack of expression\n (* (val E) *)\n | Pmod_extension of extension\n(* [%id] *)\n\nand structure = structure_item list\n\nand structure_item = Parsetree.structure_item = {\n pstr_desc : structure_item_desc;\n pstr_loc : location;\n}\n\nand structure_item_desc = Parsetree.structure_item_desc =\n | Pstr_eval of expression * attributes\n (* E *)\n | Pstr_value of rec_flag * value_binding list\n (* let P1 = E1 and ... and Pn = EN (flag = Nonrecursive)\n let rec P1 = E1 and ... and Pn = EN (flag = Recursive)\n *)\n | Pstr_primitive of value_description\n (* val x: T\n external x: T = \"s1\" ... \"sn\" *)\n | Pstr_type of rec_flag * type_declaration list\n (* type t1 = ... and ... and tn = ... *)\n | Pstr_typext of type_extension\n (* type t1 += ... *)\n | Pstr_exception of type_exception\n (* exception C of T\n exception C = M.X *)\n | Pstr_module of module_binding\n (* module X = ME *)\n | Pstr_recmodule of module_binding list\n (* module rec X1 = ME1 and ... and Xn = MEn *)\n | Pstr_modtype of module_type_declaration\n (* module type S = MT *)\n | Pstr_open of open_declaration\n (* open X *)\n | Pstr_class of class_declaration list\n (* class c1 = ... and ... and cn = ... *)\n | Pstr_class_type of class_type_declaration list\n (* class type ct1 = ... and ... and ctn = ... *)\n | Pstr_include of include_declaration\n (* include ME *)\n | Pstr_attribute of attribute\n (* [@@@id] *)\n | Pstr_extension of extension * attributes\n(* [%%id] *)\n\nand value_binding = Parsetree.value_binding = {\n pvb_pat : pattern;\n pvb_expr : expression;\n pvb_attributes : attributes;\n pvb_loc : location;\n}\n\nand module_binding = Parsetree.module_binding = {\n pmb_name : string option loc;\n pmb_expr : module_expr;\n pmb_attributes : attributes;\n pmb_loc : location;\n}\n(* X = ME *)\n\n(* Toplevel phrases *)\n\n(** {1 Toplevel} *)\n\nand toplevel_phrase = Parsetree.toplevel_phrase =\n | Ptop_def of structure\n | Ptop_dir of toplevel_directive\n(* #use, #load ... *)\n\nand toplevel_directive = Parsetree.toplevel_directive = {\n pdir_name : string loc;\n pdir_arg : directive_argument option;\n pdir_loc : location;\n}\n\nand directive_argument = Parsetree.directive_argument = {\n pdira_desc : directive_argument_desc;\n pdira_loc : location;\n}\n\nand directive_argument_desc = Parsetree.directive_argument_desc =\n | Pdir_string of string\n | Pdir_int of string * char option\n | Pdir_ident of longident\n | Pdir_bool of bool\n\nand cases = case list [@@deriving_inline traverse]\n\nclass virtual map =\n object (self)\n method virtual bool : bool -> bool\n method virtual char : char -> char\n method virtual int : int -> int\n method virtual list : 'a. ('a -> 'a) -> 'a list -> 'a list\n method virtual option : 'a. ('a -> 'a) -> 'a option -> 'a option\n method virtual string : string -> string\n\n method position : position -> position =\n fun { pos_fname; pos_lnum; pos_bol; pos_cnum } ->\n let pos_fname = self#string pos_fname in\n let pos_lnum = self#int pos_lnum in\n let pos_bol = self#int pos_bol in\n let pos_cnum = self#int pos_cnum in\n { pos_fname; pos_lnum; pos_bol; pos_cnum }\n\n method location : location -> location =\n fun { loc_start; loc_end; loc_ghost } ->\n let loc_start = self#position loc_start in\n let loc_end = self#position loc_end in\n let loc_ghost = self#bool loc_ghost in\n { loc_start; loc_end; loc_ghost }\n\n method location_stack : location_stack -> location_stack =\n self#list self#location\n\n method loc : 'a. ('a -> 'a) -> 'a loc -> 'a loc =\n fun _a { txt; loc } ->\n let txt = _a txt in\n let loc = self#location loc in\n { txt; loc }\n\n method longident : longident -> longident =\n fun x ->\n match x with\n | Lident a ->\n let a = self#string a in\n Lident a\n | Ldot (a, b) ->\n let a = self#longident a in\n let b = self#string b in\n Ldot (a, b)\n | Lapply (a, b) ->\n let a = self#longident a in\n let b = self#longident b in\n Lapply (a, b)\n\n method longident_loc : longident_loc -> longident_loc =\n self#loc self#longident\n\n method rec_flag : rec_flag -> rec_flag = fun x -> x\n method direction_flag : direction_flag -> direction_flag = fun x -> x\n method private_flag : private_flag -> private_flag = fun x -> x\n method mutable_flag : mutable_flag -> mutable_flag = fun x -> x\n method virtual_flag : virtual_flag -> virtual_flag = fun x -> x\n method override_flag : override_flag -> override_flag = fun x -> x\n method closed_flag : closed_flag -> closed_flag = fun x -> x\n method label : label -> label = self#string\n\n method arg_label : arg_label -> arg_label =\n fun x ->\n match x with\n | Nolabel -> Nolabel\n | Labelled a ->\n let a = self#string a in\n Labelled a\n | Optional a ->\n let a = self#string a in\n Optional a\n\n method variance : variance -> variance = fun x -> x\n method injectivity : injectivity -> injectivity = fun x -> x\n\n method constant : constant -> constant =\n fun x ->\n match x with\n | Pconst_integer (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n Pconst_integer (a, b)\n | Pconst_char a ->\n let a = self#char a in\n Pconst_char a\n | Pconst_string (a, b, c) ->\n let a = self#string a in\n let b = self#location b in\n let c = self#option self#string c in\n Pconst_string (a, b, c)\n | Pconst_float (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n Pconst_float (a, b)\n\n method attribute : attribute -> attribute =\n fun { attr_name; attr_payload; attr_loc } ->\n let attr_name = self#loc self#string attr_name in\n let attr_payload = self#payload attr_payload in\n let attr_loc = self#location attr_loc in\n { attr_name; attr_payload; attr_loc }\n\n method extension : extension -> extension =\n fun (a, b) ->\n let a = self#loc self#string a in\n let b = self#payload b in\n (a, b)\n\n method attributes : attributes -> attributes = self#list self#attribute\n\n method payload : payload -> payload =\n fun x ->\n match x with\n | PStr a ->\n let a = self#structure a in\n PStr a\n | PSig a ->\n let a = self#signature a in\n PSig a\n | PTyp a ->\n let a = self#core_type a in\n PTyp a\n | PPat (a, b) ->\n let a = self#pattern a in\n let b = self#option self#expression b in\n PPat (a, b)\n\n method core_type : core_type -> core_type =\n fun { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } ->\n let ptyp_desc = self#core_type_desc ptyp_desc in\n let ptyp_loc = self#location ptyp_loc in\n let ptyp_loc_stack = self#location_stack ptyp_loc_stack in\n let ptyp_attributes = self#attributes ptyp_attributes in\n { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes }\n\n method core_type_desc : core_type_desc -> core_type_desc =\n fun x ->\n match x with\n | Ptyp_any -> Ptyp_any\n | Ptyp_var a ->\n let a = self#string a in\n Ptyp_var a\n | Ptyp_arrow (a, b, c) ->\n let a = self#arg_label a in\n let b = self#core_type b in\n let c = self#core_type c in\n Ptyp_arrow (a, b, c)\n | Ptyp_tuple a ->\n let a = self#list self#core_type a in\n Ptyp_tuple a\n | Ptyp_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n Ptyp_constr (a, b)\n | Ptyp_object (a, b) ->\n let a = self#list self#object_field a in\n let b = self#closed_flag b in\n Ptyp_object (a, b)\n | Ptyp_class (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n Ptyp_class (a, b)\n | Ptyp_alias (a, b) ->\n let a = self#core_type a in\n let b = self#string b in\n Ptyp_alias (a, b)\n | Ptyp_variant (a, b, c) ->\n let a = self#list self#row_field a in\n let b = self#closed_flag b in\n let c = self#option (self#list self#label) c in\n Ptyp_variant (a, b, c)\n | Ptyp_poly (a, b) ->\n let a = self#list (self#loc self#string) a in\n let b = self#core_type b in\n Ptyp_poly (a, b)\n | Ptyp_package a ->\n let a = self#package_type a in\n Ptyp_package a\n | Ptyp_extension a ->\n let a = self#extension a in\n Ptyp_extension a\n\n method package_type : package_type -> package_type =\n fun (a, b) ->\n let a = self#longident_loc a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#core_type b in\n (a, b))\n b\n in\n (a, b)\n\n method row_field : row_field -> row_field =\n fun { prf_desc; prf_loc; prf_attributes } ->\n let prf_desc = self#row_field_desc prf_desc in\n let prf_loc = self#location prf_loc in\n let prf_attributes = self#attributes prf_attributes in\n { prf_desc; prf_loc; prf_attributes }\n\n method row_field_desc : row_field_desc -> row_field_desc =\n fun x ->\n match x with\n | Rtag (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#bool b in\n let c = self#list self#core_type c in\n Rtag (a, b, c)\n | Rinherit a ->\n let a = self#core_type a in\n Rinherit a\n\n method object_field : object_field -> object_field =\n fun { pof_desc; pof_loc; pof_attributes } ->\n let pof_desc = self#object_field_desc pof_desc in\n let pof_loc = self#location pof_loc in\n let pof_attributes = self#attributes pof_attributes in\n { pof_desc; pof_loc; pof_attributes }\n\n method object_field_desc : object_field_desc -> object_field_desc =\n fun x ->\n match x with\n | Otag (a, b) ->\n let a = self#loc self#label a in\n let b = self#core_type b in\n Otag (a, b)\n | Oinherit a ->\n let a = self#core_type a in\n Oinherit a\n\n method pattern : pattern -> pattern =\n fun { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } ->\n let ppat_desc = self#pattern_desc ppat_desc in\n let ppat_loc = self#location ppat_loc in\n let ppat_loc_stack = self#location_stack ppat_loc_stack in\n let ppat_attributes = self#attributes ppat_attributes in\n { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes }\n\n method pattern_desc : pattern_desc -> pattern_desc =\n fun x ->\n match x with\n | Ppat_any -> Ppat_any\n | Ppat_var a ->\n let a = self#loc self#string a in\n Ppat_var a\n | Ppat_alias (a, b) ->\n let a = self#pattern a in\n let b = self#loc self#string b in\n Ppat_alias (a, b)\n | Ppat_constant a ->\n let a = self#constant a in\n Ppat_constant a\n | Ppat_interval (a, b) ->\n let a = self#constant a in\n let b = self#constant b in\n Ppat_interval (a, b)\n | Ppat_tuple a ->\n let a = self#list self#pattern a in\n Ppat_tuple a\n | Ppat_construct (a, b) ->\n let a = self#longident_loc a in\n let b = self#option self#pattern b in\n Ppat_construct (a, b)\n | Ppat_variant (a, b) ->\n let a = self#label a in\n let b = self#option self#pattern b in\n Ppat_variant (a, b)\n | Ppat_record (a, b) ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#pattern b in\n (a, b))\n a\n in\n let b = self#closed_flag b in\n Ppat_record (a, b)\n | Ppat_array a ->\n let a = self#list self#pattern a in\n Ppat_array a\n | Ppat_or (a, b) ->\n let a = self#pattern a in\n let b = self#pattern b in\n Ppat_or (a, b)\n | Ppat_constraint (a, b) ->\n let a = self#pattern a in\n let b = self#core_type b in\n Ppat_constraint (a, b)\n | Ppat_type a ->\n let a = self#longident_loc a in\n Ppat_type a\n | Ppat_lazy a ->\n let a = self#pattern a in\n Ppat_lazy a\n | Ppat_unpack a ->\n let a = self#loc (self#option self#string) a in\n Ppat_unpack a\n | Ppat_exception a ->\n let a = self#pattern a in\n Ppat_exception a\n | Ppat_extension a ->\n let a = self#extension a in\n Ppat_extension a\n | Ppat_open (a, b) ->\n let a = self#longident_loc a in\n let b = self#pattern b in\n Ppat_open (a, b)\n\n method expression : expression -> expression =\n fun { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } ->\n let pexp_desc = self#expression_desc pexp_desc in\n let pexp_loc = self#location pexp_loc in\n let pexp_loc_stack = self#location_stack pexp_loc_stack in\n let pexp_attributes = self#attributes pexp_attributes in\n { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes }\n\n method expression_desc : expression_desc -> expression_desc =\n fun x ->\n match x with\n | Pexp_ident a ->\n let a = self#longident_loc a in\n Pexp_ident a\n | Pexp_constant a ->\n let a = self#constant a in\n Pexp_constant a\n | Pexp_let (a, b, c) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n let c = self#expression c in\n Pexp_let (a, b, c)\n | Pexp_function a ->\n let a = self#cases a in\n Pexp_function a\n | Pexp_fun (a, b, c, d) ->\n let a = self#arg_label a in\n let b = self#option self#expression b in\n let c = self#pattern c in\n let d = self#expression d in\n Pexp_fun (a, b, c, d)\n | Pexp_apply (a, b) ->\n let a = self#expression a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#arg_label a in\n let b = self#expression b in\n (a, b))\n b\n in\n Pexp_apply (a, b)\n | Pexp_match (a, b) ->\n let a = self#expression a in\n let b = self#cases b in\n Pexp_match (a, b)\n | Pexp_try (a, b) ->\n let a = self#expression a in\n let b = self#cases b in\n Pexp_try (a, b)\n | Pexp_tuple a ->\n let a = self#list self#expression a in\n Pexp_tuple a\n | Pexp_construct (a, b) ->\n let a = self#longident_loc a in\n let b = self#option self#expression b in\n Pexp_construct (a, b)\n | Pexp_variant (a, b) ->\n let a = self#label a in\n let b = self#option self#expression b in\n Pexp_variant (a, b)\n | Pexp_record (a, b) ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#expression b in\n (a, b))\n a\n in\n let b = self#option self#expression b in\n Pexp_record (a, b)\n | Pexp_field (a, b) ->\n let a = self#expression a in\n let b = self#longident_loc b in\n Pexp_field (a, b)\n | Pexp_setfield (a, b, c) ->\n let a = self#expression a in\n let b = self#longident_loc b in\n let c = self#expression c in\n Pexp_setfield (a, b, c)\n | Pexp_array a ->\n let a = self#list self#expression a in\n Pexp_array a\n | Pexp_ifthenelse (a, b, c) ->\n let a = self#expression a in\n let b = self#expression b in\n let c = self#option self#expression c in\n Pexp_ifthenelse (a, b, c)\n | Pexp_sequence (a, b) ->\n let a = self#expression a in\n let b = self#expression b in\n Pexp_sequence (a, b)\n | Pexp_while (a, b) ->\n let a = self#expression a in\n let b = self#expression b in\n Pexp_while (a, b)\n | Pexp_for (a, b, c, d, e) ->\n let a = self#pattern a in\n let b = self#expression b in\n let c = self#expression c in\n let d = self#direction_flag d in\n let e = self#expression e in\n Pexp_for (a, b, c, d, e)\n | Pexp_constraint (a, b) ->\n let a = self#expression a in\n let b = self#core_type b in\n Pexp_constraint (a, b)\n | Pexp_coerce (a, b, c) ->\n let a = self#expression a in\n let b = self#option self#core_type b in\n let c = self#core_type c in\n Pexp_coerce (a, b, c)\n | Pexp_send (a, b) ->\n let a = self#expression a in\n let b = self#loc self#label b in\n Pexp_send (a, b)\n | Pexp_new a ->\n let a = self#longident_loc a in\n Pexp_new a\n | Pexp_setinstvar (a, b) ->\n let a = self#loc self#label a in\n let b = self#expression b in\n Pexp_setinstvar (a, b)\n | Pexp_override a ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#loc self#label a in\n let b = self#expression b in\n (a, b))\n a\n in\n Pexp_override a\n | Pexp_letmodule (a, b, c) ->\n let a = self#loc (self#option self#string) a in\n let b = self#module_expr b in\n let c = self#expression c in\n Pexp_letmodule (a, b, c)\n | Pexp_letexception (a, b) ->\n let a = self#extension_constructor a in\n let b = self#expression b in\n Pexp_letexception (a, b)\n | Pexp_assert a ->\n let a = self#expression a in\n Pexp_assert a\n | Pexp_lazy a ->\n let a = self#expression a in\n Pexp_lazy a\n | Pexp_poly (a, b) ->\n let a = self#expression a in\n let b = self#option self#core_type b in\n Pexp_poly (a, b)\n | Pexp_object a ->\n let a = self#class_structure a in\n Pexp_object a\n | Pexp_newtype (a, b) ->\n let a = self#loc self#string a in\n let b = self#expression b in\n Pexp_newtype (a, b)\n | Pexp_pack a ->\n let a = self#module_expr a in\n Pexp_pack a\n | Pexp_open (a, b) ->\n let a = self#open_declaration a in\n let b = self#expression b in\n Pexp_open (a, b)\n | Pexp_letop a ->\n let a = self#letop a in\n Pexp_letop a\n | Pexp_extension a ->\n let a = self#extension a in\n Pexp_extension a\n | Pexp_unreachable -> Pexp_unreachable\n\n method case : case -> case =\n fun { pc_lhs; pc_guard; pc_rhs } ->\n let pc_lhs = self#pattern pc_lhs in\n let pc_guard = self#option self#expression pc_guard in\n let pc_rhs = self#expression pc_rhs in\n { pc_lhs; pc_guard; pc_rhs }\n\n method letop : letop -> letop =\n fun { let_; ands; body } ->\n let let_ = self#binding_op let_ in\n let ands = self#list self#binding_op ands in\n let body = self#expression body in\n { let_; ands; body }\n\n method binding_op : binding_op -> binding_op =\n fun { pbop_op; pbop_pat; pbop_exp; pbop_loc } ->\n let pbop_op = self#loc self#string pbop_op in\n let pbop_pat = self#pattern pbop_pat in\n let pbop_exp = self#expression pbop_exp in\n let pbop_loc = self#location pbop_loc in\n { pbop_op; pbop_pat; pbop_exp; pbop_loc }\n\n method value_description : value_description -> value_description =\n fun { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } ->\n let pval_name = self#loc self#string pval_name in\n let pval_type = self#core_type pval_type in\n let pval_prim = self#list self#string pval_prim in\n let pval_attributes = self#attributes pval_attributes in\n let pval_loc = self#location pval_loc in\n { pval_name; pval_type; pval_prim; pval_attributes; pval_loc }\n\n method type_declaration : type_declaration -> type_declaration =\n fun {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } ->\n let ptype_name = self#loc self#string ptype_name in\n let ptype_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n (a, b))\n b\n in\n (a, b))\n ptype_params\n in\n let ptype_cstrs =\n self#list\n (fun (a, b, c) ->\n let a = self#core_type a in\n let b = self#core_type b in\n let c = self#location c in\n (a, b, c))\n ptype_cstrs\n in\n let ptype_kind = self#type_kind ptype_kind in\n let ptype_private = self#private_flag ptype_private in\n let ptype_manifest = self#option self#core_type ptype_manifest in\n let ptype_attributes = self#attributes ptype_attributes in\n let ptype_loc = self#location ptype_loc in\n {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n }\n\n method type_kind : type_kind -> type_kind =\n fun x ->\n match x with\n | Ptype_abstract -> Ptype_abstract\n | Ptype_variant a ->\n let a = self#list self#constructor_declaration a in\n Ptype_variant a\n | Ptype_record a ->\n let a = self#list self#label_declaration a in\n Ptype_record a\n | Ptype_open -> Ptype_open\n\n method label_declaration : label_declaration -> label_declaration =\n fun { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } ->\n let pld_name = self#loc self#string pld_name in\n let pld_mutable = self#mutable_flag pld_mutable in\n let pld_type = self#core_type pld_type in\n let pld_loc = self#location pld_loc in\n let pld_attributes = self#attributes pld_attributes in\n { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes }\n\n method constructor_declaration\n : constructor_declaration -> constructor_declaration =\n fun { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } ->\n let pcd_name = self#loc self#string pcd_name in\n let pcd_args = self#constructor_arguments pcd_args in\n let pcd_res = self#option self#core_type pcd_res in\n let pcd_loc = self#location pcd_loc in\n let pcd_attributes = self#attributes pcd_attributes in\n { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes }\n\n method constructor_arguments\n : constructor_arguments -> constructor_arguments =\n fun x ->\n match x with\n | Pcstr_tuple a ->\n let a = self#list self#core_type a in\n Pcstr_tuple a\n | Pcstr_record a ->\n let a = self#list self#label_declaration a in\n Pcstr_record a\n\n method type_extension : type_extension -> type_extension =\n fun {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } ->\n let ptyext_path = self#longident_loc ptyext_path in\n let ptyext_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n (a, b))\n b\n in\n (a, b))\n ptyext_params\n in\n let ptyext_constructors =\n self#list self#extension_constructor ptyext_constructors\n in\n let ptyext_private = self#private_flag ptyext_private in\n let ptyext_loc = self#location ptyext_loc in\n let ptyext_attributes = self#attributes ptyext_attributes in\n {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n }\n\n method extension_constructor\n : extension_constructor -> extension_constructor =\n fun { pext_name; pext_kind; pext_loc; pext_attributes } ->\n let pext_name = self#loc self#string pext_name in\n let pext_kind = self#extension_constructor_kind pext_kind in\n let pext_loc = self#location pext_loc in\n let pext_attributes = self#attributes pext_attributes in\n { pext_name; pext_kind; pext_loc; pext_attributes }\n\n method type_exception : type_exception -> type_exception =\n fun { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } ->\n let ptyexn_constructor =\n self#extension_constructor ptyexn_constructor\n in\n let ptyexn_loc = self#location ptyexn_loc in\n let ptyexn_attributes = self#attributes ptyexn_attributes in\n { ptyexn_constructor; ptyexn_loc; ptyexn_attributes }\n\n method extension_constructor_kind\n : extension_constructor_kind -> extension_constructor_kind =\n fun x ->\n match x with\n | Pext_decl (a, b) ->\n let a = self#constructor_arguments a in\n let b = self#option self#core_type b in\n Pext_decl (a, b)\n | Pext_rebind a ->\n let a = self#longident_loc a in\n Pext_rebind a\n\n method class_type : class_type -> class_type =\n fun { pcty_desc; pcty_loc; pcty_attributes } ->\n let pcty_desc = self#class_type_desc pcty_desc in\n let pcty_loc = self#location pcty_loc in\n let pcty_attributes = self#attributes pcty_attributes in\n { pcty_desc; pcty_loc; pcty_attributes }\n\n method class_type_desc : class_type_desc -> class_type_desc =\n fun x ->\n match x with\n | Pcty_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n Pcty_constr (a, b)\n | Pcty_signature a ->\n let a = self#class_signature a in\n Pcty_signature a\n | Pcty_arrow (a, b, c) ->\n let a = self#arg_label a in\n let b = self#core_type b in\n let c = self#class_type c in\n Pcty_arrow (a, b, c)\n | Pcty_extension a ->\n let a = self#extension a in\n Pcty_extension a\n | Pcty_open (a, b) ->\n let a = self#open_description a in\n let b = self#class_type b in\n Pcty_open (a, b)\n\n method class_signature : class_signature -> class_signature =\n fun { pcsig_self; pcsig_fields } ->\n let pcsig_self = self#core_type pcsig_self in\n let pcsig_fields = self#list self#class_type_field pcsig_fields in\n { pcsig_self; pcsig_fields }\n\n method class_type_field : class_type_field -> class_type_field =\n fun { pctf_desc; pctf_loc; pctf_attributes } ->\n let pctf_desc = self#class_type_field_desc pctf_desc in\n let pctf_loc = self#location pctf_loc in\n let pctf_attributes = self#attributes pctf_attributes in\n { pctf_desc; pctf_loc; pctf_attributes }\n\n method class_type_field_desc\n : class_type_field_desc -> class_type_field_desc =\n fun x ->\n match x with\n | Pctf_inherit a ->\n let a = self#class_type a in\n Pctf_inherit a\n | Pctf_val a ->\n let a =\n (fun (a, b, c, d) ->\n let a = self#loc self#label a in\n let b = self#mutable_flag b in\n let c = self#virtual_flag c in\n let d = self#core_type d in\n (a, b, c, d))\n a\n in\n Pctf_val a\n | Pctf_method a ->\n let a =\n (fun (a, b, c, d) ->\n let a = self#loc self#label a in\n let b = self#private_flag b in\n let c = self#virtual_flag c in\n let d = self#core_type d in\n (a, b, c, d))\n a\n in\n Pctf_method a\n | Pctf_constraint a ->\n let a =\n (fun (a, b) ->\n let a = self#core_type a in\n let b = self#core_type b in\n (a, b))\n a\n in\n Pctf_constraint a\n | Pctf_attribute a ->\n let a = self#attribute a in\n Pctf_attribute a\n | Pctf_extension a ->\n let a = self#extension a in\n Pctf_extension a\n\n method class_infos : 'a. ('a -> 'a) -> 'a class_infos -> 'a class_infos =\n fun _a\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes } ->\n let pci_virt = self#virtual_flag pci_virt in\n let pci_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n (a, b))\n b\n in\n (a, b))\n pci_params\n in\n let pci_name = self#loc self#string pci_name in\n let pci_expr = _a pci_expr in\n let pci_loc = self#location pci_loc in\n let pci_attributes = self#attributes pci_attributes in\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes }\n\n method class_description : class_description -> class_description =\n self#class_infos self#class_type\n\n method class_type_declaration\n : class_type_declaration -> class_type_declaration =\n self#class_infos self#class_type\n\n method class_expr : class_expr -> class_expr =\n fun { pcl_desc; pcl_loc; pcl_attributes } ->\n let pcl_desc = self#class_expr_desc pcl_desc in\n let pcl_loc = self#location pcl_loc in\n let pcl_attributes = self#attributes pcl_attributes in\n { pcl_desc; pcl_loc; pcl_attributes }\n\n method class_expr_desc : class_expr_desc -> class_expr_desc =\n fun x ->\n match x with\n | Pcl_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n Pcl_constr (a, b)\n | Pcl_structure a ->\n let a = self#class_structure a in\n Pcl_structure a\n | Pcl_fun (a, b, c, d) ->\n let a = self#arg_label a in\n let b = self#option self#expression b in\n let c = self#pattern c in\n let d = self#class_expr d in\n Pcl_fun (a, b, c, d)\n | Pcl_apply (a, b) ->\n let a = self#class_expr a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#arg_label a in\n let b = self#expression b in\n (a, b))\n b\n in\n Pcl_apply (a, b)\n | Pcl_let (a, b, c) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n let c = self#class_expr c in\n Pcl_let (a, b, c)\n | Pcl_constraint (a, b) ->\n let a = self#class_expr a in\n let b = self#class_type b in\n Pcl_constraint (a, b)\n | Pcl_extension a ->\n let a = self#extension a in\n Pcl_extension a\n | Pcl_open (a, b) ->\n let a = self#open_description a in\n let b = self#class_expr b in\n Pcl_open (a, b)\n\n method class_structure : class_structure -> class_structure =\n fun { pcstr_self; pcstr_fields } ->\n let pcstr_self = self#pattern pcstr_self in\n let pcstr_fields = self#list self#class_field pcstr_fields in\n { pcstr_self; pcstr_fields }\n\n method class_field : class_field -> class_field =\n fun { pcf_desc; pcf_loc; pcf_attributes } ->\n let pcf_desc = self#class_field_desc pcf_desc in\n let pcf_loc = self#location pcf_loc in\n let pcf_attributes = self#attributes pcf_attributes in\n { pcf_desc; pcf_loc; pcf_attributes }\n\n method class_field_desc : class_field_desc -> class_field_desc =\n fun x ->\n match x with\n | Pcf_inherit (a, b, c) ->\n let a = self#override_flag a in\n let b = self#class_expr b in\n let c = self#option (self#loc self#string) c in\n Pcf_inherit (a, b, c)\n | Pcf_val a ->\n let a =\n (fun (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#mutable_flag b in\n let c = self#class_field_kind c in\n (a, b, c))\n a\n in\n Pcf_val a\n | Pcf_method a ->\n let a =\n (fun (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#private_flag b in\n let c = self#class_field_kind c in\n (a, b, c))\n a\n in\n Pcf_method a\n | Pcf_constraint a ->\n let a =\n (fun (a, b) ->\n let a = self#core_type a in\n let b = self#core_type b in\n (a, b))\n a\n in\n Pcf_constraint a\n | Pcf_initializer a ->\n let a = self#expression a in\n Pcf_initializer a\n | Pcf_attribute a ->\n let a = self#attribute a in\n Pcf_attribute a\n | Pcf_extension a ->\n let a = self#extension a in\n Pcf_extension a\n\n method class_field_kind : class_field_kind -> class_field_kind =\n fun x ->\n match x with\n | Cfk_virtual a ->\n let a = self#core_type a in\n Cfk_virtual a\n | Cfk_concrete (a, b) ->\n let a = self#override_flag a in\n let b = self#expression b in\n Cfk_concrete (a, b)\n\n method class_declaration : class_declaration -> class_declaration =\n self#class_infos self#class_expr\n\n method module_type : module_type -> module_type =\n fun { pmty_desc; pmty_loc; pmty_attributes } ->\n let pmty_desc = self#module_type_desc pmty_desc in\n let pmty_loc = self#location pmty_loc in\n let pmty_attributes = self#attributes pmty_attributes in\n { pmty_desc; pmty_loc; pmty_attributes }\n\n method module_type_desc : module_type_desc -> module_type_desc =\n fun x ->\n match x with\n | Pmty_ident a ->\n let a = self#longident_loc a in\n Pmty_ident a\n | Pmty_signature a ->\n let a = self#signature a in\n Pmty_signature a\n | Pmty_functor (a, b) ->\n let a = self#functor_parameter a in\n let b = self#module_type b in\n Pmty_functor (a, b)\n | Pmty_with (a, b) ->\n let a = self#module_type a in\n let b = self#list self#with_constraint b in\n Pmty_with (a, b)\n | Pmty_typeof a ->\n let a = self#module_expr a in\n Pmty_typeof a\n | Pmty_extension a ->\n let a = self#extension a in\n Pmty_extension a\n | Pmty_alias a ->\n let a = self#longident_loc a in\n Pmty_alias a\n\n method functor_parameter : functor_parameter -> functor_parameter =\n fun x ->\n match x with\n | Unit -> Unit\n | Named (a, b) ->\n let a = self#loc (self#option self#string) a in\n let b = self#module_type b in\n Named (a, b)\n\n method signature : signature -> signature = self#list self#signature_item\n\n method signature_item : signature_item -> signature_item =\n fun { psig_desc; psig_loc } ->\n let psig_desc = self#signature_item_desc psig_desc in\n let psig_loc = self#location psig_loc in\n { psig_desc; psig_loc }\n\n method signature_item_desc : signature_item_desc -> signature_item_desc =\n fun x ->\n match x with\n | Psig_value a ->\n let a = self#value_description a in\n Psig_value a\n | Psig_type (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#type_declaration b in\n Psig_type (a, b)\n | Psig_typesubst a ->\n let a = self#list self#type_declaration a in\n Psig_typesubst a\n | Psig_typext a ->\n let a = self#type_extension a in\n Psig_typext a\n | Psig_exception a ->\n let a = self#type_exception a in\n Psig_exception a\n | Psig_module a ->\n let a = self#module_declaration a in\n Psig_module a\n | Psig_modsubst a ->\n let a = self#module_substitution a in\n Psig_modsubst a\n | Psig_recmodule a ->\n let a = self#list self#module_declaration a in\n Psig_recmodule a\n | Psig_modtype a ->\n let a = self#module_type_declaration a in\n Psig_modtype a\n | Psig_open a ->\n let a = self#open_description a in\n Psig_open a\n | Psig_include a ->\n let a = self#include_description a in\n Psig_include a\n | Psig_class a ->\n let a = self#list self#class_description a in\n Psig_class a\n | Psig_class_type a ->\n let a = self#list self#class_type_declaration a in\n Psig_class_type a\n | Psig_attribute a ->\n let a = self#attribute a in\n Psig_attribute a\n | Psig_extension (a, b) ->\n let a = self#extension a in\n let b = self#attributes b in\n Psig_extension (a, b)\n\n method module_declaration : module_declaration -> module_declaration =\n fun { pmd_name; pmd_type; pmd_attributes; pmd_loc } ->\n let pmd_name = self#loc (self#option self#string) pmd_name in\n let pmd_type = self#module_type pmd_type in\n let pmd_attributes = self#attributes pmd_attributes in\n let pmd_loc = self#location pmd_loc in\n { pmd_name; pmd_type; pmd_attributes; pmd_loc }\n\n method module_substitution : module_substitution -> module_substitution =\n fun { pms_name; pms_manifest; pms_attributes; pms_loc } ->\n let pms_name = self#loc self#string pms_name in\n let pms_manifest = self#longident_loc pms_manifest in\n let pms_attributes = self#attributes pms_attributes in\n let pms_loc = self#location pms_loc in\n { pms_name; pms_manifest; pms_attributes; pms_loc }\n\n method module_type_declaration\n : module_type_declaration -> module_type_declaration =\n fun { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } ->\n let pmtd_name = self#loc self#string pmtd_name in\n let pmtd_type = self#option self#module_type pmtd_type in\n let pmtd_attributes = self#attributes pmtd_attributes in\n let pmtd_loc = self#location pmtd_loc in\n { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc }\n\n method open_infos : 'a. ('a -> 'a) -> 'a open_infos -> 'a open_infos =\n fun _a { popen_expr; popen_override; popen_loc; popen_attributes } ->\n let popen_expr = _a popen_expr in\n let popen_override = self#override_flag popen_override in\n let popen_loc = self#location popen_loc in\n let popen_attributes = self#attributes popen_attributes in\n { popen_expr; popen_override; popen_loc; popen_attributes }\n\n method open_description : open_description -> open_description =\n self#open_infos self#longident_loc\n\n method open_declaration : open_declaration -> open_declaration =\n self#open_infos self#module_expr\n\n method include_infos\n : 'a. ('a -> 'a) -> 'a include_infos -> 'a include_infos =\n fun _a { pincl_mod; pincl_loc; pincl_attributes } ->\n let pincl_mod = _a pincl_mod in\n let pincl_loc = self#location pincl_loc in\n let pincl_attributes = self#attributes pincl_attributes in\n { pincl_mod; pincl_loc; pincl_attributes }\n\n method include_description : include_description -> include_description =\n self#include_infos self#module_type\n\n method include_declaration : include_declaration -> include_declaration =\n self#include_infos self#module_expr\n\n method with_constraint : with_constraint -> with_constraint =\n fun x ->\n match x with\n | Pwith_type (a, b) ->\n let a = self#longident_loc a in\n let b = self#type_declaration b in\n Pwith_type (a, b)\n | Pwith_module (a, b) ->\n let a = self#longident_loc a in\n let b = self#longident_loc b in\n Pwith_module (a, b)\n | Pwith_typesubst (a, b) ->\n let a = self#longident_loc a in\n let b = self#type_declaration b in\n Pwith_typesubst (a, b)\n | Pwith_modsubst (a, b) ->\n let a = self#longident_loc a in\n let b = self#longident_loc b in\n Pwith_modsubst (a, b)\n\n method module_expr : module_expr -> module_expr =\n fun { pmod_desc; pmod_loc; pmod_attributes } ->\n let pmod_desc = self#module_expr_desc pmod_desc in\n let pmod_loc = self#location pmod_loc in\n let pmod_attributes = self#attributes pmod_attributes in\n { pmod_desc; pmod_loc; pmod_attributes }\n\n method module_expr_desc : module_expr_desc -> module_expr_desc =\n fun x ->\n match x with\n | Pmod_ident a ->\n let a = self#longident_loc a in\n Pmod_ident a\n | Pmod_structure a ->\n let a = self#structure a in\n Pmod_structure a\n | Pmod_functor (a, b) ->\n let a = self#functor_parameter a in\n let b = self#module_expr b in\n Pmod_functor (a, b)\n | Pmod_apply (a, b) ->\n let a = self#module_expr a in\n let b = self#module_expr b in\n Pmod_apply (a, b)\n | Pmod_constraint (a, b) ->\n let a = self#module_expr a in\n let b = self#module_type b in\n Pmod_constraint (a, b)\n | Pmod_unpack a ->\n let a = self#expression a in\n Pmod_unpack a\n | Pmod_extension a ->\n let a = self#extension a in\n Pmod_extension a\n\n method structure : structure -> structure = self#list self#structure_item\n\n method structure_item : structure_item -> structure_item =\n fun { pstr_desc; pstr_loc } ->\n let pstr_desc = self#structure_item_desc pstr_desc in\n let pstr_loc = self#location pstr_loc in\n { pstr_desc; pstr_loc }\n\n method structure_item_desc : structure_item_desc -> structure_item_desc =\n fun x ->\n match x with\n | Pstr_eval (a, b) ->\n let a = self#expression a in\n let b = self#attributes b in\n Pstr_eval (a, b)\n | Pstr_value (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n Pstr_value (a, b)\n | Pstr_primitive a ->\n let a = self#value_description a in\n Pstr_primitive a\n | Pstr_type (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#type_declaration b in\n Pstr_type (a, b)\n | Pstr_typext a ->\n let a = self#type_extension a in\n Pstr_typext a\n | Pstr_exception a ->\n let a = self#type_exception a in\n Pstr_exception a\n | Pstr_module a ->\n let a = self#module_binding a in\n Pstr_module a\n | Pstr_recmodule a ->\n let a = self#list self#module_binding a in\n Pstr_recmodule a\n | Pstr_modtype a ->\n let a = self#module_type_declaration a in\n Pstr_modtype a\n | Pstr_open a ->\n let a = self#open_declaration a in\n Pstr_open a\n | Pstr_class a ->\n let a = self#list self#class_declaration a in\n Pstr_class a\n | Pstr_class_type a ->\n let a = self#list self#class_type_declaration a in\n Pstr_class_type a\n | Pstr_include a ->\n let a = self#include_declaration a in\n Pstr_include a\n | Pstr_attribute a ->\n let a = self#attribute a in\n Pstr_attribute a\n | Pstr_extension (a, b) ->\n let a = self#extension a in\n let b = self#attributes b in\n Pstr_extension (a, b)\n\n method value_binding : value_binding -> value_binding =\n fun { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } ->\n let pvb_pat = self#pattern pvb_pat in\n let pvb_expr = self#expression pvb_expr in\n let pvb_attributes = self#attributes pvb_attributes in\n let pvb_loc = self#location pvb_loc in\n { pvb_pat; pvb_expr; pvb_attributes; pvb_loc }\n\n method module_binding : module_binding -> module_binding =\n fun { pmb_name; pmb_expr; pmb_attributes; pmb_loc } ->\n let pmb_name = self#loc (self#option self#string) pmb_name in\n let pmb_expr = self#module_expr pmb_expr in\n let pmb_attributes = self#attributes pmb_attributes in\n let pmb_loc = self#location pmb_loc in\n { pmb_name; pmb_expr; pmb_attributes; pmb_loc }\n\n method toplevel_phrase : toplevel_phrase -> toplevel_phrase =\n fun x ->\n match x with\n | Ptop_def a ->\n let a = self#structure a in\n Ptop_def a\n | Ptop_dir a ->\n let a = self#toplevel_directive a in\n Ptop_dir a\n\n method toplevel_directive : toplevel_directive -> toplevel_directive =\n fun { pdir_name; pdir_arg; pdir_loc } ->\n let pdir_name = self#loc self#string pdir_name in\n let pdir_arg = self#option self#directive_argument pdir_arg in\n let pdir_loc = self#location pdir_loc in\n { pdir_name; pdir_arg; pdir_loc }\n\n method directive_argument : directive_argument -> directive_argument =\n fun { pdira_desc; pdira_loc } ->\n let pdira_desc = self#directive_argument_desc pdira_desc in\n let pdira_loc = self#location pdira_loc in\n { pdira_desc; pdira_loc }\n\n method directive_argument_desc\n : directive_argument_desc -> directive_argument_desc =\n fun x ->\n match x with\n | Pdir_string a ->\n let a = self#string a in\n Pdir_string a\n | Pdir_int (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n Pdir_int (a, b)\n | Pdir_ident a ->\n let a = self#longident a in\n Pdir_ident a\n | Pdir_bool a ->\n let a = self#bool a in\n Pdir_bool a\n\n method cases : cases -> cases = self#list self#case\n end\n\nclass virtual iter =\n object (self)\n method virtual bool : bool -> unit\n method virtual char : char -> unit\n method virtual int : int -> unit\n method virtual list : 'a. ('a -> unit) -> 'a list -> unit\n method virtual option : 'a. ('a -> unit) -> 'a option -> unit\n method virtual string : string -> unit\n\n method position : position -> unit =\n fun { pos_fname; pos_lnum; pos_bol; pos_cnum } ->\n self#string pos_fname;\n self#int pos_lnum;\n self#int pos_bol;\n self#int pos_cnum\n\n method location : location -> unit =\n fun { loc_start; loc_end; loc_ghost } ->\n self#position loc_start;\n self#position loc_end;\n self#bool loc_ghost\n\n method location_stack : location_stack -> unit = self#list self#location\n\n method loc : 'a. ('a -> unit) -> 'a loc -> unit =\n fun _a { txt; loc } ->\n _a txt;\n self#location loc\n\n method longident : longident -> unit =\n fun x ->\n match x with\n | Lident a -> self#string a\n | Ldot (a, b) ->\n self#longident a;\n self#string b\n | Lapply (a, b) ->\n self#longident a;\n self#longident b\n\n method longident_loc : longident_loc -> unit = self#loc self#longident\n method rec_flag : rec_flag -> unit = fun _ -> ()\n method direction_flag : direction_flag -> unit = fun _ -> ()\n method private_flag : private_flag -> unit = fun _ -> ()\n method mutable_flag : mutable_flag -> unit = fun _ -> ()\n method virtual_flag : virtual_flag -> unit = fun _ -> ()\n method override_flag : override_flag -> unit = fun _ -> ()\n method closed_flag : closed_flag -> unit = fun _ -> ()\n method label : label -> unit = self#string\n\n method arg_label : arg_label -> unit =\n fun x ->\n match x with\n | Nolabel -> ()\n | Labelled a -> self#string a\n | Optional a -> self#string a\n\n method variance : variance -> unit = fun _ -> ()\n method injectivity : injectivity -> unit = fun _ -> ()\n\n method constant : constant -> unit =\n fun x ->\n match x with\n | Pconst_integer (a, b) ->\n self#string a;\n self#option self#char b\n | Pconst_char a -> self#char a\n | Pconst_string (a, b, c) ->\n self#string a;\n self#location b;\n self#option self#string c\n | Pconst_float (a, b) ->\n self#string a;\n self#option self#char b\n\n method attribute : attribute -> unit =\n fun { attr_name; attr_payload; attr_loc } ->\n self#loc self#string attr_name;\n self#payload attr_payload;\n self#location attr_loc\n\n method extension : extension -> unit =\n fun (a, b) ->\n self#loc self#string a;\n self#payload b\n\n method attributes : attributes -> unit = self#list self#attribute\n\n method payload : payload -> unit =\n fun x ->\n match x with\n | PStr a -> self#structure a\n | PSig a -> self#signature a\n | PTyp a -> self#core_type a\n | PPat (a, b) ->\n self#pattern a;\n self#option self#expression b\n\n method core_type : core_type -> unit =\n fun { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } ->\n self#core_type_desc ptyp_desc;\n self#location ptyp_loc;\n self#location_stack ptyp_loc_stack;\n self#attributes ptyp_attributes\n\n method core_type_desc : core_type_desc -> unit =\n fun x ->\n match x with\n | Ptyp_any -> ()\n | Ptyp_var a -> self#string a\n | Ptyp_arrow (a, b, c) ->\n self#arg_label a;\n self#core_type b;\n self#core_type c\n | Ptyp_tuple a -> self#list self#core_type a\n | Ptyp_constr (a, b) ->\n self#longident_loc a;\n self#list self#core_type b\n | Ptyp_object (a, b) ->\n self#list self#object_field a;\n self#closed_flag b\n | Ptyp_class (a, b) ->\n self#longident_loc a;\n self#list self#core_type b\n | Ptyp_alias (a, b) ->\n self#core_type a;\n self#string b\n | Ptyp_variant (a, b, c) ->\n self#list self#row_field a;\n self#closed_flag b;\n self#option (self#list self#label) c\n | Ptyp_poly (a, b) ->\n self#list (self#loc self#string) a;\n self#core_type b\n | Ptyp_package a -> self#package_type a\n | Ptyp_extension a -> self#extension a\n\n method package_type : package_type -> unit =\n fun (a, b) ->\n self#longident_loc a;\n self#list\n (fun (a, b) ->\n self#longident_loc a;\n self#core_type b)\n b\n\n method row_field : row_field -> unit =\n fun { prf_desc; prf_loc; prf_attributes } ->\n self#row_field_desc prf_desc;\n self#location prf_loc;\n self#attributes prf_attributes\n\n method row_field_desc : row_field_desc -> unit =\n fun x ->\n match x with\n | Rtag (a, b, c) ->\n self#loc self#label a;\n self#bool b;\n self#list self#core_type c\n | Rinherit a -> self#core_type a\n\n method object_field : object_field -> unit =\n fun { pof_desc; pof_loc; pof_attributes } ->\n self#object_field_desc pof_desc;\n self#location pof_loc;\n self#attributes pof_attributes\n\n method object_field_desc : object_field_desc -> unit =\n fun x ->\n match x with\n | Otag (a, b) ->\n self#loc self#label a;\n self#core_type b\n | Oinherit a -> self#core_type a\n\n method pattern : pattern -> unit =\n fun { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } ->\n self#pattern_desc ppat_desc;\n self#location ppat_loc;\n self#location_stack ppat_loc_stack;\n self#attributes ppat_attributes\n\n method pattern_desc : pattern_desc -> unit =\n fun x ->\n match x with\n | Ppat_any -> ()\n | Ppat_var a -> self#loc self#string a\n | Ppat_alias (a, b) ->\n self#pattern a;\n self#loc self#string b\n | Ppat_constant a -> self#constant a\n | Ppat_interval (a, b) ->\n self#constant a;\n self#constant b\n | Ppat_tuple a -> self#list self#pattern a\n | Ppat_construct (a, b) ->\n self#longident_loc a;\n self#option self#pattern b\n | Ppat_variant (a, b) ->\n self#label a;\n self#option self#pattern b\n | Ppat_record (a, b) ->\n self#list\n (fun (a, b) ->\n self#longident_loc a;\n self#pattern b)\n a;\n self#closed_flag b\n | Ppat_array a -> self#list self#pattern a\n | Ppat_or (a, b) ->\n self#pattern a;\n self#pattern b\n | Ppat_constraint (a, b) ->\n self#pattern a;\n self#core_type b\n | Ppat_type a -> self#longident_loc a\n | Ppat_lazy a -> self#pattern a\n | Ppat_unpack a -> self#loc (self#option self#string) a\n | Ppat_exception a -> self#pattern a\n | Ppat_extension a -> self#extension a\n | Ppat_open (a, b) ->\n self#longident_loc a;\n self#pattern b\n\n method expression : expression -> unit =\n fun { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } ->\n self#expression_desc pexp_desc;\n self#location pexp_loc;\n self#location_stack pexp_loc_stack;\n self#attributes pexp_attributes\n\n method expression_desc : expression_desc -> unit =\n fun x ->\n match x with\n | Pexp_ident a -> self#longident_loc a\n | Pexp_constant a -> self#constant a\n | Pexp_let (a, b, c) ->\n self#rec_flag a;\n self#list self#value_binding b;\n self#expression c\n | Pexp_function a -> self#cases a\n | Pexp_fun (a, b, c, d) ->\n self#arg_label a;\n self#option self#expression b;\n self#pattern c;\n self#expression d\n | Pexp_apply (a, b) ->\n self#expression a;\n self#list\n (fun (a, b) ->\n self#arg_label a;\n self#expression b)\n b\n | Pexp_match (a, b) ->\n self#expression a;\n self#cases b\n | Pexp_try (a, b) ->\n self#expression a;\n self#cases b\n | Pexp_tuple a -> self#list self#expression a\n | Pexp_construct (a, b) ->\n self#longident_loc a;\n self#option self#expression b\n | Pexp_variant (a, b) ->\n self#label a;\n self#option self#expression b\n | Pexp_record (a, b) ->\n self#list\n (fun (a, b) ->\n self#longident_loc a;\n self#expression b)\n a;\n self#option self#expression b\n | Pexp_field (a, b) ->\n self#expression a;\n self#longident_loc b\n | Pexp_setfield (a, b, c) ->\n self#expression a;\n self#longident_loc b;\n self#expression c\n | Pexp_array a -> self#list self#expression a\n | Pexp_ifthenelse (a, b, c) ->\n self#expression a;\n self#expression b;\n self#option self#expression c\n | Pexp_sequence (a, b) ->\n self#expression a;\n self#expression b\n | Pexp_while (a, b) ->\n self#expression a;\n self#expression b\n | Pexp_for (a, b, c, d, e) ->\n self#pattern a;\n self#expression b;\n self#expression c;\n self#direction_flag d;\n self#expression e\n | Pexp_constraint (a, b) ->\n self#expression a;\n self#core_type b\n | Pexp_coerce (a, b, c) ->\n self#expression a;\n self#option self#core_type b;\n self#core_type c\n | Pexp_send (a, b) ->\n self#expression a;\n self#loc self#label b\n | Pexp_new a -> self#longident_loc a\n | Pexp_setinstvar (a, b) ->\n self#loc self#label a;\n self#expression b\n | Pexp_override a ->\n self#list\n (fun (a, b) ->\n self#loc self#label a;\n self#expression b)\n a\n | Pexp_letmodule (a, b, c) ->\n self#loc (self#option self#string) a;\n self#module_expr b;\n self#expression c\n | Pexp_letexception (a, b) ->\n self#extension_constructor a;\n self#expression b\n | Pexp_assert a -> self#expression a\n | Pexp_lazy a -> self#expression a\n | Pexp_poly (a, b) ->\n self#expression a;\n self#option self#core_type b\n | Pexp_object a -> self#class_structure a\n | Pexp_newtype (a, b) ->\n self#loc self#string a;\n self#expression b\n | Pexp_pack a -> self#module_expr a\n | Pexp_open (a, b) ->\n self#open_declaration a;\n self#expression b\n | Pexp_letop a -> self#letop a\n | Pexp_extension a -> self#extension a\n | Pexp_unreachable -> ()\n\n method case : case -> unit =\n fun { pc_lhs; pc_guard; pc_rhs } ->\n self#pattern pc_lhs;\n self#option self#expression pc_guard;\n self#expression pc_rhs\n\n method letop : letop -> unit =\n fun { let_; ands; body } ->\n self#binding_op let_;\n self#list self#binding_op ands;\n self#expression body\n\n method binding_op : binding_op -> unit =\n fun { pbop_op; pbop_pat; pbop_exp; pbop_loc } ->\n self#loc self#string pbop_op;\n self#pattern pbop_pat;\n self#expression pbop_exp;\n self#location pbop_loc\n\n method value_description : value_description -> unit =\n fun { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } ->\n self#loc self#string pval_name;\n self#core_type pval_type;\n self#list self#string pval_prim;\n self#attributes pval_attributes;\n self#location pval_loc\n\n method type_declaration : type_declaration -> unit =\n fun {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } ->\n self#loc self#string ptype_name;\n self#list\n (fun (a, b) ->\n self#core_type a;\n (fun (a, b) ->\n self#variance a;\n self#injectivity b)\n b)\n ptype_params;\n self#list\n (fun (a, b, c) ->\n self#core_type a;\n self#core_type b;\n self#location c)\n ptype_cstrs;\n self#type_kind ptype_kind;\n self#private_flag ptype_private;\n self#option self#core_type ptype_manifest;\n self#attributes ptype_attributes;\n self#location ptype_loc\n\n method type_kind : type_kind -> unit =\n fun x ->\n match x with\n | Ptype_abstract -> ()\n | Ptype_variant a -> self#list self#constructor_declaration a\n | Ptype_record a -> self#list self#label_declaration a\n | Ptype_open -> ()\n\n method label_declaration : label_declaration -> unit =\n fun { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } ->\n self#loc self#string pld_name;\n self#mutable_flag pld_mutable;\n self#core_type pld_type;\n self#location pld_loc;\n self#attributes pld_attributes\n\n method constructor_declaration : constructor_declaration -> unit =\n fun { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } ->\n self#loc self#string pcd_name;\n self#constructor_arguments pcd_args;\n self#option self#core_type pcd_res;\n self#location pcd_loc;\n self#attributes pcd_attributes\n\n method constructor_arguments : constructor_arguments -> unit =\n fun x ->\n match x with\n | Pcstr_tuple a -> self#list self#core_type a\n | Pcstr_record a -> self#list self#label_declaration a\n\n method type_extension : type_extension -> unit =\n fun {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } ->\n self#longident_loc ptyext_path;\n self#list\n (fun (a, b) ->\n self#core_type a;\n (fun (a, b) ->\n self#variance a;\n self#injectivity b)\n b)\n ptyext_params;\n self#list self#extension_constructor ptyext_constructors;\n self#private_flag ptyext_private;\n self#location ptyext_loc;\n self#attributes ptyext_attributes\n\n method extension_constructor : extension_constructor -> unit =\n fun { pext_name; pext_kind; pext_loc; pext_attributes } ->\n self#loc self#string pext_name;\n self#extension_constructor_kind pext_kind;\n self#location pext_loc;\n self#attributes pext_attributes\n\n method type_exception : type_exception -> unit =\n fun { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } ->\n self#extension_constructor ptyexn_constructor;\n self#location ptyexn_loc;\n self#attributes ptyexn_attributes\n\n method extension_constructor_kind : extension_constructor_kind -> unit =\n fun x ->\n match x with\n | Pext_decl (a, b) ->\n self#constructor_arguments a;\n self#option self#core_type b\n | Pext_rebind a -> self#longident_loc a\n\n method class_type : class_type -> unit =\n fun { pcty_desc; pcty_loc; pcty_attributes } ->\n self#class_type_desc pcty_desc;\n self#location pcty_loc;\n self#attributes pcty_attributes\n\n method class_type_desc : class_type_desc -> unit =\n fun x ->\n match x with\n | Pcty_constr (a, b) ->\n self#longident_loc a;\n self#list self#core_type b\n | Pcty_signature a -> self#class_signature a\n | Pcty_arrow (a, b, c) ->\n self#arg_label a;\n self#core_type b;\n self#class_type c\n | Pcty_extension a -> self#extension a\n | Pcty_open (a, b) ->\n self#open_description a;\n self#class_type b\n\n method class_signature : class_signature -> unit =\n fun { pcsig_self; pcsig_fields } ->\n self#core_type pcsig_self;\n self#list self#class_type_field pcsig_fields\n\n method class_type_field : class_type_field -> unit =\n fun { pctf_desc; pctf_loc; pctf_attributes } ->\n self#class_type_field_desc pctf_desc;\n self#location pctf_loc;\n self#attributes pctf_attributes\n\n method class_type_field_desc : class_type_field_desc -> unit =\n fun x ->\n match x with\n | Pctf_inherit a -> self#class_type a\n | Pctf_val a ->\n (fun (a, b, c, d) ->\n self#loc self#label a;\n self#mutable_flag b;\n self#virtual_flag c;\n self#core_type d)\n a\n | Pctf_method a ->\n (fun (a, b, c, d) ->\n self#loc self#label a;\n self#private_flag b;\n self#virtual_flag c;\n self#core_type d)\n a\n | Pctf_constraint a ->\n (fun (a, b) ->\n self#core_type a;\n self#core_type b)\n a\n | Pctf_attribute a -> self#attribute a\n | Pctf_extension a -> self#extension a\n\n method class_infos : 'a. ('a -> unit) -> 'a class_infos -> unit =\n fun _a\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes } ->\n self#virtual_flag pci_virt;\n self#list\n (fun (a, b) ->\n self#core_type a;\n (fun (a, b) ->\n self#variance a;\n self#injectivity b)\n b)\n pci_params;\n self#loc self#string pci_name;\n _a pci_expr;\n self#location pci_loc;\n self#attributes pci_attributes\n\n method class_description : class_description -> unit =\n self#class_infos self#class_type\n\n method class_type_declaration : class_type_declaration -> unit =\n self#class_infos self#class_type\n\n method class_expr : class_expr -> unit =\n fun { pcl_desc; pcl_loc; pcl_attributes } ->\n self#class_expr_desc pcl_desc;\n self#location pcl_loc;\n self#attributes pcl_attributes\n\n method class_expr_desc : class_expr_desc -> unit =\n fun x ->\n match x with\n | Pcl_constr (a, b) ->\n self#longident_loc a;\n self#list self#core_type b\n | Pcl_structure a -> self#class_structure a\n | Pcl_fun (a, b, c, d) ->\n self#arg_label a;\n self#option self#expression b;\n self#pattern c;\n self#class_expr d\n | Pcl_apply (a, b) ->\n self#class_expr a;\n self#list\n (fun (a, b) ->\n self#arg_label a;\n self#expression b)\n b\n | Pcl_let (a, b, c) ->\n self#rec_flag a;\n self#list self#value_binding b;\n self#class_expr c\n | Pcl_constraint (a, b) ->\n self#class_expr a;\n self#class_type b\n | Pcl_extension a -> self#extension a\n | Pcl_open (a, b) ->\n self#open_description a;\n self#class_expr b\n\n method class_structure : class_structure -> unit =\n fun { pcstr_self; pcstr_fields } ->\n self#pattern pcstr_self;\n self#list self#class_field pcstr_fields\n\n method class_field : class_field -> unit =\n fun { pcf_desc; pcf_loc; pcf_attributes } ->\n self#class_field_desc pcf_desc;\n self#location pcf_loc;\n self#attributes pcf_attributes\n\n method class_field_desc : class_field_desc -> unit =\n fun x ->\n match x with\n | Pcf_inherit (a, b, c) ->\n self#override_flag a;\n self#class_expr b;\n self#option (self#loc self#string) c\n | Pcf_val a ->\n (fun (a, b, c) ->\n self#loc self#label a;\n self#mutable_flag b;\n self#class_field_kind c)\n a\n | Pcf_method a ->\n (fun (a, b, c) ->\n self#loc self#label a;\n self#private_flag b;\n self#class_field_kind c)\n a\n | Pcf_constraint a ->\n (fun (a, b) ->\n self#core_type a;\n self#core_type b)\n a\n | Pcf_initializer a -> self#expression a\n | Pcf_attribute a -> self#attribute a\n | Pcf_extension a -> self#extension a\n\n method class_field_kind : class_field_kind -> unit =\n fun x ->\n match x with\n | Cfk_virtual a -> self#core_type a\n | Cfk_concrete (a, b) ->\n self#override_flag a;\n self#expression b\n\n method class_declaration : class_declaration -> unit =\n self#class_infos self#class_expr\n\n method module_type : module_type -> unit =\n fun { pmty_desc; pmty_loc; pmty_attributes } ->\n self#module_type_desc pmty_desc;\n self#location pmty_loc;\n self#attributes pmty_attributes\n\n method module_type_desc : module_type_desc -> unit =\n fun x ->\n match x with\n | Pmty_ident a -> self#longident_loc a\n | Pmty_signature a -> self#signature a\n | Pmty_functor (a, b) ->\n self#functor_parameter a;\n self#module_type b\n | Pmty_with (a, b) ->\n self#module_type a;\n self#list self#with_constraint b\n | Pmty_typeof a -> self#module_expr a\n | Pmty_extension a -> self#extension a\n | Pmty_alias a -> self#longident_loc a\n\n method functor_parameter : functor_parameter -> unit =\n fun x ->\n match x with\n | Unit -> ()\n | Named (a, b) ->\n self#loc (self#option self#string) a;\n self#module_type b\n\n method signature : signature -> unit = self#list self#signature_item\n\n method signature_item : signature_item -> unit =\n fun { psig_desc; psig_loc } ->\n self#signature_item_desc psig_desc;\n self#location psig_loc\n\n method signature_item_desc : signature_item_desc -> unit =\n fun x ->\n match x with\n | Psig_value a -> self#value_description a\n | Psig_type (a, b) ->\n self#rec_flag a;\n self#list self#type_declaration b\n | Psig_typesubst a -> self#list self#type_declaration a\n | Psig_typext a -> self#type_extension a\n | Psig_exception a -> self#type_exception a\n | Psig_module a -> self#module_declaration a\n | Psig_modsubst a -> self#module_substitution a\n | Psig_recmodule a -> self#list self#module_declaration a\n | Psig_modtype a -> self#module_type_declaration a\n | Psig_open a -> self#open_description a\n | Psig_include a -> self#include_description a\n | Psig_class a -> self#list self#class_description a\n | Psig_class_type a -> self#list self#class_type_declaration a\n | Psig_attribute a -> self#attribute a\n | Psig_extension (a, b) ->\n self#extension a;\n self#attributes b\n\n method module_declaration : module_declaration -> unit =\n fun { pmd_name; pmd_type; pmd_attributes; pmd_loc } ->\n self#loc (self#option self#string) pmd_name;\n self#module_type pmd_type;\n self#attributes pmd_attributes;\n self#location pmd_loc\n\n method module_substitution : module_substitution -> unit =\n fun { pms_name; pms_manifest; pms_attributes; pms_loc } ->\n self#loc self#string pms_name;\n self#longident_loc pms_manifest;\n self#attributes pms_attributes;\n self#location pms_loc\n\n method module_type_declaration : module_type_declaration -> unit =\n fun { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } ->\n self#loc self#string pmtd_name;\n self#option self#module_type pmtd_type;\n self#attributes pmtd_attributes;\n self#location pmtd_loc\n\n method open_infos : 'a. ('a -> unit) -> 'a open_infos -> unit =\n fun _a { popen_expr; popen_override; popen_loc; popen_attributes } ->\n _a popen_expr;\n self#override_flag popen_override;\n self#location popen_loc;\n self#attributes popen_attributes\n\n method open_description : open_description -> unit =\n self#open_infos self#longident_loc\n\n method open_declaration : open_declaration -> unit =\n self#open_infos self#module_expr\n\n method include_infos : 'a. ('a -> unit) -> 'a include_infos -> unit =\n fun _a { pincl_mod; pincl_loc; pincl_attributes } ->\n _a pincl_mod;\n self#location pincl_loc;\n self#attributes pincl_attributes\n\n method include_description : include_description -> unit =\n self#include_infos self#module_type\n\n method include_declaration : include_declaration -> unit =\n self#include_infos self#module_expr\n\n method with_constraint : with_constraint -> unit =\n fun x ->\n match x with\n | Pwith_type (a, b) ->\n self#longident_loc a;\n self#type_declaration b\n | Pwith_module (a, b) ->\n self#longident_loc a;\n self#longident_loc b\n | Pwith_typesubst (a, b) ->\n self#longident_loc a;\n self#type_declaration b\n | Pwith_modsubst (a, b) ->\n self#longident_loc a;\n self#longident_loc b\n\n method module_expr : module_expr -> unit =\n fun { pmod_desc; pmod_loc; pmod_attributes } ->\n self#module_expr_desc pmod_desc;\n self#location pmod_loc;\n self#attributes pmod_attributes\n\n method module_expr_desc : module_expr_desc -> unit =\n fun x ->\n match x with\n | Pmod_ident a -> self#longident_loc a\n | Pmod_structure a -> self#structure a\n | Pmod_functor (a, b) ->\n self#functor_parameter a;\n self#module_expr b\n | Pmod_apply (a, b) ->\n self#module_expr a;\n self#module_expr b\n | Pmod_constraint (a, b) ->\n self#module_expr a;\n self#module_type b\n | Pmod_unpack a -> self#expression a\n | Pmod_extension a -> self#extension a\n\n method structure : structure -> unit = self#list self#structure_item\n\n method structure_item : structure_item -> unit =\n fun { pstr_desc; pstr_loc } ->\n self#structure_item_desc pstr_desc;\n self#location pstr_loc\n\n method structure_item_desc : structure_item_desc -> unit =\n fun x ->\n match x with\n | Pstr_eval (a, b) ->\n self#expression a;\n self#attributes b\n | Pstr_value (a, b) ->\n self#rec_flag a;\n self#list self#value_binding b\n | Pstr_primitive a -> self#value_description a\n | Pstr_type (a, b) ->\n self#rec_flag a;\n self#list self#type_declaration b\n | Pstr_typext a -> self#type_extension a\n | Pstr_exception a -> self#type_exception a\n | Pstr_module a -> self#module_binding a\n | Pstr_recmodule a -> self#list self#module_binding a\n | Pstr_modtype a -> self#module_type_declaration a\n | Pstr_open a -> self#open_declaration a\n | Pstr_class a -> self#list self#class_declaration a\n | Pstr_class_type a -> self#list self#class_type_declaration a\n | Pstr_include a -> self#include_declaration a\n | Pstr_attribute a -> self#attribute a\n | Pstr_extension (a, b) ->\n self#extension a;\n self#attributes b\n\n method value_binding : value_binding -> unit =\n fun { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } ->\n self#pattern pvb_pat;\n self#expression pvb_expr;\n self#attributes pvb_attributes;\n self#location pvb_loc\n\n method module_binding : module_binding -> unit =\n fun { pmb_name; pmb_expr; pmb_attributes; pmb_loc } ->\n self#loc (self#option self#string) pmb_name;\n self#module_expr pmb_expr;\n self#attributes pmb_attributes;\n self#location pmb_loc\n\n method toplevel_phrase : toplevel_phrase -> unit =\n fun x ->\n match x with\n | Ptop_def a -> self#structure a\n | Ptop_dir a -> self#toplevel_directive a\n\n method toplevel_directive : toplevel_directive -> unit =\n fun { pdir_name; pdir_arg; pdir_loc } ->\n self#loc self#string pdir_name;\n self#option self#directive_argument pdir_arg;\n self#location pdir_loc\n\n method directive_argument : directive_argument -> unit =\n fun { pdira_desc; pdira_loc } ->\n self#directive_argument_desc pdira_desc;\n self#location pdira_loc\n\n method directive_argument_desc : directive_argument_desc -> unit =\n fun x ->\n match x with\n | Pdir_string a -> self#string a\n | Pdir_int (a, b) ->\n self#string a;\n self#option self#char b\n | Pdir_ident a -> self#longident a\n | Pdir_bool a -> self#bool a\n\n method cases : cases -> unit = self#list self#case\n end\n\nclass virtual ['acc] fold =\n object (self)\n method virtual bool : bool -> 'acc -> 'acc\n method virtual char : char -> 'acc -> 'acc\n method virtual int : int -> 'acc -> 'acc\n method virtual list : 'a. ('a -> 'acc -> 'acc) -> 'a list -> 'acc -> 'acc\n\n method virtual option\n : 'a. ('a -> 'acc -> 'acc) -> 'a option -> 'acc -> 'acc\n\n method virtual string : string -> 'acc -> 'acc\n\n method position : position -> 'acc -> 'acc =\n fun { pos_fname; pos_lnum; pos_bol; pos_cnum } acc ->\n let acc = self#string pos_fname acc in\n let acc = self#int pos_lnum acc in\n let acc = self#int pos_bol acc in\n let acc = self#int pos_cnum acc in\n acc\n\n method location : location -> 'acc -> 'acc =\n fun { loc_start; loc_end; loc_ghost } acc ->\n let acc = self#position loc_start acc in\n let acc = self#position loc_end acc in\n let acc = self#bool loc_ghost acc in\n acc\n\n method location_stack : location_stack -> 'acc -> 'acc =\n self#list self#location\n\n method loc : 'a. ('a -> 'acc -> 'acc) -> 'a loc -> 'acc -> 'acc =\n fun _a { txt; loc } acc ->\n let acc = _a txt acc in\n let acc = self#location loc acc in\n acc\n\n method longident : longident -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Lident a -> self#string a acc\n | Ldot (a, b) ->\n let acc = self#longident a acc in\n let acc = self#string b acc in\n acc\n | Lapply (a, b) ->\n let acc = self#longident a acc in\n let acc = self#longident b acc in\n acc\n\n method longident_loc : longident_loc -> 'acc -> 'acc =\n self#loc self#longident\n\n method rec_flag : rec_flag -> 'acc -> 'acc = fun _ acc -> acc\n method direction_flag : direction_flag -> 'acc -> 'acc = fun _ acc -> acc\n method private_flag : private_flag -> 'acc -> 'acc = fun _ acc -> acc\n method mutable_flag : mutable_flag -> 'acc -> 'acc = fun _ acc -> acc\n method virtual_flag : virtual_flag -> 'acc -> 'acc = fun _ acc -> acc\n method override_flag : override_flag -> 'acc -> 'acc = fun _ acc -> acc\n method closed_flag : closed_flag -> 'acc -> 'acc = fun _ acc -> acc\n method label : label -> 'acc -> 'acc = self#string\n\n method arg_label : arg_label -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Nolabel -> acc\n | Labelled a -> self#string a acc\n | Optional a -> self#string a acc\n\n method variance : variance -> 'acc -> 'acc = fun _ acc -> acc\n method injectivity : injectivity -> 'acc -> 'acc = fun _ acc -> acc\n\n method constant : constant -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pconst_integer (a, b) ->\n let acc = self#string a acc in\n let acc = self#option self#char b acc in\n acc\n | Pconst_char a -> self#char a acc\n | Pconst_string (a, b, c) ->\n let acc = self#string a acc in\n let acc = self#location b acc in\n let acc = self#option self#string c acc in\n acc\n | Pconst_float (a, b) ->\n let acc = self#string a acc in\n let acc = self#option self#char b acc in\n acc\n\n method attribute : attribute -> 'acc -> 'acc =\n fun { attr_name; attr_payload; attr_loc } acc ->\n let acc = self#loc self#string attr_name acc in\n let acc = self#payload attr_payload acc in\n let acc = self#location attr_loc acc in\n acc\n\n method extension : extension -> 'acc -> 'acc =\n fun (a, b) acc ->\n let acc = self#loc self#string a acc in\n let acc = self#payload b acc in\n acc\n\n method attributes : attributes -> 'acc -> 'acc = self#list self#attribute\n\n method payload : payload -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | PStr a -> self#structure a acc\n | PSig a -> self#signature a acc\n | PTyp a -> self#core_type a acc\n | PPat (a, b) ->\n let acc = self#pattern a acc in\n let acc = self#option self#expression b acc in\n acc\n\n method core_type : core_type -> 'acc -> 'acc =\n fun { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } acc ->\n let acc = self#core_type_desc ptyp_desc acc in\n let acc = self#location ptyp_loc acc in\n let acc = self#location_stack ptyp_loc_stack acc in\n let acc = self#attributes ptyp_attributes acc in\n acc\n\n method core_type_desc : core_type_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Ptyp_any -> acc\n | Ptyp_var a -> self#string a acc\n | Ptyp_arrow (a, b, c) ->\n let acc = self#arg_label a acc in\n let acc = self#core_type b acc in\n let acc = self#core_type c acc in\n acc\n | Ptyp_tuple a -> self#list self#core_type a acc\n | Ptyp_constr (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#list self#core_type b acc in\n acc\n | Ptyp_object (a, b) ->\n let acc = self#list self#object_field a acc in\n let acc = self#closed_flag b acc in\n acc\n | Ptyp_class (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#list self#core_type b acc in\n acc\n | Ptyp_alias (a, b) ->\n let acc = self#core_type a acc in\n let acc = self#string b acc in\n acc\n | Ptyp_variant (a, b, c) ->\n let acc = self#list self#row_field a acc in\n let acc = self#closed_flag b acc in\n let acc = self#option (self#list self#label) c acc in\n acc\n | Ptyp_poly (a, b) ->\n let acc = self#list (self#loc self#string) a acc in\n let acc = self#core_type b acc in\n acc\n | Ptyp_package a -> self#package_type a acc\n | Ptyp_extension a -> self#extension a acc\n\n method package_type : package_type -> 'acc -> 'acc =\n fun (a, b) acc ->\n let acc = self#longident_loc a acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#longident_loc a acc in\n let acc = self#core_type b acc in\n acc)\n b acc\n in\n acc\n\n method row_field : row_field -> 'acc -> 'acc =\n fun { prf_desc; prf_loc; prf_attributes } acc ->\n let acc = self#row_field_desc prf_desc acc in\n let acc = self#location prf_loc acc in\n let acc = self#attributes prf_attributes acc in\n acc\n\n method row_field_desc : row_field_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Rtag (a, b, c) ->\n let acc = self#loc self#label a acc in\n let acc = self#bool b acc in\n let acc = self#list self#core_type c acc in\n acc\n | Rinherit a -> self#core_type a acc\n\n method object_field : object_field -> 'acc -> 'acc =\n fun { pof_desc; pof_loc; pof_attributes } acc ->\n let acc = self#object_field_desc pof_desc acc in\n let acc = self#location pof_loc acc in\n let acc = self#attributes pof_attributes acc in\n acc\n\n method object_field_desc : object_field_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Otag (a, b) ->\n let acc = self#loc self#label a acc in\n let acc = self#core_type b acc in\n acc\n | Oinherit a -> self#core_type a acc\n\n method pattern : pattern -> 'acc -> 'acc =\n fun { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } acc ->\n let acc = self#pattern_desc ppat_desc acc in\n let acc = self#location ppat_loc acc in\n let acc = self#location_stack ppat_loc_stack acc in\n let acc = self#attributes ppat_attributes acc in\n acc\n\n method pattern_desc : pattern_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Ppat_any -> acc\n | Ppat_var a -> self#loc self#string a acc\n | Ppat_alias (a, b) ->\n let acc = self#pattern a acc in\n let acc = self#loc self#string b acc in\n acc\n | Ppat_constant a -> self#constant a acc\n | Ppat_interval (a, b) ->\n let acc = self#constant a acc in\n let acc = self#constant b acc in\n acc\n | Ppat_tuple a -> self#list self#pattern a acc\n | Ppat_construct (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#option self#pattern b acc in\n acc\n | Ppat_variant (a, b) ->\n let acc = self#label a acc in\n let acc = self#option self#pattern b acc in\n acc\n | Ppat_record (a, b) ->\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#longident_loc a acc in\n let acc = self#pattern b acc in\n acc)\n a acc\n in\n let acc = self#closed_flag b acc in\n acc\n | Ppat_array a -> self#list self#pattern a acc\n | Ppat_or (a, b) ->\n let acc = self#pattern a acc in\n let acc = self#pattern b acc in\n acc\n | Ppat_constraint (a, b) ->\n let acc = self#pattern a acc in\n let acc = self#core_type b acc in\n acc\n | Ppat_type a -> self#longident_loc a acc\n | Ppat_lazy a -> self#pattern a acc\n | Ppat_unpack a -> self#loc (self#option self#string) a acc\n | Ppat_exception a -> self#pattern a acc\n | Ppat_extension a -> self#extension a acc\n | Ppat_open (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#pattern b acc in\n acc\n\n method expression : expression -> 'acc -> 'acc =\n fun { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } acc ->\n let acc = self#expression_desc pexp_desc acc in\n let acc = self#location pexp_loc acc in\n let acc = self#location_stack pexp_loc_stack acc in\n let acc = self#attributes pexp_attributes acc in\n acc\n\n method expression_desc : expression_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pexp_ident a -> self#longident_loc a acc\n | Pexp_constant a -> self#constant a acc\n | Pexp_let (a, b, c) ->\n let acc = self#rec_flag a acc in\n let acc = self#list self#value_binding b acc in\n let acc = self#expression c acc in\n acc\n | Pexp_function a -> self#cases a acc\n | Pexp_fun (a, b, c, d) ->\n let acc = self#arg_label a acc in\n let acc = self#option self#expression b acc in\n let acc = self#pattern c acc in\n let acc = self#expression d acc in\n acc\n | Pexp_apply (a, b) ->\n let acc = self#expression a acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#arg_label a acc in\n let acc = self#expression b acc in\n acc)\n b acc\n in\n acc\n | Pexp_match (a, b) ->\n let acc = self#expression a acc in\n let acc = self#cases b acc in\n acc\n | Pexp_try (a, b) ->\n let acc = self#expression a acc in\n let acc = self#cases b acc in\n acc\n | Pexp_tuple a -> self#list self#expression a acc\n | Pexp_construct (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#option self#expression b acc in\n acc\n | Pexp_variant (a, b) ->\n let acc = self#label a acc in\n let acc = self#option self#expression b acc in\n acc\n | Pexp_record (a, b) ->\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#longident_loc a acc in\n let acc = self#expression b acc in\n acc)\n a acc\n in\n let acc = self#option self#expression b acc in\n acc\n | Pexp_field (a, b) ->\n let acc = self#expression a acc in\n let acc = self#longident_loc b acc in\n acc\n | Pexp_setfield (a, b, c) ->\n let acc = self#expression a acc in\n let acc = self#longident_loc b acc in\n let acc = self#expression c acc in\n acc\n | Pexp_array a -> self#list self#expression a acc\n | Pexp_ifthenelse (a, b, c) ->\n let acc = self#expression a acc in\n let acc = self#expression b acc in\n let acc = self#option self#expression c acc in\n acc\n | Pexp_sequence (a, b) ->\n let acc = self#expression a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_while (a, b) ->\n let acc = self#expression a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_for (a, b, c, d, e) ->\n let acc = self#pattern a acc in\n let acc = self#expression b acc in\n let acc = self#expression c acc in\n let acc = self#direction_flag d acc in\n let acc = self#expression e acc in\n acc\n | Pexp_constraint (a, b) ->\n let acc = self#expression a acc in\n let acc = self#core_type b acc in\n acc\n | Pexp_coerce (a, b, c) ->\n let acc = self#expression a acc in\n let acc = self#option self#core_type b acc in\n let acc = self#core_type c acc in\n acc\n | Pexp_send (a, b) ->\n let acc = self#expression a acc in\n let acc = self#loc self#label b acc in\n acc\n | Pexp_new a -> self#longident_loc a acc\n | Pexp_setinstvar (a, b) ->\n let acc = self#loc self#label a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_override a ->\n self#list\n (fun (a, b) acc ->\n let acc = self#loc self#label a acc in\n let acc = self#expression b acc in\n acc)\n a acc\n | Pexp_letmodule (a, b, c) ->\n let acc = self#loc (self#option self#string) a acc in\n let acc = self#module_expr b acc in\n let acc = self#expression c acc in\n acc\n | Pexp_letexception (a, b) ->\n let acc = self#extension_constructor a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_assert a -> self#expression a acc\n | Pexp_lazy a -> self#expression a acc\n | Pexp_poly (a, b) ->\n let acc = self#expression a acc in\n let acc = self#option self#core_type b acc in\n acc\n | Pexp_object a -> self#class_structure a acc\n | Pexp_newtype (a, b) ->\n let acc = self#loc self#string a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_pack a -> self#module_expr a acc\n | Pexp_open (a, b) ->\n let acc = self#open_declaration a acc in\n let acc = self#expression b acc in\n acc\n | Pexp_letop a -> self#letop a acc\n | Pexp_extension a -> self#extension a acc\n | Pexp_unreachable -> acc\n\n method case : case -> 'acc -> 'acc =\n fun { pc_lhs; pc_guard; pc_rhs } acc ->\n let acc = self#pattern pc_lhs acc in\n let acc = self#option self#expression pc_guard acc in\n let acc = self#expression pc_rhs acc in\n acc\n\n method letop : letop -> 'acc -> 'acc =\n fun { let_; ands; body } acc ->\n let acc = self#binding_op let_ acc in\n let acc = self#list self#binding_op ands acc in\n let acc = self#expression body acc in\n acc\n\n method binding_op : binding_op -> 'acc -> 'acc =\n fun { pbop_op; pbop_pat; pbop_exp; pbop_loc } acc ->\n let acc = self#loc self#string pbop_op acc in\n let acc = self#pattern pbop_pat acc in\n let acc = self#expression pbop_exp acc in\n let acc = self#location pbop_loc acc in\n acc\n\n method value_description : value_description -> 'acc -> 'acc =\n fun { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } acc ->\n let acc = self#loc self#string pval_name acc in\n let acc = self#core_type pval_type acc in\n let acc = self#list self#string pval_prim acc in\n let acc = self#attributes pval_attributes acc in\n let acc = self#location pval_loc acc in\n acc\n\n method type_declaration : type_declaration -> 'acc -> 'acc =\n fun {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } acc ->\n let acc = self#loc self#string ptype_name acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#core_type a acc in\n let acc =\n (fun (a, b) acc ->\n let acc = self#variance a acc in\n let acc = self#injectivity b acc in\n acc)\n b acc\n in\n acc)\n ptype_params acc\n in\n let acc =\n self#list\n (fun (a, b, c) acc ->\n let acc = self#core_type a acc in\n let acc = self#core_type b acc in\n let acc = self#location c acc in\n acc)\n ptype_cstrs acc\n in\n let acc = self#type_kind ptype_kind acc in\n let acc = self#private_flag ptype_private acc in\n let acc = self#option self#core_type ptype_manifest acc in\n let acc = self#attributes ptype_attributes acc in\n let acc = self#location ptype_loc acc in\n acc\n\n method type_kind : type_kind -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Ptype_abstract -> acc\n | Ptype_variant a -> self#list self#constructor_declaration a acc\n | Ptype_record a -> self#list self#label_declaration a acc\n | Ptype_open -> acc\n\n method label_declaration : label_declaration -> 'acc -> 'acc =\n fun { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } acc ->\n let acc = self#loc self#string pld_name acc in\n let acc = self#mutable_flag pld_mutable acc in\n let acc = self#core_type pld_type acc in\n let acc = self#location pld_loc acc in\n let acc = self#attributes pld_attributes acc in\n acc\n\n method constructor_declaration : constructor_declaration -> 'acc -> 'acc =\n fun { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } acc ->\n let acc = self#loc self#string pcd_name acc in\n let acc = self#constructor_arguments pcd_args acc in\n let acc = self#option self#core_type pcd_res acc in\n let acc = self#location pcd_loc acc in\n let acc = self#attributes pcd_attributes acc in\n acc\n\n method constructor_arguments : constructor_arguments -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pcstr_tuple a -> self#list self#core_type a acc\n | Pcstr_record a -> self#list self#label_declaration a acc\n\n method type_extension : type_extension -> 'acc -> 'acc =\n fun {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } acc ->\n let acc = self#longident_loc ptyext_path acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#core_type a acc in\n let acc =\n (fun (a, b) acc ->\n let acc = self#variance a acc in\n let acc = self#injectivity b acc in\n acc)\n b acc\n in\n acc)\n ptyext_params acc\n in\n let acc =\n self#list self#extension_constructor ptyext_constructors acc\n in\n let acc = self#private_flag ptyext_private acc in\n let acc = self#location ptyext_loc acc in\n let acc = self#attributes ptyext_attributes acc in\n acc\n\n method extension_constructor : extension_constructor -> 'acc -> 'acc =\n fun { pext_name; pext_kind; pext_loc; pext_attributes } acc ->\n let acc = self#loc self#string pext_name acc in\n let acc = self#extension_constructor_kind pext_kind acc in\n let acc = self#location pext_loc acc in\n let acc = self#attributes pext_attributes acc in\n acc\n\n method type_exception : type_exception -> 'acc -> 'acc =\n fun { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } acc ->\n let acc = self#extension_constructor ptyexn_constructor acc in\n let acc = self#location ptyexn_loc acc in\n let acc = self#attributes ptyexn_attributes acc in\n acc\n\n method extension_constructor_kind\n : extension_constructor_kind -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pext_decl (a, b) ->\n let acc = self#constructor_arguments a acc in\n let acc = self#option self#core_type b acc in\n acc\n | Pext_rebind a -> self#longident_loc a acc\n\n method class_type : class_type -> 'acc -> 'acc =\n fun { pcty_desc; pcty_loc; pcty_attributes } acc ->\n let acc = self#class_type_desc pcty_desc acc in\n let acc = self#location pcty_loc acc in\n let acc = self#attributes pcty_attributes acc in\n acc\n\n method class_type_desc : class_type_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pcty_constr (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#list self#core_type b acc in\n acc\n | Pcty_signature a -> self#class_signature a acc\n | Pcty_arrow (a, b, c) ->\n let acc = self#arg_label a acc in\n let acc = self#core_type b acc in\n let acc = self#class_type c acc in\n acc\n | Pcty_extension a -> self#extension a acc\n | Pcty_open (a, b) ->\n let acc = self#open_description a acc in\n let acc = self#class_type b acc in\n acc\n\n method class_signature : class_signature -> 'acc -> 'acc =\n fun { pcsig_self; pcsig_fields } acc ->\n let acc = self#core_type pcsig_self acc in\n let acc = self#list self#class_type_field pcsig_fields acc in\n acc\n\n method class_type_field : class_type_field -> 'acc -> 'acc =\n fun { pctf_desc; pctf_loc; pctf_attributes } acc ->\n let acc = self#class_type_field_desc pctf_desc acc in\n let acc = self#location pctf_loc acc in\n let acc = self#attributes pctf_attributes acc in\n acc\n\n method class_type_field_desc : class_type_field_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pctf_inherit a -> self#class_type a acc\n | Pctf_val a ->\n (fun (a, b, c, d) acc ->\n let acc = self#loc self#label a acc in\n let acc = self#mutable_flag b acc in\n let acc = self#virtual_flag c acc in\n let acc = self#core_type d acc in\n acc)\n a acc\n | Pctf_method a ->\n (fun (a, b, c, d) acc ->\n let acc = self#loc self#label a acc in\n let acc = self#private_flag b acc in\n let acc = self#virtual_flag c acc in\n let acc = self#core_type d acc in\n acc)\n a acc\n | Pctf_constraint a ->\n (fun (a, b) acc ->\n let acc = self#core_type a acc in\n let acc = self#core_type b acc in\n acc)\n a acc\n | Pctf_attribute a -> self#attribute a acc\n | Pctf_extension a -> self#extension a acc\n\n method class_infos\n : 'a. ('a -> 'acc -> 'acc) -> 'a class_infos -> 'acc -> 'acc =\n fun _a\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes }\n acc ->\n let acc = self#virtual_flag pci_virt acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#core_type a acc in\n let acc =\n (fun (a, b) acc ->\n let acc = self#variance a acc in\n let acc = self#injectivity b acc in\n acc)\n b acc\n in\n acc)\n pci_params acc\n in\n let acc = self#loc self#string pci_name acc in\n let acc = _a pci_expr acc in\n let acc = self#location pci_loc acc in\n let acc = self#attributes pci_attributes acc in\n acc\n\n method class_description : class_description -> 'acc -> 'acc =\n self#class_infos self#class_type\n\n method class_type_declaration : class_type_declaration -> 'acc -> 'acc =\n self#class_infos self#class_type\n\n method class_expr : class_expr -> 'acc -> 'acc =\n fun { pcl_desc; pcl_loc; pcl_attributes } acc ->\n let acc = self#class_expr_desc pcl_desc acc in\n let acc = self#location pcl_loc acc in\n let acc = self#attributes pcl_attributes acc in\n acc\n\n method class_expr_desc : class_expr_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pcl_constr (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#list self#core_type b acc in\n acc\n | Pcl_structure a -> self#class_structure a acc\n | Pcl_fun (a, b, c, d) ->\n let acc = self#arg_label a acc in\n let acc = self#option self#expression b acc in\n let acc = self#pattern c acc in\n let acc = self#class_expr d acc in\n acc\n | Pcl_apply (a, b) ->\n let acc = self#class_expr a acc in\n let acc =\n self#list\n (fun (a, b) acc ->\n let acc = self#arg_label a acc in\n let acc = self#expression b acc in\n acc)\n b acc\n in\n acc\n | Pcl_let (a, b, c) ->\n let acc = self#rec_flag a acc in\n let acc = self#list self#value_binding b acc in\n let acc = self#class_expr c acc in\n acc\n | Pcl_constraint (a, b) ->\n let acc = self#class_expr a acc in\n let acc = self#class_type b acc in\n acc\n | Pcl_extension a -> self#extension a acc\n | Pcl_open (a, b) ->\n let acc = self#open_description a acc in\n let acc = self#class_expr b acc in\n acc\n\n method class_structure : class_structure -> 'acc -> 'acc =\n fun { pcstr_self; pcstr_fields } acc ->\n let acc = self#pattern pcstr_self acc in\n let acc = self#list self#class_field pcstr_fields acc in\n acc\n\n method class_field : class_field -> 'acc -> 'acc =\n fun { pcf_desc; pcf_loc; pcf_attributes } acc ->\n let acc = self#class_field_desc pcf_desc acc in\n let acc = self#location pcf_loc acc in\n let acc = self#attributes pcf_attributes acc in\n acc\n\n method class_field_desc : class_field_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pcf_inherit (a, b, c) ->\n let acc = self#override_flag a acc in\n let acc = self#class_expr b acc in\n let acc = self#option (self#loc self#string) c acc in\n acc\n | Pcf_val a ->\n (fun (a, b, c) acc ->\n let acc = self#loc self#label a acc in\n let acc = self#mutable_flag b acc in\n let acc = self#class_field_kind c acc in\n acc)\n a acc\n | Pcf_method a ->\n (fun (a, b, c) acc ->\n let acc = self#loc self#label a acc in\n let acc = self#private_flag b acc in\n let acc = self#class_field_kind c acc in\n acc)\n a acc\n | Pcf_constraint a ->\n (fun (a, b) acc ->\n let acc = self#core_type a acc in\n let acc = self#core_type b acc in\n acc)\n a acc\n | Pcf_initializer a -> self#expression a acc\n | Pcf_attribute a -> self#attribute a acc\n | Pcf_extension a -> self#extension a acc\n\n method class_field_kind : class_field_kind -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Cfk_virtual a -> self#core_type a acc\n | Cfk_concrete (a, b) ->\n let acc = self#override_flag a acc in\n let acc = self#expression b acc in\n acc\n\n method class_declaration : class_declaration -> 'acc -> 'acc =\n self#class_infos self#class_expr\n\n method module_type : module_type -> 'acc -> 'acc =\n fun { pmty_desc; pmty_loc; pmty_attributes } acc ->\n let acc = self#module_type_desc pmty_desc acc in\n let acc = self#location pmty_loc acc in\n let acc = self#attributes pmty_attributes acc in\n acc\n\n method module_type_desc : module_type_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pmty_ident a -> self#longident_loc a acc\n | Pmty_signature a -> self#signature a acc\n | Pmty_functor (a, b) ->\n let acc = self#functor_parameter a acc in\n let acc = self#module_type b acc in\n acc\n | Pmty_with (a, b) ->\n let acc = self#module_type a acc in\n let acc = self#list self#with_constraint b acc in\n acc\n | Pmty_typeof a -> self#module_expr a acc\n | Pmty_extension a -> self#extension a acc\n | Pmty_alias a -> self#longident_loc a acc\n\n method functor_parameter : functor_parameter -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Unit -> acc\n | Named (a, b) ->\n let acc = self#loc (self#option self#string) a acc in\n let acc = self#module_type b acc in\n acc\n\n method signature : signature -> 'acc -> 'acc = self#list self#signature_item\n\n method signature_item : signature_item -> 'acc -> 'acc =\n fun { psig_desc; psig_loc } acc ->\n let acc = self#signature_item_desc psig_desc acc in\n let acc = self#location psig_loc acc in\n acc\n\n method signature_item_desc : signature_item_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Psig_value a -> self#value_description a acc\n | Psig_type (a, b) ->\n let acc = self#rec_flag a acc in\n let acc = self#list self#type_declaration b acc in\n acc\n | Psig_typesubst a -> self#list self#type_declaration a acc\n | Psig_typext a -> self#type_extension a acc\n | Psig_exception a -> self#type_exception a acc\n | Psig_module a -> self#module_declaration a acc\n | Psig_modsubst a -> self#module_substitution a acc\n | Psig_recmodule a -> self#list self#module_declaration a acc\n | Psig_modtype a -> self#module_type_declaration a acc\n | Psig_open a -> self#open_description a acc\n | Psig_include a -> self#include_description a acc\n | Psig_class a -> self#list self#class_description a acc\n | Psig_class_type a -> self#list self#class_type_declaration a acc\n | Psig_attribute a -> self#attribute a acc\n | Psig_extension (a, b) ->\n let acc = self#extension a acc in\n let acc = self#attributes b acc in\n acc\n\n method module_declaration : module_declaration -> 'acc -> 'acc =\n fun { pmd_name; pmd_type; pmd_attributes; pmd_loc } acc ->\n let acc = self#loc (self#option self#string) pmd_name acc in\n let acc = self#module_type pmd_type acc in\n let acc = self#attributes pmd_attributes acc in\n let acc = self#location pmd_loc acc in\n acc\n\n method module_substitution : module_substitution -> 'acc -> 'acc =\n fun { pms_name; pms_manifest; pms_attributes; pms_loc } acc ->\n let acc = self#loc self#string pms_name acc in\n let acc = self#longident_loc pms_manifest acc in\n let acc = self#attributes pms_attributes acc in\n let acc = self#location pms_loc acc in\n acc\n\n method module_type_declaration : module_type_declaration -> 'acc -> 'acc =\n fun { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } acc ->\n let acc = self#loc self#string pmtd_name acc in\n let acc = self#option self#module_type pmtd_type acc in\n let acc = self#attributes pmtd_attributes acc in\n let acc = self#location pmtd_loc acc in\n acc\n\n method open_infos\n : 'a. ('a -> 'acc -> 'acc) -> 'a open_infos -> 'acc -> 'acc =\n fun _a { popen_expr; popen_override; popen_loc; popen_attributes } acc ->\n let acc = _a popen_expr acc in\n let acc = self#override_flag popen_override acc in\n let acc = self#location popen_loc acc in\n let acc = self#attributes popen_attributes acc in\n acc\n\n method open_description : open_description -> 'acc -> 'acc =\n self#open_infos self#longident_loc\n\n method open_declaration : open_declaration -> 'acc -> 'acc =\n self#open_infos self#module_expr\n\n method include_infos\n : 'a. ('a -> 'acc -> 'acc) -> 'a include_infos -> 'acc -> 'acc =\n fun _a { pincl_mod; pincl_loc; pincl_attributes } acc ->\n let acc = _a pincl_mod acc in\n let acc = self#location pincl_loc acc in\n let acc = self#attributes pincl_attributes acc in\n acc\n\n method include_description : include_description -> 'acc -> 'acc =\n self#include_infos self#module_type\n\n method include_declaration : include_declaration -> 'acc -> 'acc =\n self#include_infos self#module_expr\n\n method with_constraint : with_constraint -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pwith_type (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#type_declaration b acc in\n acc\n | Pwith_module (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#longident_loc b acc in\n acc\n | Pwith_typesubst (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#type_declaration b acc in\n acc\n | Pwith_modsubst (a, b) ->\n let acc = self#longident_loc a acc in\n let acc = self#longident_loc b acc in\n acc\n\n method module_expr : module_expr -> 'acc -> 'acc =\n fun { pmod_desc; pmod_loc; pmod_attributes } acc ->\n let acc = self#module_expr_desc pmod_desc acc in\n let acc = self#location pmod_loc acc in\n let acc = self#attributes pmod_attributes acc in\n acc\n\n method module_expr_desc : module_expr_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pmod_ident a -> self#longident_loc a acc\n | Pmod_structure a -> self#structure a acc\n | Pmod_functor (a, b) ->\n let acc = self#functor_parameter a acc in\n let acc = self#module_expr b acc in\n acc\n | Pmod_apply (a, b) ->\n let acc = self#module_expr a acc in\n let acc = self#module_expr b acc in\n acc\n | Pmod_constraint (a, b) ->\n let acc = self#module_expr a acc in\n let acc = self#module_type b acc in\n acc\n | Pmod_unpack a -> self#expression a acc\n | Pmod_extension a -> self#extension a acc\n\n method structure : structure -> 'acc -> 'acc = self#list self#structure_item\n\n method structure_item : structure_item -> 'acc -> 'acc =\n fun { pstr_desc; pstr_loc } acc ->\n let acc = self#structure_item_desc pstr_desc acc in\n let acc = self#location pstr_loc acc in\n acc\n\n method structure_item_desc : structure_item_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pstr_eval (a, b) ->\n let acc = self#expression a acc in\n let acc = self#attributes b acc in\n acc\n | Pstr_value (a, b) ->\n let acc = self#rec_flag a acc in\n let acc = self#list self#value_binding b acc in\n acc\n | Pstr_primitive a -> self#value_description a acc\n | Pstr_type (a, b) ->\n let acc = self#rec_flag a acc in\n let acc = self#list self#type_declaration b acc in\n acc\n | Pstr_typext a -> self#type_extension a acc\n | Pstr_exception a -> self#type_exception a acc\n | Pstr_module a -> self#module_binding a acc\n | Pstr_recmodule a -> self#list self#module_binding a acc\n | Pstr_modtype a -> self#module_type_declaration a acc\n | Pstr_open a -> self#open_declaration a acc\n | Pstr_class a -> self#list self#class_declaration a acc\n | Pstr_class_type a -> self#list self#class_type_declaration a acc\n | Pstr_include a -> self#include_declaration a acc\n | Pstr_attribute a -> self#attribute a acc\n | Pstr_extension (a, b) ->\n let acc = self#extension a acc in\n let acc = self#attributes b acc in\n acc\n\n method value_binding : value_binding -> 'acc -> 'acc =\n fun { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } acc ->\n let acc = self#pattern pvb_pat acc in\n let acc = self#expression pvb_expr acc in\n let acc = self#attributes pvb_attributes acc in\n let acc = self#location pvb_loc acc in\n acc\n\n method module_binding : module_binding -> 'acc -> 'acc =\n fun { pmb_name; pmb_expr; pmb_attributes; pmb_loc } acc ->\n let acc = self#loc (self#option self#string) pmb_name acc in\n let acc = self#module_expr pmb_expr acc in\n let acc = self#attributes pmb_attributes acc in\n let acc = self#location pmb_loc acc in\n acc\n\n method toplevel_phrase : toplevel_phrase -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Ptop_def a -> self#structure a acc\n | Ptop_dir a -> self#toplevel_directive a acc\n\n method toplevel_directive : toplevel_directive -> 'acc -> 'acc =\n fun { pdir_name; pdir_arg; pdir_loc } acc ->\n let acc = self#loc self#string pdir_name acc in\n let acc = self#option self#directive_argument pdir_arg acc in\n let acc = self#location pdir_loc acc in\n acc\n\n method directive_argument : directive_argument -> 'acc -> 'acc =\n fun { pdira_desc; pdira_loc } acc ->\n let acc = self#directive_argument_desc pdira_desc acc in\n let acc = self#location pdira_loc acc in\n acc\n\n method directive_argument_desc : directive_argument_desc -> 'acc -> 'acc =\n fun x acc ->\n match x with\n | Pdir_string a -> self#string a acc\n | Pdir_int (a, b) ->\n let acc = self#string a acc in\n let acc = self#option self#char b acc in\n acc\n | Pdir_ident a -> self#longident a acc\n | Pdir_bool a -> self#bool a acc\n\n method cases : cases -> 'acc -> 'acc = self#list self#case\n end\n\nclass virtual ['acc] fold_map =\n object (self)\n method virtual bool : bool -> 'acc -> bool * 'acc\n method virtual char : char -> 'acc -> char * 'acc\n method virtual int : int -> 'acc -> int * 'acc\n\n method virtual list\n : 'a. ('a -> 'acc -> 'a * 'acc) -> 'a list -> 'acc -> 'a list * 'acc\n\n method virtual option\n : 'a. ('a -> 'acc -> 'a * 'acc) -> 'a option -> 'acc -> 'a option * 'acc\n\n method virtual string : string -> 'acc -> string * 'acc\n\n method position : position -> 'acc -> position * 'acc =\n fun { pos_fname; pos_lnum; pos_bol; pos_cnum } acc ->\n let pos_fname, acc = self#string pos_fname acc in\n let pos_lnum, acc = self#int pos_lnum acc in\n let pos_bol, acc = self#int pos_bol acc in\n let pos_cnum, acc = self#int pos_cnum acc in\n ({ pos_fname; pos_lnum; pos_bol; pos_cnum }, acc)\n\n method location : location -> 'acc -> location * 'acc =\n fun { loc_start; loc_end; loc_ghost } acc ->\n let loc_start, acc = self#position loc_start acc in\n let loc_end, acc = self#position loc_end acc in\n let loc_ghost, acc = self#bool loc_ghost acc in\n ({ loc_start; loc_end; loc_ghost }, acc)\n\n method location_stack : location_stack -> 'acc -> location_stack * 'acc =\n self#list self#location\n\n method loc\n : 'a. ('a -> 'acc -> 'a * 'acc) -> 'a loc -> 'acc -> 'a loc * 'acc =\n fun _a { txt; loc } acc ->\n let txt, acc = _a txt acc in\n let loc, acc = self#location loc acc in\n ({ txt; loc }, acc)\n\n method longident : longident -> 'acc -> longident * 'acc =\n fun x acc ->\n match x with\n | Lident a ->\n let a, acc = self#string a acc in\n (Lident a, acc)\n | Ldot (a, b) ->\n let a, acc = self#longident a acc in\n let b, acc = self#string b acc in\n (Ldot (a, b), acc)\n | Lapply (a, b) ->\n let a, acc = self#longident a acc in\n let b, acc = self#longident b acc in\n (Lapply (a, b), acc)\n\n method longident_loc : longident_loc -> 'acc -> longident_loc * 'acc =\n self#loc self#longident\n\n method rec_flag : rec_flag -> 'acc -> rec_flag * 'acc = fun x acc -> (x, acc)\n\n method direction_flag : direction_flag -> 'acc -> direction_flag * 'acc =\n fun x acc -> (x, acc)\n\n method private_flag : private_flag -> 'acc -> private_flag * 'acc =\n fun x acc -> (x, acc)\n\n method mutable_flag : mutable_flag -> 'acc -> mutable_flag * 'acc =\n fun x acc -> (x, acc)\n\n method virtual_flag : virtual_flag -> 'acc -> virtual_flag * 'acc =\n fun x acc -> (x, acc)\n\n method override_flag : override_flag -> 'acc -> override_flag * 'acc =\n fun x acc -> (x, acc)\n\n method closed_flag : closed_flag -> 'acc -> closed_flag * 'acc =\n fun x acc -> (x, acc)\n\n method label : label -> 'acc -> label * 'acc = self#string\n\n method arg_label : arg_label -> 'acc -> arg_label * 'acc =\n fun x acc ->\n match x with\n | Nolabel -> (Nolabel, acc)\n | Labelled a ->\n let a, acc = self#string a acc in\n (Labelled a, acc)\n | Optional a ->\n let a, acc = self#string a acc in\n (Optional a, acc)\n\n method variance : variance -> 'acc -> variance * 'acc = fun x acc -> (x, acc)\n\n method injectivity : injectivity -> 'acc -> injectivity * 'acc =\n fun x acc -> (x, acc)\n\n method constant : constant -> 'acc -> constant * 'acc =\n fun x acc ->\n match x with\n | Pconst_integer (a, b) ->\n let a, acc = self#string a acc in\n let b, acc = self#option self#char b acc in\n (Pconst_integer (a, b), acc)\n | Pconst_char a ->\n let a, acc = self#char a acc in\n (Pconst_char a, acc)\n | Pconst_string (a, b, c) ->\n let a, acc = self#string a acc in\n let b, acc = self#location b acc in\n let c, acc = self#option self#string c acc in\n (Pconst_string (a, b, c), acc)\n | Pconst_float (a, b) ->\n let a, acc = self#string a acc in\n let b, acc = self#option self#char b acc in\n (Pconst_float (a, b), acc)\n\n method attribute : attribute -> 'acc -> attribute * 'acc =\n fun { attr_name; attr_payload; attr_loc } acc ->\n let attr_name, acc = self#loc self#string attr_name acc in\n let attr_payload, acc = self#payload attr_payload acc in\n let attr_loc, acc = self#location attr_loc acc in\n ({ attr_name; attr_payload; attr_loc }, acc)\n\n method extension : extension -> 'acc -> extension * 'acc =\n fun (a, b) acc ->\n let a, acc = self#loc self#string a acc in\n let b, acc = self#payload b acc in\n ((a, b), acc)\n\n method attributes : attributes -> 'acc -> attributes * 'acc =\n self#list self#attribute\n\n method payload : payload -> 'acc -> payload * 'acc =\n fun x acc ->\n match x with\n | PStr a ->\n let a, acc = self#structure a acc in\n (PStr a, acc)\n | PSig a ->\n let a, acc = self#signature a acc in\n (PSig a, acc)\n | PTyp a ->\n let a, acc = self#core_type a acc in\n (PTyp a, acc)\n | PPat (a, b) ->\n let a, acc = self#pattern a acc in\n let b, acc = self#option self#expression b acc in\n (PPat (a, b), acc)\n\n method core_type : core_type -> 'acc -> core_type * 'acc =\n fun { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } acc ->\n let ptyp_desc, acc = self#core_type_desc ptyp_desc acc in\n let ptyp_loc, acc = self#location ptyp_loc acc in\n let ptyp_loc_stack, acc = self#location_stack ptyp_loc_stack acc in\n let ptyp_attributes, acc = self#attributes ptyp_attributes acc in\n ({ ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes }, acc)\n\n method core_type_desc : core_type_desc -> 'acc -> core_type_desc * 'acc =\n fun x acc ->\n match x with\n | Ptyp_any -> (Ptyp_any, acc)\n | Ptyp_var a ->\n let a, acc = self#string a acc in\n (Ptyp_var a, acc)\n | Ptyp_arrow (a, b, c) ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#core_type b acc in\n let c, acc = self#core_type c acc in\n (Ptyp_arrow (a, b, c), acc)\n | Ptyp_tuple a ->\n let a, acc = self#list self#core_type a acc in\n (Ptyp_tuple a, acc)\n | Ptyp_constr (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#list self#core_type b acc in\n (Ptyp_constr (a, b), acc)\n | Ptyp_object (a, b) ->\n let a, acc = self#list self#object_field a acc in\n let b, acc = self#closed_flag b acc in\n (Ptyp_object (a, b), acc)\n | Ptyp_class (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#list self#core_type b acc in\n (Ptyp_class (a, b), acc)\n | Ptyp_alias (a, b) ->\n let a, acc = self#core_type a acc in\n let b, acc = self#string b acc in\n (Ptyp_alias (a, b), acc)\n | Ptyp_variant (a, b, c) ->\n let a, acc = self#list self#row_field a acc in\n let b, acc = self#closed_flag b acc in\n let c, acc = self#option (self#list self#label) c acc in\n (Ptyp_variant (a, b, c), acc)\n | Ptyp_poly (a, b) ->\n let a, acc = self#list (self#loc self#string) a acc in\n let b, acc = self#core_type b acc in\n (Ptyp_poly (a, b), acc)\n | Ptyp_package a ->\n let a, acc = self#package_type a acc in\n (Ptyp_package a, acc)\n | Ptyp_extension a ->\n let a, acc = self#extension a acc in\n (Ptyp_extension a, acc)\n\n method package_type : package_type -> 'acc -> package_type * 'acc =\n fun (a, b) acc ->\n let a, acc = self#longident_loc a acc in\n let b, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#core_type b acc in\n ((a, b), acc))\n b acc\n in\n ((a, b), acc)\n\n method row_field : row_field -> 'acc -> row_field * 'acc =\n fun { prf_desc; prf_loc; prf_attributes } acc ->\n let prf_desc, acc = self#row_field_desc prf_desc acc in\n let prf_loc, acc = self#location prf_loc acc in\n let prf_attributes, acc = self#attributes prf_attributes acc in\n ({ prf_desc; prf_loc; prf_attributes }, acc)\n\n method row_field_desc : row_field_desc -> 'acc -> row_field_desc * 'acc =\n fun x acc ->\n match x with\n | Rtag (a, b, c) ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#bool b acc in\n let c, acc = self#list self#core_type c acc in\n (Rtag (a, b, c), acc)\n | Rinherit a ->\n let a, acc = self#core_type a acc in\n (Rinherit a, acc)\n\n method object_field : object_field -> 'acc -> object_field * 'acc =\n fun { pof_desc; pof_loc; pof_attributes } acc ->\n let pof_desc, acc = self#object_field_desc pof_desc acc in\n let pof_loc, acc = self#location pof_loc acc in\n let pof_attributes, acc = self#attributes pof_attributes acc in\n ({ pof_desc; pof_loc; pof_attributes }, acc)\n\n method object_field_desc\n : object_field_desc -> 'acc -> object_field_desc * 'acc =\n fun x acc ->\n match x with\n | Otag (a, b) ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#core_type b acc in\n (Otag (a, b), acc)\n | Oinherit a ->\n let a, acc = self#core_type a acc in\n (Oinherit a, acc)\n\n method pattern : pattern -> 'acc -> pattern * 'acc =\n fun { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } acc ->\n let ppat_desc, acc = self#pattern_desc ppat_desc acc in\n let ppat_loc, acc = self#location ppat_loc acc in\n let ppat_loc_stack, acc = self#location_stack ppat_loc_stack acc in\n let ppat_attributes, acc = self#attributes ppat_attributes acc in\n ({ ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes }, acc)\n\n method pattern_desc : pattern_desc -> 'acc -> pattern_desc * 'acc =\n fun x acc ->\n match x with\n | Ppat_any -> (Ppat_any, acc)\n | Ppat_var a ->\n let a, acc = self#loc self#string a acc in\n (Ppat_var a, acc)\n | Ppat_alias (a, b) ->\n let a, acc = self#pattern a acc in\n let b, acc = self#loc self#string b acc in\n (Ppat_alias (a, b), acc)\n | Ppat_constant a ->\n let a, acc = self#constant a acc in\n (Ppat_constant a, acc)\n | Ppat_interval (a, b) ->\n let a, acc = self#constant a acc in\n let b, acc = self#constant b acc in\n (Ppat_interval (a, b), acc)\n | Ppat_tuple a ->\n let a, acc = self#list self#pattern a acc in\n (Ppat_tuple a, acc)\n | Ppat_construct (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#option self#pattern b acc in\n (Ppat_construct (a, b), acc)\n | Ppat_variant (a, b) ->\n let a, acc = self#label a acc in\n let b, acc = self#option self#pattern b acc in\n (Ppat_variant (a, b), acc)\n | Ppat_record (a, b) ->\n let a, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#pattern b acc in\n ((a, b), acc))\n a acc\n in\n let b, acc = self#closed_flag b acc in\n (Ppat_record (a, b), acc)\n | Ppat_array a ->\n let a, acc = self#list self#pattern a acc in\n (Ppat_array a, acc)\n | Ppat_or (a, b) ->\n let a, acc = self#pattern a acc in\n let b, acc = self#pattern b acc in\n (Ppat_or (a, b), acc)\n | Ppat_constraint (a, b) ->\n let a, acc = self#pattern a acc in\n let b, acc = self#core_type b acc in\n (Ppat_constraint (a, b), acc)\n | Ppat_type a ->\n let a, acc = self#longident_loc a acc in\n (Ppat_type a, acc)\n | Ppat_lazy a ->\n let a, acc = self#pattern a acc in\n (Ppat_lazy a, acc)\n | Ppat_unpack a ->\n let a, acc = self#loc (self#option self#string) a acc in\n (Ppat_unpack a, acc)\n | Ppat_exception a ->\n let a, acc = self#pattern a acc in\n (Ppat_exception a, acc)\n | Ppat_extension a ->\n let a, acc = self#extension a acc in\n (Ppat_extension a, acc)\n | Ppat_open (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#pattern b acc in\n (Ppat_open (a, b), acc)\n\n method expression : expression -> 'acc -> expression * 'acc =\n fun { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } acc ->\n let pexp_desc, acc = self#expression_desc pexp_desc acc in\n let pexp_loc, acc = self#location pexp_loc acc in\n let pexp_loc_stack, acc = self#location_stack pexp_loc_stack acc in\n let pexp_attributes, acc = self#attributes pexp_attributes acc in\n ({ pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes }, acc)\n\n method expression_desc : expression_desc -> 'acc -> expression_desc * 'acc =\n fun x acc ->\n match x with\n | Pexp_ident a ->\n let a, acc = self#longident_loc a acc in\n (Pexp_ident a, acc)\n | Pexp_constant a ->\n let a, acc = self#constant a acc in\n (Pexp_constant a, acc)\n | Pexp_let (a, b, c) ->\n let a, acc = self#rec_flag a acc in\n let b, acc = self#list self#value_binding b acc in\n let c, acc = self#expression c acc in\n (Pexp_let (a, b, c), acc)\n | Pexp_function a ->\n let a, acc = self#cases a acc in\n (Pexp_function a, acc)\n | Pexp_fun (a, b, c, d) ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#option self#expression b acc in\n let c, acc = self#pattern c acc in\n let d, acc = self#expression d acc in\n (Pexp_fun (a, b, c, d), acc)\n | Pexp_apply (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#expression b acc in\n ((a, b), acc))\n b acc\n in\n (Pexp_apply (a, b), acc)\n | Pexp_match (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#cases b acc in\n (Pexp_match (a, b), acc)\n | Pexp_try (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#cases b acc in\n (Pexp_try (a, b), acc)\n | Pexp_tuple a ->\n let a, acc = self#list self#expression a acc in\n (Pexp_tuple a, acc)\n | Pexp_construct (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#option self#expression b acc in\n (Pexp_construct (a, b), acc)\n | Pexp_variant (a, b) ->\n let a, acc = self#label a acc in\n let b, acc = self#option self#expression b acc in\n (Pexp_variant (a, b), acc)\n | Pexp_record (a, b) ->\n let a, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#expression b acc in\n ((a, b), acc))\n a acc\n in\n let b, acc = self#option self#expression b acc in\n (Pexp_record (a, b), acc)\n | Pexp_field (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#longident_loc b acc in\n (Pexp_field (a, b), acc)\n | Pexp_setfield (a, b, c) ->\n let a, acc = self#expression a acc in\n let b, acc = self#longident_loc b acc in\n let c, acc = self#expression c acc in\n (Pexp_setfield (a, b, c), acc)\n | Pexp_array a ->\n let a, acc = self#list self#expression a acc in\n (Pexp_array a, acc)\n | Pexp_ifthenelse (a, b, c) ->\n let a, acc = self#expression a acc in\n let b, acc = self#expression b acc in\n let c, acc = self#option self#expression c acc in\n (Pexp_ifthenelse (a, b, c), acc)\n | Pexp_sequence (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#expression b acc in\n (Pexp_sequence (a, b), acc)\n | Pexp_while (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#expression b acc in\n (Pexp_while (a, b), acc)\n | Pexp_for (a, b, c, d, e) ->\n let a, acc = self#pattern a acc in\n let b, acc = self#expression b acc in\n let c, acc = self#expression c acc in\n let d, acc = self#direction_flag d acc in\n let e, acc = self#expression e acc in\n (Pexp_for (a, b, c, d, e), acc)\n | Pexp_constraint (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#core_type b acc in\n (Pexp_constraint (a, b), acc)\n | Pexp_coerce (a, b, c) ->\n let a, acc = self#expression a acc in\n let b, acc = self#option self#core_type b acc in\n let c, acc = self#core_type c acc in\n (Pexp_coerce (a, b, c), acc)\n | Pexp_send (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#loc self#label b acc in\n (Pexp_send (a, b), acc)\n | Pexp_new a ->\n let a, acc = self#longident_loc a acc in\n (Pexp_new a, acc)\n | Pexp_setinstvar (a, b) ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#expression b acc in\n (Pexp_setinstvar (a, b), acc)\n | Pexp_override a ->\n let a, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#expression b acc in\n ((a, b), acc))\n a acc\n in\n (Pexp_override a, acc)\n | Pexp_letmodule (a, b, c) ->\n let a, acc = self#loc (self#option self#string) a acc in\n let b, acc = self#module_expr b acc in\n let c, acc = self#expression c acc in\n (Pexp_letmodule (a, b, c), acc)\n | Pexp_letexception (a, b) ->\n let a, acc = self#extension_constructor a acc in\n let b, acc = self#expression b acc in\n (Pexp_letexception (a, b), acc)\n | Pexp_assert a ->\n let a, acc = self#expression a acc in\n (Pexp_assert a, acc)\n | Pexp_lazy a ->\n let a, acc = self#expression a acc in\n (Pexp_lazy a, acc)\n | Pexp_poly (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#option self#core_type b acc in\n (Pexp_poly (a, b), acc)\n | Pexp_object a ->\n let a, acc = self#class_structure a acc in\n (Pexp_object a, acc)\n | Pexp_newtype (a, b) ->\n let a, acc = self#loc self#string a acc in\n let b, acc = self#expression b acc in\n (Pexp_newtype (a, b), acc)\n | Pexp_pack a ->\n let a, acc = self#module_expr a acc in\n (Pexp_pack a, acc)\n | Pexp_open (a, b) ->\n let a, acc = self#open_declaration a acc in\n let b, acc = self#expression b acc in\n (Pexp_open (a, b), acc)\n | Pexp_letop a ->\n let a, acc = self#letop a acc in\n (Pexp_letop a, acc)\n | Pexp_extension a ->\n let a, acc = self#extension a acc in\n (Pexp_extension a, acc)\n | Pexp_unreachable -> (Pexp_unreachable, acc)\n\n method case : case -> 'acc -> case * 'acc =\n fun { pc_lhs; pc_guard; pc_rhs } acc ->\n let pc_lhs, acc = self#pattern pc_lhs acc in\n let pc_guard, acc = self#option self#expression pc_guard acc in\n let pc_rhs, acc = self#expression pc_rhs acc in\n ({ pc_lhs; pc_guard; pc_rhs }, acc)\n\n method letop : letop -> 'acc -> letop * 'acc =\n fun { let_; ands; body } acc ->\n let let_, acc = self#binding_op let_ acc in\n let ands, acc = self#list self#binding_op ands acc in\n let body, acc = self#expression body acc in\n ({ let_; ands; body }, acc)\n\n method binding_op : binding_op -> 'acc -> binding_op * 'acc =\n fun { pbop_op; pbop_pat; pbop_exp; pbop_loc } acc ->\n let pbop_op, acc = self#loc self#string pbop_op acc in\n let pbop_pat, acc = self#pattern pbop_pat acc in\n let pbop_exp, acc = self#expression pbop_exp acc in\n let pbop_loc, acc = self#location pbop_loc acc in\n ({ pbop_op; pbop_pat; pbop_exp; pbop_loc }, acc)\n\n method value_description\n : value_description -> 'acc -> value_description * 'acc =\n fun { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } acc ->\n let pval_name, acc = self#loc self#string pval_name acc in\n let pval_type, acc = self#core_type pval_type acc in\n let pval_prim, acc = self#list self#string pval_prim acc in\n let pval_attributes, acc = self#attributes pval_attributes acc in\n let pval_loc, acc = self#location pval_loc acc in\n ({ pval_name; pval_type; pval_prim; pval_attributes; pval_loc }, acc)\n\n method type_declaration\n : type_declaration -> 'acc -> type_declaration * 'acc =\n fun {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } acc ->\n let ptype_name, acc = self#loc self#string ptype_name acc in\n let ptype_params, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#core_type a acc in\n let b, acc =\n (fun (a, b) acc ->\n let a, acc = self#variance a acc in\n let b, acc = self#injectivity b acc in\n ((a, b), acc))\n b acc\n in\n ((a, b), acc))\n ptype_params acc\n in\n let ptype_cstrs, acc =\n self#list\n (fun (a, b, c) acc ->\n let a, acc = self#core_type a acc in\n let b, acc = self#core_type b acc in\n let c, acc = self#location c acc in\n ((a, b, c), acc))\n ptype_cstrs acc\n in\n let ptype_kind, acc = self#type_kind ptype_kind acc in\n let ptype_private, acc = self#private_flag ptype_private acc in\n let ptype_manifest, acc =\n self#option self#core_type ptype_manifest acc\n in\n let ptype_attributes, acc = self#attributes ptype_attributes acc in\n let ptype_loc, acc = self#location ptype_loc acc in\n ( {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n },\n acc )\n\n method type_kind : type_kind -> 'acc -> type_kind * 'acc =\n fun x acc ->\n match x with\n | Ptype_abstract -> (Ptype_abstract, acc)\n | Ptype_variant a ->\n let a, acc = self#list self#constructor_declaration a acc in\n (Ptype_variant a, acc)\n | Ptype_record a ->\n let a, acc = self#list self#label_declaration a acc in\n (Ptype_record a, acc)\n | Ptype_open -> (Ptype_open, acc)\n\n method label_declaration\n : label_declaration -> 'acc -> label_declaration * 'acc =\n fun { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } acc ->\n let pld_name, acc = self#loc self#string pld_name acc in\n let pld_mutable, acc = self#mutable_flag pld_mutable acc in\n let pld_type, acc = self#core_type pld_type acc in\n let pld_loc, acc = self#location pld_loc acc in\n let pld_attributes, acc = self#attributes pld_attributes acc in\n ({ pld_name; pld_mutable; pld_type; pld_loc; pld_attributes }, acc)\n\n method constructor_declaration\n : constructor_declaration -> 'acc -> constructor_declaration * 'acc =\n fun { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } acc ->\n let pcd_name, acc = self#loc self#string pcd_name acc in\n let pcd_args, acc = self#constructor_arguments pcd_args acc in\n let pcd_res, acc = self#option self#core_type pcd_res acc in\n let pcd_loc, acc = self#location pcd_loc acc in\n let pcd_attributes, acc = self#attributes pcd_attributes acc in\n ({ pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes }, acc)\n\n method constructor_arguments\n : constructor_arguments -> 'acc -> constructor_arguments * 'acc =\n fun x acc ->\n match x with\n | Pcstr_tuple a ->\n let a, acc = self#list self#core_type a acc in\n (Pcstr_tuple a, acc)\n | Pcstr_record a ->\n let a, acc = self#list self#label_declaration a acc in\n (Pcstr_record a, acc)\n\n method type_extension : type_extension -> 'acc -> type_extension * 'acc =\n fun {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } acc ->\n let ptyext_path, acc = self#longident_loc ptyext_path acc in\n let ptyext_params, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#core_type a acc in\n let b, acc =\n (fun (a, b) acc ->\n let a, acc = self#variance a acc in\n let b, acc = self#injectivity b acc in\n ((a, b), acc))\n b acc\n in\n ((a, b), acc))\n ptyext_params acc\n in\n let ptyext_constructors, acc =\n self#list self#extension_constructor ptyext_constructors acc\n in\n let ptyext_private, acc = self#private_flag ptyext_private acc in\n let ptyext_loc, acc = self#location ptyext_loc acc in\n let ptyext_attributes, acc = self#attributes ptyext_attributes acc in\n ( {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n },\n acc )\n\n method extension_constructor\n : extension_constructor -> 'acc -> extension_constructor * 'acc =\n fun { pext_name; pext_kind; pext_loc; pext_attributes } acc ->\n let pext_name, acc = self#loc self#string pext_name acc in\n let pext_kind, acc = self#extension_constructor_kind pext_kind acc in\n let pext_loc, acc = self#location pext_loc acc in\n let pext_attributes, acc = self#attributes pext_attributes acc in\n ({ pext_name; pext_kind; pext_loc; pext_attributes }, acc)\n\n method type_exception : type_exception -> 'acc -> type_exception * 'acc =\n fun { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } acc ->\n let ptyexn_constructor, acc =\n self#extension_constructor ptyexn_constructor acc\n in\n let ptyexn_loc, acc = self#location ptyexn_loc acc in\n let ptyexn_attributes, acc = self#attributes ptyexn_attributes acc in\n ({ ptyexn_constructor; ptyexn_loc; ptyexn_attributes }, acc)\n\n method extension_constructor_kind\n : extension_constructor_kind ->\n 'acc ->\n extension_constructor_kind * 'acc =\n fun x acc ->\n match x with\n | Pext_decl (a, b) ->\n let a, acc = self#constructor_arguments a acc in\n let b, acc = self#option self#core_type b acc in\n (Pext_decl (a, b), acc)\n | Pext_rebind a ->\n let a, acc = self#longident_loc a acc in\n (Pext_rebind a, acc)\n\n method class_type : class_type -> 'acc -> class_type * 'acc =\n fun { pcty_desc; pcty_loc; pcty_attributes } acc ->\n let pcty_desc, acc = self#class_type_desc pcty_desc acc in\n let pcty_loc, acc = self#location pcty_loc acc in\n let pcty_attributes, acc = self#attributes pcty_attributes acc in\n ({ pcty_desc; pcty_loc; pcty_attributes }, acc)\n\n method class_type_desc : class_type_desc -> 'acc -> class_type_desc * 'acc =\n fun x acc ->\n match x with\n | Pcty_constr (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#list self#core_type b acc in\n (Pcty_constr (a, b), acc)\n | Pcty_signature a ->\n let a, acc = self#class_signature a acc in\n (Pcty_signature a, acc)\n | Pcty_arrow (a, b, c) ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#core_type b acc in\n let c, acc = self#class_type c acc in\n (Pcty_arrow (a, b, c), acc)\n | Pcty_extension a ->\n let a, acc = self#extension a acc in\n (Pcty_extension a, acc)\n | Pcty_open (a, b) ->\n let a, acc = self#open_description a acc in\n let b, acc = self#class_type b acc in\n (Pcty_open (a, b), acc)\n\n method class_signature : class_signature -> 'acc -> class_signature * 'acc =\n fun { pcsig_self; pcsig_fields } acc ->\n let pcsig_self, acc = self#core_type pcsig_self acc in\n let pcsig_fields, acc =\n self#list self#class_type_field pcsig_fields acc\n in\n ({ pcsig_self; pcsig_fields }, acc)\n\n method class_type_field\n : class_type_field -> 'acc -> class_type_field * 'acc =\n fun { pctf_desc; pctf_loc; pctf_attributes } acc ->\n let pctf_desc, acc = self#class_type_field_desc pctf_desc acc in\n let pctf_loc, acc = self#location pctf_loc acc in\n let pctf_attributes, acc = self#attributes pctf_attributes acc in\n ({ pctf_desc; pctf_loc; pctf_attributes }, acc)\n\n method class_type_field_desc\n : class_type_field_desc -> 'acc -> class_type_field_desc * 'acc =\n fun x acc ->\n match x with\n | Pctf_inherit a ->\n let a, acc = self#class_type a acc in\n (Pctf_inherit a, acc)\n | Pctf_val a ->\n let a, acc =\n (fun (a, b, c, d) acc ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#mutable_flag b acc in\n let c, acc = self#virtual_flag c acc in\n let d, acc = self#core_type d acc in\n ((a, b, c, d), acc))\n a acc\n in\n (Pctf_val a, acc)\n | Pctf_method a ->\n let a, acc =\n (fun (a, b, c, d) acc ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#private_flag b acc in\n let c, acc = self#virtual_flag c acc in\n let d, acc = self#core_type d acc in\n ((a, b, c, d), acc))\n a acc\n in\n (Pctf_method a, acc)\n | Pctf_constraint a ->\n let a, acc =\n (fun (a, b) acc ->\n let a, acc = self#core_type a acc in\n let b, acc = self#core_type b acc in\n ((a, b), acc))\n a acc\n in\n (Pctf_constraint a, acc)\n | Pctf_attribute a ->\n let a, acc = self#attribute a acc in\n (Pctf_attribute a, acc)\n | Pctf_extension a ->\n let a, acc = self#extension a acc in\n (Pctf_extension a, acc)\n\n method class_infos\n : 'a.\n ('a -> 'acc -> 'a * 'acc) ->\n 'a class_infos ->\n 'acc ->\n 'a class_infos * 'acc =\n fun _a\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes }\n acc ->\n let pci_virt, acc = self#virtual_flag pci_virt acc in\n let pci_params, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#core_type a acc in\n let b, acc =\n (fun (a, b) acc ->\n let a, acc = self#variance a acc in\n let b, acc = self#injectivity b acc in\n ((a, b), acc))\n b acc\n in\n ((a, b), acc))\n pci_params acc\n in\n let pci_name, acc = self#loc self#string pci_name acc in\n let pci_expr, acc = _a pci_expr acc in\n let pci_loc, acc = self#location pci_loc acc in\n let pci_attributes, acc = self#attributes pci_attributes acc in\n ( { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes },\n acc )\n\n method class_description\n : class_description -> 'acc -> class_description * 'acc =\n self#class_infos self#class_type\n\n method class_type_declaration\n : class_type_declaration -> 'acc -> class_type_declaration * 'acc =\n self#class_infos self#class_type\n\n method class_expr : class_expr -> 'acc -> class_expr * 'acc =\n fun { pcl_desc; pcl_loc; pcl_attributes } acc ->\n let pcl_desc, acc = self#class_expr_desc pcl_desc acc in\n let pcl_loc, acc = self#location pcl_loc acc in\n let pcl_attributes, acc = self#attributes pcl_attributes acc in\n ({ pcl_desc; pcl_loc; pcl_attributes }, acc)\n\n method class_expr_desc : class_expr_desc -> 'acc -> class_expr_desc * 'acc =\n fun x acc ->\n match x with\n | Pcl_constr (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#list self#core_type b acc in\n (Pcl_constr (a, b), acc)\n | Pcl_structure a ->\n let a, acc = self#class_structure a acc in\n (Pcl_structure a, acc)\n | Pcl_fun (a, b, c, d) ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#option self#expression b acc in\n let c, acc = self#pattern c acc in\n let d, acc = self#class_expr d acc in\n (Pcl_fun (a, b, c, d), acc)\n | Pcl_apply (a, b) ->\n let a, acc = self#class_expr a acc in\n let b, acc =\n self#list\n (fun (a, b) acc ->\n let a, acc = self#arg_label a acc in\n let b, acc = self#expression b acc in\n ((a, b), acc))\n b acc\n in\n (Pcl_apply (a, b), acc)\n | Pcl_let (a, b, c) ->\n let a, acc = self#rec_flag a acc in\n let b, acc = self#list self#value_binding b acc in\n let c, acc = self#class_expr c acc in\n (Pcl_let (a, b, c), acc)\n | Pcl_constraint (a, b) ->\n let a, acc = self#class_expr a acc in\n let b, acc = self#class_type b acc in\n (Pcl_constraint (a, b), acc)\n | Pcl_extension a ->\n let a, acc = self#extension a acc in\n (Pcl_extension a, acc)\n | Pcl_open (a, b) ->\n let a, acc = self#open_description a acc in\n let b, acc = self#class_expr b acc in\n (Pcl_open (a, b), acc)\n\n method class_structure : class_structure -> 'acc -> class_structure * 'acc =\n fun { pcstr_self; pcstr_fields } acc ->\n let pcstr_self, acc = self#pattern pcstr_self acc in\n let pcstr_fields, acc = self#list self#class_field pcstr_fields acc in\n ({ pcstr_self; pcstr_fields }, acc)\n\n method class_field : class_field -> 'acc -> class_field * 'acc =\n fun { pcf_desc; pcf_loc; pcf_attributes } acc ->\n let pcf_desc, acc = self#class_field_desc pcf_desc acc in\n let pcf_loc, acc = self#location pcf_loc acc in\n let pcf_attributes, acc = self#attributes pcf_attributes acc in\n ({ pcf_desc; pcf_loc; pcf_attributes }, acc)\n\n method class_field_desc\n : class_field_desc -> 'acc -> class_field_desc * 'acc =\n fun x acc ->\n match x with\n | Pcf_inherit (a, b, c) ->\n let a, acc = self#override_flag a acc in\n let b, acc = self#class_expr b acc in\n let c, acc = self#option (self#loc self#string) c acc in\n (Pcf_inherit (a, b, c), acc)\n | Pcf_val a ->\n let a, acc =\n (fun (a, b, c) acc ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#mutable_flag b acc in\n let c, acc = self#class_field_kind c acc in\n ((a, b, c), acc))\n a acc\n in\n (Pcf_val a, acc)\n | Pcf_method a ->\n let a, acc =\n (fun (a, b, c) acc ->\n let a, acc = self#loc self#label a acc in\n let b, acc = self#private_flag b acc in\n let c, acc = self#class_field_kind c acc in\n ((a, b, c), acc))\n a acc\n in\n (Pcf_method a, acc)\n | Pcf_constraint a ->\n let a, acc =\n (fun (a, b) acc ->\n let a, acc = self#core_type a acc in\n let b, acc = self#core_type b acc in\n ((a, b), acc))\n a acc\n in\n (Pcf_constraint a, acc)\n | Pcf_initializer a ->\n let a, acc = self#expression a acc in\n (Pcf_initializer a, acc)\n | Pcf_attribute a ->\n let a, acc = self#attribute a acc in\n (Pcf_attribute a, acc)\n | Pcf_extension a ->\n let a, acc = self#extension a acc in\n (Pcf_extension a, acc)\n\n method class_field_kind\n : class_field_kind -> 'acc -> class_field_kind * 'acc =\n fun x acc ->\n match x with\n | Cfk_virtual a ->\n let a, acc = self#core_type a acc in\n (Cfk_virtual a, acc)\n | Cfk_concrete (a, b) ->\n let a, acc = self#override_flag a acc in\n let b, acc = self#expression b acc in\n (Cfk_concrete (a, b), acc)\n\n method class_declaration\n : class_declaration -> 'acc -> class_declaration * 'acc =\n self#class_infos self#class_expr\n\n method module_type : module_type -> 'acc -> module_type * 'acc =\n fun { pmty_desc; pmty_loc; pmty_attributes } acc ->\n let pmty_desc, acc = self#module_type_desc pmty_desc acc in\n let pmty_loc, acc = self#location pmty_loc acc in\n let pmty_attributes, acc = self#attributes pmty_attributes acc in\n ({ pmty_desc; pmty_loc; pmty_attributes }, acc)\n\n method module_type_desc\n : module_type_desc -> 'acc -> module_type_desc * 'acc =\n fun x acc ->\n match x with\n | Pmty_ident a ->\n let a, acc = self#longident_loc a acc in\n (Pmty_ident a, acc)\n | Pmty_signature a ->\n let a, acc = self#signature a acc in\n (Pmty_signature a, acc)\n | Pmty_functor (a, b) ->\n let a, acc = self#functor_parameter a acc in\n let b, acc = self#module_type b acc in\n (Pmty_functor (a, b), acc)\n | Pmty_with (a, b) ->\n let a, acc = self#module_type a acc in\n let b, acc = self#list self#with_constraint b acc in\n (Pmty_with (a, b), acc)\n | Pmty_typeof a ->\n let a, acc = self#module_expr a acc in\n (Pmty_typeof a, acc)\n | Pmty_extension a ->\n let a, acc = self#extension a acc in\n (Pmty_extension a, acc)\n | Pmty_alias a ->\n let a, acc = self#longident_loc a acc in\n (Pmty_alias a, acc)\n\n method functor_parameter\n : functor_parameter -> 'acc -> functor_parameter * 'acc =\n fun x acc ->\n match x with\n | Unit -> (Unit, acc)\n | Named (a, b) ->\n let a, acc = self#loc (self#option self#string) a acc in\n let b, acc = self#module_type b acc in\n (Named (a, b), acc)\n\n method signature : signature -> 'acc -> signature * 'acc =\n self#list self#signature_item\n\n method signature_item : signature_item -> 'acc -> signature_item * 'acc =\n fun { psig_desc; psig_loc } acc ->\n let psig_desc, acc = self#signature_item_desc psig_desc acc in\n let psig_loc, acc = self#location psig_loc acc in\n ({ psig_desc; psig_loc }, acc)\n\n method signature_item_desc\n : signature_item_desc -> 'acc -> signature_item_desc * 'acc =\n fun x acc ->\n match x with\n | Psig_value a ->\n let a, acc = self#value_description a acc in\n (Psig_value a, acc)\n | Psig_type (a, b) ->\n let a, acc = self#rec_flag a acc in\n let b, acc = self#list self#type_declaration b acc in\n (Psig_type (a, b), acc)\n | Psig_typesubst a ->\n let a, acc = self#list self#type_declaration a acc in\n (Psig_typesubst a, acc)\n | Psig_typext a ->\n let a, acc = self#type_extension a acc in\n (Psig_typext a, acc)\n | Psig_exception a ->\n let a, acc = self#type_exception a acc in\n (Psig_exception a, acc)\n | Psig_module a ->\n let a, acc = self#module_declaration a acc in\n (Psig_module a, acc)\n | Psig_modsubst a ->\n let a, acc = self#module_substitution a acc in\n (Psig_modsubst a, acc)\n | Psig_recmodule a ->\n let a, acc = self#list self#module_declaration a acc in\n (Psig_recmodule a, acc)\n | Psig_modtype a ->\n let a, acc = self#module_type_declaration a acc in\n (Psig_modtype a, acc)\n | Psig_open a ->\n let a, acc = self#open_description a acc in\n (Psig_open a, acc)\n | Psig_include a ->\n let a, acc = self#include_description a acc in\n (Psig_include a, acc)\n | Psig_class a ->\n let a, acc = self#list self#class_description a acc in\n (Psig_class a, acc)\n | Psig_class_type a ->\n let a, acc = self#list self#class_type_declaration a acc in\n (Psig_class_type a, acc)\n | Psig_attribute a ->\n let a, acc = self#attribute a acc in\n (Psig_attribute a, acc)\n | Psig_extension (a, b) ->\n let a, acc = self#extension a acc in\n let b, acc = self#attributes b acc in\n (Psig_extension (a, b), acc)\n\n method module_declaration\n : module_declaration -> 'acc -> module_declaration * 'acc =\n fun { pmd_name; pmd_type; pmd_attributes; pmd_loc } acc ->\n let pmd_name, acc = self#loc (self#option self#string) pmd_name acc in\n let pmd_type, acc = self#module_type pmd_type acc in\n let pmd_attributes, acc = self#attributes pmd_attributes acc in\n let pmd_loc, acc = self#location pmd_loc acc in\n ({ pmd_name; pmd_type; pmd_attributes; pmd_loc }, acc)\n\n method module_substitution\n : module_substitution -> 'acc -> module_substitution * 'acc =\n fun { pms_name; pms_manifest; pms_attributes; pms_loc } acc ->\n let pms_name, acc = self#loc self#string pms_name acc in\n let pms_manifest, acc = self#longident_loc pms_manifest acc in\n let pms_attributes, acc = self#attributes pms_attributes acc in\n let pms_loc, acc = self#location pms_loc acc in\n ({ pms_name; pms_manifest; pms_attributes; pms_loc }, acc)\n\n method module_type_declaration\n : module_type_declaration -> 'acc -> module_type_declaration * 'acc =\n fun { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } acc ->\n let pmtd_name, acc = self#loc self#string pmtd_name acc in\n let pmtd_type, acc = self#option self#module_type pmtd_type acc in\n let pmtd_attributes, acc = self#attributes pmtd_attributes acc in\n let pmtd_loc, acc = self#location pmtd_loc acc in\n ({ pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc }, acc)\n\n method open_infos\n : 'a.\n ('a -> 'acc -> 'a * 'acc) ->\n 'a open_infos ->\n 'acc ->\n 'a open_infos * 'acc =\n fun _a { popen_expr; popen_override; popen_loc; popen_attributes } acc ->\n let popen_expr, acc = _a popen_expr acc in\n let popen_override, acc = self#override_flag popen_override acc in\n let popen_loc, acc = self#location popen_loc acc in\n let popen_attributes, acc = self#attributes popen_attributes acc in\n ({ popen_expr; popen_override; popen_loc; popen_attributes }, acc)\n\n method open_description\n : open_description -> 'acc -> open_description * 'acc =\n self#open_infos self#longident_loc\n\n method open_declaration\n : open_declaration -> 'acc -> open_declaration * 'acc =\n self#open_infos self#module_expr\n\n method include_infos\n : 'a.\n ('a -> 'acc -> 'a * 'acc) ->\n 'a include_infos ->\n 'acc ->\n 'a include_infos * 'acc =\n fun _a { pincl_mod; pincl_loc; pincl_attributes } acc ->\n let pincl_mod, acc = _a pincl_mod acc in\n let pincl_loc, acc = self#location pincl_loc acc in\n let pincl_attributes, acc = self#attributes pincl_attributes acc in\n ({ pincl_mod; pincl_loc; pincl_attributes }, acc)\n\n method include_description\n : include_description -> 'acc -> include_description * 'acc =\n self#include_infos self#module_type\n\n method include_declaration\n : include_declaration -> 'acc -> include_declaration * 'acc =\n self#include_infos self#module_expr\n\n method with_constraint : with_constraint -> 'acc -> with_constraint * 'acc =\n fun x acc ->\n match x with\n | Pwith_type (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#type_declaration b acc in\n (Pwith_type (a, b), acc)\n | Pwith_module (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#longident_loc b acc in\n (Pwith_module (a, b), acc)\n | Pwith_typesubst (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#type_declaration b acc in\n (Pwith_typesubst (a, b), acc)\n | Pwith_modsubst (a, b) ->\n let a, acc = self#longident_loc a acc in\n let b, acc = self#longident_loc b acc in\n (Pwith_modsubst (a, b), acc)\n\n method module_expr : module_expr -> 'acc -> module_expr * 'acc =\n fun { pmod_desc; pmod_loc; pmod_attributes } acc ->\n let pmod_desc, acc = self#module_expr_desc pmod_desc acc in\n let pmod_loc, acc = self#location pmod_loc acc in\n let pmod_attributes, acc = self#attributes pmod_attributes acc in\n ({ pmod_desc; pmod_loc; pmod_attributes }, acc)\n\n method module_expr_desc\n : module_expr_desc -> 'acc -> module_expr_desc * 'acc =\n fun x acc ->\n match x with\n | Pmod_ident a ->\n let a, acc = self#longident_loc a acc in\n (Pmod_ident a, acc)\n | Pmod_structure a ->\n let a, acc = self#structure a acc in\n (Pmod_structure a, acc)\n | Pmod_functor (a, b) ->\n let a, acc = self#functor_parameter a acc in\n let b, acc = self#module_expr b acc in\n (Pmod_functor (a, b), acc)\n | Pmod_apply (a, b) ->\n let a, acc = self#module_expr a acc in\n let b, acc = self#module_expr b acc in\n (Pmod_apply (a, b), acc)\n | Pmod_constraint (a, b) ->\n let a, acc = self#module_expr a acc in\n let b, acc = self#module_type b acc in\n (Pmod_constraint (a, b), acc)\n | Pmod_unpack a ->\n let a, acc = self#expression a acc in\n (Pmod_unpack a, acc)\n | Pmod_extension a ->\n let a, acc = self#extension a acc in\n (Pmod_extension a, acc)\n\n method structure : structure -> 'acc -> structure * 'acc =\n self#list self#structure_item\n\n method structure_item : structure_item -> 'acc -> structure_item * 'acc =\n fun { pstr_desc; pstr_loc } acc ->\n let pstr_desc, acc = self#structure_item_desc pstr_desc acc in\n let pstr_loc, acc = self#location pstr_loc acc in\n ({ pstr_desc; pstr_loc }, acc)\n\n method structure_item_desc\n : structure_item_desc -> 'acc -> structure_item_desc * 'acc =\n fun x acc ->\n match x with\n | Pstr_eval (a, b) ->\n let a, acc = self#expression a acc in\n let b, acc = self#attributes b acc in\n (Pstr_eval (a, b), acc)\n | Pstr_value (a, b) ->\n let a, acc = self#rec_flag a acc in\n let b, acc = self#list self#value_binding b acc in\n (Pstr_value (a, b), acc)\n | Pstr_primitive a ->\n let a, acc = self#value_description a acc in\n (Pstr_primitive a, acc)\n | Pstr_type (a, b) ->\n let a, acc = self#rec_flag a acc in\n let b, acc = self#list self#type_declaration b acc in\n (Pstr_type (a, b), acc)\n | Pstr_typext a ->\n let a, acc = self#type_extension a acc in\n (Pstr_typext a, acc)\n | Pstr_exception a ->\n let a, acc = self#type_exception a acc in\n (Pstr_exception a, acc)\n | Pstr_module a ->\n let a, acc = self#module_binding a acc in\n (Pstr_module a, acc)\n | Pstr_recmodule a ->\n let a, acc = self#list self#module_binding a acc in\n (Pstr_recmodule a, acc)\n | Pstr_modtype a ->\n let a, acc = self#module_type_declaration a acc in\n (Pstr_modtype a, acc)\n | Pstr_open a ->\n let a, acc = self#open_declaration a acc in\n (Pstr_open a, acc)\n | Pstr_class a ->\n let a, acc = self#list self#class_declaration a acc in\n (Pstr_class a, acc)\n | Pstr_class_type a ->\n let a, acc = self#list self#class_type_declaration a acc in\n (Pstr_class_type a, acc)\n | Pstr_include a ->\n let a, acc = self#include_declaration a acc in\n (Pstr_include a, acc)\n | Pstr_attribute a ->\n let a, acc = self#attribute a acc in\n (Pstr_attribute a, acc)\n | Pstr_extension (a, b) ->\n let a, acc = self#extension a acc in\n let b, acc = self#attributes b acc in\n (Pstr_extension (a, b), acc)\n\n method value_binding : value_binding -> 'acc -> value_binding * 'acc =\n fun { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } acc ->\n let pvb_pat, acc = self#pattern pvb_pat acc in\n let pvb_expr, acc = self#expression pvb_expr acc in\n let pvb_attributes, acc = self#attributes pvb_attributes acc in\n let pvb_loc, acc = self#location pvb_loc acc in\n ({ pvb_pat; pvb_expr; pvb_attributes; pvb_loc }, acc)\n\n method module_binding : module_binding -> 'acc -> module_binding * 'acc =\n fun { pmb_name; pmb_expr; pmb_attributes; pmb_loc } acc ->\n let pmb_name, acc = self#loc (self#option self#string) pmb_name acc in\n let pmb_expr, acc = self#module_expr pmb_expr acc in\n let pmb_attributes, acc = self#attributes pmb_attributes acc in\n let pmb_loc, acc = self#location pmb_loc acc in\n ({ pmb_name; pmb_expr; pmb_attributes; pmb_loc }, acc)\n\n method toplevel_phrase : toplevel_phrase -> 'acc -> toplevel_phrase * 'acc =\n fun x acc ->\n match x with\n | Ptop_def a ->\n let a, acc = self#structure a acc in\n (Ptop_def a, acc)\n | Ptop_dir a ->\n let a, acc = self#toplevel_directive a acc in\n (Ptop_dir a, acc)\n\n method toplevel_directive\n : toplevel_directive -> 'acc -> toplevel_directive * 'acc =\n fun { pdir_name; pdir_arg; pdir_loc } acc ->\n let pdir_name, acc = self#loc self#string pdir_name acc in\n let pdir_arg, acc = self#option self#directive_argument pdir_arg acc in\n let pdir_loc, acc = self#location pdir_loc acc in\n ({ pdir_name; pdir_arg; pdir_loc }, acc)\n\n method directive_argument\n : directive_argument -> 'acc -> directive_argument * 'acc =\n fun { pdira_desc; pdira_loc } acc ->\n let pdira_desc, acc = self#directive_argument_desc pdira_desc acc in\n let pdira_loc, acc = self#location pdira_loc acc in\n ({ pdira_desc; pdira_loc }, acc)\n\n method directive_argument_desc\n : directive_argument_desc -> 'acc -> directive_argument_desc * 'acc =\n fun x acc ->\n match x with\n | Pdir_string a ->\n let a, acc = self#string a acc in\n (Pdir_string a, acc)\n | Pdir_int (a, b) ->\n let a, acc = self#string a acc in\n let b, acc = self#option self#char b acc in\n (Pdir_int (a, b), acc)\n | Pdir_ident a ->\n let a, acc = self#longident a acc in\n (Pdir_ident a, acc)\n | Pdir_bool a ->\n let a, acc = self#bool a acc in\n (Pdir_bool a, acc)\n\n method cases : cases -> 'acc -> cases * 'acc = self#list self#case\n end\n\nclass virtual ['ctx] map_with_context =\n object (self)\n method virtual bool : 'ctx -> bool -> bool\n method virtual char : 'ctx -> char -> char\n method virtual int : 'ctx -> int -> int\n method virtual list : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a list -> 'a list\n\n method virtual option\n : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a option -> 'a option\n\n method virtual string : 'ctx -> string -> string\n\n method position : 'ctx -> position -> position =\n fun ctx { pos_fname; pos_lnum; pos_bol; pos_cnum } ->\n let pos_fname = self#string ctx pos_fname in\n let pos_lnum = self#int ctx pos_lnum in\n let pos_bol = self#int ctx pos_bol in\n let pos_cnum = self#int ctx pos_cnum in\n { pos_fname; pos_lnum; pos_bol; pos_cnum }\n\n method location : 'ctx -> location -> location =\n fun ctx { loc_start; loc_end; loc_ghost } ->\n let loc_start = self#position ctx loc_start in\n let loc_end = self#position ctx loc_end in\n let loc_ghost = self#bool ctx loc_ghost in\n { loc_start; loc_end; loc_ghost }\n\n method location_stack : 'ctx -> location_stack -> location_stack =\n self#list self#location\n\n method loc : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a loc -> 'a loc =\n fun _a ctx { txt; loc } ->\n let txt = _a ctx txt in\n let loc = self#location ctx loc in\n { txt; loc }\n\n method longident : 'ctx -> longident -> longident =\n fun ctx x ->\n match x with\n | Lident a ->\n let a = self#string ctx a in\n Lident a\n | Ldot (a, b) ->\n let a = self#longident ctx a in\n let b = self#string ctx b in\n Ldot (a, b)\n | Lapply (a, b) ->\n let a = self#longident ctx a in\n let b = self#longident ctx b in\n Lapply (a, b)\n\n method longident_loc : 'ctx -> longident_loc -> longident_loc =\n self#loc self#longident\n\n method rec_flag : 'ctx -> rec_flag -> rec_flag = fun _ctx x -> x\n\n method direction_flag : 'ctx -> direction_flag -> direction_flag =\n fun _ctx x -> x\n\n method private_flag : 'ctx -> private_flag -> private_flag = fun _ctx x -> x\n method mutable_flag : 'ctx -> mutable_flag -> mutable_flag = fun _ctx x -> x\n method virtual_flag : 'ctx -> virtual_flag -> virtual_flag = fun _ctx x -> x\n\n method override_flag : 'ctx -> override_flag -> override_flag =\n fun _ctx x -> x\n\n method closed_flag : 'ctx -> closed_flag -> closed_flag = fun _ctx x -> x\n method label : 'ctx -> label -> label = self#string\n\n method arg_label : 'ctx -> arg_label -> arg_label =\n fun ctx x ->\n match x with\n | Nolabel -> Nolabel\n | Labelled a ->\n let a = self#string ctx a in\n Labelled a\n | Optional a ->\n let a = self#string ctx a in\n Optional a\n\n method variance : 'ctx -> variance -> variance = fun _ctx x -> x\n method injectivity : 'ctx -> injectivity -> injectivity = fun _ctx x -> x\n\n method constant : 'ctx -> constant -> constant =\n fun ctx x ->\n match x with\n | Pconst_integer (a, b) ->\n let a = self#string ctx a in\n let b = self#option self#char ctx b in\n Pconst_integer (a, b)\n | Pconst_char a ->\n let a = self#char ctx a in\n Pconst_char a\n | Pconst_string (a, b, c) ->\n let a = self#string ctx a in\n let b = self#location ctx b in\n let c = self#option self#string ctx c in\n Pconst_string (a, b, c)\n | Pconst_float (a, b) ->\n let a = self#string ctx a in\n let b = self#option self#char ctx b in\n Pconst_float (a, b)\n\n method attribute : 'ctx -> attribute -> attribute =\n fun ctx { attr_name; attr_payload; attr_loc } ->\n let attr_name = self#loc self#string ctx attr_name in\n let attr_payload = self#payload ctx attr_payload in\n let attr_loc = self#location ctx attr_loc in\n { attr_name; attr_payload; attr_loc }\n\n method extension : 'ctx -> extension -> extension =\n fun ctx (a, b) ->\n let a = self#loc self#string ctx a in\n let b = self#payload ctx b in\n (a, b)\n\n method attributes : 'ctx -> attributes -> attributes =\n self#list self#attribute\n\n method payload : 'ctx -> payload -> payload =\n fun ctx x ->\n match x with\n | PStr a ->\n let a = self#structure ctx a in\n PStr a\n | PSig a ->\n let a = self#signature ctx a in\n PSig a\n | PTyp a ->\n let a = self#core_type ctx a in\n PTyp a\n | PPat (a, b) ->\n let a = self#pattern ctx a in\n let b = self#option self#expression ctx b in\n PPat (a, b)\n\n method core_type : 'ctx -> core_type -> core_type =\n fun ctx { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } ->\n let ptyp_desc = self#core_type_desc ctx ptyp_desc in\n let ptyp_loc = self#location ctx ptyp_loc in\n let ptyp_loc_stack = self#location_stack ctx ptyp_loc_stack in\n let ptyp_attributes = self#attributes ctx ptyp_attributes in\n { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes }\n\n method core_type_desc : 'ctx -> core_type_desc -> core_type_desc =\n fun ctx x ->\n match x with\n | Ptyp_any -> Ptyp_any\n | Ptyp_var a ->\n let a = self#string ctx a in\n Ptyp_var a\n | Ptyp_arrow (a, b, c) ->\n let a = self#arg_label ctx a in\n let b = self#core_type ctx b in\n let c = self#core_type ctx c in\n Ptyp_arrow (a, b, c)\n | Ptyp_tuple a ->\n let a = self#list self#core_type ctx a in\n Ptyp_tuple a\n | Ptyp_constr (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#list self#core_type ctx b in\n Ptyp_constr (a, b)\n | Ptyp_object (a, b) ->\n let a = self#list self#object_field ctx a in\n let b = self#closed_flag ctx b in\n Ptyp_object (a, b)\n | Ptyp_class (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#list self#core_type ctx b in\n Ptyp_class (a, b)\n | Ptyp_alias (a, b) ->\n let a = self#core_type ctx a in\n let b = self#string ctx b in\n Ptyp_alias (a, b)\n | Ptyp_variant (a, b, c) ->\n let a = self#list self#row_field ctx a in\n let b = self#closed_flag ctx b in\n let c = self#option (self#list self#label) ctx c in\n Ptyp_variant (a, b, c)\n | Ptyp_poly (a, b) ->\n let a = self#list (self#loc self#string) ctx a in\n let b = self#core_type ctx b in\n Ptyp_poly (a, b)\n | Ptyp_package a ->\n let a = self#package_type ctx a in\n Ptyp_package a\n | Ptyp_extension a ->\n let a = self#extension ctx a in\n Ptyp_extension a\n\n method package_type : 'ctx -> package_type -> package_type =\n fun ctx (a, b) ->\n let a = self#longident_loc ctx a in\n let b =\n self#list\n (fun ctx (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#core_type ctx b in\n (a, b))\n ctx b\n in\n (a, b)\n\n method row_field : 'ctx -> row_field -> row_field =\n fun ctx { prf_desc; prf_loc; prf_attributes } ->\n let prf_desc = self#row_field_desc ctx prf_desc in\n let prf_loc = self#location ctx prf_loc in\n let prf_attributes = self#attributes ctx prf_attributes in\n { prf_desc; prf_loc; prf_attributes }\n\n method row_field_desc : 'ctx -> row_field_desc -> row_field_desc =\n fun ctx x ->\n match x with\n | Rtag (a, b, c) ->\n let a = self#loc self#label ctx a in\n let b = self#bool ctx b in\n let c = self#list self#core_type ctx c in\n Rtag (a, b, c)\n | Rinherit a ->\n let a = self#core_type ctx a in\n Rinherit a\n\n method object_field : 'ctx -> object_field -> object_field =\n fun ctx { pof_desc; pof_loc; pof_attributes } ->\n let pof_desc = self#object_field_desc ctx pof_desc in\n let pof_loc = self#location ctx pof_loc in\n let pof_attributes = self#attributes ctx pof_attributes in\n { pof_desc; pof_loc; pof_attributes }\n\n method object_field_desc : 'ctx -> object_field_desc -> object_field_desc =\n fun ctx x ->\n match x with\n | Otag (a, b) ->\n let a = self#loc self#label ctx a in\n let b = self#core_type ctx b in\n Otag (a, b)\n | Oinherit a ->\n let a = self#core_type ctx a in\n Oinherit a\n\n method pattern : 'ctx -> pattern -> pattern =\n fun ctx { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } ->\n let ppat_desc = self#pattern_desc ctx ppat_desc in\n let ppat_loc = self#location ctx ppat_loc in\n let ppat_loc_stack = self#location_stack ctx ppat_loc_stack in\n let ppat_attributes = self#attributes ctx ppat_attributes in\n { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes }\n\n method pattern_desc : 'ctx -> pattern_desc -> pattern_desc =\n fun ctx x ->\n match x with\n | Ppat_any -> Ppat_any\n | Ppat_var a ->\n let a = self#loc self#string ctx a in\n Ppat_var a\n | Ppat_alias (a, b) ->\n let a = self#pattern ctx a in\n let b = self#loc self#string ctx b in\n Ppat_alias (a, b)\n | Ppat_constant a ->\n let a = self#constant ctx a in\n Ppat_constant a\n | Ppat_interval (a, b) ->\n let a = self#constant ctx a in\n let b = self#constant ctx b in\n Ppat_interval (a, b)\n | Ppat_tuple a ->\n let a = self#list self#pattern ctx a in\n Ppat_tuple a\n | Ppat_construct (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#option self#pattern ctx b in\n Ppat_construct (a, b)\n | Ppat_variant (a, b) ->\n let a = self#label ctx a in\n let b = self#option self#pattern ctx b in\n Ppat_variant (a, b)\n | Ppat_record (a, b) ->\n let a =\n self#list\n (fun ctx (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#pattern ctx b in\n (a, b))\n ctx a\n in\n let b = self#closed_flag ctx b in\n Ppat_record (a, b)\n | Ppat_array a ->\n let a = self#list self#pattern ctx a in\n Ppat_array a\n | Ppat_or (a, b) ->\n let a = self#pattern ctx a in\n let b = self#pattern ctx b in\n Ppat_or (a, b)\n | Ppat_constraint (a, b) ->\n let a = self#pattern ctx a in\n let b = self#core_type ctx b in\n Ppat_constraint (a, b)\n | Ppat_type a ->\n let a = self#longident_loc ctx a in\n Ppat_type a\n | Ppat_lazy a ->\n let a = self#pattern ctx a in\n Ppat_lazy a\n | Ppat_unpack a ->\n let a = self#loc (self#option self#string) ctx a in\n Ppat_unpack a\n | Ppat_exception a ->\n let a = self#pattern ctx a in\n Ppat_exception a\n | Ppat_extension a ->\n let a = self#extension ctx a in\n Ppat_extension a\n | Ppat_open (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#pattern ctx b in\n Ppat_open (a, b)\n\n method expression : 'ctx -> expression -> expression =\n fun ctx { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } ->\n let pexp_desc = self#expression_desc ctx pexp_desc in\n let pexp_loc = self#location ctx pexp_loc in\n let pexp_loc_stack = self#location_stack ctx pexp_loc_stack in\n let pexp_attributes = self#attributes ctx pexp_attributes in\n { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes }\n\n method expression_desc : 'ctx -> expression_desc -> expression_desc =\n fun ctx x ->\n match x with\n | Pexp_ident a ->\n let a = self#longident_loc ctx a in\n Pexp_ident a\n | Pexp_constant a ->\n let a = self#constant ctx a in\n Pexp_constant a\n | Pexp_let (a, b, c) ->\n let a = self#rec_flag ctx a in\n let b = self#list self#value_binding ctx b in\n let c = self#expression ctx c in\n Pexp_let (a, b, c)\n | Pexp_function a ->\n let a = self#cases ctx a in\n Pexp_function a\n | Pexp_fun (a, b, c, d) ->\n let a = self#arg_label ctx a in\n let b = self#option self#expression ctx b in\n let c = self#pattern ctx c in\n let d = self#expression ctx d in\n Pexp_fun (a, b, c, d)\n | Pexp_apply (a, b) ->\n let a = self#expression ctx a in\n let b =\n self#list\n (fun ctx (a, b) ->\n let a = self#arg_label ctx a in\n let b = self#expression ctx b in\n (a, b))\n ctx b\n in\n Pexp_apply (a, b)\n | Pexp_match (a, b) ->\n let a = self#expression ctx a in\n let b = self#cases ctx b in\n Pexp_match (a, b)\n | Pexp_try (a, b) ->\n let a = self#expression ctx a in\n let b = self#cases ctx b in\n Pexp_try (a, b)\n | Pexp_tuple a ->\n let a = self#list self#expression ctx a in\n Pexp_tuple a\n | Pexp_construct (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#option self#expression ctx b in\n Pexp_construct (a, b)\n | Pexp_variant (a, b) ->\n let a = self#label ctx a in\n let b = self#option self#expression ctx b in\n Pexp_variant (a, b)\n | Pexp_record (a, b) ->\n let a =\n self#list\n (fun ctx (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#expression ctx b in\n (a, b))\n ctx a\n in\n let b = self#option self#expression ctx b in\n Pexp_record (a, b)\n | Pexp_field (a, b) ->\n let a = self#expression ctx a in\n let b = self#longident_loc ctx b in\n Pexp_field (a, b)\n | Pexp_setfield (a, b, c) ->\n let a = self#expression ctx a in\n let b = self#longident_loc ctx b in\n let c = self#expression ctx c in\n Pexp_setfield (a, b, c)\n | Pexp_array a ->\n let a = self#list self#expression ctx a in\n Pexp_array a\n | Pexp_ifthenelse (a, b, c) ->\n let a = self#expression ctx a in\n let b = self#expression ctx b in\n let c = self#option self#expression ctx c in\n Pexp_ifthenelse (a, b, c)\n | Pexp_sequence (a, b) ->\n let a = self#expression ctx a in\n let b = self#expression ctx b in\n Pexp_sequence (a, b)\n | Pexp_while (a, b) ->\n let a = self#expression ctx a in\n let b = self#expression ctx b in\n Pexp_while (a, b)\n | Pexp_for (a, b, c, d, e) ->\n let a = self#pattern ctx a in\n let b = self#expression ctx b in\n let c = self#expression ctx c in\n let d = self#direction_flag ctx d in\n let e = self#expression ctx e in\n Pexp_for (a, b, c, d, e)\n | Pexp_constraint (a, b) ->\n let a = self#expression ctx a in\n let b = self#core_type ctx b in\n Pexp_constraint (a, b)\n | Pexp_coerce (a, b, c) ->\n let a = self#expression ctx a in\n let b = self#option self#core_type ctx b in\n let c = self#core_type ctx c in\n Pexp_coerce (a, b, c)\n | Pexp_send (a, b) ->\n let a = self#expression ctx a in\n let b = self#loc self#label ctx b in\n Pexp_send (a, b)\n | Pexp_new a ->\n let a = self#longident_loc ctx a in\n Pexp_new a\n | Pexp_setinstvar (a, b) ->\n let a = self#loc self#label ctx a in\n let b = self#expression ctx b in\n Pexp_setinstvar (a, b)\n | Pexp_override a ->\n let a =\n self#list\n (fun ctx (a, b) ->\n let a = self#loc self#label ctx a in\n let b = self#expression ctx b in\n (a, b))\n ctx a\n in\n Pexp_override a\n | Pexp_letmodule (a, b, c) ->\n let a = self#loc (self#option self#string) ctx a in\n let b = self#module_expr ctx b in\n let c = self#expression ctx c in\n Pexp_letmodule (a, b, c)\n | Pexp_letexception (a, b) ->\n let a = self#extension_constructor ctx a in\n let b = self#expression ctx b in\n Pexp_letexception (a, b)\n | Pexp_assert a ->\n let a = self#expression ctx a in\n Pexp_assert a\n | Pexp_lazy a ->\n let a = self#expression ctx a in\n Pexp_lazy a\n | Pexp_poly (a, b) ->\n let a = self#expression ctx a in\n let b = self#option self#core_type ctx b in\n Pexp_poly (a, b)\n | Pexp_object a ->\n let a = self#class_structure ctx a in\n Pexp_object a\n | Pexp_newtype (a, b) ->\n let a = self#loc self#string ctx a in\n let b = self#expression ctx b in\n Pexp_newtype (a, b)\n | Pexp_pack a ->\n let a = self#module_expr ctx a in\n Pexp_pack a\n | Pexp_open (a, b) ->\n let a = self#open_declaration ctx a in\n let b = self#expression ctx b in\n Pexp_open (a, b)\n | Pexp_letop a ->\n let a = self#letop ctx a in\n Pexp_letop a\n | Pexp_extension a ->\n let a = self#extension ctx a in\n Pexp_extension a\n | Pexp_unreachable -> Pexp_unreachable\n\n method case : 'ctx -> case -> case =\n fun ctx { pc_lhs; pc_guard; pc_rhs } ->\n let pc_lhs = self#pattern ctx pc_lhs in\n let pc_guard = self#option self#expression ctx pc_guard in\n let pc_rhs = self#expression ctx pc_rhs in\n { pc_lhs; pc_guard; pc_rhs }\n\n method letop : 'ctx -> letop -> letop =\n fun ctx { let_; ands; body } ->\n let let_ = self#binding_op ctx let_ in\n let ands = self#list self#binding_op ctx ands in\n let body = self#expression ctx body in\n { let_; ands; body }\n\n method binding_op : 'ctx -> binding_op -> binding_op =\n fun ctx { pbop_op; pbop_pat; pbop_exp; pbop_loc } ->\n let pbop_op = self#loc self#string ctx pbop_op in\n let pbop_pat = self#pattern ctx pbop_pat in\n let pbop_exp = self#expression ctx pbop_exp in\n let pbop_loc = self#location ctx pbop_loc in\n { pbop_op; pbop_pat; pbop_exp; pbop_loc }\n\n method value_description : 'ctx -> value_description -> value_description =\n fun ctx { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } ->\n let pval_name = self#loc self#string ctx pval_name in\n let pval_type = self#core_type ctx pval_type in\n let pval_prim = self#list self#string ctx pval_prim in\n let pval_attributes = self#attributes ctx pval_attributes in\n let pval_loc = self#location ctx pval_loc in\n { pval_name; pval_type; pval_prim; pval_attributes; pval_loc }\n\n method type_declaration : 'ctx -> type_declaration -> type_declaration =\n fun ctx\n {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } ->\n let ptype_name = self#loc self#string ctx ptype_name in\n let ptype_params =\n self#list\n (fun ctx (a, b) ->\n let a = self#core_type ctx a in\n let b =\n (fun ctx (a, b) ->\n let a = self#variance ctx a in\n let b = self#injectivity ctx b in\n (a, b))\n ctx b\n in\n (a, b))\n ctx ptype_params\n in\n let ptype_cstrs =\n self#list\n (fun ctx (a, b, c) ->\n let a = self#core_type ctx a in\n let b = self#core_type ctx b in\n let c = self#location ctx c in\n (a, b, c))\n ctx ptype_cstrs\n in\n let ptype_kind = self#type_kind ctx ptype_kind in\n let ptype_private = self#private_flag ctx ptype_private in\n let ptype_manifest = self#option self#core_type ctx ptype_manifest in\n let ptype_attributes = self#attributes ctx ptype_attributes in\n let ptype_loc = self#location ctx ptype_loc in\n {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n }\n\n method type_kind : 'ctx -> type_kind -> type_kind =\n fun ctx x ->\n match x with\n | Ptype_abstract -> Ptype_abstract\n | Ptype_variant a ->\n let a = self#list self#constructor_declaration ctx a in\n Ptype_variant a\n | Ptype_record a ->\n let a = self#list self#label_declaration ctx a in\n Ptype_record a\n | Ptype_open -> Ptype_open\n\n method label_declaration : 'ctx -> label_declaration -> label_declaration =\n fun ctx { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } ->\n let pld_name = self#loc self#string ctx pld_name in\n let pld_mutable = self#mutable_flag ctx pld_mutable in\n let pld_type = self#core_type ctx pld_type in\n let pld_loc = self#location ctx pld_loc in\n let pld_attributes = self#attributes ctx pld_attributes in\n { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes }\n\n method constructor_declaration\n : 'ctx -> constructor_declaration -> constructor_declaration =\n fun ctx { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } ->\n let pcd_name = self#loc self#string ctx pcd_name in\n let pcd_args = self#constructor_arguments ctx pcd_args in\n let pcd_res = self#option self#core_type ctx pcd_res in\n let pcd_loc = self#location ctx pcd_loc in\n let pcd_attributes = self#attributes ctx pcd_attributes in\n { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes }\n\n method constructor_arguments\n : 'ctx -> constructor_arguments -> constructor_arguments =\n fun ctx x ->\n match x with\n | Pcstr_tuple a ->\n let a = self#list self#core_type ctx a in\n Pcstr_tuple a\n | Pcstr_record a ->\n let a = self#list self#label_declaration ctx a in\n Pcstr_record a\n\n method type_extension : 'ctx -> type_extension -> type_extension =\n fun ctx\n {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } ->\n let ptyext_path = self#longident_loc ctx ptyext_path in\n let ptyext_params =\n self#list\n (fun ctx (a, b) ->\n let a = self#core_type ctx a in\n let b =\n (fun ctx (a, b) ->\n let a = self#variance ctx a in\n let b = self#injectivity ctx b in\n (a, b))\n ctx b\n in\n (a, b))\n ctx ptyext_params\n in\n let ptyext_constructors =\n self#list self#extension_constructor ctx ptyext_constructors\n in\n let ptyext_private = self#private_flag ctx ptyext_private in\n let ptyext_loc = self#location ctx ptyext_loc in\n let ptyext_attributes = self#attributes ctx ptyext_attributes in\n {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n }\n\n method extension_constructor\n : 'ctx -> extension_constructor -> extension_constructor =\n fun ctx { pext_name; pext_kind; pext_loc; pext_attributes } ->\n let pext_name = self#loc self#string ctx pext_name in\n let pext_kind = self#extension_constructor_kind ctx pext_kind in\n let pext_loc = self#location ctx pext_loc in\n let pext_attributes = self#attributes ctx pext_attributes in\n { pext_name; pext_kind; pext_loc; pext_attributes }\n\n method type_exception : 'ctx -> type_exception -> type_exception =\n fun ctx { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } ->\n let ptyexn_constructor =\n self#extension_constructor ctx ptyexn_constructor\n in\n let ptyexn_loc = self#location ctx ptyexn_loc in\n let ptyexn_attributes = self#attributes ctx ptyexn_attributes in\n { ptyexn_constructor; ptyexn_loc; ptyexn_attributes }\n\n method extension_constructor_kind\n : 'ctx -> extension_constructor_kind -> extension_constructor_kind =\n fun ctx x ->\n match x with\n | Pext_decl (a, b) ->\n let a = self#constructor_arguments ctx a in\n let b = self#option self#core_type ctx b in\n Pext_decl (a, b)\n | Pext_rebind a ->\n let a = self#longident_loc ctx a in\n Pext_rebind a\n\n method class_type : 'ctx -> class_type -> class_type =\n fun ctx { pcty_desc; pcty_loc; pcty_attributes } ->\n let pcty_desc = self#class_type_desc ctx pcty_desc in\n let pcty_loc = self#location ctx pcty_loc in\n let pcty_attributes = self#attributes ctx pcty_attributes in\n { pcty_desc; pcty_loc; pcty_attributes }\n\n method class_type_desc : 'ctx -> class_type_desc -> class_type_desc =\n fun ctx x ->\n match x with\n | Pcty_constr (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#list self#core_type ctx b in\n Pcty_constr (a, b)\n | Pcty_signature a ->\n let a = self#class_signature ctx a in\n Pcty_signature a\n | Pcty_arrow (a, b, c) ->\n let a = self#arg_label ctx a in\n let b = self#core_type ctx b in\n let c = self#class_type ctx c in\n Pcty_arrow (a, b, c)\n | Pcty_extension a ->\n let a = self#extension ctx a in\n Pcty_extension a\n | Pcty_open (a, b) ->\n let a = self#open_description ctx a in\n let b = self#class_type ctx b in\n Pcty_open (a, b)\n\n method class_signature : 'ctx -> class_signature -> class_signature =\n fun ctx { pcsig_self; pcsig_fields } ->\n let pcsig_self = self#core_type ctx pcsig_self in\n let pcsig_fields = self#list self#class_type_field ctx pcsig_fields in\n { pcsig_self; pcsig_fields }\n\n method class_type_field : 'ctx -> class_type_field -> class_type_field =\n fun ctx { pctf_desc; pctf_loc; pctf_attributes } ->\n let pctf_desc = self#class_type_field_desc ctx pctf_desc in\n let pctf_loc = self#location ctx pctf_loc in\n let pctf_attributes = self#attributes ctx pctf_attributes in\n { pctf_desc; pctf_loc; pctf_attributes }\n\n method class_type_field_desc\n : 'ctx -> class_type_field_desc -> class_type_field_desc =\n fun ctx x ->\n match x with\n | Pctf_inherit a ->\n let a = self#class_type ctx a in\n Pctf_inherit a\n | Pctf_val a ->\n let a =\n (fun ctx (a, b, c, d) ->\n let a = self#loc self#label ctx a in\n let b = self#mutable_flag ctx b in\n let c = self#virtual_flag ctx c in\n let d = self#core_type ctx d in\n (a, b, c, d))\n ctx a\n in\n Pctf_val a\n | Pctf_method a ->\n let a =\n (fun ctx (a, b, c, d) ->\n let a = self#loc self#label ctx a in\n let b = self#private_flag ctx b in\n let c = self#virtual_flag ctx c in\n let d = self#core_type ctx d in\n (a, b, c, d))\n ctx a\n in\n Pctf_method a\n | Pctf_constraint a ->\n let a =\n (fun ctx (a, b) ->\n let a = self#core_type ctx a in\n let b = self#core_type ctx b in\n (a, b))\n ctx a\n in\n Pctf_constraint a\n | Pctf_attribute a ->\n let a = self#attribute ctx a in\n Pctf_attribute a\n | Pctf_extension a ->\n let a = self#extension ctx a in\n Pctf_extension a\n\n method class_infos\n : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a class_infos -> 'a class_infos =\n fun _a ctx\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes } ->\n let pci_virt = self#virtual_flag ctx pci_virt in\n let pci_params =\n self#list\n (fun ctx (a, b) ->\n let a = self#core_type ctx a in\n let b =\n (fun ctx (a, b) ->\n let a = self#variance ctx a in\n let b = self#injectivity ctx b in\n (a, b))\n ctx b\n in\n (a, b))\n ctx pci_params\n in\n let pci_name = self#loc self#string ctx pci_name in\n let pci_expr = _a ctx pci_expr in\n let pci_loc = self#location ctx pci_loc in\n let pci_attributes = self#attributes ctx pci_attributes in\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes }\n\n method class_description : 'ctx -> class_description -> class_description =\n self#class_infos self#class_type\n\n method class_type_declaration\n : 'ctx -> class_type_declaration -> class_type_declaration =\n self#class_infos self#class_type\n\n method class_expr : 'ctx -> class_expr -> class_expr =\n fun ctx { pcl_desc; pcl_loc; pcl_attributes } ->\n let pcl_desc = self#class_expr_desc ctx pcl_desc in\n let pcl_loc = self#location ctx pcl_loc in\n let pcl_attributes = self#attributes ctx pcl_attributes in\n { pcl_desc; pcl_loc; pcl_attributes }\n\n method class_expr_desc : 'ctx -> class_expr_desc -> class_expr_desc =\n fun ctx x ->\n match x with\n | Pcl_constr (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#list self#core_type ctx b in\n Pcl_constr (a, b)\n | Pcl_structure a ->\n let a = self#class_structure ctx a in\n Pcl_structure a\n | Pcl_fun (a, b, c, d) ->\n let a = self#arg_label ctx a in\n let b = self#option self#expression ctx b in\n let c = self#pattern ctx c in\n let d = self#class_expr ctx d in\n Pcl_fun (a, b, c, d)\n | Pcl_apply (a, b) ->\n let a = self#class_expr ctx a in\n let b =\n self#list\n (fun ctx (a, b) ->\n let a = self#arg_label ctx a in\n let b = self#expression ctx b in\n (a, b))\n ctx b\n in\n Pcl_apply (a, b)\n | Pcl_let (a, b, c) ->\n let a = self#rec_flag ctx a in\n let b = self#list self#value_binding ctx b in\n let c = self#class_expr ctx c in\n Pcl_let (a, b, c)\n | Pcl_constraint (a, b) ->\n let a = self#class_expr ctx a in\n let b = self#class_type ctx b in\n Pcl_constraint (a, b)\n | Pcl_extension a ->\n let a = self#extension ctx a in\n Pcl_extension a\n | Pcl_open (a, b) ->\n let a = self#open_description ctx a in\n let b = self#class_expr ctx b in\n Pcl_open (a, b)\n\n method class_structure : 'ctx -> class_structure -> class_structure =\n fun ctx { pcstr_self; pcstr_fields } ->\n let pcstr_self = self#pattern ctx pcstr_self in\n let pcstr_fields = self#list self#class_field ctx pcstr_fields in\n { pcstr_self; pcstr_fields }\n\n method class_field : 'ctx -> class_field -> class_field =\n fun ctx { pcf_desc; pcf_loc; pcf_attributes } ->\n let pcf_desc = self#class_field_desc ctx pcf_desc in\n let pcf_loc = self#location ctx pcf_loc in\n let pcf_attributes = self#attributes ctx pcf_attributes in\n { pcf_desc; pcf_loc; pcf_attributes }\n\n method class_field_desc : 'ctx -> class_field_desc -> class_field_desc =\n fun ctx x ->\n match x with\n | Pcf_inherit (a, b, c) ->\n let a = self#override_flag ctx a in\n let b = self#class_expr ctx b in\n let c = self#option (self#loc self#string) ctx c in\n Pcf_inherit (a, b, c)\n | Pcf_val a ->\n let a =\n (fun ctx (a, b, c) ->\n let a = self#loc self#label ctx a in\n let b = self#mutable_flag ctx b in\n let c = self#class_field_kind ctx c in\n (a, b, c))\n ctx a\n in\n Pcf_val a\n | Pcf_method a ->\n let a =\n (fun ctx (a, b, c) ->\n let a = self#loc self#label ctx a in\n let b = self#private_flag ctx b in\n let c = self#class_field_kind ctx c in\n (a, b, c))\n ctx a\n in\n Pcf_method a\n | Pcf_constraint a ->\n let a =\n (fun ctx (a, b) ->\n let a = self#core_type ctx a in\n let b = self#core_type ctx b in\n (a, b))\n ctx a\n in\n Pcf_constraint a\n | Pcf_initializer a ->\n let a = self#expression ctx a in\n Pcf_initializer a\n | Pcf_attribute a ->\n let a = self#attribute ctx a in\n Pcf_attribute a\n | Pcf_extension a ->\n let a = self#extension ctx a in\n Pcf_extension a\n\n method class_field_kind : 'ctx -> class_field_kind -> class_field_kind =\n fun ctx x ->\n match x with\n | Cfk_virtual a ->\n let a = self#core_type ctx a in\n Cfk_virtual a\n | Cfk_concrete (a, b) ->\n let a = self#override_flag ctx a in\n let b = self#expression ctx b in\n Cfk_concrete (a, b)\n\n method class_declaration : 'ctx -> class_declaration -> class_declaration =\n self#class_infos self#class_expr\n\n method module_type : 'ctx -> module_type -> module_type =\n fun ctx { pmty_desc; pmty_loc; pmty_attributes } ->\n let pmty_desc = self#module_type_desc ctx pmty_desc in\n let pmty_loc = self#location ctx pmty_loc in\n let pmty_attributes = self#attributes ctx pmty_attributes in\n { pmty_desc; pmty_loc; pmty_attributes }\n\n method module_type_desc : 'ctx -> module_type_desc -> module_type_desc =\n fun ctx x ->\n match x with\n | Pmty_ident a ->\n let a = self#longident_loc ctx a in\n Pmty_ident a\n | Pmty_signature a ->\n let a = self#signature ctx a in\n Pmty_signature a\n | Pmty_functor (a, b) ->\n let a = self#functor_parameter ctx a in\n let b = self#module_type ctx b in\n Pmty_functor (a, b)\n | Pmty_with (a, b) ->\n let a = self#module_type ctx a in\n let b = self#list self#with_constraint ctx b in\n Pmty_with (a, b)\n | Pmty_typeof a ->\n let a = self#module_expr ctx a in\n Pmty_typeof a\n | Pmty_extension a ->\n let a = self#extension ctx a in\n Pmty_extension a\n | Pmty_alias a ->\n let a = self#longident_loc ctx a in\n Pmty_alias a\n\n method functor_parameter : 'ctx -> functor_parameter -> functor_parameter =\n fun ctx x ->\n match x with\n | Unit -> Unit\n | Named (a, b) ->\n let a = self#loc (self#option self#string) ctx a in\n let b = self#module_type ctx b in\n Named (a, b)\n\n method signature : 'ctx -> signature -> signature =\n self#list self#signature_item\n\n method signature_item : 'ctx -> signature_item -> signature_item =\n fun ctx { psig_desc; psig_loc } ->\n let psig_desc = self#signature_item_desc ctx psig_desc in\n let psig_loc = self#location ctx psig_loc in\n { psig_desc; psig_loc }\n\n method signature_item_desc\n : 'ctx -> signature_item_desc -> signature_item_desc =\n fun ctx x ->\n match x with\n | Psig_value a ->\n let a = self#value_description ctx a in\n Psig_value a\n | Psig_type (a, b) ->\n let a = self#rec_flag ctx a in\n let b = self#list self#type_declaration ctx b in\n Psig_type (a, b)\n | Psig_typesubst a ->\n let a = self#list self#type_declaration ctx a in\n Psig_typesubst a\n | Psig_typext a ->\n let a = self#type_extension ctx a in\n Psig_typext a\n | Psig_exception a ->\n let a = self#type_exception ctx a in\n Psig_exception a\n | Psig_module a ->\n let a = self#module_declaration ctx a in\n Psig_module a\n | Psig_modsubst a ->\n let a = self#module_substitution ctx a in\n Psig_modsubst a\n | Psig_recmodule a ->\n let a = self#list self#module_declaration ctx a in\n Psig_recmodule a\n | Psig_modtype a ->\n let a = self#module_type_declaration ctx a in\n Psig_modtype a\n | Psig_open a ->\n let a = self#open_description ctx a in\n Psig_open a\n | Psig_include a ->\n let a = self#include_description ctx a in\n Psig_include a\n | Psig_class a ->\n let a = self#list self#class_description ctx a in\n Psig_class a\n | Psig_class_type a ->\n let a = self#list self#class_type_declaration ctx a in\n Psig_class_type a\n | Psig_attribute a ->\n let a = self#attribute ctx a in\n Psig_attribute a\n | Psig_extension (a, b) ->\n let a = self#extension ctx a in\n let b = self#attributes ctx b in\n Psig_extension (a, b)\n\n method module_declaration : 'ctx -> module_declaration -> module_declaration\n =\n fun ctx { pmd_name; pmd_type; pmd_attributes; pmd_loc } ->\n let pmd_name = self#loc (self#option self#string) ctx pmd_name in\n let pmd_type = self#module_type ctx pmd_type in\n let pmd_attributes = self#attributes ctx pmd_attributes in\n let pmd_loc = self#location ctx pmd_loc in\n { pmd_name; pmd_type; pmd_attributes; pmd_loc }\n\n method module_substitution\n : 'ctx -> module_substitution -> module_substitution =\n fun ctx { pms_name; pms_manifest; pms_attributes; pms_loc } ->\n let pms_name = self#loc self#string ctx pms_name in\n let pms_manifest = self#longident_loc ctx pms_manifest in\n let pms_attributes = self#attributes ctx pms_attributes in\n let pms_loc = self#location ctx pms_loc in\n { pms_name; pms_manifest; pms_attributes; pms_loc }\n\n method module_type_declaration\n : 'ctx -> module_type_declaration -> module_type_declaration =\n fun ctx { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } ->\n let pmtd_name = self#loc self#string ctx pmtd_name in\n let pmtd_type = self#option self#module_type ctx pmtd_type in\n let pmtd_attributes = self#attributes ctx pmtd_attributes in\n let pmtd_loc = self#location ctx pmtd_loc in\n { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc }\n\n method open_infos\n : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a open_infos -> 'a open_infos =\n fun _a ctx { popen_expr; popen_override; popen_loc; popen_attributes } ->\n let popen_expr = _a ctx popen_expr in\n let popen_override = self#override_flag ctx popen_override in\n let popen_loc = self#location ctx popen_loc in\n let popen_attributes = self#attributes ctx popen_attributes in\n { popen_expr; popen_override; popen_loc; popen_attributes }\n\n method open_description : 'ctx -> open_description -> open_description =\n self#open_infos self#longident_loc\n\n method open_declaration : 'ctx -> open_declaration -> open_declaration =\n self#open_infos self#module_expr\n\n method include_infos\n : 'a. ('ctx -> 'a -> 'a) -> 'ctx -> 'a include_infos -> 'a include_infos\n =\n fun _a ctx { pincl_mod; pincl_loc; pincl_attributes } ->\n let pincl_mod = _a ctx pincl_mod in\n let pincl_loc = self#location ctx pincl_loc in\n let pincl_attributes = self#attributes ctx pincl_attributes in\n { pincl_mod; pincl_loc; pincl_attributes }\n\n method include_description\n : 'ctx -> include_description -> include_description =\n self#include_infos self#module_type\n\n method include_declaration\n : 'ctx -> include_declaration -> include_declaration =\n self#include_infos self#module_expr\n\n method with_constraint : 'ctx -> with_constraint -> with_constraint =\n fun ctx x ->\n match x with\n | Pwith_type (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#type_declaration ctx b in\n Pwith_type (a, b)\n | Pwith_module (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#longident_loc ctx b in\n Pwith_module (a, b)\n | Pwith_typesubst (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#type_declaration ctx b in\n Pwith_typesubst (a, b)\n | Pwith_modsubst (a, b) ->\n let a = self#longident_loc ctx a in\n let b = self#longident_loc ctx b in\n Pwith_modsubst (a, b)\n\n method module_expr : 'ctx -> module_expr -> module_expr =\n fun ctx { pmod_desc; pmod_loc; pmod_attributes } ->\n let pmod_desc = self#module_expr_desc ctx pmod_desc in\n let pmod_loc = self#location ctx pmod_loc in\n let pmod_attributes = self#attributes ctx pmod_attributes in\n { pmod_desc; pmod_loc; pmod_attributes }\n\n method module_expr_desc : 'ctx -> module_expr_desc -> module_expr_desc =\n fun ctx x ->\n match x with\n | Pmod_ident a ->\n let a = self#longident_loc ctx a in\n Pmod_ident a\n | Pmod_structure a ->\n let a = self#structure ctx a in\n Pmod_structure a\n | Pmod_functor (a, b) ->\n let a = self#functor_parameter ctx a in\n let b = self#module_expr ctx b in\n Pmod_functor (a, b)\n | Pmod_apply (a, b) ->\n let a = self#module_expr ctx a in\n let b = self#module_expr ctx b in\n Pmod_apply (a, b)\n | Pmod_constraint (a, b) ->\n let a = self#module_expr ctx a in\n let b = self#module_type ctx b in\n Pmod_constraint (a, b)\n | Pmod_unpack a ->\n let a = self#expression ctx a in\n Pmod_unpack a\n | Pmod_extension a ->\n let a = self#extension ctx a in\n Pmod_extension a\n\n method structure : 'ctx -> structure -> structure =\n self#list self#structure_item\n\n method structure_item : 'ctx -> structure_item -> structure_item =\n fun ctx { pstr_desc; pstr_loc } ->\n let pstr_desc = self#structure_item_desc ctx pstr_desc in\n let pstr_loc = self#location ctx pstr_loc in\n { pstr_desc; pstr_loc }\n\n method structure_item_desc\n : 'ctx -> structure_item_desc -> structure_item_desc =\n fun ctx x ->\n match x with\n | Pstr_eval (a, b) ->\n let a = self#expression ctx a in\n let b = self#attributes ctx b in\n Pstr_eval (a, b)\n | Pstr_value (a, b) ->\n let a = self#rec_flag ctx a in\n let b = self#list self#value_binding ctx b in\n Pstr_value (a, b)\n | Pstr_primitive a ->\n let a = self#value_description ctx a in\n Pstr_primitive a\n | Pstr_type (a, b) ->\n let a = self#rec_flag ctx a in\n let b = self#list self#type_declaration ctx b in\n Pstr_type (a, b)\n | Pstr_typext a ->\n let a = self#type_extension ctx a in\n Pstr_typext a\n | Pstr_exception a ->\n let a = self#type_exception ctx a in\n Pstr_exception a\n | Pstr_module a ->\n let a = self#module_binding ctx a in\n Pstr_module a\n | Pstr_recmodule a ->\n let a = self#list self#module_binding ctx a in\n Pstr_recmodule a\n | Pstr_modtype a ->\n let a = self#module_type_declaration ctx a in\n Pstr_modtype a\n | Pstr_open a ->\n let a = self#open_declaration ctx a in\n Pstr_open a\n | Pstr_class a ->\n let a = self#list self#class_declaration ctx a in\n Pstr_class a\n | Pstr_class_type a ->\n let a = self#list self#class_type_declaration ctx a in\n Pstr_class_type a\n | Pstr_include a ->\n let a = self#include_declaration ctx a in\n Pstr_include a\n | Pstr_attribute a ->\n let a = self#attribute ctx a in\n Pstr_attribute a\n | Pstr_extension (a, b) ->\n let a = self#extension ctx a in\n let b = self#attributes ctx b in\n Pstr_extension (a, b)\n\n method value_binding : 'ctx -> value_binding -> value_binding =\n fun ctx { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } ->\n let pvb_pat = self#pattern ctx pvb_pat in\n let pvb_expr = self#expression ctx pvb_expr in\n let pvb_attributes = self#attributes ctx pvb_attributes in\n let pvb_loc = self#location ctx pvb_loc in\n { pvb_pat; pvb_expr; pvb_attributes; pvb_loc }\n\n method module_binding : 'ctx -> module_binding -> module_binding =\n fun ctx { pmb_name; pmb_expr; pmb_attributes; pmb_loc } ->\n let pmb_name = self#loc (self#option self#string) ctx pmb_name in\n let pmb_expr = self#module_expr ctx pmb_expr in\n let pmb_attributes = self#attributes ctx pmb_attributes in\n let pmb_loc = self#location ctx pmb_loc in\n { pmb_name; pmb_expr; pmb_attributes; pmb_loc }\n\n method toplevel_phrase : 'ctx -> toplevel_phrase -> toplevel_phrase =\n fun ctx x ->\n match x with\n | Ptop_def a ->\n let a = self#structure ctx a in\n Ptop_def a\n | Ptop_dir a ->\n let a = self#toplevel_directive ctx a in\n Ptop_dir a\n\n method toplevel_directive : 'ctx -> toplevel_directive -> toplevel_directive\n =\n fun ctx { pdir_name; pdir_arg; pdir_loc } ->\n let pdir_name = self#loc self#string ctx pdir_name in\n let pdir_arg = self#option self#directive_argument ctx pdir_arg in\n let pdir_loc = self#location ctx pdir_loc in\n { pdir_name; pdir_arg; pdir_loc }\n\n method directive_argument : 'ctx -> directive_argument -> directive_argument\n =\n fun ctx { pdira_desc; pdira_loc } ->\n let pdira_desc = self#directive_argument_desc ctx pdira_desc in\n let pdira_loc = self#location ctx pdira_loc in\n { pdira_desc; pdira_loc }\n\n method directive_argument_desc\n : 'ctx -> directive_argument_desc -> directive_argument_desc =\n fun ctx x ->\n match x with\n | Pdir_string a ->\n let a = self#string ctx a in\n Pdir_string a\n | Pdir_int (a, b) ->\n let a = self#string ctx a in\n let b = self#option self#char ctx b in\n Pdir_int (a, b)\n | Pdir_ident a ->\n let a = self#longident ctx a in\n Pdir_ident a\n | Pdir_bool a ->\n let a = self#bool ctx a in\n Pdir_bool a\n\n method cases : 'ctx -> cases -> cases = self#list self#case\n end\n\nclass virtual ['res] lift =\n object (self)\n method virtual record : (string * 'res) list -> 'res\n method virtual constr : string -> 'res list -> 'res\n method virtual tuple : 'res list -> 'res\n method virtual bool : bool -> 'res\n method virtual char : char -> 'res\n method virtual int : int -> 'res\n method virtual list : 'a. ('a -> 'res) -> 'a list -> 'res\n method virtual option : 'a. ('a -> 'res) -> 'a option -> 'res\n method virtual string : string -> 'res\n\n method position : position -> 'res =\n fun { pos_fname; pos_lnum; pos_bol; pos_cnum } ->\n let pos_fname = self#string pos_fname in\n let pos_lnum = self#int pos_lnum in\n let pos_bol = self#int pos_bol in\n let pos_cnum = self#int pos_cnum in\n self#record\n [\n (\"pos_fname\", pos_fname);\n (\"pos_lnum\", pos_lnum);\n (\"pos_bol\", pos_bol);\n (\"pos_cnum\", pos_cnum);\n ]\n\n method location : location -> 'res =\n fun { loc_start; loc_end; loc_ghost } ->\n let loc_start = self#position loc_start in\n let loc_end = self#position loc_end in\n let loc_ghost = self#bool loc_ghost in\n self#record\n [\n (\"loc_start\", loc_start);\n (\"loc_end\", loc_end);\n (\"loc_ghost\", loc_ghost);\n ]\n\n method location_stack : location_stack -> 'res = self#list self#location\n\n method loc : 'a. ('a -> 'res) -> 'a loc -> 'res =\n fun _a { txt; loc } ->\n let txt = _a txt in\n let loc = self#location loc in\n self#record [ (\"txt\", txt); (\"loc\", loc) ]\n\n method longident : longident -> 'res =\n fun x ->\n match x with\n | Lident a ->\n let a = self#string a in\n self#constr \"Lident\" [ a ]\n | Ldot (a, b) ->\n let a = self#longident a in\n let b = self#string b in\n self#constr \"Ldot\" [ a; b ]\n | Lapply (a, b) ->\n let a = self#longident a in\n let b = self#longident b in\n self#constr \"Lapply\" [ a; b ]\n\n method longident_loc : longident_loc -> 'res = self#loc self#longident\n\n method rec_flag : rec_flag -> 'res =\n fun x ->\n match x with\n | Nonrecursive -> self#constr \"Nonrecursive\" []\n | Recursive -> self#constr \"Recursive\" []\n\n method direction_flag : direction_flag -> 'res =\n fun x ->\n match x with\n | Upto -> self#constr \"Upto\" []\n | Downto -> self#constr \"Downto\" []\n\n method private_flag : private_flag -> 'res =\n fun x ->\n match x with\n | Private -> self#constr \"Private\" []\n | Public -> self#constr \"Public\" []\n\n method mutable_flag : mutable_flag -> 'res =\n fun x ->\n match x with\n | Immutable -> self#constr \"Immutable\" []\n | Mutable -> self#constr \"Mutable\" []\n\n method virtual_flag : virtual_flag -> 'res =\n fun x ->\n match x with\n | Virtual -> self#constr \"Virtual\" []\n | Concrete -> self#constr \"Concrete\" []\n\n method override_flag : override_flag -> 'res =\n fun x ->\n match x with\n | Override -> self#constr \"Override\" []\n | Fresh -> self#constr \"Fresh\" []\n\n method closed_flag : closed_flag -> 'res =\n fun x ->\n match x with\n | Closed -> self#constr \"Closed\" []\n | Open -> self#constr \"Open\" []\n\n method label : label -> 'res = self#string\n\n method arg_label : arg_label -> 'res =\n fun x ->\n match x with\n | Nolabel -> self#constr \"Nolabel\" []\n | Labelled a ->\n let a = self#string a in\n self#constr \"Labelled\" [ a ]\n | Optional a ->\n let a = self#string a in\n self#constr \"Optional\" [ a ]\n\n method variance : variance -> 'res =\n fun x ->\n match x with\n | Covariant -> self#constr \"Covariant\" []\n | Contravariant -> self#constr \"Contravariant\" []\n | NoVariance -> self#constr \"NoVariance\" []\n\n method injectivity : injectivity -> 'res =\n fun x ->\n match x with\n | Injective -> self#constr \"Injective\" []\n | NoInjectivity -> self#constr \"NoInjectivity\" []\n\n method constant : constant -> 'res =\n fun x ->\n match x with\n | Pconst_integer (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n self#constr \"Pconst_integer\" [ a; b ]\n | Pconst_char a ->\n let a = self#char a in\n self#constr \"Pconst_char\" [ a ]\n | Pconst_string (a, b, c) ->\n let a = self#string a in\n let b = self#location b in\n let c = self#option self#string c in\n self#constr \"Pconst_string\" [ a; b; c ]\n | Pconst_float (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n self#constr \"Pconst_float\" [ a; b ]\n\n method attribute : attribute -> 'res =\n fun { attr_name; attr_payload; attr_loc } ->\n let attr_name = self#loc self#string attr_name in\n let attr_payload = self#payload attr_payload in\n let attr_loc = self#location attr_loc in\n self#record\n [\n (\"attr_name\", attr_name);\n (\"attr_payload\", attr_payload);\n (\"attr_loc\", attr_loc);\n ]\n\n method extension : extension -> 'res =\n fun (a, b) ->\n let a = self#loc self#string a in\n let b = self#payload b in\n self#tuple [ a; b ]\n\n method attributes : attributes -> 'res = self#list self#attribute\n\n method payload : payload -> 'res =\n fun x ->\n match x with\n | PStr a ->\n let a = self#structure a in\n self#constr \"PStr\" [ a ]\n | PSig a ->\n let a = self#signature a in\n self#constr \"PSig\" [ a ]\n | PTyp a ->\n let a = self#core_type a in\n self#constr \"PTyp\" [ a ]\n | PPat (a, b) ->\n let a = self#pattern a in\n let b = self#option self#expression b in\n self#constr \"PPat\" [ a; b ]\n\n method core_type : core_type -> 'res =\n fun { ptyp_desc; ptyp_loc; ptyp_loc_stack; ptyp_attributes } ->\n let ptyp_desc = self#core_type_desc ptyp_desc in\n let ptyp_loc = self#location ptyp_loc in\n let ptyp_loc_stack = self#location_stack ptyp_loc_stack in\n let ptyp_attributes = self#attributes ptyp_attributes in\n self#record\n [\n (\"ptyp_desc\", ptyp_desc);\n (\"ptyp_loc\", ptyp_loc);\n (\"ptyp_loc_stack\", ptyp_loc_stack);\n (\"ptyp_attributes\", ptyp_attributes);\n ]\n\n method core_type_desc : core_type_desc -> 'res =\n fun x ->\n match x with\n | Ptyp_any -> self#constr \"Ptyp_any\" []\n | Ptyp_var a ->\n let a = self#string a in\n self#constr \"Ptyp_var\" [ a ]\n | Ptyp_arrow (a, b, c) ->\n let a = self#arg_label a in\n let b = self#core_type b in\n let c = self#core_type c in\n self#constr \"Ptyp_arrow\" [ a; b; c ]\n | Ptyp_tuple a ->\n let a = self#list self#core_type a in\n self#constr \"Ptyp_tuple\" [ a ]\n | Ptyp_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n self#constr \"Ptyp_constr\" [ a; b ]\n | Ptyp_object (a, b) ->\n let a = self#list self#object_field a in\n let b = self#closed_flag b in\n self#constr \"Ptyp_object\" [ a; b ]\n | Ptyp_class (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n self#constr \"Ptyp_class\" [ a; b ]\n | Ptyp_alias (a, b) ->\n let a = self#core_type a in\n let b = self#string b in\n self#constr \"Ptyp_alias\" [ a; b ]\n | Ptyp_variant (a, b, c) ->\n let a = self#list self#row_field a in\n let b = self#closed_flag b in\n let c = self#option (self#list self#label) c in\n self#constr \"Ptyp_variant\" [ a; b; c ]\n | Ptyp_poly (a, b) ->\n let a = self#list (self#loc self#string) a in\n let b = self#core_type b in\n self#constr \"Ptyp_poly\" [ a; b ]\n | Ptyp_package a ->\n let a = self#package_type a in\n self#constr \"Ptyp_package\" [ a ]\n | Ptyp_extension a ->\n let a = self#extension a in\n self#constr \"Ptyp_extension\" [ a ]\n\n method package_type : package_type -> 'res =\n fun (a, b) ->\n let a = self#longident_loc a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#core_type b in\n self#tuple [ a; b ])\n b\n in\n self#tuple [ a; b ]\n\n method row_field : row_field -> 'res =\n fun { prf_desc; prf_loc; prf_attributes } ->\n let prf_desc = self#row_field_desc prf_desc in\n let prf_loc = self#location prf_loc in\n let prf_attributes = self#attributes prf_attributes in\n self#record\n [\n (\"prf_desc\", prf_desc);\n (\"prf_loc\", prf_loc);\n (\"prf_attributes\", prf_attributes);\n ]\n\n method row_field_desc : row_field_desc -> 'res =\n fun x ->\n match x with\n | Rtag (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#bool b in\n let c = self#list self#core_type c in\n self#constr \"Rtag\" [ a; b; c ]\n | Rinherit a ->\n let a = self#core_type a in\n self#constr \"Rinherit\" [ a ]\n\n method object_field : object_field -> 'res =\n fun { pof_desc; pof_loc; pof_attributes } ->\n let pof_desc = self#object_field_desc pof_desc in\n let pof_loc = self#location pof_loc in\n let pof_attributes = self#attributes pof_attributes in\n self#record\n [\n (\"pof_desc\", pof_desc);\n (\"pof_loc\", pof_loc);\n (\"pof_attributes\", pof_attributes);\n ]\n\n method object_field_desc : object_field_desc -> 'res =\n fun x ->\n match x with\n | Otag (a, b) ->\n let a = self#loc self#label a in\n let b = self#core_type b in\n self#constr \"Otag\" [ a; b ]\n | Oinherit a ->\n let a = self#core_type a in\n self#constr \"Oinherit\" [ a ]\n\n method pattern : pattern -> 'res =\n fun { ppat_desc; ppat_loc; ppat_loc_stack; ppat_attributes } ->\n let ppat_desc = self#pattern_desc ppat_desc in\n let ppat_loc = self#location ppat_loc in\n let ppat_loc_stack = self#location_stack ppat_loc_stack in\n let ppat_attributes = self#attributes ppat_attributes in\n self#record\n [\n (\"ppat_desc\", ppat_desc);\n (\"ppat_loc\", ppat_loc);\n (\"ppat_loc_stack\", ppat_loc_stack);\n (\"ppat_attributes\", ppat_attributes);\n ]\n\n method pattern_desc : pattern_desc -> 'res =\n fun x ->\n match x with\n | Ppat_any -> self#constr \"Ppat_any\" []\n | Ppat_var a ->\n let a = self#loc self#string a in\n self#constr \"Ppat_var\" [ a ]\n | Ppat_alias (a, b) ->\n let a = self#pattern a in\n let b = self#loc self#string b in\n self#constr \"Ppat_alias\" [ a; b ]\n | Ppat_constant a ->\n let a = self#constant a in\n self#constr \"Ppat_constant\" [ a ]\n | Ppat_interval (a, b) ->\n let a = self#constant a in\n let b = self#constant b in\n self#constr \"Ppat_interval\" [ a; b ]\n | Ppat_tuple a ->\n let a = self#list self#pattern a in\n self#constr \"Ppat_tuple\" [ a ]\n | Ppat_construct (a, b) ->\n let a = self#longident_loc a in\n let b = self#option self#pattern b in\n self#constr \"Ppat_construct\" [ a; b ]\n | Ppat_variant (a, b) ->\n let a = self#label a in\n let b = self#option self#pattern b in\n self#constr \"Ppat_variant\" [ a; b ]\n | Ppat_record (a, b) ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#pattern b in\n self#tuple [ a; b ])\n a\n in\n let b = self#closed_flag b in\n self#constr \"Ppat_record\" [ a; b ]\n | Ppat_array a ->\n let a = self#list self#pattern a in\n self#constr \"Ppat_array\" [ a ]\n | Ppat_or (a, b) ->\n let a = self#pattern a in\n let b = self#pattern b in\n self#constr \"Ppat_or\" [ a; b ]\n | Ppat_constraint (a, b) ->\n let a = self#pattern a in\n let b = self#core_type b in\n self#constr \"Ppat_constraint\" [ a; b ]\n | Ppat_type a ->\n let a = self#longident_loc a in\n self#constr \"Ppat_type\" [ a ]\n | Ppat_lazy a ->\n let a = self#pattern a in\n self#constr \"Ppat_lazy\" [ a ]\n | Ppat_unpack a ->\n let a = self#loc (self#option self#string) a in\n self#constr \"Ppat_unpack\" [ a ]\n | Ppat_exception a ->\n let a = self#pattern a in\n self#constr \"Ppat_exception\" [ a ]\n | Ppat_extension a ->\n let a = self#extension a in\n self#constr \"Ppat_extension\" [ a ]\n | Ppat_open (a, b) ->\n let a = self#longident_loc a in\n let b = self#pattern b in\n self#constr \"Ppat_open\" [ a; b ]\n\n method expression : expression -> 'res =\n fun { pexp_desc; pexp_loc; pexp_loc_stack; pexp_attributes } ->\n let pexp_desc = self#expression_desc pexp_desc in\n let pexp_loc = self#location pexp_loc in\n let pexp_loc_stack = self#location_stack pexp_loc_stack in\n let pexp_attributes = self#attributes pexp_attributes in\n self#record\n [\n (\"pexp_desc\", pexp_desc);\n (\"pexp_loc\", pexp_loc);\n (\"pexp_loc_stack\", pexp_loc_stack);\n (\"pexp_attributes\", pexp_attributes);\n ]\n\n method expression_desc : expression_desc -> 'res =\n fun x ->\n match x with\n | Pexp_ident a ->\n let a = self#longident_loc a in\n self#constr \"Pexp_ident\" [ a ]\n | Pexp_constant a ->\n let a = self#constant a in\n self#constr \"Pexp_constant\" [ a ]\n | Pexp_let (a, b, c) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n let c = self#expression c in\n self#constr \"Pexp_let\" [ a; b; c ]\n | Pexp_function a ->\n let a = self#cases a in\n self#constr \"Pexp_function\" [ a ]\n | Pexp_fun (a, b, c, d) ->\n let a = self#arg_label a in\n let b = self#option self#expression b in\n let c = self#pattern c in\n let d = self#expression d in\n self#constr \"Pexp_fun\" [ a; b; c; d ]\n | Pexp_apply (a, b) ->\n let a = self#expression a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#arg_label a in\n let b = self#expression b in\n self#tuple [ a; b ])\n b\n in\n self#constr \"Pexp_apply\" [ a; b ]\n | Pexp_match (a, b) ->\n let a = self#expression a in\n let b = self#cases b in\n self#constr \"Pexp_match\" [ a; b ]\n | Pexp_try (a, b) ->\n let a = self#expression a in\n let b = self#cases b in\n self#constr \"Pexp_try\" [ a; b ]\n | Pexp_tuple a ->\n let a = self#list self#expression a in\n self#constr \"Pexp_tuple\" [ a ]\n | Pexp_construct (a, b) ->\n let a = self#longident_loc a in\n let b = self#option self#expression b in\n self#constr \"Pexp_construct\" [ a; b ]\n | Pexp_variant (a, b) ->\n let a = self#label a in\n let b = self#option self#expression b in\n self#constr \"Pexp_variant\" [ a; b ]\n | Pexp_record (a, b) ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#longident_loc a in\n let b = self#expression b in\n self#tuple [ a; b ])\n a\n in\n let b = self#option self#expression b in\n self#constr \"Pexp_record\" [ a; b ]\n | Pexp_field (a, b) ->\n let a = self#expression a in\n let b = self#longident_loc b in\n self#constr \"Pexp_field\" [ a; b ]\n | Pexp_setfield (a, b, c) ->\n let a = self#expression a in\n let b = self#longident_loc b in\n let c = self#expression c in\n self#constr \"Pexp_setfield\" [ a; b; c ]\n | Pexp_array a ->\n let a = self#list self#expression a in\n self#constr \"Pexp_array\" [ a ]\n | Pexp_ifthenelse (a, b, c) ->\n let a = self#expression a in\n let b = self#expression b in\n let c = self#option self#expression c in\n self#constr \"Pexp_ifthenelse\" [ a; b; c ]\n | Pexp_sequence (a, b) ->\n let a = self#expression a in\n let b = self#expression b in\n self#constr \"Pexp_sequence\" [ a; b ]\n | Pexp_while (a, b) ->\n let a = self#expression a in\n let b = self#expression b in\n self#constr \"Pexp_while\" [ a; b ]\n | Pexp_for (a, b, c, d, e) ->\n let a = self#pattern a in\n let b = self#expression b in\n let c = self#expression c in\n let d = self#direction_flag d in\n let e = self#expression e in\n self#constr \"Pexp_for\" [ a; b; c; d; e ]\n | Pexp_constraint (a, b) ->\n let a = self#expression a in\n let b = self#core_type b in\n self#constr \"Pexp_constraint\" [ a; b ]\n | Pexp_coerce (a, b, c) ->\n let a = self#expression a in\n let b = self#option self#core_type b in\n let c = self#core_type c in\n self#constr \"Pexp_coerce\" [ a; b; c ]\n | Pexp_send (a, b) ->\n let a = self#expression a in\n let b = self#loc self#label b in\n self#constr \"Pexp_send\" [ a; b ]\n | Pexp_new a ->\n let a = self#longident_loc a in\n self#constr \"Pexp_new\" [ a ]\n | Pexp_setinstvar (a, b) ->\n let a = self#loc self#label a in\n let b = self#expression b in\n self#constr \"Pexp_setinstvar\" [ a; b ]\n | Pexp_override a ->\n let a =\n self#list\n (fun (a, b) ->\n let a = self#loc self#label a in\n let b = self#expression b in\n self#tuple [ a; b ])\n a\n in\n self#constr \"Pexp_override\" [ a ]\n | Pexp_letmodule (a, b, c) ->\n let a = self#loc (self#option self#string) a in\n let b = self#module_expr b in\n let c = self#expression c in\n self#constr \"Pexp_letmodule\" [ a; b; c ]\n | Pexp_letexception (a, b) ->\n let a = self#extension_constructor a in\n let b = self#expression b in\n self#constr \"Pexp_letexception\" [ a; b ]\n | Pexp_assert a ->\n let a = self#expression a in\n self#constr \"Pexp_assert\" [ a ]\n | Pexp_lazy a ->\n let a = self#expression a in\n self#constr \"Pexp_lazy\" [ a ]\n | Pexp_poly (a, b) ->\n let a = self#expression a in\n let b = self#option self#core_type b in\n self#constr \"Pexp_poly\" [ a; b ]\n | Pexp_object a ->\n let a = self#class_structure a in\n self#constr \"Pexp_object\" [ a ]\n | Pexp_newtype (a, b) ->\n let a = self#loc self#string a in\n let b = self#expression b in\n self#constr \"Pexp_newtype\" [ a; b ]\n | Pexp_pack a ->\n let a = self#module_expr a in\n self#constr \"Pexp_pack\" [ a ]\n | Pexp_open (a, b) ->\n let a = self#open_declaration a in\n let b = self#expression b in\n self#constr \"Pexp_open\" [ a; b ]\n | Pexp_letop a ->\n let a = self#letop a in\n self#constr \"Pexp_letop\" [ a ]\n | Pexp_extension a ->\n let a = self#extension a in\n self#constr \"Pexp_extension\" [ a ]\n | Pexp_unreachable -> self#constr \"Pexp_unreachable\" []\n\n method case : case -> 'res =\n fun { pc_lhs; pc_guard; pc_rhs } ->\n let pc_lhs = self#pattern pc_lhs in\n let pc_guard = self#option self#expression pc_guard in\n let pc_rhs = self#expression pc_rhs in\n self#record\n [ (\"pc_lhs\", pc_lhs); (\"pc_guard\", pc_guard); (\"pc_rhs\", pc_rhs) ]\n\n method letop : letop -> 'res =\n fun { let_; ands; body } ->\n let let_ = self#binding_op let_ in\n let ands = self#list self#binding_op ands in\n let body = self#expression body in\n self#record [ (\"let_\", let_); (\"ands\", ands); (\"body\", body) ]\n\n method binding_op : binding_op -> 'res =\n fun { pbop_op; pbop_pat; pbop_exp; pbop_loc } ->\n let pbop_op = self#loc self#string pbop_op in\n let pbop_pat = self#pattern pbop_pat in\n let pbop_exp = self#expression pbop_exp in\n let pbop_loc = self#location pbop_loc in\n self#record\n [\n (\"pbop_op\", pbop_op);\n (\"pbop_pat\", pbop_pat);\n (\"pbop_exp\", pbop_exp);\n (\"pbop_loc\", pbop_loc);\n ]\n\n method value_description : value_description -> 'res =\n fun { pval_name; pval_type; pval_prim; pval_attributes; pval_loc } ->\n let pval_name = self#loc self#string pval_name in\n let pval_type = self#core_type pval_type in\n let pval_prim = self#list self#string pval_prim in\n let pval_attributes = self#attributes pval_attributes in\n let pval_loc = self#location pval_loc in\n self#record\n [\n (\"pval_name\", pval_name);\n (\"pval_type\", pval_type);\n (\"pval_prim\", pval_prim);\n (\"pval_attributes\", pval_attributes);\n (\"pval_loc\", pval_loc);\n ]\n\n method type_declaration : type_declaration -> 'res =\n fun {\n ptype_name;\n ptype_params;\n ptype_cstrs;\n ptype_kind;\n ptype_private;\n ptype_manifest;\n ptype_attributes;\n ptype_loc;\n } ->\n let ptype_name = self#loc self#string ptype_name in\n let ptype_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n self#tuple [ a; b ])\n b\n in\n self#tuple [ a; b ])\n ptype_params\n in\n let ptype_cstrs =\n self#list\n (fun (a, b, c) ->\n let a = self#core_type a in\n let b = self#core_type b in\n let c = self#location c in\n self#tuple [ a; b; c ])\n ptype_cstrs\n in\n let ptype_kind = self#type_kind ptype_kind in\n let ptype_private = self#private_flag ptype_private in\n let ptype_manifest = self#option self#core_type ptype_manifest in\n let ptype_attributes = self#attributes ptype_attributes in\n let ptype_loc = self#location ptype_loc in\n self#record\n [\n (\"ptype_name\", ptype_name);\n (\"ptype_params\", ptype_params);\n (\"ptype_cstrs\", ptype_cstrs);\n (\"ptype_kind\", ptype_kind);\n (\"ptype_private\", ptype_private);\n (\"ptype_manifest\", ptype_manifest);\n (\"ptype_attributes\", ptype_attributes);\n (\"ptype_loc\", ptype_loc);\n ]\n\n method type_kind : type_kind -> 'res =\n fun x ->\n match x with\n | Ptype_abstract -> self#constr \"Ptype_abstract\" []\n | Ptype_variant a ->\n let a = self#list self#constructor_declaration a in\n self#constr \"Ptype_variant\" [ a ]\n | Ptype_record a ->\n let a = self#list self#label_declaration a in\n self#constr \"Ptype_record\" [ a ]\n | Ptype_open -> self#constr \"Ptype_open\" []\n\n method label_declaration : label_declaration -> 'res =\n fun { pld_name; pld_mutable; pld_type; pld_loc; pld_attributes } ->\n let pld_name = self#loc self#string pld_name in\n let pld_mutable = self#mutable_flag pld_mutable in\n let pld_type = self#core_type pld_type in\n let pld_loc = self#location pld_loc in\n let pld_attributes = self#attributes pld_attributes in\n self#record\n [\n (\"pld_name\", pld_name);\n (\"pld_mutable\", pld_mutable);\n (\"pld_type\", pld_type);\n (\"pld_loc\", pld_loc);\n (\"pld_attributes\", pld_attributes);\n ]\n\n method constructor_declaration : constructor_declaration -> 'res =\n fun { pcd_name; pcd_args; pcd_res; pcd_loc; pcd_attributes } ->\n let pcd_name = self#loc self#string pcd_name in\n let pcd_args = self#constructor_arguments pcd_args in\n let pcd_res = self#option self#core_type pcd_res in\n let pcd_loc = self#location pcd_loc in\n let pcd_attributes = self#attributes pcd_attributes in\n self#record\n [\n (\"pcd_name\", pcd_name);\n (\"pcd_args\", pcd_args);\n (\"pcd_res\", pcd_res);\n (\"pcd_loc\", pcd_loc);\n (\"pcd_attributes\", pcd_attributes);\n ]\n\n method constructor_arguments : constructor_arguments -> 'res =\n fun x ->\n match x with\n | Pcstr_tuple a ->\n let a = self#list self#core_type a in\n self#constr \"Pcstr_tuple\" [ a ]\n | Pcstr_record a ->\n let a = self#list self#label_declaration a in\n self#constr \"Pcstr_record\" [ a ]\n\n method type_extension : type_extension -> 'res =\n fun {\n ptyext_path;\n ptyext_params;\n ptyext_constructors;\n ptyext_private;\n ptyext_loc;\n ptyext_attributes;\n } ->\n let ptyext_path = self#longident_loc ptyext_path in\n let ptyext_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n self#tuple [ a; b ])\n b\n in\n self#tuple [ a; b ])\n ptyext_params\n in\n let ptyext_constructors =\n self#list self#extension_constructor ptyext_constructors\n in\n let ptyext_private = self#private_flag ptyext_private in\n let ptyext_loc = self#location ptyext_loc in\n let ptyext_attributes = self#attributes ptyext_attributes in\n self#record\n [\n (\"ptyext_path\", ptyext_path);\n (\"ptyext_params\", ptyext_params);\n (\"ptyext_constructors\", ptyext_constructors);\n (\"ptyext_private\", ptyext_private);\n (\"ptyext_loc\", ptyext_loc);\n (\"ptyext_attributes\", ptyext_attributes);\n ]\n\n method extension_constructor : extension_constructor -> 'res =\n fun { pext_name; pext_kind; pext_loc; pext_attributes } ->\n let pext_name = self#loc self#string pext_name in\n let pext_kind = self#extension_constructor_kind pext_kind in\n let pext_loc = self#location pext_loc in\n let pext_attributes = self#attributes pext_attributes in\n self#record\n [\n (\"pext_name\", pext_name);\n (\"pext_kind\", pext_kind);\n (\"pext_loc\", pext_loc);\n (\"pext_attributes\", pext_attributes);\n ]\n\n method type_exception : type_exception -> 'res =\n fun { ptyexn_constructor; ptyexn_loc; ptyexn_attributes } ->\n let ptyexn_constructor =\n self#extension_constructor ptyexn_constructor\n in\n let ptyexn_loc = self#location ptyexn_loc in\n let ptyexn_attributes = self#attributes ptyexn_attributes in\n self#record\n [\n (\"ptyexn_constructor\", ptyexn_constructor);\n (\"ptyexn_loc\", ptyexn_loc);\n (\"ptyexn_attributes\", ptyexn_attributes);\n ]\n\n method extension_constructor_kind : extension_constructor_kind -> 'res =\n fun x ->\n match x with\n | Pext_decl (a, b) ->\n let a = self#constructor_arguments a in\n let b = self#option self#core_type b in\n self#constr \"Pext_decl\" [ a; b ]\n | Pext_rebind a ->\n let a = self#longident_loc a in\n self#constr \"Pext_rebind\" [ a ]\n\n method class_type : class_type -> 'res =\n fun { pcty_desc; pcty_loc; pcty_attributes } ->\n let pcty_desc = self#class_type_desc pcty_desc in\n let pcty_loc = self#location pcty_loc in\n let pcty_attributes = self#attributes pcty_attributes in\n self#record\n [\n (\"pcty_desc\", pcty_desc);\n (\"pcty_loc\", pcty_loc);\n (\"pcty_attributes\", pcty_attributes);\n ]\n\n method class_type_desc : class_type_desc -> 'res =\n fun x ->\n match x with\n | Pcty_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n self#constr \"Pcty_constr\" [ a; b ]\n | Pcty_signature a ->\n let a = self#class_signature a in\n self#constr \"Pcty_signature\" [ a ]\n | Pcty_arrow (a, b, c) ->\n let a = self#arg_label a in\n let b = self#core_type b in\n let c = self#class_type c in\n self#constr \"Pcty_arrow\" [ a; b; c ]\n | Pcty_extension a ->\n let a = self#extension a in\n self#constr \"Pcty_extension\" [ a ]\n | Pcty_open (a, b) ->\n let a = self#open_description a in\n let b = self#class_type b in\n self#constr \"Pcty_open\" [ a; b ]\n\n method class_signature : class_signature -> 'res =\n fun { pcsig_self; pcsig_fields } ->\n let pcsig_self = self#core_type pcsig_self in\n let pcsig_fields = self#list self#class_type_field pcsig_fields in\n self#record\n [ (\"pcsig_self\", pcsig_self); (\"pcsig_fields\", pcsig_fields) ]\n\n method class_type_field : class_type_field -> 'res =\n fun { pctf_desc; pctf_loc; pctf_attributes } ->\n let pctf_desc = self#class_type_field_desc pctf_desc in\n let pctf_loc = self#location pctf_loc in\n let pctf_attributes = self#attributes pctf_attributes in\n self#record\n [\n (\"pctf_desc\", pctf_desc);\n (\"pctf_loc\", pctf_loc);\n (\"pctf_attributes\", pctf_attributes);\n ]\n\n method class_type_field_desc : class_type_field_desc -> 'res =\n fun x ->\n match x with\n | Pctf_inherit a ->\n let a = self#class_type a in\n self#constr \"Pctf_inherit\" [ a ]\n | Pctf_val a ->\n let a =\n (fun (a, b, c, d) ->\n let a = self#loc self#label a in\n let b = self#mutable_flag b in\n let c = self#virtual_flag c in\n let d = self#core_type d in\n self#tuple [ a; b; c; d ])\n a\n in\n self#constr \"Pctf_val\" [ a ]\n | Pctf_method a ->\n let a =\n (fun (a, b, c, d) ->\n let a = self#loc self#label a in\n let b = self#private_flag b in\n let c = self#virtual_flag c in\n let d = self#core_type d in\n self#tuple [ a; b; c; d ])\n a\n in\n self#constr \"Pctf_method\" [ a ]\n | Pctf_constraint a ->\n let a =\n (fun (a, b) ->\n let a = self#core_type a in\n let b = self#core_type b in\n self#tuple [ a; b ])\n a\n in\n self#constr \"Pctf_constraint\" [ a ]\n | Pctf_attribute a ->\n let a = self#attribute a in\n self#constr \"Pctf_attribute\" [ a ]\n | Pctf_extension a ->\n let a = self#extension a in\n self#constr \"Pctf_extension\" [ a ]\n\n method class_infos : 'a. ('a -> 'res) -> 'a class_infos -> 'res =\n fun _a\n { pci_virt; pci_params; pci_name; pci_expr; pci_loc; pci_attributes } ->\n let pci_virt = self#virtual_flag pci_virt in\n let pci_params =\n self#list\n (fun (a, b) ->\n let a = self#core_type a in\n let b =\n (fun (a, b) ->\n let a = self#variance a in\n let b = self#injectivity b in\n self#tuple [ a; b ])\n b\n in\n self#tuple [ a; b ])\n pci_params\n in\n let pci_name = self#loc self#string pci_name in\n let pci_expr = _a pci_expr in\n let pci_loc = self#location pci_loc in\n let pci_attributes = self#attributes pci_attributes in\n self#record\n [\n (\"pci_virt\", pci_virt);\n (\"pci_params\", pci_params);\n (\"pci_name\", pci_name);\n (\"pci_expr\", pci_expr);\n (\"pci_loc\", pci_loc);\n (\"pci_attributes\", pci_attributes);\n ]\n\n method class_description : class_description -> 'res =\n self#class_infos self#class_type\n\n method class_type_declaration : class_type_declaration -> 'res =\n self#class_infos self#class_type\n\n method class_expr : class_expr -> 'res =\n fun { pcl_desc; pcl_loc; pcl_attributes } ->\n let pcl_desc = self#class_expr_desc pcl_desc in\n let pcl_loc = self#location pcl_loc in\n let pcl_attributes = self#attributes pcl_attributes in\n self#record\n [\n (\"pcl_desc\", pcl_desc);\n (\"pcl_loc\", pcl_loc);\n (\"pcl_attributes\", pcl_attributes);\n ]\n\n method class_expr_desc : class_expr_desc -> 'res =\n fun x ->\n match x with\n | Pcl_constr (a, b) ->\n let a = self#longident_loc a in\n let b = self#list self#core_type b in\n self#constr \"Pcl_constr\" [ a; b ]\n | Pcl_structure a ->\n let a = self#class_structure a in\n self#constr \"Pcl_structure\" [ a ]\n | Pcl_fun (a, b, c, d) ->\n let a = self#arg_label a in\n let b = self#option self#expression b in\n let c = self#pattern c in\n let d = self#class_expr d in\n self#constr \"Pcl_fun\" [ a; b; c; d ]\n | Pcl_apply (a, b) ->\n let a = self#class_expr a in\n let b =\n self#list\n (fun (a, b) ->\n let a = self#arg_label a in\n let b = self#expression b in\n self#tuple [ a; b ])\n b\n in\n self#constr \"Pcl_apply\" [ a; b ]\n | Pcl_let (a, b, c) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n let c = self#class_expr c in\n self#constr \"Pcl_let\" [ a; b; c ]\n | Pcl_constraint (a, b) ->\n let a = self#class_expr a in\n let b = self#class_type b in\n self#constr \"Pcl_constraint\" [ a; b ]\n | Pcl_extension a ->\n let a = self#extension a in\n self#constr \"Pcl_extension\" [ a ]\n | Pcl_open (a, b) ->\n let a = self#open_description a in\n let b = self#class_expr b in\n self#constr \"Pcl_open\" [ a; b ]\n\n method class_structure : class_structure -> 'res =\n fun { pcstr_self; pcstr_fields } ->\n let pcstr_self = self#pattern pcstr_self in\n let pcstr_fields = self#list self#class_field pcstr_fields in\n self#record\n [ (\"pcstr_self\", pcstr_self); (\"pcstr_fields\", pcstr_fields) ]\n\n method class_field : class_field -> 'res =\n fun { pcf_desc; pcf_loc; pcf_attributes } ->\n let pcf_desc = self#class_field_desc pcf_desc in\n let pcf_loc = self#location pcf_loc in\n let pcf_attributes = self#attributes pcf_attributes in\n self#record\n [\n (\"pcf_desc\", pcf_desc);\n (\"pcf_loc\", pcf_loc);\n (\"pcf_attributes\", pcf_attributes);\n ]\n\n method class_field_desc : class_field_desc -> 'res =\n fun x ->\n match x with\n | Pcf_inherit (a, b, c) ->\n let a = self#override_flag a in\n let b = self#class_expr b in\n let c = self#option (self#loc self#string) c in\n self#constr \"Pcf_inherit\" [ a; b; c ]\n | Pcf_val a ->\n let a =\n (fun (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#mutable_flag b in\n let c = self#class_field_kind c in\n self#tuple [ a; b; c ])\n a\n in\n self#constr \"Pcf_val\" [ a ]\n | Pcf_method a ->\n let a =\n (fun (a, b, c) ->\n let a = self#loc self#label a in\n let b = self#private_flag b in\n let c = self#class_field_kind c in\n self#tuple [ a; b; c ])\n a\n in\n self#constr \"Pcf_method\" [ a ]\n | Pcf_constraint a ->\n let a =\n (fun (a, b) ->\n let a = self#core_type a in\n let b = self#core_type b in\n self#tuple [ a; b ])\n a\n in\n self#constr \"Pcf_constraint\" [ a ]\n | Pcf_initializer a ->\n let a = self#expression a in\n self#constr \"Pcf_initializer\" [ a ]\n | Pcf_attribute a ->\n let a = self#attribute a in\n self#constr \"Pcf_attribute\" [ a ]\n | Pcf_extension a ->\n let a = self#extension a in\n self#constr \"Pcf_extension\" [ a ]\n\n method class_field_kind : class_field_kind -> 'res =\n fun x ->\n match x with\n | Cfk_virtual a ->\n let a = self#core_type a in\n self#constr \"Cfk_virtual\" [ a ]\n | Cfk_concrete (a, b) ->\n let a = self#override_flag a in\n let b = self#expression b in\n self#constr \"Cfk_concrete\" [ a; b ]\n\n method class_declaration : class_declaration -> 'res =\n self#class_infos self#class_expr\n\n method module_type : module_type -> 'res =\n fun { pmty_desc; pmty_loc; pmty_attributes } ->\n let pmty_desc = self#module_type_desc pmty_desc in\n let pmty_loc = self#location pmty_loc in\n let pmty_attributes = self#attributes pmty_attributes in\n self#record\n [\n (\"pmty_desc\", pmty_desc);\n (\"pmty_loc\", pmty_loc);\n (\"pmty_attributes\", pmty_attributes);\n ]\n\n method module_type_desc : module_type_desc -> 'res =\n fun x ->\n match x with\n | Pmty_ident a ->\n let a = self#longident_loc a in\n self#constr \"Pmty_ident\" [ a ]\n | Pmty_signature a ->\n let a = self#signature a in\n self#constr \"Pmty_signature\" [ a ]\n | Pmty_functor (a, b) ->\n let a = self#functor_parameter a in\n let b = self#module_type b in\n self#constr \"Pmty_functor\" [ a; b ]\n | Pmty_with (a, b) ->\n let a = self#module_type a in\n let b = self#list self#with_constraint b in\n self#constr \"Pmty_with\" [ a; b ]\n | Pmty_typeof a ->\n let a = self#module_expr a in\n self#constr \"Pmty_typeof\" [ a ]\n | Pmty_extension a ->\n let a = self#extension a in\n self#constr \"Pmty_extension\" [ a ]\n | Pmty_alias a ->\n let a = self#longident_loc a in\n self#constr \"Pmty_alias\" [ a ]\n\n method functor_parameter : functor_parameter -> 'res =\n fun x ->\n match x with\n | Unit -> self#constr \"Unit\" []\n | Named (a, b) ->\n let a = self#loc (self#option self#string) a in\n let b = self#module_type b in\n self#constr \"Named\" [ a; b ]\n\n method signature : signature -> 'res = self#list self#signature_item\n\n method signature_item : signature_item -> 'res =\n fun { psig_desc; psig_loc } ->\n let psig_desc = self#signature_item_desc psig_desc in\n let psig_loc = self#location psig_loc in\n self#record [ (\"psig_desc\", psig_desc); (\"psig_loc\", psig_loc) ]\n\n method signature_item_desc : signature_item_desc -> 'res =\n fun x ->\n match x with\n | Psig_value a ->\n let a = self#value_description a in\n self#constr \"Psig_value\" [ a ]\n | Psig_type (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#type_declaration b in\n self#constr \"Psig_type\" [ a; b ]\n | Psig_typesubst a ->\n let a = self#list self#type_declaration a in\n self#constr \"Psig_typesubst\" [ a ]\n | Psig_typext a ->\n let a = self#type_extension a in\n self#constr \"Psig_typext\" [ a ]\n | Psig_exception a ->\n let a = self#type_exception a in\n self#constr \"Psig_exception\" [ a ]\n | Psig_module a ->\n let a = self#module_declaration a in\n self#constr \"Psig_module\" [ a ]\n | Psig_modsubst a ->\n let a = self#module_substitution a in\n self#constr \"Psig_modsubst\" [ a ]\n | Psig_recmodule a ->\n let a = self#list self#module_declaration a in\n self#constr \"Psig_recmodule\" [ a ]\n | Psig_modtype a ->\n let a = self#module_type_declaration a in\n self#constr \"Psig_modtype\" [ a ]\n | Psig_open a ->\n let a = self#open_description a in\n self#constr \"Psig_open\" [ a ]\n | Psig_include a ->\n let a = self#include_description a in\n self#constr \"Psig_include\" [ a ]\n | Psig_class a ->\n let a = self#list self#class_description a in\n self#constr \"Psig_class\" [ a ]\n | Psig_class_type a ->\n let a = self#list self#class_type_declaration a in\n self#constr \"Psig_class_type\" [ a ]\n | Psig_attribute a ->\n let a = self#attribute a in\n self#constr \"Psig_attribute\" [ a ]\n | Psig_extension (a, b) ->\n let a = self#extension a in\n let b = self#attributes b in\n self#constr \"Psig_extension\" [ a; b ]\n\n method module_declaration : module_declaration -> 'res =\n fun { pmd_name; pmd_type; pmd_attributes; pmd_loc } ->\n let pmd_name = self#loc (self#option self#string) pmd_name in\n let pmd_type = self#module_type pmd_type in\n let pmd_attributes = self#attributes pmd_attributes in\n let pmd_loc = self#location pmd_loc in\n self#record\n [\n (\"pmd_name\", pmd_name);\n (\"pmd_type\", pmd_type);\n (\"pmd_attributes\", pmd_attributes);\n (\"pmd_loc\", pmd_loc);\n ]\n\n method module_substitution : module_substitution -> 'res =\n fun { pms_name; pms_manifest; pms_attributes; pms_loc } ->\n let pms_name = self#loc self#string pms_name in\n let pms_manifest = self#longident_loc pms_manifest in\n let pms_attributes = self#attributes pms_attributes in\n let pms_loc = self#location pms_loc in\n self#record\n [\n (\"pms_name\", pms_name);\n (\"pms_manifest\", pms_manifest);\n (\"pms_attributes\", pms_attributes);\n (\"pms_loc\", pms_loc);\n ]\n\n method module_type_declaration : module_type_declaration -> 'res =\n fun { pmtd_name; pmtd_type; pmtd_attributes; pmtd_loc } ->\n let pmtd_name = self#loc self#string pmtd_name in\n let pmtd_type = self#option self#module_type pmtd_type in\n let pmtd_attributes = self#attributes pmtd_attributes in\n let pmtd_loc = self#location pmtd_loc in\n self#record\n [\n (\"pmtd_name\", pmtd_name);\n (\"pmtd_type\", pmtd_type);\n (\"pmtd_attributes\", pmtd_attributes);\n (\"pmtd_loc\", pmtd_loc);\n ]\n\n method open_infos : 'a. ('a -> 'res) -> 'a open_infos -> 'res =\n fun _a { popen_expr; popen_override; popen_loc; popen_attributes } ->\n let popen_expr = _a popen_expr in\n let popen_override = self#override_flag popen_override in\n let popen_loc = self#location popen_loc in\n let popen_attributes = self#attributes popen_attributes in\n self#record\n [\n (\"popen_expr\", popen_expr);\n (\"popen_override\", popen_override);\n (\"popen_loc\", popen_loc);\n (\"popen_attributes\", popen_attributes);\n ]\n\n method open_description : open_description -> 'res =\n self#open_infos self#longident_loc\n\n method open_declaration : open_declaration -> 'res =\n self#open_infos self#module_expr\n\n method include_infos : 'a. ('a -> 'res) -> 'a include_infos -> 'res =\n fun _a { pincl_mod; pincl_loc; pincl_attributes } ->\n let pincl_mod = _a pincl_mod in\n let pincl_loc = self#location pincl_loc in\n let pincl_attributes = self#attributes pincl_attributes in\n self#record\n [\n (\"pincl_mod\", pincl_mod);\n (\"pincl_loc\", pincl_loc);\n (\"pincl_attributes\", pincl_attributes);\n ]\n\n method include_description : include_description -> 'res =\n self#include_infos self#module_type\n\n method include_declaration : include_declaration -> 'res =\n self#include_infos self#module_expr\n\n method with_constraint : with_constraint -> 'res =\n fun x ->\n match x with\n | Pwith_type (a, b) ->\n let a = self#longident_loc a in\n let b = self#type_declaration b in\n self#constr \"Pwith_type\" [ a; b ]\n | Pwith_module (a, b) ->\n let a = self#longident_loc a in\n let b = self#longident_loc b in\n self#constr \"Pwith_module\" [ a; b ]\n | Pwith_typesubst (a, b) ->\n let a = self#longident_loc a in\n let b = self#type_declaration b in\n self#constr \"Pwith_typesubst\" [ a; b ]\n | Pwith_modsubst (a, b) ->\n let a = self#longident_loc a in\n let b = self#longident_loc b in\n self#constr \"Pwith_modsubst\" [ a; b ]\n\n method module_expr : module_expr -> 'res =\n fun { pmod_desc; pmod_loc; pmod_attributes } ->\n let pmod_desc = self#module_expr_desc pmod_desc in\n let pmod_loc = self#location pmod_loc in\n let pmod_attributes = self#attributes pmod_attributes in\n self#record\n [\n (\"pmod_desc\", pmod_desc);\n (\"pmod_loc\", pmod_loc);\n (\"pmod_attributes\", pmod_attributes);\n ]\n\n method module_expr_desc : module_expr_desc -> 'res =\n fun x ->\n match x with\n | Pmod_ident a ->\n let a = self#longident_loc a in\n self#constr \"Pmod_ident\" [ a ]\n | Pmod_structure a ->\n let a = self#structure a in\n self#constr \"Pmod_structure\" [ a ]\n | Pmod_functor (a, b) ->\n let a = self#functor_parameter a in\n let b = self#module_expr b in\n self#constr \"Pmod_functor\" [ a; b ]\n | Pmod_apply (a, b) ->\n let a = self#module_expr a in\n let b = self#module_expr b in\n self#constr \"Pmod_apply\" [ a; b ]\n | Pmod_constraint (a, b) ->\n let a = self#module_expr a in\n let b = self#module_type b in\n self#constr \"Pmod_constraint\" [ a; b ]\n | Pmod_unpack a ->\n let a = self#expression a in\n self#constr \"Pmod_unpack\" [ a ]\n | Pmod_extension a ->\n let a = self#extension a in\n self#constr \"Pmod_extension\" [ a ]\n\n method structure : structure -> 'res = self#list self#structure_item\n\n method structure_item : structure_item -> 'res =\n fun { pstr_desc; pstr_loc } ->\n let pstr_desc = self#structure_item_desc pstr_desc in\n let pstr_loc = self#location pstr_loc in\n self#record [ (\"pstr_desc\", pstr_desc); (\"pstr_loc\", pstr_loc) ]\n\n method structure_item_desc : structure_item_desc -> 'res =\n fun x ->\n match x with\n | Pstr_eval (a, b) ->\n let a = self#expression a in\n let b = self#attributes b in\n self#constr \"Pstr_eval\" [ a; b ]\n | Pstr_value (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#value_binding b in\n self#constr \"Pstr_value\" [ a; b ]\n | Pstr_primitive a ->\n let a = self#value_description a in\n self#constr \"Pstr_primitive\" [ a ]\n | Pstr_type (a, b) ->\n let a = self#rec_flag a in\n let b = self#list self#type_declaration b in\n self#constr \"Pstr_type\" [ a; b ]\n | Pstr_typext a ->\n let a = self#type_extension a in\n self#constr \"Pstr_typext\" [ a ]\n | Pstr_exception a ->\n let a = self#type_exception a in\n self#constr \"Pstr_exception\" [ a ]\n | Pstr_module a ->\n let a = self#module_binding a in\n self#constr \"Pstr_module\" [ a ]\n | Pstr_recmodule a ->\n let a = self#list self#module_binding a in\n self#constr \"Pstr_recmodule\" [ a ]\n | Pstr_modtype a ->\n let a = self#module_type_declaration a in\n self#constr \"Pstr_modtype\" [ a ]\n | Pstr_open a ->\n let a = self#open_declaration a in\n self#constr \"Pstr_open\" [ a ]\n | Pstr_class a ->\n let a = self#list self#class_declaration a in\n self#constr \"Pstr_class\" [ a ]\n | Pstr_class_type a ->\n let a = self#list self#class_type_declaration a in\n self#constr \"Pstr_class_type\" [ a ]\n | Pstr_include a ->\n let a = self#include_declaration a in\n self#constr \"Pstr_include\" [ a ]\n | Pstr_attribute a ->\n let a = self#attribute a in\n self#constr \"Pstr_attribute\" [ a ]\n | Pstr_extension (a, b) ->\n let a = self#extension a in\n let b = self#attributes b in\n self#constr \"Pstr_extension\" [ a; b ]\n\n method value_binding : value_binding -> 'res =\n fun { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } ->\n let pvb_pat = self#pattern pvb_pat in\n let pvb_expr = self#expression pvb_expr in\n let pvb_attributes = self#attributes pvb_attributes in\n let pvb_loc = self#location pvb_loc in\n self#record\n [\n (\"pvb_pat\", pvb_pat);\n (\"pvb_expr\", pvb_expr);\n (\"pvb_attributes\", pvb_attributes);\n (\"pvb_loc\", pvb_loc);\n ]\n\n method module_binding : module_binding -> 'res =\n fun { pmb_name; pmb_expr; pmb_attributes; pmb_loc } ->\n let pmb_name = self#loc (self#option self#string) pmb_name in\n let pmb_expr = self#module_expr pmb_expr in\n let pmb_attributes = self#attributes pmb_attributes in\n let pmb_loc = self#location pmb_loc in\n self#record\n [\n (\"pmb_name\", pmb_name);\n (\"pmb_expr\", pmb_expr);\n (\"pmb_attributes\", pmb_attributes);\n (\"pmb_loc\", pmb_loc);\n ]\n\n method toplevel_phrase : toplevel_phrase -> 'res =\n fun x ->\n match x with\n | Ptop_def a ->\n let a = self#structure a in\n self#constr \"Ptop_def\" [ a ]\n | Ptop_dir a ->\n let a = self#toplevel_directive a in\n self#constr \"Ptop_dir\" [ a ]\n\n method toplevel_directive : toplevel_directive -> 'res =\n fun { pdir_name; pdir_arg; pdir_loc } ->\n let pdir_name = self#loc self#string pdir_name in\n let pdir_arg = self#option self#directive_argument pdir_arg in\n let pdir_loc = self#location pdir_loc in\n self#record\n [\n (\"pdir_name\", pdir_name);\n (\"pdir_arg\", pdir_arg);\n (\"pdir_loc\", pdir_loc);\n ]\n\n method directive_argument : directive_argument -> 'res =\n fun { pdira_desc; pdira_loc } ->\n let pdira_desc = self#directive_argument_desc pdira_desc in\n let pdira_loc = self#location pdira_loc in\n self#record [ (\"pdira_desc\", pdira_desc); (\"pdira_loc\", pdira_loc) ]\n\n method directive_argument_desc : directive_argument_desc -> 'res =\n fun x ->\n match x with\n | Pdir_string a ->\n let a = self#string a in\n self#constr \"Pdir_string\" [ a ]\n | Pdir_int (a, b) ->\n let a = self#string a in\n let b = self#option self#char b in\n self#constr \"Pdir_int\" [ a; b ]\n | Pdir_ident a ->\n let a = self#longident a in\n self#constr \"Pdir_ident\" [ a ]\n | Pdir_bool a ->\n let a = self#bool a in\n self#constr \"Pdir_bool\" [ a ]\n\n method cases : cases -> 'res = self#list self#case\n end\n\n[@@@end]\n","type deriver = ..\n\nlet all = Hashtbl.create 42\n\nlet register name deriver =\n if Hashtbl.mem all name then\n Printf.ksprintf failwith\n \"Ppx_deriviers.register: %S is already registered\" name;\n Hashtbl.add all name deriver\n\nlet lookup name =\n match Hashtbl.find all name with\n | drv -> Some drv\n | exception Not_found -> None\n\nlet derivers () =\n Hashtbl.fold (fun name drv acc -> (name, drv) :: acc) all []\n","module T = struct\n type 'a map = 'a -> 'a\n type 'a iter = 'a -> unit\n type ('a, 'acc) fold = 'a -> 'acc -> 'acc\n type ('a, 'acc) fold_map = 'a -> 'acc -> 'a * 'acc\n type ('ctx, 'a) map_with_context = 'ctx -> 'a -> 'a\n type ('a, 'res) lift = 'a -> 'res\nend\n\nclass map =\n let any x = x in\n object\n method int : int T.map = any\n method string : string T.map = any\n method bool : bool T.map = any\n method char : char T.map = any\n\n method option : 'a. 'a T.map -> 'a option T.map =\n fun f x -> match x with None -> None | Some x -> Some (f x)\n\n method list : 'a. 'a T.map -> 'a list T.map = List.map\n method array : 'a. 'a T.map -> 'a array T.map = Array.map\n end\n\nclass iter =\n let any = ignore in\n object\n method int : int T.iter = any\n method string : string T.iter = any\n method bool : bool T.iter = any\n method char : char T.iter = any\n\n method option : 'a. 'a T.iter -> 'a option T.iter =\n fun f x -> match x with None -> () | Some x -> f x\n\n method list : 'a. 'a T.iter -> 'a list T.iter = List.iter\n method array : 'a. 'a T.iter -> 'a array T.iter = Array.iter\n end\n\nclass ['acc] fold =\n let any _ acc = acc in\n object\n method int : (int, 'acc) T.fold = any\n method string : (string, 'acc) T.fold = any\n method bool : (bool, 'acc) T.fold = any\n method char : (char, 'acc) T.fold = any\n\n method option : 'a. ('a, 'acc) T.fold -> ('a option, 'acc) T.fold =\n fun f x acc -> match x with None -> acc | Some x -> f x acc\n\n method list : 'a. ('a, 'acc) T.fold -> ('a list, 'acc) T.fold =\n let rec loop f l acc =\n match l with [] -> acc | x :: l -> loop f l (f x acc)\n in\n loop\n\n method array : 'a. ('a, 'acc) T.fold -> ('a array, 'acc) T.fold =\n fun f a acc ->\n let r = ref acc in\n for i = 0 to Array.length a - 1 do\n r := f (Array.unsafe_get a i) !r\n done;\n !r\n end\n\nclass ['acc] fold_map =\n let any x acc = (x, acc) in\n object\n method int : (int, 'acc) T.fold_map = any\n method string : (string, 'acc) T.fold_map = any\n method bool : (bool, 'acc) T.fold_map = any\n method char : (char, 'acc) T.fold_map = any\n\n method option : 'a. ('a, 'acc) T.fold_map -> ('a option, 'acc) T.fold_map =\n fun f x acc ->\n match x with\n | None -> (None, acc)\n | Some x ->\n let x, acc = f x acc in\n (Some x, acc)\n\n method list : 'a. ('a, 'acc) T.fold_map -> ('a list, 'acc) T.fold_map =\n let rec loop f l acc =\n match l with\n | [] -> ([], acc)\n | x :: l ->\n let x, acc = f x acc in\n let l, acc = loop f l acc in\n (x :: l, acc)\n in\n loop\n\n method array : 'a. ('a, 'acc) T.fold_map -> ('a array, 'acc) T.fold_map =\n fun f a acc ->\n let len = Array.length a in\n if len = 0 then (a, acc)\n else\n let x, acc = f (Array.unsafe_get a 0) acc in\n let a' = Array.make len x in\n let r = ref acc in\n for i = 1 to len - 1 do\n let x, acc = f (Array.unsafe_get a i) !r in\n Array.unsafe_set a' i x;\n r := acc\n done;\n (a', !r)\n end\n\nclass ['ctx] map_with_context =\n let any _ x = x in\n object\n method int : ('ctx, int) T.map_with_context = any\n method string : ('ctx, string) T.map_with_context = any\n method bool : ('ctx, bool) T.map_with_context = any\n method char : ('ctx, char) T.map_with_context = any\n\n method option\n : 'a.\n ('ctx, 'a) T.map_with_context -> ('ctx, 'a option) T.map_with_context\n =\n fun f ctx x -> match x with None -> None | Some x -> Some (f ctx x)\n\n method list\n : 'a.\n ('ctx, 'a) T.map_with_context -> ('ctx, 'a list) T.map_with_context =\n fun f ctx l -> List.map (f ctx) l\n\n method array\n : 'a.\n ('ctx, 'a) T.map_with_context -> ('ctx, 'a array) T.map_with_context =\n fun f ctx a -> Array.map (f ctx) a\n end\n\nclass virtual ['res] lift =\n object (self)\n method virtual other : 'a. ('a, 'res) T.lift\n method virtual int : (int, 'res) T.lift\n method virtual string : (string, 'res) T.lift\n method virtual bool : (bool, 'res) T.lift\n method virtual char : (char, 'res) T.lift\n method virtual array : 'a. ('a, 'res) T.lift -> ('a array, 'res) T.lift\n method virtual float : (float, 'res) T.lift\n method virtual int32 : (int32, 'res) T.lift\n method virtual int64 : (int64, 'res) T.lift\n method virtual nativeint : (nativeint, 'res) T.lift\n method virtual unit : (unit, 'res) T.lift\n method virtual record : (string * 'res) list -> 'res\n method virtual constr : string -> 'res list -> 'res\n method virtual tuple : 'res list -> 'res\n\n method option : 'a. ('a, 'res) T.lift -> ('a option, 'res) T.lift =\n fun f x ->\n match x with\n | None -> self#constr \"None\" []\n | Some x -> self#constr \"Some\" [ f x ]\n\n method list : 'a. ('a, 'res) T.lift -> ('a list, 'res) T.lift =\n fun f l ->\n match l with\n | [] -> self#constr \"[]\" []\n | x :: l -> self#constr \"::\" [ f x; self#list f l ]\n end\n\nclass type ['res] std_lifters =\n object\n method other : 'a. ('a, 'res) T.lift\n method int : (int, 'res) T.lift\n method string : (string, 'res) T.lift\n method bool : (bool, 'res) T.lift\n method char : (char, 'res) T.lift\n method array : 'a. ('a, 'res) T.lift -> ('a array, 'res) T.lift\n method record : (string * 'res) list -> 'res\n method constr : string -> 'res list -> 'res\n method tuple : 'res list -> 'res\n method float : (float, 'res) T.lift\n method int32 : (int32, 'res) T.lift\n method int64 : (int64, 'res) T.lift\n method nativeint : (nativeint, 'res) T.lift\n method unit : (unit, 'res) T.lift\n method option : 'a. ('a, 'res) T.lift -> ('a option, 'res) T.lift\n method list : 'a. ('a, 'res) T.lift -> ('a list, 'res) T.lift\n end\n","open! Import\n\nmodule T = struct\n type t = longident = Lident of string | Ldot of t * string | Lapply of t * t\n\n let compare : t -> t -> int = Poly.compare\n\n let is_normal_ident_char = function\n | 'A' .. 'Z' | 'a' .. 'z' | '0' .. '9' | '_' | '\\'' -> true\n | _ -> false\n\n let is_normal_ident = function\n | \"asr\" | \"land\" | \"lor\" | \"lsl\" | \"lsr\" | \"lxor\" | \"mod\" | \"or\" -> false\n | string -> String.for_all string ~f:is_normal_ident_char\n\n let short_name string =\n if is_normal_ident string then string else \"( \" ^ string ^ \" )\"\n\n let rec name = function\n | Lident s -> short_name s\n | Ldot (a, b) -> name a ^ \".\" ^ short_name b\n | Lapply (a, b) -> Printf.sprintf \"%s(%s)\" (name a) (name b)\n\n let sexp_of_t t = Sexp.Atom (name t)\nend\n\ninclude T\n\nlet rec flat accu = function\n | Lident s -> s :: accu\n | Ldot (lid, s) -> flat (s :: accu) lid\n | Lapply (_, _) -> invalid_arg \"Ppxlib.Longident.flatten\"\n\nlet flatten_exn lid = flat [] lid\n\nlet last_exn = function\n | Lident s -> s\n | Ldot (_, s) -> s\n | Lapply (_, _) -> invalid_arg \"Ppxlib.Longident.flatten\"\n\nlet unflatten ~init l = List.fold_left l ~init ~f:(fun acc s -> Ldot (acc, s))\n\n(* for cases without dotted operators (e.g. [parse \"A.B.C\"]) *)\nlet parse_simple s =\n match String.split_on_char s ~sep:'.' with\n | [] -> assert false\n | s :: l -> unflatten ~init:(Lident s) l\n\n(* handle [\"A.B.(+.+)\"] or [\"Vec.(.%.()<-)\"] *)\nlet parse s =\n let invalid () =\n invalid_arg (Printf.sprintf \"Ppxlib.Longident.parse: %S\" s)\n in\n match (String.index_opt s '(', String.rindex_opt s ')') with\n | None, None -> parse_simple s\n | None, _ | _, None -> invalid ()\n | Some l, Some r -> (\n if Int.(r <> String.length s - 1) then invalid ();\n let group =\n if Int.(r = l + 1) then \"()\"\n else String.trim (String.sub s ~pos:(l + 1) ~len:(r - l - 1))\n in\n if Int.(l = 0) then Lident group\n else if Char.(s.[l - 1] <> '.') then invalid ()\n else\n let before = String.sub s ~pos:0 ~len:(l - 1) in\n match String.split_on_char before ~sep:'.' with\n | [] -> assert false\n | s :: l -> Ldot (unflatten ~init:(Lident s) l, group))\n\nmodule Map = Map.Make (T)\nmodule Set = Set.Make (T)\n","open! Import\n\ntype t = {\n file_path : string;\n main_module_name : string;\n submodule_path : string loc list;\n value : string loc option;\n in_expr : bool;\n}\n\nlet top_level ~file_path =\n let main_module_name =\n file_path |> Caml.Filename.basename |> Caml.Filename.remove_extension\n |> String.capitalize_ascii\n in\n {\n file_path;\n main_module_name;\n submodule_path = [];\n value = None;\n in_expr = false;\n }\n\nlet file_path t = t.file_path\nlet main_module_name t = t.main_module_name\n\nlet submodule_path t =\n List.rev_map ~f:(fun located -> located.txt) t.submodule_path\n\nlet value t = Option.map ~f:(fun located -> located.txt) t.value\n\nlet fully_qualified_path t =\n let value = value t in\n let submodule_path =\n List.rev_map ~f:(fun located -> Some located.txt) t.submodule_path\n in\n let names = (Some t.main_module_name :: submodule_path) @ [ value ] in\n String.concat ~sep:\".\" @@ List.filter_opt names\n\nlet enter_expr t = { t with in_expr = true }\n\nlet enter_module ~loc module_name t =\n if t.in_expr then t\n else\n { t with submodule_path = { txt = module_name; loc } :: t.submodule_path }\n\nlet enter_value ~loc value_name t =\n if t.in_expr then t else { t with value = Some { txt = value_name; loc } }\n\nlet to_string_path t = String.concat ~sep:\".\" (t.file_path :: submodule_path t)\nlet with_string_path f ~loc ~path = f ~loc ~path:(to_string_path path);;\n\nlet module M = struct\n let a = \"lol\"\nend in\nM.a\n","open Import\nmodule L = Astlib.Location\n\ntype t = location = {\n loc_start : Lexing.position;\n loc_end : Lexing.position;\n loc_ghost : bool;\n}\n\nlet in_file name =\n let loc = { pos_fname = name; pos_lnum = 1; pos_bol = 0; pos_cnum = -1 } in\n { loc_start = loc; loc_end = loc; loc_ghost = true }\n\nlet set_filename loc fn =\n let loc_start = { loc.loc_start with pos_fname = fn } in\n let loc_end = { loc.loc_end with pos_fname = fn } in\n { loc with loc_start; loc_end }\n\nlet none = in_file \"_none_\"\n\nlet init lexbuf fname =\n let open Lexing in\n lexbuf.lex_curr_p <-\n { pos_fname = fname; pos_lnum = 1; pos_bol = 0; pos_cnum = 0 }\n\nlet raise_errorf ?loc fmt = L.raise_errorf ?loc fmt\nlet report_exception = L.report_exception\n\nlet of_lexbuf (lexbuf : Lexing.lexbuf) =\n {\n loc_start = lexbuf.lex_start_p;\n loc_end = lexbuf.lex_curr_p;\n loc_ghost = false;\n }\n\nlet print ppf t =\n Caml.Format.fprintf ppf \"File \\\"%s\\\", line %d, characters %d-%d:\"\n t.loc_start.pos_fname t.loc_start.pos_lnum\n (t.loc_start.pos_cnum - t.loc_start.pos_bol)\n (t.loc_end.pos_cnum - t.loc_start.pos_bol)\n\ntype nonrec 'a loc = 'a loc = { txt : 'a; loc : t }\n\nlet compare_pos p1 p2 =\n let open Lexing in\n let column p =\n (* Manual extract:\n The difference between pos_cnum and pos_bol is the character offset\n within the line (i.e. the column number, assuming each character is\n one column wide). *)\n p.pos_cnum - p.pos_bol\n in\n match Int.compare p1.pos_lnum p2.pos_lnum with\n | 0 -> Int.compare (column p1) (column p2)\n | n -> n\n\nlet min_pos p1 p2 = if compare_pos p1 p2 <= 0 then p1 else p2\nlet max_pos p1 p2 = if compare_pos p1 p2 >= 0 then p1 else p2\n\nlet compare loc1 loc2 =\n match compare_pos loc1.loc_start loc2.loc_start with\n | 0 -> compare_pos loc1.loc_end loc2.loc_end\n | n -> n\n\nmodule Error = struct\n include Ppxlib_ast.Location_error\n\n let createf ~loc fmt = Format.kasprintf (fun str -> make ~loc ~sub:[] str) fmt\nend\n\nlet error_extensionf ~loc fmt =\n Format.kasprintf\n (fun str -> Error.to_extension @@ Error.make ~loc ~sub:[] str)\n fmt\n\nexception Error = L.Error\n\nlet () =\n Caml.Printexc.register_printer (function\n | Error e -> Some (Error.message e)\n | _ -> None)\n","open Import\n\ntype t = Astlib.Location.Error.t\n\nlet to_extension (error : Astlib.Location.Error.t) =\n let open Astlib.Location.Error in\n let open Ast_helper in\n if not (is_well_formed error) then\n raise (Invalid_argument \"to_extension: expected kind Report_error\");\n let sub_msgs = sub_msgs error in\n let main_msg = main_msg error in\n let err_extension_name loc = { Location.loc; txt = \"ocaml.error\" } in\n let mk_string_constant x = Str.eval (Exp.constant (Const.string x)) in\n let extension_of_sub_msg (sub_msg : string Location.loc) =\n Str.extension\n (err_extension_name sub_msg.loc, PStr [ mk_string_constant sub_msg.txt ])\n in\n ( err_extension_name main_msg.loc,\n Parsetree.PStr\n (mk_string_constant main_msg.txt :: List.map extension_of_sub_msg sub_msgs)\n )\n\nlet register_error_of_exn = Astlib.Location.register_error_of_exn\n\nlet message error =\n let { Astlib.Location.txt; _ } = Astlib.Location.Error.main_msg error in\n txt\n\nlet set_message = Astlib.Location.Error.set_main_msg\n\nlet make ~loc txt ~sub =\n let sub = List.map (fun (loc, txt) -> { Astlib.Location.loc; txt }) sub in\n Astlib.Location.Error.make ~sub { loc; txt }\n\nlet update_loc = Astlib.Location.Error.set_main_loc\n\nlet get_location error =\n let { Astlib.Location.loc; _ } = Astlib.Location.Error.main_msg error in\n loc\n\nlet of_exn = Astlib.Location.Error.of_exn\nlet raise error = raise (Astlib.Location.Error error)\n","module Base = struct\n type t = { tool_name : string; code_path : Code_path.t; input_name : string }\n\n let top_level ~tool_name ~file_path ~input_name =\n let code_path = Code_path.top_level ~file_path in\n { tool_name; code_path; input_name }\n\n let code_path t = t.code_path\n let input_name t = t.input_name\n let tool_name t = t.tool_name\n let enter_expr t = { t with code_path = Code_path.enter_expr t.code_path }\n\n let enter_module ~loc name t =\n { t with code_path = Code_path.enter_module ~loc name t.code_path }\n\n let enter_value ~loc name t =\n { t with code_path = Code_path.enter_value ~loc name t.code_path }\nend\n\nmodule Extension = struct\n type t = { extension_point_loc : Location.t; base : Base.t }\n\n let make ~extension_point_loc ~base () = { extension_point_loc; base }\n let extension_point_loc t = t.extension_point_loc\n let code_path t = t.base.code_path\n let input_name t = t.base.input_name\n let tool_name t = t.base.tool_name\n\n let with_loc_and_path f ~ctxt =\n f ~loc:ctxt.extension_point_loc\n ~path:(Code_path.to_string_path ctxt.base.code_path)\nend\n\nmodule Deriver = struct\n type t = { derived_item_loc : Location.t; inline : bool; base : Base.t }\n\n let make ~derived_item_loc ~inline ~base () =\n { derived_item_loc; base; inline }\n\n let derived_item_loc t = t.derived_item_loc\n let code_path t = t.base.code_path\n let input_name t = t.base.input_name\n let tool_name t = t.base.tool_name\n let inline t = t.inline\n\n let with_loc_and_path f ~ctxt =\n f ~loc:ctxt.derived_item_loc\n ~path:(Code_path.to_string_path ctxt.base.code_path)\nend\n","open! Import\n\nclass map =\n object\n inherit Ppxlib_traverse_builtins.map\n inherit Ast.map\n end\n\nclass iter =\n object\n inherit Ppxlib_traverse_builtins.iter\n inherit Ast.iter\n end\n\nclass ['acc] fold =\n object\n inherit ['acc] Ppxlib_traverse_builtins.fold\n inherit ['acc] Ast.fold\n end\n\nclass ['acc] fold_map =\n object\n inherit ['acc] Ppxlib_traverse_builtins.fold_map\n inherit ['acc] Ast.fold_map\n end\n\nclass ['ctx] map_with_context =\n object\n inherit ['ctx] Ppxlib_traverse_builtins.map_with_context\n inherit ['ctx] Ast.map_with_context\n end\n\nclass virtual ['res] lift =\n object\n inherit ['res] Ppxlib_traverse_builtins.lift\n inherit ['res] Ast.lift\n end\n\nlet module_name = function None -> \"_\" | Some name -> name\nlet enter name path = if String.is_empty path then name else path ^ \".\" ^ name\nlet enter_opt name_opt path = enter (module_name name_opt) path\n\nclass map_with_path =\n object\n inherit [string] map_with_context as super\n\n (* WAS:\n method! structure_item_desc path x =\n match x with\n | Pstr_module mb -> super#structure_item_desc (enter mb.pmb_name.txt path) x\n | _ -> super#structure_item_desc path x\n\n Overriding [module_binding] seems to be OK because it does not catch\n local module bindings because at the moment the parsetree doesn't make\n use of [module_binding] for local modules, but that might change in the\n future, so this might be something to keep in mind.\n\n The following:\n\n module A = struct .. end\n module A = struct .. end\n\n is disallowed, but\n\n let _ = .. let module A = struct .. end in ..\n module A = struct .. end\n let _ = .. let module A = struct .. end in ..\n\n isn't, and the \"path\" constructed here would be able to differentiate\n between them. *)\n method! module_binding path mb =\n super#module_binding (enter_opt mb.pmb_name.txt path) mb\n\n method! module_declaration path md =\n super#module_declaration (enter_opt md.pmd_name.txt path) md\n\n method! module_type_declaration path mtd =\n super#module_type_declaration (enter mtd.pmtd_name.txt path) mtd\n end\n\nlet var_names_of =\n object\n inherit [string list] fold as super\n\n method! pattern p acc =\n let acc = super#pattern p acc in\n match p.ppat_desc with Ppat_var { txt; _ } -> txt :: acc | _ -> acc\n end\n\nlet ec_enter_module_opt ~loc name_opt ctxt =\n Expansion_context.Base.enter_module ~loc (module_name name_opt) ctxt\n\nclass map_with_expansion_context =\n object (self)\n inherit [Expansion_context.Base.t] map_with_context as super\n\n method! expression ctxt expr =\n super#expression (Expansion_context.Base.enter_expr ctxt) expr\n\n method! module_binding ctxt mb =\n super#module_binding\n (ec_enter_module_opt ~loc:mb.pmb_loc mb.pmb_name.txt ctxt)\n mb\n\n method! module_declaration ctxt md =\n super#module_declaration\n (ec_enter_module_opt ~loc:md.pmd_loc md.pmd_name.txt ctxt)\n md\n\n method! module_type_declaration ctxt mtd =\n super#module_type_declaration\n (Expansion_context.Base.enter_module ~loc:mtd.pmtd_loc mtd.pmtd_name.txt\n ctxt)\n mtd\n\n method! value_description ctxt vd =\n super#value_description\n (Expansion_context.Base.enter_value ~loc:vd.pval_loc vd.pval_name.txt\n ctxt)\n vd\n\n method! value_binding ctxt { pvb_pat; pvb_expr; pvb_attributes; pvb_loc } =\n let all_var_names = var_names_of#pattern pvb_pat [] in\n let var_name = Stdppx.List.last all_var_names in\n let in_binding_ctxt =\n match var_name with\n | None -> ctxt\n | Some var_name ->\n Expansion_context.Base.enter_value ~loc:pvb_loc var_name ctxt\n in\n let pvb_pat = self#pattern ctxt pvb_pat in\n let pvb_expr = self#expression in_binding_ctxt pvb_expr in\n let pvb_attributes = self#attributes in_binding_ctxt pvb_attributes in\n let pvb_loc = self#location ctxt pvb_loc in\n { pvb_pat; pvb_expr; pvb_attributes; pvb_loc }\n end\n\nclass sexp_of =\n object\n inherit [Sexp.t] Ast.lift\n method int = sexp_of_int\n method string = sexp_of_string\n method bool = sexp_of_bool\n method char = sexp_of_char\n method float = sexp_of_float\n method int32 = sexp_of_int32\n method int64 = sexp_of_int64\n method nativeint = sexp_of_nativeint\n method unit = sexp_of_unit\n method option = sexp_of_option\n method list = sexp_of_list\n method array : 'a. ('a -> Sexp.t) -> 'a array -> Sexp.t = sexp_of_array\n method other : 'a. 'a -> Sexp.t = fun _ -> Sexp.Atom \"_\"\n\n method record fields =\n List\n (List.map fields ~f:(fun (label, sexp) ->\n Sexp.List [ Atom label; sexp ]))\n\n method constr tag args =\n match args with [] -> Atom tag | _ -> List (Atom tag :: args)\n\n method tuple l = List l\n end\n\nlet sexp_of = new sexp_of\n","open! Import\n\nexception Cutoff_met\n\n(* As found here http://rosettacode.org/wiki/Levenshtein_distance#OCaml *)\nlet levenshtein_distance s t cutoff =\n let m = String.length s and n = String.length t in\n if cutoff = 0 || abs (m - n) >= cutoff then None\n else\n (* for all i and j, d.(i).(j) will hold the Levenshtein distance between the\n first i characters of s and the first j characters of t *)\n let d = Array.make_matrix ~dimx:(m + 1) ~dimy:(n + 1) 0 in\n for i = 0 to m do\n (* the distance of any first string to an empty second string *)\n d.(i).(0) <- i\n done;\n for j = 0 to n do\n (* the distance of any second string to an empty first string *)\n d.(0).(j) <- j\n done;\n (* the minimum of each line together with the column index will be used\n to notice cutoff exceeding and return early in that case *)\n let line_min = ref 0 in\n let distance =\n try\n for j = 1 to n do\n if !line_min >= cutoff - 1 && j >= cutoff - 1 then raise Cutoff_met;\n line_min := max m n;\n for i = 1 to m do\n let value =\n if Char.equal s.[i - 1] t.[j - 1] then d.(i - 1).(j - 1)\n (* no operation required *)\n else\n min\n (d.(i - 1).(j) + 1) (* a deletion *)\n (min\n (d.(i).(j - 1) + 1) (* an insertion *)\n (d.(i - 1).(j - 1) + 1) (* a substitution *))\n in\n d.(i).(j) <- value;\n line_min := min !line_min value\n done\n done;\n if d.(m).(n) < cutoff then Some d.(m).(n) else None\n with Cutoff_met -> None\n in\n distance\n\nlet spellcheck names name =\n let cutoff =\n match String.length name with\n | 1 | 2 -> 0\n | 3 | 4 -> 1\n | 5 | 6 -> 2\n | _ -> 3\n in\n let _, suggestions =\n List.fold_left names ~init:(Int.max_int, [])\n ~f:(fun ((best_distance, names_at_best_distance) as acc) registered_name\n ->\n match levenshtein_distance name registered_name cutoff with\n | None -> acc\n | Some dist ->\n if dist < best_distance then (dist, [ registered_name ])\n else if dist > best_distance then acc\n else (dist, registered_name :: names_at_best_distance))\n in\n match List.rev suggestions |> List.filter ~f:(String.( <> ) name) with\n | [] -> None\n | last :: rev_rest ->\n Some\n (Printf.sprintf \"Hint: Did you mean %s%s%s?\"\n (String.concat ~sep:\", \" (List.rev rev_rest))\n (if List.is_empty rev_rest then \"\" else \" or \")\n last)\n","open! Import\n\nexception Expected of Location.t * string\n\nlet fail loc expected = raise (Expected (loc, expected))\n\ntype context = {\n (* [matched] counts how many constructors have been matched. This is used to find what\n pattern matches the most some piece of ast in [Ast_pattern.alt]. In the case where\n all branches fail to match, we report the error from the one that matches the\n most.\n\n This is only incremented by combinators that can fail. *)\n mutable matched : int;\n}\n\ntype ('matched_value, 'k, 'k_result) t =\n | T of (context -> Location.t -> 'matched_value -> 'k -> 'k_result)\n","open Import\nmodule M =\n struct\n let attribute ~loc ~name ~payload =\n { attr_name = name; attr_payload = payload; attr_loc = loc }\n let binding_op ~loc ~op ~pat ~exp =\n { pbop_op = op; pbop_pat = pat; pbop_exp = exp; pbop_loc = loc }\n let case ~lhs ~guard ~rhs =\n { pc_lhs = lhs; pc_guard = guard; pc_rhs = rhs }\n let pcl_constr ~loc x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_constr (x0, x1))\n }\n let pcl_structure ~loc x0 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_structure x0) }\n let pcl_fun ~loc x0 x1 x2 x3 =\n {\n pcl_attributes = [];\n pcl_loc = loc;\n pcl_desc = (Pcl_fun (x0, x1, x2, x3))\n }\n let pcl_apply ~loc x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_apply (x0, x1)) }\n let pcl_let ~loc x0 x1 x2 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_let (x0, x1, x2))\n }\n let pcl_constraint ~loc x0 x1 =\n {\n pcl_attributes = [];\n pcl_loc = loc;\n pcl_desc = (Pcl_constraint (x0, x1))\n }\n let pcl_extension ~loc x0 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_extension x0) }\n let pcl_open ~loc x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_open (x0, x1)) }\n let pcf_inherit ~loc x0 x1 x2 =\n {\n pcf_attributes = [];\n pcf_loc = loc;\n pcf_desc = (Pcf_inherit (x0, x1, x2))\n }\n let pcf_val ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_val x0) }\n let pcf_method ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_method x0) }\n let pcf_constraint ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_constraint x0) }\n let pcf_initializer ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_initializer x0) }\n let pcf_attribute ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_attribute x0) }\n let pcf_extension ~loc x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_extension x0) }\n let class_infos ~loc ~virt ~params ~name ~expr =\n {\n pci_virt = virt;\n pci_params = params;\n pci_name = name;\n pci_expr = expr;\n pci_loc = loc;\n pci_attributes = []\n }\n let class_signature ~self ~fields =\n { pcsig_self = self; pcsig_fields = fields }\n let class_structure ~self ~fields =\n { pcstr_self = self; pcstr_fields = fields }\n let pcty_constr ~loc x0 x1 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_constr (x0, x1))\n }\n let pcty_signature ~loc x0 =\n { pcty_attributes = []; pcty_loc = loc; pcty_desc = (Pcty_signature x0)\n }\n let pcty_arrow ~loc x0 x1 x2 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_arrow (x0, x1, x2))\n }\n let pcty_extension ~loc x0 =\n { pcty_attributes = []; pcty_loc = loc; pcty_desc = (Pcty_extension x0)\n }\n let pcty_open ~loc x0 x1 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_open (x0, x1))\n }\n let pctf_inherit ~loc x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_inherit x0) }\n let pctf_val ~loc x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_val x0) }\n let pctf_method ~loc x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_method x0) }\n let pctf_constraint ~loc x0 =\n {\n pctf_attributes = [];\n pctf_loc = loc;\n pctf_desc = (Pctf_constraint x0)\n }\n let pctf_attribute ~loc x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_attribute x0)\n }\n let pctf_extension ~loc x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_extension x0)\n }\n let constructor_declaration ~loc ~name ~args ~res =\n {\n pcd_name = name;\n pcd_args = args;\n pcd_res = res;\n pcd_loc = loc;\n pcd_attributes = []\n }\n let ptyp_any ~loc =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = Ptyp_any\n }\n let ptyp_var ~loc x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_var x0)\n }\n let ptyp_arrow ~loc x0 x1 x2 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_arrow (x0, x1, x2))\n }\n let ptyp_tuple ~loc x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_tuple x0)\n }\n let ptyp_constr ~loc x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_constr (x0, x1))\n }\n let ptyp_object ~loc x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_object (x0, x1))\n }\n let ptyp_class ~loc x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_class (x0, x1))\n }\n let ptyp_alias ~loc x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_alias (x0, x1))\n }\n let ptyp_variant ~loc x0 x1 x2 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_variant (x0, x1, x2))\n }\n let ptyp_poly ~loc x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_poly (x0, x1))\n }\n let ptyp_package ~loc x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_package x0)\n }\n let ptyp_extension ~loc x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_extension x0)\n }\n let pdir_string ~loc x0 =\n { pdira_loc = loc; pdira_desc = (Pdir_string x0) }\n let pdir_int ~loc x0 x1 =\n { pdira_loc = loc; pdira_desc = (Pdir_int (x0, x1)) }\n let pdir_ident ~loc x0 =\n { pdira_loc = loc; pdira_desc = (Pdir_ident x0) }\n let pdir_bool ~loc x0 = { pdira_loc = loc; pdira_desc = (Pdir_bool x0) }\n let pexp_ident ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_ident x0)\n }\n let pexp_constant ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_constant x0)\n }\n let pexp_let ~loc x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_let (x0, x1, x2))\n }\n let pexp_function ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_function x0)\n }\n let pexp_fun ~loc x0 x1 x2 x3 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_fun (x0, x1, x2, x3))\n }\n let pexp_apply ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_apply (x0, x1))\n }\n let pexp_match ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_match (x0, x1))\n }\n let pexp_try ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_try (x0, x1))\n }\n let pexp_tuple ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_tuple x0)\n }\n let pexp_construct ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_construct (x0, x1))\n }\n let pexp_variant ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_variant (x0, x1))\n }\n let pexp_record ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_record (x0, x1))\n }\n let pexp_field ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_field (x0, x1))\n }\n let pexp_setfield ~loc x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_setfield (x0, x1, x2))\n }\n let pexp_array ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_array x0)\n }\n let pexp_ifthenelse ~loc x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_ifthenelse (x0, x1, x2))\n }\n let pexp_sequence ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_sequence (x0, x1))\n }\n let pexp_while ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_while (x0, x1))\n }\n let pexp_for ~loc x0 x1 x2 x3 x4 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_for (x0, x1, x2, x3, x4))\n }\n let pexp_constraint ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_constraint (x0, x1))\n }\n let pexp_coerce ~loc x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_coerce (x0, x1, x2))\n }\n let pexp_send ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_send (x0, x1))\n }\n let pexp_new ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_new x0)\n }\n let pexp_setinstvar ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_setinstvar (x0, x1))\n }\n let pexp_override ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_override x0)\n }\n let pexp_letmodule ~loc x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letmodule (x0, x1, x2))\n }\n let pexp_letexception ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letexception (x0, x1))\n }\n let pexp_assert ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_assert x0)\n }\n let pexp_lazy ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_lazy x0)\n }\n let pexp_poly ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_poly (x0, x1))\n }\n let pexp_object ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_object x0)\n }\n let pexp_newtype ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_newtype (x0, x1))\n }\n let pexp_pack ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_pack x0)\n }\n let pexp_open ~loc x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_open (x0, x1))\n }\n let pexp_letop ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letop x0)\n }\n let pexp_extension ~loc x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_extension x0)\n }\n let pexp_unreachable ~loc =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = Pexp_unreachable\n }\n let extension_constructor ~loc ~name ~kind =\n {\n pext_name = name;\n pext_kind = kind;\n pext_loc = loc;\n pext_attributes = []\n }\n let include_infos ~loc mod_ =\n { pincl_mod = mod_; pincl_loc = loc; pincl_attributes = [] }\n let label_declaration ~loc ~name ~mutable_ ~type_ =\n {\n pld_name = name;\n pld_mutable = mutable_;\n pld_type = type_;\n pld_loc = loc;\n pld_attributes = []\n }\n let letop ~let_ ~ands ~body = { let_; ands; body }\n let location ~start ~end_ ~ghost =\n { loc_start = start; loc_end = end_; loc_ghost = ghost }\n let module_binding ~loc ~name ~expr =\n { pmb_name = name; pmb_expr = expr; pmb_attributes = []; pmb_loc = loc\n }\n let module_declaration ~loc ~name ~type_ =\n { pmd_name = name; pmd_type = type_; pmd_attributes = []; pmd_loc = loc\n }\n let pmod_ident ~loc x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_ident x0) }\n let pmod_structure ~loc x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_structure x0)\n }\n let pmod_functor ~loc x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_functor (x0, x1))\n }\n let pmod_apply ~loc x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_apply (x0, x1))\n }\n let pmod_constraint ~loc x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_constraint (x0, x1))\n }\n let pmod_unpack ~loc x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_unpack x0) }\n let pmod_extension ~loc x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_extension x0)\n }\n let module_substitution ~loc ~name ~manifest =\n {\n pms_name = name;\n pms_manifest = manifest;\n pms_attributes = [];\n pms_loc = loc\n }\n let pmty_ident ~loc x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_ident x0) }\n let pmty_signature ~loc x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_signature x0)\n }\n let pmty_functor ~loc x0 x1 =\n {\n pmty_attributes = [];\n pmty_loc = loc;\n pmty_desc = (Pmty_functor (x0, x1))\n }\n let pmty_with ~loc x0 x1 =\n {\n pmty_attributes = [];\n pmty_loc = loc;\n pmty_desc = (Pmty_with (x0, x1))\n }\n let pmty_typeof ~loc x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_typeof x0) }\n let pmty_extension ~loc x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_extension x0)\n }\n let pmty_alias ~loc x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_alias x0) }\n let module_type_declaration ~loc ~name ~type_ =\n {\n pmtd_name = name;\n pmtd_type = type_;\n pmtd_attributes = [];\n pmtd_loc = loc\n }\n let otag ~loc x0 x1 =\n { pof_attributes = []; pof_loc = loc; pof_desc = (Otag (x0, x1)) }\n let oinherit ~loc x0 =\n { pof_attributes = []; pof_loc = loc; pof_desc = (Oinherit x0) }\n let open_infos ~loc ~expr ~override =\n {\n popen_expr = expr;\n popen_override = override;\n popen_loc = loc;\n popen_attributes = []\n }\n let ppat_any ~loc =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = Ppat_any\n }\n let ppat_var ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_var x0)\n }\n let ppat_alias ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_alias (x0, x1))\n }\n let ppat_constant ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_constant x0)\n }\n let ppat_interval ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_interval (x0, x1))\n }\n let ppat_tuple ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_tuple x0)\n }\n let ppat_construct ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_construct (x0, x1))\n }\n let ppat_variant ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_variant (x0, x1))\n }\n let ppat_record ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_record (x0, x1))\n }\n let ppat_array ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_array x0)\n }\n let ppat_or ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_or (x0, x1))\n }\n let ppat_constraint ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_constraint (x0, x1))\n }\n let ppat_type ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_type x0)\n }\n let ppat_lazy ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_lazy x0)\n }\n let ppat_unpack ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_unpack x0)\n }\n let ppat_exception ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_exception x0)\n }\n let ppat_extension ~loc x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_extension x0)\n }\n let ppat_open ~loc x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_open (x0, x1))\n }\n let position ~fname ~lnum ~bol ~cnum =\n { pos_fname = fname; pos_lnum = lnum; pos_bol = bol; pos_cnum = cnum }\n let rtag ~loc x0 x1 x2 =\n { prf_attributes = []; prf_loc = loc; prf_desc = (Rtag (x0, x1, x2)) }\n let rinherit ~loc x0 =\n { prf_attributes = []; prf_loc = loc; prf_desc = (Rinherit x0) }\n let psig_value ~loc x0 = { psig_loc = loc; psig_desc = (Psig_value x0) }\n let psig_type ~loc x0 x1 =\n { psig_loc = loc; psig_desc = (Psig_type (x0, x1)) }\n let psig_typesubst ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_typesubst x0) }\n let psig_typext ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_typext x0) }\n let psig_exception ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_exception x0) }\n let psig_module ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_module x0) }\n let psig_modsubst ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_modsubst x0) }\n let psig_recmodule ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_recmodule x0) }\n let psig_modtype ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_modtype x0) }\n let psig_open ~loc x0 = { psig_loc = loc; psig_desc = (Psig_open x0) }\n let psig_include ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_include x0) }\n let psig_class ~loc x0 = { psig_loc = loc; psig_desc = (Psig_class x0) }\n let psig_class_type ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_class_type x0) }\n let psig_attribute ~loc x0 =\n { psig_loc = loc; psig_desc = (Psig_attribute x0) }\n let psig_extension ~loc x0 x1 =\n { psig_loc = loc; psig_desc = (Psig_extension (x0, x1)) }\n let pstr_eval ~loc x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_eval (x0, x1)) }\n let pstr_value ~loc x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_value (x0, x1)) }\n let pstr_primitive ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_primitive x0) }\n let pstr_type ~loc x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_type (x0, x1)) }\n let pstr_typext ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_typext x0) }\n let pstr_exception ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_exception x0) }\n let pstr_module ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_module x0) }\n let pstr_recmodule ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_recmodule x0) }\n let pstr_modtype ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_modtype x0) }\n let pstr_open ~loc x0 = { pstr_loc = loc; pstr_desc = (Pstr_open x0) }\n let pstr_class ~loc x0 = { pstr_loc = loc; pstr_desc = (Pstr_class x0) }\n let pstr_class_type ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_class_type x0) }\n let pstr_include ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_include x0) }\n let pstr_attribute ~loc x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_attribute x0) }\n let pstr_extension ~loc x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_extension (x0, x1)) }\n let toplevel_directive ~loc ~name ~arg =\n { pdir_name = name; pdir_arg = arg; pdir_loc = loc }\n let type_declaration ~loc ~name ~params ~cstrs ~kind ~private_ \n ~manifest =\n {\n ptype_name = name;\n ptype_params = params;\n ptype_cstrs = cstrs;\n ptype_kind = kind;\n ptype_private = private_;\n ptype_manifest = manifest;\n ptype_attributes = [];\n ptype_loc = loc\n }\n let type_exception ~loc constructor =\n {\n ptyexn_constructor = constructor;\n ptyexn_loc = loc;\n ptyexn_attributes = []\n }\n let type_extension ~loc ~path ~params ~constructors ~private_ =\n {\n ptyext_path = path;\n ptyext_params = params;\n ptyext_constructors = constructors;\n ptyext_private = private_;\n ptyext_loc = loc;\n ptyext_attributes = []\n }\n let value_binding ~loc ~pat ~expr =\n { pvb_pat = pat; pvb_expr = expr; pvb_attributes = []; pvb_loc = loc }\n let value_description ~loc ~name ~type_ ~prim =\n {\n pval_name = name;\n pval_type = type_;\n pval_prim = prim;\n pval_attributes = [];\n pval_loc = loc\n }\n end\nmodule Make(Loc:sig val loc : Location.t end) =\n struct\n let loc = Loc.loc\n let attribute ~name ~payload =\n { attr_name = name; attr_payload = payload; attr_loc = loc }\n let binding_op ~op ~pat ~exp =\n { pbop_op = op; pbop_pat = pat; pbop_exp = exp; pbop_loc = loc }\n let case ~lhs ~guard ~rhs =\n { pc_lhs = lhs; pc_guard = guard; pc_rhs = rhs }\n let pcl_constr x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_constr (x0, x1))\n }\n let pcl_structure x0 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_structure x0) }\n let pcl_fun x0 x1 x2 x3 =\n {\n pcl_attributes = [];\n pcl_loc = loc;\n pcl_desc = (Pcl_fun (x0, x1, x2, x3))\n }\n let pcl_apply x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_apply (x0, x1)) }\n let pcl_let x0 x1 x2 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_let (x0, x1, x2))\n }\n let pcl_constraint x0 x1 =\n {\n pcl_attributes = [];\n pcl_loc = loc;\n pcl_desc = (Pcl_constraint (x0, x1))\n }\n let pcl_extension x0 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_extension x0) }\n let pcl_open x0 x1 =\n { pcl_attributes = []; pcl_loc = loc; pcl_desc = (Pcl_open (x0, x1)) }\n let pcf_inherit x0 x1 x2 =\n {\n pcf_attributes = [];\n pcf_loc = loc;\n pcf_desc = (Pcf_inherit (x0, x1, x2))\n }\n let pcf_val x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_val x0) }\n let pcf_method x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_method x0) }\n let pcf_constraint x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_constraint x0) }\n let pcf_initializer x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_initializer x0) }\n let pcf_attribute x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_attribute x0) }\n let pcf_extension x0 =\n { pcf_attributes = []; pcf_loc = loc; pcf_desc = (Pcf_extension x0) }\n let class_infos ~virt ~params ~name ~expr =\n {\n pci_virt = virt;\n pci_params = params;\n pci_name = name;\n pci_expr = expr;\n pci_loc = loc;\n pci_attributes = []\n }\n let class_signature ~self ~fields =\n { pcsig_self = self; pcsig_fields = fields }\n let class_structure ~self ~fields =\n { pcstr_self = self; pcstr_fields = fields }\n let pcty_constr x0 x1 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_constr (x0, x1))\n }\n let pcty_signature x0 =\n { pcty_attributes = []; pcty_loc = loc; pcty_desc = (Pcty_signature x0)\n }\n let pcty_arrow x0 x1 x2 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_arrow (x0, x1, x2))\n }\n let pcty_extension x0 =\n { pcty_attributes = []; pcty_loc = loc; pcty_desc = (Pcty_extension x0)\n }\n let pcty_open x0 x1 =\n {\n pcty_attributes = [];\n pcty_loc = loc;\n pcty_desc = (Pcty_open (x0, x1))\n }\n let pctf_inherit x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_inherit x0) }\n let pctf_val x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_val x0) }\n let pctf_method x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_method x0) }\n let pctf_constraint x0 =\n {\n pctf_attributes = [];\n pctf_loc = loc;\n pctf_desc = (Pctf_constraint x0)\n }\n let pctf_attribute x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_attribute x0)\n }\n let pctf_extension x0 =\n { pctf_attributes = []; pctf_loc = loc; pctf_desc = (Pctf_extension x0)\n }\n let constructor_declaration ~name ~args ~res =\n {\n pcd_name = name;\n pcd_args = args;\n pcd_res = res;\n pcd_loc = loc;\n pcd_attributes = []\n }\n let ptyp_any =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = Ptyp_any\n }\n let ptyp_var x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_var x0)\n }\n let ptyp_arrow x0 x1 x2 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_arrow (x0, x1, x2))\n }\n let ptyp_tuple x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_tuple x0)\n }\n let ptyp_constr x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_constr (x0, x1))\n }\n let ptyp_object x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_object (x0, x1))\n }\n let ptyp_class x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_class (x0, x1))\n }\n let ptyp_alias x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_alias (x0, x1))\n }\n let ptyp_variant x0 x1 x2 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_variant (x0, x1, x2))\n }\n let ptyp_poly x0 x1 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_poly (x0, x1))\n }\n let ptyp_package x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_package x0)\n }\n let ptyp_extension x0 =\n {\n ptyp_loc_stack = [];\n ptyp_attributes = [];\n ptyp_loc = loc;\n ptyp_desc = (Ptyp_extension x0)\n }\n let pdir_string x0 = { pdira_loc = loc; pdira_desc = (Pdir_string x0) }\n let pdir_int x0 x1 =\n { pdira_loc = loc; pdira_desc = (Pdir_int (x0, x1)) }\n let pdir_ident x0 = { pdira_loc = loc; pdira_desc = (Pdir_ident x0) }\n let pdir_bool x0 = { pdira_loc = loc; pdira_desc = (Pdir_bool x0) }\n let pexp_ident x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_ident x0)\n }\n let pexp_constant x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_constant x0)\n }\n let pexp_let x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_let (x0, x1, x2))\n }\n let pexp_function x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_function x0)\n }\n let pexp_fun x0 x1 x2 x3 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_fun (x0, x1, x2, x3))\n }\n let pexp_apply x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_apply (x0, x1))\n }\n let pexp_match x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_match (x0, x1))\n }\n let pexp_try x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_try (x0, x1))\n }\n let pexp_tuple x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_tuple x0)\n }\n let pexp_construct x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_construct (x0, x1))\n }\n let pexp_variant x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_variant (x0, x1))\n }\n let pexp_record x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_record (x0, x1))\n }\n let pexp_field x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_field (x0, x1))\n }\n let pexp_setfield x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_setfield (x0, x1, x2))\n }\n let pexp_array x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_array x0)\n }\n let pexp_ifthenelse x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_ifthenelse (x0, x1, x2))\n }\n let pexp_sequence x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_sequence (x0, x1))\n }\n let pexp_while x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_while (x0, x1))\n }\n let pexp_for x0 x1 x2 x3 x4 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_for (x0, x1, x2, x3, x4))\n }\n let pexp_constraint x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_constraint (x0, x1))\n }\n let pexp_coerce x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_coerce (x0, x1, x2))\n }\n let pexp_send x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_send (x0, x1))\n }\n let pexp_new x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_new x0)\n }\n let pexp_setinstvar x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_setinstvar (x0, x1))\n }\n let pexp_override x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_override x0)\n }\n let pexp_letmodule x0 x1 x2 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letmodule (x0, x1, x2))\n }\n let pexp_letexception x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letexception (x0, x1))\n }\n let pexp_assert x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_assert x0)\n }\n let pexp_lazy x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_lazy x0)\n }\n let pexp_poly x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_poly (x0, x1))\n }\n let pexp_object x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_object x0)\n }\n let pexp_newtype x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_newtype (x0, x1))\n }\n let pexp_pack x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_pack x0)\n }\n let pexp_open x0 x1 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_open (x0, x1))\n }\n let pexp_letop x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_letop x0)\n }\n let pexp_extension x0 =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = (Pexp_extension x0)\n }\n let pexp_unreachable =\n {\n pexp_loc_stack = [];\n pexp_attributes = [];\n pexp_loc = loc;\n pexp_desc = Pexp_unreachable\n }\n let extension_constructor ~name ~kind =\n {\n pext_name = name;\n pext_kind = kind;\n pext_loc = loc;\n pext_attributes = []\n }\n let include_infos mod_ =\n { pincl_mod = mod_; pincl_loc = loc; pincl_attributes = [] }\n let label_declaration ~name ~mutable_ ~type_ =\n {\n pld_name = name;\n pld_mutable = mutable_;\n pld_type = type_;\n pld_loc = loc;\n pld_attributes = []\n }\n let letop ~let_ ~ands ~body = { let_; ands; body }\n let location ~start ~end_ ~ghost =\n { loc_start = start; loc_end = end_; loc_ghost = ghost }\n let module_binding ~name ~expr =\n { pmb_name = name; pmb_expr = expr; pmb_attributes = []; pmb_loc = loc\n }\n let module_declaration ~name ~type_ =\n { pmd_name = name; pmd_type = type_; pmd_attributes = []; pmd_loc = loc\n }\n let pmod_ident x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_ident x0) }\n let pmod_structure x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_structure x0)\n }\n let pmod_functor x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_functor (x0, x1))\n }\n let pmod_apply x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_apply (x0, x1))\n }\n let pmod_constraint x0 x1 =\n {\n pmod_attributes = [];\n pmod_loc = loc;\n pmod_desc = (Pmod_constraint (x0, x1))\n }\n let pmod_unpack x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_unpack x0) }\n let pmod_extension x0 =\n { pmod_attributes = []; pmod_loc = loc; pmod_desc = (Pmod_extension x0)\n }\n let module_substitution ~name ~manifest =\n {\n pms_name = name;\n pms_manifest = manifest;\n pms_attributes = [];\n pms_loc = loc\n }\n let pmty_ident x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_ident x0) }\n let pmty_signature x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_signature x0)\n }\n let pmty_functor x0 x1 =\n {\n pmty_attributes = [];\n pmty_loc = loc;\n pmty_desc = (Pmty_functor (x0, x1))\n }\n let pmty_with x0 x1 =\n {\n pmty_attributes = [];\n pmty_loc = loc;\n pmty_desc = (Pmty_with (x0, x1))\n }\n let pmty_typeof x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_typeof x0) }\n let pmty_extension x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_extension x0)\n }\n let pmty_alias x0 =\n { pmty_attributes = []; pmty_loc = loc; pmty_desc = (Pmty_alias x0) }\n let module_type_declaration ~name ~type_ =\n {\n pmtd_name = name;\n pmtd_type = type_;\n pmtd_attributes = [];\n pmtd_loc = loc\n }\n let otag x0 x1 =\n { pof_attributes = []; pof_loc = loc; pof_desc = (Otag (x0, x1)) }\n let oinherit x0 =\n { pof_attributes = []; pof_loc = loc; pof_desc = (Oinherit x0) }\n let open_infos ~expr ~override =\n {\n popen_expr = expr;\n popen_override = override;\n popen_loc = loc;\n popen_attributes = []\n }\n let ppat_any =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = Ppat_any\n }\n let ppat_var x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_var x0)\n }\n let ppat_alias x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_alias (x0, x1))\n }\n let ppat_constant x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_constant x0)\n }\n let ppat_interval x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_interval (x0, x1))\n }\n let ppat_tuple x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_tuple x0)\n }\n let ppat_construct x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_construct (x0, x1))\n }\n let ppat_variant x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_variant (x0, x1))\n }\n let ppat_record x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_record (x0, x1))\n }\n let ppat_array x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_array x0)\n }\n let ppat_or x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_or (x0, x1))\n }\n let ppat_constraint x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_constraint (x0, x1))\n }\n let ppat_type x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_type x0)\n }\n let ppat_lazy x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_lazy x0)\n }\n let ppat_unpack x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_unpack x0)\n }\n let ppat_exception x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_exception x0)\n }\n let ppat_extension x0 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_extension x0)\n }\n let ppat_open x0 x1 =\n {\n ppat_loc_stack = [];\n ppat_attributes = [];\n ppat_loc = loc;\n ppat_desc = (Ppat_open (x0, x1))\n }\n let position ~fname ~lnum ~bol ~cnum =\n { pos_fname = fname; pos_lnum = lnum; pos_bol = bol; pos_cnum = cnum }\n let rtag x0 x1 x2 =\n { prf_attributes = []; prf_loc = loc; prf_desc = (Rtag (x0, x1, x2)) }\n let rinherit x0 =\n { prf_attributes = []; prf_loc = loc; prf_desc = (Rinherit x0) }\n let psig_value x0 = { psig_loc = loc; psig_desc = (Psig_value x0) }\n let psig_type x0 x1 =\n { psig_loc = loc; psig_desc = (Psig_type (x0, x1)) }\n let psig_typesubst x0 =\n { psig_loc = loc; psig_desc = (Psig_typesubst x0) }\n let psig_typext x0 = { psig_loc = loc; psig_desc = (Psig_typext x0) }\n let psig_exception x0 =\n { psig_loc = loc; psig_desc = (Psig_exception x0) }\n let psig_module x0 = { psig_loc = loc; psig_desc = (Psig_module x0) }\n let psig_modsubst x0 = { psig_loc = loc; psig_desc = (Psig_modsubst x0) }\n let psig_recmodule x0 =\n { psig_loc = loc; psig_desc = (Psig_recmodule x0) }\n let psig_modtype x0 = { psig_loc = loc; psig_desc = (Psig_modtype x0) }\n let psig_open x0 = { psig_loc = loc; psig_desc = (Psig_open x0) }\n let psig_include x0 = { psig_loc = loc; psig_desc = (Psig_include x0) }\n let psig_class x0 = { psig_loc = loc; psig_desc = (Psig_class x0) }\n let psig_class_type x0 =\n { psig_loc = loc; psig_desc = (Psig_class_type x0) }\n let psig_attribute x0 =\n { psig_loc = loc; psig_desc = (Psig_attribute x0) }\n let psig_extension x0 x1 =\n { psig_loc = loc; psig_desc = (Psig_extension (x0, x1)) }\n let pstr_eval x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_eval (x0, x1)) }\n let pstr_value x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_value (x0, x1)) }\n let pstr_primitive x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_primitive x0) }\n let pstr_type x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_type (x0, x1)) }\n let pstr_typext x0 = { pstr_loc = loc; pstr_desc = (Pstr_typext x0) }\n let pstr_exception x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_exception x0) }\n let pstr_module x0 = { pstr_loc = loc; pstr_desc = (Pstr_module x0) }\n let pstr_recmodule x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_recmodule x0) }\n let pstr_modtype x0 = { pstr_loc = loc; pstr_desc = (Pstr_modtype x0) }\n let pstr_open x0 = { pstr_loc = loc; pstr_desc = (Pstr_open x0) }\n let pstr_class x0 = { pstr_loc = loc; pstr_desc = (Pstr_class x0) }\n let pstr_class_type x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_class_type x0) }\n let pstr_include x0 = { pstr_loc = loc; pstr_desc = (Pstr_include x0) }\n let pstr_attribute x0 =\n { pstr_loc = loc; pstr_desc = (Pstr_attribute x0) }\n let pstr_extension x0 x1 =\n { pstr_loc = loc; pstr_desc = (Pstr_extension (x0, x1)) }\n let toplevel_directive ~name ~arg =\n { pdir_name = name; pdir_arg = arg; pdir_loc = loc }\n let type_declaration ~name ~params ~cstrs ~kind ~private_ ~manifest \n =\n {\n ptype_name = name;\n ptype_params = params;\n ptype_cstrs = cstrs;\n ptype_kind = kind;\n ptype_private = private_;\n ptype_manifest = manifest;\n ptype_attributes = [];\n ptype_loc = loc\n }\n let type_exception constructor =\n {\n ptyexn_constructor = constructor;\n ptyexn_loc = loc;\n ptyexn_attributes = []\n }\n let type_extension ~path ~params ~constructors ~private_ =\n {\n ptyext_path = path;\n ptyext_params = params;\n ptyext_constructors = constructors;\n ptyext_private = private_;\n ptyext_loc = loc;\n ptyext_attributes = []\n }\n let value_binding ~pat ~expr =\n { pvb_pat = pat; pvb_expr = expr; pvb_attributes = []; pvb_loc = loc }\n let value_description ~name ~type_ ~prim =\n {\n pval_name = name;\n pval_type = type_;\n pval_prim = prim;\n pval_attributes = [];\n pval_loc = loc\n }\n end\n","open! Import\n\nmodule Default = struct\n module Located = struct\n type 'a t = 'a Loc.t\n\n let loc (x : _ t) = x.loc\n let mk ~loc x = { loc; txt = x }\n let map f t = { t with txt = f t.txt }\n let map_lident x = map (fun x -> Longident.Lident x) x\n let lident ~loc x = mk ~loc (Longident.parse x)\n end\n\n include Ast_builder_generated.M\n\n let pstr_value_list ~loc rec_flag = function\n | [] -> []\n | vbs -> [ pstr_value ~loc rec_flag vbs ]\n\n let nonrec_type_declaration ~loc:_ ~name:_ ~params:_ ~cstrs:_ ~kind:_\n ~private_:_ ~manifest:_ =\n failwith\n \"Ppxlib.Ast_builder.nonrec_type_declaration: don't use this function\"\n\n let eint ~loc t = pexp_constant ~loc (Pconst_integer (Int.to_string t, None))\n let echar ~loc t = pexp_constant ~loc (Pconst_char t)\n let estring ~loc t = pexp_constant ~loc (Pconst_string (t, loc, None))\n let efloat ~loc t = pexp_constant ~loc (Pconst_float (t, None))\n\n let eint32 ~loc t =\n pexp_constant ~loc (Pconst_integer (Int32.to_string t, Some 'l'))\n\n let eint64 ~loc t =\n pexp_constant ~loc (Pconst_integer (Int64.to_string t, Some 'L'))\n\n let enativeint ~loc t =\n pexp_constant ~loc (Pconst_integer (Nativeint.to_string t, Some 'n'))\n\n let pint ~loc t = ppat_constant ~loc (Pconst_integer (Int.to_string t, None))\n let pchar ~loc t = ppat_constant ~loc (Pconst_char t)\n let pstring ~loc t = ppat_constant ~loc (Pconst_string (t, loc, None))\n let pfloat ~loc t = ppat_constant ~loc (Pconst_float (t, None))\n\n let pint32 ~loc t =\n ppat_constant ~loc (Pconst_integer (Int32.to_string t, Some 'l'))\n\n let pint64 ~loc t =\n ppat_constant ~loc (Pconst_integer (Int64.to_string t, Some 'L'))\n\n let pnativeint ~loc t =\n ppat_constant ~loc (Pconst_integer (Nativeint.to_string t, Some 'n'))\n\n let ebool ~loc t =\n pexp_construct ~loc (Located.lident ~loc (Bool.to_string t)) None\n\n let pbool ~loc t =\n ppat_construct ~loc (Located.lident ~loc (Bool.to_string t)) None\n\n let evar ~loc v = pexp_ident ~loc (Located.mk ~loc (Longident.parse v))\n let pvar ~loc v = ppat_var ~loc (Located.mk ~loc v)\n let eunit ~loc = pexp_construct ~loc (Located.lident ~loc \"()\") None\n let punit ~loc = ppat_construct ~loc (Located.lident ~loc \"()\") None\n let pexp_tuple ~loc l = match l with [ x ] -> x | _ -> pexp_tuple ~loc l\n let ppat_tuple ~loc l = match l with [ x ] -> x | _ -> ppat_tuple ~loc l\n let ptyp_tuple ~loc l = match l with [ x ] -> x | _ -> ptyp_tuple ~loc l\n\n let pexp_tuple_opt ~loc l =\n match l with [] -> None | _ :: _ -> Some (pexp_tuple ~loc l)\n\n let ppat_tuple_opt ~loc l =\n match l with [] -> None | _ :: _ -> Some (ppat_tuple ~loc l)\n\n let ptyp_poly ~loc vars ty =\n match vars with [] -> ty | _ -> ptyp_poly ~loc vars ty\n\n let pexp_apply ~loc e el =\n match (e, el) with\n | _, [] -> e\n | { pexp_desc = Pexp_apply (e, args); pexp_attributes = []; _ }, _ ->\n { e with pexp_desc = Pexp_apply (e, args @ el) }\n | _ -> pexp_apply ~loc e el\n\n let eapply ~loc e el =\n pexp_apply ~loc e (List.map el ~f:(fun e -> (Asttypes.Nolabel, e)))\n\n let eabstract ~loc ps e =\n List.fold_right ps ~init:e ~f:(fun p e ->\n pexp_fun ~loc Asttypes.Nolabel None p e)\n\n let esequence ~loc el =\n match el with\n | [] -> eunit ~loc\n | hd :: tl ->\n List.fold_left tl ~init:hd ~f:(fun acc e -> pexp_sequence ~loc acc e)\n\n let pconstruct cd arg =\n ppat_construct ~loc:cd.pcd_loc (Located.map_lident cd.pcd_name) arg\n\n let econstruct cd arg =\n pexp_construct ~loc:cd.pcd_loc (Located.map_lident cd.pcd_name) arg\n\n let rec elist ~loc l =\n match l with\n | [] -> pexp_construct ~loc (Located.mk ~loc (Longident.Lident \"[]\")) None\n | x :: l ->\n pexp_construct ~loc\n (Located.mk ~loc (Longident.Lident \"::\"))\n (Some (pexp_tuple ~loc [ x; elist ~loc l ]))\n\n let rec plist ~loc l =\n match l with\n | [] -> ppat_construct ~loc (Located.mk ~loc (Longident.Lident \"[]\")) None\n | x :: l ->\n ppat_construct ~loc\n (Located.mk ~loc (Longident.Lident \"::\"))\n (Some (ppat_tuple ~loc [ x; plist ~loc l ]))\n\n let unapplied_type_constr_conv_without_apply ~loc (ident : Longident.t) ~f =\n match ident with\n | Lident n -> pexp_ident ~loc { txt = Lident (f n); loc }\n | Ldot (path, n) -> pexp_ident ~loc { txt = Ldot (path, f n); loc }\n | Lapply _ ->\n Location.raise_errorf ~loc \"unexpected applicative functor type\"\n\n let type_constr_conv ~loc:apply_loc { Loc.loc; txt = longident } ~f args =\n let loc = { loc with loc_ghost = true } in\n match (longident : Longident.t) with\n | Lident _ | Ldot ((Lident _ | Ldot _), _) | Lapply _ -> (\n let ident =\n unapplied_type_constr_conv_without_apply longident ~loc ~f\n in\n match args with\n | [] -> ident\n | _ :: _ -> eapply ~loc:apply_loc ident args)\n | Ldot ((Lapply _ as module_path), n) ->\n let suffix_n functor_ = String.uncapitalize_ascii functor_ ^ \"__\" ^ n in\n let rec gather_lapply functor_args : Longident.t -> Longident.t * _ =\n function\n | Lapply (rest, arg) -> gather_lapply (arg :: functor_args) rest\n | Lident functor_ -> (Lident (suffix_n functor_), functor_args)\n | Ldot (functor_path, functor_) ->\n (Ldot (functor_path, suffix_n functor_), functor_args)\n in\n let ident, functor_args = gather_lapply [] module_path in\n eapply ~loc:apply_loc\n (unapplied_type_constr_conv_without_apply ident ~loc ~f)\n (List.map functor_args ~f:(fun path ->\n pexp_pack ~loc (pmod_ident ~loc { txt = path; loc }))\n @ args)\n\n let unapplied_type_constr_conv ~loc longident ~f =\n type_constr_conv longident ~loc ~f []\n\n let eta_reduce =\n let rec gather_params acc expr =\n match expr with\n | {\n pexp_desc =\n Pexp_fun (label, None (* no default expression *), subpat, body);\n pexp_attributes = [];\n pexp_loc = _;\n pexp_loc_stack = _;\n } -> (\n match subpat with\n | {\n ppat_desc = Ppat_var name;\n ppat_attributes = [];\n ppat_loc = _;\n ppat_loc_stack = _;\n } ->\n gather_params ((label, name, None) :: acc) body\n | {\n ppat_desc =\n Ppat_constraint\n ( {\n ppat_desc = Ppat_var name;\n ppat_attributes = [];\n ppat_loc = _;\n ppat_loc_stack = _;\n },\n ty );\n ppat_attributes = [];\n ppat_loc = _;\n ppat_loc_stack = _;\n } ->\n (* We reduce [fun (x : ty) -> f x] by rewriting it [(f : ty -> _)]. *)\n gather_params ((label, name, Some ty) :: acc) body\n | _ -> (List.rev acc, expr))\n | _ -> (List.rev acc, expr)\n in\n let annotate ~loc expr params =\n if List.exists params ~f:(fun (_, _, ty) -> Option.is_some ty) then\n let ty =\n List.fold_right params ~init:(ptyp_any ~loc)\n ~f:(fun (param_label, param, ty_opt) acc ->\n let loc = param.loc in\n let ty =\n match ty_opt with None -> ptyp_any ~loc | Some ty -> ty\n in\n ptyp_arrow ~loc param_label ty acc)\n in\n pexp_constraint ~loc expr ty\n else expr\n in\n let rec gather_args n x =\n if n = 0 then Some (x, [])\n else\n match x with\n | {\n pexp_desc = Pexp_apply (body, args);\n pexp_attributes = [];\n pexp_loc = _;\n pexp_loc_stack = _;\n } ->\n if List.length args <= n then\n match gather_args (n - List.length args) body with\n | None -> None\n | Some (body, args') -> Some (body, args' @ args)\n else None\n | _ -> None\n in\n fun expr ->\n let params, body = gather_params [] expr in\n match gather_args (List.length params) body with\n | None -> None\n | Some (({ pexp_desc = Pexp_ident _; _ } as f_ident), args) -> (\n match\n List.for_all2 args params\n ~f:(fun (arg_label, arg) (param_label, param, _) ->\n Poly.( = ) (arg_label : arg_label) param_label\n &&\n match arg with\n | {\n pexp_desc = Pexp_ident { txt = Lident name'; _ };\n pexp_attributes = [];\n pexp_loc = _;\n pexp_loc_stack = _;\n } ->\n String.( = ) name' param.txt\n | _ -> false)\n with\n | false -> None\n | true -> Some (annotate ~loc:expr.pexp_loc f_ident params))\n | _ -> None\n\n let eta_reduce_if_possible expr = Option.value (eta_reduce expr) ~default:expr\n\n let eta_reduce_if_possible_and_nonrec expr ~rec_flag =\n match rec_flag with\n | Recursive -> expr\n | Nonrecursive -> eta_reduce_if_possible expr\nend\n\nmodule type Loc = Ast_builder_intf.Loc\nmodule type S = Ast_builder_intf.S\n\nmodule Make (Loc : sig\n val loc : Location.t\nend) : S = struct\n include Ast_builder_generated.Make (Loc)\n\n let pstr_value_list = Default.pstr_value_list\n\n let nonrec_type_declaration ~name ~params ~cstrs ~kind ~private_ ~manifest =\n Default.nonrec_type_declaration ~loc ~name ~params ~cstrs ~kind ~private_\n ~manifest\n\n module Located = struct\n include Default.Located\n\n let loc _ = Loc.loc\n let mk x = mk ~loc:Loc.loc x\n let lident x = lident ~loc:Loc.loc x\n end\n\n let pexp_tuple l = Default.pexp_tuple ~loc l\n let ppat_tuple l = Default.ppat_tuple ~loc l\n let ptyp_tuple l = Default.ptyp_tuple ~loc l\n let pexp_tuple_opt l = Default.pexp_tuple_opt ~loc l\n let ppat_tuple_opt l = Default.ppat_tuple_opt ~loc l\n let ptyp_poly vars ty = Default.ptyp_poly ~loc vars ty\n let pexp_apply e el = Default.pexp_apply ~loc e el\n let eint t = Default.eint ~loc t\n let echar t = Default.echar ~loc t\n let estring t = Default.estring ~loc t\n let efloat t = Default.efloat ~loc t\n let eint32 t = Default.eint32 ~loc t\n let eint64 t = Default.eint64 ~loc t\n let enativeint t = Default.enativeint ~loc t\n let ebool t = Default.ebool ~loc t\n let evar t = Default.evar ~loc t\n let pint t = Default.pint ~loc t\n let pchar t = Default.pchar ~loc t\n let pstring t = Default.pstring ~loc t\n let pfloat t = Default.pfloat ~loc t\n let pint32 t = Default.pint32 ~loc t\n let pint64 t = Default.pint64 ~loc t\n let pnativeint t = Default.pnativeint ~loc t\n let pbool t = Default.pbool ~loc t\n let pvar t = Default.pvar ~loc t\n let eunit = Default.eunit ~loc\n let punit = Default.punit ~loc\n let econstruct = Default.econstruct\n let pconstruct = Default.pconstruct\n let eapply e el = Default.eapply ~loc e el\n let eabstract ps e = Default.eabstract ~loc ps e\n let esequence el = Default.esequence ~loc el\n let elist l = Default.elist ~loc l\n let plist l = Default.plist ~loc l\n\n let type_constr_conv ident ~f args =\n Default.type_constr_conv ~loc ident ~f args\n\n let unapplied_type_constr_conv ident ~f =\n Default.unapplied_type_constr_conv ~loc ident ~f\n\n let eta_reduce = Default.eta_reduce\n let eta_reduce_if_possible = Default.eta_reduce_if_possible\n\n let eta_reduce_if_possible_and_nonrec =\n Default.eta_reduce_if_possible_and_nonrec\nend\n\nlet make loc =\n (module Make (struct\n let loc = loc\n end) : S)\n","open! Import\nmodule Printexc = Caml.Printexc\n\n(* Small helper to find out who is the caller of a function *)\n\ntype t = Printexc.location option\n\nlet get ~skip =\n let skip = __FILE__ :: skip in\n let stack = Printexc.get_callstack 16 in\n let len = Printexc.raw_backtrace_length stack in\n let rec loop pos =\n if pos = len then None\n else\n match\n Printexc.get_raw_backtrace_slot stack pos\n |> Printexc.convert_raw_backtrace_slot |> Printexc.Slot.location\n with\n | None -> None\n | Some loc ->\n if List.mem ~set:skip loc.filename then loop (pos + 1) else Some loc\n in\n loop 0\n","open! Import\nopen Ast_builder.Default\nmodule Buffer = Caml.Buffer\nmodule Format = Caml.Format\n\nlet lident x = Longident.Lident x\n\nlet core_type_of_type_declaration td =\n let loc = td.ptype_name.loc in\n ptyp_constr ~loc\n (Located.map lident td.ptype_name)\n (List.map td.ptype_params ~f:fst)\n\nlet strip_gen_symbol_suffix =\n let chop n ~or_more string pos f =\n let target = !pos - n in\n while !pos > 0 && (or_more || !pos > target) && f string.[!pos - 1] do\n pos := !pos - 1\n done;\n !pos <= target\n in\n fun string ->\n let pos = ref (String.length string) in\n if\n chop 1 ~or_more:false string pos (Char.equal '_')\n && chop 3 ~or_more:true string pos (function\n | '0' .. '9' -> true\n | _ -> false)\n && chop 2 ~or_more:false string pos (Char.equal '_')\n then String.prefix string !pos\n else string\n\nlet gen_symbol =\n let cnt = ref 0 in\n fun ?(prefix = \"_x\") () ->\n cnt := !cnt + 1;\n let prefix = strip_gen_symbol_suffix prefix in\n Printf.sprintf \"%s__%03i_\" prefix !cnt\n\nlet name_type_params_in_td (td : type_declaration) : type_declaration =\n let prefix_string i =\n (* a, b, ..., y, z, aa, bb, ... *)\n String.make ((i / 26) + 1) (Char.chr (Char.code 'a' + (i mod 26)))\n in\n let name_param i (tp, variance) =\n let ptyp_desc =\n match tp.ptyp_desc with\n | Ptyp_any -> Ptyp_var (gen_symbol ~prefix:(prefix_string i) ())\n | Ptyp_var _ as v -> v\n | _ -> Location.raise_errorf ~loc:tp.ptyp_loc \"not a type parameter\"\n in\n ({ tp with ptyp_desc }, variance)\n in\n { td with ptype_params = List.mapi td.ptype_params ~f:name_param }\n\nlet combinator_type_of_type_declaration td ~f =\n let td = name_type_params_in_td td in\n let result_type =\n f ~loc:td.ptype_name.loc (core_type_of_type_declaration td)\n in\n List.fold_right td.ptype_params ~init:result_type\n ~f:(fun (tp, _variance) acc ->\n let loc = tp.ptyp_loc in\n ptyp_arrow ~loc Nolabel (f ~loc tp) acc)\n\nlet string_of_core_type ct =\n let buf = Buffer.create 128 in\n let ppf = Format.formatter_of_buffer buf in\n Pprintast.core_type ppf ct;\n Format.pp_print_flush ppf ();\n Buffer.contents buf\n\nlet get_type_param_name (ty, _) =\n let loc = ty.ptyp_loc in\n match ty.ptyp_desc with\n | Ptyp_var name -> Located.mk ~loc name\n | _ -> Location.raise_errorf ~loc \"not a type parameter\"\n\nexception Type_is_recursive\n\nclass type_is_recursive rec_flag tds =\n object (self)\n inherit Ast_traverse.iter as super\n val type_names : string list = List.map tds ~f:(fun td -> td.ptype_name.txt)\n method return_true () = raise_notrace Type_is_recursive\n\n method! core_type ctype =\n match ctype.ptyp_desc with\n | Ptyp_arrow _ -> ()\n | Ptyp_constr ({ txt = Longident.Lident id; _ }, _)\n when List.mem ~set:type_names id ->\n self#return_true ()\n | _ -> super#core_type ctype\n\n method! constructor_declaration cd =\n (* Don't recurse through cd.pcd_res *)\n match cd.pcd_args with\n | Pcstr_tuple args -> List.iter args ~f:self#core_type\n | Pcstr_record fields -> List.iter fields ~f:self#label_declaration\n\n method! attributes _ = (* Don't recurse through attributes *)\n ()\n\n method go () =\n match rec_flag with\n | Nonrecursive -> Nonrecursive\n | Recursive -> (\n match List.iter tds ~f:self#type_declaration with\n | exception Type_is_recursive -> Recursive\n | () -> Nonrecursive)\n end\n\nlet really_recursive rec_flag tds = (new type_is_recursive rec_flag tds)#go ()\nlet rec last x l = match l with [] -> x | x :: l -> last x l\n\nlet loc_of_name_and_payload name payload =\n match payload with\n | PStr [] -> name.loc\n | PStr (x :: l) -> { x.pstr_loc with loc_end = (last x l).pstr_loc.loc_end }\n | PSig [] -> name.loc\n | PSig (x :: l) -> { x.psig_loc with loc_end = (last x l).psig_loc.loc_end }\n | PTyp t -> t.ptyp_loc\n | PPat (x, None) -> x.ppat_loc\n | PPat (x, Some e) -> { x.ppat_loc with loc_end = e.pexp_loc.loc_end }\n\nlet loc_of_payload { attr_name; attr_payload; attr_loc = _ } =\n loc_of_name_and_payload attr_name attr_payload\n\nlet loc_of_attribute { attr_name; attr_payload; attr_loc = _ } =\n (* TODO: fix this in the compiler, and move the logic to omp when converting\n from older asts. *)\n (* \"ocaml.doc\" attributes are generated with [Location.none], which is not helpful for\n error messages. *)\n if Poly.( = ) attr_name.loc Location.none then\n loc_of_name_and_payload attr_name attr_payload\n else\n {\n attr_name.loc with\n loc_end = (loc_of_name_and_payload attr_name attr_payload).loc_end;\n }\n\nlet loc_of_extension (name, payload) =\n if Poly.( = ) name.loc Location.none then loc_of_name_and_payload name payload\n else\n { name.loc with loc_end = (loc_of_name_and_payload name payload).loc_end }\n\nlet curry_applications expr =\n let open Ast_builder_generated.M in\n match expr.pexp_desc with\n | Pexp_apply (f, orig_forward_args) ->\n let loc = expr.pexp_loc in\n let rec loop = function\n | [] -> f\n | last_arg :: rev_front_args ->\n pexp_apply ~loc (loop rev_front_args) [ last_arg ]\n in\n loop (List.rev orig_forward_args)\n | _ -> expr\n\nlet rec assert_no_attributes = function\n | [] -> ()\n | { attr_name = name; attr_loc = _; attr_payload = _ } :: rest\n when Name.ignore_checks name.Location.txt ->\n assert_no_attributes rest\n | attr :: _ ->\n let loc = loc_of_attribute attr in\n Location.raise_errorf ~loc \"Attributes not allowed here\"\n\nlet assert_no_attributes_in =\n object\n inherit Ast_traverse.iter\n method! attribute a = assert_no_attributes [ a ]\n end\n\nlet attribute_of_warning loc s =\n {\n attr_name = { loc; txt = \"ocaml.ppwarning\" };\n attr_payload = PStr [ pstr_eval ~loc (estring ~loc s) [] ];\n attr_loc = loc;\n }\n\nlet is_polymorphic_variant =\n let rec check = function\n | { ptyp_desc = Ptyp_variant _; _ } -> `Definitely\n | { ptyp_desc = Ptyp_alias (typ, _); _ } -> check typ\n | { ptyp_desc = Ptyp_constr _; _ } -> `Maybe\n | _ -> `Surely_not\n (* Type vars go here even though they could be polymorphic\n variants, however we don't handle it if they get substituted\n by a polymorphic variant that is then included. *)\n in\n fun td ~sig_ ->\n match td.ptype_kind with\n | Ptype_variant _ | Ptype_record _ | Ptype_open -> `Surely_not\n | Ptype_abstract -> (\n match td.ptype_manifest with\n | None -> if sig_ then `Maybe else `Surely_not\n | Some typ -> check typ)\n\nlet mk_named_sig ~loc ~sg_name ~handle_polymorphic_variant = function\n | [ td ]\n when String.equal td.ptype_name.txt \"t\" && List.is_empty td.ptype_cstrs ->\n if\n (not handle_polymorphic_variant)\n && Poly.( = ) (is_polymorphic_variant td ~sig_:true) `Definitely\n then None\n else\n let arity = List.length td.ptype_params in\n if arity >= 4 then None\n else\n let mty =\n if arity = 0 then sg_name else Printf.sprintf \"%s%d\" sg_name arity\n in\n let td = name_type_params_in_td td in\n let for_subst =\n Ast_helper.Type.mk ~loc td.ptype_name ~params:td.ptype_params\n ~manifest:\n (ptyp_constr ~loc\n (Located.map_lident td.ptype_name)\n (List.map ~f:fst td.ptype_params))\n in\n Some\n (include_infos ~loc\n (pmty_with ~loc\n (pmty_ident ~loc (Located.lident mty ~loc))\n [ Pwith_typesubst (Located.lident ~loc \"t\", for_subst) ]))\n | _ -> None\n","open Import\nopen Ast_pattern0\nlet nolabel =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Nolabel -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Nolabel\")\nlet labelled (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Labelled x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"Labelled\")\nlet optional (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Optional x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"Optional\")\nlet attribute ~name:(T name) ~payload:(T payload) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = name ctx (x.attr_name).loc (x.attr_name).txt k in\n let k = payload ctx loc x.attr_payload k in k)\nlet binding_op ~op:(T op) ~pat:(T pat) ~exp:(T exp) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = op ctx (x.pbop_op).loc (x.pbop_op).txt k in\n let k = pat ctx loc x.pbop_pat k in\n let k = exp ctx loc x.pbop_exp k in k)\nlet case ~lhs:(T lhs) ~guard:(T guard) ~rhs:(T rhs) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = lhs ctx loc x.pc_lhs k in\n let k = guard ctx loc x.pc_guard k in\n let k = rhs ctx loc x.pc_rhs k in k)\nlet pcl_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcl_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pcl_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcl_loc in\n let k = f1 ctx loc x.pcl_attributes k in\n let x = { x with pcl_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pcl_constr (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_constr (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constr\"))\nlet pcl_structure (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_structure x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"structure\"))\nlet pcl_fun (T f0) (T f1) (T f2) (T f3) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_fun (x0, x1, x2, x3) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in\n let k = f2 ctx loc x2 k in let k = f3 ctx loc x3 k in k))\n | _ -> fail loc \"fun\"))\nlet pcl_apply (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_apply (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"apply\"))\nlet pcl_let (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_let (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"let\"))\nlet pcl_constraint (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_constraint (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constraint\"))\nlet pcl_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet pcl_open (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcl_attributes;\n (let loc = x.pcl_loc in\n let x = x.pcl_desc in\n match x with\n | Pcl_open (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"open\"))\nlet pcf_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcf_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pcf_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcf_loc in\n let k = f1 ctx loc x.pcf_attributes k in\n let x = { x with pcf_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pcf_inherit (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_inherit (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"inherit\"))\nlet pcf_val (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_val x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"val\"))\nlet pcf_method (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_method x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"method\"))\nlet pcf_constraint (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_constraint x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"constraint\"))\nlet pcf_initializer (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_initializer x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"initializer\"))\nlet pcf_attribute (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_attribute x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"attribute\"))\nlet pcf_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcf_attributes;\n (let loc = x.pcf_loc in\n let x = x.pcf_desc in\n match x with\n | Pcf_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet cfk_virtual (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Cfk_virtual x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"virtual\")\nlet cfk_concrete (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Cfk_concrete (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"concrete\")\nlet class_infos_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pci_loc in\n let k = f1 ctx loc x.pci_attributes k in\n let x = { x with pci_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet class_infos ~virt:(T virt) ~params:(T params) ~name:(T name) ~expr:(T\n expr) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pci_attributes;\n (let k = virt ctx loc x.pci_virt k in\n let k = params ctx loc x.pci_params k in\n let k = name ctx (x.pci_name).loc (x.pci_name).txt k in\n let k = expr ctx loc x.pci_expr k in k))\nlet class_signature ~self:(T self) ~fields:(T fields) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = self ctx loc x.pcsig_self k in\n let k = fields ctx loc x.pcsig_fields k in k)\nlet class_structure ~self:(T self) ~fields:(T fields) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = self ctx loc x.pcstr_self k in\n let k = fields ctx loc x.pcstr_fields k in k)\nlet pcty_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcty_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pcty_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcty_loc in\n let k = f1 ctx loc x.pcty_attributes k in\n let x = { x with pcty_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pcty_constr (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcty_attributes;\n (let loc = x.pcty_loc in\n let x = x.pcty_desc in\n match x with\n | Pcty_constr (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constr\"))\nlet pcty_signature (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcty_attributes;\n (let loc = x.pcty_loc in\n let x = x.pcty_desc in\n match x with\n | Pcty_signature x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"signature\"))\nlet pcty_arrow (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcty_attributes;\n (let loc = x.pcty_loc in\n let x = x.pcty_desc in\n match x with\n | Pcty_arrow (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"arrow\"))\nlet pcty_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcty_attributes;\n (let loc = x.pcty_loc in\n let x = x.pcty_desc in\n match x with\n | Pcty_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet pcty_open (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcty_attributes;\n (let loc = x.pcty_loc in\n let x = x.pcty_desc in\n match x with\n | Pcty_open (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"open\"))\nlet pctf_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pctf_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pctf_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pctf_loc in\n let k = f1 ctx loc x.pctf_attributes k in\n let x = { x with pctf_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pctf_inherit (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_inherit x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"inherit\"))\nlet pctf_val (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_val x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"val\"))\nlet pctf_method (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_method x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"method\"))\nlet pctf_constraint (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_constraint x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"constraint\"))\nlet pctf_attribute (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_attribute x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"attribute\"))\nlet pctf_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pctf_attributes;\n (let loc = x.pctf_loc in\n let x = x.pctf_desc in\n match x with\n | Pctf_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet closed =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Closed -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Closed\")\nlet open_ =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Open -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Open\")\nlet pconst_integer (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pconst_integer (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"integer\")\nlet pconst_char (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pconst_char x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"char\")\nlet pconst_string (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pconst_string (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"string\")\nlet pconst_float (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pconst_float (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"float\")\nlet pcstr_tuple (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pcstr_tuple x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"tuple\")\nlet pcstr_record (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pcstr_record x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"record\")\nlet constructor_declaration_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pcd_loc in\n let k = f1 ctx loc x.pcd_attributes k in\n let x = { x with pcd_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet constructor_declaration ~name:(T name) ~args:(T args) ~res:(T res) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pcd_attributes;\n (let k = name ctx (x.pcd_name).loc (x.pcd_name).txt k in\n let k = args ctx loc x.pcd_args k in\n let k = res ctx loc x.pcd_res k in k))\nlet ptyp_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ptyp_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet ptyp_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ptyp_loc in\n let k = f1 ctx loc x.ptyp_attributes k in\n let x = { x with ptyp_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet ptyp_any =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_any -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"any\"))\nlet ptyp_var (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_var x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"var\"))\nlet ptyp_arrow (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_arrow (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"arrow\"))\nlet ptyp_tuple (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_tuple x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"tuple\"))\nlet ptyp_constr (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_constr (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constr\"))\nlet ptyp_object (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_object (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"object\"))\nlet ptyp_class (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_class (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"class\"))\nlet ptyp_alias (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_alias (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"alias\"))\nlet ptyp_variant (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_variant (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"variant\"))\nlet ptyp_poly (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_poly (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"poly\"))\nlet ptyp_package (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_package x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"package\"))\nlet ptyp_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyp_attributes;\n (let loc = x.ptyp_loc in\n let x = x.ptyp_desc in\n match x with\n | Ptyp_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet upto =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Upto -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Upto\")\nlet downto_ =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Downto -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Downto\")\nlet pdira_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pdira_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pdir_string (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pdira_loc in\n let x = x.pdira_desc in\n match x with\n | Pdir_string x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"string\")\nlet pdir_int (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pdira_loc in\n let x = x.pdira_desc in\n match x with\n | Pdir_int (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"int\")\nlet pdir_ident (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pdira_loc in\n let x = x.pdira_desc in\n match x with\n | Pdir_ident x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"ident\")\nlet pdir_bool (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pdira_loc in\n let x = x.pdira_desc in\n match x with\n | Pdir_bool x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"bool\")\nlet pexp_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pexp_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pexp_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pexp_loc in\n let k = f1 ctx loc x.pexp_attributes k in\n let x = { x with pexp_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pexp_ident (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_ident x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"ident\"))\nlet pexp_constant (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_constant x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"constant\"))\nlet pexp_let (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_let (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"let\"))\nlet pexp_function (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_function x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"function\"))\nlet pexp_fun (T f0) (T f1) (T f2) (T f3) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_fun (x0, x1, x2, x3) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in\n let k = f2 ctx loc x2 k in let k = f3 ctx loc x3 k in k))\n | _ -> fail loc \"fun\"))\nlet pexp_apply (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_apply (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"apply\"))\nlet pexp_match (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_match (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"match\"))\nlet pexp_try (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_try (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"try\"))\nlet pexp_tuple (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_tuple x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"tuple\"))\nlet pexp_construct (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_construct (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"construct\"))\nlet pexp_variant (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_variant (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"variant\"))\nlet pexp_record (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_record (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"record\"))\nlet pexp_field (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_field (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx x1.loc x1.txt k in k))\n | _ -> fail loc \"field\"))\nlet pexp_setfield (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_setfield (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx x1.loc x1.txt k in\n let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"setfield\"))\nlet pexp_array (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_array x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"array\"))\nlet pexp_ifthenelse (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_ifthenelse (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"ifthenelse\"))\nlet pexp_sequence (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_sequence (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"sequence\"))\nlet pexp_while (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_while (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"while\"))\nlet pexp_for (T f0) (T f1) (T f2) (T f3) (T f4) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_for (x0, x1, x2, x3, x4) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in\n let k = f2 ctx loc x2 k in\n let k = f3 ctx loc x3 k in let k = f4 ctx loc x4 k in k))\n | _ -> fail loc \"for\"))\nlet pexp_constraint (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_constraint (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constraint\"))\nlet pexp_coerce (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_coerce (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"coerce\"))\nlet pexp_send (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_send (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx x1.loc x1.txt k in k))\n | _ -> fail loc \"send\"))\nlet pexp_new (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_new x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"new\"))\nlet pexp_setinstvar (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_setinstvar (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"setinstvar\"))\nlet pexp_override (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_override x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"override\"))\nlet pexp_letmodule (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_letmodule (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"letmodule\"))\nlet pexp_letexception (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_letexception (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"letexception\"))\nlet pexp_assert (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_assert x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"assert\"))\nlet pexp_lazy (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_lazy x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"lazy\"))\nlet pexp_poly (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_poly (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"poly\"))\nlet pexp_object (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_object x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"object\"))\nlet pexp_newtype (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_newtype (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"newtype\"))\nlet pexp_pack (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_pack x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"pack\"))\nlet pexp_open (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_open (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"open\"))\nlet pexp_letop (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_letop x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"letop\"))\nlet pexp_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet pexp_unreachable =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pexp_attributes;\n (let loc = x.pexp_loc in\n let x = x.pexp_desc in\n match x with\n | Pexp_unreachable -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"unreachable\"))\nlet extension_constructor_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pext_loc in\n let k = f1 ctx loc x.pext_attributes k in\n let x = { x with pext_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet extension_constructor ~name:(T name) ~kind:(T kind) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pext_attributes;\n (let k = name ctx (x.pext_name).loc (x.pext_name).txt k in\n let k = kind ctx loc x.pext_kind k in k))\nlet pext_decl (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pext_decl (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"decl\")\nlet pext_rebind (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pext_rebind x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"rebind\")\nlet unit =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Unit -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Unit\")\nlet named (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Named (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"Named\")\nlet include_infos_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pincl_loc in\n let k = f1 ctx loc x.pincl_attributes k in\n let x = { x with pincl_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet include_infos ~mod_:(T mod_) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pincl_attributes;\n (let k = mod_ ctx loc x.pincl_mod k in k))\nlet injective =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Injective -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Injective\")\nlet noinjectivity =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | NoInjectivity -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"NoInjectivity\")\nlet label_declaration_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pld_loc in\n let k = f1 ctx loc x.pld_attributes k in\n let x = { x with pld_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet label_declaration ~name:(T name) ~mutable_:(T mutable_) ~type_:(T\n type_) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pld_attributes;\n (let k = name ctx (x.pld_name).loc (x.pld_name).txt k in\n let k = mutable_ ctx loc x.pld_mutable k in\n let k = type_ ctx loc x.pld_type k in k))\nlet letop ~let_:(T let_) ~ands:(T ands) ~body:(T body) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = let_ ctx loc x.let_ k in\n let k = ands ctx loc x.ands k in\n let k = body ctx loc x.body k in k)\nlet location ~start:(T start) ~end_:(T end_) ~ghost:(T ghost) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = start ctx loc x.loc_start k in\n let k = end_ ctx loc x.loc_end k in\n let k = ghost ctx loc x.loc_ghost k in k)\nlet lident (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Lident x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"Lident\")\nlet ldot (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ldot (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"Ldot\")\nlet lapply (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Lapply (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"Lapply\")\nlet module_binding_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmb_loc in\n let k = f1 ctx loc x.pmb_attributes k in\n let x = { x with pmb_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet module_binding ~name:(T name) ~expr:(T expr) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmb_attributes;\n (let k = name ctx (x.pmb_name).loc (x.pmb_name).txt k in\n let k = expr ctx loc x.pmb_expr k in k))\nlet module_declaration_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmd_loc in\n let k = f1 ctx loc x.pmd_attributes k in\n let x = { x with pmd_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet module_declaration ~name:(T name) ~type_:(T type_) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmd_attributes;\n (let k = name ctx (x.pmd_name).loc (x.pmd_name).txt k in\n let k = type_ ctx loc x.pmd_type k in k))\nlet pmod_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmod_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pmod_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmod_loc in\n let k = f1 ctx loc x.pmod_attributes k in\n let x = { x with pmod_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pmod_ident (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_ident x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"ident\"))\nlet pmod_structure (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_structure x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"structure\"))\nlet pmod_functor (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_functor (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"functor\"))\nlet pmod_apply (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_apply (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"apply\"))\nlet pmod_constraint (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_constraint (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constraint\"))\nlet pmod_unpack (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_unpack x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"unpack\"))\nlet pmod_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmod_attributes;\n (let loc = x.pmod_loc in\n let x = x.pmod_desc in\n match x with\n | Pmod_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet module_substitution_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pms_loc in\n let k = f1 ctx loc x.pms_attributes k in\n let x = { x with pms_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet module_substitution ~name:(T name) ~manifest:(T manifest) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pms_attributes;\n (let k = name ctx (x.pms_name).loc (x.pms_name).txt k in\n let k =\n manifest ctx (x.pms_manifest).loc (x.pms_manifest).txt k in\n k))\nlet pmty_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmty_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pmty_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmty_loc in\n let k = f1 ctx loc x.pmty_attributes k in\n let x = { x with pmty_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet pmty_ident (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_ident x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"ident\"))\nlet pmty_signature (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_signature x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"signature\"))\nlet pmty_functor (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_functor (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"functor\"))\nlet pmty_with (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_with (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"with\"))\nlet pmty_typeof (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_typeof x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"typeof\"))\nlet pmty_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet pmty_alias (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmty_attributes;\n (let loc = x.pmty_loc in\n let x = x.pmty_desc in\n match x with\n | Pmty_alias x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"alias\"))\nlet module_type_declaration_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pmtd_loc in\n let k = f1 ctx loc x.pmtd_attributes k in\n let x = { x with pmtd_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet module_type_declaration ~name:(T name) ~type_:(T type_) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pmtd_attributes;\n (let k = name ctx (x.pmtd_name).loc (x.pmtd_name).txt k in\n let k = type_ ctx loc x.pmtd_type k in k))\nlet immutable =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Immutable -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Immutable\")\nlet mutable_ =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Mutable -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Mutable\")\nlet pof_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pof_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pof_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pof_loc in\n let k = f1 ctx loc x.pof_attributes k in\n let x = { x with pof_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet otag (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pof_attributes;\n (let loc = x.pof_loc in\n let x = x.pof_desc in\n match x with\n | Otag (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"Otag\"))\nlet oinherit (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pof_attributes;\n (let loc = x.pof_loc in\n let x = x.pof_desc in\n match x with\n | Oinherit x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"Oinherit\"))\nlet open_infos_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.popen_loc in\n let k = f1 ctx loc x.popen_attributes k in\n let x = { x with popen_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet open_infos ~expr:(T expr) ~override:(T override) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.popen_attributes;\n (let k = expr ctx loc x.popen_expr k in\n let k = override ctx loc x.popen_override k in k))\nlet override =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Override -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Override\")\nlet fresh =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Fresh -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Fresh\")\nlet ppat_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ppat_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet ppat_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ppat_loc in\n let k = f1 ctx loc x.ppat_attributes k in\n let x = { x with ppat_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet ppat_any =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_any -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"any\"))\nlet ppat_var (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_var x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"var\"))\nlet ppat_alias (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_alias (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in\n let k = f1 ctx x1.loc x1.txt k in k))\n | _ -> fail loc \"alias\"))\nlet ppat_constant (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_constant x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"constant\"))\nlet ppat_interval (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_interval (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"interval\"))\nlet ppat_tuple (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_tuple x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"tuple\"))\nlet ppat_construct (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_construct (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"construct\"))\nlet ppat_variant (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_variant (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"variant\"))\nlet ppat_record (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_record (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"record\"))\nlet ppat_array (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_array x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"array\"))\nlet ppat_or (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_or (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"or\"))\nlet ppat_constraint (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_constraint (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"constraint\"))\nlet ppat_type (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_type x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"type\"))\nlet ppat_lazy (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_lazy x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"lazy\"))\nlet ppat_unpack (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_unpack x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in k))\n | _ -> fail loc \"unpack\"))\nlet ppat_exception (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_exception x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"exception\"))\nlet ppat_extension (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_extension x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"extension\"))\nlet ppat_open (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ppat_attributes;\n (let loc = x.ppat_loc in\n let x = x.ppat_desc in\n match x with\n | Ppat_open (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"open\"))\nlet pstr (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | PStr x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"PStr\")\nlet psig (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | PSig x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"PSig\")\nlet ptyp (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | PTyp x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"PTyp\")\nlet ppat (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | PPat (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"PPat\")\nlet position ~fname:(T fname) ~lnum:(T lnum) ~bol:(T bol) ~cnum:(T cnum) \n =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = fname ctx loc x.pos_fname k in\n let k = lnum ctx loc x.pos_lnum k in\n let k = bol ctx loc x.pos_bol k in\n let k = cnum ctx loc x.pos_cnum k in k)\nlet private_ =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Private -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Private\")\nlet public =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Public -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Public\")\nlet nonrecursive =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Nonrecursive -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Nonrecursive\")\nlet recursive =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Recursive -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Recursive\")\nlet prf_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.prf_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet prf_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.prf_loc in\n let k = f1 ctx loc x.prf_attributes k in\n let x = { x with prf_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet rtag (T f0) (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.prf_attributes;\n (let loc = x.prf_loc in\n let x = x.prf_desc in\n match x with\n | Rtag (x0, x1, x2) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in let k = f2 ctx loc x2 k in k))\n | _ -> fail loc \"Rtag\"))\nlet rinherit (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.prf_attributes;\n (let loc = x.prf_loc in\n let x = x.prf_desc in\n match x with\n | Rinherit x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"Rinherit\"))\nlet psig_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet psig_value (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_value x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"value\")\nlet psig_type (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_type (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"type\")\nlet psig_typesubst (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_typesubst x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"typesubst\")\nlet psig_typext (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_typext x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"typext\")\nlet psig_exception (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_exception x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"exception\")\nlet psig_module (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_module x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"module\")\nlet psig_modsubst (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_modsubst x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"modsubst\")\nlet psig_recmodule (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_recmodule x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"recmodule\")\nlet psig_modtype (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_modtype x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"modtype\")\nlet psig_open (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_open x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"open\")\nlet psig_include (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_include x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"include\")\nlet psig_class (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_class x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"class\")\nlet psig_class_type (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_class_type x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"class_type\")\nlet psig_attribute (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_attribute x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"attribute\")\nlet psig_extension (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.psig_loc in\n let x = x.psig_desc in\n match x with\n | Psig_extension (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"extension\")\nlet pstr_loc (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let k = f1 ctx loc loc k in let k = f2 ctx loc x k in k)\nlet pstr_eval (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_eval (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"eval\")\nlet pstr_value (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_value (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"value\")\nlet pstr_primitive (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_primitive x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"primitive\")\nlet pstr_type (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_type (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"type\")\nlet pstr_typext (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_typext x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"typext\")\nlet pstr_exception (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_exception x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"exception\")\nlet pstr_module (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_module x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"module\")\nlet pstr_recmodule (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_recmodule x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"recmodule\")\nlet pstr_modtype (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_modtype x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"modtype\")\nlet pstr_open (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_open x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"open\")\nlet pstr_class (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_class x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"class\")\nlet pstr_class_type (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_class_type x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"class_type\")\nlet pstr_include (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_include x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"include\")\nlet pstr_attribute (T f0) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_attribute x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"attribute\")\nlet pstr_extension (T f0) (T f1) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pstr_loc in\n let x = x.pstr_desc in\n match x with\n | Pstr_extension (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"extension\")\nlet toplevel_directive ~name:(T name) ~arg:(T arg) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n let k = name ctx (x.pdir_name).loc (x.pdir_name).txt k in\n let k = arg ctx loc x.pdir_arg k in k)\nlet ptop_def (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptop_def x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"def\")\nlet ptop_dir (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptop_dir x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"dir\")\nlet type_declaration_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ptype_loc in\n let k = f1 ctx loc x.ptype_attributes k in\n let x = { x with ptype_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet type_declaration ~name:(T name) ~params:(T params) ~cstrs:(T cstrs) \n ~kind:(T kind) ~private_:(T private_) ~manifest:(T manifest) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptype_attributes;\n (let k = name ctx (x.ptype_name).loc (x.ptype_name).txt k in\n let k = params ctx loc x.ptype_params k in\n let k = cstrs ctx loc x.ptype_cstrs k in\n let k = kind ctx loc x.ptype_kind k in\n let k = private_ ctx loc x.ptype_private k in\n let k = manifest ctx loc x.ptype_manifest k in k))\nlet type_exception_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ptyexn_loc in\n let k = f1 ctx loc x.ptyexn_attributes k in\n let x = { x with ptyexn_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet type_exception ~constructor:(T constructor) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyexn_attributes;\n (let k = constructor ctx loc x.ptyexn_constructor k in k))\nlet type_extension_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.ptyext_loc in\n let k = f1 ctx loc x.ptyext_attributes k in\n let x = { x with ptyext_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet type_extension ~path:(T path) ~params:(T params) ~constructors:(T\n constructors) ~private_:(T private_) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.ptyext_attributes;\n (let k = path ctx (x.ptyext_path).loc (x.ptyext_path).txt k in\n let k = params ctx loc x.ptyext_params k in\n let k = constructors ctx loc x.ptyext_constructors k in\n let k = private_ ctx loc x.ptyext_private k in k))\nlet ptype_abstract =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptype_abstract -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"abstract\")\nlet ptype_variant (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptype_variant x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"variant\")\nlet ptype_record (T f0) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptype_record x0 ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx loc x0 k in k))\n | _ -> fail loc \"record\")\nlet ptype_open =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Ptype_open -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"open\")\nlet value_binding_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pvb_loc in\n let k = f1 ctx loc x.pvb_attributes k in\n let x = { x with pvb_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet value_binding ~pat:(T pat) ~expr:(T expr) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pvb_attributes;\n (let k = pat ctx loc x.pvb_pat k in\n let k = expr ctx loc x.pvb_expr k in k))\nlet value_description_attributes (T f1) (T f2) =\n T\n (fun ctx ->\n fun _loc ->\n fun x ->\n fun k ->\n let loc = x.pval_loc in\n let k = f1 ctx loc x.pval_attributes k in\n let x = { x with pval_attributes = [] } in\n let k = f2 ctx loc x k in k)\nlet value_description ~name:(T name) ~type_:(T type_) ~prim:(T prim) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n Common.assert_no_attributes x.pval_attributes;\n (let k = name ctx (x.pval_name).loc (x.pval_name).txt k in\n let k = type_ ctx loc x.pval_type k in\n let k = prim ctx loc x.pval_prim k in k))\nlet covariant =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Covariant -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Covariant\")\nlet contravariant =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Contravariant -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Contravariant\")\nlet novariance =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | NoVariance -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"NoVariance\")\nlet virtual_ =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Virtual -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Virtual\")\nlet concrete =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Concrete -> (ctx.matched <- (ctx.matched + 1); k)\n | _ -> fail loc \"Concrete\")\nlet pwith_type (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pwith_type (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"type\")\nlet pwith_module (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pwith_module (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx x1.loc x1.txt k in k))\n | _ -> fail loc \"module\")\nlet pwith_typesubst (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pwith_typesubst (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx loc x1 k in k))\n | _ -> fail loc \"typesubst\")\nlet pwith_modsubst (T f0) (T f1) =\n T\n (fun ctx ->\n fun loc ->\n fun x ->\n fun k ->\n match x with\n | Pwith_modsubst (x0, x1) ->\n (ctx.matched <- (ctx.matched + 1);\n (let k = f0 ctx x0.loc x0.txt k in\n let k = f1 ctx x1.loc x1.txt k in k))\n | _ -> fail loc \"modsubst\")\n","open! Import\ninclude Ast_pattern0\n\nlet save_context ctx = ctx.matched\nlet restore_context ctx backup = ctx.matched <- backup\nlet incr_matched c = c.matched <- c.matched + 1\n\nlet parse (T f) loc ?on_error x k =\n try f { matched = 0 } loc x k\n with Expected (loc, expected) -> (\n match on_error with\n | None -> Location.raise_errorf ~loc \"%s expected\" expected\n | Some f -> f ())\n\nmodule Packed = struct\n type ('a, 'b) t = T : ('a, 'b, 'c) Ast_pattern0.t * 'b -> ('a, 'c) t\n\n let create t f = T (t, f)\n let parse (T (t, f)) loc x = parse t loc x f\nend\n\nlet __ =\n T\n (fun ctx _loc x k ->\n incr_matched ctx;\n k x)\n\nlet __' =\n T\n (fun ctx loc x k ->\n incr_matched ctx;\n k { loc; txt = x })\n\nlet drop =\n T\n (fun ctx _loc _ k ->\n incr_matched ctx;\n k)\n\nlet as__ (T f1) =\n T\n (fun ctx loc x k ->\n let k = f1 ctx loc x (k x) in\n k)\n\nlet cst ~to_string ?(equal = Poly.equal) v =\n T\n (fun ctx loc x k ->\n if equal x v then (\n incr_matched ctx;\n k)\n else fail loc (to_string v))\n\nlet int v = cst ~to_string:Int.to_string v\nlet char v = cst ~to_string:(Printf.sprintf \"%C\") v\nlet string v = cst ~to_string:(Printf.sprintf \"%S\") v\nlet float v = cst ~to_string:Float.to_string v\nlet int32 v = cst ~to_string:Int32.to_string v\nlet int64 v = cst ~to_string:Int64.to_string v\nlet nativeint v = cst ~to_string:Nativeint.to_string v\nlet bool v = cst ~to_string:Bool.to_string v\n\nlet false_ =\n T\n (fun ctx loc x k ->\n match x with\n | false ->\n ctx.matched <- ctx.matched + 1;\n k\n | _ -> fail loc \"false\")\n\nlet true_ =\n T\n (fun ctx loc x k ->\n match x with\n | true ->\n ctx.matched <- ctx.matched + 1;\n k\n | _ -> fail loc \"true\")\n\nlet nil =\n T\n (fun ctx loc x k ->\n match x with\n | [] ->\n ctx.matched <- ctx.matched + 1;\n k\n | _ -> fail loc \"[]\")\n\nlet ( ^:: ) (T f0) (T f1) =\n T\n (fun ctx loc x k ->\n match x with\n | x0 :: x1 ->\n ctx.matched <- ctx.matched + 1;\n let k = f0 ctx loc x0 k in\n let k = f1 ctx loc x1 k in\n k\n | _ -> fail loc \"::\")\n\nlet none =\n T\n (fun ctx loc x k ->\n match x with\n | None ->\n ctx.matched <- ctx.matched + 1;\n k\n | _ -> fail loc \"None\")\n\nlet some (T f0) =\n T\n (fun ctx loc x k ->\n match x with\n | Some x0 ->\n ctx.matched <- ctx.matched + 1;\n let k = f0 ctx loc x0 k in\n k\n | _ -> fail loc \"Some\")\n\nlet pair (T f1) (T f2) =\n T\n (fun ctx loc (x1, x2) k ->\n let k = f1 ctx loc x1 k in\n let k = f2 ctx loc x2 k in\n k)\n\nlet ( ** ) = pair\n\nlet triple (T f1) (T f2) (T f3) =\n T\n (fun ctx loc (x1, x2, x3) k ->\n let k = f1 ctx loc x1 k in\n let k = f2 ctx loc x2 k in\n let k = f3 ctx loc x3 k in\n k)\n\nlet alt (T f1) (T f2) =\n T\n (fun ctx loc x k ->\n let backup = save_context ctx in\n try f1 ctx loc x k\n with e1 -> (\n let m1 = save_context ctx in\n restore_context ctx backup;\n try f2 ctx loc x k\n with e2 ->\n let m2 = save_context ctx in\n if m1 >= m2 then (\n restore_context ctx m1;\n raise e1)\n else raise e2))\n\nlet ( ||| ) = alt\nlet map (T func) ~f = T (fun ctx loc x k -> func ctx loc x (f k))\nlet map' (T func) ~f = T (fun ctx loc x k -> func ctx loc x (f loc k))\nlet map_result (T func) ~f = T (fun ctx loc x k -> f (func ctx loc x k))\nlet ( >>| ) t f = map t ~f\nlet map0 (T func) ~f = T (fun ctx loc x k -> func ctx loc x (k f))\nlet map1 (T func) ~f = T (fun ctx loc x k -> func ctx loc x (fun a -> k (f a)))\n\nlet map2 (T func) ~f =\n T (fun ctx loc x k -> func ctx loc x (fun a b -> k (f a b)))\n\nlet map0' (T func) ~f = T (fun ctx loc x k -> func ctx loc x (k (f loc)))\n\nlet map1' (T func) ~f =\n T (fun ctx loc x k -> func ctx loc x (fun a -> k (f loc a)))\n\nlet map2' (T func) ~f =\n T (fun ctx loc x k -> func ctx loc x (fun a b -> k (f loc a b)))\n\nlet alt_option some none =\n alt (map1 some ~f:(fun x -> Some x)) (map0 none ~f:None)\n\nlet many (T f) =\n T (fun ctx loc l k -> k (List.map l ~f:(fun x -> f ctx loc x (fun x -> x))))\n\nlet loc (T f) = T (fun ctx _loc (x : _ Loc.t) k -> f ctx x.loc x.txt k)\nlet pack0 t = map t ~f:(fun f -> f ())\nlet pack2 t = map t ~f:(fun f x y -> f (x, y))\nlet pack3 t = map t ~f:(fun f x y z -> f (x, y, z))\n\ninclude Ast_pattern_generated\n\nlet echar t = pexp_constant (pconst_char t)\nlet estring t = pexp_constant (pconst_string t drop drop)\nlet efloat t = pexp_constant (pconst_float t drop)\nlet pchar t = ppat_constant (pconst_char t)\nlet pstring t = ppat_constant (pconst_string t drop drop)\nlet pfloat t = ppat_constant (pconst_float t drop)\nlet int' (T f) = T (fun ctx loc x k -> f ctx loc (int_of_string x) k)\nlet int32' (T f) = T (fun ctx loc x k -> f ctx loc (Int32.of_string x) k)\nlet int64' (T f) = T (fun ctx loc x k -> f ctx loc (Int64.of_string x) k)\n\nlet nativeint' (T f) =\n T (fun ctx loc x k -> f ctx loc (Nativeint.of_string x) k)\n\nlet const_int t = pconst_integer (int' t) none\nlet const_int32 t = pconst_integer (int32' t) (some (char 'l'))\nlet const_int64 t = pconst_integer (int64' t) (some (char 'L'))\nlet const_nativeint t = pconst_integer (nativeint' t) (some (char 'n'))\nlet eint t = pexp_constant (const_int t)\nlet eint32 t = pexp_constant (const_int32 t)\nlet eint64 t = pexp_constant (const_int64 t)\nlet enativeint t = pexp_constant (const_nativeint t)\nlet pint t = ppat_constant (const_int t)\nlet pint32 t = ppat_constant (const_int32 t)\nlet pint64 t = ppat_constant (const_int64 t)\nlet pnativeint t = ppat_constant (const_nativeint t)\nlet single_expr_payload t = pstr (pstr_eval t nil ^:: nil)\nlet no_label t = cst Asttypes.Nolabel ~to_string:(fun _ -> \"Nolabel\") ** t\n\nlet extension (T f1) (T f2) =\n T\n (fun ctx loc ((name : _ Loc.t), payload) k ->\n let k = f1 ctx name.loc name.txt k in\n let k = f2 ctx loc payload k in\n k)\n\nlet rec parse_elist (e : Parsetree.expression) acc =\n Common.assert_no_attributes e.pexp_attributes;\n match e.pexp_desc with\n | Pexp_construct ({ txt = Lident \"[]\"; _ }, None) -> List.rev acc\n | Pexp_construct ({ txt = Lident \"::\"; _ }, Some arg) -> (\n Common.assert_no_attributes arg.pexp_attributes;\n match arg.pexp_desc with\n | Pexp_tuple [ hd; tl ] -> parse_elist tl (hd :: acc)\n | _ -> fail arg.pexp_loc \"list\")\n | _ -> fail e.pexp_loc \"list\"\n\nlet elist (T f) =\n T\n (fun ctx _loc e k ->\n let l = parse_elist e [] in\n incr_matched ctx;\n k (List.map l ~f:(fun x -> f ctx x.Parsetree.pexp_loc x (fun x -> x))))\n\nlet esequence (T f) =\n T\n (fun ctx _loc e k ->\n let rec parse_seq expr acc =\n match expr.pexp_desc with\n | Pexp_sequence (expr, next) -> parse_seq next (expr :: acc)\n | _ -> expr :: acc\n in\n k\n (List.rev_map (parse_seq e []) ~f:(fun expr ->\n f ctx expr.pexp_loc expr (fun x -> x))))\n\nlet of_func f = T f\nlet to_func (T f) = f\n","open! Import\nopen Common\n\ntype (_, _) equality = Eq : ('a, 'a) equality | Ne : (_, _) equality\n\nmodule Context = struct\n type 'a t =\n | Class_expr : class_expr t\n | Class_field : class_field t\n | Class_type : class_type t\n | Class_type_field : class_type_field t\n | Core_type : core_type t\n | Expression : expression t\n | Module_expr : module_expr t\n | Module_type : module_type t\n | Pattern : pattern t\n | Signature_item : signature_item t\n | Structure_item : structure_item t\n | Ppx_import : type_declaration t\n\n type packed = T : _ t -> packed\n\n let class_expr = Class_expr\n let class_field = Class_field\n let class_type = Class_type\n let class_type_field = Class_type_field\n let core_type = Core_type\n let expression = Expression\n let module_expr = Module_expr\n let module_type = Module_type\n let pattern = Pattern\n let signature_item = Signature_item\n let structure_item = Structure_item\n\n let desc : type a. a t -> string = function\n | Class_expr -> \"class expression\"\n | Class_field -> \"class field\"\n | Class_type -> \"class type\"\n | Class_type_field -> \"class type field\"\n | Core_type -> \"core type\"\n | Expression -> \"expression\"\n | Module_expr -> \"module expression\"\n | Module_type -> \"module type\"\n | Pattern -> \"pattern\"\n | Signature_item -> \"signature item\"\n | Structure_item -> \"structure item\"\n | Ppx_import -> \"type declaration\"\n\n let eq : type a b. a t -> b t -> (a, b) equality =\n fun a b ->\n match (a, b) with\n | Class_expr, Class_expr -> Eq\n | Class_field, Class_field -> Eq\n | Class_type, Class_type -> Eq\n | Class_type_field, Class_type_field -> Eq\n | Core_type, Core_type -> Eq\n | Expression, Expression -> Eq\n | Module_expr, Module_expr -> Eq\n | Module_type, Module_type -> Eq\n | Pattern, Pattern -> Eq\n | Signature_item, Signature_item -> Eq\n | Structure_item, Structure_item -> Eq\n | Ppx_import, Ppx_import -> Eq\n | _ ->\n assert (Poly.( <> ) (T a) (T b));\n Ne\n\n let get_ppx_import_extension type_decl =\n match type_decl with\n | { ptype_manifest = Some { ptyp_desc = Ptyp_extension (name, _); _ }; _ }\n ->\n let virtual_payload =\n Ast_builder.Default.pstr_type ~loc:type_decl.ptype_loc Recursive\n [ type_decl ]\n in\n let attr = [] in\n Some ((name, PStr [ virtual_payload ]), attr)\n | _ -> None\n\n let get_extension : type a. a t -> a -> (extension * attributes) option =\n fun t x ->\n match (t, x) with\n | Class_expr, { pcl_desc = Pcl_extension e; pcl_attributes = a; _ } ->\n Some (e, a)\n | Class_field, { pcf_desc = Pcf_extension e; pcf_attributes = a; _ } ->\n Some (e, a)\n | Class_type, { pcty_desc = Pcty_extension e; pcty_attributes = a; _ } ->\n Some (e, a)\n | Class_type_field, { pctf_desc = Pctf_extension e; pctf_attributes = a; _ }\n ->\n Some (e, a)\n | Core_type, { ptyp_desc = Ptyp_extension e; ptyp_attributes = a; _ } ->\n Some (e, a)\n | Expression, { pexp_desc = Pexp_extension e; pexp_attributes = a; _ } ->\n Some (e, a)\n | Module_expr, { pmod_desc = Pmod_extension e; pmod_attributes = a; _ } ->\n Some (e, a)\n | Module_type, { pmty_desc = Pmty_extension e; pmty_attributes = a; _ } ->\n Some (e, a)\n | Pattern, { ppat_desc = Ppat_extension e; ppat_attributes = a; _ } ->\n Some (e, a)\n | Signature_item, { psig_desc = Psig_extension (e, a); _ } -> Some (e, a)\n | Structure_item, { pstr_desc = Pstr_extension (e, a); _ } -> Some (e, a)\n | Ppx_import, type_decl -> get_ppx_import_extension type_decl\n | _ -> None\n\n let merge_attributes : type a. a t -> a -> attributes -> a =\n fun t x attrs ->\n match t with\n | Class_expr -> { x with pcl_attributes = x.pcl_attributes @ attrs }\n | Class_field -> { x with pcf_attributes = x.pcf_attributes @ attrs }\n | Class_type -> { x with pcty_attributes = x.pcty_attributes @ attrs }\n | Class_type_field -> { x with pctf_attributes = x.pctf_attributes @ attrs }\n | Core_type -> { x with ptyp_attributes = x.ptyp_attributes @ attrs }\n | Expression -> { x with pexp_attributes = x.pexp_attributes @ attrs }\n | Module_expr -> { x with pmod_attributes = x.pmod_attributes @ attrs }\n | Module_type -> { x with pmty_attributes = x.pmty_attributes @ attrs }\n | Pattern -> { x with ppat_attributes = x.ppat_attributes @ attrs }\n | Signature_item ->\n assert_no_attributes attrs;\n x\n | Structure_item ->\n assert_no_attributes attrs;\n x\n | Ppx_import ->\n assert_no_attributes attrs;\n x\nend\n\nlet registrar =\n Name.Registrar.create ~kind:\"extension\" ~current_file:__FILE__\n ~string_of_context:(fun (Context.T ctx) -> Some (Context.desc ctx))\n\nmodule Make (Callback : sig\n type 'a t\nend) =\nstruct\n type ('a, 'b) payload_parser =\n | Payload_parser :\n ('a, 'b, 'c) Ast_pattern.t * 'b Callback.t\n -> ('a, 'c) payload_parser\n\n type ('context, 'payload) t = {\n name : Name.Pattern.t;\n context : 'context Context.t;\n payload : (payload, 'payload) payload_parser;\n with_arg : bool;\n }\n\n let declare :\n type a.\n with_arg:bool ->\n string ->\n a Context.t ->\n (payload, 'b, 'payload) Ast_pattern.t ->\n 'b Callback.t ->\n (a, 'payload) t =\n fun ~with_arg name context pattern k ->\n (* Check that there is no collisions between ppx_import and core_type\n extensions *)\n (match context with\n | Context.Ppx_import ->\n Name.Registrar.check_collisions registrar (Context.T Core_type) name\n | Context.Core_type ->\n Name.Registrar.check_collisions registrar (Context.T Ppx_import) name\n | _ -> ());\n Name.Registrar.register ~kind:`Extension registrar (Context.T context) name;\n {\n name = Name.Pattern.make name;\n context;\n payload = Payload_parser (pattern, k);\n with_arg;\n }\n\n let find ts (ext : extension) =\n let { txt = name; loc } = fst ext in\n let name, arg = Name.split_path name in\n match List.filter ts ~f:(fun t -> Name.Pattern.matches t.name name) with\n | [] -> None\n | _ :: _ :: _ as l ->\n Location.raise_errorf ~loc \"Multiple match for extensions: %s\"\n (String.concat ~sep:\", \"\n (List.map l ~f:(fun t -> Name.Pattern.name t.name)))\n | [ t ] ->\n if (not t.with_arg) && Option.is_some arg then\n Location.raise_errorf ~loc\n \"Extension %s doesn't expect a path argument\" name;\n let arg =\n Option.map arg ~f:(fun s ->\n let shift = String.length name + 1 in\n let start = loc.loc_start in\n {\n txt = Longident.parse s;\n loc =\n {\n loc with\n loc_start = { start with pos_cnum = start.pos_cnum + shift };\n };\n })\n in\n Some (t, arg)\nend\n\nmodule Expert = struct\n include Make (struct\n type 'a t = arg:Longident.t Loc.t option -> 'a\n end)\n\n let declare_with_path_arg name ctx patt f =\n declare ~with_arg:true name ctx patt f\n\n let declare name ctx patt f =\n declare ~with_arg:false name ctx patt (fun ~arg:_ -> f)\n\n let convert ts ~loc ext =\n match find ts ext with\n | None -> None\n | Some ({ payload = Payload_parser (pattern, f); _ }, arg) ->\n Some (Ast_pattern.parse pattern loc (snd ext) (f ~arg))\nend\n\nmodule M = Make (struct\n type 'a t =\n ctxt:Expansion_context.Extension.t -> arg:Longident.t Loc.t option -> 'a\nend)\n\ntype 'a expander_result = Simple of 'a | Inline of 'a list\n\nmodule For_context = struct\n type 'a t = ('a, 'a expander_result) M.t\n\n let convert ts ~ctxt ext =\n let loc = Expansion_context.Extension.extension_point_loc ctxt in\n match M.find ts ext with\n | None -> None\n | Some ({ payload = M.Payload_parser (pattern, f); _ }, arg) -> (\n match Ast_pattern.parse pattern loc (snd ext) (f ~ctxt ~arg) with\n | Simple x -> Some x\n | Inline _ -> failwith \"Extension.convert\")\n\n let convert_inline ts ~ctxt ext =\n let loc = Expansion_context.Extension.extension_point_loc ctxt in\n match M.find ts ext with\n | None -> None\n | Some ({ payload = M.Payload_parser (pattern, f); _ }, arg) -> (\n match Ast_pattern.parse pattern loc (snd ext) (f ~ctxt ~arg) with\n | Simple x -> Some [ x ]\n | Inline l -> Some l)\nend\n\ntype t = T : _ For_context.t -> t\n\nlet check_context_for_inline : type a. func:string -> a Context.t -> unit =\n fun ~func ctx ->\n match ctx with\n | Context.Class_field -> ()\n | Context.Class_type_field -> ()\n | Context.Signature_item -> ()\n | Context.Structure_item -> ()\n | context ->\n Printf.ksprintf invalid_arg \"%s: %s can't be inlined\" func\n (Context.desc context)\n\nlet rec filter_by_context :\n type a. a Context.t -> t list -> a For_context.t list =\n fun context expanders ->\n match expanders with\n | [] -> []\n | T t :: rest -> (\n match Context.eq context t.context with\n | Eq -> t :: filter_by_context context rest\n | Ne -> filter_by_context context rest)\n\nlet fail ctx (name, _) =\n if\n not\n (Name.Whitelisted.is_whitelisted ~kind:`Extension name.txt\n || Name.ignore_checks name.txt)\n then\n Name.Registrar.raise_errorf registrar (Context.T ctx)\n \"Extension `%s' was not translated\" name\n\nlet check_unused =\n object\n inherit Ast_traverse.iter as super\n\n method! extension (name, _) =\n Location.raise_errorf ~loc:name.loc\n \"extension not expected here, Ppxlib.Extension needs updating!\"\n\n method! core_type_desc =\n function\n | Ptyp_extension ext -> fail Core_type ext | x -> super#core_type_desc x\n\n method! pattern_desc =\n function\n | Ppat_extension ext -> fail Pattern ext | x -> super#pattern_desc x\n\n method! expression_desc =\n function\n | Pexp_extension ext -> fail Expression ext | x -> super#expression_desc x\n\n method! class_type_desc =\n function\n | Pcty_extension ext -> fail Class_type ext | x -> super#class_type_desc x\n\n method! class_type_field_desc =\n function\n | Pctf_extension ext -> fail Class_type_field ext\n | x -> super#class_type_field_desc x\n\n method! class_expr_desc =\n function\n | Pcl_extension ext -> fail Class_expr ext | x -> super#class_expr_desc x\n\n method! class_field_desc =\n function\n | Pcf_extension ext -> fail Class_field ext\n | x -> super#class_field_desc x\n\n method! module_type_desc =\n function\n | Pmty_extension ext -> fail Module_type ext\n | x -> super#module_type_desc x\n\n method! signature_item_desc =\n function\n | Psig_extension (ext, _) -> fail Signature_item ext\n | x -> super#signature_item_desc x\n\n method! module_expr_desc =\n function\n | Pmod_extension ext -> fail Module_expr ext\n | x -> super#module_expr_desc x\n\n method! structure_item_desc =\n function\n | Pstr_extension (ext, _) -> fail Structure_item ext\n | x -> super#structure_item_desc x\n end\n\nmodule V3 = struct\n type nonrec t = t\n\n let declare name context pattern k =\n let pattern = Ast_pattern.map_result pattern ~f:(fun x -> Simple x) in\n T\n (M.declare ~with_arg:false name context pattern (fun ~ctxt ~arg:_ ->\n k ~ctxt))\n\n let declare_inline name context pattern k =\n check_context_for_inline context ~func:\"Extension.declare_inline\";\n let pattern = Ast_pattern.map_result pattern ~f:(fun x -> Inline x) in\n T\n (M.declare ~with_arg:false name context pattern (fun ~ctxt ~arg:_ ->\n k ~ctxt))\nend\n\nlet declare name context pattern f =\n V3.declare name context pattern\n (Expansion_context.Extension.with_loc_and_path f)\n\nlet declare_inline name context pattern f =\n V3.declare_inline name context pattern\n (Expansion_context.Extension.with_loc_and_path f)\n\nlet declare_with_path_arg name context pattern k =\n let k' = Expansion_context.Extension.with_loc_and_path k in\n let pattern = Ast_pattern.map_result pattern ~f:(fun x -> Simple x) in\n T (M.declare ~with_arg:true name context pattern k')\n\nlet declare_inline_with_path_arg name context pattern k =\n let k' = Expansion_context.Extension.with_loc_and_path k in\n check_context_for_inline context\n ~func:\"Extension.declare_inline_with_path_arg\";\n let pattern = Ast_pattern.map_result pattern ~f:(fun x -> Inline x) in\n T (M.declare ~with_arg:true name context pattern k')\n\nlet __declare_ppx_import name expand =\n (* This pattern is used to unwrap the type declaration from the payload\n assembled by [Context.get_ppx_import_extension] *)\n let pattern = Ast_pattern.(pstr (pstr_type recursive (__ ^:: nil) ^:: nil)) in\n V3.declare name Context.Ppx_import pattern expand\n\nmodule V2 = struct\n type nonrec t = t\n\n let declare = declare\n let declare_inline = declare_inline\nend\n","(*$ open Ppxlib_cinaps_helpers $*)\nopen! Import\nopen Common\nmodule E = Extension\nmodule EC = Extension.Context\nmodule A = Attribute\nmodule AC = Attribute.Context\n\nmodule Rule = struct\n module Attr_group_inline = struct\n type ('a, 'b, 'c) unpacked = {\n attribute : ('b, 'c) Attribute.t;\n expect : bool;\n expand :\n ctxt:Expansion_context.Deriver.t ->\n Asttypes.rec_flag ->\n 'b list ->\n 'c option list ->\n 'a list;\n }\n\n type ('a, 'b) t = T : ('a, 'b, _) unpacked -> ('a, 'b) t\n\n let attr_name (T t) = Attribute.name t.attribute\n\n let split_normal_and_expect l =\n List.partition l ~f:(fun (T t) -> not t.expect)\n end\n\n module Attr_inline = struct\n type ('a, 'b, 'c) unpacked = {\n attribute : ('b, 'c) Attribute.t;\n expect : bool;\n expand : ctxt:Expansion_context.Deriver.t -> 'b -> 'c -> 'a list;\n }\n\n type ('a, 'b) t = T : ('a, 'b, _) unpacked -> ('a, 'b) t\n\n let attr_name (T t) = Attribute.name t.attribute\n\n let split_normal_and_expect l =\n List.partition l ~f:(fun (T t) -> not t.expect)\n end\n\n module Special_function = struct\n type t = {\n name : string;\n ident : Longident.t;\n expand : Parsetree.expression -> Parsetree.expression option;\n }\n end\n\n module Constant_kind = struct\n type t = Float | Integer\n end\n\n module Constant = struct\n type t = {\n suffix : char;\n kind : Constant_kind.t;\n expand : Location.t -> string -> Parsetree.expression;\n }\n end\n\n module Field = struct\n type 'a t =\n | Extension : Extension.t t\n | Special_function : Special_function.t t\n | Constant : Constant.t t\n | Attr_str_type_decl\n : (structure_item, type_declaration) Attr_group_inline.t t\n | Attr_sig_type_decl\n : (signature_item, type_declaration) Attr_group_inline.t t\n | Attr_str_module_type_decl\n : (structure_item, module_type_declaration) Attr_inline.t t\n | Attr_sig_module_type_decl\n : (signature_item, module_type_declaration) Attr_inline.t t\n | Attr_str_type_ext : (structure_item, type_extension) Attr_inline.t t\n | Attr_sig_type_ext : (signature_item, type_extension) Attr_inline.t t\n | Attr_str_exception : (structure_item, type_exception) Attr_inline.t t\n | Attr_sig_exception : (signature_item, type_exception) Attr_inline.t t\n\n type (_, _) equality = Eq : ('a, 'a) equality | Ne : (_, _) equality\n\n let eq : type a b. a t -> b t -> (a, b) equality =\n fun a b ->\n match (a, b) with\n | Extension, Extension -> Eq\n | Special_function, Special_function -> Eq\n | Constant, Constant -> Eq\n | Attr_str_type_decl, Attr_str_type_decl -> Eq\n | Attr_sig_type_decl, Attr_sig_type_decl -> Eq\n | Attr_str_type_ext, Attr_str_type_ext -> Eq\n | Attr_sig_type_ext, Attr_sig_type_ext -> Eq\n | Attr_str_exception, Attr_str_exception -> Eq\n | Attr_sig_exception, Attr_sig_exception -> Eq\n | Attr_str_module_type_decl, Attr_str_module_type_decl -> Eq\n | Attr_sig_module_type_decl, Attr_sig_module_type_decl -> Eq\n | _ -> Ne\n end\n\n type t = T : 'a Field.t * 'a -> t\n\n type ('a, 'b, 'c) attr_group_inline =\n ('b, 'c) Attribute.t ->\n (ctxt:Expansion_context.Deriver.t ->\n Asttypes.rec_flag ->\n 'b list ->\n 'c option list ->\n 'a list) ->\n t\n\n type ('a, 'b, 'c) attr_inline =\n ('b, 'c) Attribute.t ->\n (ctxt:Expansion_context.Deriver.t -> 'b -> 'c -> 'a list) ->\n t\n\n let rec filter : type a. a Field.t -> t list -> a list =\n fun field l ->\n match l with\n | [] -> []\n | T (field', x) :: l -> (\n match Field.eq field field' with\n | Field.Eq -> x :: filter field l\n | Field.Ne -> filter field l)\n\n let extension ext = T (Extension, ext)\n\n let special_function id f =\n T (Special_function, { name = id; ident = Longident.parse id; expand = f })\n\n let constant kind suffix expand = T (Constant, { suffix; kind; expand })\n\n let attr_str_type_decl attribute expand =\n T (Attr_str_type_decl, T { attribute; expand; expect = false })\n\n let attr_sig_type_decl attribute expand =\n T (Attr_sig_type_decl, T { attribute; expand; expect = false })\n\n let attr_str_module_type_decl attribute expand =\n T (Attr_str_module_type_decl, T { attribute; expand; expect = false })\n\n let attr_sig_module_type_decl attribute expand =\n T (Attr_sig_module_type_decl, T { attribute; expand; expect = false })\n\n let attr_str_type_ext attribute expand =\n T (Attr_str_type_ext, T { attribute; expand; expect = false })\n\n let attr_sig_type_ext attribute expand =\n T (Attr_sig_type_ext, T { attribute; expand; expect = false })\n\n let attr_str_exception attribute expand =\n T (Attr_str_exception, T { attribute; expand; expect = false })\n\n let attr_sig_exception attribute expand =\n T (Attr_sig_exception, T { attribute; expand; expect = false })\n\n let attr_str_type_decl_expect attribute expand =\n T (Attr_str_type_decl, T { attribute; expand; expect = true })\n\n let attr_sig_type_decl_expect attribute expand =\n T (Attr_sig_type_decl, T { attribute; expand; expect = true })\n\n let attr_str_module_type_decl_expect attribute expand =\n T (Attr_str_module_type_decl, T { attribute; expand; expect = true })\n\n let attr_sig_module_type_decl_expect attribute expand =\n T (Attr_sig_module_type_decl, T { attribute; expand; expect = true })\n\n let attr_str_type_ext_expect attribute expand =\n T (Attr_str_type_ext, T { attribute; expand; expect = true })\n\n let attr_sig_type_ext_expect attribute expand =\n T (Attr_sig_type_ext, T { attribute; expand; expect = true })\n\n let attr_str_exception_expect attribute expand =\n T (Attr_str_exception, T { attribute; expand; expect = true })\n\n let attr_sig_exception_expect attribute expand =\n T (Attr_sig_exception, T { attribute; expand; expect = true })\nend\n\nmodule Generated_code_hook = struct\n type 'a single_or_many = Single of 'a | Many of 'a list\n\n type t = {\n f : 'a. 'a Extension.Context.t -> Location.t -> 'a single_or_many -> unit;\n }\n\n let nop = { f = (fun _ _ _ -> ()) }\n let replace t context loc x = t.f context loc x\n\n let insert_after t context (loc : Location.t) x =\n match x with\n | Many [] -> ()\n | _ -> t.f context { loc with loc_start = loc.loc_end } x\nend\n\nlet rec map_node_rec context ts super_call loc base_ctxt x =\n let ctxt =\n Expansion_context.Extension.make ~extension_point_loc:loc ~base:base_ctxt ()\n in\n match EC.get_extension context x with\n | None -> super_call base_ctxt x\n | Some (ext, attrs) -> (\n match E.For_context.convert ts ~ctxt ext with\n | None -> super_call base_ctxt x\n | Some x ->\n map_node_rec context ts super_call loc base_ctxt\n (EC.merge_attributes context x attrs))\n\nlet map_node context ts super_call loc base_ctxt x ~hook =\n let ctxt =\n Expansion_context.Extension.make ~extension_point_loc:loc ~base:base_ctxt ()\n in\n match EC.get_extension context x with\n | None -> super_call base_ctxt x\n | Some (ext, attrs) -> (\n match E.For_context.convert ts ~ctxt ext with\n | None -> super_call base_ctxt x\n | Some x ->\n let generated_code =\n map_node_rec context ts super_call loc base_ctxt\n (EC.merge_attributes context x attrs)\n in\n Generated_code_hook.replace hook context loc (Single generated_code);\n generated_code)\n\nlet rec map_nodes context ts super_call get_loc base_ctxt l ~hook\n ~in_generated_code =\n match l with\n | [] -> []\n | x :: l -> (\n match EC.get_extension context x with\n | None ->\n (* These two lets force the evaluation order, so that errors are reported in the\n same order as they appear in the source file. *)\n let x = super_call base_ctxt x in\n let l =\n map_nodes context ts super_call get_loc base_ctxt l ~hook\n ~in_generated_code\n in\n x :: l\n | Some (ext, attrs) -> (\n let extension_point_loc = get_loc x in\n let ctxt =\n Expansion_context.Extension.make ~extension_point_loc\n ~base:base_ctxt ()\n in\n match E.For_context.convert_inline ts ~ctxt ext with\n | None ->\n let x = super_call base_ctxt x in\n let l =\n map_nodes context ts super_call get_loc base_ctxt l ~hook\n ~in_generated_code\n in\n x :: l\n | Some x ->\n assert_no_attributes attrs;\n let generated_code =\n map_nodes context ts super_call get_loc base_ctxt x ~hook\n ~in_generated_code:true\n in\n if not in_generated_code then\n Generated_code_hook.replace hook context extension_point_loc\n (Many generated_code);\n generated_code\n @ map_nodes context ts super_call get_loc base_ctxt l ~hook\n ~in_generated_code))\n\nlet map_nodes = map_nodes ~in_generated_code:false\n\nlet table_of_special_functions special_functions =\n match\n List.map special_functions\n ~f:(fun { Rule.Special_function.ident; expand; _ } -> (ident, expand))\n (* We expect the lookup to fail most of the time, by making the table big (and\n sparse), we make it more likely to fail quickly *)\n |> Hashtbl.of_alist ~size:(max 1024 (List.length special_functions * 2))\n with\n | Ok table -> table\n | Error ident ->\n Printf.ksprintf invalid_arg\n \"Context_free.V1.map_top_down: %s present twice in list of special \\\n functions\"\n (List.find_map_exn special_functions ~f:(fun r ->\n if Poly.equal r.ident ident then Some r.name else None))\n\n(* [get_group attr l] returns the list of the attributes for each\n node in [l].\n If [l] is empty or if none of the nodes in [l] have an attribute attached,\n [get_group] returns [None].\n If [l] is not empty and at least one of the nodes in [l] has an attribue\n attached, [get_group] returns the equivalent of\n [Some (List.map ~f:(Attribute.get attr) l)]. *)\nlet rec get_group attr l =\n match l with\n | [] -> None\n | x :: l -> (\n match (Attribute.get attr x, get_group attr l) with\n | None, None -> None\n | None, Some vals -> Some (None :: vals)\n | Some value, None -> Some (Some value :: List.map l ~f:(fun _ -> None))\n | Some value, Some vals -> Some (Some value :: vals))\n\n(* Same as [List.rev] then [List.concat] but expecting the input to be of length <= 2 *)\nlet rev_concat = function\n | [] -> []\n | [ x ] -> x\n | [ x; y ] -> y @ x\n | l -> List.concat (List.rev l)\n\nlet sort_attr_group_inline l =\n List.sort l ~cmp:(fun a b ->\n String.compare\n (Rule.Attr_group_inline.attr_name a)\n (Rule.Attr_group_inline.attr_name b))\n\nlet sort_attr_inline l =\n List.sort l ~cmp:(fun a b ->\n String.compare\n (Rule.Attr_inline.attr_name a)\n (Rule.Attr_inline.attr_name b))\n\nlet context_free_attribute_modification ~loc =\n Location.raise_errorf ~loc\n \"A context-free rule deleted or added attribues of a str/sig item\"\n\n(* Returns the code generated by attribute handlers. We don't remove these attributes, as\n another pass might interpret them later. For instance both ppx_deriving and\n ppxlib_deriving interprets [@@deriving] attributes.\n\n This complexity is horrible, but in practice we don't care as [attrs] is always a list\n of one element; it only has [@@deriving].\n*)\nlet handle_attr_group_inline attrs rf ~items ~expanded_items ~loc ~base_ctxt =\n List.fold_left attrs ~init:[] ~f:(fun acc (Rule.Attr_group_inline.T group) ->\n match\n ( get_group group.attribute items,\n get_group group.attribute expanded_items )\n with\n | None, None -> acc\n | None, Some _ | Some _, None -> context_free_attribute_modification ~loc\n | Some values, Some _ ->\n let ctxt =\n Expansion_context.Deriver.make ~derived_item_loc:loc\n ~inline:group.expect ~base:base_ctxt ()\n in\n let expect_items = group.expand ~ctxt rf expanded_items values in\n expect_items :: acc)\n\nlet handle_attr_inline attrs ~item ~expanded_item ~loc ~base_ctxt =\n List.fold_left attrs ~init:[] ~f:(fun acc (Rule.Attr_inline.T a) ->\n match\n (Attribute.get a.attribute item, Attribute.get a.attribute expanded_item)\n with\n | None, None -> acc\n | None, Some _ | Some _, None -> context_free_attribute_modification ~loc\n | Some value, Some _ ->\n let ctxt =\n Expansion_context.Deriver.make ~derived_item_loc:loc\n ~inline:a.expect ~base:base_ctxt ()\n in\n let expect_items = a.expand ~ctxt expanded_item value in\n expect_items :: acc)\n\nmodule Expect_mismatch_handler = struct\n type t = {\n f : 'a. 'a Attribute.Floating.Context.t -> Location.t -> 'a list -> unit;\n }\n\n let nop = { f = (fun _ _ _ -> ()) }\nend\n\nclass map_top_down ?(expect_mismatch_handler = Expect_mismatch_handler.nop)\n ?(generated_code_hook = Generated_code_hook.nop) rules =\n let hook = generated_code_hook in\n\n let special_functions =\n Rule.filter Special_function rules |> table_of_special_functions\n in\n let constants =\n Rule.filter Constant rules\n |> List.map ~f:(fun (c : Rule.Constant.t) -> ((c.suffix, c.kind), c.expand))\n |> Hashtbl.of_alist_exn\n in\n let extensions = Rule.filter Extension rules in\n let class_expr = E.filter_by_context EC.class_expr extensions\n and class_field = E.filter_by_context EC.class_field extensions\n and class_type = E.filter_by_context EC.class_type extensions\n and class_type_field = E.filter_by_context EC.class_type_field extensions\n and core_type = E.filter_by_context EC.core_type extensions\n and expression = E.filter_by_context EC.expression extensions\n and module_expr = E.filter_by_context EC.module_expr extensions\n and module_type = E.filter_by_context EC.module_type extensions\n and pattern = E.filter_by_context EC.pattern extensions\n and signature_item = E.filter_by_context EC.signature_item extensions\n and structure_item = E.filter_by_context EC.structure_item extensions\n and ppx_import = E.filter_by_context EC.Ppx_import extensions in\n\n let attr_str_type_decls, attr_str_type_decls_expect =\n Rule.filter Attr_str_type_decl rules\n |> sort_attr_group_inline |> Rule.Attr_group_inline.split_normal_and_expect\n in\n let attr_sig_type_decls, attr_sig_type_decls_expect =\n Rule.filter Attr_sig_type_decl rules\n |> sort_attr_group_inline |> Rule.Attr_group_inline.split_normal_and_expect\n in\n\n let attr_str_module_type_decls, attr_str_module_type_decls_expect =\n Rule.filter Attr_str_module_type_decl rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n let attr_sig_module_type_decls, attr_sig_module_type_decls_expect =\n Rule.filter Attr_sig_module_type_decl rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n\n let attr_str_type_exts, attr_str_type_exts_expect =\n Rule.filter Attr_str_type_ext rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n let attr_sig_type_exts, attr_sig_type_exts_expect =\n Rule.filter Attr_sig_type_ext rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n\n let attr_str_exceptions, attr_str_exceptions_expect =\n Rule.filter Attr_str_exception rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n let attr_sig_exceptions, attr_sig_exceptions_expect =\n Rule.filter Attr_sig_exception rules\n |> sort_attr_inline |> Rule.Attr_inline.split_normal_and_expect\n in\n\n let map_node = map_node ~hook in\n let map_nodes = map_nodes ~hook in\n\n object (self)\n inherit Ast_traverse.map_with_expansion_context as super\n\n (* No point recursing into every location *)\n method! location _ x = x\n\n method! core_type base_ctxt x =\n map_node EC.core_type core_type super#core_type x.ptyp_loc base_ctxt x\n\n method! pattern base_ctxt x =\n map_node EC.pattern pattern super#pattern x.ppat_loc base_ctxt x\n\n method! expression base_ctxt e =\n let e =\n match e.pexp_desc with\n | Pexp_extension _ ->\n map_node EC.expression expression\n (fun _ e -> e)\n e.pexp_loc base_ctxt e\n | _ -> e\n in\n let expand_constant kind char text =\n match Hashtbl.find_opt constants (char, kind) with\n | None -> super#expression base_ctxt e\n | Some expand -> self#expression base_ctxt (expand e.pexp_loc text)\n in\n match e.pexp_desc with\n | Pexp_apply (({ pexp_desc = Pexp_ident id; _ } as func), args) -> (\n match Hashtbl.find_opt special_functions id.txt with\n | None ->\n self#pexp_apply_without_traversing_function base_ctxt e func args\n | Some pattern -> (\n match pattern e with\n | None ->\n self#pexp_apply_without_traversing_function base_ctxt e func\n args\n | Some e -> self#expression base_ctxt e))\n | Pexp_ident id -> (\n match Hashtbl.find_opt special_functions id.txt with\n | None -> super#expression base_ctxt e\n | Some pattern -> (\n match pattern e with\n | None -> super#expression base_ctxt e\n | Some e -> self#expression base_ctxt e))\n | Pexp_constant (Pconst_integer (s, Some c)) ->\n expand_constant Integer c s\n | Pexp_constant (Pconst_float (s, Some c)) -> expand_constant Float c s\n | _ -> super#expression base_ctxt e\n\n (* Pre-conditions:\n - e.pexp_desc = Pexp_apply(func, args)\n - func.pexp_desc = Pexp_ident _\n *)\n method private pexp_apply_without_traversing_function base_ctxt e func args\n =\n let { pexp_desc = _; pexp_loc; pexp_attributes; pexp_loc_stack } = e in\n let func =\n let { pexp_desc; pexp_loc; pexp_attributes; pexp_loc_stack } = func in\n let pexp_attributes = self#attributes base_ctxt pexp_attributes in\n {\n pexp_desc;\n pexp_loc (* location doesn't need to be traversed *);\n pexp_attributes;\n pexp_loc_stack;\n }\n in\n let args =\n List.map args ~f:(fun (lab, exp) ->\n (lab, self#expression base_ctxt exp))\n in\n let pexp_attributes = self#attributes base_ctxt pexp_attributes in\n {\n pexp_loc;\n pexp_attributes;\n pexp_desc = Pexp_apply (func, args);\n pexp_loc_stack;\n }\n\n method! class_type base_ctxt x =\n map_node EC.class_type class_type super#class_type x.pcty_loc base_ctxt x\n\n method! class_type_field base_ctxt x =\n map_node EC.class_type_field class_type_field super#class_type_field\n x.pctf_loc base_ctxt x\n\n method! class_expr base_ctxt x =\n map_node EC.class_expr class_expr super#class_expr x.pcl_loc base_ctxt x\n\n method! class_field base_ctxt x =\n map_node EC.class_field class_field super#class_field x.pcf_loc base_ctxt\n x\n\n method! module_type base_ctxt x =\n map_node EC.module_type module_type super#module_type x.pmty_loc base_ctxt\n x\n\n method! module_expr base_ctxt x =\n map_node EC.module_expr module_expr super#module_expr x.pmod_loc base_ctxt\n x\n\n method! structure_item base_ctxt x =\n map_node EC.structure_item structure_item super#structure_item x.pstr_loc\n base_ctxt x\n\n method! signature_item base_ctxt x =\n map_node EC.signature_item signature_item super#signature_item x.psig_loc\n base_ctxt x\n\n method! class_structure base_ctxt { pcstr_self; pcstr_fields } =\n let pcstr_self = self#pattern base_ctxt pcstr_self in\n let pcstr_fields =\n map_nodes EC.class_field class_field super#class_field\n (fun x -> x.pcf_loc)\n base_ctxt pcstr_fields\n in\n { pcstr_self; pcstr_fields }\n\n method! type_declaration base_ctxt x =\n map_node EC.Ppx_import ppx_import super#type_declaration x.ptype_loc\n base_ctxt x\n\n method! class_signature base_ctxt { pcsig_self; pcsig_fields } =\n let pcsig_self = self#core_type base_ctxt pcsig_self in\n let pcsig_fields =\n map_nodes EC.class_type_field class_type_field super#class_type_field\n (fun x -> x.pctf_loc)\n base_ctxt pcsig_fields\n in\n { pcsig_self; pcsig_fields }\n\n (* TODO: try to factorize #structure and #signature without meta-programming *)\n (*$*)\n method! structure base_ctxt st =\n let rec with_extra_items item ~extra_items ~expect_items ~rest\n ~in_generated_code =\n let extra_items =\n loop (rev_concat extra_items) ~in_generated_code:true\n in\n if not in_generated_code then\n Generated_code_hook.insert_after hook Structure_item item.pstr_loc\n (Many extra_items);\n let original_rest = rest in\n let rest = loop rest ~in_generated_code in\n (match expect_items with\n | [] -> ()\n | _ ->\n let expected = rev_concat expect_items in\n let pos = item.pstr_loc.loc_end in\n Code_matcher.match_structure original_rest ~pos ~expected\n ~mismatch_handler:(fun loc repl ->\n expect_mismatch_handler.f Structure_item loc repl));\n item :: (extra_items @ rest)\n and loop st ~in_generated_code =\n match st with\n | [] -> []\n | item :: rest -> (\n let loc = item.pstr_loc in\n match item.pstr_desc with\n | Pstr_extension (ext, attrs) -> (\n let extension_point_loc = item.pstr_loc in\n let ctxt =\n Expansion_context.Extension.make ~extension_point_loc\n ~base:base_ctxt ()\n in\n match E.For_context.convert_inline structure_item ~ctxt ext with\n | None ->\n let item = super#structure_item base_ctxt item in\n let rest = self#structure base_ctxt rest in\n item :: rest\n | Some items ->\n assert_no_attributes attrs;\n let items = loop items ~in_generated_code:true in\n if not in_generated_code then\n Generated_code_hook.replace hook Structure_item\n item.pstr_loc (Many items);\n items @ loop rest ~in_generated_code)\n | _ -> (\n let expanded_item = super#structure_item base_ctxt item in\n match (item.pstr_desc, expanded_item.pstr_desc) with\n | Pstr_type (rf, tds), Pstr_type (exp_rf, exp_tds) ->\n (* No context-free rule can rewrite rec flags atm, this\n assert acts as a failsafe in case it ever changes *)\n assert (Poly.(rf = exp_rf));\n let extra_items =\n handle_attr_group_inline attr_str_type_decls rf ~items:tds\n ~expanded_items:exp_tds ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_group_inline attr_str_type_decls_expect rf\n ~items:tds ~expanded_items:exp_tds ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Pstr_modtype mtd, Pstr_modtype exp_mtd ->\n let extra_items =\n handle_attr_inline attr_str_module_type_decls ~item:mtd\n ~expanded_item:exp_mtd ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_str_module_type_decls_expect\n ~item:mtd ~expanded_item:exp_mtd ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Pstr_typext te, Pstr_typext exp_te ->\n let extra_items =\n handle_attr_inline attr_str_type_exts ~item:te\n ~expanded_item:exp_te ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_str_type_exts_expect ~item:te\n ~expanded_item:exp_te ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Pstr_exception ec, Pstr_exception exp_ec ->\n let extra_items =\n handle_attr_inline attr_str_exceptions ~item:ec\n ~expanded_item:exp_ec ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_str_exceptions_expect ~item:ec\n ~expanded_item:exp_ec ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | _, _ ->\n let rest = self#structure base_ctxt rest in\n expanded_item :: rest))\n in\n loop st ~in_generated_code:false\n\n (*$ str_to_sig _last_text_block *)\n method! signature base_ctxt sg =\n let rec with_extra_items item ~extra_items ~expect_items ~rest\n ~in_generated_code =\n let extra_items =\n loop (rev_concat extra_items) ~in_generated_code:true\n in\n if not in_generated_code then\n Generated_code_hook.insert_after hook Signature_item item.psig_loc\n (Many extra_items);\n let original_rest = rest in\n let rest = loop rest ~in_generated_code in\n (match expect_items with\n | [] -> ()\n | _ ->\n let expected = rev_concat expect_items in\n let pos = item.psig_loc.loc_end in\n Code_matcher.match_signature original_rest ~pos ~expected\n ~mismatch_handler:(fun loc repl ->\n expect_mismatch_handler.f Signature_item loc repl));\n item :: (extra_items @ rest)\n and loop sg ~in_generated_code =\n match sg with\n | [] -> []\n | item :: rest -> (\n let loc = item.psig_loc in\n match item.psig_desc with\n | Psig_extension (ext, attrs) -> (\n let extension_point_loc = item.psig_loc in\n let ctxt =\n Expansion_context.Extension.make ~extension_point_loc\n ~base:base_ctxt ()\n in\n match E.For_context.convert_inline signature_item ~ctxt ext with\n | None ->\n let item = super#signature_item base_ctxt item in\n let rest = self#signature base_ctxt rest in\n item :: rest\n | Some items ->\n assert_no_attributes attrs;\n let items = loop items ~in_generated_code:true in\n if not in_generated_code then\n Generated_code_hook.replace hook Signature_item\n item.psig_loc (Many items);\n items @ loop rest ~in_generated_code)\n | _ -> (\n let expanded_item = super#signature_item base_ctxt item in\n match (item.psig_desc, expanded_item.psig_desc) with\n | Psig_type (rf, tds), Psig_type (exp_rf, exp_tds) ->\n (* No context-free rule can rewrite rec flags atm, this\n assert acts as a failsafe in case it ever changes *)\n assert (Poly.(rf = exp_rf));\n let extra_items =\n handle_attr_group_inline attr_sig_type_decls rf ~items:tds\n ~expanded_items:exp_tds ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_group_inline attr_sig_type_decls_expect rf\n ~items:tds ~expanded_items:exp_tds ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Psig_modtype mtd, Psig_modtype exp_mtd ->\n let extra_items =\n handle_attr_inline attr_sig_module_type_decls ~item:mtd\n ~expanded_item:exp_mtd ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_sig_module_type_decls_expect\n ~item:mtd ~expanded_item:exp_mtd ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Psig_typext te, Psig_typext exp_te ->\n let extra_items =\n handle_attr_inline attr_sig_type_exts ~item:te\n ~expanded_item:exp_te ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_sig_type_exts_expect ~item:te\n ~expanded_item:exp_te ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | Psig_exception ec, Psig_exception exp_ec ->\n let extra_items =\n handle_attr_inline attr_sig_exceptions ~item:ec\n ~expanded_item:exp_ec ~loc ~base_ctxt\n in\n let expect_items =\n handle_attr_inline attr_sig_exceptions_expect ~item:ec\n ~expanded_item:exp_ec ~loc ~base_ctxt\n in\n with_extra_items expanded_item ~extra_items ~expect_items\n ~rest ~in_generated_code\n | _, _ ->\n let rest = self#signature base_ctxt rest in\n expanded_item :: rest))\n in\n loop sg ~in_generated_code:false\n\n (*$*)\n end\n","(*$ open Ppxlib_cinaps_helpers $*)\nopen Import\nopen Utils\nmodule Arg = Caml.Arg\n\nlet exe_name = Caml.Filename.basename Caml.Sys.executable_name\nlet args = ref []\nlet add_arg key spec ~doc = args := (key, spec, doc) :: !args\nlet loc_fname = ref None\nlet perform_checks = ref Options.perform_checks\nlet perform_checks_on_extensions = ref Options.perform_checks_on_extensions\nlet perform_locations_check = ref Options.perform_locations_check\nlet debug_attribute_drop = ref false\nlet apply_list = ref None\nlet preprocessor = ref None\nlet no_merge = ref false\nlet request_print_passes = ref false\nlet request_print_transformations = ref false\nlet use_color = ref true\nlet diff_command = ref Options.diff_command\nlet pretty = ref false\nlet styler = ref None\nlet output_metadata_filename = ref None\nlet corrected_suffix = ref \".ppx-corrected\"\n\nmodule Lint_error = struct\n type t = Location.t * string\n\n let of_string loc s = (loc, s)\nend\n\nmodule Cookies = struct\n type t = T\n\n let given_through_cli = ref []\n\n let get T name pattern =\n Option.map (Astlib.Ast_metadata.get_cookie name) ~f:(fun e ->\n let e = Selected_ast.of_ocaml Expression e in\n Ast_pattern.parse pattern e.pexp_loc e Fn.id)\n\n let set T name expr =\n Astlib.Ast_metadata.set_cookie name (Selected_ast.to_ocaml Expression expr)\n\n let handlers = ref []\n let add_handler f = handlers := !handlers @ [ f ]\n\n let add_simple_handler name pattern ~f =\n add_handler (fun T -> f (get T name pattern))\n\n let acknowledge_cookies T = List.iter !handlers ~f:(fun f -> f T)\n let post_handlers = ref []\n let add_post_handler f = post_handlers := !post_handlers @ [ f ]\n let call_post_handlers T = List.iter !post_handlers ~f:(fun f -> f T)\nend\n\nmodule Instrument = struct\n type pos = Before | After\n\n type t = {\n transformation :\n Expansion_context.Base.t -> Parsetree.structure -> Parsetree.structure;\n position : pos;\n }\n\n module V2 = struct\n let make transformation ~position = { transformation; position }\n end\n\n let make transformation ~position =\n let transformation _ st = transformation st in\n V2.make transformation ~position\nend\n\nmodule Transform = struct\n type t = {\n name : string;\n aliases : string list;\n impl :\n (Expansion_context.Base.t -> Parsetree.structure -> Parsetree.structure)\n option;\n intf :\n (Expansion_context.Base.t -> Parsetree.signature -> Parsetree.signature)\n option;\n lint_impl :\n (Expansion_context.Base.t -> Parsetree.structure -> Lint_error.t list)\n option;\n lint_intf :\n (Expansion_context.Base.t -> Parsetree.signature -> Lint_error.t list)\n option;\n preprocess_impl :\n (Expansion_context.Base.t -> Parsetree.structure -> Parsetree.structure)\n option;\n preprocess_intf :\n (Expansion_context.Base.t -> Parsetree.signature -> Parsetree.signature)\n option;\n enclose_impl :\n (Expansion_context.Base.t ->\n Location.t option ->\n Parsetree.structure * Parsetree.structure)\n option;\n enclose_intf :\n (Expansion_context.Base.t ->\n Location.t option ->\n Parsetree.signature * Parsetree.signature)\n option;\n instrument : Instrument.t option;\n rules : Context_free.Rule.t list;\n registered_at : Caller_id.t;\n }\n\n let has_name t name =\n String.equal name t.name || List.exists ~f:(String.equal name) t.aliases\n\n let all : t list ref = ref []\n\n let print_caller_id oc (caller_id : Caller_id.t) =\n match caller_id with\n | None -> output_string oc \"\"\n | Some loc -> Printf.fprintf oc \"%s:%d\" loc.filename loc.line_number\n\n let register ?(extensions = []) ?(rules = []) ?enclose_impl ?enclose_intf\n ?impl ?intf ?lint_impl ?lint_intf ?preprocess_impl ?preprocess_intf\n ?instrument ?(aliases = []) name =\n let rules = List.map extensions ~f:Context_free.Rule.extension @ rules in\n let caller_id = Caller_id.get ~skip:[ Caml.__FILE__ ] in\n (match List.filter !all ~f:(fun ct -> has_name ct name) with\n | [] -> ()\n | ct :: _ ->\n Printf.eprintf \"Warning: code transformation %s registered twice.\\n\"\n name;\n Printf.eprintf \" - first time was at %a\\n\" print_caller_id\n ct.registered_at;\n Printf.eprintf \" - second time is at %a\\n\" print_caller_id caller_id);\n let ct =\n {\n name;\n aliases;\n rules;\n enclose_impl;\n enclose_intf;\n impl;\n intf;\n lint_impl;\n preprocess_impl;\n preprocess_intf;\n lint_intf;\n instrument;\n registered_at = caller_id;\n }\n in\n all := ct :: !all\n\n let rec last prev l = match l with [] -> prev | x :: l -> last x l\n\n let loc_of_list ~get_loc l =\n match l with\n | [] -> None\n | x :: l ->\n let first : Location.t = get_loc x in\n let last = get_loc (last x l) in\n Some { first with loc_end = last.loc_end }\n\n let merge_into_generic_mappers t ~hook ~expect_mismatch_handler ~tool_name\n ~input_name =\n let { rules; enclose_impl; enclose_intf; impl; intf; _ } = t in\n let map =\n new Context_free.map_top_down\n rules ~generated_code_hook:hook ~expect_mismatch_handler\n in\n let gen_header_and_footer context whole_loc f =\n let header, footer = f whole_loc in\n (match whole_loc with\n | Some (loc : Location.t) -> (\n let loc_header = { loc with loc_end = loc.loc_start } in\n let loc_footer = { loc with loc_start = loc.loc_end } in\n (match header with\n | [] -> ()\n | _ -> hook.f context loc_header (Many header));\n match footer with\n | [] -> ()\n | _ -> hook.f context loc_footer (Many footer))\n | None -> (\n match header @ footer with\n | [] -> ()\n | l ->\n let pos =\n {\n Lexing.pos_fname = \"\";\n pos_lnum = 1;\n pos_bol = 0;\n pos_cnum = 0;\n }\n in\n let loc =\n { Location.loc_start = pos; loc_end = pos; loc_ghost = false }\n in\n hook.f context loc (Many l)));\n (header, footer)\n in\n let input_name =\n match input_name with Some input_name -> input_name | None -> \"_none_\"\n in\n let map_impl ctxt st_with_attrs =\n let st =\n let attrs, st =\n List.split_while st_with_attrs ~f:(function\n | { pstr_desc = Pstr_attribute _; _ } -> true\n | _ -> false)\n in\n let file_path = File_path.get_default_path_str st in\n let base_ctxt =\n Expansion_context.Base.top_level ~tool_name ~file_path ~input_name\n in\n let header, footer =\n match enclose_impl with\n | None -> ([], [])\n | Some f ->\n let whole_loc =\n loc_of_list st ~get_loc:(fun st -> st.Parsetree.pstr_loc)\n in\n gen_header_and_footer Structure_item whole_loc (f base_ctxt)\n in\n let attrs = map#structure base_ctxt attrs in\n let st = map#structure base_ctxt st in\n List.concat [ attrs; header; st; footer ]\n in\n match impl with None -> st | Some f -> f ctxt st\n in\n let map_intf ctxt sg_with_attrs =\n let sg =\n let attrs, sg =\n List.split_while sg_with_attrs ~f:(function\n | { psig_desc = Psig_attribute _; _ } -> true\n | _ -> false)\n in\n let file_path = File_path.get_default_path_sig sg in\n let base_ctxt =\n Expansion_context.Base.top_level ~tool_name ~file_path ~input_name\n in\n let header, footer =\n match enclose_intf with\n | None -> ([], [])\n | Some f ->\n let whole_loc =\n loc_of_list sg ~get_loc:(fun sg -> sg.Parsetree.psig_loc)\n in\n gen_header_and_footer Signature_item whole_loc (f base_ctxt)\n in\n let attrs = map#signature base_ctxt attrs in\n let sg = map#signature base_ctxt sg in\n List.concat [ attrs; header; sg; footer ]\n in\n match intf with None -> sg | Some f -> f ctxt sg\n in\n { t with impl = Some map_impl; intf = Some map_intf }\n\n let builtin_of_context_free_rewriters ~hook ~rules ~enclose_impl ~enclose_intf\n ~input_name =\n merge_into_generic_mappers ~hook ~input_name\n {\n name = \"\";\n aliases = [];\n impl = None;\n intf = None;\n lint_impl = None;\n lint_intf = None;\n preprocess_impl = None;\n preprocess_intf = None;\n enclose_impl;\n enclose_intf;\n instrument = None;\n rules;\n registered_at = Caller_id.get ~skip:[];\n }\n\n let partition_transformations ts =\n let before_instrs, after_instrs, rest =\n List.fold_left ts ~init:([], [], []) ~f:(fun (bef_i, aft_i, rest) t ->\n let reduced_t =\n {\n t with\n lint_impl = None;\n lint_intf = None;\n preprocess_impl = None;\n preprocess_intf = None;\n }\n in\n let f instr =\n (instr.Instrument.position, instr.Instrument.transformation)\n in\n match Option.map t.instrument ~f with\n | Some (Before, transf) ->\n ( { reduced_t with impl = Some transf; rules = [] } :: bef_i,\n aft_i,\n reduced_t :: rest )\n | Some (After, transf) ->\n ( bef_i,\n { reduced_t with impl = Some transf; rules = [] } :: aft_i,\n reduced_t :: rest )\n | None -> (bef_i, aft_i, reduced_t :: rest))\n in\n ( `Linters\n (List.filter_map ts ~f:(fun t ->\n if Option.is_some t.lint_impl || Option.is_some t.lint_intf then\n Some\n {\n name = Printf.sprintf \"\" t.name;\n aliases = [];\n impl = None;\n intf = None;\n lint_impl = t.lint_impl;\n lint_intf = t.lint_intf;\n enclose_impl = None;\n enclose_intf = None;\n preprocess_impl = None;\n preprocess_intf = None;\n instrument = None;\n rules = [];\n registered_at = t.registered_at;\n }\n else None)),\n `Preprocess\n (List.filter_map ts ~f:(fun t ->\n if\n Option.is_some t.preprocess_impl\n || Option.is_some t.preprocess_intf\n then\n Some\n {\n name = Printf.sprintf \"\" t.name;\n aliases = [];\n impl = t.preprocess_impl;\n intf = t.preprocess_intf;\n lint_impl = None;\n lint_intf = None;\n enclose_impl = None;\n enclose_intf = None;\n preprocess_impl = None;\n preprocess_intf = None;\n instrument = None;\n rules = [];\n registered_at = t.registered_at;\n }\n else None)),\n `Before_instrs before_instrs,\n `After_instrs after_instrs,\n `Rest rest )\nend\n\nmodule V2 = struct\n let register_transformation = Transform.register\n\n let register_transformation_using_ocaml_current_ast ?impl ?intf ?aliases name\n =\n let impl =\n Option.map impl ~f:(Ppxlib_ast.Selected_ast.of_ocaml_mapper Structure)\n in\n let intf =\n Option.map intf ~f:(Ppxlib_ast.Selected_ast.of_ocaml_mapper Signature)\n in\n register_transformation ?impl ?intf ?aliases name\nend\n\nlet add_ctxt_arg (f : 'a -> 'b) : Expansion_context.Base.t -> 'a -> 'b =\n fun _ x -> f x\n\nlet register_transformation ?extensions ?rules ?enclose_impl ?enclose_intf ?impl\n ?intf ?lint_impl ?lint_intf ?preprocess_impl ?preprocess_intf =\n let impl = Option.map impl ~f:add_ctxt_arg in\n let intf = Option.map intf ~f:add_ctxt_arg in\n let preprocess_impl = Option.map preprocess_impl ~f:add_ctxt_arg in\n let preprocess_intf = Option.map preprocess_intf ~f:add_ctxt_arg in\n let lint_impl = Option.map lint_impl ~f:add_ctxt_arg in\n let lint_intf = Option.map lint_intf ~f:add_ctxt_arg in\n let enclose_impl = Option.map enclose_impl ~f:add_ctxt_arg in\n let enclose_intf = Option.map enclose_intf ~f:add_ctxt_arg in\n V2.register_transformation ?extensions ?rules ?enclose_impl ?enclose_intf\n ?impl ?intf ?lint_impl ?lint_intf ?preprocess_impl ?preprocess_intf\n\nlet register_code_transformation ~name ?(aliases = []) ~impl ~intf =\n register_transformation name ~impl ~intf ~aliases\n [@@warning \"-16\"]\n(* This function triggers a warning 16 as of ocaml 4.12 *)\n\nlet register_transformation_using_ocaml_current_ast ?impl ?intf =\n let impl = Option.map impl ~f:add_ctxt_arg in\n let intf = Option.map intf ~f:add_ctxt_arg in\n V2.register_transformation_using_ocaml_current_ast ?impl ?intf\n\nlet debug_dropped_attribute name ~old_dropped ~new_dropped =\n let print_diff what a b =\n let diff =\n List.filter a ~f:(fun (name : _ Loc.t) ->\n not\n (List.exists b ~f:(fun (name' : _ Location.loc) ->\n name.txt == name'.txt)))\n in\n if not (List.is_empty diff) then (\n Printf.eprintf \"The following attributes %s after applying %s:\\n\" what\n name;\n List.iter diff ~f:(fun { Location.txt; loc } ->\n Caml.Format.eprintf \"- %a: %s\\n\" Location.print loc txt);\n Caml.Format.eprintf \"@.\")\n in\n print_diff \"disappeared\" new_dropped old_dropped;\n print_diff \"reappeared\" old_dropped new_dropped\n\nlet get_whole_ast_passes ~hook ~expect_mismatch_handler ~tool_name ~input_name =\n let cts =\n match !apply_list with\n | None -> List.rev !Transform.all\n | Some names ->\n List.map names ~f:(fun name ->\n List.find !Transform.all ~f:(fun (ct : Transform.t) ->\n Transform.has_name ct name))\n in\n let ( `Linters linters,\n `Preprocess preprocess,\n `Before_instrs before_instrs,\n `After_instrs after_instrs,\n `Rest cts ) =\n Transform.partition_transformations cts\n in\n (* Allow only one preprocessor to assure deterministic order *)\n (if List.length preprocess > 1 then\n let pp =\n String.concat ~sep:\", \" (List.map preprocess ~f:(fun t -> t.name))\n in\n let err =\n Printf.sprintf \"At most one preprocessor is allowed, while got: %s\" pp\n in\n failwith err);\n let make_generic transforms =\n if !no_merge then\n List.map transforms\n ~f:\n (Transform.merge_into_generic_mappers ~hook ~tool_name\n ~expect_mismatch_handler ~input_name)\n else\n (let get_enclosers ~f =\n List.filter_map transforms ~f:(fun (ct : Transform.t) ->\n match f ct with None -> None | Some x -> Some (ct.name, x))\n (* Sort them to ensure deterministic ordering *)\n |> List.sort ~cmp:(fun (a, _) (b, _) -> String.compare a b)\n |> List.map ~f:snd\n in\n\n let rules =\n List.map transforms ~f:(fun (ct : Transform.t) -> ct.rules)\n |> List.concat\n and impl_enclosers = get_enclosers ~f:(fun ct -> ct.enclose_impl)\n and intf_enclosers = get_enclosers ~f:(fun ct -> ct.enclose_intf) in\n match (rules, impl_enclosers, intf_enclosers) with\n | [], [], [] -> transforms\n | _ ->\n let merge_encloser = function\n | [] -> None\n | enclosers ->\n Some\n (fun ctxt loc ->\n let headers, footers =\n List.map enclosers ~f:(fun f -> f ctxt loc) |> List.split\n in\n let headers = List.concat headers in\n let footers = List.concat (List.rev footers) in\n (headers, footers))\n in\n Transform.builtin_of_context_free_rewriters ~rules ~hook\n ~expect_mismatch_handler\n ~enclose_impl:(merge_encloser impl_enclosers)\n ~enclose_intf:(merge_encloser intf_enclosers)\n ~tool_name ~input_name\n :: transforms)\n |> List.filter ~f:(fun (ct : Transform.t) ->\n match (ct.impl, ct.intf) with None, None -> false | _ -> true)\n in\n linters @ preprocess @ before_instrs @ make_generic cts @ after_instrs\n\nlet apply_transforms (type t) ~tool_name ~file_path ~field ~lint_field\n ~dropped_so_far ~hook ~expect_mismatch_handler ~input_name ~f_exception\n ~embed_errors x =\n let exception\n Wrapper of t list * label loc list * (location * label) list * exn\n in\n let cts =\n get_whole_ast_passes ~tool_name ~hook ~expect_mismatch_handler ~input_name\n in\n let return (x, _dropped, lint_errors) =\n ( x,\n List.map lint_errors ~f:(fun (loc, s) ->\n Common.attribute_of_warning loc s) )\n in\n try\n let acc =\n List.fold_left cts ~init:(x, [], [])\n ~f:(fun (x, dropped, (lint_errors : _ list)) (ct : Transform.t) ->\n let input_name =\n match input_name with\n | Some input_name -> input_name\n | None -> \"_none_\"\n in\n let ctxt =\n Expansion_context.Base.top_level ~tool_name ~file_path ~input_name\n in\n let lint_errors =\n match lint_field ct with\n | None -> lint_errors\n | Some f -> (\n try lint_errors @ f ctxt x\n with exn when embed_errors ->\n raise @@ Wrapper (x, dropped, lint_errors, exn))\n in\n match field ct with\n | None -> (x, dropped, lint_errors)\n | Some f ->\n let x =\n try f ctxt x\n with exn when embed_errors ->\n raise @@ Wrapper (x, dropped, lint_errors, exn)\n in\n let dropped =\n if !debug_attribute_drop then (\n let new_dropped = dropped_so_far x in\n debug_dropped_attribute ct.name ~old_dropped:dropped\n ~new_dropped;\n new_dropped)\n else []\n in\n (x, dropped, lint_errors))\n in\n Ok (return acc)\n with Wrapper (x, dropped, lint_errors, exn) ->\n Error (return (f_exception exn :: x, dropped, lint_errors))\n\n(*$*)\n\nlet error_to_str_extension error =\n let loc = Location.none in\n let ext = Location.Error.to_extension error in\n Ast_builder.Default.pstr_extension ~loc ext []\n\nlet exn_to_str_extension exn =\n match Location.Error.of_exn exn with\n | None -> raise exn\n | Some error -> error_to_str_extension error\n\n(*$ str_to_sig _last_text_block *)\n\nlet error_to_sig_extension error =\n let loc = Location.none in\n let ext = Location.Error.to_extension error in\n Ast_builder.Default.psig_extension ~loc ext []\n\nlet exn_to_sig_extension exn =\n match Location.Error.of_exn exn with\n | None -> raise exn\n | Some error -> error_to_sig_extension error\n\n(*$*)\n\nlet error_to_extension error ~(kind : Kind.t) =\n match kind with\n | Intf -> Intf_or_impl.Intf [ error_to_sig_extension error ]\n | Impl -> Intf_or_impl.Impl [ error_to_str_extension error ]\n\nlet exn_to_extension exn ~(kind : Kind.t) =\n match Location.Error.of_exn exn with\n | None -> raise exn\n | Some error -> error_to_extension error ~kind\n\n(* +-----------------------------------------------------------------+\n | Actual rewriting of structure/signatures |\n +-----------------------------------------------------------------+ *)\n\nlet print_passes () =\n let tool_name = \"ppxlib_driver\" in\n let hook = Context_free.Generated_code_hook.nop in\n let expect_mismatch_handler = Context_free.Expect_mismatch_handler.nop in\n let cts =\n get_whole_ast_passes ~hook ~expect_mismatch_handler ~tool_name\n ~input_name:None\n in\n if !perform_checks then\n Printf.printf \"\\n\";\n List.iter cts ~f:(fun ct -> Printf.printf \"%s\\n\" ct.Transform.name);\n if !perform_checks then (\n Printf.printf \"\\n\";\n if !perform_checks_on_extensions then\n Printf.printf \"\\n\")\n\n(*$*)\n\nlet map_structure_gen st ~tool_name ~hook ~expect_mismatch_handler ~input_name\n ~embed_errors =\n Cookies.acknowledge_cookies T;\n if !perform_checks then (\n Attribute.reset_checks ();\n Attribute.collect#structure st);\n let lint lint_errors st =\n let st =\n match lint_errors with\n | [] -> st\n | _ ->\n List.map lint_errors\n ~f:(fun ({ attr_name = { loc; _ }; _ } as attr) ->\n Ast_builder.Default.pstr_attribute ~loc attr)\n @ st\n in\n st\n in\n let cookies_and_check st =\n Cookies.call_post_handlers T;\n if !perform_checks then (\n (* TODO: these two passes could be merged, we now have more passes for\n checks than for actual rewriting. *)\n Attribute.check_unused#structure st;\n if !perform_checks_on_extensions then Extension.check_unused#structure st;\n Attribute.check_all_seen ();\n if !perform_locations_check then\n let open Location_check in\n ignore\n ((enforce_invariants !loc_fname)#structure st\n Non_intersecting_ranges.empty\n : Non_intersecting_ranges.t));\n st\n in\n let file_path = File_path.get_default_path_str st in\n match\n apply_transforms st ~tool_name ~file_path\n ~field:(fun (ct : Transform.t) -> ct.impl)\n ~lint_field:(fun (ct : Transform.t) -> ct.lint_impl)\n ~dropped_so_far:Attribute.dropped_so_far_structure ~hook\n ~expect_mismatch_handler ~input_name\n ~f_exception:(fun exn -> exn_to_str_extension exn)\n ~embed_errors\n with\n | Error (st, lint_errors) -> Error (lint lint_errors st)\n | Ok (st, lint_errors) -> Ok (st |> lint lint_errors |> cookies_and_check)\n\nlet map_structure st =\n match\n map_structure_gen st\n ~tool_name:(Astlib.Ast_metadata.tool_name ())\n ~hook:Context_free.Generated_code_hook.nop\n ~expect_mismatch_handler:Context_free.Expect_mismatch_handler.nop\n ~input_name:None ~embed_errors:false\n with\n | Ok ast | Error ast -> ast\n\n(*$ str_to_sig _last_text_block *)\n\nlet map_signature_gen sg ~tool_name ~hook ~expect_mismatch_handler ~input_name\n ~embed_errors =\n Cookies.acknowledge_cookies T;\n if !perform_checks then (\n Attribute.reset_checks ();\n Attribute.collect#signature sg);\n let lint lint_errors sg =\n let sg =\n match lint_errors with\n | [] -> sg\n | _ ->\n List.map lint_errors\n ~f:(fun ({ attr_name = { loc; _ }; _ } as attr) ->\n Ast_builder.Default.psig_attribute ~loc attr)\n @ sg\n in\n sg\n in\n let cookies_and_check sg =\n Cookies.call_post_handlers T;\n if !perform_checks then (\n (* TODO: these two passes could be merged, we now have more passes for\n checks than for actual rewriting. *)\n Attribute.check_unused#signature sg;\n if !perform_checks_on_extensions then Extension.check_unused#signature sg;\n Attribute.check_all_seen ();\n if !perform_locations_check then\n let open Location_check in\n ignore\n ((enforce_invariants !loc_fname)#signature sg\n Non_intersecting_ranges.empty\n : Non_intersecting_ranges.t));\n sg\n in\n let file_path = File_path.get_default_path_sig sg in\n match\n apply_transforms sg ~tool_name ~file_path\n ~field:(fun (ct : Transform.t) -> ct.intf)\n ~lint_field:(fun (ct : Transform.t) -> ct.lint_intf)\n ~dropped_so_far:Attribute.dropped_so_far_signature ~hook\n ~expect_mismatch_handler ~input_name\n ~f_exception:(fun exn -> exn_to_sig_extension exn)\n ~embed_errors\n with\n | Error (sg, lint_errors) -> Error (lint lint_errors sg)\n | Ok (sg, lint_errors) -> Ok (sg |> lint lint_errors |> cookies_and_check)\n\nlet map_signature sg =\n match\n map_signature_gen sg\n ~tool_name:(Astlib.Ast_metadata.tool_name ())\n ~hook:Context_free.Generated_code_hook.nop\n ~expect_mismatch_handler:Context_free.Expect_mismatch_handler.nop\n ~input_name:None ~embed_errors:false\n with\n | Ok ast | Error ast -> ast\n\n(*$*)\n\n(* +-----------------------------------------------------------------+\n | Entry points |\n +-----------------------------------------------------------------+ *)\n\nlet string_contains_binary_ast s =\n let test magic_number =\n String.is_prefix s ~prefix:(String.sub magic_number ~pos:0 ~len:9)\n in\n test Ast_magic.ast_intf_magic_number || test Ast_magic.ast_impl_magic_number\n\nlet versioned_errorf input_version input_file_name =\n Printf.ksprintf (fun msg ->\n let err =\n Location.Error.make ~loc:(Location.in_file input_file_name) msg ~sub:[]\n in\n Error (err, input_version))\n\nlet remove_no_error fn = try Caml.Sys.remove fn with Sys_error _ -> ()\n\nlet protectx x ~f ~finally =\n match f x with\n | v ->\n finally x;\n v\n | exception e ->\n finally x;\n raise e\n\nlet with_preprocessed_file fn ~f =\n match !preprocessor with\n | None -> f fn\n | Some pp ->\n protectx (Caml.Filename.temp_file \"ocamlpp\" \"\") ~finally:remove_no_error\n ~f:(fun tmpfile ->\n match System.run_preprocessor ~pp ~input:fn ~output:tmpfile with\n | Ok () -> f tmpfile\n | Error (failed_command, fall_back_version) ->\n versioned_errorf fall_back_version fn\n \"Error while running external preprocessor\\nCommand line: %s\\n\"\n failed_command)\n\nlet relocate_mapper =\n object\n inherit [string * string] Ast_traverse.map_with_context\n\n method! position (old_fn, new_fn) pos =\n if String.equal pos.pos_fname old_fn then { pos with pos_fname = new_fn }\n else pos\n end\n\n(* Set the input name globally. This is used by some ppx rewriters\n such as bisect_ppx. *)\nlet set_input_name = Astlib.Location.set_input_name\n\nlet load_input ~(kind : Kind.t) ~input_name ~relocate fn =\n set_input_name input_name;\n let input_source = if String.equal fn \"-\" then Ast_io.Stdin else File fn in\n let input_kind = Ast_io.Possibly_source (kind, input_name) in\n match Ast_io.read input_source ~input_kind with\n | Ok { input_name = ast_input_name; input_version; ast } ->\n let ast_kind = Intf_or_impl.kind ast in\n if not (Kind.equal kind ast_kind) then\n versioned_errorf input_version fn\n \"File contains a binary %s AST but an %s was expected\"\n (Kind.describe ast_kind) (Kind.describe kind)\n else if String.equal ast_input_name input_name || not relocate then (\n set_input_name ast_input_name;\n Ok (ast_input_name, input_version, ast))\n else\n Ok\n ( input_name,\n input_version,\n Intf_or_impl.map_with_context ast relocate_mapper\n (ast_input_name, input_name) )\n | Error (Unknown_version (unknown_magic, fall_back_version)) ->\n versioned_errorf fall_back_version fn\n \"File is a binary ast for an unknown version of OCaml with magic \\\n number '%s'\"\n unknown_magic\n | Error (System_error (error, fall_back_version))\n | Error (Source_parse_error (error, fall_back_version)) ->\n Error (error, fall_back_version)\n | Error Not_a_binary_ast -> assert false\n\nlet load_input_run_as_ppx fn =\n (* If there's an error while loading in run_as_ppx mode, the kind of AST (impl/intf) is still unknown.\n That's why, as opposed to load_input, this function raises errors instead of returning a result:\n handling an error by returning an AST with the error packed as extension node wouldn't be possible. *)\n match Ast_io.read (File fn) ~input_kind:Ast_io.Necessarily_binary with\n | Ok { input_name = ast_input_name; input_version; ast } ->\n let ast =\n match !loc_fname with\n | None ->\n set_input_name ast_input_name;\n ast\n | Some input_name ->\n set_input_name input_name;\n if String.equal ast_input_name input_name then ast\n else\n Intf_or_impl.map_with_context ast relocate_mapper\n (ast_input_name, input_name)\n in\n (* With `--as-ppx`, ocaml calls the standalone separately for every structure/signature item\n with the filename as metadata that it gets from the previous call. relocate_mapper only\n relocates positions whose position filename coincides with that metadata filename.\n So always return the metadata filename itself, even if `-loc-filename` is provided. *)\n (ast_input_name, input_version, ast)\n | Error (Unknown_version (unknown_magic, _)) ->\n Location.raise_errorf ~loc:(Location.in_file fn)\n \"The input is a binary ast for an unknown version of OCaml with magic \\\n number '%s'\"\n unknown_magic\n | Error Not_a_binary_ast ->\n Location.raise_errorf ~loc:(Location.in_file fn)\n \"Expected a binary AST as input\"\n | Error (System_error (error, _)) | Error (Source_parse_error (error, _)) ->\n let open Location.Error in\n Location.set_filename (get_location error) fn |> update_loc error |> raise\n\nlet load_source_file fn =\n let s = In_channel.read_all fn in\n if string_contains_binary_ast s then\n Location.raise_errorf ~loc:(Location.in_file fn)\n \"ppxlib_driver: cannot use -reconcile with binary AST files\";\n s\n\ntype output_mode =\n | Pretty_print\n | Dump_ast\n | Dparsetree\n | Reconcile of Reconcile.mode\n | Null\n\n(*$*)\nlet extract_cookies_str st =\n let st =\n match st with\n | ({\n pstr_desc =\n Pstr_attribute { attr_name = { txt = \"ocaml.ppx.context\"; _ }; _ };\n _;\n } as prefix)\n :: st ->\n let prefix = Ppxlib_ast.Selected_ast.to_ocaml Structure [ prefix ] in\n assert (\n List.is_empty\n (Astlib.Ast_metadata.drop_ppx_context_str ~restore:true prefix));\n st\n | _ -> st\n in\n (* The cli cookies have to be set after restoring the ppx context,\n since restoring the ppx context resets the cookies *)\n List.iter !Cookies.given_through_cli ~f:(fun (name, expr) ->\n Cookies.set T name expr);\n st\n\nlet add_cookies_str st =\n let prefix =\n Astlib.Ast_metadata.add_ppx_context_str ~tool_name:\"ppxlib_driver\" []\n |> Ppxlib_ast.Selected_ast.of_ocaml Structure\n in\n prefix @ st\n\n(*$ str_to_sig _last_text_block *)\nlet extract_cookies_sig sg =\n let sg =\n match sg with\n | ({\n psig_desc =\n Psig_attribute { attr_name = { txt = \"ocaml.ppx.context\"; _ }; _ };\n _;\n } as prefix)\n :: sg ->\n let prefix = Ppxlib_ast.Selected_ast.to_ocaml Signature [ prefix ] in\n assert (\n List.is_empty\n (Astlib.Ast_metadata.drop_ppx_context_sig ~restore:true prefix));\n sg\n | _ -> sg\n in\n (* The cli cookies have to be set after restoring the ppx context,\n since restoring the ppx context resets the cookies *)\n List.iter !Cookies.given_through_cli ~f:(fun (name, expr) ->\n Cookies.set T name expr);\n sg\n\nlet add_cookies_sig sg =\n let prefix =\n Astlib.Ast_metadata.add_ppx_context_sig ~tool_name:\"ppxlib_driver\" []\n |> Ppxlib_ast.Selected_ast.of_ocaml Signature\n in\n prefix @ sg\n\n(*$*)\n\nlet extract_cookies (ast : Intf_or_impl.t) : Intf_or_impl.t =\n match ast with\n | Intf x -> Intf (extract_cookies_sig x)\n | Impl x -> Impl (extract_cookies_str x)\n\nlet add_cookies (ast : Intf_or_impl.t) : Intf_or_impl.t =\n match ast with\n | Intf x -> Intf (add_cookies_sig x)\n | Impl x -> Impl (add_cookies_str x)\n\nlet corrections = ref []\nlet add_to_list r x = r := x :: !r\n\nlet register_correction ~loc ~repl =\n add_to_list corrections\n (Reconcile.Replacement.make_text () ~start:loc.loc_start ~stop:loc.loc_end\n ~repl)\n\nlet process_file_hooks = ref []\nlet register_process_file_hook f = add_to_list process_file_hooks f\n\nmodule File_property = struct\n type 'a t = {\n name : string;\n mutable data : 'a option;\n sexp_of_t : 'a -> Sexp.t;\n }\n\n type packed = T : _ t -> packed\n\n let all = ref []\n let register t = add_to_list all (T t)\n let reset_all () = List.iter !all ~f:(fun (T t) -> t.data <- None)\n\n let dump_and_reset_all () =\n List.filter_map (List.rev !all) ~f:(fun (T t) ->\n match t.data with\n | None -> None\n | Some v ->\n t.data <- None;\n Some (t.name, t.sexp_of_t v))\nend\n\nmodule Create_file_property (Name : sig\n val name : string\nend)\n(T : Sexpable.S) =\nstruct\n let t : _ File_property.t =\n { name = Name.name; data = None; sexp_of_t = T.sexp_of_t }\n\n let () = File_property.register t\n let set x = t.data <- Some x\nend\n\nlet process_ast (ast : Intf_or_impl.t) ~input_name ~tool_name ~hook\n ~expect_mismatch_handler ~embed_errors =\n match ast with\n | Intf x ->\n let ast =\n match\n map_signature_gen x ~tool_name ~hook ~expect_mismatch_handler\n ~input_name:(Some input_name) ~embed_errors\n with\n | Error ast | Ok ast -> ast\n in\n Intf_or_impl.Intf ast\n | Impl x ->\n let ast =\n match\n map_structure_gen x ~tool_name ~hook ~expect_mismatch_handler\n ~input_name:(Some input_name) ~embed_errors\n with\n | Error ast | Ok ast -> ast\n in\n Intf_or_impl.Impl ast\n\nlet process_file (kind : Kind.t) fn ~input_name ~relocate ~output_mode\n ~embed_errors ~output =\n File_property.reset_all ();\n List.iter (List.rev !process_file_hooks) ~f:(fun f -> f ());\n corrections := [];\n let replacements = ref [] in\n let tool_name = \"ppx_driver\" in\n let hook : Context_free.Generated_code_hook.t =\n match output_mode with\n | Reconcile (Using_line_directives | Delimiting_generated_blocks) ->\n {\n f =\n (fun context (loc : Location.t) generated ->\n add_to_list replacements\n (Reconcile.Replacement.make () ~context:(Extension context)\n ~start:loc.loc_start ~stop:loc.loc_end ~repl:generated));\n }\n | _ -> Context_free.Generated_code_hook.nop\n in\n let expect_mismatch_handler : Context_free.Expect_mismatch_handler.t =\n {\n f =\n (fun context (loc : Location.t) generated ->\n add_to_list corrections\n (Reconcile.Replacement.make () ~context:(Floating_attribute context)\n ~start:loc.loc_start ~stop:loc.loc_end ~repl:(Many generated)));\n }\n in\n\n let input_name, input_version, ast =\n let preprocessed_and_loaded =\n with_preprocessed_file fn ~f:(load_input ~kind ~input_name ~relocate)\n in\n match preprocessed_and_loaded with\n | Ok (input_fname, input_version, ast) -> (\n try\n let ast =\n extract_cookies ast\n |> process_ast ~input_name ~tool_name ~hook ~expect_mismatch_handler\n ~embed_errors\n in\n (input_fname, input_version, ast)\n with exn when embed_errors ->\n (input_fname, input_version, exn_to_extension exn ~kind))\n | Error (error, input_version) when embed_errors ->\n (input_name, input_version, error_to_extension error ~kind)\n | Error (error, _) ->\n let open Location.Error in\n Location.set_filename (get_location error) fn\n |> update_loc error |> raise\n in\n Option.iter !output_metadata_filename ~f:(fun fn ->\n let metadata = File_property.dump_and_reset_all () in\n Out_channel.write_all fn\n ~data:\n (List.map metadata ~f:(fun (s, sexp) ->\n Sexp.to_string_hum (Sexp.List [ Atom s; sexp ]) ^ \"\\n\")\n |> String.concat ~sep:\"\"));\n\n let input_contents = lazy (load_source_file fn) in\n let corrected = fn ^ !corrected_suffix in\n let mismatches_found =\n match !corrections with\n | [] ->\n if Caml.Sys.file_exists corrected then Caml.Sys.remove corrected;\n false\n | corrections ->\n Reconcile.reconcile corrections\n ~contents:(Lazy.force input_contents)\n ~output:(Some corrected) ~input_filename:fn ~input_name\n ~target:Corrected ?styler:!styler ~kind;\n true\n in\n\n (match output_mode with\n | Null -> ()\n | Pretty_print ->\n with_output output ~binary:false ~f:(fun oc ->\n let ppf = Caml.Format.formatter_of_out_channel oc in\n (match ast with\n | Intf ast -> Pprintast.signature ppf ast\n | Impl ast -> Pprintast.structure ppf ast);\n let null_ast =\n match ast with Intf [] | Impl [] -> true | _ -> false\n in\n if not null_ast then Caml.Format.pp_print_newline ppf ())\n | Dump_ast ->\n with_output output ~binary:true ~f:(fun oc ->\n Ast_io.write oc\n { input_name; input_version; ast }\n ~add_ppx_context:true)\n | Dparsetree ->\n with_output output ~binary:false ~f:(fun oc ->\n let ppf = Caml.Format.formatter_of_out_channel oc in\n let ast = add_cookies ast in\n (match ast with\n | Intf ast -> Sexp.pp_hum ppf (Ast_traverse.sexp_of#signature ast)\n | Impl ast -> Sexp.pp_hum ppf (Ast_traverse.sexp_of#structure ast));\n Caml.Format.pp_print_newline ppf ())\n | Reconcile mode ->\n Reconcile.reconcile !replacements\n ~contents:(Lazy.force input_contents)\n ~output ~input_filename:fn ~input_name ~target:(Output mode)\n ?styler:!styler ~kind);\n\n if\n mismatches_found && match !diff_command with Some \"-\" -> false | _ -> true\n then (\n Ppxlib_print_diff.print () ~file1:fn ~file2:corrected ~use_color:!use_color\n ?diff_command:!diff_command;\n Caml.exit 1)\n\nlet output_mode = ref Pretty_print\nlet output = ref None\nlet kind = ref None\nlet input = ref None\nlet embed_errors = ref false\n\nlet set_input fn =\n match !input with\n | None -> input := Some fn\n | Some _ -> raise (Arg.Bad \"too many input files\")\n\nlet set_kind k =\n match !kind with\n | Some k' when not (Kind.equal k k') ->\n raise (Arg.Bad \"must specify at most one of -impl or -intf\")\n | _ -> kind := Some k\n\nlet set_output_mode mode =\n match (!output_mode, mode) with\n | Pretty_print, _ -> output_mode := mode\n | _, Pretty_print -> assert false\n | Dump_ast, Dump_ast | Dparsetree, Dparsetree -> ()\n | Reconcile a, Reconcile b when Poly.equal a b -> ()\n | x, y ->\n let arg_of_output_mode = function\n | Pretty_print -> assert false\n | Dump_ast -> \"-dump-ast\"\n | Dparsetree -> \"-dparsetree\"\n | Reconcile Using_line_directives -> \"-reconcile\"\n | Reconcile Delimiting_generated_blocks -> \"-reconcile-with-comments\"\n | Null -> \"-null\"\n in\n raise\n (Arg.Bad\n (Printf.sprintf \"%s and %s are incompatible\" (arg_of_output_mode x)\n (arg_of_output_mode y)))\n\nlet print_transformations () =\n List.iter !Transform.all ~f:(fun (ct : Transform.t) ->\n Printf.printf \"%s\\n\" ct.name)\n\nlet parse_apply_list s =\n let names =\n if String.equal s \"\" then [] else String.split_on_char s ~sep:','\n in\n List.iter names ~f:(fun name ->\n if\n not\n (List.exists !Transform.all ~f:(fun (ct : Transform.t) ->\n Transform.has_name ct name))\n then\n raise\n (Caml.Arg.Bad\n (Printf.sprintf \"code transformation '%s' does not exist\" name)));\n names\n\ntype mask = {\n mutable apply : string list option;\n mutable dont_apply : string list option;\n}\n\nlet mask = { apply = None; dont_apply = None }\n\nlet handle_apply s =\n if Option.is_some mask.apply then\n raise (Arg.Bad \"-apply called too many times\");\n (* This is not strictly necessary but it's more intuitive *)\n if Option.is_some mask.dont_apply then\n raise (Arg.Bad \"-apply must be called before -dont-apply\");\n mask.apply <- Some (parse_apply_list s)\n\nlet handle_dont_apply s =\n if Option.is_some mask.dont_apply then\n raise (Arg.Bad \"-apply called too many times\");\n mask.dont_apply <- Some (parse_apply_list s)\n\nlet interpret_mask () =\n if Option.is_some mask.apply || Option.is_some mask.dont_apply then\n let selected_transform_name ct =\n let is_candidate =\n match mask.apply with\n | None -> true\n | Some names -> List.exists names ~f:(Transform.has_name ct)\n in\n let is_selected =\n match mask.dont_apply with\n | None -> is_candidate\n | Some names ->\n is_candidate && not (List.exists names ~f:(Transform.has_name ct))\n in\n if is_selected then Some ct.name else None\n in\n apply_list :=\n Some (List.filter_map !Transform.all ~f:selected_transform_name)\n\nlet set_cookie s =\n match String.lsplit2 s ~on:'=' with\n | None ->\n raise (Arg.Bad \"invalid cookie, must be of the form \\\"=\\\"\")\n | Some (name, value) ->\n let lexbuf = Lexing.from_string value in\n lexbuf.Lexing.lex_curr_p <-\n {\n Lexing.pos_fname = \"\";\n pos_lnum = 1;\n pos_bol = 0;\n pos_cnum = 0;\n };\n let expr = Parse.expression lexbuf in\n Cookies.given_through_cli := (name, expr) :: !Cookies.given_through_cli\n\nlet shared_args =\n [\n ( \"-loc-filename\",\n Arg.String (fun s -> loc_fname := Some s),\n \" File name to use in locations\" );\n ( \"-reserve-namespace\",\n Arg.String Name.Reserved_namespaces.reserve,\n \" Mark the given namespace as reserved\" );\n (\"-no-check\", Arg.Clear perform_checks, \" Disable checks (unsafe)\");\n (\"-check\", Arg.Set perform_checks, \" Enable checks\");\n ( \"-no-check-on-extensions\",\n Arg.Clear perform_checks_on_extensions,\n \" Disable checks on extension point only\" );\n ( \"-check-on-extensions\",\n Arg.Set perform_checks_on_extensions,\n \" Enable checks on extension point only\" );\n ( \"-no-locations-check\",\n Arg.Clear perform_locations_check,\n \" Disable locations check only\" );\n ( \"-locations-check\",\n Arg.Set perform_locations_check,\n \" Enable locations check only\" );\n ( \"-apply\",\n Arg.String handle_apply,\n \" Apply these transformations in order (comma-separated list)\" );\n ( \"-dont-apply\",\n Arg.String handle_dont_apply,\n \" Exclude these transformations\" );\n ( \"-no-merge\",\n Arg.Set no_merge,\n \" Do not merge context free transformations (better for debugging \\\n rewriters). As a result, the context-free transformations are not all \\\n applied before all impl and intf.\" );\n (\"-cookie\", Arg.String set_cookie, \"NAME=EXPR Set the cookie NAME to EXPR\");\n (\"--cookie\", Arg.String set_cookie, \" Same as -cookie\");\n ]\n\nlet () =\n List.iter shared_args ~f:(fun (key, spec, doc) -> add_arg key spec ~doc)\n\nlet as_pp () =\n set_output_mode Dump_ast;\n embed_errors := true\n\nlet standalone_args =\n [\n ( \"-as-ppx\",\n Arg.Unit (fun () -> raise (Arg.Bad \"-as-ppx must be the first argument\")),\n \" Run as a -ppx rewriter (must be the first argument)\" );\n ( \"--as-ppx\",\n Arg.Unit (fun () -> raise (Arg.Bad \"--as-ppx must be the first argument\")),\n \" Same as -as-ppx\" );\n (\"-as-pp\", Arg.Unit as_pp, \" Shorthand for: -dump-ast -embed-errors\");\n (\"--as-pp\", Arg.Unit as_pp, \" Same as -as-pp\");\n ( \"-o\",\n Arg.String (fun s -> output := Some s),\n \" Output file (use '-' for stdout)\" );\n (\"-\", Arg.Unit (fun () -> set_input \"-\"), \" Read input from stdin\");\n ( \"-dump-ast\",\n Arg.Unit (fun () -> set_output_mode Dump_ast),\n \" Dump the marshaled ast to the output file instead of pretty-printing it\"\n );\n ( \"--dump-ast\",\n Arg.Unit (fun () -> set_output_mode Dump_ast),\n \" Same as -dump-ast\" );\n ( \"-dparsetree\",\n Arg.Unit (fun () -> set_output_mode Dparsetree),\n \" Print the parsetree (same as ocamlc -dparsetree)\" );\n ( \"-embed-errors\",\n Arg.Set embed_errors,\n \" Embed errors in the output AST (default: true when -dump-ast, false \\\n otherwise)\" );\n ( \"-null\",\n Arg.Unit (fun () -> set_output_mode Null),\n \" Produce no output, except for errors\" );\n ( \"-impl\",\n Arg.Unit (fun () -> set_kind Impl),\n \" Treat the input as a .ml file\" );\n (\"--impl\", Arg.Unit (fun () -> set_kind Impl), \" Same as -impl\");\n ( \"-intf\",\n Arg.Unit (fun () -> set_kind Intf),\n \" Treat the input as a .mli file\" );\n (\"--intf\", Arg.Unit (fun () -> set_kind Intf), \" Same as -intf\");\n ( \"-debug-attribute-drop\",\n Arg.Set debug_attribute_drop,\n \" Debug attribute dropping\" );\n ( \"-print-transformations\",\n Arg.Set request_print_transformations,\n \" Print linked-in code transformations, in the order they are applied\" );\n ( \"-print-passes\",\n Arg.Set request_print_passes,\n \" Print the actual passes over the whole AST in the order they are \\\n applied\" );\n ( \"-ite-check\",\n Arg.Unit\n (fun () ->\n Printf.eprintf\n \"Warning: the -ite-check flag is deprecated and has no effect.\\n%!\";\n Extra_warnings.care_about_ite_branch := true),\n \" (no effect -- kept for compatibility)\" );\n ( \"-pp\",\n Arg.String (fun s -> preprocessor := Some s),\n \" Pipe sources through preprocessor (incompatible \\\n with -as-ppx)\" );\n ( \"-reconcile\",\n Arg.Unit (fun () -> set_output_mode (Reconcile Using_line_directives)),\n \" (WIP) Pretty print the output using a mix of the input source and the \\\n generated code\" );\n ( \"-reconcile-with-comments\",\n Arg.Unit\n (fun () -> set_output_mode (Reconcile Delimiting_generated_blocks)),\n \" (WIP) same as -reconcile but uses comments to enclose the generated \\\n code\" );\n (\"-no-color\", Arg.Clear use_color, \" Don't use colors when printing errors\");\n ( \"-diff-cmd\",\n Arg.String (fun s -> diff_command := Some s),\n \" Diff command when using code expectations (use - to disable diffing)\" );\n ( \"-pretty\",\n Arg.Set pretty,\n \" Instruct code generators to improve the prettiness of the generated \\\n code\" );\n (\"-styler\", Arg.String (fun s -> styler := Some s), \" Code styler\");\n ( \"-output-metadata\",\n Arg.String (fun s -> output_metadata_filename := Some s),\n \"FILE Where to store the output metadata\" );\n ( \"-corrected-suffix\",\n Arg.Set_string corrected_suffix,\n \"SUFFIX Suffix to append to corrected files\" );\n ]\n\nlet get_args ?(standalone_args = standalone_args) () =\n standalone_args @ List.rev !args\n\nlet standalone_main () =\n let usage = Printf.sprintf \"%s [extra_args] []\" exe_name in\n let args = get_args () in\n Arg.parse (Arg.align args) set_input usage;\n interpret_mask ();\n if !request_print_transformations then (\n print_transformations ();\n Caml.exit 0);\n if !request_print_passes then (\n print_passes ();\n Caml.exit 0);\n match !input with\n | None ->\n Printf.eprintf \"%s: no input file given\\n%!\" exe_name;\n Caml.exit 2\n | Some fn ->\n let kind =\n match !kind with\n | Some k -> k\n | None -> (\n match Kind.of_filename fn with\n | Some k -> k\n | None ->\n Printf.eprintf\n \"%s: don't know what to do with '%s', use -impl or -intf.\\n\"\n exe_name fn;\n Caml.exit 2)\n in\n let input_name, relocate =\n match !loc_fname with None -> (fn, false) | Some fn -> (fn, true)\n in\n process_file kind fn ~input_name ~relocate ~output_mode:!output_mode\n ~output:!output ~embed_errors:!embed_errors\n\nlet rewrite_binary_ast_file input_fn output_fn =\n let input_name, input_version, ast = load_input_run_as_ppx input_fn in\n let ast =\n try\n let ast = extract_cookies ast in\n let tool_name = Astlib.Ast_metadata.tool_name () in\n let hook = Context_free.Generated_code_hook.nop in\n let expect_mismatch_handler = Context_free.Expect_mismatch_handler.nop in\n process_ast ast ~input_name ~tool_name ~hook ~expect_mismatch_handler\n ~embed_errors:true\n with exn -> exn_to_extension exn ~kind:(Intf_or_impl.kind ast)\n in\n with_output (Some output_fn) ~binary:true ~f:(fun oc ->\n Ast_io.write oc { input_name; input_version; ast } ~add_ppx_context:true)\n\nlet parse_input passed_in_args ~valid_args ~incorrect_input_msg =\n try\n Arg.parse_argv passed_in_args (Arg.align valid_args)\n (fun _ -> raise (Arg.Bad \"anonymous arguments not accepted\"))\n incorrect_input_msg\n with\n | Arg.Bad msg ->\n Printf.eprintf \"%s\" msg;\n Caml.exit 2\n | Arg.Help msg ->\n Printf.eprintf \"%s\" msg;\n Caml.exit 0\n\nlet run_as_ppx_rewriter_main ~standalone_args ~usage input =\n let valid_args = get_args ~standalone_args () in\n match List.rev @@ Array.to_list @@ input with\n | output_fn :: input_fn :: flags_and_prog_name\n when List.length flags_and_prog_name > 0 ->\n let prog_name_and_flags = List.rev flags_and_prog_name |> Array.of_list in\n parse_input prog_name_and_flags ~valid_args ~incorrect_input_msg:usage;\n interpret_mask ();\n rewrite_binary_ast_file input_fn output_fn;\n Caml.exit 0\n | [ help; _ ] when String.equal help \"-help\" || String.equal help \"--help\" ->\n parse_input input ~valid_args ~incorrect_input_msg:usage;\n assert false\n | _ ->\n Printf.eprintf \"Usage: %s\\n%!\" usage;\n Caml.exit 2\n\nlet standalone_run_as_ppx_rewriter () =\n let n = Array.length Caml.Sys.argv in\n let usage =\n Printf.sprintf \"%s -as-ppx [extra_args] \" exe_name\n in\n let argv = Array.make (n - 1) \"\" in\n argv.(0) <- Caml.Sys.argv.(0);\n for i = 1 to n - 2 do\n argv.(i) <- Caml.Sys.argv.(i + 1)\n done;\n let standalone_args =\n List.map standalone_args ~f:(fun (arg, spec, _doc) ->\n (arg, spec, \" Unused with -as-ppx\"))\n in\n run_as_ppx_rewriter_main ~standalone_args ~usage argv\n\nlet standalone () =\n Astlib.init_error_reporting_style_using_env_vars ();\n try\n if\n Array.length Caml.Sys.argv >= 2\n &&\n match Caml.Sys.argv.(1) with \"-as-ppx\" | \"--as-ppx\" -> true | _ -> false\n then standalone_run_as_ppx_rewriter ()\n else standalone_main ();\n Caml.exit 0\n with exn ->\n Location.report_exception Caml.Format.err_formatter exn;\n Caml.exit 1\n\nlet run_as_ppx_rewriter () =\n let usage = Printf.sprintf \"%s [extra_args] \" exe_name in\n let input = Caml.Sys.argv in\n try run_as_ppx_rewriter_main ~standalone_args:[] ~usage input\n with exn ->\n Location.report_exception Caml.Format.err_formatter exn;\n Caml.exit 1\n\nlet pretty () = !pretty\n\nlet enable_checks () =\n (* We do not enable the locations check here, we currently require that one\n to be specifically enabled. *)\n perform_checks := true;\n perform_checks_on_extensions := true\n\nlet enable_location_check () = perform_locations_check := true\nlet disable_location_check () = perform_locations_check := false\nlet map_structure st = map_structure st\n","open! Import\n\nlet mk_attr_noloc txt = Ast_helper.Attr.mk Location.{ txt; loc = none }\nlet hide_attribute : attribute = mk_attr_noloc \"merlin.hide\" (PStr [])\nlet focus_attribute : attribute = mk_attr_noloc \"merlin.focus\" (PStr [])\n\nlet hide_pattern ({ ppat_attributes; _ } as p) =\n { p with ppat_attributes = hide_attribute :: ppat_attributes }\n\nlet focus_pattern ({ ppat_attributes; _ } as p) =\n { p with ppat_attributes = focus_attribute :: ppat_attributes }\n\nlet hide_expression ({ pexp_attributes; _ } as e) =\n { e with pexp_attributes = hide_attribute :: pexp_attributes }\n\nlet focus_expression ({ pexp_attributes; _ } as e) =\n { e with pexp_attributes = focus_attribute :: pexp_attributes }\n","open Import\nopen Ast_builder.Default\n\nlet underscore_binding exp =\n let loc = exp.pexp_loc in\n value_binding ~loc ~pat:(ppat_any ~loc) ~expr:exp\n\nlet vars_of =\n object\n inherit [Longident.t Located.t list] Ast_traverse.fold as super\n\n method! pattern patt acc =\n match patt.ppat_desc with\n | Ppat_var v -> Located.map (fun var -> Longident.Lident var) v :: acc\n | _ -> super#pattern patt acc\n end\n\n(* For every [let x = ...] structure item, add a [let _ = x] *)\nlet add_dummy_user_for_values =\n object\n inherit Ast_traverse.map as super\n\n method! structure st =\n let rec loop st acc =\n match st with\n | [] -> List.rev acc\n | ({ pstr_desc = Pstr_value (_, vbs); pstr_loc = loc } as item) :: rest\n ->\n let vars =\n List.fold_left vbs ~init:[] ~f:(fun acc vb ->\n vars_of#pattern vb.pvb_pat acc)\n in\n let ign =\n pstr_value_list ~loc Nonrecursive\n (List.rev_map vars ~f:(fun v ->\n underscore_binding (pexp_ident ~loc:v.loc v)))\n in\n loop rest (ign @ (item :: acc))\n | item :: rest -> loop rest (item :: acc)\n in\n loop (super#structure st) []\n end\n\nlet binds_module_names =\n object\n inherit [bool] Ast_traverse.fold as super\n\n method! module_binding mb acc =\n match mb.pmb_name.txt with\n | Some (_ : string) -> true\n | None -> super#module_binding mb acc\n\n method! module_declaration md acc =\n match md.pmd_name.txt with\n | Some (_ : string) -> true\n | None -> super#module_declaration md acc\n\n method! module_substitution ms _ =\n match ms.pms_name.txt with (_ : string) -> true\n\n method! functor_parameter fp acc =\n match fp with\n | Unit -> acc\n | Named (name, _) -> (\n match name.txt with\n | Some (_ : string) -> true\n | None -> super#functor_parameter fp acc)\n\n method! pattern pat acc =\n match pat.ppat_desc with\n | Ppat_unpack name -> (\n match name.txt with Some (_ : string) -> true | None -> acc)\n | _ -> super#pattern pat acc\n\n method! expression expr acc =\n match expr.pexp_desc with\n | Pexp_letmodule (name, _, _) -> (\n match name.txt with\n | Some (_ : string) -> true\n | None -> super#expression expr acc)\n | _ -> super#expression expr acc\n end\n","open! Import\ninclude Clause_syntax_intf\n\nmodule Variant = struct\n type ast = constructor_declaration\n\n type t =\n { ast : ast\n ; position : int\n }\n\n let create_list list =\n List.mapi list ~f:(fun position ast ->\n let loc = ast.pcd_loc in\n match ast.pcd_res with\n | Some _ -> unsupported ~loc \"GADT\"\n | None -> { ast; position })\n ;;\n\n let salt t = Some t.position\n let location t = t.ast.pcd_loc\n\n let weight_attribute =\n Attribute.declare\n \"quickcheck.weight\"\n Attribute.Context.constructor_declaration\n Ast_pattern.(pstr (pstr_eval __ nil ^:: nil))\n (fun x -> x)\n ;;\n\n let weight t =\n match Attribute.get weight_attribute t.ast with\n | Some expr -> expr\n | None -> efloat ~loc:{ (location t) with loc_ghost = true } \"1.\"\n ;;\n\n let core_type_list t =\n match t.ast.pcd_args with\n | Pcstr_tuple list -> list\n | Pcstr_record label_decl_list ->\n List.map label_decl_list ~f:(fun label_decl -> label_decl.pld_type)\n ;;\n\n let pattern t ~loc pat_list =\n let arg =\n match t.ast.pcd_args with\n | Pcstr_tuple _ ->\n (match pat_list with\n | [] -> None\n | [ pat ] -> Some pat\n | _ -> Some (ppat_tuple ~loc pat_list))\n | Pcstr_record label_decl_list ->\n let alist =\n List.map2_exn label_decl_list pat_list ~f:(fun label_decl pat ->\n lident_loc label_decl.pld_name, pat)\n in\n Some (ppat_record ~loc alist Closed)\n in\n ppat_construct ~loc (lident_loc t.ast.pcd_name) arg\n ;;\n\n let expression t ~loc _ expr_list =\n let arg =\n match t.ast.pcd_args with\n | Pcstr_tuple _ ->\n (match expr_list with\n | [] -> None\n | [ expr ] -> Some expr\n | _ -> Some (pexp_tuple ~loc expr_list))\n | Pcstr_record label_decl_list ->\n let alist =\n List.map2_exn label_decl_list expr_list ~f:(fun label_decl expr ->\n lident_loc label_decl.pld_name, expr)\n in\n Some (pexp_record ~loc alist None)\n in\n pexp_construct ~loc (lident_loc t.ast.pcd_name) arg\n ;;\nend\n\nmodule Polymorphic_variant = struct\n type ast = row_field\n type t = ast\n\n let create_list = Fn.id\n\n let salt t =\n match t.prf_desc with\n | Rtag (label, _, _) -> Some (Ocaml_common.Btype.hash_variant label.txt)\n | Rinherit _ -> None\n ;;\n\n let location t = t.prf_loc\n\n let weight_attribute =\n Attribute.declare\n \"quickcheck.weight\"\n Attribute.Context.rtag\n Ast_pattern.(pstr (pstr_eval __ nil ^:: nil))\n (fun x -> x)\n ;;\n\n let weight t =\n match Attribute.get weight_attribute t with\n | Some expr -> expr\n | None -> efloat ~loc:{ (location t) with loc_ghost = true } \"1.\"\n ;;\n\n let core_type_list t =\n match t.prf_desc with\n | Rtag (_, _, core_type_list) -> core_type_list\n | Rinherit core_type -> [ core_type ]\n ;;\n\n let pattern t ~loc pat_list =\n match t.prf_desc, pat_list with\n | Rtag (label, true, []), [] -> ppat_variant ~loc label.txt None\n | Rtag (label, false, [ _ ]), [ pat ] -> ppat_variant ~loc label.txt (Some pat)\n | Rtag (label, false, [ _ ]), _ :: _ :: _ ->\n ppat_variant ~loc label.txt (Some (ppat_tuple ~loc pat_list))\n | Rinherit { ptyp_desc; _ }, [ { ppat_desc; _ } ] ->\n (match ptyp_desc with\n | Ptyp_constr (id, []) ->\n (match ppat_desc with\n | Ppat_var var -> ppat_alias ~loc (ppat_type ~loc id) var\n | _ ->\n internal_error\n ~loc\n \"cannot bind a # pattern to anything other than a variable\")\n | _ ->\n unsupported ~loc \"inherited polymorphic variant type that is not a type name\")\n | Rtag (_, true, _ :: _), _ | Rtag (_, false, ([] | _ :: _ :: _)), _ ->\n unsupported ~loc \"intersection type\"\n | Rtag (_, true, []), _ :: _\n | Rtag (_, false, [ _ ]), []\n | Rinherit _, ([] | _ :: _ :: _) ->\n internal_error ~loc \"wrong number of arguments for variant clause\"\n ;;\n\n let expression t ~loc core_type expr_list =\n match t.prf_desc, expr_list with\n | Rtag (label, true, []), [] -> pexp_variant ~loc label.txt None\n | Rtag (label, false, [ _ ]), [ expr ] -> pexp_variant ~loc label.txt (Some expr)\n | Rtag (label, false, [ _ ]), _ :: _ :: _ ->\n pexp_variant ~loc label.txt (Some (pexp_tuple ~loc expr_list))\n | Rinherit inherited_type, [ expr ] ->\n pexp_coerce ~loc expr (Some inherited_type) core_type\n | Rtag (_, true, _ :: _), _ | Rtag (_, false, ([] | _ :: _ :: _)), _ ->\n unsupported ~loc \"intersection type\"\n | Rtag (_, true, []), _ :: _\n | Rtag (_, false, [ _ ]), []\n | Rinherit _, ([] | _ :: _ :: _) ->\n internal_error ~loc \"wrong number of arguments for variant clause\"\n ;;\nend\n","open! Import\ninclude Field_syntax_intf\n\nmodule Tuple = struct\n type ast = core_type\n type t = ast\n\n let create = Fn.id\n let location t = t.ptyp_loc\n let core_type t = t\n let pattern _ ~loc pat_list = ppat_tuple ~loc pat_list\n let expression _ ~loc expr_list = pexp_tuple ~loc expr_list\nend\n\nmodule Record = struct\n type ast = label_declaration\n type t = ast\n\n let create ast =\n match ast.pld_mutable with\n | Immutable -> ast\n | Mutable ->\n (* We intend to support mutable fields and values shortly, but we leave it to a\n separate feature. Integrating mutable values with replayability and shrinking is\n tricky, and we at least have to figure out what caveats to document. *)\n unsupported ~loc:ast.pld_loc \"mutable record field\"\n ;;\n\n let location t = t.pld_loc\n let core_type t = t.pld_type\n\n let pattern list ~loc pat_list =\n let alist =\n List.map2_exn list pat_list ~f:(fun t pat -> lident_loc t.pld_name, pat)\n in\n ppat_record ~loc alist Closed\n ;;\n\n let expression list ~loc expr_list =\n let alist =\n List.map2_exn list expr_list ~f:(fun t expr -> lident_loc t.pld_name, expr)\n in\n pexp_record ~loc alist None\n ;;\nend\n","open! Import\n\nlet any ~loc = [%expr Base_quickcheck.Shrinker.atomic]\nlet arrow ~loc = [%expr Base_quickcheck.Shrinker.atomic]\n\nlet compound_sequence ~loc ~make_compound_expr ~field_pats ~field_exprs ~shrinker_exprs =\n [%expr\n Base.Sequence.round_robin\n [%e\n elist\n ~loc\n (List.map3_exn\n field_pats\n field_exprs\n shrinker_exprs\n ~f:(fun field_pat field_expr shrinker ->\n let loc = { shrinker.pexp_loc with loc_ghost = true } in\n [%expr\n Base.Sequence.map\n (Base_quickcheck.Shrinker.shrink [%e shrinker] [%e field_expr])\n ~f:(fun [%p field_pat] -> [%e make_compound_expr ~loc field_exprs])]))]]\n;;\n\nlet compound\n (type field)\n ~shrinker_of_core_type\n ~loc\n ~fields\n (module Field : Field_syntax.S with type ast = field)\n =\n let fields = List.map fields ~f:Field.create in\n let field_pats, field_exprs = gensyms \"x\" (List.map fields ~f:Field.location) in\n let shrinker_exprs =\n List.map fields ~f:(fun field -> shrinker_of_core_type (Field.core_type field))\n in\n [%expr\n Base_quickcheck.Shrinker.create (fun [%p Field.pattern fields ~loc field_pats] ->\n [%e\n compound_sequence\n ~loc\n ~make_compound_expr:(Field.expression fields)\n ~field_pats\n ~field_exprs\n ~shrinker_exprs])]\n;;\n\nlet variant\n (type clause)\n ~shrinker_of_core_type\n ~loc\n ~variant_type\n ~clauses\n (module Clause : Clause_syntax.S with type ast = clause)\n =\n let clauses = Clause.create_list clauses in\n [%expr\n Base_quickcheck.Shrinker.create\n [%e\n pexp_function\n ~loc\n (List.map clauses ~f:(fun clause ->\n let loc = { (Clause.location clause) with loc_ghost = true } in\n let core_type_list = Clause.core_type_list clause in\n let field_pats, field_exprs =\n gensyms\n \"x\"\n (List.map core_type_list ~f:(fun core_type -> core_type.ptyp_loc))\n in\n let shrinker_exprs = List.map core_type_list ~f:shrinker_of_core_type in\n let lhs = Clause.pattern clause ~loc field_pats in\n let rhs =\n compound_sequence\n ~loc\n ~make_compound_expr:(Clause.expression clause variant_type)\n ~field_pats\n ~field_exprs\n ~shrinker_exprs\n in\n case ~lhs ~guard:None ~rhs))]]\n;;\n","open! Import\n\nlet arrow\n ~generator_of_core_type\n ~observer_of_core_type\n ~loc\n ~arg_label\n ~input_type\n ~output_type\n =\n let input_observer =\n match arg_label with\n | Nolabel | Labelled _ -> observer_of_core_type input_type\n | Optional _ ->\n [%expr Base_quickcheck.Observer.option [%e observer_of_core_type input_type]]\n in\n let output_generator = generator_of_core_type output_type in\n let unlabelled =\n [%expr Base_quickcheck.Generator.fn [%e input_observer] [%e output_generator]]\n in\n match arg_label with\n | Nolabel -> unlabelled\n | Labelled _ | Optional _ ->\n [%expr\n Base_quickcheck.Generator.map\n ~f:[%e fn_map_label ~loc ~from:Nolabel ~to_:arg_label]\n [%e unlabelled]]\n;;\n\nlet compound_generator ~loc ~make_compound_expr generator_list =\n let loc = { loc with loc_ghost = true } in\n let size_pat, size_expr = gensym \"size\" loc in\n let random_pat, random_expr = gensym \"random\" loc in\n [%expr\n Base_quickcheck.Generator.create (fun ~size:[%p size_pat] ~random:[%p random_pat] ->\n [%e\n make_compound_expr\n ~loc\n (List.map generator_list ~f:(fun generator ->\n let loc = { generator.pexp_loc with loc_ghost = true } in\n [%expr\n Base_quickcheck.Generator.generate\n [%e generator]\n ~size:[%e size_expr]\n ~random:[%e random_expr]]))])]\n;;\n\nlet compound\n (type field)\n ~generator_of_core_type\n ~loc\n ~fields\n (module Field : Field_syntax.S with type ast = field)\n =\n let fields = List.map fields ~f:Field.create in\n compound_generator\n ~loc\n ~make_compound_expr:(Field.expression fields)\n (List.map fields ~f:(fun field -> generator_of_core_type (Field.core_type field)))\n;;\n\nlet does_refer_to name_set =\n object (self)\n inherit [bool] Ast_traverse.fold as super\n\n method! core_type ty acc =\n match ty.ptyp_desc with\n | Ptyp_constr (name, args) ->\n acc\n || Set.mem name_set (Longident.name name.txt)\n || List.exists args ~f:(fun arg -> self#core_type arg false)\n | _ -> super#core_type ty acc\n end\n;;\n\nlet clause_is_recursive\n (type clause)\n ~clause\n ~rec_names\n (module Clause : Clause_syntax.S with type t = clause)\n =\n List.exists (Clause.core_type_list clause) ~f:(fun ty ->\n (does_refer_to rec_names)#core_type ty false)\n;;\n\nlet variant\n (type clause)\n ~generator_of_core_type\n ~loc\n ~variant_type\n ~clauses\n ~rec_names\n (module Clause : Clause_syntax.S with type ast = clause)\n =\n let clauses = Clause.create_list clauses in\n let make_generator clause =\n compound_generator\n ~loc:(Clause.location clause)\n ~make_compound_expr:(Clause.expression clause variant_type)\n (List.map (Clause.core_type_list clause) ~f:generator_of_core_type)\n in\n let make_pair clause =\n pexp_tuple\n ~loc:{ (Clause.location clause) with loc_ghost = true }\n [ Clause.weight clause; make_generator clause ]\n in\n match\n List.partition_tf clauses ~f:(fun clause ->\n clause_is_recursive ~clause ~rec_names (module Clause))\n with\n | [], clauses | clauses, [] ->\n let pairs = List.map clauses ~f:make_pair in\n [%expr Base_quickcheck.Generator.weighted_union [%e elist ~loc pairs]]\n | recursive_clauses, nonrecursive_clauses ->\n let size_pat, size_expr = gensym \"size\" loc in\n let nonrec_pat, nonrec_expr = gensym \"gen\" loc in\n let rec_pat, rec_expr = gensym \"gen\" loc in\n let nonrec_pats, nonrec_exprs =\n gensyms \"pair\" (List.map nonrecursive_clauses ~f:Clause.location)\n in\n let rec_pats, rec_exprs =\n gensyms \"pair\" (List.map recursive_clauses ~f:Clause.location)\n in\n let bindings =\n List.map2_exn nonrec_pats nonrecursive_clauses ~f:(fun pat clause ->\n let loc = { (Clause.location clause) with loc_ghost = true } in\n let expr = make_pair clause in\n value_binding ~loc ~pat ~expr)\n @ List.map2_exn rec_pats recursive_clauses ~f:(fun pat clause ->\n let loc = { (Clause.location clause) with loc_ghost = true } in\n let weight_expr = Clause.weight clause in\n let gen_expr =\n [%expr\n Base_quickcheck.Generator.bind\n Base_quickcheck.Generator.size\n ~f:(fun [%p size_pat] ->\n Base_quickcheck.Generator.with_size\n ~size:(Base.Int.pred [%e size_expr])\n [%e make_generator clause])]\n in\n let expr = pexp_tuple ~loc [ weight_expr; gen_expr ] in\n value_binding ~loc ~pat ~expr)\n in\n let body =\n [%expr\n let [%p nonrec_pat] =\n Base_quickcheck.Generator.weighted_union [%e elist ~loc nonrec_exprs]\n and [%p rec_pat] =\n Base_quickcheck.Generator.weighted_union\n [%e elist ~loc (nonrec_exprs @ rec_exprs)]\n in\n Base_quickcheck.Generator.bind Base_quickcheck.Generator.size ~f:(function\n | 0 -> [%e nonrec_expr]\n | _ -> [%e rec_expr])]\n in\n pexp_let ~loc Nonrecursive bindings body\n;;\n","open! Import\n\nlet any ~loc = [%expr Base_quickcheck.Observer.opaque]\n\nlet arrow\n ~observer_of_core_type\n ~generator_of_core_type\n ~loc\n ~arg_label\n ~input_type\n ~output_type\n =\n let input_generator =\n match arg_label with\n | Nolabel | Labelled _ -> generator_of_core_type input_type\n | Optional _ ->\n [%expr Base_quickcheck.Generator.option [%e generator_of_core_type input_type]]\n in\n let output_observer = observer_of_core_type output_type in\n let unlabelled =\n [%expr Base_quickcheck.Observer.fn [%e input_generator] [%e output_observer]]\n in\n match arg_label with\n | Nolabel -> unlabelled\n | Labelled _ | Optional _ ->\n [%expr\n Base_quickcheck.Observer.unmap\n ~f:[%e fn_map_label ~loc ~from:arg_label ~to_:Nolabel]\n [%e unlabelled]]\n;;\n\nlet compound_hash ~loc ~size_expr ~hash_expr ~hash_pat ~observer_exprs ~field_exprs =\n let alist = List.zip_exn observer_exprs field_exprs in\n List.fold_right alist ~init:hash_expr ~f:(fun (observer_expr, field_expr) body_expr ->\n [%expr\n let [%p hash_pat] =\n Base_quickcheck.Observer.observe\n [%e observer_expr]\n [%e field_expr]\n ~size:[%e size_expr]\n ~hash:[%e hash_expr]\n in\n [%e body_expr]])\n;;\n\nlet compound\n (type field)\n ~observer_of_core_type\n ~loc\n ~fields\n (module Field : Field_syntax.S with type ast = field)\n =\n let fields = List.map fields ~f:Field.create in\n let field_pats, field_exprs = gensyms \"x\" (List.map fields ~f:Field.location) in\n let pat = Field.pattern fields ~loc field_pats in\n let observer_exprs =\n List.map fields ~f:(fun field -> observer_of_core_type (Field.core_type field))\n in\n let size_pat, size_expr = gensym \"size\" loc in\n let hash_pat, hash_expr = gensym \"hash\" loc in\n [%expr\n Base_quickcheck.Observer.create\n (fun [%p pat] ~size:[%p size_pat] ~hash:[%p hash_pat] ->\n [%e\n compound_hash ~loc ~size_expr ~hash_expr ~hash_pat ~observer_exprs ~field_exprs])]\n;;\n\nlet variant\n (type clause)\n ~observer_of_core_type\n ~loc\n ~clauses\n (module Clause : Clause_syntax.S with type ast = clause)\n =\n let clauses = Clause.create_list clauses in\n let pat, expr = gensym \"x\" loc in\n let size_pat, size_expr = gensym \"size\" loc in\n let hash_pat, hash_expr = gensym \"hash\" loc in\n [%expr\n Base_quickcheck.Observer.create\n (fun [%p pat] ~size:[%p size_pat] ~hash:[%p hash_pat] ->\n [%e\n pexp_match\n ~loc\n expr\n (List.map clauses ~f:(fun clause ->\n let core_type_list = Clause.core_type_list clause in\n let observer_exprs = List.map core_type_list ~f:observer_of_core_type in\n let field_pats, field_exprs =\n gensyms\n \"x\"\n (List.map core_type_list ~f:(fun core_type -> core_type.ptyp_loc))\n in\n let lhs = Clause.pattern clause ~loc field_pats in\n let body =\n compound_hash\n ~loc\n ~size_expr\n ~hash_expr\n ~hash_pat\n ~observer_exprs\n ~field_exprs\n in\n let rhs =\n match Clause.salt clause with\n | None -> body\n | Some salt ->\n pexp_let\n ~loc\n Nonrecursive\n [ value_binding\n ~loc\n ~pat:hash_pat\n ~expr:\n [%expr\n Base.hash_fold_int [%e hash_expr] [%e eint ~loc salt]]\n ]\n body\n in\n case ~lhs ~guard:None ~rhs))])]\n;;\n","open! Import\n\nlet custom_extension ~loc tag payload =\n match String.equal tag.txt \"custom\" with\n | false -> unsupported ~loc \"uknown extension: %s\" tag.txt\n | true ->\n (match payload with\n | PStr [ { pstr_desc = Pstr_eval (expr, attributes); _ } ] ->\n assert_no_attributes attributes;\n expr\n | _ -> invalid ~loc \"[%%custom] extension expects a single expression as its payload\")\n;;\n\nlet generator_attribute =\n Attribute.declare\n \"quickcheck.generator\"\n Attribute.Context.core_type\n Ast_pattern.(pstr (pstr_eval __ nil ^:: nil))\n (fun x -> x)\n;;\n\nlet rec generator_of_core_type core_type ~gen_env ~obs_env =\n let loc = { core_type.ptyp_loc with loc_ghost = true } in\n match Attribute.get generator_attribute core_type with\n | Some expr -> expr\n | None ->\n (match core_type.ptyp_desc with\n | Ptyp_constr (constr, args) ->\n type_constr_conv\n ~loc\n ~f:generator_name\n constr\n (List.map args ~f:(generator_of_core_type ~gen_env ~obs_env))\n | Ptyp_var tyvar -> Environment.lookup gen_env ~loc ~tyvar\n | Ptyp_arrow (arg_label, input_type, output_type) ->\n Ppx_generator_expander.arrow\n ~generator_of_core_type:(generator_of_core_type ~gen_env ~obs_env)\n ~observer_of_core_type:(observer_of_core_type ~gen_env ~obs_env)\n ~loc\n ~arg_label\n ~input_type\n ~output_type\n | Ptyp_tuple fields ->\n Ppx_generator_expander.compound\n ~generator_of_core_type:(generator_of_core_type ~gen_env ~obs_env)\n ~loc\n ~fields\n (module Field_syntax.Tuple)\n | Ptyp_variant (clauses, Closed, None) ->\n Ppx_generator_expander.variant\n ~generator_of_core_type:(generator_of_core_type ~gen_env ~obs_env)\n ~loc\n ~variant_type:core_type\n ~clauses\n ~rec_names:(Set.empty (module String))\n (module Clause_syntax.Polymorphic_variant)\n | Ptyp_variant (_, Open, _) -> unsupported ~loc \"polymorphic variant type with [>]\"\n | Ptyp_variant (_, _, Some _) -> unsupported ~loc \"polymorphic variant type with [<]\"\n | Ptyp_extension (tag, payload) -> custom_extension ~loc tag payload\n | Ptyp_any\n | Ptyp_object _\n | Ptyp_class _\n | Ptyp_alias _\n | Ptyp_poly _\n | Ptyp_package _ -> unsupported ~loc \"%s\" (short_string_of_core_type core_type))\n\nand observer_of_core_type core_type ~obs_env ~gen_env =\n let loc = { core_type.ptyp_loc with loc_ghost = true } in\n match core_type.ptyp_desc with\n | Ptyp_constr (constr, args) ->\n type_constr_conv\n ~loc\n ~f:observer_name\n constr\n (List.map args ~f:(observer_of_core_type ~obs_env ~gen_env))\n | Ptyp_var tyvar -> Environment.lookup obs_env ~loc ~tyvar\n | Ptyp_arrow (arg_label, input_type, output_type) ->\n Ppx_observer_expander.arrow\n ~observer_of_core_type:(observer_of_core_type ~obs_env ~gen_env)\n ~generator_of_core_type:(generator_of_core_type ~obs_env ~gen_env)\n ~loc\n ~arg_label\n ~input_type\n ~output_type\n | Ptyp_tuple fields ->\n Ppx_observer_expander.compound\n ~observer_of_core_type:(observer_of_core_type ~obs_env ~gen_env)\n ~loc\n ~fields\n (module Field_syntax.Tuple)\n | Ptyp_variant (clauses, Closed, None) ->\n Ppx_observer_expander.variant\n ~observer_of_core_type:(observer_of_core_type ~obs_env ~gen_env)\n ~loc\n ~clauses\n (module Clause_syntax.Polymorphic_variant)\n | Ptyp_variant (_, Open, _) -> unsupported ~loc \"polymorphic variant type with [>]\"\n | Ptyp_variant (_, _, Some _) -> unsupported ~loc \"polymorphic variant type with [<]\"\n | Ptyp_extension (tag, payload) -> custom_extension ~loc tag payload\n | Ptyp_any -> Ppx_observer_expander.any ~loc\n | Ptyp_object _ | Ptyp_class _ | Ptyp_alias _ | Ptyp_poly _ | Ptyp_package _ ->\n unsupported ~loc \"%s\" (short_string_of_core_type core_type)\n;;\n\nlet rec shrinker_of_core_type core_type ~env =\n let loc = { core_type.ptyp_loc with loc_ghost = true } in\n match core_type.ptyp_desc with\n | Ptyp_constr (constr, args) ->\n type_constr_conv\n ~loc\n ~f:shrinker_name\n constr\n (List.map args ~f:(shrinker_of_core_type ~env))\n | Ptyp_var tyvar -> Environment.lookup env ~loc ~tyvar\n | Ptyp_arrow _ -> Ppx_shrinker_expander.arrow ~loc\n | Ptyp_tuple fields ->\n Ppx_shrinker_expander.compound\n ~shrinker_of_core_type:(shrinker_of_core_type ~env)\n ~loc\n ~fields\n (module Field_syntax.Tuple)\n | Ptyp_variant (clauses, Closed, None) ->\n Ppx_shrinker_expander.variant\n ~shrinker_of_core_type:(shrinker_of_core_type ~env)\n ~loc\n ~variant_type:core_type\n ~clauses\n (module Clause_syntax.Polymorphic_variant)\n | Ptyp_variant (_, Open, _) -> unsupported ~loc \"polymorphic variant type with [>]\"\n | Ptyp_variant (_, _, Some _) -> unsupported ~loc \"polymorphic variant type with [<]\"\n | Ptyp_extension (tag, payload) -> custom_extension ~loc tag payload\n | Ptyp_any -> Ppx_shrinker_expander.any ~loc\n | Ptyp_object _ | Ptyp_class _ | Ptyp_alias _ | Ptyp_poly _ | Ptyp_package _ ->\n unsupported ~loc \"%s\" (short_string_of_core_type core_type)\n;;\n\ntype impl =\n { loc : location\n ; pat : pattern\n ; var : expression\n ; exp : expression\n }\n\nlet generator_impl type_decl ~rec_names =\n let loc = type_decl.ptype_loc in\n let pat = pgenerator type_decl.ptype_name in\n let var = egenerator type_decl.ptype_name in\n let exp =\n let pat_list, `Covariant gen_env, `Contravariant obs_env =\n Environment.create_with_variance\n ~loc\n ~covariant:\"generator\"\n ~contravariant:\"observer\"\n type_decl.ptype_params\n in\n let body =\n match type_decl.ptype_kind with\n | Ptype_open -> unsupported ~loc \"open type\"\n | Ptype_variant clauses ->\n Ppx_generator_expander.variant\n ~generator_of_core_type:(generator_of_core_type ~gen_env ~obs_env)\n ~loc\n ~variant_type:[%type: _]\n ~clauses\n ~rec_names\n (module Clause_syntax.Variant)\n | Ptype_record fields ->\n Ppx_generator_expander.compound\n ~generator_of_core_type:(generator_of_core_type ~gen_env ~obs_env)\n ~loc\n ~fields\n (module Field_syntax.Record)\n | Ptype_abstract ->\n (match type_decl.ptype_manifest with\n | Some core_type -> generator_of_core_type core_type ~gen_env ~obs_env\n | None -> unsupported ~loc \"abstract type\")\n in\n List.fold_right pat_list ~init:body ~f:(fun pat body ->\n [%expr fun [%p pat] -> [%e body]])\n in\n { loc; pat; var; exp }\n;;\n\nlet observer_impl type_decl ~rec_names:_ =\n let loc = type_decl.ptype_loc in\n let pat = pobserver type_decl.ptype_name in\n let var = eobserver type_decl.ptype_name in\n let exp =\n let pat_list, `Covariant obs_env, `Contravariant gen_env =\n Environment.create_with_variance\n ~loc\n ~covariant:\"observer\"\n ~contravariant:\"generator\"\n type_decl.ptype_params\n in\n let body =\n match type_decl.ptype_kind with\n | Ptype_open -> unsupported ~loc \"open type\"\n | Ptype_variant clauses ->\n Ppx_observer_expander.variant\n ~observer_of_core_type:(observer_of_core_type ~obs_env ~gen_env)\n ~loc\n ~clauses\n (module Clause_syntax.Variant)\n | Ptype_record fields ->\n Ppx_observer_expander.compound\n ~observer_of_core_type:(observer_of_core_type ~obs_env ~gen_env)\n ~loc\n ~fields\n (module Field_syntax.Record)\n | Ptype_abstract ->\n (match type_decl.ptype_manifest with\n | Some core_type -> observer_of_core_type core_type ~obs_env ~gen_env\n | None -> unsupported ~loc \"abstract type\")\n in\n List.fold_right pat_list ~init:body ~f:(fun pat body ->\n [%expr fun [%p pat] -> [%e body]])\n in\n { loc; pat; var; exp }\n;;\n\nlet shrinker_impl type_decl ~rec_names:_ =\n let loc = type_decl.ptype_loc in\n let pat = pshrinker type_decl.ptype_name in\n let var = eshrinker type_decl.ptype_name in\n let exp =\n let pat_list, env =\n Environment.create ~loc ~prefix:\"shrinker\" type_decl.ptype_params\n in\n let body =\n match type_decl.ptype_kind with\n | Ptype_open -> unsupported ~loc \"open type\"\n | Ptype_variant clauses ->\n Ppx_shrinker_expander.variant\n ~shrinker_of_core_type:(shrinker_of_core_type ~env)\n ~loc\n ~variant_type:[%type: _]\n ~clauses\n (module Clause_syntax.Variant)\n | Ptype_record fields ->\n Ppx_shrinker_expander.compound\n ~shrinker_of_core_type:(shrinker_of_core_type ~env)\n ~loc\n ~fields\n (module Field_syntax.Record)\n | Ptype_abstract ->\n (match type_decl.ptype_manifest with\n | Some core_type -> shrinker_of_core_type core_type ~env\n | None -> unsupported ~loc \"abstract type\")\n in\n List.fold_right pat_list ~init:body ~f:(fun pat body ->\n [%expr fun [%p pat] -> [%e body]])\n in\n { loc; pat; var; exp }\n;;\n\nlet maybe_mutually_recursive decls ~loc ~rec_flag ~of_lazy ~impl =\n let decls = List.map decls ~f:name_type_params_in_td in\n let rec_names =\n match rec_flag with\n | Nonrecursive -> Set.empty (module String)\n | Recursive ->\n Set.of_list (module String) (List.map decls ~f:(fun decl -> decl.ptype_name.txt))\n in\n let impls = List.map decls ~f:(fun decl -> impl decl ~rec_names) in\n match rec_flag with\n | Nonrecursive ->\n pstr_value_list\n ~loc\n Nonrecursive\n (List.map impls ~f:(fun impl ->\n value_binding ~loc:impl.loc ~pat:impl.pat ~expr:impl.exp))\n | Recursive ->\n let pats = List.map impls ~f:(fun impl -> impl.pat) in\n let bindings =\n let inner_bindings =\n List.map impls ~f:(fun inner ->\n value_binding\n ~loc:inner.loc\n ~pat:inner.pat\n ~expr:[%expr [%e of_lazy] [%e inner.var]])\n in\n List.map impls ~f:(fun impl ->\n let body = pexp_let ~loc:impl.loc Nonrecursive inner_bindings impl.exp in\n let lazy_expr = [%expr lazy [%e body]] in\n value_binding ~loc:impl.loc ~pat:impl.pat ~expr:lazy_expr)\n in\n let body =\n pexp_tuple\n ~loc\n (List.map impls ~f:(fun impl -> [%expr [%e of_lazy] [%e impl.var]]))\n in\n pstr_value_list\n ~loc\n Nonrecursive\n [ value_binding\n ~loc\n ~pat:(ppat_tuple ~loc pats)\n ~expr:(pexp_let ~loc Recursive bindings body)\n ]\n;;\n\nlet generator_impl_list decls ~loc ~rec_flag =\n maybe_mutually_recursive\n decls\n ~loc\n ~rec_flag\n ~of_lazy:[%expr Base_quickcheck.Generator.of_lazy]\n ~impl:generator_impl\n;;\n\nlet observer_impl_list decls ~loc ~rec_flag =\n maybe_mutually_recursive\n decls\n ~loc\n ~rec_flag\n ~of_lazy:[%expr Base_quickcheck.Observer.of_lazy]\n ~impl:observer_impl\n;;\n\nlet shrinker_impl_list decls ~loc ~rec_flag =\n maybe_mutually_recursive\n decls\n ~loc\n ~rec_flag\n ~of_lazy:[%expr Base_quickcheck.Shrinker.of_lazy]\n ~impl:shrinker_impl\n;;\n\nlet intf type_decl ~f ~covar ~contravar =\n let covar = Longident.parse (\"Base_quickcheck.\" ^ covar ^ \".t\") in\n let contravar = Longident.parse (\"Base_quickcheck.\" ^ contravar ^ \".t\") in\n let type_decl = name_type_params_in_td type_decl in\n let loc = type_decl.ptype_loc in\n let name = loc_map type_decl.ptype_name ~f in\n let result =\n ptyp_constr\n ~loc\n { loc; txt = covar }\n [ ptyp_constr\n ~loc\n (lident_loc type_decl.ptype_name)\n (List.map type_decl.ptype_params ~f:fst)\n ]\n in\n let type_ =\n List.fold_right\n type_decl.ptype_params\n ~init:result\n ~f:(fun (core_type, (variance, injectivity)) result ->\n let id =\n match (variance, injectivity) with\n | ((NoVariance | Covariant), NoInjectivity) -> covar\n | (Contravariant, NoInjectivity) -> contravar\n | (_, Injective) -> Location.raise_errorf ~loc \"Injective type parameters aren't supported.\"\n in\n let arg = ptyp_constr ~loc { loc; txt = id } [ core_type ] in\n [%type: [%t arg] -> [%t result]])\n in\n psig_value ~loc (value_description ~loc ~name ~type_ ~prim:[])\n;;\n\nlet shrinker_intf = intf ~f:shrinker_name ~covar:\"Shrinker\" ~contravar:\"Shrinker\"\nlet generator_intf = intf ~f:generator_name ~covar:\"Generator\" ~contravar:\"Observer\"\nlet observer_intf = intf ~f:observer_name ~covar:\"Observer\" ~contravar:\"Generator\"\nlet generator_intf_list type_decl_list = List.map type_decl_list ~f:generator_intf\nlet observer_intf_list type_decl_list = List.map type_decl_list ~f:observer_intf\nlet shrinker_intf_list type_decl_list = List.map type_decl_list ~f:shrinker_intf\n\nlet sig_type_decl =\n Deriving.Generator.make_noarg (fun ~loc:_ ~path:_ (_, decls) ->\n generator_intf_list decls @ observer_intf_list decls @ shrinker_intf_list decls)\n;;\n\nlet str_type_decl =\n Deriving.Generator.make_noarg (fun ~loc ~path:_ (rec_flag, decls) ->\n let rec_flag = really_recursive rec_flag decls in\n generator_impl_list ~loc ~rec_flag decls\n @ observer_impl_list ~loc ~rec_flag decls\n @ shrinker_impl_list ~loc ~rec_flag decls)\n;;\n\nlet generator_extension ~loc:_ ~path:_ core_type =\n generator_of_core_type core_type ~gen_env:Environment.empty ~obs_env:Environment.empty\n;;\n\nlet observer_extension ~loc:_ ~path:_ core_type =\n observer_of_core_type core_type ~obs_env:Environment.empty ~gen_env:Environment.empty\n;;\n\nlet shrinker_extension ~loc:_ ~path:_ core_type =\n shrinker_of_core_type core_type ~env:Environment.empty\n;;\n","open! Base\nopen Ppxlib\nopen Ppx_quickcheck_expander\n\nlet (_ : Deriving.t) = Deriving.add \"quickcheck\" ~sig_type_decl ~str_type_decl\nlet (_ : Deriving.t) = Deriving.add \"quickcheck.generator\" ~extension:generator_extension\nlet (_ : Deriving.t) = Deriving.add \"quickcheck.observer\" ~extension:observer_extension\nlet (_ : Deriving.t) = Deriving.add \"quickcheck.shrinker\" ~extension:shrinker_extension\n","module Kimchi_backend_common = struct\n module Field = Kimchi_backend_common.Field\n module Scalar_challenge = Kimchi_backend_common.Scalar_challenge\nend\n\nmodule Field = Kimchi_backend_common.Field\n\nmodule Pasta = struct\n module Basic = Kimchi_pasta.Basic\n module Pallas_based_plonk = Kimchi_pasta.Pallas_based_plonk\n module Pasta = Kimchi_pasta.Pasta\n module Vesta_based_plonk = Kimchi_pasta.Vesta_based_plonk\nend\n","module Tick = struct\n include Kimchi_backend.Pasta.Vesta_based_plonk\n module Inner_curve = Kimchi_backend.Pasta.Pasta.Pallas\nend\n\nmodule Tock = struct\n include Kimchi_backend.Pasta.Pallas_based_plonk\n module Inner_curve = Kimchi_backend.Pasta.Pasta.Vesta\nend\n","(* Based on this paper. https://eprint.iacr.org/2019/403 *)\n\nopen Core_kernel\n\nmodule Spec = struct\n type 'f t = { b : 'f } [@@deriving bin_io]\nend\n\nmodule Params = struct\n type 'f t =\n { u : 'f\n ; fu : 'f\n ; sqrt_neg_three_u_squared_minus_u_over_2 : 'f\n ; sqrt_neg_three_u_squared : 'f\n ; inv_three_u_squared : 'f\n ; b : 'f\n }\n [@@deriving fields, bin_io]\n\n let spec { b; _ } = { Spec.b }\n\n let map\n { u\n ; fu\n ; sqrt_neg_three_u_squared_minus_u_over_2\n ; sqrt_neg_three_u_squared\n ; inv_three_u_squared\n ; b\n } ~f =\n { u = f u\n ; fu = f fu\n ; sqrt_neg_three_u_squared_minus_u_over_2 =\n f sqrt_neg_three_u_squared_minus_u_over_2\n ; sqrt_neg_three_u_squared = f sqrt_neg_three_u_squared\n ; inv_three_u_squared = f inv_three_u_squared\n ; b = f b\n }\n\n (* A deterministic function for constructing a valid choice of parameters for a\n given field. *)\n let create (type t) (module F : Field_intf.S_unchecked with type t = t)\n { Spec.b } =\n let open F in\n let first_map f =\n let rec go i = match f i with Some x -> x | None -> go (i + one) in\n go zero\n in\n let curve_eqn u = (u * u * u) + b in\n let u, fu =\n first_map (fun u ->\n let fu = curve_eqn u in\n if equal u zero || equal fu zero then None else Some (u, fu) )\n in\n let three_u_squared = u * u * of_int 3 in\n let sqrt_neg_three_u_squared = sqrt (negate three_u_squared) in\n { u\n ; fu\n ; sqrt_neg_three_u_squared_minus_u_over_2 =\n (sqrt_neg_three_u_squared - u) / of_int 2\n ; sqrt_neg_three_u_squared\n ; inv_three_u_squared = one / three_u_squared\n ; b\n }\nend\n\nmodule Make\n (Constant : Field_intf.S) (F : sig\n include Field_intf.S\n\n val constant : Constant.t -> t\n end) (P : sig\n val params : Constant.t Params.t\n end) =\nstruct\n open F\n open P\n\n let square x = x * x\n\n let potential_xs t =\n let t2 = t * t in\n let alpha =\n let alpha_inv = (t2 + constant params.fu) * t2 in\n one / alpha_inv\n in\n let x1 =\n let temp = square t2 * alpha * constant params.sqrt_neg_three_u_squared in\n constant params.sqrt_neg_three_u_squared_minus_u_over_2 - temp\n in\n let x2 = negate (constant params.u) - x1 in\n let x3 =\n let t2_plus_fu = t2 + constant params.fu in\n let t2_inv = alpha * t2_plus_fu in\n let temp =\n square t2_plus_fu * t2_inv * constant params.inv_three_u_squared\n in\n constant params.u - temp\n in\n (x1, x2, x3)\nend\n\nlet to_group (type t) (module F : Field_intf.S_unchecked with type t = t)\n ~params t =\n let module M =\n Make\n (F)\n (struct\n include F\n\n let constant = Fn.id\n end)\n (struct\n let params = params\n end)\n in\n let b = params.b in\n let try_decode x =\n let f x = F.((x * x * x) + b) in\n let y = f x in\n if F.is_square y then Some (x, F.sqrt y) else None\n in\n let x1, x2, x3 = M.potential_xs t in\n List.find_map [ x1; x2; x3 ] ~f:try_decode |> Option.value_exn\n\nlet%test_module \"test\" =\n ( module struct\n module Fp = struct\n include\n Snarkette.Fields.Make_fp\n (Snarkette.Nat)\n (struct\n let order =\n Snarkette.Nat.of_string\n \"5543634365110765627805495722742127385843376434033820803590214255538854698464778703795540858859767700241957783601153\"\n end)\n\n let b = of_int 7\n end\n\n module Make_tests (F : sig\n include Field_intf.S_unchecked\n\n val gen : t Quickcheck.Generator.t\n\n val b : t\n end) =\n struct\n module F = struct\n include F\n\n let constant = Fn.id\n end\n\n open F\n\n let params = Params.create (module F) { b }\n\n let curve_eqn u = (u * u * u) + params.b\n\n (* Filter the two points which cause the group-map to blow up. This\n is not an issue in practice because the points we feed into this function\n will be the output of poseidon, and thus (modeling poseidon as a random oracle)\n will not be either of those two points. *)\n let gen =\n Quickcheck.Generator.filter F.gen ~f:(fun t ->\n let t2 = t * t in\n let alpha_inv = (t2 + constant params.fu) * t2 in\n not (equal alpha_inv zero) )\n\n module M =\n Make (F) (F)\n (struct\n let params = params\n end)\n\n let%test_unit \"full map works\" =\n Quickcheck.test ~sexp_of:F.sexp_of_t gen ~f:(fun t ->\n let x, y = to_group (module F) ~params t in\n assert (equal (curve_eqn x) (y * y)) )\n end\n\n module T0 = Make_tests (Fp)\n end )\n","open Core_kernel\nopen Async_kernel\n\nlet autogen_path = \"/tmp/coda_cache_dir\"\n\nlet s3_install_path = \"/tmp/s3_cache_dir\"\n\nlet s3_keys_bucket_prefix =\n \"https://s3-us-west-2.amazonaws.com/snark-keys.o1test.net\"\n\nlet manual_install_path = \"/var/lib/coda\"\n\nlet brew_install_path = \"/usr/local/var/coda\"\n\nlet cache = []\n\nlet env_path = manual_install_path\n\nlet possible_paths base =\n List.map\n [ env_path\n ; brew_install_path\n ; s3_install_path\n ; autogen_path\n ; manual_install_path\n ] ~f:(fun d -> d ^ \"/\" ^ base)\n\nlet load_from_s3 _s3_bucket_prefix _s3_install_path ~logger:_ =\n Deferred.Or_error.fail (Error.createf \"Cannot load files from S3\")\n","(*\n\n This follows the approach of SvdW06 to construct a \"near injection\" from\n a field into an elliptic curve defined over that field. WB19 is also a useful\n reference that details several constructions which are more appropriate in other\n contexts.\n\n Fix an elliptic curve E given by y^2 = x^3 + ax + b over a field \"F\"\n Let f(x) = x^3 + ax + b.\n\n Define the variety V to be\n (x1, x2, x3, x4) : f(x1) f(x2) f(x3) = x4^2.\n\n By a not-too-hard we have a map `V -> E`. Thus, a map of type `F -> V` yields a\n map of type `F -> E` by composing.\n\n Our goal is to construct such a map of type `F -> V`. The paper SvdW06 constructs\n a family of such maps, defined by a collection of values which we'll term `params`.\n\n Define `params` to be the type of records of the form\n { u: F\n ; u_over_2: F\n ; projection_point: { z : F; y : F }\n ; conic_c: F\n ; a: F\n ; b: F }\n such that\n - a and b are the coefficients of our curve's defining equation.\n - u satisfies\n i. 0 <> 3/4 u^2 + a\n ii. 0 <> f(u)\n iii. -f(u) is not a square.\n - conic_c = 3/4 u^2 + a\n - {z; y} satisfy\n i. z^2 + conic_c * y^2 = -f(u)\n\n We will define a map of type `params -> (F -> V)`. Thus, fixing a choice of\n a value of type params, we obtain a map `F -> V` as desired.\n\nSvdW06: Shallue and van de Woestijne, \"Construction of rational points on elliptic curves over finite fields.\" Proc. ANTS 2006. https://works.bepress.com/andrew_shallue/1/download/\nWB19: Riad S. Wahby and Dan Boneh, Fast and simple constant-time hashing to the BLS12-381 elliptic curve. https://eprint.iacr.org/2019/403\n*)\n\n(* we have φ(t) : F -> S\n and φ1(λ) : S -> V with\n V(F) : f(x1)f(x2)f(x3) = x4^2,\n (f is y^2 = x^3 + Bx + C)) (note choice of constant names\n -- A is coeff of x^2 so A = 0 for us)\n\n To construct a rational point on V(F), the authors define\n the surface S(F) and the rational map φ1:S(F)→ V(F), which\n is invertible on its image [SvdW06, Lemma 6]:\n S(F) : y^2(u^2 + uv + v^2 + a) = −f(u)\n\n φ(t) : t → ( u, α(t)/β(t) - u/2, β(t) )\n φ1: (u, v, y) → ( v, −u − v, u + y^2,\n f(u + y^2)·(y^2 + uv + v^2 + ay)/y )\n*)\n\nopen Core_kernel\nmodule Field_intf = Field_intf\nmodule Bw19 = Bw19\n\nlet ( = ) = `Don't_use_polymorphic_compare\n\nlet _ = ( = )\n\nmodule Intf (F : sig\n type t\nend) =\nstruct\n module type S = sig\n val to_group : F.t -> F.t * F.t\n end\nend\n\nmodule type S = sig\n module Spec : sig\n type _ t [@@deriving bin_io]\n end\n\n module Params : sig\n type 'f t [@@deriving bin_io]\n\n val map : 'a t -> f:('a -> 'b) -> 'b t\n\n val spec : 'f t -> 'f Spec.t\n\n val create :\n (module Field_intf.S_unchecked with type t = 'f) -> 'f Spec.t -> 'f t\n end\n\n module Make\n (Constant : Field_intf.S) (F : sig\n include Field_intf.S\n\n val constant : Constant.t -> t\n end) (Params : sig\n val params : Constant.t Params.t\n end) : sig\n val potential_xs : F.t -> F.t * F.t * F.t\n end\n\n val to_group :\n (module Field_intf.S_unchecked with type t = 'f)\n -> params:'f Params.t\n -> 'f\n -> 'f * 'f\nend\n\nmodule Conic = struct\n type 'f t = { z : 'f; y : 'f } [@@deriving bin_io]\n\n let map { z; y } ~f = { z = f z; y = f y }\nend\n\nmodule S = struct\n (* S = S(u, v, y) : y^2(u^2 + uv + v^2 + a) = −f(u)\n from (12)\n *)\n type 'f t = { u : 'f; v : 'f; y : 'f }\nend\n\nmodule V = struct\n (* V = V(x1, x2, x3, x4) : f(x1)f(x2)f(x3) = x4^2\n from (8)\n *)\n type 'f t = 'f * 'f * 'f * 'f\nend\n\nmodule Spec = struct\n type 'f t = { a : 'f; b : 'f } [@@deriving fields, bin_io]\nend\n\nmodule Params = struct\n type 'f t =\n { u : 'f\n ; u_over_2 : 'f\n ; projection_point : 'f Conic.t\n ; conic_c : 'f\n ; spec : 'f Spec.t\n }\n [@@deriving fields, bin_io]\n\n let map { u; u_over_2; projection_point; conic_c; spec = { a; b } } ~f =\n { u = f u\n ; u_over_2 = f u_over_2\n ; projection_point = Conic.map ~f projection_point\n ; conic_c = f conic_c\n ; spec = { a = f a; b = f b }\n }\n\n (* A deterministic function for constructing a valid choice of parameters for a\n given field.\n\n We start by finding the first `u` satisfying the constraints described above,\n then find the first `y` satisyfing the condition described above. The other\n values are derived from these two choices*.\n\n *Actually we have one bit of freedom in choosing `z` as z = sqrt(conic_c y^2 - conic_d),\n since there are two square roots.\n *)\n\n let create (type t) (module F : Field_intf.S_unchecked with type t = t)\n ({ Spec.a; b } as spec) =\n let open F in\n let first_map f =\n let rec go i = match f i with Some x -> x | None -> go (i + one) in\n go zero\n in\n let first f = first_map (fun x -> Option.some_if (f x) x) in\n let three_fourths = of_int 3 / of_int 4 in\n let curve_eqn u = (u * u * u) + (a * u) + b in\n let u =\n first (fun u ->\n (* from (15), A = 0, B = Params.a *)\n let check = (three_fourths * u * u) + a in\n let fu = curve_eqn u in\n (not (equal check zero))\n && (not (equal fu zero))\n && not (is_square (negate fu))\n (* imeckler: I added this condition. It prevents the possibility of having\n a point (z, 0) on the conic, which is useful because in the map from the\n conic to S we divide by the \"y\" coordinate of the conic. It's not strictly\n necessary when we have a random input in a large field, but it is still nice to avoid the\n bad case in theory (and for the tests below with a small field). *) )\n in\n (* The coefficients defining the conic z^2 + c y^2 = d\n in (15). *)\n let conic_c = (three_fourths * u * u) + a in\n let conic_d = negate (curve_eqn u) in\n let projection_point =\n first_map (fun y ->\n let z2 = conic_d - (conic_c * y * y) in\n if F.is_square z2 then Some { Conic.z = F.sqrt z2; y } else None )\n in\n { u; u_over_2 = u / of_int 2; conic_c; projection_point; spec }\nend\n\nmodule Make\n (Constant : Field_intf.S) (F : sig\n include Field_intf.S\n\n val constant : Constant.t -> t\n end) (P : sig\n val params : Constant.t Params.t\n end) =\nstruct\n open F\n\n (* For a curve z^2 + c y^2 = d and a point (z0, y0) on the curve, there\n is one other point on the curve which is also on the line through (z0, y0)\n with slope t. This function returns that point. *)\n let field_to_conic t =\n let z0, y0 =\n ( constant P.params.projection_point.z\n , constant P.params.projection_point.y )\n in\n let ct = constant P.params.conic_c * t in\n let s = of_int 2 * ((ct * y0) + z0) / ((ct * t) + one) in\n { Conic.z = z0 - s; y = y0 - (s * t) }\n\n (* From (16) : φ(λ) : F → S : λ → ( u, α(λ)/β(λ) - u/2, β(λ) ) *)\n let conic_to_s { Conic.z; y } =\n { S.u = constant P.params.u\n ; v = (z / y) - constant P.params.u_over_2 (* From (16) *)\n ; y\n }\n\n (* This is here for explanatory purposes. See s_to_v_truncated. *)\n let _s_to_v { S.u; v; y } : _ V.t =\n let curve_eqn x =\n (x * x * x) + (constant P.params.spec.a * x) + constant P.params.spec.b\n in\n let h = (u * u) + (u * v) + (v * v) + constant P.params.spec.a in\n (v, negate (u + v), u + (y * y), curve_eqn (u + (y * y)) * h / y)\n\n (* from (13) *)\n\n (* We don't actually need to compute the final coordinate in V *)\n let s_to_v_truncated { S.u; v; y } = (v, negate (u + v), u + (y * y))\n\n let potential_xs =\n let ( @ ) = Fn.compose in\n s_to_v_truncated @ conic_to_s @ field_to_conic\nend\n\nlet to_group (type t) (module F : Field_intf.S_unchecked with type t = t)\n ~params t =\n let module M =\n Make\n (F)\n (struct\n include F\n\n let constant = Fn.id\n end)\n (struct\n let params = params\n end)\n in\n let { Spec.a; b } = params.spec in\n let try_decode x =\n let f x = F.((x * x * x) + (a * x) + b) in\n let y = f x in\n if F.is_square y then Some (x, F.sqrt y) else None\n in\n let x1, x2, x3 = M.potential_xs t in\n List.find_map [ x1; x2; x3 ] ~f:try_decode |> Option.value_exn\n\nlet%test_module \"test\" =\n ( module struct\n module Fp = struct\n include\n Snarkette.Fields.Make_fp\n (Snarkette.Nat)\n (struct\n let order = Snarkette.Nat.of_int 100003\n end)\n\n let a = of_int 1\n\n let b = of_int 3\n end\n\n module F13 = struct\n type t = int [@@deriving sexp]\n\n let p = 13\n\n let ( + ) x y = (x + y) mod p\n\n let ( * ) x y = x * y mod p\n\n let negate x = (p - x) mod p\n\n let ( - ) x y = (x - y + p) mod p\n\n let equal = Int.equal\n\n let ( / ) x y =\n let rec go i = if equal x (i * y) then i else go (i + 1) in\n if equal y 0 then failwith \"Divide by 0\" else go 1\n\n let sqrt' x =\n let rec go i =\n if Int.equal i p then None\n else if equal (i * i) x then Some i\n else go Int.(i + 1)\n in\n go 0\n\n let sqrt x = Option.value_exn (sqrt' x)\n\n let is_square x = Option.is_some (sqrt' x)\n\n let zero = 0\n\n let one = 1\n\n let of_int = Fn.id\n\n let gen = Int.gen_incl 0 Int.(p - 1)\n\n let a = 1\n\n let b = 3\n end\n\n module Make_tests (F : sig\n include Field_intf.S_unchecked\n\n val gen : t Quickcheck.Generator.t\n\n val a : t\n\n val b : t\n end) =\n struct\n module F = struct\n include F\n\n let constant = Fn.id\n end\n\n open F\n\n let params = Params.create (module F) { a; b }\n\n let curve_eqn u = (u * u * u) + (params.spec.a * u) + params.spec.b\n\n let conic_d =\n let open F in\n negate (curve_eqn params.u)\n\n let on_conic { Conic.z; y } =\n F.(equal ((z * z) + (params.conic_c * y * y)) conic_d)\n\n let on_s { S.u; v; y } =\n F.(equal conic_d (y * y * ((u * u) + (u * v) + (v * v) + a)))\n\n let on_v (x1, x2, x3, x4) =\n F.(equal (curve_eqn x1 * curve_eqn x2 * curve_eqn x3) (x4 * x4))\n\n (* Filter the two points which cause the group-map to blow up. This\n is not an issue in practice because the points we feed into this function\n will be the output of blake2s, and thus (modeling blake2s as a random oracle)\n will not be either of those two points. *)\n let gen =\n Quickcheck.Generator.filter F.gen ~f:(fun t ->\n not F.(equal ((params.conic_c * t * t) + one) zero) )\n\n module M =\n Make (F) (F)\n (struct\n let params = params\n end)\n\n let%test \"projection point well-formed\" = on_conic params.projection_point\n\n let%test_unit \"field-to-conic\" =\n Quickcheck.test ~sexp_of:F.sexp_of_t gen ~f:(fun t ->\n assert (on_conic (M.field_to_conic t)) )\n\n let%test_unit \"conic-to-S\" =\n let conic_gen =\n Quickcheck.Generator.filter_map F.gen ~f:(fun y ->\n let z2 = conic_d - (params.conic_c * y * y) in\n if is_square z2 then Some { Conic.z = sqrt z2; y } else None )\n in\n Quickcheck.test conic_gen ~f:(fun p -> assert (on_s (M.conic_to_s p)))\n\n let%test_unit \"field-to-S\" =\n Quickcheck.test ~sexp_of:F.sexp_of_t gen ~f:(fun t ->\n assert (on_s (Fn.compose M.conic_to_s M.field_to_conic t)) )\n\n (* Schwarz-zippel says if this tests succeeds once, then the probability that\n the implementation is correct is at least 1 - (D / field-size), where D is\n the total degree of the polynomial defining_equation_of_V(s_to_v(t)) which should\n be less than, say, 10. So, this test succeeding gives good evidence of the\n correctness of the implementation (assuming that the implementation is just a\n polynomial, which it is by parametricity!) *)\n let%test_unit \"field-to-V\" =\n Quickcheck.test ~sexp_of:F.sexp_of_t gen ~f:(fun t ->\n let s = M.conic_to_s (M.field_to_conic t) in\n assert (on_v (M._s_to_v s)) )\n\n let%test_unit \"full map works\" =\n Quickcheck.test ~sexp_of:F.sexp_of_t gen ~f:(fun t ->\n let x, y = to_group (module F) ~params t in\n assert (equal (curve_eqn x) (y * y)) )\n end\n\n module T0 = Make_tests (F13)\n module T1 = Make_tests (Fp)\n end )\n","(*\n * Copyright (c) 2006-2009 Citrix Systems Inc.\n * Copyright (c) 2010 Thomas Gazagnaire \n * Copyright (c) 2014-2016 Anil Madhavapeddy \n * Copyright (c) 2016 David Kaloper Meršinjak\n * Copyright (c) 2018 Romain Calascibetta \n *\n * Permission to use, copy, modify, and distribute this software for any\n * purpose with or without fee is hereby granted, provided that the above\n * copyright notice and this permission notice appear in all copies.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES\n * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF\n * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR\n * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES\n * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN\n * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF\n * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.\n *\n *)\n\ntype alphabet =\n { emap : int array\n ; dmap : int array }\n\ntype sub = string * int * int\n\nlet (//) x y =\n if y < 1 then raise Division_by_zero ;\n if x > 0 then 1 + ((x - 1) / y) else 0\n[@@inline]\n\nlet unsafe_get_uint8 t off = Char.code (String.unsafe_get t off)\nlet unsafe_set_uint8 t off v = Bytes.unsafe_set t off (Char.chr v)\nlet unsafe_set_uint16 = Unsafe.unsafe_set_uint16\n\nexternal unsafe_get_uint16 : string -> int -> int = \"%caml_string_get16u\" [@@noalloc]\nexternal swap16 : int -> int = \"%bswap16\" [@@noalloc]\n\nlet none = (-1)\n\n(* We mostly want to have an optional array for [dmap] (e.g. [int option\n array]). So we consider the [none] value as [-1]. *)\n\nlet make_alphabet alphabet =\n if String.length alphabet <> 64 then invalid_arg \"Length of alphabet must be 64\" ;\n if String.contains alphabet '=' then invalid_arg \"Alphabet can not contain padding character\" ;\n let emap = Array.init (String.length alphabet) (fun i -> Char.code (String.get alphabet i)) in\n let dmap = Array.make 256 none in\n String.iteri (fun idx chr -> Array.set dmap (Char.code chr) idx) alphabet ;\n { emap; dmap; }\n\nlet length_alphabet { emap; _ } = Array.length emap\nlet alphabet { emap; _ } = emap\n\nlet default_alphabet = make_alphabet \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\"\nlet uri_safe_alphabet = make_alphabet \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_\"\n\nlet unsafe_set_be_uint16 =\n if Sys.big_endian\n then fun t off v -> unsafe_set_uint16 t off v\n else fun t off v -> unsafe_set_uint16 t off (swap16 v)\n\n(* We make this exception to ensure to keep a control about which exception we\n can raise and avoid appearance of unknown exceptions like an ex-nihilo\n magic rabbit (or magic money?). *)\nexception Out_of_bounds\nexception Too_much_input\n\nlet get_uint8 t off =\n if off < 0 || off >= String.length t then raise Out_of_bounds ;\n unsafe_get_uint8 t off\n\nlet padding = int_of_char '='\n\nlet error_msgf fmt = Format.ksprintf (fun err -> Error (`Msg err)) fmt\n\nlet encode_sub pad { emap; _ } ?(off = 0) ?len input =\n let len = match len with\n | Some len -> len\n | None -> String.length input - off in\n\n if len < 0 || off < 0 || off > String.length input - len\n then error_msgf \"Invalid bounds\"\n else\n let n = len in\n let n' = n // 3 * 4 in\n let res = Bytes.create n' in\n\n let emap i = Array.unsafe_get emap i in\n\n let emit b1 b2 b3 i =\n unsafe_set_be_uint16 res i\n ((emap (b1 lsr 2 land 0x3f) lsl 8)\n lor (emap ((b1 lsl 4) lor (b2 lsr 4) land 0x3f))) ;\n unsafe_set_be_uint16 res (i + 2)\n ((emap ((b2 lsl 2) lor (b3 lsr 6) land 0x3f) lsl 8)\n lor (emap (b3 land 0x3f))) in\n\n let rec enc j i =\n if i = n then ()\n else if i = n - 1\n then emit (unsafe_get_uint8 input (off + i)) 0 0 j\n else if i = n - 2\n then emit (unsafe_get_uint8 input (off + i)) (unsafe_get_uint8 input (off + i + 1)) 0 j\n else\n (emit\n (unsafe_get_uint8 input (off + i))\n (unsafe_get_uint8 input (off + i + 1))\n (unsafe_get_uint8 input (off + i + 2))\n j ;\n enc (j + 4) (i + 3)) in\n\n let rec unsafe_fix = function\n | 0 -> ()\n | i -> unsafe_set_uint8 res (n' - i) padding ; unsafe_fix (i - 1) in\n\n enc 0 0 ;\n\n let pad_to_write = ((3 - n mod 3) mod 3) in\n\n if pad\n then begin unsafe_fix pad_to_write ; Ok (Bytes.unsafe_to_string res, 0, n') end\n else Ok (Bytes.unsafe_to_string res, 0, (n' - pad_to_write))\n(* [pad = false], we don't want to write them. *)\n\nlet encode ?(pad = true) ?(alphabet = default_alphabet) ?off ?len input =\n match encode_sub pad alphabet ?off ?len input with\n | Ok (res, off, len) -> Ok (String.sub res off len)\n | Error _ as err -> err\n\nlet encode_string ?pad ?alphabet input =\n match encode ?pad ?alphabet input with\n | Ok res -> res\n | Error _ -> assert false\n\nlet encode_sub ?(pad = true) ?(alphabet = default_alphabet) ?off ?len input =\n encode_sub pad alphabet ?off ?len input\n\nlet encode_exn ?pad ?alphabet ?off ?len input =\n match encode ?pad ?alphabet ?off ?len input with\n | Ok v -> v\n | Error (`Msg err) -> invalid_arg err\n\nlet decode_sub ?(pad = true) { dmap; _ } ?(off = 0) ?len input =\n let len = match len with\n | Some len -> len\n | None -> String.length input - off in\n\n if len < 0 || off < 0 || off > String.length input - len\n then error_msgf \"Invalid bounds\"\n else\n\n let n = (len // 4) * 4 in\n let n' = (n // 4) * 3 in\n let res = Bytes.create n' in\n let invalid_pad_overflow = pad in\n\n let get_uint8_or_padding =\n if pad then (fun t i -> if i >= len then raise Out_of_bounds ; get_uint8 t (off + i) )\n else (fun t i -> try if i < len then get_uint8 t (off + i) else padding with Out_of_bounds -> padding ) in\n\n let set_be_uint16 t off v =\n (* can not write 2 bytes. *)\n if off < 0 || off + 1 > Bytes.length t then ()\n (* can not write 1 byte but can write 1 byte *)\n else if off < 0 || off + 2 > Bytes.length t then unsafe_set_uint8 t off (v lsr 8)\n (* can write 2 bytes. *)\n else unsafe_set_be_uint16 t off v in\n\n let set_uint8 t off v =\n if off < 0 || off >= Bytes.length t then ()\n else unsafe_set_uint8 t off v in\n\n let emit a b c d j =\n let x = (a lsl 18) lor (b lsl 12) lor (c lsl 6) lor d in\n set_be_uint16 res j (x lsr 8) ;\n set_uint8 res (j + 2) (x land 0xff) in\n\n let dmap i =\n let x = Array.unsafe_get dmap i in\n if x = none then raise Not_found ; x in\n\n let only_padding pad idx =\n\n (* because we round length of [res] to the upper bound of how many\n characters we should have from [input], we got at this stage only padding\n characters and we need to delete them, so for each [====], we delete 3\n bytes. *)\n\n let pad = ref (pad + 3) in\n let idx = ref idx in\n\n while !idx + 4 < len do\n (* use [unsafe_get_uint16] instead [unsafe_get_uint32] to avoid allocation\n of [int32]. Of course, [3d3d3d3d] is [====]. *)\n if unsafe_get_uint16 input (off + !idx) <> 0x3d3d\n || unsafe_get_uint16 input (off + !idx + 2) <> 0x3d3d\n then raise Not_found ;\n (* We got something bad, should be a valid character according to\n [alphabet] but outside the scope. *)\n\n idx := !idx + 4 ;\n pad := !pad + 3 ;\n done ;\n while !idx < len do\n if unsafe_get_uint8 input (off + !idx) <> padding\n then raise Not_found ;\n\n incr idx ;\n done ; !pad in\n\n let rec dec j i =\n if i = n then 0\n else begin\n let (d, pad) =\n let x = get_uint8_or_padding input (i + 3) in\n try (dmap x, 0) with Not_found when x = padding -> (0, 1) in\n (* [Not_found] iff [x ∉ alphabet and x <> '='] can leak. *)\n let (c, pad) =\n let x = get_uint8_or_padding input (i + 2) in\n try (dmap x, pad) with Not_found when x = padding && pad = 1 -> (0, 2) in\n (* [Not_found] iff [x ∉ alphabet and x <> '='] can leak. *)\n let (b, pad) =\n let x = get_uint8_or_padding input (i + 1) in\n try (dmap x, pad) with Not_found when x = padding && pad = 2 -> (0, 3) in\n (* [Not_found] iff [x ∉ alphabet and x <> '='] can leak. *)\n let (a, pad) =\n let x = get_uint8_or_padding input i in\n try (dmap x, pad) with Not_found when x = padding && pad = 3 -> (0, 4) in\n (* [Not_found] iff [x ∉ alphabet and x <> '='] can leak. *)\n\n emit a b c d j ;\n\n if i + 4 = n\n (* end of input in anyway *)\n then match pad with\n | 0 ->\n 0\n | 4 ->\n (* assert (invalid_pad_overflow = false) ; *)\n 3\n (* [get_uint8] lies and if we get [4], that mean we got one or more (at\n most 4) padding character. In this situation, because we round length\n of [res] (see [n // 4]), we need to delete 3 bytes. *)\n | pad ->\n pad\n else match pad with\n | 0 -> dec (j + 3) (i + 4)\n | 4 ->\n (* assert (invalid_pad_overflow = false) ; *)\n only_padding 3 (i + 4)\n (* Same situation than above but we should get only more padding\n characters then. *)\n | pad ->\n if invalid_pad_overflow = true then raise Too_much_input ;\n only_padding pad (i + 4) end in\n\n match dec 0 0 with\n | 0 -> Ok (Bytes.unsafe_to_string res, 0, n')\n | pad -> Ok (Bytes.unsafe_to_string res, 0, (n' - pad))\n | exception Out_of_bounds -> error_msgf \"Wrong padding\"\n (* appear only when [pad = true] and when length of input is not a multiple of 4. *)\n | exception Not_found ->\n (* appear when one character of [input] ∉ [alphabet] and this character <> '=' *)\n error_msgf \"Malformed input\"\n | exception Too_much_input ->\n error_msgf \"Too much input\"\n\nlet decode ?pad ?(alphabet = default_alphabet) ?off ?len input =\n match decode_sub ?pad alphabet ?off ?len input with\n | Ok (res, off, len) -> Ok (String.sub res off len)\n | Error _ as err -> err\n\nlet decode_sub ?pad ?(alphabet = default_alphabet) ?off ?len input =\n decode_sub ?pad alphabet ?off ?len input\n\nlet decode_exn ?pad ?alphabet ?off ?len input =\n match decode ?pad ?alphabet ?off ?len input with\n | Ok res -> res\n | Error (`Msg err) -> invalid_arg err\n","open Core_kernel\n\nmodule Aux (Impl : Snarky_backendless.Snark_intf.Run) = struct\n open Impl\n\n let non_residue : Field.Constant.t Lazy.t =\n let open Field.Constant in\n let rec go i = if not (is_square i) then i else go (i + one) in\n lazy (go (of_int 2))\n\n let sqrt_exn x =\n let y =\n exists Field.typ ~compute:(fun () ->\n Field.Constant.sqrt (As_prover.read_var x) )\n in\n assert_square y x ; y\n\n (* let sqrt_flagged : Field.t -> Field.t * Boolean.var = *)\n let sqrt_flagged x =\n (*\n imeckler: I learned this trick from Dan Boneh\n\n m a known non residue\n\n exists is_square : bool, y.\n if is_square then assert y*y = x else assert y*y = m * x\n\n <=>\n\n assert (y*y = if is_square then x else m * x)\n *)\n let is_square =\n exists Boolean.typ ~compute:(fun () ->\n Field.Constant.is_square (As_prover.read_var x) )\n in\n let m = Lazy.force non_residue in\n (sqrt_exn (Field.if_ is_square ~then_:x ~else_:(Field.scale x m)), is_square)\nend\n\nlet wrap (type f) ((module Impl) : f Snarky_backendless.Snark0.m) ~potential_xs\n ~y_squared =\n let open Impl in\n let module A = Aux (Impl) in\n let open A in\n stage (fun x ->\n let x1, x2, x3 = potential_xs x in\n let y1, b1 = sqrt_flagged (y_squared ~x:x1)\n and y2, b2 = sqrt_flagged (y_squared ~x:x2)\n and y3, b3 = sqrt_flagged (y_squared ~x:x3) in\n Boolean.Assert.any [ b1; b2; b3 ] ;\n let x1_is_first = (b1 :> Field.t)\n and x2_is_first = (Boolean.((not b1) && b2) :> Field.t)\n and x3_is_first = (Boolean.((not b1) && (not b2) && b3) :> Field.t) in\n ( Field.((x1_is_first * x1) + (x2_is_first * x2) + (x3_is_first * x3))\n , Field.((x1_is_first * y1) + (x2_is_first * y2) + (x3_is_first * y3)) ) )\n\nmodule Make\n (M : Snarky_backendless.Snark_intf.Run) (P : sig\n val params : M.field Group_map.Params.t\n end) =\nstruct\n open P\n include Group_map.Make (M.Field.Constant) (M.Field) (P)\n open M\n\n let to_group =\n let { Group_map.Spec.a; b } = Group_map.Params.spec params in\n unstage\n (wrap\n (module M)\n ~potential_xs\n ~y_squared:Field.(fun ~x -> (x * x * x) + scale x a + constant b) )\nend\n","open Core_kernel\nmodule Params = Group_map.Params\n\nlet to_group (type t)\n (module F : Group_map.Field_intf.S_unchecked with type t = t) ~params t =\n let module M =\n Group_map.Make\n (F)\n (struct\n include F\n\n let constant = Fn.id\n end)\n (struct\n let params = params\n end)\n in\n let { Group_map.Spec.a; b } = Params.spec params in\n let try_decode x =\n let f x = F.((x * x * x) + (a * x) + b) in\n let y = f x in\n if F.is_square y then Some (x, F.sqrt y) else None\n in\n let x1, x2, x3 = M.potential_xs t in\n List.find_map [ x1; x2; x3 ] ~f:try_decode |> Option.value_exn\n\nmodule Checked = struct\n open Snarky_backendless\n\n let wrap = Checked_map.wrap\n\n let to_group (type f) (module M : Snark_intf.Run with type field = f) ~params\n t =\n let module G =\n Checked_map.Make\n (M)\n (struct\n let params = params\n end)\n in\n G.to_group t\nend\n","open Core_kernel\nopen Pickles_types\n\nmodule Constant = struct\n type t = int\nend\n\n(* TODO: Optimization(?) Have this have length n - 1 since the last one is\n determined by the remaining ones. *)\ntype ('f, 'n) t =\n ('f Snarky_backendless.Cvar.t Snarky_backendless.Boolean.t, 'n) Vector.t\n\nmodule T (Impl : Snarky_backendless.Snark_intf.Run) = struct\n type nonrec 'n t = (Impl.field, 'n) t\nend\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.Run) = struct\n module Constant = Constant\n open Impl\n include T (Impl)\n\n let of_index i ~length =\n let v = Vector.init length ~f:(fun j -> Field.equal (Field.of_int j) i) in\n Boolean.Assert.any (Vector.to_list v) ;\n v\n\n let of_vector_unsafe = Fn.id\n\n let typ (n : 'n Nat.t) : ('n t, Constant.t) Typ.t =\n let (Typ typ) = Vector.typ Boolean.typ n in\n let typ : _ Typ.t =\n Typ\n { typ with\n check =\n (fun x ->\n Impl.Internal_Basic.Checked.bind (typ.check x) ~f:(fun () ->\n make_checked (fun () ->\n Boolean.Assert.exactly_one (Vector.to_list x) ) ) )\n }\n in\n Typ.transport typ\n ~there:(fun i -> Vector.init n ~f:(( = ) i))\n ~back:(fun v ->\n let i, _ =\n List.findi (Vector.to_list v) ~f:(fun _ b -> b) |> Option.value_exn\n in\n i )\nend\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = { h : Domain.Stable.V1.t }\n [@@deriving fields, sexp, compare, yojson]\n\n let to_latest = Fn.id\n end\nend]\n","open Core_kernel\nopen Pickles_types\n\nmodule T (Impl : Snarky_backendless.Snark_intf.Run) (N : Pickles_types.Nat.Intf) =\nstruct\n open Impl\n\n type t = Field.t\n\n let length = 64 * Nat.to_int N.n\n\n module Constant = Constant.Make (N)\n\n let typ : (Field.t, Constant.t) Typ.t =\n Typ.field\n |> Typ.transport\n ~there:(fun x -> Field.Constant.project (Constant.to_bits x))\n ~back:(fun x ->\n Constant.of_bits (List.take (Field.Constant.unpack x) length) )\nend\n","open Pickles_types\n\ntype 'f t = 'f Snarky_backendless.Cvar.t\n\nmodule Constant = Constant.Make (Nat.N2)\n\nmodule type S = sig\n module Impl : Snarky_backendless.Snark_intf.Run\n\n open Impl\n\n type nonrec t = field t\n\n module Constant : sig\n type t = Constant.t [@@deriving sexp_of]\n\n val to_bits : t -> bool list\n\n val of_bits : bool list -> t\n\n val dummy : t\n end\n\n val typ : (t, Constant.t) Typ.t\n\n val length : int\nend\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.Run) :\n S with module Impl := Impl =\n Make.T (Impl) (Nat.N2)\n","open Pickles_types\nopen Core_kernel\nmodule Limbs = Nat.N4\n\nmodule Constant = struct\n include Limb_vector.Constant.Make (Limbs)\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type t =\n Limb_vector.Constant.Hex64.Stable.V1.t Vector.Vector_4.Stable.V1.t\n [@@deriving compare, sexp, yojson, hash, equal]\n\n let to_latest = Fn.id\n end\n end]\n\n (* Force the typechecker to verify that these types are equal. *)\n let (_ : (t, Stable.Latest.t) Type_equal.t) = Type_equal.T\n\n open Backend\n\n let to_tick_field x = Tick.Field.of_bits (to_bits x)\n\n let to_tock_field x = Tock.Field.of_bits (to_bits x)\n\n let of_tick_field x = of_bits (Tick.Field.to_bits x)\nend\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.Run) = struct\n open Impl\n\n type t = Field.t\n\n let to_bits = Field.choose_preimage_var ~length:Field.size_in_bits\n\n module Unsafe = struct\n let to_bits_unboolean x =\n with_label __LOC__ (fun () ->\n let length = Field.size_in_bits in\n let res =\n exists\n (Typ.list Boolean.typ_unchecked ~length)\n ~compute:As_prover.(fun () -> Field.Constant.unpack (read_var x))\n in\n Field.Assert.equal x (Field.project res) ;\n res )\n end\n\n let () = assert (Field.size_in_bits < 64 * Nat.to_int Limbs.n)\n\n module Constant = struct\n include Constant\n\n let to_bits x = List.take (to_bits x) Field.size_in_bits\n end\n\n let typ =\n Typ.transport Field.typ\n ~there:(Fn.compose Field.Constant.project Constant.to_bits)\n ~back:(Fn.compose Constant.of_bits Field.Constant.unpack)\nend\n","module D = Digest\nopen Core_kernel\nopen Pickles_types\nopen Hlist\nmodule Sc = Kimchi_backend_common.Scalar_challenge\n\ntype 'f impl = (module Snarky_backendless.Snark_intf.Run with type field = 'f)\n\ntype ('a, 'b, 'c) basic =\n | Unit : (unit, unit, < .. >) basic\n | Field\n : ('field1, 'field2, < field1 : 'field1 ; field2 : 'field2 ; .. >) basic\n | Bool : ('bool1, 'bool2, < bool1 : 'bool1 ; bool2 : 'bool2 ; .. >) basic\n | Digest\n : ( 'digest1\n , 'digest2\n , < digest1 : 'digest1 ; digest2 : 'digest2 ; .. > )\n basic\n | Challenge\n : ( 'challenge1\n , 'challenge2\n , < challenge1 : 'challenge1 ; challenge2 : 'challenge2 ; .. > )\n basic\n | Bulletproof_challenge\n : ( 'bp_chal1\n , 'bp_chal2\n , < bulletproof_challenge1 : 'bp_chal1\n ; bulletproof_challenge2 : 'bp_chal2\n ; .. > )\n basic\n | Branch_data\n : ( 'branch_data1\n , 'branch_data2\n , < branch_data1 : 'branch_data1 ; branch_data2 : 'branch_data2 ; .. >\n )\n basic\n\nmodule type Bool_intf = sig\n type var\n\n val true_ : var\n\n val false_ : var\nend\n\nmodule rec T : sig\n type (_, _, _) t =\n | B : ('a, 'b, 'env) basic -> ('a, 'b, 'env) t\n | Scalar :\n ('a, 'b, (< challenge1 : 'a ; challenge2 : 'b ; .. > as 'env)) basic\n -> ('a Sc.t, 'b Sc.t, 'env) t\n | Vector :\n ('t1, 't2, 'env) t * 'n Nat.t\n -> (('t1, 'n) Vector.t, ('t2, 'n) Vector.t, 'env) t\n | Array : ('t1, 't2, 'env) t * int -> ('t1 array, 't2 array, 'env) t\n | Struct :\n ('xs1, 'xs2, 'env) H2_1.T(T).t\n -> ('xs1 Hlist.HlistId.t, 'xs2 Hlist.HlistId.t, 'env) t\n | Opt :\n { inner : ('a1, 'a2, (< bool1 : bool ; bool2 : 'bool ; .. > as 'env)) t\n ; flag : Opt.Flag.t\n ; dummy1 : 'a1\n ; dummy2 : 'a2\n ; bool : (module Bool_intf with type var = 'bool)\n }\n -> ('a1 option, ('a2, 'bool) Opt.t, 'env) t\n | Opt_unflagged :\n { inner : ('a1, 'a2, (< bool1 : bool ; bool2 : 'bool ; .. > as 'env)) t\n ; flag : Opt.Flag.t\n ; dummy1 : 'a1\n ; dummy2 : 'a2\n }\n -> ('a1 option, 'a2 option, 'env) t\n | Constant : 'a * ('a -> 'a -> unit) * ('a, 'b, 'env) t -> ('a, 'b, 'env) t\nend =\n T\n\ntype ('scalar, 'env) pack =\n { pack : 'a 'b. ('a, 'b, 'env) basic -> 'a option -> 'b -> 'scalar array }\n\nlet rec pack :\n type t v env.\n zero:'scalar\n -> one:'scalar\n -> ('scalar, env) pack\n -> (t, v, env) T.t\n -> t option\n -> v\n -> 'scalar array =\n fun ~zero ~one p spec t_constant_opt t ->\n match spec with\n | B spec ->\n p.pack spec t_constant_opt t\n | Scalar chal ->\n let t_constant_opt =\n Option.map t_constant_opt ~f:(fun { Sc.inner = x } -> x)\n in\n let { Sc.inner = t } = t in\n p.pack chal t_constant_opt t\n | Vector (spec, _) ->\n let t_constant_opt = Option.map ~f:Vector.to_array t_constant_opt in\n let t = Vector.to_array t in\n pack ~zero ~one p (Array (spec, Array.length t)) t_constant_opt t\n | Struct [] ->\n [||]\n | Struct (spec :: specs) ->\n let (hd :: tl) = t in\n let hd_constant_opt, tl_constant_opt =\n match t_constant_opt with\n | None ->\n (None, None)\n | Some (hd :: tl) ->\n (Some hd, Some tl)\n in\n let hd = pack ~zero ~one p spec hd_constant_opt hd in\n Array.append hd (pack ~zero ~one p (Struct specs) tl_constant_opt tl)\n | Array (spec, _) ->\n Array.concat_mapi t ~f:(fun i t ->\n let t_constant_opt =\n Option.map t_constant_opt ~f:(fun t_const -> t_const.(i))\n in\n pack ~zero ~one p spec t_constant_opt t )\n | Opt { inner; dummy1; dummy2; flag = _; bool = _ } -> (\n match t with\n | Nothing ->\n let t_constant_opt = Option.map t_constant_opt ~f:(fun _ -> dummy1) in\n Array.append [| zero |]\n (pack ~zero ~one p inner t_constant_opt dummy2)\n | Just x ->\n let t_constant_opt =\n Option.map ~f:(fun x -> Option.value_exn x) t_constant_opt\n in\n Array.append [| one |] (pack ~zero ~one p inner t_constant_opt x)\n | Maybe (b, x) ->\n let b_constant_opt = Option.map ~f:Option.is_some t_constant_opt in\n let x_constant_opt =\n Option.map ~f:(Option.value ~default:dummy1) t_constant_opt\n in\n Array.append\n (p.pack Bool b_constant_opt b)\n (pack ~zero ~one p inner x_constant_opt x) )\n | Opt_unflagged { inner; dummy1; dummy2; flag = _ } -> (\n match t with\n | None ->\n let t_constant_opt = Option.map t_constant_opt ~f:(fun _ -> dummy1) in\n pack ~zero ~one p inner t_constant_opt dummy2\n | Some x ->\n let t_constant_opt =\n Option.map ~f:(fun x -> Option.value_exn x) t_constant_opt\n in\n pack ~zero ~one p inner t_constant_opt x )\n | Constant (x, _, inner) ->\n pack ~zero ~one p inner (Some x) t\n\ntype ('f, 'env) typ =\n { typ :\n 'var 'value.\n ('value, 'var, 'env) basic -> ('var, 'value, 'f) Snarky_backendless.Typ.t\n }\n\nlet rec typ :\n type f var value env.\n (f, env) typ\n -> (value, var, env) T.t\n -> (var, value, f) Snarky_backendless.Typ.t =\n let open Snarky_backendless.Typ in\n fun t spec ->\n match[@warning \"-45\"] spec with\n | B spec ->\n t.typ spec\n | Scalar chal ->\n Sc.typ (t.typ chal)\n | Vector (spec, n) ->\n Vector.typ (typ t spec) n\n | Array (spec, n) ->\n array ~length:n (typ t spec)\n | Struct [] ->\n let open Hlist.HlistId in\n transport (unit ()) ~there:(fun [] -> ()) ~back:(fun () -> [])\n |> transport_var ~there:(fun [] -> ()) ~back:(fun () -> [])\n | Struct (spec :: specs) ->\n let open Hlist.HlistId in\n tuple2 (typ t spec) (typ t (Struct specs))\n |> transport\n ~there:(fun (x :: xs) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n |> transport_var\n ~there:(fun (x :: xs) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n | Opt { inner; flag; dummy1; dummy2; bool = (module B) } ->\n let bool = typ t (B Bool) in\n let open B in\n (* Always use the same \"maybe\" layout which is a boolean and then the value *)\n Opt.constant_layout_typ bool flag ~dummy:dummy1 ~dummy_var:dummy2 ~true_\n ~false_ (typ t inner)\n | Opt_unflagged { inner; flag; dummy1; dummy2 } -> (\n match flag with\n | Opt.Flag.No ->\n let open Snarky_backendless.Typ in\n unit ()\n |> Snarky_backendless.Typ.transport\n ~there:(function Some _ -> assert false | None -> ())\n ~back:(fun () -> None)\n |> Snarky_backendless.Typ.transport_var\n ~there:(function Some _ -> assert false | None -> ())\n ~back:(fun _ -> None)\n | Opt.Flag.(Yes | Maybe) ->\n typ t inner\n |> Snarky_backendless.Typ.transport\n ~there:(function Some x -> x | None -> dummy1)\n ~back:(fun x -> Some x)\n |> Snarky_backendless.Typ.transport_var\n ~there:(function Some x -> x | None -> dummy2)\n ~back:(fun x -> Some x) )\n | Constant (x, assert_eq, spec) ->\n let (Typ typ) = typ t spec in\n let constant_var =\n let fields, aux = typ.value_to_fields x in\n let fields =\n Array.map fields ~f:(fun x -> Snarky_backendless.Cvar.Constant x)\n in\n typ.var_of_fields (fields, aux)\n in\n let open Snarky_backendless.Typ in\n unit ()\n |> transport ~there:(fun y -> assert_eq x y) ~back:(fun () -> x)\n |> transport_var ~there:(fun _ -> ()) ~back:(fun () -> constant_var)\n\nmodule ETyp = struct\n type ('var, 'value, 'f) t =\n | T :\n ('inner, 'value, 'f) Snarky_backendless.Typ.t\n * ('inner -> 'var)\n * ('var -> 'inner)\n -> ('var, 'value, 'f) t\nend\n\ntype ('f, 'env) etyp =\n { etyp : 'var 'value. ('value, 'var, 'env) basic -> ('var, 'value, 'f) ETyp.t\n }\n\nlet rec etyp :\n type f var value env.\n (f, env) etyp -> (value, var, env) T.t -> (var, value, f) ETyp.t =\n let open Snarky_backendless.Typ in\n fun e spec ->\n match[@warning \"-45\"] spec with\n | B spec ->\n e.etyp spec\n | Scalar chal ->\n let (T (typ, f, f_inv)) = e.etyp chal in\n T (Sc.typ typ, Sc.map ~f, Sc.map ~f:f_inv)\n | Vector (spec, n) ->\n let (T (typ, f, f_inv)) = etyp e spec in\n T (Vector.typ typ n, Vector.map ~f, Vector.map ~f:f_inv)\n | Array (spec, n) ->\n let (T (typ, f, f_inv)) = etyp e spec in\n T (array ~length:n typ, Array.map ~f, Array.map ~f:f_inv)\n | Struct [] ->\n let open Hlist.HlistId in\n let there [] = () in\n let back () = [] in\n T\n ( transport (unit ()) ~there ~back |> transport_var ~there ~back\n , Fn.id\n , Fn.id )\n | Struct (spec :: specs) ->\n let open Hlist.HlistId in\n let (T (t1, f1, f1_inv)) = etyp e spec in\n let (T (t2, f2, f2_inv)) = etyp e (Struct specs) in\n T\n ( tuple2 t1 t2\n |> transport\n ~there:(fun (x :: xs) -> (x, xs))\n ~back:(fun (x, xs) -> x :: xs)\n , (fun (x, xs) -> f1 x :: f2 xs)\n , fun (x :: xs) -> (f1_inv x, f2_inv xs) )\n | Opt { inner; flag; dummy1; dummy2; bool = (module B) } ->\n let (T (bool, f_bool, f_bool')) = etyp e (B Bool) in\n let (T (a, f_a, f_a')) = etyp e inner in\n let opt_map ~f1 ~f2 (x : _ Opt.t) : _ Opt.t =\n match x with\n | Nothing ->\n Opt.nothing\n | Just x ->\n Opt.just (f1 x)\n | Maybe (b, x) ->\n Maybe (f2 b, f1 x)\n in\n let f = opt_map ~f1:f_a ~f2:f_bool in\n let f' = opt_map ~f1:f_a' ~f2:f_bool' in\n T\n ( Opt.constant_layout_typ ~dummy:dummy1 ~dummy_var:(f_a' dummy2)\n ~true_:(f_bool' B.true_) ~false_:(f_bool' B.false_) bool flag a\n , f\n , f' )\n | Opt_unflagged { inner; dummy1; dummy2; flag = _ } ->\n let (T (typ, f, f_inv)) = etyp e inner in\n let f x = Some (f x) in\n let f_inv = function None -> f_inv dummy2 | Some x -> f_inv x in\n let typ =\n typ\n |> Snarky_backendless.Typ.transport\n ~there:(Option.value ~default:dummy1) ~back:(fun x -> Some x)\n in\n T (typ, f, f_inv)\n | Constant (x, _assert_eq, spec) ->\n let (T (Typ typ, f, f')) = etyp e spec in\n let constant_var =\n let fields, aux = typ.value_to_fields x in\n let fields =\n Array.map fields ~f:(fun x -> Snarky_backendless.Cvar.Constant x)\n in\n typ.var_of_fields (fields, aux)\n in\n (* We skip any constraints that would be added here, but we *do* use\n the underlying [Typ.t] to make sure that we allocate public inputs\n correctly.\n *)\n T\n ( Typ\n { typ with\n check =\n (fun _ -> Snarky_backendless.Checked_runner.Simple.return ())\n }\n , (fun _ -> f constant_var)\n , f' )\n\nmodule Common (Impl : Snarky_backendless.Snark_intf.Run) = struct\n module Digest = D.Make (Impl)\n module Challenge = Limb_vector.Challenge.Make (Impl)\n open Impl\n\n module Env = struct\n type ('other_field, 'other_field_var, 'a) t =\n < field1 : 'other_field\n ; field2 : 'other_field_var\n ; bool1 : bool\n ; bool2 : Boolean.var\n ; digest1 : Digest.Constant.t\n ; digest2 : Digest.t\n ; challenge1 : Challenge.Constant.t\n ; challenge2 : Challenge.t\n ; bulletproof_challenge1 :\n Challenge.Constant.t Sc.t Bulletproof_challenge.t\n ; bulletproof_challenge2 : Challenge.t Sc.t Bulletproof_challenge.t\n ; branch_data1 : Branch_data.t\n ; branch_data2 : Impl.field Branch_data.Checked.t\n ; .. >\n as\n 'a\n end\nend\n\nlet pack_basic (type field other_field other_field_var)\n ((module Impl) : field impl) =\n let open Impl in\n let module C = Common (Impl) in\n let open C in\n let pack :\n type a b.\n (a, b, ((other_field, other_field_var, 'e) Env.t as 'e)) basic\n -> a option\n -> b\n -> [ `Field of other_field_var | `Packed_bits of Field.t * int ] array =\n fun basic x_constant_opt x ->\n (* TODO *)\n ignore x_constant_opt ;\n match basic with\n | Unit ->\n [||]\n | Field ->\n [| `Field x |]\n | Bool ->\n [| `Packed_bits ((x :> Field.t), 1) |]\n | Digest ->\n [| `Packed_bits (x, Field.size_in_bits) |]\n | Challenge ->\n [| `Packed_bits (x, Challenge.length) |]\n | Branch_data ->\n [| `Packed_bits\n ( Branch_data.Checked.pack (module Impl) x\n , Branch_data.length_in_bits )\n |]\n | Bulletproof_challenge ->\n let { Sc.inner = pre } = Bulletproof_challenge.pack x in\n [| `Packed_bits (pre, Challenge.length) |]\n in\n { pack }\n\nlet pack (type f) ((module Impl) as impl : f impl) t =\n let open Impl in\n pack (pack_basic impl) t\n ~zero:(`Packed_bits (Field.zero, 1))\n ~one:(`Packed_bits (Field.one, 1))\n None\n\nlet typ_basic (type field other_field other_field_var)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = field)\n ~assert_16_bits (field : (other_field_var, other_field) Impl.Typ.t) =\n let open Impl in\n let module C = Common (Impl) in\n let open C in\n let typ :\n type a b.\n (a, b, ((other_field, other_field_var, 'e) Env.t as 'e)) basic\n -> (b, a) Impl.Typ.t =\n fun basic ->\n match basic with\n | Unit ->\n Typ.unit\n | Field ->\n field\n | Bool ->\n Boolean.typ\n | Branch_data ->\n Branch_data.typ (module Impl) ~assert_16_bits\n | Digest ->\n Digest.typ\n | Challenge ->\n Challenge.typ\n | Bulletproof_challenge ->\n Bulletproof_challenge.typ Challenge.typ\n in\n { typ }\n\nlet typ ~assert_16_bits impl field t =\n typ (typ_basic ~assert_16_bits impl field) t\n\nlet packed_typ_basic (type field other_field other_field_var)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = field)\n (field : (other_field_var, other_field, field) ETyp.t) =\n let open Impl in\n let module Digest = D.Make (Impl) in\n let module Challenge = Limb_vector.Challenge.Make (Impl) in\n let module Env = struct\n type ('other_field, 'other_field_var, 'a) t =\n < field1 : 'other_field\n ; field2 : 'other_field_var\n ; bool1 : bool\n ; bool2 : Boolean.var\n ; digest1 : Digest.Constant.t\n ; digest2 : Field.t\n ; challenge1 : Challenge.Constant.t\n ; challenge2 : (* Challenge.t *) Field.t\n ; bulletproof_challenge1 :\n Challenge.Constant.t Sc.t Bulletproof_challenge.t\n ; bulletproof_challenge2 : Field.t Sc.t Bulletproof_challenge.t\n ; branch_data1 : Branch_data.t\n ; branch_data2 : Field.t\n ; .. >\n as\n 'a\n end in\n let etyp :\n type a b.\n (a, b, ((other_field, other_field_var, 'e) Env.t as 'e)) basic\n -> (b, a, field) ETyp.t = function\n | Unit ->\n T (Typ.unit, Fn.id, Fn.id)\n | Field ->\n field\n | Bool ->\n T (Boolean.typ, Fn.id, Fn.id)\n | Digest ->\n T (Digest.typ, Fn.id, Fn.id)\n | Challenge ->\n T (Challenge.typ, Fn.id, Fn.id)\n | Branch_data ->\n T (Branch_data.packed_typ (module Impl), Fn.id, Fn.id)\n | Bulletproof_challenge ->\n let typ =\n let there bp_challenge =\n let { Sc.inner = pre } = Bulletproof_challenge.pack bp_challenge in\n pre\n in\n let back pre = Bulletproof_challenge.unpack { Sc.inner = pre } in\n Typ.transport Challenge.typ ~there ~back\n |> Typ.transport_var ~there ~back\n in\n T (typ, Fn.id, Fn.id)\n in\n { etyp }\n\nlet packed_typ impl field t = etyp (packed_typ_basic impl field) t\n","open Core_kernel\nopen Pickles_types\nmodule Domain = Plonk_checks.Domain\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.Run) = struct\n open Impl\n\n type ('a, 'n) t = 'n One_hot_vector.T(Impl).t * ('a, 'n) Vector.t\n\n (* TODO: Use version in common. *)\n let seal (x : Impl.Field.t) : Impl.Field.t =\n let open Impl in\n match Field.to_constant_and_terms x with\n | None, [ (x, i) ] when Field.Constant.(equal x one) ->\n Snarky_backendless.Cvar.Var i\n | Some c, [] ->\n Field.constant c\n | _ ->\n let y = exists Field.typ ~compute:As_prover.(fun () -> read_var x) in\n Field.Assert.equal x y ; y\n\n let mask (type n) (bits : n One_hot_vector.T(Impl).t) xs =\n with_label __LOC__ (fun () ->\n Vector.map\n (Vector.zip (bits :> (Boolean.var, n) Vector.t) xs)\n ~f:(fun (b, x) -> Field.((b :> t) * x))\n |> Vector.fold ~init:Field.zero ~f:Field.( + ) )\n\n let choose : type a n. (a, n) t -> f:(a -> Field.t) -> Field.t =\n fun (bits, xs) ~f -> mask bits (Vector.map xs ~f)\n\n module Degree_bound = struct\n type nonrec 'n t = (int, 'n) t\n\n let shifted_pow ~crs_max_degree t x =\n let pow = Field.(Pcs_batch.pow ~one ~mul) in\n choose t ~f:(fun deg ->\n let d = deg mod crs_max_degree in\n pow x (crs_max_degree - d) )\n end\n\n module Domain = struct\n let num_shifts = Nat.to_int Pickles_types.Plonk_types.Permuts.n\n\n (** Compute the 'shifts' used by the kimchi permutation argument.\n\n These values are selected deterministically-randomly to appear outside\n of the domain, so that every choice of [i] and [shift] results in a\n distinct value for [shift * domain_generator ^ i].\n\n Note that, for each different domain size, we attempt to use the same\n [shifts], and only sample different ones if the shifts are already a\n member of the domain (ie. there exists some [i] such that\n [shift = domain_generator ^ i]). This ensures that the invariant above\n is satisfied.\n Optimisation: since the shifts for the domains that we use in practise\n are all the same -- none of them have 2-adic order < largest domain\n size -- we can hard-code the shifts instead of using a one-hot mask,\n and this function adds no constraints to the circuit.\n *)\n let shifts (type n) ((which, log2s) : (int, n) t)\n ~(shifts : log2_size:int -> Field.Constant.t array) :\n Field.t Pickles_types.Plonk_types.Shifts.t =\n let all_shifts = Vector.map log2s ~f:(fun d -> shifts ~log2_size:d) in\n match all_shifts with\n | [] ->\n failwith \"Pseudo.Domain.shifts: no domains were given\"\n | shifts :: other_shiftss ->\n (* Runtime check that the shifts across all domains are consistent.\n The optimisation below will not work if this is not true; if the\n domain size or the shifts are modified such that this becomes\n false, [disabled_not_the_same] can be set to true to enable\n dynamic selection within the circuit.\n *)\n let all_the_same =\n Vector.for_all other_shiftss\n ~f:(Array.for_all2_exn ~f:Field.Constant.equal shifts)\n in\n (* Set to true if we do not want to allow dynamic selection of the\n shifts at runtime.\n This is possible because of the optimisation outlined in the\n doc-comment above, but this option and the original code is left\n here in case we transition to a larger domain size that uses\n different shifts than those for smaller domains.\n *)\n let disabled_not_the_same = true in\n if all_the_same then Array.map ~f:Field.constant shifts\n else if disabled_not_the_same then\n failwith \"Pseudo.Domain.shifts: found variable shifts\"\n else\n let get_ith_shift i =\n mask which\n (Vector.map all_shifts ~f:(fun a -> Field.constant a.(i)))\n in\n Array.init num_shifts ~f:get_ith_shift\n\n let generator (type n) ((which, log2s) : (int, n) t) ~domain_generator =\n mask which (Vector.map log2s ~f:(fun d -> domain_generator ~log2_size:d))\n\n type nonrec 'n t = (Domain.t, 'n) t\n\n let to_domain ~shifts:s ~domain_generator (type n) (t : n t) :\n Field.t Plonk_checks.plonk_domain =\n let log2_sizes = Vector.map (snd t) ~f:Domain.log2_size in\n let shifts = shifts (fst t, log2_sizes) ~shifts:s in\n let generator = generator (fst t, log2_sizes) ~domain_generator in\n let max_log2 =\n let _, ds = t in\n List.fold (Vector.to_list ds) ~init:0 ~f:(fun acc d ->\n Int.max acc (Domain.log2_size d) )\n in\n object\n method shifts = shifts\n\n method generator = generator\n\n method vanishing_polynomial x =\n let pow2_pows =\n let res = Array.create ~len:(max_log2 + 1) x in\n for i = 1 to max_log2 do\n res.(i) <- Field.square res.(i - 1)\n done ;\n res\n in\n let open Field in\n seal (choose t ~f:(fun d -> pow2_pows.(Domain.log2_size d)) - one)\n end\n end\nend\n","(* version_bytes.ml -- version bytes for Base58Check encodings *)\n\ntype t = char\n\n(** Base58Check version bytes for individual types\n Each of the following values should be distinct\n*)\n\nlet coinbase : t = '\\x01'\n\nlet secret_box_byteswr : t = '\\x02'\n\nlet fee_transfer_single : t = '\\x03'\n\nlet frontier_hash : t = '\\x04'\n\nlet ledger_hash : t = '\\x05'\n\nlet lite_precomputed : t = '\\x06'\n\nlet proof : t = '\\x0A'\n\nlet random_oracle_base : t = '\\x0B'\n\nlet receipt_chain_hash : t = '\\x0C'\n\nlet epoch_seed : t = '\\x0D'\n\nlet staged_ledger_hash_aux_hash : t = '\\x0E'\n\nlet staged_ledger_hash_pending_coinbase_aux : t = '\\x0F'\n\nlet state_hash : t = '\\x10'\n\nlet state_body_hash : t = '\\x11'\n\n(* don't use \\x12, which was for pre-Berkeley hard fork transaction hashes *)\n\n(* used only to deserialize transaction ids, pre-Berkeley hard fork *)\nlet signed_command_v1 : t = '\\x13'\n\nlet user_command_memo : t = '\\x14'\n\nlet vrf_truncated_output : t = '\\x15'\n\nlet web_pipe : t = '\\x16'\n\nlet coinbase_stack_data : t = '\\x17'\n\nlet coinbase_stack_hash : t = '\\x18'\n\nlet pending_coinbase_hash_builder : t = '\\x19'\n\nlet zkapp_command : t = '\\x1A'\n\nlet verification_key : t = '\\x1B'\n\nlet token_id_key : t = '\\x1C'\n\nlet transaction_hash : t = '\\x1D'\n\n(** used for testing only *)\n\nlet ledger_test_hash : t = '\\x30'\n\n(** The following version bytes are non-sequential; existing\n user key infrastructure depends on them. don't change them!\n*)\n\nlet private_key : t = '\\x5A'\n\nlet non_zero_curve_point_compressed : t = '\\xCB'\n\nlet signature : t = '\\x9A'\n","(* base58_check.ml : implement Base58Check algorithm\n see: https://www.oreilly.com/library/view/mastering-bitcoin-2nd/9781491954379/ch04.html#base58\n also: https://datatracker.ietf.org/doc/html/draft-msporny-base58-03\n\n the algorithm is modified for long strings, to apply encoding on chunks of the input\n*)\n\nopen Core_kernel\n\nexception Invalid_base58_checksum of string\n\nexception Invalid_base58_version_byte of (char * string)\n\nexception Invalid_base58_check_length of string\n\nexception Invalid_base58_character of string\n\n(* same as Bitcoin alphabet *)\nlet mina_alphabet =\n B58.make_alphabet \"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz\"\n\nlet version_len = 1\n\nlet checksum_len = 4\n\nmodule Make (M : sig\n val description : string\n\n val version_byte : char\nend) =\nstruct\n let version_byte = M.version_byte\n\n let version_string = String.make 1 version_byte\n\n let max_length = 8192\n\n let compute_checksum payload =\n (* double-hash using SHA256 *)\n let open Digestif.SHA256 in\n let ctx0 = init () in\n let ctx1 = feed_string ctx0 version_string in\n let ctx2 = feed_string ctx1 payload in\n let first_hash = get ctx2 |> to_raw_string in\n let ctx3 = feed_string ctx0 first_hash in\n let second_hash = get ctx3 |> to_raw_string in\n second_hash |> String.sub ~pos:0 ~len:checksum_len\n\n (* we don't name this with _exn, we don't expect to raise an exception\n if we do, we're encoding types that shouldn't be encoded\n *)\n let encode payload =\n let len = String.length payload in\n if len > max_length then\n failwithf\n \"String is too long (%d bytes) to Base58Check-encode, max length is %d\"\n len max_length () ;\n let checksum = compute_checksum payload in\n let bytes = version_string ^ payload ^ checksum |> Bytes.of_string in\n B58.encode mina_alphabet bytes |> Bytes.to_string\n\n let decode_exn s =\n let bytes = Bytes.of_string s in\n let decoded =\n try B58.decode mina_alphabet bytes |> Bytes.to_string\n with B58.Invalid_base58_character ->\n raise (Invalid_base58_character M.description)\n in\n let len = String.length decoded in\n (* input must be at least as long as the version byte and checksum *)\n if len < version_len + checksum_len then\n raise (Invalid_base58_check_length M.description) ;\n let checksum =\n String.sub decoded\n ~pos:(String.length decoded - checksum_len)\n ~len:checksum_len\n in\n let payload =\n String.sub decoded ~pos:1 ~len:(len - version_len - checksum_len)\n in\n if not (String.equal checksum (compute_checksum payload)) then\n raise (Invalid_base58_checksum M.description) ;\n if not (Char.equal decoded.[0] version_byte) then\n raise (Invalid_base58_version_byte (decoded.[0], M.description)) ;\n payload\n\n let decode s =\n let error_str e desc =\n sprintf \"Error decoding %s\\nInvalid base58 %s in %s\" s e desc\n in\n try Ok (decode_exn s) with\n | Invalid_base58_character str ->\n Or_error.error_string (error_str \"character\" str)\n | Invalid_base58_check_length str ->\n Or_error.error_string (error_str \"check length\" str)\n | Invalid_base58_checksum str ->\n Or_error.error_string (error_str \"checksum\" str)\n | Invalid_base58_version_byte (ch, str) ->\n Or_error.error_string\n (error_str\n (sprintf \"version byte \\\\x%02X, expected \\\\x%02X\" (Char.to_int ch)\n (Char.to_int version_byte) )\n str )\nend\n\nmodule Version_bytes = Version_bytes\n","open Core_kernel\n\nmodule type Iso_intf = sig\n type original\n\n type standardized [@@deriving yojson]\n\n val encode : original -> standardized\n\n val decode : standardized -> original\nend\n\nmodule type S = sig\n type t\n\n val to_yojson : t -> Yojson.Safe.t\n\n val of_yojson : Yojson.Safe.t -> t Ppx_deriving_yojson_runtime.error_or\nend\n\nmodule Make (Iso : Iso_intf) = struct\n let to_yojson t = Iso.encode t |> Iso.standardized_to_yojson\n\n let of_yojson json =\n Result.map ~f:Iso.decode (Iso.standardized_of_yojson json)\n\n module For_tests = struct\n let check_encoding t ~equal =\n match of_yojson (to_yojson t) with\n | Ok result ->\n equal t result\n | Error e ->\n failwithf !\"%s\" e ()\n end\nend\n\nmodule For_tests = struct\n let check_encoding (type t) (module M : S with type t = t) t ~equal =\n match M.of_yojson (M.to_yojson t) with\n | Ok result ->\n equal t result\n | Error e ->\n failwithf !\"%s\" e ()\nend\n\nmodule Make_of_int (Iso : sig\n type t\n\n val to_int : t -> int\n\n val of_int : int -> t\nend) =\nMake (struct\n type original = Iso.t\n\n type standardized = int [@@deriving yojson]\n\n let encode = Iso.to_int\n\n let decode = Iso.of_int\nend)\n\nmodule Make_of_string (Iso : sig\n type t\n\n val to_string : t -> string\n\n val of_string : string -> t\nend) =\nMake (struct\n type original = Iso.t\n\n type standardized = string [@@deriving yojson]\n\n let encode = Iso.to_string\n\n let decode = Iso.of_string\nend)\n\nmodule Make_base58_check (T : sig\n type t [@@deriving bin_io]\n\n val description : string\n\n val version_byte : char\nend) =\nstruct\n module Base58_check = Base58_check.Make (T)\n\n let to_base58_check t = Base58_check.encode (Binable.to_string (module T) t)\n\n let of_base58_check s =\n let open Or_error.Let_syntax in\n let%bind decoded = Base58_check.decode s in\n Or_error.try_with (fun () -> Binable.of_string (module T) decoded)\n\n let of_base58_check_exn s = of_base58_check s |> Or_error.ok_exn\n\n let to_yojson t = `String (to_base58_check t)\n\n let of_yojson = function\n | `String s ->\n Result.map_error (of_base58_check s) ~f:Error.to_string_hum\n | json ->\n failwithf \"of_yojson: expect JSON string, got %s\"\n (Yojson.Safe.to_string json)\n ()\nend\n\nmodule type Base58_check_base_intf = sig\n type t\n\n (** Base58Check decoding *)\n val of_base58_check : string -> t Base.Or_error.t\n\n (** Base58Check decoding *)\n val of_base58_check_exn : string -> t\nend\n\nmodule type Base58_check_intf = sig\n type t\n\n (** explicit Base58Check encoding *)\n val to_base58_check : t -> string\n\n include Base58_check_base_intf with type t := t\nend\n\nmodule Make_base64 (T : sig\n type t [@@deriving bin_io]\nend) =\nstruct\n let to_base64 (t : T.t) : string =\n Binable.to_string (module T) t\n |> (* raises only on errors from invalid optional arguments *)\n Base64.encode_exn\n\n let of_base64 b64 : T.t Or_error.t =\n match Base64.decode b64 with\n | Ok s -> (\n try Ok (Binable.of_string (module T) s)\n with Bin_prot.Common.Read_error _ as e ->\n Error (Error.of_exn ~backtrace:`Get e) )\n | Error (`Msg msg) ->\n Error (Error.of_string msg)\nend\n\nmodule type Base64_intf = sig\n type t\n\n val to_base64 : t -> string\n\n val of_base64 : string -> t Or_error.t\nend\n","open Snarky_backendless\nopen Webkit_trace_event\nopen Webkit_trace_event.Output.JSON\nopen Yojson\n\nlet to_string ?buf ?len ?std events =\n to_string ?buf ?len ?std @@ json_of_events events\n\nlet to_channel ?buf ?len ?std out_channel events =\n to_channel ?buf ?len ?std out_channel @@ json_of_events events\n\nlet to_file ?buf ?len ?std filename events =\n let oc = open_out filename in\n to_channel ?buf ?len ?std oc events ;\n close_out oc\n\nmodule Constraints (Snarky_backendless : Snark_intf.Basic) = struct\n (** Create flamechart events for Snarky_backendless constraints.\n\n This creates a chart of labels, associating each label with a 'timestamp'\n equal to the number of constraints at its start and end. *)\n open Snarky_backendless\n\n (** Generate a flamechart for the labels of a checked computation. *)\n let log ?weight (t : unit -> _ Checked.t) : events =\n let rev_events = ref [] in\n let _total =\n constraint_count ?weight t ~log:(fun ?(start = false) label count ->\n rev_events :=\n create_event label\n ~phase:(if start then Measure_start else Measure_end)\n ~timestamp:count\n :: !rev_events )\n in\n List.rev !rev_events\n\n (** Same as [log], but for functions which take [Var.t] arguments.\n Use [apply_args] to apply the corresponding OCaml-typed arguments.\n For example: {[\nopen Snarky_backendless\nmodule Snark = Snark.Make (Backends.Bn128.Default)\nopen Snark\nmodule Constraints = Snarky_log.Constraints (Snark)\n\nlet () = Snarky_log.to_file \"output.json\" @@\n Constraints.log_func ~input:Data_spec.[Field.typ; Field.typ] Field.Checked.mul\n ~apply_args:(fun mul -> mul Field.one Field.one)\n }] *)\n let log_func ~input_typ ~return_typ ~(apply_args : 'k_value -> _ Checked.t)\n (f : 'k_var) : events =\n let f' = conv (fun c -> c) input_typ return_typ f in\n log (fun () -> apply_args f')\nend\n","module B = Bigint\nmodule H_list = Snarky_backendless.H_list\nmodule Challenge = Limb_vector.Challenge\nmodule Types = Composition_types\nmodule Digest = Types.Digest\nmodule Spec = Types.Spec\nmodule Branch_data = Composition_types.Branch_data\nmodule Step_bp_vec = Types.Step_bp_vec\nmodule Nvector = Types.Nvector\nmodule Bulletproof_challenge = Types.Bulletproof_challenge\nmodule Domain = Pickles_base.Domain\nmodule Domains = Pickles_base.Domains\nmodule Scalar_challenge = Kimchi_backend_common.Scalar_challenge\n\nlet debug = false\n","open Core_kernel\nopen Pickles_types\n\nlet rec absorb :\n type a g1 g1_opt f scalar.\n absorb_field:(f -> unit)\n -> absorb_scalar:(scalar -> unit)\n -> g1_to_field_elements:(g1 -> f list)\n -> mask_g1_opt:(g1_opt -> g1)\n -> ( a\n , < scalar : scalar ; g1 : g1 ; g1_opt : g1_opt ; base_field : f > )\n Type.t\n -> a\n -> unit =\n fun ~absorb_field ~absorb_scalar ~g1_to_field_elements ~mask_g1_opt ty t ->\n match ty with\n | Type.PC ->\n List.iter ~f:absorb_field (g1_to_field_elements t)\n | Type.Field ->\n absorb_field t\n | Type.Scalar ->\n absorb_scalar t\n | Type.Without_degree_bound ->\n Array.iter\n ~f:(Fn.compose (List.iter ~f:absorb_field) g1_to_field_elements)\n t\n | Type.With_degree_bound ->\n let Pickles_types.Plonk_types.Poly_comm.With_degree_bound.\n { unshifted; shifted } =\n t\n in\n let absorb x =\n absorb ~absorb_field ~absorb_scalar ~g1_to_field_elements ~mask_g1_opt\n Type.PC (mask_g1_opt x)\n in\n Array.iter unshifted ~f:absorb ;\n absorb shifted\n | ty1 :: ty2 ->\n let absorb t =\n absorb t ~absorb_field ~absorb_scalar ~g1_to_field_elements ~mask_g1_opt\n in\n let t1, t2 = t in\n absorb ty1 t1 ; absorb ty2 t2\n\n(** [ones_vector (module I) ~first_zero n] returns a vector of booleans of\n length n which is all ones until position [first_zero], at which it is zero,\n and zero thereafter. *)\nlet ones_vector :\n type f n.\n first_zero:f Snarky_backendless.Cvar.t\n -> (module Snarky_backendless.Snark_intf.Run with type field = f)\n -> n Nat.t\n -> (f Snarky_backendless.Cvar.t Snarky_backendless.Boolean.t, n) Vector.t =\n fun ~first_zero (module Impl) n ->\n let open Impl in\n let rec go :\n type m. Boolean.var -> int -> m Nat.t -> (Boolean.var, m) Vector.t =\n fun value i m ->\n match[@warning \"-45\"] m with\n | Pickles_types.Nat.Z ->\n Pickles_types.Vector.[]\n | Pickles_types.Nat.S m ->\n let value =\n Boolean.(value && not (Field.equal first_zero (Field.of_int i)))\n in\n Pickles_types.Vector.(value :: go value (i + 1) m)\n in\n go Boolean.true_ 0 n\n\nlet seal (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n (x : Impl.Field.t) : Impl.Field.t =\n let open Impl in\n match Field.to_constant_and_terms x with\n | None, [ (x, i) ] when Field.Constant.(equal x one) ->\n Snarky_backendless.Cvar.Var i\n | Some c, [] ->\n Field.constant c\n | _ ->\n let y = exists Field.typ ~compute:As_prover.(fun () -> read_var x) in\n Field.Assert.equal x y ; y\n\nlet lowest_128_bits (type f) ~constrain_low_bits ~assert_128_bits\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f) x =\n let open Impl in\n let pow2 =\n (* 2 ^ n *)\n let rec pow2 x i =\n if i = 0 then x else pow2 Field.Constant.(x + x) (i - 1)\n in\n fun n -> pow2 Field.Constant.one n\n in\n let lo, hi =\n exists\n Typ.(field * field)\n ~compute:(fun () ->\n let lo, hi =\n Field.Constant.unpack (As_prover.read_var x)\n |> Fn.flip List.split_n 128\n in\n (Field.Constant.project lo, Field.Constant.project hi) )\n in\n assert_128_bits hi ;\n if constrain_low_bits then assert_128_bits lo ;\n Field.Assert.equal x Field.(lo + scale hi (pow2 128)) ;\n lo\n","module SC = Scalar_challenge\n\ntype t = Import.Challenge.Constant.t Import.Scalar_challenge.t\n\nmodule Wrap_inner_curve = struct\n let base : Backend.Tock.Field.t = Pasta_bindings.Vesta.endo_base ()\n\n let scalar : Backend.Tick.Field.t = Pasta_bindings.Vesta.endo_scalar ()\n\n let to_field (t : t) : Backend.Tick.Field.t =\n SC.to_field_constant (module Backend.Tick.Field) ~endo:scalar t\nend\n\nmodule Step_inner_curve = struct\n let base : Backend.Tick.Field.t = Pasta_bindings.Pallas.endo_base ()\n\n let scalar : Backend.Tock.Field.t = Pasta_bindings.Pallas.endo_scalar ()\n\n let to_field (t : t) : Backend.Tock.Field.t =\n SC.to_field_constant (module Backend.Tock.Field) ~endo:scalar t\nend\n","open Core_kernel\nopen Pickles_types\nopen Import\nopen Backend\n\nmodule Max_degree = struct\n let step_log2 = Nat.to_int Backend.Tick.Rounds.n\n\n let step = 1 lsl step_log2\n\n let wrap_log2 = Nat.to_int Backend.Tock.Rounds.n\n\n let _wrap = 1 lsl wrap_log2\nend\n\nlet tick_shifts, tock_shifts =\n let mk g =\n let f =\n Memo.general ~cache_size_bound:20 ~hashable:Int.hashable (fun log2_size ->\n g log2_size )\n in\n fun ~log2_size -> f log2_size\n in\n ( mk Kimchi_bindings.Protocol.VerifierIndex.Fp.shifts\n , mk Kimchi_bindings.Protocol.VerifierIndex.Fq.shifts )\n\nlet wrap_domains ~proofs_verified =\n let h =\n match proofs_verified with 0 -> 13 | 1 -> 14 | 2 -> 15 | _ -> assert false\n in\n { Domains.h = Domain.Pow_2_roots_of_unity h }\n\nlet actual_wrap_domain_size ~log_2_domain_size =\n let d =\n match log_2_domain_size with\n | 13 ->\n 0\n | 14 ->\n 1\n | 15 ->\n 2\n | _ ->\n assert false\n in\n Pickles_base.Proofs_verified.of_int d\n\nlet hash_messages_for_next_step_proof ~app_state\n (t : _ Types.Step.Proof_state.Messages_for_next_step_proof.t) =\n let g (x, y) = [ x; y ] in\n Tick_field_sponge.digest Tick_field_sponge.params\n (Types.Step.Proof_state.Messages_for_next_step_proof.to_field_elements t ~g\n ~comm:(fun (x : Tock.Curve.Affine.t) -> Array.of_list (g x))\n ~app_state )\n\nlet dlog_pcs_batch (type nat proofs_verified total)\n ((without_degree_bound, _pi) :\n total Nat.t * (proofs_verified, nat, total) Nat.Adds.t ) =\n Pcs_batch.create ~without_degree_bound ~with_degree_bound:[]\n\nlet when_profiling profiling default =\n match Option.map (Sys.getenv_opt \"PICKLES_PROFILING\") ~f:String.lowercase with\n | None | Some (\"0\" | \"false\") ->\n default\n | Some _ ->\n profiling\n\nlet time lab f =\n when_profiling\n (fun () ->\n let start = Time.now () in\n let x = f () in\n let stop = Time.now () in\n printf \"%s: %s\\n%!\" lab (Time.Span.to_string_hum (Time.diff stop start)) ;\n x )\n f ()\n\nlet bits_to_bytes bits =\n let byte_of_bits bs =\n List.foldi bs ~init:0 ~f:(fun i acc b ->\n if b then acc lor (1 lsl i) else acc )\n |> Char.of_int_exn\n in\n List.map (List.groupi bits ~break:(fun i _ _ -> i mod 8 = 0)) ~f:byte_of_bits\n |> String.of_char_list\n\nlet group_map m ~a ~b =\n let params = Group_map.Params.create m { a; b } in\n stage (fun x -> Group_map.to_group m ~params x)\n\nmodule Shifts = struct\n let tock2 : Backend.Tock.Field.t Shifted_value.Type2.Shift.t =\n Shifted_value.Type2.Shift.create (module Backend.Tock.Field)\n\n let tick1 : Backend.Tick.Field.t Shifted_value.Type1.Shift.t =\n Shifted_value.Type1.Shift.create (module Backend.Tick.Field)\nend\n\nmodule Lookup_parameters = struct\n let tick_zero : _ Composition_types.Zero_values.t =\n Composition_types.Zero_values.\n { value =\n { challenge = Challenge.Constant.zero\n ; scalar =\n Shifted_value.Type2.Shifted_value Impls.Wrap.Field.Constant.zero\n }\n ; var =\n { challenge = Impls.Step.Field.zero\n ; scalar =\n Shifted_value.Type2.Shifted_value\n (Impls.Step.Field.zero, Impls.Step.Boolean.false_)\n }\n }\n\n let tock_zero : _ Composition_types.Zero_values.t =\n Composition_types.Zero_values.\n { value =\n { challenge = Challenge.Constant.zero\n ; scalar =\n Shifted_value.Type2.Shifted_value Impls.Wrap.Field.Constant.zero\n }\n ; var =\n { challenge = Impls.Wrap.Field.zero\n ; scalar = Shifted_value.Type2.Shifted_value Impls.Wrap.Field.zero\n }\n }\nend\n\nlet finite_exn : 'a Kimchi_types.or_infinity -> 'a * 'a = function\n | Kimchi_types.Finite (x, y) ->\n (x, y)\n | Kimchi_types.Infinity ->\n invalid_arg \"finite_exn\"\n\nlet or_infinite_conv : ('a * 'a) Or_infinity.t -> 'a Kimchi_types.or_infinity =\n function\n | Finite (x, y) ->\n Finite (x, y)\n | Infinity ->\n Infinity\n\nmodule Ipa = struct\n open Backend\n\n (* TODO: Make all this completely generic over backend *)\n\n let compute_challenge ~endo_to_field _ c = endo_to_field c\n\n let compute_challenges ~endo_to_field field chals =\n Vector.map chals ~f:(fun prechallenge ->\n Bulletproof_challenge.pack prechallenge\n |> compute_challenge field ~endo_to_field )\n\n module Wrap = struct\n let field =\n (module Tock.Field : Kimchi_backend.Field.S with type t = Tock.Field.t)\n\n let endo_to_field = Endo.Step_inner_curve.to_field\n\n let compute_challenge c = compute_challenge field ~endo_to_field c\n\n let compute_challenges cs = compute_challenges field ~endo_to_field cs\n\n let compute_sg chals =\n let comm =\n Kimchi_bindings.Protocol.SRS.Fq.b_poly_commitment\n (Backend.Tock.Keypair.load_urs ())\n (Pickles_types.Vector.to_array (compute_challenges chals))\n in\n comm.unshifted.(0) |> finite_exn\n end\n\n module Step = struct\n let field =\n (module Tick.Field : Kimchi_backend.Field.S with type t = Tick.Field.t)\n\n let endo_to_field = Endo.Wrap_inner_curve.to_field\n\n let compute_challenge c = compute_challenge field ~endo_to_field c\n\n let compute_challenges cs = compute_challenges field ~endo_to_field cs\n\n let compute_sg chals =\n let comm =\n Kimchi_bindings.Protocol.SRS.Fp.b_poly_commitment\n (Backend.Tick.Keypair.load_urs ())\n (Pickles_types.Vector.to_array (compute_challenges chals))\n in\n comm.unshifted.(0) |> finite_exn\n\n let accumulator_check comm_chals =\n let chals =\n Array.concat\n @@ List.map comm_chals ~f:(fun (_, chals) -> Vector.to_array chals)\n in\n let comms =\n Array.of_list_map comm_chals ~f:(fun (comm, _) ->\n Or_infinity.Finite comm )\n in\n let urs = Backend.Tick.Keypair.load_urs () in\n Promise.run_in_thread (fun () ->\n Kimchi_bindings.Protocol.SRS.Fp.batch_accumulator_check urs\n (Array.map comms ~f:or_infinite_conv)\n chals )\n end\nend\n\nlet tock_unpadded_public_input_of_statement ~feature_flags prev_statement =\n let input =\n let (T (typ, _conv, _conv_inv)) = Impls.Wrap.input ~feature_flags () in\n Impls.Wrap.generate_public_input typ prev_statement\n in\n List.init\n (Backend.Tock.Field.Vector.length input)\n ~f:(Backend.Tock.Field.Vector.get input)\n\nlet tock_public_input_of_statement ~feature_flags s =\n tock_unpadded_public_input_of_statement ~feature_flags s\n\nlet tick_public_input_of_statement ~max_proofs_verified\n (prev_statement : _ Types.Step.Statement.t) =\n let input =\n let (T (input, _conv, _conv_inv)) =\n Impls.Step.input ~proofs_verified:max_proofs_verified\n ~wrap_rounds:Tock.Rounds.n\n in\n Impls.Step.generate_public_input input prev_statement\n in\n List.init\n (Backend.Tick.Field.Vector.length input)\n ~f:(Backend.Tick.Field.Vector.get input)\n\nlet ft_comm ~add:( + ) ~scale ~endoscale:_ ~negate\n ~verification_key:(m : _ Plonk_verification_key_evals.t) ~alpha:_\n ~(plonk : _ Types.Wrap.Proof_state.Deferred_values.Plonk.In_circuit.t)\n ~t_comm =\n let ( * ) x g = scale g x in\n let _, [ sigma_comm_last ] =\n Vector.split m.sigma_comm (snd (Plonk_types.Permuts_minus_1.add Nat.N1.n))\n in\n let f_comm = List.reduce_exn ~f:( + ) [ plonk.perm * sigma_comm_last ] in\n let chunked_t_comm =\n let n = Array.length t_comm in\n let res = ref t_comm.(n - 1) in\n for i = n - 2 downto 0 do\n res := t_comm.(i) + scale !res plonk.zeta_to_srs_length\n done ;\n !res\n in\n f_comm + chunked_t_comm\n + negate (scale chunked_t_comm plonk.zeta_to_domain_size)\n\nlet combined_evaluation (type f)\n (module Impl : Snarky_backendless.Snark_intf.Run with type field = f)\n ~(xi : Impl.Field.t) (without_degree_bound : _ list) =\n let open Impl in\n let open Field in\n let mul_and_add ~(acc : Field.t) ~(xi : Field.t)\n (fx : (Field.t, Boolean.var) Opt.t) : Field.t =\n match fx with\n | Nothing ->\n acc\n | Just fx ->\n fx + (xi * acc)\n | Maybe (b, fx) ->\n Field.if_ b ~then_:(fx + (xi * acc)) ~else_:acc\n in\n with_label __LOC__ (fun () ->\n Pcs_batch.combine_split_evaluations ~mul_and_add\n ~init:(function\n | Just x ->\n x\n | Nothing ->\n Field.zero\n | Maybe (b, x) ->\n (b :> Field.t) * x )\n ~xi without_degree_bound )\n","module D = Composition_types.Digest\nopen Core_kernel\n\nmodule Rounds = struct\n let rounds_full = 55\n\n let initial_ark = false\n\n let rounds_partial = 0\nend\n\nlet high_entropy_bits = 128\n\nmodule type S = sig\n module Inputs : sig\n include module type of Rounds\n\n module Field : Kimchi_backend_common.Field.S\n\n type field := Field.t\n\n val to_the_alpha : field -> field\n\n val alpha : int\n\n module Operations : Sponge.Intf.Operations with type Field.t = field\n end\n\n type field := Inputs.Field.t\n\n (* The name does not really reflect the behavior *and* is somewhat confusing w.r.t\n Inputs.Field. This is almost Sponge.Intf.Sponge *)\n module Field : sig\n type f := Sponge.Poseidon(Inputs).Field.t\n\n type params := f Sponge.Params.t\n\n type state := f Sponge.State.t\n\n type t = f Sponge.t (* TODO: Make this type abstract *)\n\n val create : ?init:state -> params -> t\n\n val make :\n state:state -> params:params -> sponge_state:Sponge.sponge_state -> t\n\n val absorb : t -> f -> unit\n\n val squeeze : t -> f\n\n val copy : t -> t\n\n val state : t -> state\n end\n\n (* TODO: Resuce module types of Sponge.Intf.Sponge *)\n module Bits : sig\n type t\n\n val create : ?init:field Sponge.State.t -> field Sponge.Params.t -> t\n\n val absorb : t -> field -> unit\n\n val squeeze : t -> length:int -> bool list\n\n val copy : t -> t\n\n val state : t -> field Sponge.State.t\n\n val squeeze_field : t -> field\n end\n\n val digest :\n field Sponge.Params.t\n -> Inputs.Field.t Core_kernel.Array.t\n -> (int64, Composition_types.Digest.Limbs.n) Pickles_types.Vector.t\nend\n\nmodule Make (Field : Kimchi_backend.Field.S) :\n S with module Inputs.Field = Field = struct\n module Inputs = struct\n include Rounds\n module Field = Field\n\n let alpha = 7\n\n (* x^7 *)\n let to_the_alpha x =\n (* square |> mul x |> square |> mul x *)\n (* 7 = 1 + 2 (1 + 2) *)\n let open Field in\n let res = square x in\n res *= x ;\n (* x^3 *)\n Mutable.square res ;\n (* x^6 *)\n res *= x ;\n (* x^7 *)\n res\n\n module Operations = struct\n module Field = Field\n\n let add_assign ~state i x = Field.(state.(i) += x)\n\n let apply_affine_map (matrix, constants) v =\n let dotv row =\n Array.reduce_exn (Array.map2_exn row v ~f:Field.( * )) ~f:Field.( + )\n in\n let res = Array.map matrix ~f:dotv in\n for i = 0 to Array.length res - 1 do\n Field.(res.(i) += constants.(i))\n done ;\n res\n\n let copy a = Array.map a ~f:(fun x -> Field.(x + zero))\n end\n end\n\n module Field = Sponge.Make_sponge (Sponge.Poseidon (Inputs))\n\n module Bits =\n Sponge.Bit_sponge.Make\n (Bool)\n (struct\n include Inputs.Field\n\n let high_entropy_bits = high_entropy_bits\n\n let finalize_discarded = ignore\n end)\n (Inputs.Field)\n (Field)\n\n let digest params elts =\n let sponge = Bits.create params in\n Array.iter elts ~f:(Bits.absorb sponge) ;\n Bits.squeeze_field sponge |> Inputs.Field.to_bits |> D.Constant.of_bits\nend\n\nmodule Test\n (Impl : Snarky_backendless.Snark_intf.Run)\n (S_constant : Sponge.Intf.Sponge\n with module Field := Impl.Field.Constant\n and module State := Sponge.State\n and type input := Impl.field\n and type digest := Impl.field)\n (S_checked : Sponge.Intf.Sponge\n with module Field := Impl.Field\n and module State := Sponge.State\n and type input := Impl.Field.t\n and type digest := Impl.Field.t) =\nstruct\n open Impl\n\n let test params : unit =\n let n = 10 in\n let a = Array.init n ~f:(fun _ -> Field.Constant.random ()) in\n Impl.Internal_Basic.Test.test_equal ~sexp_of_t:Field.Constant.sexp_of_t\n ~equal:Field.Constant.equal\n (Typ.array ~length:n Field.typ)\n Field.typ\n (fun a ->\n make_checked (fun () ->\n let s =\n S_checked.create (Sponge.Params.map ~f:Field.constant params)\n in\n Array.iter a ~f:(S_checked.absorb s) ;\n S_checked.squeeze s ) )\n (fun a ->\n let s = S_constant.create params in\n Array.iter a ~f:(S_constant.absorb s) ;\n S_constant.squeeze s )\n a\nend\n","include Make_sponge.Make (Backend.Tick.Field)\n\nlet params = Kimchi_pasta_basic.poseidon_params_fp\n","open Core_kernel\nopen Pickles_types\nopen Backend\nopen Composition_types\nopen Common\n\nlet _wrap_domains = Common.wrap_domains\n\nlet evals =\n lazy\n (let open Plonk_types in\n let e =\n Evals.map Evaluation_lengths.default ~f:(fun n ->\n let a () = Array.create ~len:n (Ro.tock ()) in\n (a (), a ()) )\n in\n let ex =\n { All_evals.With_public_input.evals = e\n ; public_input = (Ro.tock (), Ro.tock ())\n }\n in\n { All_evals.ft_eval1 = Ro.tock (); evals = ex })\n\nlet evals_combined =\n lazy\n (Plonk_types.All_evals.map (Lazy.force evals) ~f1:Fn.id\n ~f2:(Array.reduce_exn ~f:Backend.Tock.Field.( + )) )\n\nmodule Ipa = struct\n module Wrap = struct\n let challenges =\n Vector.init Tock.Rounds.n ~f:(fun _ ->\n let prechallenge = Ro.scalar_chal () in\n { Bulletproof_challenge.prechallenge } )\n\n let challenges_computed =\n lazy\n (Vector.map challenges ~f:(fun { prechallenge } : Tock.Field.t ->\n Ipa.Wrap.compute_challenge prechallenge ) )\n\n let sg =\n lazy (time \"dummy wrap sg\" (fun () -> Ipa.Wrap.compute_sg challenges))\n end\n\n module Step = struct\n let challenges =\n Vector.init Tick.Rounds.n ~f:(fun _ ->\n let prechallenge = Ro.scalar_chal () in\n { Bulletproof_challenge.prechallenge } )\n\n let challenges_computed =\n lazy\n (Vector.map challenges ~f:(fun { prechallenge } : Tick.Field.t ->\n Ipa.Step.compute_challenge prechallenge ) )\n\n let sg =\n lazy (time \"dummy wrap sg\" (fun () -> Ipa.Step.compute_sg challenges))\n end\nend\n","open Core_kernel\nopen Pickles_types\nopen Hlist\nopen Common\nopen Import\nopen Types\nopen Wrap_main_inputs\nopen Impl\nmodule SC = Scalar_challenge\n\n(* Let's define an OCaml encoding for inductive NP sets. Let A be an inductive NP set.\n\n To encode A, we require types [var(A)] and [value(A)] corresponding to\n \\mathcal{U}(A) the underlying set of A.\n\n Let r_1, ..., r_n be the inductive rules of A.\n For each i, let (A_{i, 1}, ..., A_{i, k_i}) be the predecessor inductive sets for rule i.\n\n We define a few type level lists.\n\n - For each rule r_i,\n [prev_vars(r_i) := var(A_{i, 1}) * (var(A_{i, 2}) * (... * var(A_{i, k_i})))]\n [prev_values(r_i) := value(A_{i, 1}) * (value(A_{i, 2}) * (... * value(A_{i, k_i})))]\n\n - [prev_varss(A) := map prev_vars (r_1, ..., r_n)]\n - [prev_valuess(A) := map prev_values (r_1, ..., r_n)]\n\n We use corresponding type variable names throughout this file.\n*)\n\nmodule Old_bulletproof_chals = struct\n type t =\n | T :\n 'max_local_max_proofs_verified Nat.t\n * 'max_local_max_proofs_verified Challenges_vector.t\n -> t\nend\n\nlet pack_statement max_proofs_verified t =\n let open Types.Step in\n Spec.pack\n (module Impl)\n (Statement.spec max_proofs_verified Backend.Tock.Rounds.n)\n (Statement.to_data t)\n\nlet shifts ~log2_size = Common.tock_shifts ~log2_size\n\nlet domain_generator ~log2_size =\n Backend.Tock.Field.domain_generator ~log2_size |> Impl.Field.constant\n\nlet _split_field_typ : (Field.t * Boolean.var, Field.Constant.t) Typ.t =\n Typ.transport\n Typ.(field * Boolean.typ)\n ~there:(fun (x : Field.Constant.t) ->\n let n = Bigint.of_field x in\n let is_odd = Bigint.test_bit n 0 in\n let y = Field.Constant.((if is_odd then x - one else x) / of_int 2) in\n (y, is_odd) )\n ~back:(fun (hi, is_odd) ->\n let open Field.Constant in\n let x = hi + hi in\n if is_odd then x + one else x )\n\n(* Split a field element into its high bits (packed) and the low bit.\n\n It does not check that the \"high bits\" actually fit into n - 1 bits,\n this is deferred to a call to scale_fast2, which performs this check.\n*)\nlet split_field (x : Field.t) : Field.t * Boolean.var =\n let ((y, is_odd) as res) =\n exists\n Typ.(field * Boolean.typ)\n ~compute:(fun () ->\n let x = As_prover.read_var x in\n let n = Bigint.of_field x in\n let is_odd = Bigint.test_bit n 0 in\n let y = Field.Constant.((if is_odd then x - one else x) / of_int 2) in\n (y, is_odd) )\n in\n Field.(Assert.equal ((of_int 2 * y) + (is_odd :> t)) x) ;\n res\n\n(* The SNARK function for wrapping any proof coming from the given set of keys *)\nlet wrap_main\n (type max_proofs_verified branches prev_varss max_local_max_proofs_verifieds)\n ~feature_flags\n (full_signature :\n ( max_proofs_verified\n , branches\n , max_local_max_proofs_verifieds )\n Full_signature.t ) (pi_branches : (prev_varss, branches) Hlist.Length.t)\n (step_keys :\n ( ( Wrap_main_inputs.Inner_curve.Constant.t\n , Wrap_main_inputs.Inner_curve.Constant.t option )\n Wrap_verifier.index'\n , branches )\n Vector.t\n Lazy.t ) (step_widths : (int, branches) Vector.t)\n (step_domains : (Domains.t, branches) Vector.t) ~srs\n (max_proofs_verified :\n (module Nat.Add.Intf with type n = max_proofs_verified) ) :\n (max_proofs_verified, max_local_max_proofs_verifieds) Requests.Wrap.t\n * ( ( _\n , _\n , _ Shifted_value.Type1.t\n , _\n , _\n , _\n , _\n , _\n , _\n , _\n , _ )\n Types.Wrap.Statement.In_circuit.t\n -> unit ) =\n Timer.clock __LOC__ ;\n let module Max_proofs_verified = ( val max_proofs_verified : Nat.Add.Intf\n with type n = max_proofs_verified )\n in\n let T = Max_proofs_verified.eq in\n let branches = Hlist.Length.to_nat pi_branches in\n Timer.clock __LOC__ ;\n let (module Req) =\n Requests.Wrap.(\n (create () : (max_proofs_verified, max_local_max_proofs_verifieds) t))\n in\n Timer.clock __LOC__ ;\n let { Full_signature.padded = _; maxes = (module Max_widths_by_slot) } =\n full_signature\n in\n Timer.clock __LOC__ ;\n let main\n ({ proof_state =\n { deferred_values =\n { plonk\n ; xi\n ; combined_inner_product\n ; b\n ; branch_data\n ; bulletproof_challenges\n }\n ; sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof = messages_for_next_wrap_proof_digest\n }\n ; messages_for_next_step_proof = _\n } :\n ( _\n , _\n , _ Shifted_value.Type1.t\n , _\n , _\n , _\n , _\n , _\n , _\n , _\n , Field.t )\n Types.Wrap.Statement.In_circuit.t ) =\n let logger = Internal_tracing_context_logger.get () in\n with_label __LOC__ (fun () ->\n let which_branch' =\n exists\n (Typ.transport Field.typ ~there:Field.Constant.of_int\n ~back:(fun _ -> failwith \"unimplemented\") )\n ~request:(fun () -> Req.Which_branch)\n in\n let which_branch =\n Wrap_verifier.One_hot_vector.of_index which_branch' ~length:branches\n in\n let actual_proofs_verified_mask =\n Util.ones_vector\n (module Impl)\n ~first_zero:\n (Wrap_verifier.Pseudo.choose\n (which_branch, step_widths)\n ~f:Field.of_int )\n Max_proofs_verified.n\n |> Vector.rev\n in\n let domain_log2 =\n Wrap_verifier.Pseudo.choose\n ( which_branch\n , Vector.map ~f:(fun ds -> Domain.log2_size ds.h) step_domains )\n ~f:Field.of_int\n in\n let () =\n with_label __LOC__ (fun () ->\n (* Check that the branch_data public-input is correct *)\n Branch_data.Checked.pack\n (module Impl)\n { proofs_verified_mask =\n Vector.extend_front_exn actual_proofs_verified_mask Nat.N2.n\n Boolean.false_\n ; domain_log2\n }\n |> Field.Assert.equal branch_data )\n in\n let prev_proof_state =\n with_label __LOC__ (fun () ->\n let open Types.Step.Proof_state in\n let typ =\n typ\n (module Impl)\n ~assert_16_bits:(Wrap_verifier.assert_n_bits ~n:16)\n (Vector.init Max_proofs_verified.n ~f:(fun _ ->\n Plonk_types.Features.none ) )\n (Shifted_value.Type2.typ Field.typ)\n in\n exists typ ~request:(fun () -> Req.Proof_state) )\n in\n let step_plonk_index =\n with_label __LOC__ (fun () ->\n Wrap_verifier.choose_key which_branch\n (Vector.map (Lazy.force step_keys)\n ~f:\n (Plonk_verification_key_evals.Step.map\n ~f:Inner_curve.constant ~f_opt:(function\n | None ->\n Opt.nothing\n | Some x ->\n Opt.just (Inner_curve.constant x) ) ) ) )\n in\n let prev_step_accs =\n with_label __LOC__ (fun () ->\n exists (Vector.typ Inner_curve.typ Max_proofs_verified.n)\n ~request:(fun () -> Req.Step_accs) )\n in\n let old_bp_chals =\n with_label __LOC__ (fun () ->\n let typ =\n let module T =\n H1.Typ (Impls.Wrap) (Nat) (Challenges_vector)\n (Challenges_vector.Constant)\n (struct\n let f (type n) (n : n Nat.t) =\n Vector.typ\n (Vector.typ Field.typ Backend.Tock.Rounds.n)\n n\n end)\n in\n T.f Max_widths_by_slot.maxes\n in\n let module Z = H1.Zip (Nat) (Challenges_vector) in\n let module M =\n H1.Map\n (H1.Tuple2 (Nat) (Challenges_vector))\n (E01 (Old_bulletproof_chals))\n (struct\n let f (type n)\n ((n, v) : n H1.Tuple2(Nat)(Challenges_vector).t) =\n Old_bulletproof_chals.T (n, v)\n end)\n in\n let module V = H1.To_vector (Old_bulletproof_chals) in\n Z.f Max_widths_by_slot.maxes\n (exists typ ~request:(fun () -> Req.Old_bulletproof_challenges))\n |> M.f\n |> V.f Max_widths_by_slot.length )\n in\n let new_bulletproof_challenges =\n with_label __LOC__ (fun () ->\n let evals =\n let ty =\n let ty =\n Plonk_types.All_evals.typ (module Impl) feature_flags\n in\n Vector.typ ty Max_proofs_verified.n\n in\n exists ty ~request:(fun () -> Req.Evals)\n in\n let chals =\n let wrap_domains =\n let all_possible_domains =\n Wrap_verifier.all_possible_domains ()\n in\n let wrap_domain_indices =\n exists (Vector.typ Field.typ Max_proofs_verified.n)\n ~request:(fun () -> Req.Wrap_domain_indices)\n in\n Vector.map wrap_domain_indices ~f:(fun index ->\n let which_branch =\n Wrap_verifier.One_hot_vector.of_index index\n ~length:Wrap_verifier.num_possible_domains\n in\n Wrap_verifier.Pseudo.Domain.to_domain ~shifts\n ~domain_generator\n (which_branch, all_possible_domains) )\n in\n Vector.mapn\n [ (* This is padded to max_proofs_verified for the benefit of wrapping with dummy unfinalized proofs *)\n prev_proof_state.unfinalized_proofs\n ; old_bp_chals\n ; evals\n ; wrap_domains\n ]\n ~f:(fun\n [ { deferred_values\n ; sponge_digest_before_evaluations\n ; should_finalize\n }\n ; old_bulletproof_challenges\n ; evals\n ; wrap_domain\n ]\n ->\n let sponge =\n let s = Sponge.create sponge_params in\n Sponge.absorb s sponge_digest_before_evaluations ;\n s\n in\n\n (* the type of the local max proofs-verified depends on\n which kind of step proof we are wrapping. *)\n (* For each i in [0..max_proofs_verified-1], we have\n max_local_max_proofs_verified, which is the largest\n Local_max_proofs_verified which is the i^th inner proof of a step proof.\n\n Need to compute this value from the which_branch.\n *)\n let (T\n ( _max_local_max_proofs_verified\n , old_bulletproof_challenges ) ) =\n old_bulletproof_challenges\n in\n let old_bulletproof_challenges =\n Wrap_hack.Checked.pad_challenges\n old_bulletproof_challenges\n in\n let finalized, chals =\n with_label __LOC__ (fun () ->\n Wrap_verifier.finalize_other_proof\n (module Wrap_hack.Padded_length)\n ~domain:(wrap_domain :> _ Plonk_checks.plonk_domain)\n ~sponge ~old_bulletproof_challenges deferred_values\n evals )\n in\n Boolean.(Assert.any [ finalized; not should_finalize ]) ;\n chals )\n in\n chals )\n in\n let prev_statement =\n let prev_messages_for_next_wrap_proof =\n Vector.map2 prev_step_accs old_bp_chals\n ~f:(fun sacc (T (max_local_max_proofs_verified, chals)) ->\n Wrap_hack.Checked.hash_messages_for_next_wrap_proof\n max_local_max_proofs_verified\n { challenge_polynomial_commitment = sacc\n ; old_bulletproof_challenges = chals\n } )\n in\n { Types.Step.Statement.messages_for_next_wrap_proof =\n prev_messages_for_next_wrap_proof\n ; proof_state = prev_proof_state\n }\n in\n let openings_proof =\n let shift = Shifts.tick1 in\n exists\n (Plonk_types.Openings.Bulletproof.typ\n ( Typ.transport Wrap_verifier.Other_field.Packed.typ\n ~there:(fun x ->\n (* When storing, make it a shifted value *)\n match\n Shifted_value.Type1.of_field\n (module Backend.Tick.Field)\n ~shift x\n with\n | Shifted_value x ->\n x )\n ~back:(fun x ->\n Shifted_value.Type1.to_field\n (module Backend.Tick.Field)\n ~shift (Shifted_value x) )\n (* When reading, unshift *)\n |> Typ.transport_var\n (* For the var, we just wrap the now shifted underlying value. *)\n ~there:(fun (Shifted_value.Type1.Shifted_value x) -> x)\n ~back:(fun x -> Shifted_value x) )\n Inner_curve.typ\n ~length:(Nat.to_int Backend.Tick.Rounds.n) )\n ~request:(fun () -> Req.Openings_proof)\n in\n let ( sponge_digest_before_evaluations_actual\n , (`Success bulletproof_success, bulletproof_challenges_actual) ) =\n let messages =\n with_label __LOC__ (fun () ->\n exists\n (Plonk_types.Messages.typ\n (module Impl)\n Inner_curve.typ ~bool:Boolean.typ feature_flags\n ~dummy:Inner_curve.Params.one\n ~commitment_lengths:Commitment_lengths.default )\n ~request:(fun () -> Req.Messages) )\n in\n let sponge = Wrap_verifier.Opt.create sponge_params in\n with_label __LOC__ (fun () ->\n [%log internal] \"Wrap_verifier_incrementally_verify_proof\" ;\n let res =\n Wrap_verifier.incrementally_verify_proof max_proofs_verified\n ~actual_proofs_verified_mask ~step_domains\n ~verification_key:step_plonk_index ~srs ~xi ~sponge\n ~public_input:\n (Array.map\n (pack_statement Max_proofs_verified.n prev_statement)\n ~f:(function\n | `Field (Shifted_value x) ->\n `Field (split_field x)\n | `Packed_bits (x, n) ->\n `Packed_bits (x, n) ) )\n ~sg_old:prev_step_accs\n ~advice:{ b; combined_inner_product }\n ~messages ~which_branch ~openings_proof ~plonk\n in\n [%log internal] \"Wrap_verifier_incrementally_verify_proof_done\" ;\n res )\n in\n with_label __LOC__ (fun () ->\n Boolean.Assert.is_true bulletproof_success ) ;\n with_label __LOC__ (fun () ->\n Field.Assert.equal messages_for_next_wrap_proof_digest\n (Wrap_hack.Checked.hash_messages_for_next_wrap_proof\n Max_proofs_verified.n\n { Types.Wrap.Proof_state.Messages_for_next_wrap_proof\n .challenge_polynomial_commitment =\n openings_proof.challenge_polynomial_commitment\n ; old_bulletproof_challenges = new_bulletproof_challenges\n } ) ) ;\n with_label __LOC__ (fun () ->\n Field.Assert.equal sponge_digest_before_evaluations\n sponge_digest_before_evaluations_actual ) ;\n Array.iter2_exn bulletproof_challenges_actual\n (Vector.to_array bulletproof_challenges)\n ~f:(fun\n { prechallenge = { inner = x1 } }\n ({ prechallenge = { inner = x2 } } :\n _ SC.t Bulletproof_challenge.t )\n -> with_label __LOC__ (fun () -> Field.Assert.equal x1 x2) ) ;\n () )\n in\n Timer.clock __LOC__ ;\n ((module Req), main)\n","open Pickles_types\n\nlet default =\n let one = 1 in\n { Plonk_types.Messages.Poly.w =\n Vector.init Plonk_types.Columns.n ~f:(fun _ -> one)\n ; z = one\n ; t = 7\n }\n","let default =\n let one = 1 in\n let open Pickles_types in\n let open Plonk_types in\n Evals.\n { w = Vector.init Columns.n ~f:(fun _ -> one)\n ; coefficients = Vector.init Columns.n ~f:(fun _ -> one)\n ; z = one\n ; s = Vector.init Permuts_minus_1.n ~f:(fun _ -> one)\n ; generic_selector = one\n ; poseidon_selector = one\n ; complete_add_selector = one\n ; mul_selector = one\n ; emul_selector = one\n ; endomul_scalar_selector = one\n ; (* FIXME *)\n range_check0_selector = None\n ; range_check1_selector = None\n ; foreign_field_add_selector = None\n ; foreign_field_mul_selector = None\n ; xor_selector = None\n ; rot_selector = None\n ; lookup_aggregation = None\n ; lookup_table = None\n ; lookup_sorted = Vector.init Nat.N5.n ~f:(fun _ -> None)\n ; runtime_lookup_table = None\n ; runtime_lookup_table_selector = None\n ; xor_lookup_selector = None\n ; lookup_gate_lookup_selector = None\n ; range_check_lookup_selector = None\n ; foreign_field_mul_lookup_selector = None\n }\n","open Core_kernel\nopen Backend\nopen Import\n\nlet bits_random_oracle =\n let h = Digestif.blake2s 32 in\n fun ~length s ->\n Digestif.digest_string h s |> Digestif.to_raw_string h |> String.to_list\n |> List.concat_map ~f:(fun c ->\n let c = Char.to_int c in\n List.init 8 ~f:(fun i -> (c lsr i) land 1 = 1) )\n |> fun a -> List.take a length\n\nlet ro lab length f =\n let r = ref 0 in\n fun () ->\n incr r ;\n f (bits_random_oracle ~length (sprintf \"%s_%d\" lab !r))\n\nlet tock = ro \"fq\" Tock.Field.size_in_bits Tock.Field.of_bits\n\nlet tick = ro \"fp\" Tick.Field.size_in_bits Tick.Field.of_bits\n\nlet chal = ro \"chal\" Challenge.Constant.length Challenge.Constant.of_bits\n\nlet scalar_chal () = Scalar_challenge.create (chal ())\n","module P = Proof\n\nmodule type Statement_intf = Intf.Statement\n\nmodule type Statement_var_intf = Intf.Statement_var\n\nmodule type Statement_value_intf = Intf.Statement_value\n\nmodule SC = Scalar_challenge\nopen Core_kernel\nopen Async_kernel\nopen Import\nopen Pickles_types\nopen Poly_types\nopen Hlist\nopen Backend\n\nexception Return_digest of Md5.t\n\nlet profile_constraints = false\n\nlet verify_promise = Verify.verify\n\nopen Kimchi_backend\nmodule Proof_ = P.Base\nmodule Proof = P\n\nlet pad_messages_for_next_wrap_proof\n (type local_max_proofs_verifieds max_local_max_proofs_verifieds\n max_proofs_verified )\n (module M : Hlist.Maxes.S\n with type ns = max_local_max_proofs_verifieds\n and type length = max_proofs_verified )\n (messages_for_next_wrap_proofs :\n local_max_proofs_verifieds\n H1.T(Proof_.Messages_for_next_proof_over_same_field.Wrap).t ) =\n let dummy_chals = Dummy.Ipa.Wrap.challenges in\n let module Messages =\n H1.T (Proof_.Messages_for_next_proof_over_same_field.Wrap) in\n let module Maxes = H1.T (Nat) in\n let (T (messages_len, _)) = Messages.length messages_for_next_wrap_proofs in\n let (T (maxes_len, _)) = Maxes.length M.maxes in\n let (T difference) =\n let rec sub : type n m. n Nat.t -> m Nat.t -> Nat.e =\n fun x y ->\n let open Nat in\n match (x, y) with\n | _, Z ->\n T x\n | Z, S _ ->\n assert false\n | S x, S y ->\n sub x y\n in\n sub maxes_len messages_len\n in\n let rec go :\n type len ms ns. len Nat.t -> ms Maxes.t -> ns Messages.t -> ms Messages.t\n =\n fun pad maxes messages_for_next_wrap_proofs ->\n match (pad, maxes, messages_for_next_wrap_proofs) with\n | S pad, m :: maxes, _ ->\n { challenge_polynomial_commitment = Lazy.force Dummy.Ipa.Step.sg\n ; old_bulletproof_challenges = Vector.init m ~f:(fun _ -> dummy_chals)\n }\n :: go pad maxes messages_for_next_wrap_proofs\n | S _, [], _ ->\n assert false\n | Z, [], [] ->\n []\n | ( Z\n , m :: maxes\n , messages_for_next_wrap_proof :: messages_for_next_wrap_proofs ) ->\n let messages_for_next_wrap_proof =\n { messages_for_next_wrap_proof with\n old_bulletproof_challenges =\n Vector.extend_exn\n messages_for_next_wrap_proof.old_bulletproof_challenges m\n dummy_chals\n }\n in\n messages_for_next_wrap_proof :: go Z maxes messages_for_next_wrap_proofs\n | Z, [], _ :: _ | Z, _ :: _, [] ->\n assert false\n in\n go difference M.maxes messages_for_next_wrap_proofs\n\nmodule type Proof_intf = sig\n type statement\n\n type t\n\n val verification_key : Verification_key.t Lazy.t\n\n val id : Cache.Wrap.Key.Verification.t Lazy.t\n\n val verify : (statement * t) list -> unit Or_error.t Deferred.t\n\n val verify_promise : (statement * t) list -> unit Or_error.t Promise.t\nend\n\nmodule Prover = struct\n type ('prev_values, 'local_widths, 'local_heights, 'a_value, 'proof) t =\n ?handler:\n ( Snarky_backendless.Request.request\n -> Snarky_backendless.Request.response )\n -> 'a_value\n -> 'proof\nend\n\ntype ('max_proofs_verified, 'branches, 'prev_varss) wrap_main_generic =\n { wrap_main :\n 'max_local_max_proofs_verifieds.\n Domains.t\n -> ( 'max_proofs_verified\n , 'branches\n , 'max_local_max_proofs_verifieds )\n Full_signature.t\n -> ('prev_varss, 'branches) Hlist.Length.t\n -> ( ( Wrap_main_inputs.Inner_curve.Constant.t\n , Wrap_main_inputs.Inner_curve.Constant.t option )\n Wrap_verifier.index'\n , 'branches )\n Vector.t\n Lazy.t\n -> (int, 'branches) Pickles_types.Vector.t\n -> (Import.Domains.t, 'branches) Pickles_types.Vector.t\n -> (module Pickles_types.Nat.Add.Intf with type n = 'max_proofs_verified)\n -> ('max_proofs_verified, 'max_local_max_proofs_verifieds) Requests.Wrap.t\n * ( ( ( Impls.Wrap.Field.t\n , Wrap_verifier.Challenge.t Kimchi_types.scalar_challenge\n , Wrap_verifier.Other_field.Packed.t Shifted_value.Type1.t\n , ( Wrap_verifier.Other_field.Packed.t Shifted_value.Type1.t\n , Impls.Wrap.Boolean.var )\n Opt.t\n , ( Impls.Wrap.Impl.Field.t Composition_types.Scalar_challenge.t\n , Impls.Wrap.Boolean.var )\n Pickles_types__Opt.t\n , Impls.Wrap.Boolean.var )\n Composition_types.Wrap.Proof_state.Deferred_values.Plonk\n .In_circuit\n .t\n , Wrap_verifier.Challenge.t Kimchi_types.scalar_challenge\n , Wrap_verifier.Other_field.Packed.t\n Pickles_types__Shifted_value.Type1.t\n , Impls.Wrap.Field.t\n , Impls.Wrap.Field.t\n , Impls.Wrap.Field.t\n , ( Impls.Wrap.Field.t Import.Scalar_challenge.t\n Import.Types.Bulletproof_challenge.t\n , Backend.Tick.Rounds.n )\n Vector.T.t\n , Impls.Wrap.Field.t )\n Composition_types.Wrap.Statement.t\n -> unit )\n (** An override for wrap_main, which allows for adversarial testing\n with an 'invalid' pickles statement by passing a dummy proof.\n *)\n ; tweak_statement :\n 'actual_proofs_verified 'b 'e.\n ( Import.Challenge.Constant.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , ( Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool )\n Import.Types.Opt.t\n , ( Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , bool )\n Import.Types.Opt.t\n , bool\n , 'max_proofs_verified\n Proof.Base.Messages_for_next_proof_over_same_field.Wrap.t\n , (int64, Composition_types.Digest.Limbs.n) Pickles_types.Vector.vec\n , ( 'b\n , ( Kimchi_pasta.Pallas_based_plonk.Proof.G.Affine.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t\n , ( ( Import.Challenge.Constant.t Import.Scalar_challenge.t\n Import.Bulletproof_challenge.t\n , 'e )\n Pickles_types.Vector.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t )\n Proof.Base.Messages_for_next_proof_over_same_field.Step.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n Import.Types.Bulletproof_challenge.t\n Import.Types.Step_bp_vec.t\n , Import.Types.Branch_data.t )\n Import.Types.Wrap.Statement.In_circuit.t\n -> ( Import.Challenge.Constant.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , ( Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool )\n Import.Types.Opt.t\n , ( Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , bool )\n Import.Types.Opt.t\n , bool\n , 'max_proofs_verified\n Proof.Base.Messages_for_next_proof_over_same_field.Wrap.t\n , ( Limb_vector.Constant.Hex64.t\n , Composition_types.Digest.Limbs.n )\n Pickles_types.Vector.vec\n , ( 'b\n , ( Kimchi_pasta.Pallas_based_plonk.Proof.G.Affine.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t\n , ( ( Import.Challenge.Constant.t Import.Scalar_challenge.t\n Import.Bulletproof_challenge.t\n , 'e )\n Pickles_types.Vector.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t )\n Proof.Base.Messages_for_next_proof_over_same_field.Step.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n Import.Types.Bulletproof_challenge.t\n Import.Types.Step_bp_vec.t\n , Import.Types.Branch_data.t )\n Import.Types.Wrap.Statement.In_circuit.t\n (** A function to modify the statement passed into the wrap proof,\n which will be later passed to recursion pickles rules.\n\n This function can be used to modify the pickles statement in an\n adversarial way, along with [wrap_main] above that allows that\n statement to be accepted.\n *)\n }\n\nmodule Make\n (Arg_var : Statement_var_intf)\n (Arg_value : Statement_value_intf)\n (Ret_var : T0)\n (Ret_value : T0)\n (Auxiliary_var : T0)\n (Auxiliary_value : T0) =\nstruct\n module IR =\n Inductive_rule.T (Arg_var) (Arg_value) (Ret_var) (Ret_value) (Auxiliary_var)\n (Auxiliary_value)\n module HIR = H4.T (IR)\n\n let max_local_max_proofs_verifieds ~self (type n)\n (module Max_proofs_verified : Nat.Intf with type n = n) branches choices =\n let module Local_max_proofs_verifieds = struct\n type t = (int, Max_proofs_verified.n) Vector.t\n end in\n let module M =\n H4.Map (IR) (E04 (Local_max_proofs_verifieds))\n (struct\n module V = H4.To_vector (Int)\n module HT = H4.T (Tag)\n\n module M =\n H4.Map (Tag) (E04 (Int))\n (struct\n let f (type a b c d) (t : (a, b, c, d) Tag.t) : int =\n if Type_equal.Id.same t.id self then\n Nat.to_int Max_proofs_verified.n\n else\n let (module M) = Types_map.max_proofs_verified t in\n Nat.to_int M.n\n end)\n\n let f :\n type a b c d. (a, b, c, d) IR.t -> Local_max_proofs_verifieds.t =\n fun rule ->\n let (T (_, l)) = HT.length rule.prevs in\n Vector.extend_front_exn\n (V.f l (M.f rule.prevs))\n Max_proofs_verified.n 0\n end)\n in\n let module V = H4.To_vector (Local_max_proofs_verifieds) in\n let padded = V.f branches (M.f choices) |> Vector.transpose in\n (padded, Maxes.m padded)\n\n module Lazy_keys = struct\n type t =\n (Impls.Step.Keypair.t * Dirty.t) Lazy.t\n * (Kimchi_bindings.Protocol.VerifierIndex.Fp.t * Dirty.t) Lazy.t\n\n (* TODO Think this is right.. *)\n end\n\n let log_step main _typ name index =\n let module Constraints = Snarky_log.Constraints (Impls.Step.Internal_Basic) in\n let log =\n let weight =\n let sys = Backend.Tick.R1CS_constraint_system.create () in\n fun ({ annotation; basic } : Impls.Step.Constraint.t) ->\n let prev =\n Kimchi_pasta_constraint_system.Vesta_constraint_system.next_row sys\n in\n Backend.Tick.R1CS_constraint_system.add_constraint sys\n ?label:annotation basic ;\n let next =\n Kimchi_pasta_constraint_system.Vesta_constraint_system.next_row sys\n in\n next - prev\n in\n Constraints.log ~weight (fun () -> Impls.Step.make_checked main)\n in\n if profile_constraints then\n Snarky_log.to_file (sprintf \"step-snark-%s-%d.json\" name index) log\n\n let log_wrap main typ name id =\n let module Constraints = Snarky_log.Constraints (Impls.Wrap.Internal_Basic) in\n let log =\n let sys = Backend.Tock.R1CS_constraint_system.create () in\n let weight ({ annotation; basic } : Impls.Wrap.Constraint.t) =\n let prev =\n Kimchi_pasta_constraint_system.Pallas_constraint_system.next_row sys\n in\n Backend.Tock.R1CS_constraint_system.add_constraint sys ?label:annotation\n basic ;\n let next =\n Kimchi_pasta_constraint_system.Pallas_constraint_system.next_row sys\n in\n next - prev\n in\n let log =\n Constraints.log ~weight\n Impls.Wrap.(\n fun () ->\n make_checked (fun () : unit ->\n let x = with_label __LOC__ (fun () -> exists typ) in\n main x () ))\n in\n log\n in\n if profile_constraints then\n Snarky_log.to_file\n (sprintf\n !\"wrap-%s-%{sexp:Type_equal.Id.Uid.t}.json\"\n name (Type_equal.Id.uid id) )\n log\n\n let compile :\n type var value prev_varss prev_valuess widthss heightss max_proofs_verified branches.\n self:(var, value, max_proofs_verified, branches) Tag.t\n -> cache:Key_cache.Spec.t list\n -> proof_cache:Proof_cache.t option\n -> ?disk_keys:\n (Cache.Step.Key.Verification.t, branches) Vector.t\n * Cache.Wrap.Key.Verification.t\n -> ?return_early_digest_exception:bool\n -> ?override_wrap_domain:Pickles_base.Proofs_verified.t\n -> ?override_wrap_main:\n (max_proofs_verified, branches, prev_varss) wrap_main_generic\n -> branches:(module Nat.Intf with type n = branches)\n -> max_proofs_verified:\n (module Nat.Add.Intf with type n = max_proofs_verified)\n -> name:string\n -> constraint_constants:Snark_keys_header.Constraint_constants.t\n -> public_input:\n ( var\n , value\n , Arg_var.t\n , Arg_value.t\n , Ret_var.t\n , Ret_value.t )\n Inductive_rule.public_input\n -> auxiliary_typ:(Auxiliary_var.t, Auxiliary_value.t) Impls.Step.Typ.t\n -> choices:\n ( self:(var, value, max_proofs_verified, branches) Tag.t\n -> (prev_varss, prev_valuess, widthss, heightss) H4.T(IR).t )\n -> unit\n -> ( prev_valuess\n , widthss\n , heightss\n , Arg_value.t\n , ( Ret_value.t\n * Auxiliary_value.t\n * (max_proofs_verified, max_proofs_verified) Proof.t )\n Promise.t )\n H3_2.T(Prover).t\n * _\n * _\n * _ =\n fun ~self ~cache ~proof_cache ?disk_keys\n ?(return_early_digest_exception = false) ?override_wrap_domain\n ?override_wrap_main ~branches:(module Branches) ~max_proofs_verified\n ~name ~constraint_constants ~public_input ~auxiliary_typ ~choices () ->\n let snark_keys_header kind constraint_system_hash =\n { Snark_keys_header.header_version = Snark_keys_header.header_version\n ; kind\n ; constraint_constants\n ; commits =\n { mina = Mina_version.commit_id\n ; marlin = Mina_version.marlin_commit_id\n }\n ; length = (* This is a dummy, it gets filled in on read/write. *) 0\n ; commit_date = Mina_version.commit_date\n ; constraint_system_hash\n ; identifying_hash =\n (* TODO: Proper identifying hash. *)\n constraint_system_hash\n }\n in\n Timer.start __LOC__ ;\n let module Max_proofs_verified = ( val max_proofs_verified : Nat.Add.Intf\n with type n = max_proofs_verified )\n in\n let T = Max_proofs_verified.eq in\n let choices = choices ~self in\n let (T (prev_varss_n, prev_varss_length)) = HIR.length choices in\n let T = Nat.eq_exn prev_varss_n Branches.n in\n let padded, (module Maxes) =\n max_local_max_proofs_verifieds\n ( module struct\n include Max_proofs_verified\n end )\n prev_varss_length choices ~self:self.id\n in\n let full_signature = { Full_signature.padded; maxes = (module Maxes) } in\n Timer.clock __LOC__ ;\n let feature_flags =\n let rec go :\n type a b c d.\n (a, b, c, d) H4.T(IR).t -> Opt.Flag.t Plonk_types.Features.Full.t =\n fun rules ->\n match rules with\n | [] ->\n Plonk_types.Features.Full.none\n | [ r ] ->\n Plonk_types.Features.map r.feature_flags ~f:(function\n | true ->\n Opt.Flag.Yes\n | false ->\n Opt.Flag.No )\n |> Plonk_types.Features.to_full ~or_:Opt.Flag.( ||| )\n | r :: rules ->\n let feature_flags = go rules in\n Plonk_types.Features.Full.map2\n (Plonk_types.Features.to_full ~or_:( || ) r.feature_flags)\n feature_flags ~f:(fun enabled flag ->\n match (enabled, flag) with\n | true, Yes ->\n Opt.Flag.Yes\n | false, No ->\n No\n | _, Maybe | true, No | false, Yes ->\n Maybe )\n in\n go choices\n in\n let wrap_domains =\n match override_wrap_domain with\n | None ->\n let module M =\n Wrap_domains.Make (Arg_var) (Arg_value) (Ret_var) (Ret_value)\n (Auxiliary_var)\n (Auxiliary_value)\n in\n M.f full_signature prev_varss_n prev_varss_length ~max_proofs_verified\n ~feature_flags\n | Some override ->\n Common.wrap_domains\n ~proofs_verified:(Pickles_base.Proofs_verified.to_int override)\n in\n Timer.clock __LOC__ ;\n let module Branch_data = struct\n type ('vars, 'vals, 'n, 'm) t =\n ( Arg_var.t\n , Arg_value.t\n , Ret_var.t\n , Ret_value.t\n , Auxiliary_var.t\n , Auxiliary_value.t\n , Max_proofs_verified.n\n , Branches.n\n , 'vars\n , 'vals\n , 'n\n , 'm )\n Step_branch_data.t\n end in\n let proofs_verifieds =\n let module M =\n H4.Map (IR) (E04 (Int))\n (struct\n module M = H4.T (Tag)\n\n let f : type a b c d. (a, b, c, d) IR.t -> int =\n fun r ->\n let (T (n, _)) = M.length r.prevs in\n Nat.to_int n\n end)\n in\n let module V = H4.To_vector (Int) in\n V.f prev_varss_length (M.f choices)\n in\n let step_data =\n let i = ref 0 in\n Timer.clock __LOC__ ;\n let rec f :\n type a b c d.\n (a, b, c, d) H4.T(IR).t -> (a, b, c, d) H4.T(Branch_data).t = function\n | [] ->\n []\n | rule :: rules ->\n let first =\n Timer.clock __LOC__ ;\n let res =\n Common.time \"make step data\" (fun () ->\n Step_branch_data.create ~index:!i ~feature_flags\n ~actual_feature_flags:rule.feature_flags\n ~max_proofs_verified:Max_proofs_verified.n\n ~branches:Branches.n ~self ~public_input ~auxiliary_typ\n Arg_var.to_field_elements Arg_value.to_field_elements rule\n ~wrap_domains ~proofs_verifieds )\n in\n Timer.clock __LOC__ ; incr i ; res\n in\n first :: f rules\n in\n f choices\n in\n Timer.clock __LOC__ ;\n let step_domains =\n let module M =\n H4.Map (Branch_data) (E04 (Domains))\n (struct\n let f (T b : _ Branch_data.t) = b.domains\n end)\n in\n let module V = H4.To_vector (Domains) in\n V.f prev_varss_length (M.f step_data)\n in\n let cache_handle = ref (Lazy.return `Cache_hit) in\n let accum_dirty t = cache_handle := Cache_handle.(!cache_handle + t) in\n Timer.clock __LOC__ ;\n let step_keypairs =\n let disk_keys =\n Option.map disk_keys ~f:(fun (xs, _) -> Vector.to_array xs)\n in\n let module M =\n H4.Map (Branch_data) (E04 (Lazy_keys))\n (struct\n let etyp =\n Impls.Step.input ~proofs_verified:Max_proofs_verified.n\n ~wrap_rounds:Tock.Rounds.n\n\n let f (T b : _ Branch_data.t) =\n let (T (typ, _conv, conv_inv)) = etyp in\n let main () () =\n let res = b.main ~step_domains () in\n Impls.Step.with_label \"conv_inv\" (fun () -> conv_inv res)\n in\n let () = if true then log_step main typ name b.index in\n let open Impls.Step in\n (* HACK: TODO docs *)\n if return_early_digest_exception then\n raise\n (Return_digest\n ( constraint_system ~input_typ:Typ.unit ~return_typ:typ main\n |> R1CS_constraint_system.digest ) ) ;\n\n let k_p =\n lazy\n (let cs =\n constraint_system ~input_typ:Typ.unit ~return_typ:typ main\n in\n let cs_hash =\n Md5.to_hex (R1CS_constraint_system.digest cs)\n in\n ( Type_equal.Id.uid self.id\n , snark_keys_header\n { type_ = \"step-proving-key\"\n ; identifier = name ^ \"-\" ^ b.rule.identifier\n }\n cs_hash\n , b.index\n , cs ) )\n in\n let k_v =\n match disk_keys with\n | Some ks ->\n Lazy.return ks.(b.index)\n | None ->\n lazy\n (let id, _header, index, cs = Lazy.force k_p in\n let digest = R1CS_constraint_system.digest cs in\n ( id\n , snark_keys_header\n { type_ = \"step-verification-key\"\n ; identifier = name ^ \"-\" ^ b.rule.identifier\n }\n (Md5.to_hex digest)\n , index\n , digest ) )\n in\n let ((pk, vk) as res) =\n Common.time \"step read or generate\" (fun () ->\n Cache.Step.read_or_generate\n ~prev_challenges:(Nat.to_int (fst b.proofs_verified))\n cache k_p k_v\n (Snarky_backendless.Typ.unit ())\n typ main )\n in\n accum_dirty (Lazy.map pk ~f:snd) ;\n accum_dirty (Lazy.map vk ~f:snd) ;\n res\n end)\n in\n M.f step_data\n in\n Timer.clock __LOC__ ;\n let step_vks =\n let module V = H4.To_vector (Lazy_keys) in\n lazy\n (Vector.map (V.f prev_varss_length step_keypairs) ~f:(fun (_, vk) ->\n Tick.Keypair.full_vk_commitments (fst (Lazy.force vk)) ) )\n in\n Timer.clock __LOC__ ;\n let wrap_requests, wrap_main =\n match override_wrap_main with\n | None ->\n let srs = Tick.Keypair.load_urs () in\n Wrap_main.wrap_main ~feature_flags ~srs full_signature\n prev_varss_length step_vks proofs_verifieds step_domains\n max_proofs_verified\n | Some { wrap_main; tweak_statement = _ } ->\n (* Instead of creating a proof using the pickles wrap circuit, we\n have been asked to create proof in an 'adversarial' way, where\n the wrap circuit is some other circuit.\n The [wrap_main] value passed in as part of [override_wrap_main]\n defines the alternative circuit to run; this will usually be a\n dummy circuit that verifies any public input for the purposes of\n testing.\n *)\n wrap_main wrap_domains full_signature prev_varss_length step_vks\n proofs_verifieds step_domains max_proofs_verified\n in\n Timer.clock __LOC__ ;\n let (wrap_pk, wrap_vk), disk_key =\n let open Impls.Wrap in\n let (T (typ, conv, _conv_inv)) = input ~feature_flags () in\n let main x () : unit = wrap_main (conv x) in\n let () = if true then log_wrap main typ name self.id in\n let self_id = Type_equal.Id.uid self.id in\n let disk_key_prover =\n lazy\n (let cs =\n constraint_system ~input_typ:typ\n ~return_typ:(Snarky_backendless.Typ.unit ())\n main\n in\n let cs_hash = Md5.to_hex (R1CS_constraint_system.digest cs) in\n ( self_id\n , snark_keys_header\n { type_ = \"wrap-proving-key\"; identifier = name }\n cs_hash\n , cs ) )\n in\n let disk_key_verifier =\n match disk_keys with\n | None ->\n lazy\n (let id, _header, cs = Lazy.force disk_key_prover in\n let digest = R1CS_constraint_system.digest cs in\n ( id\n , snark_keys_header\n { type_ = \"wrap-verification-key\"; identifier = name }\n (Md5.to_hex digest)\n , digest ) )\n | Some (_, (_id, header, digest)) ->\n Lazy.return (self_id, header, digest)\n in\n let r =\n Common.time \"wrap read or generate \" (fun () ->\n Cache.Wrap.read_or_generate (* Due to Wrap_hack *)\n ~prev_challenges:2 cache disk_key_prover disk_key_verifier typ\n (Snarky_backendless.Typ.unit ())\n main )\n in\n (r, disk_key_verifier)\n in\n Timer.clock __LOC__ ;\n let wrap_vk =\n Lazy.map wrap_vk ~f:(fun ((wrap_vk, _) as res) ->\n let computed_domain_size = wrap_vk.index.domain.log_size_of_group in\n let (Pow_2_roots_of_unity proposed_domain_size) = wrap_domains.h in\n if computed_domain_size <> proposed_domain_size then\n failwithf\n \"This circuit was compiled for proofs using the wrap domain of \\\n size %d, but the actual wrap domain size for the circuit has \\\n size %d. You should pass the ~override_wrap_domain argument to \\\n set the correct domain size.\"\n proposed_domain_size computed_domain_size () ;\n res )\n in\n accum_dirty (Lazy.map wrap_pk ~f:snd) ;\n accum_dirty (Lazy.map wrap_vk ~f:snd) ;\n let wrap_vk = Lazy.map wrap_vk ~f:fst in\n let module S =\n Step.Make (Arg_var) (Arg_value)\n (struct\n include Max_proofs_verified\n end)\n in\n let (typ : (var, value) Impls.Step.Typ.t) =\n match public_input with\n | Input typ ->\n typ\n | Output typ ->\n typ\n | Input_and_output (input_typ, output_typ) ->\n Impls.Step.Typ.(input_typ * output_typ)\n in\n let provers =\n let f :\n type prev_vars prev_values local_widths local_heights.\n (prev_vars, prev_values, local_widths, local_heights) Branch_data.t\n -> Lazy_keys.t\n -> ?handler:\n ( Snarky_backendless.Request.request\n -> Snarky_backendless.Request.response )\n -> Arg_value.t\n -> ( Ret_value.t\n * Auxiliary_value.t\n * (Max_proofs_verified.n, Max_proofs_verified.n) Proof.t )\n Promise.t =\n fun (T b as branch_data) (step_pk, step_vk) ->\n let _, prev_vars_length = b.proofs_verified in\n let step handler next_state =\n let wrap_vk = Lazy.force wrap_vk in\n S.f ?handler branch_data next_state ~prevs_length:prev_vars_length\n ~self ~step_domains ~self_dlog_plonk_index:wrap_vk.commitments\n ~public_input ~auxiliary_typ ~feature_flags\n (Impls.Step.Keypair.pk (fst (Lazy.force step_pk)))\n wrap_vk.index\n in\n let step_vk = fst (Lazy.force step_vk) in\n let wrap ?handler next_state =\n let wrap_vk = Lazy.force wrap_vk in\n let%bind.Promise ( proof\n , return_value\n , auxiliary_value\n , actual_wrap_domains ) =\n step ~proof_cache handler ~maxes:(module Maxes) next_state\n in\n let proof =\n { proof with\n statement =\n { proof.statement with\n messages_for_next_wrap_proof =\n pad_messages_for_next_wrap_proof\n (module Maxes)\n proof.statement.messages_for_next_wrap_proof\n }\n }\n in\n let%map.Promise proof =\n let tweak_statement =\n match override_wrap_main with\n | None ->\n None\n | Some { tweak_statement; wrap_main = _ } ->\n (* Extract the [tweak_statement] part of the\n [override_wrap_main], so that we can run an adversarial\n test.\n\n This function modifies the statement that will be proved\n over, and which gets passed to later recursive pickles\n rules.\n *)\n Some tweak_statement\n in\n Wrap.wrap ~proof_cache ~max_proofs_verified:Max_proofs_verified.n\n ~feature_flags ~actual_feature_flags:b.feature_flags\n full_signature.maxes wrap_requests ?tweak_statement\n ~dlog_plonk_index:wrap_vk.commitments wrap_main ~typ ~step_vk\n ~step_plonk_indices:(Lazy.force step_vks) ~actual_wrap_domains\n (Impls.Wrap.Keypair.pk (fst (Lazy.force wrap_pk)))\n proof\n in\n ( return_value\n , auxiliary_value\n , Proof.T\n { proof with\n statement =\n { proof.statement with\n messages_for_next_step_proof =\n { proof.statement.messages_for_next_step_proof with\n app_state = ()\n }\n }\n } )\n in\n wrap\n in\n let rec go :\n type xs1 xs2 xs3 xs4.\n (xs1, xs2, xs3, xs4) H4.T(Branch_data).t\n -> (xs1, xs2, xs3, xs4) H4.T(E04(Lazy_keys)).t\n -> ( xs2\n , xs3\n , xs4\n , Arg_value.t\n , ( Ret_value.t\n * Auxiliary_value.t\n * (max_proofs_verified, max_proofs_verified) Proof.t )\n Promise.t )\n H3_2.T(Prover).t =\n fun bs ks ->\n match (bs, ks) with\n | [], [] ->\n []\n | b :: bs, k :: ks ->\n f b k :: go bs ks\n in\n go step_data step_keypairs\n in\n Timer.clock __LOC__ ;\n let data : _ Types_map.Compiled.t =\n { branches = Branches.n\n ; proofs_verifieds\n ; max_proofs_verified\n ; public_input = typ\n ; wrap_key = Lazy.map wrap_vk ~f:Verification_key.commitments\n ; wrap_vk = Lazy.map wrap_vk ~f:Verification_key.index\n ; wrap_domains\n ; step_domains\n ; feature_flags\n }\n in\n Timer.clock __LOC__ ;\n Types_map.add_exn self data ;\n (provers, wrap_vk, disk_key, !cache_handle)\nend\n\nmodule Side_loaded = struct\n module V = Verification_key\n\n module Verification_key = struct\n include Side_loaded_verification_key\n\n let to_input (t : t) =\n to_input ~field_of_int:Impls.Step.Field.Constant.of_int t\n\n let of_compiled tag : t =\n let d = Types_map.lookup_compiled tag.Tag.id in\n let actual_wrap_domain_size =\n Common.actual_wrap_domain_size\n ~log_2_domain_size:(Lazy.force d.wrap_vk).domain.log_size_of_group\n in\n { wrap_vk = Some (Lazy.force d.wrap_vk)\n ; wrap_index = Lazy.force d.wrap_key\n ; max_proofs_verified =\n Pickles_base.Proofs_verified.of_nat (Nat.Add.n d.max_proofs_verified)\n ; actual_wrap_domain_size\n }\n\n module Max_width = Width.Max\n end\n\n let in_circuit tag vk = Types_map.set_ephemeral tag { index = `In_circuit vk }\n\n let in_prover tag vk = Types_map.set_ephemeral tag { index = `In_prover vk }\n\n let create ~name ~max_proofs_verified ~feature_flags ~typ =\n Types_map.add_side_loaded ~name\n { max_proofs_verified\n ; public_input = typ\n ; branches = Verification_key.Max_branches.n\n ; feature_flags =\n Plonk_types.Features.to_full ~or_:Opt.Flag.( ||| ) feature_flags\n }\n\n module Proof = struct\n include Proof.Proofs_verified_max\n\n let of_proof : _ Proof.t -> t = Wrap_hack.pad_proof\n end\n\n let verify_promise (type t) ~(typ : (_, t) Impls.Step.Typ.t)\n (ts : (Verification_key.t * t * Proof.t) list) =\n let m =\n ( module struct\n type nonrec t = t\n\n let to_field_elements =\n let (Typ typ) = typ in\n fun x -> fst (typ.value_to_fields x)\n end : Intf.Statement_value\n with type t = t )\n in\n (* TODO: This should be the actual max width on a per proof basis *)\n let max_proofs_verified =\n (module Verification_key.Max_width : Nat.Intf\n with type n = Verification_key.Max_width.n )\n in\n with_return (fun { return } ->\n List.map ts ~f:(fun (vk, x, p) ->\n let vk : V.t =\n { commitments = vk.wrap_index\n ; index =\n ( match vk.wrap_vk with\n | None ->\n return\n (Promise.return\n (Or_error.errorf \"Pickles.verify: wrap_vk not found\") )\n | Some x ->\n x )\n ; data =\n (* This isn't used in verify_heterogeneous, so we can leave this dummy *)\n { constraints = 0 }\n }\n in\n Verify.Instance.T (max_proofs_verified, m, vk, x, p) )\n |> Verify.verify_heterogenous )\n\n let verify ~typ ts = verify_promise ~typ ts |> Promise.to_deferred\n\n let srs_precomputation () : unit =\n let srs = Tock.Keypair.load_urs () in\n List.iter [ 0; 1; 2 ] ~f:(fun i ->\n Kimchi_bindings.Protocol.SRS.Fq.add_lagrange_basis srs\n (Domain.log2_size (Common.wrap_domains ~proofs_verified:i).h) )\nend\n\nlet compile_with_wrap_main_override_promise :\n type var value a_var a_value ret_var ret_value auxiliary_var auxiliary_value prev_varss prev_valuess widthss heightss max_proofs_verified branches.\n ?self:(var, value, max_proofs_verified, branches) Tag.t\n -> ?cache:Key_cache.Spec.t list\n -> ?proof_cache:Proof_cache.t\n -> ?disk_keys:\n (Cache.Step.Key.Verification.t, branches) Vector.t\n * Cache.Wrap.Key.Verification.t\n -> ?return_early_digest_exception:bool\n -> ?override_wrap_domain:Pickles_base.Proofs_verified.t\n -> ?override_wrap_main:\n (max_proofs_verified, branches, prev_varss) wrap_main_generic\n -> public_input:\n ( var\n , value\n , a_var\n , a_value\n , ret_var\n , ret_value )\n Inductive_rule.public_input\n -> auxiliary_typ:(auxiliary_var, auxiliary_value) Impls.Step.Typ.t\n -> branches:(module Nat.Intf with type n = branches)\n -> max_proofs_verified:\n (module Nat.Add.Intf with type n = max_proofs_verified)\n -> name:string\n -> constraint_constants:Snark_keys_header.Constraint_constants.t\n -> choices:\n ( self:(var, value, max_proofs_verified, branches) Tag.t\n -> ( prev_varss\n , prev_valuess\n , widthss\n , heightss\n , a_var\n , a_value\n , ret_var\n , ret_value\n , auxiliary_var\n , auxiliary_value )\n H4_6.T(Inductive_rule).t )\n -> unit\n -> (var, value, max_proofs_verified, branches) Tag.t\n * Cache_handle.t\n * (module Proof_intf\n with type t = (max_proofs_verified, max_proofs_verified) Proof.t\n and type statement = value )\n * ( prev_valuess\n , widthss\n , heightss\n , a_value\n , ( ret_value\n * auxiliary_value\n * (max_proofs_verified, max_proofs_verified) Proof.t )\n Promise.t )\n H3_2.T(Prover).t =\n (* This function is an adapter between the user-facing Pickles.compile API\n and the underlying Make(_).compile function which builds the circuits.\n *)\n fun ?self ?(cache = []) ?proof_cache ?disk_keys\n ?(return_early_digest_exception = false) ?override_wrap_domain\n ?override_wrap_main ~public_input ~auxiliary_typ ~branches\n ~max_proofs_verified ~name ~constraint_constants ~choices () ->\n let self =\n match self with\n | None ->\n Tag.(create ~kind:Compiled name)\n | Some self ->\n self\n in\n (* Extract to_fields methods from the public input declaration. *)\n let (a_var_to_fields : a_var -> _), (a_value_to_fields : a_value -> _) =\n match public_input with\n | Input (Typ typ) ->\n ( (fun x -> fst (typ.var_to_fields x))\n , fun x -> fst (typ.value_to_fields x) )\n | Output _ ->\n ((fun () -> [||]), fun () -> [||])\n | Input_and_output (Typ typ, _) ->\n ( (fun x -> fst (typ.var_to_fields x))\n , fun x -> fst (typ.value_to_fields x) )\n in\n let module A_var = struct\n type t = a_var\n\n let to_field_elements = a_var_to_fields\n end in\n let module A_value = struct\n type t = a_value\n\n let to_field_elements = a_value_to_fields\n end in\n let module Ret_var = struct\n type t = ret_var\n end in\n let module Ret_value = struct\n type t = ret_value\n end in\n let module Auxiliary_var = struct\n type t = auxiliary_var\n end in\n let module Auxiliary_value = struct\n type t = auxiliary_value\n end in\n let module M =\n Make (A_var) (A_value) (Ret_var) (Ret_value) (Auxiliary_var)\n (Auxiliary_value)\n in\n let rec conv_irs :\n type v1ss v2ss wss hss.\n ( v1ss\n , v2ss\n , wss\n , hss\n , a_var\n , a_value\n , ret_var\n , ret_value\n , auxiliary_var\n , auxiliary_value )\n H4_6.T(Inductive_rule).t\n -> (v1ss, v2ss, wss, hss) H4.T(M.IR).t = function\n | [] ->\n []\n | r :: rs ->\n r :: conv_irs rs\n in\n let provers, wrap_vk, wrap_disk_key, cache_handle =\n M.compile ~return_early_digest_exception ~self ~proof_cache ~cache\n ?disk_keys ?override_wrap_domain ?override_wrap_main ~branches\n ~max_proofs_verified ~name ~public_input ~auxiliary_typ\n ~constraint_constants\n ~choices:(fun ~self -> conv_irs (choices ~self))\n ()\n in\n let (module Max_proofs_verified) = max_proofs_verified in\n let T = Max_proofs_verified.eq in\n let module Value = struct\n type t = value\n\n let typ : (var, value) Impls.Step.Typ.t =\n match public_input with\n | Input typ ->\n typ\n | Output typ ->\n typ\n | Input_and_output (input_typ, output_typ) ->\n Impls.Step.Typ.(input_typ * output_typ)\n\n let to_field_elements =\n let (Typ typ) = typ in\n fun x -> fst (typ.value_to_fields x)\n end in\n let module P = struct\n type statement = value\n\n module Max_local_max_proofs_verified = Max_proofs_verified\n\n include\n Proof.Make\n (struct\n include Max_proofs_verified\n end)\n (struct\n include Max_local_max_proofs_verified\n end)\n\n let id = wrap_disk_key\n\n let verification_key = wrap_vk\n\n let verify_promise ts =\n verify_promise\n ( module struct\n include Max_proofs_verified\n end )\n (module Value)\n (Lazy.force verification_key)\n ts\n\n let verify ts = verify_promise ts |> Promise.to_deferred\n end in\n (self, cache_handle, (module P), provers)\n\nlet wrap_main_dummy_override _ _ _ _ _ _ _ =\n let requests =\n (* The requests that the logic in [Wrap.wrap] use to pass\n values into and out of the wrap proof circuit.\n Since these are unnecessary for the dummy circuit below, we\n generate them without using them.\n *)\n Requests.Wrap.create ()\n in\n (* A replacement for the 'wrap' circuit, which makes no\n assertions about the statement that it receives as its first\n argument.\n *)\n let wrap_main _ =\n let module SC' = SC in\n let open Impls.Wrap in\n let open Wrap_main_inputs in\n (* Create some variables to be used in constraints below. *)\n let x = exists Field.typ ~compute:(fun () -> Field.Constant.of_int 3) in\n let y = exists Field.typ ~compute:(fun () -> Field.Constant.of_int 0) in\n let z = exists Field.typ ~compute:(fun () -> Field.Constant.of_int 0) in\n (* Every circuit must use at least 1 of each constraint; we\n use them here.\n *)\n let () =\n let g = Inner_curve.one in\n let sponge = Sponge.create sponge_params in\n Sponge.absorb sponge x ;\n ignore (Sponge.squeeze_field sponge : Field.t) ;\n ignore\n ( SC'.to_field_checked'\n (module Impl)\n ~num_bits:16\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t * Field.t ) ;\n ignore (Ops.scale_fast g ~num_bits:5 (Shifted_value x) : Inner_curve.t) ;\n ignore\n ( Wrap_verifier.Scalar_challenge.endo g ~num_bits:4\n (Kimchi_backend_common.Scalar_challenge.create x)\n : Field.t * Field.t )\n in\n (* Pad the circuit so that its domain size matches the one\n that would have been used by the true wrap_main.\n *)\n for _ = 0 to 64000 do\n assert_r1cs x y z\n done\n in\n (requests, wrap_main)\n\nmodule Make_adversarial_test (M : sig\n val tweak_statement :\n ( Import.Challenge.Constant.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , ( Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool )\n Import.Types.Opt.t\n , ( Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , bool )\n Import.Types.Opt.t\n , bool\n , 'max_proofs_verified\n Proof.Base.Messages_for_next_proof_over_same_field.Wrap.t\n , (int64, Composition_types.Digest.Limbs.n) Pickles_types.Vector.vec\n , ( 'b\n , ( Kimchi_pasta.Pallas_based_plonk.Proof.G.Affine.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t\n , ( ( Import.Challenge.Constant.t Import.Scalar_challenge.t\n Import.Bulletproof_challenge.t\n , 'e )\n Pickles_types.Vector.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t )\n Proof.Base.Messages_for_next_proof_over_same_field.Step.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n Import.Types.Bulletproof_challenge.t\n Import.Types.Step_bp_vec.t\n , Import.Types.Branch_data.t )\n Import.Types.Wrap.Statement.In_circuit.t\n -> ( Import.Challenge.Constant.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , ( Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool )\n Import.Types.Opt.t\n , ( Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n , bool )\n Import.Types.Opt.t\n , bool\n , 'max_proofs_verified\n Proof.Base.Messages_for_next_proof_over_same_field.Wrap.t\n , ( Limb_vector.Constant.Hex64.t\n , Composition_types.Digest.Limbs.n )\n Pickles_types.Vector.vec\n , ( 'b\n , ( Kimchi_pasta.Pallas_based_plonk.Proof.G.Affine.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t\n , ( ( Import.Challenge.Constant.t Import.Scalar_challenge.t\n Import.Bulletproof_challenge.t\n , 'e )\n Pickles_types.Vector.t\n , 'actual_proofs_verified )\n Pickles_types.Vector.t )\n Proof.Base.Messages_for_next_proof_over_same_field.Step.t\n , Import.Challenge.Constant.t Import.Types.Scalar_challenge.t\n Import.Types.Bulletproof_challenge.t\n Import.Types.Step_bp_vec.t\n , Import.Types.Branch_data.t )\n Import.Types.Wrap.Statement.In_circuit.t\n\n val check_verifier_error : Error.t -> unit\nend) =\nstruct\n open Impls.Step\n\n let constraint_constants : Snark_keys_header.Constraint_constants.t =\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n\n let rule self : _ Inductive_rule.t =\n { identifier = \"main\"\n ; prevs = [ self; self ]\n ; main =\n (fun { public_input = () } ->\n let dummy_proof =\n As_prover.Ref.create (fun () ->\n Proof.dummy Nat.N2.n Nat.N2.n Nat.N2.n ~domain_log2:15 )\n in\n { previous_proof_statements =\n [ { public_input = ()\n ; proof = dummy_proof\n ; proof_must_verify = Boolean.false_\n }\n ; { public_input = ()\n ; proof = dummy_proof\n ; proof_must_verify = Boolean.false_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n ; feature_flags = Plonk_types.Features.none_bool\n }\n\n let override_wrap_main =\n { wrap_main = wrap_main_dummy_override\n ; tweak_statement = M.tweak_statement\n }\n\n let tag, _, p, ([ step ] : _ H3_2.T(Prover).t) =\n compile_with_wrap_main_override_promise () ~override_wrap_main\n ~public_input:(Input Typ.unit) ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"blockchain-snark\"\n ~constraint_constants:\n (* Dummy values *)\n { sub_windows_per_window = 0\n ; ledger_depth = 0\n ; work_delay = 0\n ; block_window_duration_ms = 0\n ; transaction_capacity = Log_2 0\n ; pending_coinbase_depth = 0\n ; coinbase_amount = Unsigned.UInt64.of_int 0\n ; supercharged_coinbase_factor = 0\n ; account_creation_fee = Unsigned.UInt64.of_int 0\n ; fork = None\n }\n ~choices:(fun ~self -> [ rule self ])\n\n module Proof = (val p)\n\n let proof_with_stmt =\n let (), (), p = Promise.block_on_async_exn (fun () -> step ()) in\n ((), p)\n\n let%test \"should not be able to verify invalid proof\" =\n match\n Promise.block_on_async_exn (fun () ->\n Proof.verify_promise [ proof_with_stmt ] )\n with\n | Ok () ->\n false\n | Error err ->\n M.check_verifier_error err ; true\n\n module Recurse_on_bad_proof = struct\n open Impls.Step\n\n type _ Snarky_backendless.Request.t +=\n | Proof : Proof.t Snarky_backendless.Request.t\n\n let handler (proof : Proof.t)\n (Snarky_backendless.Request.With { request; respond }) =\n match request with\n | Proof ->\n respond (Provide proof)\n | _ ->\n respond Unhandled\n\n let _tag, _, p, ([ step ] : _ H3_2.T(Prover).t) =\n Common.time \"compile\" (fun () ->\n compile_with_wrap_main_override_promise ()\n ~public_input:(Input Typ.unit) ~auxiliary_typ:Typ.unit\n ~branches:(module Nat.N1)\n ~max_proofs_verified:(module Nat.N2)\n ~name:\"recurse-on-bad\" ~constraint_constants\n ~choices:(fun ~self:_ ->\n [ { identifier = \"main\"\n ; feature_flags = Plonk_types.Features.none_bool\n ; prevs = [ tag; tag ]\n ; main =\n (fun { public_input = () } ->\n let proof =\n exists (Typ.Internal.ref ()) ~request:(fun () -> Proof)\n in\n { previous_proof_statements =\n [ { public_input = ()\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ; { public_input = ()\n ; proof\n ; proof_must_verify = Boolean.true_\n }\n ]\n ; public_output = ()\n ; auxiliary_output = ()\n } )\n }\n ] ) )\n\n module Proof = (val p)\n end\n\n let%test \"should not be able to create a recursive proof from an invalid \\\n proof\" =\n try\n let (), (), proof =\n Promise.block_on_async_exn (fun () ->\n Recurse_on_bad_proof.step\n ~handler:(Recurse_on_bad_proof.handler (snd proof_with_stmt))\n () )\n in\n Or_error.is_error\n @@ Promise.block_on_async_exn (fun () ->\n Recurse_on_bad_proof.Proof.verify_promise [ ((), proof) ] )\n with _ -> true\nend\n","module Make\n (Impl : Snarky_backendless.Snark_intf.Run) (B : sig\n open Impl\n\n val params : field Sponge.Params.t\n\n val to_the_alpha : field -> field\n\n module Operations : sig\n val apply_affine_map :\n field array array * field array -> field array -> field array\n end\n end) =\nstruct\n include Make_sponge.Rounds\n\n let round_table start =\n let ({ round_constants; mds } : _ Sponge.Params.t) = B.params in\n (* sbox -> mds -> ark *)\n let apply_round i s =\n let s' = Array.map s ~f:B.to_the_alpha in\n B.Operations.apply_affine_map (mds, round_constants.(i)) s'\n in\n let res =\n Array.init (rounds_full + 1) ~f:(fun _ ->\n Array.create ~len:3 Impl.Field.Constant.zero )\n in\n res.(0) <- start ;\n for i = 0 to rounds_full - 1 do\n res.(i + 1) <- apply_round i res.(i)\n done ;\n res\n\n module Field = Impl.Field\n\n let block_cipher (_params : _ Sponge.Params.t) init =\n let open Impl in\n Impl.with_label __LOC__ (fun () ->\n let t =\n exists\n (Typ.array\n ~length:Int.(rounds_full + 1)\n (Typ.array ~length:3 Field.typ) )\n ~compute:\n As_prover.(fun () -> round_table (Array.map init ~f:read_var))\n in\n t.(0) <- init ;\n (let open Kimchi_backend_common.Plonk_constraint_system.Plonk_constraint in\n with_label __LOC__ (fun () ->\n Impl.assert_\n { basic = T (Poseidon { state = t })\n ; annotation = Some \"plonk-poseidon\"\n } )) ;\n t.(Int.(Array.length t - 1)) )\n\n let add_assign ~state i x =\n state.(i) <- Util.seal (module Impl) Field.(state.(i) + x)\n\n let copy = Array.copy\nend\n","include Make_sponge.Make (Backend.Tock.Field)\n\nlet params = Kimchi_pasta_basic.poseidon_params_fq\n","open Core_kernel\nopen Backend\nopen Pickles_types\n\n(* The actual \"accumulator\" for the wrap proof contains a vector of elements,\n each of which is a vector of bulletproof challenges.\n\n The number of such vectors is equal to the maximum proofs-verified\n amongst all the step branches that that proof is wrapping.\n\n To simplify the implementation when the number of proofs-verified\n varies across proof systems (being either 0, 1, or 2) we secretly\n pad the accumulator so that it always has exactly 2 vectors, padding\n with dummy vectors.\n\n We also then pad with the corresponding dummy commitments when proving\n wrap statements, as in `pad_accumulator` which is used in wrap.ml.\n\n We add them to the **front**, not the back, of the vector of the actual\n \"real\" accumulator values so that we can precompute the sponge states\n resulting from absorbing the padding challenges\n*)\n\nmodule Padded_length = Nat.N2\n\n(* Pad up to length 2 by preprending dummy values. *)\nlet pad_vector (type a) ~dummy (v : (a, _) Vector.t) =\n Vector.extend_front_exn v Padded_length.n dummy\n\n(* Specialized padding function. *)\nlet pad_challenges (chalss : (_ Vector.t, _) Vector.t) =\n pad_vector ~dummy:(Lazy.force Dummy.Ipa.Wrap.challenges_computed) chalss\n\n(* Specialized padding function. *)\nlet pad_accumulator (xs : (Tock.Proof.Challenge_polynomial.t, _) Vector.t) =\n pad_vector xs\n ~dummy:\n { Tock.Proof.Challenge_polynomial.commitment =\n Lazy.force Dummy.Ipa.Wrap.sg\n ; challenges =\n Vector.to_array (Lazy.force Dummy.Ipa.Wrap.challenges_computed)\n }\n |> Vector.to_list\n\n(* Hash the me only, padding first. *)\nlet hash_messages_for_next_wrap_proof (type n) (_max_proofs_verified : n Nat.t)\n (t :\n ( Tick.Curve.Affine.t\n , (_, n) Vector.t )\n Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof.t ) =\n let t =\n { t with\n old_bulletproof_challenges = pad_challenges t.old_bulletproof_challenges\n }\n in\n Tock_field_sponge.digest Tock_field_sponge.params\n (Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof\n .to_field_elements t ~g1:(fun ((x, y) : Tick.Curve.Affine.t) -> [ x; y ])\n )\n\n(* Pad the messages_for_next_wrap_proof of a proof *)\nlet pad_proof (type mlmb) (T p : (mlmb, _) Proof.t) :\n Proof.Proofs_verified_max.t =\n T\n { p with\n statement =\n { p.statement with\n proof_state =\n { p.statement.proof_state with\n messages_for_next_wrap_proof =\n { p.statement.proof_state.messages_for_next_wrap_proof with\n old_bulletproof_challenges =\n pad_vector\n p.statement.proof_state.messages_for_next_wrap_proof\n .old_bulletproof_challenges\n ~dummy:Dummy.Ipa.Wrap.challenges\n }\n }\n }\n }\n\nmodule Checked = struct\n let pad_challenges (chalss : (_ Vector.t, _) Vector.t) =\n pad_vector\n ~dummy:\n (Vector.map ~f:Impls.Wrap.Field.constant\n (Lazy.force Dummy.Ipa.Wrap.challenges_computed) )\n chalss\n\n let pad_commitments (commitments : _ Vector.t) =\n pad_vector\n ~dummy:\n (Tuple_lib.Double.map ~f:Impls.Step.Field.constant\n (Lazy.force Dummy.Ipa.Wrap.sg) )\n commitments\n\n (* We precompute the sponge states that would result from absorbing\n 0, 1, or 2 dummy challenge vectors. This is used to speed up hashing\n inside the circuit. *)\n let dummy_messages_for_next_wrap_proof_sponge_states =\n lazy\n (let module S = Tock_field_sponge.Field in\n let full_state s = (S.state s, s.sponge_state) in\n let sponge = S.create Tock_field_sponge.params in\n let s0 = full_state sponge in\n let chals = Lazy.force Dummy.Ipa.Wrap.challenges_computed in\n Vector.iter ~f:(S.absorb sponge) chals ;\n let s1 = full_state sponge in\n Vector.iter ~f:(S.absorb sponge) chals ;\n let s2 = full_state sponge in\n [| s0; s1; s2 |] )\n\n let hash_constant_messages_for_next_wrap_proof =\n hash_messages_for_next_wrap_proof\n\n (* TODO: No need to hash the entire bulletproof challenges. Could\n just hash the segment of the public input LDE corresponding to them\n that we compute when verifying the previous proof. That is a commitment\n to them. *)\n let hash_messages_for_next_wrap_proof (type n) (max_proofs_verified : n Nat.t)\n (t :\n ( Wrap_main_inputs.Inner_curve.t\n , ((Impls.Wrap.Field.t, Backend.Tock.Rounds.n) Vector.t, n) Vector.t )\n Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof.t ) =\n let open Wrap_main_inputs in\n let sponge =\n (* The sponge states we would reach if we absorbed the padding challenges *)\n let s = Sponge.create sponge_params in\n let state, sponge_state =\n (Lazy.force dummy_messages_for_next_wrap_proof_sponge_states).(2\n - Nat\n .to_int\n max_proofs_verified)\n in\n { s with\n state = Array.map state ~f:Impls.Wrap.Field.constant\n ; sponge_state\n }\n in\n Array.iter ~f:(Sponge.absorb sponge)\n (Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof\n .to_field_elements ~g1:Inner_curve.to_field_elements t ) ;\n Sponge.squeeze_field sponge\n\n (* Check that the pre-absorbing technique works. I.e., that it's consistent with\n the actual definition of hash_messages_for_next_wrap_proof. *)\n let%test_unit \"hash_messages_for_next_wrap_proof correct\" =\n let open Impls.Wrap in\n let test (type n) (n : n Nat.t) =\n let messages_for_next_wrap_proof :\n _ Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof.t =\n let g = Wrap_main_inputs.Inner_curve.Constant.random () in\n { Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof\n .challenge_polynomial_commitment = g\n ; old_bulletproof_challenges =\n Vector.init n ~f:(fun _ ->\n Vector.init Tock.Rounds.n ~f:(fun _ -> Tock.Field.random ()) )\n }\n in\n Internal_Basic.Test.test_equal ~sexp_of_t:Field.Constant.sexp_of_t\n ~equal:Field.Constant.equal\n (Composition_types.Wrap.Proof_state.Messages_for_next_wrap_proof.typ\n Wrap_main_inputs.Inner_curve.typ\n (Vector.typ Field.typ Backend.Tock.Rounds.n)\n ~length:n )\n Field.typ\n (fun t -> make_checked (fun () -> hash_messages_for_next_wrap_proof n t))\n (fun t ->\n hash_constant_messages_for_next_wrap_proof n t\n |> Digest.Constant.to_bits |> Impls.Wrap.Field.Constant.project )\n messages_for_next_wrap_proof\n in\n test Nat.N0.n ; test Nat.N1.n ; test Nat.N2.n\nend\n","open Pickles_types\nopen Import\nopen Backend\n\ntype dlog_opening = (Tock.Curve.Affine.t, Tock.Field.t) Types.Step.Bulletproof.t\n\nmodule Constant = struct\n (* Out-of-circuit type for wrap proofs *)\n type t =\n { messages : Tock.Curve.Affine.t Plonk_types.Messages.t\n ; opening : dlog_opening\n }\n [@@deriving hlist]\nend\n\nopen Step_main_inputs\n\nmodule Checked = struct\n (* In-circuit type for wrap proofs *)\n type t =\n { messages :\n (Inner_curve.t, Impl.Boolean.var) Plonk_types.Messages.In_circuit.t\n ; opening :\n ( Inner_curve.t\n , Impls.Step.Other_field.t Shifted_value.Type2.t )\n Types.Step.Bulletproof.t\n }\n [@@deriving hlist]\nend\n\nopen Impls.Step\n\nlet typ : (Checked.t, Constant.t) Typ.t =\n let shift = Shifted_value.Type2.Shift.create (module Tock.Field) in\n Typ.of_hlistable ~var_to_hlist:Checked.to_hlist ~var_of_hlist:Checked.of_hlist\n ~value_to_hlist:Constant.to_hlist ~value_of_hlist:Constant.of_hlist\n [ Plonk_types.Messages.typ\n (module Impl)\n Inner_curve.typ Plonk_types.Features.Full.none ~bool:Boolean.typ\n ~dummy:Inner_curve.Params.one\n ~commitment_lengths:Commitment_lengths.default\n ; Types.Step.Bulletproof.typ ~length:(Nat.to_int Tock.Rounds.n)\n ( Typ.transport Other_field.typ\n ~there:(fun x ->\n (* When storing, make it a shifted value *)\n match\n Shifted_value.Type2.of_field (module Tock.Field) ~shift x\n with\n | Shifted_value x ->\n x )\n ~back:(fun x ->\n Shifted_value.Type2.to_field\n (module Tock.Field)\n ~shift (Shifted_value x) )\n (* When reading, unshift *)\n |> Typ.transport_var\n (* For the var, we just wrap the now shifted underlying value. *)\n ~there:(fun (Shifted_value.Type2.Shifted_value x) -> x)\n ~back:(fun x -> Shifted_value x) )\n Inner_curve.typ\n ]\n","open Core_kernel\n\ntype ('var, 'value, 'n1, 'n2) id = ('var * 'value * 'n1 * 'n2) Type_equal.Id.t\n\ntype kind = Side_loaded | Compiled\n\ntype ('var, 'value, 'n1, 'n2) t =\n { kind : kind; id : ('var, 'value, 'n1, 'n2) id }\n[@@deriving fields]\n\nlet create ?(kind = Compiled) name =\n { kind; id = Type_equal.Id.create ~name sexp_of_opaque }\n","open Pickles_types.Poly_types\nopen Pickles_types.Hlist\n\nmodule B = struct\n type t = Impls.Step.Boolean.var\nend\n\nmodule Previous_proof_statement = struct\n type ('prev_var, 'width) t =\n { public_input : 'prev_var\n ; proof : ('width, 'width) Proof.t Impls.Step.As_prover.Ref.t\n ; proof_must_verify : B.t\n }\n\n module Constant = struct\n type ('prev_value, 'width) t =\n { public_input : 'prev_value\n ; proof : ('width, 'width) Proof.t\n ; proof_must_verify : bool\n }\n end\nend\n\n(** This type relates the types of the input and output types of an inductive\n rule's [main] function to the type of the public input to the resulting\n circuit.\n*)\ntype ('var, 'value, 'input_var, 'input_value, 'ret_var, 'ret_value) public_input =\n | Input :\n ('var, 'value) Impls.Step.Typ.t\n -> ('var, 'value, 'var, 'value, unit, unit) public_input\n | Output :\n ('ret_var, 'ret_value) Impls.Step.Typ.t\n -> ('ret_var, 'ret_value, unit, unit, 'ret_var, 'ret_value) public_input\n | Input_and_output :\n ('var, 'value) Impls.Step.Typ.t * ('ret_var, 'ret_value) Impls.Step.Typ.t\n -> ( 'var * 'ret_var\n , 'value * 'ret_value\n , 'var\n , 'value\n , 'ret_var\n , 'ret_value )\n public_input\n\n(** The input type of an inductive rule's main function. *)\ntype 'public_input main_input =\n { public_input : 'public_input\n (** The publicly-exposed input to the circuit's main function. *)\n }\n\n(** The return type of an inductive rule's main function. *)\ntype ('prev_vars, 'widths, 'public_output, 'auxiliary_output) main_return =\n { previous_proof_statements :\n ('prev_vars, 'widths) H2.T(Previous_proof_statement).t\n (** A list of booleans, determining whether each previous proof must\n verify.\n *)\n ; public_output : 'public_output\n (** The publicly-exposed output from the circuit's main function. *)\n ; auxiliary_output : 'auxiliary_output\n (** The auxiliary output from the circuit's main function. This value\n is returned to the prover, but not exposed to or used by verifiers.\n *)\n }\n\n(** This type models an \"inductive rule\". It includes\n - the list of previous statements which this one assumes\n - the snarky main function\n\n The types parameters are:\n - ['prev_vars] the tuple-list of public input circuit types to the previous\n proofs.\n - For example, [Boolean.var * (Boolean.var * unit)] represents 2 previous\n proofs whose public inputs are booleans\n - ['prev_values] the tuple-list of public input non-circuit types to the\n previous proofs.\n - For example, [bool * (bool * unit)] represents 2 previous proofs whose\n public inputs are booleans.\n - ['widths] is a tuple list of the maximum number of previous proofs each\n previous proof itself had.\n - For example, [Nat.z Nat.s * (Nat.z * unit)] represents 2 previous\n proofs where the first has at most 1 previous proof and the second had\n zero previous proofs.\n - ['heights] is a tuple list of the number of inductive rules in each of\n the previous proofs\n - For example, [Nat.z Nat.s Nat.s * (Nat.z Nat.s * unit)] represents 2\n previous proofs where the first had 2 inductive rules and the second\n had 1.\n - ['a_var] is the in-circuit type of the [main] function's public input.\n - ['a_value] is the out-of-circuit type of the [main] function's public\n input.\n - ['ret_var] is the in-circuit type of the [main] function's public output.\n - ['ret_value] is the out-of-circuit type of the [main] function's public\n output.\n - ['auxiliary_var] is the in-circuit type of the [main] function's\n auxiliary data, to be returned to the prover but not exposed in the\n public input.\n - ['auxiliary_value] is the out-of-circuit type of the [main] function's\n auxiliary data, to be returned to the prover but not exposed in the\n public input.\n*)\ntype ( 'prev_vars\n , 'prev_values\n , 'widths\n , 'heights\n , 'a_var\n , 'a_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n t =\n { identifier : string\n ; prevs : ('prev_vars, 'prev_values, 'widths, 'heights) H4.T(Tag).t\n ; main :\n 'a_var main_input\n -> ('prev_vars, 'widths, 'ret_var, 'auxiliary_var) main_return\n ; feature_flags : bool Pickles_types.Plonk_types.Features.t\n }\n\nmodule T\n (Statement : T0)\n (Statement_value : T0)\n (Return_var : T0)\n (Return_value : T0)\n (Auxiliary_var : T0)\n (Auxiliary_value : T0) =\nstruct\n type nonrec ('prev_vars, 'prev_values, 'widths, 'heights) t =\n ( 'prev_vars\n , 'prev_values\n , 'widths\n , 'heights\n , Statement.t\n , Statement_value.t\n , Return_var.t\n , Return_value.t\n , Auxiliary_var.t\n , Auxiliary_value.t )\n t\nend\n","open Core_kernel\nopen Pickles_types\nopen Import\nopen Backend\n\n(* We maintain a global hash table which stores for each inductive proof system some\n data.\n*)\ntype inner_curve_var =\n Tick.Field.t Snarky_backendless.Cvar.t\n * Tick.Field.t Snarky_backendless.Cvar.t\n\nmodule Basic = struct\n type ('var, 'value, 'n1, 'n2) t =\n { max_proofs_verified : (module Nat.Add.Intf with type n = 'n1)\n ; public_input : ('var, 'value) Impls.Step.Typ.t\n ; branches : 'n2 Nat.t\n ; wrap_domains : Domains.t\n ; wrap_key : Tick.Inner_curve.Affine.t Plonk_verification_key_evals.t\n ; wrap_vk : Impls.Wrap.Verification_key.t\n ; feature_flags : Opt.Flag.t Plonk_types.Features.Full.t\n }\nend\n\nmodule Side_loaded = struct\n module Ephemeral = struct\n type t =\n { index :\n [ `In_circuit of Side_loaded_verification_key.Checked.t\n | `In_prover of Side_loaded_verification_key.t\n | `In_both of\n Side_loaded_verification_key.t\n * Side_loaded_verification_key.Checked.t ]\n }\n end\n\n module Permanent = struct\n type ('var, 'value, 'n1, 'n2) t =\n { max_proofs_verified : (module Nat.Add.Intf with type n = 'n1)\n ; public_input : ('var, 'value) Impls.Step.Typ.t\n ; feature_flags : Opt.Flag.t Plonk_types.Features.Full.t\n ; branches : 'n2 Nat.t\n }\n end\n\n type ('var, 'value, 'n1, 'n2) t =\n { ephemeral : Ephemeral.t option\n ; permanent : ('var, 'value, 'n1, 'n2) Permanent.t\n }\n\n type packed =\n | T : ('var, 'value, 'n1, 'n2) Tag.id * ('var, 'value, 'n1, 'n2) t -> packed\n\n let to_basic\n { permanent =\n { max_proofs_verified; public_input; branches; feature_flags }\n ; ephemeral\n } =\n let wrap_key, wrap_vk =\n match ephemeral with\n | Some { index = `In_prover i | `In_both (i, _) } ->\n (i.wrap_index, i.wrap_vk)\n | _ ->\n failwithf \"Side_loaded.to_basic: Expected `In_prover (%s)\" __LOC__ ()\n in\n let proofs_verified = Nat.to_int (Nat.Add.n max_proofs_verified) in\n let wrap_vk = Option.value_exn ~here:[%here] wrap_vk in\n { Basic.max_proofs_verified\n ; wrap_vk\n ; public_input\n ; branches\n ; wrap_domains = Common.wrap_domains ~proofs_verified\n ; wrap_key\n ; feature_flags\n }\nend\n\nmodule Compiled = struct\n type ('a_var, 'a_value, 'max_proofs_verified, 'branches) basic =\n { public_input : ('a_var, 'a_value) Impls.Step.Typ.t\n ; proofs_verifieds : (int, 'branches) Vector.t\n (* For each branch in this rule, how many predecessor proofs does it have? *)\n ; wrap_domains : Domains.t\n ; step_domains : (Domains.t, 'branches) Vector.t\n ; feature_flags : Opt.Flag.t Plonk_types.Features.Full.t\n }\n\n (* This is the data associated to an inductive proof system with statement type\n ['a_var], which has ['branches] many \"variants\" each of which depends on at most\n ['max_proofs_verified] many previous statements. *)\n type ('a_var, 'a_value, 'max_proofs_verified, 'branches) t =\n { branches : 'branches Nat.t\n ; max_proofs_verified :\n (module Nat.Add.Intf with type n = 'max_proofs_verified)\n ; proofs_verifieds : (int, 'branches) Vector.t\n (* For each branch in this rule, how many predecessor proofs does it have? *)\n ; public_input : ('a_var, 'a_value) Impls.Step.Typ.t\n ; wrap_key : Tick.Inner_curve.Affine.t Plonk_verification_key_evals.t Lazy.t\n ; wrap_vk : Impls.Wrap.Verification_key.t Lazy.t\n ; wrap_domains : Domains.t\n ; step_domains : (Domains.t, 'branches) Vector.t\n ; feature_flags : Opt.Flag.t Plonk_types.Features.Full.t\n }\n\n type packed =\n | T : ('var, 'value, 'n1, 'n2) Tag.id * ('var, 'value, 'n1, 'n2) t -> packed\n\n let to_basic\n { branches = _\n ; max_proofs_verified\n ; proofs_verifieds = _\n ; public_input\n ; wrap_vk\n ; wrap_domains\n ; step_domains\n ; wrap_key\n ; feature_flags\n } =\n { Basic.max_proofs_verified\n ; wrap_domains\n ; public_input\n ; branches = Vector.length step_domains\n ; wrap_key = Lazy.force wrap_key\n ; wrap_vk = Lazy.force wrap_vk\n ; feature_flags\n }\nend\n\nmodule For_step = struct\n type ('a_var, 'a_value, 'max_proofs_verified, 'branches) t =\n { branches : 'branches Nat.t\n ; max_proofs_verified :\n (module Nat.Add.Intf with type n = 'max_proofs_verified)\n ; proofs_verifieds :\n [ `Known of (Impls.Step.Field.t, 'branches) Vector.t | `Side_loaded ]\n ; public_input : ('a_var, 'a_value) Impls.Step.Typ.t\n ; wrap_key : inner_curve_var Plonk_verification_key_evals.t\n ; wrap_domain :\n [ `Known of Domain.t\n | `Side_loaded of\n Impls.Step.field Pickles_base.Proofs_verified.One_hot.Checked.t ]\n ; step_domains : [ `Known of (Domains.t, 'branches) Vector.t | `Side_loaded ]\n ; feature_flags : Opt.Flag.t Plonk_types.Features.Full.t\n }\n\n let of_side_loaded (type a b c d)\n ({ ephemeral\n ; permanent =\n { branches; max_proofs_verified; public_input; feature_flags }\n } :\n (a, b, c, d) Side_loaded.t ) : (a, b, c, d) t =\n let index =\n match ephemeral with\n | Some { index = `In_circuit i | `In_both (_, i) } ->\n i\n | _ ->\n failwithf \"For_step.side_loaded: Expected `In_circuit (%s)\" __LOC__ ()\n in\n let T = Nat.eq_exn branches Side_loaded_verification_key.Max_branches.n in\n { branches\n ; max_proofs_verified\n ; public_input\n ; proofs_verifieds = `Side_loaded\n ; wrap_key = index.wrap_index\n ; wrap_domain = `Side_loaded index.actual_wrap_domain_size\n ; step_domains = `Side_loaded\n ; feature_flags\n }\n\n let of_compiled\n ({ branches\n ; max_proofs_verified\n ; proofs_verifieds\n ; public_input\n ; wrap_key\n ; wrap_domains\n ; step_domains\n ; feature_flags\n ; wrap_vk = _\n } :\n _ Compiled.t ) =\n { branches\n ; max_proofs_verified\n ; proofs_verifieds =\n `Known (Vector.map proofs_verifieds ~f:Impls.Step.Field.of_int)\n ; public_input\n ; wrap_key =\n Plonk_verification_key_evals.map (Lazy.force wrap_key)\n ~f:Step_main_inputs.Inner_curve.constant\n ; wrap_domain = `Known wrap_domains.h\n ; step_domains = `Known step_domains\n ; feature_flags\n }\nend\n\ntype t =\n { compiled : Compiled.packed Type_equal.Id.Uid.Table.t\n ; side_loaded : Side_loaded.packed Type_equal.Id.Uid.Table.t\n }\n\nlet univ : t =\n { compiled = Type_equal.Id.Uid.Table.create ()\n ; side_loaded = Type_equal.Id.Uid.Table.create ()\n }\n\nlet find t k =\n match Hashtbl.find t k with None -> failwith \"key not found\" | Some x -> x\n\nlet lookup_compiled :\n type var value n m.\n (var, value, n, m) Tag.id -> (var, value, n, m) Compiled.t =\n fun t ->\n let (T (other_id, d)) = find univ.compiled (Type_equal.Id.uid t) in\n let T = Type_equal.Id.same_witness_exn t other_id in\n d\n\nlet lookup_side_loaded :\n type var value n m.\n (var, value, n, m) Tag.id -> (var, value, n, m) Side_loaded.t =\n fun t ->\n let (T (other_id, d)) = find univ.side_loaded (Type_equal.Id.uid t) in\n let T = Type_equal.Id.same_witness_exn t other_id in\n d\n\nlet lookup_basic :\n type var value n m. (var, value, n, m) Tag.t -> (var, value, n, m) Basic.t =\n fun t ->\n match t.kind with\n | Compiled ->\n Compiled.to_basic (lookup_compiled t.id)\n | Side_loaded ->\n Side_loaded.to_basic (lookup_side_loaded t.id)\n\nlet max_proofs_verified :\n type n1. (_, _, n1, _) Tag.t -> (module Nat.Add.Intf with type n = n1) =\n fun tag ->\n match tag.kind with\n | Compiled ->\n (lookup_compiled tag.id).max_proofs_verified\n | Side_loaded ->\n (lookup_side_loaded tag.id).permanent.max_proofs_verified\n\nlet public_input :\n type var value. (var, value, _, _) Tag.t -> (var, value) Impls.Step.Typ.t =\n fun tag ->\n match tag.kind with\n | Compiled ->\n (lookup_compiled tag.id).public_input\n | Side_loaded ->\n (lookup_side_loaded tag.id).permanent.public_input\n\nlet feature_flags :\n type var value.\n (var, value, _, _) Tag.t -> Opt.Flag.t Plonk_types.Features.Full.t =\n fun tag ->\n match tag.kind with\n | Compiled ->\n (lookup_compiled tag.id).feature_flags\n | Side_loaded ->\n (lookup_side_loaded tag.id).permanent.feature_flags\n\nlet _value_to_field_elements :\n type a. (_, a, _, _) Tag.t -> a -> Backend.Tick.Field.t array =\n fun t ->\n let (Typ typ) = public_input t in\n fun x -> fst (typ.value_to_fields x)\n\nlet _lookup_map (type var value c d) (t : (var, value, c, d) Tag.t) ~self\n ~default\n ~(f :\n [ `Compiled of (var, value, c, d) Compiled.t\n | `Side_loaded of (var, value, c, d) Side_loaded.t ]\n -> _ ) =\n match Type_equal.Id.same_witness t.id self with\n | Some _ ->\n default\n | None -> (\n match t.kind with\n | Compiled ->\n let (T (other_id, d)) = find univ.compiled (Type_equal.Id.uid t.id) in\n let T = Type_equal.Id.same_witness_exn t.id other_id in\n f (`Compiled d)\n | Side_loaded ->\n let (T (other_id, d)) =\n find univ.side_loaded (Type_equal.Id.uid t.id)\n in\n let T = Type_equal.Id.same_witness_exn t.id other_id in\n f (`Side_loaded d) )\n\nlet add_side_loaded ~name permanent =\n let (Tag.{ id; _ } as tag) = Tag.(create ~kind:Side_loaded name) in\n Hashtbl.add_exn univ.side_loaded ~key:(Type_equal.Id.uid id)\n ~data:(T (id, { ephemeral = None; permanent })) ;\n tag\n\nlet set_ephemeral { Tag.kind; id } (eph : Side_loaded.Ephemeral.t) =\n assert (match kind with Side_loaded -> true | Compiled -> false) ;\n Hashtbl.update univ.side_loaded (Type_equal.Id.uid id) ~f:(function\n | None ->\n assert false\n | Some (T (id, d)) ->\n let ephemeral =\n match (d.ephemeral, eph.index) with\n | None, _ | Some _, `In_prover _ ->\n (* Giving prover only always resets. *)\n Some eph\n | Some { index = `In_prover prover }, `In_circuit circuit\n | Some { index = `In_both (prover, _) }, `In_circuit circuit ->\n (* In-circuit extends prover if one was given. *)\n Some { index = `In_both (prover, circuit) }\n | _ ->\n (* Otherwise, just use the given value. *)\n Some eph\n in\n T (id, { d with ephemeral }) )\n\nlet add_exn (type var value c d) (tag : (var, value, c, d) Tag.t)\n (data : (var, value, c, d) Compiled.t) =\n Hashtbl.add_exn univ.compiled ~key:(Type_equal.Id.uid tag.id)\n ~data:(Compiled.T (tag.id, data))\n","open Backend\nopen Pickles_types\nopen Import\nmodule Impl = Impls.Step\nmodule One_hot_vector = One_hot_vector.Make (Impl)\n\n(* Let F, K be the two fields (either (Fp, Fq) or (Fq, Fp)).\n Each proof over F has an accumulator state which contains\n - a set of IPA challenges c_0, ..., c_{k-1}, which can be interpreted as F elements.\n - a polynomial commitment challenge_polynomial_commitment, which has coordinates in K.\n\n This part of the accumulator state is finalized by checking that challenge_polynomial_commitment\n is a commitment to the polynomial\n\n f_c := prod_{i = 0}^{k-1} (1 + c_i x^{2^{k-1 - i}})\n\n When incrementally-verifying such a proof in a K-circuit (since we need K-arithmetic to perform\n the group operations on the F-polynomial-commitments that constitute the proof),\n instead of checking this, we get an evaluation E_c at a random point zeta and check\n that challenge_polynomial_commitment opens to E_c at zeta. Then we will need to check that\n E_c = f_c(zeta) = prod_{i = 0}^{k-1} (1 + c_i zeta^{2^{k-1 - i}}).\n\n However, because we are then in a K-circuit, we cannot actually compute f_c(zeta), which requires\n F-arithmetic.\n\n Therefore, after incrementally verifying the F-proof, the challenges (c_0, ..., c_{k-1}) which are\n part of the accumulator of the F-proof we just incrementally verified, must remain part of\n the accumulator of the K-proof, along with E_c (or at least some kind of commitment to it, which is\n what we actually do).\n\n Then, when we incrementally verify that K-proof in an F-circuit, we will check that E_c was\n computed correctly using c_0, ..., c_{k-1} and they along with E_c can be discarded.\n\n So, to summarize, the accumulator state for each proof P (corresponding to an F-circuit)\n contains\n - a set of IPA challenges (thought of as K-elements) for every proof that it incrementally verified inside its circuit\n - a challenge_polynomial_commitment (coordinates in F) for every proof that it incrementally verified inside its circuit\n - a challenge_polynomial_commitment (coordinates in K) corresponding to P's own inner-product argument\n - a set of IPA challenges (thought of as F-elements) corresponding to P's own inner-product argument\n*)\n\ntype challenge = Challenge.Make(Impl).t\n\ntype scalar_challenge = challenge Scalar_challenge.t\n\n(** Represents a proof (along with its accumulation state) which wraps a\n \"step\" proof S on the other curve.\n\n To have some notation, the proof S itself comes from a circuit that verified\n up to 'max_proofs_verified many wrap proofs W_0, ..., W_max_proofs_verified.\n*)\ntype ('app_state, 'max_proofs_verified, 'num_branches) t =\n { app_state : 'app_state\n (** The user-level statement corresponding to this proof. *)\n ; wrap_proof : Wrap_proof.Checked.t\n (** The polynomial commitments, polynomial evaluations, and opening proof corresponding to\n this latest wrap proof.\n *)\n ; proof_state :\n ( challenge\n , scalar_challenge\n , Impl.Field.t Shifted_value.Type1.t\n , ( Impl.Field.t Pickles_types.Shifted_value.Type1.t\n , Impl.Boolean.var )\n Opt.t\n , (scalar_challenge, Impl.Boolean.var) Opt.t\n , Impl.Boolean.var\n , unit\n , Digest.Make(Impl).t\n , scalar_challenge Types.Bulletproof_challenge.t Types.Step_bp_vec.t\n , Impl.field Branch_data.Checked.t )\n Types.Wrap.Proof_state.In_circuit.t\n (** The accumulator state corresponding to the above proof. Contains\n - `deferred_values`: The values necessary for finishing the deferred \"scalar field\" computations.\n That is, computations which are over the \"step\" circuit's internal field that the\n previous \"wrap\" circuit was unable to verify directly, due to its internal field\n being different.\n - `sponge_digest_before_evaluations`: the sponge state: TODO\n - `messages_for_next_wrap_proof`\n *)\n ; prev_proof_evals :\n ( Impl.Field.t\n , Impl.Field.t array\n , Impl.Boolean.var )\n Plonk_types.All_evals.In_circuit.t\n (** The evaluations from the step proof that this proof wraps *)\n ; prev_challenges :\n ((Impl.Field.t, Tick.Rounds.n) Vector.t, 'max_proofs_verified) Vector.t\n (** The challenges c_0, ... c_{k - 1} corresponding to each W_i. *)\n ; prev_challenge_polynomial_commitments :\n (Step_main_inputs.Inner_curve.t, 'max_proofs_verified) Vector.t\n (** The commitments to the \"challenge polynomials\" \\prod_{i = 0}^k (1 + c_{k - 1 - i} x^{2^i})\n corresponding to each of the \"prev_challenges\".\n *)\n }\n[@@deriving hlist]\n\nmodule No_app_state = struct\n type nonrec (_, 'max_proofs_verified, 'num_branches) t =\n (unit, 'max_proofs_verified, 'num_branches) t\nend\n\nmodule Constant = struct\n type challenge = Challenge.Constant.t\n\n type scalar_challenge = challenge Scalar_challenge.t\n\n type ('statement, 'max_proofs_verified) t =\n { app_state : 'statement\n ; wrap_proof : Wrap_proof.Constant.t\n ; proof_state :\n ( challenge\n , scalar_challenge\n , Tick.Field.t Shifted_value.Type1.t\n , Tick.Field.t Shifted_value.Type1.t option\n , scalar_challenge option\n , bool\n , unit\n , Digest.Constant.t\n , scalar_challenge Types.Bulletproof_challenge.t Types.Step_bp_vec.t\n , Branch_data.t )\n Types.Wrap.Proof_state.In_circuit.t\n ; prev_proof_evals :\n (Tick.Field.t, Tick.Field.t array) Plonk_types.All_evals.t\n ; prev_challenges :\n ((Tick.Field.t, Tick.Rounds.n) Vector.t, 'max_proofs_verified) Vector.t\n ; prev_challenge_polynomial_commitments :\n (Tick.Inner_curve.Affine.t, 'max_proofs_verified) Vector.t\n }\n [@@deriving hlist]\n\n module No_app_state = struct\n type nonrec (_, 'max_proofs_verified, _) t = (unit, 'max_proofs_verified) t\n end\nend\n\nlet typ (type n avar aval) ~feature_flags\n (statement : (avar, aval) Impls.Step.Typ.t) (max_proofs_verified : n Nat.t)\n =\n let module Sc = Scalar_challenge in\n let open Impls.Step in\n let open Step_main_inputs in\n let open Step_verifier in\n Snarky_backendless.Typ.of_hlistable ~var_to_hlist:to_hlist\n ~var_of_hlist:of_hlist ~value_to_hlist:Constant.to_hlist\n ~value_of_hlist:Constant.of_hlist\n [ statement\n ; Wrap_proof.typ\n ; Types.Wrap.Proof_state.In_circuit.typ\n (module Impl)\n ~challenge:Challenge.typ ~scalar_challenge:Challenge.typ ~feature_flags\n ~dummy_scalar_challenge:(Sc.create Limb_vector.Challenge.Constant.zero)\n (Shifted_value.Type1.typ Field.typ)\n (Snarky_backendless.Typ.unit ())\n Digest.typ\n (Branch_data.typ\n (module Impl)\n ~assert_16_bits:(Step_verifier.assert_n_bits ~n:16) )\n ; Plonk_types.All_evals.typ\n (module Impl)\n (* Assume we have lookup iff we have runtime tables *)\n feature_flags\n ; Vector.typ (Vector.typ Field.typ Tick.Rounds.n) max_proofs_verified\n ; Vector.typ Inner_curve.typ max_proofs_verified\n ]\n","open Core_kernel\nopen Backend\nopen Impls.Step\nopen Pickles_types\nopen Common\nopen Import\nmodule Shifted_value = Shifted_value.Type2\n\n(* Unfinalized dlog-based proof, along with a flag which is true iff it\n is expected to verify. This allows for situations like the blockchain\n SNARK where we let the previous proof fail in the base case.\n*)\ntype t =\n ( Field.t\n , Field.t Scalar_challenge.t\n , Other_field.t Shifted_value.t\n , ( Field.t Scalar_challenge.t Bulletproof_challenge.t\n , Tock.Rounds.n )\n Pickles_types.Vector.t\n , Field.t\n , Boolean.var )\n Types.Step.Proof_state.Per_proof.In_circuit.t\n\nmodule Plonk_checks = struct\n include Plonk_checks\n include Plonk_checks.Make (Shifted_value) (Plonk_checks.Scalars.Tock)\nend\n\nmodule Constant = struct\n type t =\n ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Tock.Field.t Shifted_value.t\n , ( Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n , Tock.Rounds.n )\n Vector.t\n , Digest.Constant.t\n , bool )\n Types.Step.Proof_state.Per_proof.In_circuit.t\n\n let shift = Shifted_value.Shift.create (module Tock.Field)\n\n let dummy : t Lazy.t =\n lazy\n (let one_chal = Challenge.Constant.dummy in\n let open Ro in\n let alpha = scalar_chal () in\n let beta = chal () in\n let gamma = chal () in\n let zeta = scalar_chal () in\n let chals :\n _ Composition_types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.t\n =\n { alpha = Common.Ipa.Wrap.endo_to_field alpha\n ; beta = Challenge.Constant.to_tock_field beta\n ; gamma = Challenge.Constant.to_tock_field gamma\n ; zeta = Common.Ipa.Wrap.endo_to_field zeta\n ; joint_combiner = None\n ; feature_flags = Plonk_types.Features.none_bool\n }\n in\n let evals =\n Plonk_types.Evals.to_in_circuit\n (Lazy.force Dummy.evals_combined).evals.evals\n in\n let env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tock.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~srs_length_log2:Common.Max_degree.wrap_log2\n ~endo:Endo.Wrap_inner_curve.base ~mds:Tock_field_sponge.params.mds\n ~field_of_hex:\n (Core_kernel.Fn.compose Tock.Field.of_bigint (fun x ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string x ) )\n ~domain:\n (Plonk_checks.domain\n (module Tock.Field)\n (wrap_domains ~proofs_verified:2).h ~shifts:Common.tock_shifts\n ~domain_generator:Tock.Field.domain_generator )\n chals evals\n in\n let plonk =\n let module Field = struct\n include Tock.Field\n end in\n Plonk_checks.derive_plonk (module Field) ~env ~shift chals evals\n |> Composition_types.Step.Proof_state.Deferred_values.Plonk.In_circuit\n .of_wrap\n ~assert_none:(fun x -> assert (Option.is_none (Opt.to_option x)))\n ~assert_false:(fun x -> assert (not x))\n in\n { deferred_values =\n { plonk = { plonk with alpha; beta; gamma; zeta }\n ; combined_inner_product = Shifted_value (tock ())\n ; xi = Scalar_challenge.create one_chal\n ; bulletproof_challenges = Dummy.Ipa.Wrap.challenges\n ; b = Shifted_value (tock ())\n }\n ; should_finalize = false\n ; sponge_digest_before_evaluations = Digest.Constant.dummy\n } )\nend\n\nlet typ ~wrap_rounds:_ : (t, Constant.t) Typ.t =\n Types.Step.Proof_state.Per_proof.typ\n (module Impl)\n (Shifted_value.typ Other_field.typ)\n ~assert_16_bits:(Step_verifier.assert_n_bits ~n:16)\n\nlet dummy : unit -> t =\n Memo.unit (fun () ->\n let (Typ { var_of_fields; value_to_fields; _ }) =\n typ ~wrap_rounds:Backend.Tock.Rounds.n\n in\n let xs, aux = value_to_fields (Lazy.force Constant.dummy) in\n var_of_fields (Array.map ~f:Field.constant xs, aux) )\n","open Import\nopen Types\nopen Pickles_types\nopen Hlist\nopen Snarky_backendless.Request\nopen Backend\n\nmodule Wrap = struct\n module type S = sig\n type max_proofs_verified\n\n type max_local_max_proofs_verifieds\n\n open Impls.Wrap\n open Snarky_backendless.Request\n\n type _ t +=\n | Evals :\n ( (Field.Constant.t, Field.Constant.t array) Plonk_types.All_evals.t\n , max_proofs_verified )\n Vector.t\n t\n | Which_branch : int t\n | Step_accs : (Tock.Inner_curve.Affine.t, max_proofs_verified) Vector.t t\n | Old_bulletproof_challenges :\n max_local_max_proofs_verifieds H1.T(Challenges_vector.Constant).t t\n | Proof_state :\n ( ( ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Field.Constant.t Shifted_value.Type2.t\n , ( Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n , Tock.Rounds.n )\n Vector.t\n , Digest.Constant.t\n , bool )\n Types.Step.Proof_state.Per_proof.In_circuit.t\n , max_proofs_verified )\n Vector.t\n , Digest.Constant.t )\n Types.Step.Proof_state.t\n t\n | Messages : Tock.Inner_curve.Affine.t Plonk_types.Messages.t t\n | Openings_proof :\n ( Tock.Inner_curve.Affine.t\n , Tick.Field.t )\n Plonk_types.Openings.Bulletproof.t\n t\n | Wrap_domain_indices : (Field.Constant.t, max_proofs_verified) Vector.t t\n end\n\n type ('mb, 'ml) t =\n (module S\n with type max_proofs_verified = 'mb\n and type max_local_max_proofs_verifieds = 'ml )\n\n let create : type mb ml. unit -> (mb, ml) t =\n fun () ->\n let module R = struct\n type nonrec max_proofs_verified = mb\n\n type nonrec max_local_max_proofs_verifieds = ml\n\n open Snarky_backendless.Request\n\n type 'a vec = ('a, max_proofs_verified) Vector.t\n\n type _ t +=\n | Evals :\n (Tock.Field.t, Tock.Field.t array) Plonk_types.All_evals.t vec t\n | Which_branch : int t\n | Step_accs : Tock.Inner_curve.Affine.t vec t\n | Old_bulletproof_challenges :\n max_local_max_proofs_verifieds H1.T(Challenges_vector.Constant).t t\n | Proof_state :\n ( ( ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Tock.Field.t Shifted_value.Type2.t\n , ( Challenge.Constant.t Scalar_challenge.t\n Bulletproof_challenge.t\n , Tock.Rounds.n )\n Vector.t\n , Digest.Constant.t\n , bool )\n Types.Step.Proof_state.Per_proof.In_circuit.t\n , max_proofs_verified )\n Vector.t\n , Digest.Constant.t )\n Types.Step.Proof_state.t\n t\n | Messages : Tock.Inner_curve.Affine.t Plonk_types.Messages.t t\n | Openings_proof :\n ( Tock.Inner_curve.Affine.t\n , Tick.Field.t )\n Plonk_types.Openings.Bulletproof.t\n t\n | Wrap_domain_indices : (Tock.Field.t, max_proofs_verified) Vector.t t\n end in\n (module R)\nend\n\nmodule Step = struct\n module type S = sig\n type statement\n\n type return_value\n\n type prev_values\n\n type proofs_verified\n\n (* TODO: As an optimization this can be the local proofs-verified size *)\n type max_proofs_verified\n\n type local_signature\n\n type local_branches\n\n type auxiliary_value\n\n type _ t +=\n | Compute_prev_proof_parts :\n ( prev_values\n , local_signature )\n H2.T(Inductive_rule.Previous_proof_statement.Constant).t\n -> unit t\n | Proof_with_datas :\n ( prev_values\n , local_signature\n , local_branches )\n H3.T(Per_proof_witness.Constant.No_app_state).t\n t\n | Wrap_index : Tock.Curve.Affine.t Plonk_verification_key_evals.t t\n | App_state : statement t\n | Return_value : return_value -> unit t\n | Auxiliary_value : auxiliary_value -> unit t\n | Unfinalized_proofs :\n (Unfinalized.Constant.t, proofs_verified) Vector.t t\n | Messages_for_next_wrap_proof :\n (Digest.Constant.t, max_proofs_verified) Vector.t t\n | Wrap_domain_indices :\n (Pickles_base.Proofs_verified.t, proofs_verified) Vector.t t\n end\n\n let create :\n type proofs_verified local_signature local_branches statement return_value auxiliary_value prev_values max_proofs_verified.\n unit\n -> (module S\n with type local_signature = local_signature\n and type local_branches = local_branches\n and type statement = statement\n and type return_value = return_value\n and type auxiliary_value = auxiliary_value\n and type prev_values = prev_values\n and type proofs_verified = proofs_verified\n and type max_proofs_verified = max_proofs_verified ) =\n fun () ->\n let module R = struct\n type nonrec max_proofs_verified = max_proofs_verified\n\n type nonrec proofs_verified = proofs_verified\n\n type nonrec statement = statement\n\n type nonrec return_value = return_value\n\n type nonrec auxiliary_value = auxiliary_value\n\n type nonrec prev_values = prev_values\n\n type nonrec local_signature = local_signature\n\n type nonrec local_branches = local_branches\n\n type _ t +=\n | Compute_prev_proof_parts :\n ( prev_values\n , local_signature )\n H2.T(Inductive_rule.Previous_proof_statement.Constant).t\n -> unit t\n | Proof_with_datas :\n ( prev_values\n , local_signature\n , local_branches )\n H3.T(Per_proof_witness.Constant.No_app_state).t\n t\n | Wrap_index : Tock.Curve.Affine.t Plonk_verification_key_evals.t t\n | App_state : statement t\n | Return_value : return_value -> unit t\n | Auxiliary_value : auxiliary_value -> unit t\n | Unfinalized_proofs :\n (Unfinalized.Constant.t, proofs_verified) Vector.t t\n | Messages_for_next_wrap_proof :\n (Digest.Constant.t, max_proofs_verified) Vector.t t\n | Wrap_domain_indices :\n (Pickles_base.Proofs_verified.t, proofs_verified) Vector.t t\n end in\n (module R)\nend\n","open Core_kernel\n\nlet l = ref \"\"\n\nlet r = ref (Time.now ())\n\nlet start =\n Common.when_profiling\n (fun loc ->\n r := Time.now () ;\n l := loc )\n ignore\n\nlet clock =\n Common.when_profiling\n (fun loc ->\n let t = Time.now () in\n printf \"%s -> %s: %s\\n%!\" !l loc\n (Time.Span.to_string_hum (Time.diff t !r)) ;\n r := t ;\n l := loc )\n ignore\n","open Core_kernel\nopen Import\n\nlet zk_rows = 3\n\nlet rough_domains =\n let d = Domain.Pow_2_roots_of_unity 20 in\n { Domains.h = d }\n\nlet domains (type field gates) ?feature_flags\n (module Impl : Snarky_backendless.Snark_intf.Run\n with type field = field\n and type R1CS_constraint_system.t = ( field\n , gates )\n Kimchi_backend_common\n .Plonk_constraint_system\n .t )\n (Spec.ETyp.T (typ, conv, _conv_inv))\n (Spec.ETyp.T (return_typ, _ret_conv, ret_conv_inv)) main =\n let main x () = ret_conv_inv (main (conv x)) in\n\n let domains2 sys =\n let open Domain in\n (* Compute the domain required for the lookup tables *)\n let lookup_table_length_log2 =\n match feature_flags with\n | None ->\n 0\n | Some feature_flags ->\n let { Pickles_types.Plonk_types.Features.range_check0\n ; range_check1\n ; foreign_field_add =\n _\n (* Does not use lookup tables, therefore we do\n not need in the computation *)\n ; foreign_field_mul\n ; xor\n ; rot\n ; lookup\n ; runtime_tables\n } =\n feature_flags\n in\n let combined_lookup_table_length =\n let range_check_table_used =\n range_check0 || range_check1 || foreign_field_mul || rot\n in\n let xor_table_used = xor in\n (if range_check_table_used then Int.pow 2 12 else 0)\n + (if xor_table_used then Int.pow 2 8 else 0)\n + ( if lookup then (\n Kimchi_backend_common.Plonk_constraint_system\n .finalize_fixed_lookup_tables sys ;\n Kimchi_backend_common.Plonk_constraint_system\n .get_concatenated_fixed_lookup_table_size sys )\n else 0 )\n +\n if runtime_tables then (\n Kimchi_backend_common.Plonk_constraint_system\n .finalize_runtime_lookup_tables sys ;\n Kimchi_backend_common.Plonk_constraint_system\n .get_concatenated_runtime_lookup_table_size sys )\n else 0\n in\n\n Int.ceil_log2 (combined_lookup_table_length + zk_rows + 1)\n in\n let public_input_size =\n Set_once.get_exn\n (Impl.R1CS_constraint_system.get_public_input_size sys)\n [%here]\n in\n let rows =\n zk_rows + public_input_size + Impl.R1CS_constraint_system.get_rows_len sys\n in\n { Domains.h =\n Pow_2_roots_of_unity Int.(max lookup_table_length_log2 (ceil_log2 rows))\n }\n in\n domains2 (Impl.constraint_system ~input_typ:typ ~return_typ main)\n","open Core_kernel\nopen Pickles_types\nopen Import\nopen Kimchi_pasta.Pasta\n\nmodule Verifier_index_json = struct\n module Lookup = struct\n type 't lookup_selectors =\n 't Kimchi_types.VerifierIndex.Lookup.lookup_selectors =\n { lookup : 't option\n ; xor : 't option\n ; range_check : 't option\n ; ffmul : 't option\n }\n [@@deriving yojson]\n\n type lookup_pattern = Kimchi_types.lookup_pattern =\n | Xor\n | Lookup\n | RangeCheck\n | ForeignFieldMul\n [@@deriving yojson]\n\n type lookup_patterns = Kimchi_types.lookup_patterns =\n { xor : bool\n ; lookup : bool\n ; range_check : bool\n ; foreign_field_mul : bool\n }\n [@@deriving yojson]\n\n type lookup_features = Kimchi_types.lookup_features =\n { patterns : lookup_patterns\n ; joint_lookup_used : bool\n ; uses_runtime_tables : bool\n }\n [@@deriving yojson]\n\n type lookup_info = Kimchi_types.VerifierIndex.Lookup.lookup_info =\n { max_per_row : int; max_joint_size : int; features : lookup_features }\n [@@deriving yojson]\n\n type 'polyComm t = 'polyComm Kimchi_types.VerifierIndex.Lookup.t =\n { joint_lookup_used : bool\n ; lookup_table : 'polyComm array\n ; lookup_selectors : 'polyComm lookup_selectors\n ; table_ids : 'polyComm option\n ; lookup_info : lookup_info\n ; runtime_tables_selector : 'polyComm option\n }\n [@@deriving yojson]\n end\n\n type 'fr domain = 'fr Kimchi_types.VerifierIndex.domain =\n { log_size_of_group : int; group_gen : 'fr }\n [@@deriving yojson]\n\n type 'polyComm verification_evals =\n 'polyComm Kimchi_types.VerifierIndex.verification_evals =\n { sigma_comm : 'polyComm array\n ; coefficients_comm : 'polyComm array\n ; generic_comm : 'polyComm\n ; psm_comm : 'polyComm\n ; complete_add_comm : 'polyComm\n ; mul_comm : 'polyComm\n ; emul_comm : 'polyComm\n ; endomul_scalar_comm : 'polyComm\n ; xor_comm : 'polyComm option\n ; range_check0_comm : 'polyComm option\n ; range_check1_comm : 'polyComm option\n ; foreign_field_add_comm : 'polyComm option\n ; foreign_field_mul_comm : 'polyComm option\n ; rot_comm : 'polyComm option\n }\n [@@deriving yojson]\n\n type ('fr, 'sRS, 'polyComm) verifier_index =\n ('fr, 'sRS, 'polyComm) Kimchi_types.VerifierIndex.verifier_index =\n { domain : 'fr domain\n ; max_poly_size : int\n ; public : int\n ; prev_challenges : int\n ; srs : 'sRS\n ; evals : 'polyComm verification_evals\n ; shifts : 'fr array\n ; lookup_index : 'polyComm Lookup.t option\n }\n [@@deriving yojson]\n\n type 'f or_infinity = 'f Kimchi_types.or_infinity =\n | Infinity\n | Finite of ('f * 'f)\n [@@deriving yojson]\n\n type 'g polycomm = 'g Kimchi_types.poly_comm =\n { unshifted : 'g array; shifted : 'g option }\n [@@deriving yojson]\n\n let to_yojson fp fq =\n verifier_index_to_yojson fp\n (fun _ -> `Null)\n (polycomm_to_yojson (or_infinity_to_yojson fq))\nend\n\nmodule Data = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = { constraints : int } [@@deriving yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Repr = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n { commitments :\n Backend.Tock.Curve.Affine.Stable.V1.t\n Plonk_verification_key_evals.Stable.V2.t\n ; data : Data.Stable.V1.t\n }\n [@@deriving to_yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\n[%%versioned_binable\nmodule Stable = struct\n module V2 = struct\n type t =\n { commitments : Backend.Tock.Curve.Affine.t Plonk_verification_key_evals.t\n ; index :\n (Impls.Wrap.Verification_key.t\n [@to_yojson\n Verifier_index_json.to_yojson Backend.Tock.Field.to_yojson\n Backend.Tick.Field.to_yojson] )\n ; data : Data.t\n }\n [@@deriving fields, to_yojson]\n\n let to_latest = Fn.id\n\n let of_repr srs { Repr.commitments = c; data = d } =\n let t : Impls.Wrap.Verification_key.t =\n let log2_size = Int.ceil_log2 d.constraints in\n let public =\n let (T (input, _conv, _conv_inv)) =\n Impls.Wrap.input ~feature_flags:Plonk_types.Features.Full.maybe ()\n in\n let (Typ typ) = input in\n typ.size_in_field_elements\n in\n { domain =\n { log_size_of_group = log2_size\n ; group_gen = Backend.Tock.Field.domain_generator ~log2_size\n }\n ; max_poly_size = 1 lsl Nat.to_int Rounds.Wrap.n\n ; public\n ; prev_challenges = 2 (* Due to Wrap_hack *)\n ; srs\n ; evals =\n (let g (x, y) =\n { Kimchi_types.unshifted = [| Kimchi_types.Finite (x, y) |]\n ; shifted = None\n }\n in\n { sigma_comm = Array.map ~f:g (Vector.to_array c.sigma_comm)\n ; coefficients_comm =\n Array.map ~f:g (Vector.to_array c.coefficients_comm)\n ; generic_comm = g c.generic_comm\n ; mul_comm = g c.mul_comm\n ; psm_comm = g c.psm_comm\n ; emul_comm = g c.emul_comm\n ; complete_add_comm = g c.complete_add_comm\n ; endomul_scalar_comm = g c.endomul_scalar_comm\n ; xor_comm = None\n ; range_check0_comm = None\n ; range_check1_comm = None\n ; foreign_field_add_comm = None\n ; foreign_field_mul_comm = None\n ; rot_comm = None\n } )\n ; shifts = Common.tock_shifts ~log2_size\n ; lookup_index = None\n }\n in\n { commitments = c; data = d; index = t }\n\n include\n Binable.Of_binable\n (Repr.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable { commitments; data; index = _ } =\n { Repr.commitments; data }\n\n let of_binable r = of_repr (Backend.Tock.Keypair.load_urs ()) r\n end)\n end\nend]\n\nlet to_yojson = Stable.Latest.to_yojson\n\nlet dummy_commitments g =\n let open Plonk_types in\n { Plonk_verification_key_evals.sigma_comm =\n Vector.init Permuts.n ~f:(fun _ -> g)\n ; coefficients_comm = Vector.init Columns.n ~f:(fun _ -> g)\n ; generic_comm = g\n ; psm_comm = g\n ; complete_add_comm = g\n ; mul_comm = g\n ; emul_comm = g\n ; endomul_scalar_comm = g\n }\n\nlet dummy_step_commitments g =\n let open Plonk_types in\n { Plonk_verification_key_evals.Step.sigma_comm =\n Vector.init Permuts.n ~f:(fun _ -> g)\n ; coefficients_comm = Vector.init Columns.n ~f:(fun _ -> g)\n ; generic_comm = g\n ; psm_comm = g\n ; complete_add_comm = g\n ; mul_comm = g\n ; emul_comm = g\n ; endomul_scalar_comm = g\n ; xor_comm = None\n ; range_check0_comm = None\n ; range_check1_comm = None\n ; foreign_field_add_comm = None\n ; foreign_field_mul_comm = None\n ; rot_comm = None\n ; lookup_table_comm = Vector.init Lookup_sorted_minus_1.n ~f:(fun _ -> None)\n ; lookup_table_ids = None\n ; runtime_tables_selector = None\n ; lookup_selector_lookup = None\n ; lookup_selector_xor = None\n ; lookup_selector_range_check = None\n ; lookup_selector_ffmul = None\n }\n\nlet dummy =\n lazy\n (let rows = Domain.size (Common.wrap_domains ~proofs_verified:2).h in\n let g = Backend.Tock.Curve.(to_affine_exn one) in\n { Repr.commitments = dummy_commitments g; data = { constraints = rows } }\n |> Stable.Latest.of_repr (Kimchi_bindings.Protocol.SRS.Fq.create 1) )\n","open Core_kernel\nopen Pickles_types\nopen Import\nopen Poly_types\n\n(* Compute the domains corresponding to wrap_main *)\n\n(* TODO: this functor does not depend on any of its argument why? *)\n\nmodule Make\n (A : T0)\n (A_value : T0)\n (Ret_var : T0)\n (Ret_value : T0)\n (Auxiliary_var : T0)\n (Auxiliary_value : T0) =\nstruct\n let f_debug full_signature _num_choices choices_length ~feature_flags\n ~max_proofs_verified =\n let num_choices = Hlist.Length.to_nat choices_length in\n let dummy_step_domains =\n Vector.init num_choices ~f:(fun _ -> Fix_domains.rough_domains)\n in\n let dummy_step_widths =\n Vector.init num_choices ~f:(fun _ ->\n Nat.to_int (Nat.Add.n max_proofs_verified) )\n in\n let dummy_step_keys =\n lazy\n (Vector.init num_choices ~f:(fun _ ->\n let g = Backend.Tock.Inner_curve.(to_affine_exn one) in\n Verification_key.dummy_step_commitments g ) )\n in\n Timer.clock __LOC__ ;\n let srs = Backend.Tick.Keypair.load_urs () in\n let _, main =\n Wrap_main.wrap_main ~feature_flags ~srs full_signature choices_length\n dummy_step_keys dummy_step_widths dummy_step_domains max_proofs_verified\n in\n Timer.clock __LOC__ ;\n let t =\n Fix_domains.domains\n (module Impls.Wrap)\n (Impls.Wrap.input ~feature_flags ())\n (T (Snarky_backendless.Typ.unit (), Fn.id, Fn.id))\n main\n in\n Timer.clock __LOC__ ; t\n\n let f full_signature num_choices choices_length ~feature_flags\n ~max_proofs_verified =\n let res =\n Common.wrap_domains\n ~proofs_verified:(Nat.to_int (Nat.Add.n max_proofs_verified))\n in\n ( if debug then\n let res' =\n f_debug full_signature num_choices choices_length ~feature_flags\n ~max_proofs_verified\n in\n [%test_eq: Domains.t] res res' ) ;\n res\nend\n[@@warning \"-60\"]\n","module SC = Scalar_challenge\nmodule P = Proof\nopen Pickles_types\nopen Hlist\nopen Common\nopen Import\nopen Types\nopen Backend\n\n(* This contains the \"wrap\" prover *)\n\nlet challenge_polynomial =\n Wrap_verifier.challenge_polynomial (module Backend.Tick.Field)\n\nmodule Type1 =\n Plonk_checks.Make\n (Shifted_value.Type1)\n (struct\n let constant_term = Plonk_checks.Scalars.Tick.constant_term\n\n let index_terms = Plonk_checks.Scalars.Tick.index_terms\n end)\n\nlet _vector_of_list (type a t)\n (module V : Snarky_intf.Vector.S with type elt = a and type t = t)\n (xs : a list) : t =\n let r = V.create () in\n List.iter xs ~f:(V.emplace_back r) ;\n r\n\nlet tick_rounds = Nat.to_int Tick.Rounds.n\n\nlet combined_inner_product (type actual_proofs_verified) ~env ~domain ~ft_eval1\n ~actual_proofs_verified:\n (module AB : Nat.Add.Intf with type n = actual_proofs_verified)\n (e : _ Plonk_types.All_evals.With_public_input.t)\n ~(old_bulletproof_challenges : (_, actual_proofs_verified) Vector.t) ~r\n ~plonk ~xi ~zeta ~zetaw =\n let combined_evals =\n Plonk_checks.evals_of_split_evals ~zeta ~zetaw\n (module Tick.Field)\n ~rounds:tick_rounds e.evals\n in\n let ft_eval0 : Tick.Field.t =\n Type1.ft_eval0\n (module Tick.Field)\n plonk ~env ~domain\n (Plonk_types.Evals.to_in_circuit combined_evals)\n (fst e.public_input)\n in\n let T = AB.eq in\n let challenge_polys =\n Vector.map\n ~f:(fun chals -> unstage (challenge_polynomial (Vector.to_array chals)))\n old_bulletproof_challenges\n in\n let a = Plonk_types.Evals.to_list e.evals in\n let combine ~which_eval ~ft pt =\n let f (x, y) = match which_eval with `Fst -> x | `Snd -> y in\n let a = List.map ~f a in\n let v : Tick.Field.t array list =\n List.append\n (List.map (Vector.to_list challenge_polys) ~f:(fun f -> [| f pt |]))\n ([| f e.public_input |] :: [| ft |] :: a)\n in\n let open Tick.Field in\n Pcs_batch.combine_split_evaluations ~xi ~init:Fn.id\n ~mul_and_add:(fun ~acc ~xi fx -> fx + (xi * acc))\n v\n in\n let open Tick.Field in\n combine ~which_eval:`Fst ~ft:ft_eval0 zeta\n + (r * combine ~which_eval:`Snd ~ft:ft_eval1 zetaw)\n\nmodule Deferred_values = Types.Wrap.Proof_state.Deferred_values\n\ntype scalar_challenge_constant = Challenge.Constant.t Scalar_challenge.t\n\ntype deferred_values_and_hints =\n { x_hat_evals : Backend.Tick.Field.t * Backend.Tick.Field.t\n ; sponge_digest_before_evaluations : Tick.Field.t\n ; deferred_values :\n ( ( Challenge.Constant.t\n , scalar_challenge_constant\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , (Tick.Field.t Shifted_value.Type1.t, bool) Opt.t\n , (scalar_challenge_constant, bool) Opt.t\n , bool )\n Deferred_values.Plonk.In_circuit.t\n , scalar_challenge_constant\n , Tick.Field.t Shifted_value.Type1.t\n , Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n , Branch_data.t )\n Deferred_values.t\n }\n\nlet deferred_values (type n) ~(sgs : (Backend.Tick.Curve.Affine.t, n) Vector.t)\n ~actual_feature_flags\n ~(prev_challenges : ((Backend.Tick.Field.t, _) Vector.t, n) Vector.t)\n ~(step_vk : Kimchi_bindings.Protocol.VerifierIndex.Fp.t)\n ~(public_input : Backend.Tick.Field.t list) ~(proof : Backend.Tick.Proof.t)\n ~(actual_proofs_verified : n Nat.t) : deferred_values_and_hints =\n let module O = Tick.Oracles in\n let o =\n O.create step_vk\n Vector.(\n map2 sgs prev_challenges ~f:(fun commitment cs ->\n { Tick.Proof.Challenge_polynomial.commitment\n ; challenges = Vector.to_array cs\n } )\n |> to_list)\n public_input proof\n in\n let x_hat = O.(p_eval_1 o, p_eval_2 o) in\n let scalar_chal f =\n Scalar_challenge.map ~f:Challenge.Constant.of_tick_field (f o)\n in\n let plonk0 =\n { Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.alpha =\n scalar_chal O.alpha\n ; beta = O.beta o\n ; gamma = O.gamma o\n ; zeta = scalar_chal O.zeta\n ; joint_combiner =\n (* TODO: Needs to be changed when lookups are fully implemented *)\n Option.map (O.joint_combiner_chal o)\n ~f:(Scalar_challenge.map ~f:Challenge.Constant.of_tick_field)\n ; feature_flags = actual_feature_flags\n }\n in\n let r = scalar_chal O.u in\n let xi = scalar_chal O.v in\n let module As_field = struct\n let to_field =\n SC.to_field_constant\n (module Tick.Field)\n ~endo:Endo.Wrap_inner_curve.scalar\n\n let r = to_field r\n\n let xi = to_field xi\n\n let zeta = to_field plonk0.zeta\n\n let alpha = to_field plonk0.alpha\n\n let joint_combiner = Option.map ~f:to_field plonk0.joint_combiner\n end in\n let domain = Domain.Pow_2_roots_of_unity step_vk.domain.log_size_of_group in\n let zetaw = Tick.Field.mul As_field.zeta step_vk.domain.group_gen in\n let tick_plonk_minimal =\n { plonk0 with\n zeta = As_field.zeta\n ; alpha = As_field.alpha\n ; joint_combiner = As_field.joint_combiner\n }\n in\n let tick_combined_evals =\n Plonk_checks.evals_of_split_evals\n (module Tick.Field)\n proof.openings.evals ~rounds:(Nat.to_int Tick.Rounds.n)\n ~zeta:As_field.zeta ~zetaw\n |> Plonk_types.Evals.to_in_circuit\n in\n let tick_domain =\n Plonk_checks.domain\n (module Tick.Field)\n domain ~shifts:Common.tick_shifts\n ~domain_generator:Backend.Tick.Field.domain_generator\n in\n let tick_env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tick.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~endo:Endo.Step_inner_curve.base ~mds:Tick_field_sponge.params.mds\n ~srs_length_log2:Common.Max_degree.step_log2\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fp.of_bigint )\n ~domain:tick_domain tick_plonk_minimal tick_combined_evals\n in\n let plonk =\n let module Field = struct\n include Tick.Field\n end in\n Type1.derive_plonk\n (module Field)\n ~shift:Shifts.tick1 ~env:tick_env tick_plonk_minimal tick_combined_evals\n and new_bulletproof_challenges, b =\n let prechals =\n Array.map (O.opening_prechallenges o) ~f:(fun x ->\n Scalar_challenge.map ~f:Challenge.Constant.of_tick_field x )\n in\n let chals = Array.map prechals ~f:(fun x -> Ipa.Step.compute_challenge x) in\n let challenge_poly = unstage (challenge_polynomial chals) in\n let open As_field in\n let b =\n let open Tick.Field in\n challenge_poly zeta + (r * challenge_poly zetaw)\n in\n let prechals = Array.map prechals ~f:Bulletproof_challenge.unpack in\n (prechals, b)\n in\n let shift_value =\n Shifted_value.Type1.of_field (module Tick.Field) ~shift:Shifts.tick1\n and chal = Challenge.Constant.of_tick_field in\n { deferred_values =\n { Types.Wrap.Proof_state.Deferred_values.xi\n ; b = shift_value b\n ; bulletproof_challenges =\n Vector.of_array_and_length_exn new_bulletproof_challenges\n Tick.Rounds.n\n ; combined_inner_product =\n shift_value\n As_field.(\n combined_inner_product (* Note: We do not pad here. *)\n ~actual_proofs_verified:(Nat.Add.create actual_proofs_verified)\n { evals = proof.openings.evals; public_input = x_hat }\n ~r ~xi ~zeta ~zetaw ~old_bulletproof_challenges:prev_challenges\n ~env:tick_env ~domain:tick_domain\n ~ft_eval1:proof.openings.ft_eval1 ~plonk:tick_plonk_minimal)\n ; branch_data =\n { proofs_verified =\n ( match actual_proofs_verified with\n | Z ->\n Branch_data.Proofs_verified.N0\n | S Z ->\n N1\n | S (S Z) ->\n N2\n | S _ ->\n assert false )\n ; domain_log2 =\n Branch_data.Domain_log2.of_int_exn\n step_vk.domain.log_size_of_group\n }\n ; plonk =\n { plonk with\n zeta = plonk0.zeta\n ; alpha = plonk0.alpha\n ; beta = chal plonk0.beta\n ; gamma = chal plonk0.gamma\n ; joint_combiner = Opt.of_option plonk0.joint_combiner\n }\n }\n ; x_hat_evals = x_hat\n ; sponge_digest_before_evaluations = O.digest_before_evaluations o\n }\n\n(* Testing\n -------\n\n Invocation:\n dune exec src/lib/pickles/.pickles.inline-tests/inline_test_runner_pickles.exe \\\n --profile=dev --display short -- inline-test-runner pickles -only-test wrap.ml\n*)\nlet%test_module \"gate finalization\" =\n ( module struct\n type test_options =\n { true_is_yes : Plonk_types.Features.options\n ; true_is_maybe : Plonk_types.Features.options\n ; all_maybes : Plonk_types.Features.options\n }\n\n (* Helper function to convert actual feature flags into 3 test configurations of feature flags\n @param actual_feature_flags The actual feature flags in terms of true/false\n\n @return Corresponding feature flags configs composed of Yes/No/Maybe options\n - one where true is mapped to Yes and false is mapped to No\n - one where true is mapped to Maybe and false is mapped to No\n - one where true and false are both mapped to Maybe *)\n let generate_test_feature_flag_configs\n (actual_feature_flags : Plonk_types.Features.flags) : test_options =\n (* Set up a helper to convert actual feature flags composed of booleans into\n feature flags composed of Yes/No/Maybe options.\n @param actual_feature_flags The actual feature flags in terms of true/false\n @param true_opt Opt type to use for true/enabled features\n @param false_opt Opt type to use for false/disabled features\n @return Corresponding feature flags composed of Yes/No/Maybe values *)\n let compute_feature_flags\n (actual_feature_flags : Plonk_types.Features.flags)\n (true_opt : Opt.Flag.t) (false_opt : Opt.Flag.t) :\n Plonk_types.Features.options =\n Plonk_types.Features.map actual_feature_flags ~f:(function\n | true ->\n true_opt\n | false ->\n false_opt )\n in\n\n (* Generate the 3 configurations of the actual feature flags using\n helper *)\n let open Opt.Flag in\n { true_is_yes = compute_feature_flags actual_feature_flags Yes No\n ; true_is_maybe = compute_feature_flags actual_feature_flags Maybe No\n ; all_maybes = compute_feature_flags actual_feature_flags Maybe Maybe\n }\n\n (* Run the recursive proof tests on the supplied inputs.\n\n @param actual_feature_flags User-specified feature flags, matching those\n required by the backend circuit\n @param public_input list of public inputs (can be empty)\n @param vk Verifier index for backend circuit\n @param proof Backend proof\n\n @return true or throws and exception\n *)\n let run_recursive_proof_test\n (actual_feature_flags : Plonk_types.Features.flags)\n (feature_flags : Plonk_types.Features.options)\n (public_input : Pasta_bindings.Fp.t list)\n (vk : Kimchi_bindings.Protocol.VerifierIndex.Fp.t)\n (proof : Backend.Tick.Proof.t) : Impls.Step.Boolean.value =\n (* Constants helper - takes an OCaml value and converts it to a snarky value, where\n all values here are constant literals. N.b. this should be\n encapsulated as Snarky internals, but it never got merged. *)\n let constant (Typ typ : _ Snarky_backendless.Typ.t) x =\n let xs, aux = typ.value_to_fields x in\n typ.var_of_fields (Array.map xs ~f:Impls.Step.Field.constant, aux)\n in\n\n (* Compute deferred values - in the Pickles recursive proof system, deferred values\n are values from 2 proofs earlier in the recursion hierarchy. Every recursion\n goes through a two-phase process of step and wrap, like so\n\n step <- wrap <- step <- ... <- wrap <- step,\n `<-----------'\n deferred\n\n where there may be multiple children at each level (but let's ignore that!).\n Deferred values are values (part of the public input) that must be passed between\n the two phases in order to be verified correctly-- it works like this.\n\n - The wrap proof is passed the deferred values for its step proof as part of its public input.\n - The wrap proof starts verifying the step proof. As part of this verification it must\n perform all of the group element checks (since it's over the Vesta base field); however,\n at this stage it just assumes that the deferred values of its public input are correct\n (i.e. it defers checking them).\n - The next step proof verifies the wrap proof with a similar process, but using the other\n curve (e.g. Pallas). There are two important things to note:\n - Since it is using the other curve, it can compute the commitments to the public inputs\n of the previous wrap circuit that were passed into it. In other words, the next step\n proof receives data from the previous wrap proof about the previous step proof. Yeah,\n from two proofs back! (e.g. the deferred values)\n - The next step proof also computes the deferred values inside the circuit and verifies\n that they match those used by the previous wrap proof.\n\n The code below generates the deferred values so that we can verifiy that we can actually\n compute those values correctly inside the circuit. Special thanks to Matthew Ryan for\n explaining this in detail. *)\n let { deferred_values; x_hat_evals; sponge_digest_before_evaluations } =\n deferred_values ~actual_feature_flags ~sgs:[] ~prev_challenges:[]\n ~step_vk:vk ~public_input ~proof ~actual_proofs_verified:Nat.N0.n\n in\n\n let full_features =\n Plonk_types.Features.to_full ~or_:Opt.Flag.( ||| ) feature_flags\n in\n\n (* Define Typ.t for Deferred_values.t -- A Type.t defines how to convert a value of some type\n in OCaml into a var in circuit/Snarky.\n\n This complex function is called with two sets of inputs: once for the step circuit and\n once for the wrap circuit. It was decided not to use a functor for this. *)\n let deferred_values_typ =\n let open Impls.Step in\n let open Step_main_inputs in\n let open Step_verifier in\n Wrap.Proof_state.Deferred_values.In_circuit.typ\n (module Impls.Step)\n ~feature_flags:full_features ~challenge:Challenge.typ\n ~scalar_challenge:Challenge.typ\n ~dummy_scalar_challenge:\n (Kimchi_backend_common.Scalar_challenge.create\n Limb_vector.Challenge.Constant.zero )\n (Shifted_value.Type1.typ Field.typ)\n (Branch_data.typ\n (module Impl)\n ~assert_16_bits:(Step_verifier.assert_n_bits ~n:16) )\n in\n\n (* Use deferred_values_typ and the constant helper to prepare deferred_values\n for use in the circuit. We change some [Opt.t] to [Option.t] because that is\n what Type.t is configured to accept. *)\n let deferred_values =\n constant deferred_values_typ\n { deferred_values with\n plonk =\n { deferred_values.plonk with\n joint_combiner =\n Opt.to_option_unsafe deferred_values.plonk.joint_combiner\n }\n }\n (* Prepare all of the evaluations (i.e. all of the columns in the proof that we open)\n for use in the circuit *)\n and evals =\n constant\n (Plonk_types.All_evals.typ (module Impls.Step) full_features)\n { evals = { public_input = x_hat_evals; evals = proof.openings.evals }\n ; ft_eval1 = proof.openings.ft_eval1\n }\n in\n\n (* Run the circuit without generating a proof using run_and_check *)\n Impls.Step.run_and_check (fun () ->\n (* Set up the step sponge from the wrap sponge -- we cannot use the same poseidon\n sponge in both step and wrap because they have different fields.\n\n In order to continue the Fiat-Shamir heuristic across field boundaries we use\n the wrap sponge for everything in the wrap proof, squeeze it one final time and\n expose the squoze value in the public input to the step proof, which absorbs\n said squoze value into the step sponge. :-) This means the step sponge has absorbed\n everything from the proof so far by proxy and that is also over the native field! *)\n let res, _chals =\n let sponge =\n let open Step_main_inputs in\n let sponge = Sponge.create sponge_params in\n Sponge.absorb sponge\n (`Field (Impl.Field.constant sponge_digest_before_evaluations)) ;\n sponge\n in\n\n (* Call finalisation with all of the required details *)\n Step_verifier.finalize_other_proof\n (module Nat.N0)\n ~step_domains:\n (`Known\n [ { h = Pow_2_roots_of_unity vk.domain.log_size_of_group } ]\n )\n ~sponge ~prev_challenges:[] deferred_values evals\n in\n\n (* Read the boolean result from the circuit and make it available\n to the OCaml world. *)\n Impls.Step.(As_prover.(fun () -> read Boolean.typ res)) )\n |> Or_error.ok_exn\n\n (* Common srs value for all tests *)\n let srs =\n Kimchi_bindings.Protocol.SRS.Fp.create (1 lsl Common.Max_degree.step_log2)\n\n type example =\n Kimchi_bindings.Protocol.SRS.Fp.t\n -> Kimchi_bindings.Protocol.Index.Fp.t\n * Pasta_bindings.Fp.t list\n * ( Pasta_bindings.Fq.t Kimchi_types.or_infinity\n , Pasta_bindings.Fp.t )\n Kimchi_types.proof_with_public\n\n module type SETUP = sig\n val example : example\n\n (* Feature flags tused for backend proof *)\n val actual_feature_flags : bool Plonk_types.Features.t\n end\n\n (* [Make] is the test functor.\n\n Given a test setup, compute different test configurations and define 3\n test for said configurations. *)\n module Make (S : SETUP) = struct\n (* Generate foreign field multiplication test backend proof using Kimchi,\n obtaining the proof and corresponding prover index.\n\n Note: we only want to pay the cost of generating this proof once and\n then reuse it many times for the different recursive proof tests. *)\n let index, public_input, proof = S.example srs\n\n (* Obtain verifier key from prover index and convert backend proof to\n snarky proof *)\n let vk = Kimchi_bindings.Protocol.VerifierIndex.Fp.create index\n\n let proof = Backend.Tick.Proof.of_backend_with_public_evals proof\n\n let test_feature_flags_configs =\n generate_test_feature_flag_configs S.actual_feature_flags\n\n let runtest feature_flags =\n run_recursive_proof_test S.actual_feature_flags feature_flags\n public_input vk proof.proof\n\n let%test \"true -> yes\" = runtest test_feature_flags_configs.true_is_yes\n\n let%test \"true -> maybe\" =\n runtest test_feature_flags_configs.true_is_maybe\n\n let%test \"all maybes\" = runtest test_feature_flags_configs.all_maybes\n end\n\n (* Small combinators to lift gate example signatures to the expected\n signatures for the tests. This amounts to generating the list of public\n inputs from either no public inputs, a single one or a pair of inputs\n returned by the gate example. *)\n\n let no_public_input gate_example srs =\n let index, proof = gate_example srs in\n (index, [], proof)\n\n let public_input_1 gate_example srs =\n let index, public_input, proof = gate_example srs in\n (index, [ public_input ], proof)\n\n let public_input_2 gate_example srs =\n let index, (public_input1, public_input2), proof = gate_example srs in\n (index, [ public_input1; public_input2 ], proof)\n\n let%test_module \"lookup\" =\n ( module Make (struct\n let example =\n public_input_1 (fun srs ->\n Kimchi_bindings.Protocol.Proof.Fp.example_with_lookup srs )\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with\n lookup = true\n ; runtime_tables = true\n }\n end) )\n\n (*\n let%test_module \"foreign field multiplication\" =\n ( module Make (struct\n let example =\n no_public_input\n Kimchi_bindings.Protocol.Proof.Fp.example_with_foreign_field_mul\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with\n range_check0 = true\n ; range_check1 = true\n ; foreign_field_add = true\n ; foreign_field_mul = true\n }\n end) )\n *)\n\n let%test_module \"range check\" =\n ( module Make (struct\n let example =\n no_public_input\n Kimchi_bindings.Protocol.Proof.Fp.example_with_range_check\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with\n range_check0 = true\n ; range_check1 = true\n }\n end) )\n\n let%test_module \"range check 64 bits\" =\n ( module Make (struct\n let example =\n no_public_input\n Kimchi_bindings.Protocol.Proof.Fp.example_with_range_check0\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with range_check0 = true }\n end) )\n\n let%test_module \"xor\" =\n ( module Make (struct\n let example =\n public_input_2 Kimchi_bindings.Protocol.Proof.Fp.example_with_xor\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with xor = true }\n end) )\n\n let%test_module \"rot\" =\n ( module Make (struct\n let example =\n public_input_2 Kimchi_bindings.Protocol.Proof.Fp.example_with_rot\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with\n range_check0 = true\n ; rot = true\n }\n end) )\n\n let%test_module \"foreign field addition\" =\n ( module Make (struct\n let example =\n public_input_1 Kimchi_bindings.Protocol.Proof.Fp.example_with_ffadd\n\n let actual_feature_flags =\n { Plonk_types.Features.none_bool with\n range_check0 = true\n ; range_check1 = true\n ; foreign_field_add = true\n }\n end) )\n end )\n\nmodule Step_acc = Tock.Inner_curve.Affine\n\n(* The prover for wrapping a proof *)\nlet wrap\n (type actual_proofs_verified max_proofs_verified\n max_local_max_proofs_verifieds ) ~proof_cache\n ~(max_proofs_verified : max_proofs_verified Nat.t)\n (module Max_local_max_proof_verifieds : Hlist.Maxes.S\n with type ns = max_local_max_proofs_verifieds\n and type length = max_proofs_verified )\n (( module\n Req ) :\n (max_proofs_verified, max_local_max_proofs_verifieds) Requests.Wrap.t )\n ~dlog_plonk_index wrap_main ~(typ : _ Impls.Step.Typ.t) ~step_vk\n ~actual_wrap_domains ~step_plonk_indices:_ ~feature_flags\n ~actual_feature_flags ?tweak_statement pk\n ({ statement = prev_statement; prev_evals; proof; index = which_index } :\n ( _\n , _\n , (_, actual_proofs_verified) Vector.t\n , (_, actual_proofs_verified) Vector.t\n , max_local_max_proofs_verifieds\n H1.T(P.Base.Messages_for_next_proof_over_same_field.Wrap).t\n , ( (Tock.Field.t, Tock.Field.t array) Plonk_types.All_evals.t\n , max_proofs_verified )\n Vector.t )\n P.Base.Step.t ) =\n let logger = Internal_tracing_context_logger.get () in\n [%log internal] \"Pickles_wrap_proof\" ;\n let messages_for_next_wrap_proof =\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap)\n (P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared)\n (struct\n let f = P.Base.Messages_for_next_proof_over_same_field.Wrap.prepare\n end)\n in\n M.f prev_statement.messages_for_next_wrap_proof\n in\n let prev_statement_with_hashes : _ Types.Step.Statement.t =\n { proof_state =\n { prev_statement.proof_state with\n messages_for_next_step_proof =\n (let to_field_elements =\n let (Typ typ) = typ in\n fun x -> fst (typ.value_to_fields x)\n in\n (* TODO: Careful here... the length of\n old_buletproof_challenges inside the messages_for_next_step_proof\n might not be correct *)\n Common.hash_messages_for_next_step_proof\n ~app_state:to_field_elements\n (P.Base.Messages_for_next_proof_over_same_field.Step.prepare\n ~dlog_plonk_index\n prev_statement.proof_state.messages_for_next_step_proof ) )\n }\n ; messages_for_next_wrap_proof =\n (let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared)\n (E01 (Digest.Constant))\n (struct\n let f (type n)\n (m :\n n\n P.Base.Messages_for_next_proof_over_same_field.Wrap\n .Prepared\n .t ) =\n Wrap_hack.hash_messages_for_next_wrap_proof\n (Vector.length m.old_bulletproof_challenges)\n m\n end)\n in\n let module V = H1.To_vector (Digest.Constant) in\n V.f Max_local_max_proof_verifieds.length\n (M.f messages_for_next_wrap_proof) )\n }\n in\n let handler (Snarky_backendless.Request.With { request; respond }) =\n let open Req in\n let k x = respond (Provide x) in\n match request with\n | Evals ->\n k prev_evals\n | Step_accs ->\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared)\n (E01 (Step_acc))\n (struct\n let f :\n type a.\n a\n P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared\n .t\n -> Step_acc.t =\n fun t -> t.challenge_polynomial_commitment\n end)\n in\n let module V = H1.To_vector (Step_acc) in\n k\n (V.f Max_local_max_proof_verifieds.length\n (M.f messages_for_next_wrap_proof) )\n | Old_bulletproof_challenges ->\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared)\n (Challenges_vector.Constant)\n (struct\n let f\n (t :\n _\n P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared\n .t ) =\n t.old_bulletproof_challenges\n end)\n in\n k (M.f messages_for_next_wrap_proof)\n | Messages ->\n k proof.messages\n | Openings_proof ->\n k proof.openings.proof\n | Proof_state ->\n k prev_statement_with_hashes.proof_state\n | Which_branch ->\n k which_index\n | Wrap_domain_indices ->\n let all_possible_domains = Wrap_verifier.all_possible_domains () in\n let wrap_domain_indices =\n Vector.map actual_wrap_domains ~f:(fun domain_size ->\n let domain_index =\n Vector.foldi ~init:0 all_possible_domains\n ~f:(fun j acc (Pow_2_roots_of_unity domain) ->\n if Int.equal domain domain_size then j else acc )\n in\n Tock.Field.of_int domain_index )\n in\n k\n (Vector.extend_front_exn wrap_domain_indices max_proofs_verified\n Tock.Field.one )\n | _ ->\n Snarky_backendless.Request.unhandled\n in\n\n let public_input =\n tick_public_input_of_statement ~max_proofs_verified\n prev_statement_with_hashes\n in\n let prev_challenges =\n Vector.map ~f:Ipa.Step.compute_challenges\n prev_statement.proof_state.messages_for_next_step_proof\n .old_bulletproof_challenges\n in\n let actual_proofs_verified = Vector.length prev_challenges in\n let lte =\n Nat.lte_exn actual_proofs_verified\n (Length.to_nat Max_local_max_proof_verifieds.length)\n in\n let sgs =\n let module M =\n H1.Map\n (P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared)\n (E01 (Tick.Curve.Affine))\n (struct\n let f :\n type n.\n n P.Base.Messages_for_next_proof_over_same_field.Wrap.Prepared.t\n -> _ =\n fun t -> t.challenge_polynomial_commitment\n end)\n in\n let module V = H1.To_vector (Tick.Curve.Affine) in\n Vector.trim_front\n (V.f Max_local_max_proof_verifieds.length\n (M.f messages_for_next_wrap_proof) )\n lte\n in\n [%log internal] \"Wrap_compute_deferred_values\" ;\n let { deferred_values; x_hat_evals; sponge_digest_before_evaluations } =\n deferred_values ~sgs ~prev_challenges ~step_vk ~public_input ~proof\n ~actual_proofs_verified ~actual_feature_flags\n in\n [%log internal] \"Wrap_compute_deferred_values_done\" ;\n let next_statement : _ Types.Wrap.Statement.In_circuit.t =\n let messages_for_next_wrap_proof :\n _ P.Base.Messages_for_next_proof_over_same_field.Wrap.t =\n { challenge_polynomial_commitment =\n proof.openings.proof.challenge_polynomial_commitment\n ; old_bulletproof_challenges =\n Vector.map prev_statement.proof_state.unfinalized_proofs ~f:(fun t ->\n t.deferred_values.bulletproof_challenges )\n }\n in\n { proof_state =\n { deferred_values\n ; sponge_digest_before_evaluations =\n Digest.Constant.of_tick_field sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof\n }\n ; messages_for_next_step_proof =\n prev_statement.proof_state.messages_for_next_step_proof\n }\n in\n let next_statement =\n match tweak_statement with\n | None ->\n next_statement\n | Some f ->\n (* For adversarial tests, we want to simulate an adversary creating a\n proof that doesn't match the pickles protocol.\n In order to do this, we pass a function [tweak_statement] that takes\n the valid statement that we computed above and 'tweaks' it so that\n the statement is no longer valid. This modified statement is then\n propagated as part of any later recursion.\n *)\n f next_statement\n in\n let messages_for_next_wrap_proof_prepared =\n P.Base.Messages_for_next_proof_over_same_field.Wrap.prepare\n next_statement.proof_state.messages_for_next_wrap_proof\n in\n let next_accumulator =\n Vector.map2\n (Vector.extend_front_exn\n prev_statement.proof_state.messages_for_next_step_proof\n .challenge_polynomial_commitments max_proofs_verified\n (Lazy.force Dummy.Ipa.Wrap.sg) )\n messages_for_next_wrap_proof_prepared.old_bulletproof_challenges\n ~f:(fun sg chals ->\n { Tock.Proof.Challenge_polynomial.commitment = sg\n ; challenges = Vector.to_array chals\n } )\n |> Wrap_hack.pad_accumulator\n in\n let%map.Promise next_proof =\n let (T (input, conv, _conv_inv)) = Impls.Wrap.input ~feature_flags () in\n Common.time \"wrap proof\" (fun () ->\n [%log internal] \"Wrap_generate_witness_conv\" ;\n Impls.Wrap.generate_witness_conv\n ~f:(fun { Impls.Wrap.Proof_inputs.auxiliary_inputs; public_inputs } () ->\n [%log internal] \"Backend_tock_proof_create_async\" ;\n let create_proof () =\n Backend.Tock.Proof.create_async ~primary:public_inputs\n ~auxiliary:auxiliary_inputs pk ~message:next_accumulator\n in\n let%map.Promise proof =\n match proof_cache with\n | None ->\n create_proof ()\n | Some proof_cache -> (\n match\n Proof_cache.get_wrap_proof proof_cache ~keypair:pk\n ~public_input:public_inputs\n with\n | None ->\n let%map.Promise proof = create_proof () in\n Proof_cache.set_wrap_proof proof_cache ~keypair:pk\n ~public_input:public_inputs proof.proof ;\n proof\n | Some proof ->\n Promise.return\n ( { proof; public_evals = None }\n : Tock.Proof.with_public_evals ) )\n in\n [%log internal] \"Backend_tock_proof_create_async_done\" ;\n proof )\n ~input_typ:input\n ~return_typ:(Snarky_backendless.Typ.unit ())\n (fun x () : unit ->\n Impls.Wrap.handle (fun () : unit -> wrap_main (conv x)) handler )\n { messages_for_next_step_proof =\n prev_statement_with_hashes.proof_state\n .messages_for_next_step_proof\n ; proof_state =\n { next_statement.proof_state with\n messages_for_next_wrap_proof =\n Wrap_hack.hash_messages_for_next_wrap_proof\n max_proofs_verified messages_for_next_wrap_proof_prepared\n ; deferred_values =\n { next_statement.proof_state.deferred_values with\n plonk =\n { next_statement.proof_state.deferred_values.plonk with\n joint_combiner =\n Opt.to_option\n next_statement.proof_state.deferred_values.plonk\n .joint_combiner\n }\n }\n }\n } )\n in\n [%log internal] \"Pickles_wrap_proof_done\" ;\n ( { proof = Wrap_wire_proof.of_kimchi_proof next_proof.proof\n ; statement =\n Types.Wrap.Statement.to_minimal next_statement\n ~to_option:Opt.to_option_unsafe\n ; prev_evals =\n { Plonk_types.All_evals.evals =\n { public_input = x_hat_evals; evals = proof.openings.evals }\n ; ft_eval1 = proof.openings.ft_eval1\n }\n }\n : _ P.Base.Wrap.t )\n","module SC = Scalar_challenge\nopen Core_kernel\nopen Pickles_types\nopen Common\nopen Import\nopen Backend\n\n(* TODO: Just stick this in plonk_checks.ml *)\nmodule Plonk_checks = struct\n include Plonk_checks\n module Type1 =\n Plonk_checks.Make (Shifted_value.Type1) (Plonk_checks.Scalars.Tick)\nend\n\nlet expand_deferred (type n most_recent_width)\n ~(evals :\n ( Backend.Tick.Field.t\n , Backend.Tick.Field.t array )\n Pickles_types.Plonk_types.All_evals.t )\n ~(old_bulletproof_challenges :\n ( Challenge.Constant.t Scalar_challenge.Stable.Latest.t\n Bulletproof_challenge.t\n Step_bp_vec.t\n , most_recent_width )\n Pickles_types.Vector.t )\n ~(proof_state :\n ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Backend.Tick.Field.t Pickles_types.Shifted_value.Type1.t\n , bool\n , n Pickles__.Proof.Base.Messages_for_next_proof_over_same_field.Wrap.t\n , Digest.Constant.t\n , Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n , Branch_data.t )\n Composition_types.Wrap.Proof_state.Minimal.Stable.V1.t ) :\n _ Types.Wrap.Proof_state.Deferred_values.t =\n let module Tick_field = Backend.Tick.Field in\n let tick_field : _ Plonk_checks.field = (module Tick_field) in\n Timer.start __LOC__ ;\n let open Types.Wrap.Proof_state in\n let sc = SC.to_field_constant tick_field ~endo:Endo.Wrap_inner_curve.scalar in\n Timer.clock __LOC__ ;\n let plonk0 = proof_state.deferred_values.plonk in\n let { Deferred_values.Minimal.branch_data; bulletproof_challenges; _ } =\n Deferred_values.Minimal.map_challenges ~f:Challenge.Constant.to_tick_field\n ~scalar:sc proof_state.deferred_values\n in\n let zeta = sc plonk0.zeta in\n let alpha = sc plonk0.alpha in\n let step_domain = Branch_data.domain branch_data in\n let w =\n Tick.Field.domain_generator ~log2_size:(Domain.log2_size step_domain)\n in\n let zetaw = Tick.Field.mul zeta w in\n let tick_plonk_minimal :\n _ Composition_types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.t =\n let chal = Challenge.Constant.to_tick_field in\n { zeta\n ; alpha\n ; beta = chal plonk0.beta\n ; gamma = chal plonk0.gamma\n ; joint_combiner = Option.map ~f:sc plonk0.joint_combiner\n ; feature_flags = plonk0.feature_flags\n }\n in\n let tick_combined_evals =\n Plonk_checks.evals_of_split_evals\n (module Tick.Field)\n evals.evals.evals ~rounds:(Nat.to_int Tick.Rounds.n) ~zeta ~zetaw\n |> Plonk_types.Evals.to_in_circuit\n in\n let tick_domain =\n Plonk_checks.domain\n (module Tick.Field)\n step_domain ~shifts:Common.tick_shifts\n ~domain_generator:Backend.Tick.Field.domain_generator\n in\n let tick_env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tick.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~endo:Endo.Step_inner_curve.base ~mds:Tick_field_sponge.params.mds\n ~srs_length_log2:Common.Max_degree.step_log2\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fp.of_bigint )\n ~domain:tick_domain tick_plonk_minimal tick_combined_evals\n in\n let plonk =\n let p =\n let module Field = struct\n include Tick.Field\n end in\n Plonk_checks.Type1.derive_plonk\n (module Field)\n ~shift:Shifts.tick1 ~env:tick_env tick_plonk_minimal tick_combined_evals\n in\n { p with\n zeta = plonk0.zeta\n ; alpha = plonk0.alpha\n ; beta = plonk0.beta\n ; gamma = plonk0.gamma\n ; joint_combiner = plonk0.joint_combiner\n }\n in\n Timer.clock __LOC__ ;\n let absorb, squeeze =\n let open Tick_field_sponge.Bits in\n let sponge =\n let s = create Tick_field_sponge.params in\n absorb s\n (Digest.Constant.to_tick_field\n proof_state.sponge_digest_before_evaluations ) ;\n s\n in\n let squeeze () =\n let underlying =\n Challenge.Constant.of_bits\n (squeeze sponge ~length:Challenge.Constant.length)\n in\n Scalar_challenge.create underlying\n in\n (absorb sponge, squeeze)\n in\n let old_bulletproof_challenges =\n Vector.map ~f:Ipa.Step.compute_challenges old_bulletproof_challenges\n in\n (let challenges_digest =\n let open Tick_field_sponge.Field in\n let sponge = create Tick_field_sponge.params in\n Vector.iter old_bulletproof_challenges ~f:(Vector.iter ~f:(absorb sponge)) ;\n squeeze sponge\n in\n absorb challenges_digest ;\n absorb evals.ft_eval1 ;\n let xs = Plonk_types.Evals.to_absorption_sequence evals.evals.evals in\n let x1, x2 = evals.evals.public_input in\n absorb x1 ;\n absorb x2 ;\n List.iter xs ~f:(fun (x1, x2) ->\n Array.iter ~f:absorb x1 ; Array.iter ~f:absorb x2 ) ) ;\n let xi_chal = squeeze () in\n let xi = sc xi_chal in\n let r_chal = squeeze () in\n let r = sc r_chal in\n Timer.clock __LOC__ ;\n (* TODO: The deferred values \"bulletproof_challenges\" should get routed\n into a \"batch dlog Tick acc verifier\" *)\n let actual_proofs_verified = Vector.length old_bulletproof_challenges in\n Timer.clock __LOC__ ;\n let combined_inner_product_actual =\n Wrap.combined_inner_product ~env:tick_env ~plonk:tick_plonk_minimal\n ~domain:tick_domain ~ft_eval1:evals.ft_eval1\n ~actual_proofs_verified:(Nat.Add.create actual_proofs_verified)\n evals.evals ~old_bulletproof_challenges ~r ~xi ~zeta ~zetaw\n in\n Timer.clock __LOC__ ;\n let bulletproof_challenges =\n Ipa.Step.compute_challenges bulletproof_challenges\n in\n Timer.clock __LOC__ ;\n let b_actual =\n let challenge_poly =\n unstage\n (Wrap.challenge_polynomial (Vector.to_array bulletproof_challenges))\n in\n Tick.Field.(challenge_poly zeta + (r * challenge_poly zetaw))\n in\n let to_shifted =\n Shifted_value.Type1.of_field (module Tick.Field) ~shift:Shifts.tick1\n in\n { xi = xi_chal\n ; plonk\n ; combined_inner_product = to_shifted combined_inner_product_actual\n ; branch_data\n ; bulletproof_challenges\n ; b = to_shifted b_actual\n }\n","module SC = Scalar_challenge\nopen Pickles_types\nopen Common\nopen Import\n\nmodule Instance = struct\n type t =\n | T :\n (module Nat.Intf with type n = 'n)\n * (module Intf.Statement_value with type t = 'a)\n * Verification_key.t\n * 'a\n * ('n, 'n) Proof.t\n -> t\nend\n\nlet verify_heterogenous (ts : Instance.t list) =\n let module Tick_field = Backend.Tick.Field in\n let logger = Internal_tracing_context_logger.get () in\n [%log internal] \"Verify_heterogenous\"\n ~metadata:[ (\"count\", `Int (List.length ts)) ] ;\n let tick_field : _ Plonk_checks.field = (module Tick_field) in\n let check, result =\n let r = ref [] in\n let result () =\n match !r with\n | [] ->\n Ok ()\n | _ ->\n Error\n ( Error.tag ~tag:\"Pickles.verify\"\n @@ Error.of_list\n @@ List.map !r ~f:(fun lab -> Error.of_string (Lazy.force lab)) )\n in\n ((fun (lab, b) -> if not b then r := lab :: !r), result)\n in\n [%log internal] \"Compute_plonks_and_chals\" ;\n let _computed_bp_chals, deferred_values =\n List.map ts\n ~f:(fun\n (T\n ( _max_proofs_verified\n , _statement\n , key\n , _app_state\n , T\n { statement =\n { proof_state\n ; messages_for_next_step_proof =\n { old_bulletproof_challenges; _ }\n }\n ; prev_evals = evals\n ; proof = _\n } ) )\n ->\n Timer.start __LOC__ ;\n let non_chunking =\n let exception Is_chunked in\n match\n Pickles_types.Plonk_types.Evals.map evals.evals.evals\n ~f:(fun (x, y) ->\n if Array.length x > 1 || Array.length y > 1 then\n raise Is_chunked )\n with\n | exception Is_chunked ->\n false\n | _unit_evals ->\n (* we do not care about _unit_evals, if we reached this point, we\n know all evals have length 1 for they cannot have length 0 *)\n true\n in\n check (lazy \"only uses single chunks\", non_chunking) ;\n check\n ( lazy \"feature flags are consistent with evaluations\"\n , Pickles_types.Plonk_types.Evals.validate_feature_flags\n ~feature_flags:proof_state.deferred_values.plonk.feature_flags\n evals.evals.evals ) ;\n Timer.start __LOC__ ;\n let open Types.Wrap.Proof_state in\n let step_domain =\n Branch_data.domain proof_state.deferred_values.branch_data\n in\n check\n ( lazy \"domain size is small enough\"\n , Domain.log2_size step_domain <= Nat.to_int Backend.Tick.Rounds.n ) ;\n let sc =\n SC.to_field_constant tick_field ~endo:Endo.Wrap_inner_curve.scalar\n in\n Timer.clock __LOC__ ;\n let { Deferred_values.Minimal.plonk = _\n ; branch_data = _\n ; bulletproof_challenges\n } =\n Deferred_values.Minimal.map_challenges\n ~f:Challenge.Constant.to_tick_field ~scalar:sc\n proof_state.deferred_values\n in\n Timer.clock __LOC__ ;\n let deferred_values =\n Wrap_deferred_values.expand_deferred ~evals\n ~old_bulletproof_challenges ~proof_state\n in\n Timer.clock __LOC__ ;\n let deferred_values = { deferred_values with bulletproof_challenges } in\n let () =\n let [ Pow_2_roots_of_unity greatest_wrap_domain\n ; _\n ; Pow_2_roots_of_unity least_wrap_domain\n ] =\n Wrap_verifier.all_possible_domains ()\n in\n let actual_wrap_domain = key.index.domain.log_size_of_group in\n check\n ( lazy\n (sprintf !\"wrap_domain: %i > %i\" actual_wrap_domain\n least_wrap_domain )\n , Int.( <= ) actual_wrap_domain least_wrap_domain ) ;\n check\n ( lazy\n (sprintf !\"wrap_domain: %i < %i\" actual_wrap_domain\n greatest_wrap_domain )\n , Int.( >= ) actual_wrap_domain greatest_wrap_domain )\n in\n (bulletproof_challenges, deferred_values) )\n |> List.unzip\n in\n [%log internal] \"Compute_plonks_and_chals_done\" ;\n let open Backend.Tock.Proof in\n let open Promise.Let_syntax in\n [%log internal] \"Accumulator_check\" ;\n let%bind accumulator_check =\n Ipa.Step.accumulator_check\n (List.map ts ~f:(fun (T (_, _, _, _, T t)) ->\n ( t.statement.proof_state.messages_for_next_wrap_proof\n .challenge_polynomial_commitment\n , Ipa.Step.compute_challenges\n t.statement.proof_state.deferred_values.bulletproof_challenges ) )\n )\n in\n [%log internal] \"Accumulator_check_done\" ;\n Common.time \"batch_step_dlog_check\" (fun () ->\n check (lazy \"batch_step_dlog_check\", accumulator_check) ) ;\n [%log internal] \"Compute_batch_verify_inputs\" ;\n let batch_verify_inputs =\n List.map2_exn ts deferred_values\n ~f:(fun\n (T\n ( (module Max_proofs_verified)\n , (module A_value)\n , key\n , app_state\n , T t ) )\n deferred_values\n ->\n let prepared_statement : _ Types.Wrap.Statement.In_circuit.t =\n { messages_for_next_step_proof =\n Common.hash_messages_for_next_step_proof\n ~app_state:A_value.to_field_elements\n (Reduced_messages_for_next_proof_over_same_field.Step.prepare\n ~dlog_plonk_index:key.commitments\n { t.statement.messages_for_next_step_proof with app_state } )\n ; proof_state =\n { deferred_values =\n { plonk = deferred_values.plonk\n ; combined_inner_product =\n deferred_values.combined_inner_product\n ; b = deferred_values.b\n ; xi = deferred_values.xi\n ; bulletproof_challenges =\n deferred_values.bulletproof_challenges\n ; branch_data = deferred_values.branch_data\n }\n ; sponge_digest_before_evaluations =\n t.statement.proof_state.sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof =\n Wrap_hack.hash_messages_for_next_wrap_proof\n Max_proofs_verified.n\n (Reduced_messages_for_next_proof_over_same_field.Wrap\n .prepare\n t.statement.proof_state.messages_for_next_wrap_proof )\n }\n }\n in\n let input =\n tock_unpadded_public_input_of_statement\n ~feature_flags:Plonk_types.Features.Full.maybe prepared_statement\n in\n let message =\n Wrap_hack.pad_accumulator\n (Vector.map2\n ~f:(fun g cs ->\n { Challenge_polynomial.challenges =\n Vector.to_array (Ipa.Wrap.compute_challenges cs)\n ; commitment = g\n } )\n (Vector.extend_front_exn\n t.statement.messages_for_next_step_proof\n .challenge_polynomial_commitments Max_proofs_verified.n\n (Lazy.force Dummy.Ipa.Wrap.sg) )\n t.statement.proof_state.messages_for_next_wrap_proof\n .old_bulletproof_challenges )\n in\n ( key.index\n , { proof = Wrap_wire_proof.to_kimchi_proof t.proof\n ; public_evals = None\n }\n , input\n , Some message ) )\n in\n [%log internal] \"Compute_batch_verify_inputs_done\" ;\n [%log internal] \"Dlog_check_batch_verify\" ;\n let%map dlog_check = batch_verify batch_verify_inputs in\n [%log internal] \"Dlog_check_batch_verify_done\" ;\n Common.time \"dlog_check\" (fun () -> check (lazy \"dlog_check\", dlog_check)) ;\n result ()\n\nlet verify (type a n) (max_proofs_verified : (module Nat.Intf with type n = n))\n (a_value : (module Intf.Statement_value with type t = a))\n (key : Verification_key.t) (ts : (a * (n, n) Proof.t) list) =\n verify_heterogenous\n (List.map ts ~f:(fun (x, p) ->\n Instance.T (max_proofs_verified, a_value, key, x, p) ) )\n","open Pickles_types\nopen Hlist\nopen Import\nopen Impls.Step\nopen Step_verifier\nmodule B = Inductive_rule.B\n\n(* Converts from the one hot vector representation of a number\n 0 <= i < n\n\n 0 1 ... i-1 i i+1 n-1\n [ 0; 0; ... 0; 1; 0; ...; 0 ]\n\n to the numeric representation i. *)\n\nlet _one_hot_vector_to_num (type n) (v : n Per_proof_witness.One_hot_vector.t) :\n Field.t =\n let n = Vector.length (v :> (Boolean.var, n) Vector.t) in\n Pseudo.choose (v, Vector.init n ~f:Field.of_int) ~f:Fn.id\n\nlet verify_one ~srs\n ({ app_state\n ; wrap_proof\n ; proof_state\n ; prev_proof_evals\n ; prev_challenges\n ; prev_challenge_polynomial_commitments\n } :\n _ Per_proof_witness.t ) (d : _ Types_map.For_step.t)\n (messages_for_next_wrap_proof : Digest.t) (unfinalized : Unfinalized.t)\n (should_verify : B.t) : _ Vector.t * B.t =\n Boolean.Assert.( = ) unfinalized.should_finalize should_verify ;\n let deferred_values = proof_state.deferred_values in\n let finalized, chals =\n with_label __LOC__ (fun () ->\n let sponge_digest = proof_state.sponge_digest_before_evaluations in\n let sponge =\n let open Step_main_inputs in\n let sponge = Sponge.create sponge_params in\n Sponge.absorb sponge (`Field sponge_digest) ;\n sponge\n in\n (* TODO: Refactor args into an \"unfinalized proof\" struct *)\n finalize_other_proof d.max_proofs_verified ~step_domains:d.step_domains\n ~sponge ~prev_challenges deferred_values prev_proof_evals )\n in\n let branch_data = deferred_values.branch_data in\n let sponge_after_index, hash_messages_for_next_step_proof =\n let to_field_elements =\n let (Typ typ) = d.public_input in\n fun x -> fst (typ.var_to_fields x)\n in\n let sponge_after_index, hash_messages_for_next_step_proof =\n (* TODO: Don't rehash when it's not necessary *)\n hash_messages_for_next_step_proof_opt ~index:d.wrap_key to_field_elements\n in\n (sponge_after_index, unstage hash_messages_for_next_step_proof)\n in\n (* prepare the statement to be verified below *)\n let statement =\n let prev_messages_for_next_step_proof =\n with_label __LOC__ (fun () ->\n hash_messages_for_next_step_proof ~widths:d.proofs_verifieds\n ~max_width:(Nat.Add.n d.max_proofs_verified)\n ~proofs_verified_mask:\n (Vector.trim_front branch_data.proofs_verified_mask\n (Nat.lte_exn\n (Vector.length prev_challenge_polynomial_commitments)\n Nat.N2.n ) )\n (* Use opt sponge for cutting off the bulletproof challenges early *)\n { app_state\n ; dlog_plonk_index = d.wrap_key\n ; challenge_polynomial_commitments =\n prev_challenge_polynomial_commitments\n ; old_bulletproof_challenges = prev_challenges\n } )\n in\n (* Returns messages for the next step proof and messages for the next\n wrap proof *)\n { Types.Wrap.Statement.messages_for_next_step_proof =\n prev_messages_for_next_step_proof\n ; proof_state = { proof_state with messages_for_next_wrap_proof }\n }\n in\n (* and when the statement is prepared, we call the step verifier with this\n statement *)\n let verified =\n with_label __LOC__ (fun () ->\n verify ~srs\n ~feature_flags:(Plonk_types.Features.of_full d.feature_flags)\n ~lookup_parameters:\n { use = d.feature_flags.uses_lookups\n ; zero =\n { var =\n { challenge = Field.zero\n ; scalar = Shifted_value Field.zero\n }\n ; value =\n { challenge = Limb_vector.Challenge.Constant.zero\n ; scalar =\n Shifted_value.Type1.Shifted_value Field.Constant.zero\n }\n }\n }\n ~proofs_verified:d.max_proofs_verified ~wrap_domain:d.wrap_domain\n ~is_base_case:(Boolean.not should_verify)\n ~sponge_after_index ~sg_old:prev_challenge_polynomial_commitments\n ~proof:wrap_proof ~wrap_verification_key:d.wrap_key statement\n unfinalized )\n in\n if debug then\n as_prover\n As_prover.(\n fun () ->\n let finalized = read Boolean.typ finalized in\n let verified = read Boolean.typ verified in\n let should_verify = read Boolean.typ should_verify in\n printf \"finalized: %b\\n%!\" finalized ;\n printf \"verified: %b\\n%!\" verified ;\n printf \"should_verify: %b\\n\\n%!\" should_verify) ;\n (chals, Boolean.(verified &&& finalized ||| not should_verify))\n\n(* The SNARK function corresponding to the input inductive rule. *)\nlet step_main :\n type proofs_verified self_branches prev_vars prev_values var value a_var a_value ret_var ret_value auxiliary_var auxiliary_value max_proofs_verified local_branches local_signature.\n (module Requests.Step.S\n with type local_signature = local_signature\n and type local_branches = local_branches\n and type statement = a_value\n and type prev_values = prev_values\n and type max_proofs_verified = max_proofs_verified\n and type proofs_verified = proofs_verified\n and type return_value = ret_value\n and type auxiliary_value = auxiliary_value )\n -> (module Nat.Add.Intf with type n = max_proofs_verified)\n -> self_branches:self_branches Nat.t\n (* How many branches does this proof system have *)\n -> local_signature:local_signature H1.T(Nat).t\n (* The specification, for each proof that this step circuit verifies, of the maximum width used\n by that proof system. *)\n -> local_signature_length:(local_signature, proofs_verified) Hlist.Length.t\n -> local_branches:\n (* For each inner proof of type T , the number of branches that type T has. *)\n local_branches H1.T(Nat).t\n -> local_branches_length:(local_branches, proofs_verified) Hlist.Length.t\n -> proofs_verified:(prev_vars, proofs_verified) Hlist.Length.t\n -> lte:(proofs_verified, max_proofs_verified) Nat.Lte.t\n -> public_input:\n ( var\n , value\n , a_var\n , a_value\n , ret_var\n , ret_value )\n Inductive_rule.public_input\n -> auxiliary_typ:(auxiliary_var, auxiliary_value) Typ.t\n -> basic:\n ( var\n , value\n , max_proofs_verified\n , self_branches )\n Types_map.Compiled.basic\n -> self:(var, value, max_proofs_verified, self_branches) Tag.t\n -> ( prev_vars\n , prev_values\n , local_signature\n , local_branches\n , a_var\n , a_value\n , ret_var\n , ret_value\n , auxiliary_var\n , auxiliary_value )\n Inductive_rule.t\n -> ( unit\n -> ( (Unfinalized.t, max_proofs_verified) Vector.t\n , Field.t\n , (Field.t, max_proofs_verified) Vector.t )\n Types.Step.Statement.t )\n Staged.t =\n fun (module Req) max_proofs_verified ~self_branches ~local_signature\n ~local_signature_length ~local_branches ~local_branches_length\n ~proofs_verified ~lte ~public_input ~auxiliary_typ ~basic ~self rule ->\n let module Typ_with_max_proofs_verified = struct\n type ('var, 'value, 'local_max_proofs_verified, 'local_branches) t =\n ( ( 'var\n , 'local_max_proofs_verified\n , 'local_branches )\n Per_proof_witness.No_app_state.t\n , ( 'value\n , 'local_max_proofs_verified\n , 'local_branches )\n Per_proof_witness.Constant.No_app_state.t )\n Typ.t\n end in\n let feature_flags (d : _ Tag.t) =\n if Type_equal.Id.same self.id d.id then basic.feature_flags\n else Types_map.feature_flags d\n in\n let feature_flags =\n let rec go :\n type pvars pvals ns1 ns2 br.\n (pvars, pvals, ns1, ns2) H4.T(Tag).t\n -> (pvars, br) Length.t\n -> (Opt.Flag.t Plonk_types.Features.Full.t, br) Vector.t =\n fun ds ld ->\n match[@warning \"-4\"] (ds, ld) with\n | [], Z ->\n []\n | d :: ds, S ld ->\n feature_flags d :: go ds ld\n | [], _ ->\n .\n | _ :: _, _ ->\n .\n in\n go rule.prevs proofs_verified\n in\n let prev_proof_typs =\n let rec join :\n type pvars pvals ns1 ns2 br.\n (pvars, pvals, ns1, ns2) H4.T(Tag).t\n -> ns1 H1.T(Nat).t\n -> ns2 H1.T(Nat).t\n -> (pvars, br) Length.t\n -> (ns1, br) Length.t\n -> (ns2, br) Length.t\n -> (Opt.Flag.t Plonk_types.Features.Full.t, br) Vector.t\n -> (pvars, pvals, ns1, ns2) H4.T(Typ_with_max_proofs_verified).t =\n fun ds ns1 ns2 ld ln1 ln2 feature_flagss ->\n match[@warning \"-4\"] (ds, ns1, ns2, ld, ln1, ln2, feature_flagss) with\n | [], [], [], Z, Z, Z, [] ->\n []\n | ( _d :: ds\n , n1 :: ns1\n , _n2 :: ns2\n , S ld\n , S ln1\n , S ln2\n , feature_flags :: feature_flagss ) ->\n let t = Per_proof_witness.typ Typ.unit n1 ~feature_flags in\n t :: join ds ns1 ns2 ld ln1 ln2 feature_flagss\n | [], _, _, _, _, _, _ ->\n .\n | _ :: _, _, _, _, _, _, _ ->\n .\n in\n join rule.prevs local_signature local_branches proofs_verified\n local_signature_length local_branches_length feature_flags\n in\n let module Prev_typ =\n H4.Typ (Impls.Step) (Typ_with_max_proofs_verified)\n (Per_proof_witness.No_app_state)\n (Per_proof_witness.Constant.No_app_state)\n (struct\n let f = Fn.id\n end)\n in\n let (input_typ, output_typ)\n : (a_var, a_value) Typ.t * (ret_var, ret_value) Typ.t =\n match public_input with\n | Input typ ->\n (typ, Typ.unit)\n | Output typ ->\n (Typ.unit, typ)\n | Input_and_output (input_typ, output_typ) ->\n (input_typ, output_typ)\n in\n let main () : _ Types.Step.Statement.t =\n let open Impls.Step in\n let logger = Internal_tracing_context_logger.get () in\n with_label \"step_main\" (fun () ->\n let module Max_proofs_verified = ( val max_proofs_verified : Nat.Add.Intf\n with type n = max_proofs_verified\n )\n in\n let T = Max_proofs_verified.eq in\n let app_state = exists input_typ ~request:(fun () -> Req.App_state) in\n let { Inductive_rule.previous_proof_statements\n ; public_output = ret_var\n ; auxiliary_output = auxiliary_var\n } =\n (* Run the application logic of the rule on the predecessor statements *)\n with_label \"rule_main\" (fun () ->\n rule.main { public_input = app_state } )\n in\n let () =\n exists Typ.unit ~request:(fun () ->\n let ret_value = As_prover.read output_typ ret_var in\n Req.Return_value ret_value )\n in\n let () =\n exists Typ.unit ~request:(fun () ->\n let auxiliary_value =\n As_prover.read auxiliary_typ auxiliary_var\n in\n Req.Auxiliary_value auxiliary_value )\n in\n (* Compute proof parts outside of the prover before requesting values.\n *)\n exists Typ.unit ~request:(fun () ->\n let previous_proof_statements =\n let rec go :\n type prev_vars prev_values ns1 ns2.\n ( prev_vars\n , ns1 )\n H2.T(Inductive_rule.Previous_proof_statement).t\n -> (prev_vars, prev_values, ns1, ns2) H4.T(Tag).t\n -> ( prev_values\n , ns1 )\n H2.T(Inductive_rule.Previous_proof_statement.Constant).t =\n fun previous_proof_statement tags ->\n match (previous_proof_statement, tags) with\n | [], [] ->\n []\n | ( { public_input; proof; proof_must_verify } :: stmts\n , tag :: tags ) ->\n let public_input =\n (fun (type var value n m) (tag : (var, value, n, m) Tag.t)\n (var : var) : value ->\n let typ : (var, value) Typ.t =\n match Type_equal.Id.same_witness self.id tag.id with\n | Some T ->\n basic.public_input\n | None ->\n Types_map.public_input tag\n in\n As_prover.read typ var )\n tag public_input\n in\n { public_input\n ; proof = As_prover.Ref.get proof\n ; proof_must_verify =\n As_prover.read Boolean.typ proof_must_verify\n }\n :: go stmts tags\n in\n go previous_proof_statements rule.prevs\n in\n Req.Compute_prev_proof_parts previous_proof_statements ) ;\n let dlog_plonk_index =\n exists\n ~request:(fun () -> Req.Wrap_index)\n (Plonk_verification_key_evals.typ Inner_curve.typ)\n and prevs =\n exists (Prev_typ.f prev_proof_typs) ~request:(fun () ->\n Req.Proof_with_datas )\n and unfinalized_proofs_unextended =\n exists\n (Vector.typ'\n (Vector.map\n ~f:(fun _feature_flags ->\n Unfinalized.typ ~wrap_rounds:Backend.Tock.Rounds.n )\n feature_flags ) )\n ~request:(fun () -> Req.Unfinalized_proofs)\n and messages_for_next_wrap_proof =\n exists (Vector.typ Digest.typ Max_proofs_verified.n)\n ~request:(fun () -> Req.Messages_for_next_wrap_proof)\n and actual_wrap_domains =\n exists\n (Vector.typ (Typ.Internal.ref ()) (Length.to_nat proofs_verified))\n ~request:(fun () -> Req.Wrap_domain_indices)\n in\n let prevs =\n (* Inject the app-state values into the per-proof witnesses. *)\n let rec go :\n type vars ns1 ns2.\n (vars, ns1, ns2) H3.T(Per_proof_witness.No_app_state).t\n -> (vars, ns1) H2.T(Inductive_rule.Previous_proof_statement).t\n -> (vars, ns1, ns2) H3.T(Per_proof_witness).t =\n fun proofs stmts ->\n match (proofs, stmts) with\n | [], [] ->\n []\n | proof :: proofs, stmt :: stmts ->\n { proof with app_state = stmt.public_input } :: go proofs stmts\n in\n go prevs previous_proof_statements\n in\n let srs = Backend.Tock.Keypair.load_urs () in\n [%log internal] \"Step_compute_bulletproof_challenges\" ;\n let bulletproof_challenges =\n with_label \"prevs_verified\" (fun () ->\n let rec go :\n type vars vals ns1 ns2 n.\n (vars, ns1, ns2) H3.T(Per_proof_witness).t\n -> (vars, vals, ns1, ns2) H4.T(Types_map.For_step).t\n -> vars H1.T(E01(Digest)).t\n -> vars H1.T(E01(Unfinalized)).t\n -> (vars, ns1) H2.T(Inductive_rule.Previous_proof_statement).t\n -> (vars, n) Length.t\n -> actual_wrap_domains:\n ( Pickles_base.Proofs_verified.t As_prover.Ref.t\n , n )\n Vector.t\n -> (_, n) Vector.t * B.t list =\n fun proofs datas messages_for_next_wrap_proofs unfinalizeds stmts\n pi ~actual_wrap_domains ->\n match\n ( proofs\n , datas\n , messages_for_next_wrap_proofs\n , unfinalizeds\n , stmts\n , pi\n , actual_wrap_domains )\n with\n | [], [], [], [], [], Z, [] ->\n ([], [])\n | ( p :: proofs\n , d :: datas\n , messages_for_next_wrap_proof\n :: messages_for_next_wrap_proofs\n , unfinalized :: unfinalizeds\n , { proof_must_verify = should_verify; _ } :: stmts\n , S pi\n , actual_wrap_domain :: actual_wrap_domains ) ->\n let () =\n (* Fail with an error if the proof's domain differs from\n the hard-coded one otherwise.\n *)\n match d.wrap_domain with\n | `Known wrap_domain ->\n as_prover (fun () ->\n let actual_wrap_domain =\n As_prover.Ref.get actual_wrap_domain\n |> Pickles_base.Proofs_verified.to_int\n in\n let actual_wrap_domain =\n Common.wrap_domains\n ~proofs_verified:actual_wrap_domain\n in\n match (wrap_domain, actual_wrap_domain.h) with\n | ( Pow_2_roots_of_unity expected\n , Pow_2_roots_of_unity actual )\n when expected <> actual ->\n failwithf\n \"This circuit was compiled for proofs \\\n using the wrap domain of size %d, but a \\\n proof was given with size %d. You should \\\n pass the ~override_wrap_domain argument \\\n to set the correct domain size.\"\n expected actual ()\n | Pow_2_roots_of_unity _, Pow_2_roots_of_unity _\n ->\n () )\n | `Side_loaded _ ->\n ()\n in\n let chals, v =\n verify_one ~srs p d messages_for_next_wrap_proof\n unfinalized should_verify\n in\n let chalss, vs =\n go proofs datas messages_for_next_wrap_proofs unfinalizeds\n stmts pi ~actual_wrap_domains\n in\n (chals :: chalss, v :: vs)\n in\n let chalss, vs =\n let messages_for_next_wrap_proofs =\n with_label \"messages_for_next_wrap_proofs\" (fun () ->\n let module V = H1.Of_vector (Digest) in\n V.f proofs_verified\n (Vector.trim_front messages_for_next_wrap_proof lte) )\n and unfinalized_proofs =\n let module H = H1.Of_vector (Unfinalized) in\n H.f proofs_verified unfinalized_proofs_unextended\n and datas =\n let self_data :\n ( var\n , value\n , max_proofs_verified\n , self_branches )\n Types_map.For_step.t =\n { branches = self_branches\n ; proofs_verifieds =\n `Known\n (Vector.map basic.proofs_verifieds ~f:Field.of_int)\n ; max_proofs_verified\n ; public_input = basic.public_input\n ; wrap_domain = `Known basic.wrap_domains.h\n ; step_domains = `Known basic.step_domains\n ; wrap_key = dlog_plonk_index\n ; feature_flags = basic.feature_flags\n }\n in\n let module M =\n H4.Map (Tag) (Types_map.For_step)\n (struct\n let f :\n type a1 a2 n m.\n (a1, a2, n, m) Tag.t\n -> (a1, a2, n, m) Types_map.For_step.t =\n fun tag ->\n match Type_equal.Id.same_witness self.id tag.id with\n | Some T ->\n self_data\n | None -> (\n match tag.kind with\n | Compiled ->\n Types_map.For_step.of_compiled\n (Types_map.lookup_compiled tag.id)\n | Side_loaded ->\n Types_map.For_step.of_side_loaded\n (Types_map.lookup_side_loaded tag.id) )\n end)\n in\n M.f rule.prevs\n in\n go prevs datas messages_for_next_wrap_proofs unfinalized_proofs\n previous_proof_statements proofs_verified ~actual_wrap_domains\n in\n Boolean.Assert.all vs ; chalss )\n in\n [%log internal] \"Step_compute_bulletproof_challenges_done\" ;\n let messages_for_next_step_proof =\n let challenge_polynomial_commitments =\n let module M =\n H3.Map (Per_proof_witness) (E03 (Inner_curve))\n (struct\n let f :\n type a b c. (a, b, c) Per_proof_witness.t -> Inner_curve.t\n =\n fun acc ->\n acc.wrap_proof.opening.challenge_polynomial_commitment\n end)\n in\n let module V = H3.To_vector (Inner_curve) in\n V.f proofs_verified (M.f prevs)\n in\n with_label \"hash_messages_for_next_step_proof\" (fun () ->\n let hash_messages_for_next_step_proof =\n let to_field_elements =\n let (Typ typ) = basic.public_input in\n fun x -> fst (typ.var_to_fields x)\n in\n unstage\n (hash_messages_for_next_step_proof ~index:dlog_plonk_index\n to_field_elements )\n in\n let (app_state : var) =\n match public_input with\n | Input _ ->\n app_state\n | Output _ ->\n ret_var\n | Input_and_output _ ->\n (app_state, ret_var)\n in\n hash_messages_for_next_step_proof\n { app_state\n ; dlog_plonk_index\n ; challenge_polynomial_commitments\n ; old_bulletproof_challenges =\n (* Note: the bulletproof_challenges here are unpadded! *)\n bulletproof_challenges\n } )\n in\n let unfinalized_proofs =\n Vector.extend_front unfinalized_proofs_unextended lte\n Max_proofs_verified.n (Unfinalized.dummy ())\n in\n ( { Types.Step.Statement.proof_state =\n { unfinalized_proofs; messages_for_next_step_proof }\n ; messages_for_next_wrap_proof\n }\n : ( (Unfinalized.t, max_proofs_verified) Vector.t\n , Field.t\n , (Field.t, max_proofs_verified) Vector.t )\n Types.Step.Statement.t ) )\n in\n stage main\n","open Core_kernel\nopen Pickles_types\nopen Hlist\nopen Import\n\n(* The data obtained from \"compiling\" an inductive rule into a circuit. *)\ntype ( 'a_var\n , 'a_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value\n , 'max_proofs_verified\n , 'branches\n , 'prev_vars\n , 'prev_values\n , 'local_widths\n , 'local_heights )\n t =\n | T :\n { proofs_verified :\n 'proofs_verified Nat.t * ('prev_vars, 'proofs_verified) Hlist.Length.t\n ; index : int\n ; lte : ('proofs_verified, 'max_proofs_verified) Nat.Lte.t\n ; domains : Domains.t\n ; rule :\n ( 'prev_vars\n , 'prev_values\n , 'local_widths\n , 'local_heights\n , 'a_var\n , 'a_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value )\n Inductive_rule.t\n ; main :\n step_domains:(Domains.t, 'branches) Vector.t\n -> unit\n -> ( (Unfinalized.t, 'max_proofs_verified) Vector.t\n , Impls.Step.Field.t\n , (Impls.Step.Field.t, 'max_proofs_verified) Vector.t )\n Types.Step.Statement.t\n ; requests :\n (module Requests.Step.S\n with type statement = 'a_value\n and type max_proofs_verified = 'max_proofs_verified\n and type proofs_verified = 'proofs_verified\n and type prev_values = 'prev_values\n and type local_signature = 'local_widths\n and type local_branches = 'local_heights\n and type return_value = 'ret_value\n and type auxiliary_value = 'auxiliary_value )\n ; feature_flags : bool Plonk_types.Features.t\n }\n -> ( 'a_var\n , 'a_value\n , 'ret_var\n , 'ret_value\n , 'auxiliary_var\n , 'auxiliary_value\n , 'max_proofs_verified\n , 'branches\n , 'prev_vars\n , 'prev_values\n , 'local_widths\n , 'local_heights )\n t\n\n(* Compile an inductive rule. *)\nlet create\n (type branches max_proofs_verified var value a_var a_value ret_var ret_value)\n ~index ~(self : (var, value, max_proofs_verified, branches) Tag.t)\n ~wrap_domains ~(feature_flags : Opt.Flag.t Plonk_types.Features.Full.t)\n ~(actual_feature_flags : bool Plonk_types.Features.t)\n ~(max_proofs_verified : max_proofs_verified Nat.t)\n ~(proofs_verifieds : (int, branches) Vector.t) ~(branches : branches Nat.t)\n ~(public_input :\n ( var\n , value\n , a_var\n , a_value\n , ret_var\n , ret_value )\n Inductive_rule.public_input ) ~auxiliary_typ _var_to_field_elements\n _value_to_field_elements (rule : _ Inductive_rule.t) =\n Timer.clock __LOC__ ;\n let module HT = H4.T (Tag) in\n let (T (self_width, proofs_verified)) = HT.length rule.prevs in\n let rec extract_lengths :\n type a b n m k.\n (a, b, n, m) HT.t\n -> (a, k) Length.t\n -> n H1.T(Nat).t * m H1.T(Nat).t * (n, k) Length.t * (m, k) Length.t =\n fun ts len ->\n match (ts, len) with\n | [], Z ->\n ([], [], Z, Z)\n | t :: ts, S len -> (\n let ns, ms, len_ns, len_ms = extract_lengths ts len in\n match Type_equal.Id.same_witness self.id t.id with\n | Some T ->\n (max_proofs_verified :: ns, branches :: ms, S len_ns, S len_ms)\n | None ->\n let (module M), branches =\n match t.kind with\n | Compiled ->\n let d = Types_map.lookup_compiled t.id in\n (d.max_proofs_verified, d.branches)\n | Side_loaded ->\n let d = Types_map.lookup_side_loaded t.id in\n (d.permanent.max_proofs_verified, d.permanent.branches)\n in\n let T = M.eq in\n (M.n :: ns, branches :: ms, S len_ns, S len_ms) )\n in\n Timer.clock __LOC__ ;\n let widths, heights, local_signature_length, local_branches_length =\n extract_lengths rule.prevs proofs_verified\n in\n let lte = Nat.lte_exn self_width max_proofs_verified in\n let requests = Requests.Step.create () in\n let (typ : (var, value) Impls.Step.Typ.t) =\n match public_input with\n | Input typ ->\n typ\n | Output typ ->\n typ\n | Input_and_output (input_typ, output_typ) ->\n Impls.Step.Typ.(input_typ * output_typ)\n in\n Timer.clock __LOC__ ;\n let step ~step_domains =\n Step_main.step_main requests\n (Nat.Add.create max_proofs_verified)\n rule\n ~basic:\n { public_input = typ\n ; proofs_verifieds\n ; wrap_domains\n ; step_domains\n ; feature_flags\n }\n ~public_input ~auxiliary_typ ~self_branches:branches ~proofs_verified\n ~local_signature:widths ~local_signature_length ~local_branches:heights\n ~local_branches_length ~lte ~self\n |> unstage\n in\n Timer.clock __LOC__ ;\n let own_domains =\n let main =\n step\n ~step_domains:\n (Vector.init branches ~f:(fun _ -> Fix_domains.rough_domains))\n in\n let etyp =\n Impls.Step.input ~proofs_verified:max_proofs_verified\n ~wrap_rounds:Backend.Tock.Rounds.n\n (* TODO *)\n in\n Fix_domains.domains ~feature_flags:actual_feature_flags\n (module Impls.Step)\n (T (Snarky_backendless.Typ.unit (), Fn.id, Fn.id))\n etyp main\n in\n Timer.clock __LOC__ ;\n T\n { proofs_verified = (self_width, proofs_verified)\n ; index\n ; lte\n ; rule\n ; domains = own_domains\n ; main = step\n ; requests\n ; feature_flags = actual_feature_flags\n }\n","module SC = Scalar_challenge\nopen Pickles_types\nopen Poly_types\nopen Hlist\nopen Backend\nopen Tuple_lib\nopen Import\nopen Types\nopen Common\n\n(* This contains the \"step\" prover *)\n\nmodule Make\n (A : T0) (A_value : sig\n type t\n end)\n (Max_proofs_verified : Nat.Add.Intf_transparent) =\nstruct\n let _double_zip = Double.map2 ~f:Core_kernel.Tuple2.create\n\n module E = struct\n type t = Tock.Field.t array Double.t Plonk_types.Evals.t * Tock.Field.t\n end\n\n module Plonk_checks = struct\n include Plonk_checks\n module Type1 = Plonk_checks.Make (Shifted_value.Type1) (Scalars.Tick)\n module Type2 = Plonk_checks.Make (Shifted_value.Type2) (Scalars.Tock)\n end\n\n (* The prover corresponding to the given inductive rule. *)\n let f\n (type (* The maximum number of proofs verified by one of the proof systems verified by this rule :)\n\n In other words: each of the proofs verified by this rule comes from some pickles proof system.\n\n The ith one of those proof systems has a maximum number of proofs N_i that is verified by\n a rule in proof system i. max_local_max_proof_verifieds is the max of the N_i.\n *)\n max_local_max_proof_verifieds self_branches prev_vars prev_values\n local_widths local_heights prevs_length var value ret_var ret_value\n auxiliary_var auxiliary_value ) ?handler ~proof_cache\n (T branch_data :\n ( A.t\n , A_value.t\n , ret_var\n , ret_value\n , auxiliary_var\n , auxiliary_value\n , Max_proofs_verified.n\n , self_branches\n , prev_vars\n , prev_values\n , local_widths\n , local_heights )\n Step_branch_data.t ) (next_state : A_value.t)\n ~maxes:\n (module Maxes : Pickles_types.Hlist.Maxes.S\n with type length = Max_proofs_verified.n\n and type ns = max_local_max_proof_verifieds )\n ~(prevs_length : (prev_vars, prevs_length) Length.t) ~self ~step_domains\n ~feature_flags ~self_dlog_plonk_index\n ~(public_input :\n ( var\n , value\n , A.t\n , A_value.t\n , ret_var\n , ret_value )\n Inductive_rule.public_input )\n ~(auxiliary_typ : (auxiliary_var, auxiliary_value) Impls.Step.Typ.t) pk\n self_dlog_vk :\n ( ( value\n , (_, Max_proofs_verified.n) Vector.t\n , (_, prevs_length) Vector.t\n , (_, prevs_length) Vector.t\n , _\n , (_, Max_proofs_verified.n) Vector.t )\n Proof.Base.Step.t\n * ret_value\n * auxiliary_value\n * (int, prevs_length) Vector.t )\n Promise.t =\n let logger = Internal_tracing_context_logger.get () in\n [%log internal] \"Pickles_step_proof\" ;\n let _ = auxiliary_typ in\n (* unused *)\n let _, prev_vars_length = branch_data.proofs_verified in\n let T = Length.contr prev_vars_length prevs_length in\n let (module Req) = branch_data.requests in\n let T =\n Hlist.Length.contr (snd branch_data.proofs_verified) prev_vars_length\n in\n let prev_values_length =\n let module L12 = H4.Length_1_to_2 (Tag) in\n L12.f branch_data.rule.prevs prev_vars_length\n in\n let lte = branch_data.lte in\n let module X_hat = struct\n type t = Tock.Field.t Double.t\n end in\n let module Statement_with_hashes = struct\n type t =\n ( Challenge.Constant.t\n , Challenge.Constant.t Scalar_challenge.t\n , Tick.Field.t Shifted_value.Type1.t\n , Tick.Field.t Shifted_value.Type1.t option\n , Challenge.Constant.t Scalar_challenge.t option\n , bool\n , Digest.Constant.t\n , Digest.Constant.t\n , Digest.Constant.t\n , Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n , Branch_data.t )\n Wrap.Statement.In_circuit.t\n end in\n let challenge_polynomial =\n Wrap_verifier.challenge_polynomial (module Backend.Tock.Field)\n in\n let expand_proof :\n type var value local_max_proofs_verified m.\n Impls.Wrap.Verification_key.t\n -> 'a\n -> value\n -> (local_max_proofs_verified, local_max_proofs_verified) Proof.t\n -> (var, value, local_max_proofs_verified, m) Tag.t\n -> must_verify:bool\n -> [ `Sg of Tock.Curve.Affine.t ]\n * Unfinalized.Constant.t\n * Statement_with_hashes.t\n * X_hat.t\n * ( value\n , local_max_proofs_verified\n , m )\n Per_proof_witness.Constant.No_app_state.t\n * [ `Actual_wrap_domain of int ] =\n fun dlog_vk dlog_index app_state (T t) tag ~must_verify ->\n let t =\n { t with\n statement =\n { t.statement with\n messages_for_next_step_proof =\n { t.statement.messages_for_next_step_proof with app_state }\n }\n }\n in\n let proof = Wrap_wire_proof.to_kimchi_proof t.proof in\n let data = Types_map.lookup_basic tag in\n let plonk0 = t.statement.proof_state.deferred_values.plonk in\n let plonk =\n let domain =\n Branch_data.domain t.statement.proof_state.deferred_values.branch_data\n in\n let to_field =\n SC.to_field_constant\n (module Tick.Field)\n ~endo:Endo.Wrap_inner_curve.scalar\n in\n let alpha = to_field plonk0.alpha in\n let zeta = to_field plonk0.zeta in\n let zetaw =\n Tick.Field.(\n zeta * domain_generator ~log2_size:(Domain.log2_size domain))\n in\n let combined_evals =\n Plonk_checks.evals_of_split_evals\n (module Tick.Field)\n t.prev_evals.evals.evals ~rounds:(Nat.to_int Tick.Rounds.n) ~zeta\n ~zetaw\n |> Plonk_types.Evals.to_in_circuit\n in\n let plonk_minimal =\n { Composition_types.Wrap.Proof_state.Deferred_values.Plonk.Minimal\n .zeta\n ; alpha\n ; beta = Challenge.Constant.to_tick_field plonk0.beta\n ; gamma = Challenge.Constant.to_tick_field plonk0.gamma\n ; joint_combiner = Option.map ~f:to_field plonk0.joint_combiner\n ; feature_flags = plonk0.feature_flags\n }\n in\n let env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tick.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~srs_length_log2:Common.Max_degree.step_log2\n ~endo:Endo.Step_inner_curve.base ~mds:Tick_field_sponge.params.mds\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fp.of_bigint )\n ~domain:\n (Plonk_checks.domain\n (module Tick.Field)\n domain ~shifts:Common.tick_shifts\n ~domain_generator:Backend.Tick.Field.domain_generator )\n plonk_minimal combined_evals\n in\n time \"plonk_checks\" (fun () ->\n let module Field = struct\n include Tick.Field\n end in\n Plonk_checks.Type1.derive_plonk\n (module Field)\n ~env ~shift:Shifts.tick1 plonk_minimal combined_evals )\n in\n let (module Local_max_proofs_verified) = data.max_proofs_verified in\n let T = Local_max_proofs_verified.eq in\n let statement = t.statement in\n let prev_challenges =\n (* TODO: This is redone in the call to Reduced_messages_for_next_proof_over_same_field.Wrap.prepare *)\n Vector.map ~f:Ipa.Wrap.compute_challenges\n statement.proof_state.messages_for_next_wrap_proof\n .old_bulletproof_challenges\n in\n let deferred_values_computed =\n Wrap_deferred_values.expand_deferred ~evals:t.prev_evals\n ~old_bulletproof_challenges:\n statement.messages_for_next_step_proof.old_bulletproof_challenges\n ~proof_state:statement.proof_state\n in\n let prev_statement_with_hashes :\n ( _\n , _\n , _ Shifted_value.Type1.t\n , _\n , _\n , _\n , _\n , _\n , _\n , _\n , _ )\n Wrap.Statement.In_circuit.t =\n { messages_for_next_step_proof =\n (let to_field_elements =\n let (Typ typ) = data.public_input in\n fun x -> fst (typ.value_to_fields x)\n in\n (* TODO: Only do this hashing when necessary *)\n Common.hash_messages_for_next_step_proof\n (Reduced_messages_for_next_proof_over_same_field.Step.prepare\n ~dlog_plonk_index:dlog_index\n statement.messages_for_next_step_proof )\n ~app_state:to_field_elements )\n ; proof_state =\n { deferred_values =\n (let deferred_values = deferred_values_computed in\n { plonk =\n { plonk with\n zeta = plonk0.zeta\n ; alpha = plonk0.alpha\n ; beta = plonk0.beta\n ; gamma = plonk0.gamma\n ; joint_combiner = plonk0.joint_combiner\n }\n ; combined_inner_product =\n deferred_values.combined_inner_product\n ; b = deferred_values.b\n ; xi = deferred_values.xi\n ; bulletproof_challenges =\n statement.proof_state.deferred_values\n .bulletproof_challenges\n ; branch_data = deferred_values.branch_data\n } )\n ; sponge_digest_before_evaluations =\n statement.proof_state.sponge_digest_before_evaluations\n ; messages_for_next_wrap_proof =\n Wrap_hack.hash_messages_for_next_wrap_proof\n Local_max_proofs_verified.n\n { old_bulletproof_challenges = prev_challenges\n ; challenge_polynomial_commitment =\n statement.proof_state.messages_for_next_wrap_proof\n .challenge_polynomial_commitment\n }\n }\n }\n in\n let module O = Tock.Oracles in\n let o =\n let public_input =\n tock_public_input_of_statement ~feature_flags\n prev_statement_with_hashes\n in\n O.create dlog_vk\n ( Vector.map2\n (Vector.extend_front_exn\n statement.messages_for_next_step_proof\n .challenge_polynomial_commitments Local_max_proofs_verified.n\n (Lazy.force Dummy.Ipa.Wrap.sg) )\n (* This should indeed have length Max_proofs_verified... No! It should have type Max_proofs_verified_a. That is, the max_proofs_verified specific to a proof of this type...*)\n prev_challenges\n ~f:(fun commitment chals ->\n { Tock.Proof.Challenge_polynomial.commitment\n ; challenges = Vector.to_array chals\n } )\n |> Wrap_hack.pad_accumulator )\n public_input proof\n in\n let ((x_hat_1, _x_hat_2) as x_hat) = O.(p_eval_1 o, p_eval_2 o) in\n let scalar_chal f =\n Scalar_challenge.map ~f:Challenge.Constant.of_tock_field (f o)\n in\n let plonk0 =\n { Types.Wrap.Proof_state.Deferred_values.Plonk.Minimal.alpha =\n scalar_chal O.alpha\n ; beta = O.beta o\n ; gamma = O.gamma o\n ; zeta = scalar_chal O.zeta\n ; joint_combiner =\n Option.map\n ~f:(Scalar_challenge.map ~f:Challenge.Constant.of_tock_field)\n (O.joint_combiner_chal o)\n ; feature_flags =\n t.statement.proof_state.deferred_values.plonk.feature_flags\n }\n in\n let xi = scalar_chal O.v in\n let r = scalar_chal O.u in\n let sponge_digest_before_evaluations = O.digest_before_evaluations o in\n let to_field =\n SC.to_field_constant\n (module Tock.Field)\n ~endo:Endo.Step_inner_curve.scalar\n in\n let module As_field = struct\n let r = to_field r\n\n let xi = to_field xi\n\n let zeta = to_field plonk0.zeta\n\n let alpha = to_field plonk0.alpha\n\n let joint_combiner = O.joint_combiner o\n end in\n let w =\n Tock.Field.domain_generator ~log2_size:dlog_vk.domain.log_size_of_group\n in\n let zetaw = Tock.Field.mul As_field.zeta w in\n let new_bulletproof_challenges, b =\n let prechals =\n Array.map (O.opening_prechallenges o) ~f:(fun x ->\n Scalar_challenge.map ~f:Challenge.Constant.of_tock_field x )\n in\n let chals =\n Array.map prechals ~f:(fun x -> Ipa.Wrap.compute_challenge x)\n in\n let challenge_polynomial = unstage (challenge_polynomial chals) in\n let open As_field in\n let b =\n let open Tock.Field in\n challenge_polynomial zeta + (r * challenge_polynomial zetaw)\n in\n let prechals =\n Vector.of_list_and_length_exn\n (Array.map prechals ~f:Bulletproof_challenge.unpack |> Array.to_list)\n Tock.Rounds.n\n in\n (prechals, b)\n in\n let challenge_polynomial_commitment =\n if not must_verify then Ipa.Wrap.compute_sg new_bulletproof_challenges\n else proof.openings.proof.challenge_polynomial_commitment\n in\n let witness : _ Per_proof_witness.Constant.No_app_state.t =\n { app_state = ()\n ; proof_state =\n { prev_statement_with_hashes.proof_state with\n messages_for_next_wrap_proof = ()\n }\n ; prev_proof_evals = t.prev_evals\n ; prev_challenge_polynomial_commitments =\n Vector.extend_front_exn\n t.statement.messages_for_next_step_proof\n .challenge_polynomial_commitments Local_max_proofs_verified.n\n (Lazy.force Dummy.Ipa.Wrap.sg)\n (* TODO: This computation is also redone elsewhere. *)\n ; prev_challenges =\n Vector.extend_front_exn\n (Vector.map\n t.statement.messages_for_next_step_proof\n .old_bulletproof_challenges ~f:Ipa.Step.compute_challenges )\n Local_max_proofs_verified.n\n (Lazy.force Dummy.Ipa.Step.challenges_computed)\n ; wrap_proof =\n { opening =\n { proof.openings.proof with challenge_polynomial_commitment }\n ; messages = proof.messages\n }\n }\n in\n let tock_domain =\n Plonk_checks.domain\n (module Tock.Field)\n (Pow_2_roots_of_unity dlog_vk.domain.log_size_of_group)\n ~shifts:Common.tock_shifts\n ~domain_generator:Backend.Tock.Field.domain_generator\n in\n let tock_combined_evals =\n Plonk_checks.evals_of_split_evals\n (module Tock.Field)\n proof.openings.evals ~rounds:(Nat.to_int Tock.Rounds.n)\n ~zeta:As_field.zeta ~zetaw\n |> Plonk_types.Evals.to_in_circuit\n in\n let tock_plonk_minimal =\n { plonk0 with\n zeta = As_field.zeta\n ; alpha = As_field.alpha\n ; joint_combiner = As_field.joint_combiner\n }\n in\n let tock_env =\n let module Env_bool = struct\n type t = bool\n\n let true_ = true\n\n let false_ = false\n\n let ( &&& ) = ( && )\n\n let ( ||| ) = ( || )\n\n let any = List.exists ~f:Fn.id\n end in\n let module Env_field = struct\n include Tock.Field\n\n type bool = Env_bool.t\n\n let if_ (b : bool) ~then_ ~else_ = if b then then_ () else else_ ()\n end in\n Plonk_checks.scalars_env\n (module Env_bool)\n (module Env_field)\n ~domain:tock_domain ~srs_length_log2:Common.Max_degree.wrap_log2\n ~field_of_hex:(fun s ->\n Kimchi_pasta.Pasta.Bigint256.of_hex_string s\n |> Kimchi_pasta.Pasta.Fq.of_bigint )\n ~endo:Endo.Wrap_inner_curve.base ~mds:Tock_field_sponge.params.mds\n tock_plonk_minimal tock_combined_evals\n in\n let combined_inner_product =\n let e = proof.openings.evals in\n let b_polys =\n Vector.map\n ~f:(fun chals ->\n unstage (challenge_polynomial (Vector.to_array chals)) )\n (Wrap_hack.pad_challenges prev_challenges)\n in\n let a = Plonk_types.Evals.to_list e in\n let open As_field in\n let combine ~which_eval ~ft_eval pt =\n let f (x, y) = match which_eval with `Fst -> x | `Snd -> y in\n let v : Tock.Field.t array list =\n let a = List.map ~f a in\n List.append\n (Vector.to_list (Vector.map b_polys ~f:(fun f -> [| f pt |])))\n ([| f x_hat |] :: [| ft_eval |] :: a)\n in\n let open Tock.Field in\n Pcs_batch.combine_split_evaluations ~xi ~init:Fn.id\n ~mul_and_add:(fun ~acc ~xi fx -> fx + (xi * acc))\n v\n in\n let ft_eval0 =\n Plonk_checks.Type2.ft_eval0\n (module Tock.Field)\n ~domain:tock_domain ~env:tock_env tock_plonk_minimal\n tock_combined_evals x_hat_1\n in\n let open Tock.Field in\n combine ~which_eval:`Fst ~ft_eval:ft_eval0 As_field.zeta\n + (r * combine ~which_eval:`Snd ~ft_eval:proof.openings.ft_eval1 zetaw)\n in\n let chal = Challenge.Constant.of_tock_field in\n let plonk =\n let module Field = struct\n include Tock.Field\n end in\n (* Wrap proof, no features *)\n Plonk_checks.Type2.derive_plonk\n (module Field)\n ~env:tock_env ~shift:Shifts.tock2 tock_plonk_minimal\n tock_combined_evals\n |> Composition_types.Step.Proof_state.Deferred_values.Plonk.In_circuit\n .of_wrap\n ~assert_none:(fun x -> assert (Option.is_none (Opt.to_option x)))\n ~assert_false:(fun x -> assert (not x))\n in\n let shifted_value =\n Shifted_value.Type2.of_field (module Tock.Field) ~shift:Shifts.tock2\n in\n ( `Sg challenge_polynomial_commitment\n , { Types.Step.Proof_state.Per_proof.deferred_values =\n { plonk =\n { plonk with\n zeta = plonk0.zeta\n ; alpha = plonk0.alpha\n ; beta = chal plonk0.beta\n ; gamma = chal plonk0.gamma\n }\n ; combined_inner_product = shifted_value combined_inner_product\n ; xi\n ; bulletproof_challenges = new_bulletproof_challenges\n ; b = shifted_value b\n }\n ; should_finalize = must_verify\n ; sponge_digest_before_evaluations =\n Digest.Constant.of_tock_field sponge_digest_before_evaluations\n }\n , prev_statement_with_hashes\n , x_hat\n , witness\n , `Actual_wrap_domain dlog_vk.domain.log_size_of_group )\n in\n let challenge_polynomial_commitments = ref None in\n let unfinalized_proofs = ref None in\n let statements_with_hashes = ref None in\n let x_hats = ref None in\n let witnesses = ref None in\n let prev_proofs = ref None in\n let return_value = ref None in\n let auxiliary_value = ref None in\n let actual_wrap_domains = ref None in\n let compute_prev_proof_parts prev_proof_requests =\n let ( challenge_polynomial_commitments'\n , unfinalized_proofs'\n , statements_with_hashes'\n , x_hats'\n , witnesses'\n , prev_proofs'\n , actual_wrap_domains' ) =\n let[@warning \"-4\"] rec go :\n type vars values ns ms k.\n (vars, values, ns, ms) H4.T(Tag).t\n -> ( values\n , ns )\n H2.T(Inductive_rule.Previous_proof_statement.Constant).t\n -> (vars, k) Length.t\n -> (Tock.Curve.Affine.t, k) Vector.t\n * (Unfinalized.Constant.t, k) Vector.t\n * (Statement_with_hashes.t, k) Vector.t\n * (X_hat.t, k) Vector.t\n * ( values\n , ns\n , ms )\n H3.T(Per_proof_witness.Constant.No_app_state).t\n * (ns, ns) H2.T(Proof).t\n * (int, k) Vector.t =\n fun ts prev_proof_stmts l ->\n match (ts, prev_proof_stmts, l) with\n | [], [], Z ->\n ([], [], [], [], [], [], [])\n | ( t :: ts\n , { public_input = app_state\n ; proof = p\n ; proof_must_verify = must_verify\n }\n :: prev_proof_stmts\n , S l ) ->\n let dlog_vk, dlog_index =\n if Type_equal.Id.same self.Tag.id t.id then\n (self_dlog_vk, self_dlog_plonk_index)\n else\n let d = Types_map.lookup_basic t in\n (d.wrap_vk, d.wrap_key)\n in\n let `Sg sg, u, s, x, w, `Actual_wrap_domain domain =\n expand_proof dlog_vk dlog_index app_state p t ~must_verify\n and sgs, us, ss, xs, ws, ps, domains = go ts prev_proof_stmts l in\n ( sg :: sgs\n , u :: us\n , s :: ss\n , x :: xs\n , w :: ws\n , p :: ps\n , domain :: domains )\n | _, _ :: _, _ ->\n .\n | _, [], _ ->\n .\n in\n go branch_data.rule.prevs prev_proof_requests prev_vars_length\n in\n challenge_polynomial_commitments := Some challenge_polynomial_commitments' ;\n unfinalized_proofs := Some unfinalized_proofs' ;\n statements_with_hashes := Some statements_with_hashes' ;\n x_hats := Some x_hats' ;\n witnesses := Some witnesses' ;\n prev_proofs := Some prev_proofs' ;\n actual_wrap_domains := Some actual_wrap_domains'\n in\n let unfinalized_proofs = lazy (Option.value_exn !unfinalized_proofs) in\n let unfinalized_proofs_extended =\n lazy\n (Vector.extend_front\n (Lazy.force unfinalized_proofs)\n lte Max_proofs_verified.n\n (Lazy.force Unfinalized.Constant.dummy) )\n in\n let module Extract = struct\n module type S = sig\n type res\n\n val f : _ Proof.t -> res\n end\n end in\n let extract_from_proofs (type res)\n (module Extract : Extract.S with type res = res) =\n let rec go :\n type vars values ns ms len.\n (ns, ns) H2.T(Proof).t\n -> (values, vars, ns, ms) H4.T(Tag).t\n -> (vars, len) Length.t\n -> (res, len) Vector.t =\n fun prevs tags len ->\n match (prevs, tags, len) with\n | [], [], Z ->\n []\n | t :: prevs, _ :: tags, S len ->\n Extract.f t :: go prevs tags len\n in\n go\n (Option.value_exn !prev_proofs)\n branch_data.rule.prevs prev_values_length\n in\n let messages_for_next_step_proof :\n _ Reduced_messages_for_next_proof_over_same_field.Step.t Lazy.t =\n lazy\n (let old_bulletproof_challenges =\n extract_from_proofs\n ( module struct\n type res =\n Challenge.Constant.t Scalar_challenge.t Bulletproof_challenge.t\n Step_bp_vec.t\n\n let f (T t : _ Proof.t) =\n t.statement.proof_state.deferred_values.bulletproof_challenges\n end )\n in\n let (return_value : ret_value) = Option.value_exn !return_value in\n let (app_state : value) =\n match public_input with\n | Input _ ->\n next_state\n | Output _ ->\n return_value\n | Input_and_output _ ->\n (next_state, return_value)\n in\n (* Have the sg be available in the opening proof and verify it. *)\n { app_state\n ; challenge_polynomial_commitments =\n Option.value_exn !challenge_polynomial_commitments\n ; old_bulletproof_challenges\n } )\n in\n let messages_for_next_step_proof_prepared =\n lazy\n (Reduced_messages_for_next_proof_over_same_field.Step.prepare\n ~dlog_plonk_index:self_dlog_plonk_index\n (Lazy.force messages_for_next_step_proof) )\n in\n let messages_for_next_wrap_proof_padded =\n let rec pad :\n type n k maxes.\n (Digest.Constant.t, k) Vector.t\n -> maxes H1.T(Nat).t\n -> (maxes, n) Hlist.Length.t\n -> (Digest.Constant.t, n) Vector.t =\n fun xs maxes l ->\n match (xs, maxes, l) with\n | [], [], Z ->\n []\n | _x :: _xs, [], Z ->\n assert false\n | x :: xs, _ :: ms, S n ->\n x :: pad xs ms n\n | [], _m :: ms, S n ->\n let t : _ Types.Wrap.Proof_state.Messages_for_next_wrap_proof.t =\n { challenge_polynomial_commitment = Lazy.force Dummy.Ipa.Step.sg\n ; old_bulletproof_challenges =\n Vector.init Max_proofs_verified.n ~f:(fun _ ->\n Lazy.force Dummy.Ipa.Wrap.challenges_computed )\n }\n in\n Wrap_hack.hash_messages_for_next_wrap_proof Max_proofs_verified.n t\n :: pad [] ms n\n in\n lazy\n (Vector.rev\n (pad\n (Vector.map\n (Vector.rev (Option.value_exn !statements_with_hashes))\n ~f:(fun s -> s.proof_state.messages_for_next_wrap_proof) )\n Maxes.maxes Maxes.length ) )\n in\n let handler (Snarky_backendless.Request.With { request; respond } as r) =\n let k x = respond (Provide x) in\n match request with\n | Req.Compute_prev_proof_parts prev_proof_requests ->\n [%log internal] \"Step_compute_prev_proof_parts\" ;\n compute_prev_proof_parts prev_proof_requests ;\n [%log internal] \"Step_compute_prev_proof_parts_done\" ;\n k ()\n | Req.Proof_with_datas ->\n k (Option.value_exn !witnesses)\n | Req.Wrap_index ->\n k self_dlog_plonk_index\n | Req.App_state ->\n k next_state\n | Req.Return_value res ->\n return_value := Some res ;\n k ()\n | Req.Auxiliary_value res ->\n auxiliary_value := Some res ;\n k ()\n | Req.Unfinalized_proofs ->\n k (Lazy.force unfinalized_proofs)\n | Req.Messages_for_next_wrap_proof ->\n k (Lazy.force messages_for_next_wrap_proof_padded)\n | Req.Wrap_domain_indices ->\n let all_possible_domains = Wrap_verifier.all_possible_domains () in\n let wrap_domain_indices =\n Vector.map (Option.value_exn !actual_wrap_domains)\n ~f:(fun domain_size ->\n let domain_index =\n Vector.foldi ~init:0 all_possible_domains\n ~f:(fun j acc (Pow_2_roots_of_unity domain) ->\n if Int.equal domain domain_size then j else acc )\n in\n Pickles_base.Proofs_verified.of_int domain_index )\n in\n k wrap_domain_indices\n | _ -> (\n match handler with\n | Some f ->\n f r\n | None ->\n Snarky_backendless.Request.unhandled )\n in\n let prev_challenge_polynomial_commitments =\n lazy\n (let to_fold_in =\n extract_from_proofs\n ( module struct\n type res = Tick.Curve.Affine.t\n\n let f (T t : _ Proof.t) =\n t.statement.proof_state.messages_for_next_wrap_proof\n .challenge_polynomial_commitment\n end )\n in\n (* emphatically NOT padded with dummies *)\n Vector.(\n map2 to_fold_in\n (Lazy.force messages_for_next_step_proof_prepared)\n .old_bulletproof_challenges ~f:(fun commitment chals ->\n { Tick.Proof.Challenge_polynomial.commitment\n ; challenges = Vector.to_array chals\n } )\n |> to_list) )\n in\n let%map.Promise ( (next_proof : Tick.Proof.with_public_evals)\n , _next_statement_hashed ) =\n let (T (input, _conv, conv_inv)) =\n Impls.Step.input ~proofs_verified:Max_proofs_verified.n\n ~wrap_rounds:Tock.Rounds.n\n in\n let { Domains.h } = Vector.nth_exn step_domains branch_data.index in\n ksprintf Common.time \"step-prover %d (%d)\" branch_data.index\n (Domain.size h)\n (fun () ->\n let promise_or_error =\n (* Use a try_with to give an informative backtrace.\n If we don't do this, the backtrace will be obfuscated by the\n Promise, and it's significantly harder to track down errors.\n This only applies to errors in the 'witness generation' stage;\n proving errors are emitted inside the promise, and are therefore\n unaffected.\n *)\n Or_error.try_with ~backtrace:true (fun () ->\n [%log internal] \"Step_generate_witness_conv\" ;\n Impls.Step.generate_witness_conv\n ~f:(fun { Impls.Step.Proof_inputs.auxiliary_inputs\n ; public_inputs\n } next_statement_hashed ->\n [%log internal] \"Backend_tick_proof_create_async\" ;\n let create_proof () =\n Backend.Tick.Proof.create_async ~primary:public_inputs\n ~auxiliary:auxiliary_inputs\n ~message:\n (Lazy.force prev_challenge_polynomial_commitments)\n pk\n in\n let%map.Promise proof =\n match proof_cache with\n | None ->\n create_proof ()\n | Some proof_cache -> (\n match\n Proof_cache.get_step_proof proof_cache ~keypair:pk\n ~public_input:public_inputs\n with\n | None ->\n let%map.Promise proof = create_proof () in\n Proof_cache.set_step_proof proof_cache ~keypair:pk\n ~public_input:public_inputs proof.proof ;\n proof\n | Some proof ->\n Promise.return\n ( { proof; public_evals = None }\n : Tick.Proof.with_public_evals ) )\n in\n [%log internal] \"Backend_tick_proof_create_async_done\" ;\n (proof, next_statement_hashed) )\n ~input_typ:Impls.Step.Typ.unit ~return_typ:input\n (fun () () ->\n Impls.Step.handle\n (fun () -> conv_inv (branch_data.main ~step_domains ()))\n handler ) )\n in\n (* Re-raise any captured errors, complete with their backtrace. *)\n Or_error.ok_exn promise_or_error )\n ()\n in\n let prev_evals =\n extract_from_proofs\n ( module struct\n type res = E.t\n\n let f (T t : _ Proof.t) =\n let proof = Wrap_wire_proof.to_kimchi_proof t.proof in\n (proof.openings.evals, proof.openings.ft_eval1)\n end )\n in\n let messages_for_next_wrap_proof =\n let rec go :\n type a.\n (a, a) H2.T(Proof).t\n -> a H1.T(Proof.Base.Messages_for_next_proof_over_same_field.Wrap).t =\n function\n | [] ->\n []\n | T t :: tl ->\n t.statement.proof_state.messages_for_next_wrap_proof :: go tl\n in\n go (Option.value_exn !prev_proofs)\n in\n let next_statement : _ Types.Step.Statement.t =\n { proof_state =\n { unfinalized_proofs = Lazy.force unfinalized_proofs_extended\n ; messages_for_next_step_proof =\n Lazy.force messages_for_next_step_proof\n }\n ; messages_for_next_wrap_proof\n }\n in\n [%log internal] \"Pickles_step_proof_done\" ;\n ( { Proof.Base.Step.proof = next_proof.proof\n ; statement = next_statement\n ; index = branch_data.index\n ; prev_evals =\n Vector.extend_front\n (Vector.map2 prev_evals (Option.value_exn !x_hats)\n ~f:(fun (es, ft_eval1) x_hat ->\n Plonk_types.All_evals.\n { ft_eval1\n ; evals =\n { With_public_input.evals = es; public_input = x_hat }\n } ) )\n lte Max_proofs_verified.n (Lazy.force Dummy.evals)\n }\n , Option.value_exn !return_value\n , Option.value_exn !auxiliary_value\n , Option.value_exn !actual_wrap_domains )\nend\n","type t = [ `Cache_hit | `Generated_something | `Locally_generated ]\n\nlet ( + ) x y =\n match (x, y) with\n | `Generated_something, _ | _, `Generated_something ->\n `Generated_something\n | `Locally_generated, _ | _, `Locally_generated ->\n `Locally_generated\n | `Cache_hit, `Cache_hit ->\n `Cache_hit\n","type t = Dirty.t Lazy.t\n\nlet generate_or_load (t : t) = Lazy.force t\n\nlet ( + ) (t1 : t) (t2 : t) : t = lazy Dirty.(Lazy.force t1 + Lazy.force t2)\n","\nlet params =\n lazy\n (let module T =\n struct\n type t =\n Pickles.Backend.Tick.Field.Stable.Latest.t Group_map.Params.t\n [@@deriving bin_io_unversioned]\n end in\n Core_kernel.Binable.of_string (module T)\n \"\\002\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000i\\2196c[?\\152\\181p\\196\\252\\251\\244\\181\\140\\151w\\n\\154\\140\\220>\\209\\197|\\215\\162<\\2361\\247\\026\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\003\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\005\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\");;\n","let () = Pickles.Backend.Tock.Keypair.set_urs_info Cache_dir.cache\n\nlet () = Pickles.Backend.Tick.Keypair.set_urs_info Cache_dir.cache\n\nmodule Tock = struct\n module Full = Pickles.Impls.Wrap\n module Run = Pickles.Impls.Wrap\n\n let group_map_params () = Lazy.force Group_map_params.params\n\n include Full.Internal_Basic\n module Number = Snarky_backendless.Number.Make (Full.Internal_Basic)\n module Enumerable = Snarky_backendless.Enumerable.Make (Full.Internal_Basic)\n module Inner_curve = Pickles.Backend.Tock.Inner_curve\nend\n\nmodule Tick = struct\n module Full = Pickles.Impls.Step\n module Run = Pickles.Impls.Step\n\n let group_map_params =\n Group_map.Params.create\n (module Pickles.Backend.Tock.Field)\n Pickles.Backend.Tock.Inner_curve.Params.{ a; b }\n\n include Full.Internal_Basic\n module Number = Snarky_backendless.Number.Make (Full.Internal_Basic)\n module Enumerable = Snarky_backendless.Enumerable.Make (Full.Internal_Basic)\n module Inner_curve = Pickles.Backend.Tick.Inner_curve\nend\n","open Core_kernel\ninclude Bigint\n\nlet of_bool (b : bool) : t = if b then one else zero\n\nlet of_bit_fold_lsb ({ fold } : bool Fold_lib.Fold.t) : t =\n fold ~init:(0, zero) ~f:(fun (i, acc) b ->\n (Int.(i + 1), bit_or (shift_left (of_bool b) i) acc) )\n |> snd\n\nlet of_bits_lsb : bool list -> t =\n List.foldi ~init:zero ~f:(fun i acc b ->\n bit_or (shift_left (of_bool b) i) acc )\n","open Core_kernel\n\nmodule Make_test (F : Intf.Basic) = struct\n let test arg_typ gen_arg sexp_of_arg label unchecked checked =\n let open F.Impl in\n let converted x =\n let r =\n run_and_check\n (let open Checked.Let_syntax in\n let%bind x = exists arg_typ ~compute:(As_prover.return x) in\n checked x >>| As_prover.read F.typ)\n |> Or_error.ok_exn\n in\n r\n in\n let open Quickcheck in\n test ~trials:50 gen_arg ~f:(fun x ->\n let r1 = unchecked x in\n let r2 = converted x in\n if not (F.Unchecked.equal r1 r2) then\n failwithf\n !\"%s test failure: %{sexp:arg} -> %{sexp:F.Unchecked.t} vs \\\n %{sexp:F.Unchecked.t}\"\n label x r1 r2 ()\n else () )\n\n let test1 l f g = test F.typ F.Unchecked.gen F.Unchecked.sexp_of_t l f g\n\n let test2 l f g =\n let open F in\n test (Impl.Typ.( * ) typ typ)\n (Quickcheck.Generator.tuple2 Unchecked.gen Unchecked.gen)\n [%sexp_of: Unchecked.t * Unchecked.t] l (Tuple2.uncurry f)\n (Tuple2.uncurry g)\nend\n\nmodule Make (F : Intf.Basic) = struct\n open F.Impl\n open Let_syntax\n open F\n\n let typ = F.typ\n\n let constant = F.constant\n\n let scale = F.scale\n\n let assert_r1cs = F.assert_r1cs\n\n let equal x y =\n Checked.all\n (List.map2_exn (F.to_list x) (F.to_list y) ~f:Field.Checked.equal)\n >>= Boolean.all\n\n let assert_equal x y =\n assert_all\n (List.map2_exn\n ~f:(fun x y -> Constraint.equal x y)\n (F.to_list x) (F.to_list y) )\n\n let ( + ) = F.( + )\n\n let%test_unit \"add\" =\n let module M = Make_test (F) in\n M.test2 \"add\" Unchecked.( + ) (fun x y -> return (x + y))\n\n let ( - ) = F.( - )\n\n let negate = F.negate\n\n let zero = constant Unchecked.zero\n\n let one = constant Unchecked.one\n\n let div_unsafe x y =\n match (to_constant x, to_constant y) with\n | Some x, Some y ->\n return (constant Unchecked.(x / y))\n | _, _ ->\n let%bind x_over_y =\n exists typ\n ~compute:\n As_prover.(map2 (read typ x) (read typ y) ~f:Unchecked.( / ))\n in\n let%map () = assert_r1cs y x_over_y x in\n x_over_y\n\n let assert_square =\n match assert_square with\n | `Custom f ->\n f\n | `Define ->\n fun a a2 -> assert_r1cs a a a2\n\n let ( * ) =\n match ( * ) with\n | `Custom f ->\n f\n | `Define -> (\n fun x y ->\n match (to_constant x, to_constant y) with\n | Some x, Some y ->\n return (constant Unchecked.(x * y))\n | _, _ ->\n let%bind res =\n exists typ\n ~compute:\n As_prover.(\n map2 (read typ x) (read typ y) ~f:Unchecked.( * ))\n in\n let%map () = assert_r1cs x y res in\n res )\n\n let%test_unit \"mul\" =\n let module M = Make_test (F) in\n M.test2 \"mul\" Unchecked.( * ) ( * )\n\n let square =\n match square with\n | `Custom f ->\n f\n | `Define -> (\n fun x ->\n match to_constant x with\n | Some x ->\n return (constant (Unchecked.square x))\n | None ->\n let%bind res =\n exists typ\n ~compute:As_prover.(map (read typ x) ~f:Unchecked.square)\n in\n let%map () = assert_square x res in\n res )\n\n let%test_unit \"square\" =\n let module M = Make_test (F) in\n M.test1 \"square\" Unchecked.square square\n\n let inv_exn =\n match inv_exn with\n | `Custom f ->\n f\n | `Define -> (\n fun t ->\n match to_constant t with\n | Some x ->\n return (constant (Unchecked.inv x))\n | None ->\n let%bind res =\n exists typ\n ~compute:As_prover.(map (read typ t) ~f:Unchecked.inv)\n in\n let%map () = assert_r1cs t res one in\n res )\nend\n\nmodule Make_applicative\n (F : Intf.S)\n (A : Intf.Traversable_applicative with module Impl := F.Impl) =\nstruct\n type t = F.t A.t\n\n type 'a t_ = 'a F.t_ A.t\n\n let constant = A.map ~f:F.constant\n\n let to_constant =\n let exception None_exn in\n fun t ->\n try\n Some\n (A.map t ~f:(fun x ->\n match F.to_constant x with Some x -> x | None -> raise None_exn )\n )\n with None_exn -> None\n\n let if_ b ~then_ ~else_ =\n A.sequence (A.map2 then_ else_ ~f:(fun t e -> F.if_ b ~then_:t ~else_:e))\n\n let scale t x = A.map t ~f:(fun a -> F.scale a x)\n\n let scale' t x = A.map t ~f:(fun a -> F.scale x a)\n\n let negate t = A.map t ~f:F.negate\n\n let ( + ) = A.map2 ~f:F.( + )\n\n let ( - ) = A.map2 ~f:F.( - )\n\n let map_ t ~f = A.map t ~f:(F.map_ ~f)\n\n let map2_ t1 t2 ~f = A.map2 t1 t2 ~f:(fun x1 x2 -> F.map2_ x1 x2 ~f)\nend\n\nmodule F (Impl : Snarky_backendless.Snark_intf.S) :\n Intf.S with type 'a Base.t_ = 'a and type 'a A.t = 'a and module Impl = Impl =\nstruct\n module T = struct\n module Unchecked = struct\n include Impl.Field\n module Nat = Snarkette.Nat\n\n let order = Snarkette.Nat.of_string (Bigint.to_string Impl.Field.size)\n\n let to_yojson x = `String (to_string x)\n\n let of_yojson = function\n | `String s ->\n Ok (of_string s)\n | _ ->\n Error \"Field.of_yojson: expected string\"\n end\n\n module Impl = Impl\n open Impl\n\n let map_ t ~f = f t\n\n let map2_ t1 t2 ~f = f t1 t2\n\n module Base = struct\n type 'a t_ = 'a\n\n module Unchecked = struct\n type t = Field.t t_\n\n let to_yojson x = `String (Field.to_string x)\n\n let of_yojson = function\n | `String s ->\n Ok (Field.of_string s)\n | _ ->\n Error \"Field.of_yojson: expected string\"\n end\n\n type t = Field.Var.t t_\n\n let map_ = map_\n end\n\n module A = struct\n type 'a t = 'a\n\n let map = map_\n\n let map2 = map2_\n\n let sequence = Fn.id\n end\n\n type 'a t_ = 'a\n\n let to_list x = [ x ]\n\n type t = Field.Var.t\n\n let if_ = Field.Checked.if_\n\n let typ = Field.typ\n\n let constant = Field.Var.constant\n\n let to_constant = Field.Var.to_constant\n\n let scale = Field.Var.scale\n\n let mul_field = Field.Checked.mul\n\n let assert_r1cs a b c = assert_r1cs a b c\n\n let ( + ) = Field.Checked.( + )\n\n let ( - ) = Field.Checked.( - )\n\n let negate t = Field.Var.scale t Unchecked.(negate one)\n\n let assert_square = `Custom (fun a c -> assert_square a c)\n\n let ( * ) = `Custom Field.Checked.mul\n\n let square = `Custom Field.Checked.square\n\n let inv_exn = `Custom Field.Checked.inv\n\n let real_part = Fn.id\n end\n\n include T\n include Make (T)\nend\n\n(* Given a field F and s : F (called [non_residue] below)\n such that x^2 - s does not have a root in F, construct\n the field F(sqrt(s)) = F[x] / (x^2 - s) *)\nmodule E2\n (F : Intf.S) (Params : sig\n val non_residue : F.Unchecked.t\n\n val mul_by_non_residue : F.t -> F.t\n end) : sig\n include\n Intf.S_with_primitive_element\n with module Impl = F.Impl\n and module Base = F\n and type 'a A.t = 'a * 'a\n\n val unitary_inverse : t -> t\nend = struct\n open Params\n\n module T = struct\n module Base = F\n module Impl = F.Impl\n open Impl\n module Unchecked = Snarkette.Fields.Make_fp2 (F.Unchecked) (Params)\n\n module A = struct\n type 'a t = 'a * 'a\n\n let map (x, y) ~f = (f x, f y)\n\n let map2 (x1, y1) (x2, y2) ~f = (f x1 x2, f y1 y2)\n\n let sequence (x, y) =\n let%map x = x and y = y in\n (x, y)\n end\n\n let to_list (x, y) = F.to_list x @ F.to_list y\n\n (* A value [(a, b) : t] should be thought of as the field element\n a + b sqrt(s). Then all operations are just what follow algebraically. *)\n\n include Make_applicative (Base) (A)\n\n let mul_field (a, b) x =\n let%map a = Base.mul_field a x and b = Base.mul_field b x in\n (a, b)\n\n let typ = Typ.tuple2 F.typ F.typ\n\n (*\n (a + b sqrt(s))^2\n = a^2 + b^2 s + 2 a b sqrt(s)\n\n So it is clear that the second coordinate of the below definition is correct. Let's\n examine the first coordinate.\n\n t - ab - ab sqrt(s)\n = (a + b) (a + s b) - ab - s a b\n = a^2 + a b + s a b + s b^2 - a b - s a b\n = a^2 + s b^2\n\n so this is correct as well.\n *)\n let square (a, b) =\n let open F in\n let%map ab = a * b and t = (a + b) * (a + mul_by_non_residue b) in\n (t - ab - mul_by_non_residue ab, ab + ab)\n\n let assert_square (a, b) (a2, b2) =\n let open F in\n let ab = scale b2 Field.(one / of_int 2) in\n let%map () = assert_r1cs a b ab\n and () =\n assert_r1cs (a + b)\n (a + mul_by_non_residue b)\n (a2 + ab + mul_by_non_residue ab)\n in\n ()\n\n (*\n (a1 + b1 sqrt(s)) (a2 + b2 sqrt(s))\n = (a1 a2 + b1 b2 s) + (a2 b1 + a1 b2) sqrt(s)\n\n So it is clear that the first coordinate is correct. Let's examine the second\n coordinate.\n\n t - a1 a2 - b1 b2\n = (a1 + b1) (a2 + b2) - a1 a2 - b1 b2\n = a1 a2 + b2 b2 + a1 b2 + a2 b1 - a1 a2 - b1 b2\n = a1 b2 + a2 b1\n\n So this is correct as well.\n *)\n let ( * ) (a1, b1) (a2, b2) =\n let open F in\n let%map a = a1 * a2 and b = b1 * b2 and t = (a1 + b1) * (a2 + b2) in\n (a + mul_by_non_residue b, t - a - b)\n\n let mul_by_primitive_element (a, b) = (mul_by_non_residue b, a)\n\n let assert_r1cs (a1, b1) (a2, b2) (a3, b3) =\n let open F in\n let%bind b = b1 * b2 in\n let a = a3 - mul_by_non_residue b in\n let%map () = assert_r1cs a1 a2 a\n and () = assert_r1cs (a1 + b1) (a2 + b2) (b3 + a + b) in\n ()\n\n let square = `Custom square\n\n let ( * ) = `Custom ( * )\n\n let inv_exn = `Define\n\n let assert_square = `Custom assert_square\n\n let real_part (x, _) = Base.real_part x\n end\n\n include T\n include Make (T)\n\n let unitary_inverse (a, b) = (a, Base.negate b)\nend\n\n(* Given a prime order field F and s : F (called [non_residue] below)\n such that x^3 - s is irreducible, construct\n the field F(cube_root(s)) = F[x] / (x^3 - s).\n\n Let S = cube_root(s) in the following.\n*)\n\nmodule T3 = struct\n type 'a t = 'a * 'a * 'a\n\n let map (x, y, z) ~f = (f x, f y, f z)\n\n let map2 (x1, y1, z1) (x2, y2, z2) ~f = (f x1 x2, f y1 y2, f z1 z2)\nend\n\nmodule E3\n (F : Intf.S) (Params : sig\n val non_residue : F.Unchecked.t\n\n val frobenius_coeffs_c1 : F.Unchecked.t array\n\n val frobenius_coeffs_c2 : F.Unchecked.t array\n\n val mul_by_non_residue : F.t -> F.t\n end) :\n Intf.S_with_primitive_element\n with module Impl = F.Impl\n and module Base = F\n and type 'a A.t = 'a * 'a * 'a = struct\n module T = struct\n module Base = F\n module Unchecked = Snarkette.Fields.Make_fp3 (F.Unchecked) (Params)\n module Impl = F.Impl\n open Impl\n\n module A = struct\n include T3\n\n let sequence (x, y, z) =\n let%map x = x and y = y and z = z in\n (x, y, z)\n end\n\n let to_list (x, y, z) = F.to_list x @ F.to_list y @ F.to_list z\n\n include Make_applicative (Base) (A)\n\n let typ = Typ.tuple3 F.typ F.typ F.typ\n\n let mul_field (a, b, c) x =\n let%map a = Base.mul_field a x\n and b = Base.mul_field b x\n and c = Base.mul_field c x in\n (a, b, c)\n\n (*\n (a1 + S b1 + S^2 c1) (a2 + S b2 + S^2 c2)\n = a1 a2 + S a1 b2 + S^2 a1 c2\n + S b1 a2 + S^2 b1 b2 + S^3 b1 c2\n + S^2 c1 a2 + S^3 c1 b2 + S^4 c1 c2\n = a1 a2 + S a1 b2 + S^2 a1 c2\n + S b1 a2 + S^2 b1 b2 + s b1 c2\n + S^2 c1 a2 + s c1 b2 + s S c1 c2\n = (a1 a2 + s b1 c2 + s c1 b2)\n + S (a1 b2 + b1 a2 + s c1 c2)\n + S^2 (a1 c2 + c1 a2 + b1 b2)\n\n Let us examine the three coordinates in turn.\n\n First coordinate:\n a + s (t1 - b - c)\n = a1 a2 + s ( (b1 + c1) (b2 + c2) - b - c)\n = a1 a2 + s (b1 c2 + b2 c1)\n which is evidently correct.\n\n Second coordinate:\n t2 - a - b + s c\n (a1 + b1) (a2 + b2) - a - b + s c\n a1 b2 + b1 a2 + s c\n which is evidently correct.\n\n Third coordinate:\n t3 - a + b - c\n = (a1 + c1) (a2 + c2) - a + b - c\n = a1 c2 + c1 a2 + b\n which is evidently correct.\n *)\n let ( * ) (a1, b1, c1) (a2, b2, c2) =\n with_label __LOC__ (fun () ->\n let open F in\n let%map a = a1 * a2\n and b = b1 * b2\n and c = c1 * c2\n and t1 = (b1 + c1) * (b2 + c2)\n and t2 = (a1 + b1) * (a2 + b2)\n and t3 = (a1 + c1) * (a2 + c2) in\n ( a + Params.mul_by_non_residue (t1 - b - c)\n , t2 - a - b + Params.mul_by_non_residue c\n , t3 - a + b - c ) )\n\n (*\n (a + S b + S^2 c)^2\n = a^2 + S a b + S^2 a c\n + S a b + S^2 b^2 + S^3 b c\n + S^2 a c + S^3 b c + S^4 c^2\n = a^2 + S a b + S^2 a c\n + S a b + S^2 b^2 + s b c\n + S^2 a c + s b c + S s c^2\n = (a^2 + 2 s b c)\n + S (2 a b + s c^2)\n + S^2 (b^2 + 2 a c)\n\n Let us examine the three coordinates in turn.\n\n First coordinate:\n s0 + s s3\n = a^2 + 2 s b c\n which is evidently correct.\n\n Second coordinate:\n s1 + s s4\n = 2 a b + s c^2\n which is evidently correct.\n\n Third coordinate:\n s1 + s2 + s3 - s0 - s4\n = 2 a b + (a - b + c)^2 + 2 b c - a^2 - c^2\n = 2 a b + a^2 - 2 a b + 2 a c - 2 b c + b^2 + c^2 + 2 b c - a^2 - c^2\n = 2 a c + b^2\n which is evidently correct.\n *)\n let square (a, b, c) =\n let open F in\n let%map s0 = square a\n and ab = a * b\n and bc = b * c\n and s2 = square (a - b + c)\n and s4 = square c in\n let s1 = ab + ab in\n let s3 = bc + bc in\n ( s0 + Params.mul_by_non_residue s3\n , s1 + Params.mul_by_non_residue s4\n , s1 + s2 + s3 - s0 - s4 )\n\n let mul_by_primitive_element (a, b, c) = (Params.mul_by_non_residue c, a, b)\n\n let assert_r1cs (a1, b1, c1) (a2, b2, c2) (a3, b3, c3) =\n with_label __LOC__ (fun () ->\n let open F in\n let%bind b = b1 * b2 and c = c1 * c2 and t1 = (b1 + c1) * (b2 + c2) in\n let a = a3 - Params.mul_by_non_residue (t1 - b - c) in\n let%map () = assert_r1cs a1 a2 a\n and () =\n assert_r1cs (a1 + b1) (a2 + b2)\n (b3 + a + b - Params.mul_by_non_residue c)\n and () = assert_r1cs (a1 + c1) (a2 + c2) (c3 + a - b + c) in\n () )\n\n let square = `Custom square\n\n let ( * ) = `Custom ( * )\n\n let inv_exn = `Define\n\n let assert_square = `Define\n\n let real_part (a, _, _) = F.real_part a\n end\n\n include T\n include Make (T)\nend\n\nmodule F3\n (F : Intf.S with type 'a A.t = 'a and type 'a Base.t_ = 'a) (Params : sig\n val non_residue : F.Unchecked.t\n\n val frobenius_coeffs_c1 : F.Unchecked.t array\n\n val frobenius_coeffs_c2 : F.Unchecked.t array\n end) :\n Intf.S_with_primitive_element\n with module Impl = F.Impl\n and module Base = F\n and type 'a A.t = 'a * 'a * 'a = struct\n module T = struct\n module Base = F\n module Unchecked = Snarkette.Fields.Make_fp3 (F.Unchecked) (Params)\n module Impl = F.Impl\n open Impl\n\n let mul_by_primitive_element (a, b, c) = (F.scale c Params.non_residue, a, b)\n\n module A = struct\n include T3\n\n let sequence (x, y, z) =\n let%map x = x and y = y and z = z in\n (x, y, z)\n end\n\n let to_list (x, y, z) = [ x; y; z ]\n\n include Make_applicative (Base) (A)\n\n let typ = Typ.tuple3 F.typ F.typ F.typ\n\n let mul_field (a, b, c) x =\n let%map a = Base.mul_field a x\n and b = Base.mul_field b x\n and c = Base.mul_field c x in\n (a, b, c)\n\n let assert_r1cs (a0, a1, a2) (b0, b1, b2) (c0, c1, c2) =\n let open F in\n let%bind v0 = a0 * b0 and v4 = a2 * b2 in\n let beta = Params.non_residue in\n let beta_inv = F.Unchecked.inv beta in\n let%map () =\n assert_r1cs\n (a0 + a1 + a2)\n (b0 + b1 + b2)\n ( c1 + c2 + F.scale c0 beta_inv\n + F.(scale v0 Unchecked.(one - beta_inv))\n + F.(scale v4 Unchecked.(one - beta)) )\n and () =\n assert_r1cs\n (a0 - a1 + a2)\n (b0 - b1 + b2)\n ( c2 - c1\n + F.(scale v0 Unchecked.(one + beta_inv))\n - F.scale c0 beta_inv\n + F.(scale v4 Unchecked.(one + beta)) )\n and () =\n let two = Impl.Field.of_int 2 in\n let four = Impl.Field.of_int 4 in\n let sixteen = Impl.Field.of_int 16 in\n let eight_beta_inv = Impl.Field.(mul (of_int 8) beta_inv) in\n assert_r1cs\n (a0 + F.scale a1 two + F.scale a2 four)\n (b0 + F.scale b1 two + F.scale b2 four)\n ( F.scale c1 two + F.scale c2 four + F.scale c0 eight_beta_inv\n + F.(scale v0 Unchecked.(one - eight_beta_inv))\n + F.(scale v4 Unchecked.(sixteen - (beta + beta))) )\n in\n ()\n\n let ( * ) = `Define\n\n let inv_exn = `Define\n\n let square = `Define\n\n let assert_square = `Define\n\n let real_part (a, _, _) = F.real_part a\n end\n\n include T\n include Make (T)\nend\n\nmodule Cyclotomic_square = struct\n module Make_F4 (F2 : Intf.S_with_primitive_element) = struct\n let cyclotomic_square (c0, c1) =\n let open F2 in\n let open Impl in\n let%map b_squared = square (c0 + c1) and a = square c1 in\n let c = b_squared - a in\n let d = mul_by_primitive_element a in\n let e = c - d in\n let f = scale d (Field.of_int 2) + one in\n let g = e - one in\n (f, g)\n end\n\n module Make_F6\n (F2 : Intf.S_with_primitive_element\n with type 'a A.t = 'a * 'a\n and type 'a Base.t_ = 'a)\n (Params : sig\n val cubic_non_residue : F2.Impl.Field.t\n end) =\n struct\n let cyclotomic_square ((x00, x01, x02), (x10, x11, x12)) =\n let open F2.Impl in\n let ((a0, a1) as a) = (x00, x11) in\n let ((b0, b1) as b) = (x10, x02) in\n let ((c0, c1) as c) = (x01, x12) in\n let%map asq0, asq1 = F2.square a\n and bsq0, bsq1 = F2.square b\n and csq0, csq1 = F2.square c in\n let fpos x y =\n Field.(Var.(add (scale x (of_int 3)) (scale y (of_int 2))))\n in\n let fneg x y =\n Field.(Var.(sub (scale x (of_int 3)) (scale y (of_int 2))))\n in\n ( (fneg asq0 a0, fneg bsq0 c0, fneg csq0 b1)\n , ( fpos (Field.Var.scale csq1 Params.cubic_non_residue) b0\n , fpos asq1 a1\n , fpos bsq1 c1 ) )\n end\nend\n\nmodule F6\n (Fq : Intf.S with type 'a A.t = 'a and type 'a Base.t_ = 'a)\n (Fq2 : Intf.S_with_primitive_element\n with module Impl = Fq.Impl\n and type 'a A.t = 'a * 'a\n and type 'a Base.t_ = 'a Fq.t_)\n (Fq3 : sig\n include\n Intf.S_with_primitive_element\n with module Impl = Fq.Impl\n and type 'a A.t = 'a * 'a * 'a\n and type 'a Base.t_ = 'a Fq.t_\n\n module Params : sig\n val non_residue : Fq.Unchecked.t\n\n val frobenius_coeffs_c1 : Fq.Unchecked.t array\n\n val frobenius_coeffs_c2 : Fq.Unchecked.t array\n end\n end) (Params : sig\n val frobenius_coeffs_c1 : Fq.Unchecked.t array\n end) =\nstruct\n include\n E2\n (Fq3)\n (struct\n let non_residue : Fq3.Unchecked.t = Fq.Unchecked.(zero, one, zero)\n\n let mul_by_non_residue = Fq3.mul_by_primitive_element\n end)\n\n let fq_mul_by_non_residue x = Fq.scale x Fq3.Params.non_residue\n\n let special_mul (a0, a1) (b0, b1) =\n let open Impl in\n let%bind v1 = Fq3.(a1 * b1) in\n let%bind v0 =\n let a00, a01, a02 = a0 in\n let _, _, b02 = b0 in\n let%map a00b02 = Fq.(a00 * b02)\n and a01b02 = Fq.(a01 * b02)\n and a02b02 = Fq.(a02 * b02) in\n (fq_mul_by_non_residue a01b02, fq_mul_by_non_residue a02b02, a00b02)\n in\n let beta_v1 = Fq3.mul_by_primitive_element v1 in\n let%map t = Fq3.((a0 + a1) * (b0 + b1)) in\n Fq3.(v0 + beta_v1, t - v0 - v1)\n\n let assert_special_mul ((((a00, a01, a02) as a0), a1) : t)\n ((((_, _, b02) as b0), b1) : t) ((c00, c01, c02), c1) =\n let open Impl in\n let%bind ((v10, v11, v12) as v1) = Fq3.(a1 * b1) in\n let%bind v0 =\n exists Fq3.typ\n ~compute:\n As_prover.(\n map2 ~f:Fq3.Unchecked.( * ) (read Fq3.typ a0) (read Fq3.typ b0))\n (* v0\n = (a00 + s a01 s^2 a02) (s^2 b02)\n = non_residue a01 b02 + non_residue s a02 b02 + s^2 a00 b02 *)\n in\n let%map () =\n let%map () =\n Fq.assert_r1cs a01\n (Fq.scale b02 Fq3.Params.non_residue)\n (Field.Var.linear_combination\n [ (Field.one, c00); (Field.negate Fq3.Params.non_residue, v12) ] )\n and () =\n Fq.assert_r1cs a02 (Fq.scale b02 Fq3.Params.non_residue) Fq.(c01 - v10)\n and () = Fq.assert_r1cs a00 b02 Fq.(c02 - v11) in\n ()\n and () = Fq3.assert_r1cs Fq3.(a0 + a1) Fq3.(b0 + b1) Fq3.(c1 + v0 + v1) in\n ()\n\n let special_div_unsafe a b =\n let open Impl in\n let%bind result =\n exists typ\n ~compute:As_prover.(map2 ~f:Unchecked.( / ) (read typ a) (read typ b))\n in\n (* result * b = a *)\n let%map () = assert_special_mul result b a in\n result\n\n (* TODO: Make sure this is ok *)\n let special_div = special_div_unsafe\n\n include\n Cyclotomic_square.Make_F6\n (Fq2)\n (struct\n let cubic_non_residue = Fq3.Params.non_residue\n end)\n\n let frobenius ((c00, c01, c02), (c10, c11, c12)) power =\n let module Field = Impl.Field in\n let p3 = power mod 3 in\n let p6 = power mod 6 in\n let ( * ) s x = Field.Var.scale x s in\n ( ( c00\n , Fq3.Params.frobenius_coeffs_c1.(p3) * c01\n , Fq3.Params.frobenius_coeffs_c2.(p3) * c02 )\n , ( Params.frobenius_coeffs_c1.(p6) * c10\n , Field.mul\n Params.frobenius_coeffs_c1.(p6)\n Fq3.Params.frobenius_coeffs_c1.(p3)\n * c11\n , Field.mul\n Params.frobenius_coeffs_c1.(p6)\n Fq3.Params.frobenius_coeffs_c2.(p3)\n * c12 ) )\nend\n\nmodule F4\n (Fq2 : Intf.S_with_primitive_element\n with type 'a A.t = 'a * 'a\n and type 'a Base.t_ = 'a)\n (Params : sig\n val frobenius_coeffs_c1 : Fq2.Impl.Field.t array\n end) =\nstruct\n include\n E2\n (Fq2)\n (struct\n let non_residue = Fq2.Impl.Field.(zero, one)\n\n let mul_by_non_residue = Fq2.mul_by_primitive_element\n end)\n\n let special_mul = ( * )\n\n (* TODO: Make sure this is ok *)\n let special_div = div_unsafe\n\n include Cyclotomic_square.Make_F4 (Fq2)\n\n let frobenius ((c00, c01), (c10, c11)) power =\n let module Field = Impl.Field in\n let p2 = Params.frobenius_coeffs_c1.(Int.( * ) (power mod 2) 2) in\n let p4 = Params.frobenius_coeffs_c1.(power mod 4) in\n let ( * ) s x = Field.Var.scale x s in\n ((c00, p2 * c01), (p4 * c10, Field.(p4 * p2) * c11))\nend\n","module Bignum_bigint = Bigint\nopen Core_kernel\n\nmodule type Params_intf = sig\n type field\n\n val a : field\n\n val b : field\nend\n\nmodule type Scalar_intf = sig\n type (_, _) typ\n\n type (_, _) checked\n\n type boolean_var\n\n type var\n\n type t [@@deriving equal, sexp]\n\n val typ : (var, t) typ\n\n val length_in_bits : int\n\n val test_bit : t -> int -> bool\n\n module Checked : sig\n val equal : var -> var -> (boolean_var, _) checked\n\n module Assert : sig\n val equal : var -> var -> (unit, _) checked\n end\n end\nend\n\nmodule type Shifted_intf = sig\n type _ checked\n\n type boolean_var\n\n type curve_var\n\n type t\n\n val zero : t\n\n val add : t -> curve_var -> t checked\n\n (* This is only safe if the result is guaranteed to not be zero. *)\n\n val unshift_nonzero : t -> curve_var checked\n\n val if_ : boolean_var -> then_:t -> else_:t -> t checked\n\n module Assert : sig\n val equal : t -> t -> unit checked\n end\nend\n\nmodule type Weierstrass_checked_intf = sig\n module Impl : Snarky_backendless.Snark_intf.S\n\n open Impl\n\n type unchecked\n\n type t\n\n val typ : (t, unchecked) Typ.t\n\n module Shifted : sig\n module type S =\n Shifted_intf\n with type 'a checked := 'a Checked.t\n and type curve_var := t\n and type boolean_var := Boolean.var\n\n type 'a m = (module S with type t = 'a)\n\n val create : unit -> (module S) Checked.t\n end\n\n val negate : t -> t\n\n val constant : unchecked -> t\n\n val add_unsafe :\n t -> t -> [ `I_thought_about_this_very_carefully of t ] Checked.t\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t Checked.t\n\n val double : t -> t Checked.t\n\n val if_value : Boolean.var -> then_:unchecked -> else_:unchecked -> t\n\n val scale :\n 's Shifted.m\n -> t\n -> Boolean.var Bitstring_lib.Bitstring.Lsb_first.t\n -> init:'s\n -> 's Checked.t\n\n val scale_known :\n 's Shifted.m\n -> unchecked\n -> Boolean.var Bitstring_lib.Bitstring.Lsb_first.t\n -> init:'s\n -> 's Checked.t\n\n val sum : 's Shifted.m -> t list -> init:'s -> 's Checked.t\n\n module Assert : sig\n val on_curve : t -> unit Checked.t\n\n val equal : t -> t -> unit Checked.t\n end\nend\n\nmodule Make_weierstrass_checked\n (F : Snarky_field_extensions.Intf.S) (Scalar : sig\n type t\n\n val of_int : int -> t\n end) (Curve : sig\n type t\n\n val random : unit -> t\n\n val to_affine_exn : t -> F.Unchecked.t * F.Unchecked.t\n\n val of_affine : F.Unchecked.t * F.Unchecked.t -> t\n\n val double : t -> t\n\n val ( + ) : t -> t -> t\n\n val negate : t -> t\n\n val scale : t -> Scalar.t -> t\n end)\n (Params : Params_intf with type field := F.Unchecked.t) (Override : sig\n val add : (F.t * F.t -> F.t * F.t -> (F.t * F.t) F.Impl.Checked.t) option\n end) :\n Weierstrass_checked_intf\n with module Impl := F.Impl\n and type unchecked := Curve.t\n and type t = F.t * F.t = struct\n open F.Impl\n\n type t = F.t * F.t\n\n let assert_on_curve (x, y) =\n let open F in\n let%bind x2 = square x in\n let%bind x3 = x2 * x in\n let%bind ax = constant Params.a * x in\n assert_square y (x3 + ax + constant Params.b)\n\n let typ : (t, Curve.t) Typ.t =\n let (Typ unchecked) =\n Typ.transport\n Typ.(tuple2 F.typ F.typ)\n ~there:Curve.to_affine_exn ~back:Curve.of_affine\n in\n Typ { unchecked with check = assert_on_curve }\n\n let negate ((x, y) : t) : t = (x, F.negate y)\n\n let constant (t : Curve.t) : t =\n let x, y = Curve.to_affine_exn t in\n F.(constant x, constant y)\n\n let assert_equal (x1, y1) (x2, y2) =\n let%map () = F.assert_equal x1 x2 and () = F.assert_equal y1 y2 in\n ()\n\n module Assert = struct\n let on_curve = assert_on_curve\n\n let equal = assert_equal\n end\n\n open Let_syntax\n\n let%snarkydef_ add' ~div (ax, ay) (bx, by) =\n let open F in\n let%bind lambda = div (by - ay) (bx - ax) in\n let%bind cx =\n exists typ\n ~compute:\n (let open As_prover in\n let open Let_syntax in\n let%map ax = read typ ax\n and bx = read typ bx\n and lambda = read typ lambda in\n Unchecked.(square lambda - (ax + bx)))\n in\n let%bind () =\n (* lambda^2 = cx + ax + bx\n cx = lambda^2 - (ax + bc)\n *)\n assert_square lambda F.(cx + ax + bx)\n in\n let%bind cy =\n exists typ\n ~compute:\n (let open As_prover in\n let open Let_syntax in\n let%map ax = read typ ax\n and ay = read typ ay\n and cx = read typ cx\n and lambda = read typ lambda in\n Unchecked.((lambda * (ax - cx)) - ay))\n in\n let%map () = assert_r1cs lambda (ax - cx) (cy + ay) in\n (cx, cy)\n\n let add' ~div p1 p2 =\n match Override.add with Some add -> add p1 p2 | None -> add' ~div p1 p2\n\n (* This function MUST NOT be called UNLESS you are certain the two points\n on which it is called are not equal. If it is called on equal points,\n the prover can return almost any curve point they want to from this function. *)\n let add_unsafe p q =\n let%map r = add' ~div:F.div_unsafe p q in\n `I_thought_about_this_very_carefully r\n\n let add_exn p q = add' ~div:(fun x y -> F.inv_exn y >>= F.(( * ) x)) p q\n\n (* TODO-someday: Make it so this doesn't have to compute both branches *)\n let if_ b ~then_:(tx, ty) ~else_:(ex, ey) =\n let%map x = F.if_ b ~then_:tx ~else_:ex\n and y = F.if_ b ~then_:ty ~else_:ey in\n (x, y)\n\n module Shifted = struct\n module type S =\n Shifted_intf\n with type 'a checked := 'a Checked.t\n and type curve_var := t\n and type boolean_var := Boolean.var\n\n type 'a m = (module S with type t = 'a)\n\n module Make (M : sig\n val shift : t\n end) : S = struct\n open M\n\n type nonrec t = t\n\n let zero = shift\n\n let if_ = if_\n\n let unshift_nonzero shifted = add_exn (negate shift) shifted\n\n let add shifted x = add_exn shifted x\n\n module Assert = struct\n let equal = assert_equal\n end\n end\n\n let create () : (module S) Checked.t =\n let%map shift =\n exists typ ~compute:As_prover.(map (return ()) ~f:Curve.random)\n in\n let module M = Make (struct\n let shift = shift\n end) in\n (module M : S)\n end\n\n let%snarkydef_ double (ax, ay) =\n let open F in\n let%bind x_squared = square ax in\n let%bind lambda =\n exists typ\n ~compute:\n As_prover.(\n map2 (read typ x_squared) (read typ ay) ~f:(fun x_squared ay ->\n let open F.Unchecked in\n (x_squared + x_squared + x_squared + Params.a) * inv (ay + ay) ))\n in\n let%bind bx =\n exists typ\n ~compute:\n As_prover.(\n map2 (read typ lambda) (read typ ax) ~f:(fun lambda ax ->\n let open F.Unchecked in\n square lambda - (ax + ax) ))\n in\n let%bind by =\n exists typ\n ~compute:\n (let open As_prover in\n let open Let_syntax in\n let%map lambda = read typ lambda\n and ax = read typ ax\n and ay = read typ ay\n and bx = read typ bx in\n F.Unchecked.((lambda * (ax - bx)) - ay))\n in\n let two = Field.of_int 2 in\n let%map () =\n assert_r1cs (F.scale lambda two) ay\n (F.scale x_squared (Field.of_int 3) + F.constant Params.a)\n and () = assert_square lambda (bx + F.scale ax two)\n and () = assert_r1cs lambda (ax - bx) (by + ay) in\n (bx, by)\n\n let if_value (cond : Boolean.var) ~then_ ~else_ =\n let x1, y1 = Curve.to_affine_exn then_ in\n let x2, y2 = Curve.to_affine_exn else_ in\n let cond = (cond :> Field.Var.t) in\n let choose a1 a2 =\n let open Field.Checked in\n F.map2_ a1 a2 ~f:(fun a1 a2 ->\n (a1 * cond) + (a2 * (Field.Var.constant Field.one - cond)) )\n in\n (choose x1 x2, choose y1 y2)\n\n let%snarkydef_ scale (type shifted)\n (module Shifted : Shifted.S with type t = shifted) t\n (c : Boolean.var Bitstring_lib.Bitstring.Lsb_first.t) ~(init : shifted) :\n shifted Checked.t =\n let c = Bitstring_lib.Bitstring.Lsb_first.to_list c in\n let open Let_syntax in\n let rec go i bs0 acc pt =\n match bs0 with\n | [] ->\n return acc\n | b :: bs ->\n let%bind acc' =\n with_label (sprintf \"acc_%d\" i) (fun () ->\n let%bind add_pt = Shifted.add acc pt in\n let don't_add_pt = acc in\n Shifted.if_ b ~then_:add_pt ~else_:don't_add_pt )\n and pt' = double pt in\n go (i + 1) bs acc' pt'\n in\n go 0 c init t\n\n (* This 'looks up' a field element from a lookup table of size 2^2 = 4 with\n a 2 bit index. See https://github.com/zcash/zcash/issues/2234#issuecomment-383736266 for\n a discussion of this trick.\n *)\n let lookup_point (b0, b1) (t1, t2, t3, t4) =\n let%map b0_and_b1 = Boolean.( && ) b0 b1 in\n let lookup_one (a1, a2, a3, a4) =\n let open F.Unchecked in\n let ( * ) x b = F.map_ x ~f:(fun x -> Field.Var.scale b x) in\n let ( +^ ) = F.( + ) in\n F.constant a1\n +^ ((a2 - a1) * (b0 :> Field.Var.t))\n +^ ((a3 - a1) * (b1 :> Field.Var.t))\n +^ ((a4 + a1 - a2 - a3) * (b0_and_b1 :> Field.Var.t))\n in\n let x1, y1 = Curve.to_affine_exn t1\n and x2, y2 = Curve.to_affine_exn t2\n and x3, y3 = Curve.to_affine_exn t3\n and x4, y4 = Curve.to_affine_exn t4 in\n (lookup_one (x1, x2, x3, x4), lookup_one (y1, y2, y3, y4))\n\n (* Similar to the above, but doing lookup in a size 1 table *)\n let lookup_single_bit (b : Boolean.var) (t1, t2) =\n let lookup_one (a1, a2) =\n let open F in\n constant a1\n + map_ Unchecked.(a2 - a1) ~f:(Field.Var.scale (b :> Field.Var.t))\n in\n let x1, y1 = Curve.to_affine_exn t1 and x2, y2 = Curve.to_affine_exn t2 in\n (lookup_one (x1, x2), lookup_one (y1, y2))\n\n let scale_known (type shifted)\n (module Shifted : Shifted.S with type t = shifted) (t : Curve.t)\n (b : Boolean.var Bitstring_lib.Bitstring.Lsb_first.t) ~init =\n let b = Bitstring_lib.Bitstring.Lsb_first.to_list b in\n let sigma = t in\n let n = List.length b in\n let sigma_count = (n + 1) / 2 in\n\n (* = ceil (n / 2.0) *)\n (* We implement a complicated optimzation so that in total\n this costs roughly (1 + 3) * (n / 2) constraints, rather than\n the naive 4*n + 3*n. If scalars were represented with some\n kind of signed digit representation we could probably get it\n down to 2 * (n / 3) + 3 * (n / 3).\n *)\n (* Assume n is even *)\n (* Define\n to_term_unshifted i (b0, b1) =\n match b0, b1 with\n | false, false -> oo\n | true, false -> 2^i * t\n | false, true -> 2^{i+1} * t\n | true, true -> 2^i * t + 2^{i + 1} t\n\n to_term i (b0, b1) =\n sigma + to_term_unshifted i (b0, b1) =\n match b0, b1 with\n | false, false -> sigma\n | true, false -> sigma + 2^i * t\n | false, true -> sigma + 2^{i+1} * t\n | true, true -> sigma + 2^i * t + 2^{i + 1} t\n *)\n let to_term ~two_to_the_i ~two_to_the_i_plus_1 bits =\n lookup_point bits\n ( sigma\n , Curve.(sigma + two_to_the_i)\n , Curve.(sigma + two_to_the_i_plus_1)\n , Curve.(sigma + two_to_the_i + two_to_the_i_plus_1) )\n in\n\n (*\n Say b = b0, b1, .., b_{n-1}.\n We compute\n\n (to_term 0 (b0, b1)\n + to_term 2 (b2, b3)\n + to_term 4 (b4, b5)\n + ...\n + to_term (n-2) (b_{n-2}, b_{n-1}))\n - (n/2) * sigma\n =\n (n/2)*sigma + (b0*2^0 + b1*21 + ... + b_{n-1}*2^{n-1}) t - (n/2) * sigma\n =\n (n/2)*sigma + b * t - (n/2)*sigma\n = b * t\n *)\n let open Let_syntax in\n (* TODO #1152\n Can get away with using an unsafe add if we modify this a bit. *)\n let rec go acc two_to_the_i bits =\n match bits with\n | [] ->\n return acc\n | [ b_i ] ->\n let term =\n lookup_single_bit b_i (sigma, Curve.(sigma + two_to_the_i))\n in\n Shifted.add acc term\n | b_i :: b_i_plus_1 :: rest ->\n let two_to_the_i_plus_1 = Curve.double two_to_the_i in\n let%bind term =\n to_term ~two_to_the_i ~two_to_the_i_plus_1 (b_i, b_i_plus_1)\n in\n let%bind acc = Shifted.add acc term in\n go acc (Curve.double two_to_the_i_plus_1) rest\n in\n let%bind result_with_shift = go init t b in\n let unshift =\n Curve.scale (Curve.negate sigma) (Scalar.of_int sigma_count)\n in\n Shifted.add result_with_shift (constant unshift)\n\n let to_constant (x, y) =\n let open Option.Let_syntax in\n let%map x = F.to_constant x and y = F.to_constant y in\n Curve.of_affine (x, y)\n\n let scale m t c ~init =\n match to_constant t with\n | Some t ->\n scale_known m t c ~init\n | None ->\n scale m t c ~init\n\n let sum (type shifted) (module Shifted : Shifted.S with type t = shifted) xs\n ~init =\n let open Let_syntax in\n let rec go acc = function\n | [] ->\n return acc\n | t :: ts ->\n let%bind acc' = Shifted.add acc t in\n go acc' ts\n in\n go init xs\nend\n","module Length = struct\n type 'a t = ('a list, int) Sigs.predicate2\n\n let equal l len = Caml.List.compare_length_with l len = 0\n\n let unequal l len = Caml.List.compare_length_with l len <> 0\n\n let gte l len = Caml.List.compare_length_with l len >= 0\n\n let gt l len = Caml.List.compare_length_with l len > 0\n\n let lte l len = Caml.List.compare_length_with l len <= 0\n\n let lt l len = Caml.List.compare_length_with l len < 0\n\n module Compare = struct\n let ( = ) = equal\n\n let ( <> ) = unequal\n\n let ( >= ) = gte\n\n let ( > ) = gt\n\n let ( <= ) = lte\n\n let ( < ) = lt\n end\nend\n","open Core_kernel\ninclude Result\nopen Let_syntax\n\nmodule List = struct\n let map ls ~f =\n let%map r =\n List.fold_result ls ~init:[] ~f:(fun t el ->\n let%map h = f el in\n h :: t )\n in\n List.rev r\nend\n","(* bits_intf.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Fold_lib\n\nmodule type Basic = sig\n type t\n\n val fold : t -> bool Fold.t\n\n val size_in_bits : int\nend\n\nmodule type S = sig\n include Basic\n\n val iter : t -> f:(bool -> unit) -> unit\n\n val to_bits : t -> bool list\nend\n\nmodule type Convertible_bits = sig\n include S\n\n val of_bits : bool list -> t\nend\n\n[%%ifdef consensus_mechanism]\n\nopen Tuple_lib\n\nmodule Snarkable = struct\n module type Basic = sig\n type (_, _) typ\n\n type _ checked\n\n type boolean_var\n\n val size_in_bits : int\n\n module Packed : sig\n type var\n\n type value\n\n val typ : (var, value) typ\n\n val size_in_bits : int\n end\n\n module Unpacked : sig\n type var\n\n type value\n\n val typ : (var, value) typ\n\n val var_to_bits : var -> boolean_var Bitstring_lib.Bitstring.Lsb_first.t\n\n val var_of_bits : boolean_var Bitstring_lib.Bitstring.Lsb_first.t -> var\n\n val var_to_triples : var -> boolean_var Triple.t list\n\n val var_of_value : value -> var\n\n val size_in_bits : int\n end\n end\n\n module type Lossy = sig\n include Basic\n\n val project_value : Unpacked.value -> Packed.value\n\n val unpack_value : Packed.value -> Unpacked.value\n\n val project_var : Unpacked.var -> Packed.var\n\n val choose_preimage_var : Packed.var -> Unpacked.var checked\n end\n\n module type Faithful = sig\n include Basic\n\n val pack_value : Unpacked.value -> Packed.value\n\n val unpack_value : Packed.value -> Unpacked.value\n\n val pack_var : Unpacked.var -> Packed.var\n\n val unpack_var : Packed.var -> Unpacked.var checked\n end\n\n module type Small = sig\n type comparison_result\n\n type field_var\n\n include Faithful with type Packed.var = private field_var\n\n val compare_var : Unpacked.var -> Unpacked.var -> comparison_result checked\n\n val increment_var : Unpacked.var -> Unpacked.var checked\n\n val increment_if_var : Unpacked.var -> boolean_var -> Unpacked.var checked\n\n val assert_equal_var : Unpacked.var -> Unpacked.var -> unit checked\n\n val equal_var : Unpacked.var -> Unpacked.var -> boolean_var checked\n\n val var_of_field : field_var -> Unpacked.var checked\n\n val var_of_field_unsafe : field_var -> Packed.var\n\n val if_ :\n boolean_var\n -> then_:Unpacked.var\n -> else_:Unpacked.var\n -> Unpacked.var checked\n end\nend\n\n[%%endif]\n","open Core_kernel\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.S) = struct\n open Impl\n open Let_syntax\n\n let pack_int bs =\n assert (List.length bs < 62) ;\n let rec go pt acc = function\n | [] ->\n acc\n | b :: bs ->\n if b then go (2 * pt) (pt + acc) bs else go (2 * pt) acc bs\n in\n go 1 0 bs\n\n let boolean_assert_lte (x : Boolean.var) (y : Boolean.var) =\n (*\n x <= y\n y == 1 or x = 0\n (y - 1) * x = 0\n *)\n assert_r1cs\n Field.Var.(sub (y :> Field.Var.t) (constant Field.one))\n (x :> Field.Var.t)\n (Field.Var.constant Field.zero)\n\n let assert_decreasing : Boolean.var list -> unit Checked.t =\n let rec go prev (bs0 : Boolean.var list) =\n match bs0 with\n | [] ->\n return ()\n | b :: bs ->\n let%bind () = boolean_assert_lte b prev in\n go b bs\n in\n function [] -> return () | b :: bs -> go b bs\n\n let nth_bit x ~n = (x lsr n) land 1 = 1\n\n let apply_mask mask bs = Checked.all (List.map2_exn mask bs ~f:Boolean.( && ))\n\n let pack_unsafe (bs0 : Boolean.var list) =\n let n = List.length bs0 in\n assert (n <= Field.size_in_bits) ;\n let rec go acc two_to_the_i = function\n | b :: bs ->\n go\n (Field.Var.add acc (Field.Var.scale b two_to_the_i))\n (Field.add two_to_the_i two_to_the_i)\n bs\n | [] ->\n acc\n in\n go (Field.Var.constant Field.zero) Field.one (bs0 :> Field.Var.t list)\n\n type _ Snarky_backendless.Request.t +=\n | N_ones : bool list Snarky_backendless.Request.t\n\n let n_ones ~total_length n =\n let%bind bs =\n exists\n (Typ.list ~length:total_length Boolean.typ)\n ~request:(As_prover.return N_ones)\n ~compute:\n As_prover.(\n map (read_var n) ~f:(fun n ->\n List.init total_length ~f:(fun i ->\n Bigint.(\n compare (of_field (Field.of_int i)) (of_field n) < 0) ) ))\n in\n let%map () =\n Field.Checked.Assert.equal\n (Field.Var.sum (bs :> Field.Var.t list))\n (* This can't overflow since the field is huge *)\n n\n and () = assert_decreasing bs in\n bs\n\n let assert_num_bits_upper_bound bs u =\n let total_length = List.length bs in\n assert (total_length < Field.size_in_bits) ;\n let%bind mask = n_ones ~total_length u in\n let%bind masked = apply_mask mask bs in\n with_label __LOC__ (fun () ->\n Field.Checked.Assert.equal (pack_unsafe masked) (pack_unsafe bs) )\n\n let num_bits_int =\n let rec go acc n = if n = 0 then acc else go (1 + acc) (n lsr 1) in\n go 0\n\n let size_in_bits_size_in_bits = num_bits_int Field.size_in_bits\n\n type _ Snarky_backendless.Request.t +=\n | Num_bits_upper_bound : Field.t Snarky_backendless.Request.t\n\n let num_bits_upper_bound_unchecked x =\n let num_bits =\n match\n List.find_mapi\n (List.rev (Field.unpack x))\n ~f:(fun i x -> if x then Some i else None)\n with\n | Some leading_zeroes ->\n Field.size_in_bits - leading_zeroes\n | None ->\n 0\n in\n num_bits\n\n (* Someday: this could definitely be made more efficient *)\n let num_bits_upper_bound_unpacked : Boolean.var list -> Field.Var.t Checked.t\n =\n fun x_unpacked ->\n let%bind res =\n exists Typ.field\n ~request:(As_prover.return Num_bits_upper_bound)\n ~compute:\n As_prover.(\n map\n (read_var (Field.Var.project x_unpacked))\n ~f:(fun x -> Field.of_int (num_bits_upper_bound_unchecked x)))\n in\n let%map () = assert_num_bits_upper_bound x_unpacked res in\n res\n\n let num_bits_upper_bound ~max_length (x : Field.Var.t) : Field.Var.t Checked.t\n =\n Field.Checked.unpack x ~length:max_length >>= num_bits_upper_bound_unpacked\n\n let%test_module \"Snark_util\" =\n ( module struct\n let () = Random.init 123456789\n\n let random_bitstring length =\n List.init length ~f:(fun _ -> Random.bool ())\n\n let random_n_bit_field_elt n = Field.project (random_bitstring n)\n\n let%test_unit \"compare\" =\n let bit_length = Field.size_in_bits - 2 in\n let random () = random_n_bit_field_elt bit_length in\n let test () =\n let x = random () in\n let y = random () in\n let less, less_or_equal =\n run_and_check\n (let%map { less; less_or_equal } =\n Field.Checked.compare ~bit_length (Field.Var.constant x)\n (Field.Var.constant y)\n in\n As_prover.(\n map2 (read Boolean.typ less)\n (read Boolean.typ less_or_equal)\n ~f:Tuple2.create) )\n |> Or_error.ok_exn\n in\n let r = Bigint.(compare (of_field x) (of_field y)) in\n assert (Bool.equal less (r < 0)) ;\n assert (Bool.equal less_or_equal (r <= 0))\n in\n for _i = 0 to 100 do\n test ()\n done\n\n let%test_unit \"boolean_assert_lte\" =\n Or_error.ok_exn\n (check\n (Checked.all_unit\n [ boolean_assert_lte Boolean.false_ Boolean.false_\n ; boolean_assert_lte Boolean.false_ Boolean.true_\n ; boolean_assert_lte Boolean.true_ Boolean.true_\n ] ) ) ;\n assert (\n Or_error.is_error\n (check (boolean_assert_lte Boolean.true_ Boolean.false_)) )\n\n let%test_unit \"assert_decreasing\" =\n let decreasing bs =\n check (assert_decreasing (List.map ~f:Boolean.var_of_value bs))\n in\n Or_error.ok_exn (decreasing [ true; true; true; false ]) ;\n Or_error.ok_exn (decreasing [ true; true; false; false ]) ;\n assert (Or_error.is_error (decreasing [ true; true; false; true ]))\n\n let%test_unit \"n_ones\" =\n let total_length = 6 in\n let test n =\n let t () =\n n_ones ~total_length (Field.Var.constant (Field.of_int n))\n in\n let handle_with (resp : bool list) =\n handle t (fun (With { request; respond }) ->\n match request with\n | N_ones ->\n respond (Provide resp)\n | _ ->\n unhandled )\n in\n let correct = Int.pow 2 n - 1 in\n let to_bits k =\n List.init total_length ~f:(fun i -> (k lsr i) land 1 = 1)\n in\n for i = 0 to Int.pow 2 total_length - 1 do\n if i = correct then\n Or_error.ok_exn (check (handle_with (to_bits i)))\n else assert (Or_error.is_error (check (handle_with (to_bits i))))\n done\n in\n for n = 0 to total_length do\n test n\n done\n\n let%test_unit \"num_bits_int\" =\n assert (num_bits_int 1 = 1) ;\n assert (num_bits_int 5 = 3) ;\n assert (num_bits_int 17 = 5)\n\n let%test_unit \"num_bits_upper_bound_unchecked\" =\n let f k bs =\n assert (num_bits_upper_bound_unchecked (Field.project bs) = k)\n in\n f 3 [ true; true; true; false; false ] ;\n f 4 [ true; true; true; true; false ] ;\n f 3 [ true; false; true; false; false ] ;\n f 5 [ true; false; true; false; true ]\n\n (*let%test_unit \"num_bits_upper_bound\" =\n let max_length = Field.size_in_bits - 1 in\n let test x =\n let handle_with resp =\n handle\n (num_bits_upper_bound ~max_length (Field.Var.constant x))\n (fun (With {request; respond}) ->\n match request with\n | Num_bits_upper_bound -> respond (Field.of_int resp)\n | _ -> unhandled)\n in\n let true_answer = num_bits_upper_bound_unchecked x in\n for i = 0 to true_answer - 1 do\n if check (handle_with i) ()\n then begin\n let n = Bigint.of_field x in\n failwithf !\"Shouldn't have passed: x=%s, i=%d\"\n (String.init max_length ~f:(fun j -> if Bigint.test_bit n j then '1' else '0'))\n i ();\n end;\n done;\n assert (check (handle_with true_answer) ())\n in\n test (random_n_bit_field_elt max_length)*)\n end )\nend\n","open Snark_bits\n\nmodule type S = sig\n include Snarky_backendless.Snark_intf.S\n\n module Snarkable : sig\n module type S = sig\n type var\n\n type value\n\n val typ : (var, value) Typ.t\n end\n\n module Bits : sig\n module type Faithful =\n Bits_intf.Snarkable.Faithful\n with type ('a, 'b) typ := ('a, 'b) Typ.t\n and type 'a checked := 'a Checked.t\n and type boolean_var := Boolean.var\n\n module type Lossy =\n Bits_intf.Snarkable.Lossy\n with type ('a, 'b) typ := ('a, 'b) Typ.t\n and type 'a checked := 'a Checked.t\n and type boolean_var := Boolean.var\n end\n end\nend\n","(* data_hash.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\n[%%ifdef consensus_mechanism]\n\nopen Bitstring_lib\n\n[%%endif]\n\nmodule type Full_size = Data_hash_intf.Full_size\n\nmodule Make_basic (M : sig\n val length_in_bits : int\nend) =\nstruct\n type t = Field.t [@@deriving sexp, compare, hash]\n\n let to_decimal_string (t : Field.t) = Field.to_string t\n\n let of_decimal_string (s : string) = Field.of_string s\n\n let to_bytes t =\n Fold_lib.(Fold.bool_t_to_string (Fold.of_list (Field.unpack t)))\n\n let length_in_bits = M.length_in_bits\n\n let () = assert (Int.(length_in_bits <= Field.size_in_bits))\n\n let to_input t = Random_oracle.Input.Chunked.field t\n\n [%%ifdef consensus_mechanism]\n\n (* this is in consensus code, because Bigint comes\n from snarky functors\n *)\n let gen : t Quickcheck.Generator.t =\n let m =\n if Int.(length_in_bits = Field.size_in_bits) then\n Bignum_bigint.(Field.size - one)\n else Bignum_bigint.(pow (of_int 2) (of_int length_in_bits) - one)\n in\n Quickcheck.Generator.map\n Bignum_bigint.(gen_incl zero m)\n ~f:(fun x -> Bigint.(to_field (of_bignum_bigint x)))\n\n type var =\n { digest : Random_oracle.Checked.Digest.t\n ; mutable bits : Boolean.var Bitstring.Lsb_first.t option\n }\n\n let var_of_t t =\n let n = Bigint.of_field t in\n { digest = Field.Var.constant t\n ; bits =\n Some\n (Bitstring.Lsb_first.of_list\n (List.init M.length_in_bits ~f:(fun i ->\n Boolean.var_of_value (Bigint.test_bit n i) ) ) )\n }\n\n open Let_syntax\n\n let var_to_hash_packed { digest; _ } = digest\n\n (* TODO: Audit this usage of choose_preimage *)\n let unpack =\n if Int.( = ) length_in_bits Field.size_in_bits then fun x ->\n Field.Checked.choose_preimage_var x ~length:length_in_bits\n >>| fun x -> (x :> Boolean.var list)\n else Field.Checked.unpack ~length:length_in_bits\n\n let%snarkydef_ var_to_bits t =\n match t.bits with\n | Some bits ->\n return (bits :> Boolean.var list)\n | None ->\n let%map bits = unpack t.digest in\n t.bits <- Some (Bitstring.Lsb_first.of_list bits) ;\n bits\n\n let var_to_input (t : var) = Random_oracle.Input.Chunked.field t.digest\n\n (* TODO : use Random oracle.Digest to satisfy Bits_intf.S, move out of\n consensus_mechanism guard\n *)\n module Bs =\n Snark_bits.Bits.Make_field\n (Snark_params.Tick.Field)\n (Snark_params.Tick.Bigint)\n\n include (Bs : module type of Bs with type t := t)\n\n let assert_equal x y = Field.Checked.Assert.equal x.digest y.digest\n\n let equal_var x y = Field.Checked.equal x.digest y.digest\n\n let typ : (var, t) Typ.t =\n Typ.transport_var Typ.field\n ~there:(fun { digest; bits = _ } -> digest)\n ~back:(fun digest -> { digest; bits = None })\n\n [%%endif]\nend\n\nmodule T0 = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = (Field.t[@version_asserted]) [@@deriving sexp, compare, hash]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule Make_full_size (B58_data : Data_hash_intf.Data_hash_descriptor) = struct\n module Basic = Make_basic (struct\n let length_in_bits = Field.size_in_bits\n end)\n\n include Basic\n\n module Base58_check = Codable.Make_base58_check (struct\n (* for compatibility with legacy Base58Check serializations *)\n include T0.Stable.Latest.With_all_version_tags\n\n (* the serialization here is only used for the hash impl which is only\n used for hashtbl, it's ok to disagree with the \"real\" serialization *)\n include Hashable.Make_binable (T0.Stable.Latest)\n include B58_data\n end)\n\n [%%define_locally\n Base58_check.\n (to_base58_check, of_base58_check, of_base58_check_exn, to_yojson, of_yojson)]\n\n module T = struct\n type t = Field.t [@@deriving sexp, compare, hash]\n end\n\n include Comparable.Make (T)\n include Hashable.Make (T)\n\n let of_hash = Fn.id\n\n let to_field = Fn.id\n\n [%%ifdef consensus_mechanism]\n\n let var_of_hash_packed digest = { digest; bits = None }\n\n let var_to_field { digest; _ } = digest\n\n let if_ cond ~then_ ~else_ =\n let%map digest =\n Field.Checked.if_ cond ~then_:then_.digest ~else_:else_.digest\n in\n { digest; bits = None }\n\n [%%endif]\nend\n","type t\n\nexternal create : unit -> t = \"caml_pasta_fp_poseidon_params_create\"\n\nexternal block_cipher : t -> Kimchi_bindings.FieldVectors.Fp.t -> unit\n = \"caml_pasta_fp_poseidon_block_cipher\"\n","let length_in_bytes = 20\n\nmodule T : sig\n type t = private string\n\n val create : string -> t\nend = struct\n type t = string\n\n let padding_char = '*'\n\n let create s : t =\n let string_length = String.length s in\n let r =\n if string_length <= length_in_bytes then\n let diff = length_in_bytes - string_length in\n s ^ String.init diff (fun _ -> padding_char)\n else String.sub s 0 length_in_bytes\n in\n assert (String.length r = length_in_bytes) ;\n r\nend\n\ninclude T\n\nlet protocol_state = create \"MinaProtoState\"\n\nlet protocol_state_body = create \"MinaProtoStateBody\"\n\nlet account = create \"MinaAccount\"\n\nlet side_loaded_vk = create \"MinaSideLoadedVk\"\n\nlet zkapp_account = create \"MinaZkappAccount\"\n\nlet zkapp_payload = create \"MinaZkappPayload\"\n\nlet zkapp_body_mainnet = create \"MainnetZkappBody\"\n\nlet zkapp_body_testnet = create \"TestnetZkappBody\"\n\nlet zkapp_body ?(chain = Mina_signature_kind.t) =\n match chain with\n | Mainnet ->\n zkapp_body_mainnet\n | Testnet ->\n zkapp_body_testnet\n | Other_network chain_name ->\n create (chain_name ^ \"ZkappBody\")\n\nlet merkle_tree i = create (Printf.sprintf \"MinaMklTree%03d\" i)\n\nlet coinbase_merkle_tree i = create (Printf.sprintf \"MinaCbMklTree%03d\" i)\n\nlet merge_snark = create \"MinaMergeSnark\"\n\nlet base_snark = create \"MinaBaseSnark\"\n\nlet transition_system_snark = create \"MinaTransitionSnark\"\n\nlet signature_testnet = create \"CodaSignature\"\n\nlet signature_mainnet = create \"MinaSignatureMainnet\"\n\nlet signature_other chain_name = create (chain_name ^ \"Signature\")\n\nlet receipt_chain_user_command = create \"MinaReceiptUC\"\n\n(* leaving this one with \"Coda\", to preserve the existing hashes *)\nlet receipt_chain_zkapp = create \"CodaReceiptZkapp\"\n\nlet epoch_seed = create \"MinaEpochSeed\"\n\nlet vrf_message = create \"MinaVrfMessage\"\n\nlet vrf_output = create \"MinaVrfOutput\"\n\nlet vrf_evaluation = create \"MinaVrfEvaluation\"\n\nlet pending_coinbases = create \"PendingCoinbases\"\n\nlet coinbase_stack_data = create \"CoinbaseStackData\"\n\n(* length is limited, so we drop some characters here *)\nlet coinbase_stack_state_hash = create \"CoinbaseStackStaHash\"\n\nlet coinbase_stack = create \"CoinbaseStack\"\n\nlet coinbase = create \"Coinbase\"\n\nlet checkpoint_list = create \"MinaCheckpoints\"\n\nlet bowe_gabizon_hash = create \"MinaTockBGHash\"\n\nlet zkapp_precondition = create \"MinaZkappPred\"\n\n(*for Zkapp_precondition.Account.t*)\nlet zkapp_precondition_account = create \"MinaZkappPredAcct\"\n\nlet zkapp_precondition_protocol_state = create \"MinaZkappPredPS\"\n\n(*for Account_update.Account_precondition.t*)\nlet account_update_account_precondition = create \"MinaAcctUpdAcctPred\"\n\nlet account_update_cons = create \"MinaAcctUpdateCons\"\n\nlet account_update_node = create \"MinaAcctUpdateNode\"\n\nlet account_update_stack_frame = create \"MinaAcctUpdStckFrm\"\n\nlet account_update_stack_frame_cons = create \"MinaActUpStckFrmCons\"\n\nlet zkapp_uri = create \"MinaZkappUri\"\n\nlet zkapp_event = create \"MinaZkappEvent\"\n\nlet zkapp_events = create \"MinaZkappEvents\"\n\nlet zkapp_actions = create \"MinaZkappSeqEvents\"\n\nlet zkapp_memo = create \"MinaZkappMemo\"\n\nlet zkapp_test = create \"MinaZkappTest\"\n\nlet derive_token_id = create \"MinaDeriveTokenId\"\n","module Js = struct\n type t\n\n type 'a js_array = t\n\n type ('a, 'b) meth_callback = t\n\n external string : string -> t = \"caml_jsstring_of_string\"\n\n external to_string : t -> string = \"caml_string_of_jsstring\"\n\n external bytestring : string -> t = \"caml_jsbytes_of_string\"\n\n external to_bytestring : t -> string = \"caml_string_of_jsbytes\"\n\n external bool : bool -> t = \"caml_js_from_bool\"\n\n external to_bool : t -> bool = \"caml_js_to_bool\"\n\n external array : 'a array -> t = \"caml_js_from_array\"\n\n external to_array : t -> 'a array = \"caml_js_to_array\"\n\n external number_of_float : float -> t = \"caml_js_from_float\"\n\n external float_of_number : t -> float = \"caml_js_to_float\"\n\n external typeof : t -> t = \"caml_js_typeof\"\n\n external instanceof : t -> t -> bool = \"caml_js_instanceof\"\n\n external debugger : unit -> unit = \"debugger\"\n\n external get : t -> t -> t = \"caml_js_get\"\n\n external set : t -> t -> t -> unit = \"caml_js_set\"\n\n external delete : t -> t -> unit = \"caml_js_delete\"\n\n external call : t -> t -> t array -> t = \"caml_js_call\"\n\n external fun_call : t -> t array -> t = \"caml_js_fun_call\"\n\n external meth_call : t -> string -> t array -> t = \"caml_js_meth_call\"\n\n external new_obj : t -> t array -> t = \"caml_js_new\"\n\n external new_obj_arr : t -> t js_array -> t = \"caml_ojs_new_arr\"\n\n external obj : (string * t) array -> t = \"caml_js_object\"\n\n external equals : t -> t -> bool = \"caml_js_equals\"\n\n external pure_expr : (unit -> 'a) -> 'a = \"caml_js_pure_expr\"\n\n external eval_string : string -> 'a = \"caml_js_eval_string\"\n\n external js_expr : string -> 'a = \"caml_js_expr\"\n\n external pure_js_expr : string -> 'a = \"caml_pure_js_expr\"\n\n external callback_with_arguments :\n (t js_array -> 'b) -> ('c, t js_array -> 'b) meth_callback\n = \"caml_js_wrap_callback_arguments\"\n\n external callback_with_arity : int -> ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n = \"caml_js_wrap_callback_strict\"\n\n external meth_callback : ('b -> 'a) -> ('b, 'a) meth_callback\n = \"caml_js_wrap_meth_callback_unsafe\"\n\n external meth_callback_with_arity : int -> ('b -> 'a) -> ('b, 'a) meth_callback\n = \"caml_js_wrap_meth_callback_strict\"\n\n external meth_callback_with_arguments :\n ('b -> t js_array -> 'a) -> ('b, t js_array -> 'a) meth_callback\n = \"caml_js_wrap_meth_callback_arguments\"\n\n external wrap_callback : ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n = \"caml_js_wrap_callback\"\n\n external wrap_meth_callback : ('a -> 'b) -> ('a, 'b) meth_callback\n = \"caml_js_wrap_meth_callback\"\nend\n\nmodule Sys = struct\n type 'a callback = 'a\n\n external create_file : name:string -> content:string -> unit = \"caml_create_file\"\n\n external read_file : name:string -> string = \"caml_read_file_content\"\n\n external set_channel_output' : out_channel -> (js_string:Js.t -> unit) callback -> unit\n = \"caml_ml_set_channel_output\"\n\n external set_channel_input' : in_channel -> (unit -> string) callback -> unit\n = \"caml_ml_set_channel_refill\"\n\n external mount_point : unit -> string list = \"caml_list_mount_point\"\n\n external mount_autoload : string -> (string -> string -> string option) callback -> unit\n = \"caml_mount_autoload\"\n\n external unmount : string -> unit = \"caml_unmount\"\nend\n\nmodule Error : sig\n type t\n\n val raise_ : t -> 'a\n\n val attach_js_backtrace : exn -> force:bool -> exn\n (** Attach a JavasScript error to an OCaml exception. if [force = false] and a\n JavasScript error is already attached, it will do nothing. This function is useful to\n store and retrieve information about JavaScript stack traces.\n\n Attaching JavasScript errors will happen automatically when compiling with\n [--enable with-js-error]. *)\n\n val of_exn : exn -> t option\n (** Extract a JavaScript error attached to an OCaml exception, if any. This is useful to\n inspect an eventual stack strace, especially when sourcemap is enabled. *)\n\n exception Exn of t\n (** The [Error] exception wrap javascript exceptions when caught by OCaml code.\n In case the javascript exception is not an instance of javascript [Error],\n it will be serialized and wrapped into a [Failure] exception.\n *)\nend = struct\n type t\n\n exception Exn of t\n\n let _ = Callback.register_exception \"jsError\" (Exn (Obj.magic [||]))\n\n let raise_ : t -> 'a = Js.js_expr \"(function (exn) { throw exn })\"\n\n external of_exn : exn -> t option = \"caml_js_error_option_of_exception\"\n\n external attach_js_backtrace : exn -> force:bool -> exn = \"caml_exn_with_js_backtrace\"\nend\n\n[@@@ocaml.warning \"-32-60\"]\n\nmodule For_compatibility_only = struct\n (* Add primitives for compatibility reasons. Existing users might\n depend on it (e.g. gen_js_api), we dont want the ocaml compiler\n to complain about theses missing primitives. *)\n\n external caml_js_from_string : string -> Js.t = \"caml_js_from_string\"\n\n external caml_js_to_byte_string : Js.t -> string = \"caml_js_to_byte_string\"\n\n external caml_js_to_string : Js.t -> string = \"caml_js_to_string\"\n\n external caml_list_of_js_array : 'a Js.js_array -> 'a list = \"caml_list_of_js_array\"\n\n external caml_list_to_js_array : 'a list -> 'a Js.js_array = \"caml_list_to_js_array\"\n\n external variable : string -> 'a = \"caml_js_var\"\nend\n\nmodule Typed_array = struct\n type ('a, 'b) typedArray = Js.t\n\n type arrayBuffer = Js.t\n\n type uint8Array = Js.t\n\n external kind : ('a, 'b) typedArray -> ('a, 'b) Bigarray.kind\n = \"caml_ba_kind_of_typed_array\"\n\n external from_genarray :\n ('a, 'b, Bigarray.c_layout) Bigarray.Genarray.t -> ('a, 'b) typedArray\n = \"caml_ba_to_typed_array\"\n\n external to_genarray :\n ('a, 'b) typedArray -> ('a, 'b, Bigarray.c_layout) Bigarray.Genarray.t\n = \"caml_ba_from_typed_array\"\n\n module Bigstring = struct\n type t = (char, Bigarray.int8_unsigned_elt, Bigarray.c_layout) Bigarray.Array1.t\n\n external to_arrayBuffer : t -> arrayBuffer = \"bigstring_to_array_buffer\"\n\n external to_uint8Array : t -> uint8Array = \"bigstring_to_typed_array\"\n\n external of_arrayBuffer : arrayBuffer -> t = \"bigstring_of_array_buffer\"\n\n external of_uint8Array : uint8Array -> t = \"bigstring_of_typed_array\"\n end\n\n external of_uint8Array : uint8Array -> string = \"caml_string_of_array\"\nend\n\nmodule Int64 = struct\n external create_int64_lo_mi_hi : int -> int -> int -> Int64.t\n = \"caml_int64_create_lo_mi_hi\"\nend\n","(* Js_of_ocaml library\n * http://www.ocsigen.org/js_of_ocaml/\n * Copyright (C) 2010 Jérôme Vouillon\n * Laboratoire PPS - CNRS Université Paris Diderot\n *\n * This program is free software; you can redistribute it and/or modify\n * it under the terms of the GNU Lesser General Public License as published by\n * the Free Software Foundation, with linking exception;\n * either version 2.1 of the License, or (at your option) any later version.\n *\n * This program is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU Lesser General Public License for more details.\n *\n * You should have received a copy of the GNU Lesser General Public License\n * along with this program; if not, write to the Free Software\n * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.\n *)\nopen! Import\n\n(* This local module [Js] is needed so that the ppx_js extension work within that file. *)\nmodule Js = struct\n type +'a t\n\n type (-'a, +'b) meth_callback\n\n module Unsafe = struct\n type top\n\n type any = top t\n\n type any_js_array = any\n\n external inject : 'a -> any = \"%identity\"\n\n external coerce : _ t -> _ t = \"%identity\"\n\n external get : 'a -> 'b -> 'c = \"caml_js_get\"\n\n external set : 'a -> 'b -> 'c -> unit = \"caml_js_set\"\n\n external delete : 'a -> 'b -> unit = \"caml_js_delete\"\n\n external call : 'a -> 'b -> any array -> 'c = \"caml_js_call\"\n\n external fun_call : 'a -> any array -> 'b = \"caml_js_fun_call\"\n\n external meth_call : 'a -> string -> any array -> 'b = \"caml_js_meth_call\"\n\n external new_obj : 'a -> any array -> 'b = \"caml_js_new\"\n\n external new_obj_arr : 'a -> any_js_array -> 'b = \"caml_ojs_new_arr\"\n\n external obj : (string * any) array -> 'a = \"caml_js_object\"\n\n external equals : 'a -> 'b -> bool = \"caml_js_equals\"\n\n external pure_expr : (unit -> 'a) -> 'a = \"caml_js_pure_expr\"\n\n external eval_string : string -> 'a = \"caml_js_eval_string\"\n\n external js_expr : string -> 'a = \"caml_js_expr\"\n\n external pure_js_expr : string -> 'a = \"caml_pure_js_expr\"\n\n let global = pure_js_expr \"globalThis\"\n\n external callback : ('a -> 'b) -> ('c, 'a -> 'b) meth_callback = \"%identity\"\n\n external callback_with_arguments :\n (any_js_array -> 'b) -> ('c, any_js_array -> 'b) meth_callback\n = \"caml_js_wrap_callback_arguments\"\n\n external callback_with_arity : int -> ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n = \"caml_js_wrap_callback_strict\"\n\n external meth_callback : ('b -> 'a) -> ('b, 'a) meth_callback\n = \"caml_js_wrap_meth_callback_unsafe\"\n\n external meth_callback_with_arity : int -> ('b -> 'a) -> ('b, 'a) meth_callback\n = \"caml_js_wrap_meth_callback_strict\"\n\n external meth_callback_with_arguments :\n ('b -> any_js_array -> 'a) -> ('b, any_js_array -> 'a) meth_callback\n = \"caml_js_wrap_meth_callback_arguments\"\n\n (* DEPRECATED *)\n external variable : string -> 'a = \"caml_js_var\"\n end\n\n (****)\n\n type 'a opt = 'a\n\n type 'a optdef = 'a\n\n external debugger : unit -> unit = \"debugger\"\n\n let null : 'a opt = Unsafe.pure_js_expr \"null\"\n\n external some : 'a -> 'a opt = \"%identity\"\n\n let undefined : 'a optdef = Unsafe.pure_js_expr \"undefined\"\n\n external def : 'a -> 'a optdef = \"%identity\"\n\n module type OPT = sig\n type 'a t\n\n val empty : 'a t\n\n val return : 'a -> 'a t\n\n val map : 'a t -> ('a -> 'b) -> 'b t\n\n val bind : 'a t -> ('a -> 'b t) -> 'b t\n\n val test : 'a t -> bool\n\n val iter : 'a t -> ('a -> unit) -> unit\n\n val case : 'a t -> (unit -> 'b) -> ('a -> 'b) -> 'b\n\n val get : 'a t -> (unit -> 'a) -> 'a\n\n val option : 'a option -> 'a t\n\n val to_option : 'a t -> 'a option\n end\n\n module Opt : OPT with type 'a t = 'a opt = struct\n type 'a t = 'a opt\n\n let empty = null\n\n let return = some\n\n let map x f = if Unsafe.equals x null then null else return (f x)\n\n let bind x f = if Unsafe.equals x null then null else f x\n\n let test x = not (Unsafe.equals x null)\n\n let iter x f = if not (Unsafe.equals x null) then f x\n\n let case x f g = if Unsafe.equals x null then f () else g x\n\n let get x f = if Unsafe.equals x null then f () else x\n\n let option x =\n match x with\n | None -> empty\n | Some x -> return x\n\n let to_option x = case x (fun () -> None) (fun x -> Some x)\n end\n\n module Optdef : OPT with type 'a t = 'a optdef = struct\n type 'a t = 'a optdef\n\n let empty = undefined\n\n let return = def\n\n let map x f = if x == undefined then undefined else return (f x)\n\n let bind x f = if x == undefined then undefined else f x\n\n let test x = x != undefined\n\n let iter x f = if x != undefined then f x\n\n let case x f g = if x == undefined then f () else g x\n\n let get x f = if x == undefined then f () else x\n\n let option x =\n match x with\n | None -> empty\n | Some x -> return x\n\n let to_option x = case x (fun () -> None) (fun x -> Some x)\n end\n\n (****)\n\n let coerce x f g = Opt.get (f x) (fun () -> g x)\n\n let coerce_opt x f g = Opt.get (Opt.bind x f) (fun () -> g x)\n\n (****)\n\n type +'a meth\n\n type +'a gen_prop\n\n type 'a readonly_prop = < get : 'a > gen_prop\n\n type 'a writeonly_prop = < set : 'a -> unit > gen_prop\n\n type 'a prop = < get : 'a ; set : 'a -> unit > gen_prop\n\n type 'a optdef_prop = < get : 'a optdef ; set : 'a -> unit > gen_prop\n\n type +'a constr\n\n (****)\n\n type 'a callback = (unit, 'a) meth_callback\n\n external wrap_callback : ('a -> 'b) -> ('c, 'a -> 'b) meth_callback\n = \"caml_js_wrap_callback\"\n\n external wrap_meth_callback : ('a -> 'b) -> ('a, 'b) meth_callback\n = \"caml_js_wrap_meth_callback\"\n\n (****)\n\n let _true = Unsafe.pure_js_expr \"true\"\n\n let _false = Unsafe.pure_js_expr \"false\"\n\n type match_result_handle\n\n type string_array\n\n class type js_string =\n object\n method toString : js_string t meth\n\n method valueOf : js_string t meth\n\n method charAt : int -> js_string t meth\n\n method charCodeAt : int -> float meth\n\n (* This may return NaN... *)\n method concat : js_string t -> js_string t meth\n\n method concat_2 : js_string t -> js_string t -> js_string t meth\n\n method concat_3 : js_string t -> js_string t -> js_string t -> js_string t meth\n\n method concat_4 :\n js_string t -> js_string t -> js_string t -> js_string t -> js_string t meth\n\n method indexOf : js_string t -> int meth\n\n method indexOf_from : js_string t -> int -> int meth\n\n method lastIndexOf : js_string t -> int meth\n\n method lastIndexOf_from : js_string t -> int -> int meth\n\n method localeCompare : js_string t -> float meth\n\n method _match : regExp t -> match_result_handle t opt meth\n\n method replace : regExp t -> js_string t -> js_string t meth\n\n method replace_string : js_string t -> js_string t -> js_string t meth\n\n method search : regExp t -> int meth\n\n method slice : int -> int -> js_string t meth\n\n method slice_end : int -> js_string t meth\n\n method split : js_string t -> string_array t meth\n\n method split_limited : js_string t -> int -> string_array t meth\n\n method split_regExp : regExp t -> string_array t meth\n\n method split_regExpLimited : regExp t -> int -> string_array t meth\n\n method substring : int -> int -> js_string t meth\n\n method substring_toEnd : int -> js_string t meth\n\n method toLowerCase : js_string t meth\n\n method toLocaleLowerCase : js_string t meth\n\n method toUpperCase : js_string t meth\n\n method toLocaleUpperCase : js_string t meth\n\n method trim : js_string t meth\n\n method length : int readonly_prop\n end\n\n and regExp =\n object\n method exec : js_string t -> match_result_handle t opt meth\n\n method test : js_string t -> bool t meth\n\n method toString : js_string t meth\n\n method source : js_string t readonly_prop\n\n method global : bool t readonly_prop\n\n method ignoreCase : bool t readonly_prop\n\n method multiline : bool t readonly_prop\n\n method lastIndex : int prop\n end\n\n (* string is used by ppx_js, it needs to come before any use of the\n new syntax in this file *)\n external string : string -> js_string t = \"caml_jsstring_of_string\"\n\n external to_string : js_string t -> string = \"caml_string_of_jsstring\"\nend\n\ninclude Js\n\nclass type string_constr =\n object\n method fromCharCode : int -> js_string t meth\n end\n\nlet string_constr = Unsafe.global##._String\n\nlet regExp = Unsafe.global##._RegExp\n\nlet regExp_copy = regExp\n\nlet regExp_withFlags = regExp\n\nclass type ['a] js_array =\n object\n method toString : js_string t meth\n\n method toLocaleString : js_string t meth\n\n method concat : 'a js_array t -> 'a js_array t meth\n\n method join : js_string t -> js_string t meth\n\n method pop : 'a optdef meth\n\n method push : 'a -> int meth\n\n method push_2 : 'a -> 'a -> int meth\n\n method push_3 : 'a -> 'a -> 'a -> int meth\n\n method push_4 : 'a -> 'a -> 'a -> 'a -> int meth\n\n method reverse : 'a js_array t meth\n\n method shift : 'a optdef meth\n\n method slice : int -> int -> 'a js_array t meth\n\n method slice_end : int -> 'a js_array t meth\n\n method sort : ('a -> 'a -> float) callback -> 'a js_array t meth\n\n method sort_asStrings : 'a js_array t meth\n\n method splice : int -> int -> 'a js_array t meth\n\n method splice_1 : int -> int -> 'a -> 'a js_array t meth\n\n method splice_2 : int -> int -> 'a -> 'a -> 'a js_array t meth\n\n method splice_3 : int -> int -> 'a -> 'a -> 'a -> 'a js_array t meth\n\n method splice_4 : int -> int -> 'a -> 'a -> 'a -> 'a -> 'a js_array t meth\n\n method unshift : 'a -> int meth\n\n method unshift_2 : 'a -> 'a -> int meth\n\n method unshift_3 : 'a -> 'a -> 'a -> int meth\n\n method unshift_4 : 'a -> 'a -> 'a -> 'a -> int meth\n\n method some : ('a -> int -> 'a js_array t -> bool t) callback -> bool t meth\n\n method every : ('a -> int -> 'a js_array t -> bool t) callback -> bool t meth\n\n method forEach : ('a -> int -> 'a js_array t -> unit) callback -> unit meth\n\n method map : ('a -> int -> 'a js_array t -> 'b) callback -> 'b js_array t meth\n\n method filter : ('a -> int -> 'a js_array t -> bool t) callback -> 'a js_array t meth\n\n method reduce_init :\n ('b -> 'a -> int -> 'a js_array t -> 'b) callback -> 'b -> 'b meth\n\n method reduce : ('a -> 'a -> int -> 'a js_array t -> 'a) callback -> 'a meth\n\n method reduceRight_init :\n ('b -> 'a -> int -> 'a js_array t -> 'b) callback -> 'b -> 'b meth\n\n method reduceRight : ('a -> 'a -> int -> 'a js_array t -> 'a) callback -> 'a meth\n\n method length : int prop\n end\n\nlet object_constructor = Unsafe.global##._Object\n\nlet object_keys o : js_string t js_array t = object_constructor##keys o\n\nlet array_constructor = Unsafe.global##._Array\n\nlet array_empty = array_constructor\n\nlet array_length = array_constructor\n\nlet array_get : 'a #js_array t -> int -> 'a optdef = Unsafe.get\n\nlet array_set : 'a #js_array t -> int -> 'a -> unit = Unsafe.set\n\nlet array_map_poly :\n 'a #js_array t -> ('a -> int -> 'a #js_array t -> 'b) callback -> 'b #js_array t =\n fun a cb -> (Unsafe.coerce a)##map cb\n\nlet array_map f a = array_map_poly a (wrap_callback (fun x _idx _ -> f x))\n\nlet array_mapi f a = array_map_poly a (wrap_callback (fun x idx _ -> f idx x))\n\nclass type match_result =\n object\n inherit [js_string t] js_array\n\n method index : int readonly_prop\n\n method input : js_string t readonly_prop\n end\n\nlet str_array : string_array t -> js_string t js_array t = Unsafe.coerce\n\nlet match_result : match_result_handle t -> match_result t = Unsafe.coerce\n\nclass type number =\n object\n method toString : js_string t meth\n\n method toString_radix : int -> js_string t meth\n\n method toLocaleString : js_string t meth\n\n method toFixed : int -> js_string t meth\n\n method toExponential : js_string t meth\n\n method toExponential_digits : int -> js_string t meth\n\n method toPrecision : int -> js_string t meth\n end\n\nexternal number_of_float : float -> number t = \"caml_js_from_float\"\n\nexternal float_of_number : number t -> float = \"caml_js_to_float\"\n\nclass type date =\n object\n method toString : js_string t meth\n\n method toDateString : js_string t meth\n\n method toTimeString : js_string t meth\n\n method toLocaleString : js_string t meth\n\n method toLocaleDateString : js_string t meth\n\n method toLocaleTimeString : js_string t meth\n\n method valueOf : float meth\n\n method getTime : float meth\n\n method getFullYear : int meth\n\n method getUTCFullYear : int meth\n\n method getMonth : int meth\n\n method getUTCMonth : int meth\n\n method getDate : int meth\n\n method getUTCDate : int meth\n\n method getDay : int meth\n\n method getUTCDay : int meth\n\n method getHours : int meth\n\n method getUTCHours : int meth\n\n method getMinutes : int meth\n\n method getUTCMinutes : int meth\n\n method getSeconds : int meth\n\n method getUTCSeconds : int meth\n\n method getMilliseconds : int meth\n\n method getUTCMilliseconds : int meth\n\n method getTimezoneOffset : int meth\n\n method setTime : float -> float meth\n\n method setFullYear : int -> float meth\n\n method setUTCFullYear : int -> float meth\n\n method setMonth : int -> float meth\n\n method setUTCMonth : int -> float meth\n\n method setDate : int -> float meth\n\n method setUTCDate : int -> float meth\n\n method setDay : int -> float meth\n\n method setUTCDay : int -> float meth\n\n method setHours : int -> float meth\n\n method setUTCHours : int -> float meth\n\n method setMinutes : int -> float meth\n\n method setUTCMinutes : int -> float meth\n\n method setSeconds : int -> float meth\n\n method setUTCSeconds : int -> float meth\n\n method setMilliseconds : int -> float meth\n\n method setUTCMilliseconds : int -> float meth\n\n method toUTCString : js_string t meth\n\n method toISOString : js_string t meth\n\n method toJSON : 'a -> js_string t meth\n end\n\nclass type date_constr =\n object\n method parse : js_string t -> float meth\n\n method _UTC_month : int -> int -> float meth\n\n method _UTC_day : int -> int -> float meth\n\n method _UTC_hour : int -> int -> int -> int -> float meth\n\n method _UTC_min : int -> int -> int -> int -> int -> float meth\n\n method _UTC_sec : int -> int -> int -> int -> int -> int -> float meth\n\n method _UTC_ms : int -> int -> int -> int -> int -> int -> int -> float meth\n\n method now : float meth\n end\n\nlet date_constr = Unsafe.global##._Date\n\nlet date : date_constr t = date_constr\n\nlet date_now : date t constr = date_constr\n\nlet date_fromTimeValue : (float -> date t) constr = date_constr\n\nlet date_month : (int -> int -> date t) constr = date_constr\n\nlet date_day : (int -> int -> int -> date t) constr = date_constr\n\nlet date_hour : (int -> int -> int -> int -> date t) constr = date_constr\n\nlet date_min : (int -> int -> int -> int -> int -> date t) constr = date_constr\n\nlet date_sec : (int -> int -> int -> int -> int -> int -> date t) constr = date_constr\n\nlet date_ms : (int -> int -> int -> int -> int -> int -> int -> date t) constr =\n date_constr\n\nclass type math =\n object\n method _E : float readonly_prop\n\n method _LN2 : float readonly_prop\n\n method _LN10 : float readonly_prop\n\n method _LOG2E : float readonly_prop\n\n method _LOG10E : float readonly_prop\n\n method _PI : float readonly_prop\n\n method _SQRT1_2_ : float readonly_prop\n\n method _SQRT2 : float readonly_prop\n\n method abs : float -> float meth\n\n method acos : float -> float meth\n\n method asin : float -> float meth\n\n method atan : float -> float meth\n\n method atan2 : float -> float -> float meth\n\n method ceil : float -> float meth\n\n method cos : float -> float meth\n\n method exp : float -> float meth\n\n method floor : float -> float meth\n\n method log : float -> float meth\n\n method max : float -> float -> float meth\n\n method max_3 : float -> float -> float -> float meth\n\n method max_4 : float -> float -> float -> float -> float meth\n\n method min : float -> float -> float meth\n\n method min_3 : float -> float -> float -> float meth\n\n method min_4 : float -> float -> float -> float -> float meth\n\n method pow : float -> float -> float meth\n\n method random : float meth\n\n method round : float -> float meth\n\n method sin : float -> float meth\n\n method sqrt : float -> float meth\n\n method tan : float -> float meth\n end\n\nlet math = Unsafe.global##._Math\n\nclass type error =\n object\n method name : js_string t prop\n\n method message : js_string t prop\n\n method stack : js_string t optdef prop\n\n method toString : js_string t meth\n end\n\nlet error_constr = Unsafe.global##._Error\n\nmodule Js_error = struct\n type error_t = error t\n\n include Jsoo_runtime.Error\n\n external of_error : error_t -> t = \"%identity\"\n\n external to_error : t -> error_t = \"%identity\"\n\n let name e = to_string (to_error e)##.name\n\n let message e = to_string (to_error e)##.message\n\n let stack (e : t) : string option =\n Opt.to_option (Opt.map (to_error e)##.stack to_string)\n\n let to_string e = to_string (to_error e)##toString\nend\n\nmodule Magic = struct\n module type T = sig\n exception Error of error t\n end\n\n type ('a, 'b) eq = Eq : ('a, 'a) eq\n\n let (eq : (error t, Js_error.t) eq) = Obj.magic Eq\n\n let m =\n match eq with\n | Eq ->\n (module struct\n exception Error = Js_error.Exn\n end : T)\n\n module Error = (val m : T)\nend\n\ninclude Magic.Error\n\nlet raise_js_error e = Js_error.raise_ (Js_error.of_error e)\n\nlet string_of_error e = Js_error.to_string (Js_error.of_error e)\n\nlet exn_with_js_backtrace = Js_error.attach_js_backtrace\n\nexternal js_error_of_exn : exn -> error t opt = \"caml_js_error_of_exception\"\n\nclass type json =\n object\n method parse : js_string t -> 'a meth\n\n method stringify : 'a -> js_string t meth\n end\n\nlet _JSON : json t = Unsafe.global##._JSON\n\nlet decodeURI (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.decodeURI [| Unsafe.inject s |]\n\nlet decodeURIComponent (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.decodeURIComponent [| Unsafe.inject s |]\n\nlet encodeURI (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.encodeURI [| Unsafe.inject s |]\n\nlet encodeURIComponent (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.encodeURIComponent [| Unsafe.inject s |]\n\nlet escape (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.escape [| Unsafe.inject s |]\n\nlet unescape (s : js_string t) : js_string t =\n Unsafe.fun_call Unsafe.global##.unescape [| Unsafe.inject s |]\n\nexternal bool : bool -> bool t = \"caml_js_from_bool\"\n\nexternal to_bool : bool t -> bool = \"caml_js_to_bool\"\n\nexternal array : 'a array -> 'a js_array t = \"caml_js_from_array\"\n\nexternal to_array : 'a js_array t -> 'a array = \"caml_js_to_array\"\n\nexternal bytestring : string -> js_string t = \"caml_jsbytes_of_string\"\n\nexternal to_bytestring : js_string t -> string = \"caml_string_of_jsbytes\"\n\nexternal typeof : _ t -> js_string t = \"caml_js_typeof\"\n\nexternal instanceof : _ t -> _ constr -> bool = \"caml_js_instanceof\"\n\nlet isNaN (i : 'a) : bool =\n to_bool (Unsafe.fun_call Unsafe.global##.isNaN [| Unsafe.inject i |])\n\nlet parseInt (s : js_string t) : int =\n let s = Unsafe.fun_call Unsafe.global##.parseInt [| Unsafe.inject s |] in\n if isNaN s then failwith \"parseInt\" else s\n\nlet parseFloat (s : js_string t) : float =\n let s = Unsafe.fun_call Unsafe.global##.parseFloat [| Unsafe.inject s |] in\n if isNaN s then failwith \"parseFloat\" else s\n\nlet _ =\n Printexc.register_printer (function\n | Js_error.Exn e -> Some (Js_error.to_string e)\n | _ -> None)\n\nlet _ =\n Printexc.register_printer (fun e ->\n let e : < .. > t = Obj.magic e in\n if instanceof e array_constructor then None else Some (to_string e##toString))\n\nlet export_js (field : js_string t) x =\n Unsafe.set (Unsafe.pure_js_expr \"jsoo_exports\") field x\n\nlet export field x = export_js (string field) x\n\nlet export_all obj =\n let keys = object_keys obj in\n keys##forEach\n (wrap_callback (fun (key : js_string t) _ _ -> export_js key (Unsafe.get obj key)))\n\n(****)\n\n(* DEPRECATED *)\n\ntype float_prop = float prop\n\nexternal float : float -> float = \"%identity\"\n\nexternal to_float : float -> float = \"%identity\"\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\nmodule Field = Pickles.Impls.Step.Field.Constant\n\nexternal get_ts_bindings : unit -> Js.Unsafe.any Js.Optdef.t = \"getTsBindings\"\n\n(* the ?. operator from JS *)\nlet ( |. ) (value : _ Js.Optdef.t) (key : string) =\n Js.(\n if phys_equal value undefined then undefined\n else Unsafe.get value (string key))\n\nlet lookup kind prefix =\n get_ts_bindings () |. kind |. prefix |> Js.Optdef.to_option\n\nlet of_js x =\n Js.to_array x |> Array.map ~f:(Fn.compose Field.of_string Js.to_string)\n\nlet salt s =\n match lookup \"prefixHashes\" s with\n | Some state ->\n of_js state |> Random_oracle.State.of_array\n | None ->\n Random_oracle.salt s\n\nlet salt_legacy s =\n match lookup \"prefixHashesLegacy\" s with\n | Some state ->\n of_js state |> Random_oracle.Legacy.State.of_array\n | None ->\n Random_oracle.Legacy.salt s\n","open Core_kernel\nopen Hash_prefixes\n\nlet salt (s : Hash_prefixes.t) = Hash_prefix_create.salt (s :> string)\n\nlet salt_legacy (s : Hash_prefixes.t) =\n Hash_prefix_create.salt_legacy (s :> string)\n\nlet receipt_chain_signed_command = salt_legacy receipt_chain_user_command\n\nlet receipt_chain_zkapp_command = salt receipt_chain_user_command\n\nlet receipt_chain_zkapp = salt receipt_chain_zkapp\n\nlet coinbase = salt coinbase\n\nlet pending_coinbases = salt pending_coinbases\n\nlet coinbase_stack_data = salt coinbase_stack_data\n\nlet coinbase_stack_state_hash = salt coinbase_stack_state_hash\n\nlet coinbase_stack = salt coinbase_stack\n\nlet checkpoint_list = salt checkpoint_list\n\nlet merge_snark = salt merge_snark\n\nlet base_snark = salt base_snark\n\nlet protocol_state = salt protocol_state\n\nlet protocol_state_body = salt protocol_state_body\n\nlet merkle_tree =\n let f i = salt (merkle_tree i) in\n (* Cache up to the compiled ledger depth. *)\n let cached = ref [||] in\n fun i ->\n let len = Array.length !cached in\n if i >= len then\n cached :=\n Array.append !cached\n (Array.init (i + 1 - len) ~f:(fun i -> f (i + len))) ;\n !cached.(i)\n\nlet coinbase_merkle_tree =\n let f i = salt (coinbase_merkle_tree i) in\n let cached = ref [||] in\n fun i ->\n let len = Array.length !cached in\n if i >= len then\n cached :=\n Array.append !cached\n (Array.init (i + 1 - len) ~f:(fun i -> f (i + len))) ;\n !cached.(i)\n\nlet vrf_message = salt vrf_message\n\nlet signature_for_mainnet = salt signature_mainnet\n\nlet signature_for_testnet = salt signature_testnet\n\nlet signature_for_other chain_name = salt @@ signature_other chain_name\n\nlet signature ?(signature_kind = Mina_signature_kind.t) =\n match signature_kind with\n | Mainnet ->\n signature_for_mainnet\n | Testnet ->\n signature_for_testnet\n | Other_network chain_name ->\n signature_for_other chain_name\n\nlet signature_for_mainnet_legacy = salt_legacy signature_mainnet\n\nlet signature_for_testnet_legacy = salt_legacy signature_testnet\n\nlet signature_for_other_legacy chain_name =\n salt_legacy @@ signature_other chain_name\n\nlet signature_legacy ?(signature_kind = Mina_signature_kind.t) =\n match signature_kind with\n | Mainnet ->\n signature_for_mainnet_legacy\n | Testnet ->\n signature_for_testnet_legacy\n | Other_network chain_name ->\n signature_for_other_legacy chain_name\n\nlet vrf_output = salt vrf_output\n\nlet vrf_evaluation = salt vrf_evaluation\n\nlet epoch_seed = salt epoch_seed\n\nlet transition_system_snark = salt transition_system_snark\n\nlet account = salt account\n\nlet side_loaded_vk = salt side_loaded_vk\n\nlet zkapp_account = salt zkapp_account\n\nlet zkapp_payload = salt zkapp_payload\n\nlet zkapp_body ?(chain = Mina_signature_kind.t) = salt @@ zkapp_body ~chain\n\nlet zkapp_precondition = salt zkapp_precondition\n\nlet zkapp_precondition_account = salt zkapp_precondition_account\n\nlet zkapp_precondition_protocol_state = salt zkapp_precondition_protocol_state\n\nlet account_update_account_precondition =\n salt account_update_account_precondition\n\nlet account_update_cons = salt account_update_cons\n\nlet account_update_node = salt account_update_node\n\nlet account_update_stack_frame = salt account_update_stack_frame\n\nlet account_update_stack_frame_cons = salt account_update_stack_frame_cons\n\nlet zkapp_uri = salt zkapp_uri\n\nlet zkapp_event = salt zkapp_event\n\nlet zkapp_events = salt zkapp_events\n\nlet zkapp_actions = salt zkapp_actions\n\nlet zkapp_memo = salt zkapp_memo\n\nlet zkapp_test = salt zkapp_test\n\nlet derive_token_id = salt derive_token_id\n","open Core_kernel\nopen Fold_lib\n\nmodule Make (Impl : Snarky_backendless.Snark_intf.S) = struct\n let triple_string trips =\n let to_string b = if b then \"1\" else \"0\" in\n String.concat ~sep:\" \"\n (List.map trips ~f:(fun (b1, b2, b3) ->\n to_string b1 ^ to_string b2 ^ to_string b3 ) )\n\n let checked_to_unchecked typ1 typ2 checked input =\n let open Impl in\n let checked_result =\n run_and_check\n (let%bind input = exists typ1 ~compute:(As_prover.return input) in\n let%map result = checked input in\n As_prover.read typ2 result )\n |> Or_error.ok_exn\n in\n checked_result\n\n let test_to_triples typ fold var_to_triples input =\n let open Impl in\n let checked =\n run_and_check\n (let%bind input = exists typ ~compute:(As_prover.return input) in\n let%map result = var_to_triples input in\n As_prover.all\n (List.map result\n ~f:\n (As_prover.read\n (Typ.tuple3 Boolean.typ Boolean.typ Boolean.typ) ) ) )\n |> Or_error.ok_exn\n in\n let unchecked = Fold.to_list (fold input) in\n if not ([%equal: (bool * bool * bool) list] checked unchecked) then\n failwithf\n !\"Got %s (%d)\\nexpected %s (%d)\"\n (triple_string checked) (List.length checked) (triple_string unchecked)\n (List.length unchecked) ()\n\n let test_equal ?(equal = Poly.( = )) typ1 typ2 checked unchecked input =\n let checked_result = checked_to_unchecked typ1 typ2 checked input in\n assert (equal checked_result (unchecked input))\n\n let arbitrary_string ~len =\n String.init (Random.int len) ~f:(fun _ ->\n Char.of_int_exn (Random.int_incl 0 255) )\n\n let with_randomness r f =\n let s = Caml.Random.get_state () in\n Random.init r ;\n try\n let x = f () in\n Caml.Random.set_state s ; x\n with e -> Caml.Random.set_state s ; raise e\n\n (** utility function to print digests to put in tests, see `check_serialization' below *)\n let print_digest digest = printf \"\\\"\" ; printf \"%s\" digest ; printf \"\\\"\\n%!\"\n\n (** use this function to test Bin_prot serialization of types *)\n let check_serialization (type t) (module M : Binable.S with type t = t)\n (t : t) known_good_digest =\n (* serialize value *)\n let sz = M.bin_size_t t in\n let buf = Bin_prot.Common.create_buf sz in\n ignore (M.bin_write_t buf ~pos:0 t : int) ;\n let bytes = Bytes.create sz in\n Bin_prot.Common.blit_buf_bytes buf bytes ~len:sz ;\n (* compute MD5 digest of serialization *)\n let digest = Md5.digest_bytes bytes |> Md5.to_hex in\n let result = String.equal digest known_good_digest in\n if not result then (\n printf \"Expected digest: \" ;\n print_digest known_good_digest ;\n printf \"Got digest: \" ;\n print_digest digest ) ;\n result\nend\n\ninclude Make (Snark_params.Tick)\n","(* compressed_poly.ml -- versioned type with parameters for compressed curve point *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n [@@@with_all_version_tags]\n\n type ('field, 'boolean) t =\n ('field, 'boolean) Mina_wire_types.Public_key.Compressed.Poly.V1.t =\n { x : 'field; is_odd : 'boolean }\n [@@deriving compare, equal, hash, hlist]\n end\n end]\nend\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\nmodule Impl = Pickles.Impls.Step\nmodule Field = Impl.Field\n\n(* Ledger - local mina transaction logic for prototyping and testing zkapps *)\n\ntype public_key = Signature_lib.Public_key.Compressed.t\n\nmodule Account_update = Mina_base.Account_update\nmodule Zkapp_command = Mina_base.Zkapp_command\n\nlet ledger_class : < .. > Js.t =\n Js.Unsafe.eval_string {js|(function(v) { this.value = v; return this })|js}\n\nmodule Ledger : Mina_base.Ledger_intf.S = struct\n module Account = Mina_base.Account\n module Account_id = Mina_base.Account_id\n module Ledger_hash = Mina_base.Ledger_hash\n module Token_id = Mina_base.Token_id\n\n type t_ =\n { next_location : int\n ; accounts : Account.t Int.Map.t\n ; locations : int Account_id.Map.t\n }\n\n type t = t_ ref\n\n type location = int\n\n let get (t : t) (loc : location) : Account.t option = Map.find !t.accounts loc\n\n let location_of_account (t : t) (a : Account_id.t) : location option =\n Map.find !t.locations a\n\n let set (t : t) (loc : location) (a : Account.t) : unit =\n t := { !t with accounts = Map.set !t.accounts ~key:loc ~data:a }\n\n let next_location (t : t) : int =\n let loc = !t.next_location in\n t := { !t with next_location = loc + 1 } ;\n loc\n\n let get_or_create (t : t) (id : Account_id.t) :\n (Mina_base.Ledger_intf.account_state * Account.t * location) Or_error.t =\n let loc = location_of_account t id in\n let res =\n match loc with\n | None ->\n let loc = next_location t in\n let a = Account.create id Currency.Balance.zero in\n t := { !t with locations = Map.set !t.locations ~key:id ~data:loc } ;\n set t loc a ;\n (`Added, a, loc)\n | Some loc ->\n (`Existed, Option.value_exn (get t loc), loc)\n in\n Ok res\n\n let[@warning \"-32\"] get_or_create_account (t : t) (id : Account_id.t)\n (a : Account.t) :\n (Mina_base.Ledger_intf.account_state * location) Or_error.t =\n match location_of_account t id with\n | Some loc ->\n let a' = Option.value_exn (get t loc) in\n if Account.equal a a' then Ok (`Existed, loc)\n else\n Or_error.errorf\n !\"account %{sexp: Account_id.t} already present with different \\\n contents\"\n id\n | None ->\n let loc = next_location t in\n t := { !t with locations = Map.set !t.locations ~key:id ~data:loc } ;\n set t loc a ;\n Ok (`Added, loc)\n\n let create_new_account (t : t) (id : Account_id.t) (a : Account.t) :\n unit Or_error.t =\n match location_of_account t id with\n | Some _ ->\n Or_error.errorf !\"account %{sexp: Account_id.t} already present\" id\n | None ->\n let loc = next_location t in\n t := { !t with locations = Map.set !t.locations ~key:id ~data:loc } ;\n set t loc a ;\n Ok ()\n\n let remove_accounts_exn (t : t) (ids : Account_id.t list) : unit =\n let locs = List.filter_map ids ~f:(fun id -> Map.find !t.locations id) in\n t :=\n { !t with\n locations = List.fold ids ~init:!t.locations ~f:Map.remove\n ; accounts = List.fold locs ~init:!t.accounts ~f:Map.remove\n }\n\n (* TODO *)\n let merkle_root (_ : t) : Ledger_hash.t = Field.Constant.zero\n\n let empty ~depth:_ () : t =\n ref\n { next_location = 0\n ; accounts = Int.Map.empty\n ; locations = Account_id.Map.empty\n }\n\n let with_ledger (type a) ~depth ~(f : t -> a) : a = f (empty ~depth ())\n\n let create_masked (t : t) : t = ref !t\n\n let apply_mask (t : t) ~(masked : t) = t := !masked\nend\n\nmodule Transaction_logic = Mina_transaction_logic.Make (Ledger)\n\ntype ledger_class = < value : Ledger.t Js.prop >\n\nlet ledger_constr : (Ledger.t -> ledger_class Js.t) Js.constr =\n Obj.magic ledger_class\n\nlet create_new_account_exn (t : Ledger.t) account_id account =\n Ledger.create_new_account t account_id account |> Or_error.ok_exn\n\nlet default_token_id =\n Mina_base.Token_id.default |> Mina_base.Token_id.to_field_unsafe\n\nlet account_id (pk : public_key) token =\n Mina_base.Account_id.create pk (Mina_base.Token_id.of_field token)\n\nmodule To_js = struct\n let option (transform : 'a -> 'b) (x : 'a option) =\n Js.Optdef.option (Option.map x ~f:transform)\nend\n\nlet check_account_update_signatures zkapp_command =\n let ({ fee_payer; account_updates; memo } : Zkapp_command.t) =\n zkapp_command\n in\n let tx_commitment = Zkapp_command.commitment zkapp_command in\n let full_tx_commitment =\n Zkapp_command.Transaction_commitment.create_complete tx_commitment\n ~memo_hash:(Mina_base.Signed_command_memo.hash memo)\n ~fee_payer_hash:\n (Zkapp_command.Digest.Account_update.create\n (Account_update.of_fee_payer fee_payer) )\n in\n let key_to_string = Signature_lib.Public_key.Compressed.to_base58_check in\n let check_signature who s pk msg =\n match Signature_lib.Public_key.decompress pk with\n | None ->\n failwith\n (sprintf \"Check signature: Invalid key on %s: %s\" who\n (key_to_string pk) )\n | Some pk_ ->\n if\n not\n (Signature_lib.Schnorr.Chunked.verify s\n (Kimchi_pasta.Pasta.Pallas.of_affine pk_)\n (Random_oracle_input.Chunked.field msg) )\n then\n failwith\n (sprintf \"Check signature: Invalid signature on %s for key %s\" who\n (key_to_string pk) )\n else ()\n in\n\n check_signature \"fee payer\" fee_payer.authorization fee_payer.body.public_key\n full_tx_commitment ;\n List.iteri (Zkapp_command.Call_forest.to_account_updates account_updates)\n ~f:(fun i p ->\n let commitment =\n if p.body.use_full_commitment then full_tx_commitment else tx_commitment\n in\n match p.authorization with\n | Signature s ->\n check_signature\n (sprintf \"account_update %d\" i)\n s p.body.public_key commitment\n | Proof _ | None_given ->\n () )\n\nlet add_account_exn (l : Ledger.t) pk (balance : string) =\n let account_id = account_id pk default_token_id in\n let bal_u64 = Unsigned.UInt64.of_string balance in\n let balance = Currency.Balance.of_uint64 bal_u64 in\n let a : Mina_base.Account.t = Mina_base.Account.create account_id balance in\n create_new_account_exn l account_id a\n\nlet create () : ledger_class Js.t =\n let l = Ledger.empty ~depth:20 () in\n new%js ledger_constr l\n\nlet account_to_json =\n let deriver =\n lazy (Mina_base.Account.deriver @@ Fields_derivers_zkapps.o ())\n in\n let to_json (account : Mina_base.Account.t) : Js.Unsafe.any =\n account\n |> Fields_derivers_zkapps.to_json (Lazy.force deriver)\n |> Yojson.Safe.to_string |> Js.string |> Util.json_parse\n in\n to_json\n\nlet get_account l (pk : public_key) (token : Impl.field) :\n Js.Unsafe.any Js.optdef =\n let loc = Ledger.location_of_account l##.value (account_id pk token) in\n let account = Option.bind loc ~f:(Ledger.get l##.value) in\n To_js.option account_to_json account\n\nlet add_account l (pk : public_key) (balance : Js.js_string Js.t) =\n add_account_exn l##.value pk (Js.to_string balance)\n\nlet protocol_state_of_json =\n let deriver =\n lazy\n ( Mina_base.Zkapp_precondition.Protocol_state.View.deriver\n @@ Fields_derivers_zkapps.o () )\n in\n fun (json : Js.js_string Js.t) :\n Mina_base.Zkapp_precondition.Protocol_state.View.t ->\n json |> Js.to_string |> Yojson.Safe.from_string\n |> Fields_derivers_zkapps.of_json (Lazy.force deriver)\n\nlet apply_zkapp_command_transaction l (txn : Zkapp_command.t)\n (account_creation_fee : string)\n (network_state : Mina_base.Zkapp_precondition.Protocol_state.View.t) =\n check_account_update_signatures txn ;\n let ledger = l##.value in\n let application_result =\n Transaction_logic.apply_zkapp_command_unchecked\n ~global_slot:network_state.global_slot_since_genesis\n ~state_view:network_state\n ~constraint_constants:\n { Genesis_constants.Constraint_constants.compiled with\n account_creation_fee = Currency.Fee.of_string account_creation_fee\n }\n ledger txn\n in\n let applied, _ =\n match application_result with\n | Ok res ->\n res\n | Error err ->\n Util.raise_error (Error.to_string_hum err)\n in\n match applied.command.status with\n | Applied ->\n ()\n | Failed failures ->\n Util.raise_error\n ( Mina_base.Transaction_status.Failure.Collection.to_yojson failures\n |> Yojson.Safe.to_string )\n\nlet apply_json_transaction l (tx_json : Js.js_string Js.t)\n (account_creation_fee : Js.js_string Js.t) (network_json : Js.js_string Js.t)\n =\n let txn =\n Zkapp_command.of_json @@ Yojson.Safe.from_string @@ Js.to_string tx_json\n in\n let network_state = protocol_state_of_json network_json in\n apply_zkapp_command_transaction l txn\n (Js.to_string account_creation_fee)\n network_state\n\nlet method_ class_ (name : string) (f : _ Js.t -> _) =\n let prototype = Js.Unsafe.get class_ (Js.string \"prototype\") in\n Js.Unsafe.set prototype (Js.string name) (Js.wrap_meth_callback f)\n\nlet () =\n let static_method name f =\n Js.Unsafe.set ledger_class (Js.string name) (Js.wrap_callback f)\n in\n let method_ name (f : ledger_class Js.t -> _) = method_ ledger_class name f in\n static_method \"create\" create ;\n\n method_ \"getAccount\" get_account ;\n method_ \"addAccount\" add_account ;\n method_ \"applyJsonTransaction\" apply_json_transaction\n","(* public_key.ml *)\n\ninclude Non_zero_curve_point\nmodule Inner_curve = Snark_params.Tick.Inner_curve\n\nlet of_private_key_exn p = of_inner_curve_exn Inner_curve.(scale one p)\n","module type S = sig\n type t [@@deriving equal, sexp]\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t [@@deriving bin_io, equal, sexp]\n end\n\n module Latest : module type of V1\n end\nend\n\nmodule type Hash = sig\n type t [@@deriving compare]\n\n include S with type t := t\n\n val merge : height:int -> t -> t -> t\nend\n\nmodule type Key = S\n\nmodule type Account = sig\n type hash\n\n include S\n\n val data_hash : t -> hash\nend\n","\nlet blockchain_proof () =\n Core_kernel.Binable.of_string (module\n Pickles.Proof.Proofs_verified_2.Stable.Latest)\n \"\\252\\012\\197i\\202m3\\161\\b\\252\\139\\134\\018}\\250\\015\\240\\195\\000\\252\\137\\000\\179\\254\\154\\214\\139{\\252\\017(\\185j\\141\\210\\243\\179\\000\\252\\193\\0075\\134p\\184\\207s\\252\\156\\231\\235\\195%\\236\\155r\\000\\252%O\\171W(\\182[\\n\\252\\242\\128\\235:\\131\\152\\175\\177\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\252\\185*\\167V\\180ps\\173\\252\\252\\158\\241\\213#\\249O6\\000\\252\\000|/\\142b\\028\\135Y\\252\\135\\204&\\162s\\246\\199\\156\\000\\252\\175\\242\\182\\158\\029\\130T#\\252~\\245}\\246\\209k\\185\\213\\000\\252\\246\\134\\144\\160\\208\\247{\\020\\252h*$@\\206b^b\\000\\252\\014\\173V2c\\027\\198\\175\\252\\251\\225\\031\\161\\016r\\128\\t\\000\\252\\145A\\172\\202\\190\\030X\\249\\252\\166\\201\\183>\\153\\213\\030W\\000\\252\\189\\195d\\205\\163PN\\170\\252h\\197\\254\\193\\n\\231\\020\\216\\000\\252m\\222^\\130\\223\\172\\029\\178\\252\\165\\007\\219\\197\\023\\162\\b\\254\\000\\252\\127\\170\\230\\233\\214\\015N\\130\\252,\\127\\185N\\152:\\246\\252\\000\\252\\202\\004\\027q+\\1361\\195\\252)&\\174\\182\\199\\1729\\145\\000\\252\\239Q\\129\\253G\\143\\015\\220\\252\\135\\149;\\196Cz\\169\\000\\000\\252\\1912\\134\\209\\030\\2168`\\252\\171\\005\\170\\162p\\188\\179\\249\\000\\252ZG\\175\\229\\224\\210u\\148\\252\\246\\210\\195\\174\\002\\167\\203\\209\\000\\252\\004|-\\249\\246\\015x\\190\\252T\\226\\2512\\145X=\\225\\000\\252\\019u1\\184\\018\\183p\\198\\252\\b>H\\1543\\204u\\022\\000\\252\\209\\184\\202\\177\\162\\176\\193H\\252\\206\\177q\\192\\227\\004f\\027\\000\\000\\002\\016\\000\\000\\000\\000\\000b\\153TI\\021\\240\\155\\231\\193y\\017D-%H@S\\180Y\\005\\219\\159AV0a\\253}\\1882\\211\\015\\172\\215R\\133\\247\\193\\162O\\199\\177\\230\\226|<\\022:U\\166\\177\\23169\\003\\029\\004\\235\\165^P\\004\\005\\022\\252o\\191\\230\\172\\201\\179\\1303\\252c\\024v\\249XC\\151y\\000\\252\\151\\135\\136\\233\\006+:\\221\\252\\199\\161D)@\\230z\\221\\000\\252\\203\\159\\156\\2440\\229\\232\\198\\252\\221\\156\\160\\205e\\187\\221\\007\\000\\252\\019\\026i\\135\\162Y,S\\252{oe*\\176\\188!\\169\\000\\252\\139\\007\\016\\143\\177w\\156\\226\\252\\238\\012k\\223\\000_\\\\\\248\\000\\252\\135\\156\\176\\007-\\167\\189\\029\\252\\160&_\\233\\226\\151\\027M\\000\\252\\017_\\128V|tu\\156\\252\\232\\241\\206\\250ic\\254\\161\\000\\252M`\\233\\219\\223\\138+\\\\\\252\\155\\247\\016\\242\\140q\\140Z\\000\\252Hk\\224Q\\\\\\179\\192\\\"\\252\\237m\\169@s\\139\\136\\166\\000\\252ndv^\\181\\215\\007\\144\\252\\018\\142N\\2199\\139\\198\\193\\000\\252\\201+?7^\\227ED\\252\\229\\205\\140\\252\\021\\199@\\157\\000\\252N\\170\\188K\\132\\130\\152B\\252\\188\\183\\175\\208\\215'\\169\\151\\000\\252wn\\253\\255[=\\202\\153\\252\\148B\\\\\\021Uj\\230\\239\\000\\252T\\153\\151!q\\178}K\\252@\\200\\147a\\224\\162\\031\\149\\000\\252\\179G\\007\\178\\190\\204\\209,\\252\\029\\002d\\242<\\222\\209[\\000\\000\\252o\\191\\230\\172\\201\\179\\1303\\252c\\024v\\249XC\\151y\\000\\252\\151\\135\\136\\233\\006+:\\221\\252\\199\\161D)@\\230z\\221\\000\\252\\203\\159\\156\\2440\\229\\232\\198\\252\\221\\156\\160\\205e\\187\\221\\007\\000\\252\\019\\026i\\135\\162Y,S\\252{oe*\\176\\188!\\169\\000\\252\\139\\007\\016\\143\\177w\\156\\226\\252\\238\\012k\\223\\000_\\\\\\248\\000\\252\\135\\156\\176\\007-\\167\\189\\029\\252\\160&_\\233\\226\\151\\027M\\000\\252\\017_\\128V|tu\\156\\252\\232\\241\\206\\250ic\\254\\161\\000\\252M`\\233\\219\\223\\138+\\\\\\252\\155\\247\\016\\242\\140q\\140Z\\000\\252Hk\\224Q\\\\\\179\\192\\\"\\252\\237m\\169@s\\139\\136\\166\\000\\252ndv^\\181\\215\\007\\144\\252\\018\\142N\\2199\\139\\198\\193\\000\\252\\201+?7^\\227ED\\252\\229\\205\\140\\252\\021\\199@\\157\\000\\252N\\170\\188K\\132\\130\\152B\\252\\188\\183\\175\\208\\215'\\169\\151\\000\\252wn\\253\\255[=\\202\\153\\252\\148B\\\\\\021Uj\\230\\239\\000\\252T\\153\\151!q\\178}K\\252@\\200\\147a\\224\\162\\031\\149\\000\\252\\179G\\007\\178\\190\\204\\209,\\252\\029\\002d\\242<\\222\\209[\\000\\000\\000\\000\\002H\\1816\\232FT\\165_O\\253\\255\\253\\245\\145\\189\\157<\\161pK\\206\\240\\\\\\165\\157\\194dH\\222\\223\\211\\017k\\026,D\\221!\\199\\205YU\\239\\025\\195\\243\\171\\184B\\014\\027z\\229\\023\\020\\222\\215\\138\\132M\\\"\\007\\245\\005H\\1816\\232FT\\165_O\\253\\255\\253\\245\\145\\189\\157<\\161pK\\206\\240\\\\\\165\\157\\194dH\\222\\223\\211\\017k\\026,D\\221!\\199\\205YU\\239\\025\\195\\243\\171\\184B\\014\\027z\\229\\023\\020\\222\\215\\138\\132M\\\"\\007\\245\\005\\002\\252\\185*\\167V\\180ps\\173\\252\\252\\158\\241\\213#\\249O6\\000\\252\\000|/\\142b\\028\\135Y\\252\\135\\204&\\162s\\246\\199\\156\\000\\252\\175\\242\\182\\158\\029\\130T#\\252~\\245}\\246\\209k\\185\\213\\000\\252\\246\\134\\144\\160\\208\\247{\\020\\252h*$@\\206b^b\\000\\252\\014\\173V2c\\027\\198\\175\\252\\251\\225\\031\\161\\016r\\128\\t\\000\\252\\145A\\172\\202\\190\\030X\\249\\252\\166\\201\\183>\\153\\213\\030W\\000\\252\\189\\195d\\205\\163PN\\170\\252h\\197\\254\\193\\n\\231\\020\\216\\000\\252m\\222^\\130\\223\\172\\029\\178\\252\\165\\007\\219\\197\\023\\162\\b\\254\\000\\252\\127\\170\\230\\233\\214\\015N\\130\\252,\\127\\185N\\152:\\246\\252\\000\\252\\202\\004\\027q+\\1361\\195\\252)&\\174\\182\\199\\1729\\145\\000\\252\\239Q\\129\\253G\\143\\015\\220\\252\\135\\149;\\196Cz\\169\\000\\000\\252\\1912\\134\\209\\030\\2168`\\252\\171\\005\\170\\162p\\188\\179\\249\\000\\252ZG\\175\\229\\224\\210u\\148\\252\\246\\210\\195\\174\\002\\167\\203\\209\\000\\252\\004|-\\249\\246\\015x\\190\\252T\\226\\2512\\145X=\\225\\000\\252\\019u1\\184\\018\\183p\\198\\252\\b>H\\1543\\204u\\022\\000\\252\\209\\184\\202\\177\\162\\176\\193H\\252\\206\\177q\\192\\227\\004f\\027\\000\\000\\252\\185*\\167V\\180ps\\173\\252\\252\\158\\241\\213#\\249O6\\000\\252\\000|/\\142b\\028\\135Y\\252\\135\\204&\\162s\\246\\199\\156\\000\\252\\175\\242\\182\\158\\029\\130T#\\252~\\245}\\246\\209k\\185\\213\\000\\252\\246\\134\\144\\160\\208\\247{\\020\\252h*$@\\206b^b\\000\\252\\014\\173V2c\\027\\198\\175\\252\\251\\225\\031\\161\\016r\\128\\t\\000\\252\\145A\\172\\202\\190\\030X\\249\\252\\166\\201\\183>\\153\\213\\030W\\000\\252\\189\\195d\\205\\163PN\\170\\252h\\197\\254\\193\\n\\231\\020\\216\\000\\252m\\222^\\130\\223\\172\\029\\178\\252\\165\\007\\219\\197\\023\\162\\b\\254\\000\\252\\127\\170\\230\\233\\214\\015N\\130\\252,\\127\\185N\\152:\\246\\252\\000\\252\\202\\004\\027q+\\1361\\195\\252)&\\174\\182\\199\\1729\\145\\000\\252\\239Q\\129\\253G\\143\\015\\220\\252\\135\\149;\\196Cz\\169\\000\\000\\252\\1912\\134\\209\\030\\2168`\\252\\171\\005\\170\\162p\\188\\179\\249\\000\\252ZG\\175\\229\\224\\210u\\148\\252\\246\\210\\195\\174\\002\\167\\203\\209\\000\\252\\004|-\\249\\246\\015x\\190\\252T\\226\\2512\\145X=\\225\\000\\252\\019u1\\184\\018\\183p\\198\\252\\b>H\\1543\\204u\\022\\000\\252\\209\\184\\202\\177\\162\\176\\193H\\252\\206\\177q\\192\\227\\004f\\027\\000\\000:{\\221-N#sE\\216t.\\146\\191u'\\001f@\\238\\128u\\005\\150fI\\237\\246\\129\\015\\128\\21106\\004j\\2083\\133\\221\\031i\\128%\\012\\175\\253p\\b\\001\\136(\\0201\\130L\\169\\1533\\135\\n\\202O\\\\\\131e;\\183=D\\236o\\189M\\132\\028\\133u!\\158\\199\\015\\001\\021JS\\128h\\141\\012~\\202;\\222\\216\\131\\245\\128\\135\\239\\247\\143~\\191\\222\\131\\007qF\\128\\191~\\151\\198\\014\\001\\025\\170\\164\\1530\\233\\178\\162D\\027h\\209\\157c\\215\\019\\160V\\151\\242\\128s\\01739R\\148\\246d\\187b\\017\\001\\197\\021\\245\\023\\014\\220?\\tqX\\248\\217\\137H\\230\\178E\\192x\\222H\\020\\241Qx\\158\\243I\\249\\020\\004\\002\\001C\\193@,\\255\\146\\128\\005\\251d\\017B\\n\\208V\\246r\\176\\002uU},\\214\\237E\\235UI\\252\\191:\\001\\225U\\015BBE\\198\\181\\209\\021\\187\\255Mt\\157:8\\206\\176U\\210\\011\\255;&\\196\\226\\129(\\177\\251-\\001\\170}C.F\\236\\b<\\238\\233\\210M\\251C\\131q:B\\134\\164\\169\\247kL\\153\\216\\217\\\\\\152\\206\\2161\\001I\\183\\002\\137\\241\\162\\241\\191\\219\\021u\\157\\158n\\155Zmz\\237\\175\\134\\027%\\235Y\\145\\161\\243;\\208\\152\\015\\001\\b\\219\\140\\\"\\230\\2379\\250\\166Z\\159\\179\\218\\232\\136{\\027s\\155\\172u\\219R3\\157\\142M\\238\\250\\190o8\\001\\232\\017\\152\\1737?\\255\\211\\156\\229\\158\\154\\137l\\220\\007DE\\\"\\194_=\\020yJ\\210\\173\\235j44$\\001$P\\132\\011V\\2425^o\\198\\165\\208\\203-;\\023\\1607=K\\248\\025\\180\\026c\\028\\182-\\128q\\t\\020\\001\\179\\1366`=\\179Wo\\247\\018\\141E\\144h\\150\\195\\173V\\251\\025 \\001\\001\\173\\011\\219y\\178\\241oM\\020'\\224\\218\\254p\\192c\\016\\250F\\006\\185>\\180B\\130S\\143\\131\\218(\\241?\\001\\149\\209b,\\192\\167\\242\\219\\138\\153\\216\\021e4\\213r\\007\\170\\243\\187\\198\\165\\166\\161\\163\\021\\205\\146Bh\\130\\031\\001R\\210\\183\\129\\190\\0280\\012\\029\\203@ _`$\\007Z\\153\\011>\\214@h^\\164\\134/e\\233F\\233\\026\\0016\\137\\142\\0005\\254\\190\\022\\238\\149\\216\\1441\\223Z\\016\\213a\\217\\152\\174\\208f/]x\\187\\012\\023\\203\\216\\012\\001q#\\154.\\129wF\\242\\151\\015\\170\\222\\241\\174CQ\\\\\\138\\223\\252 \\177o\\025F\\183\\194\\231@\\178\\1902\\001!\\018\\186\\127\\215IgAV;\\148\\136xa*_\\234\\017\\254\\225\\127H\\187\\176\\011\\174\\207{\\223x\\228#\\001\\238\\220$)\\001\\238\\171\\172\\203\\182]%q\\255\\194h\\255\\245\\187f\\247T%\\165\\167\\183Y\\255\\226\\179(\\015\\001{\\r<\\248\\148\\003s\\150\\2073\\2122\\198\\017\\255\\2116\\249\\134ZJ\\143\\210\\031M\\184\\211Gn`h;\\001]\\2030\\190\\252\\242\\243\\217\\150.N.L\\162\\n\\214Lzr\\1990p\\148r\\026GQw\\159\\202\\\"#\\001\\196n\\176;\\144j\\254\\004=\\\"P\\198\\231\\028\\248Pwv\\193\\188\\\"F\\\"y\\128\\252Bw\\004\\254*\\005\\001\\n\\204+o\\253\\166\\002\\250\\226\\0075\\235\\224\\134\\198\\144\\255\\248\\139[\\011\\240\\221\\237\\177\\159\\003:\\190m\\240&\\0017\\140\\201R\\023\\239\\223\\136H\\228l\\219\\2397\\236L\\160\\239#\\169\\185$\\158\\226H\\029\\185\\025S\\144\\130\\011\\001\\225\\\\\\224\\1936\\218c\\206_9\\161\\134-\\155\\005\\004\\184~\\198\\179\\004\\224\\136\\007\\153}\\134K*\\229\\231\\003\\001\\rV!7\\211\\241qk\\016[2\\227\\140\\b\\027\\207\\250 x\\190\\162\\136\\141'o5IJE\\029\\1530\\001\\187\\193\\218H\\155\\205ze\\027\\162Q\\026^\\177\\187\\132\\197@\\014w\\130+UZ\\238\\223\\240Z\\172Z\\153\\024\\001W\\205\\189J{iYG\\001\\127\\241\\0124\\209\\239\\t\\228\\t\\178\\213k\\230\\199\\\\\\188\\194t\\172\\031(\\019\\011\\001\\230|F\\210\\155\\188\\243\\244\\152s\\002p?c\\1406\\012\\000c\\152\\140L\\252\\242\\250-\\004\\235\\249\\201a\\002\\0016Q\\227\\152o^$\\133s\\209W\\185\\141\\132\\028\\217]\\t\\190\\204\\228\\006J\\bQ+\\255i8\\129_\\017\\001\\145\\023\\209\\237E\\027\\137\\203\\187Cu1\\210@\\192\\181Fj\\214Q\\031\\205\\025\\190\\000\\026\\188\\244a\\180~\\011\\001l\\195g\\015\\236\\199\\203@\\rF\\236\\199\\143? \\007\\160\\206\\162^:\\204v0i\\222|1K\\247\\191,\\001\\165c\\201\\149\\241\\255\\143\\199\\234\\160\\027\\019\\178\\193m\\244\\2136B\\161\\155\\168o\\007\\206\\225\\237\\239\\2512-\\030\\001\\139\\159r\\164\\172\\2037\\225A\\027\\148*\\\\y\\190\\247\\191\\021\\182t\\164\\178\\186\\174\\161\\173#5'x\\021\\022\\001y=Q\\211\\206\\254\\164\\247C\\200n\\150,\\n\\195\\023\\235~\\002\\193\\146\\b\\020h\\t\\150}(\\004\\144^;\\001\\249\\166\\162\\185\\201\\nF\\183C\\144\\1632\\024\\2457\\205aW\\238m\\026l\\187\\155yrn9r\\159\\1879\\001\\000\\012Fi\\180\\220\\175\\1870\\186TB\\150,\\0145(\\024\\179\\151\\021j\\165\\156\\000~\\031*\\249\\137\\1858\\001@_\\183\\017\\234\\233\\252\\167\\136u\\219\\141\\182a\\137\\197mBo\\234\\006\\143(&\\254\\\\\\176\\176\\175\\224j\\014\\000\\001\\014P\\025\\239Y[yo\\135.\\218\\232t\\223>k\\209\\233D$\\174\\215\\186Mz\\197\\254Z\\226%$\\021\\001\\206\\206\\146J\\241(\\155\\\"o\\187l\\190\\248\\t\\185D\\\"\\169\\217\\031\\007\\130\\173\\160\\216~\\252\\131\\208\\025\\185\\027\\001JN\\233\\216\\206\\243~pMW\\131n+\\212,idf\\226q\\151\\225f\\229\\164\\172\\135\\175o\\023\\169$\\001\\222~W\\237\\0025\\237\\019\\021\\238|vX/\\232^\\2414\\016W\\026u7\\188\\215\\1899\\025\\242f\\236\\030\\001~\\168\\192\\251%~Q\\024\\229H\\217\\199\\213\\159XX\\202\\021;\\159xPb1=%\\014$\\226\\003)\\020\\001\\157S\\200[\\219\\200\\185\\248\\149\\253<\\242\\133@\\154\\222$\\208w\\198\\177\\251\\136K\\232\\237\\003\\166\\t z\\021\\001\\153\\132\\222Z\\211\\t\\028R?\\144\\219g\\146Rk6\\179\\208\\147k\\218\\138\\168\\170\\130\\017'H\\225\\170\\251-\\001\\210=DU\\\\V\\147$\\006}\\130\\129v2\\164\\180\\139\\227\\020&q\\001\\160\\152s\\025ru\\208(O\\005\\001\\141\\030\\248\\226J\\2075\\230\\143@D\\1282CR\\233!d[\\195T\\176VD\\231\\189N\\179\\168\\014\\157\\019\\001\\173\\177\\175\\207\\175\\254uiekT\\213\\2069\\247\\193\\026U\\149\\143c\\2442\\239\\186\\154\\169c4\\227\\240\\019\\001\\r\\025\\237\\186\\203\\156\\240+\\191\\\\\\028\\016S\\212\\\"G\\149&\\133P8\\192rw*\\n\\151\\015:T\\213%\\001\\137\\172pR\\195oP\\168\\155\\205\\006\\011\\166\\127\\169Dm\\254\\176\\182\\216\\nt\\239a}\\212\\175f\\204 9\\001\\172]\\016U\\230\\220\\133\\230\\150\\205\\226\\228\\205X\\228\\017uVb-\\230\\022\\192K4'\\235\\207Ny!9\\001\\162\\224T\\198[\\145K.\\204\\163\\169\\186\\1635\\160\\214\\165\\001\\156\\251\\177\\156\\224s\\234\\213.\\031\\015\\150?0\\000\\001\\222d\\191\\243\\0223\\131\\175\\\"hwM)\\249s\\130ei%\\163\\132n\\b\\209\\185\\219\\253\\129\\007\\tP\\b\\001\\026y\\201 g\\175:\\147\\227\\142;z\\181Q\\2370\\203%\\152\\190=S\\026\\252\\179\\022\\031\\244dRy\\012\\001\\195\\024\\029\\135\\208\\171J\\153\\206\\200\\133\\179\\212\\222Q\\176\\188\\163+0n\\190\\206\\141\\202\\026\\135+\\192\\239\\196\\029\\001(\\136\\194qd\\185\\0114\\026\\151\\168\\130\\197EOXh\\168\\214\\135\\150\\179\\241\\142\\245B\\128\\238?\\150(:\\001\\207\\230\\245\\252\\199R9=\\203\\252\\148\\018V\\194\\186\\132\\153\\211\\\"(\\174\\026\\221\\018\\r\\015\\190\\204\\2178\\1463\\001\\023\\230\\252\\218\\000c!\\210oh\\226\\150\\139\\bHv6\\007\\2482\\249\\173\\176\\186\\167\\026\\021\\185/y\\136%\\001\\255\\219N\\144\\157w)eu\\239\\022-\\1831X\\022\\147\\168\\174\\026&(\\233\\215\\177\\020\\246\\230H20\\n\\001@\\018\\138\\2202<\\236\\210K_M\\239\\2484\\190\\150\\012\\144\\165\\201}\\022\\206m\\018>\\222\\140\\149\\178\\191<\\001\\146\\245\\252\\220\\012L\\211\\246\\222ByH\\176x1.\\0117D\\182I2\\181Z\\246\\020\\028\\232\\254n\\216,\\001L\\177\\225\\188\\236\\132?\\171~7x\\015D\\136\\rX\\235\\250<(\\180\\192\\201\\019\\174AIZ[\\207[\\025\\001\\192\\200M\\254\\161S\\006\\187\\150'\\021\\185!\\192\\017\\127\\222\\159?\\157\\255\\169sO\\202\\151|\\174\\134T\\1447\\001\\173l\\242Y\\255\\234\\209\\141:\\2538/A\\014w\\026=]\\015&\\020T\\250i\\150\\147\\216\\028E\\204\\128<\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\223\\020\\139\\015&\\240\\031\\139Vn\\220\\030Ql\\169!J\\017\\026\\218\\152\\250\\212J\\199\\014.\\164I\\tW;\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\000\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\000_\\237f\\144(\\136\\155\\028\\146\\165\\241Ac3\\249pC\\228\\027rG\\148\\190z\\212\\148\\177\\t\\235F0\\b\\164\\027o\\160\\129\\149\\020\\157\\254pe\\136\\211o\\168M\\025v\\137\\174\\247\\138\\192t\\153tvYg\\134\\129\\003iyJ\\160\\136\\n=\\235\\242\\019\\1967\\\"\\206\\160\\246J\\151hZz\\179\\147\\218\\244\\137\\146\\240\\0222\\172\\021vgd%\\232v7\\005\\196\\167,N\\160\\197\\169\\028\\029\\238\\1686d\\015Fr.r\\\"O\\232\\249D2LE\\131\\222\\171Jw\\025\\234R;OV&_Y\\027\\245D\\223c\\203H\\018\\162\\213\\236\\031\\025\\127\\028\\020\\169\\n:(\\131\\225u\\236\\213\\219\\164\\213(I\\002\\181k\\170\\162\\209\\029\\238fw\\004u\\015\\144_ V \\188\\131\\199\\226s\\196\\017[F_\\160,\\205\\011\\011\\155\\158vH\\221\\133\\229\\215\\200\\158\\146\\243\\005\\176\\162\\001/\\158\\001J\\154S\\148\\r\\\"1v\\231\\\\+\\n\\015|fS~\\175mR\\192\\192\\244\\r]\\143\\198n\\2295\\212K\\\"96N\\007\\137A\\250\\184G\\182\\140\\028m\\175L\\211<\\239'\\239\\160\\133@R\\225\\018j\\135\\014\\003\\2516\\164nx\\133T\\152_\\019\\240h\\199J\\226J7\\232N\\156\\006l\\215!\\0005\\170\\2109\\225\\150\\006\\031\\030\\235\\243AH\\194e\\132\\002\\019=P\\007\\0167f\\138\\2182\\186q\\2514*\\224\\001\\151\\255\\249A':\\190\\159\\180\\187EGm\\192\\235\\162\\229\\206\\030\\253\\219\\153\\208\\002`\\213b\\190\\185\\172\\154\\030~\\221\\139\\182\\127\\171\\248H\\210\\007\\152\\221\\196K\\243\\179\\227C4\\203\\128`\\250\\2107\\172\\171\\193R\\1330\\209\\194\\129\\219\\026\\029p\\031R\\152o\\238\\174\\154G6eE\\184\\011\\217<%\\1734\\193\\021\\150\\011i\\237Oe\\142^\\202Y\\180\\148w\\170\\249\\127c\\023[\\247\\235\\130d\\0249\\166\\214d&#\\175{\\153bo\\168\\223j\\138\\137\\177\\138?-\\014\\192S#\\245\\179\\127i\\227z`\\\"+9m*\\133\\tp\\196\\183e\\154\\249\\207\\005\\r\\212\\0209:Z%\\017V\\t\\236U\\151x\\129|\\191\\230\\006_\\141EI\\003p\\175\\158\\156e\\217.\\253\\147\\150\\215\\177\\022$+9\\181\\209p@\\006#\\015\\166\\227\\253\\028\\022>\\217\\242\\246\\209\\247\\019?\\141^M\\238\\249H\\027j\\153\\220\\151\\167\\020\\228z(?DJ\\172\\233\\224'\\21178\\018\\214T\\228\\253\\246#:d\\182J\\223\\211\\173F'\\205\\230\\165\\214\\215\\027\\137\\131\\246?fL)L\\197K1\\232\\197\\149\\207\\216\\155d|\\207\\011\\249T#\\182\\021\\005\\201\\161$\\249\\165\\001\\183\\248R\\000\\0052\\204\\tj\\025\\213\\227h)\\174\\\\wo\\2448\\019Kk\\169}\\012\\133\\235\\022\\154\\005\\219t \\214\\028=\\026\\134{\\254\\132g _0?$\\185L\\151\\020;\\182\\b\\143#\\026\\137\\203q\\146\\195\\206\\185hGQ\\127\\r\\139\\204K\\131\\145\\017\\027\\143\\214'P\\244\\219/\\005\\004\\154-\\001\\145tg\\242\\200\\\"\\026\\217\\244\\225\\184\\177\\000|O\\246;\\006zDmw\\158\\031\\185\\206\\0056z\\230\\244\\028\\255\\230\\253\\137g\\019\\011\\161gH\\199<\\003i\\252sOj\\175\\243.\\224 +\\146ng\\209\\003\\202\\136\\208\\2323\\190\\006x\\244\\247R\\145\\166\\152\\2392\\226/\\204\\011\\231\\224\\244v\\205\\238\\\"\\196\\tV\\231 \\188\\186\\143{\\149i\\147B\\185\\t\\135\\198\\207\\220q0!\\234&b\\250\\019~R\\027\\016\\231\\rG\\128Y\\024\\2476\\190\\159\\161\\234P\\192i)^\\128\\145S\\211\\0145_\\n\\nGB\\237\\1294Q\\166\\249wh\\132\\r\\145zV\\249\\182g\\023\\004\\0258\\207\\217S\\n\\2127en\\021\\006\\236!Qz\\128\\137\\2258\\218~\\209M\\180^\\216\\161\\177\\232\\240\\241\\163\\174E\\175*\\174\\201*\\000\\132\\150|2pt\\003\\168hs\\237\\2032S\\218\\rB\\245\\178I\\018\\025\\230\\152\\189\\191Y\\147\\205:\\028:%S\\150\\252l\\194\\022)\\206\\246\\163\\141\\156\\152nP1k\\180.\\031(\\163\\225\\175\\135\\031ui\\250\\203\\rF\\207\\235u\\213?\\170\\219\\220`UL\\153\\188\\221j\\133%\\242\\166\\244\\231\\176\\168#\\237@\\221P\\252\\r\\000i\\n\\152\\217K!p\\237\\251?V\\155\\214\\222\\239\\169\\204\\161;\\t=\\149\\155\\019n\\224\\029/\\152k\\r$n\\142\\134\\243\\219QJ=\\253\\172\\247u\\006h\\011\\2340\\208\\232E\\195\\192\\214W\\250Ld\\201Z\\027%(\\018\\246\\168\\135\\249\\155\\197\\0213\\230Q\\152\\016\\199\\157\\215\\254|\\216\\015\\141\\140\\180\\131\\164\\246Rdg\\202s\\030;\\215wf\\000\\135\\168\\214\\165\\168?d\\000\\006\\188\\167\\1936\\223\\2045\\147\\b\\235\\196D\\254\\000\\230\\130k\\024s\\023k\\187\\196\\195Z@\\203\\002\\248\\217r\\024\\202\\205\\152\\242c\\221X\\181\\174\\143\\193\\184\\021\\242\\201\\197\\221)?\\199\\162\\232\\019p`P5\\249`\\203\\136T\\251\\1315\\025\\134\\204\\1363\\253\\223z\\255:\\252\\176\\021SI\\175P\\145\\227\\205\\024\\192\\146\\237\\149{\\227q\\215\\155\\202>\\0263\\191\\015\\131\\136\\172\\024\\145%\\148A\\004\\231\\\"\\191\\0118O\\193H;\\165\\r\\137F\\004\\220UF\\2284\\196\\202\\182\\000\\028\\194\\188Y\\250\\199\\152Z*zJ\\132\\167V_\\021\\242\\181\\202L\\r\\205\\241\\159\\153\\147q\\t\\185k!\\231\\165A\\209B\\001$\\022Q6\\232\\t?V\\196\\142T\\000\\254\\213\\194\\168j\\232\\2193\\133c\\245\\167\\2341\\166k-\\b3\\226\\183:\\214\\012\\166ac>\\212\\151\\030\\195\\165\\0018\\219\\182|}HB\\191\\254\\239\\177\\003\\229\\141\\147@\\026\\247\\004\\244\\204\\029\\246\\129>q\\241!\\251\\170f\\029\\203\\128\\148^\\241\\024>\\195\\207\\016\\183\\1987\\024JP;\\026\\174\\145\\b\\011R\\190\\155\\240\\240\\187\\017\\145\\157Pm\\240;\\184\\159\\246\\181:\\146\\214\\248\\015\\001\\150\\029\\197@%\\\\\\152T ~X\\178O\\210)\\239\\177n\\018\\005\\166K\\\\\\187\\152ef\\175\\132\\026\\236jM\\141\\165B\\000]9v\\021\\151\\154\\248&\\011\\204\\233'\\149\\244\\0188\\2074\\215{C`\\225\\228\\020\\209\\199\\147}\\172ky\\231M\\2299\\243r\\141\\022\\128\\225\\th\\027Ko\\128\\017\\254\\166\\167X\\248\\233'\\220.\\022\\236\\243\\196\\025\\190o\\149v\\022xd\\2555\\157j {r?\\024\\127w\\134\\021\\210\\240s+7\\175\\022\\153w\\148\\207\\131Id\\216y9'\\166u><\\022\\185\\137!\\213=\\024T\\002\\232t\\243\\024\\168\\025\\253\\242\\243\\172fg& E\\170\\138&fN|\\166\\254\\147\\241Q\\240iP\\139\\130j\\213\\208lqT\\147\\024\\203\\201\\017\\218kt\\208n\\254(\\006\\000.S`[\\128\\026\\215\\254\\167E\\233vj\\221\\141\\169\\2373X\\157u\\143\\1799\\254\\212\\0122\\156Y\\170'\\183z\\135\\136\\176\\127|\\209\\201\\198\\022\\024u\\\\\\202=\\r0:{\\ta$\\206\\012\\002\\220_E\\026\\015\\003.\\030hs\\029\\000\\184G \\003\\136#w~\\198R-\\154\\030\\1586Y \\195\\231\\206\\006J\\222\\012.\\030\\217mb\\229J\\nI\\211\\164L\\145\\158\\180\\176\\1373=d\\1626\\237\\205\\161\\146\\018t\\172i\\003\\186\\2177\\204\\227\\167\\141\\250$-\\140S\\232\\148g\\204\\152m\\2533-\\185\\135\\215lf\\231sZG\\2394\\233\\015(\\195}i,\\132s\\170\\154$k\\184^\\\\C#\\205\\012Zi\\228\\185\\206\\026\\225`\\249aD|1\\174.\\216-8qxB\\189\\227\\023\\021~\\223\\024j[*Z\\194\\1605\\160i\\177\\138\\027\\183\\144\\216\\161\\182\\014&i\\148\\226p\\242\\132\\165W\\196\\024\\175\\235\\250\\172\\162yL\\138\\246\\164v\\203\\027\\148x\\194\\005\\232\\169\\001\\023\\015qq\\021\\229\\151\\019\\200O\\136\\186\\190.\\192)%\\024\\006\\r,\\200+T\\233\\169\\201\\162\\210\\168|\\233\\030\\021]\\217<\\155,?\\206\\227\\015\\163I`\\242G/\\205\\004\\217\\222\\132\\134\\2465\\201\\185mwo\\1741\\\"\\031\\168O\\148\\160\\214\\214K\\224\\185pI\\185*\\226\\197\\138\\140\\185>y!y\\250\\181\\127\\163,F\\149\\171\\231$,|j\\165\\018;A\\170\\142\\172\\232Z~\\238\\184\\235\\178\\\"\\025\\2015;\\146vq\\017\\153\\170\\168\\001\\130\\023\\022\\235\\162\\235\\218\\159\\234\\196B\\226\\158\\249)?\\\\Ev\\147=S\\026n<\\007Q\\1425\\\"A\\005_=\\220\\245\\178\\225$S\\1846\\156B\\014v\\173\\160\\251ln\\023?\\\"q\\170\\025\\236m\\184\\001\\001\\018a\\022\\005\\00056-\\152o \\197\\152\\229<=\\224\\184\\252A0\\004\\132$1r\\175\\137<\\201\\156\\161\\153\\170\\022\\022<\\240\\149\\030j8_\\180\\234\\139^,\\240\\232\\158T\\128z\\153\\147\\139\\n\\182\\156w\\241\\185\\178\\016\\160]\\021.7\\190\\250\\157\\128\\198(\\251\\139?\\127S\\022\\145,\\023T&\\160\\173\\154\\131\\219x\\bG\\2146\\241\\204\\171\\t\\224\\r6\\204+`v\\1941\\132\\004l\\n*\\006 \\133!VD\\254)T\\154bR\\002PU\\189\\251\\028k\\223#\\014\\192z\\145S\\025\\198\\006\\173\\147\\012A\\221\\127\\tr\\\"\\173\\162wjHNu_\\235-I\\028\\238\\128+\\234\\244\\221\\186\\243\\182\\150\\152h\\157~v\\182p\\202\\166]\\219\\217!\\151\\\"z\\176\\200\\223\\1866$\\181\\201\\141:\\136\\030\\170\\213`\\r\\137\\146\\r\\255\\131\\002Py\\210{\\222<\\234\\221\\020B[\\252\\138@\\211\\016\\192D\\022(\\001%\\025\\215o\\239\\001\\007CM\\197k\\177t\\231\\209a\\012\\222/\\200mj\\167+u\\173\\026\\205q\\200\\175\\225\\167\\025\\242\\229\\232?\\206yA\\251\\1541>+\\146bH\\n\\250hg]\\207\\171d\\178\\n\\229\\128\\t=$\\004\\006\\246hK1<\\228\\006i\\189[\\161\\200\\223>\\213<\\237/G<\\003z\\241\\154\\b\\154\\204\\148\\217\\195\\231\\189\\223f\\163#\\216+\\245E\\025\\187\\143/[\\221H\\254\\206\\180Z\\139\\222\\n\\167\\1609\\150\\161\\006B\\017\\181+\\195M&Xxu\\007$\\232\\213R\\174\\156\\232\\250\\229I,}\\020\\169\\230nu\\023\\206*\\018\\131\\\"j\\156\\211\\011\\147\\130\\151\\180{\\233\\154\\000\\252\\192\\190k\\t\\167?\\024'\\252\\012b\\130\\240o\\142W\\253\\000\\252\\213\\243:\\146\\006x\\177\\001\\252\\012\\169\\223\\006\\143(kw\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\252\\185*\\167V\\180ps\\173\\252\\252\\158\\241\\213#\\249O6\\000\\252\\000|/\\142b\\028\\135Y\\252\\135\\204&\\162s\\246\\199\\156\\000\\252\\175\\242\\182\\158\\029\\130T#\\252~\\245}\\246\\209k\\185\\213\\000\\252\\246\\134\\144\\160\\208\\247{\\020\\252h*$@\\206b^b\\000\\252\\014\\173V2c\\027\\198\\175\\252\\251\\225\\031\\161\\016r\\128\\t\\000\\252\\145A\\172\\202\\190\\030X\\249\\252\\166\\201\\183>\\153\\213\\030W\\000\\252\\189\\195d\\205\\163PN\\170\\252h\\197\\254\\193\\n\\231\\020\\216\\000\\252m\\222^\\130\\223\\172\\029\\178\\252\\165\\007\\219\\197\\023\\162\\b\\254\\000\\252\\127\\170\\230\\233\\214\\015N\\130\\252,\\127\\185N\\152:\\246\\252\\000\\252\\202\\004\\027q+\\1361\\195\\252)&\\174\\182\\199\\1729\\145\\000\\252\\239Q\\129\\253G\\143\\015\\220\\252\\135\\149;\\196Cz\\169\\000\\000\\252\\1912\\134\\209\\030\\2168`\\252\\171\\005\\170\\162p\\188\\179\\249\\000\\252ZG\\175\\229\\224\\210u\\148\\252\\246\\210\\195\\174\\002\\167\\203\\209\\000\\252\\004|-\\249\\246\\015x\\190\\252T\\226\\2512\\145X=\\225\\000\\252\\019u1\\184\\018\\183p\\198\\252\\b>H\\1543\\204u\\022\\000\\252\\209\\184\\202\\177\\162\\176\\193H\\252\\206\\177q\\192\\227\\004f\\027\\000\\000\\000\\014\\000\\000\\000\\000\\000b\\153TI\\021\\240\\155\\231\\193y\\017D-%H@S\\180Y\\005\\219\\159AV0a\\253}\\1882\\211\\015\\172\\215R\\133\\247\\193\\162O\\199\\177\\230\\226|<\\022:U\\166\\177\\23169\\003\\029\\004\\235\\165^P\\004\\005\\022\\252o\\191\\230\\172\\201\\179\\1303\\252c\\024v\\249XC\\151y\\000\\252\\151\\135\\136\\233\\006+:\\221\\252\\199\\161D)@\\230z\\221\\000\\252\\203\\159\\156\\2440\\229\\232\\198\\252\\221\\156\\160\\205e\\187\\221\\007\\000\\252\\019\\026i\\135\\162Y,S\\252{oe*\\176\\188!\\169\\000\\252\\139\\007\\016\\143\\177w\\156\\226\\252\\238\\012k\\223\\000_\\\\\\248\\000\\252\\135\\156\\176\\007-\\167\\189\\029\\252\\160&_\\233\\226\\151\\027M\\000\\252\\017_\\128V|tu\\156\\252\\232\\241\\206\\250ic\\254\\161\\000\\252M`\\233\\219\\223\\138+\\\\\\252\\155\\247\\016\\242\\140q\\140Z\\000\\252Hk\\224Q\\\\\\179\\192\\\"\\252\\237m\\169@s\\139\\136\\166\\000\\252ndv^\\181\\215\\007\\144\\252\\018\\142N\\2199\\139\\198\\193\\000\\252\\201+?7^\\227ED\\252\\229\\205\\140\\252\\021\\199@\\157\\000\\252N\\170\\188K\\132\\130\\152B\\252\\188\\183\\175\\208\\215'\\169\\151\\000\\252wn\\253\\255[=\\202\\153\\252\\148B\\\\\\021Uj\\230\\239\\000\\252T\\153\\151!q\\178}K\\252@\\200\\147a\\224\\162\\031\\149\\000\\252\\179G\\007\\178\\190\\204\\209,\\252\\029\\002d\\242<\\222\\209[\\000\\000\\252o\\191\\230\\172\\201\\179\\1303\\252c\\024v\\249XC\\151y\\000\\252\\151\\135\\136\\233\\006+:\\221\\252\\199\\161D)@\\230z\\221\\000\\252\\203\\159\\156\\2440\\229\\232\\198\\252\\221\\156\\160\\205e\\187\\221\\007\\000\\252\\019\\026i\\135\\162Y,S\\252{oe*\\176\\188!\\169\\000\\252\\139\\007\\016\\143\\177w\\156\\226\\252\\238\\012k\\223\\000_\\\\\\248\\000\\252\\135\\156\\176\\007-\\167\\189\\029\\252\\160&_\\233\\226\\151\\027M\\000\\252\\017_\\128V|tu\\156\\252\\232\\241\\206\\250ic\\254\\161\\000\\252M`\\233\\219\\223\\138+\\\\\\252\\155\\247\\016\\242\\140q\\140Z\\000\\252Hk\\224Q\\\\\\179\\192\\\"\\252\\237m\\169@s\\139\\136\\166\\000\\252ndv^\\181\\215\\007\\144\\252\\018\\142N\\2199\\139\\198\\193\\000\\252\\201+?7^\\227ED\\252\\229\\205\\140\\252\\021\\199@\\157\\000\\252N\\170\\188K\\132\\130\\152B\\252\\188\\183\\175\\208\\215'\\169\\151\\000\\252wn\\253\\255[=\\202\\153\\252\\148B\\\\\\021Uj\\230\\239\\000\\252T\\153\\151!q\\178}K\\252@\\200\\147a\\224\\162\\031\\149\\000\\252\\179G\\007\\178\\190\\204\\209,\\252\\029\\002d\\242<\\222\\209[\\000\\000\\000\\000\\000\\000\\001+\\178z\\189\\247\\143\\2441kS\\153\\134\\228\\129.A\\145\\194\\241\\n\\242\\157v\\230\\254R~\\231=!\\028yl\\212\\198\\242\\150\\168\\251\\127\\131#\\239X\\007\\\\zs\\0160C\\178B\\029\\208)\\143\\162\\135]A\\t\\007\\001\\232\\236M\\246\\175l\\000\\155x\\165[\\244t(\\230\\019h\\002\\022w\\232\\189?\\205\\030\\231\\189\\135\\244\\194\\179\\007\\001\\171\\127\\188\\169\\169\\025\\150?7\\222\\003\\216\\141\\161&\\160\\205\\230\\147\\214\\003l\\004\\147xZa\\210\\217|+\\021\\001\\230\\134'\\178\\191Y\\0017\\206(\\161\\160\\185\\131m^\\1274U]Pz\\190\\235B\\022n\\209w\\0182\\019\\001\\202\\255\\136td\\134E\\219\\019a\\176lK\\1963\\255\\243\\153\\1332\\245?\\220\\222\\1769\\1510\\217\\028!.\\001\\031\\250V\\151\\255/)\\b\\214\\187\\140\\195\\139\\006%\\214\\255-\\223\\b\\131M]\\252#S(\\015\\137\\000\\254\\007\\001|\\226\\192\\159]\\201g\\171\\027^\\014\\145\\242\\206Fp\\177\\135\\157a\\020tfM\\012(\\207?\\232\\173\\158$\\001\\239|%z\\143U\\142i\\012\\022\\230U3jT\\150\\205I)-C\\253]Q\\198\\138\\n\\001\\199\\1712\\\"\\001\\245*\\234Y\\196\\237\\148z\\127B\\016\\135\\176\\031\\184\\175\\225\\031`\\135`\\025\\019\\146\\185\\156= Hr'$\\001\\252\\245\\213\\132?Tn\\194\\025\\248\\233LIj\\175\\225\\003\\212x\\148\\181.V\\003\\248\\145\\161W\\184s\\203/\\001\\216\\161\\018p\\254B\\018\\129\\245Ap4\\191\\1863\\149\\251 /\\1654t\\012\\r,I\\175_l\\246\\133&\\001\\168\\215\\239\\213}\\244\\207\\213\\138\\198B=\\189\\144k\\003\\022KRT\\219\\151\\215\\228\\138\\006\\244\\235z\\b\\217#\\0016\\002\\\"\\186\\135\\255W&\\208\\185h\\235|_d\\173\\181\\215\\1512{-\\221Mr\\219\\b6J>\\028\\006\\001\\027\\014\\230\\015\\235\\209Y\\014\\025D\\176\\168\\001\\176\\143\\231&\\204\\2397\\163R\\031\\161`\\005%tp\\015\\003,\\0016/\\136m\\132\\216\\205\\022\\183\\146q;\\002\\bR@\\162\\132d\\000\\254\\167Dt\\252W\\155\\193\\144\\246\\179#\\001\\127nv'\\218\\003\\201\\206\\241\\176\\232F\\219\\146u\\192J\\028\\018\\148=\\180\\247\\\\\\128w\\197n\\151\\rI\\003\\001q\\152\\173\\221\\1574D\\148\\r\\175\\007=\\130g\\185\\226\\153\\180\\243\\181\\1843\\011d\\154\\132\\197\\222\\014\\189&\\014\\001I\\205\\143\\176\\142\\148\\234\\158\\149\\225\\165\\250H\\156\\023\\011\\240\\b\\197\\146\\144!\\224\\248\\185\\173;\\2229j\\254\\031\\001\\170\\\\[\\166\\023HT;Z!\\227\\233?\\158k|x\\252:\\219\\211\\194\\2485]\\135k-\\176\\020\\220*\\001\\208\\018Gy\\165\\174\\157&\\2271H\\t\\003%XFE\\159\\194\\025\\179\\015{S\\178\\246\\146\\235jMa,\\001\\217\\201\\179H\\176\\229~y\\178\\246Zy\\020vn\\238\\254\\154\\165|<\\b\\177{\\176\\\"z\\243!\\131|$\\001h\\215\\b\\021\\197\\241k\\191|\\191\\205\\176\\0024\\255J*\\157H#ss\\184\\211\\243\\127v\\248\\154\\011 \\n\\001\\240\\157?\\185\\133\\198\\149\\159L\\156$Bb\\176z\\140<\\161\\248#\\239\\238\\144\\134\\007Z-\\1301*\\172-\\001cK\\156\\138\\169\\182\\188\\131E\\130\\026\\232s~O\\202\\132{\\204\\2303\\025\\154\\162\\129\\029\\170Z\\245f\\0069\\001\\031\\001*yV\\176\\143\\242\\166]k\\250\\203\\r\\158\\131x\\007]\\134\\196\\177\\235\\127 %\\012\\206\\254a\\242\\17061\\000\\001\\219\\185N\\182+\\183\\223\\190U\\151'#\\173+D\\234i\\183Kx\\029\\132f\\030\\219\\015\\130a\\196\\210b\\007\\001\\b\\233\\155\\220\\240\\133\\201(\\245\\025[\\185\\214x\\156\\206&ls\\248\\241s\\231~%\\140\\192\\145q%\\222?\\001\\216\\162\\189\\210\\028\\162\\025\\221|\\r\\161q\\240\\127\\205l\\196\\031a\\253w\\239v\\176\\136:\\025.\\150i\\137\\004\\001\\1931\\003\\169g8)\\185\\199\\234\\255R\\221d\\215\\243\\149\\006te\\129@\\026\\025\\135\\166\\151]\\180\\178\\139\\012\\001,\\029\\146\\141\\252\\\"\\227\\005\\194\\205\\192F5\\226\\252\\228\\145\\148\\241\\246\\1766!\\187a\\181\\233\\240F\\248\\028\\\"\\001\\245\\169\\182\\166\\249\\031\\031}Cl[8\\148 \\153[\\154\\130\\128\\160\\171\\203\\131\\255\\195\\153\\211\\224\\232\\195\\181\\025\\001\\254\\167\\017\\239!=:D\\020\\175D '\\012\\021U\\180\\216,,\\249]A\\252C\\016\\183\\164\\203\\b\\128\\022\\001\\220k\\224\\182$\\178\\255\\169\\218\\181\\155}\\212\\143\\019L\\130\\192\\205\\225\\136\\162\\248\\199y\\174\\244\\162N\\207%\\n\\001&7bQ\\224\\155\\248m:\\238@\\194\\244\\250\\027\\232Hq?'\\13104\\2247JMY\\017o\\195\\028\\001\\026\\249A\\180a\\187\\007\\231,i\\131\\130\\200V\\252\\006\\235\\207\\223>\\158\\183\\200x\\194\\b\\148F\\1751R\\020\\001Cs\\203R\\152\\181\\132eim=\\181\\2134\\162j\\217\\024\\238\\162Ru}\\187.\\030\\139\\157\\132\\020'\\020\\001g\\233\\236\\138\\198v;\\145u\\235\\133\\212}\\170@\\247 \\018\\166=~\\248-\\138p\\230\\145i+oE\\022\\001\\016\\233\\238\\174\\016\\200s\\194\\141\\015\\020\\192\\158R\\215\\1310\\254w\\229\\002C\\198kM\\153'\\251\\247r\\143\\015\\001\\210\\146S\\003p\\017\\200\\198\\139iDT\\005%6~n\\142ea\\144\\188n\\165>fA\\b\\132\\184\\215=\\001l$ \\220\\001\\025\\tA!\\176so\\133X\\005\\141\\148;\\183\\138\\192\\251tF\\153\\139_x#6\\161\\142\\138)\\208PM\\154j\\223,;t+\\001\\183!\\131]\\179p\\131j\\220\\021\\197\\134\\023\\133u\\019\\028\\231\\166\\134\\255\\029\\184\\1716\\216\\127\\212\\156\\228\\2102\\001\\140e\\254\\2535\\031 \\029\\019\\131\\142\\192\\031\\208\\172\\1714\\204\\171\\132\\\"\\024\\144\\230\\001Ca-\\199\\160n\\020\\001+\\173q\\005e\\000\\011\\029aH\\159\\191(sj_T\\164\\250]\\215\\141&\\001\\248\\144\\162\\192\\153\\133G+\\001r\\025\\005\\193m\\005B7\\011A\\142\\162K\\017\\031\\000E\\200`~\\207r\\178\\240\\206]\\145\\026\\199\\021\\133<\\001\\024\\218F;3z\\187\\187\\224\\133\\b@\\238\\179\\140\\191{\\180\\183v\\021I*\\196\\238\\186F~\\207y\\011\\002\\001`T[\\018\\161@S\\129\\177\\225x\\222m\\177\\233#\\026\\253\\151\\011+v\\177\\209\\222\\018\\179\\b]\\027\\153=\\001bT\\171\\173\\207\\223\\172\\131\\219\\156\\211\\029\\183\\195\\2518`\\004\\200\\152\\005\\227\\253\\227\\236\\003\\250OEt\\225\\018\\001#\\007Q\\194\\241\\172\\027\\014\\2238\\210\\145~\\012Q\\207\\241\\189k\\188\\229b\\149\\170\\244*I\\154#\\141{9\\001\\250Q\\246\\242.P\\174\\210j\\230\\189\\190\\212-\\172a\\178;]aA\\132\\014B\\148\\249\\131\\020\\196?\\r\\b\\001nd\\197\\029\\213\\018E\\1845l\\234Q\\251[\\016t\\028Z\\144yw^\\r\\242\\166\\169\\028%\\185\\131+%\\001\\203\\189\\209J%\\231\\167\\007\\236\\158k\\164\\235\\230\\236\\246\\184\\\\q\\n^\\t\\172\\150\\221R\\024{\\175'\\224\\016\\001\\027\\237%-\\246\\160L\\141\\225\\202\\237\\173O\\173\\137`h:B\\022\\198\\208-w+y\\021m\\218\\020\\234>\\001\\190\\242\\182\\160\\247\\149\\187\\216\\020\\006\\131\\023n\\000%\\201e}W$\\224\\237Tmr\\204\\000c\\159g\\007\\020\\001]\\213\\212@\\213_0f\\236\\137\\175\\005\\242\\026\\228\\145\\201{\\189\\230\\025\\250\\152\\252rQ\\225\\234\\249\\b;\\025\\000\\001\\217a\\003\\155P\\239\\232\\176\\r\\019\\133\\185|\\000\\185\\200\\237\\012;H\\0051&vP\\221\\229q\\017\\172t\\017\\001k\\132?\\218K\\028\\019n\\155\\187\\245I=\\147\\145\\012`\\247\\160\\1684\\233\\237\\240\\003\\023Wr\\247\\182\\170\\019\\001\\148\\151\\018\\200-Zi\\1799\\191Q\\1314n\\198\\237\\163\\190\\207={D&\\248\\227\\bY5Ht\\130\\b\\001\\220L\\245o\\181\\179~O\\005\\253\\205\\021\\198Z\\175G\\002K\\127\\188\\246\\253\\204\\028Z\\2155\\203>V_\\007\\001~el\\158y\\174 \\207\\153\\143\\176#\\167\\018\\001\\224\\243\\151\\213[\\\"\\019DDF\\162\\150\\1355\\000\\003\\\"\\001\\183\\181\\192\\0140\\252\\1361\\194\\004\\t\\158\\154Fmt\\216\\251\\183\\236\\209\\235\\247\\183jD\\221\\203;\\163\\1892\\001*]\\217A\\168\\207\\b,\\160Tg\\158.\\169\\005\\150\\005(;\\nV\\239)\\027)\\003\\209?\\218\\141\\2303\\001\\027\\162z\\209\\210\\021\\209\\239\\144\\007/ !\\143\\154\\237\\189\\247\\197\\\"\\134\\130rGE\\001\\225\\182\\227T\\1462\\001\\223X\\1939\\179\\012vG\\128q.\\140\\209ib\\021\\2546\\134~\\1476\\157p\\187D\\226\\190\\128gB\\024\\001\\139\\225\\168\\152\\238n\\130\\177\\031\\223r\\232\\251\\017\\247&D\\t\\142\\140\\183\\015\\006\\176\\233\\227\\192\\246\\161Z\\253>\\001\\245\\244\\\"\\151\\227\\222\\253\\228\\235\\031\\224\\011_b]R\\029>g\\201\\014\\169d\\184\\129Ui\\182\\238o\\0215\\001\\244\\144h}D\\172:\\007\\254Y\\006%\\240b\\236NW\\003ZhX\\168\\164\\216\\130;\\029\\1417\\150\\2248\\0017\\243\\145\\130\\204\\246\\\\LX\\135\\020\\024\\194\\147{\\211\\159\\023z86\\241)\\167|\\193~rD~W\\004\\001\\023\\022\\153Cf\\029\\180\\023\\128\\158\\135\\130]\\214\\018Q\\156\\018ga~\\165\\147\\153\\217 \\001\\225\\234\\234\\181\\162&\\135DV\\210\\004\\244\\018T(c~\\203\\018\\180]\\206o\\031+\\181CpW\\167],\\0019\\024\\244\\030\\168\\138^\\213^\\176\\020\\242\\025\\214\\132\\143\\251\\235\\\"\\149F#z \\0231\\246\\216Wd,<\\001(\\129\\219\\244kx\\215l\\028\\131\\2286\\189\\160\\133\\012E\\168\\167\\023\\174~\\153(\\130\\170\\241\\207/\\137\\242\\019\\001\\133dZ[\\181jE\\195\\196Md\\221\\227\\172\\240\\020f\\028\\136+\\129\\147T\\\"\\201'u\\027!\\137\\2275\\001\\175\\156\\238U\\220\\131\\172\\011\\175\\169\\024\\166\\181\\1661\\005\\178)\\006N\\162\\\"\\142\\185\\194\\163\\130\\211\\215\\179\\253$\\001\\241\\134r\\239<\\134M\\249\\199U\\200ad\\\\&\\167\\020\\212\\187\\207\\030`l)r\\249\\023\\149\\224\\017\\203\\031\\001A\\222\\168$\\183\\168)M\\247\\228U'\\202\\220\\143\\185^O\\187\\230\\235\\230z\\194ko\\197\\146Kr\\179!\\001\\220-\\145\\200\\201\\141\\151\\243\\193\\172\\201%\\229bry\\238\\186\\158\\179\\224\\2557\\203\\031\\223\\015N4\\171\\1613\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\250_\\130\\146A-\\205\\129F\\016m\\136D\\248\\159\\231\\138\\242\\187Nc\\162\\193,\\239v>K\\202\\n\\192,\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\000\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\000_\\237f\\144(\\136\\155\\028\\146\\165\\241Ac3\\249pC\\228\\027rG\\148\\190z\\212\\148\\177\\t\\235F0\\b\\164\\027o\\160\\129\\149\\020\\157\\254pe\\136\\211o\\168M\\025v\\137\\174\\247\\138\\192t\\153tvYg\\134\\129\\003iyJ\\160\\136\\n=\\235\\242\\019\\1967\\\"\\206\\160\\246J\\151hZz\\179\\147\\218\\244\\137\\146\\240\\0222\\172\\021vgd%\\232v7\\005\\196\\167,N\\160\\197\\169\\028\\029\\238\\1686d\\015Fr.r\\\"O\\232\\249D2LE\\131\\222\\171Jw\\025\\234R;OV&_Y\\027\\245D\\223c\\203H\\018\\162\\213\\236\\031\\025\\127\\028\\020\\169\\n:(\\131\\225u\\236\\213\\219\\164\\213(I\\002\\181k\\170\\162\\209\\029\\238fw\\004u\\015\\144_ V \\188\\131\\199\\226s\\196\\017[F_\\160,\\205\\011\\011\\155\\158vH\\221\\133\\229\\215\\200\\158\\146\\243\\005\\176\\162\\001/\\158\\001J\\154S\\148\\r\\\"1v\\231\\\\+\\n\\015|fS~\\175mR\\192\\192\\244\\r]\\143\\198n\\2295\\212K\\\"96N\\007\\137A\\250\\184G\\182\\140\\028m\\175L\\211<\\239'\\239\\160\\133@R\\225\\018j\\135\\014\\003\\2516\\164nx\\133T\\152_\\019\\240h\\199J\\226J7\\232N\\156\\006l\\215!\\0005\\170\\2109\\225\\150\\006\\031\\030\\235\\243AH\\194e\\132\\002\\019=P\\007\\0167f\\138\\2182\\186q\\2514*\\224\\001\\151\\255\\249A':\\190\\159\\180\\187EGm\\192\\235\\162\\229\\206\\030\\253\\219\\153\\208\\002`\\213b\\190\\185\\172\\154\\030~\\221\\139\\182\\127\\171\\248H\\210\\007\\152\\221\\196K\\243\\179\\227C4\\203\\128`\\250\\2107\\172\\171\\193R\\1330\\209\\194\\129\\219\\026\\029p\\031R\\152o\\238\\174\\154G6eE\\184\\011\\217<%\\1734\\193\\021\\150\\011i\\237Oe\\142^\\202Y\\180\\148w\\170\\249\\127c\\023[\\247\\235\\130d\\0249\\166\\214d&#\\175{\\153bo\\168\\223j\\138\\137\\177\\138?-\\014\\192S#\\245\\179\\127i\\227z`\\\"+9m*\\133\\tp\\196\\183e\\154\\249\\207\\005\\r\\212\\0209:Z%\\017V\\t\\236U\\151x\\129|\\191\\230\\006_\\141EI\\003p\\175\\158\\156e\\217.\\253\\147\\150\\215\\177\\022$+9\\181\\209p@\\006#\\015\\166\\227\\253\\028\\022>\\217\\242\\246\\209\\247\\019?\\141^M\\238\\249H\\027j\\153\\220\\151\\167\\020\\228z(?DJ\\172\\233\\224'\\21178\\018\\214T\\228\\253\\246#:d\\182J\\223\\211\\173F'\\205\\230\\165\\214\\215\\027\\137\\131\\246?fL)L\\197K1\\232\\197\\149\\207\\216\\155d|\\207\\011\\249T#\\182\\021\\005\\201\\161$\\249\\165\\001\\183\\248R\\000\\0052\\204\\tj\\025\\213\\227h)\\174\\\\wo\\2448\\019Kk\\169}\\012\\133\\235\\022\\154\\005\\219t \\214\\028=\\026\\134{\\254\\132g _0?$\\185L\\151\\020;\\182\\b\\143#\\026\\137\\203q\\146\\195\\206\\185hGQ\\127\\r\\139\\204K\\131\\145\\017\\027\\143\\214'P\\244\\219/\\005\\004\\154-\\001\\145tg\\242\\200\\\"\\026\\217\\244\\225\\184\\177\\000|O\\246;\\006zDmw\\158\\031\\185\\206\\0056z\\230\\244\\028\\255\\230\\253\\137g\\019\\011\\161gH\\199<\\003i\\252sOj\\175\\243.\\224 +\\146ng\\209\\003\\202\\136\\208\\2323\\190\\006x\\244\\247R\\145\\166\\152\\2392\\226/\\204\\011\\231\\224\\244v\\205\\238\\\"\\196\\tV\\231 \\188\\186\\143{\\149i\\147B\\185\\t\\135\\198\\207\\220q0!\\234&b\\250\\019~R\\027\\016\\231\\rG\\128Y\\024\\2476\\190\\159\\161\\234P\\192i)^\\128\\145S\\211\\0145_\\n\\nGB\\237\\1294Q\\166\\249wh\\132\\r\\145zV\\249\\182g\\023\\004\\0258\\207\\217S\\n\\2127en\\021\\006\\236!Qz\\128\\137\\2258\\218~\\209M\\180^\\216\\161\\177\\232\\240\\241\\163\\174E\\175*\\174\\201*\\000\\132\\150|2pt\\003\\168hs\\237\\2032S\\218\\rB\\245\\178I\\018\\025\\230\\152\\189\\191Y\\147\\205:\\028:%S\\150\\252l\\194\\022)\\206\\246\\163\\141\\156\\152nP1k\\180.\\031(\\163\\225\\175\\135\\031ui\\250\\203\\rF\\207\\235u\\213?\\170\\219\\220`UL\\153\\188\\221j\\133%\\242\\166\\244\\231\\176\\168#\\237@\\221P\\252\\r\\000i\\n\\152\\217K!p\\237\\251?V\\155\\214\\222\\239\\169\\204\\161;\\t=\\149\\155\\019n\\224\\029/\\152k\\r$n\\142\\134\\243\\219QJ=\\253\\172\\247u\\006h\\011\\2340\\208\\232E\\195\\192\\214W\\250Ld\\201Z\\027%(\\018\\246\\168\\135\\249\\155\\197\\0213\\230Q\\152\\016\\199\\157\\215\\254|\\216\\015\\141\\140\\180\\131\\164\\246Rdg\\202s\\030;\\215wf\\000\\135\\168\\214\\165\\168?d\\000\\006\\188\\167\\1936\\223\\2045\\147\\b\\235\\196D\\254\\000\\230\\130k\\024s\\023k\\187\\196\\195Z@\\203\\002\\248\\217r\\024\\202\\205\\152\\242c\\221X\\181\\174\\143\\193\\184\\021\\242\\201\\197\\221)?\\199\\162\\232\\019p`P5\\249`\\203\\136T\\251\\1315\\025\\134\\204\\1363\\253\\223z\\255:\\252\\176\\021SI\\175P\\145\\227\\205\\024\\192\\146\\237\\149{\\227q\\215\\155\\202>\\0263\\191\\015\\131\\136\\172\\024\\145%\\148A\\004\\231\\\"\\191\\0118O\\193H;\\165\\r\\137F\\004\\220UF\\2284\\196\\202\\182\\000\\028\\194\\188Y\\250\\199\\152Z*zJ\\132\\167V_\\021\\242\\181\\202L\\r\\205\\241\\159\\153\\147q\\t\\185k!\\231\\165A\\209B\\001$\\022Q6\\232\\t?V\\196\\142T\\000\\254\\213\\194\\168j\\232\\2193\\133c\\245\\167\\2341\\166k-\\b3\\226\\183:\\214\\012\\166ac>\\212\\151\\030\\195\\165\\0018\\219\\182|}HB\\191\\254\\239\\177\\003\\229\\141\\147@\\026\\247\\004\\244\\204\\029\\246\\129>q\\241!\\251\\170f\\029\\203\\128\\148^\\241\\024>\\195\\207\\016\\183\\1987\\024JP;\\026\\174\\145\\b\\011R\\190\\155\\240\\240\\187\\017\\145\\157Pm\\240;\\184\\159\\246\\181:\\146\\214\\248\\015\\001\\150\\029\\197@%\\\\\\152T ~X\\178O\\210)\\239\\177n\\018\\005\\166K\\\\\\187\\152ef\\175\\132\\026\\236jM\\141\\165B\\000]9v\\021\\151\\154\\248&\\011\\204\\233'\\149\\244\\0188\\2074\\215{C`\\225\\228\\020\\209\\199\\147}\\172ky\\231M\\2299\\243r\\141\\022\\128\\225\\th\\027Ko\\128\\017\\254\\166\\167X\\248\\233'\\220.\\022\\236\\243\\196\\025\\190o\\149v\\022xd\\2555\\157j {r?\\024\\127w\\134\\021\\210\\240s+7\\175\\022\\153w\\148\\207\\131Id\\216y9'\\166u><\\022\\185\\137!\\213=\\024T\\002\\232t\\243\\024\\168\\025\\253\\242\\243\\172fg& E\\170\\138&fN|\\166\\254\\147\\241Q\\240iP\\139\\130j\\213\\208lqT\\147\\024\\203\\201\\017\\218kt\\208n\\254(\\006\\000.S`[\\128\\026\\215\\254\\167E\\233vj\\221\\141\\169\\2373X\\157u\\143\\1799\\254\\212\\0122\\156Y\\170'\\183z\\135\\136\\176\\127|\\209\\201\\198\\022\\024u\\\\\\202=\\r0:{\\ta$\\206\\012\\002\\220_E\\026\\015\\003.\\030hs\\029\\000\\184G \\003\\136#w~\\198R-\\154\\030\\1586Y \\195\\231\\206\\006J\\222\\012.\\030\\217mb\\229J\\nI\\211\\164L\\145\\158\\180\\176\\1373=d\\1626\\237\\205\\161\\146\\018t\\172i\\003\\186\\2177\\204\\227\\167\\141\\250$-\\140S\\232\\148g\\204\\152m\\2533-\\185\\135\\215lf\\231sZG\\2394\\233\\015(\\195}i,\\132s\\170\\154$k\\184^\\\\C#\\205\\012Zi\\228\\185\\206\\026\\225`\\249aD|1\\174.\\216-8qxB\\189\\227\\023\\021~\\223\\024j[*Z\\194\\1605\\160i\\177\\138\\027\\183\\144\\216\\161\\182\\014&i\\148\\226p\\242\\132\\165W\\196\\024\\175\\235\\250\\172\\162yL\\138\\246\\164v\\203\\027\\148x\\194\\005\\232\\169\\001\\023\\015qq\\021\\229\\151\\019\\200O\\136\\186\\190.\\192)%\\024\\006\\r,\\200+T\\233\\169\\201\\162\\210\\168|\\233\\030\\021]\\217<\\155,?\\206\\227\\015\\163I`\\242G/\\205\\004\\217\\222\\132\\134\\2465\\201\\185mwo\\1741\\\"\\031\\168O\\148\\160\\214\\214K\\224\\185pI\\185*\\226\\197\\138\\140\\185>y!y\\250\\181\\127\\163,F\\149\\171\\231$,|j\\165\\018;A\\170\\142\\172\\232Z~\\238\\184\\235\\178\\\"\\025\\2015;\\146vq\\017\\153\\170\\168\\001\\130\\023\\022\\235\\162\\235\\218\\159\\234\\196B\\226\\158\\249)?\\\\Ev\\147=S\\026n<\\007Q\\1425\\\"A\\005_=\\220\\245\\178\\225$S\\1846\\156B\\014v\\173\\160\\251ln\\023?\\\"q\\170\\025\\236m\\184\\001\\001\\018a\\022\\005\\00056-\\152o \\197\\152\\229<=\\224\\184\\252A0\\004\\132$1r\\175\\137<\\201\\156\\161\\153\\170\\022\\022<\\240\\149\\030j8_\\180\\234\\139^,\\240\\232\\158T\\128z\\153\\147\\139\\n\\182\\156w\\241\\185\\178\\016\\160]\\021.7\\190\\250\\157\\128\\198(\\251\\139?\\127S\\022\\145,\\023T&\\160\\173\\154\\131\\219x\\bG\\2146\\241\\204\\171\\t\\224\\r6\\204+`v\\1941\\132\\004l\\n*\\006 \\133!VD\\254)T\\154bR\\002PU\\189\\251\\028k\\223#\\014\\192z\\145S\\025\\198\\006\\173\\147\\012A\\221\\127\\tr\\\"\\173\\162wjHNu_\\235-I\\028\\238\\128+\\234\\244\\221\\186\\243\\182\\150\\152h\\157~v\\182p\\202\\166]\\219\\217!\\151\\\"z\\176\\200\\223\\1866$\\181\\201\\141:\\136\\030\\170\\213`\\r\\137\\146\\r\\255\\131\\002Py\\210{\\222<\\234\\221\\020B[\\252\\138@\\211\\016\\192D\\022(\\001%\\025\\215o\\239\\001\\007CM\\197k\\177t\\231\\209a\\012\\222/\\200mj\\167+u\\173\\026\\205q\\200\\175\\225\\167\\025\\242\\229\\232?\\206yA\\251\\1541>+\\146bH\\n\\250hg]\\207\\171d\\178\\n\\229\\128\\t=$\\004\\006\\246hK1<\\228\\006i\\189[\\161\\200\\223>\\213<\\237/G<\\003z\\241\\154\\b\\154\\204\\148\\217\\195\\231\\189\\223f\\163#\\216+\\245E\\025\\187\\143/[\\221H\\254\\206\\180Z\\139\\222\\n\\167\\1609\\150\\161\\006B\\017\\181+\\195M&Xxu\\007$\\232\\213R\\174\\156\\232\\250\\229I,}\\020\\169\\230nu\\023\\206*\\018\\131\\\"j\\156\\211\\011\\147\\130\\151\\180\\001\\1770K \\166yd\\132<\\236\\003\\224\\226FW.\\\\\\137>\\220\\201\\145:\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\\001\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\000\\187*\\237\\202#z\\207\\025qG=3\\212[e\\143T\\238xc\\240\\169\\223S|\\147\\018\\n\\163\\181t\\027\";;\n","open Core_kernel\n\ntype uint64 = Unsigned.uint64\n\ntype uint32 = Unsigned.uint32\n\nmodule type S = sig\n type t [@@deriving sexp, hash, compare, yojson]\n\n val length_in_bits : int\n\n include Hashable.S with type t := t\n\n include Unsigned.S with type t := t\n\n val ( < ) : t -> t -> bool\n\n val ( > ) : t -> t -> bool\n\n val ( = ) : t -> t -> bool\n\n val ( <= ) : t -> t -> bool\n\n val ( >= ) : t -> t -> bool\n\n val to_bigint : t -> Bigint.t\nend\n\nmodule type F = functor\n (Unsigned : Unsigned.S)\n (M : sig\n val length : int\n end)\n -> S with type t = Unsigned.t\n[@@warning \"-67\"]\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Fold_lib\ninclude Intf\nmodule Intf = Intf\nopen Snark_bits\n\n[%%ifdef consensus_mechanism]\n\nmodule Make_checked\n (N : Unsigned_extended.S)\n (Bits : Bits_intf.Convertible_bits with type t := N.t) =\nstruct\n open Snark_params.Tick\n\n type var = Field.Var.t\n\n let () = assert (Int.(N.length_in_bits < Field.size_in_bits))\n\n let to_input (t : var) =\n Random_oracle.Input.Chunked.packed (t, N.length_in_bits)\n\n let to_input_legacy (t : var) =\n let to_bits (t : var) =\n with_label (sprintf \"to_bits: %s\" __LOC__) (fun () ->\n Field.Checked.choose_preimage_var t ~length:N.length_in_bits )\n in\n Checked.map (to_bits t) ~f:(fun bits ->\n Random_oracle.Input.Legacy.bitstring bits )\n\n let constant n =\n Field.Var.constant\n (Bigint.to_field (Bigint.of_bignum_bigint (N.to_bigint n)))\n\n let () = assert (Int.(N.length_in_bits mod 16 = 0))\n\n let range_check' (t : var) =\n let _, _, actual_packed =\n Pickles.Scalar_challenge.to_field_checked' ~num_bits:N.length_in_bits m\n (Kimchi_backend_common.Scalar_challenge.create t)\n in\n actual_packed\n\n let range_check t =\n let%bind actual = make_checked (fun () -> range_check' t) in\n Field.Checked.Assert.equal actual t\n\n let range_check_flag t =\n let open Pickles.Impls.Step in\n let actual = range_check' t in\n Field.equal actual t\n\n let of_field (x : Field.t) : N.t =\n let of_bits bs =\n (* TODO: Make this efficient *)\n List.foldi bs ~init:N.zero ~f:(fun i acc b ->\n if b then N.(logor (shift_left one i) acc) else acc )\n in\n of_bits (List.take (Field.unpack x) N.length_in_bits)\n\n let to_field (x : N.t) : Field.t = Field.project (Fold.to_list (Bits.fold x))\n\n let typ : (var, N.t) Typ.t =\n let (Typ field_typ) = Field.typ in\n Typ.transport\n (Typ { field_typ with check = range_check })\n ~there:to_field ~back:of_field\n\n let () = assert (N.length_in_bits * 2 < Field.size_in_bits + 1)\n\n let div_mod (x : var) (y : var) =\n let%bind q, r =\n exists (Typ.tuple2 typ typ)\n ~compute:\n As_prover.(\n let%map x = read typ x and y = read typ y in\n (N.div x y, N.rem x y))\n in\n\n (* q * y + r = x\n\n q * y = x - r\n *)\n let%map () = assert_r1cs q y (Field.Var.sub x r) in\n (q, r)\n\n type t = var\n\n let is_succ ~pred ~succ =\n let open Snark_params.Tick in\n let open Field in\n Checked.(equal (pred + Var.constant one) succ)\n\n let gte x y =\n let open Pickles.Impls.Step in\n let xy = Pickles.Util.seal m Field.(x - y) in\n let yx = Pickles.Util.seal m (Field.negate xy) in\n let x_gte_y = range_check_flag xy in\n let y_gte_x = range_check_flag yx in\n Boolean.Assert.any [ x_gte_y; y_gte_x ] ;\n x_gte_y\n\n let op op a b = make_checked (fun () -> op a b)\n\n let ( >= ) a b = op gte a b\n\n let ( <= ) a b = b >= a\n\n let ( < ) a b =\n make_checked (fun () ->\n let open Pickles.Impls.Step in\n Boolean.( &&& ) (gte b a) (Boolean.not (Field.equal b a)) )\n\n let ( > ) a b = b < a\n\n module Assert = struct\n let equal = Field.Checked.Assert.equal\n end\n\n let to_field = Fn.id\n\n module Unsafe = struct\n let of_field = Fn.id\n end\n\n let min a b =\n let%bind a_lte_b = a <= b in\n Field.Checked.if_ a_lte_b ~then_:a ~else_:b\n\n let if_ = Field.Checked.if_\n\n let succ_if (t : var) (c : Boolean.var) =\n Checked.return (Field.Var.add t (c :> Field.Var.t))\n\n let succ (t : var) =\n Checked.return (Field.Var.add t (Field.Var.constant Field.one))\n\n let seal x = make_checked (fun () -> Pickles.Util.seal m x)\n\n let add (x : var) (y : var) =\n let%bind res = seal (Field.Var.add x y) in\n let%map () = range_check res in\n res\n\n let mul (x : var) (y : var) =\n let%bind res = Field.Checked.mul x y in\n let%map () = range_check res in\n res\n\n let subtract_unpacking_or_zero x y =\n let open Pickles.Impls.Step in\n let res = Pickles.Util.seal m Field.(x - y) in\n let neg_res = Pickles.Util.seal m (Field.negate res) in\n let x_gte_y = range_check_flag res in\n let y_gte_x = range_check_flag neg_res in\n Boolean.Assert.any [ x_gte_y; y_gte_x ] ;\n (* If y_gte_x is false, then x_gte_y is true, so x >= y and\n thus there was no underflow.\n\n If y_gte_x is true, then y >= x, which means there was underflow\n iff y != x.\n\n Thus, underflow = (neg_res_good && y != x)\n *)\n let underflow = Boolean.( &&& ) y_gte_x (Boolean.not (Field.equal x y)) in\n (`Underflow underflow, Field.if_ underflow ~then_:Field.zero ~else_:res)\n\n let sub_or_zero a b = make_checked (fun () -> subtract_unpacking_or_zero a b)\n\n (* Unpacking protects against underflow *)\n let sub (x : var) (y : var) =\n let%bind res = seal (Field.Var.sub x y) in\n let%map () = range_check res in\n res\n\n let equal a b = Field.Checked.equal a b\n\n let ( = ) = equal\n\n let zero = Field.Var.constant Field.zero\nend\n\n[%%endif]\n\nopen Snark_params.Tick\n\nmodule Make (N : sig\n type t [@@deriving sexp, compare, hash]\n\n include Unsigned_extended.S with type t := t\n\n val random : unit -> t\nend)\n(Bits : Bits_intf.Convertible_bits with type t := N.t) =\nstruct\n type t = N.t [@@deriving sexp, compare, hash, yojson]\n\n (* can't be automatically derived *)\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n\n let max_value = N.max_int\n\n include Comparable.Make (N)\n\n include (N : module type of N with type t := t)\n\n let sub x y = if x < y then None else Some (N.sub x y)\n\n let to_field n = Bigint.to_field (Bigint.of_bignum_bigint (N.to_bigint n))\n\n [%%ifdef consensus_mechanism]\n\n module Checked = Make_checked (N) (Bits)\n\n (* warning: this typ does not work correctly with the generic if_ *)\n let typ = Checked.typ\n\n [%%endif]\n\n module Bits = Bits\n\n let to_bits = Bits.to_bits\n\n let of_bits = Bits.of_bits\n\n let to_input (t : t) =\n Random_oracle.Input.Chunked.packed (to_field t, N.length_in_bits)\n\n let to_input_legacy t = Random_oracle.Input.Legacy.bitstring (to_bits t)\n\n let fold t = Fold.group3 ~default:false (Bits.fold t)\n\n let gen =\n Quickcheck.Generator.map\n ~f:(fun n -> N.of_string (Bignum_bigint.to_string n))\n (Bignum_bigint.gen_incl Bignum_bigint.zero\n (Bignum_bigint.of_string N.(to_string max_int)) )\n\n let gen_incl min max =\n let open Quickcheck.Let_syntax in\n let%map n =\n Bignum_bigint.gen_incl\n (Bignum_bigint.of_string (N.to_string min))\n (Bignum_bigint.of_string (N.to_string max))\n in\n N.of_string (Bignum_bigint.to_string n)\nend\n\nmodule Make32 () : UInt32 = struct\n open Unsigned_extended\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = UInt32.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include\n Make\n (struct\n include UInt32\n\n let random () =\n let mask = if Random.bool () then one else zero in\n let open UInt32.Infix in\n logor (mask lsl 31)\n ( Int32.max_value |> Random.int32 |> Int64.of_int32\n |> UInt32.of_int64 )\n end)\n (Bits.UInt32)\n\n let to_uint32 = Unsigned_extended.UInt32.to_uint32\n\n let of_uint32 = Unsigned_extended.UInt32.of_uint32\nend\n\nmodule Make64 () : UInt64 = struct\n open Unsigned_extended\n\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = UInt64.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n include\n Make\n (struct\n include UInt64\n\n let random () =\n let mask = if Random.bool () then one else zero in\n let open UInt64.Infix in\n logor (mask lsl 63)\n (Int64.max_value |> Random.int64 |> UInt64.of_int64)\n end)\n (Bits.UInt64)\n\n let to_uint64 = Unsigned_extended.UInt64.to_uint64\n\n let of_uint64 = Unsigned_extended.UInt64.of_uint64\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Fold_lib\nopen Tuple_lib\nopen Unsigned\nopen Snark_bits\nopen Snark_params.Tick\n\nmodule type S_unchecked = sig\n type t [@@deriving sexp, compare, hash, yojson]\n\n include Comparable.S with type t := t\n\n include Hashable.S with type t := t\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n\n val max_value : t\n\n val length_in_bits : int\n\n val gen : t Quickcheck.Generator.t\n\n val gen_incl : t -> t -> t Quickcheck.Generator.t\n\n val zero : t\n\n val one : t\n\n val succ : t -> t\n\n val add : t -> t -> t\n\n val sub : t -> t -> t option\n\n val of_int : int -> t\n\n val to_int : t -> int\n\n (* Someday: I think this only does ones greater than zero, but it doesn't really matter for\n selecting the nonce *)\n\n val random : unit -> t\n\n val of_string : string -> t\n\n val to_string : t -> string\n\n module Bits : Bits_intf.Convertible_bits with type t := t\n\n val to_bits : t -> bool list\n\n val of_bits : bool list -> t\n\n val to_field : t -> Field.t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val to_input_legacy : t -> (_, bool) Random_oracle.Legacy.Input.t\n\n val fold : t -> bool Triple.t Fold.t\nend\n\n[%%ifdef consensus_mechanism]\n\nmodule type S_checked = sig\n type unchecked\n\n type var\n\n val constant : unchecked -> var\n\n type t = var\n\n val zero : t\n\n val succ : t -> t Checked.t\n\n val add : t -> t -> t Checked.t\n\n val mul : t -> t -> t Checked.t\n\n (** [sub_or_zero x y] computes [x - y].\n\n - If the argument to [`Underflow] is true, [x < y] and the returned integer\n value is pinned to [zero].\n - If the argument to [`Underflow] is false, [x >= y] and the returned\n integer value is equal to [x - y]\n *)\n val sub_or_zero : t -> t -> ([ `Underflow of Boolean.var ] * t) Checked.t\n\n (** [sub ~m x y] computes [x - y] and ensures that [0 <= x - y] *)\n val sub : t -> t -> t Checked.t\n\n val is_succ : pred:t -> succ:t -> Boolean.var Checked.t\n\n val min : t -> t -> t Checked.t\n\n val to_input : t -> Field.Var.t Random_oracle.Input.Chunked.t\n\n val to_input_legacy :\n t -> (_, Boolean.var) Random_oracle.Legacy.Input.t Checked.t\n\n val succ_if : t -> Boolean.var -> t Checked.t\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t Checked.t\n\n (** warning: this typ does not work correctly with the generic if_ *)\n val typ : (t, unchecked) Snark_params.Tick.Typ.t\n\n val equal : t -> t -> Boolean.var Checked.t\n\n val div_mod : t -> t -> (t * t) Checked.t\n\n val ( = ) : t -> t -> Boolean.var Checked.t\n\n val ( < ) : t -> t -> Boolean.var Checked.t\n\n val ( > ) : t -> t -> Boolean.var Checked.t\n\n val ( <= ) : t -> t -> Boolean.var Checked.t\n\n val ( >= ) : t -> t -> Boolean.var Checked.t\n\n module Assert : sig\n val equal : t -> t -> unit Checked.t\n end\n\n val to_field : t -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> t\n end\nend\n\n[%%endif]\n\nmodule type S = sig\n include S_unchecked\n\n [%%ifdef consensus_mechanism]\n\n module Checked : S_checked with type unchecked := t\n\n (** warning: this typ does not work correctly with the generic if_ *)\n val typ : (Checked.t, t) Snark_params.Tick.Typ.t\n\n [%%endif]\nend\n\nmodule type UInt32_A = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n include S with type t := t\n\n val to_uint32 : t -> uint32\n\n val of_uint32 : uint32 -> t\nend\n[@@warning \"-32\"]\n\nmodule type UInt32 = UInt32_A with type Stable.V1.t = Unsigned_extended.UInt32.t\n\nmodule type UInt64_A = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n include S with type t := Stable.Latest.t\n\n val to_uint64 : t -> uint64\n\n val of_uint64 : uint64 -> t\nend\n[@@warning \"-32\"]\n\nmodule type UInt64 = UInt64_A with type Stable.V1.t = Unsigned_extended.UInt64.t\n\nmodule type F = functor\n (N : sig\n type t [@@deriving bin_io, sexp, compare, hash]\n\n include Unsigned_extended.S with type t := t\n\n val random : unit -> t\n end)\n (Bits : Bits_intf.Convertible_bits with type t := N.t)\n -> S with type t := N.t and module Bits := Bits\n\n[%%ifdef consensus_mechanism]\n\nmodule type F_checked = functor\n (N : Unsigned_extended.S)\n (Bits : Bits_intf.Convertible_bits with type t := N.t)\n -> S_checked with type unchecked := N.t\n[@@warning \"-67\"]\n\n[%%endif]\n","include Nat.Make32 ()\n","module T = Nat.Make32 ()\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Account_nonce\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include Nat.Intf.UInt32_A with type Stable.V1.t = A.V1.t\n\n include Codable.S with type t := t\n end\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n include T\n\n (* while we could use an int encoding for yojson (an OCaml int is 63-bits)\n we've committed to a string encoding\n *)\n include Codable.Make_of_string (T)\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","module type S_base = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving hash, sexp, compare, equal, yojson]\n end\n end]\n\n val to_uint32 : t -> Unsigned.uint32\n\n val of_uint32 : Unsigned.uint32 -> t\n\n val to_string : t -> string\n\n val of_string : string -> t\n\n val gen : t Core_kernel.Quickcheck.Generator.t\n\n val gen_incl : t -> t -> t Core_kernel.Quickcheck.Generator.t\n\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n\n val zero : t\n\n val one : t\n\n val succ : t -> t\n\n val of_int : int -> t\n\n val to_int : t -> int\n\n val max_value : t\n\n val to_input : t -> Snark_params.Tick.Field.t Random_oracle.Input.Chunked.t\n\n val to_input_legacy : t -> ('a, bool) Random_oracle.Legacy.Input.t\n\n val to_field : t -> Snark_params.Tick.Field.t\n\n val random : unit -> t\n\n include Core_kernel.Comparable.S with type t := t\nend\n\nmodule type S = sig\n include S_base\n\n type global_slot_span\n\n module Checked : sig\n include Intf.S_checked with type unchecked := t\n\n type global_slot_span_checked\n\n open Snark_params.Tick\n\n val add : t -> global_slot_span_checked -> t Checked.t\n\n val sub : t -> global_slot_span_checked -> t Checked.t\n\n val diff : t -> t -> global_slot_span_checked Checked.t\n\n val diff_or_zero :\n t\n -> t\n -> ([ `Underflow of Boolean.var ] * global_slot_span_checked) Checked.t\n end\n\n val typ : (Checked.t, t) Snark_params.Tick.Typ.t\n\n val add : t -> global_slot_span -> t\n\n val sub : t -> global_slot_span -> t option\n\n val diff : t -> t -> global_slot_span option\nend\n\nmodule type S_span = sig\n include S_base\n\n module Checked : Intf.S_checked with type unchecked := t\n\n val typ : (Checked.t, t) Snark_params.Tick.Typ.t\n\n val add : t -> t -> t\n\n val sub : t -> t -> t option\nend\n","(** Legacy global slot implementation *)\n\n(* Used *only* for V1 payments, delegation valid_until field *)\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Global_slot_legacy\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Nat.Intf.UInt32_A with type Stable.V1.t = A.V1.t\nend\n\nmodule T = Nat.Make32 ()\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n include T\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","(** Global slot span implementation *)\n\nopen Core_kernel\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Global_slot_span\n\ntype uint32 = Unsigned.uint32\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include Global_slot_intf.S_span with type Stable.V1.t = A.V1.t\n end\nend\n\nmodule T = Nat.Make32 ()\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Wire_types.global_slot_span = Global_slot_span of T.Stable.V1.t\n [@@unboxed] [@@deriving hash, sexp, compare, equal]\n\n let to_latest = Fn.id\n\n let sexp_of_t (Global_slot_span u32) = Sexp.Atom (T.to_string u32)\n\n let t_of_sexp = function\n | Sexp.Atom i ->\n Global_slot_span (T.of_string i)\n | _ ->\n failwith \"Global_slot.of_sexp: Expected Atom\"\n\n let to_yojson (Global_slot_span t) = `String (T.to_string t)\n\n let of_yojson = function\n | `String s ->\n Ok (Global_slot_span (T.of_string s))\n | `List [ `String \"Global_slot_span\"; `String s ] ->\n Ok (Global_slot_span (T.of_string s))\n | _ ->\n Error \"Global_slot_span.of_yojson: expected string\"\n end\n end]\n\n let to_uint32 (Global_slot_span u32) : uint32 = u32\n\n let of_uint32 u32 : t = Global_slot_span u32\n\n module Checked = struct\n include T.Checked\n\n let constant t = constant @@ to_uint32 t\n\n let typ =\n Snark_params.Tick.Typ.transport T.Checked.typ ~there:to_uint32\n ~back:of_uint32\n end\n\n let sexp_of_t = Stable.Latest.sexp_of_t\n\n let t_of_sexp = Stable.Latest.t_of_sexp\n\n let to_yojson = Stable.Latest.to_yojson\n\n let of_yojson = Stable.Latest.of_yojson\n\n let to_string t = Unsigned.UInt32.to_string @@ to_uint32 t\n\n let of_string s = of_uint32 @@ Unsigned.UInt32.of_string s\n\n let typ = Checked.typ\n\n let gen =\n let%map.Quickcheck u32 = T.gen in\n of_uint32 u32\n\n let gen_incl t1 t2 =\n let u32_1 = to_uint32 t1 in\n let u32_2 = to_uint32 t2 in\n let%map.Quickcheck u32 = T.gen_incl u32_1 u32_2 in\n of_uint32 u32\n\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n\n let zero = of_uint32 T.zero\n\n let one = of_uint32 T.one\n\n let succ t = of_uint32 (T.succ @@ to_uint32 t)\n\n let max_value = of_uint32 Unsigned.UInt32.max_int\n\n let to_field t = T.to_field (to_uint32 t)\n\n let to_input t = T.to_input (to_uint32 t)\n\n let to_input_legacy t = T.to_input_legacy (to_uint32 t)\n\n include Comparable.Make (Stable.Latest)\n\n let add t1 t2 =\n let u32_1 = to_uint32 t1 in\n let u32_2 = to_uint32 t2 in\n let sum = T.add u32_1 u32_2 in\n of_uint32 sum\n\n let sub t1 t2 =\n let u32_1 = to_uint32 t1 in\n let u32_2 = to_uint32 t2 in\n Option.map (T.sub u32_1 u32_2) ~f:of_uint32\n\n let of_int n = of_uint32 (T.of_int n)\n\n let to_int t = T.to_int (to_uint32 t)\n\n let random () = of_uint32 (T.random ())\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\n\ntype uint32 = Unsigned.uint32\n\nmodule type S = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving sexp, compare]\n end\n end]\n\n module T : Intf.UInt32\n\n val to_uint32 : t -> uint32\n\n val of_uint32 : uint32 -> t\nend\n\nmodule Make (M : S) = struct\n type global_slot_span = Global_slot_span.t\n\n module T = M.T\n\n let to_uint32 = M.to_uint32\n\n let of_uint32 = M.of_uint32\n\n module Checked = struct\n include T.Checked\n\n type global_slot_span_checked = Global_slot_span.Checked.t\n\n let constant t = constant (to_uint32 t)\n\n open Snark_params.Tick\n\n let add t (span : global_slot_span_checked) =\n let t' = Global_slot_span.Checked.to_field span |> Unsafe.of_field in\n add t t'\n\n let sub t (span : global_slot_span_checked) =\n let t' = Global_slot_span.Checked.to_field span |> Unsafe.of_field in\n sub t t'\n\n let diff t1 t2 : global_slot_span_checked Checked.t =\n let%map diff = T.Checked.sub t1 t2 in\n let field = T.Checked.to_field diff in\n (* `of_field` is the identity function, here applied to a checked field *)\n Global_slot_span.Checked.Unsafe.of_field field\n\n let typ = Typ.transport T.Checked.typ ~there:to_uint32 ~back:of_uint32\n\n let diff_or_zero t1 t2 =\n let%map underflow, diff = T.Checked.sub_or_zero t1 t2 in\n let field = T.Checked.to_field diff in\n (* `of_field` is the identity function, here applied to a checked field *)\n let span = Global_slot_span.Checked.Unsafe.of_field field in\n (underflow, span)\n end\n\n let to_string t = Unsigned.UInt32.to_string @@ to_uint32 t\n\n let of_string s = of_uint32 @@ Unsigned.UInt32.of_string s\n\n let typ = Checked.typ\n\n let gen =\n let%map.Quickcheck u32 = T.gen in\n of_uint32 u32\n\n let gen_incl t1 t2 =\n let u32_1 = to_uint32 t1 in\n let u32_2 = to_uint32 t2 in\n let%map.Quickcheck u32 = T.gen_incl u32_1 u32_2 in\n of_uint32 u32\n\n let dhall_type = Ppx_dhall_type.Dhall_type.Text\n\n let zero = of_uint32 T.zero\n\n let one = of_uint32 T.one\n\n let succ t =\n let u32 = to_uint32 t in\n of_uint32 (T.succ u32)\n\n let max_value = of_uint32 Unsigned.UInt32.max_int\n\n let to_field t = T.to_field (to_uint32 t)\n\n let to_input t = T.to_input (to_uint32 t)\n\n let to_input_legacy t = T.to_input_legacy (to_uint32 t)\n\n include Comparable.Make (M.Stable.Latest)\n\n let add t span =\n let u32_slot = to_uint32 t in\n let u32_span = Global_slot_span.to_uint32 span in\n let u32_sum = T.add u32_slot u32_span in\n of_uint32 u32_sum\n\n let sub t span =\n let u32_slot = to_uint32 t in\n let u32_span = Global_slot_span.to_uint32 span in\n Option.map (T.sub u32_slot u32_span) ~f:of_uint32\n\n let diff t1 t2 =\n let u32_1 = to_uint32 t1 in\n let u32_2 = to_uint32 t2 in\n Option.map (T.sub u32_1 u32_2) ~f:Global_slot_span.of_uint32\n\n let of_int n = of_uint32 (T.of_int n)\n\n let to_int t = T.to_int (to_uint32 t)\n\n let random () = of_uint32 (T.random ())\nend\n","(** Global slot (since genesis) implementation *)\n\nopen Core_kernel\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Global_slot_since_genesis\n\ntype uint32 = Unsigned.uint32\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include\n Global_slot_intf.S\n with type Stable.V1.t = A.V1.t\n and type global_slot_span = Global_slot_span.t\n and type Checked.global_slot_span_checked = Global_slot_span.Checked.t\n end\nend\n\nmodule T = Nat.Make32 ()\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n module M = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Wire_types.global_slot = Since_genesis of T.Stable.V1.t\n [@@unboxed] [@@deriving hash, sexp, compare, equal]\n\n let to_latest = Fn.id\n\n let sexp_of_t (Since_genesis u32) = Sexp.Atom (T.to_string u32)\n\n let t_of_sexp = function\n | Sexp.Atom i ->\n Since_genesis (T.of_string i)\n | _ ->\n failwith \"Global_slot.of_sexp: Expected Atom\"\n\n let to_yojson (Since_genesis u32) = `String (T.to_string u32)\n\n let of_yojson = function\n | `String i ->\n Ok (Since_genesis (T.of_string i))\n | `List [ `String \"Since_genesis\"; `String i ] ->\n Ok (Since_genesis (T.of_string i))\n | _ ->\n Error \"Global_slot.of_yojson: Expected `String\"\n end\n end]\n\n module T = T\n\n let to_uint32 (Since_genesis u32) : uint32 = u32\n\n let of_uint32 u32 : t = Since_genesis u32\n\n let sexp_of_t = Stable.Latest.sexp_of_t\n\n let t_of_sexp = Stable.Latest.t_of_sexp\n\n let to_yojson = Stable.Latest.to_yojson\n\n let of_yojson = Stable.Latest.of_yojson\n end\n\n include M\n include Global_slot.Make (M)\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","(** Global slot (since hard fork) implementation *)\n\nopen Core_kernel\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Global_slot_since_hard_fork\n\ntype uint32 = Unsigned.uint32\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include\n Global_slot_intf.S\n with type Stable.V1.t = A.V1.t\n and type global_slot_span = Global_slot_span.t\n and type Checked.global_slot_span_checked = Global_slot_span.Checked.t\n end\nend\n\nmodule T = Nat.Make32 ()\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n module M = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Wire_types.global_slot = Since_hard_fork of T.Stable.V1.t\n [@@unboxed] [@@deriving hash, compare, equal]\n\n let to_latest = Fn.id\n\n let sexp_of_t (Since_hard_fork u32) = Sexp.Atom (T.to_string u32)\n\n let t_of_sexp = function\n | Sexp.Atom i ->\n Since_hard_fork (T.of_string i)\n | _ ->\n failwith \"Global_slot.of_sexp: Expected Atom\"\n\n let to_yojson (Since_hard_fork u32) = `String (T.to_string u32)\n\n let of_yojson = function\n | `String i ->\n Ok (Since_hard_fork (T.of_string i))\n | `List [ `String \"Since_hard_fork\"; `String i ] ->\n Ok (Since_hard_fork (T.of_string i))\n | _ ->\n Error \"Global_slot.of_yojson: Expected `String\"\n end\n end]\n\n module T = T\n\n let sexp_of_t = Stable.Latest.sexp_of_t\n\n let t_of_sexp = Stable.Latest.t_of_sexp\n\n let to_yojson = Stable.Latest.to_yojson\n\n let of_yojson = Stable.Latest.of_yojson\n\n let to_uint32 (Since_hard_fork u32) : uint32 = u32\n\n let of_uint32 u32 : t = Since_hard_fork u32\n end\n\n include M\n include Global_slot.Make (M)\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","module T = Nat.Make32 ()\n\ninclude T\ninclude Codable.Make_of_string (T)\n","module T = Nat.Make32 ()\n\nmodule Wire_types = Mina_wire_types.Mina_numbers.Index\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include Nat.Intf.UInt32_A with type Stable.V1.t = A.V1.t\n end\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n include T\n\n let to_bits = Bits.to_bits\n\n let of_bits = Bits.of_bits\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","module T = Nat.Make32 ()\n\n(** See documentation of the {!Mina_wire_types} library *)\nmodule Wire_types = Mina_wire_types.Mina_numbers.Length\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = sig\n include Nat.Intf.UInt32_A with type Stable.V1.t = A.V1.t\n end\nend\n\nmodule Make_str (_ : Wire_types.Concrete) = struct\n include T\n\n let to_bits = Bits.to_bits\n\n let of_bits = Bits.of_bits\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","module Account_nonce = Account_nonce\nmodule Length = Length\nmodule Index = Index\nmodule Nat = Nat\nmodule Global_slot_legacy = Global_slot_legacy\nmodule Global_slot_since_genesis = Global_slot_since_genesis\nmodule Global_slot_since_hard_fork = Global_slot_since_hard_fork\nmodule Global_slot_span = Global_slot_span\nmodule Hd_index = Hd_index\nmodule Zkapp_version = Zkapp_version\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_bits\nopen Snark_params.Tick\n\ntype uint64 = Unsigned.uint64\n\nmodule type Basic = sig\n type t [@@deriving sexp, compare, hash, yojson]\n\n type magnitude = t [@@deriving sexp, compare]\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n\n val max_int : t\n\n val length_in_bits : int\n\n include Comparable.S with type t := t\n\n val gen_incl : t -> t -> t Quickcheck.Generator.t\n\n val gen : t Quickcheck.Generator.t\n\n include Bits_intf.Convertible_bits with type t := t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val to_input_legacy : t -> (_, bool) Random_oracle.Legacy.Input.t\n\n val zero : t\n\n val one : t\n\n val of_string : string -> t\n\n val to_string : t -> string\n\n val of_mina_string_exn : string -> t\n\n val to_mina_string : t -> string\n\n val to_uint64 : t -> uint64\n\n val of_uint64 : uint64 -> t\n\n (* The functions below are unsafe, because they could overflow or\n underflow. They perform appropriate checks to guard against this\n and either raise Currency_overflow exception or return None\n depending on the error-handling strategy.\n\n It is advisable to use nanomina and mina wherever possible and\n limit the use of _exn veriants to places where a fixed value is\n being converted and hence overflow cannot happen. *)\n val of_mina_int_exn : int -> t\n\n val of_nanomina_int_exn : int -> t\n\n val of_mina_int : int -> t option\n\n val of_nanomina_int : int -> t option\n\n val to_mina_int : t -> int\n\n val to_nanomina_int : t -> int\n\n [%%ifdef consensus_mechanism]\n\n type var\n\n val typ : (var, t) Typ.t\n\n val var_of_t : t -> var\n\n val var_to_bits :\n var -> Boolean.var Bitstring_lib.Bitstring.Lsb_first.t Checked.t\n\n val var_to_input : var -> Field.Var.t Random_oracle.Input.Chunked.t\n\n val var_to_input_legacy :\n var -> (Field.Var.t, Boolean.var) Random_oracle.Input.Legacy.t Checked.t\n\n val equal_var : var -> var -> Boolean.var Checked.t\n\n val pack_var : var -> Field.Var.t\n\n [%%endif]\nend\n\nmodule type Arithmetic_intf = sig\n type t\n\n val add : t -> t -> t option\n\n val add_flagged : t -> t -> t * [ `Overflow of bool ]\n\n val sub : t -> t -> t option\n\n val sub_flagged : t -> t -> t * [ `Underflow of bool ]\n\n val ( + ) : t -> t -> t option\n\n val ( - ) : t -> t -> t option\n\n val scale : t -> int -> t option\nend\n\nmodule type Signed_intf = sig\n type magnitude\n\n type signed_fee\n\n [%%ifdef consensus_mechanism]\n\n type magnitude_var\n\n [%%endif]\n\n type t = (magnitude, Sgn.t) Signed_poly.t\n [@@deriving sexp, hash, compare, equal, yojson]\n\n val gen : t Quickcheck.Generator.t\n\n val create : magnitude:magnitude -> sgn:Sgn.t -> t\n\n val sgn : t -> Sgn.t\n\n val magnitude : t -> magnitude\n\n val zero : t\n\n val is_zero : t -> bool\n\n val is_positive : t -> bool\n\n val is_negative : t -> bool\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val to_input_legacy : t -> (_, bool) Random_oracle.Legacy.Input.t\n\n val add : t -> t -> t option\n\n val add_flagged : t -> t -> t * [ `Overflow of bool ]\n\n val ( + ) : t -> t -> t option\n\n val negate : t -> t\n\n val of_unsigned : magnitude -> t\n\n val to_fee : t -> signed_fee\n\n val of_fee : signed_fee -> t\n\n [%%ifdef consensus_mechanism]\n\n type var (* = (magnitude_var, Sgn.var) Signed_poly.t *)\n\n val create_var : magnitude:magnitude_var -> sgn:Sgn.var -> var\n\n val typ : (var, t) Typ.t\n\n module Checked : sig\n type signed_fee_var\n\n val constant : t -> var\n\n val of_unsigned : magnitude_var -> var\n\n val sgn : var -> Sgn.var Checked.t\n\n val magnitude : var -> magnitude_var Checked.t\n\n val negate : var -> var\n\n val if_ : Boolean.var -> then_:var -> else_:var -> var Checked.t\n\n val to_input : var -> Field.Var.t Random_oracle.Input.Chunked.t Checked.t\n\n val to_input_legacy :\n var -> (_, Boolean.var) Random_oracle.Legacy.Input.t Checked.t\n\n val add : var -> var -> var Checked.t\n\n val add_flagged :\n var -> var -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val assert_equal : var -> var -> unit Checked.t\n\n val equal : var -> var -> Boolean.var Checked.t\n\n val ( + ) : var -> var -> var Checked.t\n\n val to_field_var : var -> Field.Var.t Checked.t\n\n val to_fee : var -> signed_fee_var\n\n val of_fee : signed_fee_var -> var\n\n type t = var\n end\n\n [%%endif]\nend\n\n[%%ifdef consensus_mechanism]\n\nmodule type Checked_arithmetic_intf = sig\n type value\n\n type var\n\n type t = var\n\n type signed_var\n\n val if_ : Boolean.var -> then_:var -> else_:var -> var Checked.t\n\n val add : var -> var -> var Checked.t\n\n val sub : var -> var -> var Checked.t\n\n val sub_flagged :\n var -> var -> (var * [ `Underflow of Boolean.var ]) Checked.t\n\n val sub_or_zero : var -> var -> var Checked.t\n\n val add_flagged : var -> var -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val ( + ) : var -> var -> var Checked.t\n\n val ( - ) : var -> var -> var Checked.t\n\n val add_signed : var -> signed_var -> var Checked.t\n\n val add_signed_flagged :\n var -> signed_var -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val assert_equal : var -> var -> unit Checked.t\n\n val equal : var -> var -> Boolean.var Checked.t\n\n val ( = ) : t -> t -> Boolean.var Checked.t\n\n val ( < ) : t -> t -> Boolean.var Checked.t\n\n val ( > ) : t -> t -> Boolean.var Checked.t\n\n val ( <= ) : t -> t -> Boolean.var Checked.t\n\n val ( >= ) : t -> t -> Boolean.var Checked.t\n\n val scale : Field.Var.t -> var -> var Checked.t\nend\n\n[%%endif]\n\nmodule type S = sig\n include Basic\n\n include Arithmetic_intf with type t := t\n\n [%%ifdef consensus_mechanism]\n\n module Signed :\n Signed_intf with type magnitude := t and type magnitude_var := var\n\n module Checked :\n Checked_arithmetic_intf\n with type var := var\n and type signed_var := Signed.var\n and type value := t\n\n [%%else]\n\n module Signed : Signed_intf with type magnitude := t\n\n [%%endif]\n\n val add_signed_flagged : t -> Signed.t -> t * [ `Overflow of bool ]\nend\n\nmodule type Full = sig\n [%%ifdef consensus_mechanism]\n\n open Snark_params.Tick\n\n module Signed_var : sig\n type 'mag repr = ('mag, Sgn.var) Signed_poly.t\n\n (* Invariant: At least one of these is Some *)\n type nonrec 'mag t =\n { repr : 'mag repr; mutable value : Field.Var.t option }\n end\n\n [%%endif]\n\n module Signed_poly = Signed_poly\n\n module Fee : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t [@@deriving sexp, compare, hash, yojson, equal]\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n end\n end]\n\n include Basic with type t := Stable.Latest.t\n\n include Arithmetic_intf with type t := t\n\n include Codable.S with type t := t\n\n val minimum_user_command_fee : t\n\n val default_transaction_fee : t\n\n val default_snark_worker_fee : t\n\n (* TODO: Get rid of signed fee, use signed amount *)\n [%%ifdef consensus_mechanism]\n\n module Signed :\n Signed_intf\n with type magnitude := t\n and type magnitude_var := var\n and type signed_fee := (t, Sgn.t) Signed_poly.t\n and type Checked.signed_fee_var := Field.Var.t Signed_var.t\n\n [%%else]\n\n module Signed :\n Signed_intf\n with type magnitude := t\n and type signed_fee := (t, Sgn.t) Signed_poly.t\n\n [%%endif]\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n include\n Checked_arithmetic_intf\n with type var := var\n and type signed_var := Signed.var\n and type value := t\n\n val add_signed : var -> Signed.var -> var Checked.t\n end\n\n [%%endif]\n end\n [@@warning \"-32\"]\n\n module Amount : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n [@@@with_all_version_tags]\n\n type t [@@deriving sexp, compare, hash, equal, yojson]\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n end\n end]\n\n include Basic with type t := Stable.Latest.t\n\n include Arithmetic_intf with type t := t\n\n include Codable.S with type t := t\n\n [%%ifdef consensus_mechanism]\n\n module Signed :\n Signed_intf\n with type magnitude := t\n and type magnitude_var := var\n and type signed_fee := Fee.Signed.t\n and type Checked.signed_fee_var := Fee.Signed.Checked.t\n\n [%%else]\n\n module Signed :\n Signed_intf with type magnitude := t and type signed_fee := Fee.Signed.t\n\n [%%endif]\n\n (* TODO: Delete these functions *)\n\n val of_fee : Fee.t -> t\n\n val to_fee : t -> Fee.t\n\n val add_fee : t -> Fee.t -> t option\n\n val add_signed_flagged : t -> Signed.t -> t * [ `Overflow of bool ]\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n include\n Checked_arithmetic_intf\n with type var := var\n and type signed_var := Signed.var\n and type value := t\n\n val add_signed : var -> Signed.var -> var Checked.t\n\n val add_signed_flagged :\n var -> Signed.var -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val of_fee : Fee.var -> var\n\n val to_fee : var -> Fee.var\n\n val to_field : var -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> t\n end\n end\n\n [%%endif]\n end\n [@@warning \"-32\"]\n\n module Balance : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving sexp, compare, hash, yojson, equal]\n\n (* not automatically derived *)\n val dhall_type : Ppx_dhall_type.Dhall_type.t\n end\n end]\n\n include Basic with type t := Stable.Latest.t\n\n val to_amount : t -> Amount.t\n\n val add_amount : t -> Amount.t -> t option\n\n val add_amount_flagged : t -> Amount.t -> t * [ `Overflow of bool ]\n\n val sub_amount : t -> Amount.t -> t option\n\n val sub_amount_flagged : t -> Amount.t -> t * [ `Underflow of bool ]\n\n val add_signed_amount_flagged :\n t -> Amount.Signed.t -> t * [ `Overflow of bool ]\n\n val ( + ) : t -> Amount.t -> t option\n\n val ( - ) : t -> Amount.t -> t option\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n type t = var\n\n val to_amount : t -> Amount.var\n\n val add_signed_amount : var -> Amount.Signed.var -> var Checked.t\n\n val add_amount : var -> Amount.var -> var Checked.t\n\n val sub_amount : var -> Amount.var -> var Checked.t\n\n val sub_amount_flagged :\n var -> Amount.var -> (var * [ `Underflow of Boolean.var ]) Checked.t\n\n val add_amount_flagged :\n var -> Amount.var -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val add_signed_amount_flagged :\n var\n -> Amount.Signed.var\n -> (var * [ `Overflow of Boolean.var ]) Checked.t\n\n val sub_or_zero : var -> var -> var Checked.t\n\n val sub_amount_or_zero : var -> Amount.var -> var Checked.t\n\n val ( + ) : var -> Amount.var -> var Checked.t\n\n val ( - ) : var -> Amount.var -> var Checked.t\n\n val equal : var -> var -> Boolean.var Checked.t\n\n val ( = ) : var -> var -> Boolean.var Checked.t\n\n val ( < ) : var -> var -> Boolean.var Checked.t\n\n val ( > ) : var -> var -> Boolean.var Checked.t\n\n val ( <= ) : var -> var -> Boolean.var Checked.t\n\n val ( >= ) : var -> var -> Boolean.var Checked.t\n\n val if_ : Boolean.var -> then_:var -> else_:var -> var Checked.t\n\n val to_field : var -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> var\n end\n end\n\n [%%endif]\n end\n [@@warning \"-32\"]\n\n module Fee_rate : sig\n type t\n\n include Arithmetic_intf with type t := t\n\n include Comparable.S with type t := t\n\n include Sexpable.S with type t := t\n\n val of_q : Q.t -> t option\n\n val of_q_exn : Q.t -> t\n\n val to_q : t -> Q.t\n\n (** construct a fee rate from a fee and a weight *)\n val make : Fee.t -> int -> t option\n\n (** construct a fee rate from a fee and a weight *)\n val make_exn : Fee.t -> int -> t\n\n (** convert to uint64, if the fee rate is equivalent to an integer. *)\n val to_uint64 : t -> uint64 option\n\n (** convert to uint64, if the fee rate is equivalent to an integer. *)\n val to_uint64_exn : t -> uint64\n\n val mul : t -> t -> t option\n\n val scale_exn : t -> int -> t\n\n val div : t -> t -> t option\n\n val ( * ) : t -> t -> t option\n end\nend\n","(*\n RE - A regular expression library\n\n Copyright (C) 2001 Jerome Vouillon\n email: Jerome.Vouillon@pps.jussieu.fr\n\n This library is free software; you can redistribute it and/or\n modify it under the terms of the GNU Lesser General Public\n License as published by the Free Software Foundation, with\n linking exception; either version 2.1 of the License, or (at\n your option) any later version.\n\n This library is distributed in the hope that it will be useful,\n but WITHOUT ANY WARRANTY; without even the implied warranty of\n MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\n Lesser General Public License for more details.\n\n You should have received a copy of the GNU Lesser General Public\n License along with this library; if not, write to the Free Software\n Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA\n*)\n\nlet rec iter n f v = if n = 0 then v else iter (n - 1) f (f v)\n\n(****)\n\nlet unknown = -2\nlet break = -3\n\ntype match_info =\n | Match of Group.t\n | Failed\n | Running\n\ntype state =\n { idx : int;\n (* Index of the current position in the position table.\n Not yet computed transitions point to a dummy state where\n [idx] is set to [unknown];\n If [idx] is set to [break] for states that either always\n succeed or always fail. *)\n real_idx : int;\n (* The real index, in case [idx] is set to [break] *)\n next : state array;\n (* Transition table, indexed by color *)\n mutable final :\n (Category.t *\n (Automata.idx * Automata.status)) list;\n (* Mapping from the category of the next character to\n - the index where the next position should be saved\n - possibly, the list of marks (and the corresponding indices)\n corresponding to the best match *)\n desc : Automata.State.t\n (* Description of this state of the automata *) }\n\n(* Automata (compiled regular expression) *)\ntype re =\n { initial : Automata.expr;\n (* The whole regular expression *)\n mutable initial_states : (Category.t * state) list;\n (* Initial states, indexed by initial category *)\n colors : Bytes.t;\n (* Color table *)\n color_repr : Bytes.t;\n (* Table from colors to one character of this color *)\n ncolor : int;\n (* Number of colors. *)\n lnl : int;\n (* Color of the last newline. -1 if unnecessary *)\n tbl : Automata.working_area;\n (* Temporary table used to compute the first available index\n when computing a new state *)\n states : state Automata.State.Table.t;\n (* States of the deterministic automata *)\n group_count : int\n (* Number of groups in the regular expression *) }\n\nlet pp_re ch re = Automata.pp ch re.initial\n\nlet print_re = pp_re\n\n(* Information used during matching *)\ntype info =\n { re : re;\n (* The automata *)\n colors : Bytes.t;\n (* Color table ([x.colors = x.re.colors])\n Shortcut used for performance reasons *)\n mutable positions : int array;\n (* Array of mark positions\n The mark are off by one for performance reasons *)\n pos : int;\n (* Position where the match is started *)\n last : int\n (* Position where the match should stop *) }\n\n\n(****)\n\nlet category re ~color =\n if color = -1 then\n Category.inexistant\n (* Special category for the last newline *)\n else if color = re.lnl then\n Category.(lastnewline ++ newline ++ not_letter)\n else\n Category.from_char (Bytes.get re.color_repr color)\n\n(****)\n\nlet dummy_next = [||]\n\nlet unknown_state =\n { idx = unknown; real_idx = 0;\n next = dummy_next; final = [];\n desc = Automata.State.dummy }\n\nlet mk_state ncol desc =\n let break_state =\n match Automata.status desc with\n | Automata.Running -> false\n | Automata.Failed\n | Automata.Match _ -> true\n in\n { idx = if break_state then break else desc.Automata.State.idx;\n real_idx = desc.Automata.State.idx;\n next = if break_state then dummy_next else Array.make ncol unknown_state;\n final = [];\n desc }\n\nlet find_state re desc =\n try\n Automata.State.Table.find re.states desc\n with Not_found ->\n let st = mk_state re.ncolor desc in\n Automata.State.Table.add re.states desc st;\n st\n\n(**** Match with marks ****)\n\nlet delta info cat ~color st =\n let desc = Automata.delta info.re.tbl cat color st.desc in\n let len = Array.length info.positions in\n if desc.Automata.State.idx = len && len > 0 then begin\n let pos = info.positions in\n info.positions <- Array.make (2 * len) 0;\n Array.blit pos 0 info.positions 0 len\n end;\n desc\n\nlet validate info (s:string) ~pos st =\n let color = Char.code (Bytes.get info.colors (Char.code s.[pos])) in\n let cat = category info.re ~color in\n let desc' = delta info cat ~color st in\n let st' = find_state info.re desc' in\n st.next.(color) <- st'\n\n(*\nlet rec loop info s pos st =\n if pos < info.last then\n let st' = st.next.(Char.code info.cols.[Char.code s.[pos]]) in\n let idx = st'.idx in\n if idx >= 0 then begin\n info.positions.(idx) <- pos;\n loop info s (pos + 1) st'\n end else if idx = break then begin\n info.positions.(st'.real_idx) <- pos;\n st'\n end else begin (* Unknown *)\n validate info s pos st;\n loop info s pos st\n end\n else\n st\n*)\n\nlet rec loop info (s:string) ~pos st =\n if pos < info.last then\n let st' = st.next.(Char.code (Bytes.get info.colors (Char.code s.[pos]))) in\n loop2 info s ~pos st st'\n else\n st\n\nand loop2 info s ~pos st st' =\n if st'.idx >= 0 then begin\n let pos = pos + 1 in\n if pos < info.last then begin\n (* It is important to place these reads before the write *)\n (* But then, we don't have enough registers left to store the\n right position. So, we store the position plus one. *)\n let st'' =\n st'.next.(Char.code (Bytes.get info.colors (Char.code s.[pos]))) in\n info.positions.(st'.idx) <- pos;\n loop2 info s ~pos st' st''\n end else begin\n info.positions.(st'.idx) <- pos;\n st'\n end\n end else if st'.idx = break then begin\n info.positions.(st'.real_idx) <- pos + 1;\n st'\n end else begin (* Unknown *)\n validate info s ~pos st;\n loop info s ~pos st\n end\n\nlet rec loop_no_mark info s ~pos ~last st =\n if pos < last then\n let st' = st.next.(Char.code (Bytes.get info.colors (Char.code s.[pos]))) in\n if st'.idx >= 0 then\n loop_no_mark info s ~pos:(pos + 1) ~last st'\n else if st'.idx = break then\n st'\n else begin (* Unknown *)\n validate info s ~pos st;\n loop_no_mark info s ~pos ~last st\n end\n else\n st\n\nlet final info st cat =\n try\n List.assq cat st.final\n with Not_found ->\n let st' = delta info cat ~color:(-1) st in\n let res = (st'.Automata.State.idx, Automata.status st') in\n st.final <- (cat, res) :: st.final;\n res\n\nlet find_initial_state re cat =\n try\n List.assq cat re.initial_states\n with Not_found ->\n let st = find_state re (Automata.State.create cat re.initial) in\n re.initial_states <- (cat, st) :: re.initial_states;\n st\n\nlet get_color re (s:string) pos =\n if pos < 0 then\n -1\n else\n let slen = String.length s in\n if pos >= slen then\n -1\n else if pos = slen - 1 && re.lnl <> -1 && s.[pos] = '\\n' then\n (* Special case for the last newline *)\n re.lnl\n else\n Char.code (Bytes.get re.colors (Char.code s.[pos]))\n\nlet rec handle_last_newline info ~pos st ~groups =\n let st' = st.next.(info.re.lnl) in\n if st'.idx >= 0 then begin\n if groups then info.positions.(st'.idx) <- pos + 1;\n st'\n end else if st'.idx = break then begin\n if groups then info.positions.(st'.real_idx) <- pos + 1;\n st'\n end else begin (* Unknown *)\n let color = info.re.lnl in\n let real_c = Char.code (Bytes.get info.colors (Char.code '\\n')) in\n let cat = category info.re ~color in\n let desc' = delta info cat ~color:real_c st in\n let st' = find_state info.re desc' in\n st.next.(color) <- st';\n handle_last_newline info ~pos st ~groups\n end\n\nlet rec scan_str info (s:string) initial_state ~groups =\n let pos = info.pos in\n let last = info.last in\n if (last = String.length s\n && info.re.lnl <> -1\n && last > pos\n && String.get s (last - 1) = '\\n')\n then begin\n let info = { info with last = last - 1 } in\n let st = scan_str info s initial_state ~groups in\n if st.idx = break then\n st\n else\n handle_last_newline info ~pos:(last - 1) st ~groups\n end else if groups then\n loop info s ~pos initial_state\n else\n loop_no_mark info s ~pos ~last initial_state\n\nlet match_str ~groups ~partial re s ~pos ~len =\n let slen = String.length s in\n let last = if len = -1 then slen else pos + len in\n let info =\n { re ; colors = re.colors; pos ; last\n ; positions =\n if groups then begin\n let n = Automata.index_count re.tbl + 1 in\n if n <= 10 then\n [|0;0;0;0;0;0;0;0;0;0|]\n else\n Array.make n 0\n end else\n [||] }\n in\n let initial_cat =\n if pos = 0 then\n Category.(search_boundary ++ inexistant)\n else\n Category.(search_boundary\n ++ category re ~color:(get_color re s (pos - 1)))\n in\n let initial_state = find_initial_state re initial_cat in\n let st = scan_str info s initial_state ~groups in\n let res =\n if st.idx = break || partial then\n Automata.status st.desc\n else\n let final_cat =\n if last = slen then\n Category.(search_boundary ++ inexistant)\n else\n Category.(search_boundary ++ category re ~color:(get_color re s last))\n in\n let (idx, res) = final info st final_cat in\n if groups then info.positions.(idx) <- last + 1;\n res\n in\n match res with\n Automata.Match (marks, pmarks) ->\n Match { s ; marks; pmarks ; gpos = info.positions; gcount = re.group_count}\n | Automata.Failed -> Failed\n | Automata.Running -> Running\n\nlet mk_re ~initial ~colors ~color_repr ~ncolor ~lnl ~group_count =\n { initial ;\n initial_states = [];\n colors;\n color_repr;\n ncolor;\n lnl;\n tbl = Automata.create_working_area ();\n states = Automata.State.Table.create 97;\n group_count }\n\n(**** Character sets ****)\n\nlet cseq c c' = Cset.seq (Char.code c) (Char.code c')\nlet cadd c s = Cset.add (Char.code c) s\n\nlet trans_set cache cm s =\n match Cset.one_char s with\n | Some i -> Cset.csingle (Bytes.get cm i)\n | None ->\n let v = (Cset.hash_rec s, s) in\n try\n Cset.CSetMap.find v !cache\n with Not_found ->\n let l =\n Cset.fold_right\n s\n ~f:(fun (i, j) l -> Cset.union (cseq (Bytes.get cm i)\n (Bytes.get cm j)) l)\n ~init:Cset.empty\n in\n cache := Cset.CSetMap.add v l !cache;\n l\n\n(****)\n\ntype regexp =\n Set of Cset.t\n | Sequence of regexp list\n | Alternative of regexp list\n | Repeat of regexp * int * int option\n | Beg_of_line | End_of_line\n | Beg_of_word | End_of_word | Not_bound\n | Beg_of_str | End_of_str\n | Last_end_of_line | Start | Stop\n | Sem of Automata.sem * regexp\n | Sem_greedy of Automata.rep_kind * regexp\n | Group of regexp | No_group of regexp | Nest of regexp\n | Case of regexp | No_case of regexp\n | Intersection of regexp list\n | Complement of regexp list\n | Difference of regexp * regexp\n | Pmark of Pmark.t * regexp\n\nmodule View = struct\n type t = regexp =\n Set of Cset.t\n | Sequence of regexp list\n | Alternative of regexp list\n | Repeat of regexp * int * int option\n | Beg_of_line | End_of_line\n | Beg_of_word | End_of_word | Not_bound\n | Beg_of_str | End_of_str\n | Last_end_of_line | Start | Stop\n | Sem of Automata.sem * regexp\n | Sem_greedy of Automata.rep_kind * regexp\n | Group of regexp | No_group of regexp | Nest of regexp\n | Case of regexp | No_case of regexp\n | Intersection of regexp list\n | Complement of regexp list\n | Difference of regexp * regexp\n | Pmark of Pmark.t * regexp\n\n let view t = t\nend\n\nlet rec pp fmt t =\n let open Fmt in\n let var s re = sexp fmt s pp re in\n let seq s rel = sexp fmt s (list pp) rel in\n match t with\n | Set s -> sexp fmt \"Set\" Cset.pp s\n | Sequence sq -> seq \"Sequence\" sq\n | Alternative alt -> seq \"Alternative\" alt\n | Repeat (re, start, stop) ->\n let pp' fmt () = fprintf fmt \"%a@ %d%a\" pp re start optint stop in\n sexp fmt \"Repeat\" pp' ()\n | Beg_of_line -> str fmt \"Beg_of_line\"\n | End_of_line -> str fmt \"End_of_line\"\n | Beg_of_word -> str fmt \"Beg_of_word\"\n | End_of_word -> str fmt \"End_of_word\"\n | Not_bound -> str fmt \"Not_bound\"\n | Beg_of_str -> str fmt \"Beg_of_str\"\n | End_of_str -> str fmt \"End_of_str\"\n | Last_end_of_line -> str fmt \"Last_end_of_line\"\n | Start -> str fmt \"Start\"\n | Stop -> str fmt \"Stop\"\n | Sem (sem, re) ->\n sexp fmt \"Sem\" (pair Automata.pp_sem pp) (sem, re)\n | Sem_greedy (k, re) ->\n sexp fmt \"Sem_greedy\" (pair Automata.pp_rep_kind pp) (k, re)\n | Group c -> var \"Group\" c\n | No_group c -> var \"No_group\" c\n | Nest c -> var \"Nest\" c\n | Case c -> var \"Case\" c\n | No_case c -> var \"No_case\" c\n | Intersection c -> seq \"Intersection\" c\n | Complement c -> seq \"Complement\" c\n | Difference (a, b) -> sexp fmt \"Difference\" (pair pp pp) (a, b)\n | Pmark (m, r) -> sexp fmt \"Pmark\" (pair Pmark.pp pp) (m, r)\n\nlet rec is_charset = function\n | Set _ ->\n true\n | Alternative l | Intersection l | Complement l ->\n List.for_all is_charset l\n | Difference (r, r') ->\n is_charset r && is_charset r'\n | Sem (_, r) | Sem_greedy (_, r)\n | No_group r | Case r | No_case r ->\n is_charset r\n | Sequence _ | Repeat _ | Beg_of_line | End_of_line\n | Beg_of_word | End_of_word | Beg_of_str | End_of_str\n | Not_bound | Last_end_of_line | Start | Stop\n | Group _ | Nest _ | Pmark (_,_)->\n false\n\n(*XXX Use a better algorithm allowing non-contiguous regions? *)\n\nlet cupper =\n Cset.union (cseq 'A' 'Z')\n (Cset.union (cseq '\\192' '\\214') (cseq '\\216' '\\222'))\nlet clower = Cset.offset 32 cupper\nlet calpha =\n List.fold_right cadd ['\\170'; '\\181'; '\\186'; '\\223'; '\\255']\n (Cset.union clower cupper)\nlet cdigit = cseq '0' '9'\nlet calnum = Cset.union calpha cdigit\nlet cword = cadd '_' calnum\n\nlet colorize c regexp =\n let lnl = ref false in\n let rec colorize regexp =\n match regexp with\n Set s -> Color_map.split s c\n | Sequence l -> List.iter colorize l\n | Alternative l -> List.iter colorize l\n | Repeat (r, _, _) -> colorize r\n | Beg_of_line | End_of_line -> Color_map.split (Cset.csingle '\\n') c\n | Beg_of_word | End_of_word\n | Not_bound -> Color_map.split cword c\n | Beg_of_str | End_of_str\n | Start | Stop -> ()\n | Last_end_of_line -> lnl := true\n | Sem (_, r)\n | Sem_greedy (_, r)\n | Group r | No_group r\n | Nest r | Pmark (_,r) -> colorize r\n | Case _ | No_case _\n | Intersection _\n | Complement _\n | Difference _ -> assert false\n in\n colorize regexp;\n !lnl\n\n(**** Compilation ****)\n\nlet rec equal x1 x2 =\n match x1, x2 with\n Set s1, Set s2 ->\n s1 = s2\n | Sequence l1, Sequence l2 ->\n eq_list l1 l2\n | Alternative l1, Alternative l2 ->\n eq_list l1 l2\n | Repeat (x1', i1, j1), Repeat (x2', i2, j2) ->\n i1 = i2 && j1 = j2 && equal x1' x2'\n | Beg_of_line, Beg_of_line\n | End_of_line, End_of_line\n | Beg_of_word, Beg_of_word\n | End_of_word, End_of_word\n | Not_bound, Not_bound\n | Beg_of_str, Beg_of_str\n | End_of_str, End_of_str\n | Last_end_of_line, Last_end_of_line\n | Start, Start\n | Stop, Stop ->\n true\n | Sem (sem1, x1'), Sem (sem2, x2') ->\n sem1 = sem2 && equal x1' x2'\n | Sem_greedy (k1, x1'), Sem_greedy (k2, x2') ->\n k1 = k2 && equal x1' x2'\n | Group _, Group _ -> (* Do not merge groups! *)\n false\n | No_group x1', No_group x2' ->\n equal x1' x2'\n | Nest x1', Nest x2' ->\n equal x1' x2'\n | Case x1', Case x2' ->\n equal x1' x2'\n | No_case x1', No_case x2' ->\n equal x1' x2'\n | Intersection l1, Intersection l2 ->\n eq_list l1 l2\n | Complement l1, Complement l2 ->\n eq_list l1 l2\n | Difference (x1', x1''), Difference (x2', x2'') ->\n equal x1' x2' && equal x1'' x2''\n | Pmark (m1, r1), Pmark (m2, r2) ->\n Pmark.equal m1 m2 && equal r1 r2\n | _ ->\n false\n\nand eq_list l1 l2 =\n match l1, l2 with\n [], [] ->\n true\n | x1 :: r1, x2 :: r2 ->\n equal x1 x2 && eq_list r1 r2\n | _ ->\n false\n\nlet sequence = function\n | [x] -> x\n | l -> Sequence l\n\nlet rec merge_sequences = function\n | [] ->\n []\n | Alternative l' :: r ->\n merge_sequences (l' @ r)\n | Sequence (x :: y) :: r ->\n begin match merge_sequences r with\n Sequence (x' :: y') :: r' when equal x x' ->\n Sequence [x; Alternative [sequence y; sequence y']] :: r'\n | r' ->\n Sequence (x :: y) :: r'\n end\n | x :: r ->\n x :: merge_sequences r\n\nmodule A = Automata\n\nlet enforce_kind ids kind kind' cr =\n match kind, kind' with\n `First, `First -> cr\n | `First, k -> A.seq ids k cr (A.eps ids)\n | _ -> cr\n\n(* XXX should probably compute a category mask *)\nlet rec translate ids kind ign_group ign_case greedy pos cache c = function\n | Set s ->\n (A.cst ids (trans_set cache c s), kind)\n | Sequence l ->\n (trans_seq ids kind ign_group ign_case greedy pos cache c l, kind)\n | Alternative l ->\n begin match merge_sequences l with\n [r'] ->\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy pos cache c r' in\n (enforce_kind ids kind kind' cr, kind)\n | merged_sequences ->\n (A.alt ids\n (List.map\n (fun r' ->\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy\n pos cache c r' in\n enforce_kind ids kind kind' cr)\n merged_sequences),\n kind)\n end\n | Repeat (r', i, j) ->\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy pos cache c r' in\n let rem =\n match j with\n None ->\n A.rep ids greedy kind' cr\n | Some j ->\n let f =\n match greedy with\n `Greedy ->\n fun rem ->\n A.alt ids\n [A.seq ids kind' (A.rename ids cr) rem; A.eps ids]\n | `Non_greedy ->\n fun rem ->\n A.alt ids\n [A.eps ids; A.seq ids kind' (A.rename ids cr) rem]\n in\n iter (j - i) f (A.eps ids)\n in\n (iter i (fun rem -> A.seq ids kind' (A.rename ids cr) rem) rem, kind)\n | Beg_of_line ->\n (A.after ids Category.(inexistant ++ newline), kind)\n | End_of_line ->\n (A.before ids Category.(inexistant ++ newline), kind)\n | Beg_of_word ->\n (A.seq ids `First\n (A.after ids Category.(inexistant ++ not_letter))\n (A.before ids Category.(inexistant ++ letter)),\n kind)\n | End_of_word ->\n (A.seq ids `First\n (A.after ids Category.(inexistant ++ letter))\n (A.before ids Category.(inexistant ++ not_letter)),\n kind)\n | Not_bound ->\n (A.alt ids [A.seq ids `First\n (A.after ids Category.letter)\n (A.before ids Category.letter);\n A.seq ids `First\n (A.after ids Category.letter)\n (A.before ids Category.letter)],\n kind)\n | Beg_of_str ->\n (A.after ids Category.inexistant, kind)\n | End_of_str ->\n (A.before ids Category.inexistant, kind)\n | Last_end_of_line ->\n (A.before ids Category.(inexistant ++ lastnewline), kind)\n | Start ->\n (A.after ids Category.search_boundary, kind)\n | Stop ->\n (A.before ids Category.search_boundary, kind)\n | Sem (kind', r') ->\n let (cr, kind'') =\n translate ids kind' ign_group ign_case greedy pos cache c r' in\n (enforce_kind ids kind' kind'' cr,\n kind')\n | Sem_greedy (greedy', r') ->\n translate ids kind ign_group ign_case greedy' pos cache c r'\n | Group r' ->\n if ign_group then\n translate ids kind ign_group ign_case greedy pos cache c r'\n else\n let p = !pos in\n pos := !pos + 2;\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy pos cache c r' in\n (A.seq ids `First (A.mark ids p) (\n A.seq ids `First cr (A.mark ids (p + 1))),\n kind')\n | No_group r' ->\n translate ids kind true ign_case greedy pos cache c r'\n | Nest r' ->\n let b = !pos in\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy pos cache c r'\n in\n let e = !pos - 1 in\n if e < b then\n (cr, kind')\n else\n (A.seq ids `First (A.erase ids b e) cr, kind')\n | Difference _ | Complement _ | Intersection _ | No_case _ | Case _ ->\n assert false\n | Pmark (i, r') ->\n let (cr, kind') =\n translate ids kind ign_group ign_case greedy pos cache c r' in\n (A.seq ids `First (A.pmark ids i) cr, kind')\n\nand trans_seq ids kind ign_group ign_case greedy pos cache c = function\n | [] ->\n A.eps ids\n | [r] ->\n let (cr', kind') =\n translate ids kind ign_group ign_case greedy pos cache c r in\n enforce_kind ids kind kind' cr'\n | r :: rem ->\n let (cr', kind') =\n translate ids kind ign_group ign_case greedy pos cache c r in\n let cr'' =\n trans_seq ids kind ign_group ign_case greedy pos cache c rem in\n if A.is_eps cr'' then\n cr'\n else if A.is_eps cr' then\n cr''\n else\n A.seq ids kind' cr' cr''\n\n(**** Case ****)\n\nlet case_insens s =\n Cset.union s (Cset.union (Cset.offset 32 (Cset.inter s cupper))\n (Cset.offset (-32) (Cset.inter s clower)))\n\nlet as_set = function\n | Set s -> s\n | _ -> assert false\n\n(* XXX Should split alternatives into (1) charsets and (2) more\n complex regular expressions; alternative should therefore probably\n be flatten here *)\nlet rec handle_case ign_case = function\n | Set s ->\n Set (if ign_case then case_insens s else s)\n | Sequence l ->\n Sequence (List.map (handle_case ign_case) l)\n | Alternative l ->\n let l' = List.map (handle_case ign_case) l in\n if is_charset (Alternative l') then\n Set (List.fold_left (fun s r -> Cset.union s (as_set r)) Cset.empty l')\n else\n Alternative l'\n | Repeat (r, i, j) ->\n Repeat (handle_case ign_case r, i, j)\n | Beg_of_line | End_of_line | Beg_of_word | End_of_word | Not_bound\n | Beg_of_str | End_of_str | Last_end_of_line | Start | Stop as r ->\n r\n | Sem (k, r) ->\n let r' = handle_case ign_case r in\n if is_charset r' then r' else Sem (k, r')\n | Sem_greedy (k, r) ->\n let r' = handle_case ign_case r in\n if is_charset r' then r' else Sem_greedy (k, r')\n | Group r ->\n Group (handle_case ign_case r)\n | No_group r ->\n let r' = handle_case ign_case r in\n if is_charset r' then r' else No_group r'\n | Nest r ->\n let r' = handle_case ign_case r in\n if is_charset r' then r' else Nest r'\n | Case r ->\n handle_case false r\n | No_case r ->\n handle_case true r\n | Intersection l ->\n let l' = List.map (fun r -> handle_case ign_case r) l in\n Set (List.fold_left (fun s r -> Cset.inter s (as_set r)) Cset.cany l')\n | Complement l ->\n let l' = List.map (fun r -> handle_case ign_case r) l in\n Set (Cset.diff Cset.cany\n (List.fold_left (fun s r -> Cset.union s (as_set r))\n Cset.empty l'))\n | Difference (r, r') ->\n Set (Cset.inter (as_set (handle_case ign_case r))\n (Cset.diff Cset.cany (as_set (handle_case ign_case r'))))\n | Pmark (i,r) -> Pmark (i,handle_case ign_case r)\n\n(****)\n\nlet compile_1 regexp =\n let regexp = handle_case false regexp in\n let c = Color_map.make () in\n let need_lnl = colorize c regexp in\n let (colors, color_repr, ncolor) = Color_map.flatten c in\n let lnl = if need_lnl then ncolor else -1 in\n let ncolor = if need_lnl then ncolor + 1 else ncolor in\n let ids = A.create_ids () in\n let pos = ref 0 in\n let (r, kind) =\n translate ids\n `First false false `Greedy pos (ref Cset.CSetMap.empty) colors regexp in\n let r = enforce_kind ids `First kind r in\n (*Format.eprintf \"<%d %d>@.\" !ids ncol;*)\n mk_re ~initial:r ~colors ~color_repr ~ncolor ~lnl ~group_count:(!pos / 2)\n\n(****)\n\nlet rec anchored = function\n | Sequence l ->\n List.exists anchored l\n | Alternative l ->\n List.for_all anchored l\n | Repeat (r, i, _) ->\n i > 0 && anchored r\n | Set _ | Beg_of_line | End_of_line | Beg_of_word | End_of_word\n | Not_bound | End_of_str | Last_end_of_line | Stop\n | Intersection _ | Complement _ | Difference _ ->\n false\n | Beg_of_str | Start ->\n true\n | Sem (_, r) | Sem_greedy (_, r) | Group r | No_group r | Nest r\n | Case r | No_case r | Pmark (_, r) ->\n anchored r\n\n(****)\n\ntype t = regexp\n\nlet str s =\n let l = ref [] in\n for i = String.length s - 1 downto 0 do\n l := Set (Cset.csingle s.[i]) :: !l\n done;\n Sequence !l\nlet char c = Set (Cset.csingle c)\n\nlet alt = function\n | [r] -> r\n | l -> Alternative l\nlet seq = function\n | [r] -> r\n | l -> Sequence l\n\nlet empty = alt []\nlet epsilon = seq []\nlet repn r i j =\n if i < 0 then invalid_arg \"Re.repn\";\n begin match j with\n | Some j when j < i -> invalid_arg \"Re.repn\"\n | _ -> ()\n end;\n Repeat (r, i, j)\nlet rep r = repn r 0 None\nlet rep1 r = repn r 1 None\nlet opt r = repn r 0 (Some 1)\nlet bol = Beg_of_line\nlet eol = End_of_line\nlet bow = Beg_of_word\nlet eow = End_of_word\nlet word r = seq [bow; r; eow]\nlet not_boundary = Not_bound\nlet bos = Beg_of_str\nlet eos = End_of_str\nlet whole_string r = seq [bos; r; eos]\nlet leol = Last_end_of_line\nlet start = Start\nlet stop = Stop\nlet longest r = Sem (`Longest, r)\nlet shortest r = Sem (`Shortest, r)\nlet first r = Sem (`First, r)\nlet greedy r = Sem_greedy (`Greedy, r)\nlet non_greedy r = Sem_greedy (`Non_greedy, r)\nlet group r = Group r\nlet no_group r = No_group r\nlet nest r = Nest r\nlet mark r = let i = Pmark.gen () in (i,Pmark (i,r))\n\nlet set str =\n let s = ref Cset.empty in\n for i = 0 to String.length str - 1 do\n s := Cset.union (Cset.csingle str.[i]) !s\n done;\n Set !s\n\nlet rg c c' = Set (cseq c c')\n\nlet inter l =\n let r = Intersection l in\n if is_charset r then\n r\n else\n invalid_arg \"Re.inter\"\n\nlet compl l =\n let r = Complement l in\n if is_charset r then\n r\n else\n invalid_arg \"Re.compl\"\n\nlet diff r r' =\n let r'' = Difference (r, r') in\n if is_charset r'' then\n r''\n else\n invalid_arg \"Re.diff\"\n\nlet any = Set Cset.cany\nlet notnl = Set (Cset.diff Cset.cany (Cset.csingle '\\n'))\n\nlet lower = alt [rg 'a' 'z'; char '\\181'; rg '\\223' '\\246'; rg '\\248' '\\255']\nlet upper = alt [rg 'A' 'Z'; rg '\\192' '\\214'; rg '\\216' '\\222']\nlet alpha = alt [lower; upper; char '\\170'; char '\\186']\nlet digit = rg '0' '9'\nlet alnum = alt [alpha; digit]\nlet wordc = alt [alnum; char '_']\nlet ascii = rg '\\000' '\\127'\nlet blank = set \"\\t \"\nlet cntrl = alt [rg '\\000' '\\031'; rg '\\127' '\\159']\nlet graph = alt [rg '\\033' '\\126'; rg '\\160' '\\255']\nlet print = alt [rg '\\032' '\\126'; rg '\\160' '\\255']\nlet punct =\n alt [rg '\\033' '\\047'; rg '\\058' '\\064'; rg '\\091' '\\096';\n rg '\\123' '\\126'; rg '\\160' '\\169'; rg '\\171' '\\180';\n rg '\\182' '\\185'; rg '\\187' '\\191'; char '\\215'; char '\\247']\nlet space = alt [char ' '; rg '\\009' '\\013']\nlet xdigit = alt [digit; rg 'a' 'f'; rg 'A' 'F']\n\nlet case r = Case r\nlet no_case r = No_case r\n\n(****)\n\nlet compile r =\n compile_1 (\n if anchored r then\n group r\n else\n seq [shortest (rep any); group r]\n )\n\nlet exec_internal name ?(pos=0) ?(len = -1) ~partial ~groups re s =\n if pos < 0 || len < -1 || pos + len > String.length s then\n invalid_arg name;\n match_str ~groups ~partial re s ~pos ~len\n\nlet exec ?pos ?len re s =\n match exec_internal \"Re.exec\" ?pos ?len ~groups:true ~partial:false re s with\n Match substr -> substr\n | _ -> raise Not_found\n\nlet exec_opt ?pos ?len re s =\n match exec_internal \"Re.exec_opt\" ?pos ?len ~groups:true ~partial:false\n re s with\n Match substr -> Some substr\n | _ -> None\n\nlet execp ?pos ?len re s =\n match exec_internal ~groups:false ~partial:false \"Re.execp\" ?pos ?len re s with\n Match _substr -> true\n | _ -> false\n\nlet exec_partial ?pos ?len re s =\n match exec_internal ~groups:false ~partial:true \"Re.exec_partial\"\n ?pos ?len re s with\n Match _ -> `Full\n | Running -> `Partial\n | Failed -> `Mismatch\n\nmodule Mark = struct\n\n type t = Pmark.t\n\n let test (g : Group.t) p =\n Pmark.Set.mem p g.pmarks\n\n let all (g : Group.t) = g.pmarks\n\n module Set = Pmark.Set\n\n let equal = Pmark.equal\n\n let compare = Pmark.compare\n\nend\n\ntype split_token =\n [ `Text of string\n | `Delim of Group.t\n ]\n\nmodule Rseq = struct\n let all ?(pos=0) ?len re s : _ Seq.t =\n if pos < 0 then invalid_arg \"Re.all\";\n (* index of the first position we do not consider.\n !pos < limit is an invariant *)\n let limit = match len with\n | None -> String.length s\n | Some l ->\n if l<0 || pos+l > String.length s then invalid_arg \"Re.all\";\n pos+l\n in\n (* iterate on matches. When a match is found, search for the next\n one just after its end *)\n let rec aux pos () =\n if pos >= limit\n then Seq.Nil (* no more matches *)\n else\n match match_str ~groups:true ~partial:false re s\n ~pos ~len:(limit - pos) with\n | Match substr ->\n let p1, p2 = Group.offset substr 0 in\n let pos = if p1=p2 then p2+1 else p2 in\n Seq.Cons (substr, aux pos)\n | Running\n | Failed -> Seq.Nil\n in\n aux pos\n\n let matches ?pos ?len re s : _ Seq.t =\n all ?pos ?len re s\n |> Seq.map (fun sub -> Group.get sub 0)\n\n let split_full ?(pos=0) ?len re s : _ Seq.t =\n if pos < 0 then invalid_arg \"Re.split\";\n let limit = match len with\n | None -> String.length s\n | Some l ->\n if l<0 || pos+l > String.length s then invalid_arg \"Re.split\";\n pos+l\n in\n (* i: start of delimited string\n pos: first position after last match of [re]\n limit: first index we ignore (!pos < limit is an invariant) *)\n let pos0 = pos in\n let rec aux state i pos () = match state with\n | `Idle when pos >= limit ->\n if i < limit then (\n let sub = String.sub s i (limit - i) in\n Seq.Cons (`Text sub, aux state (i+1) pos)\n ) else Seq.Nil\n | `Idle ->\n begin match match_str ~groups:true ~partial:false re s ~pos\n ~len:(limit - pos) with\n | Match substr ->\n let p1, p2 = Group.offset substr 0 in\n let pos = if p1=p2 then p2+1 else p2 in\n let old_i = i in\n let i = p2 in\n if p1 > pos0 then (\n (* string does not start by a delimiter *)\n let text = String.sub s old_i (p1 - old_i) in\n let state = `Yield (`Delim substr) in\n Seq.Cons (`Text text, aux state i pos)\n ) else Seq.Cons (`Delim substr, aux state i pos)\n | Running -> Seq.Nil\n | Failed ->\n if i < limit\n then (\n let text = String.sub s i (limit - i) in\n (* yield last string *)\n Seq.Cons (`Text text, aux state limit pos)\n ) else\n Seq.Nil\n end\n | `Yield x ->\n Seq.Cons (x, aux `Idle i pos)\n in\n aux `Idle pos pos\n\n let split ?pos ?len re s : _ Seq.t =\n let seq = split_full ?pos ?len re s in\n let rec filter seq () = match seq () with\n | Seq.Nil -> Seq.Nil\n | Seq.Cons (`Delim _, tl) -> filter tl ()\n | Seq.Cons (`Text s,tl) -> Seq.Cons (s, filter tl)\n in filter seq\nend\n\nmodule Rlist = struct\n let list_of_seq (s:'a Seq.t) : 'a list =\n Seq.fold_left (fun l x -> x :: l) [] s |> List.rev\n\n let all ?pos ?len re s = Rseq.all ?pos ?len re s |> list_of_seq\n\n let matches ?pos ?len re s = Rseq.matches ?pos ?len re s |> list_of_seq\n\n let split_full ?pos ?len re s = Rseq.split_full ?pos ?len re s |> list_of_seq\n\n let split ?pos ?len re s = Rseq.split ?pos ?len re s |> list_of_seq\nend\n\nmodule Gen = struct\n type 'a gen = unit -> 'a option\n let gen_of_seq (s:'a Seq.t) : 'a gen =\n let r = ref s in\n fun () -> match !r () with\n | Seq.Nil -> None\n | Seq.Cons (x, tl) ->\n r := tl;\n Some x\n\n let split ?pos ?len re s : _ gen =\n Rseq.split ?pos ?len re s |> gen_of_seq\n\n let split_full ?pos ?len re s : _ gen =\n Rseq.split_full ?pos ?len re s |> gen_of_seq\n\n let all ?pos ?len re s = Rseq.all ?pos ?len re s |> gen_of_seq\n\n let matches ?pos ?len re s = Rseq.matches ?pos ?len re s |> gen_of_seq\nend\n\nlet replace ?(pos=0) ?len ?(all=true) re ~f s =\n if pos < 0 then invalid_arg \"Re.replace\";\n let limit = match len with\n | None -> String.length s\n | Some l ->\n if l<0 || pos+l > String.length s then invalid_arg \"Re.replace\";\n pos+l\n in\n (* buffer into which we write the result *)\n let buf = Buffer.create (String.length s) in\n (* iterate on matched substrings. *)\n let rec iter pos =\n if pos < limit\n then\n match match_str ~groups:true ~partial:false re s ~pos ~len:(limit-pos) with\n | Match substr ->\n let p1, p2 = Group.offset substr 0 in\n (* add string between previous match and current match *)\n Buffer.add_substring buf s pos (p1-pos);\n (* what should we replace the matched group with? *)\n let replacing = f substr in\n Buffer.add_string buf replacing;\n if all then\n (* if we matched a non-char e.g. ^ we must manually advance by 1 *)\n iter (\n if p1=p2 then (\n (* a non char could be past the end of string. e.g. $ *)\n if p2 < limit then Buffer.add_char buf s.[p2];\n p2+1\n ) else\n p2)\n else\n Buffer.add_substring buf s p2 (limit-p2)\n | Running -> ()\n | Failed ->\n Buffer.add_substring buf s pos (limit-pos)\n in\n iter pos;\n Buffer.contents buf\n\nlet replace_string ?pos ?len ?all re ~by s =\n replace ?pos ?len ?all re s ~f:(fun _ -> by)\n\nlet witness t =\n let rec witness = function\n | Set c -> String.make 1 (Char.chr (Cset.pick c))\n | Sequence xs -> String.concat \"\" (List.map witness xs)\n | Alternative (x :: _) -> witness x\n | Alternative [] -> assert false\n | Repeat (r, from, _to) ->\n let w = witness r in\n let b = Buffer.create (String.length w * from) in\n for _i=1 to from do\n Buffer.add_string b w\n done;\n Buffer.contents b\n | No_case r -> witness r\n | Intersection _\n | Complement _\n | Difference (_, _) -> assert false\n | Group r\n | No_group r\n | Nest r\n | Sem (_, r)\n | Pmark (_, r)\n | Case r\n | Sem_greedy (_, r) -> witness r\n | Beg_of_line\n | End_of_line\n | Beg_of_word\n | End_of_word\n | Not_bound\n | Beg_of_str\n | Last_end_of_line\n | Start\n | Stop\n | End_of_str -> \"\" in\n witness (handle_case false t)\n\ntype 'a seq = 'a Seq.t\nmodule Seq = Rseq\nmodule List = Rlist\nmodule Group = Group\n\n(** {2 Deprecated functions} *)\n\ntype 'a gen = 'a Gen.gen\nlet all_gen = Gen.all\nlet matches_gen = Gen.matches\nlet split_gen = Gen.split\nlet split_full_gen = Gen.split_full\n\nlet all_seq = Seq.all\nlet matches_seq = Seq.matches\nlet split_seq = Seq.split\nlet split_full_seq = Seq.split_full\n\n\ntype substrings = Group.t\n\nlet get = Group.get\nlet get_ofs = Group.offset\nlet get_all = Group.all\nlet get_all_ofs = Group.all_offset\nlet test = Group.test\n\ntype markid = Mark.t\n\nlet marked = Mark.test\nlet mark_set = Mark.all\n\n(**********************************)\n\n(*\nInformation about the previous character:\n- does not exists\n- is a letter\n- is not a letter\n- is a newline\n- is last newline\n\nBeginning of word:\n- previous is not a letter or does not exist\n- current is a letter or does not exist\n\nEnd of word:\n- previous is a letter or does not exist\n- current is not a letter or does not exist\n\nBeginning of line:\n- previous is a newline or does not exist\n\nBeginning of buffer:\n- previous does not exist\n\nEnd of buffer\n- current does not exist\n\nEnd of line\n- current is a newline or does not exist\n*)\n\n(*\nRep: e = T,e | ()\n - semantics of the comma (shortest/longest/first)\n - semantics of the union (greedy/non-greedy)\n\nBounded repetition\n a{0,3} = (a,(a,a?)?)?\n*)\n\ntype groups = Group.t\n\ninclude Rlist\n","include Ast\n\nlet string_of_pos (pos : Lexing.position) =\n Format.sprintf \"Line %d col %d\" pos.pos_lnum (pos.pos_cnum - pos.pos_bol + 1)\n\nlet parse s =\n let lexbuf = Lexing.from_string s in\n try Ok (Parser.doc Lexer.token lexbuf) with\n | Parser.Error ->\n let pos = lexbuf.lex_start_p in\n Error (Format.sprintf \"%s: Syntax error\" (string_of_pos pos))\n | Lexer.Error msg ->\n let pos = lexbuf.lex_curr_p in\n Error (Format.sprintf \"%s: %s\" (string_of_pos pos) msg)\n","open Core_kernel\nopen Fieldslib\n\nmodule Js_layout = struct\n module Input = struct\n type 'a t =\n < js_layout : [> `Assoc of (string * Yojson.Safe.t) list ] ref ; .. >\n as\n 'a\n end\n\n module Accumulator = struct\n type field = { key : string; value : Yojson.Safe.t; docs : Yojson.Safe.t }\n\n let to_key ({ key; _ } : field) = `String key\n\n let to_entry ({ key; value; _ } : field) : string * Yojson.Safe.t =\n (key, value)\n\n let to_doc_entry ({ key; docs; _ } : field) : string * Yojson.Safe.t =\n (key, docs)\n\n type 'a t = < js_layout_accumulator : field option list ref ; .. > as 'a\n constraint 'a t = 'a Input.t\n end\n\n let docs (s : Fields_derivers.Annotations.Fields.T.t) : Yojson.Safe.t =\n match s.doc with Some t -> `String t | None -> `Null\n\n let add_field ~t_fields_annots t_field field (acc : _ Accumulator.t) :\n _ * _ Accumulator.t =\n let annotations =\n Fields_derivers.Annotations.Fields.of_annots t_fields_annots\n (Field.name field)\n in\n let rest = !(acc#js_layout_accumulator) in\n let key =\n Option.value annotations.name\n ~default:(Fields_derivers.name_under_to_camel field)\n in\n let value = !(t_field#js_layout) in\n let new_field =\n if annotations.skip || !(t_field#skip) then None\n else Some Accumulator.{ key; value; docs = docs annotations }\n in\n acc#js_layout_accumulator := new_field :: rest ;\n ((fun _ -> failwith \"Unused\"), acc)\n\n let finish name ~t_toplevel_annots (_creator, obj) =\n let annotations =\n Fields_derivers.Annotations.Top.of_annots ~name t_toplevel_annots\n in\n let accumulator =\n List.filter_map ~f:Fn.id !(obj#js_layout_accumulator) |> List.rev\n in\n obj#js_layout :=\n `Assoc\n [ (\"type\", `String \"object\")\n ; (\"name\", `String annotations.name)\n ; ( \"docs\"\n , match annotations.doc with Some s -> `String s | None -> `Null )\n ; (\"keys\", `List (List.map ~f:Accumulator.to_key accumulator))\n ; (\"entries\", `Assoc (List.map ~f:Accumulator.to_entry accumulator))\n ; ( \"docEntries\"\n , `Assoc (List.map ~f:Accumulator.to_doc_entry accumulator) )\n ] ;\n obj\n\n type leaf_type =\n | String\n | Number\n | Null\n | Field\n | Bool\n | UInt32\n | UInt64\n | PublicKey\n | Sign\n | Custom of string\n\n let leaf_type_to_string = function\n | String ->\n \"string\"\n | Number ->\n \"number\"\n | Null ->\n \"null\"\n | Field ->\n \"Field\"\n | Bool ->\n \"Bool\"\n | UInt32 ->\n \"UInt32\"\n | UInt64 ->\n \"UInt64\"\n | PublicKey ->\n \"PublicKey\"\n | Sign ->\n \"Sign\"\n | Custom s ->\n s\n\n type option_type =\n | Flagged_option\n | Closed_interval of (string * string)\n | Or_undefined\n\n let leaf_type (s : leaf_type) =\n `Assoc [ (\"type\", `String (leaf_type_to_string s)) ]\n\n let of_layout layout obj =\n obj#js_layout := layout ;\n obj\n\n let skip obj =\n obj#skip := true ;\n obj#js_layout := leaf_type Null ;\n obj\n\n let int obj =\n obj#js_layout := leaf_type Number ;\n obj\n\n let string obj =\n obj#js_layout := leaf_type String ;\n obj\n\n let bool obj =\n obj#js_layout := leaf_type Bool ;\n obj\n\n let list ?static_length x obj : _ Input.t =\n let inner = !(x#js_layout) in\n let static_length =\n match static_length with Some length -> `Int length | None -> `Null\n in\n obj#js_layout :=\n `Assoc\n [ (\"type\", `String \"array\")\n ; (\"inner\", inner)\n ; (\"staticLength\", static_length)\n ] ;\n obj\n\n let record (entries : (string * 'a) list) (obj : _ Input.t) : _ Input.t =\n obj#js_layout :=\n `Assoc\n [ (\"type\", `String \"object\")\n ; (\"name\", `String \"Anonymous\")\n ; (\"docs\", `Null)\n ; (\"keys\", `List (List.map ~f:(fun (key, _) -> `String key) entries))\n ; ( \"entries\"\n , `Assoc (List.map ~f:(fun (key, inner) -> (key, inner)) entries) )\n ; ( \"docEntries\"\n , `Assoc (List.map ~f:(fun (key, _) -> (key, `String \"\")) entries) )\n ] ;\n obj\n\n let option x obj ~(js_type : option_type) : _ Input.t =\n let inner = !(x#js_layout) in\n let layout =\n match js_type with\n | Flagged_option ->\n `Assoc\n [ (\"type\", `String \"option\")\n ; (\"optionType\", `String \"flaggedOption\")\n ; (\"inner\", inner)\n ]\n | Closed_interval (min, max) ->\n `Assoc\n [ (\"type\", `String \"option\")\n ; (\"optionType\", `String \"closedInterval\")\n ; (\"rangeMin\", `String min)\n ; (\"rangeMax\", `String max)\n ; (\"inner\", inner)\n ]\n | Or_undefined ->\n `Assoc\n [ (\"type\", `String \"option\")\n ; (\"optionType\", `String \"orUndefined\")\n ; (\"inner\", inner)\n ]\n in\n obj#js_layout := layout ;\n obj\n\n let wrapped x obj =\n obj#js_layout := !(x#js_layout) ;\n obj\n\n let needs_custom_js ~name (x : _ Input.t) (obj : _ Input.t) =\n match !(obj#js_layout) with\n | `Assoc layout ->\n obj#js_layout :=\n `Assoc\n ( layout\n @ [ (\"checkedType\", !(x#js_layout))\n ; (\"checkedTypeName\", `String name)\n ] ) ;\n obj\n | _ ->\n failwith \"impossible\"\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_bits\n\n[%%endif]\n\nmodule type Data_hash_descriptor = sig\n val version_byte : char\n\n val description : string\nend\n\nmodule type Basic = sig\n type t = Field.t [@@deriving sexp, yojson]\n\n val to_decimal_string : t -> string\n\n val of_decimal_string : string -> t\n\n val to_bytes : t -> string\n\n [%%ifdef consensus_mechanism]\n\n val gen : t Quickcheck.Generator.t\n\n type var\n\n val var_to_hash_packed : var -> Random_oracle.Checked.Digest.t\n\n val var_to_input : var -> Field.Var.t Random_oracle.Input.Chunked.t\n\n val var_to_bits : var -> Boolean.var list Checked.t\n\n val typ : (var, t) Typ.t\n\n val assert_equal : var -> var -> unit Checked.t\n\n val equal_var : var -> var -> Boolean.var Checked.t\n\n val var_of_t : t -> var\n\n (* TODO : define bit ops using Random_oracle instead of Pedersen.Digest,\n move this outside of consensus_mechanism guard\n *)\n include Bits_intf.S with type t := t\n\n [%%endif]\n\n val to_base58_check : t -> string\n\n val of_base58_check : string -> t Base.Or_error.t\n\n val of_base58_check_exn : string -> t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\nend\n\nmodule type Full_size = sig\n include Basic\n\n include Comparable.S with type t := t\n\n include Hashable with type t := t\n\n [%%ifdef consensus_mechanism]\n\n val if_ : Boolean.var -> then_:var -> else_:var -> var Checked.t\n\n val var_of_hash_packed : Random_oracle.Checked.Digest.t -> var\n\n val var_to_field : var -> Random_oracle.Checked.Digest.t\n\n [%%endif]\n\n val of_hash : Field.t -> t\n\n val to_field : t -> Field.t\nend\n","module type S = sig\n open Async_kernel\n open Core_kernel\n open Snark_params\n open Snark_bits\n\n module Time : sig\n type t [@@deriving sexp, compare, yojson]\n\n val zero : t\n\n val max_value : t\n\n include Comparable.S with type t := t\n\n include Hashable.S with type t := t\n\n module Controller : sig\n type t [@@deriving sexp, equal, compare]\n\n val create : t -> t\n\n val basic : logger:Logger.t -> t\n\n (** Override the time offset set by the [MINA_TIME_OFFSET] environment\n variable for all block time controllers.\n [enable_setting_offset] must have been called first, and\n [disable_setting_offset] must not have been called, otherwise this\n raises a [Failure].\n *)\n val set_time_offset : Time.Span.t -> unit\n\n (** Get the current time offset, either from the [MINA_TIME_OFFSET]\n environment variable, or as last set by [set_time_offset].\n *)\n val get_time_offset : logger:Logger.t -> Time.Span.t\n\n (** Disallow setting the time offset. This should be run at every\n entrypoint which does not explicitly need to update the time offset.\n *)\n val disable_setting_offset : unit -> unit\n\n (** Allow setting the time offset. This may only be run if\n [disable_setting_offset] has not already been called, otherwise it will\n raise a [Failure].\n *)\n val enable_setting_offset : unit -> unit\n end\n\n [%%versioned:\n module Stable : sig\n [@@@no_toplevel_latest_type]\n\n module V1 : sig\n type nonrec t = t [@@deriving sexp, compare, equal, hash, yojson]\n\n include Hashable.S with type t := t\n end\n end]\n\n module Bits : Bits_intf.Convertible_bits with type t := t\n\n include\n Tick.Snarkable.Bits.Faithful\n with type Unpacked.value = t\n and type Packed.value = t\n and type Packed.var = private Tick.Field.Var.t\n\n val to_input : t -> Tick.Field.t Random_oracle_input.Chunked.t\n\n module Checked : sig\n open Snark_params.Tick\n\n type t\n\n val typ : (t, Stable.Latest.t) Typ.t\n\n val to_input : t -> Field.Var.t Random_oracle_input.Chunked.t\n\n val ( = ) : t -> t -> Boolean.var Checked.t\n\n val ( < ) : t -> t -> Boolean.var Checked.t\n\n val ( > ) : t -> t -> Boolean.var Checked.t\n\n val ( <= ) : t -> t -> Boolean.var Checked.t\n\n val ( >= ) : t -> t -> Boolean.var Checked.t\n\n val to_field : t -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> t\n end\n end\n\n module Span : sig\n type t [@@deriving sexp, compare, equal, yojson]\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving bin_io, equal, sexp, compare, hash, yojson, version]\n end\n end\n\n val of_time_span : Time.Span.t -> t\n\n val to_time_span : t -> Time.Span.t\n\n module Bits : Bits_intf.Convertible_bits with type t := t\n\n include\n Tick.Snarkable.Bits.Faithful\n with type Unpacked.value = t\n and type Packed.value = t\n\n val to_time_ns_span : t -> Core_kernel.Time_ns.Span.t\n\n val of_time_ns_span : Core_kernel.Time_ns.Span.t -> t\n\n val to_string_hum : t -> string\n\n val to_ms : t -> Int64.t\n\n val of_ms : Int64.t -> t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val ( * ) : t -> t -> t\n\n val ( < ) : t -> t -> bool\n\n val ( > ) : t -> t -> bool\n\n val ( = ) : t -> t -> bool\n\n val ( <= ) : t -> t -> bool\n\n val ( >= ) : t -> t -> bool\n\n val min : t -> t -> t\n\n val zero : t\n\n val to_input : t -> Tick.Field.t Random_oracle_input.Chunked.t\n\n module Checked : sig\n type t\n\n val typ : (t, Stable.V1.t) Snark_params.Tick.Typ.t\n\n open Snark_params.Tick\n\n val to_input : t -> Tick.Field.Var.t Random_oracle_input.Chunked.t\n\n val to_field : t -> Field.Var.t\n\n module Unsafe : sig\n val of_field : Field.Var.t -> t\n end\n end\n end\n\n val field_var_to_unpacked : Tick.Field.Var.t -> Unpacked.var Tick.Checked.t\n\n val diff_checked :\n Unpacked.var -> Unpacked.var -> Span.Unpacked.var Tick.Checked.t\n\n val unpacked_to_number : Span.Unpacked.var -> Tick.Number.t\n\n val add : t -> Span.t -> t\n\n val diff : t -> t -> Span.t\n\n val sub : t -> Span.t -> t\n\n val to_span_since_epoch : t -> Span.t\n\n val of_span_since_epoch : Span.t -> t\n\n val modulus : t -> Span.t -> Span.t\n\n val of_time : Time.t -> t\n\n val to_time_exn : t -> Time.t\n\n val now : Controller.t -> t\n\n val to_int64 : t -> Int64.t\n\n val of_int64 : Int64.t -> t\n\n val of_uint64 : Unsigned.UInt64.t -> t\n\n val to_uint64 : t -> Unsigned.UInt64.t\n\n val of_time_ns : Time_ns.t -> t\n\n val to_string_exn : t -> string\n\n (** Strip time offset *)\n val to_string_system_time_exn : Controller.t -> t -> string\n\n (** Strip time offset *)\n val to_system_time : Controller.t -> t -> t\n\n val of_string_exn : string -> t\n\n val gen_incl : t -> t -> t Quickcheck.Generator.t\n\n val gen : t Quickcheck.Generator.t\n end\n\n include module type of Time with type t = Time.t\n\n module Timeout : sig\n type 'a t\n\n type time\n\n val create : Controller.t -> Span.t -> f:(time -> 'a) -> 'a t\n\n val to_deferred : 'a t -> 'a Async_kernel.Deferred.t\n\n val peek : 'a t -> 'a option\n\n val cancel : Controller.t -> 'a t -> 'a -> unit\n\n val remaining_time : 'a t -> Span.t\n\n val await :\n timeout_duration:Span.t\n -> Controller.t\n -> 'a Deferred.t\n -> [ `Ok of 'a | `Timeout ] Deferred.t\n\n val await_exn :\n timeout_duration:Span.t -> Controller.t -> 'a Deferred.t -> 'a Deferred.t\n end\n with type time := t\nend\n","(* quickcheck_lib.ml *)\n\nopen Core_kernel\nopen Quickcheck.Generator\nopen Quickcheck.Let_syntax\n\nlet of_array array = Quickcheck.Generator.of_list @@ Array.to_list array\n\nlet rec map_gens ls ~f =\n match ls with\n | [] ->\n return []\n | h :: t ->\n let%bind h' = f h in\n let%map t' = map_gens t ~f in\n h' :: t'\n\nlet replicate_gen g n = map_gens (List.init n ~f:Fn.id) ~f:(Fn.const g)\n\nlet init_gen ~f n =\n let rec go : 'a list -> int -> 'a list Quickcheck.Generator.t =\n fun xs n' ->\n if n' < n then f n' >>= fun x -> go (x :: xs) (n' + 1)\n else return @@ List.rev xs\n in\n go [] 0\n\nlet init_gen_array ~f n = map ~f:Array.of_list @@ init_gen ~f n\n\nlet gen_pair g =\n let%map a = g and b = g in\n (a, b)\n\nlet shuffle_arr_inplace arr =\n (* Fisher-Yates shuffle, you need fast swaps for decent performance, so we\n want an array if we're not getting unnecessarily fancy. *)\n let rec go n =\n if n < Array.length arr then (\n let%bind swap_idx = Int.gen_uniform_incl n (Array.length arr - 1) in\n Array.swap arr n swap_idx ;\n go (n + 1) )\n else return arr\n in\n go 0\n\nlet shuffle_arr arr = shuffle_arr_inplace @@ Array.copy arr\n\nlet shuffle list =\n Array.of_list list |> shuffle_arr_inplace |> map ~f:Array.to_list\n\n(* Generate a list with a Dirichlet distribution, used for coming up with random\n splits of a quantity. Symmetric Dirichlet distribution with alpha = 1.\n*)\nlet gen_symm_dirichlet : int -> float list Quickcheck.Generator.t =\n fun n ->\n let open Quickcheck.Generator.Let_syntax in\n let%map gammas =\n map_gens\n (List.init n ~f:(Fn.const ()))\n ~f:(fun _ ->\n let open Quickcheck.Generator.Let_syntax in\n (* technically this should be (0, 1] and not (0, 1) but I expect it\n doesn't matter for our purposes. *)\n let%map uniform = Float.gen_uniform_excl 0. 1. in\n Float.log uniform )\n in\n let sum = List.fold gammas ~init:0. ~f:(fun x y -> x +. y) in\n List.map gammas ~f:(fun gamma -> gamma /. sum)\n\nmodule type Int_s = sig\n type t\n\n val zero : t\n\n val ( + ) : t -> t -> t\n\n val ( - ) : t -> t -> t\n\n val ( > ) : t -> t -> bool\n\n val of_int : int -> t\n\n val to_int : t -> int\nend\n\nlet gen_division_generic (type t) (module M : Int_s with type t = t) (n : t)\n (k : int) : M.t list Quickcheck.Generator.t =\n if k = 0 then Quickcheck.Generator.return []\n else\n let open Quickcheck.Generator.Let_syntax in\n (* Using a symmetric Dirichlet distribution with concentration parameter 1\n defined above gives a distribution with uniform probability density over\n all possible splits of the quantity. See the Wikipedia article for some\n more detail: https://en.wikipedia.org/wiki/Dirichlet_distribution,\n particularly the sections about the flat Dirichlet distribution and\n string cutting.\n *)\n let%bind dirichlet = gen_symm_dirichlet k in\n let n_float = Float.of_int @@ M.to_int n in\n let float_to_mt : float -> t =\n fun fl ->\n match Float.iround_down fl with\n | Some int ->\n M.of_int int\n | None ->\n failwith \"gen_division_generic: out of range\"\n in\n let res = List.map dirichlet ~f:(fun x -> float_to_mt @@ (x *. n_float)) in\n let total = List.fold res ~f:M.( + ) ~init:M.zero in\n return\n ( match res with\n | [] ->\n failwith\n \"empty result list in gen_symm_dirichlet, this should be \\\n impossible. \"\n | head :: rest ->\n (* Going through floating point land may have caused some rounding error. We\n tack it onto the first result so that the sum of the output is equal to n.\n *)\n if M.( > ) n total then M.(head + (n - total)) :: rest\n else M.(head - (total - n)) :: rest )\n\nlet gen_division = gen_division_generic (module Int)\n\nlet gen_division_currency =\n gen_division_generic\n ( module struct\n include Currency.Amount\n\n let ( + ) a b = Option.value_exn (a + b)\n\n let ( - ) a b = Option.value_exn (a - b)\n\n let of_int = of_nanomina_int_exn\n\n let to_int = to_nanomina_int\n end )\n\nlet imperative_fixed_point root ~f =\n let%map f' = fixed_point f in\n f' root\n\nlet gen_imperative_rose_tree ?(p = 0.75) (root_gen : 'a t)\n (node_gen : ('a -> 'a) t) =\n let%bind root = root_gen in\n imperative_fixed_point root ~f:(fun self ->\n match%bind size with\n | 0 ->\n return (fun parent -> Rose_tree.T (parent, []))\n | n ->\n let%bind fork_count = geometric ~p 1 >>| Int.max n in\n let%bind fork_sizes = gen_division n fork_count in\n let positive_fork_sizes =\n List.filter fork_sizes ~f:(fun s -> s > 0)\n in\n let%map forks =\n map_gens positive_fork_sizes ~f:(fun s ->\n tuple2 node_gen (with_size ~size:(s - 1) self) )\n in\n fun parent ->\n Rose_tree.T\n (parent, List.map forks ~f:(fun (this, f) -> f (this parent))) )\n\nlet gen_imperative_ktree ?(p = 0.75) (root_gen : 'a t) (node_gen : ('a -> 'a) t)\n =\n let%bind root = root_gen in\n imperative_fixed_point root ~f:(fun self ->\n match%bind size with\n | 0 ->\n return (fun _ -> [])\n (* this case is optional but more effecient *)\n | 1 ->\n let%map this = node_gen in\n fun parent -> [ this parent ]\n | n ->\n let%bind this = node_gen in\n let%bind fork_count = geometric ~p 1 >>| Int.max n in\n let%bind fork_sizes = gen_division (n - 1) fork_count in\n let%map forks =\n map_gens fork_sizes ~f:(fun s -> with_size ~size:s self)\n in\n fun parent ->\n let x = this parent in\n x :: List.bind forks ~f:(fun f -> f x) )\n\nlet gen_imperative_list (root_gen : 'a t) (node_gen : ('a -> 'a) t) =\n let%bind root = root_gen in\n imperative_fixed_point root ~f:(fun self ->\n match%bind size with\n | 0 ->\n return (fun _ -> [])\n | n ->\n let%bind this = node_gen in\n let%map f = with_size ~size:(n - 1) self in\n fun parent -> parent :: f (this parent) )\n\nlet%test_module \"Quickcheck lib tests\" =\n ( module struct\n let%test_unit \"gen_imperative_list\" =\n let increment = ( + ) 2 in\n let root = 1 in\n let root_gen = return root in\n let gen =\n Int.gen_incl 2 100\n >>= fun size ->\n Quickcheck.Generator.with_size ~size\n (gen_imperative_list root_gen (return increment))\n in\n Quickcheck.test gen ~f:(fun list ->\n match list with\n | [] ->\n failwith \"We assume that our list has at least one element\"\n | x :: xs ->\n assert (x = root) ;\n let result =\n List.fold_result xs ~init:x ~f:(fun elem next_elem ->\n if next_elem = increment elem then Result.return next_elem\n else\n Or_error.errorf\n !\"elements do not add up correctly %d %d\"\n elem next_elem )\n in\n assert (Result.is_ok result) )\n end )\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nlet field_of_bool =\n Snark_params.Tick.(fun b -> if b then Field.one else Field.zero)\n\nlet bit_length_to_triple_length n =\n let r = n mod 3 in\n let k = n / 3 in\n if r = 0 then k else k + 1\n\nlet split_last_exn =\n let rec go acc x xs =\n match xs with [] -> (List.rev acc, x) | x' :: xs -> go (x :: acc) x' xs\n in\n function [] -> failwith \"split_last: Empty list\" | x :: xs -> go [] x xs\n\nlet two_to_the i = Bignum_bigint.(pow (of_int 2) (of_int i))\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Mina_base_import\n\nmodule type S = sig\n module Digest : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n val of_field : Snark_params.Tick.Field.t -> t\n\n val to_field_unsafe : t -> Snark_params.Tick.Field.t\n\n include Stringable.S with type t := t\n\n (* so we can easily import these into Token_id *)\n module Binables : sig\n include Comparable_binable with type t := t\n\n include Hashable_binable with type t := t\n end\n\n include module type of Binables\n\n val to_input : t -> Snark_params.Tick.Field.t Random_oracle.Input.Chunked.t\n\n val default : t\n\n val gen : t Quickcheck.Generator.t\n\n val gen_non_default : t Quickcheck.Generator.t\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n open Pickles.Impls.Step\n\n type t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val constant : Stable.Latest.t -> t\n\n val equal : t -> t -> Boolean.var\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t\n\n val of_field : Pickles.Impls.Step.Field.t -> t\n\n val to_field_unsafe : t -> Pickles.Impls.Step.Field.t\n\n module Assert : sig\n val equal : t -> t -> unit\n end\n end\n\n val typ : (Checked.t, t) Snark_params.Tick.Typ.t\n\n [%%endif]\n end\n\n [%%versioned:\n module Stable : sig\n module V2 : sig\n type t [@@deriving sexp, equal, compare, hash, yojson]\n end\n end]\n\n val create : Public_key.Compressed.t -> Digest.t -> t\n\n val derive_token_id : owner:t -> Digest.t\n\n val empty : t\n\n val invalid : t\n\n val public_key : t -> Public_key.Compressed.t\n\n val of_public_key : Public_key.t -> t\n\n val token_id : t -> Digest.t\n\n val to_input : t -> Snark_params.Tick.Field.t Random_oracle.Input.Chunked.t\n\n val gen : t Quickcheck.Generator.t\n\n include Comparable.S with type t := t\n\n include Hashable.S_binable with type t := t\n\n [%%ifdef consensus_mechanism]\n\n type var\n\n val typ : (var, t) Snark_params.Tick.Typ.t\n\n val var_of_t : t -> var\n\n module Checked : sig\n open Snark_params\n open Tick\n\n val create : Public_key.Compressed.var -> Digest.Checked.t -> var\n\n val public_key : var -> Public_key.Compressed.var\n\n val token_id : var -> Digest.Checked.t\n\n val to_input :\n var -> Snark_params.Tick.Field.Var.t Random_oracle.Input.Chunked.t\n\n val equal : var -> var -> Boolean.var Checked.t\n\n val if_ : Boolean.var -> then_:var -> else_:var -> var Checked.t\n\n val derive_token_id : owner:var -> Digest.Checked.t\n end\n\n [%%endif]\nend\n","(* hash_prefix.ml *)\n\ninclude Hash_prefix_states\n","(* data_hash.ml *)\n\ninclude Data_hash_lib.Data_hash\n","open Core_kernel\n\nmodule Legacy_token = Mina_numbers.Nat.Make64 ()\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Account_id.Digest.Stable.V1.t\n [@@deriving sexp, yojson, equal, compare, hash]\n\n let to_latest = Fn.id\n end\n\n (* for transactions in pre-Berkeley hard fork *)\n module V1 = struct\n [@@@with_all_version_tags]\n\n type t = Legacy_token.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest token_id =\n Legacy_token.to_field token_id |> Account_id.Digest.of_field\n end\nend]\n\n[%%define_locally\nAccount_id.Digest.\n ( default\n , typ\n , to_input\n , gen\n , gen_non_default\n , to_field_unsafe\n , of_field\n , to_string\n , of_string\n , comparator\n , ( <> ) )]\n\nlet of_string s =\n try Account_id.Digest.of_string s\n with Base58_check.Invalid_base58_check_length _ ->\n Legacy_token.of_string s |> Stable.V1.to_latest\n\ninclude Account_id.Digest.Binables\n\n(* someday, allow this in %%define_locally *)\nmodule Checked = Account_id.Digest.Checked\n\nlet deriver obj =\n (* this doesn't use js_type:Field because it is converted to JSON differently than a normal Field *)\n Fields_derivers_zkapps.iso_string obj ~name:\"TokenId\"\n ~js_type:(Custom \"TokenId\") ~doc:\"String representing a token ID\" ~to_string\n ~of_string:(Fields_derivers_zkapps.except ~f:of_string `Token_id)\n","(** Fee excesses associated with transactions or transitions.\n\n These are represented as a 'left' and 'right' excess, which describe the\n unresolved fee excesses in the fee tokens of the first (or leftmost) and\n last (or rightmost) transactions in the transition.\n\n Assumptions:\n * Transactions are grouped by their fee token.\n * The 'fee transfer' transaction to dispense those fees is part of this\n group.\n * The fee excess for each token is 0 across the group.\n * No transactions with fees paid in another token are executed while the\n previous fee token's excess is non-zero.\n\n By maintaining these assumptions, we can ensure that the un-settled fee\n excesses can be represented by excesses in (at most) 2 tokens.\n Consider, for example, any consecutive subsequence of the transactions\n\n ..[txn@2][ft@2][txn@3][txn@3][ft@3][txn@4][ft@4][txn@5][txn@5][ft@5][txn@6][ft@6]..\n\n where [txn@i] and [ft@i] are transactions and fee transfers respectively\n paid in token i.\n The only groups which may have non-zero fee excesses are those which\n contain the start and end of the subsequence.\n\n The code below also defines a canonical representation where fewer than 2\n tokens have non-zero excesses. See [rebalance] below for details and the\n implementation.\n*)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n[%%ifndef consensus_mechanism]\n\nopen Mina_base_import\n\n[%%endif]\n\nopen Currency\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params\nopen Tick\n\n[%%endif]\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type ('token, 'fee) t =\n ('token, 'fee) Mina_wire_types.Mina_base.Fee_excess.Poly.V1.t =\n { fee_token_l : 'token\n ; fee_excess_l : 'fee\n ; fee_token_r : 'token\n ; fee_excess_r : 'fee\n }\n [@@deriving compare, equal, hash, sexp, hlist]\n\n let to_yojson token_to_yojson fee_to_yojson\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n `List\n [ `Assoc\n [ (\"token\", token_to_yojson fee_token_l)\n ; (\"amount\", fee_to_yojson fee_excess_l)\n ]\n ; `Assoc\n [ (\"token\", token_to_yojson fee_token_r)\n ; (\"amount\", fee_to_yojson fee_excess_r)\n ]\n ]\n\n let of_yojson token_of_yojson fee_of_yojson = function\n | `List [ `Assoc [ left0; left1 ]; `Assoc [ right0; right1 ] ] -> (\n (* allow for reversed field order: \"be liberal in what you accept\" *)\n let token_and_excess pair0 pair1 =\n match (pair0, pair1) with\n | (\"token\", token), (\"amount\", excess) ->\n Some (token, excess)\n | (\"amount\", excess), (\"token\", token) ->\n Some (token, excess)\n | _ ->\n None\n in\n let left = token_and_excess left0 left1 in\n let right = token_and_excess right0 right1 in\n match (left, right) with\n | Some (fee_token_l, fee_excess_l), Some (fee_token_r, fee_excess_r)\n ->\n let open Result.Let_syntax in\n let%map fee_token_l = token_of_yojson fee_token_l\n and fee_excess_l = fee_of_yojson fee_excess_l\n and fee_token_r = token_of_yojson fee_token_r\n and fee_excess_r = fee_of_yojson fee_excess_r in\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r }\n | _ ->\n Error \"Fee_excess.Poly.Stable.V1.t, unexpected JSON field\" )\n | _ ->\n Error \"Fee_excess.Poly.Stable.V1.t\"\n end\n end]\n\n [%%define_locally Stable.Latest.(to_yojson, of_yojson)]\n\n [%%ifdef consensus_mechanism]\n\n let typ (token_typ : ('token_var, 'token) Typ.t)\n (fee_typ : ('fee_var, 'fee) Typ.t) :\n (('token_var, 'fee_var) t, ('token, 'fee) t) Typ.t =\n Typ.of_hlistable\n [ token_typ; fee_typ; token_typ; fee_typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n [%%endif]\nend\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type t =\n ( Token_id.Stable.V2.t\n , (Fee.Stable.V1.t, Sgn.Stable.V1.t) Signed_poly.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving compare, equal, hash, sexp, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\ntype ('token, 'fee) poly = ('token, 'fee) Poly.t =\n { fee_token_l : 'token\n ; fee_excess_l : 'fee\n ; fee_token_r : 'token\n ; fee_excess_r : 'fee\n }\n[@@deriving compare, equal, hash, sexp]\n\nlet poly_to_yojson = Poly.to_yojson\n\nlet poly_of_yojson = Poly.of_yojson\n\n[%%ifdef consensus_mechanism]\n\ntype var = (Token_id.Checked.t, Fee.Signed.var) poly\n\nlet typ : (var, t) Typ.t = Poly.typ Token_id.typ Fee.Signed.typ\n\nlet var_of_t ({ fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } : t) :\n var =\n { fee_token_l = Token_id.Checked.constant fee_token_l\n ; fee_excess_l = Fee.Signed.Checked.constant fee_excess_l\n ; fee_token_r = Token_id.Checked.constant fee_token_r\n ; fee_excess_r = Fee.Signed.Checked.constant fee_excess_r\n }\n\n[%%endif]\n\nlet to_input { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n let open Random_oracle.Input.Chunked in\n List.reduce_exn ~f:append\n [ Token_id.to_input fee_token_l\n ; Fee.Signed.to_input fee_excess_l\n ; Token_id.to_input fee_token_r\n ; Fee.Signed.to_input fee_excess_r\n ]\n\n[%%ifdef consensus_mechanism]\n\nlet to_input_checked { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n let fee_token_l = Token_id.Checked.to_input fee_token_l\n and fee_token_r = Token_id.Checked.to_input fee_token_r in\n let%map fee_excess_l = Fee.Signed.Checked.to_input fee_excess_l\n and fee_excess_r = Fee.Signed.Checked.to_input fee_excess_r in\n List.reduce_exn ~f:Random_oracle.Input.Chunked.append\n [ fee_token_l; fee_excess_l; fee_token_r; fee_excess_r ]\n\nlet assert_equal_checked (t1 : var) (t2 : var) =\n Checked.all_unit\n [ [%with_label_ \"fee_token_l\"] (fun () ->\n make_checked (fun () ->\n Token_id.Checked.Assert.equal t1.fee_token_l t2.fee_token_l ) )\n ; [%with_label_ \"fee_excess_l\"] (fun () ->\n Fee.Signed.Checked.assert_equal t1.fee_excess_l t2.fee_excess_l )\n ; [%with_label_ \"fee_token_r\"] (fun () ->\n make_checked (fun () ->\n Token_id.Checked.Assert.equal t1.fee_token_r t2.fee_token_r ) )\n ; [%with_label_ \"fee_excess_r\"] (fun () ->\n Fee.Signed.Checked.assert_equal t1.fee_excess_r t2.fee_excess_r )\n ]\n\n[%%endif]\n\n(** Eliminate a fee excess, either by combining it with one to the left/right,\n or by checking that it is zero.\n*)\nlet eliminate_fee_excess (fee_token_l, fee_excess_l) (fee_token_m, fee_excess_m)\n (fee_token_r, fee_excess_r) =\n let add_err x y =\n match Fee.Signed.add x y with\n | Some z ->\n Or_error.return z\n | None ->\n Or_error.errorf \"Error adding fees: overflow.\"\n in\n let open Or_error.Let_syntax in\n if\n Token_id.equal fee_token_l fee_token_m\n || Fee.(equal zero) fee_excess_l.Signed_poly.magnitude\n then\n let%map fee_excess_l = add_err fee_excess_l fee_excess_m in\n ((fee_token_m, fee_excess_l), (fee_token_r, fee_excess_r))\n else if\n Token_id.equal fee_token_r fee_token_m\n || Fee.(equal zero fee_excess_r.Signed_poly.magnitude)\n then\n let%map fee_excess_r = add_err fee_excess_r fee_excess_m in\n ((fee_token_l, fee_excess_l), (fee_token_m, fee_excess_r))\n else if Fee.(equal zero) fee_excess_m.Signed_poly.magnitude then\n return ((fee_token_l, fee_excess_l), (fee_token_r, fee_excess_r))\n else\n Or_error.errorf\n !\"Error eliminating fee excess: Excess for token %{sexp: Token_id.t} \\\n %{sexp: Fee.Signed.t} was nonzero\"\n fee_token_m fee_excess_m\n\n[%%ifdef consensus_mechanism]\n\n(* We use field elements instead of a currency type here, under the following\n assumptions:\n * the additions and subtractions performed upon members of the currency\n type do not overflow the field size\n - The currency type is currently 64-bit, which is much smaller than the\n field size.\n * it is acceptable for the currency type to overflow/underflow, as long as\n a subsequent subtraction/addition brings it back into the range for the\n currency type.\n - These situations will be rejected by the unchecked code that checks\n each addition/subtraction, but this superset of that behaviour seems\n well-defined, and is still 'correct' in the sense that currency is\n preserved.\n\n This optimisation saves serveral hundred constraints in the proof by not\n unpacking the result of each arithmetic operation.\n*)\nlet%snarkydef_ eliminate_fee_excess_checked (fee_token_l, fee_excess_l)\n (fee_token_m, fee_excess_m) (fee_token_r, fee_excess_r) =\n let open Tick in\n let open Checked.Let_syntax in\n let combine (fee_token, fee_excess) fee_excess_m =\n let%bind fee_token_equal =\n make_checked (fun () -> Token_id.Checked.equal fee_token fee_token_m)\n in\n let%bind fee_excess_zero =\n Field.(Checked.equal (Var.constant zero)) fee_excess\n in\n let%bind may_move = Boolean.(fee_token_equal ||| fee_excess_zero) in\n let%bind fee_token =\n make_checked (fun () ->\n Token_id.Checked.if_ fee_excess_zero ~then_:fee_token_m\n ~else_:fee_token )\n in\n let%map fee_excess_to_move =\n Field.Checked.if_ may_move ~then_:fee_excess_m\n ~else_:Field.(Var.constant zero)\n in\n ( (fee_token, Field.Var.add fee_excess fee_excess_to_move)\n , Field.Var.sub fee_excess_m fee_excess_to_move )\n in\n (* NOTE: Below, we may update the tokens on both sides, even though we only\n promote the excess to one of them. This differs from the unchecked\n version, but\n * the token may only be changed if it is associated with 0 fee excess\n * any intermediate 0 fee excesses can always be either combined or erased\n in later eliminations\n * a fee excess of 0 on the left or right will have its token erased to the\n default\n *)\n let%bind (fee_token_l, fee_excess_l), fee_excess_m =\n combine (fee_token_l, fee_excess_l) fee_excess_m\n in\n let%bind (fee_token_r, fee_excess_r), fee_excess_m =\n combine (fee_token_r, fee_excess_r) fee_excess_m\n in\n let%map () =\n [%with_label_ \"Fee excess is eliminated\"]\n Field.(fun () -> Checked.Assert.equal (Var.constant zero) fee_excess_m)\n in\n ((fee_token_l, fee_excess_l), (fee_token_r, fee_excess_r))\n\n[%%endif]\n\n(* 'Rebalance' to a canonical form, where\n - if there is only 1 nonzero excess, it is to the left\n - any zero fee excess has the default token\n - if the fee tokens are the same, the excesses are combined\n*)\nlet rebalance ({ fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } : t) =\n let open Or_error.Let_syntax in\n (* Use the same token for both if [fee_excess_l] is zero. *)\n let fee_token_l =\n if Fee.(equal zero) fee_excess_l.magnitude then fee_token_r else fee_token_l\n in\n (* Rebalancing. *)\n let%map fee_excess_l, fee_excess_r =\n if Token_id.equal fee_token_l fee_token_r then\n match Fee.Signed.add fee_excess_l fee_excess_r with\n | Some fee_excess_l ->\n return (fee_excess_l, Fee.Signed.zero)\n | None ->\n Or_error.errorf !\"Error adding fees: overflow\"\n else return (fee_excess_l, fee_excess_r)\n in\n (* Use the default token if the excess is zero.\n This allows [verify_complete_merge] to verify a proof without knowledge of\n the particular fee tokens used.\n *)\n let fee_token_l =\n if Fee.(equal zero) fee_excess_l.magnitude then Token_id.default\n else fee_token_l\n in\n let fee_token_r =\n if Fee.(equal zero) fee_excess_r.magnitude then Token_id.default\n else fee_token_r\n in\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r }\n\n[%%ifdef consensus_mechanism]\n\nlet rebalance_checked { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n let open Checked.Let_syntax in\n (* Use the same token for both if [fee_excess_l] is zero. *)\n let%bind fee_token_l =\n let%bind excess_is_zero =\n Field.(Checked.equal (Var.constant zero) fee_excess_l)\n in\n make_checked (fun () ->\n Token_id.Checked.if_ excess_is_zero ~then_:fee_token_r\n ~else_:fee_token_l )\n in\n (* Rebalancing. *)\n let%bind fee_excess_l, fee_excess_r =\n let%bind tokens_equal =\n make_checked (fun () -> Token_id.Checked.equal fee_token_l fee_token_r)\n in\n let%map amount_to_move =\n Field.Checked.if_ tokens_equal ~then_:fee_excess_r\n ~else_:Field.(Var.constant zero)\n in\n ( Field.Var.add fee_excess_l amount_to_move\n , Field.Var.sub fee_excess_r amount_to_move )\n in\n (* Use the default token if the excess is zero. *)\n let%bind fee_token_l =\n let%bind excess_is_zero =\n Field.(Checked.equal (Var.constant zero) fee_excess_l)\n in\n make_checked (fun () ->\n Token_id.Checked.if_ excess_is_zero\n ~then_:Token_id.(Checked.constant default)\n ~else_:fee_token_l )\n in\n let%map fee_token_r =\n let%bind excess_is_zero =\n Field.(Checked.equal (Var.constant zero) fee_excess_r)\n in\n make_checked (fun () ->\n Token_id.Checked.if_ excess_is_zero\n ~then_:Token_id.(Checked.constant default)\n ~else_:fee_token_r )\n in\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r }\n\n[%%endif]\n\n(** Combine the fee excesses from two transitions. *)\nlet combine\n ({ fee_token_l = fee_token1_l\n ; fee_excess_l = fee_excess1_l\n ; fee_token_r = fee_token1_r\n ; fee_excess_r = fee_excess1_r\n } :\n t )\n ({ fee_token_l = fee_token2_l\n ; fee_excess_l = fee_excess2_l\n ; fee_token_r = fee_token2_r\n ; fee_excess_r = fee_excess2_r\n } :\n t ) : t Or_error.t =\n let open Or_error.Let_syntax in\n (* Eliminate fee_excess1_r. *)\n let%bind (fee_token1_l, fee_excess1_l), (fee_token2_l, fee_excess2_l) =\n (* [1l; 1r; 2l; 2r] -> [1l; 2l; 2r] *)\n eliminate_fee_excess\n (fee_token1_l, fee_excess1_l)\n (fee_token1_r, fee_excess1_r)\n (fee_token2_l, fee_excess2_l)\n in\n (* Eliminate fee_excess2_l. *)\n let%bind (fee_token1_l, fee_excess1_l), (fee_token2_r, fee_excess2_r) =\n (* [1l; 2l; 2r] -> [1l; 2r] *)\n eliminate_fee_excess\n (fee_token1_l, fee_excess1_l)\n (fee_token2_l, fee_excess2_l)\n (fee_token2_r, fee_excess2_r)\n in\n rebalance\n { fee_token_l = fee_token1_l\n ; fee_excess_l = fee_excess1_l\n ; fee_token_r = fee_token2_r\n ; fee_excess_r = fee_excess2_r\n }\n\n[%%ifdef consensus_mechanism]\n\nlet%snarkydef_ combine_checked\n { fee_token_l = fee_token1_l\n ; fee_excess_l = fee_excess1_l\n ; fee_token_r = fee_token1_r\n ; fee_excess_r = fee_excess1_r\n }\n { fee_token_l = fee_token2_l\n ; fee_excess_l = fee_excess2_l\n ; fee_token_r = fee_token2_r\n ; fee_excess_r = fee_excess2_r\n } =\n let open Checked.Let_syntax in\n (* Represent amounts as field elements. *)\n let%bind fee_excess1_l = Fee.Signed.Checked.to_field_var fee_excess1_l in\n let%bind fee_excess1_r = Fee.Signed.Checked.to_field_var fee_excess1_r in\n let%bind fee_excess2_l = Fee.Signed.Checked.to_field_var fee_excess2_l in\n let%bind fee_excess2_r = Fee.Signed.Checked.to_field_var fee_excess2_r in\n (* Eliminations. *)\n let%bind (fee_token1_l, fee_excess1_l), (fee_token2_l, fee_excess2_l) =\n (* [1l; 1r; 2l; 2r] -> [1l; 2l; 2r] *)\n [%with_label_ \"Eliminate fee_excess1_r\"] (fun () ->\n eliminate_fee_excess_checked\n (fee_token1_l, fee_excess1_l)\n (fee_token1_r, fee_excess1_r)\n (fee_token2_l, fee_excess2_l) )\n in\n let%bind (fee_token1_l, fee_excess1_l), (fee_token2_r, fee_excess2_r) =\n (* [1l; 2l; 2r] -> [1l; 2r] *)\n [%with_label_ \"Eliminate fee_excess2_l\"] (fun () ->\n eliminate_fee_excess_checked\n (fee_token1_l, fee_excess1_l)\n (fee_token2_l, fee_excess2_l)\n (fee_token2_r, fee_excess2_r) )\n in\n let%bind { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n rebalance_checked\n { fee_token_l = fee_token1_l\n ; fee_excess_l = fee_excess1_l\n ; fee_token_r = fee_token2_r\n ; fee_excess_r = fee_excess2_r\n }\n in\n let convert_to_currency excess =\n let%bind currency_excess =\n exists Fee.Signed.typ\n ~compute:\n As_prover.(\n let%map excess = read Field.typ excess in\n let is_neg =\n Bigint.test_bit (Bigint.of_field excess) (Field.size_in_bits - 1)\n in\n let sgn = if is_neg then Sgn.Neg else Sgn.Pos in\n let excess =\n if is_neg then Field.(mul (negate one) excess) else excess\n in\n let magnitude =\n (* TODO: Add a native coercion [Bigint -> UInt64] in Snarky's FFI\n bindings, use it here.\n *)\n let n = Bigint.of_field excess in\n let total = ref Unsigned_extended.UInt64.zero in\n for i = 0 to Unsigned_extended.UInt64.length_in_bits - 1 do\n if Bigint.test_bit n i then\n total :=\n Unsigned_extended.UInt64.(add !total (shift_left one i))\n done ;\n Fee.of_uint64 !total\n in\n Fee.Signed.create ~magnitude ~sgn)\n in\n let%bind excess_from_currency =\n Fee.Signed.Checked.to_field_var currency_excess\n in\n let%map () =\n [%with_label_ \"Fee excess does not overflow\"] (fun () ->\n Field.Checked.Assert.equal excess excess_from_currency )\n in\n currency_excess\n in\n (* Convert to currency. *)\n let%bind fee_excess_l =\n [%with_label_ \"Check for overflow in fee_excess_l\"] (fun () ->\n convert_to_currency fee_excess_l )\n in\n let%map fee_excess_r =\n [%with_label_ \"Check for overflow in fee_excess_r\"] (fun () ->\n convert_to_currency fee_excess_r )\n in\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r }\n\n[%%endif]\n\nlet empty =\n { fee_token_l = Token_id.default\n ; fee_excess_l = Fee.Signed.zero\n ; fee_token_r = Token_id.default\n ; fee_excess_r = Fee.Signed.zero\n }\n\nlet is_empty { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } =\n Fee.Signed.(equal zero) fee_excess_l\n && Fee.Signed.(equal zero) fee_excess_r\n && Token_id.(equal default) fee_token_l\n && Token_id.(equal default) fee_token_r\n\nlet zero = empty\n\nlet is_zero = is_empty\n\nlet of_single (fee_token_l, fee_excess_l) =\n (* This is safe, we know that we will not hit overflow above. *)\n Or_error.ok_exn\n @@ rebalance\n { fee_token_l\n ; fee_excess_l\n ; fee_token_r = Token_id.default\n ; fee_excess_r = Fee.Signed.zero\n }\n\nlet of_one_or_two excesses =\n let unreduced =\n match excesses with\n | `One (fee_token_l, fee_excess_l) ->\n { fee_token_l\n ; fee_excess_l\n ; fee_token_r = Token_id.default\n ; fee_excess_r = Fee.Signed.zero\n }\n | `Two ((fee_token_l, fee_excess_l), (fee_token_r, fee_excess_r)) ->\n { fee_token_l; fee_excess_l; fee_token_r; fee_excess_r }\n in\n rebalance unreduced\n\nlet to_one_or_two ({ fee_token_l; fee_excess_l; fee_token_r; fee_excess_r } : t)\n =\n if Fee.(equal zero) fee_excess_r.magnitude then\n `One (fee_token_l, fee_excess_l)\n else `Two ((fee_token_l, fee_excess_l), (fee_token_r, fee_excess_r))\n\n[%%ifdef consensus_mechanism]\n\nlet gen_single ?(token_id = Token_id.gen) ?(excess = Fee.Signed.gen) () :\n (Token_id.t * Fee.Signed.t) Quickcheck.Generator.t =\n Quickcheck.Generator.tuple2 token_id excess\n\nlet gen : t Quickcheck.Generator.t =\n let open Quickcheck.Generator.Let_syntax in\n let%map excesses = One_or_two.gen @@ gen_single () in\n match of_one_or_two excesses with\n | Ok ret ->\n ret\n | Error _ -> (\n (* There is an overflow, just choose the first excess. *)\n match excesses with\n | `One (fee_token_l, fee_excess_l) | `Two ((fee_token_l, fee_excess_l), _)\n ->\n { fee_token_l\n ; fee_excess_l\n ; fee_token_r = Token_id.default\n ; fee_excess_r = Fee.Signed.zero\n } )\n\n[%%endif]\n","open Core_kernel\nopen Snark_params.Tick\n\nmodule type S = sig\n include Data_hash.Full_size\n\n [%%versioned:\n module Stable : sig\n [@@@no_toplevel_latest_type]\n\n module V1 : sig\n type t = Field.t [@@deriving sexp, compare, hash, yojson]\n\n val to_latest : t -> t\n\n include Comparable.S with type t := t\n\n include Hashable_binable with type t := t\n end\n end]\nend\n","include Ledger_hash0\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Snark_params.Tick\n\nmodule type S = sig\n exception Too_long_user_memo_input\n\n exception Too_long_digestible_string\n\n type t [@@deriving sexp, equal, compare, hash, yojson]\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving bin_io, sexp, equal, compare, hash, yojson, version]\n\n module With_all_version_tags : Bin_prot.Binable.S with type t = t\n end\n\n module Latest = V1\n end\n\n [%%ifdef consensus_mechanism]\n\n module Checked : sig\n type unchecked = t\n\n type t = private Boolean.var array\n\n val constant : unchecked -> t\n end\n\n (** typ representation *)\n val typ : (Checked.t, t) Typ.t\n\n [%%endif]\n\n val dummy : t\n\n val empty : t\n\n val to_base58_check : t -> string\n\n val of_base58_check : string -> t Or_error.t\n\n val of_base58_check_exn : string -> t\n\n (** for a memo of bytes, return a plaintext string\n for a memo of a digest, return a hex-encoded string, prefixed by '0x'\n *)\n val to_string_hum : t -> string\n\n (** is the memo a digest *)\n val is_digest : t -> bool\n\n (** is the memo well-formed *)\n val is_valid : t -> bool\n\n (** bound on length of strings to digest *)\n val max_digestible_string_length : int\n\n (** bound on length of strings or bytes in memo *)\n val max_input_length : int\n\n (** create a memo by digesting a string; raises [Too_long_digestible_string] if\n length exceeds [max_digestible_string_length]\n *)\n val create_by_digesting_string_exn : string -> t\n\n (** create a memo by digesting a string; returns error if\n length exceeds [max_digestible_string_length]\n *)\n val create_by_digesting_string : string -> t Or_error.t\n\n (** create a memo from bytes of length up to max_input_length;\n raise [Too_long_user_memo_input] if length is greater\n *)\n val create_from_bytes_exn : bytes -> t\n\n (** create a memo from bytes of length up to max_input_length; returns\n error is length is greater\n *)\n val create_from_bytes : bytes -> t Or_error.t\n\n (** create a memo from a string of length up to max_input_length;\n raise [Too_long_user_memo_input] if length is greater\n *)\n val create_from_string_exn : string -> t\n\n (** create a memo from a string of length up to max_input_length;\n returns error if length is greater\n *)\n val create_from_string : string -> t Or_error.t\n\n (** convert a memo to a list of bools\n *)\n val to_bits : t -> bool list\n\n (** Quickcheck generator for memos. *)\n val gen : t Quickcheck.Generator.t\n\n (** Compute a standalone hash of the current memo. *)\n val hash : t -> Field.t\n\n (* This type definition was generated by hovering over `deriver` in signed_command_memo.ml and copying the type *)\n val deriver :\n (< contramap : (t -> Yojson.Safe.t) ref\n ; graphql_arg :\n (unit -> Yojson.Safe.t Fields_derivers_graphql.Schema.Arg.arg_typ)\n ref\n ; graphql_fields :\n Yojson.Safe.t Fields_derivers_zkapps.Graphql.Fields.Input.T.t ref\n ; graphql_query : string option ref\n ; graphql_query_accumulator : (string * string option) list ref\n ; map : (Yojson.Safe.t -> t) ref\n ; nullable_graphql_arg :\n ( unit\n -> Yojson.Safe.t option Fields_derivers_graphql.Schema.Arg.arg_typ\n )\n ref\n ; nullable_graphql_fields :\n Yojson.Safe.t option Fields_derivers_zkapps.Graphql.Fields.Input.T.t\n ref\n ; of_json : (Yojson.Safe.t -> Yojson.Safe.t) ref\n ; to_json : (Yojson.Safe.t -> Yojson.Safe.t) ref\n ; js_layout : Yojson.Safe.t ref\n ; .. >\n as\n 'a )\n Fields_derivers_zkapps.Unified_input.t\n Fields_derivers_zkapps.Unified_input.t\n Fields_derivers_zkapps.Unified_input.t\n -> 'a Fields_derivers_zkapps.Unified_input.t\n\n type raw =\n | Digest of string (** The digest of the string, encoded by base58-check *)\n | Bytes of string (** A string containing the raw bytes in the memo. *)\n\n (** Convert into a raw representation.\n\n Raises if the tag or length are invalid.\n *)\n val to_raw_exn : t -> raw\n\n (** Convert back into the raw input bytes.\n\n Raises if the tag or length are invalid, or if the memo was a digest.\n Equivalent to [to_raw_exn] and then a match on [Bytes].\n *)\n val to_raw_bytes_exn : t -> string\n\n (** Convert from a raw representation.\n\n Raises if the digest is not a valid base58-check string, or if the bytes\n string is too long.\n *)\n val of_raw_exn : raw -> t\nend\n","(* transaction_union_payload.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\nopen Currency\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nopen Signature_lib\nmodule Tag = Transaction_union_tag\n\nmodule Body = struct\n type ('tag, 'public_key, 'token_id, 'amount, 'bool) t_ =\n { tag : 'tag\n ; source_pk : 'public_key\n ; receiver_pk : 'public_key\n ; token_id : 'token_id\n ; amount : 'amount\n }\n [@@deriving sexp, hlist]\n\n type t =\n (Tag.t, Public_key.Compressed.t, Token_id.t, Currency.Amount.t, bool) t_\n [@@deriving sexp]\n\n let of_user_command_payload_body ~fee_payer_pk = function\n | Signed_command_payload.Body.Payment { receiver_pk; amount } ->\n { tag = Tag.Payment\n ; source_pk = fee_payer_pk\n ; receiver_pk\n ; token_id = Token_id.default\n ; amount\n }\n | Stake_delegation (Set_delegate { new_delegate }) ->\n { tag = Tag.Stake_delegation\n ; source_pk = fee_payer_pk\n ; receiver_pk = new_delegate\n ; token_id = Token_id.default\n ; amount = Currency.Amount.zero\n }\n\n let gen ~fee =\n let open Quickcheck.Generator.Let_syntax in\n let%bind tag = Tag.gen in\n let%map amount =\n let min, max =\n let max_amount_without_overflow =\n Amount.(sub max_int (of_fee fee))\n |> Option.value_exn ?here:None ?message:None ?error:None\n in\n match tag with\n | Payment ->\n (Amount.zero, max_amount_without_overflow)\n | Stake_delegation ->\n (Amount.zero, Amount.zero)\n | Fee_transfer ->\n (Amount.zero, max_amount_without_overflow)\n | Coinbase ->\n (* In this case,\n amount - fee should be defined. In other words,\n amount >= fee *)\n (Amount.of_fee fee, Amount.max_int)\n in\n Amount.gen_incl min max\n and source_pk = Public_key.Compressed.gen\n and receiver_pk = Public_key.Compressed.gen\n and token_id =\n match tag with\n | Payment ->\n Token_id.gen\n | Stake_delegation ->\n return Token_id.default\n | Fee_transfer ->\n return Token_id.default\n | Coinbase ->\n return Token_id.default\n in\n { tag; source_pk; receiver_pk; token_id; amount }\n\n [%%ifdef consensus_mechanism]\n\n type var =\n ( Tag.Unpacked.var\n , Public_key.Compressed.var\n , Token_id.Checked.t\n , Currency.Amount.var\n , Boolean.var )\n t_\n\n let typ =\n Typ.of_hlistable\n [ Tag.unpacked_typ\n ; Public_key.Compressed.typ\n ; Public_key.Compressed.typ\n ; Token_id.typ\n ; Currency.Amount.typ\n ]\n ~var_to_hlist:t__to_hlist ~value_to_hlist:t__to_hlist\n ~var_of_hlist:t__of_hlist ~value_of_hlist:t__of_hlist\n\n module Checked = struct\n let constant ({ tag; source_pk; receiver_pk; token_id; amount } : t) : var =\n { tag = Tag.unpacked_of_t tag\n ; source_pk = Public_key.Compressed.var_of_t source_pk\n ; receiver_pk = Public_key.Compressed.var_of_t receiver_pk\n ; token_id = Token_id.Checked.constant token_id\n ; amount = Currency.Amount.var_of_t amount\n }\n\n let to_input_legacy { tag; source_pk; receiver_pk; token_id; amount } =\n let%map amount = Currency.Amount.var_to_input_legacy amount\n and () =\n make_checked (fun () ->\n Token_id.Checked.Assert.equal token_id\n (Token_id.Checked.constant Token_id.default) )\n in\n let token_id = Signed_command_payload.Legacy_token_id.default_checked in\n Array.reduce_exn ~f:Random_oracle.Input.Legacy.append\n [| Tag.Unpacked.to_input_legacy tag\n ; Public_key.Compressed.Checked.to_input_legacy source_pk\n ; Public_key.Compressed.Checked.to_input_legacy receiver_pk\n ; token_id\n ; amount\n ; Random_oracle.Input.Legacy.bitstring [ Boolean.false_ ]\n |]\n end\n\n [%%endif]\n\n let to_input_legacy { tag; source_pk; receiver_pk; token_id; amount } =\n assert (Token_id.equal token_id Token_id.default) ;\n Array.reduce_exn ~f:Random_oracle.Input.Legacy.append\n [| Tag.to_input_legacy tag\n ; Public_key.Compressed.to_input_legacy source_pk\n ; Public_key.Compressed.to_input_legacy receiver_pk\n ; Signed_command_payload.Legacy_token_id.default\n ; Currency.Amount.to_input_legacy amount\n ; Random_oracle.Input.Legacy.bitstring [ false ]\n |]\nend\n\nmodule Payload_common = struct\n module Poly = struct\n type ('fee, 'public_key, 'token_id, 'nonce, 'global_slot, 'memo) t =\n { fee : 'fee\n ; fee_token : 'token_id\n ; fee_payer_pk : 'public_key\n ; nonce : 'nonce\n ; valid_until : 'global_slot\n ; memo : 'memo\n }\n [@@deriving sexp, hlist]\n end\n\n let to_signed_command_payload_common\n { Poly.fee; fee_payer_pk; nonce; valid_until; memo; fee_token = _ } =\n { Signed_command_payload.Common.Poly.fee\n ; fee_payer_pk\n ; nonce\n ; valid_until\n ; memo\n }\n\n type t =\n ( Currency.Fee.t\n , Public_key.Compressed.t\n , Token_id.t\n , Mina_numbers.Account_nonce.t\n , Mina_numbers.Global_slot_since_genesis.t\n , Signed_command_memo.t )\n Poly.t\n [@@deriving sexp]\n\n [%%ifdef consensus_mechanism]\n\n module Checked = struct\n type value = t\n\n type t =\n ( Currency.Fee.Checked.t\n , Public_key.Compressed.var\n , Token_id.Checked.t\n , Mina_numbers.Account_nonce.Checked.t\n , Mina_numbers.Global_slot_since_genesis.Checked.t\n , Signed_command_memo.Checked.t )\n Poly.t\n\n let constant\n ({ fee; fee_payer_pk; nonce; valid_until; memo; fee_token } : value) : t\n =\n { fee = Currency.Fee.var_of_t fee\n ; fee_payer_pk = Public_key.Compressed.var_of_t fee_payer_pk\n ; fee_token = Token_id.Checked.constant fee_token\n ; nonce = Mina_numbers.Account_nonce.Checked.constant nonce\n ; memo = Signed_command_memo.Checked.constant memo\n ; valid_until =\n Mina_numbers.Global_slot_since_genesis.Checked.constant valid_until\n }\n end\n\n let typ : (Checked.t, t) Typ.t =\n let open Poly in\n Typ.of_hlistable\n [ Currency.Fee.typ\n ; Token_id.typ\n ; Public_key.Compressed.typ\n ; Mina_numbers.Account_nonce.typ\n ; Mina_numbers.Global_slot_since_genesis.typ\n ; Signed_command_memo.typ\n ]\n ~var_to_hlist:to_hlist ~value_to_hlist:to_hlist ~var_of_hlist:of_hlist\n ~value_of_hlist:of_hlist\n\n [%%endif]\nend\n\ntype t = (Payload_common.t, Body.t) Signed_command_payload.Poly.t\n[@@deriving sexp]\n\ntype payload = t [@@deriving sexp]\n\nlet of_user_command_payload\n ({ common = { memo; fee; fee_payer_pk; nonce; valid_until }; body } :\n Signed_command_payload.t ) : t =\n { common =\n { fee\n ; fee_token = Token_id.default\n ; fee_payer_pk\n ; nonce\n ; valid_until\n ; memo\n }\n ; body = Body.of_user_command_payload_body ~fee_payer_pk body\n }\n\nlet gen =\n let open Quickcheck.Generator.Let_syntax in\n let%bind common = Signed_command_payload.Common.gen in\n let%map body = Body.gen ~fee:common.fee in\n Signed_command_payload.Poly.{ common; body }\n\n[%%ifdef consensus_mechanism]\n\ntype var = (Payload_common.Checked.t, Body.var) Signed_command_payload.Poly.t\n\ntype payload_var = var\n\nlet typ : (var, t) Typ.t =\n let to_hlist = Signed_command_payload.Poly.to_hlist in\n let of_hlist = Signed_command_payload.Poly.of_hlist in\n Typ.of_hlistable\n [ Payload_common.typ; Body.typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\nlet payload_typ = typ\n\nmodule Checked = struct\n let to_input_legacy ({ common; body } : var) =\n let%map common =\n Signed_command_payload.Common.Checked.to_input_legacy\n (Payload_common.to_signed_command_payload_common common)\n and body = Body.Checked.to_input_legacy body in\n Random_oracle.Input.Legacy.append common body\n\n let constant ({ common; body } : t) : var =\n { common = Payload_common.Checked.constant common\n ; body = Body.Checked.constant body\n }\nend\n\n[%%endif]\n\nlet to_input_legacy ({ common; body } : t) =\n Random_oracle.Input.Legacy.append\n (Signed_command_payload.Common.to_input_legacy\n (Payload_common.to_signed_command_payload_common common) )\n (Body.to_input_legacy body)\n\nlet excess (payload : t) : Amount.Signed.t =\n let tag = payload.body.tag in\n let fee = payload.common.fee in\n let amount = payload.body.amount in\n match tag with\n | Payment | Stake_delegation ->\n (* For all user commands, the fee excess is just the fee. *)\n Amount.Signed.of_unsigned (Amount.of_fee fee)\n | Fee_transfer ->\n Option.value_exn (Amount.add_fee amount fee)\n |> Amount.Signed.of_unsigned |> Amount.Signed.negate\n | Coinbase ->\n Amount.Signed.zero\n\nlet fee_excess ({ body = { tag; amount; _ }; common = { fee; _ } } : t) =\n match tag with\n | Payment | Stake_delegation ->\n (* For all user commands, the fee excess is just the fee. *)\n Fee_excess.of_single (Token_id.default, Fee.Signed.of_unsigned fee)\n | Fee_transfer ->\n let excess =\n Option.value_exn (Amount.add_fee amount fee)\n |> Amount.to_fee |> Fee.Signed.of_unsigned |> Fee.Signed.negate\n in\n Fee_excess.of_single (Token_id.default, excess)\n | Coinbase ->\n Fee_excess.of_single (Token_id.default, Fee.Signed.zero)\n\nlet expected_supply_increase (payload : payload) =\n let tag = payload.body.tag in\n match tag with\n | Coinbase ->\n payload.body.amount\n | Payment | Stake_delegation | Fee_transfer ->\n Amount.zero\n","(* user_command_intf.ml *)\n\n[%%import \"/src/config.mlh\"]\n\nopen Mina_base_import\nopen Core_kernel\nopen Snark_params.Tick\nopen Mina_numbers\n\nmodule type Gen_intf = sig\n type t\n\n module Gen : sig\n (** Generate a single transaction between\n * Generate random keys for sender and receiver\n * for fee $\\in [Currency.Fee.minimum_user_command_fee,\n * Currency.Fee.minimum_user_command_fee+fee_range]$\n * and an amount $\\in [1,max_amount]$\n *)\n val payment :\n ?sign_type:[ `Fake | `Real ]\n -> key_gen:\n (Signature_keypair.t * Signature_keypair.t) Quickcheck.Generator.t\n -> ?nonce:Account_nonce.t\n -> ?min_amount:int\n -> max_amount:int\n -> fee_range:int\n -> unit\n -> t Quickcheck.Generator.t\n\n (** Generate a single transaction between\n * $a, b \\in keys$\n * for fee $\\in [Currency.Fee.minimum_user_command_fee,\n * Currency.Fee.minimum_user_command_fee+fee_range]$\n * and an amount $\\in [1,max_amount]$\n *)\n val payment_with_random_participants :\n ?sign_type:[ `Fake | `Real ]\n -> keys:Signature_keypair.t array\n -> ?nonce:Account_nonce.t\n -> ?min_amount:int\n -> max_amount:int\n -> fee_range:int\n -> unit\n -> t Quickcheck.Generator.t\n\n val stake_delegation :\n key_gen:\n (Signature_keypair.t * Signature_keypair.t) Quickcheck.Generator.t\n -> ?nonce:Account_nonce.t\n -> fee_range:int\n -> unit\n -> t Quickcheck.Generator.t\n\n val stake_delegation_with_random_participants :\n keys:Signature_keypair.t array\n -> ?nonce:Account_nonce.t\n -> fee_range:int\n -> unit\n -> t Quickcheck.Generator.t\n\n (** Generate a valid sequence of payments based on the initial state of a\n ledger. Use this together with Ledger.gen_initial_ledger_state.\n *)\n val sequence :\n ?length:int\n -> ?sign_type:[ `Fake | `Real ]\n -> ( Signature_lib.Keypair.t\n * Currency.Amount.t\n * Mina_numbers.Account_nonce.t\n * Account_timing.t )\n array\n -> t list Quickcheck.Generator.t\n end\nend\n\nmodule type S = sig\n type t [@@deriving sexp, yojson, hash]\n\n (* type of signed commands, pre-Berkeley hard fork *)\n type t_v1\n\n include Comparable.S with type t := t\n\n include Hashable.S with type t := t\n\n val signature : t -> Signature.t\n\n val payload : t -> Signed_command_payload.t\n\n val fee : t -> Currency.Fee.t\n\n val nonce : t -> Account_nonce.t\n\n val signer : t -> Public_key.t\n\n val fee_token : t -> Token_id.t\n\n val fee_payer_pk : t -> Public_key.Compressed.t\n\n val fee_payer : t -> Account_id.t\n\n val fee_excess : t -> Fee_excess.t\n\n val token : t -> Token_id.t\n\n val receiver_pk : t -> Public_key.Compressed.t\n\n val receiver : t -> Account_id.t\n\n val public_keys : t -> Public_key.Compressed.t list\n\n val amount : t -> Currency.Amount.t option\n\n val memo : t -> Signed_command_memo.t\n\n val valid_until : t -> Global_slot_since_genesis.t\n\n (* for filtering *)\n val minimum_fee : Currency.Fee.t\n\n val has_insufficient_fee : t -> bool\n\n val tag : t -> Transaction_union_tag.t\n\n val tag_string : t -> string\n\n val to_input_legacy :\n Signed_command_payload.t -> (Field.t, bool) Random_oracle_input.Legacy.t\n\n include Gen_intf with type t := t\n\n module With_valid_signature : sig\n module Stable : sig\n module Latest : sig\n type nonrec t\n [@@deriving sexp, equal, bin_io, yojson, version, compare, hash]\n\n include Gen_intf with type t := t\n end\n\n module V2 = Latest\n end\n\n type t = Stable.Latest.t [@@deriving sexp, yojson, compare, hash]\n\n include Gen_intf with type t := t\n\n include Comparable.S with type t := t\n end\n\n val sign_payload :\n ?signature_kind:Mina_signature_kind.t\n -> Signature_lib.Private_key.t\n -> Signed_command_payload.t\n -> Signature.t\n\n val sign :\n ?signature_kind:Mina_signature_kind.t\n -> Signature_keypair.t\n -> Signed_command_payload.t\n -> With_valid_signature.t\n\n val check_signature : ?signature_kind:Mina_signature_kind.t -> t -> bool\n\n val create_with_signature_checked :\n ?signature_kind:Mina_signature_kind.t\n -> Signature.t\n -> Public_key.Compressed.t\n -> Signed_command_payload.t\n -> With_valid_signature.t option\n\n val check_valid_keys : t -> bool\n\n module For_tests : sig\n (** the signature kind is an argument, to match `sign`, but ignored *)\n val fake_sign :\n ?signature_kind:Mina_signature_kind.t\n -> Signature_keypair.t\n -> Signed_command_payload.t\n -> With_valid_signature.t\n end\n\n (** checks signature and keys *)\n val check : t -> With_valid_signature.t option\n\n val check_only_for_signature : t -> With_valid_signature.t option\n\n val to_valid_unsafe :\n t\n -> [ `If_this_is_used_it_should_have_a_comment_justifying_it of\n With_valid_signature.t ]\n\n (** Forget the signature check. *)\n val forget_check : With_valid_signature.t -> t\n\n (** returned status always `Accessed for fee payer *)\n val account_access_statuses :\n t\n -> Transaction_status.t\n -> (Account_id.t * [ `Accessed | `Not_accessed ]) list\n\n (** all account ids mentioned in a command *)\n val accounts_referenced : t -> Account_id.t list\n\n val filter_by_participant : t list -> Public_key.Compressed.t -> t list\n\n val of_base58_check_exn_v1 : string -> t_v1 Or_error.t\n\n val to_base58_check_v1 : t_v1 -> string\n\n include Codable.Base64_intf with type t := t\nend\n\nmodule type Full = sig\n module Payload = Signed_command_payload\n\n module Poly : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type ('payload, 'pk, 'signature) t =\n ( 'payload\n , 'pk\n , 'signature )\n Mina_wire_types.Mina_base.Signed_command.Poly.V1.t =\n { payload : 'payload; signer : 'pk; signature : 'signature }\n [@@deriving sexp, hash, yojson, equal, compare]\n end\n end]\n end\n\n [%%versioned:\n module Stable : sig\n [@@@with_top_version_tag]\n\n module V2 : sig\n type t =\n ( Payload.Stable.V2.t\n , Public_key.Stable.V1.t\n , Signature.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving sexp, hash, yojson, version]\n\n include Comparable.S with type t := t\n\n include Hashable.S with type t := t\n\n val account_access_statuses :\n t\n -> Transaction_status.t\n -> (Account_id.t * [ `Accessed | `Not_accessed ]) list\n\n val accounts_referenced : t -> Account_id.t list\n end\n\n module V1 : sig\n type t =\n ( Payload.Stable.V1.t\n , Public_key.Stable.V1.t\n , Signature.Stable.V1.t )\n Poly.Stable.V1.t\n [@@deriving compare, sexp, hash, yojson]\n\n val to_latest : t -> Latest.t\n end\n end]\n\n include S with type t = Stable.V2.t and type t_v1 = Stable.V1.t\nend\n","[%%import \"/src/config.mlh\"]\n\n[%%ifdef consensus_mechanism]\n\ninclude Pickles.Side_loaded.Verification_key\n\n[%%else]\n\nopen Core_kernel\n\nmodule G = struct\n open Snark_params.Tick\n\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Field.Stable.V1.t * Field.Stable.V1.t\n [@@deriving sexp, equal, compare, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\nmodule R = struct\n [%%versioned\n module Stable = struct\n module V2 = struct\n type t =\n G.Stable.V1.t Pickles_base.Side_loaded_verification_key.Repr.Stable.V2.t\n [@@deriving sexp, compare, equal, yojson]\n\n let to_latest = Fn.id\n end\n end]\nend\n\n[%%versioned_binable\nmodule Stable = struct\n module V2 = struct\n type t =\n ( G.Stable.V1.t\n , unit )\n Pickles_base.Side_loaded_verification_key.Poly.Stable.V2.t\n [@@deriving hash]\n\n open Pickles_base.Side_loaded_verification_key\n\n let to_latest = Fn.id\n\n let to_repr { Poly.step_data; max_width; wrap_index; wrap_vk = _ } =\n { Repr.Stable.V2.step_data; max_width; wrap_index }\n\n let of_repr { Repr.Stable.V2.step_data; max_width; wrap_index = c } =\n { Poly.step_data; max_width; wrap_index = c; wrap_vk = Some () }\n\n include\n Binable.Of_binable\n (R.Stable.V2)\n (struct\n type nonrec t = t\n\n let to_binable = to_repr\n\n let of_binable = of_repr\n end)\n\n let sexp_of_t t = R.sexp_of_t (to_repr t)\n\n let t_of_sexp sexp = of_repr (R.t_of_sexp sexp)\n\n let to_yojson t = R.to_yojson (to_repr t)\n\n let of_yojson json = Result.map ~f:of_repr (R.of_yojson json)\n\n let equal x y = R.equal (to_repr x) (to_repr y)\n\n let compare x y = R.compare (to_repr x) (to_repr y)\n end\nend]\n\nlet to_input x =\n Pickles_base.Side_loaded_verification_key.to_input\n ~field_of_int:Snark_params.Tick.Field.of_int x\n\nlet dummy : t =\n let open Pickles_types in\n { step_data = At_most.[]\n ; max_width = Pickles_base.Side_loaded_verification_key.Width.zero\n ; wrap_index =\n (let g = Snarkette.Pasta.Pallas.(to_affine_exn one) in\n { sigma_comm = Vector.init Dlog_plonk_types.Permuts.n ~f:(fun _ -> g)\n ; coefficients_comm =\n Vector.init Dlog_plonk_types.Columns.n ~f:(fun _ -> g)\n ; generic_comm = g\n ; psm_comm = g\n ; complete_add_comm = g\n ; mul_comm = g\n ; emul_comm = g\n ; endomul_scalar_comm = g\n } )\n ; wrap_vk = None\n }\n\n[%%endif]\n","(* state_hash.ml *)\nopen Core_kernel\nmodule T = Data_hash_lib.State_hash\ninclude T\n\nmodule State_hashes = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t =\n { mutable state_body_hash : State_body_hash.Stable.V1.t option\n ; state_hash : T.Stable.V1.t\n }\n [@@deriving equal, sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n let state_hash { state_hash; _ } = state_hash\n\n let state_body_hash t ~compute_hashes =\n match t.state_body_hash with\n | Some state_body_hash ->\n state_body_hash\n | None ->\n let { state_hash; state_body_hash } = compute_hashes () in\n assert (T.equal state_hash t.state_hash) ;\n assert (Option.is_some state_body_hash) ;\n t.state_body_hash <- state_body_hash ;\n Option.value_exn state_body_hash\nend\n\nmodule With_state_hashes = struct\n [%%versioned\n module Stable = struct\n [@@@no_toplevel_latest_type]\n\n module V1 = struct\n type 'a t = ('a, State_hashes.Stable.V1.t) With_hash.Stable.V1.t\n [@@deriving equal, sexp, to_yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n type 'a t = ('a, State_hashes.t) With_hash.t\n [@@deriving equal, sexp, to_yojson]\n\n open With_hash\n open State_hashes.Stable.Latest\n\n let data { data; _ } = data\n\n let hashes { hash = hashes; _ } = hashes\n\n let state_hash { hash = { state_hash; _ }; _ } = state_hash\n\n let state_body_hash { hash; data } ~compute_hashes =\n State_hashes.state_body_hash hash ~compute_hashes:(fun () ->\n compute_hashes data )\nend\n","(* verification_key_wire.ml *)\n\nopen Core_kernel\nopen Zkapp_basic\n\n(* the digest functions are declared locally in Zkapp_account, which depends on\n this module; the definitions here avoid a cyclic dependency\n*)\n\nlet digest_vk (t : Side_loaded_verification_key.t) =\n Random_oracle.(\n hash ~init:Hash_prefix_states.side_loaded_vk\n (pack_input (Side_loaded_verification_key.to_input t)))\n\nlet dummy_vk_hash =\n Memo.unit (fun () -> digest_vk Side_loaded_verification_key.dummy)\n\n[%%versioned_binable\nmodule Stable = struct\n module V1 = struct\n module T = struct\n type t = (Side_loaded_verification_key.t, F.t) With_hash.t\n [@@deriving sexp, yojson, equal, compare, hash]\n end\n\n include T\n\n let to_latest = Fn.id\n\n module M = struct\n type nonrec t = t\n\n (* don't send hash over the wire; restore hash on receipt *)\n\n let to_binable (t : t) = t.data\n\n let of_binable vk : t =\n let data = vk in\n let hash = digest_vk vk in\n { data; hash }\n end\n\n include\n Binable.Of_binable_without_uuid\n (Side_loaded_verification_key.Stable.V2)\n (M)\n end\nend]\n","open Core_kernel\nopen Mina_base_import\nopen Snark_params\nopen Snarky_backendless\nopen Tick\nopen Let_syntax\n\nlet merge_var ~height h1 h2 =\n Random_oracle.Checked.hash ~init:(Hash_prefix.merkle_tree height) [| h1; h2 |]\n\nmodule Merkle_tree =\n Snarky_backendless.Merkle_tree.Checked\n (Tick)\n (struct\n type value = Field.t\n\n type var = Field.Var.t\n\n let typ = Field.typ\n\n let merge ~height h1 h2 =\n Tick.make_checked (fun () -> merge_var ~height h1 h2)\n\n let assert_equal h1 h2 = Field.Checked.Assert.equal h1 h2\n\n let if_ = Field.Checked.if_\n end)\n (struct\n include Account\n\n let hash = Checked.digest\n end)\n\ninclude Ledger_hash0\n\n(* End boilerplate *)\nlet merge ~height (h1 : t) (h2 : t) =\n Random_oracle.hash\n ~init:(Hash_prefix.merkle_tree height)\n [| (h1 :> field); (h2 :> field) |]\n |> of_hash\n\nlet empty_hash = of_hash Outside_hash_image.t\n\nlet%bench \"Ledger_hash.merge ~height:1 empty_hash empty_hash\" =\n merge ~height:1 empty_hash empty_hash\n\nlet of_digest = Fn.compose Fn.id of_hash\n\ntype path = Random_oracle.Digest.t list\n\ntype _ Request.t +=\n | Get_path : Account.Index.t -> path Request.t\n | Get_element : Account.Index.t -> (Account.t * path) Request.t\n | Set : Account.Index.t * Account.t -> unit Request.t\n | Find_index : Account_id.t -> Account.Index.t Request.t\n\nlet reraise_merkle_requests (With { request; respond }) =\n match request with\n | Merkle_tree.Get_path addr ->\n respond (Delegate (Get_path addr))\n | Merkle_tree.Set (addr, account) ->\n respond (Delegate (Set (addr, account)))\n | Merkle_tree.Get_element addr ->\n respond (Delegate (Get_element addr))\n | _ ->\n unhandled\n\nlet get ~depth t addr =\n handle\n (fun () -> Merkle_tree.get_req ~depth (var_to_hash_packed t) addr)\n reraise_merkle_requests\n\n(*\n [modify_account t aid ~filter ~f] implements the following spec:\n\n - finds an account [account] in [t] for [aid] at path [addr] where [filter\n account] holds.\n note that the account is not guaranteed to have identifier [aid]; it might\n be a new account created to satisfy this request.\n - returns a root [t'] of a tree of depth [depth] which is [t] but with the\n account [f account] at path [addr].\n*)\nlet%snarkydef_ modify_account ~depth t aid\n ~(filter : Account.var -> 'a Checked.t) ~f =\n let%bind addr =\n request_witness\n (Account.Index.Unpacked.typ ~ledger_depth:depth)\n As_prover.(map (read Account_id.typ aid) ~f:(fun s -> Find_index s))\n in\n handle\n (fun () ->\n Merkle_tree.modify_req ~depth (var_to_hash_packed t) addr\n ~f:(fun account ->\n let%bind x = filter account in\n f x account ) )\n reraise_merkle_requests\n >>| var_of_hash_packed\n\n(*\n [modify_account_send t aid ~f] implements the following spec:\n\n - finds an account [account] in [t] at path [addr] whose account id is [aid]\n OR it is a fee transfer and is an empty account\n - returns a root [t'] of a tree of depth [depth] which is [t] but with the\n account [f account] at path [addr].\n*)\nlet%snarkydef_ modify_account_send ~depth t aid ~is_writeable ~f =\n modify_account ~depth t aid\n ~filter:(fun account ->\n [%with_label_ \"modify_account_send filter\"] (fun () ->\n let%bind account_already_there =\n Account_id.Checked.equal (Account.identifier_of_var account) aid\n in\n let%bind account_not_there =\n Public_key.Compressed.Checked.equal account.public_key\n Public_key.Compressed.(var_of_t empty)\n in\n let%bind not_there_but_writeable =\n Boolean.(account_not_there && is_writeable)\n in\n let%bind () =\n [%with_label_ \"account is either present or empty and writeable\"]\n (fun () ->\n Boolean.Assert.any\n [ account_already_there; not_there_but_writeable ] )\n in\n return not_there_but_writeable ) )\n ~f:(fun is_empty_and_writeable x -> f ~is_empty_and_writeable x)\n\n(*\n [modify_account_recv t aid ~f] implements the following spec:\n\n - finds an account [account] in [t] at path [addr] whose account id is [aid]\n OR which is an empty account\n - returns a root [t'] of a tree of depth [depth] which is [t] but with the\n account [f account] at path [addr].\n*)\nlet%snarkydef_ modify_account_recv ~depth t aid ~f =\n modify_account ~depth t aid\n ~filter:(fun account ->\n [%with_label_ \"modify_account_recv filter\"] (fun () ->\n let%bind account_already_there =\n Account_id.Checked.equal (Account.identifier_of_var account) aid\n in\n let%bind account_not_there =\n Public_key.Compressed.Checked.equal account.public_key\n Public_key.Compressed.(var_of_t empty)\n in\n let%bind () =\n [%with_label_ \"account is either present or empty\"] (fun () ->\n Boolean.Assert.any [ account_already_there; account_not_there ] )\n in\n return account_not_there ) )\n ~f:(fun is_empty_and_writeable x -> f ~is_empty_and_writeable x)\n","open Snark_params\nopen Snarky_backendless\nopen Tick\n\nmodule type S = sig\n include Ledger_hash_intf0.S\n\n type path = Random_oracle.Digest.t list\n\n type _ Request.t +=\n | Get_path : Account.Index.t -> path Request.t\n | Get_element : Account.Index.t -> (Account.t * path) Request.t\n | Set : Account.Index.t * Account.t -> unit Request.t\n | Find_index : Account_id.t -> Account.Index.t Request.t\n\n val get :\n depth:int -> var -> Account.Index.Unpacked.var -> Account.var Checked.t\n\n val merge : height:int -> t -> t -> t\n\n (** string representation of hash is Base58Check of bin_io representation *)\n val to_base58_check : t -> string\n\n val of_base58_check : string -> t Base.Or_error.t\n\n val empty_hash : t\n\n val of_digest : Random_oracle.Digest.t -> t\n\n val modify_account :\n depth:int\n -> var\n -> Account_id.var\n -> filter:(Account.var -> 'a Checked.t)\n -> f:('a -> Account.var -> Account.var Checked.t)\n -> var Checked.t\n\n val modify_account_send :\n depth:int\n -> var\n -> Account_id.var\n -> is_writeable:Boolean.var\n -> f:\n ( is_empty_and_writeable:Boolean.var\n -> Account.var\n -> Account.var Checked.t )\n -> var Checked.t\n\n val modify_account_recv :\n depth:int\n -> var\n -> Account_id.var\n -> f:\n ( is_empty_and_writeable:Boolean.var\n -> Account.var\n -> Account.var Checked.t )\n -> var Checked.t\nend\n","include Ledger_hash\n\nlet of_ledger_hash (h : Ledger_hash.t) : t = h\n\nlet to_ledger_hash (t : t) : Ledger_hash.t = t\n","open Core_kernel\n\nmodule type S = sig\n module Stable : sig\n module V1 : sig\n type t = private Zkapp_basic.F.t\n\n val to_yojson : t -> Yojson.Safe.t\n\n val of_yojson : Yojson.Safe.t -> t Ppx_deriving_yojson_runtime.error_or\n\n val bin_size_t : t Bin_prot.Size.sizer\n\n val bin_write_t : t Bin_prot.Write.writer\n\n val bin_read_t : t Bin_prot.Read.reader\n\n val __bin_read_t__ : (int -> t) Bin_prot.Read.reader\n\n val bin_shape_t : Bin_prot.Shape.t\n\n val bin_writer_t : t Bin_prot.Type_class.writer\n\n val bin_reader_t : t Bin_prot.Type_class.reader\n\n val bin_t : t Bin_prot.Type_class.t\n\n val __versioned__ : unit\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n val compare : t -> t -> int\n\n val equal : t -> t -> bool\n\n val hash_fold_t :\n Base_internalhash_types.state -> t -> Base_internalhash_types.state\n\n val hash : t -> int\n end\n\n module Latest = V1\n end\n\n type t = Stable.V1.t\n\n val to_yojson : t -> Yojson.Safe.t\n\n val of_yojson : Yojson.Safe.t -> t Ppx_deriving_yojson_runtime.error_or\n\n val t_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> t\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n val compare : t -> t -> int\n\n val equal : t -> t -> bool\n\n val hash_fold_t :\n Base_internalhash_types.state -> t -> Base_internalhash_types.state\n\n val hash : t -> int\nend\n\nmodule type S_checked = sig\n open Pickles.Impls.Step\n\n type t = private Field.t\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t\n\n val equal : t -> t -> Boolean.var\n\n module Assert : sig\n val equal : t -> t -> unit\n end\nend\n\nmodule type S_aux = sig\n type t\n\n type checked\n\n val typ : (checked, t) Pickles.Impls.Step.Typ.t\n\n val constant : t -> checked\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\n[%%ifdef consensus_mechanism]\n\nopen Snark_params.Tick\n\n[%%endif]\n\nmodule Poly = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type 'comm t = { account_update : 'comm; calls : 'comm }\n [@@deriving hlist, sexp, yojson]\n end\n end]\n\n let to_field_elements (t : 'c t) : 'c array =\n let [ x0; x1 ] = to_hlist t in\n [| x0; x1 |]\nend\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Zkapp_command.Transaction_commitment.Stable.V1.t Poly.Stable.V1.t\n [@@deriving sexp, yojson]\n\n let to_latest = Fn.id\n end\nend]\n\nlet to_field_elements : t -> _ = Poly.to_field_elements\n\nlet of_tree (type account_update)\n ({ account_update = _; account_update_digest; calls } :\n ( account_update\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.Tree.t ) : t =\n { account_update =\n (account_update_digest :> Zkapp_command.Transaction_commitment.t)\n ; calls =\n ( Zkapp_command.Call_forest.hash calls\n :> Zkapp_command.Transaction_commitment.t )\n }\n\nlet zkapp_statements_of_forest' (type data)\n (forest : data Zkapp_command.Call_forest.With_hashes_and_data.t) :\n (data * t) Zkapp_command.Call_forest.With_hashes_and_data.t =\n Zkapp_command.Call_forest.mapi_with_trees forest\n ~f:(fun _i (account_update, data) tree ->\n (account_update, (data, of_tree tree)) )\n\nlet zkapp_statements_of_forest (type account_update)\n (forest : (account_update, _, _) Zkapp_command.Call_forest.t) :\n (account_update * t, _, _) Zkapp_command.Call_forest.t =\n Zkapp_command.Call_forest.mapi_with_trees forest\n ~f:(fun _i account_update tree -> (account_update, of_tree tree))\n\n[%%ifdef consensus_mechanism]\n\nmodule Checked = struct\n type t = Zkapp_command.Transaction_commitment.Checked.t Poly.t\n\n let to_field_elements : t -> _ = Poly.to_field_elements\n\n open Pickles.Impls.Step\n\n module Assert = struct\n let equal (t1 : t) (t2 : t) =\n Array.iter2_exn ~f:Field.Assert.equal (to_field_elements t1)\n (to_field_elements t2)\n end\nend\n\nlet typ =\n let open Poly in\n Typ.of_hlistable\n Zkapp_command.Transaction_commitment.[ typ; typ ]\n ~var_to_hlist:to_hlist ~var_of_hlist:of_hlist ~value_to_hlist:to_hlist\n ~value_of_hlist:of_hlist\n\n[%%endif]\n","open Snark_params.Tick.Run\n\ntype 'a t = 'a As_prover.Ref.t\n\nlet get = As_prover.Ref.get\n\nlet create = As_prover.Ref.create\n\nlet if_ b ~then_ ~else_ =\n create (fun () ->\n get (if Impl.As_prover.read Boolean.typ b then then_ else else_) )\n\nlet map t ~f = create (fun () -> f (get t))\n\nlet typ = Typ.Internal.ref\n","open Core_kernel\n\n(* Same as the type of the field account_updates in Mina_base.Zkapp_command.t *)\ntype t =\n ( Account_update.t\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.t\n\ntype account_update =\n (Account_update.t, Zkapp_command.Digest.Account_update.t) With_hash.t\n\nlet empty () = []\n\nlet if_ = Zkapp_command.value_if\n\nlet is_empty = List.is_empty\n\nlet pop_exn : t -> (Account_update.t * t) * t = function\n | { stack_hash = _\n ; elt = { account_update; calls; account_update_digest = _ }\n }\n :: xs ->\n ((account_update, calls), xs)\n | _ ->\n failwith \"pop_exn\"\n\nlet push ~account_update ~calls t =\n Zkapp_command.Call_forest.cons ~calls account_update t\n\nlet hash (t : t) = Zkapp_command.Call_forest.hash t\n\nopen Snark_params.Tick.Run\n\nmodule Checked = struct\n module F = Zkapp_command.Digest.Forest.Checked\n module V = Prover_value\n\n type account_update =\n { account_update :\n ( Account_update.Body.Checked.t\n , Zkapp_command.Digest.Account_update.Checked.t )\n With_hash.t\n ; control : Control.t Prover_value.t\n }\n\n let account_update_typ () :\n ( account_update\n , (Account_update.t, Zkapp_command.Digest.Account_update.t) With_hash.t\n )\n Typ.t =\n let (Typ typ) =\n Typ.(\n Account_update.Body.typ () * Prover_value.typ ()\n * Zkapp_command.Digest.Account_update.typ)\n |> Typ.transport\n ~back:(fun ((body, authorization), hash) ->\n { With_hash.data = { Account_update.body; authorization }; hash }\n )\n ~there:(fun { With_hash.data = { Account_update.body; authorization }\n ; hash\n } -> ((body, authorization), hash) )\n |> Typ.transport_var\n ~back:(fun ((account_update, control), hash) ->\n { account_update = { hash; data = account_update }; control } )\n ~there:(fun { account_update = { hash; data = account_update }\n ; control\n } -> ((account_update, control), hash) )\n in\n Typ\n { typ with\n check =\n (fun ( { account_update = { hash; data = account_update }\n ; control = _\n } as x ) ->\n Impl.make_checked (fun () ->\n Impl.run_checked (typ.check x) ;\n Field.Assert.equal\n (hash :> Field.t)\n ( Zkapp_command.Call_forest.Digest.Account_update.Checked\n .create account_update\n :> Field.t ) ) )\n }\n\n type t =\n ( ( Account_update.t\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.t\n V.t\n , F.t )\n With_hash.t\n\n let if_ b ~then_:(t : t) ~else_:(e : t) : t =\n { hash = F.if_ b ~then_:t.hash ~else_:e.hash\n ; data = V.if_ b ~then_:t.data ~else_:e.data\n }\n\n let empty =\n Zkapp_command.Digest.Forest.constant\n Zkapp_command.Call_forest.With_hashes.empty\n\n let is_empty ({ hash = x; _ } : t) = F.equal empty x\n\n let empty () : t = { hash = empty; data = V.create (fun () -> []) }\n\n let pop_exn ({ hash = h; data = r } : t) : (account_update * t) * t =\n with_label \"Zkapp_call_forest.pop_exn\" (fun () ->\n let hd_r =\n V.create (fun () -> V.get r |> List.hd_exn |> With_stack_hash.elt)\n in\n let account_update = V.create (fun () -> (V.get hd_r).account_update) in\n let auth =\n V.(create (fun () -> (V.get account_update).authorization))\n in\n let account_update =\n exists (Account_update.Body.typ ()) ~compute:(fun () ->\n (V.get account_update).body )\n in\n let account_update =\n With_hash.of_data account_update\n ~hash_data:Zkapp_command.Digest.Account_update.Checked.create\n in\n let subforest : t =\n let subforest = V.create (fun () -> (V.get hd_r).calls) in\n let subforest_hash =\n exists Zkapp_command.Digest.Forest.typ ~compute:(fun () ->\n Zkapp_command.Call_forest.hash (V.get subforest) )\n in\n { hash = subforest_hash; data = subforest }\n in\n let tl_hash =\n exists Zkapp_command.Digest.Forest.typ ~compute:(fun () ->\n V.get r |> List.tl_exn |> Zkapp_command.Call_forest.hash )\n in\n let tree_hash =\n Zkapp_command.Digest.Tree.Checked.create\n ~account_update:account_update.hash ~calls:subforest.hash\n in\n let hash_cons =\n Zkapp_command.Digest.Forest.Checked.cons tree_hash tl_hash\n in\n F.Assert.equal hash_cons h ;\n ( ( ({ account_update; control = auth }, subforest)\n , { hash = tl_hash\n ; data = V.(create (fun () -> List.tl_exn (get r)))\n } )\n : (account_update * t) * t ) )\n\n let pop ~dummy ~dummy_tree_hash ({ hash = h; data = r } : t) :\n (account_update * t) * t =\n with_label \"Zkapp_call_forest.pop\" (fun () ->\n let hd_r =\n V.create (fun () ->\n match V.get r with\n | hd :: _ ->\n With_stack_hash.elt hd\n | [] ->\n dummy )\n in\n let account_update = V.create (fun () -> (V.get hd_r).account_update) in\n let auth =\n V.(create (fun () -> (V.get account_update).authorization))\n in\n let account_update =\n exists (Account_update.Body.typ ()) ~compute:(fun () ->\n (V.get account_update).body )\n in\n let account_update =\n With_hash.of_data account_update\n ~hash_data:Zkapp_command.Digest.Account_update.Checked.create\n in\n let subforest : t =\n let subforest = V.create (fun () -> (V.get hd_r).calls) in\n let subforest_hash =\n exists Zkapp_command.Digest.Forest.typ ~compute:(fun () ->\n Zkapp_command.Call_forest.hash (V.get subforest) )\n in\n { hash = subforest_hash; data = subforest }\n in\n let tl_hash =\n exists Zkapp_command.Digest.Forest.typ ~compute:(fun () ->\n match V.get r with\n | _ :: tl ->\n Zkapp_command.Call_forest.hash tl\n | [] ->\n Zkapp_command.Digest.Forest.empty )\n in\n let tree_hash =\n Zkapp_command.Digest.Tree.Checked.create\n ~account_update:account_update.hash ~calls:subforest.hash\n in\n let hash_cons =\n Zkapp_command.Digest.Forest.Checked.cons tree_hash tl_hash\n in\n let () =\n let correct = F.equal hash_cons h in\n let empty = F.equal F.empty h in\n let is_dummy =\n Zkapp_command.Digest.Tree.Checked.equal tree_hash dummy_tree_hash\n in\n Boolean.(Assert.any [ correct; empty &&& is_dummy ])\n in\n ( ( ({ account_update; control = auth }, subforest)\n , { hash = tl_hash\n ; data =\n V.(\n create (fun () ->\n match get r with _ :: tl -> tl | [] -> [] ))\n } )\n : (account_update * t) * t ) )\n\n let push\n ~account_update:\n { account_update = { hash = account_update_hash; data = account_update }\n ; control = auth\n } ~calls:({ hash = calls_hash; data = calls } : t)\n ({ hash = tl_hash; data = tl_data } : t) : t =\n with_label \"Zkapp_call_forest.push\" (fun () ->\n let tree_hash =\n Zkapp_command.Digest.Tree.Checked.create\n ~account_update:account_update_hash ~calls:calls_hash\n in\n let hash_cons =\n Zkapp_command.Digest.Forest.Checked.cons tree_hash tl_hash\n in\n let data =\n V.create (fun () ->\n let body =\n As_prover.read (Account_update.Body.typ ()) account_update\n in\n let authorization = V.get auth in\n let tl = V.get tl_data in\n let account_update : Account_update.t = { body; authorization } in\n let calls = V.get calls in\n let res =\n Zkapp_command.Call_forest.cons ~calls account_update tl\n in\n (* Sanity check; we're re-hashing anyway, might as well make sure it's\n consistent.\n *)\n assert (\n Zkapp_command.Digest.Forest.(\n equal\n (As_prover.read typ hash_cons)\n (Zkapp_command.Call_forest.hash res)) ) ;\n res )\n in\n ({ hash = hash_cons; data } : t) )\n\n let hash ({ hash; _ } : t) = hash\nend\n\nlet typ : (Checked.t, t) Typ.t =\n Typ.(Zkapp_command.Digest.Forest.typ * Prover_value.typ ())\n |> Typ.transport\n ~back:(fun (_digest, forest) ->\n Zkapp_command.Call_forest.map\n ~f:(fun account_update -> account_update)\n forest )\n ~there:(fun forest ->\n ( Zkapp_command.Call_forest.hash forest\n , Zkapp_command.Call_forest.map\n ~f:(fun account_update -> account_update)\n forest ) )\n |> Typ.transport_var\n ~back:(fun (digest, forest) -> { With_hash.hash = digest; data = forest })\n ~there:(fun { With_hash.hash = digest; data = forest } ->\n (digest, forest) )\n","open Core_kernel\nopen Mina_base_import\n\nmodule type Full = sig\n module Single : sig\n module Stable : sig\n module V2 : sig\n type t = private\n { receiver_pk : Public_key.Compressed.Stable.V1.t\n ; fee : Currency.Fee.Stable.V1.t\n ; fee_token : Token_id.Stable.V2.t\n }\n [@@deriving bin_io, sexp, compare, equal, yojson, version, hash]\n end\n\n module Latest = V2\n end\n\n type t = Stable.Latest.t = private\n { receiver_pk : Public_key.Compressed.t\n ; fee : Currency.Fee.t\n ; fee_token : Token_id.t\n }\n [@@deriving sexp, compare, yojson, hash]\n\n include Comparable.S with type t := t\n\n include Codable.Base58_check_intf with type t := t\n\n val create :\n receiver_pk:Public_key.Compressed.t\n -> fee:Currency.Fee.t\n -> fee_token:Token_id.t\n -> t\n\n val receiver_pk : t -> Public_key.Compressed.t\n\n val receiver : t -> Account_id.t\n\n val fee : t -> Currency.Fee.t\n\n val fee_token : t -> Token_id.t\n\n module Gen : sig\n val with_random_receivers :\n ?min_fee:int\n -> max_fee:int\n -> token:Token_id.t Quickcheck.Generator.t\n -> Signature_keypair.t array\n -> t Quickcheck.Generator.t\n end\n end\n\n module Stable : sig\n module V2 : sig\n type t = private Single.Stable.V2.t One_or_two.Stable.V1.t\n [@@deriving bin_io, sexp, compare, equal, yojson, version, hash]\n end\n\n module Latest = V2\n end\n\n type t = Stable.Latest.t [@@deriving sexp, compare, yojson, hash]\n\n type single = Single.t = private\n { receiver_pk : Public_key.Compressed.t\n ; fee : Currency.Fee.t\n ; fee_token : Token_id.t\n }\n [@@deriving sexp, compare, yojson, hash]\n\n include Comparable.S with type t := t\n\n val create : Single.t -> Single.t option -> t Or_error.t\n\n val create_single :\n receiver_pk:Public_key.Compressed.t\n -> fee:Currency.Fee.t\n -> fee_token:Token_id.t\n -> t\n\n val to_singles : t -> Single.t One_or_two.t\n\n val of_singles : Single.t One_or_two.t -> t Or_error.t\n\n val fee_excess : t -> Fee_excess.t Or_error.t\n\n val fee_token : single -> Token_id.t\n\n val fee_tokens : t -> Token_id.t One_or_two.t\n\n val receiver_pks : t -> Public_key.Compressed.t list\n\n val receivers : t -> Account_id.t list\n\n val fee_payer_pk : t -> Public_key.Compressed.t\n\n val map : t -> f:(Single.t -> 'b) -> 'b One_or_two.t\n\n val fold : t -> init:'acc -> f:('acc -> Single.t -> 'acc) -> 'acc\n\n val to_list : t -> Single.t list\n\n val to_numbered_list : t -> (int * Single.t) list\nend\n","open Core_kernel\nopen Mina_base_import\n\nmodule type Full = sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t = private\n { receiver_pk : Public_key.Compressed.Stable.V1.t\n ; fee : Currency.Fee.Stable.V1.t\n }\n [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n\n val create : receiver_pk:Public_key.Compressed.t -> fee:Currency.Fee.t -> t\n\n include Comparable.S with type t := t\n\n include Codable.Base58_check_intf with type t := t\n\n val receiver_pk : t -> Public_key.Compressed.t\n\n val receiver : t -> Account_id.t\n\n val fee : t -> Currency.Fee.t\n\n val to_fee_transfer : t -> Fee_transfer.Single.t\n\n module Gen : sig\n (** [gen ?min_fee max_fee] generates fee transfers between [min_fee] and\n [max_fee].\n\n @param min_fee defaults to zero *)\n val gen :\n ?min_fee:Currency.Fee.t -> Currency.Fee.t -> t Quickcheck.Generator.t\n\n (** [with_random_receivers ~key ?min_fee coinbase_amount] creates coinbase\n fee transfers with fees between [min_fee] and [coinbase_amount]\n\n @param min_fee defaults to {!val:Currency.Fee.zero}\n *)\n val with_random_receivers :\n keys:Signature_keypair.t array\n -> ?min_fee:Currency.Fee.t\n -> Currency.Amount.t\n -> t Quickcheck.Generator.t\n end\nend\n","open Core_kernel\nopen Mina_base_import\n\nmodule type Full = sig\n module Fee_transfer = Coinbase_fee_transfer\n\n module Stable : sig\n module V1 : sig\n type t = private\n { receiver : Public_key.Compressed.Stable.V1.t\n ; amount : Currency.Amount.Stable.V1.t\n ; fee_transfer : Fee_transfer.Stable.V1.t option\n }\n [@@deriving sexp, bin_io, compare, equal, version, hash, yojson]\n end\n\n module Latest = V1\n end\n\n (* bin_io intentionally omitted in deriving list *)\n type t = Stable.Latest.t = private\n { receiver : Public_key.Compressed.t\n ; amount : Currency.Amount.t\n ; fee_transfer : Fee_transfer.t option\n }\n [@@deriving sexp, compare, equal, hash, yojson]\n\n include Codable.Base58_check_intf with type t := t\n\n val receiver_pk : t -> Public_key.Compressed.t\n\n val receiver : t -> Account_id.t\n\n val fee_payer_pk : t -> Public_key.Compressed.t\n\n val amount : t -> Currency.Amount.t\n\n val fee_transfer : t -> Fee_transfer.t option\n\n val account_access_statuses :\n t\n -> Transaction_status.t\n -> (Account_id.t * [ `Accessed | `Not_accessed ]) list\n\n val accounts_referenced : t -> Account_id.t list\n\n val create :\n amount:Currency.Amount.t\n -> receiver:Public_key.Compressed.t\n -> fee_transfer:Fee_transfer.t option\n -> t Or_error.t\n\n val expected_supply_increase : t -> Currency.Amount.t Or_error.t\n\n val fee_excess : t -> Fee_excess.t Or_error.t\n\n module Gen : sig\n val gen :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> (t * [ `Supercharged_coinbase of bool ]) Quickcheck.Generator.t\n\n (** Creates coinbase with reward between [min_amount] and [max_amount]. The generated amount[coinbase_amount] is then used as the upper bound for the fee transfer. *)\n val with_random_receivers :\n keys:Signature_keypair.t array\n -> min_amount:int\n -> max_amount:int\n -> fee_transfer:\n ( coinbase_amount:Currency.Amount.t\n -> Fee_transfer.t Quickcheck.Generator.t )\n -> t Quickcheck.Generator.t\n end\nend\n","(** Pending_coinbase is to keep track of all the coinbase transactions that have been applied to the ledger but for which there is no ledger proof yet. Every ledger proof corresponds to a sequence of coinbase transactions which is part of all the transactions it proves. Each of these sequences[Stack] are stored using the merkle tree representation. The stacks are operated in a FIFO manner by keeping track of its positions in the merkle tree. Whenever a ledger proof is emitted, the oldest stack is removed from the tree and when a new coinbase is applied, the latest stack is updated with the new coinbase.\n The operations on the merkle tree of coinbase stacks include:\n 1) adding a new singleton stack\n 2) updating the latest stack when a new coinbase is added to it\n 2) deleting the oldest stack\n\n A stack can be either be created or modified by pushing a coinbase on to it.\n\n This module also provides an interface for the checked computations required required to prove it in snark\n\n Stack operations are done for transaction snarks and tree operations are done for the blockchain snark*)\n\nopen Core_kernel\nopen Snark_params\nopen Snarky_backendless\nopen Tick\nopen Signature_lib\nopen Currency\n\nmodule type S = sig\n type t [@@deriving sexp, to_yojson]\n\n module Stable : sig\n module V2 : sig\n type nonrec t = t [@@deriving bin_io, sexp, to_yojson, version]\n end\n\n module Latest = V2\n end\n\n module Coinbase_data : sig\n module Stable : sig\n module V1 : sig\n type t = Public_key.Compressed.Stable.V1.t * Amount.Stable.V1.t\n [@@deriving sexp, bin_io, to_yojson]\n end\n\n module Latest = V1\n end\n\n type t = Stable.Latest.t [@@deriving sexp, to_yojson]\n\n type var = Public_key.Compressed.var * Amount.var\n\n val typ : (var, t) Typ.t\n\n val empty : t\n\n val of_coinbase : Coinbase.t -> t\n\n val genesis : t\n\n val var_of_t : t -> var\n end\n\n module type Data_hash_intf = sig\n type t = private Field.t [@@deriving sexp, compare, equal, yojson, hash]\n\n type var\n\n val var_of_t : t -> var\n\n val typ : (var, t) Typ.t\n\n val var_to_hash_packed : var -> Field.Var.t\n\n val equal_var : var -> var -> Boolean.var Tick.Checked.t\n\n val to_bytes : t -> string\n\n val to_bits : t -> bool list\n\n val to_base58_check : t -> string\n\n val of_base58_check_exn : string -> t\n\n val gen : t Quickcheck.Generator.t\n end\n\n module rec Hash : sig\n include Data_hash_intf\n\n val merge : height:int -> t -> t -> t\n\n val empty_hash : t\n\n val of_digest : Random_oracle.Digest.t -> t\n end\n\n module Hash_versioned : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type nonrec t = Hash.t [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n end\n\n module Stack_versioned : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type nonrec t [@@deriving sexp, compare, equal, yojson, hash]\n end\n end]\n end\n\n module Stack : sig\n type t = Stack_versioned.t [@@deriving sexp, compare, equal, yojson, hash]\n\n type var\n\n val data_hash : t -> Hash.t\n\n val var_of_t : t -> var\n\n val typ : (var, t) Typ.t\n\n val gen : t Quickcheck.Generator.t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val to_bits : t -> bool list\n\n val to_bytes : t -> string\n\n val equal_var : var -> var -> Boolean.var Tick.Checked.t\n\n val var_to_input : var -> Field.Var.t Random_oracle.Input.Chunked.t\n\n val empty : t\n\n (** Creates a new stack with the state stack from an existing stack*)\n val create_with : t -> t\n\n val equal_data : t -> t -> bool\n\n val equal_state_hash : t -> t -> bool\n\n (** The two stacks are connected. This should be used instead of `equal` to\n check one transaction snark statement follow the other.*)\n val connected : ?prev:t option -> first:t -> second:t -> unit -> bool\n\n val push_coinbase : Coinbase.t -> t -> t\n\n val push_state :\n State_body_hash.t -> Mina_numbers.Global_slot_since_genesis.t -> t -> t\n\n module Checked : sig\n type t = var\n\n val push_coinbase : Coinbase_data.var -> t -> t Tick.Checked.t\n\n val push_state :\n State_body_hash.var\n -> Mina_numbers.Global_slot_since_genesis.Checked.var\n -> t\n -> t Tick.Checked.t\n\n val if_ : Boolean.var -> then_:t -> else_:t -> t Tick.Checked.t\n\n val check_merge :\n transition1:t * t -> transition2:t * t -> Boolean.var Tick.Checked.t\n\n val empty : t\n\n val create_with : t -> t\n end\n end\n\n module State_stack : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t\n end\n end]\n end\n\n module Update : sig\n module Action : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t =\n | Update_none\n | Update_one\n | Update_two_coinbase_in_first\n | Update_two_coinbase_in_second\n [@@deriving sexp, to_yojson]\n end\n end]\n\n type var = Boolean.var * Boolean.var\n\n val typ : (var, t) Typ.t\n\n val var_of_t : t -> var\n end\n\n module Poly : sig\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type ('action, 'coinbase_amount) t =\n { action : 'action; coinbase_amount : 'coinbase_amount }\n [@@deriving sexp]\n end\n end]\n end\n\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t = (Action.Stable.V1.t, Amount.Stable.V1.t) Poly.Stable.V1.t\n [@@deriving sexp, to_yojson]\n end\n end]\n\n type var = (Action.var, Amount.var) Poly.t\n\n val genesis : t\n\n val typ : (var, t) Typ.t\n\n val var_of_t : t -> var\n end\n\n val create : depth:int -> unit -> t Or_error.t\n\n (** Delete the oldest stack*)\n val remove_coinbase_stack : depth:int -> t -> (Stack.t * t) Or_error.t\n\n (** Root of the merkle tree that has stacks as leaves*)\n val merkle_root : t -> Hash.t\n\n val handler :\n depth:int -> t -> is_new_stack:bool -> (request -> response) Staged.t\n\n (** Update the current working stack or if [is_new_stack] add as the new working stack*)\n val update_coinbase_stack :\n depth:int -> t -> Stack.t -> is_new_stack:bool -> t Or_error.t\n\n (** Stack that is currently being updated. if [is_new_stack] then a new stack is returned*)\n val latest_stack : t -> is_new_stack:bool -> Stack.t Or_error.t\n\n (** The stack that corresponds to the next ledger proof that is to be generated*)\n val oldest_stack : t -> Stack.t Or_error.t\n\n (** Hash of the auxiliary data (everything except the merkle root (Hash.t))*)\n val hash_extra : t -> string\n\n module Checked : sig\n type var = Hash.var\n\n type path\n\n module Address : sig\n type value\n\n type var\n\n val typ : depth:int -> (var, value) Typ.t\n end\n\n type _ Request.t +=\n | Coinbase_stack_path : Address.value -> path Request.t\n | Get_coinbase_stack : Address.value -> (Stack.t * path) Request.t\n | Set_coinbase_stack : Address.value * Stack.t -> unit Request.t\n | Set_oldest_coinbase_stack : Address.value * Stack.t -> unit Request.t\n | Find_index_of_newest_stacks :\n Update.Action.t\n -> (Address.value * Address.value) Request.t\n | Find_index_of_oldest_stack : Address.value Request.t\n | Get_previous_stack : State_stack.t Request.t\n\n val get : depth:int -> var -> Address.var -> Stack.var Tick.Checked.t\n\n (**\n [update_stack t ~is_new_stack updated_stack] implements the following spec:\n - gets the address[addr] of the latest stack or a new stack\n - finds a coinbase stack in [t] at path [addr] and pushes the coinbase_data on to the stack\n - returns a root [t'] of the tree\n *)\n val add_coinbase :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> var\n -> Update.var\n -> coinbase_receiver:Public_key.Compressed.var\n -> supercharge_coinbase:Boolean.var\n -> State_body_hash.var\n -> Mina_numbers.Global_slot_since_genesis.Checked.t\n -> var Tick.Checked.t\n\n (**\n [pop_coinbases t pk updated_stack] implements the following spec:\n\n - gets the address[addr] of the oldest stack.\n - finds a coinbase stack in [t] at path [addr] and replaces it with empty stack if a [proof_emitted] is true\n - returns a root [t'] of the tree\n *)\n val pop_coinbases :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> var\n -> proof_emitted:Boolean.var\n -> (var * Stack.var) Tick.Checked.t\n end\nend\n","open Async_kernel\n\nlet run_in_thread f = Deferred.return (f ())\n\nlet block_on_async_exn f =\n let res = f () in\n match Async_kernel.Deferred.peek res with\n | Some res ->\n res\n | None ->\n failwith\n \"block_on_async_exn: Cannot block thread, and the deferred computation \\\n did not resolve immediately.\"\n","module type Full = sig\n open Core_kernel\n open Snark_params.Tick\n\n type t [@@deriving sexp, equal, compare, hash, yojson]\n\n include Hashable with type t := t\n\n type value [@@deriving sexp, equal, compare, hash]\n\n type var\n\n val var_of_t : t -> var\n\n val typ : (var, t) Typ.t\n\n val var_to_input : var -> Field.Var.t Random_oracle.Input.Chunked.t\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val genesis :\n constraint_constants:Genesis_constants.Constraint_constants.t\n -> genesis_ledger_hash:Ledger_hash.t\n -> t\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving bin_io, sexp, equal, compare, hash, yojson, version]\n end\n\n module Latest : module type of V1\n end\n\n module Aux_hash : sig\n type t\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving bin_io, sexp, equal, compare, hash, yojson, version]\n end\n\n module Latest : module type of V1\n end\n\n val of_bytes : string -> t\n\n val to_bytes : t -> string\n\n val to_base58_check : t -> string\n\n val of_base58_check_exn : string -> t\n\n val compare : t -> t -> int\n\n val sexp_of_t : t -> Ppx_sexp_conv_lib.Sexp.t\n\n val dummy : t\n\n val of_sha256 : Digestif.SHA256.t -> t\n\n val gen : t Quickcheck.Generator.t\n end\n\n module Pending_coinbase_aux : sig\n type t\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving bin_io, sexp, equal, compare, hash, yojson, version]\n end\n\n module Latest : module type of V1\n end\n\n val to_base58_check : t -> string\n\n val of_base58_check_exn : string -> t\n\n val dummy : t\n end\n\n val ledger_hash : t -> Ledger_hash.t\n\n val aux_hash : t -> Aux_hash.t\n\n val pending_coinbase_aux : t -> Pending_coinbase_aux.t\n\n val pending_coinbase_hash : t -> Pending_coinbase.Hash.t\n\n val pending_coinbase_hash_var : var -> Pending_coinbase.Hash.var\n\n val of_aux_ledger_and_coinbase_hash :\n Aux_hash.t -> Ledger_hash.t -> Pending_coinbase.t -> t\nend\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V1 = struct\n type ('caller, 'zkapp_command) t =\n { caller : 'caller; caller_caller : 'caller; calls : 'zkapp_command }\n [@@deriving make, fields, sexp, yojson]\n end\nend]\n\ntype value =\n ( Token_id.t\n , ( Account_update.t\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.t )\n t\n\ntype ('caller, 'zkapp_command) frame = ('caller, 'zkapp_command) t\n\nlet empty : value =\n { caller = Token_id.default; caller_caller = Token_id.default; calls = [] }\n\nmodule type Stack_frame_digest_intf = sig\n include Digest_intf.S\n\n val create :\n ( Token_id.t\n , ( 'p\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.t )\n frame\n -> t\n\n val gen : t Quickcheck.Generator.t\n\n open Pickles.Impls.Step\n\n module Checked : sig\n include Digest_intf.S_checked\n\n val create :\n hash_zkapp_command:\n ('zkapp_command -> Zkapp_command.Digest.Forest.Checked.t)\n -> (Token_id.Checked.t, 'zkapp_command) frame\n -> t\n end\n\n val typ : (Checked.t, t) Typ.t\nend\n\nmodule Wire_types = Mina_wire_types.Mina_base.Stack_frame.Digest\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Stack_frame_digest_intf with type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Kimchi_backend.Pasta.Basic.Fp.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n open Pickles.Impls.Step\n\n let gen = Field.Constant.gen\n\n let to_input (type p)\n ({ caller; caller_caller; calls } :\n ( Token_id.t\n , ( p\n , Zkapp_command.Digest.Account_update.t\n , Zkapp_command.Digest.Forest.t )\n Zkapp_command.Call_forest.t )\n frame ) =\n List.reduce_exn ~f:Random_oracle.Input.Chunked.append\n [ Token_id.to_input caller\n ; Token_id.to_input caller_caller\n ; Random_oracle.Input.Chunked.field\n (Zkapp_command.Call_forest.hash calls :> Field.Constant.t)\n ]\n\n let create frame =\n Random_oracle.hash ~init:Hash_prefix_states.account_update_stack_frame\n (Random_oracle.pack_input (to_input frame))\n\n module Checked = struct\n include Field\n\n let to_input (type zkapp_command)\n ~(hash_zkapp_command :\n zkapp_command -> Zkapp_command.Digest.Forest.Checked.t )\n ({ caller; caller_caller; calls } : _ frame) =\n List.reduce_exn ~f:Random_oracle.Input.Chunked.append\n [ Token_id.Checked.to_input caller\n ; Token_id.Checked.to_input caller_caller\n ; Random_oracle.Input.Chunked.field (hash_zkapp_command calls :> Field.t)\n ]\n\n let create ~hash_zkapp_command frame =\n Random_oracle.Checked.hash\n ~init:Hash_prefix_states.account_update_stack_frame\n (Random_oracle.Checked.pack_input (to_input ~hash_zkapp_command frame))\n end\n\n let typ = Field.typ\nend\n\nmodule Digest = Wire_types.Make (Make_sig) (Make_str)\n\nmodule Checked = struct\n type nonrec 'zkapp_command t = (Token_id.Checked.t, 'zkapp_command) t\n\n let if_ f b ~then_ ~else_ : _ t =\n { caller = Token_id.Checked.if_ b ~then_:then_.caller ~else_:else_.caller\n ; caller_caller =\n Token_id.Checked.if_ b ~then_:then_.caller_caller\n ~else_:else_.caller_caller\n ; calls = f b ~then_:then_.calls ~else_:else_.calls\n }\nend\n","open Core_kernel\nopen Mina_base_import\nopen Snark_params.Tick\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n ( Ledger_hash.Stable.V1.t\n , Account_id.Stable.V2.t\n , Account.Stable.V2.t )\n Sparse_ledger_lib.Sparse_ledger.T.Stable.V2.t\n [@@deriving yojson, sexp]\n\n let to_latest = Fn.id\n end\nend]\n\ntype sparse_ledger = t [@@deriving sexp, to_yojson]\n\nmodule Hash = struct\n include Ledger_hash\n\n let merge = Ledger_hash.merge\nend\n\nmodule Account = struct\n include Account\n\n let data_hash = Fn.compose Ledger_hash.of_digest Account.digest\nend\n\nmodule Global_state = struct\n type t =\n { first_pass_ledger : sparse_ledger\n ; second_pass_ledger : sparse_ledger\n ; fee_excess : Currency.Amount.Signed.t\n ; supply_increase : Currency.Amount.Signed.t\n ; protocol_state : Zkapp_precondition.Protocol_state.View.t\n ; block_global_slot : Mina_numbers.Global_slot_since_genesis.t\n }\n [@@deriving sexp, to_yojson]\nend\n\nmodule M = Sparse_ledger_lib.Sparse_ledger.Make (Hash) (Account_id) (Account)\n\ntype account_state = [ `Added | `Existed ] [@@deriving equal]\n\n(** Create a new 'empty' ledger.\n This ledger has an invalid root hash, and cannot be used except as a\n placeholder.\n*)\nlet empty ~depth () = M.of_hash ~depth Outside_hash_image.t\n\nmodule L = struct\n type t = M.t ref\n\n type location = int\n\n let get : t -> location -> Account.t option =\n fun t loc ->\n Option.try_with (fun () ->\n let account = M.get_exn !t loc in\n if Public_key.Compressed.(equal empty account.public_key) then None\n else Some account )\n |> Option.bind ~f:Fn.id\n\n let location_of_account : t -> Account_id.t -> location option =\n fun t id ->\n try\n let loc = M.find_index_exn !t id in\n let account = M.get_exn !t loc in\n if Public_key.Compressed.(equal empty account.public_key) then None\n else Some loc\n with _ -> None\n\n let set : t -> location -> Account.t -> unit =\n fun t loc a -> t := M.set_exn !t loc a\n\n let get_or_create_exn :\n t -> Account_id.t -> account_state * Account.t * location =\n fun t id ->\n let loc = M.find_index_exn !t id in\n let account = M.get_exn !t loc in\n if Public_key.Compressed.(equal empty account.public_key) then (\n let public_key = Account_id.public_key id in\n let account' : Account.t =\n { account with\n delegate = Some public_key\n ; public_key\n ; token_id = Account_id.token_id id\n }\n in\n set t loc account' ;\n (`Added, account', loc) )\n else (`Existed, account, loc)\n\n let get_or_create t id = Or_error.try_with (fun () -> get_or_create_exn t id)\n\n let get_or_create_account :\n t -> Account_id.t -> Account.t -> (account_state * location) Or_error.t =\n fun t id to_set ->\n Or_error.try_with (fun () ->\n let loc = M.find_index_exn !t id in\n let a = M.get_exn !t loc in\n if Public_key.Compressed.(equal empty a.public_key) then (\n set t loc to_set ;\n (`Added, loc) )\n else (`Existed, loc) )\n\n let create_new_account t id to_set =\n get_or_create_account t id to_set |> Or_error.map ~f:ignore\n\n let remove_accounts_exn : t -> Account_id.t list -> unit =\n fun _t _xs -> failwith \"remove_accounts_exn: not implemented\"\n\n let merkle_root : t -> Ledger_hash.t = fun t -> M.merkle_root !t\n\n let with_ledger : depth:int -> f:(t -> 'a) -> 'a =\n fun ~depth:_ ~f:_ -> failwith \"with_ledger: not implemented\"\n\n (** Create a new ledger mask 'on top of' the given ledger.\n\n Warning: For technical reasons, this mask cannot be applied directly to\n the parent ledger; instead, use\n [apply_mask parent_ledger ~masked:this_ledger] to update the parent\n ledger as necessary.\n *)\n let create_masked t = ref !t\n\n (** [apply_mask ledger ~masked] applies any updates in [masked] to the ledger\n [ledger]. [masked] should be created by calling [create_masked ledger].\n\n Warning: This function may behave unexpectedly if [ledger] was modified\n after calling [create_masked], or the given [ledger] was not used to\n create [masked].\n *)\n let apply_mask t ~masked = t := !masked\n\n (** Create a new 'empty' ledger.\n This ledger has an invalid root hash, and cannot be used except as a\n placeholder.\n *)\n let empty ~depth () = ref (empty ~depth ())\nend\n\n[%%define_locally\nM.\n ( of_hash\n , to_yojson\n , get_exn\n , path_exn\n , set_exn\n , find_index_exn\n , add_path\n , merkle_root\n , iteri )]\n\nlet of_root ~depth (h : Ledger_hash.t) =\n of_hash ~depth (Ledger_hash.of_digest (h :> Random_oracle.Digest.t))\n\nlet get_or_initialize_exn account_id t idx =\n let account = get_exn t idx in\n if Public_key.Compressed.(equal empty account.public_key) then\n let public_key = Account_id.public_key account_id in\n let token_id = Account_id.token_id account_id in\n let delegate =\n (* Only allow delegation if this account is for the default token. *)\n if Token_id.(equal default) token_id then Some public_key else None\n in\n ( `Added\n , { account with\n delegate\n ; public_key\n ; token_id = Account_id.token_id account_id\n } )\n else (`Existed, account)\n\nlet has_locked_tokens_exn ~global_slot ~account_id t =\n let idx = find_index_exn t account_id in\n let _, account = get_or_initialize_exn account_id t idx in\n Account.has_locked_tokens ~global_slot account\n\nlet merkle_root t = Ledger_hash.of_hash (merkle_root t :> Random_oracle.Digest.t)\n\nlet depth t = M.depth t\n\nlet handler t =\n let ledger = ref t in\n let path_exn idx =\n List.map (path_exn !ledger idx) ~f:(function `Left h -> h | `Right h -> h)\n in\n stage (fun (With { request; respond }) ->\n match request with\n | Ledger_hash.Get_element idx ->\n let elt = get_exn !ledger idx in\n let path = (path_exn idx :> Random_oracle.Digest.t list) in\n respond (Provide (elt, path))\n | Ledger_hash.Get_path idx ->\n let path = (path_exn idx :> Random_oracle.Digest.t list) in\n respond (Provide path)\n | Ledger_hash.Set (idx, account) ->\n ledger := set_exn !ledger idx account ;\n respond (Provide ())\n | Ledger_hash.Find_index pk ->\n let index = find_index_exn !ledger pk in\n respond (Provide index)\n | _ ->\n unhandled )\n","module type Full = sig\n open Core_kernel\n open Snark_params\n open Tick\n open Mina_base_import\n\n [@@@warning \"-32\"]\n\n [%%versioned:\n module Stable : sig\n module V1 : sig\n type t =\n { fee : Currency.Fee.Stable.V1.t\n ; prover : Public_key.Compressed.Stable.V1.t\n }\n [@@deriving sexp, yojson, equal, compare]\n end\n end]\n\n [@@@warning \"+32\"]\n\n type t = Stable.Latest.t =\n { fee : Currency.Fee.Stable.V1.t\n ; prover : Public_key.Compressed.Stable.V1.t\n }\n [@@deriving sexp, yojson, equal, compare]\n\n val create : fee:Currency.Fee.t -> prover:Public_key.Compressed.t -> t\n\n module Digest : sig\n type t [@@deriving sexp, equal, yojson, hash, compare]\n\n module Stable : sig\n module V1 : sig\n type nonrec t = t\n [@@deriving sexp, bin_io, hash, compare, equal, yojson, version]\n end\n\n module Latest = V1\n end\n\n module Checked : sig\n type t\n\n val to_input : t -> Field.Var.t Random_oracle.Input.Chunked.t\n end\n\n val to_input : t -> Field.t Random_oracle.Input.Chunked.t\n\n val typ : (Checked.t, t) Typ.t\n\n val default : t\n end\n\n val digest : t -> Digest.t\nend\n","[%%import \"/src/config.mlh\"]\n\nopen Core_kernel\n\nlet blockchain_dummy = lazy (Dummy_values.blockchain_proof ())\n\nlet transaction_dummy = lazy (Dummy_values.transaction_proof ())\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t = Pickles.Proof.Proofs_verified_2.Stable.V2.t\n [@@deriving sexp, yojson, compare]\n\n let to_latest = Fn.id\n\n let to_yojson_full = Pickles.Proof.Proofs_verified_2.to_yojson_full\n end\nend]\n\n[%%define_locally Stable.Latest.(to_yojson, of_yojson, to_yojson_full)]\n","open Core_kernel\n\n[%%versioned\nmodule Stable = struct\n module V2 = struct\n type t =\n { pending_coinbases : Pending_coinbase.Stable.V2.t; is_new_stack : bool }\n [@@deriving sexp, to_yojson]\n\n let to_latest = Fn.id\n end\nend]\n","open Core_kernel\n\nmodule type Full = sig\n include Digest_intf.S\n\n val cons : Stack_frame.Digest.t -> t -> t\n\n val empty : t\n\n val gen : t Quickcheck.Generator.t\n\n module Checked : sig\n include Digest_intf.S_checked\n\n val cons : Stack_frame.Digest.Checked.t -> t -> t\n end\n\n include Digest_intf.S_aux with type t := t and type checked := Checked.t\nend\n","open Core_kernel\nmodule Wire_types = Mina_wire_types.Mina_base.Call_stack_digest\n\nmodule Make_sig (A : Wire_types.Types.S) = struct\n module type S = Call_stack_digest_intf.Full with type Stable.V1.t = A.V1.t\nend\n\nmodule Make_str (A : Wire_types.Concrete) = struct\n [%%versioned\n module Stable = struct\n module V1 = struct\n type t = Kimchi_backend.Pasta.Basic.Fp.Stable.V1.t\n [@@deriving sexp, compare, equal, hash, yojson]\n\n let to_latest = Fn.id\n end\n end]\n\n open Pickles.Impls.Step\n\n let cons (h : Stack_frame.Digest.t) (t : t) : t =\n Random_oracle.hash ~init:Hash_prefix_states.account_update_stack_frame_cons\n [| (h :> Field.Constant.t); t |]\n\n let empty = Field.Constant.zero\n\n let gen = Field.Constant.gen\n\n module Checked = struct\n include Field\n\n let cons (h : Stack_frame.Digest.Checked.t) (t : t) : t =\n Random_oracle.Checked.hash\n ~init:Hash_prefix_states.account_update_stack_frame_cons\n [| (h :> Field.t); t |]\n end\n\n let constant = Field.constant\n\n let typ = Field.typ\nend\n\ninclude Wire_types.Make (Make_sig) (Make_str)\n","open Core_kernel\n\ntype account_state = [ `Added | `Existed ] [@@deriving equal]\n\nmodule type S = sig\n type t\n\n type location\n\n val get : t -> location -> Account.t option\n\n val location_of_account : t -> Account_id.t -> location option\n\n val set : t -> location -> Account.t -> unit\n\n val get_or_create :\n t -> Account_id.t -> (account_state * Account.t * location) Or_error.t\n\n val get_or_create_account :\n t -> Account_id.t -> Account.t -> (account_state * location) Or_error.t\n\n val create_new_account : t -> Account_id.t -> Account.t -> unit Or_error.t\n\n val remove_accounts_exn : t -> Account_id.t list -> unit\n\n val merkle_root : t -> Ledger_hash.t\n\n val with_ledger : depth:int -> f:(t -> 'a) -> 'a\n\n val empty : depth:int -> unit -> t\n\n val create_masked : t -> t\n\n val apply_mask : t -> masked:t -> unit\nend\n","module Import = Mina_base_import\nmodule Util = Mina_base_util\nmodule Account = Account\nmodule Account_id = Account_id\nmodule Account_timing = Account_timing\nmodule Call_stack_digest = Call_stack_digest\nmodule Coinbase = Coinbase\nmodule Coinbase_fee_transfer = Coinbase_fee_transfer\nmodule Control = Control\nmodule Data_as_hash = Data_as_hash\nmodule Data_hash = Data_hash\nmodule Epoch_data = Epoch_data\nmodule Epoch_ledger = Epoch_ledger\nmodule Epoch_seed = Epoch_seed\nmodule Fee_excess = Fee_excess\nmodule Fee_transfer = Fee_transfer\nmodule Fee_with_prover = Fee_with_prover\nmodule Frozen_ledger_hash = Frozen_ledger_hash\nmodule Frozen_ledger_hash0 = Frozen_ledger_hash0\nmodule Hash_prefix = Hash_prefix\nmodule Ledger_hash = Ledger_hash\nmodule Ledger_hash0 = Ledger_hash0\nmodule Ledger_hash_intf = Ledger_hash_intf\nmodule Ledger_hash_intf0 = Ledger_hash_intf0\nmodule Ledger_intf = Ledger_intf\nmodule Account_update = Account_update\nmodule Payment_payload = Payment_payload\nmodule Pending_coinbase = Pending_coinbase\nmodule Pending_coinbase_intf = Pending_coinbase_intf\nmodule Pending_coinbase_witness = Pending_coinbase_witness\nmodule Permissions = Permissions\nmodule Proof = Proof\nmodule Protocol_constants_checked = Protocol_constants_checked\nmodule Prover_value = Prover_value\nmodule Receipt = Receipt\nmodule Side_loaded_verification_key = Side_loaded_verification_key\nmodule Signature = Signature\nmodule Signed_command = Signed_command\nmodule Signed_command_intf = Signed_command_intf\nmodule Signed_command_memo = Signed_command_memo\nmodule Signed_command_payload = Signed_command_payload\nmodule Zkapp_account = Zkapp_account\nmodule Zkapp_basic = Zkapp_basic\nmodule Zkapp_call_forest = Zkapp_call_forest\nmodule Zkapp_command = Zkapp_command\nmodule Zkapp_precondition = Zkapp_precondition\nmodule Zkapp_state = Zkapp_state\nmodule Zkapp_statement = Zkapp_statement\nmodule Sok_message = Sok_message\nmodule Sparse_ledger_base = Sparse_ledger_base\nmodule Stack_frame = Stack_frame\nmodule Staged_ledger_hash = Staged_ledger_hash\nmodule Stake_delegation = Stake_delegation\nmodule State_body_hash = State_body_hash\nmodule State_hash = State_hash\nmodule Token_id = Token_id\nmodule Transaction_status = Transaction_status\nmodule Transaction_union_payload = Transaction_union_payload\nmodule Transaction_union_tag = Transaction_union_tag\nmodule User_command = User_command\nmodule Verification_key_wire = Verification_key_wire\nmodule With_stack_hash = With_stack_hash\nmodule With_status = With_status\n","open Core_kernel\nmodule Js = Js_of_ocaml.Js\n\nlet _console_log_string s = Js_of_ocaml.Firebug.console##log (Js.string s)\n\nlet _console_log s = Js_of_ocaml.Firebug.console##log s\n\nlet _console_dir s : unit =\n let f =\n Js.Unsafe.eval_string {js|(function(s) { console.dir(s, {depth: 5}); })|js}\n in\n Js.Unsafe.(fun_call f [| inject s |])\n\nlet raise_error s =\n Js.Js_error.(raise_ @@ of_error (new%js Js.error_constr (Js.string s)))\n\nexternal raise_exn_js : exn -> Js.js_string Js.t -> 'a = \"custom_reraise_exn\"\n\nlet raise_exn exn = raise_exn_js exn (Js.string (Exn.to_string exn))\n\nlet json_parse (str : Js.js_string Js.t) =\n Js.Unsafe.(fun_call global ##. JSON##.parse [| inject str |])\n","module Js = Js_of_ocaml.Js\n\nlet export () =\n Js.export \"Snarky\" Snarky_bindings.snarky ;\n Js.export \"Ledger\" Local_ledger.ledger_class ;\n Js.export \"Pickles\" Pickles_bindings.pickles ;\n Js.export \"Test\" Consistency_test.test\n\nlet export_global () =\n let snarky_obj =\n Js.Unsafe.(\n let i = inject in\n obj\n [| (\"Snarky\", i Snarky_bindings.snarky)\n ; (\"Ledger\", i Local_ledger.ledger_class)\n ; (\"Pickles\", i Pickles_bindings.pickles)\n ; (\"Test\", i Consistency_test.test)\n |])\n in\n Js.Unsafe.(set global (Js.string \"__snarky\") snarky_obj)\n","let () = Snarky_js_bindings_lib.export_global ()\n\nlet () = Snarky_js_bindings_lib.export ()\n","(**************************************************************************)\n(* *)\n(* OCaml *)\n(* *)\n(* Xavier Leroy, projet Cristal, INRIA Rocquencourt *)\n(* *)\n(* Copyright 1996 Institut National de Recherche en Informatique et *)\n(* en Automatique. *)\n(* *)\n(* All rights reserved. This file is distributed under the terms of *)\n(* the GNU Lesser General Public License version 2.1, with the *)\n(* special exception on linking described in the file LICENSE. *)\n(* *)\n(**************************************************************************)\n\n(* Ensure that [at_exit] functions are called at the end of every program *)\n\nlet _ = do_at_exit()\n"]} \ No newline at end of file diff --git a/compiled/web_bindings/snarky_js_web.bc.js b/compiled/web_bindings/snarky_js_web.bc.js index c100e1c3..3b74561e 100644 --- a/compiled/web_bindings/snarky_js_web.bc.js +++ b/compiled/web_bindings/snarky_js_web.bc.js @@ -1,6 +1,6 @@ "use strict";(function(_){typeof globalThis!="object"&&(this?e():(_.defineProperty(_.prototype,"_T_",{configurable:!0,get:e}),_T_));function e(){var u=this||self;u.globalThis=u,delete _.prototype._T_}})(Object),function(_){var e=_;(function(){var u={days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],AM:"AM",PM:"PM",am:"am",pm:"pm",formats:{D:"%m/%d/%y",F:"%Y-%m-%d",R:"%H:%M",T:"%H:%M:%S",X:"%T",c:"%a %b %d %X %Y",r:"%I:%M:%S %p",v:"%e-%b-%Y",x:"%D"}},d=new R(u,0,!1),$=typeof module<"u",w;$?(w=module.exports=N,w.strftime=L,e&&(e.strftime=N)):(w=e||function(){return this||(0,eval)("this")}(),w.strftime=N);var q=$?"require('strftime')":"strftime",z={};function P(t_,e_){z[t_]||(typeof console<"u"&&typeof console.warn=="function"&&console.warn("[WARNING] "+t_+" is deprecated and will be removed in version 1.0. Instead, use `"+e_+"`."),z[t_]=!0)}w.strftimeTZ=U,w.strftimeUTC=W,w.localizedStrftime=K;function V(t_){t_.localize=d.localize.bind(d),t_.timezone=d.timezone.bind(d),t_.utc=d.utc.bind(d)}V(N);function N(t_,e_,a_){e_&&e_.days&&(a_=e_,e_=void 0),a_&&P("`"+q+"(format, [date], [locale])`","var s = "+q+".localize(locale); s(format, [date])");var r_=a_?d.localize(a_):d;return r_(t_,e_)}V(L);function L(t_,e_,a_){a_?P("`"+q+".strftime(format, [date], [locale])`","var s = "+q+".localize(locale); s(format, [date])"):P("`"+q+".strftime(format, [date])`",q+"(format, [date])");var r_=a_?d.localize(a_):d;return r_(t_,e_)}function U(t_,e_,a_,r_){(typeof a_=="number"||typeof a_=="string")&&r_==null&&(r_=a_,a_=void 0),a_?P("`"+q+".strftimeTZ(format, date, locale, tz)`","var s = "+q+".localize(locale).timezone(tz); s(format, [date])` or `var s = "+q+".localize(locale); s.timezone(tz)(format, [date])"):P("`"+q+".strftimeTZ(format, date, tz)`","var s = "+q+".timezone(tz); s(format, [date])` or `"+q+".timezone(tz)(format, [date])");var n_=(a_?d.localize(a_):d).timezone(r_);return n_(t_,e_)}var Y=d.utc();function W(t_,e_,a_){a_?P("`"+q+".strftimeUTC(format, date, locale)`","var s = "+q+".localize(locale).utc(); s(format, [date])"):P("`"+q+".strftimeUTC(format, [date])`","var s = "+q+".utc(); s(format, [date])");var r_=a_?Y.localize(a_):Y;return r_(t_,e_)}function K(t_){return P("`"+q+".localizedStrftime(locale)`",q+".localize(locale)"),d.localize(t_)}typeof Date.now!="function"&&(Date.now=function(){return+new Date});function R(t_,e_,a_){var r_=t_||u,n_=e_||0,c_=a_||!1,l_=0,f_;function o_(x_,b_){var y_;if(b_)y_=b_.getTime(),c_&&(b_=new Date(b_.getTime()+__(b_)+n_));else{var d_=Date.now();d_>l_&&(l_=d_,f_=new Date(l_),y_=l_,c_&&(f_=new Date(l_+__(f_)+n_))),b_=f_}return i_(x_,b_,r_,y_)}function i_(x_,b_,y_,d_){for(var p_="",$_=null,w_=!1,j_=x_.length,M_=!1,D_=0;D_9?t_:(e_==null&&(e_="0"),e_+t_)}function Q(t_){return t_>99?t_:t_>9?"0"+t_:"00"+t_}function X(t_){return t_===0?12:t_>12?t_-12:t_}function Z(t_,e_){e_=e_||"sunday";var a_=t_.getDay();e_==="monday"&&(a_===0?a_=6:a_--);var r_=Date.UTC(t_.getFullYear(),0,1),n_=Date.UTC(t_.getFullYear(),t_.getMonth(),t_.getDate()),c_=Math.floor((n_-r_)/864e5),l_=(c_+7-a_)/7;return Math.floor(l_)}function I(t_){var e_=t_%10,a_=t_%100;if(a_>=11&&a_<=13||e_===0||e_>=4)return"th";switch(e_){case 1:return"st";case 2:return"nd";case 3:return"rd"}}function __(t_){return(t_.getTimezoneOffset()||0)*6e4}})()}(globalThis),function(globalThis){"use strict";var joo_global_object=globalThis;function Base_am_testing(_){return 0}function caml_mul(_,e){return Math.imul(_,e)}function caml_hash_mix_int(_,e){return e=caml_mul(e,-862048943),e=e<<15|e>>>32-15,e=caml_mul(e,461845907),_^=e,_=_<<13|_>>>32-13,(_+(_<<2)|0)+-430675100|0}function caml_hash_mix_jsbytes(_,e){var u=e.length,d,$;for(d=0;d+4<=u;d+=4)$=e.charCodeAt(d)|e.charCodeAt(d+1)<<8|e.charCodeAt(d+2)<<16|e.charCodeAt(d+3)<<24,_=caml_hash_mix_int(_,$);switch($=0,u&3){case 3:$=e.charCodeAt(d+2)<<16;case 2:$|=e.charCodeAt(d+1)<<8;case 1:$|=e.charCodeAt(d),_=caml_hash_mix_int(_,$)}return _^=u,_}var log2_ok=Math.log2&&Math.log2(11235582092889474e291)==1020;function jsoo_floor_log2(_){if(log2_ok)return Math.floor(Math.log2(_));var e=0;if(_==0)return-1/0;if(_>=1)for(;_>=2;)_/=2,e++;else for(;_<1;)_*=2,e--;return e}var caml_int64_offset=Math.pow(2,-24);function caml_raise_constant(_){throw _}var caml_global_data=[0];function caml_raise_zero_divide(){caml_raise_constant(caml_global_data.Division_by_zero)}function MlInt64(_,e,u){this.lo=_&16777215,this.mi=e&16777215,this.hi=u&65535}MlInt64.prototype.caml_custom="_j",MlInt64.prototype.copy=function(){return new MlInt64(this.lo,this.mi,this.hi)},MlInt64.prototype.ucompare=function(_){return this.hi>_.hi?1:this.hi<_.hi?-1:this.mi>_.mi?1:this.mi<_.mi?-1:this.lo>_.lo?1:this.lo<_.lo?-1:0},MlInt64.prototype.compare=function(_){var e=this.hi<<16,u=_.hi<<16;return e>u?1:e_.mi?1:this.mi<_.mi?-1:this.lo>_.lo?1:this.lo<_.lo?-1:0},MlInt64.prototype.neg=function(){var _=-this.lo,e=-this.mi+(_>>24),u=-this.hi+(e>>24);return new MlInt64(_,e,u)},MlInt64.prototype.add=function(_){var e=this.lo+_.lo,u=this.mi+_.mi+(e>>24),d=this.hi+_.hi+(u>>24);return new MlInt64(e,u,d)},MlInt64.prototype.sub=function(_){var e=this.lo-_.lo,u=this.mi-_.mi+(e>>24),d=this.hi-_.hi+(u>>24);return new MlInt64(e,u,d)},MlInt64.prototype.mul=function(_){var e=this.lo*_.lo,u=(e*caml_int64_offset|0)+this.mi*_.lo+this.lo*_.mi,d=(u*caml_int64_offset|0)+this.hi*_.lo+this.mi*_.mi+this.lo*_.hi;return new MlInt64(e,u,d)},MlInt64.prototype.isZero=function(){return(this.lo|this.mi|this.hi)==0},MlInt64.prototype.isNeg=function(){return this.hi<<16<0},MlInt64.prototype.and=function(_){return new MlInt64(this.lo&_.lo,this.mi&_.mi,this.hi&_.hi)},MlInt64.prototype.or=function(_){return new MlInt64(this.lo|_.lo,this.mi|_.mi,this.hi|_.hi)},MlInt64.prototype.xor=function(_){return new MlInt64(this.lo^_.lo,this.mi^_.mi,this.hi^_.hi)},MlInt64.prototype.shift_left=function(_){return _=_&63,_==0?this:_<24?new MlInt64(this.lo<<_,this.mi<<_|this.lo>>24-_,this.hi<<_|this.mi>>24-_):_<48?new MlInt64(0,this.lo<<_-24,this.mi<<_-24|this.lo>>48-_):new MlInt64(0,0,this.lo<<_-48)},MlInt64.prototype.shift_right_unsigned=function(_){return _=_&63,_==0?this:_<24?new MlInt64(this.lo>>_|this.mi<<24-_,this.mi>>_|this.hi<<24-_,this.hi>>_):_<48?new MlInt64(this.mi>>_-24|this.hi<<48-_,this.hi>>_-24,0):new MlInt64(this.hi>>_-48,0,0)},MlInt64.prototype.shift_right=function(_){if(_=_&63,_==0)return this;var e=this.hi<<16>>16;if(_<24)return new MlInt64(this.lo>>_|this.mi<<24-_,this.mi>>_|e<<24-_,this.hi<<16>>_>>>16);var u=this.hi<<16>>31;return _<48?new MlInt64(this.mi>>_-24|this.hi<<48-_,this.hi<<16>>_-24>>16,u&65535):new MlInt64(this.hi<<16>>_-32,u,u)},MlInt64.prototype.lsl1=function(){this.hi=this.hi<<1|this.mi>>23,this.mi=(this.mi<<1|this.lo>>23)&16777215,this.lo=this.lo<<1&16777215},MlInt64.prototype.lsr1=function(){this.lo=(this.lo>>>1|this.mi<<23)&16777215,this.mi=(this.mi>>>1|this.hi<<23)&16777215,this.hi=this.hi>>>1},MlInt64.prototype.udivmod=function(_){for(var e=0,u=this.copy(),d=_.copy(),$=new MlInt64(0,0,0);u.ucompare(d)>0;)e++,d.lsl1();for(;e>=0;)e--,$.lsl1(),u.ucompare(d)>=0&&($.lo++,u=u.sub(d)),d.lsr1();return{quotient:$,modulus:u}},MlInt64.prototype.div=function(_){var e=this;_.isZero()&&caml_raise_zero_divide();var u=e.hi^_.hi;e.hi&32768&&(e=e.neg()),_.hi&32768&&(_=_.neg());var d=e.udivmod(_).quotient;return u&32768&&(d=d.neg()),d},MlInt64.prototype.mod=function(_){var e=this;_.isZero()&&caml_raise_zero_divide();var u=e.hi;e.hi&32768&&(e=e.neg()),_.hi&32768&&(_=_.neg());var d=e.udivmod(_).modulus;return u&32768&&(d=d.neg()),d},MlInt64.prototype.toInt=function(){return this.lo|this.mi<<24},MlInt64.prototype.toFloat=function(){return(this.hi<<16)*Math.pow(2,32)+this.mi*Math.pow(2,24)+this.lo},MlInt64.prototype.toArray=function(){return[this.hi>>8,this.hi&255,this.mi>>16,this.mi>>8&255,this.mi&255,this.lo>>16,this.lo>>8&255,this.lo&255]},MlInt64.prototype.lo32=function(){return this.lo|(this.mi&255)<<24},MlInt64.prototype.hi32=function(){return this.mi>>>8&65535|this.hi<<16};function caml_int64_create_lo_mi_hi(_,e,u){return new MlInt64(_,e,u)}function caml_int64_bits_of_float(_){if(!isFinite(_))return isNaN(_)?caml_int64_create_lo_mi_hi(1,0,32752):_>0?caml_int64_create_lo_mi_hi(0,0,32752):caml_int64_create_lo_mi_hi(0,0,65520);var e=_==0&&1/_==-1/0?32768:_>=0?0:32768;e&&(_=-_);var u=jsoo_floor_log2(_)+1023;u<=0?(u=0,_/=Math.pow(2,-1026)):(_/=Math.pow(2,u-1027),_<16&&(_*=2,u-=1),u==0&&(_/=2));var d=Math.pow(2,24),$=_|0;_=(_-$)*d;var w=_|0;_=(_-w)*d;var q=_|0;return $=$&15|e|u<<4,caml_int64_create_lo_mi_hi(q,w,$)}function caml_int64_lo32(_){return _.lo32()}function caml_int64_hi32(_){return _.hi32()}function caml_hash_mix_int64(_,e){return _=caml_hash_mix_int(_,caml_int64_lo32(e)),_=caml_hash_mix_int(_,caml_int64_hi32(e)),_}function caml_hash_mix_float(_,e){return caml_hash_mix_int64(_,caml_int64_bits_of_float(e))}function caml_str_repeat(_,e){if(_==0)return"";if(e.repeat)return e.repeat(_);for(var u="",d=0;;){if(_&1&&(u+=e),_>>=1,_==0)return u;e+=e,d++,d==9&&e.slice(0,1)}}function caml_subarray_to_jsbytes(_,e,u){var d=String.fromCharCode;if(e==0&&u<=4096&&u==_.length)return d.apply(null,_);for(var $="";0127)return!1;return!0}else return!/[^\x00-\x7f]/.test(_)}function caml_utf16_of_utf8(_){for(var e="",u="",d,$,w,q,z=0,P=_.length;z512?(u.substr(0,1),e+=u,u="",e+=_.slice(z,V)):u+=_.slice(z,V),V==P)break;z=V}q=1,++z=55295&&q<57344)&&(q=2)):(q=3,++z1114111)&&(q=3)))))),q<4?(z-=q,u+="\uFFFD"):q>65535?u+=String.fromCharCode(55232+(q>>10),56320+(q&1023)):u+=String.fromCharCode(q),u.length>1024&&(u.substr(0,1),e+=u,u="")}return e+u}function MlBytes(_,e,u){this.t=_,this.c=e,this.l=u}MlBytes.prototype.toString=function(){switch(this.t){case 9:return this.c;default:caml_convert_string_to_bytes(this);case 0:if(jsoo_is_ascii(this.c))return this.t=9,this.c;this.t=8;case 8:return this.c}},MlBytes.prototype.toUtf16=function(){var _=this.toString();return this.t==9?_:caml_utf16_of_utf8(_)},MlBytes.prototype.slice=function(){var _=this.t==4?this.c.slice():this.c;return new MlBytes(this.t,_,this.l)};function caml_ml_bytes_content(_){switch(_.t&6){default:caml_convert_string_to_bytes(_);case 0:return _.c;case 4:return _.c}}function caml_hash_mix_bytes(_,e){var u=caml_ml_bytes_content(e);return typeof u=="string"?caml_hash_mix_jsbytes(_,u):caml_hash_mix_bytes_arr(_,u)}function caml_int32_bits_of_float(_){var e=new globalThis.Float32Array(1);e[0]=_;var u=new globalThis.Int32Array(e.buffer);return u[0]|0}function caml_int64_to_bytes(_){return _.toArray()}function caml_ba_serialize(_,e,u){if(_.write(32,e.dims.length),_.write(32,e.kind|e.layout<<8),e.caml_custom=="_bigarr02")for(var d=0;d>4;if($==2047)return e|u|d&15?NaN:d&32768?-1/0:1/0;var w=Math.pow(2,-24),q=(e*w+u)*w+(d&15);return $>0?(q+=16,q*=Math.pow(2,$-1027)):q*=Math.pow(2,-1026),d&32768&&(q=-q),q}function caml_ba_get_size(_){for(var e=_.length,u=1,d=0;d>>24&255|(e&65535)<<8,e>>>16&65535)}function caml_array_bound_error(){caml_invalid_argument("index out of bounds")}var caml_ba_custom_name="_bigarr02";function Ml_Bigarray(_,e,u,d){this.kind=_,this.layout=e,this.dims=u,this.data=d}Ml_Bigarray.prototype.caml_custom=caml_ba_custom_name,Ml_Bigarray.prototype.offset=function(_){var e=0;if(typeof _=="number"&&(_=[_]),_ instanceof Array||caml_invalid_argument("bigarray.js: invalid offset"),this.dims.length!=_.length&&caml_invalid_argument("Bigarray.get/set: bad number of dimensions"),this.layout==0)for(var u=0;u=this.dims[u])&&caml_array_bound_error(),e=e*this.dims[u]+_[u];else for(var u=this.dims.length-1;u>=0;u--)(_[u]<1||_[u]>this.dims[u])&&caml_array_bound_error(),e=e*this.dims[u]+(_[u]-1);return e},Ml_Bigarray.prototype.get=function(_){switch(this.kind){case 7:var e=this.data[_*2+0],u=this.data[_*2+1];return caml_int64_create_lo_hi(e,u);case 10:case 11:var d=this.data[_*2+0],$=this.data[_*2+1];return[254,d,$];default:return this.data[_]}},Ml_Bigarray.prototype.set=function(_,e){switch(this.kind){case 7:this.data[_*2+0]=caml_int64_lo32(e),this.data[_*2+1]=caml_int64_hi32(e);break;case 10:case 11:this.data[_*2+0]=e[1],this.data[_*2+1]=e[2];break;default:this.data[_]=e;break}return 0},Ml_Bigarray.prototype.fill=function(_){switch(this.kind){case 7:var e=caml_int64_lo32(_),u=caml_int64_hi32(_);if(e==u)this.data.fill(e);else for(var d=0;dq)return 1;if(w!=q){if(!e)return NaN;if(w==w)return 1;if(q==q)return-1}}break;case 7:for(var $=0;$_.data[$+1])return 1;if(this.data[$]>>>0<_.data[$]>>>0)return-1;if(this.data[$]>>>0>_.data[$]>>>0)return 1}break;case 2:case 3:case 4:case 5:case 6:case 8:case 9:case 12:for(var $=0;$_.data[$])return 1}break}return 0};function Ml_Bigarray_c_1_1(_,e,u,d){this.kind=_,this.layout=e,this.dims=u,this.data=d}Ml_Bigarray_c_1_1.prototype=new Ml_Bigarray,Ml_Bigarray_c_1_1.prototype.offset=function(_){return typeof _!="number"&&(_ instanceof Array&&_.length==1?_=_[0]:caml_invalid_argument("Ml_Bigarray_c_1_1.offset")),(_<0||_>=this.dims[0])&&caml_array_bound_error(),_},Ml_Bigarray_c_1_1.prototype.get=function(_){return this.data[_]},Ml_Bigarray_c_1_1.prototype.set=function(_,e){return this.data[_]=e,0},Ml_Bigarray_c_1_1.prototype.fill=function(_){return this.data.fill(_),0};function caml_ba_create_unsafe(_,e,u,d){var $=caml_ba_get_size_per_element(_);return caml_ba_get_size(u)*$!=d.length&&caml_invalid_argument("length doesn't match dims"),e==0&&u.length==1&&$==1?new Ml_Bigarray_c_1_1(_,e,u,d):new Ml_Bigarray(_,e,u,d)}function caml_bytes_of_jsbytes(_){return new MlBytes(0,_,_.length)}function caml_string_of_jsbytes(_){return caml_bytes_of_jsbytes(_)}function caml_failwith(_){caml_global_data.Failure||(caml_global_data.Failure=[248,caml_string_of_jsbytes("Failure"),-3]),caml_raise_with_string(caml_global_data.Failure,_)}function caml_ba_deserialize(_,e,u){var d=_.read32s();(d<0||d>16)&&caml_failwith("input_value: wrong number of bigarray dimensions");var $=_.read32s(),w=$&255,q=$>>8&1,z=[];if(u=="_bigarr02")for(var P=0;P256&&(e=256);var d=0,$=0;for($=0;$+4<=_.data.length;$+=4)d=_.data[$+0]|_.data[$+1]<<8|_.data[$+2]<<16|_.data[$+3]<<24,u=caml_hash_mix_int(u,d);switch(d=0,e&3){case 3:d=_.data[$+2]<<16;case 2:d|=_.data[$+1]<<8;case 1:d|=_.data[$+0],u=caml_hash_mix_int(u,d)}break;case 4:case 5:e>128&&(e=128);var d=0,$=0;for($=0;$+2<=_.data.length;$+=2)d=_.data[$+0]|_.data[$+1]<<16,u=caml_hash_mix_int(u,d);e&1&&(u=caml_hash_mix_int(u,_.data[$]));break;case 6:e>64&&(e=64);for(var $=0;$64&&(e=64);for(var $=0;$32&&(e=32),e*=2;for(var $=0;$64&&(e=64);for(var $=0;$32&&(e=32);for(var $=0;$>>16,_=caml_mul(_,-2048144789),_^=_>>>13,_=caml_mul(_,-1028477387),_^=_>>>16,_}function caml_is_ml_bytes(_){return _ instanceof MlBytes}function caml_is_ml_string(_){return caml_is_ml_bytes(_)}function caml_hash(_,e,u,d){var $,w,q,z,P,V,N,L,U;for(z=e,(z<0||z>256)&&(z=256),P=_,V=u,$=[d],w=0,q=1;w0;)if(N=$[w++],N&&N.caml_custom){if(caml_custom_ops[N.caml_custom]&&caml_custom_ops[N.caml_custom].hash){var Y=caml_custom_ops[N.caml_custom].hash(N);V=caml_hash_mix_int(V,Y),P--}}else if(N instanceof Array&&N[0]===(N[0]|0))switch(N[0]){case 248:V=caml_hash_mix_int(V,N[2]),P--;break;case 250:$[--w]=N[1];break;default:var W=N.length-1<<10|N[0];for(V=caml_hash_mix_int(V,W),L=1,U=N.length;L=z);L++)$[q++]=N[L];break}else caml_is_ml_bytes(N)?(V=caml_hash_mix_bytes(V,N),P--):caml_is_ml_string(N)?(V=caml_hash_mix_string(V,N),P--):typeof N=="string"?(V=caml_hash_mix_jsbytes(V,N),P--):N===(N|0)?(V=caml_hash_mix_int(V,N+N+1),P--):N===+N&&(V=caml_hash_mix_float(V,N),P--);return V=caml_hash_mix_final(V),V&1073741823}function Base_hash_double(_){return caml_hash(1,1,0,_)}function Base_hash_string(_){return caml_hash(1,1,0,_)}function Base_int_math_int32_clz(_){var e=32,u;return u=_>>16,u!=0&&(e=e-16,_=u),u=_>>8,u!=0&&(e=e-8,_=u),u=_>>4,u!=0&&(e=e-4,_=u),u=_>>2,u!=0&&(e=e-2,_=u),u=_>>1,u!=0?e-2:e-_}function Base_int_math_int32_ctz(_){if(_===0)return 32;var e=1;return _&65535||(e=e+16,_=_>>16),_&255||(e=e+8,_=_>>8),_&15||(e=e+4,_=_>>4),_&3||(e=e+2,_=_>>2),e-(_&1)}function caml_int64_shift_right_unsigned(_,e){return _.shift_right_unsigned(e)}function caml_int64_is_zero(_){return+_.isZero()}function caml_int64_to_int32(_){return _.toInt()}function Base_int_math_int64_clz(_){var e=64,u;return u=caml_int64_shift_right_unsigned(_,32),caml_int64_is_zero(u)||(e=e-32,_=u),u=caml_int64_shift_right_unsigned(_,16),caml_int64_is_zero(u)||(e=e-16,_=u),u=caml_int64_shift_right_unsigned(_,8),caml_int64_is_zero(u)||(e=e-8,_=u),u=caml_int64_shift_right_unsigned(_,4),caml_int64_is_zero(u)||(e=e-4,_=u),u=caml_int64_shift_right_unsigned(_,2),caml_int64_is_zero(u)||(e=e-2,_=u),u=caml_int64_shift_right_unsigned(_,1),caml_int64_is_zero(u)?e-caml_int64_to_int32(_):e-2}function caml_int64_and(_,e){return _.and(e)}function caml_int64_of_int32(_){return new MlInt64(_&16777215,_>>24&16777215,_>>31&65535)}function Base_int_math_int64_ctz(_){if(caml_int64_is_zero(_))return 64;var e=1;function u(w){return caml_int64_is_zero(w)}function d(w,q){return caml_int64_and(w,q)}function $(w){return caml_int64_create_lo_mi_hi(w,0,0)}return u(d(_,caml_int64_create_lo_mi_hi(16777215,255,0)))&&(e=e+32,_=caml_int64_shift_right_unsigned(_,32)),u(d(_,$(65535)))&&(e=e+16,_=caml_int64_shift_right_unsigned(_,16)),u(d(_,$(255)))&&(e=e+8,_=caml_int64_shift_right_unsigned(_,8)),u(d(_,$(15)))&&(e=e+4,_=caml_int64_shift_right_unsigned(_,4)),u(d(_,$(3)))&&(e=e+2,_=caml_int64_shift_right_unsigned(_,2)),e-caml_int64_to_int32(caml_int64_and(_,$(1)))}function caml_int64_mul(_,e){return _.mul(e)}function Base_int_math_int64_pow_stub(_,e){for(var u=caml_int64_create_lo_hi(1,0),d=[u,_,u,u],$=u;!caml_int64_is_zero(e);)d[1]=caml_int64_mul(d[1],d[3]),d[2]=caml_int64_mul(d[1],d[1]),d[3]=caml_int64_mul(d[2],d[1]),$=caml_int64_mul($,d[caml_int64_lo32(e)&3]),e=caml_int64_shift_right_unsigned(e,2);return $}function Base_int_math_int_clz(_){return Base_int_math_int32_clz(_)}function Base_int_math_int_ctz(_){return Base_int_math_int32_ctz(_)}function Base_int_math_int_popcount(_){return _=_-(_>>>1&1431655765),_=(_&858993459)+(_>>>2&858993459),(_+(_>>>4)&252645135)*16843009>>>24}function Base_int_math_int_pow_stub(_,e){for(var u=1,d=[u,_,u,u],$=u;!e==0;)d[1]=d[1]*d[3]|0,d[2]=d[1]*d[1]|0,d[3]=d[2]*d[1]|0,$=$*d[e&3]|0,e=e>>2;return $}function Base_int_math_nativeint_clz(_){return Base_int_math_int32_clz(_)}function Base_int_math_nativeint_ctz(_){return Base_int_math_int32_ctz(_)}var Base_internalhash_fold_float=caml_hash_mix_float,Base_internalhash_fold_int=caml_hash_mix_int,Base_internalhash_fold_int64=caml_hash_mix_int64,Base_internalhash_fold_string=caml_hash_mix_string;function Base_internalhash_get_hash_value(_){var e=caml_hash_mix_final(_);return e&1073741823}function incr_nat(_,e,u,d){for(var $=d,w=0;w>>0)+$;if(_.data[e+w]=q|0,q==q>>>0){$=0;break}else $=1}return $}function add_nat(_,e,u,d,$,w,q){for(var z=q,P=0;P>>0)+(d.data[$+P]>>>0)+z;_.data[e+P]=V,V==V>>>0?z=0:z=1}return incr_nat(_,e+w,u-w,z)}function caml_js_from_array(_){return _.slice(1)}function caml_ba_create(_,e,u){var d=caml_js_from_array(u),$=caml_ba_create_buffer(_,caml_ba_get_size(d));return caml_ba_create_unsafe(_,e,d,$)}function bigstring_alloc(_,e){return caml_ba_create(12,0,[0,e])}function caml_ml_bytes_length(_){return _.l}function caml_convert_bytes_to_array(_){if(globalThis.Uint8Array)var e=new globalThis.Uint8Array(_.l);else var e=new Array(_.l);for(var u=_.c,d=u.length,$=0;$=u.l||u.t==2&&$>=u.c.length))u.c=_.t==4?caml_subarray_to_jsbytes(_.c,e,$):e==0&&_.c.length==$?_.c:_.c.substr(e,$),u.t=u.c.length==u.l?0:2;else if(u.t==2&&d==u.c.length)u.c+=_.t==4?caml_subarray_to_jsbytes(_.c,e,$):e==0&&_.c.length==$?_.c:_.c.substr(e,$),u.t=u.c.length==u.l?0:2;else{u.t!=4&&caml_convert_bytes_to_array(u);var w=_.c,q=u.c;if(_.t==4)if(d<=e)for(var z=0;z<$;z++)q[d+z]=w[e+z];else for(var z=$-1;z>=0;z--)q[d+z]=w[e+z];else{for(var P=Math.min($,w.length-e),z=0;z_.data.length&&caml_array_bound_error(),d+$>caml_ml_bytes_length(u)&&caml_array_bound_error();var q=_.data.slice(w,w+$);return caml_blit_bytes(caml_bytes_of_array(q),0,u,d,$),0}function bigstring_blit_bigstring_bytes_stub(_,e,u,d,$){return caml_bigstring_blit_ba_to_bytes(_,e,u,d,$)}function caml_array_of_bytes(_){return _.t!=4&&caml_convert_bytes_to_array(_),_.c}function caml_bigstring_blit_bytes_to_ba(_,e,u,d,$){if(u.kind!=12&&caml_invalid_argument("caml_bigstring_blit_string_to_ba: kind mismatch"),$==0)return 0;var w=u.offset(d);e+$>caml_ml_bytes_length(_)&&caml_array_bound_error(),w+$>u.data.length&&caml_array_bound_error();var q=caml_array_of_bytes(_).slice(e,e+$);return u.data.set(q,w),0}function bigstring_blit_bytes_bigstring_stub(_,e,u,d,$){return caml_bigstring_blit_bytes_to_ba(_,e,u,d,$)}function caml_ml_string_length(_){return caml_ml_bytes_length(_)}function caml_bytes_unsafe_get(_,e){switch(_.t&6){default:if(e>=_.c.length)return 0;case 0:return _.c.charCodeAt(e);case 4:return _.c[e]}}function caml_string_unsafe_get(_,e){return caml_bytes_unsafe_get(_,e)}function caml_array_of_string(_){for(var e=caml_ml_string_length(_),u=new Array(e),d=0;dcaml_ml_string_length(_)&&caml_array_bound_error(),w+$>u.data.length&&caml_array_bound_error();var q=caml_array_of_string(_).slice(e,e+$);return u.data.set(q,w),0}function bigstring_blit_string_bigstring_stub(_,e,u,d,$){return caml_bigstring_blit_string_to_ba(_,e,u,d,$)}function caml_bigstring_blit_ba_to_ba(_,e,u,d,$){if(_.kind!=12&&caml_invalid_argument("caml_bigstring_blit_ba_to_ba: kind mismatch"),u.kind!=12&&caml_invalid_argument("caml_bigstring_blit_ba_to_ba: kind mismatch"),$==0)return 0;var w=_.offset(e),q=u.offset(d);w+$>_.data.length&&caml_array_bound_error(),q+$>u.data.length&&caml_array_bound_error();var z=_.data.subarray(w,w+$);return u.data.set(z,d),0}function bigstring_blit_stub(_,e,u,d,$){return caml_bigstring_blit_ba_to_ba(_,e,u,d,$)}function caml_bytes_unsafe_set(_,e,u){if(u&=255,_.t!=4){if(e==_.c.length)return _.c+=String.fromCharCode(u),e+1==_.l&&(_.t=0),0;caml_convert_bytes_to_array(_)}return _.c[e]=u,0}function caml_string_unsafe_set(_,e,u){return caml_bytes_unsafe_set(_,e,u)}function caml_ba_get_1(_,e){return _.get(_.offset(e))}function bigstringaf_blit_to_bytes(_,e,u,d,$){for(var w=0;w<$;w++)caml_string_unsafe_set(u,d+w,caml_ba_get_1(_,e+w))}function bin_prot_blit_buf_bytes_stub(_,e,u,d,$){return caml_bigstring_blit_ba_to_bytes(e,_,d,u,$)}function caml_check_bound(_,e){return e>>>0>=_.length-1&&caml_array_bound_error(),_}function caml_check_bound_bigstring(_,e){e>>>0>=_.data.length&&caml_array_bound_error()}function bin_prot_blit_buf_float_array_stub(_,e,u,d,$){if($==0)return 0;caml_check_bound(d,u),caml_check_bound(d,u+$-1),caml_check_bound_bigstring(e,_),caml_check_bound_bigstring(e,_+$*8-1);var w=new joo_global_object.Float64Array($),q=new joo_global_object.Uint8Array(w.buffer);q.set(e.data.subarray(_,_+$*8));for(var z=0;z<$;z++)d[u+z+1]=w[z];return 0}function bin_prot_blit_float_array_buf_stub(_,e,u,d,$){if($==0)return 0;caml_check_bound(e,_),caml_check_bound(e,_+$-1),caml_check_bound_bigstring(d,u),caml_check_bound_bigstring(d,u+$*8-1),_=_+1;var w=new joo_global_object.Float64Array(e.slice(_,_+$)),q=new joo_global_object.Uint8Array(w.buffer),z=d.data.subarray(u,u+$*8);return z.set(q),0}function bin_prot_blit_string_buf_stub(_,e,u,d,$){return caml_bigstring_blit_string_to_ba(e,_,d,u,$)}function blit_nat(_,e,u,d,$){for(var w=0;w<$;w++)_.data[e+w]=u.data[d+w];return 0}function caml_array_append(_,e){var u=_.length,d=e.length,$=u+d-1,w=new Array($);w[0]=0;for(var q=1,z=1;q=1;w--)u[d+w]=_[e+w];return 0}function caml_array_concat(_){for(var e=[0];_!==0;){for(var u=_[1],d=1;d=_.length-1)&&caml_array_bound_error(),_[e+1]=u,0}function caml_array_sub(_,e,u){var d=new Array(u+1);d[0]=0;for(var $=1,w=e+1;$<=u;$++,w++)d[$]=_[w];return d}function caml_ba_blit(_,e){e.dims.length!=_.dims.length&&caml_invalid_argument("Bigarray.blit: dimension mismatch");for(var u=0;u=_.dims.length)&&caml_invalid_argument("Bigarray.dim"),_.dims[e]}function caml_ba_dim_1(_){return caml_ba_dim(_,0)}function caml_ba_dim_2(_){return caml_ba_dim(_,1)}function caml_ba_get_2(_,e,u){return _.get(_.offset([e,u]))}function caml_ba_layout(_){return _.layout}function caml_ba_set_1(_,e,u){return _.set(_.offset(e),u),0}function caml_ba_set_2(_,e,u,d){return _.set(_.offset([e,u]),d),0}function caml_ba_sub(_,e,u){var d,$=1;if(_.layout==0){for(var w=1;w<_.dims.length;w++)$=$*_.dims[w];d=0}else{for(var w=0;w<_.dims.length-1;w++)$=$*_.dims[w];d=_.dims.length-1,e=e-1}(e<0||u<0||e+u>_.dims[d])&&caml_invalid_argument("Bigarray.sub: bad sub-array");for(var q=[],w=0;w<_.dims.length;w++)q[w]=_.dims[w];q[d]=u,$*=caml_ba_get_size_per_element(_.kind);var z=_.data.subarray(e*$,(e+u)*$);return caml_ba_create_unsafe(_.kind,_.layout,q,z)}function caml_ba_uint8_get16(_,e){var u=_.offset(e);u+1>=_.data.length&&caml_array_bound_error();var d=_.get(u),$=_.get(u+1);return d|$<<8}function caml_ba_uint8_get32(_,e){var u=_.offset(e);u+3>=_.data.length&&caml_array_bound_error();var d=_.get(u+0),$=_.get(u+1),w=_.get(u+2),q=_.get(u+3);return d<<0|$<<8|w<<16|q<<24}function caml_ba_uint8_get64(_,e){var u=_.offset(e);u+7>=_.data.length&&caml_array_bound_error();var d=_.get(u+0),$=_.get(u+1),w=_.get(u+2),q=_.get(u+3),z=_.get(u+4),P=_.get(u+5),V=_.get(u+6),N=_.get(u+7);return caml_int64_of_bytes([N,V,P,z,q,w,$,d])}function caml_ba_uint8_set16(_,e,u){var d=_.offset(e);return d+1>=_.data.length&&caml_array_bound_error(),_.set(d+0,u&255),_.set(d+1,u>>>8&255),0}function caml_ba_uint8_set32(_,e,u){var d=_.offset(e);return d+3>=_.data.length&&caml_array_bound_error(),_.set(d+0,u&255),_.set(d+1,u>>>8&255),_.set(d+2,u>>>16&255),_.set(d+3,u>>>24&255),0}function caml_ba_uint8_set64(_,e,$){var d=_.offset(e);d+7>=_.data.length&&caml_array_bound_error();for(var $=caml_int64_to_bytes($),w=0;w<8;w++)_.set(d+w,$[7-w]);return 0}function caml_backtrace_status(){return 0}var plonk_wasm=globalThis.plonk_wasm,caml_bigint_256_bytes_per_limb=plonk_wasm.caml_bigint_256_bytes_per_limb,caml_bigint_256_compare=plonk_wasm.caml_bigint_256_compare,caml_bigint_256_div=plonk_wasm.caml_bigint_256_div,caml_bigint_256_num_limbs=plonk_wasm.caml_bigint_256_num_limbs;function caml_bytes_to_uint8array(_){for(var e=caml_ml_bytes_length(_),u=new globalThis.Uint8Array(e),d=0;d512?(u.substr(0,1),e+=u,u="",e+=_.slice(w,z)):u+=_.slice(w,z),z==q)break;w=z}d<2048?(u+=String.fromCharCode(192|d>>6),u+=String.fromCharCode(128|d&63)):d<55296||d>=57343?u+=String.fromCharCode(224|d>>12,128|d>>6&63,128|d&63):d>=56319||w+1==q||($=_.charCodeAt(w+1))<56320||$>57343?u+="\xEF\xBF\xBD":(w++,d=(d<<10)+$-56613888,u+=String.fromCharCode(240|d>>18,128|d>>12&63,128|d>>6&63,128|d&63)),u.length>1024&&(u.substr(0,1),e+=u,u="")}return e+u}function caml_bytes_of_utf16_jsstring(_){var e=9;return jsoo_is_ascii(_)||(e=8,_=caml_utf8_of_utf16(_)),new MlBytes(e,_,_.length)}function caml_string_of_jsstring(_){return caml_bytes_of_utf16_jsstring(_)}function caml_bigint_256_to_string(_){return caml_string_of_jsstring(plonk_wasm.caml_bigint_256_to_string(_))}function caml_bytes_of_string(_){return _}function caml_blit_string(_,e,u,d,$){return caml_blit_bytes(_,e,u,d,$),0}function caml_bswap16(_){return(_&255)<<8|(_&65280)>>8}function caml_bytes_compare(_,e){return _.t&6&&caml_convert_string_to_bytes(_),e.t&6&&caml_convert_string_to_bytes(e),_.ce.c?1:0}function caml_bytes_equal(_,e){return _===e?1:(_.t&6&&caml_convert_string_to_bytes(_),e.t&6&&caml_convert_string_to_bytes(e),_.c==e.c?1:0)}function caml_bytes_bound_error(){caml_invalid_argument("index out of bounds")}function caml_bytes_get(_,e){return e>>>0>=_.l&&caml_bytes_bound_error(),caml_bytes_unsafe_get(_,e)}function caml_bytes_get16(_,e){e>>>0>=_.l-1&&caml_bytes_bound_error();var u=caml_bytes_unsafe_get(_,e),d=caml_bytes_unsafe_get(_,e+1);return d<<8|u}function caml_bytes_lessequal(_,e){return _.t&6&&caml_convert_string_to_bytes(_),e.t&6&&caml_convert_string_to_bytes(e),_.c<=e.c?1:0}function caml_bytes_greaterequal(_,e){return caml_bytes_lessequal(e,_)}function caml_bytes_lessthan(_,e){return _.t&6&&caml_convert_string_to_bytes(_),e.t&6&&caml_convert_string_to_bytes(e),_.c>>0>=_.l&&caml_bytes_bound_error(),caml_bytes_unsafe_set(_,e,u)}function caml_bytes_set16(_,e,u){e>>>0>=_.l-1&&caml_bytes_bound_error();var d=255&u>>8,$=255&u;return caml_bytes_unsafe_set(_,e+0,$),caml_bytes_unsafe_set(_,e+1,d),0}function caml_bytes_set32(_,e,u){e>>>0>=_.l-3&&caml_bytes_bound_error();var d=255&u>>24,$=255&u>>16,w=255&u>>8,q=255&u;return caml_bytes_unsafe_set(_,e+0,q),caml_bytes_unsafe_set(_,e+1,w),caml_bytes_unsafe_set(_,e+2,$),caml_bytes_unsafe_set(_,e+3,d),0}function caml_bytes_set64(_,e,u){e>>>0>=_.l-7&&caml_bytes_bound_error();for(var d=caml_int64_to_bytes(u),$=0;$<8;$++)caml_bytes_unsafe_set(_,e+7-$,d[$]);return 0}function caml_call_gen(_,e){if(_.fun)return caml_call_gen(_.fun,e);if(typeof _!="function")return _;var u=_.length|0;if(u===0)return _.apply(null,e);var d=e.length|0,$=u-d|0;return $==0?_.apply(null,e):$<0?caml_call_gen(_.apply(null,e.slice(0,u)),e.slice(u)):function(){for(var w=arguments.length==0?1:arguments.length,q=new Array(e.length+w),z=0;z=22250738585072014e-324?0:_!=0?1:2:isNaN(_)?4:3}function caml_compare_val_get_custom(_){return caml_custom_ops[_.caml_custom]&&caml_custom_ops[_.caml_custom].compare}function caml_compare_val_number_custom(_,e,u,d){var $=caml_compare_val_get_custom(e);if($){var w=u>0?$(e,_,d):$(_,e,d);if(d&&w!=w)return u;if(+w!=+w)return+w;if(w|0)return w|0}return u}function caml_compare_val_tag(_){if(typeof _=="number")return 1e3;if(caml_is_ml_bytes(_))return 252;if(caml_is_ml_string(_))return 1252;if(_ instanceof Array&&_[0]===_[0]>>>0&&_[0]<=255){var e=_[0]|0;return e==254?0:e}else{if(_ instanceof String)return 12520;if(typeof _=="string")return 12520;if(_ instanceof Number)return 1e3;if(_&&_.caml_custom)return 1255;if(_&&_.compare)return 1256;if(typeof _=="function")return 1247;if(typeof _=="symbol")return 1251}return 1001}function caml_int_compare(_,e){return _e)return 1;if(_!=e){if(!u)return NaN;if(_==_)return 1;if(e==e)return-1}break;case 1001:if(_e)return 1;if(_!=e){if(!u)return NaN;if(_==_)return 1;if(e==e)return-1}break;case 1251:if(_!==e)return u?1:NaN;break;case 1252:var _=caml_jsbytes_of_string(_),e=caml_jsbytes_of_string(e);if(_!==e){if(_e)return 1}break;case 12520:var _=_.toString(),e=e.toString();if(_!==e){if(_e)return 1}break;case 246:case 254:default:if(_.length!=e.length)return _.length1&&d.push(_,e,1);break}}if(d.length==0)return 0;var P=d.pop();e=d.pop(),_=d.pop(),P+1<_.length&&d.push(_,e,P+1),_=_[P],e=e[P]}}function caml_compare(_,e){return caml_compare_val(_,e,!0)}function caml_convert_raw_backtrace(){return[0]}function caml_convert_raw_backtrace_slot(){caml_failwith("caml_convert_raw_backtrace_slot")}function caml_div(_,e){return e==0&&caml_raise_zero_divide(),_/e|0}var caml_ephe_key_offset=3;function caml_weak_create(_){_<0&&caml_invalid_argument("Weak.create");var e=[251,"caml_ephe_list_head"];return e.length=caml_ephe_key_offset+_,e}var caml_ephe_create=caml_weak_create,caml_ephe_data_offset=2;function caml_ephe_get_data(_){return _[caml_ephe_data_offset]===void 0?0:[0,_[caml_ephe_data_offset]]}function caml_ephe_set_data(_,e){return _[caml_ephe_data_offset]=e,0}function caml_weak_set(_,e,u){return(e<0||caml_ephe_key_offset+e>=_.length)&&caml_invalid_argument("Weak.set"),_[caml_ephe_key_offset+e]=u,0}function caml_ephe_set_key(_,e,u){return caml_weak_set(_,e,[0,u])}function caml_equal(_,e){return+(caml_compare_val(_,e,!1)==0)}function caml_fill_bytes(_,e,u,d){if(u>0)if(e==0&&(u>=_.l||_.t==2&&u>=_.c.length))d==0?(_.c="",_.t=2):(_.c=caml_str_repeat(u,String.fromCharCode(d)),_.t=u==_.l?0:2);else for(_.t!=4&&caml_convert_bytes_to_array(_),u+=e;ee||_===_?1:e===e?-1:0}function caml_float_of_string(_){var e;if(_=caml_jsbytes_of_string(_),e=+_,_.length>0&&e===e||(_=_.replace(/_/g,""),e=+_,_.length>0&&e===e||/^[+-]?nan$/i.test(_)))return e;var u=/^ *([+-]?)0x([0-9a-f]+)\.?([0-9a-f]*)(p([+-]?[0-9]+))?/i.exec(_);if(u){var d=u[3].replace(/0+$/,""),$=parseInt(u[1]+u[2]+d,16),w=(u[5]|0)-4*d.length;return e=$*Math.pow(2,w),e}if(/^\+?inf(inity)?$/i.test(_))return 1/0;if(/^-inf(inity)?$/i.test(_))return-1/0;caml_failwith("float_of_string")}function caml_parse_format(_){_=caml_jsbytes_of_string(_);var e=_.length;e>31&&caml_invalid_argument("format_int: format too long");for(var u={justify:"+",signstyle:"-",filler:" ",alternate:!1,base:0,signedconv:!1,width:0,uppercase:!1,sign:1,prec:-1,conv:"f"},d=0;d=0&&$<=9;)u.width=u.width*10+$,d++;d--;break;case".":for(u.prec=0,d++;$=_.charCodeAt(d)-48,$>=0&&$<=9;)u.prec=u.prec*10+$,d++;d--;case"d":case"i":u.signedconv=!0;case"u":u.base=10;break;case"x":u.base=16;break;case"X":u.base=16,u.uppercase=!0;break;case"o":u.base=8;break;case"e":case"f":case"g":u.signedconv=!0,u.conv=$;break;case"E":case"F":case"G":u.signedconv=!0,u.uppercase=!0,u.conv=$.toLowerCase();break}}return u}function caml_finish_formatting(_,e){_.uppercase&&(e=e.toUpperCase());var u=e.length;_.signedconv&&(_.sign<0||_.signstyle!="-")&&u++,_.alternate&&(_.base==8&&(u+=1),_.base==16&&(u+=2));var d="";if(_.justify=="+"&&_.filler==" ")for(var $=u;$<_.width;$++)d+=" ";if(_.signedconv&&(_.sign<0?d+="-":_.signstyle!="-"&&(d+=_.signstyle)),_.alternate&&_.base==8&&(d+="0"),_.alternate&&_.base==16&&(d+="0x"),_.justify=="+"&&_.filler=="0")for(var $=u;$<_.width;$++)d+="0";if(d+=e,_.justify=="-")for(var $=u;$<_.width;$++)d+=" ";return caml_string_of_jsbytes(d)}function caml_format_float(_,e){function u(N,L){if(Math.abs(N)<1)return N.toFixed(L);var U=parseInt(N.toString().split("+")[1]);return U>20?(U-=20,N/=Math.pow(10,U),N+=new Array(U+1).join("0"),L>0&&(N=N+"."+new Array(L+1).join("0")),N):N.toFixed(L)}var d,$=caml_parse_format(_),w=$.prec<0?6:$.prec;if((e<0||e==0&&1/e==-1/0)&&($.sign=-1,e=-e),isNaN(e))d="nan",$.filler=" ";else if(!isFinite(e))d="inf",$.filler=" ";else switch($.conv){case"e":var d=e.toExponential(w),q=d.length;d.charAt(q-3)=="e"&&(d=d.slice(0,q-1)+"0"+d.slice(q-1));break;case"f":d=u(e,w);break;case"g":w=w||1,d=e.toExponential(w-1);var z=d.indexOf("e"),P=+d.slice(z+1);if(P<-4||e>=1e21||e.toFixed(0).length>w){for(var q=z-1;d.charAt(q)=="0";)q--;d.charAt(q)=="."&&q--,d=d.slice(0,q+1)+d.slice(z),q=d.length,d.charAt(q-3)=="e"&&(d=d.slice(0,q-1)+"0"+d.slice(q-1));break}else{var V=w;if(P<0)V-=P+1,d=e.toFixed(V);else for(;d=e.toFixed(V),d.length>w+1;)V--;if(V){for(var q=d.length-1;d.charAt(q)=="0";)q--;d.charAt(q)=="."&&q--,d=d.slice(0,q+1)}}break}return caml_finish_formatting($,d)}function caml_format_int(_,e){if(caml_jsbytes_of_string(_)=="%d")return caml_string_of_jsbytes(""+e);var u=caml_parse_format(_);e<0&&(u.signedconv?(u.sign=-1,e=-e):e>>>=0);var d=e.toString(u.base);if(u.prec>=0){u.filler=" ";var $=u.prec-d.length;$>0&&(d=caml_str_repeat($,"0")+d)}return caml_finish_formatting(u,d)}function rust_affine_to_caml_affine(_){var e=_.infinity;if(e)return _.free(),0;var u=_.x,d=_.y;return _.free(),[0,[0,u,d]]}function js_class_vector_of_rust_vector(_,e){for(var u=_.length,d=new Array(u),$=0;$=1;)_*=.5,u++;return e&&(_=-_),[0,_,u]}function fs_node_supported(){return typeof globalThis.process<"u"&&typeof globalThis.process.versions<"u"&&typeof globalThis.process.versions.node<"u"}function make_path_is_absolute(){function _(u){if(u.charAt(0)==="/")return["",u.substring(1)]}function e(u){var d=/^([a-zA-Z]:|[\\/]{2}[^\\/]+[\\/]+[^\\/]+)?([\\/])?([\s\S]*?)$/,$=d.exec(u),w=$[1]||"",q=Boolean(w&&w.charAt(1)!==":");if(Boolean($[2]||q)){var z=$[1]||"",P=$[2]||"";return[z,u.substring(z.length+P.length)]}}return fs_node_supported()&&globalThis.process&&globalThis.process.platform&&globalThis.process.platform==="win32"?e:_}var path_is_absolute=make_path_is_absolute();function caml_trailing_slash(_){return _.slice(-1)!=="/"?_+"/":_}if(fs_node_supported()&&globalThis.process&&globalThis.process.cwd)var caml_current_dir=globalThis.process.cwd().replace(/\\/g,"/");else var caml_current_dir="/static";caml_current_dir=caml_trailing_slash(caml_current_dir);function caml_make_path(_){_=caml_jsstring_of_string(_),path_is_absolute(_)||(_=caml_current_dir+_);for(var e=path_is_absolute(_),u=e[1].split("/"),d=[],$=0;$1&&d.pop();break;case".":break;default:d.push(u[$]);break}return d.unshift(e[0]),d.orig=_,d}var unix_error=["E2BIG","EACCES","EAGAIN","EBADF","EBUSY","ECHILD","EDEADLK","EDOM","EEXIST","EFAULT","EFBIG","EINTR","EINVAL","EIO","EISDIR","EMFILE","EMLINK","ENAMETOOLONG","ENFILE","ENODEV","ENOENT","ENOEXEC","ENOLCK","ENOMEM","ENOSPC","ENOSYS","ENOTDIR","ENOTEMPTY","ENOTTY","ENXIO","EPERM","EPIPE","ERANGE","EROFS","ESPIPE","ESRCH","EXDEV","EWOULDBLOCK","EINPROGRESS","EALREADY","ENOTSOCK","EDESTADDRREQ","EMSGSIZE","EPROTOTYPE","ENOPROTOOPT","EPROTONOSUPPORT","ESOCKTNOSUPPORT","EOPNOTSUPP","EPFNOSUPPORT","EAFNOSUPPORT","EADDRINUSE","EADDRNOTAVAIL","ENETDOWN","ENETUNREACH","ENETRESET","ECONNABORTED","ECONNRESET","ENOBUFS","EISCONN","ENOTCONN","ESHUTDOWN","ETOOMANYREFS","ETIMEDOUT","ECONNREFUSED","EHOSTDOWN","EHOSTUNREACH","ELOOP","EOVERFLOW"];function make_unix_err_args(_,e,u,d){var $=unix_error.indexOf(_);$<0&&(d==null&&(d=-9999),$=[0,d]);var w=[$,caml_string_of_jsstring(e||""),caml_string_of_jsstring(u||"")];return w}var caml_named_values={};function caml_named_value(_){return caml_named_values[_]}function caml_raise_with_args(_,e){throw[0,_].concat(e)}function caml_raise_sys_error(_){caml_raise_with_string(caml_global_data.Sys_error,_)}function caml_raise_no_such_file(_){caml_raise_sys_error(_+": No such file or directory")}function MlFile(){}function MlFakeFile(_){this.data=_}MlFakeFile.prototype=new MlFile,MlFakeFile.prototype.truncate=function(_){var e=this.data;this.data=caml_create_bytes(_|0),caml_blit_bytes(e,0,this.data,0,_)},MlFakeFile.prototype.length=function(){return caml_ml_bytes_length(this.data)},MlFakeFile.prototype.write=function(_,e,u,d){var $=this.length();if(_+d>=$){var w=caml_create_bytes(_+d),q=this.data;this.data=w,caml_blit_bytes(q,0,this.data,0,$)}return caml_blit_string(e,u,this.data,_,d),0},MlFakeFile.prototype.read=function(_,e,u,d){var $=this.length();return caml_blit_bytes(this.data,_,e,u,d),0},MlFakeFile.prototype.read_one=function(_){return caml_bytes_get(this.data,_)},MlFakeFile.prototype.close=function(){},MlFakeFile.prototype.constructor=MlFakeFile;function MlFakeDevice(_,e){this.content={},this.root=_,this.lookupFun=e}MlFakeDevice.prototype.nm=function(_){return this.root+_},MlFakeDevice.prototype.create_dir_if_needed=function(_){for(var e=_.split("/"),u="",d=0;d>1|1,e=0)}function caml_greaterthan(_,e){return+(caml_compare_val(_,e,!1)>0)}function caml_hexstring_of_float(_,e,u){if(!isFinite(_))return isNaN(_)?caml_string_of_jsstring("nan"):caml_string_of_jsstring(_>0?"infinity":"-infinity");var d=_==0&&1/_==-1/0?1:_>=0?0:1;d&&(_=-_);var $=0;if(_!=0)if(_<1)for(;_<1&&$>-1022;)_*=2,$--;else for(;_>=2;)_/=2,$++;var w=$<0?"":"+",q="";if(d)q="-";else switch(u){case 43:q="+";break;case 32:q=" ";break;default:break}if(e>=0&&e<13){var z=Math.pow(2,e*4);_=Math.round(_*z)/z}var P=_.toString(16);if(e>=0){var V=P.indexOf(".");if(V<0)P+="."+caml_str_repeat(e,"0");else{var N=V+1+e;P.length>24},read16u:function(){var _=this.s,e=this.i;return this.i=e+2,_.charCodeAt(e)<<8|_.charCodeAt(e+1)},read16s:function(){var _=this.s,e=this.i;return this.i=e+2,_.charCodeAt(e)<<24>>16|_.charCodeAt(e+1)},read32u:function(){var _=this.s,e=this.i;return this.i=e+4,(_.charCodeAt(e)<<24|_.charCodeAt(e+1)<<16|_.charCodeAt(e+2)<<8|_.charCodeAt(e+3))>>>0},read32s:function(){var _=this.s,e=this.i;return this.i=e+4,_.charCodeAt(e)<<24|_.charCodeAt(e+1)<<16|_.charCodeAt(e+2)<<8|_.charCodeAt(e+3)},readstr:function(_){var e=this.i;return this.i=e+_,caml_string_of_jsbytes(this.s.substring(e,e+_))}};function caml_float_of_bytes(_){return caml_int64_float_of_bits(caml_int64_of_bytes(_))}function caml_input_value_from_reader(_,e){var u=_.read32u(),d=_.read32u(),$=_.read32u(),w=_.read32u(),q=_.read32u(),z=[],P=$>0?[]:null,V=0;function N(){var K=_.read8u();if(K>=64)if(K>=128){var R=K&15,J=K>>4&7,Q=[R];return J==0||(P&&(P[V++]=Q),z.push(Q,J)),Q}else return K&63;else if(K>=32){var X=K&31,Q=_.readstr(X);return P&&(P[V++]=Q),Q}else switch(K){case 0:return _.read8s();case 1:return _.read16s();case 2:return _.read32s();case 3:caml_failwith("input_value: integer too large");break;case 4:var Z=_.read8u();return P[V-Z];case 5:var Z=_.read16u();return P[V-Z];case 6:var Z=_.read32u();return P[V-Z];case 8:var I=_.read32u(),R=I&255,J=I>>10,Q=[R];return J==0||(P&&(P[V++]=Q),z.push(Q,J)),Q;case 19:caml_failwith("input_value: data block too large");break;case 9:var X=_.read8u(),Q=_.readstr(X);return P&&(P[V++]=Q),Q;case 10:var X=_.read32u(),Q=_.readstr(X);return P&&(P[V++]=Q),Q;case 12:for(var e_=new Array(8),__=0;__<8;__++)e_[7-__]=_.read8u();var Q=caml_float_of_bytes(e_);return P&&(P[V++]=Q),Q;case 11:for(var e_=new Array(8),__=0;__<8;__++)e_[__]=_.read8u();var Q=caml_float_of_bytes(e_);return P&&(P[V++]=Q),Q;case 14:var X=_.read8u(),Q=new Array(X+1);Q[0]=254;var e_=new Array(8);P&&(P[V++]=Q);for(var __=1;__<=X;__++){for(var t_=0;t_<8;t_++)e_[7-t_]=_.read8u();Q[__]=caml_float_of_bytes(e_)}return Q;case 13:var X=_.read8u(),Q=new Array(X+1);Q[0]=254;var e_=new Array(8);P&&(P[V++]=Q);for(var __=1;__<=X;__++){for(var t_=0;t_<8;t_++)e_[t_]=_.read8u();Q[__]=caml_float_of_bytes(e_)}return Q;case 7:var X=_.read32u(),Q=new Array(X+1);Q[0]=254,P&&(P[V++]=Q);for(var e_=new Array(8),__=1;__<=X;__++){for(var t_=0;t_<8;t_++)e_[7-t_]=_.read8u();Q[__]=caml_float_of_bytes(e_)}return Q;case 15:var X=_.read32u(),Q=new Array(X+1);Q[0]=254;for(var e_=new Array(8),__=1;__<=X;__++){for(var t_=0;t_<8;t_++)e_[t_]=_.read8u();Q[__]=caml_float_of_bytes(e_)}return Q;case 16:case 17:caml_failwith("input_value: code pointer");break;case 18:case 24:case 25:for(var a_,r_="";(a_=_.read8u())!=0;)r_+=String.fromCharCode(a_);var n_=caml_custom_ops[r_],c_;switch(n_||caml_failwith("input_value: unknown custom block identifier"),K){case 18:break;case 25:n_.fixed_length||caml_failwith("input_value: expected a fixed-size custom block"),c_=n_.fixed_length;break;case 24:c_=_.read32u(),_.read32s(),_.read32s();break}var l_=_.i,J=[0],Q=n_.deserialize(_,J);return c_!=null&&c_!=J[0]&&caml_failwith("input_value: incorrect length of serialized custom block"),P&&(P[V++]=Q),Q;default:caml_failwith("input_value: ill-formed message")}}for(var L=N();z.length>0;){var U=z.pop(),Y=z.pop(),W=Y.length;W>>8|(_&4278190080)>>>24}function caml_int64_add(_,e){return _.add(e)}function caml_int64_bswap(_){var e=caml_int64_to_bytes(_);return caml_int64_of_bytes([e[7],e[6],e[5],e[4],e[3],e[2],e[1],e[0]])}function caml_int64_div(_,e){return _.div(e)}function caml_int64_is_negative(_){return+_.isNeg()}function caml_int64_neg(_){return _.neg()}function caml_int64_format(_,e){var u=caml_parse_format(_);u.signedconv&&caml_int64_is_negative(e)&&(u.sign=-1,e=caml_int64_neg(e));var d="",$=caml_int64_of_int32(u.base),w="0123456789abcdef";do{var q=e.udivmod($);e=q.quotient,d=w.charAt(caml_int64_to_int32(q.modulus))+d}while(!caml_int64_is_zero(e));if(u.prec>=0){u.filler=" ";var z=u.prec-d.length;z>0&&(d=caml_str_repeat(z,"0")+d)}return caml_finish_formatting(u,d)}function caml_int64_mod(_,e){return _.mod(e)}function caml_int64_of_float(_){return _<0&&(_=Math.ceil(_)),new MlInt64(_&16777215,Math.floor(_*caml_int64_offset)&16777215,Math.floor(_*caml_int64_offset*caml_int64_offset)&65535)}function caml_int64_ult(_,e){return _.ucompare(e)<0}function caml_parse_sign_and_base(_){var e=0,u=caml_ml_string_length(_),d=10,$=1;if(u>0)switch(caml_string_unsafe_get(_,e)){case 45:e++,$=-1;break;case 43:e++,$=1;break}if(e+1=48&&_<=57?_-48:_>=65&&_<=90?_-55:_>=97&&_<=122?_-87:-1}function caml_int64_of_string(_){var e=caml_parse_sign_and_base(_),u=e[0],d=e[1],$=e[2],w=caml_int64_of_int32($),q=new MlInt64(16777215,268435455,65535).udivmod(w).quotient,z=caml_string_unsafe_get(_,u),P=caml_parse_digit(z);(P<0||P>=$)&&caml_failwith("int_of_string");for(var V=caml_int64_of_int32(P);;)if(u++,z=caml_string_unsafe_get(_,u),z!=95){if(P=caml_parse_digit(z),P<0||P>=$)break;caml_int64_ult(q,V)&&caml_failwith("int_of_string"),P=caml_int64_of_int32(P),V=caml_int64_add(caml_int64_mul(w,V),P),caml_int64_ult(V,P)&&caml_failwith("int_of_string")}return u!=caml_ml_string_length(_)&&caml_failwith("int_of_string"),$==10&&caml_int64_ult(new MlInt64(0,0,32768),V)&&caml_failwith("int_of_string"),d<0&&(V=caml_int64_neg(V)),V}function caml_int64_or(_,e){return _.or(e)}function caml_int64_shift_left(_,e){return _.shift_left(e)}function caml_int64_shift_right(_,e){return _.shift_right(e)}function caml_int64_sub(_,e){return _.sub(e)}function caml_int64_to_float(_){return _.toFloat()}function caml_int64_xor(_,e){return _.xor(e)}function caml_int_of_string(_){var e=caml_parse_sign_and_base(_),u=e[0],d=e[1],$=e[2],w=caml_ml_string_length(_),q=-1>>>0,z=u=$)&&caml_failwith("int_of_string");var V=P;for(u++;u=$)break;V=$*V+P,V>q&&caml_failwith("int_of_string")}return u!=w&&caml_failwith("int_of_string"),V=d*V,$==10&&(V|0)!=V&&caml_failwith("int_of_string"),V|0}function caml_js_eval_string(s){return eval(caml_jsstring_of_string(s))}function caml_js_to_array(_){var e=_.length,u=new Array(e+1);u[0]=0;for(var d=0;d0){for(var u=new Array(e),d=0;d1023&&(e-=1023,_*=Math.pow(2,1023),e>1023&&(e-=1023,_*=Math.pow(2,1023))),e<-1023&&(e+=1023,_*=Math.pow(2,-1023)),_*=Math.pow(2,e),_}function caml_lessequal(_,e){return+(caml_compare_val(_,e,!1)<=0)}function caml_lessthan(_,e){return+(caml_compare_val(_,e,!1)<0)}function caml_lex_array(_){_=caml_jsbytes_of_string(_);for(var e=_.length/2,u=new Array(e),d=0;d>16;return u}function caml_lex_engine(_,e,u){var d=2,$=3,w=5,q=6,z=7,P=8,V=9,N=1,L=2,U=3,Y=4,W=5;_.lex_default||(_.lex_base=caml_lex_array(_[N]),_.lex_backtrk=caml_lex_array(_[L]),_.lex_check=caml_lex_array(_[W]),_.lex_trans=caml_lex_array(_[Y]),_.lex_default=caml_lex_array(_[U]));var K,R=e,J=caml_array_of_bytes(u[d]);for(R>=0?(u[z]=u[w]=u[q],u[P]=-1):R=-R-1;;){var Q=_.lex_base[R];if(Q<0)return-Q-1;var X=_.lex_backtrk[R];if(X>=0&&(u[z]=u[q],u[P]=X),u[q]>=u[$]){if(u[V]==0)return-R-1;K=256}else K=J[u[q]],u[q]++;if(_.lex_check[Q+K]==R?R=_.lex_trans[Q+K]:R=_.lex_default[R],R<0)if(u[q]=u[z],u[P]==-1)caml_failwith("lexing: empty token");else return u[P];else K==256&&(u[V]=0)}}function caml_list_of_js_array(_){for(var e=0,u=_.length-1;u>=0;u--){var d=_[u];e=[0,d,e]}return e}function caml_log10_float(_){return Math.log10(_)}function caml_make_float_vect(e){e<0&&caml_array_bound_error();var e=e+1|0,u=new Array(e);u[0]=254;for(var d=1;d>>32-L,V)}function u(z,P,V,N,L,U,Y){return e(P&V|~P&N,z,P,L,U,Y)}function d(z,P,V,N,L,U,Y){return e(P&N|V&~N,z,P,L,U,Y)}function $(z,P,V,N,L,U,Y){return e(P^V^N,z,P,L,U,Y)}function w(z,P,V,N,L,U,Y){return e(V^(P|~N),z,P,L,U,Y)}function q(z,P){var V=P;for(z[V>>2]|=128<<8*(V&3),V=(V&-4)+8;(V&63)<60;V+=4)z[(V>>2)-1]=0;z[(V>>2)-1]=P<<3,z[V>>2]=P>>29&536870911;var N=[1732584193,4023233417,2562383102,271733878];for(V=0;V>8*R&255;return K}return function(z,P,V){var N=[],L=caml_ml_bytes_content(z);if(typeof L=="string"){for(var U=L,Y=0;Y>2]=U.charCodeAt(W)|U.charCodeAt(W+1)<<8|U.charCodeAt(W+2)<<16|U.charCodeAt(W+3)<<24}for(;Y>2]|=U.charCodeAt(Y+P)<<8*(Y&3)}else{for(var K=L,Y=0;Y>2]=K[W]|K[W+1]<<8|K[W+2]<<16|K[W+3]<<24}for(;Y>2]|=K[Y+P]<<8*(Y&3)}return caml_string_of_array(q(N,V))}}();function caml_md5_string(_,e,u){return caml_md5_bytes(_,e,u)}function caml_ml_channel_size(_){var e=caml_ml_channels[_];return e.file.length()}function caml_ml_channel_size_64(_){var e=caml_ml_channels[_];return caml_int64_of_float(e.file.length())}function caml_sys_close(_){return delete caml_global_data.fds[_],0}function caml_ml_flush(_){var e=caml_ml_channels[_];if(e.opened||caml_raise_sys_error("Cannot flush a closed channel"),!e.buffer||e.buffer=="")return 0;if(e.fd&&caml_global_data.fds[e.fd]&&caml_global_data.fds[e.fd].output){var u=caml_global_data.fds[e.fd].output;switch(u.length){case 2:u(_,e.buffer);break;default:u(e.buffer)}}return e.buffer="",0}function caml_ml_close_channel(_){var e=caml_ml_channels[_];return caml_ml_flush(_),e.opened=!1,e.file.close(),caml_sys_close(e.fd),0}function caml_ml_debug_info_status(){return 0}function caml_ml_refill_input(_){var e=_.refill(),u=caml_ml_string_length(e);return u==0&&(_.refill=null),_.file.write(_.file.length(),e,0,u),u}function caml_ml_input(_,e,u,d){var $=caml_ml_channels[_],w=$.file.length()-$.offset;return w==0&&$.refill!=null&&(w=caml_ml_refill_input($)),w=e.file.length()&&caml_raise_end_of_file();var u=e.file.read_one(e.offset);return e.offset++,u}function caml_ml_input_int(_){for(var e=caml_ml_channels[_],u=e.file;e.offset+3>=u.length();){var d=caml_ml_refill_input(e);d==0&&caml_raise_end_of_file()}var $=e.offset,w=u.read_one($)<<24|u.read_one($+1)<<16|u.read_one($+2)<<8|u.read_one($+3);return e.offset+=4,w}function caml_std_output(_,e){var u=caml_ml_channels[_],d=caml_string_of_jsbytes(e),$=caml_ml_string_length(d);return u.file.write(u.offset,d,0,$),u.offset+=$,0}function js_print_stderr(e){var e=caml_utf16_of_utf8(e),u=globalThis;if(u.process&&u.process.stdout&&u.process.stdout.write)u.process.stderr.write(e);else{e.charCodeAt(e.length-1)==10&&(e=e.substr(0,e.length-1));var d=u.console;d&&d.error&&d.error(e)}}function js_print_stdout(e){var e=caml_utf16_of_utf8(e),u=globalThis;if(u.process&&u.process.stdout&&u.process.stdout.write)u.process.stdout.write(e);else{e.charCodeAt(e.length-1)==10&&(e=e.substr(0,e.length-1));var d=u.console;d&&d.log&&d.log(e)}}function caml_sys_open_internal(_,e,u,d){caml_global_data.fds===void 0&&(caml_global_data.fds=new Array),d=d||{};var $={};return $.file=u,$.offset=d.append?u.length():0,$.flags=d,$.output=e,caml_global_data.fds[_]=$,(!caml_global_data.fd_last_idx||_>caml_global_data.fd_last_idx)&&(caml_global_data.fd_last_idx=_),_}function caml_sys_open(_,e,u){for(var d={};e;){switch(e[1]){case 0:d.rdonly=1;break;case 1:d.wronly=1;break;case 2:d.append=1;break;case 3:d.create=1;break;case 4:d.truncate=1;break;case 5:d.excl=1;break;case 6:d.binary=1;break;case 7:d.text=1;break;case 8:d.nonblock=1;break}e=e[2]}d.rdonly&&d.wronly&&caml_raise_sys_error(caml_jsbytes_of_string(_)+" : flags Open_rdonly and Open_wronly are not compatible"),d.text&&d.binary&&caml_raise_sys_error(caml_jsbytes_of_string(_)+" : flags Open_text and Open_binary are not compatible");var $=resolve_fs_device(_),w=$.device.open($.rest,d),q=caml_global_data.fd_last_idx?caml_global_data.fd_last_idx:0;return caml_sys_open_internal(q+1,caml_std_output,w,d)}caml_sys_open_internal(0,caml_std_output,new MlFakeFile(caml_create_bytes(0))),caml_sys_open_internal(1,js_print_stdout,new MlFakeFile(caml_create_bytes(0))),caml_sys_open_internal(2,js_print_stderr,new MlFakeFile(caml_create_bytes(0)));function caml_ml_open_descriptor_in(_){var e=caml_global_data.fds[_];e.flags.wronly&&caml_raise_sys_error("fd "+_+" is writeonly");var u=null;if(_==0&&fs_node_supported()){var d=require("fs");u=function(){return caml_string_of_jsstring(d.readFileSync(0,"utf8"))}}var $={file:e.file,offset:e.offset,fd:_,opened:!0,out:!1,refill:u};return caml_ml_channels[$.fd]=$,$.fd}function caml_ml_open_descriptor_out(_){var e=caml_global_data.fds[_];e.flags.rdonly&&caml_raise_sys_error("fd "+_+" is readonly");var u={file:e.file,offset:e.offset,fd:_,opened:!0,out:!0,buffer:""};return caml_ml_channels[u.fd]=u,u.fd}function caml_ml_out_channels_list(){for(var _=0,e=0;e>24&255,e>>16&255,e>>8&255,e&255],d=caml_string_of_array(u);return caml_ml_output(_,d,0,4),0}function caml_ml_pos_in(_){return caml_ml_channels[_].offset}function caml_ml_pos_in_64(_){return caml_int64_of_float(caml_ml_channels[_].offset)}function caml_ml_pos_out(_){return caml_ml_flush(_),caml_ml_channels[_].offset}function caml_ml_pos_out_64(_){return caml_ml_flush(_),caml_int64_of_float(caml_ml_channels[_].offset)}function caml_ml_seek_in(_,e){var u=caml_ml_channels[_];return u.refill!=null&&caml_raise_sys_error("Illegal seek"),u.offset=e,0}function caml_ml_seek_in_64(_,e){var u=caml_ml_channels[_];return u.refill!=null&&caml_raise_sys_error("Illegal seek"),u.offset=caml_int64_to_float(e),0}function caml_ml_seek_out(_,e){return caml_ml_flush(_),caml_ml_channels[_].offset=e,0}function caml_ml_seek_out_64(_,e){return caml_ml_flush(_),caml_ml_channels[_].offset=caml_int64_to_float(e),0}function caml_ml_set_binary_mode(_,e){var u=caml_ml_channels[_],d=caml_global_data.fds[u.fd];return d.flags.text=!e,d.flags.binary=e,0}function caml_ml_set_channel_name(){return 0}function caml_mod(_,e){return e==0&&caml_raise_zero_divide(),_%e}function caml_modf_float(_){if(isFinite(_)){var e=1/_<0;_=Math.abs(_);var u=Math.floor(_),d=_-u;return e&&(u=-u,d=-d),[0,d,u]}return isNaN(_)?[0,NaN,NaN]:[0,1/_,_]}function caml_lex_run_mem(_,e,u,d){for(;;){var $=_.charCodeAt(e);if(e++,$==255)return;var w=_.charCodeAt(e);e++,w==255?u[$+1]=d:u[$+1]=u[w+1]}}function caml_lex_run_tag(_,e,u){for(;;){var d=_.charCodeAt(e);if(e++,d==255)return;var $=_.charCodeAt(e);e++,$==255?u[d+1]=-1:u[d+1]=u[$+1]}}function caml_new_lex_engine(_,e,u){var d=2,$=3,w=5,q=6,z=7,P=8,V=9,N=10,L=1,U=2,Y=3,W=4,K=5,R=6,J=7,Q=8,X=9,Z=10,I=11;_.lex_default||(_.lex_base=caml_lex_array(_[L]),_.lex_backtrk=caml_lex_array(_[U]),_.lex_check=caml_lex_array(_[K]),_.lex_trans=caml_lex_array(_[W]),_.lex_default=caml_lex_array(_[Y])),_.lex_default_code||(_.lex_base_code=caml_lex_array(_[R]),_.lex_backtrk_code=caml_lex_array(_[J]),_.lex_check_code=caml_lex_array(_[Z]),_.lex_trans_code=caml_lex_array(_[X]),_.lex_default_code=caml_lex_array(_[Q])),_.lex_code==null&&(_.lex_code=caml_jsbytes_of_string(_[I]));var __,t_=e,e_=caml_array_of_bytes(u[d]);for(t_>=0?(u[z]=u[w]=u[q],u[P]=-1):t_=-t_-1;;){var a_=_.lex_base[t_];if(a_<0){var r_=_.lex_base_code[t_];return caml_lex_run_tag(_.lex_code,r_,u[N]),-a_-1}var n_=_.lex_backtrk[t_];if(n_>=0){var r_=_.lex_backtrk_code[t_];caml_lex_run_tag(_.lex_code,r_,u[N]),u[z]=u[q],u[P]=n_}if(u[q]>=u[$]){if(u[V]==0)return-t_-1;__=256}else __=e_[u[q]],u[q]++;var c_=t_;if(_.lex_check[a_+__]==t_?t_=_.lex_trans[a_+__]:t_=_.lex_default[t_],t_<0)if(u[q]=u[z],u[P]==-1)caml_failwith("lexing: empty token");else return u[P];else{var l_=_.lex_base_code[c_],r_;_.lex_check_code[l_+__]==c_?r_=_.lex_trans_code[l_+__]:r_=_.lex_default_code[c_],r_>0&&caml_lex_run_mem(_.lex_code,r_,u[N],u[q]),__==256&&(u[V]=0)}}}function caml_notequal(_,e){return+(caml_compare_val(_,e,!1)!=0)}function caml_obj_block(_,e){var u=new Array(e+1);u[0]=_;for(var d=1;d<=e;d++)u[d]=0;return u}function caml_obj_make_forward(_,e){return _[0]=250,_[1]=e,0}function caml_obj_tag(_){return _ instanceof Array&&_[0]==_[0]>>>0?_[0]:caml_is_ml_bytes(_)||caml_is_ml_string(_)?252:_ instanceof Function||typeof _=="function"?247:_&&_.caml_custom?255:1e3}function caml_out_channel_pos_fd(_){var e=caml_ml_channels[_];return e.offset}var MlObjectTable;typeof globalThis.WeakMap>"u"?MlObjectTable=function(){function _(e){this.objs=e}return _.prototype.get=function(e){for(var u=0;u=0;d-=8)this.chunk[this.chunk_idx++]=u>>d&255},write_at:function($,u,d){for(var $=$,w=u-8;w>=0;w-=8)this.chunk[$++]=d>>w&255},write_code:function(e,u,d){this.chunk[this.chunk_idx++]=u;for(var $=e-8;$>=0;$-=8)this.chunk[this.chunk_idx++]=d>>$&255},write_shared:function(e){e<1<<8?this.write_code(8,4,e):e<1<<16?this.write_code(16,5,e):this.write_code(32,6,e)},pos:function(){return this.chunk_idx},finalize:function(){return this.block_len=this.chunk_idx-20,this.chunk_idx=0,this.write(32,2224400062),this.write(32,this.block_len),this.write(32,this.obj_counter),this.write(32,this.size_32),this.write(32,this.size_64),this.chunk}},function(e,u){u=caml_list_to_js_array(u);var d=u.indexOf(0)!==-1,$=u.indexOf(1)!==-1;$&&globalThis.console.warn("in caml_output_val: flag Marshal.Closures is not supported.");var w=new _,q=[],z=d?null:new MlObjectTable;function P(L){if(d)return!1;var U=z.recall(L);return U?(w.write_shared(U),!0):(z.store(L),!1)}function V(L){if(L.caml_custom){if(P(L))return;var U=L.caml_custom,Y=caml_custom_ops[U],W=[0,0];if(Y.serialize||caml_invalid_argument("output_value: abstract value (Custom)"),caml_legacy_custom_code){w.write(8,18);for(var K=0;K>2),w.size_64+=2+(W[1]+7>>3)}else if(L instanceof Array&&L[0]===(L[0]|0)){if(L[0]==251&&caml_failwith("output_value: abstract value (Abstract)"),L.length>1&&P(L))return;L[0]<16&&L.length-1<8?w.write(8,128+L[0]+(L.length-1<<4)):w.write_code(32,8,L.length-1<<10|L[0]),w.size_32+=L.length,w.size_64+=L.length,L.length>1&&q.push(L,1)}else if(caml_is_ml_bytes(L)){if(caml_is_ml_bytes(caml_string_of_jsbytes(""))||caml_failwith("output_value: [Bytes.t] cannot safely be marshaled with [--enable use-js-string]"),P(L))return;var Q=caml_ml_bytes_length(L);Q<32?w.write(8,32+Q):Q<256?w.write_code(8,9,Q):w.write_code(32,10,Q);for(var K=0;K=0&&L<64?w.write(8,64+L):L>=-(1<<7)&&L<1<<7?w.write_code(8,0,L):L>=-(1<<15)&&L<1<<15?w.write_code(16,1,L):w.write_code(32,2,L)}for(V(e);q.length>0;){var N=q.pop(),e=q.pop();N+1u&&caml_failwith("Marshal.to_buffer: buffer overflow"),caml_blit_bytes(w,0,_,e,w.length),0}function caml_pallas_add(_,e){var u=plonk_wasm.caml_pallas_add(_,e);return free_on_finalize(u),u}function caml_pallas_double(_){var e=plonk_wasm.caml_pallas_double(_);return free_on_finalize(e),e}var caml_pallas_endo_base=plonk_wasm.caml_pallas_endo_base,caml_pallas_endo_scalar=plonk_wasm.caml_pallas_endo_scalar;function caml_pallas_negate(_){var e=plonk_wasm.caml_pallas_negate(_);return free_on_finalize(e),e}function caml_pallas_of_affine_coordinates(_,e){var u=plonk_wasm.caml_pallas_of_affine_coordinates(_,e);return free_on_finalize(u),u}function caml_pallas_one(){var _=plonk_wasm.caml_pallas_one();return free_on_finalize(_),_}function caml_pallas_random(){var _=plonk_wasm.caml_pallas_random();return free_on_finalize(_),_}function caml_pallas_scale(_,e){var u=plonk_wasm.caml_pallas_scale(_,e);return free_on_finalize(u),u}function caml_pallas_sub(_,e){var u=plonk_wasm.caml_pallas_sub(_,e);return free_on_finalize(u),u}function caml_pallas_to_affine(_){var e=plonk_wasm.caml_pallas_to_affine(_);return rust_affine_to_caml_affine(e)}var caml_pasta_fp_add=plonk_wasm.caml_pasta_fp_add;function caml_pasta_fp_copy(_,e){for(var u=0,d=_.length;u>>0>=caml_ml_string_length(_)&&caml_string_bound_error(),caml_string_unsafe_get(_,e)}function caml_string_get16(_,e){e>>>0>=caml_ml_string_length(_)-1&&caml_string_bound_error();var u=caml_string_unsafe_get(_,e),d=caml_string_unsafe_get(_,e+1);return d<<8|u}function caml_string_get32(_,e){e>>>0>=caml_ml_string_length(_)-3&&caml_string_bound_error();var u=caml_string_unsafe_get(_,e),d=caml_string_unsafe_get(_,e+1),$=caml_string_unsafe_get(_,e+2),w=caml_string_unsafe_get(_,e+3);return w<<24|$<<16|d<<8|u}function caml_string_get64(_,e){e>>>0>=caml_ml_string_length(_)-7&&caml_string_bound_error();for(var u=new Array(8),d=0;d<8;d++)u[7-d]=caml_string_unsafe_get(_,e+d);return caml_int64_of_bytes(u)}function caml_string_lessequal(_,e){return caml_bytes_lessequal(_,e)}function caml_string_greaterequal(_,e){return caml_string_lessequal(e,_)}function caml_string_lessthan(_,e){return caml_bytes_lessthan(_,e)}function caml_string_greaterthan(_,e){return caml_string_lessthan(e,_)}function caml_string_notequal(_,e){return 1-caml_string_equal(_,e)}var caml_argv=function(){var _=globalThis,e="a.out",u=[];if(_.process&&_.process.argv&&_.process.argv.length>1){var d=_.process.argv;e=d[1],u=d.slice(2)}for(var $=caml_string_of_jsstring(e),w=[0,$],q=0;q=0;d--)if(_.data[e+d]!=0)return d+1;return 1}function compare_nat(_,e,u,d,$,w){var q=num_digits_nat(_,e,u),z=num_digits_nat(d,$,w);if(q>z)return 1;if(q=0;P--){if(_.data[e+P]>>>0>d.data[$+P]>>>0)return 1;if(_.data[e+P]>>>0>>0)return-1}return 0}var core_array_unsafe_float_blit=caml_array_blit,core_array_unsafe_int_blit=caml_array_blit;function core_kernel_gc_minor_words(){return 0}function core_kernel_time_ns_format(_,e){var u=new Date(_*1e3),d=caml_jsbytes_of_string(e),$=joo_global_object.strftime(d,u);return caml_string_of_jsbytes($)}function caml_md5_chan(_,e){var u=caml_ml_channels[_],d=u.file.length();e<0&&(e=d-u.offset),u.offset+e>d&&caml_raise_end_of_file();var $=caml_create_bytes(e);return u.file.read(u.offset,$,0,e),caml_md5_string($,0,e)}function core_md5_fd(_){var e=caml_ml_open_descriptor_in(_);try{return caml_md5_chan(e,-1)}finally{caml_ml_close_channel(e)}}function MlNat(_){this.data=new globalThis.Int32Array(_),this.length=this.data.length+2}MlNat.prototype.caml_custom="_nat";function create_nat(_){for(var e=new MlNat(_),u=0;u<_;u++)e.data[u]=-1;return e}function custom_reraise_exn(_,e){var u=_[2];throw u instanceof globalThis.Error?u:Error(e)}function decr_nat(_,e,u,d){for(var $=d==1?0:1,w=0;w>>0)-$;if(_.data[e+w]=q,q>=0){$=0;break}else $=1}return $==1?0:1}function deferred_bind(_,e){var u={promise:_.promise.then(e).then(function(d){return d.promise}).then(function(d){return u.value=d,u.isDetermined=!0,d}).catch(function(d){throw u.error=d,u.isError=!0,u.isDetermined=!0,d}),isError:!1,isDetermined:!1};return u}function deferred_map(_,e){var u={promise:_.promise.then(e).then(function(d){return u.value=d,u.isDetermined=!0,d}).catch(function(d){throw u.error=d,u.isError=!0,u.isDetermined=!0,d}),isError:!1,isDetermined:!1};return u}function deferred_return(_){return{promise:Promise.resolve(_),value:_,isError:!1,isDetermined:!0}}function deferred_run(_){var e={promise:Promise.resolve().then(_).then(function(u){return e.value=u,e.isDetermined=!0,u}).catch(function(u){throw e.error=u,e.isError=!0,e.isDetermined=!0,u}),isError:!1,isDetermined:!1};return e}function deferred_to_promise(_){return _.promise}function deferred_upon_exn(_,e){_.promise.then(function(){e(_.value)})}function div_helper(_,e,u){var d=_*65536+(e>>>16),$=Math.floor(d/u)*65536,w=d%u*65536,q=w+(e&65535);return[$+Math.floor(q/u),q%u]}function div_digit_nat(_,e,u,d,$,w,q,z,P){for(var V=$.data[w+q-1]>>>0,N=q-2;N>=0;N--){var L=div_helper(V,$.data[w+N]>>>0,z.data[P]>>>0);_.data[e+N]=L[0],V=L[1]}return u.data[d]=V,0}function num_leading_zero_bits_in_digit(_,e){var u=_.data[e],d=0;return u&4294901760&&(d+=16,u>>>=16),u&65280&&(d+=8,u>>>=8),u&240&&(d+=4,u>>>=4),u&12&&(d+=2,u>>>=2),u&2&&(d+=1,u>>>=1),u&1&&(d+=1),32-d}function shift_left_nat(_,e,u,d,$,w){if(w==0)return d.data[$]=0,0;for(var q=0,z=0;z>>0;_.data[e+z]=P<>>32-w}return d.data[$]=q,0}function shift_right_nat(_,e,u,d,$,w){if(w==0)return d.data[$]=0,0;for(var q=0,z=u-1;z>=0;z--){var P=_.data[e+z]>>>0;_.data[e+z]=P>>>w|q,q=P<<32-w}return d.data[$]=q,0}function set_to_zero_nat(_,e,u){for(var d=0;d>>0,N=0;N>>0)+(d.data[$+N]>>>0)*(V&65535)+P,U=(d.data[$+N]>>>0)*(V>>>16);P=Math.floor(U/65536);var Y=L+U%65536*65536;_.data[e+N]=Y,P+=Math.floor(Y/4294967296)}return w>>0)-(d.data[$+P]>>>0)-z;_.data[e+P]=V,V>=0?z=0:z=1}return decr_nat(_,e+w,u-w,z==1?0:1)}function div_nat(_,e,u,d,$,w){if(w==1)return div_digit_nat(_,e+1,_,e,_,e,u,d,$),0;var q=num_leading_zero_bits_in_digit(d,$+w-1);shift_left_nat(d,$,w,nat_of_array([0]),0,q),shift_left_nat(_,e,u,nat_of_array([0]),0,q);for(var z=(d.data[$+w-1]>>>0)+1,P=create_nat(w+1),V=u-1;V>=w;V--){var N=z==4294967296?_.data[e+V]>>>0:div_helper(_.data[e+V]>>>0,_.data[e+V-1]>>>0,z)[0];for(set_to_zero_nat(P,0,w+1),mult_digit_nat(P,0,w+1,d,$,w,nat_of_array([N]),0),sub_nat(_,e+V-w,w+1,P,0,w+1,1);_.data[e+V]!=0||compare_nat(_,e+V-w,w,d,$,w)>=0;)N=N+1,sub_nat(_,e+V-w,w+1,d,$,w,1);_.data[e+V]=N}return shift_right_nat(_,e,w,nat_of_array([0]),0,q),shift_right_nat(d,$,w,nat_of_array([0]),0,q),0}var expect_test_collector_saved_stderr,expect_test_collector_saved_stdout;function expect_test_collector_after_test(_,e){return caml_ml_channels[_]=expect_test_collector_saved_stdout,caml_ml_channels[e]=expect_test_collector_saved_stderr,0}function expect_test_collector_before_test(_,e,u){expect_test_collector_saved_stderr=caml_ml_channels[u],expect_test_collector_saved_stdout=caml_ml_channels[e];var d=caml_ml_channels[_];return caml_ml_channels[e]=d,caml_ml_channels[u]=d,0}function caml_random_oracles_of_rust(_){var e=_.joint_combiner_chal,u=_.joint_combiner,d=void 0;return e!==void 0&&u!==void 0&&(d=[0,[0,e],u]),[0,caml_option_of_maybe_undefined(d),_.beta,_.gamma,[0,_.alpha_chal],_.alpha,_.zeta,_.v,_.u,[0,_.zeta_chal],[0,_.v_chal],[0,_.u_chal]]}function caml_oracles_of_rust(_){return[0,caml_random_oracles_of_rust(_.o),[0,_.p_eval0,_.p_eval1],caml_u8array_vector_of_rust_flat_vector(_.opening_prechallenges,32),_.digest_before_evaluations]}function fp_oracles_create(_,e,u){return caml_oracles_of_rust(plonk_wasm.fp_oracles_create(caml_array_to_rust_vector(_,caml_vesta_poly_comm_to_rust),caml_pasta_fp_plonk_verifier_index_to_rust(e),caml_pasta_fp_proof_to_rust(u)))}function fp_oracles_create_no_public(_,e,u){return fp_oracles_create(_,e,[0,0,u])}function fq_oracles_create(_,e,u){return caml_oracles_of_rust(plonk_wasm.fq_oracles_create(caml_array_to_rust_vector(_,caml_pallas_poly_comm_to_rust),caml_pasta_fq_plonk_verifier_index_to_rust(e),caml_pasta_fq_proof_to_rust(u)))}function fq_oracles_create_no_public(_,e,u){return fq_oracles_create(_,e,[0,0,u])}var tsBindings=globalThis.__snarkyTsBindings;function getTsBindings(){return tsBindings}function serialize_nat(_,e,u){var d=e.data.length;_.write(32,d);for(var $=0;$=d&&caml_failwith("int_of_string");var w=caml_string_unsafe_get(_,u);w===45?(u++,$=!0):w===43&&u++;var q=!0;e.hi=e.hi>>>0;for(var z=caml_int64_of_int32(10),P=e.udivmod(z).quotient,V=caml_int64_of_int32(0);u=10)break;if(q=!1,caml_int64_ult(P,V)||(N=caml_int64_of_int32(N),V=caml_int64_add(caml_int64_mul(z,V),N),caml_int64_ult(V,N)))return e}return q&&caml_failwith("int_of_string"),$&&(V=caml_int64_neg(V)),V.hi=V.hi>>>0,V}var UInt32=function(){function _(e){this.value=e>>>0}return _.prototype.caml_custom="integers:uint32",_}();function integers_uint32_of_int64(_){return new UInt32(caml_int64_to_int32(_))}function integers_uint32_of_string(_){var e=caml_int64_create_lo_mi_hi(16777215,16777215,65535);return integers_uint32_of_int64(integers_uint_of_string(_,e))}function integers_uint16_of_string(_){var e=integers_uint32_of_string(_);return e.value&65535}function integers_uint32_add(_,e){return new UInt32(_.value+e.value)}function integers_uint32_div(_,e){return new UInt32(_.value/e.value)}function integers_uint32_logand(_,e){return new UInt32(_.value&e.value)}function integers_uint32_logor(_,e){return new UInt32(_.value|e.value)}function integers_uint32_logxor(_,e){return new UInt32(_.value^e.value)}function integers_uint32_max(_){return new UInt32(4294967295)}function integers_uint32_to_int64(_){return caml_int64_create_lo_mi_hi(_.value&16777215,_.value>>>24&16777215,0)}function integers_uint32_mul(_,e){var u=integers_uint32_to_int64(_),d=integers_uint32_to_int64(e);return new UInt32(caml_int64_to_int32(caml_int64_mul(u,d)))}function integers_uint32_of_int(_){return new UInt32(_)}function integers_uint32_of_int32(_){return new UInt32(_)}function integers_uint32_rem(_,e){return e.value==0&&caml_raise_zero_divide(),new UInt32(_.value%e.value)}function integers_uint32_shift_left(_,e){return new UInt32(_.value<>>e)}function integers_uint32_sub(_,e){return new UInt32(_.value-e.value)}function integers_uint32_to_int(_){return _.value|0}function caml_new_string(_){return caml_string_of_jsbytes(_)}function integers_uint32_to_string(_){return caml_new_string(_.value.toString())}var UInt64=function(){function _(e){this.value=e}return _.prototype.caml_custom="integers:uint64",_}();function integers_uint64_add(_,e){return new UInt64(caml_int64_add(_.value,e.value))}function integers_uint64_div(_,e){return e.value.isZero()&&caml_raise_zero_divide(),_.value.hi=_.value.hi>>>0,e.value.hi=e.value.hi>>>0,new UInt64(_.value.udivmod(e.value).quotient)}function integers_uint64_logand(_,e){return new UInt64(caml_int64_and(_.value,e.value))}function integers_uint64_logor(_,e){return new UInt64(caml_int64_or(_.value,e.value))}function integers_uint64_logxor(_,e){return new UInt64(caml_int64_xor(_.value,e.value))}function integers_uint64_max(_){var e=caml_int64_create_lo_mi_hi(16777215,16777215,65535);return e.hi=e.hi>>>0,new UInt64(e)}function integers_uint64_mul(_,e){return new UInt64(caml_int64_mul(_.value,e.value))}function integers_uint64_of_int(_){return new UInt64(caml_int64_of_int32(_))}function integers_uint64_of_int64(_){return new UInt64(caml_int64_create_lo_mi_hi(_.lo,_.mi,_.hi>>>0))}function integers_uint64_of_string(_){var e=caml_int64_create_lo_mi_hi(16777215,16777215,65535);return new UInt64(integers_uint_of_string(_,e))}function integers_uint64_of_uint32(_){return new UInt64(caml_int64_of_int32(_))}function integers_uint64_rem(_,e){return e.value.isZero()&&caml_raise_zero_divide(),_.value.hi=_.value.hi>>>0,e.value.hi=e.value.hi>>>0,new UInt64(_.value.udivmod(e.value).modulus)}function integers_uint64_shift_left(_,e){return new UInt64(caml_int64_shift_left(_.value,e))}function integers_uint64_shift_right(_,e){return new UInt64(caml_int64_shift_right_unsigned(_.value,e))}function integers_uint64_sub(_,e){return new UInt64(caml_int64_sub(_.value,e.value))}function integers_uint64_to_int(_){return caml_int64_to_int32(_.value)}function integers_uint64_to_int64(_){return _=_.value,caml_int64_create_lo_mi_hi(_.lo,_.mi,_.hi|0)}function integers_uint64_to_string(_){return caml_int64_format(caml_new_string("%u"),_.value)}function integers_uint8_of_string(_){var e=integers_uint32_of_string(_);return _.value&255}function integers_uint_size(_){return 4}function integers_ulong_size(_){return 4}function integers_ulonglong_size(_){return 8}function integers_uint8_deserialize(_,e){return e[0]=1,_.read8u()}function integers_uint16_deserialize(_,e){return e[0]=2,_.read16u()}function integers_uint32_serialize(_,e,u){_.write(32,e.value),u[0]=4,u[1]=4}function integers_uint32_deserialize(_,e){return e[0]=4,new UInt32(_.read32u())}function integers_uint32_hash(_){return _.value}function integers_uint32_compare(_,e){return _.value>e.value?1:_.value>>0,e.value.hi=e.value.hi>>>0,_.value.ucompare(e.value)}function integers_uint64_hash(_){return caml_int64_hash(_.value)}function integers_uint64_marshal(_,e,u){caml_int64_marshal(_,e.value,u)}function integers_uint64_unmarshal(_,e){return new UInt64(caml_int64_unmarshal(_,e))}function integers_unsigned_init(_){return caml_custom_ops["integers:uint8"]={deserialize:integers_uint8_deserialize,fixed_length:1},caml_custom_ops["integers:uint16"]={deserialize:integers_uint16_deserialize,fixed_length:2},caml_custom_ops["integers:uint32"]={serialize:integers_uint32_serialize,deserialize:integers_uint32_deserialize,fixed_length:4,hash:integers_uint32_hash,compare:integers_uint32_compare},caml_custom_ops["integers:uint64"]={serialize:integers_uint64_marshal,deserialize:integers_uint64_unmarshal,hash:integers_uint64_hash,compare:integers_uint64_compare},_}function integers_ushort_size(_){return 4}function is_digit_int(_,e){return _.data[e]>=0?1:0}function is_digit_zero(_,e){return _.data[e]==0?1:0}function land_digit_nat(_,e,u,d){return _.data[e]&=u.data[d],0}function lor_digit_nat(_,e,u,d){return _.data[e]|=u.data[d],0}var bigInt=function(_){"use strict";var e=1e7,u=7,d=9007199254740992,$=Y(d),w="0123456789abcdefghijklmnopqrstuvwxyz",q=joo_global_object.BigInt,z=typeof q=="function";function P(k_,z_,v_,U_){return typeof k_>"u"?P[0]:typeof z_<"u"?+z_==10&&!v_?B_(k_):W_(k_,z_,v_,U_):B_(k_)}function V(k_,z_){this.value=k_,this.sign=z_,this.isSmall=!1,this.caml_custom="_z"}V.prototype=Object.create(P.prototype);function N(k_){this.value=k_,this.sign=k_<0,this.isSmall=!0,this.caml_custom="_z"}N.prototype=Object.create(P.prototype);function L(k_){this.value=k_,this.caml_custom="_z"}L.prototype=Object.create(P.prototype);function U(k_){return-d0?Math.floor(k_):Math.ceil(k_)}function Q(k_,z_){var v_=k_.length,U_=z_.length,R_=new Array(v_),K_=0,Q_=e,Y_,Z_;for(Z_=0;Z_=Q_?1:0,R_[Z_]=Y_-K_*Q_;for(;Z_0&&R_.push(K_),R_}function X(k_,z_){return k_.length>=z_.length?Q(k_,z_):Q(z_,k_)}function Z(k_,z_){var v_=k_.length,U_=new Array(v_),R_=e,K_,Q_;for(Q_=0;Q_0;)U_[Q_++]=z_%R_,z_=Math.floor(z_/R_);return U_}V.prototype.add=function(k_){var z_=B_(k_);if(this.sign!==z_.sign)return this.subtract(z_.negate());var v_=this.value,U_=z_.value;return z_.isSmall?new V(Z(v_,Math.abs(U_)),this.sign):new V(X(v_,U_),this.sign)},V.prototype.plus=V.prototype.add,N.prototype.add=function(k_){var z_=B_(k_),v_=this.value;if(v_<0!==z_.sign)return this.subtract(z_.negate());var U_=z_.value;if(z_.isSmall){if(U(v_+U_))return new N(v_+U_);U_=Y(Math.abs(U_))}return new V(Z(U_,Math.abs(v_)),v_<0)},N.prototype.plus=N.prototype.add,L.prototype.add=function(k_){return new L(this.value+B_(k_).value)},L.prototype.plus=L.prototype.add;function I(k_,z_){var v_=k_.length,U_=z_.length,R_=new Array(v_),K_=0,Q_=e,Y_,Z_;for(Y_=0;Y_=0?U_=I(k_,z_):(U_=I(z_,k_),v_=!v_),U_=W(U_),typeof U_=="number"?(v_&&(U_=-U_),new N(U_)):new V(U_,v_)}function t_(k_,z_,v_){var U_=k_.length,R_=new Array(U_),K_=-z_,Q_=e,Y_,Z_;for(Y_=0;Y_=0)},N.prototype.minus=N.prototype.subtract,L.prototype.subtract=function(k_){return new L(this.value-B_(k_).value)},L.prototype.minus=L.prototype.subtract,V.prototype.negate=function(){return new V(this.value,!this.sign)},N.prototype.negate=function(){var k_=this.sign,z_=new N(-this.value);return z_.sign=!k_,z_},L.prototype.negate=function(){return new L(-this.value)},V.prototype.abs=function(){return new V(this.value,!1)},N.prototype.abs=function(){return new N(Math.abs(this.value))},L.prototype.abs=function(){return new L(this.value>=0?this.value:-this.value)};function e_(k_,z_){var v_=k_.length,U_=z_.length,R_=v_+U_,K_=R(R_),Q_=e,Y_,Z_,_0,a0,I_;for(_0=0;_00;)U_[Y_++]=K_%R_,K_=Math.floor(K_/R_);return U_}function r_(k_,z_){for(var v_=[];z_-- >0;)v_.push(0);return v_.concat(k_)}function n_(k_,z_){var v_=Math.max(k_.length,z_.length);if(v_<=30)return e_(k_,z_);v_=Math.ceil(v_/2);var U_=k_.slice(v_),R_=k_.slice(0,v_),K_=z_.slice(v_),Q_=z_.slice(0,v_),Y_=n_(R_,Q_),Z_=n_(U_,K_),_0=n_(X(R_,U_),X(Q_,K_)),a0=X(X(Y_,r_(I(I(_0,Y_),Z_),v_)),r_(Z_,2*v_));return K(a0),a0}function c_(k_,z_){return-(.012*k_)-.012*z_+15e-6*k_*z_>0}V.prototype.multiply=function(k_){var z_=B_(k_),v_=this.value,U_=z_.value,R_=this.sign!==z_.sign,K_;if(z_.isSmall){if(U_===0)return P[0];if(U_===1)return this;if(U_===-1)return this.negate();if(K_=Math.abs(U_),K_=0;I_--){for(a0=R_-1,Z_[I_+U_]!==Q_&&(a0=Math.floor((Z_[I_+U_]*R_+Z_[I_+U_-1])/Q_)),X_=0,c0=0,d0=_0.length,l0=0;l0U_&&(_0=(_0+1)*Q_),Y_=Math.ceil(_0/a0);do{if(I_=a_(z_,Y_),b_(I_,K_)<=0)break;Y_--}while(Y_);R_.push(Y_),K_=I(K_,I_)}return R_.reverse(),[W(R_),W(K_)]}function u_(k_,z_){var v_=k_.length,U_=R(v_),R_=e,K_,Q_,Y_,Z_;for(Y_=0,K_=v_-1;K_>=0;--K_)Z_=Y_*R_+k_[K_],Q_=J(Z_/z_),Y_=Z_-Q_*z_,U_[K_]=Q_|0;return[U_,Y_|0]}function x_(k_,z_){var v_,U_=B_(z_);if(z)return[new L(k_.value/U_.value),new L(k_.value%U_.value)];var R_=k_.value,K_=U_.value,Q_;if(K_===0)throw new Error("Cannot divide by zero");if(k_.isSmall)return U_.isSmall?[new N(J(R_/K_)),new N(R_%K_)]:[P[0],k_];if(U_.isSmall){if(K_===1)return[k_,P[0]];if(K_==-1)return[k_.negate(),P[0]];var Y_=Math.abs(K_);if(Y_z_.length?1:-1;for(var v_=k_.length-1;v_>=0;v_--)if(k_[v_]!==z_[v_])return k_[v_]>z_[v_]?1:-1;return 0}V.prototype.compareAbs=function(k_){var z_=B_(k_),v_=this.value,U_=z_.value;return z_.isSmall?1:b_(v_,U_)},N.prototype.compareAbs=function(k_){var z_=B_(k_),v_=Math.abs(this.value),U_=z_.value;return z_.isSmall?(U_=Math.abs(U_),v_===U_?0:v_>U_?1:-1):-1},L.prototype.compareAbs=function(k_){var z_=this.value,v_=B_(k_).value;return z_=z_>=0?z_:-z_,v_=v_>=0?v_:-v_,z_===v_?0:z_>v_?1:-1},V.prototype.compare=function(k_){if(k_===1/0)return-1;if(k_===-1/0)return 1;var z_=B_(k_),v_=this.value,U_=z_.value;return this.sign!==z_.sign?z_.sign?1:-1:z_.isSmall?this.sign?-1:1:b_(v_,U_)*(this.sign?-1:1)},V.prototype.compareTo=V.prototype.compare,N.prototype.compare=function(k_){if(k_===1/0)return-1;if(k_===-1/0)return 1;var z_=B_(k_),v_=this.value,U_=z_.value;return z_.isSmall?v_==U_?0:v_>U_?1:-1:v_<0!==z_.sign?v_<0?-1:1:v_<0?1:-1},N.prototype.compareTo=N.prototype.compare,L.prototype.compare=function(k_){if(k_===1/0)return-1;if(k_===-1/0)return 1;var z_=this.value,v_=B_(k_).value;return z_===v_?0:z_>v_?1:-1},L.prototype.compareTo=L.prototype.compare,V.prototype.equals=function(k_){return this.compare(k_)===0},L.prototype.eq=L.prototype.equals=N.prototype.eq=N.prototype.equals=V.prototype.eq=V.prototype.equals,V.prototype.notEquals=function(k_){return this.compare(k_)!==0},L.prototype.neq=L.prototype.notEquals=N.prototype.neq=N.prototype.notEquals=V.prototype.neq=V.prototype.notEquals,V.prototype.greater=function(k_){return this.compare(k_)>0},L.prototype.gt=L.prototype.greater=N.prototype.gt=N.prototype.greater=V.prototype.gt=V.prototype.greater,V.prototype.lesser=function(k_){return this.compare(k_)<0},L.prototype.lt=L.prototype.lesser=N.prototype.lt=N.prototype.lesser=V.prototype.lt=V.prototype.lesser,V.prototype.greaterOrEquals=function(k_){return this.compare(k_)>=0},L.prototype.geq=L.prototype.greaterOrEquals=N.prototype.geq=N.prototype.greaterOrEquals=V.prototype.geq=V.prototype.greaterOrEquals,V.prototype.lesserOrEquals=function(k_){return this.compare(k_)<=0},L.prototype.leq=L.prototype.lesserOrEquals=N.prototype.leq=N.prototype.lesserOrEquals=V.prototype.leq=V.prototype.lesserOrEquals,V.prototype.isEven=function(){return(this.value[0]&1)===0},N.prototype.isEven=function(){return(this.value&1)===0},L.prototype.isEven=function(){return(this.value&q(1))===q(0)},V.prototype.isOdd=function(){return(this.value[0]&1)===1},N.prototype.isOdd=function(){return(this.value&1)===1},L.prototype.isOdd=function(){return(this.value&q(1))===q(1)},V.prototype.isPositive=function(){return!this.sign},N.prototype.isPositive=function(){return this.value>0},L.prototype.isPositive=N.prototype.isPositive,V.prototype.isNegative=function(){return this.sign},N.prototype.isNegative=function(){return this.value<0},L.prototype.isNegative=N.prototype.isNegative,V.prototype.isUnit=function(){return!1},N.prototype.isUnit=function(){return Math.abs(this.value)===1},L.prototype.isUnit=function(){return this.abs().value===q(1)},V.prototype.isZero=function(){return!1},N.prototype.isZero=function(){return this.value===0},L.prototype.isZero=function(){return this.value===q(0)},V.prototype.isDivisibleBy=function(k_){var z_=B_(k_);return z_.isZero()?!1:z_.isUnit()?!0:z_.compareAbs(2)===0?this.isEven():this.mod(z_).isZero()},L.prototype.isDivisibleBy=N.prototype.isDivisibleBy=V.prototype.isDivisibleBy;function y_(k_){var z_=k_.abs();if(z_.isUnit())return!1;if(z_.equals(2)||z_.equals(3)||z_.equals(5))return!0;if(z_.isEven()||z_.isDivisibleBy(3)||z_.isDivisibleBy(5))return!1;if(z_.lesser(49))return!0}function d_(k_,z_){for(var v_=k_.prev(),U_=v_,R_=0,K_,Q_,Y_,Z_;U_.isEven();)U_=U_.divide(2),R_++;_:for(Y_=0;Y_-d?new N(k_-1):new V($,!0)},L.prototype.prev=function(){return new L(this.value-q(1))};for(var p_=[1];2*p_[p_.length-1]<=e;)p_.push(2*p_[p_.length-1]);var $_=p_.length,w_=p_[$_-1];function j_(k_){return Math.abs(k_)<=e}V.prototype.shiftLeft=function(k_){var z_=B_(k_).toJSNumber();if(!j_(z_))throw new Error(String(z_)+" is too large for shifting.");if(z_<0)return this.shiftRight(-z_);var v_=this;if(v_.isZero())return v_;for(;z_>=$_;)v_=v_.multiply(w_),z_-=$_-1;return v_.multiply(p_[z_])},L.prototype.shiftLeft=N.prototype.shiftLeft=V.prototype.shiftLeft,V.prototype.shiftRight=function(k_){var z_,v_=B_(k_).toJSNumber();if(!j_(v_))throw new Error(String(v_)+" is too large for shifting.");if(v_<0)return this.shiftLeft(-v_);for(var U_=this;v_>=$_;){if(U_.isZero()||U_.isNegative()&&U_.isUnit())return U_;z_=x_(U_,w_),U_=z_[1].isNegative()?z_[0].prev():z_[0],v_-=$_-1}return z_=x_(U_,p_[v_]),z_[1].isNegative()?z_[0].prev():z_[0]},L.prototype.shiftRight=N.prototype.shiftRight=V.prototype.shiftRight;function M_(k_,z_,v_){z_=B_(z_);for(var U_=k_.isNegative(),R_=z_.isNegative(),K_=U_?k_.not():k_,Q_=R_?z_.not():z_,Y_=0,Z_=0,_0=null,a0=null,I_=[];!K_.isZero()||!Q_.isZero();)_0=x_(K_,w_),Y_=_0[1].toJSNumber(),U_&&(Y_=w_-1-Y_),a0=x_(Q_,w_),Z_=a0[1].toJSNumber(),R_&&(Z_=w_-1-Z_),K_=_0[0],Q_=a0[0],I_.push(v_(Y_,Z_));for(var X_=v_(U_?1:0,R_?1:0)!==0?bigInt(-1):bigInt(0),c0=I_.length-1;c0>=0;c0-=1)X_=X_.multiply(w_).add(bigInt(I_[c0]));return X_}V.prototype.not=function(){return this.negate().prev()},L.prototype.not=N.prototype.not=V.prototype.not,V.prototype.and=function(k_){return M_(this,k_,function(z_,v_){return z_&v_})},L.prototype.and=N.prototype.and=V.prototype.and,V.prototype.or=function(k_){return M_(this,k_,function(z_,v_){return z_|v_})},L.prototype.or=N.prototype.or=V.prototype.or,V.prototype.xor=function(k_){return M_(this,k_,function(z_,v_){return z_^v_})},L.prototype.xor=N.prototype.xor=V.prototype.xor;var D_=1<<30,A_=(e&-e)*(e&-e)|D_;function O_(k_){var z_=k_.value,v_=typeof z_=="number"?z_|D_:typeof z_=="bigint"?z_|q(D_):z_[0]+z_[1]*e|A_;return v_&-v_}function E_(k_,z_){if(z_.compareTo(k_)<=0){var v_=E_(k_,z_.square(z_)),U_=v_.p,R_=v_.e,K_=U_.multiply(z_);return K_.compareTo(k_)<=0?{p:K_,e:R_*2+1}:{p:U_,e:R_*2}}return{p:bigInt(1),e:0}}V.prototype.bitLength=function(){var k_=this;return k_.compareTo(bigInt(0))<0&&(k_=k_.negate().subtract(bigInt(1))),k_.compareTo(bigInt(0))===0?bigInt(0):bigInt(E_(k_,bigInt(2)).e).add(bigInt(1))},L.prototype.bitLength=N.prototype.bitLength=V.prototype.bitLength;function L_(k_,z_){return k_=B_(k_),z_=B_(z_),k_.greater(z_)?k_:z_}function V_(k_,z_){return k_=B_(k_),z_=B_(z_),k_.lesser(z_)?k_:z_}function C_(k_,z_){if(k_=B_(k_).abs(),z_=B_(z_).abs(),k_.equals(z_))return k_;if(k_.isZero())return z_;if(z_.isZero())return k_;for(var v_=P[1],U_,R_;k_.isEven()&&z_.isEven();)U_=V_(O_(k_),O_(z_)),k_=k_.divide(U_),z_=z_.divide(U_),v_=v_.multiply(U_);for(;k_.isEven();)k_=k_.divide(O_(k_));do{for(;z_.isEven();)z_=z_.divide(O_(z_));k_.greater(z_)&&(R_=z_,z_=k_,k_=R_),z_=z_.subtract(k_)}while(!z_.isZero());return v_.isUnit()?k_:k_.multiply(v_)}function H_(k_,z_){return k_=B_(k_).abs(),z_=B_(z_).abs(),k_.divide(C_(k_,z_)).multiply(z_)}function F_(k_,z_){k_=B_(k_),z_=B_(z_);var v_=V_(k_,z_),U_=L_(k_,z_),R_=U_.subtract(v_).add(1);if(R_.isSmall)return v_.add(Math.floor(Math.random()*R_));for(var K_=T_(R_,e).value,Q_=[],Y_=!0,Z_=0;Z_=Q_){if(Z_==="1"&&Q_===1)continue;throw new Error(Z_+" is not a valid digit in base "+z_+".")}}z_=B_(z_);var _0=[],a0=k_[0]==="-";for(K_=a0?1:0;K_"&&K_=0;K_--)U_=U_.add(k_[K_].times(R_)),R_=R_.times(z_);return v_?U_.negate():U_}function h_(k_,z_){return z_=z_||w,k_"}function T_(k_,z_){if(z_=bigInt(z_),z_.isZero()){if(k_.isZero())return{value:[0],isNegative:!1};throw new Error("Cannot convert nonzero numbers to base 0.")}if(z_.equals(-1)){if(k_.isZero())return{value:[0],isNegative:!1};if(k_.isNegative())return{value:[].concat.apply([],Array.apply(null,Array(-k_.toJSNumber())).map(Array.prototype.valueOf,[1,0])),isNegative:!1};var v_=Array.apply(null,Array(k_.toJSNumber()-1)).map(Array.prototype.valueOf,[0,1]);return v_.unshift([1]),{value:[].concat.apply([],v_),isNegative:!1}}var U_=!1;if(k_.isNegative()&&z_.isPositive()&&(U_=!0,k_=k_.abs()),z_.isUnit())return k_.isZero()?{value:[0],isNegative:!1}:{value:Array.apply(null,Array(k_.toJSNumber())).map(Number.prototype.valueOf,1),isNegative:U_};for(var R_=[],K_=k_,Q_;K_.isNegative()||K_.compareAbs(z_)>=0;){Q_=K_.divmod(z_),K_=Q_.quotient;var Y_=Q_.remainder;Y_.isNegative()&&(Y_=z_.minus(Y_).abs(),K_=K_.next()),R_.push(Y_.toJSNumber())}return R_.push(K_.toJSNumber()),{value:R_.reverse(),isNegative:U_}}function g_(k_,z_,v_){var U_=T_(k_,z_);return(U_.isNegative?"-":"")+U_.value.map(function(R_){return h_(R_,v_)}).join("")}V.prototype.toArray=function(k_){return T_(this,k_)},N.prototype.toArray=function(k_){return T_(this,k_)},L.prototype.toArray=function(k_){return T_(this,k_)},V.prototype.toString=function(k_,z_){if(k_===_&&(k_=10),k_!==10)return g_(this,k_,z_);for(var v_=this.value,U_=v_.length,R_=String(v_[--U_]),K_="0000000",Q_;--U_>=0;)Q_=String(v_[U_]),R_+=K_.slice(Q_.length)+Q_;var Y_=this.sign?"-":"";return Y_+R_},N.prototype.toString=function(k_,z_){return k_===_&&(k_=10),k_!=10?g_(this,k_,z_):String(this.value)},L.prototype.toString=N.prototype.toString,L.prototype.toJSON=V.prototype.toJSON=N.prototype.toJSON=function(){return this.toString()},V.prototype.valueOf=function(){return parseInt(this.toString(),10)},V.prototype.toJSNumber=V.prototype.valueOf,N.prototype.valueOf=function(){return this.value},N.prototype.toJSNumber=N.prototype.valueOf,L.prototype.valueOf=L.prototype.toJSNumber=function(){return parseInt(this.toString(),10)};function P_(k_){if(U(+k_)){var z_=+k_;if(z_===J(z_))return z?new L(q(z_)):new N(z_);throw new Error("Invalid integer: "+k_)}var v_=k_[0]==="-";v_&&(k_=k_.slice(1));var U_=k_.split(/e/i);if(U_.length>2)throw new Error("Invalid integer: "+U_.join("e"));if(U_.length===2){var R_=U_[1];if(R_[0]==="+"&&(R_=R_.slice(1)),R_=+R_,R_!==J(R_)||!U(R_))throw new Error("Invalid integer: "+R_+" is not a valid exponent.");var K_=U_[0],Q_=K_.indexOf(".");if(Q_>=0&&(R_-=K_.length-Q_-1,K_=K_.slice(0,Q_)+K_.slice(Q_+1)),R_<0)throw new Error("Cannot include negative exponent part for integers");K_+=new Array(R_+1).join("0"),k_=K_}var Y_=/^([0-9][0-9]*)$/.test(k_);if(!Y_)throw new Error("Invalid integer: "+k_);if(z)return new L(q(v_?"-"+k_:k_));for(var Z_=[],_0=k_.length,a0=u,I_=_0-a0;_0>0;)Z_.push(+k_.slice(I_,_0)),I_-=a0,I_<0&&(I_=0),_0-=a0;return K(Z_),new V(Z_,v_)}function S_(k_){if(z)return new L(q(k_));if(U(k_)){if(k_!==J(k_))throw new Error(k_+" is not an integer.");return new N(k_)}return P_(k_.toString())}function B_(k_){return typeof k_=="number"?S_(k_):typeof k_=="string"?P_(k_):typeof k_=="bigint"?new L(k_):k_}for(var G_=0;G_<1e3;G_++)P[G_]=B_(G_),G_>0&&(P[-G_]=B_(-G_));return P.one=P[1],P.zero=P[0],P.minusOne=P[-1],P.max=L_,P.min=V_,P.gcd=C_,P.lcm=H_,P.isInstance=function(k_){return k_ instanceof V||k_ instanceof N||k_ instanceof L},P.randBetween=F_,P.fromArray=function(k_,z_,v_){return q_(k_.map(B_),B_(z_||10),v_)},P}();function ml_z_normalize(_){var e=_.toJSNumber()|0;return _.equals(bigInt(e))?e:_}function ml_z_abs(_){return ml_z_normalize(bigInt(_).abs())}function ml_z_add(_,e){return ml_z_normalize(bigInt(_).add(bigInt(e)))}function ml_z_compare(_,e){return bigInt(_).compare(bigInt(e))}function ml_z_div(_,e){return e=bigInt(e),e.equals(bigInt(0))&&caml_raise_zero_divide(),ml_z_normalize(bigInt(_).divide(bigInt(e)))}function ml_z_divexact(_,e){return ml_z_div(_,e)}function ml_z_equal(_,e){return bigInt(_).equals(bigInt(e))}function ml_z_fits_int(_){return _==(_|0)?1:0}function ml_z_fits_int32(_){return ml_z_fits_int(_)}function ml_z_format(u,e){e=bigInt(e);for(var u=caml_jsbytes_of_string(u),d=10,$=0,w=0,q=0,z=0,P="",V=" ",N=0,L="";u[N]=="%";)N++;for(;;N++)if(u[N]=="#")q=1;else if(u[N]=="0")V="0";else if(u[N]=="-")z=1;else if(u[N]==" "||u[N]=="+")P=u[N];else break;for(e.lt(bigInt(0))&&(P="-",e=e.negate());u[N]>="0"&&u[N]<="9";N++)w=10*w+ +u[N];switch(u[N]){case"i":case"d":case"u":break;case"b":d=2,q&&(L="0b");break;case"o":d=8,q&&(L="0o");break;case"x":d=16,q&&(L="0x");break;case"X":d=16,q&&(L="0X"),$=1;break;default:caml_failwith("Unsupported format '"+u+"'")}z&&(V=" ");var U=e.toString(d);$===1&&(U=U.toUpperCase());var Y=U.length;if(V==" ")if(z)for(U=P+L+U;U.length=0;q--)_.write(8,d.value[q]>>>0&255),_.write(8,d.value[q]>>>8&255),_.write(8,d.value[q]>>>16&255),_.write(8,d.value[q]>>>24&255);u[0]=4*(1+((w+3)/4|0)),u[1]=8*(1+((w+7)/8|0))}function caml_zarith_unmarshal(_,e){var u;switch(_.read8u()){case 1:u=!0;break;case 0:u=!1;break;default:caml_failwith("input_value: z (malformed input)")}for(var d=_.read32u(),$=bigInt(0),w=0;w>>0),$=q.shiftLeft(w*32).add($)}return u&&($=$.negate()),e[0]=d+4,ml_z_normalize($)}function ml_z_init(_){return caml_custom_ops._z={serialize:caml_zarith_marshal,deserialize:caml_zarith_unmarshal,hash:ml_z_hash,compare:ml_z_compare},0}function ml_z_logand(_,e){return ml_z_normalize(bigInt(_).and(bigInt(e)))}function ml_z_lognot(_){return ml_z_normalize(bigInt(_).not())}function ml_z_logor(_,e){return ml_z_normalize(bigInt(_).or(bigInt(e)))}function ml_z_logxor(_,e){return ml_z_normalize(bigInt(_).xor(bigInt(e)))}function ml_z_mul(_,e){return ml_z_normalize(bigInt(_).multiply(bigInt(e)))}function ml_z_neg(_){return ml_z_normalize(bigInt(_).negate())}function ml_z_numbits(_){_=bigInt(_).abs();for(var e=0,u=bigInt.one;u.leq(_);)e+=1,u=u.multiply(2);return e}function ml_z_of_bits(_){for(var e=bigInt.zero,u=bigInt(256),d=bigInt.one,$=0;$>>0,d=caml_int64_hi32(_)>>>0,$=bigInt(u).add(bigInt(d).shiftLeft(32));return e&&($=$.negate()),ml_z_normalize($)}function ml_z_of_nativeint(_){return ml_z_of_int(_)}function jsoo_z_of_js_string_base(_,e){if(_==0){_=10;var u=0,d=1;if(e[u]=="-"?(d=-1,u++):e[u]=="+"&&u++,e[u]=="0"){if(u++,e.length==u)return 0;var $=e[u];$=="o"||$=="O"?_=8:$=="x"||$=="X"?_=16:($=="b"||$=="B")&&(_=2),_!=10&&(e=e.substring(u+1),d==-1&&(e="-"+e))}}e[0]=="+"&&(e=e.substring(1)),e=e.replace(/^0+/,""),(e=="-"||e=="")&&(e="0");function w(P){if(P>=48&&P<=57)return P-48;if(P>=97&&P<=102)return P-97+10;if(P>=65&&P<=70)return P-65+10}var q=0;for(e[q]=="-"&&q++;q=_)&&caml_invalid_argument("Z.of_substring_base: invalid digit")}return ml_z_normalize(bigInt(e,_))}function ml_z_of_substring_base(_,e,u,d){return e=caml_jsbytes_of_string(e),(u!=0||d!=e.length)&&(e.length-u=0?1:0}function ml_z_to_int64(_){_=bigInt(_),ml_z_fits_int64(_)||caml_raise_constant(caml_named_value("ml_z_overflow"));var e=bigInt(4294967295),u=_.and(e).toJSNumber(),d=_.shiftRight(32).and(e).toJSNumber(),$=caml_int64_create_lo_hi(u,d);return $}function ml_z_to_nativeint(_){return ml_z_to_int(_)}function mult_nat(_,e,u,d,$,w,q,z,P){for(var V=0,N=0;N9?t_:(e_==null&&(e_="0"),e_+t_)}function Q(t_){return t_>99?t_:t_>9?"0"+t_:"00"+t_}function X(t_){return t_===0?12:t_>12?t_-12:t_}function Z(t_,e_){e_=e_||"sunday";var a_=t_.getDay();e_==="monday"&&(a_===0?a_=6:a_--);var r_=Date.UTC(t_.getFullYear(),0,1),n_=Date.UTC(t_.getFullYear(),t_.getMonth(),t_.getDate()),c_=Math.floor((n_-r_)/864e5),l_=(c_+7-a_)/7;return Math.floor(l_)}function I(t_){var e_=t_%10,a_=t_%100;if(a_>=11&&a_<=13||e_===0||e_>=4)return"th";switch(e_){case 1:return"st";case 2:return"nd";case 3:return"rd"}}function __(t_){return(t_.getTimezoneOffset()||0)*6e4}})()}(globalThis),function(globalThis){"use strict";var joo_global_object=globalThis;function Base_am_testing(_){return 0}function caml_mul(_,e){return Math.imul(_,e)}function caml_hash_mix_int(_,e){return e=caml_mul(e,-862048943),e=e<<15|e>>>32-15,e=caml_mul(e,461845907),_^=e,_=_<<13|_>>>32-13,(_+(_<<2)|0)+-430675100|0}function caml_hash_mix_jsbytes(_,e){var u=e.length,d,$;for(d=0;d+4<=u;d+=4)$=e.charCodeAt(d)|e.charCodeAt(d+1)<<8|e.charCodeAt(d+2)<<16|e.charCodeAt(d+3)<<24,_=caml_hash_mix_int(_,$);switch($=0,u&3){case 3:$=e.charCodeAt(d+2)<<16;case 2:$|=e.charCodeAt(d+1)<<8;case 1:$|=e.charCodeAt(d),_=caml_hash_mix_int(_,$)}return _^=u,_}var log2_ok=Math.log2&&Math.log2(11235582092889474e291)==1020;function jsoo_floor_log2(_){if(log2_ok)return Math.floor(Math.log2(_));var e=0;if(_==0)return-1/0;if(_>=1)for(;_>=2;)_/=2,e++;else for(;_<1;)_*=2,e--;return e}var caml_int64_offset=Math.pow(2,-24);function caml_raise_constant(_){throw _}var caml_global_data=[0];function caml_raise_zero_divide(){caml_raise_constant(caml_global_data.Division_by_zero)}function MlInt64(_,e,u){this.lo=_&16777215,this.mi=e&16777215,this.hi=u&65535}MlInt64.prototype.caml_custom="_j",MlInt64.prototype.copy=function(){return new MlInt64(this.lo,this.mi,this.hi)},MlInt64.prototype.ucompare=function(_){return this.hi>_.hi?1:this.hi<_.hi?-1:this.mi>_.mi?1:this.mi<_.mi?-1:this.lo>_.lo?1:this.lo<_.lo?-1:0},MlInt64.prototype.compare=function(_){var e=this.hi<<16,u=_.hi<<16;return e>u?1:e_.mi?1:this.mi<_.mi?-1:this.lo>_.lo?1:this.lo<_.lo?-1:0},MlInt64.prototype.neg=function(){var _=-this.lo,e=-this.mi+(_>>24),u=-this.hi+(e>>24);return new MlInt64(_,e,u)},MlInt64.prototype.add=function(_){var e=this.lo+_.lo,u=this.mi+_.mi+(e>>24),d=this.hi+_.hi+(u>>24);return new MlInt64(e,u,d)},MlInt64.prototype.sub=function(_){var e=this.lo-_.lo,u=this.mi-_.mi+(e>>24),d=this.hi-_.hi+(u>>24);return new MlInt64(e,u,d)},MlInt64.prototype.mul=function(_){var e=this.lo*_.lo,u=(e*caml_int64_offset|0)+this.mi*_.lo+this.lo*_.mi,d=(u*caml_int64_offset|0)+this.hi*_.lo+this.mi*_.mi+this.lo*_.hi;return new MlInt64(e,u,d)},MlInt64.prototype.isZero=function(){return(this.lo|this.mi|this.hi)==0},MlInt64.prototype.isNeg=function(){return this.hi<<16<0},MlInt64.prototype.and=function(_){return new MlInt64(this.lo&_.lo,this.mi&_.mi,this.hi&_.hi)},MlInt64.prototype.or=function(_){return new MlInt64(this.lo|_.lo,this.mi|_.mi,this.hi|_.hi)},MlInt64.prototype.xor=function(_){return new MlInt64(this.lo^_.lo,this.mi^_.mi,this.hi^_.hi)},MlInt64.prototype.shift_left=function(_){return _=_&63,_==0?this:_<24?new MlInt64(this.lo<<_,this.mi<<_|this.lo>>24-_,this.hi<<_|this.mi>>24-_):_<48?new MlInt64(0,this.lo<<_-24,this.mi<<_-24|this.lo>>48-_):new MlInt64(0,0,this.lo<<_-48)},MlInt64.prototype.shift_right_unsigned=function(_){return _=_&63,_==0?this:_<24?new MlInt64(this.lo>>_|this.mi<<24-_,this.mi>>_|this.hi<<24-_,this.hi>>_):_<48?new MlInt64(this.mi>>_-24|this.hi<<48-_,this.hi>>_-24,0):new MlInt64(this.hi>>_-48,0,0)},MlInt64.prototype.shift_right=function(_){if(_=_&63,_==0)return this;var e=this.hi<<16>>16;if(_<24)return new MlInt64(this.lo>>_|this.mi<<24-_,this.mi>>_|e<<24-_,this.hi<<16>>_>>>16);var u=this.hi<<16>>31;return _<48?new MlInt64(this.mi>>_-24|this.hi<<48-_,this.hi<<16>>_-24>>16,u&65535):new MlInt64(this.hi<<16>>_-32,u,u)},MlInt64.prototype.lsl1=function(){this.hi=this.hi<<1|this.mi>>23,this.mi=(this.mi<<1|this.lo>>23)&16777215,this.lo=this.lo<<1&16777215},MlInt64.prototype.lsr1=function(){this.lo=(this.lo>>>1|this.mi<<23)&16777215,this.mi=(this.mi>>>1|this.hi<<23)&16777215,this.hi=this.hi>>>1},MlInt64.prototype.udivmod=function(_){for(var e=0,u=this.copy(),d=_.copy(),$=new MlInt64(0,0,0);u.ucompare(d)>0;)e++,d.lsl1();for(;e>=0;)e--,$.lsl1(),u.ucompare(d)>=0&&($.lo++,u=u.sub(d)),d.lsr1();return{quotient:$,modulus:u}},MlInt64.prototype.div=function(_){var e=this;_.isZero()&&caml_raise_zero_divide();var u=e.hi^_.hi;e.hi&32768&&(e=e.neg()),_.hi&32768&&(_=_.neg());var d=e.udivmod(_).quotient;return u&32768&&(d=d.neg()),d},MlInt64.prototype.mod=function(_){var e=this;_.isZero()&&caml_raise_zero_divide();var u=e.hi;e.hi&32768&&(e=e.neg()),_.hi&32768&&(_=_.neg());var d=e.udivmod(_).modulus;return u&32768&&(d=d.neg()),d},MlInt64.prototype.toInt=function(){return this.lo|this.mi<<24},MlInt64.prototype.toFloat=function(){return(this.hi<<16)*Math.pow(2,32)+this.mi*Math.pow(2,24)+this.lo},MlInt64.prototype.toArray=function(){return[this.hi>>8,this.hi&255,this.mi>>16,this.mi>>8&255,this.mi&255,this.lo>>16,this.lo>>8&255,this.lo&255]},MlInt64.prototype.lo32=function(){return this.lo|(this.mi&255)<<24},MlInt64.prototype.hi32=function(){return this.mi>>>8&65535|this.hi<<16};function caml_int64_create_lo_mi_hi(_,e,u){return new MlInt64(_,e,u)}function caml_int64_bits_of_float(_){if(!isFinite(_))return isNaN(_)?caml_int64_create_lo_mi_hi(1,0,32752):_>0?caml_int64_create_lo_mi_hi(0,0,32752):caml_int64_create_lo_mi_hi(0,0,65520);var e=_==0&&1/_==-1/0?32768:_>=0?0:32768;e&&(_=-_);var u=jsoo_floor_log2(_)+1023;u<=0?(u=0,_/=Math.pow(2,-1026)):(_/=Math.pow(2,u-1027),_<16&&(_*=2,u-=1),u==0&&(_/=2));var d=Math.pow(2,24),$=_|0;_=(_-$)*d;var w=_|0;_=(_-w)*d;var q=_|0;return $=$&15|e|u<<4,caml_int64_create_lo_mi_hi(q,w,$)}function caml_int64_lo32(_){return _.lo32()}function caml_int64_hi32(_){return _.hi32()}function caml_hash_mix_int64(_,e){return _=caml_hash_mix_int(_,caml_int64_lo32(e)),_=caml_hash_mix_int(_,caml_int64_hi32(e)),_}function caml_hash_mix_float(_,e){return caml_hash_mix_int64(_,caml_int64_bits_of_float(e))}function caml_str_repeat(_,e){if(_==0)return"";if(e.repeat)return e.repeat(_);for(var u="",d=0;;){if(_&1&&(u+=e),_>>=1,_==0)return u;e+=e,d++,d==9&&e.slice(0,1)}}function caml_subarray_to_jsbytes(_,e,u){var d=String.fromCharCode;if(e==0&&u<=4096&&u==_.length)return d.apply(null,_);for(var $="";0127)return!1;return!0}else return!/[^\x00-\x7f]/.test(_)}function caml_utf16_of_utf8(_){for(var e="",u="",d,$,w,q,z=0,P=_.length;z512?(u.substr(0,1),e+=u,u="",e+=_.slice(z,V)):u+=_.slice(z,V),V==P)break;z=V}q=1,++z=55295&&q<57344)&&(q=2)):(q=3,++z1114111)&&(q=3)))))),q<4?(z-=q,u+="\uFFFD"):q>65535?u+=String.fromCharCode(55232+(q>>10),56320+(q&1023)):u+=String.fromCharCode(q),u.length>1024&&(u.substr(0,1),e+=u,u="")}return e+u}function MlBytes(_,e,u){this.t=_,this.c=e,this.l=u}MlBytes.prototype.toString=function(){switch(this.t){case 9:return this.c;default:caml_convert_string_to_bytes(this);case 0:if(jsoo_is_ascii(this.c))return this.t=9,this.c;this.t=8;case 8:return this.c}},MlBytes.prototype.toUtf16=function(){var _=this.toString();return this.t==9?_:caml_utf16_of_utf8(_)},MlBytes.prototype.slice=function(){var _=this.t==4?this.c.slice():this.c;return new MlBytes(this.t,_,this.l)};function caml_ml_bytes_content(_){switch(_.t&6){default:caml_convert_string_to_bytes(_);case 0:return _.c;case 4:return _.c}}function caml_hash_mix_bytes(_,e){var u=caml_ml_bytes_content(e);return typeof u=="string"?caml_hash_mix_jsbytes(_,u):caml_hash_mix_bytes_arr(_,u)}function caml_int32_bits_of_float(_){var e=new globalThis.Float32Array(1);e[0]=_;var u=new globalThis.Int32Array(e.buffer);return u[0]|0}function caml_int64_to_bytes(_){return _.toArray()}function caml_ba_serialize(_,e,u){if(_.write(32,e.dims.length),_.write(32,e.kind|e.layout<<8),e.caml_custom=="_bigarr02")for(var d=0;d>4;if($==2047)return e|u|d&15?NaN:d&32768?-1/0:1/0;var w=Math.pow(2,-24),q=(e*w+u)*w+(d&15);return $>0?(q+=16,q*=Math.pow(2,$-1027)):q*=Math.pow(2,-1026),d&32768&&(q=-q),q}function caml_ba_get_size(_){for(var e=_.length,u=1,d=0;d>>24&255|(e&65535)<<8,e>>>16&65535)}function caml_array_bound_error(){caml_invalid_argument("index out of bounds")}var caml_ba_custom_name="_bigarr02";function Ml_Bigarray(_,e,u,d){this.kind=_,this.layout=e,this.dims=u,this.data=d}Ml_Bigarray.prototype.caml_custom=caml_ba_custom_name,Ml_Bigarray.prototype.offset=function(_){var e=0;if(typeof _=="number"&&(_=[_]),_ instanceof Array||caml_invalid_argument("bigarray.js: invalid offset"),this.dims.length!=_.length&&caml_invalid_argument("Bigarray.get/set: bad number of dimensions"),this.layout==0)for(var u=0;u=this.dims[u])&&caml_array_bound_error(),e=e*this.dims[u]+_[u];else for(var u=this.dims.length-1;u>=0;u--)(_[u]<1||_[u]>this.dims[u])&&caml_array_bound_error(),e=e*this.dims[u]+(_[u]-1);return e},Ml_Bigarray.prototype.get=function(_){switch(this.kind){case 7:var e=this.data[_*2+0],u=this.data[_*2+1];return caml_int64_create_lo_hi(e,u);case 10:case 11:var d=this.data[_*2+0],$=this.data[_*2+1];return[254,d,$];default:return this.data[_]}},Ml_Bigarray.prototype.set=function(_,e){switch(this.kind){case 7:this.data[_*2+0]=caml_int64_lo32(e),this.data[_*2+1]=caml_int64_hi32(e);break;case 10:case 11:this.data[_*2+0]=e[1],this.data[_*2+1]=e[2];break;default:this.data[_]=e;break}return 0},Ml_Bigarray.prototype.fill=function(_){switch(this.kind){case 7:var e=caml_int64_lo32(_),u=caml_int64_hi32(_);if(e==u)this.data.fill(e);else for(var d=0;dq)return 1;if(w!=q){if(!e)return NaN;if(w==w)return 1;if(q==q)return-1}}break;case 7:for(var $=0;$_.data[$+1])return 1;if(this.data[$]>>>0<_.data[$]>>>0)return-1;if(this.data[$]>>>0>_.data[$]>>>0)return 1}break;case 2:case 3:case 4:case 5:case 6:case 8:case 9:case 12:for(var $=0;$_.data[$])return 1}break}return 0};function Ml_Bigarray_c_1_1(_,e,u,d){this.kind=_,this.layout=e,this.dims=u,this.data=d}Ml_Bigarray_c_1_1.prototype=new Ml_Bigarray,Ml_Bigarray_c_1_1.prototype.offset=function(_){return typeof _!="number"&&(_ instanceof Array&&_.length==1?_=_[0]:caml_invalid_argument("Ml_Bigarray_c_1_1.offset")),(_<0||_>=this.dims[0])&&caml_array_bound_error(),_},Ml_Bigarray_c_1_1.prototype.get=function(_){return this.data[_]},Ml_Bigarray_c_1_1.prototype.set=function(_,e){return this.data[_]=e,0},Ml_Bigarray_c_1_1.prototype.fill=function(_){return this.data.fill(_),0};function caml_ba_create_unsafe(_,e,u,d){var $=caml_ba_get_size_per_element(_);return caml_ba_get_size(u)*$!=d.length&&caml_invalid_argument("length doesn't match dims"),e==0&&u.length==1&&$==1?new Ml_Bigarray_c_1_1(_,e,u,d):new Ml_Bigarray(_,e,u,d)}function caml_bytes_of_jsbytes(_){return new MlBytes(0,_,_.length)}function caml_string_of_jsbytes(_){return caml_bytes_of_jsbytes(_)}function caml_failwith(_){caml_global_data.Failure||(caml_global_data.Failure=[248,caml_string_of_jsbytes("Failure"),-3]),caml_raise_with_string(caml_global_data.Failure,_)}function caml_ba_deserialize(_,e,u){var d=_.read32s();(d<0||d>16)&&caml_failwith("input_value: wrong number of bigarray dimensions");var $=_.read32s(),w=$&255,q=$>>8&1,z=[];if(u=="_bigarr02")for(var P=0;P256&&(e=256);var d=0,$=0;for($=0;$+4<=_.data.length;$+=4)d=_.data[$+0]|_.data[$+1]<<8|_.data[$+2]<<16|_.data[$+3]<<24,u=caml_hash_mix_int(u,d);switch(d=0,e&3){case 3:d=_.data[$+2]<<16;case 2:d|=_.data[$+1]<<8;case 1:d|=_.data[$+0],u=caml_hash_mix_int(u,d)}break;case 4:case 5:e>128&&(e=128);var d=0,$=0;for($=0;$+2<=_.data.length;$+=2)d=_.data[$+0]|_.data[$+1]<<16,u=caml_hash_mix_int(u,d);e&1&&(u=caml_hash_mix_int(u,_.data[$]));break;case 6:e>64&&(e=64);for(var $=0;$64&&(e=64);for(var $=0;$32&&(e=32),e*=2;for(var $=0;$64&&(e=64);for(var $=0;$32&&(e=32);for(var $=0;$>>16,_=caml_mul(_,-2048144789),_^=_>>>13,_=caml_mul(_,-1028477387),_^=_>>>16,_}function caml_is_ml_bytes(_){return _ instanceof MlBytes}function caml_is_ml_string(_){return caml_is_ml_bytes(_)}function caml_hash(_,e,u,d){var $,w,q,z,P,V,N,L,U;for(z=e,(z<0||z>256)&&(z=256),P=_,V=u,$=[d],w=0,q=1;w0;)if(N=$[w++],N&&N.caml_custom){if(caml_custom_ops[N.caml_custom]&&caml_custom_ops[N.caml_custom].hash){var Y=caml_custom_ops[N.caml_custom].hash(N);V=caml_hash_mix_int(V,Y),P--}}else if(N instanceof Array&&N[0]===(N[0]|0))switch(N[0]){case 248:V=caml_hash_mix_int(V,N[2]),P--;break;case 250:$[--w]=N[1];break;default:var W=N.length-1<<10|N[0];for(V=caml_hash_mix_int(V,W),L=1,U=N.length;L=z);L++)$[q++]=N[L];break}else caml_is_ml_bytes(N)?(V=caml_hash_mix_bytes(V,N),P--):caml_is_ml_string(N)?(V=caml_hash_mix_string(V,N),P--):typeof N=="string"?(V=caml_hash_mix_jsbytes(V,N),P--):N===(N|0)?(V=caml_hash_mix_int(V,N+N+1),P--):N===+N&&(V=caml_hash_mix_float(V,N),P--);return V=caml_hash_mix_final(V),V&1073741823}function Base_hash_double(_){return caml_hash(1,1,0,_)}function Base_hash_string(_){return caml_hash(1,1,0,_)}function Base_int_math_int32_clz(_){var e=32,u;return u=_>>16,u!=0&&(e=e-16,_=u),u=_>>8,u!=0&&(e=e-8,_=u),u=_>>4,u!=0&&(e=e-4,_=u),u=_>>2,u!=0&&(e=e-2,_=u),u=_>>1,u!=0?e-2:e-_}function Base_int_math_int32_ctz(_){if(_===0)return 32;var e=1;return _&65535||(e=e+16,_=_>>16),_&255||(e=e+8,_=_>>8),_&15||(e=e+4,_=_>>4),_&3||(e=e+2,_=_>>2),e-(_&1)}function caml_int64_shift_right_unsigned(_,e){return _.shift_right_unsigned(e)}function caml_int64_is_zero(_){return+_.isZero()}function caml_int64_to_int32(_){return _.toInt()}function Base_int_math_int64_clz(_){var e=64,u;return u=caml_int64_shift_right_unsigned(_,32),caml_int64_is_zero(u)||(e=e-32,_=u),u=caml_int64_shift_right_unsigned(_,16),caml_int64_is_zero(u)||(e=e-16,_=u),u=caml_int64_shift_right_unsigned(_,8),caml_int64_is_zero(u)||(e=e-8,_=u),u=caml_int64_shift_right_unsigned(_,4),caml_int64_is_zero(u)||(e=e-4,_=u),u=caml_int64_shift_right_unsigned(_,2),caml_int64_is_zero(u)||(e=e-2,_=u),u=caml_int64_shift_right_unsigned(_,1),caml_int64_is_zero(u)?e-caml_int64_to_int32(_):e-2}function caml_int64_and(_,e){return _.and(e)}function caml_int64_of_int32(_){return new MlInt64(_&16777215,_>>24&16777215,_>>31&65535)}function Base_int_math_int64_ctz(_){if(caml_int64_is_zero(_))return 64;var e=1;function u(w){return caml_int64_is_zero(w)}function d(w,q){return caml_int64_and(w,q)}function $(w){return caml_int64_create_lo_mi_hi(w,0,0)}return u(d(_,caml_int64_create_lo_mi_hi(16777215,255,0)))&&(e=e+32,_=caml_int64_shift_right_unsigned(_,32)),u(d(_,$(65535)))&&(e=e+16,_=caml_int64_shift_right_unsigned(_,16)),u(d(_,$(255)))&&(e=e+8,_=caml_int64_shift_right_unsigned(_,8)),u(d(_,$(15)))&&(e=e+4,_=caml_int64_shift_right_unsigned(_,4)),u(d(_,$(3)))&&(e=e+2,_=caml_int64_shift_right_unsigned(_,2)),e-caml_int64_to_int32(caml_int64_and(_,$(1)))}function caml_int64_mul(_,e){return _.mul(e)}function Base_int_math_int64_pow_stub(_,e){for(var u=caml_int64_create_lo_hi(1,0),d=[u,_,u,u],$=u;!caml_int64_is_zero(e);)d[1]=caml_int64_mul(d[1],d[3]),d[2]=caml_int64_mul(d[1],d[1]),d[3]=caml_int64_mul(d[2],d[1]),$=caml_int64_mul($,d[caml_int64_lo32(e)&3]),e=caml_int64_shift_right_unsigned(e,2);return $}function Base_int_math_int_clz(_){return Base_int_math_int32_clz(_)}function Base_int_math_int_ctz(_){return Base_int_math_int32_ctz(_)}function Base_int_math_int_popcount(_){return _=_-(_>>>1&1431655765),_=(_&858993459)+(_>>>2&858993459),(_+(_>>>4)&252645135)*16843009>>>24}function Base_int_math_int_pow_stub(_,e){for(var u=1,d=[u,_,u,u],$=u;!e==0;)d[1]=d[1]*d[3]|0,d[2]=d[1]*d[1]|0,d[3]=d[2]*d[1]|0,$=$*d[e&3]|0,e=e>>2;return $}function Base_int_math_nativeint_clz(_){return Base_int_math_int32_clz(_)}function Base_int_math_nativeint_ctz(_){return Base_int_math_int32_ctz(_)}var Base_internalhash_fold_float=caml_hash_mix_float,Base_internalhash_fold_int=caml_hash_mix_int,Base_internalhash_fold_int64=caml_hash_mix_int64,Base_internalhash_fold_string=caml_hash_mix_string;function Base_internalhash_get_hash_value(_){var e=caml_hash_mix_final(_);return e&1073741823}function incr_nat(_,e,u,d){for(var $=d,w=0;w>>0)+$;if(_.data[e+w]=q|0,q==q>>>0){$=0;break}else $=1}return $}function add_nat(_,e,u,d,$,w,q){for(var z=q,P=0;P>>0)+(d.data[$+P]>>>0)+z;_.data[e+P]=V,V==V>>>0?z=0:z=1}return incr_nat(_,e+w,u-w,z)}function caml_js_from_array(_){return _.slice(1)}function caml_ba_create(_,e,u){var d=caml_js_from_array(u),$=caml_ba_create_buffer(_,caml_ba_get_size(d));return caml_ba_create_unsafe(_,e,d,$)}function bigstring_alloc(_,e){return caml_ba_create(12,0,[0,e])}function caml_ml_bytes_length(_){return _.l}function caml_convert_bytes_to_array(_){if(globalThis.Uint8Array)var e=new globalThis.Uint8Array(_.l);else var e=new Array(_.l);for(var u=_.c,d=u.length,$=0;$=u.l||u.t==2&&$>=u.c.length))u.c=_.t==4?caml_subarray_to_jsbytes(_.c,e,$):e==0&&_.c.length==$?_.c:_.c.substr(e,$),u.t=u.c.length==u.l?0:2;else if(u.t==2&&d==u.c.length)u.c+=_.t==4?caml_subarray_to_jsbytes(_.c,e,$):e==0&&_.c.length==$?_.c:_.c.substr(e,$),u.t=u.c.length==u.l?0:2;else{u.t!=4&&caml_convert_bytes_to_array(u);var w=_.c,q=u.c;if(_.t==4)if(d<=e)for(var z=0;z<$;z++)q[d+z]=w[e+z];else for(var z=$-1;z>=0;z--)q[d+z]=w[e+z];else{for(var P=Math.min($,w.length-e),z=0;z_.data.length&&caml_array_bound_error(),d+$>caml_ml_bytes_length(u)&&caml_array_bound_error();var q=_.data.slice(w,w+$);return caml_blit_bytes(caml_bytes_of_array(q),0,u,d,$),0}function bigstring_blit_bigstring_bytes_stub(_,e,u,d,$){return caml_bigstring_blit_ba_to_bytes(_,e,u,d,$)}function caml_array_of_bytes(_){return _.t!=4&&caml_convert_bytes_to_array(_),_.c}function caml_bigstring_blit_bytes_to_ba(_,e,u,d,$){if(u.kind!=12&&caml_invalid_argument("caml_bigstring_blit_string_to_ba: kind mismatch"),$==0)return 0;var w=u.offset(d);e+$>caml_ml_bytes_length(_)&&caml_array_bound_error(),w+$>u.data.length&&caml_array_bound_error();var q=caml_array_of_bytes(_).slice(e,e+$);return u.data.set(q,w),0}function bigstring_blit_bytes_bigstring_stub(_,e,u,d,$){return caml_bigstring_blit_bytes_to_ba(_,e,u,d,$)}function caml_ml_string_length(_){return caml_ml_bytes_length(_)}function caml_bytes_unsafe_get(_,e){switch(_.t&6){default:if(e>=_.c.length)return 0;case 0:return _.c.charCodeAt(e);case 4:return _.c[e]}}function caml_string_unsafe_get(_,e){return caml_bytes_unsafe_get(_,e)}function caml_array_of_string(_){for(var e=caml_ml_string_length(_),u=new Array(e),d=0;dcaml_ml_string_length(_)&&caml_array_bound_error(),w+$>u.data.length&&caml_array_bound_error();var q=caml_array_of_string(_).slice(e,e+$);return u.data.set(q,w),0}function bigstring_blit_string_bigstring_stub(_,e,u,d,$){return caml_bigstring_blit_string_to_ba(_,e,u,d,$)}function caml_bigstring_blit_ba_to_ba(_,e,u,d,$){if(_.kind!=12&&caml_invalid_argument("caml_bigstring_blit_ba_to_ba: kind mismatch"),u.kind!=12&&caml_invalid_argument("caml_bigstring_blit_ba_to_ba: kind mismatch"),$==0)return 0;var w=_.offset(e),q=u.offset(d);w+$>_.data.length&&caml_array_bound_error(),q+$>u.data.length&&caml_array_bound_error();var z=_.data.subarray(w,w+$);return u.data.set(z,d),0}function bigstring_blit_stub(_,e,u,d,$){return caml_bigstring_blit_ba_to_ba(_,e,u,d,$)}function caml_bytes_unsafe_set(_,e,u){if(u&=255,_.t!=4){if(e==_.c.length)return _.c+=String.fromCharCode(u),e+1==_.l&&(_.t=0),0;caml_convert_bytes_to_array(_)}return _.c[e]=u,0}function caml_string_unsafe_set(_,e,u){return caml_bytes_unsafe_set(_,e,u)}function caml_ba_get_1(_,e){return _.get(_.offset(e))}function bigstringaf_blit_to_bytes(_,e,u,d,$){for(var w=0;w<$;w++)caml_string_unsafe_set(u,d+w,caml_ba_get_1(_,e+w))}function bin_prot_blit_buf_bytes_stub(_,e,u,d,$){return caml_bigstring_blit_ba_to_bytes(e,_,d,u,$)}function caml_check_bound(_,e){return e>>>0>=_.length-1&&caml_array_bound_error(),_}function caml_check_bound_bigstring(_,e){e>>>0>=_.data.length&&caml_array_bound_error()}function bin_prot_blit_buf_float_array_stub(_,e,u,d,$){if($==0)return 0;caml_check_bound(d,u),caml_check_bound(d,u+$-1),caml_check_bound_bigstring(e,_),caml_check_bound_bigstring(e,_+$*8-1);var w=new joo_global_object.Float64Array($),q=new joo_global_object.Uint8Array(w.buffer);q.set(e.data.subarray(_,_+$*8));for(var z=0;z<$;z++)d[u+z+1]=w[z];return 0}function bin_prot_blit_float_array_buf_stub(_,e,u,d,$){if($==0)return 0;caml_check_bound(e,_),caml_check_bound(e,_+$-1),caml_check_bound_bigstring(d,u),caml_check_bound_bigstring(d,u+$*8-1),_=_+1;var w=new joo_global_object.Float64Array(e.slice(_,_+$)),q=new joo_global_object.Uint8Array(w.buffer),z=d.data.subarray(u,u+$*8);return z.set(q),0}function bin_prot_blit_string_buf_stub(_,e,u,d,$){return caml_bigstring_blit_string_to_ba(e,_,d,u,$)}function blit_nat(_,e,u,d,$){for(var w=0;w<$;w++)_.data[e+w]=u.data[d+w];return 0}function caml_array_append(_,e){var u=_.length,d=e.length,$=u+d-1,w=new Array($);w[0]=0;for(var q=1,z=1;q=1;w--)u[d+w]=_[e+w];return 0}function caml_array_concat(_){for(var e=[0];_!==0;){for(var u=_[1],d=1;d=_.length-1)&&caml_array_bound_error(),_[e+1]=u,0}function caml_array_sub(_,e,u){var d=new Array(u+1);d[0]=0;for(var $=1,w=e+1;$<=u;$++,w++)d[$]=_[w];return d}function caml_ba_blit(_,e){e.dims.length!=_.dims.length&&caml_invalid_argument("Bigarray.blit: dimension mismatch");for(var u=0;u=_.dims.length)&&caml_invalid_argument("Bigarray.dim"),_.dims[e]}function caml_ba_dim_1(_){return caml_ba_dim(_,0)}function caml_ba_dim_2(_){return caml_ba_dim(_,1)}function caml_ba_get_2(_,e,u){return _.get(_.offset([e,u]))}function caml_ba_layout(_){return _.layout}function caml_ba_set_1(_,e,u){return _.set(_.offset(e),u),0}function caml_ba_set_2(_,e,u,d){return _.set(_.offset([e,u]),d),0}function caml_ba_sub(_,e,u){var d,$=1;if(_.layout==0){for(var w=1;w<_.dims.length;w++)$=$*_.dims[w];d=0}else{for(var w=0;w<_.dims.length-1;w++)$=$*_.dims[w];d=_.dims.length-1,e=e-1}(e<0||u<0||e+u>_.dims[d])&&caml_invalid_argument("Bigarray.sub: bad sub-array");for(var q=[],w=0;w<_.dims.length;w++)q[w]=_.dims[w];q[d]=u,$*=caml_ba_get_size_per_element(_.kind);var z=_.data.subarray(e*$,(e+u)*$);return caml_ba_create_unsafe(_.kind,_.layout,q,z)}function caml_ba_uint8_get16(_,e){var u=_.offset(e);u+1>=_.data.length&&caml_array_bound_error();var d=_.get(u),$=_.get(u+1);return d|$<<8}function caml_ba_uint8_get32(_,e){var u=_.offset(e);u+3>=_.data.length&&caml_array_bound_error();var d=_.get(u+0),$=_.get(u+1),w=_.get(u+2),q=_.get(u+3);return d<<0|$<<8|w<<16|q<<24}function caml_ba_uint8_get64(_,e){var u=_.offset(e);u+7>=_.data.length&&caml_array_bound_error();var d=_.get(u+0),$=_.get(u+1),w=_.get(u+2),q=_.get(u+3),z=_.get(u+4),P=_.get(u+5),V=_.get(u+6),N=_.get(u+7);return caml_int64_of_bytes([N,V,P,z,q,w,$,d])}function caml_ba_uint8_set16(_,e,u){var d=_.offset(e);return d+1>=_.data.length&&caml_array_bound_error(),_.set(d+0,u&255),_.set(d+1,u>>>8&255),0}function caml_ba_uint8_set32(_,e,u){var d=_.offset(e);return d+3>=_.data.length&&caml_array_bound_error(),_.set(d+0,u&255),_.set(d+1,u>>>8&255),_.set(d+2,u>>>16&255),_.set(d+3,u>>>24&255),0}function caml_ba_uint8_set64(_,e,$){var d=_.offset(e);d+7>=_.data.length&&caml_array_bound_error();for(var $=caml_int64_to_bytes($),w=0;w<8;w++)_.set(d+w,$[7-w]);return 0}function caml_backtrace_status(){return 0}var plonk_wasm=globalThis.plonk_wasm,caml_bigint_256_bytes_per_limb=plonk_wasm.caml_bigint_256_bytes_per_limb,caml_bigint_256_compare=plonk_wasm.caml_bigint_256_compare,caml_bigint_256_div=plonk_wasm.caml_bigint_256_div,caml_bigint_256_num_limbs=plonk_wasm.caml_bigint_256_num_limbs;function caml_bytes_to_uint8array(_){for(var e=caml_ml_bytes_length(_),u=new globalThis.Uint8Array(e),d=0;d512?(u.substr(0,1),e+=u,u="",e+=_.slice(w,z)):u+=_.slice(w,z),z==q)break;w=z}d<2048?(u+=String.fromCharCode(192|d>>6),u+=String.fromCharCode(128|d&63)):d<55296||d>=57343?u+=String.fromCharCode(224|d>>12,128|d>>6&63,128|d&63):d>=56319||w+1==q||($=_.charCodeAt(w+1))<56320||$>57343?u+="\xEF\xBF\xBD":(w++,d=(d<<10)+$-56613888,u+=String.fromCharCode(240|d>>18,128|d>>12&63,128|d>>6&63,128|d&63)),u.length>1024&&(u.substr(0,1),e+=u,u="")}return e+u}function caml_bytes_of_utf16_jsstring(_){var e=9;return jsoo_is_ascii(_)||(e=8,_=caml_utf8_of_utf16(_)),new MlBytes(e,_,_.length)}function caml_string_of_jsstring(_){return caml_bytes_of_utf16_jsstring(_)}function caml_bigint_256_to_string(_){return caml_string_of_jsstring(plonk_wasm.caml_bigint_256_to_string(_))}function caml_bytes_of_string(_){return _}function caml_blit_string(_,e,u,d,$){return caml_blit_bytes(_,e,u,d,$),0}function caml_bswap16(_){return(_&255)<<8|(_&65280)>>8}function caml_bytes_compare(_,e){return _.t&6&&caml_convert_string_to_bytes(_),e.t&6&&caml_convert_string_to_bytes(e),_.ce.c?1:0}function caml_bytes_equal(_,e){return _===e?1:(_.t&6&&caml_convert_string_to_bytes(_),e.t&6&&caml_convert_string_to_bytes(e),_.c==e.c?1:0)}function caml_bytes_bound_error(){caml_invalid_argument("index out of bounds")}function caml_bytes_get(_,e){return e>>>0>=_.l&&caml_bytes_bound_error(),caml_bytes_unsafe_get(_,e)}function caml_bytes_get16(_,e){e>>>0>=_.l-1&&caml_bytes_bound_error();var u=caml_bytes_unsafe_get(_,e),d=caml_bytes_unsafe_get(_,e+1);return d<<8|u}function caml_bytes_lessequal(_,e){return _.t&6&&caml_convert_string_to_bytes(_),e.t&6&&caml_convert_string_to_bytes(e),_.c<=e.c?1:0}function caml_bytes_greaterequal(_,e){return caml_bytes_lessequal(e,_)}function caml_bytes_lessthan(_,e){return _.t&6&&caml_convert_string_to_bytes(_),e.t&6&&caml_convert_string_to_bytes(e),_.c>>0>=_.l&&caml_bytes_bound_error(),caml_bytes_unsafe_set(_,e,u)}function caml_bytes_set16(_,e,u){e>>>0>=_.l-1&&caml_bytes_bound_error();var d=255&u>>8,$=255&u;return caml_bytes_unsafe_set(_,e+0,$),caml_bytes_unsafe_set(_,e+1,d),0}function caml_bytes_set32(_,e,u){e>>>0>=_.l-3&&caml_bytes_bound_error();var d=255&u>>24,$=255&u>>16,w=255&u>>8,q=255&u;return caml_bytes_unsafe_set(_,e+0,q),caml_bytes_unsafe_set(_,e+1,w),caml_bytes_unsafe_set(_,e+2,$),caml_bytes_unsafe_set(_,e+3,d),0}function caml_bytes_set64(_,e,u){e>>>0>=_.l-7&&caml_bytes_bound_error();for(var d=caml_int64_to_bytes(u),$=0;$<8;$++)caml_bytes_unsafe_set(_,e+7-$,d[$]);return 0}function caml_call_gen(_,e){if(_.fun)return caml_call_gen(_.fun,e);if(typeof _!="function")return _;var u=_.length|0;if(u===0)return _.apply(null,e);var d=e.length|0,$=u-d|0;return $==0?_.apply(null,e):$<0?caml_call_gen(_.apply(null,e.slice(0,u)),e.slice(u)):function(){for(var w=arguments.length==0?1:arguments.length,q=new Array(e.length+w),z=0;z=22250738585072014e-324?0:_!=0?1:2:isNaN(_)?4:3}function caml_compare_val_get_custom(_){return caml_custom_ops[_.caml_custom]&&caml_custom_ops[_.caml_custom].compare}function caml_compare_val_number_custom(_,e,u,d){var $=caml_compare_val_get_custom(e);if($){var w=u>0?$(e,_,d):$(_,e,d);if(d&&w!=w)return u;if(+w!=+w)return+w;if(w|0)return w|0}return u}function caml_compare_val_tag(_){if(typeof _=="number")return 1e3;if(caml_is_ml_bytes(_))return 252;if(caml_is_ml_string(_))return 1252;if(_ instanceof Array&&_[0]===_[0]>>>0&&_[0]<=255){var e=_[0]|0;return e==254?0:e}else{if(_ instanceof String)return 12520;if(typeof _=="string")return 12520;if(_ instanceof Number)return 1e3;if(_&&_.caml_custom)return 1255;if(_&&_.compare)return 1256;if(typeof _=="function")return 1247;if(typeof _=="symbol")return 1251}return 1001}function caml_int_compare(_,e){return _e)return 1;if(_!=e){if(!u)return NaN;if(_==_)return 1;if(e==e)return-1}break;case 1001:if(_e)return 1;if(_!=e){if(!u)return NaN;if(_==_)return 1;if(e==e)return-1}break;case 1251:if(_!==e)return u?1:NaN;break;case 1252:var _=caml_jsbytes_of_string(_),e=caml_jsbytes_of_string(e);if(_!==e){if(_e)return 1}break;case 12520:var _=_.toString(),e=e.toString();if(_!==e){if(_e)return 1}break;case 246:case 254:default:if(_.length!=e.length)return _.length1&&d.push(_,e,1);break}}if(d.length==0)return 0;var P=d.pop();e=d.pop(),_=d.pop(),P+1<_.length&&d.push(_,e,P+1),_=_[P],e=e[P]}}function caml_compare(_,e){return caml_compare_val(_,e,!0)}function caml_convert_raw_backtrace(){return[0]}function caml_convert_raw_backtrace_slot(){caml_failwith("caml_convert_raw_backtrace_slot")}function caml_div(_,e){return e==0&&caml_raise_zero_divide(),_/e|0}var caml_ephe_key_offset=3;function caml_weak_create(_){_<0&&caml_invalid_argument("Weak.create");var e=[251,"caml_ephe_list_head"];return e.length=caml_ephe_key_offset+_,e}var caml_ephe_create=caml_weak_create,caml_ephe_data_offset=2;function caml_ephe_get_data(_){return _[caml_ephe_data_offset]===void 0?0:[0,_[caml_ephe_data_offset]]}function caml_ephe_set_data(_,e){return _[caml_ephe_data_offset]=e,0}function caml_weak_set(_,e,u){return(e<0||caml_ephe_key_offset+e>=_.length)&&caml_invalid_argument("Weak.set"),_[caml_ephe_key_offset+e]=u,0}function caml_ephe_set_key(_,e,u){return caml_weak_set(_,e,[0,u])}function caml_equal(_,e){return+(caml_compare_val(_,e,!1)==0)}function caml_fill_bytes(_,e,u,d){if(u>0)if(e==0&&(u>=_.l||_.t==2&&u>=_.c.length))d==0?(_.c="",_.t=2):(_.c=caml_str_repeat(u,String.fromCharCode(d)),_.t=u==_.l?0:2);else for(_.t!=4&&caml_convert_bytes_to_array(_),u+=e;ee||_===_?1:e===e?-1:0}function caml_float_of_string(_){var e;if(_=caml_jsbytes_of_string(_),e=+_,_.length>0&&e===e||(_=_.replace(/_/g,""),e=+_,_.length>0&&e===e||/^[+-]?nan$/i.test(_)))return e;var u=/^ *([+-]?)0x([0-9a-f]+)\.?([0-9a-f]*)(p([+-]?[0-9]+))?/i.exec(_);if(u){var d=u[3].replace(/0+$/,""),$=parseInt(u[1]+u[2]+d,16),w=(u[5]|0)-4*d.length;return e=$*Math.pow(2,w),e}if(/^\+?inf(inity)?$/i.test(_))return 1/0;if(/^-inf(inity)?$/i.test(_))return-1/0;caml_failwith("float_of_string")}function caml_parse_format(_){_=caml_jsbytes_of_string(_);var e=_.length;e>31&&caml_invalid_argument("format_int: format too long");for(var u={justify:"+",signstyle:"-",filler:" ",alternate:!1,base:0,signedconv:!1,width:0,uppercase:!1,sign:1,prec:-1,conv:"f"},d=0;d=0&&$<=9;)u.width=u.width*10+$,d++;d--;break;case".":for(u.prec=0,d++;$=_.charCodeAt(d)-48,$>=0&&$<=9;)u.prec=u.prec*10+$,d++;d--;case"d":case"i":u.signedconv=!0;case"u":u.base=10;break;case"x":u.base=16;break;case"X":u.base=16,u.uppercase=!0;break;case"o":u.base=8;break;case"e":case"f":case"g":u.signedconv=!0,u.conv=$;break;case"E":case"F":case"G":u.signedconv=!0,u.uppercase=!0,u.conv=$.toLowerCase();break}}return u}function caml_finish_formatting(_,e){_.uppercase&&(e=e.toUpperCase());var u=e.length;_.signedconv&&(_.sign<0||_.signstyle!="-")&&u++,_.alternate&&(_.base==8&&(u+=1),_.base==16&&(u+=2));var d="";if(_.justify=="+"&&_.filler==" ")for(var $=u;$<_.width;$++)d+=" ";if(_.signedconv&&(_.sign<0?d+="-":_.signstyle!="-"&&(d+=_.signstyle)),_.alternate&&_.base==8&&(d+="0"),_.alternate&&_.base==16&&(d+="0x"),_.justify=="+"&&_.filler=="0")for(var $=u;$<_.width;$++)d+="0";if(d+=e,_.justify=="-")for(var $=u;$<_.width;$++)d+=" ";return caml_string_of_jsbytes(d)}function caml_format_float(_,e){function u(N,L){if(Math.abs(N)<1)return N.toFixed(L);var U=parseInt(N.toString().split("+")[1]);return U>20?(U-=20,N/=Math.pow(10,U),N+=new Array(U+1).join("0"),L>0&&(N=N+"."+new Array(L+1).join("0")),N):N.toFixed(L)}var d,$=caml_parse_format(_),w=$.prec<0?6:$.prec;if((e<0||e==0&&1/e==-1/0)&&($.sign=-1,e=-e),isNaN(e))d="nan",$.filler=" ";else if(!isFinite(e))d="inf",$.filler=" ";else switch($.conv){case"e":var d=e.toExponential(w),q=d.length;d.charAt(q-3)=="e"&&(d=d.slice(0,q-1)+"0"+d.slice(q-1));break;case"f":d=u(e,w);break;case"g":w=w||1,d=e.toExponential(w-1);var z=d.indexOf("e"),P=+d.slice(z+1);if(P<-4||e>=1e21||e.toFixed(0).length>w){for(var q=z-1;d.charAt(q)=="0";)q--;d.charAt(q)=="."&&q--,d=d.slice(0,q+1)+d.slice(z),q=d.length,d.charAt(q-3)=="e"&&(d=d.slice(0,q-1)+"0"+d.slice(q-1));break}else{var V=w;if(P<0)V-=P+1,d=e.toFixed(V);else for(;d=e.toFixed(V),d.length>w+1;)V--;if(V){for(var q=d.length-1;d.charAt(q)=="0";)q--;d.charAt(q)=="."&&q--,d=d.slice(0,q+1)}}break}return caml_finish_formatting($,d)}function caml_format_int(_,e){if(caml_jsbytes_of_string(_)=="%d")return caml_string_of_jsbytes(""+e);var u=caml_parse_format(_);e<0&&(u.signedconv?(u.sign=-1,e=-e):e>>>=0);var d=e.toString(u.base);if(u.prec>=0){u.filler=" ";var $=u.prec-d.length;$>0&&(d=caml_str_repeat($,"0")+d)}return caml_finish_formatting(u,d)}function rust_affine_to_caml_affine(_){var e=_.infinity;if(e)return _.free(),0;var u=_.x,d=_.y;return _.free(),[0,[0,u,d]]}function js_class_vector_of_rust_vector(_,e){for(var u=_.length,d=new Array(u),$=0;$=1;)_*=.5,u++;return e&&(_=-_),[0,_,u]}function fs_node_supported(){return typeof globalThis.process<"u"&&typeof globalThis.process.versions<"u"&&typeof globalThis.process.versions.node<"u"}function make_path_is_absolute(){function _(u){if(u.charAt(0)==="/")return["",u.substring(1)]}function e(u){var d=/^([a-zA-Z]:|[\\/]{2}[^\\/]+[\\/]+[^\\/]+)?([\\/])?([\s\S]*?)$/,$=d.exec(u),w=$[1]||"",q=Boolean(w&&w.charAt(1)!==":");if(Boolean($[2]||q)){var z=$[1]||"",P=$[2]||"";return[z,u.substring(z.length+P.length)]}}return fs_node_supported()&&globalThis.process&&globalThis.process.platform&&globalThis.process.platform==="win32"?e:_}var path_is_absolute=make_path_is_absolute();function caml_trailing_slash(_){return _.slice(-1)!=="/"?_+"/":_}if(fs_node_supported()&&globalThis.process&&globalThis.process.cwd)var caml_current_dir=globalThis.process.cwd().replace(/\\/g,"/");else var caml_current_dir="/static";caml_current_dir=caml_trailing_slash(caml_current_dir);function caml_make_path(_){_=caml_jsstring_of_string(_),path_is_absolute(_)||(_=caml_current_dir+_);for(var e=path_is_absolute(_),u=e[1].split("/"),d=[],$=0;$1&&d.pop();break;case".":break;default:d.push(u[$]);break}return d.unshift(e[0]),d.orig=_,d}var unix_error=["E2BIG","EACCES","EAGAIN","EBADF","EBUSY","ECHILD","EDEADLK","EDOM","EEXIST","EFAULT","EFBIG","EINTR","EINVAL","EIO","EISDIR","EMFILE","EMLINK","ENAMETOOLONG","ENFILE","ENODEV","ENOENT","ENOEXEC","ENOLCK","ENOMEM","ENOSPC","ENOSYS","ENOTDIR","ENOTEMPTY","ENOTTY","ENXIO","EPERM","EPIPE","ERANGE","EROFS","ESPIPE","ESRCH","EXDEV","EWOULDBLOCK","EINPROGRESS","EALREADY","ENOTSOCK","EDESTADDRREQ","EMSGSIZE","EPROTOTYPE","ENOPROTOOPT","EPROTONOSUPPORT","ESOCKTNOSUPPORT","EOPNOTSUPP","EPFNOSUPPORT","EAFNOSUPPORT","EADDRINUSE","EADDRNOTAVAIL","ENETDOWN","ENETUNREACH","ENETRESET","ECONNABORTED","ECONNRESET","ENOBUFS","EISCONN","ENOTCONN","ESHUTDOWN","ETOOMANYREFS","ETIMEDOUT","ECONNREFUSED","EHOSTDOWN","EHOSTUNREACH","ELOOP","EOVERFLOW"];function make_unix_err_args(_,e,u,d){var $=unix_error.indexOf(_);$<0&&(d==null&&(d=-9999),$=[0,d]);var w=[$,caml_string_of_jsstring(e||""),caml_string_of_jsstring(u||"")];return w}var caml_named_values={};function caml_named_value(_){return caml_named_values[_]}function caml_raise_with_args(_,e){throw[0,_].concat(e)}function caml_raise_sys_error(_){caml_raise_with_string(caml_global_data.Sys_error,_)}function caml_raise_no_such_file(_){caml_raise_sys_error(_+": No such file or directory")}function MlFile(){}function MlFakeFile(_){this.data=_}MlFakeFile.prototype=new MlFile,MlFakeFile.prototype.truncate=function(_){var e=this.data;this.data=caml_create_bytes(_|0),caml_blit_bytes(e,0,this.data,0,_)},MlFakeFile.prototype.length=function(){return caml_ml_bytes_length(this.data)},MlFakeFile.prototype.write=function(_,e,u,d){var $=this.length();if(_+d>=$){var w=caml_create_bytes(_+d),q=this.data;this.data=w,caml_blit_bytes(q,0,this.data,0,$)}return caml_blit_string(e,u,this.data,_,d),0},MlFakeFile.prototype.read=function(_,e,u,d){var $=this.length();return caml_blit_bytes(this.data,_,e,u,d),0},MlFakeFile.prototype.read_one=function(_){return caml_bytes_get(this.data,_)},MlFakeFile.prototype.close=function(){},MlFakeFile.prototype.constructor=MlFakeFile;function MlFakeDevice(_,e){this.content={},this.root=_,this.lookupFun=e}MlFakeDevice.prototype.nm=function(_){return this.root+_},MlFakeDevice.prototype.create_dir_if_needed=function(_){for(var e=_.split("/"),u="",d=0;d>1|1,e=0)}function caml_greaterthan(_,e){return+(caml_compare_val(_,e,!1)>0)}function caml_hexstring_of_float(_,e,u){if(!isFinite(_))return isNaN(_)?caml_string_of_jsstring("nan"):caml_string_of_jsstring(_>0?"infinity":"-infinity");var d=_==0&&1/_==-1/0?1:_>=0?0:1;d&&(_=-_);var $=0;if(_!=0)if(_<1)for(;_<1&&$>-1022;)_*=2,$--;else for(;_>=2;)_/=2,$++;var w=$<0?"":"+",q="";if(d)q="-";else switch(u){case 43:q="+";break;case 32:q=" ";break;default:break}if(e>=0&&e<13){var z=Math.pow(2,e*4);_=Math.round(_*z)/z}var P=_.toString(16);if(e>=0){var V=P.indexOf(".");if(V<0)P+="."+caml_str_repeat(e,"0");else{var N=V+1+e;P.length>24},read16u:function(){var _=this.s,e=this.i;return this.i=e+2,_.charCodeAt(e)<<8|_.charCodeAt(e+1)},read16s:function(){var _=this.s,e=this.i;return this.i=e+2,_.charCodeAt(e)<<24>>16|_.charCodeAt(e+1)},read32u:function(){var _=this.s,e=this.i;return this.i=e+4,(_.charCodeAt(e)<<24|_.charCodeAt(e+1)<<16|_.charCodeAt(e+2)<<8|_.charCodeAt(e+3))>>>0},read32s:function(){var _=this.s,e=this.i;return this.i=e+4,_.charCodeAt(e)<<24|_.charCodeAt(e+1)<<16|_.charCodeAt(e+2)<<8|_.charCodeAt(e+3)},readstr:function(_){var e=this.i;return this.i=e+_,caml_string_of_jsbytes(this.s.substring(e,e+_))}};function caml_float_of_bytes(_){return caml_int64_float_of_bits(caml_int64_of_bytes(_))}function caml_input_value_from_reader(_,e){var u=_.read32u(),d=_.read32u(),$=_.read32u(),w=_.read32u(),q=_.read32u(),z=[],P=$>0?[]:null,V=0;function N(){var K=_.read8u();if(K>=64)if(K>=128){var R=K&15,J=K>>4&7,Q=[R];return J==0||(P&&(P[V++]=Q),z.push(Q,J)),Q}else return K&63;else if(K>=32){var X=K&31,Q=_.readstr(X);return P&&(P[V++]=Q),Q}else switch(K){case 0:return _.read8s();case 1:return _.read16s();case 2:return _.read32s();case 3:caml_failwith("input_value: integer too large");break;case 4:var Z=_.read8u();return P[V-Z];case 5:var Z=_.read16u();return P[V-Z];case 6:var Z=_.read32u();return P[V-Z];case 8:var I=_.read32u(),R=I&255,J=I>>10,Q=[R];return J==0||(P&&(P[V++]=Q),z.push(Q,J)),Q;case 19:caml_failwith("input_value: data block too large");break;case 9:var X=_.read8u(),Q=_.readstr(X);return P&&(P[V++]=Q),Q;case 10:var X=_.read32u(),Q=_.readstr(X);return P&&(P[V++]=Q),Q;case 12:for(var e_=new Array(8),__=0;__<8;__++)e_[7-__]=_.read8u();var Q=caml_float_of_bytes(e_);return P&&(P[V++]=Q),Q;case 11:for(var e_=new Array(8),__=0;__<8;__++)e_[__]=_.read8u();var Q=caml_float_of_bytes(e_);return P&&(P[V++]=Q),Q;case 14:var X=_.read8u(),Q=new Array(X+1);Q[0]=254;var e_=new Array(8);P&&(P[V++]=Q);for(var __=1;__<=X;__++){for(var t_=0;t_<8;t_++)e_[7-t_]=_.read8u();Q[__]=caml_float_of_bytes(e_)}return Q;case 13:var X=_.read8u(),Q=new Array(X+1);Q[0]=254;var e_=new Array(8);P&&(P[V++]=Q);for(var __=1;__<=X;__++){for(var t_=0;t_<8;t_++)e_[t_]=_.read8u();Q[__]=caml_float_of_bytes(e_)}return Q;case 7:var X=_.read32u(),Q=new Array(X+1);Q[0]=254,P&&(P[V++]=Q);for(var e_=new Array(8),__=1;__<=X;__++){for(var t_=0;t_<8;t_++)e_[7-t_]=_.read8u();Q[__]=caml_float_of_bytes(e_)}return Q;case 15:var X=_.read32u(),Q=new Array(X+1);Q[0]=254;for(var e_=new Array(8),__=1;__<=X;__++){for(var t_=0;t_<8;t_++)e_[t_]=_.read8u();Q[__]=caml_float_of_bytes(e_)}return Q;case 16:case 17:caml_failwith("input_value: code pointer");break;case 18:case 24:case 25:for(var a_,r_="";(a_=_.read8u())!=0;)r_+=String.fromCharCode(a_);var n_=caml_custom_ops[r_],c_;switch(n_||caml_failwith("input_value: unknown custom block identifier"),K){case 18:break;case 25:n_.fixed_length||caml_failwith("input_value: expected a fixed-size custom block"),c_=n_.fixed_length;break;case 24:c_=_.read32u(),_.read32s(),_.read32s();break}var l_=_.i,J=[0],Q=n_.deserialize(_,J);return c_!=null&&c_!=J[0]&&caml_failwith("input_value: incorrect length of serialized custom block"),P&&(P[V++]=Q),Q;default:caml_failwith("input_value: ill-formed message")}}for(var L=N();z.length>0;){var U=z.pop(),Y=z.pop(),W=Y.length;W>>8|(_&4278190080)>>>24}function caml_int64_add(_,e){return _.add(e)}function caml_int64_bswap(_){var e=caml_int64_to_bytes(_);return caml_int64_of_bytes([e[7],e[6],e[5],e[4],e[3],e[2],e[1],e[0]])}function caml_int64_div(_,e){return _.div(e)}function caml_int64_is_negative(_){return+_.isNeg()}function caml_int64_neg(_){return _.neg()}function caml_int64_format(_,e){var u=caml_parse_format(_);u.signedconv&&caml_int64_is_negative(e)&&(u.sign=-1,e=caml_int64_neg(e));var d="",$=caml_int64_of_int32(u.base),w="0123456789abcdef";do{var q=e.udivmod($);e=q.quotient,d=w.charAt(caml_int64_to_int32(q.modulus))+d}while(!caml_int64_is_zero(e));if(u.prec>=0){u.filler=" ";var z=u.prec-d.length;z>0&&(d=caml_str_repeat(z,"0")+d)}return caml_finish_formatting(u,d)}function caml_int64_mod(_,e){return _.mod(e)}function caml_int64_of_float(_){return _<0&&(_=Math.ceil(_)),new MlInt64(_&16777215,Math.floor(_*caml_int64_offset)&16777215,Math.floor(_*caml_int64_offset*caml_int64_offset)&65535)}function caml_int64_ult(_,e){return _.ucompare(e)<0}function caml_parse_sign_and_base(_){var e=0,u=caml_ml_string_length(_),d=10,$=1;if(u>0)switch(caml_string_unsafe_get(_,e)){case 45:e++,$=-1;break;case 43:e++,$=1;break}if(e+1=48&&_<=57?_-48:_>=65&&_<=90?_-55:_>=97&&_<=122?_-87:-1}function caml_int64_of_string(_){var e=caml_parse_sign_and_base(_),u=e[0],d=e[1],$=e[2],w=caml_int64_of_int32($),q=new MlInt64(16777215,268435455,65535).udivmod(w).quotient,z=caml_string_unsafe_get(_,u),P=caml_parse_digit(z);(P<0||P>=$)&&caml_failwith("int_of_string");for(var V=caml_int64_of_int32(P);;)if(u++,z=caml_string_unsafe_get(_,u),z!=95){if(P=caml_parse_digit(z),P<0||P>=$)break;caml_int64_ult(q,V)&&caml_failwith("int_of_string"),P=caml_int64_of_int32(P),V=caml_int64_add(caml_int64_mul(w,V),P),caml_int64_ult(V,P)&&caml_failwith("int_of_string")}return u!=caml_ml_string_length(_)&&caml_failwith("int_of_string"),$==10&&caml_int64_ult(new MlInt64(0,0,32768),V)&&caml_failwith("int_of_string"),d<0&&(V=caml_int64_neg(V)),V}function caml_int64_or(_,e){return _.or(e)}function caml_int64_shift_left(_,e){return _.shift_left(e)}function caml_int64_shift_right(_,e){return _.shift_right(e)}function caml_int64_sub(_,e){return _.sub(e)}function caml_int64_to_float(_){return _.toFloat()}function caml_int64_xor(_,e){return _.xor(e)}function caml_int_of_string(_){var e=caml_parse_sign_and_base(_),u=e[0],d=e[1],$=e[2],w=caml_ml_string_length(_),q=-1>>>0,z=u=$)&&caml_failwith("int_of_string");var V=P;for(u++;u=$)break;V=$*V+P,V>q&&caml_failwith("int_of_string")}return u!=w&&caml_failwith("int_of_string"),V=d*V,$==10&&(V|0)!=V&&caml_failwith("int_of_string"),V|0}function caml_js_eval_string(s){return eval(caml_jsstring_of_string(s))}function caml_js_to_array(_){var e=_.length,u=new Array(e+1);u[0]=0;for(var d=0;d0){for(var u=new Array(e),d=0;d1023&&(e-=1023,_*=Math.pow(2,1023),e>1023&&(e-=1023,_*=Math.pow(2,1023))),e<-1023&&(e+=1023,_*=Math.pow(2,-1023)),_*=Math.pow(2,e),_}function caml_lessequal(_,e){return+(caml_compare_val(_,e,!1)<=0)}function caml_lessthan(_,e){return+(caml_compare_val(_,e,!1)<0)}function caml_lex_array(_){_=caml_jsbytes_of_string(_);for(var e=_.length/2,u=new Array(e),d=0;d>16;return u}function caml_lex_engine(_,e,u){var d=2,$=3,w=5,q=6,z=7,P=8,V=9,N=1,L=2,U=3,Y=4,W=5;_.lex_default||(_.lex_base=caml_lex_array(_[N]),_.lex_backtrk=caml_lex_array(_[L]),_.lex_check=caml_lex_array(_[W]),_.lex_trans=caml_lex_array(_[Y]),_.lex_default=caml_lex_array(_[U]));var K,R=e,J=caml_array_of_bytes(u[d]);for(R>=0?(u[z]=u[w]=u[q],u[P]=-1):R=-R-1;;){var Q=_.lex_base[R];if(Q<0)return-Q-1;var X=_.lex_backtrk[R];if(X>=0&&(u[z]=u[q],u[P]=X),u[q]>=u[$]){if(u[V]==0)return-R-1;K=256}else K=J[u[q]],u[q]++;if(_.lex_check[Q+K]==R?R=_.lex_trans[Q+K]:R=_.lex_default[R],R<0)if(u[q]=u[z],u[P]==-1)caml_failwith("lexing: empty token");else return u[P];else K==256&&(u[V]=0)}}function caml_list_of_js_array(_){for(var e=0,u=_.length-1;u>=0;u--){var d=_[u];e=[0,d,e]}return e}function caml_log10_float(_){return Math.log10(_)}function caml_make_float_vect(e){e<0&&caml_array_bound_error();var e=e+1|0,u=new Array(e);u[0]=254;for(var d=1;d>>32-L,V)}function u(z,P,V,N,L,U,Y){return e(P&V|~P&N,z,P,L,U,Y)}function d(z,P,V,N,L,U,Y){return e(P&N|V&~N,z,P,L,U,Y)}function $(z,P,V,N,L,U,Y){return e(P^V^N,z,P,L,U,Y)}function w(z,P,V,N,L,U,Y){return e(V^(P|~N),z,P,L,U,Y)}function q(z,P){var V=P;for(z[V>>2]|=128<<8*(V&3),V=(V&-4)+8;(V&63)<60;V+=4)z[(V>>2)-1]=0;z[(V>>2)-1]=P<<3,z[V>>2]=P>>29&536870911;var N=[1732584193,4023233417,2562383102,271733878];for(V=0;V>8*R&255;return K}return function(z,P,V){var N=[],L=caml_ml_bytes_content(z);if(typeof L=="string"){for(var U=L,Y=0;Y>2]=U.charCodeAt(W)|U.charCodeAt(W+1)<<8|U.charCodeAt(W+2)<<16|U.charCodeAt(W+3)<<24}for(;Y>2]|=U.charCodeAt(Y+P)<<8*(Y&3)}else{for(var K=L,Y=0;Y>2]=K[W]|K[W+1]<<8|K[W+2]<<16|K[W+3]<<24}for(;Y>2]|=K[Y+P]<<8*(Y&3)}return caml_string_of_array(q(N,V))}}();function caml_md5_string(_,e,u){return caml_md5_bytes(_,e,u)}function caml_ml_channel_size(_){var e=caml_ml_channels[_];return e.file.length()}function caml_ml_channel_size_64(_){var e=caml_ml_channels[_];return caml_int64_of_float(e.file.length())}function caml_sys_close(_){return delete caml_global_data.fds[_],0}function caml_ml_flush(_){var e=caml_ml_channels[_];if(e.opened||caml_raise_sys_error("Cannot flush a closed channel"),!e.buffer||e.buffer=="")return 0;if(e.fd&&caml_global_data.fds[e.fd]&&caml_global_data.fds[e.fd].output){var u=caml_global_data.fds[e.fd].output;switch(u.length){case 2:u(_,e.buffer);break;default:u(e.buffer)}}return e.buffer="",0}function caml_ml_close_channel(_){var e=caml_ml_channels[_];return caml_ml_flush(_),e.opened=!1,e.file.close(),caml_sys_close(e.fd),0}function caml_ml_debug_info_status(){return 0}function caml_ml_refill_input(_){var e=_.refill(),u=caml_ml_string_length(e);return u==0&&(_.refill=null),_.file.write(_.file.length(),e,0,u),u}function caml_ml_input(_,e,u,d){var $=caml_ml_channels[_],w=$.file.length()-$.offset;return w==0&&$.refill!=null&&(w=caml_ml_refill_input($)),w=e.file.length()&&caml_raise_end_of_file();var u=e.file.read_one(e.offset);return e.offset++,u}function caml_ml_input_int(_){for(var e=caml_ml_channels[_],u=e.file;e.offset+3>=u.length();){var d=caml_ml_refill_input(e);d==0&&caml_raise_end_of_file()}var $=e.offset,w=u.read_one($)<<24|u.read_one($+1)<<16|u.read_one($+2)<<8|u.read_one($+3);return e.offset+=4,w}function caml_std_output(_,e){var u=caml_ml_channels[_],d=caml_string_of_jsbytes(e),$=caml_ml_string_length(d);return u.file.write(u.offset,d,0,$),u.offset+=$,0}function js_print_stderr(e){var e=caml_utf16_of_utf8(e),u=globalThis;if(u.process&&u.process.stdout&&u.process.stdout.write)u.process.stderr.write(e);else{e.charCodeAt(e.length-1)==10&&(e=e.substr(0,e.length-1));var d=u.console;d&&d.error&&d.error(e)}}function js_print_stdout(e){var e=caml_utf16_of_utf8(e),u=globalThis;if(u.process&&u.process.stdout&&u.process.stdout.write)u.process.stdout.write(e);else{e.charCodeAt(e.length-1)==10&&(e=e.substr(0,e.length-1));var d=u.console;d&&d.log&&d.log(e)}}function caml_sys_open_internal(_,e,u,d){caml_global_data.fds===void 0&&(caml_global_data.fds=new Array),d=d||{};var $={};return $.file=u,$.offset=d.append?u.length():0,$.flags=d,$.output=e,caml_global_data.fds[_]=$,(!caml_global_data.fd_last_idx||_>caml_global_data.fd_last_idx)&&(caml_global_data.fd_last_idx=_),_}function caml_sys_open(_,e,u){for(var d={};e;){switch(e[1]){case 0:d.rdonly=1;break;case 1:d.wronly=1;break;case 2:d.append=1;break;case 3:d.create=1;break;case 4:d.truncate=1;break;case 5:d.excl=1;break;case 6:d.binary=1;break;case 7:d.text=1;break;case 8:d.nonblock=1;break}e=e[2]}d.rdonly&&d.wronly&&caml_raise_sys_error(caml_jsbytes_of_string(_)+" : flags Open_rdonly and Open_wronly are not compatible"),d.text&&d.binary&&caml_raise_sys_error(caml_jsbytes_of_string(_)+" : flags Open_text and Open_binary are not compatible");var $=resolve_fs_device(_),w=$.device.open($.rest,d),q=caml_global_data.fd_last_idx?caml_global_data.fd_last_idx:0;return caml_sys_open_internal(q+1,caml_std_output,w,d)}caml_sys_open_internal(0,caml_std_output,new MlFakeFile(caml_create_bytes(0))),caml_sys_open_internal(1,js_print_stdout,new MlFakeFile(caml_create_bytes(0))),caml_sys_open_internal(2,js_print_stderr,new MlFakeFile(caml_create_bytes(0)));function caml_ml_open_descriptor_in(_){var e=caml_global_data.fds[_];e.flags.wronly&&caml_raise_sys_error("fd "+_+" is writeonly");var u=null;if(_==0&&fs_node_supported()){var d=require("fs");u=function(){return caml_string_of_jsstring(d.readFileSync(0,"utf8"))}}var $={file:e.file,offset:e.offset,fd:_,opened:!0,out:!1,refill:u};return caml_ml_channels[$.fd]=$,$.fd}function caml_ml_open_descriptor_out(_){var e=caml_global_data.fds[_];e.flags.rdonly&&caml_raise_sys_error("fd "+_+" is readonly");var u={file:e.file,offset:e.offset,fd:_,opened:!0,out:!0,buffer:""};return caml_ml_channels[u.fd]=u,u.fd}function caml_ml_out_channels_list(){for(var _=0,e=0;e>24&255,e>>16&255,e>>8&255,e&255],d=caml_string_of_array(u);return caml_ml_output(_,d,0,4),0}function caml_ml_pos_in(_){return caml_ml_channels[_].offset}function caml_ml_pos_in_64(_){return caml_int64_of_float(caml_ml_channels[_].offset)}function caml_ml_pos_out(_){return caml_ml_flush(_),caml_ml_channels[_].offset}function caml_ml_pos_out_64(_){return caml_ml_flush(_),caml_int64_of_float(caml_ml_channels[_].offset)}function caml_ml_seek_in(_,e){var u=caml_ml_channels[_];return u.refill!=null&&caml_raise_sys_error("Illegal seek"),u.offset=e,0}function caml_ml_seek_in_64(_,e){var u=caml_ml_channels[_];return u.refill!=null&&caml_raise_sys_error("Illegal seek"),u.offset=caml_int64_to_float(e),0}function caml_ml_seek_out(_,e){return caml_ml_flush(_),caml_ml_channels[_].offset=e,0}function caml_ml_seek_out_64(_,e){return caml_ml_flush(_),caml_ml_channels[_].offset=caml_int64_to_float(e),0}function caml_ml_set_binary_mode(_,e){var u=caml_ml_channels[_],d=caml_global_data.fds[u.fd];return d.flags.text=!e,d.flags.binary=e,0}function caml_ml_set_channel_name(){return 0}function caml_mod(_,e){return e==0&&caml_raise_zero_divide(),_%e}function caml_modf_float(_){if(isFinite(_)){var e=1/_<0;_=Math.abs(_);var u=Math.floor(_),d=_-u;return e&&(u=-u,d=-d),[0,d,u]}return isNaN(_)?[0,NaN,NaN]:[0,1/_,_]}function caml_lex_run_mem(_,e,u,d){for(;;){var $=_.charCodeAt(e);if(e++,$==255)return;var w=_.charCodeAt(e);e++,w==255?u[$+1]=d:u[$+1]=u[w+1]}}function caml_lex_run_tag(_,e,u){for(;;){var d=_.charCodeAt(e);if(e++,d==255)return;var $=_.charCodeAt(e);e++,$==255?u[d+1]=-1:u[d+1]=u[$+1]}}function caml_new_lex_engine(_,e,u){var d=2,$=3,w=5,q=6,z=7,P=8,V=9,N=10,L=1,U=2,Y=3,W=4,K=5,R=6,J=7,Q=8,X=9,Z=10,I=11;_.lex_default||(_.lex_base=caml_lex_array(_[L]),_.lex_backtrk=caml_lex_array(_[U]),_.lex_check=caml_lex_array(_[K]),_.lex_trans=caml_lex_array(_[W]),_.lex_default=caml_lex_array(_[Y])),_.lex_default_code||(_.lex_base_code=caml_lex_array(_[R]),_.lex_backtrk_code=caml_lex_array(_[J]),_.lex_check_code=caml_lex_array(_[Z]),_.lex_trans_code=caml_lex_array(_[X]),_.lex_default_code=caml_lex_array(_[Q])),_.lex_code==null&&(_.lex_code=caml_jsbytes_of_string(_[I]));var __,t_=e,e_=caml_array_of_bytes(u[d]);for(t_>=0?(u[z]=u[w]=u[q],u[P]=-1):t_=-t_-1;;){var a_=_.lex_base[t_];if(a_<0){var r_=_.lex_base_code[t_];return caml_lex_run_tag(_.lex_code,r_,u[N]),-a_-1}var n_=_.lex_backtrk[t_];if(n_>=0){var r_=_.lex_backtrk_code[t_];caml_lex_run_tag(_.lex_code,r_,u[N]),u[z]=u[q],u[P]=n_}if(u[q]>=u[$]){if(u[V]==0)return-t_-1;__=256}else __=e_[u[q]],u[q]++;var c_=t_;if(_.lex_check[a_+__]==t_?t_=_.lex_trans[a_+__]:t_=_.lex_default[t_],t_<0)if(u[q]=u[z],u[P]==-1)caml_failwith("lexing: empty token");else return u[P];else{var l_=_.lex_base_code[c_],r_;_.lex_check_code[l_+__]==c_?r_=_.lex_trans_code[l_+__]:r_=_.lex_default_code[c_],r_>0&&caml_lex_run_mem(_.lex_code,r_,u[N],u[q]),__==256&&(u[V]=0)}}}function caml_notequal(_,e){return+(caml_compare_val(_,e,!1)!=0)}function caml_obj_block(_,e){var u=new Array(e+1);u[0]=_;for(var d=1;d<=e;d++)u[d]=0;return u}function caml_obj_make_forward(_,e){return _[0]=250,_[1]=e,0}function caml_obj_tag(_){return _ instanceof Array&&_[0]==_[0]>>>0?_[0]:caml_is_ml_bytes(_)||caml_is_ml_string(_)?252:_ instanceof Function||typeof _=="function"?247:_&&_.caml_custom?255:1e3}function caml_out_channel_pos_fd(_){var e=caml_ml_channels[_];return e.offset}var MlObjectTable;typeof globalThis.WeakMap>"u"?MlObjectTable=function(){function _(e){this.objs=e}return _.prototype.get=function(e){for(var u=0;u=0;d-=8)this.chunk[this.chunk_idx++]=u>>d&255},write_at:function($,u,d){for(var $=$,w=u-8;w>=0;w-=8)this.chunk[$++]=d>>w&255},write_code:function(e,u,d){this.chunk[this.chunk_idx++]=u;for(var $=e-8;$>=0;$-=8)this.chunk[this.chunk_idx++]=d>>$&255},write_shared:function(e){e<1<<8?this.write_code(8,4,e):e<1<<16?this.write_code(16,5,e):this.write_code(32,6,e)},pos:function(){return this.chunk_idx},finalize:function(){return this.block_len=this.chunk_idx-20,this.chunk_idx=0,this.write(32,2224400062),this.write(32,this.block_len),this.write(32,this.obj_counter),this.write(32,this.size_32),this.write(32,this.size_64),this.chunk}},function(e,u){u=caml_list_to_js_array(u);var d=u.indexOf(0)!==-1,$=u.indexOf(1)!==-1;$&&globalThis.console.warn("in caml_output_val: flag Marshal.Closures is not supported.");var w=new _,q=[],z=d?null:new MlObjectTable;function P(L){if(d)return!1;var U=z.recall(L);return U?(w.write_shared(U),!0):(z.store(L),!1)}function V(L){if(L.caml_custom){if(P(L))return;var U=L.caml_custom,Y=caml_custom_ops[U],W=[0,0];if(Y.serialize||caml_invalid_argument("output_value: abstract value (Custom)"),caml_legacy_custom_code){w.write(8,18);for(var K=0;K>2),w.size_64+=2+(W[1]+7>>3)}else if(L instanceof Array&&L[0]===(L[0]|0)){if(L[0]==251&&caml_failwith("output_value: abstract value (Abstract)"),L.length>1&&P(L))return;L[0]<16&&L.length-1<8?w.write(8,128+L[0]+(L.length-1<<4)):w.write_code(32,8,L.length-1<<10|L[0]),w.size_32+=L.length,w.size_64+=L.length,L.length>1&&q.push(L,1)}else if(caml_is_ml_bytes(L)){if(caml_is_ml_bytes(caml_string_of_jsbytes(""))||caml_failwith("output_value: [Bytes.t] cannot safely be marshaled with [--enable use-js-string]"),P(L))return;var Q=caml_ml_bytes_length(L);Q<32?w.write(8,32+Q):Q<256?w.write_code(8,9,Q):w.write_code(32,10,Q);for(var K=0;K=0&&L<64?w.write(8,64+L):L>=-(1<<7)&&L<1<<7?w.write_code(8,0,L):L>=-(1<<15)&&L<1<<15?w.write_code(16,1,L):w.write_code(32,2,L)}for(V(e);q.length>0;){var N=q.pop(),e=q.pop();N+1u&&caml_failwith("Marshal.to_buffer: buffer overflow"),caml_blit_bytes(w,0,_,e,w.length),0}function caml_pallas_add(_,e){var u=plonk_wasm.caml_pallas_add(_,e);return free_on_finalize(u),u}function caml_pallas_double(_){var e=plonk_wasm.caml_pallas_double(_);return free_on_finalize(e),e}var caml_pallas_endo_base=plonk_wasm.caml_pallas_endo_base,caml_pallas_endo_scalar=plonk_wasm.caml_pallas_endo_scalar;function caml_pallas_negate(_){var e=plonk_wasm.caml_pallas_negate(_);return free_on_finalize(e),e}function caml_pallas_of_affine_coordinates(_,e){var u=plonk_wasm.caml_pallas_of_affine_coordinates(_,e);return free_on_finalize(u),u}function caml_pallas_one(){var _=plonk_wasm.caml_pallas_one();return free_on_finalize(_),_}function caml_pallas_random(){var _=plonk_wasm.caml_pallas_random();return free_on_finalize(_),_}function caml_pallas_scale(_,e){var u=plonk_wasm.caml_pallas_scale(_,e);return free_on_finalize(u),u}function caml_pallas_sub(_,e){var u=plonk_wasm.caml_pallas_sub(_,e);return free_on_finalize(u),u}function caml_pallas_to_affine(_){var e=plonk_wasm.caml_pallas_to_affine(_);return rust_affine_to_caml_affine(e)}var caml_pasta_fp_add=plonk_wasm.caml_pasta_fp_add;function caml_pasta_fp_copy(_,e){for(var u=0,d=_.length;u>>0>=caml_ml_string_length(_)&&caml_string_bound_error(),caml_string_unsafe_get(_,e)}function caml_string_get16(_,e){e>>>0>=caml_ml_string_length(_)-1&&caml_string_bound_error();var u=caml_string_unsafe_get(_,e),d=caml_string_unsafe_get(_,e+1);return d<<8|u}function caml_string_get32(_,e){e>>>0>=caml_ml_string_length(_)-3&&caml_string_bound_error();var u=caml_string_unsafe_get(_,e),d=caml_string_unsafe_get(_,e+1),$=caml_string_unsafe_get(_,e+2),w=caml_string_unsafe_get(_,e+3);return w<<24|$<<16|d<<8|u}function caml_string_get64(_,e){e>>>0>=caml_ml_string_length(_)-7&&caml_string_bound_error();for(var u=new Array(8),d=0;d<8;d++)u[7-d]=caml_string_unsafe_get(_,e+d);return caml_int64_of_bytes(u)}function caml_string_lessequal(_,e){return caml_bytes_lessequal(_,e)}function caml_string_greaterequal(_,e){return caml_string_lessequal(e,_)}function caml_string_lessthan(_,e){return caml_bytes_lessthan(_,e)}function caml_string_greaterthan(_,e){return caml_string_lessthan(e,_)}function caml_string_notequal(_,e){return 1-caml_string_equal(_,e)}var caml_argv=function(){var _=globalThis,e="a.out",u=[];if(_.process&&_.process.argv&&_.process.argv.length>1){var d=_.process.argv;e=d[1],u=d.slice(2)}for(var $=caml_string_of_jsstring(e),w=[0,$],q=0;q=0;d--)if(_.data[e+d]!=0)return d+1;return 1}function compare_nat(_,e,u,d,$,w){var q=num_digits_nat(_,e,u),z=num_digits_nat(d,$,w);if(q>z)return 1;if(q=0;P--){if(_.data[e+P]>>>0>d.data[$+P]>>>0)return 1;if(_.data[e+P]>>>0>>0)return-1}return 0}var core_array_unsafe_float_blit=caml_array_blit,core_array_unsafe_int_blit=caml_array_blit;function core_kernel_gc_minor_words(){return 0}function core_kernel_time_ns_format(_,e){var u=new Date(_*1e3),d=caml_jsbytes_of_string(e),$=joo_global_object.strftime(d,u);return caml_string_of_jsbytes($)}function caml_md5_chan(_,e){var u=caml_ml_channels[_],d=u.file.length();e<0&&(e=d-u.offset),u.offset+e>d&&caml_raise_end_of_file();var $=caml_create_bytes(e);return u.file.read(u.offset,$,0,e),caml_md5_string($,0,e)}function core_md5_fd(_){var e=caml_ml_open_descriptor_in(_);try{return caml_md5_chan(e,-1)}finally{caml_ml_close_channel(e)}}function MlNat(_){this.data=new globalThis.Int32Array(_),this.length=this.data.length+2}MlNat.prototype.caml_custom="_nat";function create_nat(_){for(var e=new MlNat(_),u=0;u<_;u++)e.data[u]=-1;return e}function custom_reraise_exn(_,e){var u=_[2];throw u instanceof globalThis.Error?u:Error(e)}function decr_nat(_,e,u,d){for(var $=d==1?0:1,w=0;w>>0)-$;if(_.data[e+w]=q,q>=0){$=0;break}else $=1}return $==1?0:1}function deferred_bind(_,e){var u={promise:_.promise.then(e).then(function(d){return d.promise}).then(function(d){return u.value=d,u.isDetermined=!0,d}).catch(function(d){throw u.error=d,u.isError=!0,u.isDetermined=!0,d}),isError:!1,isDetermined:!1};return u}function deferred_map(_,e){var u={promise:_.promise.then(e).then(function(d){return u.value=d,u.isDetermined=!0,d}).catch(function(d){throw u.error=d,u.isError=!0,u.isDetermined=!0,d}),isError:!1,isDetermined:!1};return u}function deferred_return(_){return{promise:Promise.resolve(_),value:_,isError:!1,isDetermined:!0}}function deferred_run(_){var e={promise:Promise.resolve().then(_).then(function(u){return e.value=u,e.isDetermined=!0,u}).catch(function(u){throw e.error=u,e.isError=!0,e.isDetermined=!0,u}),isError:!1,isDetermined:!1};return e}function deferred_to_promise(_){return _.promise}function deferred_upon_exn(_,e){_.promise.then(function(){e(_.value)})}function div_helper(_,e,u){var d=_*65536+(e>>>16),$=Math.floor(d/u)*65536,w=d%u*65536,q=w+(e&65535);return[$+Math.floor(q/u),q%u]}function div_digit_nat(_,e,u,d,$,w,q,z,P){for(var V=$.data[w+q-1]>>>0,N=q-2;N>=0;N--){var L=div_helper(V,$.data[w+N]>>>0,z.data[P]>>>0);_.data[e+N]=L[0],V=L[1]}return u.data[d]=V,0}function num_leading_zero_bits_in_digit(_,e){var u=_.data[e],d=0;return u&4294901760&&(d+=16,u>>>=16),u&65280&&(d+=8,u>>>=8),u&240&&(d+=4,u>>>=4),u&12&&(d+=2,u>>>=2),u&2&&(d+=1,u>>>=1),u&1&&(d+=1),32-d}function shift_left_nat(_,e,u,d,$,w){if(w==0)return d.data[$]=0,0;for(var q=0,z=0;z>>0;_.data[e+z]=P<>>32-w}return d.data[$]=q,0}function shift_right_nat(_,e,u,d,$,w){if(w==0)return d.data[$]=0,0;for(var q=0,z=u-1;z>=0;z--){var P=_.data[e+z]>>>0;_.data[e+z]=P>>>w|q,q=P<<32-w}return d.data[$]=q,0}function set_to_zero_nat(_,e,u){for(var d=0;d>>0,N=0;N>>0)+(d.data[$+N]>>>0)*(V&65535)+P,U=(d.data[$+N]>>>0)*(V>>>16);P=Math.floor(U/65536);var Y=L+U%65536*65536;_.data[e+N]=Y,P+=Math.floor(Y/4294967296)}return w>>0)-(d.data[$+P]>>>0)-z;_.data[e+P]=V,V>=0?z=0:z=1}return decr_nat(_,e+w,u-w,z==1?0:1)}function div_nat(_,e,u,d,$,w){if(w==1)return div_digit_nat(_,e+1,_,e,_,e,u,d,$),0;var q=num_leading_zero_bits_in_digit(d,$+w-1);shift_left_nat(d,$,w,nat_of_array([0]),0,q),shift_left_nat(_,e,u,nat_of_array([0]),0,q);for(var z=(d.data[$+w-1]>>>0)+1,P=create_nat(w+1),V=u-1;V>=w;V--){var N=z==4294967296?_.data[e+V]>>>0:div_helper(_.data[e+V]>>>0,_.data[e+V-1]>>>0,z)[0];for(set_to_zero_nat(P,0,w+1),mult_digit_nat(P,0,w+1,d,$,w,nat_of_array([N]),0),sub_nat(_,e+V-w,w+1,P,0,w+1,1);_.data[e+V]!=0||compare_nat(_,e+V-w,w,d,$,w)>=0;)N=N+1,sub_nat(_,e+V-w,w+1,d,$,w,1);_.data[e+V]=N}return shift_right_nat(_,e,w,nat_of_array([0]),0,q),shift_right_nat(d,$,w,nat_of_array([0]),0,q),0}var expect_test_collector_saved_stderr,expect_test_collector_saved_stdout;function expect_test_collector_after_test(_,e){return caml_ml_channels[_]=expect_test_collector_saved_stdout,caml_ml_channels[e]=expect_test_collector_saved_stderr,0}function expect_test_collector_before_test(_,e,u){expect_test_collector_saved_stderr=caml_ml_channels[u],expect_test_collector_saved_stdout=caml_ml_channels[e];var d=caml_ml_channels[_];return caml_ml_channels[e]=d,caml_ml_channels[u]=d,0}function caml_random_oracles_of_rust(_){var e=_.joint_combiner_chal,u=_.joint_combiner,d=void 0;return e!==void 0&&u!==void 0&&(d=[0,[0,e],u]),[0,caml_option_of_maybe_undefined(d),_.beta,_.gamma,[0,_.alpha_chal],_.alpha,_.zeta,_.v,_.u,[0,_.zeta_chal],[0,_.v_chal],[0,_.u_chal]]}function caml_oracles_of_rust(_){return[0,caml_random_oracles_of_rust(_.o),[0,_.p_eval0,_.p_eval1],caml_u8array_vector_of_rust_flat_vector(_.opening_prechallenges,32),_.digest_before_evaluations]}function fp_oracles_create(_,e,u){return caml_oracles_of_rust(plonk_wasm.fp_oracles_create(caml_array_to_rust_vector(_,caml_vesta_poly_comm_to_rust),caml_pasta_fp_plonk_verifier_index_to_rust(e),caml_pasta_fp_proof_to_rust(u)))}function fp_oracles_create_no_public(_,e,u){return fp_oracles_create(_,e,[0,0,u])}function fq_oracles_create(_,e,u){return caml_oracles_of_rust(plonk_wasm.fq_oracles_create(caml_array_to_rust_vector(_,caml_pallas_poly_comm_to_rust),caml_pasta_fq_plonk_verifier_index_to_rust(e),caml_pasta_fq_proof_to_rust(u)))}function fq_oracles_create_no_public(_,e,u){return fq_oracles_create(_,e,[0,0,u])}var tsBindings=globalThis.__snarkyTsBindings;function getTsBindings(){return tsBindings}function serialize_nat(_,e,u){var d=e.data.length;_.write(32,d);for(var $=0;$=d&&caml_failwith("int_of_string");var w=caml_string_unsafe_get(_,u);w===45?(u++,$=!0):w===43&&u++;var q=!0;e.hi=e.hi>>>0;for(var z=caml_int64_of_int32(10),P=e.udivmod(z).quotient,V=caml_int64_of_int32(0);u=10)break;if(q=!1,caml_int64_ult(P,V)||(N=caml_int64_of_int32(N),V=caml_int64_add(caml_int64_mul(z,V),N),caml_int64_ult(V,N)))return e}return q&&caml_failwith("int_of_string"),$&&(V=caml_int64_neg(V)),V.hi=V.hi>>>0,V}var UInt32=function(){function _(e){this.value=e>>>0}return _.prototype.caml_custom="integers:uint32",_}();function integers_uint32_of_int64(_){return new UInt32(caml_int64_to_int32(_))}function integers_uint32_of_string(_){var e=caml_int64_create_lo_mi_hi(16777215,16777215,65535);return integers_uint32_of_int64(integers_uint_of_string(_,e))}function integers_uint16_of_string(_){var e=integers_uint32_of_string(_);return e.value&65535}function integers_uint32_add(_,e){return new UInt32(_.value+e.value)}function integers_uint32_div(_,e){return new UInt32(_.value/e.value)}function integers_uint32_logand(_,e){return new UInt32(_.value&e.value)}function integers_uint32_logor(_,e){return new UInt32(_.value|e.value)}function integers_uint32_logxor(_,e){return new UInt32(_.value^e.value)}function integers_uint32_max(_){return new UInt32(4294967295)}function integers_uint32_to_int64(_){return caml_int64_create_lo_mi_hi(_.value&16777215,_.value>>>24&16777215,0)}function integers_uint32_mul(_,e){var u=integers_uint32_to_int64(_),d=integers_uint32_to_int64(e);return new UInt32(caml_int64_to_int32(caml_int64_mul(u,d)))}function integers_uint32_of_int(_){return new UInt32(_)}function integers_uint32_of_int32(_){return new UInt32(_)}function integers_uint32_rem(_,e){return e.value==0&&caml_raise_zero_divide(),new UInt32(_.value%e.value)}function integers_uint32_shift_left(_,e){return new UInt32(_.value<>>e)}function integers_uint32_sub(_,e){return new UInt32(_.value-e.value)}function integers_uint32_to_int(_){return _.value|0}function caml_new_string(_){return caml_string_of_jsbytes(_)}function integers_uint32_to_string(_){return caml_new_string(_.value.toString())}var UInt64=function(){function _(e){this.value=e}return _.prototype.caml_custom="integers:uint64",_}();function integers_uint64_add(_,e){return new UInt64(caml_int64_add(_.value,e.value))}function integers_uint64_div(_,e){return e.value.isZero()&&caml_raise_zero_divide(),_.value.hi=_.value.hi>>>0,e.value.hi=e.value.hi>>>0,new UInt64(_.value.udivmod(e.value).quotient)}function integers_uint64_logand(_,e){return new UInt64(caml_int64_and(_.value,e.value))}function integers_uint64_logor(_,e){return new UInt64(caml_int64_or(_.value,e.value))}function integers_uint64_logxor(_,e){return new UInt64(caml_int64_xor(_.value,e.value))}function integers_uint64_max(_){var e=caml_int64_create_lo_mi_hi(16777215,16777215,65535);return e.hi=e.hi>>>0,new UInt64(e)}function integers_uint64_mul(_,e){return new UInt64(caml_int64_mul(_.value,e.value))}function integers_uint64_of_int(_){return new UInt64(caml_int64_of_int32(_))}function integers_uint64_of_int64(_){return new UInt64(caml_int64_create_lo_mi_hi(_.lo,_.mi,_.hi>>>0))}function integers_uint64_of_string(_){var e=caml_int64_create_lo_mi_hi(16777215,16777215,65535);return new UInt64(integers_uint_of_string(_,e))}function integers_uint64_of_uint32(_){return new UInt64(caml_int64_of_int32(_))}function integers_uint64_rem(_,e){return e.value.isZero()&&caml_raise_zero_divide(),_.value.hi=_.value.hi>>>0,e.value.hi=e.value.hi>>>0,new UInt64(_.value.udivmod(e.value).modulus)}function integers_uint64_shift_left(_,e){return new UInt64(caml_int64_shift_left(_.value,e))}function integers_uint64_shift_right(_,e){return new UInt64(caml_int64_shift_right_unsigned(_.value,e))}function integers_uint64_sub(_,e){return new UInt64(caml_int64_sub(_.value,e.value))}function integers_uint64_to_int(_){return caml_int64_to_int32(_.value)}function integers_uint64_to_int64(_){return _=_.value,caml_int64_create_lo_mi_hi(_.lo,_.mi,_.hi|0)}function integers_uint64_to_string(_){return caml_int64_format(caml_new_string("%u"),_.value)}function integers_uint8_of_string(_){var e=integers_uint32_of_string(_);return _.value&255}function integers_uint_size(_){return 4}function integers_ulong_size(_){return 4}function integers_ulonglong_size(_){return 8}function integers_uint8_deserialize(_,e){return e[0]=1,_.read8u()}function integers_uint16_deserialize(_,e){return e[0]=2,_.read16u()}function integers_uint32_serialize(_,e,u){_.write(32,e.value),u[0]=4,u[1]=4}function integers_uint32_deserialize(_,e){return e[0]=4,new UInt32(_.read32u())}function integers_uint32_hash(_){return _.value}function integers_uint32_compare(_,e){return _.value>e.value?1:_.value>>0,e.value.hi=e.value.hi>>>0,_.value.ucompare(e.value)}function integers_uint64_hash(_){return caml_int64_hash(_.value)}function integers_uint64_marshal(_,e,u){caml_int64_marshal(_,e.value,u)}function integers_uint64_unmarshal(_,e){return new UInt64(caml_int64_unmarshal(_,e))}function integers_unsigned_init(_){return caml_custom_ops["integers:uint8"]={deserialize:integers_uint8_deserialize,fixed_length:1},caml_custom_ops["integers:uint16"]={deserialize:integers_uint16_deserialize,fixed_length:2},caml_custom_ops["integers:uint32"]={serialize:integers_uint32_serialize,deserialize:integers_uint32_deserialize,fixed_length:4,hash:integers_uint32_hash,compare:integers_uint32_compare},caml_custom_ops["integers:uint64"]={serialize:integers_uint64_marshal,deserialize:integers_uint64_unmarshal,hash:integers_uint64_hash,compare:integers_uint64_compare},_}function integers_ushort_size(_){return 4}function is_digit_int(_,e){return _.data[e]>=0?1:0}function is_digit_zero(_,e){return _.data[e]==0?1:0}function land_digit_nat(_,e,u,d){return _.data[e]&=u.data[d],0}function lor_digit_nat(_,e,u,d){return _.data[e]|=u.data[d],0}var bigInt=function(_){"use strict";var e=1e7,u=7,d=9007199254740992,$=Y(d),w="0123456789abcdefghijklmnopqrstuvwxyz",q=joo_global_object.BigInt,z=typeof q=="function";function P(k_,z_,v_,U_){return typeof k_>"u"?P[0]:typeof z_<"u"?+z_==10&&!v_?B_(k_):W_(k_,z_,v_,U_):B_(k_)}function V(k_,z_){this.value=k_,this.sign=z_,this.isSmall=!1,this.caml_custom="_z"}V.prototype=Object.create(P.prototype);function N(k_){this.value=k_,this.sign=k_<0,this.isSmall=!0,this.caml_custom="_z"}N.prototype=Object.create(P.prototype);function L(k_){this.value=k_,this.caml_custom="_z"}L.prototype=Object.create(P.prototype);function U(k_){return-d0?Math.floor(k_):Math.ceil(k_)}function Q(k_,z_){var v_=k_.length,U_=z_.length,R_=new Array(v_),K_=0,Q_=e,Y_,Z_;for(Z_=0;Z_=Q_?1:0,R_[Z_]=Y_-K_*Q_;for(;Z_0&&R_.push(K_),R_}function X(k_,z_){return k_.length>=z_.length?Q(k_,z_):Q(z_,k_)}function Z(k_,z_){var v_=k_.length,U_=new Array(v_),R_=e,K_,Q_;for(Q_=0;Q_0;)U_[Q_++]=z_%R_,z_=Math.floor(z_/R_);return U_}V.prototype.add=function(k_){var z_=B_(k_);if(this.sign!==z_.sign)return this.subtract(z_.negate());var v_=this.value,U_=z_.value;return z_.isSmall?new V(Z(v_,Math.abs(U_)),this.sign):new V(X(v_,U_),this.sign)},V.prototype.plus=V.prototype.add,N.prototype.add=function(k_){var z_=B_(k_),v_=this.value;if(v_<0!==z_.sign)return this.subtract(z_.negate());var U_=z_.value;if(z_.isSmall){if(U(v_+U_))return new N(v_+U_);U_=Y(Math.abs(U_))}return new V(Z(U_,Math.abs(v_)),v_<0)},N.prototype.plus=N.prototype.add,L.prototype.add=function(k_){return new L(this.value+B_(k_).value)},L.prototype.plus=L.prototype.add;function I(k_,z_){var v_=k_.length,U_=z_.length,R_=new Array(v_),K_=0,Q_=e,Y_,Z_;for(Y_=0;Y_=0?U_=I(k_,z_):(U_=I(z_,k_),v_=!v_),U_=W(U_),typeof U_=="number"?(v_&&(U_=-U_),new N(U_)):new V(U_,v_)}function t_(k_,z_,v_){var U_=k_.length,R_=new Array(U_),K_=-z_,Q_=e,Y_,Z_;for(Y_=0;Y_=0)},N.prototype.minus=N.prototype.subtract,L.prototype.subtract=function(k_){return new L(this.value-B_(k_).value)},L.prototype.minus=L.prototype.subtract,V.prototype.negate=function(){return new V(this.value,!this.sign)},N.prototype.negate=function(){var k_=this.sign,z_=new N(-this.value);return z_.sign=!k_,z_},L.prototype.negate=function(){return new L(-this.value)},V.prototype.abs=function(){return new V(this.value,!1)},N.prototype.abs=function(){return new N(Math.abs(this.value))},L.prototype.abs=function(){return new L(this.value>=0?this.value:-this.value)};function e_(k_,z_){var v_=k_.length,U_=z_.length,R_=v_+U_,K_=R(R_),Q_=e,Y_,Z_,_0,a0,I_;for(_0=0;_00;)U_[Y_++]=K_%R_,K_=Math.floor(K_/R_);return U_}function r_(k_,z_){for(var v_=[];z_-- >0;)v_.push(0);return v_.concat(k_)}function n_(k_,z_){var v_=Math.max(k_.length,z_.length);if(v_<=30)return e_(k_,z_);v_=Math.ceil(v_/2);var U_=k_.slice(v_),R_=k_.slice(0,v_),K_=z_.slice(v_),Q_=z_.slice(0,v_),Y_=n_(R_,Q_),Z_=n_(U_,K_),_0=n_(X(R_,U_),X(Q_,K_)),a0=X(X(Y_,r_(I(I(_0,Y_),Z_),v_)),r_(Z_,2*v_));return K(a0),a0}function c_(k_,z_){return-(.012*k_)-.012*z_+15e-6*k_*z_>0}V.prototype.multiply=function(k_){var z_=B_(k_),v_=this.value,U_=z_.value,R_=this.sign!==z_.sign,K_;if(z_.isSmall){if(U_===0)return P[0];if(U_===1)return this;if(U_===-1)return this.negate();if(K_=Math.abs(U_),K_=0;I_--){for(a0=R_-1,Z_[I_+U_]!==Q_&&(a0=Math.floor((Z_[I_+U_]*R_+Z_[I_+U_-1])/Q_)),X_=0,c0=0,d0=_0.length,l0=0;l0U_&&(_0=(_0+1)*Q_),Y_=Math.ceil(_0/a0);do{if(I_=a_(z_,Y_),b_(I_,K_)<=0)break;Y_--}while(Y_);R_.push(Y_),K_=I(K_,I_)}return R_.reverse(),[W(R_),W(K_)]}function u_(k_,z_){var v_=k_.length,U_=R(v_),R_=e,K_,Q_,Y_,Z_;for(Y_=0,K_=v_-1;K_>=0;--K_)Z_=Y_*R_+k_[K_],Q_=J(Z_/z_),Y_=Z_-Q_*z_,U_[K_]=Q_|0;return[U_,Y_|0]}function x_(k_,z_){var v_,U_=B_(z_);if(z)return[new L(k_.value/U_.value),new L(k_.value%U_.value)];var R_=k_.value,K_=U_.value,Q_;if(K_===0)throw new Error("Cannot divide by zero");if(k_.isSmall)return U_.isSmall?[new N(J(R_/K_)),new N(R_%K_)]:[P[0],k_];if(U_.isSmall){if(K_===1)return[k_,P[0]];if(K_==-1)return[k_.negate(),P[0]];var Y_=Math.abs(K_);if(Y_z_.length?1:-1;for(var v_=k_.length-1;v_>=0;v_--)if(k_[v_]!==z_[v_])return k_[v_]>z_[v_]?1:-1;return 0}V.prototype.compareAbs=function(k_){var z_=B_(k_),v_=this.value,U_=z_.value;return z_.isSmall?1:b_(v_,U_)},N.prototype.compareAbs=function(k_){var z_=B_(k_),v_=Math.abs(this.value),U_=z_.value;return z_.isSmall?(U_=Math.abs(U_),v_===U_?0:v_>U_?1:-1):-1},L.prototype.compareAbs=function(k_){var z_=this.value,v_=B_(k_).value;return z_=z_>=0?z_:-z_,v_=v_>=0?v_:-v_,z_===v_?0:z_>v_?1:-1},V.prototype.compare=function(k_){if(k_===1/0)return-1;if(k_===-1/0)return 1;var z_=B_(k_),v_=this.value,U_=z_.value;return this.sign!==z_.sign?z_.sign?1:-1:z_.isSmall?this.sign?-1:1:b_(v_,U_)*(this.sign?-1:1)},V.prototype.compareTo=V.prototype.compare,N.prototype.compare=function(k_){if(k_===1/0)return-1;if(k_===-1/0)return 1;var z_=B_(k_),v_=this.value,U_=z_.value;return z_.isSmall?v_==U_?0:v_>U_?1:-1:v_<0!==z_.sign?v_<0?-1:1:v_<0?1:-1},N.prototype.compareTo=N.prototype.compare,L.prototype.compare=function(k_){if(k_===1/0)return-1;if(k_===-1/0)return 1;var z_=this.value,v_=B_(k_).value;return z_===v_?0:z_>v_?1:-1},L.prototype.compareTo=L.prototype.compare,V.prototype.equals=function(k_){return this.compare(k_)===0},L.prototype.eq=L.prototype.equals=N.prototype.eq=N.prototype.equals=V.prototype.eq=V.prototype.equals,V.prototype.notEquals=function(k_){return this.compare(k_)!==0},L.prototype.neq=L.prototype.notEquals=N.prototype.neq=N.prototype.notEquals=V.prototype.neq=V.prototype.notEquals,V.prototype.greater=function(k_){return this.compare(k_)>0},L.prototype.gt=L.prototype.greater=N.prototype.gt=N.prototype.greater=V.prototype.gt=V.prototype.greater,V.prototype.lesser=function(k_){return this.compare(k_)<0},L.prototype.lt=L.prototype.lesser=N.prototype.lt=N.prototype.lesser=V.prototype.lt=V.prototype.lesser,V.prototype.greaterOrEquals=function(k_){return this.compare(k_)>=0},L.prototype.geq=L.prototype.greaterOrEquals=N.prototype.geq=N.prototype.greaterOrEquals=V.prototype.geq=V.prototype.greaterOrEquals,V.prototype.lesserOrEquals=function(k_){return this.compare(k_)<=0},L.prototype.leq=L.prototype.lesserOrEquals=N.prototype.leq=N.prototype.lesserOrEquals=V.prototype.leq=V.prototype.lesserOrEquals,V.prototype.isEven=function(){return(this.value[0]&1)===0},N.prototype.isEven=function(){return(this.value&1)===0},L.prototype.isEven=function(){return(this.value&q(1))===q(0)},V.prototype.isOdd=function(){return(this.value[0]&1)===1},N.prototype.isOdd=function(){return(this.value&1)===1},L.prototype.isOdd=function(){return(this.value&q(1))===q(1)},V.prototype.isPositive=function(){return!this.sign},N.prototype.isPositive=function(){return this.value>0},L.prototype.isPositive=N.prototype.isPositive,V.prototype.isNegative=function(){return this.sign},N.prototype.isNegative=function(){return this.value<0},L.prototype.isNegative=N.prototype.isNegative,V.prototype.isUnit=function(){return!1},N.prototype.isUnit=function(){return Math.abs(this.value)===1},L.prototype.isUnit=function(){return this.abs().value===q(1)},V.prototype.isZero=function(){return!1},N.prototype.isZero=function(){return this.value===0},L.prototype.isZero=function(){return this.value===q(0)},V.prototype.isDivisibleBy=function(k_){var z_=B_(k_);return z_.isZero()?!1:z_.isUnit()?!0:z_.compareAbs(2)===0?this.isEven():this.mod(z_).isZero()},L.prototype.isDivisibleBy=N.prototype.isDivisibleBy=V.prototype.isDivisibleBy;function y_(k_){var z_=k_.abs();if(z_.isUnit())return!1;if(z_.equals(2)||z_.equals(3)||z_.equals(5))return!0;if(z_.isEven()||z_.isDivisibleBy(3)||z_.isDivisibleBy(5))return!1;if(z_.lesser(49))return!0}function d_(k_,z_){for(var v_=k_.prev(),U_=v_,R_=0,K_,Q_,Y_,Z_;U_.isEven();)U_=U_.divide(2),R_++;_:for(Y_=0;Y_-d?new N(k_-1):new V($,!0)},L.prototype.prev=function(){return new L(this.value-q(1))};for(var p_=[1];2*p_[p_.length-1]<=e;)p_.push(2*p_[p_.length-1]);var $_=p_.length,w_=p_[$_-1];function j_(k_){return Math.abs(k_)<=e}V.prototype.shiftLeft=function(k_){var z_=B_(k_).toJSNumber();if(!j_(z_))throw new Error(String(z_)+" is too large for shifting.");if(z_<0)return this.shiftRight(-z_);var v_=this;if(v_.isZero())return v_;for(;z_>=$_;)v_=v_.multiply(w_),z_-=$_-1;return v_.multiply(p_[z_])},L.prototype.shiftLeft=N.prototype.shiftLeft=V.prototype.shiftLeft,V.prototype.shiftRight=function(k_){var z_,v_=B_(k_).toJSNumber();if(!j_(v_))throw new Error(String(v_)+" is too large for shifting.");if(v_<0)return this.shiftLeft(-v_);for(var U_=this;v_>=$_;){if(U_.isZero()||U_.isNegative()&&U_.isUnit())return U_;z_=x_(U_,w_),U_=z_[1].isNegative()?z_[0].prev():z_[0],v_-=$_-1}return z_=x_(U_,p_[v_]),z_[1].isNegative()?z_[0].prev():z_[0]},L.prototype.shiftRight=N.prototype.shiftRight=V.prototype.shiftRight;function M_(k_,z_,v_){z_=B_(z_);for(var U_=k_.isNegative(),R_=z_.isNegative(),K_=U_?k_.not():k_,Q_=R_?z_.not():z_,Y_=0,Z_=0,_0=null,a0=null,I_=[];!K_.isZero()||!Q_.isZero();)_0=x_(K_,w_),Y_=_0[1].toJSNumber(),U_&&(Y_=w_-1-Y_),a0=x_(Q_,w_),Z_=a0[1].toJSNumber(),R_&&(Z_=w_-1-Z_),K_=_0[0],Q_=a0[0],I_.push(v_(Y_,Z_));for(var X_=v_(U_?1:0,R_?1:0)!==0?bigInt(-1):bigInt(0),c0=I_.length-1;c0>=0;c0-=1)X_=X_.multiply(w_).add(bigInt(I_[c0]));return X_}V.prototype.not=function(){return this.negate().prev()},L.prototype.not=N.prototype.not=V.prototype.not,V.prototype.and=function(k_){return M_(this,k_,function(z_,v_){return z_&v_})},L.prototype.and=N.prototype.and=V.prototype.and,V.prototype.or=function(k_){return M_(this,k_,function(z_,v_){return z_|v_})},L.prototype.or=N.prototype.or=V.prototype.or,V.prototype.xor=function(k_){return M_(this,k_,function(z_,v_){return z_^v_})},L.prototype.xor=N.prototype.xor=V.prototype.xor;var D_=1<<30,A_=(e&-e)*(e&-e)|D_;function O_(k_){var z_=k_.value,v_=typeof z_=="number"?z_|D_:typeof z_=="bigint"?z_|q(D_):z_[0]+z_[1]*e|A_;return v_&-v_}function E_(k_,z_){if(z_.compareTo(k_)<=0){var v_=E_(k_,z_.square(z_)),U_=v_.p,R_=v_.e,K_=U_.multiply(z_);return K_.compareTo(k_)<=0?{p:K_,e:R_*2+1}:{p:U_,e:R_*2}}return{p:bigInt(1),e:0}}V.prototype.bitLength=function(){var k_=this;return k_.compareTo(bigInt(0))<0&&(k_=k_.negate().subtract(bigInt(1))),k_.compareTo(bigInt(0))===0?bigInt(0):bigInt(E_(k_,bigInt(2)).e).add(bigInt(1))},L.prototype.bitLength=N.prototype.bitLength=V.prototype.bitLength;function L_(k_,z_){return k_=B_(k_),z_=B_(z_),k_.greater(z_)?k_:z_}function V_(k_,z_){return k_=B_(k_),z_=B_(z_),k_.lesser(z_)?k_:z_}function C_(k_,z_){if(k_=B_(k_).abs(),z_=B_(z_).abs(),k_.equals(z_))return k_;if(k_.isZero())return z_;if(z_.isZero())return k_;for(var v_=P[1],U_,R_;k_.isEven()&&z_.isEven();)U_=V_(O_(k_),O_(z_)),k_=k_.divide(U_),z_=z_.divide(U_),v_=v_.multiply(U_);for(;k_.isEven();)k_=k_.divide(O_(k_));do{for(;z_.isEven();)z_=z_.divide(O_(z_));k_.greater(z_)&&(R_=z_,z_=k_,k_=R_),z_=z_.subtract(k_)}while(!z_.isZero());return v_.isUnit()?k_:k_.multiply(v_)}function H_(k_,z_){return k_=B_(k_).abs(),z_=B_(z_).abs(),k_.divide(C_(k_,z_)).multiply(z_)}function F_(k_,z_){k_=B_(k_),z_=B_(z_);var v_=V_(k_,z_),U_=L_(k_,z_),R_=U_.subtract(v_).add(1);if(R_.isSmall)return v_.add(Math.floor(Math.random()*R_));for(var K_=T_(R_,e).value,Q_=[],Y_=!0,Z_=0;Z_=Q_){if(Z_==="1"&&Q_===1)continue;throw new Error(Z_+" is not a valid digit in base "+z_+".")}}z_=B_(z_);var _0=[],a0=k_[0]==="-";for(K_=a0?1:0;K_"&&K_=0;K_--)U_=U_.add(k_[K_].times(R_)),R_=R_.times(z_);return v_?U_.negate():U_}function h_(k_,z_){return z_=z_||w,k_"}function T_(k_,z_){if(z_=bigInt(z_),z_.isZero()){if(k_.isZero())return{value:[0],isNegative:!1};throw new Error("Cannot convert nonzero numbers to base 0.")}if(z_.equals(-1)){if(k_.isZero())return{value:[0],isNegative:!1};if(k_.isNegative())return{value:[].concat.apply([],Array.apply(null,Array(-k_.toJSNumber())).map(Array.prototype.valueOf,[1,0])),isNegative:!1};var v_=Array.apply(null,Array(k_.toJSNumber()-1)).map(Array.prototype.valueOf,[0,1]);return v_.unshift([1]),{value:[].concat.apply([],v_),isNegative:!1}}var U_=!1;if(k_.isNegative()&&z_.isPositive()&&(U_=!0,k_=k_.abs()),z_.isUnit())return k_.isZero()?{value:[0],isNegative:!1}:{value:Array.apply(null,Array(k_.toJSNumber())).map(Number.prototype.valueOf,1),isNegative:U_};for(var R_=[],K_=k_,Q_;K_.isNegative()||K_.compareAbs(z_)>=0;){Q_=K_.divmod(z_),K_=Q_.quotient;var Y_=Q_.remainder;Y_.isNegative()&&(Y_=z_.minus(Y_).abs(),K_=K_.next()),R_.push(Y_.toJSNumber())}return R_.push(K_.toJSNumber()),{value:R_.reverse(),isNegative:U_}}function g_(k_,z_,v_){var U_=T_(k_,z_);return(U_.isNegative?"-":"")+U_.value.map(function(R_){return h_(R_,v_)}).join("")}V.prototype.toArray=function(k_){return T_(this,k_)},N.prototype.toArray=function(k_){return T_(this,k_)},L.prototype.toArray=function(k_){return T_(this,k_)},V.prototype.toString=function(k_,z_){if(k_===_&&(k_=10),k_!==10)return g_(this,k_,z_);for(var v_=this.value,U_=v_.length,R_=String(v_[--U_]),K_="0000000",Q_;--U_>=0;)Q_=String(v_[U_]),R_+=K_.slice(Q_.length)+Q_;var Y_=this.sign?"-":"";return Y_+R_},N.prototype.toString=function(k_,z_){return k_===_&&(k_=10),k_!=10?g_(this,k_,z_):String(this.value)},L.prototype.toString=N.prototype.toString,L.prototype.toJSON=V.prototype.toJSON=N.prototype.toJSON=function(){return this.toString()},V.prototype.valueOf=function(){return parseInt(this.toString(),10)},V.prototype.toJSNumber=V.prototype.valueOf,N.prototype.valueOf=function(){return this.value},N.prototype.toJSNumber=N.prototype.valueOf,L.prototype.valueOf=L.prototype.toJSNumber=function(){return parseInt(this.toString(),10)};function P_(k_){if(U(+k_)){var z_=+k_;if(z_===J(z_))return z?new L(q(z_)):new N(z_);throw new Error("Invalid integer: "+k_)}var v_=k_[0]==="-";v_&&(k_=k_.slice(1));var U_=k_.split(/e/i);if(U_.length>2)throw new Error("Invalid integer: "+U_.join("e"));if(U_.length===2){var R_=U_[1];if(R_[0]==="+"&&(R_=R_.slice(1)),R_=+R_,R_!==J(R_)||!U(R_))throw new Error("Invalid integer: "+R_+" is not a valid exponent.");var K_=U_[0],Q_=K_.indexOf(".");if(Q_>=0&&(R_-=K_.length-Q_-1,K_=K_.slice(0,Q_)+K_.slice(Q_+1)),R_<0)throw new Error("Cannot include negative exponent part for integers");K_+=new Array(R_+1).join("0"),k_=K_}var Y_=/^([0-9][0-9]*)$/.test(k_);if(!Y_)throw new Error("Invalid integer: "+k_);if(z)return new L(q(v_?"-"+k_:k_));for(var Z_=[],_0=k_.length,a0=u,I_=_0-a0;_0>0;)Z_.push(+k_.slice(I_,_0)),I_-=a0,I_<0&&(I_=0),_0-=a0;return K(Z_),new V(Z_,v_)}function S_(k_){if(z)return new L(q(k_));if(U(k_)){if(k_!==J(k_))throw new Error(k_+" is not an integer.");return new N(k_)}return P_(k_.toString())}function B_(k_){return typeof k_=="number"?S_(k_):typeof k_=="string"?P_(k_):typeof k_=="bigint"?new L(k_):k_}for(var G_=0;G_<1e3;G_++)P[G_]=B_(G_),G_>0&&(P[-G_]=B_(-G_));return P.one=P[1],P.zero=P[0],P.minusOne=P[-1],P.max=L_,P.min=V_,P.gcd=C_,P.lcm=H_,P.isInstance=function(k_){return k_ instanceof V||k_ instanceof N||k_ instanceof L},P.randBetween=F_,P.fromArray=function(k_,z_,v_){return q_(k_.map(B_),B_(z_||10),v_)},P}();function ml_z_normalize(_){var e=_.toJSNumber()|0;return _.equals(bigInt(e))?e:_}function ml_z_abs(_){return ml_z_normalize(bigInt(_).abs())}function ml_z_add(_,e){return ml_z_normalize(bigInt(_).add(bigInt(e)))}function ml_z_compare(_,e){return bigInt(_).compare(bigInt(e))}function ml_z_div(_,e){return e=bigInt(e),e.equals(bigInt(0))&&caml_raise_zero_divide(),ml_z_normalize(bigInt(_).divide(bigInt(e)))}function ml_z_divexact(_,e){return ml_z_div(_,e)}function ml_z_equal(_,e){return bigInt(_).equals(bigInt(e))}function ml_z_fits_int(_){return _==(_|0)?1:0}function ml_z_fits_int32(_){return ml_z_fits_int(_)}function ml_z_format(u,e){e=bigInt(e);for(var u=caml_jsbytes_of_string(u),d=10,$=0,w=0,q=0,z=0,P="",V=" ",N=0,L="";u[N]=="%";)N++;for(;;N++)if(u[N]=="#")q=1;else if(u[N]=="0")V="0";else if(u[N]=="-")z=1;else if(u[N]==" "||u[N]=="+")P=u[N];else break;for(e.lt(bigInt(0))&&(P="-",e=e.negate());u[N]>="0"&&u[N]<="9";N++)w=10*w+ +u[N];switch(u[N]){case"i":case"d":case"u":break;case"b":d=2,q&&(L="0b");break;case"o":d=8,q&&(L="0o");break;case"x":d=16,q&&(L="0x");break;case"X":d=16,q&&(L="0X"),$=1;break;default:caml_failwith("Unsupported format '"+u+"'")}z&&(V=" ");var U=e.toString(d);$===1&&(U=U.toUpperCase());var Y=U.length;if(V==" ")if(z)for(U=P+L+U;U.length=0;q--)_.write(8,d.value[q]>>>0&255),_.write(8,d.value[q]>>>8&255),_.write(8,d.value[q]>>>16&255),_.write(8,d.value[q]>>>24&255);u[0]=4*(1+((w+3)/4|0)),u[1]=8*(1+((w+7)/8|0))}function caml_zarith_unmarshal(_,e){var u;switch(_.read8u()){case 1:u=!0;break;case 0:u=!1;break;default:caml_failwith("input_value: z (malformed input)")}for(var d=_.read32u(),$=bigInt(0),w=0;w>>0),$=q.shiftLeft(w*32).add($)}return u&&($=$.negate()),e[0]=d+4,ml_z_normalize($)}function ml_z_init(_){return caml_custom_ops._z={serialize:caml_zarith_marshal,deserialize:caml_zarith_unmarshal,hash:ml_z_hash,compare:ml_z_compare},0}function ml_z_logand(_,e){return ml_z_normalize(bigInt(_).and(bigInt(e)))}function ml_z_lognot(_){return ml_z_normalize(bigInt(_).not())}function ml_z_logor(_,e){return ml_z_normalize(bigInt(_).or(bigInt(e)))}function ml_z_logxor(_,e){return ml_z_normalize(bigInt(_).xor(bigInt(e)))}function ml_z_mul(_,e){return ml_z_normalize(bigInt(_).multiply(bigInt(e)))}function ml_z_neg(_){return ml_z_normalize(bigInt(_).negate())}function ml_z_numbits(_){_=bigInt(_).abs();for(var e=0,u=bigInt.one;u.leq(_);)e+=1,u=u.multiply(2);return e}function ml_z_of_bits(_){for(var e=bigInt.zero,u=bigInt(256),d=bigInt.one,$=0;$>>0,d=caml_int64_hi32(_)>>>0,$=bigInt(u).add(bigInt(d).shiftLeft(32));return e&&($=$.negate()),ml_z_normalize($)}function ml_z_of_nativeint(_){return ml_z_of_int(_)}function jsoo_z_of_js_string_base(_,e){if(_==0){_=10;var u=0,d=1;if(e[u]=="-"?(d=-1,u++):e[u]=="+"&&u++,e[u]=="0"){if(u++,e.length==u)return 0;var $=e[u];$=="o"||$=="O"?_=8:$=="x"||$=="X"?_=16:($=="b"||$=="B")&&(_=2),_!=10&&(e=e.substring(u+1),d==-1&&(e="-"+e))}}e[0]=="+"&&(e=e.substring(1)),e=e.replace(/^0+/,""),(e=="-"||e=="")&&(e="0");function w(P){if(P>=48&&P<=57)return P-48;if(P>=97&&P<=102)return P-97+10;if(P>=65&&P<=70)return P-65+10}var q=0;for(e[q]=="-"&&q++;q=_)&&caml_invalid_argument("Z.of_substring_base: invalid digit")}return ml_z_normalize(bigInt(e,_))}function ml_z_of_substring_base(_,e,u,d){return e=caml_jsbytes_of_string(e),(u!=0||d!=e.length)&&(e.length-u=0?1:0}function ml_z_to_int64(_){_=bigInt(_),ml_z_fits_int64(_)||caml_raise_constant(caml_named_value("ml_z_overflow"));var e=bigInt(4294967295),u=_.and(e).toJSNumber(),d=_.shiftRight(32).and(e).toJSNumber(),$=caml_int64_create_lo_hi(u,d);return $}function ml_z_to_nativeint(_){return ml_z_to_int(_)}function mult_nat(_,e,u,d,$,w,q,z,P){for(var V=0,N=0;N"),null$3=caml_string_of_jsbytes(""),tp_loc$0=caml_string_of_jsbytes("shape/src/bin_shape.ml.Sorted_table.t"),tp_loc$1=caml_string_of_jsbytes("shape/src/bin_shape.ml.Canonical_exp_constructor.t"),tp_loc$2=caml_string_of_jsbytes("shape/src/bin_shape.ml.Canonical_full.Exp1.t0"),loc$0=caml_string_of_jsbytes("blit_buf_string"),loc=caml_string_of_jsbytes("blit_string_buf"),enable_everything=[0,0,0],am_running_inline_test_env_var=caml_string_of_jsbytes("TESTING_FRAMEWORK"),flags=[0,0,0],flags$0=[0,1,[0,3,0]],am_recording_environment_varia=caml_string_of_jsbytes("PPX_MODULE_TIMER"),name$2=caml_string_of_jsbytes("int"),name$3=caml_string_of_jsbytes("int32"),name$4=caml_string_of_jsbytes("int64"),name$5=caml_string_of_jsbytes("nativeint"),name$6=caml_string_of_jsbytes("char"),name$7=caml_string_of_jsbytes("float"),name$8=caml_string_of_jsbytes("string"),name$9=caml_string_of_jsbytes("bytes"),name$10=caml_string_of_jsbytes("bool"),name$11=caml_string_of_jsbytes("unit"),name$12=caml_string_of_jsbytes("option"),name$13=caml_string_of_jsbytes("list"),name$14=caml_string_of_jsbytes("array"),name$15=caml_string_of_jsbytes("lazy_t"),name$16=caml_string_of_jsbytes("ref"),name$17=caml_string_of_jsbytes("function"),name$18=caml_string_of_jsbytes("tuple0"),name$19=caml_string_of_jsbytes("tuple2"),name$20=caml_string_of_jsbytes("tuple3"),name$21=caml_string_of_jsbytes("tuple4"),name$22=caml_string_of_jsbytes("tuple5"),ocaml_lex_tables$0=[0,caml_string_of_jsbytes(`\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\xFF\xFF\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0 \0\0\0\0\0\f\0\0\0\0\0\0\0\0\x1B\0\0\0\0\0U\0\xFD\xFF\xFE\xFF\0.\0/\0(\0\0.\x000\0\x07\0O\0\0>\0\b\0\xFF\xFF \0C\0C\0g\0d\0i\0_\0k\0_\0q\0 \0h\0h\0t\0h\0z\0h\0t\0o\0q\0\v\0t\0u\0}\0\x7F\0\f\0~\0s\0w\0z\0\r\0`),caml_string_of_jsbytes("\0\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\0\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF"),caml_string_of_jsbytes("\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\0\0\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF/\0\0\0\0\0\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\0\0\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF"),caml_string_of_jsbytes(`\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\b\0\f\0\0\0\f\0'\0\f\x007\0;\0=\0G\0;\0V\0;\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\x000\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\x001\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"\0\0\0\x07\0\0 \0 \0\0\0\0\0\0\0\x1B\0\0\0\0\0\0\v\0\0\0\0\0\r\0\0 \0!\0#\0$\0%\0&\0(\0)\0*\0+\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0Q\x002\x003\x004\x005\x006\0<\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\x009\x008\0:\0>\0.\0?\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0.\0@\0A\0B\0C\0D\0E\0F\0H\0I\0J\0K\0L\0M\0N\0O\0P\0R\0S\0T\0U\0W\0X\0Y\0Z\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0-\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0`),caml_string_of_jsbytes(`\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\x07\0\v\0\r\0\0!\0&\0+\x006\0:\0<\0F\0P\0U\0Z\0\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\0\0/\0\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\0\0/\0\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\0\0\0\0\0\b\0\b\0\0\0\0\0\0\0\0\0\0\0\0\0